We use docusaurus to power docs.getdbt.com.
Please review the dbt docs contributors code of conduct. Creating an inclusive and equitable environment for our documents is more important than any other aspect. Syntax errors can be corrected, but trust, once lost, is difficult to gain back.
We welcome contributions from community members to this repo:
- Fixes: When you notice an error, you can use the
Edit this page
button at the bottom of each page to suggest a change. - New documentation: If you contributed code in dbt-core, we encourage you to also write the docs here! Please reach out in the dbt community if you need help finding a place for these docs.
- Major rewrites: You can file an issue or start a discussion to propose ideas for a content area that requires attention.
You can use components documented in the docusaurus library.
We author content using Markdown and sometimes HTML. When writing content, you should refer to the style guide and content types to help you understand our writing standards and how we break down information in the product documentation.
We now enable you to reuse content between different docs pages, version pages, and establish product variables in the dbt Labs product documentation. To learn more about how to single source content between versions, product variables, and other content, see Single-sourcing content.
You can add code snippets and other content in a tabbed view. To learn more about adding tabbed components, see Adding page components.
You can click a link available in a netlify bot PR comment to see and review your changes rendered on a staging server. You are also able to see and review your proposed modifications locally on your computer. Our setup instructions use homebrew:
- (Mac Terminal) Install Xcode Command Line Tools
- Open a terminal window, run
xcode-select --install
, and follow the on-screen prompts in the pop-up window.
- Open a terminal window, run
- (Mac and Linux) Install homebrew
- Copy and paste
/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
in to a terminal window and follow the prompts. Once the installation has completed, follow the Next Steps instructions listed in terminal.
- Copy and paste
- (Windows) Install Node.js
- (Mac and Linux only) Install
node
:brew install node
- Clone this repo:
git clone https://github.com/dbt-labs/docs.getdbt.com.git
cd
into the repo:cd docs.getdbt.com
cd
into thewebsite
subdirectory:cd website
- Install the required node packages:
npm install
(optional — install any updates) - Build the website:
npm start
- Before pushing your changes to a branch, check that all links work by using the
make build
script.
Advisory:
- If you run into an
fatal error: 'vips/vips8' file not found
error when you runnpm install
, you may need to runbrew install vips
. Warning: this one will take a while -- go ahead and grab some coffee!
Method 1: Utilizing the Cypress GUI
cd
into the repo:cd docs.getdbt.com
cd
into thewebsite
subdirectory:cd website
- Install the required node packages:
npm install
- Run
npx cypress open
to open the Cypress GUI, and chooseE2E Testing
as the Testing Type, before finally selecting your browser and clickingStart E2E testing in {broswer}
- Click on a test and watch it run!
Method 2: Running the Cypress E2E tests headlessly
cd
into the repo:cd docs.getdbt.com
cd
into thewebsite
subdirectory:cd website
- Install the required node packages:
npm install
- Run
npx cypress run
The folder structure is broken into several high-level categories under the main website
folder: blog, cypress, docs, functions, plugins, snippets, src, static.
Images are under the static
> img
folder.
The TOC is managed in the sidebar.js
file. You only need to edit the sidebar.js
file when you are adding a new page or deleting an existing page. The sidebar.js
file is the one that causes most of the merge conflicts because many technical writers are working on content daily. You will need to accept the changes from other contributors if you are committing a PR.
Don't worry if you're not sure where in the TOC a new topic belongs. Do your best and when you submit your PR, the dbt Labs Documentation team will edit it and help to find the right placement.
The right-hand TOC is created automatically when you add headings to a page.
If you are adding a new file, it must be named following our naming conventions. The file name should always start with the feature type (such as dbt-cloud, ide, or job-scheduler). Depending on the content type, it typically also includes a secondary descriptor and a verb. Verbs are used when you are creating a task topic.
Because we author content using Markdown, you must add the .md
the file extension to the file name.
If you are adding a new page to an existing feature category, follow the existing naming convention for that category.
Example: Concept file
snapshots-backup-hooks.md
Example: Reference file
snapshots-backup-hooks.md
Example: Task file
releases-creating-customer.md
Example: Tutorial file
tutorial-ha-cluster-deploying.md
- Screenshots are use sparingly to minimize the maintenance of out-of-date content. However, we do include some screenshots to provide context.
- Use a focused area of the UI, unless the entire screen is truly needed for context.
- We only use PNG format, which renders a better quality and lossless compression.
- For privacy and legal purposes, do your best to not reveal personal information, IP addresses, domain information, login credentials and so on in screenshots, code blocks, or text.
- Add title="" for all images to write a consice title of the image. For accessibility, it's important to use succinct text that is clear and complete. For more information about images formatting, see the following section.
- For images that are difficult to see, you can click on the image to enlarge it on the same page.
docs.getdbt.com uses its own CSS, and Docusaurus supports its own specific Markdown syntax. The following table provides an overview of the supported syntax elements.
Element | Syntax |
---|---|
Headings | # H1 , ## H2 , ### H3 |
Bold | **bold text** |
Italic | _italicized text_ |
Ordered List | 1. First item (use 1. for each item) |
Unordered List | - or * (for each item) |
Code or command in a sentence | code |
Link - external site | [Title](https://www.example.com) |
Link - topic in same folder | [Title](/folder/file-name) without file extension |
Link - topic in different folder | [Title](/folder/file-name) without file extension |
Link - section in topic in same folder | [Title](/folder/file-name#section-name) |
Link - section in topic in different folder | [Title](/folder/file-name#section-name) |
Image | <Lightbox src="/img/docs/<image-name>.png" title="Concise description of image"/>() |
Note callouts are formatted as follows:
:::note
text
:::
Info callouts are formatted as follows:
:::info
text
:::
Tip callouts, typically used for tips, are formatted as follows:
:::tip
text
:::
Caution callouts, typically used for warnings/considerations, are formatted as follows:
:::caution
text
:::
### Tables
We use traditional markdown for tables, which can be a useful way of presenting complex or comparative information.
For more guidelines on markdown tables, review the [docs.getdbt.com style guide](https://github.com/dbt-labs/product-docs-team/tree/main).
## Style Guidelines
The docs.getdbt.com product documentation has in-house style guidelines that the Docs team uses when reviewing your PR. Feel free to just add the content you need or make change, knowing that our team will be there to help with editorial reviews and information architecture, such as TOC placement, and so on. The Docs team will actively edit or write content, not just give editorial reviews and we highly encourage your contributions in the true open-source spirit.
## SME and Editorial Reviews
All PRs that are submitted are reviewed by the dbt Labs Docs team for editorial review.
Content that is submitted by our users, and the open-source community are also reviewed by our dbt Labs subject matter experts (SMEs) to help ensure technical accuracy.