Skip to content

Latest commit

 

History

History
505 lines (336 loc) · 15.6 KB

components.mdx

File metadata and controls

505 lines (336 loc) · 15.6 KB
title description
Components
Using components in MDX with Starlight.

Components let you easily reuse a piece of UI or styling consistently. Examples might include a link card or a YouTube embed. Starlight supports the use of components in MDX files and provides some common components for you to use.

Learn more about building components in the Astro Docs.

Using a component

You can use a component by importing it into your MDX file and then rendering it as a JSX tag. These look like HTML tags but start with an uppercase letter matching the name in your import statement:

---
# src/content/docs/example.mdx
title: Welcome to my docs
---

import SomeComponent from '../../components/SomeComponent.astro';
import AnotherComponent from '../../components/AnotherComponent.astro';

<SomeComponent prop="something" />

<AnotherComponent>
	Components can also contain **nested content**.
</AnotherComponent>

Because Starlight is powered by Astro, you can add support for components built with any supported UI framework (React, Preact, Svelte, Vue, Solid, Lit, and Alpine) in your MDX files. Learn more about using components in MDX in the Astro docs.

Compatibility with Starlight’s styles

Starlight applies default styling to your Markdown content, for example adding margin between elements. If these styles conflict with your component’s appearance, set the not-content class on your component to disable them.

---
// src/components/Example.astro
---

<div class="not-content">
	<p>Not impacted by Starlight’s default content styling.</p>
</div>

Built-in components

Starlight provides some built-in components for common documentation use cases. These components are available from the @astrojs/starlight/components package.

Tabs

import { Tabs, TabItem } from '@astrojs/starlight/components';

You can display a tabbed interface using the <Tabs> and <TabItem> components. Each <TabItem> must have a label to display to users. Use the optional icon attribute to include one of Starlight’s built-in icons next to the label.

# src/content/docs/example.mdx

import { Tabs, TabItem } from '@astrojs/starlight/components';

<Tabs>
	<TabItem label="Stars" icon="star">
		Sirius, Vega, Betelgeuse
	</TabItem>
	<TabItem label="Moons" icon="moon">
		Io, Europa, Ganymede
	</TabItem>
</Tabs>

The code above generates the following tabs on the page:

Sirius, Vega, Betelgeuse Io, Europa, Ganymede

Synced tabs

Keep multiple tab groups synchronized by adding the syncKey attribute.

All <Tabs> with the same syncKey value will display the same active label. This allows your reader to choose once (e.g. their operating system or package manager), and see their choice persisted across page navigations.

To synchronize related tabs, add an identical syncKey property to each <Tabs> component and ensure that they all use the same <TabItem> labels:

# src/content/docs/example.mdx

import { Tabs, TabItem } from '@astrojs/starlight/components';

_Some stars:_

<Tabs syncKey="constellations">
	<TabItem label="Orion">Bellatrix, Rigel, Betelgeuse</TabItem>
	<TabItem label="Gemini">Pollux, Castor A, Castor B</TabItem>
</Tabs>

_Some exoplanets:_

<Tabs syncKey="constellations">
	<TabItem label="Orion">HD 34445 b, Gliese 179 b, Wasp-82 b</TabItem>
	<TabItem label="Gemini">Pollux b, HAT-P-24b, HD 50554 b</TabItem>
</Tabs>

The code above generates the following on the page:

Some stars:

Bellatrix, Rigel, Betelgeuse Pollux, Castor A, Castor B

Some exoplanets:

HD 34445 b, Gliese 179 b, Wasp-82 b Pollux b, HAT-P-24b, HD 50554 b

Cards

import { Card, CardGrid } from '@astrojs/starlight/components';

You can display content in a box matching Starlight’s styles using the <Card> component. Wrap multiple cards in the <CardGrid> component to display cards side-by-side when there’s enough space.

A <Card> requires a title and can optionally include an icon attribute set to the name of one of Starlight’s built-in icons.

# src/content/docs/example.mdx

