@redocly/theme 0.55.0-next.7 → 0.55.0-next.9

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 (286) hide show
  1. package/lib/components/Breadcrumbs/Breadcrumbs.d.ts +2 -0
  2. package/lib/components/Breadcrumbs/Breadcrumbs.js +2 -1
  3. package/lib/components/Catalog/Catalog.d.ts +11 -0
  4. package/lib/components/Catalog/Catalog.js +138 -0
  5. package/lib/components/Catalog/CatalogActionsRow.d.ts +15 -0
  6. package/lib/components/Catalog/CatalogActionsRow.js +34 -0
  7. package/lib/components/Catalog/CatalogCardView/CatalogCard.d.ts +8 -0
  8. package/lib/components/Catalog/CatalogCardView/CatalogCard.js +179 -0
  9. package/lib/components/Catalog/CatalogCardView/CatalogCardView.d.ts +8 -0
  10. package/lib/components/Catalog/CatalogCardView/CatalogCardView.js +20 -0
  11. package/lib/components/Catalog/CatalogEntities.d.ts +18 -0
  12. package/lib/components/Catalog/CatalogEntities.js +63 -0
  13. package/lib/components/Catalog/CatalogEntitiesEmptyState.d.ts +2 -0
  14. package/lib/components/Catalog/CatalogEntitiesEmptyState.js +38 -0
  15. package/lib/components/Catalog/CatalogEntity/CatalogEntity.d.ts +12 -0
  16. package/lib/components/Catalog/CatalogEntity/CatalogEntity.js +133 -0
  17. package/lib/components/Catalog/CatalogEntity/CatalogEntityInfoBar.d.ts +7 -0
  18. package/lib/components/Catalog/CatalogEntity/CatalogEntityInfoBar.js +49 -0
  19. package/lib/components/Catalog/CatalogEntity/CatalogEntityLinks.d.ts +6 -0
  20. package/lib/components/Catalog/CatalogEntity/CatalogEntityLinks.js +48 -0
  21. package/lib/components/Catalog/CatalogEntity/CatalogEntityMetadata.d.ts +6 -0
  22. package/lib/components/Catalog/CatalogEntity/CatalogEntityMetadata.js +111 -0
  23. package/lib/components/Catalog/CatalogEntity/CatalogEntityProperties/ApiDescriptionProperty.d.ts +6 -0
  24. package/lib/components/Catalog/CatalogEntity/CatalogEntityProperties/ApiDescriptionProperty.js +25 -0
  25. package/lib/components/Catalog/CatalogEntity/CatalogEntityProperties/CatalogEntityProperties.d.ts +6 -0
  26. package/lib/components/Catalog/CatalogEntity/CatalogEntityProperties/CatalogEntityProperties.js +69 -0
  27. package/lib/components/Catalog/CatalogEntity/CatalogEntityProperties/CatalogEntityPropertyCard.d.ts +7 -0
  28. package/lib/components/Catalog/CatalogEntity/CatalogEntityProperties/CatalogEntityPropertyCard.js +48 -0
  29. package/lib/components/Catalog/CatalogEntity/CatalogEntityProperties/ContactProperty.d.ts +6 -0
  30. package/lib/components/Catalog/CatalogEntity/CatalogEntityProperties/ContactProperty.js +19 -0
  31. package/lib/components/Catalog/CatalogEntity/CatalogEntityProperties/DomainsProperty.d.ts +6 -0
  32. package/lib/components/Catalog/CatalogEntity/CatalogEntityProperties/DomainsProperty.js +20 -0
  33. package/lib/components/Catalog/CatalogEntity/CatalogEntityProperties/EntityTypeProperty.d.ts +6 -0
  34. package/lib/components/Catalog/CatalogEntity/CatalogEntityProperties/EntityTypeProperty.js +20 -0
  35. package/lib/components/Catalog/CatalogEntity/CatalogEntityProperties/GitProperty.d.ts +6 -0
  36. package/lib/components/Catalog/CatalogEntity/CatalogEntityProperties/GitProperty.js +23 -0
  37. package/lib/components/Catalog/CatalogEntity/CatalogEntityProperties/OwnersProperty.d.ts +6 -0
  38. package/lib/components/Catalog/CatalogEntity/CatalogEntityProperties/OwnersProperty.js +21 -0
  39. package/lib/components/Catalog/CatalogEntity/CatalogEntityProperties/TagsProperty.d.ts +6 -0
  40. package/lib/components/Catalog/CatalogEntity/CatalogEntityProperties/TagsProperty.js +24 -0
  41. package/lib/components/Catalog/CatalogEntity/CatalogEntityProperties/UserEmailProperty.d.ts +6 -0
  42. package/lib/components/Catalog/CatalogEntity/CatalogEntityProperties/UserEmailProperty.js +21 -0
  43. package/lib/components/Catalog/CatalogEntity/CatalogEntityRelations/CatalogEntityDefaultRelations.d.ts +21 -0
  44. package/lib/components/Catalog/CatalogEntity/CatalogEntityRelations/CatalogEntityDefaultRelations.js +37 -0
  45. package/lib/components/Catalog/CatalogEntity/CatalogEntityRelations/CatalogEntityRelations.d.ts +10 -0
  46. package/lib/components/Catalog/CatalogEntity/CatalogEntityRelations/CatalogEntityRelations.js +31 -0
  47. package/lib/components/Catalog/CatalogEntity/CatalogEntityRelations/CatalogEntityRelationsTable.d.ts +25 -0
  48. package/lib/components/Catalog/CatalogEntity/CatalogEntityRelations/CatalogEntityRelationsTable.js +27 -0
  49. package/lib/components/Catalog/CatalogEntity/CatalogEntityRelations/CatalogEntityTeamRelations.d.ts +22 -0
  50. package/lib/components/Catalog/CatalogEntity/CatalogEntityRelations/CatalogEntityTeamRelations.js +60 -0
  51. package/lib/components/Catalog/CatalogEntityIcon.d.ts +5 -0
  52. package/lib/components/Catalog/CatalogEntityIcon.js +38 -0
  53. package/lib/components/Catalog/CatalogEntityTypeIcon.d.ts +5 -0
  54. package/lib/components/Catalog/CatalogEntityTypeIcon.js +42 -0
  55. package/lib/components/Catalog/CatalogHighlight.d.ts +4 -0
  56. package/lib/components/Catalog/CatalogHighlight.js +48 -0
  57. package/lib/components/Catalog/CatalogPageDescription.d.ts +9 -0
  58. package/lib/components/Catalog/CatalogPageDescription.js +52 -0
  59. package/lib/components/Catalog/CatalogSelector.d.ts +12 -0
  60. package/lib/components/Catalog/CatalogSelector.js +48 -0
  61. package/lib/components/Catalog/CatalogSortButton.d.ts +10 -0
  62. package/lib/components/Catalog/CatalogSortButton.js +71 -0
  63. package/lib/components/Catalog/CatalogTableView/CatalogDomainsCell.d.ts +5 -0
  64. package/lib/components/Catalog/CatalogTableView/CatalogDomainsCell.js +19 -0
  65. package/lib/components/Catalog/CatalogTableView/CatalogEntityCell.d.ts +6 -0
  66. package/lib/components/Catalog/CatalogTableView/CatalogEntityCell.js +63 -0
  67. package/lib/components/Catalog/CatalogTableView/CatalogOwnersCell.d.ts +5 -0
  68. package/lib/components/Catalog/CatalogTableView/CatalogOwnersCell.js +19 -0
  69. package/lib/components/Catalog/CatalogTableView/CatalogTableHeaderCell.d.ts +11 -0
  70. package/lib/components/Catalog/CatalogTableView/CatalogTableHeaderCell.js +101 -0
  71. package/lib/components/Catalog/CatalogTableView/CatalogTableView.d.ts +31 -0
  72. package/lib/components/Catalog/CatalogTableView/CatalogTableView.js +106 -0
  73. package/lib/components/Catalog/CatalogTableView/CatalogTableViewRow.d.ts +27 -0
  74. package/lib/components/Catalog/CatalogTableView/CatalogTableViewRow.js +127 -0
  75. package/lib/components/Catalog/CatalogTableView/CatalogTagsCell.d.ts +6 -0
  76. package/lib/components/Catalog/CatalogTableView/CatalogTagsCell.js +20 -0
  77. package/lib/components/Catalog/CatalogTableView/CatalogUserEntityCell.d.ts +7 -0
  78. package/lib/components/Catalog/CatalogTableView/CatalogUserEntityCell.js +66 -0
  79. package/lib/components/Catalog/CatalogTagsWithTooltip.d.ts +9 -0
  80. package/lib/components/Catalog/CatalogTagsWithTooltip.js +46 -0
  81. package/lib/components/Catalog/CatalogViewModeToggle.d.ts +7 -0
  82. package/lib/components/Catalog/CatalogViewModeToggle.js +67 -0
  83. package/lib/components/Catalog/variables.d.ts +1 -0
  84. package/lib/components/Catalog/variables.dark.d.ts +1 -0
  85. package/lib/components/Catalog/variables.dark.js +8 -0
  86. package/lib/components/Catalog/variables.js +354 -0
  87. package/lib/components/CatalogClassic/CatalogClassicHighlight.js +1 -1
  88. package/lib/components/Filter/Filter.d.ts +1 -1
  89. package/lib/components/Filter/Filter.js +2 -2
  90. package/lib/components/Filter/FilterCheckboxes.d.ts +1 -1
  91. package/lib/components/Filter/FilterCheckboxes.js +4 -4
  92. package/lib/components/Filter/FilterContent.d.ts +3 -1
  93. package/lib/components/Filter/FilterContent.js +34 -4
  94. package/lib/components/Filter/FilterInput.js +35 -3
  95. package/lib/components/Filter/FilterSelect.d.ts +1 -1
  96. package/lib/components/Filter/FilterSelect.js +4 -4
  97. package/lib/components/LoadMore/LoadMore.d.ts +8 -0
  98. package/lib/components/LoadMore/LoadMore.js +18 -0
  99. package/lib/components/Markdown/Markdown.js +1 -1
  100. package/lib/components/PageNavigation/NavigationButton.d.ts +13 -0
  101. package/lib/components/PageNavigation/NavigationButton.js +32 -0
  102. package/lib/components/PageNavigation/NextButton.js +10 -29
  103. package/lib/components/PageNavigation/PageNavigation.js +1 -1
  104. package/lib/components/PageNavigation/PreviousButton.js +11 -27
  105. package/lib/components/Search/SearchAiConversationInput.js +2 -1
  106. package/lib/components/Select/Select.js +3 -3
  107. package/lib/components/Sidebar/Sidebar.d.ts +3 -0
  108. package/lib/components/Sidebar/Sidebar.js +3 -2
  109. package/lib/components/SkipContent/SkipContent.d.ts +2 -0
  110. package/lib/components/SkipContent/SkipContent.js +68 -0
  111. package/lib/components/SkipContent/variables.d.ts +1 -0
  112. package/lib/components/SkipContent/variables.js +23 -0
  113. package/lib/components/Tag/Tag.d.ts +3 -1
  114. package/lib/components/Tag/Tag.js +54 -2
  115. package/lib/components/Tag/variables.js +21 -0
  116. package/lib/components/Tooltip/Tooltip.d.ts +2 -1
  117. package/lib/components/Tooltip/Tooltip.js +26 -19
  118. package/lib/components/Tooltip/variables.js +17 -0
  119. package/lib/core/constants/catalog.d.ts +1 -0
  120. package/lib/core/constants/catalog.js +5 -0
  121. package/lib/core/constants/common.d.ts +1 -0
  122. package/lib/core/constants/common.js +2 -1
  123. package/lib/core/constants/index.d.ts +1 -0
  124. package/lib/core/constants/index.js +1 -0
  125. package/lib/core/constants/search.d.ts +1 -0
  126. package/lib/core/constants/search.js +2 -1
  127. package/lib/core/hooks/__mocks__/use-theme-hooks.d.ts +1 -0
  128. package/lib/core/hooks/__mocks__/use-theme-hooks.js +1 -0
  129. package/lib/core/hooks/catalog/useCatalogEntities.d.ts +4 -0
  130. package/lib/core/hooks/catalog/useCatalogEntities.js +17 -0
  131. package/lib/core/hooks/catalog/useCatalogTableHeaderCellActions.d.ts +15 -0
  132. package/lib/core/hooks/catalog/useCatalogTableHeaderCellActions.js +23 -0
  133. package/lib/core/hooks/catalog/useCatalogTableViewRow.d.ts +11 -0
  134. package/lib/core/hooks/catalog/useCatalogTableViewRow.js +26 -0
  135. package/lib/core/hooks/index.d.ts +2 -0
  136. package/lib/core/hooks/index.js +2 -0
  137. package/lib/core/hooks/use-user-teams.d.ts +1 -0
  138. package/lib/core/hooks/use-user-teams.js +10 -0
  139. package/lib/core/styles/dark.js +2 -0
  140. package/lib/core/styles/global.js +65 -60
  141. package/lib/core/types/catalog.d.ts +118 -5
  142. package/lib/core/types/filter.d.ts +1 -0
  143. package/lib/core/types/hooks.d.ts +11 -4
  144. package/lib/core/types/index.d.ts +1 -0
  145. package/lib/core/types/index.js +1 -0
  146. package/lib/core/types/l10n.d.ts +1 -1
  147. package/lib/core/types/telemetry.d.ts +32 -0
  148. package/lib/core/types/telemetry.js +3 -0
  149. package/lib/icons/AscSortIcon/AscSortIcon.d.ts +9 -0
  150. package/lib/icons/AscSortIcon/AscSortIcon.js +25 -0
  151. package/lib/icons/CardsIcon/CardsIcon.d.ts +9 -0
  152. package/lib/icons/CardsIcon/CardsIcon.js +25 -0
  153. package/lib/icons/CaretDownIcon/CaretDownIcon.d.ts +9 -0
  154. package/lib/icons/CaretDownIcon/CaretDownIcon.js +22 -0
  155. package/lib/icons/CaretUpIcon/CaretUpIcon.d.ts +9 -0
  156. package/lib/icons/CaretUpIcon/CaretUpIcon.js +22 -0
  157. package/lib/icons/DescSortIcon/DescSortIcon.d.ts +9 -0
  158. package/lib/icons/DescSortIcon/DescSortIcon.js +25 -0
  159. package/lib/icons/EntityTypeIcon/EntityTypeIcon.d.ts +9 -0
  160. package/lib/icons/EntityTypeIcon/EntityTypeIcon.js +26 -0
  161. package/lib/icons/GithubIcon/GithubIcon.d.ts +9 -0
  162. package/lib/icons/GithubIcon/GithubIcon.js +22 -0
  163. package/lib/icons/GraphIcon/GraphIcon.d.ts +9 -0
  164. package/lib/icons/GraphIcon/GraphIcon.js +22 -0
  165. package/lib/icons/PeopleIcon/PeopleIcon.d.ts +9 -0
  166. package/lib/icons/PeopleIcon/PeopleIcon.js +27 -0
  167. package/lib/icons/SlackIcon/SlackIcon.d.ts +9 -0
  168. package/lib/icons/SlackIcon/SlackIcon.js +29 -0
  169. package/lib/icons/SortIcon/SortIcon.d.ts +9 -0
  170. package/lib/icons/SortIcon/SortIcon.js +25 -0
  171. package/lib/icons/TableIcon/TableIcon.d.ts +9 -0
  172. package/lib/icons/TableIcon/TableIcon.js +22 -0
  173. package/lib/icons/TagsIcon/TagsIcon.d.ts +9 -0
  174. package/lib/icons/TagsIcon/TagsIcon.js +24 -0
  175. package/lib/index.d.ts +18 -0
  176. package/lib/index.js +19 -0
  177. package/lib/layouts/PageLayout.js +2 -1
  178. package/lib/layouts/RootLayout.js +2 -0
  179. package/lib/markdoc/components/Tabs/Tab.d.ts +2 -1
  180. package/lib/markdoc/components/Tabs/Tab.js +10 -2
  181. package/lib/markdoc/components/Tabs/TabList.js +2 -2
  182. package/lib/markdoc/components/Tabs/Tabs.d.ts +3 -1
  183. package/lib/markdoc/components/Tabs/Tabs.js +2 -2
  184. package/package.json +2 -1
  185. package/src/components/Breadcrumbs/Breadcrumbs.tsx +7 -2
  186. package/src/components/Catalog/Catalog.tsx +235 -0
  187. package/src/components/Catalog/CatalogActionsRow.tsx +58 -0
  188. package/src/components/Catalog/CatalogCardView/CatalogCard.tsx +227 -0
  189. package/src/components/Catalog/CatalogCardView/CatalogCardView.tsx +29 -0
  190. package/src/components/Catalog/CatalogEntities.tsx +107 -0
  191. package/src/components/Catalog/CatalogEntitiesEmptyState.tsx +38 -0
  192. package/src/components/Catalog/CatalogEntity/CatalogEntity.tsx +207 -0
  193. package/src/components/Catalog/CatalogEntity/CatalogEntityInfoBar.tsx +60 -0
  194. package/src/components/Catalog/CatalogEntity/CatalogEntityLinks.tsx +67 -0
  195. package/src/components/Catalog/CatalogEntity/CatalogEntityMetadata.tsx +93 -0
  196. package/src/components/Catalog/CatalogEntity/CatalogEntityProperties/ApiDescriptionProperty.tsx +35 -0
  197. package/src/components/Catalog/CatalogEntity/CatalogEntityProperties/CatalogEntityProperties.tsx +83 -0
  198. package/src/components/Catalog/CatalogEntity/CatalogEntityProperties/CatalogEntityPropertyCard.tsx +62 -0
  199. package/src/components/Catalog/CatalogEntity/CatalogEntityProperties/ContactProperty.tsx +36 -0
  200. package/src/components/Catalog/CatalogEntity/CatalogEntityProperties/DomainsProperty.tsx +38 -0
  201. package/src/components/Catalog/CatalogEntity/CatalogEntityProperties/EntityTypeProperty.tsx +33 -0
  202. package/src/components/Catalog/CatalogEntity/CatalogEntityProperties/GitProperty.tsx +41 -0
  203. package/src/components/Catalog/CatalogEntity/CatalogEntityProperties/OwnersProperty.tsx +42 -0
  204. package/src/components/Catalog/CatalogEntity/CatalogEntityProperties/TagsProperty.tsx +39 -0
  205. package/src/components/Catalog/CatalogEntity/CatalogEntityProperties/UserEmailProperty.tsx +31 -0
  206. package/src/components/Catalog/CatalogEntity/CatalogEntityRelations/CatalogEntityDefaultRelations.tsx +97 -0
  207. package/src/components/Catalog/CatalogEntity/CatalogEntityRelations/CatalogEntityRelations.tsx +80 -0
  208. package/src/components/Catalog/CatalogEntity/CatalogEntityRelations/CatalogEntityRelationsTable.tsx +92 -0
  209. package/src/components/Catalog/CatalogEntity/CatalogEntityRelations/CatalogEntityTeamRelations.tsx +127 -0
  210. package/src/components/Catalog/CatalogEntityIcon.tsx +41 -0
  211. package/src/components/Catalog/CatalogEntityTypeIcon.tsx +48 -0
  212. package/src/components/Catalog/CatalogHighlight.tsx +56 -0
  213. package/src/components/Catalog/CatalogPageDescription.tsx +72 -0
  214. package/src/components/Catalog/CatalogSelector.tsx +67 -0
  215. package/src/components/Catalog/CatalogSortButton.tsx +78 -0
  216. package/src/components/Catalog/CatalogTableView/CatalogDomainsCell.tsx +26 -0
  217. package/src/components/Catalog/CatalogTableView/CatalogEntityCell.tsx +77 -0
  218. package/src/components/Catalog/CatalogTableView/CatalogOwnersCell.tsx +26 -0
  219. package/src/components/Catalog/CatalogTableView/CatalogTableHeaderCell.tsx +120 -0
  220. package/src/components/Catalog/CatalogTableView/CatalogTableView.tsx +176 -0
  221. package/src/components/Catalog/CatalogTableView/CatalogTableViewRow.tsx +180 -0
  222. package/src/components/Catalog/CatalogTableView/CatalogTagsCell.tsx +28 -0
  223. package/src/components/Catalog/CatalogTableView/CatalogUserEntityCell.tsx +77 -0
  224. package/src/components/Catalog/CatalogTagsWithTooltip.tsx +83 -0
  225. package/src/components/Catalog/CatalogViewModeToggle.tsx +65 -0
  226. package/src/components/Catalog/variables.dark.ts +5 -0
  227. package/src/components/Catalog/variables.ts +351 -0
  228. package/src/components/CatalogClassic/CatalogClassicHighlight.tsx +1 -1
  229. package/src/components/Filter/Filter.tsx +10 -2
  230. package/src/components/Filter/FilterCheckboxes.tsx +8 -4
  231. package/src/components/Filter/FilterContent.tsx +21 -5
  232. package/src/components/Filter/FilterInput.tsx +16 -4
  233. package/src/components/Filter/FilterSelect.tsx +8 -4
  234. package/src/components/LoadMore/LoadMore.tsx +38 -0
  235. package/src/components/Markdown/Markdown.tsx +1 -1
  236. package/src/components/PageNavigation/NavigationButton.tsx +68 -0
  237. package/src/components/PageNavigation/NextButton.tsx +20 -43
  238. package/src/components/PageNavigation/PageNavigation.tsx +1 -1
  239. package/src/components/PageNavigation/PreviousButton.tsx +20 -43
  240. package/src/components/Search/SearchAiConversationInput.tsx +3 -0
  241. package/src/components/Select/Select.tsx +5 -3
  242. package/src/components/Sidebar/Sidebar.tsx +1 -1
  243. package/src/components/SkipContent/SkipContent.tsx +47 -0
  244. package/src/components/SkipContent/variables.ts +20 -0
  245. package/src/components/Tag/Tag.tsx +67 -1
  246. package/src/components/Tag/variables.ts +21 -0
  247. package/src/components/Tooltip/Tooltip.tsx +31 -22
  248. package/src/components/Tooltip/variables.ts +17 -0
  249. package/src/core/constants/catalog.ts +1 -0
  250. package/src/core/constants/common.ts +1 -0
  251. package/src/core/constants/index.ts +1 -0
  252. package/src/core/constants/search.ts +2 -0
  253. package/src/core/hooks/__mocks__/use-theme-hooks.ts +1 -0
  254. package/src/core/hooks/catalog/useCatalogEntities.ts +16 -0
  255. package/src/core/hooks/catalog/useCatalogTableHeaderCellActions.ts +38 -0
  256. package/src/core/hooks/catalog/useCatalogTableViewRow.ts +40 -0
  257. package/src/core/hooks/index.ts +2 -0
  258. package/src/core/hooks/use-user-teams.ts +8 -0
  259. package/src/core/styles/dark.ts +2 -0
  260. package/src/core/styles/global.ts +5 -0
  261. package/src/core/types/catalog.ts +143 -5
  262. package/src/core/types/filter.ts +1 -0
  263. package/src/core/types/hooks.ts +32 -5
  264. package/src/core/types/index.ts +1 -0
  265. package/src/core/types/l10n.ts +22 -1
  266. package/src/core/types/telemetry.ts +36 -0
  267. package/src/core/utils/load-and-navigate.ts +5 -4
  268. package/src/icons/AscSortIcon/AscSortIcon.tsx +29 -0
  269. package/src/icons/CardsIcon/CardsIcon.tsx +38 -0
  270. package/src/icons/CaretDownIcon/CaretDownIcon.tsx +26 -0
  271. package/src/icons/CaretUpIcon/CaretUpIcon.tsx +26 -0
  272. package/src/icons/DescSortIcon/DescSortIcon.tsx +29 -0
  273. package/src/icons/EntityTypeIcon/EntityTypeIcon.tsx +49 -0
  274. package/src/icons/GithubIcon/GithubIcon.tsx +35 -0
  275. package/src/icons/GraphIcon/GraphIcon.tsx +26 -0
  276. package/src/icons/PeopleIcon/PeopleIcon.tsx +46 -0
  277. package/src/icons/SlackIcon/SlackIcon.tsx +61 -0
  278. package/src/icons/SortIcon/SortIcon.tsx +29 -0
  279. package/src/icons/TableIcon/TableIcon.tsx +26 -0
  280. package/src/icons/TagsIcon/TagsIcon.tsx +41 -0
  281. package/src/index.ts +20 -0
  282. package/src/layouts/PageLayout.tsx +4 -1
  283. package/src/layouts/RootLayout.tsx +2 -0
  284. package/src/markdoc/components/Tabs/Tab.tsx +12 -1
  285. package/src/markdoc/components/Tabs/TabList.tsx +2 -1
  286. package/src/markdoc/components/Tabs/Tabs.tsx +8 -3
