@redocly/theme 0.1.8 → 0.1.11

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 (322) hide show
  1. package/Button/index.d.ts +1 -1
  2. package/Button/index.js +1 -1
  3. package/CodeBlock/index.d.ts +1 -1
  4. package/CodeBlock/index.js +1 -1
  5. package/CopyButton/index.d.ts +2 -2
  6. package/CopyButton/index.js +2 -2
  7. package/Footer/Footer.d.ts +2 -2
  8. package/Footer/Footer.js +6 -5
  9. package/Footer/FooterColumn.d.ts +1 -1
  10. package/Footer/FooterColumn.js +8 -7
  11. package/Footer/FooterColumns.d.ts +3 -3
  12. package/Footer/FooterColumns.js +4 -4
  13. package/Footer/FooterCopyright.d.ts +3 -3
  14. package/Footer/FooterCopyright.js +3 -2
  15. package/Footer/index.d.ts +4 -4
  16. package/Footer/index.js +17 -11
  17. package/Headings/index.d.ts +1 -1
  18. package/Headings/index.js +1 -1
  19. package/JsonViewer/index.d.ts +2 -2
  20. package/JsonViewer/index.js +2 -2
  21. package/Layout/PageLayout.d.ts +1 -1
  22. package/Layout/PageLayout.js +2 -1
  23. package/Layout/RootLayout.d.ts +1 -1
  24. package/Layout/RootLayout.js +2 -1
  25. package/Layout/index.d.ts +2 -2
  26. package/Layout/index.js +15 -7
  27. package/Markdown/{Admonition/Admonition.d.ts → Admonition.d.ts} +0 -0
  28. package/Markdown/{Admonition/Admonition.js → Admonition.js} +5 -5
  29. package/Markdown/CodeSample/index.d.ts +3 -0
  30. package/Markdown/CodeSample/index.js +19 -0
  31. package/Markdown/{Heading/Heading.d.ts → Heading.d.ts} +0 -0
  32. package/Markdown/{Heading/Heading.js → Heading.js} +1 -1
  33. package/Markdown/MarkdownLayout.d.ts +2 -2
  34. package/Markdown/{Mermaid/Mermaid.d.ts → Mermaid.d.ts} +0 -0
  35. package/Markdown/{Mermaid/Mermaid.js → Mermaid.js} +0 -0
  36. package/Markdown/StyledMarkdown.js +2 -2
  37. package/Markdown/Tabs/index.d.ts +2 -0
  38. package/Markdown/Tabs/index.js +18 -0
  39. package/Markdown/index.d.ts +9 -0
  40. package/Markdown/index.js +25 -0
  41. package/Navbar/Navbar.d.ts +1 -2
  42. package/Navbar/Navbar.js +3 -3
  43. package/Navbar/NavbarItem.d.ts +1 -1
  44. package/Navbar/NavbarItem.js +3 -3
  45. package/Navbar/NavbarMenu.d.ts +1 -1
  46. package/Navbar/NavbarMenu.js +5 -4
  47. package/Navbar/index.d.ts +3 -0
  48. package/Navbar/index.js +19 -0
  49. package/NavbarLogo/NavbarLogo.d.ts +6 -0
  50. package/{Logo/Logo.js → NavbarLogo/NavbarLogo.js} +8 -5
  51. package/NavbarLogo/index.d.ts +1 -0
  52. package/NavbarLogo/index.js +17 -0
  53. package/OperationBadge/index.d.ts +1 -1
  54. package/OperationBadge/index.js +1 -1
  55. package/PageNavigation/index.d.ts +3 -0
  56. package/PageNavigation/index.js +19 -0
  57. package/Panel/index.d.ts +8 -8
  58. package/Panel/index.js +8 -8
  59. package/REAMDE.md +1 -0
  60. package/SamplesPanelControls/index.d.ts +1 -1
  61. package/SamplesPanelControls/index.js +1 -1
  62. package/Search/Autocomplete.js +1 -1
  63. package/Search/ClearIcon.js +1 -1
  64. package/Search/Parameters.js +2 -2
  65. package/Search/SearchIcon.js +1 -1
  66. package/Search/SearchItem.js +2 -2
  67. package/Search/index.d.ts +9 -0
  68. package/Search/index.js +25 -0
  69. package/Search/utils.js +1 -1
  70. package/Sidebar/ApiCallItem.d.ts +2 -2
  71. package/Sidebar/ApiCallItem.js +6 -6
  72. package/Sidebar/ArrowBack.d.ts +1 -2
  73. package/Sidebar/ArrowBack.js +2 -1
  74. package/Sidebar/BackButton.d.ts +1 -1
  75. package/Sidebar/BackButton.js +5 -4
  76. package/Sidebar/Drilldown.d.ts +2 -2
  77. package/Sidebar/Drilldown.js +8 -7
  78. package/Sidebar/DrilldownMenu.d.ts +2 -2
  79. package/Sidebar/DrilldownMenu.js +5 -7
  80. package/Sidebar/DrilldownMenuItem.d.ts +2 -2
  81. package/Sidebar/DrilldownMenuItem.js +5 -4
  82. package/Sidebar/ExternalIcon.d.ts +1 -2
  83. package/Sidebar/ExternalIcon.js +2 -1
  84. package/Sidebar/Menu.d.ts +1 -2
  85. package/Sidebar/Menu.js +3 -2
  86. package/Sidebar/MenuContainer.d.ts +1 -2
  87. package/Sidebar/MenuContainer.js +2 -1
  88. package/Sidebar/MenuGroup.d.ts +1 -1
  89. package/Sidebar/MenuGroup.js +6 -6
  90. package/Sidebar/MenuItem.d.ts +2 -2
  91. package/Sidebar/MenuItem.js +7 -6
  92. package/Sidebar/MenuItemLabel.d.ts +1 -2
  93. package/Sidebar/MenuItemLabel.js +4 -3
  94. package/Sidebar/MenuLink.d.ts +1 -2
  95. package/Sidebar/MenuLink.js +3 -2
  96. package/Sidebar/MenuLinkItem.d.ts +2 -2
  97. package/Sidebar/MenuLinkItem.js +4 -3
  98. package/Sidebar/MobileSidebarButton.d.ts +1 -2
  99. package/Sidebar/MobileSidebarButton.js +3 -2
  100. package/Sidebar/Separator.d.ts +2 -2
  101. package/Sidebar/Separator.js +5 -4
  102. package/Sidebar/SeparatorItem.d.ts +1 -2
  103. package/Sidebar/SeparatorItem.js +3 -2
  104. package/Sidebar/SeparatorLine.d.ts +1 -2
  105. package/Sidebar/SeparatorLine.js +2 -1
  106. package/Sidebar/Sidebar.d.ts +2 -2
  107. package/Sidebar/Sidebar.js +3 -2
  108. package/Sidebar/SidebarLayout.d.ts +1 -1
  109. package/Sidebar/SidebarLayout.js +6 -5
  110. package/Sidebar/index.d.ts +19 -0
  111. package/Sidebar/index.js +35 -0
  112. package/Sidebar/types/DrilldownMenuProps.d.ts +2 -2
  113. package/Sidebar/types/ItemState.d.ts +2 -3
  114. package/Sidebar/types/MenuItemProps.d.ts +2 -2
  115. package/Sidebar/types/NavItem.d.ts +1 -1
  116. package/Sidebar/types/index.d.ts +5 -0
  117. package/Sidebar/types/index.js +21 -0
  118. package/SidebarLogo/index.d.ts +1 -1
  119. package/SidebarLogo/index.js +1 -1
  120. package/SourceCode/index.d.ts +1 -1
  121. package/SourceCode/index.js +1 -1
  122. package/TableOfContent/TableOfContent.d.ts +1 -1
  123. package/TableOfContent/TableOfContent.js +9 -9
  124. package/TableOfContent/index.d.ts +1 -0
  125. package/TableOfContent/index.js +17 -0
  126. package/Tooltip/index.d.ts +1 -1
  127. package/Tooltip/index.js +1 -1
  128. package/globalStyle.d.ts +1 -0
  129. package/globalStyle.js +7 -3
  130. package/hooks/index.d.ts +7 -7
  131. package/hooks/index.js +7 -7
  132. package/hooks/useActiveSectionId.d.ts +2 -2
  133. package/hooks/useActiveSectionId.js +1 -0
  134. package/icons/ShelfIcon/index.d.ts +2 -2
  135. package/icons/ShelfIcon/index.js +1 -1
  136. package/icons/index.d.ts +1 -1
  137. package/icons/index.js +1 -1
  138. package/index.d.ts +1 -0
  139. package/index.js +1 -0
  140. package/mocks/Link.js +4 -1
  141. package/mocks/hooks/usePageData.js +4 -1
  142. package/package.json +1 -1
  143. package/src/Button/Button.stories.tsx +1 -1
  144. package/src/Button/index.ts +1 -1
  145. package/src/CodeBlock/index.ts +1 -1
  146. package/src/CopyButton/CopyButton.stories.tsx +1 -1
  147. package/src/CopyButton/index.ts +2 -2
  148. package/src/DesignTokens/borders.stories.mdx +20 -0
  149. package/src/DesignTokens/colors.stories.mdx +24 -0
  150. package/src/DesignTokens/page-layout.stories.mdx +12 -0
  151. package/src/DesignTokens/tokens-generated.scss +610 -0
  152. package/src/DesignTokens/typography.stories.mdx +36 -0
  153. package/src/Footer/Footer.stories.tsx +57 -0
  154. package/src/Footer/Footer.tsx +7 -10
  155. package/src/Footer/FooterColumn.tsx +8 -8
  156. package/src/Footer/FooterColumns.tsx +5 -3
  157. package/src/Footer/FooterCopyright.tsx +6 -4
  158. package/src/Footer/__tests__/Footer.test.tsx +55 -0
  159. package/src/Footer/__tests__/__snapshots__/Footer.test.tsx.snap +253 -0
  160. package/src/Footer/index.ts +4 -0
  161. package/src/Headings/index.ts +1 -1
  162. package/src/JsonViewer/JsonViewer.stories.tsx +1 -1
  163. package/src/JsonViewer/index.ts +2 -2
  164. package/src/Layout/PageLayout.tsx +1 -1
  165. package/src/Layout/RootLayout.tsx +1 -1
  166. package/src/Layout/__tests__/PageLayout.test.tsx +17 -0
  167. package/src/Layout/__tests__/RootLayout.test.tsx +17 -0
  168. package/src/Layout/__tests__/__snapshots__/PageLayout.test.tsx.snap +38 -0
  169. package/src/Layout/__tests__/__snapshots__/RootLayout.test.tsx.snap +18 -0
  170. package/src/Layout/index.ts +2 -0
  171. package/src/Markdown/{Admonition/Admonition.tsx → Admonition.tsx} +15 -15
  172. package/src/Markdown/CodeSample/index.ts +3 -0
  173. package/src/Markdown/{Heading/Heading.tsx → Heading.tsx} +4 -1
  174. package/src/Markdown/MarkdownLayout.tsx +2 -2
  175. package/src/Markdown/{Mermaid/Mermaid.tsx → Mermaid.tsx} +0 -0
  176. package/src/Markdown/StyledMarkdown.tsx +27 -27
  177. package/src/Markdown/Tabs/index.ts +2 -0
  178. package/src/Markdown/index.ts +9 -0
  179. package/src/Navbar/Navbar.stories.tsx +10 -6
  180. package/src/Navbar/Navbar.tsx +3 -4
  181. package/src/Navbar/NavbarItem.tsx +2 -2
  182. package/src/Navbar/NavbarMenu.tsx +3 -3
  183. package/src/Navbar/__tests__/Navbar.test.tsx +55 -0
  184. package/src/Navbar/__tests__/__snapshots__/Navbar.test.tsx.snap +256 -0
  185. package/src/Navbar/index.ts +3 -0
  186. package/src/NavbarLogo/NavbarLogo.stories.tsx +20 -0
  187. package/src/NavbarLogo/NavbarLogo.tsx +24 -0
  188. package/src/NavbarLogo/__tests__/NavbarLogo.test.tsx +47 -0
  189. package/src/NavbarLogo/__tests__/__snapshots__/NavbarLogo.test.tsx.snap +38 -0
  190. package/src/NavbarLogo/index.ts +1 -0
  191. package/src/OperationBadge/OperationBadge.stories.tsx +1 -1
  192. package/src/OperationBadge/index.ts +1 -1
  193. package/src/PageNavigation/PageNavigation.stories.tsx +21 -0
  194. package/src/PageNavigation/__tests__/NextPageLink.test.tsx +29 -0
  195. package/src/PageNavigation/__tests__/PageNavigation.test.tsx +54 -0
  196. package/src/PageNavigation/__tests__/PreviousPageLink.test.tsx +29 -0
  197. package/src/PageNavigation/__tests__/__snapshots__/NextPageLink.test.tsx.snap +67 -0
  198. package/src/PageNavigation/__tests__/__snapshots__/PageNavigation.test.tsx.snap +275 -0
  199. package/src/PageNavigation/__tests__/__snapshots__/PreviousPageLink.test.tsx.snap +67 -0
  200. package/src/PageNavigation/index.ts +3 -0
  201. package/src/Panel/index.ts +8 -8
  202. package/src/SamplesPanelControls/SamplesControlButton.stories.tsx +1 -1
  203. package/src/SamplesPanelControls/index.ts +1 -1
  204. package/src/Search/Autocomplete.tsx +1 -1
  205. package/src/Search/ClearIcon.tsx +11 -12
  206. package/src/Search/Parameters.tsx +2 -2
  207. package/src/Search/SearchIcon.tsx +11 -12
  208. package/src/Search/SearchItem.tsx +2 -2
  209. package/src/Search/__tests__/Input.test.tsx +13 -0
  210. package/src/Search/__tests__/__snapshots__/Input.test.tsx.snap +36 -0
  211. package/src/Search/index.ts +9 -0
  212. package/src/Search/utils.tsx +1 -1
  213. package/src/Sidebar/ApiCallItem.tsx +5 -5
  214. package/src/Sidebar/ArrowBack.tsx +1 -1
  215. package/src/Sidebar/BackButton.tsx +4 -4
  216. package/src/Sidebar/Drilldown.tsx +6 -6
  217. package/src/Sidebar/DrilldownMenu.tsx +4 -4
  218. package/src/Sidebar/DrilldownMenuItem.tsx +6 -6
  219. package/src/Sidebar/ExternalIcon.tsx +1 -1
  220. package/src/Sidebar/Menu.tsx +2 -2
  221. package/src/Sidebar/MenuContainer.tsx +1 -1
  222. package/src/Sidebar/MenuGroup.tsx +5 -5
  223. package/src/Sidebar/MenuItem.tsx +6 -6
  224. package/src/Sidebar/MenuItemLabel.tsx +5 -5
  225. package/src/Sidebar/MenuLink.tsx +2 -2
  226. package/src/Sidebar/MenuLinkItem.tsx +3 -3
  227. package/src/Sidebar/MobileSidebarButton.tsx +3 -3
  228. package/src/Sidebar/Separator.tsx +4 -4
  229. package/src/Sidebar/SeparatorItem.tsx +2 -2
  230. package/src/Sidebar/SeparatorLine.tsx +1 -1
  231. package/src/Sidebar/Sidebar.tsx +2 -2
  232. package/src/Sidebar/SidebarLayout.tsx +4 -4
  233. package/src/Sidebar/index.ts +19 -0
  234. package/src/Sidebar/types/DrilldownMenuProps.ts +2 -2
  235. package/src/Sidebar/types/ItemState.ts +2 -4
  236. package/src/Sidebar/types/MenuItemProps.ts +2 -2
  237. package/src/Sidebar/types/NavItem.ts +1 -1
  238. package/src/Sidebar/types/index.ts +5 -0
  239. package/src/SidebarLogo/SidebarLogo.stories.tsx +1 -1
  240. package/src/SidebarLogo/index.ts +1 -1
  241. package/src/SourceCode/SourceCode.stories.tsx +1 -1
  242. package/src/SourceCode/index.ts +1 -1
  243. package/src/TableOfContent/TableOfContent.stories.tsx +37 -0
  244. package/src/TableOfContent/TableOfContent.tsx +13 -11
  245. package/src/TableOfContent/__tests__/TableOfContent.test.tsx +61 -0
  246. package/src/TableOfContent/__tests__/__snapshots__/TableOfContent.test.tsx.snap +153 -0
  247. package/src/TableOfContent/index.ts +1 -0
  248. package/src/Tooltip/Tooltip.stories.tsx +1 -1
  249. package/src/Tooltip/index.ts +1 -1
  250. package/src/Welcome.stories.mdx +7 -0
  251. package/src/globalStyle.ts +333 -144
  252. package/src/hooks/index.ts +7 -7
  253. package/src/hooks/useActiveSectionId.ts +3 -3
  254. package/src/icons/ShelfIcon/index.ts +2 -2
  255. package/src/icons/index.ts +1 -1
  256. package/src/index.ts +1 -0
  257. package/src/mocks/Link.tsx +5 -2
  258. package/src/mocks/hooks/usePageData.ts +4 -1
  259. package/src/types/portal/index.d.ts +0 -1
  260. package/src/types/portal/src/client/app/Sidebar/types.d.ts +32 -41
  261. package/src/types/portal/src/client/app/media-css.d.ts +4 -4
  262. package/src/types/portal/src/client/styling/default.d.ts +585 -391
  263. package/src/types/portal/src/client/styling/index.d.ts +2 -6
  264. package/src/types/portal/src/server/constants.d.ts +5 -9
  265. package/src/types/portal/src/server/plugins/markdown/types.d.ts +14 -19
  266. package/src/types/portal/src/server/plugins/portal-config/types.d.ts +12 -12
  267. package/src/types/portal/src/server/plugins/types.d.ts +55 -0
  268. package/src/types/portal/src/server/store.d.ts +49 -97
  269. package/src/types/portal/src/server/utils/async.d.ts +1 -5
  270. package/src/types/portal/src/server/utils/content-provider.d.ts +51 -0
  271. package/src/types/portal/src/server/utils/index.d.ts +1 -1
  272. package/src/types/portal/src/server/utils/paths.d.ts +10 -13
  273. package/src/types/portal/src/server/utils/reporter/formatter.d.ts +8 -8
  274. package/src/types/portal/src/server/utils/reporter/reporter.d.ts +15 -15
  275. package/src/types/portal/src/server/version-store.d.ts +35 -0
  276. package/src/types/portal/src/shared/constants.d.ts +6 -6
  277. package/src/types/portal/src/shared/types.d.ts +97 -58
  278. package/src/types/portal/src/shared/urls.d.ts +2 -1
  279. package/src/ui/AlertIcon.tsx +8 -7
  280. package/src/ui/{Arrow/Arrow.tsx → Arrow.tsx} +0 -0
  281. package/src/ui/Background.tsx +3 -3
  282. package/src/ui/Dropdown.tsx +5 -5
  283. package/src/ui/Jumbotron.tsx +3 -3
  284. package/src/ui/Tiles/TileHeader.ts +1 -1
  285. package/src/ui/Tiles/TileText.tsx +2 -2
  286. package/src/ui/Tiles/index.ts +4 -0
  287. package/src/ui/Typography.tsx +22 -22
  288. package/src/ui/UniversalLink.tsx +2 -2
  289. package/src/ui/index.tsx +8 -3
  290. package/src/utils/isUrl.ts +1 -1
  291. package/src/utils/replaceHashInColor.ts +1 -1
  292. package/ui/AlertIcon.d.ts +3 -2
  293. package/ui/AlertIcon.js +2 -2
  294. package/ui/{Arrow/Arrow.d.ts → Arrow.d.ts} +0 -0
  295. package/ui/{Arrow/Arrow.js → Arrow.js} +0 -0
  296. package/ui/Background.js +1 -1
  297. package/ui/Dropdown.d.ts +1 -1
  298. package/ui/Dropdown.js +5 -4
  299. package/ui/Jumbotron.js +3 -3
  300. package/ui/Tiles/TileHeader.js +1 -1
  301. package/ui/Tiles/TileText.js +1 -1
  302. package/ui/Tiles/index.d.ts +4 -0
  303. package/ui/Tiles/index.js +20 -0
  304. package/ui/Typography.js +20 -20
  305. package/ui/UniversalLink.js +4 -4
  306. package/ui/index.d.ts +7 -3
  307. package/ui/index.js +7 -3
  308. package/utils/isUrl.d.ts +1 -1
  309. package/utils/isUrl.js +2 -1
  310. package/utils/replaceHashInColor.d.ts +1 -1
  311. package/utils/replaceHashInColor.js +2 -1
  312. package/Logo/Logo.d.ts +0 -5
  313. package/src/Footer/index.tsx +0 -4
  314. package/src/Introduction.stories.mdx +0 -7
  315. package/src/Layout/index.tsx +0 -2
  316. package/src/Logo/Logo.tsx +0 -17
  317. package/src/types/portal/src/server/plugins/nav-utils.d.ts +0 -19
  318. package/src/types/portal/src/server/plugins/sidebars/index.d.ts +0 -16
  319. package/src/types/portal/src/server/plugins/versions/index.d.ts +0 -15
  320. package/src/types/portal/src/server/plugins/versions/types.d.ts +0 -23
  321. package/src/types/portal/src/server/plugins/versions/utils.d.ts +0 -10
  322. package/src/types/portal/src/server/utils/watcher.d.ts +0 -16
