@redocly/theme 0.59.0-next.1 → 0.59.0-next.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 (275) hide show
  1. package/LICENSE +7 -1
  2. package/lib/components/Accordion/Accordion.js +17 -7
  3. package/lib/components/Accordion/AccordionBody.js +17 -7
  4. package/lib/components/Admonition/Admonition.js +17 -7
  5. package/lib/components/Badge/Badge.js +17 -7
  6. package/lib/components/Breadcrumbs/Breadcrumb.js +17 -7
  7. package/lib/components/Breadcrumbs/BreadcrumbDropdown.js +17 -7
  8. package/lib/components/Button/Button.js +17 -7
  9. package/lib/components/Buttons/AIAssistantButton.js +23 -9
  10. package/lib/components/Buttons/ConnectMCPButton.d.ts +8 -0
  11. package/lib/components/Buttons/ConnectMCPButton.js +145 -0
  12. package/lib/components/Buttons/CopyButton.js +17 -7
  13. package/lib/components/Buttons/variables.d.ts +1 -0
  14. package/lib/components/Buttons/variables.js +42 -2
  15. package/lib/components/Catalog/Catalog.d.ts +6 -0
  16. package/lib/components/Catalog/Catalog.js +7 -6
  17. package/lib/components/Catalog/CatalogEntities.js +17 -7
  18. package/lib/components/Catalog/CatalogEntity/CatalogEntityGraph/CatalogEntityRelationsGraph.js +17 -7
  19. package/lib/components/Catalog/CatalogEntity/CatalogEntityGraph/CatalogEntityRelationsGraph.lazy.js +17 -7
  20. package/lib/components/Catalog/CatalogEntity/CatalogEntityInfoBar.js +1 -0
  21. package/lib/components/Catalog/CatalogEntity/CatalogEntityMetadata.js +17 -7
  22. package/lib/components/Catalog/CatalogEntity/CatalogEntityRelations/CatalogEntityApiDescriptionRelations.js +1 -1
  23. package/lib/components/Catalog/CatalogEntity/CatalogEntityRelations/CatalogEntityRelations.js +17 -7
  24. package/lib/components/Catalog/CatalogEntity/CatalogEntityRelations/CatalogEntityTeamRelations.js +1 -1
  25. package/lib/components/Catalog/CatalogEntity/CatalogEntitySchema.js +17 -7
  26. package/lib/components/Catalog/CatalogEntityIcon.js +2 -1
  27. package/lib/components/Catalog/CatalogFilter/CatalogFilter.js +4 -0
  28. package/lib/components/Catalog/CatalogFilter/CatalogFilterCheckboxes.js +17 -7
  29. package/lib/components/Catalog/CatalogFilter/CatalogFilterContent.js +17 -7
  30. package/lib/components/Catalog/CatalogFilter/CatalogFilterDateRange.js +17 -7
  31. package/lib/components/Catalog/CatalogFilter/CatalogFilterSelect.js +17 -7
  32. package/lib/components/Catalog/CatalogSortButton.js +17 -7
  33. package/lib/components/Catalog/CatalogTableView/CatalogTableHeaderCell.js +17 -7
  34. package/lib/components/Catalog/CatalogViewModeToggle.js +17 -7
  35. package/lib/components/Catalog/variables.js +1 -1
  36. package/lib/components/CatalogClassic/CatalogClassicActions.js +17 -7
  37. package/lib/components/CatalogClassic/CatalogClassicCard.js +17 -7
  38. package/lib/components/CatalogClassic/CatalogClassicHighlight.js +17 -7
  39. package/lib/components/CatalogClassic/CatalogClassicVirtualizedGroups.js +17 -7
  40. package/lib/components/CodeBlock/CodeBlock.js +17 -7
  41. package/lib/components/CodeBlock/CodeBlockContainer.js +17 -7
  42. package/lib/components/CodeBlock/CodeBlockTabs.js +17 -7
  43. package/lib/components/Dropdown/Dropdown.d.ts +16 -2
  44. package/lib/components/Dropdown/Dropdown.js +22 -12
  45. package/lib/components/Dropdown/DropdownMenuItem.js +17 -7
  46. package/lib/components/Feedback/Comment.js +17 -7
  47. package/lib/components/Feedback/Feedback.js +17 -7
  48. package/lib/components/Feedback/Mood.js +17 -7
  49. package/lib/components/Feedback/Rating.js +17 -7
  50. package/lib/components/Feedback/Reasons.js +17 -7
  51. package/lib/components/Feedback/Scale.js +17 -7
  52. package/lib/components/Feedback/Sentiment.js +17 -7
  53. package/lib/components/Feedback/Stars.js +17 -7
  54. package/lib/components/Filter/FilterContent.js +17 -7
  55. package/lib/components/Filter/FilterInput.js +17 -7
  56. package/lib/components/Image/Image.js +17 -7
  57. package/lib/components/JsonViewer/JsonViewer.js +17 -7
  58. package/lib/components/JsonViewer/helpers.js +17 -7
  59. package/lib/components/LastUpdated/LastUpdated.js +17 -7
  60. package/lib/components/Link/Link.js +17 -7
  61. package/lib/components/Markdown/Markdown.js +17 -7
  62. package/lib/components/Marker/Marker.js +17 -7
  63. package/lib/components/Menu/MenuContainer.js +17 -7
  64. package/lib/components/Menu/MenuItem.js +18 -8
  65. package/lib/components/Menu/MenuMobile.js +17 -7
  66. package/lib/components/Navbar/NavbarItem.js +3 -3
  67. package/lib/components/PageActions/PageActions.js +21 -8
  68. package/lib/components/PageActions/variables.js +2 -0
  69. package/lib/components/PageNavigation/NextButton.js +17 -7
  70. package/lib/components/Panel/Panel.js +17 -7
  71. package/lib/components/Panel/PanelBody.js +17 -7
  72. package/lib/components/Search/FilterFields/SearchFilterFieldSelect.js +17 -7
  73. package/lib/components/Search/FilterFields/SearchFilterFieldTags.js +1 -2
  74. package/lib/components/Search/SearchAiActionButtons.d.ts +10 -0
  75. package/lib/components/Search/SearchAiActionButtons.js +43 -0
  76. package/lib/components/Search/SearchAiConversationInput.d.ts +3 -1
  77. package/lib/components/Search/SearchAiConversationInput.js +56 -14
  78. package/lib/components/Search/SearchAiDialog.d.ts +3 -6
  79. package/lib/components/Search/SearchAiDialog.js +37 -16
  80. package/lib/components/Search/SearchAiMessage.d.ts +9 -5
  81. package/lib/components/Search/SearchAiMessage.js +146 -22
  82. package/lib/components/Search/SearchAiNegativeFeedbackForm.d.ts +8 -0
  83. package/lib/components/Search/SearchAiNegativeFeedbackForm.js +169 -0
  84. package/lib/components/Search/SearchDialog.js +53 -12
  85. package/lib/components/Search/SearchFilter.js +17 -7
  86. package/lib/components/Search/SearchGroups.js +19 -9
  87. package/lib/components/Search/SearchHighlight.js +17 -7
  88. package/lib/components/Search/SearchItem.js +17 -7
  89. package/lib/components/Search/SearchRecent.js +17 -7
  90. package/lib/components/Search/SearchShortcut.js +17 -7
  91. package/lib/components/Search/SearchSuggestedPages.js +17 -7
  92. package/lib/components/Search/SearchTrigger.js +17 -7
  93. package/lib/components/Search/variables.js +36 -64
  94. package/lib/components/Segmented/Segmented.d.ts +1 -8
  95. package/lib/components/Segmented/Segmented.js +20 -8
  96. package/lib/components/Select/Select.js +17 -7
  97. package/lib/components/Select/SelectInput.js +18 -8
  98. package/lib/components/Sidebar/Sidebar.js +17 -7
  99. package/lib/components/SidebarActions/styled.js +17 -7
  100. package/lib/components/SkipContent/SkipContent.js +17 -7
  101. package/lib/components/Switch/Switch.js +17 -7
  102. package/lib/components/TableOfContent/TableOfContent.js +17 -7
  103. package/lib/components/Tag/Tag.d.ts +2 -1
  104. package/lib/components/Tag/Tag.js +67 -18
  105. package/lib/components/Tag/variables.dark.js +135 -36
  106. package/lib/components/Tag/variables.js +78 -61
  107. package/lib/components/Tooltip/Tooltip.js +17 -7
  108. package/lib/components/VersionPicker/VersionPicker.js +17 -7
  109. package/lib/core/constants/index.d.ts +1 -0
  110. package/lib/core/constants/index.js +1 -0
  111. package/lib/core/constants/mcp.d.ts +1 -0
  112. package/lib/core/constants/mcp.js +5 -0
  113. package/lib/core/constants/search.d.ts +5 -4
  114. package/lib/core/constants/search.js +4 -5
  115. package/lib/core/contexts/CodeSnippetContext.js +17 -7
  116. package/lib/core/hooks/index.d.ts +3 -0
  117. package/lib/core/hooks/index.js +3 -0
  118. package/lib/core/hooks/menu/use-nested-menu.js +1 -1
  119. package/lib/core/hooks/search/use-feedback-tooltip.d.ts +6 -0
  120. package/lib/core/hooks/search/use-feedback-tooltip.js +26 -0
  121. package/lib/core/hooks/use-connect-mcp-button.d.ts +13 -0
  122. package/lib/core/hooks/use-connect-mcp-button.js +50 -0
  123. package/lib/core/hooks/use-mcp-config.d.ts +9 -0
  124. package/lib/core/hooks/use-mcp-config.js +27 -0
  125. package/lib/core/hooks/use-page-actions.d.ts +1 -1
  126. package/lib/core/hooks/use-page-actions.js +98 -95
  127. package/lib/core/hooks/use-product-picker.js +2 -1
  128. package/lib/core/hooks/use-tabs.d.ts +3 -2
  129. package/lib/core/hooks/use-tabs.js +115 -57
  130. package/lib/core/hooks/use-telemetry-fallback.d.ts +10 -8
  131. package/lib/core/hooks/use-telemetry-fallback.js +10 -8
  132. package/lib/core/openapi/index.d.ts +1 -0
  133. package/lib/core/styles/dark.js +4 -0
  134. package/lib/core/styles/global.js +5 -0
  135. package/lib/core/templates/Markdown.js +17 -7
  136. package/lib/core/types/hooks.d.ts +6 -3
  137. package/lib/core/types/index.d.ts +1 -0
  138. package/lib/core/types/index.js +1 -0
  139. package/lib/core/types/l10n.d.ts +1 -1
  140. package/lib/core/types/mcp.d.ts +6 -0
  141. package/lib/core/types/mcp.js +3 -0
  142. package/lib/core/types/search.d.ts +11 -4
  143. package/lib/core/types/search.js +6 -0
  144. package/lib/core/types/segmented.d.ts +12 -0
  145. package/lib/core/types/segmented.js +3 -0
  146. package/lib/core/utils/download-code-walkthrough.js +17 -7
  147. package/lib/core/utils/frontmatter-translate.d.ts +6 -0
  148. package/lib/core/utils/frontmatter-translate.js +14 -0
  149. package/lib/core/utils/get-file-icon.js +17 -7
  150. package/lib/core/utils/index.d.ts +2 -0
  151. package/lib/core/utils/index.js +2 -0
  152. package/lib/core/utils/mcp.d.ts +2 -0
  153. package/lib/core/utils/mcp.js +31 -0
  154. package/lib/icons/AiStarsGradientIcon/AiStarsGradientIcon.js +44 -4
  155. package/lib/icons/AiStarsIcon/AiStarsIcon.js +11 -2
  156. package/lib/icons/ConnectIcon/ConnectIcon.d.ts +9 -0
  157. package/lib/icons/ConnectIcon/ConnectIcon.js +17 -0
  158. package/lib/icons/CubeIcon/CubeIcon.d.ts +9 -0
  159. package/lib/icons/CubeIcon/CubeIcon.js +17 -0
  160. package/lib/icons/GenericIcon/GenericIcon.js +17 -7
  161. package/lib/icons/HashtagIcon/HashtagIcon.d.ts +9 -0
  162. package/lib/icons/HashtagIcon/HashtagIcon.js +22 -0
  163. package/lib/icons/RedoclyIcon/RedoclyIcon.js +4 -7
  164. package/lib/icons/Spinner/Spinner.js +17 -7
  165. package/lib/icons/ThumbDownFilledIcon/ThumbDownFilledIcon.d.ts +9 -0
  166. package/lib/icons/ThumbDownFilledIcon/ThumbDownFilledIcon.js +34 -0
  167. package/lib/icons/ThumbUpFilledIcon/ThumbUpFilledIcon.d.ts +9 -0
  168. package/lib/icons/ThumbUpFilledIcon/ThumbUpFilledIcon.js +34 -0
  169. package/lib/icons/VSCodeIcon/VSCodeIcon.d.ts +9 -0
  170. package/lib/icons/VSCodeIcon/VSCodeIcon.js +17 -0
  171. package/lib/index.d.ts +1 -0
  172. package/lib/index.js +18 -7
  173. package/lib/layouts/OIDCForbidden.js +17 -7
  174. package/lib/layouts/ThreePanelLayout.js +17 -7
  175. package/lib/markdoc/components/Cards/Card.js +1 -28
  176. package/lib/markdoc/components/Cards/Cards.js +17 -7
  177. package/lib/markdoc/components/CodeGroup/CodeGroup.js +17 -7
  178. package/lib/markdoc/components/CodeWalkthrough/CodeContainer.js +17 -7
  179. package/lib/markdoc/components/CodeWalkthrough/CodePanel.js +17 -7
  180. package/lib/markdoc/components/CodeWalkthrough/CodePanelHeader.js +17 -7
  181. package/lib/markdoc/components/CodeWalkthrough/CodePanelPreview.js +17 -7
  182. package/lib/markdoc/components/CodeWalkthrough/CodePanelToolbar.js +17 -7
  183. package/lib/markdoc/components/CodeWalkthrough/CodeStep.js +17 -7
  184. package/lib/markdoc/components/CodeWalkthrough/CodeToggle.js +17 -7
  185. package/lib/markdoc/components/CodeWalkthrough/CodeWalkthrough.js +17 -7
  186. package/lib/markdoc/components/CodeWalkthrough/Input.js +17 -7
  187. package/lib/markdoc/components/ConnectMCP/ConnectMCP.d.ts +8 -0
  188. package/lib/markdoc/components/ConnectMCP/ConnectMCP.js +19 -0
  189. package/lib/markdoc/components/Heading/Heading.js +17 -7
  190. package/lib/markdoc/components/HtmlBlock/HtmlBlock.js +17 -7
  191. package/lib/markdoc/components/InlineSvg/InlineSvg.js +17 -7
  192. package/lib/markdoc/components/MarkdocExample/MarkdocExample.js +17 -7
  193. package/lib/markdoc/components/Tabs/TabList.d.ts +3 -1
  194. package/lib/markdoc/components/Tabs/TabList.js +214 -54
  195. package/lib/markdoc/components/Tabs/Tabs.d.ts +2 -1
  196. package/lib/markdoc/components/Tabs/Tabs.js +74 -19
  197. package/lib/markdoc/components/default.d.ts +1 -0
  198. package/lib/markdoc/components/default.js +1 -0
  199. package/lib/markdoc/default.d.ts +110 -1
  200. package/lib/markdoc/default.js +19 -7
  201. package/lib/markdoc/tags/card.js +0 -1
  202. package/lib/markdoc/tags/connect-mcp.d.ts +2 -0
  203. package/lib/markdoc/tags/connect-mcp.js +27 -0
  204. package/package.json +8 -8
  205. package/src/components/Buttons/AIAssistantButton.tsx +6 -2
  206. package/src/components/Buttons/ConnectMCPButton.tsx +180 -0
  207. package/src/components/Buttons/variables.ts +42 -1
  208. package/src/components/Catalog/Catalog.tsx +15 -4
  209. package/src/components/Catalog/CatalogEntity/CatalogEntityInfoBar.tsx +1 -0
  210. package/src/components/Catalog/CatalogEntity/CatalogEntityRelations/CatalogEntityApiDescriptionRelations.tsx +1 -1
  211. package/src/components/Catalog/CatalogEntity/CatalogEntityRelations/CatalogEntityTeamRelations.tsx +1 -1
  212. package/src/components/Catalog/CatalogEntityIcon.tsx +2 -1
  213. package/src/components/Catalog/CatalogFilter/CatalogFilter.tsx +5 -0
  214. package/src/components/Catalog/variables.ts +1 -1
  215. package/src/components/Dropdown/Dropdown.tsx +84 -79
  216. package/src/components/Menu/MenuItem.tsx +1 -0
  217. package/src/components/Navbar/NavbarItem.tsx +6 -5
  218. package/src/components/PageActions/PageActions.tsx +5 -1
  219. package/src/components/PageActions/variables.ts +2 -0
  220. package/src/components/Search/FilterFields/SearchFilterFieldTags.tsx +3 -3
  221. package/src/components/Search/SearchAiActionButtons.tsx +76 -0
  222. package/src/components/Search/SearchAiConversationInput.tsx +61 -18
  223. package/src/components/Search/SearchAiDialog.tsx +52 -23
  224. package/src/components/Search/SearchAiMessage.tsx +172 -43
  225. package/src/components/Search/SearchAiNegativeFeedbackForm.tsx +210 -0
  226. package/src/components/Search/SearchDialog.tsx +49 -13
  227. package/src/components/Search/SearchGroups.tsx +2 -0
  228. package/src/components/Search/variables.ts +36 -64
  229. package/src/components/Segmented/Segmented.tsx +15 -20
  230. package/src/components/Select/SelectInput.tsx +1 -0
  231. package/src/components/Tag/Tag.tsx +36 -20
  232. package/src/components/Tag/variables.dark.ts +135 -36
  233. package/src/components/Tag/variables.ts +78 -61
  234. package/src/core/constants/index.ts +1 -0
  235. package/src/core/constants/mcp.ts +1 -0
  236. package/src/core/constants/search.ts +8 -4
  237. package/src/core/hooks/index.ts +3 -0
  238. package/src/core/hooks/menu/use-nested-menu.ts +2 -2
  239. package/src/core/hooks/search/use-feedback-tooltip.ts +32 -0
  240. package/src/core/hooks/use-connect-mcp-button.ts +79 -0
  241. package/src/core/hooks/use-mcp-config.ts +43 -0
  242. package/src/core/hooks/use-page-actions.ts +148 -126
  243. package/src/core/hooks/use-product-picker.ts +2 -1
  244. package/src/core/hooks/use-tabs.ts +168 -86
  245. package/src/core/hooks/use-telemetry-fallback.ts +10 -8
  246. package/src/core/openapi/index.ts +1 -0
  247. package/src/core/styles/dark.ts +4 -0
  248. package/src/core/styles/global.ts +6 -1
  249. package/src/core/types/hooks.ts +6 -1
  250. package/src/core/types/index.ts +1 -0
  251. package/src/core/types/l10n.ts +14 -0
  252. package/src/core/types/mcp.ts +8 -0
  253. package/src/core/types/search.ts +13 -4
  254. package/src/core/types/segmented.ts +14 -0
  255. package/src/core/utils/frontmatter-translate.ts +9 -0
  256. package/src/core/utils/index.ts +2 -0
  257. package/src/core/utils/mcp.ts +34 -0
  258. package/src/icons/AiStarsGradientIcon/AiStarsGradientIcon.tsx +13 -4
  259. package/src/icons/AiStarsIcon/AiStarsIcon.tsx +11 -2
  260. package/src/icons/ConnectIcon/ConnectIcon.tsx +27 -0
  261. package/src/icons/CubeIcon/CubeIcon.tsx +27 -0
  262. package/src/icons/HashtagIcon/HashtagIcon.tsx +23 -0
  263. package/src/icons/RedoclyIcon/RedoclyIcon.tsx +4 -22
  264. package/src/icons/ThumbDownFilledIcon/ThumbDownFilledIcon.tsx +38 -0
  265. package/src/icons/ThumbUpFilledIcon/ThumbUpFilledIcon.tsx +35 -0
  266. package/src/icons/VSCodeIcon/VSCodeIcon.tsx +29 -0
  267. package/src/index.ts +1 -0
  268. package/src/markdoc/components/Cards/Card.tsx +1 -28
  269. package/src/markdoc/components/ConnectMCP/ConnectMCP.tsx +28 -0
  270. package/src/markdoc/components/Tabs/TabList.tsx +312 -105
  271. package/src/markdoc/components/Tabs/Tabs.tsx +136 -11
  272. package/src/markdoc/components/default.ts +1 -0
  273. package/src/markdoc/default.ts +2 -0
  274. package/src/markdoc/tags/card.ts +0 -1
  275. package/src/markdoc/tags/connect-mcp.ts +25 -0