@@ -85,4 +85,5 @@ export const useThemeHooks = jest.fn(() => ({
85
85
  submitFeedback: jest.fn(),
86
86
  })),
87
87
  useLoadAndNavigate: jest.fn(),
88
+ usePageProps: jest.fn().mockReturnValue({}),
88
89
  }));
@@ -0,0 +1,16 @@
1
+ import type { UseCatalogEntitiesProps } from '@redocly/theme';
2
+
3
+ export function useCatalogEntities({ entitiesTypes, excludedEntities }: UseCatalogEntitiesProps) {
4
+ const initialTypesWithoutAll = entitiesTypes.filter((type) => type !== 'all');
5
+ const initialTypesFilter = entitiesTypes.length ? `type:${initialTypesWithoutAll.join(',')}` : '';
6
+ const initialExcludedEntitiesFilter = excludedEntities?.length
7
+ ? `-key:${excludedEntities.map((entity) => entity.key).join(',')}`
8
+ : '';
9
+ const initialFilter = initialTypesFilter
10
+ ? `${initialTypesFilter} AND ${initialExcludedEntitiesFilter}`
11
+ : initialExcludedEntitiesFilter;
12
+
13
+ return {
14
+ initialFilter,
15
+ };
16
+ }
@@ -0,0 +1,38 @@
1
+ import {
2
+ BaseEntity,
3
+ CatalogColumn,
4
+ } from '@redocly/theme/components/Catalog/CatalogTableView/CatalogTableView';
5
+
6
+ import { SortOption } from '../../types';
7
+
8
+ type CatalogTableHeaderCellActionsProps<T extends BaseEntity> = {
9
+ column: CatalogColumn<T>;
10
+ handleSortClick: (sortKey: string, direction: 'asc' | 'desc') => void;
11
+ setSortOption: (sortOption: SortOption | null) => void;
12
+ isColumnSorted: (sortKey: string, direction: 'asc' | 'desc') => boolean;
13
+ };
14
+
15
+ export function useCatalogTableHeaderCellActions<T extends BaseEntity>({
16
+ column,
17
+ handleSortClick,
18
+ setSortOption,
19
+ isColumnSorted,
20
+ }: CatalogTableHeaderCellActionsProps<T>) {
21
+ const sortKey = column.sortKey;
22
+ const isUpActive = sortKey ? isColumnSorted(sortKey, 'desc') : false;
23
+ const isDownActive = sortKey ? isColumnSorted(sortKey, 'asc') : false;
24
+
25
+ const handleCellClick = (): void => {
26
+ if (!column.sortable || !sortKey) return;
27
+
28
+ if (isDownActive) {
29
+ handleSortClick(sortKey, 'desc');
30
+ } else if (isUpActive) {
31
+ setSortOption(null);
32
+ } else {
33
+ handleSortClick(sortKey, 'asc');
34
+ }
35
+ };
36
+
37
+ return { handleCellClick, sortKey, isUpActive, isDownActive };
38
+ }
@@ -0,0 +1,40 @@
1
+ import { CatalogEntityConfig, EntitiesCatalogConfig } from '@redocly/config';
2
+
3
+ import { getPathPrefix } from '../../utils';
4
+
5
+ type CatalogTableViewRowProps = {
6
+ entityKey: string;
7
+ entityType: string;
8
+ catalogConfig: CatalogEntityConfig;
9
+ entitiesCatalogConfig?: EntitiesCatalogConfig;
10
+ };
11
+
12
+ export function useCatalogTableViewRow({
13
+ entityKey,
14
+ entityType,
15
+ catalogConfig,
16
+ entitiesCatalogConfig,
17
+ }: CatalogTableViewRowProps) {
18
+ const getCatalogSpecificConfigByEntityTypeIncluded = () => {
19
+ if (!entitiesCatalogConfig) {
20
+ return;
21
+ }
22
+
23
+ return Object.values(entitiesCatalogConfig.catalogs ?? {}).find((catalog) => {
24
+ return catalog.includes?.some((include) => include.type === entityType);
25
+ });
26
+ };
27
+
28
+ const getEntityDetailsLink = () => {
29
+ const pathPrefix = getPathPrefix();
30
+ const catalogSpecificConfig = getCatalogSpecificConfigByEntityTypeIncluded();
31
+
32
+ if (!catalogSpecificConfig || !entitiesCatalogConfig) {
33
+ return `${pathPrefix}/catalogs/${catalogConfig.slug}/entities/${entityKey}`;
34
+ }
35
+
36
+ return `${pathPrefix}/catalogs/${catalogSpecificConfig.slug}/entities/${entityKey}`;
37
+ };
38
+
39
+ return { getEntityDetailsLink };
40
+ }
@@ -36,5 +36,7 @@ export * from '@redocly/theme/core/hooks/code-walkthrough/use-renderable-files';
36
36
  export * from '@redocly/theme/core/hooks/use-element-size';