@@ -1,14 +1,11 @@
1
1
  import React from 'react';
2
2
  import styled from 'styled-components';
3
3
 
4
- import FooterColumns from '@theme/Footer/FooterColumns';
5
- import FooterCopyright from '@theme/Footer/FooterCopyright';
4
+ import { FooterColumns } from '@theme/Footer/FooterColumns';
5
+ import { FooterCopyright } from '@theme/Footer/FooterCopyright';
6
6
  import type { FooterConfig } from '@theme/types/portal';
7
7
 
8
- export default function Footer({
9
- columns,
10
- copyrightText,
11
- }: React.PropsWithChildren<FooterConfig>): JSX.Element | null {
8
+ export function Footer({ columns, copyrightText }: FooterConfig): JSX.Element | null {
12
9
  if (!(columns?.length || copyrightText)) {
13
10
  return null;
14
11
  }
@@ -24,11 +21,11 @@ export default function Footer({
24
21
  const FooterContainer = styled.footer`
25
22
  font-size: 1rem;
26
23
  flex-shrink: 0;
27
- background-color: var(--footer-color-background);
28
- color: var(--footer-color-text);
29
- font-family: var(--font-family-primary);
24
+ background-color: var(--footer-background-color);
25
+ color: var(--footer-text-color);
26
+ font-family: var(--font-family-base);
30
27
  a,
31
28
  a:hover {
32
- color: var(--footer-color-text);
29
+ color: var(--footer-text-color);
33
30
  }
34
31
  `;
@@ -8,21 +8,21 @@ interface FooterColumnProps {
8
8
  column: Column;
9
9
  }
10
10
 
11
- export default function FooterColumn({ column }: FooterColumnProps): JSX.Element {
11
+ export function FooterColumn({ column }: FooterColumnProps): JSX.Element {
12
12
  return (
13
13
  <FooterColumnContainer data-component-name="Footer/FooterColumn">
14
14
  <FooterColumnTitle>{column.group || column.label}</FooterColumnTitle>
15
- {column.items.map((columnItem, columnItemInex) => {
15
+ {column.items.map((columnItem, columnItemIndex) => {
16
16
  if (columnItem.type === 'error') {
17
17
  return null;
18
18
  }
19
19
 
20
20
  return columnItem.type === 'separator' ? (
21
- <FooterSeparator key={columnItem.label + '_' + columnItemInex}>
21
+ <FooterSeparator key={columnItem.label + '_' + columnItemIndex}>
22
22
  {columnItem.label}
23
23
  </FooterSeparator>
24
24
  ) : (
25
- <FooterLink key={columnItemInex} to={columnItem.link} data-cy={columnItem.label}>
25
+ <FooterLink key={columnItemIndex} to={columnItem.link} data-cy={columnItem.label}>
26
26
  {columnItem.label}
27
27
  </FooterLink>
28
28
  );
@@ -36,7 +36,7 @@ const FooterColumnTitle = styled.p`
36
36
  font-weight: var(--font-weight-regular);
37
37
  font-size: 24px;
38
38
  margin-bottom: 1.5em;
39
- font-family: var(--font-family-h);
39
+ font-family: var(--h-font-family);
40
40
  `;
41
41
 
42
42
  const FooterSeparator = styled.div`
@@ -44,19 +44,19 @@ const FooterSeparator = styled.div`
44
44
  margin: 10px 0 5px 0;
45
45
  font-size: 0.75em;
46
46
  text-transform: uppercase;
47
- font-family: var(--font-family-h);
47
+ font-family: var(--h-font-family);
48
48
  `;
49
49
 
50
50
  const FooterColumnContainer = styled.div`
51
51
  display: flex;
52
52
  flex-direction: column;
53
53
  text-align: left;
54
- margin: 0px 30px;
54
+ margin: 0 30px;
55
55
  `;
56
56
 
57
57
  const FooterLink = styled(Link)`
58
58
  font-weight: var(--font-weight-bold);
59
59
  padding-bottom: 0.75em;
60
- color: var(--footer-color-text);
60
+ color: var(--footer-text-color);
61
61
  text-decoration: none;
62
62
  `;
@@ -1,12 +1,14 @@
1
1
  import React from 'react';
2
2
  import styled from 'styled-components';
3
3
 
4
- import FooterColumn from '@theme/Footer/FooterColumn';
4
+ import { FooterColumn } from '@theme/Footer/FooterColumn';
5
5
  import type { FooterConfig } from '@theme/types/portal';
6
6
 
7
- export default function FooterColumns({
7
+ export function FooterColumns({
8
8
  columns = [],
9
- }: React.PropsWithChildren<{ columns?: FooterConfig['columns'] }>): JSX.Element | null {
9
+ }: {
10
+ columns?: FooterConfig['columns'];
11
+ }): JSX.Element | null {
10
12
  if (!columns?.length) {
11
13
  return null;
12
14
  }
@@ -3,9 +3,11 @@ import styled from 'styled-components';
3
3
 
4
4
  import type { FooterConfig } from '@theme/types/portal';
5
5
 
6
- export default function FooterCopyright({
6
+ export function FooterCopyright({
7
7
  copyrightText = '',
8
- }: React.PropsWithChildren<{ copyrightText?: FooterConfig['copyrightText'] }>): JSX.Element | null {
8
+ }: {
9
+ copyrightText?: FooterConfig['copyrightText'];
10
+ }): JSX.Element | null {
9
11
  return copyrightText ? (
10
12
  <Wrapper data-component-name="Footer/FooterCopyright">{copyrightText}</Wrapper>
11
13
  ) : null;
@@ -17,8 +19,8 @@ const Wrapper = styled.section`
17
19
  font-size: 0.875em;
18
20
  padding: 1.5em 3em;
19
21
  font-weight: var(--font-weight-bold);
20
- background-color: var(--footer-color-background);
21
- color: var(--footer-color-text);
22
+ background-color: var(--footer-background-color);
23
+ color: var(--footer-text-color);
22
24
  text-align: center;
23
25
  span {
24
26
  max-width: 1200px;
@@ -0,0 +1,55 @@
1
+ import React from 'react';
2
+
3
+ import { renderWithTheme } from '../../../tests/utils';
4
+
5
+ import { Footer } from '@theme/Footer';
6
+
7
+ describe('Footer', () => {
8
+ it('renders columns with copyright and columns', () => {
9
+ const { container } = renderWithTheme(
10
+ <Footer
11
+ columns={[
12
+ {
13
+ group: 'Other',
14
+ items: [
15
+ { label: 'External', type: 'link', link: 'https://google.com/' },
16
+ { type: 'separator', separatorLine: true },
17
+ { label: 'Twitter', type: 'link', link: 'https://twitter.com/' },
18
+ { label: 'Error link', type: 'error' },
19
+ ],
20
+ },
21
+ {
22
+ group: '',
23
+ label: 'Another',
24
+ items: [
25
+ { type: 'separator', separatorLine: true },
26
+ { label: 'Twitter', type: 'link', link: 'https://twitter.com/' },
27
+ { label: 'Error link', type: 'error' },
28
+ ],
29
+ },
30
+ ]}
31
+ copyrightText="Copyright®"
32
+ />,
33
+ );
34
+
35
+ expect(container.firstChild).toMatchSnapshot();
36
+ });
37
+
38
+ it('renders columns with copyright only', () => {
39
+ const { container } = renderWithTheme(<Footer copyrightText="Copyright®" />);
40
+
41
+ expect(container.firstChild).toMatchSnapshot();
42
+ });
43
+
44
+ it('renders nothing, if no columns and copyright provided', () => {
45
+ const { container } = renderWithTheme(<Footer />);
46
+
47
+ expect(container.firstChild).toMatchSnapshot();
48
+ });
49
+
50
+ it('renders nothing, if empty columns and copyright provided', () => {
51
+ const { container } = renderWithTheme(<Footer columns={[]} />);
52
+
53
+ expect(container.firstChild).toMatchSnapshot();
54
+ });
55
+ });
@@ -0,0 +1,253 @@
1
+ // Jest Snapshot v1, https://goo.gl/fbAQLP
2
+
3
+ exports[`Footer renders columns with copyright and columns 1`] = `
4
+ .c4 {
5
+ display: inline-block;
6
+ font-weight: var(--font-weight-regular);
7
+ font-size: 24px;
8
+ margin-bottom: 1.5em;
9
+ font-family: var(--h-font-family);
10
+ }
11
+
12
+ .c6 {
13
+ opacity: 0.75;
14
+ margin: 10px 0 5px 0;
15
+ font-size: 0.75em;
16
+ text-transform: uppercase;
17
+ font-family: var(--h-font-family);
18
+ }
19
+
20
+ .c3 {
21
+ display: -webkit-box;
22
+ display: -webkit-flex;
23
+ display: -ms-flexbox;
24
+ display: flex;
25
+ -webkit-flex-direction: column;
26
+ -ms-flex-direction: column;
27
+ flex-direction: column;
28
+ text-align: left;
29
+ margin: 0 30px;
30
+ }
31
+
32
+ .c5 {
33
+ font-weight: var(--font-weight-bold);
34
+ padding-bottom: 0.75em;
35
+ color: var(--footer-text-color);
36
+ -webkit-text-decoration: none;
37
+ text-decoration: none;
38
+ }
39
+
40
+ .c1 {
41
+ padding: 3em 20px 1em 20px;
42
+ display: -webkit-box;
43
+ display: -webkit-flex;
44
+ display: -ms-flexbox;
45
+ display: flex;
46
+ -webkit-flex-direction: column;
47
+ -ms-flex-direction: column;
48
+ flex-direction: column;
49
+ -webkit-box-pack: center;
50
+ -webkit-justify-content: center;
51
+ -ms-flex-pack: center;
52
+ justify-content: center;
53
+ max-width: 1200px;
54
+ margin: 0 auto;
55
+ }
56
+
57
+ .c2 {
58
+ display: -webkit-box;
59
+ display: -webkit-flex;
60
+ display: -ms-flexbox;
61
+ display: flex;
62
+ -webkit-flex-wrap: wrap;
63
+ -ms-flex-wrap: wrap;
64
+ flex-wrap: wrap;
65
+ -webkit-box-pack: start;
66
+ -webkit-justify-content: flex-start;
67
+ -ms-flex-pack: start;
68
+ justify-content: flex-start;
69
+ }
70
+
71
+ .c7 {
72
+ display: -webkit-box;
73
+ display: -webkit-flex;
74
+ display: -ms-flexbox;
75
+ display: flex;
76
+ -webkit-box-pack: center;
77
+ -webkit-justify-content: center;
78
+ -ms-flex-pack: center;
79
+ justify-content: center;
80
+ font-size: 0.875em;
81
+ padding: 1.5em 3em;
82
+ font-weight: var(--font-weight-bold);
83
+ background-color: var(--footer-background-color);
84
+ color: var(--footer-text-color);
85
+ text-align: center;
86
+ }
87
+
88
+ .c7 span {
89
+ max-width: 1200px;
90
+ }
91
+
92
+ .c0 {
93
+ font-size: 1rem;
94
+ -webkit-flex-shrink: 0;
95
+ -ms-flex-negative: 0;
96
+ flex-shrink: 0;
97
+ background-color: var(--footer-background-color);
98
+ color: var(--footer-text-color);
99
+ font-family: var(--font-family-base);
100
+ }
101
+
102
+ .c0 a,
103
+ .c0 a:hover {
104
+ color: var(--footer-text-color);
105
+ }
106
+
107
+ @media screen and (min-width:50rem) {
108
+ .c1 {
109
+ padding: 5.625em 20px 3.9375em 20px;
110
+ }
111
+ }
112
+
113
+ @media print {
114
+ .c1 {
115
+ color: black;
116
+ display: none;
117
+ }
118
+ }
119
+
120
+ @media screen and (min-width:50rem) {
121
+ .c2 {
122
+ -webkit-box-pack: space-evenly;
123
+ -webkit-justify-content: space-evenly;
124
+ -ms-flex-pack: space-evenly;
125
+ justify-content: space-evenly;
126
+ }
127
+ }
128
+
129
+ <footer
130
+ class="c0"
131
+ data-component-name="Footer/Footer"
132
+ >
133
+ <div
134
+ class="c1"
135
+ data-component-name="Footer/FooterColumns"
136
+ >
137
+ <div
138
+ class="c2"
139
+ >
140
+ <div
141
+ class="c3"
142
+ data-component-name="Footer/FooterColumn"
143
+ >
144
+ <p
145
+ class="c4"
146
+ >
147
+ Other
148
+ </p>
149
+ <a
150
+ class="c5"
151
+ data-cy="External"
152
+ href="https://google.com/"
153
+ to="https://google.com/"
154
+ >
155
+ External
156
+ </a>
157
+ <div
158
+ class="c6"
159
+ />
160
+ <a
161
+ class="c5"
162
+ data-cy="Twitter"
163
+ href="https://twitter.com/"
164
+ to="https://twitter.com/"
165
+ >
166
+ Twitter
167
+ </a>
168
+ </div>
169
+ <div
170
+ class="c3"
171
+ data-component-name="Footer/FooterColumn"
172
+ >
173
+ <p
174
+ class="c4"
175
+ >
176
+ Another
177
+ </p>
178
+ <div
179
+ class="c6"
180
+ />
181
+ <a
182
+ class="c5"
183
+ data-cy="Twitter"
184
+ href="https://twitter.com/"
185
+ to="https://twitter.com/"
186
+ >
187
+ Twitter
188
+ </a>
189
+ </div>
190
+ </div>
191
+ </div>
192
+ <section
193
+ class="c7"
194
+ data-component-name="Footer/FooterCopyright"
195
+ >
196
+ Copyright®
197
+ </section>
198
+ </footer>
199
+ `;
200
+
201
+ exports[`Footer renders columns with copyright only 1`] = `
202
+ .c1 {
203
+ display: -webkit-box;
204
+ display: -webkit-flex;
205
+ display: -ms-flexbox;
206
+ display: flex;
207
+ -webkit-box-pack: center;
208
+ -webkit-justify-content: center;
209
+ -ms-flex-pack: center;
210
+ justify-content: center;
211
+ font-size: 0.875em;
212
+ padding: 1.5em 3em;
213
+ font-weight: var(--font-weight-bold);
214
+ background-color: var(--footer-background-color);
215
+ color: var(--footer-text-color);
216
+ text-align: center;
217
+ }
218
+
219
+ .c1 span {
220
+ max-width: 1200px;
221
+ }
222
+
223
+ .c0 {
224
+ font-size: 1rem;
225
+ -webkit-flex-shrink: 0;
226
+ -ms-flex-negative: 0;
227
+ flex-shrink: 0;
228
+ background-color: var(--footer-background-color);
229
+ color: var(--footer-text-color);
230
+ font-family: var(--font-family-base);
231
+ }
232
+
233
+ .c0 a,
234
+ .c0 a:hover {
235
+ color: var(--footer-text-color);
236
+ }
237
+
238
+ <footer
239
+ class="c0"
240
+ data-component-name="Footer/Footer"
241
+ >
242
+ <section
243
+ class="c1"
244
+ data-component-name="Footer/FooterCopyright"
245
+ >
246
+ Copyright®
247
+ </section>
248
+ </footer>
249
+ `;
250
+
251
+ exports[`Footer renders nothing, if empty columns and copyright provided 1`] = `null`;
252
+
253
+ exports[`Footer renders nothing, if no columns and copyright provided 1`] = `null`;
@@ -0,0 +1,4 @@
1
+ export * from '@theme/Footer/Footer';
2
+ export * from '@theme/Footer/FooterColumn';
3
+ export * from '@theme/Footer/FooterColumns';
4
+ export * from '@theme/Footer/FooterCopyright';
@@ -1 +1 @@
1
- export * from './Headings';
1
+ export * from '@theme/Headings/Headings';
@@ -4,7 +4,7 @@ import { ComponentStory, ComponentMeta } from '@storybook/react';
4
4
  import { JsonViewer } from '@theme/JsonViewer';
5
5
 
6
6
  export default {
7
- title: 'JsonViewer',
7
+ title: 'Components/JsonViewer',
8
8
  component: JsonViewer,
9
9
  } as ComponentMeta<typeof JsonViewer>;
10
10
 
@@ -1,2 +1,2 @@
1
- export * from './JsonViewer';
2
- export * from './styled';
1
+ export * from '@theme/JsonViewer/JsonViewer';
2
+ export * from '@theme/JsonViewer/styled';
@@ -5,7 +5,7 @@ interface PageLayoutProps {
5
5
  sidebar?: React.ReactNode;
6
6
  }
7
7
 
8
- export default function PageLayout({
8
+ export function PageLayout({
9
9
  sidebar,
10
10
  children,
11
11
  }: React.PropsWithChildren<PageLayoutProps>): JSX.Element {
@@ -8,7 +8,7 @@ interface LayoutConfig {
8
8
 
9
9
  const Wrapper = styled.div``;
10
10
 
11
- export default function RootLayout({
11
+ export function RootLayout({
12
12
  navbar,
13
13
  footer,
14
14
  children,
@@ -0,0 +1,17 @@
1
+ import React from 'react';
2
+
3
+ import { renderWithTheme } from '../../../tests/utils';
4
+
5
+ import { PageLayout } from '@theme/Layout/PageLayout';
6
+
7
+ describe('PageLayout', () => {
8
+ it('renders', () => {
9
+ const { container } = renderWithTheme(
10
+ <PageLayout sidebar={<div>sidebar</div>}>
11
+ <div>test content</div>
12
+ </PageLayout>,
13
+ );
14
+
15
+ expect(container.firstChild).toMatchSnapshot();
16
+ });
17
+ });
@@ -0,0 +1,17 @@
1
+ import React from 'react';
2
+
3
+ import { renderWithTheme } from '../../../tests/utils';
4
+
5
+ import { RootLayout } from '@theme/Layout/RootLayout';
6
+
7
+ describe('RootLayout', () => {
8
+ it('renders', () => {
9
+ const { container } = renderWithTheme(
10
+ <RootLayout footer={<div>footer</div>} navbar={<div>navbar</div>}>
11
+ <div>content</div>
12
+ </RootLayout>,
13
+ );
14
+
15
+ expect(container.firstChild).toMatchSnapshot();
16
+ });
17
+ });
@@ -0,0 +1,38 @@
1
+ // Jest Snapshot v1, https://goo.gl/fbAQLP
2
+
3
+ exports[`PageLayout renders 1`] = `
4
+ .c0 {
5
+ display: -webkit-box;
6
+ display: -webkit-flex;
7
+ display: -ms-flexbox;
8
+ display: flex;
9
+ -webkit-flex-direction: row;
10
+ -ms-flex-direction: row;
11
+ flex-direction: row;
12
+ min-height: calc(100vh - var(--navbar-height));
13
+ }
14
+
15
+ .c1 {
16
+ -webkit-flex: 1 0 0;
17
+ -ms-flex: 1 0 0;
18
+ flex: 1 0 0;
19
+ width: 0;
20
+ max-width: 100%;
21
+ }
22
+
23
+ <div
24
+ class="c0"
25
+ data-component-name="Layout/PageLayout"
26
+ >
27
+ <div>
28
+ sidebar
29
+ </div>
30
+ <div
31
+ class="c1"
32
+ >
33
+ <div>
34
+ test content
35
+ </div>
36
+ </div>
37
+ </div>
38
+ `;
@@ -0,0 +1,18 @@
1
+ // Jest Snapshot v1, https://goo.gl/fbAQLP
2
+
3
+ exports[`RootLayout renders 1`] = `
4
+ <div
5
+ class=""
6
+ data-component-name="Layout/RootLayout"
7
+ >
8
+ <div>
9
+ navbar
10
+ </div>
11
+ <div>
12
+ content
13
+ </div>
14
+ <div>
15
+ footer
16
+ </div>
17
+ </div>
18
+ `;
@@ -0,0 +1,2 @@
1
+ export * from '@theme/Layout/RootLayout';
2
+ export * from '@theme/Layout/PageLayout';
@@ -28,17 +28,17 @@ export function Admonition({
28
28
  const Wrapper = styled.div<AdmonitionTypeProps>`
29
29
  position: relative;
30
30
  align-items: center;
31
- margin: var(--alert-margin-vertical) var(--alert-margin-horizontal);
32
- padding: var(--alert-padding-vertical) var(--alert-padding-horizontal);
33
- padding-left: calc(var(--alert-padding-horizontal) * 2 + var(--alert-icon-size));
34
- border-radius: var(--alert-border-radius);
35
- font-size: var(--alert-font-size);
36
- font-weight: var(--alert-font-weight);
37
- line-height: var(--alert-line-height);
31
+ margin: var(--admonition-margin-vertical) var(--admonition-margin-horizontal);
32
+ padding: var(--admonition-padding-vertical) var(--admonition-padding-horizontal);
33
+ padding-left: calc(var(--admonition-padding-horizontal) * 2 + var(--admonition-icon-size));
34
+ border-radius: var(--admonition-border-radius);
35
+ font-size: var(--admonition-font-size);
36
+ font-weight: var(--admonition-font-weight);
37
+ line-height: var(--admonition-line-height);
38
38
 
39
39
  ${({ type }) => `
40
- background-color: var(--alert-${type}-background-color);
41
- color: var(--alert-${type}-text-color);
40
+ background-color: var(--admonition-${type}-background-color);
41
+ color: var(--admonition-${type}-text-color);
42
42
  `}
43
43
  `;
44
44
 
@@ -46,14 +46,14 @@ const Heading = styled.h5<AdmonitionTypeProps>`
46
46
  display: block;
47
47
  margin: 0 0 10px;
48
48
 
49
- letter-spacing: var(--alert-heading-letter-spacing);
50
- color: ${({ type }) => `var(--alert-${type}-heading-color)`};
49
+ letter-spacing: var(--admonition-heading-letter-spacing);
50
+ color: ${({ type }) => `var(--admonition-${type}-text-color)`};
51
51
 
52
52
  && {
53
- font-size: var(--alert-heading-font-size);
54
- font-weight: var(--alert-heading-font-weight);
55
- line-height: var(--alert-line-height);
56
- transform: var(--alert-heading-transform);
53
+ font-size: var(--admonition-heading-font-size);
54
+ font-weight: var(--admonition-heading-font-weight);
55
+ line-height: var(--admonition-line-height);
56
+ transform: var(--admonition-heading-transform);
57
57
  }
58
58
  `;
59
59
 
@@ -0,0 +1,3 @@
1
+ export * from '@theme/Markdown/CodeSample/CodeSample';
2
+ export * from '@theme/Markdown/CodeSample/styled';
3
+ export * from '@theme/Markdown/CodeSample/types';
@@ -30,6 +30,9 @@ export function Heading({
30
30
  return createElement(
31
31
  `h${level}`,
32
32
  { id, className: 'heading-anchor', 'data-component-name': 'Markdown/Heading/Heading' },
33
- [linkEl, children],
33
+ <>
34
+ {linkEl}
35
+ {children}
36
+ </>,
34
37
  );
35
38
  }
@@ -5,8 +5,8 @@ import { ContentWrapper } from '@theme/Markdown/ContentWrapper';
5
5
  import { PageNavigation } from '@theme/PageNavigation/PageNavigation';
6
6
 
7
7
  type MarkdownLayoutProps = {
8
- tableOfContent: React.Component;
9
- markdownWrapper: React.Component;
8
+ tableOfContent: React.ReactNode;
9
+ markdownWrapper: React.ReactNode;
10
10
  };
11
11
 
12
12
  export function MarkdownLayout({