@docusaurus/core 2.0.0-beta.2 → 2.0.0-beta.22

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (223) hide show
  1. package/README.md +1 -0
  2. package/bin/beforeCli.mjs +140 -0
  3. package/bin/docusaurus.mjs +221 -0
  4. package/lib/babel/preset.d.ts +8 -3
  5. package/lib/babel/preset.js +10 -8
  6. package/lib/client/App.d.ts +2 -3
  7. package/lib/client/App.js +31 -28
  8. package/lib/client/BaseUrlIssueBanner/index.d.ts +27 -0
  9. package/lib/client/{baseUrlIssueBanner/BaseUrlIssueBanner.js → BaseUrlIssueBanner/index.js} +25 -14
  10. package/lib/client/{baseUrlIssueBanner → BaseUrlIssueBanner}/styles.module.css +0 -0
  11. package/lib/client/ClientLifecyclesDispatcher.d.ts +16 -0
  12. package/lib/client/ClientLifecyclesDispatcher.js +39 -0
  13. package/lib/client/LinksCollector.d.ts +3 -3
  14. package/lib/client/LinksCollector.js +8 -13
  15. package/lib/client/PendingNavigation.d.ts +17 -3
  16. package/lib/client/PendingNavigation.js +47 -72
  17. package/lib/client/{baseUrlIssueBanner/BaseUrlIssueBanner.d.ts → SiteMetadataDefaults.d.ts} +1 -2
  18. package/lib/client/SiteMetadataDefaults.js +21 -0
  19. package/lib/{choosePort.d.ts → client/browserContext.d.ts} +5 -5
  20. package/lib/client/browserContext.js +22 -0
  21. package/lib/client/clientEntry.js +14 -9
  22. package/lib/client/docusaurus.d.ts +12 -6
  23. package/lib/client/docusaurus.js +30 -43
  24. package/lib/client/docusaurusContext.d.ts +12 -0
  25. package/lib/client/docusaurusContext.js +25 -0
  26. package/lib/client/exports/BrowserOnly.d.ts +3 -5
  27. package/lib/client/exports/BrowserOnly.js +14 -8
  28. package/lib/client/exports/ComponentCreator.d.ts +6 -2
  29. package/lib/client/exports/ComponentCreator.js +75 -42
  30. package/lib/client/exports/ErrorBoundary.d.ts +18 -0
  31. package/lib/client/exports/ErrorBoundary.js +37 -0
  32. package/lib/client/exports/Head.d.ts +2 -3
  33. package/lib/client/exports/Head.js +3 -4
  34. package/lib/client/exports/Interpolate.d.ts +2 -2
  35. package/lib/client/exports/Interpolate.js +20 -49
  36. package/lib/client/exports/Link.d.ts +4 -10
  37. package/lib/client/exports/Link.js +40 -40
  38. package/lib/client/exports/Translate.d.ts +1 -1
  39. package/lib/client/exports/Translate.js +14 -9
  40. package/lib/client/exports/constants.js +1 -11
  41. package/lib/client/exports/isInternalUrl.js +1 -1
  42. package/lib/client/exports/renderRoutes.d.ts +1 -2
  43. package/lib/client/exports/renderRoutes.js +1 -2
  44. package/lib/client/exports/router.d.ts +1 -1
  45. package/lib/client/exports/router.js +1 -1
  46. package/lib/client/exports/useBaseUrl.js +11 -14
  47. package/lib/client/exports/useDocusaurusContext.d.ts +2 -3
  48. package/lib/client/exports/useDocusaurusContext.js +3 -9
  49. package/lib/client/exports/useGlobalData.d.ts +4 -3
  50. package/lib/client/exports/useGlobalData.js +6 -13
  51. package/lib/{server/versions/__tests/index.test.d.ts → client/exports/useIsBrowser.d.ts} +1 -1
  52. package/lib/client/exports/useIsBrowser.js +11 -0
  53. package/lib/client/exports/useRouteContext.d.ts +8 -0
  54. package/lib/client/exports/useRouteContext.js +15 -0
  55. package/lib/client/flat.d.ts +12 -2
  56. package/lib/client/flat.js +19 -15
  57. package/lib/client/normalizeLocation.d.ts +2 -5
  58. package/lib/client/normalizeLocation.js +14 -10
  59. package/lib/client/prefetch.d.ts +1 -2
  60. package/lib/client/prefetch.js +12 -32
  61. package/lib/client/preload.d.ts +3 -4
  62. package/lib/client/preload.js +5 -12
  63. package/lib/client/routeContext.d.ts +13 -0
  64. package/lib/client/routeContext.js +31 -0
  65. package/lib/client/serverEntry.d.ts +10 -0
  66. package/lib/client/serverEntry.js +108 -146
  67. package/lib/client/theme-fallback/Error/index.d.ts +10 -0
  68. package/lib/client/theme-fallback/Error/index.js +45 -0
  69. package/lib/client/theme-fallback/Layout/index.d.ts +10 -0
  70. package/lib/client/theme-fallback/Layout/index.js +2 -26
  71. package/lib/client/theme-fallback/Loading/index.d.ts +9 -0
  72. package/lib/client/theme-fallback/Loading/index.js +50 -116
  73. package/lib/client/{exports/context.js → theme-fallback/NotFound/index.d.ts} +2 -2
  74. package/lib/client/theme-fallback/NotFound/index.js +19 -18
  75. package/lib/client/theme-fallback/Root/index.d.ts +10 -0
  76. package/lib/client/theme-fallback/Root/index.js +2 -6
  77. package/lib/{server/html-tags/htmlTags.d.ts → client/theme-fallback/SiteMetadata/index.d.ts} +2 -1
  78. package/lib/client/theme-fallback/SiteMetadata/index.js +10 -0
  79. package/lib/commands/build.d.ts +6 -2
  80. package/lib/commands/build.js +81 -64
  81. package/lib/commands/clear.d.ts +7 -1
  82. package/lib/commands/clear.js +34 -21
  83. package/lib/commands/deploy.d.ts +5 -2
  84. package/lib/commands/deploy.js +104 -81
  85. package/lib/commands/external.d.ts +2 -2
  86. package/lib/commands/external.js +9 -11
  87. package/lib/commands/serve.d.ts +8 -2
  88. package/lib/commands/serve.js +29 -28
  89. package/lib/commands/start.d.ts +9 -2
  90. package/lib/commands/start.js +109 -101
  91. package/lib/commands/swizzle/actions.d.ts +23 -0
  92. package/lib/commands/swizzle/actions.js +101 -0
  93. package/lib/commands/swizzle/common.d.ts +33 -0
  94. package/lib/commands/swizzle/common.js +56 -0
  95. package/lib/commands/swizzle/components.d.ts +29 -0
  96. package/lib/commands/swizzle/components.js +200 -0
  97. package/lib/commands/swizzle/config.d.ts +10 -0
  98. package/lib/commands/swizzle/config.js +84 -0
  99. package/lib/{server/client-modules/index.d.ts → commands/swizzle/context.d.ts} +2 -2
  100. package/lib/commands/swizzle/context.js +24 -0
  101. package/lib/commands/swizzle/index.d.ts +8 -0
  102. package/lib/commands/swizzle/index.js +118 -0
  103. package/lib/commands/swizzle/prompts.d.ts +12 -0
  104. package/lib/commands/swizzle/prompts.js +110 -0
  105. package/lib/{client/exports/context.d.ts → commands/swizzle/tables.d.ts} +3 -4
  106. package/lib/commands/swizzle/tables.js +113 -0
  107. package/lib/commands/swizzle/themes.d.ts +20 -0
  108. package/lib/commands/swizzle/themes.js +106 -0
  109. package/lib/commands/writeHeadingIds.d.ts +2 -6
  110. package/lib/commands/writeHeadingIds.js +22 -81
  111. package/lib/commands/writeTranslations.d.ts +4 -5
  112. package/lib/commands/writeTranslations.js +46 -25
  113. package/lib/index.d.ts +9 -9
  114. package/lib/index.js +14 -14
  115. package/lib/server/brokenLinks.d.ts +4 -17
  116. package/lib/server/brokenLinks.js +67 -56
  117. package/lib/server/clientModules.d.ts +12 -0
  118. package/lib/server/clientModules.js +20 -0
  119. package/lib/server/config.d.ts +5 -2
  120. package/lib/server/config.js +29 -6
  121. package/lib/server/configValidation.d.ts +4 -4
  122. package/lib/server/configValidation.js +86 -41
  123. package/lib/server/getHostPort.d.ts +14 -0
  124. package/lib/server/getHostPort.js +79 -0
  125. package/lib/server/htmlTags.d.ts +12 -0
  126. package/lib/server/htmlTags.js +62 -0
  127. package/lib/server/i18n.d.ts +3 -13
  128. package/lib/server/i18n.js +21 -55
  129. package/lib/server/index.d.ts +28 -13
  130. package/lib/server/index.js +83 -165
  131. package/lib/server/plugins/configs.d.ts +51 -0
  132. package/lib/server/plugins/configs.js +101 -0
  133. package/lib/server/plugins/index.d.ts +9 -8
  134. package/lib/server/plugins/index.js +73 -134
  135. package/lib/server/plugins/init.d.ts +6 -5
  136. package/lib/server/plugins/init.js +44 -109
  137. package/lib/server/plugins/moduleShorthand.d.ts +9 -0
  138. package/lib/server/plugins/moduleShorthand.js +46 -0
  139. package/lib/server/plugins/pluginIds.d.ts +5 -1
  140. package/lib/server/plugins/pluginIds.js +12 -7
  141. package/lib/server/plugins/presets.d.ts +12 -0
  142. package/lib/server/plugins/presets.js +49 -0
  143. package/lib/server/plugins/routeConfig.d.ts +11 -0
  144. package/lib/server/plugins/routeConfig.js +54 -0
  145. package/lib/server/plugins/synthetic.d.ts +20 -0
  146. package/lib/server/plugins/synthetic.js +111 -0
  147. package/lib/server/routes.d.ts +39 -7
  148. package/lib/server/routes.js +182 -95
  149. package/lib/server/siteMetadata.d.ts +12 -0
  150. package/lib/server/siteMetadata.js +81 -0
  151. package/lib/server/translations/translations.d.ts +14 -19
  152. package/lib/server/translations/translations.js +40 -72
  153. package/lib/server/translations/translationsExtractor.d.ts +10 -4
  154. package/lib/server/translations/translationsExtractor.js +158 -122
  155. package/lib/server/utils.d.ts +9 -3
  156. package/lib/server/utils.js +7 -9
  157. package/lib/webpack/aliases/index.d.ts +34 -0
  158. package/lib/webpack/aliases/index.js +106 -0
  159. package/lib/webpack/base.d.ts +3 -4
  160. package/lib/webpack/base.js +45 -57
  161. package/lib/webpack/client.d.ts +3 -3
  162. package/lib/webpack/client.js +12 -19
  163. package/lib/webpack/plugins/ChunkAssetPlugin.d.ts +13 -3
  164. package/lib/webpack/plugins/ChunkAssetPlugin.js +24 -17
  165. package/lib/webpack/plugins/CleanWebpackPlugin.d.ts +6 -25
  166. package/lib/webpack/plugins/CleanWebpackPlugin.js +33 -17
  167. package/lib/webpack/plugins/LogPlugin.d.ts +1 -1
  168. package/lib/webpack/plugins/LogPlugin.js +4 -5
  169. package/lib/webpack/plugins/WaitPlugin.d.ts +3 -3
  170. package/lib/webpack/plugins/WaitPlugin.js +1 -1
  171. package/lib/webpack/server.d.ts +5 -5
  172. package/lib/webpack/server.js +22 -9
  173. package/lib/{client → webpack}/templates/index.html.template.ejs +0 -0
  174. package/lib/webpack/templates/ssr.html.template.d.ts +8 -0
  175. package/lib/{client → webpack}/templates/ssr.html.template.js +3 -2
  176. package/lib/webpack/utils.d.ts +15 -31
  177. package/lib/webpack/utils.js +61 -182
  178. package/package.json +81 -77
  179. package/bin/docusaurus.js +0 -325
  180. package/lib/.tsbuildinfo +0 -1
  181. package/lib/choosePort.js +0 -105
  182. package/lib/client/.eslintrc.js +0 -29
  183. package/lib/client/.tsbuildinfo +0 -1
  184. package/lib/client/client-lifecycles-dispatcher.d.ts +0 -12
  185. package/lib/client/client-lifecycles-dispatcher.js +0 -27
  186. package/lib/client/nprogress.css +0 -36
  187. package/lib/commands/buildRemoteBranchUrl.d.ts +0 -7
  188. package/lib/commands/buildRemoteBranchUrl.js +0 -27
  189. package/lib/commands/commandUtils.d.ts +0 -3
  190. package/lib/commands/commandUtils.js +0 -21
  191. package/lib/commands/swizzle.d.ts +0 -9
  192. package/lib/commands/swizzle.js +0 -245
  193. package/lib/constants.d.ts +0 -18
  194. package/lib/constants.js +0 -23
  195. package/lib/server/client-modules/index.js +0 -14
  196. package/lib/server/duplicateRoutes.d.ts +0 -10
  197. package/lib/server/duplicateRoutes.js +0 -38
  198. package/lib/server/html-tags/htmlTags.js +0 -40
  199. package/lib/server/html-tags/index.d.ts +0 -9
  200. package/lib/server/html-tags/index.js +0 -43
  201. package/lib/server/loadSetup.d.ts +0 -9
  202. package/lib/server/loadSetup.js +0 -25
  203. package/lib/server/plugins/applyRouteTrailingSlash.d.ts +0 -8
  204. package/lib/server/plugins/applyRouteTrailingSlash.js +0 -19
  205. package/lib/server/presets/index.d.ts +0 -11
  206. package/lib/server/presets/index.js +0 -48
  207. package/lib/server/themes/alias.d.ts +0 -8
  208. package/lib/server/themes/alias.js +0 -40
  209. package/lib/server/themes/index.d.ts +0 -12
  210. package/lib/server/themes/index.js +0 -47
  211. package/lib/server/versions/__fixtures__/dummy-plugin.js +0 -0
  212. package/lib/server/versions/__fixtures__/package.json +0 -3
  213. package/lib/server/versions/__tests/index.test.js +0 -25
  214. package/lib/server/versions/index.d.ts +0 -10
  215. package/lib/server/versions/index.js +0 -50
  216. package/lib/webpack/react-dev-utils-webpack5/README.md +0 -11
  217. package/lib/webpack/react-dev-utils-webpack5/evalSourceMapMiddleware.js +0 -57
  218. package/lib/webpack/react-dev-utils-webpack5/formatWebpackMessages.js +0 -138
  219. package/lib/webpack/react-dev-utils-webpack5/webpackHotDevClient.js +0 -285
  220. package/lib/webpack/sharedModuleAliases.d.ts +0 -10
  221. package/lib/webpack/sharedModuleAliases.js +0 -18
  222. package/tsconfig.client.json +0 -13
  223. package/tsconfig.json +0 -13
