Read the Solid Docs Manifesto first!
We welcome contributions of any size and contributors of any skill level. As an open source project, we believe in giving back to our contributors. We are happy to help with guidance on PRs, technical writing, and turning a feature idea into a reality.
Tip for new contributors: Take a look at this GitHub guide to learn how to use Git and GitHub to contribute to open-source.
Our #docs
channel on Discord is our home for general docs discussion. Feel free to introduce yourself there!
-
Submit a new GitHub Issue to propose a change or addition to the docs.
-
Bugs must be reported as Issues; it isn't enough to tell us on Discord!
-
GitHub Issues allow us to assign tasks and prioritize them, thanks to our GitHub project board. This is our task management tool.
-
Because this project is new, most of our Issues represent new content that must be created. If you're interested in writing new content—or editing content to our standards—be sure to read the Writing Guide before contributing.
In short, no! Here are ways you can help us if you don't yet know how to use Solid:
- Editing existing content for clarity
- Finding and fixing typos
- Making sure existing content and proposed PRs follow our Writing Guide
If you don't yet know how to use Solid, but you're learning, here's how you can help us along the way:
- "Testing" a tutorial, how-to guide, or concept page by using it to learn that topic
- Asking and answering questions in our #learn-solid channel on Discord
That said, if you want to contribute to open-source but aren't interested in Solid or documentation, we'd be happy to help you find an open-source project that suits you.
To find something to help with, check out our existing Issues. We're also happy to help you find something that suits you: ask a member of the Docs Team on Discord to help get you situated.
You can sort by labels, which categorize the issues. These include:
- a label for each of the four content types. For example, you know you prefer to work on deep concept explanations, you can choose the
concept
label. new content
for when something needs to be written from scratch.docs-migration
is used when content already exists but needs to be rewritten.infrastructure
for technical changes; great if you're interested in diving into our codebaseadvanced-experience
for issues that require advanced Solid knowledge to implementno-experience-needed
for issues that you can help with even if you don't have Solid knowledge
Note If you've never submitted a pull request on GitHub before, check out this overview.
- Make sure your PR addresses an existing Issue.
- Group your work so that one PR solves one problem.
- Before you make a large PR, try to discuss it with the Docs Team on #docs. This will make sure we're on the same page and increase the chances of your PR getting merged.
- When you make a PR, you get a Netlify preview link. If you're not done with your changes but want that link to share with us, feel free to make a draft PR and add
[Draft]
to the title.
Note Existing PRs and Issues need reviewing, triaging, and feedback, too! You can make valuable contributions by commenting, suggesting, testing, researching, brainstorming and generally helping in all areas on GitHub!
Our site is build on SolidStart. This is a framework that's still in development, so if you have any issues, check out the #docs or #solid-start channels on Discord. (In fact, the SolidStart team is working on documentation within our repo, too!)
We have two folders of note: content and src. content contains all of the pages and page-specific components. This includes the four content folders corresponding to our four content types:
content/guides/tutorials
content/guides/how-to-guides
content/guides/foundations
content/references/concepts
content/references/api-reference
(not being worked on currently, as we have the existing API reference)
In src, we have the SolidStart entry files, the root component, and the md.tsx
component which maps markdown syntax to elements. Of note:
src/components
: General components, like the sidebar navigation, footer, and Asides.src/NAV_SECTIONS.ts
: This file determines the two sidebar navigation sections, Guides and Reference. Guides contains Tutorials and How-To Guides, and Reference contains Concept pages and API reference.
Every content page must have its own folder, even if it only has one page. For example, the Tracking concept page is one page, so it is found in an index.md
file inside content/references/concepts/tracking
. The Getting Started with Solid tutorial has several pages, which are found inside content/guides/tutorials/getting-started-with-solid
.
These folders will automatically generate routes; so, content/guides/tutorials/getting-started-with-solid/installing-solid
will be shown at https://docs.solidjs.com/guides/tutorials/getting-started-with-solid/installing-solid
.
If a content page has its own custom components and code snippets, place these inside its content folder. See the Getting Started with Solid folder for an example.
Warning There is also
start
folder incontent/routes
; it is a heavy work-in-progress managed by the SolidStart team and does not yet follow our Writing guide.
- Choose one of the four folders inside
content/
, corresponding to your page's content type - Create a new folder inside that folder. The new folder's name should be the kebab case of your page's title: e.g.,
getting-started-with-solid
. - Add
mdx
files for each subpage.
Feel free to submit a PR at this stage, and we can handle adding it to the nav. But if you'd like to do that:
- Open
NAV_SECTIONS.ts
. This will allow you to add your new page to the nav. If your page is a tutorial or how-to guide, edit theGUIDES_SECTIONS
object; if it's a concept page, edit theREFERENCE_SECTIONS
object. - Find the object key corresponding to your content type. Then, add a new object to its
pages
array. - If your page doesn't have subpages, provide a
name
and alink
property. (Search the file for "Tracking" for an example) - If your page does subpages, provide a
name
property and apages
array which contains your subpages. (Search the file for "Getting Started with Solid" for an example)