Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(core): hash router option - browse site offline (experimental) #9859

Merged
merged 53 commits into from
May 19, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
53 commits
Select commit Hold shift + click to select a range
27b1acf
attempt to use hash-based history and make it work offline
slorber Feb 16, 2024
da45fff
Merge branch 'main' into slorber/offline-mode-poc-2
slorber Feb 22, 2024
de0df2d
Add router type to config file
slorber Feb 22, 2024
0c5034b
fix tests
slorber Feb 22, 2024
45c1c9d
add link hack
slorber Feb 22, 2024
25a9004
disable redirect plugin with the hash router?
slorber Feb 22, 2024
904f730
add siteConfig DOCUSAURUS_ROUTER env variable
slorber Feb 22, 2024
a1b9ba6
logging message
slorber Feb 22, 2024
547d8ab
sitemap should support hash router?
slorber Feb 22, 2024
4c5a9de
Disable PWA/client-redirects plugins in Hash Router mode
slorber Feb 22, 2024
c22da5a
Fix heading/TOC/anchor links with hash router
slorber Feb 22, 2024
4a22ebb
urlUtils normalizeUrl should support hash router
slorber Feb 23, 2024
5a5d2f3
simplify feeds unit tests
slorber Feb 23, 2024
81dbd82
blog feed support for Hash Router
slorber Feb 23, 2024
6c072c3
remove comment
slorber Feb 23, 2024
bffb2f0
add unit test for sitemap with hash router
slorber Feb 23, 2024
030688a
Add router config type doc
slorber Feb 23, 2024
62aa2cb
Make it possible to switch router dynamically
slorber Feb 23, 2024
6582ea7
Rework full build workflow for hash router support
slorber Feb 23, 2024
2f33aad
refactor: apply lint autofix
slorber Feb 23, 2024
e902401
Merge branch 'main' into slorber/offline-mode-poc-2
slorber May 17, 2024
b82e8a5
add missing route codegen after merge
slorber May 17, 2024
abc3a31
Encapsulate router impl switch in docusaurus core to avoid pnpm / yar…
slorber May 17, 2024
62fc20e
rename siteConfig import
slorber May 17, 2024
b80d22c
disable sitemap plugin with hash router
slorber May 17, 2024
e8ef286
disable blog feeds for hash router
slorber May 17, 2024
6282cca
improve disabled plugin warning
slorber May 17, 2024
b7d2884
Fix router type
slorber May 17, 2024
2c323f1
Move router config to siteConfig.future.experimental_router + add con…
slorber May 17, 2024
520bc92
fix webpack client config
slorber May 17, 2024
61f453e
fix unit tests breaking due to missing siteConfig.future
slorber May 17, 2024
62a25c5
Fix Docusaurus website config
slorber May 17, 2024
0a24bb7
simpler router switch
slorber May 17, 2024
9bbb135
simpler router switch
slorber May 17, 2024
15cc555
fix dev server with hash router + baseUrl
slorber May 17, 2024
f12aeee
fix hash router build
slorber May 17, 2024
bbc94c7
do not emit Algolia opensearch file with hash router
slorber May 17, 2024
533e307
Extract StaticDirectoriesCopyPlugin + move it to the client webpack c…
slorber May 17, 2024
1dad032
Add some tests for useBaseUrl with hash router
slorber May 17, 2024
f8edab1
basic router type docs
slorber May 17, 2024
b1f2c8d
revert useless serverEntry hack
slorber May 17, 2024
0465e7e
simplify ssg params
slorber May 17, 2024
a36ab2e
Add CI workflow for build with hash router
slorber May 17, 2024
905e681
fix CI workflow?
slorber May 17, 2024
4b7a8c2
only apply hash router logic when the hash router is enabled for html…
slorber May 17, 2024
db860a8
Add hack comment
slorber May 17, 2024
d877806
deploy hash router to github pages
slorber May 19, 2024
2b5e458
deploy hash router to github pages
slorber May 19, 2024
19745dc
deploy hash router to github pages
slorber May 19, 2024
a732f95
deploy hash router to github pages
slorber May 19, 2024
3610306
deploy hash router to github pages
slorber May 19, 2024
2de9c18
deploy hash router to github pages
slorber May 19, 2024
7cf6500
deploy hash router to github pages
slorber May 19, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Rework full build workflow for hash router support
Do not compile a server bundle that we won't use
  • Loading branch information
