Spaces:
Running
Running
| import { Image } from 'astro:assets'; | |
| import placeholder from '../assets/image/placeholder.png'; | |
| import audioDemo from '../assets/audio/audio-example.wav'; | |
| import HtmlEmbed from '../../components/HtmlEmbed.astro'; | |
| import Sidenote from '../../components/Sidenote.astro'; | |
| import Wide from '../../components/Wide.astro'; | |
| import Note from '../../components/Note.astro'; | |
| import FullWidth from '../../components/FullWidth.astro'; | |
| import Accordion from '../../components/Accordion.astro'; | |
| import ResponsiveImage from '../../components/ResponsiveImage.astro'; | |
| ## Components | |
| **All** the following **components** are available in the **article.mdx** file. You can also create your own **components** by creating a new file in the `/components` folder. | |
| You have to import them in the **.mdx** file you want to use them in. | |
| <br/> | |
| <div className="button-group"> | |
| <a className="button" href="#responsiveimage">ResponsiveImage</a> | |
| <a className="button" href="#placement">Placement</a> | |
| <a className="button" href="#accordion">Accordion</a> | |
| <a className="button" href="#note">Note</a> | |
| <a className="button" href="#htmlembed">HtmlEmbed</a> | |
| <a className="button" href="#iframe">Iframe</a> | |
| </div> | |
| ### ResponsiveImage | |
| **Responsive images** automatically generate an optimized `srcset` and `sizes` so the browser downloads the most appropriate file for the current viewport and DPR. You can also request multiple output formats (e.g., **AVIF**, **WebP**, fallback **PNG/JPEG**) and control **lazy loading/decoding** for better **performance**. | |
| | Prop | Required | Description | |
| |------------------------|----------|------------------------------------------------------- | |
| | `zoomable` | No | Adds a zoomable lightbox (Medium-like). | |
| | `downloadable` | No | Adds a download button to fetch the image file. | |
| | `loading="lazy"` | No | Lazy loads the image. | |
| | `caption` | No | Adds a caption and credit. | |
| | `id` | No | Adds an `id` to the outer figure for deep-linking and cross-references. | |
| <ResponsiveImage | |
| src={placeholder} | |
| zoomable | |
| downloadable | |
| id="placeholder-image" | |
| layout="fixed" | |
| alt="A placeholder image alt text" | |
| caption={'A placeholder image description <span class="image-credit">From the <a target="_blank" href="https://commons.wikimedia.org/wiki/File:RCA_Indian_Head_Test_Pattern.svg">RCA Indian Head Test Pattern</a></span>'} | |
| /> | |
| <Accordion title="Code example"> | |
| ```mdx | |
| import ResponsiveImage from '../components/ResponsiveImage.astro' | |
| import myImage from './assets/image/placeholder.jpg' | |
| <ResponsiveImage src={myImage} alt="Responsive, optimized example image" /> | |
| <ResponsiveImage | |
| src={myImage} | |
| layout="fixed" | |
| zoomable | |
| downloadable | |
| loading="lazy" | |
| alt="Example with caption and credit" | |
| caption={'Optimized image with a descriptive caption. <span class="image-credit">Credit: Photo by <a href="https://example.com">Author</a></span>'} | |
| /> | |
| ``` | |
| </Accordion> | |
| ### Placement | |
| Use these helpers when you need to step outside the main content flow: **Sidenotes** for contextual side notes, **Wide** to extend beyond the main column, and **Full-width** for full-width, immersive sections. | |
| #### Sidenotes | |
| <Sidenote> | |
| This paragraph presents a **key idea** concisely. | |
| <Fragment slot="aside"> | |
| **Side note** for brief context or a definition. | |
| </Fragment> | |
| </Sidenote> | |
| <Accordion title="Code example"> | |
| ```mdx | |
| import Sidenote from '../components/Sidenote.astro' | |
| <Sidenote> | |
| Main paragraph with the core idea. | |
| <Fragment slot="aside">Short side note.</Fragment> | |
| </Sidenote> | |
| ``` | |
| </Accordion> | |
| #### Wide example | |
| <Wide> | |
| <div className="demo-wide">demo wide</div> | |
| </Wide> | |
| <Accordion title="Code example"> | |
| ```mdx | |
| import Wide from '../components/Wide.astro' | |
| <Wide> | |
| Your content here... | |
| </Wide> | |
| ``` | |
| </Accordion> | |
| #### Full-width example | |
| <FullWidth> | |
| <div className="demo-full-width">demo full-width</div> | |
| </FullWidth> | |
| <Accordion title="Code example"> | |
| ```mdx | |
| import FullWidth from '../components/FullWidth.astro' | |
| <FullWidth> | |
| Your content here... | |
| </FullWidth> | |
| ``` | |
| </Accordion> | |
| ### Accordion | |
| Can be used like this `<Accordion>some content</Accordion>`. You can pass any children content. | |
| <Accordion title="What can this accordion hold?" open> | |
| <p>Text, lists, images, code blocks, etc.</p> | |
| <ul> | |
| <li>Item one</li> | |
| <li>Item two</li> | |
| </ul> | |
| </Accordion> | |
| <Accordion title="A table inside an accordion"> | |
| | Prop | Required | Description | |
| |-------------|----------|---------------------------------------------------------------------------------- | |
| | `src` | Yes | Path to the embed file in the `embeds` folder. | |
| | `title` | No | Short title displayed above the card. | |
| | `desc` | No | Short description displayed below the card. Supports inline HTML (e.g., links). | |
| | `frameless` | No | Removes the card background and border for seamless embeds. | |
| | `align` | No | Aligns the title/description text. One of `left` (default), `center`, `right`. | |
| | `id` | No | Adds an `id` to the outer figure for deep-linking and cross-references. | |
| </Accordion> | |
| <Accordion title="Code example"> | |
| ````mdx | |
| import Accordion from '../components/Accordion.astro' | |
| <Accordion title="Accordion title" open> | |
| <p>Free content with <strong>markdown</strong> and MDX components.</p> | |
| </Accordion> | |
| <Accordion title="A table inside an accordion"> | |
| | Prop | Required | Description | |
| |-------------|----------|---------------------------------------------------------------------------------- | |
| | `src` | Yes | Path to the embed file in the `embeds` folder. | |
| | `title` | No | Short title displayed above the card. | |
| | `desc` | No | Short description displayed below the card. Supports inline HTML (e.g., links). | |
| | `frameless` | No | Removes the card background and border for seamless embeds. | |
| | `align` | No | Aligns the title/description text. One of `left` (default), `center`, `right`. | |
| | `id` | No | Adds an `id` to the outer figure for deep-linking and cross-references. | |
| </Accordion> | |
| <Accordion title="Code example"> | |
| ```ts | |
| function greet(name: string) { | |
| console.log(`Hello, ${name}`); | |
| } | |
| greet("Astro"); | |
| ``` | |
| </Accordion> | |
| ```` | |
| </Accordion> | |
| ### Note | |
| Small contextual callout for tips, caveats, or emphasis. | |
| <Note title="Heads‑up" emoji="💡" variant="info"> | |
| Use notes to surface context without breaking reading flow. | |
| </Note> | |
| <Note variant="success"> | |
| Operation completed successfully. | |
| </Note> | |
| <Note variant="danger"> | |
| Be careful: this action cannot be undone. | |
| </Note> | |
| <Note> | |
| Plain note without header. Useful for short clarifications. | |
| </Note> | |
| | Prop | Required | Type | Description | | |
| |----------|----------|------------------------------|-------------------------------------| | |
| | `title` | No | string | Short title displayed in header | | |
| | `emoji` | No | string | Emoji displayed before the title | | |
| | `class` | No | string | Extra classes for custom styling | | |
| | `variant`| No | 'info' | 'success' | 'danger' | Visual intent of the note | | |
| <Accordion title="Code example"> | |
| ```mdx | |
| import Note from '../../components/Note.astro' | |
| <Note title="Heads‑up" emoji="💡" variant="info"> | |
| Use notes to surface context without breaking reading flow. | |
| </Note> | |
| <Note variant="success"> | |
| Operation completed successfully. | |
| </Note> | |
| <Note variant="danger"> | |
| Be careful: this action cannot be undone. | |
| </Note> | |
| <Note> | |
| Plain note without header. Useful for short clarifications. | |
| </Note> | |
| ``` | |
| </Accordion> | |
| ### HtmlEmbed | |
| The main purpose of the ```HtmlEmbed``` component is to **embed** a **Plotly** or **D3.js** chart in your article. **Libraries** are already imported in the template. | |
| They exist in the `app/src/content/embeds` folder. | |
| For researchers who want to stay in **Python** while targeting **D3**, the [d3blocks](https://github.com/d3blocks/d3blocks) library lets you create interactive D3 charts with only a few lines of code. In **2025**, **D3** often provides more flexibility and a more web‑native rendering than **Plotly** for custom visualizations. | |
| <HtmlEmbed src="d3-line-example.html" title="This is a chart title" desc="Some chart description" /> | |
| | Prop | Required | Description | |
| |-------------|----------|---------------------------------------------------------------------------------- | |
| | `src` | Yes | Path to the embed file in the `embeds` folder. | |
| | `title` | No | Short title displayed above the card. | |
| | `desc` | No | Short description displayed below the card. Supports inline HTML (e.g., links). | |
| | `frameless` | No | Removes the card background and border for seamless embeds. | |
| | `align` | No | Aligns the title/description text. One of `left` (default), `center`, `right`. | |
| | `id` | No | Adds an `id` to the outer figure for deep-linking and cross-references. | |
| <Note emoji="💡" variant="info"> | |
| You can refer to a chart by giving it a name and pointing to it with a link. | |
| -> `<a href="#neural-network-mnist-like">like his</a>` | |
| -> `<HtmlEmbed id="neural-network-mnist-like"/>` | |
| Live example: <a href="#neural-network-mnist-like">Fig 1</a> | |
| </Note> | |
| <Accordion title="Code example"> | |
| ```mdx | |
| import HtmlEmbed from '../components/HtmlEmbed.astro' | |
| <HtmlEmbed src="plotly-line.html" title="Plotly Line" desc="Some chart description" /> | |
| <HtmlEmbed src="d3-line-example.html" title="D3 Line" desc="Some chart description" /> | |
| <HtmlEmbed src="d3-line-example.html" id="real-world-examples" title="D3 Line (with id)" desc="Linkable example via #real-world-examples" /> | |
| ``` | |
| </Accordion> | |
| #### Data | |
| If you need to link your **HTML embeds** to **data files**, there is an **`assets/data`** folder for this. | |
| As long as your files are there, they will be served from the **`public/data`** folder. | |
| You can fetch them with this address: **`[domain]/data/your-data.ext`** | |
| <Note emoji="⚠️" variant="danger"><b>Be careful</b>, unlike images, <b>data files are not optimized</b> by Astro. You need to optimize them manually.</Note> | |
| #### Vibe coding charts | |
| If you are from the research field, it can be difficult to use **D3.js** charts instead of **Plotly**. | |
| Happily, **LLM's** are here to help you! In the `app/src/content/embeds` folder, there is a `vibe-code-d3-embeds-directives.md` file that you can use to vibe code **D3.js** charts. | |
| Inside this file, you will find every directives you need to code your own **HtmlEmbed** proof **D3.js** chart. | |
| #### Real world examples | |
| Here are some examples that were vibe coded to inspire you. | |
| --- | |
| <HtmlEmbed src="d3-line.html" title="Training curves by metric" desc="Interactive time series across runs. Choose a metric; hover for values." /> | |
| --- | |
| <HtmlEmbed src="d3-bar.html" title="D3 Memory usage with recomputation" desc={`Memory usage with recomputation — <a href="https://huggingface.co/spaces/nanotron/ultrascale-playbook?section=activation_recomputation" target="_blank">from the ultrascale playbook</a>`}/> | |
| --- | |
| <Wide> | |
| <HtmlEmbed src="d3-neural.html" id="neural-network-mnist-like" title="D3 Interactive neural network (MNIST-like)" desc="Visualize activations and class probabilities (0–9)." align="center" /> | |
| </Wide> | |
| --- | |
| <Wide> | |
| <HtmlEmbed src="d3-pie.html" desc="D3 Pie charts by category" align="center" /> | |
| </Wide> | |
| --- | |
| <Wide> | |
| <HtmlEmbed src="filters-quad.html" desc="D3 Stacked Line charts" align="center" /> | |
| </Wide> | |
| --- | |
| <HtmlEmbed src="d3-comparison.html" title="Image similarity: query vs top-k" desc="Compare a query image to top-k matches. Shows rank and similarity." /> | |
| --- | |
| ### Iframes | |
| You can embed external content in your article using **iframes**. For example, **TrackIO**, **Gradio** or even **Github code embeds** can be used this way. | |
| <small className="muted">Github code embed</small> | |
| <iframe frameborder="0" scrolling="no" style="width:100%; height:292px;" allow="clipboard-write" src="https://emgithub.com/iframe.html?target=https%3A%2F%2Fgithub.com%2Fhuggingface%2Fpicotron%2Fblob%2F1004ae37b87887cde597c9060fb067faa060bafe%2Fsetup.py&style=default&type=code&showBorder=on&showLineNumbers=on"></iframe> | |
| <small className="muted">TrackIO embed</small> | |
| <div className=""> | |
| <iframe src="https://trackio-documentation.hf.space/?project=fake-training-750735&metrics=train_loss,train_accuracy&sidebar=hidden&lang=en" width="100%" height="660" frameborder="0"></iframe> | |
| </div> | |
| <small className="muted">Gradio embed</small> | |
| <div className=""> | |
| <iframe src="https://gradio-hello-world.hf.space" width="100%" height="380" frameborder="0"></iframe> | |
| </div> | |
| <Accordion title="Code example"> | |
| ```mdx | |
| <iframe frameborder="0" scrolling="no" style="width:100%; height:292px;" allow="clipboard-write" src="https://emgithub.com/iframe.html?target=https%3A%2F%2Fgithub.com%2Fhuggingface%2Fpicotron%2Fblob%2F1004ae37b87887cde597c9060fb067faa060bafe%2Fsetup.py&style=default&type=code&showBorder=on&showLineNumbers=on"></iframe> | |
| <iframe src="https://trackio-documentation.hf.space/?project=fake-training-750735&metrics=train_loss,train_accuracy&sidebar=hidden&lang=en" width="100%" height="600" frameborder="0"></iframe> | |
| <iframe src="https://gradio-hello-world.hf.space" width="100%" height="380" frameborder="0"></iframe> | |
| ``` | |
| </Accordion> | |