@boilerhaus-ui/boilerhaus-ui 0.1.0

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 (75) hide show
  1. package/README.md +73 -0
  2. package/dist/components/Accordion/Accordion.d.ts +22 -0
  3. package/dist/components/Accordion/index.d.ts +2 -0
  4. package/dist/components/Alert/Alert.d.ts +34 -0
  5. package/dist/components/Alert/index.d.ts +2 -0
  6. package/dist/components/AspectRatio/AspectRatio.d.ts +23 -0
  7. package/dist/components/AspectRatio/index.d.ts +2 -0
  8. package/dist/components/Avatar/Avatar.d.ts +40 -0
  9. package/dist/components/Avatar/index.d.ts +2 -0
  10. package/dist/components/Badge/Badge.d.ts +14 -0
  11. package/dist/components/Badge/index.d.ts +2 -0
  12. package/dist/components/Breadcrumb/Breadcrumb.d.ts +52 -0
  13. package/dist/components/Breadcrumb/index.d.ts +2 -0
  14. package/dist/components/Button/Button.d.ts +19 -0
  15. package/dist/components/Button/index.d.ts +2 -0
  16. package/dist/components/Card/Card.d.ts +39 -0
  17. package/dist/components/Card/index.d.ts +2 -0
  18. package/dist/components/Checkbox/Checkbox.d.ts +22 -0
  19. package/dist/components/Checkbox/index.d.ts +2 -0
  20. package/dist/components/Combobox/Combobox.d.ts +27 -0
  21. package/dist/components/Combobox/index.d.ts +2 -0
  22. package/dist/components/DataTable/DataTable.d.ts +34 -0
  23. package/dist/components/DataTable/index.d.ts +2 -0
  24. package/dist/components/DatePicker/DatePicker.d.ts +17 -0
  25. package/dist/components/DatePicker/index.d.ts +2 -0
  26. package/dist/components/Dialog/Dialog.d.ts +53 -0
  27. package/dist/components/Dialog/index.d.ts +2 -0
  28. package/dist/components/DropdownMenu/DropdownMenu.d.ts +51 -0
  29. package/dist/components/DropdownMenu/index.d.ts +2 -0
  30. package/dist/components/FileUpload/FileUpload.d.ts +26 -0
  31. package/dist/components/FileUpload/index.d.ts +2 -0
  32. package/dist/components/Input/Input.d.ts +23 -0
  33. package/dist/components/Input/index.d.ts +2 -0
  34. package/dist/components/Label/Label.d.ts +20 -0
  35. package/dist/components/Label/index.d.ts +2 -0
  36. package/dist/components/PageShell/PageShell.d.ts +73 -0
  37. package/dist/components/PageShell/index.d.ts +2 -0
  38. package/dist/components/Popover/Popover.d.ts +24 -0
  39. package/dist/components/Popover/index.d.ts +2 -0
  40. package/dist/components/Progress/Progress.d.ts +26 -0
  41. package/dist/components/Progress/index.d.ts +2 -0
  42. package/dist/components/RadioGroup/RadioGroup.d.ts +29 -0
  43. package/dist/components/RadioGroup/index.d.ts +2 -0
  44. package/dist/components/Select/Select.d.ts +32 -0
  45. package/dist/components/Select/index.d.ts +2 -0
  46. package/dist/components/Skeleton/Skeleton.d.ts +12 -0
  47. package/dist/components/Skeleton/index.d.ts +2 -0
  48. package/dist/components/Spinner/Spinner.d.ts +18 -0
  49. package/dist/components/Spinner/index.d.ts +2 -0
  50. package/dist/components/Stat/Stat.d.ts +22 -0
  51. package/dist/components/Stat/index.d.ts +2 -0
  52. package/dist/components/Stepper/Stepper.d.ts +24 -0
  53. package/dist/components/Stepper/index.d.ts +2 -0
  54. package/dist/components/Switch/Switch.d.ts +17 -0
  55. package/dist/components/Switch/index.d.ts +2 -0
  56. package/dist/components/Table/Table.d.ts +73 -0
  57. package/dist/components/Table/index.d.ts +2 -0
  58. package/dist/components/Tabs/Tabs.d.ts +28 -0
  59. package/dist/components/Tabs/index.d.ts +2 -0
  60. package/dist/components/Textarea/Textarea.d.ts +23 -0
  61. package/dist/components/Textarea/index.d.ts +2 -0
  62. package/dist/components/Toast/Toast.d.ts +17 -0
  63. package/dist/components/Toast/index.d.ts +4 -0
  64. package/dist/components/Toast/use-toast.d.ts +26 -0
  65. package/dist/components/Tooltip/Tooltip.d.ts +24 -0
  66. package/dist/components/Tooltip/index.d.ts +2 -0
  67. package/dist/components/index.d.ts +64 -0
  68. package/dist/index.cjs +51 -0
  69. package/dist/index.cjs.map +1 -0
  70. package/dist/index.d.ts +81 -0
  71. package/dist/index.js +10475 -0
  72. package/dist/index.js.map +1 -0
  73. package/dist/lib/cn.d.ts +7 -0
  74. package/dist/tokens.css +163 -0
  75. package/package.json +91 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","names":["React","React","createSlot","isSlottable","Slot","createSlotClone","getElementRef","mergeProps","SLOTTABLE_IDENTIFIER","isNumber","clamp","React","createContextScope","composeContextScopes","createSlot","React","isSlottable","createSlotClone","getElementRef","mergeProps","SLOTTABLE_IDENTIFIER","createContextScope","React","createSlot","React","createSlot","React","isSlottable","createSlotClone","getElementRef","mergeProps","SLOTTABLE_IDENTIFIER","Primitive","createSlot","React","useCallbackRef","React","useCallbackRef","React","Primitive","useCallbackRef","handleAndDispatchCustomEvent","Root","count","EVENT_OPTIONS","React","useCallbackRef","getTabbableCandidates","Primitive","focusFirst","React","React","useId","computePosition","arrow","flip","hide","offset","shift","limitShift","size","isHTMLElement","getComputedStyle","isHTMLElement","offset","offset$1","shift","shift$1","flip","flip$1","size","size$1","hide","hide$1","arrow","arrow$1","limitShift","limitShift$1","useLayoutEffect","React","NAME","Arrow","React","Primitive","Root","React","createContextScope","React","ANCHOR_NAME","Primitive","CONTENT_NAME","arrow","floatingUIarrow","useCallbackRef","ARROW_NAME","ArrowPrimitive.Root","Root2","Content","PORTAL_NAME","Portal","React","ReactDOM","Primitive","createSlot","React","isSlottable","createSlotClone","getElementRef","mergeProps","SLOTTABLE_IDENTIFIER","React","useLayoutEffect","isFunction","React","NAME","React","Primitive","Root","React","React","React","React","React","React","SideCar","SELECTION_KEYS","Collection","useCollection","createCollectionScope","createContextScope","usePopperScope","Select","React","PopperPrimitive.Root","useId","TRIGGER_NAME","PopperPrimitive.Anchor","Primitive","Fragment","PORTAL_NAME","PortalPrimitive","CONTENT_NAME","ReactDOM","Slot","createSlot","RemoveScroll","clamp","PopperPrimitive.Content","VIEWPORT_NAME","GROUP_NAME","LABEL_NAME","ITEM_NAME","SelectItem","ITEM_INDICATOR_NAME","SEPARATOR_NAME","ARROW_NAME","PopperPrimitive.Arrow","BUBBLE_INPUT_NAME","useCallbackRef","wrapArray","Root2","Trigger","Portal","Content2","Viewport","Item","ItemIndicator","React","React2","getElementRef","createSlot","React","isSlottable","createSlotClone","getElementRef","mergeProps","SLOTTABLE_IDENTIFIER","createContextScope","Dialog","React","useId","TRIGGER_NAME","DialogTrigger","Primitive","getState","PORTAL_NAME","PortalProvider","usePortalContext","PortalPrimitive","Slot","createSlot","RemoveScroll","CONTENT_NAME","DialogContent","Fragment","TITLE_NAME","DialogTitle","DESCRIPTION_NAME","DialogDescription","CLOSE_NAME","DialogClose","createContext","Root","Trigger","Portal","Content","Title","Description","Close","createContextScope","React","isIndeterminate","TRIGGER_NAME","Primitive","getState","Checkbox","Fragment","INDICATOR_NAME","BUBBLE_INPUT_NAME","createContextScope","Switch","React","Primitive","getState","BUBBLE_INPUT_NAME","Root","PROVIDER_NAME","Collection","useCollection","createCollectionScope","createContextScope","React","focusFirst","DismissableLayer.Branch","Primitive","useCallbackRef","Fragment","ReactDOM","DismissableLayer.Root","Portal","CLOSE_NAME","Provider","Root2","Close","GROUP_NAME","Collection","useCollection","createCollectionScope","createContextScope","React","useCallbackRef","Primitive","ITEM_NAME","useId","wrapArray","focusFirst","Root","Item","createContextScope","useRovingFocusGroupScope","Tabs","React","useId","Primitive","TabsList","RovingFocusGroup.Root","TRIGGER_NAME","TabsTrigger","RovingFocusGroup.Item","CONTENT_NAME","TabsContent","Root2","Trigger","Content","createSlot","React","isSlottable","createSlotClone","getElementRef","mergeProps","SLOTTABLE_IDENTIFIER","Collection","useCollection","createCollectionScope","createContextScope","usePopperScope","useRovingFocusGroupScope","React","useCallbackRef","PopperPrimitive.Root","ANCHOR_NAME","PopperPrimitive.Anchor","PORTAL_NAME","PortalProvider","usePortalContext","PortalPrimitive","CONTENT_NAME","Slot","createSlot","RemoveScroll","RovingFocusGroup.Root","PopperPrimitive.Content","GROUP_NAME","Primitive","LABEL_NAME","ITEM_NAME","RovingFocusGroup.Item","CHECKBOX_ITEM_NAME","RADIO_GROUP_NAME","RadioGroupProvider","useRadioGroupContext","RADIO_ITEM_NAME","SEPARATOR_NAME","ARROW_NAME","PopperPrimitive.Arrow","useId","SUB_TRIGGER_NAME","SUB_CONTENT_NAME","isPointInPolygon","Root3","Anchor2","Portal","Content2","Label","Item2","RadioGroup","createContextScope","DropdownMenu","React","useId","MenuPrimitive.Root","TRIGGER_NAME","DropdownMenuTrigger","MenuPrimitive.Anchor","Primitive","PORTAL_NAME","MenuPrimitive.Portal","CONTENT_NAME","DropdownMenuContent","MenuPrimitive.Content","DropdownMenuGroup","MenuPrimitive.Group","DropdownMenuLabel","MenuPrimitive.Label","ITEM_NAME","DropdownMenuItem","MenuPrimitive.Item","DropdownMenuCheckboxItem","MenuPrimitive.CheckboxItem","RADIO_GROUP_NAME","DropdownMenuRadioGroup","MenuPrimitive.RadioGroup","DropdownMenuRadioItem","MenuPrimitive.RadioItem","INDICATOR_NAME","MenuPrimitive.ItemIndicator","DropdownMenuSeparator","MenuPrimitive.Separator","ARROW_NAME","MenuPrimitive.Arrow","DropdownMenuSub","MenuPrimitive.Sub","DropdownMenuSubTrigger","MenuPrimitive.SubTrigger","DropdownMenuSubContent","MenuPrimitive.SubContent","Root2","Trigger","Content2","Item2","SLOTTABLE_IDENTIFIER","Fragment2","createContextScope","usePopperScope","TooltipProvider","React","Tooltip","useId","PopperPrimitive.Root","TRIGGER_NAME","TooltipTrigger","PopperPrimitive.Anchor","Primitive","PORTAL_NAME","PortalProvider","usePortalContext","PortalPrimitive","CONTENT_NAME","TooltipContent","PopperPrimitive.Content","VisuallyHiddenPrimitive.Root","ARROW_NAME","PopperPrimitive.Arrow","Trigger","Portal","Content2","createContextScope","React","composeContextScopes","Primitive","createSlot","React","createContextScope","Progress","React","Primitive","INDICATOR_NAME","Root","Indicator","React","Primitive","createSlot","React","React","Avatar","React","Primitive","useCallbackRef","Root","createContextScope","Radio","React","Primitive","getState","createContextScope2","RadioGroup","React2","RovingFocusGroup.Root","Primitive2","ITEM_NAME","useComposedRefs2","RovingFocusGroup.Item","composeEventHandlers2","Root2","React","createContextScope","Popover","React","PopperPrimitive.Root","useId","PopoverAnchor","PopperPrimitive.Anchor","TRIGGER_NAME","PopoverTrigger","Primitive","getState","PortalPrimitive","CONTENT_NAME","PopoverContent","RemoveScroll","PopperPrimitive.Content","PopoverClose","PopperPrimitive.Arrow","Root2","Trigger","Content2","createContextScope","React","useId","Primitive","getState","TRIGGER_NAME","CONTENT_NAME","Root","createContextScope","Accordion","React","Primitive","AccordionItem","useId","CollapsiblePrimitive.Root","AccordionTrigger","CollapsiblePrimitive.Trigger","AccordionContent","CollapsiblePrimitive.Content","createSlot","React","AspectRatio","React"],"sources":["../node_modules/@radix-ui/react-compose-refs/dist/index.mjs","../node_modules/@radix-ui/react-slot/dist/index.mjs","../node_modules/clsx/dist/clsx.mjs","../node_modules/tailwind-merge/dist/bundle-mjs.mjs","../src/lib/cn.ts","../src/components/Button/Button.tsx","../src/components/Badge/Badge.tsx","../src/components/Label/Label.tsx","../src/components/Input/Input.tsx","../src/components/Card/Card.tsx","../node_modules/@radix-ui/number/dist/index.mjs","../node_modules/@radix-ui/primitive/dist/index.mjs","../node_modules/@radix-ui/react-context/dist/index.mjs","../node_modules/@radix-ui/react-collection/node_modules/@radix-ui/react-slot/dist/index.mjs","../node_modules/@radix-ui/react-collection/dist/index.mjs","../node_modules/@radix-ui/react-direction/dist/index.mjs","../node_modules/@radix-ui/react-primitive/node_modules/@radix-ui/react-slot/dist/index.mjs","../node_modules/@radix-ui/react-primitive/dist/index.mjs","../node_modules/@radix-ui/react-use-callback-ref/dist/index.mjs","../node_modules/@radix-ui/react-use-escape-keydown/dist/index.mjs","../node_modules/@radix-ui/react-dismissable-layer/dist/index.mjs","../node_modules/@radix-ui/react-focus-guards/dist/index.mjs","../node_modules/@radix-ui/react-focus-scope/dist/index.mjs","../node_modules/@radix-ui/react-use-layout-effect/dist/index.mjs","../node_modules/@radix-ui/react-id/dist/index.mjs","../node_modules/@floating-ui/utils/dist/floating-ui.utils.mjs","../node_modules/@floating-ui/core/dist/floating-ui.core.mjs","../node_modules/@floating-ui/utils/dist/floating-ui.utils.dom.mjs","../node_modules/@floating-ui/dom/dist/floating-ui.dom.mjs","../node_modules/@floating-ui/react-dom/dist/floating-ui.react-dom.mjs","../node_modules/@radix-ui/react-arrow/dist/index.mjs","../node_modules/@radix-ui/react-use-size/dist/index.mjs","../node_modules/@radix-ui/react-popper/dist/index.mjs","../node_modules/@radix-ui/react-portal/dist/index.mjs","../node_modules/@radix-ui/react-select/node_modules/@radix-ui/react-slot/dist/index.mjs","../node_modules/@radix-ui/react-use-controllable-state/dist/index.mjs","../node_modules/@radix-ui/react-use-previous/dist/index.mjs","../node_modules/@radix-ui/react-visually-hidden/dist/index.mjs","../node_modules/aria-hidden/dist/es2015/index.js","../node_modules/tslib/tslib.es6.mjs","../node_modules/react-remove-scroll-bar/dist/es2015/constants.js","../node_modules/use-callback-ref/dist/es2015/assignRef.js","../node_modules/use-callback-ref/dist/es2015/useRef.js","../node_modules/use-callback-ref/dist/es2015/useMergeRef.js","../node_modules/use-sidecar/dist/es2015/medium.js","../node_modules/use-sidecar/dist/es2015/exports.js","../node_modules/react-remove-scroll/dist/es2015/medium.js","../node_modules/react-remove-scroll/dist/es2015/UI.js","../node_modules/get-nonce/dist/es2015/index.js","../node_modules/react-style-singleton/dist/es2015/singleton.js","../node_modules/react-style-singleton/dist/es2015/hook.js","../node_modules/react-style-singleton/dist/es2015/component.js","../node_modules/react-remove-scroll-bar/dist/es2015/utils.js","../node_modules/react-remove-scroll-bar/dist/es2015/component.js","../node_modules/react-remove-scroll/dist/es2015/aggresiveCapture.js","../node_modules/react-remove-scroll/dist/es2015/handleScroll.js","../node_modules/react-remove-scroll/dist/es2015/SideEffect.js","../node_modules/react-remove-scroll/dist/es2015/sidecar.js","../node_modules/react-remove-scroll/dist/es2015/Combination.js","../node_modules/@radix-ui/react-select/dist/index.mjs","../src/components/Select/Select.tsx","../node_modules/@radix-ui/react-presence/dist/index.mjs","../node_modules/@radix-ui/react-dialog/node_modules/@radix-ui/react-slot/dist/index.mjs","../node_modules/@radix-ui/react-dialog/dist/index.mjs","../src/components/Dialog/Dialog.tsx","../src/components/PageShell/PageShell.tsx","../src/components/Table/Table.tsx","../src/components/Textarea/Textarea.tsx","../node_modules/@radix-ui/react-checkbox/dist/index.mjs","../src/components/Checkbox/Checkbox.tsx","../node_modules/@radix-ui/react-switch/dist/index.mjs","../src/components/Switch/Switch.tsx","../src/components/Alert/Alert.tsx","../node_modules/@radix-ui/react-toast/dist/index.mjs","../src/components/Toast/use-toast.ts","../src/components/Toast/Toast.tsx","../node_modules/@radix-ui/react-roving-focus/dist/index.mjs","../node_modules/@radix-ui/react-tabs/dist/index.mjs","../src/components/Tabs/Tabs.tsx","../node_modules/@radix-ui/react-menu/node_modules/@radix-ui/react-slot/dist/index.mjs","../node_modules/@radix-ui/react-menu/dist/index.mjs","../node_modules/@radix-ui/react-dropdown-menu/dist/index.mjs","../src/components/DropdownMenu/DropdownMenu.tsx","../node_modules/@radix-ui/react-tooltip/node_modules/@radix-ui/react-slot/dist/index.mjs","../node_modules/@radix-ui/react-tooltip/dist/index.mjs","../src/components/Tooltip/Tooltip.tsx","../src/components/Spinner/Spinner.tsx","../src/components/Skeleton/Skeleton.tsx","../node_modules/@radix-ui/react-progress/node_modules/@radix-ui/react-context/dist/index.mjs","../node_modules/@radix-ui/react-progress/node_modules/@radix-ui/react-primitive/dist/index.mjs","../node_modules/@radix-ui/react-progress/dist/index.mjs","../src/components/Progress/Progress.tsx","../src/components/Stat/Stat.tsx","../node_modules/@radix-ui/react-avatar/node_modules/@radix-ui/react-context/dist/index.mjs","../node_modules/@radix-ui/react-avatar/node_modules/@radix-ui/react-primitive/dist/index.mjs","../node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.production.js","../node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.development.js","../node_modules/use-sync-external-store/shim/index.js","../node_modules/@radix-ui/react-use-is-hydrated/dist/index.mjs","../node_modules/@radix-ui/react-avatar/dist/index.mjs","../src/components/Avatar/Avatar.tsx","../node_modules/@radix-ui/react-radio-group/dist/index.mjs","../src/components/RadioGroup/RadioGroup.tsx","../node_modules/@radix-ui/react-popover/node_modules/@radix-ui/react-slot/dist/index.mjs","../node_modules/@radix-ui/react-popover/dist/index.mjs","../src/components/Popover/Popover.tsx","../src/components/Breadcrumb/Breadcrumb.tsx","../node_modules/@radix-ui/react-collapsible/dist/index.mjs","../node_modules/@radix-ui/react-accordion/dist/index.mjs","../src/components/Accordion/Accordion.tsx","../src/components/Stepper/Stepper.tsx","../src/components/Combobox/Combobox.tsx","../src/components/DatePicker/DatePicker.tsx","../src/components/FileUpload/FileUpload.tsx","../src/components/DataTable/DataTable.tsx","../node_modules/@radix-ui/react-aspect-ratio/node_modules/@radix-ui/react-primitive/dist/index.mjs","../node_modules/@radix-ui/react-aspect-ratio/dist/index.mjs","../src/components/AspectRatio/AspectRatio.tsx"],"sourcesContent":["// packages/react/compose-refs/src/compose-refs.tsx\nimport * as React from \"react\";\nfunction setRef(ref, value) {\n if (typeof ref === \"function\") {\n return ref(value);\n } else if (ref !== null && ref !== void 0) {\n ref.current = value;\n }\n}\nfunction composeRefs(...refs) {\n return (node) => {\n let hasCleanup = false;\n const cleanups = refs.map((ref) => {\n const cleanup = setRef(ref, node);\n if (!hasCleanup && typeof cleanup == \"function\") {\n hasCleanup = true;\n }\n return cleanup;\n });\n if (hasCleanup) {\n return () => {\n for (let i = 0; i < cleanups.length; i++) {\n const cleanup = cleanups[i];\n if (typeof cleanup == \"function\") {\n cleanup();\n } else {\n setRef(refs[i], null);\n }\n }\n };\n }\n };\n}\nfunction useComposedRefs(...refs) {\n return React.useCallback(composeRefs(...refs), refs);\n}\nexport {\n composeRefs,\n useComposedRefs\n};\n//# sourceMappingURL=index.mjs.map\n","// src/slot.tsx\nimport * as React from \"react\";\nimport { composeRefs } from \"@radix-ui/react-compose-refs\";\nimport { Fragment as Fragment2, jsx } from \"react/jsx-runtime\";\nvar REACT_LAZY_TYPE = Symbol.for(\"react.lazy\");\nvar use = React[\" use \".trim().toString()];\nfunction isPromiseLike(value) {\n return typeof value === \"object\" && value !== null && \"then\" in value;\n}\nfunction isLazyComponent(element) {\n return element != null && typeof element === \"object\" && \"$$typeof\" in element && element.$$typeof === REACT_LAZY_TYPE && \"_payload\" in element && isPromiseLike(element._payload);\n}\n// @__NO_SIDE_EFFECTS__\nfunction createSlot(ownerName) {\n const SlotClone = /* @__PURE__ */ createSlotClone(ownerName);\n const Slot2 = React.forwardRef((props, forwardedRef) => {\n let { children, ...slotProps } = props;\n if (isLazyComponent(children) && typeof use === \"function\") {\n children = use(children._payload);\n }\n const childrenArray = React.Children.toArray(children);\n const slottable = childrenArray.find(isSlottable);\n if (slottable) {\n const newElement = slottable.props.children;\n const newChildren = childrenArray.map((child) => {\n if (child === slottable) {\n if (React.Children.count(newElement) > 1) return React.Children.only(null);\n return React.isValidElement(newElement) ? newElement.props.children : null;\n } else {\n return child;\n }\n });\n return /* @__PURE__ */ jsx(SlotClone, { ...slotProps, ref: forwardedRef, children: React.isValidElement(newElement) ? React.cloneElement(newElement, void 0, newChildren) : null });\n }\n return /* @__PURE__ */ jsx(SlotClone, { ...slotProps, ref: forwardedRef, children });\n });\n Slot2.displayName = `${ownerName}.Slot`;\n return Slot2;\n}\nvar Slot = /* @__PURE__ */ createSlot(\"Slot\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlotClone(ownerName) {\n const SlotClone = React.forwardRef((props, forwardedRef) => {\n let { children, ...slotProps } = props;\n if (isLazyComponent(children) && typeof use === \"function\") {\n children = use(children._payload);\n }\n if (React.isValidElement(children)) {\n const childrenRef = getElementRef(children);\n const props2 = mergeProps(slotProps, children.props);\n if (children.type !== React.Fragment) {\n props2.ref = forwardedRef ? composeRefs(forwardedRef, childrenRef) : childrenRef;\n }\n return React.cloneElement(children, props2);\n }\n return React.Children.count(children) > 1 ? React.Children.only(null) : null;\n });\n SlotClone.displayName = `${ownerName}.SlotClone`;\n return SlotClone;\n}\nvar SLOTTABLE_IDENTIFIER = Symbol(\"radix.slottable\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlottable(ownerName) {\n const Slottable2 = ({ children }) => {\n return /* @__PURE__ */ jsx(Fragment2, { children });\n };\n Slottable2.displayName = `${ownerName}.Slottable`;\n Slottable2.__radixId = SLOTTABLE_IDENTIFIER;\n return Slottable2;\n}\nvar Slottable = /* @__PURE__ */ createSlottable(\"Slottable\");\nfunction isSlottable(child) {\n return React.isValidElement(child) && typeof child.type === \"function\" && \"__radixId\" in child.type && child.type.__radixId === SLOTTABLE_IDENTIFIER;\n}\nfunction mergeProps(slotProps, childProps) {\n const overrideProps = { ...childProps };\n for (const propName in childProps) {\n const slotPropValue = slotProps[propName];\n const childPropValue = childProps[propName];\n const isHandler = /^on[A-Z]/.test(propName);\n if (isHandler) {\n if (slotPropValue && childPropValue) {\n overrideProps[propName] = (...args) => {\n const result = childPropValue(...args);\n slotPropValue(...args);\n return result;\n };\n } else if (slotPropValue) {\n overrideProps[propName] = slotPropValue;\n }\n } else if (propName === \"style\") {\n overrideProps[propName] = { ...slotPropValue, ...childPropValue };\n } else if (propName === \"className\") {\n overrideProps[propName] = [slotPropValue, childPropValue].filter(Boolean).join(\" \");\n }\n }\n return { ...slotProps, ...overrideProps };\n}\nfunction getElementRef(element) {\n let getter = Object.getOwnPropertyDescriptor(element.props, \"ref\")?.get;\n let mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.ref;\n }\n getter = Object.getOwnPropertyDescriptor(element, \"ref\")?.get;\n mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.props.ref;\n }\n return element.props.ref || element.ref;\n}\nexport {\n Slot as Root,\n Slot,\n Slottable,\n createSlot,\n createSlottable\n};\n//# sourceMappingURL=index.mjs.map\n","function r(e){var t,f,n=\"\";if(\"string\"==typeof e||\"number\"==typeof e)n+=e;else if(\"object\"==typeof e)if(Array.isArray(e)){var o=e.length;for(t=0;t<o;t++)e[t]&&(f=r(e[t]))&&(n&&(n+=\" \"),n+=f)}else for(f in e)e[f]&&(n&&(n+=\" \"),n+=f);return n}export function clsx(){for(var e,t,f=0,n=\"\",o=arguments.length;f<o;f++)(e=arguments[f])&&(t=r(e))&&(n&&(n+=\" \"),n+=t);return n}export default clsx;","/**\n * Concatenates two arrays faster than the array spread operator.\n */\nconst concatArrays = (array1, array2) => {\n // Pre-allocate for better V8 optimization\n const combinedArray = new Array(array1.length + array2.length);\n for (let i = 0; i < array1.length; i++) {\n combinedArray[i] = array1[i];\n }\n for (let i = 0; i < array2.length; i++) {\n combinedArray[array1.length + i] = array2[i];\n }\n return combinedArray;\n};\n\n// Factory function ensures consistent object shapes\nconst createClassValidatorObject = (classGroupId, validator) => ({\n classGroupId,\n validator\n});\n// Factory ensures consistent ClassPartObject shape\nconst createClassPartObject = (nextPart = new Map(), validators = null, classGroupId) => ({\n nextPart,\n validators,\n classGroupId\n});\nconst CLASS_PART_SEPARATOR = '-';\nconst EMPTY_CONFLICTS = [];\n// I use two dots here because one dot is used as prefix for class groups in plugins\nconst ARBITRARY_PROPERTY_PREFIX = 'arbitrary..';\nconst createClassGroupUtils = config => {\n const classMap = createClassMap(config);\n const {\n conflictingClassGroups,\n conflictingClassGroupModifiers\n } = config;\n const getClassGroupId = className => {\n if (className.startsWith('[') && className.endsWith(']')) {\n return getGroupIdForArbitraryProperty(className);\n }\n const classParts = className.split(CLASS_PART_SEPARATOR);\n // Classes like `-inset-1` produce an empty string as first classPart. We assume that classes for negative values are used correctly and skip it.\n const startIndex = classParts[0] === '' && classParts.length > 1 ? 1 : 0;\n return getGroupRecursive(classParts, startIndex, classMap);\n };\n const getConflictingClassGroupIds = (classGroupId, hasPostfixModifier) => {\n if (hasPostfixModifier) {\n const modifierConflicts = conflictingClassGroupModifiers[classGroupId];\n const baseConflicts = conflictingClassGroups[classGroupId];\n if (modifierConflicts) {\n if (baseConflicts) {\n // Merge base conflicts with modifier conflicts\n return concatArrays(baseConflicts, modifierConflicts);\n }\n // Only modifier conflicts\n return modifierConflicts;\n }\n // Fall back to without postfix if no modifier conflicts\n return baseConflicts || EMPTY_CONFLICTS;\n }\n return conflictingClassGroups[classGroupId] || EMPTY_CONFLICTS;\n };\n return {\n getClassGroupId,\n getConflictingClassGroupIds\n };\n};\nconst getGroupRecursive = (classParts, startIndex, classPartObject) => {\n const classPathsLength = classParts.length - startIndex;\n if (classPathsLength === 0) {\n return classPartObject.classGroupId;\n }\n const currentClassPart = classParts[startIndex];\n const nextClassPartObject = classPartObject.nextPart.get(currentClassPart);\n if (nextClassPartObject) {\n const result = getGroupRecursive(classParts, startIndex + 1, nextClassPartObject);\n if (result) return result;\n }\n const validators = classPartObject.validators;\n if (validators === null) {\n return undefined;\n }\n // Build classRest string efficiently by joining from startIndex onwards\n const classRest = startIndex === 0 ? classParts.join(CLASS_PART_SEPARATOR) : classParts.slice(startIndex).join(CLASS_PART_SEPARATOR);\n const validatorsLength = validators.length;\n for (let i = 0; i < validatorsLength; i++) {\n const validatorObj = validators[i];\n if (validatorObj.validator(classRest)) {\n return validatorObj.classGroupId;\n }\n }\n return undefined;\n};\n/**\n * Get the class group ID for an arbitrary property.\n *\n * @param className - The class name to get the group ID for. Is expected to be string starting with `[` and ending with `]`.\n */\nconst getGroupIdForArbitraryProperty = className => className.slice(1, -1).indexOf(':') === -1 ? undefined : (() => {\n const content = className.slice(1, -1);\n const colonIndex = content.indexOf(':');\n const property = content.slice(0, colonIndex);\n return property ? ARBITRARY_PROPERTY_PREFIX + property : undefined;\n})();\n/**\n * Exported for testing only\n */\nconst createClassMap = config => {\n const {\n theme,\n classGroups\n } = config;\n return processClassGroups(classGroups, theme);\n};\n// Split into separate functions to maintain monomorphic call sites\nconst processClassGroups = (classGroups, theme) => {\n const classMap = createClassPartObject();\n for (const classGroupId in classGroups) {\n const group = classGroups[classGroupId];\n processClassesRecursively(group, classMap, classGroupId, theme);\n }\n return classMap;\n};\nconst processClassesRecursively = (classGroup, classPartObject, classGroupId, theme) => {\n const len = classGroup.length;\n for (let i = 0; i < len; i++) {\n const classDefinition = classGroup[i];\n processClassDefinition(classDefinition, classPartObject, classGroupId, theme);\n }\n};\n// Split into separate functions for each type to maintain monomorphic call sites\nconst processClassDefinition = (classDefinition, classPartObject, classGroupId, theme) => {\n if (typeof classDefinition === 'string') {\n processStringDefinition(classDefinition, classPartObject, classGroupId);\n return;\n }\n if (typeof classDefinition === 'function') {\n processFunctionDefinition(classDefinition, classPartObject, classGroupId, theme);\n return;\n }\n processObjectDefinition(classDefinition, classPartObject, classGroupId, theme);\n};\nconst processStringDefinition = (classDefinition, classPartObject, classGroupId) => {\n const classPartObjectToEdit = classDefinition === '' ? classPartObject : getPart(classPartObject, classDefinition);\n classPartObjectToEdit.classGroupId = classGroupId;\n};\nconst processFunctionDefinition = (classDefinition, classPartObject, classGroupId, theme) => {\n if (isThemeGetter(classDefinition)) {\n processClassesRecursively(classDefinition(theme), classPartObject, classGroupId, theme);\n return;\n }\n if (classPartObject.validators === null) {\n classPartObject.validators = [];\n }\n classPartObject.validators.push(createClassValidatorObject(classGroupId, classDefinition));\n};\nconst processObjectDefinition = (classDefinition, classPartObject, classGroupId, theme) => {\n const entries = Object.entries(classDefinition);\n const len = entries.length;\n for (let i = 0; i < len; i++) {\n const [key, value] = entries[i];\n processClassesRecursively(value, getPart(classPartObject, key), classGroupId, theme);\n }\n};\nconst getPart = (classPartObject, path) => {\n let current = classPartObject;\n const parts = path.split(CLASS_PART_SEPARATOR);\n const len = parts.length;\n for (let i = 0; i < len; i++) {\n const part = parts[i];\n let next = current.nextPart.get(part);\n if (!next) {\n next = createClassPartObject();\n current.nextPart.set(part, next);\n }\n current = next;\n }\n return current;\n};\n// Type guard maintains monomorphic check\nconst isThemeGetter = func => 'isThemeGetter' in func && func.isThemeGetter === true;\n\n// LRU cache implementation using plain objects for simplicity\nconst createLruCache = maxCacheSize => {\n if (maxCacheSize < 1) {\n return {\n get: () => undefined,\n set: () => {}\n };\n }\n let cacheSize = 0;\n let cache = Object.create(null);\n let previousCache = Object.create(null);\n const update = (key, value) => {\n cache[key] = value;\n cacheSize++;\n if (cacheSize > maxCacheSize) {\n cacheSize = 0;\n previousCache = cache;\n cache = Object.create(null);\n }\n };\n return {\n get(key) {\n let value = cache[key];\n if (value !== undefined) {\n return value;\n }\n if ((value = previousCache[key]) !== undefined) {\n update(key, value);\n return value;\n }\n },\n set(key, value) {\n if (key in cache) {\n cache[key] = value;\n } else {\n update(key, value);\n }\n }\n };\n};\nconst IMPORTANT_MODIFIER = '!';\nconst MODIFIER_SEPARATOR = ':';\nconst EMPTY_MODIFIERS = [];\n// Pre-allocated result object shape for consistency\nconst createResultObject = (modifiers, hasImportantModifier, baseClassName, maybePostfixModifierPosition, isExternal) => ({\n modifiers,\n hasImportantModifier,\n baseClassName,\n maybePostfixModifierPosition,\n isExternal\n});\nconst createParseClassName = config => {\n const {\n prefix,\n experimentalParseClassName\n } = config;\n /**\n * Parse class name into parts.\n *\n * Inspired by `splitAtTopLevelOnly` used in Tailwind CSS\n * @see https://github.com/tailwindlabs/tailwindcss/blob/v3.2.2/src/util/splitAtTopLevelOnly.js\n */\n let parseClassName = className => {\n // Use simple array with push for better performance\n const modifiers = [];\n let bracketDepth = 0;\n let parenDepth = 0;\n let modifierStart = 0;\n let postfixModifierPosition;\n const len = className.length;\n for (let index = 0; index < len; index++) {\n const currentCharacter = className[index];\n if (bracketDepth === 0 && parenDepth === 0) {\n if (currentCharacter === MODIFIER_SEPARATOR) {\n modifiers.push(className.slice(modifierStart, index));\n modifierStart = index + 1;\n continue;\n }\n if (currentCharacter === '/') {\n postfixModifierPosition = index;\n continue;\n }\n }\n if (currentCharacter === '[') bracketDepth++;else if (currentCharacter === ']') bracketDepth--;else if (currentCharacter === '(') parenDepth++;else if (currentCharacter === ')') parenDepth--;\n }\n const baseClassNameWithImportantModifier = modifiers.length === 0 ? className : className.slice(modifierStart);\n // Inline important modifier check\n let baseClassName = baseClassNameWithImportantModifier;\n let hasImportantModifier = false;\n if (baseClassNameWithImportantModifier.endsWith(IMPORTANT_MODIFIER)) {\n baseClassName = baseClassNameWithImportantModifier.slice(0, -1);\n hasImportantModifier = true;\n } else if (\n /**\n * In Tailwind CSS v3 the important modifier was at the start of the base class name. This is still supported for legacy reasons.\n * @see https://github.com/dcastil/tailwind-merge/issues/513#issuecomment-2614029864\n */\n baseClassNameWithImportantModifier.startsWith(IMPORTANT_MODIFIER)) {\n baseClassName = baseClassNameWithImportantModifier.slice(1);\n hasImportantModifier = true;\n }\n const maybePostfixModifierPosition = postfixModifierPosition && postfixModifierPosition > modifierStart ? postfixModifierPosition - modifierStart : undefined;\n return createResultObject(modifiers, hasImportantModifier, baseClassName, maybePostfixModifierPosition);\n };\n if (prefix) {\n const fullPrefix = prefix + MODIFIER_SEPARATOR;\n const parseClassNameOriginal = parseClassName;\n parseClassName = className => className.startsWith(fullPrefix) ? parseClassNameOriginal(className.slice(fullPrefix.length)) : createResultObject(EMPTY_MODIFIERS, false, className, undefined, true);\n }\n if (experimentalParseClassName) {\n const parseClassNameOriginal = parseClassName;\n parseClassName = className => experimentalParseClassName({\n className,\n parseClassName: parseClassNameOriginal\n });\n }\n return parseClassName;\n};\n\n/**\n * Sorts modifiers according to following schema:\n * - Predefined modifiers are sorted alphabetically\n * - When an arbitrary variant appears, it must be preserved which modifiers are before and after it\n */\nconst createSortModifiers = config => {\n // Pre-compute weights for all known modifiers for O(1) comparison\n const modifierWeights = new Map();\n // Assign weights to sensitive modifiers (highest priority, but preserve order)\n config.orderSensitiveModifiers.forEach((mod, index) => {\n modifierWeights.set(mod, 1000000 + index); // High weights for sensitive mods\n });\n return modifiers => {\n const result = [];\n let currentSegment = [];\n // Process modifiers in one pass\n for (let i = 0; i < modifiers.length; i++) {\n const modifier = modifiers[i];\n // Check if modifier is sensitive (starts with '[' or in orderSensitiveModifiers)\n const isArbitrary = modifier[0] === '[';\n const isOrderSensitive = modifierWeights.has(modifier);\n if (isArbitrary || isOrderSensitive) {\n // Sort and flush current segment alphabetically\n if (currentSegment.length > 0) {\n currentSegment.sort();\n result.push(...currentSegment);\n currentSegment = [];\n }\n result.push(modifier);\n } else {\n // Regular modifier - add to current segment for batch sorting\n currentSegment.push(modifier);\n }\n }\n // Sort and add any remaining segment items\n if (currentSegment.length > 0) {\n currentSegment.sort();\n result.push(...currentSegment);\n }\n return result;\n };\n};\nconst createConfigUtils = config => ({\n cache: createLruCache(config.cacheSize),\n parseClassName: createParseClassName(config),\n sortModifiers: createSortModifiers(config),\n ...createClassGroupUtils(config)\n});\nconst SPLIT_CLASSES_REGEX = /\\s+/;\nconst mergeClassList = (classList, configUtils) => {\n const {\n parseClassName,\n getClassGroupId,\n getConflictingClassGroupIds,\n sortModifiers\n } = configUtils;\n /**\n * Set of classGroupIds in following format:\n * `{importantModifier}{variantModifiers}{classGroupId}`\n * @example 'float'\n * @example 'hover:focus:bg-color'\n * @example 'md:!pr'\n */\n const classGroupsInConflict = [];\n const classNames = classList.trim().split(SPLIT_CLASSES_REGEX);\n let result = '';\n for (let index = classNames.length - 1; index >= 0; index -= 1) {\n const originalClassName = classNames[index];\n const {\n isExternal,\n modifiers,\n hasImportantModifier,\n baseClassName,\n maybePostfixModifierPosition\n } = parseClassName(originalClassName);\n if (isExternal) {\n result = originalClassName + (result.length > 0 ? ' ' + result : result);\n continue;\n }\n let hasPostfixModifier = !!maybePostfixModifierPosition;\n let classGroupId = getClassGroupId(hasPostfixModifier ? baseClassName.substring(0, maybePostfixModifierPosition) : baseClassName);\n if (!classGroupId) {\n if (!hasPostfixModifier) {\n // Not a Tailwind class\n result = originalClassName + (result.length > 0 ? ' ' + result : result);\n continue;\n }\n classGroupId = getClassGroupId(baseClassName);\n if (!classGroupId) {\n // Not a Tailwind class\n result = originalClassName + (result.length > 0 ? ' ' + result : result);\n continue;\n }\n hasPostfixModifier = false;\n }\n // Fast path: skip sorting for empty or single modifier\n const variantModifier = modifiers.length === 0 ? '' : modifiers.length === 1 ? modifiers[0] : sortModifiers(modifiers).join(':');\n const modifierId = hasImportantModifier ? variantModifier + IMPORTANT_MODIFIER : variantModifier;\n const classId = modifierId + classGroupId;\n if (classGroupsInConflict.indexOf(classId) > -1) {\n // Tailwind class omitted due to conflict\n continue;\n }\n classGroupsInConflict.push(classId);\n const conflictGroups = getConflictingClassGroupIds(classGroupId, hasPostfixModifier);\n for (let i = 0; i < conflictGroups.length; ++i) {\n const group = conflictGroups[i];\n classGroupsInConflict.push(modifierId + group);\n }\n // Tailwind class not in conflict\n result = originalClassName + (result.length > 0 ? ' ' + result : result);\n }\n return result;\n};\n\n/**\n * The code in this file is copied from https://github.com/lukeed/clsx and modified to suit the needs of tailwind-merge better.\n *\n * Specifically:\n * - Runtime code from https://github.com/lukeed/clsx/blob/v1.2.1/src/index.js\n * - TypeScript types from https://github.com/lukeed/clsx/blob/v1.2.1/clsx.d.ts\n *\n * Original code has MIT license: Copyright (c) Luke Edwards <luke.edwards05@gmail.com> (lukeed.com)\n */\nconst twJoin = (...classLists) => {\n let index = 0;\n let argument;\n let resolvedValue;\n let string = '';\n while (index < classLists.length) {\n if (argument = classLists[index++]) {\n if (resolvedValue = toValue(argument)) {\n string && (string += ' ');\n string += resolvedValue;\n }\n }\n }\n return string;\n};\nconst toValue = mix => {\n // Fast path for strings\n if (typeof mix === 'string') {\n return mix;\n }\n let resolvedValue;\n let string = '';\n for (let k = 0; k < mix.length; k++) {\n if (mix[k]) {\n if (resolvedValue = toValue(mix[k])) {\n string && (string += ' ');\n string += resolvedValue;\n }\n }\n }\n return string;\n};\nconst createTailwindMerge = (createConfigFirst, ...createConfigRest) => {\n let configUtils;\n let cacheGet;\n let cacheSet;\n let functionToCall;\n const initTailwindMerge = classList => {\n const config = createConfigRest.reduce((previousConfig, createConfigCurrent) => createConfigCurrent(previousConfig), createConfigFirst());\n configUtils = createConfigUtils(config);\n cacheGet = configUtils.cache.get;\n cacheSet = configUtils.cache.set;\n functionToCall = tailwindMerge;\n return tailwindMerge(classList);\n };\n const tailwindMerge = classList => {\n const cachedResult = cacheGet(classList);\n if (cachedResult) {\n return cachedResult;\n }\n const result = mergeClassList(classList, configUtils);\n cacheSet(classList, result);\n return result;\n };\n functionToCall = initTailwindMerge;\n return (...args) => functionToCall(twJoin(...args));\n};\nconst fallbackThemeArr = [];\nconst fromTheme = key => {\n const themeGetter = theme => theme[key] || fallbackThemeArr;\n themeGetter.isThemeGetter = true;\n return themeGetter;\n};\nconst arbitraryValueRegex = /^\\[(?:(\\w[\\w-]*):)?(.+)\\]$/i;\nconst arbitraryVariableRegex = /^\\((?:(\\w[\\w-]*):)?(.+)\\)$/i;\nconst fractionRegex = /^\\d+(?:\\.\\d+)?\\/\\d+(?:\\.\\d+)?$/;\nconst tshirtUnitRegex = /^(\\d+(\\.\\d+)?)?(xs|sm|md|lg|xl)$/;\nconst lengthUnitRegex = /\\d+(%|px|r?em|[sdl]?v([hwib]|min|max)|pt|pc|in|cm|mm|cap|ch|ex|r?lh|cq(w|h|i|b|min|max))|\\b(calc|min|max|clamp)\\(.+\\)|^0$/;\nconst colorFunctionRegex = /^(rgba?|hsla?|hwb|(ok)?(lab|lch)|color-mix)\\(.+\\)$/;\n// Shadow always begins with x and y offset separated by underscore optionally prepended by inset\nconst shadowRegex = /^(inset_)?-?((\\d+)?\\.?(\\d+)[a-z]+|0)_-?((\\d+)?\\.?(\\d+)[a-z]+|0)/;\nconst imageRegex = /^(url|image|image-set|cross-fade|element|(repeating-)?(linear|radial|conic)-gradient)\\(.+\\)$/;\nconst isFraction = value => fractionRegex.test(value);\nconst isNumber = value => !!value && !Number.isNaN(Number(value));\nconst isInteger = value => !!value && Number.isInteger(Number(value));\nconst isPercent = value => value.endsWith('%') && isNumber(value.slice(0, -1));\nconst isTshirtSize = value => tshirtUnitRegex.test(value);\nconst isAny = () => true;\nconst isLengthOnly = value =>\n// `colorFunctionRegex` check is necessary because color functions can have percentages in them which which would be incorrectly classified as lengths.\n// For example, `hsl(0 0% 0%)` would be classified as a length without this check.\n// I could also use lookbehind assertion in `lengthUnitRegex` but that isn't supported widely enough.\nlengthUnitRegex.test(value) && !colorFunctionRegex.test(value);\nconst isNever = () => false;\nconst isShadow = value => shadowRegex.test(value);\nconst isImage = value => imageRegex.test(value);\nconst isAnyNonArbitrary = value => !isArbitraryValue(value) && !isArbitraryVariable(value);\nconst isArbitrarySize = value => getIsArbitraryValue(value, isLabelSize, isNever);\nconst isArbitraryValue = value => arbitraryValueRegex.test(value);\nconst isArbitraryLength = value => getIsArbitraryValue(value, isLabelLength, isLengthOnly);\nconst isArbitraryNumber = value => getIsArbitraryValue(value, isLabelNumber, isNumber);\nconst isArbitraryWeight = value => getIsArbitraryValue(value, isLabelWeight, isAny);\nconst isArbitraryFamilyName = value => getIsArbitraryValue(value, isLabelFamilyName, isNever);\nconst isArbitraryPosition = value => getIsArbitraryValue(value, isLabelPosition, isNever);\nconst isArbitraryImage = value => getIsArbitraryValue(value, isLabelImage, isImage);\nconst isArbitraryShadow = value => getIsArbitraryValue(value, isLabelShadow, isShadow);\nconst isArbitraryVariable = value => arbitraryVariableRegex.test(value);\nconst isArbitraryVariableLength = value => getIsArbitraryVariable(value, isLabelLength);\nconst isArbitraryVariableFamilyName = value => getIsArbitraryVariable(value, isLabelFamilyName);\nconst isArbitraryVariablePosition = value => getIsArbitraryVariable(value, isLabelPosition);\nconst isArbitraryVariableSize = value => getIsArbitraryVariable(value, isLabelSize);\nconst isArbitraryVariableImage = value => getIsArbitraryVariable(value, isLabelImage);\nconst isArbitraryVariableShadow = value => getIsArbitraryVariable(value, isLabelShadow, true);\nconst isArbitraryVariableWeight = value => getIsArbitraryVariable(value, isLabelWeight, true);\n// Helpers\nconst getIsArbitraryValue = (value, testLabel, testValue) => {\n const result = arbitraryValueRegex.exec(value);\n if (result) {\n if (result[1]) {\n return testLabel(result[1]);\n }\n return testValue(result[2]);\n }\n return false;\n};\nconst getIsArbitraryVariable = (value, testLabel, shouldMatchNoLabel = false) => {\n const result = arbitraryVariableRegex.exec(value);\n if (result) {\n if (result[1]) {\n return testLabel(result[1]);\n }\n return shouldMatchNoLabel;\n }\n return false;\n};\n// Labels\nconst isLabelPosition = label => label === 'position' || label === 'percentage';\nconst isLabelImage = label => label === 'image' || label === 'url';\nconst isLabelSize = label => label === 'length' || label === 'size' || label === 'bg-size';\nconst isLabelLength = label => label === 'length';\nconst isLabelNumber = label => label === 'number';\nconst isLabelFamilyName = label => label === 'family-name';\nconst isLabelWeight = label => label === 'number' || label === 'weight';\nconst isLabelShadow = label => label === 'shadow';\nconst validators = /*#__PURE__*/Object.defineProperty({\n __proto__: null,\n isAny,\n isAnyNonArbitrary,\n isArbitraryFamilyName,\n isArbitraryImage,\n isArbitraryLength,\n isArbitraryNumber,\n isArbitraryPosition,\n isArbitraryShadow,\n isArbitrarySize,\n isArbitraryValue,\n isArbitraryVariable,\n isArbitraryVariableFamilyName,\n isArbitraryVariableImage,\n isArbitraryVariableLength,\n isArbitraryVariablePosition,\n isArbitraryVariableShadow,\n isArbitraryVariableSize,\n isArbitraryVariableWeight,\n isArbitraryWeight,\n isFraction,\n isInteger,\n isNumber,\n isPercent,\n isTshirtSize\n}, Symbol.toStringTag, {\n value: 'Module'\n});\nconst getDefaultConfig = () => {\n /**\n * Theme getters for theme variable namespaces\n * @see https://tailwindcss.com/docs/theme#theme-variable-namespaces\n */\n /***/\n const themeColor = fromTheme('color');\n const themeFont = fromTheme('font');\n const themeText = fromTheme('text');\n const themeFontWeight = fromTheme('font-weight');\n const themeTracking = fromTheme('tracking');\n const themeLeading = fromTheme('leading');\n const themeBreakpoint = fromTheme('breakpoint');\n const themeContainer = fromTheme('container');\n const themeSpacing = fromTheme('spacing');\n const themeRadius = fromTheme('radius');\n const themeShadow = fromTheme('shadow');\n const themeInsetShadow = fromTheme('inset-shadow');\n const themeTextShadow = fromTheme('text-shadow');\n const themeDropShadow = fromTheme('drop-shadow');\n const themeBlur = fromTheme('blur');\n const themePerspective = fromTheme('perspective');\n const themeAspect = fromTheme('aspect');\n const themeEase = fromTheme('ease');\n const themeAnimate = fromTheme('animate');\n /**\n * Helpers to avoid repeating the same scales\n *\n * We use functions that create a new array every time they're called instead of static arrays.\n * This ensures that users who modify any scale by mutating the array (e.g. with `array.push(element)`) don't accidentally mutate arrays in other parts of the config.\n */\n /***/\n const scaleBreak = () => ['auto', 'avoid', 'all', 'avoid-page', 'page', 'left', 'right', 'column'];\n const scalePosition = () => ['center', 'top', 'bottom', 'left', 'right', 'top-left',\n // Deprecated since Tailwind CSS v4.1.0, see https://github.com/tailwindlabs/tailwindcss/pull/17378\n 'left-top', 'top-right',\n // Deprecated since Tailwind CSS v4.1.0, see https://github.com/tailwindlabs/tailwindcss/pull/17378\n 'right-top', 'bottom-right',\n // Deprecated since Tailwind CSS v4.1.0, see https://github.com/tailwindlabs/tailwindcss/pull/17378\n 'right-bottom', 'bottom-left',\n // Deprecated since Tailwind CSS v4.1.0, see https://github.com/tailwindlabs/tailwindcss/pull/17378\n 'left-bottom'];\n const scalePositionWithArbitrary = () => [...scalePosition(), isArbitraryVariable, isArbitraryValue];\n const scaleOverflow = () => ['auto', 'hidden', 'clip', 'visible', 'scroll'];\n const scaleOverscroll = () => ['auto', 'contain', 'none'];\n const scaleUnambiguousSpacing = () => [isArbitraryVariable, isArbitraryValue, themeSpacing];\n const scaleInset = () => [isFraction, 'full', 'auto', ...scaleUnambiguousSpacing()];\n const scaleGridTemplateColsRows = () => [isInteger, 'none', 'subgrid', isArbitraryVariable, isArbitraryValue];\n const scaleGridColRowStartAndEnd = () => ['auto', {\n span: ['full', isInteger, isArbitraryVariable, isArbitraryValue]\n }, isInteger, isArbitraryVariable, isArbitraryValue];\n const scaleGridColRowStartOrEnd = () => [isInteger, 'auto', isArbitraryVariable, isArbitraryValue];\n const scaleGridAutoColsRows = () => ['auto', 'min', 'max', 'fr', isArbitraryVariable, isArbitraryValue];\n const scaleAlignPrimaryAxis = () => ['start', 'end', 'center', 'between', 'around', 'evenly', 'stretch', 'baseline', 'center-safe', 'end-safe'];\n const scaleAlignSecondaryAxis = () => ['start', 'end', 'center', 'stretch', 'center-safe', 'end-safe'];\n const scaleMargin = () => ['auto', ...scaleUnambiguousSpacing()];\n const scaleSizing = () => [isFraction, 'auto', 'full', 'dvw', 'dvh', 'lvw', 'lvh', 'svw', 'svh', 'min', 'max', 'fit', ...scaleUnambiguousSpacing()];\n const scaleSizingInline = () => [isFraction, 'screen', 'full', 'dvw', 'lvw', 'svw', 'min', 'max', 'fit', ...scaleUnambiguousSpacing()];\n const scaleSizingBlock = () => [isFraction, 'screen', 'full', 'lh', 'dvh', 'lvh', 'svh', 'min', 'max', 'fit', ...scaleUnambiguousSpacing()];\n const scaleColor = () => [themeColor, isArbitraryVariable, isArbitraryValue];\n const scaleBgPosition = () => [...scalePosition(), isArbitraryVariablePosition, isArbitraryPosition, {\n position: [isArbitraryVariable, isArbitraryValue]\n }];\n const scaleBgRepeat = () => ['no-repeat', {\n repeat: ['', 'x', 'y', 'space', 'round']\n }];\n const scaleBgSize = () => ['auto', 'cover', 'contain', isArbitraryVariableSize, isArbitrarySize, {\n size: [isArbitraryVariable, isArbitraryValue]\n }];\n const scaleGradientStopPosition = () => [isPercent, isArbitraryVariableLength, isArbitraryLength];\n const scaleRadius = () => [\n // Deprecated since Tailwind CSS v4.0.0\n '', 'none', 'full', themeRadius, isArbitraryVariable, isArbitraryValue];\n const scaleBorderWidth = () => ['', isNumber, isArbitraryVariableLength, isArbitraryLength];\n const scaleLineStyle = () => ['solid', 'dashed', 'dotted', 'double'];\n const scaleBlendMode = () => ['normal', 'multiply', 'screen', 'overlay', 'darken', 'lighten', 'color-dodge', 'color-burn', 'hard-light', 'soft-light', 'difference', 'exclusion', 'hue', 'saturation', 'color', 'luminosity'];\n const scaleMaskImagePosition = () => [isNumber, isPercent, isArbitraryVariablePosition, isArbitraryPosition];\n const scaleBlur = () => [\n // Deprecated since Tailwind CSS v4.0.0\n '', 'none', themeBlur, isArbitraryVariable, isArbitraryValue];\n const scaleRotate = () => ['none', isNumber, isArbitraryVariable, isArbitraryValue];\n const scaleScale = () => ['none', isNumber, isArbitraryVariable, isArbitraryValue];\n const scaleSkew = () => [isNumber, isArbitraryVariable, isArbitraryValue];\n const scaleTranslate = () => [isFraction, 'full', ...scaleUnambiguousSpacing()];\n return {\n cacheSize: 500,\n theme: {\n animate: ['spin', 'ping', 'pulse', 'bounce'],\n aspect: ['video'],\n blur: [isTshirtSize],\n breakpoint: [isTshirtSize],\n color: [isAny],\n container: [isTshirtSize],\n 'drop-shadow': [isTshirtSize],\n ease: ['in', 'out', 'in-out'],\n font: [isAnyNonArbitrary],\n 'font-weight': ['thin', 'extralight', 'light', 'normal', 'medium', 'semibold', 'bold', 'extrabold', 'black'],\n 'inset-shadow': [isTshirtSize],\n leading: ['none', 'tight', 'snug', 'normal', 'relaxed', 'loose'],\n perspective: ['dramatic', 'near', 'normal', 'midrange', 'distant', 'none'],\n radius: [isTshirtSize],\n shadow: [isTshirtSize],\n spacing: ['px', isNumber],\n text: [isTshirtSize],\n 'text-shadow': [isTshirtSize],\n tracking: ['tighter', 'tight', 'normal', 'wide', 'wider', 'widest']\n },\n classGroups: {\n // --------------\n // --- Layout ---\n // --------------\n /**\n * Aspect Ratio\n * @see https://tailwindcss.com/docs/aspect-ratio\n */\n aspect: [{\n aspect: ['auto', 'square', isFraction, isArbitraryValue, isArbitraryVariable, themeAspect]\n }],\n /**\n * Container\n * @see https://tailwindcss.com/docs/container\n * @deprecated since Tailwind CSS v4.0.0\n */\n container: ['container'],\n /**\n * Columns\n * @see https://tailwindcss.com/docs/columns\n */\n columns: [{\n columns: [isNumber, isArbitraryValue, isArbitraryVariable, themeContainer]\n }],\n /**\n * Break After\n * @see https://tailwindcss.com/docs/break-after\n */\n 'break-after': [{\n 'break-after': scaleBreak()\n }],\n /**\n * Break Before\n * @see https://tailwindcss.com/docs/break-before\n */\n 'break-before': [{\n 'break-before': scaleBreak()\n }],\n /**\n * Break Inside\n * @see https://tailwindcss.com/docs/break-inside\n */\n 'break-inside': [{\n 'break-inside': ['auto', 'avoid', 'avoid-page', 'avoid-column']\n }],\n /**\n * Box Decoration Break\n * @see https://tailwindcss.com/docs/box-decoration-break\n */\n 'box-decoration': [{\n 'box-decoration': ['slice', 'clone']\n }],\n /**\n * Box Sizing\n * @see https://tailwindcss.com/docs/box-sizing\n */\n box: [{\n box: ['border', 'content']\n }],\n /**\n * Display\n * @see https://tailwindcss.com/docs/display\n */\n display: ['block', 'inline-block', 'inline', 'flex', 'inline-flex', 'table', 'inline-table', 'table-caption', 'table-cell', 'table-column', 'table-column-group', 'table-footer-group', 'table-header-group', 'table-row-group', 'table-row', 'flow-root', 'grid', 'inline-grid', 'contents', 'list-item', 'hidden'],\n /**\n * Screen Reader Only\n * @see https://tailwindcss.com/docs/display#screen-reader-only\n */\n sr: ['sr-only', 'not-sr-only'],\n /**\n * Floats\n * @see https://tailwindcss.com/docs/float\n */\n float: [{\n float: ['right', 'left', 'none', 'start', 'end']\n }],\n /**\n * Clear\n * @see https://tailwindcss.com/docs/clear\n */\n clear: [{\n clear: ['left', 'right', 'both', 'none', 'start', 'end']\n }],\n /**\n * Isolation\n * @see https://tailwindcss.com/docs/isolation\n */\n isolation: ['isolate', 'isolation-auto'],\n /**\n * Object Fit\n * @see https://tailwindcss.com/docs/object-fit\n */\n 'object-fit': [{\n object: ['contain', 'cover', 'fill', 'none', 'scale-down']\n }],\n /**\n * Object Position\n * @see https://tailwindcss.com/docs/object-position\n */\n 'object-position': [{\n object: scalePositionWithArbitrary()\n }],\n /**\n * Overflow\n * @see https://tailwindcss.com/docs/overflow\n */\n overflow: [{\n overflow: scaleOverflow()\n }],\n /**\n * Overflow X\n * @see https://tailwindcss.com/docs/overflow\n */\n 'overflow-x': [{\n 'overflow-x': scaleOverflow()\n }],\n /**\n * Overflow Y\n * @see https://tailwindcss.com/docs/overflow\n */\n 'overflow-y': [{\n 'overflow-y': scaleOverflow()\n }],\n /**\n * Overscroll Behavior\n * @see https://tailwindcss.com/docs/overscroll-behavior\n */\n overscroll: [{\n overscroll: scaleOverscroll()\n }],\n /**\n * Overscroll Behavior X\n * @see https://tailwindcss.com/docs/overscroll-behavior\n */\n 'overscroll-x': [{\n 'overscroll-x': scaleOverscroll()\n }],\n /**\n * Overscroll Behavior Y\n * @see https://tailwindcss.com/docs/overscroll-behavior\n */\n 'overscroll-y': [{\n 'overscroll-y': scaleOverscroll()\n }],\n /**\n * Position\n * @see https://tailwindcss.com/docs/position\n */\n position: ['static', 'fixed', 'absolute', 'relative', 'sticky'],\n /**\n * Inset\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n inset: [{\n inset: scaleInset()\n }],\n /**\n * Inset Inline\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n 'inset-x': [{\n 'inset-x': scaleInset()\n }],\n /**\n * Inset Block\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n 'inset-y': [{\n 'inset-y': scaleInset()\n }],\n /**\n * Inset Inline Start\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n * @todo class group will be renamed to `inset-s` in next major release\n */\n start: [{\n 'inset-s': scaleInset(),\n /**\n * @deprecated since Tailwind CSS v4.2.0 in favor of `inset-s-*` utilities.\n * @see https://github.com/tailwindlabs/tailwindcss/pull/19613\n */\n start: scaleInset()\n }],\n /**\n * Inset Inline End\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n * @todo class group will be renamed to `inset-e` in next major release\n */\n end: [{\n 'inset-e': scaleInset(),\n /**\n * @deprecated since Tailwind CSS v4.2.0 in favor of `inset-e-*` utilities.\n * @see https://github.com/tailwindlabs/tailwindcss/pull/19613\n */\n end: scaleInset()\n }],\n /**\n * Inset Block Start\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n 'inset-bs': [{\n 'inset-bs': scaleInset()\n }],\n /**\n * Inset Block End\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n 'inset-be': [{\n 'inset-be': scaleInset()\n }],\n /**\n * Top\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n top: [{\n top: scaleInset()\n }],\n /**\n * Right\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n right: [{\n right: scaleInset()\n }],\n /**\n * Bottom\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n bottom: [{\n bottom: scaleInset()\n }],\n /**\n * Left\n * @see https://tailwindcss.com/docs/top-right-bottom-left\n */\n left: [{\n left: scaleInset()\n }],\n /**\n * Visibility\n * @see https://tailwindcss.com/docs/visibility\n */\n visibility: ['visible', 'invisible', 'collapse'],\n /**\n * Z-Index\n * @see https://tailwindcss.com/docs/z-index\n */\n z: [{\n z: [isInteger, 'auto', isArbitraryVariable, isArbitraryValue]\n }],\n // ------------------------\n // --- Flexbox and Grid ---\n // ------------------------\n /**\n * Flex Basis\n * @see https://tailwindcss.com/docs/flex-basis\n */\n basis: [{\n basis: [isFraction, 'full', 'auto', themeContainer, ...scaleUnambiguousSpacing()]\n }],\n /**\n * Flex Direction\n * @see https://tailwindcss.com/docs/flex-direction\n */\n 'flex-direction': [{\n flex: ['row', 'row-reverse', 'col', 'col-reverse']\n }],\n /**\n * Flex Wrap\n * @see https://tailwindcss.com/docs/flex-wrap\n */\n 'flex-wrap': [{\n flex: ['nowrap', 'wrap', 'wrap-reverse']\n }],\n /**\n * Flex\n * @see https://tailwindcss.com/docs/flex\n */\n flex: [{\n flex: [isNumber, isFraction, 'auto', 'initial', 'none', isArbitraryValue]\n }],\n /**\n * Flex Grow\n * @see https://tailwindcss.com/docs/flex-grow\n */\n grow: [{\n grow: ['', isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Flex Shrink\n * @see https://tailwindcss.com/docs/flex-shrink\n */\n shrink: [{\n shrink: ['', isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Order\n * @see https://tailwindcss.com/docs/order\n */\n order: [{\n order: [isInteger, 'first', 'last', 'none', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Grid Template Columns\n * @see https://tailwindcss.com/docs/grid-template-columns\n */\n 'grid-cols': [{\n 'grid-cols': scaleGridTemplateColsRows()\n }],\n /**\n * Grid Column Start / End\n * @see https://tailwindcss.com/docs/grid-column\n */\n 'col-start-end': [{\n col: scaleGridColRowStartAndEnd()\n }],\n /**\n * Grid Column Start\n * @see https://tailwindcss.com/docs/grid-column\n */\n 'col-start': [{\n 'col-start': scaleGridColRowStartOrEnd()\n }],\n /**\n * Grid Column End\n * @see https://tailwindcss.com/docs/grid-column\n */\n 'col-end': [{\n 'col-end': scaleGridColRowStartOrEnd()\n }],\n /**\n * Grid Template Rows\n * @see https://tailwindcss.com/docs/grid-template-rows\n */\n 'grid-rows': [{\n 'grid-rows': scaleGridTemplateColsRows()\n }],\n /**\n * Grid Row Start / End\n * @see https://tailwindcss.com/docs/grid-row\n */\n 'row-start-end': [{\n row: scaleGridColRowStartAndEnd()\n }],\n /**\n * Grid Row Start\n * @see https://tailwindcss.com/docs/grid-row\n */\n 'row-start': [{\n 'row-start': scaleGridColRowStartOrEnd()\n }],\n /**\n * Grid Row End\n * @see https://tailwindcss.com/docs/grid-row\n */\n 'row-end': [{\n 'row-end': scaleGridColRowStartOrEnd()\n }],\n /**\n * Grid Auto Flow\n * @see https://tailwindcss.com/docs/grid-auto-flow\n */\n 'grid-flow': [{\n 'grid-flow': ['row', 'col', 'dense', 'row-dense', 'col-dense']\n }],\n /**\n * Grid Auto Columns\n * @see https://tailwindcss.com/docs/grid-auto-columns\n */\n 'auto-cols': [{\n 'auto-cols': scaleGridAutoColsRows()\n }],\n /**\n * Grid Auto Rows\n * @see https://tailwindcss.com/docs/grid-auto-rows\n */\n 'auto-rows': [{\n 'auto-rows': scaleGridAutoColsRows()\n }],\n /**\n * Gap\n * @see https://tailwindcss.com/docs/gap\n */\n gap: [{\n gap: scaleUnambiguousSpacing()\n }],\n /**\n * Gap X\n * @see https://tailwindcss.com/docs/gap\n */\n 'gap-x': [{\n 'gap-x': scaleUnambiguousSpacing()\n }],\n /**\n * Gap Y\n * @see https://tailwindcss.com/docs/gap\n */\n 'gap-y': [{\n 'gap-y': scaleUnambiguousSpacing()\n }],\n /**\n * Justify Content\n * @see https://tailwindcss.com/docs/justify-content\n */\n 'justify-content': [{\n justify: [...scaleAlignPrimaryAxis(), 'normal']\n }],\n /**\n * Justify Items\n * @see https://tailwindcss.com/docs/justify-items\n */\n 'justify-items': [{\n 'justify-items': [...scaleAlignSecondaryAxis(), 'normal']\n }],\n /**\n * Justify Self\n * @see https://tailwindcss.com/docs/justify-self\n */\n 'justify-self': [{\n 'justify-self': ['auto', ...scaleAlignSecondaryAxis()]\n }],\n /**\n * Align Content\n * @see https://tailwindcss.com/docs/align-content\n */\n 'align-content': [{\n content: ['normal', ...scaleAlignPrimaryAxis()]\n }],\n /**\n * Align Items\n * @see https://tailwindcss.com/docs/align-items\n */\n 'align-items': [{\n items: [...scaleAlignSecondaryAxis(), {\n baseline: ['', 'last']\n }]\n }],\n /**\n * Align Self\n * @see https://tailwindcss.com/docs/align-self\n */\n 'align-self': [{\n self: ['auto', ...scaleAlignSecondaryAxis(), {\n baseline: ['', 'last']\n }]\n }],\n /**\n * Place Content\n * @see https://tailwindcss.com/docs/place-content\n */\n 'place-content': [{\n 'place-content': scaleAlignPrimaryAxis()\n }],\n /**\n * Place Items\n * @see https://tailwindcss.com/docs/place-items\n */\n 'place-items': [{\n 'place-items': [...scaleAlignSecondaryAxis(), 'baseline']\n }],\n /**\n * Place Self\n * @see https://tailwindcss.com/docs/place-self\n */\n 'place-self': [{\n 'place-self': ['auto', ...scaleAlignSecondaryAxis()]\n }],\n // Spacing\n /**\n * Padding\n * @see https://tailwindcss.com/docs/padding\n */\n p: [{\n p: scaleUnambiguousSpacing()\n }],\n /**\n * Padding Inline\n * @see https://tailwindcss.com/docs/padding\n */\n px: [{\n px: scaleUnambiguousSpacing()\n }],\n /**\n * Padding Block\n * @see https://tailwindcss.com/docs/padding\n */\n py: [{\n py: scaleUnambiguousSpacing()\n }],\n /**\n * Padding Inline Start\n * @see https://tailwindcss.com/docs/padding\n */\n ps: [{\n ps: scaleUnambiguousSpacing()\n }],\n /**\n * Padding Inline End\n * @see https://tailwindcss.com/docs/padding\n */\n pe: [{\n pe: scaleUnambiguousSpacing()\n }],\n /**\n * Padding Block Start\n * @see https://tailwindcss.com/docs/padding\n */\n pbs: [{\n pbs: scaleUnambiguousSpacing()\n }],\n /**\n * Padding Block End\n * @see https://tailwindcss.com/docs/padding\n */\n pbe: [{\n pbe: scaleUnambiguousSpacing()\n }],\n /**\n * Padding Top\n * @see https://tailwindcss.com/docs/padding\n */\n pt: [{\n pt: scaleUnambiguousSpacing()\n }],\n /**\n * Padding Right\n * @see https://tailwindcss.com/docs/padding\n */\n pr: [{\n pr: scaleUnambiguousSpacing()\n }],\n /**\n * Padding Bottom\n * @see https://tailwindcss.com/docs/padding\n */\n pb: [{\n pb: scaleUnambiguousSpacing()\n }],\n /**\n * Padding Left\n * @see https://tailwindcss.com/docs/padding\n */\n pl: [{\n pl: scaleUnambiguousSpacing()\n }],\n /**\n * Margin\n * @see https://tailwindcss.com/docs/margin\n */\n m: [{\n m: scaleMargin()\n }],\n /**\n * Margin Inline\n * @see https://tailwindcss.com/docs/margin\n */\n mx: [{\n mx: scaleMargin()\n }],\n /**\n * Margin Block\n * @see https://tailwindcss.com/docs/margin\n */\n my: [{\n my: scaleMargin()\n }],\n /**\n * Margin Inline Start\n * @see https://tailwindcss.com/docs/margin\n */\n ms: [{\n ms: scaleMargin()\n }],\n /**\n * Margin Inline End\n * @see https://tailwindcss.com/docs/margin\n */\n me: [{\n me: scaleMargin()\n }],\n /**\n * Margin Block Start\n * @see https://tailwindcss.com/docs/margin\n */\n mbs: [{\n mbs: scaleMargin()\n }],\n /**\n * Margin Block End\n * @see https://tailwindcss.com/docs/margin\n */\n mbe: [{\n mbe: scaleMargin()\n }],\n /**\n * Margin Top\n * @see https://tailwindcss.com/docs/margin\n */\n mt: [{\n mt: scaleMargin()\n }],\n /**\n * Margin Right\n * @see https://tailwindcss.com/docs/margin\n */\n mr: [{\n mr: scaleMargin()\n }],\n /**\n * Margin Bottom\n * @see https://tailwindcss.com/docs/margin\n */\n mb: [{\n mb: scaleMargin()\n }],\n /**\n * Margin Left\n * @see https://tailwindcss.com/docs/margin\n */\n ml: [{\n ml: scaleMargin()\n }],\n /**\n * Space Between X\n * @see https://tailwindcss.com/docs/margin#adding-space-between-children\n */\n 'space-x': [{\n 'space-x': scaleUnambiguousSpacing()\n }],\n /**\n * Space Between X Reverse\n * @see https://tailwindcss.com/docs/margin#adding-space-between-children\n */\n 'space-x-reverse': ['space-x-reverse'],\n /**\n * Space Between Y\n * @see https://tailwindcss.com/docs/margin#adding-space-between-children\n */\n 'space-y': [{\n 'space-y': scaleUnambiguousSpacing()\n }],\n /**\n * Space Between Y Reverse\n * @see https://tailwindcss.com/docs/margin#adding-space-between-children\n */\n 'space-y-reverse': ['space-y-reverse'],\n // --------------\n // --- Sizing ---\n // --------------\n /**\n * Size\n * @see https://tailwindcss.com/docs/width#setting-both-width-and-height\n */\n size: [{\n size: scaleSizing()\n }],\n /**\n * Inline Size\n * @see https://tailwindcss.com/docs/width\n */\n 'inline-size': [{\n inline: ['auto', ...scaleSizingInline()]\n }],\n /**\n * Min-Inline Size\n * @see https://tailwindcss.com/docs/min-width\n */\n 'min-inline-size': [{\n 'min-inline': ['auto', ...scaleSizingInline()]\n }],\n /**\n * Max-Inline Size\n * @see https://tailwindcss.com/docs/max-width\n */\n 'max-inline-size': [{\n 'max-inline': ['none', ...scaleSizingInline()]\n }],\n /**\n * Block Size\n * @see https://tailwindcss.com/docs/height\n */\n 'block-size': [{\n block: ['auto', ...scaleSizingBlock()]\n }],\n /**\n * Min-Block Size\n * @see https://tailwindcss.com/docs/min-height\n */\n 'min-block-size': [{\n 'min-block': ['auto', ...scaleSizingBlock()]\n }],\n /**\n * Max-Block Size\n * @see https://tailwindcss.com/docs/max-height\n */\n 'max-block-size': [{\n 'max-block': ['none', ...scaleSizingBlock()]\n }],\n /**\n * Width\n * @see https://tailwindcss.com/docs/width\n */\n w: [{\n w: [themeContainer, 'screen', ...scaleSizing()]\n }],\n /**\n * Min-Width\n * @see https://tailwindcss.com/docs/min-width\n */\n 'min-w': [{\n 'min-w': [themeContainer, 'screen', /** Deprecated. @see https://github.com/tailwindlabs/tailwindcss.com/issues/2027#issuecomment-2620152757 */\n 'none', ...scaleSizing()]\n }],\n /**\n * Max-Width\n * @see https://tailwindcss.com/docs/max-width\n */\n 'max-w': [{\n 'max-w': [themeContainer, 'screen', 'none', /** Deprecated since Tailwind CSS v4.0.0. @see https://github.com/tailwindlabs/tailwindcss.com/issues/2027#issuecomment-2620152757 */\n 'prose', /** Deprecated since Tailwind CSS v4.0.0. @see https://github.com/tailwindlabs/tailwindcss.com/issues/2027#issuecomment-2620152757 */\n {\n screen: [themeBreakpoint]\n }, ...scaleSizing()]\n }],\n /**\n * Height\n * @see https://tailwindcss.com/docs/height\n */\n h: [{\n h: ['screen', 'lh', ...scaleSizing()]\n }],\n /**\n * Min-Height\n * @see https://tailwindcss.com/docs/min-height\n */\n 'min-h': [{\n 'min-h': ['screen', 'lh', 'none', ...scaleSizing()]\n }],\n /**\n * Max-Height\n * @see https://tailwindcss.com/docs/max-height\n */\n 'max-h': [{\n 'max-h': ['screen', 'lh', ...scaleSizing()]\n }],\n // ------------------\n // --- Typography ---\n // ------------------\n /**\n * Font Size\n * @see https://tailwindcss.com/docs/font-size\n */\n 'font-size': [{\n text: ['base', themeText, isArbitraryVariableLength, isArbitraryLength]\n }],\n /**\n * Font Smoothing\n * @see https://tailwindcss.com/docs/font-smoothing\n */\n 'font-smoothing': ['antialiased', 'subpixel-antialiased'],\n /**\n * Font Style\n * @see https://tailwindcss.com/docs/font-style\n */\n 'font-style': ['italic', 'not-italic'],\n /**\n * Font Weight\n * @see https://tailwindcss.com/docs/font-weight\n */\n 'font-weight': [{\n font: [themeFontWeight, isArbitraryVariableWeight, isArbitraryWeight]\n }],\n /**\n * Font Stretch\n * @see https://tailwindcss.com/docs/font-stretch\n */\n 'font-stretch': [{\n 'font-stretch': ['ultra-condensed', 'extra-condensed', 'condensed', 'semi-condensed', 'normal', 'semi-expanded', 'expanded', 'extra-expanded', 'ultra-expanded', isPercent, isArbitraryValue]\n }],\n /**\n * Font Family\n * @see https://tailwindcss.com/docs/font-family\n */\n 'font-family': [{\n font: [isArbitraryVariableFamilyName, isArbitraryFamilyName, themeFont]\n }],\n /**\n * Font Feature Settings\n * @see https://tailwindcss.com/docs/font-feature-settings\n */\n 'font-features': [{\n 'font-features': [isArbitraryValue]\n }],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-normal': ['normal-nums'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-ordinal': ['ordinal'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-slashed-zero': ['slashed-zero'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-figure': ['lining-nums', 'oldstyle-nums'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-spacing': ['proportional-nums', 'tabular-nums'],\n /**\n * Font Variant Numeric\n * @see https://tailwindcss.com/docs/font-variant-numeric\n */\n 'fvn-fraction': ['diagonal-fractions', 'stacked-fractions'],\n /**\n * Letter Spacing\n * @see https://tailwindcss.com/docs/letter-spacing\n */\n tracking: [{\n tracking: [themeTracking, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Line Clamp\n * @see https://tailwindcss.com/docs/line-clamp\n */\n 'line-clamp': [{\n 'line-clamp': [isNumber, 'none', isArbitraryVariable, isArbitraryNumber]\n }],\n /**\n * Line Height\n * @see https://tailwindcss.com/docs/line-height\n */\n leading: [{\n leading: [/** Deprecated since Tailwind CSS v4.0.0. @see https://github.com/tailwindlabs/tailwindcss.com/issues/2027#issuecomment-2620152757 */\n themeLeading, ...scaleUnambiguousSpacing()]\n }],\n /**\n * List Style Image\n * @see https://tailwindcss.com/docs/list-style-image\n */\n 'list-image': [{\n 'list-image': ['none', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * List Style Position\n * @see https://tailwindcss.com/docs/list-style-position\n */\n 'list-style-position': [{\n list: ['inside', 'outside']\n }],\n /**\n * List Style Type\n * @see https://tailwindcss.com/docs/list-style-type\n */\n 'list-style-type': [{\n list: ['disc', 'decimal', 'none', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Text Alignment\n * @see https://tailwindcss.com/docs/text-align\n */\n 'text-alignment': [{\n text: ['left', 'center', 'right', 'justify', 'start', 'end']\n }],\n /**\n * Placeholder Color\n * @deprecated since Tailwind CSS v3.0.0\n * @see https://v3.tailwindcss.com/docs/placeholder-color\n */\n 'placeholder-color': [{\n placeholder: scaleColor()\n }],\n /**\n * Text Color\n * @see https://tailwindcss.com/docs/text-color\n */\n 'text-color': [{\n text: scaleColor()\n }],\n /**\n * Text Decoration\n * @see https://tailwindcss.com/docs/text-decoration\n */\n 'text-decoration': ['underline', 'overline', 'line-through', 'no-underline'],\n /**\n * Text Decoration Style\n * @see https://tailwindcss.com/docs/text-decoration-style\n */\n 'text-decoration-style': [{\n decoration: [...scaleLineStyle(), 'wavy']\n }],\n /**\n * Text Decoration Thickness\n * @see https://tailwindcss.com/docs/text-decoration-thickness\n */\n 'text-decoration-thickness': [{\n decoration: [isNumber, 'from-font', 'auto', isArbitraryVariable, isArbitraryLength]\n }],\n /**\n * Text Decoration Color\n * @see https://tailwindcss.com/docs/text-decoration-color\n */\n 'text-decoration-color': [{\n decoration: scaleColor()\n }],\n /**\n * Text Underline Offset\n * @see https://tailwindcss.com/docs/text-underline-offset\n */\n 'underline-offset': [{\n 'underline-offset': [isNumber, 'auto', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Text Transform\n * @see https://tailwindcss.com/docs/text-transform\n */\n 'text-transform': ['uppercase', 'lowercase', 'capitalize', 'normal-case'],\n /**\n * Text Overflow\n * @see https://tailwindcss.com/docs/text-overflow\n */\n 'text-overflow': ['truncate', 'text-ellipsis', 'text-clip'],\n /**\n * Text Wrap\n * @see https://tailwindcss.com/docs/text-wrap\n */\n 'text-wrap': [{\n text: ['wrap', 'nowrap', 'balance', 'pretty']\n }],\n /**\n * Text Indent\n * @see https://tailwindcss.com/docs/text-indent\n */\n indent: [{\n indent: scaleUnambiguousSpacing()\n }],\n /**\n * Vertical Alignment\n * @see https://tailwindcss.com/docs/vertical-align\n */\n 'vertical-align': [{\n align: ['baseline', 'top', 'middle', 'bottom', 'text-top', 'text-bottom', 'sub', 'super', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Whitespace\n * @see https://tailwindcss.com/docs/whitespace\n */\n whitespace: [{\n whitespace: ['normal', 'nowrap', 'pre', 'pre-line', 'pre-wrap', 'break-spaces']\n }],\n /**\n * Word Break\n * @see https://tailwindcss.com/docs/word-break\n */\n break: [{\n break: ['normal', 'words', 'all', 'keep']\n }],\n /**\n * Overflow Wrap\n * @see https://tailwindcss.com/docs/overflow-wrap\n */\n wrap: [{\n wrap: ['break-word', 'anywhere', 'normal']\n }],\n /**\n * Hyphens\n * @see https://tailwindcss.com/docs/hyphens\n */\n hyphens: [{\n hyphens: ['none', 'manual', 'auto']\n }],\n /**\n * Content\n * @see https://tailwindcss.com/docs/content\n */\n content: [{\n content: ['none', isArbitraryVariable, isArbitraryValue]\n }],\n // -------------------\n // --- Backgrounds ---\n // -------------------\n /**\n * Background Attachment\n * @see https://tailwindcss.com/docs/background-attachment\n */\n 'bg-attachment': [{\n bg: ['fixed', 'local', 'scroll']\n }],\n /**\n * Background Clip\n * @see https://tailwindcss.com/docs/background-clip\n */\n 'bg-clip': [{\n 'bg-clip': ['border', 'padding', 'content', 'text']\n }],\n /**\n * Background Origin\n * @see https://tailwindcss.com/docs/background-origin\n */\n 'bg-origin': [{\n 'bg-origin': ['border', 'padding', 'content']\n }],\n /**\n * Background Position\n * @see https://tailwindcss.com/docs/background-position\n */\n 'bg-position': [{\n bg: scaleBgPosition()\n }],\n /**\n * Background Repeat\n * @see https://tailwindcss.com/docs/background-repeat\n */\n 'bg-repeat': [{\n bg: scaleBgRepeat()\n }],\n /**\n * Background Size\n * @see https://tailwindcss.com/docs/background-size\n */\n 'bg-size': [{\n bg: scaleBgSize()\n }],\n /**\n * Background Image\n * @see https://tailwindcss.com/docs/background-image\n */\n 'bg-image': [{\n bg: ['none', {\n linear: [{\n to: ['t', 'tr', 'r', 'br', 'b', 'bl', 'l', 'tl']\n }, isInteger, isArbitraryVariable, isArbitraryValue],\n radial: ['', isArbitraryVariable, isArbitraryValue],\n conic: [isInteger, isArbitraryVariable, isArbitraryValue]\n }, isArbitraryVariableImage, isArbitraryImage]\n }],\n /**\n * Background Color\n * @see https://tailwindcss.com/docs/background-color\n */\n 'bg-color': [{\n bg: scaleColor()\n }],\n /**\n * Gradient Color Stops From Position\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-from-pos': [{\n from: scaleGradientStopPosition()\n }],\n /**\n * Gradient Color Stops Via Position\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-via-pos': [{\n via: scaleGradientStopPosition()\n }],\n /**\n * Gradient Color Stops To Position\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-to-pos': [{\n to: scaleGradientStopPosition()\n }],\n /**\n * Gradient Color Stops From\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-from': [{\n from: scaleColor()\n }],\n /**\n * Gradient Color Stops Via\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-via': [{\n via: scaleColor()\n }],\n /**\n * Gradient Color Stops To\n * @see https://tailwindcss.com/docs/gradient-color-stops\n */\n 'gradient-to': [{\n to: scaleColor()\n }],\n // ---------------\n // --- Borders ---\n // ---------------\n /**\n * Border Radius\n * @see https://tailwindcss.com/docs/border-radius\n */\n rounded: [{\n rounded: scaleRadius()\n }],\n /**\n * Border Radius Start\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-s': [{\n 'rounded-s': scaleRadius()\n }],\n /**\n * Border Radius End\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-e': [{\n 'rounded-e': scaleRadius()\n }],\n /**\n * Border Radius Top\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-t': [{\n 'rounded-t': scaleRadius()\n }],\n /**\n * Border Radius Right\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-r': [{\n 'rounded-r': scaleRadius()\n }],\n /**\n * Border Radius Bottom\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-b': [{\n 'rounded-b': scaleRadius()\n }],\n /**\n * Border Radius Left\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-l': [{\n 'rounded-l': scaleRadius()\n }],\n /**\n * Border Radius Start Start\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-ss': [{\n 'rounded-ss': scaleRadius()\n }],\n /**\n * Border Radius Start End\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-se': [{\n 'rounded-se': scaleRadius()\n }],\n /**\n * Border Radius End End\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-ee': [{\n 'rounded-ee': scaleRadius()\n }],\n /**\n * Border Radius End Start\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-es': [{\n 'rounded-es': scaleRadius()\n }],\n /**\n * Border Radius Top Left\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-tl': [{\n 'rounded-tl': scaleRadius()\n }],\n /**\n * Border Radius Top Right\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-tr': [{\n 'rounded-tr': scaleRadius()\n }],\n /**\n * Border Radius Bottom Right\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-br': [{\n 'rounded-br': scaleRadius()\n }],\n /**\n * Border Radius Bottom Left\n * @see https://tailwindcss.com/docs/border-radius\n */\n 'rounded-bl': [{\n 'rounded-bl': scaleRadius()\n }],\n /**\n * Border Width\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w': [{\n border: scaleBorderWidth()\n }],\n /**\n * Border Width Inline\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-x': [{\n 'border-x': scaleBorderWidth()\n }],\n /**\n * Border Width Block\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-y': [{\n 'border-y': scaleBorderWidth()\n }],\n /**\n * Border Width Inline Start\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-s': [{\n 'border-s': scaleBorderWidth()\n }],\n /**\n * Border Width Inline End\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-e': [{\n 'border-e': scaleBorderWidth()\n }],\n /**\n * Border Width Block Start\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-bs': [{\n 'border-bs': scaleBorderWidth()\n }],\n /**\n * Border Width Block End\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-be': [{\n 'border-be': scaleBorderWidth()\n }],\n /**\n * Border Width Top\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-t': [{\n 'border-t': scaleBorderWidth()\n }],\n /**\n * Border Width Right\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-r': [{\n 'border-r': scaleBorderWidth()\n }],\n /**\n * Border Width Bottom\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-b': [{\n 'border-b': scaleBorderWidth()\n }],\n /**\n * Border Width Left\n * @see https://tailwindcss.com/docs/border-width\n */\n 'border-w-l': [{\n 'border-l': scaleBorderWidth()\n }],\n /**\n * Divide Width X\n * @see https://tailwindcss.com/docs/border-width#between-children\n */\n 'divide-x': [{\n 'divide-x': scaleBorderWidth()\n }],\n /**\n * Divide Width X Reverse\n * @see https://tailwindcss.com/docs/border-width#between-children\n */\n 'divide-x-reverse': ['divide-x-reverse'],\n /**\n * Divide Width Y\n * @see https://tailwindcss.com/docs/border-width#between-children\n */\n 'divide-y': [{\n 'divide-y': scaleBorderWidth()\n }],\n /**\n * Divide Width Y Reverse\n * @see https://tailwindcss.com/docs/border-width#between-children\n */\n 'divide-y-reverse': ['divide-y-reverse'],\n /**\n * Border Style\n * @see https://tailwindcss.com/docs/border-style\n */\n 'border-style': [{\n border: [...scaleLineStyle(), 'hidden', 'none']\n }],\n /**\n * Divide Style\n * @see https://tailwindcss.com/docs/border-style#setting-the-divider-style\n */\n 'divide-style': [{\n divide: [...scaleLineStyle(), 'hidden', 'none']\n }],\n /**\n * Border Color\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color': [{\n border: scaleColor()\n }],\n /**\n * Border Color Inline\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-x': [{\n 'border-x': scaleColor()\n }],\n /**\n * Border Color Block\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-y': [{\n 'border-y': scaleColor()\n }],\n /**\n * Border Color Inline Start\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-s': [{\n 'border-s': scaleColor()\n }],\n /**\n * Border Color Inline End\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-e': [{\n 'border-e': scaleColor()\n }],\n /**\n * Border Color Block Start\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-bs': [{\n 'border-bs': scaleColor()\n }],\n /**\n * Border Color Block End\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-be': [{\n 'border-be': scaleColor()\n }],\n /**\n * Border Color Top\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-t': [{\n 'border-t': scaleColor()\n }],\n /**\n * Border Color Right\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-r': [{\n 'border-r': scaleColor()\n }],\n /**\n * Border Color Bottom\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-b': [{\n 'border-b': scaleColor()\n }],\n /**\n * Border Color Left\n * @see https://tailwindcss.com/docs/border-color\n */\n 'border-color-l': [{\n 'border-l': scaleColor()\n }],\n /**\n * Divide Color\n * @see https://tailwindcss.com/docs/divide-color\n */\n 'divide-color': [{\n divide: scaleColor()\n }],\n /**\n * Outline Style\n * @see https://tailwindcss.com/docs/outline-style\n */\n 'outline-style': [{\n outline: [...scaleLineStyle(), 'none', 'hidden']\n }],\n /**\n * Outline Offset\n * @see https://tailwindcss.com/docs/outline-offset\n */\n 'outline-offset': [{\n 'outline-offset': [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Outline Width\n * @see https://tailwindcss.com/docs/outline-width\n */\n 'outline-w': [{\n outline: ['', isNumber, isArbitraryVariableLength, isArbitraryLength]\n }],\n /**\n * Outline Color\n * @see https://tailwindcss.com/docs/outline-color\n */\n 'outline-color': [{\n outline: scaleColor()\n }],\n // ---------------\n // --- Effects ---\n // ---------------\n /**\n * Box Shadow\n * @see https://tailwindcss.com/docs/box-shadow\n */\n shadow: [{\n shadow: [\n // Deprecated since Tailwind CSS v4.0.0\n '', 'none', themeShadow, isArbitraryVariableShadow, isArbitraryShadow]\n }],\n /**\n * Box Shadow Color\n * @see https://tailwindcss.com/docs/box-shadow#setting-the-shadow-color\n */\n 'shadow-color': [{\n shadow: scaleColor()\n }],\n /**\n * Inset Box Shadow\n * @see https://tailwindcss.com/docs/box-shadow#adding-an-inset-shadow\n */\n 'inset-shadow': [{\n 'inset-shadow': ['none', themeInsetShadow, isArbitraryVariableShadow, isArbitraryShadow]\n }],\n /**\n * Inset Box Shadow Color\n * @see https://tailwindcss.com/docs/box-shadow#setting-the-inset-shadow-color\n */\n 'inset-shadow-color': [{\n 'inset-shadow': scaleColor()\n }],\n /**\n * Ring Width\n * @see https://tailwindcss.com/docs/box-shadow#adding-a-ring\n */\n 'ring-w': [{\n ring: scaleBorderWidth()\n }],\n /**\n * Ring Width Inset\n * @see https://v3.tailwindcss.com/docs/ring-width#inset-rings\n * @deprecated since Tailwind CSS v4.0.0\n * @see https://github.com/tailwindlabs/tailwindcss/blob/v4.0.0/packages/tailwindcss/src/utilities.ts#L4158\n */\n 'ring-w-inset': ['ring-inset'],\n /**\n * Ring Color\n * @see https://tailwindcss.com/docs/box-shadow#setting-the-ring-color\n */\n 'ring-color': [{\n ring: scaleColor()\n }],\n /**\n * Ring Offset Width\n * @see https://v3.tailwindcss.com/docs/ring-offset-width\n * @deprecated since Tailwind CSS v4.0.0\n * @see https://github.com/tailwindlabs/tailwindcss/blob/v4.0.0/packages/tailwindcss/src/utilities.ts#L4158\n */\n 'ring-offset-w': [{\n 'ring-offset': [isNumber, isArbitraryLength]\n }],\n /**\n * Ring Offset Color\n * @see https://v3.tailwindcss.com/docs/ring-offset-color\n * @deprecated since Tailwind CSS v4.0.0\n * @see https://github.com/tailwindlabs/tailwindcss/blob/v4.0.0/packages/tailwindcss/src/utilities.ts#L4158\n */\n 'ring-offset-color': [{\n 'ring-offset': scaleColor()\n }],\n /**\n * Inset Ring Width\n * @see https://tailwindcss.com/docs/box-shadow#adding-an-inset-ring\n */\n 'inset-ring-w': [{\n 'inset-ring': scaleBorderWidth()\n }],\n /**\n * Inset Ring Color\n * @see https://tailwindcss.com/docs/box-shadow#setting-the-inset-ring-color\n */\n 'inset-ring-color': [{\n 'inset-ring': scaleColor()\n }],\n /**\n * Text Shadow\n * @see https://tailwindcss.com/docs/text-shadow\n */\n 'text-shadow': [{\n 'text-shadow': ['none', themeTextShadow, isArbitraryVariableShadow, isArbitraryShadow]\n }],\n /**\n * Text Shadow Color\n * @see https://tailwindcss.com/docs/text-shadow#setting-the-shadow-color\n */\n 'text-shadow-color': [{\n 'text-shadow': scaleColor()\n }],\n /**\n * Opacity\n * @see https://tailwindcss.com/docs/opacity\n */\n opacity: [{\n opacity: [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Mix Blend Mode\n * @see https://tailwindcss.com/docs/mix-blend-mode\n */\n 'mix-blend': [{\n 'mix-blend': [...scaleBlendMode(), 'plus-darker', 'plus-lighter']\n }],\n /**\n * Background Blend Mode\n * @see https://tailwindcss.com/docs/background-blend-mode\n */\n 'bg-blend': [{\n 'bg-blend': scaleBlendMode()\n }],\n /**\n * Mask Clip\n * @see https://tailwindcss.com/docs/mask-clip\n */\n 'mask-clip': [{\n 'mask-clip': ['border', 'padding', 'content', 'fill', 'stroke', 'view']\n }, 'mask-no-clip'],\n /**\n * Mask Composite\n * @see https://tailwindcss.com/docs/mask-composite\n */\n 'mask-composite': [{\n mask: ['add', 'subtract', 'intersect', 'exclude']\n }],\n /**\n * Mask Image\n * @see https://tailwindcss.com/docs/mask-image\n */\n 'mask-image-linear-pos': [{\n 'mask-linear': [isNumber]\n }],\n 'mask-image-linear-from-pos': [{\n 'mask-linear-from': scaleMaskImagePosition()\n }],\n 'mask-image-linear-to-pos': [{\n 'mask-linear-to': scaleMaskImagePosition()\n }],\n 'mask-image-linear-from-color': [{\n 'mask-linear-from': scaleColor()\n }],\n 'mask-image-linear-to-color': [{\n 'mask-linear-to': scaleColor()\n }],\n 'mask-image-t-from-pos': [{\n 'mask-t-from': scaleMaskImagePosition()\n }],\n 'mask-image-t-to-pos': [{\n 'mask-t-to': scaleMaskImagePosition()\n }],\n 'mask-image-t-from-color': [{\n 'mask-t-from': scaleColor()\n }],\n 'mask-image-t-to-color': [{\n 'mask-t-to': scaleColor()\n }],\n 'mask-image-r-from-pos': [{\n 'mask-r-from': scaleMaskImagePosition()\n }],\n 'mask-image-r-to-pos': [{\n 'mask-r-to': scaleMaskImagePosition()\n }],\n 'mask-image-r-from-color': [{\n 'mask-r-from': scaleColor()\n }],\n 'mask-image-r-to-color': [{\n 'mask-r-to': scaleColor()\n }],\n 'mask-image-b-from-pos': [{\n 'mask-b-from': scaleMaskImagePosition()\n }],\n 'mask-image-b-to-pos': [{\n 'mask-b-to': scaleMaskImagePosition()\n }],\n 'mask-image-b-from-color': [{\n 'mask-b-from': scaleColor()\n }],\n 'mask-image-b-to-color': [{\n 'mask-b-to': scaleColor()\n }],\n 'mask-image-l-from-pos': [{\n 'mask-l-from': scaleMaskImagePosition()\n }],\n 'mask-image-l-to-pos': [{\n 'mask-l-to': scaleMaskImagePosition()\n }],\n 'mask-image-l-from-color': [{\n 'mask-l-from': scaleColor()\n }],\n 'mask-image-l-to-color': [{\n 'mask-l-to': scaleColor()\n }],\n 'mask-image-x-from-pos': [{\n 'mask-x-from': scaleMaskImagePosition()\n }],\n 'mask-image-x-to-pos': [{\n 'mask-x-to': scaleMaskImagePosition()\n }],\n 'mask-image-x-from-color': [{\n 'mask-x-from': scaleColor()\n }],\n 'mask-image-x-to-color': [{\n 'mask-x-to': scaleColor()\n }],\n 'mask-image-y-from-pos': [{\n 'mask-y-from': scaleMaskImagePosition()\n }],\n 'mask-image-y-to-pos': [{\n 'mask-y-to': scaleMaskImagePosition()\n }],\n 'mask-image-y-from-color': [{\n 'mask-y-from': scaleColor()\n }],\n 'mask-image-y-to-color': [{\n 'mask-y-to': scaleColor()\n }],\n 'mask-image-radial': [{\n 'mask-radial': [isArbitraryVariable, isArbitraryValue]\n }],\n 'mask-image-radial-from-pos': [{\n 'mask-radial-from': scaleMaskImagePosition()\n }],\n 'mask-image-radial-to-pos': [{\n 'mask-radial-to': scaleMaskImagePosition()\n }],\n 'mask-image-radial-from-color': [{\n 'mask-radial-from': scaleColor()\n }],\n 'mask-image-radial-to-color': [{\n 'mask-radial-to': scaleColor()\n }],\n 'mask-image-radial-shape': [{\n 'mask-radial': ['circle', 'ellipse']\n }],\n 'mask-image-radial-size': [{\n 'mask-radial': [{\n closest: ['side', 'corner'],\n farthest: ['side', 'corner']\n }]\n }],\n 'mask-image-radial-pos': [{\n 'mask-radial-at': scalePosition()\n }],\n 'mask-image-conic-pos': [{\n 'mask-conic': [isNumber]\n }],\n 'mask-image-conic-from-pos': [{\n 'mask-conic-from': scaleMaskImagePosition()\n }],\n 'mask-image-conic-to-pos': [{\n 'mask-conic-to': scaleMaskImagePosition()\n }],\n 'mask-image-conic-from-color': [{\n 'mask-conic-from': scaleColor()\n }],\n 'mask-image-conic-to-color': [{\n 'mask-conic-to': scaleColor()\n }],\n /**\n * Mask Mode\n * @see https://tailwindcss.com/docs/mask-mode\n */\n 'mask-mode': [{\n mask: ['alpha', 'luminance', 'match']\n }],\n /**\n * Mask Origin\n * @see https://tailwindcss.com/docs/mask-origin\n */\n 'mask-origin': [{\n 'mask-origin': ['border', 'padding', 'content', 'fill', 'stroke', 'view']\n }],\n /**\n * Mask Position\n * @see https://tailwindcss.com/docs/mask-position\n */\n 'mask-position': [{\n mask: scaleBgPosition()\n }],\n /**\n * Mask Repeat\n * @see https://tailwindcss.com/docs/mask-repeat\n */\n 'mask-repeat': [{\n mask: scaleBgRepeat()\n }],\n /**\n * Mask Size\n * @see https://tailwindcss.com/docs/mask-size\n */\n 'mask-size': [{\n mask: scaleBgSize()\n }],\n /**\n * Mask Type\n * @see https://tailwindcss.com/docs/mask-type\n */\n 'mask-type': [{\n 'mask-type': ['alpha', 'luminance']\n }],\n /**\n * Mask Image\n * @see https://tailwindcss.com/docs/mask-image\n */\n 'mask-image': [{\n mask: ['none', isArbitraryVariable, isArbitraryValue]\n }],\n // ---------------\n // --- Filters ---\n // ---------------\n /**\n * Filter\n * @see https://tailwindcss.com/docs/filter\n */\n filter: [{\n filter: [\n // Deprecated since Tailwind CSS v3.0.0\n '', 'none', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Blur\n * @see https://tailwindcss.com/docs/blur\n */\n blur: [{\n blur: scaleBlur()\n }],\n /**\n * Brightness\n * @see https://tailwindcss.com/docs/brightness\n */\n brightness: [{\n brightness: [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Contrast\n * @see https://tailwindcss.com/docs/contrast\n */\n contrast: [{\n contrast: [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Drop Shadow\n * @see https://tailwindcss.com/docs/drop-shadow\n */\n 'drop-shadow': [{\n 'drop-shadow': [\n // Deprecated since Tailwind CSS v4.0.0\n '', 'none', themeDropShadow, isArbitraryVariableShadow, isArbitraryShadow]\n }],\n /**\n * Drop Shadow Color\n * @see https://tailwindcss.com/docs/filter-drop-shadow#setting-the-shadow-color\n */\n 'drop-shadow-color': [{\n 'drop-shadow': scaleColor()\n }],\n /**\n * Grayscale\n * @see https://tailwindcss.com/docs/grayscale\n */\n grayscale: [{\n grayscale: ['', isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Hue Rotate\n * @see https://tailwindcss.com/docs/hue-rotate\n */\n 'hue-rotate': [{\n 'hue-rotate': [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Invert\n * @see https://tailwindcss.com/docs/invert\n */\n invert: [{\n invert: ['', isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Saturate\n * @see https://tailwindcss.com/docs/saturate\n */\n saturate: [{\n saturate: [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Sepia\n * @see https://tailwindcss.com/docs/sepia\n */\n sepia: [{\n sepia: ['', isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Filter\n * @see https://tailwindcss.com/docs/backdrop-filter\n */\n 'backdrop-filter': [{\n 'backdrop-filter': [\n // Deprecated since Tailwind CSS v3.0.0\n '', 'none', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Blur\n * @see https://tailwindcss.com/docs/backdrop-blur\n */\n 'backdrop-blur': [{\n 'backdrop-blur': scaleBlur()\n }],\n /**\n * Backdrop Brightness\n * @see https://tailwindcss.com/docs/backdrop-brightness\n */\n 'backdrop-brightness': [{\n 'backdrop-brightness': [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Contrast\n * @see https://tailwindcss.com/docs/backdrop-contrast\n */\n 'backdrop-contrast': [{\n 'backdrop-contrast': [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Grayscale\n * @see https://tailwindcss.com/docs/backdrop-grayscale\n */\n 'backdrop-grayscale': [{\n 'backdrop-grayscale': ['', isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Hue Rotate\n * @see https://tailwindcss.com/docs/backdrop-hue-rotate\n */\n 'backdrop-hue-rotate': [{\n 'backdrop-hue-rotate': [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Invert\n * @see https://tailwindcss.com/docs/backdrop-invert\n */\n 'backdrop-invert': [{\n 'backdrop-invert': ['', isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Opacity\n * @see https://tailwindcss.com/docs/backdrop-opacity\n */\n 'backdrop-opacity': [{\n 'backdrop-opacity': [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Saturate\n * @see https://tailwindcss.com/docs/backdrop-saturate\n */\n 'backdrop-saturate': [{\n 'backdrop-saturate': [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Backdrop Sepia\n * @see https://tailwindcss.com/docs/backdrop-sepia\n */\n 'backdrop-sepia': [{\n 'backdrop-sepia': ['', isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n // --------------\n // --- Tables ---\n // --------------\n /**\n * Border Collapse\n * @see https://tailwindcss.com/docs/border-collapse\n */\n 'border-collapse': [{\n border: ['collapse', 'separate']\n }],\n /**\n * Border Spacing\n * @see https://tailwindcss.com/docs/border-spacing\n */\n 'border-spacing': [{\n 'border-spacing': scaleUnambiguousSpacing()\n }],\n /**\n * Border Spacing X\n * @see https://tailwindcss.com/docs/border-spacing\n */\n 'border-spacing-x': [{\n 'border-spacing-x': scaleUnambiguousSpacing()\n }],\n /**\n * Border Spacing Y\n * @see https://tailwindcss.com/docs/border-spacing\n */\n 'border-spacing-y': [{\n 'border-spacing-y': scaleUnambiguousSpacing()\n }],\n /**\n * Table Layout\n * @see https://tailwindcss.com/docs/table-layout\n */\n 'table-layout': [{\n table: ['auto', 'fixed']\n }],\n /**\n * Caption Side\n * @see https://tailwindcss.com/docs/caption-side\n */\n caption: [{\n caption: ['top', 'bottom']\n }],\n // ---------------------------------\n // --- Transitions and Animation ---\n // ---------------------------------\n /**\n * Transition Property\n * @see https://tailwindcss.com/docs/transition-property\n */\n transition: [{\n transition: ['', 'all', 'colors', 'opacity', 'shadow', 'transform', 'none', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Transition Behavior\n * @see https://tailwindcss.com/docs/transition-behavior\n */\n 'transition-behavior': [{\n transition: ['normal', 'discrete']\n }],\n /**\n * Transition Duration\n * @see https://tailwindcss.com/docs/transition-duration\n */\n duration: [{\n duration: [isNumber, 'initial', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Transition Timing Function\n * @see https://tailwindcss.com/docs/transition-timing-function\n */\n ease: [{\n ease: ['linear', 'initial', themeEase, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Transition Delay\n * @see https://tailwindcss.com/docs/transition-delay\n */\n delay: [{\n delay: [isNumber, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Animation\n * @see https://tailwindcss.com/docs/animation\n */\n animate: [{\n animate: ['none', themeAnimate, isArbitraryVariable, isArbitraryValue]\n }],\n // ------------------\n // --- Transforms ---\n // ------------------\n /**\n * Backface Visibility\n * @see https://tailwindcss.com/docs/backface-visibility\n */\n backface: [{\n backface: ['hidden', 'visible']\n }],\n /**\n * Perspective\n * @see https://tailwindcss.com/docs/perspective\n */\n perspective: [{\n perspective: [themePerspective, isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Perspective Origin\n * @see https://tailwindcss.com/docs/perspective-origin\n */\n 'perspective-origin': [{\n 'perspective-origin': scalePositionWithArbitrary()\n }],\n /**\n * Rotate\n * @see https://tailwindcss.com/docs/rotate\n */\n rotate: [{\n rotate: scaleRotate()\n }],\n /**\n * Rotate X\n * @see https://tailwindcss.com/docs/rotate\n */\n 'rotate-x': [{\n 'rotate-x': scaleRotate()\n }],\n /**\n * Rotate Y\n * @see https://tailwindcss.com/docs/rotate\n */\n 'rotate-y': [{\n 'rotate-y': scaleRotate()\n }],\n /**\n * Rotate Z\n * @see https://tailwindcss.com/docs/rotate\n */\n 'rotate-z': [{\n 'rotate-z': scaleRotate()\n }],\n /**\n * Scale\n * @see https://tailwindcss.com/docs/scale\n */\n scale: [{\n scale: scaleScale()\n }],\n /**\n * Scale X\n * @see https://tailwindcss.com/docs/scale\n */\n 'scale-x': [{\n 'scale-x': scaleScale()\n }],\n /**\n * Scale Y\n * @see https://tailwindcss.com/docs/scale\n */\n 'scale-y': [{\n 'scale-y': scaleScale()\n }],\n /**\n * Scale Z\n * @see https://tailwindcss.com/docs/scale\n */\n 'scale-z': [{\n 'scale-z': scaleScale()\n }],\n /**\n * Scale 3D\n * @see https://tailwindcss.com/docs/scale\n */\n 'scale-3d': ['scale-3d'],\n /**\n * Skew\n * @see https://tailwindcss.com/docs/skew\n */\n skew: [{\n skew: scaleSkew()\n }],\n /**\n * Skew X\n * @see https://tailwindcss.com/docs/skew\n */\n 'skew-x': [{\n 'skew-x': scaleSkew()\n }],\n /**\n * Skew Y\n * @see https://tailwindcss.com/docs/skew\n */\n 'skew-y': [{\n 'skew-y': scaleSkew()\n }],\n /**\n * Transform\n * @see https://tailwindcss.com/docs/transform\n */\n transform: [{\n transform: [isArbitraryVariable, isArbitraryValue, '', 'none', 'gpu', 'cpu']\n }],\n /**\n * Transform Origin\n * @see https://tailwindcss.com/docs/transform-origin\n */\n 'transform-origin': [{\n origin: scalePositionWithArbitrary()\n }],\n /**\n * Transform Style\n * @see https://tailwindcss.com/docs/transform-style\n */\n 'transform-style': [{\n transform: ['3d', 'flat']\n }],\n /**\n * Translate\n * @see https://tailwindcss.com/docs/translate\n */\n translate: [{\n translate: scaleTranslate()\n }],\n /**\n * Translate X\n * @see https://tailwindcss.com/docs/translate\n */\n 'translate-x': [{\n 'translate-x': scaleTranslate()\n }],\n /**\n * Translate Y\n * @see https://tailwindcss.com/docs/translate\n */\n 'translate-y': [{\n 'translate-y': scaleTranslate()\n }],\n /**\n * Translate Z\n * @see https://tailwindcss.com/docs/translate\n */\n 'translate-z': [{\n 'translate-z': scaleTranslate()\n }],\n /**\n * Translate None\n * @see https://tailwindcss.com/docs/translate\n */\n 'translate-none': ['translate-none'],\n // ---------------------\n // --- Interactivity ---\n // ---------------------\n /**\n * Accent Color\n * @see https://tailwindcss.com/docs/accent-color\n */\n accent: [{\n accent: scaleColor()\n }],\n /**\n * Appearance\n * @see https://tailwindcss.com/docs/appearance\n */\n appearance: [{\n appearance: ['none', 'auto']\n }],\n /**\n * Caret Color\n * @see https://tailwindcss.com/docs/just-in-time-mode#caret-color-utilities\n */\n 'caret-color': [{\n caret: scaleColor()\n }],\n /**\n * Color Scheme\n * @see https://tailwindcss.com/docs/color-scheme\n */\n 'color-scheme': [{\n scheme: ['normal', 'dark', 'light', 'light-dark', 'only-dark', 'only-light']\n }],\n /**\n * Cursor\n * @see https://tailwindcss.com/docs/cursor\n */\n cursor: [{\n cursor: ['auto', 'default', 'pointer', 'wait', 'text', 'move', 'help', 'not-allowed', 'none', 'context-menu', 'progress', 'cell', 'crosshair', 'vertical-text', 'alias', 'copy', 'no-drop', 'grab', 'grabbing', 'all-scroll', 'col-resize', 'row-resize', 'n-resize', 'e-resize', 's-resize', 'w-resize', 'ne-resize', 'nw-resize', 'se-resize', 'sw-resize', 'ew-resize', 'ns-resize', 'nesw-resize', 'nwse-resize', 'zoom-in', 'zoom-out', isArbitraryVariable, isArbitraryValue]\n }],\n /**\n * Field Sizing\n * @see https://tailwindcss.com/docs/field-sizing\n */\n 'field-sizing': [{\n 'field-sizing': ['fixed', 'content']\n }],\n /**\n * Pointer Events\n * @see https://tailwindcss.com/docs/pointer-events\n */\n 'pointer-events': [{\n 'pointer-events': ['auto', 'none']\n }],\n /**\n * Resize\n * @see https://tailwindcss.com/docs/resize\n */\n resize: [{\n resize: ['none', '', 'y', 'x']\n }],\n /**\n * Scroll Behavior\n * @see https://tailwindcss.com/docs/scroll-behavior\n */\n 'scroll-behavior': [{\n scroll: ['auto', 'smooth']\n }],\n /**\n * Scroll Margin\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-m': [{\n 'scroll-m': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin Inline\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-mx': [{\n 'scroll-mx': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin Block\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-my': [{\n 'scroll-my': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin Inline Start\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-ms': [{\n 'scroll-ms': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin Inline End\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-me': [{\n 'scroll-me': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin Block Start\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-mbs': [{\n 'scroll-mbs': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin Block End\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-mbe': [{\n 'scroll-mbe': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin Top\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-mt': [{\n 'scroll-mt': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin Right\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-mr': [{\n 'scroll-mr': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin Bottom\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-mb': [{\n 'scroll-mb': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Margin Left\n * @see https://tailwindcss.com/docs/scroll-margin\n */\n 'scroll-ml': [{\n 'scroll-ml': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-p': [{\n 'scroll-p': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding Inline\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-px': [{\n 'scroll-px': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding Block\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-py': [{\n 'scroll-py': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding Inline Start\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-ps': [{\n 'scroll-ps': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding Inline End\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pe': [{\n 'scroll-pe': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding Block Start\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pbs': [{\n 'scroll-pbs': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding Block End\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pbe': [{\n 'scroll-pbe': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding Top\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pt': [{\n 'scroll-pt': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding Right\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pr': [{\n 'scroll-pr': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding Bottom\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pb': [{\n 'scroll-pb': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Padding Left\n * @see https://tailwindcss.com/docs/scroll-padding\n */\n 'scroll-pl': [{\n 'scroll-pl': scaleUnambiguousSpacing()\n }],\n /**\n * Scroll Snap Align\n * @see https://tailwindcss.com/docs/scroll-snap-align\n */\n 'snap-align': [{\n snap: ['start', 'end', 'center', 'align-none']\n }],\n /**\n * Scroll Snap Stop\n * @see https://tailwindcss.com/docs/scroll-snap-stop\n */\n 'snap-stop': [{\n snap: ['normal', 'always']\n }],\n /**\n * Scroll Snap Type\n * @see https://tailwindcss.com/docs/scroll-snap-type\n */\n 'snap-type': [{\n snap: ['none', 'x', 'y', 'both']\n }],\n /**\n * Scroll Snap Type Strictness\n * @see https://tailwindcss.com/docs/scroll-snap-type\n */\n 'snap-strictness': [{\n snap: ['mandatory', 'proximity']\n }],\n /**\n * Touch Action\n * @see https://tailwindcss.com/docs/touch-action\n */\n touch: [{\n touch: ['auto', 'none', 'manipulation']\n }],\n /**\n * Touch Action X\n * @see https://tailwindcss.com/docs/touch-action\n */\n 'touch-x': [{\n 'touch-pan': ['x', 'left', 'right']\n }],\n /**\n * Touch Action Y\n * @see https://tailwindcss.com/docs/touch-action\n */\n 'touch-y': [{\n 'touch-pan': ['y', 'up', 'down']\n }],\n /**\n * Touch Action Pinch Zoom\n * @see https://tailwindcss.com/docs/touch-action\n */\n 'touch-pz': ['touch-pinch-zoom'],\n /**\n * User Select\n * @see https://tailwindcss.com/docs/user-select\n */\n select: [{\n select: ['none', 'text', 'all', 'auto']\n }],\n /**\n * Will Change\n * @see https://tailwindcss.com/docs/will-change\n */\n 'will-change': [{\n 'will-change': ['auto', 'scroll', 'contents', 'transform', isArbitraryVariable, isArbitraryValue]\n }],\n // -----------\n // --- SVG ---\n // -----------\n /**\n * Fill\n * @see https://tailwindcss.com/docs/fill\n */\n fill: [{\n fill: ['none', ...scaleColor()]\n }],\n /**\n * Stroke Width\n * @see https://tailwindcss.com/docs/stroke-width\n */\n 'stroke-w': [{\n stroke: [isNumber, isArbitraryVariableLength, isArbitraryLength, isArbitraryNumber]\n }],\n /**\n * Stroke\n * @see https://tailwindcss.com/docs/stroke\n */\n stroke: [{\n stroke: ['none', ...scaleColor()]\n }],\n // ---------------------\n // --- Accessibility ---\n // ---------------------\n /**\n * Forced Color Adjust\n * @see https://tailwindcss.com/docs/forced-color-adjust\n */\n 'forced-color-adjust': [{\n 'forced-color-adjust': ['auto', 'none']\n }]\n },\n conflictingClassGroups: {\n overflow: ['overflow-x', 'overflow-y'],\n overscroll: ['overscroll-x', 'overscroll-y'],\n inset: ['inset-x', 'inset-y', 'inset-bs', 'inset-be', 'start', 'end', 'top', 'right', 'bottom', 'left'],\n 'inset-x': ['right', 'left'],\n 'inset-y': ['top', 'bottom'],\n flex: ['basis', 'grow', 'shrink'],\n gap: ['gap-x', 'gap-y'],\n p: ['px', 'py', 'ps', 'pe', 'pbs', 'pbe', 'pt', 'pr', 'pb', 'pl'],\n px: ['pr', 'pl'],\n py: ['pt', 'pb'],\n m: ['mx', 'my', 'ms', 'me', 'mbs', 'mbe', 'mt', 'mr', 'mb', 'ml'],\n mx: ['mr', 'ml'],\n my: ['mt', 'mb'],\n size: ['w', 'h'],\n 'font-size': ['leading'],\n 'fvn-normal': ['fvn-ordinal', 'fvn-slashed-zero', 'fvn-figure', 'fvn-spacing', 'fvn-fraction'],\n 'fvn-ordinal': ['fvn-normal'],\n 'fvn-slashed-zero': ['fvn-normal'],\n 'fvn-figure': ['fvn-normal'],\n 'fvn-spacing': ['fvn-normal'],\n 'fvn-fraction': ['fvn-normal'],\n 'line-clamp': ['display', 'overflow'],\n rounded: ['rounded-s', 'rounded-e', 'rounded-t', 'rounded-r', 'rounded-b', 'rounded-l', 'rounded-ss', 'rounded-se', 'rounded-ee', 'rounded-es', 'rounded-tl', 'rounded-tr', 'rounded-br', 'rounded-bl'],\n 'rounded-s': ['rounded-ss', 'rounded-es'],\n 'rounded-e': ['rounded-se', 'rounded-ee'],\n 'rounded-t': ['rounded-tl', 'rounded-tr'],\n 'rounded-r': ['rounded-tr', 'rounded-br'],\n 'rounded-b': ['rounded-br', 'rounded-bl'],\n 'rounded-l': ['rounded-tl', 'rounded-bl'],\n 'border-spacing': ['border-spacing-x', 'border-spacing-y'],\n 'border-w': ['border-w-x', 'border-w-y', 'border-w-s', 'border-w-e', 'border-w-bs', 'border-w-be', 'border-w-t', 'border-w-r', 'border-w-b', 'border-w-l'],\n 'border-w-x': ['border-w-r', 'border-w-l'],\n 'border-w-y': ['border-w-t', 'border-w-b'],\n 'border-color': ['border-color-x', 'border-color-y', 'border-color-s', 'border-color-e', 'border-color-bs', 'border-color-be', 'border-color-t', 'border-color-r', 'border-color-b', 'border-color-l'],\n 'border-color-x': ['border-color-r', 'border-color-l'],\n 'border-color-y': ['border-color-t', 'border-color-b'],\n translate: ['translate-x', 'translate-y', 'translate-none'],\n 'translate-none': ['translate', 'translate-x', 'translate-y', 'translate-z'],\n 'scroll-m': ['scroll-mx', 'scroll-my', 'scroll-ms', 'scroll-me', 'scroll-mbs', 'scroll-mbe', 'scroll-mt', 'scroll-mr', 'scroll-mb', 'scroll-ml'],\n 'scroll-mx': ['scroll-mr', 'scroll-ml'],\n 'scroll-my': ['scroll-mt', 'scroll-mb'],\n 'scroll-p': ['scroll-px', 'scroll-py', 'scroll-ps', 'scroll-pe', 'scroll-pbs', 'scroll-pbe', 'scroll-pt', 'scroll-pr', 'scroll-pb', 'scroll-pl'],\n 'scroll-px': ['scroll-pr', 'scroll-pl'],\n 'scroll-py': ['scroll-pt', 'scroll-pb'],\n touch: ['touch-x', 'touch-y', 'touch-pz'],\n 'touch-x': ['touch'],\n 'touch-y': ['touch'],\n 'touch-pz': ['touch']\n },\n conflictingClassGroupModifiers: {\n 'font-size': ['leading']\n },\n orderSensitiveModifiers: ['*', '**', 'after', 'backdrop', 'before', 'details-content', 'file', 'first-letter', 'first-line', 'marker', 'placeholder', 'selection']\n };\n};\n\n/**\n * @param baseConfig Config where other config will be merged into. This object will be mutated.\n * @param configExtension Partial config to merge into the `baseConfig`.\n */\nconst mergeConfigs = (baseConfig, {\n cacheSize,\n prefix,\n experimentalParseClassName,\n extend = {},\n override = {}\n}) => {\n overrideProperty(baseConfig, 'cacheSize', cacheSize);\n overrideProperty(baseConfig, 'prefix', prefix);\n overrideProperty(baseConfig, 'experimentalParseClassName', experimentalParseClassName);\n overrideConfigProperties(baseConfig.theme, override.theme);\n overrideConfigProperties(baseConfig.classGroups, override.classGroups);\n overrideConfigProperties(baseConfig.conflictingClassGroups, override.conflictingClassGroups);\n overrideConfigProperties(baseConfig.conflictingClassGroupModifiers, override.conflictingClassGroupModifiers);\n overrideProperty(baseConfig, 'orderSensitiveModifiers', override.orderSensitiveModifiers);\n mergeConfigProperties(baseConfig.theme, extend.theme);\n mergeConfigProperties(baseConfig.classGroups, extend.classGroups);\n mergeConfigProperties(baseConfig.conflictingClassGroups, extend.conflictingClassGroups);\n mergeConfigProperties(baseConfig.conflictingClassGroupModifiers, extend.conflictingClassGroupModifiers);\n mergeArrayProperties(baseConfig, extend, 'orderSensitiveModifiers');\n return baseConfig;\n};\nconst overrideProperty = (baseObject, overrideKey, overrideValue) => {\n if (overrideValue !== undefined) {\n baseObject[overrideKey] = overrideValue;\n }\n};\nconst overrideConfigProperties = (baseObject, overrideObject) => {\n if (overrideObject) {\n for (const key in overrideObject) {\n overrideProperty(baseObject, key, overrideObject[key]);\n }\n }\n};\nconst mergeConfigProperties = (baseObject, mergeObject) => {\n if (mergeObject) {\n for (const key in mergeObject) {\n mergeArrayProperties(baseObject, mergeObject, key);\n }\n }\n};\nconst mergeArrayProperties = (baseObject, mergeObject, key) => {\n const mergeValue = mergeObject[key];\n if (mergeValue !== undefined) {\n baseObject[key] = baseObject[key] ? baseObject[key].concat(mergeValue) : mergeValue;\n }\n};\nconst extendTailwindMerge = (configExtension, ...createConfig) => typeof configExtension === 'function' ? createTailwindMerge(getDefaultConfig, configExtension, ...createConfig) : createTailwindMerge(() => mergeConfigs(getDefaultConfig(), configExtension), ...createConfig);\nconst twMerge = /*#__PURE__*/createTailwindMerge(getDefaultConfig);\nexport { createTailwindMerge, extendTailwindMerge, fromTheme, getDefaultConfig, mergeConfigs, twJoin, twMerge, validators };\n//# sourceMappingURL=bundle-mjs.mjs.map\n","import { clsx, type ClassValue } from 'clsx'\nimport { twMerge } from 'tailwind-merge'\n\n/**\n * Merge Tailwind classes safely.\n * clsx handles conditionals; twMerge resolves conflicting Tailwind utilities\n * (e.g. bg-signal + bg-void → bg-void wins, not both).\n */\nexport function cn(...inputs: ClassValue[]) {\n return twMerge(clsx(inputs))\n}\n","import { Slot } from '@radix-ui/react-slot'\nimport { cn } from '../../lib/cn'\n\nexport type ButtonVariant = 'primary' | 'secondary' | 'ghost' | 'destructive'\n\nexport interface ButtonProps extends React.ButtonHTMLAttributes<HTMLButtonElement> {\n /** Visual treatment of the button. Defaults to 'primary'. */\n variant?: ButtonVariant\n /**\n * Render as a child element instead of <button>.\n * Useful for routing links: <Button asChild><a href=\"/path\">Go</a></Button>\n */\n asChild?: boolean\n}\n\nconst base = [\n // Layout\n 'inline-flex items-center justify-center gap-2 whitespace-nowrap',\n // Typography — Barlow Condensed, tracked uppercase\n 'font-display font-bold text-sm tracking-[0.08em] uppercase leading-none',\n // Geometry\n 'px-6 py-2 rounded-md border border-solid',\n // Interaction\n 'cursor-pointer select-none no-underline',\n // Motion — fast, no bounce\n 'transition-all duration-fast ease-[var(--ease-standard)]',\n // Focus — always visible, signal-alt blue ring\n 'outline-none focus-visible:ring-[3px] focus-visible:ring-signal-alt focus-visible:ring-offset-0',\n // Disabled\n 'disabled:opacity-[0.38] disabled:cursor-not-allowed disabled:pointer-events-none',\n // Active\n 'active:translate-y-px',\n].join(' ')\n\nconst variants: Record<ButtonVariant, string> = {\n /**\n * Signal red fill — the dominant CTA.\n * Use once per view. Hover darkens via color-mix.\n */\n primary: cn(\n 'bg-signal text-paper border-signal',\n 'hover:bg-[color-mix(in_srgb,var(--color-signal)_82%,var(--color-void))]',\n 'hover:border-[color-mix(in_srgb,var(--color-signal)_82%,var(--color-void))]',\n ),\n\n /**\n * Paper fill, rule border — supporting or alternate action.\n */\n secondary: cn(\n 'bg-paper text-void border-rule',\n 'hover:bg-[color-mix(in_srgb,var(--color-paper)_88%,var(--color-void))]',\n 'hover:border-smoke',\n ),\n\n /**\n * Transparent — tertiary or inline action. Low visual weight.\n */\n ghost: cn(\n 'bg-transparent text-void border-transparent',\n 'hover:bg-[color-mix(in_srgb,var(--color-rule)_40%,transparent)]',\n 'hover:border-rule',\n ),\n\n /**\n * Paper fill, signal red text + border — danger confirmation.\n * Inverts to filled red on hover to raise urgency before confirm.\n * Uses red focus ring, not blue.\n */\n destructive: cn(\n 'bg-paper text-signal border-signal',\n 'hover:bg-signal hover:text-paper hover:border-signal',\n 'focus-visible:ring-[color-mix(in_srgb,var(--color-signal)_50%,transparent)]',\n ),\n}\n\n/**\n * The foundational interactive element.\n * All styles are derived from Bauhaus design tokens.\n *\n * @example\n * <Button variant=\"primary\">Submit</Button>\n * <Button variant=\"destructive\" asChild><a href=\"/delete\">Delete</a></Button>\n */\nexport function Button({\n variant = 'primary',\n asChild = false,\n className,\n children,\n ...props\n}: ButtonProps) {\n const Comp = asChild ? Slot : 'button'\n\n return (\n <Comp className={cn(base, variants[variant], className)} {...props}>\n {children}\n </Comp>\n )\n}\n","import { cn } from '../../lib/cn'\n\nexport type BadgeVariant = 'neutral' | 'active' | 'warning' | 'danger' | 'success'\n\nexport interface BadgeProps extends React.HTMLAttributes<HTMLSpanElement> {\n /** Semantic status conveyed by this badge. Defaults to 'neutral'. */\n variant?: BadgeVariant\n}\n\nconst base = [\n // Layout\n 'inline-flex items-center',\n // Typography — xs, display, bold, tracked uppercase\n 'font-display font-bold text-xs tracking-[0.10em] uppercase leading-none',\n // Geometry — minimal radius, consistent padding\n 'px-2 py-[3px] rounded-sm',\n // No interaction\n 'select-none whitespace-nowrap',\n].join(' ')\n\nconst variants: Record<BadgeVariant, string> = {\n /**\n * Smoke on rule-tinted background — draft, pending, default state.\n */\n neutral: cn(\n 'text-smoke',\n 'bg-[color-mix(in_srgb,var(--color-smoke)_10%,var(--color-paper))]',\n ),\n\n /**\n * Signal-alt blue — in progress, active, under review.\n */\n active: cn(\n 'text-signal-alt',\n 'bg-[color-mix(in_srgb,var(--color-signal-alt)_10%,var(--color-paper))]',\n ),\n\n /**\n * Caution amber — on hold, revision required, needs attention.\n */\n warning: cn(\n 'text-[var(--color-caution)]',\n 'bg-[color-mix(in_srgb,var(--color-caution)_10%,var(--color-paper))]',\n ),\n\n /**\n * Signal red — blocked, rejected, critical.\n */\n danger: cn(\n 'text-signal',\n 'bg-[color-mix(in_srgb,var(--color-signal)_10%,var(--color-paper))]',\n ),\n\n /**\n * Growth green — complete, approved, resolved.\n */\n success: cn(\n 'text-[var(--color-growth)]',\n 'bg-[color-mix(in_srgb,var(--color-growth)_10%,var(--color-paper))]',\n ),\n}\n\n/**\n * Non-interactive status label.\n * Conveys project state, change-order state, or any categorical label.\n *\n * @example\n * <Badge variant=\"active\">In Progress</Badge>\n * <Badge variant=\"danger\">Blocked</Badge>\n */\nexport function Badge({\n variant = 'neutral',\n className,\n children,\n ...props\n}: BadgeProps) {\n return (\n <span className={cn(base, variants[variant], className)} {...props}>\n {children}\n </span>\n )\n}\n","import { cn } from '../../lib/cn'\n\nexport interface LabelProps extends React.LabelHTMLAttributes<HTMLLabelElement> {\n /**\n * Appends a required indicator (*) after the label text.\n * Does not affect validation — pair with the `required` attribute on the input.\n */\n required?: boolean\n /**\n * Reduces opacity to match a disabled input.\n * Does not affect the native label behaviour.\n */\n disabled?: boolean\n}\n\n/**\n * Accessible form label. Link to an input via `htmlFor` / `id`.\n *\n * @example\n * <Label htmlFor=\"name\" required>Project Name</Label>\n * <Input id=\"name\" required />\n */\nexport function Label({\n required,\n disabled,\n className,\n children,\n ...props\n}: LabelProps) {\n return (\n <label\n className={cn(\n // Typography — body font, sm size, medium weight\n 'font-body font-medium text-sm leading-none',\n // Color\n 'text-void',\n // Disabled state\n disabled && 'opacity-[0.38] cursor-not-allowed',\n className,\n )}\n {...props}\n >\n {children}\n {required && (\n <span\n className=\"ml-1 text-signal\"\n aria-hidden=\"true\"\n >\n *\n </span>\n )}\n </label>\n )\n}\n","import { cn } from '../../lib/cn'\n\nexport interface InputProps extends React.InputHTMLAttributes<HTMLInputElement> {\n /**\n * Error message shown below the input.\n * When set, the input renders in an error state (signal-red border).\n */\n error?: string\n /**\n * Hint text shown below the input when there is no error.\n */\n helperText?: string\n}\n\nconst inputBase = [\n // Layout — full width of its container\n 'w-full',\n // Typography\n 'font-body text-base text-void',\n // Geometry\n 'px-4 py-2 rounded-sm border border-solid',\n // Color\n 'bg-paper border-rule',\n // Placeholder\n 'placeholder:text-smoke',\n // Focus — signal-alt ring, remove default outline\n 'outline-none',\n 'focus-visible:border-signal-alt',\n 'focus-visible:ring-[2px] focus-visible:ring-signal-alt focus-visible:ring-offset-0',\n // Transition\n 'transition-colors duration-fast ease-[var(--ease-standard)]',\n // Disabled\n 'disabled:opacity-[0.38] disabled:cursor-not-allowed',\n 'disabled:bg-[color-mix(in_srgb,var(--color-rule)_30%,var(--color-paper))]',\n].join(' ')\n\nconst inputError = [\n 'border-signal',\n 'focus-visible:border-signal',\n 'focus-visible:ring-[color-mix(in_srgb,var(--color-signal)_40%,transparent)]',\n].join(' ')\n\n/**\n * Single-line text input.\n * Compose with Label for accessible form fields:\n *\n * @example\n * <Label htmlFor=\"name\" required>Project Name</Label>\n * <Input id=\"name\" placeholder=\"e.g. Kitchen Reno\" required />\n *\n * @example\n * <Input id=\"budget\" error=\"Budget is required.\" />\n */\nexport function Input({\n id,\n error,\n helperText,\n className,\n ...props\n}: InputProps) {\n const errorId = id ? `${id}-error` : undefined\n const helperIdId = id ? `${id}-hint` : undefined\n\n const describedBy = error\n ? errorId\n : helperText\n ? helperIdId\n : undefined\n\n return (\n <div className=\"flex flex-col gap-1\">\n <input\n id={id}\n className={cn(inputBase, error && inputError, className)}\n aria-invalid={error ? 'true' : undefined}\n aria-describedby={describedBy}\n {...props}\n />\n {error && (\n <p\n id={errorId}\n role=\"alert\"\n className=\"text-xs text-signal leading-none\"\n >\n {error}\n </p>\n )}\n {!error && helperText && (\n <p\n id={helperIdId}\n className=\"text-xs text-smoke leading-none\"\n >\n {helperText}\n </p>\n )}\n </div>\n )\n}\n","import { cn } from '../../lib/cn'\n\nexport interface CardProps extends React.HTMLAttributes<HTMLDivElement> {}\nexport interface CardHeaderProps extends React.HTMLAttributes<HTMLDivElement> {}\nexport interface CardBodyProps extends React.HTMLAttributes<HTMLDivElement> {}\nexport interface CardFooterProps extends React.HTMLAttributes<HTMLDivElement> {}\n\n/**\n * Elevated container for project summaries, scope items, and change orders.\n * Compose with CardHeader, CardBody, CardFooter as needed.\n *\n * @example\n * <Card>\n * <CardHeader>\n * <span>Kitchen Reno</span>\n * <Badge variant=\"active\">In Progress</Badge>\n * </CardHeader>\n * <CardBody>…</CardBody>\n * <CardFooter>\n * <Button variant=\"ghost\">View</Button>\n * </CardFooter>\n * </Card>\n */\nexport function Card({ className, children, ...props }: CardProps) {\n return (\n <div\n className={cn(\n 'bg-paper border border-rule rounded-sm shadow-[var(--shadow-sm)]',\n 'overflow-hidden',\n className,\n )}\n {...props}\n >\n {children}\n </div>\n )\n}\n\n/**\n * Optional header slot. Renders a flex row — ideal for a title + Badge.\n * Separated from the body by a 1px rule border.\n */\nexport function CardHeader({ className, children, ...props }: CardHeaderProps) {\n return (\n <div\n className={cn(\n 'flex items-center justify-between gap-4',\n 'px-5 py-4',\n 'border-b border-rule',\n className,\n )}\n {...props}\n >\n {children}\n </div>\n )\n}\n\n/**\n * Main content area. Handles its own padding.\n */\nexport function CardBody({ className, children, ...props }: CardBodyProps) {\n return (\n <div\n className={cn('px-5 py-4', className)}\n {...props}\n >\n {children}\n </div>\n )\n}\n\n/**\n * Optional footer slot. Renders a flex row for action buttons.\n * Separated from the body by a 1px rule border.\n */\nexport function CardFooter({ className, children, ...props }: CardFooterProps) {\n return (\n <div\n className={cn(\n 'flex items-center justify-end gap-3',\n 'px-5 py-4',\n 'border-t border-rule',\n className,\n )}\n {...props}\n >\n {children}\n </div>\n )\n}\n","// packages/core/number/src/number.ts\nfunction clamp(value, [min, max]) {\n return Math.min(max, Math.max(min, value));\n}\nexport {\n clamp\n};\n//# sourceMappingURL=index.mjs.map\n","// src/primitive.tsx\nvar canUseDOM = !!(typeof window !== \"undefined\" && window.document && window.document.createElement);\nfunction composeEventHandlers(originalEventHandler, ourEventHandler, { checkForDefaultPrevented = true } = {}) {\n return function handleEvent(event) {\n originalEventHandler?.(event);\n if (checkForDefaultPrevented === false || !event.defaultPrevented) {\n return ourEventHandler?.(event);\n }\n };\n}\nfunction getOwnerWindow(element) {\n if (!canUseDOM) {\n throw new Error(\"Cannot access window outside of the DOM\");\n }\n return element?.ownerDocument?.defaultView ?? window;\n}\nfunction getOwnerDocument(element) {\n if (!canUseDOM) {\n throw new Error(\"Cannot access document outside of the DOM\");\n }\n return element?.ownerDocument ?? document;\n}\nfunction getActiveElement(node, activeDescendant = false) {\n const { activeElement } = getOwnerDocument(node);\n if (!activeElement?.nodeName) {\n return null;\n }\n if (isFrame(activeElement) && activeElement.contentDocument) {\n return getActiveElement(activeElement.contentDocument.body, activeDescendant);\n }\n if (activeDescendant) {\n const id = activeElement.getAttribute(\"aria-activedescendant\");\n if (id) {\n const element = getOwnerDocument(activeElement).getElementById(id);\n if (element) {\n return element;\n }\n }\n }\n return activeElement;\n}\nfunction isFrame(element) {\n return element.tagName === \"IFRAME\";\n}\nexport {\n canUseDOM,\n composeEventHandlers,\n getActiveElement,\n getOwnerDocument,\n getOwnerWindow,\n isFrame\n};\n//# sourceMappingURL=index.mjs.map\n","// packages/react/context/src/create-context.tsx\nimport * as React from \"react\";\nimport { jsx } from \"react/jsx-runtime\";\nfunction createContext2(rootComponentName, defaultContext) {\n const Context = React.createContext(defaultContext);\n const Provider = (props) => {\n const { children, ...context } = props;\n const value = React.useMemo(() => context, Object.values(context));\n return /* @__PURE__ */ jsx(Context.Provider, { value, children });\n };\n Provider.displayName = rootComponentName + \"Provider\";\n function useContext2(consumerName) {\n const context = React.useContext(Context);\n if (context) return context;\n if (defaultContext !== void 0) return defaultContext;\n throw new Error(`\\`${consumerName}\\` must be used within \\`${rootComponentName}\\``);\n }\n return [Provider, useContext2];\n}\nfunction createContextScope(scopeName, createContextScopeDeps = []) {\n let defaultContexts = [];\n function createContext3(rootComponentName, defaultContext) {\n const BaseContext = React.createContext(defaultContext);\n const index = defaultContexts.length;\n defaultContexts = [...defaultContexts, defaultContext];\n const Provider = (props) => {\n const { scope, children, ...context } = props;\n const Context = scope?.[scopeName]?.[index] || BaseContext;\n const value = React.useMemo(() => context, Object.values(context));\n return /* @__PURE__ */ jsx(Context.Provider, { value, children });\n };\n Provider.displayName = rootComponentName + \"Provider\";\n function useContext2(consumerName, scope) {\n const Context = scope?.[scopeName]?.[index] || BaseContext;\n const context = React.useContext(Context);\n if (context) return context;\n if (defaultContext !== void 0) return defaultContext;\n throw new Error(`\\`${consumerName}\\` must be used within \\`${rootComponentName}\\``);\n }\n return [Provider, useContext2];\n }\n const createScope = () => {\n const scopeContexts = defaultContexts.map((defaultContext) => {\n return React.createContext(defaultContext);\n });\n return function useScope(scope) {\n const contexts = scope?.[scopeName] || scopeContexts;\n return React.useMemo(\n () => ({ [`__scope${scopeName}`]: { ...scope, [scopeName]: contexts } }),\n [scope, contexts]\n );\n };\n };\n createScope.scopeName = scopeName;\n return [createContext3, composeContextScopes(createScope, ...createContextScopeDeps)];\n}\nfunction composeContextScopes(...scopes) {\n const baseScope = scopes[0];\n if (scopes.length === 1) return baseScope;\n const createScope = () => {\n const scopeHooks = scopes.map((createScope2) => ({\n useScope: createScope2(),\n scopeName: createScope2.scopeName\n }));\n return function useComposedScopes(overrideScopes) {\n const nextScopes = scopeHooks.reduce((nextScopes2, { useScope, scopeName }) => {\n const scopeProps = useScope(overrideScopes);\n const currentScope = scopeProps[`__scope${scopeName}`];\n return { ...nextScopes2, ...currentScope };\n }, {});\n return React.useMemo(() => ({ [`__scope${baseScope.scopeName}`]: nextScopes }), [nextScopes]);\n };\n };\n createScope.scopeName = baseScope.scopeName;\n return createScope;\n}\nexport {\n createContext2 as createContext,\n createContextScope\n};\n//# sourceMappingURL=index.mjs.map\n","// src/slot.tsx\nimport * as React from \"react\";\nimport { composeRefs } from \"@radix-ui/react-compose-refs\";\nimport { Fragment as Fragment2, jsx } from \"react/jsx-runtime\";\n// @__NO_SIDE_EFFECTS__\nfunction createSlot(ownerName) {\n const SlotClone = /* @__PURE__ */ createSlotClone(ownerName);\n const Slot2 = React.forwardRef((props, forwardedRef) => {\n const { children, ...slotProps } = props;\n const childrenArray = React.Children.toArray(children);\n const slottable = childrenArray.find(isSlottable);\n if (slottable) {\n const newElement = slottable.props.children;\n const newChildren = childrenArray.map((child) => {\n if (child === slottable) {\n if (React.Children.count(newElement) > 1) return React.Children.only(null);\n return React.isValidElement(newElement) ? newElement.props.children : null;\n } else {\n return child;\n }\n });\n return /* @__PURE__ */ jsx(SlotClone, { ...slotProps, ref: forwardedRef, children: React.isValidElement(newElement) ? React.cloneElement(newElement, void 0, newChildren) : null });\n }\n return /* @__PURE__ */ jsx(SlotClone, { ...slotProps, ref: forwardedRef, children });\n });\n Slot2.displayName = `${ownerName}.Slot`;\n return Slot2;\n}\nvar Slot = /* @__PURE__ */ createSlot(\"Slot\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlotClone(ownerName) {\n const SlotClone = React.forwardRef((props, forwardedRef) => {\n const { children, ...slotProps } = props;\n if (React.isValidElement(children)) {\n const childrenRef = getElementRef(children);\n const props2 = mergeProps(slotProps, children.props);\n if (children.type !== React.Fragment) {\n props2.ref = forwardedRef ? composeRefs(forwardedRef, childrenRef) : childrenRef;\n }\n return React.cloneElement(children, props2);\n }\n return React.Children.count(children) > 1 ? React.Children.only(null) : null;\n });\n SlotClone.displayName = `${ownerName}.SlotClone`;\n return SlotClone;\n}\nvar SLOTTABLE_IDENTIFIER = Symbol(\"radix.slottable\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlottable(ownerName) {\n const Slottable2 = ({ children }) => {\n return /* @__PURE__ */ jsx(Fragment2, { children });\n };\n Slottable2.displayName = `${ownerName}.Slottable`;\n Slottable2.__radixId = SLOTTABLE_IDENTIFIER;\n return Slottable2;\n}\nvar Slottable = /* @__PURE__ */ createSlottable(\"Slottable\");\nfunction isSlottable(child) {\n return React.isValidElement(child) && typeof child.type === \"function\" && \"__radixId\" in child.type && child.type.__radixId === SLOTTABLE_IDENTIFIER;\n}\nfunction mergeProps(slotProps, childProps) {\n const overrideProps = { ...childProps };\n for (const propName in childProps) {\n const slotPropValue = slotProps[propName];\n const childPropValue = childProps[propName];\n const isHandler = /^on[A-Z]/.test(propName);\n if (isHandler) {\n if (slotPropValue && childPropValue) {\n overrideProps[propName] = (...args) => {\n const result = childPropValue(...args);\n slotPropValue(...args);\n return result;\n };\n } else if (slotPropValue) {\n overrideProps[propName] = slotPropValue;\n }\n } else if (propName === \"style\") {\n overrideProps[propName] = { ...slotPropValue, ...childPropValue };\n } else if (propName === \"className\") {\n overrideProps[propName] = [slotPropValue, childPropValue].filter(Boolean).join(\" \");\n }\n }\n return { ...slotProps, ...overrideProps };\n}\nfunction getElementRef(element) {\n let getter = Object.getOwnPropertyDescriptor(element.props, \"ref\")?.get;\n let mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.ref;\n }\n getter = Object.getOwnPropertyDescriptor(element, \"ref\")?.get;\n mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.props.ref;\n }\n return element.props.ref || element.ref;\n}\nexport {\n Slot as Root,\n Slot,\n Slottable,\n createSlot,\n createSlottable\n};\n//# sourceMappingURL=index.mjs.map\n","\"use client\";\n\n// src/collection-legacy.tsx\nimport React from \"react\";\nimport { createContextScope } from \"@radix-ui/react-context\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { createSlot } from \"@radix-ui/react-slot\";\nimport { jsx } from \"react/jsx-runtime\";\nfunction createCollection(name) {\n const PROVIDER_NAME = name + \"CollectionProvider\";\n const [createCollectionContext, createCollectionScope] = createContextScope(PROVIDER_NAME);\n const [CollectionProviderImpl, useCollectionContext] = createCollectionContext(\n PROVIDER_NAME,\n { collectionRef: { current: null }, itemMap: /* @__PURE__ */ new Map() }\n );\n const CollectionProvider = (props) => {\n const { scope, children } = props;\n const ref = React.useRef(null);\n const itemMap = React.useRef(/* @__PURE__ */ new Map()).current;\n return /* @__PURE__ */ jsx(CollectionProviderImpl, { scope, itemMap, collectionRef: ref, children });\n };\n CollectionProvider.displayName = PROVIDER_NAME;\n const COLLECTION_SLOT_NAME = name + \"CollectionSlot\";\n const CollectionSlotImpl = createSlot(COLLECTION_SLOT_NAME);\n const CollectionSlot = React.forwardRef(\n (props, forwardedRef) => {\n const { scope, children } = props;\n const context = useCollectionContext(COLLECTION_SLOT_NAME, scope);\n const composedRefs = useComposedRefs(forwardedRef, context.collectionRef);\n return /* @__PURE__ */ jsx(CollectionSlotImpl, { ref: composedRefs, children });\n }\n );\n CollectionSlot.displayName = COLLECTION_SLOT_NAME;\n const ITEM_SLOT_NAME = name + \"CollectionItemSlot\";\n const ITEM_DATA_ATTR = \"data-radix-collection-item\";\n const CollectionItemSlotImpl = createSlot(ITEM_SLOT_NAME);\n const CollectionItemSlot = React.forwardRef(\n (props, forwardedRef) => {\n const { scope, children, ...itemData } = props;\n const ref = React.useRef(null);\n const composedRefs = useComposedRefs(forwardedRef, ref);\n const context = useCollectionContext(ITEM_SLOT_NAME, scope);\n React.useEffect(() => {\n context.itemMap.set(ref, { ref, ...itemData });\n return () => void context.itemMap.delete(ref);\n });\n return /* @__PURE__ */ jsx(CollectionItemSlotImpl, { ...{ [ITEM_DATA_ATTR]: \"\" }, ref: composedRefs, children });\n }\n );\n CollectionItemSlot.displayName = ITEM_SLOT_NAME;\n function useCollection(scope) {\n const context = useCollectionContext(name + \"CollectionConsumer\", scope);\n const getItems = React.useCallback(() => {\n const collectionNode = context.collectionRef.current;\n if (!collectionNode) return [];\n const orderedNodes = Array.from(collectionNode.querySelectorAll(`[${ITEM_DATA_ATTR}]`));\n const items = Array.from(context.itemMap.values());\n const orderedItems = items.sort(\n (a, b) => orderedNodes.indexOf(a.ref.current) - orderedNodes.indexOf(b.ref.current)\n );\n return orderedItems;\n }, [context.collectionRef, context.itemMap]);\n return getItems;\n }\n return [\n { Provider: CollectionProvider, Slot: CollectionSlot, ItemSlot: CollectionItemSlot },\n useCollection,\n createCollectionScope\n ];\n}\n\n// src/collection.tsx\nimport React2 from \"react\";\nimport { createContextScope as createContextScope2 } from \"@radix-ui/react-context\";\nimport { useComposedRefs as useComposedRefs2 } from \"@radix-ui/react-compose-refs\";\nimport { createSlot as createSlot2 } from \"@radix-ui/react-slot\";\n\n// src/ordered-dictionary.ts\nvar __instanciated = /* @__PURE__ */ new WeakMap();\nvar OrderedDict = class _OrderedDict extends Map {\n #keys;\n constructor(entries) {\n super(entries);\n this.#keys = [...super.keys()];\n __instanciated.set(this, true);\n }\n set(key, value) {\n if (__instanciated.get(this)) {\n if (this.has(key)) {\n this.#keys[this.#keys.indexOf(key)] = key;\n } else {\n this.#keys.push(key);\n }\n }\n super.set(key, value);\n return this;\n }\n insert(index, key, value) {\n const has = this.has(key);\n const length = this.#keys.length;\n const relativeIndex = toSafeInteger(index);\n let actualIndex = relativeIndex >= 0 ? relativeIndex : length + relativeIndex;\n const safeIndex = actualIndex < 0 || actualIndex >= length ? -1 : actualIndex;\n if (safeIndex === this.size || has && safeIndex === this.size - 1 || safeIndex === -1) {\n this.set(key, value);\n return this;\n }\n const size = this.size + (has ? 0 : 1);\n if (relativeIndex < 0) {\n actualIndex++;\n }\n const keys = [...this.#keys];\n let nextValue;\n let shouldSkip = false;\n for (let i = actualIndex; i < size; i++) {\n if (actualIndex === i) {\n let nextKey = keys[i];\n if (keys[i] === key) {\n nextKey = keys[i + 1];\n }\n if (has) {\n this.delete(key);\n }\n nextValue = this.get(nextKey);\n this.set(key, value);\n } else {\n if (!shouldSkip && keys[i - 1] === key) {\n shouldSkip = true;\n }\n const currentKey = keys[shouldSkip ? i : i - 1];\n const currentValue = nextValue;\n nextValue = this.get(currentKey);\n this.delete(currentKey);\n this.set(currentKey, currentValue);\n }\n }\n return this;\n }\n with(index, key, value) {\n const copy = new _OrderedDict(this);\n copy.insert(index, key, value);\n return copy;\n }\n before(key) {\n const index = this.#keys.indexOf(key) - 1;\n if (index < 0) {\n return void 0;\n }\n return this.entryAt(index);\n }\n /**\n * Sets a new key-value pair at the position before the given key.\n */\n setBefore(key, newKey, value) {\n const index = this.#keys.indexOf(key);\n if (index === -1) {\n return this;\n }\n return this.insert(index, newKey, value);\n }\n after(key) {\n let index = this.#keys.indexOf(key);\n index = index === -1 || index === this.size - 1 ? -1 : index + 1;\n if (index === -1) {\n return void 0;\n }\n return this.entryAt(index);\n }\n /**\n * Sets a new key-value pair at the position after the given key.\n */\n setAfter(key, newKey, value) {\n const index = this.#keys.indexOf(key);\n if (index === -1) {\n return this;\n }\n return this.insert(index + 1, newKey, value);\n }\n first() {\n return this.entryAt(0);\n }\n last() {\n return this.entryAt(-1);\n }\n clear() {\n this.#keys = [];\n return super.clear();\n }\n delete(key) {\n const deleted = super.delete(key);\n if (deleted) {\n this.#keys.splice(this.#keys.indexOf(key), 1);\n }\n return deleted;\n }\n deleteAt(index) {\n const key = this.keyAt(index);\n if (key !== void 0) {\n return this.delete(key);\n }\n return false;\n }\n at(index) {\n const key = at(this.#keys, index);\n if (key !== void 0) {\n return this.get(key);\n }\n }\n entryAt(index) {\n const key = at(this.#keys, index);\n if (key !== void 0) {\n return [key, this.get(key)];\n }\n }\n indexOf(key) {\n return this.#keys.indexOf(key);\n }\n keyAt(index) {\n return at(this.#keys, index);\n }\n from(key, offset) {\n const index = this.indexOf(key);\n if (index === -1) {\n return void 0;\n }\n let dest = index + offset;\n if (dest < 0) dest = 0;\n if (dest >= this.size) dest = this.size - 1;\n return this.at(dest);\n }\n keyFrom(key, offset) {\n const index = this.indexOf(key);\n if (index === -1) {\n return void 0;\n }\n let dest = index + offset;\n if (dest < 0) dest = 0;\n if (dest >= this.size) dest = this.size - 1;\n return this.keyAt(dest);\n }\n find(predicate, thisArg) {\n let index = 0;\n for (const entry of this) {\n if (Reflect.apply(predicate, thisArg, [entry, index, this])) {\n return entry;\n }\n index++;\n }\n return void 0;\n }\n findIndex(predicate, thisArg) {\n let index = 0;\n for (const entry of this) {\n if (Reflect.apply(predicate, thisArg, [entry, index, this])) {\n return index;\n }\n index++;\n }\n return -1;\n }\n filter(predicate, thisArg) {\n const entries = [];\n let index = 0;\n for (const entry of this) {\n if (Reflect.apply(predicate, thisArg, [entry, index, this])) {\n entries.push(entry);\n }\n index++;\n }\n return new _OrderedDict(entries);\n }\n map(callbackfn, thisArg) {\n const entries = [];\n let index = 0;\n for (const entry of this) {\n entries.push([entry[0], Reflect.apply(callbackfn, thisArg, [entry, index, this])]);\n index++;\n }\n return new _OrderedDict(entries);\n }\n reduce(...args) {\n const [callbackfn, initialValue] = args;\n let index = 0;\n let accumulator = initialValue ?? this.at(0);\n for (const entry of this) {\n if (index === 0 && args.length === 1) {\n accumulator = entry;\n } else {\n accumulator = Reflect.apply(callbackfn, this, [accumulator, entry, index, this]);\n }\n index++;\n }\n return accumulator;\n }\n reduceRight(...args) {\n const [callbackfn, initialValue] = args;\n let accumulator = initialValue ?? this.at(-1);\n for (let index = this.size - 1; index >= 0; index--) {\n const entry = this.at(index);\n if (index === this.size - 1 && args.length === 1) {\n accumulator = entry;\n } else {\n accumulator = Reflect.apply(callbackfn, this, [accumulator, entry, index, this]);\n }\n }\n return accumulator;\n }\n toSorted(compareFn) {\n const entries = [...this.entries()].sort(compareFn);\n return new _OrderedDict(entries);\n }\n toReversed() {\n const reversed = new _OrderedDict();\n for (let index = this.size - 1; index >= 0; index--) {\n const key = this.keyAt(index);\n const element = this.get(key);\n reversed.set(key, element);\n }\n return reversed;\n }\n toSpliced(...args) {\n const entries = [...this.entries()];\n entries.splice(...args);\n return new _OrderedDict(entries);\n }\n slice(start, end) {\n const result = new _OrderedDict();\n let stop = this.size - 1;\n if (start === void 0) {\n return result;\n }\n if (start < 0) {\n start = start + this.size;\n }\n if (end !== void 0 && end > 0) {\n stop = end - 1;\n }\n for (let index = start; index <= stop; index++) {\n const key = this.keyAt(index);\n const element = this.get(key);\n result.set(key, element);\n }\n return result;\n }\n every(predicate, thisArg) {\n let index = 0;\n for (const entry of this) {\n if (!Reflect.apply(predicate, thisArg, [entry, index, this])) {\n return false;\n }\n index++;\n }\n return true;\n }\n some(predicate, thisArg) {\n let index = 0;\n for (const entry of this) {\n if (Reflect.apply(predicate, thisArg, [entry, index, this])) {\n return true;\n }\n index++;\n }\n return false;\n }\n};\nfunction at(array, index) {\n if (\"at\" in Array.prototype) {\n return Array.prototype.at.call(array, index);\n }\n const actualIndex = toSafeIndex(array, index);\n return actualIndex === -1 ? void 0 : array[actualIndex];\n}\nfunction toSafeIndex(array, index) {\n const length = array.length;\n const relativeIndex = toSafeInteger(index);\n const actualIndex = relativeIndex >= 0 ? relativeIndex : length + relativeIndex;\n return actualIndex < 0 || actualIndex >= length ? -1 : actualIndex;\n}\nfunction toSafeInteger(number) {\n return number !== number || number === 0 ? 0 : Math.trunc(number);\n}\n\n// src/collection.tsx\nimport { jsx as jsx2 } from \"react/jsx-runtime\";\nfunction createCollection2(name) {\n const PROVIDER_NAME = name + \"CollectionProvider\";\n const [createCollectionContext, createCollectionScope] = createContextScope2(PROVIDER_NAME);\n const [CollectionContextProvider, useCollectionContext] = createCollectionContext(\n PROVIDER_NAME,\n {\n collectionElement: null,\n collectionRef: { current: null },\n collectionRefObject: { current: null },\n itemMap: new OrderedDict(),\n setItemMap: () => void 0\n }\n );\n const CollectionProvider = ({ state, ...props }) => {\n return state ? /* @__PURE__ */ jsx2(CollectionProviderImpl, { ...props, state }) : /* @__PURE__ */ jsx2(CollectionInit, { ...props });\n };\n CollectionProvider.displayName = PROVIDER_NAME;\n const CollectionInit = (props) => {\n const state = useInitCollection();\n return /* @__PURE__ */ jsx2(CollectionProviderImpl, { ...props, state });\n };\n CollectionInit.displayName = PROVIDER_NAME + \"Init\";\n const CollectionProviderImpl = (props) => {\n const { scope, children, state } = props;\n const ref = React2.useRef(null);\n const [collectionElement, setCollectionElement] = React2.useState(\n null\n );\n const composeRefs = useComposedRefs2(ref, setCollectionElement);\n const [itemMap, setItemMap] = state;\n React2.useEffect(() => {\n if (!collectionElement) return;\n const observer = getChildListObserver(() => {\n });\n observer.observe(collectionElement, {\n childList: true,\n subtree: true\n });\n return () => {\n observer.disconnect();\n };\n }, [collectionElement]);\n return /* @__PURE__ */ jsx2(\n CollectionContextProvider,\n {\n scope,\n itemMap,\n setItemMap,\n collectionRef: composeRefs,\n collectionRefObject: ref,\n collectionElement,\n children\n }\n );\n };\n CollectionProviderImpl.displayName = PROVIDER_NAME + \"Impl\";\n const COLLECTION_SLOT_NAME = name + \"CollectionSlot\";\n const CollectionSlotImpl = createSlot2(COLLECTION_SLOT_NAME);\n const CollectionSlot = React2.forwardRef(\n (props, forwardedRef) => {\n const { scope, children } = props;\n const context = useCollectionContext(COLLECTION_SLOT_NAME, scope);\n const composedRefs = useComposedRefs2(forwardedRef, context.collectionRef);\n return /* @__PURE__ */ jsx2(CollectionSlotImpl, { ref: composedRefs, children });\n }\n );\n CollectionSlot.displayName = COLLECTION_SLOT_NAME;\n const ITEM_SLOT_NAME = name + \"CollectionItemSlot\";\n const ITEM_DATA_ATTR = \"data-radix-collection-item\";\n const CollectionItemSlotImpl = createSlot2(ITEM_SLOT_NAME);\n const CollectionItemSlot = React2.forwardRef(\n (props, forwardedRef) => {\n const { scope, children, ...itemData } = props;\n const ref = React2.useRef(null);\n const [element, setElement] = React2.useState(null);\n const composedRefs = useComposedRefs2(forwardedRef, ref, setElement);\n const context = useCollectionContext(ITEM_SLOT_NAME, scope);\n const { setItemMap } = context;\n const itemDataRef = React2.useRef(itemData);\n if (!shallowEqual(itemDataRef.current, itemData)) {\n itemDataRef.current = itemData;\n }\n const memoizedItemData = itemDataRef.current;\n React2.useEffect(() => {\n const itemData2 = memoizedItemData;\n setItemMap((map) => {\n if (!element) {\n return map;\n }\n if (!map.has(element)) {\n map.set(element, { ...itemData2, element });\n return map.toSorted(sortByDocumentPosition);\n }\n return map.set(element, { ...itemData2, element }).toSorted(sortByDocumentPosition);\n });\n return () => {\n setItemMap((map) => {\n if (!element || !map.has(element)) {\n return map;\n }\n map.delete(element);\n return new OrderedDict(map);\n });\n };\n }, [element, memoizedItemData, setItemMap]);\n return /* @__PURE__ */ jsx2(CollectionItemSlotImpl, { ...{ [ITEM_DATA_ATTR]: \"\" }, ref: composedRefs, children });\n }\n );\n CollectionItemSlot.displayName = ITEM_SLOT_NAME;\n function useInitCollection() {\n return React2.useState(new OrderedDict());\n }\n function useCollection(scope) {\n const { itemMap } = useCollectionContext(name + \"CollectionConsumer\", scope);\n return itemMap;\n }\n const functions = {\n createCollectionScope,\n useCollection,\n useInitCollection\n };\n return [\n { Provider: CollectionProvider, Slot: CollectionSlot, ItemSlot: CollectionItemSlot },\n functions\n ];\n}\nfunction shallowEqual(a, b) {\n if (a === b) return true;\n if (typeof a !== \"object\" || typeof b !== \"object\") return false;\n if (a == null || b == null) return false;\n const keysA = Object.keys(a);\n const keysB = Object.keys(b);\n if (keysA.length !== keysB.length) return false;\n for (const key of keysA) {\n if (!Object.prototype.hasOwnProperty.call(b, key)) return false;\n if (a[key] !== b[key]) return false;\n }\n return true;\n}\nfunction isElementPreceding(a, b) {\n return !!(b.compareDocumentPosition(a) & Node.DOCUMENT_POSITION_PRECEDING);\n}\nfunction sortByDocumentPosition(a, b) {\n return !a[1].element || !b[1].element ? 0 : isElementPreceding(a[1].element, b[1].element) ? -1 : 1;\n}\nfunction getChildListObserver(callback) {\n const observer = new MutationObserver((mutationsList) => {\n for (const mutation of mutationsList) {\n if (mutation.type === \"childList\") {\n callback();\n return;\n }\n }\n });\n return observer;\n}\nexport {\n createCollection,\n createCollection2 as unstable_createCollection\n};\n//# sourceMappingURL=index.mjs.map\n","// packages/react/direction/src/direction.tsx\nimport * as React from \"react\";\nimport { jsx } from \"react/jsx-runtime\";\nvar DirectionContext = React.createContext(void 0);\nvar DirectionProvider = (props) => {\n const { dir, children } = props;\n return /* @__PURE__ */ jsx(DirectionContext.Provider, { value: dir, children });\n};\nfunction useDirection(localDir) {\n const globalDir = React.useContext(DirectionContext);\n return localDir || globalDir || \"ltr\";\n}\nvar Provider = DirectionProvider;\nexport {\n DirectionProvider,\n Provider,\n useDirection\n};\n//# sourceMappingURL=index.mjs.map\n","// src/slot.tsx\nimport * as React from \"react\";\nimport { composeRefs } from \"@radix-ui/react-compose-refs\";\nimport { Fragment as Fragment2, jsx } from \"react/jsx-runtime\";\n// @__NO_SIDE_EFFECTS__\nfunction createSlot(ownerName) {\n const SlotClone = /* @__PURE__ */ createSlotClone(ownerName);\n const Slot2 = React.forwardRef((props, forwardedRef) => {\n const { children, ...slotProps } = props;\n const childrenArray = React.Children.toArray(children);\n const slottable = childrenArray.find(isSlottable);\n if (slottable) {\n const newElement = slottable.props.children;\n const newChildren = childrenArray.map((child) => {\n if (child === slottable) {\n if (React.Children.count(newElement) > 1) return React.Children.only(null);\n return React.isValidElement(newElement) ? newElement.props.children : null;\n } else {\n return child;\n }\n });\n return /* @__PURE__ */ jsx(SlotClone, { ...slotProps, ref: forwardedRef, children: React.isValidElement(newElement) ? React.cloneElement(newElement, void 0, newChildren) : null });\n }\n return /* @__PURE__ */ jsx(SlotClone, { ...slotProps, ref: forwardedRef, children });\n });\n Slot2.displayName = `${ownerName}.Slot`;\n return Slot2;\n}\nvar Slot = /* @__PURE__ */ createSlot(\"Slot\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlotClone(ownerName) {\n const SlotClone = React.forwardRef((props, forwardedRef) => {\n const { children, ...slotProps } = props;\n if (React.isValidElement(children)) {\n const childrenRef = getElementRef(children);\n const props2 = mergeProps(slotProps, children.props);\n if (children.type !== React.Fragment) {\n props2.ref = forwardedRef ? composeRefs(forwardedRef, childrenRef) : childrenRef;\n }\n return React.cloneElement(children, props2);\n }\n return React.Children.count(children) > 1 ? React.Children.only(null) : null;\n });\n SlotClone.displayName = `${ownerName}.SlotClone`;\n return SlotClone;\n}\nvar SLOTTABLE_IDENTIFIER = Symbol(\"radix.slottable\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlottable(ownerName) {\n const Slottable2 = ({ children }) => {\n return /* @__PURE__ */ jsx(Fragment2, { children });\n };\n Slottable2.displayName = `${ownerName}.Slottable`;\n Slottable2.__radixId = SLOTTABLE_IDENTIFIER;\n return Slottable2;\n}\nvar Slottable = /* @__PURE__ */ createSlottable(\"Slottable\");\nfunction isSlottable(child) {\n return React.isValidElement(child) && typeof child.type === \"function\" && \"__radixId\" in child.type && child.type.__radixId === SLOTTABLE_IDENTIFIER;\n}\nfunction mergeProps(slotProps, childProps) {\n const overrideProps = { ...childProps };\n for (const propName in childProps) {\n const slotPropValue = slotProps[propName];\n const childPropValue = childProps[propName];\n const isHandler = /^on[A-Z]/.test(propName);\n if (isHandler) {\n if (slotPropValue && childPropValue) {\n overrideProps[propName] = (...args) => {\n const result = childPropValue(...args);\n slotPropValue(...args);\n return result;\n };\n } else if (slotPropValue) {\n overrideProps[propName] = slotPropValue;\n }\n } else if (propName === \"style\") {\n overrideProps[propName] = { ...slotPropValue, ...childPropValue };\n } else if (propName === \"className\") {\n overrideProps[propName] = [slotPropValue, childPropValue].filter(Boolean).join(\" \");\n }\n }\n return { ...slotProps, ...overrideProps };\n}\nfunction getElementRef(element) {\n let getter = Object.getOwnPropertyDescriptor(element.props, \"ref\")?.get;\n let mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.ref;\n }\n getter = Object.getOwnPropertyDescriptor(element, \"ref\")?.get;\n mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.props.ref;\n }\n return element.props.ref || element.ref;\n}\nexport {\n Slot as Root,\n Slot,\n Slottable,\n createSlot,\n createSlottable\n};\n//# sourceMappingURL=index.mjs.map\n","// src/primitive.tsx\nimport * as React from \"react\";\nimport * as ReactDOM from \"react-dom\";\nimport { createSlot } from \"@radix-ui/react-slot\";\nimport { jsx } from \"react/jsx-runtime\";\nvar NODES = [\n \"a\",\n \"button\",\n \"div\",\n \"form\",\n \"h2\",\n \"h3\",\n \"img\",\n \"input\",\n \"label\",\n \"li\",\n \"nav\",\n \"ol\",\n \"p\",\n \"select\",\n \"span\",\n \"svg\",\n \"ul\"\n];\nvar Primitive = NODES.reduce((primitive, node) => {\n const Slot = createSlot(`Primitive.${node}`);\n const Node = React.forwardRef((props, forwardedRef) => {\n const { asChild, ...primitiveProps } = props;\n const Comp = asChild ? Slot : node;\n if (typeof window !== \"undefined\") {\n window[Symbol.for(\"radix-ui\")] = true;\n }\n return /* @__PURE__ */ jsx(Comp, { ...primitiveProps, ref: forwardedRef });\n });\n Node.displayName = `Primitive.${node}`;\n return { ...primitive, [node]: Node };\n}, {});\nfunction dispatchDiscreteCustomEvent(target, event) {\n if (target) ReactDOM.flushSync(() => target.dispatchEvent(event));\n}\nvar Root = Primitive;\nexport {\n Primitive,\n Root,\n dispatchDiscreteCustomEvent\n};\n//# sourceMappingURL=index.mjs.map\n","// packages/react/use-callback-ref/src/use-callback-ref.tsx\nimport * as React from \"react\";\nfunction useCallbackRef(callback) {\n const callbackRef = React.useRef(callback);\n React.useEffect(() => {\n callbackRef.current = callback;\n });\n return React.useMemo(() => (...args) => callbackRef.current?.(...args), []);\n}\nexport {\n useCallbackRef\n};\n//# sourceMappingURL=index.mjs.map\n","// packages/react/use-escape-keydown/src/use-escape-keydown.tsx\nimport * as React from \"react\";\nimport { useCallbackRef } from \"@radix-ui/react-use-callback-ref\";\nfunction useEscapeKeydown(onEscapeKeyDownProp, ownerDocument = globalThis?.document) {\n const onEscapeKeyDown = useCallbackRef(onEscapeKeyDownProp);\n React.useEffect(() => {\n const handleKeyDown = (event) => {\n if (event.key === \"Escape\") {\n onEscapeKeyDown(event);\n }\n };\n ownerDocument.addEventListener(\"keydown\", handleKeyDown, { capture: true });\n return () => ownerDocument.removeEventListener(\"keydown\", handleKeyDown, { capture: true });\n }, [onEscapeKeyDown, ownerDocument]);\n}\nexport {\n useEscapeKeydown\n};\n//# sourceMappingURL=index.mjs.map\n","\"use client\";\n\n// src/dismissable-layer.tsx\nimport * as React from \"react\";\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\nimport { Primitive, dispatchDiscreteCustomEvent } from \"@radix-ui/react-primitive\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { useCallbackRef } from \"@radix-ui/react-use-callback-ref\";\nimport { useEscapeKeydown } from \"@radix-ui/react-use-escape-keydown\";\nimport { jsx } from \"react/jsx-runtime\";\nvar DISMISSABLE_LAYER_NAME = \"DismissableLayer\";\nvar CONTEXT_UPDATE = \"dismissableLayer.update\";\nvar POINTER_DOWN_OUTSIDE = \"dismissableLayer.pointerDownOutside\";\nvar FOCUS_OUTSIDE = \"dismissableLayer.focusOutside\";\nvar originalBodyPointerEvents;\nvar DismissableLayerContext = React.createContext({\n layers: /* @__PURE__ */ new Set(),\n layersWithOutsidePointerEventsDisabled: /* @__PURE__ */ new Set(),\n branches: /* @__PURE__ */ new Set()\n});\nvar DismissableLayer = React.forwardRef(\n (props, forwardedRef) => {\n const {\n disableOutsidePointerEvents = false,\n onEscapeKeyDown,\n onPointerDownOutside,\n onFocusOutside,\n onInteractOutside,\n onDismiss,\n ...layerProps\n } = props;\n const context = React.useContext(DismissableLayerContext);\n const [node, setNode] = React.useState(null);\n const ownerDocument = node?.ownerDocument ?? globalThis?.document;\n const [, force] = React.useState({});\n const composedRefs = useComposedRefs(forwardedRef, (node2) => setNode(node2));\n const layers = Array.from(context.layers);\n const [highestLayerWithOutsidePointerEventsDisabled] = [...context.layersWithOutsidePointerEventsDisabled].slice(-1);\n const highestLayerWithOutsidePointerEventsDisabledIndex = layers.indexOf(highestLayerWithOutsidePointerEventsDisabled);\n const index = node ? layers.indexOf(node) : -1;\n const isBodyPointerEventsDisabled = context.layersWithOutsidePointerEventsDisabled.size > 0;\n const isPointerEventsEnabled = index >= highestLayerWithOutsidePointerEventsDisabledIndex;\n const pointerDownOutside = usePointerDownOutside((event) => {\n const target = event.target;\n const isPointerDownOnBranch = [...context.branches].some((branch) => branch.contains(target));\n if (!isPointerEventsEnabled || isPointerDownOnBranch) return;\n onPointerDownOutside?.(event);\n onInteractOutside?.(event);\n if (!event.defaultPrevented) onDismiss?.();\n }, ownerDocument);\n const focusOutside = useFocusOutside((event) => {\n const target = event.target;\n const isFocusInBranch = [...context.branches].some((branch) => branch.contains(target));\n if (isFocusInBranch) return;\n onFocusOutside?.(event);\n onInteractOutside?.(event);\n if (!event.defaultPrevented) onDismiss?.();\n }, ownerDocument);\n useEscapeKeydown((event) => {\n const isHighestLayer = index === context.layers.size - 1;\n if (!isHighestLayer) return;\n onEscapeKeyDown?.(event);\n if (!event.defaultPrevented && onDismiss) {\n event.preventDefault();\n onDismiss();\n }\n }, ownerDocument);\n React.useEffect(() => {\n if (!node) return;\n if (disableOutsidePointerEvents) {\n if (context.layersWithOutsidePointerEventsDisabled.size === 0) {\n originalBodyPointerEvents = ownerDocument.body.style.pointerEvents;\n ownerDocument.body.style.pointerEvents = \"none\";\n }\n context.layersWithOutsidePointerEventsDisabled.add(node);\n }\n context.layers.add(node);\n dispatchUpdate();\n return () => {\n if (disableOutsidePointerEvents && context.layersWithOutsidePointerEventsDisabled.size === 1) {\n ownerDocument.body.style.pointerEvents = originalBodyPointerEvents;\n }\n };\n }, [node, ownerDocument, disableOutsidePointerEvents, context]);\n React.useEffect(() => {\n return () => {\n if (!node) return;\n context.layers.delete(node);\n context.layersWithOutsidePointerEventsDisabled.delete(node);\n dispatchUpdate();\n };\n }, [node, context]);\n React.useEffect(() => {\n const handleUpdate = () => force({});\n document.addEventListener(CONTEXT_UPDATE, handleUpdate);\n return () => document.removeEventListener(CONTEXT_UPDATE, handleUpdate);\n }, []);\n return /* @__PURE__ */ jsx(\n Primitive.div,\n {\n ...layerProps,\n ref: composedRefs,\n style: {\n pointerEvents: isBodyPointerEventsDisabled ? isPointerEventsEnabled ? \"auto\" : \"none\" : void 0,\n ...props.style\n },\n onFocusCapture: composeEventHandlers(props.onFocusCapture, focusOutside.onFocusCapture),\n onBlurCapture: composeEventHandlers(props.onBlurCapture, focusOutside.onBlurCapture),\n onPointerDownCapture: composeEventHandlers(\n props.onPointerDownCapture,\n pointerDownOutside.onPointerDownCapture\n )\n }\n );\n }\n);\nDismissableLayer.displayName = DISMISSABLE_LAYER_NAME;\nvar BRANCH_NAME = \"DismissableLayerBranch\";\nvar DismissableLayerBranch = React.forwardRef((props, forwardedRef) => {\n const context = React.useContext(DismissableLayerContext);\n const ref = React.useRef(null);\n const composedRefs = useComposedRefs(forwardedRef, ref);\n React.useEffect(() => {\n const node = ref.current;\n if (node) {\n context.branches.add(node);\n return () => {\n context.branches.delete(node);\n };\n }\n }, [context.branches]);\n return /* @__PURE__ */ jsx(Primitive.div, { ...props, ref: composedRefs });\n});\nDismissableLayerBranch.displayName = BRANCH_NAME;\nfunction usePointerDownOutside(onPointerDownOutside, ownerDocument = globalThis?.document) {\n const handlePointerDownOutside = useCallbackRef(onPointerDownOutside);\n const isPointerInsideReactTreeRef = React.useRef(false);\n const handleClickRef = React.useRef(() => {\n });\n React.useEffect(() => {\n const handlePointerDown = (event) => {\n if (event.target && !isPointerInsideReactTreeRef.current) {\n let handleAndDispatchPointerDownOutsideEvent2 = function() {\n handleAndDispatchCustomEvent(\n POINTER_DOWN_OUTSIDE,\n handlePointerDownOutside,\n eventDetail,\n { discrete: true }\n );\n };\n var handleAndDispatchPointerDownOutsideEvent = handleAndDispatchPointerDownOutsideEvent2;\n const eventDetail = { originalEvent: event };\n if (event.pointerType === \"touch\") {\n ownerDocument.removeEventListener(\"click\", handleClickRef.current);\n handleClickRef.current = handleAndDispatchPointerDownOutsideEvent2;\n ownerDocument.addEventListener(\"click\", handleClickRef.current, { once: true });\n } else {\n handleAndDispatchPointerDownOutsideEvent2();\n }\n } else {\n ownerDocument.removeEventListener(\"click\", handleClickRef.current);\n }\n isPointerInsideReactTreeRef.current = false;\n };\n const timerId = window.setTimeout(() => {\n ownerDocument.addEventListener(\"pointerdown\", handlePointerDown);\n }, 0);\n return () => {\n window.clearTimeout(timerId);\n ownerDocument.removeEventListener(\"pointerdown\", handlePointerDown);\n ownerDocument.removeEventListener(\"click\", handleClickRef.current);\n };\n }, [ownerDocument, handlePointerDownOutside]);\n return {\n // ensures we check React component tree (not just DOM tree)\n onPointerDownCapture: () => isPointerInsideReactTreeRef.current = true\n };\n}\nfunction useFocusOutside(onFocusOutside, ownerDocument = globalThis?.document) {\n const handleFocusOutside = useCallbackRef(onFocusOutside);\n const isFocusInsideReactTreeRef = React.useRef(false);\n React.useEffect(() => {\n const handleFocus = (event) => {\n if (event.target && !isFocusInsideReactTreeRef.current) {\n const eventDetail = { originalEvent: event };\n handleAndDispatchCustomEvent(FOCUS_OUTSIDE, handleFocusOutside, eventDetail, {\n discrete: false\n });\n }\n };\n ownerDocument.addEventListener(\"focusin\", handleFocus);\n return () => ownerDocument.removeEventListener(\"focusin\", handleFocus);\n }, [ownerDocument, handleFocusOutside]);\n return {\n onFocusCapture: () => isFocusInsideReactTreeRef.current = true,\n onBlurCapture: () => isFocusInsideReactTreeRef.current = false\n };\n}\nfunction dispatchUpdate() {\n const event = new CustomEvent(CONTEXT_UPDATE);\n document.dispatchEvent(event);\n}\nfunction handleAndDispatchCustomEvent(name, handler, detail, { discrete }) {\n const target = detail.originalEvent.target;\n const event = new CustomEvent(name, { bubbles: false, cancelable: true, detail });\n if (handler) target.addEventListener(name, handler, { once: true });\n if (discrete) {\n dispatchDiscreteCustomEvent(target, event);\n } else {\n target.dispatchEvent(event);\n }\n}\nvar Root = DismissableLayer;\nvar Branch = DismissableLayerBranch;\nexport {\n Branch,\n DismissableLayer,\n DismissableLayerBranch,\n Root\n};\n//# sourceMappingURL=index.mjs.map\n","\"use client\";\n\n// src/focus-guards.tsx\nimport * as React from \"react\";\nvar count = 0;\nfunction FocusGuards(props) {\n useFocusGuards();\n return props.children;\n}\nfunction useFocusGuards() {\n React.useEffect(() => {\n const edgeGuards = document.querySelectorAll(\"[data-radix-focus-guard]\");\n document.body.insertAdjacentElement(\"afterbegin\", edgeGuards[0] ?? createFocusGuard());\n document.body.insertAdjacentElement(\"beforeend\", edgeGuards[1] ?? createFocusGuard());\n count++;\n return () => {\n if (count === 1) {\n document.querySelectorAll(\"[data-radix-focus-guard]\").forEach((node) => node.remove());\n }\n count--;\n };\n }, []);\n}\nfunction createFocusGuard() {\n const element = document.createElement(\"span\");\n element.setAttribute(\"data-radix-focus-guard\", \"\");\n element.tabIndex = 0;\n element.style.outline = \"none\";\n element.style.opacity = \"0\";\n element.style.position = \"fixed\";\n element.style.pointerEvents = \"none\";\n return element;\n}\nexport {\n FocusGuards,\n FocusGuards as Root,\n useFocusGuards\n};\n//# sourceMappingURL=index.mjs.map\n","\"use client\";\n\n// src/focus-scope.tsx\nimport * as React from \"react\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { useCallbackRef } from \"@radix-ui/react-use-callback-ref\";\nimport { jsx } from \"react/jsx-runtime\";\nvar AUTOFOCUS_ON_MOUNT = \"focusScope.autoFocusOnMount\";\nvar AUTOFOCUS_ON_UNMOUNT = \"focusScope.autoFocusOnUnmount\";\nvar EVENT_OPTIONS = { bubbles: false, cancelable: true };\nvar FOCUS_SCOPE_NAME = \"FocusScope\";\nvar FocusScope = React.forwardRef((props, forwardedRef) => {\n const {\n loop = false,\n trapped = false,\n onMountAutoFocus: onMountAutoFocusProp,\n onUnmountAutoFocus: onUnmountAutoFocusProp,\n ...scopeProps\n } = props;\n const [container, setContainer] = React.useState(null);\n const onMountAutoFocus = useCallbackRef(onMountAutoFocusProp);\n const onUnmountAutoFocus = useCallbackRef(onUnmountAutoFocusProp);\n const lastFocusedElementRef = React.useRef(null);\n const composedRefs = useComposedRefs(forwardedRef, (node) => setContainer(node));\n const focusScope = React.useRef({\n paused: false,\n pause() {\n this.paused = true;\n },\n resume() {\n this.paused = false;\n }\n }).current;\n React.useEffect(() => {\n if (trapped) {\n let handleFocusIn2 = function(event) {\n if (focusScope.paused || !container) return;\n const target = event.target;\n if (container.contains(target)) {\n lastFocusedElementRef.current = target;\n } else {\n focus(lastFocusedElementRef.current, { select: true });\n }\n }, handleFocusOut2 = function(event) {\n if (focusScope.paused || !container) return;\n const relatedTarget = event.relatedTarget;\n if (relatedTarget === null) return;\n if (!container.contains(relatedTarget)) {\n focus(lastFocusedElementRef.current, { select: true });\n }\n }, handleMutations2 = function(mutations) {\n const focusedElement = document.activeElement;\n if (focusedElement !== document.body) return;\n for (const mutation of mutations) {\n if (mutation.removedNodes.length > 0) focus(container);\n }\n };\n var handleFocusIn = handleFocusIn2, handleFocusOut = handleFocusOut2, handleMutations = handleMutations2;\n document.addEventListener(\"focusin\", handleFocusIn2);\n document.addEventListener(\"focusout\", handleFocusOut2);\n const mutationObserver = new MutationObserver(handleMutations2);\n if (container) mutationObserver.observe(container, { childList: true, subtree: true });\n return () => {\n document.removeEventListener(\"focusin\", handleFocusIn2);\n document.removeEventListener(\"focusout\", handleFocusOut2);\n mutationObserver.disconnect();\n };\n }\n }, [trapped, container, focusScope.paused]);\n React.useEffect(() => {\n if (container) {\n focusScopesStack.add(focusScope);\n const previouslyFocusedElement = document.activeElement;\n const hasFocusedCandidate = container.contains(previouslyFocusedElement);\n if (!hasFocusedCandidate) {\n const mountEvent = new CustomEvent(AUTOFOCUS_ON_MOUNT, EVENT_OPTIONS);\n container.addEventListener(AUTOFOCUS_ON_MOUNT, onMountAutoFocus);\n container.dispatchEvent(mountEvent);\n if (!mountEvent.defaultPrevented) {\n focusFirst(removeLinks(getTabbableCandidates(container)), { select: true });\n if (document.activeElement === previouslyFocusedElement) {\n focus(container);\n }\n }\n }\n return () => {\n container.removeEventListener(AUTOFOCUS_ON_MOUNT, onMountAutoFocus);\n setTimeout(() => {\n const unmountEvent = new CustomEvent(AUTOFOCUS_ON_UNMOUNT, EVENT_OPTIONS);\n container.addEventListener(AUTOFOCUS_ON_UNMOUNT, onUnmountAutoFocus);\n container.dispatchEvent(unmountEvent);\n if (!unmountEvent.defaultPrevented) {\n focus(previouslyFocusedElement ?? document.body, { select: true });\n }\n container.removeEventListener(AUTOFOCUS_ON_UNMOUNT, onUnmountAutoFocus);\n focusScopesStack.remove(focusScope);\n }, 0);\n };\n }\n }, [container, onMountAutoFocus, onUnmountAutoFocus, focusScope]);\n const handleKeyDown = React.useCallback(\n (event) => {\n if (!loop && !trapped) return;\n if (focusScope.paused) return;\n const isTabKey = event.key === \"Tab\" && !event.altKey && !event.ctrlKey && !event.metaKey;\n const focusedElement = document.activeElement;\n if (isTabKey && focusedElement) {\n const container2 = event.currentTarget;\n const [first, last] = getTabbableEdges(container2);\n const hasTabbableElementsInside = first && last;\n if (!hasTabbableElementsInside) {\n if (focusedElement === container2) event.preventDefault();\n } else {\n if (!event.shiftKey && focusedElement === last) {\n event.preventDefault();\n if (loop) focus(first, { select: true });\n } else if (event.shiftKey && focusedElement === first) {\n event.preventDefault();\n if (loop) focus(last, { select: true });\n }\n }\n }\n },\n [loop, trapped, focusScope.paused]\n );\n return /* @__PURE__ */ jsx(Primitive.div, { tabIndex: -1, ...scopeProps, ref: composedRefs, onKeyDown: handleKeyDown });\n});\nFocusScope.displayName = FOCUS_SCOPE_NAME;\nfunction focusFirst(candidates, { select = false } = {}) {\n const previouslyFocusedElement = document.activeElement;\n for (const candidate of candidates) {\n focus(candidate, { select });\n if (document.activeElement !== previouslyFocusedElement) return;\n }\n}\nfunction getTabbableEdges(container) {\n const candidates = getTabbableCandidates(container);\n const first = findVisible(candidates, container);\n const last = findVisible(candidates.reverse(), container);\n return [first, last];\n}\nfunction getTabbableCandidates(container) {\n const nodes = [];\n const walker = document.createTreeWalker(container, NodeFilter.SHOW_ELEMENT, {\n acceptNode: (node) => {\n const isHiddenInput = node.tagName === \"INPUT\" && node.type === \"hidden\";\n if (node.disabled || node.hidden || isHiddenInput) return NodeFilter.FILTER_SKIP;\n return node.tabIndex >= 0 ? NodeFilter.FILTER_ACCEPT : NodeFilter.FILTER_SKIP;\n }\n });\n while (walker.nextNode()) nodes.push(walker.currentNode);\n return nodes;\n}\nfunction findVisible(elements, container) {\n for (const element of elements) {\n if (!isHidden(element, { upTo: container })) return element;\n }\n}\nfunction isHidden(node, { upTo }) {\n if (getComputedStyle(node).visibility === \"hidden\") return true;\n while (node) {\n if (upTo !== void 0 && node === upTo) return false;\n if (getComputedStyle(node).display === \"none\") return true;\n node = node.parentElement;\n }\n return false;\n}\nfunction isSelectableInput(element) {\n return element instanceof HTMLInputElement && \"select\" in element;\n}\nfunction focus(element, { select = false } = {}) {\n if (element && element.focus) {\n const previouslyFocusedElement = document.activeElement;\n element.focus({ preventScroll: true });\n if (element !== previouslyFocusedElement && isSelectableInput(element) && select)\n element.select();\n }\n}\nvar focusScopesStack = createFocusScopesStack();\nfunction createFocusScopesStack() {\n let stack = [];\n return {\n add(focusScope) {\n const activeFocusScope = stack[0];\n if (focusScope !== activeFocusScope) {\n activeFocusScope?.pause();\n }\n stack = arrayRemove(stack, focusScope);\n stack.unshift(focusScope);\n },\n remove(focusScope) {\n stack = arrayRemove(stack, focusScope);\n stack[0]?.resume();\n }\n };\n}\nfunction arrayRemove(array, item) {\n const updatedArray = [...array];\n const index = updatedArray.indexOf(item);\n if (index !== -1) {\n updatedArray.splice(index, 1);\n }\n return updatedArray;\n}\nfunction removeLinks(items) {\n return items.filter((item) => item.tagName !== \"A\");\n}\nvar Root = FocusScope;\nexport {\n FocusScope,\n Root\n};\n//# sourceMappingURL=index.mjs.map\n","// packages/react/use-layout-effect/src/use-layout-effect.tsx\nimport * as React from \"react\";\nvar useLayoutEffect2 = globalThis?.document ? React.useLayoutEffect : () => {\n};\nexport {\n useLayoutEffect2 as useLayoutEffect\n};\n//# sourceMappingURL=index.mjs.map\n","// packages/react/id/src/id.tsx\nimport * as React from \"react\";\nimport { useLayoutEffect } from \"@radix-ui/react-use-layout-effect\";\nvar useReactId = React[\" useId \".trim().toString()] || (() => void 0);\nvar count = 0;\nfunction useId(deterministicId) {\n const [id, setId] = React.useState(useReactId());\n useLayoutEffect(() => {\n if (!deterministicId) setId((reactId) => reactId ?? String(count++));\n }, [deterministicId]);\n return deterministicId || (id ? `radix-${id}` : \"\");\n}\nexport {\n useId\n};\n//# sourceMappingURL=index.mjs.map\n","/**\n * Custom positioning reference element.\n * @see https://floating-ui.com/docs/virtual-elements\n */\n\nconst sides = ['top', 'right', 'bottom', 'left'];\nconst alignments = ['start', 'end'];\nconst placements = /*#__PURE__*/sides.reduce((acc, side) => acc.concat(side, side + \"-\" + alignments[0], side + \"-\" + alignments[1]), []);\nconst min = Math.min;\nconst max = Math.max;\nconst round = Math.round;\nconst floor = Math.floor;\nconst createCoords = v => ({\n x: v,\n y: v\n});\nconst oppositeSideMap = {\n left: 'right',\n right: 'left',\n bottom: 'top',\n top: 'bottom'\n};\nfunction clamp(start, value, end) {\n return max(start, min(value, end));\n}\nfunction evaluate(value, param) {\n return typeof value === 'function' ? value(param) : value;\n}\nfunction getSide(placement) {\n return placement.split('-')[0];\n}\nfunction getAlignment(placement) {\n return placement.split('-')[1];\n}\nfunction getOppositeAxis(axis) {\n return axis === 'x' ? 'y' : 'x';\n}\nfunction getAxisLength(axis) {\n return axis === 'y' ? 'height' : 'width';\n}\nfunction getSideAxis(placement) {\n const firstChar = placement[0];\n return firstChar === 't' || firstChar === 'b' ? 'y' : 'x';\n}\nfunction getAlignmentAxis(placement) {\n return getOppositeAxis(getSideAxis(placement));\n}\nfunction getAlignmentSides(placement, rects, rtl) {\n if (rtl === void 0) {\n rtl = false;\n }\n const alignment = getAlignment(placement);\n const alignmentAxis = getAlignmentAxis(placement);\n const length = getAxisLength(alignmentAxis);\n let mainAlignmentSide = alignmentAxis === 'x' ? alignment === (rtl ? 'end' : 'start') ? 'right' : 'left' : alignment === 'start' ? 'bottom' : 'top';\n if (rects.reference[length] > rects.floating[length]) {\n mainAlignmentSide = getOppositePlacement(mainAlignmentSide);\n }\n return [mainAlignmentSide, getOppositePlacement(mainAlignmentSide)];\n}\nfunction getExpandedPlacements(placement) {\n const oppositePlacement = getOppositePlacement(placement);\n return [getOppositeAlignmentPlacement(placement), oppositePlacement, getOppositeAlignmentPlacement(oppositePlacement)];\n}\nfunction getOppositeAlignmentPlacement(placement) {\n return placement.includes('start') ? placement.replace('start', 'end') : placement.replace('end', 'start');\n}\nconst lrPlacement = ['left', 'right'];\nconst rlPlacement = ['right', 'left'];\nconst tbPlacement = ['top', 'bottom'];\nconst btPlacement = ['bottom', 'top'];\nfunction getSideList(side, isStart, rtl) {\n switch (side) {\n case 'top':\n case 'bottom':\n if (rtl) return isStart ? rlPlacement : lrPlacement;\n return isStart ? lrPlacement : rlPlacement;\n case 'left':\n case 'right':\n return isStart ? tbPlacement : btPlacement;\n default:\n return [];\n }\n}\nfunction getOppositeAxisPlacements(placement, flipAlignment, direction, rtl) {\n const alignment = getAlignment(placement);\n let list = getSideList(getSide(placement), direction === 'start', rtl);\n if (alignment) {\n list = list.map(side => side + \"-\" + alignment);\n if (flipAlignment) {\n list = list.concat(list.map(getOppositeAlignmentPlacement));\n }\n }\n return list;\n}\nfunction getOppositePlacement(placement) {\n const side = getSide(placement);\n return oppositeSideMap[side] + placement.slice(side.length);\n}\nfunction expandPaddingObject(padding) {\n return {\n top: 0,\n right: 0,\n bottom: 0,\n left: 0,\n ...padding\n };\n}\nfunction getPaddingObject(padding) {\n return typeof padding !== 'number' ? expandPaddingObject(padding) : {\n top: padding,\n right: padding,\n bottom: padding,\n left: padding\n };\n}\nfunction rectToClientRect(rect) {\n const {\n x,\n y,\n width,\n height\n } = rect;\n return {\n width,\n height,\n top: y,\n left: x,\n right: x + width,\n bottom: y + height,\n x,\n y\n };\n}\n\nexport { alignments, clamp, createCoords, evaluate, expandPaddingObject, floor, getAlignment, getAlignmentAxis, getAlignmentSides, getAxisLength, getExpandedPlacements, getOppositeAlignmentPlacement, getOppositeAxis, getOppositeAxisPlacements, getOppositePlacement, getPaddingObject, getSide, getSideAxis, max, min, placements, rectToClientRect, round, sides };\n","import { getSideAxis, getAlignmentAxis, getAxisLength, getSide, getAlignment, evaluate, getPaddingObject, rectToClientRect, min, clamp, placements, getAlignmentSides, getOppositeAlignmentPlacement, getOppositePlacement, getExpandedPlacements, getOppositeAxisPlacements, sides, max, getOppositeAxis } from '@floating-ui/utils';\nexport { rectToClientRect } from '@floating-ui/utils';\n\nfunction computeCoordsFromPlacement(_ref, placement, rtl) {\n let {\n reference,\n floating\n } = _ref;\n const sideAxis = getSideAxis(placement);\n const alignmentAxis = getAlignmentAxis(placement);\n const alignLength = getAxisLength(alignmentAxis);\n const side = getSide(placement);\n const isVertical = sideAxis === 'y';\n const commonX = reference.x + reference.width / 2 - floating.width / 2;\n const commonY = reference.y + reference.height / 2 - floating.height / 2;\n const commonAlign = reference[alignLength] / 2 - floating[alignLength] / 2;\n let coords;\n switch (side) {\n case 'top':\n coords = {\n x: commonX,\n y: reference.y - floating.height\n };\n break;\n case 'bottom':\n coords = {\n x: commonX,\n y: reference.y + reference.height\n };\n break;\n case 'right':\n coords = {\n x: reference.x + reference.width,\n y: commonY\n };\n break;\n case 'left':\n coords = {\n x: reference.x - floating.width,\n y: commonY\n };\n break;\n default:\n coords = {\n x: reference.x,\n y: reference.y\n };\n }\n switch (getAlignment(placement)) {\n case 'start':\n coords[alignmentAxis] -= commonAlign * (rtl && isVertical ? -1 : 1);\n break;\n case 'end':\n coords[alignmentAxis] += commonAlign * (rtl && isVertical ? -1 : 1);\n break;\n }\n return coords;\n}\n\n/**\n * Resolves with an object of overflow side offsets that determine how much the\n * element is overflowing a given clipping boundary on each side.\n * - positive = overflowing the boundary by that number of pixels\n * - negative = how many pixels left before it will overflow\n * - 0 = lies flush with the boundary\n * @see https://floating-ui.com/docs/detectOverflow\n */\nasync function detectOverflow(state, options) {\n var _await$platform$isEle;\n if (options === void 0) {\n options = {};\n }\n const {\n x,\n y,\n platform,\n rects,\n elements,\n strategy\n } = state;\n const {\n boundary = 'clippingAncestors',\n rootBoundary = 'viewport',\n elementContext = 'floating',\n altBoundary = false,\n padding = 0\n } = evaluate(options, state);\n const paddingObject = getPaddingObject(padding);\n const altContext = elementContext === 'floating' ? 'reference' : 'floating';\n const element = elements[altBoundary ? altContext : elementContext];\n const clippingClientRect = rectToClientRect(await platform.getClippingRect({\n element: ((_await$platform$isEle = await (platform.isElement == null ? void 0 : platform.isElement(element))) != null ? _await$platform$isEle : true) ? element : element.contextElement || (await (platform.getDocumentElement == null ? void 0 : platform.getDocumentElement(elements.floating))),\n boundary,\n rootBoundary,\n strategy\n }));\n const rect = elementContext === 'floating' ? {\n x,\n y,\n width: rects.floating.width,\n height: rects.floating.height\n } : rects.reference;\n const offsetParent = await (platform.getOffsetParent == null ? void 0 : platform.getOffsetParent(elements.floating));\n const offsetScale = (await (platform.isElement == null ? void 0 : platform.isElement(offsetParent))) ? (await (platform.getScale == null ? void 0 : platform.getScale(offsetParent))) || {\n x: 1,\n y: 1\n } : {\n x: 1,\n y: 1\n };\n const elementClientRect = rectToClientRect(platform.convertOffsetParentRelativeRectToViewportRelativeRect ? await platform.convertOffsetParentRelativeRectToViewportRelativeRect({\n elements,\n rect,\n offsetParent,\n strategy\n }) : rect);\n return {\n top: (clippingClientRect.top - elementClientRect.top + paddingObject.top) / offsetScale.y,\n bottom: (elementClientRect.bottom - clippingClientRect.bottom + paddingObject.bottom) / offsetScale.y,\n left: (clippingClientRect.left - elementClientRect.left + paddingObject.left) / offsetScale.x,\n right: (elementClientRect.right - clippingClientRect.right + paddingObject.right) / offsetScale.x\n };\n}\n\n// Maximum number of resets that can occur before bailing to avoid infinite reset loops.\nconst MAX_RESET_COUNT = 50;\n\n/**\n * Computes the `x` and `y` coordinates that will place the floating element\n * next to a given reference element.\n *\n * This export does not have any `platform` interface logic. You will need to\n * write one for the platform you are using Floating UI with.\n */\nconst computePosition = async (reference, floating, config) => {\n const {\n placement = 'bottom',\n strategy = 'absolute',\n middleware = [],\n platform\n } = config;\n const platformWithDetectOverflow = platform.detectOverflow ? platform : {\n ...platform,\n detectOverflow\n };\n const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(floating));\n let rects = await platform.getElementRects({\n reference,\n floating,\n strategy\n });\n let {\n x,\n y\n } = computeCoordsFromPlacement(rects, placement, rtl);\n let statefulPlacement = placement;\n let resetCount = 0;\n const middlewareData = {};\n for (let i = 0; i < middleware.length; i++) {\n const currentMiddleware = middleware[i];\n if (!currentMiddleware) {\n continue;\n }\n const {\n name,\n fn\n } = currentMiddleware;\n const {\n x: nextX,\n y: nextY,\n data,\n reset\n } = await fn({\n x,\n y,\n initialPlacement: placement,\n placement: statefulPlacement,\n strategy,\n middlewareData,\n rects,\n platform: platformWithDetectOverflow,\n elements: {\n reference,\n floating\n }\n });\n x = nextX != null ? nextX : x;\n y = nextY != null ? nextY : y;\n middlewareData[name] = {\n ...middlewareData[name],\n ...data\n };\n if (reset && resetCount < MAX_RESET_COUNT) {\n resetCount++;\n if (typeof reset === 'object') {\n if (reset.placement) {\n statefulPlacement = reset.placement;\n }\n if (reset.rects) {\n rects = reset.rects === true ? await platform.getElementRects({\n reference,\n floating,\n strategy\n }) : reset.rects;\n }\n ({\n x,\n y\n } = computeCoordsFromPlacement(rects, statefulPlacement, rtl));\n }\n i = -1;\n }\n }\n return {\n x,\n y,\n placement: statefulPlacement,\n strategy,\n middlewareData\n };\n};\n\n/**\n * Provides data to position an inner element of the floating element so that it\n * appears centered to the reference element.\n * @see https://floating-ui.com/docs/arrow\n */\nconst arrow = options => ({\n name: 'arrow',\n options,\n async fn(state) {\n const {\n x,\n y,\n placement,\n rects,\n platform,\n elements,\n middlewareData\n } = state;\n // Since `element` is required, we don't Partial<> the type.\n const {\n element,\n padding = 0\n } = evaluate(options, state) || {};\n if (element == null) {\n return {};\n }\n const paddingObject = getPaddingObject(padding);\n const coords = {\n x,\n y\n };\n const axis = getAlignmentAxis(placement);\n const length = getAxisLength(axis);\n const arrowDimensions = await platform.getDimensions(element);\n const isYAxis = axis === 'y';\n const minProp = isYAxis ? 'top' : 'left';\n const maxProp = isYAxis ? 'bottom' : 'right';\n const clientProp = isYAxis ? 'clientHeight' : 'clientWidth';\n const endDiff = rects.reference[length] + rects.reference[axis] - coords[axis] - rects.floating[length];\n const startDiff = coords[axis] - rects.reference[axis];\n const arrowOffsetParent = await (platform.getOffsetParent == null ? void 0 : platform.getOffsetParent(element));\n let clientSize = arrowOffsetParent ? arrowOffsetParent[clientProp] : 0;\n\n // DOM platform can return `window` as the `offsetParent`.\n if (!clientSize || !(await (platform.isElement == null ? void 0 : platform.isElement(arrowOffsetParent)))) {\n clientSize = elements.floating[clientProp] || rects.floating[length];\n }\n const centerToReference = endDiff / 2 - startDiff / 2;\n\n // If the padding is large enough that it causes the arrow to no longer be\n // centered, modify the padding so that it is centered.\n const largestPossiblePadding = clientSize / 2 - arrowDimensions[length] / 2 - 1;\n const minPadding = min(paddingObject[minProp], largestPossiblePadding);\n const maxPadding = min(paddingObject[maxProp], largestPossiblePadding);\n\n // Make sure the arrow doesn't overflow the floating element if the center\n // point is outside the floating element's bounds.\n const min$1 = minPadding;\n const max = clientSize - arrowDimensions[length] - maxPadding;\n const center = clientSize / 2 - arrowDimensions[length] / 2 + centerToReference;\n const offset = clamp(min$1, center, max);\n\n // If the reference is small enough that the arrow's padding causes it to\n // to point to nothing for an aligned placement, adjust the offset of the\n // floating element itself. To ensure `shift()` continues to take action,\n // a single reset is performed when this is true.\n const shouldAddOffset = !middlewareData.arrow && getAlignment(placement) != null && center !== offset && rects.reference[length] / 2 - (center < min$1 ? minPadding : maxPadding) - arrowDimensions[length] / 2 < 0;\n const alignmentOffset = shouldAddOffset ? center < min$1 ? center - min$1 : center - max : 0;\n return {\n [axis]: coords[axis] + alignmentOffset,\n data: {\n [axis]: offset,\n centerOffset: center - offset - alignmentOffset,\n ...(shouldAddOffset && {\n alignmentOffset\n })\n },\n reset: shouldAddOffset\n };\n }\n});\n\nfunction getPlacementList(alignment, autoAlignment, allowedPlacements) {\n const allowedPlacementsSortedByAlignment = alignment ? [...allowedPlacements.filter(placement => getAlignment(placement) === alignment), ...allowedPlacements.filter(placement => getAlignment(placement) !== alignment)] : allowedPlacements.filter(placement => getSide(placement) === placement);\n return allowedPlacementsSortedByAlignment.filter(placement => {\n if (alignment) {\n return getAlignment(placement) === alignment || (autoAlignment ? getOppositeAlignmentPlacement(placement) !== placement : false);\n }\n return true;\n });\n}\n/**\n * Optimizes the visibility of the floating element by choosing the placement\n * that has the most space available automatically, without needing to specify a\n * preferred placement. Alternative to `flip`.\n * @see https://floating-ui.com/docs/autoPlacement\n */\nconst autoPlacement = function (options) {\n if (options === void 0) {\n options = {};\n }\n return {\n name: 'autoPlacement',\n options,\n async fn(state) {\n var _middlewareData$autoP, _middlewareData$autoP2, _placementsThatFitOnE;\n const {\n rects,\n middlewareData,\n placement,\n platform,\n elements\n } = state;\n const {\n crossAxis = false,\n alignment,\n allowedPlacements = placements,\n autoAlignment = true,\n ...detectOverflowOptions\n } = evaluate(options, state);\n const placements$1 = alignment !== undefined || allowedPlacements === placements ? getPlacementList(alignment || null, autoAlignment, allowedPlacements) : allowedPlacements;\n const overflow = await platform.detectOverflow(state, detectOverflowOptions);\n const currentIndex = ((_middlewareData$autoP = middlewareData.autoPlacement) == null ? void 0 : _middlewareData$autoP.index) || 0;\n const currentPlacement = placements$1[currentIndex];\n if (currentPlacement == null) {\n return {};\n }\n const alignmentSides = getAlignmentSides(currentPlacement, rects, await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating)));\n\n // Make `computeCoords` start from the right place.\n if (placement !== currentPlacement) {\n return {\n reset: {\n placement: placements$1[0]\n }\n };\n }\n const currentOverflows = [overflow[getSide(currentPlacement)], overflow[alignmentSides[0]], overflow[alignmentSides[1]]];\n const allOverflows = [...(((_middlewareData$autoP2 = middlewareData.autoPlacement) == null ? void 0 : _middlewareData$autoP2.overflows) || []), {\n placement: currentPlacement,\n overflows: currentOverflows\n }];\n const nextPlacement = placements$1[currentIndex + 1];\n\n // There are more placements to check.\n if (nextPlacement) {\n return {\n data: {\n index: currentIndex + 1,\n overflows: allOverflows\n },\n reset: {\n placement: nextPlacement\n }\n };\n }\n const placementsSortedByMostSpace = allOverflows.map(d => {\n const alignment = getAlignment(d.placement);\n return [d.placement, alignment && crossAxis ?\n // Check along the mainAxis and main crossAxis side.\n d.overflows.slice(0, 2).reduce((acc, v) => acc + v, 0) :\n // Check only the mainAxis.\n d.overflows[0], d.overflows];\n }).sort((a, b) => a[1] - b[1]);\n const placementsThatFitOnEachSide = placementsSortedByMostSpace.filter(d => d[2].slice(0,\n // Aligned placements should not check their opposite crossAxis\n // side.\n getAlignment(d[0]) ? 2 : 3).every(v => v <= 0));\n const resetPlacement = ((_placementsThatFitOnE = placementsThatFitOnEachSide[0]) == null ? void 0 : _placementsThatFitOnE[0]) || placementsSortedByMostSpace[0][0];\n if (resetPlacement !== placement) {\n return {\n data: {\n index: currentIndex + 1,\n overflows: allOverflows\n },\n reset: {\n placement: resetPlacement\n }\n };\n }\n return {};\n }\n };\n};\n\n/**\n * Optimizes the visibility of the floating element by flipping the `placement`\n * in order to keep it in view when the preferred placement(s) will overflow the\n * clipping boundary. Alternative to `autoPlacement`.\n * @see https://floating-ui.com/docs/flip\n */\nconst flip = function (options) {\n if (options === void 0) {\n options = {};\n }\n return {\n name: 'flip',\n options,\n async fn(state) {\n var _middlewareData$arrow, _middlewareData$flip;\n const {\n placement,\n middlewareData,\n rects,\n initialPlacement,\n platform,\n elements\n } = state;\n const {\n mainAxis: checkMainAxis = true,\n crossAxis: checkCrossAxis = true,\n fallbackPlacements: specifiedFallbackPlacements,\n fallbackStrategy = 'bestFit',\n fallbackAxisSideDirection = 'none',\n flipAlignment = true,\n ...detectOverflowOptions\n } = evaluate(options, state);\n\n // If a reset by the arrow was caused due to an alignment offset being\n // added, we should skip any logic now since `flip()` has already done its\n // work.\n // https://github.com/floating-ui/floating-ui/issues/2549#issuecomment-1719601643\n if ((_middlewareData$arrow = middlewareData.arrow) != null && _middlewareData$arrow.alignmentOffset) {\n return {};\n }\n const side = getSide(placement);\n const initialSideAxis = getSideAxis(initialPlacement);\n const isBasePlacement = getSide(initialPlacement) === initialPlacement;\n const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating));\n const fallbackPlacements = specifiedFallbackPlacements || (isBasePlacement || !flipAlignment ? [getOppositePlacement(initialPlacement)] : getExpandedPlacements(initialPlacement));\n const hasFallbackAxisSideDirection = fallbackAxisSideDirection !== 'none';\n if (!specifiedFallbackPlacements && hasFallbackAxisSideDirection) {\n fallbackPlacements.push(...getOppositeAxisPlacements(initialPlacement, flipAlignment, fallbackAxisSideDirection, rtl));\n }\n const placements = [initialPlacement, ...fallbackPlacements];\n const overflow = await platform.detectOverflow(state, detectOverflowOptions);\n const overflows = [];\n let overflowsData = ((_middlewareData$flip = middlewareData.flip) == null ? void 0 : _middlewareData$flip.overflows) || [];\n if (checkMainAxis) {\n overflows.push(overflow[side]);\n }\n if (checkCrossAxis) {\n const sides = getAlignmentSides(placement, rects, rtl);\n overflows.push(overflow[sides[0]], overflow[sides[1]]);\n }\n overflowsData = [...overflowsData, {\n placement,\n overflows\n }];\n\n // One or more sides is overflowing.\n if (!overflows.every(side => side <= 0)) {\n var _middlewareData$flip2, _overflowsData$filter;\n const nextIndex = (((_middlewareData$flip2 = middlewareData.flip) == null ? void 0 : _middlewareData$flip2.index) || 0) + 1;\n const nextPlacement = placements[nextIndex];\n if (nextPlacement) {\n const ignoreCrossAxisOverflow = checkCrossAxis === 'alignment' ? initialSideAxis !== getSideAxis(nextPlacement) : false;\n if (!ignoreCrossAxisOverflow ||\n // We leave the current main axis only if every placement on that axis\n // overflows the main axis.\n overflowsData.every(d => getSideAxis(d.placement) === initialSideAxis ? d.overflows[0] > 0 : true)) {\n // Try next placement and re-run the lifecycle.\n return {\n data: {\n index: nextIndex,\n overflows: overflowsData\n },\n reset: {\n placement: nextPlacement\n }\n };\n }\n }\n\n // First, find the candidates that fit on the mainAxis side of overflow,\n // then find the placement that fits the best on the main crossAxis side.\n let resetPlacement = (_overflowsData$filter = overflowsData.filter(d => d.overflows[0] <= 0).sort((a, b) => a.overflows[1] - b.overflows[1])[0]) == null ? void 0 : _overflowsData$filter.placement;\n\n // Otherwise fallback.\n if (!resetPlacement) {\n switch (fallbackStrategy) {\n case 'bestFit':\n {\n var _overflowsData$filter2;\n const placement = (_overflowsData$filter2 = overflowsData.filter(d => {\n if (hasFallbackAxisSideDirection) {\n const currentSideAxis = getSideAxis(d.placement);\n return currentSideAxis === initialSideAxis ||\n // Create a bias to the `y` side axis due to horizontal\n // reading directions favoring greater width.\n currentSideAxis === 'y';\n }\n return true;\n }).map(d => [d.placement, d.overflows.filter(overflow => overflow > 0).reduce((acc, overflow) => acc + overflow, 0)]).sort((a, b) => a[1] - b[1])[0]) == null ? void 0 : _overflowsData$filter2[0];\n if (placement) {\n resetPlacement = placement;\n }\n break;\n }\n case 'initialPlacement':\n resetPlacement = initialPlacement;\n break;\n }\n }\n if (placement !== resetPlacement) {\n return {\n reset: {\n placement: resetPlacement\n }\n };\n }\n }\n return {};\n }\n };\n};\n\nfunction getSideOffsets(overflow, rect) {\n return {\n top: overflow.top - rect.height,\n right: overflow.right - rect.width,\n bottom: overflow.bottom - rect.height,\n left: overflow.left - rect.width\n };\n}\nfunction isAnySideFullyClipped(overflow) {\n return sides.some(side => overflow[side] >= 0);\n}\n/**\n * Provides data to hide the floating element in applicable situations, such as\n * when it is not in the same clipping context as the reference element.\n * @see https://floating-ui.com/docs/hide\n */\nconst hide = function (options) {\n if (options === void 0) {\n options = {};\n }\n return {\n name: 'hide',\n options,\n async fn(state) {\n const {\n rects,\n platform\n } = state;\n const {\n strategy = 'referenceHidden',\n ...detectOverflowOptions\n } = evaluate(options, state);\n switch (strategy) {\n case 'referenceHidden':\n {\n const overflow = await platform.detectOverflow(state, {\n ...detectOverflowOptions,\n elementContext: 'reference'\n });\n const offsets = getSideOffsets(overflow, rects.reference);\n return {\n data: {\n referenceHiddenOffsets: offsets,\n referenceHidden: isAnySideFullyClipped(offsets)\n }\n };\n }\n case 'escaped':\n {\n const overflow = await platform.detectOverflow(state, {\n ...detectOverflowOptions,\n altBoundary: true\n });\n const offsets = getSideOffsets(overflow, rects.floating);\n return {\n data: {\n escapedOffsets: offsets,\n escaped: isAnySideFullyClipped(offsets)\n }\n };\n }\n default:\n {\n return {};\n }\n }\n }\n };\n};\n\nfunction getBoundingRect(rects) {\n const minX = min(...rects.map(rect => rect.left));\n const minY = min(...rects.map(rect => rect.top));\n const maxX = max(...rects.map(rect => rect.right));\n const maxY = max(...rects.map(rect => rect.bottom));\n return {\n x: minX,\n y: minY,\n width: maxX - minX,\n height: maxY - minY\n };\n}\nfunction getRectsByLine(rects) {\n const sortedRects = rects.slice().sort((a, b) => a.y - b.y);\n const groups = [];\n let prevRect = null;\n for (let i = 0; i < sortedRects.length; i++) {\n const rect = sortedRects[i];\n if (!prevRect || rect.y - prevRect.y > prevRect.height / 2) {\n groups.push([rect]);\n } else {\n groups[groups.length - 1].push(rect);\n }\n prevRect = rect;\n }\n return groups.map(rect => rectToClientRect(getBoundingRect(rect)));\n}\n/**\n * Provides improved positioning for inline reference elements that can span\n * over multiple lines, such as hyperlinks or range selections.\n * @see https://floating-ui.com/docs/inline\n */\nconst inline = function (options) {\n if (options === void 0) {\n options = {};\n }\n return {\n name: 'inline',\n options,\n async fn(state) {\n const {\n placement,\n elements,\n rects,\n platform,\n strategy\n } = state;\n // A MouseEvent's client{X,Y} coords can be up to 2 pixels off a\n // ClientRect's bounds, despite the event listener being triggered. A\n // padding of 2 seems to handle this issue.\n const {\n padding = 2,\n x,\n y\n } = evaluate(options, state);\n const nativeClientRects = Array.from((await (platform.getClientRects == null ? void 0 : platform.getClientRects(elements.reference))) || []);\n const clientRects = getRectsByLine(nativeClientRects);\n const fallback = rectToClientRect(getBoundingRect(nativeClientRects));\n const paddingObject = getPaddingObject(padding);\n function getBoundingClientRect() {\n // There are two rects and they are disjoined.\n if (clientRects.length === 2 && clientRects[0].left > clientRects[1].right && x != null && y != null) {\n // Find the first rect in which the point is fully inside.\n return clientRects.find(rect => x > rect.left - paddingObject.left && x < rect.right + paddingObject.right && y > rect.top - paddingObject.top && y < rect.bottom + paddingObject.bottom) || fallback;\n }\n\n // There are 2 or more connected rects.\n if (clientRects.length >= 2) {\n if (getSideAxis(placement) === 'y') {\n const firstRect = clientRects[0];\n const lastRect = clientRects[clientRects.length - 1];\n const isTop = getSide(placement) === 'top';\n const top = firstRect.top;\n const bottom = lastRect.bottom;\n const left = isTop ? firstRect.left : lastRect.left;\n const right = isTop ? firstRect.right : lastRect.right;\n const width = right - left;\n const height = bottom - top;\n return {\n top,\n bottom,\n left,\n right,\n width,\n height,\n x: left,\n y: top\n };\n }\n const isLeftSide = getSide(placement) === 'left';\n const maxRight = max(...clientRects.map(rect => rect.right));\n const minLeft = min(...clientRects.map(rect => rect.left));\n const measureRects = clientRects.filter(rect => isLeftSide ? rect.left === minLeft : rect.right === maxRight);\n const top = measureRects[0].top;\n const bottom = measureRects[measureRects.length - 1].bottom;\n const left = minLeft;\n const right = maxRight;\n const width = right - left;\n const height = bottom - top;\n return {\n top,\n bottom,\n left,\n right,\n width,\n height,\n x: left,\n y: top\n };\n }\n return fallback;\n }\n const resetRects = await platform.getElementRects({\n reference: {\n getBoundingClientRect\n },\n floating: elements.floating,\n strategy\n });\n if (rects.reference.x !== resetRects.reference.x || rects.reference.y !== resetRects.reference.y || rects.reference.width !== resetRects.reference.width || rects.reference.height !== resetRects.reference.height) {\n return {\n reset: {\n rects: resetRects\n }\n };\n }\n return {};\n }\n };\n};\n\nconst originSides = /*#__PURE__*/new Set(['left', 'top']);\n\n// For type backwards-compatibility, the `OffsetOptions` type was also\n// Derivable.\n\nasync function convertValueToCoords(state, options) {\n const {\n placement,\n platform,\n elements\n } = state;\n const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating));\n const side = getSide(placement);\n const alignment = getAlignment(placement);\n const isVertical = getSideAxis(placement) === 'y';\n const mainAxisMulti = originSides.has(side) ? -1 : 1;\n const crossAxisMulti = rtl && isVertical ? -1 : 1;\n const rawValue = evaluate(options, state);\n\n // eslint-disable-next-line prefer-const\n let {\n mainAxis,\n crossAxis,\n alignmentAxis\n } = typeof rawValue === 'number' ? {\n mainAxis: rawValue,\n crossAxis: 0,\n alignmentAxis: null\n } : {\n mainAxis: rawValue.mainAxis || 0,\n crossAxis: rawValue.crossAxis || 0,\n alignmentAxis: rawValue.alignmentAxis\n };\n if (alignment && typeof alignmentAxis === 'number') {\n crossAxis = alignment === 'end' ? alignmentAxis * -1 : alignmentAxis;\n }\n return isVertical ? {\n x: crossAxis * crossAxisMulti,\n y: mainAxis * mainAxisMulti\n } : {\n x: mainAxis * mainAxisMulti,\n y: crossAxis * crossAxisMulti\n };\n}\n\n/**\n * Modifies the placement by translating the floating element along the\n * specified axes.\n * A number (shorthand for `mainAxis` or distance), or an axes configuration\n * object may be passed.\n * @see https://floating-ui.com/docs/offset\n */\nconst offset = function (options) {\n if (options === void 0) {\n options = 0;\n }\n return {\n name: 'offset',\n options,\n async fn(state) {\n var _middlewareData$offse, _middlewareData$arrow;\n const {\n x,\n y,\n placement,\n middlewareData\n } = state;\n const diffCoords = await convertValueToCoords(state, options);\n\n // If the placement is the same and the arrow caused an alignment offset\n // then we don't need to change the positioning coordinates.\n if (placement === ((_middlewareData$offse = middlewareData.offset) == null ? void 0 : _middlewareData$offse.placement) && (_middlewareData$arrow = middlewareData.arrow) != null && _middlewareData$arrow.alignmentOffset) {\n return {};\n }\n return {\n x: x + diffCoords.x,\n y: y + diffCoords.y,\n data: {\n ...diffCoords,\n placement\n }\n };\n }\n };\n};\n\n/**\n * Optimizes the visibility of the floating element by shifting it in order to\n * keep it in view when it will overflow the clipping boundary.\n * @see https://floating-ui.com/docs/shift\n */\nconst shift = function (options) {\n if (options === void 0) {\n options = {};\n }\n return {\n name: 'shift',\n options,\n async fn(state) {\n const {\n x,\n y,\n placement,\n platform\n } = state;\n const {\n mainAxis: checkMainAxis = true,\n crossAxis: checkCrossAxis = false,\n limiter = {\n fn: _ref => {\n let {\n x,\n y\n } = _ref;\n return {\n x,\n y\n };\n }\n },\n ...detectOverflowOptions\n } = evaluate(options, state);\n const coords = {\n x,\n y\n };\n const overflow = await platform.detectOverflow(state, detectOverflowOptions);\n const crossAxis = getSideAxis(getSide(placement));\n const mainAxis = getOppositeAxis(crossAxis);\n let mainAxisCoord = coords[mainAxis];\n let crossAxisCoord = coords[crossAxis];\n if (checkMainAxis) {\n const minSide = mainAxis === 'y' ? 'top' : 'left';\n const maxSide = mainAxis === 'y' ? 'bottom' : 'right';\n const min = mainAxisCoord + overflow[minSide];\n const max = mainAxisCoord - overflow[maxSide];\n mainAxisCoord = clamp(min, mainAxisCoord, max);\n }\n if (checkCrossAxis) {\n const minSide = crossAxis === 'y' ? 'top' : 'left';\n const maxSide = crossAxis === 'y' ? 'bottom' : 'right';\n const min = crossAxisCoord + overflow[minSide];\n const max = crossAxisCoord - overflow[maxSide];\n crossAxisCoord = clamp(min, crossAxisCoord, max);\n }\n const limitedCoords = limiter.fn({\n ...state,\n [mainAxis]: mainAxisCoord,\n [crossAxis]: crossAxisCoord\n });\n return {\n ...limitedCoords,\n data: {\n x: limitedCoords.x - x,\n y: limitedCoords.y - y,\n enabled: {\n [mainAxis]: checkMainAxis,\n [crossAxis]: checkCrossAxis\n }\n }\n };\n }\n };\n};\n/**\n * Built-in `limiter` that will stop `shift()` at a certain point.\n */\nconst limitShift = function (options) {\n if (options === void 0) {\n options = {};\n }\n return {\n options,\n fn(state) {\n const {\n x,\n y,\n placement,\n rects,\n middlewareData\n } = state;\n const {\n offset = 0,\n mainAxis: checkMainAxis = true,\n crossAxis: checkCrossAxis = true\n } = evaluate(options, state);\n const coords = {\n x,\n y\n };\n const crossAxis = getSideAxis(placement);\n const mainAxis = getOppositeAxis(crossAxis);\n let mainAxisCoord = coords[mainAxis];\n let crossAxisCoord = coords[crossAxis];\n const rawOffset = evaluate(offset, state);\n const computedOffset = typeof rawOffset === 'number' ? {\n mainAxis: rawOffset,\n crossAxis: 0\n } : {\n mainAxis: 0,\n crossAxis: 0,\n ...rawOffset\n };\n if (checkMainAxis) {\n const len = mainAxis === 'y' ? 'height' : 'width';\n const limitMin = rects.reference[mainAxis] - rects.floating[len] + computedOffset.mainAxis;\n const limitMax = rects.reference[mainAxis] + rects.reference[len] - computedOffset.mainAxis;\n if (mainAxisCoord < limitMin) {\n mainAxisCoord = limitMin;\n } else if (mainAxisCoord > limitMax) {\n mainAxisCoord = limitMax;\n }\n }\n if (checkCrossAxis) {\n var _middlewareData$offse, _middlewareData$offse2;\n const len = mainAxis === 'y' ? 'width' : 'height';\n const isOriginSide = originSides.has(getSide(placement));\n const limitMin = rects.reference[crossAxis] - rects.floating[len] + (isOriginSide ? ((_middlewareData$offse = middlewareData.offset) == null ? void 0 : _middlewareData$offse[crossAxis]) || 0 : 0) + (isOriginSide ? 0 : computedOffset.crossAxis);\n const limitMax = rects.reference[crossAxis] + rects.reference[len] + (isOriginSide ? 0 : ((_middlewareData$offse2 = middlewareData.offset) == null ? void 0 : _middlewareData$offse2[crossAxis]) || 0) - (isOriginSide ? computedOffset.crossAxis : 0);\n if (crossAxisCoord < limitMin) {\n crossAxisCoord = limitMin;\n } else if (crossAxisCoord > limitMax) {\n crossAxisCoord = limitMax;\n }\n }\n return {\n [mainAxis]: mainAxisCoord,\n [crossAxis]: crossAxisCoord\n };\n }\n };\n};\n\n/**\n * Provides data that allows you to change the size of the floating element —\n * for instance, prevent it from overflowing the clipping boundary or match the\n * width of the reference element.\n * @see https://floating-ui.com/docs/size\n */\nconst size = function (options) {\n if (options === void 0) {\n options = {};\n }\n return {\n name: 'size',\n options,\n async fn(state) {\n var _state$middlewareData, _state$middlewareData2;\n const {\n placement,\n rects,\n platform,\n elements\n } = state;\n const {\n apply = () => {},\n ...detectOverflowOptions\n } = evaluate(options, state);\n const overflow = await platform.detectOverflow(state, detectOverflowOptions);\n const side = getSide(placement);\n const alignment = getAlignment(placement);\n const isYAxis = getSideAxis(placement) === 'y';\n const {\n width,\n height\n } = rects.floating;\n let heightSide;\n let widthSide;\n if (side === 'top' || side === 'bottom') {\n heightSide = side;\n widthSide = alignment === ((await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating))) ? 'start' : 'end') ? 'left' : 'right';\n } else {\n widthSide = side;\n heightSide = alignment === 'end' ? 'top' : 'bottom';\n }\n const maximumClippingHeight = height - overflow.top - overflow.bottom;\n const maximumClippingWidth = width - overflow.left - overflow.right;\n const overflowAvailableHeight = min(height - overflow[heightSide], maximumClippingHeight);\n const overflowAvailableWidth = min(width - overflow[widthSide], maximumClippingWidth);\n const noShift = !state.middlewareData.shift;\n let availableHeight = overflowAvailableHeight;\n let availableWidth = overflowAvailableWidth;\n if ((_state$middlewareData = state.middlewareData.shift) != null && _state$middlewareData.enabled.x) {\n availableWidth = maximumClippingWidth;\n }\n if ((_state$middlewareData2 = state.middlewareData.shift) != null && _state$middlewareData2.enabled.y) {\n availableHeight = maximumClippingHeight;\n }\n if (noShift && !alignment) {\n const xMin = max(overflow.left, 0);\n const xMax = max(overflow.right, 0);\n const yMin = max(overflow.top, 0);\n const yMax = max(overflow.bottom, 0);\n if (isYAxis) {\n availableWidth = width - 2 * (xMin !== 0 || xMax !== 0 ? xMin + xMax : max(overflow.left, overflow.right));\n } else {\n availableHeight = height - 2 * (yMin !== 0 || yMax !== 0 ? yMin + yMax : max(overflow.top, overflow.bottom));\n }\n }\n await apply({\n ...state,\n availableWidth,\n availableHeight\n });\n const nextDimensions = await platform.getDimensions(elements.floating);\n if (width !== nextDimensions.width || height !== nextDimensions.height) {\n return {\n reset: {\n rects: true\n }\n };\n }\n return {};\n }\n };\n};\n\nexport { arrow, autoPlacement, computePosition, detectOverflow, flip, hide, inline, limitShift, offset, shift, size };\n","function hasWindow() {\n return typeof window !== 'undefined';\n}\nfunction getNodeName(node) {\n if (isNode(node)) {\n return (node.nodeName || '').toLowerCase();\n }\n // Mocked nodes in testing environments may not be instances of Node. By\n // returning `#document` an infinite loop won't occur.\n // https://github.com/floating-ui/floating-ui/issues/2317\n return '#document';\n}\nfunction getWindow(node) {\n var _node$ownerDocument;\n return (node == null || (_node$ownerDocument = node.ownerDocument) == null ? void 0 : _node$ownerDocument.defaultView) || window;\n}\nfunction getDocumentElement(node) {\n var _ref;\n return (_ref = (isNode(node) ? node.ownerDocument : node.document) || window.document) == null ? void 0 : _ref.documentElement;\n}\nfunction isNode(value) {\n if (!hasWindow()) {\n return false;\n }\n return value instanceof Node || value instanceof getWindow(value).Node;\n}\nfunction isElement(value) {\n if (!hasWindow()) {\n return false;\n }\n return value instanceof Element || value instanceof getWindow(value).Element;\n}\nfunction isHTMLElement(value) {\n if (!hasWindow()) {\n return false;\n }\n return value instanceof HTMLElement || value instanceof getWindow(value).HTMLElement;\n}\nfunction isShadowRoot(value) {\n if (!hasWindow() || typeof ShadowRoot === 'undefined') {\n return false;\n }\n return value instanceof ShadowRoot || value instanceof getWindow(value).ShadowRoot;\n}\nfunction isOverflowElement(element) {\n const {\n overflow,\n overflowX,\n overflowY,\n display\n } = getComputedStyle(element);\n return /auto|scroll|overlay|hidden|clip/.test(overflow + overflowY + overflowX) && display !== 'inline' && display !== 'contents';\n}\nfunction isTableElement(element) {\n return /^(table|td|th)$/.test(getNodeName(element));\n}\nfunction isTopLayer(element) {\n try {\n if (element.matches(':popover-open')) {\n return true;\n }\n } catch (_e) {\n // no-op\n }\n try {\n return element.matches(':modal');\n } catch (_e) {\n return false;\n }\n}\nconst willChangeRe = /transform|translate|scale|rotate|perspective|filter/;\nconst containRe = /paint|layout|strict|content/;\nconst isNotNone = value => !!value && value !== 'none';\nlet isWebKitValue;\nfunction isContainingBlock(elementOrCss) {\n const css = isElement(elementOrCss) ? getComputedStyle(elementOrCss) : elementOrCss;\n\n // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block\n // https://drafts.csswg.org/css-transforms-2/#individual-transforms\n return isNotNone(css.transform) || isNotNone(css.translate) || isNotNone(css.scale) || isNotNone(css.rotate) || isNotNone(css.perspective) || !isWebKit() && (isNotNone(css.backdropFilter) || isNotNone(css.filter)) || willChangeRe.test(css.willChange || '') || containRe.test(css.contain || '');\n}\nfunction getContainingBlock(element) {\n let currentNode = getParentNode(element);\n while (isHTMLElement(currentNode) && !isLastTraversableNode(currentNode)) {\n if (isContainingBlock(currentNode)) {\n return currentNode;\n } else if (isTopLayer(currentNode)) {\n return null;\n }\n currentNode = getParentNode(currentNode);\n }\n return null;\n}\nfunction isWebKit() {\n if (isWebKitValue == null) {\n isWebKitValue = typeof CSS !== 'undefined' && CSS.supports && CSS.supports('-webkit-backdrop-filter', 'none');\n }\n return isWebKitValue;\n}\nfunction isLastTraversableNode(node) {\n return /^(html|body|#document)$/.test(getNodeName(node));\n}\nfunction getComputedStyle(element) {\n return getWindow(element).getComputedStyle(element);\n}\nfunction getNodeScroll(element) {\n if (isElement(element)) {\n return {\n scrollLeft: element.scrollLeft,\n scrollTop: element.scrollTop\n };\n }\n return {\n scrollLeft: element.scrollX,\n scrollTop: element.scrollY\n };\n}\nfunction getParentNode(node) {\n if (getNodeName(node) === 'html') {\n return node;\n }\n const result =\n // Step into the shadow DOM of the parent of a slotted node.\n node.assignedSlot ||\n // DOM Element detected.\n node.parentNode ||\n // ShadowRoot detected.\n isShadowRoot(node) && node.host ||\n // Fallback.\n getDocumentElement(node);\n return isShadowRoot(result) ? result.host : result;\n}\nfunction getNearestOverflowAncestor(node) {\n const parentNode = getParentNode(node);\n if (isLastTraversableNode(parentNode)) {\n return node.ownerDocument ? node.ownerDocument.body : node.body;\n }\n if (isHTMLElement(parentNode) && isOverflowElement(parentNode)) {\n return parentNode;\n }\n return getNearestOverflowAncestor(parentNode);\n}\nfunction getOverflowAncestors(node, list, traverseIframes) {\n var _node$ownerDocument2;\n if (list === void 0) {\n list = [];\n }\n if (traverseIframes === void 0) {\n traverseIframes = true;\n }\n const scrollableAncestor = getNearestOverflowAncestor(node);\n const isBody = scrollableAncestor === ((_node$ownerDocument2 = node.ownerDocument) == null ? void 0 : _node$ownerDocument2.body);\n const win = getWindow(scrollableAncestor);\n if (isBody) {\n const frameElement = getFrameElement(win);\n return list.concat(win, win.visualViewport || [], isOverflowElement(scrollableAncestor) ? scrollableAncestor : [], frameElement && traverseIframes ? getOverflowAncestors(frameElement) : []);\n } else {\n return list.concat(scrollableAncestor, getOverflowAncestors(scrollableAncestor, [], traverseIframes));\n }\n}\nfunction getFrameElement(win) {\n return win.parent && Object.getPrototypeOf(win.parent) ? win.frameElement : null;\n}\n\nexport { getComputedStyle, getContainingBlock, getDocumentElement, getFrameElement, getNearestOverflowAncestor, getNodeName, getNodeScroll, getOverflowAncestors, getParentNode, getWindow, isContainingBlock, isElement, isHTMLElement, isLastTraversableNode, isNode, isOverflowElement, isShadowRoot, isTableElement, isTopLayer, isWebKit };\n","import { rectToClientRect, arrow as arrow$1, autoPlacement as autoPlacement$1, detectOverflow as detectOverflow$1, flip as flip$1, hide as hide$1, inline as inline$1, limitShift as limitShift$1, offset as offset$1, shift as shift$1, size as size$1, computePosition as computePosition$1 } from '@floating-ui/core';\nimport { round, createCoords, max, min, floor } from '@floating-ui/utils';\nimport { getComputedStyle as getComputedStyle$1, isHTMLElement, isElement, getWindow, isWebKit, getFrameElement, getNodeScroll, getDocumentElement, isTopLayer, getNodeName, isOverflowElement, getOverflowAncestors, getParentNode, isLastTraversableNode, isContainingBlock, isTableElement, getContainingBlock } from '@floating-ui/utils/dom';\nexport { getOverflowAncestors } from '@floating-ui/utils/dom';\n\nfunction getCssDimensions(element) {\n const css = getComputedStyle$1(element);\n // In testing environments, the `width` and `height` properties are empty\n // strings for SVG elements, returning NaN. Fallback to `0` in this case.\n let width = parseFloat(css.width) || 0;\n let height = parseFloat(css.height) || 0;\n const hasOffset = isHTMLElement(element);\n const offsetWidth = hasOffset ? element.offsetWidth : width;\n const offsetHeight = hasOffset ? element.offsetHeight : height;\n const shouldFallback = round(width) !== offsetWidth || round(height) !== offsetHeight;\n if (shouldFallback) {\n width = offsetWidth;\n height = offsetHeight;\n }\n return {\n width,\n height,\n $: shouldFallback\n };\n}\n\nfunction unwrapElement(element) {\n return !isElement(element) ? element.contextElement : element;\n}\n\nfunction getScale(element) {\n const domElement = unwrapElement(element);\n if (!isHTMLElement(domElement)) {\n return createCoords(1);\n }\n const rect = domElement.getBoundingClientRect();\n const {\n width,\n height,\n $\n } = getCssDimensions(domElement);\n let x = ($ ? round(rect.width) : rect.width) / width;\n let y = ($ ? round(rect.height) : rect.height) / height;\n\n // 0, NaN, or Infinity should always fallback to 1.\n\n if (!x || !Number.isFinite(x)) {\n x = 1;\n }\n if (!y || !Number.isFinite(y)) {\n y = 1;\n }\n return {\n x,\n y\n };\n}\n\nconst noOffsets = /*#__PURE__*/createCoords(0);\nfunction getVisualOffsets(element) {\n const win = getWindow(element);\n if (!isWebKit() || !win.visualViewport) {\n return noOffsets;\n }\n return {\n x: win.visualViewport.offsetLeft,\n y: win.visualViewport.offsetTop\n };\n}\nfunction shouldAddVisualOffsets(element, isFixed, floatingOffsetParent) {\n if (isFixed === void 0) {\n isFixed = false;\n }\n if (!floatingOffsetParent || isFixed && floatingOffsetParent !== getWindow(element)) {\n return false;\n }\n return isFixed;\n}\n\nfunction getBoundingClientRect(element, includeScale, isFixedStrategy, offsetParent) {\n if (includeScale === void 0) {\n includeScale = false;\n }\n if (isFixedStrategy === void 0) {\n isFixedStrategy = false;\n }\n const clientRect = element.getBoundingClientRect();\n const domElement = unwrapElement(element);\n let scale = createCoords(1);\n if (includeScale) {\n if (offsetParent) {\n if (isElement(offsetParent)) {\n scale = getScale(offsetParent);\n }\n } else {\n scale = getScale(element);\n }\n }\n const visualOffsets = shouldAddVisualOffsets(domElement, isFixedStrategy, offsetParent) ? getVisualOffsets(domElement) : createCoords(0);\n let x = (clientRect.left + visualOffsets.x) / scale.x;\n let y = (clientRect.top + visualOffsets.y) / scale.y;\n let width = clientRect.width / scale.x;\n let height = clientRect.height / scale.y;\n if (domElement) {\n const win = getWindow(domElement);\n const offsetWin = offsetParent && isElement(offsetParent) ? getWindow(offsetParent) : offsetParent;\n let currentWin = win;\n let currentIFrame = getFrameElement(currentWin);\n while (currentIFrame && offsetParent && offsetWin !== currentWin) {\n const iframeScale = getScale(currentIFrame);\n const iframeRect = currentIFrame.getBoundingClientRect();\n const css = getComputedStyle$1(currentIFrame);\n const left = iframeRect.left + (currentIFrame.clientLeft + parseFloat(css.paddingLeft)) * iframeScale.x;\n const top = iframeRect.top + (currentIFrame.clientTop + parseFloat(css.paddingTop)) * iframeScale.y;\n x *= iframeScale.x;\n y *= iframeScale.y;\n width *= iframeScale.x;\n height *= iframeScale.y;\n x += left;\n y += top;\n currentWin = getWindow(currentIFrame);\n currentIFrame = getFrameElement(currentWin);\n }\n }\n return rectToClientRect({\n width,\n height,\n x,\n y\n });\n}\n\n// If <html> has a CSS width greater than the viewport, then this will be\n// incorrect for RTL.\nfunction getWindowScrollBarX(element, rect) {\n const leftScroll = getNodeScroll(element).scrollLeft;\n if (!rect) {\n return getBoundingClientRect(getDocumentElement(element)).left + leftScroll;\n }\n return rect.left + leftScroll;\n}\n\nfunction getHTMLOffset(documentElement, scroll) {\n const htmlRect = documentElement.getBoundingClientRect();\n const x = htmlRect.left + scroll.scrollLeft - getWindowScrollBarX(documentElement, htmlRect);\n const y = htmlRect.top + scroll.scrollTop;\n return {\n x,\n y\n };\n}\n\nfunction convertOffsetParentRelativeRectToViewportRelativeRect(_ref) {\n let {\n elements,\n rect,\n offsetParent,\n strategy\n } = _ref;\n const isFixed = strategy === 'fixed';\n const documentElement = getDocumentElement(offsetParent);\n const topLayer = elements ? isTopLayer(elements.floating) : false;\n if (offsetParent === documentElement || topLayer && isFixed) {\n return rect;\n }\n let scroll = {\n scrollLeft: 0,\n scrollTop: 0\n };\n let scale = createCoords(1);\n const offsets = createCoords(0);\n const isOffsetParentAnElement = isHTMLElement(offsetParent);\n if (isOffsetParentAnElement || !isOffsetParentAnElement && !isFixed) {\n if (getNodeName(offsetParent) !== 'body' || isOverflowElement(documentElement)) {\n scroll = getNodeScroll(offsetParent);\n }\n if (isOffsetParentAnElement) {\n const offsetRect = getBoundingClientRect(offsetParent);\n scale = getScale(offsetParent);\n offsets.x = offsetRect.x + offsetParent.clientLeft;\n offsets.y = offsetRect.y + offsetParent.clientTop;\n }\n }\n const htmlOffset = documentElement && !isOffsetParentAnElement && !isFixed ? getHTMLOffset(documentElement, scroll) : createCoords(0);\n return {\n width: rect.width * scale.x,\n height: rect.height * scale.y,\n x: rect.x * scale.x - scroll.scrollLeft * scale.x + offsets.x + htmlOffset.x,\n y: rect.y * scale.y - scroll.scrollTop * scale.y + offsets.y + htmlOffset.y\n };\n}\n\nfunction getClientRects(element) {\n return Array.from(element.getClientRects());\n}\n\n// Gets the entire size of the scrollable document area, even extending outside\n// of the `<html>` and `<body>` rect bounds if horizontally scrollable.\nfunction getDocumentRect(element) {\n const html = getDocumentElement(element);\n const scroll = getNodeScroll(element);\n const body = element.ownerDocument.body;\n const width = max(html.scrollWidth, html.clientWidth, body.scrollWidth, body.clientWidth);\n const height = max(html.scrollHeight, html.clientHeight, body.scrollHeight, body.clientHeight);\n let x = -scroll.scrollLeft + getWindowScrollBarX(element);\n const y = -scroll.scrollTop;\n if (getComputedStyle$1(body).direction === 'rtl') {\n x += max(html.clientWidth, body.clientWidth) - width;\n }\n return {\n width,\n height,\n x,\n y\n };\n}\n\n// Safety check: ensure the scrollbar space is reasonable in case this\n// calculation is affected by unusual styles.\n// Most scrollbars leave 15-18px of space.\nconst SCROLLBAR_MAX = 25;\nfunction getViewportRect(element, strategy) {\n const win = getWindow(element);\n const html = getDocumentElement(element);\n const visualViewport = win.visualViewport;\n let width = html.clientWidth;\n let height = html.clientHeight;\n let x = 0;\n let y = 0;\n if (visualViewport) {\n width = visualViewport.width;\n height = visualViewport.height;\n const visualViewportBased = isWebKit();\n if (!visualViewportBased || visualViewportBased && strategy === 'fixed') {\n x = visualViewport.offsetLeft;\n y = visualViewport.offsetTop;\n }\n }\n const windowScrollbarX = getWindowScrollBarX(html);\n // <html> `overflow: hidden` + `scrollbar-gutter: stable` reduces the\n // visual width of the <html> but this is not considered in the size\n // of `html.clientWidth`.\n if (windowScrollbarX <= 0) {\n const doc = html.ownerDocument;\n const body = doc.body;\n const bodyStyles = getComputedStyle(body);\n const bodyMarginInline = doc.compatMode === 'CSS1Compat' ? parseFloat(bodyStyles.marginLeft) + parseFloat(bodyStyles.marginRight) || 0 : 0;\n const clippingStableScrollbarWidth = Math.abs(html.clientWidth - body.clientWidth - bodyMarginInline);\n if (clippingStableScrollbarWidth <= SCROLLBAR_MAX) {\n width -= clippingStableScrollbarWidth;\n }\n } else if (windowScrollbarX <= SCROLLBAR_MAX) {\n // If the <body> scrollbar is on the left, the width needs to be extended\n // by the scrollbar amount so there isn't extra space on the right.\n width += windowScrollbarX;\n }\n return {\n width,\n height,\n x,\n y\n };\n}\n\n// Returns the inner client rect, subtracting scrollbars if present.\nfunction getInnerBoundingClientRect(element, strategy) {\n const clientRect = getBoundingClientRect(element, true, strategy === 'fixed');\n const top = clientRect.top + element.clientTop;\n const left = clientRect.left + element.clientLeft;\n const scale = isHTMLElement(element) ? getScale(element) : createCoords(1);\n const width = element.clientWidth * scale.x;\n const height = element.clientHeight * scale.y;\n const x = left * scale.x;\n const y = top * scale.y;\n return {\n width,\n height,\n x,\n y\n };\n}\nfunction getClientRectFromClippingAncestor(element, clippingAncestor, strategy) {\n let rect;\n if (clippingAncestor === 'viewport') {\n rect = getViewportRect(element, strategy);\n } else if (clippingAncestor === 'document') {\n rect = getDocumentRect(getDocumentElement(element));\n } else if (isElement(clippingAncestor)) {\n rect = getInnerBoundingClientRect(clippingAncestor, strategy);\n } else {\n const visualOffsets = getVisualOffsets(element);\n rect = {\n x: clippingAncestor.x - visualOffsets.x,\n y: clippingAncestor.y - visualOffsets.y,\n width: clippingAncestor.width,\n height: clippingAncestor.height\n };\n }\n return rectToClientRect(rect);\n}\nfunction hasFixedPositionAncestor(element, stopNode) {\n const parentNode = getParentNode(element);\n if (parentNode === stopNode || !isElement(parentNode) || isLastTraversableNode(parentNode)) {\n return false;\n }\n return getComputedStyle$1(parentNode).position === 'fixed' || hasFixedPositionAncestor(parentNode, stopNode);\n}\n\n// A \"clipping ancestor\" is an `overflow` element with the characteristic of\n// clipping (or hiding) child elements. This returns all clipping ancestors\n// of the given element up the tree.\nfunction getClippingElementAncestors(element, cache) {\n const cachedResult = cache.get(element);\n if (cachedResult) {\n return cachedResult;\n }\n let result = getOverflowAncestors(element, [], false).filter(el => isElement(el) && getNodeName(el) !== 'body');\n let currentContainingBlockComputedStyle = null;\n const elementIsFixed = getComputedStyle$1(element).position === 'fixed';\n let currentNode = elementIsFixed ? getParentNode(element) : element;\n\n // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block\n while (isElement(currentNode) && !isLastTraversableNode(currentNode)) {\n const computedStyle = getComputedStyle$1(currentNode);\n const currentNodeIsContaining = isContainingBlock(currentNode);\n if (!currentNodeIsContaining && computedStyle.position === 'fixed') {\n currentContainingBlockComputedStyle = null;\n }\n const shouldDropCurrentNode = elementIsFixed ? !currentNodeIsContaining && !currentContainingBlockComputedStyle : !currentNodeIsContaining && computedStyle.position === 'static' && !!currentContainingBlockComputedStyle && (currentContainingBlockComputedStyle.position === 'absolute' || currentContainingBlockComputedStyle.position === 'fixed') || isOverflowElement(currentNode) && !currentNodeIsContaining && hasFixedPositionAncestor(element, currentNode);\n if (shouldDropCurrentNode) {\n // Drop non-containing blocks.\n result = result.filter(ancestor => ancestor !== currentNode);\n } else {\n // Record last containing block for next iteration.\n currentContainingBlockComputedStyle = computedStyle;\n }\n currentNode = getParentNode(currentNode);\n }\n cache.set(element, result);\n return result;\n}\n\n// Gets the maximum area that the element is visible in due to any number of\n// clipping ancestors.\nfunction getClippingRect(_ref) {\n let {\n element,\n boundary,\n rootBoundary,\n strategy\n } = _ref;\n const elementClippingAncestors = boundary === 'clippingAncestors' ? isTopLayer(element) ? [] : getClippingElementAncestors(element, this._c) : [].concat(boundary);\n const clippingAncestors = [...elementClippingAncestors, rootBoundary];\n const firstRect = getClientRectFromClippingAncestor(element, clippingAncestors[0], strategy);\n let top = firstRect.top;\n let right = firstRect.right;\n let bottom = firstRect.bottom;\n let left = firstRect.left;\n for (let i = 1; i < clippingAncestors.length; i++) {\n const rect = getClientRectFromClippingAncestor(element, clippingAncestors[i], strategy);\n top = max(rect.top, top);\n right = min(rect.right, right);\n bottom = min(rect.bottom, bottom);\n left = max(rect.left, left);\n }\n return {\n width: right - left,\n height: bottom - top,\n x: left,\n y: top\n };\n}\n\nfunction getDimensions(element) {\n const {\n width,\n height\n } = getCssDimensions(element);\n return {\n width,\n height\n };\n}\n\nfunction getRectRelativeToOffsetParent(element, offsetParent, strategy) {\n const isOffsetParentAnElement = isHTMLElement(offsetParent);\n const documentElement = getDocumentElement(offsetParent);\n const isFixed = strategy === 'fixed';\n const rect = getBoundingClientRect(element, true, isFixed, offsetParent);\n let scroll = {\n scrollLeft: 0,\n scrollTop: 0\n };\n const offsets = createCoords(0);\n\n // If the <body> scrollbar appears on the left (e.g. RTL systems). Use\n // Firefox with layout.scrollbar.side = 3 in about:config to test this.\n function setLeftRTLScrollbarOffset() {\n offsets.x = getWindowScrollBarX(documentElement);\n }\n if (isOffsetParentAnElement || !isOffsetParentAnElement && !isFixed) {\n if (getNodeName(offsetParent) !== 'body' || isOverflowElement(documentElement)) {\n scroll = getNodeScroll(offsetParent);\n }\n if (isOffsetParentAnElement) {\n const offsetRect = getBoundingClientRect(offsetParent, true, isFixed, offsetParent);\n offsets.x = offsetRect.x + offsetParent.clientLeft;\n offsets.y = offsetRect.y + offsetParent.clientTop;\n } else if (documentElement) {\n setLeftRTLScrollbarOffset();\n }\n }\n if (isFixed && !isOffsetParentAnElement && documentElement) {\n setLeftRTLScrollbarOffset();\n }\n const htmlOffset = documentElement && !isOffsetParentAnElement && !isFixed ? getHTMLOffset(documentElement, scroll) : createCoords(0);\n const x = rect.left + scroll.scrollLeft - offsets.x - htmlOffset.x;\n const y = rect.top + scroll.scrollTop - offsets.y - htmlOffset.y;\n return {\n x,\n y,\n width: rect.width,\n height: rect.height\n };\n}\n\nfunction isStaticPositioned(element) {\n return getComputedStyle$1(element).position === 'static';\n}\n\nfunction getTrueOffsetParent(element, polyfill) {\n if (!isHTMLElement(element) || getComputedStyle$1(element).position === 'fixed') {\n return null;\n }\n if (polyfill) {\n return polyfill(element);\n }\n let rawOffsetParent = element.offsetParent;\n\n // Firefox returns the <html> element as the offsetParent if it's non-static,\n // while Chrome and Safari return the <body> element. The <body> element must\n // be used to perform the correct calculations even if the <html> element is\n // non-static.\n if (getDocumentElement(element) === rawOffsetParent) {\n rawOffsetParent = rawOffsetParent.ownerDocument.body;\n }\n return rawOffsetParent;\n}\n\n// Gets the closest ancestor positioned element. Handles some edge cases,\n// such as table ancestors and cross browser bugs.\nfunction getOffsetParent(element, polyfill) {\n const win = getWindow(element);\n if (isTopLayer(element)) {\n return win;\n }\n if (!isHTMLElement(element)) {\n let svgOffsetParent = getParentNode(element);\n while (svgOffsetParent && !isLastTraversableNode(svgOffsetParent)) {\n if (isElement(svgOffsetParent) && !isStaticPositioned(svgOffsetParent)) {\n return svgOffsetParent;\n }\n svgOffsetParent = getParentNode(svgOffsetParent);\n }\n return win;\n }\n let offsetParent = getTrueOffsetParent(element, polyfill);\n while (offsetParent && isTableElement(offsetParent) && isStaticPositioned(offsetParent)) {\n offsetParent = getTrueOffsetParent(offsetParent, polyfill);\n }\n if (offsetParent && isLastTraversableNode(offsetParent) && isStaticPositioned(offsetParent) && !isContainingBlock(offsetParent)) {\n return win;\n }\n return offsetParent || getContainingBlock(element) || win;\n}\n\nconst getElementRects = async function (data) {\n const getOffsetParentFn = this.getOffsetParent || getOffsetParent;\n const getDimensionsFn = this.getDimensions;\n const floatingDimensions = await getDimensionsFn(data.floating);\n return {\n reference: getRectRelativeToOffsetParent(data.reference, await getOffsetParentFn(data.floating), data.strategy),\n floating: {\n x: 0,\n y: 0,\n width: floatingDimensions.width,\n height: floatingDimensions.height\n }\n };\n};\n\nfunction isRTL(element) {\n return getComputedStyle$1(element).direction === 'rtl';\n}\n\nconst platform = {\n convertOffsetParentRelativeRectToViewportRelativeRect,\n getDocumentElement,\n getClippingRect,\n getOffsetParent,\n getElementRects,\n getClientRects,\n getDimensions,\n getScale,\n isElement,\n isRTL\n};\n\nfunction rectsAreEqual(a, b) {\n return a.x === b.x && a.y === b.y && a.width === b.width && a.height === b.height;\n}\n\n// https://samthor.au/2021/observing-dom/\nfunction observeMove(element, onMove) {\n let io = null;\n let timeoutId;\n const root = getDocumentElement(element);\n function cleanup() {\n var _io;\n clearTimeout(timeoutId);\n (_io = io) == null || _io.disconnect();\n io = null;\n }\n function refresh(skip, threshold) {\n if (skip === void 0) {\n skip = false;\n }\n if (threshold === void 0) {\n threshold = 1;\n }\n cleanup();\n const elementRectForRootMargin = element.getBoundingClientRect();\n const {\n left,\n top,\n width,\n height\n } = elementRectForRootMargin;\n if (!skip) {\n onMove();\n }\n if (!width || !height) {\n return;\n }\n const insetTop = floor(top);\n const insetRight = floor(root.clientWidth - (left + width));\n const insetBottom = floor(root.clientHeight - (top + height));\n const insetLeft = floor(left);\n const rootMargin = -insetTop + \"px \" + -insetRight + \"px \" + -insetBottom + \"px \" + -insetLeft + \"px\";\n const options = {\n rootMargin,\n threshold: max(0, min(1, threshold)) || 1\n };\n let isFirstUpdate = true;\n function handleObserve(entries) {\n const ratio = entries[0].intersectionRatio;\n if (ratio !== threshold) {\n if (!isFirstUpdate) {\n return refresh();\n }\n if (!ratio) {\n // If the reference is clipped, the ratio is 0. Throttle the refresh\n // to prevent an infinite loop of updates.\n timeoutId = setTimeout(() => {\n refresh(false, 1e-7);\n }, 1000);\n } else {\n refresh(false, ratio);\n }\n }\n if (ratio === 1 && !rectsAreEqual(elementRectForRootMargin, element.getBoundingClientRect())) {\n // It's possible that even though the ratio is reported as 1, the\n // element is not actually fully within the IntersectionObserver's root\n // area anymore. This can happen under performance constraints. This may\n // be a bug in the browser's IntersectionObserver implementation. To\n // work around this, we compare the element's bounding rect now with\n // what it was at the time we created the IntersectionObserver. If they\n // are not equal then the element moved, so we refresh.\n refresh();\n }\n isFirstUpdate = false;\n }\n\n // Older browsers don't support a `document` as the root and will throw an\n // error.\n try {\n io = new IntersectionObserver(handleObserve, {\n ...options,\n // Handle <iframe>s\n root: root.ownerDocument\n });\n } catch (_e) {\n io = new IntersectionObserver(handleObserve, options);\n }\n io.observe(element);\n }\n refresh(true);\n return cleanup;\n}\n\n/**\n * Automatically updates the position of the floating element when necessary.\n * Should only be called when the floating element is mounted on the DOM or\n * visible on the screen.\n * @returns cleanup function that should be invoked when the floating element is\n * removed from the DOM or hidden from the screen.\n * @see https://floating-ui.com/docs/autoUpdate\n */\nfunction autoUpdate(reference, floating, update, options) {\n if (options === void 0) {\n options = {};\n }\n const {\n ancestorScroll = true,\n ancestorResize = true,\n elementResize = typeof ResizeObserver === 'function',\n layoutShift = typeof IntersectionObserver === 'function',\n animationFrame = false\n } = options;\n const referenceEl = unwrapElement(reference);\n const ancestors = ancestorScroll || ancestorResize ? [...(referenceEl ? getOverflowAncestors(referenceEl) : []), ...(floating ? getOverflowAncestors(floating) : [])] : [];\n ancestors.forEach(ancestor => {\n ancestorScroll && ancestor.addEventListener('scroll', update, {\n passive: true\n });\n ancestorResize && ancestor.addEventListener('resize', update);\n });\n const cleanupIo = referenceEl && layoutShift ? observeMove(referenceEl, update) : null;\n let reobserveFrame = -1;\n let resizeObserver = null;\n if (elementResize) {\n resizeObserver = new ResizeObserver(_ref => {\n let [firstEntry] = _ref;\n if (firstEntry && firstEntry.target === referenceEl && resizeObserver && floating) {\n // Prevent update loops when using the `size` middleware.\n // https://github.com/floating-ui/floating-ui/issues/1740\n resizeObserver.unobserve(floating);\n cancelAnimationFrame(reobserveFrame);\n reobserveFrame = requestAnimationFrame(() => {\n var _resizeObserver;\n (_resizeObserver = resizeObserver) == null || _resizeObserver.observe(floating);\n });\n }\n update();\n });\n if (referenceEl && !animationFrame) {\n resizeObserver.observe(referenceEl);\n }\n if (floating) {\n resizeObserver.observe(floating);\n }\n }\n let frameId;\n let prevRefRect = animationFrame ? getBoundingClientRect(reference) : null;\n if (animationFrame) {\n frameLoop();\n }\n function frameLoop() {\n const nextRefRect = getBoundingClientRect(reference);\n if (prevRefRect && !rectsAreEqual(prevRefRect, nextRefRect)) {\n update();\n }\n prevRefRect = nextRefRect;\n frameId = requestAnimationFrame(frameLoop);\n }\n update();\n return () => {\n var _resizeObserver2;\n ancestors.forEach(ancestor => {\n ancestorScroll && ancestor.removeEventListener('scroll', update);\n ancestorResize && ancestor.removeEventListener('resize', update);\n });\n cleanupIo == null || cleanupIo();\n (_resizeObserver2 = resizeObserver) == null || _resizeObserver2.disconnect();\n resizeObserver = null;\n if (animationFrame) {\n cancelAnimationFrame(frameId);\n }\n };\n}\n\n/**\n * Resolves with an object of overflow side offsets that determine how much the\n * element is overflowing a given clipping boundary on each side.\n * - positive = overflowing the boundary by that number of pixels\n * - negative = how many pixels left before it will overflow\n * - 0 = lies flush with the boundary\n * @see https://floating-ui.com/docs/detectOverflow\n */\nconst detectOverflow = detectOverflow$1;\n\n/**\n * Modifies the placement by translating the floating element along the\n * specified axes.\n * A number (shorthand for `mainAxis` or distance), or an axes configuration\n * object may be passed.\n * @see https://floating-ui.com/docs/offset\n */\nconst offset = offset$1;\n\n/**\n * Optimizes the visibility of the floating element by choosing the placement\n * that has the most space available automatically, without needing to specify a\n * preferred placement. Alternative to `flip`.\n * @see https://floating-ui.com/docs/autoPlacement\n */\nconst autoPlacement = autoPlacement$1;\n\n/**\n * Optimizes the visibility of the floating element by shifting it in order to\n * keep it in view when it will overflow the clipping boundary.\n * @see https://floating-ui.com/docs/shift\n */\nconst shift = shift$1;\n\n/**\n * Optimizes the visibility of the floating element by flipping the `placement`\n * in order to keep it in view when the preferred placement(s) will overflow the\n * clipping boundary. Alternative to `autoPlacement`.\n * @see https://floating-ui.com/docs/flip\n */\nconst flip = flip$1;\n\n/**\n * Provides data that allows you to change the size of the floating element —\n * for instance, prevent it from overflowing the clipping boundary or match the\n * width of the reference element.\n * @see https://floating-ui.com/docs/size\n */\nconst size = size$1;\n\n/**\n * Provides data to hide the floating element in applicable situations, such as\n * when it is not in the same clipping context as the reference element.\n * @see https://floating-ui.com/docs/hide\n */\nconst hide = hide$1;\n\n/**\n * Provides data to position an inner element of the floating element so that it\n * appears centered to the reference element.\n * @see https://floating-ui.com/docs/arrow\n */\nconst arrow = arrow$1;\n\n/**\n * Provides improved positioning for inline reference elements that can span\n * over multiple lines, such as hyperlinks or range selections.\n * @see https://floating-ui.com/docs/inline\n */\nconst inline = inline$1;\n\n/**\n * Built-in `limiter` that will stop `shift()` at a certain point.\n */\nconst limitShift = limitShift$1;\n\n/**\n * Computes the `x` and `y` coordinates that will place the floating element\n * next to a given reference element.\n */\nconst computePosition = (reference, floating, options) => {\n // This caches the expensive `getClippingElementAncestors` function so that\n // multiple lifecycle resets re-use the same result. It only lives for a\n // single call. If other functions become expensive, we can add them as well.\n const cache = new Map();\n const mergedOptions = {\n platform,\n ...options\n };\n const platformWithCache = {\n ...mergedOptions.platform,\n _c: cache\n };\n return computePosition$1(reference, floating, {\n ...mergedOptions,\n platform: platformWithCache\n });\n};\n\nexport { arrow, autoPlacement, autoUpdate, computePosition, detectOverflow, flip, hide, inline, limitShift, offset, platform, shift, size };\n","import { computePosition, arrow as arrow$2, autoPlacement as autoPlacement$1, flip as flip$1, hide as hide$1, inline as inline$1, limitShift as limitShift$1, offset as offset$1, shift as shift$1, size as size$1 } from '@floating-ui/dom';\nexport { autoUpdate, computePosition, detectOverflow, getOverflowAncestors, platform } from '@floating-ui/dom';\nimport * as React from 'react';\nimport { useLayoutEffect } from 'react';\nimport * as ReactDOM from 'react-dom';\n\nvar isClient = typeof document !== 'undefined';\n\nvar noop = function noop() {};\nvar index = isClient ? useLayoutEffect : noop;\n\n// Fork of `fast-deep-equal` that only does the comparisons we need and compares\n// functions\nfunction deepEqual(a, b) {\n if (a === b) {\n return true;\n }\n if (typeof a !== typeof b) {\n return false;\n }\n if (typeof a === 'function' && a.toString() === b.toString()) {\n return true;\n }\n let length;\n let i;\n let keys;\n if (a && b && typeof a === 'object') {\n if (Array.isArray(a)) {\n length = a.length;\n if (length !== b.length) return false;\n for (i = length; i-- !== 0;) {\n if (!deepEqual(a[i], b[i])) {\n return false;\n }\n }\n return true;\n }\n keys = Object.keys(a);\n length = keys.length;\n if (length !== Object.keys(b).length) {\n return false;\n }\n for (i = length; i-- !== 0;) {\n if (!{}.hasOwnProperty.call(b, keys[i])) {\n return false;\n }\n }\n for (i = length; i-- !== 0;) {\n const key = keys[i];\n if (key === '_owner' && a.$$typeof) {\n continue;\n }\n if (!deepEqual(a[key], b[key])) {\n return false;\n }\n }\n return true;\n }\n return a !== a && b !== b;\n}\n\nfunction getDPR(element) {\n if (typeof window === 'undefined') {\n return 1;\n }\n const win = element.ownerDocument.defaultView || window;\n return win.devicePixelRatio || 1;\n}\n\nfunction roundByDPR(element, value) {\n const dpr = getDPR(element);\n return Math.round(value * dpr) / dpr;\n}\n\nfunction useLatestRef(value) {\n const ref = React.useRef(value);\n index(() => {\n ref.current = value;\n });\n return ref;\n}\n\n/**\n * Provides data to position a floating element.\n * @see https://floating-ui.com/docs/useFloating\n */\nfunction useFloating(options) {\n if (options === void 0) {\n options = {};\n }\n const {\n placement = 'bottom',\n strategy = 'absolute',\n middleware = [],\n platform,\n elements: {\n reference: externalReference,\n floating: externalFloating\n } = {},\n transform = true,\n whileElementsMounted,\n open\n } = options;\n const [data, setData] = React.useState({\n x: 0,\n y: 0,\n strategy,\n placement,\n middlewareData: {},\n isPositioned: false\n });\n const [latestMiddleware, setLatestMiddleware] = React.useState(middleware);\n if (!deepEqual(latestMiddleware, middleware)) {\n setLatestMiddleware(middleware);\n }\n const [_reference, _setReference] = React.useState(null);\n const [_floating, _setFloating] = React.useState(null);\n const setReference = React.useCallback(node => {\n if (node !== referenceRef.current) {\n referenceRef.current = node;\n _setReference(node);\n }\n }, []);\n const setFloating = React.useCallback(node => {\n if (node !== floatingRef.current) {\n floatingRef.current = node;\n _setFloating(node);\n }\n }, []);\n const referenceEl = externalReference || _reference;\n const floatingEl = externalFloating || _floating;\n const referenceRef = React.useRef(null);\n const floatingRef = React.useRef(null);\n const dataRef = React.useRef(data);\n const hasWhileElementsMounted = whileElementsMounted != null;\n const whileElementsMountedRef = useLatestRef(whileElementsMounted);\n const platformRef = useLatestRef(platform);\n const openRef = useLatestRef(open);\n const update = React.useCallback(() => {\n if (!referenceRef.current || !floatingRef.current) {\n return;\n }\n const config = {\n placement,\n strategy,\n middleware: latestMiddleware\n };\n if (platformRef.current) {\n config.platform = platformRef.current;\n }\n computePosition(referenceRef.current, floatingRef.current, config).then(data => {\n const fullData = {\n ...data,\n // The floating element's position may be recomputed while it's closed\n // but still mounted (such as when transitioning out). To ensure\n // `isPositioned` will be `false` initially on the next open, avoid\n // setting it to `true` when `open === false` (must be specified).\n isPositioned: openRef.current !== false\n };\n if (isMountedRef.current && !deepEqual(dataRef.current, fullData)) {\n dataRef.current = fullData;\n ReactDOM.flushSync(() => {\n setData(fullData);\n });\n }\n });\n }, [latestMiddleware, placement, strategy, platformRef, openRef]);\n index(() => {\n if (open === false && dataRef.current.isPositioned) {\n dataRef.current.isPositioned = false;\n setData(data => ({\n ...data,\n isPositioned: false\n }));\n }\n }, [open]);\n const isMountedRef = React.useRef(false);\n index(() => {\n isMountedRef.current = true;\n return () => {\n isMountedRef.current = false;\n };\n }, []);\n index(() => {\n if (referenceEl) referenceRef.current = referenceEl;\n if (floatingEl) floatingRef.current = floatingEl;\n if (referenceEl && floatingEl) {\n if (whileElementsMountedRef.current) {\n return whileElementsMountedRef.current(referenceEl, floatingEl, update);\n }\n update();\n }\n }, [referenceEl, floatingEl, update, whileElementsMountedRef, hasWhileElementsMounted]);\n const refs = React.useMemo(() => ({\n reference: referenceRef,\n floating: floatingRef,\n setReference,\n setFloating\n }), [setReference, setFloating]);\n const elements = React.useMemo(() => ({\n reference: referenceEl,\n floating: floatingEl\n }), [referenceEl, floatingEl]);\n const floatingStyles = React.useMemo(() => {\n const initialStyles = {\n position: strategy,\n left: 0,\n top: 0\n };\n if (!elements.floating) {\n return initialStyles;\n }\n const x = roundByDPR(elements.floating, data.x);\n const y = roundByDPR(elements.floating, data.y);\n if (transform) {\n return {\n ...initialStyles,\n transform: \"translate(\" + x + \"px, \" + y + \"px)\",\n ...(getDPR(elements.floating) >= 1.5 && {\n willChange: 'transform'\n })\n };\n }\n return {\n position: strategy,\n left: x,\n top: y\n };\n }, [strategy, transform, elements.floating, data.x, data.y]);\n return React.useMemo(() => ({\n ...data,\n update,\n refs,\n elements,\n floatingStyles\n }), [data, update, refs, elements, floatingStyles]);\n}\n\n/**\n * Provides data to position an inner element of the floating element so that it\n * appears centered to the reference element.\n * This wraps the core `arrow` middleware to allow React refs as the element.\n * @see https://floating-ui.com/docs/arrow\n */\nconst arrow$1 = options => {\n function isRef(value) {\n return {}.hasOwnProperty.call(value, 'current');\n }\n return {\n name: 'arrow',\n options,\n fn(state) {\n const {\n element,\n padding\n } = typeof options === 'function' ? options(state) : options;\n if (element && isRef(element)) {\n if (element.current != null) {\n return arrow$2({\n element: element.current,\n padding\n }).fn(state);\n }\n return {};\n }\n if (element) {\n return arrow$2({\n element,\n padding\n }).fn(state);\n }\n return {};\n }\n };\n};\n\n/**\n * Modifies the placement by translating the floating element along the\n * specified axes.\n * A number (shorthand for `mainAxis` or distance), or an axes configuration\n * object may be passed.\n * @see https://floating-ui.com/docs/offset\n */\nconst offset = (options, deps) => {\n const result = offset$1(options);\n return {\n name: result.name,\n fn: result.fn,\n options: [options, deps]\n };\n};\n\n/**\n * Optimizes the visibility of the floating element by shifting it in order to\n * keep it in view when it will overflow the clipping boundary.\n * @see https://floating-ui.com/docs/shift\n */\nconst shift = (options, deps) => {\n const result = shift$1(options);\n return {\n name: result.name,\n fn: result.fn,\n options: [options, deps]\n };\n};\n\n/**\n * Built-in `limiter` that will stop `shift()` at a certain point.\n */\nconst limitShift = (options, deps) => {\n const result = limitShift$1(options);\n return {\n fn: result.fn,\n options: [options, deps]\n };\n};\n\n/**\n * Optimizes the visibility of the floating element by flipping the `placement`\n * in order to keep it in view when the preferred placement(s) will overflow the\n * clipping boundary. Alternative to `autoPlacement`.\n * @see https://floating-ui.com/docs/flip\n */\nconst flip = (options, deps) => {\n const result = flip$1(options);\n return {\n name: result.name,\n fn: result.fn,\n options: [options, deps]\n };\n};\n\n/**\n * Provides data that allows you to change the size of the floating element —\n * for instance, prevent it from overflowing the clipping boundary or match the\n * width of the reference element.\n * @see https://floating-ui.com/docs/size\n */\nconst size = (options, deps) => {\n const result = size$1(options);\n return {\n name: result.name,\n fn: result.fn,\n options: [options, deps]\n };\n};\n\n/**\n * Optimizes the visibility of the floating element by choosing the placement\n * that has the most space available automatically, without needing to specify a\n * preferred placement. Alternative to `flip`.\n * @see https://floating-ui.com/docs/autoPlacement\n */\nconst autoPlacement = (options, deps) => {\n const result = autoPlacement$1(options);\n return {\n name: result.name,\n fn: result.fn,\n options: [options, deps]\n };\n};\n\n/**\n * Provides data to hide the floating element in applicable situations, such as\n * when it is not in the same clipping context as the reference element.\n * @see https://floating-ui.com/docs/hide\n */\nconst hide = (options, deps) => {\n const result = hide$1(options);\n return {\n name: result.name,\n fn: result.fn,\n options: [options, deps]\n };\n};\n\n/**\n * Provides improved positioning for inline reference elements that can span\n * over multiple lines, such as hyperlinks or range selections.\n * @see https://floating-ui.com/docs/inline\n */\nconst inline = (options, deps) => {\n const result = inline$1(options);\n return {\n name: result.name,\n fn: result.fn,\n options: [options, deps]\n };\n};\n\n/**\n * Provides data to position an inner element of the floating element so that it\n * appears centered to the reference element.\n * This wraps the core `arrow` middleware to allow React refs as the element.\n * @see https://floating-ui.com/docs/arrow\n */\nconst arrow = (options, deps) => {\n const result = arrow$1(options);\n return {\n name: result.name,\n fn: result.fn,\n options: [options, deps]\n };\n};\n\nexport { arrow, autoPlacement, flip, hide, inline, limitShift, offset, shift, size, useFloating };\n","// src/arrow.tsx\nimport * as React from \"react\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { jsx } from \"react/jsx-runtime\";\nvar NAME = \"Arrow\";\nvar Arrow = React.forwardRef((props, forwardedRef) => {\n const { children, width = 10, height = 5, ...arrowProps } = props;\n return /* @__PURE__ */ jsx(\n Primitive.svg,\n {\n ...arrowProps,\n ref: forwardedRef,\n width,\n height,\n viewBox: \"0 0 30 10\",\n preserveAspectRatio: \"none\",\n children: props.asChild ? children : /* @__PURE__ */ jsx(\"polygon\", { points: \"0,0 30,0 15,10\" })\n }\n );\n});\nArrow.displayName = NAME;\nvar Root = Arrow;\nexport {\n Arrow,\n Root\n};\n//# sourceMappingURL=index.mjs.map\n","// packages/react/use-size/src/use-size.tsx\nimport * as React from \"react\";\nimport { useLayoutEffect } from \"@radix-ui/react-use-layout-effect\";\nfunction useSize(element) {\n const [size, setSize] = React.useState(void 0);\n useLayoutEffect(() => {\n if (element) {\n setSize({ width: element.offsetWidth, height: element.offsetHeight });\n const resizeObserver = new ResizeObserver((entries) => {\n if (!Array.isArray(entries)) {\n return;\n }\n if (!entries.length) {\n return;\n }\n const entry = entries[0];\n let width;\n let height;\n if (\"borderBoxSize\" in entry) {\n const borderSizeEntry = entry[\"borderBoxSize\"];\n const borderSize = Array.isArray(borderSizeEntry) ? borderSizeEntry[0] : borderSizeEntry;\n width = borderSize[\"inlineSize\"];\n height = borderSize[\"blockSize\"];\n } else {\n width = element.offsetWidth;\n height = element.offsetHeight;\n }\n setSize({ width, height });\n });\n resizeObserver.observe(element, { box: \"border-box\" });\n return () => resizeObserver.unobserve(element);\n } else {\n setSize(void 0);\n }\n }, [element]);\n return size;\n}\nexport {\n useSize\n};\n//# sourceMappingURL=index.mjs.map\n","\"use client\";\n\n// src/popper.tsx\nimport * as React from \"react\";\nimport {\n useFloating,\n autoUpdate,\n offset,\n shift,\n limitShift,\n hide,\n arrow as floatingUIarrow,\n flip,\n size\n} from \"@floating-ui/react-dom\";\nimport * as ArrowPrimitive from \"@radix-ui/react-arrow\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { createContextScope } from \"@radix-ui/react-context\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { useCallbackRef } from \"@radix-ui/react-use-callback-ref\";\nimport { useLayoutEffect } from \"@radix-ui/react-use-layout-effect\";\nimport { useSize } from \"@radix-ui/react-use-size\";\nimport { jsx } from \"react/jsx-runtime\";\nvar SIDE_OPTIONS = [\"top\", \"right\", \"bottom\", \"left\"];\nvar ALIGN_OPTIONS = [\"start\", \"center\", \"end\"];\nvar POPPER_NAME = \"Popper\";\nvar [createPopperContext, createPopperScope] = createContextScope(POPPER_NAME);\nvar [PopperProvider, usePopperContext] = createPopperContext(POPPER_NAME);\nvar Popper = (props) => {\n const { __scopePopper, children } = props;\n const [anchor, setAnchor] = React.useState(null);\n return /* @__PURE__ */ jsx(PopperProvider, { scope: __scopePopper, anchor, onAnchorChange: setAnchor, children });\n};\nPopper.displayName = POPPER_NAME;\nvar ANCHOR_NAME = \"PopperAnchor\";\nvar PopperAnchor = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopePopper, virtualRef, ...anchorProps } = props;\n const context = usePopperContext(ANCHOR_NAME, __scopePopper);\n const ref = React.useRef(null);\n const composedRefs = useComposedRefs(forwardedRef, ref);\n const anchorRef = React.useRef(null);\n React.useEffect(() => {\n const previousAnchor = anchorRef.current;\n anchorRef.current = virtualRef?.current || ref.current;\n if (previousAnchor !== anchorRef.current) {\n context.onAnchorChange(anchorRef.current);\n }\n });\n return virtualRef ? null : /* @__PURE__ */ jsx(Primitive.div, { ...anchorProps, ref: composedRefs });\n }\n);\nPopperAnchor.displayName = ANCHOR_NAME;\nvar CONTENT_NAME = \"PopperContent\";\nvar [PopperContentProvider, useContentContext] = createPopperContext(CONTENT_NAME);\nvar PopperContent = React.forwardRef(\n (props, forwardedRef) => {\n const {\n __scopePopper,\n side = \"bottom\",\n sideOffset = 0,\n align = \"center\",\n alignOffset = 0,\n arrowPadding = 0,\n avoidCollisions = true,\n collisionBoundary = [],\n collisionPadding: collisionPaddingProp = 0,\n sticky = \"partial\",\n hideWhenDetached = false,\n updatePositionStrategy = \"optimized\",\n onPlaced,\n ...contentProps\n } = props;\n const context = usePopperContext(CONTENT_NAME, __scopePopper);\n const [content, setContent] = React.useState(null);\n const composedRefs = useComposedRefs(forwardedRef, (node) => setContent(node));\n const [arrow, setArrow] = React.useState(null);\n const arrowSize = useSize(arrow);\n const arrowWidth = arrowSize?.width ?? 0;\n const arrowHeight = arrowSize?.height ?? 0;\n const desiredPlacement = side + (align !== \"center\" ? \"-\" + align : \"\");\n const collisionPadding = typeof collisionPaddingProp === \"number\" ? collisionPaddingProp : { top: 0, right: 0, bottom: 0, left: 0, ...collisionPaddingProp };\n const boundary = Array.isArray(collisionBoundary) ? collisionBoundary : [collisionBoundary];\n const hasExplicitBoundaries = boundary.length > 0;\n const detectOverflowOptions = {\n padding: collisionPadding,\n boundary: boundary.filter(isNotNull),\n // with `strategy: 'fixed'`, this is the only way to get it to respect boundaries\n altBoundary: hasExplicitBoundaries\n };\n const { refs, floatingStyles, placement, isPositioned, middlewareData } = useFloating({\n // default to `fixed` strategy so users don't have to pick and we also avoid focus scroll issues\n strategy: \"fixed\",\n placement: desiredPlacement,\n whileElementsMounted: (...args) => {\n const cleanup = autoUpdate(...args, {\n animationFrame: updatePositionStrategy === \"always\"\n });\n return cleanup;\n },\n elements: {\n reference: context.anchor\n },\n middleware: [\n offset({ mainAxis: sideOffset + arrowHeight, alignmentAxis: alignOffset }),\n avoidCollisions && shift({\n mainAxis: true,\n crossAxis: false,\n limiter: sticky === \"partial\" ? limitShift() : void 0,\n ...detectOverflowOptions\n }),\n avoidCollisions && flip({ ...detectOverflowOptions }),\n size({\n ...detectOverflowOptions,\n apply: ({ elements, rects, availableWidth, availableHeight }) => {\n const { width: anchorWidth, height: anchorHeight } = rects.reference;\n const contentStyle = elements.floating.style;\n contentStyle.setProperty(\"--radix-popper-available-width\", `${availableWidth}px`);\n contentStyle.setProperty(\"--radix-popper-available-height\", `${availableHeight}px`);\n contentStyle.setProperty(\"--radix-popper-anchor-width\", `${anchorWidth}px`);\n contentStyle.setProperty(\"--radix-popper-anchor-height\", `${anchorHeight}px`);\n }\n }),\n arrow && floatingUIarrow({ element: arrow, padding: arrowPadding }),\n transformOrigin({ arrowWidth, arrowHeight }),\n hideWhenDetached && hide({ strategy: \"referenceHidden\", ...detectOverflowOptions })\n ]\n });\n const [placedSide, placedAlign] = getSideAndAlignFromPlacement(placement);\n const handlePlaced = useCallbackRef(onPlaced);\n useLayoutEffect(() => {\n if (isPositioned) {\n handlePlaced?.();\n }\n }, [isPositioned, handlePlaced]);\n const arrowX = middlewareData.arrow?.x;\n const arrowY = middlewareData.arrow?.y;\n const cannotCenterArrow = middlewareData.arrow?.centerOffset !== 0;\n const [contentZIndex, setContentZIndex] = React.useState();\n useLayoutEffect(() => {\n if (content) setContentZIndex(window.getComputedStyle(content).zIndex);\n }, [content]);\n return /* @__PURE__ */ jsx(\n \"div\",\n {\n ref: refs.setFloating,\n \"data-radix-popper-content-wrapper\": \"\",\n style: {\n ...floatingStyles,\n transform: isPositioned ? floatingStyles.transform : \"translate(0, -200%)\",\n // keep off the page when measuring\n minWidth: \"max-content\",\n zIndex: contentZIndex,\n [\"--radix-popper-transform-origin\"]: [\n middlewareData.transformOrigin?.x,\n middlewareData.transformOrigin?.y\n ].join(\" \"),\n // hide the content if using the hide middleware and should be hidden\n // set visibility to hidden and disable pointer events so the UI behaves\n // as if the PopperContent isn't there at all\n ...middlewareData.hide?.referenceHidden && {\n visibility: \"hidden\",\n pointerEvents: \"none\"\n }\n },\n dir: props.dir,\n children: /* @__PURE__ */ jsx(\n PopperContentProvider,\n {\n scope: __scopePopper,\n placedSide,\n onArrowChange: setArrow,\n arrowX,\n arrowY,\n shouldHideArrow: cannotCenterArrow,\n children: /* @__PURE__ */ jsx(\n Primitive.div,\n {\n \"data-side\": placedSide,\n \"data-align\": placedAlign,\n ...contentProps,\n ref: composedRefs,\n style: {\n ...contentProps.style,\n // if the PopperContent hasn't been placed yet (not all measurements done)\n // we prevent animations so that users's animation don't kick in too early referring wrong sides\n animation: !isPositioned ? \"none\" : void 0\n }\n }\n )\n }\n )\n }\n );\n }\n);\nPopperContent.displayName = CONTENT_NAME;\nvar ARROW_NAME = \"PopperArrow\";\nvar OPPOSITE_SIDE = {\n top: \"bottom\",\n right: \"left\",\n bottom: \"top\",\n left: \"right\"\n};\nvar PopperArrow = React.forwardRef(function PopperArrow2(props, forwardedRef) {\n const { __scopePopper, ...arrowProps } = props;\n const contentContext = useContentContext(ARROW_NAME, __scopePopper);\n const baseSide = OPPOSITE_SIDE[contentContext.placedSide];\n return (\n // we have to use an extra wrapper because `ResizeObserver` (used by `useSize`)\n // doesn't report size as we'd expect on SVG elements.\n // it reports their bounding box which is effectively the largest path inside the SVG.\n /* @__PURE__ */ jsx(\n \"span\",\n {\n ref: contentContext.onArrowChange,\n style: {\n position: \"absolute\",\n left: contentContext.arrowX,\n top: contentContext.arrowY,\n [baseSide]: 0,\n transformOrigin: {\n top: \"\",\n right: \"0 0\",\n bottom: \"center 0\",\n left: \"100% 0\"\n }[contentContext.placedSide],\n transform: {\n top: \"translateY(100%)\",\n right: \"translateY(50%) rotate(90deg) translateX(-50%)\",\n bottom: `rotate(180deg)`,\n left: \"translateY(50%) rotate(-90deg) translateX(50%)\"\n }[contentContext.placedSide],\n visibility: contentContext.shouldHideArrow ? \"hidden\" : void 0\n },\n children: /* @__PURE__ */ jsx(\n ArrowPrimitive.Root,\n {\n ...arrowProps,\n ref: forwardedRef,\n style: {\n ...arrowProps.style,\n // ensures the element can be measured correctly (mostly for if SVG)\n display: \"block\"\n }\n }\n )\n }\n )\n );\n});\nPopperArrow.displayName = ARROW_NAME;\nfunction isNotNull(value) {\n return value !== null;\n}\nvar transformOrigin = (options) => ({\n name: \"transformOrigin\",\n options,\n fn(data) {\n const { placement, rects, middlewareData } = data;\n const cannotCenterArrow = middlewareData.arrow?.centerOffset !== 0;\n const isArrowHidden = cannotCenterArrow;\n const arrowWidth = isArrowHidden ? 0 : options.arrowWidth;\n const arrowHeight = isArrowHidden ? 0 : options.arrowHeight;\n const [placedSide, placedAlign] = getSideAndAlignFromPlacement(placement);\n const noArrowAlign = { start: \"0%\", center: \"50%\", end: \"100%\" }[placedAlign];\n const arrowXCenter = (middlewareData.arrow?.x ?? 0) + arrowWidth / 2;\n const arrowYCenter = (middlewareData.arrow?.y ?? 0) + arrowHeight / 2;\n let x = \"\";\n let y = \"\";\n if (placedSide === \"bottom\") {\n x = isArrowHidden ? noArrowAlign : `${arrowXCenter}px`;\n y = `${-arrowHeight}px`;\n } else if (placedSide === \"top\") {\n x = isArrowHidden ? noArrowAlign : `${arrowXCenter}px`;\n y = `${rects.floating.height + arrowHeight}px`;\n } else if (placedSide === \"right\") {\n x = `${-arrowHeight}px`;\n y = isArrowHidden ? noArrowAlign : `${arrowYCenter}px`;\n } else if (placedSide === \"left\") {\n x = `${rects.floating.width + arrowHeight}px`;\n y = isArrowHidden ? noArrowAlign : `${arrowYCenter}px`;\n }\n return { data: { x, y } };\n }\n});\nfunction getSideAndAlignFromPlacement(placement) {\n const [side, align = \"center\"] = placement.split(\"-\");\n return [side, align];\n}\nvar Root2 = Popper;\nvar Anchor = PopperAnchor;\nvar Content = PopperContent;\nvar Arrow = PopperArrow;\nexport {\n ALIGN_OPTIONS,\n Anchor,\n Arrow,\n Content,\n Popper,\n PopperAnchor,\n PopperArrow,\n PopperContent,\n Root2 as Root,\n SIDE_OPTIONS,\n createPopperScope\n};\n//# sourceMappingURL=index.mjs.map\n","\"use client\";\n\n// src/portal.tsx\nimport * as React from \"react\";\nimport ReactDOM from \"react-dom\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { useLayoutEffect } from \"@radix-ui/react-use-layout-effect\";\nimport { jsx } from \"react/jsx-runtime\";\nvar PORTAL_NAME = \"Portal\";\nvar Portal = React.forwardRef((props, forwardedRef) => {\n const { container: containerProp, ...portalProps } = props;\n const [mounted, setMounted] = React.useState(false);\n useLayoutEffect(() => setMounted(true), []);\n const container = containerProp || mounted && globalThis?.document?.body;\n return container ? ReactDOM.createPortal(/* @__PURE__ */ jsx(Primitive.div, { ...portalProps, ref: forwardedRef }), container) : null;\n});\nPortal.displayName = PORTAL_NAME;\nvar Root = Portal;\nexport {\n Portal,\n Root\n};\n//# sourceMappingURL=index.mjs.map\n","// src/slot.tsx\nimport * as React from \"react\";\nimport { composeRefs } from \"@radix-ui/react-compose-refs\";\nimport { Fragment as Fragment2, jsx } from \"react/jsx-runtime\";\n// @__NO_SIDE_EFFECTS__\nfunction createSlot(ownerName) {\n const SlotClone = /* @__PURE__ */ createSlotClone(ownerName);\n const Slot2 = React.forwardRef((props, forwardedRef) => {\n const { children, ...slotProps } = props;\n const childrenArray = React.Children.toArray(children);\n const slottable = childrenArray.find(isSlottable);\n if (slottable) {\n const newElement = slottable.props.children;\n const newChildren = childrenArray.map((child) => {\n if (child === slottable) {\n if (React.Children.count(newElement) > 1) return React.Children.only(null);\n return React.isValidElement(newElement) ? newElement.props.children : null;\n } else {\n return child;\n }\n });\n return /* @__PURE__ */ jsx(SlotClone, { ...slotProps, ref: forwardedRef, children: React.isValidElement(newElement) ? React.cloneElement(newElement, void 0, newChildren) : null });\n }\n return /* @__PURE__ */ jsx(SlotClone, { ...slotProps, ref: forwardedRef, children });\n });\n Slot2.displayName = `${ownerName}.Slot`;\n return Slot2;\n}\nvar Slot = /* @__PURE__ */ createSlot(\"Slot\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlotClone(ownerName) {\n const SlotClone = React.forwardRef((props, forwardedRef) => {\n const { children, ...slotProps } = props;\n if (React.isValidElement(children)) {\n const childrenRef = getElementRef(children);\n const props2 = mergeProps(slotProps, children.props);\n if (children.type !== React.Fragment) {\n props2.ref = forwardedRef ? composeRefs(forwardedRef, childrenRef) : childrenRef;\n }\n return React.cloneElement(children, props2);\n }\n return React.Children.count(children) > 1 ? React.Children.only(null) : null;\n });\n SlotClone.displayName = `${ownerName}.SlotClone`;\n return SlotClone;\n}\nvar SLOTTABLE_IDENTIFIER = Symbol(\"radix.slottable\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlottable(ownerName) {\n const Slottable2 = ({ children }) => {\n return /* @__PURE__ */ jsx(Fragment2, { children });\n };\n Slottable2.displayName = `${ownerName}.Slottable`;\n Slottable2.__radixId = SLOTTABLE_IDENTIFIER;\n return Slottable2;\n}\nvar Slottable = /* @__PURE__ */ createSlottable(\"Slottable\");\nfunction isSlottable(child) {\n return React.isValidElement(child) && typeof child.type === \"function\" && \"__radixId\" in child.type && child.type.__radixId === SLOTTABLE_IDENTIFIER;\n}\nfunction mergeProps(slotProps, childProps) {\n const overrideProps = { ...childProps };\n for (const propName in childProps) {\n const slotPropValue = slotProps[propName];\n const childPropValue = childProps[propName];\n const isHandler = /^on[A-Z]/.test(propName);\n if (isHandler) {\n if (slotPropValue && childPropValue) {\n overrideProps[propName] = (...args) => {\n const result = childPropValue(...args);\n slotPropValue(...args);\n return result;\n };\n } else if (slotPropValue) {\n overrideProps[propName] = slotPropValue;\n }\n } else if (propName === \"style\") {\n overrideProps[propName] = { ...slotPropValue, ...childPropValue };\n } else if (propName === \"className\") {\n overrideProps[propName] = [slotPropValue, childPropValue].filter(Boolean).join(\" \");\n }\n }\n return { ...slotProps, ...overrideProps };\n}\nfunction getElementRef(element) {\n let getter = Object.getOwnPropertyDescriptor(element.props, \"ref\")?.get;\n let mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.ref;\n }\n getter = Object.getOwnPropertyDescriptor(element, \"ref\")?.get;\n mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.props.ref;\n }\n return element.props.ref || element.ref;\n}\nexport {\n Slot as Root,\n Slot,\n Slottable,\n createSlot,\n createSlottable\n};\n//# sourceMappingURL=index.mjs.map\n","// src/use-controllable-state.tsx\nimport * as React from \"react\";\nimport { useLayoutEffect } from \"@radix-ui/react-use-layout-effect\";\nvar useInsertionEffect = React[\" useInsertionEffect \".trim().toString()] || useLayoutEffect;\nfunction useControllableState({\n prop,\n defaultProp,\n onChange = () => {\n },\n caller\n}) {\n const [uncontrolledProp, setUncontrolledProp, onChangeRef] = useUncontrolledState({\n defaultProp,\n onChange\n });\n const isControlled = prop !== void 0;\n const value = isControlled ? prop : uncontrolledProp;\n if (true) {\n const isControlledRef = React.useRef(prop !== void 0);\n React.useEffect(() => {\n const wasControlled = isControlledRef.current;\n if (wasControlled !== isControlled) {\n const from = wasControlled ? \"controlled\" : \"uncontrolled\";\n const to = isControlled ? \"controlled\" : \"uncontrolled\";\n console.warn(\n `${caller} is changing from ${from} to ${to}. Components should not switch from controlled to uncontrolled (or vice versa). Decide between using a controlled or uncontrolled value for the lifetime of the component.`\n );\n }\n isControlledRef.current = isControlled;\n }, [isControlled, caller]);\n }\n const setValue = React.useCallback(\n (nextValue) => {\n if (isControlled) {\n const value2 = isFunction(nextValue) ? nextValue(prop) : nextValue;\n if (value2 !== prop) {\n onChangeRef.current?.(value2);\n }\n } else {\n setUncontrolledProp(nextValue);\n }\n },\n [isControlled, prop, setUncontrolledProp, onChangeRef]\n );\n return [value, setValue];\n}\nfunction useUncontrolledState({\n defaultProp,\n onChange\n}) {\n const [value, setValue] = React.useState(defaultProp);\n const prevValueRef = React.useRef(value);\n const onChangeRef = React.useRef(onChange);\n useInsertionEffect(() => {\n onChangeRef.current = onChange;\n }, [onChange]);\n React.useEffect(() => {\n if (prevValueRef.current !== value) {\n onChangeRef.current?.(value);\n prevValueRef.current = value;\n }\n }, [value, prevValueRef]);\n return [value, setValue, onChangeRef];\n}\nfunction isFunction(value) {\n return typeof value === \"function\";\n}\n\n// src/use-controllable-state-reducer.tsx\nimport * as React2 from \"react\";\nimport { useEffectEvent } from \"@radix-ui/react-use-effect-event\";\nvar SYNC_STATE = Symbol(\"RADIX:SYNC_STATE\");\nfunction useControllableStateReducer(reducer, userArgs, initialArg, init) {\n const { prop: controlledState, defaultProp, onChange: onChangeProp, caller } = userArgs;\n const isControlled = controlledState !== void 0;\n const onChange = useEffectEvent(onChangeProp);\n if (true) {\n const isControlledRef = React2.useRef(controlledState !== void 0);\n React2.useEffect(() => {\n const wasControlled = isControlledRef.current;\n if (wasControlled !== isControlled) {\n const from = wasControlled ? \"controlled\" : \"uncontrolled\";\n const to = isControlled ? \"controlled\" : \"uncontrolled\";\n console.warn(\n `${caller} is changing from ${from} to ${to}. Components should not switch from controlled to uncontrolled (or vice versa). Decide between using a controlled or uncontrolled value for the lifetime of the component.`\n );\n }\n isControlledRef.current = isControlled;\n }, [isControlled, caller]);\n }\n const args = [{ ...initialArg, state: defaultProp }];\n if (init) {\n args.push(init);\n }\n const [internalState, dispatch] = React2.useReducer(\n (state2, action) => {\n if (action.type === SYNC_STATE) {\n return { ...state2, state: action.state };\n }\n const next = reducer(state2, action);\n if (isControlled && !Object.is(next.state, state2.state)) {\n onChange(next.state);\n }\n return next;\n },\n ...args\n );\n const uncontrolledState = internalState.state;\n const prevValueRef = React2.useRef(uncontrolledState);\n React2.useEffect(() => {\n if (prevValueRef.current !== uncontrolledState) {\n prevValueRef.current = uncontrolledState;\n if (!isControlled) {\n onChange(uncontrolledState);\n }\n }\n }, [onChange, uncontrolledState, prevValueRef, isControlled]);\n const state = React2.useMemo(() => {\n const isControlled2 = controlledState !== void 0;\n if (isControlled2) {\n return { ...internalState, state: controlledState };\n }\n return internalState;\n }, [internalState, controlledState]);\n React2.useEffect(() => {\n if (isControlled && !Object.is(controlledState, internalState.state)) {\n dispatch({ type: SYNC_STATE, state: controlledState });\n }\n }, [controlledState, internalState.state, isControlled]);\n return [state, dispatch];\n}\nexport {\n useControllableState,\n useControllableStateReducer\n};\n//# sourceMappingURL=index.mjs.map\n","// packages/react/use-previous/src/use-previous.tsx\nimport * as React from \"react\";\nfunction usePrevious(value) {\n const ref = React.useRef({ value, previous: value });\n return React.useMemo(() => {\n if (ref.current.value !== value) {\n ref.current.previous = ref.current.value;\n ref.current.value = value;\n }\n return ref.current.previous;\n }, [value]);\n}\nexport {\n usePrevious\n};\n//# sourceMappingURL=index.mjs.map\n","// src/visually-hidden.tsx\nimport * as React from \"react\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { jsx } from \"react/jsx-runtime\";\nvar VISUALLY_HIDDEN_STYLES = Object.freeze({\n // See: https://github.com/twbs/bootstrap/blob/main/scss/mixins/_visually-hidden.scss\n position: \"absolute\",\n border: 0,\n width: 1,\n height: 1,\n padding: 0,\n margin: -1,\n overflow: \"hidden\",\n clip: \"rect(0, 0, 0, 0)\",\n whiteSpace: \"nowrap\",\n wordWrap: \"normal\"\n});\nvar NAME = \"VisuallyHidden\";\nvar VisuallyHidden = React.forwardRef(\n (props, forwardedRef) => {\n return /* @__PURE__ */ jsx(\n Primitive.span,\n {\n ...props,\n ref: forwardedRef,\n style: { ...VISUALLY_HIDDEN_STYLES, ...props.style }\n }\n );\n }\n);\nVisuallyHidden.displayName = NAME;\nvar Root = VisuallyHidden;\nexport {\n Root,\n VISUALLY_HIDDEN_STYLES,\n VisuallyHidden\n};\n//# sourceMappingURL=index.mjs.map\n","var getDefaultParent = function (originalTarget) {\n if (typeof document === 'undefined') {\n return null;\n }\n var sampleTarget = Array.isArray(originalTarget) ? originalTarget[0] : originalTarget;\n return sampleTarget.ownerDocument.body;\n};\nvar counterMap = new WeakMap();\nvar uncontrolledNodes = new WeakMap();\nvar markerMap = {};\nvar lockCount = 0;\nvar unwrapHost = function (node) {\n return node && (node.host || unwrapHost(node.parentNode));\n};\nvar correctTargets = function (parent, targets) {\n return targets\n .map(function (target) {\n if (parent.contains(target)) {\n return target;\n }\n var correctedTarget = unwrapHost(target);\n if (correctedTarget && parent.contains(correctedTarget)) {\n return correctedTarget;\n }\n console.error('aria-hidden', target, 'in not contained inside', parent, '. Doing nothing');\n return null;\n })\n .filter(function (x) { return Boolean(x); });\n};\n/**\n * Marks everything except given node(or nodes) as aria-hidden\n * @param {Element | Element[]} originalTarget - elements to keep on the page\n * @param [parentNode] - top element, defaults to document.body\n * @param {String} [markerName] - a special attribute to mark every node\n * @param {String} [controlAttribute] - html Attribute to control\n * @return {Undo} undo command\n */\nvar applyAttributeToOthers = function (originalTarget, parentNode, markerName, controlAttribute) {\n var targets = correctTargets(parentNode, Array.isArray(originalTarget) ? originalTarget : [originalTarget]);\n if (!markerMap[markerName]) {\n markerMap[markerName] = new WeakMap();\n }\n var markerCounter = markerMap[markerName];\n var hiddenNodes = [];\n var elementsToKeep = new Set();\n var elementsToStop = new Set(targets);\n var keep = function (el) {\n if (!el || elementsToKeep.has(el)) {\n return;\n }\n elementsToKeep.add(el);\n keep(el.parentNode);\n };\n targets.forEach(keep);\n var deep = function (parent) {\n if (!parent || elementsToStop.has(parent)) {\n return;\n }\n Array.prototype.forEach.call(parent.children, function (node) {\n if (elementsToKeep.has(node)) {\n deep(node);\n }\n else {\n try {\n var attr = node.getAttribute(controlAttribute);\n var alreadyHidden = attr !== null && attr !== 'false';\n var counterValue = (counterMap.get(node) || 0) + 1;\n var markerValue = (markerCounter.get(node) || 0) + 1;\n counterMap.set(node, counterValue);\n markerCounter.set(node, markerValue);\n hiddenNodes.push(node);\n if (counterValue === 1 && alreadyHidden) {\n uncontrolledNodes.set(node, true);\n }\n if (markerValue === 1) {\n node.setAttribute(markerName, 'true');\n }\n if (!alreadyHidden) {\n node.setAttribute(controlAttribute, 'true');\n }\n }\n catch (e) {\n console.error('aria-hidden: cannot operate on ', node, e);\n }\n }\n });\n };\n deep(parentNode);\n elementsToKeep.clear();\n lockCount++;\n return function () {\n hiddenNodes.forEach(function (node) {\n var counterValue = counterMap.get(node) - 1;\n var markerValue = markerCounter.get(node) - 1;\n counterMap.set(node, counterValue);\n markerCounter.set(node, markerValue);\n if (!counterValue) {\n if (!uncontrolledNodes.has(node)) {\n node.removeAttribute(controlAttribute);\n }\n uncontrolledNodes.delete(node);\n }\n if (!markerValue) {\n node.removeAttribute(markerName);\n }\n });\n lockCount--;\n if (!lockCount) {\n // clear\n counterMap = new WeakMap();\n counterMap = new WeakMap();\n uncontrolledNodes = new WeakMap();\n markerMap = {};\n }\n };\n};\n/**\n * Marks everything except given node(or nodes) as aria-hidden\n * @param {Element | Element[]} originalTarget - elements to keep on the page\n * @param [parentNode] - top element, defaults to document.body\n * @param {String} [markerName] - a special attribute to mark every node\n * @return {Undo} undo command\n */\nexport var hideOthers = function (originalTarget, parentNode, markerName) {\n if (markerName === void 0) { markerName = 'data-aria-hidden'; }\n var targets = Array.from(Array.isArray(originalTarget) ? originalTarget : [originalTarget]);\n var activeParentNode = parentNode || getDefaultParent(originalTarget);\n if (!activeParentNode) {\n return function () { return null; };\n }\n // we should not hide aria-live elements - https://github.com/theKashey/aria-hidden/issues/10\n // and script elements, as they have no impact on accessibility.\n targets.push.apply(targets, Array.from(activeParentNode.querySelectorAll('[aria-live], script')));\n return applyAttributeToOthers(targets, activeParentNode, markerName, 'aria-hidden');\n};\n/**\n * Marks everything except given node(or nodes) as inert\n * @param {Element | Element[]} originalTarget - elements to keep on the page\n * @param [parentNode] - top element, defaults to document.body\n * @param {String} [markerName] - a special attribute to mark every node\n * @return {Undo} undo command\n */\nexport var inertOthers = function (originalTarget, parentNode, markerName) {\n if (markerName === void 0) { markerName = 'data-inert-ed'; }\n var activeParentNode = parentNode || getDefaultParent(originalTarget);\n if (!activeParentNode) {\n return function () { return null; };\n }\n return applyAttributeToOthers(originalTarget, activeParentNode, markerName, 'inert');\n};\n/**\n * @returns if current browser supports inert\n */\nexport var supportsInert = function () {\n return typeof HTMLElement !== 'undefined' && HTMLElement.prototype.hasOwnProperty('inert');\n};\n/**\n * Automatic function to \"suppress\" DOM elements - _hide_ or _inert_ in the best possible way\n * @param {Element | Element[]} originalTarget - elements to keep on the page\n * @param [parentNode] - top element, defaults to document.body\n * @param {String} [markerName] - a special attribute to mark every node\n * @return {Undo} undo command\n */\nexport var suppressOthers = function (originalTarget, parentNode, markerName) {\n if (markerName === void 0) { markerName = 'data-suppressed'; }\n return (supportsInert() ? inertOthers : hideOthers)(originalTarget, parentNode, markerName);\n};\n","/******************************************************************************\nCopyright (c) Microsoft Corporation.\n\nPermission to use, copy, modify, and/or distribute this software for any\npurpose with or without fee is hereby granted.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\nPERFORMANCE OF THIS SOFTWARE.\n***************************************************************************** */\n/* global Reflect, Promise, SuppressedError, Symbol, Iterator */\n\nvar extendStatics = function(d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n};\n\nexport function __extends(d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n}\n\nexport var __assign = function() {\n __assign = Object.assign || function __assign(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\n }\n return t;\n }\n return __assign.apply(this, arguments);\n}\n\nexport function __rest(s, e) {\n var t = {};\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\n t[p] = s[p];\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\n t[p[i]] = s[p[i]];\n }\n return t;\n}\n\nexport function __decorate(decorators, target, key, desc) {\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\n return c > 3 && r && Object.defineProperty(target, key, r), r;\n}\n\nexport function __param(paramIndex, decorator) {\n return function (target, key) { decorator(target, key, paramIndex); }\n}\n\nexport function __esDecorate(ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {\n function accept(f) { if (f !== void 0 && typeof f !== \"function\") throw new TypeError(\"Function expected\"); return f; }\n var kind = contextIn.kind, key = kind === \"getter\" ? \"get\" : kind === \"setter\" ? \"set\" : \"value\";\n var target = !descriptorIn && ctor ? contextIn[\"static\"] ? ctor : ctor.prototype : null;\n var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});\n var _, done = false;\n for (var i = decorators.length - 1; i >= 0; i--) {\n var context = {};\n for (var p in contextIn) context[p] = p === \"access\" ? {} : contextIn[p];\n for (var p in contextIn.access) context.access[p] = contextIn.access[p];\n context.addInitializer = function (f) { if (done) throw new TypeError(\"Cannot add initializers after decoration has completed\"); extraInitializers.push(accept(f || null)); };\n var result = (0, decorators[i])(kind === \"accessor\" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);\n if (kind === \"accessor\") {\n if (result === void 0) continue;\n if (result === null || typeof result !== \"object\") throw new TypeError(\"Object expected\");\n if (_ = accept(result.get)) descriptor.get = _;\n if (_ = accept(result.set)) descriptor.set = _;\n if (_ = accept(result.init)) initializers.unshift(_);\n }\n else if (_ = accept(result)) {\n if (kind === \"field\") initializers.unshift(_);\n else descriptor[key] = _;\n }\n }\n if (target) Object.defineProperty(target, contextIn.name, descriptor);\n done = true;\n};\n\nexport function __runInitializers(thisArg, initializers, value) {\n var useValue = arguments.length > 2;\n for (var i = 0; i < initializers.length; i++) {\n value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);\n }\n return useValue ? value : void 0;\n};\n\nexport function __propKey(x) {\n return typeof x === \"symbol\" ? x : \"\".concat(x);\n};\n\nexport function __setFunctionName(f, name, prefix) {\n if (typeof name === \"symbol\") name = name.description ? \"[\".concat(name.description, \"]\") : \"\";\n return Object.defineProperty(f, \"name\", { configurable: true, value: prefix ? \"\".concat(prefix, \" \", name) : name });\n};\n\nexport function __metadata(metadataKey, metadataValue) {\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\n}\n\nexport function __awaiter(thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n}\n\nexport function __generator(thisArg, body) {\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === \"function\" ? Iterator : Object).prototype);\n return g.next = verb(0), g[\"throw\"] = verb(1), g[\"return\"] = verb(2), typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\n function verb(n) { return function (v) { return step([n, v]); }; }\n function step(op) {\n if (f) throw new TypeError(\"Generator is already executing.\");\n while (g && (g = 0, op[0] && (_ = 0)), _) try {\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\n if (y = 0, t) op = [op[0] & 2, t.value];\n switch (op[0]) {\n case 0: case 1: t = op; break;\n case 4: _.label++; return { value: op[1], done: false };\n case 5: _.label++; y = op[1]; op = [0]; continue;\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\n default:\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\n if (t[2]) _.ops.pop();\n _.trys.pop(); continue;\n }\n op = body.call(thisArg, _);\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\n }\n}\n\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n var desc = Object.getOwnPropertyDescriptor(m, k);\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n desc = { enumerable: true, get: function() { return m[k]; } };\n }\n Object.defineProperty(o, k2, desc);\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n});\n\nexport function __exportStar(m, o) {\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\n}\n\nexport function __values(o) {\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\n if (m) return m.call(o);\n if (o && typeof o.length === \"number\") return {\n next: function () {\n if (o && i >= o.length) o = void 0;\n return { value: o && o[i++], done: !o };\n }\n };\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\n}\n\nexport function __read(o, n) {\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\n if (!m) return o;\n var i = m.call(o), r, ar = [], e;\n try {\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\n }\n catch (error) { e = { error: error }; }\n finally {\n try {\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\n }\n finally { if (e) throw e.error; }\n }\n return ar;\n}\n\n/** @deprecated */\nexport function __spread() {\n for (var ar = [], i = 0; i < arguments.length; i++)\n ar = ar.concat(__read(arguments[i]));\n return ar;\n}\n\n/** @deprecated */\nexport function __spreadArrays() {\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\n r[k] = a[j];\n return r;\n}\n\nexport function __spreadArray(to, from, pack) {\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\n if (ar || !(i in from)) {\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\n ar[i] = from[i];\n }\n }\n return to.concat(ar || Array.prototype.slice.call(from));\n}\n\nexport function __await(v) {\n return this instanceof __await ? (this.v = v, this) : new __await(v);\n}\n\nexport function __asyncGenerator(thisArg, _arguments, generator) {\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\n return i = Object.create((typeof AsyncIterator === \"function\" ? AsyncIterator : Object).prototype), verb(\"next\"), verb(\"throw\"), verb(\"return\", awaitReturn), i[Symbol.asyncIterator] = function () { return this; }, i;\n function awaitReturn(f) { return function (v) { return Promise.resolve(v).then(f, reject); }; }\n function verb(n, f) { if (g[n]) { i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; if (f) i[n] = f(i[n]); } }\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\n function fulfill(value) { resume(\"next\", value); }\n function reject(value) { resume(\"throw\", value); }\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\n}\n\nexport function __asyncDelegator(o) {\n var i, p;\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: false } : f ? f(v) : v; } : f; }\n}\n\nexport function __asyncValues(o) {\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\n var m = o[Symbol.asyncIterator], i;\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\n}\n\nexport function __makeTemplateObject(cooked, raw) {\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\n return cooked;\n};\n\nvar __setModuleDefault = Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n};\n\nvar ownKeys = function(o) {\n ownKeys = Object.getOwnPropertyNames || function (o) {\n var ar = [];\n for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;\n return ar;\n };\n return ownKeys(o);\n};\n\nexport function __importStar(mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== \"default\") __createBinding(result, mod, k[i]);\n __setModuleDefault(result, mod);\n return result;\n}\n\nexport function __importDefault(mod) {\n return (mod && mod.__esModule) ? mod : { default: mod };\n}\n\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\n}\n\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\n}\n\nexport function __classPrivateFieldIn(state, receiver) {\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\n}\n\nexport function __addDisposableResource(env, value, async) {\n if (value !== null && value !== void 0) {\n if (typeof value !== \"object\" && typeof value !== \"function\") throw new TypeError(\"Object expected.\");\n var dispose, inner;\n if (async) {\n if (!Symbol.asyncDispose) throw new TypeError(\"Symbol.asyncDispose is not defined.\");\n dispose = value[Symbol.asyncDispose];\n }\n if (dispose === void 0) {\n if (!Symbol.dispose) throw new TypeError(\"Symbol.dispose is not defined.\");\n dispose = value[Symbol.dispose];\n if (async) inner = dispose;\n }\n if (typeof dispose !== \"function\") throw new TypeError(\"Object not disposable.\");\n if (inner) dispose = function() { try { inner.call(this); } catch (e) { return Promise.reject(e); } };\n env.stack.push({ value: value, dispose: dispose, async: async });\n }\n else if (async) {\n env.stack.push({ async: true });\n }\n return value;\n}\n\nvar _SuppressedError = typeof SuppressedError === \"function\" ? SuppressedError : function (error, suppressed, message) {\n var e = new Error(message);\n return e.name = \"SuppressedError\", e.error = error, e.suppressed = suppressed, e;\n};\n\nexport function __disposeResources(env) {\n function fail(e) {\n env.error = env.hasError ? new _SuppressedError(e, env.error, \"An error was suppressed during disposal.\") : e;\n env.hasError = true;\n }\n var r, s = 0;\n function next() {\n while (r = env.stack.pop()) {\n try {\n if (!r.async && s === 1) return s = 0, env.stack.push(r), Promise.resolve().then(next);\n if (r.dispose) {\n var result = r.dispose.call(r.value);\n if (r.async) return s |= 2, Promise.resolve(result).then(next, function(e) { fail(e); return next(); });\n }\n else s |= 1;\n }\n catch (e) {\n fail(e);\n }\n }\n if (s === 1) return env.hasError ? Promise.reject(env.error) : Promise.resolve();\n if (env.hasError) throw env.error;\n }\n return next();\n}\n\nexport function __rewriteRelativeImportExtension(path, preserveJsx) {\n if (typeof path === \"string\" && /^\\.\\.?\\//.test(path)) {\n return path.replace(/\\.(tsx)$|((?:\\.d)?)((?:\\.[^./]+?)?)\\.([cm]?)ts$/i, function (m, tsx, d, ext, cm) {\n return tsx ? preserveJsx ? \".jsx\" : \".js\" : d && (!ext || !cm) ? m : (d + ext + \".\" + cm.toLowerCase() + \"js\");\n });\n }\n return path;\n}\n\nexport default {\n __extends,\n __assign,\n __rest,\n __decorate,\n __param,\n __esDecorate,\n __runInitializers,\n __propKey,\n __setFunctionName,\n __metadata,\n __awaiter,\n __generator,\n __createBinding,\n __exportStar,\n __values,\n __read,\n __spread,\n __spreadArrays,\n __spreadArray,\n __await,\n __asyncGenerator,\n __asyncDelegator,\n __asyncValues,\n __makeTemplateObject,\n __importStar,\n __importDefault,\n __classPrivateFieldGet,\n __classPrivateFieldSet,\n __classPrivateFieldIn,\n __addDisposableResource,\n __disposeResources,\n __rewriteRelativeImportExtension,\n};\n","export var zeroRightClassName = 'right-scroll-bar-position';\nexport var fullWidthClassName = 'width-before-scroll-bar';\nexport var noScrollbarsClassName = 'with-scroll-bars-hidden';\n/**\n * Name of a CSS variable containing the amount of \"hidden\" scrollbar\n * ! might be undefined ! use will fallback!\n */\nexport var removedBarSizeVariable = '--removed-body-scroll-bar-size';\n","/**\n * Assigns a value for a given ref, no matter of the ref format\n * @param {RefObject} ref - a callback function or ref object\n * @param value - a new value\n *\n * @see https://github.com/theKashey/use-callback-ref#assignref\n * @example\n * const refObject = useRef();\n * const refFn = (ref) => {....}\n *\n * assignRef(refObject, \"refValue\");\n * assignRef(refFn, \"refValue\");\n */\nexport function assignRef(ref, value) {\n if (typeof ref === 'function') {\n ref(value);\n }\n else if (ref) {\n ref.current = value;\n }\n return ref;\n}\n","import { useState } from 'react';\n/**\n * creates a MutableRef with ref change callback\n * @param initialValue - initial ref value\n * @param {Function} callback - a callback to run when value changes\n *\n * @example\n * const ref = useCallbackRef(0, (newValue, oldValue) => console.log(oldValue, '->', newValue);\n * ref.current = 1;\n * // prints 0 -> 1\n *\n * @see https://reactjs.org/docs/hooks-reference.html#useref\n * @see https://github.com/theKashey/use-callback-ref#usecallbackref---to-replace-reactuseref\n * @returns {MutableRefObject}\n */\nexport function useCallbackRef(initialValue, callback) {\n var ref = useState(function () { return ({\n // value\n value: initialValue,\n // last callback\n callback: callback,\n // \"memoized\" public interface\n facade: {\n get current() {\n return ref.value;\n },\n set current(value) {\n var last = ref.value;\n if (last !== value) {\n ref.value = value;\n ref.callback(value, last);\n }\n },\n },\n }); })[0];\n // update callback\n ref.callback = callback;\n return ref.facade;\n}\n","import * as React from 'react';\nimport { assignRef } from './assignRef';\nimport { useCallbackRef } from './useRef';\nvar useIsomorphicLayoutEffect = typeof window !== 'undefined' ? React.useLayoutEffect : React.useEffect;\nvar currentValues = new WeakMap();\n/**\n * Merges two or more refs together providing a single interface to set their value\n * @param {RefObject|Ref} refs\n * @returns {MutableRefObject} - a new ref, which translates all changes to {refs}\n *\n * @see {@link mergeRefs} a version without buit-in memoization\n * @see https://github.com/theKashey/use-callback-ref#usemergerefs\n * @example\n * const Component = React.forwardRef((props, ref) => {\n * const ownRef = useRef();\n * const domRef = useMergeRefs([ref, ownRef]); // 👈 merge together\n * return <div ref={domRef}>...</div>\n * }\n */\nexport function useMergeRefs(refs, defaultValue) {\n var callbackRef = useCallbackRef(defaultValue || null, function (newValue) {\n return refs.forEach(function (ref) { return assignRef(ref, newValue); });\n });\n // handle refs changes - added or removed\n useIsomorphicLayoutEffect(function () {\n var oldValue = currentValues.get(callbackRef);\n if (oldValue) {\n var prevRefs_1 = new Set(oldValue);\n var nextRefs_1 = new Set(refs);\n var current_1 = callbackRef.current;\n prevRefs_1.forEach(function (ref) {\n if (!nextRefs_1.has(ref)) {\n assignRef(ref, null);\n }\n });\n nextRefs_1.forEach(function (ref) {\n if (!prevRefs_1.has(ref)) {\n assignRef(ref, current_1);\n }\n });\n }\n currentValues.set(callbackRef, refs);\n }, [refs]);\n return callbackRef;\n}\n","import { __assign } from \"tslib\";\nfunction ItoI(a) {\n return a;\n}\nfunction innerCreateMedium(defaults, middleware) {\n if (middleware === void 0) { middleware = ItoI; }\n var buffer = [];\n var assigned = false;\n var medium = {\n read: function () {\n if (assigned) {\n throw new Error('Sidecar: could not `read` from an `assigned` medium. `read` could be used only with `useMedium`.');\n }\n if (buffer.length) {\n return buffer[buffer.length - 1];\n }\n return defaults;\n },\n useMedium: function (data) {\n var item = middleware(data, assigned);\n buffer.push(item);\n return function () {\n buffer = buffer.filter(function (x) { return x !== item; });\n };\n },\n assignSyncMedium: function (cb) {\n assigned = true;\n while (buffer.length) {\n var cbs = buffer;\n buffer = [];\n cbs.forEach(cb);\n }\n buffer = {\n push: function (x) { return cb(x); },\n filter: function () { return buffer; },\n };\n },\n assignMedium: function (cb) {\n assigned = true;\n var pendingQueue = [];\n if (buffer.length) {\n var cbs = buffer;\n buffer = [];\n cbs.forEach(cb);\n pendingQueue = buffer;\n }\n var executeQueue = function () {\n var cbs = pendingQueue;\n pendingQueue = [];\n cbs.forEach(cb);\n };\n var cycle = function () { return Promise.resolve().then(executeQueue); };\n cycle();\n buffer = {\n push: function (x) {\n pendingQueue.push(x);\n cycle();\n },\n filter: function (filter) {\n pendingQueue = pendingQueue.filter(filter);\n return buffer;\n },\n };\n },\n };\n return medium;\n}\nexport function createMedium(defaults, middleware) {\n if (middleware === void 0) { middleware = ItoI; }\n return innerCreateMedium(defaults, middleware);\n}\n// eslint-disable-next-line @typescript-eslint/ban-types\nexport function createSidecarMedium(options) {\n if (options === void 0) { options = {}; }\n var medium = innerCreateMedium(null);\n medium.options = __assign({ async: true, ssr: false }, options);\n return medium;\n}\n","import { __assign, __rest } from \"tslib\";\nimport * as React from 'react';\nvar SideCar = function (_a) {\n var sideCar = _a.sideCar, rest = __rest(_a, [\"sideCar\"]);\n if (!sideCar) {\n throw new Error('Sidecar: please provide `sideCar` property to import the right car');\n }\n var Target = sideCar.read();\n if (!Target) {\n throw new Error('Sidecar medium not found');\n }\n return React.createElement(Target, __assign({}, rest));\n};\nSideCar.isSideCarExport = true;\nexport function exportSidecar(medium, exported) {\n medium.useMedium(exported);\n return SideCar;\n}\n","import { createSidecarMedium } from 'use-sidecar';\nexport var effectCar = createSidecarMedium();\n","import { __assign, __rest } from \"tslib\";\nimport * as React from 'react';\nimport { fullWidthClassName, zeroRightClassName } from 'react-remove-scroll-bar/constants';\nimport { useMergeRefs } from 'use-callback-ref';\nimport { effectCar } from './medium';\nvar nothing = function () {\n return;\n};\n/**\n * Removes scrollbar from the page and contain the scroll within the Lock\n */\nvar RemoveScroll = React.forwardRef(function (props, parentRef) {\n var ref = React.useRef(null);\n var _a = React.useState({\n onScrollCapture: nothing,\n onWheelCapture: nothing,\n onTouchMoveCapture: nothing,\n }), callbacks = _a[0], setCallbacks = _a[1];\n var forwardProps = props.forwardProps, children = props.children, className = props.className, removeScrollBar = props.removeScrollBar, enabled = props.enabled, shards = props.shards, sideCar = props.sideCar, noRelative = props.noRelative, noIsolation = props.noIsolation, inert = props.inert, allowPinchZoom = props.allowPinchZoom, _b = props.as, Container = _b === void 0 ? 'div' : _b, gapMode = props.gapMode, rest = __rest(props, [\"forwardProps\", \"children\", \"className\", \"removeScrollBar\", \"enabled\", \"shards\", \"sideCar\", \"noRelative\", \"noIsolation\", \"inert\", \"allowPinchZoom\", \"as\", \"gapMode\"]);\n var SideCar = sideCar;\n var containerRef = useMergeRefs([ref, parentRef]);\n var containerProps = __assign(__assign({}, rest), callbacks);\n return (React.createElement(React.Fragment, null,\n enabled && (React.createElement(SideCar, { sideCar: effectCar, removeScrollBar: removeScrollBar, shards: shards, noRelative: noRelative, noIsolation: noIsolation, inert: inert, setCallbacks: setCallbacks, allowPinchZoom: !!allowPinchZoom, lockRef: ref, gapMode: gapMode })),\n forwardProps ? (React.cloneElement(React.Children.only(children), __assign(__assign({}, containerProps), { ref: containerRef }))) : (React.createElement(Container, __assign({}, containerProps, { className: className, ref: containerRef }), children))));\n});\nRemoveScroll.defaultProps = {\n enabled: true,\n removeScrollBar: true,\n inert: false,\n};\nRemoveScroll.classNames = {\n fullWidth: fullWidthClassName,\n zeroRight: zeroRightClassName,\n};\nexport { RemoveScroll };\n","var currentNonce;\nexport var setNonce = function (nonce) {\n currentNonce = nonce;\n};\nexport var getNonce = function () {\n if (currentNonce) {\n return currentNonce;\n }\n if (typeof __webpack_nonce__ !== 'undefined') {\n return __webpack_nonce__;\n }\n return undefined;\n};\n","import { getNonce } from 'get-nonce';\nfunction makeStyleTag() {\n if (!document)\n return null;\n var tag = document.createElement('style');\n tag.type = 'text/css';\n var nonce = getNonce();\n if (nonce) {\n tag.setAttribute('nonce', nonce);\n }\n return tag;\n}\nfunction injectStyles(tag, css) {\n // @ts-ignore\n if (tag.styleSheet) {\n // @ts-ignore\n tag.styleSheet.cssText = css;\n }\n else {\n tag.appendChild(document.createTextNode(css));\n }\n}\nfunction insertStyleTag(tag) {\n var head = document.head || document.getElementsByTagName('head')[0];\n head.appendChild(tag);\n}\nexport var stylesheetSingleton = function () {\n var counter = 0;\n var stylesheet = null;\n return {\n add: function (style) {\n if (counter == 0) {\n if ((stylesheet = makeStyleTag())) {\n injectStyles(stylesheet, style);\n insertStyleTag(stylesheet);\n }\n }\n counter++;\n },\n remove: function () {\n counter--;\n if (!counter && stylesheet) {\n stylesheet.parentNode && stylesheet.parentNode.removeChild(stylesheet);\n stylesheet = null;\n }\n },\n };\n};\n","import * as React from 'react';\nimport { stylesheetSingleton } from './singleton';\n/**\n * creates a hook to control style singleton\n * @see {@link styleSingleton} for a safer component version\n * @example\n * ```tsx\n * const useStyle = styleHookSingleton();\n * ///\n * useStyle('body { overflow: hidden}');\n */\nexport var styleHookSingleton = function () {\n var sheet = stylesheetSingleton();\n return function (styles, isDynamic) {\n React.useEffect(function () {\n sheet.add(styles);\n return function () {\n sheet.remove();\n };\n }, [styles && isDynamic]);\n };\n};\n","import { styleHookSingleton } from './hook';\n/**\n * create a Component to add styles on demand\n * - styles are added when first instance is mounted\n * - styles are removed when the last instance is unmounted\n * - changing styles in runtime does nothing unless dynamic is set. But with multiple components that can lead to the undefined behavior\n */\nexport var styleSingleton = function () {\n var useStyle = styleHookSingleton();\n var Sheet = function (_a) {\n var styles = _a.styles, dynamic = _a.dynamic;\n useStyle(styles, dynamic);\n return null;\n };\n return Sheet;\n};\n","export var zeroGap = {\n left: 0,\n top: 0,\n right: 0,\n gap: 0,\n};\nvar parse = function (x) { return parseInt(x || '', 10) || 0; };\nvar getOffset = function (gapMode) {\n var cs = window.getComputedStyle(document.body);\n var left = cs[gapMode === 'padding' ? 'paddingLeft' : 'marginLeft'];\n var top = cs[gapMode === 'padding' ? 'paddingTop' : 'marginTop'];\n var right = cs[gapMode === 'padding' ? 'paddingRight' : 'marginRight'];\n return [parse(left), parse(top), parse(right)];\n};\nexport var getGapWidth = function (gapMode) {\n if (gapMode === void 0) { gapMode = 'margin'; }\n if (typeof window === 'undefined') {\n return zeroGap;\n }\n var offsets = getOffset(gapMode);\n var documentWidth = document.documentElement.clientWidth;\n var windowWidth = window.innerWidth;\n return {\n left: offsets[0],\n top: offsets[1],\n right: offsets[2],\n gap: Math.max(0, windowWidth - documentWidth + offsets[2] - offsets[0]),\n };\n};\n","import * as React from 'react';\nimport { styleSingleton } from 'react-style-singleton';\nimport { fullWidthClassName, zeroRightClassName, noScrollbarsClassName, removedBarSizeVariable } from './constants';\nimport { getGapWidth } from './utils';\nvar Style = styleSingleton();\nexport var lockAttribute = 'data-scroll-locked';\n// important tip - once we measure scrollBar width and remove them\n// we could not repeat this operation\n// thus we are using style-singleton - only the first \"yet correct\" style will be applied.\nvar getStyles = function (_a, allowRelative, gapMode, important) {\n var left = _a.left, top = _a.top, right = _a.right, gap = _a.gap;\n if (gapMode === void 0) { gapMode = 'margin'; }\n return \"\\n .\".concat(noScrollbarsClassName, \" {\\n overflow: hidden \").concat(important, \";\\n padding-right: \").concat(gap, \"px \").concat(important, \";\\n }\\n body[\").concat(lockAttribute, \"] {\\n overflow: hidden \").concat(important, \";\\n overscroll-behavior: contain;\\n \").concat([\n allowRelative && \"position: relative \".concat(important, \";\"),\n gapMode === 'margin' &&\n \"\\n padding-left: \".concat(left, \"px;\\n padding-top: \").concat(top, \"px;\\n padding-right: \").concat(right, \"px;\\n margin-left:0;\\n margin-top:0;\\n margin-right: \").concat(gap, \"px \").concat(important, \";\\n \"),\n gapMode === 'padding' && \"padding-right: \".concat(gap, \"px \").concat(important, \";\"),\n ]\n .filter(Boolean)\n .join(''), \"\\n }\\n \\n .\").concat(zeroRightClassName, \" {\\n right: \").concat(gap, \"px \").concat(important, \";\\n }\\n \\n .\").concat(fullWidthClassName, \" {\\n margin-right: \").concat(gap, \"px \").concat(important, \";\\n }\\n \\n .\").concat(zeroRightClassName, \" .\").concat(zeroRightClassName, \" {\\n right: 0 \").concat(important, \";\\n }\\n \\n .\").concat(fullWidthClassName, \" .\").concat(fullWidthClassName, \" {\\n margin-right: 0 \").concat(important, \";\\n }\\n \\n body[\").concat(lockAttribute, \"] {\\n \").concat(removedBarSizeVariable, \": \").concat(gap, \"px;\\n }\\n\");\n};\nvar getCurrentUseCounter = function () {\n var counter = parseInt(document.body.getAttribute(lockAttribute) || '0', 10);\n return isFinite(counter) ? counter : 0;\n};\nexport var useLockAttribute = function () {\n React.useEffect(function () {\n document.body.setAttribute(lockAttribute, (getCurrentUseCounter() + 1).toString());\n return function () {\n var newCounter = getCurrentUseCounter() - 1;\n if (newCounter <= 0) {\n document.body.removeAttribute(lockAttribute);\n }\n else {\n document.body.setAttribute(lockAttribute, newCounter.toString());\n }\n };\n }, []);\n};\n/**\n * Removes page scrollbar and blocks page scroll when mounted\n */\nexport var RemoveScrollBar = function (_a) {\n var noRelative = _a.noRelative, noImportant = _a.noImportant, _b = _a.gapMode, gapMode = _b === void 0 ? 'margin' : _b;\n useLockAttribute();\n /*\n gap will be measured on every component mount\n however it will be used only by the \"first\" invocation\n due to singleton nature of <Style\n */\n var gap = React.useMemo(function () { return getGapWidth(gapMode); }, [gapMode]);\n return React.createElement(Style, { styles: getStyles(gap, !noRelative, gapMode, !noImportant ? '!important' : '') });\n};\n","var passiveSupported = false;\nif (typeof window !== 'undefined') {\n try {\n var options = Object.defineProperty({}, 'passive', {\n get: function () {\n passiveSupported = true;\n return true;\n },\n });\n // @ts-ignore\n window.addEventListener('test', options, options);\n // @ts-ignore\n window.removeEventListener('test', options, options);\n }\n catch (err) {\n passiveSupported = false;\n }\n}\nexport var nonPassive = passiveSupported ? { passive: false } : false;\n","var alwaysContainsScroll = function (node) {\n // textarea will always _contain_ scroll inside self. It only can be hidden\n return node.tagName === 'TEXTAREA';\n};\nvar elementCanBeScrolled = function (node, overflow) {\n if (!(node instanceof Element)) {\n return false;\n }\n var styles = window.getComputedStyle(node);\n return (\n // not-not-scrollable\n styles[overflow] !== 'hidden' &&\n // contains scroll inside self\n !(styles.overflowY === styles.overflowX && !alwaysContainsScroll(node) && styles[overflow] === 'visible'));\n};\nvar elementCouldBeVScrolled = function (node) { return elementCanBeScrolled(node, 'overflowY'); };\nvar elementCouldBeHScrolled = function (node) { return elementCanBeScrolled(node, 'overflowX'); };\nexport var locationCouldBeScrolled = function (axis, node) {\n var ownerDocument = node.ownerDocument;\n var current = node;\n do {\n // Skip over shadow root\n if (typeof ShadowRoot !== 'undefined' && current instanceof ShadowRoot) {\n current = current.host;\n }\n var isScrollable = elementCouldBeScrolled(axis, current);\n if (isScrollable) {\n var _a = getScrollVariables(axis, current), scrollHeight = _a[1], clientHeight = _a[2];\n if (scrollHeight > clientHeight) {\n return true;\n }\n }\n current = current.parentNode;\n } while (current && current !== ownerDocument.body);\n return false;\n};\nvar getVScrollVariables = function (_a) {\n var scrollTop = _a.scrollTop, scrollHeight = _a.scrollHeight, clientHeight = _a.clientHeight;\n return [\n scrollTop,\n scrollHeight,\n clientHeight,\n ];\n};\nvar getHScrollVariables = function (_a) {\n var scrollLeft = _a.scrollLeft, scrollWidth = _a.scrollWidth, clientWidth = _a.clientWidth;\n return [\n scrollLeft,\n scrollWidth,\n clientWidth,\n ];\n};\nvar elementCouldBeScrolled = function (axis, node) {\n return axis === 'v' ? elementCouldBeVScrolled(node) : elementCouldBeHScrolled(node);\n};\nvar getScrollVariables = function (axis, node) {\n return axis === 'v' ? getVScrollVariables(node) : getHScrollVariables(node);\n};\nvar getDirectionFactor = function (axis, direction) {\n /**\n * If the element's direction is rtl (right-to-left), then scrollLeft is 0 when the scrollbar is at its rightmost position,\n * and then increasingly negative as you scroll towards the end of the content.\n * @see https://developer.mozilla.org/en-US/docs/Web/API/Element/scrollLeft\n */\n return axis === 'h' && direction === 'rtl' ? -1 : 1;\n};\nexport var handleScroll = function (axis, endTarget, event, sourceDelta, noOverscroll) {\n var directionFactor = getDirectionFactor(axis, window.getComputedStyle(endTarget).direction);\n var delta = directionFactor * sourceDelta;\n // find scrollable target\n var target = event.target;\n var targetInLock = endTarget.contains(target);\n var shouldCancelScroll = false;\n var isDeltaPositive = delta > 0;\n var availableScroll = 0;\n var availableScrollTop = 0;\n do {\n if (!target) {\n break;\n }\n var _a = getScrollVariables(axis, target), position = _a[0], scroll_1 = _a[1], capacity = _a[2];\n var elementScroll = scroll_1 - capacity - directionFactor * position;\n if (position || elementScroll) {\n if (elementCouldBeScrolled(axis, target)) {\n availableScroll += elementScroll;\n availableScrollTop += position;\n }\n }\n var parent_1 = target.parentNode;\n // we will \"bubble\" from ShadowDom in case we are, or just to the parent in normal case\n // this is the same logic used in focus-lock\n target = (parent_1 && parent_1.nodeType === Node.DOCUMENT_FRAGMENT_NODE ? parent_1.host : parent_1);\n } while (\n // portaled content\n (!targetInLock && target !== document.body) ||\n // self content\n (targetInLock && (endTarget.contains(target) || endTarget === target)));\n // handle epsilon around 0 (non standard zoom levels)\n if (isDeltaPositive &&\n ((noOverscroll && Math.abs(availableScroll) < 1) || (!noOverscroll && delta > availableScroll))) {\n shouldCancelScroll = true;\n }\n else if (!isDeltaPositive &&\n ((noOverscroll && Math.abs(availableScrollTop) < 1) || (!noOverscroll && -delta > availableScrollTop))) {\n shouldCancelScroll = true;\n }\n return shouldCancelScroll;\n};\n","import { __spreadArray } from \"tslib\";\nimport * as React from 'react';\nimport { RemoveScrollBar } from 'react-remove-scroll-bar';\nimport { styleSingleton } from 'react-style-singleton';\nimport { nonPassive } from './aggresiveCapture';\nimport { handleScroll, locationCouldBeScrolled } from './handleScroll';\nexport var getTouchXY = function (event) {\n return 'changedTouches' in event ? [event.changedTouches[0].clientX, event.changedTouches[0].clientY] : [0, 0];\n};\nexport var getDeltaXY = function (event) { return [event.deltaX, event.deltaY]; };\nvar extractRef = function (ref) {\n return ref && 'current' in ref ? ref.current : ref;\n};\nvar deltaCompare = function (x, y) { return x[0] === y[0] && x[1] === y[1]; };\nvar generateStyle = function (id) { return \"\\n .block-interactivity-\".concat(id, \" {pointer-events: none;}\\n .allow-interactivity-\").concat(id, \" {pointer-events: all;}\\n\"); };\nvar idCounter = 0;\nvar lockStack = [];\nexport function RemoveScrollSideCar(props) {\n var shouldPreventQueue = React.useRef([]);\n var touchStartRef = React.useRef([0, 0]);\n var activeAxis = React.useRef();\n var id = React.useState(idCounter++)[0];\n var Style = React.useState(styleSingleton)[0];\n var lastProps = React.useRef(props);\n React.useEffect(function () {\n lastProps.current = props;\n }, [props]);\n React.useEffect(function () {\n if (props.inert) {\n document.body.classList.add(\"block-interactivity-\".concat(id));\n var allow_1 = __spreadArray([props.lockRef.current], (props.shards || []).map(extractRef), true).filter(Boolean);\n allow_1.forEach(function (el) { return el.classList.add(\"allow-interactivity-\".concat(id)); });\n return function () {\n document.body.classList.remove(\"block-interactivity-\".concat(id));\n allow_1.forEach(function (el) { return el.classList.remove(\"allow-interactivity-\".concat(id)); });\n };\n }\n return;\n }, [props.inert, props.lockRef.current, props.shards]);\n var shouldCancelEvent = React.useCallback(function (event, parent) {\n if (('touches' in event && event.touches.length === 2) || (event.type === 'wheel' && event.ctrlKey)) {\n return !lastProps.current.allowPinchZoom;\n }\n var touch = getTouchXY(event);\n var touchStart = touchStartRef.current;\n var deltaX = 'deltaX' in event ? event.deltaX : touchStart[0] - touch[0];\n var deltaY = 'deltaY' in event ? event.deltaY : touchStart[1] - touch[1];\n var currentAxis;\n var target = event.target;\n var moveDirection = Math.abs(deltaX) > Math.abs(deltaY) ? 'h' : 'v';\n // allow horizontal touch move on Range inputs. They will not cause any scroll\n if ('touches' in event && moveDirection === 'h' && target.type === 'range') {\n return false;\n }\n // allow drag selection (iOS); check if selection's anchorNode is the same as target or contains target\n var selection = window.getSelection();\n var anchorNode = selection && selection.anchorNode;\n var isTouchingSelection = anchorNode ? anchorNode === target || anchorNode.contains(target) : false;\n if (isTouchingSelection) {\n return false;\n }\n var canBeScrolledInMainDirection = locationCouldBeScrolled(moveDirection, target);\n if (!canBeScrolledInMainDirection) {\n return true;\n }\n if (canBeScrolledInMainDirection) {\n currentAxis = moveDirection;\n }\n else {\n currentAxis = moveDirection === 'v' ? 'h' : 'v';\n canBeScrolledInMainDirection = locationCouldBeScrolled(moveDirection, target);\n // other axis might be not scrollable\n }\n if (!canBeScrolledInMainDirection) {\n return false;\n }\n if (!activeAxis.current && 'changedTouches' in event && (deltaX || deltaY)) {\n activeAxis.current = currentAxis;\n }\n if (!currentAxis) {\n return true;\n }\n var cancelingAxis = activeAxis.current || currentAxis;\n return handleScroll(cancelingAxis, parent, event, cancelingAxis === 'h' ? deltaX : deltaY, true);\n }, []);\n var shouldPrevent = React.useCallback(function (_event) {\n var event = _event;\n if (!lockStack.length || lockStack[lockStack.length - 1] !== Style) {\n // not the last active\n return;\n }\n var delta = 'deltaY' in event ? getDeltaXY(event) : getTouchXY(event);\n var sourceEvent = shouldPreventQueue.current.filter(function (e) { return e.name === event.type && (e.target === event.target || event.target === e.shadowParent) && deltaCompare(e.delta, delta); })[0];\n // self event, and should be canceled\n if (sourceEvent && sourceEvent.should) {\n if (event.cancelable) {\n event.preventDefault();\n }\n return;\n }\n // outside or shard event\n if (!sourceEvent) {\n var shardNodes = (lastProps.current.shards || [])\n .map(extractRef)\n .filter(Boolean)\n .filter(function (node) { return node.contains(event.target); });\n var shouldStop = shardNodes.length > 0 ? shouldCancelEvent(event, shardNodes[0]) : !lastProps.current.noIsolation;\n if (shouldStop) {\n if (event.cancelable) {\n event.preventDefault();\n }\n }\n }\n }, []);\n var shouldCancel = React.useCallback(function (name, delta, target, should) {\n var event = { name: name, delta: delta, target: target, should: should, shadowParent: getOutermostShadowParent(target) };\n shouldPreventQueue.current.push(event);\n setTimeout(function () {\n shouldPreventQueue.current = shouldPreventQueue.current.filter(function (e) { return e !== event; });\n }, 1);\n }, []);\n var scrollTouchStart = React.useCallback(function (event) {\n touchStartRef.current = getTouchXY(event);\n activeAxis.current = undefined;\n }, []);\n var scrollWheel = React.useCallback(function (event) {\n shouldCancel(event.type, getDeltaXY(event), event.target, shouldCancelEvent(event, props.lockRef.current));\n }, []);\n var scrollTouchMove = React.useCallback(function (event) {\n shouldCancel(event.type, getTouchXY(event), event.target, shouldCancelEvent(event, props.lockRef.current));\n }, []);\n React.useEffect(function () {\n lockStack.push(Style);\n props.setCallbacks({\n onScrollCapture: scrollWheel,\n onWheelCapture: scrollWheel,\n onTouchMoveCapture: scrollTouchMove,\n });\n document.addEventListener('wheel', shouldPrevent, nonPassive);\n document.addEventListener('touchmove', shouldPrevent, nonPassive);\n document.addEventListener('touchstart', scrollTouchStart, nonPassive);\n return function () {\n lockStack = lockStack.filter(function (inst) { return inst !== Style; });\n document.removeEventListener('wheel', shouldPrevent, nonPassive);\n document.removeEventListener('touchmove', shouldPrevent, nonPassive);\n document.removeEventListener('touchstart', scrollTouchStart, nonPassive);\n };\n }, []);\n var removeScrollBar = props.removeScrollBar, inert = props.inert;\n return (React.createElement(React.Fragment, null,\n inert ? React.createElement(Style, { styles: generateStyle(id) }) : null,\n removeScrollBar ? React.createElement(RemoveScrollBar, { noRelative: props.noRelative, gapMode: props.gapMode }) : null));\n}\nfunction getOutermostShadowParent(node) {\n var shadowParent = null;\n while (node !== null) {\n if (node instanceof ShadowRoot) {\n shadowParent = node.host;\n node = node.host;\n }\n node = node.parentNode;\n }\n return shadowParent;\n}\n","import { exportSidecar } from 'use-sidecar';\nimport { RemoveScrollSideCar } from './SideEffect';\nimport { effectCar } from './medium';\nexport default exportSidecar(effectCar, RemoveScrollSideCar);\n","import { __assign } from \"tslib\";\nimport * as React from 'react';\nimport { RemoveScroll } from './UI';\nimport SideCar from './sidecar';\nvar ReactRemoveScroll = React.forwardRef(function (props, ref) { return (React.createElement(RemoveScroll, __assign({}, props, { ref: ref, sideCar: SideCar }))); });\nReactRemoveScroll.classNames = RemoveScroll.classNames;\nexport default ReactRemoveScroll;\n","\"use client\";\n\n// src/select.tsx\nimport * as React from \"react\";\nimport * as ReactDOM from \"react-dom\";\nimport { clamp } from \"@radix-ui/number\";\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\nimport { createCollection } from \"@radix-ui/react-collection\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { createContextScope } from \"@radix-ui/react-context\";\nimport { useDirection } from \"@radix-ui/react-direction\";\nimport { DismissableLayer } from \"@radix-ui/react-dismissable-layer\";\nimport { useFocusGuards } from \"@radix-ui/react-focus-guards\";\nimport { FocusScope } from \"@radix-ui/react-focus-scope\";\nimport { useId } from \"@radix-ui/react-id\";\nimport * as PopperPrimitive from \"@radix-ui/react-popper\";\nimport { createPopperScope } from \"@radix-ui/react-popper\";\nimport { Portal as PortalPrimitive } from \"@radix-ui/react-portal\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { createSlot } from \"@radix-ui/react-slot\";\nimport { useCallbackRef } from \"@radix-ui/react-use-callback-ref\";\nimport { useControllableState } from \"@radix-ui/react-use-controllable-state\";\nimport { useLayoutEffect } from \"@radix-ui/react-use-layout-effect\";\nimport { usePrevious } from \"@radix-ui/react-use-previous\";\nimport { VISUALLY_HIDDEN_STYLES } from \"@radix-ui/react-visually-hidden\";\nimport { hideOthers } from \"aria-hidden\";\nimport { RemoveScroll } from \"react-remove-scroll\";\nimport { Fragment, jsx, jsxs } from \"react/jsx-runtime\";\nvar OPEN_KEYS = [\" \", \"Enter\", \"ArrowUp\", \"ArrowDown\"];\nvar SELECTION_KEYS = [\" \", \"Enter\"];\nvar SELECT_NAME = \"Select\";\nvar [Collection, useCollection, createCollectionScope] = createCollection(SELECT_NAME);\nvar [createSelectContext, createSelectScope] = createContextScope(SELECT_NAME, [\n createCollectionScope,\n createPopperScope\n]);\nvar usePopperScope = createPopperScope();\nvar [SelectProvider, useSelectContext] = createSelectContext(SELECT_NAME);\nvar [SelectNativeOptionsProvider, useSelectNativeOptionsContext] = createSelectContext(SELECT_NAME);\nvar Select = (props) => {\n const {\n __scopeSelect,\n children,\n open: openProp,\n defaultOpen,\n onOpenChange,\n value: valueProp,\n defaultValue,\n onValueChange,\n dir,\n name,\n autoComplete,\n disabled,\n required,\n form\n } = props;\n const popperScope = usePopperScope(__scopeSelect);\n const [trigger, setTrigger] = React.useState(null);\n const [valueNode, setValueNode] = React.useState(null);\n const [valueNodeHasChildren, setValueNodeHasChildren] = React.useState(false);\n const direction = useDirection(dir);\n const [open, setOpen] = useControllableState({\n prop: openProp,\n defaultProp: defaultOpen ?? false,\n onChange: onOpenChange,\n caller: SELECT_NAME\n });\n const [value, setValue] = useControllableState({\n prop: valueProp,\n defaultProp: defaultValue,\n onChange: onValueChange,\n caller: SELECT_NAME\n });\n const triggerPointerDownPosRef = React.useRef(null);\n const isFormControl = trigger ? form || !!trigger.closest(\"form\") : true;\n const [nativeOptionsSet, setNativeOptionsSet] = React.useState(/* @__PURE__ */ new Set());\n const nativeSelectKey = Array.from(nativeOptionsSet).map((option) => option.props.value).join(\";\");\n return /* @__PURE__ */ jsx(PopperPrimitive.Root, { ...popperScope, children: /* @__PURE__ */ jsxs(\n SelectProvider,\n {\n required,\n scope: __scopeSelect,\n trigger,\n onTriggerChange: setTrigger,\n valueNode,\n onValueNodeChange: setValueNode,\n valueNodeHasChildren,\n onValueNodeHasChildrenChange: setValueNodeHasChildren,\n contentId: useId(),\n value,\n onValueChange: setValue,\n open,\n onOpenChange: setOpen,\n dir: direction,\n triggerPointerDownPosRef,\n disabled,\n children: [\n /* @__PURE__ */ jsx(Collection.Provider, { scope: __scopeSelect, children: /* @__PURE__ */ jsx(\n SelectNativeOptionsProvider,\n {\n scope: props.__scopeSelect,\n onNativeOptionAdd: React.useCallback((option) => {\n setNativeOptionsSet((prev) => new Set(prev).add(option));\n }, []),\n onNativeOptionRemove: React.useCallback((option) => {\n setNativeOptionsSet((prev) => {\n const optionsSet = new Set(prev);\n optionsSet.delete(option);\n return optionsSet;\n });\n }, []),\n children\n }\n ) }),\n isFormControl ? /* @__PURE__ */ jsxs(\n SelectBubbleInput,\n {\n \"aria-hidden\": true,\n required,\n tabIndex: -1,\n name,\n autoComplete,\n value,\n onChange: (event) => setValue(event.target.value),\n disabled,\n form,\n children: [\n value === void 0 ? /* @__PURE__ */ jsx(\"option\", { value: \"\" }) : null,\n Array.from(nativeOptionsSet)\n ]\n },\n nativeSelectKey\n ) : null\n ]\n }\n ) });\n};\nSelect.displayName = SELECT_NAME;\nvar TRIGGER_NAME = \"SelectTrigger\";\nvar SelectTrigger = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeSelect, disabled = false, ...triggerProps } = props;\n const popperScope = usePopperScope(__scopeSelect);\n const context = useSelectContext(TRIGGER_NAME, __scopeSelect);\n const isDisabled = context.disabled || disabled;\n const composedRefs = useComposedRefs(forwardedRef, context.onTriggerChange);\n const getItems = useCollection(__scopeSelect);\n const pointerTypeRef = React.useRef(\"touch\");\n const [searchRef, handleTypeaheadSearch, resetTypeahead] = useTypeaheadSearch((search) => {\n const enabledItems = getItems().filter((item) => !item.disabled);\n const currentItem = enabledItems.find((item) => item.value === context.value);\n const nextItem = findNextItem(enabledItems, search, currentItem);\n if (nextItem !== void 0) {\n context.onValueChange(nextItem.value);\n }\n });\n const handleOpen = (pointerEvent) => {\n if (!isDisabled) {\n context.onOpenChange(true);\n resetTypeahead();\n }\n if (pointerEvent) {\n context.triggerPointerDownPosRef.current = {\n x: Math.round(pointerEvent.pageX),\n y: Math.round(pointerEvent.pageY)\n };\n }\n };\n return /* @__PURE__ */ jsx(PopperPrimitive.Anchor, { asChild: true, ...popperScope, children: /* @__PURE__ */ jsx(\n Primitive.button,\n {\n type: \"button\",\n role: \"combobox\",\n \"aria-controls\": context.contentId,\n \"aria-expanded\": context.open,\n \"aria-required\": context.required,\n \"aria-autocomplete\": \"none\",\n dir: context.dir,\n \"data-state\": context.open ? \"open\" : \"closed\",\n disabled: isDisabled,\n \"data-disabled\": isDisabled ? \"\" : void 0,\n \"data-placeholder\": shouldShowPlaceholder(context.value) ? \"\" : void 0,\n ...triggerProps,\n ref: composedRefs,\n onClick: composeEventHandlers(triggerProps.onClick, (event) => {\n event.currentTarget.focus();\n if (pointerTypeRef.current !== \"mouse\") {\n handleOpen(event);\n }\n }),\n onPointerDown: composeEventHandlers(triggerProps.onPointerDown, (event) => {\n pointerTypeRef.current = event.pointerType;\n const target = event.target;\n if (target.hasPointerCapture(event.pointerId)) {\n target.releasePointerCapture(event.pointerId);\n }\n if (event.button === 0 && event.ctrlKey === false && event.pointerType === \"mouse\") {\n handleOpen(event);\n event.preventDefault();\n }\n }),\n onKeyDown: composeEventHandlers(triggerProps.onKeyDown, (event) => {\n const isTypingAhead = searchRef.current !== \"\";\n const isModifierKey = event.ctrlKey || event.altKey || event.metaKey;\n if (!isModifierKey && event.key.length === 1) handleTypeaheadSearch(event.key);\n if (isTypingAhead && event.key === \" \") return;\n if (OPEN_KEYS.includes(event.key)) {\n handleOpen();\n event.preventDefault();\n }\n })\n }\n ) });\n }\n);\nSelectTrigger.displayName = TRIGGER_NAME;\nvar VALUE_NAME = \"SelectValue\";\nvar SelectValue = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeSelect, className, style, children, placeholder = \"\", ...valueProps } = props;\n const context = useSelectContext(VALUE_NAME, __scopeSelect);\n const { onValueNodeHasChildrenChange } = context;\n const hasChildren = children !== void 0;\n const composedRefs = useComposedRefs(forwardedRef, context.onValueNodeChange);\n useLayoutEffect(() => {\n onValueNodeHasChildrenChange(hasChildren);\n }, [onValueNodeHasChildrenChange, hasChildren]);\n return /* @__PURE__ */ jsx(\n Primitive.span,\n {\n ...valueProps,\n ref: composedRefs,\n style: { pointerEvents: \"none\" },\n children: shouldShowPlaceholder(context.value) ? /* @__PURE__ */ jsx(Fragment, { children: placeholder }) : children\n }\n );\n }\n);\nSelectValue.displayName = VALUE_NAME;\nvar ICON_NAME = \"SelectIcon\";\nvar SelectIcon = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeSelect, children, ...iconProps } = props;\n return /* @__PURE__ */ jsx(Primitive.span, { \"aria-hidden\": true, ...iconProps, ref: forwardedRef, children: children || \"\\u25BC\" });\n }\n);\nSelectIcon.displayName = ICON_NAME;\nvar PORTAL_NAME = \"SelectPortal\";\nvar SelectPortal = (props) => {\n return /* @__PURE__ */ jsx(PortalPrimitive, { asChild: true, ...props });\n};\nSelectPortal.displayName = PORTAL_NAME;\nvar CONTENT_NAME = \"SelectContent\";\nvar SelectContent = React.forwardRef(\n (props, forwardedRef) => {\n const context = useSelectContext(CONTENT_NAME, props.__scopeSelect);\n const [fragment, setFragment] = React.useState();\n useLayoutEffect(() => {\n setFragment(new DocumentFragment());\n }, []);\n if (!context.open) {\n const frag = fragment;\n return frag ? ReactDOM.createPortal(\n /* @__PURE__ */ jsx(SelectContentProvider, { scope: props.__scopeSelect, children: /* @__PURE__ */ jsx(Collection.Slot, { scope: props.__scopeSelect, children: /* @__PURE__ */ jsx(\"div\", { children: props.children }) }) }),\n frag\n ) : null;\n }\n return /* @__PURE__ */ jsx(SelectContentImpl, { ...props, ref: forwardedRef });\n }\n);\nSelectContent.displayName = CONTENT_NAME;\nvar CONTENT_MARGIN = 10;\nvar [SelectContentProvider, useSelectContentContext] = createSelectContext(CONTENT_NAME);\nvar CONTENT_IMPL_NAME = \"SelectContentImpl\";\nvar Slot = createSlot(\"SelectContent.RemoveScroll\");\nvar SelectContentImpl = React.forwardRef(\n (props, forwardedRef) => {\n const {\n __scopeSelect,\n position = \"item-aligned\",\n onCloseAutoFocus,\n onEscapeKeyDown,\n onPointerDownOutside,\n //\n // PopperContent props\n side,\n sideOffset,\n align,\n alignOffset,\n arrowPadding,\n collisionBoundary,\n collisionPadding,\n sticky,\n hideWhenDetached,\n avoidCollisions,\n //\n ...contentProps\n } = props;\n const context = useSelectContext(CONTENT_NAME, __scopeSelect);\n const [content, setContent] = React.useState(null);\n const [viewport, setViewport] = React.useState(null);\n const composedRefs = useComposedRefs(forwardedRef, (node) => setContent(node));\n const [selectedItem, setSelectedItem] = React.useState(null);\n const [selectedItemText, setSelectedItemText] = React.useState(\n null\n );\n const getItems = useCollection(__scopeSelect);\n const [isPositioned, setIsPositioned] = React.useState(false);\n const firstValidItemFoundRef = React.useRef(false);\n React.useEffect(() => {\n if (content) return hideOthers(content);\n }, [content]);\n useFocusGuards();\n const focusFirst = React.useCallback(\n (candidates) => {\n const [firstItem, ...restItems] = getItems().map((item) => item.ref.current);\n const [lastItem] = restItems.slice(-1);\n const PREVIOUSLY_FOCUSED_ELEMENT = document.activeElement;\n for (const candidate of candidates) {\n if (candidate === PREVIOUSLY_FOCUSED_ELEMENT) return;\n candidate?.scrollIntoView({ block: \"nearest\" });\n if (candidate === firstItem && viewport) viewport.scrollTop = 0;\n if (candidate === lastItem && viewport) viewport.scrollTop = viewport.scrollHeight;\n candidate?.focus();\n if (document.activeElement !== PREVIOUSLY_FOCUSED_ELEMENT) return;\n }\n },\n [getItems, viewport]\n );\n const focusSelectedItem = React.useCallback(\n () => focusFirst([selectedItem, content]),\n [focusFirst, selectedItem, content]\n );\n React.useEffect(() => {\n if (isPositioned) {\n focusSelectedItem();\n }\n }, [isPositioned, focusSelectedItem]);\n const { onOpenChange, triggerPointerDownPosRef } = context;\n React.useEffect(() => {\n if (content) {\n let pointerMoveDelta = { x: 0, y: 0 };\n const handlePointerMove = (event) => {\n pointerMoveDelta = {\n x: Math.abs(Math.round(event.pageX) - (triggerPointerDownPosRef.current?.x ?? 0)),\n y: Math.abs(Math.round(event.pageY) - (triggerPointerDownPosRef.current?.y ?? 0))\n };\n };\n const handlePointerUp = (event) => {\n if (pointerMoveDelta.x <= 10 && pointerMoveDelta.y <= 10) {\n event.preventDefault();\n } else {\n if (!content.contains(event.target)) {\n onOpenChange(false);\n }\n }\n document.removeEventListener(\"pointermove\", handlePointerMove);\n triggerPointerDownPosRef.current = null;\n };\n if (triggerPointerDownPosRef.current !== null) {\n document.addEventListener(\"pointermove\", handlePointerMove);\n document.addEventListener(\"pointerup\", handlePointerUp, { capture: true, once: true });\n }\n return () => {\n document.removeEventListener(\"pointermove\", handlePointerMove);\n document.removeEventListener(\"pointerup\", handlePointerUp, { capture: true });\n };\n }\n }, [content, onOpenChange, triggerPointerDownPosRef]);\n React.useEffect(() => {\n const close = () => onOpenChange(false);\n window.addEventListener(\"blur\", close);\n window.addEventListener(\"resize\", close);\n return () => {\n window.removeEventListener(\"blur\", close);\n window.removeEventListener(\"resize\", close);\n };\n }, [onOpenChange]);\n const [searchRef, handleTypeaheadSearch] = useTypeaheadSearch((search) => {\n const enabledItems = getItems().filter((item) => !item.disabled);\n const currentItem = enabledItems.find((item) => item.ref.current === document.activeElement);\n const nextItem = findNextItem(enabledItems, search, currentItem);\n if (nextItem) {\n setTimeout(() => nextItem.ref.current.focus());\n }\n });\n const itemRefCallback = React.useCallback(\n (node, value, disabled) => {\n const isFirstValidItem = !firstValidItemFoundRef.current && !disabled;\n const isSelectedItem = context.value !== void 0 && context.value === value;\n if (isSelectedItem || isFirstValidItem) {\n setSelectedItem(node);\n if (isFirstValidItem) firstValidItemFoundRef.current = true;\n }\n },\n [context.value]\n );\n const handleItemLeave = React.useCallback(() => content?.focus(), [content]);\n const itemTextRefCallback = React.useCallback(\n (node, value, disabled) => {\n const isFirstValidItem = !firstValidItemFoundRef.current && !disabled;\n const isSelectedItem = context.value !== void 0 && context.value === value;\n if (isSelectedItem || isFirstValidItem) {\n setSelectedItemText(node);\n }\n },\n [context.value]\n );\n const SelectPosition = position === \"popper\" ? SelectPopperPosition : SelectItemAlignedPosition;\n const popperContentProps = SelectPosition === SelectPopperPosition ? {\n side,\n sideOffset,\n align,\n alignOffset,\n arrowPadding,\n collisionBoundary,\n collisionPadding,\n sticky,\n hideWhenDetached,\n avoidCollisions\n } : {};\n return /* @__PURE__ */ jsx(\n SelectContentProvider,\n {\n scope: __scopeSelect,\n content,\n viewport,\n onViewportChange: setViewport,\n itemRefCallback,\n selectedItem,\n onItemLeave: handleItemLeave,\n itemTextRefCallback,\n focusSelectedItem,\n selectedItemText,\n position,\n isPositioned,\n searchRef,\n children: /* @__PURE__ */ jsx(RemoveScroll, { as: Slot, allowPinchZoom: true, children: /* @__PURE__ */ jsx(\n FocusScope,\n {\n asChild: true,\n trapped: context.open,\n onMountAutoFocus: (event) => {\n event.preventDefault();\n },\n onUnmountAutoFocus: composeEventHandlers(onCloseAutoFocus, (event) => {\n context.trigger?.focus({ preventScroll: true });\n event.preventDefault();\n }),\n children: /* @__PURE__ */ jsx(\n DismissableLayer,\n {\n asChild: true,\n disableOutsidePointerEvents: true,\n onEscapeKeyDown,\n onPointerDownOutside,\n onFocusOutside: (event) => event.preventDefault(),\n onDismiss: () => context.onOpenChange(false),\n children: /* @__PURE__ */ jsx(\n SelectPosition,\n {\n role: \"listbox\",\n id: context.contentId,\n \"data-state\": context.open ? \"open\" : \"closed\",\n dir: context.dir,\n onContextMenu: (event) => event.preventDefault(),\n ...contentProps,\n ...popperContentProps,\n onPlaced: () => setIsPositioned(true),\n ref: composedRefs,\n style: {\n // flex layout so we can place the scroll buttons properly\n display: \"flex\",\n flexDirection: \"column\",\n // reset the outline by default as the content MAY get focused\n outline: \"none\",\n ...contentProps.style\n },\n onKeyDown: composeEventHandlers(contentProps.onKeyDown, (event) => {\n const isModifierKey = event.ctrlKey || event.altKey || event.metaKey;\n if (event.key === \"Tab\") event.preventDefault();\n if (!isModifierKey && event.key.length === 1) handleTypeaheadSearch(event.key);\n if ([\"ArrowUp\", \"ArrowDown\", \"Home\", \"End\"].includes(event.key)) {\n const items = getItems().filter((item) => !item.disabled);\n let candidateNodes = items.map((item) => item.ref.current);\n if ([\"ArrowUp\", \"End\"].includes(event.key)) {\n candidateNodes = candidateNodes.slice().reverse();\n }\n if ([\"ArrowUp\", \"ArrowDown\"].includes(event.key)) {\n const currentElement = event.target;\n const currentIndex = candidateNodes.indexOf(currentElement);\n candidateNodes = candidateNodes.slice(currentIndex + 1);\n }\n setTimeout(() => focusFirst(candidateNodes));\n event.preventDefault();\n }\n })\n }\n )\n }\n )\n }\n ) })\n }\n );\n }\n);\nSelectContentImpl.displayName = CONTENT_IMPL_NAME;\nvar ITEM_ALIGNED_POSITION_NAME = \"SelectItemAlignedPosition\";\nvar SelectItemAlignedPosition = React.forwardRef((props, forwardedRef) => {\n const { __scopeSelect, onPlaced, ...popperProps } = props;\n const context = useSelectContext(CONTENT_NAME, __scopeSelect);\n const contentContext = useSelectContentContext(CONTENT_NAME, __scopeSelect);\n const [contentWrapper, setContentWrapper] = React.useState(null);\n const [content, setContent] = React.useState(null);\n const composedRefs = useComposedRefs(forwardedRef, (node) => setContent(node));\n const getItems = useCollection(__scopeSelect);\n const shouldExpandOnScrollRef = React.useRef(false);\n const shouldRepositionRef = React.useRef(true);\n const { viewport, selectedItem, selectedItemText, focusSelectedItem } = contentContext;\n const position = React.useCallback(() => {\n if (context.trigger && context.valueNode && contentWrapper && content && viewport && selectedItem && selectedItemText) {\n const triggerRect = context.trigger.getBoundingClientRect();\n const contentRect = content.getBoundingClientRect();\n const valueNodeRect = context.valueNode.getBoundingClientRect();\n const itemTextRect = selectedItemText.getBoundingClientRect();\n if (context.dir !== \"rtl\") {\n const itemTextOffset = itemTextRect.left - contentRect.left;\n const left = valueNodeRect.left - itemTextOffset;\n const leftDelta = triggerRect.left - left;\n const minContentWidth = triggerRect.width + leftDelta;\n const contentWidth = Math.max(minContentWidth, contentRect.width);\n const rightEdge = window.innerWidth - CONTENT_MARGIN;\n const clampedLeft = clamp(left, [\n CONTENT_MARGIN,\n // Prevents the content from going off the starting edge of the\n // viewport. It may still go off the ending edge, but this can be\n // controlled by the user since they may want to manage overflow in a\n // specific way.\n // https://github.com/radix-ui/primitives/issues/2049\n Math.max(CONTENT_MARGIN, rightEdge - contentWidth)\n ]);\n contentWrapper.style.minWidth = minContentWidth + \"px\";\n contentWrapper.style.left = clampedLeft + \"px\";\n } else {\n const itemTextOffset = contentRect.right - itemTextRect.right;\n const right = window.innerWidth - valueNodeRect.right - itemTextOffset;\n const rightDelta = window.innerWidth - triggerRect.right - right;\n const minContentWidth = triggerRect.width + rightDelta;\n const contentWidth = Math.max(minContentWidth, contentRect.width);\n const leftEdge = window.innerWidth - CONTENT_MARGIN;\n const clampedRight = clamp(right, [\n CONTENT_MARGIN,\n Math.max(CONTENT_MARGIN, leftEdge - contentWidth)\n ]);\n contentWrapper.style.minWidth = minContentWidth + \"px\";\n contentWrapper.style.right = clampedRight + \"px\";\n }\n const items = getItems();\n const availableHeight = window.innerHeight - CONTENT_MARGIN * 2;\n const itemsHeight = viewport.scrollHeight;\n const contentStyles = window.getComputedStyle(content);\n const contentBorderTopWidth = parseInt(contentStyles.borderTopWidth, 10);\n const contentPaddingTop = parseInt(contentStyles.paddingTop, 10);\n const contentBorderBottomWidth = parseInt(contentStyles.borderBottomWidth, 10);\n const contentPaddingBottom = parseInt(contentStyles.paddingBottom, 10);\n const fullContentHeight = contentBorderTopWidth + contentPaddingTop + itemsHeight + contentPaddingBottom + contentBorderBottomWidth;\n const minContentHeight = Math.min(selectedItem.offsetHeight * 5, fullContentHeight);\n const viewportStyles = window.getComputedStyle(viewport);\n const viewportPaddingTop = parseInt(viewportStyles.paddingTop, 10);\n const viewportPaddingBottom = parseInt(viewportStyles.paddingBottom, 10);\n const topEdgeToTriggerMiddle = triggerRect.top + triggerRect.height / 2 - CONTENT_MARGIN;\n const triggerMiddleToBottomEdge = availableHeight - topEdgeToTriggerMiddle;\n const selectedItemHalfHeight = selectedItem.offsetHeight / 2;\n const itemOffsetMiddle = selectedItem.offsetTop + selectedItemHalfHeight;\n const contentTopToItemMiddle = contentBorderTopWidth + contentPaddingTop + itemOffsetMiddle;\n const itemMiddleToContentBottom = fullContentHeight - contentTopToItemMiddle;\n const willAlignWithoutTopOverflow = contentTopToItemMiddle <= topEdgeToTriggerMiddle;\n if (willAlignWithoutTopOverflow) {\n const isLastItem = items.length > 0 && selectedItem === items[items.length - 1].ref.current;\n contentWrapper.style.bottom = \"0px\";\n const viewportOffsetBottom = content.clientHeight - viewport.offsetTop - viewport.offsetHeight;\n const clampedTriggerMiddleToBottomEdge = Math.max(\n triggerMiddleToBottomEdge,\n selectedItemHalfHeight + // viewport might have padding bottom, include it to avoid a scrollable viewport\n (isLastItem ? viewportPaddingBottom : 0) + viewportOffsetBottom + contentBorderBottomWidth\n );\n const height = contentTopToItemMiddle + clampedTriggerMiddleToBottomEdge;\n contentWrapper.style.height = height + \"px\";\n } else {\n const isFirstItem = items.length > 0 && selectedItem === items[0].ref.current;\n contentWrapper.style.top = \"0px\";\n const clampedTopEdgeToTriggerMiddle = Math.max(\n topEdgeToTriggerMiddle,\n contentBorderTopWidth + viewport.offsetTop + // viewport might have padding top, include it to avoid a scrollable viewport\n (isFirstItem ? viewportPaddingTop : 0) + selectedItemHalfHeight\n );\n const height = clampedTopEdgeToTriggerMiddle + itemMiddleToContentBottom;\n contentWrapper.style.height = height + \"px\";\n viewport.scrollTop = contentTopToItemMiddle - topEdgeToTriggerMiddle + viewport.offsetTop;\n }\n contentWrapper.style.margin = `${CONTENT_MARGIN}px 0`;\n contentWrapper.style.minHeight = minContentHeight + \"px\";\n contentWrapper.style.maxHeight = availableHeight + \"px\";\n onPlaced?.();\n requestAnimationFrame(() => shouldExpandOnScrollRef.current = true);\n }\n }, [\n getItems,\n context.trigger,\n context.valueNode,\n contentWrapper,\n content,\n viewport,\n selectedItem,\n selectedItemText,\n context.dir,\n onPlaced\n ]);\n useLayoutEffect(() => position(), [position]);\n const [contentZIndex, setContentZIndex] = React.useState();\n useLayoutEffect(() => {\n if (content) setContentZIndex(window.getComputedStyle(content).zIndex);\n }, [content]);\n const handleScrollButtonChange = React.useCallback(\n (node) => {\n if (node && shouldRepositionRef.current === true) {\n position();\n focusSelectedItem?.();\n shouldRepositionRef.current = false;\n }\n },\n [position, focusSelectedItem]\n );\n return /* @__PURE__ */ jsx(\n SelectViewportProvider,\n {\n scope: __scopeSelect,\n contentWrapper,\n shouldExpandOnScrollRef,\n onScrollButtonChange: handleScrollButtonChange,\n children: /* @__PURE__ */ jsx(\n \"div\",\n {\n ref: setContentWrapper,\n style: {\n display: \"flex\",\n flexDirection: \"column\",\n position: \"fixed\",\n zIndex: contentZIndex\n },\n children: /* @__PURE__ */ jsx(\n Primitive.div,\n {\n ...popperProps,\n ref: composedRefs,\n style: {\n // When we get the height of the content, it includes borders. If we were to set\n // the height without having `boxSizing: 'border-box'` it would be too big.\n boxSizing: \"border-box\",\n // We need to ensure the content doesn't get taller than the wrapper\n maxHeight: \"100%\",\n ...popperProps.style\n }\n }\n )\n }\n )\n }\n );\n});\nSelectItemAlignedPosition.displayName = ITEM_ALIGNED_POSITION_NAME;\nvar POPPER_POSITION_NAME = \"SelectPopperPosition\";\nvar SelectPopperPosition = React.forwardRef((props, forwardedRef) => {\n const {\n __scopeSelect,\n align = \"start\",\n collisionPadding = CONTENT_MARGIN,\n ...popperProps\n } = props;\n const popperScope = usePopperScope(__scopeSelect);\n return /* @__PURE__ */ jsx(\n PopperPrimitive.Content,\n {\n ...popperScope,\n ...popperProps,\n ref: forwardedRef,\n align,\n collisionPadding,\n style: {\n // Ensure border-box for floating-ui calculations\n boxSizing: \"border-box\",\n ...popperProps.style,\n // re-namespace exposed content custom properties\n ...{\n \"--radix-select-content-transform-origin\": \"var(--radix-popper-transform-origin)\",\n \"--radix-select-content-available-width\": \"var(--radix-popper-available-width)\",\n \"--radix-select-content-available-height\": \"var(--radix-popper-available-height)\",\n \"--radix-select-trigger-width\": \"var(--radix-popper-anchor-width)\",\n \"--radix-select-trigger-height\": \"var(--radix-popper-anchor-height)\"\n }\n }\n }\n );\n});\nSelectPopperPosition.displayName = POPPER_POSITION_NAME;\nvar [SelectViewportProvider, useSelectViewportContext] = createSelectContext(CONTENT_NAME, {});\nvar VIEWPORT_NAME = \"SelectViewport\";\nvar SelectViewport = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeSelect, nonce, ...viewportProps } = props;\n const contentContext = useSelectContentContext(VIEWPORT_NAME, __scopeSelect);\n const viewportContext = useSelectViewportContext(VIEWPORT_NAME, __scopeSelect);\n const composedRefs = useComposedRefs(forwardedRef, contentContext.onViewportChange);\n const prevScrollTopRef = React.useRef(0);\n return /* @__PURE__ */ jsxs(Fragment, { children: [\n /* @__PURE__ */ jsx(\n \"style\",\n {\n dangerouslySetInnerHTML: {\n __html: `[data-radix-select-viewport]{scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch;}[data-radix-select-viewport]::-webkit-scrollbar{display:none}`\n },\n nonce\n }\n ),\n /* @__PURE__ */ jsx(Collection.Slot, { scope: __scopeSelect, children: /* @__PURE__ */ jsx(\n Primitive.div,\n {\n \"data-radix-select-viewport\": \"\",\n role: \"presentation\",\n ...viewportProps,\n ref: composedRefs,\n style: {\n // we use position: 'relative' here on the `viewport` so that when we call\n // `selectedItem.offsetTop` in calculations, the offset is relative to the viewport\n // (independent of the scrollUpButton).\n position: \"relative\",\n flex: 1,\n // Viewport should only be scrollable in the vertical direction.\n // This won't work in vertical writing modes, so we'll need to\n // revisit this if/when that is supported\n // https://developer.chrome.com/blog/vertical-form-controls\n overflow: \"hidden auto\",\n ...viewportProps.style\n },\n onScroll: composeEventHandlers(viewportProps.onScroll, (event) => {\n const viewport = event.currentTarget;\n const { contentWrapper, shouldExpandOnScrollRef } = viewportContext;\n if (shouldExpandOnScrollRef?.current && contentWrapper) {\n const scrolledBy = Math.abs(prevScrollTopRef.current - viewport.scrollTop);\n if (scrolledBy > 0) {\n const availableHeight = window.innerHeight - CONTENT_MARGIN * 2;\n const cssMinHeight = parseFloat(contentWrapper.style.minHeight);\n const cssHeight = parseFloat(contentWrapper.style.height);\n const prevHeight = Math.max(cssMinHeight, cssHeight);\n if (prevHeight < availableHeight) {\n const nextHeight = prevHeight + scrolledBy;\n const clampedNextHeight = Math.min(availableHeight, nextHeight);\n const heightDiff = nextHeight - clampedNextHeight;\n contentWrapper.style.height = clampedNextHeight + \"px\";\n if (contentWrapper.style.bottom === \"0px\") {\n viewport.scrollTop = heightDiff > 0 ? heightDiff : 0;\n contentWrapper.style.justifyContent = \"flex-end\";\n }\n }\n }\n }\n prevScrollTopRef.current = viewport.scrollTop;\n })\n }\n ) })\n ] });\n }\n);\nSelectViewport.displayName = VIEWPORT_NAME;\nvar GROUP_NAME = \"SelectGroup\";\nvar [SelectGroupContextProvider, useSelectGroupContext] = createSelectContext(GROUP_NAME);\nvar SelectGroup = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeSelect, ...groupProps } = props;\n const groupId = useId();\n return /* @__PURE__ */ jsx(SelectGroupContextProvider, { scope: __scopeSelect, id: groupId, children: /* @__PURE__ */ jsx(Primitive.div, { role: \"group\", \"aria-labelledby\": groupId, ...groupProps, ref: forwardedRef }) });\n }\n);\nSelectGroup.displayName = GROUP_NAME;\nvar LABEL_NAME = \"SelectLabel\";\nvar SelectLabel = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeSelect, ...labelProps } = props;\n const groupContext = useSelectGroupContext(LABEL_NAME, __scopeSelect);\n return /* @__PURE__ */ jsx(Primitive.div, { id: groupContext.id, ...labelProps, ref: forwardedRef });\n }\n);\nSelectLabel.displayName = LABEL_NAME;\nvar ITEM_NAME = \"SelectItem\";\nvar [SelectItemContextProvider, useSelectItemContext] = createSelectContext(ITEM_NAME);\nvar SelectItem = React.forwardRef(\n (props, forwardedRef) => {\n const {\n __scopeSelect,\n value,\n disabled = false,\n textValue: textValueProp,\n ...itemProps\n } = props;\n const context = useSelectContext(ITEM_NAME, __scopeSelect);\n const contentContext = useSelectContentContext(ITEM_NAME, __scopeSelect);\n const isSelected = context.value === value;\n const [textValue, setTextValue] = React.useState(textValueProp ?? \"\");\n const [isFocused, setIsFocused] = React.useState(false);\n const composedRefs = useComposedRefs(\n forwardedRef,\n (node) => contentContext.itemRefCallback?.(node, value, disabled)\n );\n const textId = useId();\n const pointerTypeRef = React.useRef(\"touch\");\n const handleSelect = () => {\n if (!disabled) {\n context.onValueChange(value);\n context.onOpenChange(false);\n }\n };\n if (value === \"\") {\n throw new Error(\n \"A <Select.Item /> must have a value prop that is not an empty string. This is because the Select value can be set to an empty string to clear the selection and show the placeholder.\"\n );\n }\n return /* @__PURE__ */ jsx(\n SelectItemContextProvider,\n {\n scope: __scopeSelect,\n value,\n disabled,\n textId,\n isSelected,\n onItemTextChange: React.useCallback((node) => {\n setTextValue((prevTextValue) => prevTextValue || (node?.textContent ?? \"\").trim());\n }, []),\n children: /* @__PURE__ */ jsx(\n Collection.ItemSlot,\n {\n scope: __scopeSelect,\n value,\n disabled,\n textValue,\n children: /* @__PURE__ */ jsx(\n Primitive.div,\n {\n role: \"option\",\n \"aria-labelledby\": textId,\n \"data-highlighted\": isFocused ? \"\" : void 0,\n \"aria-selected\": isSelected && isFocused,\n \"data-state\": isSelected ? \"checked\" : \"unchecked\",\n \"aria-disabled\": disabled || void 0,\n \"data-disabled\": disabled ? \"\" : void 0,\n tabIndex: disabled ? void 0 : -1,\n ...itemProps,\n ref: composedRefs,\n onFocus: composeEventHandlers(itemProps.onFocus, () => setIsFocused(true)),\n onBlur: composeEventHandlers(itemProps.onBlur, () => setIsFocused(false)),\n onClick: composeEventHandlers(itemProps.onClick, () => {\n if (pointerTypeRef.current !== \"mouse\") handleSelect();\n }),\n onPointerUp: composeEventHandlers(itemProps.onPointerUp, () => {\n if (pointerTypeRef.current === \"mouse\") handleSelect();\n }),\n onPointerDown: composeEventHandlers(itemProps.onPointerDown, (event) => {\n pointerTypeRef.current = event.pointerType;\n }),\n onPointerMove: composeEventHandlers(itemProps.onPointerMove, (event) => {\n pointerTypeRef.current = event.pointerType;\n if (disabled) {\n contentContext.onItemLeave?.();\n } else if (pointerTypeRef.current === \"mouse\") {\n event.currentTarget.focus({ preventScroll: true });\n }\n }),\n onPointerLeave: composeEventHandlers(itemProps.onPointerLeave, (event) => {\n if (event.currentTarget === document.activeElement) {\n contentContext.onItemLeave?.();\n }\n }),\n onKeyDown: composeEventHandlers(itemProps.onKeyDown, (event) => {\n const isTypingAhead = contentContext.searchRef?.current !== \"\";\n if (isTypingAhead && event.key === \" \") return;\n if (SELECTION_KEYS.includes(event.key)) handleSelect();\n if (event.key === \" \") event.preventDefault();\n })\n }\n )\n }\n )\n }\n );\n }\n);\nSelectItem.displayName = ITEM_NAME;\nvar ITEM_TEXT_NAME = \"SelectItemText\";\nvar SelectItemText = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeSelect, className, style, ...itemTextProps } = props;\n const context = useSelectContext(ITEM_TEXT_NAME, __scopeSelect);\n const contentContext = useSelectContentContext(ITEM_TEXT_NAME, __scopeSelect);\n const itemContext = useSelectItemContext(ITEM_TEXT_NAME, __scopeSelect);\n const nativeOptionsContext = useSelectNativeOptionsContext(ITEM_TEXT_NAME, __scopeSelect);\n const [itemTextNode, setItemTextNode] = React.useState(null);\n const composedRefs = useComposedRefs(\n forwardedRef,\n (node) => setItemTextNode(node),\n itemContext.onItemTextChange,\n (node) => contentContext.itemTextRefCallback?.(node, itemContext.value, itemContext.disabled)\n );\n const textContent = itemTextNode?.textContent;\n const nativeOption = React.useMemo(\n () => /* @__PURE__ */ jsx(\"option\", { value: itemContext.value, disabled: itemContext.disabled, children: textContent }, itemContext.value),\n [itemContext.disabled, itemContext.value, textContent]\n );\n const { onNativeOptionAdd, onNativeOptionRemove } = nativeOptionsContext;\n useLayoutEffect(() => {\n onNativeOptionAdd(nativeOption);\n return () => onNativeOptionRemove(nativeOption);\n }, [onNativeOptionAdd, onNativeOptionRemove, nativeOption]);\n return /* @__PURE__ */ jsxs(Fragment, { children: [\n /* @__PURE__ */ jsx(Primitive.span, { id: itemContext.textId, ...itemTextProps, ref: composedRefs }),\n itemContext.isSelected && context.valueNode && !context.valueNodeHasChildren ? ReactDOM.createPortal(itemTextProps.children, context.valueNode) : null\n ] });\n }\n);\nSelectItemText.displayName = ITEM_TEXT_NAME;\nvar ITEM_INDICATOR_NAME = \"SelectItemIndicator\";\nvar SelectItemIndicator = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeSelect, ...itemIndicatorProps } = props;\n const itemContext = useSelectItemContext(ITEM_INDICATOR_NAME, __scopeSelect);\n return itemContext.isSelected ? /* @__PURE__ */ jsx(Primitive.span, { \"aria-hidden\": true, ...itemIndicatorProps, ref: forwardedRef }) : null;\n }\n);\nSelectItemIndicator.displayName = ITEM_INDICATOR_NAME;\nvar SCROLL_UP_BUTTON_NAME = \"SelectScrollUpButton\";\nvar SelectScrollUpButton = React.forwardRef((props, forwardedRef) => {\n const contentContext = useSelectContentContext(SCROLL_UP_BUTTON_NAME, props.__scopeSelect);\n const viewportContext = useSelectViewportContext(SCROLL_UP_BUTTON_NAME, props.__scopeSelect);\n const [canScrollUp, setCanScrollUp] = React.useState(false);\n const composedRefs = useComposedRefs(forwardedRef, viewportContext.onScrollButtonChange);\n useLayoutEffect(() => {\n if (contentContext.viewport && contentContext.isPositioned) {\n let handleScroll2 = function() {\n const canScrollUp2 = viewport.scrollTop > 0;\n setCanScrollUp(canScrollUp2);\n };\n var handleScroll = handleScroll2;\n const viewport = contentContext.viewport;\n handleScroll2();\n viewport.addEventListener(\"scroll\", handleScroll2);\n return () => viewport.removeEventListener(\"scroll\", handleScroll2);\n }\n }, [contentContext.viewport, contentContext.isPositioned]);\n return canScrollUp ? /* @__PURE__ */ jsx(\n SelectScrollButtonImpl,\n {\n ...props,\n ref: composedRefs,\n onAutoScroll: () => {\n const { viewport, selectedItem } = contentContext;\n if (viewport && selectedItem) {\n viewport.scrollTop = viewport.scrollTop - selectedItem.offsetHeight;\n }\n }\n }\n ) : null;\n});\nSelectScrollUpButton.displayName = SCROLL_UP_BUTTON_NAME;\nvar SCROLL_DOWN_BUTTON_NAME = \"SelectScrollDownButton\";\nvar SelectScrollDownButton = React.forwardRef((props, forwardedRef) => {\n const contentContext = useSelectContentContext(SCROLL_DOWN_BUTTON_NAME, props.__scopeSelect);\n const viewportContext = useSelectViewportContext(SCROLL_DOWN_BUTTON_NAME, props.__scopeSelect);\n const [canScrollDown, setCanScrollDown] = React.useState(false);\n const composedRefs = useComposedRefs(forwardedRef, viewportContext.onScrollButtonChange);\n useLayoutEffect(() => {\n if (contentContext.viewport && contentContext.isPositioned) {\n let handleScroll2 = function() {\n const maxScroll = viewport.scrollHeight - viewport.clientHeight;\n const canScrollDown2 = Math.ceil(viewport.scrollTop) < maxScroll;\n setCanScrollDown(canScrollDown2);\n };\n var handleScroll = handleScroll2;\n const viewport = contentContext.viewport;\n handleScroll2();\n viewport.addEventListener(\"scroll\", handleScroll2);\n return () => viewport.removeEventListener(\"scroll\", handleScroll2);\n }\n }, [contentContext.viewport, contentContext.isPositioned]);\n return canScrollDown ? /* @__PURE__ */ jsx(\n SelectScrollButtonImpl,\n {\n ...props,\n ref: composedRefs,\n onAutoScroll: () => {\n const { viewport, selectedItem } = contentContext;\n if (viewport && selectedItem) {\n viewport.scrollTop = viewport.scrollTop + selectedItem.offsetHeight;\n }\n }\n }\n ) : null;\n});\nSelectScrollDownButton.displayName = SCROLL_DOWN_BUTTON_NAME;\nvar SelectScrollButtonImpl = React.forwardRef((props, forwardedRef) => {\n const { __scopeSelect, onAutoScroll, ...scrollIndicatorProps } = props;\n const contentContext = useSelectContentContext(\"SelectScrollButton\", __scopeSelect);\n const autoScrollTimerRef = React.useRef(null);\n const getItems = useCollection(__scopeSelect);\n const clearAutoScrollTimer = React.useCallback(() => {\n if (autoScrollTimerRef.current !== null) {\n window.clearInterval(autoScrollTimerRef.current);\n autoScrollTimerRef.current = null;\n }\n }, []);\n React.useEffect(() => {\n return () => clearAutoScrollTimer();\n }, [clearAutoScrollTimer]);\n useLayoutEffect(() => {\n const activeItem = getItems().find((item) => item.ref.current === document.activeElement);\n activeItem?.ref.current?.scrollIntoView({ block: \"nearest\" });\n }, [getItems]);\n return /* @__PURE__ */ jsx(\n Primitive.div,\n {\n \"aria-hidden\": true,\n ...scrollIndicatorProps,\n ref: forwardedRef,\n style: { flexShrink: 0, ...scrollIndicatorProps.style },\n onPointerDown: composeEventHandlers(scrollIndicatorProps.onPointerDown, () => {\n if (autoScrollTimerRef.current === null) {\n autoScrollTimerRef.current = window.setInterval(onAutoScroll, 50);\n }\n }),\n onPointerMove: composeEventHandlers(scrollIndicatorProps.onPointerMove, () => {\n contentContext.onItemLeave?.();\n if (autoScrollTimerRef.current === null) {\n autoScrollTimerRef.current = window.setInterval(onAutoScroll, 50);\n }\n }),\n onPointerLeave: composeEventHandlers(scrollIndicatorProps.onPointerLeave, () => {\n clearAutoScrollTimer();\n })\n }\n );\n});\nvar SEPARATOR_NAME = \"SelectSeparator\";\nvar SelectSeparator = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeSelect, ...separatorProps } = props;\n return /* @__PURE__ */ jsx(Primitive.div, { \"aria-hidden\": true, ...separatorProps, ref: forwardedRef });\n }\n);\nSelectSeparator.displayName = SEPARATOR_NAME;\nvar ARROW_NAME = \"SelectArrow\";\nvar SelectArrow = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeSelect, ...arrowProps } = props;\n const popperScope = usePopperScope(__scopeSelect);\n const context = useSelectContext(ARROW_NAME, __scopeSelect);\n const contentContext = useSelectContentContext(ARROW_NAME, __scopeSelect);\n return context.open && contentContext.position === \"popper\" ? /* @__PURE__ */ jsx(PopperPrimitive.Arrow, { ...popperScope, ...arrowProps, ref: forwardedRef }) : null;\n }\n);\nSelectArrow.displayName = ARROW_NAME;\nvar BUBBLE_INPUT_NAME = \"SelectBubbleInput\";\nvar SelectBubbleInput = React.forwardRef(\n ({ __scopeSelect, value, ...props }, forwardedRef) => {\n const ref = React.useRef(null);\n const composedRefs = useComposedRefs(forwardedRef, ref);\n const prevValue = usePrevious(value);\n React.useEffect(() => {\n const select = ref.current;\n if (!select) return;\n const selectProto = window.HTMLSelectElement.prototype;\n const descriptor = Object.getOwnPropertyDescriptor(\n selectProto,\n \"value\"\n );\n const setValue = descriptor.set;\n if (prevValue !== value && setValue) {\n const event = new Event(\"change\", { bubbles: true });\n setValue.call(select, value);\n select.dispatchEvent(event);\n }\n }, [prevValue, value]);\n return /* @__PURE__ */ jsx(\n Primitive.select,\n {\n ...props,\n style: { ...VISUALLY_HIDDEN_STYLES, ...props.style },\n ref: composedRefs,\n defaultValue: value\n }\n );\n }\n);\nSelectBubbleInput.displayName = BUBBLE_INPUT_NAME;\nfunction shouldShowPlaceholder(value) {\n return value === \"\" || value === void 0;\n}\nfunction useTypeaheadSearch(onSearchChange) {\n const handleSearchChange = useCallbackRef(onSearchChange);\n const searchRef = React.useRef(\"\");\n const timerRef = React.useRef(0);\n const handleTypeaheadSearch = React.useCallback(\n (key) => {\n const search = searchRef.current + key;\n handleSearchChange(search);\n (function updateSearch(value) {\n searchRef.current = value;\n window.clearTimeout(timerRef.current);\n if (value !== \"\") timerRef.current = window.setTimeout(() => updateSearch(\"\"), 1e3);\n })(search);\n },\n [handleSearchChange]\n );\n const resetTypeahead = React.useCallback(() => {\n searchRef.current = \"\";\n window.clearTimeout(timerRef.current);\n }, []);\n React.useEffect(() => {\n return () => window.clearTimeout(timerRef.current);\n }, []);\n return [searchRef, handleTypeaheadSearch, resetTypeahead];\n}\nfunction findNextItem(items, search, currentItem) {\n const isRepeated = search.length > 1 && Array.from(search).every((char) => char === search[0]);\n const normalizedSearch = isRepeated ? search[0] : search;\n const currentItemIndex = currentItem ? items.indexOf(currentItem) : -1;\n let wrappedItems = wrapArray(items, Math.max(currentItemIndex, 0));\n const excludeCurrentItem = normalizedSearch.length === 1;\n if (excludeCurrentItem) wrappedItems = wrappedItems.filter((v) => v !== currentItem);\n const nextItem = wrappedItems.find(\n (item) => item.textValue.toLowerCase().startsWith(normalizedSearch.toLowerCase())\n );\n return nextItem !== currentItem ? nextItem : void 0;\n}\nfunction wrapArray(array, startIndex) {\n return array.map((_, index) => array[(startIndex + index) % array.length]);\n}\nvar Root2 = Select;\nvar Trigger = SelectTrigger;\nvar Value = SelectValue;\nvar Icon = SelectIcon;\nvar Portal = SelectPortal;\nvar Content2 = SelectContent;\nvar Viewport = SelectViewport;\nvar Group = SelectGroup;\nvar Label = SelectLabel;\nvar Item = SelectItem;\nvar ItemText = SelectItemText;\nvar ItemIndicator = SelectItemIndicator;\nvar ScrollUpButton = SelectScrollUpButton;\nvar ScrollDownButton = SelectScrollDownButton;\nvar Separator = SelectSeparator;\nvar Arrow2 = SelectArrow;\nexport {\n Arrow2 as Arrow,\n Content2 as Content,\n Group,\n Icon,\n Item,\n ItemIndicator,\n ItemText,\n Label,\n Portal,\n Root2 as Root,\n ScrollDownButton,\n ScrollUpButton,\n Select,\n SelectArrow,\n SelectContent,\n SelectGroup,\n SelectIcon,\n SelectItem,\n SelectItemIndicator,\n SelectItemText,\n SelectLabel,\n SelectPortal,\n SelectScrollDownButton,\n SelectScrollUpButton,\n SelectSeparator,\n SelectTrigger,\n SelectValue,\n SelectViewport,\n Separator,\n Trigger,\n Value,\n Viewport,\n createSelectScope\n};\n//# sourceMappingURL=index.mjs.map\n","import * as SelectPrimitive from '@radix-ui/react-select'\nimport { cn } from '../../lib/cn'\n\n/* ----------------------------------------------------------\n SelectItem\n ---------------------------------------------------------- */\n\nexport interface SelectItemProps\n extends React.ComponentPropsWithoutRef<typeof SelectPrimitive.Item> {}\n\n/**\n * A single option inside a Select.\n * Renders the checkmark indicator when selected.\n */\nexport function SelectItem({ className, children, ...props }: SelectItemProps) {\n return (\n <SelectPrimitive.Item\n className={cn(\n // Layout\n 'flex items-center justify-between gap-3',\n // Typography\n 'font-body text-sm text-void',\n // Spacing\n 'px-4 py-2',\n // Interaction\n 'cursor-default select-none outline-none',\n // Highlighted (keyboard / hover)\n 'data-[highlighted]:bg-[color-mix(in_srgb,var(--color-rule)_50%,var(--color-paper))]',\n // Selected\n 'data-[state=checked]:text-signal-alt data-[state=checked]:font-medium',\n // Disabled\n 'data-[disabled]:opacity-[0.38] data-[disabled]:pointer-events-none',\n className,\n )}\n {...props}\n >\n <SelectPrimitive.ItemText>{children}</SelectPrimitive.ItemText>\n <SelectPrimitive.ItemIndicator>\n <CheckIcon />\n </SelectPrimitive.ItemIndicator>\n </SelectPrimitive.Item>\n )\n}\n\n\n/* ----------------------------------------------------------\n Select (root + trigger + content)\n ---------------------------------------------------------- */\n\nexport interface SelectProps\n extends React.ComponentPropsWithoutRef<typeof SelectPrimitive.Root> {\n /** The id applied to the trigger button — links to a Label via htmlFor. */\n id?: string\n /** Placeholder text shown when no value is selected. */\n placeholder?: string\n /** Error message shown below the trigger. Puts the trigger in error state. */\n error?: string\n /** Additional className applied to the outer wrapper div. */\n className?: string\n /** Inline styles applied to the outer wrapper div. */\n style?: React.CSSProperties\n}\n\nconst triggerBase = [\n // Layout — matches Input sizing exactly\n 'w-full flex items-center justify-between gap-2',\n // Typography\n 'font-body text-base text-void',\n // Geometry\n 'px-4 py-2 rounded-sm border border-solid',\n // Color\n 'bg-paper border-rule',\n // Placeholder color\n '[&[data-placeholder]]:text-smoke',\n // Focus\n 'outline-none',\n 'focus-visible:border-signal-alt',\n 'focus-visible:ring-[2px] focus-visible:ring-signal-alt focus-visible:ring-offset-0',\n // Transition\n 'transition-colors duration-fast ease-[var(--ease-standard)]',\n // Disabled\n 'disabled:opacity-[0.38] disabled:cursor-not-allowed',\n 'disabled:bg-[color-mix(in_srgb,var(--color-rule)_30%,var(--color-paper))]',\n].join(' ')\n\nconst triggerError = [\n 'border-signal',\n 'focus-visible:border-signal',\n 'focus-visible:ring-[color-mix(in_srgb,var(--color-signal)_40%,transparent)]',\n].join(' ')\n\n/**\n * Dropdown selector. Wraps Radix Select with Boilerhaus styling.\n * Matches Input visually — use with Label for accessible form fields.\n *\n * @example\n * <Label htmlFor=\"status\" required>Status</Label>\n * <Select id=\"status\" placeholder=\"Select status\" onValueChange={setValue}>\n * <SelectItem value=\"active\">In Progress</SelectItem>\n * <SelectItem value=\"complete\">Complete</SelectItem>\n * </Select>\n */\nexport function Select({\n id,\n placeholder,\n error,\n className,\n style,\n children,\n ...props\n}: SelectProps) {\n const errorId = id ? `${id}-error` : undefined\n\n return (\n <div className={cn('flex flex-col gap-1', className)} style={style}>\n <SelectPrimitive.Root {...props}>\n <SelectPrimitive.Trigger\n id={id}\n className={cn(triggerBase, error && triggerError)}\n aria-invalid={error ? 'true' : undefined}\n aria-describedby={error ? errorId : undefined}\n >\n <SelectPrimitive.Value placeholder={placeholder} />\n <SelectPrimitive.Icon asChild>\n <ChevronDownIcon />\n </SelectPrimitive.Icon>\n </SelectPrimitive.Trigger>\n\n <SelectPrimitive.Portal>\n <SelectPrimitive.Content\n position=\"popper\"\n sideOffset={4}\n className={cn(\n // Geometry\n 'rounded-sm border border-rule',\n // Color + elevation\n 'bg-paper shadow-[var(--shadow-md)]',\n // Sizing — matches trigger width\n 'w-[var(--radix-select-trigger-width)]',\n // Max height\n 'max-h-[var(--radix-select-content-available-height)]',\n // Z-index\n 'z-50 overflow-hidden',\n )}\n >\n <SelectPrimitive.Viewport className=\"py-1\">\n {children}\n </SelectPrimitive.Viewport>\n </SelectPrimitive.Content>\n </SelectPrimitive.Portal>\n </SelectPrimitive.Root>\n\n {error && (\n <p\n id={errorId}\n role=\"alert\"\n className=\"text-xs text-signal leading-none\"\n >\n {error}\n </p>\n )}\n </div>\n )\n}\n\n\n/* ----------------------------------------------------------\n Icons — inline SVGs, no external dependency\n ---------------------------------------------------------- */\n\nfunction ChevronDownIcon() {\n return (\n <svg\n width=\"14\"\n height=\"14\"\n viewBox=\"0 0 14 14\"\n fill=\"none\"\n aria-hidden=\"true\"\n className=\"shrink-0 text-smoke\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n >\n <path d=\"M3 5l4 4 4-4\" />\n </svg>\n )\n}\n\nfunction CheckIcon() {\n return (\n <svg\n width=\"14\"\n height=\"14\"\n viewBox=\"0 0 14 14\"\n fill=\"none\"\n aria-hidden=\"true\"\n className=\"text-signal-alt\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n >\n <path d=\"M2.5 7l3.5 3.5 5.5-6\" />\n </svg>\n )\n}\n","\"use client\";\n\n// src/presence.tsx\nimport * as React2 from \"react\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { useLayoutEffect } from \"@radix-ui/react-use-layout-effect\";\n\n// src/use-state-machine.tsx\nimport * as React from \"react\";\nfunction useStateMachine(initialState, machine) {\n return React.useReducer((state, event) => {\n const nextState = machine[state][event];\n return nextState ?? state;\n }, initialState);\n}\n\n// src/presence.tsx\nvar Presence = (props) => {\n const { present, children } = props;\n const presence = usePresence(present);\n const child = typeof children === \"function\" ? children({ present: presence.isPresent }) : React2.Children.only(children);\n const ref = useComposedRefs(presence.ref, getElementRef(child));\n const forceMount = typeof children === \"function\";\n return forceMount || presence.isPresent ? React2.cloneElement(child, { ref }) : null;\n};\nPresence.displayName = \"Presence\";\nfunction usePresence(present) {\n const [node, setNode] = React2.useState();\n const stylesRef = React2.useRef(null);\n const prevPresentRef = React2.useRef(present);\n const prevAnimationNameRef = React2.useRef(\"none\");\n const initialState = present ? \"mounted\" : \"unmounted\";\n const [state, send] = useStateMachine(initialState, {\n mounted: {\n UNMOUNT: \"unmounted\",\n ANIMATION_OUT: \"unmountSuspended\"\n },\n unmountSuspended: {\n MOUNT: \"mounted\",\n ANIMATION_END: \"unmounted\"\n },\n unmounted: {\n MOUNT: \"mounted\"\n }\n });\n React2.useEffect(() => {\n const currentAnimationName = getAnimationName(stylesRef.current);\n prevAnimationNameRef.current = state === \"mounted\" ? currentAnimationName : \"none\";\n }, [state]);\n useLayoutEffect(() => {\n const styles = stylesRef.current;\n const wasPresent = prevPresentRef.current;\n const hasPresentChanged = wasPresent !== present;\n if (hasPresentChanged) {\n const prevAnimationName = prevAnimationNameRef.current;\n const currentAnimationName = getAnimationName(styles);\n if (present) {\n send(\"MOUNT\");\n } else if (currentAnimationName === \"none\" || styles?.display === \"none\") {\n send(\"UNMOUNT\");\n } else {\n const isAnimating = prevAnimationName !== currentAnimationName;\n if (wasPresent && isAnimating) {\n send(\"ANIMATION_OUT\");\n } else {\n send(\"UNMOUNT\");\n }\n }\n prevPresentRef.current = present;\n }\n }, [present, send]);\n useLayoutEffect(() => {\n if (node) {\n let timeoutId;\n const ownerWindow = node.ownerDocument.defaultView ?? window;\n const handleAnimationEnd = (event) => {\n const currentAnimationName = getAnimationName(stylesRef.current);\n const isCurrentAnimation = currentAnimationName.includes(CSS.escape(event.animationName));\n if (event.target === node && isCurrentAnimation) {\n send(\"ANIMATION_END\");\n if (!prevPresentRef.current) {\n const currentFillMode = node.style.animationFillMode;\n node.style.animationFillMode = \"forwards\";\n timeoutId = ownerWindow.setTimeout(() => {\n if (node.style.animationFillMode === \"forwards\") {\n node.style.animationFillMode = currentFillMode;\n }\n });\n }\n }\n };\n const handleAnimationStart = (event) => {\n if (event.target === node) {\n prevAnimationNameRef.current = getAnimationName(stylesRef.current);\n }\n };\n node.addEventListener(\"animationstart\", handleAnimationStart);\n node.addEventListener(\"animationcancel\", handleAnimationEnd);\n node.addEventListener(\"animationend\", handleAnimationEnd);\n return () => {\n ownerWindow.clearTimeout(timeoutId);\n node.removeEventListener(\"animationstart\", handleAnimationStart);\n node.removeEventListener(\"animationcancel\", handleAnimationEnd);\n node.removeEventListener(\"animationend\", handleAnimationEnd);\n };\n } else {\n send(\"ANIMATION_END\");\n }\n }, [node, send]);\n return {\n isPresent: [\"mounted\", \"unmountSuspended\"].includes(state),\n ref: React2.useCallback((node2) => {\n stylesRef.current = node2 ? getComputedStyle(node2) : null;\n setNode(node2);\n }, [])\n };\n}\nfunction getAnimationName(styles) {\n return styles?.animationName || \"none\";\n}\nfunction getElementRef(element) {\n let getter = Object.getOwnPropertyDescriptor(element.props, \"ref\")?.get;\n let mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.ref;\n }\n getter = Object.getOwnPropertyDescriptor(element, \"ref\")?.get;\n mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.props.ref;\n }\n return element.props.ref || element.ref;\n}\nvar Root = Presence;\nexport {\n Presence,\n Root\n};\n//# sourceMappingURL=index.mjs.map\n","// src/slot.tsx\nimport * as React from \"react\";\nimport { composeRefs } from \"@radix-ui/react-compose-refs\";\nimport { Fragment as Fragment2, jsx } from \"react/jsx-runtime\";\n// @__NO_SIDE_EFFECTS__\nfunction createSlot(ownerName) {\n const SlotClone = /* @__PURE__ */ createSlotClone(ownerName);\n const Slot2 = React.forwardRef((props, forwardedRef) => {\n const { children, ...slotProps } = props;\n const childrenArray = React.Children.toArray(children);\n const slottable = childrenArray.find(isSlottable);\n if (slottable) {\n const newElement = slottable.props.children;\n const newChildren = childrenArray.map((child) => {\n if (child === slottable) {\n if (React.Children.count(newElement) > 1) return React.Children.only(null);\n return React.isValidElement(newElement) ? newElement.props.children : null;\n } else {\n return child;\n }\n });\n return /* @__PURE__ */ jsx(SlotClone, { ...slotProps, ref: forwardedRef, children: React.isValidElement(newElement) ? React.cloneElement(newElement, void 0, newChildren) : null });\n }\n return /* @__PURE__ */ jsx(SlotClone, { ...slotProps, ref: forwardedRef, children });\n });\n Slot2.displayName = `${ownerName}.Slot`;\n return Slot2;\n}\nvar Slot = /* @__PURE__ */ createSlot(\"Slot\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlotClone(ownerName) {\n const SlotClone = React.forwardRef((props, forwardedRef) => {\n const { children, ...slotProps } = props;\n if (React.isValidElement(children)) {\n const childrenRef = getElementRef(children);\n const props2 = mergeProps(slotProps, children.props);\n if (children.type !== React.Fragment) {\n props2.ref = forwardedRef ? composeRefs(forwardedRef, childrenRef) : childrenRef;\n }\n return React.cloneElement(children, props2);\n }\n return React.Children.count(children) > 1 ? React.Children.only(null) : null;\n });\n SlotClone.displayName = `${ownerName}.SlotClone`;\n return SlotClone;\n}\nvar SLOTTABLE_IDENTIFIER = Symbol(\"radix.slottable\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlottable(ownerName) {\n const Slottable2 = ({ children }) => {\n return /* @__PURE__ */ jsx(Fragment2, { children });\n };\n Slottable2.displayName = `${ownerName}.Slottable`;\n Slottable2.__radixId = SLOTTABLE_IDENTIFIER;\n return Slottable2;\n}\nvar Slottable = /* @__PURE__ */ createSlottable(\"Slottable\");\nfunction isSlottable(child) {\n return React.isValidElement(child) && typeof child.type === \"function\" && \"__radixId\" in child.type && child.type.__radixId === SLOTTABLE_IDENTIFIER;\n}\nfunction mergeProps(slotProps, childProps) {\n const overrideProps = { ...childProps };\n for (const propName in childProps) {\n const slotPropValue = slotProps[propName];\n const childPropValue = childProps[propName];\n const isHandler = /^on[A-Z]/.test(propName);\n if (isHandler) {\n if (slotPropValue && childPropValue) {\n overrideProps[propName] = (...args) => {\n const result = childPropValue(...args);\n slotPropValue(...args);\n return result;\n };\n } else if (slotPropValue) {\n overrideProps[propName] = slotPropValue;\n }\n } else if (propName === \"style\") {\n overrideProps[propName] = { ...slotPropValue, ...childPropValue };\n } else if (propName === \"className\") {\n overrideProps[propName] = [slotPropValue, childPropValue].filter(Boolean).join(\" \");\n }\n }\n return { ...slotProps, ...overrideProps };\n}\nfunction getElementRef(element) {\n let getter = Object.getOwnPropertyDescriptor(element.props, \"ref\")?.get;\n let mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.ref;\n }\n getter = Object.getOwnPropertyDescriptor(element, \"ref\")?.get;\n mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.props.ref;\n }\n return element.props.ref || element.ref;\n}\nexport {\n Slot as Root,\n Slot,\n Slottable,\n createSlot,\n createSlottable\n};\n//# sourceMappingURL=index.mjs.map\n","\"use client\";\n\n// src/dialog.tsx\nimport * as React from \"react\";\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { createContext, createContextScope } from \"@radix-ui/react-context\";\nimport { useId } from \"@radix-ui/react-id\";\nimport { useControllableState } from \"@radix-ui/react-use-controllable-state\";\nimport { DismissableLayer } from \"@radix-ui/react-dismissable-layer\";\nimport { FocusScope } from \"@radix-ui/react-focus-scope\";\nimport { Portal as PortalPrimitive } from \"@radix-ui/react-portal\";\nimport { Presence } from \"@radix-ui/react-presence\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { useFocusGuards } from \"@radix-ui/react-focus-guards\";\nimport { RemoveScroll } from \"react-remove-scroll\";\nimport { hideOthers } from \"aria-hidden\";\nimport { createSlot } from \"@radix-ui/react-slot\";\nimport { Fragment, jsx, jsxs } from \"react/jsx-runtime\";\nvar DIALOG_NAME = \"Dialog\";\nvar [createDialogContext, createDialogScope] = createContextScope(DIALOG_NAME);\nvar [DialogProvider, useDialogContext] = createDialogContext(DIALOG_NAME);\nvar Dialog = (props) => {\n const {\n __scopeDialog,\n children,\n open: openProp,\n defaultOpen,\n onOpenChange,\n modal = true\n } = props;\n const triggerRef = React.useRef(null);\n const contentRef = React.useRef(null);\n const [open, setOpen] = useControllableState({\n prop: openProp,\n defaultProp: defaultOpen ?? false,\n onChange: onOpenChange,\n caller: DIALOG_NAME\n });\n return /* @__PURE__ */ jsx(\n DialogProvider,\n {\n scope: __scopeDialog,\n triggerRef,\n contentRef,\n contentId: useId(),\n titleId: useId(),\n descriptionId: useId(),\n open,\n onOpenChange: setOpen,\n onOpenToggle: React.useCallback(() => setOpen((prevOpen) => !prevOpen), [setOpen]),\n modal,\n children\n }\n );\n};\nDialog.displayName = DIALOG_NAME;\nvar TRIGGER_NAME = \"DialogTrigger\";\nvar DialogTrigger = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeDialog, ...triggerProps } = props;\n const context = useDialogContext(TRIGGER_NAME, __scopeDialog);\n const composedTriggerRef = useComposedRefs(forwardedRef, context.triggerRef);\n return /* @__PURE__ */ jsx(\n Primitive.button,\n {\n type: \"button\",\n \"aria-haspopup\": \"dialog\",\n \"aria-expanded\": context.open,\n \"aria-controls\": context.contentId,\n \"data-state\": getState(context.open),\n ...triggerProps,\n ref: composedTriggerRef,\n onClick: composeEventHandlers(props.onClick, context.onOpenToggle)\n }\n );\n }\n);\nDialogTrigger.displayName = TRIGGER_NAME;\nvar PORTAL_NAME = \"DialogPortal\";\nvar [PortalProvider, usePortalContext] = createDialogContext(PORTAL_NAME, {\n forceMount: void 0\n});\nvar DialogPortal = (props) => {\n const { __scopeDialog, forceMount, children, container } = props;\n const context = useDialogContext(PORTAL_NAME, __scopeDialog);\n return /* @__PURE__ */ jsx(PortalProvider, { scope: __scopeDialog, forceMount, children: React.Children.map(children, (child) => /* @__PURE__ */ jsx(Presence, { present: forceMount || context.open, children: /* @__PURE__ */ jsx(PortalPrimitive, { asChild: true, container, children: child }) })) });\n};\nDialogPortal.displayName = PORTAL_NAME;\nvar OVERLAY_NAME = \"DialogOverlay\";\nvar DialogOverlay = React.forwardRef(\n (props, forwardedRef) => {\n const portalContext = usePortalContext(OVERLAY_NAME, props.__scopeDialog);\n const { forceMount = portalContext.forceMount, ...overlayProps } = props;\n const context = useDialogContext(OVERLAY_NAME, props.__scopeDialog);\n return context.modal ? /* @__PURE__ */ jsx(Presence, { present: forceMount || context.open, children: /* @__PURE__ */ jsx(DialogOverlayImpl, { ...overlayProps, ref: forwardedRef }) }) : null;\n }\n);\nDialogOverlay.displayName = OVERLAY_NAME;\nvar Slot = createSlot(\"DialogOverlay.RemoveScroll\");\nvar DialogOverlayImpl = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeDialog, ...overlayProps } = props;\n const context = useDialogContext(OVERLAY_NAME, __scopeDialog);\n return (\n // Make sure `Content` is scrollable even when it doesn't live inside `RemoveScroll`\n // ie. when `Overlay` and `Content` are siblings\n /* @__PURE__ */ jsx(RemoveScroll, { as: Slot, allowPinchZoom: true, shards: [context.contentRef], children: /* @__PURE__ */ jsx(\n Primitive.div,\n {\n \"data-state\": getState(context.open),\n ...overlayProps,\n ref: forwardedRef,\n style: { pointerEvents: \"auto\", ...overlayProps.style }\n }\n ) })\n );\n }\n);\nvar CONTENT_NAME = \"DialogContent\";\nvar DialogContent = React.forwardRef(\n (props, forwardedRef) => {\n const portalContext = usePortalContext(CONTENT_NAME, props.__scopeDialog);\n const { forceMount = portalContext.forceMount, ...contentProps } = props;\n const context = useDialogContext(CONTENT_NAME, props.__scopeDialog);\n return /* @__PURE__ */ jsx(Presence, { present: forceMount || context.open, children: context.modal ? /* @__PURE__ */ jsx(DialogContentModal, { ...contentProps, ref: forwardedRef }) : /* @__PURE__ */ jsx(DialogContentNonModal, { ...contentProps, ref: forwardedRef }) });\n }\n);\nDialogContent.displayName = CONTENT_NAME;\nvar DialogContentModal = React.forwardRef(\n (props, forwardedRef) => {\n const context = useDialogContext(CONTENT_NAME, props.__scopeDialog);\n const contentRef = React.useRef(null);\n const composedRefs = useComposedRefs(forwardedRef, context.contentRef, contentRef);\n React.useEffect(() => {\n const content = contentRef.current;\n if (content) return hideOthers(content);\n }, []);\n return /* @__PURE__ */ jsx(\n DialogContentImpl,\n {\n ...props,\n ref: composedRefs,\n trapFocus: context.open,\n disableOutsidePointerEvents: true,\n onCloseAutoFocus: composeEventHandlers(props.onCloseAutoFocus, (event) => {\n event.preventDefault();\n context.triggerRef.current?.focus();\n }),\n onPointerDownOutside: composeEventHandlers(props.onPointerDownOutside, (event) => {\n const originalEvent = event.detail.originalEvent;\n const ctrlLeftClick = originalEvent.button === 0 && originalEvent.ctrlKey === true;\n const isRightClick = originalEvent.button === 2 || ctrlLeftClick;\n if (isRightClick) event.preventDefault();\n }),\n onFocusOutside: composeEventHandlers(\n props.onFocusOutside,\n (event) => event.preventDefault()\n )\n }\n );\n }\n);\nvar DialogContentNonModal = React.forwardRef(\n (props, forwardedRef) => {\n const context = useDialogContext(CONTENT_NAME, props.__scopeDialog);\n const hasInteractedOutsideRef = React.useRef(false);\n const hasPointerDownOutsideRef = React.useRef(false);\n return /* @__PURE__ */ jsx(\n DialogContentImpl,\n {\n ...props,\n ref: forwardedRef,\n trapFocus: false,\n disableOutsidePointerEvents: false,\n onCloseAutoFocus: (event) => {\n props.onCloseAutoFocus?.(event);\n if (!event.defaultPrevented) {\n if (!hasInteractedOutsideRef.current) context.triggerRef.current?.focus();\n event.preventDefault();\n }\n hasInteractedOutsideRef.current = false;\n hasPointerDownOutsideRef.current = false;\n },\n onInteractOutside: (event) => {\n props.onInteractOutside?.(event);\n if (!event.defaultPrevented) {\n hasInteractedOutsideRef.current = true;\n if (event.detail.originalEvent.type === \"pointerdown\") {\n hasPointerDownOutsideRef.current = true;\n }\n }\n const target = event.target;\n const targetIsTrigger = context.triggerRef.current?.contains(target);\n if (targetIsTrigger) event.preventDefault();\n if (event.detail.originalEvent.type === \"focusin\" && hasPointerDownOutsideRef.current) {\n event.preventDefault();\n }\n }\n }\n );\n }\n);\nvar DialogContentImpl = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeDialog, trapFocus, onOpenAutoFocus, onCloseAutoFocus, ...contentProps } = props;\n const context = useDialogContext(CONTENT_NAME, __scopeDialog);\n const contentRef = React.useRef(null);\n const composedRefs = useComposedRefs(forwardedRef, contentRef);\n useFocusGuards();\n return /* @__PURE__ */ jsxs(Fragment, { children: [\n /* @__PURE__ */ jsx(\n FocusScope,\n {\n asChild: true,\n loop: true,\n trapped: trapFocus,\n onMountAutoFocus: onOpenAutoFocus,\n onUnmountAutoFocus: onCloseAutoFocus,\n children: /* @__PURE__ */ jsx(\n DismissableLayer,\n {\n role: \"dialog\",\n id: context.contentId,\n \"aria-describedby\": context.descriptionId,\n \"aria-labelledby\": context.titleId,\n \"data-state\": getState(context.open),\n ...contentProps,\n ref: composedRefs,\n onDismiss: () => context.onOpenChange(false)\n }\n )\n }\n ),\n /* @__PURE__ */ jsxs(Fragment, { children: [\n /* @__PURE__ */ jsx(TitleWarning, { titleId: context.titleId }),\n /* @__PURE__ */ jsx(DescriptionWarning, { contentRef, descriptionId: context.descriptionId })\n ] })\n ] });\n }\n);\nvar TITLE_NAME = \"DialogTitle\";\nvar DialogTitle = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeDialog, ...titleProps } = props;\n const context = useDialogContext(TITLE_NAME, __scopeDialog);\n return /* @__PURE__ */ jsx(Primitive.h2, { id: context.titleId, ...titleProps, ref: forwardedRef });\n }\n);\nDialogTitle.displayName = TITLE_NAME;\nvar DESCRIPTION_NAME = \"DialogDescription\";\nvar DialogDescription = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeDialog, ...descriptionProps } = props;\n const context = useDialogContext(DESCRIPTION_NAME, __scopeDialog);\n return /* @__PURE__ */ jsx(Primitive.p, { id: context.descriptionId, ...descriptionProps, ref: forwardedRef });\n }\n);\nDialogDescription.displayName = DESCRIPTION_NAME;\nvar CLOSE_NAME = \"DialogClose\";\nvar DialogClose = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeDialog, ...closeProps } = props;\n const context = useDialogContext(CLOSE_NAME, __scopeDialog);\n return /* @__PURE__ */ jsx(\n Primitive.button,\n {\n type: \"button\",\n ...closeProps,\n ref: forwardedRef,\n onClick: composeEventHandlers(props.onClick, () => context.onOpenChange(false))\n }\n );\n }\n);\nDialogClose.displayName = CLOSE_NAME;\nfunction getState(open) {\n return open ? \"open\" : \"closed\";\n}\nvar TITLE_WARNING_NAME = \"DialogTitleWarning\";\nvar [WarningProvider, useWarningContext] = createContext(TITLE_WARNING_NAME, {\n contentName: CONTENT_NAME,\n titleName: TITLE_NAME,\n docsSlug: \"dialog\"\n});\nvar TitleWarning = ({ titleId }) => {\n const titleWarningContext = useWarningContext(TITLE_WARNING_NAME);\n const MESSAGE = `\\`${titleWarningContext.contentName}\\` requires a \\`${titleWarningContext.titleName}\\` for the component to be accessible for screen reader users.\n\nIf you want to hide the \\`${titleWarningContext.titleName}\\`, you can wrap it with our VisuallyHidden component.\n\nFor more information, see https://radix-ui.com/primitives/docs/components/${titleWarningContext.docsSlug}`;\n React.useEffect(() => {\n if (titleId) {\n const hasTitle = document.getElementById(titleId);\n if (!hasTitle) console.error(MESSAGE);\n }\n }, [MESSAGE, titleId]);\n return null;\n};\nvar DESCRIPTION_WARNING_NAME = \"DialogDescriptionWarning\";\nvar DescriptionWarning = ({ contentRef, descriptionId }) => {\n const descriptionWarningContext = useWarningContext(DESCRIPTION_WARNING_NAME);\n const MESSAGE = `Warning: Missing \\`Description\\` or \\`aria-describedby={undefined}\\` for {${descriptionWarningContext.contentName}}.`;\n React.useEffect(() => {\n const describedById = contentRef.current?.getAttribute(\"aria-describedby\");\n if (descriptionId && describedById) {\n const hasDescription = document.getElementById(descriptionId);\n if (!hasDescription) console.warn(MESSAGE);\n }\n }, [MESSAGE, contentRef, descriptionId]);\n return null;\n};\nvar Root = Dialog;\nvar Trigger = DialogTrigger;\nvar Portal = DialogPortal;\nvar Overlay = DialogOverlay;\nvar Content = DialogContent;\nvar Title = DialogTitle;\nvar Description = DialogDescription;\nvar Close = DialogClose;\nexport {\n Close,\n Content,\n Description,\n Dialog,\n DialogClose,\n DialogContent,\n DialogDescription,\n DialogOverlay,\n DialogPortal,\n DialogTitle,\n DialogTrigger,\n Overlay,\n Portal,\n Root,\n Title,\n Trigger,\n WarningProvider,\n createDialogScope\n};\n//# sourceMappingURL=index.mjs.map\n","import * as DialogPrimitive from '@radix-ui/react-dialog'\nimport { cn } from '../../lib/cn'\n\n/* ----------------------------------------------------------\n Re-export primitives that need no styling\n ---------------------------------------------------------- */\n\n/** Controls open/close state. Wrap all Dialog parts with this. */\nexport const Dialog = DialogPrimitive.Root\n\n/** Renders the element that opens the dialog. Use asChild with a Button. */\nexport const DialogTrigger = DialogPrimitive.Trigger\n\n/**\n * Closes the dialog without additional action.\n * Use asChild with a Button:\n * @example\n * <DialogClose asChild><Button variant=\"secondary\">Cancel</Button></DialogClose>\n */\nexport const DialogClose = DialogPrimitive.Close\n\n\n/* ----------------------------------------------------------\n DialogContent\n ---------------------------------------------------------- */\n\nexport interface DialogContentProps\n extends React.ComponentPropsWithoutRef<typeof DialogPrimitive.Content> {}\n\n/**\n * The dialog panel — rendered in a portal above an overlay.\n * Always include DialogTitle for accessibility.\n *\n * @example\n * <Dialog>\n * <DialogTrigger asChild><Button>Open</Button></DialogTrigger>\n * <DialogContent>\n * <DialogTitle>Confirm Action</DialogTitle>\n * <DialogDescription>This cannot be undone.</DialogDescription>\n * <DialogFooter>\n * <DialogClose asChild><Button variant=\"secondary\">Cancel</Button></DialogClose>\n * <Button variant=\"destructive\">Delete</Button>\n * </DialogFooter>\n * </DialogContent>\n * </Dialog>\n */\nexport function DialogContent({ className, children, ...props }: DialogContentProps) {\n return (\n <DialogPrimitive.Portal>\n {/* Overlay */}\n <DialogPrimitive.Overlay\n className={cn(\n 'fixed inset-0 z-50',\n 'bg-void/50',\n 'backdrop-blur-[2px]',\n )}\n />\n\n {/* Panel */}\n <DialogPrimitive.Content\n className={cn(\n // Position — centered\n 'fixed z-50',\n 'top-1/2 left-1/2 -translate-x-1/2 -translate-y-1/2',\n // Sizing\n 'w-full max-w-lg',\n // Geometry\n 'rounded-sm border border-rule',\n // Color + elevation\n 'bg-paper shadow-[var(--shadow-xl)]',\n // Layout\n 'flex flex-col gap-4',\n 'p-6',\n // Close button anchor\n 'relative',\n // Overflow safety\n 'max-h-[85vh] overflow-y-auto',\n className,\n )}\n {...props}\n >\n {children}\n\n {/* Close × button — top-right */}\n <DialogPrimitive.Close\n className={cn(\n 'absolute top-4 right-4',\n 'flex items-center justify-center',\n 'w-7 h-7 rounded-sm',\n 'text-smoke',\n 'hover:text-void hover:bg-[color-mix(in_srgb,var(--color-rule)_50%,transparent)]',\n 'outline-none focus-visible:ring-[2px] focus-visible:ring-signal-alt',\n 'transition-colors duration-fast ease-[var(--ease-standard)]',\n )}\n aria-label=\"Close dialog\"\n >\n <CloseIcon />\n </DialogPrimitive.Close>\n </DialogPrimitive.Content>\n </DialogPrimitive.Portal>\n )\n}\n\n\n/* ----------------------------------------------------------\n DialogTitle\n ---------------------------------------------------------- */\n\nexport interface DialogTitleProps\n extends React.ComponentPropsWithoutRef<typeof DialogPrimitive.Title> {}\n\n/**\n * Required for accessibility — sets the dialog's accessible name.\n * Rendered as a heading in display font.\n */\nexport function DialogTitle({ className, ...props }: DialogTitleProps) {\n return (\n <DialogPrimitive.Title\n className={cn(\n 'font-display font-bold text-lg uppercase tracking-[0.06em] text-void',\n // Leave space for the close button on the right\n 'pr-8',\n className,\n )}\n {...props}\n />\n )\n}\n\n\n/* ----------------------------------------------------------\n DialogDescription\n ---------------------------------------------------------- */\n\nexport interface DialogDescriptionProps\n extends React.ComponentPropsWithoutRef<typeof DialogPrimitive.Description> {}\n\n/**\n * Optional supporting text below the title.\n * Sets the dialog's accessible description.\n */\nexport function DialogDescription({ className, ...props }: DialogDescriptionProps) {\n return (\n <DialogPrimitive.Description\n className={cn('text-sm text-smoke leading-relaxed', className)}\n {...props}\n />\n )\n}\n\n\n/* ----------------------------------------------------------\n DialogFooter\n ---------------------------------------------------------- */\n\nexport interface DialogFooterProps extends React.HTMLAttributes<HTMLDivElement> {}\n\n/**\n * Action button row. Renders right-aligned by default.\n * Reverses to column on small screens for touch accessibility.\n */\nexport function DialogFooter({ className, ...props }: DialogFooterProps) {\n return (\n <div\n className={cn(\n 'flex items-center justify-end gap-3',\n 'pt-2 border-t border-rule',\n className,\n )}\n {...props}\n />\n )\n}\n\n\n/* ----------------------------------------------------------\n Icon — inline SVG, no external dependency\n ---------------------------------------------------------- */\n\nfunction CloseIcon() {\n return (\n <svg\n width=\"14\"\n height=\"14\"\n viewBox=\"0 0 14 14\"\n fill=\"none\"\n aria-hidden=\"true\"\n stroke=\"currentColor\"\n strokeWidth=\"1.75\"\n strokeLinecap=\"round\"\n >\n <path d=\"M2 2l10 10M12 2L2 12\" />\n </svg>\n )\n}\n","import { Slot } from '@radix-ui/react-slot'\nimport { cn } from '../../lib/cn'\n\n/* ----------------------------------------------------------\n PageShell\n ---------------------------------------------------------- */\n\nexport interface PageShellProps extends React.HTMLAttributes<HTMLDivElement> {}\n\n/**\n * Root layout container. Takes up full viewport height via flex column.\n * Always include PageShellTopbar + PageShellBody as direct children.\n *\n * @example\n * <PageShell>\n * <PageShellTopbar>…</PageShellTopbar>\n * <PageShellBody>\n * <PageShellSidebar>…</PageShellSidebar>\n * <PageShellContent>…</PageShellContent>\n * </PageShellBody>\n * </PageShell>\n */\nexport function PageShell({ className, children, ...props }: PageShellProps) {\n return (\n <div\n className={cn('flex flex-col bg-paper', className)}\n {...props}\n >\n {children}\n </div>\n )\n}\n\n\n/* ----------------------------------------------------------\n PageShellTopbar\n ---------------------------------------------------------- */\n\nexport interface PageShellTopbarProps extends React.HTMLAttributes<HTMLElement> {}\n\n/**\n * Horizontal top bar — brand, nav, user menu.\n * Fixed height defined by --topbar-height token (48px).\n */\nexport function PageShellTopbar({ className, children, ...props }: PageShellTopbarProps) {\n return (\n <header\n className={cn(\n // Height — matches --topbar-height token\n 'h-[var(--topbar-height)] shrink-0',\n // Layout\n 'flex items-center gap-4 px-5',\n // Color\n 'bg-paper border-b border-rule',\n className,\n )}\n {...props}\n >\n {children}\n </header>\n )\n}\n\n\n/* ----------------------------------------------------------\n PageShellBody\n ---------------------------------------------------------- */\n\nexport interface PageShellBodyProps extends React.HTMLAttributes<HTMLDivElement> {}\n\n/**\n * Flex row below the topbar. Overflow is hidden here;\n * each child (sidebar, content) manages its own scroll.\n */\nexport function PageShellBody({ className, children, ...props }: PageShellBodyProps) {\n return (\n <div\n className={cn('flex-1 flex overflow-hidden', className)}\n {...props}\n >\n {children}\n </div>\n )\n}\n\n\n/* ----------------------------------------------------------\n PageShellSidebar\n ---------------------------------------------------------- */\n\nexport interface PageShellSidebarProps extends React.HTMLAttributes<HTMLElement> {}\n\n/**\n * Dark left panel — navigation, project list, context.\n * Width is controlled by --sidebar-width token (280px).\n * Uses ash background (near-black) to contrast the paper content area.\n */\nexport function PageShellSidebar({ className, children, ...props }: PageShellSidebarProps) {\n return (\n <aside\n className={cn(\n // Width — matches --sidebar-width token\n 'w-[var(--sidebar-width)] shrink-0',\n // Layout\n 'flex flex-col overflow-y-auto',\n // Color — inverted (dark)\n 'bg-ash',\n // Right border separates from content area\n 'border-r border-[color-mix(in_srgb,var(--color-paper)_8%,transparent)]',\n className,\n )}\n {...props}\n >\n {children}\n </aside>\n )\n}\n\n\n/* ----------------------------------------------------------\n PageShellContent\n ---------------------------------------------------------- */\n\nexport interface PageShellContentProps extends React.HTMLAttributes<HTMLElement> {}\n\n/**\n * Main content area — fills remaining horizontal space, scrolls independently.\n * This is where page-level content renders.\n */\nexport function PageShellContent({ className, children, ...props }: PageShellContentProps) {\n return (\n <main\n className={cn('flex-1 overflow-y-auto p-6', className)}\n {...props}\n >\n {children}\n </main>\n )\n}\n\n\n/* ----------------------------------------------------------\n PageShellNavItem\n ---------------------------------------------------------- */\n\nexport interface PageShellNavItemProps extends React.HTMLAttributes<HTMLElement> {\n /**\n * Marks this item as the current page/section.\n * Adds a signal-red left border indicator and highlights text.\n * Sets aria-current=\"page\" automatically.\n */\n active?: boolean\n /**\n * Optional 16×16 icon rendered before the label.\n */\n icon?: React.ReactNode\n /**\n * Render as a child element instead of <button>.\n * Use for routing links: <PageShellNavItem asChild><a href=\"/projects\">…</a></PageShellNavItem>\n */\n asChild?: boolean\n}\n\n/**\n * Sidebar navigation item. Designed for use on the ash (dark) sidebar.\n * Supports asChild for framework routing links.\n *\n * @example\n * // With Next.js Link\n * <PageShellNavItem asChild active={pathname === '/projects'} icon={<IconGrid />}>\n * <Link href=\"/projects\">Projects</Link>\n * </PageShellNavItem>\n */\nexport function PageShellNavItem({\n active,\n icon,\n asChild = false,\n className,\n children,\n ...props\n}: PageShellNavItemProps) {\n const Comp = asChild ? Slot : 'button'\n\n return (\n <Comp\n className={cn(\n // Layout\n 'flex items-center gap-3 w-full',\n // Spacing\n 'px-4 py-[10px]',\n // Typography — body font, small\n 'font-body text-sm leading-none',\n // Base color — muted paper on dark bg\n 'text-[color-mix(in_srgb,var(--color-paper)_60%,transparent)]',\n // No native button styles\n 'cursor-pointer select-none no-underline outline-none border-none bg-transparent',\n // Left border placeholder — keeps text aligned between states\n 'border-l-2 border-transparent',\n // Hover\n 'hover:text-paper hover:bg-[color-mix(in_srgb,var(--color-paper)_6%,transparent)]',\n // Focus\n 'focus-visible:ring-[2px] focus-visible:ring-inset focus-visible:ring-signal-alt',\n // Active\n active && [\n 'text-paper',\n 'border-l-signal',\n 'bg-[color-mix(in_srgb,var(--color-paper)_8%,transparent)]',\n ],\n // Transition\n 'transition-colors duration-fast ease-[var(--ease-standard)]',\n className,\n )}\n aria-current={active ? 'page' : undefined}\n {...props}\n >\n {icon && (\n <span\n className=\"shrink-0 w-4 h-4 flex items-center justify-center\"\n aria-hidden=\"true\"\n >\n {icon}\n </span>\n )}\n <span>{children}</span>\n </Comp>\n )\n}\n","import { cn } from '../../lib/cn'\n\n/* ----------------------------------------------------------\n Table\n ---------------------------------------------------------- */\n\nexport interface TableProps extends React.HTMLAttributes<HTMLTableElement> {}\n\n/**\n * Semantic data table. Use with TableHeader, TableBody, TableFoot,\n * TableRow, TableHead, and TableCell.\n *\n * @example\n * <Table>\n * <TableHeader>\n * <TableRow>\n * <TableHead>Description</TableHead>\n * <TableHead numeric>Amount</TableHead>\n * </TableRow>\n * </TableHeader>\n * <TableBody>\n * <TableRow>\n * <TableCell>Framing</TableCell>\n * <TableCell numeric>$8,500</TableCell>\n * </TableRow>\n * </TableBody>\n * <TableFoot>\n * <TableRow>\n * <TableCell>Total</TableCell>\n * <TableCell numeric>$8,500</TableCell>\n * </TableRow>\n * </TableFoot>\n * </Table>\n */\nexport function Table({ className, children, ...props }: TableProps) {\n return (\n <div className=\"w-full overflow-x-auto\">\n <table\n className={cn(\n 'w-full border-collapse text-sm',\n className,\n )}\n {...props}\n >\n {children}\n </table>\n </div>\n )\n}\n\n\n/* ----------------------------------------------------------\n TableHeader\n ---------------------------------------------------------- */\n\nexport interface TableHeaderProps extends React.HTMLAttributes<HTMLTableSectionElement> {}\n\n/** Wraps heading rows in a <thead>. */\nexport function TableHeader({ className, children, ...props }: TableHeaderProps) {\n return (\n <thead className={cn('border-b border-rule', className)} {...props}>\n {children}\n </thead>\n )\n}\n\n\n/* ----------------------------------------------------------\n TableBody\n ---------------------------------------------------------- */\n\nexport interface TableBodyProps extends React.HTMLAttributes<HTMLTableSectionElement> {}\n\n/** Wraps data rows in a <tbody>. */\nexport function TableBody({ className, children, ...props }: TableBodyProps) {\n return (\n <tbody className={cn(className)} {...props}>\n {children}\n </tbody>\n )\n}\n\n\n/* ----------------------------------------------------------\n TableFoot\n ---------------------------------------------------------- */\n\nexport interface TableFootProps extends React.HTMLAttributes<HTMLTableSectionElement> {}\n\n/**\n * Optional totals/summary row section.\n * Bold typography to distinguish from body rows.\n */\nexport function TableFoot({ className, children, ...props }: TableFootProps) {\n return (\n <tfoot\n className={cn(\n 'border-t-2 border-void',\n 'font-bold text-void',\n className,\n )}\n {...props}\n >\n {children}\n </tfoot>\n )\n}\n\n\n/* ----------------------------------------------------------\n TableRow\n ---------------------------------------------------------- */\n\nexport interface TableRowProps extends React.HTMLAttributes<HTMLTableRowElement> {}\n\n/** A <tr> with a bottom border and hover highlight. */\nexport function TableRow({ className, children, ...props }: TableRowProps) {\n return (\n <tr\n className={cn(\n 'border-b border-rule last:border-b-0',\n 'transition-colors duration-fast ease-[var(--ease-standard)]',\n // Hover — only on tbody rows (tfoot rows don't need it)\n '[tbody_&]:hover:bg-[color-mix(in_srgb,var(--color-rule)_30%,var(--color-paper))]',\n className,\n )}\n {...props}\n >\n {children}\n </tr>\n )\n}\n\n\n/* ----------------------------------------------------------\n TableHead\n ---------------------------------------------------------- */\n\nexport interface TableHeadProps extends React.ThHTMLAttributes<HTMLTableCellElement> {\n /**\n * Right-aligns the column — use for numeric data (amounts, quantities).\n */\n numeric?: boolean\n}\n\n/**\n * Column header cell (<th>).\n * Typography: display font, uppercase, extra-small.\n */\nexport function TableHead({\n numeric,\n className,\n children,\n ...props\n}: TableHeadProps) {\n return (\n <th\n scope=\"col\"\n className={cn(\n // Typography — Barlow Condensed, small, tracked uppercase\n 'font-display font-bold text-xs uppercase tracking-[0.10em]',\n // Color\n 'text-smoke',\n // Spacing\n 'px-4 py-3',\n // Alignment\n numeric ? 'text-right' : 'text-left',\n className,\n )}\n {...props}\n >\n {children}\n </th>\n )\n}\n\n\n/* ----------------------------------------------------------\n TableCell\n ---------------------------------------------------------- */\n\nexport interface TableCellProps extends React.TdHTMLAttributes<HTMLTableCellElement> {\n /**\n * Right-aligns the cell — use for numeric data (amounts, quantities).\n * Should match the numeric prop on the corresponding TableHead.\n */\n numeric?: boolean\n /**\n * Renders the cell in secondary/muted text color.\n * Useful for supporting information (dates, trade names, units).\n */\n muted?: boolean\n}\n\n/** Data cell (<td>). */\nexport function TableCell({\n numeric,\n muted,\n className,\n children,\n ...props\n}: TableCellProps) {\n return (\n <td\n className={cn(\n // Typography\n 'font-body text-sm',\n // Color\n muted ? 'text-smoke' : 'text-void',\n // Spacing\n 'px-4 py-3',\n // Alignment\n numeric ? 'text-right tabular-nums' : 'text-left',\n className,\n )}\n {...props}\n >\n {children}\n </td>\n )\n}\n","import { cn } from '../../lib/cn'\n\nexport interface TextareaProps extends React.TextareaHTMLAttributes<HTMLTextAreaElement> {\n /**\n * Error message shown below the textarea.\n * When set, the textarea renders in an error state (signal-red border).\n */\n error?: string\n /**\n * Hint text shown below the textarea when there is no error.\n */\n helperText?: string\n}\n\nconst textareaBase = [\n // Layout\n 'w-full',\n // Typography\n 'font-body text-base text-void',\n // Geometry\n 'px-4 py-2 rounded-sm border border-solid',\n // Size\n 'min-h-[80px] resize-y',\n // Color\n 'bg-paper border-rule',\n // Placeholder\n 'placeholder:text-smoke',\n // Focus\n 'outline-none',\n 'focus-visible:border-signal-alt',\n 'focus-visible:ring-[2px] focus-visible:ring-signal-alt focus-visible:ring-offset-0',\n // Transition\n 'transition-colors duration-fast ease-[var(--ease-standard)]',\n // Disabled\n 'disabled:opacity-[0.38] disabled:cursor-not-allowed',\n 'disabled:bg-[color-mix(in_srgb,var(--color-rule)_30%,var(--color-paper))]',\n 'disabled:resize-none',\n].join(' ')\n\nconst textareaError = [\n 'border-signal',\n 'focus-visible:border-signal',\n 'focus-visible:ring-[color-mix(in_srgb,var(--color-signal)_40%,transparent)]',\n].join(' ')\n\n/**\n * Multi-line text input.\n * Same error/helper/disabled API as Input — compose with Label for accessible fields.\n *\n * @example\n * <Label htmlFor=\"notes\" required>Scope Notes</Label>\n * <Textarea id=\"notes\" rows={4} placeholder=\"Describe the work scope…\" />\n *\n * @example\n * <Textarea id=\"desc\" error=\"Description is required.\" />\n */\nexport function Textarea({\n id,\n error,\n helperText,\n className,\n ...props\n}: TextareaProps) {\n const errorId = id ? `${id}-error` : undefined\n const hintId = id ? `${id}-hint` : undefined\n\n const describedBy = error\n ? errorId\n : helperText\n ? hintId\n : undefined\n\n return (\n <div className=\"flex flex-col gap-1\">\n <textarea\n id={id}\n className={cn(textareaBase, error && textareaError, className)}\n aria-invalid={error ? 'true' : undefined}\n aria-describedby={describedBy}\n {...props}\n />\n {error && (\n <p\n id={errorId}\n role=\"alert\"\n className=\"text-xs text-signal leading-none\"\n >\n {error}\n </p>\n )}\n {!error && helperText && (\n <p\n id={hintId}\n className=\"text-xs text-smoke leading-none\"\n >\n {helperText}\n </p>\n )}\n </div>\n )\n}\n","\"use client\";\n\n// src/checkbox.tsx\nimport * as React from \"react\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { createContextScope } from \"@radix-ui/react-context\";\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\nimport { useControllableState } from \"@radix-ui/react-use-controllable-state\";\nimport { usePrevious } from \"@radix-ui/react-use-previous\";\nimport { useSize } from \"@radix-ui/react-use-size\";\nimport { Presence } from \"@radix-ui/react-presence\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { Fragment, jsx, jsxs } from \"react/jsx-runtime\";\nvar CHECKBOX_NAME = \"Checkbox\";\nvar [createCheckboxContext, createCheckboxScope] = createContextScope(CHECKBOX_NAME);\nvar [CheckboxProviderImpl, useCheckboxContext] = createCheckboxContext(CHECKBOX_NAME);\nfunction CheckboxProvider(props) {\n const {\n __scopeCheckbox,\n checked: checkedProp,\n children,\n defaultChecked,\n disabled,\n form,\n name,\n onCheckedChange,\n required,\n value = \"on\",\n // @ts-expect-error\n internal_do_not_use_render\n } = props;\n const [checked, setChecked] = useControllableState({\n prop: checkedProp,\n defaultProp: defaultChecked ?? false,\n onChange: onCheckedChange,\n caller: CHECKBOX_NAME\n });\n const [control, setControl] = React.useState(null);\n const [bubbleInput, setBubbleInput] = React.useState(null);\n const hasConsumerStoppedPropagationRef = React.useRef(false);\n const isFormControl = control ? !!form || !!control.closest(\"form\") : (\n // We set this to true by default so that events bubble to forms without JS (SSR)\n true\n );\n const context = {\n checked,\n disabled,\n setChecked,\n control,\n setControl,\n name,\n form,\n value,\n hasConsumerStoppedPropagationRef,\n required,\n defaultChecked: isIndeterminate(defaultChecked) ? false : defaultChecked,\n isFormControl,\n bubbleInput,\n setBubbleInput\n };\n return /* @__PURE__ */ jsx(\n CheckboxProviderImpl,\n {\n scope: __scopeCheckbox,\n ...context,\n children: isFunction(internal_do_not_use_render) ? internal_do_not_use_render(context) : children\n }\n );\n}\nvar TRIGGER_NAME = \"CheckboxTrigger\";\nvar CheckboxTrigger = React.forwardRef(\n ({ __scopeCheckbox, onKeyDown, onClick, ...checkboxProps }, forwardedRef) => {\n const {\n control,\n value,\n disabled,\n checked,\n required,\n setControl,\n setChecked,\n hasConsumerStoppedPropagationRef,\n isFormControl,\n bubbleInput\n } = useCheckboxContext(TRIGGER_NAME, __scopeCheckbox);\n const composedRefs = useComposedRefs(forwardedRef, setControl);\n const initialCheckedStateRef = React.useRef(checked);\n React.useEffect(() => {\n const form = control?.form;\n if (form) {\n const reset = () => setChecked(initialCheckedStateRef.current);\n form.addEventListener(\"reset\", reset);\n return () => form.removeEventListener(\"reset\", reset);\n }\n }, [control, setChecked]);\n return /* @__PURE__ */ jsx(\n Primitive.button,\n {\n type: \"button\",\n role: \"checkbox\",\n \"aria-checked\": isIndeterminate(checked) ? \"mixed\" : checked,\n \"aria-required\": required,\n \"data-state\": getState(checked),\n \"data-disabled\": disabled ? \"\" : void 0,\n disabled,\n value,\n ...checkboxProps,\n ref: composedRefs,\n onKeyDown: composeEventHandlers(onKeyDown, (event) => {\n if (event.key === \"Enter\") event.preventDefault();\n }),\n onClick: composeEventHandlers(onClick, (event) => {\n setChecked((prevChecked) => isIndeterminate(prevChecked) ? true : !prevChecked);\n if (bubbleInput && isFormControl) {\n hasConsumerStoppedPropagationRef.current = event.isPropagationStopped();\n if (!hasConsumerStoppedPropagationRef.current) event.stopPropagation();\n }\n })\n }\n );\n }\n);\nCheckboxTrigger.displayName = TRIGGER_NAME;\nvar Checkbox = React.forwardRef(\n (props, forwardedRef) => {\n const {\n __scopeCheckbox,\n name,\n checked,\n defaultChecked,\n required,\n disabled,\n value,\n onCheckedChange,\n form,\n ...checkboxProps\n } = props;\n return /* @__PURE__ */ jsx(\n CheckboxProvider,\n {\n __scopeCheckbox,\n checked,\n defaultChecked,\n disabled,\n required,\n onCheckedChange,\n name,\n form,\n value,\n internal_do_not_use_render: ({ isFormControl }) => /* @__PURE__ */ jsxs(Fragment, { children: [\n /* @__PURE__ */ jsx(\n CheckboxTrigger,\n {\n ...checkboxProps,\n ref: forwardedRef,\n __scopeCheckbox\n }\n ),\n isFormControl && /* @__PURE__ */ jsx(\n CheckboxBubbleInput,\n {\n __scopeCheckbox\n }\n )\n ] })\n }\n );\n }\n);\nCheckbox.displayName = CHECKBOX_NAME;\nvar INDICATOR_NAME = \"CheckboxIndicator\";\nvar CheckboxIndicator = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeCheckbox, forceMount, ...indicatorProps } = props;\n const context = useCheckboxContext(INDICATOR_NAME, __scopeCheckbox);\n return /* @__PURE__ */ jsx(\n Presence,\n {\n present: forceMount || isIndeterminate(context.checked) || context.checked === true,\n children: /* @__PURE__ */ jsx(\n Primitive.span,\n {\n \"data-state\": getState(context.checked),\n \"data-disabled\": context.disabled ? \"\" : void 0,\n ...indicatorProps,\n ref: forwardedRef,\n style: { pointerEvents: \"none\", ...props.style }\n }\n )\n }\n );\n }\n);\nCheckboxIndicator.displayName = INDICATOR_NAME;\nvar BUBBLE_INPUT_NAME = \"CheckboxBubbleInput\";\nvar CheckboxBubbleInput = React.forwardRef(\n ({ __scopeCheckbox, ...props }, forwardedRef) => {\n const {\n control,\n hasConsumerStoppedPropagationRef,\n checked,\n defaultChecked,\n required,\n disabled,\n name,\n value,\n form,\n bubbleInput,\n setBubbleInput\n } = useCheckboxContext(BUBBLE_INPUT_NAME, __scopeCheckbox);\n const composedRefs = useComposedRefs(forwardedRef, setBubbleInput);\n const prevChecked = usePrevious(checked);\n const controlSize = useSize(control);\n React.useEffect(() => {\n const input = bubbleInput;\n if (!input) return;\n const inputProto = window.HTMLInputElement.prototype;\n const descriptor = Object.getOwnPropertyDescriptor(\n inputProto,\n \"checked\"\n );\n const setChecked = descriptor.set;\n const bubbles = !hasConsumerStoppedPropagationRef.current;\n if (prevChecked !== checked && setChecked) {\n const event = new Event(\"click\", { bubbles });\n input.indeterminate = isIndeterminate(checked);\n setChecked.call(input, isIndeterminate(checked) ? false : checked);\n input.dispatchEvent(event);\n }\n }, [bubbleInput, prevChecked, checked, hasConsumerStoppedPropagationRef]);\n const defaultCheckedRef = React.useRef(isIndeterminate(checked) ? false : checked);\n return /* @__PURE__ */ jsx(\n Primitive.input,\n {\n type: \"checkbox\",\n \"aria-hidden\": true,\n defaultChecked: defaultChecked ?? defaultCheckedRef.current,\n required,\n disabled,\n name,\n value,\n form,\n ...props,\n tabIndex: -1,\n ref: composedRefs,\n style: {\n ...props.style,\n ...controlSize,\n position: \"absolute\",\n pointerEvents: \"none\",\n opacity: 0,\n margin: 0,\n // We transform because the input is absolutely positioned but we have\n // rendered it **after** the button. This pulls it back to sit on top\n // of the button.\n transform: \"translateX(-100%)\"\n }\n }\n );\n }\n);\nCheckboxBubbleInput.displayName = BUBBLE_INPUT_NAME;\nfunction isFunction(value) {\n return typeof value === \"function\";\n}\nfunction isIndeterminate(checked) {\n return checked === \"indeterminate\";\n}\nfunction getState(checked) {\n return isIndeterminate(checked) ? \"indeterminate\" : checked ? \"checked\" : \"unchecked\";\n}\nexport {\n Checkbox,\n CheckboxIndicator,\n CheckboxIndicator as Indicator,\n Checkbox as Root,\n createCheckboxScope,\n CheckboxBubbleInput as unstable_BubbleInput,\n CheckboxBubbleInput as unstable_CheckboxBubbleInput,\n CheckboxProvider as unstable_CheckboxProvider,\n CheckboxTrigger as unstable_CheckboxTrigger,\n CheckboxProvider as unstable_Provider,\n CheckboxTrigger as unstable_Trigger\n};\n//# sourceMappingURL=index.mjs.map\n","import * as CheckboxPrimitive from '@radix-ui/react-checkbox'\nimport { cn } from '../../lib/cn'\n\nexport interface CheckboxProps\n extends React.ComponentPropsWithoutRef<typeof CheckboxPrimitive.Root> {}\n\n/* Checkmark SVG */\nfunction CheckIcon() {\n return (\n <svg\n viewBox=\"0 0 10 8\"\n className=\"w-2.5 h-2\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth={2.2}\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n aria-hidden=\"true\"\n >\n <path d=\"M1 4L3.5 6.5L9 1.5\" />\n </svg>\n )\n}\n\n/* Dash SVG — rendered when checked === 'indeterminate' */\nfunction DashIcon() {\n return (\n <svg\n viewBox=\"0 0 10 2\"\n className=\"w-2.5 h-0.5\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth={2.2}\n strokeLinecap=\"round\"\n aria-hidden=\"true\"\n >\n <path d=\"M1 1h8\" />\n </svg>\n )\n}\n\n/**\n * Accessible checkbox. Compose with Label for labelled form fields.\n *\n * @example\n * // Unlabelled\n * <Checkbox id=\"approved\" checked={approved} onCheckedChange={setApproved} />\n *\n * @example\n * // Labelled\n * <div className=\"flex items-center gap-2\">\n * <Checkbox id=\"approved\" />\n * <Label htmlFor=\"approved\">Mark as approved</Label>\n * </div>\n *\n * @example\n * // Indeterminate (select-all pattern)\n * <Checkbox checked=\"indeterminate\" />\n */\nexport function Checkbox({ checked, className, ...props }: CheckboxProps) {\n return (\n <CheckboxPrimitive.Root\n checked={checked}\n className={cn(\n // Geometry\n 'h-4 w-4 shrink-0 rounded-sm border border-rule',\n // Color — unchecked\n 'bg-paper',\n // Checked / indeterminate\n 'data-[state=checked]:bg-signal-alt data-[state=checked]:border-signal-alt data-[state=checked]:text-paper',\n 'data-[state=indeterminate]:bg-signal-alt data-[state=indeterminate]:border-signal-alt data-[state=indeterminate]:text-paper',\n // Focus\n 'outline-none',\n 'focus-visible:ring-[2px] focus-visible:ring-signal-alt focus-visible:ring-offset-1',\n // Disabled\n 'disabled:opacity-[0.38] disabled:cursor-not-allowed',\n // Transition\n 'transition-colors duration-fast ease-[var(--ease-standard)]',\n className,\n )}\n {...props}\n >\n <CheckboxPrimitive.Indicator className=\"flex items-center justify-center text-current\">\n {checked === 'indeterminate' ? <DashIcon /> : <CheckIcon />}\n </CheckboxPrimitive.Indicator>\n </CheckboxPrimitive.Root>\n )\n}\n","\"use client\";\n\n// src/switch.tsx\nimport * as React from \"react\";\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { createContextScope } from \"@radix-ui/react-context\";\nimport { useControllableState } from \"@radix-ui/react-use-controllable-state\";\nimport { usePrevious } from \"@radix-ui/react-use-previous\";\nimport { useSize } from \"@radix-ui/react-use-size\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { jsx, jsxs } from \"react/jsx-runtime\";\nvar SWITCH_NAME = \"Switch\";\nvar [createSwitchContext, createSwitchScope] = createContextScope(SWITCH_NAME);\nvar [SwitchProvider, useSwitchContext] = createSwitchContext(SWITCH_NAME);\nvar Switch = React.forwardRef(\n (props, forwardedRef) => {\n const {\n __scopeSwitch,\n name,\n checked: checkedProp,\n defaultChecked,\n required,\n disabled,\n value = \"on\",\n onCheckedChange,\n form,\n ...switchProps\n } = props;\n const [button, setButton] = React.useState(null);\n const composedRefs = useComposedRefs(forwardedRef, (node) => setButton(node));\n const hasConsumerStoppedPropagationRef = React.useRef(false);\n const isFormControl = button ? form || !!button.closest(\"form\") : true;\n const [checked, setChecked] = useControllableState({\n prop: checkedProp,\n defaultProp: defaultChecked ?? false,\n onChange: onCheckedChange,\n caller: SWITCH_NAME\n });\n return /* @__PURE__ */ jsxs(SwitchProvider, { scope: __scopeSwitch, checked, disabled, children: [\n /* @__PURE__ */ jsx(\n Primitive.button,\n {\n type: \"button\",\n role: \"switch\",\n \"aria-checked\": checked,\n \"aria-required\": required,\n \"data-state\": getState(checked),\n \"data-disabled\": disabled ? \"\" : void 0,\n disabled,\n value,\n ...switchProps,\n ref: composedRefs,\n onClick: composeEventHandlers(props.onClick, (event) => {\n setChecked((prevChecked) => !prevChecked);\n if (isFormControl) {\n hasConsumerStoppedPropagationRef.current = event.isPropagationStopped();\n if (!hasConsumerStoppedPropagationRef.current) event.stopPropagation();\n }\n })\n }\n ),\n isFormControl && /* @__PURE__ */ jsx(\n SwitchBubbleInput,\n {\n control: button,\n bubbles: !hasConsumerStoppedPropagationRef.current,\n name,\n value,\n checked,\n required,\n disabled,\n form,\n style: { transform: \"translateX(-100%)\" }\n }\n )\n ] });\n }\n);\nSwitch.displayName = SWITCH_NAME;\nvar THUMB_NAME = \"SwitchThumb\";\nvar SwitchThumb = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeSwitch, ...thumbProps } = props;\n const context = useSwitchContext(THUMB_NAME, __scopeSwitch);\n return /* @__PURE__ */ jsx(\n Primitive.span,\n {\n \"data-state\": getState(context.checked),\n \"data-disabled\": context.disabled ? \"\" : void 0,\n ...thumbProps,\n ref: forwardedRef\n }\n );\n }\n);\nSwitchThumb.displayName = THUMB_NAME;\nvar BUBBLE_INPUT_NAME = \"SwitchBubbleInput\";\nvar SwitchBubbleInput = React.forwardRef(\n ({\n __scopeSwitch,\n control,\n checked,\n bubbles = true,\n ...props\n }, forwardedRef) => {\n const ref = React.useRef(null);\n const composedRefs = useComposedRefs(ref, forwardedRef);\n const prevChecked = usePrevious(checked);\n const controlSize = useSize(control);\n React.useEffect(() => {\n const input = ref.current;\n if (!input) return;\n const inputProto = window.HTMLInputElement.prototype;\n const descriptor = Object.getOwnPropertyDescriptor(\n inputProto,\n \"checked\"\n );\n const setChecked = descriptor.set;\n if (prevChecked !== checked && setChecked) {\n const event = new Event(\"click\", { bubbles });\n setChecked.call(input, checked);\n input.dispatchEvent(event);\n }\n }, [prevChecked, checked, bubbles]);\n return /* @__PURE__ */ jsx(\n \"input\",\n {\n type: \"checkbox\",\n \"aria-hidden\": true,\n defaultChecked: checked,\n ...props,\n tabIndex: -1,\n ref: composedRefs,\n style: {\n ...props.style,\n ...controlSize,\n position: \"absolute\",\n pointerEvents: \"none\",\n opacity: 0,\n margin: 0\n }\n }\n );\n }\n);\nSwitchBubbleInput.displayName = BUBBLE_INPUT_NAME;\nfunction getState(checked) {\n return checked ? \"checked\" : \"unchecked\";\n}\nvar Root = Switch;\nvar Thumb = SwitchThumb;\nexport {\n Root,\n Switch,\n SwitchThumb,\n Thumb,\n createSwitchScope\n};\n//# sourceMappingURL=index.mjs.map\n","import * as SwitchPrimitive from '@radix-ui/react-switch'\nimport { cn } from '../../lib/cn'\n\nexport interface SwitchProps\n extends React.ComponentPropsWithoutRef<typeof SwitchPrimitive.Root> {}\n\n/**\n * Toggle switch for boolean settings.\n * Compose with Label for accessible form fields.\n *\n * Track dimensions: 36×20px. Thumb: 14×14px.\n * Thumb travel: 3px (off) → 19px (on).\n *\n * @example\n * <div className=\"flex items-center gap-2\">\n * <Switch id=\"notifs\" checked={enabled} onCheckedChange={setEnabled} />\n * <Label htmlFor=\"notifs\">Email notifications</Label>\n * </div>\n */\nexport function Switch({ className, ...props }: SwitchProps) {\n return (\n <SwitchPrimitive.Root\n className={cn(\n // Track geometry\n 'relative inline-flex h-5 w-9 shrink-0 cursor-pointer items-center rounded-full',\n // Track color — off\n 'bg-rule',\n // Track color — on\n 'data-[state=checked]:bg-signal-alt',\n // Focus\n 'outline-none',\n 'focus-visible:ring-[2px] focus-visible:ring-signal-alt focus-visible:ring-offset-2',\n // Disabled\n 'disabled:opacity-[0.38] disabled:cursor-not-allowed',\n // Transition\n 'transition-colors duration-fast ease-[var(--ease-standard)]',\n className,\n )}\n {...props}\n >\n <SwitchPrimitive.Thumb\n className={cn(\n // Thumb geometry\n 'block h-3.5 w-3.5 rounded-full',\n // Thumb color\n 'bg-paper',\n // Elevation\n 'shadow-[var(--shadow-sm)]',\n // Position — off\n 'translate-x-[3px]',\n // Position — on\n 'data-[state=checked]:translate-x-[19px]',\n // Transition\n 'transition-transform duration-fast ease-[var(--ease-standard)]',\n )}\n />\n </SwitchPrimitive.Root>\n )\n}\n","import { cn } from '../../lib/cn'\n\nexport type AlertVariant = 'neutral' | 'info' | 'warning' | 'danger' | 'success'\n\nexport interface AlertProps extends React.HTMLAttributes<HTMLDivElement> {\n /** Semantic intent conveyed by the alert. Defaults to 'neutral'. */\n variant?: AlertVariant\n /** Bold heading line above the description. */\n title?: string\n /**\n * Override the default variant icon.\n * Pass `null` to suppress the icon entirely.\n */\n icon?: React.ReactNode\n /**\n * Callback for the dismiss (×) button.\n * When provided, an × button is rendered — the consumer is responsible\n * for removing the alert from the DOM on click.\n */\n onDismiss?: () => void\n}\n\n/* ----------------------------------------------------------\n Default icons (16×16 filled SVGs)\n ---------------------------------------------------------- */\n\nfunction InfoIcon() {\n return (\n <svg viewBox=\"0 0 16 16\" width=\"16\" height=\"16\" fill=\"currentColor\" aria-hidden=\"true\">\n <path d=\"M8 1a7 7 0 1 1 0 14A7 7 0 0 1 8 1zm0 1a6 6 0 1 0 0 12A6 6 0 0 0 8 2zm.002 5a.75.75 0 0 1 .744.648L8.75 8.75v3a.75.75 0 0 1-1.493.102L7.25 11.75v-3A.75.75 0 0 1 8.002 8zM8 4.5a.875.875 0 1 1 0 1.75A.875.875 0 0 1 8 4.5z\" />\n </svg>\n )\n}\n\nfunction WarningIcon() {\n return (\n <svg viewBox=\"0 0 16 16\" width=\"16\" height=\"16\" fill=\"currentColor\" aria-hidden=\"true\">\n <path d=\"M8.982 1.566a1.13 1.13 0 0 0-1.96 0L.165 13.233c-.457.778.091 1.767.98 1.767h13.713c.889 0 1.438-.99.98-1.767L8.982 1.566zM8 5c.535 0 .954.462.9.995l-.35 3.507a.552.552 0 0 1-1.1 0L7.1 5.995A.905.905 0 0 1 8 5zm.002 6a1 1 0 1 1 0 2 1 1 0 0 1 0-2z\" />\n </svg>\n )\n}\n\nfunction DangerIcon() {\n return (\n <svg viewBox=\"0 0 16 16\" width=\"16\" height=\"16\" fill=\"currentColor\" aria-hidden=\"true\">\n <path d=\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM5.354 4.646a.5.5 0 1 0-.708.708L7.293 8l-2.647 2.646a.5.5 0 0 0 .708.708L8 8.707l2.646 2.647a.5.5 0 0 0 .708-.708L8.707 8l2.647-2.646a.5.5 0 0 0-.708-.708L8 7.293 5.354 4.646z\" />\n </svg>\n )\n}\n\nfunction SuccessIcon() {\n return (\n <svg viewBox=\"0 0 16 16\" width=\"16\" height=\"16\" fill=\"currentColor\" aria-hidden=\"true\">\n <path d=\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zm-3.97-3.03a.75.75 0 0 0-1.08.022L7.477 9.417 5.384 7.323a.75.75 0 0 0-1.06 1.061L6.97 11.03a.75.75 0 0 0 1.079-.02l3.992-4.99a.75.75 0 0 0-.01-1.05z\" />\n </svg>\n )\n}\n\nfunction CloseIcon() {\n return (\n <svg viewBox=\"0 0 16 16\" width=\"14\" height=\"14\" fill=\"currentColor\" aria-hidden=\"true\">\n <path d=\"M4.646 4.646a.5.5 0 0 1 .708 0L8 7.293l2.646-2.647a.5.5 0 0 1 .708.708L8.707 8l2.647 2.646a.5.5 0 0 1-.708.708L8 8.707l-2.646 2.647a.5.5 0 0 1-.708-.708L7.293 8 4.646 5.354a.5.5 0 0 1 0-.708z\" />\n </svg>\n )\n}\n\nconst defaultIcons: Record<AlertVariant, React.ReactNode> = {\n neutral: <InfoIcon />,\n info: <InfoIcon />,\n warning: <WarningIcon />,\n danger: <DangerIcon />,\n success: <SuccessIcon />,\n}\n\n/* ----------------------------------------------------------\n Variant styles\n ---------------------------------------------------------- */\n\nconst variants: Record<AlertVariant, { container: string; icon: string; title: string }> = {\n neutral: {\n container: cn(\n 'border-l-smoke',\n 'bg-[color-mix(in_srgb,var(--color-smoke)_8%,var(--color-paper))]',\n ),\n icon: 'text-smoke',\n title: 'text-smoke',\n },\n info: {\n container: cn(\n 'border-l-signal-alt',\n 'bg-[color-mix(in_srgb,var(--color-signal-alt)_8%,var(--color-paper))]',\n ),\n icon: 'text-signal-alt',\n title: 'text-signal-alt',\n },\n warning: {\n container: cn(\n 'border-l-[var(--color-caution)]',\n 'bg-[color-mix(in_srgb,var(--color-caution)_8%,var(--color-paper))]',\n ),\n icon: 'text-[var(--color-caution)]',\n title: 'text-[var(--color-caution)]',\n },\n danger: {\n container: cn(\n 'border-l-signal',\n 'bg-[color-mix(in_srgb,var(--color-signal)_8%,var(--color-paper))]',\n ),\n icon: 'text-signal',\n title: 'text-signal',\n },\n success: {\n container: cn(\n 'border-l-[var(--color-growth)]',\n 'bg-[color-mix(in_srgb,var(--color-growth)_8%,var(--color-paper))]',\n ),\n icon: 'text-[var(--color-growth)]',\n title: 'text-[var(--color-growth)]',\n },\n}\n\n/**\n * Inline status banner. Use for form errors, page-level warnings,\n * and contextual success/info messages.\n *\n * @example\n * <Alert variant=\"danger\" title=\"Save failed\">\n * Check your connection and try again.\n * </Alert>\n *\n * @example\n * // Dismissible\n * {show && (\n * <Alert variant=\"success\" title=\"Changes saved\" onDismiss={() => setShow(false)} />\n * )}\n */\nexport function Alert({\n variant = 'neutral',\n title,\n icon,\n onDismiss,\n className,\n children,\n ...props\n}: AlertProps) {\n const v = variants[variant]\n const iconEl = icon === null ? null : (icon ?? defaultIcons[variant])\n\n return (\n <div\n role=\"alert\"\n className={cn(\n // Layout\n 'flex items-start gap-3',\n // Border\n 'border-l-4 rounded-sm',\n // Spacing\n 'px-4 py-3',\n // Variant\n v.container,\n className,\n )}\n {...props}\n >\n {/* Icon */}\n {iconEl && (\n <span className={cn('mt-0.5 shrink-0', v.icon)}>\n {iconEl}\n </span>\n )}\n\n {/* Body */}\n <div className=\"flex-1 min-w-0\">\n {title && (\n <p className={cn('font-display font-bold text-sm uppercase tracking-[0.06em] leading-snug', v.title)}>\n {title}\n </p>\n )}\n {children && (\n <div className={cn('text-sm text-void leading-relaxed', title && 'mt-0.5')}>\n {children}\n </div>\n )}\n </div>\n\n {/* Dismiss button */}\n {onDismiss && (\n <button\n type=\"button\"\n aria-label=\"Dismiss\"\n onClick={onDismiss}\n className={cn(\n 'shrink-0 mt-0.5 opacity-50 hover:opacity-100',\n 'transition-opacity duration-fast ease-[var(--ease-standard)]',\n 'outline-none focus-visible:ring-[2px] focus-visible:ring-signal-alt rounded-sm',\n v.icon,\n )}\n >\n <CloseIcon />\n </button>\n )}\n </div>\n )\n}\n","\"use client\";\n\n// src/toast.tsx\nimport * as React from \"react\";\nimport * as ReactDOM from \"react-dom\";\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { createCollection } from \"@radix-ui/react-collection\";\nimport { createContextScope } from \"@radix-ui/react-context\";\nimport * as DismissableLayer from \"@radix-ui/react-dismissable-layer\";\nimport { Portal } from \"@radix-ui/react-portal\";\nimport { Presence } from \"@radix-ui/react-presence\";\nimport { Primitive, dispatchDiscreteCustomEvent } from \"@radix-ui/react-primitive\";\nimport { useCallbackRef } from \"@radix-ui/react-use-callback-ref\";\nimport { useControllableState } from \"@radix-ui/react-use-controllable-state\";\nimport { useLayoutEffect } from \"@radix-ui/react-use-layout-effect\";\nimport { VisuallyHidden } from \"@radix-ui/react-visually-hidden\";\nimport { Fragment, jsx, jsxs } from \"react/jsx-runtime\";\nvar PROVIDER_NAME = \"ToastProvider\";\nvar [Collection, useCollection, createCollectionScope] = createCollection(\"Toast\");\nvar [createToastContext, createToastScope] = createContextScope(\"Toast\", [createCollectionScope]);\nvar [ToastProviderProvider, useToastProviderContext] = createToastContext(PROVIDER_NAME);\nvar ToastProvider = (props) => {\n const {\n __scopeToast,\n label = \"Notification\",\n duration = 5e3,\n swipeDirection = \"right\",\n swipeThreshold = 50,\n children\n } = props;\n const [viewport, setViewport] = React.useState(null);\n const [toastCount, setToastCount] = React.useState(0);\n const isFocusedToastEscapeKeyDownRef = React.useRef(false);\n const isClosePausedRef = React.useRef(false);\n if (!label.trim()) {\n console.error(\n `Invalid prop \\`label\\` supplied to \\`${PROVIDER_NAME}\\`. Expected non-empty \\`string\\`.`\n );\n }\n return /* @__PURE__ */ jsx(Collection.Provider, { scope: __scopeToast, children: /* @__PURE__ */ jsx(\n ToastProviderProvider,\n {\n scope: __scopeToast,\n label,\n duration,\n swipeDirection,\n swipeThreshold,\n toastCount,\n viewport,\n onViewportChange: setViewport,\n onToastAdd: React.useCallback(() => setToastCount((prevCount) => prevCount + 1), []),\n onToastRemove: React.useCallback(() => setToastCount((prevCount) => prevCount - 1), []),\n isFocusedToastEscapeKeyDownRef,\n isClosePausedRef,\n children\n }\n ) });\n};\nToastProvider.displayName = PROVIDER_NAME;\nvar VIEWPORT_NAME = \"ToastViewport\";\nvar VIEWPORT_DEFAULT_HOTKEY = [\"F8\"];\nvar VIEWPORT_PAUSE = \"toast.viewportPause\";\nvar VIEWPORT_RESUME = \"toast.viewportResume\";\nvar ToastViewport = React.forwardRef(\n (props, forwardedRef) => {\n const {\n __scopeToast,\n hotkey = VIEWPORT_DEFAULT_HOTKEY,\n label = \"Notifications ({hotkey})\",\n ...viewportProps\n } = props;\n const context = useToastProviderContext(VIEWPORT_NAME, __scopeToast);\n const getItems = useCollection(__scopeToast);\n const wrapperRef = React.useRef(null);\n const headFocusProxyRef = React.useRef(null);\n const tailFocusProxyRef = React.useRef(null);\n const ref = React.useRef(null);\n const composedRefs = useComposedRefs(forwardedRef, ref, context.onViewportChange);\n const hotkeyLabel = hotkey.join(\"+\").replace(/Key/g, \"\").replace(/Digit/g, \"\");\n const hasToasts = context.toastCount > 0;\n React.useEffect(() => {\n const handleKeyDown = (event) => {\n const isHotkeyPressed = hotkey.length !== 0 && hotkey.every((key) => event[key] || event.code === key);\n if (isHotkeyPressed) ref.current?.focus();\n };\n document.addEventListener(\"keydown\", handleKeyDown);\n return () => document.removeEventListener(\"keydown\", handleKeyDown);\n }, [hotkey]);\n React.useEffect(() => {\n const wrapper = wrapperRef.current;\n const viewport = ref.current;\n if (hasToasts && wrapper && viewport) {\n const handlePause = () => {\n if (!context.isClosePausedRef.current) {\n const pauseEvent = new CustomEvent(VIEWPORT_PAUSE);\n viewport.dispatchEvent(pauseEvent);\n context.isClosePausedRef.current = true;\n }\n };\n const handleResume = () => {\n if (context.isClosePausedRef.current) {\n const resumeEvent = new CustomEvent(VIEWPORT_RESUME);\n viewport.dispatchEvent(resumeEvent);\n context.isClosePausedRef.current = false;\n }\n };\n const handleFocusOutResume = (event) => {\n const isFocusMovingOutside = !wrapper.contains(event.relatedTarget);\n if (isFocusMovingOutside) handleResume();\n };\n const handlePointerLeaveResume = () => {\n const isFocusInside = wrapper.contains(document.activeElement);\n if (!isFocusInside) handleResume();\n };\n wrapper.addEventListener(\"focusin\", handlePause);\n wrapper.addEventListener(\"focusout\", handleFocusOutResume);\n wrapper.addEventListener(\"pointermove\", handlePause);\n wrapper.addEventListener(\"pointerleave\", handlePointerLeaveResume);\n window.addEventListener(\"blur\", handlePause);\n window.addEventListener(\"focus\", handleResume);\n return () => {\n wrapper.removeEventListener(\"focusin\", handlePause);\n wrapper.removeEventListener(\"focusout\", handleFocusOutResume);\n wrapper.removeEventListener(\"pointermove\", handlePause);\n wrapper.removeEventListener(\"pointerleave\", handlePointerLeaveResume);\n window.removeEventListener(\"blur\", handlePause);\n window.removeEventListener(\"focus\", handleResume);\n };\n }\n }, [hasToasts, context.isClosePausedRef]);\n const getSortedTabbableCandidates = React.useCallback(\n ({ tabbingDirection }) => {\n const toastItems = getItems();\n const tabbableCandidates = toastItems.map((toastItem) => {\n const toastNode = toastItem.ref.current;\n const toastTabbableCandidates = [toastNode, ...getTabbableCandidates(toastNode)];\n return tabbingDirection === \"forwards\" ? toastTabbableCandidates : toastTabbableCandidates.reverse();\n });\n return (tabbingDirection === \"forwards\" ? tabbableCandidates.reverse() : tabbableCandidates).flat();\n },\n [getItems]\n );\n React.useEffect(() => {\n const viewport = ref.current;\n if (viewport) {\n const handleKeyDown = (event) => {\n const isMetaKey = event.altKey || event.ctrlKey || event.metaKey;\n const isTabKey = event.key === \"Tab\" && !isMetaKey;\n if (isTabKey) {\n const focusedElement = document.activeElement;\n const isTabbingBackwards = event.shiftKey;\n const targetIsViewport = event.target === viewport;\n if (targetIsViewport && isTabbingBackwards) {\n headFocusProxyRef.current?.focus();\n return;\n }\n const tabbingDirection = isTabbingBackwards ? \"backwards\" : \"forwards\";\n const sortedCandidates = getSortedTabbableCandidates({ tabbingDirection });\n const index = sortedCandidates.findIndex((candidate) => candidate === focusedElement);\n if (focusFirst(sortedCandidates.slice(index + 1))) {\n event.preventDefault();\n } else {\n isTabbingBackwards ? headFocusProxyRef.current?.focus() : tailFocusProxyRef.current?.focus();\n }\n }\n };\n viewport.addEventListener(\"keydown\", handleKeyDown);\n return () => viewport.removeEventListener(\"keydown\", handleKeyDown);\n }\n }, [getItems, getSortedTabbableCandidates]);\n return /* @__PURE__ */ jsxs(\n DismissableLayer.Branch,\n {\n ref: wrapperRef,\n role: \"region\",\n \"aria-label\": label.replace(\"{hotkey}\", hotkeyLabel),\n tabIndex: -1,\n style: { pointerEvents: hasToasts ? void 0 : \"none\" },\n children: [\n hasToasts && /* @__PURE__ */ jsx(\n FocusProxy,\n {\n ref: headFocusProxyRef,\n onFocusFromOutsideViewport: () => {\n const tabbableCandidates = getSortedTabbableCandidates({\n tabbingDirection: \"forwards\"\n });\n focusFirst(tabbableCandidates);\n }\n }\n ),\n /* @__PURE__ */ jsx(Collection.Slot, { scope: __scopeToast, children: /* @__PURE__ */ jsx(Primitive.ol, { tabIndex: -1, ...viewportProps, ref: composedRefs }) }),\n hasToasts && /* @__PURE__ */ jsx(\n FocusProxy,\n {\n ref: tailFocusProxyRef,\n onFocusFromOutsideViewport: () => {\n const tabbableCandidates = getSortedTabbableCandidates({\n tabbingDirection: \"backwards\"\n });\n focusFirst(tabbableCandidates);\n }\n }\n )\n ]\n }\n );\n }\n);\nToastViewport.displayName = VIEWPORT_NAME;\nvar FOCUS_PROXY_NAME = \"ToastFocusProxy\";\nvar FocusProxy = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeToast, onFocusFromOutsideViewport, ...proxyProps } = props;\n const context = useToastProviderContext(FOCUS_PROXY_NAME, __scopeToast);\n return /* @__PURE__ */ jsx(\n VisuallyHidden,\n {\n tabIndex: 0,\n ...proxyProps,\n ref: forwardedRef,\n style: { position: \"fixed\" },\n onFocus: (event) => {\n const prevFocusedElement = event.relatedTarget;\n const isFocusFromOutsideViewport = !context.viewport?.contains(prevFocusedElement);\n if (isFocusFromOutsideViewport) onFocusFromOutsideViewport();\n }\n }\n );\n }\n);\nFocusProxy.displayName = FOCUS_PROXY_NAME;\nvar TOAST_NAME = \"Toast\";\nvar TOAST_SWIPE_START = \"toast.swipeStart\";\nvar TOAST_SWIPE_MOVE = \"toast.swipeMove\";\nvar TOAST_SWIPE_CANCEL = \"toast.swipeCancel\";\nvar TOAST_SWIPE_END = \"toast.swipeEnd\";\nvar Toast = React.forwardRef(\n (props, forwardedRef) => {\n const { forceMount, open: openProp, defaultOpen, onOpenChange, ...toastProps } = props;\n const [open, setOpen] = useControllableState({\n prop: openProp,\n defaultProp: defaultOpen ?? true,\n onChange: onOpenChange,\n caller: TOAST_NAME\n });\n return /* @__PURE__ */ jsx(Presence, { present: forceMount || open, children: /* @__PURE__ */ jsx(\n ToastImpl,\n {\n open,\n ...toastProps,\n ref: forwardedRef,\n onClose: () => setOpen(false),\n onPause: useCallbackRef(props.onPause),\n onResume: useCallbackRef(props.onResume),\n onSwipeStart: composeEventHandlers(props.onSwipeStart, (event) => {\n event.currentTarget.setAttribute(\"data-swipe\", \"start\");\n }),\n onSwipeMove: composeEventHandlers(props.onSwipeMove, (event) => {\n const { x, y } = event.detail.delta;\n event.currentTarget.setAttribute(\"data-swipe\", \"move\");\n event.currentTarget.style.setProperty(\"--radix-toast-swipe-move-x\", `${x}px`);\n event.currentTarget.style.setProperty(\"--radix-toast-swipe-move-y\", `${y}px`);\n }),\n onSwipeCancel: composeEventHandlers(props.onSwipeCancel, (event) => {\n event.currentTarget.setAttribute(\"data-swipe\", \"cancel\");\n event.currentTarget.style.removeProperty(\"--radix-toast-swipe-move-x\");\n event.currentTarget.style.removeProperty(\"--radix-toast-swipe-move-y\");\n event.currentTarget.style.removeProperty(\"--radix-toast-swipe-end-x\");\n event.currentTarget.style.removeProperty(\"--radix-toast-swipe-end-y\");\n }),\n onSwipeEnd: composeEventHandlers(props.onSwipeEnd, (event) => {\n const { x, y } = event.detail.delta;\n event.currentTarget.setAttribute(\"data-swipe\", \"end\");\n event.currentTarget.style.removeProperty(\"--radix-toast-swipe-move-x\");\n event.currentTarget.style.removeProperty(\"--radix-toast-swipe-move-y\");\n event.currentTarget.style.setProperty(\"--radix-toast-swipe-end-x\", `${x}px`);\n event.currentTarget.style.setProperty(\"--radix-toast-swipe-end-y\", `${y}px`);\n setOpen(false);\n })\n }\n ) });\n }\n);\nToast.displayName = TOAST_NAME;\nvar [ToastInteractiveProvider, useToastInteractiveContext] = createToastContext(TOAST_NAME, {\n onClose() {\n }\n});\nvar ToastImpl = React.forwardRef(\n (props, forwardedRef) => {\n const {\n __scopeToast,\n type = \"foreground\",\n duration: durationProp,\n open,\n onClose,\n onEscapeKeyDown,\n onPause,\n onResume,\n onSwipeStart,\n onSwipeMove,\n onSwipeCancel,\n onSwipeEnd,\n ...toastProps\n } = props;\n const context = useToastProviderContext(TOAST_NAME, __scopeToast);\n const [node, setNode] = React.useState(null);\n const composedRefs = useComposedRefs(forwardedRef, (node2) => setNode(node2));\n const pointerStartRef = React.useRef(null);\n const swipeDeltaRef = React.useRef(null);\n const duration = durationProp || context.duration;\n const closeTimerStartTimeRef = React.useRef(0);\n const closeTimerRemainingTimeRef = React.useRef(duration);\n const closeTimerRef = React.useRef(0);\n const { onToastAdd, onToastRemove } = context;\n const handleClose = useCallbackRef(() => {\n const isFocusInToast = node?.contains(document.activeElement);\n if (isFocusInToast) context.viewport?.focus();\n onClose();\n });\n const startTimer = React.useCallback(\n (duration2) => {\n if (!duration2 || duration2 === Infinity) return;\n window.clearTimeout(closeTimerRef.current);\n closeTimerStartTimeRef.current = (/* @__PURE__ */ new Date()).getTime();\n closeTimerRef.current = window.setTimeout(handleClose, duration2);\n },\n [handleClose]\n );\n React.useEffect(() => {\n const viewport = context.viewport;\n if (viewport) {\n const handleResume = () => {\n startTimer(closeTimerRemainingTimeRef.current);\n onResume?.();\n };\n const handlePause = () => {\n const elapsedTime = (/* @__PURE__ */ new Date()).getTime() - closeTimerStartTimeRef.current;\n closeTimerRemainingTimeRef.current = closeTimerRemainingTimeRef.current - elapsedTime;\n window.clearTimeout(closeTimerRef.current);\n onPause?.();\n };\n viewport.addEventListener(VIEWPORT_PAUSE, handlePause);\n viewport.addEventListener(VIEWPORT_RESUME, handleResume);\n return () => {\n viewport.removeEventListener(VIEWPORT_PAUSE, handlePause);\n viewport.removeEventListener(VIEWPORT_RESUME, handleResume);\n };\n }\n }, [context.viewport, duration, onPause, onResume, startTimer]);\n React.useEffect(() => {\n if (open && !context.isClosePausedRef.current) startTimer(duration);\n }, [open, duration, context.isClosePausedRef, startTimer]);\n React.useEffect(() => {\n onToastAdd();\n return () => onToastRemove();\n }, [onToastAdd, onToastRemove]);\n const announceTextContent = React.useMemo(() => {\n return node ? getAnnounceTextContent(node) : null;\n }, [node]);\n if (!context.viewport) return null;\n return /* @__PURE__ */ jsxs(Fragment, { children: [\n announceTextContent && /* @__PURE__ */ jsx(\n ToastAnnounce,\n {\n __scopeToast,\n role: \"status\",\n \"aria-live\": type === \"foreground\" ? \"assertive\" : \"polite\",\n children: announceTextContent\n }\n ),\n /* @__PURE__ */ jsx(ToastInteractiveProvider, { scope: __scopeToast, onClose: handleClose, children: ReactDOM.createPortal(\n /* @__PURE__ */ jsx(Collection.ItemSlot, { scope: __scopeToast, children: /* @__PURE__ */ jsx(\n DismissableLayer.Root,\n {\n asChild: true,\n onEscapeKeyDown: composeEventHandlers(onEscapeKeyDown, () => {\n if (!context.isFocusedToastEscapeKeyDownRef.current) handleClose();\n context.isFocusedToastEscapeKeyDownRef.current = false;\n }),\n children: /* @__PURE__ */ jsx(\n Primitive.li,\n {\n tabIndex: 0,\n \"data-state\": open ? \"open\" : \"closed\",\n \"data-swipe-direction\": context.swipeDirection,\n ...toastProps,\n ref: composedRefs,\n style: { userSelect: \"none\", touchAction: \"none\", ...props.style },\n onKeyDown: composeEventHandlers(props.onKeyDown, (event) => {\n if (event.key !== \"Escape\") return;\n onEscapeKeyDown?.(event.nativeEvent);\n if (!event.nativeEvent.defaultPrevented) {\n context.isFocusedToastEscapeKeyDownRef.current = true;\n handleClose();\n }\n }),\n onPointerDown: composeEventHandlers(props.onPointerDown, (event) => {\n if (event.button !== 0) return;\n pointerStartRef.current = { x: event.clientX, y: event.clientY };\n }),\n onPointerMove: composeEventHandlers(props.onPointerMove, (event) => {\n if (!pointerStartRef.current) return;\n const x = event.clientX - pointerStartRef.current.x;\n const y = event.clientY - pointerStartRef.current.y;\n const hasSwipeMoveStarted = Boolean(swipeDeltaRef.current);\n const isHorizontalSwipe = [\"left\", \"right\"].includes(context.swipeDirection);\n const clamp = [\"left\", \"up\"].includes(context.swipeDirection) ? Math.min : Math.max;\n const clampedX = isHorizontalSwipe ? clamp(0, x) : 0;\n const clampedY = !isHorizontalSwipe ? clamp(0, y) : 0;\n const moveStartBuffer = event.pointerType === \"touch\" ? 10 : 2;\n const delta = { x: clampedX, y: clampedY };\n const eventDetail = { originalEvent: event, delta };\n if (hasSwipeMoveStarted) {\n swipeDeltaRef.current = delta;\n handleAndDispatchCustomEvent(TOAST_SWIPE_MOVE, onSwipeMove, eventDetail, {\n discrete: false\n });\n } else if (isDeltaInDirection(delta, context.swipeDirection, moveStartBuffer)) {\n swipeDeltaRef.current = delta;\n handleAndDispatchCustomEvent(TOAST_SWIPE_START, onSwipeStart, eventDetail, {\n discrete: false\n });\n event.target.setPointerCapture(event.pointerId);\n } else if (Math.abs(x) > moveStartBuffer || Math.abs(y) > moveStartBuffer) {\n pointerStartRef.current = null;\n }\n }),\n onPointerUp: composeEventHandlers(props.onPointerUp, (event) => {\n const delta = swipeDeltaRef.current;\n const target = event.target;\n if (target.hasPointerCapture(event.pointerId)) {\n target.releasePointerCapture(event.pointerId);\n }\n swipeDeltaRef.current = null;\n pointerStartRef.current = null;\n if (delta) {\n const toast = event.currentTarget;\n const eventDetail = { originalEvent: event, delta };\n if (isDeltaInDirection(delta, context.swipeDirection, context.swipeThreshold)) {\n handleAndDispatchCustomEvent(TOAST_SWIPE_END, onSwipeEnd, eventDetail, {\n discrete: true\n });\n } else {\n handleAndDispatchCustomEvent(\n TOAST_SWIPE_CANCEL,\n onSwipeCancel,\n eventDetail,\n {\n discrete: true\n }\n );\n }\n toast.addEventListener(\"click\", (event2) => event2.preventDefault(), {\n once: true\n });\n }\n })\n }\n )\n }\n ) }),\n context.viewport\n ) })\n ] });\n }\n);\nvar ToastAnnounce = (props) => {\n const { __scopeToast, children, ...announceProps } = props;\n const context = useToastProviderContext(TOAST_NAME, __scopeToast);\n const [renderAnnounceText, setRenderAnnounceText] = React.useState(false);\n const [isAnnounced, setIsAnnounced] = React.useState(false);\n useNextFrame(() => setRenderAnnounceText(true));\n React.useEffect(() => {\n const timer = window.setTimeout(() => setIsAnnounced(true), 1e3);\n return () => window.clearTimeout(timer);\n }, []);\n return isAnnounced ? null : /* @__PURE__ */ jsx(Portal, { asChild: true, children: /* @__PURE__ */ jsx(VisuallyHidden, { ...announceProps, children: renderAnnounceText && /* @__PURE__ */ jsxs(Fragment, { children: [\n context.label,\n \" \",\n children\n ] }) }) });\n};\nvar TITLE_NAME = \"ToastTitle\";\nvar ToastTitle = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeToast, ...titleProps } = props;\n return /* @__PURE__ */ jsx(Primitive.div, { ...titleProps, ref: forwardedRef });\n }\n);\nToastTitle.displayName = TITLE_NAME;\nvar DESCRIPTION_NAME = \"ToastDescription\";\nvar ToastDescription = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeToast, ...descriptionProps } = props;\n return /* @__PURE__ */ jsx(Primitive.div, { ...descriptionProps, ref: forwardedRef });\n }\n);\nToastDescription.displayName = DESCRIPTION_NAME;\nvar ACTION_NAME = \"ToastAction\";\nvar ToastAction = React.forwardRef(\n (props, forwardedRef) => {\n const { altText, ...actionProps } = props;\n if (!altText.trim()) {\n console.error(\n `Invalid prop \\`altText\\` supplied to \\`${ACTION_NAME}\\`. Expected non-empty \\`string\\`.`\n );\n return null;\n }\n return /* @__PURE__ */ jsx(ToastAnnounceExclude, { altText, asChild: true, children: /* @__PURE__ */ jsx(ToastClose, { ...actionProps, ref: forwardedRef }) });\n }\n);\nToastAction.displayName = ACTION_NAME;\nvar CLOSE_NAME = \"ToastClose\";\nvar ToastClose = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeToast, ...closeProps } = props;\n const interactiveContext = useToastInteractiveContext(CLOSE_NAME, __scopeToast);\n return /* @__PURE__ */ jsx(ToastAnnounceExclude, { asChild: true, children: /* @__PURE__ */ jsx(\n Primitive.button,\n {\n type: \"button\",\n ...closeProps,\n ref: forwardedRef,\n onClick: composeEventHandlers(props.onClick, interactiveContext.onClose)\n }\n ) });\n }\n);\nToastClose.displayName = CLOSE_NAME;\nvar ToastAnnounceExclude = React.forwardRef((props, forwardedRef) => {\n const { __scopeToast, altText, ...announceExcludeProps } = props;\n return /* @__PURE__ */ jsx(\n Primitive.div,\n {\n \"data-radix-toast-announce-exclude\": \"\",\n \"data-radix-toast-announce-alt\": altText || void 0,\n ...announceExcludeProps,\n ref: forwardedRef\n }\n );\n});\nfunction getAnnounceTextContent(container) {\n const textContent = [];\n const childNodes = Array.from(container.childNodes);\n childNodes.forEach((node) => {\n if (node.nodeType === node.TEXT_NODE && node.textContent) textContent.push(node.textContent);\n if (isHTMLElement(node)) {\n const isHidden = node.ariaHidden || node.hidden || node.style.display === \"none\";\n const isExcluded = node.dataset.radixToastAnnounceExclude === \"\";\n if (!isHidden) {\n if (isExcluded) {\n const altText = node.dataset.radixToastAnnounceAlt;\n if (altText) textContent.push(altText);\n } else {\n textContent.push(...getAnnounceTextContent(node));\n }\n }\n }\n });\n return textContent;\n}\nfunction handleAndDispatchCustomEvent(name, handler, detail, { discrete }) {\n const currentTarget = detail.originalEvent.currentTarget;\n const event = new CustomEvent(name, { bubbles: true, cancelable: true, detail });\n if (handler) currentTarget.addEventListener(name, handler, { once: true });\n if (discrete) {\n dispatchDiscreteCustomEvent(currentTarget, event);\n } else {\n currentTarget.dispatchEvent(event);\n }\n}\nvar isDeltaInDirection = (delta, direction, threshold = 0) => {\n const deltaX = Math.abs(delta.x);\n const deltaY = Math.abs(delta.y);\n const isDeltaX = deltaX > deltaY;\n if (direction === \"left\" || direction === \"right\") {\n return isDeltaX && deltaX > threshold;\n } else {\n return !isDeltaX && deltaY > threshold;\n }\n};\nfunction useNextFrame(callback = () => {\n}) {\n const fn = useCallbackRef(callback);\n useLayoutEffect(() => {\n let raf1 = 0;\n let raf2 = 0;\n raf1 = window.requestAnimationFrame(() => raf2 = window.requestAnimationFrame(fn));\n return () => {\n window.cancelAnimationFrame(raf1);\n window.cancelAnimationFrame(raf2);\n };\n }, [fn]);\n}\nfunction isHTMLElement(node) {\n return node.nodeType === node.ELEMENT_NODE;\n}\nfunction getTabbableCandidates(container) {\n const nodes = [];\n const walker = document.createTreeWalker(container, NodeFilter.SHOW_ELEMENT, {\n acceptNode: (node) => {\n const isHiddenInput = node.tagName === \"INPUT\" && node.type === \"hidden\";\n if (node.disabled || node.hidden || isHiddenInput) return NodeFilter.FILTER_SKIP;\n return node.tabIndex >= 0 ? NodeFilter.FILTER_ACCEPT : NodeFilter.FILTER_SKIP;\n }\n });\n while (walker.nextNode()) nodes.push(walker.currentNode);\n return nodes;\n}\nfunction focusFirst(candidates) {\n const previouslyFocusedElement = document.activeElement;\n return candidates.some((candidate) => {\n if (candidate === previouslyFocusedElement) return true;\n candidate.focus();\n return document.activeElement !== previouslyFocusedElement;\n });\n}\nvar Provider = ToastProvider;\nvar Viewport = ToastViewport;\nvar Root2 = Toast;\nvar Title = ToastTitle;\nvar Description = ToastDescription;\nvar Action = ToastAction;\nvar Close = ToastClose;\nexport {\n Action,\n Close,\n Description,\n Provider,\n Root2 as Root,\n Title,\n Toast,\n ToastAction,\n ToastClose,\n ToastDescription,\n ToastProvider,\n ToastTitle,\n ToastViewport,\n Viewport,\n createToastScope\n};\n//# sourceMappingURL=index.mjs.map\n","import * as React from 'react'\n\nexport type ToastVariant = 'neutral' | 'success' | 'warning' | 'danger'\n\nexport interface ToastItem {\n id: string\n title?: string\n description?: string\n variant?: ToastVariant\n duration?: number // ms — default 4000, set to Infinity to persist\n}\n\ninterface ToastState {\n toasts: ToastItem[]\n}\n\ntype ToastAction =\n | { type: 'ADD'; toast: ToastItem }\n | { type: 'REMOVE'; id: string }\n\nfunction reducer(state: ToastState, action: ToastAction): ToastState {\n switch (action.type) {\n case 'ADD':\n return { toasts: [...state.toasts, action.toast] }\n case 'REMOVE':\n return { toasts: state.toasts.filter(t => t.id !== action.id) }\n }\n}\n\n/* ----------------------------------------------------------\n Global dispatch — allows toast() to be called outside React trees\n ---------------------------------------------------------- */\n\nconst listeners: Array<React.Dispatch<ToastAction>> = []\n\nfunction dispatch(action: ToastAction) {\n listeners.forEach(fn => fn(action))\n}\n\nlet counter = 0\nfunction genId() {\n return `toast-${++counter}`\n}\n\n/* ----------------------------------------------------------\n Public API\n ---------------------------------------------------------- */\n\nexport interface ToastOptions {\n title?: string\n description?: string\n variant?: ToastVariant\n duration?: number\n}\n\n/** Imperatively show a toast from anywhere. */\nexport function toast(options: ToastOptions): string {\n const id = genId()\n dispatch({\n type: 'ADD',\n toast: {\n id,\n variant: 'neutral',\n duration: 4000,\n ...options,\n },\n })\n return id\n}\n\n/** Dismiss a toast by id, or dismiss all toasts if no id is provided. */\ntoast.dismiss = function (id?: string) {\n if (id) {\n dispatch({ type: 'REMOVE', id })\n } else {\n // dismiss all — clone array before iterating so listeners don't mutate mid-loop\n listeners.forEach(() => {\n // We can't read state here directly — this is a best-effort clear\n })\n dispatch({ type: 'REMOVE', id: '__all__' })\n }\n}\n\n/** Shorthand variants */\ntoast.success = (options: Omit<ToastOptions, 'variant'>) =>\n toast({ ...options, variant: 'success' })\n\ntoast.warning = (options: Omit<ToastOptions, 'variant'>) =>\n toast({ ...options, variant: 'warning' })\n\ntoast.danger = (options: Omit<ToastOptions, 'variant'>) =>\n toast({ ...options, variant: 'danger' })\n\n/* ----------------------------------------------------------\n Hook — used internally by Toaster\n ---------------------------------------------------------- */\n\nexport function useToastStore() {\n const [state, dispatchLocal] = React.useReducer(reducer, { toasts: [] })\n\n React.useEffect(() => {\n listeners.push(dispatchLocal)\n return () => {\n const idx = listeners.indexOf(dispatchLocal)\n if (idx > -1) listeners.splice(idx, 1)\n }\n }, [])\n\n const dismiss = React.useCallback((id: string) => {\n dispatchLocal({ type: 'REMOVE', id })\n }, [])\n\n return { toasts: state.toasts, dismiss }\n}\n","import * as ToastPrimitive from '@radix-ui/react-toast'\nimport { cn } from '../../lib/cn'\nimport { useToastStore, type ToastVariant } from './use-toast'\n\n/* ----------------------------------------------------------\n Icons\n ---------------------------------------------------------- */\n\nfunction SuccessIcon() {\n return (\n <svg viewBox=\"0 0 16 16\" width=\"16\" height=\"16\" fill=\"currentColor\" aria-hidden=\"true\">\n <path d=\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zm-3.97-3.03a.75.75 0 0 0-1.08.022L7.477 9.417 5.384 7.323a.75.75 0 0 0-1.06 1.061L6.97 11.03a.75.75 0 0 0 1.079-.02l3.992-4.99a.75.75 0 0 0-.01-1.05z\" />\n </svg>\n )\n}\n\nfunction WarningIcon() {\n return (\n <svg viewBox=\"0 0 16 16\" width=\"16\" height=\"16\" fill=\"currentColor\" aria-hidden=\"true\">\n <path d=\"M8.982 1.566a1.13 1.13 0 0 0-1.96 0L.165 13.233c-.457.778.091 1.767.98 1.767h13.713c.889 0 1.438-.99.98-1.767L8.982 1.566zM8 5c.535 0 .954.462.9.995l-.35 3.507a.552.552 0 0 1-1.1 0L7.1 5.995A.905.905 0 0 1 8 5zm.002 6a1 1 0 1 1 0 2 1 1 0 0 1 0-2z\" />\n </svg>\n )\n}\n\nfunction DangerIcon() {\n return (\n <svg viewBox=\"0 0 16 16\" width=\"16\" height=\"16\" fill=\"currentColor\" aria-hidden=\"true\">\n <path d=\"M16 8A8 8 0 1 1 0 8a8 8 0 0 1 16 0zM5.354 4.646a.5.5 0 1 0-.708.708L7.293 8l-2.647 2.646a.5.5 0 0 0 .708.708L8 8.707l2.646 2.647a.5.5 0 0 0 .708-.708L8.707 8l2.647-2.646a.5.5 0 0 0-.708-.708L8 7.293 5.354 4.646z\" />\n </svg>\n )\n}\n\nfunction CloseIcon() {\n return (\n <svg viewBox=\"0 0 16 16\" width=\"14\" height=\"14\" fill=\"currentColor\" aria-hidden=\"true\">\n <path d=\"M4.646 4.646a.5.5 0 0 1 .708 0L8 7.293l2.646-2.647a.5.5 0 0 1 .708.708L8.707 8l2.647 2.646a.5.5 0 0 1-.708.708L8 8.707l-2.646 2.647a.5.5 0 0 1-.708-.708L7.293 8 4.646 5.354a.5.5 0 0 1 0-.708z\" />\n </svg>\n )\n}\n\n/* ----------------------------------------------------------\n Variant styles\n ---------------------------------------------------------- */\n\nconst variantStyles: Record<ToastVariant, { container: string; icon: React.ReactNode | null }> = {\n neutral: {\n container: 'bg-ash text-paper border-[color-mix(in_srgb,var(--color-paper)_15%,transparent)]',\n icon: null,\n },\n success: {\n container: 'bg-ash text-paper border-[color-mix(in_srgb,var(--color-growth)_50%,transparent)]',\n icon: <SuccessIcon />,\n },\n warning: {\n container: 'bg-ash text-paper border-[color-mix(in_srgb,var(--color-caution)_50%,transparent)]',\n icon: <WarningIcon />,\n },\n danger: {\n container: 'bg-ash text-paper border-[color-mix(in_srgb,var(--color-signal)_50%,transparent)]',\n icon: <DangerIcon />,\n },\n}\n\nconst iconColors: Record<ToastVariant, string> = {\n neutral: 'text-smoke',\n success: 'text-[var(--color-growth)]',\n warning: 'text-[var(--color-caution)]',\n danger: 'text-signal',\n}\n\n/* ----------------------------------------------------------\n Toaster — renders portal + all active toasts\n Render once, near the root of your app.\n ---------------------------------------------------------- */\n\nexport interface ToasterProps {\n /** Pixel distance from the viewport edge. Default: 16. */\n offset?: number\n}\n\n/**\n * Renders the Radix Toast viewport and all active toasts.\n * Mount once near the app root (inside your layout or PageShell).\n *\n * @example\n * // In your root layout:\n * <Toaster />\n *\n * // Anywhere in your app:\n * import { toast } from '@boilerhaus-ui/boilerhaus-ui'\n * toast.success({ title: 'Saved', description: 'Project details updated.' })\n */\nexport function Toaster({ offset = 16 }: ToasterProps) {\n const { toasts, dismiss } = useToastStore()\n\n return (\n <ToastPrimitive.Provider swipeDirection=\"right\">\n {toasts.map((t) => {\n const v = variantStyles[t.variant ?? 'neutral']\n const iconCol = iconColors[t.variant ?? 'neutral']\n\n return (\n <ToastPrimitive.Root\n key={t.id}\n duration={t.duration === Infinity ? undefined : t.duration}\n onOpenChange={(open) => { if (!open) dismiss(t.id) }}\n className={cn(\n // Layout\n 'flex items-start gap-3',\n // Geometry\n 'w-[360px] max-w-[calc(100vw-32px)] rounded-sm border',\n // Spacing\n 'px-4 py-3',\n // Elevation\n 'shadow-[var(--shadow-lg)]',\n // Animation — slide in from right, fade out\n 'data-[state=open]:animate-[toast-in_200ms_var(--ease-enter)]',\n 'data-[state=closed]:animate-[toast-out_150ms_var(--ease-exit)]',\n 'data-[swipe=move]:translate-x-[var(--radix-toast-swipe-move-x)]',\n 'data-[swipe=cancel]:translate-x-0 data-[swipe=cancel]:transition-transform',\n 'data-[swipe=end]:animate-[toast-out_150ms_var(--ease-exit)]',\n v.container,\n )}\n >\n {/* Variant icon */}\n {v.icon && (\n <span className={cn('mt-0.5 shrink-0', iconCol)}>\n {v.icon}\n </span>\n )}\n\n {/* Body */}\n <div className=\"flex-1 min-w-0\">\n {t.title && (\n <ToastPrimitive.Title className=\"font-display font-bold text-sm uppercase tracking-[0.06em] leading-snug\">\n {t.title}\n </ToastPrimitive.Title>\n )}\n {t.description && (\n <ToastPrimitive.Description\n className={cn(\n 'text-sm text-smoke leading-relaxed',\n t.title && 'mt-0.5',\n )}\n >\n {t.description}\n </ToastPrimitive.Description>\n )}\n </div>\n\n {/* Close */}\n <ToastPrimitive.Close\n aria-label=\"Dismiss\"\n className={cn(\n 'shrink-0 mt-0.5 text-smoke opacity-60 hover:opacity-100',\n 'transition-opacity duration-fast ease-[var(--ease-standard)]',\n 'outline-none focus-visible:ring-[2px] focus-visible:ring-signal-alt rounded-sm',\n )}\n >\n <CloseIcon />\n </ToastPrimitive.Close>\n </ToastPrimitive.Root>\n )\n })}\n\n <ToastPrimitive.Viewport\n className=\"fixed bottom-0 right-0 flex flex-col gap-2 p-4 w-[392px] max-w-[100vw] z-50 outline-none\"\n style={{ '--offset': `${offset}px` } as React.CSSProperties}\n />\n </ToastPrimitive.Provider>\n )\n}\n","\"use client\";\n\n// src/roving-focus-group.tsx\nimport * as React from \"react\";\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\nimport { createCollection } from \"@radix-ui/react-collection\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { createContextScope } from \"@radix-ui/react-context\";\nimport { useId } from \"@radix-ui/react-id\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { useCallbackRef } from \"@radix-ui/react-use-callback-ref\";\nimport { useControllableState } from \"@radix-ui/react-use-controllable-state\";\nimport { useDirection } from \"@radix-ui/react-direction\";\nimport { jsx } from \"react/jsx-runtime\";\nvar ENTRY_FOCUS = \"rovingFocusGroup.onEntryFocus\";\nvar EVENT_OPTIONS = { bubbles: false, cancelable: true };\nvar GROUP_NAME = \"RovingFocusGroup\";\nvar [Collection, useCollection, createCollectionScope] = createCollection(GROUP_NAME);\nvar [createRovingFocusGroupContext, createRovingFocusGroupScope] = createContextScope(\n GROUP_NAME,\n [createCollectionScope]\n);\nvar [RovingFocusProvider, useRovingFocusContext] = createRovingFocusGroupContext(GROUP_NAME);\nvar RovingFocusGroup = React.forwardRef(\n (props, forwardedRef) => {\n return /* @__PURE__ */ jsx(Collection.Provider, { scope: props.__scopeRovingFocusGroup, children: /* @__PURE__ */ jsx(Collection.Slot, { scope: props.__scopeRovingFocusGroup, children: /* @__PURE__ */ jsx(RovingFocusGroupImpl, { ...props, ref: forwardedRef }) }) });\n }\n);\nRovingFocusGroup.displayName = GROUP_NAME;\nvar RovingFocusGroupImpl = React.forwardRef((props, forwardedRef) => {\n const {\n __scopeRovingFocusGroup,\n orientation,\n loop = false,\n dir,\n currentTabStopId: currentTabStopIdProp,\n defaultCurrentTabStopId,\n onCurrentTabStopIdChange,\n onEntryFocus,\n preventScrollOnEntryFocus = false,\n ...groupProps\n } = props;\n const ref = React.useRef(null);\n const composedRefs = useComposedRefs(forwardedRef, ref);\n const direction = useDirection(dir);\n const [currentTabStopId, setCurrentTabStopId] = useControllableState({\n prop: currentTabStopIdProp,\n defaultProp: defaultCurrentTabStopId ?? null,\n onChange: onCurrentTabStopIdChange,\n caller: GROUP_NAME\n });\n const [isTabbingBackOut, setIsTabbingBackOut] = React.useState(false);\n const handleEntryFocus = useCallbackRef(onEntryFocus);\n const getItems = useCollection(__scopeRovingFocusGroup);\n const isClickFocusRef = React.useRef(false);\n const [focusableItemsCount, setFocusableItemsCount] = React.useState(0);\n React.useEffect(() => {\n const node = ref.current;\n if (node) {\n node.addEventListener(ENTRY_FOCUS, handleEntryFocus);\n return () => node.removeEventListener(ENTRY_FOCUS, handleEntryFocus);\n }\n }, [handleEntryFocus]);\n return /* @__PURE__ */ jsx(\n RovingFocusProvider,\n {\n scope: __scopeRovingFocusGroup,\n orientation,\n dir: direction,\n loop,\n currentTabStopId,\n onItemFocus: React.useCallback(\n (tabStopId) => setCurrentTabStopId(tabStopId),\n [setCurrentTabStopId]\n ),\n onItemShiftTab: React.useCallback(() => setIsTabbingBackOut(true), []),\n onFocusableItemAdd: React.useCallback(\n () => setFocusableItemsCount((prevCount) => prevCount + 1),\n []\n ),\n onFocusableItemRemove: React.useCallback(\n () => setFocusableItemsCount((prevCount) => prevCount - 1),\n []\n ),\n children: /* @__PURE__ */ jsx(\n Primitive.div,\n {\n tabIndex: isTabbingBackOut || focusableItemsCount === 0 ? -1 : 0,\n \"data-orientation\": orientation,\n ...groupProps,\n ref: composedRefs,\n style: { outline: \"none\", ...props.style },\n onMouseDown: composeEventHandlers(props.onMouseDown, () => {\n isClickFocusRef.current = true;\n }),\n onFocus: composeEventHandlers(props.onFocus, (event) => {\n const isKeyboardFocus = !isClickFocusRef.current;\n if (event.target === event.currentTarget && isKeyboardFocus && !isTabbingBackOut) {\n const entryFocusEvent = new CustomEvent(ENTRY_FOCUS, EVENT_OPTIONS);\n event.currentTarget.dispatchEvent(entryFocusEvent);\n if (!entryFocusEvent.defaultPrevented) {\n const items = getItems().filter((item) => item.focusable);\n const activeItem = items.find((item) => item.active);\n const currentItem = items.find((item) => item.id === currentTabStopId);\n const candidateItems = [activeItem, currentItem, ...items].filter(\n Boolean\n );\n const candidateNodes = candidateItems.map((item) => item.ref.current);\n focusFirst(candidateNodes, preventScrollOnEntryFocus);\n }\n }\n isClickFocusRef.current = false;\n }),\n onBlur: composeEventHandlers(props.onBlur, () => setIsTabbingBackOut(false))\n }\n )\n }\n );\n});\nvar ITEM_NAME = \"RovingFocusGroupItem\";\nvar RovingFocusGroupItem = React.forwardRef(\n (props, forwardedRef) => {\n const {\n __scopeRovingFocusGroup,\n focusable = true,\n active = false,\n tabStopId,\n children,\n ...itemProps\n } = props;\n const autoId = useId();\n const id = tabStopId || autoId;\n const context = useRovingFocusContext(ITEM_NAME, __scopeRovingFocusGroup);\n const isCurrentTabStop = context.currentTabStopId === id;\n const getItems = useCollection(__scopeRovingFocusGroup);\n const { onFocusableItemAdd, onFocusableItemRemove, currentTabStopId } = context;\n React.useEffect(() => {\n if (focusable) {\n onFocusableItemAdd();\n return () => onFocusableItemRemove();\n }\n }, [focusable, onFocusableItemAdd, onFocusableItemRemove]);\n return /* @__PURE__ */ jsx(\n Collection.ItemSlot,\n {\n scope: __scopeRovingFocusGroup,\n id,\n focusable,\n active,\n children: /* @__PURE__ */ jsx(\n Primitive.span,\n {\n tabIndex: isCurrentTabStop ? 0 : -1,\n \"data-orientation\": context.orientation,\n ...itemProps,\n ref: forwardedRef,\n onMouseDown: composeEventHandlers(props.onMouseDown, (event) => {\n if (!focusable) event.preventDefault();\n else context.onItemFocus(id);\n }),\n onFocus: composeEventHandlers(props.onFocus, () => context.onItemFocus(id)),\n onKeyDown: composeEventHandlers(props.onKeyDown, (event) => {\n if (event.key === \"Tab\" && event.shiftKey) {\n context.onItemShiftTab();\n return;\n }\n if (event.target !== event.currentTarget) return;\n const focusIntent = getFocusIntent(event, context.orientation, context.dir);\n if (focusIntent !== void 0) {\n if (event.metaKey || event.ctrlKey || event.altKey || event.shiftKey) return;\n event.preventDefault();\n const items = getItems().filter((item) => item.focusable);\n let candidateNodes = items.map((item) => item.ref.current);\n if (focusIntent === \"last\") candidateNodes.reverse();\n else if (focusIntent === \"prev\" || focusIntent === \"next\") {\n if (focusIntent === \"prev\") candidateNodes.reverse();\n const currentIndex = candidateNodes.indexOf(event.currentTarget);\n candidateNodes = context.loop ? wrapArray(candidateNodes, currentIndex + 1) : candidateNodes.slice(currentIndex + 1);\n }\n setTimeout(() => focusFirst(candidateNodes));\n }\n }),\n children: typeof children === \"function\" ? children({ isCurrentTabStop, hasTabStop: currentTabStopId != null }) : children\n }\n )\n }\n );\n }\n);\nRovingFocusGroupItem.displayName = ITEM_NAME;\nvar MAP_KEY_TO_FOCUS_INTENT = {\n ArrowLeft: \"prev\",\n ArrowUp: \"prev\",\n ArrowRight: \"next\",\n ArrowDown: \"next\",\n PageUp: \"first\",\n Home: \"first\",\n PageDown: \"last\",\n End: \"last\"\n};\nfunction getDirectionAwareKey(key, dir) {\n if (dir !== \"rtl\") return key;\n return key === \"ArrowLeft\" ? \"ArrowRight\" : key === \"ArrowRight\" ? \"ArrowLeft\" : key;\n}\nfunction getFocusIntent(event, orientation, dir) {\n const key = getDirectionAwareKey(event.key, dir);\n if (orientation === \"vertical\" && [\"ArrowLeft\", \"ArrowRight\"].includes(key)) return void 0;\n if (orientation === \"horizontal\" && [\"ArrowUp\", \"ArrowDown\"].includes(key)) return void 0;\n return MAP_KEY_TO_FOCUS_INTENT[key];\n}\nfunction focusFirst(candidates, preventScroll = false) {\n const PREVIOUSLY_FOCUSED_ELEMENT = document.activeElement;\n for (const candidate of candidates) {\n if (candidate === PREVIOUSLY_FOCUSED_ELEMENT) return;\n candidate.focus({ preventScroll });\n if (document.activeElement !== PREVIOUSLY_FOCUSED_ELEMENT) return;\n }\n}\nfunction wrapArray(array, startIndex) {\n return array.map((_, index) => array[(startIndex + index) % array.length]);\n}\nvar Root = RovingFocusGroup;\nvar Item = RovingFocusGroupItem;\nexport {\n Item,\n Root,\n RovingFocusGroup,\n RovingFocusGroupItem,\n createRovingFocusGroupScope\n};\n//# sourceMappingURL=index.mjs.map\n","\"use client\";\n\n// src/tabs.tsx\nimport * as React from \"react\";\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\nimport { createContextScope } from \"@radix-ui/react-context\";\nimport { createRovingFocusGroupScope } from \"@radix-ui/react-roving-focus\";\nimport { Presence } from \"@radix-ui/react-presence\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport * as RovingFocusGroup from \"@radix-ui/react-roving-focus\";\nimport { useDirection } from \"@radix-ui/react-direction\";\nimport { useControllableState } from \"@radix-ui/react-use-controllable-state\";\nimport { useId } from \"@radix-ui/react-id\";\nimport { jsx } from \"react/jsx-runtime\";\nvar TABS_NAME = \"Tabs\";\nvar [createTabsContext, createTabsScope] = createContextScope(TABS_NAME, [\n createRovingFocusGroupScope\n]);\nvar useRovingFocusGroupScope = createRovingFocusGroupScope();\nvar [TabsProvider, useTabsContext] = createTabsContext(TABS_NAME);\nvar Tabs = React.forwardRef(\n (props, forwardedRef) => {\n const {\n __scopeTabs,\n value: valueProp,\n onValueChange,\n defaultValue,\n orientation = \"horizontal\",\n dir,\n activationMode = \"automatic\",\n ...tabsProps\n } = props;\n const direction = useDirection(dir);\n const [value, setValue] = useControllableState({\n prop: valueProp,\n onChange: onValueChange,\n defaultProp: defaultValue ?? \"\",\n caller: TABS_NAME\n });\n return /* @__PURE__ */ jsx(\n TabsProvider,\n {\n scope: __scopeTabs,\n baseId: useId(),\n value,\n onValueChange: setValue,\n orientation,\n dir: direction,\n activationMode,\n children: /* @__PURE__ */ jsx(\n Primitive.div,\n {\n dir: direction,\n \"data-orientation\": orientation,\n ...tabsProps,\n ref: forwardedRef\n }\n )\n }\n );\n }\n);\nTabs.displayName = TABS_NAME;\nvar TAB_LIST_NAME = \"TabsList\";\nvar TabsList = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeTabs, loop = true, ...listProps } = props;\n const context = useTabsContext(TAB_LIST_NAME, __scopeTabs);\n const rovingFocusGroupScope = useRovingFocusGroupScope(__scopeTabs);\n return /* @__PURE__ */ jsx(\n RovingFocusGroup.Root,\n {\n asChild: true,\n ...rovingFocusGroupScope,\n orientation: context.orientation,\n dir: context.dir,\n loop,\n children: /* @__PURE__ */ jsx(\n Primitive.div,\n {\n role: \"tablist\",\n \"aria-orientation\": context.orientation,\n ...listProps,\n ref: forwardedRef\n }\n )\n }\n );\n }\n);\nTabsList.displayName = TAB_LIST_NAME;\nvar TRIGGER_NAME = \"TabsTrigger\";\nvar TabsTrigger = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeTabs, value, disabled = false, ...triggerProps } = props;\n const context = useTabsContext(TRIGGER_NAME, __scopeTabs);\n const rovingFocusGroupScope = useRovingFocusGroupScope(__scopeTabs);\n const triggerId = makeTriggerId(context.baseId, value);\n const contentId = makeContentId(context.baseId, value);\n const isSelected = value === context.value;\n return /* @__PURE__ */ jsx(\n RovingFocusGroup.Item,\n {\n asChild: true,\n ...rovingFocusGroupScope,\n focusable: !disabled,\n active: isSelected,\n children: /* @__PURE__ */ jsx(\n Primitive.button,\n {\n type: \"button\",\n role: \"tab\",\n \"aria-selected\": isSelected,\n \"aria-controls\": contentId,\n \"data-state\": isSelected ? \"active\" : \"inactive\",\n \"data-disabled\": disabled ? \"\" : void 0,\n disabled,\n id: triggerId,\n ...triggerProps,\n ref: forwardedRef,\n onMouseDown: composeEventHandlers(props.onMouseDown, (event) => {\n if (!disabled && event.button === 0 && event.ctrlKey === false) {\n context.onValueChange(value);\n } else {\n event.preventDefault();\n }\n }),\n onKeyDown: composeEventHandlers(props.onKeyDown, (event) => {\n if ([\" \", \"Enter\"].includes(event.key)) context.onValueChange(value);\n }),\n onFocus: composeEventHandlers(props.onFocus, () => {\n const isAutomaticActivation = context.activationMode !== \"manual\";\n if (!isSelected && !disabled && isAutomaticActivation) {\n context.onValueChange(value);\n }\n })\n }\n )\n }\n );\n }\n);\nTabsTrigger.displayName = TRIGGER_NAME;\nvar CONTENT_NAME = \"TabsContent\";\nvar TabsContent = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeTabs, value, forceMount, children, ...contentProps } = props;\n const context = useTabsContext(CONTENT_NAME, __scopeTabs);\n const triggerId = makeTriggerId(context.baseId, value);\n const contentId = makeContentId(context.baseId, value);\n const isSelected = value === context.value;\n const isMountAnimationPreventedRef = React.useRef(isSelected);\n React.useEffect(() => {\n const rAF = requestAnimationFrame(() => isMountAnimationPreventedRef.current = false);\n return () => cancelAnimationFrame(rAF);\n }, []);\n return /* @__PURE__ */ jsx(Presence, { present: forceMount || isSelected, children: ({ present }) => /* @__PURE__ */ jsx(\n Primitive.div,\n {\n \"data-state\": isSelected ? \"active\" : \"inactive\",\n \"data-orientation\": context.orientation,\n role: \"tabpanel\",\n \"aria-labelledby\": triggerId,\n hidden: !present,\n id: contentId,\n tabIndex: 0,\n ...contentProps,\n ref: forwardedRef,\n style: {\n ...props.style,\n animationDuration: isMountAnimationPreventedRef.current ? \"0s\" : void 0\n },\n children: present && children\n }\n ) });\n }\n);\nTabsContent.displayName = CONTENT_NAME;\nfunction makeTriggerId(baseId, value) {\n return `${baseId}-trigger-${value}`;\n}\nfunction makeContentId(baseId, value) {\n return `${baseId}-content-${value}`;\n}\nvar Root2 = Tabs;\nvar List = TabsList;\nvar Trigger = TabsTrigger;\nvar Content = TabsContent;\nexport {\n Content,\n List,\n Root2 as Root,\n Tabs,\n TabsContent,\n TabsList,\n TabsTrigger,\n Trigger,\n createTabsScope\n};\n//# sourceMappingURL=index.mjs.map\n","import * as TabsPrimitive from '@radix-ui/react-tabs'\nimport { cn } from '../../lib/cn'\n\n/* ----------------------------------------------------------\n Re-export primitives that need no styling\n ---------------------------------------------------------- */\n\n/** Controls the active tab. Wrap all Tabs parts with this. */\nexport const Tabs = TabsPrimitive.Root\n\n/** Associates a panel with a trigger via matching `value` props. */\nexport const TabsContent = TabsPrimitive.Content\n\n/* ----------------------------------------------------------\n TabsList\n ---------------------------------------------------------- */\n\nexport interface TabsListProps\n extends React.ComponentPropsWithoutRef<typeof TabsPrimitive.List> {}\n\n/**\n * Container for tab trigger buttons.\n * Renders as an underlined bar — Bauhaus horizontal rule aesthetic.\n *\n * @example\n * <Tabs defaultValue=\"budget\">\n * <TabsList>\n * <TabsTrigger value=\"budget\">Budget</TabsTrigger>\n * <TabsTrigger value=\"schedule\">Schedule</TabsTrigger>\n * </TabsList>\n * <TabsContent value=\"budget\">…</TabsContent>\n * <TabsContent value=\"schedule\">…</TabsContent>\n * </Tabs>\n */\nexport function TabsList({ className, ...props }: TabsListProps) {\n return (\n <TabsPrimitive.List\n className={cn(\n // Layout — horizontal row\n 'flex items-end gap-0',\n // Bottom border — the rule the active tab \"sits on\"\n 'border-b border-rule',\n className,\n )}\n {...props}\n />\n )\n}\n\n\n/* ----------------------------------------------------------\n TabsTrigger\n ---------------------------------------------------------- */\n\nexport interface TabsTriggerProps\n extends React.ComponentPropsWithoutRef<typeof TabsPrimitive.Trigger> {}\n\n/**\n * Individual tab button. Active state: Bauhaus red bottom border.\n */\nexport function TabsTrigger({ className, ...props }: TabsTriggerProps) {\n return (\n <TabsPrimitive.Trigger\n className={cn(\n // Layout\n 'relative flex items-center gap-1.5',\n // Typography\n 'font-display font-bold text-xs uppercase tracking-widest',\n // Spacing — bottom padding creates space for the active indicator\n 'px-4 pb-3 pt-2',\n // Color — inactive\n 'text-smoke',\n // Active indicator — 2px red bottom border\n 'border-b-2 border-transparent -mb-px',\n // Active state\n 'data-[state=active]:text-void data-[state=active]:border-b-signal',\n // Hover — inactive tabs only\n 'data-[state=inactive]:hover:text-void',\n // Focus\n 'outline-none focus-visible:ring-2 focus-visible:ring-signal-alt focus-visible:ring-inset rounded-t-sm',\n // Disabled\n 'disabled:opacity-[0.38] disabled:cursor-not-allowed disabled:pointer-events-none',\n // Transition\n 'transition-colors duration-fast ease-(--ease-standard)',\n className,\n )}\n {...props}\n />\n )\n}\n","// src/slot.tsx\nimport * as React from \"react\";\nimport { composeRefs } from \"@radix-ui/react-compose-refs\";\nimport { Fragment as Fragment2, jsx } from \"react/jsx-runtime\";\n// @__NO_SIDE_EFFECTS__\nfunction createSlot(ownerName) {\n const SlotClone = /* @__PURE__ */ createSlotClone(ownerName);\n const Slot2 = React.forwardRef((props, forwardedRef) => {\n const { children, ...slotProps } = props;\n const childrenArray = React.Children.toArray(children);\n const slottable = childrenArray.find(isSlottable);\n if (slottable) {\n const newElement = slottable.props.children;\n const newChildren = childrenArray.map((child) => {\n if (child === slottable) {\n if (React.Children.count(newElement) > 1) return React.Children.only(null);\n return React.isValidElement(newElement) ? newElement.props.children : null;\n } else {\n return child;\n }\n });\n return /* @__PURE__ */ jsx(SlotClone, { ...slotProps, ref: forwardedRef, children: React.isValidElement(newElement) ? React.cloneElement(newElement, void 0, newChildren) : null });\n }\n return /* @__PURE__ */ jsx(SlotClone, { ...slotProps, ref: forwardedRef, children });\n });\n Slot2.displayName = `${ownerName}.Slot`;\n return Slot2;\n}\nvar Slot = /* @__PURE__ */ createSlot(\"Slot\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlotClone(ownerName) {\n const SlotClone = React.forwardRef((props, forwardedRef) => {\n const { children, ...slotProps } = props;\n if (React.isValidElement(children)) {\n const childrenRef = getElementRef(children);\n const props2 = mergeProps(slotProps, children.props);\n if (children.type !== React.Fragment) {\n props2.ref = forwardedRef ? composeRefs(forwardedRef, childrenRef) : childrenRef;\n }\n return React.cloneElement(children, props2);\n }\n return React.Children.count(children) > 1 ? React.Children.only(null) : null;\n });\n SlotClone.displayName = `${ownerName}.SlotClone`;\n return SlotClone;\n}\nvar SLOTTABLE_IDENTIFIER = Symbol(\"radix.slottable\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlottable(ownerName) {\n const Slottable2 = ({ children }) => {\n return /* @__PURE__ */ jsx(Fragment2, { children });\n };\n Slottable2.displayName = `${ownerName}.Slottable`;\n Slottable2.__radixId = SLOTTABLE_IDENTIFIER;\n return Slottable2;\n}\nvar Slottable = /* @__PURE__ */ createSlottable(\"Slottable\");\nfunction isSlottable(child) {\n return React.isValidElement(child) && typeof child.type === \"function\" && \"__radixId\" in child.type && child.type.__radixId === SLOTTABLE_IDENTIFIER;\n}\nfunction mergeProps(slotProps, childProps) {\n const overrideProps = { ...childProps };\n for (const propName in childProps) {\n const slotPropValue = slotProps[propName];\n const childPropValue = childProps[propName];\n const isHandler = /^on[A-Z]/.test(propName);\n if (isHandler) {\n if (slotPropValue && childPropValue) {\n overrideProps[propName] = (...args) => {\n const result = childPropValue(...args);\n slotPropValue(...args);\n return result;\n };\n } else if (slotPropValue) {\n overrideProps[propName] = slotPropValue;\n }\n } else if (propName === \"style\") {\n overrideProps[propName] = { ...slotPropValue, ...childPropValue };\n } else if (propName === \"className\") {\n overrideProps[propName] = [slotPropValue, childPropValue].filter(Boolean).join(\" \");\n }\n }\n return { ...slotProps, ...overrideProps };\n}\nfunction getElementRef(element) {\n let getter = Object.getOwnPropertyDescriptor(element.props, \"ref\")?.get;\n let mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.ref;\n }\n getter = Object.getOwnPropertyDescriptor(element, \"ref\")?.get;\n mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.props.ref;\n }\n return element.props.ref || element.ref;\n}\nexport {\n Slot as Root,\n Slot,\n Slottable,\n createSlot,\n createSlottable\n};\n//# sourceMappingURL=index.mjs.map\n","\"use client\";\n\n// src/menu.tsx\nimport * as React from \"react\";\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\nimport { createCollection } from \"@radix-ui/react-collection\";\nimport { useComposedRefs, composeRefs } from \"@radix-ui/react-compose-refs\";\nimport { createContextScope } from \"@radix-ui/react-context\";\nimport { useDirection } from \"@radix-ui/react-direction\";\nimport { DismissableLayer } from \"@radix-ui/react-dismissable-layer\";\nimport { useFocusGuards } from \"@radix-ui/react-focus-guards\";\nimport { FocusScope } from \"@radix-ui/react-focus-scope\";\nimport { useId } from \"@radix-ui/react-id\";\nimport * as PopperPrimitive from \"@radix-ui/react-popper\";\nimport { createPopperScope } from \"@radix-ui/react-popper\";\nimport { Portal as PortalPrimitive } from \"@radix-ui/react-portal\";\nimport { Presence } from \"@radix-ui/react-presence\";\nimport { Primitive, dispatchDiscreteCustomEvent } from \"@radix-ui/react-primitive\";\nimport * as RovingFocusGroup from \"@radix-ui/react-roving-focus\";\nimport { createRovingFocusGroupScope } from \"@radix-ui/react-roving-focus\";\nimport { createSlot } from \"@radix-ui/react-slot\";\nimport { useCallbackRef } from \"@radix-ui/react-use-callback-ref\";\nimport { hideOthers } from \"aria-hidden\";\nimport { RemoveScroll } from \"react-remove-scroll\";\nimport { jsx } from \"react/jsx-runtime\";\nvar SELECTION_KEYS = [\"Enter\", \" \"];\nvar FIRST_KEYS = [\"ArrowDown\", \"PageUp\", \"Home\"];\nvar LAST_KEYS = [\"ArrowUp\", \"PageDown\", \"End\"];\nvar FIRST_LAST_KEYS = [...FIRST_KEYS, ...LAST_KEYS];\nvar SUB_OPEN_KEYS = {\n ltr: [...SELECTION_KEYS, \"ArrowRight\"],\n rtl: [...SELECTION_KEYS, \"ArrowLeft\"]\n};\nvar SUB_CLOSE_KEYS = {\n ltr: [\"ArrowLeft\"],\n rtl: [\"ArrowRight\"]\n};\nvar MENU_NAME = \"Menu\";\nvar [Collection, useCollection, createCollectionScope] = createCollection(MENU_NAME);\nvar [createMenuContext, createMenuScope] = createContextScope(MENU_NAME, [\n createCollectionScope,\n createPopperScope,\n createRovingFocusGroupScope\n]);\nvar usePopperScope = createPopperScope();\nvar useRovingFocusGroupScope = createRovingFocusGroupScope();\nvar [MenuProvider, useMenuContext] = createMenuContext(MENU_NAME);\nvar [MenuRootProvider, useMenuRootContext] = createMenuContext(MENU_NAME);\nvar Menu = (props) => {\n const { __scopeMenu, open = false, children, dir, onOpenChange, modal = true } = props;\n const popperScope = usePopperScope(__scopeMenu);\n const [content, setContent] = React.useState(null);\n const isUsingKeyboardRef = React.useRef(false);\n const handleOpenChange = useCallbackRef(onOpenChange);\n const direction = useDirection(dir);\n React.useEffect(() => {\n const handleKeyDown = () => {\n isUsingKeyboardRef.current = true;\n document.addEventListener(\"pointerdown\", handlePointer, { capture: true, once: true });\n document.addEventListener(\"pointermove\", handlePointer, { capture: true, once: true });\n };\n const handlePointer = () => isUsingKeyboardRef.current = false;\n document.addEventListener(\"keydown\", handleKeyDown, { capture: true });\n return () => {\n document.removeEventListener(\"keydown\", handleKeyDown, { capture: true });\n document.removeEventListener(\"pointerdown\", handlePointer, { capture: true });\n document.removeEventListener(\"pointermove\", handlePointer, { capture: true });\n };\n }, []);\n return /* @__PURE__ */ jsx(PopperPrimitive.Root, { ...popperScope, children: /* @__PURE__ */ jsx(\n MenuProvider,\n {\n scope: __scopeMenu,\n open,\n onOpenChange: handleOpenChange,\n content,\n onContentChange: setContent,\n children: /* @__PURE__ */ jsx(\n MenuRootProvider,\n {\n scope: __scopeMenu,\n onClose: React.useCallback(() => handleOpenChange(false), [handleOpenChange]),\n isUsingKeyboardRef,\n dir: direction,\n modal,\n children\n }\n )\n }\n ) });\n};\nMenu.displayName = MENU_NAME;\nvar ANCHOR_NAME = \"MenuAnchor\";\nvar MenuAnchor = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeMenu, ...anchorProps } = props;\n const popperScope = usePopperScope(__scopeMenu);\n return /* @__PURE__ */ jsx(PopperPrimitive.Anchor, { ...popperScope, ...anchorProps, ref: forwardedRef });\n }\n);\nMenuAnchor.displayName = ANCHOR_NAME;\nvar PORTAL_NAME = \"MenuPortal\";\nvar [PortalProvider, usePortalContext] = createMenuContext(PORTAL_NAME, {\n forceMount: void 0\n});\nvar MenuPortal = (props) => {\n const { __scopeMenu, forceMount, children, container } = props;\n const context = useMenuContext(PORTAL_NAME, __scopeMenu);\n return /* @__PURE__ */ jsx(PortalProvider, { scope: __scopeMenu, forceMount, children: /* @__PURE__ */ jsx(Presence, { present: forceMount || context.open, children: /* @__PURE__ */ jsx(PortalPrimitive, { asChild: true, container, children }) }) });\n};\nMenuPortal.displayName = PORTAL_NAME;\nvar CONTENT_NAME = \"MenuContent\";\nvar [MenuContentProvider, useMenuContentContext] = createMenuContext(CONTENT_NAME);\nvar MenuContent = React.forwardRef(\n (props, forwardedRef) => {\n const portalContext = usePortalContext(CONTENT_NAME, props.__scopeMenu);\n const { forceMount = portalContext.forceMount, ...contentProps } = props;\n const context = useMenuContext(CONTENT_NAME, props.__scopeMenu);\n const rootContext = useMenuRootContext(CONTENT_NAME, props.__scopeMenu);\n return /* @__PURE__ */ jsx(Collection.Provider, { scope: props.__scopeMenu, children: /* @__PURE__ */ jsx(Presence, { present: forceMount || context.open, children: /* @__PURE__ */ jsx(Collection.Slot, { scope: props.__scopeMenu, children: rootContext.modal ? /* @__PURE__ */ jsx(MenuRootContentModal, { ...contentProps, ref: forwardedRef }) : /* @__PURE__ */ jsx(MenuRootContentNonModal, { ...contentProps, ref: forwardedRef }) }) }) });\n }\n);\nvar MenuRootContentModal = React.forwardRef(\n (props, forwardedRef) => {\n const context = useMenuContext(CONTENT_NAME, props.__scopeMenu);\n const ref = React.useRef(null);\n const composedRefs = useComposedRefs(forwardedRef, ref);\n React.useEffect(() => {\n const content = ref.current;\n if (content) return hideOthers(content);\n }, []);\n return /* @__PURE__ */ jsx(\n MenuContentImpl,\n {\n ...props,\n ref: composedRefs,\n trapFocus: context.open,\n disableOutsidePointerEvents: context.open,\n disableOutsideScroll: true,\n onFocusOutside: composeEventHandlers(\n props.onFocusOutside,\n (event) => event.preventDefault(),\n { checkForDefaultPrevented: false }\n ),\n onDismiss: () => context.onOpenChange(false)\n }\n );\n }\n);\nvar MenuRootContentNonModal = React.forwardRef((props, forwardedRef) => {\n const context = useMenuContext(CONTENT_NAME, props.__scopeMenu);\n return /* @__PURE__ */ jsx(\n MenuContentImpl,\n {\n ...props,\n ref: forwardedRef,\n trapFocus: false,\n disableOutsidePointerEvents: false,\n disableOutsideScroll: false,\n onDismiss: () => context.onOpenChange(false)\n }\n );\n});\nvar Slot = createSlot(\"MenuContent.ScrollLock\");\nvar MenuContentImpl = React.forwardRef(\n (props, forwardedRef) => {\n const {\n __scopeMenu,\n loop = false,\n trapFocus,\n onOpenAutoFocus,\n onCloseAutoFocus,\n disableOutsidePointerEvents,\n onEntryFocus,\n onEscapeKeyDown,\n onPointerDownOutside,\n onFocusOutside,\n onInteractOutside,\n onDismiss,\n disableOutsideScroll,\n ...contentProps\n } = props;\n const context = useMenuContext(CONTENT_NAME, __scopeMenu);\n const rootContext = useMenuRootContext(CONTENT_NAME, __scopeMenu);\n const popperScope = usePopperScope(__scopeMenu);\n const rovingFocusGroupScope = useRovingFocusGroupScope(__scopeMenu);\n const getItems = useCollection(__scopeMenu);\n const [currentItemId, setCurrentItemId] = React.useState(null);\n const contentRef = React.useRef(null);\n const composedRefs = useComposedRefs(forwardedRef, contentRef, context.onContentChange);\n const timerRef = React.useRef(0);\n const searchRef = React.useRef(\"\");\n const pointerGraceTimerRef = React.useRef(0);\n const pointerGraceIntentRef = React.useRef(null);\n const pointerDirRef = React.useRef(\"right\");\n const lastPointerXRef = React.useRef(0);\n const ScrollLockWrapper = disableOutsideScroll ? RemoveScroll : React.Fragment;\n const scrollLockWrapperProps = disableOutsideScroll ? { as: Slot, allowPinchZoom: true } : void 0;\n const handleTypeaheadSearch = (key) => {\n const search = searchRef.current + key;\n const items = getItems().filter((item) => !item.disabled);\n const currentItem = document.activeElement;\n const currentMatch = items.find((item) => item.ref.current === currentItem)?.textValue;\n const values = items.map((item) => item.textValue);\n const nextMatch = getNextMatch(values, search, currentMatch);\n const newItem = items.find((item) => item.textValue === nextMatch)?.ref.current;\n (function updateSearch(value) {\n searchRef.current = value;\n window.clearTimeout(timerRef.current);\n if (value !== \"\") timerRef.current = window.setTimeout(() => updateSearch(\"\"), 1e3);\n })(search);\n if (newItem) {\n setTimeout(() => newItem.focus());\n }\n };\n React.useEffect(() => {\n return () => window.clearTimeout(timerRef.current);\n }, []);\n useFocusGuards();\n const isPointerMovingToSubmenu = React.useCallback((event) => {\n const isMovingTowards = pointerDirRef.current === pointerGraceIntentRef.current?.side;\n return isMovingTowards && isPointerInGraceArea(event, pointerGraceIntentRef.current?.area);\n }, []);\n return /* @__PURE__ */ jsx(\n MenuContentProvider,\n {\n scope: __scopeMenu,\n searchRef,\n onItemEnter: React.useCallback(\n (event) => {\n if (isPointerMovingToSubmenu(event)) event.preventDefault();\n },\n [isPointerMovingToSubmenu]\n ),\n onItemLeave: React.useCallback(\n (event) => {\n if (isPointerMovingToSubmenu(event)) return;\n contentRef.current?.focus();\n setCurrentItemId(null);\n },\n [isPointerMovingToSubmenu]\n ),\n onTriggerLeave: React.useCallback(\n (event) => {\n if (isPointerMovingToSubmenu(event)) event.preventDefault();\n },\n [isPointerMovingToSubmenu]\n ),\n pointerGraceTimerRef,\n onPointerGraceIntentChange: React.useCallback((intent) => {\n pointerGraceIntentRef.current = intent;\n }, []),\n children: /* @__PURE__ */ jsx(ScrollLockWrapper, { ...scrollLockWrapperProps, children: /* @__PURE__ */ jsx(\n FocusScope,\n {\n asChild: true,\n trapped: trapFocus,\n onMountAutoFocus: composeEventHandlers(onOpenAutoFocus, (event) => {\n event.preventDefault();\n contentRef.current?.focus({ preventScroll: true });\n }),\n onUnmountAutoFocus: onCloseAutoFocus,\n children: /* @__PURE__ */ jsx(\n DismissableLayer,\n {\n asChild: true,\n disableOutsidePointerEvents,\n onEscapeKeyDown,\n onPointerDownOutside,\n onFocusOutside,\n onInteractOutside,\n onDismiss,\n children: /* @__PURE__ */ jsx(\n RovingFocusGroup.Root,\n {\n asChild: true,\n ...rovingFocusGroupScope,\n dir: rootContext.dir,\n orientation: \"vertical\",\n loop,\n currentTabStopId: currentItemId,\n onCurrentTabStopIdChange: setCurrentItemId,\n onEntryFocus: composeEventHandlers(onEntryFocus, (event) => {\n if (!rootContext.isUsingKeyboardRef.current) event.preventDefault();\n }),\n preventScrollOnEntryFocus: true,\n children: /* @__PURE__ */ jsx(\n PopperPrimitive.Content,\n {\n role: \"menu\",\n \"aria-orientation\": \"vertical\",\n \"data-state\": getOpenState(context.open),\n \"data-radix-menu-content\": \"\",\n dir: rootContext.dir,\n ...popperScope,\n ...contentProps,\n ref: composedRefs,\n style: { outline: \"none\", ...contentProps.style },\n onKeyDown: composeEventHandlers(contentProps.onKeyDown, (event) => {\n const target = event.target;\n const isKeyDownInside = target.closest(\"[data-radix-menu-content]\") === event.currentTarget;\n const isModifierKey = event.ctrlKey || event.altKey || event.metaKey;\n const isCharacterKey = event.key.length === 1;\n if (isKeyDownInside) {\n if (event.key === \"Tab\") event.preventDefault();\n if (!isModifierKey && isCharacterKey) handleTypeaheadSearch(event.key);\n }\n const content = contentRef.current;\n if (event.target !== content) return;\n if (!FIRST_LAST_KEYS.includes(event.key)) return;\n event.preventDefault();\n const items = getItems().filter((item) => !item.disabled);\n const candidateNodes = items.map((item) => item.ref.current);\n if (LAST_KEYS.includes(event.key)) candidateNodes.reverse();\n focusFirst(candidateNodes);\n }),\n onBlur: composeEventHandlers(props.onBlur, (event) => {\n if (!event.currentTarget.contains(event.target)) {\n window.clearTimeout(timerRef.current);\n searchRef.current = \"\";\n }\n }),\n onPointerMove: composeEventHandlers(\n props.onPointerMove,\n whenMouse((event) => {\n const target = event.target;\n const pointerXHasChanged = lastPointerXRef.current !== event.clientX;\n if (event.currentTarget.contains(target) && pointerXHasChanged) {\n const newDir = event.clientX > lastPointerXRef.current ? \"right\" : \"left\";\n pointerDirRef.current = newDir;\n lastPointerXRef.current = event.clientX;\n }\n })\n )\n }\n )\n }\n )\n }\n )\n }\n ) })\n }\n );\n }\n);\nMenuContent.displayName = CONTENT_NAME;\nvar GROUP_NAME = \"MenuGroup\";\nvar MenuGroup = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeMenu, ...groupProps } = props;\n return /* @__PURE__ */ jsx(Primitive.div, { role: \"group\", ...groupProps, ref: forwardedRef });\n }\n);\nMenuGroup.displayName = GROUP_NAME;\nvar LABEL_NAME = \"MenuLabel\";\nvar MenuLabel = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeMenu, ...labelProps } = props;\n return /* @__PURE__ */ jsx(Primitive.div, { ...labelProps, ref: forwardedRef });\n }\n);\nMenuLabel.displayName = LABEL_NAME;\nvar ITEM_NAME = \"MenuItem\";\nvar ITEM_SELECT = \"menu.itemSelect\";\nvar MenuItem = React.forwardRef(\n (props, forwardedRef) => {\n const { disabled = false, onSelect, ...itemProps } = props;\n const ref = React.useRef(null);\n const rootContext = useMenuRootContext(ITEM_NAME, props.__scopeMenu);\n const contentContext = useMenuContentContext(ITEM_NAME, props.__scopeMenu);\n const composedRefs = useComposedRefs(forwardedRef, ref);\n const isPointerDownRef = React.useRef(false);\n const handleSelect = () => {\n const menuItem = ref.current;\n if (!disabled && menuItem) {\n const itemSelectEvent = new CustomEvent(ITEM_SELECT, { bubbles: true, cancelable: true });\n menuItem.addEventListener(ITEM_SELECT, (event) => onSelect?.(event), { once: true });\n dispatchDiscreteCustomEvent(menuItem, itemSelectEvent);\n if (itemSelectEvent.defaultPrevented) {\n isPointerDownRef.current = false;\n } else {\n rootContext.onClose();\n }\n }\n };\n return /* @__PURE__ */ jsx(\n MenuItemImpl,\n {\n ...itemProps,\n ref: composedRefs,\n disabled,\n onClick: composeEventHandlers(props.onClick, handleSelect),\n onPointerDown: (event) => {\n props.onPointerDown?.(event);\n isPointerDownRef.current = true;\n },\n onPointerUp: composeEventHandlers(props.onPointerUp, (event) => {\n if (!isPointerDownRef.current) event.currentTarget?.click();\n }),\n onKeyDown: composeEventHandlers(props.onKeyDown, (event) => {\n const isTypingAhead = contentContext.searchRef.current !== \"\";\n if (disabled || isTypingAhead && event.key === \" \") return;\n if (SELECTION_KEYS.includes(event.key)) {\n event.currentTarget.click();\n event.preventDefault();\n }\n })\n }\n );\n }\n);\nMenuItem.displayName = ITEM_NAME;\nvar MenuItemImpl = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeMenu, disabled = false, textValue, ...itemProps } = props;\n const contentContext = useMenuContentContext(ITEM_NAME, __scopeMenu);\n const rovingFocusGroupScope = useRovingFocusGroupScope(__scopeMenu);\n const ref = React.useRef(null);\n const composedRefs = useComposedRefs(forwardedRef, ref);\n const [isFocused, setIsFocused] = React.useState(false);\n const [textContent, setTextContent] = React.useState(\"\");\n React.useEffect(() => {\n const menuItem = ref.current;\n if (menuItem) {\n setTextContent((menuItem.textContent ?? \"\").trim());\n }\n }, [itemProps.children]);\n return /* @__PURE__ */ jsx(\n Collection.ItemSlot,\n {\n scope: __scopeMenu,\n disabled,\n textValue: textValue ?? textContent,\n children: /* @__PURE__ */ jsx(RovingFocusGroup.Item, { asChild: true, ...rovingFocusGroupScope, focusable: !disabled, children: /* @__PURE__ */ jsx(\n Primitive.div,\n {\n role: \"menuitem\",\n \"data-highlighted\": isFocused ? \"\" : void 0,\n \"aria-disabled\": disabled || void 0,\n \"data-disabled\": disabled ? \"\" : void 0,\n ...itemProps,\n ref: composedRefs,\n onPointerMove: composeEventHandlers(\n props.onPointerMove,\n whenMouse((event) => {\n if (disabled) {\n contentContext.onItemLeave(event);\n } else {\n contentContext.onItemEnter(event);\n if (!event.defaultPrevented) {\n const item = event.currentTarget;\n item.focus({ preventScroll: true });\n }\n }\n })\n ),\n onPointerLeave: composeEventHandlers(\n props.onPointerLeave,\n whenMouse((event) => contentContext.onItemLeave(event))\n ),\n onFocus: composeEventHandlers(props.onFocus, () => setIsFocused(true)),\n onBlur: composeEventHandlers(props.onBlur, () => setIsFocused(false))\n }\n ) })\n }\n );\n }\n);\nvar CHECKBOX_ITEM_NAME = \"MenuCheckboxItem\";\nvar MenuCheckboxItem = React.forwardRef(\n (props, forwardedRef) => {\n const { checked = false, onCheckedChange, ...checkboxItemProps } = props;\n return /* @__PURE__ */ jsx(ItemIndicatorProvider, { scope: props.__scopeMenu, checked, children: /* @__PURE__ */ jsx(\n MenuItem,\n {\n role: \"menuitemcheckbox\",\n \"aria-checked\": isIndeterminate(checked) ? \"mixed\" : checked,\n ...checkboxItemProps,\n ref: forwardedRef,\n \"data-state\": getCheckedState(checked),\n onSelect: composeEventHandlers(\n checkboxItemProps.onSelect,\n () => onCheckedChange?.(isIndeterminate(checked) ? true : !checked),\n { checkForDefaultPrevented: false }\n )\n }\n ) });\n }\n);\nMenuCheckboxItem.displayName = CHECKBOX_ITEM_NAME;\nvar RADIO_GROUP_NAME = \"MenuRadioGroup\";\nvar [RadioGroupProvider, useRadioGroupContext] = createMenuContext(\n RADIO_GROUP_NAME,\n { value: void 0, onValueChange: () => {\n } }\n);\nvar MenuRadioGroup = React.forwardRef(\n (props, forwardedRef) => {\n const { value, onValueChange, ...groupProps } = props;\n const handleValueChange = useCallbackRef(onValueChange);\n return /* @__PURE__ */ jsx(RadioGroupProvider, { scope: props.__scopeMenu, value, onValueChange: handleValueChange, children: /* @__PURE__ */ jsx(MenuGroup, { ...groupProps, ref: forwardedRef }) });\n }\n);\nMenuRadioGroup.displayName = RADIO_GROUP_NAME;\nvar RADIO_ITEM_NAME = \"MenuRadioItem\";\nvar MenuRadioItem = React.forwardRef(\n (props, forwardedRef) => {\n const { value, ...radioItemProps } = props;\n const context = useRadioGroupContext(RADIO_ITEM_NAME, props.__scopeMenu);\n const checked = value === context.value;\n return /* @__PURE__ */ jsx(ItemIndicatorProvider, { scope: props.__scopeMenu, checked, children: /* @__PURE__ */ jsx(\n MenuItem,\n {\n role: \"menuitemradio\",\n \"aria-checked\": checked,\n ...radioItemProps,\n ref: forwardedRef,\n \"data-state\": getCheckedState(checked),\n onSelect: composeEventHandlers(\n radioItemProps.onSelect,\n () => context.onValueChange?.(value),\n { checkForDefaultPrevented: false }\n )\n }\n ) });\n }\n);\nMenuRadioItem.displayName = RADIO_ITEM_NAME;\nvar ITEM_INDICATOR_NAME = \"MenuItemIndicator\";\nvar [ItemIndicatorProvider, useItemIndicatorContext] = createMenuContext(\n ITEM_INDICATOR_NAME,\n { checked: false }\n);\nvar MenuItemIndicator = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeMenu, forceMount, ...itemIndicatorProps } = props;\n const indicatorContext = useItemIndicatorContext(ITEM_INDICATOR_NAME, __scopeMenu);\n return /* @__PURE__ */ jsx(\n Presence,\n {\n present: forceMount || isIndeterminate(indicatorContext.checked) || indicatorContext.checked === true,\n children: /* @__PURE__ */ jsx(\n Primitive.span,\n {\n ...itemIndicatorProps,\n ref: forwardedRef,\n \"data-state\": getCheckedState(indicatorContext.checked)\n }\n )\n }\n );\n }\n);\nMenuItemIndicator.displayName = ITEM_INDICATOR_NAME;\nvar SEPARATOR_NAME = \"MenuSeparator\";\nvar MenuSeparator = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeMenu, ...separatorProps } = props;\n return /* @__PURE__ */ jsx(\n Primitive.div,\n {\n role: \"separator\",\n \"aria-orientation\": \"horizontal\",\n ...separatorProps,\n ref: forwardedRef\n }\n );\n }\n);\nMenuSeparator.displayName = SEPARATOR_NAME;\nvar ARROW_NAME = \"MenuArrow\";\nvar MenuArrow = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeMenu, ...arrowProps } = props;\n const popperScope = usePopperScope(__scopeMenu);\n return /* @__PURE__ */ jsx(PopperPrimitive.Arrow, { ...popperScope, ...arrowProps, ref: forwardedRef });\n }\n);\nMenuArrow.displayName = ARROW_NAME;\nvar SUB_NAME = \"MenuSub\";\nvar [MenuSubProvider, useMenuSubContext] = createMenuContext(SUB_NAME);\nvar MenuSub = (props) => {\n const { __scopeMenu, children, open = false, onOpenChange } = props;\n const parentMenuContext = useMenuContext(SUB_NAME, __scopeMenu);\n const popperScope = usePopperScope(__scopeMenu);\n const [trigger, setTrigger] = React.useState(null);\n const [content, setContent] = React.useState(null);\n const handleOpenChange = useCallbackRef(onOpenChange);\n React.useEffect(() => {\n if (parentMenuContext.open === false) handleOpenChange(false);\n return () => handleOpenChange(false);\n }, [parentMenuContext.open, handleOpenChange]);\n return /* @__PURE__ */ jsx(PopperPrimitive.Root, { ...popperScope, children: /* @__PURE__ */ jsx(\n MenuProvider,\n {\n scope: __scopeMenu,\n open,\n onOpenChange: handleOpenChange,\n content,\n onContentChange: setContent,\n children: /* @__PURE__ */ jsx(\n MenuSubProvider,\n {\n scope: __scopeMenu,\n contentId: useId(),\n triggerId: useId(),\n trigger,\n onTriggerChange: setTrigger,\n children\n }\n )\n }\n ) });\n};\nMenuSub.displayName = SUB_NAME;\nvar SUB_TRIGGER_NAME = \"MenuSubTrigger\";\nvar MenuSubTrigger = React.forwardRef(\n (props, forwardedRef) => {\n const context = useMenuContext(SUB_TRIGGER_NAME, props.__scopeMenu);\n const rootContext = useMenuRootContext(SUB_TRIGGER_NAME, props.__scopeMenu);\n const subContext = useMenuSubContext(SUB_TRIGGER_NAME, props.__scopeMenu);\n const contentContext = useMenuContentContext(SUB_TRIGGER_NAME, props.__scopeMenu);\n const openTimerRef = React.useRef(null);\n const { pointerGraceTimerRef, onPointerGraceIntentChange } = contentContext;\n const scope = { __scopeMenu: props.__scopeMenu };\n const clearOpenTimer = React.useCallback(() => {\n if (openTimerRef.current) window.clearTimeout(openTimerRef.current);\n openTimerRef.current = null;\n }, []);\n React.useEffect(() => clearOpenTimer, [clearOpenTimer]);\n React.useEffect(() => {\n const pointerGraceTimer = pointerGraceTimerRef.current;\n return () => {\n window.clearTimeout(pointerGraceTimer);\n onPointerGraceIntentChange(null);\n };\n }, [pointerGraceTimerRef, onPointerGraceIntentChange]);\n return /* @__PURE__ */ jsx(MenuAnchor, { asChild: true, ...scope, children: /* @__PURE__ */ jsx(\n MenuItemImpl,\n {\n id: subContext.triggerId,\n \"aria-haspopup\": \"menu\",\n \"aria-expanded\": context.open,\n \"aria-controls\": subContext.contentId,\n \"data-state\": getOpenState(context.open),\n ...props,\n ref: composeRefs(forwardedRef, subContext.onTriggerChange),\n onClick: (event) => {\n props.onClick?.(event);\n if (props.disabled || event.defaultPrevented) return;\n event.currentTarget.focus();\n if (!context.open) context.onOpenChange(true);\n },\n onPointerMove: composeEventHandlers(\n props.onPointerMove,\n whenMouse((event) => {\n contentContext.onItemEnter(event);\n if (event.defaultPrevented) return;\n if (!props.disabled && !context.open && !openTimerRef.current) {\n contentContext.onPointerGraceIntentChange(null);\n openTimerRef.current = window.setTimeout(() => {\n context.onOpenChange(true);\n clearOpenTimer();\n }, 100);\n }\n })\n ),\n onPointerLeave: composeEventHandlers(\n props.onPointerLeave,\n whenMouse((event) => {\n clearOpenTimer();\n const contentRect = context.content?.getBoundingClientRect();\n if (contentRect) {\n const side = context.content?.dataset.side;\n const rightSide = side === \"right\";\n const bleed = rightSide ? -5 : 5;\n const contentNearEdge = contentRect[rightSide ? \"left\" : \"right\"];\n const contentFarEdge = contentRect[rightSide ? \"right\" : \"left\"];\n contentContext.onPointerGraceIntentChange({\n area: [\n // Apply a bleed on clientX to ensure that our exit point is\n // consistently within polygon bounds\n { x: event.clientX + bleed, y: event.clientY },\n { x: contentNearEdge, y: contentRect.top },\n { x: contentFarEdge, y: contentRect.top },\n { x: contentFarEdge, y: contentRect.bottom },\n { x: contentNearEdge, y: contentRect.bottom }\n ],\n side\n });\n window.clearTimeout(pointerGraceTimerRef.current);\n pointerGraceTimerRef.current = window.setTimeout(\n () => contentContext.onPointerGraceIntentChange(null),\n 300\n );\n } else {\n contentContext.onTriggerLeave(event);\n if (event.defaultPrevented) return;\n contentContext.onPointerGraceIntentChange(null);\n }\n })\n ),\n onKeyDown: composeEventHandlers(props.onKeyDown, (event) => {\n const isTypingAhead = contentContext.searchRef.current !== \"\";\n if (props.disabled || isTypingAhead && event.key === \" \") return;\n if (SUB_OPEN_KEYS[rootContext.dir].includes(event.key)) {\n context.onOpenChange(true);\n context.content?.focus();\n event.preventDefault();\n }\n })\n }\n ) });\n }\n);\nMenuSubTrigger.displayName = SUB_TRIGGER_NAME;\nvar SUB_CONTENT_NAME = \"MenuSubContent\";\nvar MenuSubContent = React.forwardRef(\n (props, forwardedRef) => {\n const portalContext = usePortalContext(CONTENT_NAME, props.__scopeMenu);\n const { forceMount = portalContext.forceMount, ...subContentProps } = props;\n const context = useMenuContext(CONTENT_NAME, props.__scopeMenu);\n const rootContext = useMenuRootContext(CONTENT_NAME, props.__scopeMenu);\n const subContext = useMenuSubContext(SUB_CONTENT_NAME, props.__scopeMenu);\n const ref = React.useRef(null);\n const composedRefs = useComposedRefs(forwardedRef, ref);\n return /* @__PURE__ */ jsx(Collection.Provider, { scope: props.__scopeMenu, children: /* @__PURE__ */ jsx(Presence, { present: forceMount || context.open, children: /* @__PURE__ */ jsx(Collection.Slot, { scope: props.__scopeMenu, children: /* @__PURE__ */ jsx(\n MenuContentImpl,\n {\n id: subContext.contentId,\n \"aria-labelledby\": subContext.triggerId,\n ...subContentProps,\n ref: composedRefs,\n align: \"start\",\n side: rootContext.dir === \"rtl\" ? \"left\" : \"right\",\n disableOutsidePointerEvents: false,\n disableOutsideScroll: false,\n trapFocus: false,\n onOpenAutoFocus: (event) => {\n if (rootContext.isUsingKeyboardRef.current) ref.current?.focus();\n event.preventDefault();\n },\n onCloseAutoFocus: (event) => event.preventDefault(),\n onFocusOutside: composeEventHandlers(props.onFocusOutside, (event) => {\n if (event.target !== subContext.trigger) context.onOpenChange(false);\n }),\n onEscapeKeyDown: composeEventHandlers(props.onEscapeKeyDown, (event) => {\n rootContext.onClose();\n event.preventDefault();\n }),\n onKeyDown: composeEventHandlers(props.onKeyDown, (event) => {\n const isKeyDownInside = event.currentTarget.contains(event.target);\n const isCloseKey = SUB_CLOSE_KEYS[rootContext.dir].includes(event.key);\n if (isKeyDownInside && isCloseKey) {\n context.onOpenChange(false);\n subContext.trigger?.focus();\n event.preventDefault();\n }\n })\n }\n ) }) }) });\n }\n);\nMenuSubContent.displayName = SUB_CONTENT_NAME;\nfunction getOpenState(open) {\n return open ? \"open\" : \"closed\";\n}\nfunction isIndeterminate(checked) {\n return checked === \"indeterminate\";\n}\nfunction getCheckedState(checked) {\n return isIndeterminate(checked) ? \"indeterminate\" : checked ? \"checked\" : \"unchecked\";\n}\nfunction focusFirst(candidates) {\n const PREVIOUSLY_FOCUSED_ELEMENT = document.activeElement;\n for (const candidate of candidates) {\n if (candidate === PREVIOUSLY_FOCUSED_ELEMENT) return;\n candidate.focus();\n if (document.activeElement !== PREVIOUSLY_FOCUSED_ELEMENT) return;\n }\n}\nfunction wrapArray(array, startIndex) {\n return array.map((_, index) => array[(startIndex + index) % array.length]);\n}\nfunction getNextMatch(values, search, currentMatch) {\n const isRepeated = search.length > 1 && Array.from(search).every((char) => char === search[0]);\n const normalizedSearch = isRepeated ? search[0] : search;\n const currentMatchIndex = currentMatch ? values.indexOf(currentMatch) : -1;\n let wrappedValues = wrapArray(values, Math.max(currentMatchIndex, 0));\n const excludeCurrentMatch = normalizedSearch.length === 1;\n if (excludeCurrentMatch) wrappedValues = wrappedValues.filter((v) => v !== currentMatch);\n const nextMatch = wrappedValues.find(\n (value) => value.toLowerCase().startsWith(normalizedSearch.toLowerCase())\n );\n return nextMatch !== currentMatch ? nextMatch : void 0;\n}\nfunction isPointInPolygon(point, polygon) {\n const { x, y } = point;\n let inside = false;\n for (let i = 0, j = polygon.length - 1; i < polygon.length; j = i++) {\n const ii = polygon[i];\n const jj = polygon[j];\n const xi = ii.x;\n const yi = ii.y;\n const xj = jj.x;\n const yj = jj.y;\n const intersect = yi > y !== yj > y && x < (xj - xi) * (y - yi) / (yj - yi) + xi;\n if (intersect) inside = !inside;\n }\n return inside;\n}\nfunction isPointerInGraceArea(event, area) {\n if (!area) return false;\n const cursorPos = { x: event.clientX, y: event.clientY };\n return isPointInPolygon(cursorPos, area);\n}\nfunction whenMouse(handler) {\n return (event) => event.pointerType === \"mouse\" ? handler(event) : void 0;\n}\nvar Root3 = Menu;\nvar Anchor2 = MenuAnchor;\nvar Portal = MenuPortal;\nvar Content2 = MenuContent;\nvar Group = MenuGroup;\nvar Label = MenuLabel;\nvar Item2 = MenuItem;\nvar CheckboxItem = MenuCheckboxItem;\nvar RadioGroup = MenuRadioGroup;\nvar RadioItem = MenuRadioItem;\nvar ItemIndicator = MenuItemIndicator;\nvar Separator = MenuSeparator;\nvar Arrow2 = MenuArrow;\nvar Sub = MenuSub;\nvar SubTrigger = MenuSubTrigger;\nvar SubContent = MenuSubContent;\nexport {\n Anchor2 as Anchor,\n Arrow2 as Arrow,\n CheckboxItem,\n Content2 as Content,\n Group,\n Item2 as Item,\n ItemIndicator,\n Label,\n Menu,\n MenuAnchor,\n MenuArrow,\n MenuCheckboxItem,\n MenuContent,\n MenuGroup,\n MenuItem,\n MenuItemIndicator,\n MenuLabel,\n MenuPortal,\n MenuRadioGroup,\n MenuRadioItem,\n MenuSeparator,\n MenuSub,\n MenuSubContent,\n MenuSubTrigger,\n Portal,\n RadioGroup,\n RadioItem,\n Root3 as Root,\n Separator,\n Sub,\n SubContent,\n SubTrigger,\n createMenuScope\n};\n//# sourceMappingURL=index.mjs.map\n","\"use client\";\n\n// src/dropdown-menu.tsx\nimport * as React from \"react\";\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\nimport { composeRefs } from \"@radix-ui/react-compose-refs\";\nimport { createContextScope } from \"@radix-ui/react-context\";\nimport { useControllableState } from \"@radix-ui/react-use-controllable-state\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport * as MenuPrimitive from \"@radix-ui/react-menu\";\nimport { createMenuScope } from \"@radix-ui/react-menu\";\nimport { useId } from \"@radix-ui/react-id\";\nimport { jsx } from \"react/jsx-runtime\";\nvar DROPDOWN_MENU_NAME = \"DropdownMenu\";\nvar [createDropdownMenuContext, createDropdownMenuScope] = createContextScope(\n DROPDOWN_MENU_NAME,\n [createMenuScope]\n);\nvar useMenuScope = createMenuScope();\nvar [DropdownMenuProvider, useDropdownMenuContext] = createDropdownMenuContext(DROPDOWN_MENU_NAME);\nvar DropdownMenu = (props) => {\n const {\n __scopeDropdownMenu,\n children,\n dir,\n open: openProp,\n defaultOpen,\n onOpenChange,\n modal = true\n } = props;\n const menuScope = useMenuScope(__scopeDropdownMenu);\n const triggerRef = React.useRef(null);\n const [open, setOpen] = useControllableState({\n prop: openProp,\n defaultProp: defaultOpen ?? false,\n onChange: onOpenChange,\n caller: DROPDOWN_MENU_NAME\n });\n return /* @__PURE__ */ jsx(\n DropdownMenuProvider,\n {\n scope: __scopeDropdownMenu,\n triggerId: useId(),\n triggerRef,\n contentId: useId(),\n open,\n onOpenChange: setOpen,\n onOpenToggle: React.useCallback(() => setOpen((prevOpen) => !prevOpen), [setOpen]),\n modal,\n children: /* @__PURE__ */ jsx(MenuPrimitive.Root, { ...menuScope, open, onOpenChange: setOpen, dir, modal, children })\n }\n );\n};\nDropdownMenu.displayName = DROPDOWN_MENU_NAME;\nvar TRIGGER_NAME = \"DropdownMenuTrigger\";\nvar DropdownMenuTrigger = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeDropdownMenu, disabled = false, ...triggerProps } = props;\n const context = useDropdownMenuContext(TRIGGER_NAME, __scopeDropdownMenu);\n const menuScope = useMenuScope(__scopeDropdownMenu);\n return /* @__PURE__ */ jsx(MenuPrimitive.Anchor, { asChild: true, ...menuScope, children: /* @__PURE__ */ jsx(\n Primitive.button,\n {\n type: \"button\",\n id: context.triggerId,\n \"aria-haspopup\": \"menu\",\n \"aria-expanded\": context.open,\n \"aria-controls\": context.open ? context.contentId : void 0,\n \"data-state\": context.open ? \"open\" : \"closed\",\n \"data-disabled\": disabled ? \"\" : void 0,\n disabled,\n ...triggerProps,\n ref: composeRefs(forwardedRef, context.triggerRef),\n onPointerDown: composeEventHandlers(props.onPointerDown, (event) => {\n if (!disabled && event.button === 0 && event.ctrlKey === false) {\n context.onOpenToggle();\n if (!context.open) event.preventDefault();\n }\n }),\n onKeyDown: composeEventHandlers(props.onKeyDown, (event) => {\n if (disabled) return;\n if ([\"Enter\", \" \"].includes(event.key)) context.onOpenToggle();\n if (event.key === \"ArrowDown\") context.onOpenChange(true);\n if ([\"Enter\", \" \", \"ArrowDown\"].includes(event.key)) event.preventDefault();\n })\n }\n ) });\n }\n);\nDropdownMenuTrigger.displayName = TRIGGER_NAME;\nvar PORTAL_NAME = \"DropdownMenuPortal\";\nvar DropdownMenuPortal = (props) => {\n const { __scopeDropdownMenu, ...portalProps } = props;\n const menuScope = useMenuScope(__scopeDropdownMenu);\n return /* @__PURE__ */ jsx(MenuPrimitive.Portal, { ...menuScope, ...portalProps });\n};\nDropdownMenuPortal.displayName = PORTAL_NAME;\nvar CONTENT_NAME = \"DropdownMenuContent\";\nvar DropdownMenuContent = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeDropdownMenu, ...contentProps } = props;\n const context = useDropdownMenuContext(CONTENT_NAME, __scopeDropdownMenu);\n const menuScope = useMenuScope(__scopeDropdownMenu);\n const hasInteractedOutsideRef = React.useRef(false);\n return /* @__PURE__ */ jsx(\n MenuPrimitive.Content,\n {\n id: context.contentId,\n \"aria-labelledby\": context.triggerId,\n ...menuScope,\n ...contentProps,\n ref: forwardedRef,\n onCloseAutoFocus: composeEventHandlers(props.onCloseAutoFocus, (event) => {\n if (!hasInteractedOutsideRef.current) context.triggerRef.current?.focus();\n hasInteractedOutsideRef.current = false;\n event.preventDefault();\n }),\n onInteractOutside: composeEventHandlers(props.onInteractOutside, (event) => {\n const originalEvent = event.detail.originalEvent;\n const ctrlLeftClick = originalEvent.button === 0 && originalEvent.ctrlKey === true;\n const isRightClick = originalEvent.button === 2 || ctrlLeftClick;\n if (!context.modal || isRightClick) hasInteractedOutsideRef.current = true;\n }),\n style: {\n ...props.style,\n // re-namespace exposed content custom properties\n ...{\n \"--radix-dropdown-menu-content-transform-origin\": \"var(--radix-popper-transform-origin)\",\n \"--radix-dropdown-menu-content-available-width\": \"var(--radix-popper-available-width)\",\n \"--radix-dropdown-menu-content-available-height\": \"var(--radix-popper-available-height)\",\n \"--radix-dropdown-menu-trigger-width\": \"var(--radix-popper-anchor-width)\",\n \"--radix-dropdown-menu-trigger-height\": \"var(--radix-popper-anchor-height)\"\n }\n }\n }\n );\n }\n);\nDropdownMenuContent.displayName = CONTENT_NAME;\nvar GROUP_NAME = \"DropdownMenuGroup\";\nvar DropdownMenuGroup = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeDropdownMenu, ...groupProps } = props;\n const menuScope = useMenuScope(__scopeDropdownMenu);\n return /* @__PURE__ */ jsx(MenuPrimitive.Group, { ...menuScope, ...groupProps, ref: forwardedRef });\n }\n);\nDropdownMenuGroup.displayName = GROUP_NAME;\nvar LABEL_NAME = \"DropdownMenuLabel\";\nvar DropdownMenuLabel = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeDropdownMenu, ...labelProps } = props;\n const menuScope = useMenuScope(__scopeDropdownMenu);\n return /* @__PURE__ */ jsx(MenuPrimitive.Label, { ...menuScope, ...labelProps, ref: forwardedRef });\n }\n);\nDropdownMenuLabel.displayName = LABEL_NAME;\nvar ITEM_NAME = \"DropdownMenuItem\";\nvar DropdownMenuItem = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeDropdownMenu, ...itemProps } = props;\n const menuScope = useMenuScope(__scopeDropdownMenu);\n return /* @__PURE__ */ jsx(MenuPrimitive.Item, { ...menuScope, ...itemProps, ref: forwardedRef });\n }\n);\nDropdownMenuItem.displayName = ITEM_NAME;\nvar CHECKBOX_ITEM_NAME = \"DropdownMenuCheckboxItem\";\nvar DropdownMenuCheckboxItem = React.forwardRef((props, forwardedRef) => {\n const { __scopeDropdownMenu, ...checkboxItemProps } = props;\n const menuScope = useMenuScope(__scopeDropdownMenu);\n return /* @__PURE__ */ jsx(MenuPrimitive.CheckboxItem, { ...menuScope, ...checkboxItemProps, ref: forwardedRef });\n});\nDropdownMenuCheckboxItem.displayName = CHECKBOX_ITEM_NAME;\nvar RADIO_GROUP_NAME = \"DropdownMenuRadioGroup\";\nvar DropdownMenuRadioGroup = React.forwardRef((props, forwardedRef) => {\n const { __scopeDropdownMenu, ...radioGroupProps } = props;\n const menuScope = useMenuScope(__scopeDropdownMenu);\n return /* @__PURE__ */ jsx(MenuPrimitive.RadioGroup, { ...menuScope, ...radioGroupProps, ref: forwardedRef });\n});\nDropdownMenuRadioGroup.displayName = RADIO_GROUP_NAME;\nvar RADIO_ITEM_NAME = \"DropdownMenuRadioItem\";\nvar DropdownMenuRadioItem = React.forwardRef((props, forwardedRef) => {\n const { __scopeDropdownMenu, ...radioItemProps } = props;\n const menuScope = useMenuScope(__scopeDropdownMenu);\n return /* @__PURE__ */ jsx(MenuPrimitive.RadioItem, { ...menuScope, ...radioItemProps, ref: forwardedRef });\n});\nDropdownMenuRadioItem.displayName = RADIO_ITEM_NAME;\nvar INDICATOR_NAME = \"DropdownMenuItemIndicator\";\nvar DropdownMenuItemIndicator = React.forwardRef((props, forwardedRef) => {\n const { __scopeDropdownMenu, ...itemIndicatorProps } = props;\n const menuScope = useMenuScope(__scopeDropdownMenu);\n return /* @__PURE__ */ jsx(MenuPrimitive.ItemIndicator, { ...menuScope, ...itemIndicatorProps, ref: forwardedRef });\n});\nDropdownMenuItemIndicator.displayName = INDICATOR_NAME;\nvar SEPARATOR_NAME = \"DropdownMenuSeparator\";\nvar DropdownMenuSeparator = React.forwardRef((props, forwardedRef) => {\n const { __scopeDropdownMenu, ...separatorProps } = props;\n const menuScope = useMenuScope(__scopeDropdownMenu);\n return /* @__PURE__ */ jsx(MenuPrimitive.Separator, { ...menuScope, ...separatorProps, ref: forwardedRef });\n});\nDropdownMenuSeparator.displayName = SEPARATOR_NAME;\nvar ARROW_NAME = \"DropdownMenuArrow\";\nvar DropdownMenuArrow = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeDropdownMenu, ...arrowProps } = props;\n const menuScope = useMenuScope(__scopeDropdownMenu);\n return /* @__PURE__ */ jsx(MenuPrimitive.Arrow, { ...menuScope, ...arrowProps, ref: forwardedRef });\n }\n);\nDropdownMenuArrow.displayName = ARROW_NAME;\nvar DropdownMenuSub = (props) => {\n const { __scopeDropdownMenu, children, open: openProp, onOpenChange, defaultOpen } = props;\n const menuScope = useMenuScope(__scopeDropdownMenu);\n const [open, setOpen] = useControllableState({\n prop: openProp,\n defaultProp: defaultOpen ?? false,\n onChange: onOpenChange,\n caller: \"DropdownMenuSub\"\n });\n return /* @__PURE__ */ jsx(MenuPrimitive.Sub, { ...menuScope, open, onOpenChange: setOpen, children });\n};\nvar SUB_TRIGGER_NAME = \"DropdownMenuSubTrigger\";\nvar DropdownMenuSubTrigger = React.forwardRef((props, forwardedRef) => {\n const { __scopeDropdownMenu, ...subTriggerProps } = props;\n const menuScope = useMenuScope(__scopeDropdownMenu);\n return /* @__PURE__ */ jsx(MenuPrimitive.SubTrigger, { ...menuScope, ...subTriggerProps, ref: forwardedRef });\n});\nDropdownMenuSubTrigger.displayName = SUB_TRIGGER_NAME;\nvar SUB_CONTENT_NAME = \"DropdownMenuSubContent\";\nvar DropdownMenuSubContent = React.forwardRef((props, forwardedRef) => {\n const { __scopeDropdownMenu, ...subContentProps } = props;\n const menuScope = useMenuScope(__scopeDropdownMenu);\n return /* @__PURE__ */ jsx(\n MenuPrimitive.SubContent,\n {\n ...menuScope,\n ...subContentProps,\n ref: forwardedRef,\n style: {\n ...props.style,\n // re-namespace exposed content custom properties\n ...{\n \"--radix-dropdown-menu-content-transform-origin\": \"var(--radix-popper-transform-origin)\",\n \"--radix-dropdown-menu-content-available-width\": \"var(--radix-popper-available-width)\",\n \"--radix-dropdown-menu-content-available-height\": \"var(--radix-popper-available-height)\",\n \"--radix-dropdown-menu-trigger-width\": \"var(--radix-popper-anchor-width)\",\n \"--radix-dropdown-menu-trigger-height\": \"var(--radix-popper-anchor-height)\"\n }\n }\n }\n );\n});\nDropdownMenuSubContent.displayName = SUB_CONTENT_NAME;\nvar Root2 = DropdownMenu;\nvar Trigger = DropdownMenuTrigger;\nvar Portal2 = DropdownMenuPortal;\nvar Content2 = DropdownMenuContent;\nvar Group2 = DropdownMenuGroup;\nvar Label2 = DropdownMenuLabel;\nvar Item2 = DropdownMenuItem;\nvar CheckboxItem2 = DropdownMenuCheckboxItem;\nvar RadioGroup2 = DropdownMenuRadioGroup;\nvar RadioItem2 = DropdownMenuRadioItem;\nvar ItemIndicator2 = DropdownMenuItemIndicator;\nvar Separator2 = DropdownMenuSeparator;\nvar Arrow2 = DropdownMenuArrow;\nvar Sub2 = DropdownMenuSub;\nvar SubTrigger2 = DropdownMenuSubTrigger;\nvar SubContent2 = DropdownMenuSubContent;\nexport {\n Arrow2 as Arrow,\n CheckboxItem2 as CheckboxItem,\n Content2 as Content,\n DropdownMenu,\n DropdownMenuArrow,\n DropdownMenuCheckboxItem,\n DropdownMenuContent,\n DropdownMenuGroup,\n DropdownMenuItem,\n DropdownMenuItemIndicator,\n DropdownMenuLabel,\n DropdownMenuPortal,\n DropdownMenuRadioGroup,\n DropdownMenuRadioItem,\n DropdownMenuSeparator,\n DropdownMenuSub,\n DropdownMenuSubContent,\n DropdownMenuSubTrigger,\n DropdownMenuTrigger,\n Group2 as Group,\n Item2 as Item,\n ItemIndicator2 as ItemIndicator,\n Label2 as Label,\n Portal2 as Portal,\n RadioGroup2 as RadioGroup,\n RadioItem2 as RadioItem,\n Root2 as Root,\n Separator2 as Separator,\n Sub2 as Sub,\n SubContent2 as SubContent,\n SubTrigger2 as SubTrigger,\n Trigger,\n createDropdownMenuScope\n};\n//# sourceMappingURL=index.mjs.map\n","import * as DropdownMenuPrimitive from '@radix-ui/react-dropdown-menu'\nimport { cn } from '../../lib/cn'\n\n/* ----------------------------------------------------------\n Re-export primitives that need no styling\n ---------------------------------------------------------- */\n\nexport const DropdownMenu = DropdownMenuPrimitive.Root\nexport const DropdownMenuTrigger = DropdownMenuPrimitive.Trigger\nexport const DropdownMenuGroup = DropdownMenuPrimitive.Group\nexport const DropdownMenuSub = DropdownMenuPrimitive.Sub\nexport const DropdownMenuRadioGroup = DropdownMenuPrimitive.RadioGroup\n\n\n/* ----------------------------------------------------------\n DropdownMenuContent\n ---------------------------------------------------------- */\n\nexport interface DropdownMenuContentProps\n extends React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.Content> {}\n\n/**\n * The floating menu panel. Rendered in a portal, anchored to the trigger.\n *\n * @example\n * <DropdownMenu>\n * <DropdownMenuTrigger asChild>\n * <Button variant=\"ghost\" size=\"icon\" aria-label=\"Row actions\">⋯</Button>\n * </DropdownMenuTrigger>\n * <DropdownMenuContent align=\"end\">\n * <DropdownMenuItem>Edit</DropdownMenuItem>\n * <DropdownMenuItem>Duplicate</DropdownMenuItem>\n * <DropdownMenuSeparator />\n * <DropdownMenuItem destructive>Delete</DropdownMenuItem>\n * </DropdownMenuContent>\n * </DropdownMenu>\n */\nexport function DropdownMenuContent({\n className,\n sideOffset = 4,\n align = 'start',\n ...props\n}: DropdownMenuContentProps) {\n return (\n <DropdownMenuPrimitive.Portal>\n <DropdownMenuPrimitive.Content\n sideOffset={sideOffset}\n align={align}\n className={cn(\n // Geometry\n 'min-w-[160px] rounded-sm border border-rule',\n // Color + elevation\n 'bg-paper shadow-[var(--shadow-md)]',\n // Layout\n 'py-1',\n // Z-index\n 'z-50',\n // Animation\n 'data-[state=open]:animate-[dropdown-in_120ms_var(--ease-enter)]',\n 'data-[state=closed]:animate-[dropdown-out_80ms_var(--ease-exit)]',\n className,\n )}\n {...props}\n />\n </DropdownMenuPrimitive.Portal>\n )\n}\n\n\n/* ----------------------------------------------------------\n DropdownMenuItem\n ---------------------------------------------------------- */\n\nexport interface DropdownMenuItemProps\n extends React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.Item> {\n /** Renders in signal-red — use for delete / destructive actions. */\n destructive?: boolean\n /** Optional leading icon node. */\n icon?: React.ReactNode\n}\n\nexport function DropdownMenuItem({\n destructive,\n icon,\n className,\n children,\n ...props\n}: DropdownMenuItemProps) {\n return (\n <DropdownMenuPrimitive.Item\n className={cn(\n // Layout\n 'flex items-center gap-2',\n // Typography\n 'font-body text-sm',\n // Spacing\n 'px-4 py-2',\n // Interaction\n 'cursor-default select-none outline-none',\n // Color\n destructive ? 'text-signal' : 'text-void',\n // Highlighted\n destructive\n ? 'data-[highlighted]:bg-[color-mix(in_srgb,var(--color-signal)_8%,var(--color-paper))]'\n : 'data-[highlighted]:bg-[color-mix(in_srgb,var(--color-rule)_60%,var(--color-paper))]',\n // Disabled\n 'data-[disabled]:opacity-[0.38] data-[disabled]:pointer-events-none',\n className,\n )}\n {...props}\n >\n {icon && (\n <span className=\"shrink-0 w-4 h-4 flex items-center justify-center opacity-70\">\n {icon}\n </span>\n )}\n {children}\n </DropdownMenuPrimitive.Item>\n )\n}\n\n\n/* ----------------------------------------------------------\n DropdownMenuCheckboxItem\n ---------------------------------------------------------- */\n\nexport interface DropdownMenuCheckboxItemProps\n extends React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.CheckboxItem> {}\n\nexport function DropdownMenuCheckboxItem({\n className,\n children,\n checked,\n ...props\n}: DropdownMenuCheckboxItemProps) {\n return (\n <DropdownMenuPrimitive.CheckboxItem\n checked={checked}\n className={cn(\n 'flex items-center gap-2 font-body text-sm text-void',\n 'px-4 py-2 cursor-default select-none outline-none',\n 'data-[highlighted]:bg-[color-mix(in_srgb,var(--color-rule)_60%,var(--color-paper))]',\n 'data-[disabled]:opacity-[0.38] data-[disabled]:pointer-events-none',\n className,\n )}\n {...props}\n >\n {/* Checkbox indicator — 16px box */}\n <span className=\"shrink-0 w-4 h-4 flex items-center justify-center rounded-sm border border-rule data-[state=checked]:bg-signal-alt data-[state=checked]:border-signal-alt\">\n <DropdownMenuPrimitive.ItemIndicator>\n <CheckIcon />\n </DropdownMenuPrimitive.ItemIndicator>\n </span>\n {children}\n </DropdownMenuPrimitive.CheckboxItem>\n )\n}\n\n\n/* ----------------------------------------------------------\n DropdownMenuRadioItem\n ---------------------------------------------------------- */\n\nexport interface DropdownMenuRadioItemProps\n extends React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.RadioItem> {}\n\nexport function DropdownMenuRadioItem({\n className,\n children,\n ...props\n}: DropdownMenuRadioItemProps) {\n return (\n <DropdownMenuPrimitive.RadioItem\n className={cn(\n 'flex items-center gap-2 font-body text-sm text-void',\n 'px-4 py-2 cursor-default select-none outline-none',\n 'data-[highlighted]:bg-[color-mix(in_srgb,var(--color-rule)_60%,var(--color-paper))]',\n 'data-[disabled]:opacity-[0.38] data-[disabled]:pointer-events-none',\n className,\n )}\n {...props}\n >\n {/* Radio dot */}\n <span className=\"shrink-0 w-4 h-4 flex items-center justify-center rounded-full border border-rule\">\n <DropdownMenuPrimitive.ItemIndicator>\n <span className=\"block w-2 h-2 rounded-full bg-signal-alt\" />\n </DropdownMenuPrimitive.ItemIndicator>\n </span>\n {children}\n </DropdownMenuPrimitive.RadioItem>\n )\n}\n\n\n/* ----------------------------------------------------------\n DropdownMenuLabel\n ---------------------------------------------------------- */\n\nexport interface DropdownMenuLabelProps\n extends React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.Label> {}\n\n/** Section label — not interactive. */\nexport function DropdownMenuLabel({ className, ...props }: DropdownMenuLabelProps) {\n return (\n <DropdownMenuPrimitive.Label\n className={cn(\n 'px-4 py-1.5',\n 'font-display font-bold text-xs uppercase tracking-widest text-smoke',\n className,\n )}\n {...props}\n />\n )\n}\n\n\n/* ----------------------------------------------------------\n DropdownMenuSeparator\n ---------------------------------------------------------- */\n\nexport interface DropdownMenuSeparatorProps\n extends React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.Separator> {}\n\nexport function DropdownMenuSeparator({ className, ...props }: DropdownMenuSeparatorProps) {\n return (\n <DropdownMenuPrimitive.Separator\n className={cn('my-1 h-px bg-rule', className)}\n {...props}\n />\n )\n}\n\n\n/* ----------------------------------------------------------\n DropdownMenuSubTrigger\n ---------------------------------------------------------- */\n\nexport interface DropdownMenuSubTriggerProps\n extends React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.SubTrigger> {}\n\nexport function DropdownMenuSubTrigger({ className, children, ...props }: DropdownMenuSubTriggerProps) {\n return (\n <DropdownMenuPrimitive.SubTrigger\n className={cn(\n 'flex items-center justify-between gap-2',\n 'font-body text-sm text-void',\n 'px-4 py-2 cursor-default select-none outline-none',\n 'data-[highlighted]:bg-[color-mix(in_srgb,var(--color-rule)_60%,var(--color-paper))]',\n 'data-[state=open]:bg-[color-mix(in_srgb,var(--color-rule)_60%,var(--color-paper))]',\n className,\n )}\n {...props}\n >\n {children}\n <ChevronRightIcon />\n </DropdownMenuPrimitive.SubTrigger>\n )\n}\n\n\n/* ----------------------------------------------------------\n DropdownMenuSubContent\n ---------------------------------------------------------- */\n\nexport interface DropdownMenuSubContentProps\n extends React.ComponentPropsWithoutRef<typeof DropdownMenuPrimitive.SubContent> {}\n\nexport function DropdownMenuSubContent({ className, ...props }: DropdownMenuSubContentProps) {\n return (\n <DropdownMenuPrimitive.SubContent\n className={cn(\n 'min-w-[160px] rounded-sm border border-rule',\n 'bg-paper shadow-[var(--shadow-md)]',\n 'py-1 z-50',\n className,\n )}\n {...props}\n />\n )\n}\n\n\n/* ----------------------------------------------------------\n Icons\n ---------------------------------------------------------- */\n\nfunction CheckIcon() {\n return (\n <svg viewBox=\"0 0 10 8\" className=\"w-2.5 h-2 text-paper\" fill=\"none\" stroke=\"currentColor\" strokeWidth={2.2} strokeLinecap=\"round\" strokeLinejoin=\"round\" aria-hidden=\"true\">\n <path d=\"M1 4L3.5 6.5L9 1.5\" />\n </svg>\n )\n}\n\nfunction ChevronRightIcon() {\n return (\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"1.5\" strokeLinecap=\"round\" strokeLinejoin=\"round\" aria-hidden=\"true\" className=\"text-smoke\">\n <path d=\"M4.5 2.5L8 6l-3.5 3.5\" />\n </svg>\n )\n}\n","// src/slot.tsx\nimport * as React from \"react\";\nimport { composeRefs } from \"@radix-ui/react-compose-refs\";\nimport { Fragment as Fragment2, jsx } from \"react/jsx-runtime\";\n// @__NO_SIDE_EFFECTS__\nfunction createSlot(ownerName) {\n const SlotClone = /* @__PURE__ */ createSlotClone(ownerName);\n const Slot2 = React.forwardRef((props, forwardedRef) => {\n const { children, ...slotProps } = props;\n const childrenArray = React.Children.toArray(children);\n const slottable = childrenArray.find(isSlottable);\n if (slottable) {\n const newElement = slottable.props.children;\n const newChildren = childrenArray.map((child) => {\n if (child === slottable) {\n if (React.Children.count(newElement) > 1) return React.Children.only(null);\n return React.isValidElement(newElement) ? newElement.props.children : null;\n } else {\n return child;\n }\n });\n return /* @__PURE__ */ jsx(SlotClone, { ...slotProps, ref: forwardedRef, children: React.isValidElement(newElement) ? React.cloneElement(newElement, void 0, newChildren) : null });\n }\n return /* @__PURE__ */ jsx(SlotClone, { ...slotProps, ref: forwardedRef, children });\n });\n Slot2.displayName = `${ownerName}.Slot`;\n return Slot2;\n}\nvar Slot = /* @__PURE__ */ createSlot(\"Slot\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlotClone(ownerName) {\n const SlotClone = React.forwardRef((props, forwardedRef) => {\n const { children, ...slotProps } = props;\n if (React.isValidElement(children)) {\n const childrenRef = getElementRef(children);\n const props2 = mergeProps(slotProps, children.props);\n if (children.type !== React.Fragment) {\n props2.ref = forwardedRef ? composeRefs(forwardedRef, childrenRef) : childrenRef;\n }\n return React.cloneElement(children, props2);\n }\n return React.Children.count(children) > 1 ? React.Children.only(null) : null;\n });\n SlotClone.displayName = `${ownerName}.SlotClone`;\n return SlotClone;\n}\nvar SLOTTABLE_IDENTIFIER = Symbol(\"radix.slottable\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlottable(ownerName) {\n const Slottable2 = ({ children }) => {\n return /* @__PURE__ */ jsx(Fragment2, { children });\n };\n Slottable2.displayName = `${ownerName}.Slottable`;\n Slottable2.__radixId = SLOTTABLE_IDENTIFIER;\n return Slottable2;\n}\nvar Slottable = /* @__PURE__ */ createSlottable(\"Slottable\");\nfunction isSlottable(child) {\n return React.isValidElement(child) && typeof child.type === \"function\" && \"__radixId\" in child.type && child.type.__radixId === SLOTTABLE_IDENTIFIER;\n}\nfunction mergeProps(slotProps, childProps) {\n const overrideProps = { ...childProps };\n for (const propName in childProps) {\n const slotPropValue = slotProps[propName];\n const childPropValue = childProps[propName];\n const isHandler = /^on[A-Z]/.test(propName);\n if (isHandler) {\n if (slotPropValue && childPropValue) {\n overrideProps[propName] = (...args) => {\n const result = childPropValue(...args);\n slotPropValue(...args);\n return result;\n };\n } else if (slotPropValue) {\n overrideProps[propName] = slotPropValue;\n }\n } else if (propName === \"style\") {\n overrideProps[propName] = { ...slotPropValue, ...childPropValue };\n } else if (propName === \"className\") {\n overrideProps[propName] = [slotPropValue, childPropValue].filter(Boolean).join(\" \");\n }\n }\n return { ...slotProps, ...overrideProps };\n}\nfunction getElementRef(element) {\n let getter = Object.getOwnPropertyDescriptor(element.props, \"ref\")?.get;\n let mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.ref;\n }\n getter = Object.getOwnPropertyDescriptor(element, \"ref\")?.get;\n mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.props.ref;\n }\n return element.props.ref || element.ref;\n}\nexport {\n Slot as Root,\n Slot,\n Slottable,\n createSlot,\n createSlottable\n};\n//# sourceMappingURL=index.mjs.map\n","\"use client\";\n\n// src/tooltip.tsx\nimport * as React from \"react\";\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { createContextScope } from \"@radix-ui/react-context\";\nimport { DismissableLayer } from \"@radix-ui/react-dismissable-layer\";\nimport { useId } from \"@radix-ui/react-id\";\nimport * as PopperPrimitive from \"@radix-ui/react-popper\";\nimport { createPopperScope } from \"@radix-ui/react-popper\";\nimport { Portal as PortalPrimitive } from \"@radix-ui/react-portal\";\nimport { Presence } from \"@radix-ui/react-presence\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { createSlottable } from \"@radix-ui/react-slot\";\nimport { useControllableState } from \"@radix-ui/react-use-controllable-state\";\nimport * as VisuallyHiddenPrimitive from \"@radix-ui/react-visually-hidden\";\nimport { jsx, jsxs } from \"react/jsx-runtime\";\nvar [createTooltipContext, createTooltipScope] = createContextScope(\"Tooltip\", [\n createPopperScope\n]);\nvar usePopperScope = createPopperScope();\nvar PROVIDER_NAME = \"TooltipProvider\";\nvar DEFAULT_DELAY_DURATION = 700;\nvar TOOLTIP_OPEN = \"tooltip.open\";\nvar [TooltipProviderContextProvider, useTooltipProviderContext] = createTooltipContext(PROVIDER_NAME);\nvar TooltipProvider = (props) => {\n const {\n __scopeTooltip,\n delayDuration = DEFAULT_DELAY_DURATION,\n skipDelayDuration = 300,\n disableHoverableContent = false,\n children\n } = props;\n const isOpenDelayedRef = React.useRef(true);\n const isPointerInTransitRef = React.useRef(false);\n const skipDelayTimerRef = React.useRef(0);\n React.useEffect(() => {\n const skipDelayTimer = skipDelayTimerRef.current;\n return () => window.clearTimeout(skipDelayTimer);\n }, []);\n return /* @__PURE__ */ jsx(\n TooltipProviderContextProvider,\n {\n scope: __scopeTooltip,\n isOpenDelayedRef,\n delayDuration,\n onOpen: React.useCallback(() => {\n window.clearTimeout(skipDelayTimerRef.current);\n isOpenDelayedRef.current = false;\n }, []),\n onClose: React.useCallback(() => {\n window.clearTimeout(skipDelayTimerRef.current);\n skipDelayTimerRef.current = window.setTimeout(\n () => isOpenDelayedRef.current = true,\n skipDelayDuration\n );\n }, [skipDelayDuration]),\n isPointerInTransitRef,\n onPointerInTransitChange: React.useCallback((inTransit) => {\n isPointerInTransitRef.current = inTransit;\n }, []),\n disableHoverableContent,\n children\n }\n );\n};\nTooltipProvider.displayName = PROVIDER_NAME;\nvar TOOLTIP_NAME = \"Tooltip\";\nvar [TooltipContextProvider, useTooltipContext] = createTooltipContext(TOOLTIP_NAME);\nvar Tooltip = (props) => {\n const {\n __scopeTooltip,\n children,\n open: openProp,\n defaultOpen,\n onOpenChange,\n disableHoverableContent: disableHoverableContentProp,\n delayDuration: delayDurationProp\n } = props;\n const providerContext = useTooltipProviderContext(TOOLTIP_NAME, props.__scopeTooltip);\n const popperScope = usePopperScope(__scopeTooltip);\n const [trigger, setTrigger] = React.useState(null);\n const contentId = useId();\n const openTimerRef = React.useRef(0);\n const disableHoverableContent = disableHoverableContentProp ?? providerContext.disableHoverableContent;\n const delayDuration = delayDurationProp ?? providerContext.delayDuration;\n const wasOpenDelayedRef = React.useRef(false);\n const [open, setOpen] = useControllableState({\n prop: openProp,\n defaultProp: defaultOpen ?? false,\n onChange: (open2) => {\n if (open2) {\n providerContext.onOpen();\n document.dispatchEvent(new CustomEvent(TOOLTIP_OPEN));\n } else {\n providerContext.onClose();\n }\n onOpenChange?.(open2);\n },\n caller: TOOLTIP_NAME\n });\n const stateAttribute = React.useMemo(() => {\n return open ? wasOpenDelayedRef.current ? \"delayed-open\" : \"instant-open\" : \"closed\";\n }, [open]);\n const handleOpen = React.useCallback(() => {\n window.clearTimeout(openTimerRef.current);\n openTimerRef.current = 0;\n wasOpenDelayedRef.current = false;\n setOpen(true);\n }, [setOpen]);\n const handleClose = React.useCallback(() => {\n window.clearTimeout(openTimerRef.current);\n openTimerRef.current = 0;\n setOpen(false);\n }, [setOpen]);\n const handleDelayedOpen = React.useCallback(() => {\n window.clearTimeout(openTimerRef.current);\n openTimerRef.current = window.setTimeout(() => {\n wasOpenDelayedRef.current = true;\n setOpen(true);\n openTimerRef.current = 0;\n }, delayDuration);\n }, [delayDuration, setOpen]);\n React.useEffect(() => {\n return () => {\n if (openTimerRef.current) {\n window.clearTimeout(openTimerRef.current);\n openTimerRef.current = 0;\n }\n };\n }, []);\n return /* @__PURE__ */ jsx(PopperPrimitive.Root, { ...popperScope, children: /* @__PURE__ */ jsx(\n TooltipContextProvider,\n {\n scope: __scopeTooltip,\n contentId,\n open,\n stateAttribute,\n trigger,\n onTriggerChange: setTrigger,\n onTriggerEnter: React.useCallback(() => {\n if (providerContext.isOpenDelayedRef.current) handleDelayedOpen();\n else handleOpen();\n }, [providerContext.isOpenDelayedRef, handleDelayedOpen, handleOpen]),\n onTriggerLeave: React.useCallback(() => {\n if (disableHoverableContent) {\n handleClose();\n } else {\n window.clearTimeout(openTimerRef.current);\n openTimerRef.current = 0;\n }\n }, [handleClose, disableHoverableContent]),\n onOpen: handleOpen,\n onClose: handleClose,\n disableHoverableContent,\n children\n }\n ) });\n};\nTooltip.displayName = TOOLTIP_NAME;\nvar TRIGGER_NAME = \"TooltipTrigger\";\nvar TooltipTrigger = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeTooltip, ...triggerProps } = props;\n const context = useTooltipContext(TRIGGER_NAME, __scopeTooltip);\n const providerContext = useTooltipProviderContext(TRIGGER_NAME, __scopeTooltip);\n const popperScope = usePopperScope(__scopeTooltip);\n const ref = React.useRef(null);\n const composedRefs = useComposedRefs(forwardedRef, ref, context.onTriggerChange);\n const isPointerDownRef = React.useRef(false);\n const hasPointerMoveOpenedRef = React.useRef(false);\n const handlePointerUp = React.useCallback(() => isPointerDownRef.current = false, []);\n React.useEffect(() => {\n return () => document.removeEventListener(\"pointerup\", handlePointerUp);\n }, [handlePointerUp]);\n return /* @__PURE__ */ jsx(PopperPrimitive.Anchor, { asChild: true, ...popperScope, children: /* @__PURE__ */ jsx(\n Primitive.button,\n {\n \"aria-describedby\": context.open ? context.contentId : void 0,\n \"data-state\": context.stateAttribute,\n ...triggerProps,\n ref: composedRefs,\n onPointerMove: composeEventHandlers(props.onPointerMove, (event) => {\n if (event.pointerType === \"touch\") return;\n if (!hasPointerMoveOpenedRef.current && !providerContext.isPointerInTransitRef.current) {\n context.onTriggerEnter();\n hasPointerMoveOpenedRef.current = true;\n }\n }),\n onPointerLeave: composeEventHandlers(props.onPointerLeave, () => {\n context.onTriggerLeave();\n hasPointerMoveOpenedRef.current = false;\n }),\n onPointerDown: composeEventHandlers(props.onPointerDown, () => {\n if (context.open) {\n context.onClose();\n }\n isPointerDownRef.current = true;\n document.addEventListener(\"pointerup\", handlePointerUp, { once: true });\n }),\n onFocus: composeEventHandlers(props.onFocus, () => {\n if (!isPointerDownRef.current) context.onOpen();\n }),\n onBlur: composeEventHandlers(props.onBlur, context.onClose),\n onClick: composeEventHandlers(props.onClick, context.onClose)\n }\n ) });\n }\n);\nTooltipTrigger.displayName = TRIGGER_NAME;\nvar PORTAL_NAME = \"TooltipPortal\";\nvar [PortalProvider, usePortalContext] = createTooltipContext(PORTAL_NAME, {\n forceMount: void 0\n});\nvar TooltipPortal = (props) => {\n const { __scopeTooltip, forceMount, children, container } = props;\n const context = useTooltipContext(PORTAL_NAME, __scopeTooltip);\n return /* @__PURE__ */ jsx(PortalProvider, { scope: __scopeTooltip, forceMount, children: /* @__PURE__ */ jsx(Presence, { present: forceMount || context.open, children: /* @__PURE__ */ jsx(PortalPrimitive, { asChild: true, container, children }) }) });\n};\nTooltipPortal.displayName = PORTAL_NAME;\nvar CONTENT_NAME = \"TooltipContent\";\nvar TooltipContent = React.forwardRef(\n (props, forwardedRef) => {\n const portalContext = usePortalContext(CONTENT_NAME, props.__scopeTooltip);\n const { forceMount = portalContext.forceMount, side = \"top\", ...contentProps } = props;\n const context = useTooltipContext(CONTENT_NAME, props.__scopeTooltip);\n return /* @__PURE__ */ jsx(Presence, { present: forceMount || context.open, children: context.disableHoverableContent ? /* @__PURE__ */ jsx(TooltipContentImpl, { side, ...contentProps, ref: forwardedRef }) : /* @__PURE__ */ jsx(TooltipContentHoverable, { side, ...contentProps, ref: forwardedRef }) });\n }\n);\nvar TooltipContentHoverable = React.forwardRef((props, forwardedRef) => {\n const context = useTooltipContext(CONTENT_NAME, props.__scopeTooltip);\n const providerContext = useTooltipProviderContext(CONTENT_NAME, props.__scopeTooltip);\n const ref = React.useRef(null);\n const composedRefs = useComposedRefs(forwardedRef, ref);\n const [pointerGraceArea, setPointerGraceArea] = React.useState(null);\n const { trigger, onClose } = context;\n const content = ref.current;\n const { onPointerInTransitChange } = providerContext;\n const handleRemoveGraceArea = React.useCallback(() => {\n setPointerGraceArea(null);\n onPointerInTransitChange(false);\n }, [onPointerInTransitChange]);\n const handleCreateGraceArea = React.useCallback(\n (event, hoverTarget) => {\n const currentTarget = event.currentTarget;\n const exitPoint = { x: event.clientX, y: event.clientY };\n const exitSide = getExitSideFromRect(exitPoint, currentTarget.getBoundingClientRect());\n const paddedExitPoints = getPaddedExitPoints(exitPoint, exitSide);\n const hoverTargetPoints = getPointsFromRect(hoverTarget.getBoundingClientRect());\n const graceArea = getHull([...paddedExitPoints, ...hoverTargetPoints]);\n setPointerGraceArea(graceArea);\n onPointerInTransitChange(true);\n },\n [onPointerInTransitChange]\n );\n React.useEffect(() => {\n return () => handleRemoveGraceArea();\n }, [handleRemoveGraceArea]);\n React.useEffect(() => {\n if (trigger && content) {\n const handleTriggerLeave = (event) => handleCreateGraceArea(event, content);\n const handleContentLeave = (event) => handleCreateGraceArea(event, trigger);\n trigger.addEventListener(\"pointerleave\", handleTriggerLeave);\n content.addEventListener(\"pointerleave\", handleContentLeave);\n return () => {\n trigger.removeEventListener(\"pointerleave\", handleTriggerLeave);\n content.removeEventListener(\"pointerleave\", handleContentLeave);\n };\n }\n }, [trigger, content, handleCreateGraceArea, handleRemoveGraceArea]);\n React.useEffect(() => {\n if (pointerGraceArea) {\n const handleTrackPointerGrace = (event) => {\n const target = event.target;\n const pointerPosition = { x: event.clientX, y: event.clientY };\n const hasEnteredTarget = trigger?.contains(target) || content?.contains(target);\n const isPointerOutsideGraceArea = !isPointInPolygon(pointerPosition, pointerGraceArea);\n if (hasEnteredTarget) {\n handleRemoveGraceArea();\n } else if (isPointerOutsideGraceArea) {\n handleRemoveGraceArea();\n onClose();\n }\n };\n document.addEventListener(\"pointermove\", handleTrackPointerGrace);\n return () => document.removeEventListener(\"pointermove\", handleTrackPointerGrace);\n }\n }, [trigger, content, pointerGraceArea, onClose, handleRemoveGraceArea]);\n return /* @__PURE__ */ jsx(TooltipContentImpl, { ...props, ref: composedRefs });\n});\nvar [VisuallyHiddenContentContextProvider, useVisuallyHiddenContentContext] = createTooltipContext(TOOLTIP_NAME, { isInside: false });\nvar Slottable = createSlottable(\"TooltipContent\");\nvar TooltipContentImpl = React.forwardRef(\n (props, forwardedRef) => {\n const {\n __scopeTooltip,\n children,\n \"aria-label\": ariaLabel,\n onEscapeKeyDown,\n onPointerDownOutside,\n ...contentProps\n } = props;\n const context = useTooltipContext(CONTENT_NAME, __scopeTooltip);\n const popperScope = usePopperScope(__scopeTooltip);\n const { onClose } = context;\n React.useEffect(() => {\n document.addEventListener(TOOLTIP_OPEN, onClose);\n return () => document.removeEventListener(TOOLTIP_OPEN, onClose);\n }, [onClose]);\n React.useEffect(() => {\n if (context.trigger) {\n const handleScroll = (event) => {\n const target = event.target;\n if (target?.contains(context.trigger)) onClose();\n };\n window.addEventListener(\"scroll\", handleScroll, { capture: true });\n return () => window.removeEventListener(\"scroll\", handleScroll, { capture: true });\n }\n }, [context.trigger, onClose]);\n return /* @__PURE__ */ jsx(\n DismissableLayer,\n {\n asChild: true,\n disableOutsidePointerEvents: false,\n onEscapeKeyDown,\n onPointerDownOutside,\n onFocusOutside: (event) => event.preventDefault(),\n onDismiss: onClose,\n children: /* @__PURE__ */ jsxs(\n PopperPrimitive.Content,\n {\n \"data-state\": context.stateAttribute,\n ...popperScope,\n ...contentProps,\n ref: forwardedRef,\n style: {\n ...contentProps.style,\n // re-namespace exposed content custom properties\n ...{\n \"--radix-tooltip-content-transform-origin\": \"var(--radix-popper-transform-origin)\",\n \"--radix-tooltip-content-available-width\": \"var(--radix-popper-available-width)\",\n \"--radix-tooltip-content-available-height\": \"var(--radix-popper-available-height)\",\n \"--radix-tooltip-trigger-width\": \"var(--radix-popper-anchor-width)\",\n \"--radix-tooltip-trigger-height\": \"var(--radix-popper-anchor-height)\"\n }\n },\n children: [\n /* @__PURE__ */ jsx(Slottable, { children }),\n /* @__PURE__ */ jsx(VisuallyHiddenContentContextProvider, { scope: __scopeTooltip, isInside: true, children: /* @__PURE__ */ jsx(VisuallyHiddenPrimitive.Root, { id: context.contentId, role: \"tooltip\", children: ariaLabel || children }) })\n ]\n }\n )\n }\n );\n }\n);\nTooltipContent.displayName = CONTENT_NAME;\nvar ARROW_NAME = \"TooltipArrow\";\nvar TooltipArrow = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeTooltip, ...arrowProps } = props;\n const popperScope = usePopperScope(__scopeTooltip);\n const visuallyHiddenContentContext = useVisuallyHiddenContentContext(\n ARROW_NAME,\n __scopeTooltip\n );\n return visuallyHiddenContentContext.isInside ? null : /* @__PURE__ */ jsx(PopperPrimitive.Arrow, { ...popperScope, ...arrowProps, ref: forwardedRef });\n }\n);\nTooltipArrow.displayName = ARROW_NAME;\nfunction getExitSideFromRect(point, rect) {\n const top = Math.abs(rect.top - point.y);\n const bottom = Math.abs(rect.bottom - point.y);\n const right = Math.abs(rect.right - point.x);\n const left = Math.abs(rect.left - point.x);\n switch (Math.min(top, bottom, right, left)) {\n case left:\n return \"left\";\n case right:\n return \"right\";\n case top:\n return \"top\";\n case bottom:\n return \"bottom\";\n default:\n throw new Error(\"unreachable\");\n }\n}\nfunction getPaddedExitPoints(exitPoint, exitSide, padding = 5) {\n const paddedExitPoints = [];\n switch (exitSide) {\n case \"top\":\n paddedExitPoints.push(\n { x: exitPoint.x - padding, y: exitPoint.y + padding },\n { x: exitPoint.x + padding, y: exitPoint.y + padding }\n );\n break;\n case \"bottom\":\n paddedExitPoints.push(\n { x: exitPoint.x - padding, y: exitPoint.y - padding },\n { x: exitPoint.x + padding, y: exitPoint.y - padding }\n );\n break;\n case \"left\":\n paddedExitPoints.push(\n { x: exitPoint.x + padding, y: exitPoint.y - padding },\n { x: exitPoint.x + padding, y: exitPoint.y + padding }\n );\n break;\n case \"right\":\n paddedExitPoints.push(\n { x: exitPoint.x - padding, y: exitPoint.y - padding },\n { x: exitPoint.x - padding, y: exitPoint.y + padding }\n );\n break;\n }\n return paddedExitPoints;\n}\nfunction getPointsFromRect(rect) {\n const { top, right, bottom, left } = rect;\n return [\n { x: left, y: top },\n { x: right, y: top },\n { x: right, y: bottom },\n { x: left, y: bottom }\n ];\n}\nfunction isPointInPolygon(point, polygon) {\n const { x, y } = point;\n let inside = false;\n for (let i = 0, j = polygon.length - 1; i < polygon.length; j = i++) {\n const ii = polygon[i];\n const jj = polygon[j];\n const xi = ii.x;\n const yi = ii.y;\n const xj = jj.x;\n const yj = jj.y;\n const intersect = yi > y !== yj > y && x < (xj - xi) * (y - yi) / (yj - yi) + xi;\n if (intersect) inside = !inside;\n }\n return inside;\n}\nfunction getHull(points) {\n const newPoints = points.slice();\n newPoints.sort((a, b) => {\n if (a.x < b.x) return -1;\n else if (a.x > b.x) return 1;\n else if (a.y < b.y) return -1;\n else if (a.y > b.y) return 1;\n else return 0;\n });\n return getHullPresorted(newPoints);\n}\nfunction getHullPresorted(points) {\n if (points.length <= 1) return points.slice();\n const upperHull = [];\n for (let i = 0; i < points.length; i++) {\n const p = points[i];\n while (upperHull.length >= 2) {\n const q = upperHull[upperHull.length - 1];\n const r = upperHull[upperHull.length - 2];\n if ((q.x - r.x) * (p.y - r.y) >= (q.y - r.y) * (p.x - r.x)) upperHull.pop();\n else break;\n }\n upperHull.push(p);\n }\n upperHull.pop();\n const lowerHull = [];\n for (let i = points.length - 1; i >= 0; i--) {\n const p = points[i];\n while (lowerHull.length >= 2) {\n const q = lowerHull[lowerHull.length - 1];\n const r = lowerHull[lowerHull.length - 2];\n if ((q.x - r.x) * (p.y - r.y) >= (q.y - r.y) * (p.x - r.x)) lowerHull.pop();\n else break;\n }\n lowerHull.push(p);\n }\n lowerHull.pop();\n if (upperHull.length === 1 && lowerHull.length === 1 && upperHull[0].x === lowerHull[0].x && upperHull[0].y === lowerHull[0].y) {\n return upperHull;\n } else {\n return upperHull.concat(lowerHull);\n }\n}\nvar Provider = TooltipProvider;\nvar Root3 = Tooltip;\nvar Trigger = TooltipTrigger;\nvar Portal = TooltipPortal;\nvar Content2 = TooltipContent;\nvar Arrow2 = TooltipArrow;\nexport {\n Arrow2 as Arrow,\n Content2 as Content,\n Portal,\n Provider,\n Root3 as Root,\n Tooltip,\n TooltipArrow,\n TooltipContent,\n TooltipPortal,\n TooltipProvider,\n TooltipTrigger,\n Trigger,\n createTooltipScope\n};\n//# sourceMappingURL=index.mjs.map\n","import * as TooltipPrimitive from '@radix-ui/react-tooltip'\nimport { cn } from '../../lib/cn'\n\n/* ----------------------------------------------------------\n TooltipProvider\n Wrap your app (or Storybook decorator) once with this.\n Controls the global delayDuration and skipDelayDuration.\n ---------------------------------------------------------- */\n\nexport interface TooltipProviderProps\n extends React.ComponentPropsWithoutRef<typeof TooltipPrimitive.Provider> {}\n\nexport const TooltipProvider = TooltipPrimitive.Provider\n\n/* ----------------------------------------------------------\n Tooltip root + trigger\n Re-exported without modification — no styling needed.\n ---------------------------------------------------------- */\n\nexport const Tooltip = TooltipPrimitive.Root\nexport const TooltipTrigger = TooltipPrimitive.Trigger\n\n\n/* ----------------------------------------------------------\n TooltipContent\n ---------------------------------------------------------- */\n\nexport interface TooltipContentProps\n extends React.ComponentPropsWithoutRef<typeof TooltipPrimitive.Content> {}\n\n/**\n * The floating label shown on hover/focus of the trigger.\n * Keep text short — one phrase, no punctuation.\n *\n * @example\n * // Wrap your app once with TooltipProvider, then:\n * <Tooltip>\n * <TooltipTrigger asChild>\n * <Button variant=\"ghost\" size=\"icon\" aria-label=\"Delete row\">\n * <TrashIcon />\n * </Button>\n * </TooltipTrigger>\n * <TooltipContent>Delete row</TooltipContent>\n * </Tooltip>\n */\nexport function TooltipContent({\n className,\n sideOffset = 6,\n side = 'top',\n ...props\n}: TooltipContentProps) {\n return (\n <TooltipPrimitive.Portal>\n <TooltipPrimitive.Content\n sideOffset={sideOffset}\n side={side}\n className={cn(\n // Geometry\n 'rounded-sm px-2.5 py-1.5',\n // Color — inverted: ash bg, paper text\n 'bg-ash text-paper',\n // Typography\n 'font-body text-xs leading-none',\n // Elevation\n 'shadow-[var(--shadow-md)]',\n // Z-index\n 'z-50',\n // Max width — prevent very long strings\n 'max-w-[220px] text-center',\n // Animation\n 'data-[state=delayed-open]:animate-[tooltip-in_100ms_var(--ease-enter)]',\n 'data-[state=instant-open]:animate-[tooltip-in_100ms_var(--ease-enter)]',\n 'data-[state=closed]:animate-[tooltip-out_80ms_var(--ease-exit)]',\n className,\n )}\n {...props}\n />\n </TooltipPrimitive.Portal>\n )\n}\n","import { cn } from '../../lib/cn'\n\nexport type SpinnerSize = 'sm' | 'md' | 'lg'\n\nexport interface SpinnerProps extends React.SVGAttributes<SVGSVGElement> {\n /** Visual size of the spinner. Defaults to 'md'. */\n size?: SpinnerSize\n /** Accessible label announced to screen readers. Defaults to 'Loading'. */\n label?: string\n}\n\nconst sizes: Record<SpinnerSize, string> = {\n sm: 'w-4 h-4',\n md: 'w-6 h-6',\n lg: 'w-8 h-8',\n}\n\n/**\n * Spinning indicator for loading states.\n * Inherits `color` from its parent — place inside a coloured container or\n * set `className=\"text-signal-alt\"` to tint it.\n *\n * @example\n * <Spinner /> // 24px, inherits color\n * <Spinner size=\"sm\" className=\"text-signal-alt\" />\n * <Button disabled><Spinner size=\"sm\" /> Saving…</Button>\n */\nexport function Spinner({\n size = 'md',\n label = 'Loading',\n className,\n ...props\n}: SpinnerProps) {\n return (\n <svg\n role=\"status\"\n aria-label={label}\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n className={cn('animate-spin shrink-0', sizes[size], className)}\n {...props}\n >\n {/* Track ring */}\n <circle\n cx=\"12\"\n cy=\"12\"\n r=\"10\"\n stroke=\"currentColor\"\n strokeWidth=\"2.5\"\n className=\"opacity-20\"\n />\n {/* Active arc — top quarter */}\n <path\n d=\"M12 2a10 10 0 0 1 10 10\"\n stroke=\"currentColor\"\n strokeWidth=\"2.5\"\n strokeLinecap=\"round\"\n />\n </svg>\n )\n}\n","import { cn } from '../../lib/cn'\n\nexport interface SkeletonProps extends React.HTMLAttributes<HTMLDivElement> {}\n\n/**\n * Placeholder shape shown while content is loading.\n * Compose by setting width, height, and border-radius via `className`.\n *\n * @example\n * <Skeleton className=\"w-48 h-4\" /> // text line\n * <Skeleton className=\"w-10 h-10 rounded-full\" /> // avatar\n * <Skeleton className=\"w-full h-32 rounded-md\" /> // card\n */\nexport function Skeleton({ className, ...props }: SkeletonProps) {\n return (\n <div\n aria-hidden=\"true\"\n className={cn('animate-pulse rounded-sm bg-rule', className)}\n {...props}\n />\n )\n}\n","// src/create-context.tsx\nimport * as React from \"react\";\nimport { jsx } from \"react/jsx-runtime\";\nfunction createContext2(rootComponentName, defaultContext) {\n const Context = React.createContext(defaultContext);\n Context.displayName = rootComponentName + \"Context\";\n const Provider = (props) => {\n const { children, ...context } = props;\n const value = React.useMemo(() => context, Object.values(context));\n return /* @__PURE__ */ jsx(Context.Provider, { value, children });\n };\n Provider.displayName = rootComponentName + \"Provider\";\n function useContext2(consumerName) {\n const context = React.useContext(Context);\n if (context) return context;\n if (defaultContext !== void 0) return defaultContext;\n throw new Error(`\\`${consumerName}\\` must be used within \\`${rootComponentName}\\``);\n }\n return [Provider, useContext2];\n}\nfunction createContextScope(scopeName, createContextScopeDeps = []) {\n let defaultContexts = [];\n function createContext3(rootComponentName, defaultContext) {\n const BaseContext = React.createContext(defaultContext);\n BaseContext.displayName = rootComponentName + \"Context\";\n const index = defaultContexts.length;\n defaultContexts = [...defaultContexts, defaultContext];\n const Provider = (props) => {\n const { scope, children, ...context } = props;\n const Context = scope?.[scopeName]?.[index] || BaseContext;\n const value = React.useMemo(() => context, Object.values(context));\n return /* @__PURE__ */ jsx(Context.Provider, { value, children });\n };\n Provider.displayName = rootComponentName + \"Provider\";\n function useContext2(consumerName, scope) {\n const Context = scope?.[scopeName]?.[index] || BaseContext;\n const context = React.useContext(Context);\n if (context) return context;\n if (defaultContext !== void 0) return defaultContext;\n throw new Error(`\\`${consumerName}\\` must be used within \\`${rootComponentName}\\``);\n }\n return [Provider, useContext2];\n }\n const createScope = () => {\n const scopeContexts = defaultContexts.map((defaultContext) => {\n return React.createContext(defaultContext);\n });\n return function useScope(scope) {\n const contexts = scope?.[scopeName] || scopeContexts;\n return React.useMemo(\n () => ({ [`__scope${scopeName}`]: { ...scope, [scopeName]: contexts } }),\n [scope, contexts]\n );\n };\n };\n createScope.scopeName = scopeName;\n return [createContext3, composeContextScopes(createScope, ...createContextScopeDeps)];\n}\nfunction composeContextScopes(...scopes) {\n const baseScope = scopes[0];\n if (scopes.length === 1) return baseScope;\n const createScope = () => {\n const scopeHooks = scopes.map((createScope2) => ({\n useScope: createScope2(),\n scopeName: createScope2.scopeName\n }));\n return function useComposedScopes(overrideScopes) {\n const nextScopes = scopeHooks.reduce((nextScopes2, { useScope, scopeName }) => {\n const scopeProps = useScope(overrideScopes);\n const currentScope = scopeProps[`__scope${scopeName}`];\n return { ...nextScopes2, ...currentScope };\n }, {});\n return React.useMemo(() => ({ [`__scope${baseScope.scopeName}`]: nextScopes }), [nextScopes]);\n };\n };\n createScope.scopeName = baseScope.scopeName;\n return createScope;\n}\nexport {\n createContext2 as createContext,\n createContextScope\n};\n//# sourceMappingURL=index.mjs.map\n","// src/primitive.tsx\nimport * as React from \"react\";\nimport * as ReactDOM from \"react-dom\";\nimport { createSlot } from \"@radix-ui/react-slot\";\nimport { jsx } from \"react/jsx-runtime\";\nvar NODES = [\n \"a\",\n \"button\",\n \"div\",\n \"form\",\n \"h2\",\n \"h3\",\n \"img\",\n \"input\",\n \"label\",\n \"li\",\n \"nav\",\n \"ol\",\n \"p\",\n \"select\",\n \"span\",\n \"svg\",\n \"ul\"\n];\nvar Primitive = NODES.reduce((primitive, node) => {\n const Slot = createSlot(`Primitive.${node}`);\n const Node = React.forwardRef((props, forwardedRef) => {\n const { asChild, ...primitiveProps } = props;\n const Comp = asChild ? Slot : node;\n if (typeof window !== \"undefined\") {\n window[Symbol.for(\"radix-ui\")] = true;\n }\n return /* @__PURE__ */ jsx(Comp, { ...primitiveProps, ref: forwardedRef });\n });\n Node.displayName = `Primitive.${node}`;\n return { ...primitive, [node]: Node };\n}, {});\nfunction dispatchDiscreteCustomEvent(target, event) {\n if (target) ReactDOM.flushSync(() => target.dispatchEvent(event));\n}\nvar Root = Primitive;\nexport {\n Primitive,\n Root,\n dispatchDiscreteCustomEvent\n};\n//# sourceMappingURL=index.mjs.map\n","\"use client\";\n\n// src/progress.tsx\nimport * as React from \"react\";\nimport { createContextScope } from \"@radix-ui/react-context\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { jsx } from \"react/jsx-runtime\";\nvar PROGRESS_NAME = \"Progress\";\nvar DEFAULT_MAX = 100;\nvar [createProgressContext, createProgressScope] = createContextScope(PROGRESS_NAME);\nvar [ProgressProvider, useProgressContext] = createProgressContext(PROGRESS_NAME);\nvar Progress = React.forwardRef(\n (props, forwardedRef) => {\n const {\n __scopeProgress,\n value: valueProp = null,\n max: maxProp,\n getValueLabel = defaultGetValueLabel,\n ...progressProps\n } = props;\n if ((maxProp || maxProp === 0) && !isValidMaxNumber(maxProp)) {\n console.error(getInvalidMaxError(`${maxProp}`, \"Progress\"));\n }\n const max = isValidMaxNumber(maxProp) ? maxProp : DEFAULT_MAX;\n if (valueProp !== null && !isValidValueNumber(valueProp, max)) {\n console.error(getInvalidValueError(`${valueProp}`, \"Progress\"));\n }\n const value = isValidValueNumber(valueProp, max) ? valueProp : null;\n const valueLabel = isNumber(value) ? getValueLabel(value, max) : void 0;\n return /* @__PURE__ */ jsx(ProgressProvider, { scope: __scopeProgress, value, max, children: /* @__PURE__ */ jsx(\n Primitive.div,\n {\n \"aria-valuemax\": max,\n \"aria-valuemin\": 0,\n \"aria-valuenow\": isNumber(value) ? value : void 0,\n \"aria-valuetext\": valueLabel,\n role: \"progressbar\",\n \"data-state\": getProgressState(value, max),\n \"data-value\": value ?? void 0,\n \"data-max\": max,\n ...progressProps,\n ref: forwardedRef\n }\n ) });\n }\n);\nProgress.displayName = PROGRESS_NAME;\nvar INDICATOR_NAME = \"ProgressIndicator\";\nvar ProgressIndicator = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeProgress, ...indicatorProps } = props;\n const context = useProgressContext(INDICATOR_NAME, __scopeProgress);\n return /* @__PURE__ */ jsx(\n Primitive.div,\n {\n \"data-state\": getProgressState(context.value, context.max),\n \"data-value\": context.value ?? void 0,\n \"data-max\": context.max,\n ...indicatorProps,\n ref: forwardedRef\n }\n );\n }\n);\nProgressIndicator.displayName = INDICATOR_NAME;\nfunction defaultGetValueLabel(value, max) {\n return `${Math.round(value / max * 100)}%`;\n}\nfunction getProgressState(value, maxValue) {\n return value == null ? \"indeterminate\" : value === maxValue ? \"complete\" : \"loading\";\n}\nfunction isNumber(value) {\n return typeof value === \"number\";\n}\nfunction isValidMaxNumber(max) {\n return isNumber(max) && !isNaN(max) && max > 0;\n}\nfunction isValidValueNumber(value, max) {\n return isNumber(value) && !isNaN(value) && value <= max && value >= 0;\n}\nfunction getInvalidMaxError(propValue, componentName) {\n return `Invalid prop \\`max\\` of value \\`${propValue}\\` supplied to \\`${componentName}\\`. Only numbers greater than 0 are valid max values. Defaulting to \\`${DEFAULT_MAX}\\`.`;\n}\nfunction getInvalidValueError(propValue, componentName) {\n return `Invalid prop \\`value\\` of value \\`${propValue}\\` supplied to \\`${componentName}\\`. The \\`value\\` prop must be:\n - a positive number\n - less than the value passed to \\`max\\` (or ${DEFAULT_MAX} if no \\`max\\` prop is set)\n - \\`null\\` or \\`undefined\\` if the progress is indeterminate.\n\nDefaulting to \\`null\\`.`;\n}\nvar Root = Progress;\nvar Indicator = ProgressIndicator;\nexport {\n Indicator,\n Progress,\n ProgressIndicator,\n Root,\n createProgressScope\n};\n//# sourceMappingURL=index.mjs.map\n","import * as ProgressPrimitive from '@radix-ui/react-progress'\nimport { cn } from '../../lib/cn'\n\nexport type ProgressSize = 'sm' | 'md' | 'lg'\nexport type ProgressVariant = 'default' | 'warning' | 'danger' | 'success'\n\nexport interface ProgressProps\n extends Omit<React.ComponentPropsWithoutRef<typeof ProgressPrimitive.Root>, 'value'> {\n /** Current value (0–max). Defaults to 0. */\n value?: number\n /** Maximum value. Defaults to 100. */\n max?: number\n /** Track height. Defaults to 'md'. */\n size?: ProgressSize\n /** Indicator colour. Defaults to 'default' (signal-alt blue). */\n variant?: ProgressVariant\n /** Accessible label for the progress bar. */\n label?: string\n /** Render the numeric percentage to the right of the label row. */\n showValue?: boolean\n}\n\nconst trackSizes: Record<ProgressSize, string> = {\n sm: 'h-1.5',\n md: 'h-2.5',\n lg: 'h-4',\n}\n\nconst indicatorColors: Record<ProgressVariant, string> = {\n default: 'bg-signal-alt',\n warning: 'bg-[var(--color-caution)]',\n danger: 'bg-signal',\n success: 'bg-[var(--color-growth)]',\n}\n\n/**\n * Horizontal progress bar built on Radix Progress.\n * Manages ARIA progressbar role, aria-valuenow/min/max automatically.\n *\n * @example\n * <Progress value={65} />\n * <Progress value={65} label=\"Budget used\" showValue variant=\"warning\" />\n */\nexport function Progress({\n value = 0,\n max = 100,\n size = 'md',\n variant = 'default',\n label,\n showValue = false,\n className,\n ...props\n}: ProgressProps) {\n const pct = Math.min(100, Math.max(0, max > 0 ? (value / max) * 100 : 0))\n\n return (\n <div className={cn('flex flex-col gap-1', className)}>\n {(label || showValue) && (\n <div className=\"flex items-center justify-between gap-3\">\n {label && (\n <span className=\"text-sm text-smoke\">{label}</span>\n )}\n {showValue && (\n <span className=\"text-sm text-smoke tabular-nums ml-auto\">\n {Math.round(pct)}%\n </span>\n )}\n </div>\n )}\n\n <ProgressPrimitive.Root\n value={value}\n max={max}\n aria-label={label ?? 'Progress'}\n className={cn(\n 'relative w-full overflow-hidden rounded-full bg-rule',\n trackSizes[size],\n )}\n {...props}\n >\n <ProgressPrimitive.Indicator\n className={cn(\n 'h-full transition-[width] duration-slow ease-(--ease-standard)',\n indicatorColors[variant],\n )}\n style={{ width: `${pct}%` }}\n />\n </ProgressPrimitive.Root>\n </div>\n )\n}\n","import { cn } from '../../lib/cn'\n\nexport type StatDeltaDirection = 'up' | 'down' | 'neutral'\n\nexport interface StatProps extends React.HTMLAttributes<HTMLDivElement> {\n /** Primary metric value — number, currency string, percentage, etc. */\n value: string | number\n /** Short label identifying the metric. Rendered in display font uppercase. */\n label: string\n /** Change indicator text, e.g. \"+$8,200\" or \"-4%\". */\n delta?: string | number\n /** Direction controls colour: up=green, down=red, neutral=smoke. Defaults to 'neutral'. */\n deltaDirection?: StatDeltaDirection\n /** Secondary supporting text shown below the value row. */\n caption?: string\n}\n\nconst deltaColors: Record<StatDeltaDirection, string> = {\n up: 'text-[var(--color-growth)]',\n down: 'text-signal',\n neutral: 'text-smoke',\n}\n\nconst deltaIcons: Record<StatDeltaDirection, string> = {\n up: '↑',\n down: '↓',\n neutral: '—',\n}\n\n/**\n * KPI tile displaying a headline metric with optional delta indicator.\n * Designed for dashboard summary rows and project header strips.\n *\n * @example\n * <Stat label=\"Contract Value\" value=\"$1.24M\" />\n * <Stat label=\"Budget Used\" value=\"62%\" delta=\"+8%\" deltaDirection=\"up\" caption=\"this period\" />\n */\nexport function Stat({\n value,\n label,\n delta,\n deltaDirection = 'neutral',\n caption,\n className,\n ...props\n}: StatProps) {\n return (\n <div\n className={cn(\n 'flex flex-col gap-1 p-4 border border-rule rounded-md bg-paper',\n className,\n )}\n {...props}\n >\n {/* Metric label */}\n <span className=\"font-display text-xs tracking-widest uppercase text-smoke leading-none\">\n {label}\n </span>\n\n {/* Value + delta */}\n <div className=\"flex items-baseline gap-2 mt-0.5\">\n <span className=\"font-display font-bold text-2xl text-void leading-none tabular-nums\">\n {value}\n </span>\n {delta !== undefined && (\n <span\n className={cn('text-sm font-medium tabular-nums leading-none', deltaColors[deltaDirection])}\n aria-label={`${deltaDirection === 'up' ? 'increase' : deltaDirection === 'down' ? 'decrease' : 'no change'} of ${delta}`}\n >\n <span aria-hidden=\"true\">{deltaIcons[deltaDirection]} </span>\n {delta}\n </span>\n )}\n </div>\n\n {/* Supporting caption */}\n {caption && (\n <span className=\"text-sm text-smoke leading-snug\">{caption}</span>\n )}\n </div>\n )\n}\n","// src/create-context.tsx\nimport * as React from \"react\";\nimport { jsx } from \"react/jsx-runtime\";\nfunction createContext2(rootComponentName, defaultContext) {\n const Context = React.createContext(defaultContext);\n Context.displayName = rootComponentName + \"Context\";\n const Provider = (props) => {\n const { children, ...context } = props;\n const value = React.useMemo(() => context, Object.values(context));\n return /* @__PURE__ */ jsx(Context.Provider, { value, children });\n };\n Provider.displayName = rootComponentName + \"Provider\";\n function useContext2(consumerName) {\n const context = React.useContext(Context);\n if (context) return context;\n if (defaultContext !== void 0) return defaultContext;\n throw new Error(`\\`${consumerName}\\` must be used within \\`${rootComponentName}\\``);\n }\n return [Provider, useContext2];\n}\nfunction createContextScope(scopeName, createContextScopeDeps = []) {\n let defaultContexts = [];\n function createContext3(rootComponentName, defaultContext) {\n const BaseContext = React.createContext(defaultContext);\n BaseContext.displayName = rootComponentName + \"Context\";\n const index = defaultContexts.length;\n defaultContexts = [...defaultContexts, defaultContext];\n const Provider = (props) => {\n const { scope, children, ...context } = props;\n const Context = scope?.[scopeName]?.[index] || BaseContext;\n const value = React.useMemo(() => context, Object.values(context));\n return /* @__PURE__ */ jsx(Context.Provider, { value, children });\n };\n Provider.displayName = rootComponentName + \"Provider\";\n function useContext2(consumerName, scope) {\n const Context = scope?.[scopeName]?.[index] || BaseContext;\n const context = React.useContext(Context);\n if (context) return context;\n if (defaultContext !== void 0) return defaultContext;\n throw new Error(`\\`${consumerName}\\` must be used within \\`${rootComponentName}\\``);\n }\n return [Provider, useContext2];\n }\n const createScope = () => {\n const scopeContexts = defaultContexts.map((defaultContext) => {\n return React.createContext(defaultContext);\n });\n return function useScope(scope) {\n const contexts = scope?.[scopeName] || scopeContexts;\n return React.useMemo(\n () => ({ [`__scope${scopeName}`]: { ...scope, [scopeName]: contexts } }),\n [scope, contexts]\n );\n };\n };\n createScope.scopeName = scopeName;\n return [createContext3, composeContextScopes(createScope, ...createContextScopeDeps)];\n}\nfunction composeContextScopes(...scopes) {\n const baseScope = scopes[0];\n if (scopes.length === 1) return baseScope;\n const createScope = () => {\n const scopeHooks = scopes.map((createScope2) => ({\n useScope: createScope2(),\n scopeName: createScope2.scopeName\n }));\n return function useComposedScopes(overrideScopes) {\n const nextScopes = scopeHooks.reduce((nextScopes2, { useScope, scopeName }) => {\n const scopeProps = useScope(overrideScopes);\n const currentScope = scopeProps[`__scope${scopeName}`];\n return { ...nextScopes2, ...currentScope };\n }, {});\n return React.useMemo(() => ({ [`__scope${baseScope.scopeName}`]: nextScopes }), [nextScopes]);\n };\n };\n createScope.scopeName = baseScope.scopeName;\n return createScope;\n}\nexport {\n createContext2 as createContext,\n createContextScope\n};\n//# sourceMappingURL=index.mjs.map\n","// src/primitive.tsx\nimport * as React from \"react\";\nimport * as ReactDOM from \"react-dom\";\nimport { createSlot } from \"@radix-ui/react-slot\";\nimport { jsx } from \"react/jsx-runtime\";\nvar NODES = [\n \"a\",\n \"button\",\n \"div\",\n \"form\",\n \"h2\",\n \"h3\",\n \"img\",\n \"input\",\n \"label\",\n \"li\",\n \"nav\",\n \"ol\",\n \"p\",\n \"select\",\n \"span\",\n \"svg\",\n \"ul\"\n];\nvar Primitive = NODES.reduce((primitive, node) => {\n const Slot = createSlot(`Primitive.${node}`);\n const Node = React.forwardRef((props, forwardedRef) => {\n const { asChild, ...primitiveProps } = props;\n const Comp = asChild ? Slot : node;\n if (typeof window !== \"undefined\") {\n window[Symbol.for(\"radix-ui\")] = true;\n }\n return /* @__PURE__ */ jsx(Comp, { ...primitiveProps, ref: forwardedRef });\n });\n Node.displayName = `Primitive.${node}`;\n return { ...primitive, [node]: Node };\n}, {});\nfunction dispatchDiscreteCustomEvent(target, event) {\n if (target) ReactDOM.flushSync(() => target.dispatchEvent(event));\n}\nvar Root = Primitive;\nexport {\n Primitive,\n Root,\n dispatchDiscreteCustomEvent\n};\n//# sourceMappingURL=index.mjs.map\n","/**\n * @license React\n * use-sync-external-store-shim.production.js\n *\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n\"use strict\";\nvar React = require(\"react\");\nfunction is(x, y) {\n return (x === y && (0 !== x || 1 / x === 1 / y)) || (x !== x && y !== y);\n}\nvar objectIs = \"function\" === typeof Object.is ? Object.is : is,\n useState = React.useState,\n useEffect = React.useEffect,\n useLayoutEffect = React.useLayoutEffect,\n useDebugValue = React.useDebugValue;\nfunction useSyncExternalStore$2(subscribe, getSnapshot) {\n var value = getSnapshot(),\n _useState = useState({ inst: { value: value, getSnapshot: getSnapshot } }),\n inst = _useState[0].inst,\n forceUpdate = _useState[1];\n useLayoutEffect(\n function () {\n inst.value = value;\n inst.getSnapshot = getSnapshot;\n checkIfSnapshotChanged(inst) && forceUpdate({ inst: inst });\n },\n [subscribe, value, getSnapshot]\n );\n useEffect(\n function () {\n checkIfSnapshotChanged(inst) && forceUpdate({ inst: inst });\n return subscribe(function () {\n checkIfSnapshotChanged(inst) && forceUpdate({ inst: inst });\n });\n },\n [subscribe]\n );\n useDebugValue(value);\n return value;\n}\nfunction checkIfSnapshotChanged(inst) {\n var latestGetSnapshot = inst.getSnapshot;\n inst = inst.value;\n try {\n var nextValue = latestGetSnapshot();\n return !objectIs(inst, nextValue);\n } catch (error) {\n return !0;\n }\n}\nfunction useSyncExternalStore$1(subscribe, getSnapshot) {\n return getSnapshot();\n}\nvar shim =\n \"undefined\" === typeof window ||\n \"undefined\" === typeof window.document ||\n \"undefined\" === typeof window.document.createElement\n ? useSyncExternalStore$1\n : useSyncExternalStore$2;\nexports.useSyncExternalStore =\n void 0 !== React.useSyncExternalStore ? React.useSyncExternalStore : shim;\n","/**\n * @license React\n * use-sync-external-store-shim.development.js\n *\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n\"use strict\";\n\"production\" !== process.env.NODE_ENV &&\n (function () {\n function is(x, y) {\n return (x === y && (0 !== x || 1 / x === 1 / y)) || (x !== x && y !== y);\n }\n function useSyncExternalStore$2(subscribe, getSnapshot) {\n didWarnOld18Alpha ||\n void 0 === React.startTransition ||\n ((didWarnOld18Alpha = !0),\n console.error(\n \"You are using an outdated, pre-release alpha of React 18 that does not support useSyncExternalStore. The use-sync-external-store shim will not work correctly. Upgrade to a newer pre-release.\"\n ));\n var value = getSnapshot();\n if (!didWarnUncachedGetSnapshot) {\n var cachedValue = getSnapshot();\n objectIs(value, cachedValue) ||\n (console.error(\n \"The result of getSnapshot should be cached to avoid an infinite loop\"\n ),\n (didWarnUncachedGetSnapshot = !0));\n }\n cachedValue = useState({\n inst: { value: value, getSnapshot: getSnapshot }\n });\n var inst = cachedValue[0].inst,\n forceUpdate = cachedValue[1];\n useLayoutEffect(\n function () {\n inst.value = value;\n inst.getSnapshot = getSnapshot;\n checkIfSnapshotChanged(inst) && forceUpdate({ inst: inst });\n },\n [subscribe, value, getSnapshot]\n );\n useEffect(\n function () {\n checkIfSnapshotChanged(inst) && forceUpdate({ inst: inst });\n return subscribe(function () {\n checkIfSnapshotChanged(inst) && forceUpdate({ inst: inst });\n });\n },\n [subscribe]\n );\n useDebugValue(value);\n return value;\n }\n function checkIfSnapshotChanged(inst) {\n var latestGetSnapshot = inst.getSnapshot;\n inst = inst.value;\n try {\n var nextValue = latestGetSnapshot();\n return !objectIs(inst, nextValue);\n } catch (error) {\n return !0;\n }\n }\n function useSyncExternalStore$1(subscribe, getSnapshot) {\n return getSnapshot();\n }\n \"undefined\" !== typeof __REACT_DEVTOOLS_GLOBAL_HOOK__ &&\n \"function\" ===\n typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStart &&\n __REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStart(Error());\n var React = require(\"react\"),\n objectIs = \"function\" === typeof Object.is ? Object.is : is,\n useState = React.useState,\n useEffect = React.useEffect,\n useLayoutEffect = React.useLayoutEffect,\n useDebugValue = React.useDebugValue,\n didWarnOld18Alpha = !1,\n didWarnUncachedGetSnapshot = !1,\n shim =\n \"undefined\" === typeof window ||\n \"undefined\" === typeof window.document ||\n \"undefined\" === typeof window.document.createElement\n ? useSyncExternalStore$1\n : useSyncExternalStore$2;\n exports.useSyncExternalStore =\n void 0 !== React.useSyncExternalStore ? React.useSyncExternalStore : shim;\n \"undefined\" !== typeof __REACT_DEVTOOLS_GLOBAL_HOOK__ &&\n \"function\" ===\n typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStop &&\n __REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStop(Error());\n })();\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('../cjs/use-sync-external-store-shim.production.js');\n} else {\n module.exports = require('../cjs/use-sync-external-store-shim.development.js');\n}\n","// src/use-is-hydrated.tsx\nimport { useSyncExternalStore } from \"use-sync-external-store/shim\";\nfunction useIsHydrated() {\n return useSyncExternalStore(\n subscribe,\n () => true,\n () => false\n );\n}\nfunction subscribe() {\n return () => {\n };\n}\nexport {\n useIsHydrated\n};\n//# sourceMappingURL=index.mjs.map\n","\"use client\";\n\n// src/avatar.tsx\nimport * as React from \"react\";\nimport { createContextScope } from \"@radix-ui/react-context\";\nimport { useCallbackRef } from \"@radix-ui/react-use-callback-ref\";\nimport { useLayoutEffect } from \"@radix-ui/react-use-layout-effect\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { useIsHydrated } from \"@radix-ui/react-use-is-hydrated\";\nimport { jsx } from \"react/jsx-runtime\";\nvar AVATAR_NAME = \"Avatar\";\nvar [createAvatarContext, createAvatarScope] = createContextScope(AVATAR_NAME);\nvar [AvatarProvider, useAvatarContext] = createAvatarContext(AVATAR_NAME);\nvar Avatar = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeAvatar, ...avatarProps } = props;\n const [imageLoadingStatus, setImageLoadingStatus] = React.useState(\"idle\");\n return /* @__PURE__ */ jsx(\n AvatarProvider,\n {\n scope: __scopeAvatar,\n imageLoadingStatus,\n onImageLoadingStatusChange: setImageLoadingStatus,\n children: /* @__PURE__ */ jsx(Primitive.span, { ...avatarProps, ref: forwardedRef })\n }\n );\n }\n);\nAvatar.displayName = AVATAR_NAME;\nvar IMAGE_NAME = \"AvatarImage\";\nvar AvatarImage = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeAvatar, src, onLoadingStatusChange = () => {\n }, ...imageProps } = props;\n const context = useAvatarContext(IMAGE_NAME, __scopeAvatar);\n const imageLoadingStatus = useImageLoadingStatus(src, imageProps);\n const handleLoadingStatusChange = useCallbackRef((status) => {\n onLoadingStatusChange(status);\n context.onImageLoadingStatusChange(status);\n });\n useLayoutEffect(() => {\n if (imageLoadingStatus !== \"idle\") {\n handleLoadingStatusChange(imageLoadingStatus);\n }\n }, [imageLoadingStatus, handleLoadingStatusChange]);\n return imageLoadingStatus === \"loaded\" ? /* @__PURE__ */ jsx(Primitive.img, { ...imageProps, ref: forwardedRef, src }) : null;\n }\n);\nAvatarImage.displayName = IMAGE_NAME;\nvar FALLBACK_NAME = \"AvatarFallback\";\nvar AvatarFallback = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeAvatar, delayMs, ...fallbackProps } = props;\n const context = useAvatarContext(FALLBACK_NAME, __scopeAvatar);\n const [canRender, setCanRender] = React.useState(delayMs === void 0);\n React.useEffect(() => {\n if (delayMs !== void 0) {\n const timerId = window.setTimeout(() => setCanRender(true), delayMs);\n return () => window.clearTimeout(timerId);\n }\n }, [delayMs]);\n return canRender && context.imageLoadingStatus !== \"loaded\" ? /* @__PURE__ */ jsx(Primitive.span, { ...fallbackProps, ref: forwardedRef }) : null;\n }\n);\nAvatarFallback.displayName = FALLBACK_NAME;\nfunction resolveLoadingStatus(image, src) {\n if (!image) {\n return \"idle\";\n }\n if (!src) {\n return \"error\";\n }\n if (image.src !== src) {\n image.src = src;\n }\n return image.complete && image.naturalWidth > 0 ? \"loaded\" : \"loading\";\n}\nfunction useImageLoadingStatus(src, { referrerPolicy, crossOrigin }) {\n const isHydrated = useIsHydrated();\n const imageRef = React.useRef(null);\n const image = (() => {\n if (!isHydrated) return null;\n if (!imageRef.current) {\n imageRef.current = new window.Image();\n }\n return imageRef.current;\n })();\n const [loadingStatus, setLoadingStatus] = React.useState(\n () => resolveLoadingStatus(image, src)\n );\n useLayoutEffect(() => {\n setLoadingStatus(resolveLoadingStatus(image, src));\n }, [image, src]);\n useLayoutEffect(() => {\n const updateStatus = (status) => () => {\n setLoadingStatus(status);\n };\n if (!image) return;\n const handleLoad = updateStatus(\"loaded\");\n const handleError = updateStatus(\"error\");\n image.addEventListener(\"load\", handleLoad);\n image.addEventListener(\"error\", handleError);\n if (referrerPolicy) {\n image.referrerPolicy = referrerPolicy;\n }\n if (typeof crossOrigin === \"string\") {\n image.crossOrigin = crossOrigin;\n }\n return () => {\n image.removeEventListener(\"load\", handleLoad);\n image.removeEventListener(\"error\", handleError);\n };\n }, [image, crossOrigin, referrerPolicy]);\n return loadingStatus;\n}\nvar Root = Avatar;\nvar Image = AvatarImage;\nvar Fallback = AvatarFallback;\nexport {\n Avatar,\n AvatarFallback,\n AvatarImage,\n Fallback,\n Image,\n Root,\n createAvatarScope\n};\n//# sourceMappingURL=index.mjs.map\n","import React from 'react'\nimport * as AvatarPrimitive from '@radix-ui/react-avatar'\nimport { cn } from '../../lib/cn'\n\nexport type AvatarSize = 'sm' | 'md' | 'lg' | 'xl'\n\nexport interface AvatarProps\n extends React.ComponentPropsWithoutRef<typeof AvatarPrimitive.Root> {\n /** Image URL. When absent or broken the initials fallback renders. */\n src?: string\n /** Person's name — used for initials fallback and alt text. */\n alt?: string\n /** Visual size. Defaults to 'md'. */\n size?: AvatarSize\n}\n\nexport interface AvatarGroupProps extends React.HTMLAttributes<HTMLDivElement> {\n /** Maximum avatars to display before showing an overflow count. Defaults to 4. */\n max?: number\n /** Size forwarded to the overflow badge. Match the size used on child Avatars. Defaults to 'md'. */\n size?: AvatarSize\n}\n\n/* ----------------------------------------------------------\n Sizes\n ---------------------------------------------------------- */\n\nconst sizeClasses: Record<AvatarSize, string> = {\n sm: 'w-6 h-6 text-[10px]',\n md: 'w-8 h-8 text-xs',\n lg: 'w-10 h-10 text-sm',\n xl: 'w-12 h-12 text-base',\n}\n\n/* ----------------------------------------------------------\n Deterministic fallback colour — hash name → one of 6 palettes\n ---------------------------------------------------------- */\n\nconst fallbackPalettes = [\n 'bg-signal-alt text-paper',\n 'bg-[var(--color-growth)] text-paper',\n 'bg-[var(--color-caution)] text-paper',\n 'bg-signal text-paper',\n 'bg-ash text-paper',\n 'bg-smoke text-paper',\n]\n\nfunction hashName(name: string): number {\n let h = 0\n for (let i = 0; i < name.length; i++) {\n h = (h * 31 + name.charCodeAt(i)) >>> 0\n }\n return h\n}\n\nfunction getInitials(name: string): string {\n const parts = name.trim().split(/\\s+/).filter(Boolean)\n if (parts.length === 0) return '?'\n if (parts.length === 1) return parts[0].slice(0, 2).toUpperCase()\n return (parts[0][0] + parts[parts.length - 1][0]).toUpperCase()\n}\n\n/* ----------------------------------------------------------\n Avatar\n ---------------------------------------------------------- */\n\n/**\n * Circular user avatar — shows an image when available, falls back to\n * coloured initials derived from `alt`.\n *\n * @example\n * <Avatar src=\"/avatars/jlee.jpg\" alt=\"Jordan Lee\" />\n * <Avatar alt=\"Jordan Lee\" /> // initials fallback\n * <Avatar alt=\"Jordan Lee\" size=\"lg\" />\n */\nexport function Avatar({\n src,\n alt = '',\n size = 'md',\n className,\n ...props\n}: AvatarProps) {\n const initials = getInitials(alt)\n const palette = fallbackPalettes[hashName(alt) % fallbackPalettes.length]\n\n return (\n <AvatarPrimitive.Root\n className={cn(\n 'relative inline-flex items-center justify-center rounded-full overflow-hidden shrink-0 select-none',\n sizeClasses[size],\n className,\n )}\n {...props}\n >\n {src && (\n <AvatarPrimitive.Image\n src={src}\n alt={alt}\n className=\"w-full h-full object-cover\"\n />\n )}\n <AvatarPrimitive.Fallback\n className={cn(\n 'flex items-center justify-center w-full h-full font-display font-bold leading-none',\n palette,\n )}\n delayMs={src ? 300 : 0}\n >\n {initials}\n </AvatarPrimitive.Fallback>\n </AvatarPrimitive.Root>\n )\n}\n\n/* ----------------------------------------------------------\n AvatarGroup\n ---------------------------------------------------------- */\n\n/**\n * Stacks multiple Avatars with overlap rings. Shows a \"+N\" overflow badge\n * when children exceed `max`.\n *\n * @example\n * <AvatarGroup max={3}>\n * <Avatar alt=\"Alex Kovacs\" />\n * <Avatar alt=\"Jordan Lee\" />\n * <Avatar alt=\"Maria da Silva\" />\n * <Avatar alt=\"Sam Chen\" /> // → \"+1\" badge\n * </AvatarGroup>\n */\nexport function AvatarGroup({\n children,\n max = 4,\n size = 'md',\n className,\n ...props\n}: AvatarGroupProps) {\n const all = React.Children.toArray(children)\n const visible = all.slice(0, max)\n const overflow = all.length - max\n\n return (\n <div className={cn('flex items-center', className)} {...props}>\n {visible.map((child, i) => (\n <div\n key={i}\n className={cn(\n 'ring-2 ring-paper rounded-full',\n i > 0 && '-ml-2',\n )}\n >\n {child}\n </div>\n ))}\n\n {overflow > 0 && (\n <div\n aria-label={`${overflow} more team members`}\n className={cn(\n '-ml-2 ring-2 ring-paper rounded-full flex items-center justify-center',\n 'bg-rule text-smoke font-display font-bold shrink-0',\n sizeClasses[size],\n )}\n >\n +{overflow}\n </div>\n )}\n </div>\n )\n}\n","\"use client\";\n\n// src/radio-group.tsx\nimport * as React2 from \"react\";\nimport { composeEventHandlers as composeEventHandlers2 } from \"@radix-ui/primitive\";\nimport { useComposedRefs as useComposedRefs2 } from \"@radix-ui/react-compose-refs\";\nimport { createContextScope as createContextScope2 } from \"@radix-ui/react-context\";\nimport { Primitive as Primitive2 } from \"@radix-ui/react-primitive\";\nimport * as RovingFocusGroup from \"@radix-ui/react-roving-focus\";\nimport { createRovingFocusGroupScope } from \"@radix-ui/react-roving-focus\";\nimport { useControllableState } from \"@radix-ui/react-use-controllable-state\";\nimport { useDirection } from \"@radix-ui/react-direction\";\n\n// src/radio.tsx\nimport * as React from \"react\";\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { createContextScope } from \"@radix-ui/react-context\";\nimport { useSize } from \"@radix-ui/react-use-size\";\nimport { usePrevious } from \"@radix-ui/react-use-previous\";\nimport { Presence } from \"@radix-ui/react-presence\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { jsx, jsxs } from \"react/jsx-runtime\";\nvar RADIO_NAME = \"Radio\";\nvar [createRadioContext, createRadioScope] = createContextScope(RADIO_NAME);\nvar [RadioProvider, useRadioContext] = createRadioContext(RADIO_NAME);\nvar Radio = React.forwardRef(\n (props, forwardedRef) => {\n const {\n __scopeRadio,\n name,\n checked = false,\n required,\n disabled,\n value = \"on\",\n onCheck,\n form,\n ...radioProps\n } = props;\n const [button, setButton] = React.useState(null);\n const composedRefs = useComposedRefs(forwardedRef, (node) => setButton(node));\n const hasConsumerStoppedPropagationRef = React.useRef(false);\n const isFormControl = button ? form || !!button.closest(\"form\") : true;\n return /* @__PURE__ */ jsxs(RadioProvider, { scope: __scopeRadio, checked, disabled, children: [\n /* @__PURE__ */ jsx(\n Primitive.button,\n {\n type: \"button\",\n role: \"radio\",\n \"aria-checked\": checked,\n \"data-state\": getState(checked),\n \"data-disabled\": disabled ? \"\" : void 0,\n disabled,\n value,\n ...radioProps,\n ref: composedRefs,\n onClick: composeEventHandlers(props.onClick, (event) => {\n if (!checked) onCheck?.();\n if (isFormControl) {\n hasConsumerStoppedPropagationRef.current = event.isPropagationStopped();\n if (!hasConsumerStoppedPropagationRef.current) event.stopPropagation();\n }\n })\n }\n ),\n isFormControl && /* @__PURE__ */ jsx(\n RadioBubbleInput,\n {\n control: button,\n bubbles: !hasConsumerStoppedPropagationRef.current,\n name,\n value,\n checked,\n required,\n disabled,\n form,\n style: { transform: \"translateX(-100%)\" }\n }\n )\n ] });\n }\n);\nRadio.displayName = RADIO_NAME;\nvar INDICATOR_NAME = \"RadioIndicator\";\nvar RadioIndicator = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeRadio, forceMount, ...indicatorProps } = props;\n const context = useRadioContext(INDICATOR_NAME, __scopeRadio);\n return /* @__PURE__ */ jsx(Presence, { present: forceMount || context.checked, children: /* @__PURE__ */ jsx(\n Primitive.span,\n {\n \"data-state\": getState(context.checked),\n \"data-disabled\": context.disabled ? \"\" : void 0,\n ...indicatorProps,\n ref: forwardedRef\n }\n ) });\n }\n);\nRadioIndicator.displayName = INDICATOR_NAME;\nvar BUBBLE_INPUT_NAME = \"RadioBubbleInput\";\nvar RadioBubbleInput = React.forwardRef(\n ({\n __scopeRadio,\n control,\n checked,\n bubbles = true,\n ...props\n }, forwardedRef) => {\n const ref = React.useRef(null);\n const composedRefs = useComposedRefs(ref, forwardedRef);\n const prevChecked = usePrevious(checked);\n const controlSize = useSize(control);\n React.useEffect(() => {\n const input = ref.current;\n if (!input) return;\n const inputProto = window.HTMLInputElement.prototype;\n const descriptor = Object.getOwnPropertyDescriptor(\n inputProto,\n \"checked\"\n );\n const setChecked = descriptor.set;\n if (prevChecked !== checked && setChecked) {\n const event = new Event(\"click\", { bubbles });\n setChecked.call(input, checked);\n input.dispatchEvent(event);\n }\n }, [prevChecked, checked, bubbles]);\n return /* @__PURE__ */ jsx(\n Primitive.input,\n {\n type: \"radio\",\n \"aria-hidden\": true,\n defaultChecked: checked,\n ...props,\n tabIndex: -1,\n ref: composedRefs,\n style: {\n ...props.style,\n ...controlSize,\n position: \"absolute\",\n pointerEvents: \"none\",\n opacity: 0,\n margin: 0\n }\n }\n );\n }\n);\nRadioBubbleInput.displayName = BUBBLE_INPUT_NAME;\nfunction getState(checked) {\n return checked ? \"checked\" : \"unchecked\";\n}\n\n// src/radio-group.tsx\nimport { jsx as jsx2 } from \"react/jsx-runtime\";\nvar ARROW_KEYS = [\"ArrowUp\", \"ArrowDown\", \"ArrowLeft\", \"ArrowRight\"];\nvar RADIO_GROUP_NAME = \"RadioGroup\";\nvar [createRadioGroupContext, createRadioGroupScope] = createContextScope2(RADIO_GROUP_NAME, [\n createRovingFocusGroupScope,\n createRadioScope\n]);\nvar useRovingFocusGroupScope = createRovingFocusGroupScope();\nvar useRadioScope = createRadioScope();\nvar [RadioGroupProvider, useRadioGroupContext] = createRadioGroupContext(RADIO_GROUP_NAME);\nvar RadioGroup = React2.forwardRef(\n (props, forwardedRef) => {\n const {\n __scopeRadioGroup,\n name,\n defaultValue,\n value: valueProp,\n required = false,\n disabled = false,\n orientation,\n dir,\n loop = true,\n onValueChange,\n ...groupProps\n } = props;\n const rovingFocusGroupScope = useRovingFocusGroupScope(__scopeRadioGroup);\n const direction = useDirection(dir);\n const [value, setValue] = useControllableState({\n prop: valueProp,\n defaultProp: defaultValue ?? null,\n onChange: onValueChange,\n caller: RADIO_GROUP_NAME\n });\n return /* @__PURE__ */ jsx2(\n RadioGroupProvider,\n {\n scope: __scopeRadioGroup,\n name,\n required,\n disabled,\n value,\n onValueChange: setValue,\n children: /* @__PURE__ */ jsx2(\n RovingFocusGroup.Root,\n {\n asChild: true,\n ...rovingFocusGroupScope,\n orientation,\n dir: direction,\n loop,\n children: /* @__PURE__ */ jsx2(\n Primitive2.div,\n {\n role: \"radiogroup\",\n \"aria-required\": required,\n \"aria-orientation\": orientation,\n \"data-disabled\": disabled ? \"\" : void 0,\n dir: direction,\n ...groupProps,\n ref: forwardedRef\n }\n )\n }\n )\n }\n );\n }\n);\nRadioGroup.displayName = RADIO_GROUP_NAME;\nvar ITEM_NAME = \"RadioGroupItem\";\nvar RadioGroupItem = React2.forwardRef(\n (props, forwardedRef) => {\n const { __scopeRadioGroup, disabled, ...itemProps } = props;\n const context = useRadioGroupContext(ITEM_NAME, __scopeRadioGroup);\n const isDisabled = context.disabled || disabled;\n const rovingFocusGroupScope = useRovingFocusGroupScope(__scopeRadioGroup);\n const radioScope = useRadioScope(__scopeRadioGroup);\n const ref = React2.useRef(null);\n const composedRefs = useComposedRefs2(forwardedRef, ref);\n const checked = context.value === itemProps.value;\n const isArrowKeyPressedRef = React2.useRef(false);\n React2.useEffect(() => {\n const handleKeyDown = (event) => {\n if (ARROW_KEYS.includes(event.key)) {\n isArrowKeyPressedRef.current = true;\n }\n };\n const handleKeyUp = () => isArrowKeyPressedRef.current = false;\n document.addEventListener(\"keydown\", handleKeyDown);\n document.addEventListener(\"keyup\", handleKeyUp);\n return () => {\n document.removeEventListener(\"keydown\", handleKeyDown);\n document.removeEventListener(\"keyup\", handleKeyUp);\n };\n }, []);\n return /* @__PURE__ */ jsx2(\n RovingFocusGroup.Item,\n {\n asChild: true,\n ...rovingFocusGroupScope,\n focusable: !isDisabled,\n active: checked,\n children: /* @__PURE__ */ jsx2(\n Radio,\n {\n disabled: isDisabled,\n required: context.required,\n checked,\n ...radioScope,\n ...itemProps,\n name: context.name,\n ref: composedRefs,\n onCheck: () => context.onValueChange(itemProps.value),\n onKeyDown: composeEventHandlers2((event) => {\n if (event.key === \"Enter\") event.preventDefault();\n }),\n onFocus: composeEventHandlers2(itemProps.onFocus, () => {\n if (isArrowKeyPressedRef.current) ref.current?.click();\n })\n }\n )\n }\n );\n }\n);\nRadioGroupItem.displayName = ITEM_NAME;\nvar INDICATOR_NAME2 = \"RadioGroupIndicator\";\nvar RadioGroupIndicator = React2.forwardRef(\n (props, forwardedRef) => {\n const { __scopeRadioGroup, ...indicatorProps } = props;\n const radioScope = useRadioScope(__scopeRadioGroup);\n return /* @__PURE__ */ jsx2(RadioIndicator, { ...radioScope, ...indicatorProps, ref: forwardedRef });\n }\n);\nRadioGroupIndicator.displayName = INDICATOR_NAME2;\nvar Root2 = RadioGroup;\nvar Item2 = RadioGroupItem;\nvar Indicator = RadioGroupIndicator;\nexport {\n Indicator,\n Item2 as Item,\n RadioGroup,\n RadioGroupIndicator,\n RadioGroupItem,\n Root2 as Root,\n createRadioGroupScope\n};\n//# sourceMappingURL=index.mjs.map\n","import * as RadioGroupPrimitive from '@radix-ui/react-radio-group'\nimport { cn } from '../../lib/cn'\n\nexport interface RadioGroupProps\n extends React.ComponentPropsWithoutRef<typeof RadioGroupPrimitive.Root> {\n /** Stack direction. Defaults to 'vertical'. */\n orientation?: 'vertical' | 'horizontal'\n}\n\nexport interface RadioProps\n extends React.ComponentPropsWithoutRef<typeof RadioGroupPrimitive.Item> {\n /** Visible label text. */\n label?: string\n /** Optional supporting description rendered below the label. */\n description?: string\n}\n\n/* ----------------------------------------------------------\n RadioGroup\n ---------------------------------------------------------- */\n\n/**\n * Container for a set of mutually exclusive Radio options.\n * Built on Radix RadioGroup — handles ARIA radiogroup role and keyboard nav.\n *\n * @example\n * <RadioGroup defaultValue=\"net30\" onValueChange={setTerms}>\n * <Radio value=\"net30\" label=\"Net 30\" />\n * <Radio value=\"net45\" label=\"Net 45\" />\n * </RadioGroup>\n */\nexport function RadioGroup({\n orientation = 'vertical',\n className,\n ...props\n}: RadioGroupProps) {\n return (\n <RadioGroupPrimitive.Root\n orientation={orientation}\n className={cn(\n 'flex',\n orientation === 'vertical' ? 'flex-col gap-3' : 'flex-row flex-wrap gap-4',\n className,\n )}\n {...props}\n />\n )\n}\n\n/* ----------------------------------------------------------\n Radio (item)\n ---------------------------------------------------------- */\n\n/**\n * A single radio option inside a RadioGroup.\n *\n * @example\n * <Radio value=\"net30\" label=\"Net 30\" description=\"Due within 30 days.\" />\n */\nexport function Radio({\n label,\n description,\n className,\n disabled,\n ...props\n}: RadioProps) {\n return (\n <label\n className={cn(\n 'flex items-start gap-2.5 group',\n disabled ? 'cursor-not-allowed opacity-50' : 'cursor-pointer',\n className,\n )}\n >\n <RadioGroupPrimitive.Item\n disabled={disabled}\n className={cn(\n // Layout — vertically centred with first line of label\n 'mt-0.5 shrink-0',\n // Shape\n 'w-4 h-4 rounded-full border border-rule bg-paper',\n // Focus\n 'outline-none focus-visible:ring-2 focus-visible:ring-signal-alt focus-visible:ring-offset-1',\n // Checked track\n 'data-[state=checked]:border-signal-alt',\n // Transition\n 'transition-colors duration-fast',\n )}\n {...props}\n >\n <RadioGroupPrimitive.Indicator className=\"flex items-center justify-center w-full h-full relative\">\n {/* Filled dot */}\n <span className=\"w-2 h-2 rounded-full bg-signal-alt block\" />\n </RadioGroupPrimitive.Indicator>\n </RadioGroupPrimitive.Item>\n\n {(label || description) && (\n <div className=\"flex flex-col gap-0.5 leading-none\">\n {label && (\n <span className={cn(\n 'text-sm text-void leading-tight',\n disabled && 'text-smoke',\n )}>\n {label}\n </span>\n )}\n {description && (\n <span className=\"text-sm text-smoke leading-snug\">\n {description}\n </span>\n )}\n </div>\n )}\n </label>\n )\n}\n","// src/slot.tsx\nimport * as React from \"react\";\nimport { composeRefs } from \"@radix-ui/react-compose-refs\";\nimport { Fragment as Fragment2, jsx } from \"react/jsx-runtime\";\n// @__NO_SIDE_EFFECTS__\nfunction createSlot(ownerName) {\n const SlotClone = /* @__PURE__ */ createSlotClone(ownerName);\n const Slot2 = React.forwardRef((props, forwardedRef) => {\n const { children, ...slotProps } = props;\n const childrenArray = React.Children.toArray(children);\n const slottable = childrenArray.find(isSlottable);\n if (slottable) {\n const newElement = slottable.props.children;\n const newChildren = childrenArray.map((child) => {\n if (child === slottable) {\n if (React.Children.count(newElement) > 1) return React.Children.only(null);\n return React.isValidElement(newElement) ? newElement.props.children : null;\n } else {\n return child;\n }\n });\n return /* @__PURE__ */ jsx(SlotClone, { ...slotProps, ref: forwardedRef, children: React.isValidElement(newElement) ? React.cloneElement(newElement, void 0, newChildren) : null });\n }\n return /* @__PURE__ */ jsx(SlotClone, { ...slotProps, ref: forwardedRef, children });\n });\n Slot2.displayName = `${ownerName}.Slot`;\n return Slot2;\n}\nvar Slot = /* @__PURE__ */ createSlot(\"Slot\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlotClone(ownerName) {\n const SlotClone = React.forwardRef((props, forwardedRef) => {\n const { children, ...slotProps } = props;\n if (React.isValidElement(children)) {\n const childrenRef = getElementRef(children);\n const props2 = mergeProps(slotProps, children.props);\n if (children.type !== React.Fragment) {\n props2.ref = forwardedRef ? composeRefs(forwardedRef, childrenRef) : childrenRef;\n }\n return React.cloneElement(children, props2);\n }\n return React.Children.count(children) > 1 ? React.Children.only(null) : null;\n });\n SlotClone.displayName = `${ownerName}.SlotClone`;\n return SlotClone;\n}\nvar SLOTTABLE_IDENTIFIER = Symbol(\"radix.slottable\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlottable(ownerName) {\n const Slottable2 = ({ children }) => {\n return /* @__PURE__ */ jsx(Fragment2, { children });\n };\n Slottable2.displayName = `${ownerName}.Slottable`;\n Slottable2.__radixId = SLOTTABLE_IDENTIFIER;\n return Slottable2;\n}\nvar Slottable = /* @__PURE__ */ createSlottable(\"Slottable\");\nfunction isSlottable(child) {\n return React.isValidElement(child) && typeof child.type === \"function\" && \"__radixId\" in child.type && child.type.__radixId === SLOTTABLE_IDENTIFIER;\n}\nfunction mergeProps(slotProps, childProps) {\n const overrideProps = { ...childProps };\n for (const propName in childProps) {\n const slotPropValue = slotProps[propName];\n const childPropValue = childProps[propName];\n const isHandler = /^on[A-Z]/.test(propName);\n if (isHandler) {\n if (slotPropValue && childPropValue) {\n overrideProps[propName] = (...args) => {\n const result = childPropValue(...args);\n slotPropValue(...args);\n return result;\n };\n } else if (slotPropValue) {\n overrideProps[propName] = slotPropValue;\n }\n } else if (propName === \"style\") {\n overrideProps[propName] = { ...slotPropValue, ...childPropValue };\n } else if (propName === \"className\") {\n overrideProps[propName] = [slotPropValue, childPropValue].filter(Boolean).join(\" \");\n }\n }\n return { ...slotProps, ...overrideProps };\n}\nfunction getElementRef(element) {\n let getter = Object.getOwnPropertyDescriptor(element.props, \"ref\")?.get;\n let mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.ref;\n }\n getter = Object.getOwnPropertyDescriptor(element, \"ref\")?.get;\n mayWarn = getter && \"isReactWarning\" in getter && getter.isReactWarning;\n if (mayWarn) {\n return element.props.ref;\n }\n return element.props.ref || element.ref;\n}\nexport {\n Slot as Root,\n Slot,\n Slottable,\n createSlot,\n createSlottable\n};\n//# sourceMappingURL=index.mjs.map\n","\"use client\";\n\n// src/popover.tsx\nimport * as React from \"react\";\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { createContextScope } from \"@radix-ui/react-context\";\nimport { DismissableLayer } from \"@radix-ui/react-dismissable-layer\";\nimport { useFocusGuards } from \"@radix-ui/react-focus-guards\";\nimport { FocusScope } from \"@radix-ui/react-focus-scope\";\nimport { useId } from \"@radix-ui/react-id\";\nimport * as PopperPrimitive from \"@radix-ui/react-popper\";\nimport { createPopperScope } from \"@radix-ui/react-popper\";\nimport { Portal as PortalPrimitive } from \"@radix-ui/react-portal\";\nimport { Presence } from \"@radix-ui/react-presence\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { createSlot } from \"@radix-ui/react-slot\";\nimport { useControllableState } from \"@radix-ui/react-use-controllable-state\";\nimport { hideOthers } from \"aria-hidden\";\nimport { RemoveScroll } from \"react-remove-scroll\";\nimport { jsx } from \"react/jsx-runtime\";\nvar POPOVER_NAME = \"Popover\";\nvar [createPopoverContext, createPopoverScope] = createContextScope(POPOVER_NAME, [\n createPopperScope\n]);\nvar usePopperScope = createPopperScope();\nvar [PopoverProvider, usePopoverContext] = createPopoverContext(POPOVER_NAME);\nvar Popover = (props) => {\n const {\n __scopePopover,\n children,\n open: openProp,\n defaultOpen,\n onOpenChange,\n modal = false\n } = props;\n const popperScope = usePopperScope(__scopePopover);\n const triggerRef = React.useRef(null);\n const [hasCustomAnchor, setHasCustomAnchor] = React.useState(false);\n const [open, setOpen] = useControllableState({\n prop: openProp,\n defaultProp: defaultOpen ?? false,\n onChange: onOpenChange,\n caller: POPOVER_NAME\n });\n return /* @__PURE__ */ jsx(PopperPrimitive.Root, { ...popperScope, children: /* @__PURE__ */ jsx(\n PopoverProvider,\n {\n scope: __scopePopover,\n contentId: useId(),\n triggerRef,\n open,\n onOpenChange: setOpen,\n onOpenToggle: React.useCallback(() => setOpen((prevOpen) => !prevOpen), [setOpen]),\n hasCustomAnchor,\n onCustomAnchorAdd: React.useCallback(() => setHasCustomAnchor(true), []),\n onCustomAnchorRemove: React.useCallback(() => setHasCustomAnchor(false), []),\n modal,\n children\n }\n ) });\n};\nPopover.displayName = POPOVER_NAME;\nvar ANCHOR_NAME = \"PopoverAnchor\";\nvar PopoverAnchor = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopePopover, ...anchorProps } = props;\n const context = usePopoverContext(ANCHOR_NAME, __scopePopover);\n const popperScope = usePopperScope(__scopePopover);\n const { onCustomAnchorAdd, onCustomAnchorRemove } = context;\n React.useEffect(() => {\n onCustomAnchorAdd();\n return () => onCustomAnchorRemove();\n }, [onCustomAnchorAdd, onCustomAnchorRemove]);\n return /* @__PURE__ */ jsx(PopperPrimitive.Anchor, { ...popperScope, ...anchorProps, ref: forwardedRef });\n }\n);\nPopoverAnchor.displayName = ANCHOR_NAME;\nvar TRIGGER_NAME = \"PopoverTrigger\";\nvar PopoverTrigger = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopePopover, ...triggerProps } = props;\n const context = usePopoverContext(TRIGGER_NAME, __scopePopover);\n const popperScope = usePopperScope(__scopePopover);\n const composedTriggerRef = useComposedRefs(forwardedRef, context.triggerRef);\n const trigger = /* @__PURE__ */ jsx(\n Primitive.button,\n {\n type: \"button\",\n \"aria-haspopup\": \"dialog\",\n \"aria-expanded\": context.open,\n \"aria-controls\": context.contentId,\n \"data-state\": getState(context.open),\n ...triggerProps,\n ref: composedTriggerRef,\n onClick: composeEventHandlers(props.onClick, context.onOpenToggle)\n }\n );\n return context.hasCustomAnchor ? trigger : /* @__PURE__ */ jsx(PopperPrimitive.Anchor, { asChild: true, ...popperScope, children: trigger });\n }\n);\nPopoverTrigger.displayName = TRIGGER_NAME;\nvar PORTAL_NAME = \"PopoverPortal\";\nvar [PortalProvider, usePortalContext] = createPopoverContext(PORTAL_NAME, {\n forceMount: void 0\n});\nvar PopoverPortal = (props) => {\n const { __scopePopover, forceMount, children, container } = props;\n const context = usePopoverContext(PORTAL_NAME, __scopePopover);\n return /* @__PURE__ */ jsx(PortalProvider, { scope: __scopePopover, forceMount, children: /* @__PURE__ */ jsx(Presence, { present: forceMount || context.open, children: /* @__PURE__ */ jsx(PortalPrimitive, { asChild: true, container, children }) }) });\n};\nPopoverPortal.displayName = PORTAL_NAME;\nvar CONTENT_NAME = \"PopoverContent\";\nvar PopoverContent = React.forwardRef(\n (props, forwardedRef) => {\n const portalContext = usePortalContext(CONTENT_NAME, props.__scopePopover);\n const { forceMount = portalContext.forceMount, ...contentProps } = props;\n const context = usePopoverContext(CONTENT_NAME, props.__scopePopover);\n return /* @__PURE__ */ jsx(Presence, { present: forceMount || context.open, children: context.modal ? /* @__PURE__ */ jsx(PopoverContentModal, { ...contentProps, ref: forwardedRef }) : /* @__PURE__ */ jsx(PopoverContentNonModal, { ...contentProps, ref: forwardedRef }) });\n }\n);\nPopoverContent.displayName = CONTENT_NAME;\nvar Slot = createSlot(\"PopoverContent.RemoveScroll\");\nvar PopoverContentModal = React.forwardRef(\n (props, forwardedRef) => {\n const context = usePopoverContext(CONTENT_NAME, props.__scopePopover);\n const contentRef = React.useRef(null);\n const composedRefs = useComposedRefs(forwardedRef, contentRef);\n const isRightClickOutsideRef = React.useRef(false);\n React.useEffect(() => {\n const content = contentRef.current;\n if (content) return hideOthers(content);\n }, []);\n return /* @__PURE__ */ jsx(RemoveScroll, { as: Slot, allowPinchZoom: true, children: /* @__PURE__ */ jsx(\n PopoverContentImpl,\n {\n ...props,\n ref: composedRefs,\n trapFocus: context.open,\n disableOutsidePointerEvents: true,\n onCloseAutoFocus: composeEventHandlers(props.onCloseAutoFocus, (event) => {\n event.preventDefault();\n if (!isRightClickOutsideRef.current) context.triggerRef.current?.focus();\n }),\n onPointerDownOutside: composeEventHandlers(\n props.onPointerDownOutside,\n (event) => {\n const originalEvent = event.detail.originalEvent;\n const ctrlLeftClick = originalEvent.button === 0 && originalEvent.ctrlKey === true;\n const isRightClick = originalEvent.button === 2 || ctrlLeftClick;\n isRightClickOutsideRef.current = isRightClick;\n },\n { checkForDefaultPrevented: false }\n ),\n onFocusOutside: composeEventHandlers(\n props.onFocusOutside,\n (event) => event.preventDefault(),\n { checkForDefaultPrevented: false }\n )\n }\n ) });\n }\n);\nvar PopoverContentNonModal = React.forwardRef(\n (props, forwardedRef) => {\n const context = usePopoverContext(CONTENT_NAME, props.__scopePopover);\n const hasInteractedOutsideRef = React.useRef(false);\n const hasPointerDownOutsideRef = React.useRef(false);\n return /* @__PURE__ */ jsx(\n PopoverContentImpl,\n {\n ...props,\n ref: forwardedRef,\n trapFocus: false,\n disableOutsidePointerEvents: false,\n onCloseAutoFocus: (event) => {\n props.onCloseAutoFocus?.(event);\n if (!event.defaultPrevented) {\n if (!hasInteractedOutsideRef.current) context.triggerRef.current?.focus();\n event.preventDefault();\n }\n hasInteractedOutsideRef.current = false;\n hasPointerDownOutsideRef.current = false;\n },\n onInteractOutside: (event) => {\n props.onInteractOutside?.(event);\n if (!event.defaultPrevented) {\n hasInteractedOutsideRef.current = true;\n if (event.detail.originalEvent.type === \"pointerdown\") {\n hasPointerDownOutsideRef.current = true;\n }\n }\n const target = event.target;\n const targetIsTrigger = context.triggerRef.current?.contains(target);\n if (targetIsTrigger) event.preventDefault();\n if (event.detail.originalEvent.type === \"focusin\" && hasPointerDownOutsideRef.current) {\n event.preventDefault();\n }\n }\n }\n );\n }\n);\nvar PopoverContentImpl = React.forwardRef(\n (props, forwardedRef) => {\n const {\n __scopePopover,\n trapFocus,\n onOpenAutoFocus,\n onCloseAutoFocus,\n disableOutsidePointerEvents,\n onEscapeKeyDown,\n onPointerDownOutside,\n onFocusOutside,\n onInteractOutside,\n ...contentProps\n } = props;\n const context = usePopoverContext(CONTENT_NAME, __scopePopover);\n const popperScope = usePopperScope(__scopePopover);\n useFocusGuards();\n return /* @__PURE__ */ jsx(\n FocusScope,\n {\n asChild: true,\n loop: true,\n trapped: trapFocus,\n onMountAutoFocus: onOpenAutoFocus,\n onUnmountAutoFocus: onCloseAutoFocus,\n children: /* @__PURE__ */ jsx(\n DismissableLayer,\n {\n asChild: true,\n disableOutsidePointerEvents,\n onInteractOutside,\n onEscapeKeyDown,\n onPointerDownOutside,\n onFocusOutside,\n onDismiss: () => context.onOpenChange(false),\n children: /* @__PURE__ */ jsx(\n PopperPrimitive.Content,\n {\n \"data-state\": getState(context.open),\n role: \"dialog\",\n id: context.contentId,\n ...popperScope,\n ...contentProps,\n ref: forwardedRef,\n style: {\n ...contentProps.style,\n // re-namespace exposed content custom properties\n ...{\n \"--radix-popover-content-transform-origin\": \"var(--radix-popper-transform-origin)\",\n \"--radix-popover-content-available-width\": \"var(--radix-popper-available-width)\",\n \"--radix-popover-content-available-height\": \"var(--radix-popper-available-height)\",\n \"--radix-popover-trigger-width\": \"var(--radix-popper-anchor-width)\",\n \"--radix-popover-trigger-height\": \"var(--radix-popper-anchor-height)\"\n }\n }\n }\n )\n }\n )\n }\n );\n }\n);\nvar CLOSE_NAME = \"PopoverClose\";\nvar PopoverClose = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopePopover, ...closeProps } = props;\n const context = usePopoverContext(CLOSE_NAME, __scopePopover);\n return /* @__PURE__ */ jsx(\n Primitive.button,\n {\n type: \"button\",\n ...closeProps,\n ref: forwardedRef,\n onClick: composeEventHandlers(props.onClick, () => context.onOpenChange(false))\n }\n );\n }\n);\nPopoverClose.displayName = CLOSE_NAME;\nvar ARROW_NAME = \"PopoverArrow\";\nvar PopoverArrow = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopePopover, ...arrowProps } = props;\n const popperScope = usePopperScope(__scopePopover);\n return /* @__PURE__ */ jsx(PopperPrimitive.Arrow, { ...popperScope, ...arrowProps, ref: forwardedRef });\n }\n);\nPopoverArrow.displayName = ARROW_NAME;\nfunction getState(open) {\n return open ? \"open\" : \"closed\";\n}\nvar Root2 = Popover;\nvar Anchor2 = PopoverAnchor;\nvar Trigger = PopoverTrigger;\nvar Portal = PopoverPortal;\nvar Content2 = PopoverContent;\nvar Close = PopoverClose;\nvar Arrow2 = PopoverArrow;\nexport {\n Anchor2 as Anchor,\n Arrow2 as Arrow,\n Close,\n Content2 as Content,\n Popover,\n PopoverAnchor,\n PopoverArrow,\n PopoverClose,\n PopoverContent,\n PopoverPortal,\n PopoverTrigger,\n Portal,\n Root2 as Root,\n Trigger,\n createPopoverScope\n};\n//# sourceMappingURL=index.mjs.map\n","import * as PopoverPrimitive from '@radix-ui/react-popover'\nimport { cn } from '../../lib/cn'\n\nexport const Popover = PopoverPrimitive.Root\nexport const PopoverTrigger = PopoverPrimitive.Trigger\nexport const PopoverClose = PopoverPrimitive.Close\nexport const PopoverAnchor = PopoverPrimitive.Anchor\n\nexport interface PopoverContentProps\n extends React.ComponentPropsWithoutRef<typeof PopoverPrimitive.Content> {}\n\n/**\n * Styled Popover panel — renders in a portal, animated in/out.\n * Pair with `Popover`, `PopoverTrigger`, and optionally `PopoverClose`.\n *\n * Radix handles: focus trap, scroll lock, outside-click dismiss, ARIA.\n *\n * @example\n * <Popover>\n * <PopoverTrigger asChild>\n * <Button>Open</Button>\n * </PopoverTrigger>\n * <PopoverContent>\n * <p>Popover body</p>\n * </PopoverContent>\n * </Popover>\n */\nexport function PopoverContent({\n className,\n align = 'start',\n sideOffset = 8,\n ...props\n}: PopoverContentProps) {\n return (\n <PopoverPrimitive.Portal>\n <PopoverPrimitive.Content\n align={align}\n sideOffset={sideOffset}\n className={cn(\n // Layout + shape\n 'z-50 rounded-md border border-rule bg-paper p-4',\n // Shadow\n 'shadow-[var(--shadow-md)]',\n // Width default — consumers override via className\n 'w-64',\n // Open animations\n 'data-[state=open]:animate-[popover-in_150ms_ease]',\n // Close animations\n 'data-[state=closed]:animate-[popover-out_100ms_ease]',\n // Focus\n 'outline-none',\n className,\n )}\n {...props}\n />\n </PopoverPrimitive.Portal>\n )\n}\n","import { Slot } from '@radix-ui/react-slot'\nimport { cn } from '../../lib/cn'\n\n/* ----------------------------------------------------------\n Breadcrumb — root nav\n ---------------------------------------------------------- */\n\nexport interface BreadcrumbProps extends React.HTMLAttributes<HTMLElement> {}\n\n/**\n * Root `<nav>` wrapper. Sets aria-label=\"breadcrumb\".\n */\nexport function Breadcrumb({ className, ...props }: BreadcrumbProps) {\n return (\n <nav aria-label=\"breadcrumb\" className={cn(className)} {...props} />\n )\n}\n\n/* ----------------------------------------------------------\n BreadcrumbList — ordered list\n ---------------------------------------------------------- */\n\nexport interface BreadcrumbListProps extends React.HTMLAttributes<HTMLOListElement> {}\n\n/**\n * `<ol>` that lays out breadcrumb items horizontally with wrapping.\n */\nexport function BreadcrumbList({ className, ...props }: BreadcrumbListProps) {\n return (\n <ol\n className={cn(\n 'flex flex-wrap items-center gap-1 text-sm text-smoke',\n className,\n )}\n {...props}\n />\n )\n}\n\n/* ----------------------------------------------------------\n BreadcrumbItem — list item\n ---------------------------------------------------------- */\n\nexport interface BreadcrumbItemProps extends React.HTMLAttributes<HTMLLIElement> {}\n\n/**\n * `<li>` wrapper for a link or the current page label.\n */\nexport function BreadcrumbItem({ className, ...props }: BreadcrumbItemProps) {\n return (\n <li\n className={cn('inline-flex items-center gap-1', className)}\n {...props}\n />\n )\n}\n\n/* ----------------------------------------------------------\n BreadcrumbLink — ancestor link\n ---------------------------------------------------------- */\n\nexport interface BreadcrumbLinkProps\n extends React.AnchorHTMLAttributes<HTMLAnchorElement> {\n /** Render as child component (e.g. React Router `<Link>` or Next.js `<Link>`). */\n asChild?: boolean\n}\n\n/**\n * Ancestor crumb link. Use `asChild` to render as a router `<Link>`.\n *\n * @example\n * <BreadcrumbLink href=\"/projects\">Projects</BreadcrumbLink>\n * <BreadcrumbLink asChild><Link to=\"/projects\">Projects</Link></BreadcrumbLink>\n */\nexport function BreadcrumbLink({\n asChild,\n className,\n ...props\n}: BreadcrumbLinkProps) {\n const Comp = asChild ? Slot : 'a'\n return (\n <Comp\n className={cn(\n 'text-smoke hover:text-void transition-colors duration-fast',\n 'underline-offset-2 hover:underline',\n 'outline-none focus-visible:ring-2 focus-visible:ring-signal-alt rounded-sm',\n className,\n )}\n {...props}\n />\n )\n}\n\n/* ----------------------------------------------------------\n BreadcrumbPage — current page (not a link)\n ---------------------------------------------------------- */\n\nexport interface BreadcrumbPageProps extends React.HTMLAttributes<HTMLSpanElement> {}\n\n/**\n * The final (current) crumb — rendered as a `<span>` with `aria-current=\"page\"`.\n */\nexport function BreadcrumbPage({ className, ...props }: BreadcrumbPageProps) {\n return (\n <span\n aria-current=\"page\"\n className={cn('text-void font-medium', className)}\n {...props}\n />\n )\n}\n\n/* ----------------------------------------------------------\n BreadcrumbSeparator — visual divider\n ---------------------------------------------------------- */\n\nexport interface BreadcrumbSeparatorProps extends React.HTMLAttributes<HTMLLIElement> {}\n\n/**\n * Separator between crumbs. Defaults to \"/\" — pass children to customise.\n *\n * @example\n * <BreadcrumbSeparator />\n * <BreadcrumbSeparator><ChevronRightIcon /></BreadcrumbSeparator>\n */\nexport function BreadcrumbSeparator({\n children,\n className,\n ...props\n}: BreadcrumbSeparatorProps) {\n return (\n <li\n role=\"presentation\"\n aria-hidden=\"true\"\n className={cn('text-smoke select-none', className)}\n {...props}\n >\n {children ?? '/'}\n </li>\n )\n}\n\n/* ----------------------------------------------------------\n BreadcrumbEllipsis — collapsed middle\n ---------------------------------------------------------- */\n\nexport interface BreadcrumbEllipsisProps extends React.HTMLAttributes<HTMLSpanElement> {}\n\n/**\n * Placeholder for collapsed intermediate crumbs.\n */\nexport function BreadcrumbEllipsis({ className, ...props }: BreadcrumbEllipsisProps) {\n return (\n <span\n role=\"presentation\"\n aria-hidden=\"true\"\n className={cn('text-smoke select-none tracking-widest', className)}\n {...props}\n >\n …\n </span>\n )\n}\n","\"use client\";\n\n// src/collapsible.tsx\nimport * as React from \"react\";\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\nimport { createContextScope } from \"@radix-ui/react-context\";\nimport { useControllableState } from \"@radix-ui/react-use-controllable-state\";\nimport { useLayoutEffect } from \"@radix-ui/react-use-layout-effect\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { Presence } from \"@radix-ui/react-presence\";\nimport { useId } from \"@radix-ui/react-id\";\nimport { jsx } from \"react/jsx-runtime\";\nvar COLLAPSIBLE_NAME = \"Collapsible\";\nvar [createCollapsibleContext, createCollapsibleScope] = createContextScope(COLLAPSIBLE_NAME);\nvar [CollapsibleProvider, useCollapsibleContext] = createCollapsibleContext(COLLAPSIBLE_NAME);\nvar Collapsible = React.forwardRef(\n (props, forwardedRef) => {\n const {\n __scopeCollapsible,\n open: openProp,\n defaultOpen,\n disabled,\n onOpenChange,\n ...collapsibleProps\n } = props;\n const [open, setOpen] = useControllableState({\n prop: openProp,\n defaultProp: defaultOpen ?? false,\n onChange: onOpenChange,\n caller: COLLAPSIBLE_NAME\n });\n return /* @__PURE__ */ jsx(\n CollapsibleProvider,\n {\n scope: __scopeCollapsible,\n disabled,\n contentId: useId(),\n open,\n onOpenToggle: React.useCallback(() => setOpen((prevOpen) => !prevOpen), [setOpen]),\n children: /* @__PURE__ */ jsx(\n Primitive.div,\n {\n \"data-state\": getState(open),\n \"data-disabled\": disabled ? \"\" : void 0,\n ...collapsibleProps,\n ref: forwardedRef\n }\n )\n }\n );\n }\n);\nCollapsible.displayName = COLLAPSIBLE_NAME;\nvar TRIGGER_NAME = \"CollapsibleTrigger\";\nvar CollapsibleTrigger = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeCollapsible, ...triggerProps } = props;\n const context = useCollapsibleContext(TRIGGER_NAME, __scopeCollapsible);\n return /* @__PURE__ */ jsx(\n Primitive.button,\n {\n type: \"button\",\n \"aria-controls\": context.contentId,\n \"aria-expanded\": context.open || false,\n \"data-state\": getState(context.open),\n \"data-disabled\": context.disabled ? \"\" : void 0,\n disabled: context.disabled,\n ...triggerProps,\n ref: forwardedRef,\n onClick: composeEventHandlers(props.onClick, context.onOpenToggle)\n }\n );\n }\n);\nCollapsibleTrigger.displayName = TRIGGER_NAME;\nvar CONTENT_NAME = \"CollapsibleContent\";\nvar CollapsibleContent = React.forwardRef(\n (props, forwardedRef) => {\n const { forceMount, ...contentProps } = props;\n const context = useCollapsibleContext(CONTENT_NAME, props.__scopeCollapsible);\n return /* @__PURE__ */ jsx(Presence, { present: forceMount || context.open, children: ({ present }) => /* @__PURE__ */ jsx(CollapsibleContentImpl, { ...contentProps, ref: forwardedRef, present }) });\n }\n);\nCollapsibleContent.displayName = CONTENT_NAME;\nvar CollapsibleContentImpl = React.forwardRef((props, forwardedRef) => {\n const { __scopeCollapsible, present, children, ...contentProps } = props;\n const context = useCollapsibleContext(CONTENT_NAME, __scopeCollapsible);\n const [isPresent, setIsPresent] = React.useState(present);\n const ref = React.useRef(null);\n const composedRefs = useComposedRefs(forwardedRef, ref);\n const heightRef = React.useRef(0);\n const height = heightRef.current;\n const widthRef = React.useRef(0);\n const width = widthRef.current;\n const isOpen = context.open || isPresent;\n const isMountAnimationPreventedRef = React.useRef(isOpen);\n const originalStylesRef = React.useRef(void 0);\n React.useEffect(() => {\n const rAF = requestAnimationFrame(() => isMountAnimationPreventedRef.current = false);\n return () => cancelAnimationFrame(rAF);\n }, []);\n useLayoutEffect(() => {\n const node = ref.current;\n if (node) {\n originalStylesRef.current = originalStylesRef.current || {\n transitionDuration: node.style.transitionDuration,\n animationName: node.style.animationName\n };\n node.style.transitionDuration = \"0s\";\n node.style.animationName = \"none\";\n const rect = node.getBoundingClientRect();\n heightRef.current = rect.height;\n widthRef.current = rect.width;\n if (!isMountAnimationPreventedRef.current) {\n node.style.transitionDuration = originalStylesRef.current.transitionDuration;\n node.style.animationName = originalStylesRef.current.animationName;\n }\n setIsPresent(present);\n }\n }, [context.open, present]);\n return /* @__PURE__ */ jsx(\n Primitive.div,\n {\n \"data-state\": getState(context.open),\n \"data-disabled\": context.disabled ? \"\" : void 0,\n id: context.contentId,\n hidden: !isOpen,\n ...contentProps,\n ref: composedRefs,\n style: {\n [`--radix-collapsible-content-height`]: height ? `${height}px` : void 0,\n [`--radix-collapsible-content-width`]: width ? `${width}px` : void 0,\n ...props.style\n },\n children: isOpen && children\n }\n );\n});\nfunction getState(open) {\n return open ? \"open\" : \"closed\";\n}\nvar Root = Collapsible;\nvar Trigger = CollapsibleTrigger;\nvar Content = CollapsibleContent;\nexport {\n Collapsible,\n CollapsibleContent,\n CollapsibleTrigger,\n Content,\n Root,\n Trigger,\n createCollapsibleScope\n};\n//# sourceMappingURL=index.mjs.map\n","\"use client\";\n\n// src/accordion.tsx\nimport React from \"react\";\nimport { createContextScope } from \"@radix-ui/react-context\";\nimport { createCollection } from \"@radix-ui/react-collection\";\nimport { useComposedRefs } from \"@radix-ui/react-compose-refs\";\nimport { composeEventHandlers } from \"@radix-ui/primitive\";\nimport { useControllableState } from \"@radix-ui/react-use-controllable-state\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport * as CollapsiblePrimitive from \"@radix-ui/react-collapsible\";\nimport { createCollapsibleScope } from \"@radix-ui/react-collapsible\";\nimport { useId } from \"@radix-ui/react-id\";\nimport { useDirection } from \"@radix-ui/react-direction\";\nimport { jsx } from \"react/jsx-runtime\";\nvar ACCORDION_NAME = \"Accordion\";\nvar ACCORDION_KEYS = [\"Home\", \"End\", \"ArrowDown\", \"ArrowUp\", \"ArrowLeft\", \"ArrowRight\"];\nvar [Collection, useCollection, createCollectionScope] = createCollection(ACCORDION_NAME);\nvar [createAccordionContext, createAccordionScope] = createContextScope(ACCORDION_NAME, [\n createCollectionScope,\n createCollapsibleScope\n]);\nvar useCollapsibleScope = createCollapsibleScope();\nvar Accordion = React.forwardRef(\n (props, forwardedRef) => {\n const { type, ...accordionProps } = props;\n const singleProps = accordionProps;\n const multipleProps = accordionProps;\n return /* @__PURE__ */ jsx(Collection.Provider, { scope: props.__scopeAccordion, children: type === \"multiple\" ? /* @__PURE__ */ jsx(AccordionImplMultiple, { ...multipleProps, ref: forwardedRef }) : /* @__PURE__ */ jsx(AccordionImplSingle, { ...singleProps, ref: forwardedRef }) });\n }\n);\nAccordion.displayName = ACCORDION_NAME;\nvar [AccordionValueProvider, useAccordionValueContext] = createAccordionContext(ACCORDION_NAME);\nvar [AccordionCollapsibleProvider, useAccordionCollapsibleContext] = createAccordionContext(\n ACCORDION_NAME,\n { collapsible: false }\n);\nvar AccordionImplSingle = React.forwardRef(\n (props, forwardedRef) => {\n const {\n value: valueProp,\n defaultValue,\n onValueChange = () => {\n },\n collapsible = false,\n ...accordionSingleProps\n } = props;\n const [value, setValue] = useControllableState({\n prop: valueProp,\n defaultProp: defaultValue ?? \"\",\n onChange: onValueChange,\n caller: ACCORDION_NAME\n });\n return /* @__PURE__ */ jsx(\n AccordionValueProvider,\n {\n scope: props.__scopeAccordion,\n value: React.useMemo(() => value ? [value] : [], [value]),\n onItemOpen: setValue,\n onItemClose: React.useCallback(() => collapsible && setValue(\"\"), [collapsible, setValue]),\n children: /* @__PURE__ */ jsx(AccordionCollapsibleProvider, { scope: props.__scopeAccordion, collapsible, children: /* @__PURE__ */ jsx(AccordionImpl, { ...accordionSingleProps, ref: forwardedRef }) })\n }\n );\n }\n);\nvar AccordionImplMultiple = React.forwardRef((props, forwardedRef) => {\n const {\n value: valueProp,\n defaultValue,\n onValueChange = () => {\n },\n ...accordionMultipleProps\n } = props;\n const [value, setValue] = useControllableState({\n prop: valueProp,\n defaultProp: defaultValue ?? [],\n onChange: onValueChange,\n caller: ACCORDION_NAME\n });\n const handleItemOpen = React.useCallback(\n (itemValue) => setValue((prevValue = []) => [...prevValue, itemValue]),\n [setValue]\n );\n const handleItemClose = React.useCallback(\n (itemValue) => setValue((prevValue = []) => prevValue.filter((value2) => value2 !== itemValue)),\n [setValue]\n );\n return /* @__PURE__ */ jsx(\n AccordionValueProvider,\n {\n scope: props.__scopeAccordion,\n value,\n onItemOpen: handleItemOpen,\n onItemClose: handleItemClose,\n children: /* @__PURE__ */ jsx(AccordionCollapsibleProvider, { scope: props.__scopeAccordion, collapsible: true, children: /* @__PURE__ */ jsx(AccordionImpl, { ...accordionMultipleProps, ref: forwardedRef }) })\n }\n );\n});\nvar [AccordionImplProvider, useAccordionContext] = createAccordionContext(ACCORDION_NAME);\nvar AccordionImpl = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeAccordion, disabled, dir, orientation = \"vertical\", ...accordionProps } = props;\n const accordionRef = React.useRef(null);\n const composedRefs = useComposedRefs(accordionRef, forwardedRef);\n const getItems = useCollection(__scopeAccordion);\n const direction = useDirection(dir);\n const isDirectionLTR = direction === \"ltr\";\n const handleKeyDown = composeEventHandlers(props.onKeyDown, (event) => {\n if (!ACCORDION_KEYS.includes(event.key)) return;\n const target = event.target;\n const triggerCollection = getItems().filter((item) => !item.ref.current?.disabled);\n const triggerIndex = triggerCollection.findIndex((item) => item.ref.current === target);\n const triggerCount = triggerCollection.length;\n if (triggerIndex === -1) return;\n event.preventDefault();\n let nextIndex = triggerIndex;\n const homeIndex = 0;\n const endIndex = triggerCount - 1;\n const moveNext = () => {\n nextIndex = triggerIndex + 1;\n if (nextIndex > endIndex) {\n nextIndex = homeIndex;\n }\n };\n const movePrev = () => {\n nextIndex = triggerIndex - 1;\n if (nextIndex < homeIndex) {\n nextIndex = endIndex;\n }\n };\n switch (event.key) {\n case \"Home\":\n nextIndex = homeIndex;\n break;\n case \"End\":\n nextIndex = endIndex;\n break;\n case \"ArrowRight\":\n if (orientation === \"horizontal\") {\n if (isDirectionLTR) {\n moveNext();\n } else {\n movePrev();\n }\n }\n break;\n case \"ArrowDown\":\n if (orientation === \"vertical\") {\n moveNext();\n }\n break;\n case \"ArrowLeft\":\n if (orientation === \"horizontal\") {\n if (isDirectionLTR) {\n movePrev();\n } else {\n moveNext();\n }\n }\n break;\n case \"ArrowUp\":\n if (orientation === \"vertical\") {\n movePrev();\n }\n break;\n }\n const clampedIndex = nextIndex % triggerCount;\n triggerCollection[clampedIndex].ref.current?.focus();\n });\n return /* @__PURE__ */ jsx(\n AccordionImplProvider,\n {\n scope: __scopeAccordion,\n disabled,\n direction: dir,\n orientation,\n children: /* @__PURE__ */ jsx(Collection.Slot, { scope: __scopeAccordion, children: /* @__PURE__ */ jsx(\n Primitive.div,\n {\n ...accordionProps,\n \"data-orientation\": orientation,\n ref: composedRefs,\n onKeyDown: disabled ? void 0 : handleKeyDown\n }\n ) })\n }\n );\n }\n);\nvar ITEM_NAME = \"AccordionItem\";\nvar [AccordionItemProvider, useAccordionItemContext] = createAccordionContext(ITEM_NAME);\nvar AccordionItem = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeAccordion, value, ...accordionItemProps } = props;\n const accordionContext = useAccordionContext(ITEM_NAME, __scopeAccordion);\n const valueContext = useAccordionValueContext(ITEM_NAME, __scopeAccordion);\n const collapsibleScope = useCollapsibleScope(__scopeAccordion);\n const triggerId = useId();\n const open = value && valueContext.value.includes(value) || false;\n const disabled = accordionContext.disabled || props.disabled;\n return /* @__PURE__ */ jsx(\n AccordionItemProvider,\n {\n scope: __scopeAccordion,\n open,\n disabled,\n triggerId,\n children: /* @__PURE__ */ jsx(\n CollapsiblePrimitive.Root,\n {\n \"data-orientation\": accordionContext.orientation,\n \"data-state\": getState(open),\n ...collapsibleScope,\n ...accordionItemProps,\n ref: forwardedRef,\n disabled,\n open,\n onOpenChange: (open2) => {\n if (open2) {\n valueContext.onItemOpen(value);\n } else {\n valueContext.onItemClose(value);\n }\n }\n }\n )\n }\n );\n }\n);\nAccordionItem.displayName = ITEM_NAME;\nvar HEADER_NAME = \"AccordionHeader\";\nvar AccordionHeader = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeAccordion, ...headerProps } = props;\n const accordionContext = useAccordionContext(ACCORDION_NAME, __scopeAccordion);\n const itemContext = useAccordionItemContext(HEADER_NAME, __scopeAccordion);\n return /* @__PURE__ */ jsx(\n Primitive.h3,\n {\n \"data-orientation\": accordionContext.orientation,\n \"data-state\": getState(itemContext.open),\n \"data-disabled\": itemContext.disabled ? \"\" : void 0,\n ...headerProps,\n ref: forwardedRef\n }\n );\n }\n);\nAccordionHeader.displayName = HEADER_NAME;\nvar TRIGGER_NAME = \"AccordionTrigger\";\nvar AccordionTrigger = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeAccordion, ...triggerProps } = props;\n const accordionContext = useAccordionContext(ACCORDION_NAME, __scopeAccordion);\n const itemContext = useAccordionItemContext(TRIGGER_NAME, __scopeAccordion);\n const collapsibleContext = useAccordionCollapsibleContext(TRIGGER_NAME, __scopeAccordion);\n const collapsibleScope = useCollapsibleScope(__scopeAccordion);\n return /* @__PURE__ */ jsx(Collection.ItemSlot, { scope: __scopeAccordion, children: /* @__PURE__ */ jsx(\n CollapsiblePrimitive.Trigger,\n {\n \"aria-disabled\": itemContext.open && !collapsibleContext.collapsible || void 0,\n \"data-orientation\": accordionContext.orientation,\n id: itemContext.triggerId,\n ...collapsibleScope,\n ...triggerProps,\n ref: forwardedRef\n }\n ) });\n }\n);\nAccordionTrigger.displayName = TRIGGER_NAME;\nvar CONTENT_NAME = \"AccordionContent\";\nvar AccordionContent = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeAccordion, ...contentProps } = props;\n const accordionContext = useAccordionContext(ACCORDION_NAME, __scopeAccordion);\n const itemContext = useAccordionItemContext(CONTENT_NAME, __scopeAccordion);\n const collapsibleScope = useCollapsibleScope(__scopeAccordion);\n return /* @__PURE__ */ jsx(\n CollapsiblePrimitive.Content,\n {\n role: \"region\",\n \"aria-labelledby\": itemContext.triggerId,\n \"data-orientation\": accordionContext.orientation,\n ...collapsibleScope,\n ...contentProps,\n ref: forwardedRef,\n style: {\n [\"--radix-accordion-content-height\"]: \"var(--radix-collapsible-content-height)\",\n [\"--radix-accordion-content-width\"]: \"var(--radix-collapsible-content-width)\",\n ...props.style\n }\n }\n );\n }\n);\nAccordionContent.displayName = CONTENT_NAME;\nfunction getState(open) {\n return open ? \"open\" : \"closed\";\n}\nvar Root2 = Accordion;\nvar Item = AccordionItem;\nvar Header = AccordionHeader;\nvar Trigger2 = AccordionTrigger;\nvar Content2 = AccordionContent;\nexport {\n Accordion,\n AccordionContent,\n AccordionHeader,\n AccordionItem,\n AccordionTrigger,\n Content2 as Content,\n Header,\n Item,\n Root2 as Root,\n Trigger2 as Trigger,\n createAccordionScope\n};\n//# sourceMappingURL=index.mjs.map\n","import * as AccordionPrimitive from '@radix-ui/react-accordion'\nimport { cn } from '../../lib/cn'\n\nexport const Accordion = AccordionPrimitive.Root\n\nexport interface AccordionItemProps\n extends React.ComponentPropsWithoutRef<typeof AccordionPrimitive.Item> {}\n\nexport interface AccordionTriggerProps\n extends React.ComponentPropsWithoutRef<typeof AccordionPrimitive.Trigger> {}\n\nexport interface AccordionContentProps\n extends React.ComponentPropsWithoutRef<typeof AccordionPrimitive.Content> {}\n\n/* ----------------------------------------------------------\n AccordionItem\n ---------------------------------------------------------- */\n\n/**\n * Wrapper for one collapsible section. Requires a unique `value` prop.\n */\nexport function AccordionItem({ className, ...props }: AccordionItemProps) {\n return (\n <AccordionPrimitive.Item\n className={cn('border-b border-rule', className)}\n {...props}\n />\n )\n}\n\n/* ----------------------------------------------------------\n AccordionTrigger\n ---------------------------------------------------------- */\n\n/**\n * Clickable header that toggles the section open/closed.\n * Renders a rotating chevron on the right — pass children for the label.\n */\nexport function AccordionTrigger({ className, children, ...props }: AccordionTriggerProps) {\n return (\n <AccordionPrimitive.Header className=\"flex\">\n <AccordionPrimitive.Trigger\n className={cn(\n // Layout\n 'flex flex-1 items-center justify-between',\n // Spacing\n 'py-4',\n // Typography\n 'font-display font-bold text-sm tracking-widest uppercase text-void',\n // Interaction\n 'cursor-pointer',\n 'transition-colors duration-fast',\n 'hover:text-signal-alt',\n // Disabled\n 'disabled:cursor-not-allowed disabled:opacity-50 disabled:hover:text-void',\n // Focus\n 'outline-none focus-visible:ring-2 focus-visible:ring-signal-alt focus-visible:ring-inset rounded-sm',\n className,\n )}\n {...props}\n >\n {children}\n\n {/* Chevron — rotates 180° when open */}\n <svg\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 16 16\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"1.5\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n aria-hidden=\"true\"\n className=\"shrink-0 text-smoke transition-transform duration-base ease-(--ease-standard) group-data-[state=open]:rotate-180 [[data-state=open]_&]:rotate-180\"\n >\n <path d=\"M4 6l4 4 4-4\" />\n </svg>\n </AccordionPrimitive.Trigger>\n </AccordionPrimitive.Header>\n )\n}\n\n/* ----------------------------------------------------------\n AccordionContent\n ---------------------------------------------------------- */\n\n/**\n * Collapsible body panel. Animates height via CSS keyframes that consume\n * `--radix-accordion-content-height`.\n */\nexport function AccordionContent({ className, children, ...props }: AccordionContentProps) {\n return (\n <AccordionPrimitive.Content\n className={cn(\n 'overflow-hidden text-sm text-void',\n 'data-[state=open]:animate-[accordion-down_200ms_ease]',\n 'data-[state=closed]:animate-[accordion-up_150ms_ease]',\n className,\n )}\n {...props}\n >\n <div className=\"pb-4 pt-0\">{children}</div>\n </AccordionPrimitive.Content>\n )\n}\n","import { cn } from '../../lib/cn'\n\nexport type StepState = 'completed' | 'active' | 'upcoming' | 'error'\nexport type StepperOrientation = 'horizontal' | 'vertical'\n\nexport interface Step {\n label: string\n description?: string\n /** Override the computed state for this step, e.g. 'error'. */\n state?: StepState\n}\n\nexport interface StepperProps extends React.HTMLAttributes<HTMLDivElement> {\n steps: Step[]\n /** Zero-based index of the currently active step. */\n currentStep: number\n orientation?: StepperOrientation\n}\n\n/* ----------------------------------------------------------\n Helpers\n ---------------------------------------------------------- */\n\nfunction resolveState(step: Step, index: number, currentStep: number): StepState {\n if (step.state) return step.state\n if (index < currentStep) return 'completed'\n if (index === currentStep) return 'active'\n return 'upcoming'\n}\n\n/* ----------------------------------------------------------\n Step indicator icon\n ---------------------------------------------------------- */\n\nfunction StepIcon({ state, index }: { state: StepState; index: number }) {\n const base = 'w-8 h-8 rounded-full flex items-center justify-center shrink-0 transition-colors duration-base'\n\n if (state === 'completed') {\n return (\n <span className={cn(base, 'bg-[var(--color-growth)] text-paper')}>\n <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"2\" strokeLinecap=\"round\" strokeLinejoin=\"round\" aria-hidden=\"true\">\n <path d=\"M2 7l3.5 3.5L12 3\" />\n </svg>\n </span>\n )\n }\n\n if (state === 'error') {\n return (\n <span className={cn(base, 'bg-signal text-paper')}>\n <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"2\" strokeLinecap=\"round\" aria-hidden=\"true\">\n <path d=\"M2 2l10 10M12 2L2 12\" />\n </svg>\n </span>\n )\n }\n\n if (state === 'active') {\n return (\n <span className={cn(\n base,\n 'bg-signal-alt text-paper',\n 'ring-4 ring-[color-mix(in_srgb,var(--color-signal-alt)_20%,var(--color-paper))]',\n )}>\n <span className=\"font-display font-bold text-xs leading-none\">{index + 1}</span>\n </span>\n )\n }\n\n // upcoming\n return (\n <span className={cn(base, 'border-2 border-rule bg-paper text-smoke')}>\n <span className=\"font-display font-bold text-xs leading-none\">{index + 1}</span>\n </span>\n )\n}\n\n/* ----------------------------------------------------------\n Stepper — horizontal\n ---------------------------------------------------------- */\n\nfunction HorizontalStepper({ steps, currentStep }: { steps: Step[]; currentStep: number }) {\n return (\n <div className=\"flex items-start w-full\">\n {steps.map((step, i) => {\n const state = resolveState(step, i, currentStep)\n const isLast = i === steps.length - 1\n const lineComplete = i < currentStep\n\n return (\n <div\n key={i}\n role=\"listitem\"\n aria-current={state === 'active' ? 'step' : undefined}\n className={cn('flex items-start', !isLast && 'flex-1')}\n >\n {/* Icon + label stacked */}\n <div className=\"flex flex-col items-center gap-1.5 shrink-0\">\n <StepIcon state={state} index={i} />\n <p className={cn(\n 'text-xs font-display font-bold tracking-widest uppercase leading-tight text-center',\n state === 'active' && 'text-void',\n state === 'completed' && 'text-[var(--color-growth)]',\n state === 'error' && 'text-signal',\n state === 'upcoming' && 'text-smoke',\n )}>\n {step.label}\n </p>\n {step.description && (\n <p className=\"text-xs text-smoke leading-snug text-center max-w-[100px]\">\n {step.description}\n </p>\n )}\n </div>\n\n {/* Connector line */}\n {!isLast && (\n <div\n aria-hidden=\"true\"\n className={cn(\n 'flex-1 h-px mt-4 mx-2 transition-colors duration-base',\n lineComplete ? 'bg-[var(--color-growth)]' : 'bg-rule',\n )}\n />\n )}\n </div>\n )\n })}\n </div>\n )\n}\n\n/* ----------------------------------------------------------\n Stepper — vertical\n ---------------------------------------------------------- */\n\nfunction VerticalStepper({ steps, currentStep }: { steps: Step[]; currentStep: number }) {\n return (\n <div className=\"flex flex-col\">\n {steps.map((step, i) => {\n const state = resolveState(step, i, currentStep)\n const isLast = i === steps.length - 1\n const lineComplete = i < currentStep\n\n return (\n <div\n key={i}\n role=\"listitem\"\n aria-current={state === 'active' ? 'step' : undefined}\n className=\"flex gap-3\"\n >\n {/* Left column: icon + connector line */}\n <div className=\"flex flex-col items-center\">\n <StepIcon state={state} index={i} />\n {!isLast && (\n <div\n aria-hidden=\"true\"\n className={cn(\n 'w-px flex-1 my-1 min-h-[20px] transition-colors duration-base',\n lineComplete ? 'bg-[var(--color-growth)]' : 'bg-rule',\n )}\n />\n )}\n </div>\n\n {/* Right column: label + description */}\n <div className={cn('flex flex-col justify-center', !isLast && 'pb-6')}>\n <p className={cn(\n 'text-xs font-display font-bold tracking-widest uppercase leading-tight',\n state === 'active' && 'text-void',\n state === 'completed' && 'text-[var(--color-growth)]',\n state === 'error' && 'text-signal',\n state === 'upcoming' && 'text-smoke',\n )}>\n {step.label}\n </p>\n {step.description && (\n <p className=\"text-xs text-smoke leading-snug mt-0.5\">{step.description}</p>\n )}\n </div>\n </div>\n )\n })}\n </div>\n )\n}\n\n/* ----------------------------------------------------------\n Stepper (public)\n ---------------------------------------------------------- */\n\n/**\n * Progress indicator for multi-step flows.\n * Step states are computed automatically from `currentStep`; override a\n * specific step by setting `step.state = 'error'`.\n *\n * @example\n * <Stepper steps={wizardSteps} currentStep={1} />\n * <Stepper steps={coSteps} currentStep={2} orientation=\"vertical\" />\n */\nexport function Stepper({\n steps,\n currentStep,\n orientation = 'horizontal',\n className,\n ...props\n}: StepperProps) {\n return (\n <div\n role=\"list\"\n aria-label=\"Progress\"\n className={cn(className)}\n {...props}\n >\n {orientation === 'vertical'\n ? <VerticalStepper steps={steps} currentStep={currentStep} />\n : <HorizontalStepper steps={steps} currentStep={currentStep} />\n }\n </div>\n )\n}\n","import React, { useState, useRef, useId, useMemo, useCallback, useEffect } from 'react'\nimport * as PopoverPrimitive from '@radix-ui/react-popover'\nimport { cn } from '../../lib/cn'\n\nexport interface ComboboxOption {\n value: string\n label: string\n description?: string\n disabled?: boolean\n}\n\nexport interface ComboboxProps {\n options: ComboboxOption[]\n /** Controlled selected value. */\n value?: string\n onValueChange?: (value: string) => void\n placeholder?: string\n searchPlaceholder?: string\n emptyMessage?: string\n disabled?: boolean\n className?: string\n id?: string\n}\n\n/* ----------------------------------------------------------\n Icons\n ---------------------------------------------------------- */\n\nfunction ChevronDownIcon({ className }: { className?: string }) {\n return (\n <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"1.5\" strokeLinecap=\"round\" strokeLinejoin=\"round\" aria-hidden=\"true\" className={className}>\n <path d=\"M3 5l4 4 4-4\" />\n </svg>\n )\n}\n\nfunction CheckIcon() {\n return (\n <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"2\" strokeLinecap=\"round\" strokeLinejoin=\"round\" aria-hidden=\"true\">\n <path d=\"M2 7l3.5 3.5L12 3\" />\n </svg>\n )\n}\n\nfunction SearchIcon() {\n return (\n <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"1.5\" strokeLinecap=\"round\" strokeLinejoin=\"round\" aria-hidden=\"true\">\n <circle cx=\"6\" cy=\"6\" r=\"4\" />\n <path d=\"M12 12l-2.5-2.5\" />\n </svg>\n )\n}\n\n/* ----------------------------------------------------------\n Combobox\n ---------------------------------------------------------- */\n\n/**\n * Searchable select — a text input that filters a dropdown list.\n * Built on Radix Popover with a custom listbox for full token compliance.\n * Keyboard: ArrowDown/Up navigate, Enter selects, Escape closes.\n *\n * @example\n * <Combobox options={trades} placeholder=\"Select trade…\" onValueChange={setTrade} />\n */\nexport function Combobox({\n options,\n value,\n onValueChange,\n placeholder = 'Select…',\n searchPlaceholder = 'Search…',\n emptyMessage = 'No results found.',\n disabled = false,\n className,\n id,\n}: ComboboxProps) {\n const [open, setOpen] = useState(false)\n const [search, setSearch] = useState('')\n const [highlightedIndex, setHighlightedIndex] = useState(0)\n\n const inputRef = useRef<HTMLInputElement>(null)\n const listRef = useRef<HTMLUListElement>(null)\n const genId = useId()\n const listboxId = `${id ?? genId}-listbox`\n\n // Derive label for the currently selected value\n const selectedLabel = useMemo(\n () => options.find((o) => o.value === value)?.label ?? '',\n [options, value],\n )\n\n // Filter options by search text\n const filtered = useMemo(() => {\n const q = search.toLowerCase()\n return q\n ? options.filter(\n (o) => o.label.toLowerCase().includes(q) || o.description?.toLowerCase().includes(q),\n )\n : options\n }, [options, search])\n\n // Reset highlight when filtered list changes\n useEffect(() => {\n setHighlightedIndex(0)\n }, [filtered.length])\n\n // Scroll highlighted item into view\n useEffect(() => {\n if (!open) return\n const item = listRef.current?.children[highlightedIndex] as HTMLElement | undefined\n item?.scrollIntoView({ block: 'nearest' })\n }, [highlightedIndex, open])\n\n const selectOption = useCallback((option: ComboboxOption) => {\n if (option.disabled) return\n onValueChange?.(option.value)\n setSearch('')\n setOpen(false)\n }, [onValueChange])\n\n const handleKeyDown = useCallback((e: React.KeyboardEvent) => {\n if (!open) {\n if (e.key === 'ArrowDown' || e.key === 'Enter' || e.key === ' ') {\n e.preventDefault()\n setOpen(true)\n }\n return\n }\n\n switch (e.key) {\n case 'ArrowDown':\n e.preventDefault()\n setHighlightedIndex((i) => Math.min(i + 1, filtered.length - 1))\n break\n case 'ArrowUp':\n e.preventDefault()\n setHighlightedIndex((i) => Math.max(i - 1, 0))\n break\n case 'Enter':\n e.preventDefault()\n if (filtered[highlightedIndex] && !filtered[highlightedIndex].disabled) {\n selectOption(filtered[highlightedIndex])\n }\n break\n case 'Escape':\n e.preventDefault()\n setSearch('')\n setOpen(false)\n break\n }\n }, [open, filtered, highlightedIndex, selectOption])\n\n return (\n <PopoverPrimitive.Root open={open} onOpenChange={(next) => {\n if (disabled) return\n setOpen(next)\n if (!next) setSearch('')\n }}>\n {/* Trigger — the input button */}\n <PopoverPrimitive.Trigger asChild>\n <button\n id={id}\n type=\"button\"\n role=\"combobox\"\n aria-expanded={open}\n aria-controls={listboxId}\n aria-haspopup=\"listbox\"\n disabled={disabled}\n onKeyDown={handleKeyDown}\n className={cn(\n // Layout\n 'flex items-center justify-between w-full gap-2',\n // Shape\n 'rounded-sm border border-rule bg-paper',\n // Spacing\n 'h-9 px-3',\n // Typography\n 'text-sm text-void',\n // Disabled\n 'disabled:cursor-not-allowed disabled:opacity-50',\n // Focus\n 'outline-none focus-visible:ring-2 focus-visible:ring-signal-alt focus-visible:ring-offset-0',\n // Hover\n 'hover:border-smoke transition-colors duration-fast',\n // Open state border\n open && 'border-signal-alt ring-2 ring-signal-alt',\n className,\n )}\n >\n <span className={cn('truncate', !selectedLabel && 'text-smoke')}>\n {selectedLabel || placeholder}\n </span>\n <ChevronDownIcon className={cn('shrink-0 text-smoke transition-transform duration-fast', open && 'rotate-180')} />\n </button>\n </PopoverPrimitive.Trigger>\n\n {/* Dropdown panel */}\n <PopoverPrimitive.Portal>\n <PopoverPrimitive.Content\n align=\"start\"\n sideOffset={4}\n style={{ width: 'var(--radix-popover-trigger-width)' }}\n onOpenAutoFocus={(e) => {\n e.preventDefault()\n inputRef.current?.focus()\n }}\n className={cn(\n 'z-50 rounded-md border border-rule bg-paper shadow-[var(--shadow-md)] overflow-hidden',\n 'data-[state=open]:animate-[popover-in_150ms_ease]',\n 'data-[state=closed]:animate-[popover-out_100ms_ease]',\n 'outline-none',\n )}\n >\n {/* Search input */}\n <div className=\"flex items-center gap-2 px-3 py-2 border-b border-rule text-smoke\">\n <SearchIcon />\n <input\n ref={inputRef}\n type=\"text\"\n value={search}\n onChange={(e) => setSearch(e.target.value)}\n onKeyDown={handleKeyDown}\n placeholder={searchPlaceholder}\n aria-controls={listboxId}\n className=\"flex-1 text-sm text-void bg-transparent outline-none placeholder:text-smoke\"\n />\n {search && (\n <button\n type=\"button\"\n aria-label=\"Clear search\"\n onClick={() => setSearch('')}\n className=\"text-smoke hover:text-void transition-colors duration-fast\"\n >\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"1.5\" strokeLinecap=\"round\" aria-hidden=\"true\">\n <path d=\"M2 2l8 8M10 2l-8 8\" />\n </svg>\n </button>\n )}\n </div>\n\n {/* Option list */}\n <ul\n id={listboxId}\n ref={listRef}\n role=\"listbox\"\n aria-label=\"Options\"\n className=\"max-h-60 overflow-y-auto py-1\"\n >\n {filtered.length === 0 ? (\n <li className=\"px-3 py-6 text-sm text-smoke text-center\">{emptyMessage}</li>\n ) : (\n filtered.map((option, i) => {\n const isSelected = option.value === value\n const isHighlighted = i === highlightedIndex\n return (\n <li\n key={option.value}\n role=\"option\"\n aria-selected={isSelected}\n aria-disabled={option.disabled}\n onMouseEnter={() => setHighlightedIndex(i)}\n onClick={() => selectOption(option)}\n className={cn(\n 'flex items-center gap-2 px-3 py-2 cursor-pointer select-none',\n // Highlight on hover/keyboard nav\n isHighlighted && !option.disabled && 'bg-[color-mix(in_srgb,var(--color-signal-alt)_8%,var(--color-paper))]',\n // Disabled\n option.disabled && 'cursor-not-allowed opacity-40',\n )}\n >\n {/* Check mark column (always occupies space to prevent label shift) */}\n <span className={cn('w-4 shrink-0 text-signal-alt', !isSelected && 'invisible')}>\n <CheckIcon />\n </span>\n\n <span className=\"flex flex-col min-w-0\">\n <span className={cn('text-sm truncate', isSelected ? 'text-void font-medium' : 'text-void')}>\n {option.label}\n </span>\n {option.description && (\n <span className=\"text-xs text-smoke truncate\">{option.description}</span>\n )}\n </span>\n </li>\n )\n })\n )}\n </ul>\n </PopoverPrimitive.Content>\n </PopoverPrimitive.Portal>\n </PopoverPrimitive.Root>\n )\n}\n","import { useState } from 'react'\nimport * as PopoverPrimitive from '@radix-ui/react-popover'\nimport { cn } from '../../lib/cn'\n\n/* ----------------------------------------------------------\n Calendar helpers\n ---------------------------------------------------------- */\n\nconst DAY_ABBR = ['Su', 'Mo', 'Tu', 'We', 'Th', 'Fr', 'Sa']\n\nfunction isSameDay(a: Date, b: Date): boolean {\n return (\n a.getFullYear() === b.getFullYear() &&\n a.getMonth() === b.getMonth() &&\n a.getDate() === b.getDate()\n )\n}\n\nfunction isToday(date: Date): boolean {\n return isSameDay(date, new Date())\n}\n\n/** Returns a padded 42-cell grid (6 × 7) for the given month. */\nfunction getCalendarGrid(year: number, month: number): Array<Date | null> {\n const first = new Date(year, month, 1)\n const lastDate = new Date(year, month + 1, 0).getDate()\n const startPad = first.getDay()\n const grid: Array<Date | null> = []\n\n for (let i = 0; i < startPad; i++) grid.push(null)\n for (let d = 1; d <= lastDate; d++) grid.push(new Date(year, month, d))\n\n const remainder = grid.length % 7\n if (remainder > 0) {\n for (let i = 0; i < 7 - remainder; i++) grid.push(null)\n }\n\n return grid\n}\n\nfunction formatDisplay(date: Date): string {\n return new Intl.DateTimeFormat('en-CA', { dateStyle: 'medium' }).format(date)\n}\n\nfunction formatMonthYear(year: number, month: number): string {\n return new Intl.DateTimeFormat('en-CA', {\n month: 'long',\n year: 'numeric',\n }).format(new Date(year, month, 1))\n}\n\n/* ----------------------------------------------------------\n Calendar grid (internal)\n ---------------------------------------------------------- */\n\ninterface CalendarProps {\n selected?: Date\n onSelect: (date: Date) => void\n viewYear: number\n viewMonth: number\n onMonthChange: (year: number, month: number) => void\n}\n\nfunction Calendar({ selected, onSelect, viewYear, viewMonth, onMonthChange }: CalendarProps) {\n const grid = getCalendarGrid(viewYear, viewMonth)\n\n function prevMonth() {\n viewMonth === 0\n ? onMonthChange(viewYear - 1, 11)\n : onMonthChange(viewYear, viewMonth - 1)\n }\n\n function nextMonth() {\n viewMonth === 11\n ? onMonthChange(viewYear + 1, 0)\n : onMonthChange(viewYear, viewMonth + 1)\n }\n\n const navBtn = cn(\n 'w-7 h-7 flex items-center justify-center rounded-sm',\n 'text-smoke hover:text-void hover:bg-rule',\n 'transition-colors duration-fast',\n 'outline-none focus-visible:ring-2 focus-visible:ring-signal-alt',\n )\n\n return (\n <div className=\"p-3 select-none w-[268px]\">\n {/* Month / year nav */}\n <div className=\"flex items-center justify-between mb-3\">\n <button type=\"button\" onClick={prevMonth} aria-label=\"Previous month\" className={navBtn}>\n <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"1.5\" strokeLinecap=\"round\" strokeLinejoin=\"round\" aria-hidden=\"true\">\n <path d=\"M9 3L5 7l4 4\" />\n </svg>\n </button>\n <span className=\"font-display font-bold text-xs tracking-widest uppercase text-void\">\n {formatMonthYear(viewYear, viewMonth)}\n </span>\n <button type=\"button\" onClick={nextMonth} aria-label=\"Next month\" className={navBtn}>\n <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"1.5\" strokeLinecap=\"round\" strokeLinejoin=\"round\" aria-hidden=\"true\">\n <path d=\"M5 3l4 4-4 4\" />\n </svg>\n </button>\n </div>\n\n {/* Day-of-week headers */}\n <div className=\"grid grid-cols-7 mb-1\">\n {DAY_ABBR.map((d) => (\n <div key={d} className=\"h-8 flex items-center justify-center text-xs text-smoke font-display font-bold tracking-wider uppercase\">\n {d}\n </div>\n ))}\n </div>\n\n {/* Day buttons */}\n <div className=\"grid grid-cols-7 gap-y-0.5\">\n {grid.map((date, i) => {\n if (!date) return <div key={`pad-${i}`} className=\"h-8\" />\n\n const isSelected = selected && isSameDay(date, selected)\n const today = isToday(date)\n\n return (\n <button\n key={date.toISOString()}\n type=\"button\"\n onClick={() => onSelect(date)}\n aria-label={formatDisplay(date)}\n aria-pressed={isSelected ?? false}\n className={cn(\n 'h-8 w-8 mx-auto flex items-center justify-center rounded-sm text-sm',\n 'outline-none focus-visible:ring-2 focus-visible:ring-signal-alt',\n 'transition-colors duration-fast',\n isSelected\n ? 'bg-signal-alt text-paper font-medium'\n : today\n ? 'border border-signal-alt text-signal-alt font-medium hover:bg-[color-mix(in_srgb,var(--color-signal-alt)_10%,var(--color-paper))]'\n : 'text-void hover:bg-rule',\n )}\n >\n {date.getDate()}\n </button>\n )\n })}\n </div>\n </div>\n )\n}\n\n/* ----------------------------------------------------------\n DatePicker\n ---------------------------------------------------------- */\n\nexport interface DatePickerProps {\n /** Controlled selected date. */\n value?: Date\n onValueChange?: (date: Date) => void\n placeholder?: string\n disabled?: boolean\n className?: string\n id?: string\n}\n\n/**\n * Date input with a calendar popover.\n * Built on Radix Popover — handles portal, focus, outside-click.\n *\n * @example\n * <DatePicker value={date} onValueChange={setDate} placeholder=\"Select date…\" />\n */\nexport function DatePicker({\n value,\n onValueChange,\n placeholder = 'Select date…',\n disabled = false,\n className,\n id,\n}: DatePickerProps) {\n const today = new Date()\n const [open, setOpen] = useState(false)\n const [viewYear, setViewYear] = useState(value?.getFullYear() ?? today.getFullYear())\n const [viewMonth, setViewMonth] = useState(value?.getMonth() ?? today.getMonth())\n\n function handleOpenChange(next: boolean) {\n if (disabled) return\n if (next && value) {\n setViewYear(value.getFullYear())\n setViewMonth(value.getMonth())\n }\n setOpen(next)\n }\n\n function handleSelect(date: Date) {\n onValueChange?.(date)\n setOpen(false)\n }\n\n return (\n <PopoverPrimitive.Root open={open} onOpenChange={handleOpenChange}>\n <PopoverPrimitive.Trigger asChild>\n <button\n id={id}\n type=\"button\"\n disabled={disabled}\n aria-haspopup=\"dialog\"\n aria-expanded={open}\n className={cn(\n 'flex items-center justify-between w-full gap-2',\n 'rounded-sm border border-rule bg-paper',\n 'h-9 px-3 text-sm',\n value ? 'text-void' : 'text-smoke',\n 'disabled:cursor-not-allowed disabled:opacity-50',\n 'outline-none focus-visible:ring-2 focus-visible:ring-signal-alt',\n 'hover:border-smoke transition-colors duration-fast',\n open && 'border-signal-alt ring-2 ring-signal-alt',\n className,\n )}\n >\n <span>{value ? formatDisplay(value) : placeholder}</span>\n {/* Calendar icon */}\n <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"1.5\" strokeLinecap=\"round\" strokeLinejoin=\"round\" aria-hidden=\"true\" className=\"shrink-0 text-smoke\">\n <rect x=\"1.5\" y=\"2.5\" width=\"11\" height=\"10\" rx=\"1\" />\n <path d=\"M1.5 6h11M5 1v3M9 1v3\" />\n </svg>\n </button>\n </PopoverPrimitive.Trigger>\n\n <PopoverPrimitive.Portal>\n <PopoverPrimitive.Content\n align=\"start\"\n sideOffset={4}\n className={cn(\n 'z-50 rounded-md border border-rule bg-paper shadow-[var(--shadow-md)]',\n 'data-[state=open]:animate-[popover-in_150ms_ease]',\n 'data-[state=closed]:animate-[popover-out_100ms_ease]',\n 'outline-none',\n )}\n >\n <Calendar\n selected={value}\n onSelect={handleSelect}\n viewYear={viewYear}\n viewMonth={viewMonth}\n onMonthChange={(y, m) => { setViewYear(y); setViewMonth(m) }}\n />\n </PopoverPrimitive.Content>\n </PopoverPrimitive.Portal>\n </PopoverPrimitive.Root>\n )\n}\n","import React, { useRef, useState, useCallback, useId } from 'react'\nimport { cn } from '../../lib/cn'\n\nexport interface FileUploadProps {\n /** Accepted MIME types or extensions, e.g. \".pdf,image/*\". Passed to <input>. */\n accept?: string\n multiple?: boolean\n /** Max bytes per file. Violations are reported as errors, not silently dropped. */\n maxSize?: number\n /** Max total files. Additional files beyond this are ignored with an error. */\n maxFiles?: number\n onFilesChange?: (files: File[]) => void\n disabled?: boolean\n /** Override the primary drop zone label. */\n label?: string\n /** Short helper text shown below the label inside the drop zone. */\n hint?: string\n className?: string\n id?: string\n}\n\n/* ----------------------------------------------------------\n Helpers\n ---------------------------------------------------------- */\n\nfunction formatBytes(bytes: number): string {\n if (bytes < 1024) return `${bytes} B`\n if (bytes < 1048576) return `${(bytes / 1024).toFixed(1)} KB`\n return `${(bytes / 1048576).toFixed(1)} MB`\n}\n\nfunction getFileExtension(file: File): string {\n return file.name.split('.').pop()?.toUpperCase() ?? '?'\n}\n\n/* ----------------------------------------------------------\n Icons\n ---------------------------------------------------------- */\n\nfunction UploadIcon() {\n return (\n <svg width=\"32\" height=\"32\" viewBox=\"0 0 32 32\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"1.5\" strokeLinecap=\"round\" strokeLinejoin=\"round\" aria-hidden=\"true\">\n <path d=\"M10 22a6 6 0 0 1 0-12h.5A8.5 8.5 0 0 1 27 14.5c0 4.14-3.36 7.5-7.5 7.5H10z\" />\n <path d=\"M16 26V16M12 20l4-4 4 4\" />\n </svg>\n )\n}\n\nfunction FileIcon() {\n return (\n <svg width=\"16\" height=\"16\" viewBox=\"0 0 16 16\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"1.5\" strokeLinecap=\"round\" strokeLinejoin=\"round\" aria-hidden=\"true\">\n <path d=\"M10 2H4a1 1 0 0 0-1 1v10a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1V6l-3-4z\" />\n <path d=\"M10 2v4h4\" />\n </svg>\n )\n}\n\n/* ----------------------------------------------------------\n FileUpload\n ---------------------------------------------------------- */\n\n/**\n * Drag-and-drop file upload zone.\n * Validates file size and count; reports errors inline.\n * Use `accept` to restrict file types (passed straight to `<input type=\"file\">`).\n *\n * @example\n * <FileUpload accept=\".pdf\" multiple maxSize={10 * 1024 * 1024} onFilesChange={setDocs} />\n */\nexport function FileUpload({\n accept,\n multiple = true,\n maxSize,\n maxFiles,\n onFilesChange,\n disabled = false,\n label = 'Drop files here or click to browse',\n hint,\n className,\n id,\n}: FileUploadProps) {\n const [files, setFiles] = useState<File[]>([])\n const [dragging, setDragging] = useState(false)\n const [errors, setErrors] = useState<string[]>([])\n\n const inputRef = useRef<HTMLInputElement>(null)\n const genId = useId()\n const inputId = id ?? genId\n\n const validate = useCallback((incoming: File[]): { accepted: File[]; errors: string[] } => {\n const errs: string[] = []\n let accepted = incoming\n\n if (maxFiles && files.length + incoming.length > maxFiles) {\n const allowed = maxFiles - files.length\n errs.push(`Max ${maxFiles} files — only ${allowed > 0 ? allowed : 0} more can be added.`)\n accepted = incoming.slice(0, Math.max(0, allowed))\n }\n\n if (maxSize) {\n const tooBig = accepted.filter((f) => f.size > maxSize)\n if (tooBig.length > 0) {\n errs.push(`${tooBig.map((f) => f.name).join(', ')} exceed${tooBig.length === 1 ? 's' : ''} the ${formatBytes(maxSize)} limit.`)\n accepted = accepted.filter((f) => f.size <= maxSize)\n }\n }\n\n return { accepted, errors: errs }\n }, [files.length, maxSize, maxFiles])\n\n const addFiles = useCallback((incoming: File[]) => {\n // Deduplicate by name+size\n const existing = new Set(files.map((f) => `${f.name}:${f.size}`))\n const fresh = incoming.filter((f) => !existing.has(`${f.name}:${f.size}`))\n\n const { accepted, errors: errs } = validate(fresh)\n const next = multiple ? [...files, ...accepted] : accepted.slice(0, 1)\n setFiles(next)\n setErrors(errs)\n onFilesChange?.(next)\n }, [files, multiple, onFilesChange, validate])\n\n const removeFile = useCallback((index: number) => {\n const next = files.filter((_, i) => i !== index)\n setFiles(next)\n setErrors([])\n onFilesChange?.(next)\n // Reset input so the same file can be re-added\n if (inputRef.current) inputRef.current.value = ''\n }, [files, onFilesChange])\n\n /* --- Drag handlers --- */\n function onDragEnter(e: React.DragEvent) {\n e.preventDefault()\n if (!disabled) setDragging(true)\n }\n function onDragLeave(e: React.DragEvent) {\n e.preventDefault()\n if (e.currentTarget === e.target) setDragging(false)\n }\n function onDragOver(e: React.DragEvent) {\n e.preventDefault()\n }\n function onDrop(e: React.DragEvent) {\n e.preventDefault()\n setDragging(false)\n if (disabled) return\n addFiles(Array.from(e.dataTransfer.files))\n }\n\n function onInputChange(e: React.ChangeEvent<HTMLInputElement>) {\n if (e.target.files) addFiles(Array.from(e.target.files))\n }\n\n return (\n <div className={cn('flex flex-col gap-2', className)}>\n {/* Drop zone */}\n <div\n role=\"button\"\n aria-label={label}\n tabIndex={disabled ? -1 : 0}\n onDragEnter={onDragEnter}\n onDragLeave={onDragLeave}\n onDragOver={onDragOver}\n onDrop={onDrop}\n onClick={() => !disabled && inputRef.current?.click()}\n onKeyDown={(e) => { if (e.key === 'Enter' || e.key === ' ') { e.preventDefault(); !disabled && inputRef.current?.click() } }}\n className={cn(\n 'flex flex-col items-center justify-center gap-2 rounded-md border-2 border-dashed',\n 'py-8 px-4 text-center cursor-pointer',\n 'transition-colors duration-fast',\n !dragging && !disabled && 'border-rule text-smoke hover:border-signal-alt hover:text-signal-alt',\n dragging && 'border-signal-alt bg-[color-mix(in_srgb,var(--color-signal-alt)_6%,var(--color-paper))] text-signal-alt',\n disabled && 'border-rule text-smoke opacity-50 cursor-not-allowed',\n 'outline-none focus-visible:ring-2 focus-visible:ring-signal-alt focus-visible:ring-offset-0',\n )}\n >\n <UploadIcon />\n <p className=\"text-sm font-medium\">{label}</p>\n {hint && <p className=\"text-xs text-smoke\">{hint}</p>}\n\n <input\n ref={inputRef}\n id={inputId}\n type=\"file\"\n accept={accept}\n multiple={multiple}\n disabled={disabled}\n onChange={onInputChange}\n className=\"sr-only\"\n tabIndex={-1}\n />\n </div>\n\n {/* Validation errors */}\n {errors.length > 0 && (\n <ul className=\"flex flex-col gap-1\" role=\"alert\">\n {errors.map((err, i) => (\n <li key={i} className=\"text-xs text-signal flex items-start gap-1.5\">\n <span aria-hidden=\"true\">•</span> {err}\n </li>\n ))}\n </ul>\n )}\n\n {/* File list */}\n {files.length > 0 && (\n <ul className=\"flex flex-col divide-y divide-rule border border-rule rounded-sm overflow-hidden\" aria-label=\"Selected files\">\n {files.map((file, i) => (\n <li key={`${file.name}-${i}`} className=\"flex items-center gap-3 px-3 py-2 bg-paper\">\n <span className=\"text-smoke shrink-0\"><FileIcon /></span>\n <div className=\"flex flex-col min-w-0 flex-1\">\n <span className=\"text-sm text-void truncate\">{file.name}</span>\n <span className=\"text-xs text-smoke\">{getFileExtension(file)} — {formatBytes(file.size)}</span>\n </div>\n <button\n type=\"button\"\n onClick={() => removeFile(i)}\n aria-label={`Remove ${file.name}`}\n className={cn(\n 'shrink-0 text-smoke hover:text-signal transition-colors duration-fast',\n 'outline-none focus-visible:ring-2 focus-visible:ring-signal-alt rounded-sm',\n )}\n >\n <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"1.5\" strokeLinecap=\"round\" aria-hidden=\"true\">\n <path d=\"M2 2l10 10M12 2L2 12\" />\n </svg>\n </button>\n </li>\n ))}\n </ul>\n )}\n </div>\n )\n}\n","import React, { useState, useMemo, useCallback } from 'react'\nimport { Table, TableHeader, TableBody, TableRow, TableHead, TableCell } from '../Table'\nimport { cn } from '../../lib/cn'\n\n/* ----------------------------------------------------------\n Types\n ---------------------------------------------------------- */\n\nexport interface DataTableColumn<T> {\n /** Column identifier — also the default sort key via `(row as any)[key]`. */\n key: string\n header: string\n /** Custom cell renderer. If omitted, renders `(row as any)[key]` as a string. */\n cell?: (row: T) => React.ReactNode\n sortable?: boolean\n headerClassName?: string\n cellClassName?: string\n}\n\nexport interface DataTableProps<T> {\n columns: DataTableColumn<T>[]\n data: T[]\n /** Returns a stable unique string key for each row. */\n rowKey: (row: T) => string\n /** Enables pagination; omit to show all rows. */\n pageSize?: number\n /** Renders a search input above the table. */\n searchable?: boolean\n searchPlaceholder?: string\n emptyMessage?: string\n /** Called when a row is clicked. */\n onRowClick?: (row: T) => void\n className?: string\n}\n\ntype SortDir = 'asc' | 'desc'\n\n/* ----------------------------------------------------------\n Sort icons\n ---------------------------------------------------------- */\n\nfunction SortIcon({ dir }: { dir?: SortDir }) {\n return (\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"1.5\" strokeLinecap=\"round\" strokeLinejoin=\"round\" aria-hidden=\"true\" className=\"shrink-0 ml-1\">\n {(!dir || dir === 'asc') && <path d={!dir ? 'M6 2v8M3 5l3-3 3 3' : 'M3 5l3-3 3 3'} className={!dir ? 'opacity-30' : ''} />}\n {(!dir || dir === 'desc') && <path d={!dir ? 'M6 2v8M3 9l3 3 3-3' : 'M3 9l3 3 3-3'} className={!dir ? 'opacity-30' : ''} />}\n </svg>\n )\n}\n\n/* ----------------------------------------------------------\n DataTable\n ---------------------------------------------------------- */\n\n/**\n * Full-featured data table with optional column sorting, search, and pagination.\n * Wraps the base `Table` component and manages all UI state internally.\n *\n * @example\n * <DataTable columns={cols} data={rows} rowKey={(r) => r.id} pageSize={10} searchable />\n */\nexport function DataTable<T>({\n columns,\n data,\n rowKey,\n pageSize,\n searchable = false,\n searchPlaceholder = 'Search…',\n emptyMessage = 'No results found.',\n onRowClick,\n className,\n}: DataTableProps<T>) {\n const [sortCol, setSortCol] = useState<string | null>(null)\n const [sortDir, setSortDir] = useState<SortDir>('asc')\n const [page, setPage] = useState(1)\n const [search, setSearch] = useState('')\n\n const handleSort = useCallback((key: string) => {\n if (sortCol === key) {\n setSortDir((d) => (d === 'asc' ? 'desc' : 'asc'))\n } else {\n setSortCol(key)\n setSortDir('asc')\n }\n setPage(1)\n }, [sortCol])\n\n const handleSearch = useCallback((q: string) => {\n setSearch(q)\n setPage(1)\n }, [])\n\n /* --- Filter --- */\n const filtered = useMemo(() => {\n if (!search.trim()) return data\n const q = search.toLowerCase()\n return data.filter((row) =>\n Object.values(row as Record<string, unknown>).some((v) =>\n String(v ?? '').toLowerCase().includes(q),\n ),\n )\n }, [data, search])\n\n /* --- Sort --- */\n const sorted = useMemo(() => {\n if (!sortCol) return filtered\n return [...filtered].sort((a, b) => {\n const av = (a as Record<string, unknown>)[sortCol]\n const bv = (b as Record<string, unknown>)[sortCol]\n let cmp = 0\n if (typeof av === 'number' && typeof bv === 'number') {\n cmp = av - bv\n } else {\n cmp = String(av ?? '').localeCompare(String(bv ?? ''))\n }\n return sortDir === 'asc' ? cmp : -cmp\n })\n }, [filtered, sortCol, sortDir])\n\n /* --- Paginate --- */\n const totalPages = pageSize ? Math.max(1, Math.ceil(sorted.length / pageSize)) : 1\n const safePage = Math.min(page, totalPages)\n const paged = pageSize\n ? sorted.slice((safePage - 1) * pageSize, safePage * pageSize)\n : sorted\n\n const start = pageSize ? (safePage - 1) * pageSize + 1 : 1\n const end = pageSize ? Math.min(safePage * pageSize, sorted.length) : sorted.length\n\n return (\n <div className={cn('flex flex-col gap-2', className)}>\n {/* Search bar */}\n {searchable && (\n <div className=\"flex items-center gap-2 text-smoke\">\n <svg width=\"14\" height=\"14\" viewBox=\"0 0 14 14\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"1.5\" strokeLinecap=\"round\" strokeLinejoin=\"round\" aria-hidden=\"true\">\n <circle cx=\"6\" cy=\"6\" r=\"4\" />\n <path d=\"M12 12l-2.5-2.5\" />\n </svg>\n <input\n type=\"text\"\n value={search}\n onChange={(e) => handleSearch(e.target.value)}\n placeholder={searchPlaceholder}\n className={cn(\n 'flex-1 h-9 px-0 text-sm text-void bg-transparent border-b border-rule',\n 'outline-none focus:border-signal-alt placeholder:text-smoke',\n 'transition-colors duration-fast',\n )}\n />\n {search && (\n <button\n type=\"button\"\n aria-label=\"Clear search\"\n onClick={() => handleSearch('')}\n className=\"text-smoke hover:text-void transition-colors duration-fast outline-none focus-visible:ring-2 focus-visible:ring-signal-alt rounded-sm\"\n >\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"1.5\" strokeLinecap=\"round\" aria-hidden=\"true\">\n <path d=\"M2 2l8 8M10 2l-8 8\" />\n </svg>\n </button>\n )}\n </div>\n )}\n\n {/* Table */}\n <div className=\"overflow-x-auto rounded-md border border-rule\">\n <Table>\n <TableHeader>\n <TableRow>\n {columns.map((col) => (\n <TableHead\n key={col.key}\n className={cn(\n col.sortable && 'cursor-pointer select-none hover:text-void transition-colors duration-fast',\n col.headerClassName,\n )}\n onClick={col.sortable ? () => handleSort(col.key) : undefined}\n aria-sort={\n sortCol === col.key\n ? sortDir === 'asc' ? 'ascending' : 'descending'\n : col.sortable ? 'none' : undefined\n }\n >\n <span className=\"inline-flex items-center\">\n {col.header}\n {col.sortable && (\n <SortIcon dir={sortCol === col.key ? sortDir : undefined} />\n )}\n </span>\n </TableHead>\n ))}\n </TableRow>\n </TableHeader>\n\n <TableBody>\n {paged.length === 0 ? (\n <TableRow>\n <TableCell\n colSpan={columns.length}\n className=\"py-10 text-center text-sm text-smoke\"\n >\n {emptyMessage}\n </TableCell>\n </TableRow>\n ) : (\n paged.map((row) => (\n <TableRow\n key={rowKey(row)}\n onClick={onRowClick ? () => onRowClick(row) : undefined}\n className={onRowClick ? 'cursor-pointer hover:bg-[color-mix(in_srgb,var(--color-rule)_40%,var(--color-paper))]' : undefined}\n >\n {columns.map((col) => (\n <TableCell key={col.key} className={col.cellClassName}>\n {col.cell\n ? col.cell(row)\n : String((row as Record<string, unknown>)[col.key] ?? '')}\n </TableCell>\n ))}\n </TableRow>\n ))\n )}\n </TableBody>\n </Table>\n </div>\n\n {/* Pagination footer */}\n {pageSize && sorted.length > 0 && (\n <div className=\"flex items-center justify-between text-sm text-smoke px-1\">\n <span className=\"tabular-nums\">\n {start}–{end} of {sorted.length}\n </span>\n <div className=\"flex items-center gap-1\">\n <button\n type=\"button\"\n disabled={safePage <= 1}\n onClick={() => setPage((p) => p - 1)}\n aria-label=\"Previous page\"\n className={cn(\n 'w-8 h-8 flex items-center justify-center rounded-sm border border-rule',\n 'hover:border-smoke hover:text-void transition-colors duration-fast',\n 'outline-none focus-visible:ring-2 focus-visible:ring-signal-alt',\n 'disabled:opacity-40 disabled:cursor-not-allowed disabled:hover:border-rule disabled:hover:text-smoke',\n )}\n >\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"1.5\" strokeLinecap=\"round\" strokeLinejoin=\"round\" aria-hidden=\"true\">\n <path d=\"M8 2L4 6l4 4\" />\n </svg>\n </button>\n <span className=\"px-2 tabular-nums text-void\">\n {safePage} / {totalPages}\n </span>\n <button\n type=\"button\"\n disabled={safePage >= totalPages}\n onClick={() => setPage((p) => p + 1)}\n aria-label=\"Next page\"\n className={cn(\n 'w-8 h-8 flex items-center justify-center rounded-sm border border-rule',\n 'hover:border-smoke hover:text-void transition-colors duration-fast',\n 'outline-none focus-visible:ring-2 focus-visible:ring-signal-alt',\n 'disabled:opacity-40 disabled:cursor-not-allowed disabled:hover:border-rule disabled:hover:text-smoke',\n )}\n >\n <svg width=\"12\" height=\"12\" viewBox=\"0 0 12 12\" fill=\"none\" stroke=\"currentColor\" strokeWidth=\"1.5\" strokeLinecap=\"round\" strokeLinejoin=\"round\" aria-hidden=\"true\">\n <path d=\"M4 2l4 4-4 4\" />\n </svg>\n </button>\n </div>\n </div>\n )}\n </div>\n )\n}\n","// src/primitive.tsx\nimport * as React from \"react\";\nimport * as ReactDOM from \"react-dom\";\nimport { createSlot } from \"@radix-ui/react-slot\";\nimport { jsx } from \"react/jsx-runtime\";\nvar NODES = [\n \"a\",\n \"button\",\n \"div\",\n \"form\",\n \"h2\",\n \"h3\",\n \"img\",\n \"input\",\n \"label\",\n \"li\",\n \"nav\",\n \"ol\",\n \"p\",\n \"select\",\n \"span\",\n \"svg\",\n \"ul\"\n];\nvar Primitive = NODES.reduce((primitive, node) => {\n const Slot = createSlot(`Primitive.${node}`);\n const Node = React.forwardRef((props, forwardedRef) => {\n const { asChild, ...primitiveProps } = props;\n const Comp = asChild ? Slot : node;\n if (typeof window !== \"undefined\") {\n window[Symbol.for(\"radix-ui\")] = true;\n }\n return /* @__PURE__ */ jsx(Comp, { ...primitiveProps, ref: forwardedRef });\n });\n Node.displayName = `Primitive.${node}`;\n return { ...primitive, [node]: Node };\n}, {});\nfunction dispatchDiscreteCustomEvent(target, event) {\n if (target) ReactDOM.flushSync(() => target.dispatchEvent(event));\n}\nvar Root = Primitive;\nexport {\n Primitive,\n Root,\n dispatchDiscreteCustomEvent\n};\n//# sourceMappingURL=index.mjs.map\n","// src/aspect-ratio.tsx\nimport * as React from \"react\";\nimport { Primitive } from \"@radix-ui/react-primitive\";\nimport { jsx } from \"react/jsx-runtime\";\nvar NAME = \"AspectRatio\";\nvar AspectRatio = React.forwardRef(\n (props, forwardedRef) => {\n const { ratio = 1 / 1, style, ...aspectRatioProps } = props;\n return /* @__PURE__ */ jsx(\n \"div\",\n {\n style: {\n // ensures inner element is contained\n position: \"relative\",\n // ensures padding bottom trick maths works\n width: \"100%\",\n paddingBottom: `${100 / ratio}%`\n },\n \"data-radix-aspect-ratio-wrapper\": \"\",\n children: /* @__PURE__ */ jsx(\n Primitive.div,\n {\n ...aspectRatioProps,\n ref: forwardedRef,\n style: {\n ...style,\n // ensures children expand in ratio\n position: \"absolute\",\n top: 0,\n right: 0,\n bottom: 0,\n left: 0\n }\n }\n )\n }\n );\n }\n);\nAspectRatio.displayName = NAME;\nvar Root = AspectRatio;\nexport {\n AspectRatio,\n Root\n};\n//# sourceMappingURL=index.mjs.map\n","import * as AspectRatioPrimitive from '@radix-ui/react-aspect-ratio'\nimport { cn } from '../../lib/cn'\n\nexport interface AspectRatioProps\n extends React.ComponentPropsWithoutRef<typeof AspectRatioPrimitive.Root> {\n /**\n * Width-to-height ratio. Defaults to 16/9.\n * Pass a number: `ratio={4/3}`, `ratio={1}`, `ratio={16/9}`.\n */\n ratio?: number\n}\n\n/**\n * Constrains children to a fixed aspect ratio box.\n * Children should fill the box with `w-full h-full`; use `object-cover` on `<img>`.\n * Overlay content can be positioned absolutely inside.\n *\n * @example\n * <AspectRatio ratio={16 / 9}>\n * <img src={src} alt={alt} className=\"w-full h-full object-cover\" />\n * </AspectRatio>\n *\n * <AspectRatio ratio={1} className=\"rounded-md overflow-hidden\">\n * <Skeleton className=\"w-full h-full\" />\n * </AspectRatio>\n */\nexport function AspectRatio({\n ratio = 16 / 9,\n className,\n ...props\n}: AspectRatioProps) {\n return (\n <AspectRatioPrimitive.Root\n ratio={ratio}\n className={cn('relative', className)}\n {...props}\n />\n )\n}\n"],"x_google_ignoreList":[0,1,2,3,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,61,62,63,68,70,73,76,77,79,80,81,83,84,88,89,90,93,94,95,96,97,98,99,101,103,104,107,108,115,116],"mappings":"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"}