@node-core/ui-components 1.0.1-df203d0fe21ee5d80d258c60dc821e8ac0601ce4 → 1.0.1-e1f87bde264af01e260a8efa4fab1749a2c6bc29

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 (263) hide show
  1. package/Common/AlertBox/index.js +5 -0
  2. package/Common/AlertBox/index.module.css +47 -46
  3. package/Common/AvatarGroup/Avatar/index.js +11 -0
  4. package/Common/AvatarGroup/Avatar/index.module.css +50 -30
  5. package/Common/AvatarGroup/Overlay/index.js +6 -0
  6. package/Common/AvatarGroup/Overlay/index.module.css +28 -21
  7. package/Common/AvatarGroup/index.js +21 -0
  8. package/Common/AvatarGroup/index.module.css +12 -15
  9. package/Common/Badge/index.js +7 -0
  10. package/Common/Badge/index.module.css +34 -26
  11. package/Common/BadgeGroup/index.js +6 -0
  12. package/Common/BadgeGroup/index.module.css +75 -51
  13. package/Common/Banner/index.js +4 -0
  14. package/Common/Banner/index.module.css +30 -27
  15. package/Common/BaseActiveLink/index.js +14 -0
  16. package/Common/BaseButton/index.js +10 -0
  17. package/Common/BaseButton/index.module.css +332 -102
  18. package/Common/BaseCodeBox/index.js +50 -0
  19. package/Common/BaseCodeBox/index.module.css +76 -64
  20. package/Common/BaseCrossLink/index.js +12 -0
  21. package/Common/BaseCrossLink/index.module.css +57 -39
  22. package/Common/BaseLinkTabs/index.js +5 -0
  23. package/Common/BaseLinkTabs/index.module.css +67 -33
  24. package/Common/BasePagination/Ellipsis/index.js +4 -0
  25. package/Common/BasePagination/Ellipsis/index.module.css +14 -8
  26. package/Common/BasePagination/PaginationListItem/index.js +6 -0
  27. package/Common/BasePagination/PaginationListItem/index.module.css +36 -21
  28. package/Common/BasePagination/PrevNextArrow.js +7 -0
  29. package/Common/BasePagination/index.js +10 -0
  30. package/Common/BasePagination/index.module.css +27 -26
  31. package/Common/BasePagination/useGetPageElements.js +77 -0
  32. package/Common/Blockquote/index.js +4 -0
  33. package/Common/Blockquote/index.module.css +44 -23
  34. package/Common/Breadcrumbs/BreadcrumbHomeLink/index.js +9 -0
  35. package/Common/Breadcrumbs/BreadcrumbHomeLink/index.module.css +3 -3
  36. package/Common/Breadcrumbs/BreadcrumbItem/index.js +6 -0
  37. package/Common/Breadcrumbs/BreadcrumbItem/index.module.css +38 -27
  38. package/Common/Breadcrumbs/BreadcrumbLink/index.js +5 -0
  39. package/Common/Breadcrumbs/BreadcrumbLink/index.module.css +26 -16
  40. package/Common/Breadcrumbs/BreadcrumbRoot/index.js +4 -0
  41. package/Common/Breadcrumbs/BreadcrumbRoot/index.module.css +8 -7
  42. package/Common/Breadcrumbs/BreadcrumbTruncatedItem/index.js +4 -0
  43. package/Common/Breadcrumbs/index.js +22 -0
  44. package/Common/ChangeHistory/index.js +9 -0
  45. package/Common/ChangeHistory/index.module.css +198 -0
  46. package/Common/CodeTabs/index.js +5 -0
  47. package/Common/CodeTabs/index.module.css +47 -36
  48. package/Common/DataTag/index.js +18 -0
  49. package/Common/DataTag/index.module.css +54 -0
  50. package/Common/GlowingBackdrop/index.js +5 -0
  51. package/Common/GlowingBackdrop/index.module.css +126 -28
  52. package/Common/LanguageDropDown/index.js +11 -0
  53. package/Common/LanguageDropDown/index.module.css +140 -42
  54. package/Common/Modal/index.js +10 -0
  55. package/Common/Modal/index.module.css +217 -62
  56. package/Common/NodejsLogo/index.js +7 -0
  57. package/Common/NodejsLogo/index.module.css +3 -4
  58. package/Common/Notification/index.js +6 -0
  59. package/Common/Notification/index.module.css +101 -17
  60. package/Common/Preview/index.js +7 -0
  61. package/Common/Preview/index.module.css +269 -65
  62. package/Common/Select/index.js +46 -0
  63. package/Common/Select/index.module.css +294 -127
  64. package/Common/Separator/index.js +7 -0
  65. package/Common/Separator/index.module.css +7 -10
  66. package/Common/Skeleton/index.js +18 -0
  67. package/Common/Skeleton/index.module.css +118 -21
  68. package/Common/Tabs/index.js +6 -0
  69. package/Common/Tabs/index.module.css +58 -40
  70. package/Common/ThemeToggle/index.js +7 -0
  71. package/Common/ThemeToggle/index.module.css +18 -11
  72. package/Common/Tooltip/index.js +8 -0
  73. package/Common/Tooltip/index.module.css +119 -29
  74. package/Containers/Article/index.js +4 -0
  75. package/Containers/Article/index.module.css +127 -58
  76. package/Containers/DocSideBar/index.js +1 -0
  77. package/Containers/Footer/index.js +22 -0
  78. package/Containers/Footer/index.module.css +51 -36
  79. package/Containers/MetaBar/index.js +12 -0
  80. package/Containers/MetaBar/index.module.css +101 -69
  81. package/Containers/NavBar/NavItem/index.js +7 -0
  82. package/Containers/NavBar/NavItem/index.module.css +50 -36
  83. package/Containers/NavBar/index.js +18 -0
  84. package/Containers/NavBar/index.module.css +176 -96
  85. package/Containers/Sidebar/ProgressionIcon/index.js +3 -0
  86. package/Containers/Sidebar/SidebarGroup/index.js +9 -0
  87. package/Containers/Sidebar/SidebarGroup/index.module.css +188 -22
  88. package/Containers/Sidebar/SidebarItem/index.js +11 -0
  89. package/Containers/Sidebar/SidebarItem/index.module.css +60 -28
  90. package/Containers/Sidebar/index.js +15 -0
  91. package/Containers/Sidebar/index.module.css +44 -27
  92. package/Icons/HexagonGrid.js +3 -0
  93. package/Icons/InstallationMethod/Choco.js +3 -0
  94. package/Icons/InstallationMethod/Devbox.js +3 -0
  95. package/Icons/InstallationMethod/Docker.js +3 -0
  96. package/Icons/InstallationMethod/FNM.js +3 -0
  97. package/Icons/InstallationMethod/Homebrew.js +3 -0
  98. package/Icons/InstallationMethod/N.js +5 -0
  99. package/Icons/InstallationMethod/NVM.js +3 -0
  100. package/Icons/InstallationMethod/Volta.js +3 -0
  101. package/Icons/InstallationMethod/{index.ts → index.js} +0 -1
  102. package/Icons/Logos/JsWhite.js +3 -0
  103. package/Icons/Logos/Nodejs.js +12 -0
  104. package/Icons/Logos/index.js +3 -0
  105. package/Icons/OperatingSystem/AIX.js +3 -0
  106. package/Icons/OperatingSystem/Apple.js +3 -0
  107. package/Icons/OperatingSystem/Linux.js +3 -0
  108. package/Icons/OperatingSystem/Microsoft.js +3 -0
  109. package/Icons/OperatingSystem/{index.ts → index.js} +0 -1
  110. package/Icons/PackageManager/Npm.js +3 -0
  111. package/Icons/PackageManager/Pnpm.js +3 -0
  112. package/Icons/PackageManager/Yarn.js +3 -0
  113. package/Icons/PackageManager/{index.ts → index.js} +0 -1
  114. package/Icons/Social/Bluesky.js +3 -0
  115. package/Icons/Social/Discord.js +3 -0
  116. package/Icons/Social/GitHub.js +3 -0
  117. package/Icons/Social/LinkedIn.js +3 -0
  118. package/Icons/Social/Mastodon.js +3 -0
  119. package/Icons/Social/Slack.js +3 -0
  120. package/Icons/Social/X.js +3 -0
  121. package/Icons/Social/{index.ts → index.js} +0 -1
  122. package/MDX/CodeTabs.js +16 -0
  123. package/package.json +19 -69
  124. package/stylelint/one-utility-class-per-line.mjs +34 -50
  125. package/stylelint/utils.mjs +19 -25
  126. package/styles/index.css +1124 -26
  127. package/types.js +1 -0
  128. package/Common/AlertBox/index.stories.tsx +0 -73
  129. package/Common/AlertBox/index.tsx +0 -24
  130. package/Common/AvatarGroup/Avatar/index.stories.tsx +0 -22
  131. package/Common/AvatarGroup/Avatar/index.tsx +0 -67
  132. package/Common/AvatarGroup/Overlay/index.stories.tsx +0 -33
  133. package/Common/AvatarGroup/Overlay/index.tsx +0 -37
  134. package/Common/AvatarGroup/__tests__/index.test.jsx +0 -55
  135. package/Common/AvatarGroup/index.stories.tsx +0 -56
  136. package/Common/AvatarGroup/index.tsx +0 -87
  137. package/Common/Badge/index.stories.tsx +0 -38
  138. package/Common/Badge/index.tsx +0 -35
  139. package/Common/BadgeGroup/index.stories.tsx +0 -35
  140. package/Common/BadgeGroup/index.tsx +0 -35
  141. package/Common/Banner/index.stories.tsx +0 -29
  142. package/Common/Banner/index.tsx +0 -18
  143. package/Common/BaseActiveLink/__tests__/index.test.jsx +0 -52
  144. package/Common/BaseActiveLink/index.tsx +0 -34
  145. package/Common/BaseButton/index.stories.tsx +0 -67
  146. package/Common/BaseButton/index.tsx +0 -59
  147. package/Common/BaseCodeBox/index.stories.tsx +0 -39
  148. package/Common/BaseCodeBox/index.tsx +0 -133
  149. package/Common/BaseCrossLink/index.stories.tsx +0 -38
  150. package/Common/BaseCrossLink/index.tsx +0 -46
  151. package/Common/BaseLinkTabs/index.stories.tsx +0 -34
  152. package/Common/BaseLinkTabs/index.tsx +0 -53
  153. package/Common/BasePagination/Ellipsis/index.stories.tsx +0 -10
  154. package/Common/BasePagination/Ellipsis/index.tsx +0 -11
  155. package/Common/BasePagination/PaginationListItem/__tests__/index.test.jsx +0 -58
  156. package/Common/BasePagination/PaginationListItem/index.stories.tsx +0 -40
  157. package/Common/BasePagination/PaginationListItem/index.tsx +0 -39
  158. package/Common/BasePagination/PrevNextArrow.tsx +0 -15
  159. package/Common/BasePagination/__tests__/index.test.jsx +0 -180
  160. package/Common/BasePagination/index.stories.tsx +0 -67
  161. package/Common/BasePagination/index.tsx +0 -77
  162. package/Common/BasePagination/useGetPageElements.tsx +0 -132
  163. package/Common/Blockquote/index.stories.tsx +0 -45
  164. package/Common/Blockquote/index.tsx +0 -11
  165. package/Common/Breadcrumbs/BreadcrumbHomeLink/index.tsx +0 -30
  166. package/Common/Breadcrumbs/BreadcrumbItem/index.tsx +0 -42
  167. package/Common/Breadcrumbs/BreadcrumbLink/index.tsx +0 -37
  168. package/Common/Breadcrumbs/BreadcrumbRoot/index.tsx +0 -20
  169. package/Common/Breadcrumbs/BreadcrumbTruncatedItem/index.tsx +0 -9
  170. package/Common/Breadcrumbs/index.stories.tsx +0 -94
  171. package/Common/Breadcrumbs/index.tsx +0 -81
  172. package/Common/CodeTabs/index.stories.tsx +0 -74
  173. package/Common/CodeTabs/index.tsx +0 -16
  174. package/Common/GlowingBackdrop/index.stories.tsx +0 -10
  175. package/Common/GlowingBackdrop/index.tsx +0 -13
  176. package/Common/LanguageDropDown/index.stories.tsx +0 -19
  177. package/Common/LanguageDropDown/index.tsx +0 -56
  178. package/Common/Modal/index.stories.tsx +0 -32
  179. package/Common/Modal/index.tsx +0 -48
  180. package/Common/NodejsLogo/index.stories.tsx +0 -14
  181. package/Common/NodejsLogo/index.tsx +0 -26
  182. package/Common/Notification/index.stories.tsx +0 -36
  183. package/Common/Notification/index.tsx +0 -34
  184. package/Common/Preview/index.stories.tsx +0 -44
  185. package/Common/Preview/index.tsx +0 -25
  186. package/Common/ProgressionSidebar/ProgressionSidebarGroup/index.module.css +0 -47
  187. package/Common/ProgressionSidebar/ProgressionSidebarGroup/index.tsx +0 -35
  188. package/Common/ProgressionSidebar/ProgressionSidebarIcon/index.tsx +0 -16
  189. package/Common/ProgressionSidebar/ProgressionSidebarItem/index.module.css +0 -39
  190. package/Common/ProgressionSidebar/ProgressionSidebarItem/index.tsx +0 -32
  191. package/Common/ProgressionSidebar/index.module.css +0 -30
  192. package/Common/ProgressionSidebar/index.stories.tsx +0 -79
  193. package/Common/ProgressionSidebar/index.tsx +0 -59
  194. package/Common/Select/__tests__/index.test.jsx +0 -67
  195. package/Common/Select/index.stories.tsx +0 -111
  196. package/Common/Select/index.tsx +0 -187
  197. package/Common/Separator/index.stories.tsx +0 -32
  198. package/Common/Separator/index.tsx +0 -27
  199. package/Common/Skeleton/index.tsx +0 -39
  200. package/Common/Tabs/__tests__/index.test.jsx +0 -52
  201. package/Common/Tabs/index.stories.tsx +0 -50
  202. package/Common/Tabs/index.tsx +0 -54
  203. package/Common/ThemeToggle/__tests__/index.test.jsx +0 -35
  204. package/Common/ThemeToggle/index.stories.tsx +0 -10
  205. package/Common/ThemeToggle/index.tsx +0 -15
  206. package/Common/Tooltip/index.stories.tsx +0 -73
  207. package/Common/Tooltip/index.tsx +0 -48
  208. package/Containers/Article/index.stories.tsx +0 -39
  209. package/Containers/Article/index.tsx +0 -9
  210. package/Containers/Footer/index.stories.tsx +0 -27
  211. package/Containers/Footer/index.tsx +0 -95
  212. package/Containers/MetaBar/__tests__/index.test.jsx +0 -63
  213. package/Containers/MetaBar/index.stories.tsx +0 -80
  214. package/Containers/MetaBar/index.tsx +0 -72
  215. package/Containers/NavBar/NavItem/index.stories.tsx +0 -38
  216. package/Containers/NavBar/NavItem/index.tsx +0 -44
  217. package/Containers/NavBar/index.stories.tsx +0 -45
  218. package/Containers/NavBar/index.tsx +0 -94
  219. package/Containers/Sidebar/SidebarGroup/index.stories.tsx +0 -36
  220. package/Containers/Sidebar/SidebarGroup/index.tsx +0 -30
  221. package/Containers/Sidebar/SidebarItem/index.stories.tsx +0 -15
  222. package/Containers/Sidebar/SidebarItem/index.tsx +0 -26
  223. package/Containers/Sidebar/index.stories.tsx +0 -84
  224. package/Containers/Sidebar/index.tsx +0 -58
  225. package/Icons/HexagonGrid.stories.tsx +0 -10
  226. package/Icons/HexagonGrid.tsx +0 -1434
  227. package/Icons/InstallationMethod/Choco.tsx +0 -78
  228. package/Icons/InstallationMethod/Devbox.tsx +0 -21
  229. package/Icons/InstallationMethod/Docker.tsx +0 -20
  230. package/Icons/InstallationMethod/FNM.tsx +0 -132
  231. package/Icons/InstallationMethod/Homebrew.tsx +0 -69
  232. package/Icons/InstallationMethod/N.tsx +0 -32
  233. package/Icons/InstallationMethod/NVM.tsx +0 -63
  234. package/Icons/InstallationMethod/Volta.tsx +0 -34
  235. package/Icons/Logos/JsGreen.tsx +0 -24
  236. package/Icons/Logos/JsWhite.tsx +0 -37
  237. package/Icons/Logos/Nodejs.tsx +0 -188
  238. package/Icons/Logos/NodejsStackedBlack.tsx +0 -98
  239. package/Icons/Logos/NodejsStackedDark.tsx +0 -124
  240. package/Icons/Logos/NodejsStackedLight.tsx +0 -123
  241. package/Icons/Logos/NodejsStackedWhite.tsx +0 -98
  242. package/Icons/Logos/index.ts +0 -17
  243. package/Icons/OperatingSystem/AIX.tsx +0 -46
  244. package/Icons/OperatingSystem/Apple.tsx +0 -23
  245. package/Icons/OperatingSystem/Linux.tsx +0 -969
  246. package/Icons/OperatingSystem/Microsoft.tsx +0 -19
  247. package/Icons/PackageManager/Npm.tsx +0 -21
  248. package/Icons/PackageManager/Pnpm.tsx +0 -22
  249. package/Icons/PackageManager/Yarn.tsx +0 -22
  250. package/Icons/Social/Bluesky.tsx +0 -19
  251. package/Icons/Social/Discord.tsx +0 -20
  252. package/Icons/Social/GitHub.tsx +0 -16
  253. package/Icons/Social/LinkedIn.tsx +0 -16
  254. package/Icons/Social/Mastodon.tsx +0 -36
  255. package/Icons/Social/Slack.tsx +0 -31
  256. package/Icons/Social/X.tsx +0 -16
  257. package/stylelint/__tests__/index.test.mjs +0 -80
  258. package/styles/animations.css +0 -47
  259. package/styles/base.css +0 -17
  260. package/styles/effects.css +0 -12
  261. package/styles/markdown.css +0 -173
  262. package/styles/theme.css +0 -175
  263. package/types.ts +0 -25