slorber committed Feb 23, 2024
commit 6582ea79d76bb75e40736d1df564b31d43ff59ad
72 changes: 49 additions & 23 deletions packages/docusaurus/src/commands/build.ts
Original file line number Diff line number Diff line change
Expand Up @@ -23,12 +23,21 @@ import {
import {PerfLogger} from '../utils';

import {loadI18n} from '../server/i18n';
import {generateStaticFiles, loadAppRenderer} from '../ssg';
import {compileSSRTemplate} from '../templates/templates';
import {
generateHashRouterEntrypoint,
generateStaticFiles,
loadAppRenderer
} from '../ssg';
import {
compileSSRTemplate,
renderHashRouterTemplate,
} from '../templates/templates';
import defaultSSRTemplate from '../templates/ssr.html.template';
import type {
SSGParams} from '../ssg';

import type {Manifest} from 'react-loadable-ssr-addon-v5-slorber';
import type {LoadedPlugin, Props} from '@docusaurus/types';
import type {LoadedPlugin, Props, RouterType} from '@docusaurus/types';
import type {SiteCollectedData} from '../common';

export type BuildCLIOptions = Pick<
Expand Down Expand Up @@ -171,7 +180,11 @@ async function buildLocale({
PerfLogger.end('Loading site');

// Apply user webpack config.
const {outDir, plugins} = props;
const {
outDir,
plugins,
siteConfig: {router},
} = props;

// We can build the 2 configs in parallel
PerfLogger.start('Creating webpack configs');
Expand All @@ -196,14 +209,19 @@ async function buildLocale({

// Run webpack to build JS bundle (client) and static html files (server).
PerfLogger.start('Bundling');
await compile([clientConfig, serverConfig]);
if (router === 'hash') {
await compile([clientConfig]);
} else {
await compile([clientConfig, serverConfig]);
}
PerfLogger.end('Bundling');

PerfLogger.start('Executing static site generation');
const {collectedData} = await executeSSG({
props,
serverBundlePath,
clientManifestPath,
router,
});
PerfLogger.end('Executing static site generation');

Expand Down Expand Up @@ -242,11 +260,13 @@ async function executeSSG({
props,
serverBundlePath,
clientManifestPath,
router,
}: {
props: Props;
serverBundlePath: string;
clientManifestPath: string;
}) {
router: RouterType;
}): Promise<{collectedData: SiteCollectedData}> {
PerfLogger.start('Reading client manifest');
const manifest: Manifest = await fs.readJSON(clientManifestPath, 'utf-8');
PerfLogger.end('Reading client manifest');
Expand All @@ -257,32 +277,38 @@ async function executeSSG({
);
PerfLogger.end('Compiling SSR template');

const params: SSGParams = {
trailingSlash: props.siteConfig.trailingSlash,
outDir: props.outDir,
baseUrl: props.baseUrl,
manifest,
headTags: props.headTags,
preBodyTags: props.preBodyTags,
postBodyTags: props.postBodyTags,
ssrTemplate,
noIndex: props.siteConfig.noIndex,
DOCUSAURUS_VERSION,
};

if (router === 'hash') {
PerfLogger.start('Generate Hash Router entry point');
const content = renderHashRouterTemplate({params});
await generateHashRouterEntrypoint({content, params});
PerfLogger.end('Generate Hash Router entry point');
return {collectedData: {}};
}

PerfLogger.start('Loading App renderer');
const renderer = await loadAppRenderer({
serverBundlePath,
});
PerfLogger.end('Loading App renderer');

// TODO maybe there's a more elegant way than reusing our SSG pipeline?
const pathnames =
props.siteConfig.router === 'hash' ? ['/'] : props.routesPaths;

PerfLogger.start('Generate static files');
const ssgResult = await generateStaticFiles({
pathnames,
pathnames: props.routesPaths,
renderer,
params: {
trailingSlash: props.siteConfig.trailingSlash,
outDir: props.outDir,
baseUrl: props.baseUrl,
manifest,
headTags: props.headTags,
preBodyTags: props.preBodyTags,
postBodyTags: props.postBodyTags,
ssrTemplate,
noIndex: props.siteConfig.noIndex,
DOCUSAURUS_VERSION,
},
params,
});
PerfLogger.end('Generate static files');

Expand Down
14 changes: 14 additions & 0 deletions packages/docusaurus/src/ssg.ts
Original file line number Diff line number Diff line change
Expand Up @@ -226,6 +226,20 @@ It might also require to wrap your client code in ${logger.code(
return parts.join('\n');
}

export async function generateHashRouterEntrypoint({
content,
params,
}: {
content: string;
params: SSGParams;
}): Promise<void> {
await writeStaticFile({
pathname: '/',
content,
params,
});
}

async function writeStaticFile({
content,
pathname,
Expand Down
42 changes: 40 additions & 2 deletions packages/docusaurus/src/templates/templates.ts
Original file line number Diff line number Diff line change
Expand Up @@ -70,7 +70,7 @@ export function renderSSRTemplate({
result: AppRenderResult;
}): string {
const {
// baseUrl,
baseUrl,
headTags,
preBodyTags,
postBodyTags,
Expand Down Expand Up @@ -98,7 +98,7 @@ export function renderSSRTemplate({

const data: SSRTemplateData = {
appHtml,
baseUrl: './',
baseUrl,
htmlAttributes,
bodyAttributes,
headTags,
Expand All @@ -113,3 +113,41 @@ export function renderSSRTemplate({

return ssrTemplate(data);
}

export function renderHashRouterTemplate({
params,
}: {
params: SSGParams;
}): string {
const {
// baseUrl,
headTags,
preBodyTags,
postBodyTags,
manifest,
DOCUSAURUS_VERSION,
ssrTemplate,
} = params;

const {scripts, stylesheets} = getScriptsAndStylesheets({
manifest,
modules: [],
});

const data: SSRTemplateData = {
appHtml: '',
baseUrl: './',
htmlAttributes: '',
bodyAttributes: '',
headTags,
preBodyTags,
postBodyTags,
metaAttributes: [],
scripts,
stylesheets,
noIndex: false,
version: DOCUSAURUS_VERSION,
};

return ssrTemplate(data);
}
2 changes: 1 addition & 1 deletion packages/docusaurus/src/webpack/base.ts
Original file line number Diff line number Diff line change
Expand Up @@ -112,7 +112,7 @@ export async function createBaseConfig({
chunkFilename: isProd
? 'assets/js/[name].[contenthash:8].js'
: '[name].js',
publicPath: isServer ? baseUrl : 'auto',
publicPath: siteConfig.router === 'hash' ? 'auto' : baseUrl,
hashFunction: 'xxhash64',
},
// Don't throw warning when asset created is over 250kb
Expand Down
Loading