@@ -6,99 +6,100 @@
6
6
  * LICENSE file in the root directory of this source tree.
7
7
  */
8
8
  Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.start = void 0;
9
10
  const tslib_1 = require("tslib");
11
+ const fs_extra_1 = tslib_1.__importDefault(require("fs-extra"));
12
+ const path_1 = tslib_1.__importDefault(require("path"));
13
+ const lodash_1 = tslib_1.__importDefault(require("lodash"));
14
+ const logger_1 = tslib_1.__importDefault(require("@docusaurus/logger"));
10
15
  const utils_1 = require("@docusaurus/utils");
11
- const chalk = require("chalk");
12
16
  const chokidar_1 = tslib_1.__importDefault(require("chokidar"));
13
- const express_1 = tslib_1.__importDefault(require("express"));
14
17
  const html_webpack_plugin_1 = tslib_1.__importDefault(require("html-webpack-plugin"));
15
- const path_1 = tslib_1.__importDefault(require("path"));
16
- const lodash_1 = require("lodash");
17
18
  const openBrowser_1 = tslib_1.__importDefault(require("react-dev-utils/openBrowser"));
18
19
  const WebpackDevServerUtils_1 = require("react-dev-utils/WebpackDevServerUtils");
19
- const errorOverlayMiddleware_1 = tslib_1.__importDefault(require("react-dev-utils/errorOverlayMiddleware"));
20
- // import evalSourceMapMiddleware from 'react-dev-utils/evalSourceMapMiddleware';
21
- const evalSourceMapMiddleware_1 = tslib_1.__importDefault(require("../webpack/react-dev-utils-webpack5/evalSourceMapMiddleware"));
20
+ const evalSourceMapMiddleware_1 = tslib_1.__importDefault(require("react-dev-utils/evalSourceMapMiddleware"));
22
21
  const webpack_1 = tslib_1.__importDefault(require("webpack"));
