@flamingo-stack/openframe-frontend-core 0.0.286 → 0.0.287

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 (81) hide show
  1. package/dist/{chunk-HLQW7MWJ.cjs → chunk-3SDBXXDP.cjs} +21 -21
  2. package/dist/{chunk-HLQW7MWJ.cjs.map → chunk-3SDBXXDP.cjs.map} +1 -1
  3. package/dist/{chunk-4WACBTZU.cjs → chunk-6AW25OS6.cjs} +25 -25
  4. package/dist/{chunk-4WACBTZU.cjs.map → chunk-6AW25OS6.cjs.map} +1 -1
  5. package/dist/{chunk-QCKN37OP.cjs → chunk-6CSW5TMS.cjs} +35 -35
  6. package/dist/{chunk-QCKN37OP.cjs.map → chunk-6CSW5TMS.cjs.map} +1 -1
  7. package/dist/{chunk-YVB3VDIQ.js → chunk-7EYWERFT.js} +2 -2
  8. package/dist/{chunk-6N26CURS.cjs → chunk-D6RK5YXX.cjs} +25 -3
  9. package/dist/chunk-D6RK5YXX.cjs.map +1 -0
  10. package/dist/{chunk-FSBDVT6R.js → chunk-EFYXPR43.js} +2 -2
  11. package/dist/{chunk-XQL4WDML.js → chunk-GJDXIVEQ.js} +3 -3
  12. package/dist/{chunk-D5YY5U6J.cjs → chunk-JQ4I743L.cjs} +11 -11
  13. package/dist/{chunk-D5YY5U6J.cjs.map → chunk-JQ4I743L.cjs.map} +1 -1
  14. package/dist/{chunk-C6SCWXDP.js → chunk-MV67MBV3.js} +3 -3
  15. package/dist/{chunk-BBZ7AX5H.cjs → chunk-MWS25U4U.cjs} +10 -10
  16. package/dist/{chunk-BBZ7AX5H.cjs.map → chunk-MWS25U4U.cjs.map} +1 -1
  17. package/dist/{chunk-DDAT4RKX.js → chunk-ODR6A6FC.js} +24 -2
  18. package/dist/chunk-ODR6A6FC.js.map +1 -0
  19. package/dist/{chunk-GDF2R2ER.cjs → chunk-OXC72UIP.cjs} +120 -120
  20. package/dist/{chunk-GDF2R2ER.cjs.map → chunk-OXC72UIP.cjs.map} +1 -1
  21. package/dist/{chunk-RQ6RTBKF.cjs → chunk-RG6FNZUA.cjs} +65 -27
  22. package/dist/chunk-RG6FNZUA.cjs.map +1 -0
  23. package/dist/{chunk-5BTZOVDQ.js → chunk-RWCA2ZQK.js} +2 -2
  24. package/dist/{chunk-QF2X6PTD.js → chunk-TY2EB7VK.js} +58 -20
  25. package/dist/chunk-TY2EB7VK.js.map +1 -0
  26. package/dist/{chunk-VCQ3CTYK.js → chunk-ZYLQMCHW.js} +3 -3
  27. package/dist/components/chat/index.cjs +3 -3
  28. package/dist/components/chat/index.js +2 -2
  29. package/dist/components/contact/index.cjs +4 -4
  30. package/dist/components/contact/index.js +3 -3
  31. package/dist/components/docs/index.cjs +3 -3
  32. package/dist/components/docs/index.js +2 -2
  33. package/dist/components/embeds/index.cjs +4 -4
  34. package/dist/components/embeds/index.js +3 -3
  35. package/dist/components/faq/faq-section.d.ts.map +1 -1
  36. package/dist/components/faq/index.cjs +4 -4
  37. package/dist/components/faq/index.js +3 -3
  38. package/dist/components/faq-accordion.d.ts.map +1 -1
  39. package/dist/components/features/index.cjs +3 -3
  40. package/dist/components/features/index.js +2 -2
  41. package/dist/components/index.cjs +142 -142
  42. package/dist/components/index.js +7 -7
  43. package/dist/components/navigation/index.cjs +3 -3
  44. package/dist/components/navigation/index.js +2 -2
  45. package/dist/components/related-content/index.cjs +4 -4
  46. package/dist/components/related-content/index.js +3 -3
  47. package/dist/components/tickets/index.cjs +53 -53
  48. package/dist/components/tickets/index.js +4 -4
  49. package/dist/components/ui/index.cjs +3 -3
  50. package/dist/components/ui/index.js +2 -2
  51. package/dist/index.cjs +9 -3
  52. package/dist/index.cjs.map +1 -1
  53. package/dist/index.js +8 -2
  54. package/dist/types/marketing.d.ts +1 -1
  55. package/dist/types/marketing.d.ts.map +1 -1
  56. package/dist/utils/faq-anchor.d.ts +51 -0
  57. package/dist/utils/faq-anchor.d.ts.map +1 -0
  58. package/dist/utils/index.cjs +23 -1
  59. package/dist/utils/index.cjs.map +1 -1
  60. package/dist/utils/index.d.ts +2 -0
  61. package/dist/utils/index.d.ts.map +1 -1
  62. package/dist/utils/index.js +21 -2
  63. package/dist/utils/index.js.map +1 -1
  64. package/dist/utils/list-url.d.ts.map +1 -1
  65. package/package.json +1 -1
  66. package/src/components/faq/faq-section.tsx +78 -26
  67. package/src/components/faq-accordion.tsx +8 -1
  68. package/src/types/marketing.ts +1 -0
  69. package/src/utils/faq-anchor.ts +70 -0
  70. package/src/utils/index.ts +7 -0
  71. package/src/utils/list-url.ts +1 -0
  72. package/dist/chunk-6N26CURS.cjs.map +0 -1
  73. package/dist/chunk-DDAT4RKX.js.map +0 -1
  74. package/dist/chunk-QF2X6PTD.js.map +0 -1
  75. package/dist/chunk-RQ6RTBKF.cjs.map +0 -1
  76. /package/dist/{chunk-YVB3VDIQ.js.map → chunk-7EYWERFT.js.map} +0 -0
  77. /package/dist/{chunk-FSBDVT6R.js.map → chunk-EFYXPR43.js.map} +0 -0
  78. /package/dist/{chunk-XQL4WDML.js.map → chunk-GJDXIVEQ.js.map} +0 -0
  79. /package/dist/{chunk-C6SCWXDP.js.map → chunk-MV67MBV3.js.map} +0 -0
  80. /package/dist/{chunk-5BTZOVDQ.js.map → chunk-RWCA2ZQK.js.map} +0 -0
  81. /package/dist/{chunk-VCQ3CTYK.js.map → chunk-ZYLQMCHW.js.map} +0 -0
@@ -4,12 +4,15 @@
4
4
  var _chunkD3LEFMOAcjs = require('./chunk-D3LEFMOA.cjs');
5
5
 
6
6
 
7
- var _chunkGDF2R2ERcjs = require('./chunk-GDF2R2ER.cjs');
7
+ var _chunkOXC72UIPcjs = require('./chunk-OXC72UIP.cjs');
8
8
 
9
9
 
10
10
 
11
11
 
12
- var _chunk6N26CURScjs = require('./chunk-6N26CURS.cjs');
12
+
13
+
14
+
15
+ var _chunkD6RK5YXXcjs = require('./chunk-D6RK5YXX.cjs');
13
16
 
14
17
 
15
18
 
@@ -67,7 +70,8 @@ function FaqAccordion({ items, defaultOpenIds = [] }) {
67
70
  return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
68
71
  "div",
69
72
  {
70
- className: _chunkFIG2RKZFcjs.cn.call(void 0, "group transition-colors hover:bg-[#1E1E1E]", isOpen ? "bg-ods-bg" : "bg-transparent"),
73
+ id: _chunkD6RK5YXXcjs.faqItemAnchor.call(void 0, item.id),
74
+ className: _chunkFIG2RKZFcjs.cn.call(void 0, "group scroll-mt-24 transition-colors hover:bg-[#1E1E1E]", isOpen ? "bg-ods-bg" : "bg-transparent"),
71
75
  children: [
72
76
  /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
73
77
  "div",
@@ -86,7 +90,7 @@ function FaqAccordion({ items, defaultOpenIds = [] }) {
86
90
  children: [
87
91
  /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "div", { className: "min-w-0 pr-4", children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "h3", { children: item.question }) }),
88
92
  /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "div", { className: "flex-shrink-0", children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
89
- _chunkGDF2R2ERcjs.ChevronButton,
93
+ _chunkOXC72UIPcjs.ChevronButton,
90
94
  {
91
95
  "aria-label": isOpen ? "Collapse question" : "Expand question",
92
96
  size: "md",
@@ -146,10 +150,7 @@ function buildFaqJsonLdFromFaqs(faqs, opts = {}) {
146
150
 
147
151
  var DEFAULT_HEADING_TEXT = "Frequently Asked Questions";
148
152
  function buildFaqsUrl(entityType, entityId, minResults, apiBaseUrl = "") {
149
- return _chunk6N26CURScjs.buildSuggestionUrl.call(void 0, "/api/faqs", { apiBaseUrl, entityType, entityId, count: minResults });
150
- }
151
- function sectionSlug(section) {
152
- return "faq-" + section.toLowerCase().replace(/[^a-z0-9]+/g, "-").replace(/^-+|-+$/g, "");
153
+ return _chunkD6RK5YXXcjs.buildSuggestionUrl.call(void 0, "/api/faqs", { apiBaseUrl, entityType, entityId, count: minResults });
153
154
  }
154
155
  function groupFaqsBySection(faqs) {
155
156
  const order = [];
@@ -165,7 +166,7 @@ function groupFaqsBySection(faqs) {
165
166
  }
166
167
  let group = byName.get(name);
167
168
  if (!group) {
168
- group = { section: name, slug: sectionSlug(name), items: [] };
169
+ group = { section: name, slug: _chunkD6RK5YXXcjs.faqSectionSlug.call(void 0, name), items: [] };
169
170
  byName.set(name, group);
170
171
  order.push(name);
171
172
  }
@@ -176,6 +177,8 @@ function groupFaqsBySection(faqs) {
176
177
  return groups;
177
178
  }
178
179
  var FAQ_NAV_HEADER_OFFSET = 96;
180
+ var UNCATEGORIZED_KEY = "__uncategorized__";
181
+ var groupKey = (g) => _nullishCoalesce(g.slug, () => ( UNCATEGORIZED_KEY));
179
182
  function GroupedFaqList({
180
183
  groups,
181
184
  categoryHeadingAs
@@ -212,11 +215,36 @@ function GroupedFaqList({
212
215
  }
213
216
  return () => observer.disconnect();
214
217
  }, [slugKey]);
218
+ const [hashTarget, setHashTarget] = _react.useState.call(void 0, null);
219
+ _react.useEffect.call(void 0, () => {
220
+ const refresh = () => setHashTarget(_chunkD6RK5YXXcjs.parseFaqHash.call(void 0, window.location.hash));
221
+ refresh();
222
+ window.addEventListener("hashchange", refresh);
223
+ return () => window.removeEventListener("hashchange", refresh);
224
+ }, []);
225
+ const defaultOpenByGroupKey = _react.useMemo.call(void 0, () => {
226
+ if (_optionalChain([hashTarget, 'optionalAccess', _7 => _7.kind]) !== "item") return null;
227
+ const targetId = hashTarget.rawId;
228
+ const result = /* @__PURE__ */ new Map();
229
+ for (const group of groups) {
230
+ const hit = group.items.find((i) => String(i.id) === targetId);
231
+ if (hit) result.set(groupKey(group), [hit.id]);
232
+ }
233
+ return result.size > 0 ? result : null;
234
+ }, [groups, hashTarget]);
235
+ const accordionKeySuffix = _optionalChain([hashTarget, 'optionalAccess', _8 => _8.kind]) === "item" ? `item:${hashTarget.rawId}` : "default";
236
+ _react.useEffect.call(void 0, () => {
237
+ if (!hashTarget) return;
238
+ const elId = hashTarget.kind === "item" ? _chunkD6RK5YXXcjs.faqItemAnchor.call(void 0, hashTarget.rawId) : hashTarget.slug;
239
+ const el = document.getElementById(elId);
240
+ if (el) _chunkD6RK5YXXcjs.scrollElementIntoView.call(void 0, el, { headerOffset: FAQ_NAV_HEADER_OFFSET });
241
+ if (hashTarget.kind === "section") setActiveSlug(hashTarget.slug);
242
+ }, [hashTarget]);
215
243
  const handleJump = _react.useCallback.call(void 0,
216
244
  (e, slug) => {
217
245
  e.preventDefault();
218
246
  setActiveSlug(slug);
219
- _chunk6N26CURScjs.scrollElementIntoView.call(void 0, document.getElementById(slug), {
247
+ _chunkD6RK5YXXcjs.scrollElementIntoView.call(void 0, document.getElementById(slug), {
220
248
  headerOffset: FAQ_NAV_HEADER_OFFSET
221
249
  });
222
250
  if (typeof history !== "undefined") history.replaceState(null, "", `#${slug}`);
@@ -241,18 +269,28 @@ function GroupedFaqList({
241
269
  group.slug
242
270
  );
243
271
  }) }),
244
- /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "div", { className: "space-y-10", children: groups.map((group) => /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
245
- "section",
246
- {
247
- id: _nullishCoalesce(group.slug, () => ( void 0)),
248
- className: "scroll-mt-24 space-y-4",
249
- children: [
250
- group.section && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, CategoryHeading, { className: _chunkY4JNA4W6cjs.SECTION_HEADING_CLASS, children: group.section }),
251
- /* @__PURE__ */ _jsxruntime.jsx.call(void 0, FaqAccordion, { items: group.items })
252
- ]
253
- },
254
- _nullishCoalesce(group.slug, () => ( "faq-uncategorized"))
255
- )) })
272
+ /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "div", { className: "space-y-10", children: groups.map((group) => {
273
+ const key = groupKey(group);
274
+ return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
275
+ "section",
276
+ {
277
+ id: _nullishCoalesce(group.slug, () => ( void 0)),
278
+ className: "scroll-mt-24 space-y-4",
279
+ children: [
280
+ group.section && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, CategoryHeading, { className: _chunkY4JNA4W6cjs.SECTION_HEADING_CLASS, children: group.section }),
281
+ /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
282
+ FaqAccordion,
283
+ {
284
+ items: group.items,
285
+ defaultOpenIds: _optionalChain([defaultOpenByGroupKey, 'optionalAccess', _9 => _9.get, 'call', _10 => _10(key)])
286
+ },
287
+ `${key}:${accordionKeySuffix}`
288
+ )
289
+ ]
290
+ },
291
+ key
292
+ );
293
+ }) })
256
294
  ] });
257
295
  }
258
296
  function FaqSkeleton() {
@@ -281,7 +319,7 @@ function FaqSection({
281
319
  [initialFaqs]
282
320
  );
283
321
  const { data, isLoading, error } = _chunkD3LEFMOAcjs.useSelfFetch.call(void 0, url, { initialData });
284
- const faqs = _nullishCoalesce(_optionalChain([data, 'optionalAccess', _7 => _7.faqs]), () => ( []));
322
+ const faqs = _nullishCoalesce(_optionalChain([data, 'optionalAccess', _11 => _11.faqs]), () => ( []));
285
323
  const groups = _react.useMemo.call(void 0, () => faqs.length > 0 ? groupFaqsBySection(faqs) : [], [faqs]);
286
324
  const headingNode = heading === void 0 ? /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "h2", { className: _chunkY4JNA4W6cjs.SECTION_HEADING_CLASS, children: DEFAULT_HEADING_TEXT }) : heading;
287
325
  if (error) return null;
@@ -299,7 +337,7 @@ function FaqSection({
299
337
  "script",
300
338
  {
301
339
  type: "application/ld+json",
302
- dangerouslySetInnerHTML: { __html: _chunk6N26CURScjs.serializeJsonLd.call(void 0, schema) }
340
+ dangerouslySetInnerHTML: { __html: _chunkD6RK5YXXcjs.serializeJsonLd.call(void 0, schema) }
303
341
  }
304
342
  )
305
343
  ] });
