@misael703/ui 1.37.0 → 1.38.1

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 (126) hide show
  1. package/dist/{chunk-42EYBIRW.js → chunk-2PNXLTEM.js} +3 -3
  2. package/dist/{chunk-42EYBIRW.js.map → chunk-2PNXLTEM.js.map} +1 -1
  3. package/dist/{chunk-M5LAEA7D.mjs → chunk-3AW3TK6D.mjs} +3 -3
  4. package/dist/{chunk-M5LAEA7D.mjs.map → chunk-3AW3TK6D.mjs.map} +1 -1
  5. package/dist/{chunk-4WGXCRNN.js → chunk-3JRP3DGM.js} +3 -3
  6. package/dist/{chunk-4WGXCRNN.js.map → chunk-3JRP3DGM.js.map} +1 -1
  7. package/dist/{chunk-726G5C65.mjs → chunk-3JYYZOEJ.mjs} +3 -3
  8. package/dist/{chunk-726G5C65.mjs.map → chunk-3JYYZOEJ.mjs.map} +1 -1
  9. package/dist/{chunk-ABN634QO.js → chunk-565UJQ2M.js} +4 -4
  10. package/dist/{chunk-ABN634QO.js.map → chunk-565UJQ2M.js.map} +1 -1
  11. package/dist/{chunk-KQ66GQU6.mjs → chunk-5X6SKHZW.mjs} +4 -4
  12. package/dist/{chunk-KQ66GQU6.mjs.map → chunk-5X6SKHZW.mjs.map} +1 -1
  13. package/dist/{chunk-JZ3JAEK4.mjs → chunk-63LUAWJS.mjs} +5 -5
  14. package/dist/{chunk-JZ3JAEK4.mjs.map → chunk-63LUAWJS.mjs.map} +1 -1
  15. package/dist/{chunk-56AR3HZK.mjs → chunk-6KIM3DOH.mjs} +6 -4
  16. package/dist/chunk-6KIM3DOH.mjs.map +1 -0
  17. package/dist/{chunk-TW54NMEG.js → chunk-AGMDYCGG.js} +4 -4
  18. package/dist/{chunk-TW54NMEG.js.map → chunk-AGMDYCGG.js.map} +1 -1
  19. package/dist/{chunk-K5B6WQFI.js → chunk-C7UG47HQ.js} +5 -5
  20. package/dist/{chunk-K5B6WQFI.js.map → chunk-C7UG47HQ.js.map} +1 -1
  21. package/dist/{chunk-BB4WO2VU.js → chunk-D44PGK5V.js} +4 -4
  22. package/dist/{chunk-BB4WO2VU.js.map → chunk-D44PGK5V.js.map} +1 -1
  23. package/dist/{chunk-Z5PAD5A6.mjs → chunk-DH3IXJRJ.mjs} +4 -4
  24. package/dist/{chunk-Z5PAD5A6.mjs.map → chunk-DH3IXJRJ.mjs.map} +1 -1
  25. package/dist/{chunk-NZKXHTM4.js → chunk-F3PTSBHH.js} +6 -6
  26. package/dist/{chunk-NZKXHTM4.js.map → chunk-F3PTSBHH.js.map} +1 -1
  27. package/dist/{chunk-4GF3YGPG.mjs → chunk-FD3Y5IP7.mjs} +4 -4
  28. package/dist/{chunk-4GF3YGPG.mjs.map → chunk-FD3Y5IP7.mjs.map} +1 -1
  29. package/dist/{chunk-6GFZO3UZ.mjs → chunk-FHOI6O37.mjs} +10 -3
  30. package/dist/chunk-FHOI6O37.mjs.map +1 -0
  31. package/dist/{chunk-I7URH4F2.mjs → chunk-FR4JV3JA.mjs} +3 -3
  32. package/dist/{chunk-I7URH4F2.mjs.map → chunk-FR4JV3JA.mjs.map} +1 -1
  33. package/dist/{chunk-3TFYIWFE.mjs → chunk-G5I2VVOC.mjs} +3 -3
  34. package/dist/{chunk-3TFYIWFE.mjs.map → chunk-G5I2VVOC.mjs.map} +1 -1
  35. package/dist/{chunk-732BPQGZ.js → chunk-HCTY5QYL.js} +3 -3
  36. package/dist/{chunk-732BPQGZ.js.map → chunk-HCTY5QYL.js.map} +1 -1
  37. package/dist/{chunk-3T7MQEQG.mjs → chunk-HWOG3TZD.mjs} +3 -3
  38. package/dist/{chunk-3T7MQEQG.mjs.map → chunk-HWOG3TZD.mjs.map} +1 -1
  39. package/dist/{chunk-OQXOF34S.js → chunk-JJ54RD36.js} +5 -5
  40. package/dist/{chunk-OQXOF34S.js.map → chunk-JJ54RD36.js.map} +1 -1
  41. package/dist/{chunk-QR6X2UOT.mjs → chunk-JMFDIN5R.mjs} +3 -3
  42. package/dist/{chunk-QR6X2UOT.mjs.map → chunk-JMFDIN5R.mjs.map} +1 -1
  43. package/dist/{chunk-CEY7IC35.js → chunk-KWXF6OQW.js} +5 -5
  44. package/dist/{chunk-CEY7IC35.js.map → chunk-KWXF6OQW.js.map} +1 -1
  45. package/dist/{chunk-KJ6YAYWS.js → chunk-MW7HQCFC.js} +3 -3
  46. package/dist/{chunk-KJ6YAYWS.js.map → chunk-MW7HQCFC.js.map} +1 -1
  47. package/dist/{chunk-74XHJITO.js → chunk-NMUTNNAC.js} +6 -4
  48. package/dist/chunk-NMUTNNAC.js.map +1 -0
  49. package/dist/{chunk-PUEGDRTJ.mjs → chunk-NS6CI6RP.mjs} +3 -3
  50. package/dist/{chunk-PUEGDRTJ.mjs.map → chunk-NS6CI6RP.mjs.map} +1 -1
  51. package/dist/{chunk-JZNUYA42.js → chunk-NU4GAGUV.js} +3 -3
  52. package/dist/{chunk-JZNUYA42.js.map → chunk-NU4GAGUV.js.map} +1 -1
  53. package/dist/{chunk-VC46KCRL.mjs → chunk-OIYIWG53.mjs} +4 -4
  54. package/dist/{chunk-VC46KCRL.mjs.map → chunk-OIYIWG53.mjs.map} +1 -1
  55. package/dist/{chunk-SAAU2FYV.js → chunk-P6ZVZXTC.js} +4 -4
  56. package/dist/{chunk-SAAU2FYV.js.map → chunk-P6ZVZXTC.js.map} +1 -1
  57. package/dist/{chunk-5ELGA7CC.js → chunk-PFPD2HFZ.js} +3 -3
  58. package/dist/{chunk-5ELGA7CC.js.map → chunk-PFPD2HFZ.js.map} +1 -1
  59. package/dist/{chunk-5TWNDG3J.mjs → chunk-S5OEOR57.mjs} +5 -5
  60. package/dist/{chunk-5TWNDG3J.mjs.map → chunk-S5OEOR57.mjs.map} +1 -1
  61. package/dist/{chunk-REBDGX5X.js → chunk-T2LO33GM.js} +10 -3
  62. package/dist/chunk-T2LO33GM.js.map +1 -0
  63. package/dist/{chunk-MATGDAGX.js → chunk-TX4BUYX4.js} +4 -4
  64. package/dist/{chunk-MATGDAGX.js.map → chunk-TX4BUYX4.js.map} +1 -1
  65. package/dist/{chunk-Y3IPKGOU.mjs → chunk-VOSVV3LL.mjs} +6 -6
  66. package/dist/{chunk-Y3IPKGOU.mjs.map → chunk-VOSVV3LL.mjs.map} +1 -1
  67. package/dist/{chunk-QUDDL33X.js → chunk-WPCQJ7XW.js} +4 -4
  68. package/dist/{chunk-QUDDL33X.js.map → chunk-WPCQJ7XW.js.map} +1 -1
  69. package/dist/{chunk-HFRMDYNW.mjs → chunk-X36H75RR.mjs} +3 -3
  70. package/dist/{chunk-HFRMDYNW.mjs.map → chunk-X36H75RR.mjs.map} +1 -1
  71. package/dist/{chunk-SFA3NSVM.js → chunk-YIGSCVHS.js} +5 -5
  72. package/dist/{chunk-SFA3NSVM.js.map → chunk-YIGSCVHS.js.map} +1 -1
  73. package/dist/{chunk-ZTAAFZNC.mjs → chunk-YXUYWO2W.mjs} +3 -3
  74. package/dist/{chunk-ZTAAFZNC.mjs.map → chunk-YXUYWO2W.mjs.map} +1 -1
  75. package/dist/{chunk-KSIAOURE.mjs → chunk-ZK6OK55L.mjs} +3 -3
  76. package/dist/{chunk-KSIAOURE.mjs.map → chunk-ZK6OK55L.mjs.map} +1 -1
  77. package/dist/components/AdvancedPickers.js +9 -9
  78. package/dist/components/AdvancedPickers.mjs +5 -5
  79. package/dist/components/AppShell.js +8 -8
  80. package/dist/components/AppShell.mjs +6 -6
  81. package/dist/components/Comments.js +8 -8
  82. package/dist/components/Comments.mjs +5 -5
  83. package/dist/components/Commerce.js +18 -18
  84. package/dist/components/Commerce.mjs +7 -7
  85. package/dist/components/ContextMenu.js +3 -3
  86. package/dist/components/ContextMenu.mjs +2 -2
  87. package/dist/components/DataTable.d.mts +10 -1
  88. package/dist/components/DataTable.d.ts +10 -1
  89. package/dist/components/DataTable.js +7 -7
  90. package/dist/components/DataTable.mjs +1 -1
  91. package/dist/components/Display2.js +7 -7
  92. package/dist/components/Display2.mjs +3 -3
  93. package/dist/components/Display3.js +11 -11
  94. package/dist/components/Display3.mjs +5 -5
  95. package/dist/components/Editing.js +12 -12
  96. package/dist/components/Editing.mjs +7 -7
  97. package/dist/components/HoverCard.js +3 -3
  98. package/dist/components/HoverCard.mjs +2 -2
  99. package/dist/components/InputsExtra.js +11 -11
  100. package/dist/components/InputsExtra.mjs +2 -2
  101. package/dist/components/Layout.js +21 -21
  102. package/dist/components/Layout.mjs +2 -2
  103. package/dist/components/Logo.js +3 -3
  104. package/dist/components/Logo.mjs +2 -2
  105. package/dist/components/Menubar.js +3 -3
  106. package/dist/components/Menubar.mjs +2 -2
  107. package/dist/components/NavigationMenu.js +4 -4
  108. package/dist/components/NavigationMenu.mjs +3 -3
  109. package/dist/components/Overlay.js +8 -8
  110. package/dist/components/Overlay.mjs +6 -6
  111. package/dist/components/Pickers.js +9 -9
  112. package/dist/components/Pickers.mjs +4 -4
  113. package/dist/components/Popover.js +3 -3
  114. package/dist/components/Popover.mjs +2 -2
  115. package/dist/components/TimeAgo.js +6 -6
  116. package/dist/components/TimeAgo.mjs +4 -4
  117. package/dist/hooks/index.js +10 -10
  118. package/dist/hooks/index.mjs +2 -2
  119. package/dist/index.js +140 -140
  120. package/dist/index.mjs +30 -30
  121. package/dist/styles.css +1 -1
  122. package/package.json +1 -1
  123. package/dist/chunk-56AR3HZK.mjs.map +0 -1
  124. package/dist/chunk-6GFZO3UZ.mjs.map +0 -1
  125. package/dist/chunk-74XHJITO.js.map +0 -1
  126. package/dist/chunk-REBDGX5X.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/components/Menubar.tsx"],"names":[],"mappings":"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","file":"chunk-ZTAAFZNC.mjs","sourcesContent":["'use client';\nimport * as React from 'react';\nimport { cx } from '../utils/cx';\nimport { Portal } from './Portal';\nimport { usePopoverPosition } from '../hooks/usePopoverPosition';\nimport { useDismiss } from '../hooks/useDismiss';\n\nexport interface MenubarItem {\n id: string;\n label?: React.ReactNode;\n onSelect?: () => void;\n disabled?: boolean;\n separator?: boolean;\n shortcut?: string;\n}\n\nexport interface MenubarMenu {\n id: string;\n label: React.ReactNode;\n items: MenubarItem[];\n}\n\nexport interface MenubarProps {\n menus: MenubarMenu[];\n className?: string;\n ariaLabel?: string;\n}\n\nexport function Menubar({ menus, className, ariaLabel = 'Barra de menús' }: MenubarProps) {\n const [openId, setOpenId] = React.useState<string | null>(null);\n const [active, setActive] = React.useState(0);\n // Roving tab stop for the menubar row (one tab stop, arrows move between\n // triggers — WAI-ARIA menubar pattern).\n const [tabId, setTabId] = React.useState<string | null>(menus[0]?.id ?? null);\n // Keyboard opens move focus into the menu; pointer opens don't.\n const focusOnOpen = React.useRef(false);\n const rootRef = React.useRef<HTMLDivElement>(null);\n const panelRef = React.useRef<HTMLUListElement>(null);\n const anchorRef = React.useRef<HTMLElement | null>(null);\n const triggerRefs = React.useRef<Record<string, HTMLButtonElement | null>>({});\n const itemRefs = React.useRef<Array<HTMLButtonElement | null>>([]);\n\n const open = openId !== null;\n const openMenu = menus.find((m) => m.id === openId) ?? null;\n const menuIndex = menus.findIndex((m) => m.id === openId);\n\n // Positions within the open menu that are selectable (no\n // separators/disabled). `active` indexes into this list.\n const enabledIdx = (openMenu?.items ?? [])\n .map((it, i) => (it.separator || it.disabled ? -1 : i))\n .filter((i) => i >= 0);\n\n const pos = usePopoverPosition(anchorRef, panelRef, {\n open,\n side: 'bottom',\n align: 'start',\n offset: 6,\n });\n\n useDismiss({\n open,\n onDismiss: () => setOpenId(null),\n refs: [rootRef, panelRef],\n closeOnEscape: false,\n });\n\n const focusTrigger = (id: string | null) => {\n if (id) triggerRefs.current[id]?.focus();\n };\n\n const openMenuById = (id: string, viaKeyboard: boolean) => {\n const el = triggerRefs.current[id];\n if (el) anchorRef.current = el;\n focusOnOpen.current = viaKeyboard;\n setActive(0);\n setTabId(id);\n setOpenId(id);\n };\n\n const closeAndFocusTrigger = () => {\n const id = openId;\n setOpenId(null);\n focusTrigger(id);\n };\n\n React.useEffect(() => {\n if (open && focusOnOpen.current) {\n focusOnOpen.current = false;\n const realIdx = enabledIdx[0];\n if (realIdx != null) itemRefs.current[realIdx]?.focus();\n }\n }, [open, enabledIdx]);\n\n React.useEffect(() => {\n if (!open || focusOnOpen.current) return;\n const realIdx = enabledIdx[active];\n if (realIdx != null) itemRefs.current[realIdx]?.focus();\n }, [open, active, enabledIdx]);\n\n const selectItem = (item: MenubarItem) => {\n if (item.disabled || item.separator) return;\n item.onSelect?.();\n closeAndFocusTrigger();\n };\n\n const stepMenu = (dir: 1 | -1) => {\n if (menus.length === 0) return;\n const from = menuIndex >= 0 ? menuIndex : 0;\n const next = (from + dir + menus.length) % menus.length;\n openMenuById(menus[next].id, true);\n };\n\n const onTriggerKeyDown = (e: React.KeyboardEvent, menu: MenubarMenu, index: number) => {\n if (e.key === 'ArrowDown' || e.key === 'Enter' || e.key === ' ') {\n e.preventDefault();\n openMenuById(menu.id, true);\n } else if (e.key === 'ArrowRight') {\n e.preventDefault();\n const next = menus[(index + 1) % menus.length];\n setTabId(next.id);\n if (open) openMenuById(next.id, true);\n else focusTrigger(next.id);\n } else if (e.key === 'ArrowLeft') {\n e.preventDefault();\n const prev = menus[(index - 1 + menus.length) % menus.length];\n setTabId(prev.id);\n if (open) openMenuById(prev.id, true);\n else focusTrigger(prev.id);\n } else if (e.key === 'Escape' && open) {\n e.preventDefault();\n setOpenId(null);\n } else if (e.key === 'Home') {\n e.preventDefault();\n setTabId(menus[0].id);\n focusTrigger(menus[0].id);\n } else if (e.key === 'End') {\n e.preventDefault();\n const last = menus[menus.length - 1];\n setTabId(last.id);\n focusTrigger(last.id);\n }\n };\n\n const onPanelKeyDown = (e: React.KeyboardEvent) => {\n if (e.key === 'Escape') {\n e.preventDefault();\n closeAndFocusTrigger();\n } else if (e.key === 'Tab') {\n setOpenId(null);\n } else if (e.key === 'ArrowDown') {\n e.preventDefault();\n setActive((a) => Math.min(a + 1, enabledIdx.length - 1));\n } else if (e.key === 'ArrowUp') {\n e.preventDefault();\n setActive((a) => Math.max(a - 1, 0));\n } else if (e.key === 'Home') {\n e.preventDefault();\n setActive(0);\n } else if (e.key === 'End') {\n e.preventDefault();\n setActive(Math.max(enabledIdx.length - 1, 0));\n } else if (e.key === 'ArrowRight') {\n e.preventDefault();\n stepMenu(1);\n } else if (e.key === 'ArrowLeft') {\n e.preventDefault();\n stepMenu(-1);\n } else if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault();\n const realIdx = enabledIdx[active];\n const it = realIdx != null ? openMenu?.items[realIdx] : undefined;\n if (it) selectItem(it);\n }\n };\n\n return (\n <div ref={rootRef} role=\"menubar\" aria-label={ariaLabel} className={cx('menubar', className)}>\n {menus.map((menu, index) => {\n const isOpen = openId === menu.id;\n return (\n <div key={menu.id} className=\"menubar__menu\">\n <button\n type=\"button\"\n role=\"menuitem\"\n ref={(el) => { triggerRefs.current[menu.id] = el; }}\n tabIndex={(tabId ?? menus[0]?.id) === menu.id ? 0 : -1}\n aria-haspopup=\"menu\"\n aria-expanded={isOpen}\n className={cx('menubar__trigger', isOpen && 'is-open')}\n onClick={(e) => {\n if (isOpen) { setOpenId(null); return; }\n anchorRef.current = e.currentTarget;\n focusOnOpen.current = false;\n setActive(0);\n setTabId(menu.id);\n setOpenId(menu.id);\n }}\n onMouseEnter={(e) => {\n if (!openId) return;\n anchorRef.current = e.currentTarget;\n focusOnOpen.current = false;\n setActive(0);\n setTabId(menu.id);\n setOpenId(menu.id);\n }}\n onFocus={() => setTabId(menu.id)}\n onKeyDown={(e) => onTriggerKeyDown(e, menu, index)}\n >\n {menu.label}\n </button>\n {isOpen && (\n <Portal>\n <ul\n ref={panelRef}\n role=\"menu\"\n aria-label={typeof menu.label === 'string' ? menu.label : undefined}\n className=\"menubar__list\"\n onKeyDown={onPanelKeyDown}\n style={{\n position: 'fixed',\n top: pos.top,\n left: pos.left,\n visibility: pos.ready ? 'visible' : 'hidden',\n }}\n >\n {menu.items.map((item, i) =>\n item.separator ? (\n <li key={item.id} className=\"menubar__separator\" role=\"separator\" />\n ) : (\n <li key={item.id} role=\"none\">\n <button\n type=\"button\"\n role=\"menuitem\"\n ref={(el) => { itemRefs.current[i] = el; }}\n tabIndex={enabledIdx[active] === i ? 0 : -1}\n disabled={item.disabled}\n className={cx('menubar__item', item.disabled && 'is-disabled', enabledIdx[active] === i && 'is-active')}\n onMouseEnter={() => setActive(enabledIdx.indexOf(i))}\n onClick={() => selectItem(item)}\n >\n <span className=\"menubar__label\">{item.label}</span>\n {item.shortcut && <kbd className=\"menubar__shortcut\">{item.shortcut}</kbd>}\n </button>\n </li>\n )\n )}\n </ul>\n </Portal>\n )}\n </div>\n );\n })}\n </div>\n );\n}\n"]}
1
+ {"version":3,"sources":["../src/components/Menubar.tsx"],"names":[],"mappings":"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","file":"chunk-YXUYWO2W.mjs","sourcesContent":["'use client';\nimport * as React from 'react';\nimport { cx } from '../utils/cx';\nimport { Portal } from './Portal';\nimport { usePopoverPosition } from '../hooks/usePopoverPosition';\nimport { useDismiss } from '../hooks/useDismiss';\n\nexport interface MenubarItem {\n id: string;\n label?: React.ReactNode;\n onSelect?: () => void;\n disabled?: boolean;\n separator?: boolean;\n shortcut?: string;\n}\n\nexport interface MenubarMenu {\n id: string;\n label: React.ReactNode;\n items: MenubarItem[];\n}\n\nexport interface MenubarProps {\n menus: MenubarMenu[];\n className?: string;\n ariaLabel?: string;\n}\n\nexport function Menubar({ menus, className, ariaLabel = 'Barra de menús' }: MenubarProps) {\n const [openId, setOpenId] = React.useState<string | null>(null);\n const [active, setActive] = React.useState(0);\n // Roving tab stop for the menubar row (one tab stop, arrows move between\n // triggers — WAI-ARIA menubar pattern).\n const [tabId, setTabId] = React.useState<string | null>(menus[0]?.id ?? null);\n // Keyboard opens move focus into the menu; pointer opens don't.\n const focusOnOpen = React.useRef(false);\n const rootRef = React.useRef<HTMLDivElement>(null);\n const panelRef = React.useRef<HTMLUListElement>(null);\n const anchorRef = React.useRef<HTMLElement | null>(null);\n const triggerRefs = React.useRef<Record<string, HTMLButtonElement | null>>({});\n const itemRefs = React.useRef<Array<HTMLButtonElement | null>>([]);\n\n const open = openId !== null;\n const openMenu = menus.find((m) => m.id === openId) ?? null;\n const menuIndex = menus.findIndex((m) => m.id === openId);\n\n // Positions within the open menu that are selectable (no\n // separators/disabled). `active` indexes into this list.\n const enabledIdx = (openMenu?.items ?? [])\n .map((it, i) => (it.separator || it.disabled ? -1 : i))\n .filter((i) => i >= 0);\n\n const pos = usePopoverPosition(anchorRef, panelRef, {\n open,\n side: 'bottom',\n align: 'start',\n offset: 6,\n });\n\n useDismiss({\n open,\n onDismiss: () => setOpenId(null),\n refs: [rootRef, panelRef],\n closeOnEscape: false,\n });\n\n const focusTrigger = (id: string | null) => {\n if (id) triggerRefs.current[id]?.focus();\n };\n\n const openMenuById = (id: string, viaKeyboard: boolean) => {\n const el = triggerRefs.current[id];\n if (el) anchorRef.current = el;\n focusOnOpen.current = viaKeyboard;\n setActive(0);\n setTabId(id);\n setOpenId(id);\n };\n\n const closeAndFocusTrigger = () => {\n const id = openId;\n setOpenId(null);\n focusTrigger(id);\n };\n\n React.useEffect(() => {\n if (open && focusOnOpen.current) {\n focusOnOpen.current = false;\n const realIdx = enabledIdx[0];\n if (realIdx != null) itemRefs.current[realIdx]?.focus();\n }\n }, [open, enabledIdx]);\n\n React.useEffect(() => {\n if (!open || focusOnOpen.current) return;\n const realIdx = enabledIdx[active];\n if (realIdx != null) itemRefs.current[realIdx]?.focus();\n }, [open, active, enabledIdx]);\n\n const selectItem = (item: MenubarItem) => {\n if (item.disabled || item.separator) return;\n item.onSelect?.();\n closeAndFocusTrigger();\n };\n\n const stepMenu = (dir: 1 | -1) => {\n if (menus.length === 0) return;\n const from = menuIndex >= 0 ? menuIndex : 0;\n const next = (from + dir + menus.length) % menus.length;\n openMenuById(menus[next].id, true);\n };\n\n const onTriggerKeyDown = (e: React.KeyboardEvent, menu: MenubarMenu, index: number) => {\n if (e.key === 'ArrowDown' || e.key === 'Enter' || e.key === ' ') {\n e.preventDefault();\n openMenuById(menu.id, true);\n } else if (e.key === 'ArrowRight') {\n e.preventDefault();\n const next = menus[(index + 1) % menus.length];\n setTabId(next.id);\n if (open) openMenuById(next.id, true);\n else focusTrigger(next.id);\n } else if (e.key === 'ArrowLeft') {\n e.preventDefault();\n const prev = menus[(index - 1 + menus.length) % menus.length];\n setTabId(prev.id);\n if (open) openMenuById(prev.id, true);\n else focusTrigger(prev.id);\n } else if (e.key === 'Escape' && open) {\n e.preventDefault();\n setOpenId(null);\n } else if (e.key === 'Home') {\n e.preventDefault();\n setTabId(menus[0].id);\n focusTrigger(menus[0].id);\n } else if (e.key === 'End') {\n e.preventDefault();\n const last = menus[menus.length - 1];\n setTabId(last.id);\n focusTrigger(last.id);\n }\n };\n\n const onPanelKeyDown = (e: React.KeyboardEvent) => {\n if (e.key === 'Escape') {\n e.preventDefault();\n closeAndFocusTrigger();\n } else if (e.key === 'Tab') {\n setOpenId(null);\n } else if (e.key === 'ArrowDown') {\n e.preventDefault();\n setActive((a) => Math.min(a + 1, enabledIdx.length - 1));\n } else if (e.key === 'ArrowUp') {\n e.preventDefault();\n setActive((a) => Math.max(a - 1, 0));\n } else if (e.key === 'Home') {\n e.preventDefault();\n setActive(0);\n } else if (e.key === 'End') {\n e.preventDefault();\n setActive(Math.max(enabledIdx.length - 1, 0));\n } else if (e.key === 'ArrowRight') {\n e.preventDefault();\n stepMenu(1);\n } else if (e.key === 'ArrowLeft') {\n e.preventDefault();\n stepMenu(-1);\n } else if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault();\n const realIdx = enabledIdx[active];\n const it = realIdx != null ? openMenu?.items[realIdx] : undefined;\n if (it) selectItem(it);\n }\n };\n\n return (\n <div ref={rootRef} role=\"menubar\" aria-label={ariaLabel} className={cx('menubar', className)}>\n {menus.map((menu, index) => {\n const isOpen = openId === menu.id;\n return (\n <div key={menu.id} className=\"menubar__menu\">\n <button\n type=\"button\"\n role=\"menuitem\"\n ref={(el) => { triggerRefs.current[menu.id] = el; }}\n tabIndex={(tabId ?? menus[0]?.id) === menu.id ? 0 : -1}\n aria-haspopup=\"menu\"\n aria-expanded={isOpen}\n className={cx('menubar__trigger', isOpen && 'is-open')}\n onClick={(e) => {\n if (isOpen) { setOpenId(null); return; }\n anchorRef.current = e.currentTarget;\n focusOnOpen.current = false;\n setActive(0);\n setTabId(menu.id);\n setOpenId(menu.id);\n }}\n onMouseEnter={(e) => {\n if (!openId) return;\n anchorRef.current = e.currentTarget;\n focusOnOpen.current = false;\n setActive(0);\n setTabId(menu.id);\n setOpenId(menu.id);\n }}\n onFocus={() => setTabId(menu.id)}\n onKeyDown={(e) => onTriggerKeyDown(e, menu, index)}\n >\n {menu.label}\n </button>\n {isOpen && (\n <Portal>\n <ul\n ref={panelRef}\n role=\"menu\"\n aria-label={typeof menu.label === 'string' ? menu.label : undefined}\n className=\"menubar__list\"\n onKeyDown={onPanelKeyDown}\n style={{\n position: 'fixed',\n top: pos.top,\n left: pos.left,\n visibility: pos.ready ? 'visible' : 'hidden',\n }}\n >\n {menu.items.map((item, i) =>\n item.separator ? (\n <li key={item.id} className=\"menubar__separator\" role=\"separator\" />\n ) : (\n <li key={item.id} role=\"none\">\n <button\n type=\"button\"\n role=\"menuitem\"\n ref={(el) => { itemRefs.current[i] = el; }}\n tabIndex={enabledIdx[active] === i ? 0 : -1}\n disabled={item.disabled}\n className={cx('menubar__item', item.disabled && 'is-disabled', enabledIdx[active] === i && 'is-active')}\n onMouseEnter={() => setActive(enabledIdx.indexOf(i))}\n onClick={() => selectItem(item)}\n >\n <span className=\"menubar__label\">{item.label}</span>\n {item.shortcut && <kbd className=\"menubar__shortcut\">{item.shortcut}</kbd>}\n </button>\n </li>\n )\n )}\n </ul>\n </Portal>\n )}\n </div>\n );\n })}\n </div>\n );\n}\n"]}
@@ -1,6 +1,6 @@
1
1
  'use client';
2
2
  import { formatIsoDateTime, smartDateTime, formatIsoDate, smartDate } from './chunk-XAGXAVWN.mjs';
3
- import { Tooltip } from './chunk-6GFZO3UZ.mjs';
3
+ import { Tooltip } from './chunk-FHOI6O37.mjs';
4
4
  import { useLocale } from './chunk-SXAGF7EG.mjs';
5
5
  import * as React from 'react';
6
6
  import { jsx } from 'react/jsx-runtime';
@@ -25,5 +25,5 @@ function TimeAgoDate({ iso, side = "top", now }) {
25
25
  }
26
26
 
27
27
  export { TimeAgo, TimeAgoDate };
28
- //# sourceMappingURL=chunk-KSIAOURE.mjs.map
29
- //# sourceMappingURL=chunk-KSIAOURE.mjs.map
28
+ //# sourceMappingURL=chunk-ZK6OK55L.mjs.map
29
+ //# sourceMappingURL=chunk-ZK6OK55L.mjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/components/TimeAgo.tsx"],"names":[],"mappings":";;;;;;AA+BO,SAAS,QAAQ,EAAE,GAAA,EAAK,IAAA,GAAO,KAAA,EAAO,KAAI,EAAiB;AAChE,EAAA,MAAM,SAAS,SAAA,EAAU;AACzB,EAAA,MAAM,QAAA,GAAW,iBAAA,CAAkB,GAAA,EAAK,MAAA,EAAQ,GAAG,CAAA;AACnD,EAAA,MAAM,CAAC,IAAA,EAAM,OAAO,CAAA,GAAU,eAAS,QAAQ,CAAA;AAC/C,EAAM,gBAAU,MAAM;AACpB,IAAA,OAAA,CAAQ,aAAA,CAAc,GAAA,EAAK,MAAA,EAAQ,GAAG,CAAC,CAAA;AAAA,EACzC,CAAA,EAAG,CAAC,GAAA,EAAK,MAAA,EAAQ,GAAG,CAAC,CAAA;AACrB,EAAA,uBACE,GAAA,CAAC,OAAA,EAAA,EAAQ,KAAA,EAAO,QAAA,EAAU,IAAA,EACxB,8BAAC,MAAA,EAAA,EAAK,QAAA,EAAU,GAAA,EAAM,QAAA,EAAA,IAAA,EAAK,CAAA,EAC7B,CAAA;AAEJ;AAOO,SAAS,YAAY,EAAE,GAAA,EAAK,IAAA,GAAO,KAAA,EAAO,KAAI,EAAiB;AACpE,EAAA,MAAM,SAAS,SAAA,EAAU;AACzB,EAAA,MAAM,QAAA,GAAW,aAAA,CAAc,GAAA,EAAK,MAAA,EAAQ,GAAG,CAAA;AAC/C,EAAA,MAAM,CAAC,IAAA,EAAM,OAAO,CAAA,GAAU,eAAS,QAAQ,CAAA;AAC/C,EAAM,gBAAU,MAAM;AACpB,IAAA,OAAA,CAAQ,SAAA,CAAU,GAAA,EAAK,MAAA,EAAQ,GAAG,CAAC,CAAA;AAAA,EACrC,CAAA,EAAG,CAAC,GAAA,EAAK,MAAA,EAAQ,GAAG,CAAC,CAAA;AACrB,EAAA,uBACE,GAAA,CAAC,OAAA,EAAA,EAAQ,KAAA,EAAO,QAAA,EAAU,IAAA,EACxB,8BAAC,MAAA,EAAA,EAAK,QAAA,EAAU,GAAA,EAAM,QAAA,EAAA,IAAA,EAAK,CAAA,EAC7B,CAAA;AAEJ","file":"chunk-KSIAOURE.mjs","sourcesContent":["'use client';\nimport * as React from 'react';\nimport { useLocale } from '../locale/LocaleProvider';\nimport { Tooltip } from './Layout';\nimport { formatIsoDate, formatIsoDateTime, smartDate, smartDateTime } from '../utils/smartTime';\n\nexport interface TimeAgoProps {\n /** ISO 8601 timestamp. */\n iso: string;\n /** Tooltip position. Defaults to `'top'`. */\n side?: 'top' | 'bottom' | 'left' | 'right';\n /**\n * Reference instant for relative formatting. Defaults to `new Date()`\n * at mount. Provide a stable value when you need predictable output\n * across renders (testing, fixed report timestamps).\n */\n now?: Date;\n}\n\n/**\n * Adaptive datetime label with absolute tooltip and semantic `<time>` markup.\n *\n * SSR-safe: the first render (server + first client paint) emits the\n * **absolute** label so server HTML matches the client's first paint\n * byte-for-byte. A `useEffect` then swaps to the smart relative label —\n * any divergence (clock skew, NTP drift, TZ between server and client)\n * is contained to a post-mount transition, never a hydration mismatch.\n *\n * The tooltip always shows the full absolute datetime, independent of\n * the relative label.\n */\nexport function TimeAgo({ iso, side = 'top', now }: TimeAgoProps) {\n const locale = useLocale();\n const absolute = formatIsoDateTime(iso, locale, now);\n const [text, setText] = React.useState(absolute);\n React.useEffect(() => {\n setText(smartDateTime(iso, locale, now));\n }, [iso, locale, now]);\n return (\n <Tooltip label={absolute} side={side}>\n <time dateTime={iso}>{text}</time>\n </Tooltip>\n );\n}\n\n/**\n * Same SSR-safe contract as {@link TimeAgo} but date-only (no time-of-day).\n * Use for date stamps where the hour is irrelevant: delivery dates,\n * day-precision history entries, etc.\n */\nexport function TimeAgoDate({ iso, side = 'top', now }: TimeAgoProps) {\n const locale = useLocale();\n const absolute = formatIsoDate(iso, locale, now);\n const [text, setText] = React.useState(absolute);\n React.useEffect(() => {\n setText(smartDate(iso, locale, now));\n }, [iso, locale, now]);\n return (\n <Tooltip label={absolute} side={side}>\n <time dateTime={iso}>{text}</time>\n </Tooltip>\n );\n}\n"]}
1
+ {"version":3,"sources":["../src/components/TimeAgo.tsx"],"names":[],"mappings":";;;;;;AA+BO,SAAS,QAAQ,EAAE,GAAA,EAAK,IAAA,GAAO,KAAA,EAAO,KAAI,EAAiB;AAChE,EAAA,MAAM,SAAS,SAAA,EAAU;AACzB,EAAA,MAAM,QAAA,GAAW,iBAAA,CAAkB,GAAA,EAAK,MAAA,EAAQ,GAAG,CAAA;AACnD,EAAA,MAAM,CAAC,IAAA,EAAM,OAAO,CAAA,GAAU,eAAS,QAAQ,CAAA;AAC/C,EAAM,gBAAU,MAAM;AACpB,IAAA,OAAA,CAAQ,aAAA,CAAc,GAAA,EAAK,MAAA,EAAQ,GAAG,CAAC,CAAA;AAAA,EACzC,CAAA,EAAG,CAAC,GAAA,EAAK,MAAA,EAAQ,GAAG,CAAC,CAAA;AACrB,EAAA,uBACE,GAAA,CAAC,OAAA,EAAA,EAAQ,KAAA,EAAO,QAAA,EAAU,IAAA,EACxB,8BAAC,MAAA,EAAA,EAAK,QAAA,EAAU,GAAA,EAAM,QAAA,EAAA,IAAA,EAAK,CAAA,EAC7B,CAAA;AAEJ;AAOO,SAAS,YAAY,EAAE,GAAA,EAAK,IAAA,GAAO,KAAA,EAAO,KAAI,EAAiB;AACpE,EAAA,MAAM,SAAS,SAAA,EAAU;AACzB,EAAA,MAAM,QAAA,GAAW,aAAA,CAAc,GAAA,EAAK,MAAA,EAAQ,GAAG,CAAA;AAC/C,EAAA,MAAM,CAAC,IAAA,EAAM,OAAO,CAAA,GAAU,eAAS,QAAQ,CAAA;AAC/C,EAAM,gBAAU,MAAM;AACpB,IAAA,OAAA,CAAQ,SAAA,CAAU,GAAA,EAAK,MAAA,EAAQ,GAAG,CAAC,CAAA;AAAA,EACrC,CAAA,EAAG,CAAC,GAAA,EAAK,MAAA,EAAQ,GAAG,CAAC,CAAA;AACrB,EAAA,uBACE,GAAA,CAAC,OAAA,EAAA,EAAQ,KAAA,EAAO,QAAA,EAAU,IAAA,EACxB,8BAAC,MAAA,EAAA,EAAK,QAAA,EAAU,GAAA,EAAM,QAAA,EAAA,IAAA,EAAK,CAAA,EAC7B,CAAA;AAEJ","file":"chunk-ZK6OK55L.mjs","sourcesContent":["'use client';\nimport * as React from 'react';\nimport { useLocale } from '../locale/LocaleProvider';\nimport { Tooltip } from './Layout';\nimport { formatIsoDate, formatIsoDateTime, smartDate, smartDateTime } from '../utils/smartTime';\n\nexport interface TimeAgoProps {\n /** ISO 8601 timestamp. */\n iso: string;\n /** Tooltip position. Defaults to `'top'`. */\n side?: 'top' | 'bottom' | 'left' | 'right';\n /**\n * Reference instant for relative formatting. Defaults to `new Date()`\n * at mount. Provide a stable value when you need predictable output\n * across renders (testing, fixed report timestamps).\n */\n now?: Date;\n}\n\n/**\n * Adaptive datetime label with absolute tooltip and semantic `<time>` markup.\n *\n * SSR-safe: the first render (server + first client paint) emits the\n * **absolute** label so server HTML matches the client's first paint\n * byte-for-byte. A `useEffect` then swaps to the smart relative label —\n * any divergence (clock skew, NTP drift, TZ between server and client)\n * is contained to a post-mount transition, never a hydration mismatch.\n *\n * The tooltip always shows the full absolute datetime, independent of\n * the relative label.\n */\nexport function TimeAgo({ iso, side = 'top', now }: TimeAgoProps) {\n const locale = useLocale();\n const absolute = formatIsoDateTime(iso, locale, now);\n const [text, setText] = React.useState(absolute);\n React.useEffect(() => {\n setText(smartDateTime(iso, locale, now));\n }, [iso, locale, now]);\n return (\n <Tooltip label={absolute} side={side}>\n <time dateTime={iso}>{text}</time>\n </Tooltip>\n );\n}\n\n/**\n * Same SSR-safe contract as {@link TimeAgo} but date-only (no time-of-day).\n * Use for date stamps where the hour is irrelevant: delivery dates,\n * day-precision history entries, etc.\n */\nexport function TimeAgoDate({ iso, side = 'top', now }: TimeAgoProps) {\n const locale = useLocale();\n const absolute = formatIsoDate(iso, locale, now);\n const [text, setText] = React.useState(absolute);\n React.useEffect(() => {\n setText(smartDate(iso, locale, now));\n }, [iso, locale, now]);\n return (\n <Tooltip label={absolute} side={side}>\n <time dateTime={iso}>{text}</time>\n </Tooltip>\n );\n}\n"]}
@@ -1,34 +1,34 @@
1
1
  'use client';
2
2
  'use strict';
3
3
 
4
- var chunkCEY7IC35_js = require('../chunk-CEY7IC35.js');
4
+ var chunkKWXF6OQW_js = require('../chunk-KWXF6OQW.js');
5
+ require('../chunk-W725MLGN.js');
5
6
  require('../chunk-MVJITG75.js');
6
7
  require('../chunk-WAGWB35Q.js');
7
- require('../chunk-W725MLGN.js');
8
- require('../chunk-UBSBSZPB.js');
9
- require('../chunk-C4AKMVDZ.js');
10
- require('../chunk-PASF6T4H.js');
11
8
  require('../chunk-3PXYCXDW.js');
9
+ require('../chunk-UBSBSZPB.js');
12
10
  require('../chunk-XMLBKK7X.js');
13
11
  require('../chunk-CRKYET66.js');
12
+ require('../chunk-C4AKMVDZ.js');
13
+ require('../chunk-PASF6T4H.js');
14
14
 
15
15
 
16
16
 
17
17
  Object.defineProperty(exports, "CommandPalette", {
18
18
  enumerable: true,
19
- get: function () { return chunkCEY7IC35_js.CommandPalette; }
19
+ get: function () { return chunkKWXF6OQW_js.CommandPalette; }
20
20
  });
21
21
  Object.defineProperty(exports, "DateRangePicker", {
22
22
  enumerable: true,
23
- get: function () { return chunkCEY7IC35_js.DateRangePicker; }
23
+ get: function () { return chunkKWXF6OQW_js.DateRangePicker; }
24
24
  });
25
25
  Object.defineProperty(exports, "MultiCombobox", {
26
26
  enumerable: true,
27
- get: function () { return chunkCEY7IC35_js.MultiCombobox; }
27
+ get: function () { return chunkKWXF6OQW_js.MultiCombobox; }
28
28
  });
29
29
  Object.defineProperty(exports, "useCommandPalette", {
30
30
  enumerable: true,
31
- get: function () { return chunkCEY7IC35_js.useCommandPalette; }
31
+ get: function () { return chunkKWXF6OQW_js.useCommandPalette; }
32
32
  });
33
33
  //# sourceMappingURL=AdvancedPickers.js.map
34
34
  //# sourceMappingURL=AdvancedPickers.js.map
@@ -1,13 +1,13 @@
1
1
  'use client';
2
- export { CommandPalette, DateRangePicker, MultiCombobox, useCommandPalette } from '../chunk-5TWNDG3J.mjs';
2
+ export { CommandPalette, DateRangePicker, MultiCombobox, useCommandPalette } from '../chunk-S5OEOR57.mjs';
3
+ import '../chunk-OWIPC5NO.mjs';
3
4
  import '../chunk-4QHE5H36.mjs';
4
5
  import '../chunk-FKBQYQQD.mjs';
5
- import '../chunk-OWIPC5NO.mjs';
6
- import '../chunk-SXAGF7EG.mjs';
7
- import '../chunk-BJGMROKL.mjs';
8
- import '../chunk-IEPCH3JB.mjs';
9
6
  import '../chunk-5GEWIK4T.mjs';
7
+ import '../chunk-SXAGF7EG.mjs';
10
8
  import '../chunk-6P2TKRTL.mjs';
11
9
  import '../chunk-5XT2LX3I.mjs';
10
+ import '../chunk-BJGMROKL.mjs';
11
+ import '../chunk-IEPCH3JB.mjs';
12
12
  //# sourceMappingURL=AdvancedPickers.mjs.map
13
13
  //# sourceMappingURL=AdvancedPickers.mjs.map
@@ -1,27 +1,27 @@
1
1
  'use client';
2
2
  'use strict';
3
3
 
4
- var chunkK5B6WQFI_js = require('../chunk-K5B6WQFI.js');
5
- require('../chunk-UBSBSZPB.js');
6
- require('../chunk-C4AKMVDZ.js');
7
- require('../chunk-PASF6T4H.js');
4
+ var chunkC7UG47HQ_js = require('../chunk-C7UG47HQ.js');
8
5
  require('../chunk-2KZ4NI3X.js');
9
- require('../chunk-D2H4VZVL.js');
10
6
  require('../chunk-FL4ZCWUF.js');
11
- require('../chunk-XMLBKK7X.js');
12
7
  require('../chunk-NPXEZCTA.js');
13
8
  require('../chunk-55P5FA5Q.js');
9
+ require('../chunk-D2H4VZVL.js');
10
+ require('../chunk-UBSBSZPB.js');
11
+ require('../chunk-XMLBKK7X.js');
14
12
  require('../chunk-CRKYET66.js');
13
+ require('../chunk-C4AKMVDZ.js');
14
+ require('../chunk-PASF6T4H.js');
15
15
 
16
16
 
17
17
 
18
18
  Object.defineProperty(exports, "AppShell", {
19
19
  enumerable: true,
20
- get: function () { return chunkK5B6WQFI_js.AppShell; }
20
+ get: function () { return chunkC7UG47HQ_js.AppShell; }
21
21
  });
22
22
  Object.defineProperty(exports, "PageHeader", {
23
23
  enumerable: true,
24
- get: function () { return chunkK5B6WQFI_js.PageHeader; }
24
+ get: function () { return chunkC7UG47HQ_js.PageHeader; }
25
25
  });
26
26
  //# sourceMappingURL=AppShell.js.map
27
27
  //# sourceMappingURL=AppShell.js.map
@@ -1,14 +1,14 @@
1
1
  'use client';
2
- export { AppShell, PageHeader } from '../chunk-JZ3JAEK4.mjs';
3
- import '../chunk-SXAGF7EG.mjs';
4
- import '../chunk-BJGMROKL.mjs';
5
- import '../chunk-IEPCH3JB.mjs';
2
+ export { AppShell, PageHeader } from '../chunk-63LUAWJS.mjs';
6
3
  import '../chunk-QQE3XOEM.mjs';
7
- import '../chunk-R5DCDEB5.mjs';
8
4
  import '../chunk-U3JH4T3A.mjs';
9
- import '../chunk-6P2TKRTL.mjs';
10
5
  import '../chunk-6W7ZGWNA.mjs';
11
6
  import '../chunk-XOV4D6J3.mjs';
7
+ import '../chunk-R5DCDEB5.mjs';
8
+ import '../chunk-SXAGF7EG.mjs';
9
+ import '../chunk-6P2TKRTL.mjs';
12
10
  import '../chunk-5XT2LX3I.mjs';
11
+ import '../chunk-BJGMROKL.mjs';
12
+ import '../chunk-IEPCH3JB.mjs';
13
13
  //# sourceMappingURL=AppShell.mjs.map
14
14
  //# sourceMappingURL=AppShell.mjs.map
@@ -1,29 +1,29 @@
1
1
  'use client';
2
2
  'use strict';
3
3
 
4
- var chunkBB4WO2VU_js = require('../chunk-BB4WO2VU.js');
5
- require('../chunk-TW54NMEG.js');
6
- require('../chunk-WAGWB35Q.js');
4
+ var chunkD44PGK5V_js = require('../chunk-D44PGK5V.js');
5
+ require('../chunk-AGMDYCGG.js');
7
6
  require('../chunk-W725MLGN.js');
7
+ require('../chunk-WAGWB35Q.js');
8
8
  require('../chunk-UBSBSZPB.js');
9
- require('../chunk-C4AKMVDZ.js');
10
- require('../chunk-PASF6T4H.js');
11
9
  require('../chunk-XMLBKK7X.js');
12
10
  require('../chunk-CRKYET66.js');
11
+ require('../chunk-C4AKMVDZ.js');
12
+ require('../chunk-PASF6T4H.js');
13
13
 
14
14
 
15
15
 
16
16
  Object.defineProperty(exports, "AttachmentList", {
17
17
  enumerable: true,
18
- get: function () { return chunkBB4WO2VU_js.AttachmentList; }
18
+ get: function () { return chunkD44PGK5V_js.AttachmentList; }
19
19
  });
20
20
  Object.defineProperty(exports, "CommentThread", {
21
21
  enumerable: true,
22
- get: function () { return chunkBB4WO2VU_js.CommentThread; }
22
+ get: function () { return chunkD44PGK5V_js.CommentThread; }
23
23
  });
24
24
  Object.defineProperty(exports, "_internal", {
25
25
  enumerable: true,
26
- get: function () { return chunkBB4WO2VU_js._internal; }
26
+ get: function () { return chunkD44PGK5V_js._internal; }
27
27
  });
28
28
  //# sourceMappingURL=Comments.js.map
29
29
  //# sourceMappingURL=Comments.js.map
@@ -1,12 +1,12 @@
1
1
  'use client';
2
- export { AttachmentList, CommentThread, _internal } from '../chunk-3TFYIWFE.mjs';
3
- import '../chunk-Z5PAD5A6.mjs';
4
- import '../chunk-FKBQYQQD.mjs';
2
+ export { AttachmentList, CommentThread, _internal } from '../chunk-G5I2VVOC.mjs';
3
+ import '../chunk-DH3IXJRJ.mjs';
5
4
  import '../chunk-OWIPC5NO.mjs';
5
+ import '../chunk-FKBQYQQD.mjs';
6
6
  import '../chunk-SXAGF7EG.mjs';
7
- import '../chunk-BJGMROKL.mjs';
8
- import '../chunk-IEPCH3JB.mjs';
9
7
  import '../chunk-6P2TKRTL.mjs';
10
8
  import '../chunk-5XT2LX3I.mjs';
9
+ import '../chunk-BJGMROKL.mjs';
10
+ import '../chunk-IEPCH3JB.mjs';
11
11
  //# sourceMappingURL=Comments.mjs.map
12
12
  //# sourceMappingURL=Comments.mjs.map
@@ -1,66 +1,66 @@
1
1
  'use client';
2
2
  'use strict';
3
3
 
4
- var chunkOQXOF34S_js = require('../chunk-OQXOF34S.js');
5
- require('../chunk-NZKXHTM4.js');
4
+ var chunkJJ54RD36_js = require('../chunk-JJ54RD36.js');
5
+ require('../chunk-F3PTSBHH.js');
6
6
  require('../chunk-W725MLGN.js');
7
- require('../chunk-UBSBSZPB.js');
8
- require('../chunk-C4AKMVDZ.js');
9
- require('../chunk-PASF6T4H.js');
10
7
  require('../chunk-3PXYCXDW.js');
11
8
  require('../chunk-2KZ4NI3X.js');
12
- require('../chunk-D2H4VZVL.js');
13
9
  require('../chunk-FL4ZCWUF.js');
14
- require('../chunk-XMLBKK7X.js');
15
10
  require('../chunk-NPXEZCTA.js');
16
11
  require('../chunk-55P5FA5Q.js');
12
+ require('../chunk-D2H4VZVL.js');
13
+ require('../chunk-UBSBSZPB.js');
14
+ require('../chunk-XMLBKK7X.js');
17
15
  require('../chunk-CRKYET66.js');
16
+ require('../chunk-C4AKMVDZ.js');
17
+ require('../chunk-PASF6T4H.js');
18
18
 
19
19
 
20
20
 
21
21
  Object.defineProperty(exports, "AddressForm", {
22
22
  enumerable: true,
23
- get: function () { return chunkOQXOF34S_js.AddressForm; }
23
+ get: function () { return chunkJJ54RD36_js.AddressForm; }
24
24
  });
25
25
  Object.defineProperty(exports, "CartDrawer", {
26
26
  enumerable: true,
27
- get: function () { return chunkOQXOF34S_js.CartDrawer; }
27
+ get: function () { return chunkJJ54RD36_js.CartDrawer; }
28
28
  });
29
29
  Object.defineProperty(exports, "CompareTable", {
30
30
  enumerable: true,
31
- get: function () { return chunkOQXOF34S_js.CompareTable; }
31
+ get: function () { return chunkJJ54RD36_js.CompareTable; }
32
32
  });
33
33
  Object.defineProperty(exports, "FreeShippingProgress", {
34
34
  enumerable: true,
35
- get: function () { return chunkOQXOF34S_js.FreeShippingProgress; }
35
+ get: function () { return chunkJJ54RD36_js.FreeShippingProgress; }
36
36
  });
37
37
  Object.defineProperty(exports, "OrderSummary", {
38
38
  enumerable: true,
39
- get: function () { return chunkOQXOF34S_js.OrderSummary; }
39
+ get: function () { return chunkJJ54RD36_js.OrderSummary; }
40
40
  });
41
41
  Object.defineProperty(exports, "PriceDisplay", {
42
42
  enumerable: true,
43
- get: function () { return chunkOQXOF34S_js.PriceDisplay; }
43
+ get: function () { return chunkJJ54RD36_js.PriceDisplay; }
44
44
  });
45
45
  Object.defineProperty(exports, "PromoCodeInput", {
46
46
  enumerable: true,
47
- get: function () { return chunkOQXOF34S_js.PromoCodeInput; }
47
+ get: function () { return chunkJJ54RD36_js.PromoCodeInput; }
48
48
  });
49
49
  Object.defineProperty(exports, "QuantitySelector", {
50
50
  enumerable: true,
51
- get: function () { return chunkOQXOF34S_js.QuantitySelector; }
51
+ get: function () { return chunkJJ54RD36_js.QuantitySelector; }
52
52
  });
53
53
  Object.defineProperty(exports, "Rating", {
54
54
  enumerable: true,
55
- get: function () { return chunkOQXOF34S_js.Rating; }
55
+ get: function () { return chunkJJ54RD36_js.Rating; }
56
56
  });
57
57
  Object.defineProperty(exports, "VariantSelector", {
58
58
  enumerable: true,
59
- get: function () { return chunkOQXOF34S_js.VariantSelector; }
59
+ get: function () { return chunkJJ54RD36_js.VariantSelector; }
60
60
  });
61
61
  Object.defineProperty(exports, "WishlistButton", {
62
62
  enumerable: true,
63
- get: function () { return chunkOQXOF34S_js.WishlistButton; }
63
+ get: function () { return chunkJJ54RD36_js.WishlistButton; }
64
64
  });
65
65
  //# sourceMappingURL=Commerce.js.map
66
66
  //# sourceMappingURL=Commerce.js.map
@@ -1,17 +1,17 @@
1
1
  'use client';
2
- export { AddressForm, CartDrawer, CompareTable, FreeShippingProgress, OrderSummary, PriceDisplay, PromoCodeInput, QuantitySelector, Rating, VariantSelector, WishlistButton } from '../chunk-4GF3YGPG.mjs';
3
- import '../chunk-Y3IPKGOU.mjs';
2
+ export { AddressForm, CartDrawer, CompareTable, FreeShippingProgress, OrderSummary, PriceDisplay, PromoCodeInput, QuantitySelector, Rating, VariantSelector, WishlistButton } from '../chunk-FD3Y5IP7.mjs';
3
+ import '../chunk-VOSVV3LL.mjs';
4
4
  import '../chunk-OWIPC5NO.mjs';
5
- import '../chunk-SXAGF7EG.mjs';
6
- import '../chunk-BJGMROKL.mjs';
7
- import '../chunk-IEPCH3JB.mjs';
8
5
  import '../chunk-5GEWIK4T.mjs';
9
6
  import '../chunk-QQE3XOEM.mjs';
10
- import '../chunk-R5DCDEB5.mjs';
11
7
  import '../chunk-U3JH4T3A.mjs';
12
- import '../chunk-6P2TKRTL.mjs';
13
8
  import '../chunk-6W7ZGWNA.mjs';
14
9
  import '../chunk-XOV4D6J3.mjs';
10
+ import '../chunk-R5DCDEB5.mjs';
11
+ import '../chunk-SXAGF7EG.mjs';
12
+ import '../chunk-6P2TKRTL.mjs';
15
13
  import '../chunk-5XT2LX3I.mjs';
14
+ import '../chunk-BJGMROKL.mjs';
15
+ import '../chunk-IEPCH3JB.mjs';
16
16
  //# sourceMappingURL=Commerce.mjs.map
17
17
  //# sourceMappingURL=Commerce.mjs.map
@@ -1,17 +1,17 @@
1
1
  'use client';
2
2
  'use strict';
3
3
 
4
- var chunk42EYBIRW_js = require('../chunk-42EYBIRW.js');
4
+ var chunk2PNXLTEM_js = require('../chunk-2PNXLTEM.js');
5
5
  require('../chunk-WAGWB35Q.js');
6
- require('../chunk-PASF6T4H.js');
7
6
  require('../chunk-XMLBKK7X.js');
8
7
  require('../chunk-CRKYET66.js');
8
+ require('../chunk-PASF6T4H.js');
9
9
 
10
10
 
11
11
 
12
12
  Object.defineProperty(exports, "ContextMenu", {
13
13
  enumerable: true,
14
- get: function () { return chunk42EYBIRW_js.ContextMenu; }
14
+ get: function () { return chunk2PNXLTEM_js.ContextMenu; }
15
15
  });
16
16
  //# sourceMappingURL=ContextMenu.js.map
17
17
  //# sourceMappingURL=ContextMenu.js.map
@@ -1,8 +1,8 @@
1
1
  'use client';
2
- export { ContextMenu } from '../chunk-PUEGDRTJ.mjs';
2
+ export { ContextMenu } from '../chunk-NS6CI6RP.mjs';
3
3
  import '../chunk-FKBQYQQD.mjs';
4
- import '../chunk-IEPCH3JB.mjs';
5
4
  import '../chunk-6P2TKRTL.mjs';
6
5
  import '../chunk-5XT2LX3I.mjs';
6
+ import '../chunk-IEPCH3JB.mjs';
7
7
  //# sourceMappingURL=ContextMenu.mjs.map
8
8
  //# sourceMappingURL=ContextMenu.mjs.map
@@ -118,6 +118,15 @@ interface DataTableProps<T> {
118
118
  * legacy sibling pattern (`<TableToolbar/><DataTable/>`) still works.
119
119
  */
120
120
  toolbar?: React.ReactNode;
121
+ /**
122
+ * Surface chrome mode. Default `'card'`: the table draws its own
123
+ * border + radius (and `--table-elevation` if set), the standalone
124
+ * surface. `'flush'`: drops that chrome so the table sits clean inside
125
+ * a parent that already owns the surface (a `<Card>`) without doubling
126
+ * the border or nesting a radius. Use `'flush'` for the embedded-in-Card
127
+ * case; leave the default for standalone tables.
128
+ */
129
+ surface?: 'card' | 'flush';
121
130
  className?: string;
122
131
  }
123
132
  /**
@@ -131,7 +140,7 @@ interface DataTableProps<T> {
131
140
  * - No virtualization; tested up to ~200 rows. For large datasets, plug
132
141
  * in react-window/tanstack-virtual around the body rows.
133
142
  */
134
- declare function DataTable<T>({ columns, rows, rowKey, sort, onSortChange, selectable, selectedKeys, onSelectionChange, empty, error, loading, stickyHeader, mobileLayout, ariaLabel, rowLabel, className, density, rowHref, onRowClick, renderRow, toolbar, }: DataTableProps<T>): react_jsx_runtime.JSX.Element;
143
+ declare function DataTable<T>({ columns, rows, rowKey, sort, onSortChange, selectable, selectedKeys, onSelectionChange, empty, error, loading, stickyHeader, mobileLayout, ariaLabel, rowLabel, className, density, rowHref, onRowClick, renderRow, toolbar, surface, }: DataTableProps<T>): react_jsx_runtime.JSX.Element;
135
144
  interface AccordionProps {
136
145
  multiple?: boolean;
137
146
  defaultOpen?: string[];
@@ -118,6 +118,15 @@ interface DataTableProps<T> {
118
118
  * legacy sibling pattern (`<TableToolbar/><DataTable/>`) still works.
119
119
  */
120
120
  toolbar?: React.ReactNode;
121
+ /**
122
+ * Surface chrome mode. Default `'card'`: the table draws its own
123
+ * border + radius (and `--table-elevation` if set), the standalone
124
+ * surface. `'flush'`: drops that chrome so the table sits clean inside
125
+ * a parent that already owns the surface (a `<Card>`) without doubling
126
+ * the border or nesting a radius. Use `'flush'` for the embedded-in-Card
127
+ * case; leave the default for standalone tables.
128
+ */
129
+ surface?: 'card' | 'flush';
121
130
  className?: string;
122
131
  }
123
132
  /**
@@ -131,7 +140,7 @@ interface DataTableProps<T> {
131
140
  * - No virtualization; tested up to ~200 rows. For large datasets, plug
132
141
  * in react-window/tanstack-virtual around the body rows.
133
142
  */
134
- declare function DataTable<T>({ columns, rows, rowKey, sort, onSortChange, selectable, selectedKeys, onSelectionChange, empty, error, loading, stickyHeader, mobileLayout, ariaLabel, rowLabel, className, density, rowHref, onRowClick, renderRow, toolbar, }: DataTableProps<T>): react_jsx_runtime.JSX.Element;
143
+ declare function DataTable<T>({ columns, rows, rowKey, sort, onSortChange, selectable, selectedKeys, onSelectionChange, empty, error, loading, stickyHeader, mobileLayout, ariaLabel, rowLabel, className, density, rowHref, onRowClick, renderRow, toolbar, surface, }: DataTableProps<T>): react_jsx_runtime.JSX.Element;
135
144
  interface AccordionProps {
136
145
  multiple?: boolean;
137
146
  defaultOpen?: string[];
@@ -1,7 +1,7 @@
1
1
  'use client';
2
2
  'use strict';
3
3
 
4
- var chunk74XHJITO_js = require('../chunk-74XHJITO.js');
4
+ var chunkNMUTNNAC_js = require('../chunk-NMUTNNAC.js');
5
5
  require('../chunk-6SSTTJV4.js');
6
6
  require('../chunk-A423552C.js');
7
7
  require('../chunk-W725MLGN.js');
@@ -13,27 +13,27 @@ require('../chunk-PASF6T4H.js');
13
13
 
14
14
  Object.defineProperty(exports, "Accordion", {
15
15
  enumerable: true,
16
- get: function () { return chunk74XHJITO_js.Accordion; }
16
+ get: function () { return chunkNMUTNNAC_js.Accordion; }
17
17
  });
18
18
  Object.defineProperty(exports, "AccordionItem", {
19
19
  enumerable: true,
20
- get: function () { return chunk74XHJITO_js.AccordionItem; }
20
+ get: function () { return chunkNMUTNNAC_js.AccordionItem; }
21
21
  });
22
22
  Object.defineProperty(exports, "Breadcrumbs", {
23
23
  enumerable: true,
24
- get: function () { return chunk74XHJITO_js.Breadcrumbs; }
24
+ get: function () { return chunkNMUTNNAC_js.Breadcrumbs; }
25
25
  });
26
26
  Object.defineProperty(exports, "DataTable", {
27
27
  enumerable: true,
28
- get: function () { return chunk74XHJITO_js.DataTable; }
28
+ get: function () { return chunkNMUTNNAC_js.DataTable; }
29
29
  });
30
30
  Object.defineProperty(exports, "TablePagination", {
31
31
  enumerable: true,
32
- get: function () { return chunk74XHJITO_js.TablePagination; }
32
+ get: function () { return chunkNMUTNNAC_js.TablePagination; }
33
33
  });
34
34
  Object.defineProperty(exports, "TableToolbar", {
35
35
  enumerable: true,
36
- get: function () { return chunk74XHJITO_js.TableToolbar; }
36
+ get: function () { return chunkNMUTNNAC_js.TableToolbar; }
37
37
  });
38
38
  //# sourceMappingURL=DataTable.js.map
39
39
  //# sourceMappingURL=DataTable.js.map
@@ -1,5 +1,5 @@
1
1
  'use client';
2
- export { Accordion, AccordionItem, Breadcrumbs, DataTable, TablePagination, TableToolbar } from '../chunk-56AR3HZK.mjs';
2
+ export { Accordion, AccordionItem, Breadcrumbs, DataTable, TablePagination, TableToolbar } from '../chunk-6KIM3DOH.mjs';
3
3
  import '../chunk-SUQLII3F.mjs';
4
4
  import '../chunk-CNQ7HZQT.mjs';
5
5
  import '../chunk-OWIPC5NO.mjs';
@@ -1,30 +1,30 @@
1
1
  'use client';
2
2
  'use strict';
3
3
 
4
- var chunkTW54NMEG_js = require('../chunk-TW54NMEG.js');
4
+ var chunkAGMDYCGG_js = require('../chunk-AGMDYCGG.js');
5
5
  require('../chunk-WAGWB35Q.js');
6
- require('../chunk-C4AKMVDZ.js');
7
- require('../chunk-PASF6T4H.js');
8
6
  require('../chunk-XMLBKK7X.js');
9
7
  require('../chunk-CRKYET66.js');
8
+ require('../chunk-C4AKMVDZ.js');
9
+ require('../chunk-PASF6T4H.js');
10
10
 
11
11
 
12
12
 
13
13
  Object.defineProperty(exports, "Avatar", {
14
14
  enumerable: true,
15
- get: function () { return chunkTW54NMEG_js.Avatar; }
15
+ get: function () { return chunkAGMDYCGG_js.Avatar; }
16
16
  });
17
17
  Object.defineProperty(exports, "AvatarGroup", {
18
18
  enumerable: true,
19
- get: function () { return chunkTW54NMEG_js.AvatarGroup; }
19
+ get: function () { return chunkAGMDYCGG_js.AvatarGroup; }
20
20
  });
21
21
  Object.defineProperty(exports, "Menu", {
22
22
  enumerable: true,
23
- get: function () { return chunkTW54NMEG_js.Menu; }
23
+ get: function () { return chunkAGMDYCGG_js.Menu; }
24
24
  });
25
25
  Object.defineProperty(exports, "Stat", {
26
26
  enumerable: true,
27
- get: function () { return chunkTW54NMEG_js.Stat; }
27
+ get: function () { return chunkAGMDYCGG_js.Stat; }
28
28
  });
29
29
  //# sourceMappingURL=Display2.js.map
30
30
  //# sourceMappingURL=Display2.js.map
@@ -1,9 +1,9 @@
1
1
  'use client';
2
- export { Avatar, AvatarGroup, Menu, Stat } from '../chunk-Z5PAD5A6.mjs';
2
+ export { Avatar, AvatarGroup, Menu, Stat } from '../chunk-DH3IXJRJ.mjs';
3
3
  import '../chunk-FKBQYQQD.mjs';
4
- import '../chunk-BJGMROKL.mjs';
5
- import '../chunk-IEPCH3JB.mjs';
6
4
  import '../chunk-6P2TKRTL.mjs';
7
5
  import '../chunk-5XT2LX3I.mjs';
6
+ import '../chunk-BJGMROKL.mjs';
7
+ import '../chunk-IEPCH3JB.mjs';
8
8
  //# sourceMappingURL=Display2.mjs.map
9
9
  //# sourceMappingURL=Display2.mjs.map