This repo contains the website configuration and documentation for NativeBase website.
- Git.
- Node (version 12 or greater).
- Yarn (version 1.5 or greater).
- A fork of the repo (for any contributions).
- A clone of the
websiterepo.
yarnto install the website's workspace dependencies.cd remark-snackplayerto go into the snackplayer plugin.yarnto install the snackplayer plugin's dependencies.cd ..to go back to website root directory.
yarn startto start the development server (powered by Docusaurus 2).open http://localhost:3000/to open the site in your preferred browser.
If you would like to contribute an edit or addition to the docs, then all our content is generated from markdown files you can find in the docs directory.
To edit the internals of how the site is built, you may want to get familiarized with how the site is built. The NativeBase website is a static site generated using Docusaurus 2. Visit the Docusaurus website to learn more about all the available configuration options.
The following is a high-level overview of relevant files and folders.
website/
├── blog/
│ ├── ...
├── docs/
│ ├── migration/
│ ├── Accordion.md
│ ├── ...
│ ├── FAB.md
│ ├── ...
├── plugins/
│ ├── docusaurus-tailwindcss-loader/
├── remark-snackplayer/
│ └── en/
├── src/
│ ├── components/
│ │ ├── AndroidBadge/
│ │ └── ...
│ ├── css/
│ │ ├── custom.css
│ ├── img/
│ │ ├── Discord.js
│ │ └── ...
│ ├── pages/
│ │ ├── index.js
│ │ └── styles.module.css
│ ├── theme/
│ │ ├── Navbar.js
│ │ └── styles.module.css
├── static/
│ ├── img/
├── versioned_docs/
│ ├── version-3.0.0-next.13/
│ └── ...
├── versioned_sidebars/
│ ├── version-3.0.0-next.13-sidebars.json
│ └── ...
├── babel.config.js
├── docusaurus.config.js
├── package.json
├── sidebars.json
├── snackPlayerInitializer.js
├── tailwind.config.js
└── versions.json
As mentioned above, the docs folder contains the markdown source files for all of the docs pages in the NativeBase website. In most cases, you will want to edit the files within this directory. If you're adding a new doc or you need to alter the order the docs appear in the sidebar, take a look at the sidebars.json file in the website directory. The sidebars file contains a list of document ids that should match those defined in the header metadata (aka frontmatter) of the docs markdown files.
The NativeBase website is versioned to allow users to go back and see the API reference docs for any given native-base version. A new version of the website is generally generated whenever there is a new native-base release. When this happens, any changes made to the docs and sidebars.json files will be copied over to the corresponding location within versioned_docs and versioned_sidebars.
Note: Do not edit the auto-generated files within
versioned_docsorversioned_sidebarsunless you are sure it is necessary. Edits made to older versions will not be propagated to newer versions of the documentation.
Docusaurus keeps track of the list of versions for the site in the versions.json file. The ordering of the versions in this file should be in reverse chronological order.
The main config file for the website can be found at docusaurus.config.js. This file tells Docusaurus how to build the website. Edits to this file are rarely necessary.
The src/components subdirectory contains JavaScript and React components that are used in different parts of the website.
The src/pages subdirectory contains the React components that make up the non-documentation pages of the site, such as the landing page..
The src/theme subdirectory contains the swizzled React components from the Docusaurus theme.
git checkout masterin your local repository.git pull origin masterto ensure you have the latest main code.git checkout -b the-name-of-my-branchto create a branch.replace
the-name-of-my-branchwith a suitable name, such asupdate-animations-page
- Follow the "Running locally" instructions.
- Save the files and check in the browser.
- Some changes may require a server restart to generate new files. (Pages in
docsalways do!) - Edits to pages in
docswill only be visible in the latest version of the documentation, called "Next", located under thedocs/nextpath.
Visit http://localhost:3000/docs/next/YOUR-DOCS-PAGE to see your work..
If possible, test any visual changes in all latest versions of the following browsers:
- Chrome and Firefox on the desktop.
- Chrome and Safari on mobile.
git add -A && git commit -m "My message"to stage and commit your changes.replace
My messagewith a commit message, such asFixed typo in Accordion Examplegit push my-fork-name the-name-of-my-branch- Go to the nativebase/website repo and you should see recently pushed branch.
- Follow GitHub's instructions and create a Pull Request to merge your branch in
master. - Describe briefly your changes (in case of visual changes, please include screenshots).