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
website
repo.
yarn
to install the website's workspace dependencies.cd remark-snackplayer
to go into the snackplayer plugin.yarn
to install the snackplayer plugin's dependencies.cd ..
to go back to website root directory.
yarn start
to 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_docs
orversioned_sidebars
unless 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 master
in your local repository.git pull origin master
to ensure you have the latest main code.git checkout -b the-name-of-my-branch
to create a branch.replace
the-name-of-my-branch
with 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
docs
always do!) - Edits to pages in
docs
will only be visible in the latest version of the documentation, called "Next", located under thedocs/next
path.
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 message
with a commit message, such asFixed typo in Accordion Example
git 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).