@flamingo-stack/openframe-frontend-core 0.0.209 → 0.0.210-snapshot.20260528032637

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 (74) hide show
  1. package/dist/{chunk-HZT4YU33.js → chunk-3E5ANY55.js} +49 -26
  2. package/dist/chunk-3E5ANY55.js.map +1 -0
  3. package/dist/{chunk-RFSBDUXD.js → chunk-5BNWGK6D.js} +2 -2
  4. package/dist/{chunk-6RZYJICV.cjs → chunk-P5EE2VJX.cjs} +1 -1
  5. package/dist/chunk-P5EE2VJX.cjs.map +1 -0
  6. package/dist/{chunk-GIKD2LWD.js → chunk-QKFBZLIR.js} +2 -2
  7. package/dist/{chunk-Y7IXGY7T.cjs → chunk-VTUIMMHO.cjs} +24 -24
  8. package/dist/{chunk-Y7IXGY7T.cjs.map → chunk-VTUIMMHO.cjs.map} +1 -1
  9. package/dist/{chunk-SJQLTQC7.cjs → chunk-WI76ZUBE.cjs} +57 -34
  10. package/dist/chunk-WI76ZUBE.cjs.map +1 -0
  11. package/dist/{chunk-S2B3UFVP.cjs → chunk-ZFBLC5GV.cjs} +17 -17
  12. package/dist/{chunk-S2B3UFVP.cjs.map → chunk-ZFBLC5GV.cjs.map} +1 -1
  13. package/dist/{chunk-7L4DWM7P.js → chunk-ZG2YY5E7.js} +1 -1
  14. package/dist/chunk-ZG2YY5E7.js.map +1 -0
  15. package/dist/components/chat/entity-cards/blog-card.d.ts.map +1 -1
  16. package/dist/components/chat/hooks/use-chat-identity.d.ts +3 -3
  17. package/dist/components/chat/hooks/use-chat-identity.d.ts.map +1 -1
  18. package/dist/components/chat/index.cjs +3 -3
  19. package/dist/components/chat/index.js +2 -2
  20. package/dist/components/contact/index.cjs +4 -4
  21. package/dist/components/contact/index.js +3 -3
  22. package/dist/components/features/index.cjs +3 -3
  23. package/dist/components/features/index.js +2 -2
  24. package/dist/components/footer-waitlist-button.d.ts +21 -2
  25. package/dist/components/footer-waitlist-button.d.ts.map +1 -1
  26. package/dist/components/index.cjs +87 -91
  27. package/dist/components/index.cjs.map +1 -1
  28. package/dist/components/index.js +12 -16
  29. package/dist/components/index.js.map +1 -1
  30. package/dist/components/navigation/index.cjs +3 -3
  31. package/dist/components/navigation/index.js +2 -2
  32. package/dist/components/navigation/sticky-section-nav.d.ts.map +1 -1
  33. package/dist/components/tickets/help-center-card.d.ts.map +1 -1
  34. package/dist/components/tickets/index.cjs +139 -98
  35. package/dist/components/tickets/index.cjs.map +1 -1
  36. package/dist/components/tickets/index.js +95 -54
  37. package/dist/components/tickets/index.js.map +1 -1
  38. package/dist/components/tickets/ticket-row.d.ts.map +1 -1
  39. package/dist/components/ui/index.cjs +3 -3
  40. package/dist/components/ui/index.js +2 -2
  41. package/dist/contexts/chat-runtime-context.d.ts +6 -3
  42. package/dist/contexts/chat-runtime-context.d.ts.map +1 -1
  43. package/dist/contexts/index.cjs +2 -2
  44. package/dist/contexts/index.js +1 -1
  45. package/dist/index.cjs +5 -3
  46. package/dist/index.cjs.map +1 -1
  47. package/dist/index.js +4 -2
  48. package/dist/utils/index.cjs +10 -0
  49. package/dist/utils/index.cjs.map +1 -1
  50. package/dist/utils/index.d.ts +1 -0
  51. package/dist/utils/index.d.ts.map +1 -1
  52. package/dist/utils/index.js +10 -1
  53. package/dist/utils/index.js.map +1 -1
  54. package/dist/utils/scroll-into-view.d.ts +63 -0
  55. package/dist/utils/scroll-into-view.d.ts.map +1 -0
  56. package/package.json +1 -1
  57. package/src/components/chat/entity-cards/blog-card.tsx +25 -16
  58. package/src/components/chat/hooks/use-chat-identity.ts +8 -7
  59. package/src/components/footer-waitlist-button.tsx +33 -16
  60. package/src/components/navigation/sticky-section-nav.tsx +6 -4
  61. package/src/components/tickets/help-center-card.tsx +55 -1
  62. package/src/components/tickets/help-center-list.tsx +9 -1
  63. package/src/components/tickets/ticket-detail-drawer.tsx +19 -4
  64. package/src/components/tickets/ticket-row.tsx +30 -19
  65. package/src/contexts/chat-runtime-context.tsx +6 -3
  66. package/src/stories/EmbeddableChat.stories.tsx +1 -1
  67. package/src/utils/index.ts +12 -0
  68. package/src/utils/scroll-into-view.ts +74 -0
  69. package/dist/chunk-6RZYJICV.cjs.map +0 -1
  70. package/dist/chunk-7L4DWM7P.js.map +0 -1
  71. package/dist/chunk-HZT4YU33.js.map +0 -1
  72. package/dist/chunk-SJQLTQC7.cjs.map +0 -1
  73. /package/dist/{chunk-RFSBDUXD.js.map → chunk-5BNWGK6D.js.map} +0 -0
  74. /package/dist/{chunk-GIKD2LWD.js.map → chunk-QKFBZLIR.js.map} +0 -0
@@ -14,7 +14,7 @@
14
14
 
15
15
 
16
16
 
17
- var _chunkSJQLTQC7cjs = require('./chunk-SJQLTQC7.cjs');
17
+ var _chunkWI76ZUBEcjs = require('./chunk-WI76ZUBE.cjs');
18
18
 
19
19
 
20
20
 