@@ -6,15 +6,20 @@ const react_1 = require("react");
6
6
  const react_router_dom_1 = require("react-router-dom");
7
7
  const MORE_BUTTON_WIDTH = 80;
8
8
  const TABS_GAP = 8;
9
- function useTabs({ activeTab, onTabChange, totalTabs, containerRef }) {
9
+ function useTabs({ activeTab, onTabChange, totalTabs, containerRef, }) {
10
10
  const [tabs, setTabs] = (0, react_1.useState)({
11
11
  visible: Array.from({ length: totalTabs }, (_, i) => i),
12
12
  overflow: [],
13
13
  });
14
+ const [isReady, setIsReady] = (0, react_1.useState)(false);
15
+ const isFirstCalculation = (0, react_1.useRef)(true);
14
16
  const tabRefs = (0, react_1.useRef)([]);
15
17
  const tabWidthsRef = (0, react_1.useRef)([]);
16
18
  const tabLabelsRef = (0, react_1.useRef)([]);
17
- const allTabsHidden = (0, react_1.useMemo)(() => tabs.visible.length === 0, [tabs.visible]);
19
+ const activeTabRef = (0, react_1.useRef)(activeTab);
20
+ const calculateVisibleTabsRef = (0, react_1.useRef)(null);
21
+ // Synchronously update ref before any callbacks or effects run
22
+ activeTabRef.current = activeTab;
18
23
  const setTabRef = (0, react_1.useCallback)((element, index) => {
19
24
  tabRefs.current[index] = element;
20
25
  const width = element === null || element === void 0 ? void 0 : element.offsetWidth;
@@ -25,18 +30,25 @@ function useTabs({ activeTab, onTabChange, totalTabs, containerRef }) {
25
30
  if (label) {
26
31
  tabLabelsRef.current[index] = label;
27
32
  }
28
- }, []);
29
- const focusTab = (index) => {
33
+ // Trigger calculation once all tabs are registered
34
+ if (isFirstCalculation.current &&
35
+ tabWidthsRef.current.length >= totalTabs &&
36
+ tabLabelsRef.current.length >= totalTabs &&
37
+ calculateVisibleTabsRef.current) {
38
+ requestAnimationFrame(calculateVisibleTabsRef.current);
39
+ }
40
+ }, [totalTabs]);
41
+ const focusTab = (0, react_1.useCallback)((index) => {
30
42
  const currentElement = tabRefs.current[index];
31
43
  currentElement === null || currentElement === void 0 ? void 0 : currentElement.focus();
32
- };
44
+ }, []);
33
45
  const onTabSelect = (0, react_1.useCallback)((index) => {
34
46
  var _a;
35
47
  focusTab(index);
36
48
  const label = (_a = tabRefs.current[index]) === null || _a === void 0 ? void 0 : _a.getAttribute('data-label');
37
49
  if (label)
38
50
  onTabChange(label);
39
- }, [onTabChange]);
51
+ }, [onTabChange, focusTab]);
40
52
  const handleKeyboard = (0, react_1.useCallback)((event, index) => {
41
53
  let newIndex = index;
42
54
  if (event.key === 'ArrowRight') {
@@ -59,109 +71,155 @@ function useTabs({ activeTab, onTabChange, totalTabs, containerRef }) {
59
71
  onTabSelect(newIndex);
60
72
  }, [totalTabs, onTabSelect]);
61
73
  const replaceLastVisibleTabWithClickedOverflowTab = (0, react_1.useCallback)((clickedIndex) => {
62
- const { visible: visibleTabs, overflow: overflowTabs } = tabs;
63
- // Indexes of visible tabs should be sorted(asc), to replace the last visible tab with the clicked tab
64
- const newVisibleTabs = [...visibleTabs].sort((a, b) => a - b);
65
- const newOverflowTabs = [...overflowTabs];
66
- const clickedIdxInOverflow = newOverflowTabs.indexOf(clickedIndex);
67
- if (clickedIdxInOverflow !== -1) {
68
- const lastVisible = newVisibleTabs[newVisibleTabs.length - 1];
69
- newOverflowTabs.splice(clickedIdxInOverflow, 1);
70
- newOverflowTabs.unshift(lastVisible);
71
- newVisibleTabs.splice(newVisibleTabs.length - 1, 1);
72
- newVisibleTabs.unshift(clickedIndex);
73
- }
74
- setTabs({
75
- visible: newVisibleTabs,
76
- overflow: newOverflowTabs,
74
+ setTabs((prevTabs) => {
75
+ const { visible: visibleTabs, overflow: overflowTabs } = prevTabs;
76
+ const sortedVisible = [...visibleTabs].sort((a, b) => a - b);
77
+ const lastVisible = sortedVisible[sortedVisible.length - 1];
78
+ return {
79
+ visible: visibleTabs.map((idx) => (idx === lastVisible ? clickedIndex : idx)),
80
+ overflow: overflowTabs.map((idx) => (idx === clickedIndex ? lastVisible : idx)),
81
+ };
77
82
  });
78
- }, [tabs]);
83
+ }, []);
79
84
  const onTabClick = (0, react_1.useCallback)((labelOrIndex) => {
80
85
  const clickedIndex = typeof labelOrIndex === 'string'
81
86
  ? tabRefs.current.findIndex((ref) => (ref === null || ref === void 0 ? void 0 : ref.getAttribute('data-label')) === labelOrIndex)
82
87
  : labelOrIndex;
83
88
  if (clickedIndex === -1)
84
89
  return;
85
- const hasOverflowTabs = tabs.overflow.length > 0;
86
- if (hasOverflowTabs && !allTabsHidden && tabs.overflow.includes(clickedIndex)) {
87
- replaceLastVisibleTabWithClickedOverflowTab(clickedIndex);
88
- }
89
90
  const label = tabLabelsRef.current[clickedIndex];
90
- if (label) {
91
- onTabChange(label);
92
- focusTab(clickedIndex);
91
+ if (!label)
92
+ return;
93
+ // If this is an overflow tab, replace it with a visible one
94
+ if (tabs.overflow.includes(clickedIndex)) {
95
+ replaceLastVisibleTabWithClickedOverflowTab(clickedIndex);
93
96
  }
94
- }, [allTabsHidden, tabs.overflow, onTabChange, replaceLastVisibleTabWithClickedOverflowTab]);
97
+ onTabChange(label);
98
+ focusTab(clickedIndex);
99
+ }, [tabs.overflow, onTabChange, replaceLastVisibleTabWithClickedOverflowTab, focusTab]);
95
100
  const calculateVisibleTabs = (0, react_1.useCallback)(() => {
96
101
  const container = containerRef === null || containerRef === void 0 ? void 0 : containerRef.current;
97
102
  if (!container)
98
103
  return;
99
104
  const containerWidth = container.offsetWidth;
100
105
  const tabWidths = tabWidthsRef.current;
101
- const activeTabIndex = tabRefs.current.findIndex((ref) => (ref === null || ref === void 0 ? void 0 : ref.getAttribute('data-label')) === activeTab);
102
- // Active tab should always be visible, so we include it at the beginning of the array
106
+ const tabLabels = tabLabelsRef.current;
107
+ // Wait until all tabs are registered before calculating
108
+ if (tabWidths.length < totalTabs || tabLabels.length < totalTabs) {
109
+ return;
110
+ }
111
+ // Check if container has proper width (not zero)
112
+ if (containerWidth === 0) {
113
+ return;
114
+ }
115
+ // Find active tab index by label in tabLabelsRef, not by DOM element
116
+ // because tab might not be rendered if it's in overflow
117
+ const activeTabIndex = tabLabels.findIndex((label) => label === activeTabRef.current);
103
118
  let tabsWidth = activeTabIndex !== -1 ? tabWidths[activeTabIndex] : 0;
104
- const visible = activeTabIndex !== -1 ? [activeTabIndex] : [];
105
- const overflow = [];
119
+ const visibleTabs = activeTabIndex !== -1 ? [activeTabIndex] : [];
120
+ const overflowTabs = [];
106
121
  for (let i = 0; i < tabWidths.length; i++) {
107
- // Skip active tab, it was added initially
108
- if (i === activeTabIndex) {
122
+ if (i === activeTabIndex)
109
123
  continue;
110
- }
111
124
  const tabWidthWithGap = tabWidths[i] + TABS_GAP;
112
125
  const projectedWidth = tabsWidth + tabWidthWithGap;
113
126
  if (projectedWidth <= containerWidth) {
114
- visible.push(i);
127
+ visibleTabs.push(i);
115
128
  tabsWidth += tabWidthWithGap;
116
129
  }
117
130
  else {
118
- overflow.push(i);
131
+ overflowTabs.push(i);
119
132
  }
120
133
  }
121
- if (overflow.length > 0) {
134
+ if (overflowTabs.length > 0) {
122
135
  tabsWidth += MORE_BUTTON_WIDTH;
123
- // Remove tabs starting from the end of the array until the width of the visible tabs is less than the container width
124
- while (tabsWidth > containerWidth && visible.length) {
125
- const removed = visible.pop();
126
- if (removed !== undefined) {
127
- overflow.unshift(removed);
136
+ while (tabsWidth > containerWidth && visibleTabs.length > 1) {
137
+ const removed = visibleTabs.pop();
138
+ // Never remove the active tab - it should always stay visible or be the last one
139
+ if (removed !== undefined && removed !== activeTabIndex) {
140
+ overflowTabs.unshift(removed);
128
141
  tabsWidth -= tabWidths[removed];
129
142
  }
143
+ else if (removed === activeTabIndex) {
144
+ // Put it back if we accidentally removed the active tab
145
+ visibleTabs.push(removed);
146
+ break;
147
+ }
148
+ }
149
+ // If even with only the active tab visible, it doesn't fit with More button,
150
+ // move all tabs to overflow (show only dropdown)
151
+ if (tabsWidth > containerWidth && visibleTabs.length === 1) {
152
+ overflowTabs.unshift(...visibleTabs);
153
+ visibleTabs.length = 0;
130
154
  }
131
155
  }
132
156
  setTabs({
133
- visible,
134
- overflow,
157
+ visible: visibleTabs,
158
+ overflow: overflowTabs,
135
159
  });
136
- }, [containerRef, activeTab]);
160
+ // Set ready state on first calculation
161
+ if (isFirstCalculation.current) {
162
+ isFirstCalculation.current = false;
163
+ setIsReady(true);
164
+ }
165
+ }, [containerRef, totalTabs]);
166
+ // Store calculateVisibleTabs in ref for use in setTabRef
167
+ calculateVisibleTabsRef.current = calculateVisibleTabs;
168
+ // Reset isFirstCalculation when totalTabs changes (new page/tabs)
137
169
  (0, react_1.useEffect)(() => {
138
- if (!(containerRef === null || containerRef === void 0 ? void 0 : containerRef.current))
170
+ isFirstCalculation.current = true;
171
+ setIsReady(false);
172
+ // Clear refs so we wait for new tabs to register
173
+ tabWidthsRef.current = [];
174
+ tabLabelsRef.current = [];
175
+ }, [totalTabs]);
176
+ // Call calculateVisibleTabs on first render and resize
177
+ (0, react_1.useEffect)(() => {
178
+ const container = containerRef === null || containerRef === void 0 ? void 0 : containerRef.current;
179
+ if (!container)
139
180
  return;
140
- let resizeTimeout = requestAnimationFrame(calculateVisibleTabs);
181
+ let resizeTimeout = null;
182
+ // Use ResizeObserver to wait until container has proper size
183
+ const resizeObserver = new ResizeObserver(() => {
184
+ if (resizeTimeout)
185
+ cancelAnimationFrame(resizeTimeout);
186
+ resizeTimeout = requestAnimationFrame(calculateVisibleTabs);
187
+ });
188
+ resizeObserver.observe(container);
141
189
  const handleResize = () => {
142
- if (resizeTimeout) {
190
+ if (resizeTimeout)
143
191
  cancelAnimationFrame(resizeTimeout);
144
- }
145
192
  resizeTimeout = requestAnimationFrame(calculateVisibleTabs);
146
193
  };
147
194
  window.addEventListener('resize', handleResize);
148
195
  return () => {
196
+ resizeObserver.disconnect();
149
197
  window.removeEventListener('resize', handleResize);
150
- cancelAnimationFrame(resizeTimeout);
198
+ if (resizeTimeout)
199
+ cancelAnimationFrame(resizeTimeout);
151
200
  };
152
201
  }, [containerRef, totalTabs, calculateVisibleTabs]);
202
+ // Recalculate when activeTab changes to ensure it's visible
203
+ (0, react_1.useEffect)(() => {
204
+ if (!(containerRef === null || containerRef === void 0 ? void 0 : containerRef.current) || isFirstCalculation.current)
205
+ return;
206
+ requestAnimationFrame(calculateVisibleTabs);
207
+ }, [activeTab, containerRef, calculateVisibleTabs]);
153
208
  return {
154
209
  setTabRef,
155
210
  onTabClick,
156
211
  handleKeyboard,
157
212
  visibleTabs: tabs.visible,
158
213
  overflowTabs: tabs.overflow,
159
- allTabsHidden,
214
+ isReady,
160
215
  };
161
216
  }
162
217
  const useActiveTab = ({ initialTab, tabsId }) => {
163
218
  const [searchParams, setSearchParams] = (0, react_router_dom_1.useSearchParams)();
164
- const [activeTab, setActiveTab] = (0, react_1.useState)(getInitialTab({ initialTab, searchParams, tabsId }));
219
+ const initialTabValue = (0, react_1.useMemo)(() => getInitialTab({ initialTab, searchParams, tabsId }),
220
+ // eslint-disable-next-line react-hooks/exhaustive-deps
221
+ []);
222
+ const [activeTab, setActiveTab] = (0, react_1.useState)(initialTabValue);
165
223
  const prevActiveTabRef = (0, react_1.useRef)(activeTab);
166
224
  (0, react_1.useEffect)(() => {
167
225
  const hasActiveTabChanged = prevActiveTabRef.current !== activeTab;
@@ -174,10 +232,10 @@ const useActiveTab = ({ initialTab, tabsId }) => {
174
232
  return searchParams;
175
233
  });
176
234
  }, [activeTab, setSearchParams, tabsId]);
177
- return {
235
+ return (0, react_1.useMemo)(() => ({
178
236
  activeTab,
179
237
  setActiveTab,
180
- };
238
+ }), [activeTab]);
181
239
  };