import { Card, CardGrid } from '@astrojs/starlight/components';

<Card title="Check this out">Interesting content you want to highlight.</Card>

<CardGrid>
	<Card title="Stars" icon="star">
		Sirius, Vega, Betelgeuse
	</Card>
	<Card title="Moons" icon="moon">
		Io, Europa, Ganymede
	</Card>
</CardGrid>

The code above generates the following on the page:

Interesting content you want to highlight.

Sirius, Vega, Betelgeuse Io, Europa, Ganymede

:::tip Use a card grid on your home page to display your project’s key features. Add the stagger attribute to shift the second column of cards vertically and add visual interest:

<CardGrid stagger>
	<!-- cards -->
</CardGrid>

:::

Link Cards

Use the <LinkCard> component to link prominently to different pages.

A <LinkCard> requires a title and an href attribute. You can optionally include a short description or other link attributes such as target.

Group multiple <LinkCard> components in <CardGrid> to display cards side-by-side when there’s enough space.

# src/content/docs/example.mdx

import { LinkCard, CardGrid } from '@astrojs/starlight/components';

<LinkCard
	title="Customizing Starlight"
	description="Learn how to make your Starlight site your own with custom styles, fonts, and more."
	href="/guides/customization/"
/>

<CardGrid>
	<LinkCard title="Authoring Markdown" href="/guides/authoring-content/" />
	<LinkCard title="Components" href="/guides/components/" />
</CardGrid>

The above code generates the following on the page:

import { LinkCard } from '@astrojs/starlight/components';

Link Buttons

Use the <LinkButton> component for visually distinct call-to-action links. A link button is useful for directing users to the most relevant or actionable content and often used on landing pages

A <LinkButton> requires an href attribute and optionally accepts other link attributes such as target.

The icon attribute can optionally be set to the name of one of Starlight's built-in icons to include an icon next to the text. The iconPlacement attribute can be used to place the icon before the text by setting it to start (defaults to end).

Customize the appearance of the link button using the variant attribute, which can be set to primary (the default), secondary, or minimal.

# src/content/docs/example.mdx

import { LinkButton } from '@astrojs/starlight/components';

<LinkButton href="/getting-started/">Get started</LinkButton>
<LinkButton href="https://docs.astro.build" variant="secondary" icon="external">
	Related: Astro
</LinkButton>

The above code generates the following on the page:

import { LinkButton } from '@astrojs/starlight/components';

Get started Related: Astro

Asides

Asides (also known as “admonitions” or “callouts”) are useful for displaying secondary information alongside a page’s main content.

An <Aside> can have an optional type of note (the default), tip, caution or danger. Setting a title attribute overrides the default aside title.

# src/content/docs/example.mdx

import { Aside } from '@astrojs/starlight/components';

<Aside>A default aside without a custom title.</Aside>

<Aside type="caution" title="Watch out!">
	A warning aside *with* a custom title.
</Aside>

<Aside type="tip">

Other content is also supported in asides.

```js
// A code snippet, for example.
```

</Aside>

<Aside type="danger">Do not give your password to anyone.</Aside>

The above code generates the following on the page:

import { Aside } from '@astrojs/starlight/components';

A default aside without a custom title. A warning aside *with* a custom title.

Other content is also supported in asides.

// A code snippet, for example.
Do not give your password to anyone.

Starlight also provides a custom syntax for rendering asides in Markdown and MDX as an alternative to the <Aside> component. See the “Authoring Content in Markdown” guide for details of the custom syntax.

Code

Use the <Code> component to render syntax highlighted code when using a Markdown code block is not possible, for example, to render data coming from external sources like files, databases, or APIs.

See the Expressive Code “Code Component” docs for full details of the props <Code> supports.

# src/content/docs/example.mdx

import { Code } from '@astrojs/starlight/components';

export const exampleCode = `console.log('This could come from a file or CMS!');`;
export const fileName = 'example.js';
export const highlights = ['file', 'CMS'];

