This directory contains the code and content for https://fluidframework.com.
The website is built using Docusaurus, a modern static website generator.
The Fluid Framework repository uses pnpm for dependency management.
If you don't have pnpm
installed, you will need to do so first.
pnpm i
There are two options for local testing.
The easiest way to get started testing the website is to leverage Docusaurus's start
functionality.
This command starts a local development server and opens up a browser window.
Most changes are reflected live without having to restart the server.
Before you can use this, you'll need to ensure our API documentation has been built. So start by running:
npm run build:generate-content
Then, run:
npm start
The following functionality will not work in this mode. Instead, you will need to build and serve
Our current offline search implementation does not work in this mode.
It requires running a full build to run its indexing.
To test search, you will need to use the build
and serve
workflow instead.
The second option, which is substantially slower, leverages the same build that our build pipelines use to generate our production site. First, run:
npm run build
This command generates static content into the build
directory and can be served using any static contents hosting service.
This includes the generation of API documentation contents.
To just run content generation steps, run build:generate-content
.
To just build the static site (without rebuilding the API documentation), run build:site
.
Then, run:
npm run serve
Note: the Docusaurus build is fairly slow.
If you don't need to test search, it is recommended to run npm start
instead.
This is faster, and will watch for content changes and update automatically.
You will still need to build the API documentation first.
To include repo-local API documentation when building the site locally, you will first need to do the following:
- Build the code from the root of the repo.
- Create a
.env
file in this directory with the following contents:LOCAL_API_DOCS=true
So long as the LOCAL_API_DOCS
environment variable is set to true
, local API documentation will be included when building the site.
To remove the local API docs, simply remove the above variable or set it to false
, npm run clean
and rebuild as needed.
The Fluid Framework website collects basic user telemetry to help improve the experience for our users. The telemetry data includes anonymous information such as:
- Daily / Monthly users
- Pages visited
- User flow
This data is collected in compliance with relevant privacy standards. For more information, please refer to our privacy policy.. If you have any concerns about telemetry, please reach out to our team via GitHub Issues.
To test this telemetry locally add the following key to the .env file. This key is used to instantiate Application Insights so that usage events can be tracked. The key can be requested from internal Microsoft Fluid Framework engineers.
INSTRUMENTATION_KEY=<key>
The Fluid Framework website is deployed using the build-docs pipeline. INSTRUMENTATION_KEY
is set as a pipeline variable here.
For details about authoring documentation content in Docusaurus, see here.
|--- docs (Current version documentation)
|--- versioned_docs (previous and future version documentation)
| |---version-x (version *x* documentation)
| |---version-local (special directory in which repo-local API docs are generated and can be previewed when building the site locally)
|--- src
| |--- components (React components available to other site documents, pages, and components)
| |--- css (CSS modules available to other site documents, pages, and components)
| |--- pages (Unversioned site contents)
| |--- theme (Theme component / page overrides)
MDX syntax (supported by Docusaurus) is powerful. But there is a subset of standard Markdown syntax that is not supported. For example, any HTML-like syntax will always be treated as JSX syntax, so standard embedded HTML patterns don't work. Most of the time, this isn't an issue, since substituting JSX syntax is generally fine. With some exceptions.
For an overview of how to leverage React components in MDX documentation, see here.
React components should be saved under src/components/...
.
They can be imported in other components, pages, and documents via @site/src/components/...
.
A common pattern for adding inline comments in .md
files looks like:
<!-- I am a comment -->
The replacement syntax to use in .mdx
files would be:
{/* I am a comment */}
(just like you would do in a JSX context!)
In GitHub-flavored Markdown, you can assign a custom anchor ID to a heading by appending {#<id>}
to the heading text.
E.g.,
# Foo {#bar}
Because curly braces are interpreted specially by JSX, this syntax doesn't work as is in .mdx
documents.
Instead, you'll need to escape the opening brace to prevent MDX from attempting to process the syntax as JSX.
E.g.,
# Foo \{#bar}
See the following Docusaurus issue for more context: facebook/docusaurus#9155.
Docusaurus has built-in support for mermaid diagrams. We recommend leveraging these when possible over alternatives (ascii art, binary image files, SVG, etc.).
Rationale:
- Docusaurus will ensure consistent styling
- Non-binary source, directly in the document.
For more details about leveraging Mermaid diagrams in Docusaurus, see here.
Documents and Pages are distinct concepts in Docusaurus. For an overview of each, see: Documents and Pages.
Some primary distinctions:
- Documents live under
docs
andversioned_docs
. Pages live undersrc/pages
. - Documents are versioned. Pages are not.
For an overview of how to configure sidebars in Docusaurus, see here.
The site's "current" version sidebar is configured via sidebars.ts
.
Sidebars for other versions are configured via versioned_sidebars/version-<version-id>.json
.
- Versioned sidebars do not yet support JS/TS file formats. See facebook/docusaurus#10407.
Note that sidebars are configured for documents under docs
and versioned_docs
; they do not apply to unversioned Pages.
For an overview of Docusaurus's versioning functionality, see here.
We currently offer versioned documentation for each of our supported major versions. This documentation is intended to be kept up-to-date with the most recent release of each major version series.
For now, this means we publish documentation (including generated API documentation) for versions 1.x
and 2.x
.
- We also support generating API documentation for the local repo code in local development only. See Local API docs build, but these are not intended to be published.
We aim to keep the number of concurrently maintained site versions minimized, for a number of reasons:
- Developer overhead - the more versions of the docs we offer, the more work we take on to keep documentation for supported versions up to date.
- User overhead - the more versions we offer, the more users have to think about when they engage with our website.
- Build performance - Docusaurus's build isn't fast. The more versions we add to our suite, the longer our build times become.
These steps are based on Docusaurus's tutorial here.
Note: generating the API documentation for the new "current" version will fail if the release branch for that version has not yet been created.
- Run
npx --no-install docusaurus docs:version v<current-major-version-number>
from the root of this directory. E.g.,... docusaurus docs:version v2
when prepping forv3
documentation.- This will copy the contents of
docs
intoversioned_docs
under the specified version ID. - This will also generate a sidebar configuration for the copied version under
versioned_sidebars
.
- This will copy the contents of
- Update
config/docs-versions.mjs
to update the version ID for the "current" version, and add the newly frozen version to theotherVersions
list. This will automatically update aspects of the site, including:- Which versions of the API documentation are generated during the build
- The version selection drop-down in the site header
Generally, it is recommended to include file extensions in links when possible.
E.g., prefer [foo](./foo.mdx)
over [foo](./foo)
.
- Docusaurus applies a different resolution strategy for relative file path links than it does for URL links. See: https://docusaurus.io/docs/markdown-features/links
When adding image assets for use in the website, please follow the instructions outlined here. Namely, avoid adding binary files like images to the GitHub repo. Instead, upload them to our Azure blob storage, and reference by URL. E.g., https://storage.fluidframework.com/static/images/website/brainstorm-example.png
Images may only be uploaded by Microsoft Fluid team members. If you do not have the appropriate permissions, but would like to contribute to our documentation, please reach out to us here.
To meet our privacy requirements, it is important that we avoid embedding content that will collect cookies.
To ensure this, please never embed YouTube videos using their standard embed format.
Instead, be sure to leverage https://www.youtube-nocookie.com/
.
To make this easy, we have a YoutubeVideo
component under @site/src/components/youtubeVideo
that can be used to embed a specified video ID using the correct settings.
Example:
import { YoutubeVideo } from "@site/src/components/youtubeVideo";
...
<YoutubeVideo videoId="foo" className="my-styling" />
The following npm scripts are supported in this directory:
Script | Description |
---|---|
build |
Build everything: the API documentation, the website, the tests, etc. |
build:api-documentation |
Download API model artifacts and generate API documentation. |
prebuild:docusaurus |
Runs pre-site build metadata generation. |
build:docusaurus |
Build the website with Docusaurus. |
build:generate-content |
Generate site content. Includes API documentation, as well as content generated / embedded by markdown-magic . |
build:markdown-magic |
Run markdown-magic to generate / embed contents in Markdown files. |
build:site |
Build the site, including API documentation. |
build:test |
TSC build of the test code as a sanity check. |
check-links |
Run link validation on the website. Requires the website to be running locally, either via start or serve . |
ci:check-links |
check-links variant for CI. Serves the site before running checks. |
clean |
Clean up generated artifacts (build output, etc.). |
clean:api-documentation |
Clean up generate API documentation content. |
clean:doc-models |
Clean up downloaded API model artifacts. |
clean:docusaurus |
Run Docusaurus's "clean". |
clean:test |
Clean up generated test output |
clean:versions-json |
Clean up generated versions.json file. |
download-doc-models |
Download API model artifacts published from our release branches. |
eslint |
Run eslint . |
eslint:fix |
Run eslint with auto-fix enabled. |
format |
Fix formatting issues with prettier . |
generate-api-documentation |
Generate API documentation from downloaded API model artifacts. |
generate-versions |
dotenv -- node ./infra/generate-versions.mjs |
lint |
Check for linter violations. |
lint:fix |
Auto-fix linter violations. |
preinstall |
Ensure developer is using pnpm . |
prettier |
Check for formatting issues with prettier . |
prettier:fix |
Fix formatting issues with prettier . |
rebuild |
Clean up existing generated artifacts and re-run the build. |
serve |
Serves the built website using Docusaurus. |
serve-with-azure-emulation |
Serves the built website using Docusaurus, including Azure service emulation for our Azure functions. |
prestart |
Runs pre-site build metadata generation. |
start |
Runs the website in watch mode with Docusaurus. |
pretest |
Install necessary playwright dependencies before running tests. |
test |
Run tests using playwright |