@@ -72,7 +72,7 @@ function UnifiedPagination({
72
72
  };
73
73
  if (totalPages <= 1) return null;
74
74
  return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "div", { className, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
75
- _chunkSJQLTQC7cjs.Pagination,
75
+ _chunkWI76ZUBEcjs.Pagination,
76
76
  {
77
77
  currentPage,
78
78
  totalPages,
@@ -85,7 +85,7 @@ var init_unified_pagination = _chunkVRHGVLSLcjs.__esm.call(void 0, {
85
85
  "use strict";
86
86
  "use client";
87
87
  _chunkG7UE6RKVcjs.init_next_navigation.call(void 0, );
88
- _chunkSJQLTQC7cjs.init_pagination.call(void 0, );
88
+ _chunkWI76ZUBEcjs.init_pagination.call(void 0, );
89
89
  }
90
90
  });
91
91
 
@@ -239,7 +239,7 @@ function EmptyState({
239
239
  var _react = require('react');
240
240
 
241
241
  function DevSectionView({ sectionKey, hero, preControls, children }) {
242
- const section = _chunkSJQLTQC7cjs.OPENFRAME_DEV_SECTIONS[sectionKey];
242
+ const section = _chunkWI76ZUBEcjs.OPENFRAME_DEV_SECTIONS[sectionKey];
243
243
  const router = _chunkG7UE6RKVcjs.useRouter.call(void 0, );
244
244
  const pathname = _chunkG7UE6RKVcjs.usePathname.call(void 0, );
245
245
  const searchParams = _chunkG7UE6RKVcjs.useSearchParams.call(void 0, );
@@ -279,7 +279,7 @@ function DevSectionView({ sectionKey, hero, preControls, children }) {
279
279
  preControls,
280
280
  (search || filter) && /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "space-y-4", children: [
281
281
  search && /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
282
- _chunkSJQLTQC7cjs.SearchInput,
282
+ _chunkWI76ZUBEcjs.SearchInput,
283
283
  {
284
284
  showDropdown: false,
285
285
  placeholder: search.placeholder,
@@ -289,7 +289,7 @@ function DevSectionView({ sectionKey, hero, preControls, children }) {
289
289
  }
290
290
  ),
291
291
  filter && /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
292
- _chunkSJQLTQC7cjs.StatusFilterComponent,
292
+ _chunkWI76ZUBEcjs.StatusFilterComponent,
293
293
  {
294
294
  selectedStatus: currentFilterValue,
295
295
  onStatusChange: handleFilterChange,
@@ -307,13 +307,13 @@ _chunkG7UE6RKVcjs.init_next_navigation.call(void 0, );
307
307
  var SECTION_HERO_ICON_CLASS = "h-10 w-10 text-ods-accent";
308
308
  function DevSectionPage({ sectionKey, children, preControls, backButton }) {
309
309
  const router = _chunkG7UE6RKVcjs.useRouter.call(void 0, );
310
- const section = _chunkSJQLTQC7cjs.OPENFRAME_DEV_SECTIONS[sectionKey];
310
+ const section = _chunkWI76ZUBEcjs.OPENFRAME_DEV_SECTIONS[sectionKey];
311
311
  const Icon = section.icon;
312
312
  const backCfg = backButton === false ? void 0 : {
313
313
  label: _nullishCoalesce((backButton ? backButton.label : void 0), () => ( "Back to home")),
314
314
  onClick: () => router.push(_nullishCoalesce((backButton ? backButton.href : void 0), () => ( "/")))
315
315
  };
316
- return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkSJQLTQC7cjs.PageShell, { children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkSJQLTQC7cjs.PageLayout, { backButton: backCfg, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
316
+ return /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkWI76ZUBEcjs.PageShell, { children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkWI76ZUBEcjs.PageLayout, { backButton: backCfg, children: /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
317
317
  DevSectionView,
318
318
  {
319
319
  sectionKey,
@@ -357,7 +357,7 @@ function ConversationCardRow({
357
357
  const hasBody = body.trim().length > 0;
358
358
  const hasAttachments = !!attachments && attachments.length > 0;
359
359
  if (!hasBody && !hasAttachments) return null;
360
- const relativeTime = timestamp ? _chunkSJQLTQC7cjs.formatRelativeTime.call(void 0, timestamp) : null;
360
+ const relativeTime = timestamp ? _chunkWI76ZUBEcjs.formatRelativeTime.call(void 0, timestamp) : null;
361
361
  return /* @__PURE__ */ _jsxruntime.jsxs.call(void 0,
362
362
  "article",
363
363
  {
@@ -365,7 +365,7 @@ function ConversationCardRow({
365
365
  "aria-label": `${author}${relativeTime ? ` \xB7 ${relativeTime}` : ""}`,
366
366
  children: [
367
367
  /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
368
- _chunkSJQLTQC7cjs.SquareAvatar,
368
+ _chunkWI76ZUBEcjs.SquareAvatar,
369
369
  {
370
370
  src: avatarSrc,
371
371
  alt: author,
@@ -391,7 +391,7 @@ function ConversationCardRow({
391
391
  )
392
392
  ] }),
393
393
  hasBody && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, "p", { className: "text-h4 text-ods-text-primary whitespace-pre-wrap break-words", children: body }),
394
- hasAttachments && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkSJQLTQC7cjs.TicketAttachmentsList, { attachments })
394
+ hasAttachments && /* @__PURE__ */ _jsxruntime.jsx.call(void 0, _chunkWI76ZUBEcjs.TicketAttachmentsList, { attachments })
395
395
  ] })
396
396
  ]
397
397
  }
@@ -461,9 +461,9 @@ function DeliveryRow({
461
461
  className
462
462
  }) {
463
463
  const taskType = item.taskType;
464
- const typeBadgeLabel = _chunkSJQLTQC7cjs.TASK_TYPE_LABELS[taskType] || "TASK";
465
- const typeBadgeTextColor = _chunkSJQLTQC7cjs.TASK_TYPE_TEXT_COLORS[taskType] || "";
466
- const statusBadgeScheme = _chunkSJQLTQC7cjs.getStatusColorScheme.call(void 0, item.status);
464
+ const typeBadgeLabel = _chunkWI76ZUBEcjs.TASK_TYPE_LABELS[taskType] || "TASK";
465
+ const typeBadgeTextColor = _chunkWI76ZUBEcjs.TASK_TYPE_TEXT_COLORS[taskType] || "";
466
+ const statusBadgeScheme = _chunkWI76ZUBEcjs.getStatusColorScheme.call(void 0, item.status);
467
467
  const relativeTime = getRelativeTime(item.dateUpdated);
468
468
  const subtitle = `ACTIVE ${relativeTime}${item.listNames.length > 0 ? `, ${item.listNames.join(", ")}` : ""}, ${item.id}`;
469
469
  const inner = /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "flex flex-col md:flex-row items-start justify-between gap-[12px] md:gap-[16px] w-full", children: [
@@ -475,7 +475,7 @@ function DeliveryRow({
475
475
  ] }),
476
476
  /* @__PURE__ */ _jsxruntime.jsxs.call(void 0, "div", { className: "flex-shrink-0 self-start flex flex-col gap-2", children: [
477
477
  /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
478
- _chunkSJQLTQC7cjs.StatusBadge,
478
+ _chunkWI76ZUBEcjs.StatusBadge,
479
479
  {
480
480
  text: item.status.toUpperCase(),
481
481
  colorScheme: statusBadgeScheme,
@@ -484,7 +484,7 @@ function DeliveryRow({
484
484
  }
485
485
  ),
486
486
  /* @__PURE__ */ _jsxruntime.jsx.call(void 0,
487
- _chunkSJQLTQC7cjs.StatusBadge,
487
+ _chunkWI76ZUBEcjs.StatusBadge,
488
488
  {
489
489
  text: typeBadgeLabel,
490
490
  variant: "card",
@@ -518,4 +518,4 @@ function DeliveryRow({
518
518
 
519
519
 
520
520
  exports.EmptyState = EmptyState; exports.UnifiedPagination = UnifiedPagination; exports.unified_pagination_exports = unified_pagination_exports; exports.init_unified_pagination = init_unified_pagination; exports.DevSectionView = DevSectionView; exports.DevSectionPage = DevSectionPage; exports.DevCardRowContent = DevCardRowContent; exports.ConversationCardRow = ConversationCardRow; exports.ConversationCardRowSkeletonList = ConversationCardRowSkeletonList; exports.DevCardRowSkeleton = DevCardRowSkeleton; exports.DevCardRowSkeletonList = DevCardRowSkeletonList; exports.DeliveryRow = DeliveryRow;
521
- //# sourceMappingURL=chunk-S2B3UFVP.cjs.map
521
+ //# sourceMappingURL=chunk-ZFBLC5GV.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["/home/runner/work/openframe-oss-lib/openframe-oss-lib/openframe-frontend-core/dist/chunk-S2B3UFVP.cjs","../src/components/unified-pagination.tsx","../src/components/empty-state.tsx","../src/components/shared/dev-section/dev-section-view.tsx","../src/components/shared/dev-section/dev-section-page.tsx","../src/components/shared/dev-section/dev-card-row.tsx","../src/components/shared/delivery/delivery-row.tsx"],"names":["jsx","jsxs"],"mappings":"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","file":"/home/runner/work/openframe-oss-lib/openframe-oss-lib/openframe-frontend-core/dist/chunk-S2B3UFVP.cjs","sourcesContent":[null,"\"use client\"\n\nimport { useRouter, useSearchParams, usePathname } from \"../embed-shims/next-navigation\"\nimport { Pagination } from \"./pagination\"\n\ninterface UnifiedPaginationProps {\n currentPage: number\n totalPages: number\n onPageChange?: (page: number) => void\n className?: string\n}\n\nexport function UnifiedPagination({ \n currentPage, \n totalPages, \n onPageChange,\n className = \"mt-8 flex justify-center w-full\"\n}: UnifiedPaginationProps) {\n const router = useRouter()\n const searchParams = useSearchParams()\n const pathname = usePathname()\n\n const handlePageChange = (page: number) => {\n // Preserve current scroll position\n const currentScrollY = window.scrollY\n \n // Call the callback to update local state (prevents reload)\n if (onPageChange) {\n onPageChange(page)\n }\n \n // Update URL for bookmarking without navigation\n const params = new URLSearchParams(searchParams.toString())\n params.set(\"page\", page.toString())\n \n // Update URL without navigation (for bookmarking support)\n const newUrl = `${pathname}?${params.toString()}`\n window.history.replaceState(null, '', newUrl)\n \n // Restore scroll position after a brief delay to allow content to render\n setTimeout(() => {\n window.scrollTo({\n top: currentScrollY,\n behavior: 'instant' // Instant to prevent any scroll animation\n })\n }, 0)\n }\n\n // Don't render pagination if there's only one page\n if (totalPages <= 1) return null\n\n return (\n <div className={className}>\n <Pagination\n currentPage={currentPage}\n totalPages={totalPages}\n onPageChange={handlePageChange}\n />\n </div>\n )\n} ","\"use client\";\n\nimport { Search, FileText, Package } from \"lucide-react\"\nimport { Button } from \"./ui/button\"\nimport { useRouter } from \"../embed-shims/next-navigation\"\n\nexport interface EmptyStateProps {\n type: 'vendors' | 'posts' | 'search' | 'generic'\n title?: string\n description?: string\n showBackButton?: boolean\n onGoBack?: () => void\n backButtonText?: string\n // New CTA properties\n showCTA?: boolean\n ctaText?: string\n onCtaClick?: () => void\n ctaVariant?: 'primary' | 'secondary'\n}\n\nexport function EmptyState({\n type,\n title,\n description,\n showBackButton = false,\n onGoBack,\n backButtonText = \"Go Back\",\n showCTA = true,\n ctaText,\n onCtaClick,\n ctaVariant = 'primary'\n}: EmptyStateProps) {\n const router = useRouter()\n\n // Default content based on type\n const getDefaultContent = () => {\n switch (type) {\n case 'vendors':\n return {\n icon: <Package className=\"w-full h-full\" />,\n title: \"No vendors found\",\n description: \"We couldn't find any vendors matching your criteria. Try adjusting your filters or search terms.\"\n }\n case 'posts':\n return {\n icon: <FileText className=\"w-full h-full\" />,\n title: \"No articles found\",\n description: \"We couldn't find any articles matching your criteria. Try different categories, tags, or search terms.\"\n }\n case 'search':\n return {\n icon: <Search className=\"w-full h-full\" />,\n title: \"No results found\",\n description: \"Your search didn't return any results. Try different keywords or browse our categories.\"\n }\n default:\n return {\n icon: <Search className=\"w-full h-full\" />,\n title: \"Nothing found\",\n description: \"We couldn't find what you're looking for. Try adjusting your search or filters.\"\n }\n }\n }\n\n // Smart CTA logic based on context\n const getSmartCTA = () => {\n // If custom CTA is provided, use it\n if (ctaText && onCtaClick) {\n return {\n text: ctaText,\n action: onCtaClick\n }\n }\n\n // Check if we're on the client side\n const isClient = typeof window !== 'undefined'\n const currentPath = isClient ? window.location.pathname : ''\n\n // Smart defaults based on type and context\n switch (type) {\n case 'search':\n return {\n text: \"Reset Filters\",\n action: () => {\n if (isClient) {\n // Try to reset search by clearing URL params and refreshing\n const url = new URL(window.location.href)\n url.search = ''\n router.push(url.pathname)\n }\n }\n }\n case 'posts':\n // If we're on blog/community pages, reset blog filters\n if (currentPath.includes('/blog')) {\n return {\n text: \"Reset Filters\",\n action: () => {\n if (isClient) {\n // Reset blog search and filters by clearing URL params\n const url = new URL(window.location.href)\n url.search = ''\n router.push(url.pathname)\n }\n }\n }\n } else if (currentPath.includes('/profile')) {\n return {\n text: \"Browse Vendors\",\n action: () => router.push('/vendors')\n }\n }\n return {\n text: \"View All Posts\",\n action: () => router.push('/blog')\n }\n case 'vendors':\n // If we're in profile or other pages, direct to main content\n if (currentPath.includes('/profile')) {\n return {\n text: \"Browse Vendors\",\n action: () => router.push('/vendors')\n }\n } else if (currentPath.includes('/vendors') || currentPath.includes('/margin-increase/compare')) {\n return {\n text: \"Reset Filters\",\n action: () => {\n if (isClient) {\n // Reset vendor search and filters by clearing URL params\n const url = new URL(window.location.href)\n url.search = ''\n router.push(url.pathname)\n }\n }\n }\n }\n return {\n text: \"Browse Vendors\",\n action: () => router.push('/vendors')\n }\n default:\n return {\n text: \"Browse Vendors\",\n action: () => router.push('/vendors')\n }\n }\n }\n\n const defaultContent = getDefaultContent()\n const displayTitle = title || defaultContent.title\n const displayDescription = description || defaultContent.description\n const smartCTA = getSmartCTA()\n\n return (\n <div className=\"flex flex-col items-center justify-center py-6 md:py-16 px-6 text-center\">\n {/* Icon */}\n <div className=\"mb-3 md:mb-6 flex items-center justify-center\">\n <div className=\"rounded-full bg-ods-card p-3 md:p-6 border border-ods-border\">\n <div className=\"w-8 h-8 md:w-16 md:h-16 text-ods-text-secondary flex items-center justify-center\">\n {defaultContent.icon}\n </div>\n </div>\n </div>\n\n {/* Title */}\n <h2 className=\"mb-2 md:mb-3 text-lg md:text-xl font-semibold font-['DM_Sans'] text-ods-text-primary tracking-[-0.02em]\">\n {displayTitle}\n </h2>\n\n {/* Description */}\n <p className=\"mb-4 md:mb-8 max-w-md text-sm font-medium font-['DM_Sans'] text-ods-text-secondary leading-[1.43em]\">\n {displayDescription}\n </p>\n\n {/* Smart CTA Button */}\n {showCTA && smartCTA && (\n <div className=\"w-full max-w-xs mb-3\">\n <Button\n onClick={smartCTA.action}\n className={ctaVariant === 'primary' \n ? \"w-full bg-[#FFC008] text-black hover:bg-[#FFC008]/90 transition-all duration-150 font-['DM_Sans'] font-medium\"\n : \"w-full bg-transparent border border-ods-border text-ods-text-primary hover:border-[#FFC008] hover:text-ods-accent transition-all duration-150 font-['DM_Sans'] font-medium\"\n }\n >\n {smartCTA.text}\n </Button>\n </div>\n )}\n\n {/* Optional Back Button */}\n {showBackButton && onGoBack && (\n <div className=\"w-full max-w-xs\">\n <Button\n onClick={onGoBack}\n variant=\"outline\"\n className=\"w-full transition-all duration-150 font-['DM_Sans'] font-medium\"\n >\n {backButtonText}\n </Button>\n </div>\n )}\n </div>\n )\n} ","'use client';\n\n/**\n * DevSectionView — the canonical chrome for ANY dev-center section\n * (Roadmap / Delivery / Releases). One component, used in BOTH:\n *\n * - tabbed `/roadmap-and-releases` (compact title mode, no `hero`)\n * - full-page `/roadmap`, `/bug-fixes-and-enhancements`, `/releases`\n * (hero mode with icon + description + back link)\n *\n * Owns: title rendering, the inline search input, the filter pill row,\n * and the URL-param wiring that connects both. The list `children`\n * receive a clean URL contract — they read `?<paramKey>=...` via\n * `useSearchParams()` and refetch on change. No duplicated controls.\n */\n\nimport type { ReactNode } from 'react';\nimport { useState, useEffect } from 'react';\nimport { useRouter, useSearchParams, usePathname } from '../../../embed-shims';\nimport { SearchInput } from '../../ui';\nimport { StatusFilterComponent } from '../../features';\nimport {\n OPENFRAME_DEV_SECTIONS,\n type OpenframeDevSectionKey,\n} from '../../../utils/dev-sections/openframe-dev-sections';\n\nexport interface DevSectionViewProps {\n /** Which section to render — drives title, search, and filter\n * config via the `OPENFRAME_DEV_SECTIONS` registry. */\n sectionKey: OpenframeDevSectionKey;\n /** When set, renders the rich page-level hero (icon + h1 + description).\n * Omit for the compact tab-context heading. */\n hero?: {\n /** Pre-rendered icon JSX. Server components render the icon themselves\n * and pass the element here — function references can't cross the\n * server→client boundary, but React elements can. */\n icon: ReactNode;\n description: string;\n };\n /** Optional slot rendered BETWEEN the hero and the search/filter\n * controls. Use this for an entry-action surface that should sit\n * above the list (e.g. the Help Center's \"Open a new ticket\" form).\n * The slot is wrapped in the same `gap-10` flex column so spacing\n * matches the surrounding chrome — callers should NOT add their\n * own top/bottom margin. Renders `null` (no DOM) when omitted. */\n preControls?: ReactNode;\n /** The page-specific list body. Reads URL params written by this\n * component (search input + filter pills). */\n children: ReactNode;\n}\n\nexport function DevSectionView({ sectionKey, hero, preControls, children }: DevSectionViewProps) {\n const section = OPENFRAME_DEV_SECTIONS[sectionKey];\n const router = useRouter();\n const pathname = usePathname();\n const searchParams = useSearchParams();\n\n const search = section.search;\n const filter = section.filter;\n\n const currentSearch = search ? searchParams.get(search.paramKey) || '' : '';\n const currentFilterValue = filter\n ? searchParams.get(filter.paramKey) || filter.defaultValue\n : '';\n\n // Controlled search-input state — input commits to the URL only on\n // Enter (not on every keystroke), preserving the legacy behavior.\n // Lazy init from URL avoids a brief flash of stale value on first\n // paint after URL-driven re-render (e.g. tab switch).\n const [searchValue, setSearchValue] = useState(() => currentSearch);\n useEffect(() => {\n setSearchValue(currentSearch);\n }, [currentSearch]);\n\n const handleSearchSubmit = (value: string) => {\n if (!search) return;\n const params = new URLSearchParams(searchParams.toString());\n if (value.trim()) params.set(search.paramKey, value.trim());\n else params.delete(search.paramKey);\n router.replace(`${pathname}?${params.toString()}`, { scroll: false });\n };\n\n const handleFilterChange = (value: string) => {\n if (!filter) return;\n const params = new URLSearchParams(searchParams.toString());\n if (value === filter.defaultValue) params.delete(filter.paramKey);\n else params.set(filter.paramKey, value);\n router.replace(`${pathname}?${params.toString()}`, { scroll: false });\n };\n\n return (\n <div className=\"w-full flex flex-col gap-10\">\n {hero ? (\n <div className=\"space-y-4\">\n <h1 className=\"text-h1 tracking-[-1.12px] text-ods-text-primary flex items-center gap-3\">\n {hero.icon}\n {section.hero.title}\n </h1>\n <p className=\"font-['DM_Sans'] font-medium text-[18px] leading-[28px] text-ods-text-secondary max-w-3xl\">\n {hero.description}\n </p>\n </div>\n ) : (\n <div className=\"flex items-center justify-between w-full\">\n <h2 className=\"font-['Azeret_Mono'] font-semibold text-[32px] md:text-[40px] lg:text-[48px] leading-[40px] md:leading-[48px] lg:leading-[56px] text-ods-text-primary tracking-[-0.64px] md:tracking-[-0.8px] lg:tracking-[-0.96px]\">\n {section.hero.title}\n <span className=\"text-ods-accent\">:</span>\n </h2>\n </div>\n )}\n\n {preControls}\n\n {(search || filter) && (\n <div className=\"space-y-4\">\n {search && (\n <SearchInput\n showDropdown={false}\n placeholder={search.placeholder}\n value={searchValue}\n onChange={setSearchValue}\n onSubmit={handleSearchSubmit}\n />\n )}\n {filter && (\n <StatusFilterComponent\n selectedStatus={currentFilterValue}\n onStatusChange={handleFilterChange}\n statusOptions={[...filter.options]}\n />\n )}\n </div>\n )}\n\n {children}\n </div>\n );\n}\n","'use client';\n\n/**\n * DevSectionPage — full-page wrapper for a dev-center section\n * (`/roadmap`, `/bug-fixes-and-enhancements`, `/releases`).\n *\n * Mounts the lib's canonical `PageLayout` directly (no in-app wrapper)\n * so the back-button affordance stays in lockstep with whatever the\n * design system ships — any future lib change to BackButton / TitleBlock\n * propagates automatically.\n *\n * Composition: `PageShell` → `PageLayout` (back-to-home wired) →\n * `DevSectionView` (icon hero + search + filter pills) → list body.\n *\n * Adding a new section is one entry in `OPENFRAME_DEV_SECTIONS` plus a\n * single-line page file mounting this factory with the new key.\n */\n\nimport type { ReactNode } from 'react';\nimport { useRouter } from '../../../embed-shims/next-navigation';\nimport { PageShell, PageLayout } from '../../ui';\nimport { DevSectionView } from './dev-section-view';\nimport {\n OPENFRAME_DEV_SECTIONS,\n type OpenframeDevSectionKey,\n} from '../../../utils/dev-sections/openframe-dev-sections';\n\nconst SECTION_HERO_ICON_CLASS = 'h-10 w-10 text-ods-accent';\n\nexport interface DevSectionPageProps {\n sectionKey: OpenframeDevSectionKey;\n /** The page-specific list body (e.g. `<RoadmapList />`). */\n children: ReactNode;\n /** Optional slot rendered BETWEEN the hero and search/filter — see\n * `DevSectionView.preControls`. Used by surfaces that want an entry\n * action (e.g. Help Center's \"Open a new ticket\" form) above the\n * controls instead of below them. */\n preControls?: ReactNode;\n /** Back-button config — same shape as `LegalDocumentPage` /\n * `ReleaseDetailPage`. Pass `false` to hide. Default\n * `{ label: 'Back to home', href: '/' }`. */\n backButton?: { label?: string; href?: string } | false;\n}\n\nexport function DevSectionPage({ sectionKey, children, preControls, backButton }: DevSectionPageProps) {\n const router = useRouter();\n const section = OPENFRAME_DEV_SECTIONS[sectionKey];\n const Icon = section.icon;\n\n // Back-button config — mirrors LegalDocumentPage / ReleaseDetailPage.\n // Default: { label: 'Back to home', href: '/' }. Pass `false` to hide.\n // After `backButton &&` narrowing, inner type is `{ label?, href? } |\n // undefined`; don't re-compare to `false` (TS2367).\n const backCfg =\n backButton === false\n ? undefined\n : {\n label: (backButton ? backButton.label : undefined) ?? 'Back to home',\n onClick: () => router.push((backButton ? backButton.href : undefined) ?? '/'),\n };\n\n return (\n <PageShell>\n <PageLayout backButton={backCfg}>\n <DevSectionView\n sectionKey={sectionKey}\n hero={{\n icon: <Icon className={SECTION_HERO_ICON_CLASS} />,\n description: section.hero.description,\n }}\n preControls={preControls}\n >\n {children}\n </DevSectionView>\n </PageLayout>\n </PageShell>\n );\n}\n","'use client';\n\n/**\n * Shared row chrome for any `DevSectionPage` list (delivery, tickets,\n * future sections). One source of truth for the layout that every\n * dev-section card row uses:\n * left column → title (h3) / subtitle (h5 uppercase) / description\n * (h4 line-clamp-3), each in a fixed min-height block\n * so rows align across the grid\n * right column → caller-supplied stacked badges\n *\n * Surface stays small on purpose — `rightBadges` is a `ReactNode` so\n * the caller decides how many badges (delivery: 2, tickets: 1-2,\n * future: anything). No behavior baked in: the caller wraps the row\n * in a `<div>` (static, like delivery) or `<button>` (clickable, like\n * tickets) and renders the row content via this component.\n *\n * Pair with `DevCardRowSkeletonList` for the loading state — the\n * skeleton mirrors the same min-heights so the in-flight UI doesn't\n * shift the layout when real data lands.\n */\n\nimport type { ReactNode } from 'react';\nimport { SquareAvatar } from '../../ui/square-avatar';\nimport {\n TicketAttachmentsList,\n type TicketAttachment,\n} from '../../ui/ticket-attachments-list';\nimport { formatRelativeTime } from '../../../utils/date-utils';\n\nexport interface DevCardRowContentProps {\n title: string;\n /** Single-line uppercase metadata (e.g. \"UPDATED today, #4271, Code review\"). */\n subtitle: string;\n /** 3-line description block. Empty string renders the fallback. */\n description: string;\n /** Fallback copy when `description` is empty. Defaults to a generic\n * string; ticket / delivery surfaces override. */\n emptyDescription?: string;\n /** Right column — caller renders its own stacked badges. */\n rightBadges: ReactNode;\n}\n\nexport function DevCardRowContent({\n title,\n subtitle,\n description,\n emptyDescription = 'No description provided',\n rightBadges,\n}: DevCardRowContentProps) {\n return (\n <div className=\"flex flex-col md:flex-row items-start justify-between gap-[12px] md:gap-[16px] w-full\">\n <div className=\"flex-1 min-w-0 w-full md:w-auto flex flex-col gap-[12px] md:gap-[16px]\">\n <div className=\"min-h-[24px] flex items-center\">\n <h3 className=\"text-h3 text-ods-text-primary tracking-[-0.36px] flex-1 line-clamp-2 md:truncate break-words\">\n {title}\n </h3>\n </div>\n <div className=\"min-h-[20px] flex items-center\">\n <p className=\"text-h5 text-ods-text-secondary uppercase tracking-[-0.28px] truncate\">\n {subtitle}\n </p>\n </div>\n <div className=\"min-h-[72px] flex items-center\">\n <p className=\"text-h4 text-ods-text-secondary line-clamp-3 break-words\">\n {description || emptyDescription}\n </p>\n </div>\n </div>\n <div className=\"flex-shrink-0 self-start flex flex-col gap-2\">\n {rightBadges}\n </div>\n </div>\n );\n}\n\n// ────────────────────────────────────────────────────────────────────────────\n// ConversationCardRow — sibling row variant for thread-style conversation\n// surfaces (ticket detail drawer, future inbox replies, etc.). Shares the\n// outer chrome (`border-b last:border-b-0 p-[12px] md:p-[16px]`) with\n// `DevCardRowContent` so a list mixing both variants stays visually\n// coherent. Internal layout differs because the data shape is different:\n// instead of title/subtitle/description + right-stacked badges, a\n// conversation message has an author (avatar + name + role + timestamp)\n// and a free-form body that should NOT be line-clamped, plus optional\n// attachments rendered via the shared `<TicketAttachmentsList>` so\n// download UX is identical to any other attachments surface in the lib.\n//\n// 2026 conversation-UI best practices applied (UXPin / Salesforce UX /\n// Coveo support-ticket research):\n// - Author identity visible on every turn (avatar + name + role chip)\n// - Threaded single-side layout — best for async business support,\n// not alternating bubbles\n// - Relative timestamp right-aligned, absolute on hover (`title` attr)\n// - Body uses `whitespace-pre-wrap break-words` so multi-line replies\n// and long URLs render without clipping\n// - WCAG 2.2 contrast + 44×44 touch targets enforced by the shared\n// `<TicketAttachmentsList>` download button\n// ────────────────────────────────────────────────────────────────────────────\n\nexport interface ConversationCardRowProps {\n /** Display name of the message author. \"You\" for the current customer,\n * \"Support team\" for any non-customer engagement. */\n author: string;\n /** Optional short role label rendered as an inline chip beside the\n * author name — e.g. \"You\", \"Original message\", \"Resolution\". Keeps\n * the header line scannable on long threads. */\n role?: string;\n /** Avatar image URL. Falls back to `author` initials when missing\n * (initials derived by `<SquareAvatar>` via `getFirstLastInitials`). */\n avatarSrc?: string;\n /** ISO timestamp. Renders via `formatRelativeTime` with the absolute\n * string in the `title` for hover-precision. `null`/`undefined`\n * hides the timestamp entirely (e.g. the original ticket body which\n * shares the ticket's `created_at`). */\n timestamp?: string | null;\n /** Free-form message body. Empty string + zero attachments renders\n * nothing (the row is skipped at the caller level). */\n body: string;\n /** Files attached to this message. Rendered through the lib's\n * `<TicketAttachmentsList>` so the chip styling, file-icon picker\n * and download button match every other attachments surface. */\n attachments?: TicketAttachment[];\n /** Author bucket — kept for semantic markup + future styling needs.\n * Does NOT drive avatar color anymore: the avatar always renders\n * with the canonical `<SquareAvatar>` defaults (ODS palette,\n * derived by the component itself). Adding bespoke bg-color\n * overrides per role drifted from the ODS theme and was reverted. */\n variant?: 'current-user' | 'support';\n}\n\nexport function ConversationCardRow({\n author,\n role,\n avatarSrc,\n timestamp,\n body,\n attachments,\n variant = 'support',\n}: ConversationCardRowProps) {\n const hasBody = body.trim().length > 0;\n const hasAttachments = !!attachments && attachments.length > 0;\n if (!hasBody && !hasAttachments) return null;\n\n const relativeTime = timestamp ? formatRelativeTime(timestamp) : null;\n\n return (\n <article\n className=\"border-b border-ods-border last:border-b-0 p-[12px] md:p-[16px] flex gap-[12px] md:gap-[16px] w-full\"\n aria-label={`${author}${relativeTime ? ` · ${relativeTime}` : ''}`}\n >\n {/* Avatar — canonical `<SquareAvatar>` with NO className override.\n Color, border, and fallback styling all come from the ODS\n theme defaults (`bg-ods-bg` + `border-ods-border` +\n `text-ods-text-primary`). Per-role bespoke colors\n (bg-ods-flamingo-pink for customer / bg-ods-flamingo-cyan\n for support) were tried + reverted — they drifted from the\n standard theme and broke parity with other surfaces that\n use SquareAvatar without overrides (assignee-dropdown,\n ticket-info-section). */}\n <SquareAvatar\n src={avatarSrc}\n alt={author}\n fallback={author}\n size=\"sm\"\n variant=\"round\"\n />\n\n <div className=\"flex-1 min-w-0 flex flex-col gap-[8px] md:gap-[12px]\">\n {/* Header row — author + optional role chip on the left,\n relative time on the right. The header collapses cleanly on\n narrow viewports by wrapping. */}\n <div className=\"flex items-baseline justify-between gap-[8px] flex-wrap\">\n <div className=\"flex items-baseline gap-[8px] min-w-0\">\n <h3 className=\"text-h4 text-ods-text-primary truncate\">{author}</h3>\n {role && (\n <span className=\"text-h6 text-ods-text-secondary uppercase tracking-[-0.28px] shrink-0\">\n {role}\n </span>\n )}\n </div>\n {relativeTime && (\n <time\n className=\"text-h6 text-ods-text-secondary uppercase tracking-[-0.28px] shrink-0\"\n dateTime={timestamp ?? undefined}\n title={timestamp ?? undefined}\n >\n {relativeTime}\n </time>\n )}\n </div>\n\n {/* Body — full message, no line-clamp. `pre-wrap` preserves\n authored line breaks; `break-words` handles long URLs. */}\n {hasBody && (\n <p className=\"text-h4 text-ods-text-primary whitespace-pre-wrap break-words\">\n {body}\n </p>\n )}\n\n {/* Attachments — delegated to the canonical lib component so\n every file-attachment surface (chat, drawer, future inbox)\n shares the same chip styling + download UX. */}\n {hasAttachments && <TicketAttachmentsList attachments={attachments!} />}\n </div>\n </article>\n );\n}\n\n/**\n * Skeleton variant matching `ConversationCardRow`'s layout. Used by\n * the ticket-detail-drawer's timeline panel while engagements load —\n * mirrors avatar + header + body so the loading→loaded swap doesn't\n * reshape the row vertically.\n */\nexport function ConversationCardRowSkeleton() {\n return (\n <div className=\"border-b border-ods-border last:border-b-0 p-[12px] md:p-[16px] flex gap-[12px] md:gap-[16px] w-full\">\n {/* Avatar — matches SquareAvatar size=\"sm\" (32px) used by the\n real row. Round to match `variant=\"round\"`. */}\n <div className=\"h-8 w-8 shrink-0 rounded-full bg-ods-border animate-pulse\" />\n <div className=\"flex-1 min-w-0 flex flex-col gap-[8px] md:gap-[12px]\">\n {/* Header row — author + role chip + timestamp placeholders. */}\n <div className=\"flex items-baseline justify-between gap-[8px]\">\n <div className=\"flex items-baseline gap-[8px] flex-1\">\n <div className=\"h-[24px] w-32 bg-ods-border rounded animate-pulse\" />\n <div className=\"h-[20px] w-16 bg-ods-border rounded animate-pulse\" />\n </div>\n <div className=\"h-[20px] w-20 bg-ods-border rounded animate-pulse shrink-0\" />\n </div>\n {/* Body — two-line placeholder. */}\n <div className=\"space-y-2\">\n <div className=\"h-[20px] w-full bg-ods-border rounded animate-pulse\" />\n <div className=\"h-[20px] w-3/4 bg-ods-border rounded animate-pulse\" />\n </div>\n </div>\n </div>\n );\n}\n\n/** Multi-row skeleton list — drop-in for the conversation timeline's\n * loading state. Defaults to 2 rows so the placeholder fits in a\n * reasonable vertical footprint without dominating the drawer. */\nexport function ConversationCardRowSkeletonList({ rows = 2 }: { rows?: number }) {\n return (\n <div className=\"bg-ods-card border border-ods-border rounded-[6px] overflow-hidden w-full\">\n {Array.from({ length: rows }, (_, i) => (\n <ConversationCardRowSkeleton key={i} />\n ))}\n </div>\n );\n}\n\n/**\n * Skeleton rendering for a single row — the bars mirror the same\n * min-heights as `DevCardRowContent` so the loading→loaded swap\n * doesn't reflow.\n */\nexport function DevCardRowSkeleton() {\n return (\n <div className=\"border-b border-ods-border last:border-b-0 p-[12px] md:p-[16px]\">\n <div className=\"flex flex-col md:flex-row items-start justify-between gap-[12px] md:gap-[16px] w-full\">\n <div className=\"flex-1 min-w-0 w-full md:w-auto flex flex-col gap-[12px] md:gap-[16px]\">\n <div className=\"min-h-[24px] flex items-center\">\n <div className=\"h-[20px] bg-ods-border rounded animate-pulse w-full\" />\n </div>\n <div className=\"min-h-[20px] flex items-center\">\n <div className=\"h-[20px] bg-ods-border rounded animate-pulse w-1/2\" />\n </div>\n <div className=\"min-h-[72px] flex items-center\">\n <div className=\"flex-1 space-y-1\">\n <div className=\"h-[20px] bg-ods-border rounded animate-pulse w-full\" />\n <div className=\"h-[20px] bg-ods-border rounded animate-pulse w-full\" />\n <div className=\"h-[20px] bg-ods-border rounded animate-pulse w-2/3\" />\n </div>\n </div>\n </div>\n <div className=\"flex-shrink-0 self-start flex flex-col gap-2\">\n <div className=\"h-[32px] w-[100px] bg-ods-border rounded animate-pulse\" />\n <div className=\"h-[32px] w-[120px] bg-ods-border rounded animate-pulse\" />\n </div>\n </div>\n </div>\n );\n}\n\n/**\n * The standard \"5 skeleton rows inside a bordered card\" loading state\n * used by every list shell. Both delivery (`delivery-table.tsx`) and\n * tickets (`tickets-list.tsx`) mount this directly.\n */\nexport function DevCardRowSkeletonList({ rows = 5 }: { rows?: number }) {\n return (\n <div className=\"bg-ods-card border border-ods-border rounded-[6px] overflow-hidden w-full\">\n {Array.from({ length: rows }, (_, i) => (\n <DevCardRowSkeleton key={i} />\n ))}\n </div>\n );\n}\n","'use client'\n\n/**\n * `<DeliveryRow />` — canonical single-row presentation for a ClickUp\n * delivery item.\n *\n * Single source of truth: both the `/bug-fixes-and-enhancements` page\n * (via `DeliveryTable`) AND the linked-delivery card on a HubSpot ticket\n * (via `TicketLinkedDeliveryCard`) compose this primitive. Visual parity\n * across those two surfaces is the design goal — the user reads the\n * card on their ticket and recognises it as a row from the public\n * delivery list.\n *\n * Behaviors:\n * - `href` set → outer element is an `<a>`, the whole row becomes\n * clickable (used by the linked-card surface to deep-link into\n * `/bug-fixes-and-enhancements?focus=<id>`).\n * - `id` set → outer element gets that DOM id so the consuming page\n * can `scrollIntoView` to it when the URL carries `?focus=<id>`.\n * - `highlighted` true → brief accent border + background pulse\n * (`animate-flash-focus` keyframe defined in `tailwind.config.ts`).\n * - `caption` set → small uppercase label rendered above the title\n * (\"LINKED DELIVERY\" on the ticket-side variant). Omitted on the\n * standard list rendering.\n */\n\nimport * as React from 'react'\nimport Link from '../../../embed-shims/next-link'\nimport { StatusBadge } from '../../ui/status-badge'\nimport { getStatusColorScheme } from '../../../utils'\nimport {\n type DeliveryItem,\n TASK_TYPE_LABELS,\n TASK_TYPE_TEXT_COLORS,\n} from '../../../types/delivery'\nimport { cn } from '../../../utils/cn'\n\n/** Same heuristic as DeliveryTable's local helper. Inlined so the row\n * primitive owns its complete rendering contract. */\nfunction getRelativeTime(timestamp: number): string {\n const now = Date.now()\n const diff = now - timestamp\n const days = Math.floor(diff / (1000 * 60 * 60 * 24))\n const weeks = Math.floor(days / 7)\n const months = Math.floor(days / 30)\n if (months > 0) return months === 1 ? 'last month' : `${months} months ago`\n if (weeks > 0) return weeks === 1 ? 'last week' : `${weeks} weeks ago`\n if (days > 0) return days === 1 ? 'yesterday' : `${days} days ago`\n return 'today'\n}\n\nexport interface DeliveryRowProps {\n item: DeliveryItem\n /** When set, the row becomes a clickable anchor. The ticket-side\n * linked-card composes this from `buildDevSectionUrl('delivery', id)`\n * which carries `?search=<id>` — the delivery list filters to that\n * exact task on landing (canonical deep-link mechanism, same one\n * the chat-inline delivery card uses). */\n href?: string\n /** Small uppercase caption rendered above the title. Used by the\n * linked-delivery card variant (\"LINKED DELIVERY\"). */\n caption?: string\n className?: string\n}\n\nexport function DeliveryRow({\n item,\n href,\n caption,\n className,\n}: DeliveryRowProps) {\n const taskType = item.taskType as keyof typeof TASK_TYPE_LABELS\n const typeBadgeLabel = TASK_TYPE_LABELS[taskType] || 'TASK'\n const typeBadgeTextColor = TASK_TYPE_TEXT_COLORS[taskType] || ''\n const statusBadgeScheme = getStatusColorScheme(item.status)\n const relativeTime = getRelativeTime(item.dateUpdated)\n const subtitle = `ACTIVE ${relativeTime}${item.listNames.length > 0 ? `, ${item.listNames.join(', ')}` : ''}, ${item.id}`\n\n const inner = (\n <div className=\"flex flex-col md:flex-row items-start justify-between gap-[12px] md:gap-[16px] w-full\">\n {/* Left: caption (optional) + title + subtitle + description */}\n <div className=\"flex-1 min-w-0 w-full md:w-auto flex flex-col gap-[12px] md:gap-[16px]\">\n {caption && (\n <p className=\"text-xs font-medium uppercase tracking-wider text-ods-text-secondary\">\n {caption}\n </p>\n )}\n <div className=\"min-h-[24px] md:min-h-[24px] flex items-center\">\n <h3 className=\"text-h3 text-ods-text-primary tracking-[-0.36px] flex-1 line-clamp-2 md:truncate break-words\">\n {item.title}\n </h3>\n </div>\n <div className=\"min-h-[20px] flex items-center\">\n <p className=\"text-h5 text-ods-text-secondary uppercase tracking-[-0.28px] truncate\">\n {subtitle}\n </p>\n </div>\n <div className=\"min-h-[72px] flex items-center\">\n <p className=\"text-h4 text-ods-text-secondary line-clamp-3 break-words\">\n {item.description || 'No description provided'}\n </p>\n </div>\n </div>\n\n {/* Right: status + task-type badges */}\n <div className=\"flex-shrink-0 self-start flex flex-col gap-2\">\n <StatusBadge\n text={item.status.toUpperCase()}\n colorScheme={statusBadgeScheme}\n variant=\"card\"\n className=\"border border-ods-border\"\n />\n <StatusBadge\n text={typeBadgeLabel}\n variant=\"card\"\n className={`border border-ods-border ${typeBadgeTextColor}`}\n />\n </div>\n </div>\n )\n\n const baseClass = cn(\n 'block p-[12px] md:p-[16px] no-underline text-inherit transition-colors duration-150',\n href && 'hover:bg-ods-bg-hover cursor-pointer',\n className,\n )\n\n if (href) {\n // `Link` is the env-aware embed-shim — delegates to `next/link` on\n // a Next.js host (soft RSC nav, back-button restores the previous\n // page's React state intact), falls back to a plain `<a>` on\n // non-Next embedders. A raw `<a href>` was hard-navigating +\n // losing TanStack-Query state on back, leaving /tickets stuck on\n // its skeleton.\n return (\n <Link href={href} className={baseClass} prefetch={false}>\n {inner}\n </Link>\n )\n }\n\n return <div className={baseClass}>{inner}</div>\n}\n"]}
1
+ {"version":3,"sources":["/home/runner/work/openframe-oss-lib/openframe-oss-lib/openframe-frontend-core/dist/chunk-ZFBLC5GV.cjs","../src/components/unified-pagination.tsx","../src/components/empty-state.tsx","../src/components/shared/dev-section/dev-section-view.tsx","../src/components/shared/dev-section/dev-section-page.tsx","../src/components/shared/dev-section/dev-card-row.tsx","../src/components/shared/delivery/delivery-row.tsx"],"names":["jsx","jsxs"],"mappings":"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","file":"/home/runner/work/openframe-oss-lib/openframe-oss-lib/openframe-frontend-core/dist/chunk-ZFBLC5GV.cjs","sourcesContent":[null,"\"use client\"\n\nimport { useRouter, useSearchParams, usePathname } from \"../embed-shims/next-navigation\"\nimport { Pagination } from \"./pagination\"\n\ninterface UnifiedPaginationProps {\n currentPage: number\n totalPages: number\n onPageChange?: (page: number) => void\n className?: string\n}\n\nexport function UnifiedPagination({ \n currentPage, \n totalPages, \n onPageChange,\n className = \"mt-8 flex justify-center w-full\"\n}: UnifiedPaginationProps) {\n const router = useRouter()\n const searchParams = useSearchParams()\n const pathname = usePathname()\n\n const handlePageChange = (page: number) => {\n // Preserve current scroll position\n const currentScrollY = window.scrollY\n \n // Call the callback to update local state (prevents reload)\n if (onPageChange) {\n onPageChange(page)\n }\n \n // Update URL for bookmarking without navigation\n const params = new URLSearchParams(searchParams.toString())\n params.set(\"page\", page.toString())\n \n // Update URL without navigation (for bookmarking support)\n const newUrl = `${pathname}?${params.toString()}`\n window.history.replaceState(null, '', newUrl)\n \n // Restore scroll position after a brief delay to allow content to render\n setTimeout(() => {\n window.scrollTo({\n top: currentScrollY,\n behavior: 'instant' // Instant to prevent any scroll animation\n })\n }, 0)\n }\n\n // Don't render pagination if there's only one page\n if (totalPages <= 1) return null\n\n return (\n <div className={className}>\n <Pagination\n currentPage={currentPage}\n totalPages={totalPages}\n onPageChange={handlePageChange}\n />\n </div>\n )\n} ","\"use client\";\n\nimport { Search, FileText, Package } from \"lucide-react\"\nimport { Button } from \"./ui/button\"\nimport { useRouter } from \"../embed-shims/next-navigation\"\n\nexport interface EmptyStateProps {\n type: 'vendors' | 'posts' | 'search' | 'generic'\n title?: string\n description?: string\n showBackButton?: boolean\n onGoBack?: () => void\n backButtonText?: string\n // New CTA properties\n showCTA?: boolean\n ctaText?: string\n onCtaClick?: () => void\n ctaVariant?: 'primary' | 'secondary'\n}\n\nexport function EmptyState({\n type,\n title,\n description,\n showBackButton = false,\n onGoBack,\n backButtonText = \"Go Back\",\n showCTA = true,\n ctaText,\n onCtaClick,\n ctaVariant = 'primary'\n}: EmptyStateProps) {\n const router = useRouter()\n\n // Default content based on type\n const getDefaultContent = () => {\n switch (type) {\n case 'vendors':\n return {\n icon: <Package className=\"w-full h-full\" />,\n title: \"No vendors found\",\n description: \"We couldn't find any vendors matching your criteria. Try adjusting your filters or search terms.\"\n }\n case 'posts':\n return {\n icon: <FileText className=\"w-full h-full\" />,\n title: \"No articles found\",\n description: \"We couldn't find any articles matching your criteria. Try different categories, tags, or search terms.\"\n }\n case 'search':\n return {\n icon: <Search className=\"w-full h-full\" />,\n title: \"No results found\",\n description: \"Your search didn't return any results. Try different keywords or browse our categories.\"\n }\n default:\n return {\n icon: <Search className=\"w-full h-full\" />,\n title: \"Nothing found\",\n description: \"We couldn't find what you're looking for. Try adjusting your search or filters.\"\n }\n }\n }\n\n // Smart CTA logic based on context\n const getSmartCTA = () => {\n // If custom CTA is provided, use it\n if (ctaText && onCtaClick) {\n return {\n text: ctaText,\n action: onCtaClick\n }\n }\n\n // Check if we're on the client side\n const isClient = typeof window !== 'undefined'\n const currentPath = isClient ? window.location.pathname : ''\n\n // Smart defaults based on type and context\n switch (type) {\n case 'search':\n return {\n text: \"Reset Filters\",\n action: () => {\n if (isClient) {\n // Try to reset search by clearing URL params and refreshing\n const url = new URL(window.location.href)\n url.search = ''\n router.push(url.pathname)\n }\n }\n }\n case 'posts':\n // If we're on blog/community pages, reset blog filters\n if (currentPath.includes('/blog')) {\n return {\n text: \"Reset Filters\",\n action: () => {\n if (isClient) {\n // Reset blog search and filters by clearing URL params\n const url = new URL(window.location.href)\n url.search = ''\n router.push(url.pathname)\n }\n }\n }\n } else if (currentPath.includes('/profile')) {\n return {\n text: \"Browse Vendors\",\n action: () => router.push('/vendors')\n }\n }\n return {\n text: \"View All Posts\",\n action: () => router.push('/blog')\n }\n case 'vendors':\n // If we're in profile or other pages, direct to main content\n if (currentPath.includes('/profile')) {\n return {\n text: \"Browse Vendors\",\n action: () => router.push('/vendors')\n }\n } else if (currentPath.includes('/vendors') || currentPath.includes('/margin-increase/compare')) {\n return {\n text: \"Reset Filters\",\n action: () => {\n if (isClient) {\n // Reset vendor search and filters by clearing URL params\n const url = new URL(window.location.href)\n url.search = ''\n router.push(url.pathname)\n }\n }\n }\n }\n return {\n text: \"Browse Vendors\",\n action: () => router.push('/vendors')\n }\n default:\n return {\n text: \"Browse Vendors\",\n action: () => router.push('/vendors')\n }\n }\n }\n\n const defaultContent = getDefaultContent()\n const displayTitle = title || defaultContent.title\n const displayDescription = description || defaultContent.description\n const smartCTA = getSmartCTA()\n\n return (\n <div className=\"flex flex-col items-center justify-center py-6 md:py-16 px-6 text-center\">\n {/* Icon */}\n <div className=\"mb-3 md:mb-6 flex items-center justify-center\">\n <div className=\"rounded-full bg-ods-card p-3 md:p-6 border border-ods-border\">\n <div className=\"w-8 h-8 md:w-16 md:h-16 text-ods-text-secondary flex items-center justify-center\">\n {defaultContent.icon}\n </div>\n </div>\n </div>\n\n {/* Title */}\n <h2 className=\"mb-2 md:mb-3 text-lg md:text-xl font-semibold font-['DM_Sans'] text-ods-text-primary tracking-[-0.02em]\">\n {displayTitle}\n </h2>\n\n {/* Description */}\n <p className=\"mb-4 md:mb-8 max-w-md text-sm font-medium font-['DM_Sans'] text-ods-text-secondary leading-[1.43em]\">\n {displayDescription}\n </p>\n\n {/* Smart CTA Button */}\n {showCTA && smartCTA && (\n <div className=\"w-full max-w-xs mb-3\">\n <Button\n onClick={smartCTA.action}\n className={ctaVariant === 'primary' \n ? \"w-full bg-[#FFC008] text-black hover:bg-[#FFC008]/90 transition-all duration-150 font-['DM_Sans'] font-medium\"\n : \"w-full bg-transparent border border-ods-border text-ods-text-primary hover:border-[#FFC008] hover:text-ods-accent transition-all duration-150 font-['DM_Sans'] font-medium\"\n }\n >\n {smartCTA.text}\n </Button>\n </div>\n )}\n\n {/* Optional Back Button */}\n {showBackButton && onGoBack && (\n <div className=\"w-full max-w-xs\">\n <Button\n onClick={onGoBack}\n variant=\"outline\"\n className=\"w-full transition-all duration-150 font-['DM_Sans'] font-medium\"\n >\n {backButtonText}\n </Button>\n </div>\n )}\n </div>\n )\n} ","'use client';\n\n/**\n * DevSectionView — the canonical chrome for ANY dev-center section\n * (Roadmap / Delivery / Releases). One component, used in BOTH:\n *\n * - tabbed `/roadmap-and-releases` (compact title mode, no `hero`)\n * - full-page `/roadmap`, `/bug-fixes-and-enhancements`, `/releases`\n * (hero mode with icon + description + back link)\n *\n * Owns: title rendering, the inline search input, the filter pill row,\n * and the URL-param wiring that connects both. The list `children`\n * receive a clean URL contract — they read `?<paramKey>=...` via\n * `useSearchParams()` and refetch on change. No duplicated controls.\n */\n\nimport type { ReactNode } from 'react';\nimport { useState, useEffect } from 'react';\nimport { useRouter, useSearchParams, usePathname } from '../../../embed-shims';\nimport { SearchInput } from '../../ui';\nimport { StatusFilterComponent } from '../../features';\nimport {\n OPENFRAME_DEV_SECTIONS,\n type OpenframeDevSectionKey,\n} from '../../../utils/dev-sections/openframe-dev-sections';\n\nexport interface DevSectionViewProps {\n /** Which section to render — drives title, search, and filter\n * config via the `OPENFRAME_DEV_SECTIONS` registry. */\n sectionKey: OpenframeDevSectionKey;\n /** When set, renders the rich page-level hero (icon + h1 + description).\n * Omit for the compact tab-context heading. */\n hero?: {\n /** Pre-rendered icon JSX. Server components render the icon themselves\n * and pass the element here — function references can't cross the\n * server→client boundary, but React elements can. */\n icon: ReactNode;\n description: string;\n };\n /** Optional slot rendered BETWEEN the hero and the search/filter\n * controls. Use this for an entry-action surface that should sit\n * above the list (e.g. the Help Center's \"Open a new ticket\" form).\n * The slot is wrapped in the same `gap-10` flex column so spacing\n * matches the surrounding chrome — callers should NOT add their\n * own top/bottom margin. Renders `null` (no DOM) when omitted. */\n preControls?: ReactNode;\n /** The page-specific list body. Reads URL params written by this\n * component (search input + filter pills). */\n children: ReactNode;\n}\n\nexport function DevSectionView({ sectionKey, hero, preControls, children }: DevSectionViewProps) {\n const section = OPENFRAME_DEV_SECTIONS[sectionKey];\n const router = useRouter();\n const pathname = usePathname();\n const searchParams = useSearchParams();\n\n const search = section.search;\n const filter = section.filter;\n\n const currentSearch = search ? searchParams.get(search.paramKey) || '' : '';\n const currentFilterValue = filter\n ? searchParams.get(filter.paramKey) || filter.defaultValue\n : '';\n\n // Controlled search-input state — input commits to the URL only on\n // Enter (not on every keystroke), preserving the legacy behavior.\n // Lazy init from URL avoids a brief flash of stale value on first\n // paint after URL-driven re-render (e.g. tab switch).\n const [searchValue, setSearchValue] = useState(() => currentSearch);\n useEffect(() => {\n setSearchValue(currentSearch);\n }, [currentSearch]);\n\n const handleSearchSubmit = (value: string) => {\n if (!search) return;\n const params = new URLSearchParams(searchParams.toString());\n if (value.trim()) params.set(search.paramKey, value.trim());\n else params.delete(search.paramKey);\n router.replace(`${pathname}?${params.toString()}`, { scroll: false });\n };\n\n const handleFilterChange = (value: string) => {\n if (!filter) return;\n const params = new URLSearchParams(searchParams.toString());\n if (value === filter.defaultValue) params.delete(filter.paramKey);\n else params.set(filter.paramKey, value);\n router.replace(`${pathname}?${params.toString()}`, { scroll: false });\n };\n\n return (\n <div className=\"w-full flex flex-col gap-10\">\n {hero ? (\n <div className=\"space-y-4\">\n <h1 className=\"text-h1 tracking-[-1.12px] text-ods-text-primary flex items-center gap-3\">\n {hero.icon}\n {section.hero.title}\n </h1>\n <p className=\"font-['DM_Sans'] font-medium text-[18px] leading-[28px] text-ods-text-secondary max-w-3xl\">\n {hero.description}\n </p>\n </div>\n ) : (\n <div className=\"flex items-center justify-between w-full\">\n <h2 className=\"font-['Azeret_Mono'] font-semibold text-[32px] md:text-[40px] lg:text-[48px] leading-[40px] md:leading-[48px] lg:leading-[56px] text-ods-text-primary tracking-[-0.64px] md:tracking-[-0.8px] lg:tracking-[-0.96px]\">\n {section.hero.title}\n <span className=\"text-ods-accent\">:</span>\n </h2>\n </div>\n )}\n\n {preControls}\n\n {(search || filter) && (\n <div className=\"space-y-4\">\n {search && (\n <SearchInput\n showDropdown={false}\n placeholder={search.placeholder}\n value={searchValue}\n onChange={setSearchValue}\n onSubmit={handleSearchSubmit}\n />\n )}\n {filter && (\n <StatusFilterComponent\n selectedStatus={currentFilterValue}\n onStatusChange={handleFilterChange}\n statusOptions={[...filter.options]}\n />\n )}\n </div>\n )}\n\n {children}\n </div>\n );\n}\n","'use client';\n\n/**\n * DevSectionPage — full-page wrapper for a dev-center section\n * (`/roadmap`, `/bug-fixes-and-enhancements`, `/releases`).\n *\n * Mounts the lib's canonical `PageLayout` directly (no in-app wrapper)\n * so the back-button affordance stays in lockstep with whatever the\n * design system ships — any future lib change to BackButton / TitleBlock\n * propagates automatically.\n *\n * Composition: `PageShell` → `PageLayout` (back-to-home wired) →\n * `DevSectionView` (icon hero + search + filter pills) → list body.\n *\n * Adding a new section is one entry in `OPENFRAME_DEV_SECTIONS` plus a\n * single-line page file mounting this factory with the new key.\n */\n\nimport type { ReactNode } from 'react';\nimport { useRouter } from '../../../embed-shims/next-navigation';\nimport { PageShell, PageLayout } from '../../ui';\nimport { DevSectionView } from './dev-section-view';\nimport {\n OPENFRAME_DEV_SECTIONS,\n type OpenframeDevSectionKey,\n} from '../../../utils/dev-sections/openframe-dev-sections';\n\nconst SECTION_HERO_ICON_CLASS = 'h-10 w-10 text-ods-accent';\n\nexport interface DevSectionPageProps {\n sectionKey: OpenframeDevSectionKey;\n /** The page-specific list body (e.g. `<RoadmapList />`). */\n children: ReactNode;\n /** Optional slot rendered BETWEEN the hero and search/filter — see\n * `DevSectionView.preControls`. Used by surfaces that want an entry\n * action (e.g. Help Center's \"Open a new ticket\" form) above the\n * controls instead of below them. */\n preControls?: ReactNode;\n /** Back-button config — same shape as `LegalDocumentPage` /\n * `ReleaseDetailPage`. Pass `false` to hide. Default\n * `{ label: 'Back to home', href: '/' }`. */\n backButton?: { label?: string; href?: string } | false;\n}\n\nexport function DevSectionPage({ sectionKey, children, preControls, backButton }: DevSectionPageProps) {\n const router = useRouter();\n const section = OPENFRAME_DEV_SECTIONS[sectionKey];\n const Icon = section.icon;\n\n // Back-button config — mirrors LegalDocumentPage / ReleaseDetailPage.\n // Default: { label: 'Back to home', href: '/' }. Pass `false` to hide.\n // After `backButton &&` narrowing, inner type is `{ label?, href? } |\n // undefined`; don't re-compare to `false` (TS2367).\n const backCfg =\n backButton === false\n ? undefined\n : {\n label: (backButton ? backButton.label : undefined) ?? 'Back to home',\n onClick: () => router.push((backButton ? backButton.href : undefined) ?? '/'),\n };\n\n return (\n <PageShell>\n <PageLayout backButton={backCfg}>\n <DevSectionView\n sectionKey={sectionKey}\n hero={{\n icon: <Icon className={SECTION_HERO_ICON_CLASS} />,\n description: section.hero.description,\n }}\n preControls={preControls}\n >\n {children}\n </DevSectionView>\n </PageLayout>\n </PageShell>\n );\n}\n","'use client';\n\n/**\n * Shared row chrome for any `DevSectionPage` list (delivery, tickets,\n * future sections). One source of truth for the layout that every\n * dev-section card row uses:\n * left column → title (h3) / subtitle (h5 uppercase) / description\n * (h4 line-clamp-3), each in a fixed min-height block\n * so rows align across the grid\n * right column → caller-supplied stacked badges\n *\n * Surface stays small on purpose — `rightBadges` is a `ReactNode` so\n * the caller decides how many badges (delivery: 2, tickets: 1-2,\n * future: anything). No behavior baked in: the caller wraps the row\n * in a `<div>` (static, like delivery) or `<button>` (clickable, like\n * tickets) and renders the row content via this component.\n *\n * Pair with `DevCardRowSkeletonList` for the loading state — the\n * skeleton mirrors the same min-heights so the in-flight UI doesn't\n * shift the layout when real data lands.\n */\n\nimport type { ReactNode } from 'react';\nimport { SquareAvatar } from '../../ui/square-avatar';\nimport {\n TicketAttachmentsList,\n type TicketAttachment,\n} from '../../ui/ticket-attachments-list';\nimport { formatRelativeTime } from '../../../utils/date-utils';\n\nexport interface DevCardRowContentProps {\n title: string;\n /** Single-line uppercase metadata (e.g. \"UPDATED today, #4271, Code review\"). */\n subtitle: string;\n /** 3-line description block. Empty string renders the fallback. */\n description: string;\n /** Fallback copy when `description` is empty. Defaults to a generic\n * string; ticket / delivery surfaces override. */\n emptyDescription?: string;\n /** Right column — caller renders its own stacked badges. */\n rightBadges: ReactNode;\n}\n\nexport function DevCardRowContent({\n title,\n subtitle,\n description,\n emptyDescription = 'No description provided',\n rightBadges,\n}: DevCardRowContentProps) {\n return (\n <div className=\"flex flex-col md:flex-row items-start justify-between gap-[12px] md:gap-[16px] w-full\">\n <div className=\"flex-1 min-w-0 w-full md:w-auto flex flex-col gap-[12px] md:gap-[16px]\">\n <div className=\"min-h-[24px] flex items-center\">\n <h3 className=\"text-h3 text-ods-text-primary tracking-[-0.36px] flex-1 line-clamp-2 md:truncate break-words\">\n {title}\n </h3>\n </div>\n <div className=\"min-h-[20px] flex items-center\">\n <p className=\"text-h5 text-ods-text-secondary uppercase tracking-[-0.28px] truncate\">\n {subtitle}\n </p>\n </div>\n <div className=\"min-h-[72px] flex items-center\">\n <p className=\"text-h4 text-ods-text-secondary line-clamp-3 break-words\">\n {description || emptyDescription}\n </p>\n </div>\n </div>\n <div className=\"flex-shrink-0 self-start flex flex-col gap-2\">\n {rightBadges}\n </div>\n </div>\n );\n}\n\n// ────────────────────────────────────────────────────────────────────────────\n// ConversationCardRow — sibling row variant for thread-style conversation\n// surfaces (ticket detail drawer, future inbox replies, etc.). Shares the\n// outer chrome (`border-b last:border-b-0 p-[12px] md:p-[16px]`) with\n// `DevCardRowContent` so a list mixing both variants stays visually\n// coherent. Internal layout differs because the data shape is different:\n// instead of title/subtitle/description + right-stacked badges, a\n// conversation message has an author (avatar + name + role + timestamp)\n// and a free-form body that should NOT be line-clamped, plus optional\n// attachments rendered via the shared `<TicketAttachmentsList>` so\n// download UX is identical to any other attachments surface in the lib.\n//\n// 2026 conversation-UI best practices applied (UXPin / Salesforce UX /\n// Coveo support-ticket research):\n// - Author identity visible on every turn (avatar + name + role chip)\n// - Threaded single-side layout — best for async business support,\n// not alternating bubbles\n// - Relative timestamp right-aligned, absolute on hover (`title` attr)\n// - Body uses `whitespace-pre-wrap break-words` so multi-line replies\n// and long URLs render without clipping\n// - WCAG 2.2 contrast + 44×44 touch targets enforced by the shared\n// `<TicketAttachmentsList>` download button\n// ────────────────────────────────────────────────────────────────────────────\n\nexport interface ConversationCardRowProps {\n /** Display name of the message author. \"You\" for the current customer,\n * \"Support team\" for any non-customer engagement. */\n author: string;\n /** Optional short role label rendered as an inline chip beside the\n * author name — e.g. \"You\", \"Original message\", \"Resolution\". Keeps\n * the header line scannable on long threads. */\n role?: string;\n /** Avatar image URL. Falls back to `author` initials when missing\n * (initials derived by `<SquareAvatar>` via `getFirstLastInitials`). */\n avatarSrc?: string;\n /** ISO timestamp. Renders via `formatRelativeTime` with the absolute\n * string in the `title` for hover-precision. `null`/`undefined`\n * hides the timestamp entirely (e.g. the original ticket body which\n * shares the ticket's `created_at`). */\n timestamp?: string | null;\n /** Free-form message body. Empty string + zero attachments renders\n * nothing (the row is skipped at the caller level). */\n body: string;\n /** Files attached to this message. Rendered through the lib's\n * `<TicketAttachmentsList>` so the chip styling, file-icon picker\n * and download button match every other attachments surface. */\n attachments?: TicketAttachment[];\n /** Author bucket — kept for semantic markup + future styling needs.\n * Does NOT drive avatar color anymore: the avatar always renders\n * with the canonical `<SquareAvatar>` defaults (ODS palette,\n * derived by the component itself). Adding bespoke bg-color\n * overrides per role drifted from the ODS theme and was reverted. */\n variant?: 'current-user' | 'support';\n}\n\nexport function ConversationCardRow({\n author,\n role,\n avatarSrc,\n timestamp,\n body,\n attachments,\n variant = 'support',\n}: ConversationCardRowProps) {\n const hasBody = body.trim().length > 0;\n const hasAttachments = !!attachments && attachments.length > 0;\n if (!hasBody && !hasAttachments) return null;\n\n const relativeTime = timestamp ? formatRelativeTime(timestamp) : null;\n\n return (\n <article\n className=\"border-b border-ods-border last:border-b-0 p-[12px] md:p-[16px] flex gap-[12px] md:gap-[16px] w-full\"\n aria-label={`${author}${relativeTime ? ` · ${relativeTime}` : ''}`}\n >\n {/* Avatar — canonical `<SquareAvatar>` with NO className override.\n Color, border, and fallback styling all come from the ODS\n theme defaults (`bg-ods-bg` + `border-ods-border` +\n `text-ods-text-primary`). Per-role bespoke colors\n (bg-ods-flamingo-pink for customer / bg-ods-flamingo-cyan\n for support) were tried + reverted — they drifted from the\n standard theme and broke parity with other surfaces that\n use SquareAvatar without overrides (assignee-dropdown,\n ticket-info-section). */}\n <SquareAvatar\n src={avatarSrc}\n alt={author}\n fallback={author}\n size=\"sm\"\n variant=\"round\"\n />\n\n <div className=\"flex-1 min-w-0 flex flex-col gap-[8px] md:gap-[12px]\">\n {/* Header row — author + optional role chip on the left,\n relative time on the right. The header collapses cleanly on\n narrow viewports by wrapping. */}\n <div className=\"flex items-baseline justify-between gap-[8px] flex-wrap\">\n <div className=\"flex items-baseline gap-[8px] min-w-0\">\n <h3 className=\"text-h4 text-ods-text-primary truncate\">{author}</h3>\n {role && (\n <span className=\"text-h6 text-ods-text-secondary uppercase tracking-[-0.28px] shrink-0\">\n {role}\n </span>\n )}\n </div>\n {relativeTime && (\n <time\n className=\"text-h6 text-ods-text-secondary uppercase tracking-[-0.28px] shrink-0\"\n dateTime={timestamp ?? undefined}\n title={timestamp ?? undefined}\n >\n {relativeTime}\n </time>\n )}\n </div>\n\n {/* Body — full message, no line-clamp. `pre-wrap` preserves\n authored line breaks; `break-words` handles long URLs. */}\n {hasBody && (\n <p className=\"text-h4 text-ods-text-primary whitespace-pre-wrap break-words\">\n {body}\n </p>\n )}\n\n {/* Attachments — delegated to the canonical lib component so\n every file-attachment surface (chat, drawer, future inbox)\n shares the same chip styling + download UX. */}\n {hasAttachments && <TicketAttachmentsList attachments={attachments!} />}\n </div>\n </article>\n );\n}\n\n/**\n * Skeleton variant matching `ConversationCardRow`'s layout. Used by\n * the ticket-detail-drawer's timeline panel while engagements load —\n * mirrors avatar + header + body so the loading→loaded swap doesn't\n * reshape the row vertically.\n */\nexport function ConversationCardRowSkeleton() {\n return (\n <div className=\"border-b border-ods-border last:border-b-0 p-[12px] md:p-[16px] flex gap-[12px] md:gap-[16px] w-full\">\n {/* Avatar — matches SquareAvatar size=\"sm\" (32px) used by the\n real row. Round to match `variant=\"round\"`. */}\n <div className=\"h-8 w-8 shrink-0 rounded-full bg-ods-border animate-pulse\" />\n <div className=\"flex-1 min-w-0 flex flex-col gap-[8px] md:gap-[12px]\">\n {/* Header row — author + role chip + timestamp placeholders. */}\n <div className=\"flex items-baseline justify-between gap-[8px]\">\n <div className=\"flex items-baseline gap-[8px] flex-1\">\n <div className=\"h-[24px] w-32 bg-ods-border rounded animate-pulse\" />\n <div className=\"h-[20px] w-16 bg-ods-border rounded animate-pulse\" />\n </div>\n <div className=\"h-[20px] w-20 bg-ods-border rounded animate-pulse shrink-0\" />\n </div>\n {/* Body — two-line placeholder. */}\n <div className=\"space-y-2\">\n <div className=\"h-[20px] w-full bg-ods-border rounded animate-pulse\" />\n <div className=\"h-[20px] w-3/4 bg-ods-border rounded animate-pulse\" />\n </div>\n </div>\n </div>\n );\n}\n\n/** Multi-row skeleton list — drop-in for the conversation timeline's\n * loading state. Defaults to 2 rows so the placeholder fits in a\n * reasonable vertical footprint without dominating the drawer. */\nexport function ConversationCardRowSkeletonList({ rows = 2 }: { rows?: number }) {\n return (\n <div className=\"bg-ods-card border border-ods-border rounded-[6px] overflow-hidden w-full\">\n {Array.from({ length: rows }, (_, i) => (\n <ConversationCardRowSkeleton key={i} />\n ))}\n </div>\n );\n}\n\n/**\n * Skeleton rendering for a single row — the bars mirror the same\n * min-heights as `DevCardRowContent` so the loading→loaded swap\n * doesn't reflow.\n */\nexport function DevCardRowSkeleton() {\n return (\n <div className=\"border-b border-ods-border last:border-b-0 p-[12px] md:p-[16px]\">\n <div className=\"flex flex-col md:flex-row items-start justify-between gap-[12px] md:gap-[16px] w-full\">\n <div className=\"flex-1 min-w-0 w-full md:w-auto flex flex-col gap-[12px] md:gap-[16px]\">\n <div className=\"min-h-[24px] flex items-center\">\n <div className=\"h-[20px] bg-ods-border rounded animate-pulse w-full\" />\n </div>\n <div className=\"min-h-[20px] flex items-center\">\n <div className=\"h-[20px] bg-ods-border rounded animate-pulse w-1/2\" />\n </div>\n <div className=\"min-h-[72px] flex items-center\">\n <div className=\"flex-1 space-y-1\">\n <div className=\"h-[20px] bg-ods-border rounded animate-pulse w-full\" />\n <div className=\"h-[20px] bg-ods-border rounded animate-pulse w-full\" />\n <div className=\"h-[20px] bg-ods-border rounded animate-pulse w-2/3\" />\n </div>\n </div>\n </div>\n <div className=\"flex-shrink-0 self-start flex flex-col gap-2\">\n <div className=\"h-[32px] w-[100px] bg-ods-border rounded animate-pulse\" />\n <div className=\"h-[32px] w-[120px] bg-ods-border rounded animate-pulse\" />\n </div>\n </div>\n </div>\n );\n}\n\n/**\n * The standard \"5 skeleton rows inside a bordered card\" loading state\n * used by every list shell. Both delivery (`delivery-table.tsx`) and\n * tickets (`tickets-list.tsx`) mount this directly.\n */\nexport function DevCardRowSkeletonList({ rows = 5 }: { rows?: number }) {\n return (\n <div className=\"bg-ods-card border border-ods-border rounded-[6px] overflow-hidden w-full\">\n {Array.from({ length: rows }, (_, i) => (\n <DevCardRowSkeleton key={i} />\n ))}\n </div>\n );\n}\n","'use client'\n\n/**\n * `<DeliveryRow />` — canonical single-row presentation for a ClickUp\n * delivery item.\n *\n * Single source of truth: both the `/bug-fixes-and-enhancements` page\n * (via `DeliveryTable`) AND the linked-delivery card on a HubSpot ticket\n * (via `TicketLinkedDeliveryCard`) compose this primitive. Visual parity\n * across those two surfaces is the design goal — the user reads the\n * card on their ticket and recognises it as a row from the public\n * delivery list.\n *\n * Behaviors:\n * - `href` set → outer element is an `<a>`, the whole row becomes\n * clickable (used by the linked-card surface to deep-link into\n * `/bug-fixes-and-enhancements?focus=<id>`).\n * - `id` set → outer element gets that DOM id so the consuming page\n * can `scrollIntoView` to it when the URL carries `?focus=<id>`.\n * - `highlighted` true → brief accent border + background pulse\n * (`animate-flash-focus` keyframe defined in `tailwind.config.ts`).\n * - `caption` set → small uppercase label rendered above the title\n * (\"LINKED DELIVERY\" on the ticket-side variant). Omitted on the\n * standard list rendering.\n */\n\nimport * as React from 'react'\nimport Link from '../../../embed-shims/next-link'\nimport { StatusBadge } from '../../ui/status-badge'\nimport { getStatusColorScheme } from '../../../utils'\nimport {\n type DeliveryItem,\n TASK_TYPE_LABELS,\n TASK_TYPE_TEXT_COLORS,\n} from '../../../types/delivery'\nimport { cn } from '../../../utils/cn'\n\n/** Same heuristic as DeliveryTable's local helper. Inlined so the row\n * primitive owns its complete rendering contract. */\nfunction getRelativeTime(timestamp: number): string {\n const now = Date.now()\n const diff = now - timestamp\n const days = Math.floor(diff / (1000 * 60 * 60 * 24))\n const weeks = Math.floor(days / 7)\n const months = Math.floor(days / 30)\n if (months > 0) return months === 1 ? 'last month' : `${months} months ago`\n if (weeks > 0) return weeks === 1 ? 'last week' : `${weeks} weeks ago`\n if (days > 0) return days === 1 ? 'yesterday' : `${days} days ago`\n return 'today'\n}\n\nexport interface DeliveryRowProps {\n item: DeliveryItem\n /** When set, the row becomes a clickable anchor. The ticket-side\n * linked-card composes this from `buildDevSectionUrl('delivery', id)`\n * which carries `?search=<id>` — the delivery list filters to that\n * exact task on landing (canonical deep-link mechanism, same one\n * the chat-inline delivery card uses). */\n href?: string\n /** Small uppercase caption rendered above the title. Used by the\n * linked-delivery card variant (\"LINKED DELIVERY\"). */\n caption?: string\n className?: string\n}\n\nexport function DeliveryRow({\n item,\n href,\n caption,\n className,\n}: DeliveryRowProps) {\n const taskType = item.taskType as keyof typeof TASK_TYPE_LABELS\n const typeBadgeLabel = TASK_TYPE_LABELS[taskType] || 'TASK'\n const typeBadgeTextColor = TASK_TYPE_TEXT_COLORS[taskType] || ''\n const statusBadgeScheme = getStatusColorScheme(item.status)\n const relativeTime = getRelativeTime(item.dateUpdated)\n const subtitle = `ACTIVE ${relativeTime}${item.listNames.length > 0 ? `, ${item.listNames.join(', ')}` : ''}, ${item.id}`\n\n const inner = (\n <div className=\"flex flex-col md:flex-row items-start justify-between gap-[12px] md:gap-[16px] w-full\">\n {/* Left: caption (optional) + title + subtitle + description */}\n <div className=\"flex-1 min-w-0 w-full md:w-auto flex flex-col gap-[12px] md:gap-[16px]\">\n {caption && (\n <p className=\"text-xs font-medium uppercase tracking-wider text-ods-text-secondary\">\n {caption}\n </p>\n )}\n <div className=\"min-h-[24px] md:min-h-[24px] flex items-center\">\n <h3 className=\"text-h3 text-ods-text-primary tracking-[-0.36px] flex-1 line-clamp-2 md:truncate break-words\">\n {item.title}\n </h3>\n </div>\n <div className=\"min-h-[20px] flex items-center\">\n <p className=\"text-h5 text-ods-text-secondary uppercase tracking-[-0.28px] truncate\">\n {subtitle}\n </p>\n </div>\n <div className=\"min-h-[72px] flex items-center\">\n <p className=\"text-h4 text-ods-text-secondary line-clamp-3 break-words\">\n {item.description || 'No description provided'}\n </p>\n </div>\n </div>\n\n {/* Right: status + task-type badges */}\n <div className=\"flex-shrink-0 self-start flex flex-col gap-2\">\n <StatusBadge\n text={item.status.toUpperCase()}\n colorScheme={statusBadgeScheme}\n variant=\"card\"\n className=\"border border-ods-border\"\n />\n <StatusBadge\n text={typeBadgeLabel}\n variant=\"card\"\n className={`border border-ods-border ${typeBadgeTextColor}`}\n />\n </div>\n </div>\n )\n\n const baseClass = cn(\n 'block p-[12px] md:p-[16px] no-underline text-inherit transition-colors duration-150',\n href && 'hover:bg-ods-bg-hover cursor-pointer',\n className,\n )\n\n if (href) {\n // `Link` is the env-aware embed-shim — delegates to `next/link` on\n // a Next.js host (soft RSC nav, back-button restores the previous\n // page's React state intact), falls back to a plain `<a>` on\n // non-Next embedders. A raw `<a href>` was hard-navigating +\n // losing TanStack-Query state on back, leaving /tickets stuck on\n // its skeleton.\n return (\n <Link href={href} className={baseClass} prefetch={false}>\n {inner}\n </Link>\n )\n }\n\n return <div className={baseClass}>{inner}</div>\n}\n"]}
@@ -21,4 +21,4 @@ export {
21
21
  useChatRuntime,
22
22
  useRequiredChatRuntime
23
23
  };
24
- //# sourceMappingURL=chunk-7L4DWM7P.js.map
24
+ //# sourceMappingURL=chunk-ZG2YY5E7.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/contexts/chat-runtime-context.tsx"],"sourcesContent":["'use client'\n\n/**\n * Chat runtime context — single seam for embedding the chat panel in a\n * different host (e.g. user1.openframe.ai reverse-proxying API calls\n * under /api/mingo-guide/* to hub.openframe.ai/api/*).\n *\n * Three concerns, one context:\n * 1. API endpoints: chatStreamUrl / approvalToolUrl / commandsUrl /\n * buildListUrl + attachment endpoints + chat-identity. The chat\n * reads them from runtime; hub vs embedded app supply different\n * strings via different providers.\n * 2. Navigation mode + callbacks: 'host' or 'embed' mode. Host wires\n * its own router/docNav via the optional `navigate` callback\n * (plain function, NOT a hook); embed forces new-tab via\n * `defaultContentOrigin` + lib's `resolveExternalNavigation`.\n * 3. Identity context: only `source` (required for localStorage\n * namespacing). The display identity (greeting first-name etc.)\n * comes from the server via `useChatIdentity()` — never injected\n * client-side, so it always matches the server-resolved auth.\n *\n * Sibling of EndpointsRuntimeContext (announcement bar, contact form,\n * access codes). Each runtime stays an independent React context so\n * embedders can opt into either feature without forcing the other.\n *\n * IMPORTANT for embedders: memoize the value passed to\n * `<ChatRuntimeContext.Provider value={...}>` (e.g. via React.useMemo).\n * Every change to its reference identity invalidates downstream\n * `useMemo` consumers (the chat input's slash-commands binding,\n * useNavLink's embed-resolution memo, useDocChat's streamFn factory).\n * The hub's `<HubRuntimeProvider>` already memoizes correctly with\n * stable deps. Embedded apps that build the value inline on each render\n * will pay an avoidable re-render cost across the entire chat tree.\n */\n\nimport { createContext, useContext, type ReactNode } from 'react'\n\n/**\n * Runtime config consumed by the chat panel.\n */\nexport interface ChatRuntime {\n endpoints: {\n /** POST streaming chat. Hub: '/api/docs/chat'. */\n chatStreamUrl: string\n /** POST agent approve/reject. Hub: '/api/chat/agent/confirm-tool'. */\n approvalToolUrl: string\n /** GET slash-command catalog. Hub: '/api/docs/commands'. */\n commandsUrl: string\n /** Build entity-card list URL for a content type + ids. Hub delegates\n * to the rag-table-config registry; embedded app provides its own\n * per-type URL builder against the reverse proxy. Returns null when\n * the type has no list endpoint (caller skips rendering). */\n buildListUrl: (type: string, ids: string[]) => string | null\n /** Chat-attachment endpoints — added for the v2 attachment feature.\n *\n * Three concerns:\n * - `attachmentUploadUrl` — POSTed by the chat-attachment hook\n * to mint a Supabase signed-upload-URL + HMAC view token.\n * - `attachmentViewUrlPrefix` — embedded in markdown URLs the\n * chat hosts in user message bubbles (`![]()` / `[Attached]`).\n * Stored in chat history; chosen at SEND time. In host mode the\n * relative `/api/storage/view/chat-attachments/` is sufficient\n * (same-origin); embedders supply an absolute hub URL so the\n * browser can fetch cross-origin.\n * - `identityUrl` — GET endpoint the `useChatIdentity` hook\n * hits to learn the `{authTier, source, attachmentsEnabled}`\n * capability bag for the current session. Used beyond chat\n * (tickets / contact form / any embedded surface that needs\n * to identify the proxied customer), so the name has no\n * \"chat\" prefix even though the consuming hook still does. */\n attachmentUploadUrl: string\n attachmentViewUrlPrefix: string\n identityUrl: string\n /** Optional URL prefix for the image proxy (`<prefix>?url=<external>`).\n * When unset, lib's `getProxiedImageUrl` returns the original URL\n * unchanged. Hub default: '/api/image-proxy'. Embedders that don't\n * host an image-proxy route leave this undefined → images load\n * directly cross-origin (CORS-permitting). */\n imageProxyUrlPrefix?: string\n /** Optional list of hostnames that should bypass the image proxy\n * (rendered direct). Hub uses ['openmsp.ai']; embedders typically\n * leave it unset. Matches the `skipDomains` parameter of\n * `getProxiedImageUrl`. */\n imageProxySkipDomains?: string[]\n }\n navigation: {\n /** ONE knob, two behaviors:\n * - 'host' = use the host page's existing click-routing untouched.\n * The chat panel calls `navigate?.()` for in-app routing.\n * - 'embed' = guest inside another app: short-circuit at the top\n * of click handlers to force new-tab + absolutize via\n * resolveExternalNavigation. */\n mode: 'host' | 'embed'\n /** Embed-only fallback origin for relative URLs whose target platform\n * can't be inferred. Used by resolveExternalNavigation when\n * `targetPlatform` is null — without this, a relative `/foo` href would\n * window.open against the embedder's origin, which is WRONG.\n * Set to your content host (e.g. 'https://hub.openframe.ai').\n * Required by the embedded app whenever mode='embed'. */\n defaultContentOrigin?: string\n /** Override for opening external URLs. MUST BE SYNCHRONOUS —\n * Safari/Firefox block popups opened outside a direct user gesture.\n * Default: window.open(href, '_blank', 'noopener,noreferrer'). */\n openExternal?: (href: string) => void\n /** Optional in-app navigation callback (host-mode only).\n * Returns `true` if the host handled the click in-app\n * (router.push + docNav.navigate); returns `false`, `undefined`,\n * or `void` → lib falls back to window.location.assign(href).\n * Hub wires this via HubRuntimeProvider's HubNavigationWiring;\n * embedders not in Next.js leave it undefined. */\n navigate?: (input: { href: string; path?: string | null; targetPlatform?: string | null }) => boolean | void\n /** Optional new-tab decision callback. Returns true → lib opens in\n * new tab; false → same tab via `navigate`. Hub wires the existing\n * `decideNewTab` logic from use-nav-link.tsx (re-imports the pure\n * helper from lib). Embedders may omit; lib defaults to:\n * same-origin/same-platform → same tab, else new tab. */\n decideNewTab?: (args: { href: string; targetPlatform?: string | null }) => boolean\n }\n /** Chat source identifier — REQUIRED. Used for localStorage\n * namespacing (`mingo-chat-<source>-v1`). Hub sets via\n * `currentPlatform()`; embedders set explicitly.\n * `useEmbeddedChat()` throws if source is empty/missing. */\n source: string\n // NOTE: No `user` field. The chat's display identity (greeting\n // first-name, etc.) comes from the SERVER-resolved auth via\n // `useChatIdentity()` — the same identity the server uses to\n // authorize requests. Letting embedders pass a client-side `user`\n // would let it desync from the actual auth tier, causing greetings\n // like \"Hey Bob\" while the server treats the session as\n // alice@example.com. Single source of truth: the server.\n}\n\nexport const ChatRuntimeContext = createContext<ChatRuntime | null>(null)\n\n/**\n * Returns the active runtime, or null when no provider is mounted.\n * NULL is a first-class value — it signals \"no chat runtime configured.\"\n * Optional consumers fall back to no-op behavior; strict consumers\n * use `useRequiredChatRuntime` (below).\n */\nexport function useChatRuntime(): ChatRuntime | null {\n return useContext(ChatRuntimeContext)\n}\n\n/**\n * Strict variant used INSIDE the chat panel. Throws if no provider.\n * The hub guarantees one exists by mounting `<HubRuntimeProvider>` at\n * root; the embedded app mounts its own `<ChatRuntimeContext.Provider>`\n * at the tree root. In Jest / Storybook tests that render chat\n * internals directly, wrap with `<HubRuntimeProvider>` (hub defaults)\n * or supply `<ChatRuntimeContext.Provider value={mockedRuntime}>`.\n */\nexport function useRequiredChatRuntime(): ChatRuntime {\n const v = useContext(ChatRuntimeContext)\n if (!v) {\n throw new Error(\n '[chat-runtime] hook called outside a <ChatRuntimeContext.Provider>. ' +\n 'The hub mounts <HubRuntimeProvider> at root — this only fires when ' +\n 'chat internals are rendered above the provider tree. ' +\n 'Fix: ensure the rendering subtree descends from the runtime provider. ' +\n 'In tests/Storybook: wrap with <HubRuntimeProvider> or supply ' +\n 'a <ChatRuntimeContext.Provider value={mockedRuntime}>.',\n )\n }\n return v\n}\n"],"mappings":";;;AAmCA,SAAS,eAAe,kBAAkC;AAiGnD,IAAM,qBAAqB,cAAkC,IAAI;AAQjE,SAAS,iBAAqC;AACnD,SAAO,WAAW,kBAAkB;AACtC;AAUO,SAAS,yBAAsC;AACpD,QAAM,IAAI,WAAW,kBAAkB;AACvC,MAAI,CAAC,GAAG;AACN,UAAM,IAAI;AAAA,MACR;AAAA,IAMF;AAAA,EACF;AACA,SAAO;AACT;","names":[]}
@@ -1 +1 @@
1
- {"version":3,"file":"blog-card.d.ts","sourceRoot":"","sources":["../../../../src/components/chat/entity-cards/blog-card.tsx"],"names":[],"mappings":"AAwBA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AAe1D,MAAM,WAAW,aAAa;IAC5B,IAAI,EAAE,eAAe,CAAA;IACrB,kEAAkE;IAClE,IAAI,EAAE,MAAM,CAAA;IACZ;mDAC+C;IAC/C,MAAM,CAAC,EAAE,QAAQ,CAAA;IACjB,GAAG,CAAC,EAAE,qBAAqB,CAAA;IAC3B;;sCAEkC;IAClC,cAAc,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IAC9B;mEAC+D;IAC/D,cAAc,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IAC9B,IAAI,CAAC,EAAE,SAAS,GAAG,IAAI,CAAA;IACvB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,gDAAgD;IAChD,gBAAgB,CAAC,EAAE,OAAO,CAAA;IAC1B;;0CAEsC;IACtC,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB;AAED,wBAAgB,gBAAgB,CAAC,EAAE,IAAgB,EAAE,EAAE;IAAE,IAAI,CAAC,EAAE,SAAS,GAAG,IAAI,CAAA;CAAE,2CAkCjF;AAED,wBAAgB,QAAQ,CAAC,EACvB,IAAI,EACJ,IAAI,EAEJ,MAAM,EAEN,GAAG,EACH,cAAc,EACd,IAAgB,EAChB,SAAS,EACT,gBAAwB,EACxB,QAAgB,GACjB,EAAE,aAAa,2CAkJf"}
1
+ {"version":3,"file":"blog-card.d.ts","sourceRoot":"","sources":["../../../../src/components/chat/entity-cards/blog-card.tsx"],"names":[],"mappings":"AAyBA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AAe1D,MAAM,WAAW,aAAa;IAC5B,IAAI,EAAE,eAAe,CAAA;IACrB,kEAAkE;IAClE,IAAI,EAAE,MAAM,CAAA;IACZ;mDAC+C;IAC/C,MAAM,CAAC,EAAE,QAAQ,CAAA;IACjB,GAAG,CAAC,EAAE,qBAAqB,CAAA;IAC3B;;sCAEkC;IAClC,cAAc,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IAC9B;mEAC+D;IAC/D,cAAc,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IAC9B,IAAI,CAAC,EAAE,SAAS,GAAG,IAAI,CAAA;IACvB,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,gDAAgD;IAChD,gBAAgB,CAAC,EAAE,OAAO,CAAA;IAC1B;;0CAEsC;IACtC,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB;AAED,wBAAgB,gBAAgB,CAAC,EAAE,IAAgB,EAAE,EAAE;IAAE,IAAI,CAAC,EAAE,SAAS,GAAG,IAAI,CAAA;CAAE,2CAkCjF;AAED,wBAAgB,QAAQ,CAAC,EACvB,IAAI,EACJ,IAAI,EAEJ,MAAM,EAEN,GAAG,EACH,cAAc,EACd,IAAgB,EAChB,SAAS,EACT,gBAAwB,EACxB,QAAgB,GACjB,EAAE,aAAa,2CA0Jf"}
@@ -1,7 +1,7 @@
1
1
  /**
2
- * Wire-shape for the `/api/chat/identity` route response. Mirrors
3
- * the hub's `ChatIdentityResponse` (in `app/api/chat/identity/route.ts`)
4
- * kept in sync there. Lib-side declaration so the chat panel can
2
+ * Wire-shape for the identity route response. Mirrors the hub's
3
+ * `ChatIdentityResponse` (in `app/api/auth/identity/route.ts`)
4
+ * kept in sync there. Lib-side declaration so the chat panel can
5
5
  * compile without depending on hub-internal types.
6
6
  */
7
7
  export interface ChatIdentityResponse {
@@ -1 +1 @@
1
- {"version":3,"file":"use-chat-identity.d.ts","sourceRoot":"","sources":["../../../../src/components/chat/hooks/use-chat-identity.ts"],"names":[],"mappings":"AAsCA;;;;;GAKG;AACH,MAAM,WAAW,oBAAoB;IACnC,QAAQ,EAAE,SAAS,GAAG,eAAe,GAAG,MAAM,CAAA;IAC9C,MAAM,EAAE,MAAM,GAAG,IAAI,CAAA;IACrB,kBAAkB,EAAE,OAAO,CAAA;IAC3B;;;;;;;qDAOiD;IACjD,IAAI,EAAE;QACJ,IAAI,EAAE,MAAM,GAAG,IAAI,CAAA;QACnB,KAAK,EAAE,MAAM,GAAG,IAAI,CAAA;QACpB;;;oDAG4C;QAC5C,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;QACzB;sEAC8D;QAC9D,QAAQ,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;QACxB,8DAA8D;QAC9D,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;KAC1B,GAAG,IAAI,CAAA;CACT;AAED;0EAC0E;AAC1E,MAAM,WAAW,mBAAoB,SAAQ,oBAAoB;IAC/D;iDAC6C;IAC7C,SAAS,EAAE,OAAO,CAAA;CACnB;AASD,wBAAgB,eAAe,IAAI,mBAAmB,CA+CrD"}
1
+ {"version":3,"file":"use-chat-identity.d.ts","sourceRoot":"","sources":["../../../../src/components/chat/hooks/use-chat-identity.ts"],"names":[],"mappings":"AAuCA;;;;;GAKG;AACH,MAAM,WAAW,oBAAoB;IACnC,QAAQ,EAAE,SAAS,GAAG,eAAe,GAAG,MAAM,CAAA;IAC9C,MAAM,EAAE,MAAM,GAAG,IAAI,CAAA;IACrB,kBAAkB,EAAE,OAAO,CAAA;IAC3B;;;;;;;qDAOiD;IACjD,IAAI,EAAE;QACJ,IAAI,EAAE,MAAM,GAAG,IAAI,CAAA;QACnB,KAAK,EAAE,MAAM,GAAG,IAAI,CAAA;QACpB;;;oDAG4C;QAC5C,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;QACzB;sEAC8D;QAC9D,QAAQ,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;QACxB,8DAA8D;QAC9D,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;KAC1B,GAAG,IAAI,CAAA;CACT;AAED;0EAC0E;AAC1E,MAAM,WAAW,mBAAoB,SAAQ,oBAAoB;IAC/D;iDAC6C;IAC7C,SAAS,EAAE,OAAO,CAAA;CACnB;AASD,wBAAgB,eAAe,IAAI,mBAAmB,CA+CrD"}
@@ -192,12 +192,12 @@
192
192
 
193
193
 
194
194
 
195
- var _chunkSJQLTQC7cjs = require('../../chunk-SJQLTQC7.cjs');
195
+ var _chunkWI76ZUBEcjs = require('../../chunk-WI76ZUBE.cjs');
196
196
  require('../../chunk-EH3RWVF3.cjs');
197
197
  require('../../chunk-24KCAECR.cjs');
198
198
  require('../../chunk-65CPJ4SX.cjs');
199
199
  require('../../chunk-XQFFGR6U.cjs');
200
- require('../../chunk-6RZYJICV.cjs');
200
+ require('../../chunk-P5EE2VJX.cjs');
201
201
  require('../../chunk-27APPAJN.cjs');
202
202
  require('../../chunk-BZFW3FOF.cjs');
203
203
  require('../../chunk-G7UE6RKV.cjs');
@@ -400,5 +400,5 @@ require('../../chunk-VRHGVLSL.cjs');
400
400
 
401
401
 
402
402
 
403
- exports.ANTHROPIC_SUPPORTED_IMAGE_MIME = _chunkSJQLTQC7cjs.ANTHROPIC_SUPPORTED_IMAGE_MIME; exports.APPROVAL_STATUS = _chunkSJQLTQC7cjs.APPROVAL_STATUS; exports.ASSISTANT_TYPE = _chunkSJQLTQC7cjs.ASSISTANT_TYPE; exports.AUTHOR_TYPE = _chunkSJQLTQC7cjs.AUTHOR_TYPE; exports.AUTO_CONTINUATION_DIRECTIVE_PREFIX = _chunkSJQLTQC7cjs.AUTO_CONTINUATION_DIRECTIVE_PREFIX; exports.AdminContentCard = _chunkSJQLTQC7cjs.AdminContentCard; exports.ApprovalBatchMessage = _chunkSJQLTQC7cjs.ApprovalBatchMessage; exports.ApprovalRequestMessage = _chunkSJQLTQC7cjs.ApprovalRequestMessage; exports.ArgRow = _chunkSJQLTQC7cjs.ArgRow; exports.BlockCard = _chunkSJQLTQC7cjs.BlockCard; exports.BlogCard = _chunkSJQLTQC7cjs.BlogCard; exports.BlogCardSkeleton = _chunkSJQLTQC7cjs.BlogCardSkeleton; exports.BlogImagePlaceholder = _chunkSJQLTQC7cjs.BlogImagePlaceholder; exports.CHAT_ATTACHMENT_CONCURRENT_UPLOADS_PER_USER = _chunkSJQLTQC7cjs.CHAT_ATTACHMENT_CONCURRENT_UPLOADS_PER_USER; exports.CHAT_ATTACHMENT_MARKDOWN_PATTERN = _chunkSJQLTQC7cjs.CHAT_ATTACHMENT_MARKDOWN_PATTERN; exports.CHAT_ATTACHMENT_MIME_TYPES = _chunkSJQLTQC7cjs.CHAT_ATTACHMENT_MIME_TYPES; exports.CHAT_ATTACHMENT_VIEW_TOKEN_QUERY_PARAM = _chunkSJQLTQC7cjs.CHAT_ATTACHMENT_VIEW_TOKEN_QUERY_PARAM; exports.CHAT_ATTACHMENT_VIEW_URL_PREFIX = _chunkSJQLTQC7cjs.CHAT_ATTACHMENT_VIEW_URL_PREFIX; exports.CHAT_ATTACHMENT_VIEW_URL_PREFIX_REGEX_ESCAPED = _chunkSJQLTQC7cjs.CHAT_ATTACHMENT_VIEW_URL_PREFIX_REGEX_ESCAPED; exports.CHAT_TYPE = _chunkSJQLTQC7cjs.CHAT_TYPE; exports.CHIP_ACTION_BUTTON_CLASS = _chunkSJQLTQC7cjs.CHIP_ACTION_BUTTON_CLASS; exports.COMPACT_CARD_ICON_SLOT = _chunkSJQLTQC7cjs.COMPACT_CARD_ICON_SLOT; exports.COMPACT_CARD_IMAGE_SLOT = _chunkSJQLTQC7cjs.COMPACT_CARD_IMAGE_SLOT; exports.COMPACT_CARD_META_ROW = _chunkSJQLTQC7cjs.COMPACT_CARD_META_ROW; exports.COMPACT_CARD_META_ROW_BOX = _chunkSJQLTQC7cjs.COMPACT_CARD_META_ROW_BOX; exports.COMPACT_CARD_OUTER = _chunkSJQLTQC7cjs.COMPACT_CARD_OUTER; exports.COMPACT_CARD_OUTER_STATIC = _chunkSJQLTQC7cjs.COMPACT_CARD_OUTER_STATIC; exports.COMPACT_CARD_ROW_FILLER = _chunkSJQLTQC7cjs.COMPACT_CARD_ROW_FILLER; exports.COMPACT_CARD_SKELETON_IMAGE_SLOT = _chunkSJQLTQC7cjs.COMPACT_CARD_SKELETON_IMAGE_SLOT; exports.COMPACT_CARD_SKELETON_OUTER = _chunkSJQLTQC7cjs.COMPACT_CARD_SKELETON_OUTER; exports.COMPACT_CARD_SUBTITLE = _chunkSJQLTQC7cjs.COMPACT_CARD_SUBTITLE; exports.COMPACT_CARD_SUMMARY = _chunkSJQLTQC7cjs.COMPACT_CARD_SUMMARY; exports.COMPACT_CARD_TEXT_COL = _chunkSJQLTQC7cjs.COMPACT_CARD_TEXT_COL; exports.COMPACT_CARD_TITLE = _chunkSJQLTQC7cjs.COMPACT_CARD_TITLE; exports.COMPACT_CARD_TITLE_ROW = _chunkSJQLTQC7cjs.COMPACT_CARD_TITLE_ROW; exports.CONNECTION_STATUS = _chunkSJQLTQC7cjs.CONNECTION_STATUS; exports.CUSTOM_ITEM_ID = _chunkSJQLTQC7cjs.CUSTOM_ITEM_ID; exports.CampaignCardAdmin = _chunkSJQLTQC7cjs.CampaignCardAdmin; exports.CampaignCardAdminSkeleton = _chunkSJQLTQC7cjs.CampaignCardAdminSkeleton; exports.CaseStudyCard = _chunkSJQLTQC7cjs.CaseStudyCard; exports.CaseStudyCardSkeleton = _chunkSJQLTQC7cjs.CaseStudyCardSkeleton; exports.ChatAttachmentAddButton = _chunkSJQLTQC7cjs.ChatAttachmentAddButton; exports.ChatAttachmentChipStrip = _chunkSJQLTQC7cjs.ChatAttachmentChipStrip; exports.ChatCardLoader = _chunkSJQLTQC7cjs.ChatCardLoader; exports.ChatContainer = _chunkSJQLTQC7cjs.ChatContainer; exports.ChatContent = _chunkSJQLTQC7cjs.ChatContent; exports.ChatFooter = _chunkSJQLTQC7cjs.ChatFooter; exports.ChatHeader = _chunkSJQLTQC7cjs.ChatHeader; exports.ChatInput = _chunkSJQLTQC7cjs.ChatInput; exports.ChatMessageEnhanced = _chunkSJQLTQC7cjs.MemoizedChatMessageEnhanced; exports.ChatMessageList = _chunkSJQLTQC7cjs.ChatMessageList; exports.ChatQuickAction = _chunkSJQLTQC7cjs.ChatQuickAction; exports.ChatSidebar = _chunkSJQLTQC7cjs.ChatSidebar; exports.ChatTicketItem = _chunkSJQLTQC7cjs.ChatTicketItem; exports.ChatTicketList = _chunkSJQLTQC7cjs.ChatTicketList; exports.ChatTypingIndicator = _chunkSJQLTQC7cjs.ChatTypingIndicator; exports.ChatVideoEntityCard = _chunkSJQLTQC7cjs.ChatVideoEntityCard; exports.ContextCompactionDisplay = _chunkSJQLTQC7cjs.ContextCompactionDisplay; exports.CustomerInterviewCard = _chunkSJQLTQC7cjs.CustomerInterviewCard; exports.CustomerInterviewCardSkeleton = _chunkSJQLTQC7cjs.CustomerInterviewCardSkeleton; exports.DEFAULT_DOCUMENT_TYPE_TO_TABLE_ID = _chunkSJQLTQC7cjs.DEFAULT_DOCUMENT_TYPE_TO_TABLE_ID; exports.DataRoomDocCard = _chunkSJQLTQC7cjs.DataRoomDocCard; exports.DataRoomDocCardSkeleton = _chunkSJQLTQC7cjs.DataRoomDocCardSkeleton; exports.DialogListItem = _chunkSJQLTQC7cjs.DialogListItem; exports.EMPTY_AUTHOR_PLACEHOLDER = _chunkSJQLTQC7cjs.EMPTY_AUTHOR_PLACEHOLDER; exports.EmbeddableChat = _chunkSJQLTQC7cjs.EmbeddableChat; exports.EntityAuthorCard = _chunkSJQLTQC7cjs.EntityAuthorCard; exports.EntityMetadataAuthorCell = _chunkSJQLTQC7cjs.EntityMetadataAuthorCell; exports.EntityMetadataValueCell = _chunkSJQLTQC7cjs.EntityMetadataValueCell; exports.ErrorMessageDisplay = _chunkSJQLTQC7cjs.ErrorMessageDisplay; exports.ExpandChevron = _chunkSJQLTQC7cjs.ExpandChevron; exports.GenericEntityCard = _chunkSJQLTQC7cjs.GenericEntityCard; exports.GenericEntityCardSkeleton = _chunkSJQLTQC7cjs.GenericEntityCardSkeleton; exports.GitHubActivityCard = _chunkSJQLTQC7cjs.GitHubActivityCard; exports.GitHubActivityCardSkeleton = _chunkSJQLTQC7cjs.GitHubActivityCardSkeleton; exports.HubspotTicketCard = _chunkSJQLTQC7cjs.HubspotTicketCard; exports.HubspotTicketCardSkeleton = _chunkSJQLTQC7cjs.HubspotTicketCardSkeleton; exports.ICON_REGISTRY = _chunkSJQLTQC7cjs.ICON_REGISTRY; exports.InvestorUpdateCard = _chunkSJQLTQC7cjs.InvestorUpdateCard; exports.InvestorUpdateCardSkeleton = _chunkSJQLTQC7cjs.InvestorUpdateCardSkeleton; exports.MESSAGE_ROLE = _chunkSJQLTQC7cjs.MESSAGE_ROLE; exports.MESSAGE_TYPE = _chunkSJQLTQC7cjs.MESSAGE_TYPE; exports.MessageSegmentAccumulator = _chunkSJQLTQC7cjs.MessageSegmentAccumulator; exports.MingoOnboardingCard = _chunkSJQLTQC7cjs.MingoOnboardingCard; exports.MingoOnboardingCardSkeleton = _chunkSJQLTQC7cjs.MingoOnboardingCardSkeleton; exports.MingoOnboardingListSkeleton = _chunkSJQLTQC7cjs.MingoOnboardingListSkeleton; exports.ModelDisplay = _chunkSJQLTQC7cjs.ModelDisplay; exports.NETWORK_CONFIG = _chunkSJQLTQC7cjs.NETWORK_CONFIG; exports.NEW_TAB_FEATURES = _chunkSJQLTQC7cjs.NEW_TAB_FEATURES; exports.NavLinkAnchorViaRuntime = _chunkSJQLTQC7cjs.NavLinkAnchorViaRuntime; exports.OWNER_TYPE = _chunkSJQLTQC7cjs.OWNER_TYPE; exports.OnboardingGuideCard = _chunkSJQLTQC7cjs.OnboardingGuideCard; exports.OnboardingGuideCardSkeleton = _chunkSJQLTQC7cjs.OnboardingGuideCardSkeleton; exports.ProductReleaseCard = _chunkSJQLTQC7cjs.ProductReleaseCard; exports.ProductReleaseCardSkeleton = _chunkSJQLTQC7cjs.ProductReleaseCardSkeleton; exports.ProgramCard = _chunkSJQLTQC7cjs.ProgramCard; exports.ProgramCardSkeleton = _chunkSJQLTQC7cjs.ProgramCardSkeleton; exports.ResultBlock = _chunkSJQLTQC7cjs.ResultBlock; exports.RoadmapCard = _chunkSJQLTQC7cjs.RoadmapCard; exports.RoadmapCardSkeleton = _chunkSJQLTQC7cjs.RoadmapCardSkeleton; exports.RoadmapVoteButton = _chunkSJQLTQC7cjs.RoadmapVoteButton; exports.SCROLL_ANCHOR = _chunkSJQLTQC7cjs.SCROLL_ANCHOR; exports.SCROLL_ANCHOR_WIRE_KEY = _chunkSJQLTQC7cjs.SCROLL_ANCHOR_WIRE_KEY; exports.SOURCE_ICON_NAMES = _chunkSJQLTQC7cjs.SOURCE_ICON_NAMES; exports.SOURCE_LABELS_BY_TABLE = _chunkSJQLTQC7cjs.SOURCE_LABELS_BY_TABLE; exports.SlackMessageCard = _chunkSJQLTQC7cjs.SlackMessageCard; exports.SlackMessageCardSkeleton = _chunkSJQLTQC7cjs.SlackMessageCardSkeleton; exports.SlashCommandSuggestions = _chunkSJQLTQC7cjs.SlashCommandSuggestions; exports.SourceActionButton = _chunkSJQLTQC7cjs.SourceActionButton; exports.TaskTypeIcon = _chunkSJQLTQC7cjs.TaskTypeIcon; exports.ThinkingDisplay = _chunkSJQLTQC7cjs.ThinkingDisplay; exports.ToolExecutionDisplay = _chunkSJQLTQC7cjs.ToolExecutionDisplay; exports.applyProxyAuth = _chunkSJQLTQC7cjs.applyProxyAuth; exports.buildAnchorProps = _chunkSJQLTQC7cjs.buildAnchorProps; exports.buildAutoContinuationDirective = _chunkSJQLTQC7cjs.buildAutoContinuationDirective; exports.buildChatAttachmentViewUrl = _chunkSJQLTQC7cjs.buildChatAttachmentViewUrl; exports.buildChatRefKey = _chunkSJQLTQC7cjs.buildChatRefKey; exports.buildDiscussAddendum = _chunkSJQLTQC7cjs.buildDiscussAddendum; exports.buildNatsWsUrl = _chunkSJQLTQC7cjs.buildNatsWsUrl; exports.chatAuthedFetch = _chunkSJQLTQC7cjs.embedAuthedFetch; exports.chatChipClass = _chunkSJQLTQC7cjs.chatChipClass; exports.clearChatProxyAuth = _chunkSJQLTQC7cjs.clearEmbedProxyAuth; exports.clickupTaskUrl = _chunkSJQLTQC7cjs.clickupTaskUrl; exports.computeIsNewTab = _chunkSJQLTQC7cjs.computeIsNewTab; exports.createMessageSegmentAccumulator = _chunkSJQLTQC7cjs.createMessageSegmentAccumulator; exports.decideNewTab = _chunkSJQLTQC7cjs.decideNewTab; exports.defaultTableIdForDocumentType = _chunkSJQLTQC7cjs.defaultTableIdForDocumentType; exports.escapeMarkdownInline = _chunkSJQLTQC7cjs.escapeMarkdownInline; exports.extractEntityIdFilter = _chunkSJQLTQC7cjs.extractEntityIdFilter; exports.extractErrorMessages = _chunkSJQLTQC7cjs.extractErrorMessages; exports.extractIncompleteMessageState = _chunkSJQLTQC7cjs.extractIncompleteMessageState; exports.extractTextFromChunk = _chunkSJQLTQC7cjs.extractTextFromChunk; exports.fetchSlashCommands = _chunkSJQLTQC7cjs.fetchSlashCommands; exports.flattenAssistantContent = _chunkSJQLTQC7cjs.flattenAssistantContent; exports.formatChatAttachmentMarkdownForBubble = _chunkSJQLTQC7cjs.formatChatAttachmentMarkdownForBubble; exports.formatInvestorUpdatePeriod = _chunkSJQLTQC7cjs.formatInvestorUpdatePeriod; exports.formatSingularLookupInvocation = _chunkSJQLTQC7cjs.formatSingularLookupInvocation; exports.getChatProxyAuth = _chunkSJQLTQC7cjs.getEmbedProxyAuth; exports.getCommandText = _chunkSJQLTQC7cjs.getCommandText; exports.getDynamicIcon = _chunkSJQLTQC7cjs.getDynamicIcon; exports.getIconComponent = _chunkSJQLTQC7cjs.getIconComponent; exports.getPersistedProxyEmail = _chunkSJQLTQC7cjs.getPersistedProxyEmail; exports.getSourceIconName = _chunkSJQLTQC7cjs.getSourceIconName; exports.getSourceLabel = _chunkSJQLTQC7cjs.getSourceLabel; exports.getStatusColorScheme = _chunkSJQLTQC7cjs.getStatusColorScheme; exports.getTaskTypeLabel = _chunkSJQLTQC7cjs.getTaskTypeLabel; exports.handleChatNavClick = _chunkSJQLTQC7cjs.handleChatNavClick; exports.isControlChunk = _chunkSJQLTQC7cjs.isControlChunk; exports.isCrossOriginUrl = _chunkSJQLTQC7cjs.isCrossOriginUrl; exports.isErrorChunk = _chunkSJQLTQC7cjs.isErrorChunk; exports.isMetadataChunk = _chunkSJQLTQC7cjs.isMetadataChunk; exports.isModifierClick = _chunkSJQLTQC7cjs.isModifierClick; exports.isStructuredContent = _chunkSJQLTQC7cjs.isStructuredContent; exports.newTabAnchorAttrs = _chunkSJQLTQC7cjs.newTabAnchorAttrs; exports.normalizeContent = _chunkSJQLTQC7cjs.normalizeContent; exports.normalizeIconKey = _chunkSJQLTQC7cjs.normalizeIconKey; exports.parseChunkToAction = _chunkSJQLTQC7cjs.parseChunkToAction; exports.parseScrollAnchor = _chunkSJQLTQC7cjs.parseScrollAnchor; exports.parseWireCommandOverride = _chunkSJQLTQC7cjs.parseWireCommandOverride; exports.processHistoricalMessages = _chunkSJQLTQC7cjs.processHistoricalMessages; exports.processHistoricalMessagesWithErrors = _chunkSJQLTQC7cjs.processHistoricalMessagesWithErrors; exports.remarkCardLinks = _chunkSJQLTQC7cjs.remarkCardLinks; exports.renderChatInlineEntityCard = _chunkSJQLTQC7cjs.renderChatInlineEntityCard; exports.resolveExternalNavigation = _chunkSJQLTQC7cjs.resolveExternalNavigation; exports.resolveSourceIcon = _chunkSJQLTQC7cjs.resolveSourceIcon; exports.resolveSourceRowCTA = _chunkSJQLTQC7cjs.resolveSourceRowCTA; exports.safeHref = _chunkSJQLTQC7cjs.safeHref; exports.sanitizeTitleForChat = _chunkSJQLTQC7cjs.sanitizeTitleForChat; exports.setChatProxyAuth = _chunkSJQLTQC7cjs.setEmbedProxyAuth; exports.stripChatAttachmentMarkdown = _chunkSJQLTQC7cjs.stripChatAttachmentMarkdown; exports.stripSameOriginToPath = _chunkSJQLTQC7cjs.stripSameOriginToPath; exports.transformEventToProgram = _chunkSJQLTQC7cjs.transformEventToProgram; exports.transformPodcastToProgram = _chunkSJQLTQC7cjs.transformPodcastToProgram; exports.transformWebinarToProgram = _chunkSJQLTQC7cjs.transformWebinarToProgram; exports.useChat = _chunkSJQLTQC7cjs.useChat; exports.useChatAttachmentImageGallery = _chunkSJQLTQC7cjs.useChatAttachmentImageGallery; exports.useChatAttachments = _chunkSJQLTQC7cjs.useChatAttachments; exports.useChatCardItem = _chunkSJQLTQC7cjs.useChatCardItem; exports.useChatIdentity = _chunkSJQLTQC7cjs.useChatIdentity; exports.useChunkCatchup = _chunkSJQLTQC7cjs.useChunkCatchup; exports.useCloseOnNavigation = _chunkSJQLTQC7cjs.useCloseOnNavigation; exports.useCollapsible = _chunkSJQLTQC7cjs.useCollapsible; exports.useEmbeddedChat = _chunkSJQLTQC7cjs.useSseChatAdapter; exports.useJetStreamDialogSubscription = _chunkSJQLTQC7cjs.useJetStreamDialogSubscription; exports.useNatsChatAdapter = _chunkSJQLTQC7cjs.useNatsChatAdapter; exports.useNatsDialogSubscription = _chunkSJQLTQC7cjs.useNatsDialogSubscription; exports.useProxiedImageUrl = _chunkSJQLTQC7cjs.useProxiedImageUrl; exports.useRealtimeChunkProcessor = _chunkSJQLTQC7cjs.useRealtimeChunkProcessor; exports.useSSE = _chunkSJQLTQC7cjs.useSSE; exports.useSlashCommands = _chunkSJQLTQC7cjs.useSlashCommands; exports.useSseChatAdapter = _chunkSJQLTQC7cjs.useSseChatAdapter; exports.useUnifiedChat = _chunkSJQLTQC7cjs.useUnifiedChat;
403
+ exports.ANTHROPIC_SUPPORTED_IMAGE_MIME = _chunkWI76ZUBEcjs.ANTHROPIC_SUPPORTED_IMAGE_MIME; exports.APPROVAL_STATUS = _chunkWI76ZUBEcjs.APPROVAL_STATUS; exports.ASSISTANT_TYPE = _chunkWI76ZUBEcjs.ASSISTANT_TYPE; exports.AUTHOR_TYPE = _chunkWI76ZUBEcjs.AUTHOR_TYPE; exports.AUTO_CONTINUATION_DIRECTIVE_PREFIX = _chunkWI76ZUBEcjs.AUTO_CONTINUATION_DIRECTIVE_PREFIX; exports.AdminContentCard = _chunkWI76ZUBEcjs.AdminContentCard; exports.ApprovalBatchMessage = _chunkWI76ZUBEcjs.ApprovalBatchMessage; exports.ApprovalRequestMessage = _chunkWI76ZUBEcjs.ApprovalRequestMessage; exports.ArgRow = _chunkWI76ZUBEcjs.ArgRow; exports.BlockCard = _chunkWI76ZUBEcjs.BlockCard; exports.BlogCard = _chunkWI76ZUBEcjs.BlogCard; exports.BlogCardSkeleton = _chunkWI76ZUBEcjs.BlogCardSkeleton; exports.BlogImagePlaceholder = _chunkWI76ZUBEcjs.BlogImagePlaceholder; exports.CHAT_ATTACHMENT_CONCURRENT_UPLOADS_PER_USER = _chunkWI76ZUBEcjs.CHAT_ATTACHMENT_CONCURRENT_UPLOADS_PER_USER; exports.CHAT_ATTACHMENT_MARKDOWN_PATTERN = _chunkWI76ZUBEcjs.CHAT_ATTACHMENT_MARKDOWN_PATTERN; exports.CHAT_ATTACHMENT_MIME_TYPES = _chunkWI76ZUBEcjs.CHAT_ATTACHMENT_MIME_TYPES; exports.CHAT_ATTACHMENT_VIEW_TOKEN_QUERY_PARAM = _chunkWI76ZUBEcjs.CHAT_ATTACHMENT_VIEW_TOKEN_QUERY_PARAM; exports.CHAT_ATTACHMENT_VIEW_URL_PREFIX = _chunkWI76ZUBEcjs.CHAT_ATTACHMENT_VIEW_URL_PREFIX; exports.CHAT_ATTACHMENT_VIEW_URL_PREFIX_REGEX_ESCAPED = _chunkWI76ZUBEcjs.CHAT_ATTACHMENT_VIEW_URL_PREFIX_REGEX_ESCAPED; exports.CHAT_TYPE = _chunkWI76ZUBEcjs.CHAT_TYPE; exports.CHIP_ACTION_BUTTON_CLASS = _chunkWI76ZUBEcjs.CHIP_ACTION_BUTTON_CLASS; exports.COMPACT_CARD_ICON_SLOT = _chunkWI76ZUBEcjs.COMPACT_CARD_ICON_SLOT; exports.COMPACT_CARD_IMAGE_SLOT = _chunkWI76ZUBEcjs.COMPACT_CARD_IMAGE_SLOT; exports.COMPACT_CARD_META_ROW = _chunkWI76ZUBEcjs.COMPACT_CARD_META_ROW; exports.COMPACT_CARD_META_ROW_BOX = _chunkWI76ZUBEcjs.COMPACT_CARD_META_ROW_BOX; exports.COMPACT_CARD_OUTER = _chunkWI76ZUBEcjs.COMPACT_CARD_OUTER; exports.COMPACT_CARD_OUTER_STATIC = _chunkWI76ZUBEcjs.COMPACT_CARD_OUTER_STATIC; exports.COMPACT_CARD_ROW_FILLER = _chunkWI76ZUBEcjs.COMPACT_CARD_ROW_FILLER; exports.COMPACT_CARD_SKELETON_IMAGE_SLOT = _chunkWI76ZUBEcjs.COMPACT_CARD_SKELETON_IMAGE_SLOT; exports.COMPACT_CARD_SKELETON_OUTER = _chunkWI76ZUBEcjs.COMPACT_CARD_SKELETON_OUTER; exports.COMPACT_CARD_SUBTITLE = _chunkWI76ZUBEcjs.COMPACT_CARD_SUBTITLE; exports.COMPACT_CARD_SUMMARY = _chunkWI76ZUBEcjs.COMPACT_CARD_SUMMARY; exports.COMPACT_CARD_TEXT_COL = _chunkWI76ZUBEcjs.COMPACT_CARD_TEXT_COL; exports.COMPACT_CARD_TITLE = _chunkWI76ZUBEcjs.COMPACT_CARD_TITLE; exports.COMPACT_CARD_TITLE_ROW = _chunkWI76ZUBEcjs.COMPACT_CARD_TITLE_ROW; exports.CONNECTION_STATUS = _chunkWI76ZUBEcjs.CONNECTION_STATUS; exports.CUSTOM_ITEM_ID = _chunkWI76ZUBEcjs.CUSTOM_ITEM_ID; exports.CampaignCardAdmin = _chunkWI76ZUBEcjs.CampaignCardAdmin; exports.CampaignCardAdminSkeleton = _chunkWI76ZUBEcjs.CampaignCardAdminSkeleton; exports.CaseStudyCard = _chunkWI76ZUBEcjs.CaseStudyCard; exports.CaseStudyCardSkeleton = _chunkWI76ZUBEcjs.CaseStudyCardSkeleton; exports.ChatAttachmentAddButton = _chunkWI76ZUBEcjs.ChatAttachmentAddButton; exports.ChatAttachmentChipStrip = _chunkWI76ZUBEcjs.ChatAttachmentChipStrip; exports.ChatCardLoader = _chunkWI76ZUBEcjs.ChatCardLoader; exports.ChatContainer = _chunkWI76ZUBEcjs.ChatContainer; exports.ChatContent = _chunkWI76ZUBEcjs.ChatContent; exports.ChatFooter = _chunkWI76ZUBEcjs.ChatFooter; exports.ChatHeader = _chunkWI76ZUBEcjs.ChatHeader; exports.ChatInput = _chunkWI76ZUBEcjs.ChatInput; exports.ChatMessageEnhanced = _chunkWI76ZUBEcjs.MemoizedChatMessageEnhanced; exports.ChatMessageList = _chunkWI76ZUBEcjs.ChatMessageList; exports.ChatQuickAction = _chunkWI76ZUBEcjs.ChatQuickAction; exports.ChatSidebar = _chunkWI76ZUBEcjs.ChatSidebar; exports.ChatTicketItem = _chunkWI76ZUBEcjs.ChatTicketItem; exports.ChatTicketList = _chunkWI76ZUBEcjs.ChatTicketList; exports.ChatTypingIndicator = _chunkWI76ZUBEcjs.ChatTypingIndicator; exports.ChatVideoEntityCard = _chunkWI76ZUBEcjs.ChatVideoEntityCard; exports.ContextCompactionDisplay = _chunkWI76ZUBEcjs.ContextCompactionDisplay; exports.CustomerInterviewCard = _chunkWI76ZUBEcjs.CustomerInterviewCard; exports.CustomerInterviewCardSkeleton = _chunkWI76ZUBEcjs.CustomerInterviewCardSkeleton; exports.DEFAULT_DOCUMENT_TYPE_TO_TABLE_ID = _chunkWI76ZUBEcjs.DEFAULT_DOCUMENT_TYPE_TO_TABLE_ID; exports.DataRoomDocCard = _chunkWI76ZUBEcjs.DataRoomDocCard; exports.DataRoomDocCardSkeleton = _chunkWI76ZUBEcjs.DataRoomDocCardSkeleton; exports.DialogListItem = _chunkWI76ZUBEcjs.DialogListItem; exports.EMPTY_AUTHOR_PLACEHOLDER = _chunkWI76ZUBEcjs.EMPTY_AUTHOR_PLACEHOLDER; exports.EmbeddableChat = _chunkWI76ZUBEcjs.EmbeddableChat; exports.EntityAuthorCard = _chunkWI76ZUBEcjs.EntityAuthorCard; exports.EntityMetadataAuthorCell = _chunkWI76ZUBEcjs.EntityMetadataAuthorCell; exports.EntityMetadataValueCell = _chunkWI76ZUBEcjs.EntityMetadataValueCell; exports.ErrorMessageDisplay = _chunkWI76ZUBEcjs.ErrorMessageDisplay; exports.ExpandChevron = _chunkWI76ZUBEcjs.ExpandChevron; exports.GenericEntityCard = _chunkWI76ZUBEcjs.GenericEntityCard; exports.GenericEntityCardSkeleton = _chunkWI76ZUBEcjs.GenericEntityCardSkeleton; exports.GitHubActivityCard = _chunkWI76ZUBEcjs.GitHubActivityCard; exports.GitHubActivityCardSkeleton = _chunkWI76ZUBEcjs.GitHubActivityCardSkeleton; exports.HubspotTicketCard = _chunkWI76ZUBEcjs.HubspotTicketCard; exports.HubspotTicketCardSkeleton = _chunkWI76ZUBEcjs.HubspotTicketCardSkeleton; exports.ICON_REGISTRY = _chunkWI76ZUBEcjs.ICON_REGISTRY; exports.InvestorUpdateCard = _chunkWI76ZUBEcjs.InvestorUpdateCard; exports.InvestorUpdateCardSkeleton = _chunkWI76ZUBEcjs.InvestorUpdateCardSkeleton; exports.MESSAGE_ROLE = _chunkWI76ZUBEcjs.MESSAGE_ROLE; exports.MESSAGE_TYPE = _chunkWI76ZUBEcjs.MESSAGE_TYPE; exports.MessageSegmentAccumulator = _chunkWI76ZUBEcjs.MessageSegmentAccumulator; exports.MingoOnboardingCard = _chunkWI76ZUBEcjs.MingoOnboardingCard; exports.MingoOnboardingCardSkeleton = _chunkWI76ZUBEcjs.MingoOnboardingCardSkeleton; exports.MingoOnboardingListSkeleton = _chunkWI76ZUBEcjs.MingoOnboardingListSkeleton; exports.ModelDisplay = _chunkWI76ZUBEcjs.ModelDisplay; exports.NETWORK_CONFIG = _chunkWI76ZUBEcjs.NETWORK_CONFIG; exports.NEW_TAB_FEATURES = _chunkWI76ZUBEcjs.NEW_TAB_FEATURES; exports.NavLinkAnchorViaRuntime = _chunkWI76ZUBEcjs.NavLinkAnchorViaRuntime; exports.OWNER_TYPE = _chunkWI76ZUBEcjs.OWNER_TYPE; exports.OnboardingGuideCard = _chunkWI76ZUBEcjs.OnboardingGuideCard; exports.OnboardingGuideCardSkeleton = _chunkWI76ZUBEcjs.OnboardingGuideCardSkeleton; exports.ProductReleaseCard = _chunkWI76ZUBEcjs.ProductReleaseCard; exports.ProductReleaseCardSkeleton = _chunkWI76ZUBEcjs.ProductReleaseCardSkeleton; exports.ProgramCard = _chunkWI76ZUBEcjs.ProgramCard; exports.ProgramCardSkeleton = _chunkWI76ZUBEcjs.ProgramCardSkeleton; exports.ResultBlock = _chunkWI76ZUBEcjs.ResultBlock; exports.RoadmapCard = _chunkWI76ZUBEcjs.RoadmapCard; exports.RoadmapCardSkeleton = _chunkWI76ZUBEcjs.RoadmapCardSkeleton; exports.RoadmapVoteButton = _chunkWI76ZUBEcjs.RoadmapVoteButton; exports.SCROLL_ANCHOR = _chunkWI76ZUBEcjs.SCROLL_ANCHOR; exports.SCROLL_ANCHOR_WIRE_KEY = _chunkWI76ZUBEcjs.SCROLL_ANCHOR_WIRE_KEY; exports.SOURCE_ICON_NAMES = _chunkWI76ZUBEcjs.SOURCE_ICON_NAMES; exports.SOURCE_LABELS_BY_TABLE = _chunkWI76ZUBEcjs.SOURCE_LABELS_BY_TABLE; exports.SlackMessageCard = _chunkWI76ZUBEcjs.SlackMessageCard; exports.SlackMessageCardSkeleton = _chunkWI76ZUBEcjs.SlackMessageCardSkeleton; exports.SlashCommandSuggestions = _chunkWI76ZUBEcjs.SlashCommandSuggestions; exports.SourceActionButton = _chunkWI76ZUBEcjs.SourceActionButton; exports.TaskTypeIcon = _chunkWI76ZUBEcjs.TaskTypeIcon; exports.ThinkingDisplay = _chunkWI76ZUBEcjs.ThinkingDisplay; exports.ToolExecutionDisplay = _chunkWI76ZUBEcjs.ToolExecutionDisplay; exports.applyProxyAuth = _chunkWI76ZUBEcjs.applyProxyAuth; exports.buildAnchorProps = _chunkWI76ZUBEcjs.buildAnchorProps; exports.buildAutoContinuationDirective = _chunkWI76ZUBEcjs.buildAutoContinuationDirective; exports.buildChatAttachmentViewUrl = _chunkWI76ZUBEcjs.buildChatAttachmentViewUrl; exports.buildChatRefKey = _chunkWI76ZUBEcjs.buildChatRefKey; exports.buildDiscussAddendum = _chunkWI76ZUBEcjs.buildDiscussAddendum; exports.buildNatsWsUrl = _chunkWI76ZUBEcjs.buildNatsWsUrl; exports.chatAuthedFetch = _chunkWI76ZUBEcjs.embedAuthedFetch; exports.chatChipClass = _chunkWI76ZUBEcjs.chatChipClass; exports.clearChatProxyAuth = _chunkWI76ZUBEcjs.clearEmbedProxyAuth; exports.clickupTaskUrl = _chunkWI76ZUBEcjs.clickupTaskUrl; exports.computeIsNewTab = _chunkWI76ZUBEcjs.computeIsNewTab; exports.createMessageSegmentAccumulator = _chunkWI76ZUBEcjs.createMessageSegmentAccumulator; exports.decideNewTab = _chunkWI76ZUBEcjs.decideNewTab; exports.defaultTableIdForDocumentType = _chunkWI76ZUBEcjs.defaultTableIdForDocumentType; exports.escapeMarkdownInline = _chunkWI76ZUBEcjs.escapeMarkdownInline; exports.extractEntityIdFilter = _chunkWI76ZUBEcjs.extractEntityIdFilter; exports.extractErrorMessages = _chunkWI76ZUBEcjs.extractErrorMessages; exports.extractIncompleteMessageState = _chunkWI76ZUBEcjs.extractIncompleteMessageState; exports.extractTextFromChunk = _chunkWI76ZUBEcjs.extractTextFromChunk; exports.fetchSlashCommands = _chunkWI76ZUBEcjs.fetchSlashCommands; exports.flattenAssistantContent = _chunkWI76ZUBEcjs.flattenAssistantContent; exports.formatChatAttachmentMarkdownForBubble = _chunkWI76ZUBEcjs.formatChatAttachmentMarkdownForBubble; exports.formatInvestorUpdatePeriod = _chunkWI76ZUBEcjs.formatInvestorUpdatePeriod; exports.formatSingularLookupInvocation = _chunkWI76ZUBEcjs.formatSingularLookupInvocation; exports.getChatProxyAuth = _chunkWI76ZUBEcjs.getEmbedProxyAuth; exports.getCommandText = _chunkWI76ZUBEcjs.getCommandText; exports.getDynamicIcon = _chunkWI76ZUBEcjs.getDynamicIcon; exports.getIconComponent = _chunkWI76ZUBEcjs.getIconComponent; exports.getPersistedProxyEmail = _chunkWI76ZUBEcjs.getPersistedProxyEmail; exports.getSourceIconName = _chunkWI76ZUBEcjs.getSourceIconName; exports.getSourceLabel = _chunkWI76ZUBEcjs.getSourceLabel; exports.getStatusColorScheme = _chunkWI76ZUBEcjs.getStatusColorScheme; exports.getTaskTypeLabel = _chunkWI76ZUBEcjs.getTaskTypeLabel; exports.handleChatNavClick = _chunkWI76ZUBEcjs.handleChatNavClick; exports.isControlChunk = _chunkWI76ZUBEcjs.isControlChunk; exports.isCrossOriginUrl = _chunkWI76ZUBEcjs.isCrossOriginUrl; exports.isErrorChunk = _chunkWI76ZUBEcjs.isErrorChunk; exports.isMetadataChunk = _chunkWI76ZUBEcjs.isMetadataChunk; exports.isModifierClick = _chunkWI76ZUBEcjs.isModifierClick; exports.isStructuredContent = _chunkWI76ZUBEcjs.isStructuredContent; exports.newTabAnchorAttrs = _chunkWI76ZUBEcjs.newTabAnchorAttrs; exports.normalizeContent = _chunkWI76ZUBEcjs.normalizeContent; exports.normalizeIconKey = _chunkWI76ZUBEcjs.normalizeIconKey; exports.parseChunkToAction = _chunkWI76ZUBEcjs.parseChunkToAction; exports.parseScrollAnchor = _chunkWI76ZUBEcjs.parseScrollAnchor; exports.parseWireCommandOverride = _chunkWI76ZUBEcjs.parseWireCommandOverride; exports.processHistoricalMessages = _chunkWI76ZUBEcjs.processHistoricalMessages; exports.processHistoricalMessagesWithErrors = _chunkWI76ZUBEcjs.processHistoricalMessagesWithErrors; exports.remarkCardLinks = _chunkWI76ZUBEcjs.remarkCardLinks; exports.renderChatInlineEntityCard = _chunkWI76ZUBEcjs.renderChatInlineEntityCard; exports.resolveExternalNavigation = _chunkWI76ZUBEcjs.resolveExternalNavigation; exports.resolveSourceIcon = _chunkWI76ZUBEcjs.resolveSourceIcon; exports.resolveSourceRowCTA = _chunkWI76ZUBEcjs.resolveSourceRowCTA; exports.safeHref = _chunkWI76ZUBEcjs.safeHref; exports.sanitizeTitleForChat = _chunkWI76ZUBEcjs.sanitizeTitleForChat; exports.setChatProxyAuth = _chunkWI76ZUBEcjs.setEmbedProxyAuth; exports.stripChatAttachmentMarkdown = _chunkWI76ZUBEcjs.stripChatAttachmentMarkdown; exports.stripSameOriginToPath = _chunkWI76ZUBEcjs.stripSameOriginToPath; exports.transformEventToProgram = _chunkWI76ZUBEcjs.transformEventToProgram; exports.transformPodcastToProgram = _chunkWI76ZUBEcjs.transformPodcastToProgram; exports.transformWebinarToProgram = _chunkWI76ZUBEcjs.transformWebinarToProgram; exports.useChat = _chunkWI76ZUBEcjs.useChat; exports.useChatAttachmentImageGallery = _chunkWI76ZUBEcjs.useChatAttachmentImageGallery; exports.useChatAttachments = _chunkWI76ZUBEcjs.useChatAttachments; exports.useChatCardItem = _chunkWI76ZUBEcjs.useChatCardItem; exports.useChatIdentity = _chunkWI76ZUBEcjs.useChatIdentity; exports.useChunkCatchup = _chunkWI76ZUBEcjs.useChunkCatchup; exports.useCloseOnNavigation = _chunkWI76ZUBEcjs.useCloseOnNavigation; exports.useCollapsible = _chunkWI76ZUBEcjs.useCollapsible; exports.useEmbeddedChat = _chunkWI76ZUBEcjs.useSseChatAdapter; exports.useJetStreamDialogSubscription = _chunkWI76ZUBEcjs.useJetStreamDialogSubscription; exports.useNatsChatAdapter = _chunkWI76ZUBEcjs.useNatsChatAdapter; exports.useNatsDialogSubscription = _chunkWI76ZUBEcjs.useNatsDialogSubscription; exports.useProxiedImageUrl = _chunkWI76ZUBEcjs.useProxiedImageUrl; exports.useRealtimeChunkProcessor = _chunkWI76ZUBEcjs.useRealtimeChunkProcessor; exports.useSSE = _chunkWI76ZUBEcjs.useSSE; exports.useSlashCommands = _chunkWI76ZUBEcjs.useSlashCommands; exports.useSseChatAdapter = _chunkWI76ZUBEcjs.useSseChatAdapter; exports.useUnifiedChat = _chunkWI76ZUBEcjs.useUnifiedChat;
404
404
  //# sourceMappingURL=index.cjs.map
@@ -192,12 +192,12 @@ import {
192
192
  useSlashCommands,
193
193
  useSseChatAdapter,
194
194
  useUnifiedChat
195
- } from "../../chunk-HZT4YU33.js";
195
+ } from "../../chunk-3E5ANY55.js";
196
196
  import "../../chunk-UYQOPC57.js";
197
197
  import "../../chunk-CIPO6DXK.js";
198
198
  import "../../chunk-EDW2NVRV.js";
199
199
  import "../../chunk-W72U7OU7.js";
200
- import "../../chunk-7L4DWM7P.js";
200
+ import "../../chunk-ZG2YY5E7.js";
201
201
  import "../../chunk-MJNXIEV2.js";
202
202
  import "../../chunk-EL5YVPD5.js";
203
203
  import "../../chunk-PLJLE4A4.js";
@@ -1,13 +1,13 @@
1
1
  "use strict";Object.defineProperty(exports, "__esModule", {value: true});"use client";
2
2
 
3
3
 
4
- var _chunkY7IXGY7Tcjs = require('../../chunk-Y7IXGY7T.cjs');
5
- require('../../chunk-SJQLTQC7.cjs');
4
+ var _chunkVTUIMMHOcjs = require('../../chunk-VTUIMMHO.cjs');
5
+ require('../../chunk-WI76ZUBE.cjs');
6
6
  require('../../chunk-EH3RWVF3.cjs');
7
7
  require('../../chunk-24KCAECR.cjs');
8
8
  require('../../chunk-65CPJ4SX.cjs');
9
9
  require('../../chunk-XQFFGR6U.cjs');
10
- require('../../chunk-6RZYJICV.cjs');
10
+ require('../../chunk-P5EE2VJX.cjs');
11
11
  require('../../chunk-27APPAJN.cjs');
12
12
  require('../../chunk-BZFW3FOF.cjs');
13
13
  require('../../chunk-G7UE6RKV.cjs');
@@ -19,5 +19,5 @@ require('../../chunk-WBR7H6E3.cjs');
19
19
  require('../../chunk-VRHGVLSL.cjs');
20
20
 
21
21
 
22
- exports.ContactForm = _chunkY7IXGY7Tcjs.ContactForm;
22
+ exports.ContactForm = _chunkVTUIMMHOcjs.ContactForm;
23
23
  //# sourceMappingURL=index.cjs.map
@@ -1,13 +1,13 @@
1
1
  "use client";
2
2
  import {
3
3
  ContactForm
4
- } from "../../chunk-RFSBDUXD.js";
5
- import "../../chunk-HZT4YU33.js";
4
+ } from "../../chunk-5BNWGK6D.js";
5
+ import "../../chunk-3E5ANY55.js";
6
6
  import "../../chunk-UYQOPC57.js";
7
7
  import "../../chunk-CIPO6DXK.js";
8
8
  import "../../chunk-EDW2NVRV.js";
9
9
  import "../../chunk-W72U7OU7.js";
10
- import "../../chunk-7L4DWM7P.js";
10
+ import "../../chunk-ZG2YY5E7.js";
11
11
  import "../../chunk-MJNXIEV2.js";
12
12
  import "../../chunk-EL5YVPD5.js";
13
13
  import "../../chunk-PLJLE4A4.js";
@@ -90,12 +90,12 @@
90
90
 
91
91
 
92
92
 
93
- var _chunkSJQLTQC7cjs = require('../../chunk-SJQLTQC7.cjs');
93
+ var _chunkWI76ZUBEcjs = require('../../chunk-WI76ZUBE.cjs');
94
94
  require('../../chunk-EH3RWVF3.cjs');
95
95
  require('../../chunk-24KCAECR.cjs');
96
96
  require('../../chunk-65CPJ4SX.cjs');
97
97
  require('../../chunk-XQFFGR6U.cjs');
98
- require('../../chunk-6RZYJICV.cjs');
98
+ require('../../chunk-P5EE2VJX.cjs');
99
99
  require('../../chunk-27APPAJN.cjs');
100
100
  require('../../chunk-BZFW3FOF.cjs');
101
101
  require('../../chunk-G7UE6RKV.cjs');
@@ -195,5 +195,5 @@ require('../../chunk-VRHGVLSL.cjs');
195
195
 
196
196
 
197
197
 
198
- exports.AIEnrichButton = _chunkSJQLTQC7cjs.AIEnrichButton; exports.AIEnrichSection = _chunkSJQLTQC7cjs.AIEnrichSection; exports.AIRequiredBadge = _chunkSJQLTQC7cjs.AIRequiredBadge; exports.AIStatusIndicator = _chunkSJQLTQC7cjs.AIStatusIndicator; exports.AIWarningsSection = _chunkSJQLTQC7cjs.AIWarningsSection; exports.ArrayEntryManager = _chunkSJQLTQC7cjs.ArrayEntryManager; exports.AuthProvidersList = _chunkSJQLTQC7cjs.AuthProvidersList; exports.Board = _chunkSJQLTQC7cjs.Board; exports.BoardColumn = _chunkSJQLTQC7cjs.BoardColumn; exports.BoardColumnHeader = _chunkSJQLTQC7cjs.BoardColumnHeader; exports.ChangelogManager = _chunkSJQLTQC7cjs.ChangelogManager; exports.ChangelogSectionsManager = _chunkSJQLTQC7cjs.ChangelogSectionsManager; exports.ClickUpTasksManager = _chunkSJQLTQC7cjs.ClickUpTasksManager; exports.CommandBox = _chunkSJQLTQC7cjs.CommandBox; exports.ConfidenceBadge = _chunkSJQLTQC7cjs.ConfidenceBadge; exports.DEFAULT_THEME = _chunkSJQLTQC7cjs.DEFAULT_THEME; exports.DynamicThemeProvider = _chunkSJQLTQC7cjs.DynamicThemeProvider; exports.EntitySummaryEditor = _chunkSJQLTQC7cjs.EntitySummaryEditor; exports.EntityVideoSection = _chunkSJQLTQC7cjs.EntityVideoSection; exports.ErrorBoundary = _chunkSJQLTQC7cjs.ErrorBoundary; exports.FigmaPrototypeViewer = _chunkSJQLTQC7cjs.FigmaPrototypeViewer; exports.FiltersDropdown = _chunkSJQLTQC7cjs.FiltersDropdown; exports.GitHubReleasesManager = _chunkSJQLTQC7cjs.GitHubReleasesManager; exports.HighlightConfigSection = _chunkSJQLTQC7cjs.HighlightConfigSection; exports.HighlightGenerationSection = _chunkSJQLTQC7cjs.HighlightGenerationSection; exports.HighlightVideoCombinedSection = _chunkSJQLTQC7cjs.HighlightVideoCombinedSection; exports.HighlightVideoPreview = _chunkSJQLTQC7cjs.HighlightVideoPreview; exports.HighlightVideoSection = _chunkSJQLTQC7cjs.HighlightVideoSection; exports.KnowledgeBaseLinksManager = _chunkSJQLTQC7cjs.KnowledgeBaseLinksManager; exports.LoadingProvider = _chunkSJQLTQC7cjs.LoadingProvider; exports.MediaGalleryManager = _chunkSJQLTQC7cjs.MediaGalleryManager; exports.MoreAboutButton = _chunkSJQLTQC7cjs.MoreAboutButton; exports.NotificationDrawer = _chunkSJQLTQC7cjs.NotificationDrawer; exports.NotificationTile = _chunkSJQLTQC7cjs.NotificationTile; exports.NotificationsProvider = _chunkSJQLTQC7cjs.NotificationsProvider; exports.OPENFRAME_PATHS = _chunkSJQLTQC7cjs.OPENFRAME_PATHS; exports.OSTypeBadge = _chunkSJQLTQC7cjs.OSTypeBadge; exports.OSTypeBadgeGroup = _chunkSJQLTQC7cjs.OSTypeBadgeGroup; exports.OSTypeIcon = _chunkSJQLTQC7cjs.OSTypeIcon; exports.OSTypeLabel = _chunkSJQLTQC7cjs.OSTypeLabel; exports.ParallaxImageShowcase = _chunkSJQLTQC7cjs.ParallaxImageShowcase; exports.PathsDisplay = _chunkSJQLTQC7cjs.PathsDisplay; exports.PlatformBadge = _chunkSJQLTQC7cjs.PlatformBadge; exports.PlatformFilterComponent = _chunkSJQLTQC7cjs.PlatformFilterComponent; exports.PolicyConfigurationPanel = _chunkSJQLTQC7cjs.PolicyConfigurationPanel; exports.ProviderButton = _chunkSJQLTQC7cjs.ProviderButton; exports.PushButtonSelector = _chunkSJQLTQC7cjs.PushButtonSelector; exports.RATIO_DISPLAY_GRID_CLASS = _chunkSJQLTQC7cjs.RATIO_DISPLAY_GRID_CLASS; exports.RATIO_GRID_CLASS = _chunkSJQLTQC7cjs.RATIO_GRID_CLASS; exports.RatioTabs = _chunkSJQLTQC7cjs.RatioTabs; exports.ReleaseMediaManager = _chunkSJQLTQC7cjs.ReleaseMediaManager; exports.SEOEditorPreview = _chunkSJQLTQC7cjs.SEOEditorPreview; exports.SectionSelector = _chunkSJQLTQC7cjs.SectionSelector; exports.SelectButton = _chunkSJQLTQC7cjs.SelectButton; exports.SocialLinksManager = _chunkSJQLTQC7cjs.SocialLinksManager; exports.StartWithOpenFrameButton = _chunkSJQLTQC7cjs.StartWithOpenFrameButton; exports.StatusFilterComponent = _chunkSJQLTQC7cjs.StatusFilterComponent; exports.THEME_ATTRIBUTE = _chunkSJQLTQC7cjs.THEME_ATTRIBUTE; exports.THEME_STORAGE_KEY = _chunkSJQLTQC7cjs.THEME_STORAGE_KEY; exports.TagsSelector = _chunkSJQLTQC7cjs.TagsSelector; exports.ThemeProvider = _chunkSJQLTQC7cjs.ThemeProvider; exports.TicketCard = _chunkSJQLTQC7cjs.TicketCard; exports.TicketCardSkeleton = _chunkSJQLTQC7cjs.TicketCardSkeleton; exports.TranscribeAndSummarizeCombinedSection = _chunkSJQLTQC7cjs.TranscribeAndSummarizeCombinedSection; exports.TranscribeSummarizeSection = _chunkSJQLTQC7cjs.TranscribeSummarizeSection; exports.TranscriptSummaryEditor = _chunkSJQLTQC7cjs.TranscriptSummaryEditor; exports.Video = _chunkSJQLTQC7cjs.Video; exports.VideoBiteCard = _chunkSJQLTQC7cjs.VideoBiteCard; exports.VideoBitesDisplay = _chunkSJQLTQC7cjs.VideoBitesDisplay; exports.VideoClipsSection = _chunkSJQLTQC7cjs.VideoClipsSection; exports.VideoSourceSelector = _chunkSJQLTQC7cjs.VideoSourceSelector; exports.ViewToggle = _chunkSJQLTQC7cjs.ViewToggle; exports.WaitlistForm = _chunkSJQLTQC7cjs.WaitlistForm; exports.columnFromTicketStatus = _chunkSJQLTQC7cjs.columnFromTicketStatus; exports.detectAspectRatio = _chunkSJQLTQC7cjs.detectAspectRatio; exports.extractYouTubeId = _chunkSJQLTQC7cjs.extractYouTubeId; exports.getOpenFramePaths = _chunkSJQLTQC7cjs.getOpenFramePaths; exports.groupByAspectRatio = _chunkSJQLTQC7cjs.groupByAspectRatio; exports.groupTicketsByStatus = _chunkSJQLTQC7cjs.groupTicketsByStatus; exports.ratioToCategory = _chunkSJQLTQC7cjs.ratioToCategory; exports.tintOnDark = _chunkSJQLTQC7cjs.tintOnDark; exports.useBoardCollapse = _chunkSJQLTQC7cjs.useBoardCollapse; exports.useDynamicTheme = _chunkSJQLTQC7cjs.useDynamicTheme; exports.useFiltersDropdown = _chunkSJQLTQC7cjs.useFiltersDropdown; exports.useLoading = _chunkSJQLTQC7cjs.useLoading; exports.useNotifications = _chunkSJQLTQC7cjs.useNotifications; exports.useOptionalNotifications = _chunkSJQLTQC7cjs.useOptionalNotifications; exports.useTheme = _chunkSJQLTQC7cjs.useTheme; exports.useThemeToggle = _chunkSJQLTQC7cjs.useThemeToggle;
198
+ exports.AIEnrichButton = _chunkWI76ZUBEcjs.AIEnrichButton; exports.AIEnrichSection = _chunkWI76ZUBEcjs.AIEnrichSection; exports.AIRequiredBadge = _chunkWI76ZUBEcjs.AIRequiredBadge; exports.AIStatusIndicator = _chunkWI76ZUBEcjs.AIStatusIndicator; exports.AIWarningsSection = _chunkWI76ZUBEcjs.AIWarningsSection; exports.ArrayEntryManager = _chunkWI76ZUBEcjs.ArrayEntryManager; exports.AuthProvidersList = _chunkWI76ZUBEcjs.AuthProvidersList; exports.Board = _chunkWI76ZUBEcjs.Board; exports.BoardColumn = _chunkWI76ZUBEcjs.BoardColumn; exports.BoardColumnHeader = _chunkWI76ZUBEcjs.BoardColumnHeader; exports.ChangelogManager = _chunkWI76ZUBEcjs.ChangelogManager; exports.ChangelogSectionsManager = _chunkWI76ZUBEcjs.ChangelogSectionsManager; exports.ClickUpTasksManager = _chunkWI76ZUBEcjs.ClickUpTasksManager; exports.CommandBox = _chunkWI76ZUBEcjs.CommandBox; exports.ConfidenceBadge = _chunkWI76ZUBEcjs.ConfidenceBadge; exports.DEFAULT_THEME = _chunkWI76ZUBEcjs.DEFAULT_THEME; exports.DynamicThemeProvider = _chunkWI76ZUBEcjs.DynamicThemeProvider; exports.EntitySummaryEditor = _chunkWI76ZUBEcjs.EntitySummaryEditor; exports.EntityVideoSection = _chunkWI76ZUBEcjs.EntityVideoSection; exports.ErrorBoundary = _chunkWI76ZUBEcjs.ErrorBoundary; exports.FigmaPrototypeViewer = _chunkWI76ZUBEcjs.FigmaPrototypeViewer; exports.FiltersDropdown = _chunkWI76ZUBEcjs.FiltersDropdown; exports.GitHubReleasesManager = _chunkWI76ZUBEcjs.GitHubReleasesManager; exports.HighlightConfigSection = _chunkWI76ZUBEcjs.HighlightConfigSection; exports.HighlightGenerationSection = _chunkWI76ZUBEcjs.HighlightGenerationSection; exports.HighlightVideoCombinedSection = _chunkWI76ZUBEcjs.HighlightVideoCombinedSection; exports.HighlightVideoPreview = _chunkWI76ZUBEcjs.HighlightVideoPreview; exports.HighlightVideoSection = _chunkWI76ZUBEcjs.HighlightVideoSection; exports.KnowledgeBaseLinksManager = _chunkWI76ZUBEcjs.KnowledgeBaseLinksManager; exports.LoadingProvider = _chunkWI76ZUBEcjs.LoadingProvider; exports.MediaGalleryManager = _chunkWI76ZUBEcjs.MediaGalleryManager; exports.MoreAboutButton = _chunkWI76ZUBEcjs.MoreAboutButton; exports.NotificationDrawer = _chunkWI76ZUBEcjs.NotificationDrawer; exports.NotificationTile = _chunkWI76ZUBEcjs.NotificationTile; exports.NotificationsProvider = _chunkWI76ZUBEcjs.NotificationsProvider; exports.OPENFRAME_PATHS = _chunkWI76ZUBEcjs.OPENFRAME_PATHS; exports.OSTypeBadge = _chunkWI76ZUBEcjs.OSTypeBadge; exports.OSTypeBadgeGroup = _chunkWI76ZUBEcjs.OSTypeBadgeGroup; exports.OSTypeIcon = _chunkWI76ZUBEcjs.OSTypeIcon; exports.OSTypeLabel = _chunkWI76ZUBEcjs.OSTypeLabel; exports.ParallaxImageShowcase = _chunkWI76ZUBEcjs.ParallaxImageShowcase; exports.PathsDisplay = _chunkWI76ZUBEcjs.PathsDisplay; exports.PlatformBadge = _chunkWI76ZUBEcjs.PlatformBadge; exports.PlatformFilterComponent = _chunkWI76ZUBEcjs.PlatformFilterComponent; exports.PolicyConfigurationPanel = _chunkWI76ZUBEcjs.PolicyConfigurationPanel; exports.ProviderButton = _chunkWI76ZUBEcjs.ProviderButton; exports.PushButtonSelector = _chunkWI76ZUBEcjs.PushButtonSelector; exports.RATIO_DISPLAY_GRID_CLASS = _chunkWI76ZUBEcjs.RATIO_DISPLAY_GRID_CLASS; exports.RATIO_GRID_CLASS = _chunkWI76ZUBEcjs.RATIO_GRID_CLASS; exports.RatioTabs = _chunkWI76ZUBEcjs.RatioTabs; exports.ReleaseMediaManager = _chunkWI76ZUBEcjs.ReleaseMediaManager; exports.SEOEditorPreview = _chunkWI76ZUBEcjs.SEOEditorPreview; exports.SectionSelector = _chunkWI76ZUBEcjs.SectionSelector; exports.SelectButton = _chunkWI76ZUBEcjs.SelectButton; exports.SocialLinksManager = _chunkWI76ZUBEcjs.SocialLinksManager; exports.StartWithOpenFrameButton = _chunkWI76ZUBEcjs.StartWithOpenFrameButton; exports.StatusFilterComponent = _chunkWI76ZUBEcjs.StatusFilterComponent; exports.THEME_ATTRIBUTE = _chunkWI76ZUBEcjs.THEME_ATTRIBUTE; exports.THEME_STORAGE_KEY = _chunkWI76ZUBEcjs.THEME_STORAGE_KEY; exports.TagsSelector = _chunkWI76ZUBEcjs.TagsSelector; exports.ThemeProvider = _chunkWI76ZUBEcjs.ThemeProvider; exports.TicketCard = _chunkWI76ZUBEcjs.TicketCard; exports.TicketCardSkeleton = _chunkWI76ZUBEcjs.TicketCardSkeleton; exports.TranscribeAndSummarizeCombinedSection = _chunkWI76ZUBEcjs.TranscribeAndSummarizeCombinedSection; exports.TranscribeSummarizeSection = _chunkWI76ZUBEcjs.TranscribeSummarizeSection; exports.TranscriptSummaryEditor = _chunkWI76ZUBEcjs.TranscriptSummaryEditor; exports.Video = _chunkWI76ZUBEcjs.Video; exports.VideoBiteCard = _chunkWI76ZUBEcjs.VideoBiteCard; exports.VideoBitesDisplay = _chunkWI76ZUBEcjs.VideoBitesDisplay; exports.VideoClipsSection = _chunkWI76ZUBEcjs.VideoClipsSection; exports.VideoSourceSelector = _chunkWI76ZUBEcjs.VideoSourceSelector; exports.ViewToggle = _chunkWI76ZUBEcjs.ViewToggle; exports.WaitlistForm = _chunkWI76ZUBEcjs.WaitlistForm; exports.columnFromTicketStatus = _chunkWI76ZUBEcjs.columnFromTicketStatus; exports.detectAspectRatio = _chunkWI76ZUBEcjs.detectAspectRatio; exports.extractYouTubeId = _chunkWI76ZUBEcjs.extractYouTubeId; exports.getOpenFramePaths = _chunkWI76ZUBEcjs.getOpenFramePaths; exports.groupByAspectRatio = _chunkWI76ZUBEcjs.groupByAspectRatio; exports.groupTicketsByStatus = _chunkWI76ZUBEcjs.groupTicketsByStatus; exports.ratioToCategory = _chunkWI76ZUBEcjs.ratioToCategory; exports.tintOnDark = _chunkWI76ZUBEcjs.tintOnDark; exports.useBoardCollapse = _chunkWI76ZUBEcjs.useBoardCollapse; exports.useDynamicTheme = _chunkWI76ZUBEcjs.useDynamicTheme; exports.useFiltersDropdown = _chunkWI76ZUBEcjs.useFiltersDropdown; exports.useLoading = _chunkWI76ZUBEcjs.useLoading; exports.useNotifications = _chunkWI76ZUBEcjs.useNotifications; exports.useOptionalNotifications = _chunkWI76ZUBEcjs.useOptionalNotifications; exports.useTheme = _chunkWI76ZUBEcjs.useTheme; exports.useThemeToggle = _chunkWI76ZUBEcjs.useThemeToggle;
199
199
  //# sourceMappingURL=index.cjs.map