37
37
  export * from '@redocly/theme/core/hooks/use-time-ago';
38
38
  export * from '@redocly/theme/core/hooks/use-input-key-commands';
39
+ export * from '@redocly/theme/core/hooks/catalog/useCatalogEntities';
39
40
  export * from '@redocly/theme/core/hooks/use-active-page-version';
40
41
  export * from '@redocly/theme/core/hooks/use-page-versions';
42
+ export * from '@redocly/theme/core/hooks/use-user-teams';
@@ -0,0 +1,8 @@
1
+ import { useThemeHooks } from '@redocly/theme/core/hooks';
2
+
3
+ export function useUserTeams() {
4
+ const { useUserTeams } = useThemeHooks();
5
+ const userTeams = useUserTeams();
6
+
7
+ return userTeams;
8
+ }
@@ -10,6 +10,7 @@ import { tagDarkMode } from '@redocly/theme/components/Tag/variables.dark';
10
10
  import { statusCodeDarkMode } from '@redocly/theme/components/StatusCode/variables.dark';
11
11
  import { switcherDarkMode } from '@redocly/theme/components/Switch/variables.dark';
12
12
  import { cardsDarkMode } from '@redocly/theme/markdoc/components/Cards/variables.dark';
13
+ import { catalogDarkMode } from '@redocly/theme/components/Catalog/variables.dark';
13
14
 