<Code code={exampleCode} lang="js" title={fileName} mark={highlights} />

The code above generates the following on the page:

import { Code } from '@astrojs/starlight/components';

export const exampleCode = console.log('This could come from a file or CMS!');; export const fileName = 'example.js'; export const highlights = ['file', 'CMS'];

Imported Code

Use Vite’s ?raw import suffix to import any code file as a string. You can then pass this imported string to the <Code> component to include it on your page.

import { Code } from '@astrojs/starlight/components';
import importedCode from '/src/env.d.ts?raw';

<Code code={importedCode} lang="ts" title="src/env.d.ts" />

The code above generates the following on the page:

import importedCode from '/src/env.d.ts?raw';

File Tree

Use the <FileTree> component to display the structure of a directory with file icons and collapsible sub-directories.

Specify the structure of your files and directories with an unordered Markdown list inside <FileTree>. Create a sub-directory using a nested list or add a / to the end of a list item to render it as a directory without specific content.

The following syntax can be used to customize the appearance of the file tree:

  • Highlight a file or directory by making its name bold, e.g. **README.md**.
  • Add a comment to a file or directory by adding more text after the name.
  • Add placeholder files and directories by using either ... or as the name.
# src/content/docs/example.mdx

import { FileTree } from '@astrojs/starlight/components';

<FileTree>

- astro.config.mjs an **important** file
- package.json
- README.md
- src
  - components
    - **Header.astro**
  -- pages/

</FileTree>

The above code generates the following on the page:

import { FileTree } from '@astrojs/starlight/components';

  • astro.config.mjs an important file
  • package.json
  • README.md
  • src
    • components
      • Header.astro
  • pages/

Steps

Use the <Steps> component to style numbered lists of tasks. This is useful for more complex step-by-step guides where each step needs to be clearly highlighted.

Wrap <Steps> around a standard Markdown ordered list. All the usual Markdown syntax is applicable inside <Steps>.

import { Steps } from '@astrojs/starlight/components';

<Steps>

1. Import the component into your MDX file:

   ```js
   import { Steps } from '@astrojs/starlight/components';
   ```

2. Wrap `<Steps>` around your ordered list items.

</Steps>

The code above generates the following on the page:

import { Steps } from '@astrojs/starlight/components';

  1. Import the component into your MDX file:

    import { Steps } from '@astrojs/starlight/components';
  2. Wrap <Steps> around your ordered list items.

Badges

import { Badge } from '@astrojs/starlight/components';

Use the <Badge> component to display small pieces of information, such as status or labels.

Pass the content you want to display to the text attribute of the <Badge> component.

By default, the badge will use the theme accent color of your site. To use a built-in badge color, set the variant attribute to one of the following values: note (blue), tip (purple), danger (red), caution (orange), or success (green).

The size attribute (default: small) controls the size of the badge text. medium and large are also available options for displaying a larger badge.

For further customization, use other <span> attributes such as class or style with custom CSS.

import { Badge } from '@astrojs/starlight/components';

<Badge text="New" variant="tip" size="small" />
<Badge text="Deprecated" variant="caution" size="medium" />
<Badge text="Starlight" variant="note" size="large" />
<Badge text="Custom" variant="success" style={{ fontStyle: 'italic' }} />

The code above generates the following on the page:

Icon

import { Icon } from '@astrojs/starlight/components'; import IconsList from '~/components/icons-list.astro';

Starlight provides a set of common icons that you can display in your content using the <Icon> component.

Each <Icon> requires a name and can optionally include a label to provide context for screen readers. The size and color attributes can be used to adjust the icon’s appearance using CSS units and color values.

# src/content/docs/example.mdx

import { Icon } from '@astrojs/starlight/components';

<Icon name="star" color="goldenrod" size="2rem" />
<Icon name="rocket" color="var(--sl-color-text-accent)" />

The code above generates the following on the page:

All icons

A list of all available icons is shown below with their associated names. Click an icon to copy the component code for it.