@@ -1,27 +0,0 @@
1
- import type { Meta as MetaObj, StoryObj } from '@storybook/react';
2
-
3
- import Footer from '#ui/Containers/Footer';
4
-
5
- type Story = StoryObj<typeof Footer>;
6
- type Meta = MetaObj<typeof Footer>;
7
-
8
- export const Default: Story = {
9
- args: {
10
- navigation: {
11
- footerLinks: [
12
- { link: '/', text: 'Home' },
13
- { link: 'https://openjsf.org', text: 'OpenJS Foundation' },
14
- ],
15
- socialLinks: [
16
- { icon: 'github', link: 'https://github.com' },
17
- { icon: 'mastodon', link: 'https://mastodon.social' },
18
- { icon: 'twitter', link: 'https://twitter.com' },
19
- { icon: 'slack', link: 'https://slack.com' },
20
- { icon: 'linkedin', link: 'https://linkedin.com' },
21
- { icon: 'bluesky', link: 'https://bsky.app' },
22
- ],
23
- },
24
- },
25
- };
26
-
27
- export default { component: Footer } as Meta;
@@ -1,95 +0,0 @@
1
- 'use client';
2
-
3
- import type { FC, SVGProps } from 'react';
4
-
5
- import NavItem from '#ui/Containers/NavBar/NavItem';
6
- import {
7
- Bluesky,
8
- Discord,
9
- GitHub,
10
- LinkedIn,
11
- Mastodon,
12
- Slack,
13
- X,
14
- } from '#ui/Icons/Social';
15
- import type { LinkLike } from '#ui/types';
16
-
17
- import styles from './index.module.css';
18
-
19
- const footerSocialIcons: Record<string, React.FC<SVGProps<SVGSVGElement>>> = {
20
- github: GitHub,
21
- mastodon: Mastodon,
22
- twitter: X,
23
- slack: Slack,
24
- linkedin: LinkedIn,
25
- bluesky: Bluesky,
26
- discord: Discord,
27
- };
28
-
29
- type Navigation = {
30
- socialLinks: Array<{
31
- icon: string;
32
- link: string;
33
- }>;
34
- footerLinks: Array<{
35
- text: string;
36
- link: string;
37
- }>;
38
- };
39
-
40
- const Footer: FC<{
41
- pathname: string;
42
- as: LinkLike;
43
- navigation: Navigation;
44
- }> = ({ pathname = '/', as = 'a', navigation }) => {
45
- const openJSlink = navigation.footerLinks.at(-1)!;
46
-
47
- return (
48
- <footer className={styles.footer}>
49
- <div className={styles.sectionPrimary}>
50
- {navigation.footerLinks.slice(0, -1).map(item => (
51
- <NavItem
52
- key={item.link}
53
- type="footer"
54
- href={item.link}
55
- as={as}
56
- pathname={pathname}
57
- >
58
- {item.text}
59
- </NavItem>
60
- ))}
61
- </div>
62
-
63
- <div className={styles.sectionSecondary}>
64
- <NavItem
65
- type="footer"
66
- href={openJSlink.link}
67
- as={as}
68
- pathname={pathname}
69
- >
70
- &copy; {openJSlink.text}
71
- </NavItem>
72
-
73
- <div className={styles.social}>
74
- {navigation.socialLinks.map(link => {
75
- const SocialIcon = footerSocialIcons[link.icon];
76
-
77
- return (
78
- <NavItem
79
- key={link.icon}
80
- href={link.link}
81
- type="footer"
82
- as={as}
83
- pathname={pathname}
84
- >
85
- <SocialIcon width={20} height={20} aria-label={link.link} />
86
- </NavItem>
87
- );
88
- })}
89
- </div>
90
- </div>
91
- </footer>
92
- );
93
- };
94
-
95
- export default Footer;
@@ -1,63 +0,0 @@
1
- import { describe, it } from 'node:test';
2
- import assert from 'node:assert/strict';
3
-
4
- import { render } from '@testing-library/react';
5
-
6
- import MetaBar from '..';
7
-
8
- describe('MetaBar', () => {
9
- it('does not render h5s in the table of contents', () => {
10
- const { queryByText, getByText } = render(
11
- <MetaBar
12
- items={{}}
13
- headings={{
14
- items: [
15
- {
16
- value: 'Heading Level 1',
17
- depth: 1,
18
- data: { id: 'heading-1' },
19
- },
20
- {
21
- value: 'Heading Level 2',
22
- depth: 2,
23
- data: { id: 'heading-2' },
24
- },
25
- {
26
- value: 'Heading Level 3',
27
- depth: 3,
28
- data: { id: 'heading-3' },
29
- },
30
- {
31
- value: 'Heading Level 4',
32
- depth: 4,
33
- data: { id: 'heading-4' },
34
- },
35
- {
36
- value: 'Heading Level 5',
37
- depth: 5,
38
- data: { id: 'heading-5' },
39
- },
40
- {
41
- value: 'Heading Level 6',
42
- depth: 6,
43
- data: { id: 'heading-6' },
44
- },
45
- ],
46
- }}
47
- />
48
- );
49
-
50
- const h1Element = queryByText('Heading Level 1');
51
- assert.ok(!h1Element?.ownerDocument);
52
-
53
- getByText('Heading Level 2');
54
- getByText('Heading Level 3');
55
- getByText('Heading Level 4');
56
-
57
- const h5Element = queryByText('Heading Level 5');
58
- assert.ok(!h5Element?.ownerDocument);
59
-
60
- const h6Element = queryByText('Heading Level 6');
61
- assert.ok(!h6Element?.ownerDocument);
62
- });
63
- });
@@ -1,80 +0,0 @@
1
- import { CodeBracketIcon } from '@heroicons/react/24/outline';
2
- import type { Meta as MetaObj, StoryObj } from '@storybook/react';
3
-
4
- import MetaBar from '#ui/Containers/MetaBar';
5
- import GitHubIcon from '#ui/Icons/Social/GitHub';
6
-
7
- type Story = StoryObj<typeof MetaBar>;
8
- type Meta = MetaObj<typeof MetaBar>;
9
-
10
- export const Default: Story = {
11
- args: {
12
- items: {
13
- 'components.metabar.lastUpdated': new Date(
14
- '17 October 2023'
15
- ).toLocaleDateString(),
16
- 'components.metabar.readingTime': '15 minutes',
17
- 'components.metabar.addedIn': 'v1.0.0',
18
- 'components.metabar.author': 'The Node.js Project',
19
- 'components.metabar.authors': <p>...</p>,
20
- 'components.metabar.contribute': (
21
- <>
22
- <GitHubIcon className="fill-neutral-700 dark:fill-neutral-100" />
23
- <a href="/contribute">Edit this page</a>
24
- </>
25
- ),
26
- 'components.metabar.viewAs': (
27
- <>
28
- <CodeBracketIcon />
29
- <a href="/json">JSON</a>
30
- </>
31
- ),
32
- },
33
- headings: {
34
- items: [
35
- {
36
- value: 'OpenSSL update assessment, and Node.js project plans',
37
- depth: 1,
38
- data: { id: 'heading-1' },
39
- },
40
- {
41
- value: 'Summary',
42
- depth: 2,
43
- data: { id: 'summary' },
44
- },
45
- {
46
- value: 'Analysis',
47
- depth: 2,
48
- data: { id: 'analysis' },
49
- },
50
- {
51
- value: 'The c_rehash script allows command injection (CVE-2022-2068)',
52
- depth: 3,
53
- data: { id: 'the_c_rehash' },
54
- },
55
- {
56
- value: 'Contact and future updates',
57
- depth: 3,
58
- data: { id: 'contact_and_future_updates' },
59
- },
60
- {
61
- value: 'Email',
62
- depth: 4,
63
- data: { id: 'email' },
64
- },
65
- {
66
- value: 'Slack',
67
- depth: 4,
68
- data: { id: 'slack' },
69
- },
70
- {
71
- value: '#node-website',
72
- depth: 5, // h5s do not get shown
73
- data: { id: 'node-website' },
74
- },
75
- ],
76
- },
77
- },
78
- };
79
-
80
- export default { component: MetaBar } as Meta;
@@ -1,72 +0,0 @@
1
- import type { Heading } from '@vcarl/remark-headings';
2
- import { Fragment, useMemo } from 'react';
3
- import type { FC } from 'react';
4
-
5
- import type { LinkLike } from '#ui/types';
6
-
7
- import styles from './index.module.css';
8
-
9
- type MetaBarProps = {
10
- items: Partial<Record<string, React.ReactNode>>;
11
- headings?: {
12
- items: Array<Heading>;
13
- minDepth?: number;
14
- };
15
- as?: LinkLike;
16
- heading: string;
17
- };
18
-
19
- const MetaBar: FC<MetaBarProps> = ({
20
- items,
21
- headings,
22
- as: Component = 'a',
23
- heading,
24
- }) => {
25
- // The default depth of headings to display in the table of contents.
26
- const { minDepth = 2, items: headingItems = [] } = headings || {};
27
-
28
- const filteredHeadings = useMemo(
29
- () => headingItems.filter(({ depth }) => depth >= minDepth && depth <= 4),
30
- [minDepth, headingItems]
31
- );
32
-
33
- return (
34
- <div className={styles.wrapper}>
35
- <dl>
36
- {Object.entries(items)
37
- .filter(([, value]) => !!value)
38
- .map(([key, value]) => (
39
- <Fragment key={key}>
40
- <dt>{key}</dt>
41
- <dd>{value}</dd>
42
- </Fragment>
43
- ))}
44
-
45
- {filteredHeadings.length > 0 && (
46
- <>
47
- <dt>{heading}</dt>
48
- <dd>
49
- <ol>
50
- {filteredHeadings.map(head => (
51
- <li
52
- key={head.value}
53
- className={
54
- head.depth === 3 ? 'pl-2' : head.depth === 4 ? 'pl-4' : ''
55
- }
56
- >
57
- <Component href={`#${head?.data?.id}`}>
58
- {' '}
59
- {head.value}
60
- </Component>
61
- </li>
62
- ))}
63
- </ol>
64
- </dd>
65
- </>
66
- )}
67
- </dl>
68
- </div>
69
- );
70
- };
71
-
72
- export default MetaBar;
@@ -1,38 +0,0 @@
1
- import type { Meta as MetaObj, StoryObj } from '@storybook/react';
2
-
3
- import NavItem from '#ui/Containers/NavBar/NavItem';
4
-
5
- type Story = StoryObj<typeof NavItem>;
6
- type Meta = MetaObj<typeof NavItem>;
7
-
8
- export const Default: Story = {
9
- args: {
10
- href: '/learn',
11
- children: 'Learn',
12
- },
13
- };
14
-
15
- export const WithExternalLink: Story = {
16
- args: {
17
- href: 'https://nodejs.org/en',
18
- children: 'Learn',
19
- target: '_blank',
20
- },
21
- };
22
-
23
- export const WithChildren: Story = {
24
- args: {
25
- href: 'https://nodejs.org/en',
26
- children: <b>Learn</b>,
27
- },
28
- };
29
-
30
- export const FooterItem: Story = {
31
- args: {
32
- href: '/about',
33
- children: 'Trademark Policy',
34
- type: 'footer',
35
- },
36
- };
37
-
38
- export default { component: NavItem } as Meta;
@@ -1,44 +0,0 @@
1
- import { ArrowUpRightIcon } from '@heroicons/react/24/solid';
2
- import classNames from 'classnames';
3
- import type { FC, HTMLAttributeAnchorTarget, PropsWithChildren } from 'react';
4
-
5
- import BaseActiveLink from '#ui/Common/BaseActiveLink';
6
- import type { LinkLike } from '#ui/types';
7
-
8
- import styles from './index.module.css';
9
-
10
- type NavItemType = 'nav' | 'footer';
11
-
12
- type NavItemProps = {
13
- href: string;
14
- type?: NavItemType;
15
- className?: string;
16
- target?: HTMLAttributeAnchorTarget | undefined;
17
-
18
- pathname: string;
19
- as: LinkLike;
20
- };
21
-
22
- const NavItem: FC<PropsWithChildren<NavItemProps>> = ({
23
- href = '',
24
- type = 'nav',
25
- children,
26
- className,
27
- target,
28
- ...props
29
- }) => (
30
- <BaseActiveLink
31
- target={target}
32
- href={href}
33
- className={classNames(styles.navItem, styles[type], className)}
34
- activeClassName={styles.active}
35
- allowSubPath={href.startsWith('/')}
36
- {...props}
37
- >
38
- <span className={styles.label}>{children}</span>
39
-
40
- {target === '_blank' && <ArrowUpRightIcon className={styles.icon} />}
41
- </BaseActiveLink>
42
- );
43
-
44
- export default NavItem;
@@ -1,45 +0,0 @@
1
- import type { Meta as MetaObj, StoryObj } from '@storybook/react';
2
-
3
- import NavBar from '#ui/Containers/NavBar';
4
-
5
- type Story = StoryObj<typeof NavBar>;
6
- type Meta = MetaObj<typeof NavBar>;
7
-
8
- export const Default: Story = {
9
- args: {
10
- as: 'a',
11
- Logo: 'a',
12
- pathname: '/',
13
-
14
- children: <a>Some other child</a>,
15
-
16
- navItems: [
17
- {
18
- text: 'Learn',
19
- link: '/',
20
- },
21
- {
22
- text: 'About',
23
- link: '/about',
24
- },
25
- {
26
- text: 'Docs',
27
- link: '/docs',
28
- },
29
- {
30
- text: 'Download',
31
- link: '/download',
32
- },
33
- {
34
- text: 'Blog',
35
- link: '/blog',
36
- },
37
- {
38
- text: 'Certification',
39
- link: 'https://openjsf.org/certification',
40
- },
41
- ],
42
- },
43
- };
44
-
45
- export default { component: NavBar } as Meta;
@@ -1,94 +0,0 @@
1
- 'use client';
2
-
3
- import Hamburger from '@heroicons/react/24/solid/Bars3Icon';
4
- import XMark from '@heroicons/react/24/solid/XMarkIcon';
5
- import * as Label from '@radix-ui/react-label';
6
- import classNames from 'classnames';
7
- import { useState } from 'react';
8
- import type {
9
- FC,
10
- HTMLAttributeAnchorTarget,
11
- PropsWithChildren,
12
- ElementType,
13
- } from 'react';
14
-
15
- import NavItem from '#ui/Containers/NavBar/NavItem';
16
- import type { FormattedMessage, LinkLike } from '#ui/types';
17
-
18
- import style from './index.module.css';
19
-
20
- const navInteractionIcons = {
21
- show: <Hamburger className={style.navInteractionIcon} />,
22
- close: <XMark className={style.navInteractionIcon} />,
23
- };
24
-
25
- type NavbarProps = {
26
- navItems: Array<{
27
- text: FormattedMessage;
28
- link: string;
29
- target?: HTMLAttributeAnchorTarget | undefined;
30
- }>;
31
- Logo: ElementType;
32
- as: LinkLike;
33
- pathname: string;
34
- sidebarItemTogglerAriaLabel: string;
35
- };
36
-
37
- const NavBar: FC<PropsWithChildren<NavbarProps>> = ({
38
- children,
39
- Logo,
40
- as: Component = 'a',
41
- navItems,
42
- pathname,
43
- sidebarItemTogglerAriaLabel,
44
- }) => {
45
- const [isMenuOpen, setIsMenuOpen] = useState(false);
46
-
47
- return (
48
- <nav className={style.container}>
49
- <div className={style.nodeIconAndMobileItemsToggler}>
50
- <Component className={style.nodeIconWrapper} href="/" aria-label="Home">
51
- <Logo />
52
- </Component>
53
-
54
- <Label.Root
55
- className={style.sidebarItemTogglerLabel}
56
- htmlFor="sidebarItemToggler"
57
- role="button"
58
- aria-label={sidebarItemTogglerAriaLabel}
59
- >
60
- {navInteractionIcons[isMenuOpen ? 'close' : 'show']}
61
- </Label.Root>
62
- </div>
63
-
64
- <input
65
- className={classNames(['peer', style.sidebarItemToggler])}
66
- id="sidebarItemToggler"
67
- type="checkbox"
68
- onChange={e => setIsMenuOpen(() => e.target.checked)}
69
- aria-label={sidebarItemTogglerAriaLabel}
70
- tabIndex={-1}
71
- />
72
-
73
- <div className={`${style.main} hidden peer-checked:flex`}>
74
- <div className={style.navItems}>
75
- {navItems.map(({ text, link, target }) => (
76
- <NavItem
77
- pathname={pathname}
78
- as={Component}
79
- key={link}
80
- href={link}
81
- target={target}
82
- >
83
- {text}
84
- </NavItem>
85
- ))}
86
- </div>
87
-
88
- <div className={style.actionsWrapper}>{children}</div>
89
- </div>
90
- </nav>
91
- );
92
- };
93
-
94
- export default NavBar;
@@ -1,36 +0,0 @@
1
- import type { Meta as MetaObj, StoryObj } from '@storybook/react';
2
-
3
- import SidebarGroup from '#ui/Containers/Sidebar/SidebarGroup';
4
-
5
- type Story = StoryObj<typeof SidebarGroup>;
6
- type Meta = MetaObj<typeof SidebarGroup>;
7
-
8
- export const Default: Story = {
9
- args: {
10
- groupName: 'Example Group',
11
- items: [
12
- { label: 'Item 1', link: '/item1' },
13
- { label: 'Item 2', link: '/item2' },
14
- { label: 'Item 3', link: '/item3' },
15
- ],
16
- },
17
- };
18
-
19
- export const CustomGroup: Story = {
20
- args: {
21
- groupName: 'Custom Group',
22
- items: [
23
- { label: 'Custom Item 1', link: '/custom-item1' },
24
- { label: 'Custom Item 2', link: '/custom-item2' },
25
- ],
26
- },
27
- };
28
-
29
- export const EmptyGroup: Story = {
30
- args: {
31
- groupName: 'Empty Group',
32
- items: [],
33
- },
34
- };
35
-
36
- export default { component: SidebarGroup } as Meta;
@@ -1,30 +0,0 @@
1
- import type { ComponentProps, FC } from 'react';
2
-
3
- import SidebarItem from '#ui/Containers/Sidebar/SidebarItem';
4
- import type { FormattedMessage, LinkLike } from '#ui/types';
5
-
6
- import styles from './index.module.css';
7
-
8
- type SidebarGroupProps = {
9
- groupName: FormattedMessage;
10
- items: Array<Omit<ComponentProps<typeof SidebarItem>, 'as' | 'pathname'>>;
11
- as?: LinkLike;
12
- pathname?: string;
13
- };
14
-
15
- const SidebarGroup: FC<SidebarGroupProps> = ({
16
- groupName,
17
- items,
18
- ...props
19
- }) => (
20
- <section className={styles.group}>
21
- <label className={styles.groupName}>{groupName}</label>
22
- <ul className={styles.itemList}>
23
- {items.map(({ label, link }) => (
24
- <SidebarItem key={link} label={label} link={link} {...props} />
25
- ))}
26
- </ul>
27
- </section>
28
- );
29
-
30
- export default SidebarGroup;
@@ -1,15 +0,0 @@
1
- import type { Meta as MetaObj, StoryObj } from '@storybook/react';
2
-
3
- import SidebarItem from '#ui/Containers/Sidebar/SidebarItem';
4
-
5
- type Story = StoryObj<typeof SidebarItem>;
6
- type Meta = MetaObj<typeof SidebarItem>;
7
-
8
- export const Default: Story = {
9
- args: {
10
- label: 'Example Item',
11
- link: '/example',
12
- },
13
- };
14
-
15
- export default { component: SidebarItem } as Meta;
@@ -1,26 +0,0 @@
1
- import { ArrowUpRightIcon } from '@heroicons/react/24/solid';
2
- import type { FC } from 'react';
3
-
4
- import ActiveLink from '#ui/Common/BaseActiveLink';
5
- import type { FormattedMessage, LinkLike } from '#ui/types';
6
-
7
- import styles from './index.module.css';
8
-
9
- type SidebarItemProps = {
10
- label: FormattedMessage;
11
- link: string;
12
- as?: LinkLike;
13
- pathname?: string;
14
- };
15
-
16
- const SidebarItem: FC<SidebarItemProps> = ({ label, link, ...props }) => (
17
- <li className={styles.sideBarItem}>
18
- <ActiveLink href={link} activeClassName={styles.active} {...props}>
19
- <span className={styles.label}>{label}</span>
20
-
21
- {link.startsWith('http') && <ArrowUpRightIcon className={styles.icon} />}
22
- </ActiveLink>
23
- </li>
24
- );
25
-
26
- export default SidebarItem;