14
15
 
15
16
  const replayDarkMode = css`
@@ -316,6 +317,7 @@ export const darkMode = css`
316
317
  ${replayDarkMode}
317
318
  ${switcherDarkMode}
318
319
  ${cardsDarkMode}
320
+ ${catalogDarkMode}
319
321
 
320
322
  /**
321
323
  * @tokens Dark Theme Scrollbar Config
@@ -8,6 +8,7 @@ import { sidebar } from '@redocly/theme/components/Sidebar/variables';
8
8
  import { breadcrumbs } from '@redocly/theme/components/Breadcrumbs/variables';
9
9
  import { tag } from '@redocly/theme/components/Tag/variables';
10
10
  import { toc } from '@redocly/theme/components/TableOfContent/variables';
11
+ import { catalog } from '@redocly/theme/components/Catalog/variables';
11
12
  import { filter } from '@redocly/theme/components/Filter/variables';
12
13
  import { catalogClassic } from '@redocly/theme/components/CatalogClassic/variables';
13
14
  import { apiReferencePanels, responsePanelColors } from '@redocly/theme/components/Panel/variables';
@@ -37,6 +38,7 @@ import { datePicker } from '@redocly/theme/components/DatePicker/variables'
37
38
  import { switcher } from '@redocly/theme/components/Switch/variables';
38
39
  import { cards } from '@redocly/theme/markdoc/components/Cards/variables';
39
40
  import { codeWalkthrough } from '@redocly/theme/markdoc/components/CodeWalkthrough/variables';
41
+ import { skipContent } from '@redocly/theme/components/SkipContent/variables';
40
42
 
41
43
  const themeColors = css`
42
44
  /* === Palette === */
