@docusaurus/theme-common 2.0.0-beta.fc64c12e4 → 2.0.0

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 (274) hide show
  1. package/lib/components/Collapsible/index.d.ts +35 -6
  2. package/lib/components/Collapsible/index.d.ts.map +1 -0
  3. package/lib/components/Collapsible/index.js +33 -30
  4. package/lib/components/Collapsible/index.js.map +1 -0
  5. package/lib/components/Details/index.d.ts +8 -3
  6. package/lib/components/Details/index.d.ts.map +1 -0
  7. package/lib/components/Details/index.js +31 -19
  8. package/lib/components/Details/index.js.map +1 -0
  9. package/lib/components/Details/styles.module.css +14 -11
  10. package/lib/contexts/announcementBar.d.ts +22 -0
  11. package/lib/contexts/announcementBar.d.ts.map +1 -0
  12. package/lib/{utils/announcementBarUtils.js → contexts/announcementBar.js} +30 -31
  13. package/lib/contexts/announcementBar.js.map +1 -0
  14. package/lib/contexts/blogPost.d.ts +33 -0
  15. package/lib/contexts/blogPost.d.ts.map +1 -0
  16. package/lib/contexts/blogPost.js +46 -0
  17. package/lib/contexts/blogPost.js.map +1 -0
  18. package/lib/contexts/colorMode.d.ts +27 -0
  19. package/lib/contexts/colorMode.d.ts.map +1 -0
  20. package/lib/contexts/colorMode.js +132 -0
  21. package/lib/contexts/colorMode.js.map +1 -0
  22. package/lib/contexts/doc.d.ts +30 -0
  23. package/lib/contexts/doc.d.ts.map +1 -0
  24. package/lib/contexts/doc.js +48 -0
  25. package/lib/contexts/doc.js.map +1 -0
  26. package/lib/contexts/docSidebarItemsExpandedState.d.ts +31 -0
  27. package/lib/contexts/docSidebarItemsExpandedState.d.ts.map +1 -0
  28. package/lib/contexts/docSidebarItemsExpandedState.js +28 -0
  29. package/lib/contexts/docSidebarItemsExpandedState.js.map +1 -0
  30. package/lib/contexts/docsPreferredVersion.d.ts +30 -0
  31. package/lib/contexts/docsPreferredVersion.d.ts.map +1 -0
  32. package/lib/contexts/docsPreferredVersion.js +130 -0
  33. package/lib/contexts/docsPreferredVersion.js.map +1 -0
  34. package/lib/contexts/docsSidebar.d.ts +26 -0
  35. package/lib/contexts/docsSidebar.d.ts.map +1 -0
  36. package/lib/contexts/docsSidebar.js +30 -0
  37. package/lib/contexts/docsSidebar.js.map +1 -0
  38. package/lib/contexts/docsVersion.d.ts +20 -0
  39. package/lib/contexts/docsVersion.d.ts.map +1 -0
  40. package/lib/contexts/docsVersion.js +26 -0
  41. package/lib/contexts/docsVersion.js.map +1 -0
  42. package/lib/contexts/navbarMobileSidebar.d.ts +31 -0
  43. package/lib/contexts/navbarMobileSidebar.d.ts.map +1 -0
  44. package/lib/contexts/navbarMobileSidebar.js +56 -0
  45. package/lib/contexts/navbarMobileSidebar.js.map +1 -0
  46. package/lib/contexts/navbarSecondaryMenu/content.d.ts +37 -0
  47. package/lib/contexts/navbarSecondaryMenu/content.d.ts.map +1 -0
  48. package/lib/contexts/navbarSecondaryMenu/content.js +50 -0
  49. package/lib/contexts/navbarSecondaryMenu/content.js.map +1 -0
  50. package/lib/contexts/navbarSecondaryMenu/display.d.ts +24 -0
  51. package/lib/contexts/navbarSecondaryMenu/display.d.ts.map +1 -0
  52. package/lib/contexts/navbarSecondaryMenu/display.js +62 -0
  53. package/lib/contexts/navbarSecondaryMenu/display.js.map +1 -0
  54. package/lib/contexts/tabGroupChoice.d.ts +21 -0
  55. package/lib/contexts/tabGroupChoice.d.ts.map +1 -0
  56. package/lib/contexts/tabGroupChoice.js +49 -0
  57. package/lib/contexts/tabGroupChoice.js.map +1 -0
  58. package/lib/{utils/usePrevious.d.ts → hooks/styles.css} +4 -1
  59. package/lib/hooks/useBackToTopButton.d.ts +27 -0
  60. package/lib/hooks/useBackToTopButton.d.ts.map +1 -0
  61. package/lib/hooks/useBackToTopButton.js +50 -0
  62. package/lib/hooks/useBackToTopButton.js.map +1 -0
  63. package/lib/hooks/useCodeWordWrap.d.ts +14 -0
  64. package/lib/hooks/useCodeWordWrap.d.ts.map +1 -0
  65. package/lib/hooks/useCodeWordWrap.js +67 -0
  66. package/lib/hooks/useCodeWordWrap.js.map +1 -0
  67. package/lib/hooks/useHideableNavbar.d.ts +17 -0
  68. package/lib/hooks/useHideableNavbar.d.ts.map +1 -0
  69. package/lib/hooks/useHideableNavbar.js +60 -0
  70. package/lib/hooks/useHideableNavbar.js.map +1 -0
  71. package/lib/hooks/useKeyboardNavigation.d.ts +20 -0
  72. package/lib/hooks/useKeyboardNavigation.d.ts.map +1 -0
  73. package/lib/hooks/useKeyboardNavigation.js +39 -0
  74. package/lib/hooks/useKeyboardNavigation.js.map +1 -0
  75. package/lib/hooks/useLockBodyScroll.d.ts +12 -0
  76. package/lib/hooks/useLockBodyScroll.d.ts.map +1 -0
  77. package/lib/hooks/useLockBodyScroll.js +20 -0
  78. package/lib/hooks/useLockBodyScroll.js.map +1 -0
  79. package/lib/hooks/useMutationObserver.d.ts +4 -0
  80. package/lib/hooks/useMutationObserver.d.ts.map +1 -0
  81. package/lib/hooks/useMutationObserver.js +29 -0
  82. package/lib/hooks/useMutationObserver.js.map +1 -0
  83. package/lib/hooks/usePrismTheme.d.ts +13 -0
  84. package/lib/hooks/usePrismTheme.d.ts.map +1 -0
  85. package/lib/hooks/usePrismTheme.js +21 -0
  86. package/lib/hooks/usePrismTheme.js.map +1 -0
  87. package/lib/hooks/useSearchPage.d.ts +25 -0
  88. package/lib/hooks/useSearchPage.d.ts.map +1 -0
  89. package/lib/hooks/useSearchPage.js +43 -0
  90. package/lib/hooks/useSearchPage.js.map +1 -0
  91. package/lib/hooks/useSkipToContent.d.ts +25 -0
  92. package/lib/hooks/useSkipToContent.d.ts.map +1 -0
  93. package/lib/hooks/useSkipToContent.js +35 -0
  94. package/lib/hooks/useSkipToContent.js.map +1 -0
  95. package/lib/hooks/useTOCHighlight.d.ts +25 -0
  96. package/lib/hooks/useTOCHighlight.d.ts.map +1 -0
  97. package/lib/hooks/useTOCHighlight.js +130 -0
  98. package/lib/hooks/useTOCHighlight.js.map +1 -0
  99. package/lib/hooks/useWindowSize.d.ts +28 -0
  100. package/lib/hooks/useWindowSize.d.ts.map +1 -0
  101. package/lib/hooks/useWindowSize.js +59 -0
  102. package/lib/hooks/useWindowSize.js.map +1 -0
  103. package/lib/index.d.ts +15 -19
  104. package/lib/index.d.ts.map +1 -0
  105. package/lib/index.js +22 -15
  106. package/lib/index.js.map +1 -0
  107. package/lib/internal.d.ts +41 -0
  108. package/lib/internal.d.ts.map +1 -0
  109. package/lib/internal.js +52 -0
  110. package/lib/internal.js.map +1 -0
  111. package/lib/utils/ThemeClassNames.d.ts +49 -12
  112. package/lib/utils/ThemeClassNames.d.ts.map +1 -0
  113. package/lib/utils/ThemeClassNames.js +47 -4
  114. package/lib/utils/ThemeClassNames.js.map +1 -0
  115. package/lib/utils/codeBlockUtils.d.ts +63 -0
  116. package/lib/utils/codeBlockUtils.d.ts.map +1 -0
  117. package/lib/utils/codeBlockUtils.js +159 -3
  118. package/lib/utils/codeBlockUtils.js.map +1 -0
  119. package/lib/utils/docsUtils.d.ts +91 -0
  120. package/lib/utils/docsUtils.d.ts.map +1 -0
  121. package/lib/utils/docsUtils.js +217 -1
  122. package/lib/utils/docsUtils.js.map +1 -0
  123. package/lib/utils/footerUtils.d.ts +13 -0
  124. package/lib/utils/footerUtils.d.ts.map +1 -0
  125. package/lib/utils/footerUtils.js +14 -0
  126. package/lib/utils/footerUtils.js.map +1 -0
  127. package/lib/utils/generalUtils.d.ts +11 -1
  128. package/lib/utils/generalUtils.d.ts.map +1 -0
  129. package/lib/utils/generalUtils.js +9 -5
  130. package/lib/utils/generalUtils.js.map +1 -0
  131. package/lib/utils/historyUtils.d.ts +17 -0
  132. package/lib/utils/historyUtils.d.ts.map +1 -0
  133. package/lib/utils/historyUtils.js +38 -0
  134. package/lib/utils/historyUtils.js.map +1 -0
  135. package/lib/utils/jsUtils.d.ts +23 -0
  136. package/lib/utils/jsUtils.d.ts.map +1 -0
  137. package/lib/utils/jsUtils.js +29 -0
  138. package/lib/utils/jsUtils.js.map +1 -0
  139. package/lib/utils/metadataUtils.d.ts +38 -0
  140. package/lib/utils/metadataUtils.d.ts.map +1 -0
  141. package/lib/utils/metadataUtils.js +70 -0
  142. package/lib/utils/metadataUtils.js.map +1 -0
  143. package/lib/utils/navbarUtils.d.ts +21 -0
  144. package/lib/utils/navbarUtils.d.ts.map +1 -0
  145. package/lib/utils/navbarUtils.js +36 -0
  146. package/lib/utils/navbarUtils.js.map +1 -0
  147. package/lib/utils/reactUtils.d.ts +69 -0
  148. package/lib/utils/reactUtils.d.ts.map +1 -0
  149. package/lib/utils/reactUtils.js +98 -0
  150. package/lib/utils/reactUtils.js.map +1 -0
  151. package/lib/utils/regexpUtils.d.ts +12 -0
  152. package/lib/utils/regexpUtils.d.ts.map +1 -0
  153. package/lib/utils/regexpUtils.js +18 -0
  154. package/lib/utils/regexpUtils.js.map +1 -0
  155. package/lib/utils/routesUtils.d.ts +26 -0
  156. package/lib/utils/routesUtils.d.ts.map +1 -0
  157. package/lib/utils/routesUtils.js +54 -0
  158. package/lib/utils/routesUtils.js.map +1 -0
  159. package/lib/utils/scrollUtils.d.ts +83 -0
  160. package/lib/utils/scrollUtils.d.ts.map +1 -0
  161. package/lib/utils/scrollUtils.js +200 -0
  162. package/lib/utils/scrollUtils.js.map +1 -0
  163. package/lib/utils/searchUtils.d.ts +13 -0
  164. package/lib/utils/searchUtils.d.ts.map +1 -0
  165. package/lib/utils/searchUtils.js +37 -0
  166. package/lib/utils/searchUtils.js.map +1 -0
  167. package/lib/utils/storageUtils.d.ts +15 -7
  168. package/lib/utils/storageUtils.d.ts.map +1 -0
  169. package/lib/utils/storageUtils.js +55 -22
  170. package/lib/utils/storageUtils.js.map +1 -0
  171. package/lib/utils/tagsUtils.d.ts +18 -0
  172. package/lib/utils/tagsUtils.d.ts.map +1 -0
  173. package/lib/utils/tagsUtils.js +36 -0
  174. package/lib/utils/tagsUtils.js.map +1 -0
  175. package/lib/utils/tocUtils.d.ts +36 -0
  176. package/lib/utils/tocUtils.d.ts.map +1 -0
  177. package/lib/utils/tocUtils.js +84 -0
  178. package/lib/utils/tocUtils.js.map +1 -0
  179. package/lib/utils/useAlternatePageUtils.d.ts +21 -1
  180. package/lib/utils/useAlternatePageUtils.d.ts.map +1 -0
  181. package/lib/utils/useAlternatePageUtils.js +9 -4
  182. package/lib/utils/useAlternatePageUtils.js.map +1 -0
  183. package/lib/utils/useLocalPathname.d.ts +6 -0
  184. package/lib/utils/useLocalPathname.d.ts.map +1 -0
  185. package/lib/utils/useLocalPathname.js +7 -4
  186. package/lib/utils/useLocalPathname.js.map +1 -0
  187. package/lib/utils/useLocationChange.d.ts +9 -6
  188. package/lib/utils/useLocationChange.d.ts.map +1 -0
  189. package/lib/utils/useLocationChange.js +17 -11
  190. package/lib/utils/useLocationChange.js.map +1 -0
  191. package/lib/utils/usePluralForm.d.ts +12 -0
  192. package/lib/utils/usePluralForm.d.ts.map +1 -0
  193. package/lib/utils/usePluralForm.js +36 -37
  194. package/lib/utils/usePluralForm.js.map +1 -0
  195. package/lib/utils/useThemeConfig.d.ts +56 -29
  196. package/lib/utils/useThemeConfig.d.ts.map +1 -0
  197. package/lib/utils/useThemeConfig.js +4 -0
  198. package/lib/utils/useThemeConfig.js.map +1 -0
  199. package/package.json +35 -15
  200. package/src/components/Collapsible/index.tsx +57 -48
  201. package/src/components/Details/index.tsx +27 -12
  202. package/src/components/Details/styles.module.css +14 -11
  203. package/src/{utils/announcementBarUtils.tsx → contexts/announcementBar.tsx} +43 -39
  204. package/src/contexts/blogPost.tsx +80 -0
  205. package/src/contexts/colorMode.tsx +198 -0
  206. package/src/contexts/doc.tsx +71 -0
  207. package/src/contexts/docSidebarItemsExpandedState.tsx +55 -0
  208. package/src/contexts/docsPreferredVersion.tsx +251 -0
  209. package/src/contexts/docsSidebar.tsx +50 -0
  210. package/src/contexts/docsVersion.tsx +36 -0
  211. package/src/contexts/navbarMobileSidebar.tsx +99 -0
  212. package/src/contexts/navbarSecondaryMenu/content.tsx +100 -0
  213. package/src/contexts/navbarSecondaryMenu/display.tsx +102 -0
  214. package/src/contexts/tabGroupChoice.tsx +85 -0
  215. package/{lib/utils/pathUtils.d.ts → src/hooks/styles.css} +4 -1
  216. package/src/hooks/useBackToTopButton.ts +73 -0
  217. package/src/hooks/useCodeWordWrap.ts +105 -0
  218. package/src/hooks/useHideableNavbar.ts +75 -0
  219. package/src/hooks/useKeyboardNavigation.ts +45 -0
  220. package/src/hooks/useLockBodyScroll.ts +21 -0
  221. package/src/hooks/useMutationObserver.ts +38 -0
  222. package/src/hooks/usePrismTheme.ts +24 -0
  223. package/src/hooks/useSearchPage.ts +79 -0
  224. package/src/hooks/useSkipToContent.ts +58 -0
  225. package/src/hooks/useTOCHighlight.ts +189 -0
  226. package/src/hooks/useWindowSize.ts +72 -0
  227. package/src/index.ts +49 -42
  228. package/src/internal.ts +122 -0
  229. package/src/types.d.ts +0 -2
  230. package/src/utils/ThemeClassNames.ts +54 -5
  231. package/src/utils/codeBlockUtils.ts +241 -2
  232. package/src/utils/docsUtils.tsx +334 -0
  233. package/src/utils/footerUtils.ts +18 -0
  234. package/src/utils/generalUtils.ts +9 -5
  235. package/src/utils/historyUtils.ts +45 -0
  236. package/src/utils/jsUtils.ts +36 -0
  237. package/src/utils/metadataUtils.tsx +115 -0
  238. package/src/utils/navbarUtils.tsx +45 -0
  239. package/src/utils/reactUtils.tsx +129 -0
  240. package/src/utils/regexpUtils.ts +24 -0
  241. package/src/utils/routesUtils.ts +75 -0
  242. package/src/utils/scrollUtils.tsx +304 -0
  243. package/src/utils/searchUtils.ts +51 -0
  244. package/src/utils/storageUtils.ts +56 -23
  245. package/src/utils/tagsUtils.ts +50 -0
  246. package/src/utils/tocUtils.ts +119 -0
  247. package/src/utils/useAlternatePageUtils.ts +19 -6
  248. package/src/utils/useLocalPathname.ts +6 -4
  249. package/src/utils/useLocationChange.ts +24 -20
  250. package/src/utils/usePluralForm.ts +50 -38
  251. package/src/utils/useThemeConfig.ts +55 -31
  252. package/copyUntypedFiles.js +0 -20
  253. package/lib/.tsbuildinfo +0 -1
  254. package/lib/utils/announcementBarUtils.d.ts +0 -17
  255. package/lib/utils/docsPreferredVersion/DocsPreferredVersionProvider.d.ts +0 -21
  256. package/lib/utils/docsPreferredVersion/DocsPreferredVersionProvider.js +0 -94
  257. package/lib/utils/docsPreferredVersion/DocsPreferredVersionStorage.d.ts +0 -13
  258. package/lib/utils/docsPreferredVersion/DocsPreferredVersionStorage.js +0 -20
  259. package/lib/utils/docsPreferredVersion/useDocsPreferredVersion.d.ts +0 -5
  260. package/lib/utils/docsPreferredVersion/useDocsPreferredVersion.js +0 -41
  261. package/lib/utils/mobileSecondaryMenu.d.ts +0 -20
  262. package/lib/utils/mobileSecondaryMenu.js +0 -50
  263. package/lib/utils/pathUtils.js +0 -13
  264. package/lib/utils/usePrevious.js +0 -14
  265. package/src/utils/__tests__/codeBlockUtils.test.ts +0 -54
  266. package/src/utils/__tests__/pathUtils.test.ts +0 -32
  267. package/src/utils/docsPreferredVersion/DocsPreferredVersionProvider.tsx +0 -165
  268. package/src/utils/docsPreferredVersion/DocsPreferredVersionStorage.ts +0 -34
  269. package/src/utils/docsPreferredVersion/useDocsPreferredVersion.ts +0 -66
  270. package/src/utils/docsUtils.ts +0 -11
  271. package/src/utils/mobileSecondaryMenu.tsx +0 -115
  272. package/src/utils/pathUtils.ts +0 -17
  273. package/src/utils/usePrevious.ts +0 -18
  274. package/tsconfig.json +0 -10
