-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathREADME.qmd
94 lines (69 loc) · 2.54 KB
/
README.qmd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
---
title: "base64 shortcode for Quarto"
subtitle: "A Quarto shortcode to easily base64 encode images and other files"
format:
gfm: default
html:
toc: true
toc-level: 2
toc-location: right
toc-title: "base64"
code-links:
- text: gadenbuie/quarto-base64
href: "https://github.com/gadenbuie/quarto-base64"
icon: github
- text: Question or Issue?
href: "https://github.com/gadenbuie/quarto-base64/issues/new"
icon: question-circle-fill
format-links: false
---
Easily embed base64 encoded files in your [Quarto documents](https://quarto.org).
**Why would you want to do this?** If you're using the [shinylive Quarto extension](https://quarto-ext.github.io/shinylive/), you can use the `base64` shortcode to embed binary files in your Shinylive apps.
If you aren't using Shinylive, pandoc can help you embed images in your documents via `--embed-resources` (or `embed-resources: true` in Quarto). But this applies to all images and resources in your document. If you find yourself wanting to embed a single image or resource: the `base64-data` shortcode can help!
## Installing
```bash
quarto add gadenbuie/quarto-base64
```
This will install the extension under the `_extensions` subdirectory.
If you're using version control, you will want to check in this directory.
## Using
### base64
To encode a file into a base64 string, use the `base64` shortcode.
````{.markdown shortcodes="false"}
```{shinylive-python}
#| standalone: true
#| components: [editor, viewer]
#| layout: vertical
## file: app.py
from pathlib import Path
from shiny.express import render, ui
@render.ui
def image():
return ui.img(src="photo.png")
## file: www/photo.png
## type: binary
{{< base64 photo.png >}}
```
````
### base64-data
To encode a file into a base64 data URI, use the `base64-data` shortcode.
````{.markdown shortcodes="false"}
data:image/s3,"s3://crabby-images/88863/888638ccc406439e8c9a3bc2caa41f5f847b872d" alt=""
````
The `base64-data` shortcode will automatically guess [the MIME type of the file](https://www.iana.org/assignments/media-types/media-types.xhtml) using [the puremagic Lua module](https://github.com/wbond/puremagic). If it guesses wrong, or can't determine the MIME type, you can specify the MIME type explicitly.
````{.markdown shortcodes="false"}
data:image/s3,"s3://crabby-images/6cb79/6cb7903654eaeb825a5f2ee7964afcccc4275095" alt=""
````
## Example
```{.markdown shortcodes="false"}
{{< base64 photo.png >}}
```
```{.markdown}
{{< base64 photo.png >}}
```
```{.markdown shortcodes="false"}
<img src="{{< base64-data photo.png >}}">
```
```{=html}
<img src="{{< base64-data photo.png >}}">
```