182
240
  exports.useActiveTab = useActiveTab;
183
241
  const getInitialTab = ({ initialTab, searchParams, tabsId }) => {
@@ -36,20 +36,22 @@ export declare const useTelemetryFallback: () => {
36
36
  sendLanguagePickerLocaleChangedMessage: () => void;
37
37
  sendSearchOpenedMessage: () => void;
38
38
  sendSearchQueryMessage: () => void;
39
+ sendSearchAiOpenedMessage: () => void;
39
40
  sendSearchAIQueryMessage: () => void;
41
+ sendSearchAIFeedbackMessage: () => void;
40
42
  sendFeedbackMessage: () => void;
41
43
  sendSearchResultClickedMessage: () => void;
42
44
  sendRedirectMessage: () => void;
43
45
  sendOpenapiDocsMessage: () => void;
44
46
  sendCopyCodeSnippetClickedMessage: () => void;
45
- sendOpenapiDocsViewedMessage: () => void;
46
- sendOpenapiDocsPerformanceMetricsMessage: () => void;
47
- sendOpenapiDocsDownloadDefinitionClickedMessage: () => void;
48
- sendOpenapiDocsSelectLanguageClickedMessage: () => void;
49
- sendOpenapiDocsExpandCollapseAllClickedMessage: () => void;
50
- sendOpenapiDocsSwitchServersClickedMessage: () => void;
51
- sendOpenapiDocsExamplesSwitcherClickedMessage: () => void;
52
- sendOpenapiDocsTryItOpenedMessage: () => void;
47
+ sendViewedMessage: () => void;
48
+ sendPerformanceMetricsMessage: () => void;
49
+ sendDownloadDefinitionClickedMessage: () => void;
50
+ sendSelectLanguageClickedMessage: () => void;
51
+ sendExpandCollapseAllClickedMessage: () => void;
52
+ sendSwitchServersClickedMessage: () => void;
53
+ sendExamplesSwitcherClickedMessage: () => void;
54
+ sendTryItOpenedMessage: () => void;
53
55
  sendAsyncapiDocsViewedMessage: () => void;
54
56
  sendAsyncapiDocsPerformanceMetricsMessage: () => void;
55
57
  sendAsyncapiDocsSwitchMessageClickedMessage: () => void;
@@ -40,20 +40,22 @@ const useTelemetryFallback = () => ({
40
40
  sendLanguagePickerLocaleChangedMessage: () => { },
41
41
  sendSearchOpenedMessage: () => { },
42
42
  sendSearchQueryMessage: () => { },
43
+ sendSearchAiOpenedMessage: () => { },
43
44
  sendSearchAIQueryMessage: () => { },
45
+ sendSearchAIFeedbackMessage: () => { },
44
46
  sendFeedbackMessage: () => { },
45
47
  sendSearchResultClickedMessage: () => { },
46
48
  sendRedirectMessage: () => { },
47
49
  sendOpenapiDocsMessage: () => { },
48
50
  sendCopyCodeSnippetClickedMessage: () => { },
49
- sendOpenapiDocsViewedMessage: () => { },
50
- sendOpenapiDocsPerformanceMetricsMessage: () => { },
51
- sendOpenapiDocsDownloadDefinitionClickedMessage: () => { },
52
- sendOpenapiDocsSelectLanguageClickedMessage: () => { },
53
- sendOpenapiDocsExpandCollapseAllClickedMessage: () => { },
54
- sendOpenapiDocsSwitchServersClickedMessage: () => { },
55
- sendOpenapiDocsExamplesSwitcherClickedMessage: () => { },
56
- sendOpenapiDocsTryItOpenedMessage: () => { },
51
+ sendViewedMessage: () => { },
52
+ sendPerformanceMetricsMessage: () => { },
53
+ sendDownloadDefinitionClickedMessage: () => { },
54
+ sendSelectLanguageClickedMessage: () => { },
55
+ sendExpandCollapseAllClickedMessage: () => { },
56
+ sendSwitchServersClickedMessage: () => { },
57
+ sendExamplesSwitcherClickedMessage: () => { },
58
+ sendTryItOpenedMessage: () => { },
57
59
  sendAsyncapiDocsViewedMessage: () => { },
58
60
  sendAsyncapiDocsPerformanceMetricsMessage: () => { },
59
61
  sendAsyncapiDocsSwitchMessageClickedMessage: () => { },
@@ -2,6 +2,7 @@ export type { UserClaims } from '../types/user-claims';
2
2
  export type { OperationParameter, ParameterHighlight } from '../types/search';
3
3
  export type { TFunction, TOptions } from '../types/l10n';
4
4
  export type { SelectOption, SelectProps } from '../types/select';
5
+ export type { SegmentedOption, SegmentedProps } from '../types/segmented';
5
6
  export { IS_BROWSER } from '../utils/dom';
6
7
  export { addLeadingSlash, removeLeadingSlash, getPathPrefix, combineUrls, addTrailingSlash, withPathPrefix, } from '../utils/urls';
7
8
  export { capitalize } from '../utils/string';
@@ -37,6 +37,10 @@ const replayDarkMode = (0, styled_components_1.css) `
37
37
  --replay-server-variable-bg-color-hover: rgba(31, 10, 144, 0.4); // @presenter Color
38
38
  --replay-path-parameter-bg-color-hover: rgba(5, 88, 99, 0.4); // @presenter Color
39
39
 
40
+ --replay-runtime-expression-color: rgba(147, 166, 249, 1); // @presenter Color
41
+ --replay-runtime-expression-bg-color: rgba(147, 166, 249, 0.16); // @presenter Color
42
+ --replay-operators-color: rgba(168, 143, 88, 1); // @presenter Color
43
+
40
44
  // @tokens End
41
45
  `;
42
46
  exports.darkMode = (0, styled_components_1.css) `
@@ -1203,6 +1203,10 @@ const replay = (0, styled_components_1.css) `
1203
1203
  --replay-server-variable-bg-color-hover: rgba(119, 45, 240, 0.16); // @presenter Color
1204
1204
  --replay-path-parameter-bg-color-hover: rgba(4, 117, 161, 0.16); // @presenter Color
1205
1205
 
1206
+ --replay-runtime-expression-color: rgba(54, 90, 249, 1); // @presenter Color
1207
+ --replay-runtime-expression-bg-color: rgba(54, 90, 249, 0.08); // @presenter Color
1208
+ --replay-operators-color: rgba(193, 142, 31, 1); // @presenter Color
1209
+
1206
1210
  // @tokens End
1207
1211
  `;
1208
1212
  exports.styles = (0, styled_components_1.css) `
@@ -1216,6 +1220,7 @@ exports.styles = (0, styled_components_1.css) `
1216
1220
  ${variables_5.breadcrumbs}
1217
1221
  ${variables_19.button}
1218
1222
  ${variables_20.aiAssistantButton}
1223
+ ${variables_20.connectMCPButton}
1219
1224
  ${variables_38.cards}
1220
1225
  ${variables_8.catalog}
1221
1226
  ${variables_10.catalogClassic}
@@ -15,13 +15,23 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (
15
15
  }) : function(o, v) {
16
16
  o["default"] = v;
17
17
  });
18
- var __importStar = (this && this.__importStar) || function (mod) {
19
- if (mod && mod.__esModule) return mod;
20
- var result = {};
21
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
- __setModuleDefault(result, mod);
23
- return result;
24
- };
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
25
35
  Object.defineProperty(exports, "__esModule", { value: true });
26
36
  exports.default = default_1;
27
37
  const React = __importStar(require("react"));
@@ -60,7 +60,7 @@ export type ThemeHooks = {
60
60
  breadcrumbs: BreadcrumbItem[];
61
61
  currentItemSiblings?: BreadcrumbItem[];
62
62
  };
63
- useSearch: (product?: string, autoSearchDisabled?: boolean) => {
63
+ useSearch: (product?: string, autoSearchDisabled?: boolean, searchSessionId?: string) => {
64
64
  query: string;
65
65
  setQuery: React.Dispatch<React.SetStateAction<string>>;
66
66
  filter: SearchFilterItem[];
@@ -78,7 +78,7 @@ export type ThemeHooks = {
78
78
  };
79
79
  useAiSearch: (options?: {
80
80
  filter?: SearchFilterItem[];
81
- }) => {
81
+ }, searchSessionId?: string) => {
82
82
  askQuestion: (question: string, history?: AiSearchConversationItem[]) => void;
83
83
  isGeneratingResponse: boolean;
84
84
  question: string;
@@ -112,7 +112,10 @@ export type ThemeHooks = {
112
112
  prevPage?: ResolvedNavItemWithLink;
113
113
  nextPage?: ResolvedNavItemWithLink;
114
114
  } | undefined;
115
- useCatalog: (config?: CatalogEntityConfig, entitiesCounterInitial?: number, initialViewMode?: CatalogViewMode) => UseCatalogResponse;
115
+ useCatalog: (config?: CatalogEntityConfig, serverFilters?: Record<string, {
116
+ value: string;
117
+ count: number;
118
+ }[]>, entitiesCounterInitial?: number, initialViewMode?: CatalogViewMode) => UseCatalogResponse;
116
119
  useCatalogSort: () => UseCatalogSortResponse;
117
120
  useCatalogSearch: () => UseCatalogSearchResponse;
118
121
  useFetchCatalogEntities: (params: CatalogApiParams, initialData?: BffCatalogEntityList) => CatalogApiResults<BffCatalogEntity, BffCatalogEntityList>;
@@ -1,6 +1,7 @@
1
1
  export * from './breadcrumb';
2
2
  export * from './catalog';
3
3
  export * from './l10n';
4
+ export * from './mcp';
4
5
  export * from './feedback';
5
6
  export * from './hooks';
6
7
  export * from './markdown';
@@ -17,6 +17,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
17
17
  __exportStar(require("./breadcrumb"), exports);
18
18
  __exportStar(require("./catalog"), exports);
19
19
  __exportStar(require("./l10n"), exports);
20
+ __exportStar(require("./mcp"), exports);
20
21
  __exportStar(require("./feedback"), exports);
21
22
  __exportStar(require("./hooks"), exports);
22
23
  __exportStar(require("./markdown"), exports);
@@ -1,5 +1,5 @@
1
1
  import type { TOptions } from 'i18next';
2
- export type TranslationKey = 'dev.newApp' | 'dev.newApp.text' | 'dev.sidebar.header' | 'dev.sidebar.footer.text' | 'dev.create.app.dialog.appName.placeholder' | 'dev.create.app.dialog.appName.error' | 'dev.create.app.dialog.selectAPIs' | 'dev.create.app.dialog.description' | 'dev.create.app.dialog.description.placeholder' | 'dev.create.app.dialog.create' | 'dev.create.app.dialog.cancel' | 'dev.main.tab.appKeys' | 'dev.main.tab.logs' | 'dev.app.description.title' | 'dev.edit.description.dialog.title' | 'dev.edit.description.dialog.save' | 'dev.edit.description.dialog.cancel' | 'dev.edit.apis.dialog.selectedAPIs' | 'dev.app.key.create' | 'dev.create.key.dialog.title' | 'dev.create.key.dialog.create' | 'dev.create.key.dialog.cancel' | 'dev.app.edit' | 'dev.app.delete' | 'dev.edit.app.dialog.title' | 'dev.edit.app.dialog.save' | 'dev.edit.app.dialog.cancel' | 'dev.delete.app.dialog.title' | 'dev.delete.app.dialog.confirmation' | 'dev.delete.app.dialog.delete' | 'dev.delete.app.dialog.cancel' | 'dev.app.key.roll' | 'dev.roll.key.dialog.title' | 'dev.roll.key.dialog.apiKey' | 'dev.roll.key.dialog.expires' | 'dev.roll.key.dialog.confirmation' | 'dev.roll.key.dialog.cancel' | 'dev.roll.key.dialog.roll' | 'dev.update.key.dialog.title' | 'dev.update.key.dialog.update' | 'dev.update.key.dialog.cancel' | 'dev.app.key.api.name' | 'dev.app.key.api.status' | 'dev.app.key.api.edit' | 'dev.edit.apis.dialog.title' | 'dev.edit.apis.dialog.apiKey' | 'dev.edit.apis.dialog.save' | 'dev.edit.apis.dialog.cancel' | 'dev.select.placeholder' | 'dev.app.overview.status.pending' | 'dev.app.overview.status.approved' | 'dev.app.overview.status.revoked' | 'dev.app.overview.status' | 'dev.app.overview.non-production' | 'dev.app.overview.production' | 'dev.app.overview.clientId' | 'dev.app.overview.apiKey' | 'dev.app.key.revoke' | 'dev.revoke.key.dialog.title' | 'dev.revoke.key.dialog.apiKey' | 'dev.revoke.key.dialog.expires' | 'dev.revoke.key.dialog.confirmation' | 'dev.revoke.key.dialog.revoke' | 'dev.revoke.key.dialog.cancel' | 'dev.app.overview.expires' | 'dev.app.overview.created' | 'dev.app.overview.visibilityToggle.hide' | 'dev.app.overview.visibilityToggle.show' | 'search.loading' | 'search.noResults.title' | 'search.keys.navigate' | 'search.keys.select' | 'search.keys.exit' | 'search.label' | 'search.cancel' | 'search.recent' | 'search.navbar.label' | 'search.suggested' | 'search.showMore' | 'search.filter.title' | 'search.filter.reset' | 'search.filter.field.reset' | 'search.ai.welcomeText' | 'search.ai.newConversation' | 'search.ai.backToSearch' | 'search.ai.placeholder' | 'search.ai.generatingResponse' | 'search.ai.followUpQuestion' | 'search.ai.suggestionsTitle' | 'search.ai.thinkingText' | 'search.ai.resourcesFound' | 'search.ai.resourcesFound.basedOn' | 'search.ai.resourcesFound.resources' | 'search.ai.button' | 'search.ai.label' | 'search.ai.disclaimer' | 'search.ai.error.description' | 'search.ai.error.description.forbidden' | 'search.ai.error.description.unauthorized' | 'search.ai.error.header' | 'search.ai.error.header.forbidden' | 'search.ai.error.header.unauthorized' | 'aiAssistant.trigger' | 'toc.header' | 'footer.copyrightText' | 'page.homeButton' | 'page.forbidden.title' | 'page.notFound.title' | 'page.notFound.description' | 'page.lastUpdated.timeago' | 'page.lastUpdated.on' | 'catalog.filters.placeholder' | 'catalog.filters.title' | 'catalog.filters.add' | 'catalog.filters.clearAll' | 'catalog.filters.select.addFilter' | 'catalog.filters.select.all' | 'catalog.filters.done' | 'catalog.catalogs.all.title' | 'catalog.catalogs.all.description' | 'catalog.catalogs.all.switcherLabel' | 'catalog.catalogs.service.title' | 'catalog.catalogs.service.description' | 'catalog.catalogs.service.switcherLabel' | 'catalog.catalogs.user.title' | 'catalog.catalogs.user.description' | 'catalog.catalogs.user.switcherLabel' | 'catalog.catalogs.team.title' | 'catalog.catalogs.team.description' | 'catalog.catalogs.team.switcherLabel' | 'catalog.catalogs.domain.title' | 'catalog.catalogs.domain.description' | 'catalog.catalogs.domain.switcherLabel' | 'catalog.catalogs.apiDescription.title' | 'catalog.catalogs.apiDescription.description' | 'catalog.catalogs.apiDescription.switcherLabel' | 'catalog.catalogs.dataSchema.title' | 'catalog.catalogs.dataSchema.description' | 'catalog.catalogs.dataSchema.switcherLabel' | 'catalog.catalogs.apiOperation.title' | 'catalog.catalogs.apiOperation.description' | 'catalog.catalogs.apiOperation.switcherLabel' | 'catalog.entity.metadata.title' | 'catalog.entity.schema.title' | 'catalog.entity.properties.apiDescription.title' | 'sidebar.menu.backLabel' | 'sidebar.menu.backToLabel' | 'sidebar.actions.show' | 'sidebar.actions.hide' | 'sidebar.actions.changeToSingleColumn' | 'sidebar.actions.changeToTwoColumns' | 'sidebar.actions.singleColumn' | 'sidebar.actions.twoColumns' | 'versionPicker.label' | 'versionPicker.unversioned' | 'codeSnippet.copy.buttonText' | 'codeSnippet.copy.tooltipText' | 'codeSnippet.copy.toasterText' | 'markdown.editPage.text' | 'feedback.settings.comment.submitText' | 'feedback.settings.comment.label' | 'feedback.settings.comment.send' | 'feedback.settings.comment.cancel' | 'feedback.settings.comment.satisfiedLabel' | 'feedback.settings.comment.neutralLabel' | 'feedback.settings.comment.dissatisfiedLabel' | 'feedback.settings.submitText' | 'feedback.settings.label' | 'feedback.settings.reasons.label' | 'feedback.submit' | 'feedback.cancel' | 'feedback.settings.comment.likeLabel' | 'feedback.settings.comment.dislikeLabel' | 'feedback.sentiment.thumbUp' | 'feedback.sentiment.thumbDown' | 'feedback.settings.leftScaleLabel' | 'feedback.settings.rightScaleLabel' | 'feedback.settings.optionalEmail.placeholder' | 'feedback.settings.optionalEmail.label' | 'codeSnippet.report.buttonText' | 'codeSnippet.report.tooltipText' | 'codeSnippet.report.label' | 'codeSnippet.expand.tooltipText' | 'codeSnippet.collapse.tooltipText' | 'userMenu.login' | 'userMenu.logout' | 'userMenu.devOnboardingLabel' | 'mobileMenu.mainMenu' | 'mobileMenu.previous' | 'mobileMenu.products' | 'mobileMenu.version' | 'navbar.products' | 'page.nextButton' | 'page.previousButton' | 'page.actions.copyButtonText' | 'page.actions.copyTitle' | 'page.actions.copyDescription' | 'page.actions.viewAsMdTitle' | 'page.actions.viewAsMdButtonText' | 'page.actions.viewAsMdDescription' | 'page.actions.chatGptTitle' | 'page.actions.chatGptButtonText' | 'page.actions.chatGptDescription' | 'page.actions.claudeTitle' | 'page.actions.claudeButtonText' | 'page.actions.claudeDescription' | 'page.actions.cursorMcpButtonText' | 'page.actions.cursorMcpTitle' | 'page.actions.cursorMcpDescription' | 'openapi.download.description.title' | 'openapi.info.title' | 'openapi.info.contact.url' | 'openapi.info.contact.name' | 'openapi.info.license' | 'openapi.info.termsOfService' | 'openapi.info.metadata.title' | 'openapi.key' | 'openapi.value' | 'openapi.enum' | 'openapi.items' | 'openapi.default' | 'openapi.variable' | 'openapi.variables' | 'openapi.actions.show' | 'openapi.actions.hide' | 'openapi.actions.more' | 'openapi.languages.title' | 'openapi.servers.title' | 'openapi.operations' | 'openapi.webhooks' | 'openapi.description' | 'openapi.badges.deprecated' | 'openapi.badges.required' | 'openapi.badges.webhook' | 'openapi.request' | 'openapi.path' | 'openapi.query' | 'openapi.cookie' | 'openapi.header' | 'openapi.body' | 'openapi.responses' | 'openapi.response' | 'openapi.callbacks' | 'openapi.callbackRequest' | 'openapi.callbackResponse' | 'openapi.payload' | 'openapi.discriminator' | 'openapi.contentType' | 'openapi.tryIt' | 'openapi.loading' | 'openapi.example' | 'openapi.examples' | 'openapi.additionalProperties' | 'openapi.patternProperties' | 'openapi.required' | 'openapi.recursive' | 'openapi.complex' | 'openapi.hideExample' | 'openapi.showExample' | 'openapi.expandAll' | 'openapi.collapseAll' | 'openapi.viewSecurityDetails' | 'openapi.noResponseExample' | 'openapi.discriminator.searchPlaceholder' | 'openapi.discriminator.searchNoResults' | 'openapi.noResponseContent' | 'openapi.noRequestPayload' | 'openapi.hidePattern' | 'openapi.showPattern' | 'openapi.authorizationUrl' | 'openapi.tokenUrl' | 'openapi.refreshUrl' | 'openapi.showOptionalScopes' | 'openapi.hideOptionalScopes' | 'openapi.security' | 'openapi.httpAuthorizationScheme' | 'openapi.bearerFormat' | 'openapi.parameterName' | 'openapi.flowType' | 'openapi.connectUrl' | 'openapi.requiredScopes' | 'openapi.unsupportedLanguage' | 'openapi.failedToGenerateCodeSample' | 'openapi.schemaCatalogLink.title' | 'openapi.schemaCatalogLink.copyButtonTooltip' | 'openapi.schemaCatalogLink.copiedTooltip' | 'openapi.mcp.title' | 'openapi.mcp.endpoint' | 'openapi.mcp.tools' | 'openapi.mcp.protocolVersion' | 'openapi.mcp.capabilities' | 'openapi.mcp.experimentalCapabilities' | 'openapi.mcp.inputSchema' | 'openapi.mcp.inputExample' | 'openapi.mcp.outputSchema' | 'openapi.mcp.outputExample' | 'asyncapi.download.description.title' | 'asyncapi.info.title' | 'graphql.queries' | 'graphql.mutations' | 'graphql.subscriptions' | 'graphql.directives' | 'graphql.objects' | 'graphql.interfaces' | 'graphql.unions' | 'graphql.enums' | 'graphql.inputs' | 'graphql.scalars' | 'graphql.arguments.label' | 'graphql.arguments.show' | 'graphql.arguments.hide' | 'graphql.arguments.here' | 'graphql.returnTypes.label' | 'graphql.returnTypes.show' | 'graphql.returnTypes.hide' | 'graphql.possibleTypes' | 'graphql.defaultValue' | 'graphql.deprecationReason' | 'graphql.requiredScopes' | 'graphql.viewSecurityDetails' | 'graphql.objectScopes' | 'graphql.fieldScopes' | 'graphql.implementedInterfaces' | 'graphql.nonNull' | 'graphql.required' | 'graphql.deprecated' | 'graphql.variables' | 'graphql.querySample' | 'graphql.mutationSample' | 'graphql.subscriptionSample' | 'graphql.responseSample' | 'graphql.locations' | 'graphql.sample' | 'graphql.referenced' | 'graphql.content.fragment' | 'codeWalkthrough.download' | 'codeWalkthrough.preview' | 'time.justNow' | 'time.past.second' | 'time.past.seconds' | 'time.past.minute' | 'time.past.minutes' | 'time.past.hour' | 'time.past.hours' | 'time.past.day' | 'time.past.days' | 'time.past.week' | 'time.past.weeks' | 'time.past.month' | 'time.past.months' | 'time.past.year' | 'time.past.years' | 'page.internalServerError.title' | 'page.internalServerError.description' | 'page.skipToContent.label';
2
+ export type TranslationKey = 'dev.newApp' | 'dev.newApp.text' | 'dev.sidebar.header' | 'dev.sidebar.footer.text' | 'dev.create.app.dialog.appName.placeholder' | 'dev.create.app.dialog.appName.error' | 'dev.create.app.dialog.selectAPIs' | 'dev.create.app.dialog.description' | 'dev.create.app.dialog.description.placeholder' | 'dev.create.app.dialog.create' | 'dev.create.app.dialog.cancel' | 'dev.main.tab.appKeys' | 'dev.main.tab.logs' | 'dev.app.description.title' | 'dev.edit.description.dialog.title' | 'dev.edit.description.dialog.save' | 'dev.edit.description.dialog.cancel' | 'dev.edit.apis.dialog.selectedAPIs' | 'dev.app.key.create' | 'dev.create.key.dialog.title' | 'dev.create.key.dialog.create' | 'dev.create.key.dialog.cancel' | 'dev.app.edit' | 'dev.app.delete' | 'dev.edit.app.dialog.title' | 'dev.edit.app.dialog.save' | 'dev.edit.app.dialog.cancel' | 'dev.delete.app.dialog.title' | 'dev.delete.app.dialog.confirmation' | 'dev.delete.app.dialog.delete' | 'dev.delete.app.dialog.cancel' | 'dev.app.key.roll' | 'dev.roll.key.dialog.title' | 'dev.roll.key.dialog.apiKey' | 'dev.roll.key.dialog.expires' | 'dev.roll.key.dialog.confirmation' | 'dev.roll.key.dialog.cancel' | 'dev.roll.key.dialog.roll' | 'dev.update.key.dialog.title' | 'dev.update.key.dialog.update' | 'dev.update.key.dialog.cancel' | 'dev.app.key.api.name' | 'dev.app.key.api.status' | 'dev.app.key.api.edit' | 'dev.edit.apis.dialog.title' | 'dev.edit.apis.dialog.apiKey' | 'dev.edit.apis.dialog.save' | 'dev.edit.apis.dialog.cancel' | 'dev.select.placeholder' | 'dev.app.overview.status.pending' | 'dev.app.overview.status.approved' | 'dev.app.overview.status.revoked' | 'dev.app.overview.status' | 'dev.app.overview.non-production' | 'dev.app.overview.production' | 'dev.app.overview.clientId' | 'dev.app.overview.apiKey' | 'dev.app.key.revoke' | 'dev.revoke.key.dialog.title' | 'dev.revoke.key.dialog.apiKey' | 'dev.revoke.key.dialog.expires' | 'dev.revoke.key.dialog.confirmation' | 'dev.revoke.key.dialog.revoke' | 'dev.revoke.key.dialog.cancel' | 'dev.app.overview.expires' | 'dev.app.overview.created' | 'dev.app.overview.visibilityToggle.hide' | 'dev.app.overview.visibilityToggle.show' | 'search.loading' | 'search.noResults.title' | 'search.keys.navigate' | 'search.keys.select' | 'search.keys.exit' | 'search.label' | 'search.cancel' | 'search.recent' | 'search.navbar.label' | 'search.suggested' | 'search.showMore' | 'search.filter.title' | 'search.filter.reset' | 'search.filter.field.reset' | 'search.ai.welcomeText' | 'search.ai.newConversation' | 'search.ai.backToSearch' | 'search.ai.back' | 'search.ai.placeholder' | 'search.ai.generatingResponse' | 'search.ai.followUpQuestion' | 'search.ai.suggestionsTitle' | 'search.ai.thinkingText' | 'search.ai.resourcesFound' | 'search.ai.resourcesFound.basedOn' | 'search.ai.resourcesFound.resources' | 'search.ai.feedback.title' | 'search.ai.feedback.detailsPlaceholder' | 'search.ai.feedback.thanks' | 'search.ai.button' | 'search.ai.label' | 'search.ai.disclaimer' | 'search.ai.error.description' | 'search.ai.error.description.forbidden' | 'search.ai.error.description.unauthorized' | 'search.ai.error.header' | 'search.ai.error.header.forbidden' | 'search.ai.error.header.unauthorized' | 'aiAssistant.trigger' | 'toc.header' | 'footer.copyrightText' | 'page.homeButton' | 'page.forbidden.title' | 'page.notFound.title' | 'page.notFound.description' | 'page.lastUpdated.timeago' | 'page.lastUpdated.on' | 'catalog.filters.placeholder' | 'catalog.filters.title' | 'catalog.filters.add' | 'catalog.filters.clearAll' | 'catalog.filters.select.addFilter' | 'catalog.filters.select.all' | 'catalog.filters.done' | 'catalog.catalogs.all.title' | 'catalog.catalogs.all.description' | 'catalog.catalogs.all.switcherLabel' | 'catalog.catalogs.service.title' | 'catalog.catalogs.service.description' | 'catalog.catalogs.service.switcherLabel' | 'catalog.catalogs.user.title' | 'catalog.catalogs.user.description' | 'catalog.catalogs.user.switcherLabel' | 'catalog.catalogs.team.title' | 'catalog.catalogs.team.description' | 'catalog.catalogs.team.switcherLabel' | 'catalog.catalogs.domain.title' | 'catalog.catalogs.domain.description' | 'catalog.catalogs.domain.switcherLabel' | 'catalog.catalogs.apiDescription.title' | 'catalog.catalogs.apiDescription.description' | 'catalog.catalogs.apiDescription.switcherLabel' | 'catalog.catalogs.dataSchema.title' | 'catalog.catalogs.dataSchema.description' | 'catalog.catalogs.dataSchema.switcherLabel' | 'catalog.catalogs.apiOperation.title' | 'catalog.catalogs.apiOperation.description' | 'catalog.catalogs.apiOperation.switcherLabel' | 'catalog.entity.metadata.title' | 'catalog.entity.schema.title' | 'catalog.entity.properties.apiDescription.title' | 'catalog.backToAllLabel' | 'sidebar.menu.backLabel' | 'sidebar.menu.backToLabel' | 'sidebar.actions.show' | 'sidebar.actions.hide' | 'sidebar.actions.changeToSingleColumn' | 'sidebar.actions.changeToTwoColumns' | 'sidebar.actions.singleColumn' | 'sidebar.actions.twoColumns' | 'versionPicker.label' | 'versionPicker.unversioned' | 'codeSnippet.copy.buttonText' | 'codeSnippet.copy.tooltipText' | 'codeSnippet.copy.toasterText' | 'markdown.editPage.text' | 'feedback.settings.comment.submitText' | 'feedback.settings.comment.label' | 'feedback.settings.comment.send' | 'feedback.settings.comment.cancel' | 'feedback.settings.comment.satisfiedLabel' | 'feedback.settings.comment.neutralLabel' | 'feedback.settings.comment.dissatisfiedLabel' | 'feedback.settings.submitText' | 'feedback.settings.label' | 'feedback.settings.reasons.label' | 'feedback.submit' | 'feedback.cancel' | 'feedback.settings.comment.likeLabel' | 'feedback.settings.comment.dislikeLabel' | 'feedback.sentiment.thumbUp' | 'feedback.sentiment.thumbDown' | 'feedback.settings.leftScaleLabel' | 'feedback.settings.rightScaleLabel' | 'feedback.settings.optionalEmail.placeholder' | 'feedback.settings.optionalEmail.label' | 'codeSnippet.report.buttonText' | 'codeSnippet.report.tooltipText' | 'codeSnippet.report.label' | 'codeSnippet.expand.tooltipText' | 'codeSnippet.collapse.tooltipText' | 'userMenu.login' | 'userMenu.logout' | 'userMenu.devOnboardingLabel' | 'mobileMenu.mainMenu' | 'mobileMenu.previous' | 'mobileMenu.products' | 'mobileMenu.version' | 'navbar.products' | 'page.nextButton' | 'page.previousButton' | 'page.actions.copyButtonText' | 'page.actions.copyTitle' | 'page.actions.copyDescription' | 'page.actions.viewAsMdTitle' | 'page.actions.viewAsMdButtonText' | 'page.actions.viewAsMdDescription' | 'page.actions.chatGptTitle' | 'page.actions.chatGptButtonText' | 'page.actions.chatGptDescription' | 'page.actions.claudeTitle' | 'page.actions.claudeButtonText' | 'page.actions.claudeDescription' | 'page.actions.cursorMcpButtonText' | 'page.actions.cursorMcpTitle' | 'page.actions.cursorMcpDescription' | 'page.actions.connectMcp' | 'page.actions.connectMcp.cursor' | 'page.actions.connectMcp.cursorDescription' | 'page.actions.connectMcp.vscode' | 'page.actions.connectMcp.vscodeDescription' | 'page.actions.connectMcp.copyConfig' | 'page.actions.connectMcp.copyConfigDescription' | 'openapi.download.description.title' | 'openapi.info.title' | 'openapi.info.contact.url' | 'openapi.info.contact.name' | 'openapi.info.license' | 'openapi.info.termsOfService' | 'openapi.info.metadata.title' | 'openapi.key' | 'openapi.value' | 'openapi.enum' | 'openapi.items' | 'openapi.default' | 'openapi.variable' | 'openapi.variables' | 'openapi.actions.show' | 'openapi.actions.hide' | 'openapi.actions.more' | 'openapi.languages.title' | 'openapi.servers.title' | 'openapi.operations' | 'openapi.webhooks' | 'openapi.description' | 'openapi.badges.deprecated' | 'openapi.badges.required' | 'openapi.badges.webhook' | 'openapi.request' | 'openapi.path' | 'openapi.query' | 'openapi.cookie' | 'openapi.header' | 'openapi.body' | 'openapi.responses' | 'openapi.response' | 'openapi.callbacks' | 'openapi.callbackRequest' | 'openapi.callbackResponse' | 'openapi.payload' | 'openapi.discriminator' | 'openapi.contentType' | 'openapi.tryIt' | 'openapi.loading' | 'openapi.example' | 'openapi.examples' | 'openapi.additionalProperties' | 'openapi.patternProperties' | 'openapi.required' | 'openapi.recursive' | 'openapi.complex' | 'openapi.hideExample' | 'openapi.showExample' | 'openapi.expandAll' | 'openapi.collapseAll' | 'openapi.viewSecurityDetails' | 'openapi.noResponseExample' | 'openapi.discriminator.searchPlaceholder' | 'openapi.discriminator.searchNoResults' | 'openapi.discriminator.defaultMapping' | 'openapi.discriminator.defaultMappingTooltip' | 'openapi.noResponseContent' | 'openapi.noRequestPayload' | 'openapi.hidePattern' | 'openapi.showPattern' | 'openapi.authorizationUrl' | 'openapi.tokenUrl' | 'openapi.refreshUrl' | 'openapi.showOptionalScopes' | 'openapi.hideOptionalScopes' | 'openapi.security' | 'openapi.httpAuthorizationScheme' | 'openapi.bearerFormat' | 'openapi.parameterName' | 'openapi.flowType' | 'openapi.connectUrl' | 'openapi.requiredScopes' | 'openapi.unsupportedLanguage' | 'openapi.failedToGenerateCodeSample' | 'openapi.schemaCatalogLink.title' | 'openapi.schemaCatalogLink.copyButtonTooltip' | 'openapi.schemaCatalogLink.copiedTooltip' | 'openapi.mcp.title' | 'openapi.mcp.endpoint' | 'openapi.mcp.tools' | 'openapi.mcp.protocolVersion' | 'openapi.mcp.capabilities' | 'openapi.mcp.experimentalCapabilities' | 'openapi.mcp.inputSchema' | 'openapi.mcp.inputExample' | 'openapi.mcp.outputSchema' | 'openapi.mcp.outputExample' | 'asyncapi.download.description.title' | 'asyncapi.info.title' | 'graphql.queries' | 'graphql.mutations' | 'graphql.subscriptions' | 'graphql.directives' | 'graphql.objects' | 'graphql.interfaces' | 'graphql.unions' | 'graphql.enums' | 'graphql.inputs' | 'graphql.scalars' | 'graphql.arguments.label' | 'graphql.arguments.show' | 'graphql.arguments.hide' | 'graphql.arguments.here' | 'graphql.returnTypes.label' | 'graphql.returnTypes.show' | 'graphql.returnTypes.hide' | 'graphql.possibleTypes' | 'graphql.defaultValue' | 'graphql.deprecationReason' | 'graphql.requiredScopes' | 'graphql.viewSecurityDetails' | 'graphql.objectScopes' | 'graphql.fieldScopes' | 'graphql.implementedInterfaces' | 'graphql.nonNull' | 'graphql.required' | 'graphql.deprecated' | 'graphql.variables' | 'graphql.querySample' | 'graphql.mutationSample' | 'graphql.subscriptionSample' | 'graphql.responseSample' | 'graphql.locations' | 'graphql.sample' | 'graphql.referenced' | 'graphql.content.fragment' | 'codeWalkthrough.download' | 'codeWalkthrough.preview' | 'time.justNow' | 'time.past.second' | 'time.past.seconds' | 'time.past.minute' | 'time.past.minutes' | 'time.past.hour' | 'time.past.hours' | 'time.past.day' | 'time.past.days' | 'time.past.week' | 'time.past.weeks' | 'time.past.month' | 'time.past.months' | 'time.past.year' | 'time.past.years' | 'page.internalServerError.title' | 'page.internalServerError.description' | 'page.skipToContent.label';
3
3
  export type Locale = {
4
4
  code: string;
5
5
  name: string;
@@ -0,0 +1,6 @@
1
+ export type MCPClientType = 'cursor' | 'vscode';
2
+ export type MCPOption = 'cursor' | 'vscode' | 'copy';
3
+ export type McpConnectionParams = {
4
+ serverName: string;
5
+ url: string;
6
+ };
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=mcp.js.map
@@ -82,11 +82,18 @@ export type AiSearchErrorConfig = {
82
82
  messageKey: string;
83
83
  messageDefault: string;
84
84
  };
85
+ export declare enum FeedbackType {
86
+ Like = "like",
87
+ Dislike = "dislike"
88
+ }
89
+ export type SearchAiMessageResource = {
90
+ url: string;
91
+ title: string;
92
+ };
85
93
  export type AiSearchConversationItem = {
86
94
  role: AiSearchConversationRole;
87
95
  content: string;
88
- resources?: {
89
- url: string;
90
- title: string;
91
- }[];
96
+ resources?: SearchAiMessageResource[];
97
+ messageId?: string;
98
+ feedback?: FeedbackType;
92
99
  };
@@ -1,3 +1,9 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.FeedbackType = void 0;
4
+ var FeedbackType;
5
+ (function (FeedbackType) {
6
+ FeedbackType["Like"] = "like";
7
+ FeedbackType["Dislike"] = "dislike";
8
+ })(FeedbackType || (exports.FeedbackType = FeedbackType = {}));
3
9
  //# sourceMappingURL=search.js.map
@@ -0,0 +1,12 @@
1
+ import type React from 'react';
2
+ import type { SelectOption } from './select';
3
+ export type SegmentedOption<T> = SelectOption<T> & {
4
+ divider?: React.ReactNode;
5
+ };
6
+ export type SegmentedProps<T = any> = {
7
+ options: SegmentedOption<T>[];
8
+ value: T;
9
+ onChange: ({ label, value }: SegmentedOption<T>) => void;
10
+ className?: string;
11
+ size?: 'regular' | 'small';
12
+ };
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=segmented.js.map
@@ -15,13 +15,23 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (
15
15
  }) : function(o, v) {
16
16
  o["default"] = v;
17
17
  });
18
- var __importStar = (this && this.__importStar) || function (mod) {
19
- if (mod && mod.__esModule) return mod;
20
- var result = {};
21
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
- __setModuleDefault(result, mod);
23
- return result;
24
- };
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
25
35
  var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
26
36
  function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
27
37
  return new (P || (P = Promise))(function (resolve, reject) {
@@ -0,0 +1,6 @@
1
+ /**
2
+ * Utility function for use in React frontmatter
3
+ * This function creates a string that will be processed by the frontmatter loader
4
+ * to convert it into a translation key object
5
+ */
6
+ export declare const frontmatterTranslate: (key: string, defaultValue: string) => string;