@@ -1,14 +0,0 @@
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 { useRef, useEffect } from 'react';
8
- export function usePrevious(value) {
9
- const ref = useRef();
10
- useEffect(() => {
11
- ref.current = value;
12
- });
13
- return ref.current;
14
- }
@@ -1,54 +0,0 @@
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
-
8
- import {parseCodeBlockTitle} from '../codeBlockUtils';
9
-
10
- describe('parseCodeBlockTitle', () => {
11
- test('should parse double quote delimited title', () => {
12
- expect(parseCodeBlockTitle(`title="index.js"`)).toEqual(`index.js`);
13
- });
14
-
15
- test('should parse single quote delimited title', () => {
16
- expect(parseCodeBlockTitle(`title='index.js'`)).toEqual(`index.js`);
17
- });
18
-
19
- test('should not parse mismatched quote delimiters', () => {
20
- expect(parseCodeBlockTitle(`title="index.js'`)).toEqual(``);
21
- });
22
-
23
- test('should parse undefined metastring', () => {
24
- expect(parseCodeBlockTitle(undefined)).toEqual(``);
25
- });
26
-
27
- test('should parse metastring with no title specified', () => {
28
- expect(parseCodeBlockTitle(`{1,2-3}`)).toEqual(``);
29
- });
30
-
31
- test('should parse with multiple metadatas title first', () => {
32
- expect(parseCodeBlockTitle(`title="index.js" label="JavaScript"`)).toEqual(
33
- `index.js`,
34
- );
35
- });
36
-
37
- test('should parse with multiple metadatas title last', () => {
38
- expect(parseCodeBlockTitle(`label="JavaScript" title="index.js"`)).toEqual(
39
- `index.js`,
40
- );
41
- });
42
-
43
- test('should parse double quotes when delimited by single quotes', () => {
44
- expect(parseCodeBlockTitle(`title='console.log("Hello, World!")'`)).toEqual(
45
- `console.log("Hello, World!")`,
46
- );
47
- });
48
-
49
- test('should parse single quotes when delimited by double quotes', () => {
50
- expect(parseCodeBlockTitle(`title="console.log('Hello, World!')"`)).toEqual(
51
- `console.log('Hello, World!')`,
52
- );
53
- });
54
- });
@@ -1,32 +0,0 @@
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
-
8
- import {isSamePath} from '../pathUtils';
9
-
10
- describe('isSamePath', () => {
11
- test('should be true for compared path without trailing slash', () => {
12
- expect(isSamePath('/docs', '/docs')).toBeTruthy();
13
- });
14
-
15
- test('should be true for compared path with trailing slash', () => {
16
- expect(isSamePath('/docs', '/docs/')).toBeTruthy();
17
- });
18
-
19
- test('should be false for compared path with double trailing slash', () => {
20
- expect(isSamePath('/docs', '/docs//')).toBeFalsy();
21
- });
22
-
23
- test('should be true for twice undefined/null', () => {
24
- expect(isSamePath(undefined, undefined)).toBeTruthy();
25
- expect(isSamePath(undefined, undefined)).toBeTruthy();
26
- });
27
-
28
- test('should be false when one undefined', () => {
29
- expect(isSamePath('/docs', undefined)).toBeFalsy();
30
- expect(isSamePath(undefined, '/docs')).toBeFalsy();
31
- });
32
- });
@@ -1,165 +0,0 @@
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 React, {
8
- createContext,
9
- ReactNode,
10
- useContext,
11
- useEffect,
12
- useMemo,
13
- useState,
14
- } from 'react';
15
- import {useThemeConfig, DocsVersionPersistence} from '../useThemeConfig';
16
- import {isDocsPluginEnabled} from '../docsUtils';
17
-
18
- import {useAllDocsData} from '@theme/hooks/useDocs';
19
-
20
- import DocsPreferredVersionStorage from './DocsPreferredVersionStorage';
21
-
22
- type DocsPreferredVersionName = string | null;
23
-
24
- // State for a single docs plugin instance
25
- type DocsPreferredVersionPluginState = {
26
- preferredVersionName: DocsPreferredVersionName;
27
- };
28
-
29
- // We need to store in state/storage globally
30
- // one preferred version per docs plugin instance
31
- // pluginId => pluginState
32
- type DocsPreferredVersionState = Record<
33
- string,
34
- DocsPreferredVersionPluginState
35
- >;
36
-
37
- // Initial state is always null as we can't read localstorage from node SSR
38
- function getInitialState(pluginIds: string[]): DocsPreferredVersionState {
39
- const initialState: DocsPreferredVersionState = {};
40
- pluginIds.forEach((pluginId) => {
41
- initialState[pluginId] = {
42
- preferredVersionName: null,
43
- };
44
- });
45
- return initialState;
46
- }
47
-
48
- // Read storage for all docs plugins
49
- // Assign to each doc plugin a preferred version (if found)
50
- function readStorageState({
51
- pluginIds,
52
- versionPersistence,
53
- allDocsData,
54
- }: {
55
- pluginIds: string[];
56
- versionPersistence: DocsVersionPersistence;
57
- allDocsData: any; // TODO find a way to type it :(
58
- }): DocsPreferredVersionState {
59
- // The storage value we read might be stale,
60
- // and belong to a version that does not exist in the site anymore
61
- // In such case, we remove the storage value to avoid downstream errors
62
- function restorePluginState(
63
- pluginId: string,
64
- ): DocsPreferredVersionPluginState {
65
- const preferredVersionNameUnsafe = DocsPreferredVersionStorage.read(
66
- pluginId,
67
- versionPersistence,
68
- );
69
- const pluginData = allDocsData[pluginId];
70
- const versionExists = pluginData.versions.some(
71
- (version: any) => version.name === preferredVersionNameUnsafe,
72
- );
73
- if (versionExists) {
74
- return {preferredVersionName: preferredVersionNameUnsafe};
75
- } else {
76
- DocsPreferredVersionStorage.clear(pluginId, versionPersistence);
77
- return {preferredVersionName: null};
78
- }
79
- }
80
-
81
- const initialState: DocsPreferredVersionState = {};
82
- pluginIds.forEach((pluginId) => {
83
- initialState[pluginId] = restorePluginState(pluginId);
84
- });
85
- return initialState;
86
- }
87
-
88
- function useVersionPersistence(): DocsVersionPersistence {
89
- return useThemeConfig().docs.versionPersistence;
90
- }
91
-
92
- // Value that will be accessible through context: [state,api]
93
- function useContextValue() {
94
- const allDocsData = useAllDocsData();
95
- const versionPersistence = useVersionPersistence();
96
- const pluginIds = useMemo(() => Object.keys(allDocsData), [allDocsData]);
97
-
98
- // Initial state is empty, as we can't read browser storage in node/SSR
99
- const [state, setState] = useState(() => getInitialState(pluginIds));
100
-
101
- // On mount, we set the state read from browser storage
102
- useEffect(() => {
103
- setState(readStorageState({allDocsData, versionPersistence, pluginIds}));
104
- }, [allDocsData, versionPersistence, pluginIds]);
105
-
106
- // The API that we expose to consumer hooks (memo for constant object)
107
- const api = useMemo(() => {
108
- function savePreferredVersion(pluginId: string, versionName: string) {
109
- DocsPreferredVersionStorage.save(
110
- pluginId,
111
- versionPersistence,
112
- versionName,
113
- );
114
- setState((s) => ({
115
- ...s,
116
- [pluginId]: {preferredVersionName: versionName},
117
- }));
118
- }
119
-
120
- return {
121
- savePreferredVersion,
122
- };
123
- }, [setState]);
124
-
125
- return [state, api] as const;
126
- }
127
-
128
- type DocsPreferredVersionContextValue = ReturnType<typeof useContextValue>;
129
-
130
- const Context = createContext<DocsPreferredVersionContextValue | null>(null);
131
-
132
- export function DocsPreferredVersionContextProvider({
133
- children,
134
- }: {
135
- children: ReactNode;
136
- }): JSX.Element {
137
- if (isDocsPluginEnabled) {
138
- return (
139
- <DocsPreferredVersionContextProviderUnsafe>
140
- {children}
141
- </DocsPreferredVersionContextProviderUnsafe>
142
- );
143
- } else {
144
- return <>{children}</>;
145
- }
146
- }
147
-
148
- function DocsPreferredVersionContextProviderUnsafe({
149
- children,
150
- }: {
151
- children: ReactNode;
152
- }): JSX.Element {
153
- const contextValue = useContextValue();
154
- return <Context.Provider value={contextValue}>{children}</Context.Provider>;
155
- }
156
-
157
- export function useDocsPreferredVersionContext(): DocsPreferredVersionContextValue {
158
- const value = useContext(Context);
159
- if (!value) {
160
- throw new Error(
161
- 'Can\'t find docs preferred context, maybe you forgot to use the "DocsPreferredVersionContextProvider"?',
162
- );
163
- }
164
- return value;
165
- }
@@ -1,34 +0,0 @@
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
-
8
- import {createStorageSlot} from '../storageUtils';
9
- import {DocsVersionPersistence} from '../useThemeConfig';
10
-
11
- const storageKey = (pluginId: string) => `docs-preferred-version-${pluginId}`;
12
-
13
- const DocsPreferredVersionStorage = {
14
- save: (
15
- pluginId: string,
16
- persistence: DocsVersionPersistence,
17
- versionName: string,
18
- ): void => {
19
- createStorageSlot(storageKey(pluginId), {persistence}).set(versionName);
20
- },
21
-
22
- read: (
23
- pluginId: string,
24
- persistence: DocsVersionPersistence,
25
- ): string | null => {
26
- return createStorageSlot(storageKey(pluginId), {persistence}).get();
27
- },
28
-
29
- clear: (pluginId: string, persistence: DocsVersionPersistence): void => {
30
- createStorageSlot(storageKey(pluginId), {persistence}).del();
31
- },
32
- };
33
-
34
- export default DocsPreferredVersionStorage;
@@ -1,66 +0,0 @@
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 {useCallback} from 'react';
8
- import {useDocsPreferredVersionContext} from './DocsPreferredVersionProvider';
9
- import {useAllDocsData, useDocsData} from '@theme/hooks/useDocs';
10
-
11
- import {DEFAULT_PLUGIN_ID} from '@docusaurus/constants';
12
-
13
- // TODO improve typing
14
-
15
- // Note, the preferredVersion attribute will always be null before mount
16
- export function useDocsPreferredVersion(
17
- pluginId: string | undefined = DEFAULT_PLUGIN_ID,
18
- ) {
19
- const docsData = useDocsData(pluginId);
20
- const [state, api] = useDocsPreferredVersionContext();
21
-
22
- const {preferredVersionName} = state[pluginId];
23
-
24
- const preferredVersion = preferredVersionName
25
- ? docsData.versions.find(
26
- (version: any) => version.name === preferredVersionName,
27
- )
28
- : null;
29
-
30
- const savePreferredVersionName = useCallback(
31
- (versionName: string) => {
32
- api.savePreferredVersion(pluginId, versionName);
33
- },
34
- [api],
35
- );
36
-
37
- return {preferredVersion, savePreferredVersionName} as const;
38
- }
39
-
40
- export function useDocsPreferredVersionByPluginId(): Record<string, any> {
41
- const allDocsData = useAllDocsData();
42
- const [state] = useDocsPreferredVersionContext();
43
-
44
- function getPluginIdPreferredVersion(pluginId: string) {
45
- const docsData = allDocsData[pluginId];
46
- const {preferredVersionName} = state[pluginId];
47
-
48
- return preferredVersionName
49
- ? docsData.versions.find(
50
- (version: any) => version.name === preferredVersionName,
51
- )
52
- : null;
53
- }
54
-
55
- const pluginIds = Object.keys(allDocsData);
56
-
57
- const result: Record<
58
- string,
59
- any // TODO find a way to type this properly!
60
- > = {};
61
- pluginIds.forEach((pluginId) => {
62
- result[pluginId] = getPluginIdPreferredVersion(pluginId);
63
- });
64
-
65
- return result;
66
- }
@@ -1,11 +0,0 @@
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
-
8
- import {useAllDocsData} from '@theme/hooks/useDocs';
9
-
10
- // TODO not ideal, see also "useDocs"
11
- export const isDocsPluginEnabled: boolean = !!useAllDocsData;
@@ -1,115 +0,0 @@
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
-
8
- import React, {
9
- useState,
10
- ReactNode,
11
- useContext,
12
- createContext,
13
- useEffect,
14
- ComponentType,
15
- useMemo,
16
- } from 'react';
17
-
18
- /*
19
- The idea behind all this is that a specific component must be able to fill a placeholder in the generic layout
20
- The doc page should be able to fill the secondary menu of the main mobile navbar.
21
- This permits to reduce coupling between the main layout and the specific page.
22
-
23
- This kind of feature is often called portal/teleport/gateway... various unmaintained React libs exist
24
- Most up-to-date one: https://github.com/gregberge/react-teleporter
25
- Not sure any of those is safe regarding concurrent mode.
26
- */
27
-
28
- type ExtraProps = {
29
- toggleSidebar: () => void;
30
- };
31
-
32
- export type MobileSecondaryMenuComponent<Props extends unknown> = ComponentType<
33
- Props & ExtraProps
34
- >;
35
-
36
- type State = {
37
- component: MobileSecondaryMenuComponent<unknown>;
38
- props: unknown;
39
- } | null;
40
-
41
- function useContextValue() {
42
- return useState<State>(null);
43
- }
44
-
45
- type ContextValue = ReturnType<typeof useContextValue>;
46
-
47
- const Context = createContext<ContextValue | null>(null);
48
-
49
- export function MobileSecondaryMenuProvider({
50
- children,
51
- }: {
52
- children: ReactNode;
53
- }): JSX.Element {
54
- return (
55
- <Context.Provider value={useContextValue()}>{children}</Context.Provider>
56
- );
57
- }
58
-
59
- function useMobileSecondaryMenuContext(): ContextValue {
60
- const value = useContext(Context);
61
- if (value === null) {
62
- throw new Error(
63
- 'MobileSecondaryMenuProvider was not used correctly, context value is null',
64
- );
65
- }
66
- return value;
67
- }
68
-
69
- export function useMobileSecondaryMenuRenderer(): (
70
- extraProps: ExtraProps,
71
- ) => ReactNode | undefined {
72
- const [state] = useMobileSecondaryMenuContext();
73
- if (state) {
74
- const Comp = state.component;
75
- return function render(extraProps) {
76
- return <Comp {...state.props} {...extraProps} />;
77
- };
78
- }
79
- return () => undefined;
80
- }
81
-
82
- function useShallowMemoizedObject<O extends Record<string, unknown>>(obj: O) {
83
- return useMemo(
84
- () => obj,
85
- // Is this safe?
86
- [...Object.keys(obj), ...Object.values(obj)],
87
- );
88
- }
89
-
90
- // Fill the secondary menu placeholder with some real content
91
- export function MobileSecondaryMenuFiller<
92
- Props extends Record<string, unknown>
93
- >({
94
- component,
95
- props,
96
- }: {
97
- component: MobileSecondaryMenuComponent<Props & ExtraProps>;
98
- props: Props;
99
- }): JSX.Element | null {
100
- const [, setState] = useMobileSecondaryMenuContext();
101
-
102
- // To avoid useless context re-renders, props are memoized shallowly
103
- const memoizedProps = useShallowMemoizedObject(props);
104
-
105
- useEffect(() => {
106
- // @ts-expect-error: context is not 100% typesafe but it's ok
107
- setState({component, props: memoizedProps});
108
- }, [setState, component, memoizedProps]);
109
-
110
- useEffect(() => {
111
- return () => setState(null);
112
- }, [setState]);
113
-
114
- return null;
115
- }
@@ -1,17 +0,0 @@
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
-
8
- // Compare the 2 paths, ignoring trailing /
9
- export const isSamePath = (
10
- path1: string | undefined,
11
- path2: string | undefined,
12
- ): boolean => {
13
- const normalize = (pathname: string | undefined) => {
14
- return !pathname || pathname?.endsWith('/') ? pathname : `${pathname}/`;
15
- };
16
- return normalize(path1) === normalize(path2);
17
- };
@@ -1,18 +0,0 @@
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
-
8
- import {useRef, useEffect} from 'react';
9
-
10
- export function usePrevious<T>(value: T): T | undefined {
11
- const ref = useRef<T>();
12
-
13
- useEffect(() => {
14
- ref.current = value;
15
- });
16
-
17
- return ref.current;
18
- }
package/tsconfig.json DELETED
@@ -1,10 +0,0 @@
1
- {
2
- "extends": "../../tsconfig.json",
3
- "compilerOptions": {
4
- "incremental": true,
5
- "tsBuildInfoFile": "./lib/.tsbuildinfo",
6
- "module": "esnext",
7
- "rootDir": "src",
8
- "outDir": "lib"
9
- }
10
- }