@@ -319,8 +357,8 @@ function FaqDocumentPage({
319
357
  }) {
320
358
  const router = _chunkG7UE6RKVcjs.useRouter.call(void 0, );
321
359
  const backCfg = backButton === false ? void 0 : {
322
- label: _nullishCoalesce(_optionalChain([backButton, 'optionalAccess', _8 => _8.label]), () => ( "Back to home")),
323
- onClick: () => router.push(_nullishCoalesce(_optionalChain([backButton, 'optionalAccess', _9 => _9.href]), () => ( "/")))
360
+ label: _nullishCoalesce(_optionalChain([backButton, 'optionalAccess', _12 => _12.label]), () => ( "Back to home")),
361
+ onClick: () => router.push(_nullishCoalesce(_optionalChain([backButton, 'optionalAccess', _13 => _13.href]), () => ( "/")))
324
362
  };
325
363
  return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkEI4WALN2cjs.PageShell, { children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkEI4WALN2cjs.PageLayout, { title, subtitle, backButton: backCfg, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
326
364
  FaqSection,
@@ -339,4 +377,4 @@ function FaqDocumentPage({
339
377
 
340
378
 
341
379
  exports.FaqAccordion = FaqAccordion; exports.FaqSection = FaqSection; exports.FaqDocumentPage = FaqDocumentPage;
342
- //# sourceMappingURL=chunk-RQ6RTBKF.cjs.map
380
+ //# sourceMappingURL=chunk-RG6FNZUA.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["/home/runner/work/openframe-oss-lib/openframe-oss-lib/openframe-frontend-core/dist/chunk-RG6FNZUA.cjs","../src/components/faq/faq-section.tsx","../src/components/faq-accordion.tsx","../src/components/faq/json-ld.ts","../src/components/faq/faq-document-page.tsx"],"names":["jsx","jsxs"],"mappings":"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","file":"/home/runner/work/openframe-oss-lib/openframe-oss-lib/openframe-frontend-core/dist/chunk-RG6FNZUA.cjs","sourcesContent":[null,"\"use client\"\n\nimport React, { useCallback, useEffect, useMemo, useState } from 'react'\nimport type { Faq } from '../../types/faq'\nimport { FaqAccordion, type FaqItem } from '../faq-accordion'\nimport { useSelfFetch } from '../../hooks/use-self-fetch'\nimport { buildSuggestionUrl } from '../../utils/suggestion-url'\nimport { serializeJsonLd } from '../../utils/common'\nimport { scrollElementIntoView } from '../../utils/scroll-into-view'\nimport { faqSectionSlug, faqItemAnchor, parseFaqHash, type FaqHashTarget } from '../../utils/faq-anchor'\nimport { cn } from '../../utils/cn'\nimport { buildFaqJsonLdFromFaqs, type FaqSchemaOptions } from './json-ld'\nimport { SECTION_HEADING_CLASS } from '../layout/page-heading'\n\nexport interface FaqSectionProps {\n /**\n * SSR hydrate. When provided, the hook skips the first client fetch (per\n * useSelfFetch contract). The consuming server page resolves FAQs then drills\n * them into this prop — the lib never re-fetches what the host already gated on.\n */\n initialFaqs?: Faq[]\n /** Both required together for entity-attached FAQs; partial → bare /api/faqs. */\n entityType?: string\n entityId?: number | string\n /**\n * Heading node above the grouped list. `undefined` → default\n * `<h2>`\"Frequently Asked Questions\". `null` → no heading (the host page\n * owns the `<h1>`, as the standalone /faqs surface does). A React node lets a\n * platform drill its own <PageHeading> without the lib referencing platform\n * state. Also drives category nesting so the document outline stays correct:\n * `null` → categories render `<h2>` (directly under the page `<h1>`);\n * otherwise categories render `<h3>` beneath this heading.\n */\n heading?: React.ReactNode | null\n /** Inject FAQPage schema.org JSON-LD as a <script>. Off by default so embeds\n * don't emit duplicate schema. */\n emitJsonLd?: boolean\n /** Overrides for the JSON-LD's name/description/url. */\n jsonLd?: FaqSchemaOptions\n className?: string\n /** Maps to /api/faqs `?count=` (the 5-tier fill target). Absent → param\n * not sent (server default applies). */\n minResults?: number\n /** Fetch-URL prefix for third-party embeds / reverse proxies\n * ('' = same-origin relative). */\n apiBaseUrl?: string\n}\n\nconst DEFAULT_HEADING_TEXT = 'Frequently Asked Questions'\n\n/** URL composition shared with RelatedContentSection (`buildSuggestionUrl`)\n * — byte-identical to the historical `buildFaqsUrl` output when\n * `minResults`/`apiBaseUrl` are absent. */\nfunction buildFaqsUrl(\n entityType?: string,\n entityId?: number | string,\n minResults?: number,\n apiBaseUrl = '',\n): string {\n return buildSuggestionUrl('/api/faqs', { apiBaseUrl, entityType, entityId, count: minResults })\n}\n\ninterface FaqGroup {\n /** null → the uncategorized bucket: no heading, no jump pill, rendered last. */\n section: string | null\n slug: string | null\n items: FaqItem[]\n}\n\n/** Group FAQs by `faq.section`, preserving the server's first-seen\n * (display_order) order for BOTH the section order and the rows within each\n * section. The uncategorized bucket (blank/missing section) sinks to the end\n * since it renders without a heading. Items carry NO badge here — the `<h2>`\n * IS the category, so a per-row chip would be redundant. */\nfunction groupFaqsBySection(faqs: Faq[]): FaqGroup[] {\n const order: string[] = []\n const byName = new Map<string, FaqGroup>()\n let uncategorized: FaqGroup | null = null\n for (const faq of faqs) {\n const item: FaqItem = { id: faq.id, question: faq.question, answer: faq.answer }\n const name = faq.section?.trim()\n if (!name) {\n if (!uncategorized) uncategorized = { section: null, slug: null, items: [] }\n uncategorized.items.push(item)\n continue\n }\n let group = byName.get(name)\n if (!group) {\n group = { section: name, slug: faqSectionSlug(name), items: [] }\n byName.set(name, group)\n order.push(name)\n }\n group.items.push(item)\n }\n const groups = order.map((name) => byName.get(name)!)\n if (uncategorized) groups.push(uncategorized)\n return groups\n}\n\n/** The standard hub sticky-header height — same offset `useNavLink`'s hash\n * scroll uses, so a category jump lands below the header, not under it. */\nconst FAQ_NAV_HEADER_OFFSET = 96\n\n/** Map key for the uncategorized bucket — `group.slug` is null for it, so\n * every per-group map (default-open ids, accordion keys) uses this sentinel\n * to keep the lookup typed. */\nconst UNCATEGORIZED_KEY = '__uncategorized__'\nconst groupKey = (g: FaqGroup): string => g.slug ?? UNCATEGORIZED_KEY\n\n/**\n * Grouped FAQ layout: a category jump-nav above stacked `<h2>` category\n * sections (each its own accordion). Isolated into its own component so the\n * scroll-spy hooks only mount in grouped mode — `FaqSection`'s own hooks stay\n * unconditional.\n *\n * The pills are real `<a href=\"#slug\">` anchors (crawlable in-page links,\n * deep-linkable, work without JS); the click handler upgrades the jump to the\n * cancellation-proof `scrollElementIntoView` tween and syncs the URL hash.\n */\nfunction GroupedFaqList({\n groups,\n categoryHeadingAs,\n}: {\n groups: FaqGroup[]\n /** Heading tag for each category, so the document outline nests correctly\n * under whatever owns the heading above this block: `h2` on the standalone\n * page (the page owns the `<h1>`), `h3` beneath an embed's `<h2>` title.\n * The VISUAL is `SECTION_HEADING_CLASS` either way, so categories look\n * identical on every surface. */\n categoryHeadingAs: 'h2' | 'h3'\n}) {\n const CategoryHeading = categoryHeadingAs\n const navGroups = useMemo(() => groups.filter((g) => g.slug), [groups])\n const [activeSlug, setActiveSlug] = useState<string | null>(navGroups[0]?.slug ?? null)\n // Identity-stable key for the section set so the observer re-binds only when\n // the categories actually change (not on every parent re-render).\n const slugKey = navGroups.map((g) => g.slug).join('|')\n\n // Scroll-spy: mark the pill for the category currently at the top of the\n // viewport. rootMargin drops the trigger line just below the sticky header\n // and ignores the bottom ~55% so \"active\" is the section being read, not the\n // next one peeking in.\n useEffect(() => {\n if (navGroups.length < 2) return\n const tops = new Map<string, number>()\n const observer = new IntersectionObserver(\n (entries) => {\n for (const entry of entries) {\n const id = (entry.target as HTMLElement).id\n if (entry.isIntersecting) tops.set(id, entry.boundingClientRect.top)\n else tops.delete(id)\n }\n let bestId: string | null = null\n let bestTop = Number.POSITIVE_INFINITY\n for (const [id, top] of tops) {\n if (top < bestTop) {\n bestTop = top\n bestId = id\n }\n }\n if (bestId) setActiveSlug(bestId)\n },\n { rootMargin: `-${FAQ_NAV_HEADER_OFFSET}px 0px -55% 0px`, threshold: 0 },\n )\n for (const group of navGroups) {\n const el = group.slug ? document.getElementById(group.slug) : null\n if (el) observer.observe(el)\n }\n return () => observer.disconnect()\n // slugKey encodes the section set; re-observe only when it changes.\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [slugKey])\n\n // ─── Hash dispatch — `/faqs#faq-item-<id>` or `/faqs#faq-<section-slug>` ──\n // Tracks the current hash so:\n // 1. an item-kind hash seeds `defaultOpenIds` on the matching accordion\n // (auto-expands the cited question);\n // 2. either kind triggers the cancellation-proof tween scroll with the\n // sticky-header offset (native browser hash scroll runs once, ignores\n // our offset — re-running the tween puts the target in the right spot).\n // Listens to `hashchange` so back/forward replays the same behavior. SSR-\n // safe: initial null state matches the server render; the first effect\n // tick on the client updates it.\n const [hashTarget, setHashTarget] = useState<FaqHashTarget | null>(null)\n useEffect(() => {\n const refresh = () => setHashTarget(parseFaqHash(window.location.hash))\n refresh()\n window.addEventListener('hashchange', refresh)\n return () => window.removeEventListener('hashchange', refresh)\n }, [])\n\n // Per-group default-open set when the hash points at an item. The map key\n // matches `groupKey(group)` so the render-time lookup is O(1) per group.\n const defaultOpenByGroupKey = useMemo(() => {\n if (hashTarget?.kind !== 'item') return null\n const targetId = hashTarget.rawId\n const result = new Map<string, (string | number)[]>()\n for (const group of groups) {\n const hit = group.items.find((i) => String(i.id) === targetId)\n if (hit) result.set(groupKey(group), [hit.id])\n }\n return result.size > 0 ? result : null\n }, [groups, hashTarget])\n\n // Accordion is uncontrolled — `defaultOpenIds` is only consumed at mount,\n // so a new item hash needs a remount to honor it. Keying off the item-id\n // suffix triggers exactly the remount we need (and stays stable when the\n // hash points at a section, so category navigation never disturbs the\n // accordion's open state).\n const accordionKeySuffix =\n hashTarget?.kind === 'item' ? `item:${hashTarget.rawId}` : 'default'\n\n useEffect(() => {\n if (!hashTarget) return\n const elId =\n hashTarget.kind === 'item' ? faqItemAnchor(hashTarget.rawId) : hashTarget.slug\n const el = document.getElementById(elId)\n if (el) scrollElementIntoView(el, { headerOffset: FAQ_NAV_HEADER_OFFSET })\n if (hashTarget.kind === 'section') setActiveSlug(hashTarget.slug)\n }, [hashTarget])\n\n const handleJump = useCallback(\n (e: React.MouseEvent<HTMLAnchorElement>, slug: string) => {\n e.preventDefault()\n setActiveSlug(slug)\n scrollElementIntoView(document.getElementById(slug), {\n headerOffset: FAQ_NAV_HEADER_OFFSET,\n })\n if (typeof history !== 'undefined') history.replaceState(null, '', `#${slug}`)\n },\n [],\n )\n\n return (\n <div className=\"space-y-8\">\n {navGroups.length > 1 && (\n <nav aria-label=\"FAQ categories\" className=\"flex flex-wrap gap-2\">\n {navGroups.map((group) => {\n const isActive = group.slug === activeSlug\n return (\n <a\n key={group.slug}\n href={`#${group.slug}`}\n aria-current={isActive ? 'true' : undefined}\n onClick={(e) => handleJump(e, group.slug as string)}\n className={cn(\n \"rounded-full border px-4 py-2 text-sm font-medium font-['DM_Sans'] transition-colors\",\n isActive\n ? 'border-ods-text-primary bg-ods-card text-ods-text-primary'\n : 'border-ods-border bg-ods-card text-ods-text-secondary hover:border-ods-text-secondary hover:text-ods-text-primary',\n )}\n >\n {group.section}\n </a>\n )\n })}\n </nav>\n )}\n <div className=\"space-y-10\">\n {groups.map((group) => {\n const key = groupKey(group)\n return (\n <section\n key={key}\n id={group.slug ?? undefined}\n className=\"scroll-mt-24 space-y-4\"\n >\n {group.section && (\n <CategoryHeading className={SECTION_HEADING_CLASS}>{group.section}</CategoryHeading>\n )}\n <FaqAccordion\n // Re-key on item-hash changes so the remount picks up the new\n // `defaultOpenIds` (the accordion is uncontrolled). Stable for\n // section hashes — category navigation doesn't disturb state.\n key={`${key}:${accordionKeySuffix}`}\n items={group.items}\n defaultOpenIds={defaultOpenByGroupKey?.get(key)}\n />\n </section>\n )\n })}\n </div>\n </div>\n )\n}\n\nfunction FaqSkeleton() {\n return (\n <div className=\"space-y-8 animate-pulse\">\n <div className=\"h-12 md:h-14 w-2/3 rounded bg-ods-border\" />\n <div className=\"rounded-3xl border border-ods-border overflow-hidden bg-ods-card divide-y divide-ods-border w-full\">\n {Array.from({ length: 8 }).map((_, idx) => (\n <div key={idx} className=\"flex items-center justify-between px-6 md:px-8 py-6\">\n <div className=\"h-6 w-5/6 rounded bg-ods-border\" />\n <div className=\"h-10 w-10 rounded-md bg-ods-border\" />\n </div>\n ))}\n </div>\n </div>\n )\n}\n\ninterface FaqsResponse {\n faqs: Faq[]\n}\n\n/**\n * The FAQ display surface — ONE rendering on every host: the list grouped by\n * `faq.section` (each category a heading + its own accordion, with a category\n * jump-nav once there are 2+ categories). There is no flat/ungrouped mode and\n * no page-vs-embedded shell fork; the standalone /faqs page and every embed\n * render through this single path, so they cannot drift.\n *\n * - Standalone /faqs page: pass `initialFaqs` (SSR) + `heading={null}` (the\n * page owns the <h1>) + `emitJsonLd` with `jsonLd` overrides for SEO.\n * - Per-entity embed: pass `entityType` + `entityId` (no `initialFaqs`); the\n * hook self-fetches `GET /api/faqs`, and `heading` is this block's own <h2>.\n *\n * CONTRACT: the consuming app MUST implement `GET /api/faqs`. On a fetch error\n * (or zero FAQs) the component renders nothing so the host page isn't\n * disfigured. The host always supplies the page shell — this renders a bare\n * <section>.\n */\nexport function FaqSection({\n initialFaqs,\n entityType,\n entityId,\n heading,\n emitJsonLd = false,\n jsonLd,\n className,\n minResults,\n apiBaseUrl = '',\n}: FaqSectionProps) {\n const url = buildFaqsUrl(entityType, entityId, minResults, apiBaseUrl)\n // Memoized — useSelfFetch re-syncs on [initialData]; a fresh per-render\n // wrapper object would setState-loop under re-rendering parents.\n const initialData = useMemo<FaqsResponse | undefined>(\n () => (initialFaqs ? { faqs: initialFaqs } : undefined),\n [initialFaqs],\n )\n const { data, isLoading, error } = useSelfFetch<FaqsResponse>(url, { initialData })\n\n const faqs = data?.faqs ?? []\n // Grouped before the early returns so the hook order stays stable.\n const groups = useMemo(() => (faqs.length > 0 ? groupFaqsBySection(faqs) : []), [faqs])\n\n // `undefined` → default <h2> title; `null` → the host page owns the <h1>, so\n // no title renders here. `heading === null` also makes the category headings\n // <h2> (directly under the page <h1>); otherwise they nest as <h3>.\n const headingNode =\n heading === undefined ? <h2 className={SECTION_HEADING_CLASS}>{DEFAULT_HEADING_TEXT}</h2> : heading\n\n // Degrade silently — never show an error banner or an empty section shell\n // where FAQs would be (host pages and the standalone surface both rely on it).\n if (error) return null\n if (!isLoading && faqs.length === 0) return null\n if (isLoading && faqs.length === 0) {\n return (\n <div className={className}>\n <FaqSkeleton />\n </div>\n )\n }\n\n const schema = emitJsonLd ? buildFaqJsonLdFromFaqs(faqs, jsonLd) : null\n\n return (\n <>\n <section className={className ?? 'space-y-10'}>\n {headingNode}\n <GroupedFaqList groups={groups} categoryHeadingAs={heading === null ? 'h2' : 'h3'} />\n </section>\n {schema && (\n <script\n type=\"application/ld+json\"\n // eslint-disable-next-line react/no-danger\n // serializeJsonLd, NOT raw JSON.stringify — FAQ answers are\n // admin-entered; an embedded \"</script>\" must not break the tag.\n dangerouslySetInnerHTML={{ __html: serializeJsonLd(schema) }}\n />\n )}\n </>\n )\n}\n","\"use client\"\n\nimport React, { useRef, useState, useEffect, useCallback } from 'react'\nimport { ChevronButton } from './ui/chevron-button'\nimport { cn } from \"../utils/cn\"\nimport { faqItemAnchor } from \"../utils/faq-anchor\"\n\nexport interface FaqItem {\n id: number | string\n question: string\n answer: string\n}\n\ninterface FaqAccordionProps {\n items: FaqItem[]\n defaultOpenIds?: (number | string)[]\n}\n\n// Utility to measure scrollHeight outside render cycle\nconst useMeasuredHeight = (isOpen: boolean) => {\n const ref = useRef<HTMLDivElement | null>(null)\n const [maxHeight, setMaxHeight] = useState<string>('0px')\n\n const measure = useCallback(() => {\n if (ref.current) {\n const height = ref.current.scrollHeight\n setMaxHeight(`${height}px`)\n }\n }, [])\n\n // Update height only when section is open\n useEffect(() => {\n if (isOpen) {\n measure()\n } else {\n setMaxHeight('0px')\n }\n }, [isOpen, measure])\n\n return { ref, maxHeight }\n}\n\nexport function FaqAccordion({ items, defaultOpenIds = [] }: FaqAccordionProps) {\n const [openSet, setOpenSet] = useState<Set<string | number>>(new Set(defaultOpenIds))\n\n const toggle = (id: string | number) => {\n setOpenSet(prev => {\n const next = new Set(prev)\n if (next.has(id)) next.delete(id)\n else next.add(id)\n return next\n })\n }\n\n return (\n <div className=\"rounded-3xl border border-ods-border divide-y divide-ods-border bg-ods-card overflow-hidden\">\n {items.map(item => {\n const isOpen = openSet.has(item.id)\n const { ref, maxHeight } = useMeasuredHeight(isOpen)\n\n return (\n <div\n key={item.id}\n // Per-row anchor — chat citation chips (`/faqs#faq-item-<id>`) land\n // here via native browser hash scroll AND via `FaqSection`'s tween\n // dispatch. `scroll-mt-24` keeps the row header below the 96px\n // sticky nav offset (matches `<section>`'s scroll-margin for\n // category anchors).\n id={faqItemAnchor(item.id)}\n className={cn('group scroll-mt-24 transition-colors hover:bg-[#1E1E1E]', isOpen ? 'bg-ods-bg' : 'bg-transparent')}\n >\n {/* Header */}\n <div\n role=\"button\"\n tabIndex={0}\n onClick={() => toggle(item.id)}\n onKeyDown={(e) => {\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault();\n toggle(item.id);\n }\n }}\n aria-expanded={isOpen}\n className=\"flex w-full items-center justify-between px-6 md:px-8 py-6 text-left focus:outline-none transition-colors cursor-pointer\"\n >\n <div className=\"min-w-0 pr-4\">\n <h3>\n {item.question}\n </h3>\n </div>\n <div className=\"flex-shrink-0\">\n <ChevronButton\n aria-label={isOpen ? 'Collapse question' : 'Expand question'}\n size=\"md\"\n isExpanded={isOpen}\n backgroundColor=\"transparent\"\n borderColor=\"#3A3A3A\"\n />\n </div>\n </div>\n {/* Content wrapper with max-height animation */}\n <div\n style={{ maxHeight, transition: 'max-height 0.35s ease-in-out, opacity 0.35s ease-in-out', opacity: isOpen ? 1 : 0 }}\n className=\"overflow-hidden group-hover:bg-[#1E1E1E]/30\"\n >\n <div ref={ref} className=\"px-6 md:px-8 pb-6 text-ods-text-primary text-h4\">\n {item.answer}\n </div>\n </div>\n </div>\n )\n })}\n </div>\n )\n} ","/**\n * Pure FAQ JSON-LD builder. No React, no client-only deps — safe to import from\n * Server Components via the `./components/faq` subpath export. (Do NOT import\n * through the root `./components` barrel — that barrel is `\"use client\"` and\n * dragging it into a Server Component would force the client graph into the\n * server.)\n *\n * The hub used to harcode `name`/`description` here for OpenMSP; in the lib we\n * accept overrides so every embedder can supply its own platform branding.\n */\nimport type { Faq } from '../../types/faq'\n\nexport interface FaqSchemaOptions {\n name?: string\n description?: string\n url?: string\n}\n\nconst DEFAULT_NAME = 'Frequently Asked Questions'\nconst DEFAULT_DESCRIPTION =\n 'Answers to common questions.'\n\nexport function baseFaqSchema(opts: FaqSchemaOptions = {}) {\n return {\n '@context': 'https://schema.org',\n '@type': 'FAQPage',\n name: opts.name ?? DEFAULT_NAME,\n description: opts.description ?? DEFAULT_DESCRIPTION,\n ...(opts.url ? { url: opts.url } : {}),\n } as const\n}\n\nexport function buildFaqJsonLdFromFaqs(faqs: Faq[], opts: FaqSchemaOptions = {}) {\n return {\n ...baseFaqSchema(opts),\n mainEntity: faqs.map((faq) => ({\n '@type': 'Question',\n name: faq.question,\n acceptedAnswer: {\n '@type': 'Answer',\n text: faq.answer,\n },\n })),\n } as const\n}\n","'use client';\n\n/**\n * FaqDocumentPage — the full `/faqs` page with chrome, so embedders drop in\n * ONE component instead of hand-assembling `PageShell` + `PageLayout` around the\n * bare `<FaqSection>`. Mirrors `LegalDocumentPage` / `DevSectionPage`: the\n * page-level layout lives in the lib, the host passes only config + a back button.\n *\n * `<FaqSection heading={null}>` lets `PageLayout`'s `TitleBlock` own the heading +\n * back button; it self-fetches `${apiBaseUrl}/api/faqs` via the authed\n * `useSelfFetch`, and renders nothing on a fetch error or zero FAQs.\n */\n\nimport { PageShell, PageLayout } from '../ui';\nimport { useRouter } from '../../embed-shims/next-navigation';\nimport { FaqSection } from './faq-section';\n\nexport interface FaqDocumentPageProps {\n /** Page title (PageLayout TitleBlock). Default \"FAQs\". */\n title?: string;\n /** Subtitle under the title. */\n subtitle?: string;\n /** Back-button config — same pattern as `DevSectionPage` / `LegalDocumentPage`.\n * Pass `false` to hide. Default `{ label: 'Back to home', href: '/' }`. */\n backButton?: { label?: string; href?: string } | false;\n /** Base URL `FaqSection` appends `/api/faqs` to (reverse-proxy embedders). */\n apiBaseUrl?: string;\n /** Optional entity scoping forwarded to `FaqSection`. */\n entityType?: string;\n entityId?: number | string;\n /** Minimum FAQ count before the section renders (forwarded to `FaqSection`). */\n minResults?: number;\n}\n\nexport function FaqDocumentPage({\n title = 'FAQs',\n subtitle,\n backButton,\n apiBaseUrl,\n entityType,\n entityId,\n minResults,\n}: FaqDocumentPageProps) {\n const router = useRouter();\n\n // Back-button config — mirrors LegalDocumentPage/DevSectionPage. Hide entirely\n // when the caller passes `false` (embed-mode where the host owns nav chrome).\n const backCfg =\n backButton === false\n ? undefined\n : {\n label: backButton?.label ?? 'Back to home',\n onClick: () => router.push(backButton?.href ?? '/'),\n };\n\n return (\n <PageShell>\n <PageLayout title={title} subtitle={subtitle} backButton={backCfg}>\n <FaqSection\n heading={null}\n apiBaseUrl={apiBaseUrl}\n entityType={entityType}\n entityId={entityId}\n minResults={minResults}\n />\n </PageLayout>\n </PageShell>\n );\n}\n"]}
@@ -11,7 +11,7 @@ import {
11
11
  SelectValue,
12
12
  Textarea,
13
13
  useChatAttachments
14
- } from "./chunk-FSBDVT6R.js";
14
+ } from "./chunk-EFYXPR43.js";
15
15
  import {
16
16
  useContactSubmission,
17
17
  useHumanitySignals
@@ -376,4 +376,4 @@ function ContactForm({
376
376
  export {
377
377
  ContactForm
378
378
  };
379
- //# sourceMappingURL=chunk-5BTZOVDQ.js.map
379
+ //# sourceMappingURL=chunk-RWCA2ZQK.js.map
@@ -4,12 +4,15 @@ import {
4
4
  } from "./chunk-3ZXUQQL4.js";
5
5
  import {
6
6
  ChevronButton
7
- } from "./chunk-FSBDVT6R.js";
7
+ } from "./chunk-EFYXPR43.js";
8
8
  import {
9
9
  buildSuggestionUrl,
10
+ faqItemAnchor,
11
+ faqSectionSlug,
12
+ parseFaqHash,
10
13
  scrollElementIntoView,
11
14
  serializeJsonLd
12
- } from "./chunk-DDAT4RKX.js";
15
+ } from "./chunk-ODR6A6FC.js";
13
16
  import {
14
17
  PageLayout,
15
18
  PageShell
@@ -67,7 +70,8 @@ function FaqAccordion({ items, defaultOpenIds = [] }) {
67
70
  return /* @__PURE__ */ jsxs(
68
71
  "div",
69
72
  {
70
- className: cn("group transition-colors hover:bg-[#1E1E1E]", isOpen ? "bg-ods-bg" : "bg-transparent"),
73
+ id: faqItemAnchor(item.id),
74
+ className: cn("group scroll-mt-24 transition-colors hover:bg-[#1E1E1E]", isOpen ? "bg-ods-bg" : "bg-transparent"),
71
75
  children: [
72
76
  /* @__PURE__ */ jsxs(
73
77
  "div",
@@ -148,9 +152,6 @@ var DEFAULT_HEADING_TEXT = "Frequently Asked Questions";
148
152
  function buildFaqsUrl(entityType, entityId, minResults, apiBaseUrl = "") {
149
153
  return buildSuggestionUrl("/api/faqs", { apiBaseUrl, entityType, entityId, count: minResults });
150
154
  }
151
- function sectionSlug(section) {
152
- return "faq-" + section.toLowerCase().replace(/[^a-z0-9]+/g, "-").replace(/^-+|-+$/g, "");
153
- }
154
155
  function groupFaqsBySection(faqs) {
155
156
  const order = [];
156
157
  const byName = /* @__PURE__ */ new Map();
@@ -165,7 +166,7 @@ function groupFaqsBySection(faqs) {
165
166
  }
166
167
  let group = byName.get(name);
167
168
  if (!group) {
168
- group = { section: name, slug: sectionSlug(name), items: [] };
169
+ group = { section: name, slug: faqSectionSlug(name), items: [] };
169
170
  byName.set(name, group);
170
171
  order.push(name);
171
172
  }
@@ -176,6 +177,8 @@ function groupFaqsBySection(faqs) {
176
177
  return groups;
177
178
  }
178
179
  var FAQ_NAV_HEADER_OFFSET = 96;
180
+ var UNCATEGORIZED_KEY = "__uncategorized__";
181
+ var groupKey = (g) => g.slug ?? UNCATEGORIZED_KEY;
179
182
  function GroupedFaqList({
180
183
  groups,
181
184
  categoryHeadingAs
@@ -212,6 +215,31 @@ function GroupedFaqList({
212
215
  }
213
216
  return () => observer.disconnect();
214
217
  }, [slugKey]);
218
+ const [hashTarget, setHashTarget] = useState2(null);
219
+ useEffect2(() => {
220
+ const refresh = () => setHashTarget(parseFaqHash(window.location.hash));
221
+ refresh();
222
+ window.addEventListener("hashchange", refresh);
223
+ return () => window.removeEventListener("hashchange", refresh);
224
+ }, []);
225
+ const defaultOpenByGroupKey = useMemo(() => {
226
+ if (hashTarget?.kind !== "item") return null;
227
+ const targetId = hashTarget.rawId;
228
+ const result = /* @__PURE__ */ new Map();
229
+ for (const group of groups) {
230
+ const hit = group.items.find((i) => String(i.id) === targetId);
231
+ if (hit) result.set(groupKey(group), [hit.id]);
232
+ }
233
+ return result.size > 0 ? result : null;
234
+ }, [groups, hashTarget]);
235
+ const accordionKeySuffix = hashTarget?.kind === "item" ? `item:${hashTarget.rawId}` : "default";
236
+ useEffect2(() => {
237
+ if (!hashTarget) return;
238
+ const elId = hashTarget.kind === "item" ? faqItemAnchor(hashTarget.rawId) : hashTarget.slug;
239
+ const el = document.getElementById(elId);
240
+ if (el) scrollElementIntoView(el, { headerOffset: FAQ_NAV_HEADER_OFFSET });
241
+ if (hashTarget.kind === "section") setActiveSlug(hashTarget.slug);
242
+ }, [hashTarget]);
215
243
  const handleJump = useCallback2(
216
244
  (e, slug) => {
217
245
  e.preventDefault();
@@ -241,18 +269,28 @@ function GroupedFaqList({
241
269
  group.slug
242
270
  );
243
271
  }) }),
244
- /* @__PURE__ */ jsx2("div", { className: "space-y-10", children: groups.map((group) => /* @__PURE__ */ jsxs2(
245
- "section",
246
- {
247
- id: group.slug ?? void 0,
248
- className: "scroll-mt-24 space-y-4",
249
- children: [
250
- group.section && /* @__PURE__ */ jsx2(CategoryHeading, { className: SECTION_HEADING_CLASS, children: group.section }),
251
- /* @__PURE__ */ jsx2(FaqAccordion, { items: group.items })
252
- ]
253
- },
254
- group.slug ?? "faq-uncategorized"
255
- )) })
272
+ /* @__PURE__ */ jsx2("div", { className: "space-y-10", children: groups.map((group) => {
273
+ const key = groupKey(group);
274
+ return /* @__PURE__ */ jsxs2(
275
+ "section",
276
+ {
277
+ id: group.slug ?? void 0,
278
+ className: "scroll-mt-24 space-y-4",
279
+ children: [
280
+ group.section && /* @__PURE__ */ jsx2(CategoryHeading, { className: SECTION_HEADING_CLASS, children: group.section }),
281
+ /* @__PURE__ */ jsx2(
282
+ FaqAccordion,
283
+ {
284
+ items: group.items,
285
+ defaultOpenIds: defaultOpenByGroupKey?.get(key)
286
+ },
287
+ `${key}:${accordionKeySuffix}`
288
+ )
289
+ ]
290
+ },
291
+ key
292
+ );
293
+ }) })
256
294
  ] });
257
295
  }
258
296
  function FaqSkeleton() {
@@ -339,4 +377,4 @@ export {
339
377
  FaqSection,
340
378
  FaqDocumentPage
341
379
  };
342
- //# sourceMappingURL=chunk-QF2X6PTD.js.map
380
+ //# sourceMappingURL=chunk-TY2EB7VK.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/faq/faq-section.tsx","../src/components/faq-accordion.tsx","../src/components/faq/json-ld.ts","../src/components/faq/faq-document-page.tsx"],"sourcesContent":["\"use client\"\n\nimport React, { useCallback, useEffect, useMemo, useState } from 'react'\nimport type { Faq } from '../../types/faq'\nimport { FaqAccordion, type FaqItem } from '../faq-accordion'\nimport { useSelfFetch } from '../../hooks/use-self-fetch'\nimport { buildSuggestionUrl } from '../../utils/suggestion-url'\nimport { serializeJsonLd } from '../../utils/common'\nimport { scrollElementIntoView } from '../../utils/scroll-into-view'\nimport { faqSectionSlug, faqItemAnchor, parseFaqHash, type FaqHashTarget } from '../../utils/faq-anchor'\nimport { cn } from '../../utils/cn'\nimport { buildFaqJsonLdFromFaqs, type FaqSchemaOptions } from './json-ld'\nimport { SECTION_HEADING_CLASS } from '../layout/page-heading'\n\nexport interface FaqSectionProps {\n /**\n * SSR hydrate. When provided, the hook skips the first client fetch (per\n * useSelfFetch contract). The consuming server page resolves FAQs then drills\n * them into this prop — the lib never re-fetches what the host already gated on.\n */\n initialFaqs?: Faq[]\n /** Both required together for entity-attached FAQs; partial → bare /api/faqs. */\n entityType?: string\n entityId?: number | string\n /**\n * Heading node above the grouped list. `undefined` → default\n * `<h2>`\"Frequently Asked Questions\". `null` → no heading (the host page\n * owns the `<h1>`, as the standalone /faqs surface does). A React node lets a\n * platform drill its own <PageHeading> without the lib referencing platform\n * state. Also drives category nesting so the document outline stays correct:\n * `null` → categories render `<h2>` (directly under the page `<h1>`);\n * otherwise categories render `<h3>` beneath this heading.\n */\n heading?: React.ReactNode | null\n /** Inject FAQPage schema.org JSON-LD as a <script>. Off by default so embeds\n * don't emit duplicate schema. */\n emitJsonLd?: boolean\n /** Overrides for the JSON-LD's name/description/url. */\n jsonLd?: FaqSchemaOptions\n className?: string\n /** Maps to /api/faqs `?count=` (the 5-tier fill target). Absent → param\n * not sent (server default applies). */\n minResults?: number\n /** Fetch-URL prefix for third-party embeds / reverse proxies\n * ('' = same-origin relative). */\n apiBaseUrl?: string\n}\n\nconst DEFAULT_HEADING_TEXT = 'Frequently Asked Questions'\n\n/** URL composition shared with RelatedContentSection (`buildSuggestionUrl`)\n * — byte-identical to the historical `buildFaqsUrl` output when\n * `minResults`/`apiBaseUrl` are absent. */\nfunction buildFaqsUrl(\n entityType?: string,\n entityId?: number | string,\n minResults?: number,\n apiBaseUrl = '',\n): string {\n return buildSuggestionUrl('/api/faqs', { apiBaseUrl, entityType, entityId, count: minResults })\n}\n\ninterface FaqGroup {\n /** null → the uncategorized bucket: no heading, no jump pill, rendered last. */\n section: string | null\n slug: string | null\n items: FaqItem[]\n}\n\n/** Group FAQs by `faq.section`, preserving the server's first-seen\n * (display_order) order for BOTH the section order and the rows within each\n * section. The uncategorized bucket (blank/missing section) sinks to the end\n * since it renders without a heading. Items carry NO badge here — the `<h2>`\n * IS the category, so a per-row chip would be redundant. */\nfunction groupFaqsBySection(faqs: Faq[]): FaqGroup[] {\n const order: string[] = []\n const byName = new Map<string, FaqGroup>()\n let uncategorized: FaqGroup | null = null\n for (const faq of faqs) {\n const item: FaqItem = { id: faq.id, question: faq.question, answer: faq.answer }\n const name = faq.section?.trim()\n if (!name) {\n if (!uncategorized) uncategorized = { section: null, slug: null, items: [] }\n uncategorized.items.push(item)\n continue\n }\n let group = byName.get(name)\n if (!group) {\n group = { section: name, slug: faqSectionSlug(name), items: [] }\n byName.set(name, group)\n order.push(name)\n }\n group.items.push(item)\n }\n const groups = order.map((name) => byName.get(name)!)\n if (uncategorized) groups.push(uncategorized)\n return groups\n}\n\n/** The standard hub sticky-header height — same offset `useNavLink`'s hash\n * scroll uses, so a category jump lands below the header, not under it. */\nconst FAQ_NAV_HEADER_OFFSET = 96\n\n/** Map key for the uncategorized bucket — `group.slug` is null for it, so\n * every per-group map (default-open ids, accordion keys) uses this sentinel\n * to keep the lookup typed. */\nconst UNCATEGORIZED_KEY = '__uncategorized__'\nconst groupKey = (g: FaqGroup): string => g.slug ?? UNCATEGORIZED_KEY\n\n/**\n * Grouped FAQ layout: a category jump-nav above stacked `<h2>` category\n * sections (each its own accordion). Isolated into its own component so the\n * scroll-spy hooks only mount in grouped mode — `FaqSection`'s own hooks stay\n * unconditional.\n *\n * The pills are real `<a href=\"#slug\">` anchors (crawlable in-page links,\n * deep-linkable, work without JS); the click handler upgrades the jump to the\n * cancellation-proof `scrollElementIntoView` tween and syncs the URL hash.\n */\nfunction GroupedFaqList({\n groups,\n categoryHeadingAs,\n}: {\n groups: FaqGroup[]\n /** Heading tag for each category, so the document outline nests correctly\n * under whatever owns the heading above this block: `h2` on the standalone\n * page (the page owns the `<h1>`), `h3` beneath an embed's `<h2>` title.\n * The VISUAL is `SECTION_HEADING_CLASS` either way, so categories look\n * identical on every surface. */\n categoryHeadingAs: 'h2' | 'h3'\n}) {\n const CategoryHeading = categoryHeadingAs\n const navGroups = useMemo(() => groups.filter((g) => g.slug), [groups])\n const [activeSlug, setActiveSlug] = useState<string | null>(navGroups[0]?.slug ?? null)\n // Identity-stable key for the section set so the observer re-binds only when\n // the categories actually change (not on every parent re-render).\n const slugKey = navGroups.map((g) => g.slug).join('|')\n\n // Scroll-spy: mark the pill for the category currently at the top of the\n // viewport. rootMargin drops the trigger line just below the sticky header\n // and ignores the bottom ~55% so \"active\" is the section being read, not the\n // next one peeking in.\n useEffect(() => {\n if (navGroups.length < 2) return\n const tops = new Map<string, number>()\n const observer = new IntersectionObserver(\n (entries) => {\n for (const entry of entries) {\n const id = (entry.target as HTMLElement).id\n if (entry.isIntersecting) tops.set(id, entry.boundingClientRect.top)\n else tops.delete(id)\n }\n let bestId: string | null = null\n let bestTop = Number.POSITIVE_INFINITY\n for (const [id, top] of tops) {\n if (top < bestTop) {\n bestTop = top\n bestId = id\n }\n }\n if (bestId) setActiveSlug(bestId)\n },\n { rootMargin: `-${FAQ_NAV_HEADER_OFFSET}px 0px -55% 0px`, threshold: 0 },\n )\n for (const group of navGroups) {\n const el = group.slug ? document.getElementById(group.slug) : null\n if (el) observer.observe(el)\n }\n return () => observer.disconnect()\n // slugKey encodes the section set; re-observe only when it changes.\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [slugKey])\n\n // ─── Hash dispatch — `/faqs#faq-item-<id>` or `/faqs#faq-<section-slug>` ──\n // Tracks the current hash so:\n // 1. an item-kind hash seeds `defaultOpenIds` on the matching accordion\n // (auto-expands the cited question);\n // 2. either kind triggers the cancellation-proof tween scroll with the\n // sticky-header offset (native browser hash scroll runs once, ignores\n // our offset — re-running the tween puts the target in the right spot).\n // Listens to `hashchange` so back/forward replays the same behavior. SSR-\n // safe: initial null state matches the server render; the first effect\n // tick on the client updates it.\n const [hashTarget, setHashTarget] = useState<FaqHashTarget | null>(null)\n useEffect(() => {\n const refresh = () => setHashTarget(parseFaqHash(window.location.hash))\n refresh()\n window.addEventListener('hashchange', refresh)\n return () => window.removeEventListener('hashchange', refresh)\n }, [])\n\n // Per-group default-open set when the hash points at an item. The map key\n // matches `groupKey(group)` so the render-time lookup is O(1) per group.\n const defaultOpenByGroupKey = useMemo(() => {\n if (hashTarget?.kind !== 'item') return null\n const targetId = hashTarget.rawId\n const result = new Map<string, (string | number)[]>()\n for (const group of groups) {\n const hit = group.items.find((i) => String(i.id) === targetId)\n if (hit) result.set(groupKey(group), [hit.id])\n }\n return result.size > 0 ? result : null\n }, [groups, hashTarget])\n\n // Accordion is uncontrolled — `defaultOpenIds` is only consumed at mount,\n // so a new item hash needs a remount to honor it. Keying off the item-id\n // suffix triggers exactly the remount we need (and stays stable when the\n // hash points at a section, so category navigation never disturbs the\n // accordion's open state).\n const accordionKeySuffix =\n hashTarget?.kind === 'item' ? `item:${hashTarget.rawId}` : 'default'\n\n useEffect(() => {\n if (!hashTarget) return\n const elId =\n hashTarget.kind === 'item' ? faqItemAnchor(hashTarget.rawId) : hashTarget.slug\n const el = document.getElementById(elId)\n if (el) scrollElementIntoView(el, { headerOffset: FAQ_NAV_HEADER_OFFSET })\n if (hashTarget.kind === 'section') setActiveSlug(hashTarget.slug)\n }, [hashTarget])\n\n const handleJump = useCallback(\n (e: React.MouseEvent<HTMLAnchorElement>, slug: string) => {\n e.preventDefault()\n setActiveSlug(slug)\n scrollElementIntoView(document.getElementById(slug), {\n headerOffset: FAQ_NAV_HEADER_OFFSET,\n })\n if (typeof history !== 'undefined') history.replaceState(null, '', `#${slug}`)\n },\n [],\n )\n\n return (\n <div className=\"space-y-8\">\n {navGroups.length > 1 && (\n <nav aria-label=\"FAQ categories\" className=\"flex flex-wrap gap-2\">\n {navGroups.map((group) => {\n const isActive = group.slug === activeSlug\n return (\n <a\n key={group.slug}\n href={`#${group.slug}`}\n aria-current={isActive ? 'true' : undefined}\n onClick={(e) => handleJump(e, group.slug as string)}\n className={cn(\n \"rounded-full border px-4 py-2 text-sm font-medium font-['DM_Sans'] transition-colors\",\n isActive\n ? 'border-ods-text-primary bg-ods-card text-ods-text-primary'\n : 'border-ods-border bg-ods-card text-ods-text-secondary hover:border-ods-text-secondary hover:text-ods-text-primary',\n )}\n >\n {group.section}\n </a>\n )\n })}\n </nav>\n )}\n <div className=\"space-y-10\">\n {groups.map((group) => {\n const key = groupKey(group)\n return (\n <section\n key={key}\n id={group.slug ?? undefined}\n className=\"scroll-mt-24 space-y-4\"\n >\n {group.section && (\n <CategoryHeading className={SECTION_HEADING_CLASS}>{group.section}</CategoryHeading>\n )}\n <FaqAccordion\n // Re-key on item-hash changes so the remount picks up the new\n // `defaultOpenIds` (the accordion is uncontrolled). Stable for\n // section hashes — category navigation doesn't disturb state.\n key={`${key}:${accordionKeySuffix}`}\n items={group.items}\n defaultOpenIds={defaultOpenByGroupKey?.get(key)}\n />\n </section>\n )\n })}\n </div>\n </div>\n )\n}\n\nfunction FaqSkeleton() {\n return (\n <div className=\"space-y-8 animate-pulse\">\n <div className=\"h-12 md:h-14 w-2/3 rounded bg-ods-border\" />\n <div className=\"rounded-3xl border border-ods-border overflow-hidden bg-ods-card divide-y divide-ods-border w-full\">\n {Array.from({ length: 8 }).map((_, idx) => (\n <div key={idx} className=\"flex items-center justify-between px-6 md:px-8 py-6\">\n <div className=\"h-6 w-5/6 rounded bg-ods-border\" />\n <div className=\"h-10 w-10 rounded-md bg-ods-border\" />\n </div>\n ))}\n </div>\n </div>\n )\n}\n\ninterface FaqsResponse {\n faqs: Faq[]\n}\n\n/**\n * The FAQ display surface — ONE rendering on every host: the list grouped by\n * `faq.section` (each category a heading + its own accordion, with a category\n * jump-nav once there are 2+ categories). There is no flat/ungrouped mode and\n * no page-vs-embedded shell fork; the standalone /faqs page and every embed\n * render through this single path, so they cannot drift.\n *\n * - Standalone /faqs page: pass `initialFaqs` (SSR) + `heading={null}` (the\n * page owns the <h1>) + `emitJsonLd` with `jsonLd` overrides for SEO.\n * - Per-entity embed: pass `entityType` + `entityId` (no `initialFaqs`); the\n * hook self-fetches `GET /api/faqs`, and `heading` is this block's own <h2>.\n *\n * CONTRACT: the consuming app MUST implement `GET /api/faqs`. On a fetch error\n * (or zero FAQs) the component renders nothing so the host page isn't\n * disfigured. The host always supplies the page shell — this renders a bare\n * <section>.\n */\nexport function FaqSection({\n initialFaqs,\n entityType,\n entityId,\n heading,\n emitJsonLd = false,\n jsonLd,\n className,\n minResults,\n apiBaseUrl = '',\n}: FaqSectionProps) {\n const url = buildFaqsUrl(entityType, entityId, minResults, apiBaseUrl)\n // Memoized — useSelfFetch re-syncs on [initialData]; a fresh per-render\n // wrapper object would setState-loop under re-rendering parents.\n const initialData = useMemo<FaqsResponse | undefined>(\n () => (initialFaqs ? { faqs: initialFaqs } : undefined),\n [initialFaqs],\n )\n const { data, isLoading, error } = useSelfFetch<FaqsResponse>(url, { initialData })\n\n const faqs = data?.faqs ?? []\n // Grouped before the early returns so the hook order stays stable.\n const groups = useMemo(() => (faqs.length > 0 ? groupFaqsBySection(faqs) : []), [faqs])\n\n // `undefined` → default <h2> title; `null` → the host page owns the <h1>, so\n // no title renders here. `heading === null` also makes the category headings\n // <h2> (directly under the page <h1>); otherwise they nest as <h3>.\n const headingNode =\n heading === undefined ? <h2 className={SECTION_HEADING_CLASS}>{DEFAULT_HEADING_TEXT}</h2> : heading\n\n // Degrade silently — never show an error banner or an empty section shell\n // where FAQs would be (host pages and the standalone surface both rely on it).\n if (error) return null\n if (!isLoading && faqs.length === 0) return null\n if (isLoading && faqs.length === 0) {\n return (\n <div className={className}>\n <FaqSkeleton />\n </div>\n )\n }\n\n const schema = emitJsonLd ? buildFaqJsonLdFromFaqs(faqs, jsonLd) : null\n\n return (\n <>\n <section className={className ?? 'space-y-10'}>\n {headingNode}\n <GroupedFaqList groups={groups} categoryHeadingAs={heading === null ? 'h2' : 'h3'} />\n </section>\n {schema && (\n <script\n type=\"application/ld+json\"\n // eslint-disable-next-line react/no-danger\n // serializeJsonLd, NOT raw JSON.stringify — FAQ answers are\n // admin-entered; an embedded \"</script>\" must not break the tag.\n dangerouslySetInnerHTML={{ __html: serializeJsonLd(schema) }}\n />\n )}\n </>\n )\n}\n","\"use client\"\n\nimport React, { useRef, useState, useEffect, useCallback } from 'react'\nimport { ChevronButton } from './ui/chevron-button'\nimport { cn } from \"../utils/cn\"\nimport { faqItemAnchor } from \"../utils/faq-anchor\"\n\nexport interface FaqItem {\n id: number | string\n question: string\n answer: string\n}\n\ninterface FaqAccordionProps {\n items: FaqItem[]\n defaultOpenIds?: (number | string)[]\n}\n\n// Utility to measure scrollHeight outside render cycle\nconst useMeasuredHeight = (isOpen: boolean) => {\n const ref = useRef<HTMLDivElement | null>(null)\n const [maxHeight, setMaxHeight] = useState<string>('0px')\n\n const measure = useCallback(() => {\n if (ref.current) {\n const height = ref.current.scrollHeight\n setMaxHeight(`${height}px`)\n }\n }, [])\n\n // Update height only when section is open\n useEffect(() => {\n if (isOpen) {\n measure()\n } else {\n setMaxHeight('0px')\n }\n }, [isOpen, measure])\n\n return { ref, maxHeight }\n}\n\nexport function FaqAccordion({ items, defaultOpenIds = [] }: FaqAccordionProps) {\n const [openSet, setOpenSet] = useState<Set<string | number>>(new Set(defaultOpenIds))\n\n const toggle = (id: string | number) => {\n setOpenSet(prev => {\n const next = new Set(prev)\n if (next.has(id)) next.delete(id)\n else next.add(id)\n return next\n })\n }\n\n return (\n <div className=\"rounded-3xl border border-ods-border divide-y divide-ods-border bg-ods-card overflow-hidden\">\n {items.map(item => {\n const isOpen = openSet.has(item.id)\n const { ref, maxHeight } = useMeasuredHeight(isOpen)\n\n return (\n <div\n key={item.id}\n // Per-row anchor — chat citation chips (`/faqs#faq-item-<id>`) land\n // here via native browser hash scroll AND via `FaqSection`'s tween\n // dispatch. `scroll-mt-24` keeps the row header below the 96px\n // sticky nav offset (matches `<section>`'s scroll-margin for\n // category anchors).\n id={faqItemAnchor(item.id)}\n className={cn('group scroll-mt-24 transition-colors hover:bg-[#1E1E1E]', isOpen ? 'bg-ods-bg' : 'bg-transparent')}\n >\n {/* Header */}\n <div\n role=\"button\"\n tabIndex={0}\n onClick={() => toggle(item.id)}\n onKeyDown={(e) => {\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault();\n toggle(item.id);\n }\n }}\n aria-expanded={isOpen}\n className=\"flex w-full items-center justify-between px-6 md:px-8 py-6 text-left focus:outline-none transition-colors cursor-pointer\"\n >\n <div className=\"min-w-0 pr-4\">\n <h3>\n {item.question}\n </h3>\n </div>\n <div className=\"flex-shrink-0\">\n <ChevronButton\n aria-label={isOpen ? 'Collapse question' : 'Expand question'}\n size=\"md\"\n isExpanded={isOpen}\n backgroundColor=\"transparent\"\n borderColor=\"#3A3A3A\"\n />\n </div>\n </div>\n {/* Content wrapper with max-height animation */}\n <div\n style={{ maxHeight, transition: 'max-height 0.35s ease-in-out, opacity 0.35s ease-in-out', opacity: isOpen ? 1 : 0 }}\n className=\"overflow-hidden group-hover:bg-[#1E1E1E]/30\"\n >\n <div ref={ref} className=\"px-6 md:px-8 pb-6 text-ods-text-primary text-h4\">\n {item.answer}\n </div>\n </div>\n </div>\n )\n })}\n </div>\n )\n} ","/**\n * Pure FAQ JSON-LD builder. No React, no client-only deps — safe to import from\n * Server Components via the `./components/faq` subpath export. (Do NOT import\n * through the root `./components` barrel — that barrel is `\"use client\"` and\n * dragging it into a Server Component would force the client graph into the\n * server.)\n *\n * The hub used to harcode `name`/`description` here for OpenMSP; in the lib we\n * accept overrides so every embedder can supply its own platform branding.\n */\nimport type { Faq } from '../../types/faq'\n\nexport interface FaqSchemaOptions {\n name?: string\n description?: string\n url?: string\n}\n\nconst DEFAULT_NAME = 'Frequently Asked Questions'\nconst DEFAULT_DESCRIPTION =\n 'Answers to common questions.'\n\nexport function baseFaqSchema(opts: FaqSchemaOptions = {}) {\n return {\n '@context': 'https://schema.org',\n '@type': 'FAQPage',\n name: opts.name ?? DEFAULT_NAME,\n description: opts.description ?? DEFAULT_DESCRIPTION,\n ...(opts.url ? { url: opts.url } : {}),\n } as const\n}\n\nexport function buildFaqJsonLdFromFaqs(faqs: Faq[], opts: FaqSchemaOptions = {}) {\n return {\n ...baseFaqSchema(opts),\n mainEntity: faqs.map((faq) => ({\n '@type': 'Question',\n name: faq.question,\n acceptedAnswer: {\n '@type': 'Answer',\n text: faq.answer,\n },\n })),\n } as const\n}\n","'use client';\n\n/**\n * FaqDocumentPage — the full `/faqs` page with chrome, so embedders drop in\n * ONE component instead of hand-assembling `PageShell` + `PageLayout` around the\n * bare `<FaqSection>`. Mirrors `LegalDocumentPage` / `DevSectionPage`: the\n * page-level layout lives in the lib, the host passes only config + a back button.\n *\n * `<FaqSection heading={null}>` lets `PageLayout`'s `TitleBlock` own the heading +\n * back button; it self-fetches `${apiBaseUrl}/api/faqs` via the authed\n * `useSelfFetch`, and renders nothing on a fetch error or zero FAQs.\n */\n\nimport { PageShell, PageLayout } from '../ui';\nimport { useRouter } from '../../embed-shims/next-navigation';\nimport { FaqSection } from './faq-section';\n\nexport interface FaqDocumentPageProps {\n /** Page title (PageLayout TitleBlock). Default \"FAQs\". */\n title?: string;\n /** Subtitle under the title. */\n subtitle?: string;\n /** Back-button config — same pattern as `DevSectionPage` / `LegalDocumentPage`.\n * Pass `false` to hide. Default `{ label: 'Back to home', href: '/' }`. */\n backButton?: { label?: string; href?: string } | false;\n /** Base URL `FaqSection` appends `/api/faqs` to (reverse-proxy embedders). */\n apiBaseUrl?: string;\n /** Optional entity scoping forwarded to `FaqSection`. */\n entityType?: string;\n entityId?: number | string;\n /** Minimum FAQ count before the section renders (forwarded to `FaqSection`). */\n minResults?: number;\n}\n\nexport function FaqDocumentPage({\n title = 'FAQs',\n subtitle,\n backButton,\n apiBaseUrl,\n entityType,\n entityId,\n minResults,\n}: FaqDocumentPageProps) {\n const router = useRouter();\n\n // Back-button config — mirrors LegalDocumentPage/DevSectionPage. Hide entirely\n // when the caller passes `false` (embed-mode where the host owns nav chrome).\n const backCfg =\n backButton === false\n ? undefined\n : {\n label: backButton?.label ?? 'Back to home',\n onClick: () => router.push(backButton?.href ?? '/'),\n };\n\n return (\n <PageShell>\n <PageLayout title={title} subtitle={subtitle} backButton={backCfg}>\n <FaqSection\n heading={null}\n apiBaseUrl={apiBaseUrl}\n entityType={entityType}\n entityId={entityId}\n minResults={minResults}\n />\n </PageLayout>\n </PageShell>\n );\n}\n"],"mappings":"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","names":["useCallback","useEffect","useState","jsx","jsxs","useState","useEffect","useCallback","jsx"]}
@@ -22,7 +22,7 @@ import {
22
22
  WhatIShippedCardSkeleton,
23
23
  buildProductReleaseCardProps,
24
24
  init_pagination
25
- } from "./chunk-FSBDVT6R.js";
25
+ } from "./chunk-EFYXPR43.js";
26
26
  import {
27
27
  CONTENT_REF_GROUPS,
28
28
  buildListUrl,
@@ -32,7 +32,7 @@ import {
32
32
  extractItems,
33
33
  getContentRefLabelOrTitleCase,
34
34
  orderContentRefTypes
35
- } from "./chunk-DDAT4RKX.js";
35
+ } from "./chunk-ODR6A6FC.js";
36
36
  import {
37
37
  OnboardingGuideCard,
38
38
  OnboardingGuideCardSkeleton
@@ -365,4 +365,4 @@ export {
365
365
  GROUP_PAGE_SIZE,
366
366
  RelatedContentSection
367
367
  };
368
- //# sourceMappingURL=chunk-VCQ3CTYK.js.map
368
+ //# sourceMappingURL=chunk-ZYLQMCHW.js.map
@@ -170,7 +170,7 @@
170
170
 
171
171
 
172
172
 
173
- var _chunkGDF2R2ERcjs = require('../../chunk-GDF2R2ER.cjs');
173
+ var _chunkOXC72UIPcjs = require('../../chunk-OXC72UIP.cjs');
174
174
 
175
175
 
176
176
 
@@ -197,7 +197,7 @@ var _chunkGDF2R2ERcjs = require('../../chunk-GDF2R2ER.cjs');
197
197
 
198
198
 
199
199
 
200
- var _chunk6N26CURScjs = require('../../chunk-6N26CURS.cjs');
200
+ var _chunkD6RK5YXXcjs = require('../../chunk-D6RK5YXX.cjs');
201
201
  require('../../chunk-KBKZYJRI.cjs');
202
202
  require('../../chunk-5KD3S25X.cjs');
203
203
  require('../../chunk-27APPAJN.cjs');
@@ -516,5 +516,5 @@ require('../../chunk-VRHGVLSL.cjs');
516
516
 
517
517
 
518
518
 
519
- exports.ANTHROPIC_SUPPORTED_IMAGE_MIME = _chunk6N26CURScjs.ANTHROPIC_SUPPORTED_IMAGE_MIME; exports.APPROVAL_STATUS = _chunkGDF2R2ERcjs.APPROVAL_STATUS; exports.ASSISTANT_TYPE = _chunkGDF2R2ERcjs.ASSISTANT_TYPE; exports.AUTHOR_TYPE = _chunkGDF2R2ERcjs.AUTHOR_TYPE; exports.AUTO_CONTINUATION_DIRECTIVE_PREFIX = _chunk6N26CURScjs.AUTO_CONTINUATION_DIRECTIVE_PREFIX; exports.AdminContentCard = _chunkGDF2R2ERcjs.AdminContentCard; exports.ApprovalBatchMessage = _chunkGDF2R2ERcjs.ApprovalBatchMessage; exports.ApprovalRequestMessage = _chunkGDF2R2ERcjs.ApprovalRequestMessage; exports.ArchiveChatModal = _chunkGDF2R2ERcjs.ArchiveChatModal; exports.ArgRow = _chunkGDF2R2ERcjs.ArgRow; exports.BlockCard = _chunkGDF2R2ERcjs.BlockCard; exports.BlogCard = _chunkGDF2R2ERcjs.BlogCard; exports.BlogCardSkeleton = _chunkGDF2R2ERcjs.BlogCardSkeleton; exports.BlogImagePlaceholder = _chunkEI4WALN2cjs.BlogImagePlaceholder; exports.CHAT_ATTACHMENT_CONCURRENT_UPLOADS_PER_USER = _chunkGDF2R2ERcjs.CHAT_ATTACHMENT_CONCURRENT_UPLOADS_PER_USER; exports.CHAT_ATTACHMENT_MARKDOWN_PATTERN = _chunk6N26CURScjs.CHAT_ATTACHMENT_MARKDOWN_PATTERN; exports.CHAT_ATTACHMENT_MIME_TYPES = _chunkGDF2R2ERcjs.CHAT_ATTACHMENT_MIME_TYPES; exports.CHAT_ATTACHMENT_VIEW_TOKEN_QUERY_PARAM = _chunk6N26CURScjs.CHAT_ATTACHMENT_VIEW_TOKEN_QUERY_PARAM; exports.CHAT_ATTACHMENT_VIEW_URL_PREFIX = _chunk6N26CURScjs.CHAT_ATTACHMENT_VIEW_URL_PREFIX; exports.CHAT_ATTACHMENT_VIEW_URL_PREFIX_REGEX_ESCAPED = _chunk6N26CURScjs.CHAT_ATTACHMENT_VIEW_URL_PREFIX_REGEX_ESCAPED; exports.CHAT_CONTEXT_ITEMS_DEFAULT_MAX = _chunkGDF2R2ERcjs.CHAT_CONTEXT_ITEMS_DEFAULT_MAX; exports.CHAT_TYPE = _chunkGDF2R2ERcjs.CHAT_TYPE; exports.CHIP_ACTION_BUTTON_CLASS = _chunkGDF2R2ERcjs.CHIP_ACTION_BUTTON_CLASS; exports.COMPACT_CARD_ICON_SLOT = _chunkY4JNA4W6cjs.COMPACT_CARD_ICON_SLOT; exports.COMPACT_CARD_IMAGE_SLOT = _chunkY4JNA4W6cjs.COMPACT_CARD_IMAGE_SLOT; exports.COMPACT_CARD_META_ROW = _chunkY4JNA4W6cjs.COMPACT_CARD_META_ROW; exports.COMPACT_CARD_META_ROW_BOX = _chunkY4JNA4W6cjs.COMPACT_CARD_META_ROW_BOX; exports.COMPACT_CARD_OUTER = _chunkY4JNA4W6cjs.COMPACT_CARD_OUTER; exports.COMPACT_CARD_OUTER_STATIC = _chunkY4JNA4W6cjs.COMPACT_CARD_OUTER_STATIC; exports.COMPACT_CARD_ROW_FILLER = _chunkY4JNA4W6cjs.COMPACT_CARD_ROW_FILLER; exports.COMPACT_CARD_SKELETON_IMAGE_SLOT = _chunkY4JNA4W6cjs.COMPACT_CARD_SKELETON_IMAGE_SLOT; exports.COMPACT_CARD_SKELETON_OUTER = _chunkY4JNA4W6cjs.COMPACT_CARD_SKELETON_OUTER; exports.COMPACT_CARD_SUBTITLE = _chunkY4JNA4W6cjs.COMPACT_CARD_SUBTITLE; exports.COMPACT_CARD_SUMMARY = _chunkY4JNA4W6cjs.COMPACT_CARD_SUMMARY; exports.COMPACT_CARD_TEXT_COL = _chunkY4JNA4W6cjs.COMPACT_CARD_TEXT_COL; exports.COMPACT_CARD_TITLE = _chunkY4JNA4W6cjs.COMPACT_CARD_TITLE; exports.COMPACT_CARD_TITLE_ROW = _chunkY4JNA4W6cjs.COMPACT_CARD_TITLE_ROW; exports.COMPACT_HEADER_BUTTON = _chunkGDF2R2ERcjs.COMPACT_HEADER_BUTTON; exports.CONNECTION_STATUS = _chunkGDF2R2ERcjs.CONNECTION_STATUS; exports.CONTEXT_BACK_CLASS = _chunkGDF2R2ERcjs.CONTEXT_BACK_CLASS; exports.CONTEXT_ICON_CLASS = _chunkGDF2R2ERcjs.CONTEXT_ICON_CLASS; exports.CONTEXT_LABEL_CLASS = _chunkGDF2R2ERcjs.CONTEXT_LABEL_CLASS; exports.CONTEXT_ROW_CLASS = _chunkGDF2R2ERcjs.CONTEXT_ROW_CLASS; exports.CONTEXT_STATE_CLASS = _chunkGDF2R2ERcjs.CONTEXT_STATE_CLASS; exports.CUSTOM_ITEM_ID = _chunk6N26CURScjs.CUSTOM_ITEM_ID; exports.CampaignCardAdmin = _chunkGDF2R2ERcjs.CampaignCardAdmin; exports.CampaignCardAdminSkeleton = _chunkGDF2R2ERcjs.CampaignCardAdminSkeleton; exports.CaseStudyCard = _chunkGDF2R2ERcjs.CaseStudyCard; exports.CaseStudyCardSkeleton = _chunkGDF2R2ERcjs.CaseStudyCardSkeleton; exports.ChatArchivePage = _chunkGDF2R2ERcjs.ChatArchivePage; exports.ChatAttachmentAddButton = _chunkGDF2R2ERcjs.ChatAttachmentAddButton; exports.ChatAttachmentChipStrip = _chunkGDF2R2ERcjs.ChatAttachmentChipStrip; exports.ChatCardLoader = _chunkGDF2R2ERcjs.ChatCardLoader; exports.ChatComposer = _chunkGDF2R2ERcjs.ChatComposer; exports.ChatComposerPlusMenu = _chunkGDF2R2ERcjs.ChatComposerPlusMenu; exports.ChatContainer = _chunkGDF2R2ERcjs.ChatContainer; exports.ChatContent = _chunkGDF2R2ERcjs.ChatContent; exports.ChatContextChipStrip = _chunkGDF2R2ERcjs.ChatContextChipStrip; exports.ChatContextPicker = _chunkGDF2R2ERcjs.ChatContextPicker; exports.ChatDialogModals = _chunkGDF2R2ERcjs.ChatDialogModals; exports.ChatFooter = _chunkGDF2R2ERcjs.ChatFooter; exports.ChatHeader = _chunkGDF2R2ERcjs.ChatHeader; exports.ChatHeaderIconButton = _chunkGDF2R2ERcjs.ChatHeaderIconButton; exports.ChatIdentityProvider = _chunkGDF2R2ERcjs.ChatIdentityProvider; exports.ChatInput = _chunkGDF2R2ERcjs.ChatInput; exports.ChatMessageEnhanced = _chunkGDF2R2ERcjs.MemoizedChatMessageEnhanced; exports.ChatMessageList = _chunkGDF2R2ERcjs.ChatMessageList; exports.ChatMessageListSkeleton = _chunkGDF2R2ERcjs.ChatMessageListSkeleton; exports.ChatMessageRow = _chunkGDF2R2ERcjs.ChatMessageRow; exports.ChatMessageRowSkeleton = _chunkGDF2R2ERcjs.ChatMessageRowSkeleton; exports.ChatMessageSkeleton = _chunkGDF2R2ERcjs.ChatMessageSkeleton; exports.ChatPanelHeader = _chunkGDF2R2ERcjs.ChatPanelHeader; exports.ChatQuickAction = _chunkGDF2R2ERcjs.ChatQuickAction; exports.ChatQuickActionRow = _chunkGDF2R2ERcjs.ChatQuickActionRow; exports.ChatQuickActionRowSkeleton = _chunkGDF2R2ERcjs.ChatQuickActionRowSkeleton; exports.ChatSidebar = _chunkGDF2R2ERcjs.ChatSidebar; exports.ChatTicketItem = _chunkGDF2R2ERcjs.ChatTicketItem; exports.ChatTicketList = _chunkGDF2R2ERcjs.ChatTicketList; exports.ChatTypingIndicator = _chunkGDF2R2ERcjs.ChatTypingIndicator; exports.ChatVideoEntityCard = _chunkGDF2R2ERcjs.ChatVideoEntityCard; exports.ContextCompactionDisplay = _chunkGDF2R2ERcjs.ContextCompactionDisplay; exports.ContextErrorBoundary = _chunkGDF2R2ERcjs.ContextErrorBoundary; exports.ContextItemsList = _chunkGDF2R2ERcjs.ContextItemsList; exports.ContextItemsSkeleton = _chunkGDF2R2ERcjs.ContextItemsSkeleton; exports.ContextMenuRow = _chunkGDF2R2ERcjs.ContextMenuRow; exports.CustomerInterviewCard = _chunkGDF2R2ERcjs.CustomerInterviewCard; exports.CustomerInterviewCardSkeleton = _chunkGDF2R2ERcjs.CustomerInterviewCardSkeleton; exports.DEFAULT_DOCUMENT_TYPE_TO_TABLE_ID = _chunkY4JNA4W6cjs.DEFAULT_DOCUMENT_TYPE_TO_TABLE_ID; exports.DataRoomDocCard = _chunkGDF2R2ERcjs.DataRoomDocCard; exports.DataRoomDocCardSkeleton = _chunkGDF2R2ERcjs.DataRoomDocCardSkeleton; exports.DialogListItem = _chunkGDF2R2ERcjs.DialogListItem; exports.EMPTY_AUTHOR_PLACEHOLDER = _chunkEI4WALN2cjs.EMPTY_AUTHOR_PLACEHOLDER; exports.EmbeddableChat = _chunkGDF2R2ERcjs.EmbeddableChat; exports.EntityAuthorCard = _chunkEI4WALN2cjs.EntityAuthorCard; exports.EntityMetadataAuthorCell = _chunkEI4WALN2cjs.EntityMetadataAuthorCell; exports.EntityMetadataValueCell = _chunkEI4WALN2cjs.EntityMetadataValueCell; exports.ErrorMessageDisplay = _chunkGDF2R2ERcjs.ErrorMessageDisplay; exports.ExpandChevron = _chunkGDF2R2ERcjs.ExpandChevron; exports.GenericEntityCard = _chunkGDF2R2ERcjs.GenericEntityCard; exports.GenericEntityCardSkeleton = _chunkGDF2R2ERcjs.GenericEntityCardSkeleton; exports.GitHubActivityCard = _chunkGDF2R2ERcjs.GitHubActivityCard; exports.GitHubActivityCardSkeleton = _chunkGDF2R2ERcjs.GitHubActivityCardSkeleton; exports.GuideModeBanner = _chunkGDF2R2ERcjs.GuideModeBanner; exports.GuideWelcome = _chunkGDF2R2ERcjs.GuideWelcome; exports.HubspotTicketCard = _chunkGDF2R2ERcjs.HubspotTicketCard; exports.HubspotTicketCardSkeleton = _chunkGDF2R2ERcjs.HubspotTicketCardSkeleton; exports.ICON_REGISTRY = _chunkY4JNA4W6cjs.ICON_REGISTRY; exports.InvestorUpdateCard = _chunkGDF2R2ERcjs.InvestorUpdateCard; exports.InvestorUpdateCardSkeleton = _chunkGDF2R2ERcjs.InvestorUpdateCardSkeleton; exports.MESSAGE_ROLE = _chunkGDF2R2ERcjs.MESSAGE_ROLE; exports.MESSAGE_TYPE = _chunk6N26CURScjs.MESSAGE_TYPE; exports.MessageSegmentAccumulator = _chunkGDF2R2ERcjs.MessageSegmentAccumulator; exports.MingoChatHistory = _chunkGDF2R2ERcjs.MingoChatHistory; exports.MingoChatHistorySkeleton = _chunkGDF2R2ERcjs.MingoChatHistorySkeleton; exports.MingoOnboardingCard = _chunkGDF2R2ERcjs.MingoOnboardingCard; exports.MingoOnboardingCardSkeleton = _chunkGDF2R2ERcjs.MingoOnboardingCardSkeleton; exports.MingoOnboardingListSkeleton = _chunkGDF2R2ERcjs.MingoOnboardingListSkeleton; exports.MingoWelcome = _chunkGDF2R2ERcjs.MingoWelcome; exports.ModelDisplay = _chunkGDF2R2ERcjs.ModelDisplay; exports.ModelDisplaySkeleton = _chunkGDF2R2ERcjs.ModelDisplaySkeleton; exports.NETWORK_CONFIG = _chunkGDF2R2ERcjs.NETWORK_CONFIG; exports.NEW_TAB_FEATURES = _chunkY4JNA4W6cjs.NEW_TAB_FEATURES; exports.NavLinkAnchorViaRuntime = _chunkGDF2R2ERcjs.NavLinkAnchorViaRuntime; exports.ONBOARDING_ICONS = _chunkGDF2R2ERcjs.ONBOARDING_ICONS; exports.ONBOARDING_ICON_OPTIONS = _chunkGDF2R2ERcjs.ONBOARDING_ICON_OPTIONS; exports.OWNER_TYPE = _chunkGDF2R2ERcjs.OWNER_TYPE; exports.OnboardingGuideCard = _chunkEI4WALN2cjs.OnboardingGuideCard; exports.OnboardingGuideCardSkeleton = _chunkEI4WALN2cjs.OnboardingGuideCardSkeleton; exports.ProductReleaseCard = _chunkGDF2R2ERcjs.ProductReleaseCard; exports.ProductReleaseCardSkeleton = _chunkGDF2R2ERcjs.ProductReleaseCardSkeleton; exports.ProgramCard = _chunkGDF2R2ERcjs.ProgramCard; exports.ProgramCardSkeleton = _chunkGDF2R2ERcjs.ProgramCardSkeleton; exports.RenameChatModal = _chunkGDF2R2ERcjs.RenameChatModal; exports.ResultBlock = _chunkGDF2R2ERcjs.ResultBlock; exports.RoadmapCard = _chunkGDF2R2ERcjs.RoadmapCard; exports.RoadmapCardSkeleton = _chunkGDF2R2ERcjs.RoadmapCardSkeleton; exports.RoadmapVoteButton = _chunkGDF2R2ERcjs.RoadmapVoteButton; exports.SCROLL_ANCHOR = _chunk6N26CURScjs.SCROLL_ANCHOR; exports.SCROLL_ANCHOR_WIRE_KEY = _chunk6N26CURScjs.SCROLL_ANCHOR_WIRE_KEY; exports.SOURCE_ICON_NAMES = _chunkY4JNA4W6cjs.SOURCE_ICON_NAMES; exports.SOURCE_LABELS_BY_TABLE = _chunkY4JNA4W6cjs.SOURCE_LABELS_BY_TABLE; exports.SYNTHETIC_REALTIME_ID_PREFIXES = _chunkGDF2R2ERcjs.SYNTHETIC_REALTIME_ID_PREFIXES; exports.SlackMessageCard = _chunkGDF2R2ERcjs.SlackMessageCard; exports.SlackMessageCardSkeleton = _chunkGDF2R2ERcjs.SlackMessageCardSkeleton; exports.SlashCommandSuggestions = _chunkGDF2R2ERcjs.SlashCommandSuggestions; exports.SourceActionButton = _chunkGDF2R2ERcjs.SourceActionButton; exports.TaskTypeIcon = _chunkGDF2R2ERcjs.TaskTypeIcon; exports.ThinkingDisplay = _chunkGDF2R2ERcjs.ThinkingDisplay; exports.ToolExecutionDisplay = _chunkGDF2R2ERcjs.ToolExecutionDisplay; exports.UnarchiveChatModal = _chunkGDF2R2ERcjs.UnarchiveChatModal; exports.WhatIShippedCard = _chunkGDF2R2ERcjs.WhatIShippedCard; exports.WhatIShippedCardSkeleton = _chunkGDF2R2ERcjs.WhatIShippedCardSkeleton; exports.applyProxyAuth = _chunkYETA25JWcjs.applyProxyAuth; exports.buildAnchorProps = _chunkEI4WALN2cjs.buildAnchorProps; exports.buildAutoContinuationDirective = _chunk6N26CURScjs.buildAutoContinuationDirective; exports.buildChatAttachmentViewUrl = _chunk6N26CURScjs.buildChatAttachmentViewUrl; exports.buildChatRefKey = _chunkGDF2R2ERcjs.buildChatRefKey; exports.buildDiscussAddendum = _chunk6N26CURScjs.buildDiscussAddendum; exports.buildNatsWsUrl = _chunkGDF2R2ERcjs.buildNatsWsUrl; exports.buildProductReleaseCardProps = _chunkGDF2R2ERcjs.buildProductReleaseCardProps; exports.chatAuthedFetch = _chunkYETA25JWcjs.embedAuthedFetch; exports.chatChipClass = _chunkGDF2R2ERcjs.chatChipClass; exports.clearChatProxyAuth = _chunkYETA25JWcjs.clearEmbedProxyAuth; exports.clickupTaskUrl = _chunk6N26CURScjs.clickupTaskUrl; exports.computeHistoryPrepend = _chunkGDF2R2ERcjs.computeHistoryPrepend; exports.computeIsNewTab = _chunkEI4WALN2cjs.computeIsNewTab; exports.createMessageSegmentAccumulator = _chunkGDF2R2ERcjs.createMessageSegmentAccumulator; exports.decideNewTab = _chunkY4JNA4W6cjs.decideNewTab; exports.defaultBuildProductReleaseCardProps = _chunkGDF2R2ERcjs.defaultBuildProductReleaseCardProps; exports.defaultTableIdForDocumentType = _chunkY4JNA4W6cjs.defaultTableIdForDocumentType; exports.escapeMarkdownInline = _chunk6N26CURScjs.escapeMarkdownInline; exports.executeNavigation = _chunkGDF2R2ERcjs.executeNavigation; exports.executeNavigationImperative = _chunkGDF2R2ERcjs.executeNavigationImperative; exports.extractEntityIdFilter = _chunk6N26CURScjs.extractEntityIdFilter; exports.extractErrorMessages = _chunkGDF2R2ERcjs.extractErrorMessages; exports.extractIncompleteMessageState = _chunkGDF2R2ERcjs.extractIncompleteMessageState; exports.extractTextFromChunk = _chunkGDF2R2ERcjs.extractTextFromChunk; exports.fetchEmptyStateConfig = _chunkGDF2R2ERcjs.fetchEmptyStateConfig; exports.fetchSlashCommands = _chunkGDF2R2ERcjs.fetchSlashCommands; exports.flattenAssistantContent = _chunk6N26CURScjs.flattenAssistantContent; exports.flattenMessagePagesChronological = _chunkGDF2R2ERcjs.flattenMessagePagesChronological; exports.formatChatAttachmentMarkdownForBubble = _chunk6N26CURScjs.formatChatAttachmentMarkdownForBubble; exports.formatInvestorUpdatePeriod = _chunkGDF2R2ERcjs.formatInvestorUpdatePeriod; exports.formatSingularLookupInvocation = _chunk6N26CURScjs.formatSingularLookupInvocation; exports.getChatProxyAuth = _chunkYETA25JWcjs.getEmbedProxyAuth; exports.getCommandText = _chunkGDF2R2ERcjs.getCommandText; exports.getDynamicIcon = _chunkY4JNA4W6cjs.getDynamicIcon; exports.getIconComponent = _chunkY4JNA4W6cjs.getIconComponent; exports.getPersistedProxyEmail = _chunkYETA25JWcjs.getPersistedProxyEmail; exports.getSourceIconName = _chunkY4JNA4W6cjs.getSourceIconName; exports.getSourceLabel = _chunkY4JNA4W6cjs.getSourceLabel; exports.getStatusColorScheme = _chunk6N26CURScjs.getStatusColorScheme; exports.getTaskTypeLabel = _chunk6N26CURScjs.getTaskTypeLabel; exports.handleChatNavClick = _chunkGDF2R2ERcjs.handleChatNavClick; exports.isControlChunk = _chunkGDF2R2ERcjs.isControlChunk; exports.isCrossOriginUrl = _chunkY4JNA4W6cjs.isCrossOriginUrl; exports.isErrorChunk = _chunkGDF2R2ERcjs.isErrorChunk; exports.isMetadataChunk = _chunkGDF2R2ERcjs.isMetadataChunk; exports.isModifierClick = _chunkY4JNA4W6cjs.isModifierClick; exports.isStructuredContent = _chunkGDF2R2ERcjs.isStructuredContent; exports.maxPersistedStreamSeq = _chunkGDF2R2ERcjs.maxPersistedStreamSeq; exports.mergeHistoryWithRealtime = _chunkGDF2R2ERcjs.mergeHistoryWithRealtime; exports.newTabAnchorAttrs = _chunkEI4WALN2cjs.newTabAnchorAttrs; exports.normalizeContent = _chunkGDF2R2ERcjs.normalizeContent; exports.normalizeIconKey = _chunkY4JNA4W6cjs.normalizeIconKey; exports.parseChunkToAction = _chunkGDF2R2ERcjs.parseChunkToAction; exports.parseScrollAnchor = _chunk6N26CURScjs.parseScrollAnchor; exports.parseWireCommandOverride = _chunk6N26CURScjs.parseWireCommandOverride; exports.processHistoricalMessages = _chunkGDF2R2ERcjs.processHistoricalMessages; exports.processHistoricalMessagesWithErrors = _chunkGDF2R2ERcjs.processHistoricalMessagesWithErrors; exports.remarkCardLinks = _chunkGDF2R2ERcjs.remarkCardLinks; exports.renderChatInlineEntityCard = _chunkGDF2R2ERcjs.renderChatInlineEntityCard; exports.resolveExternalNavigation = _chunkY4JNA4W6cjs.resolveExternalNavigation; exports.resolveOnboardingIcon = _chunkGDF2R2ERcjs.resolveOnboardingIcon; exports.resolveSourceIcon = _chunkY4JNA4W6cjs.resolveSourceIcon; exports.resolveSourceRowCTA = _chunkY4JNA4W6cjs.resolveSourceRowCTA; exports.safeHref = _chunkY4JNA4W6cjs.safeHref; exports.sanitizeTitleForChat = _chunk6N26CURScjs.sanitizeTitleForChat; exports.setChatProxyAuth = _chunkYETA25JWcjs.setEmbedProxyAuth; exports.stripChatAttachmentMarkdown = _chunk6N26CURScjs.stripChatAttachmentMarkdown; exports.stripSameOriginToPath = _chunkY4JNA4W6cjs.stripSameOriginToPath; exports.transformEventToProgram = _chunkGDF2R2ERcjs.transformEventToProgram; exports.transformPodcastToProgram = _chunkGDF2R2ERcjs.transformPodcastToProgram; exports.transformWebinarToProgram = _chunkGDF2R2ERcjs.transformWebinarToProgram; exports.useChat = _chunkGDF2R2ERcjs.useChat; exports.useChatAttachmentImageGallery = _chunkGDF2R2ERcjs.useChatAttachmentImageGallery; exports.useChatAttachments = _chunkGDF2R2ERcjs.useChatAttachments; exports.useChatCardItem = _chunkGDF2R2ERcjs.useChatCardItem; exports.useChatIdentity = _chunkGDF2R2ERcjs.useChatIdentity; exports.useChunkCatchup = _chunkGDF2R2ERcjs.useChunkCatchup; exports.useCloseOnNavigation = _chunkGDF2R2ERcjs.useCloseOnNavigation; exports.useCollapsible = _chunkGDF2R2ERcjs.useCollapsible; exports.useEmbeddedChat = _chunkGDF2R2ERcjs.useSseChatAdapter; exports.useEmptyStateConfig = _chunkGDF2R2ERcjs.useEmptyStateConfig; exports.useJetStreamDialogSubscription = _chunkGDF2R2ERcjs.useJetStreamDialogSubscription; exports.useNatsChatAdapter = _chunkGDF2R2ERcjs.useNatsChatAdapter; exports.useNatsDialogSubscription = _chunkGDF2R2ERcjs.useNatsDialogSubscription; exports.useProxiedImageUrl = _chunkGDF2R2ERcjs.useProxiedImageUrl; exports.useRealtimeChunkProcessor = _chunkGDF2R2ERcjs.useRealtimeChunkProcessor; exports.useSSE = _chunkGDF2R2ERcjs.useSSE; exports.useSlashCommandRegistry = _chunkGDF2R2ERcjs.useSlashCommandRegistry; exports.useSlashCommands = _chunkGDF2R2ERcjs.useSlashCommands; exports.useSseChatAdapter = _chunkGDF2R2ERcjs.useSseChatAdapter; exports.useUnifiedChat = _chunkGDF2R2ERcjs.useUnifiedChat;
519
+ exports.ANTHROPIC_SUPPORTED_IMAGE_MIME = _chunkD6RK5YXXcjs.ANTHROPIC_SUPPORTED_IMAGE_MIME; exports.APPROVAL_STATUS = _chunkOXC72UIPcjs.APPROVAL_STATUS; exports.ASSISTANT_TYPE = _chunkOXC72UIPcjs.ASSISTANT_TYPE; exports.AUTHOR_TYPE = _chunkOXC72UIPcjs.AUTHOR_TYPE; exports.AUTO_CONTINUATION_DIRECTIVE_PREFIX = _chunkD6RK5YXXcjs.AUTO_CONTINUATION_DIRECTIVE_PREFIX; exports.AdminContentCard = _chunkOXC72UIPcjs.AdminContentCard; exports.ApprovalBatchMessage = _chunkOXC72UIPcjs.ApprovalBatchMessage; exports.ApprovalRequestMessage = _chunkOXC72UIPcjs.ApprovalRequestMessage; exports.ArchiveChatModal = _chunkOXC72UIPcjs.ArchiveChatModal; exports.ArgRow = _chunkOXC72UIPcjs.ArgRow; exports.BlockCard = _chunkOXC72UIPcjs.BlockCard; exports.BlogCard = _chunkOXC72UIPcjs.BlogCard; exports.BlogCardSkeleton = _chunkOXC72UIPcjs.BlogCardSkeleton; exports.BlogImagePlaceholder = _chunkEI4WALN2cjs.BlogImagePlaceholder; exports.CHAT_ATTACHMENT_CONCURRENT_UPLOADS_PER_USER = _chunkOXC72UIPcjs.CHAT_ATTACHMENT_CONCURRENT_UPLOADS_PER_USER; exports.CHAT_ATTACHMENT_MARKDOWN_PATTERN = _chunkD6RK5YXXcjs.CHAT_ATTACHMENT_MARKDOWN_PATTERN; exports.CHAT_ATTACHMENT_MIME_TYPES = _chunkOXC72UIPcjs.CHAT_ATTACHMENT_MIME_TYPES; exports.CHAT_ATTACHMENT_VIEW_TOKEN_QUERY_PARAM = _chunkD6RK5YXXcjs.CHAT_ATTACHMENT_VIEW_TOKEN_QUERY_PARAM; exports.CHAT_ATTACHMENT_VIEW_URL_PREFIX = _chunkD6RK5YXXcjs.CHAT_ATTACHMENT_VIEW_URL_PREFIX; exports.CHAT_ATTACHMENT_VIEW_URL_PREFIX_REGEX_ESCAPED = _chunkD6RK5YXXcjs.CHAT_ATTACHMENT_VIEW_URL_PREFIX_REGEX_ESCAPED; exports.CHAT_CONTEXT_ITEMS_DEFAULT_MAX = _chunkOXC72UIPcjs.CHAT_CONTEXT_ITEMS_DEFAULT_MAX; exports.CHAT_TYPE = _chunkOXC72UIPcjs.CHAT_TYPE; exports.CHIP_ACTION_BUTTON_CLASS = _chunkOXC72UIPcjs.CHIP_ACTION_BUTTON_CLASS; exports.COMPACT_CARD_ICON_SLOT = _chunkY4JNA4W6cjs.COMPACT_CARD_ICON_SLOT; exports.COMPACT_CARD_IMAGE_SLOT = _chunkY4JNA4W6cjs.COMPACT_CARD_IMAGE_SLOT; exports.COMPACT_CARD_META_ROW = _chunkY4JNA4W6cjs.COMPACT_CARD_META_ROW; exports.COMPACT_CARD_META_ROW_BOX = _chunkY4JNA4W6cjs.COMPACT_CARD_META_ROW_BOX; exports.COMPACT_CARD_OUTER = _chunkY4JNA4W6cjs.COMPACT_CARD_OUTER; exports.COMPACT_CARD_OUTER_STATIC = _chunkY4JNA4W6cjs.COMPACT_CARD_OUTER_STATIC; exports.COMPACT_CARD_ROW_FILLER = _chunkY4JNA4W6cjs.COMPACT_CARD_ROW_FILLER; exports.COMPACT_CARD_SKELETON_IMAGE_SLOT = _chunkY4JNA4W6cjs.COMPACT_CARD_SKELETON_IMAGE_SLOT; exports.COMPACT_CARD_SKELETON_OUTER = _chunkY4JNA4W6cjs.COMPACT_CARD_SKELETON_OUTER; exports.COMPACT_CARD_SUBTITLE = _chunkY4JNA4W6cjs.COMPACT_CARD_SUBTITLE; exports.COMPACT_CARD_SUMMARY = _chunkY4JNA4W6cjs.COMPACT_CARD_SUMMARY; exports.COMPACT_CARD_TEXT_COL = _chunkY4JNA4W6cjs.COMPACT_CARD_TEXT_COL; exports.COMPACT_CARD_TITLE = _chunkY4JNA4W6cjs.COMPACT_CARD_TITLE; exports.COMPACT_CARD_TITLE_ROW = _chunkY4JNA4W6cjs.COMPACT_CARD_TITLE_ROW; exports.COMPACT_HEADER_BUTTON = _chunkOXC72UIPcjs.COMPACT_HEADER_BUTTON; exports.CONNECTION_STATUS = _chunkOXC72UIPcjs.CONNECTION_STATUS; exports.CONTEXT_BACK_CLASS = _chunkOXC72UIPcjs.CONTEXT_BACK_CLASS; exports.CONTEXT_ICON_CLASS = _chunkOXC72UIPcjs.CONTEXT_ICON_CLASS; exports.CONTEXT_LABEL_CLASS = _chunkOXC72UIPcjs.CONTEXT_LABEL_CLASS; exports.CONTEXT_ROW_CLASS = _chunkOXC72UIPcjs.CONTEXT_ROW_CLASS; exports.CONTEXT_STATE_CLASS = _chunkOXC72UIPcjs.CONTEXT_STATE_CLASS; exports.CUSTOM_ITEM_ID = _chunkD6RK5YXXcjs.CUSTOM_ITEM_ID; exports.CampaignCardAdmin = _chunkOXC72UIPcjs.CampaignCardAdmin; exports.CampaignCardAdminSkeleton = _chunkOXC72UIPcjs.CampaignCardAdminSkeleton; exports.CaseStudyCard = _chunkOXC72UIPcjs.CaseStudyCard; exports.CaseStudyCardSkeleton = _chunkOXC72UIPcjs.CaseStudyCardSkeleton; exports.ChatArchivePage = _chunkOXC72UIPcjs.ChatArchivePage; exports.ChatAttachmentAddButton = _chunkOXC72UIPcjs.ChatAttachmentAddButton; exports.ChatAttachmentChipStrip = _chunkOXC72UIPcjs.ChatAttachmentChipStrip; exports.ChatCardLoader = _chunkOXC72UIPcjs.ChatCardLoader; exports.ChatComposer = _chunkOXC72UIPcjs.ChatComposer; exports.ChatComposerPlusMenu = _chunkOXC72UIPcjs.ChatComposerPlusMenu; exports.ChatContainer = _chunkOXC72UIPcjs.ChatContainer; exports.ChatContent = _chunkOXC72UIPcjs.ChatContent; exports.ChatContextChipStrip = _chunkOXC72UIPcjs.ChatContextChipStrip; exports.ChatContextPicker = _chunkOXC72UIPcjs.ChatContextPicker; exports.ChatDialogModals = _chunkOXC72UIPcjs.ChatDialogModals; exports.ChatFooter = _chunkOXC72UIPcjs.ChatFooter; exports.ChatHeader = _chunkOXC72UIPcjs.ChatHeader; exports.ChatHeaderIconButton = _chunkOXC72UIPcjs.ChatHeaderIconButton; exports.ChatIdentityProvider = _chunkOXC72UIPcjs.ChatIdentityProvider; exports.ChatInput = _chunkOXC72UIPcjs.ChatInput; exports.ChatMessageEnhanced = _chunkOXC72UIPcjs.MemoizedChatMessageEnhanced; exports.ChatMessageList = _chunkOXC72UIPcjs.ChatMessageList; exports.ChatMessageListSkeleton = _chunkOXC72UIPcjs.ChatMessageListSkeleton; exports.ChatMessageRow = _chunkOXC72UIPcjs.ChatMessageRow; exports.ChatMessageRowSkeleton = _chunkOXC72UIPcjs.ChatMessageRowSkeleton; exports.ChatMessageSkeleton = _chunkOXC72UIPcjs.ChatMessageSkeleton; exports.ChatPanelHeader = _chunkOXC72UIPcjs.ChatPanelHeader; exports.ChatQuickAction = _chunkOXC72UIPcjs.ChatQuickAction; exports.ChatQuickActionRow = _chunkOXC72UIPcjs.ChatQuickActionRow; exports.ChatQuickActionRowSkeleton = _chunkOXC72UIPcjs.ChatQuickActionRowSkeleton; exports.ChatSidebar = _chunkOXC72UIPcjs.ChatSidebar; exports.ChatTicketItem = _chunkOXC72UIPcjs.ChatTicketItem; exports.ChatTicketList = _chunkOXC72UIPcjs.ChatTicketList; exports.ChatTypingIndicator = _chunkOXC72UIPcjs.ChatTypingIndicator; exports.ChatVideoEntityCard = _chunkOXC72UIPcjs.ChatVideoEntityCard; exports.ContextCompactionDisplay = _chunkOXC72UIPcjs.ContextCompactionDisplay; exports.ContextErrorBoundary = _chunkOXC72UIPcjs.ContextErrorBoundary; exports.ContextItemsList = _chunkOXC72UIPcjs.ContextItemsList; exports.ContextItemsSkeleton = _chunkOXC72UIPcjs.ContextItemsSkeleton; exports.ContextMenuRow = _chunkOXC72UIPcjs.ContextMenuRow; exports.CustomerInterviewCard = _chunkOXC72UIPcjs.CustomerInterviewCard; exports.CustomerInterviewCardSkeleton = _chunkOXC72UIPcjs.CustomerInterviewCardSkeleton; exports.DEFAULT_DOCUMENT_TYPE_TO_TABLE_ID = _chunkY4JNA4W6cjs.DEFAULT_DOCUMENT_TYPE_TO_TABLE_ID; exports.DataRoomDocCard = _chunkOXC72UIPcjs.DataRoomDocCard; exports.DataRoomDocCardSkeleton = _chunkOXC72UIPcjs.DataRoomDocCardSkeleton; exports.DialogListItem = _chunkOXC72UIPcjs.DialogListItem; exports.EMPTY_AUTHOR_PLACEHOLDER = _chunkEI4WALN2cjs.EMPTY_AUTHOR_PLACEHOLDER; exports.EmbeddableChat = _chunkOXC72UIPcjs.EmbeddableChat; exports.EntityAuthorCard = _chunkEI4WALN2cjs.EntityAuthorCard; exports.EntityMetadataAuthorCell = _chunkEI4WALN2cjs.EntityMetadataAuthorCell; exports.EntityMetadataValueCell = _chunkEI4WALN2cjs.EntityMetadataValueCell; exports.ErrorMessageDisplay = _chunkOXC72UIPcjs.ErrorMessageDisplay; exports.ExpandChevron = _chunkOXC72UIPcjs.ExpandChevron; exports.GenericEntityCard = _chunkOXC72UIPcjs.GenericEntityCard; exports.GenericEntityCardSkeleton = _chunkOXC72UIPcjs.GenericEntityCardSkeleton; exports.GitHubActivityCard = _chunkOXC72UIPcjs.GitHubActivityCard; exports.GitHubActivityCardSkeleton = _chunkOXC72UIPcjs.GitHubActivityCardSkeleton; exports.GuideModeBanner = _chunkOXC72UIPcjs.GuideModeBanner; exports.GuideWelcome = _chunkOXC72UIPcjs.GuideWelcome; exports.HubspotTicketCard = _chunkOXC72UIPcjs.HubspotTicketCard; exports.HubspotTicketCardSkeleton = _chunkOXC72UIPcjs.HubspotTicketCardSkeleton; exports.ICON_REGISTRY = _chunkY4JNA4W6cjs.ICON_REGISTRY; exports.InvestorUpdateCard = _chunkOXC72UIPcjs.InvestorUpdateCard; exports.InvestorUpdateCardSkeleton = _chunkOXC72UIPcjs.InvestorUpdateCardSkeleton; exports.MESSAGE_ROLE = _chunkOXC72UIPcjs.MESSAGE_ROLE; exports.MESSAGE_TYPE = _chunkD6RK5YXXcjs.MESSAGE_TYPE; exports.MessageSegmentAccumulator = _chunkOXC72UIPcjs.MessageSegmentAccumulator; exports.MingoChatHistory = _chunkOXC72UIPcjs.MingoChatHistory; exports.MingoChatHistorySkeleton = _chunkOXC72UIPcjs.MingoChatHistorySkeleton; exports.MingoOnboardingCard = _chunkOXC72UIPcjs.MingoOnboardingCard; exports.MingoOnboardingCardSkeleton = _chunkOXC72UIPcjs.MingoOnboardingCardSkeleton; exports.MingoOnboardingListSkeleton = _chunkOXC72UIPcjs.MingoOnboardingListSkeleton; exports.MingoWelcome = _chunkOXC72UIPcjs.MingoWelcome; exports.ModelDisplay = _chunkOXC72UIPcjs.ModelDisplay; exports.ModelDisplaySkeleton = _chunkOXC72UIPcjs.ModelDisplaySkeleton; exports.NETWORK_CONFIG = _chunkOXC72UIPcjs.NETWORK_CONFIG; exports.NEW_TAB_FEATURES = _chunkY4JNA4W6cjs.NEW_TAB_FEATURES; exports.NavLinkAnchorViaRuntime = _chunkOXC72UIPcjs.NavLinkAnchorViaRuntime; exports.ONBOARDING_ICONS = _chunkOXC72UIPcjs.ONBOARDING_ICONS; exports.ONBOARDING_ICON_OPTIONS = _chunkOXC72UIPcjs.ONBOARDING_ICON_OPTIONS; exports.OWNER_TYPE = _chunkOXC72UIPcjs.OWNER_TYPE; exports.OnboardingGuideCard = _chunkEI4WALN2cjs.OnboardingGuideCard; exports.OnboardingGuideCardSkeleton = _chunkEI4WALN2cjs.OnboardingGuideCardSkeleton; exports.ProductReleaseCard = _chunkOXC72UIPcjs.ProductReleaseCard; exports.ProductReleaseCardSkeleton = _chunkOXC72UIPcjs.ProductReleaseCardSkeleton; exports.ProgramCard = _chunkOXC72UIPcjs.ProgramCard; exports.ProgramCardSkeleton = _chunkOXC72UIPcjs.ProgramCardSkeleton; exports.RenameChatModal = _chunkOXC72UIPcjs.RenameChatModal; exports.ResultBlock = _chunkOXC72UIPcjs.ResultBlock; exports.RoadmapCard = _chunkOXC72UIPcjs.RoadmapCard; exports.RoadmapCardSkeleton = _chunkOXC72UIPcjs.RoadmapCardSkeleton; exports.RoadmapVoteButton = _chunkOXC72UIPcjs.RoadmapVoteButton; exports.SCROLL_ANCHOR = _chunkD6RK5YXXcjs.SCROLL_ANCHOR; exports.SCROLL_ANCHOR_WIRE_KEY = _chunkD6RK5YXXcjs.SCROLL_ANCHOR_WIRE_KEY; exports.SOURCE_ICON_NAMES = _chunkY4JNA4W6cjs.SOURCE_ICON_NAMES; exports.SOURCE_LABELS_BY_TABLE = _chunkY4JNA4W6cjs.SOURCE_LABELS_BY_TABLE; exports.SYNTHETIC_REALTIME_ID_PREFIXES = _chunkOXC72UIPcjs.SYNTHETIC_REALTIME_ID_PREFIXES; exports.SlackMessageCard = _chunkOXC72UIPcjs.SlackMessageCard; exports.SlackMessageCardSkeleton = _chunkOXC72UIPcjs.SlackMessageCardSkeleton; exports.SlashCommandSuggestions = _chunkOXC72UIPcjs.SlashCommandSuggestions; exports.SourceActionButton = _chunkOXC72UIPcjs.SourceActionButton; exports.TaskTypeIcon = _chunkOXC72UIPcjs.TaskTypeIcon; exports.ThinkingDisplay = _chunkOXC72UIPcjs.ThinkingDisplay; exports.ToolExecutionDisplay = _chunkOXC72UIPcjs.ToolExecutionDisplay; exports.UnarchiveChatModal = _chunkOXC72UIPcjs.UnarchiveChatModal; exports.WhatIShippedCard = _chunkOXC72UIPcjs.WhatIShippedCard; exports.WhatIShippedCardSkeleton = _chunkOXC72UIPcjs.WhatIShippedCardSkeleton; exports.applyProxyAuth = _chunkYETA25JWcjs.applyProxyAuth; exports.buildAnchorProps = _chunkEI4WALN2cjs.buildAnchorProps; exports.buildAutoContinuationDirective = _chunkD6RK5YXXcjs.buildAutoContinuationDirective; exports.buildChatAttachmentViewUrl = _chunkD6RK5YXXcjs.buildChatAttachmentViewUrl; exports.buildChatRefKey = _chunkOXC72UIPcjs.buildChatRefKey; exports.buildDiscussAddendum = _chunkD6RK5YXXcjs.buildDiscussAddendum; exports.buildNatsWsUrl = _chunkOXC72UIPcjs.buildNatsWsUrl; exports.buildProductReleaseCardProps = _chunkOXC72UIPcjs.buildProductReleaseCardProps; exports.chatAuthedFetch = _chunkYETA25JWcjs.embedAuthedFetch; exports.chatChipClass = _chunkOXC72UIPcjs.chatChipClass; exports.clearChatProxyAuth = _chunkYETA25JWcjs.clearEmbedProxyAuth; exports.clickupTaskUrl = _chunkD6RK5YXXcjs.clickupTaskUrl; exports.computeHistoryPrepend = _chunkOXC72UIPcjs.computeHistoryPrepend; exports.computeIsNewTab = _chunkEI4WALN2cjs.computeIsNewTab; exports.createMessageSegmentAccumulator = _chunkOXC72UIPcjs.createMessageSegmentAccumulator; exports.decideNewTab = _chunkY4JNA4W6cjs.decideNewTab; exports.defaultBuildProductReleaseCardProps = _chunkOXC72UIPcjs.defaultBuildProductReleaseCardProps; exports.defaultTableIdForDocumentType = _chunkY4JNA4W6cjs.defaultTableIdForDocumentType; exports.escapeMarkdownInline = _chunkD6RK5YXXcjs.escapeMarkdownInline; exports.executeNavigation = _chunkOXC72UIPcjs.executeNavigation; exports.executeNavigationImperative = _chunkOXC72UIPcjs.executeNavigationImperative; exports.extractEntityIdFilter = _chunkD6RK5YXXcjs.extractEntityIdFilter; exports.extractErrorMessages = _chunkOXC72UIPcjs.extractErrorMessages; exports.extractIncompleteMessageState = _chunkOXC72UIPcjs.extractIncompleteMessageState; exports.extractTextFromChunk = _chunkOXC72UIPcjs.extractTextFromChunk; exports.fetchEmptyStateConfig = _chunkOXC72UIPcjs.fetchEmptyStateConfig; exports.fetchSlashCommands = _chunkOXC72UIPcjs.fetchSlashCommands; exports.flattenAssistantContent = _chunkD6RK5YXXcjs.flattenAssistantContent; exports.flattenMessagePagesChronological = _chunkOXC72UIPcjs.flattenMessagePagesChronological; exports.formatChatAttachmentMarkdownForBubble = _chunkD6RK5YXXcjs.formatChatAttachmentMarkdownForBubble; exports.formatInvestorUpdatePeriod = _chunkOXC72UIPcjs.formatInvestorUpdatePeriod; exports.formatSingularLookupInvocation = _chunkD6RK5YXXcjs.formatSingularLookupInvocation; exports.getChatProxyAuth = _chunkYETA25JWcjs.getEmbedProxyAuth; exports.getCommandText = _chunkOXC72UIPcjs.getCommandText; exports.getDynamicIcon = _chunkY4JNA4W6cjs.getDynamicIcon; exports.getIconComponent = _chunkY4JNA4W6cjs.getIconComponent; exports.getPersistedProxyEmail = _chunkYETA25JWcjs.getPersistedProxyEmail; exports.getSourceIconName = _chunkY4JNA4W6cjs.getSourceIconName; exports.getSourceLabel = _chunkY4JNA4W6cjs.getSourceLabel; exports.getStatusColorScheme = _chunkD6RK5YXXcjs.getStatusColorScheme; exports.getTaskTypeLabel = _chunkD6RK5YXXcjs.getTaskTypeLabel; exports.handleChatNavClick = _chunkOXC72UIPcjs.handleChatNavClick; exports.isControlChunk = _chunkOXC72UIPcjs.isControlChunk; exports.isCrossOriginUrl = _chunkY4JNA4W6cjs.isCrossOriginUrl; exports.isErrorChunk = _chunkOXC72UIPcjs.isErrorChunk; exports.isMetadataChunk = _chunkOXC72UIPcjs.isMetadataChunk; exports.isModifierClick = _chunkY4JNA4W6cjs.isModifierClick; exports.isStructuredContent = _chunkOXC72UIPcjs.isStructuredContent; exports.maxPersistedStreamSeq = _chunkOXC72UIPcjs.maxPersistedStreamSeq; exports.mergeHistoryWithRealtime = _chunkOXC72UIPcjs.mergeHistoryWithRealtime; exports.newTabAnchorAttrs = _chunkEI4WALN2cjs.newTabAnchorAttrs; exports.normalizeContent = _chunkOXC72UIPcjs.normalizeContent; exports.normalizeIconKey = _chunkY4JNA4W6cjs.normalizeIconKey; exports.parseChunkToAction = _chunkOXC72UIPcjs.parseChunkToAction; exports.parseScrollAnchor = _chunkD6RK5YXXcjs.parseScrollAnchor; exports.parseWireCommandOverride = _chunkD6RK5YXXcjs.parseWireCommandOverride; exports.processHistoricalMessages = _chunkOXC72UIPcjs.processHistoricalMessages; exports.processHistoricalMessagesWithErrors = _chunkOXC72UIPcjs.processHistoricalMessagesWithErrors; exports.remarkCardLinks = _chunkOXC72UIPcjs.remarkCardLinks; exports.renderChatInlineEntityCard = _chunkOXC72UIPcjs.renderChatInlineEntityCard; exports.resolveExternalNavigation = _chunkY4JNA4W6cjs.resolveExternalNavigation; exports.resolveOnboardingIcon = _chunkOXC72UIPcjs.resolveOnboardingIcon; exports.resolveSourceIcon = _chunkY4JNA4W6cjs.resolveSourceIcon; exports.resolveSourceRowCTA = _chunkY4JNA4W6cjs.resolveSourceRowCTA; exports.safeHref = _chunkY4JNA4W6cjs.safeHref; exports.sanitizeTitleForChat = _chunkD6RK5YXXcjs.sanitizeTitleForChat; exports.setChatProxyAuth = _chunkYETA25JWcjs.setEmbedProxyAuth; exports.stripChatAttachmentMarkdown = _chunkD6RK5YXXcjs.stripChatAttachmentMarkdown; exports.stripSameOriginToPath = _chunkY4JNA4W6cjs.stripSameOriginToPath; exports.transformEventToProgram = _chunkOXC72UIPcjs.transformEventToProgram; exports.transformPodcastToProgram = _chunkOXC72UIPcjs.transformPodcastToProgram; exports.transformWebinarToProgram = _chunkOXC72UIPcjs.transformWebinarToProgram; exports.useChat = _chunkOXC72UIPcjs.useChat; exports.useChatAttachmentImageGallery = _chunkOXC72UIPcjs.useChatAttachmentImageGallery; exports.useChatAttachments = _chunkOXC72UIPcjs.useChatAttachments; exports.useChatCardItem = _chunkOXC72UIPcjs.useChatCardItem; exports.useChatIdentity = _chunkOXC72UIPcjs.useChatIdentity; exports.useChunkCatchup = _chunkOXC72UIPcjs.useChunkCatchup; exports.useCloseOnNavigation = _chunkOXC72UIPcjs.useCloseOnNavigation; exports.useCollapsible = _chunkOXC72UIPcjs.useCollapsible; exports.useEmbeddedChat = _chunkOXC72UIPcjs.useSseChatAdapter; exports.useEmptyStateConfig = _chunkOXC72UIPcjs.useEmptyStateConfig; exports.useJetStreamDialogSubscription = _chunkOXC72UIPcjs.useJetStreamDialogSubscription; exports.useNatsChatAdapter = _chunkOXC72UIPcjs.useNatsChatAdapter; exports.useNatsDialogSubscription = _chunkOXC72UIPcjs.useNatsDialogSubscription; exports.useProxiedImageUrl = _chunkOXC72UIPcjs.useProxiedImageUrl; exports.useRealtimeChunkProcessor = _chunkOXC72UIPcjs.useRealtimeChunkProcessor; exports.useSSE = _chunkOXC72UIPcjs.useSSE; exports.useSlashCommandRegistry = _chunkOXC72UIPcjs.useSlashCommandRegistry; exports.useSlashCommands = _chunkOXC72UIPcjs.useSlashCommands; exports.useSseChatAdapter = _chunkOXC72UIPcjs.useSseChatAdapter; exports.useUnifiedChat = _chunkOXC72UIPcjs.useUnifiedChat;
520
520
  //# sourceMappingURL=index.cjs.map
@@ -170,7 +170,7 @@ import {
170
170
  useSlashCommands,
171
171
  useSseChatAdapter,
172
172
  useUnifiedChat
173
- } from "../../chunk-FSBDVT6R.js";
173
+ } from "../../chunk-EFYXPR43.js";
174
174
  import {
175
175
  ANTHROPIC_SUPPORTED_IMAGE_MIME,
176
176
  AUTO_CONTINUATION_DIRECTIVE_PREFIX,
@@ -197,7 +197,7 @@ import {
197
197
  parseWireCommandOverride,
198
198
  sanitizeTitleForChat,
199
199
  stripChatAttachmentMarkdown
200
- } from "../../chunk-DDAT4RKX.js";
200
+ } from "../../chunk-ODR6A6FC.js";
201
201
  import "../../chunk-N6ZM5PYZ.js";
202
202
  import "../../chunk-TYZEMPPH.js";
203
203
  import "../../chunk-MJNXIEV2.js";