path | title | isInternal | published |
---|---|---|---|
/components |
Custom components and their usage |
true |
true |
This guide helps authors and developers unify implementation by providing you with components, tokens, and practices for our docsite.
Translating markdown and HTML components into human-usable formatting can be scary. Follow these best practices to have a better experience:
- Line breaks to separate HTML-style tags in React components from other types of content. For example:
<Callout intent="info">
<CalloutTitle>CALLOUT-TITLE</CalloutTitle>
<CalloutDescription>
CALLOUT CONTENT.
</CalloutDescription>
</Callout>
-
Left-justify text content inside callouts
As pictured above. Callout contents do not respect markdown unless they are left-justified.
-
Line breaks after every component
Separate headers, components, and other formatting with a paragraph break. This ensures the text formats correctly. Don't worry about inline links, those don't mess up any formatting.
# EXAMPLE HEADER
< -- this line deliberately left blank -- >
Content content.
You can put code samples and markdown into callouts in one of two ways.
Use a code block:
<CalloutTitle><code>more_code</code></CalloutTitle>
Or insert blank lines above and below where you want to use the markdown:
<Callout intent="info">
<CalloutTitle>
`more_code`
</CalloutTitle>
<CalloutDescription>
`even_more_code`
</CalloutDescription>
</Callout>
There are four different types of callouts:
<Callout intent="info"> (blue)
<Callout intent="warning"> (yellow)
<Callout intent="alert"> (red)
<Callout intent="primary"> (light blue)
Learn more: Single link
<CodeTabs defaultValue="text" values={[ { label: 'Single Learn More', value: 'text', }, ] }>
<LearnMore>
Learn more: [Single link](/foobar)
</LearnMore>
Learn more:
<CodeTabs defaultValue="LearnMore" values={[ { label: 'Multiple Learn More', value: 'LearnMore', }, ] }>
<LearnMore>
Learn more:
* [This is an internal link](/foobar)
* [External link](http://reactjunkie.com)
* [Another internal link](/foobar)
</LearnMore>
Some lead text describing the links.
<CodeTabs defaultValue="LearnMore" values={[ { label: 'Using Additional Text', value: 'LearnMore', }, ] }>
<LearnMore>
Some lead text describing the links.<br/><br/>
* [This is an internal link](/foobar)
* [External link](http://reactjunkie.com)
* [Another internal link](/foobar)
</LearnMore>
The docs site supports a details or "disclosure" component to expand/collapse information.
Here are some expanded details
<CodeTabs defaultValue="" values={[ { label: 'Details', value: 'Details', }, ] }>
<Details summary="Click to open more information">
Here are some expanded details
</Details>
Details may also be set to be open by default
This details is open by default
<CodeTabs defaultValue="" values={[ { label: 'Details', value: 'Details', }, ] }>
<Details open summary="Click to open more information">
This details is open by default
</Details>
The docs site supports PNGs and GIFs. Just use Markdown images. Put the images in /src/content/images
. In your Markdown, the path to the image is relative to that directory.
<CodeTabs defaultValue="" values={[ { label: 'Image', value: 'Image', }, ] }>
![Some caption](data-export.png)
Include a blank line between the opening and closing <CalloutDescription>
tags and the content. Do not indent any lines.
You do not have to send users to LaunchDarkly in advance. Check out this page. You can target them with feature flags have LaunchDarkly accounts of their own. Users appear in the Users list automatically after they encounter feature flags.
Adding users to LaunchDarklyYou do not have to send users to LaunchDarkly in advance. Check out this page. You can target them with feature flags have LaunchDarkly accounts of their own. Users appear in the Users list automatically after they encounter feature flags.
Adding users to LaunchDarklyYou do not have to send users to LaunchDarkly in advance. Check out this page. You can target them with feature flags have LaunchDarkly accounts of their own. Users appear in the Users list automatically after they encounter feature flags.
Adding users to LaunchDarklyYou do not have to send users to LaunchDarkly in advance. Check out this page. You can target them with feature flags have LaunchDarkly accounts of their own. Users appear in the Users list automatically after they encounter feature flags.
<CodeTabs defaultValue="Callout" values={[ { label: 'Callout', value: 'Callout', }, ] }>
<Callout intent="primary"> <!-- OR alert, warning, info -->
<CalloutTitle>Adding users to LaunchDarkly</CalloutTitle>
<CalloutDescription>
You do not have to send users to LaunchDarkly in advance. <a href="">Check out this page</a>. You can target them with feature flags have LaunchDarkly accounts of their own. Users appear in the <strong>Users</strong> list automatically after they encounter feature flags.
</CalloutDescription>
</Callout>
- Write code block as markdown as usual.
- Add a
CodeTabs
component with a default value, which will be the first tab shown, and a values array of objects with a label and value. - Each CodeTabItem will be one of the tabs.
- If a tab has federal-specific content, include two versions of the language. Set
site=federal
after the language for the federal-specific code block. When the reader selects "LaunchDarkly docs," the CodeTabItem displays the unannotated code block. When they select "Federal docs," the CodeTabItem displays thesite=federal
code block.
<CodeTabs defaultValue="code" values={[ { label: 'Code snippet', value: 'code', }, ] }>
<CodeTabs
defaultValue="js"
values={[
{ label: 'JavaScript', value: 'js', },
{ label: 'Python', value: 'py', },
{ label: 'Java', value: 'java', },
]
}>
<CodeTabItem value="js">
```js
function helloWorld() {
console.log('Hello, world!');
}
```
```js site=federal
function helloFederal() {
console.log('Hello, federal!');
}
```
</CodeTabItem>
<CodeTabItem value="py">
```py
def hello_world():
print 'Hello, world!'
```
</CodeTabItem>
<CodeTabItem value="java">
```java
class HelloWorld {
public static void main(String args[]) {
System.out.println("Hello, World");
}
}
```
</CodeTabItem>
</CodeTabs>
Markdown tables are hard to read in text editors and easy to break. We built our own table component to use instead. It's much like an HTML table. When content in a table cell is left-justified, and bracketed by empty lines, you can use HTML tags in it.
<CodeTabs defaultValue="Table" values={[ { label: 'Table', value: 'Table', }, ] }>
<Table>
<TableHeader>
<TableHeadCell>Name of column 1</TableHeadCell>
<TableHeadCell>Name of column 2</TableHeadCell>
</TableHeader>
<TableBody>
<TableRow>
<TableCell>Column 1 Cell 1</TableCell>
<TableCell>Column 1 Cell 2</TableCell>
</TableRow>
<TableRow>
<TableCell>
Column 2 Cell 1 <a href="example.com">with a link in it</a>.
</TableCell>
<TableCell>Column 2 Cell 2</TableCell>
</TableRow>
</TableBody>
</Table>