Official documentation of our UI components' library, PayGreen-UI.
This doc is built using Docusaurus 2, a modern static website generator.
yarn install
yarn start
This command starts a local development server and open up a browser window. Most changes are reflected live without having to restart the server.
yarn build
This command generates static content into the build
directory and can be served using any static contents hosting service.
GIT_USER=<Your GitHub username> USE_SSH=true yarn deploy
If you are using GitHub pages for hosting, this command is a convenient way to build the website and push to the gh-pages
branch.
- Create a new
mdx
file (or folder with a file inside, if you want to create more than one file for your component's documentation) insidedocs/YourCategory
. - Start your file with this:
---
id: yourComponent
title: YourComponent
---
## Your title (H2)
Your doc.
id
will be used for urltitle
will be used insideh1
title and inside sidebar
- You can re-order your doc inside sidebar by adding
sidebar_position: [number]
at the top of your mdx file:
---
id: yourComponent
title: YourComponent
sidebar_position: 1
---
4. You can re-order your folder inside sidebar by creating a file named `_category_.json` with this content:
```json
{
"position": 1
}
You can write content using GitHub-flavored Markdown syntax.
Emphasis, aka italics, with asterisks or underscores.
Strong emphasis, aka bold, with asterisks or underscores.
Combined emphasis with asterisks and underscores.
Strikethrough uses two tildes. Scratch this.
- First ordered list item
- Another item
- Unordered sub-list.
- Actual numbers don't matter, just that it's a number
- Ordered sub-list
- And another item.
- Unordered list can use asterisks
- Or minuses
- Or pluses
I'm an inline-style link with title
You can use numbers for reference-style link definitions
Or leave it empty and use the link text itself.
URLs and URLs in angle brackets will automatically get turned into links. http://www.example.com/ or http://www.example.com/ and sometimes example.com (but not on GitHub, for example).
Some text to show that the reference links can follow later.
Here's our logo (hover to see the title text):
Images from any folder can be used by providing path to file. Path should be relative to the original markdown file or absolute to the /static
folder.
var s = 'JavaScript syntax highlighting';
alert(s);
s = "Python syntax highlighting"
print(s)
No language indicated, so no syntax highlighting.
But let's throw in a <b>tag</b>.
function highlightMe() {
console.log('This line can be highlighted!');
}
Colons can be used to align columns.
Tables | Are | Cool |
---|---|---|
col 3 is | right-aligned | $1600 |
col 2 is | centered | $12 |
zebra stripes | are neat | $1 |
There must be at least 3 dashes separating each header cell. The outer pipes (|) are optional, and you don't need to make the raw Markdown line up prettily. You can also use inline Markdown.
Markdown | Less | Pretty |
---|---|---|
Still | renders |
nicely |
1 | 2 | 3 |
Blockquotes are very handy in email to emulate reply text. This line is part of the same quote.
Quote break.
This is a very long line that will still be quoted properly when it wraps. Oh boy let's keep writing to make sure this is long enough to actually wrap for everyone. Oh, you can put Markdown into a blockquote.
- Definition list
- Is something people use sometimes.
- Markdown in HTML
- Does *not* work **very** well. Use HTML tags.
Here's a line for us to start with.
This line is separated from the one above by two newlines, so it will be a separate paragraph.
This line is also a separate paragraph, but... This line is only separated by a single newline, so it's a separate line in the same paragraph.
:::note
This is a note
:::
:::tip
This is a tip
:::
:::important
This is important
:::
:::caution
This is a caution
:::
:::warning
This is a warning
:::
You can write JSX and use React components within your Markdown thanks to MDX.
The .mdx
extension is not required, but will enable better support from tooling (IDE, Prettier...).
export const Highlight = ({ children, color }) => (
<span
style={{
backgroundColor: color,
borderRadius: '2px',
color: '#fff',
padding: '0.2rem',
}}
onClick={() => alert('Highlight pressed!')}
>
{children}
</span>
);
<>
<Highlight color="#25c2a0">Docusaurus green</Highlight> and
<Highlight color="#1877F2">Facebook blue</Highlight> are my favorite colors.
</>;