@@ -367,6 +369,7 @@ const typography = css`
367
369
  --font-size-base: 14px; // Base font size of the entire system.
368
370
  --font-size-sm: 12px;
369
371
  --font-size-lg: 16px;
372
+ --font-size-md: 18px;
370
373
  --font-size-xl: 20px;
371
374
 
372
375
  /**
@@ -1211,6 +1214,7 @@ export const styles = css`
1211
1214
  ${breadcrumbs}
1212
1215
  ${button}
1213
1216
  ${cards}
1217
+ ${catalog}
1214
1218
  ${catalogClassic}
1215
1219
  ${code}
1216
1220
  ${codeWalkthrough}
@@ -1262,6 +1266,7 @@ export const styles = css`
1262
1266
  ${scorecard}
1263
1267
  ${datePicker}
1264
1268
  ${replay}
1269
+ ${skipContent}
1265
1270
 
1266
1271
  background-color: var(--bg-color);
1267
1272
  color: var(--text-color-primary);
@@ -1,5 +1,41 @@
1
+ import { InfiniteData, UseInfiniteQueryResult } from '@tanstack/react-query';
2
+ import { CatalogEntityConfig, LayoutVariant } from '@redocly/config';
3
+
1
4
  import type { CatalogFilterConfig } from '@redocly/theme/config';
2
5
 
6
+ export type SortOption = 'title' | '-title' | 'type' | '-type';
7
+
8
+ export type UseCatalogResponse = {
9
+ filters: ResolvedFilter[];
10
+ filterQuery: string;
11
+ searchQuery: string;
12
+ setSearchQuery: (query: string) => void;
13
+ sortOption: SortOption | null;
14
+ setSortOption: (option: SortOption | null) => void;
15
+ handleSortClick: (sortKey: string, direction: 'asc' | 'desc') => void;
16
+ isColumnSorted: (sortKey: string, direction: 'asc' | 'desc') => boolean;
17
+ viewMode: CatalogViewMode;
18
+ setViewMode: (mode: CatalogViewMode) => void;
19
+ entitiesCounter: number;
20
+ setEntitiesCounter: (counter: number) => void;
21
+ onChangeViewClick: () => void;
22
+ onChangeCollapseSidebarClick: () => void;
23
+ layout: LayoutVariant;
24
+ collapsedSidebar: boolean;
25
+ };
26
+
27
+ export type UseCatalogSortResponse = {
28
+ sortOption: SortOption | null;
29
+ setSortOption: (option: SortOption | null) => void;
30
+ handleSortClick: (sortKey: string, direction: 'asc' | 'desc') => void;
31
+ isColumnSorted: (sortKey: string, direction: 'asc' | 'desc') => boolean;
32
+ };
33
+
34
+ export type UseCatalogSearchResponse = {
35
+ searchQuery: string;
36
+ setSearchQuery: (query: string) => void;
37
+ };
38
+
3
39
  export type FilteredCatalog = {
4
40
  groups: { title: string; items: CatalogItem[] }[];
5
41
  filters: ResolvedFilter[];
@@ -12,10 +48,6 @@ export type ResolvedFilter = Omit<CatalogFilterConfig, 'options'> & {
12
48
  value: string;
13
49
  count: number;
14
50
  }[];
15
- filteredOptions: {
16
- value: string;
17
- count: number;
18
- }[];
19
51
  toggleOption: (option: string) => void;
20
52
  selectOption: (option: string) => void;
21
53
  parentUsed: boolean;
@@ -34,9 +66,115 @@ export type CatalogItem = {
34
66
  scorecardLevelIdx?: number;
35
67
  scorecardLevels?: Record<string, { uniqueErrors: number; uniqueWarnings: number }>;
36
68
  scoreCardSlug?: string;
37
- tags?: unknown[];
69
+ tags?: string[];
38
70
  versions?: CatalogItem[];
39
71
  version?: string;
40
72
  versionFolderId?: string;
41
73
  [k: string]: unknown;
42
74
  };
75
+
76
+ export type DefaultCatalogSlug =
77
+ | 'services'
78
+ | 'users'
79
+ | 'teams'
80
+ | 'domains'
81
+ | 'api-descriptions'
82
+ | 'all';
83
+
84
+ export type CatalogApiResults<T, L> = {
85
+ query: UseInfiniteQueryResult<InfiniteData<L, unknown>, Error>;
86
+ items: T[];
87
+ total: number;
88
+ };
89
+
90
+ export type CatalogApiParams = {
91
+ limit?: number;
92
+ filter?: string;
93
+ sort?: string;
94
+ search?: string;
95
+ };
96
+
97
+ export type UseCatalogEntitiesProps = {
98
+ entitiesTypes: string[];
99
+ excludedEntities?: CatalogEntityConfig['excludes'];
100
+ };
101
+
102
+ export type UseCatalogEntitiesResponse = {
103
+ setEntitiesCounter: (counter: number) => void;
104
+ };
105
+
106
+ export type EntityType = 'service' | 'domain' | 'team' | 'user' | 'api-description';
107
+
108
+ export type CatalogViewMode = 'cards' | 'table';
109
+
110
+ export type CatalogSwitcherItem = {
111
+ labelTranslationKey: string;
112
+ slug: string;
113
+ selected: boolean;
114
+ };
115
+
116
+ // TODO: remove this types after we make api-sdk package public and will be able import them from there
117
+ export type BffCatalogRelatedEntity = {
118
+ readonly id: string;
119
+ type: string;
120
+ key: string;
121
+ title: string;
122
+ summary?: string | null;
123
+ readonly source: 'api' | 'file';
124
+ sourceFile?: string | null;
125
+ metadata?: Record<string, any>;
126
+ readonly createdAt: string | null;
127
+ readonly updatedAt: string | null;
128
+ };
129
+
130
+ export type BffCatalogEntity = {
131
+ readonly id: string;
132
+ readonly organizationId: string;
133
+ readonly projectId: string;
134
+ key: string;
135
+ type: string;
136
+ title: string;
137
+ readonly source: 'api' | 'file';
138
+ domains?: Array<BffCatalogRelatedEntity>;
139
+ owners?: Array<BffCatalogRelatedEntity>;
140
+ summary?: string;
141
+ tags?: Array<string>;
142
+ metadata?: Record<string, any>;
143
+ git?: Array<string>;
144
+ contact?: {
145
+ slack?: {
146
+ channels?: Array<{
147
+ name: string;
148
+ }>;
149
+ };
150
+ };
151
+ links?: Array<{
152
+ label: string;
153
+ url: string;
154
+ }>;
155
+ sourceFile?: string;
156
+ readonly object: 'catalogEntityView';
157
+ readonly createdAt: string;
158
+ readonly updatedAt: string;
159
+ };
160
+
161
+ export type BffCatalogEntityList = {
162
+ object: 'list';
163
+ page: Page;
164
+ items: Array<BffCatalogEntity>;
165
+ };
166
+
167
+ export type BffCatalogRelatedEntityList = {
168
+ object: 'list';
169
+ page: Page;
170
+ items: Array<BffCatalogRelatedEntity>;
171
+ };
172
+
173
+ export type Page = {
174
+ endCursor: string | null;
175
+ startCursor: string | null;
176
+ hasNextPage: boolean;
177
+ hasPrevPage: boolean;
178
+ limit: number;
179
+ total: number;
180
+ };
@@ -4,6 +4,7 @@ import type { RedoclyConfig } from '@redocly/config';
4
4
  export type FilterProps = {
5
5
  filter: ResolvedFilter & { selectedOptions: any };
6
6
  filterValuesCasing?: NonNullable<RedoclyConfig['catalog']>[string]['filterValuesCasing'];
7
+ showCounter?: boolean;
7
8
  };
8
9
 
9
10
  export type FilterTypes = NonNullable<FilterProps['filter']['type']>;
@@ -1,13 +1,16 @@
1
- import { AsyncApiRealm } from '@redocly/realm-asyncapi-sdk';
2
-
3
- import type { PageProps, ResolvedNavItemWithLink, Version } from '@redocly/config';
1
+ import type {
2
+ CatalogEntityConfig,
3
+ PageProps,
4
+ ResolvedNavItemWithLink,
5
+ Version,
6
+ } from '@redocly/config';
4
7
  import type { ShikiTransformer } from '@shikijs/types';
5
8
  import type { Callback, TFunction as TFunc } from 'i18next';
6
9
  import type { To, Location, NavigateFunction } from 'react-router-dom';
7
10
  import type { CatalogConfig, ProductUiConfig } from '@redocly/theme/config';
8
11
  import type {
9
12
  UserMenuData,
10
- FilteredCatalog,
13
+ UseCatalogResponse,
11
14
  ItemState,
12
15
  SearchItemData,
13
16
  SubmitFeedbackParams,
@@ -18,8 +21,21 @@ import type {
18
21
  SearchFilterItem,
19
22
  SearchFacetQuery,
20
23
  AiSearchConversationItem,
24
+ CatalogApiResults,
25
+ CatalogApiParams,
26
+ FilteredCatalog,
27
+ UseCatalogSortResponse,
28
+ UseCatalogSearchResponse,
29
+ EventType,
30
+ SendEventParams,
21
31
  } from '@redocly/theme/core/types';
22
32
 
33
+ import {
34
+ BffCatalogEntity,
35
+ BffCatalogEntityList,
36
+ BffCatalogRelatedEntity,
37
+ BffCatalogRelatedEntityList,
38
+ } from '@redocly/theme/core/types';
23
39
  import { AiSearchError } from '@redocly/theme/core/constants';
24
40
 
25
41
  export type ThemeHooks = {
@@ -118,9 +134,20 @@ export type ThemeHooks = {
118
134
  nextPage?: ResolvedNavItemWithLink;
119
135
  }
120
136
  | undefined;
137
+ useCatalog: (config?: CatalogEntityConfig, entitiesCounterInitial?: number) => UseCatalogResponse;
138
+ useCatalogSort: () => UseCatalogSortResponse;
139
+ useCatalogSearch: () => UseCatalogSearchResponse;
140
+ useFetchCatalogEntities: (
141
+ params: CatalogApiParams,
142
+ initialData?: BffCatalogEntityList,
143
+ ) => CatalogApiResults<BffCatalogEntity, BffCatalogEntityList>;
144
+ useFetchCatalogEntitiesRelations: (
145
+ params: CatalogApiParams & { entityKey: string },
146
+ initialData?: BffCatalogRelatedEntityList,
147
+ ) => CatalogApiResults<BffCatalogRelatedEntity, BffCatalogRelatedEntityList>;
121
148
  useCatalogClassic: (config: CatalogConfig) => FilteredCatalog;
122
149
  useTelemetry: () => {
123
- send(data: AsyncApiRealm.Messages): void;
150
+ send<TEventType extends EventType>(event: SendEventParams<TEventType>): void;
124
151
  };
125
152
  useUserTeams: () => string[];
126
153
  usePageProps: <T extends Record<string, unknown>>() => PageProps & T;
@@ -15,3 +15,4 @@ export * from '@redocly/theme/core/types/common';
15
15
  export * from '@redocly/theme/core/types/open-api-server';
16
16
  export * from '@redocly/theme/core/types/marker';
17
17
  export * from '@redocly/theme/core/types/code-walkthrough';
18
+ export * from '@redocly/theme/core/types/telemetry';
@@ -118,6 +118,26 @@ export type TranslationKey =
118
118
  | 'catalog.filters.select.addFilter'
119
119
  | 'catalog.filters.select.all'
120
120
  | 'catalog.filters.done'
121
+ | 'catalog.catalogs.all.title'
122
+ | 'catalog.catalogs.all.description'
123
+ | 'catalog.catalogs.all.switcherLabel'
124
+ | 'catalog.catalogs.service.title'
125
+ | 'catalog.catalogs.service.description'
126
+ | 'catalog.catalogs.service.switcherLabel'
127
+ | 'catalog.catalogs.user.title'
128
+ | 'catalog.catalogs.user.description'
129
+ | 'catalog.catalogs.user.switcherLabel'
130
+ | 'catalog.catalogs.team.title'
131
+ | 'catalog.catalogs.team.description'
132
+ | 'catalog.catalogs.team.switcherLabel'
133
+ | 'catalog.catalogs.domain.title'
134
+ | 'catalog.catalogs.domain.description'
135
+ | 'catalog.catalogs.domain.switcherLabel'
136
+ | 'catalog.catalogs.apiDescription.title'
137
+ | 'catalog.catalogs.apiDescription.description'
138
+ | 'catalog.catalogs.apiDescription.switcherLabel'
139
+ | 'catalog.entity.metadata.title'
140
+ | 'catalog.entity.properties.apiDescription.title'
121
141
  | 'sidebar.menu.backLabel'
122
142
  | 'sidebar.menu.backToLabel'
123
143
  | 'sidebar.actions.show'
@@ -287,7 +307,8 @@ export type TranslationKey =
287
307
  | 'time.past.year'
288
308
  | 'time.past.years'
289
309
  | 'page.internalServerError.title'
290
- | 'page.internalServerError.description';
310
+ | 'page.internalServerError.description'
311
+ | 'page.skipToContent.label';
291
312
 
292
313
  export type Locale = { code: string; name: string };
293
314
 
@@ -0,0 +1,36 @@
1
+ import { AsyncApiRealm } from '@redocly/realm-asyncapi-sdk';
2
+
3
+ type ExtractEventType<T> = T extends {
4
+ span?: { attributes?: { 'cloudevents.event_type': infer EventType } };
5
+ }
6
+ ? EventType
7
+ : never;
8
+
9
+ export type EventType = ExtractEventType<AsyncApiRealm.Messages>;
10
+
11
+ type GetMessageForEventType<TEventType extends EventType> = Extract<
12
+ AsyncApiRealm.Messages,
13
+ { span?: { attributes?: { 'cloudevents.event_type': TEventType } } }
14
+ >;
15
+
16
+ type ExtractEventDataForType<TEventType extends EventType> =
17
+ GetMessageForEventType<TEventType> extends {
18
+ span?: { attributes?: infer Attrs };
19
+ }
20
+ ? {
21
+ [K in keyof Attrs as K extends `cloudevents.event_data.${string}` ? K : never]: Attrs[K];
22
+ }
23
+ : never;
24
+
25
+ export type ConvertEventDataToPayload<T> = {
26
+ [K in keyof T as K extends `cloudevents.event_data.${infer FieldName}` ? FieldName : never]: T[K];
27
+ };
28
+
29
+ export type EventPayload<TEventType extends EventType> = ConvertEventDataToPayload<
30
+ ExtractEventDataForType<TEventType>
31
+ >;
32
+
33
+ export interface SendEventParams<TEventType extends EventType> {
34
+ type: TEventType;
35
+ payload?: EventPayload<TEventType>;
36
+ }
@@ -32,10 +32,11 @@ export async function loadAndNavigate({
32
32
  if (result && lastNavigatedPath === to) {
33
33
  if (pathname !== window.location.pathname || search !== window.location.search) {
34
34
  // origin is used to prevent infinite loop when navigating from post message (from wysiwyg)
35
- navigate(
36
- { pathname, search, hash },
37
- { ...options, state: { origin }, unstable_flushSync: true },
38
- );
35
+ navigate({ pathname, search, hash }, {
36
+ ...options,
37
+ state: { origin },
38
+ unstable_flushSync: true,
39
+ } as NavigateOptions & { unstable_flushSync: boolean });
39
40
  }
40
41
  // @ts-ignore
41
42
  if (result.props?.disableAutoScroll) return;
@@ -0,0 +1,29 @@
1
+ import React from 'react';
2
+ import styled from 'styled-components';
3
+
4
+ import type { IconProps } from '@redocly/theme/icons/types';
5
+
6
+ import { getCssColorVariable } from '@redocly/theme/core/utils';
7
+
8
+ const Icon = (props: IconProps) => (
9
+ <svg viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg" {...props}>
10
+ <path
11
+ d="M9 11L9.707 10.293L11.5 12.086V2H12.5V12.086L14.293 10.293L15 11L12 14L9 11Z"
12
+ fill="#22242B"
13
+ />
14
+ <path d="M8 9H1V10H8V9Z" fill="#22242B" />
15
+ <path d="M8 6H3V7H8V6Z" fill="#22242B" />
16
+ <path d="M8 3H5V4H8V3Z" fill="#22242B" />
17
+ </svg>
18
+ );
19
+
20
+ export const AscSortIcon = styled(Icon).attrs(() => ({
21
+ 'data-component-name': 'icons/AscSortIcon/AscSortIcon',
22
+ }))<IconProps>`
23
+ path {
24
+ fill: ${({ color }) => getCssColorVariable(color)};
25
+ }
26
+
27
+ height: ${({ size }) => size || '16px'};
28
+ width: ${({ size }) => size || '16px'};
29
+ `;
@@ -0,0 +1,38 @@
1
+ import React from 'react';
2
+ import styled from 'styled-components';
3
+
4
+ import type { IconProps } from '@redocly/theme/icons/types';
5
+
6
+ import { getCssColorVariable } from '@redocly/theme/core/utils';
7
+
8
+ const Icon = (props: IconProps) => (
9
+ <svg viewBox="0 0 12 12" fill="none" xmlns="http://www.w3.org/2000/svg" {...props}>
10
+ <path
11
+ d="M4 0H1C0.734784 0 0.48043 0.105357 0.292893 0.292893C0.105357 0.48043 0 0.734784 0 1V4C0 4.26522 0.105357 4.51957 0.292893 4.70711C0.48043 4.89464 0.734784 5 1 5H4C4.26522 5 4.51957 4.89464 4.70711 4.70711C4.89464 4.51957 5 4.26522 5 4V1C5 0.734784 4.89464 0.48043 4.70711 0.292893C4.51957 0.105357 4.26522 0 4 0ZM4 4H1V1H4V4Z"
12
+ fill="#22242B"
13
+ />
14
+ <path
15
+ d="M11 0H8C7.73478 0 7.48043 0.105357 7.29289 0.292893C7.10536 0.48043 7 0.734784 7 1V4C7 4.26522 7.10536 4.51957 7.29289 4.70711C7.48043 4.89464 7.73478 5 8 5H11C11.2652 5 11.5196 4.89464 11.7071 4.70711C11.8946 4.51957 12 4.26522 12 4V1C12 0.734784 11.8946 0.48043 11.7071 0.292893C11.5196 0.105357 11.2652 0 11 0ZM11 4H8V1H11V4Z"
16
+ fill="#22242B"
17
+ />
18
+ <path
19
+ d="M4 7H1C0.734784 7 0.48043 7.10536 0.292893 7.29289C0.105357 7.48043 0 7.73478 0 8V11C0 11.2652 0.105357 11.5196 0.292893 11.7071C0.48043 11.8946 0.734784 12 1 12H4C4.26522 12 4.51957 11.8946 4.70711 11.7071C4.89464 11.5196 5 11.2652 5 11V8C5 7.73478 4.89464 7.48043 4.70711 7.29289C4.51957 7.10536 4.26522 7 4 7ZM4 11H1V8H4V11Z"
20
+ fill="#22242B"
21
+ />
22
+ <path
23
+ d="M11 7H8C7.73478 7 7.48043 7.10536 7.29289 7.29289C7.10536 7.48043 7 7.73478 7 8V11C7 11.2652 7.10536 11.5196 7.29289 11.7071C7.48043 11.8946 7.73478 12 8 12H11C11.2652 12 11.5196 11.8946 11.7071 11.7071C11.8946 11.5196 12 11.2652 12 11V8C12 7.73478 11.8946 7.48043 11.7071 7.29289C11.5196 7.10536 11.2652 7 11 7ZM11 11H8V8H11V11Z"
24
+ fill="#22242B"
25
+ />
26
+ </svg>
27
+ );
28
+
29
+ export const CardsIcon = styled(Icon).attrs(() => ({
30
+ 'data-component-name': 'icons/CardsIcon/CardsIcon',
31
+ }))<IconProps>`
32
+ path {
33
+ fill: ${({ color }) => getCssColorVariable(color)};
34
+ }
35
+
36
+ height: ${({ size }) => size || '16px'};
37
+ width: ${({ size }) => size || '16px'};
38
+ `;
@@ -0,0 +1,26 @@
1
+ import React from 'react';
2
+ import styled from 'styled-components';
3
+
4
+ import type { IconProps } from '@redocly/theme/icons/types';
5
+
6
+ import { getCssColorVariable } from '@redocly/theme/core/utils';
7
+
8
+ const Icon = (props: IconProps) => (
9
+ <svg viewBox="0 0 8 4" fill="none" xmlns="http://www.w3.org/2000/svg" {...props}>
10
+ <path
11
+ d="M6.77566 0C7.04293 0 7.17678 0.323143 6.98779 0.512132L4.21205 3.28787C4.0949 3.40503 3.90495 3.40503 3.78779 3.28787L1.01205 0.512132C0.823064 0.323142 0.956914 0 1.22419 0H6.77566Z"
12
+ fill="#6E6F7A"
13
+ />
14
+ </svg>
15
+ );
16
+
17
+ export const CaretDownIcon = styled(Icon).attrs(() => ({
18
+ 'data-component-name': 'icons/CaretDownIcon/CaretDownIcon',
19
+ }))<IconProps>`
20
+ path {
21
+ fill: ${({ color }) => getCssColorVariable(color)};
22
+ }
23
+
24
+ height: ${({ size }) => size || '4px'};
25
+ width: ${({ size }) => size || '8px'};
26
+ `;
@@ -0,0 +1,26 @@
1
+ import React from 'react';
2
+ import styled from 'styled-components';
3
+
4
+ import type { IconProps } from '@redocly/theme/icons/types';
5
+
6
+ import { getCssColorVariable } from '@redocly/theme/core/utils';
7
+
8
+ const Icon = (props: IconProps) => (
9
+ <svg viewBox="0 0 8 4" fill="none" xmlns="http://www.w3.org/2000/svg" {...props}>
10
+ <path
11
+ d="M1.22419 3.99573C0.956914 3.99573 0.823064 3.67259 1.01205 3.4836L3.78779 0.707863C3.90495 0.590706 4.0949 0.590706 4.21205 0.707863L6.98779 3.4836C7.17678 3.67259 7.04293 3.99573 6.77566 3.99573L1.22419 3.99573Z"
12
+ fill="#6E6F7A"
13
+ />
14
+ </svg>
15
+ );
16
+
17
+ export const CaretUpIcon = styled(Icon).attrs(() => ({
18
+ 'data-component-name': 'icons/CaretUpIcon/CaretUpIcon',
19
+ }))<IconProps>`
20
+ path {
21
+ fill: ${({ color }) => getCssColorVariable(color)};
22
+ }
23
+
24
+ height: ${({ size }) => size || '4px'};
25
+ width: ${({ size }) => size || '8px'};
26
+ `;
@@ -0,0 +1,29 @@
1
+ import React from 'react';
2
+ import styled from 'styled-components';
3
+
4
+ import type { IconProps } from '@redocly/theme/icons/types';
5
+
6
+ import { getCssColorVariable } from '@redocly/theme/core/utils';
7
+
8
+ const Icon = (props: IconProps) => (
9
+ <svg viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg" {...props}>
10
+ <path
11
+ d="M9 11L9.707 10.293L11.5 12.086V2H12.5V12.086L14.293 10.293L15 11L12 14L9 11Z"
12
+ fill="#22242B"
13
+ />
14
+ <path d="M8 3H1V4H8V3Z" fill="#22242B" />
15
+ <path d="M8 6H3V7H8V6Z" fill="#22242B" />
16
+ <path d="M8 9H5V10H8V9Z" fill="#22242B" />
17
+ </svg>
18
+ );
19
+
20
+ export const DescSortIcon = styled(Icon).attrs(() => ({
21
+ 'data-component-name': 'icons/DescSortIcon/DescSortIcon',
22
+ }))<IconProps>`
23
+ path {
24
+ fill: ${({ color }) => getCssColorVariable(color)};
25
+ }
26
+
27
+ height: ${({ size }) => size || '16px'};
28
+ width: ${({ size }) => size || '16px'};
29
+ `;