Each page is its own directory, containing these files:
meta.yml
- Meta Properties, used to change properties of the page itselfpage.kubejsdoc
- Page Document (see below for syntax). Optional - if not present, its assumed that its an auto-index page that only contains links to its sub-pagesen.yml
- English Language Document<other language>.yml
- Other Language Documents. Language must be specified in /languages/ directory
An example meta.yml
:
# Ordered, comma-separated list of pages to include in index. "" for no index
index: "page1, page2, ..."
# Version range this page exists for, see Version Syntax below
versions: "[1202, 1605]"
# Redirects this page to another
redirect: "/path/to/redirect"
# Author ID, you can find yours by right-clicking on yourself in Discord and opening Apps > KubeJS Profile
author: "00000001"
# Marks the page as "Also see" in the sidebar
see-also: "/path/to/see/also"
# Downloads
download-curseforge: "kubejs"
download-modrinth: "kubejs"
download-github: "KubeJS-Mods/KubeJS"
An example en.yml
:
# Meta property that is also used for page title
title: "Page Title"
# Meta property that is also used for page subtitle
description: "Page Description"
# Custom key
language-key-1: "Hello"
Documents of other languages will fall back to English if key is missing. Values can contain kubejsdoc syntax like "Text **bold** text"
and will be recursively parsed. They can contain other language keys, but its recommended to write docs in such way that it's not necessary.
page.kubejsdoc
files are very similar to markdown, with few differences, mostly related to linking to pages/files. Full spec below.
You can preview some test syntax here.
**text**
- Bold text*text*
- Italic text~~text~~
- Strikethrough text__text__
- Underlined text`text`
- Inline code==text==
- Highlighted text{replacement}
- Language key or global replacement, typically emojis (e.g.{language-key-1}
or{yes}
, see global.yml)[[/path/to/page]]
or[[/path/to/page|text]]
- Page link. Text is optional, page title is used otherwise (e.g.[[/addons]]
or[[/addons|Cool Addons]]
)![[filename]]
- Media block - can be an image, video or file in same directory as page. Alt text is optional (e.g.![[image.png]]
)![[youtube:code]]
- Youtube media block (e.g.![[youtube:eT3BFzSD6YY]]
)![[emoji:filename]]
- Media block but image will be inlined (e.g.![[emoji:pepehands.png]]
)![[media|alt]]
- Same media block but with description text (e.g.![[image.png|A very cool image]]
)[text](url)
- External link, only supports https:// (e.g.[KubeJS Website](https://kubejs.com/)
)---
- Horizontal line# Heading 1
- Heading 1## Heading 2
- Heading 2### Heading 3
- Heading 3#[[color|text]]
- Colored text. You can use either hex code#z\RRGGBB
or color name, one of- red
- orange
- yellow
- green
- blue
- purple
- magenta
```lang
code
```
Special formatted blocks:
>>> info
Info text here.
Supports multiple lines and **formatting** inside of it.
<<<
You can use one of these markers:
quote
(default, gray)info
(blue)success
(green)warning
(orange)danger
(red)
Variable blocks are useful when you want to include multiple elements in one inline block, for example multiple items in a list or table.
Define block:
>>> #identifier
Content here.
<<<
Reference block: {{#identifier}}
e.g.
>>> #test
Line 1
![[test.png]]
Line 3
<<<
- List item 1
- {{#test}}
Each line starts with 2N spaces (0, 2, 4...) and a -
followed by space, then content:
- Item 1
- Item 2
- Item 3
- Sub-Item 1
- Sub-Item 2
- Sub-Item 3
Will create:
- Item 1
- Item 2
- Item 3
- Sub-Item 1
- Sub-Item 2
- Sub-Item 3
Same syntax as unordered lists, but with .
instead of -
:
. Item 1
. Item 2
. Item 3
. Sub-Item 1
. Sub-Item 2
. Sub-Item 3
Will create:
- Item 1
- Item 2
- Item 3
- Sub-Item 1
- Sub-Item 2
- Sub-Item 3
|> Title
Content
<|
You can use |>+
to make it expanded by default:
|>+ Title
Content
<|
You can also nest tabs:
|> Title
Content
|> Title 2
Content 2
<|
<|
|> Tab 1 name
Content
<||> Tab 2 name
Content
<|
You can use |>+
to select default tab:
|> Tab 1 name
Content
<||>+ Tab 2 name
Content
<|
| Header 1 | Header 2 |
| Cell 1 | Cell 2 |
| Cell 3 | Cell 4 |
[min,max]
- Version range between min and max, inclusive (e.g.[1202,1605]
)[min,]
- Version range between min and latest, inclusive (e.g.[1202,]
)[,max]
- Version range between oldest and max, inclusive (e.g.[,1605]
)version
- Only one specific version (e.g1202
)