23
22
  const webpack_dev_server_1 = tslib_1.__importDefault(require("webpack-dev-server"));
24
23
  const webpack_merge_1 = tslib_1.__importDefault(require("webpack-merge"));
25
- const HotModuleReplacementPlugin_1 = tslib_1.__importDefault(require("webpack/lib/HotModuleReplacementPlugin"));
26
24
  const server_1 = require("../server");
27
- const constants_1 = require("../constants");
28
25
  const client_1 = tslib_1.__importDefault(require("../webpack/client"));
29
26
  const utils_2 = require("../webpack/utils");
30
- const commandUtils_1 = require("./commandUtils");
31
- const translations_1 = require("../server/translations/translations");
32
- async function start(siteDir, cliOptions) {
27
+ const getHostPort_1 = require("../server/getHostPort");
28
+ async function start(siteDirParam = '.', cliOptions = {}) {
29
+ const siteDir = await fs_extra_1.default.realpath(siteDirParam);
33
30
  process.env.NODE_ENV = 'development';
34
31
  process.env.BABEL_ENV = 'development';
35
- console.log(chalk.blue('Starting the development server...'));
32
+ logger_1.default.info('Starting the development server...');
36
33
  function loadSite() {
37
- return server_1.load(siteDir, {
38
- customConfigFilePath: cliOptions.config,
34
+ return (0, server_1.load)({
35
+ siteDir,
36
+ config: cliOptions.config,
39
37
  locale: cliOptions.locale,
40
- localizePath: undefined, // should this be configurable?
38
+ localizePath: undefined, // Should this be configurable?
41
39
  });
42
40
  }
43
41
  // Process all related files as a prop.
44
42
  const props = await loadSite();
45
43
  const protocol = process.env.HTTPS === 'true' ? 'https' : 'http';
46
- const host = commandUtils_1.getCLIOptionHost(cliOptions.host);
47
- const port = await commandUtils_1.getCLIOptionPort(cliOptions.port, host);
44
+ const { host, port } = await (0, getHostPort_1.getHostPort)(cliOptions);
48
45
  if (port === null) {
49
46
  process.exit();
50
47
  }
51
48
  const { baseUrl, headTags, preBodyTags, postBodyTags } = props;
52
- const urls = WebpackDevServerUtils_1.prepareUrls(protocol, host, port);
53
- const openUrl = utils_1.normalizeUrl([urls.localUrlForBrowser, baseUrl]);
54
- console.log(chalk.cyanBright(`Docusaurus website is running at "${openUrl}".`));
49
+ const urls = (0, WebpackDevServerUtils_1.prepareUrls)(protocol, host, port);
50
+ const openUrl = (0, utils_1.normalizeUrl)([urls.localUrlForBrowser, baseUrl]);
51
+ logger_1.default.success `Docusaurus website is running at: url=${openUrl}`;
55
52
  // Reload files processing.
56
- const reload = lodash_1.debounce(() => {
53
+ const reload = lodash_1.default.debounce(() => {
57
54
  loadSite()
58
55
  .then(({ baseUrl: newBaseUrl }) => {
59
- const newOpenUrl = utils_1.normalizeUrl([urls.localUrlForBrowser, newBaseUrl]);
56
+ const newOpenUrl = (0, utils_1.normalizeUrl)([urls.localUrlForBrowser, newBaseUrl]);
60
57
  if (newOpenUrl !== openUrl) {
61
- console.log(chalk.cyanBright(`Docusaurus website is running at "${newOpenUrl}".`));
58
+ logger_1.default.success `Docusaurus website is running at: url=${newOpenUrl}`;
62
59
  }
63
60
  })
64
61
  .catch((err) => {
65
- console.error(chalk.red(err.stack));
62
+ logger_1.default.error(err.stack);
66
63
  });
67
64
  }, 500);
68
- const { siteConfig, plugins = [] } = props;
65
+ const { siteConfig, plugins, localizationDir } = props;
69
66
  const normalizeToSiteDir = (filepath) => {
70
67
  if (filepath && path_1.default.isAbsolute(filepath)) {
71
- return utils_1.posixPath(path_1.default.relative(siteDir, filepath));
68
+ return (0, utils_1.posixPath)(path_1.default.relative(siteDir, filepath));
72
69
  }
73
- return utils_1.posixPath(filepath);
70
+ return (0, utils_1.posixPath)(filepath);
74
71
  };
75
- const pluginPaths = []
76
- .concat(...plugins
77
- .map((plugin) => { var _a, _b; return (_b = (_a = plugin.getPathsToWatch) === null || _a === void 0 ? void 0 : _a.call(plugin)) !== null && _b !== void 0 ? _b : []; })
78
- .filter(Boolean))
72
+ const pluginPaths = plugins
73
+ .flatMap((plugin) => plugin.getPathsToWatch?.() ?? [])
74
+ .filter(Boolean)
79
75
  .map(normalizeToSiteDir);
80
- const pathsToWatch = [
81
- ...pluginPaths,
82
- props.siteConfigPath,
83
- translations_1.getTranslationsLocaleDirPath({
84
- siteDir,
85
- locale: props.i18n.currentLocale,
86
- }),
87
- ];
88
- const fsWatcher = chokidar_1.default.watch(pathsToWatch, {
89
- cwd: siteDir,
90
- ignoreInitial: true,
76
+ const pathsToWatch = [...pluginPaths, props.siteConfigPath, localizationDir];
77
+ const pollingOptions = {
91
78
  usePolling: !!cliOptions.poll,
92
79
  interval: Number.isInteger(cliOptions.poll)
93
80
  ? cliOptions.poll
94
81
  : undefined,
82
+ };
83
+ const httpsConfig = await (0, utils_2.getHttpsConfig)();
84
+ const fsWatcher = chokidar_1.default.watch(pathsToWatch, {
85
+ cwd: siteDir,
86
+ ignoreInitial: true,
87
+ ...{ pollingOptions },
95
88
  });
96
89
  ['add', 'change', 'unlink', 'addDir', 'unlinkDir'].forEach((event) => fsWatcher.on(event, reload));
97
- let config = webpack_merge_1.default(client_1.default(props), {
90
+ let config = (0, webpack_merge_1.default)(await (0, client_1.default)(props, cliOptions.minify), {
91
+ watchOptions: {
92
+ ignored: /node_modules\/(?!@docusaurus)/,
93
+ poll: cliOptions.poll,
94
+ },
95
+ infrastructureLogging: {
96
+ // Reduce log verbosity, see https://github.com/facebook/docusaurus/pull/5420#issuecomment-906613105
97
+ level: 'warn',
98
+ },
98
99
  plugins: [
99
100
  // Generates an `index.html` file with the <script> injected.
100
101
  new html_webpack_plugin_1.default({
101
- template: path_1.default.resolve(__dirname, '../client/templates/index.html.template.ejs'),
102
+ template: path_1.default.join(__dirname, '../webpack/templates/index.html.template.ejs'),
102
103
  // So we can define the position where the scripts are injected.
103
104
  inject: false,
104
105
  filename: 'index.html',
@@ -107,86 +108,93 @@ async function start(siteDir, cliOptions) {
107
108
  preBodyTags,
108
109
  postBodyTags,
109
110
  }),
110
- // This is necessary to emit hot updates for webpack-dev-server.
111
- new HotModuleReplacementPlugin_1.default(),
112
111
  ],
113
112
  });
114
113
  // Plugin Lifecycle - configureWebpack and configurePostCss.
115
114
  plugins.forEach((plugin) => {
116
- var _a;
117
115
  const { configureWebpack, configurePostCss } = plugin;
118
116
  if (configurePostCss) {
119
- config = utils_2.applyConfigurePostCss(configurePostCss, config);
117
+ config = (0, utils_2.applyConfigurePostCss)(configurePostCss.bind(plugin), config);
120
118
  }
121
119
  if (configureWebpack) {
122
- config = utils_2.applyConfigureWebpack(configureWebpack.bind(plugin), // The plugin lifecycle may reference `this`. // TODO remove this implicit api: inject in callback instead
123
- config, false, (_a = props.siteConfig.webpack) === null || _a === void 0 ? void 0 : _a.jsLoader, plugin.content);
120
+ config = (0, utils_2.applyConfigureWebpack)(configureWebpack.bind(plugin), // The plugin lifecycle may reference `this`.
121
+ config, false, props.siteConfig.webpack?.jsLoader, plugin.content);
124
122
  }
125
123
  });
126
- // https://webpack.js.org/configuration/dev-server
127
- const devServerConfig = {
128
- ...{
129
- compress: true,
130
- clientLogLevel: 'error',
131
- hot: true,
132
- hotOnly: cliOptions.hotOnly,
133
- // Use 'ws' instead of 'sockjs-node' on server since we're using native
134
- // websockets in `webpackHotDevClient`.
135
- transportMode: 'ws',
136
- // Prevent a WS client from getting injected as we're already including
137
- // `webpackHotDevClient`.
138
- injectClient: false,
139
- quiet: true,
140
- https: utils_2.getHttpsConfig(),
141
- headers: {
142
- 'access-control-allow-origin': '*',
143
- },
144
- publicPath: baseUrl,
145
- watchOptions: {
146
- ignored: /node_modules/,
147
- poll: cliOptions.poll,
148
- },
149
- historyApiFallback: {
150
- rewrites: [{ from: /\/*/, to: baseUrl }],
151
- },
152
- disableHostCheck: true,
153
- // Disable overlay on browser since we use CRA's overlay error reporting.
154
- overlay: false,
155
- host,
156
- before: (app, server) => {
157
- app.use(baseUrl, express_1.default.static(path_1.default.resolve(siteDir, constants_1.STATIC_DIR_NAME)));
158
- // This lets us fetch source contents from webpack for the error overlay.
159
- app.use(evalSourceMapMiddleware_1.default(server));
160
- // This lets us open files from the runtime error overlay.
161
- app.use(errorOverlayMiddleware_1.default());
162
- },
163
- },
164
- };
165
- const compiler = webpack_1.default(config);
124
+ const compiler = (0, webpack_1.default)(config);
166
125
  if (process.env.E2E_TEST) {
167
126
  compiler.hooks.done.tap('done', (stats) => {
168
127
  if (stats.hasErrors()) {
169
- console.log('E2E_TEST: Project has compiler errors.');
128
+ logger_1.default.error('E2E_TEST: Project has compiler errors.');
170
129
  process.exit(1);
171
130
  }
172
- console.log('E2E_TEST: Project can compile.');
131
+ logger_1.default.success('E2E_TEST: Project can compile.');
173
132
  process.exit(0);
174
133
  });
175
134
  }
176
- const devServer = new webpack_dev_server_1.default(compiler, devServerConfig);
177
- devServer.listen(port, host, (err) => {
178
- if (err) {
179
- console.log(err);
180
- }
135
+ // https://webpack.js.org/configuration/dev-server
136
+ const defaultDevServerConfig = {
137
+ hot: cliOptions.hotOnly ? 'only' : true,
138
+ liveReload: false,
139
+ client: {
140
+ progress: true,
141
+ overlay: {
142
+ warnings: false,
143
+ errors: true,
144
+ },
145
+ },
146
+ headers: {
147
+ 'access-control-allow-origin': '*',
148
+ },
149
+ devMiddleware: {
150
+ publicPath: baseUrl,
151
+ // Reduce log verbosity, see https://github.com/facebook/docusaurus/pull/5420#issuecomment-906613105
152
+ stats: 'summary',
153
+ },
154
+ static: siteConfig.staticDirectories.map((dir) => ({
155
+ publicPath: baseUrl,
156
+ directory: path_1.default.resolve(siteDir, dir),
157
+ watch: {
158
+ // Useful options for our own monorepo using symlinks!
159
+ // See https://github.com/webpack/webpack/issues/11612#issuecomment-879259806
160
+ followSymlinks: true,
161
+ ignored: /node_modules\/(?!@docusaurus)/,
162
+ ...{ pollingOptions },
163
+ },
164
+ })),
165
+ ...(httpsConfig && {
166
+ server: typeof httpsConfig === 'object'
167
+ ? {
168
+ type: 'https',
169
+ options: httpsConfig,
170
+ }
171
+ : 'https',
172
+ }),
173
+ historyApiFallback: {
174
+ rewrites: [{ from: /\/*/, to: baseUrl }],
175
+ },
176
+ allowedHosts: 'all',
177
+ host,
178
+ port,
179
+ setupMiddlewares: (middlewares, devServer) => {
180
+ // This lets us fetch source contents from webpack for the error overlay.
181
+ middlewares.unshift((0, evalSourceMapMiddleware_1.default)(devServer));
182
+ return middlewares;
183
+ },
184
+ };
185
+ // Allow plugin authors to customize/override devServer config
186
+ const devServerConfig = (0, webpack_merge_1.default)([defaultDevServerConfig, config.devServer].filter(Boolean));
187
+ const devServer = new webpack_dev_server_1.default(devServerConfig, compiler);
188
+ devServer.startCallback(() => {
181
189
  if (cliOptions.open) {
182
- openBrowser_1.default(openUrl);
190
+ (0, openBrowser_1.default)(openUrl);
183
191
  }
184
192
  });
185
193
  ['SIGINT', 'SIGTERM'].forEach((sig) => {
186
194
  process.on(sig, () => {
187
- devServer.close();
195
+ devServer.stop();
188
196
  process.exit();
189
197
  });
190
198
  });
191
199
  }
192
- exports.default = start;
200
+ exports.start = start;
@@ -0,0 +1,23 @@
1
+ /**
2
+ * Copyright (c) Facebook, Inc. and its affiliates.
3
+ *
4
+ * This source code is licensed under the MIT license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ */
7
+ import type { SwizzleAction, SwizzleComponentConfig } from '@docusaurus/types';
8
+ import type { SwizzleCLIOptions } from './common';
9
+ export declare const SwizzleActions: SwizzleAction[];
10
+ export declare function getAction(componentConfig: SwizzleComponentConfig, options: Pick<SwizzleCLIOptions, 'wrap' | 'eject'>): Promise<SwizzleAction>;
11
+ export declare type ActionParams = {
12
+ siteDir: string;
13
+ themePath: string;
14
+ componentName: string;
15
+ };
16
+ export declare type ActionResult = {
17
+ createdFiles: string[];
18
+ };
19
+ export declare function eject({ siteDir, themePath, componentName, }: ActionParams): Promise<ActionResult>;
20
+ export declare function wrap({ siteDir, themePath, componentName: themeComponentName, typescript, importType, }: ActionParams & {
21
+ typescript: boolean;
22
+ importType?: 'original' | 'init';
23
+ }): Promise<ActionResult>;
@@ -0,0 +1,101 @@
1
+ "use strict";
2
+ /**
3
+ * Copyright (c) Facebook, Inc. and its affiliates.
4
+ *
5
+ * This source code is licensed under the MIT license found in the
6
+ * LICENSE file in the root directory of this source tree.
7
+ */
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.wrap = exports.eject = exports.getAction = exports.SwizzleActions = void 0;
10
+ const tslib_1 = require("tslib");
11
+ const fs_extra_1 = tslib_1.__importDefault(require("fs-extra"));
12
+ const path_1 = tslib_1.__importDefault(require("path"));
13
+ const lodash_1 = tslib_1.__importDefault(require("lodash"));
14
+ const logger_1 = tslib_1.__importDefault(require("@docusaurus/logger"));
15
+ const utils_1 = require("@docusaurus/utils");
16
+ const prompts_1 = require("./prompts");
17
+ exports.SwizzleActions = ['wrap', 'eject'];
18
+ async function getAction(componentConfig, options) {
19
+ if (options.wrap) {
20
+ return 'wrap';
21
+ }
22
+ if (options.eject) {
23
+ return 'eject';
24
+ }
25
+ return (0, prompts_1.askSwizzleAction)(componentConfig);
26
+ }
27
+ exports.getAction = getAction;
28
+ async function isDir(dirPath) {
29
+ return ((await fs_extra_1.default.pathExists(dirPath)) && (await fs_extra_1.default.stat(dirPath)).isDirectory());
30
+ }
31
+ async function eject({ siteDir, themePath, componentName, }) {
32
+ const fromPath = path_1.default.join(themePath, componentName);
33
+ const isDirectory = await isDir(fromPath);
34
+ const globPattern = isDirectory
35
+ ? // Do we really want to copy all components?
36
+ path_1.default.join(fromPath, '*')
37
+ : `${fromPath}.*`;
38
+ const globPatternPosix = (0, utils_1.posixPath)(globPattern);
39
+ const filesToCopy = await (0, utils_1.Globby)(globPatternPosix, {
40
+ ignore: ['**/*.{story,stories,test,tests}.{js,jsx,ts,tsx}'],
41
+ });
42
+ if (filesToCopy.length === 0) {
43
+ // This should never happen
44
+ throw new Error(logger_1.default.interpolate `No files to copy from path=${fromPath} with glob code=${globPatternPosix}`);
45
+ }
46
+ const toPath = path_1.default.join(siteDir, utils_1.THEME_PATH);
47
+ await fs_extra_1.default.ensureDir(toPath);
48
+ const createdFiles = await Promise.all(filesToCopy.map(async (sourceFile) => {
49
+ const targetFile = path_1.default.join(toPath, path_1.default.relative(themePath, sourceFile));
50
+ try {
51
+ const fileContents = await fs_extra_1.default.readFile(sourceFile, 'utf-8');
52
+ await fs_extra_1.default.outputFile(targetFile, fileContents.trimStart().replace(/^\/\*.+?\*\/\s*/ms, ''));
53
+ }
54
+ catch (err) {
55
+ logger_1.default.error `Could not copy file from path=${sourceFile} to path=${targetFile}`;
56
+ throw err;
57
+ }
58
+ return targetFile;
59
+ }));
60
+ return { createdFiles };
61
+ }
62
+ exports.eject = eject;
63
+ async function wrap({ siteDir, themePath, componentName: themeComponentName, typescript, importType = 'original', }) {
64
+ const isDirectory = await isDir(path_1.default.join(themePath, themeComponentName));
65
+ // Top/Parent/ComponentName => ComponentName
66
+ const componentName = lodash_1.default.last(themeComponentName.split('/'));
67
+ const wrapperComponentName = `${componentName}Wrapper`;
68
+ const wrapperFileName = `${themeComponentName}${isDirectory ? '/index' : ''}${typescript ? '.tsx' : '.js'}`;
69
+ await fs_extra_1.default.ensureDir(path_1.default.resolve(siteDir, utils_1.THEME_PATH));
70
+ const toPath = path_1.default.resolve(siteDir, utils_1.THEME_PATH, wrapperFileName);
71
+ const content = typescript
72
+ ? `import React from 'react';
73
+ import ${componentName} from '@theme-${importType}/${themeComponentName}';
74
+ import type ${componentName}Type from '@theme/${themeComponentName}';
75
+ import type {WrapperProps} from '@docusaurus/types';
76
+
77
+ type Props = WrapperProps<typeof ${componentName}Type>;
78
+
79
+ export default function ${wrapperComponentName}(props: Props): JSX.Element {
80
+ return (
81
+ <>
82
+ <${componentName} {...props} />
83
+ </>
84
+ );
85
+ }
86
+ `
87
+ : `import React from 'react';
88
+ import ${componentName} from '@theme-${importType}/${themeComponentName}';
89
+
90
+ export default function ${wrapperComponentName}(props) {
91
+ return (
92
+ <>
93
+ <${componentName} {...props} />
94
+ </>
95
+ );
96
+ }
97
+ `;
98
+ await fs_extra_1.default.outputFile(toPath, content);
99
+ return { createdFiles: [toPath] };
100
+ }
101
+ exports.wrap = wrap;
@@ -0,0 +1,33 @@
1
+ /**
2
+ * Copyright (c) Facebook, Inc. and its affiliates.
3
+ *
4
+ * This source code is licensed under the MIT license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ */
7
+ import type { NormalizedPluginConfig } from '../../server/plugins/configs';
8
+ import type { InitializedPlugin, SwizzleAction, SwizzleActionStatus } from '@docusaurus/types';
9
+ export declare const SwizzleActions: SwizzleAction[];
10
+ export declare const SwizzleActionsStatuses: SwizzleActionStatus[];
11
+ export declare const PartiallySafeHint: string;
12
+ export declare function actionStatusLabel(status: SwizzleActionStatus): string;
13
+ export declare function actionStatusColor(status: SwizzleActionStatus, str: string): string;
14
+ export declare function actionStatusSuffix(status: SwizzleActionStatus, options?: {
15
+ partiallySafe?: boolean;
16
+ }): string;
17
+ export declare type SwizzlePlugin = {
18
+ instance: InitializedPlugin;
19
+ plugin: NormalizedPluginConfig;
20
+ };
21
+ export declare type SwizzleContext = {
22
+ plugins: SwizzlePlugin[];
23
+ };
24
+ export declare type SwizzleCLIOptions = {
25
+ typescript: boolean;
26
+ danger: boolean;
27
+ list: boolean;
28
+ wrap: boolean;
29
+ eject: boolean;
30
+ };
31
+ export declare function normalizeOptions(options: Partial<SwizzleCLIOptions>): SwizzleCLIOptions;
32
+ export declare function findStringIgnoringCase(str: string, values: string[]): string | undefined;
33
+ export declare function findClosestValue(str: string, values: string[], maxLevenshtein?: number): string | undefined;
@@ -0,0 +1,56 @@
1
+ "use strict";
2
+ /**
3
+ * Copyright (c) Facebook, Inc. and its affiliates.
4
+ *
5
+ * This source code is licensed under the MIT license found in the
6
+ * LICENSE file in the root directory of this source tree.
7
+ */
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.findClosestValue = exports.findStringIgnoringCase = exports.normalizeOptions = exports.actionStatusSuffix = exports.actionStatusColor = exports.actionStatusLabel = exports.PartiallySafeHint = exports.SwizzleActionsStatuses = exports.SwizzleActions = void 0;
10
+ const tslib_1 = require("tslib");
11
+ const lodash_1 = tslib_1.__importDefault(require("lodash"));
12
+ const logger_1 = tslib_1.__importDefault(require("@docusaurus/logger"));
13
+ const leven_1 = tslib_1.__importDefault(require("leven"));
14
+ exports.SwizzleActions = ['wrap', 'eject'];
15
+ exports.SwizzleActionsStatuses = [
16
+ 'safe',
17
+ 'unsafe',
18
+ 'forbidden',
19
+ ];
20
+ exports.PartiallySafeHint = logger_1.default.red('*');
21
+ function actionStatusLabel(status) {
22
+ return lodash_1.default.capitalize(status);
23
+ }
24
+ exports.actionStatusLabel = actionStatusLabel;
25
+ const SwizzleActionStatusColors = {
26
+ safe: logger_1.default.green,
27
+ unsafe: logger_1.default.yellow,
28
+ forbidden: logger_1.default.red,
29
+ };
30
+ function actionStatusColor(status, str) {
31
+ const colorFn = SwizzleActionStatusColors[status];
32
+ return colorFn(str);
33
+ }
34
+ exports.actionStatusColor = actionStatusColor;
35
+ function actionStatusSuffix(status, options = {}) {
36
+ return ` (${actionStatusColor(status, actionStatusLabel(status))}${options.partiallySafe ? exports.PartiallySafeHint : ''})`;
37
+ }
38
+ exports.actionStatusSuffix = actionStatusSuffix;
39
+ function normalizeOptions(options) {
40
+ return {
41
+ typescript: options.typescript ?? false,
42
+ danger: options.danger ?? false,
43
+ list: options.list ?? false,
44
+ wrap: options.wrap ?? false,
45
+ eject: options.eject ?? false,
46
+ };
47
+ }
48
+ exports.normalizeOptions = normalizeOptions;
49
+ function findStringIgnoringCase(str, values) {
50
+ return values.find((v) => v.toLowerCase() === str.toLowerCase());
51
+ }
52
+ exports.findStringIgnoringCase = findStringIgnoringCase;
53
+ function findClosestValue(str, values, maxLevenshtein = 3) {
54
+ return values.find((v) => (0, leven_1.default)(v, str) <= maxLevenshtein);
55
+ }
56
+ exports.findClosestValue = findClosestValue;
@@ -0,0 +1,29 @@
1
+ /**
2
+ * Copyright (c) Facebook, Inc. and its affiliates.
3
+ *
4
+ * This source code is licensed under the MIT license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ */
7
+ import type { SwizzleAction, SwizzleActionStatus, SwizzleComponentConfig, SwizzleConfig } from '@docusaurus/types';
8
+ export declare type ThemeComponents = {
9
+ themeName: string;
10
+ all: string[];
11
+ getConfig: (component: string) => SwizzleComponentConfig;
12
+ getDescription: (component: string) => string;
13
+ getActionStatus: (component: string, action: SwizzleAction) => SwizzleActionStatus;
14
+ isSafeAction: (component: string, action: SwizzleAction) => boolean;
15
+ hasAnySafeAction: (component: string) => boolean;
16
+ hasAllSafeAction: (component: string) => boolean;
17
+ };
18
+ export declare function readComponentNames(themePath: string): Promise<string[]>;
19
+ export declare function listComponentNames(themeComponents: ThemeComponents): string;
20
+ export declare function getThemeComponents({ themeName, themePath, swizzleConfig, }: {
21
+ themeName: string;
22
+ themePath: string;
23
+ swizzleConfig: SwizzleConfig;
24
+ }): Promise<ThemeComponents>;
25
+ export declare function getComponentName({ componentNameParam, themeComponents, list, }: {
26
+ componentNameParam: string | undefined;
27
+ themeComponents: ThemeComponents;
28
+ list: boolean | undefined;
29
+ }): Promise<string>;