1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-10-22 11:18:20 +02:00
unleash.unleash/website
Fredrik Strand Oseberg 2fd40e7372
fix: only load ga and gtm in production (#10612)
CookieYes was throwing an uncaught error triggered by GA and GTM
scripts. We don't want analytics to run in development anyway, so I
disabled them in these environments.
2025-09-04 09:35:56 +02:00
..
.yarn/releases
docs docs: 7.2 updates (#10611) 2025-09-03 14:50:59 +02:00
remote-content docs: some details spotted to align with new token types (#10523) 2025-08-22 10:47:32 -03:00
src fix: only load ga and gtm in production (#10612) 2025-09-04 09:35:56 +02:00
static docs: 7.2 updates (#10611) 2025-09-03 14:50:59 +02:00
.gitignore Docusaurus v3 (#8485) 2024-10-30 11:55:51 +00:00
.nvmrc Update docs for data and privacy (#9397) 2025-02-28 16:28:32 +01:00
.yarnrc.yml chore: Bumped Yarn to 4.9.2 (#10126) 2025-06-12 12:01:43 +02:00
docusaurus.config.ts Fix/website performance (#10489) 2025-08-27 15:54:32 +02:00
package.json Fix/website performance (#10489) 2025-08-27 15:54:32 +02:00
prepare-generated-docs.mjs
README.md
sidebars.ts docs: add feature and versioning info (#10547) 2025-08-28 17:51:52 +02:00
tsconfig.json
vercel.json chore: update references to repositories (#10465) 2025-08-06 14:45:26 +02:00
yarn.lock Fix/website performance (#10489) 2025-08-27 15:54:32 +02:00

Website

This website is built using Docusaurus 2, a modern static website generator.

Installation

In a terminal, cd into the website folder of the locally cloned unleash repository and then start the installation.

cd unleash/website
yarn install

Generate OpenAPI docs

yarn generate

Generate the Open API docs that live at Reference documentation > APIs > OpenAPI

Local Development

Before running the docs the first time, you'll need to generate external documentation, as described in the generate OpenAPI docs section.

yarn start

Start a local development server and opens up a browser window. Most changes are reflected live without having to restart the server.

Build

yarn build

This command generates static content into the build directory and can be served using any static contents hosting service.

Cleaning dependencies and caches

If you're upgrading many dependencies, it's always good to delete the node_modules directory, refresh yarn.lock and clean the various caches.

rm -rf node_modules
rm -rf .docusaurus
rm -rf docs/reference/api/unleash
rm -rf yarn.lock
touch yarn.lock

This website uses Algolia DocSearch v3 with a dedicated Algolia application and a hosted crawler. All configuration is managed directly through the Algolia dashboard.

Search prioritization

Conceptual and reference documentation pages should rank over specific API endpoints, while still allowing Algolia's relevance algorithm to find the most accurate results.

The configuration

Inside the Algolia crawler: The crawler configuration has been updated to look for a tag in the HTML of each page. It extracts the numerical value and saves it as a priority attribute on the search record. Pages without this tag are automatically assigned a default priority of 0. Algolia is configured to use the priority attribute for custom ranking in descending order.

Within the docs: We have a reusable React component, <SearchPriority /> -> src/components/SearchPriority.jsx. This component provides a simple shortcut to add the correct tag to any .mdx page.

For high priority pages, use <SearchPriority level="high" />. For pages referencing deprecated features use <SearchPriority level="noindex" />. For autogenerated pages, use searchPriority: 'high' key-value pair in the document definition of the file (works at the root level or for individual subpages). See website/remote-content/edge-proxy.js as an example.

Troubleshooting

TypeError: source_default(...).bold is not a function

If you get an error like this, it's probably due to a formatting issue within one of the markdown files. It could be

  • unescaped angle brackets (markdown will try to parse <your-key> (when it's not quoted) as HTML, which breaks the build)
  • incorrectly formatted titles or missing pieces of files
  • a lot of other stuff.
Component Figure was not imported, exported, or provided by MDXProvider as global scope

TypeError: source_default(...).bold is not a function
[ERROR] Unable to build website for locale en.

This error is very hard to debug, but there is a trick that appears to work (as shared in this discussion on docusaurus' repo):

In node_modules/@docusaurus/core/lib/client/serverEntry.js, remove all references to chalk. You can use a regex replace for that, by replacing chalk(\w|\.)+ with the empty string.

Depending on your editor, that regex might need more escapes. For instance, here's a command to run with evil-ex in Emacs:

%s/chalk\(\w\|\.\)+//g

For macOS sed, it'd be:

sed -i '' 's/chalk\(\w\|\.\)\+//g' node_modules/@docusaurus/core/lib/client/serverEntry.js

For GNU sed:

sed -i 's/chalk\(\w\|\.\)\+//g' node_modules/@docusaurus/core/lib/client/serverEntry.js

That might turn your error into something like this:

[ERROR] Docusaurus server-side rendering could not render static page with path /reference/api/unleash/change-requests.
[ERROR] Docusaurus server-side rendering could not render static page with path /reference/api/unleash/feature-types.
[ERROR] Docusaurus server-side rendering could not render static page with path /reference/api/unleash/frontend-api.
[ERROR] Docusaurus server-side rendering could not render static page with path /reference/api/unleash/maintenance.
[ERROR] Docusaurus server-side rendering could not render static page with path /reference/api/unleash/notifications.
[ERROR] Docusaurus server-side rendering could not render static page with path /reference/api/unleash/personal-access-tokens.
[ERROR] Docusaurus server-side rendering could not render static page with path /reference/api/unleash/segments.
[ERROR] Docusaurus server-side rendering could not render static page with path /reference/api/unleash/service-accounts.
[ERROR] Docusaurus server-side rendering could not render static page with path /reference/api/unleash/telemetry.
[ERROR] Docusaurus server-side rendering could not render static page with path /reference/api/unleash/unstable.
Component Figure was not imported, exported, or provided by MDXProvider as global scope

Error: Unexpected: cant find current sidebar in context
[ERROR] Unable to build website for locale en.