Text & HTML
Text
¶
You can add short or long-form Markdown content to your app with the Text
block.
Info
Markdown is a lightweight markup language that allows you to include formatted text in your app, and can be accessed through dp.Text
, or by passing in a string directly.
Check here for more information on how to format your text with markdown.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
text |
str
|
The markdown formatted text, use triple-quotes, ( |
None
|
file |
NPath
|
Path to a file containing markdown text |
None
|
name |
BlockId
|
A unique name for the block to reference when adding text or embedding (optional) |
None
|
label |
str
|
A label used when displaying the block (optional) |
None
|
Note
File encodings are auto-detected, if this fails please read the file manually with an explicit encoding and use the text parameter on dp.Attachment
¶
Simple Text from Markdown¶
Multi-line Text¶
To include multi-line text and formatting the words, use triple-quoted string, e.g. """Some words"""
md = """Quas *diva coeperat usum*; suisque, ab alii, prato. Et cornua frontes puerum,
referam vocassent **umeris**. Dies nec suorum alis adstitit, *temeraria*,
anhelis aliis lacunabant quoque adhuc spissatus illum refugam perterrita in
sonus. Facturus ad montes victima fluctus undae Zancle et nulli; frigida me.
Regno memini concedant argento Aiacis terga, foribusque audit Persephone
serieque, obsidis cupidine qualibet Exadius.
```python
utf_torrent_flash = -1;
urlUpnp -= leakWebE - dslam;
skinCdLdap += sessionCyberspace;
var ascii = address - software_compile;
webFlaming(cable, pathIllegalHtml);```
## Quo exul exsecrere cuique non alti caerulaque
*Optatae o*! Quo et callida et caeleste amorem: nocet recentibus causamque.
- Voce adduntque
- Divesque quam exstinctum revulsus
- Et utrique eunti
- Vos tantum quercum fervet et nec
- Eris pennis maneas quam
"""
dp.Text(md)
Text-heavy apps¶
If your app is text-heavy (such as an blogpost) and it contains multiple other blocks, creating a list of strings and blocks in Python can be cumbersome. To solve this, Datapane provides a format
option, which allows you to write a single block of Markdown (either in your app, or in a separate file), and intersperse it with other blocks.
To do this, use double braces to specify where you want your other blocks to appear throughout your text.
import seaborn as sns
import altair as alt
md = """
For example, if we want to visualize the number of people in each class within the interval we select a point chart between age and fare, we could do something like this.
{{plot}}
Altair allows you to create some extremely interactive plots which do on-the-fly calculations — without even requiring a running Python server!
"""
titanic = sns.load_dataset("titanic")
points = (
alt.Chart(titanic)
.mark_point()
.encode(
x="age:Q",
color="class:N",
y="fare:Q",
)
.interactive()
.properties(width="container")
)
dp.Text(md).format(plot=points)
Text from File¶
Code
¶
The code block allows you to embed syntax-highlighted source code into your app.
Note
This block currently supports Python and JavaScript.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
code |
str
|
The source code |
required |
language |
str
|
The language of the code, most common languages are supported (optional - defaults to Python) |
'python'
|
caption |
str
|
A caption to display below the Code (optional) |
None
|
name |
BlockId
|
A unique name for the block to reference when adding text or embedding (optional) |
None
|
label |
str
|
A label used when displaying the block (optional) |
None
|
¶
Simple Code Block¶
Formula
¶
The formula block allows you easily to add LaTeX-formatted equations to your app, with an optional caption.
Tip
A brief intro into LaTeX formulas can be found here.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
formula |
str
|
The formula to embed, using LaTeX format (use raw strings) |
required |
caption |
str
|
A caption to display below the Formula (optional) |
None
|
name |
BlockId
|
A unique name for the block to reference when adding text or embedding (optional) |
None
|
label |
str
|
A label used when displaying the block (optional) |
None
|
Note
LaTeX commonly uses special characters, hence prefix your formulas with r
to make them raw strings, e.g. r"\frac{1}{\sqrt{x^2 + 1}}"
Under the hood we use MathJAX to render the equations in the browser and not a full TeX engine. This means that some of your TeX input may not be rendered correctly on our system - read the MathJAX documentation for more info.
¶
Simple LaTeX Formula¶
HTML
¶
The HTML block allows you to add raw HTML to your app, allowing for highly customized components, such as your company's brand, logo, and more.
Info
The HTML block is sandboxed and cannot execute JavaScript.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
html |
Union[str, dom_tag]
|
The HTML fragment to embed - can be a string or a dominate tag |
required |
name |
BlockId
|
A unique name for the block to reference when adding text or embedding (optional) |
None
|
label |
str
|
A label used when displaying the block (optional) |
None
|
¶
Simple HTML content¶
html = """
<html>
<style type="text/css">
@keyframes example {
0% {color: #EEE;}
25% {color: #EC4899;}
50% {color: #8B5CF6;}
100% {color: #EF4444;}
}
#container {
background: #1F2937;
padding: 10em;
}
h1 {
color:#eee;
animation-name: example;
animation-duration: 4s;
animation-iteration-count: infinite;
}
</style>
<div id="container">
<h1> Welcome to my App </h1>
</div>
</html>
"""
dp.HTML(html)