This repository hosts the source code for the Embrace documentation site.
The docs site is automatically deployed from this repository on a regular daily interval. We welcome all contributors who would like to grow knowledge and clarity regarding the Embrace mobile SDKs, dashboard, and data forwarding features. Please feel free to make a pull request to make an addition, or open an issue to make a suggestion of what might be change.
This website is built using Docusaurus, a modern static documentation generator written using React. Some specific changes to Docusaurus are noted below in Embrace Customizations.
You can make edits to these docs from within GitHub UI or by forking/cloning the repo to make edits locally.
For quick edits that don't require adding or reorganizing pages, you can edit the specific Markdown file from within the docs folder. Edit the file, commit your changes and make a PR.
For larger reorganization, you should follow the structure of the docs folder to see where your new pages will go. Any change to the landing page organization will be in the Categories.tsx file. Any change to the outer-most level of organization will be in the sidebars.ts file.
You can edit and build these docs on your local machine by pulling the repo and following the instructions below. We recommend using an integrated development environment like VSCode to simultaneously edit the source files, note markdown or linking errors, and run the docs via Node.
$ npm i
This command will install all node packages and their dependencies. This command is usually optional, as the packages are prebuilt in this repository.
$ npm start
This command starts a local development server and opens up a browser window. Most changes are reflected live when a file is saved, without having to restart the server.
$ npm run build
This command generates static content into the build
directory and can be served using any static contents hosting service.
You can serve contents of that static directory using npm run serve
Besides basic "markdown" syntax we are using these Docusaurus features:
- Admonitions for various hints/tips/warnings "callouts"
- Tabs to show code snippets for several languages or platforms. Note that tabs support synchronizing their state across multiple (for example, several sets of tabs on one page will all switch from Swift to Objective-C together if user clicks on any one).
- MDX and React to load reusable snippets of text from shared/ directory
The following are the extras we added to handle Embrace's documentation:
@easyops-cn/docusaurus-search-local
search pluginsrc/remark/embrace-sdk-version.js
Remark plugin that inserts latest SDK version (fromembrace.json
into various code blocks), using{{ embrace_sdk_version platform="something" }}
syntax.- Snippets in
shared/
that are loaded on several pages
And we customized the following:
- Various logo and titles, as well as site-wide footer in
docusaurus.config.js
- Extra syntax-highlighting languages in
docusaurus.config.js
- Single sidebar used site-wide in
sidebars.js
that also enforse some collapsed/open state - Homepage via
src/components/HomepageFeatures
insrc/pages/index.js
- Some styling via
src/css/custom.css
(for both light and dark modes)
- If you make changes to
docusaurus.config.js
or some other site-wide.js
files you typically need to fully restartnpm start
process and not rely on its hot-reloading. - The searchbox on the site is only indexed for static
build
and is not available via localnpm start
. - Docusaurus will navigate relative links for you. When linking within these docs, use a path from the section's folder rather than the absolute path of the page. Also, you can leave off the markdown file extension in a link. For example, linking to iOS trace instrumentation should be in
/ios/open-source/tracing
, not/docs/ios/open-source/tracing.md
.