@aurora-ds/lib-test 0.0.1-dev.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +134 -0
- package/dist/components/actions/_shared/buttons/constants/index.d.ts +4 -0
- package/dist/components/actions/_shared/buttons/styles/buttonShared.css.d.ts +349 -0
- package/dist/components/actions/_shared/buttons/styles/variants/contained.d.ts +107 -0
- package/dist/components/actions/_shared/buttons/styles/variants/ghost.d.ts +100 -0
- package/dist/components/actions/_shared/buttons/styles/variants/outlined.d.ts +106 -0
- package/dist/components/actions/_shared/buttons/types/index.d.ts +6 -0
- package/dist/components/actions/button/Button.css.d.ts +36 -0
- package/dist/components/actions/button/Button.d.ts +4 -0
- package/dist/components/actions/button/constants/index.d.ts +4 -0
- package/dist/components/actions/button/index.d.ts +4 -0
- package/dist/components/actions/button/types/Button.props.d.ts +11 -0
- package/dist/components/actions/button/types/Button.types.d.ts +7 -0
- package/dist/components/actions/icon-button/IconButton.css.d.ts +35 -0
- package/dist/components/actions/icon-button/IconButton.d.ts +4 -0
- package/dist/components/actions/icon-button/constants/index.d.ts +2 -0
- package/dist/components/actions/icon-button/index.d.ts +4 -0
- package/dist/components/actions/icon-button/types/IconButton.props.d.ts +9 -0
- package/dist/components/actions/icon-button/types/IconButton.types.d.ts +7 -0
- package/dist/components/data-display/index.d.ts +1 -0
- package/dist/components/data-display/table/Table.css.d.ts +40 -0
- package/dist/components/data-display/table/Table.d.ts +4 -0
- package/dist/components/data-display/table/components/index.d.ts +9 -0
- package/dist/components/data-display/table/components/table-body/TableBody.css.d.ts +2 -0
- package/dist/components/data-display/table/components/table-body/TableBody.d.ts +4 -0
- package/dist/components/data-display/table/components/table-body/index.d.ts +3 -0
- package/dist/components/data-display/table/components/table-body/types/TableBody.props.d.ts +2 -0
- package/dist/components/data-display/table/components/table-caption/TableCaption.css.d.ts +1 -0
- package/dist/components/data-display/table/components/table-caption/TableCaption.d.ts +4 -0
- package/dist/components/data-display/table/components/table-caption/index.d.ts +3 -0
- package/dist/components/data-display/table/components/table-caption/types/TableCaption.props.d.ts +2 -0
- package/dist/components/data-display/table/components/table-cell/TableCell.css.d.ts +27 -0
- package/dist/components/data-display/table/components/table-cell/TableCell.d.ts +4 -0
- package/dist/components/data-display/table/components/table-cell/index.d.ts +3 -0
- package/dist/components/data-display/table/components/table-cell/types/TableCell.props.d.ts +15 -0
- package/dist/components/data-display/table/components/table-col/TableCol.d.ts +4 -0
- package/dist/components/data-display/table/components/table-col/index.d.ts +2 -0
- package/dist/components/data-display/table/components/table-col/types/TableCol.props.d.ts +18 -0
- package/dist/components/data-display/table/components/table-col-group/TableColGroup.d.ts +4 -0
- package/dist/components/data-display/table/components/table-col-group/index.d.ts +2 -0
- package/dist/components/data-display/table/components/table-col-group/types/TableColGroup.props.d.ts +2 -0
- package/dist/components/data-display/table/components/table-footer/TableFooter.css.d.ts +1 -0
- package/dist/components/data-display/table/components/table-footer/TableFooter.d.ts +4 -0
- package/dist/components/data-display/table/components/table-footer/index.d.ts +3 -0
- package/dist/components/data-display/table/components/table-footer/types/TableFooter.props.d.ts +2 -0
- package/dist/components/data-display/table/components/table-head/TableHead.css.d.ts +23 -0
- package/dist/components/data-display/table/components/table-head/TableHead.d.ts +4 -0
- package/dist/components/data-display/table/components/table-head/index.d.ts +3 -0
- package/dist/components/data-display/table/components/table-head/types/TableHead.props.d.ts +15 -0
- package/dist/components/data-display/table/components/table-header/TableHeader.css.d.ts +1 -0
- package/dist/components/data-display/table/components/table-header/TableHeader.d.ts +4 -0
- package/dist/components/data-display/table/components/table-header/index.d.ts +3 -0
- package/dist/components/data-display/table/components/table-header/types/TableHeader.props.d.ts +2 -0
- package/dist/components/data-display/table/components/table-row/TableRow.css.d.ts +56 -0
- package/dist/components/data-display/table/components/table-row/TableRow.d.ts +4 -0
- package/dist/components/data-display/table/components/table-row/index.d.ts +3 -0
- package/dist/components/data-display/table/components/table-row/types/TableRow.props.d.ts +11 -0
- package/dist/components/data-display/table/constants/index.d.ts +5 -0
- package/dist/components/data-display/table/index.d.ts +5 -0
- package/dist/components/data-display/table/types/Table.props.d.ts +14 -0
- package/dist/components/data-display/table/types/Table.types.d.ts +4 -0
- package/dist/components/forms/_shared/checkboxVisual.css.d.ts +16 -0
- package/dist/components/forms/_shared/radioVisual.css.d.ts +12 -0
- package/dist/components/forms/checkbox/Checkbox.css.d.ts +22 -0
- package/dist/components/forms/checkbox/Checkbox.d.ts +15 -0
- package/dist/components/forms/checkbox/index.d.ts +3 -0
- package/dist/components/forms/checkbox/types/Checkbox.props.d.ts +6 -0
- package/dist/components/forms/index.d.ts +2 -0
- package/dist/components/forms/radio-group/RadioGroup.d.ts +16 -0
- package/dist/components/forms/radio-group/components/radio-item/RadioItem.css.d.ts +16 -0
- package/dist/components/forms/radio-group/components/radio-item/RadioItem.d.ts +13 -0
- package/dist/components/forms/radio-group/components/radio-item/types/RadioItem.props.d.ts +6 -0
- package/dist/components/forms/radio-group/index.d.ts +5 -0
- package/dist/components/forms/radio-group/types/RadioGroup.props.d.ts +3 -0
- package/dist/components/foundation/icon/Icon.css.d.ts +35 -0
- package/dist/components/foundation/icon/Icon.d.ts +4 -0
- package/dist/components/foundation/icon/index.d.ts +4 -0
- package/dist/components/foundation/icon/types/Icon.props.d.ts +7 -0
- package/dist/components/foundation/icon/types/Icon.types.d.ts +1 -0
- package/dist/components/foundation/typography/Typography.css.d.ts +198 -0
- package/dist/components/foundation/typography/Typography.d.ts +4 -0
- package/dist/components/foundation/typography/constants/index.d.ts +26 -0
- package/dist/components/foundation/typography/index.d.ts +5 -0
- package/dist/components/foundation/typography/types/Typography.props.d.ts +12 -0
- package/dist/components/foundation/typography/types/Typography.types.d.ts +6 -0
- package/dist/components/index.d.ts +10 -0
- package/dist/components/layout/box/Box.css.d.ts +938 -0
- package/dist/components/layout/box/Box.d.ts +4 -0
- package/dist/components/layout/box/index.d.ts +5 -0
- package/dist/components/layout/box/types/Box.props.d.ts +8 -0
- package/dist/components/layout/box/types/Box.types.d.ts +2 -0
- package/dist/components/layout/flex/Flex.css.d.ts +74 -0
- package/dist/components/layout/flex/Flex.d.ts +4 -0
- package/dist/components/layout/flex/index.d.ts +5 -0
- package/dist/components/layout/flex/types/Flex.props.d.ts +3 -0
- package/dist/components/layout/flex/types/Flex.types.d.ts +8 -0
- package/dist/components/layout/grid/Grid.css.d.ts +153 -0
- package/dist/components/layout/grid/Grid.d.ts +4 -0
- package/dist/components/layout/grid/index.d.ts +5 -0
- package/dist/components/layout/grid/types/Grid.props.d.ts +3 -0
- package/dist/components/layout/grid/types/Grid.types.d.ts +14 -0
- package/dist/components/layout/index.d.ts +3 -0
- package/dist/components/overlay/dropdown-menu/DropdownMenu.d.ts +10 -0
- package/dist/components/overlay/dropdown-menu/components/_shared/item.css.d.ts +14 -0
- package/dist/components/overlay/dropdown-menu/components/_shared/useViewportShift.d.ts +1 -0
- package/dist/components/overlay/dropdown-menu/components/content/dropdown-menu-content/DropdownMenuContent.css.d.ts +6 -0
- package/dist/components/overlay/dropdown-menu/components/content/dropdown-menu-content/DropdownMenuContent.d.ts +16 -0
- package/dist/components/overlay/dropdown-menu/components/content/dropdown-menu-content/types/DropdownMenuContent.props.d.ts +24 -0
- package/dist/components/overlay/dropdown-menu/components/groups/dropdown-menu-group/DropdownMenuGroup.d.ts +9 -0
- package/dist/components/overlay/dropdown-menu/components/groups/dropdown-menu-group/types/DropdownMenuGroup.props.d.ts +2 -0
- package/dist/components/overlay/dropdown-menu/components/groups/dropdown-menu-radio-group/DropdownMenuRadioGroup.d.ts +10 -0
- package/dist/components/overlay/dropdown-menu/components/groups/dropdown-menu-radio-group/types/DropdownMenuRadioGroup.props.d.ts +2 -0
- package/dist/components/overlay/dropdown-menu/components/index.d.ts +26 -0
- package/dist/components/overlay/dropdown-menu/components/items/dropdown-menu-checkbox-item/DropdownMenuCheckboxItem.d.ts +4 -0
- package/dist/components/overlay/dropdown-menu/components/items/dropdown-menu-checkbox-item/types/DropdownMenuCheckboxItem.props.d.ts +6 -0
- package/dist/components/overlay/dropdown-menu/components/items/dropdown-menu-item/DropdownMenuItem.d.ts +18 -0
- package/dist/components/overlay/dropdown-menu/components/items/dropdown-menu-item/types/DropdownMenuItem.props.d.ts +14 -0
- package/dist/components/overlay/dropdown-menu/components/items/dropdown-menu-radio-item/DropdownMenuRadioItem.d.ts +4 -0
- package/dist/components/overlay/dropdown-menu/components/items/dropdown-menu-radio-item/types/DropdownMenuRadioItem.props.d.ts +6 -0
- package/dist/components/overlay/dropdown-menu/components/label/dropdown-menu-label/DropdownMenuLabel.css.d.ts +5 -0
- package/dist/components/overlay/dropdown-menu/components/label/dropdown-menu-label/DropdownMenuLabel.d.ts +10 -0
- package/dist/components/overlay/dropdown-menu/components/label/dropdown-menu-label/types/DropdownMenuLabel.props.d.ts +6 -0
- package/dist/components/overlay/dropdown-menu/components/separator/dropdown-menu-separator/DropdownMenuSeparator.css.d.ts +5 -0
- package/dist/components/overlay/dropdown-menu/components/separator/dropdown-menu-separator/DropdownMenuSeparator.d.ts +9 -0
- package/dist/components/overlay/dropdown-menu/components/separator/dropdown-menu-separator/types/DropdownMenuSeparator.props.d.ts +2 -0
- package/dist/components/overlay/dropdown-menu/components/shortcut/dropdown-menu-shortcut/DropdownMenuShortcut.css.d.ts +6 -0
- package/dist/components/overlay/dropdown-menu/components/shortcut/dropdown-menu-shortcut/DropdownMenuShortcut.d.ts +10 -0
- package/dist/components/overlay/dropdown-menu/components/shortcut/dropdown-menu-shortcut/types/DropdownMenuShortcut.props.d.ts +2 -0
- package/dist/components/overlay/dropdown-menu/components/sub/dropdown-menu-sub/DropdownMenuSub.d.ts +10 -0
- package/dist/components/overlay/dropdown-menu/components/sub/dropdown-menu-sub/types/DropdownMenuSub.props.d.ts +2 -0
- package/dist/components/overlay/dropdown-menu/components/sub/dropdown-menu-sub-content/DropdownMenuSubContent.css.d.ts +6 -0
- package/dist/components/overlay/dropdown-menu/components/sub/dropdown-menu-sub-content/DropdownMenuSubContent.d.ts +13 -0
- package/dist/components/overlay/dropdown-menu/components/sub/dropdown-menu-sub-content/types/DropdownMenuSubContent.props.d.ts +16 -0
- package/dist/components/overlay/dropdown-menu/components/sub/dropdown-menu-sub-trigger/DropdownMenuSubTrigger.css.d.ts +9 -0
- package/dist/components/overlay/dropdown-menu/components/sub/dropdown-menu-sub-trigger/DropdownMenuSubTrigger.d.ts +10 -0
- package/dist/components/overlay/dropdown-menu/components/sub/dropdown-menu-sub-trigger/types/DropdownMenuSubTrigger.props.d.ts +8 -0
- package/dist/components/overlay/dropdown-menu/components/trigger/dropdown-menu-trigger/DropdownMenuTrigger.d.ts +10 -0
- package/dist/components/overlay/dropdown-menu/components/trigger/dropdown-menu-trigger/types/DropdownMenuTrigger.props.d.ts +2 -0
- package/dist/components/overlay/dropdown-menu/index.d.ts +6 -0
- package/dist/components/overlay/dropdown-menu/types/DropdownMenu.props.d.ts +4 -0
- package/dist/components/overlay/dropdown-menu/types/DropdownMenu.types.d.ts +4 -0
- package/dist/components/overlay/tooltip/Tooltip.css.d.ts +2 -0
- package/dist/components/overlay/tooltip/Tooltip.d.ts +4 -0
- package/dist/components/overlay/tooltip/index.d.ts +5 -0
- package/dist/components/overlay/tooltip/types/Tooltip.props.d.ts +28 -0
- package/dist/components/overlay/tooltip/types/Tooltip.types.d.ts +29 -0
- package/dist/components/theme-provider/ThemeProvider.context.d.ts +30 -0
- package/dist/components/theme-provider/ThemeProvider.d.ts +36 -0
- package/dist/components/theme-provider/index.d.ts +4 -0
- package/dist/components/theme-provider/types/ThemeProvider.props.d.ts +32 -0
- package/dist/components/theme-provider/utils/getSystemTheme.utils.d.ts +5 -0
- package/dist/components/theme-provider/utils/resolveTheme.utils.d.ts +2 -0
- package/dist/constants/animations/fade/fadeIn.css.d.ts +1 -0
- package/dist/constants/animations/fade/fadeOut.css.d.ts +1 -0
- package/dist/constants/animations/index.d.ts +11 -0
- package/dist/constants/animations/slide/slideDownIn.css.d.ts +1 -0
- package/dist/constants/animations/slide/slideDownOut.css.d.ts +1 -0
- package/dist/constants/animations/slide/slideLeftIn.css.d.ts +1 -0
- package/dist/constants/animations/slide/slideLeftOut.css.d.ts +1 -0
- package/dist/constants/animations/slide/slideRightIn.css.d.ts +1 -0
- package/dist/constants/animations/slide/slideRightOut.css.d.ts +1 -0
- package/dist/constants/animations/slide/slideUpIn.css.d.ts +1 -0
- package/dist/constants/animations/slide/slideUpOut.css.d.ts +1 -0
- package/dist/constants/animations/spin/spinAnimation.css.d.ts +1 -0
- package/dist/constants/index.d.ts +1 -0
- package/dist/hooks/index.d.ts +1 -0
- package/dist/hooks/use-viewport-shift/constants/index.d.ts +1 -0
- package/dist/hooks/use-viewport-shift/helpers/createCorrector.helper.d.ts +11 -0
- package/dist/hooks/use-viewport-shift/helpers/guardAccidentalSelection.helper.d.ts +15 -0
- package/dist/hooks/use-viewport-shift/helpers/normalizePadding.helper.d.ts +3 -0
- package/dist/hooks/use-viewport-shift/helpers/watchRepositions.helper.d.ts +10 -0
- package/dist/hooks/use-viewport-shift/types/index.d.ts +12 -0
- package/dist/hooks/use-viewport-shift/useViewportShift.hook.d.ts +13 -0
- package/dist/index.cjs +42 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.js +6970 -0
- package/dist/index.js.map +1 -0
- package/dist/stories/overview/theme/colors/components/color-group-card/ColorGroupCard.d.ts +2 -0
- package/dist/stories/overview/theme/colors/components/color-group-card/ColorGroupCard.styles.d.ts +5 -0
- package/dist/stories/overview/theme/colors/components/color-group-card/types/index.d.ts +11 -0
- package/dist/stories/overview/theme/colors/components/color-palette-section/ColorPaletteSection.d.ts +2 -0
- package/dist/stories/overview/theme/colors/components/color-palette-section/ColorPaletteSection.styles.d.ts +5 -0
- package/dist/stories/overview/theme/colors/components/color-palette-section/types/index.d.ts +11 -0
- package/dist/stories/overview/theme/colors/components/color-swatch/ColorSwatch.d.ts +2 -0
- package/dist/stories/overview/theme/colors/components/color-swatch/ColorSwatch.styles.d.ts +8 -0
- package/dist/stories/overview/theme/colors/components/color-swatch/types/index.d.ts +5 -0
- package/dist/stories/overview/theme/colors/components/index.d.ts +4 -0
- package/dist/stories/overview/theme/css-variables/components/copy-mui-button/CopyMuiButton.d.ts +1 -0
- package/dist/stories/overview/theme/css-variables/components/copy-mui-button/index.d.ts +1 -0
- package/dist/stories/overview/theme/css-variables/components/copy-plain-css-button/CopyPlainCssButton.d.ts +1 -0
- package/dist/stories/overview/theme/css-variables/components/copy-plain-css-button/index.d.ts +1 -0
- package/dist/stories/overview/theme/css-variables/components/copy-tailwind-button/CopyTailwindButton.d.ts +1 -0
- package/dist/stories/overview/theme/css-variables/components/copy-tailwind-button/index.d.ts +1 -0
- package/dist/stories/overview/theme/css-variables/components/copy-theme-button/CopyThemeButton.d.ts +1 -0
- package/dist/stories/overview/theme/css-variables/components/copy-theme-button/index.d.ts +1 -0
- package/dist/stories/overview/theme/css-variables/components/copy-vanilla-extract-button/CopyVanillaExtractButton.d.ts +1 -0
- package/dist/stories/overview/theme/css-variables/components/copy-vanilla-extract-button/index.d.ts +1 -0
- package/dist/stories/overview/theme/css-variables/components/var-table/VarTable.css.d.ts +5 -0
- package/dist/stories/overview/theme/css-variables/components/var-table/VarTable.d.ts +2 -0
- package/dist/stories/overview/theme/css-variables/components/var-table/index.d.ts +2 -0
- package/dist/stories/overview/theme/css-variables/components/var-table/types/index.d.ts +6 -0
- package/dist/stories/overview/theme/css-variables/types/index.d.ts +6 -0
- package/dist/stories/overview/theme/css-variables/utils/theme.utils.d.ts +27 -0
- package/dist/stories/overview/theme/tokens/components/copy-badge/CopyBadge.d.ts +2 -0
- package/dist/stories/overview/theme/tokens/components/copy-badge/CopyBadge.styles.d.ts +2 -0
- package/dist/stories/overview/theme/tokens/components/copy-badge/types/index.d.ts +3 -0
- package/dist/stories/overview/theme/tokens/components/index.d.ts +9 -0
- package/dist/stories/overview/theme/tokens/components/motion-section/MotionSection.d.ts +1 -0
- package/dist/stories/overview/theme/tokens/components/motion-section/MotionSection.styles.d.ts +11 -0
- package/dist/stories/overview/theme/tokens/components/radius-section/RadiusSection.d.ts +1 -0
- package/dist/stories/overview/theme/tokens/components/radius-section/RadiusSection.styles.d.ts +2 -0
- package/dist/stories/overview/theme/tokens/components/shadow-section/ShadowSection.d.ts +1 -0
- package/dist/stories/overview/theme/tokens/components/shadow-section/ShadowSection.styles.d.ts +7 -0
- package/dist/stories/overview/theme/tokens/components/spacing-section/SpacingSection.d.ts +1 -0
- package/dist/stories/overview/theme/tokens/components/spacing-section/SpacingSection.styles.d.ts +9 -0
- package/dist/stories/overview/theme/tokens/components/spacing-section/utils/toPx.d.ts +5 -0
- package/dist/stories/overview/theme/tokens/components/token-card/TokenCard.d.ts +2 -0
- package/dist/stories/overview/theme/tokens/components/token-card/TokenCard.styles.d.ts +6 -0
- package/dist/stories/overview/theme/tokens/components/token-card/types/index.d.ts +6 -0
- package/dist/stories/overview/theme/tokens/components/token-section/TokenSection.d.ts +2 -0
- package/dist/stories/overview/theme/tokens/components/token-section/TokenSection.styles.d.ts +5 -0
- package/dist/stories/overview/theme/tokens/components/token-section/types/index.d.ts +6 -0
- package/dist/stories/overview/theme/tokens/components/typography-section/TypographySection.d.ts +1 -0
- package/dist/stories/overview/theme/tokens/components/typography-section/TypographySection.styles.d.ts +6 -0
- package/dist/stories/overview/theme/tokens/components/zindex-section/ZIndexSection.d.ts +1 -0
- package/dist/stories/overview/theme/tokens/components/zindex-section/ZIndexSection.styles.d.ts +7 -0
- package/dist/theme/colors/dark.d.ts +2 -0
- package/dist/theme/colors/index.d.ts +3 -0
- package/dist/theme/colors/light.d.ts +72 -0
- package/dist/theme/contract.css.d.ts +191 -0
- package/dist/theme/globalStyles.css.d.ts +1 -0
- package/dist/theme/index.d.ts +10 -0
- package/dist/theme/override.d.ts +11 -0
- package/dist/theme/tokens/index.d.ts +294 -0
- package/dist/theme/tokens/motion.d.ts +17 -0
- package/dist/theme/tokens/palette.d.ts +85 -0
- package/dist/theme/tokens/radii.d.ts +11 -0
- package/dist/theme/tokens/shadows.d.ts +21 -0
- package/dist/theme/tokens/spacing.d.ts +16 -0
- package/dist/theme/tokens/typography.d.ts +50 -0
- package/dist/theme/tokens/zIndex.d.ts +14 -0
- package/dist/theme/types/index.d.ts +6 -0
- package/dist/ui-kit.css +2 -0
- package/dist/utils/cn.d.ts +7 -0
- package/dist/vite-env.d.ts +3 -0
- package/package.json +95 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.cjs","names":["host","idCounter","Icon","setRef","React","React","React","React","useLayoutEffect","isFunction","React","React","React","React2","getElementRef","React","React","React","isIndeterminate","isFunction","TRIGGER_NAME","getState","Checkbox","Fragment","INDICATOR_NAME","BUBBLE_INPUT_NAME","React","React","count","useId","useCallbackRef","React","React","EVENT_OPTIONS","GROUP_NAME","Collection","useCollection","createCollectionScope","React","useCallbackRef","ITEM_NAME","useId","wrapArray","focusFirst","Root","React","TRIGGER_NAME","Fragment","INDICATOR_NAME","RADIO_GROUP_NAME","createContextScope2","useRovingFocusGroupScope","RadioGroupProvider","useRadioGroupContext","RadioGroup","React2","RovingFocusGroup.Root","Primitive2","ITEM_NAME","useComposedRefs2","RovingFocusGroup.Item","composeEventHandlers2","Fragment2","useCallbackRef","React","useCallbackRef","computePosition","arrow","flip","hide","offset","shift","limitShift","size","getComputedStyle","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","Root","React","ANCHOR_NAME","CONTENT_NAME","arrow","floatingUIarrow","useCallbackRef","ARROW_NAME","ArrowPrimitive.Root","Root2","PORTAL_NAME","Portal","React","ReactDOM","React","usePopperScope","React","Tooltip","useId","PopperPrimitive.Root","TRIGGER_NAME","PopperPrimitive.Anchor","PORTAL_NAME","PortalProvider","usePortalContext","PortalPrimitive","CONTENT_NAME","isPointInPolygon","PopperPrimitive.Content","VisuallyHiddenPrimitive.Root","ARROW_NAME","PopperPrimitive.Arrow","Root3","Trigger","Portal","Content2","Arrow2","React","useCallbackRef","focusFirst","React","React","React","React","React","React","SideCar","React","useCallbackRef","PopperPrimitive.Root","PopperPrimitive.Anchor","PORTAL_NAME","PortalPrimitive","CONTENT_NAME","RemoveScroll","RovingFocusGroup.Root","PopperPrimitive.Content","GROUP_NAME","LABEL_NAME","ITEM_NAME","RovingFocusGroup.Item","CHECKBOX_ITEM_NAME","RADIO_GROUP_NAME","RADIO_ITEM_NAME","SEPARATOR_NAME","ARROW_NAME","PopperPrimitive.Arrow","useId","SUB_TRIGGER_NAME","SUB_CONTENT_NAME","Content2","Item2","RadioGroup","RadioItem","DropdownMenu","React","useId","MenuPrimitive.Root","DropdownMenuTrigger","MenuPrimitive.Anchor","MenuPrimitive.Portal","DropdownMenuContent","MenuPrimitive.Content","DropdownMenuGroup","MenuPrimitive.Group","DropdownMenuLabel","MenuPrimitive.Label","DropdownMenuItem","MenuPrimitive.Item","DropdownMenuCheckboxItem","MenuPrimitive.CheckboxItem","DropdownMenuRadioGroup","MenuPrimitive.RadioGroup","DropdownMenuRadioItem","MenuPrimitive.RadioItem","MenuPrimitive.ItemIndicator","DropdownMenuSeparator","MenuPrimitive.Separator","MenuPrimitive.Arrow","DropdownMenuSub","MenuPrimitive.Sub","DropdownMenuSubTrigger","MenuPrimitive.SubTrigger","DropdownMenuSubContent","MenuPrimitive.SubContent"],"sources":["../src/theme/contract.css.ts","../src/utils/cn.ts","../src/constants/animations/fade/fadeIn.css.ts","../src/constants/animations/fade/fadeOut.css.ts","../src/constants/animations/slide/slideDownIn.css.ts","../src/constants/animations/slide/slideDownOut.css.ts","../src/constants/animations/slide/slideUpIn.css.ts","../src/constants/animations/slide/slideUpOut.css.ts","../src/constants/animations/slide/slideRightIn.css.ts","../src/constants/animations/slide/slideRightOut.css.ts","../src/constants/animations/slide/slideLeftIn.css.ts","../src/constants/animations/slide/slideLeftOut.css.ts","../src/constants/animations/spin/spinAnimation.css.ts","../src/hooks/use-viewport-shift/helpers/guardAccidentalSelection.helper.ts","../src/hooks/use-viewport-shift/helpers/normalizePadding.helper.ts","../src/hooks/use-viewport-shift/constants/index.ts","../src/hooks/use-viewport-shift/helpers/createCorrector.helper.ts","../src/hooks/use-viewport-shift/helpers/watchRepositions.helper.ts","../src/hooks/use-viewport-shift/useViewportShift.hook.ts","../src/components/theme-provider/ThemeProvider.context.ts","../src/components/theme-provider/utils/getSystemTheme.utils.ts","../src/components/theme-provider/utils/resolveTheme.utils.ts","../src/components/theme-provider/ThemeProvider.tsx","../node_modules/@vanilla-extract/recipes/dist/createRuntimeFn-62c9670f.esm.js","../src/components/data-display/table/Table.css.ts","../src/components/data-display/table/Table.tsx","../src/components/data-display/table/components/table-header/TableHeader.css.ts","../src/components/data-display/table/components/table-header/TableHeader.tsx","../src/components/data-display/table/components/table-body/TableBody.css.ts","../src/components/data-display/table/components/table-body/TableBody.tsx","../src/components/data-display/table/components/table-footer/TableFooter.css.ts","../src/components/data-display/table/components/table-footer/TableFooter.tsx","../src/components/data-display/table/components/table-row/TableRow.css.ts","../src/components/data-display/table/components/table-row/TableRow.tsx","../node_modules/@iconify/react/dist/iconify.js","../src/components/foundation/icon/Icon.css.ts","../src/components/foundation/icon/Icon.tsx","../src/components/data-display/table/components/table-head/TableHead.css.ts","../src/components/data-display/table/components/table-head/TableHead.tsx","../src/components/data-display/table/components/table-cell/TableCell.css.ts","../src/components/data-display/table/components/table-cell/TableCell.tsx","../src/components/data-display/table/components/table-caption/TableCaption.css.ts","../src/components/data-display/table/components/table-caption/TableCaption.tsx","../src/components/data-display/table/components/table-col-group/TableColGroup.tsx","../src/components/data-display/table/components/table-col/TableCol.tsx","../src/components/actions/button/Button.css.ts","../src/components/foundation/typography/Typography.css.ts","../src/components/foundation/typography/constants/index.ts","../src/components/foundation/typography/Typography.tsx","../src/components/actions/_shared/buttons/constants/index.ts","../src/components/actions/button/constants/index.ts","../src/components/actions/button/Button.tsx","../src/components/actions/icon-button/IconButton.css.ts","../src/components/actions/icon-button/IconButton.tsx","../node_modules/@radix-ui/react-compose-refs/dist/index.mjs","../node_modules/@radix-ui/react-context/dist/index.mjs","../node_modules/@radix-ui/primitive/dist/index.mjs","../node_modules/@radix-ui/react-use-layout-effect/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-use-size/dist/index.mjs","../node_modules/@radix-ui/react-presence/dist/index.mjs","../node_modules/@radix-ui/react-slot/dist/index.mjs","../node_modules/@radix-ui/react-primitive/dist/index.mjs","../node_modules/@radix-ui/react-checkbox/dist/index.mjs","../src/components/layout/flex/Flex.css.ts","../src/components/layout/box/Box.css.ts","../src/components/layout/box/Box.tsx","../src/components/layout/flex/Flex.tsx","../src/components/forms/checkbox/Checkbox.css.ts","../src/components/forms/checkbox/Checkbox.tsx","../node_modules/@radix-ui/react-collection/dist/index.mjs","../node_modules/@radix-ui/react-id/dist/index.mjs","../node_modules/@radix-ui/react-use-callback-ref/dist/index.mjs","../node_modules/@radix-ui/react-direction/dist/index.mjs","../node_modules/@radix-ui/react-roving-focus/dist/index.mjs","../node_modules/@radix-ui/react-radio-group/dist/index.mjs","../src/components/forms/radio-group/RadioGroup.tsx","../src/components/forms/radio-group/components/radio-item/RadioItem.css.ts","../src/components/forms/radio-group/components/radio-item/RadioItem.tsx","../src/components/layout/grid/Grid.css.ts","../src/components/layout/grid/Grid.tsx","../node_modules/@radix-ui/react-use-escape-keydown/dist/index.mjs","../node_modules/@radix-ui/react-dismissable-layer/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-popper/dist/index.mjs","../node_modules/@radix-ui/react-portal/dist/index.mjs","../node_modules/@radix-ui/react-visually-hidden/dist/index.mjs","../node_modules/@radix-ui/react-tooltip/dist/index.mjs","../src/components/overlay/tooltip/Tooltip.css.ts","../src/components/overlay/tooltip/types/Tooltip.types.ts","../src/components/overlay/tooltip/Tooltip.tsx","../node_modules/@radix-ui/react-focus-guards/dist/index.mjs","../node_modules/@radix-ui/react-focus-scope/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-menu/dist/index.mjs","../node_modules/@radix-ui/react-dropdown-menu/dist/index.mjs","../src/components/overlay/dropdown-menu/DropdownMenu.tsx","../src/components/overlay/dropdown-menu/components/trigger/dropdown-menu-trigger/DropdownMenuTrigger.tsx","../src/components/overlay/dropdown-menu/components/content/dropdown-menu-content/DropdownMenuContent.css.ts","../src/components/overlay/dropdown-menu/components/content/dropdown-menu-content/DropdownMenuContent.tsx","../src/components/overlay/dropdown-menu/components/groups/dropdown-menu-group/DropdownMenuGroup.tsx","../src/components/overlay/dropdown-menu/components/groups/dropdown-menu-radio-group/DropdownMenuRadioGroup.tsx","../src/components/overlay/dropdown-menu/components/_shared/item.css.ts","../src/components/overlay/dropdown-menu/components/shortcut/dropdown-menu-shortcut/DropdownMenuShortcut.css.ts","../src/components/overlay/dropdown-menu/components/shortcut/dropdown-menu-shortcut/DropdownMenuShortcut.tsx","../src/components/overlay/dropdown-menu/components/items/dropdown-menu-item/DropdownMenuItem.tsx","../src/components/overlay/dropdown-menu/components/items/dropdown-menu-checkbox-item/DropdownMenuCheckboxItem.tsx","../src/components/overlay/dropdown-menu/components/items/dropdown-menu-radio-item/DropdownMenuRadioItem.tsx","../src/components/overlay/dropdown-menu/components/label/dropdown-menu-label/DropdownMenuLabel.css.ts","../src/components/overlay/dropdown-menu/components/label/dropdown-menu-label/DropdownMenuLabel.tsx","../src/components/overlay/dropdown-menu/components/separator/dropdown-menu-separator/DropdownMenuSeparator.css.ts","../src/components/overlay/dropdown-menu/components/separator/dropdown-menu-separator/DropdownMenuSeparator.tsx","../src/components/overlay/dropdown-menu/components/sub/dropdown-menu-sub/DropdownMenuSub.tsx","../src/components/overlay/dropdown-menu/components/sub/dropdown-menu-sub-trigger/DropdownMenuSubTrigger.css.ts","../src/components/overlay/dropdown-menu/components/sub/dropdown-menu-sub-trigger/DropdownMenuSubTrigger.tsx","../src/components/overlay/dropdown-menu/components/sub/dropdown-menu-sub-content/DropdownMenuSubContent.css.ts","../src/components/overlay/dropdown-menu/components/sub/dropdown-menu-sub-content/DropdownMenuSubContent.tsx"],"sourcesContent":["import { assignVars, createGlobalTheme, createGlobalThemeContract, globalStyle } from '@vanilla-extract/css'\r\n\r\nimport { darkColors } from '@theme/colors/index.ts'\r\nimport { lightTheme } from '@theme/tokens/index.ts'\r\nimport { darkShadows, darkDropShadows } from '@theme/tokens/shadows.ts'\r\n\r\n/** Typed token contract. `vars.color.primary` → CSS var `--color-primary`. */\r\nexport const vars = createGlobalThemeContract(lightTheme, (_value, path) => path.join('-'))\r\n\r\n// 1. Light theme on :root.\r\ncreateGlobalTheme(':root', vars, lightTheme)\r\n\r\nconst darkOverrides = {\r\n ...assignVars(vars.color, darkColors),\r\n ...assignVars(vars.shadow, darkShadows),\r\n ...assignVars(vars.dropShadow, darkDropShadows),\r\n}\r\n\r\n// 2. Explicit dark theme.\r\nglobalStyle('[data-theme=\"dark\"]', { vars: darkOverrides })\r\n\r\n// 3. Automatic dark — OS preference, but never overrides an explicit data-theme.\r\nglobalStyle(':root:not([data-theme])', {\r\n '@media': {\r\n '(prefers-color-scheme: dark)': { vars: darkOverrides },\r\n },\r\n})\r\n\r\n/** Fully-typed design-token contract. */\r\nexport type ThemeVars = typeof vars\r\n","/**\r\n * Joins class names, filtering out any falsy values.\r\n *\r\n * Vanilla Extract generates scoped, conflict-free class names, so simple\r\n * concatenation is all that's needed — no conflict resolution required.\r\n */\r\nexport const cn = (...classes: (string | undefined | null | false)[]): string =>\r\n classes.filter(Boolean).join(' ')\r\n","import { keyframes } from '@vanilla-extract/css'\r\n\r\nexport const fadeIn = keyframes({\r\n from: { opacity: 0 },\r\n to: { opacity: 1 },\r\n})\r\n","import { keyframes } from '@vanilla-extract/css'\r\n\r\nexport const fadeOut = keyframes({\r\n from: { opacity: 1 },\r\n to: { opacity: 0 },\r\n})\r\n","import { keyframes } from '@vanilla-extract/css'\r\n\r\nexport const slideDownIn = keyframes({\r\n from: { opacity: 0, transform: 'translateY(-6px) scale(0.97)' },\r\n to: { opacity: 1, transform: 'translateY(0) scale(1)' },\r\n})\r\n","import { keyframes } from '@vanilla-extract/css'\r\n\r\nexport const slideDownOut = keyframes({\r\n from: { opacity: 1, transform: 'translateY(0) scale(1)' },\r\n to: { opacity: 0, transform: 'translateY(-6px) scale(0.97)' },\r\n})\r\n","import { keyframes } from '@vanilla-extract/css'\r\n\r\nexport const slideUpIn = keyframes({\r\n from: { opacity: 0, transform: 'translateY(6px) scale(0.97)' },\r\n to: { opacity: 1, transform: 'translateY(0) scale(1)' },\r\n})\r\n","import { keyframes } from '@vanilla-extract/css'\r\n\r\nexport const slideUpOut = keyframes({\r\n from: { opacity: 1, transform: 'translateY(0) scale(1)' },\r\n to: { opacity: 0, transform: 'translateY(6px) scale(0.97)' },\r\n})\r\n","import { keyframes } from '@vanilla-extract/css'\r\n\r\nexport const slideRightIn = keyframes({\r\n from: { opacity: 0, transform: 'translateX(-6px) scale(0.97)' },\r\n to: { opacity: 1, transform: 'translateX(0) scale(1)' },\r\n})\r\n","import { keyframes } from '@vanilla-extract/css'\r\n\r\nexport const slideRightOut = keyframes({\r\n from: { opacity: 1, transform: 'translateX(0) scale(1)' },\r\n to: { opacity: 0, transform: 'translateX(-6px) scale(0.97)' },\r\n})\r\n","import { keyframes } from '@vanilla-extract/css'\r\n\r\nexport const slideLeftIn = keyframes({\r\n from: { opacity: 0, transform: 'translateX(6px) scale(0.97)' },\r\n to: { opacity: 1, transform: 'translateX(0) scale(1)' },\r\n})\r\n","import { keyframes } from '@vanilla-extract/css'\r\n\r\nexport const slideLeftOut = keyframes({\r\n from: { opacity: 1, transform: 'translateX(0) scale(1)' },\r\n to: { opacity: 0, transform: 'translateX(6px) scale(0.97)' },\r\n})\r\n","import { keyframes } from '@vanilla-extract/css'\r\n\r\nexport const spinAnimation = keyframes({\r\n from: { transform: 'rotate(0deg)' },\r\n to: { transform: 'rotate(360deg)' },\r\n})\r\n","/**\r\n * Prevents the accidental selection caused by sliding an item under the cursor.\r\n *\r\n * Radix selects an item by synthesizing a click on `pointerup` when the press\r\n * did **not** start on it (`@radix-ui/react-menu`: `onPointerUp` →\r\n * `currentTarget.click()` while `!isPointerDownRef.current`). Once shifted, the\r\n * `pointerup` releasing the *opening* click lands on an item and triggers it.\r\n *\r\n * We enforce the invariant *a pointer selection requires a `pointerdown` inside\r\n * the panel*: a press-less `pointerup` is stopped in the capture phase, so the\r\n * synthetic click never fires. It self-scopes (a `pointerup` only reaches the\r\n * panel once moved under the cursor) and leaves genuine clicks and keyboard\r\n * navigation untouched. Returns a cleanup that detaches the listeners.\r\n */\r\nexport const guardAccidentalSelection = (content: HTMLElement) => {\r\n let pointerDownInside = false\r\n\r\n const onPointerDown = () => { pointerDownInside = true }\r\n const onPointerUp = (event: PointerEvent) => {\r\n if (!pointerDownInside) { event.stopImmediatePropagation() }\r\n pointerDownInside = false\r\n }\r\n\r\n content.addEventListener('pointerdown', onPointerDown, true)\r\n content.addEventListener('pointerup', onPointerUp, true)\r\n\r\n return () => {\r\n content.removeEventListener('pointerdown', onPointerDown, true)\r\n content.removeEventListener('pointerup', onPointerUp, true)\r\n }\r\n}\r\n","import type { NormalizedPadding, Padding } from '@hooks/use-viewport-shift/types'\r\n\r\n/** Expands a uniform number or a partial per-side object into a full padding. */\r\nexport const normalizePadding = (padding: Padding): NormalizedPadding => {\r\n if (typeof padding === 'number') {\r\n return { top: padding, right: padding, bottom: padding, left: padding }\r\n }\r\n return { top: 0, right: 0, bottom: 0, left: 0, ...padding }\r\n}\r\n","// Radix parks the panel off-screen at this exact transform while floating-ui\r\n// measures it (before `isPositioned` becomes true). Any correction computed in\r\n// that state would be garbage, so we detect & skip it.\r\nexport const OFFSCREEN_SENTINEL = '-200%'\r\n","import { OFFSCREEN_SENTINEL } from '@hooks/use-viewport-shift/constants'\r\nimport type { NormalizedPadding } from '@hooks/use-viewport-shift/types'\r\n\r\n/** `true` while Radix keeps the popper wrapper off-screen for measurement. */\r\nconst isAwaitingPosition = (wrapper: HTMLElement) =>\r\n wrapper.style.transform.includes(OFFSCREEN_SENTINEL)\r\n\r\n/**\r\n * Pure geometry: the `translate` string needed to pull `rect` back inside the\r\n * viewport (minus `pad`), or `''` when it already fits. Right/bottom overflow\r\n * takes priority over left/top.\r\n */\r\nconst computeTranslate = (rect: DOMRect, pad: NormalizedPadding): string => {\r\n let dx = 0\r\n let dy = 0\r\n\r\n if (rect.right > window.innerWidth - pad.right) {\r\n dx = window.innerWidth - pad.right - rect.right\r\n } else if (rect.left < pad.left) {\r\n dx = pad.left - rect.left\r\n }\r\n\r\n if (rect.bottom > window.innerHeight - pad.bottom) {\r\n dy = window.innerHeight - pad.bottom - rect.bottom\r\n } else if (rect.top < pad.top) {\r\n dy = pad.top - rect.top\r\n }\r\n\r\n return (dx !== 0 || dy !== 0) ? `${Math.round(dx)}px ${Math.round(dy)}px` : ''\r\n}\r\n\r\n/**\r\n * Builds the idempotent correction pass. It **measures the wrapper** (stable\r\n * final geometry, immune to the content's entrance `transform` animation) and\r\n * **writes `translate` to the content** (composing with — not overriding — that\r\n * animation). Reading the wrapper is unaffected by our content write, so the\r\n * result is absolute and re-running never accumulates.\r\n */\r\nexport const createCorrector = (\r\n content: HTMLElement,\r\n wrapper: HTMLElement,\r\n padRef: { current: NormalizedPadding },\r\n) => () => {\r\n if (isAwaitingPosition(wrapper)) { return }\r\n content.style.translate = computeTranslate(wrapper.getBoundingClientRect(), padRef.current)\r\n}\r\n","/**\r\n * Re-runs `correct` on every event that can change the panel's box:\r\n * - the wrapper's `style` mutations → floating-ui (re)positioning, incl. the\r\n * async transition from the off-screen sentinel to the final coordinates;\r\n * - the content resizing (dynamic item lists) — also fires once on observe,\r\n * covering a wrapper already positioned when the ref attached;\r\n * - viewport resize.\r\n * Returns a cleanup that detaches everything.\r\n */\r\nexport const watchRepositions = (content: HTMLElement, wrapper: HTMLElement, correct: () => void) => {\r\n const mutation = new MutationObserver(correct)\r\n mutation.observe(wrapper, { attributes: true, attributeFilter: ['style'] })\r\n\r\n const resize = new ResizeObserver(correct)\r\n resize.observe(content)\r\n\r\n window.addEventListener('resize', correct)\r\n\r\n return () => {\r\n mutation.disconnect()\r\n resize.disconnect()\r\n window.removeEventListener('resize', correct)\r\n }\r\n}\r\n","import { useCallback, useRef } from 'react'\r\nimport { guardAccidentalSelection } from '@hooks/use-viewport-shift/helpers/guardAccidentalSelection.helper.ts'\r\nimport { normalizePadding } from '@hooks/use-viewport-shift/helpers/normalizePadding.helper.ts'\r\nimport { createCorrector } from '@hooks/use-viewport-shift/helpers/createCorrector.helper.ts'\r\nimport { watchRepositions } from '@hooks/use-viewport-shift/helpers/watchRepositions.helper.ts'\r\nimport type { Padding } from '@hooks/use-viewport-shift/types'\r\n\r\n/**\r\n * Returns a React 19 **callback ref** that keeps a Radix floating panel fully\r\n * visible within the viewport by applying a CSS `translate` correction.\r\n *\r\n * A callback ref is required because Radix `Portal` mounts content in a second\r\n * render pass, so a parent `useLayoutEffect` would fire while the node is still\r\n * `null`; the callback fires exactly when the DOM node attaches.\r\n *\r\n * @param collisionPadding - Minimum gap in px between the panel and each\r\n * viewport edge. Accepts a uniform number or a per-side object. @default 8\r\n */\r\nexport const useViewportShift = (collisionPadding: Padding = 8) => {\r\n // Stable ref so the callback always reads the latest padding without being\r\n // recreated on every render.\r\n const padRef = useRef(normalizePadding(collisionPadding))\r\n padRef.current = normalizePadding(collisionPadding)\r\n\r\n return useCallback((content: HTMLDivElement | null): (() => void) | void => {\r\n // `parentElement` is the Radix popper wrapper carrying floating-ui's\r\n // positioning transform — the element we measure and observe.\r\n const wrapper = content?.parentElement\r\n if (!content || !wrapper) { return }\r\n\r\n const correct = createCorrector(content, wrapper, padRef)\r\n const stopWatching = watchRepositions(content, wrapper, correct)\r\n const stopGuarding = guardAccidentalSelection(content)\r\n\r\n // React 19 callback ref cleanup — called automatically on unmount.\r\n return () => {\r\n stopWatching()\r\n stopGuarding()\r\n }\r\n }, []) // stable: only padRef (a ref) is captured — never changes identity\r\n}\r\n","import { createContext, useContext } from 'react'\r\nimport type { ThemeMode } from '@components/theme-provider/types/ThemeProvider.props.ts'\r\n\r\nexport interface ThemeContextValue {\r\n /** Currently active mode. `'system'` means \"follow the OS preference\". */\r\n theme: ThemeMode\r\n\r\n /**\r\n * The concrete resolved mode — always `'light'` or `'dark'`, never\r\n * `'system'`. Useful for conditional rendering that depends on the actual\r\n * visual state (e.g. swapping an icon).\r\n */\r\n resolvedTheme: 'light' | 'dark'\r\n\r\n /**\r\n * Change the active mode.\r\n * - In **uncontrolled** mode this updates internal state.\r\n * - In **controlled** mode (`theme` prop is provided) it only fires\r\n * `onThemeChange`; the parent is responsible for updating `theme`.\r\n */\r\n setTheme: (theme: ThemeMode) => void\r\n}\r\n\r\n/**\r\n * Default context value used when `useTheme` is called outside a\r\n * `ThemeProvider`. Falls back to `'system'` / `'light'` so the hook is\r\n * always safe to call.\r\n */\r\nconst defaultContext: ThemeContextValue = {\r\n theme: 'system',\r\n resolvedTheme: 'light',\r\n setTheme: () => undefined,\r\n}\r\n\r\nexport const ThemeContext = createContext<ThemeContextValue>(defaultContext)\r\n\r\n/**\r\n * Returns the nearest `ThemeProvider` context.\r\n *\r\n * Safe to call outside a provider — returns `{ theme: 'system', resolvedTheme:\r\n * 'light', setTheme: noop }` as a fallback.\r\n *\r\n * @example\r\n * const { resolvedTheme, setTheme } = useTheme()\r\n */\r\nexport const useTheme = (): ThemeContextValue => useContext(ThemeContext)\r\n","/**\r\n * Reads the OS color-scheme preference. Returns `'light'` in SSR / non-browser\r\n * environments to avoid hydration mismatches.\r\n */\r\nexport const getSystemTheme = (): 'light' | 'dark' =>\r\n typeof window !== 'undefined' && window.matchMedia('(prefers-color-scheme: dark)').matches\r\n ? 'dark'\r\n : 'light'\r\n","import type { ThemeMode } from '@components'\r\n\r\nexport const resolveTheme = (mode: ThemeMode, systemTheme: 'light' | 'dark'): 'light' | 'dark' =>\r\n mode === 'system' ? systemTheme : mode\r\n","import { type FC, useEffect, useMemo, useState } from 'react'\r\nimport { ThemeContext } from '@components/theme-provider/ThemeProvider.context.ts'\r\nimport type { ThemeMode, ThemeProviderProps } from '@components/theme-provider/types/ThemeProvider.props.ts'\r\nimport { getSystemTheme } from '@components/theme-provider/utils/getSystemTheme.utils.ts'\r\nimport { resolveTheme } from '@components/theme-provider/utils/resolveTheme.utils.ts'\r\n\r\n/**\r\n * `ThemeProvider` wraps a subtree and manages the active color-scheme.\r\n *\r\n * ### What it does\r\n * - Sets `data-theme=\"light\"` or `data-theme=\"dark\"` on its wrapper `<div>` so\r\n * the kit's CSS-variable scoping works out of the box.\r\n * - In `'system'` mode it follows `prefers-color-scheme` and reactively updates\r\n * when the OS preference changes.\r\n * - Accepts a `tokens` map to inject runtime CSS-variable overrides directly\r\n * on the wrapper element — no `.css.ts` file required.\r\n * - Exposes `{ theme, resolvedTheme, setTheme }` via React context so any child\r\n * can read or change the active mode with the `useTheme` hook.\r\n *\r\n * ### Controlled vs uncontrolled\r\n * - **Uncontrolled** (default): omit the `theme` prop. The component manages\r\n * its own state; use `defaultTheme` to set the initial value.\r\n * - **Controlled**: pass `theme` and handle `onThemeChange` in the parent.\r\n *\r\n * ### Placing in your app\r\n * Wrap your whole application to enable global theming:\r\n * ```tsx\r\n * <ThemeProvider defaultTheme=\"system\">\r\n * <App />\r\n * </ThemeProvider>\r\n * ```\r\n * Or scope it to a single subtree:\r\n * ```tsx\r\n * <ThemeProvider theme=\"dark\" tokens={{ primary: 'oklch(0.70 0.16 185)' }}>\r\n * <DarkWidget />\r\n * </ThemeProvider>\r\n * ```\r\n */\r\nconst ThemeProvider: FC<ThemeProviderProps> = ({\r\n theme: controlledTheme,\r\n defaultTheme = 'system',\r\n onThemeChange,\r\n tokens,\r\n style,\r\n children,\r\n ...divProps\r\n}) => {\r\n\r\n // 1. Internal state (uncontrolled mode)\r\n\r\n const [internalTheme, setInternalTheme] = useState<ThemeMode>(defaultTheme)\r\n const activeTheme = controlledTheme ?? internalTheme\r\n\r\n // 2. Resolve OS preference and subscribe to changes\r\n\r\n const [systemTheme, setSystemTheme] = useState<'light' | 'dark'>(getSystemTheme)\r\n\r\n useEffect(() => {\r\n const mql = window.matchMedia('(prefers-color-scheme: dark)')\r\n const handler = (e: MediaQueryListEvent) => setSystemTheme(e.matches ? 'dark' : 'light')\r\n mql.addEventListener('change', handler)\r\n return () => mql.removeEventListener('change', handler)\r\n }, [])\r\n\r\n const resolvedTheme = resolveTheme(activeTheme, systemTheme)\r\n\r\n // 3. setTheme — works in both controlled and uncontrolled modes\r\n\r\n const setTheme = (next: ThemeMode) => {\r\n if (controlledTheme === undefined) {\r\n setInternalTheme(next)\r\n }\r\n onThemeChange?.(next)\r\n }\r\n\r\n // 4. Convert `tokens` → inline CSS custom properties\r\n\r\n const tokenStyles = useMemo<React.CSSProperties>(() => {\r\n if (!tokens) { return {} }\r\n return Object.fromEntries(\r\n Object.entries(tokens).map(([key, value]) => [`--color-${key}`, value]),\r\n ) as React.CSSProperties\r\n }, [tokens])\r\n\r\n // 5. Render\r\n\r\n return (\r\n <ThemeContext.Provider value={{ theme: activeTheme, resolvedTheme, setTheme }}>\r\n <div\r\n data-theme={resolvedTheme}\r\n style={{ ...tokenStyles, ...style }}\r\n {...divProps}\r\n >\r\n {children}\r\n </div>\r\n </ThemeContext.Provider>\r\n )\r\n}\r\n\r\nThemeProvider.displayName = 'ThemeProvider'\r\n\r\nexport default ThemeProvider\r\n","function toPrimitive(t, r) {\n if (\"object\" != typeof t || !t) return t;\n var e = t[Symbol.toPrimitive];\n if (void 0 !== e) {\n var i = e.call(t, r || \"default\");\n if (\"object\" != typeof i) return i;\n throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n }\n return (\"string\" === r ? String : Number)(t);\n}\n\nfunction toPropertyKey(t) {\n var i = toPrimitive(t, \"string\");\n return \"symbol\" == typeof i ? i : String(i);\n}\n\nfunction _defineProperty(obj, key, value) {\n key = toPropertyKey(key);\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n return obj;\n}\n\nfunction ownKeys(e, r) {\n var t = Object.keys(e);\n if (Object.getOwnPropertySymbols) {\n var o = Object.getOwnPropertySymbols(e);\n r && (o = o.filter(function (r) {\n return Object.getOwnPropertyDescriptor(e, r).enumerable;\n })), t.push.apply(t, o);\n }\n return t;\n}\nfunction _objectSpread2(e) {\n for (var r = 1; r < arguments.length; r++) {\n var t = null != arguments[r] ? arguments[r] : {};\n r % 2 ? ownKeys(Object(t), !0).forEach(function (r) {\n _defineProperty(e, r, t[r]);\n }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) {\n Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r));\n });\n }\n return e;\n}\n\nfunction mapValues(input, fn) {\n var result = {};\n for (var _key in input) {\n result[_key] = fn(input[_key], _key);\n }\n return result;\n}\n\nvar shouldApplyCompound = (compoundCheck, selections, defaultVariants) => {\n for (var key of Object.keys(compoundCheck)) {\n var _selections$key;\n if (compoundCheck[key] !== ((_selections$key = selections[key]) !== null && _selections$key !== void 0 ? _selections$key : defaultVariants[key])) {\n return false;\n }\n }\n return true;\n};\nvar createRuntimeFn = config => {\n var runtimeFn = options => {\n var className = config.defaultClassName;\n var selections = _objectSpread2(_objectSpread2({}, config.defaultVariants), options);\n for (var variantName in selections) {\n var _selections$variantNa;\n var variantSelection = (_selections$variantNa = selections[variantName]) !== null && _selections$variantNa !== void 0 ? _selections$variantNa : config.defaultVariants[variantName];\n if (variantSelection != null) {\n var selection = variantSelection;\n if (typeof selection === 'boolean') {\n // @ts-expect-error\n selection = selection === true ? 'true' : 'false';\n }\n var selectionClassName =\n // @ts-expect-error\n config.variantClassNames[variantName][selection];\n if (selectionClassName) {\n className += ' ' + selectionClassName;\n }\n }\n }\n for (var [compoundCheck, compoundClassName] of config.compoundVariants) {\n if (shouldApplyCompound(compoundCheck, selections, config.defaultVariants)) {\n className += ' ' + compoundClassName;\n }\n }\n return className;\n };\n runtimeFn.variants = () => Object.keys(config.variantClassNames);\n runtimeFn.classNames = {\n get base() {\n return config.defaultClassName.split(' ')[0];\n },\n get variants() {\n return mapValues(config.variantClassNames, classNames => mapValues(classNames, className => className.split(' ')[0]));\n }\n };\n return runtimeFn;\n};\n\nexport { createRuntimeFn as c, mapValues as m };\n","import { createVar, globalStyle, style } from '@vanilla-extract/css'\r\nimport { recipe, type RecipeVariants } from '@vanilla-extract/recipes'\r\n\r\nimport { vars } from '@theme/contract.css.ts'\r\n\r\n/**\r\n * CSS custom property seeded on <table>, inherited by every <th>/<td>\r\n * descendant — lets the `size` variant control cell density from one place.\r\n */\r\nexport const cellPaddingBlockVar = createVar()\r\n\r\nexport const tableWrapperClass = style({\r\n position: 'relative',\r\n width: '100%',\r\n overflowX: 'auto',\r\n})\r\n\r\n/**\r\n * Applied to <table> when `striped` is true.\r\n * Skips rows that carry an explicit `data-intent` attribute so intent row\r\n * colours always win over the stripe background.\r\n */\r\nexport const tableStripedClass = style({})\r\nglobalStyle(`${tableStripedClass} tbody tr:nth-child(even):not([data-intent])`, {\r\n backgroundColor: vars.color.muted,\r\n})\r\n\r\n/**\r\n * Applied to <table> when `bordered` is true.\r\n * Adds borders on all four sides of every header and data cell.\r\n */\r\nexport const tableBorderedClass = style({})\r\nglobalStyle(`${tableBorderedClass} th, ${tableBorderedClass} td`, {\r\n border: `1px solid ${vars.color.border}`,\r\n})\r\n\r\n/** Applied to <table> when `fixed` is true. Enables `table-layout: fixed`. */\r\nexport const tableFixedClass = style({\r\n tableLayout: 'fixed',\r\n})\r\n\r\nexport const tableRecipe = recipe({\r\n base: {\r\n width: '100%',\r\n captionSide: 'bottom',\r\n fontSize: vars.fontSize.sm,\r\n borderCollapse: 'collapse',\r\n vars: { [cellPaddingBlockVar]: vars.space.sm },\r\n },\r\n variants: {\r\n size: {\r\n sm: { vars: { [cellPaddingBlockVar]: vars.space.xs } },\r\n md: { vars: { [cellPaddingBlockVar]: vars.space.sm } },\r\n lg: { vars: { [cellPaddingBlockVar]: vars.space.md } },\r\n },\r\n },\r\n defaultVariants: { size: 'md' },\r\n})\r\n\r\nexport type TableRecipeVariants = NonNullable<RecipeVariants<typeof tableRecipe>>\r\n","import type { FC } from 'react'\r\n\r\nimport {\r\n tableRecipe,\r\n tableWrapperClass,\r\n tableStripedClass,\r\n tableBorderedClass,\r\n tableFixedClass,\r\n} from '@components/data-display/table/Table.css.ts'\r\nimport type { TableProps } from '@components/data-display/table/types/Table.props.ts'\r\nimport { cn } from '@utils/cn.ts'\r\n\r\nconst Table: FC<TableProps> = ({ size, striped, bordered, fixed, className, ref, ...props }) => (\r\n <div\r\n className={tableWrapperClass}\r\n // Scrollable overflow containers must be keyboard-reachable so users\r\n // can scroll them without a mouse (WCAG 2.1 SC 2.1.1).\r\n // eslint-disable-next-line jsx-a11y/no-noninteractive-tabindex\r\n tabIndex={0}\r\n >\r\n <table\r\n ref={ref}\r\n className={cn(\r\n tableRecipe({ size }),\r\n striped && tableStripedClass,\r\n bordered && tableBorderedClass,\r\n fixed && tableFixedClass,\r\n className,\r\n )}\r\n {...props}\r\n />\r\n </div>\r\n)\r\n\r\nTable.displayName = 'Table'\r\n\r\nexport default Table\r\n","import { style } from '@vanilla-extract/css'\r\n\r\nimport { vars } from '@theme/contract.css.ts'\r\n\r\nexport const tableHeaderClass = style({\r\n borderBottom: `1px solid ${vars.color.border}`,\r\n})\r\n","import type { FC } from 'react'\r\n\r\nimport { tableHeaderClass } from '@components/data-display/table/components/table-header/TableHeader.css.ts'\r\nimport type { TableHeaderProps } from '@components/data-display/table/components/table-header/types/TableHeader.props.ts'\r\nimport { cn } from '@utils/cn.ts'\r\n\r\nconst TableHeader: FC<TableHeaderProps> = ({ className, ref, ...props }) => (\r\n <thead\r\n ref={ref}\r\n className={cn(tableHeaderClass, className)}\r\n {...props}\r\n />\r\n)\r\n\r\nTableHeader.displayName = 'TableHeader'\r\n\r\nexport default TableHeader\r\n","import { globalStyle, style } from '@vanilla-extract/css'\r\n\r\nimport { vars } from '@theme/contract.css.ts'\r\n\r\nexport const tableBodyClass = style({})\r\n\r\nglobalStyle(`${tableBodyClass} tr:last-child`, {\r\n borderBottom: 'none',\r\n})\r\n\r\nexport const tableBodyStripedClass = style({})\r\n\r\nglobalStyle(`${tableBodyStripedClass} tr:nth-child(even)`, {\r\n backgroundColor: vars.color.muted,\r\n})\r\n","import type { FC } from 'react'\r\n\r\nimport { tableBodyClass } from '@components/data-display/table/components/table-body/TableBody.css.ts'\r\nimport type { TableBodyProps } from '@components/data-display/table/components/table-body/types/TableBody.props.ts'\r\nimport { cn } from '@utils/cn.ts'\r\n\r\nconst TableBody: FC<TableBodyProps> = ({ className, ref, ...props }) => (\r\n <tbody\r\n ref={ref}\r\n className={cn(tableBodyClass, className)}\r\n {...props}\r\n />\r\n)\r\n\r\nTableBody.displayName = 'TableBody'\r\n\r\nexport default TableBody\r\n","import { globalStyle, style } from '@vanilla-extract/css'\r\n\r\nimport { vars } from '@theme/contract.css.ts'\r\n\r\nexport const tableFooterClass = style({\r\n borderTop: `1px solid ${vars.color.border}`,\r\n backgroundColor: vars.color.muted,\r\n fontWeight: vars.fontWeight.medium,\r\n color: vars.color.mutedForeground,\r\n})\r\n\r\nglobalStyle(`${tableFooterClass} tr:last-child`, {\r\n borderBottom: 'none',\r\n})\r\n","import type { FC } from 'react'\r\n\r\nimport { tableFooterClass } from '@components/data-display/table/components/table-footer/TableFooter.css.ts'\r\nimport type { TableFooterProps } from '@components/data-display/table/components/table-footer/types/TableFooter.props.ts'\r\nimport { cn } from '@utils/cn.ts'\r\n\r\nconst TableFooter: FC<TableFooterProps> = ({ className, ref, ...props }) => (\r\n <tfoot\r\n ref={ref}\r\n className={cn(tableFooterClass, className)}\r\n {...props}\r\n />\r\n)\r\n\r\nTableFooter.displayName = 'TableFooter'\r\n\r\nexport default TableFooter\r\n","import { recipe, type RecipeVariants } from '@vanilla-extract/recipes'\r\n\r\nimport { vars } from '@theme/contract.css.ts'\r\n\r\nexport const tableRowRecipe = recipe({\r\n base: {\r\n borderBottom: `1px solid ${vars.color.border}`,\r\n transition: `background-color ${vars.duration.fast} ${vars.easing.standard}`,\r\n },\r\n variants: {\r\n hoverable: {\r\n true: {\r\n selectors: {\r\n '&:hover': {\r\n backgroundColor: vars.color.muted,\r\n },\r\n },\r\n },\r\n },\r\n /**\r\n * Makes the row visually interactive: adds `cursor: pointer` and a\r\n * hover background. Use together with `onClick` and `selected` to build\r\n * a row-selection pattern without extra wrapper components.\r\n * Implies `hoverable` behaviour — there is no need to pass both.\r\n */\r\n selectable: {\r\n true: {\r\n cursor: 'pointer',\r\n selectors: {\r\n '&:hover': {\r\n backgroundColor: vars.color.muted,\r\n },\r\n '&:focus-visible': {\r\n outline: 'none',\r\n boxShadow: `inset 0 0 0 2px ${vars.color.ring}`,\r\n },\r\n },\r\n },\r\n },\r\n selected: {\r\n true: {\r\n backgroundColor: vars.color.primarySubtle,\r\n },\r\n },\r\n intent: {\r\n success: {\r\n backgroundColor: vars.color.successSubtle,\r\n color: vars.color.successSubtleForeground,\r\n },\r\n warning: {\r\n backgroundColor: vars.color.warningSubtle,\r\n color: vars.color.warningSubtleForeground,\r\n },\r\n destructive: {\r\n backgroundColor: vars.color.destructiveSubtle,\r\n color: vars.color.destructiveSubtleForeground,\r\n },\r\n info: {\r\n backgroundColor: vars.color.infoSubtle,\r\n color: vars.color.infoSubtleForeground,\r\n },\r\n },\r\n },\r\n compoundVariants: [\r\n {\r\n variants: { hoverable: true, intent: 'success' },\r\n style: { selectors: { '&:hover': { backgroundColor: vars.color.successSubtleHover } } },\r\n },\r\n {\r\n variants: { hoverable: true, intent: 'warning' },\r\n style: { selectors: { '&:hover': { backgroundColor: vars.color.warningSubtleHover } } },\r\n },\r\n {\r\n variants: { hoverable: true, intent: 'destructive' },\r\n style: { selectors: { '&:hover': { backgroundColor: vars.color.destructiveSubtleHover } } },\r\n },\r\n {\r\n variants: { hoverable: true, intent: 'info' },\r\n style: { selectors: { '&:hover': { backgroundColor: vars.color.infoSubtleHover } } },\r\n },\r\n {\r\n variants: { selectable: true, intent: 'success' },\r\n style: { selectors: { '&:hover': { backgroundColor: vars.color.successSubtleHover } } },\r\n },\r\n {\r\n variants: { selectable: true, intent: 'warning' },\r\n style: { selectors: { '&:hover': { backgroundColor: vars.color.warningSubtleHover } } },\r\n },\r\n {\r\n variants: { selectable: true, intent: 'destructive' },\r\n style: { selectors: { '&:hover': { backgroundColor: vars.color.destructiveSubtleHover } } },\r\n },\r\n {\r\n variants: { selectable: true, intent: 'info' },\r\n style: { selectors: { '&:hover': { backgroundColor: vars.color.infoSubtleHover } } },\r\n },\r\n ],\r\n defaultVariants: {\r\n hoverable: false,\r\n selected: false,\r\n },\r\n})\r\n\r\nexport type TableRowRecipeVariants = NonNullable<RecipeVariants<typeof tableRowRecipe>>\r\n","import type { FC, KeyboardEvent } from 'react'\r\n\r\nimport { tableRowRecipe } from '@components/data-display/table/components/table-row/TableRow.css.ts'\r\nimport type { TableRowProps } from '@components/data-display/table/components/table-row/types/TableRow.props.ts'\r\nimport { cn } from '@utils/cn.ts'\r\n\r\nconst TableRow: FC<TableRowProps> = ({\r\n hoverable,\r\n selectable,\r\n selected,\r\n intent,\r\n className,\r\n ref,\r\n onKeyDown,\r\n ...props\r\n}) => {\r\n const handleKeyDown = (e: KeyboardEvent<HTMLTableRowElement>) => {\r\n if (selectable && (e.key === 'Enter' || e.key === ' ')) {\r\n e.preventDefault()\r\n e.currentTarget.click()\r\n }\r\n onKeyDown?.(e)\r\n }\r\n\r\n return (\r\n <tr\r\n ref={ref}\r\n data-intent={intent}\r\n aria-selected={selectable ? selected ?? false : undefined}\r\n tabIndex={selectable ? 0 : undefined}\r\n onKeyDown={selectable || onKeyDown ? handleKeyDown : undefined}\r\n className={cn(tableRowRecipe({ hoverable, selectable, selected, intent }), className)}\r\n {...props}\r\n />\r\n )\r\n}\r\n\r\nTableRow.displayName = 'TableRow'\r\n\r\nexport default TableRow\r\n","'use client';\n\nimport { createElement, forwardRef, useState, useEffect } from 'react';\n\n/**\n* Resolve icon set icons\n*\n* Returns parent icon for each icon\n*/\nfunction getIconsTree(data, names) {\n\tconst icons = data.icons;\n\tconst aliases = data.aliases || Object.create(null);\n\tconst resolved = Object.create(null);\n\tfunction resolve(name) {\n\t\tif (icons[name]) return resolved[name] = [];\n\t\tif (!(name in resolved)) {\n\t\t\tresolved[name] = null;\n\t\t\tconst parent = aliases[name] && aliases[name].parent;\n\t\t\tconst value = parent && resolve(parent);\n\t\t\tif (value) resolved[name] = [parent].concat(value);\n\t\t}\n\t\treturn resolved[name];\n\t}\n\t(Object.keys(icons).concat(Object.keys(aliases))).forEach(resolve);\n\treturn resolved;\n}\n\n/**\n* Default values for dimensions\n*/\nconst defaultIconDimensions = Object.freeze({\n\tleft: 0,\n\ttop: 0,\n\twidth: 16,\n\theight: 16\n});\n/**\n* Default values for transformations\n*/\nconst defaultIconTransformations = Object.freeze({\n\trotate: 0,\n\tvFlip: false,\n\thFlip: false\n});\n/**\n* Default values for all optional IconifyIcon properties\n*/\nconst defaultIconProps = Object.freeze({\n\t...defaultIconDimensions,\n\t...defaultIconTransformations\n});\n/**\n* Default values for all properties used in ExtendedIconifyIcon\n*/\nconst defaultExtendedIconProps = Object.freeze({\n\t...defaultIconProps,\n\tbody: \"\",\n\thidden: false\n});\n\n/**\n* Merge transformations\n*/\nfunction mergeIconTransformations(obj1, obj2) {\n\tconst result = {};\n\tif (!obj1.hFlip !== !obj2.hFlip) result.hFlip = true;\n\tif (!obj1.vFlip !== !obj2.vFlip) result.vFlip = true;\n\tconst rotate = ((obj1.rotate || 0) + (obj2.rotate || 0)) % 4;\n\tif (rotate) result.rotate = rotate;\n\treturn result;\n}\n\n/**\n* Merge icon and alias\n*\n* Can also be used to merge default values and icon\n*/\nfunction mergeIconData(parent, child) {\n\tconst result = mergeIconTransformations(parent, child);\n\tfor (const key in defaultExtendedIconProps) if (key in defaultIconTransformations) {\n\t\tif (key in parent && !(key in result)) result[key] = defaultIconTransformations[key];\n\t} else if (key in child) result[key] = child[key];\n\telse if (key in parent) result[key] = parent[key];\n\treturn result;\n}\n\n/**\n* Get icon data, using prepared aliases tree\n*/\nfunction internalGetIconData(data, name, tree) {\n\tconst icons = data.icons;\n\tconst aliases = data.aliases || Object.create(null);\n\tlet currentProps = {};\n\tfunction parse(name$1) {\n\t\tcurrentProps = mergeIconData(icons[name$1] || aliases[name$1], currentProps);\n\t}\n\tparse(name);\n\ttree.forEach(parse);\n\treturn mergeIconData(data, currentProps);\n}\n\n/**\n* Extract icons from an icon set\n*\n* Returns list of icons that were found in icon set\n*/\nfunction parseIconSet(data, callback) {\n\tconst names = [];\n\tif (typeof data !== \"object\" || typeof data.icons !== \"object\") return names;\n\tif (data.not_found instanceof Array) data.not_found.forEach((name) => {\n\t\tcallback(name, null);\n\t\tnames.push(name);\n\t});\n\tconst tree = getIconsTree(data);\n\tfor (const name in tree) {\n\t\tconst item = tree[name];\n\t\tif (item) {\n\t\t\tcallback(name, internalGetIconData(data, name, item));\n\t\t\tnames.push(name);\n\t\t}\n\t}\n\treturn names;\n}\n\n/**\n* Optional properties\n*/\nconst optionalPropertyDefaults = {\n\tprovider: \"\",\n\taliases: {},\n\tnot_found: {},\n\t...defaultIconDimensions\n};\n/**\n* Check props\n*/\nfunction checkOptionalProps(item, defaults) {\n\tfor (const prop in defaults) if (prop in item && typeof item[prop] !== typeof defaults[prop]) return false;\n\treturn true;\n}\n/**\n* Validate icon set, return it as IconifyJSON on success, null on failure\n*\n* Unlike validateIconSet(), this function is very basic.\n* It does not throw exceptions, it does not check metadata, it does not fix stuff.\n*/\nfunction quicklyValidateIconSet(obj) {\n\tif (typeof obj !== \"object\" || obj === null) return null;\n\tconst data = obj;\n\tif (typeof data.prefix !== \"string\" || !obj.icons || typeof obj.icons !== \"object\") return null;\n\tif (!checkOptionalProps(obj, optionalPropertyDefaults)) return null;\n\tconst icons = data.icons;\n\tfor (const name in icons) {\n\t\tconst icon = icons[name];\n\t\tif (!name || typeof icon.body !== \"string\" || !checkOptionalProps(icon, defaultExtendedIconProps)) return null;\n\t}\n\tconst aliases = data.aliases || Object.create(null);\n\tfor (const name in aliases) {\n\t\tconst icon = aliases[name];\n\t\tconst parent = icon.parent;\n\t\tif (!name || typeof parent !== \"string\" || !icons[parent] && !aliases[parent] || !checkOptionalProps(icon, defaultExtendedIconProps)) return null;\n\t}\n\treturn data;\n}\n\n/**\n* Storage by provider and prefix\n*/\nconst dataStorage = Object.create(null);\n/**\n* Create new storage\n*/\nfunction newStorage(provider, prefix) {\n\treturn {\n\t\tprovider,\n\t\tprefix,\n\t\ticons: Object.create(null),\n\t\tmissing: /* @__PURE__ */ new Set()\n\t};\n}\n/**\n* Get storage for provider and prefix\n*/\nfunction getStorage(provider, prefix) {\n\tconst providerStorage = dataStorage[provider] || (dataStorage[provider] = Object.create(null));\n\treturn providerStorage[prefix] || (providerStorage[prefix] = newStorage(provider, prefix));\n}\n/**\n* Add icon set to storage\n*\n* Returns array of added icons\n*/\nfunction addIconSet(storage, data) {\n\tif (!quicklyValidateIconSet(data)) return [];\n\treturn parseIconSet(data, (name, icon) => {\n\t\tif (icon) storage.icons[name] = icon;\n\t\telse storage.missing.add(name);\n\t});\n}\n/**\n* Add icon to storage\n*/\nfunction addIconToStorage(storage, name, icon) {\n\ttry {\n\t\tif (typeof icon.body === \"string\") {\n\t\t\tstorage.icons[name] = { ...icon };\n\t\t\treturn true;\n\t\t}\n\t} catch (err) {}\n\treturn false;\n}\n/**\n* List available icons\n*/\nfunction listIcons(provider, prefix) {\n\tlet allIcons = [];\n\tconst providers = typeof provider === \"string\" ? [provider] : Object.keys(dataStorage);\n\tproviders.forEach((provider$1) => {\n\t\tconst prefixes = typeof provider$1 === \"string\" && typeof prefix === \"string\" ? [prefix] : Object.keys(dataStorage[provider$1] || {});\n\t\tprefixes.forEach((prefix$1) => {\n\t\t\tconst storage = getStorage(provider$1, prefix$1);\n\t\t\tallIcons = allIcons.concat(Object.keys(storage.icons).map((name) => (provider$1 !== \"\" ? \"@\" + provider$1 + \":\" : \"\") + prefix$1 + \":\" + name));\n\t\t});\n\t});\n\treturn allIcons;\n}\n\n/**\n* Expression to test part of icon name.\n*\n* Used when loading icons from Iconify API due to project naming convension.\n* Ignored when using custom icon sets - convension does not apply.\n*/\nconst matchIconName = /^[a-z0-9]+(-[a-z0-9]+)*$/;\n/**\n* Convert string icon name to IconifyIconName object.\n*/\nconst stringToIcon = (value, validate, allowSimpleName, provider = \"\") => {\n\tconst colonSeparated = value.split(\":\");\n\tif (value.slice(0, 1) === \"@\") {\n\t\tif (colonSeparated.length < 2 || colonSeparated.length > 3) return null;\n\t\tprovider = colonSeparated.shift().slice(1);\n\t}\n\tif (colonSeparated.length > 3 || !colonSeparated.length) return null;\n\tif (colonSeparated.length > 1) {\n\t\tconst name$1 = colonSeparated.pop();\n\t\tconst prefix = colonSeparated.pop();\n\t\tconst result = {\n\t\t\tprovider: colonSeparated.length > 0 ? colonSeparated[0] : provider,\n\t\t\tprefix,\n\t\t\tname: name$1\n\t\t};\n\t\treturn validate && !validateIconName(result) ? null : result;\n\t}\n\tconst name = colonSeparated[0];\n\tconst dashSeparated = name.split(\"-\");\n\tif (dashSeparated.length > 1) {\n\t\tconst result = {\n\t\t\tprovider,\n\t\t\tprefix: dashSeparated.shift(),\n\t\t\tname: dashSeparated.join(\"-\")\n\t\t};\n\t\treturn validate && !validateIconName(result) ? null : result;\n\t}\n\tif (allowSimpleName && provider === \"\") {\n\t\tconst result = {\n\t\t\tprovider,\n\t\t\tprefix: \"\",\n\t\t\tname\n\t\t};\n\t\treturn validate && !validateIconName(result, allowSimpleName) ? null : result;\n\t}\n\treturn null;\n};\n/**\n* Check if icon is valid.\n*\n* This function is not part of stringToIcon because validation is not needed for most code.\n*/\nconst validateIconName = (icon, allowSimpleName) => {\n\tif (!icon) return false;\n\treturn !!((allowSimpleName && icon.prefix === \"\" || !!icon.prefix) && !!icon.name);\n};\n\n/**\n* Allow storing icons without provider or prefix, making it possible to store icons like \"home\"\n*/\nlet simpleNames = false;\nfunction allowSimpleNames(allow) {\n\tif (typeof allow === \"boolean\") simpleNames = allow;\n\treturn simpleNames;\n}\n/**\n* Get icon data\n*\n* Returns:\n* - IconifyIcon on success, object directly from storage so don't modify it\n* - null if icon is marked as missing (returned in `not_found` property from API, so don't bother sending API requests)\n* - undefined if icon is missing in storage\n*/\nfunction getIconData(name) {\n\tconst icon = typeof name === \"string\" ? stringToIcon(name, true, simpleNames) : name;\n\tif (icon) {\n\t\tconst storage = getStorage(icon.provider, icon.prefix);\n\t\tconst iconName = icon.name;\n\t\treturn storage.icons[iconName] || (storage.missing.has(iconName) ? null : void 0);\n\t}\n}\n/**\n* Add one icon\n*/\nfunction addIcon(name, data) {\n\tconst icon = stringToIcon(name, true, simpleNames);\n\tif (!icon) return false;\n\tconst storage = getStorage(icon.provider, icon.prefix);\n\tif (data) return addIconToStorage(storage, icon.name, data);\n\telse {\n\t\tstorage.missing.add(icon.name);\n\t\treturn true;\n\t}\n}\n/**\n* Add icon set\n*/\nfunction addCollection(data, provider) {\n\tif (typeof data !== \"object\") return false;\n\tif (typeof provider !== \"string\") provider = data.provider || \"\";\n\tif (simpleNames && !provider && !data.prefix) {\n\t\tlet added = false;\n\t\tif (quicklyValidateIconSet(data)) {\n\t\t\tdata.prefix = \"\";\n\t\t\tparseIconSet(data, (name, icon) => {\n\t\t\t\tif (addIcon(name, icon)) added = true;\n\t\t\t});\n\t\t}\n\t\treturn added;\n\t}\n\tconst prefix = data.prefix;\n\tif (!validateIconName({\n\t\tprefix,\n\t\tname: \"a\"\n\t})) return false;\n\tconst storage = getStorage(provider, prefix);\n\treturn !!addIconSet(storage, data);\n}\n/**\n* Check if icon data is available\n*/\nfunction iconLoaded(name) {\n\treturn !!getIconData(name);\n}\n/**\n* Get full icon\n*/\nfunction getIcon(name) {\n\tconst result = getIconData(name);\n\treturn result ? {\n\t\t...defaultIconProps,\n\t\t...result\n\t} : result;\n}\n\n/**\n* Default icon customisations values\n*/\nconst defaultIconSizeCustomisations = Object.freeze({\n\twidth: null,\n\theight: null\n});\nconst defaultIconCustomisations = Object.freeze({\n\t...defaultIconSizeCustomisations,\n\t...defaultIconTransformations\n});\n\n/**\n* Regular expressions for calculating dimensions\n*/\nconst unitsSplit = /(-?[0-9.]*[0-9]+[0-9.]*)/g;\nconst unitsTest = /^-?[0-9.]*[0-9]+[0-9.]*$/g;\nfunction calculateSize(size, ratio, precision) {\n\tif (ratio === 1) return size;\n\tprecision = precision || 100;\n\tif (typeof size === \"number\") return Math.ceil(size * ratio * precision) / precision;\n\tif (typeof size !== \"string\") return size;\n\tconst oldParts = size.split(unitsSplit);\n\tif (oldParts === null || !oldParts.length) return size;\n\tconst newParts = [];\n\tlet code = oldParts.shift();\n\tlet isNumber = unitsTest.test(code);\n\twhile (true) {\n\t\tif (isNumber) {\n\t\t\tconst num = parseFloat(code);\n\t\t\tif (isNaN(num)) newParts.push(code);\n\t\t\telse newParts.push(Math.ceil(num * ratio * precision) / precision);\n\t\t} else newParts.push(code);\n\t\tcode = oldParts.shift();\n\t\tif (code === void 0) return newParts.join(\"\");\n\t\tisNumber = !isNumber;\n\t}\n}\n\nfunction splitSVGDefs(content, tag = \"defs\") {\n\tlet defs = \"\";\n\tconst index = content.indexOf(\"<\" + tag);\n\twhile (index >= 0) {\n\t\tconst start = content.indexOf(\">\", index);\n\t\tconst end = content.indexOf(\"</\" + tag);\n\t\tif (start === -1 || end === -1) break;\n\t\tconst endEnd = content.indexOf(\">\", end);\n\t\tif (endEnd === -1) break;\n\t\tdefs += content.slice(start + 1, end).trim();\n\t\tcontent = content.slice(0, index).trim() + content.slice(endEnd + 1);\n\t}\n\treturn {\n\t\tdefs,\n\t\tcontent\n\t};\n}\n/**\n* Merge defs and content\n*/\nfunction mergeDefsAndContent(defs, content) {\n\treturn defs ? \"<defs>\" + defs + \"</defs>\" + content : content;\n}\n/**\n* Wrap SVG content, without wrapping definitions\n*/\nfunction wrapSVGContent(body, start, end) {\n\tconst split = splitSVGDefs(body);\n\treturn mergeDefsAndContent(split.defs, start + split.content + end);\n}\n\n/**\n* Check if value should be unset. Allows multiple keywords\n*/\nconst isUnsetKeyword = (value) => value === \"unset\" || value === \"undefined\" || value === \"none\";\n/**\n* Get SVG attributes and content from icon + customisations\n*\n* Does not generate style to make it compatible with frameworks that use objects for style, such as React.\n* Instead, it generates 'inline' value. If true, rendering engine should add verticalAlign: -0.125em to icon.\n*\n* Customisations should be normalised by platform specific parser.\n* Result should be converted to <svg> by platform specific parser.\n* Use replaceIDs to generate unique IDs for body.\n*/\nfunction iconToSVG(icon, customisations) {\n\tconst fullIcon = {\n\t\t...defaultIconProps,\n\t\t...icon\n\t};\n\tconst fullCustomisations = {\n\t\t...defaultIconCustomisations,\n\t\t...customisations\n\t};\n\tconst box = {\n\t\tleft: fullIcon.left,\n\t\ttop: fullIcon.top,\n\t\twidth: fullIcon.width,\n\t\theight: fullIcon.height\n\t};\n\tlet body = fullIcon.body;\n\t[fullIcon, fullCustomisations].forEach((props) => {\n\t\tconst transformations = [];\n\t\tconst hFlip = props.hFlip;\n\t\tconst vFlip = props.vFlip;\n\t\tlet rotation = props.rotate;\n\t\tif (hFlip) if (vFlip) rotation += 2;\n\t\telse {\n\t\t\ttransformations.push(\"translate(\" + (box.width + box.left).toString() + \" \" + (0 - box.top).toString() + \")\");\n\t\t\ttransformations.push(\"scale(-1 1)\");\n\t\t\tbox.top = box.left = 0;\n\t\t}\n\t\telse if (vFlip) {\n\t\t\ttransformations.push(\"translate(\" + (0 - box.left).toString() + \" \" + (box.height + box.top).toString() + \")\");\n\t\t\ttransformations.push(\"scale(1 -1)\");\n\t\t\tbox.top = box.left = 0;\n\t\t}\n\t\tlet tempValue;\n\t\tif (rotation < 0) rotation -= Math.floor(rotation / 4) * 4;\n\t\trotation = rotation % 4;\n\t\tswitch (rotation) {\n\t\t\tcase 1:\n\t\t\t\ttempValue = box.height / 2 + box.top;\n\t\t\t\ttransformations.unshift(\"rotate(90 \" + tempValue.toString() + \" \" + tempValue.toString() + \")\");\n\t\t\t\tbreak;\n\t\t\tcase 2:\n\t\t\t\ttransformations.unshift(\"rotate(180 \" + (box.width / 2 + box.left).toString() + \" \" + (box.height / 2 + box.top).toString() + \")\");\n\t\t\t\tbreak;\n\t\t\tcase 3:\n\t\t\t\ttempValue = box.width / 2 + box.left;\n\t\t\t\ttransformations.unshift(\"rotate(-90 \" + tempValue.toString() + \" \" + tempValue.toString() + \")\");\n\t\t\t\tbreak;\n\t\t}\n\t\tif (rotation % 2 === 1) {\n\t\t\tif (box.left !== box.top) {\n\t\t\t\ttempValue = box.left;\n\t\t\t\tbox.left = box.top;\n\t\t\t\tbox.top = tempValue;\n\t\t\t}\n\t\t\tif (box.width !== box.height) {\n\t\t\t\ttempValue = box.width;\n\t\t\t\tbox.width = box.height;\n\t\t\t\tbox.height = tempValue;\n\t\t\t}\n\t\t}\n\t\tif (transformations.length) body = wrapSVGContent(body, \"<g transform=\\\"\" + transformations.join(\" \") + \"\\\">\", \"</g>\");\n\t});\n\tconst customisationsWidth = fullCustomisations.width;\n\tconst customisationsHeight = fullCustomisations.height;\n\tconst boxWidth = box.width;\n\tconst boxHeight = box.height;\n\tlet width;\n\tlet height;\n\tif (customisationsWidth === null) {\n\t\theight = customisationsHeight === null ? \"1em\" : customisationsHeight === \"auto\" ? boxHeight : customisationsHeight;\n\t\twidth = calculateSize(height, boxWidth / boxHeight);\n\t} else {\n\t\twidth = customisationsWidth === \"auto\" ? boxWidth : customisationsWidth;\n\t\theight = customisationsHeight === null ? calculateSize(width, boxHeight / boxWidth) : customisationsHeight === \"auto\" ? boxHeight : customisationsHeight;\n\t}\n\tconst attributes = {};\n\tconst setAttr = (prop, value) => {\n\t\tif (!isUnsetKeyword(value)) attributes[prop] = value.toString();\n\t};\n\tsetAttr(\"width\", width);\n\tsetAttr(\"height\", height);\n\tconst viewBox = [\n\t\tbox.left,\n\t\tbox.top,\n\t\tboxWidth,\n\t\tboxHeight\n\t];\n\tattributes.viewBox = viewBox.join(\" \");\n\treturn {\n\t\tattributes,\n\t\tviewBox,\n\t\tbody\n\t};\n}\n\n/**\n* IDs usage:\n*\n* id=\"{id}\"\n* xlink:href=\"#{id}\"\n* url(#{id})\n*\n* From SVG animations:\n*\n* begin=\"0;{id}.end\"\n* begin=\"{id}.end\"\n* begin=\"{id}.click\"\n*/\n/**\n* Regular expression for finding ids\n*/\nconst regex = /\\sid=\"(\\S+)\"/g;\n/**\n* New random-ish prefix for ids\n*\n* Do not use dash, it cannot be used in SVG 2 animations\n*/\nconst randomPrefix = \"IconifyId\" + Date.now().toString(16) + (Math.random() * 16777216 | 0).toString(16);\n/**\n* Counter for ids, increasing with every replacement\n*/\nlet counter = 0;\n/**\n* Replace IDs in SVG output with unique IDs\n*/\nfunction replaceIDs(body, prefix = randomPrefix) {\n\tconst ids = [];\n\tlet match;\n\twhile (match = regex.exec(body)) ids.push(match[1]);\n\tif (!ids.length) return body;\n\tconst suffix = \"suffix\" + (Math.random() * 16777216 | Date.now()).toString(16);\n\tids.forEach((id) => {\n\t\tconst newID = typeof prefix === \"function\" ? prefix(id) : prefix + (counter++).toString();\n\t\tconst escapedID = id.replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\");\n\t\tbody = body.replace(new RegExp(\"([#;\\\"])(\" + escapedID + \")([\\\")]|\\\\.[a-z])\", \"g\"), \"$1\" + newID + suffix + \"$3\");\n\t});\n\tbody = body.replace(new RegExp(suffix, \"g\"), \"\");\n\treturn body;\n}\n\n/**\n* Local storate types and entries\n*/\nconst storage = Object.create(null);\n/**\n* Set API module\n*/\nfunction setAPIModule(provider, item) {\n\tstorage[provider] = item;\n}\n/**\n* Get API module\n*/\nfunction getAPIModule(provider) {\n\treturn storage[provider] || storage[\"\"];\n}\n\n/**\n* Create full API configuration from partial data\n*/\nfunction createAPIConfig(source) {\n\tlet resources;\n\tif (typeof source.resources === \"string\") resources = [source.resources];\n\telse {\n\t\tresources = source.resources;\n\t\tif (!(resources instanceof Array) || !resources.length) return null;\n\t}\n\tconst result = {\n\t\tresources,\n\t\tpath: source.path || \"/\",\n\t\tmaxURL: source.maxURL || 500,\n\t\trotate: source.rotate || 750,\n\t\ttimeout: source.timeout || 5e3,\n\t\trandom: source.random === true,\n\t\tindex: source.index || 0,\n\t\tdataAfterTimeout: source.dataAfterTimeout !== false\n\t};\n\treturn result;\n}\n/**\n* Local storage\n*/\nconst configStorage = Object.create(null);\n/**\n* Redundancy for API servers.\n*\n* API should have very high uptime because of implemented redundancy at server level, but\n* sometimes bad things happen. On internet 100% uptime is not possible.\n*\n* There could be routing problems. Server might go down for whatever reason, but it takes\n* few minutes to detect that downtime, so during those few minutes API might not be accessible.\n*\n* This script has some redundancy to mitigate possible network issues.\n*\n* If one host cannot be reached in 'rotate' (750 by default) ms, script will try to retrieve\n* data from different host. Hosts have different configurations, pointing to different\n* API servers hosted at different providers.\n*/\nconst fallBackAPISources = [\"https://api.simplesvg.com\", \"https://api.unisvg.com\"];\nconst fallBackAPI = [];\nwhile (fallBackAPISources.length > 0) if (fallBackAPISources.length === 1) fallBackAPI.push(fallBackAPISources.shift());\nelse if (Math.random() > .5) fallBackAPI.push(fallBackAPISources.shift());\nelse fallBackAPI.push(fallBackAPISources.pop());\nconfigStorage[\"\"] = createAPIConfig({ resources: [\"https://api.iconify.design\"].concat(fallBackAPI) });\n/**\n* Add custom config for provider\n*/\nfunction addAPIProvider(provider, customConfig) {\n\tconst config = createAPIConfig(customConfig);\n\tif (config === null) return false;\n\tconfigStorage[provider] = config;\n\treturn true;\n}\n/**\n* Get API configuration\n*/\nfunction getAPIConfig(provider) {\n\treturn configStorage[provider];\n}\n/**\n* List API providers\n*/\nfunction listAPIProviders() {\n\treturn Object.keys(configStorage);\n}\n\nconst detectFetch = () => {\n\tlet callback;\n\ttry {\n\t\tcallback = fetch;\n\t\tif (typeof callback === \"function\") return callback;\n\t} catch (err) {}\n};\n/**\n* Fetch function\n*/\nlet fetchModule = detectFetch();\n/**\n* Set custom fetch() function\n*/\nfunction setFetch(fetch$1) {\n\tfetchModule = fetch$1;\n}\n/**\n* Get fetch() function. Used by Icon Finder Core\n*/\nfunction getFetch() {\n\treturn fetchModule;\n}\n/**\n* Calculate maximum icons list length for prefix\n*/\nfunction calculateMaxLength(provider, prefix) {\n\tconst config = getAPIConfig(provider);\n\tif (!config) return 0;\n\tlet result;\n\tif (!config.maxURL) result = 0;\n\telse {\n\t\tlet maxHostLength = 0;\n\t\tconfig.resources.forEach((item) => {\n\t\t\tconst host = item;\n\t\t\tmaxHostLength = Math.max(maxHostLength, host.length);\n\t\t});\n\t\tconst url = prefix + \".json?icons=\";\n\t\tresult = config.maxURL - maxHostLength - config.path.length - url.length;\n\t}\n\treturn result;\n}\n/**\n* Should query be aborted, based on last HTTP status\n*/\nfunction shouldAbort(status) {\n\treturn status === 404;\n}\n/**\n* Prepare params\n*/\nconst prepare = (provider, prefix, icons) => {\n\tconst results = [];\n\tconst maxLength = calculateMaxLength(provider, prefix);\n\tconst type = \"icons\";\n\tlet item = {\n\t\ttype,\n\t\tprovider,\n\t\tprefix,\n\t\ticons: []\n\t};\n\tlet length = 0;\n\ticons.forEach((name, index) => {\n\t\tlength += name.length + 1;\n\t\tif (length >= maxLength && index > 0) {\n\t\t\tresults.push(item);\n\t\t\titem = {\n\t\t\t\ttype,\n\t\t\t\tprovider,\n\t\t\t\tprefix,\n\t\t\t\ticons: []\n\t\t\t};\n\t\t\tlength = name.length;\n\t\t}\n\t\titem.icons.push(name);\n\t});\n\tresults.push(item);\n\treturn results;\n};\n/**\n* Get path\n*/\nfunction getPath(provider) {\n\tif (typeof provider === \"string\") {\n\t\tconst config = getAPIConfig(provider);\n\t\tif (config) return config.path;\n\t}\n\treturn \"/\";\n}\n/**\n* Load icons\n*/\nconst send = (host, params, callback) => {\n\tif (!fetchModule) {\n\t\tcallback(\"abort\", 424);\n\t\treturn;\n\t}\n\tlet path = getPath(params.provider);\n\tswitch (params.type) {\n\t\tcase \"icons\": {\n\t\t\tconst prefix = params.prefix;\n\t\t\tconst icons = params.icons;\n\t\t\tconst iconsList = icons.join(\",\");\n\t\t\tconst urlParams = new URLSearchParams({ icons: iconsList });\n\t\t\tpath += prefix + \".json?\" + urlParams.toString();\n\t\t\tbreak;\n\t\t}\n\t\tcase \"custom\": {\n\t\t\tconst uri = params.uri;\n\t\t\tpath += uri.slice(0, 1) === \"/\" ? uri.slice(1) : uri;\n\t\t\tbreak;\n\t\t}\n\t\tdefault:\n\t\t\tcallback(\"abort\", 400);\n\t\t\treturn;\n\t}\n\tlet defaultError = 503;\n\tfetchModule(host + path).then((response) => {\n\t\tconst status = response.status;\n\t\tif (status !== 200) {\n\t\t\tsetTimeout(() => {\n\t\t\t\tcallback(shouldAbort(status) ? \"abort\" : \"next\", status);\n\t\t\t});\n\t\t\treturn;\n\t\t}\n\t\tdefaultError = 501;\n\t\treturn response.json();\n\t}).then((data) => {\n\t\tif (typeof data !== \"object\" || data === null) {\n\t\t\tsetTimeout(() => {\n\t\t\t\tif (data === 404) callback(\"abort\", data);\n\t\t\t\telse callback(\"next\", defaultError);\n\t\t\t});\n\t\t\treturn;\n\t\t}\n\t\tsetTimeout(() => {\n\t\t\tcallback(\"success\", data);\n\t\t});\n\t}).catch(() => {\n\t\tcallback(\"next\", defaultError);\n\t});\n};\n/**\n* Export module\n*/\nconst fetchAPIModule = {\n\tprepare,\n\tsend\n};\n\n/**\n* Remove callback\n*/\nfunction removeCallback(storages, id) {\n\tstorages.forEach((storage) => {\n\t\tconst items = storage.loaderCallbacks;\n\t\tif (items) storage.loaderCallbacks = items.filter((row) => row.id !== id);\n\t});\n}\n/**\n* Update all callbacks for provider and prefix\n*/\nfunction updateCallbacks(storage) {\n\tif (!storage.pendingCallbacksFlag) {\n\t\tstorage.pendingCallbacksFlag = true;\n\t\tsetTimeout(() => {\n\t\t\tstorage.pendingCallbacksFlag = false;\n\t\t\tconst items = storage.loaderCallbacks ? storage.loaderCallbacks.slice(0) : [];\n\t\t\tif (!items.length) return;\n\t\t\tlet hasPending = false;\n\t\t\tconst provider = storage.provider;\n\t\t\tconst prefix = storage.prefix;\n\t\t\titems.forEach((item) => {\n\t\t\t\tconst icons = item.icons;\n\t\t\t\tconst oldLength = icons.pending.length;\n\t\t\t\ticons.pending = icons.pending.filter((icon) => {\n\t\t\t\t\tif (icon.prefix !== prefix) return true;\n\t\t\t\t\tconst name = icon.name;\n\t\t\t\t\tif (storage.icons[name]) icons.loaded.push({\n\t\t\t\t\t\tprovider,\n\t\t\t\t\t\tprefix,\n\t\t\t\t\t\tname\n\t\t\t\t\t});\n\t\t\t\t\telse if (storage.missing.has(name)) icons.missing.push({\n\t\t\t\t\t\tprovider,\n\t\t\t\t\t\tprefix,\n\t\t\t\t\t\tname\n\t\t\t\t\t});\n\t\t\t\t\telse {\n\t\t\t\t\t\thasPending = true;\n\t\t\t\t\t\treturn true;\n\t\t\t\t\t}\n\t\t\t\t\treturn false;\n\t\t\t\t});\n\t\t\t\tif (icons.pending.length !== oldLength) {\n\t\t\t\t\tif (!hasPending) removeCallback([storage], item.id);\n\t\t\t\t\titem.callback(icons.loaded.slice(0), icons.missing.slice(0), icons.pending.slice(0), item.abort);\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t}\n}\n/**\n* Unique id counter for callbacks\n*/\nlet idCounter = 0;\n/**\n* Add callback\n*/\nfunction storeCallback(callback, icons, pendingSources) {\n\tconst id = idCounter++;\n\tconst abort = removeCallback.bind(null, pendingSources, id);\n\tif (!icons.pending.length) return abort;\n\tconst item = {\n\t\tid,\n\t\ticons,\n\t\tcallback,\n\t\tabort\n\t};\n\tpendingSources.forEach((storage) => {\n\t\t(storage.loaderCallbacks || (storage.loaderCallbacks = [])).push(item);\n\t});\n\treturn abort;\n}\n\n/**\n* Check if icons have been loaded\n*/\nfunction sortIcons(icons) {\n\tconst result = {\n\t\tloaded: [],\n\t\tmissing: [],\n\t\tpending: []\n\t};\n\tconst storage = Object.create(null);\n\ticons.sort((a, b) => {\n\t\tif (a.provider !== b.provider) return a.provider.localeCompare(b.provider);\n\t\tif (a.prefix !== b.prefix) return a.prefix.localeCompare(b.prefix);\n\t\treturn a.name.localeCompare(b.name);\n\t});\n\tlet lastIcon = {\n\t\tprovider: \"\",\n\t\tprefix: \"\",\n\t\tname: \"\"\n\t};\n\ticons.forEach((icon) => {\n\t\tif (lastIcon.name === icon.name && lastIcon.prefix === icon.prefix && lastIcon.provider === icon.provider) return;\n\t\tlastIcon = icon;\n\t\tconst provider = icon.provider;\n\t\tconst prefix = icon.prefix;\n\t\tconst name = icon.name;\n\t\tconst providerStorage = storage[provider] || (storage[provider] = Object.create(null));\n\t\tconst localStorage = providerStorage[prefix] || (providerStorage[prefix] = getStorage(provider, prefix));\n\t\tlet list;\n\t\tif (name in localStorage.icons) list = result.loaded;\n\t\telse if (prefix === \"\" || localStorage.missing.has(name)) list = result.missing;\n\t\telse list = result.pending;\n\t\tconst item = {\n\t\t\tprovider,\n\t\t\tprefix,\n\t\t\tname\n\t\t};\n\t\tlist.push(item);\n\t});\n\treturn result;\n}\n\n/**\n* Convert icons list from string/icon mix to icons and validate them\n*/\nfunction listToIcons(list, validate = true, simpleNames = false) {\n\tconst result = [];\n\tlist.forEach((item) => {\n\t\tconst icon = typeof item === \"string\" ? stringToIcon(item, validate, simpleNames) : item;\n\t\tif (icon) result.push(icon);\n\t});\n\treturn result;\n}\n\n/**\n* Default RedundancyConfig for API calls\n*/\nconst defaultConfig = {\n\tresources: [],\n\tindex: 0,\n\ttimeout: 2e3,\n\trotate: 750,\n\trandom: false,\n\tdataAfterTimeout: false\n};\n\n/**\n* Send query\n*/\nfunction sendQuery(config, payload, query, done) {\n\tconst resourcesCount = config.resources.length;\n\tconst startIndex = config.random ? Math.floor(Math.random() * resourcesCount) : config.index;\n\tlet resources;\n\tif (config.random) {\n\t\tlet list = config.resources.slice(0);\n\t\tresources = [];\n\t\twhile (list.length > 1) {\n\t\t\tconst nextIndex = Math.floor(Math.random() * list.length);\n\t\t\tresources.push(list[nextIndex]);\n\t\t\tlist = list.slice(0, nextIndex).concat(list.slice(nextIndex + 1));\n\t\t}\n\t\tresources = resources.concat(list);\n\t} else resources = config.resources.slice(startIndex).concat(config.resources.slice(0, startIndex));\n\tconst startTime = Date.now();\n\tlet status = \"pending\";\n\tlet queriesSent = 0;\n\tlet lastError;\n\tlet timer = null;\n\tlet queue = [];\n\tlet doneCallbacks = [];\n\tif (typeof done === \"function\") doneCallbacks.push(done);\n\t/**\n\t* Reset timer\n\t*/\n\tfunction resetTimer() {\n\t\tif (timer) {\n\t\t\tclearTimeout(timer);\n\t\t\ttimer = null;\n\t\t}\n\t}\n\t/**\n\t* Abort everything\n\t*/\n\tfunction abort() {\n\t\tif (status === \"pending\") status = \"aborted\";\n\t\tresetTimer();\n\t\tqueue.forEach((item) => {\n\t\t\tif (item.status === \"pending\") item.status = \"aborted\";\n\t\t});\n\t\tqueue = [];\n\t}\n\t/**\n\t* Add / replace callback to call when execution is complete.\n\t* This can be used to abort pending query implementations when query is complete or aborted.\n\t*/\n\tfunction subscribe(callback, overwrite) {\n\t\tif (overwrite) doneCallbacks = [];\n\t\tif (typeof callback === \"function\") doneCallbacks.push(callback);\n\t}\n\t/**\n\t* Get query status\n\t*/\n\tfunction getQueryStatus() {\n\t\treturn {\n\t\t\tstartTime,\n\t\t\tpayload,\n\t\t\tstatus,\n\t\t\tqueriesSent,\n\t\t\tqueriesPending: queue.length,\n\t\t\tsubscribe,\n\t\t\tabort\n\t\t};\n\t}\n\t/**\n\t* Fail query\n\t*/\n\tfunction failQuery() {\n\t\tstatus = \"failed\";\n\t\tdoneCallbacks.forEach((callback) => {\n\t\t\tcallback(void 0, lastError);\n\t\t});\n\t}\n\t/**\n\t* Clear queue\n\t*/\n\tfunction clearQueue() {\n\t\tqueue.forEach((item) => {\n\t\t\tif (item.status === \"pending\") item.status = \"aborted\";\n\t\t});\n\t\tqueue = [];\n\t}\n\t/**\n\t* Got response from module\n\t*/\n\tfunction moduleResponse(item, response, data) {\n\t\tconst isError = response !== \"success\";\n\t\tqueue = queue.filter((queued) => queued !== item);\n\t\tswitch (status) {\n\t\t\tcase \"pending\": break;\n\t\t\tcase \"failed\":\n\t\t\t\tif (isError || !config.dataAfterTimeout) return;\n\t\t\t\tbreak;\n\t\t\tdefault: return;\n\t\t}\n\t\tif (response === \"abort\") {\n\t\t\tlastError = data;\n\t\t\tfailQuery();\n\t\t\treturn;\n\t\t}\n\t\tif (isError) {\n\t\t\tlastError = data;\n\t\t\tif (!queue.length) if (!resources.length) failQuery();\n\t\t\telse execNext();\n\t\t\treturn;\n\t\t}\n\t\tresetTimer();\n\t\tclearQueue();\n\t\tif (!config.random) {\n\t\t\tconst index = config.resources.indexOf(item.resource);\n\t\t\tif (index !== -1 && index !== config.index) config.index = index;\n\t\t}\n\t\tstatus = \"completed\";\n\t\tdoneCallbacks.forEach((callback) => {\n\t\t\tcallback(data);\n\t\t});\n\t}\n\t/**\n\t* Execute next query\n\t*/\n\tfunction execNext() {\n\t\tif (status !== \"pending\") return;\n\t\tresetTimer();\n\t\tconst resource = resources.shift();\n\t\tif (resource === void 0) {\n\t\t\tif (queue.length) {\n\t\t\t\ttimer = setTimeout(() => {\n\t\t\t\t\tresetTimer();\n\t\t\t\t\tif (status === \"pending\") {\n\t\t\t\t\t\tclearQueue();\n\t\t\t\t\t\tfailQuery();\n\t\t\t\t\t}\n\t\t\t\t}, config.timeout);\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tfailQuery();\n\t\t\treturn;\n\t\t}\n\t\tconst item = {\n\t\t\tstatus: \"pending\",\n\t\t\tresource,\n\t\t\tcallback: (status$1, data) => {\n\t\t\t\tmoduleResponse(item, status$1, data);\n\t\t\t}\n\t\t};\n\t\tqueue.push(item);\n\t\tqueriesSent++;\n\t\ttimer = setTimeout(execNext, config.rotate);\n\t\tquery(resource, payload, item.callback);\n\t}\n\tsetTimeout(execNext);\n\treturn getQueryStatus;\n}\n\n/**\n* Redundancy instance\n*/\nfunction initRedundancy(cfg) {\n\tconst config = {\n\t\t...defaultConfig,\n\t\t...cfg\n\t};\n\tlet queries = [];\n\t/**\n\t* Remove aborted and completed queries\n\t*/\n\tfunction cleanup() {\n\t\tqueries = queries.filter((item) => item().status === \"pending\");\n\t}\n\t/**\n\t* Send query\n\t*/\n\tfunction query(payload, queryCallback, doneCallback) {\n\t\tconst query$1 = sendQuery(config, payload, queryCallback, (data, error) => {\n\t\t\tcleanup();\n\t\t\tif (doneCallback) doneCallback(data, error);\n\t\t});\n\t\tqueries.push(query$1);\n\t\treturn query$1;\n\t}\n\t/**\n\t* Find instance\n\t*/\n\tfunction find(callback) {\n\t\treturn queries.find((value) => {\n\t\t\treturn callback(value);\n\t\t}) || null;\n\t}\n\tconst instance = {\n\t\tquery,\n\t\tfind,\n\t\tsetIndex: (index) => {\n\t\t\tconfig.index = index;\n\t\t},\n\t\tgetIndex: () => config.index,\n\t\tcleanup\n\t};\n\treturn instance;\n}\n\nfunction emptyCallback$1() {}\nconst redundancyCache = Object.create(null);\n/**\n* Get Redundancy instance for provider\n*/\nfunction getRedundancyCache(provider) {\n\tif (!redundancyCache[provider]) {\n\t\tconst config = getAPIConfig(provider);\n\t\tif (!config) return;\n\t\tconst redundancy = initRedundancy(config);\n\t\tconst cachedReundancy = {\n\t\t\tconfig,\n\t\t\tredundancy\n\t\t};\n\t\tredundancyCache[provider] = cachedReundancy;\n\t}\n\treturn redundancyCache[provider];\n}\n/**\n* Send API query\n*/\nfunction sendAPIQuery(target, query, callback) {\n\tlet redundancy;\n\tlet send;\n\tif (typeof target === \"string\") {\n\t\tconst api = getAPIModule(target);\n\t\tif (!api) {\n\t\t\tcallback(void 0, 424);\n\t\t\treturn emptyCallback$1;\n\t\t}\n\t\tsend = api.send;\n\t\tconst cached = getRedundancyCache(target);\n\t\tif (cached) redundancy = cached.redundancy;\n\t} else {\n\t\tconst config = createAPIConfig(target);\n\t\tif (config) {\n\t\t\tredundancy = initRedundancy(config);\n\t\t\tconst moduleKey = target.resources ? target.resources[0] : \"\";\n\t\t\tconst api = getAPIModule(moduleKey);\n\t\t\tif (api) send = api.send;\n\t\t}\n\t}\n\tif (!redundancy || !send) {\n\t\tcallback(void 0, 424);\n\t\treturn emptyCallback$1;\n\t}\n\treturn redundancy.query(query, send, callback)().abort;\n}\n\nfunction emptyCallback() {}\n/**\n* Function called when new icons have been loaded\n*/\nfunction loadedNewIcons(storage) {\n\tif (!storage.iconsLoaderFlag) {\n\t\tstorage.iconsLoaderFlag = true;\n\t\tsetTimeout(() => {\n\t\t\tstorage.iconsLoaderFlag = false;\n\t\t\tupdateCallbacks(storage);\n\t\t});\n\t}\n}\n/**\n* Check icon names for API\n*/\nfunction checkIconNamesForAPI(icons) {\n\tconst valid = [];\n\tconst invalid = [];\n\ticons.forEach((name) => {\n\t\t(name.match(matchIconName) ? valid : invalid).push(name);\n\t});\n\treturn {\n\t\tvalid,\n\t\tinvalid\n\t};\n}\n/**\n* Parse loader response\n*/\nfunction parseLoaderResponse(storage, icons, data) {\n\tfunction checkMissing() {\n\t\tconst pending = storage.pendingIcons;\n\t\ticons.forEach((name) => {\n\t\t\tif (pending) pending.delete(name);\n\t\t\tif (!storage.icons[name]) storage.missing.add(name);\n\t\t});\n\t}\n\tif (data && typeof data === \"object\") try {\n\t\tconst parsed = addIconSet(storage, data);\n\t\tif (!parsed.length) {\n\t\t\tcheckMissing();\n\t\t\treturn;\n\t\t}\n\t} catch (err) {\n\t\tconsole.error(err);\n\t}\n\tcheckMissing();\n\tloadedNewIcons(storage);\n}\n/**\n* Handle response that can be async\n*/\nfunction parsePossiblyAsyncResponse(response, callback) {\n\tif (response instanceof Promise) response.then((data) => {\n\t\tcallback(data);\n\t}).catch(() => {\n\t\tcallback(null);\n\t});\n\telse callback(response);\n}\n/**\n* Load icons\n*/\nfunction loadNewIcons(storage, icons) {\n\tif (!storage.iconsToLoad) storage.iconsToLoad = icons;\n\telse storage.iconsToLoad = storage.iconsToLoad.concat(icons).sort();\n\tif (!storage.iconsQueueFlag) {\n\t\tstorage.iconsQueueFlag = true;\n\t\tsetTimeout(() => {\n\t\t\tstorage.iconsQueueFlag = false;\n\t\t\tconst { provider, prefix } = storage;\n\t\t\tconst icons$1 = storage.iconsToLoad;\n\t\t\tdelete storage.iconsToLoad;\n\t\t\tif (!icons$1 || !icons$1.length) return;\n\t\t\tconst customIconLoader = storage.loadIcon;\n\t\t\tif (storage.loadIcons && (icons$1.length > 1 || !customIconLoader)) {\n\t\t\t\tparsePossiblyAsyncResponse(storage.loadIcons(icons$1, prefix, provider), (data) => {\n\t\t\t\t\tparseLoaderResponse(storage, icons$1, data);\n\t\t\t\t});\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tif (customIconLoader) {\n\t\t\t\ticons$1.forEach((name) => {\n\t\t\t\t\tconst response = customIconLoader(name, prefix, provider);\n\t\t\t\t\tparsePossiblyAsyncResponse(response, (data) => {\n\t\t\t\t\t\tconst iconSet = data ? {\n\t\t\t\t\t\t\tprefix,\n\t\t\t\t\t\t\ticons: { [name]: data }\n\t\t\t\t\t\t} : null;\n\t\t\t\t\t\tparseLoaderResponse(storage, [name], iconSet);\n\t\t\t\t\t});\n\t\t\t\t});\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tconst { valid, invalid } = checkIconNamesForAPI(icons$1);\n\t\t\tif (invalid.length) parseLoaderResponse(storage, invalid, null);\n\t\t\tif (!valid.length) return;\n\t\t\tconst api = prefix.match(matchIconName) ? getAPIModule(provider) : null;\n\t\t\tif (!api) {\n\t\t\t\tparseLoaderResponse(storage, valid, null);\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tconst params = api.prepare(provider, prefix, valid);\n\t\t\tparams.forEach((item) => {\n\t\t\t\tsendAPIQuery(provider, item, (data) => {\n\t\t\t\t\tparseLoaderResponse(storage, item.icons, data);\n\t\t\t\t});\n\t\t\t});\n\t\t});\n\t}\n}\n/**\n* Load icons\n*/\nconst loadIcons = (icons, callback) => {\n\tconst cleanedIcons = listToIcons(icons, true, allowSimpleNames());\n\tconst sortedIcons = sortIcons(cleanedIcons);\n\tif (!sortedIcons.pending.length) {\n\t\tlet callCallback = true;\n\t\tif (callback) setTimeout(() => {\n\t\t\tif (callCallback) callback(sortedIcons.loaded, sortedIcons.missing, sortedIcons.pending, emptyCallback);\n\t\t});\n\t\treturn () => {\n\t\t\tcallCallback = false;\n\t\t};\n\t}\n\tconst newIcons = Object.create(null);\n\tconst sources = [];\n\tlet lastProvider, lastPrefix;\n\tsortedIcons.pending.forEach((icon) => {\n\t\tconst { provider, prefix } = icon;\n\t\tif (prefix === lastPrefix && provider === lastProvider) return;\n\t\tlastProvider = provider;\n\t\tlastPrefix = prefix;\n\t\tsources.push(getStorage(provider, prefix));\n\t\tconst providerNewIcons = newIcons[provider] || (newIcons[provider] = Object.create(null));\n\t\tif (!providerNewIcons[prefix]) providerNewIcons[prefix] = [];\n\t});\n\tsortedIcons.pending.forEach((icon) => {\n\t\tconst { provider, prefix, name } = icon;\n\t\tconst storage = getStorage(provider, prefix);\n\t\tconst pendingQueue = storage.pendingIcons || (storage.pendingIcons = /* @__PURE__ */ new Set());\n\t\tif (!pendingQueue.has(name)) {\n\t\t\tpendingQueue.add(name);\n\t\t\tnewIcons[provider][prefix].push(name);\n\t\t}\n\t});\n\tsources.forEach((storage) => {\n\t\tconst list = newIcons[storage.provider][storage.prefix];\n\t\tif (list.length) loadNewIcons(storage, list);\n\t});\n\treturn callback ? storeCallback(callback, sortedIcons, sources) : emptyCallback;\n};\n/**\n* Load one icon using Promise\n*/\nconst loadIcon = (icon) => {\n\treturn new Promise((fulfill, reject) => {\n\t\tconst iconObj = typeof icon === \"string\" ? stringToIcon(icon, true) : icon;\n\t\tif (!iconObj) {\n\t\t\treject(icon);\n\t\t\treturn;\n\t\t}\n\t\tloadIcons([iconObj || icon], (loaded) => {\n\t\t\tif (loaded.length && iconObj) {\n\t\t\t\tconst data = getIconData(iconObj);\n\t\t\t\tif (data) {\n\t\t\t\t\tfulfill({\n\t\t\t\t\t\t...defaultIconProps,\n\t\t\t\t\t\t...data\n\t\t\t\t\t});\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t}\n\t\t\treject(icon);\n\t\t});\n\t});\n};\n\n/**\n* Set custom loader for multiple icons\n*/\nfunction setCustomIconsLoader(loader, prefix, provider) {\n\tgetStorage(provider || \"\", prefix).loadIcons = loader;\n}\n/**\n* Set custom loader for one icon\n*/\nfunction setCustomIconLoader(loader, prefix, provider) {\n\tgetStorage(provider || \"\", prefix).loadIcon = loader;\n}\n\n/**\n* Convert IconifyIconCustomisations to FullIconCustomisations, checking value types\n*/\nfunction mergeCustomisations(defaults, item) {\n\tconst result = { ...defaults };\n\tfor (const key in item) {\n\t\tconst value = item[key];\n\t\tconst valueType = typeof value;\n\t\tif (key in defaultIconSizeCustomisations) {\n\t\t\tif (value === null || value && (valueType === \"string\" || valueType === \"number\")) result[key] = value;\n\t\t} else if (valueType === typeof result[key]) result[key] = key === \"rotate\" ? value % 4 : value;\n\t}\n\treturn result;\n}\n\nconst separator = /[\\s,]+/;\n/**\n* Apply \"flip\" string to icon customisations\n*/\nfunction flipFromString(custom, flip) {\n\tflip.split(separator).forEach((str) => {\n\t\tconst value = str.trim();\n\t\tswitch (value) {\n\t\t\tcase \"horizontal\":\n\t\t\t\tcustom.hFlip = true;\n\t\t\t\tbreak;\n\t\t\tcase \"vertical\":\n\t\t\t\tcustom.vFlip = true;\n\t\t\t\tbreak;\n\t\t}\n\t});\n}\n\n/**\n* Get rotation value\n*/\nfunction rotateFromString(value, defaultValue = 0) {\n\tconst units = value.replace(/^-?[0-9.]*/, \"\");\n\tfunction cleanup(value$1) {\n\t\twhile (value$1 < 0) value$1 += 4;\n\t\treturn value$1 % 4;\n\t}\n\tif (units === \"\") {\n\t\tconst num = parseInt(value);\n\t\treturn isNaN(num) ? 0 : cleanup(num);\n\t} else if (units !== value) {\n\t\tlet split = 0;\n\t\tswitch (units) {\n\t\t\tcase \"%\":\n\t\t\t\tsplit = 25;\n\t\t\t\tbreak;\n\t\t\tcase \"deg\": split = 90;\n\t\t}\n\t\tif (split) {\n\t\t\tlet num = parseFloat(value.slice(0, value.length - units.length));\n\t\t\tif (isNaN(num)) return 0;\n\t\t\tnum = num / split;\n\t\t\treturn num % 1 === 0 ? cleanup(num) : 0;\n\t\t}\n\t}\n\treturn defaultValue;\n}\n\n/**\n* Generate <svg>\n*/\nfunction iconToHTML(body, attributes) {\n\tlet renderAttribsHTML = body.indexOf(\"xlink:\") === -1 ? \"\" : \" xmlns:xlink=\\\"http://www.w3.org/1999/xlink\\\"\";\n\tfor (const attr in attributes) renderAttribsHTML += \" \" + attr + \"=\\\"\" + attributes[attr] + \"\\\"\";\n\treturn \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\"\" + renderAttribsHTML + \">\" + body + \"</svg>\";\n}\n\n/**\n* Encode SVG for use in url()\n*\n* Short alternative to encodeURIComponent() that encodes only stuff used in SVG, generating\n* smaller code.\n*/\nfunction encodeSVGforURL(svg) {\n\treturn svg.replace(/\"/g, \"'\").replace(/%/g, \"%25\").replace(/#/g, \"%23\").replace(/</g, \"%3C\").replace(/>/g, \"%3E\").replace(/\\s+/g, \" \");\n}\n/**\n* Generate data: URL from SVG\n*/\nfunction svgToData(svg) {\n\treturn \"data:image/svg+xml,\" + encodeSVGforURL(svg);\n}\n/**\n* Generate url() from SVG\n*/\nfunction svgToURL(svg) {\n\treturn \"url(\\\"\" + svgToData(svg) + \"\\\")\";\n}\n\nlet policy;\n/**\n* Attempt to create policy\n*/\nfunction createPolicy() {\n\ttry {\n\t\tpolicy = window.trustedTypes.createPolicy(\"iconify\", { createHTML: (s) => s });\n\t} catch (err) {\n\t\tpolicy = null;\n\t}\n}\n/**\n* Clean up value for innerHTML assignment\n*\n* This code doesn't actually clean up anything.\n* It is intended be used with Iconify icon data, which has already been validated\n*/\nfunction cleanUpInnerHTML(html) {\n\tif (policy === void 0) createPolicy();\n\treturn policy ? policy.createHTML(html) : html;\n}\n\nconst defaultExtendedIconCustomisations = {\n ...defaultIconCustomisations,\n inline: false,\n};\n\n/**\n * Default SVG attributes\n */\nconst svgDefaults = {\n 'xmlns': 'http://www.w3.org/2000/svg',\n 'xmlnsXlink': 'http://www.w3.org/1999/xlink',\n 'aria-hidden': true,\n 'role': 'img',\n};\n/**\n * Style modes\n */\nconst commonProps = {\n display: 'inline-block',\n};\nconst monotoneProps = {\n backgroundColor: 'currentColor',\n};\nconst coloredProps = {\n backgroundColor: 'transparent',\n};\n// Dynamically add common props to variables above\nconst propsToAdd = {\n Image: 'var(--svg)',\n Repeat: 'no-repeat',\n Size: '100% 100%',\n};\nconst propsToAddTo = {\n WebkitMask: monotoneProps,\n mask: monotoneProps,\n background: coloredProps,\n};\nfor (const prefix in propsToAddTo) {\n const list = propsToAddTo[prefix];\n for (const prop in propsToAdd) {\n list[prefix + prop] = propsToAdd[prop];\n }\n}\n/**\n * Default values for customisations for inline icon\n */\nconst inlineDefaults = {\n ...defaultExtendedIconCustomisations,\n inline: true,\n};\n/**\n * Fix size: add 'px' to numbers\n */\nfunction fixSize(value) {\n return value + (value.match(/^[-0-9.]+$/) ? 'px' : '');\n}\n/**\n * Render icon\n */\nconst render = (\n// Icon must be validated before calling this function\nicon, \n// Partial properties\nprops, \n// Icon name\nname) => {\n // Get default properties\n const defaultProps = props.inline\n ? inlineDefaults\n : defaultExtendedIconCustomisations;\n // Get all customisations\n const customisations = mergeCustomisations(defaultProps, props);\n // Check mode\n const mode = props.mode || 'svg';\n // Create style\n const style = {};\n const customStyle = props.style || {};\n // Create SVG component properties\n const componentProps = {\n ...(mode === 'svg' ? svgDefaults : {}),\n };\n if (name) {\n const iconName = stringToIcon(name, false, true);\n if (iconName) {\n const classNames = ['iconify'];\n const props = [\n 'provider',\n 'prefix',\n ];\n for (const prop of props) {\n if (iconName[prop]) {\n classNames.push('iconify--' + iconName[prop]);\n }\n }\n componentProps.className = classNames.join(' ');\n }\n }\n // Get element properties\n for (let key in props) {\n const value = props[key];\n if (value === void 0) {\n continue;\n }\n switch (key) {\n // Properties to ignore\n case 'icon':\n case 'style':\n case 'children':\n case 'onLoad':\n case 'mode':\n case 'ssr':\n case 'fallback':\n break;\n // Forward ref\n case '_ref':\n componentProps.ref = value;\n break;\n // Merge class names\n case 'className':\n componentProps[key] =\n (componentProps[key] ? componentProps[key] + ' ' : '') +\n value;\n break;\n // Boolean attributes\n case 'inline':\n case 'hFlip':\n case 'vFlip':\n customisations[key] =\n value === true || value === 'true' || value === 1;\n break;\n // Flip as string: 'horizontal,vertical'\n case 'flip':\n if (typeof value === 'string') {\n flipFromString(customisations, value);\n }\n break;\n // Color: copy to style\n case 'color':\n style.color = value;\n break;\n // Rotation as string\n case 'rotate':\n if (typeof value === 'string') {\n customisations[key] = rotateFromString(value);\n }\n else if (typeof value === 'number') {\n customisations[key] = value;\n }\n break;\n // Remove aria-hidden\n case 'ariaHidden':\n case 'aria-hidden':\n if (value !== true && value !== 'true') {\n delete componentProps['aria-hidden'];\n }\n break;\n // Copy missing property if it does not exist in customisations\n default:\n if (defaultProps[key] === void 0) {\n componentProps[key] = value;\n }\n }\n }\n // Generate icon\n const item = iconToSVG(icon, customisations);\n const renderAttribs = item.attributes;\n // Inline display\n if (customisations.inline) {\n style.verticalAlign = '-0.125em';\n }\n if (mode === 'svg') {\n // Add style\n componentProps.style = {\n ...style,\n ...customStyle,\n };\n // Add icon stuff\n Object.assign(componentProps, renderAttribs);\n // Counter for ids based on \"id\" property to render icons consistently on server and client\n let localCounter = 0;\n let id = props.id;\n if (typeof id === 'string') {\n // Convert '-' to '_' to avoid errors in animations\n id = id.replace(/-/g, '_');\n }\n // Add icon stuff\n componentProps.dangerouslySetInnerHTML = {\n __html: cleanUpInnerHTML(replaceIDs(item.body, id ? () => id + 'ID' + localCounter++ : 'iconifyReact')),\n };\n return createElement('svg', componentProps);\n }\n // Render <span> with style\n const { body, width, height } = icon;\n const useMask = mode === 'mask' ||\n (mode === 'bg' ? false : body.indexOf('currentColor') !== -1);\n // Generate SVG\n const html = iconToHTML(body, {\n ...renderAttribs,\n width: width + '',\n height: height + '',\n });\n // Generate style\n componentProps.style = {\n ...style,\n '--svg': svgToURL(html),\n 'width': fixSize(renderAttribs.width),\n 'height': fixSize(renderAttribs.height),\n ...commonProps,\n ...(useMask ? monotoneProps : coloredProps),\n ...customStyle,\n };\n return createElement('span', componentProps);\n};\n\n/**\n * Initialise stuff\n */\n// Enable short names\nallowSimpleNames(true);\n// Set API module\nsetAPIModule('', fetchAPIModule);\n/**\n * Browser stuff\n */\nif (typeof document !== 'undefined' && typeof window !== 'undefined') {\n const _window = window;\n // Load icons from global \"IconifyPreload\"\n if (_window.IconifyPreload !== void 0) {\n const preload = _window.IconifyPreload;\n const err = 'Invalid IconifyPreload syntax.';\n if (typeof preload === 'object' && preload !== null) {\n (preload instanceof Array ? preload : [preload]).forEach((item) => {\n try {\n if (\n // Check if item is an object and not null/array\n typeof item !== 'object' ||\n item === null ||\n item instanceof Array ||\n // Check for 'icons' and 'prefix'\n typeof item.icons !== 'object' ||\n typeof item.prefix !== 'string' ||\n // Add icon set\n !addCollection(item)) {\n console.error(err);\n }\n }\n catch (e) {\n console.error(err);\n }\n });\n }\n }\n // Set API from global \"IconifyProviders\"\n if (_window.IconifyProviders !== void 0) {\n const providers = _window.IconifyProviders;\n if (typeof providers === 'object' && providers !== null) {\n for (let key in providers) {\n const err = 'IconifyProviders[' + key + '] is invalid.';\n try {\n const value = providers[key];\n if (typeof value !== 'object' ||\n !value ||\n value.resources === void 0) {\n continue;\n }\n if (!addAPIProvider(key, value)) {\n console.error(err);\n }\n }\n catch (e) {\n console.error(err);\n }\n }\n }\n }\n}\nfunction IconComponent(props) {\n const [mounted, setMounted] = useState(!!props.ssr);\n const [abort, setAbort] = useState({});\n // Get initial state\n function getInitialState(mounted) {\n if (mounted) {\n const name = props.icon;\n if (typeof name === 'object') {\n // Icon as object\n return {\n name: '',\n data: name,\n };\n }\n const data = getIconData(name);\n if (data) {\n return {\n name,\n data,\n };\n }\n }\n return {\n name: '',\n };\n }\n const [state, setState] = useState(getInitialState(!!props.ssr));\n // Cancel loading\n function cleanup() {\n const callback = abort.callback;\n if (callback) {\n callback();\n setAbort({});\n }\n }\n // Change state if it is different\n function changeState(newState) {\n if (JSON.stringify(state) !== JSON.stringify(newState)) {\n cleanup();\n setState(newState);\n return true;\n }\n }\n // Update state\n function updateState() {\n var _a;\n const name = props.icon;\n if (typeof name === 'object') {\n // Icon as object\n changeState({\n name: '',\n data: name,\n });\n return;\n }\n // New icon or got icon data\n const data = getIconData(name);\n if (changeState({\n name,\n data,\n })) {\n if (data === undefined) {\n // Load icon, update state when done\n const callback = loadIcons([name], updateState);\n setAbort({\n callback,\n });\n }\n else if (data) {\n // Icon data is available: trigger onLoad callback if present\n (_a = props.onLoad) === null || _a === void 0 ? void 0 : _a.call(props, name);\n }\n }\n }\n // Mounted state, cleanup for loader\n useEffect(() => {\n setMounted(true);\n return cleanup;\n }, []);\n // Icon changed or component mounted\n useEffect(() => {\n if (mounted) {\n updateState();\n }\n }, [props.icon, mounted]);\n // Render icon\n const { name, data } = state;\n if (!data) {\n return props.children\n ? props.children\n : props.fallback\n ? props.fallback\n : createElement('span', {});\n }\n return render({\n ...defaultIconProps,\n ...data,\n }, props, name);\n}\n/**\n * Block icon\n *\n * @param props - Component properties\n */\nconst Icon = forwardRef((props, ref) => IconComponent({\n ...props,\n _ref: ref,\n}));\n/**\n * Inline icon (has negative verticalAlign that makes it behave like icon font)\n *\n * @param props - Component properties\n */\nconst InlineIcon = forwardRef((props, ref) => IconComponent({\n inline: true,\n ...props,\n _ref: ref,\n}));\n/**\n * Internal API\n */\nconst _api = {\n getAPIConfig,\n setAPIModule,\n sendAPIQuery,\n setFetch,\n getFetch,\n listAPIProviders,\n};\n\nexport { Icon, InlineIcon, _api, addAPIProvider, addCollection, addIcon, iconToSVG as buildIcon, calculateSize, getIcon, iconLoaded, listIcons, loadIcon, loadIcons, replaceIDs, setCustomIconLoader, setCustomIconsLoader };\n","import { recipe, type RecipeVariants } from '@vanilla-extract/recipes'\r\n\r\nimport { vars } from '@theme/contract.css.ts'\r\nimport { spinAnimation } from '@constants/animations'\r\n\r\nexport const iconRecipe = recipe({\r\n base: {\r\n display: 'inline-block',\r\n flexShrink: 0,\r\n verticalAlign: 'middle',\r\n fill: 'currentColor',\r\n },\r\n variants: {\r\n size: {\r\n xs: { width: vars.fontSize.xs, height: vars.fontSize.xs }, // 12px\r\n sm: { width: vars.fontSize.sm, height: vars.fontSize.sm }, // 14px\r\n md: { width: vars.fontSize.base, height: vars.fontSize.base }, // 16px\r\n lg: { width: vars.fontSize.xl, height: vars.fontSize.xl }, // 20px\r\n xl: { width: vars.fontSize['2xl'], height: vars.fontSize['2xl'] }, // 24px\r\n '2xl': { width: vars.fontSize['4xl'], height: vars.fontSize['4xl'] }, // 36px\r\n },\r\n spin: {\r\n true: {\r\n animation: `${spinAnimation} 1s linear infinite`,\r\n },\r\n },\r\n },\r\n defaultVariants: {\r\n size: 'md',\r\n },\r\n})\r\n\r\nexport type IconRecipeVariants = NonNullable<RecipeVariants<typeof iconRecipe>>\r\n","import { Icon as Iconify } from '@iconify/react'\r\n\r\nimport { iconRecipe } from '@components/foundation/icon/Icon.css.ts'\r\nimport type { IconProps } from '@components/foundation/icon/types/Icon.props.ts'\r\nimport { vars } from '@theme/contract.css.ts'\r\nimport { cn } from '@utils/cn.ts'\r\nimport type { FC } from 'react'\r\n\r\nconst Icon: FC<IconProps> = ({\r\n icon,\r\n size,\r\n spin,\r\n color,\r\n 'aria-label': ariaLabel,\r\n className,\r\n style,\r\n ...props\r\n}) => {\r\n const isDecorative = ariaLabel === undefined\r\n\r\n return (\r\n <Iconify\r\n icon={icon}\r\n aria-hidden={isDecorative}\r\n aria-label={ariaLabel}\r\n role={isDecorative ? undefined : 'img'}\r\n className={cn(iconRecipe({ size, spin }), className)}\r\n style={color ? { color: vars.color[color], ...style } : style}\r\n {...props}\r\n />\r\n )\r\n}\r\n\r\nIcon.displayName = 'Icon'\r\n\r\nexport default Icon\r\n","import { style } from '@vanilla-extract/css'\r\nimport { recipe, type RecipeVariants } from '@vanilla-extract/recipes'\r\n\r\nimport { vars } from '@theme/contract.css.ts'\r\nimport { cellPaddingBlockVar } from '@components/data-display/table/Table.css.ts'\r\n\r\nexport const tableHeadRecipe = recipe({\r\n base: {\r\n height: '2.75rem',\r\n paddingInline: vars.space.lg,\r\n paddingBlock: cellPaddingBlockVar,\r\n verticalAlign: 'middle',\r\n fontSize: vars.fontSize.xs,\r\n fontWeight: vars.fontWeight.medium,\r\n color: vars.color.mutedForeground,\r\n letterSpacing: vars.letterSpacing.wide,\r\n whiteSpace: 'nowrap',\r\n },\r\n variants: {\r\n align: {\r\n left: { textAlign: 'left' },\r\n center: { textAlign: 'center' },\r\n right: { textAlign: 'right' },\r\n },\r\n },\r\n defaultVariants: { align: 'left' },\r\n})\r\n\r\nexport type TableHeadRecipeVariants = NonNullable<RecipeVariants<typeof tableHeadRecipe>>\r\n\r\n/** Applied when `sortable` is true. Signals the column is interactive. */\r\nexport const tableHeadSortableClass = style({\r\n cursor: 'pointer',\r\n userSelect: 'none',\r\n selectors: {\r\n '&:hover': {\r\n color: vars.color.foreground,\r\n },\r\n '&:focus-visible': {\r\n outline: `2px solid ${vars.color.ring}`,\r\n outlineOffset: '2px',\r\n borderRadius: vars.radius.xs,\r\n },\r\n },\r\n})\r\n\r\n/** Wraps the cell content + sort icon in an inline flex row. */\r\nexport const tableHeadSortWrapperClass = style({\r\n display: 'inline-flex',\r\n alignItems: 'center',\r\n gap: vars.space.xs,\r\n})\r\n\r\n/** Sort icon at rest — muted (used for `sortDirection=\"none\"`). */\r\nexport const tableHeadSortIconClass = style({\r\n flexShrink: 0,\r\n opacity: 0.4,\r\n transition: `opacity ${vars.duration.fast} ${vars.easing.standard}`,\r\n})\r\n\r\n/** Sort icon when a direction is active (`asc` or `desc`). */\r\nexport const tableHeadSortIconActiveClass = style({\r\n opacity: 1,\r\n})\r\n","import type { FC, KeyboardEvent } from 'react'\r\n\r\nimport { Icon } from '@components/foundation/icon'\r\nimport {\r\n tableHeadRecipe,\r\n tableHeadSortableClass,\r\n tableHeadSortWrapperClass,\r\n tableHeadSortIconClass,\r\n tableHeadSortIconActiveClass,\r\n} from '@components/data-display/table/components/table-head/TableHead.css.ts'\r\nimport type { TableHeadProps, TableSortDirection } from '@components/data-display/table/components/table-head/types/TableHead.props.ts'\r\nimport { cn } from '@utils/cn.ts'\r\n\r\nconst SORT_ICONS: Record<TableSortDirection, string> = {\r\n none: 'lucide:arrow-up-down',\r\n asc: 'lucide:arrow-up',\r\n desc: 'lucide:arrow-down',\r\n}\r\n\r\nconst ariaSortMap = {\r\n asc: 'ascending',\r\n desc: 'descending',\r\n none: 'none',\r\n} as const\r\n\r\nconst TableHead: FC<TableHeadProps> = ({\r\n align,\r\n sortable,\r\n sortDirection,\r\n children,\r\n className,\r\n ref,\r\n onKeyDown,\r\n ...props\r\n}) => {\r\n const isActiveSort = sortDirection === 'asc' || sortDirection === 'desc'\r\n\r\n const handleKeyDown = (e: KeyboardEvent<HTMLTableCellElement>) => {\r\n if (sortable && (e.key === 'Enter' || e.key === ' ')) {\r\n e.preventDefault()\r\n e.currentTarget.click()\r\n }\r\n onKeyDown?.(e)\r\n }\r\n\r\n return (\r\n <th\r\n // `scope=\"col\"` is overridable — pass `scope=\"row\"` for row-header cells\r\n scope={'col'}\r\n tabIndex={sortable ? 0 : undefined}\r\n {...props}\r\n ref={ref}\r\n aria-sort={sortDirection ? ariaSortMap[sortDirection] : undefined}\r\n onKeyDown={sortable || onKeyDown ? handleKeyDown : undefined}\r\n className={cn(\r\n tableHeadRecipe({ align }),\r\n sortable && tableHeadSortableClass,\r\n className,\r\n )}\r\n >\r\n {sortDirection !== undefined ? (\r\n <span className={tableHeadSortWrapperClass}>\r\n {children}\r\n <Icon\r\n icon={SORT_ICONS[sortDirection]}\r\n size={'xs'}\r\n className={cn(\r\n tableHeadSortIconClass,\r\n isActiveSort && tableHeadSortIconActiveClass,\r\n )}\r\n />\r\n </span>\r\n ) : (\r\n children\r\n )}\r\n </th>\r\n )\r\n}\r\n\r\nTableHead.displayName = 'TableHead'\r\n\r\nexport default TableHead\r\n","import { style } from '@vanilla-extract/css'\r\nimport { recipe, type RecipeVariants } from '@vanilla-extract/recipes'\r\n\r\nimport { vars } from '@theme/contract.css.ts'\r\nimport { cellPaddingBlockVar } from '@components/data-display/table/Table.css.ts'\r\n\r\nexport const tableCellRecipe = recipe({\r\n base: {\r\n paddingInline: vars.space.lg,\r\n paddingBlock: cellPaddingBlockVar,\r\n verticalAlign: 'middle',\r\n color: vars.color.foreground,\r\n },\r\n variants: {\r\n align: {\r\n left: { textAlign: 'left' },\r\n center: { textAlign: 'center' },\r\n right: { textAlign: 'right' },\r\n },\r\n },\r\n defaultVariants: { align: 'left' },\r\n})\r\n\r\nexport type TableCellRecipeVariants = NonNullable<RecipeVariants<typeof tableCellRecipe>>\r\n\r\n/**\r\n * Enables text truncation inside a cell. The parent column must have a\r\n * constrained width (e.g. via `style={{ maxWidth: '12rem' }}`) for\r\n * `text-overflow: ellipsis` to take effect in a table context.\r\n */\r\nexport const tableCellTruncateClass = style({\r\n overflow: 'hidden',\r\n textOverflow: 'ellipsis',\r\n whiteSpace: 'nowrap',\r\n})\r\n\r\n/**\r\n * Right-aligns content and enables tabular (monospaced) number rendering —\r\n * ideal for numeric columns such as amounts, counts or IDs.\r\n * Overrides the `align` variant when both are applied.\r\n */\r\nexport const tableCellNumericClass = style({\r\n textAlign: 'right',\r\n fontVariantNumeric: 'tabular-nums',\r\n})\r\n","import type { FC } from 'react'\r\n\r\nimport {\r\n tableCellRecipe,\r\n tableCellNumericClass,\r\n tableCellTruncateClass,\r\n} from '@components/data-display/table/components/table-cell/TableCell.css.ts'\r\nimport type { TableCellProps } from '@components/data-display/table/components/table-cell/types/TableCell.props.ts'\r\nimport { cn } from '@utils/cn.ts'\r\n\r\nconst TableCell: FC<TableCellProps> = ({\r\n align,\r\n numeric,\r\n truncate,\r\n className,\r\n ref,\r\n ...props\r\n}) => (\r\n <td\r\n ref={ref}\r\n className={cn(\r\n tableCellRecipe({ align }),\r\n numeric && tableCellNumericClass,\r\n truncate && tableCellTruncateClass,\r\n className,\r\n )}\r\n {...props}\r\n />\r\n)\r\n\r\nTableCell.displayName = 'TableCell'\r\n\r\nexport default TableCell\r\n","import { style } from '@vanilla-extract/css'\r\n\r\nimport { vars } from '@theme/contract.css.ts'\r\n\r\nexport const tableCaptionClass = style({\r\n marginTop: vars.space.sm,\r\n fontSize: vars.fontSize.sm,\r\n color: vars.color.mutedForeground,\r\n textAlign: 'center',\r\n})\r\n","import type { FC } from 'react'\r\n\r\nimport { tableCaptionClass } from '@components/data-display/table/components/table-caption/TableCaption.css.ts'\r\nimport type { TableCaptionProps } from '@components/data-display/table/components/table-caption/types/TableCaption.props.ts'\r\nimport { cn } from '@utils/cn.ts'\r\n\r\nconst TableCaption: FC<TableCaptionProps> = ({ className, ref, ...props }) => (\r\n <caption\r\n ref={ref}\r\n className={cn(tableCaptionClass, className)}\r\n {...props}\r\n />\r\n)\r\n\r\nTableCaption.displayName = 'TableCaption'\r\n\r\nexport default TableCaption\r\n","import type { FC } from 'react'\r\n\r\nimport type { TableColGroupProps } from '@components/data-display/table/components/table-col-group/types/TableColGroup.props.ts'\r\n\r\nconst TableColGroup: FC<TableColGroupProps> = ({ ref, ...props }) => (\r\n <colgroup\r\n ref={ref}\r\n {...props}\r\n />\r\n)\r\n\r\nTableColGroup.displayName = 'TableColGroup'\r\n\r\nexport default TableColGroup\r\n","import type { FC } from 'react'\r\n\r\nimport type { TableColProps } from '@components/data-display/table/components/table-col/types/TableCol.props.ts'\r\n\r\nconst TableCol: FC<TableColProps> = ({ width, minWidth, maxWidth, style, ref, ...props }) => (\r\n <col\r\n ref={ref}\r\n style={{ width, minWidth, maxWidth, ...style }}\r\n {...props}\r\n />\r\n)\r\n\r\nTableCol.displayName = 'TableCol'\r\n\r\nexport default TableCol\r\n","import { recipe, type RecipeVariants } from '@vanilla-extract/recipes'\r\n\r\nimport { vars } from '@theme/contract.css.ts'\r\nimport {\r\n iconReset,\r\n buttonBaseStyles,\r\n sharedButtonVariantVariants,\r\n sharedButtonColorVariants,\r\n sharedButtonCompoundVariants,\r\n sharedButtonDefaultVariants,\r\n} from '@components/actions/_shared/buttons/styles/buttonShared.css.ts'\r\n\r\nexport const buttonRecipe = recipe({\r\n base: [\r\n iconReset,\r\n {\r\n ...buttonBaseStyles,\r\n gap: vars.space.sm,\r\n whiteSpace: 'nowrap',\r\n },\r\n ],\r\n variants: {\r\n variant: sharedButtonVariantVariants,\r\n color: sharedButtonColorVariants,\r\n size: {\r\n sm: {\r\n height: '2.25rem',\r\n paddingInline: vars.space.md,\r\n },\r\n md: {\r\n height: '2.5rem',\r\n paddingInline: vars.space.lg,\r\n paddingBlock: vars.space.sm,\r\n },\r\n lg: {\r\n height: '2.75rem',\r\n paddingInline: vars.space['2xl'],\r\n },\r\n },\r\n },\r\n compoundVariants: sharedButtonCompoundVariants,\r\n defaultVariants: sharedButtonDefaultVariants,\r\n})\r\n\r\nexport type ButtonRecipeVariants = NonNullable<RecipeVariants<typeof buttonRecipe>>\r\n","import { recipe, type RecipeVariants } from '@vanilla-extract/recipes'\r\n\r\nimport { vars } from '@theme/contract.css.ts'\r\n\r\nexport const typographyRecipe = recipe({\r\n base: {\r\n margin: 0,\r\n },\r\n\r\n variants: {\r\n variant: {\r\n h1: {\r\n scrollMarginTop: vars.space['3xl'],\r\n fontSize: vars.fontSize['5xl'],\r\n fontWeight: vars.fontWeight.extrabold,\r\n letterSpacing: vars.letterSpacing.tight,\r\n textWrap: 'balance',\r\n },\r\n h2: {\r\n scrollMarginTop: vars.space['3xl'],\r\n fontSize: vars.fontSize['4xl'],\r\n fontWeight: vars.fontWeight.semibold,\r\n letterSpacing: vars.letterSpacing.tight,\r\n },\r\n h3: {\r\n scrollMarginTop: vars.space['3xl'],\r\n fontSize: vars.fontSize['3xl'],\r\n fontWeight: vars.fontWeight.semibold,\r\n letterSpacing: vars.letterSpacing.tight,\r\n },\r\n h4: {\r\n scrollMarginTop: vars.space['3xl'],\r\n fontSize: vars.fontSize['2xl'],\r\n fontWeight: vars.fontWeight.semibold,\r\n letterSpacing: vars.letterSpacing.tight,\r\n },\r\n h5: {\r\n scrollMarginTop: vars.space['3xl'],\r\n fontSize: vars.fontSize.xl,\r\n fontWeight: vars.fontWeight.semibold,\r\n letterSpacing: vars.letterSpacing.tight,\r\n },\r\n h6: {\r\n scrollMarginTop: vars.space['3xl'],\r\n fontSize: vars.fontSize.base,\r\n fontWeight: vars.fontWeight.semibold,\r\n letterSpacing: vars.letterSpacing.tight,\r\n },\r\n p: {\r\n fontSize: vars.fontSize.base,\r\n lineHeight: vars.lineHeight.loose,\r\n },\r\n span: {},\r\n label: {\r\n fontSize: vars.fontSize.sm,\r\n fontWeight: vars.fontWeight.medium,\r\n lineHeight: vars.lineHeight.none,\r\n },\r\n small: {\r\n fontSize: vars.fontSize.sm,\r\n lineHeight: vars.lineHeight.none,\r\n },\r\n strong: {\r\n fontWeight: vars.fontWeight.bold,\r\n },\r\n em: {\r\n fontStyle: 'italic',\r\n },\r\n blockquote: {\r\n borderLeft: `2px solid ${vars.color.border}`,\r\n paddingLeft: vars.space.xl,\r\n fontStyle: 'italic',\r\n color: vars.color.mutedForeground,\r\n },\r\n pre: {\r\n borderRadius: vars.radius.md,\r\n backgroundColor: vars.color.muted,\r\n padding: vars.space.lg,\r\n fontFamily: vars.fontFamily.mono,\r\n fontSize: vars.fontSize.sm,\r\n overflowX: 'auto',\r\n },\r\n code: {\r\n borderRadius: vars.radius.sm,\r\n backgroundColor: vars.color.muted,\r\n paddingInline: '0.3rem',\r\n paddingBlock: '0.2rem',\r\n fontFamily: vars.fontFamily.mono,\r\n fontSize: vars.fontSize.sm,\r\n fontWeight: vars.fontWeight.semibold,\r\n },\r\n kbd: {\r\n borderRadius: vars.radius.sm,\r\n border: `1px solid ${vars.color.border}`,\r\n backgroundColor: vars.color.muted,\r\n paddingInline: vars.space.sm,\r\n paddingBlock: vars.space.xs,\r\n fontFamily: vars.fontFamily.mono,\r\n fontSize: vars.fontSize.xs,\r\n fontWeight: vars.fontWeight.semibold,\r\n boxShadow: vars.shadow.sm,\r\n },\r\n samp: {\r\n fontFamily: vars.fontFamily.mono,\r\n fontSize: vars.fontSize.sm,\r\n },\r\n abbr: {\r\n textDecoration: 'underline dotted',\r\n cursor: 'help',\r\n },\r\n cite: {\r\n fontStyle: 'italic',\r\n color: vars.color.mutedForeground,\r\n },\r\n mark: {\r\n borderRadius: vars.radius.sm,\r\n backgroundColor: vars.color.highlight,\r\n color: vars.color.highlightForeground,\r\n paddingInline: vars.space.xs,\r\n },\r\n del: {\r\n textDecoration: 'line-through',\r\n opacity: 0.7,\r\n },\r\n ins: {\r\n textDecoration: 'underline',\r\n },\r\n sub: {\r\n fontSize: vars.fontSize.xs,\r\n verticalAlign: 'sub',\r\n },\r\n sup: {\r\n fontSize: vars.fontSize.xs,\r\n verticalAlign: 'super',\r\n },\r\n },\r\n\r\n fontSize: {\r\n xs: { fontSize: vars.fontSize.xs },\r\n sm: { fontSize: vars.fontSize.sm },\r\n base: { fontSize: vars.fontSize.base },\r\n lg: { fontSize: vars.fontSize.lg },\r\n xl: { fontSize: vars.fontSize.xl },\r\n '2xl': { fontSize: vars.fontSize['2xl'] },\r\n '3xl': { fontSize: vars.fontSize['3xl'] },\r\n '4xl': { fontSize: vars.fontSize['4xl'] },\r\n '5xl': { fontSize: vars.fontSize['5xl'] },\r\n '6xl': { fontSize: vars.fontSize['6xl'] },\r\n },\r\n\r\n fontWeight: {\r\n thin: { fontWeight: vars.fontWeight.thin },\r\n extralight: { fontWeight: vars.fontWeight.extralight },\r\n light: { fontWeight: vars.fontWeight.light },\r\n normal: { fontWeight: vars.fontWeight.normal },\r\n medium: { fontWeight: vars.fontWeight.medium },\r\n semibold: { fontWeight: vars.fontWeight.semibold },\r\n bold: { fontWeight: vars.fontWeight.bold },\r\n extrabold: { fontWeight: vars.fontWeight.extrabold },\r\n black: { fontWeight: vars.fontWeight.black },\r\n },\r\n\r\n ellipsis: {\r\n true: {\r\n overflow: 'hidden',\r\n textOverflow: 'ellipsis',\r\n whiteSpace: 'nowrap',\r\n },\r\n },\r\n },\r\n\r\n defaultVariants: {\r\n variant: 'p',\r\n },\r\n})\r\n\r\nexport type TypographyRecipeVariants = NonNullable<RecipeVariants<typeof typographyRecipe>>\r\n","import type { TypographyVariant } from '@components/foundation/typography/types/Typography.types.ts'\r\n\r\nexport const TYPOGRAPHY_ELEMENT_MAP = {\r\n h1: 'h1',\r\n h2: 'h2',\r\n h3: 'h3',\r\n h4: 'h4',\r\n h5: 'h5',\r\n h6: 'h6',\r\n p: 'p',\r\n span: 'span',\r\n label: 'label',\r\n small: 'small',\r\n strong: 'strong',\r\n em: 'em',\r\n blockquote: 'blockquote',\r\n pre: 'pre',\r\n code: 'code',\r\n kbd: 'kbd',\r\n samp: 'samp',\r\n abbr: 'abbr',\r\n cite: 'cite',\r\n mark: 'mark',\r\n del: 'del',\r\n ins: 'ins',\r\n sub: 'sub',\r\n sup: 'sup',\r\n} as const satisfies Record<TypographyVariant, string>\r\n","import { typographyRecipe } from '@components/foundation/typography/Typography.css.ts'\r\nimport { TYPOGRAPHY_ELEMENT_MAP } from '@components/foundation/typography/constants'\r\nimport type { TypographyProps } from '@components/foundation/typography/types/Typography.props.ts'\r\nimport type { TypographyVariant } from '@components/foundation/typography/types/Typography.types.ts'\r\nimport { vars } from '@theme/contract.css.ts'\r\nimport { cn } from '@utils/cn.ts'\r\nimport type { FC } from 'react'\r\n\r\nconst Typography: FC<TypographyProps> = ({\r\n as,\r\n variant,\r\n fontSize,\r\n fontWeight,\r\n color,\r\n ellipsis,\r\n className,\r\n style,\r\n ref,\r\n ...props\r\n}) => {\r\n const Element = as ?? TYPOGRAPHY_ELEMENT_MAP[(variant as TypographyVariant) ?? 'p'] ?? 'p'\r\n\r\n return (\r\n <Element\r\n ref={ref}\r\n className={cn(typographyRecipe({ variant, fontSize, fontWeight, ellipsis }), className)}\r\n style={color ? { color: vars.color[color], ...style } : style}\r\n {...props}\r\n />\r\n )\r\n}\r\n\r\nTypography.displayName = 'Typography'\r\n\r\nexport default Typography\r\n","import type { ButtonSizeShared } from '@components/actions/_shared/buttons/types'\r\nimport type { IconSize } from '@components/foundation/icon'\r\n\r\n/** Size-to-icon-size mapping shared by Button and IconButton. */\r\nexport const buttonSizeToIconSize: Record<NonNullable<ButtonSizeShared>, IconSize> = {\r\n sm: 'sm',\r\n md: 'md',\r\n lg: 'lg',\r\n}\r\n","import type { ButtonSize, TypographySize } from '@components'\r\nimport { buttonSizeToIconSize } from '@components/actions/_shared/buttons/constants'\r\n\r\nexport { buttonSizeToIconSize }\r\n\r\nexport const buttonSizeToFontSize: Record<NonNullable<ButtonSize>, TypographySize> = {\r\n sm: 'sm',\r\n md: 'base',\r\n lg: 'lg',\r\n}\r\n","import { buttonRecipe } from '@components/actions/button/Button.css.ts'\r\nimport { Icon } from '@components/foundation/icon'\r\nimport { Typography } from '@components/foundation/typography'\r\nimport type { ButtonProps } from '@components/actions/button/types/Button.props.ts'\r\nimport { cn } from '@utils/cn.ts'\r\nimport type { FC } from 'react'\r\nimport { buttonSizeToFontSize, buttonSizeToIconSize } from '@components/actions/button/constants'\r\n\r\nconst Button: FC<ButtonProps> = ({\r\n variant,\r\n color,\r\n size = 'md',\r\n className,\r\n label,\r\n startIcon,\r\n endIcon,\r\n ref,\r\n ...props\r\n}) => {\r\n const iconSize = buttonSizeToIconSize[size]\r\n const textSize = buttonSizeToFontSize[size]\r\n\r\n return (\r\n <button\r\n ref={ref}\r\n className={cn(buttonRecipe({ variant, color, size }), className)}\r\n {...props}\r\n >\r\n {startIcon && (\r\n <Icon\r\n icon={startIcon}\r\n size={iconSize}\r\n />\r\n )}\r\n {label && (\r\n <Typography\r\n as={'span'}\r\n variant={'span'}\r\n fontSize={textSize}\r\n fontWeight={'medium'}\r\n >\r\n {label}\r\n </Typography>\r\n )}\r\n {endIcon && (\r\n <Icon\r\n icon={endIcon}\r\n size={iconSize}\r\n />\r\n )}\r\n </button>\r\n )\r\n}\r\n\r\nButton.displayName = 'Button'\r\n\r\nexport default Button\r\n","import { recipe, type RecipeVariants } from '@vanilla-extract/recipes'\r\n\r\nimport {\r\n iconReset,\r\n buttonBaseStyles,\r\n sharedButtonVariantVariants,\r\n sharedButtonColorVariants,\r\n sharedButtonCompoundVariants,\r\n sharedButtonDefaultVariants,\r\n} from '@components/actions/_shared/buttons/styles/buttonShared.css.ts'\r\n\r\nexport const iconButtonRecipe = recipe({\r\n base: [\r\n iconReset,\r\n {\r\n ...buttonBaseStyles,\r\n flexShrink: 0,\r\n },\r\n ],\r\n\r\n variants: {\r\n variant: sharedButtonVariantVariants,\r\n color: sharedButtonColorVariants,\r\n size: {\r\n sm: {\r\n height: '2.25rem',\r\n width: '2.25rem',\r\n },\r\n md: {\r\n height: '2.5rem',\r\n width: '2.5rem',\r\n },\r\n lg: {\r\n height: '2.75rem',\r\n width: '2.75rem',\r\n },\r\n },\r\n },\r\n\r\n compoundVariants: sharedButtonCompoundVariants,\r\n defaultVariants: sharedButtonDefaultVariants,\r\n})\r\n\r\nexport type IconButtonRecipeVariants = NonNullable<RecipeVariants<typeof iconButtonRecipe>>\r\n","import { iconButtonRecipe } from '@components/actions/icon-button/IconButton.css.ts'\r\nimport { Icon } from '@components/foundation/icon'\r\nimport type { IconButtonProps } from '@components/actions/icon-button/types/IconButton.props.ts'\r\nimport { cn } from '@utils/cn.ts'\r\nimport type { FC } from 'react'\r\nimport { iconButtonSizeToIconSize } from '@components/actions/icon-button/constants'\r\n\r\nconst IconButton: FC<IconButtonProps> = ({\r\n variant,\r\n color,\r\n size = 'md',\r\n className,\r\n icon,\r\n ref,\r\n ...props\r\n}) => {\r\n const iconSize = iconButtonSizeToIconSize[size]\r\n\r\n return (\r\n <button\r\n ref={ref}\r\n className={cn(iconButtonRecipe({ variant, color, size }), className)}\r\n {...props}\r\n >\r\n <Icon\r\n icon={icon}\r\n size={iconSize}\r\n />\r\n </button>\r\n )\r\n}\r\n\r\nIconButton.displayName = 'IconButton'\r\n\r\nexport default IconButton\r\n","// 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/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\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","// 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","// 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 }, [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","// 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/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/presence.tsx\nimport * as React2 from \"react\";\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 = useStableComposedRefs(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 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 useStableComposedRefs(...refs) {\n const refsRef = React2.useRef(refs);\n refsRef.current = refs;\n return React2.useCallback((node) => {\n const currentRefs = refsRef.current;\n let hasCleanup = false;\n const cleanups = currentRefs.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(currentRefs[i], null);\n }\n }\n };\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 { useComposedRefs } from \"@radix-ui/react-compose-refs\";\n// @__NO_SIDE_EFFECTS__\nfunction createSlot(ownerName) {\n const Slot2 = React.forwardRef((props, forwardedRef) => {\n let { children, ...slotProps } = props;\n let slottableElement = null;\n let hasSlottable = false;\n const newChildren = [];\n if (isLazyComponent(children) && typeof use === \"function\") {\n children = use(children._payload);\n }\n React.Children.forEach(children, (maybeSlottable) => {\n if (isSlottable(maybeSlottable)) {\n hasSlottable = true;\n const slottable = maybeSlottable;\n let child = \"child\" in slottable.props ? slottable.props.child : slottable.props.children;\n if (isLazyComponent(child) && typeof use === \"function\") {\n child = use(child._payload);\n }\n slottableElement = getSlottableElementFromSlottable(slottable, child);\n newChildren.push(slottableElement?.props?.children);\n } else {\n newChildren.push(maybeSlottable);\n }\n });\n if (slottableElement) {\n slottableElement = React.cloneElement(slottableElement, void 0, newChildren);\n } else if (\n // A `Slottable` was found but it didn't resolve to a single element (e.g.\n // it wrapped multiple elements, text, or a render-prop `child` that\n // wasn't an element). Don't fall back to treating the `Slottable` wrapper\n // itself as the slot target — throw a descriptive error below instead.\n !hasSlottable && React.Children.count(children) === 1 && React.isValidElement(children)\n ) {\n slottableElement = children;\n }\n const slottableElementRef = slottableElement ? getElementRef(slottableElement) : void 0;\n const composedRef = useComposedRefs(forwardedRef, slottableElementRef);\n if (!slottableElement) {\n if (children || children === 0) {\n throw new Error(\n hasSlottable ? createSlottableError(ownerName) : createSlotError(ownerName)\n );\n }\n return children;\n }\n const mergedProps = mergeProps(slotProps, slottableElement.props ?? {});\n if (slottableElement.type !== React.Fragment) {\n mergedProps.ref = forwardedRef ? composedRef : slottableElementRef;\n }\n return React.cloneElement(slottableElement, mergedProps);\n });\n Slot2.displayName = `${ownerName}.Slot`;\n return Slot2;\n}\nvar Slot = /* @__PURE__ */ createSlot(\"Slot\");\nvar SLOTTABLE_IDENTIFIER = Symbol.for(\"radix.slottable\");\n// @__NO_SIDE_EFFECTS__\nfunction createSlottable(ownerName) {\n const Slottable2 = (props) => \"child\" in props ? props.children(props.child) : props.children;\n Slottable2.displayName = `${ownerName}.Slottable`;\n Slottable2.__radixId = SLOTTABLE_IDENTIFIER;\n return Slottable2;\n}\nvar Slottable = /* @__PURE__ */ createSlottable(\"Slottable\");\nvar getSlottableElementFromSlottable = (slottable, child) => {\n if (\"child\" in slottable.props) {\n const child2 = slottable.props.child;\n if (!React.isValidElement(child2)) return null;\n return React.cloneElement(child2, void 0, slottable.props.children(child2.props.children));\n }\n return React.isValidElement(child) ? child : null;\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}\nfunction isSlottable(child) {\n return React.isValidElement(child) && typeof child.type === \"function\" && \"__radixId\" in child.type && child.type.__radixId === SLOTTABLE_IDENTIFIER;\n}\nvar REACT_LAZY_TYPE = Symbol.for(\"react.lazy\");\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}\nfunction isPromiseLike(value) {\n return typeof value === \"object\" && value !== null && \"then\" in value;\n}\nvar createSlotError = (ownerName) => {\n return `${ownerName} failed to slot onto its children. Expected a single React element child or \\`Slottable\\`.`;\n};\nvar createSlottableError = (ownerName) => {\n return `${ownerName} failed to slot onto its \\`Slottable\\`. Expected \\`Slottable\\` to receive a single React element child.`;\n};\nvar use = React[\" use \".trim().toString()];\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","\"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 { recipe, type RecipeVariants } from '@vanilla-extract/recipes'\r\n\r\nexport const flexRecipe = recipe({\r\n base: {\r\n display: 'flex',\r\n },\r\n\r\n variants: {\r\n inline: {\r\n true: { display: 'inline-flex' },\r\n },\r\n\r\n direction: {\r\n row: { flexDirection: 'row' },\r\n column: { flexDirection: 'column' },\r\n 'row-reverse': { flexDirection: 'row-reverse' },\r\n 'column-reverse': { flexDirection: 'column-reverse' },\r\n },\r\n\r\n wrap: {\r\n nowrap: { flexWrap: 'nowrap' },\r\n wrap: { flexWrap: 'wrap' },\r\n 'wrap-reverse': { flexWrap: 'wrap-reverse' },\r\n },\r\n\r\n align: {\r\n start: { alignItems: 'flex-start' },\r\n end: { alignItems: 'flex-end' },\r\n center: { alignItems: 'center' },\r\n stretch: { alignItems: 'stretch' },\r\n baseline: { alignItems: 'baseline' },\r\n },\r\n\r\n justify: {\r\n start: { justifyContent: 'flex-start' },\r\n end: { justifyContent: 'flex-end' },\r\n center: { justifyContent: 'center' },\r\n between: { justifyContent: 'space-between' },\r\n around: { justifyContent: 'space-around' },\r\n evenly: { justifyContent: 'space-evenly' },\r\n stretch: { justifyContent: 'stretch' },\r\n },\r\n },\r\n\r\n defaultVariants: {\r\n direction: 'row',\r\n align: 'center',\r\n },\r\n})\r\n\r\nexport type FlexRecipeVariants = NonNullable<RecipeVariants<typeof flexRecipe>>\r\n","import { recipe, type RecipeVariants } from '@vanilla-extract/recipes'\r\n\r\nimport { vars } from '@theme/contract.css.ts'\r\n\r\nexport const boxRecipe = recipe({\r\n base: {},\r\n\r\n variants: {\r\n // ── Display ──────────────────────────────────────────────────────────────\r\n display: {\r\n block: { display: 'block' },\r\n flex: { display: 'flex' },\r\n 'inline-flex': { display: 'inline-flex' },\r\n inline: { display: 'inline' },\r\n 'inline-block': { display: 'inline-block' },\r\n grid: { display: 'grid' },\r\n 'inline-grid': { display: 'inline-grid' },\r\n none: { display: 'none' },\r\n contents: { display: 'contents' },\r\n 'flow-root': { display: 'flow-root' },\r\n },\r\n\r\n // ── Width ─────────────────────────────────────────────────────────────────\r\n w: {\r\n full: { width: '100%' },\r\n screen: { width: '100vw' },\r\n fit: { width: 'fit-content' },\r\n min: { width: 'min-content' },\r\n max: { width: 'max-content' },\r\n auto: { width: 'auto' },\r\n },\r\n\r\n // ── Height ────────────────────────────────────────────────────────────────\r\n h: {\r\n full: { height: '100%' },\r\n screen: { height: '100vh' },\r\n fit: { height: 'fit-content' },\r\n min: { height: 'min-content' },\r\n max: { height: 'max-content' },\r\n auto: { height: 'auto' },\r\n },\r\n\r\n // ── Overflow ──────────────────────────────────────────────────────────────\r\n overflow: {\r\n visible: { overflow: 'visible' },\r\n hidden: { overflow: 'hidden' },\r\n auto: { overflow: 'auto' },\r\n scroll: { overflow: 'scroll' },\r\n clip: { overflow: 'clip' },\r\n },\r\n\r\n overflowX: {\r\n visible: { overflowX: 'visible' },\r\n hidden: { overflowX: 'hidden' },\r\n auto: { overflowX: 'auto' },\r\n scroll: { overflowX: 'scroll' },\r\n clip: { overflowX: 'clip' },\r\n },\r\n\r\n overflowY: {\r\n visible: { overflowY: 'visible' },\r\n hidden: { overflowY: 'hidden' },\r\n auto: { overflowY: 'auto' },\r\n scroll: { overflowY: 'scroll' },\r\n clip: { overflowY: 'clip' },\r\n },\r\n\r\n // ── Position ──────────────────────────────────────────────────────────────\r\n position: {\r\n static: { position: 'static' },\r\n relative: { position: 'relative' },\r\n absolute: { position: 'absolute' },\r\n fixed: { position: 'fixed' },\r\n sticky: { position: 'sticky' },\r\n },\r\n\r\n // ── Border Radius ─────────────────────────────────────────────────────────\r\n rounded: {\r\n none: { borderRadius: vars.radius.none },\r\n xs: { borderRadius: vars.radius.xs },\r\n sm: { borderRadius: vars.radius.sm },\r\n md: { borderRadius: vars.radius.md },\r\n lg: { borderRadius: vars.radius.lg },\r\n xl: { borderRadius: vars.radius.xl },\r\n '2xl': { borderRadius: vars.radius['2xl'] },\r\n full: { borderRadius: vars.radius.full },\r\n },\r\n\r\n // ── Padding ───────────────────────────────────────────────────────────────\r\n p: {\r\n none: { padding: vars.space.none },\r\n px: { padding: vars.space.px },\r\n xxs: { padding: vars.space.xxs },\r\n xs: { padding: vars.space.xs },\r\n xs2: { padding: vars.space.xs2 },\r\n sm: { padding: vars.space.sm },\r\n md: { padding: vars.space.md },\r\n lg: { padding: vars.space.lg },\r\n xl: { padding: vars.space.xl },\r\n '2xl': { padding: vars.space['2xl'] },\r\n '3xl': { padding: vars.space['3xl'] },\r\n '4xl': { padding: vars.space['4xl'] },\r\n '5xl': { padding: vars.space['5xl'] },\r\n },\r\n\r\n px: {\r\n none: { paddingInline: vars.space.none },\r\n px: { paddingInline: vars.space.px },\r\n xxs: { paddingInline: vars.space.xxs },\r\n xs: { paddingInline: vars.space.xs },\r\n xs2: { paddingInline: vars.space.xs2 },\r\n sm: { paddingInline: vars.space.sm },\r\n md: { paddingInline: vars.space.md },\r\n lg: { paddingInline: vars.space.lg },\r\n xl: { paddingInline: vars.space.xl },\r\n '2xl': { paddingInline: vars.space['2xl'] },\r\n '3xl': { paddingInline: vars.space['3xl'] },\r\n '4xl': { paddingInline: vars.space['4xl'] },\r\n '5xl': { paddingInline: vars.space['5xl'] },\r\n },\r\n\r\n py: {\r\n none: { paddingBlock: vars.space.none },\r\n px: { paddingBlock: vars.space.px },\r\n xxs: { paddingBlock: vars.space.xxs },\r\n xs: { paddingBlock: vars.space.xs },\r\n xs2: { paddingBlock: vars.space.xs2 },\r\n sm: { paddingBlock: vars.space.sm },\r\n md: { paddingBlock: vars.space.md },\r\n lg: { paddingBlock: vars.space.lg },\r\n xl: { paddingBlock: vars.space.xl },\r\n '2xl': { paddingBlock: vars.space['2xl'] },\r\n '3xl': { paddingBlock: vars.space['3xl'] },\r\n '4xl': { paddingBlock: vars.space['4xl'] },\r\n '5xl': { paddingBlock: vars.space['5xl'] },\r\n },\r\n\r\n pt: {\r\n none: { paddingTop: vars.space.none },\r\n px: { paddingTop: vars.space.px },\r\n xxs: { paddingTop: vars.space.xxs },\r\n xs: { paddingTop: vars.space.xs },\r\n xs2: { paddingTop: vars.space.xs2 },\r\n sm: { paddingTop: vars.space.sm },\r\n md: { paddingTop: vars.space.md },\r\n lg: { paddingTop: vars.space.lg },\r\n xl: { paddingTop: vars.space.xl },\r\n '2xl': { paddingTop: vars.space['2xl'] },\r\n '3xl': { paddingTop: vars.space['3xl'] },\r\n '4xl': { paddingTop: vars.space['4xl'] },\r\n '5xl': { paddingTop: vars.space['5xl'] },\r\n },\r\n\r\n pr: {\r\n none: { paddingRight: vars.space.none },\r\n px: { paddingRight: vars.space.px },\r\n xxs: { paddingRight: vars.space.xxs },\r\n xs: { paddingRight: vars.space.xs },\r\n xs2: { paddingRight: vars.space.xs2 },\r\n sm: { paddingRight: vars.space.sm },\r\n md: { paddingRight: vars.space.md },\r\n lg: { paddingRight: vars.space.lg },\r\n xl: { paddingRight: vars.space.xl },\r\n '2xl': { paddingRight: vars.space['2xl'] },\r\n '3xl': { paddingRight: vars.space['3xl'] },\r\n '4xl': { paddingRight: vars.space['4xl'] },\r\n '5xl': { paddingRight: vars.space['5xl'] },\r\n },\r\n\r\n pb: {\r\n none: { paddingBottom: vars.space.none },\r\n px: { paddingBottom: vars.space.px },\r\n xxs: { paddingBottom: vars.space.xxs },\r\n xs: { paddingBottom: vars.space.xs },\r\n xs2: { paddingBottom: vars.space.xs2 },\r\n sm: { paddingBottom: vars.space.sm },\r\n md: { paddingBottom: vars.space.md },\r\n lg: { paddingBottom: vars.space.lg },\r\n xl: { paddingBottom: vars.space.xl },\r\n '2xl': { paddingBottom: vars.space['2xl'] },\r\n '3xl': { paddingBottom: vars.space['3xl'] },\r\n '4xl': { paddingBottom: vars.space['4xl'] },\r\n '5xl': { paddingBottom: vars.space['5xl'] },\r\n },\r\n\r\n pl: {\r\n none: { paddingLeft: vars.space.none },\r\n px: { paddingLeft: vars.space.px },\r\n xxs: { paddingLeft: vars.space.xxs },\r\n xs: { paddingLeft: vars.space.xs },\r\n xs2: { paddingLeft: vars.space.xs2 },\r\n sm: { paddingLeft: vars.space.sm },\r\n md: { paddingLeft: vars.space.md },\r\n lg: { paddingLeft: vars.space.lg },\r\n xl: { paddingLeft: vars.space.xl },\r\n '2xl': { paddingLeft: vars.space['2xl'] },\r\n '3xl': { paddingLeft: vars.space['3xl'] },\r\n '4xl': { paddingLeft: vars.space['4xl'] },\r\n '5xl': { paddingLeft: vars.space['5xl'] },\r\n },\r\n\r\n // ── Margin ────────────────────────────────────────────────────────────────\r\n m: {\r\n auto: { margin: 'auto' },\r\n none: { margin: vars.space.none },\r\n px: { margin: vars.space.px },\r\n xxs: { margin: vars.space.xxs },\r\n xs: { margin: vars.space.xs },\r\n xs2: { margin: vars.space.xs2 },\r\n sm: { margin: vars.space.sm },\r\n md: { margin: vars.space.md },\r\n lg: { margin: vars.space.lg },\r\n xl: { margin: vars.space.xl },\r\n '2xl': { margin: vars.space['2xl'] },\r\n '3xl': { margin: vars.space['3xl'] },\r\n '4xl': { margin: vars.space['4xl'] },\r\n '5xl': { margin: vars.space['5xl'] },\r\n },\r\n\r\n mx: {\r\n auto: { marginInline: 'auto' },\r\n none: { marginInline: vars.space.none },\r\n px: { marginInline: vars.space.px },\r\n xxs: { marginInline: vars.space.xxs },\r\n xs: { marginInline: vars.space.xs },\r\n xs2: { marginInline: vars.space.xs2 },\r\n sm: { marginInline: vars.space.sm },\r\n md: { marginInline: vars.space.md },\r\n lg: { marginInline: vars.space.lg },\r\n xl: { marginInline: vars.space.xl },\r\n '2xl': { marginInline: vars.space['2xl'] },\r\n '3xl': { marginInline: vars.space['3xl'] },\r\n '4xl': { marginInline: vars.space['4xl'] },\r\n '5xl': { marginInline: vars.space['5xl'] },\r\n },\r\n\r\n my: {\r\n auto: { marginBlock: 'auto' },\r\n none: { marginBlock: vars.space.none },\r\n px: { marginBlock: vars.space.px },\r\n xxs: { marginBlock: vars.space.xxs },\r\n xs: { marginBlock: vars.space.xs },\r\n xs2: { marginBlock: vars.space.xs2 },\r\n sm: { marginBlock: vars.space.sm },\r\n md: { marginBlock: vars.space.md },\r\n lg: { marginBlock: vars.space.lg },\r\n xl: { marginBlock: vars.space.xl },\r\n '2xl': { marginBlock: vars.space['2xl'] },\r\n '3xl': { marginBlock: vars.space['3xl'] },\r\n '4xl': { marginBlock: vars.space['4xl'] },\r\n '5xl': { marginBlock: vars.space['5xl'] },\r\n },\r\n\r\n mt: {\r\n auto: { marginTop: 'auto' },\r\n none: { marginTop: vars.space.none },\r\n px: { marginTop: vars.space.px },\r\n xxs: { marginTop: vars.space.xxs },\r\n xs: { marginTop: vars.space.xs },\r\n xs2: { marginTop: vars.space.xs2 },\r\n sm: { marginTop: vars.space.sm },\r\n md: { marginTop: vars.space.md },\r\n lg: { marginTop: vars.space.lg },\r\n xl: { marginTop: vars.space.xl },\r\n '2xl': { marginTop: vars.space['2xl'] },\r\n '3xl': { marginTop: vars.space['3xl'] },\r\n '4xl': { marginTop: vars.space['4xl'] },\r\n '5xl': { marginTop: vars.space['5xl'] },\r\n },\r\n\r\n mr: {\r\n auto: { marginRight: 'auto' },\r\n none: { marginRight: vars.space.none },\r\n px: { marginRight: vars.space.px },\r\n xxs: { marginRight: vars.space.xxs },\r\n xs: { marginRight: vars.space.xs },\r\n xs2: { marginRight: vars.space.xs2 },\r\n sm: { marginRight: vars.space.sm },\r\n md: { marginRight: vars.space.md },\r\n lg: { marginRight: vars.space.lg },\r\n xl: { marginRight: vars.space.xl },\r\n '2xl': { marginRight: vars.space['2xl'] },\r\n '3xl': { marginRight: vars.space['3xl'] },\r\n '4xl': { marginRight: vars.space['4xl'] },\r\n '5xl': { marginRight: vars.space['5xl'] },\r\n },\r\n\r\n mb: {\r\n auto: { marginBottom: 'auto' },\r\n none: { marginBottom: vars.space.none },\r\n px: { marginBottom: vars.space.px },\r\n xxs: { marginBottom: vars.space.xxs },\r\n xs: { marginBottom: vars.space.xs },\r\n xs2: { marginBottom: vars.space.xs2 },\r\n sm: { marginBottom: vars.space.sm },\r\n md: { marginBottom: vars.space.md },\r\n lg: { marginBottom: vars.space.lg },\r\n xl: { marginBottom: vars.space.xl },\r\n '2xl': { marginBottom: vars.space['2xl'] },\r\n '3xl': { marginBottom: vars.space['3xl'] },\r\n '4xl': { marginBottom: vars.space['4xl'] },\r\n '5xl': { marginBottom: vars.space['5xl'] },\r\n },\r\n\r\n ml: {\r\n auto: { marginLeft: 'auto' },\r\n none: { marginLeft: vars.space.none },\r\n px: { marginLeft: vars.space.px },\r\n xxs: { marginLeft: vars.space.xxs },\r\n xs: { marginLeft: vars.space.xs },\r\n xs2: { marginLeft: vars.space.xs2 },\r\n sm: { marginLeft: vars.space.sm },\r\n md: { marginLeft: vars.space.md },\r\n lg: { marginLeft: vars.space.lg },\r\n xl: { marginLeft: vars.space.xl },\r\n '2xl': { marginLeft: vars.space['2xl'] },\r\n '3xl': { marginLeft: vars.space['3xl'] },\r\n '4xl': { marginLeft: vars.space['4xl'] },\r\n '5xl': { marginLeft: vars.space['5xl'] },\r\n },\r\n\r\n // ── Gap (for flex / grid children) ────────────────────────────────────────\r\n gap: {\r\n none: { gap: vars.space.none },\r\n px: { gap: vars.space.px },\r\n xxs: { gap: vars.space.xxs },\r\n xs: { gap: vars.space.xs },\r\n xs2: { gap: vars.space.xs2 },\r\n sm: { gap: vars.space.sm },\r\n md: { gap: vars.space.md },\r\n lg: { gap: vars.space.lg },\r\n xl: { gap: vars.space.xl },\r\n '2xl': { gap: vars.space['2xl'] },\r\n '3xl': { gap: vars.space['3xl'] },\r\n '4xl': { gap: vars.space['4xl'] },\r\n '5xl': { gap: vars.space['5xl'] },\r\n },\r\n\r\n gapX: {\r\n none: { columnGap: vars.space.none },\r\n px: { columnGap: vars.space.px },\r\n xxs: { columnGap: vars.space.xxs },\r\n xs: { columnGap: vars.space.xs },\r\n xs2: { columnGap: vars.space.xs2 },\r\n sm: { columnGap: vars.space.sm },\r\n md: { columnGap: vars.space.md },\r\n lg: { columnGap: vars.space.lg },\r\n xl: { columnGap: vars.space.xl },\r\n '2xl': { columnGap: vars.space['2xl'] },\r\n '3xl': { columnGap: vars.space['3xl'] },\r\n '4xl': { columnGap: vars.space['4xl'] },\r\n '5xl': { columnGap: vars.space['5xl'] },\r\n },\r\n\r\n gapY: {\r\n none: { rowGap: vars.space.none },\r\n px: { rowGap: vars.space.px },\r\n xxs: { rowGap: vars.space.xxs },\r\n xs: { rowGap: vars.space.xs },\r\n xs2: { rowGap: vars.space.xs2 },\r\n sm: { rowGap: vars.space.sm },\r\n md: { rowGap: vars.space.md },\r\n lg: { rowGap: vars.space.lg },\r\n xl: { rowGap: vars.space.xl },\r\n '2xl': { rowGap: vars.space['2xl'] },\r\n '3xl': { rowGap: vars.space['3xl'] },\r\n '4xl': { rowGap: vars.space['4xl'] },\r\n '5xl': { rowGap: vars.space['5xl'] },\r\n },\r\n\r\n // ── Background Color ──────────────────────────────────────────────────────\r\n bg: {\r\n transparent: { background: 'transparent' },\r\n background: { background: vars.color.background },\r\n card: { background: vars.color.card },\r\n muted: { background: vars.color.muted },\r\n primary: { background: vars.color.primary },\r\n primarySubtle: { background: vars.color.primarySubtle },\r\n secondary: { background: vars.color.secondary },\r\n secondarySubtle: { background: vars.color.secondarySubtle },\r\n success: { background: vars.color.success },\r\n successSubtle: { background: vars.color.successSubtle },\r\n warning: { background: vars.color.warning },\r\n warningSubtle: { background: vars.color.warningSubtle },\r\n info: { background: vars.color.info },\r\n infoSubtle: { background: vars.color.infoSubtle },\r\n destructive: { background: vars.color.destructive },\r\n destructiveSubtle: { background: vars.color.destructiveSubtle },\r\n },\r\n },\r\n})\r\n\r\nexport type BoxRecipeVariants = NonNullable<RecipeVariants<typeof boxRecipe>>\r\n","import { boxRecipe } from '@components/layout/box/Box.css.ts'\r\nimport type { BoxProps } from '@components/layout/box/types/Box.props.ts'\r\nimport { cn } from '@utils/cn.ts'\r\nimport type { FC } from 'react'\r\n\r\nconst Box: FC<BoxProps> = ({\r\n as: Element = 'div',\r\n display,\r\n w,\r\n h,\r\n overflow,\r\n overflowX,\r\n overflowY,\r\n position,\r\n rounded,\r\n p,\r\n px,\r\n py,\r\n pt,\r\n pr,\r\n pb,\r\n pl,\r\n m,\r\n mx,\r\n my,\r\n mt,\r\n mr,\r\n mb,\r\n ml,\r\n gap,\r\n gapX,\r\n gapY,\r\n bg,\r\n className,\r\n ref,\r\n ...props\r\n}) => {\r\n return (\r\n <Element\r\n ref={ref}\r\n className={cn(\r\n boxRecipe({\r\n display,\r\n w,\r\n h,\r\n overflow,\r\n overflowX,\r\n overflowY,\r\n position,\r\n rounded,\r\n p,\r\n px,\r\n py,\r\n pt,\r\n pr,\r\n pb,\r\n pl,\r\n m,\r\n mx,\r\n my,\r\n mt,\r\n mr,\r\n mb,\r\n ml,\r\n gap,\r\n gapX,\r\n gapY,\r\n bg,\r\n }),\r\n className,\r\n )}\r\n {...props}\r\n />\r\n )\r\n}\r\n\r\nBox.displayName = 'Box'\r\n\r\nexport default Box\r\n","import { flexRecipe } from '@components/layout/flex/Flex.css.ts'\r\nimport type { FlexProps } from '@components/layout/flex/types/Flex.props.ts'\r\nimport { cn } from '@utils/cn.ts'\r\nimport type { FC } from 'react'\r\n\r\nimport Box from '@components/layout/box/Box.tsx'\r\n\r\nconst Flex: FC<FlexProps> = ({\r\n direction,\r\n wrap,\r\n align,\r\n justify,\r\n inline,\r\n gap = 'sm',\r\n className,\r\n ...props\r\n}) => {\r\n return (\r\n <Box\r\n gap={gap}\r\n className={cn(flexRecipe({ direction, wrap, align, justify, inline }), className)}\r\n {...props}\r\n />\r\n )\r\n}\r\n\r\nFlex.displayName = 'Flex'\r\n\r\nexport default Flex\r\n","import { style, globalStyle } from '@vanilla-extract/css'\r\nimport { vars } from '@theme/contract.css.ts'\r\n/**\r\n * Root element — the visible box (applied on `Checkbox.Root`, a `<button>`).\r\n *\r\n * Dual-context design:\r\n * - **Standalone** (`Checkbox` component): `data-state` / `data-disabled` live\r\n * on this element itself → self-selectors `&[...]` apply.\r\n * - **Dropdown** (`DropdownMenuCheckboxItem`): this class is re-used on the\r\n * `<span>` indicator inside the item. The parent item carries `data-state` /\r\n * `data-highlighted` / `data-disabled` → ancestor selectors `[...] &` apply.\r\n *\r\n * Both selector sets coexist without conflict:\r\n * - In standalone context the span/button is `data-state` itself → only `&[...]`.\r\n * - In dropdown context the span never has `data-state` → only `[...] &`.\r\n */\r\nexport const checkboxRootClass = style({\r\n flexShrink: 0,\r\n width: '1rem',\r\n height: '1rem',\r\n borderRadius: vars.radius.xs,\r\n border: `1.5px solid ${vars.color.input}`,\r\n padding: 0,\r\n display: 'flex',\r\n alignItems: 'center',\r\n justifyContent: 'center',\r\n color: 'transparent',\r\n backgroundColor: 'transparent',\r\n cursor: 'pointer',\r\n outline: 'none',\r\n transition: [\r\n `background-color ${vars.duration.fast} ${vars.easing.standard}`,\r\n `border-color ${vars.duration.fast} ${vars.easing.standard}`,\r\n `color ${vars.duration.fast} ${vars.easing.standard}`,\r\n `box-shadow ${vars.duration.fast} ${vars.easing.standard}`,\r\n ].join(', '),\r\n selectors: {\r\n /* Standalone: hover (only when NOT disabled) */\r\n '&:not([data-disabled]):hover': {\r\n borderColor: vars.color.primaryHover,\r\n backgroundColor: vars.color.primarySubtle,\r\n },\r\n /* Standalone: active (only when NOT disabled) */\r\n '&:not([data-disabled]):active': {\r\n borderColor: vars.color.primaryActive,\r\n backgroundColor: vars.color.primarySubtleActive,\r\n },\r\n /* Standalone: focus ring */\r\n '&:focus-visible': {\r\n outline: 'none',\r\n boxShadow: `0 0 0 2px ${vars.color.background}, 0 0 0 4px ${vars.color.ring}`,\r\n },\r\n /* Standalone: checked */\r\n '&[data-state=\"checked\"]': {\r\n backgroundColor: vars.color.primary,\r\n borderColor: vars.color.primary,\r\n color: vars.color.primaryForeground,\r\n },\r\n /* Standalone: checked + hover (only when NOT disabled) */\r\n '&[data-state=\"checked\"]:not([data-disabled]):hover': {\r\n backgroundColor: vars.color.primaryHover,\r\n borderColor: vars.color.primaryHover,\r\n },\r\n /* Standalone: checked + active (only when NOT disabled) */\r\n '&[data-state=\"checked\"]:not([data-disabled]):active': {\r\n backgroundColor: vars.color.primaryActive,\r\n borderColor: vars.color.primaryActive,\r\n },\r\n /* Standalone: disabled */\r\n '&[data-disabled]': {\r\n cursor: 'not-allowed',\r\n opacity: 0.45,\r\n },\r\n /* Dropdown: highlighted parent */\r\n '[data-highlighted] &': {\r\n borderColor: vars.color.primaryHover,\r\n backgroundColor: vars.color.primarySubtle,\r\n },\r\n /* Dropdown: checked parent */\r\n '[data-state=\"checked\"] &': {\r\n backgroundColor: vars.color.primary,\r\n borderColor: vars.color.primary,\r\n color: vars.color.primaryForeground,\r\n },\r\n /* Dropdown: checked + highlighted parent */\r\n '[data-state=\"checked\"][data-highlighted] &': {\r\n backgroundColor: vars.color.primaryHover,\r\n borderColor: vars.color.primaryHover,\r\n },\r\n /* Dropdown: disabled parent — neutralize hover on span */\r\n '[data-disabled] &': {\r\n cursor: 'not-allowed',\r\n pointerEvents: 'none',\r\n },\r\n },\r\n})\r\n/**\r\n * Indicator slot — keeps the check icon centred.\r\n * `color: inherit` picks up the `primaryForeground` set on the root when checked.\r\n */\r\nexport const checkboxIndicatorClass = style({\r\n display: 'flex',\r\n alignItems: 'center',\r\n justifyContent: 'center',\r\n color: 'inherit',\r\n})\r\n/** Typography label associated with the checkbox control. */\r\nexport const checkboxLabelClass = style({\r\n cursor: 'pointer',\r\n userSelect: 'none',\r\n selectors: {\r\n /* Mirrors disabled opacity when the paired checkbox is disabled */\r\n '[data-disabled] ~ &': {\r\n cursor: 'not-allowed',\r\n opacity: 0.45,\r\n },\r\n },\r\n})\r\nglobalStyle(`${checkboxRootClass} svg`, {\r\n width: '0.625rem',\r\n height: '0.625rem',\r\n pointerEvents: 'none',\r\n})\r\n","import * as RadixCheckbox from '@radix-ui/react-checkbox'\r\nimport { useId, type FC } from 'react'\r\n\r\nimport { Icon } from '@components/foundation/icon'\r\nimport { Typography } from '@components/foundation/typography'\r\nimport { Flex } from '@components/layout/flex'\r\nimport { cn } from '@utils/cn.ts'\r\nimport {\r\n checkboxRootClass,\r\n checkboxIndicatorClass,\r\n checkboxLabelClass,\r\n} from '@components/forms/checkbox/Checkbox.css.ts'\r\nimport type { CheckboxProps } from '@components/forms/checkbox/types/Checkbox.props.ts'\r\n\r\n/**\r\n * A styled checkbox control built on top of `@radix-ui/react-checkbox`.\r\n *\r\n * Supports controlled (`checked` + `onCheckedChange`) and uncontrolled\r\n * (`defaultChecked`) modes, plus an optional inline `label`.\r\n *\r\n * @example\r\n * ```tsx\r\n * <Checkbox label=\"Accept terms\" checked={accepted} onCheckedChange={setAccepted} />\r\n * ```\r\n */\r\nconst Checkbox: FC<CheckboxProps> = ({ label, id, className, ...props }) => {\r\n const generatedId = useId()\r\n const checkboxId = id ?? (label ? generatedId : undefined)\r\n\r\n return (\r\n <Flex\r\n as={'span'}\r\n inline\r\n gap={'sm'}\r\n >\r\n <RadixCheckbox.Root\r\n id={checkboxId}\r\n className={cn(checkboxRootClass, className)}\r\n {...props}\r\n >\r\n <RadixCheckbox.Indicator className={checkboxIndicatorClass}>\r\n <Icon\r\n icon={'mdi:check'}\r\n size={'xs'}\r\n />\r\n </RadixCheckbox.Indicator>\r\n </RadixCheckbox.Root>\r\n\r\n {label && (\r\n <Typography\r\n as={'label'}\r\n variant={'label'}\r\n color={'foreground'}\r\n htmlFor={checkboxId}\r\n className={checkboxLabelClass}\r\n >\r\n {label}\r\n </Typography>\r\n )}\r\n </Flex>\r\n )\r\n}\r\n\r\nCheckbox.displayName = 'Checkbox'\r\n\r\nexport default Checkbox\r\n","\"use client\";\n\n// src/collection-legacy.tsx\nimport * as 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 * as 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","// 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","// 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","\"use client\";\n\n// 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","\"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/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 { Fragment, jsx, jsxs } from \"react/jsx-runtime\";\nvar RADIO_NAME = \"Radio\";\nvar [createRadioContext, createRadioScope] = createContextScope(RADIO_NAME);\nvar [RadioProviderImpl, useRadioContext] = createRadioContext(RADIO_NAME);\nfunction RadioProvider(props) {\n const {\n __scopeRadio,\n checked = false,\n children,\n disabled,\n form,\n name,\n onCheck,\n required,\n value = \"on\",\n // @ts-expect-error\n internal_do_not_use_render\n } = props;\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 required,\n name,\n form,\n value,\n control,\n setControl,\n hasConsumerStoppedPropagationRef,\n isFormControl,\n bubbleInput,\n setBubbleInput,\n onCheck: () => onCheck?.()\n };\n return /* @__PURE__ */ jsx(RadioProviderImpl, { scope: __scopeRadio, ...context, children: isFunction(internal_do_not_use_render) ? internal_do_not_use_render(context) : children });\n}\nvar TRIGGER_NAME = \"RadioTrigger\";\nvar RadioTrigger = React.forwardRef(\n ({ __scopeRadio, onClick, ...radioProps }, forwardedRef) => {\n const {\n checked,\n disabled,\n value,\n setControl,\n onCheck,\n hasConsumerStoppedPropagationRef,\n isFormControl,\n bubbleInput\n } = useRadioContext(TRIGGER_NAME, __scopeRadio);\n const composedRefs = useComposedRefs(forwardedRef, setControl);\n return /* @__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(onClick, (event) => {\n if (!checked) onCheck();\n if (bubbleInput && isFormControl) {\n hasConsumerStoppedPropagationRef.current = event.isPropagationStopped();\n if (!hasConsumerStoppedPropagationRef.current) event.stopPropagation();\n }\n })\n }\n );\n }\n);\nRadioTrigger.displayName = TRIGGER_NAME;\nvar Radio = React.forwardRef(\n (props, forwardedRef) => {\n const { __scopeRadio, name, checked, required, disabled, value, onCheck, form, ...radioProps } = props;\n return /* @__PURE__ */ jsx(\n RadioProvider,\n {\n __scopeRadio,\n checked,\n disabled,\n required,\n onCheck,\n name,\n form,\n value,\n internal_do_not_use_render: ({ isFormControl }) => /* @__PURE__ */ jsxs(Fragment, { children: [\n /* @__PURE__ */ jsx(\n RadioTrigger,\n {\n ...radioProps,\n ref: forwardedRef,\n __scopeRadio\n }\n ),\n isFormControl && /* @__PURE__ */ jsx(\n RadioBubbleInput,\n {\n __scopeRadio\n }\n )\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 ({ __scopeRadio, ...props }, forwardedRef) => {\n const {\n control,\n checked,\n required,\n disabled,\n name,\n value,\n form,\n bubbleInput,\n setBubbleInput,\n hasConsumerStoppedPropagationRef\n } = useRadioContext(BUBBLE_INPUT_NAME, __scopeRadio);\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 setChecked.call(input, checked);\n input.dispatchEvent(event);\n }\n }, [bubbleInput, prevChecked, checked, hasConsumerStoppedPropagationRef]);\n const defaultCheckedRef = React.useRef(checked);\n return /* @__PURE__ */ jsx(\n Primitive.input,\n {\n type: \"radio\",\n \"aria-hidden\": true,\n 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);\nRadioBubbleInput.displayName = BUBBLE_INPUT_NAME;\nfunction isFunction(value) {\n return typeof value === \"function\";\n}\nfunction getState(checked) {\n return checked ? \"checked\" : \"unchecked\";\n}\n\n// src/radio-group.tsx\nimport { Fragment as Fragment2, jsx as jsx2, jsxs as jsxs2 } 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 ITEM_PROVIDER_NAME = \"RadioGroupItemProvider\";\nvar ITEM_TRIGGER_NAME = \"RadioGroupItemTrigger\";\nvar ITEM_BUBBLE_INPUT_NAME = \"RadioGroupItemBubbleInput\";\nfunction RadioGroupItemProvider(props) {\n const {\n __scopeRadioGroup,\n value,\n disabled,\n children,\n // @ts-expect-error\n internal_do_not_use_render\n } = props;\n const context = useRadioGroupContext(ITEM_PROVIDER_NAME, __scopeRadioGroup);\n const radioScope = useRadioScope(__scopeRadioGroup);\n const isDisabled = context.disabled || disabled;\n return /* @__PURE__ */ jsx2(\n RadioProvider,\n {\n ...radioScope,\n checked: context.value === value,\n disabled: isDisabled,\n required: context.required,\n name: context.name,\n value,\n onCheck: () => context.onValueChange(value),\n internal_do_not_use_render,\n children\n }\n );\n}\nvar RadioGroupItemTrigger = React2.forwardRef((props, forwardedRef) => {\n const { __scopeRadioGroup, ...triggerProps } = props;\n const rovingFocusGroupScope = useRovingFocusGroupScope(__scopeRadioGroup);\n const radioScope = useRadioScope(__scopeRadioGroup);\n const { checked, disabled } = useRadioContext(ITEM_TRIGGER_NAME, radioScope.__scopeRadio);\n const ref = React2.useRef(null);\n const composedRefs = useComposedRefs2(forwardedRef, ref);\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: !disabled,\n active: checked,\n children: /* @__PURE__ */ jsx2(\n RadioTrigger,\n {\n ...radioScope,\n ...triggerProps,\n ref: composedRefs,\n onKeyDown: composeEventHandlers2(triggerProps.onKeyDown, (event) => {\n if (event.key === \"Enter\") event.preventDefault();\n }),\n onFocus: composeEventHandlers2(triggerProps.onFocus, () => {\n if (isArrowKeyPressedRef.current) {\n ref.current?.click();\n }\n })\n }\n )\n }\n );\n});\nRadioGroupItemTrigger.displayName = ITEM_TRIGGER_NAME;\nvar RadioGroupItem = React2.forwardRef(\n (props, forwardedRef) => {\n const { __scopeRadioGroup, value, disabled, ...itemProps } = props;\n return /* @__PURE__ */ jsx2(\n RadioGroupItemProvider,\n {\n __scopeRadioGroup,\n value,\n disabled,\n internal_do_not_use_render: ({ isFormControl }) => /* @__PURE__ */ jsxs2(Fragment2, { children: [\n /* @__PURE__ */ jsx2(\n RadioGroupItemTrigger,\n {\n ...itemProps,\n ref: forwardedRef,\n __scopeRadioGroup\n }\n ),\n isFormControl && /* @__PURE__ */ jsx2(\n RadioGroupItemBubbleInput,\n {\n __scopeRadioGroup\n }\n )\n ] })\n }\n );\n }\n);\nRadioGroupItem.displayName = ITEM_NAME;\nvar RadioGroupItemBubbleInput = React2.forwardRef((props, forwardedRef) => {\n const { __scopeRadioGroup, ...bubbleProps } = props;\n const radioScope = useRadioScope(__scopeRadioGroup);\n return /* @__PURE__ */ jsx2(RadioBubbleInput, { ...radioScope, ...bubbleProps, ref: forwardedRef });\n});\nRadioGroupItemBubbleInput.displayName = ITEM_BUBBLE_INPUT_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;\nexport {\n RadioGroupIndicator as Indicator,\n RadioGroupItem as Item,\n RadioGroup,\n RadioGroupIndicator,\n RadioGroupItem,\n RadioGroup as Root,\n createRadioGroupScope,\n RadioGroupItemBubbleInput as unstable_ItemBubbleInput,\n RadioGroupItemProvider as unstable_ItemProvider,\n RadioGroupItemTrigger as unstable_ItemTrigger,\n RadioGroupItemBubbleInput as unstable_RadioGroupItemBubbleInput,\n RadioGroupItemProvider as unstable_RadioGroupItemProvider,\n RadioGroupItemTrigger as unstable_RadioGroupItemTrigger\n};\n//# sourceMappingURL=index.mjs.map\n","import * as RadixRadioGroup from '@radix-ui/react-radio-group'\r\nimport type { FC } from 'react'\r\n\r\nimport { Flex } from '@components/layout/flex'\r\nimport type { RadioGroupProps } from '@components/forms/radio-group/types/RadioGroup.props.ts'\r\n\r\n/**\r\n * The root container for a group of `RadioItem` components.\r\n * Manages the single-selection state.\r\n *\r\n * @example\r\n * ```tsx\r\n * <RadioGroup value={value} onValueChange={setValue}>\r\n * <RadioItem value=\"a\" label=\"Option A\" />\r\n * <RadioItem value=\"b\" label=\"Option B\" />\r\n * </RadioGroup>\r\n * ```\r\n */\r\nconst RadioGroup: FC<RadioGroupProps> = ({ className, children, ...props }) => (\r\n <RadixRadioGroup.Root\r\n asChild\r\n {...props}\r\n >\r\n <Flex\r\n direction={'column'}\r\n gap={'sm'}\r\n align={'start'}\r\n className={className}\r\n >\r\n {children}\r\n </Flex>\r\n </RadixRadioGroup.Root>\r\n)\r\n\r\nRadioGroup.displayName = 'RadioGroup'\r\n\r\nexport default RadioGroup\r\n","import { style, globalStyle } from '@vanilla-extract/css'\r\nimport { vars } from '@theme/contract.css.ts'\r\n\r\n/**\r\n * RadioGroup.Item root — the circular button (applied on `RadioGroup.Item`, a `<button>`).\r\n *\r\n * Dual-context design — mirrors `checkboxRootClass`:\r\n * - **Standalone** (`RadioItem` component): self-selectors `&[...]` apply.\r\n * - **Dropdown** (`DropdownMenuRadioItem`): this class is re-used on the\r\n * `<span>` indicator. Ancestor selectors `[...] &` apply.\r\n */\r\nexport const radioItemRootClass = style({\r\n flexShrink: 0,\r\n width: '1rem',\r\n height: '1rem',\r\n borderRadius: vars.radius.full,\r\n border: `1.5px solid ${vars.color.input}`,\r\n padding: 0,\r\n display: 'flex',\r\n alignItems: 'center',\r\n justifyContent: 'center',\r\n color: 'transparent',\r\n backgroundColor: 'transparent',\r\n cursor: 'pointer',\r\n outline: 'none',\r\n transition: [\r\n `background-color ${vars.duration.fast} ${vars.easing.standard}`,\r\n `border-color ${vars.duration.fast} ${vars.easing.standard}`,\r\n `color ${vars.duration.fast} ${vars.easing.standard}`,\r\n `box-shadow ${vars.duration.fast} ${vars.easing.standard}`,\r\n ].join(', '),\r\n selectors: {\r\n /* ── Standalone: hover (only when NOT disabled) ─────────── */\r\n '&:not([data-disabled]):hover': {\r\n borderColor: vars.color.primaryHover,\r\n backgroundColor: vars.color.primarySubtle,\r\n },\r\n /* ── Standalone: active (only when NOT disabled) ────────── */\r\n '&:not([data-disabled]):active': {\r\n borderColor: vars.color.primaryActive,\r\n backgroundColor: vars.color.primarySubtleActive,\r\n },\r\n /* ── Standalone: focus ring ──────────────────────────────── */\r\n '&:focus-visible': {\r\n outline: 'none',\r\n boxShadow: `0 0 0 2px ${vars.color.background}, 0 0 0 4px ${vars.color.ring}`,\r\n },\r\n /* ── Standalone: checked ─────────────────────────────────── */\r\n '&[data-state=\"checked\"]': {\r\n backgroundColor: vars.color.primary,\r\n borderColor: vars.color.primary,\r\n color: vars.color.primaryForeground,\r\n },\r\n /* ── Standalone: checked + hover (only when NOT disabled) ── */\r\n '&[data-state=\"checked\"]:not([data-disabled]):hover': {\r\n backgroundColor: vars.color.primaryHover,\r\n borderColor: vars.color.primaryHover,\r\n },\r\n /* ── Standalone: checked + active (only when NOT disabled) ── */\r\n '&[data-state=\"checked\"]:not([data-disabled]):active': {\r\n backgroundColor: vars.color.primaryActive,\r\n borderColor: vars.color.primaryActive,\r\n },\r\n /* ── Standalone: disabled ────────────────────────────────── */\r\n '&[data-disabled]': {\r\n cursor: 'not-allowed',\r\n opacity: 0.45,\r\n },\r\n /* ── Dropdown: highlighted parent ────────────────────────── */\r\n '[data-highlighted] &': {\r\n borderColor: vars.color.primaryHover,\r\n backgroundColor: vars.color.primarySubtle,\r\n },\r\n /* ── Dropdown: checked parent ────────────────────────────── */\r\n '[data-state=\"checked\"] &': {\r\n backgroundColor: vars.color.primary,\r\n borderColor: vars.color.primary,\r\n color: vars.color.primaryForeground,\r\n },\r\n /* ── Dropdown: checked + highlighted parent ──────────────── */\r\n '[data-state=\"checked\"][data-highlighted] &': {\r\n backgroundColor: vars.color.primaryHover,\r\n borderColor: vars.color.primaryHover,\r\n },\r\n /* ── Dropdown: disabled parent — neutralise hover on span ── */\r\n '[data-disabled] &': {\r\n cursor: 'not-allowed',\r\n pointerEvents: 'none',\r\n },\r\n },\r\n})\r\n\r\n/**\r\n * Indicator slot inside the circle.\r\n * `color: inherit` picks up `primaryForeground` from the checked root.\r\n */\r\nexport const radioIndicatorClass = style({\r\n display: 'flex',\r\n alignItems: 'center',\r\n justifyContent: 'center',\r\n color: 'inherit',\r\n})\r\n\r\n/** Typography label associated with the radio button. */\r\nexport const radioItemLabelClass = style({\r\n cursor: 'pointer',\r\n userSelect: 'none',\r\n selectors: {\r\n '[data-disabled] ~ &': {\r\n cursor: 'not-allowed',\r\n opacity: 0.45,\r\n },\r\n },\r\n})\r\n\r\nglobalStyle(`${radioItemRootClass} svg`, {\r\n width: '0.5rem',\r\n height: '0.5rem',\r\n pointerEvents: 'none',\r\n})\r\n","import * as RadixRadioGroup from '@radix-ui/react-radio-group'\r\nimport { useId, type FC } from 'react'\r\n\r\nimport { Icon } from '@components/foundation/icon'\r\nimport { Typography } from '@components/foundation/typography'\r\nimport { Flex } from '@components/layout/flex'\r\nimport { cn } from '@utils/cn.ts'\r\nimport {\r\n radioItemRootClass,\r\n radioIndicatorClass,\r\n radioItemLabelClass,\r\n} from '@components/forms/radio-group/components/radio-item/RadioItem.css.ts'\r\nimport type { RadioItemProps } from '@components/forms/radio-group/components/radio-item/types/RadioItem.props.ts'\r\n\r\n/**\r\n * A single radio button inside a `RadioGroup`.\r\n * Renders a circular indicator that fills with the primary colour when selected.\r\n *\r\n * @example\r\n * ```tsx\r\n * <RadioItem value=\"dark\" label=\"Dark mode\" />\r\n * ```\r\n */\r\nconst RadioItem: FC<RadioItemProps> = ({ label, id, className, value, ...props }) => {\r\n const generatedId = useId()\r\n const radioId = id ?? (label ? generatedId : undefined)\r\n\r\n return (\r\n <Flex\r\n as={'span'}\r\n inline\r\n gap={'sm'}\r\n >\r\n <RadixRadioGroup.Item\r\n id={radioId}\r\n value={value}\r\n className={cn(radioItemRootClass, className)}\r\n {...props}\r\n >\r\n <RadixRadioGroup.Indicator className={radioIndicatorClass}>\r\n <Icon\r\n icon={'mdi:circle'}\r\n size={'xs'}\r\n />\r\n </RadixRadioGroup.Indicator>\r\n </RadixRadioGroup.Item>\r\n\r\n {label && (\r\n <Typography\r\n as={'label'}\r\n variant={'label'}\r\n color={'foreground'}\r\n htmlFor={radioId}\r\n className={radioItemLabelClass}\r\n >\r\n {label}\r\n </Typography>\r\n )}\r\n </Flex>\r\n )\r\n}\r\n\r\nRadioItem.displayName = 'RadioItem'\r\n\r\nexport default RadioItem\r\n","import { recipe, type RecipeVariants } from '@vanilla-extract/recipes'\r\n\r\nexport const gridRecipe = recipe({\r\n base: {\r\n display: 'grid',\r\n },\r\n\r\n variants: {\r\n // Columns\r\n columns: {\r\n none: { gridTemplateColumns: 'none' },\r\n 1: { gridTemplateColumns: 'repeat(1, minmax(0, 1fr))' },\r\n 2: { gridTemplateColumns: 'repeat(2, minmax(0, 1fr))' },\r\n 3: { gridTemplateColumns: 'repeat(3, minmax(0, 1fr))' },\r\n 4: { gridTemplateColumns: 'repeat(4, minmax(0, 1fr))' },\r\n 5: { gridTemplateColumns: 'repeat(5, minmax(0, 1fr))' },\r\n 6: { gridTemplateColumns: 'repeat(6, minmax(0, 1fr))' },\r\n 7: { gridTemplateColumns: 'repeat(7, minmax(0, 1fr))' },\r\n 8: { gridTemplateColumns: 'repeat(8, minmax(0, 1fr))' },\r\n 9: { gridTemplateColumns: 'repeat(9, minmax(0, 1fr))' },\r\n 10: { gridTemplateColumns: 'repeat(10, minmax(0, 1fr))' },\r\n 11: { gridTemplateColumns: 'repeat(11, minmax(0, 1fr))' },\r\n 12: { gridTemplateColumns: 'repeat(12, minmax(0, 1fr))' },\r\n },\r\n\r\n // Auto Rows\r\n autoRows: {\r\n auto: { gridAutoRows: 'auto' },\r\n min: { gridAutoRows: 'min-content' },\r\n max: { gridAutoRows: 'max-content' },\r\n fr: { gridAutoRows: 'minmax(0, 1fr)' },\r\n },\r\n\r\n // Auto Flow\r\n flow: {\r\n row: { gridAutoFlow: 'row' },\r\n column: { gridAutoFlow: 'column' },\r\n dense: { gridAutoFlow: 'dense' },\r\n 'row-dense': { gridAutoFlow: 'row dense' },\r\n 'column-dense': { gridAutoFlow: 'column dense' },\r\n },\r\n\r\n // Align Items\r\n align: {\r\n start: { alignItems: 'start' },\r\n end: { alignItems: 'end' },\r\n center: { alignItems: 'center' },\r\n stretch: { alignItems: 'stretch' },\r\n baseline: { alignItems: 'baseline' },\r\n },\r\n\r\n // Justify Items\r\n justifyItems: {\r\n start: { justifyItems: 'start' },\r\n end: { justifyItems: 'end' },\r\n center: { justifyItems: 'center' },\r\n stretch: { justifyItems: 'stretch' },\r\n },\r\n\r\n // Align Content\r\n alignContent: {\r\n start: { alignContent: 'start' },\r\n end: { alignContent: 'end' },\r\n center: { alignContent: 'center' },\r\n stretch: { alignContent: 'stretch' },\r\n between: { alignContent: 'space-between' },\r\n around: { alignContent: 'space-around' },\r\n evenly: { alignContent: 'space-evenly' },\r\n },\r\n\r\n // Justify Content\r\n justifyContent: {\r\n start: { justifyContent: 'start' },\r\n end: { justifyContent: 'end' },\r\n center: { justifyContent: 'center' },\r\n stretch: { justifyContent: 'stretch' },\r\n between: { justifyContent: 'space-between' },\r\n around: { justifyContent: 'space-around' },\r\n evenly: { justifyContent: 'space-evenly' },\r\n },\r\n },\r\n})\r\n\r\nexport type GridRecipeVariants = NonNullable<RecipeVariants<typeof gridRecipe>>\r\n","import { gridRecipe } from '@components/layout/grid/Grid.css.ts'\r\nimport type { GridProps } from '@components/layout/grid/types/Grid.props.ts'\r\nimport { cn } from '@utils/cn.ts'\r\nimport type { FC } from 'react'\r\n\r\nimport Box from '@components/layout/box/Box.tsx'\r\n\r\nconst Grid: FC<GridProps> = ({\r\n columns,\r\n autoRows,\r\n flow,\r\n align,\r\n justifyItems,\r\n alignContent,\r\n justifyContent,\r\n gap = 'md',\r\n className,\r\n ...props\r\n}) => {\r\n return (\r\n <Box\r\n gap={gap}\r\n className={cn(\r\n gridRecipe({ columns, autoRows, flow, align, justifyItems, alignContent, justifyContent }),\r\n className,\r\n )}\r\n {...props}\r\n />\r\n )\r\n}\r\n\r\nGrid.displayName = 'Grid'\r\n\r\nexport default Grid\r\n","// 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 // Outside elements that belong to a layer's own dismiss affordance (eg, a\n // dialog overlay). Pressing them should dismiss the layer regardless of\n // whether or not they stop propagation.\n //\n // See https://github.com/radix-ui/primitives/issues/3346\n dismissableSurfaces: /* @__PURE__ */ new Set()\n});\nvar DismissableLayer = React.forwardRef(\n (props, forwardedRef) => {\n const {\n disableOutsidePointerEvents = false,\n deferPointerDownOutside = 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 isDeferredPointerDownOutsideRef = React.useRef(false);\n const pointerDownOutside = usePointerDownOutside(\n (event) => {\n const target = event.target;\n if (!(target instanceof Node)) {\n return;\n }\n const isPointerDownOnBranch = [...context.branches].some(\n (branch) => branch.contains(target)\n );\n if (!isPointerEventsEnabled || isPointerDownOnBranch) return;\n onPointerDownOutside?.(event);\n onInteractOutside?.(event);\n if (!event.defaultPrevented) onDismiss?.();\n },\n {\n ownerDocument,\n deferPointerDownOutside,\n isDeferredPointerDownOutsideRef,\n dismissableSurfaces: context.dismissableSurfaces\n }\n );\n const focusOutside = useFocusOutside((event) => {\n if (deferPointerDownOutside && isDeferredPointerDownOutsideRef.current) {\n return;\n }\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) {\n context.layersWithOutsidePointerEventsDisabled.delete(node);\n if (context.layersWithOutsidePointerEventsDisabled.size === 0) {\n ownerDocument.body.style.pointerEvents = originalBodyPointerEvents;\n }\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 useDismissableLayerSurface() {\n const context = React.useContext(DismissableLayerContext);\n const [node, setNode] = React.useState(null);\n React.useEffect(() => {\n if (!node) {\n return;\n }\n context.dismissableSurfaces.add(node);\n return () => {\n context.dismissableSurfaces.delete(node);\n };\n }, [node, context.dismissableSurfaces]);\n return setNode;\n}\nfunction usePointerDownOutside(onPointerDownOutside, args) {\n const {\n ownerDocument = globalThis?.document,\n deferPointerDownOutside = false,\n isDeferredPointerDownOutsideRef,\n dismissableSurfaces\n } = args;\n const handlePointerDownOutside = useCallbackRef(onPointerDownOutside);\n const isPointerInsideReactTreeRef = React.useRef(false);\n const isPointerDownOutsideRef = React.useRef(false);\n const interceptedOutsideInteractionEventsRef = React.useRef(/* @__PURE__ */ new Map());\n const handleClickRef = React.useRef(() => {\n });\n React.useEffect(() => {\n function resetOutsideInteraction() {\n isPointerDownOutsideRef.current = false;\n isDeferredPointerDownOutsideRef.current = false;\n interceptedOutsideInteractionEventsRef.current.clear();\n }\n function isOutsideInteractionIntercepted() {\n return Array.from(interceptedOutsideInteractionEventsRef.current.values()).some(Boolean);\n }\n function handleInteractionCapture(event) {\n if (!isPointerDownOutsideRef.current) {\n return;\n }\n const target = event.target;\n const isDismissableSurface = target instanceof Node && [...dismissableSurfaces].some((surface) => surface.contains(target));\n if (!isDismissableSurface) {\n interceptedOutsideInteractionEventsRef.current.set(event.type, true);\n }\n if (event.type === \"click\") {\n window.setTimeout(() => {\n if (isPointerDownOutsideRef.current) {\n handleClickRef.current();\n }\n }, 0);\n }\n }\n function handleInteractionBubble(event) {\n if (isPointerDownOutsideRef.current) {\n interceptedOutsideInteractionEventsRef.current.set(event.type, false);\n }\n }\n const handlePointerDown = (event) => {\n if (event.target && !isPointerInsideReactTreeRef.current) {\n let handleAndDispatchPointerDownOutsideEvent2 = function() {\n ownerDocument.removeEventListener(\"click\", handleClickRef.current);\n const wasOutsideInteractionIntercepted = isOutsideInteractionIntercepted();\n resetOutsideInteraction();\n if (!wasOutsideInteractionIntercepted) {\n handleAndDispatchCustomEvent(\n POINTER_DOWN_OUTSIDE,\n handlePointerDownOutside,\n eventDetail,\n { discrete: true }\n );\n }\n };\n var handleAndDispatchPointerDownOutsideEvent = handleAndDispatchPointerDownOutsideEvent2;\n const eventDetail = { originalEvent: event };\n isPointerDownOutsideRef.current = true;\n isDeferredPointerDownOutsideRef.current = deferPointerDownOutside && event.button === 0;\n interceptedOutsideInteractionEventsRef.current.clear();\n if (!deferPointerDownOutside || event.button !== 0) {\n handleAndDispatchPointerDownOutsideEvent2();\n } else {\n ownerDocument.removeEventListener(\"click\", handleClickRef.current);\n handleClickRef.current = handleAndDispatchPointerDownOutsideEvent2;\n ownerDocument.addEventListener(\"click\", handleClickRef.current, { once: true });\n }\n } else {\n ownerDocument.removeEventListener(\"click\", handleClickRef.current);\n resetOutsideInteraction();\n }\n isPointerInsideReactTreeRef.current = false;\n };\n const outsideInteractionEvents = [\n \"pointerup\",\n \"mousedown\",\n \"mouseup\",\n \"touchstart\",\n \"touchend\",\n \"click\"\n ];\n for (const eventName of outsideInteractionEvents) {\n ownerDocument.addEventListener(eventName, handleInteractionCapture, true);\n ownerDocument.addEventListener(eventName, handleInteractionBubble);\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 for (const eventName of outsideInteractionEvents) {\n ownerDocument.removeEventListener(eventName, handleInteractionCapture, true);\n ownerDocument.removeEventListener(eventName, handleInteractionBubble);\n }\n };\n }, [\n ownerDocument,\n handlePointerDownOutside,\n deferPointerDownOutside,\n isDeferredPointerDownOutsideRef,\n dismissableSurfaces\n ]);\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 useDismissableLayerSurface\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","\"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 const [placementState, setPlacementState] = React.useState(void 0);\n return /* @__PURE__ */ jsx(\n PopperProvider,\n {\n scope: __scopePopper,\n anchor,\n onAnchorChange: setAnchor,\n placementState,\n setPlacementState,\n children\n }\n );\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 onAnchorChange = context.onAnchorChange;\n const callbackRef = React.useCallback(\n (node) => {\n ref.current = node;\n if (node) {\n onAnchorChange(node);\n }\n },\n [onAnchorChange]\n );\n const composedRefs = useComposedRefs(forwardedRef, callbackRef);\n const anchorRef = React.useRef(null);\n React.useEffect(() => {\n if (!virtualRef) {\n return;\n }\n const previousAnchor = anchorRef.current;\n anchorRef.current = virtualRef.current;\n if (previousAnchor !== anchorRef.current) {\n onAnchorChange(anchorRef.current);\n }\n });\n const sideAndAlign = context.placementState && getSideAndAlignFromPlacement(context.placementState);\n const placedSide = sideAndAlign?.[0];\n const placedAlign = sideAndAlign?.[1];\n return virtualRef ? null : /* @__PURE__ */ jsx(\n Primitive.div,\n {\n \"data-radix-popper-side\": placedSide,\n \"data-radix-popper-align\": placedAlign,\n ...anchorProps,\n ref: composedRefs\n }\n );\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({\n strategy: \"referenceHidden\",\n ...detectOverflowOptions,\n // `hide` detects whether the anchor (reference) is clipped, so when\n // no explicit `collisionBoundary` is set we fall back to Floating\n // UI's default clipping ancestors (e.g. a scrollable menu). This\n // lets an occluded submenu hide once its anchor scrolls out of view\n // (#3237). The collision/size middlewares deliberately keep the\n // viewport-based default to avoid clamping content rendered inside\n // transformed or overflow-clipping portal containers.\n boundary: hasExplicitBoundaries ? detectOverflowOptions.boundary : void 0\n })\n ]\n });\n const setPlacementState = context.setPlacementState;\n useLayoutEffect(() => {\n setPlacementState(placement);\n return () => {\n setPlacementState(void 0);\n };\n }, [placement, setPlacementState]);\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 placedAlign,\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 * as 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/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","\"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 if (skipDelayDuration <= 0) return;\n window.clearTimeout(skipDelayTimerRef.current);\n isOpenDelayedRef.current = false;\n }, [skipDelayDuration]),\n onClose: React.useCallback(() => {\n if (skipDelayDuration <= 0) return;\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 if (event.target instanceof Node && event.target.contains(context.trigger)) {\n onClose();\n }\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 { style, keyframes } from '@vanilla-extract/css'\r\n\r\nimport { vars } from '@theme/contract.css.ts'\r\n\r\nconst fadeZoomIn = keyframes({\r\n from: { opacity: 0, transform: 'scale(0.95)' },\r\n to: { opacity: 1, transform: 'scale(1)' },\r\n})\r\n\r\nconst fadeZoomOut = keyframes({\r\n from: { opacity: 1, transform: 'scale(1)' },\r\n to: { opacity: 0, transform: 'scale(0.95)' },\r\n})\r\n\r\nexport const tooltipContentClass = style({\r\n zIndex: vars.zIndex.tooltip,\r\n borderRadius: vars.radius.sm,\r\n backgroundColor: vars.color.popover,\r\n color: vars.color.popoverForeground,\r\n paddingInline: vars.space.md,\r\n paddingBlock: vars.space.xs,\r\n fontFamily: vars.fontFamily.sans,\r\n fontSize: vars.fontSize.xs,\r\n lineHeight: vars.lineHeight.normal,\r\n filter: vars.dropShadow.sm,\r\n transformOrigin: 'var(--radix-tooltip-content-transform-origin)',\r\n selectors: {\r\n '&[data-state=\"delayed-open\"], &[data-state=\"instant-open\"]': {\r\n animation: `${fadeZoomIn} 0.15s ease-out`,\r\n },\r\n '&[data-state=\"closed\"]': {\r\n animation: `${fadeZoomOut} 0.15s ease-in`,\r\n },\r\n },\r\n})\r\n\r\nexport const tooltipArrowClass = style({\r\n fill: vars.color.popover,\r\n})\r\n","/** Side position of the tooltip relative to its trigger. */\r\nexport type TooltipSide = 'top' | 'right' | 'bottom' | 'left';\r\n\r\n/** Alignment of the tooltip relative to its trigger. */\r\nexport type TooltipAlign = 'start' | 'center' | 'end';\r\n\r\n/**\r\n * Combined position of the tooltip — shorthand that sets both `side` and `align`\r\n * in a single prop. Twelve values are available (4 sides × 3 alignments).\r\n *\r\n * | Value | side | align |\r\n * |-----------------|----------|----------|\r\n * | `top-start` | top | start |\r\n * | `top` | top | center |\r\n * | `top-end` | top | end |\r\n * | `right-start` | right | start |\r\n * | `right` | right | center |\r\n * | `right-end` | right | end |\r\n * | `bottom-start` | bottom | start |\r\n * | `bottom` | bottom | center |\r\n * | `bottom-end` | bottom | end |\r\n * | `left-start` | left | start |\r\n * | `left` | left | center |\r\n * | `left-end` | left | end |\r\n */\r\nexport type TooltipPosition =\r\n | 'top-start' | 'top' | 'top-end'\r\n | 'right-start' | 'right' | 'right-end'\r\n | 'bottom-start' | 'bottom' | 'bottom-end'\r\n | 'left-start' | 'left' | 'left-end';\r\n\r\n/** Parses a `TooltipPosition` string into its `side` and `align` parts. */\r\nexport const parsePosition = (position: TooltipPosition): { side: TooltipSide; align: TooltipAlign } => {\r\n const parts = position.split('-') as [TooltipSide, TooltipAlign?]\r\n const side = parts[0]\r\n const align = parts[1] ?? 'center'\r\n return { side, align }\r\n}\r\n","import * as RadixTooltip from '@radix-ui/react-tooltip'\r\n\r\nimport type { TooltipProps } from '@components/overlay/tooltip/types/Tooltip.props.ts'\r\nimport { tooltipArrowClass, tooltipContentClass } from '@components/overlay/tooltip/Tooltip.css.ts'\r\nimport { cn } from '@utils/cn.ts'\r\nimport { parsePosition } from '@components/overlay/tooltip/types/Tooltip.types.ts'\r\nimport type {FC} from \"react\";\r\n\r\nconst Tooltip: FC<TooltipProps> = ({\r\n children,\r\n content,\r\n position,\r\n side: sideProp = 'top',\r\n align: alignProp = 'center',\r\n delayDuration = 300,\r\n disabled = false,\r\n className,\r\n open,\r\n onOpenChange,\r\n}) => {\r\n if (disabled) {\r\n return <>{children}</>\r\n }\r\n\r\n const { side, align } = position\r\n ? parsePosition(position)\r\n : { side: sideProp, align: alignProp }\r\n\r\n return (\r\n <RadixTooltip.Provider>\r\n <RadixTooltip.Root\r\n delayDuration={delayDuration}\r\n open={open}\r\n onOpenChange={onOpenChange}\r\n >\r\n <RadixTooltip.Trigger asChild>\r\n {children}\r\n </RadixTooltip.Trigger>\r\n\r\n <RadixTooltip.Portal>\r\n <RadixTooltip.Content\r\n side={side}\r\n align={align}\r\n className={cn(tooltipContentClass, className)}\r\n sideOffset={6}\r\n >\r\n {content}\r\n <RadixTooltip.Arrow className={tooltipArrowClass} />\r\n </RadixTooltip.Content>\r\n </RadixTooltip.Portal>\r\n </RadixTooltip.Root>\r\n </RadixTooltip.Provider>\r\n )\r\n}\r\n\r\nTooltip.displayName = 'Tooltip'\r\n\r\nexport default Tooltip\r\n\r\n","\"use client\";\n\n// src/focus-guards.tsx\nimport * as React from \"react\";\nvar count = 0;\nvar guards = null;\nfunction FocusGuards(props) {\n useFocusGuards();\n return props.children;\n}\nfunction useFocusGuards() {\n React.useEffect(() => {\n if (!guards) {\n guards = { start: createFocusGuard(), end: createFocusGuard() };\n }\n const { start, end } = guards;\n if (document.body.firstElementChild !== start) {\n document.body.insertAdjacentElement(\"afterbegin\", start);\n }\n if (document.body.lastElementChild !== end) {\n document.body.insertAdjacentElement(\"beforeend\", end);\n }\n count++;\n return () => {\n if (count === 1) {\n guards?.start.remove();\n guards?.end.remove();\n guards = null;\n }\n count = Math.max(0, count - 1);\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","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/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 React.useEffect(() => {\n if (!open) {\n return;\n }\n const handleBlur = () => handleOpenChange(false);\n window.addEventListener(\"blur\", handleBlur);\n return () => window.removeEventListener(\"blur\", handleBlur);\n }, [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 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\": context.open ? subContext.contentId : void 0,\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, align = \"start\", ...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,\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 RadixDropdownMenu from '@radix-ui/react-dropdown-menu'\r\n\r\nimport type { DropdownMenuProps } from '@components/overlay/dropdown-menu/types/DropdownMenu.props.ts'\r\n\r\n/**\r\n * The root wrapper that manages open/close state.\r\n * Accepts `open`, `onOpenChange`, `defaultOpen` and `modal` from Radix.\r\n */\r\nconst DropdownMenu = (props: DropdownMenuProps) => (\r\n <RadixDropdownMenu.Root {...props} />\r\n)\r\n\r\nDropdownMenu.displayName = 'DropdownMenu'\r\n\r\nexport default DropdownMenu","import * as RadixDropdownMenu from '@radix-ui/react-dropdown-menu'\r\n\r\nimport type { DropdownMenuTriggerProps } from '@components/overlay/dropdown-menu/components/trigger/dropdown-menu-trigger/types/DropdownMenuTrigger.props.ts'\r\n\r\n/**\r\n * The element that opens the dropdown.\r\n * Use `asChild` to forward the trigger behaviour to your own element.\r\n */\r\nconst DropdownMenuTrigger = (props: DropdownMenuTriggerProps) => (\r\n <RadixDropdownMenu.Trigger {...props} />\r\n)\r\n\r\nDropdownMenuTrigger.displayName = 'DropdownMenuTrigger'\r\n\r\nexport default DropdownMenuTrigger\r\n","import { style } from '@vanilla-extract/css'\r\n\r\nimport { vars } from '@theme/contract.css.ts'\r\nimport {\r\n slideDownIn, slideDownOut,\r\n slideUpIn, slideUpOut,\r\n slideRightIn, slideRightOut,\r\n slideLeftIn, slideLeftOut,\r\n} from '@constants/animations/index.ts'\r\n\r\n/**\r\n * The floating panel that appears below (or beside) the trigger.\r\n * Uses box-shadow for elevation — cleaner than filter: drop-shadow for\r\n * rectangular surfaces.\r\n */\r\nexport const dropdownMenuContentClass = style({\r\n zIndex: vars.zIndex.dropdown,\r\n minWidth: '11rem',\r\n overflow: 'hidden',\r\n borderRadius: vars.radius.lg,\r\n border: `1px solid ${vars.color.border}`,\r\n backgroundColor: vars.color.popover,\r\n color: vars.color.popoverForeground,\r\n padding: vars.space.xs,\r\n boxShadow: vars.shadow.lg,\r\n transformOrigin: 'var(--radix-dropdown-menu-content-transform-origin)',\r\n\r\n selectors: {\r\n '&[data-state=\"open\"][data-side=\"bottom\"]': {\r\n animation: `${slideDownIn} 0.18s ${vars.easing.out} both`,\r\n },\r\n '&[data-state=\"closed\"][data-side=\"bottom\"]': {\r\n animation: `${slideDownOut} 0.12s ${vars.easing.in} both`,\r\n },\r\n '&[data-state=\"open\"][data-side=\"top\"]': {\r\n animation: `${slideUpIn} 0.18s ${vars.easing.out} both`,\r\n },\r\n '&[data-state=\"closed\"][data-side=\"top\"]': {\r\n animation: `${slideUpOut} 0.12s ${vars.easing.in} both`,\r\n },\r\n '&[data-state=\"open\"][data-side=\"right\"]': {\r\n animation: `${slideRightIn} 0.18s ${vars.easing.out} both`,\r\n },\r\n '&[data-state=\"closed\"][data-side=\"right\"]': {\r\n animation: `${slideRightOut} 0.12s ${vars.easing.in} both`,\r\n },\r\n '&[data-state=\"open\"][data-side=\"left\"]': {\r\n animation: `${slideLeftIn} 0.18s ${vars.easing.out} both`,\r\n },\r\n '&[data-state=\"closed\"][data-side=\"left\"]': {\r\n animation: `${slideLeftOut} 0.12s ${vars.easing.in} both`,\r\n },\r\n },\r\n})\r\n","import * as RadixDropdownMenu from '@radix-ui/react-dropdown-menu'\r\n\r\nimport { cn } from '@utils/cn.ts'\r\nimport { dropdownMenuContentClass } from '@components/overlay/dropdown-menu/components/content/dropdown-menu-content/DropdownMenuContent.css.ts'\r\nimport type { DropdownMenuContentProps } from '@components/overlay/dropdown-menu/components/content/dropdown-menu-content/types/DropdownMenuContent.props.ts'\r\nimport { useViewportShift } from '@hooks'\r\n\r\n/**\r\n * The panel that pops out from the trigger.\r\n * Rendered inside a portal by default for correct stacking.\r\n *\r\n * Radix's built-in `avoidCollisions` is disabled here: it would flip the menu\r\n * to the opposite side when space is tight, which is jarring.\r\n * Instead, `useViewportShift` detects any overflow after positioning and\r\n * shifts the panel inward by exactly the overflowing amount — keeping the\r\n * original side and never cropping the menu.\r\n */\r\nconst DropdownMenuContent = ({\r\n className,\r\n side = 'bottom',\r\n align = 'start',\r\n sideOffset = 6,\r\n collisionPadding = 8,\r\n ...props\r\n}: DropdownMenuContentProps) => {\r\n const contentRef = useViewportShift(collisionPadding)\r\n\r\n return (\r\n <RadixDropdownMenu.Portal>\r\n <RadixDropdownMenu.Content\r\n ref={contentRef}\r\n side={side}\r\n align={align}\r\n sideOffset={sideOffset}\r\n className={cn(dropdownMenuContentClass, className)}\r\n {...props}\r\n // Disable Radix's flip/shift — our hook handles collision instead.\r\n avoidCollisions={false}\r\n />\r\n </RadixDropdownMenu.Portal>\r\n )\r\n}\r\n\r\nDropdownMenuContent.displayName = 'DropdownMenuContent'\r\n\r\nexport default DropdownMenuContent\r\n","import * as RadixDropdownMenu from '@radix-ui/react-dropdown-menu'\r\n\r\nimport type { DropdownMenuGroupProps } from '@components/overlay/dropdown-menu/components/groups/dropdown-menu-group/types/DropdownMenuGroup.props.ts'\r\n\r\n/**\r\n * Groups related items together semantically. Pair with `DropdownMenuLabel`.\r\n */\r\nconst DropdownMenuGroup = (props: DropdownMenuGroupProps) => (\r\n <RadixDropdownMenu.Group {...props} />\r\n)\r\n\r\nDropdownMenuGroup.displayName = 'DropdownMenuGroup'\r\n\r\nexport default DropdownMenuGroup\r\n","import * as RadixDropdownMenu from '@radix-ui/react-dropdown-menu'\r\n\r\nimport type { DropdownMenuRadioGroupProps } from '@components/overlay/dropdown-menu/components/groups/dropdown-menu-radio-group/types/DropdownMenuRadioGroup.props.ts'\r\n\r\n/**\r\n * Groups radio items so only one can be selected at a time.\r\n * Use `value` and `onValueChange` for controlled behaviour.\r\n */\r\nconst DropdownMenuRadioGroup = (props: DropdownMenuRadioGroupProps) => (\r\n <RadixDropdownMenu.RadioGroup {...props} />\r\n)\r\n\r\nDropdownMenuRadioGroup.displayName = 'DropdownMenuRadioGroup'\r\n\r\nexport default DropdownMenuRadioGroup\r\n","import { style, globalStyle } from '@vanilla-extract/css'\r\n\r\nimport { vars } from '@theme/contract.css.ts'\r\n\r\n/**\r\n * Base style shared by all interactive menu items:\r\n * MenuItem, CheckboxItem, RadioItem, SubTrigger.\r\n */\r\nexport const dropdownMenuItemClass = style({\r\n position: 'relative',\r\n borderRadius: vars.radius.sm,\r\n paddingBlock: vars.space.xs2,\r\n paddingInline: vars.space.sm,\r\n fontSize: vars.fontSize.sm,\r\n lineHeight: vars.lineHeight.normal,\r\n fontFamily: vars.fontFamily.sans,\r\n color: vars.color.popoverForeground,\r\n cursor: 'pointer',\r\n userSelect: 'none',\r\n outline: 'none',\r\n transition: [\r\n `background-color ${vars.duration.fast} ${vars.easing.standard}`,\r\n `color ${vars.duration.fast} ${vars.easing.standard}`,\r\n ].join(', '),\r\n\r\n selectors: {\r\n '&[data-highlighted]': {\r\n backgroundColor: vars.color.primarySubtle,\r\n color: vars.color.primarySubtleForeground,\r\n },\r\n // pressed / active — slightly stronger blue tint\r\n '&[data-highlighted]:active': {\r\n backgroundColor: vars.color.primarySubtleActive,\r\n },\r\n '&[data-disabled]': {\r\n cursor: 'not-allowed',\r\n opacity: 0.45,\r\n },\r\n },\r\n})\r\n\r\n/**\r\n * Modifier applied to destructive actions (e.g. \"Delete\", \"Remove\").\r\n */\r\nexport const dropdownMenuItemDestructiveClass = style({\r\n color: vars.color.destructive,\r\n selectors: {\r\n '&[data-highlighted]': {\r\n backgroundColor: vars.color.destructiveSubtle,\r\n color: vars.color.destructiveSubtleForeground,\r\n },\r\n '&[data-highlighted]:active': {\r\n backgroundColor: vars.color.destructiveSubtleHover,\r\n },\r\n },\r\n})\r\n\r\n/**\r\n * Wrapper for leading / trailing icons inside an item.\r\n * Inherits current color so it automatically matches item state (normal, destructive, highlighted…).\r\n */\r\nexport const dropdownMenuItemIconClass = style({\r\n flexShrink: 0,\r\n width: '1rem',\r\n height: '1rem',\r\n color: 'inherit',\r\n transition: `color ${vars.duration.fast} ${vars.easing.standard}`,\r\n})\r\n\r\nglobalStyle(`${dropdownMenuItemIconClass} svg`, {\r\n width: '1rem',\r\n height: '1rem',\r\n pointerEvents: 'none',\r\n})\r\n","import { style } from '@vanilla-extract/css'\r\n\r\nimport { vars } from '@theme/contract.css.ts'\r\n\r\n/**\r\n * Keyboard shortcut badge rendered at the trailing edge of an item.\r\n * Styled as a subtle <kbd> element — monospace, bordered, muted.\r\n * Adapts to highlighted and disabled states via ancestor selectors.\r\n */\r\nexport const dropdownMenuShortcutClass = style({\r\n marginLeft: 'auto',\r\n fontSize: vars.fontSize.xs,\r\n fontFamily: vars.fontFamily.mono,\r\n letterSpacing: vars.letterSpacing.wide,\r\n color: vars.color.mutedForeground,\r\n backgroundColor: vars.color.muted,\r\n border: `1px solid ${vars.color.border}`,\r\n borderRadius: vars.radius.xs,\r\n paddingBlock: '0.0625rem',\r\n paddingInline: vars.space.xs,\r\n lineHeight: vars.lineHeight.normal,\r\n transition: [\r\n `background-color ${vars.duration.fast} ${vars.easing.standard}`,\r\n `border-color ${vars.duration.fast} ${vars.easing.standard}`,\r\n `color ${vars.duration.fast} ${vars.easing.standard}`,\r\n ].join(', '),\r\n\r\n selectors: {\r\n '[data-highlighted] &': {\r\n backgroundColor: vars.color.primarySubtleHover,\r\n borderColor: vars.color.primary,\r\n color: vars.color.primarySubtleForeground,\r\n opacity: 0.85,\r\n },\r\n '[data-disabled] &': {\r\n opacity: 0.4,\r\n },\r\n },\r\n})\r\n","import { cn } from '@utils/cn.ts'\r\nimport { Flex } from '@components/layout/flex'\r\nimport { dropdownMenuShortcutClass } from '@components/overlay/dropdown-menu/components/shortcut/dropdown-menu-shortcut/DropdownMenuShortcut.css.ts'\r\nimport type { DropdownMenuShortcutProps } from '@components/overlay/dropdown-menu/components/shortcut/dropdown-menu-shortcut/types/DropdownMenuShortcut.props.ts'\r\n\r\n/**\r\n * Displays a keyboard shortcut hint aligned to the right of an item.\r\n * Automatically aria-hidden — purely decorative.\r\n */\r\nconst DropdownMenuShortcut = ({ className, ...props }: DropdownMenuShortcutProps) => (\r\n <Flex\r\n as={'span'}\r\n inline\r\n className={cn(dropdownMenuShortcutClass, className)}\r\n aria-hidden\r\n {...props}\r\n />\r\n)\r\n\r\nDropdownMenuShortcut.displayName = 'DropdownMenuShortcut'\r\n\r\nexport default DropdownMenuShortcut\r\n","import * as RadixDropdownMenu from '@radix-ui/react-dropdown-menu'\r\n\r\nimport { cn } from '@utils/cn.ts'\r\nimport {\r\n dropdownMenuItemClass,\r\n dropdownMenuItemDestructiveClass,\r\n dropdownMenuItemIconClass,\r\n} from '@components/overlay/dropdown-menu/components/_shared/item.css.ts'\r\nimport { Flex } from '@components/layout/flex'\r\nimport { Icon } from '@components/foundation/icon'\r\nimport { Typography } from '@components/foundation/typography'\r\nimport DropdownMenuShortcut from '@components/overlay/dropdown-menu/components/shortcut/dropdown-menu-shortcut/DropdownMenuShortcut.tsx'\r\nimport type { DropdownMenuItemProps } from '@components/overlay/dropdown-menu/components/items/dropdown-menu-item/types/DropdownMenuItem.props.ts'\r\n\r\n/**\r\n * A single actionable item inside the dropdown.\r\n *\r\n * @example\r\n * ```tsx\r\n * <DropdownMenuItem\r\n * label={'Edit'}\r\n * startIcon={'mdi:pencil'}\r\n * shortcut={'⌘E'}\r\n * />\r\n * ```\r\n */\r\nconst DropdownMenuItem = ({\r\n className,\r\n destructive = false,\r\n startIcon,\r\n endIcon,\r\n shortcut,\r\n label,\r\n ...props\r\n}: DropdownMenuItemProps) => (\r\n <RadixDropdownMenu.Item asChild {...props}>\r\n <Flex\r\n gap={'sm'}\r\n className={cn(\r\n dropdownMenuItemClass,\r\n destructive && dropdownMenuItemDestructiveClass,\r\n className,\r\n )}\r\n >\r\n {startIcon && (\r\n <Flex as={'span'} justify={'center'} className={dropdownMenuItemIconClass} aria-hidden>\r\n <Icon icon={startIcon} size={'xs'} />\r\n </Flex>\r\n )}\r\n <Typography as={'span'} variant={'span'} style={{ flex: 1 }}>{label}</Typography>\r\n {shortcut && (\r\n <DropdownMenuShortcut>{shortcut}</DropdownMenuShortcut>\r\n )}\r\n {endIcon && (\r\n <Flex as={'span'} justify={'center'} className={dropdownMenuItemIconClass} aria-hidden>\r\n <Icon icon={endIcon} size={'xs'} />\r\n </Flex>\r\n )}\r\n </Flex>\r\n </RadixDropdownMenu.Item>\r\n)\r\n\r\nDropdownMenuItem.displayName = 'DropdownMenuItem'\r\n\r\nexport default DropdownMenuItem\r\n","import * as RadixDropdownMenu from '@radix-ui/react-dropdown-menu'\r\n\r\nimport { cn } from '@utils/cn.ts'\r\nimport {\r\n dropdownMenuItemClass,\r\n} from '@components/overlay/dropdown-menu/components/_shared/item.css.ts'\r\nimport { Box } from '@components/layout/box'\r\nimport { Flex } from '@components/layout/flex'\r\nimport {checkboxIndicatorClass, checkboxRootClass} from '@components/forms/checkbox/Checkbox.css.ts'\r\nimport { Icon } from '@components/foundation/icon'\r\nimport { Typography } from '@components/foundation/typography'\r\nimport type { DropdownMenuCheckboxItemProps } from '@components/overlay/dropdown-menu/components/items/dropdown-menu-checkbox-item/types/DropdownMenuCheckboxItem.props.ts'\r\nimport type {FC} from \"react\"\r\n\r\nconst DropdownMenuCheckboxItem: FC<DropdownMenuCheckboxItemProps> = ({\r\n className,\r\n label,\r\n checked,\r\n onSelect,\r\n ...props\r\n}) => (\r\n <RadixDropdownMenu.CheckboxItem asChild checked={checked} onSelect={(e) => { e.preventDefault(); onSelect?.(e) }} {...props}>\r\n <Flex gap={'sm'} className={cn(dropdownMenuItemClass, className)}>\r\n <Box as={'span'} className={checkboxRootClass}>\r\n <RadixDropdownMenu.ItemIndicator className={checkboxIndicatorClass}>\r\n <Icon icon={'mdi:check'} size={'xs'} />\r\n </RadixDropdownMenu.ItemIndicator>\r\n </Box>\r\n <Typography as={'span'} variant={'span'}>{label}</Typography>\r\n </Flex>\r\n </RadixDropdownMenu.CheckboxItem>\r\n)\r\n\r\nDropdownMenuCheckboxItem.displayName = 'DropdownMenuCheckboxItem'\r\n\r\nexport default DropdownMenuCheckboxItem\r\n","import * as RadixDropdownMenu from '@radix-ui/react-dropdown-menu'\r\n\r\nimport { cn } from '@utils/cn.ts'\r\nimport {\r\n dropdownMenuItemClass,\r\n} from '@components/overlay/dropdown-menu/components/_shared/item.css.ts'\r\nimport { Box } from '@components/layout/box'\r\nimport { Flex } from '@components/layout/flex'\r\nimport {\r\n radioIndicatorClass,\r\n radioItemRootClass\r\n} from '@components/forms/radio-group/components/radio-item/RadioItem.css.ts'\r\nimport { Icon } from '@components/foundation/icon'\r\nimport { Typography } from '@components/foundation/typography'\r\nimport type { DropdownMenuRadioItemProps } from '@components/overlay/dropdown-menu/components/items/dropdown-menu-radio-item/types/DropdownMenuRadioItem.props.ts'\r\nimport type { FC } from \"react\"\r\n\r\nconst DropdownMenuRadioItem: FC<DropdownMenuRadioItemProps> = ({\r\n className,\r\n label,\r\n onSelect,\r\n ...props\r\n}) => (\r\n <RadixDropdownMenu.RadioItem asChild onSelect={(e) => { e.preventDefault(); onSelect?.(e) }} {...props}>\r\n <Flex gap={'sm'} className={cn(dropdownMenuItemClass, className)}>\r\n <Box as={'span'} className={radioItemRootClass}>\r\n <RadixDropdownMenu.ItemIndicator className={radioIndicatorClass}>\r\n <Icon icon={'mdi:circle'} size={'xs'} />\r\n </RadixDropdownMenu.ItemIndicator>\r\n </Box>\r\n <Typography as={'span'} variant={'span'}>{label}</Typography>\r\n </Flex>\r\n </RadixDropdownMenu.RadioItem>\r\n)\r\n\r\nDropdownMenuRadioItem.displayName = 'DropdownMenuRadioItem'\r\n\r\nexport default DropdownMenuRadioItem\r\n","import { style } from '@vanilla-extract/css'\r\n\r\nimport { vars } from '@theme/contract.css.ts'\r\n\r\n/**\r\n * Non-interactive section heading — small, muted, uppercase.\r\n * Typically paired with DropdownMenuGroup for semantic grouping.\r\n */\r\nexport const dropdownMenuLabelClass = style({\r\n paddingBlock: vars.space.xs2,\r\n paddingInline: vars.space.sm,\r\n fontSize: vars.fontSize.xs,\r\n fontWeight: vars.fontWeight.semibold,\r\n fontFamily: vars.fontFamily.sans,\r\n color: vars.color.mutedForeground,\r\n letterSpacing: vars.letterSpacing.wider,\r\n textTransform: 'uppercase',\r\n})\r\n","import * as RadixDropdownMenu from '@radix-ui/react-dropdown-menu'\r\n\r\nimport { cn } from '@utils/cn.ts'\r\nimport { dropdownMenuLabelClass } from '@components/overlay/dropdown-menu/components/label/dropdown-menu-label/DropdownMenuLabel.css.ts'\r\nimport { Typography } from '@components/foundation/typography'\r\nimport type { DropdownMenuLabelProps } from '@components/overlay/dropdown-menu/components/label/dropdown-menu-label/types/DropdownMenuLabel.props.ts'\r\n\r\n/**\r\n * A non-interactive section heading. Pair with `DropdownMenuGroup` for\r\n * semantic grouping of related items.\r\n */\r\nconst DropdownMenuLabel = ({ className, label, ...props }: DropdownMenuLabelProps) => (\r\n <RadixDropdownMenu.Label\r\n className={cn(dropdownMenuLabelClass, className)}\r\n {...props}\r\n >\r\n <Typography as={'span'} variant={'span'}>{label}</Typography>\r\n </RadixDropdownMenu.Label>\r\n)\r\n\r\nDropdownMenuLabel.displayName = 'DropdownMenuLabel'\r\n\r\nexport default DropdownMenuLabel\r\n","import { style } from '@vanilla-extract/css'\r\n\r\nimport { vars } from '@theme/contract.css.ts'\r\n\r\n/**\r\n * Thin horizontal rule between groups of items.\r\n * Extends marginInline to reach the panel edges.\r\n */\r\nexport const dropdownMenuSeparatorClass = style({\r\n marginBlock: vars.space.xs,\r\n marginInline: `calc(${vars.space.xs} * -1)`,\r\n height: '1px',\r\n backgroundColor: vars.color.border,\r\n opacity: 0.7,\r\n})\r\n","import * as RadixDropdownMenu from '@radix-ui/react-dropdown-menu'\r\n\r\nimport { cn } from '@utils/cn.ts'\r\nimport { dropdownMenuSeparatorClass } from '@components/overlay/dropdown-menu/components/separator/dropdown-menu-separator/DropdownMenuSeparator.css.ts'\r\nimport type { DropdownMenuSeparatorProps } from '@components/overlay/dropdown-menu/components/separator/dropdown-menu-separator/types/DropdownMenuSeparator.props.ts'\r\n\r\n/**\r\n * A thin horizontal rule used to visually divide groups of items.\r\n */\r\nconst DropdownMenuSeparator = ({ className, ...props }: DropdownMenuSeparatorProps) => (\r\n <RadixDropdownMenu.Separator\r\n className={cn(dropdownMenuSeparatorClass, className)}\r\n {...props}\r\n />\r\n)\r\n\r\nDropdownMenuSeparator.displayName = 'DropdownMenuSeparator'\r\n\r\nexport default DropdownMenuSeparator\r\n","import * as RadixDropdownMenu from '@radix-ui/react-dropdown-menu'\r\n\r\nimport type { DropdownMenuSubProps } from '@components/overlay/dropdown-menu/components/sub/dropdown-menu-sub/types/DropdownMenuSub.props.ts'\r\n\r\n/**\r\n * Wraps a nested sub-menu.\r\n * Use with `DropdownMenuSubTrigger` and `DropdownMenuSubContent`.\r\n */\r\nconst DropdownMenuSub = (props: DropdownMenuSubProps) => (\r\n <RadixDropdownMenu.Sub {...props} />\r\n)\r\n\r\nDropdownMenuSub.displayName = 'DropdownMenuSub'\r\n\r\nexport default DropdownMenuSub\r\n","import { style, globalStyle } from '@vanilla-extract/css'\r\n\r\nimport { vars } from '@theme/contract.css.ts'\r\nimport { dropdownMenuItemClass } from '@components/overlay/dropdown-menu/components/_shared/item.css.ts'\r\n\r\n/**\r\n * The item that opens a nested sub-menu on hover / focus.\r\n * Stays visually \"active\" while the sub-menu is open (data-state=\"open\").\r\n */\r\nexport const dropdownMenuSubTriggerClass = style([\r\n dropdownMenuItemClass,\r\n {\r\n selectors: {\r\n '&[data-state=\"open\"]': {\r\n backgroundColor: vars.color.primarySubtle,\r\n color: vars.color.primarySubtleForeground,\r\n },\r\n },\r\n },\r\n])\r\n\r\n/**\r\n * Trailing chevron icon. Rotates when the sub-menu is open.\r\n */\r\nexport const dropdownMenuSubTriggerChevronClass = style({\r\n marginLeft: 'auto',\r\n width: '1rem',\r\n height: '1rem',\r\n flexShrink: 0,\r\n color: vars.color.mutedForeground,\r\n transition: [\r\n `transform ${vars.duration.normal} ${vars.easing.emphasized}`,\r\n `color ${vars.duration.fast} ${vars.easing.standard}`,\r\n ].join(', '),\r\n\r\n selectors: {\r\n '[data-state=\"open\"] &': {\r\n color: vars.color.primarySubtleForeground,\r\n },\r\n '[data-highlighted] &': {\r\n color: vars.color.primarySubtleForeground,\r\n },\r\n },\r\n})\r\n\r\nglobalStyle(`${dropdownMenuSubTriggerChevronClass} svg`, {\r\n width: '1rem',\r\n height: '1rem',\r\n pointerEvents: 'none',\r\n})\r\n","import * as RadixDropdownMenu from '@radix-ui/react-dropdown-menu'\r\n\r\nimport { cn } from '@utils/cn.ts'\r\nimport {\r\n dropdownMenuSubTriggerClass,\r\n dropdownMenuSubTriggerChevronClass,\r\n} from '@components/overlay/dropdown-menu/components/sub/dropdown-menu-sub-trigger/DropdownMenuSubTrigger.css.ts'\r\nimport { dropdownMenuItemIconClass } from '@components/overlay/dropdown-menu/components/_shared/item.css.ts'\r\nimport { Flex } from '@components/layout/flex'\r\nimport { Icon } from '@components/foundation/icon'\r\nimport { Typography } from '@components/foundation/typography'\r\nimport type { DropdownMenuSubTriggerProps } from '@components/overlay/dropdown-menu/components/sub/dropdown-menu-sub-trigger/types/DropdownMenuSubTrigger.props.ts'\r\n\r\n/**\r\n * The item that opens the nested sub-menu on hover/focus.\r\n * A chevron icon is automatically appended on the right.\r\n */\r\nconst DropdownMenuSubTrigger = ({\r\n className,\r\n startIcon,\r\n label,\r\n ...props\r\n}: DropdownMenuSubTriggerProps) => (\r\n <RadixDropdownMenu.SubTrigger asChild {...props}>\r\n <Flex gap={'sm'} className={cn(dropdownMenuSubTriggerClass, className)}>\r\n {startIcon && (\r\n <Flex as={'span'} justify={'center'} className={dropdownMenuItemIconClass} aria-hidden>\r\n <Icon icon={startIcon} size={'xs'} />\r\n </Flex>\r\n )}\r\n <Typography as={'span'} variant={'span'} style={{ flex: 1 }}>{label}</Typography>\r\n <Flex as={'span'} justify={'center'} className={dropdownMenuSubTriggerChevronClass} aria-hidden>\r\n <Icon icon={'mdi:chevron-right'} size={'xs'} />\r\n </Flex>\r\n </Flex>\r\n </RadixDropdownMenu.SubTrigger>\r\n)\r\n\r\nDropdownMenuSubTrigger.displayName = 'DropdownMenuSubTrigger'\r\n\r\nexport default DropdownMenuSubTrigger\r\n\r\n","import { style } from '@vanilla-extract/css'\r\n\r\nimport { vars } from '@theme/contract.css.ts'\r\nimport { fadeIn, fadeOut } from '@constants/animations/index.ts'\r\nimport { dropdownMenuContentClass } from '@components/overlay/dropdown-menu/components/content/dropdown-menu-content/DropdownMenuContent.css.ts'\r\n\r\n/**\r\n * Nested sub-menu panel. Inherits all base panel styles from\r\n * dropdownMenuContentClass and uses a simple fade instead of a directional\r\n * slide (since the side direction is always the same as the parent).\r\n */\r\nexport const dropdownMenuSubContentClass = style([\r\n dropdownMenuContentClass,\r\n {\r\n selectors: {\r\n '&[data-state=\"open\"]': {\r\n animation: `${fadeIn} 0.15s ${vars.easing.out} both`,\r\n },\r\n '&[data-state=\"closed\"]': {\r\n animation: `${fadeOut} 0.10s ${vars.easing.in} both`,\r\n },\r\n },\r\n },\r\n])\r\n","import * as RadixDropdownMenu from '@radix-ui/react-dropdown-menu'\r\n\r\nimport { cn } from '@utils/cn.ts'\r\nimport { dropdownMenuSubContentClass } from '@components/overlay/dropdown-menu/components/sub/dropdown-menu-sub-content/DropdownMenuSubContent.css.ts'\r\nimport type { DropdownMenuSubContentProps } from '@components/overlay/dropdown-menu/components/sub/dropdown-menu-sub-content/types/DropdownMenuSubContent.props.ts'\r\nimport { useViewportShift } from '@hooks'\r\n\r\n/**\r\n * The panel that appears for a nested sub-menu.\r\n * Rendered in a portal for correct stacking.\r\n *\r\n * Same viewport-shift strategy as DropdownMenuContent:\r\n * Radix's side-flipping is disabled and replaced by an offset correction.\r\n */\r\nconst DropdownMenuSubContent = ({ className, collisionPadding = 8, ...props }: DropdownMenuSubContentProps) => {\r\n const contentRef = useViewportShift(collisionPadding)\r\n\r\n return (\r\n <RadixDropdownMenu.Portal>\r\n <RadixDropdownMenu.SubContent\r\n ref={contentRef}\r\n sideOffset={6}\r\n className={cn(dropdownMenuSubContentClass, className)}\r\n {...props}\r\n // Disable Radix's flip/shift — our hook handles collision instead.\r\n avoidCollisions={false}\r\n />\r\n </RadixDropdownMenu.Portal>\r\n )\r\n}\r\n\r\nDropdownMenuSubContent.displayName = 'DropdownMenuSubContent'\r\n\r\nexport default DropdownMenuSubContent\r\n"],"x_google_ignoreList":[23,34,54,55,56,57,58,59,60,61,62,63,64,71,72,73,74,75,76,82,83,84,85,86,87,88,89,90,91,92,93,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121],"mappings":"67MCMa,GAAM,GAAG,IAClB,EAAQ,OAAO,OAAO,CAAC,CAAC,KAAK,GAAG,wJYOvB,EAA4B,GAAyB,CAC9D,IAAI,EAAoB,GAElB,MAAsB,CAAE,EAAoB,EAAK,EACjD,EAAe,GAAwB,CACpC,GAAqB,EAAM,yBAAyB,EACzD,EAAoB,EACxB,EAKA,OAHA,EAAQ,iBAAiB,cAAe,EAAe,EAAI,EAC3D,EAAQ,iBAAiB,YAAa,EAAa,EAAI,MAE1C,CACT,EAAQ,oBAAoB,cAAe,EAAe,EAAI,EAC9D,EAAQ,oBAAoB,YAAa,EAAa,EAAI,CAC9D,CACJ,EC3Ba,EAAoB,GACzB,OAAO,GAAY,SACZ,CAAE,IAAK,EAAS,MAAO,EAAS,OAAQ,EAAS,KAAM,CAAQ,EAEnE,CAAE,IAAK,EAAG,MAAO,EAAG,OAAQ,EAAG,KAAM,EAAG,GAAG,CAAQ,ECJjD,EAAqB,QCC5B,EAAsB,GACxB,EAAQ,MAAM,UAAU,SAAS,CAAkB,EAOjD,GAAoB,EAAe,IAAmC,CACxE,IAAI,EAAK,EACL,EAAK,EAcT,OAZI,EAAK,MAAQ,OAAO,WAAa,EAAI,MACrC,EAAK,OAAO,WAAa,EAAI,MAAQ,EAAK,MACnC,EAAK,KAAO,EAAI,OACvB,EAAK,EAAI,KAAO,EAAK,MAGrB,EAAK,OAAS,OAAO,YAAc,EAAI,OACvC,EAAK,OAAO,YAAc,EAAI,OAAS,EAAK,OACrC,EAAK,IAAM,EAAI,MACtB,EAAK,EAAI,IAAM,EAAK,KAGhB,IAAO,GAAK,IAAO,EAAK,GAAG,KAAK,MAAM,CAAE,EAAE,KAAK,KAAK,MAAM,CAAE,EAAE,IAAM,EAChF,EASa,GACT,EACA,EACA,QACO,CACH,EAAmB,CAAO,IAC9B,EAAQ,MAAM,UAAY,EAAiB,EAAQ,sBAAsB,EAAG,EAAO,OAAO,EAC9F,ECpCa,GAAoB,EAAsB,EAAsB,IAAwB,CACjG,IAAM,EAAW,IAAI,iBAAiB,CAAO,EAC7C,EAAS,QAAQ,EAAS,CAAE,WAAY,GAAM,gBAAiB,CAAC,OAAO,CAAE,CAAC,EAE1E,IAAM,EAAS,IAAI,eAAe,CAAO,EAKzC,OAJA,EAAO,QAAQ,CAAO,EAEtB,OAAO,iBAAiB,SAAU,CAAO,MAE5B,CACT,EAAS,WAAW,EACpB,EAAO,WAAW,EAClB,OAAO,oBAAoB,SAAU,CAAO,CAChD,CACJ,ECLa,GAAoB,EAA4B,IAAM,CAG/D,IAAM,GAAA,EAAA,EAAA,OAAA,CAAgB,EAAiB,CAAgB,CAAC,EAGxD,MAFA,GAAO,QAAU,EAAiB,CAAgB,GAElD,EAAA,EAAA,YAAA,CAAoB,GAAwD,CAGxE,IAAM,EAAU,GAAS,cACzB,GAAI,CAAC,GAAW,CAAC,EAAW,OAG5B,IAAM,EAAe,EAAiB,EAAS,EAD/B,EAAgB,EAAS,EAAS,CACM,CAAO,EACzD,EAAe,EAAyB,CAAO,EAGrD,UAAa,CACT,EAAa,EACb,EAAa,CACjB,CACJ,EAAG,CAAC,CAAC,CACT,ECNa,GAAA,EAAA,EAAA,cAAA,CAAgD,CALzD,MAAO,SACP,cAAe,QACf,aAAgB,IAAA,EAGyC,CAAc,EAW9D,OAAA,EAAA,EAAA,WAAA,CAA+C,CAAY,ECzC3D,OACT,OAAO,OAAW,KAAe,OAAO,WAAW,8BAA8B,CAAC,CAAC,QAC7E,OACA,QCLG,GAAgB,EAAiB,IAC1C,IAAS,SAAW,EAAc,ECmChC,IAAyC,CAC3C,MAAO,EACP,eAAe,SACf,gBACA,SACA,QACA,WACA,GAAG,KACD,CAIF,GAAM,CAAC,EAAe,IAAA,EAAA,EAAA,SAAA,CAAwC,CAAY,EACpE,EAAc,GAAmB,EAIjC,CAAC,EAAa,IAAA,EAAA,EAAA,SAAA,CAA6C,EAAc,GAE/E,EAAA,EAAA,UAAA,KAAgB,CACZ,IAAM,EAAM,OAAO,WAAW,8BAA8B,EACtD,EAAW,GAA2B,EAAe,EAAE,QAAU,OAAS,OAAO,EAEvF,OADA,EAAI,iBAAiB,SAAU,CAAO,MACzB,EAAI,oBAAoB,SAAU,CAAO,CAC1D,EAAG,CAAC,CAAC,EAEL,IAAM,EAAgB,EAAa,EAAa,CAAW,EAIrD,EAAY,GAAoB,CAC9B,IAAoB,IAAA,IACpB,EAAiB,CAAI,EAEzB,IAAgB,CAAI,CACxB,EAIM,GAAA,EAAA,EAAA,QAAA,KACG,EACE,OAAO,YACV,OAAO,QAAQ,CAAM,CAAC,CAAC,KAAK,CAAC,EAAK,KAAW,CAAC,WAAW,IAAO,CAAK,CAAC,CAC1E,EAHsB,CAAC,EAIxB,CAAC,CAAM,CAAC,EAIX,OACI,EAAA,EAAA,IAAA,CAAC,EAAa,SAAd,CAAuB,MAAO,CAAE,MAAO,EAAa,gBAAe,UAAS,YACxE,EAAA,EAAA,IAAA,CAAC,MAAD,CACI,aAAY,EACZ,MAAO,CAAE,GAAG,EAAa,GAAG,CAAM,EAClC,GAAI,EAEH,UACA,CAAA,CACc,CAAA,CAE/B,EAEA,GAAc,YAAc,gBCnG5B,SAAS,GAAY,EAAG,EAAG,CACzB,GAAgB,OAAO,GAAnB,UAAwB,CAAC,EAAG,OAAO,EACvC,IAAI,EAAI,EAAE,OAAO,aACjB,GAAe,IAAX,IAAK,GAAS,CAChB,IAAI,EAAI,EAAE,KAAK,EAAG,GAAK,SAAS,EAChC,GAAgB,OAAO,GAAnB,SAAsB,OAAO,EACjC,MAAU,UAAU,8CAA8C,CACpE,CACA,OAAqB,IAAb,SAAiB,OAAS,OAAA,CAAQ,CAAC,CAC7C,CAEA,SAAS,GAAc,EAAG,CACxB,IAAI,EAAI,GAAY,EAAG,QAAQ,EAC/B,OAAmB,OAAO,GAAnB,SAAuB,EAAI,OAAO,CAAC,CAC5C,CAEA,SAAS,GAAgB,EAAK,EAAK,EAAO,CAYxC,MAXA,GAAM,GAAc,CAAG,EACnB,KAAO,EACT,OAAO,eAAe,EAAK,EAAK,CACvB,QACP,WAAY,GACZ,aAAc,GACd,SAAU,EACZ,CAAC,EAED,EAAI,GAAO,EAEN,CACT,CAEA,SAAS,GAAQ,EAAG,EAAG,CACrB,IAAI,EAAI,OAAO,KAAK,CAAC,EACrB,GAAI,OAAO,sBAAuB,CAChC,IAAI,EAAI,OAAO,sBAAsB,CAAC,EACtC,IAAM,EAAI,EAAE,OAAO,SAAU,EAAG,CAC9B,OAAO,OAAO,yBAAyB,EAAG,CAAC,CAAC,CAAC,UAC/C,CAAC,GAAI,EAAE,KAAK,MAAM,EAAG,CAAC,CACxB,CACA,OAAO,CACT,CACA,SAAS,GAAe,EAAG,CACzB,IAAK,IAAI,EAAI,EAAG,EAAI,UAAU,OAAQ,IAAK,CACzC,IAAI,EAAY,UAAU,IAAlB,KAAsC,CAAC,EAAhB,UAAU,GACzC,EAAI,EAAI,GAAQ,OAAO,CAAC,EAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,SAAU,EAAG,CAClD,GAAgB,EAAG,EAAG,EAAE,EAAE,CAC5B,CAAC,EAAI,OAAO,0BAA4B,OAAO,iBAAiB,EAAG,OAAO,0BAA0B,CAAC,CAAC,EAAI,GAAQ,OAAO,CAAC,CAAC,CAAC,CAAC,QAAQ,SAAU,EAAG,CAChJ,OAAO,eAAe,EAAG,EAAG,OAAO,yBAAyB,EAAG,CAAC,CAAC,CACnE,CAAC,CACH,CACA,OAAO,CACT,CAEA,SAAS,GAAU,EAAO,EAAI,CAC5B,IAAI,EAAS,CAAC,EACd,IAAK,IAAI,KAAQ,EACf,EAAO,GAAQ,EAAG,EAAM,GAAO,CAAI,EAErC,OAAO,CACT,CAEA,IAAI,IAAuB,EAAe,EAAY,IAAoB,CACxE,IAAK,IAAI,KAAO,OAAO,KAAK,CAAa,EAEvC,GAAI,EAAc,MAA6B,EAAW,IAAiE,EAAgB,IACzI,MAAO,GAGX,MAAO,EACT,EACI,EAAkB,GAAU,CAC9B,IAAI,EAAY,GAAW,CACzB,IAAI,EAAY,EAAO,iBACnB,EAAa,GAAe,GAAe,CAAC,EAAG,EAAO,eAAe,EAAG,CAAO,EACnF,IAAK,IAAI,KAAe,EAAY,CAClC,IACI,EAA4C,EAAW,IAAqF,EAAO,gBAAgB,GACvK,GAAI,GAAoB,KAAM,CAC5B,IAAI,EAAY,EACZ,OAAO,GAAc,YAEvB,EAAY,IAAc,GAAO,OAAS,SAE5C,IAAI,EAEJ,EAAO,kBAAkB,EAAY,CAAC,GAClC,IACF,GAAa,IAAM,EAEvB,CACF,CACA,IAAK,GAAI,CAAC,EAAe,KAAsB,EAAO,iBAChD,GAAoB,EAAe,EAAY,EAAO,eAAe,IACvE,GAAa,IAAM,GAGvB,OAAO,CACT,EAUA,MATA,GAAU,aAAiB,OAAO,KAAK,EAAO,iBAAiB,EAC/D,EAAU,WAAa,CACrB,IAAI,MAAO,CACT,OAAO,EAAO,iBAAiB,MAAM,GAAG,CAAC,CAAC,EAC5C,EACA,IAAI,UAAW,CACb,OAAO,GAAU,EAAO,kBAAmB,GAAc,GAAU,EAAY,GAAa,EAAU,MAAM,GAAG,CAAC,CAAC,EAAE,CAAC,CACtH,CACF,EACO,CACT,2MEhGM,IAAyB,CAAE,OAAM,UAAS,WAAU,QAAO,YAAW,MAAK,GAAG,MAChF,EAAA,EAAA,IAAA,CAAC,MAAD,CACI,UAAW,GAIX,SAAU,YAEV,EAAA,EAAA,IAAA,CAAC,QAAD,CACS,MACL,UAAW,EACP,GAAY,CAAE,MAAK,CAAC,EACpB,GAAA,UACA,GAAA,UACA,GAAA,UACA,CACJ,EACA,GAAI,CACP,CAAA,CACA,CAAA,EAGT,GAAM,YAAc,2BE5Bd,IAAqC,CAAE,YAAW,MAAK,GAAG,MAC5D,EAAA,EAAA,IAAA,CAAC,QAAD,CACS,MACL,UAAW,EAAG,GAAkB,CAAS,EACzC,GAAI,CACP,CAAA,EAGL,GAAY,YAAc,+BERpB,IAAiC,CAAE,YAAW,MAAK,GAAG,MACxD,EAAA,EAAA,IAAA,CAAC,QAAD,CACS,MACL,UAAW,EAAG,GAAgB,CAAS,EACvC,GAAI,CACP,CAAA,EAGL,GAAU,YAAc,+BERlB,IAAqC,CAAE,YAAW,MAAK,GAAG,MAC5D,EAAA,EAAA,IAAA,CAAC,QAAD,CACS,MACL,UAAW,EAAG,GAAkB,CAAS,EACzC,GAAI,CACP,CAAA,EAGL,GAAY,YAAc,gpBERpB,IAA+B,CACjC,YACA,aACA,WACA,SACA,YACA,MACA,YACA,GAAG,MAWC,EAAA,EAAA,IAAA,CAAC,KAAD,CACS,MACL,cAAa,EACb,gBAAe,EAAa,GAAY,GAAQ,IAAA,GAChD,SAAU,EAAa,EAAI,IAAA,GAC3B,UAAW,GAAc,EAdV,GAA0C,CACzD,IAAe,EAAE,MAAQ,SAAW,EAAE,MAAQ,OAC9C,EAAE,eAAe,EACjB,EAAE,cAAc,MAAM,GAE1B,IAAY,CAAC,CACjB,EAQ6D,IAAA,GACrD,UAAW,EAAG,GAAe,CAAE,YAAW,aAAY,WAAU,QAAO,CAAC,EAAG,CAAS,EACpF,GAAI,CACP,CAAA,EAIT,GAAS,YAAc,WC5BvB,SAAS,GAAa,EAAM,EAAO,CAClC,IAAM,EAAQ,EAAK,MACb,EAAU,EAAK,SAAW,OAAO,OAAO,IAAI,EAC5C,EAAW,OAAO,OAAO,IAAI,EACnC,SAAS,EAAQ,EAAM,CACtB,GAAI,EAAM,GAAO,MAAO,GAAS,GAAQ,CAAC,EAC1C,GAAI,EAAE,KAAQ,GAAW,CACxB,EAAS,GAAQ,KACjB,IAAM,EAAS,EAAQ,IAAS,EAAQ,EAAK,CAAC,OACxC,EAAQ,GAAU,EAAQ,CAAM,EAClC,IAAO,EAAS,GAAQ,CAAC,CAAM,CAAC,CAAC,OAAO,CAAK,EAClD,CACA,OAAO,EAAS,EACjB,CAEA,OADA,OAAQ,KAAK,CAAK,CAAC,CAAC,OAAO,OAAO,KAAK,CAAO,CAAC,CAAC,CAAE,QAAQ,CAAO,EAC1D,CACR,CAKA,IAAM,GAAwB,OAAO,OAAO,CAC3C,KAAM,EACN,IAAK,EACL,MAAO,GACP,OAAQ,EACT,CAAC,EAIK,GAA6B,OAAO,OAAO,CAChD,OAAQ,EACR,MAAO,GACP,MAAO,EACR,CAAC,EAIK,GAAmB,OAAO,OAAO,CACtC,GAAG,GACH,GAAG,EACJ,CAAC,EAIK,GAA2B,OAAO,OAAO,CAC9C,GAAG,GACH,KAAM,GACN,OAAQ,EACT,CAAC,EAKD,SAAS,GAAyB,EAAM,EAAM,CAC7C,IAAM,EAAS,CAAC,EACZ,CAAC,EAAK,OAAU,CAAC,EAAK,QAAO,EAAO,MAAQ,IAC5C,CAAC,EAAK,OAAU,CAAC,EAAK,QAAO,EAAO,MAAQ,IAChD,IAAM,IAAW,EAAK,QAAU,IAAM,EAAK,QAAU,IAAM,EAE3D,OADI,IAAQ,EAAO,OAAS,GACrB,CACR,CAOA,SAAS,GAAc,EAAQ,EAAO,CACrC,IAAM,EAAS,GAAyB,EAAQ,CAAK,EACrD,IAAK,IAAM,KAAO,GAA8B,KAAO,GAClD,KAAO,GAAU,EAAE,KAAO,KAAS,EAAO,GAAO,GAA2B,IACtE,KAAO,EAAO,EAAO,GAAO,EAAM,GACpC,KAAO,IAAQ,EAAO,GAAO,EAAO,IAC7C,OAAO,CACR,CAKA,SAAS,GAAoB,EAAM,EAAM,EAAM,CAC9C,IAAM,EAAQ,EAAK,MACb,EAAU,EAAK,SAAW,OAAO,OAAO,IAAI,EAC9C,EAAe,CAAC,EACpB,SAAS,EAAM,EAAQ,CACtB,EAAe,GAAc,EAAM,IAAW,EAAQ,GAAS,CAAY,CAC5E,CAGA,OAFA,EAAM,CAAI,EACV,EAAK,QAAQ,CAAK,EACX,GAAc,EAAM,CAAY,CACxC,CAOA,SAAS,GAAa,EAAM,EAAU,CACrC,IAAM,EAAQ,CAAC,EACf,GAAI,OAAO,GAAS,UAAY,OAAO,EAAK,OAAU,SAAU,OAAO,EACnE,EAAK,qBAAqB,OAAO,EAAK,UAAU,QAAS,GAAS,CACrE,EAAS,EAAM,IAAI,EACnB,EAAM,KAAK,CAAI,CAChB,CAAC,EACD,IAAM,EAAO,GAAa,CAAI,EAC9B,IAAK,IAAM,KAAQ,EAAM,CACxB,IAAM,EAAO,EAAK,GACd,IACH,EAAS,EAAM,GAAoB,EAAM,EAAM,CAAI,CAAC,EACpD,EAAM,KAAK,CAAI,EAEjB,CACA,OAAO,CACR,CAKA,IAAM,GAA2B,CAChC,SAAU,GACV,QAAS,CAAC,EACV,UAAW,CAAC,EACZ,GAAG,EACJ,EAIA,SAAS,GAAmB,EAAM,EAAU,CAC3C,IAAK,IAAM,KAAQ,EAAU,GAAI,KAAQ,GAAQ,OAAO,EAAK,IAAU,OAAO,EAAS,GAAO,MAAO,GACrG,MAAO,EACR,CAOA,SAAS,GAAuB,EAAK,CACpC,GAAI,OAAO,GAAQ,WAAY,EAAc,OAAO,KACpD,IAAM,EAAO,EAEb,GADI,OAAO,EAAK,QAAW,UAAY,CAAC,EAAI,OAAS,OAAO,EAAI,OAAU,UACtE,CAAC,GAAmB,EAAK,EAAwB,EAAG,OAAO,KAC/D,IAAM,EAAQ,EAAK,MACnB,IAAK,IAAM,KAAQ,EAAO,CACzB,IAAM,EAAO,EAAM,GACnB,GAAI,CAAC,GAAQ,OAAO,EAAK,MAAS,UAAY,CAAC,GAAmB,EAAM,EAAwB,EAAG,OAAO,IAC3G,CACA,IAAM,EAAU,EAAK,SAAW,OAAO,OAAO,IAAI,EAClD,IAAK,IAAM,KAAQ,EAAS,CAC3B,IAAM,EAAO,EAAQ,GACf,EAAS,EAAK,OACpB,GAAI,CAAC,GAAQ,OAAO,GAAW,UAAY,CAAC,EAAM,IAAW,CAAC,EAAQ,IAAW,CAAC,GAAmB,EAAM,EAAwB,EAAG,OAAO,IAC9I,CACA,OAAO,CACR,CAKA,IAAM,GAAc,OAAO,OAAO,IAAI,EAItC,SAAS,GAAW,EAAU,EAAQ,CACrC,MAAO,CACN,WACA,SACA,MAAO,OAAO,OAAO,IAAI,EACzB,QAAyB,IAAI,GAC9B,CACD,CAIA,SAAS,GAAW,EAAU,EAAQ,CACrC,IAAM,EAAkB,GAAY,KAAc,GAAY,GAAY,OAAO,OAAO,IAAI,GAC5F,OAAO,EAAgB,KAAY,EAAgB,GAAU,GAAW,EAAU,CAAM,EACzF,CAMA,SAAS,GAAW,EAAS,EAAM,CAElC,OADK,GAAuB,CAAI,EACzB,GAAa,GAAO,EAAM,IAAS,CACrC,EAAM,EAAQ,MAAM,GAAQ,EAC3B,EAAQ,QAAQ,IAAI,CAAI,CAC9B,CAAC,EAJyC,CAAC,CAK5C,CAIA,SAAS,GAAiB,EAAS,EAAM,EAAM,CAC9C,GAAI,CACH,GAAI,OAAO,EAAK,MAAS,SAExB,MADA,GAAQ,MAAM,GAAQ,CAAE,GAAG,CAAK,EACzB,EAET,MAAc,CAAC,CACf,MAAO,EACR,CAuBA,IAAM,GAAgB,2BAIhB,IAAgB,EAAO,EAAU,EAAiB,EAAW,KAAO,CACzE,IAAM,EAAiB,EAAM,MAAM,GAAG,EACtC,GAAI,EAAM,MAAM,EAAG,CAAC,IAAM,IAAK,CAC9B,GAAI,EAAe,OAAS,GAAK,EAAe,OAAS,EAAG,OAAO,KACnE,EAAW,EAAe,MAAM,CAAC,CAAC,MAAM,CAAC,CAC1C,CACA,GAAI,EAAe,OAAS,GAAK,CAAC,EAAe,OAAQ,OAAO,KAChE,GAAI,EAAe,OAAS,EAAG,CAC9B,IAAM,EAAS,EAAe,IAAI,EAC5B,EAAS,EAAe,IAAI,EAC5B,EAAS,CACd,SAAU,EAAe,OAAS,EAAI,EAAe,GAAK,EAC1D,SACA,KAAM,CACP,EACA,OAAO,GAAY,CAAC,GAAiB,CAAM,EAAI,KAAO,CACvD,CACA,IAAM,EAAO,EAAe,GACtB,EAAgB,EAAK,MAAM,GAAG,EACpC,GAAI,EAAc,OAAS,EAAG,CAC7B,IAAM,EAAS,CACd,WACA,OAAQ,EAAc,MAAM,EAC5B,KAAM,EAAc,KAAK,GAAG,CAC7B,EACA,OAAO,GAAY,CAAC,GAAiB,CAAM,EAAI,KAAO,CACvD,CACA,GAAI,GAAmB,IAAa,GAAI,CACvC,IAAM,EAAS,CACd,WACA,OAAQ,GACR,MACD,EACA,OAAO,GAAY,CAAC,GAAiB,EAAQ,CAAe,EAAI,KAAO,CACxE,CACA,OAAO,IACR,EAMM,IAAoB,EAAM,IAC1B,EACE,CAAC,GAAG,GAAmB,EAAK,SAAW,IAAQ,EAAK,SAAa,EAAK,MAD3D,GAOf,GAAc,GAClB,SAAS,GAAiB,EAAO,CAEhC,OADI,OAAO,GAAU,YAAW,GAAc,GACvC,EACR,CASA,SAAS,GAAY,EAAM,CAC1B,IAAM,EAAO,OAAO,GAAS,SAAW,GAAa,EAAM,GAAM,EAAW,EAAI,EAChF,GAAI,EAAM,CACT,IAAM,EAAU,GAAW,EAAK,SAAU,EAAK,MAAM,EAC/C,EAAW,EAAK,KACtB,OAAO,EAAQ,MAAM,KAAc,EAAQ,QAAQ,IAAI,CAAQ,EAAI,KAAO,IAAK,GAChF,CACD,CAIA,SAAS,GAAQ,EAAM,EAAM,CAC5B,IAAM,EAAO,GAAa,EAAM,GAAM,EAAW,EACjD,GAAI,CAAC,EAAM,MAAO,GAClB,IAAM,EAAU,GAAW,EAAK,SAAU,EAAK,MAAM,EAIpD,OAHG,EAAa,GAAiB,EAAS,EAAK,KAAM,CAAI,GAEzD,EAAQ,QAAQ,IAAI,EAAK,IAAI,EACtB,GAET,CAIA,SAAS,GAAc,EAAM,EAAU,CACtC,GAAI,OAAO,GAAS,SAAU,MAAO,GAErC,GADI,OAAO,GAAa,WAAU,EAAW,EAAK,UAAY,IAC1D,IAAe,CAAC,GAAY,CAAC,EAAK,OAAQ,CAC7C,IAAI,EAAQ,GAOZ,OANI,GAAuB,CAAI,IAC9B,EAAK,OAAS,GACd,GAAa,GAAO,EAAM,IAAS,CAC9B,GAAQ,EAAM,CAAI,IAAG,EAAQ,GAClC,CAAC,GAEK,CACR,CACA,IAAM,EAAS,EAAK,OAMpB,OALK,GAAiB,CACrB,SACA,KAAM,GACP,CAAC,EAEM,CAAC,CAAC,GADO,GAAW,EAAU,CACX,EAAG,CAAI,EAFtB,EAGZ,CAqBA,IAAM,GAAgC,OAAO,OAAO,CACnD,MAAO,KACP,OAAQ,IACT,CAAC,EACK,GAA4B,OAAO,OAAO,CAC/C,GAAG,GACH,GAAG,EACJ,CAAC,EAKK,GAAa,4BACb,GAAY,4BAClB,SAAS,GAAc,EAAM,EAAO,EAAW,CAC9C,GAAI,IAAU,EAAG,OAAO,EAExB,GADA,IAAyB,IACrB,OAAO,GAAS,SAAU,OAAO,KAAK,KAAK,EAAO,EAAQ,CAAS,EAAI,EAC3E,GAAI,OAAO,GAAS,SAAU,OAAO,EACrC,IAAM,EAAW,EAAK,MAAM,EAAU,EACtC,GAAI,IAAa,MAAQ,CAAC,EAAS,OAAQ,OAAO,EAClD,IAAM,EAAW,CAAC,EACd,EAAO,EAAS,MAAM,EACtB,EAAW,GAAU,KAAK,CAAI,EAClC,OAAa,CACZ,GAAI,EAAU,CACb,IAAM,EAAM,WAAW,CAAI,EACvB,MAAM,CAAG,EAAG,EAAS,KAAK,CAAI,EAC7B,EAAS,KAAK,KAAK,KAAK,EAAM,EAAQ,CAAS,EAAI,CAAS,CAClE,MAAO,EAAS,KAAK,CAAI,EAEzB,GADA,EAAO,EAAS,MAAM,EAClB,IAAS,IAAK,GAAG,OAAO,EAAS,KAAK,EAAE,EAC5C,EAAW,CAAC,CACb,CACD,CAEA,SAAS,GAAa,EAAS,EAAM,OAAQ,CAC5C,IAAI,EAAO,GACL,EAAQ,EAAQ,QAAQ,IAAM,CAAG,EACvC,KAAO,GAAS,GAAG,CAClB,IAAM,EAAQ,EAAQ,QAAQ,IAAK,CAAK,EAClC,EAAM,EAAQ,QAAQ,KAAO,CAAG,EACtC,GAAI,IAAU,IAAM,IAAQ,GAAI,MAChC,IAAM,EAAS,EAAQ,QAAQ,IAAK,CAAG,EACvC,GAAI,IAAW,GAAI,MACnB,GAAQ,EAAQ,MAAM,EAAQ,EAAG,CAAG,CAAC,CAAC,KAAK,EAC3C,EAAU,EAAQ,MAAM,EAAG,CAAK,CAAC,CAAC,KAAK,EAAI,EAAQ,MAAM,EAAS,CAAC,CACpE,CACA,MAAO,CACN,OACA,SACD,CACD,CAIA,SAAS,GAAoB,EAAM,EAAS,CAC3C,OAAO,EAAO,SAAW,EAAO,UAAY,EAAU,CACvD,CAIA,SAAS,GAAe,EAAM,EAAO,EAAK,CACzC,IAAM,EAAQ,GAAa,CAAI,EAC/B,OAAO,GAAoB,EAAM,KAAM,EAAQ,EAAM,QAAU,CAAG,CACnE,CAKA,IAAM,GAAkB,GAAU,IAAU,SAAW,IAAU,aAAe,IAAU,OAW1F,SAAS,GAAU,EAAM,EAAgB,CACxC,IAAM,EAAW,CAChB,GAAG,GACH,GAAG,CACJ,EACM,EAAqB,CAC1B,GAAG,GACH,GAAG,CACJ,EACM,EAAM,CACX,KAAM,EAAS,KACf,IAAK,EAAS,IACd,MAAO,EAAS,MAChB,OAAQ,EAAS,MAClB,EACI,EAAO,EAAS,KACpB,CAAC,EAAU,CAAkB,CAAC,CAAC,QAAS,GAAU,CACjD,IAAM,EAAkB,CAAC,EACnB,EAAQ,EAAM,MACd,EAAQ,EAAM,MAChB,EAAW,EAAM,OACjB,EAAW,EAAO,GAAY,GAEjC,EAAgB,KAAK,cAAgB,EAAI,MAAQ,EAAI,KAAA,CAAM,SAAS,EAAI,KAAO,EAAI,EAAI,IAAA,CAAK,SAAS,EAAI,GAAG,EAC5G,EAAgB,KAAK,aAAa,EAClC,EAAI,IAAM,EAAI,KAAO,GAEb,IACR,EAAgB,KAAK,cAAgB,EAAI,EAAI,KAAA,CAAM,SAAS,EAAI,KAAO,EAAI,OAAS,EAAI,IAAA,CAAK,SAAS,EAAI,GAAG,EAC7G,EAAgB,KAAK,aAAa,EAClC,EAAI,IAAM,EAAI,KAAO,GAEtB,IAAI,EAGJ,OAFI,EAAW,IAAG,GAAY,KAAK,MAAM,EAAW,CAAC,EAAI,GACzD,GAAsB,EACd,EAAR,CACC,IAAK,GACJ,EAAY,EAAI,OAAS,EAAI,EAAI,IACjC,EAAgB,QAAQ,aAAe,EAAU,SAAS,EAAI,IAAM,EAAU,SAAS,EAAI,GAAG,EAC9F,MACD,IAAK,GACJ,EAAgB,QAAQ,eAAiB,EAAI,MAAQ,EAAI,EAAI,KAAA,CAAM,SAAS,EAAI,KAAO,EAAI,OAAS,EAAI,EAAI,IAAA,CAAK,SAAS,EAAI,GAAG,EACjI,MACD,IAAK,GACJ,EAAY,EAAI,MAAQ,EAAI,EAAI,KAChC,EAAgB,QAAQ,cAAgB,EAAU,SAAS,EAAI,IAAM,EAAU,SAAS,EAAI,GAAG,EAC/F,KACF,CACI,EAAW,GAAM,IAChB,EAAI,OAAS,EAAI,MACpB,EAAY,EAAI,KAChB,EAAI,KAAO,EAAI,IACf,EAAI,IAAM,GAEP,EAAI,QAAU,EAAI,SACrB,EAAY,EAAI,MAChB,EAAI,MAAQ,EAAI,OAChB,EAAI,OAAS,IAGX,EAAgB,SAAQ,EAAO,GAAe,EAAM,iBAAoB,EAAgB,KAAK,GAAG,EAAI,KAAO,MAAM,EACtH,CAAC,EACD,IAAM,EAAsB,EAAmB,MACzC,EAAuB,EAAmB,OAC1C,EAAW,EAAI,MACf,EAAY,EAAI,OAClB,EACA,EACA,IAAwB,MAC3B,EAAS,IAAyB,KAAO,MAAQ,IAAyB,OAAS,EAAY,EAC/F,EAAQ,GAAc,EAAQ,EAAW,CAAS,IAElD,EAAQ,IAAwB,OAAS,EAAW,EACpD,EAAS,IAAyB,KAAO,GAAc,EAAO,EAAY,CAAQ,EAAI,IAAyB,OAAS,EAAY,GAErI,IAAM,EAAa,CAAC,EACd,GAAW,EAAM,IAAU,CAC3B,GAAe,CAAK,IAAG,EAAW,GAAQ,EAAM,SAAS,EAC/D,EACA,EAAQ,QAAS,CAAK,EACtB,EAAQ,SAAU,CAAM,EACxB,IAAM,EAAU,CACf,EAAI,KACJ,EAAI,IACJ,EACA,CACD,EAEA,MADA,GAAW,QAAU,EAAQ,KAAK,GAAG,EAC9B,CACN,aACA,UACA,MACD,CACD,CAkBA,IAAM,GAAQ,gBAMR,GAAe,YAAc,KAAK,IAAI,CAAC,CAAC,SAAS,EAAE,GAAK,KAAK,OAAO,EAAI,SAAW,EAAA,CAAG,SAAS,EAAE,EAInG,GAAU,EAId,SAAS,GAAW,EAAM,EAAS,GAAc,CAChD,IAAM,EAAM,CAAC,EACT,EACJ,KAAO,EAAQ,GAAM,KAAK,CAAI,GAAG,EAAI,KAAK,EAAM,EAAE,EAClD,GAAI,CAAC,EAAI,OAAQ,OAAO,EACxB,IAAM,EAAS,UAAY,KAAK,OAAO,EAAI,SAAW,KAAK,IAAI,EAAA,CAAG,SAAS,EAAE,EAO7E,OANA,EAAI,QAAS,GAAO,CACnB,IAAM,EAAQ,OAAO,GAAW,WAAa,EAAO,CAAE,EAAI,GAAU,KAAA,CAAW,SAAS,EAClF,EAAY,EAAG,QAAQ,sBAAuB,MAAM,EAC1D,EAAO,EAAK,QAAY,OAAO,WAAc,EAAY,mBAAqB,GAAG,EAAG,KAAO,EAAQ,EAAS,IAAI,CACjH,CAAC,EACD,EAAO,EAAK,QAAQ,IAAI,OAAO,EAAQ,GAAG,EAAG,EAAE,EACxC,CACR,CAKA,IAAM,GAAU,OAAO,OAAO,IAAI,EAIlC,SAAS,GAAa,EAAU,EAAM,CACrC,GAAQ,GAAY,CACrB,CAIA,SAAS,GAAa,EAAU,CAC/B,OAAO,GAAQ,IAAa,GAAQ,GACrC,CAKA,SAAS,GAAgB,EAAQ,CAChC,IAAI,EACJ,GAAI,OAAO,EAAO,WAAc,SAAU,EAAY,CAAC,EAAO,SAAS,OAGtE,GADA,EAAY,EAAO,UACf,EAAE,aAAqB,QAAU,CAAC,EAAU,OAAQ,OAAO,KAYhE,MAAO,CATN,YACA,KAAM,EAAO,MAAQ,IACrB,OAAQ,EAAO,QAAU,IACzB,OAAQ,EAAO,QAAU,IACzB,QAAS,EAAO,SAAW,IAC3B,OAAQ,EAAO,SAAW,GAC1B,MAAO,EAAO,OAAS,EACvB,iBAAkB,EAAO,mBAAqB,EAEnC,CACb,CAsBA,IAlBA,IAAM,GAAgB,OAAO,OAAO,IAAI,EAgBlC,GAAqB,CAAC,4BAA6B,wBAAwB,EAC3E,GAAc,CAAC,EACd,GAAmB,OAAS,GAAO,GAAmB,SAAW,GAC/D,KAAK,OAAO,EAAI,GADkD,GAAY,KAAK,GAAmB,MAAM,CAAC,EAEjH,GAAY,KAAK,GAAmB,IAAI,CAAC,EAC9C,GAAc,IAAM,GAAgB,CAAE,UAAW,CAAC,4BAA4B,CAAC,CAAC,OAAO,EAAW,CAAE,CAAC,EAIrG,SAAS,GAAe,EAAU,EAAc,CAC/C,IAAM,EAAS,GAAgB,CAAY,EAG3C,OAFI,IAAW,KAAa,IAC5B,GAAc,GAAY,EACnB,GACR,CAIA,SAAS,GAAa,EAAU,CAC/B,OAAO,GAAc,EACtB,CAkBA,IAAI,QAVsB,CACzB,IAAI,EACJ,GAAI,CAEH,GADA,EAAW,MACP,OAAO,GAAa,WAAY,OAAO,CAC5C,MAAc,CAAC,CAChB,EAIkB,CAAY,EAgB9B,SAAS,GAAmB,EAAU,EAAQ,CAC7C,IAAM,EAAS,GAAa,CAAQ,EACpC,GAAI,CAAC,EAAQ,MAAO,GACpB,IAAI,EACJ,GAAI,CAAC,EAAO,OAAQ,EAAS,MACxB,CACJ,IAAI,EAAgB,EACpB,EAAO,UAAU,QAAS,GAAS,CAElC,EAAgB,KAAK,IAAI,EAAeA,EAAK,MAAM,CACpD,CAAC,EACD,IAAM,EAAM,EAAS,eACrB,EAAS,EAAO,OAAS,EAAgB,EAAO,KAAK,OAAS,EAAI,MACnE,CACA,OAAO,CACR,CAIA,SAAS,GAAY,EAAQ,CAC5B,OAAO,IAAW,GACnB,CAIA,IAAM,IAAW,EAAU,EAAQ,IAAU,CAC5C,IAAM,EAAU,CAAC,EACX,EAAY,GAAmB,EAAU,CAAM,EAC/C,EAAO,QACT,EAAO,CACV,OACA,WACA,SACA,MAAO,CAAC,CACT,EACI,EAAS,EAgBb,OAfA,EAAM,SAAS,EAAM,IAAU,CAC9B,GAAU,EAAK,OAAS,EACpB,GAAU,GAAa,EAAQ,IAClC,EAAQ,KAAK,CAAI,EACjB,EAAO,CACN,OACA,WACA,SACA,MAAO,CAAC,CACT,EACA,EAAS,EAAK,QAEf,EAAK,MAAM,KAAK,CAAI,CACrB,CAAC,EACD,EAAQ,KAAK,CAAI,EACV,CACR,EAIA,SAAS,GAAQ,EAAU,CAC1B,GAAI,OAAO,GAAa,SAAU,CACjC,IAAM,EAAS,GAAa,CAAQ,EACpC,GAAI,EAAQ,OAAO,EAAO,IAC3B,CACA,MAAO,GACR,CAyDA,IAAM,GAAiB,CACtB,WACA,MAvDa,EAAM,EAAQ,IAAa,CACxC,GAAI,CAAC,GAAa,CACjB,EAAS,QAAS,GAAG,EACrB,MACD,CACA,IAAI,EAAO,GAAQ,EAAO,QAAQ,EAClC,OAAQ,EAAO,KAAf,CACC,IAAK,QAAS,CACb,IAAM,EAAS,EAAO,OAEhB,EADQ,EAAO,MACG,KAAK,GAAG,EAC1B,EAAY,IAAI,gBAAgB,CAAE,MAAO,CAAU,CAAC,EAC1D,GAAQ,EAAS,SAAW,EAAU,SAAS,EAC/C,KACD,CACA,IAAK,SAAU,CACd,IAAM,EAAM,EAAO,IACnB,GAAQ,EAAI,MAAM,EAAG,CAAC,IAAM,IAAM,EAAI,MAAM,CAAC,EAAI,EACjD,KACD,CACA,QACC,EAAS,QAAS,GAAG,EACrB,MACF,CACA,IAAI,EAAe,IACnB,GAAY,EAAO,CAAI,CAAC,CAAC,KAAM,GAAa,CAC3C,IAAM,EAAS,EAAS,OACxB,GAAI,IAAW,IAAK,CACnB,eAAiB,CAChB,EAAS,GAAY,CAAM,EAAI,QAAU,OAAQ,CAAM,CACxD,CAAC,EACD,MACD,CAEA,MADA,GAAe,IACR,EAAS,KAAK,CACtB,CAAC,CAAC,CAAC,KAAM,GAAS,CACjB,GAAI,OAAO,GAAS,WAAY,EAAe,CAC9C,eAAiB,CACZ,IAAS,IAAK,EAAS,QAAS,CAAI,EACnC,EAAS,OAAQ,CAAY,CACnC,CAAC,EACD,MACD,CACA,eAAiB,CAChB,EAAS,UAAW,CAAI,CACzB,CAAC,CACF,CAAC,CAAC,CAAC,UAAY,CACd,EAAS,OAAQ,CAAY,CAC9B,CAAC,CACF,CAOA,EAKA,SAAS,GAAe,EAAU,EAAI,CACrC,EAAS,QAAS,GAAY,CAC7B,IAAM,EAAQ,EAAQ,gBAClB,IAAO,EAAQ,gBAAkB,EAAM,OAAQ,GAAQ,EAAI,KAAO,CAAE,EACzE,CAAC,CACF,CAIA,SAAS,GAAgB,EAAS,CAC5B,EAAQ,uBACZ,EAAQ,qBAAuB,GAC/B,eAAiB,CAChB,EAAQ,qBAAuB,GAC/B,IAAM,EAAQ,EAAQ,gBAAkB,EAAQ,gBAAgB,MAAM,CAAC,EAAI,CAAC,EAC5E,GAAI,CAAC,EAAM,OAAQ,OACnB,IAAI,EAAa,GACX,EAAW,EAAQ,SACnB,EAAS,EAAQ,OACvB,EAAM,QAAS,GAAS,CACvB,IAAM,EAAQ,EAAK,MACb,EAAY,EAAM,QAAQ,OAChC,EAAM,QAAU,EAAM,QAAQ,OAAQ,GAAS,CAC9C,GAAI,EAAK,SAAW,EAAQ,MAAO,GACnC,IAAM,EAAO,EAAK,KAClB,GAAI,EAAQ,MAAM,GAAO,EAAM,OAAO,KAAK,CAC1C,WACA,SACA,MACD,CAAC,OACI,GAAI,EAAQ,QAAQ,IAAI,CAAI,EAAG,EAAM,QAAQ,KAAK,CACtD,WACA,SACA,MACD,CAAC,OAGA,MADA,GAAa,GACN,GAER,MAAO,EACR,CAAC,EACG,EAAM,QAAQ,SAAW,IACvB,GAAY,GAAe,CAAC,CAAO,EAAG,EAAK,EAAE,EAClD,EAAK,SAAS,EAAM,OAAO,MAAM,CAAC,EAAG,EAAM,QAAQ,MAAM,CAAC,EAAG,EAAM,QAAQ,MAAM,CAAC,EAAG,EAAK,KAAK,EAEjG,CAAC,CACF,CAAC,EAEH,CAIA,IAAIC,GAAY,EAIhB,SAAS,GAAc,EAAU,EAAO,EAAgB,CACvD,IAAM,EAAK,KACL,EAAQ,GAAe,KAAK,KAAM,EAAgB,CAAE,EAC1D,GAAI,CAAC,EAAM,QAAQ,OAAQ,OAAO,EAClC,IAAM,EAAO,CACZ,KACA,QACA,WACA,OACD,EAIA,OAHA,EAAe,QAAS,GAAY,EAClC,AAA4B,EAAQ,kBAAkB,CAAC,EAAA,CAAI,KAAK,CAAI,CACtE,CAAC,EACM,CACR,CAKA,SAAS,GAAU,EAAO,CACzB,IAAM,EAAS,CACd,OAAQ,CAAC,EACT,QAAS,CAAC,EACV,QAAS,CAAC,CACX,EACM,EAAU,OAAO,OAAO,IAAI,EAClC,EAAM,MAAM,EAAG,IACV,EAAE,WAAa,EAAE,SACjB,EAAE,SAAW,EAAE,OACZ,EAAE,KAAK,cAAc,EAAE,IAAI,EADA,EAAE,OAAO,cAAc,EAAE,MAAM,EAD3B,EAAE,SAAS,cAAc,EAAE,QAAQ,CAGzE,EACD,IAAI,EAAW,CACd,SAAU,GACV,OAAQ,GACR,KAAM,EACP,EAoBA,OAnBA,EAAM,QAAS,GAAS,CACvB,GAAI,EAAS,OAAS,EAAK,MAAQ,EAAS,SAAW,EAAK,QAAU,EAAS,WAAa,EAAK,SAAU,OAC3G,EAAW,EACX,IAAM,EAAW,EAAK,SAChB,EAAS,EAAK,OACd,EAAO,EAAK,KACZ,EAAkB,EAAQ,KAAc,EAAQ,GAAY,OAAO,OAAO,IAAI,GAC9E,EAAe,EAAgB,KAAY,EAAgB,GAAU,GAAW,EAAU,CAAM,GAClG,EACJ,AAEK,EAFD,KAAQ,EAAa,MAAc,EAAO,OACrC,IAAW,IAAM,EAAa,QAAQ,IAAI,CAAI,EAAU,EAAO,QAC5D,EAAO,QACnB,IAAM,EAAO,CACZ,WACA,SACA,MACD,EACA,EAAK,KAAK,CAAI,CACf,CAAC,EACM,CACR,CAKA,SAAS,GAAY,EAAM,EAAW,GAAM,EAAc,GAAO,CAChE,IAAM,EAAS,CAAC,EAKhB,OAJA,EAAK,QAAS,GAAS,CACtB,IAAM,EAAO,OAAO,GAAS,SAAW,GAAa,EAAM,EAAU,CAAW,EAAI,EAChF,GAAM,EAAO,KAAK,CAAI,CAC3B,CAAC,EACM,CACR,CAKA,IAAM,GAAgB,CACrB,UAAW,CAAC,EACZ,MAAO,EACP,QAAS,IACT,OAAQ,IACR,OAAQ,GACR,iBAAkB,EACnB,EAKA,SAAS,GAAU,EAAQ,EAAS,EAAO,EAAM,CAChD,IAAM,EAAiB,EAAO,UAAU,OAClC,EAAa,EAAO,OAAS,KAAK,MAAM,KAAK,OAAO,EAAI,CAAc,EAAI,EAAO,MACnF,EACJ,GAAI,EAAO,OAAQ,CAClB,IAAI,EAAO,EAAO,UAAU,MAAM,CAAC,EAEnC,IADA,EAAY,CAAC,EACN,EAAK,OAAS,GAAG,CACvB,IAAM,EAAY,KAAK,MAAM,KAAK,OAAO,EAAI,EAAK,MAAM,EACxD,EAAU,KAAK,EAAK,EAAU,EAC9B,EAAO,EAAK,MAAM,EAAG,CAAS,CAAC,CAAC,OAAO,EAAK,MAAM,EAAY,CAAC,CAAC,CACjE,CACA,EAAY,EAAU,OAAO,CAAI,CAClC,KAAO,GAAY,EAAO,UAAU,MAAM,CAAU,CAAC,CAAC,OAAO,EAAO,UAAU,MAAM,EAAG,CAAU,CAAC,EAClG,IAAM,EAAY,KAAK,IAAI,EACvB,EAAS,UACT,EAAc,EACd,EACA,EAAQ,KACR,EAAQ,CAAC,EACT,EAAgB,CAAC,EACjB,OAAO,GAAS,YAAY,EAAc,KAAK,CAAI,EAIvD,SAAS,GAAa,CACrB,AAEC,KADA,aAAa,CAAK,EACV,KAEV,CAIA,SAAS,GAAQ,CACZ,IAAW,YAAW,EAAS,WACnC,EAAW,EACX,EAAM,QAAS,GAAS,CACnB,EAAK,SAAW,YAAW,EAAK,OAAS,UAC9C,CAAC,EACD,EAAQ,CAAC,CACV,CAKA,SAAS,EAAU,EAAU,EAAW,CACnC,IAAW,EAAgB,CAAC,GAC5B,OAAO,GAAa,YAAY,EAAc,KAAK,CAAQ,CAChE,CAIA,SAAS,GAAiB,CACzB,MAAO,CACN,YACA,UACA,SACA,cACA,eAAgB,EAAM,OACtB,YACA,OACD,CACD,CAIA,SAAS,GAAY,CACpB,EAAS,SACT,EAAc,QAAS,GAAa,CACnC,EAAS,IAAK,GAAG,CAAS,CAC3B,CAAC,CACF,CAIA,SAAS,GAAa,CACrB,EAAM,QAAS,GAAS,CACnB,EAAK,SAAW,YAAW,EAAK,OAAS,UAC9C,CAAC,EACD,EAAQ,CAAC,CACV,CAIA,SAAS,EAAe,EAAM,EAAU,EAAM,CAC7C,IAAM,EAAU,IAAa,UAE7B,OADA,EAAQ,EAAM,OAAQ,GAAW,IAAW,CAAI,EACxC,EAAR,CACC,IAAK,UAAW,MAChB,IAAK,SACJ,GAAI,GAAW,CAAC,EAAO,iBAAkB,OACzC,MACD,QAAS,MACV,CACA,GAAI,IAAa,QAAS,CACzB,EAAY,EACZ,EAAU,EACV,MACD,CACA,GAAI,EAAS,CACZ,EAAY,EACP,EAAM,SAAa,EAAU,OAC7B,EAAS,EAD4B,EAAU,GAEpD,MACD,CAGA,GAFA,EAAW,EACX,EAAW,EACP,CAAC,EAAO,OAAQ,CACnB,IAAM,EAAQ,EAAO,UAAU,QAAQ,EAAK,QAAQ,EAChD,IAAU,IAAM,IAAU,EAAO,QAAO,EAAO,MAAQ,EAC5D,CACA,EAAS,YACT,EAAc,QAAS,GAAa,CACnC,EAAS,CAAI,CACd,CAAC,CACF,CAIA,SAAS,GAAW,CACnB,GAAI,IAAW,UAAW,OAC1B,EAAW,EACX,IAAM,EAAW,EAAU,MAAM,EACjC,GAAI,IAAa,IAAK,GAAG,CACxB,GAAI,EAAM,OAAQ,CACjB,EAAQ,eAAiB,CACxB,EAAW,EACP,IAAW,YACd,EAAW,EACX,EAAU,EAEZ,EAAG,EAAO,OAAO,EACjB,MACD,CACA,EAAU,EACV,MACD,CACA,IAAM,EAAO,CACZ,OAAQ,UACR,WACA,UAAW,EAAU,IAAS,CAC7B,EAAe,EAAM,EAAU,CAAI,CACpC,CACD,EACA,EAAM,KAAK,CAAI,EACf,IACA,EAAQ,WAAW,EAAU,EAAO,MAAM,EAC1C,EAAM,EAAU,EAAS,EAAK,QAAQ,CACvC,CAEA,OADA,WAAW,CAAQ,EACZ,CACR,CAKA,SAAS,GAAe,EAAK,CAC5B,IAAM,EAAS,CACd,GAAG,GACH,GAAG,CACJ,EACI,EAAU,CAAC,EAIf,SAAS,GAAU,CAClB,EAAU,EAAQ,OAAQ,GAAS,EAAK,CAAC,CAAC,SAAW,SAAS,CAC/D,CAIA,SAAS,EAAM,EAAS,EAAe,EAAc,CACpD,IAAM,EAAU,GAAU,EAAQ,EAAS,GAAgB,EAAM,IAAU,CAC1E,EAAQ,EACJ,GAAc,EAAa,EAAM,CAAK,CAC3C,CAAC,EAED,OADA,EAAQ,KAAK,CAAO,EACb,CACR,CAIA,SAAS,EAAK,EAAU,CACvB,OAAO,EAAQ,KAAM,GACb,EAAS,CAAK,CACrB,GAAK,IACP,CAUA,MAAO,CARN,QACA,OACA,SAAW,GAAU,CACpB,EAAO,MAAQ,CAChB,EACA,aAAgB,EAAO,MACvB,SAEa,CACf,CAEA,SAAS,IAAkB,CAAC,CAC5B,IAAM,GAAkB,OAAO,OAAO,IAAI,EAI1C,SAAS,GAAmB,EAAU,CACrC,GAAI,CAAC,GAAgB,GAAW,CAC/B,IAAM,EAAS,GAAa,CAAQ,EACpC,GAAI,CAAC,EAAQ,OAMb,GAAgB,GAAY,CAH3B,SACA,WAHkB,GAAe,CAGxB,CAEgC,CAC3C,CACA,OAAO,GAAgB,EACxB,CAIA,SAAS,GAAa,EAAQ,EAAO,EAAU,CAC9C,IAAI,EACA,EACJ,GAAI,OAAO,GAAW,SAAU,CAC/B,IAAM,EAAM,GAAa,CAAM,EAC/B,GAAI,CAAC,EAEJ,OADA,EAAS,IAAK,GAAG,GAAG,EACb,GAER,EAAO,EAAI,KACX,IAAM,EAAS,GAAmB,CAAM,EACpC,IAAQ,EAAa,EAAO,WACjC,KAAO,CACN,IAAM,EAAS,GAAgB,CAAM,EACrC,GAAI,EAAQ,CACX,EAAa,GAAe,CAAM,EAElC,IAAM,EAAM,GADM,EAAO,UAAY,EAAO,UAAU,GAAK,EACzB,EAC9B,IAAK,EAAO,EAAI,KACrB,CACD,CAKA,MAJI,CAAC,GAAc,CAAC,GACnB,EAAS,IAAK,GAAG,GAAG,EACb,IAED,EAAW,MAAM,EAAO,EAAM,CAAQ,CAAC,CAAC,CAAC,CAAC,KAClD,CAEA,SAAS,IAAgB,CAAC,CAI1B,SAAS,GAAe,EAAS,CAC3B,EAAQ,kBACZ,EAAQ,gBAAkB,GAC1B,eAAiB,CAChB,EAAQ,gBAAkB,GAC1B,GAAgB,CAAO,CACxB,CAAC,EAEH,CAIA,SAAS,GAAqB,EAAO,CACpC,IAAM,EAAQ,CAAC,EACT,EAAU,CAAC,EAIjB,OAHA,EAAM,QAAS,GAAS,EACtB,EAAK,MAAM,EAAa,EAAI,EAAQ,EAAA,CAAS,KAAK,CAAI,CACxD,CAAC,EACM,CACN,QACA,SACD,CACD,CAIA,SAAS,GAAoB,EAAS,EAAO,EAAM,CAClD,SAAS,GAAe,CACvB,IAAM,EAAU,EAAQ,aACxB,EAAM,QAAS,GAAS,CACnB,GAAS,EAAQ,OAAO,CAAI,EAC3B,EAAQ,MAAM,IAAO,EAAQ,QAAQ,IAAI,CAAI,CACnD,CAAC,CACF,CACA,GAAI,GAAQ,OAAO,GAAS,SAAU,GAAI,CAEzC,GAAI,CADW,GAAW,EAAS,CACzB,CAAC,CAAC,OAAQ,CACnB,EAAa,EACb,MACD,CACD,OAAS,EAAK,CACb,QAAQ,MAAM,CAAG,CAClB,CACA,EAAa,EACb,GAAe,CAAO,CACvB,CAIA,SAAS,GAA2B,EAAU,EAAU,CACnD,aAAoB,QAAS,EAAS,KAAM,GAAS,CACxD,EAAS,CAAI,CACd,CAAC,CAAC,CAAC,UAAY,CACd,EAAS,IAAI,CACd,CAAC,EACI,EAAS,CAAQ,CACvB,CAIA,SAAS,GAAa,EAAS,EAAO,CAChC,EAAQ,YACR,EAAQ,YAAc,EAAQ,YAAY,OAAO,CAAK,CAAC,CAAC,KAAK,EADxC,EAAQ,YAAc,EAE3C,EAAQ,iBACZ,EAAQ,eAAiB,GACzB,eAAiB,CAChB,EAAQ,eAAiB,GACzB,GAAM,CAAE,WAAU,UAAW,EACvB,EAAU,EAAQ,YAExB,GADA,OAAO,EAAQ,YACX,CAAC,GAAW,CAAC,EAAQ,OAAQ,OACjC,IAAM,EAAmB,EAAQ,SACjC,GAAI,EAAQ,YAAc,EAAQ,OAAS,GAAK,CAAC,GAAmB,CACnE,GAA2B,EAAQ,UAAU,EAAS,EAAQ,CAAQ,EAAI,GAAS,CAClF,GAAoB,EAAS,EAAS,CAAI,CAC3C,CAAC,EACD,MACD,CACA,GAAI,EAAkB,CACrB,EAAQ,QAAS,GAAS,CAEzB,GADiB,EAAiB,EAAM,EAAQ,CACd,EAAI,GAAS,CAK9C,GAAoB,EAAS,CAAC,CAAI,EAJlB,EAAO,CACtB,SACA,MAAO,EAAG,GAAO,CAAK,CACvB,EAAI,IACwC,CAC7C,CAAC,CACF,CAAC,EACD,MACD,CACA,GAAM,CAAE,QAAO,WAAY,GAAqB,CAAO,EAEvD,GADI,EAAQ,QAAQ,GAAoB,EAAS,EAAS,IAAI,EAC1D,CAAC,EAAM,OAAQ,OACnB,IAAM,EAAM,EAAO,MAAM,EAAa,EAAI,GAAa,CAAQ,EAAI,KACnE,GAAI,CAAC,EAAK,CACT,GAAoB,EAAS,EAAO,IAAI,EACxC,MACD,CAEA,EADmB,QAAQ,EAAU,EAAQ,CACxC,CAAC,CAAC,QAAS,GAAS,CACxB,GAAa,EAAU,EAAO,GAAS,CACtC,GAAoB,EAAS,EAAK,MAAO,CAAI,CAC9C,CAAC,CACF,CAAC,CACF,CAAC,EAEH,CAIA,IAAM,IAAa,EAAO,IAAa,CAEtC,IAAM,EAAc,GADC,GAAY,EAAO,GAAM,GAAiB,CACtB,CAAC,EAC1C,GAAI,CAAC,EAAY,QAAQ,OAAQ,CAChC,IAAI,EAAe,GAInB,OAHI,GAAU,eAAiB,CAC1B,GAAc,EAAS,EAAY,OAAQ,EAAY,QAAS,EAAY,QAAS,EAAa,CACvG,CAAC,MACY,CACZ,EAAe,EAChB,CACD,CACA,IAAM,EAAW,OAAO,OAAO,IAAI,EAC7B,EAAU,CAAC,EACb,EAAc,EAuBlB,OAtBA,EAAY,QAAQ,QAAS,GAAS,CACrC,GAAM,CAAE,WAAU,UAAW,EAC7B,GAAI,IAAW,GAAc,IAAa,EAAc,OACxD,EAAe,EACf,EAAa,EACb,EAAQ,KAAK,GAAW,EAAU,CAAM,CAAC,EACzC,IAAM,EAAmB,EAAS,KAAc,EAAS,GAAY,OAAO,OAAO,IAAI,GAClF,EAAiB,KAAS,EAAiB,GAAU,CAAC,EAC5D,CAAC,EACD,EAAY,QAAQ,QAAS,GAAS,CACrC,GAAM,CAAE,WAAU,SAAQ,QAAS,EAC7B,EAAU,GAAW,EAAU,CAAM,EACrC,EAAe,AAAyB,EAAQ,eAA+B,IAAI,IACpF,EAAa,IAAI,CAAI,IACzB,EAAa,IAAI,CAAI,EACrB,EAAS,EAAS,CAAC,EAAO,CAAC,KAAK,CAAI,EAEtC,CAAC,EACD,EAAQ,QAAS,GAAY,CAC5B,IAAM,EAAO,EAAS,EAAQ,SAAS,CAAC,EAAQ,QAC5C,EAAK,QAAQ,GAAa,EAAS,CAAI,CAC5C,CAAC,EACM,EAAW,GAAc,EAAU,EAAa,CAAO,EAAI,EACnE,EA2CA,SAAS,GAAoB,EAAU,EAAM,CAC5C,IAAM,EAAS,CAAE,GAAG,CAAS,EAC7B,IAAK,IAAM,KAAO,EAAM,CACvB,IAAM,EAAQ,EAAK,GACb,EAAY,OAAO,EACrB,KAAO,IACN,IAAU,MAAQ,IAAU,IAAc,UAAY,IAAc,aAAW,EAAO,GAAO,GACvF,IAAc,OAAO,EAAO,KAAM,EAAO,GAAO,IAAQ,SAAW,EAAQ,EAAI,EAC3F,CACA,OAAO,CACR,CAEA,IAAM,GAAY,SAIlB,SAAS,GAAe,EAAQ,EAAM,CACrC,EAAK,MAAM,EAAS,CAAC,CAAC,QAAS,GAAQ,CAEtC,OADc,EAAI,KACN,EAAZ,CACC,IAAK,aACJ,EAAO,MAAQ,GACf,MACD,IAAK,WACJ,EAAO,MAAQ,GACf,KACF,CACD,CAAC,CACF,CAKA,SAAS,GAAiB,EAAO,EAAe,EAAG,CAClD,IAAM,EAAQ,EAAM,QAAQ,aAAc,EAAE,EAC5C,SAAS,EAAQ,EAAS,CACzB,KAAO,EAAU,GAAG,GAAW,EAC/B,OAAO,EAAU,CAClB,CACA,GAAI,IAAU,GAAI,CACjB,IAAM,EAAM,SAAS,CAAK,EAC1B,OAAO,MAAM,CAAG,EAAI,EAAI,EAAQ,CAAG,CACpC,MAAO,GAAI,IAAU,EAAO,CAC3B,IAAI,EAAQ,EACZ,OAAQ,EAAR,CACC,IAAK,IACJ,EAAQ,GACR,MACD,IAAK,MAAO,EAAQ,EACrB,CACA,GAAI,EAAO,CACV,IAAI,EAAM,WAAW,EAAM,MAAM,EAAG,EAAM,OAAS,EAAM,MAAM,CAAC,EAGhE,OAFI,MAAM,CAAG,EAAU,GACvB,GAAY,EACL,EAAM,GAAM,EAAI,EAAQ,CAAG,EAAI,EACvC,CACD,CACA,OAAO,CACR,CAKA,SAAS,GAAW,EAAM,EAAY,CACrC,IAAI,EAAoB,EAAK,QAAQ,QAAQ,IAAM,GAAK,GAAK,8CAC7D,IAAK,IAAM,KAAQ,EAAY,GAAqB,IAAM,EAAO,KAAQ,EAAW,GAAQ,IAC5F,MAAO,0CAA8C,EAAoB,IAAM,EAAO,QACvF,CAQA,SAAS,GAAgB,EAAK,CAC7B,OAAO,EAAI,QAAQ,KAAM,GAAG,CAAC,CAAC,QAAQ,KAAM,KAAK,CAAC,CAAC,QAAQ,KAAM,KAAK,CAAC,CAAC,QAAQ,KAAM,KAAK,CAAC,CAAC,QAAQ,KAAM,KAAK,CAAC,CAAC,QAAQ,OAAQ,GAAG,CACtI,CAIA,SAAS,GAAU,EAAK,CACvB,MAAO,sBAAwB,GAAgB,CAAG,CACnD,CAIA,SAAS,GAAS,EAAK,CACtB,MAAO,QAAW,GAAU,CAAG,EAAI,IACpC,CAEA,IAAI,GAIJ,SAAS,IAAe,CACvB,GAAI,CACH,GAAS,OAAO,aAAa,aAAa,UAAW,CAAE,WAAa,GAAM,CAAE,CAAC,CAC9E,MAAc,CACb,GAAS,IACV,CACD,CAOA,SAAS,GAAiB,EAAM,CAE/B,OADI,KAAW,IAAK,IAAG,GAAa,EAC7B,GAAS,GAAO,WAAW,CAAI,EAAI,CAC3C,CAEA,IAAM,GAAoC,CACtC,GAAG,GACH,OAAQ,EACZ,EAKM,GAAc,CAChB,MAAS,6BACT,WAAc,+BACd,cAAe,GACf,KAAQ,KACZ,EAIM,GAAc,CAChB,QAAS,cACb,EACM,GAAgB,CAClB,gBAAiB,cACrB,EACM,GAAe,CACjB,gBAAiB,aACrB,EAEM,GAAa,CACf,MAAO,aACP,OAAQ,YACR,KAAM,WACV,EACM,GAAe,CACjB,WAAY,GACZ,KAAM,GACN,WAAY,EAChB,EACA,IAAK,IAAM,KAAU,GAAc,CAC/B,IAAM,EAAO,GAAa,GAC1B,IAAK,IAAM,KAAQ,GACf,EAAK,EAAS,GAAQ,GAAW,EAEzC,CAIA,IAAM,GAAiB,CACnB,GAAG,GACH,OAAQ,EACZ,EAIA,SAAS,GAAQ,EAAO,CACpB,OAAO,GAAS,EAAM,MAAM,YAAY,EAAI,KAAO,GACvD,CAIA,IAAM,IAEN,EAEA,EAEA,IAAS,CAEL,IAAM,EAAe,EAAM,OACrB,GACA,GAEA,EAAiB,GAAoB,EAAc,CAAK,EAExD,EAAO,EAAM,MAAQ,MAErB,EAAQ,CAAC,EACT,EAAc,EAAM,OAAS,CAAC,EAE9B,EAAiB,CACnB,GAAI,IAAS,MAAQ,GAAc,CAAC,CACxC,EACA,GAAI,EAAM,CACN,IAAM,EAAW,GAAa,EAAM,GAAO,EAAI,EAC/C,GAAI,EAAU,CACV,IAAM,EAAa,CAAC,SAAS,EAK7B,IAAK,IAAM,IAAQ,CAHf,WACA,QAEmB,EACf,EAAS,IACT,EAAW,KAAK,YAAc,EAAS,EAAK,EAGpD,EAAe,UAAY,EAAW,KAAK,GAAG,CAClD,CACJ,CAEA,IAAK,IAAI,KAAO,EAAO,CACnB,IAAM,EAAQ,EAAM,GAChB,OAAU,IAAK,GAGnB,OAAQ,EAAR,CAEI,IAAK,OACL,IAAK,QACL,IAAK,WACL,IAAK,SACL,IAAK,OACL,IAAK,MACL,IAAK,WACD,MAEJ,IAAK,OACD,EAAe,IAAM,EACrB,MAEJ,IAAK,YACD,EAAe,IACV,EAAe,GAAO,EAAe,GAAO,IAAM,IAC/C,EACR,MAEJ,IAAK,SACL,IAAK,QACL,IAAK,QACD,EAAe,GACX,IAAU,IAAQ,IAAU,QAAU,IAAU,EACpD,MAEJ,IAAK,OACG,OAAO,GAAU,UACjB,GAAe,EAAgB,CAAK,EAExC,MAEJ,IAAK,QACD,EAAM,MAAQ,EACd,MAEJ,IAAK,SACG,OAAO,GAAU,SACjB,EAAe,GAAO,GAAiB,CAAK,EAEvC,OAAO,GAAU,WACtB,EAAe,GAAO,GAE1B,MAEJ,IAAK,aACL,IAAK,cACG,IAAU,IAAQ,IAAU,QAC5B,OAAO,EAAe,eAE1B,MAEJ,QACQ,EAAa,KAAS,IAAK,KAC3B,EAAe,GAAO,EAElC,CACJ,CAEA,IAAM,EAAO,GAAU,EAAM,CAAc,EACrC,EAAgB,EAAK,WAK3B,GAHI,EAAe,SACf,EAAM,cAAgB,YAEtB,IAAS,MAAO,CAEhB,EAAe,MAAQ,CACnB,GAAG,EACH,GAAG,CACP,EAEA,OAAO,OAAO,EAAgB,CAAa,EAE3C,IAAI,EAAe,EACf,EAAK,EAAM,GASf,OARI,OAAO,GAAO,WAEd,EAAK,EAAG,QAAQ,KAAM,GAAG,GAG7B,EAAe,wBAA0B,CACrC,OAAQ,GAAiB,GAAW,EAAK,KAAM,MAAW,EAAK,KAAO,IAAiB,cAAc,CAAC,CAC1G,GACA,EAAA,EAAA,cAAA,CAAqB,MAAO,CAAc,CAC9C,CAEA,GAAM,CAAE,OAAM,QAAO,UAAW,EAC1B,EAAU,IAAS,SACpB,IAAS,KAAO,GAAQ,EAAK,QAAQ,cAAc,IAAM,IAExD,EAAO,GAAW,EAAM,CAC1B,GAAG,EACH,MAAO,EAAQ,GACf,OAAQ,EAAS,EACrB,CAAC,EAWD,MATA,GAAe,MAAQ,CACnB,GAAG,EACH,QAAS,GAAS,CAAI,EACtB,MAAS,GAAQ,EAAc,KAAK,EACpC,OAAU,GAAQ,EAAc,MAAM,EACtC,GAAG,GACH,GAAI,EAAU,GAAgB,GAC9B,GAAG,CACP,GACA,EAAA,EAAA,cAAA,CAAqB,OAAQ,CAAc,CAC/C,EAYA,GANA,GAAiB,EAAI,EAErB,GAAa,GAAI,EAAc,EAI3B,OAAO,SAAa,KAAe,OAAO,OAAW,IAAa,CAClE,IAAM,EAAU,OAEhB,GAAI,EAAQ,iBAAmB,IAAK,GAAG,CACnC,IAAM,EAAU,EAAQ,eAClB,EAAM,iCACR,OAAO,GAAY,UAAY,IAC9B,aAAmB,MAAQ,EAAU,CAAC,CAAO,EAAA,CAAG,QAAS,GAAS,CAC/D,GAAI,EAGA,OAAO,GAAS,WACZ,GACA,aAAgB,OAEhB,OAAO,EAAK,OAAU,UACtB,OAAO,EAAK,QAAW,UAEvB,CAAC,GAAc,CAAI,IACnB,QAAQ,MAAM,CAAG,CAEzB,MACU,CACN,QAAQ,MAAM,CAAG,CACrB,CACJ,CAAC,CAET,CAEA,GAAI,EAAQ,mBAAqB,IAAK,GAAG,CACrC,IAAM,EAAY,EAAQ,iBAC1B,GAAI,OAAO,GAAc,UAAY,EACjC,IAAK,IAAI,KAAO,EAAW,CACvB,IAAM,EAAM,oBAAsB,EAAM,gBACxC,GAAI,CACA,IAAM,EAAQ,EAAU,GACxB,GAAI,OAAO,GAAU,UACjB,CAAC,GACD,EAAM,YAAc,IAAK,GACzB,SAEC,GAAe,EAAK,CAAK,GAC1B,QAAQ,MAAM,CAAG,CAEzB,MACU,CACN,QAAQ,MAAM,CAAG,CACrB,CACJ,CAER,CACJ,CACA,SAAS,GAAc,EAAO,CAC1B,GAAM,CAAC,EAAS,IAAA,EAAA,EAAA,SAAA,CAAuB,CAAC,CAAC,EAAM,GAAG,EAC5C,CAAC,EAAO,IAAA,EAAA,EAAA,SAAA,CAAqB,CAAC,CAAC,EAErC,SAAS,EAAgB,EAAS,CAC9B,GAAI,EAAS,CACT,IAAM,EAAO,EAAM,KACnB,GAAI,OAAO,GAAS,SAEhB,MAAO,CACH,KAAM,GACN,KAAM,CACV,EAEJ,IAAM,EAAO,GAAY,CAAI,EAC7B,GAAI,EACA,MAAO,CACH,OACA,MACJ,CAER,CACA,MAAO,CACH,KAAM,EACV,CACJ,CACA,GAAM,CAAC,EAAO,IAAA,EAAA,EAAA,SAAA,CAAqB,EAAgB,CAAC,CAAC,EAAM,GAAG,CAAC,EAE/D,SAAS,GAAU,CACf,IAAM,EAAW,EAAM,SACnB,IACA,EAAS,EACT,EAAS,CAAC,CAAC,EAEnB,CAEA,SAAS,EAAY,EAAU,CAC3B,GAAI,KAAK,UAAU,CAAK,IAAM,KAAK,UAAU,CAAQ,EAGjD,OAFA,EAAQ,EACR,EAAS,CAAQ,EACV,EAEf,CAEA,SAAS,GAAc,CACnB,IAAI,EACJ,IAAM,EAAO,EAAM,KACnB,GAAI,OAAO,GAAS,SAAU,CAE1B,EAAY,CACR,KAAM,GACN,KAAM,CACV,CAAC,EACD,MACJ,CAEA,IAAM,EAAO,GAAY,CAAI,EACzB,EAAY,CACZ,OACA,MACJ,CAAC,IACO,IAAS,IAAA,GAGT,EAAS,CACL,SAFa,GAAU,CAAC,CAAI,EAAG,CAExB,CACX,CAAC,EAEI,KAEJ,EAAK,EAAM,SAAY,MAAiC,EAAG,KAAK,EAAO,CAAI,GAGxF,EAEA,EAAA,EAAA,UAAA,MACI,EAAW,EAAI,EACR,GACR,CAAC,CAAC,GAEL,EAAA,EAAA,UAAA,KAAgB,CACR,GACA,EAAY,CAEpB,EAAG,CAAC,EAAM,KAAM,CAAO,CAAC,EAExB,GAAM,CAAE,OAAM,QAAS,EAQvB,OAPK,EAOE,GAAO,CACV,GAAG,GACH,GAAG,CACP,EAAG,EAAO,CAAI,EATH,EAAM,SACP,EAAM,SACN,EAAM,SACF,EAAM,UAAA,EAAA,EAAA,cAAA,CACQ,OAAQ,CAAC,CAAC,CAM1C,CAMA,IAAMC,IAAAA,EAAAA,EAAAA,WAAAA,EAAmB,EAAO,IAAQ,GAAc,CAClD,GAAG,EACH,KAAM,CACV,CAAC,CAAC,GAMI,EAAA,EAAA,WAAA,EAAyB,EAAO,IAAQ,GAAc,CACxD,OAAQ,GACR,GAAG,EACH,KAAM,CACV,CAAC,CAAC,2OEr3DI,GAAuB,CACzB,OACA,OACA,OACA,QACA,aAAc,EACd,YACA,QACA,GAAG,KACD,CACF,IAAM,EAAe,IAAc,IAAA,GAEnC,OACI,EAAA,EAAA,IAAA,CAAC,GAAD,CACU,OACN,cAAa,EACb,aAAY,EACZ,KAAM,EAAe,IAAA,GAAY,MACjC,UAAW,EAAG,GAAW,CAAE,OAAM,MAAK,CAAC,EAAG,CAAS,EACnD,MAAO,EAAQ,CAAE,MAAO,EAAK,MAAM,GAAQ,GAAG,CAAM,EAAI,EACxD,GAAI,CACP,CAAA,CAET,EAEA,EAAK,YAAc,iMEpBb,GAAiD,CACnD,KAAM,uBACN,IAAK,kBACL,KAAM,mBACV,EAEM,GAAc,CAChB,IAAK,YACL,KAAM,aACN,KAAM,MACV,EAEM,IAAiC,CACnC,QACA,WACA,gBACA,WACA,YACA,MACA,YACA,GAAG,KACD,CACF,IAAM,EAAe,IAAkB,OAAS,IAAkB,OAE5D,EAAiB,GAA2C,CAC1D,IAAa,EAAE,MAAQ,SAAW,EAAE,MAAQ,OAC5C,EAAE,eAAe,EACjB,EAAE,cAAc,MAAM,GAE1B,IAAY,CAAC,CACjB,EAEA,OACI,EAAA,EAAA,IAAA,CAAC,KAAD,CAEI,MAAO,MACP,SAAU,EAAW,EAAI,IAAA,GACzB,GAAI,EACC,MACL,YAAW,EAAgB,GAAY,GAAiB,IAAA,GACxD,UAAW,GAAY,EAAY,EAAgB,IAAA,GACnD,UAAW,EACP,GAAgB,CAAE,OAAM,CAAC,EACzB,GAAA,SACA,CACJ,WAEC,IAAkB,IAAA,GAaf,GAZA,EAAA,EAAA,KAAA,CAAC,OAAD,CAAM,UAAW,YAAjB,CACK,GACD,EAAA,EAAA,IAAA,CAAC,EAAD,CACI,KAAM,GAAW,GACjB,KAAM,KACN,UAAW,EACP,GACA,GAAA,QACJ,CACH,CAAA,CACC,GAIV,CAAA,CAEZ,EAEA,GAAU,YAAc,sLErElB,IAAiC,CACnC,QACA,UACA,WACA,YACA,MACA,GAAG,MAEH,EAAA,EAAA,IAAA,CAAC,KAAD,CACS,MACL,UAAW,EACP,GAAgB,CAAE,OAAM,CAAC,EACzB,GAAA,WACA,GAAA,WACA,CACJ,EACA,GAAI,CACP,CAAA,EAGL,GAAU,YAAc,+BExBlB,IAAuC,CAAE,YAAW,MAAK,GAAG,MAC9D,EAAA,EAAA,IAAA,CAAC,UAAD,CACS,MACL,UAAW,EAAG,GAAmB,CAAS,EAC1C,GAAI,CACP,CAAA,EAGL,GAAa,YAAc,eCV3B,IAAM,IAAyC,CAAE,MAAK,GAAG,MACrD,EAAA,EAAA,IAAA,CAAC,WAAD,CACS,MACL,GAAI,CACP,CAAA,EAGL,GAAc,YAAc,gBCP5B,IAAM,IAA+B,CAAE,QAAO,WAAU,WAAU,QAAO,MAAK,GAAG,MAC7E,EAAA,EAAA,IAAA,CAAC,MAAD,CACS,MACL,MAAO,CAAE,QAAO,WAAU,WAAU,GAAG,CAAM,EAC7C,GAAI,CACP,CAAA,EAGL,GAAS,YAAc,ssEGVV,GAAyB,CAClC,GAAI,KACJ,GAAI,KACJ,GAAI,KACJ,GAAI,KACJ,GAAI,KACJ,GAAI,KACJ,EAAG,IACH,KAAM,OACN,MAAO,QACP,MAAO,QACP,OAAQ,SACR,GAAI,KACJ,WAAY,aACZ,IAAK,MACL,KAAM,OACN,IAAK,MACL,KAAM,OACN,KAAM,OACN,KAAM,OACN,KAAM,OACN,IAAK,MACL,IAAK,MACL,IAAK,MACL,IAAK,KACT,ECnBM,GAAmC,CACrC,KACA,UACA,WACA,aACA,QACA,WACA,YACA,QACA,MACA,GAAG,MAKC,EAAA,EAAA,IAAA,CAHY,GAAM,GAAwB,GAAiC,MAAQ,IAGnF,CACS,MACL,UAAW,EAAG,GAAiB,CAAE,UAAS,WAAU,aAAY,UAAS,CAAC,EAAG,CAAS,EACtF,MAAO,EAAQ,CAAE,MAAO,EAAK,MAAM,GAAQ,GAAG,CAAM,EAAI,EACxD,GAAI,CACP,CAAA,EAIT,EAAW,YAAc,aC5BzB,IAAa,GAAwE,CACjF,GAAI,KACJ,GAAI,KACJ,GAAI,IACR,ECHa,GAAwE,CACjF,GAAI,KACJ,GAAI,OACJ,GAAI,IACR,ECDM,IAA2B,CAC7B,UACA,QACA,OAAO,KACP,YACA,QACA,YACA,UACA,MACA,GAAG,KACD,CACF,IAAM,EAAW,GAAqB,GAChC,EAAW,GAAqB,GAEtC,OACI,EAAA,EAAA,KAAA,CAAC,SAAD,CACS,MACL,UAAW,EAAG,GAAa,CAAE,UAAS,QAAO,MAAK,CAAC,EAAG,CAAS,EAC/D,GAAI,WAHR,CAKK,IACG,EAAA,EAAA,IAAA,CAAC,EAAD,CACI,KAAM,EACN,KAAM,CACT,CAAA,EAEJ,IACG,EAAA,EAAA,IAAA,CAAC,EAAD,CACI,GAAI,OACJ,QAAS,OACT,SAAU,EACV,WAAY,kBAEX,CACO,CAAA,EAEf,IACG,EAAA,EAAA,IAAA,CAAC,EAAD,CACI,KAAM,EACN,KAAM,CACT,CAAA,CAED,GAEhB,EAEA,GAAO,YAAc,qtCE/Cf,IAAmC,CACrC,UACA,QACA,OAAO,KACP,YACA,OACA,MACA,GAAG,KACD,CACF,IAAM,EAAW,GAAyB,GAE1C,OACI,EAAA,EAAA,IAAA,CAAC,SAAD,CACS,MACL,UAAW,EAAG,GAAiB,CAAE,UAAS,QAAO,MAAK,CAAC,EAAG,CAAS,EACnE,GAAI,YAEJ,EAAA,EAAA,IAAA,CAAC,EAAD,CACU,OACN,KAAM,CACT,CAAA,CACG,CAAA,CAEhB,EAEA,GAAW,YAAc,aC9BzB,SAASC,GAAO,EAAK,EAAO,CAC1B,GAAI,OAAO,GAAQ,WACjB,OAAO,EAAI,CAAK,EACP,GAAQ,OACjB,EAAI,QAAU,EAElB,CACA,SAAS,GAAY,GAAG,EAAM,CAC5B,MAAQ,IAAS,CACf,IAAI,EAAa,GACX,EAAW,EAAK,IAAK,GAAQ,CACjC,IAAM,EAAUA,GAAO,EAAK,CAAI,EAIhC,MAHI,CAAC,GAAc,OAAO,GAAW,aACnC,EAAa,IAER,CACT,CAAC,EACD,GAAI,EACF,UAAa,CACX,IAAK,IAAI,EAAI,EAAG,EAAI,EAAS,OAAQ,IAAK,CACxC,IAAM,EAAU,EAAS,GACrB,OAAO,GAAW,WACpB,EAAQ,EAER,GAAO,EAAK,GAAI,IAAI,CAExB,CACF,CAEJ,CACF,CACA,SAAS,EAAgB,GAAG,EAAM,CAChC,OAAOC,EAAM,YAAY,GAAY,GAAG,CAAI,EAAG,CAAI,CACrD,CCfA,SAAS,GAAmB,EAAW,EAAyB,CAAC,EAAG,CAClE,IAAI,EAAkB,CAAC,EACvB,SAAS,EAAe,EAAmB,EAAgB,CACzD,IAAM,EAAcC,EAAM,cAAc,CAAc,EACtD,EAAY,YAAc,EAAoB,UAC9C,IAAM,EAAQ,EAAgB,OAC9B,EAAkB,CAAC,GAAG,EAAiB,CAAc,EACrD,IAAM,EAAY,GAAU,CAC1B,GAAM,CAAE,QAAO,WAAU,GAAG,GAAY,EAClC,EAAU,IAAQ,EAAU,GAAG,IAAU,EACzC,EAAQA,EAAM,YAAc,EAAS,OAAO,OAAO,CAAO,CAAC,EACjE,OAAuB,EAAA,EAAA,IAAA,CAAI,EAAQ,SAAU,CAAE,QAAO,UAAS,CAAC,CAClE,EACA,EAAS,YAAc,EAAoB,WAC3C,SAAS,EAAY,EAAc,EAAO,CACxC,IAAM,EAAU,IAAQ,EAAU,GAAG,IAAU,EACzC,EAAUA,EAAM,WAAW,CAAO,EACxC,GAAI,EAAS,OAAO,EACpB,GAAI,IAAmB,IAAK,GAAG,OAAO,EACtC,MAAU,MAAM,KAAK,EAAa,2BAA2B,EAAkB,GAAG,CACpF,CACA,MAAO,CAAC,EAAU,CAAW,CAC/B,CACA,IAAM,MAAoB,CACxB,IAAM,EAAgB,EAAgB,IAAK,GAClCA,EAAM,cAAc,CAAc,CAC1C,EACD,OAAO,SAAkB,EAAO,CAC9B,IAAM,EAAW,IAAQ,IAAc,EACvC,OAAOA,EAAM,aACJ,EAAG,UAAU,KAAc,CAAE,GAAG,GAAQ,GAAY,CAAS,CAAE,GACtE,CAAC,EAAO,CAAQ,CAClB,CACF,CACF,EAEA,MADA,GAAY,UAAY,EACjB,CAAC,EAAgB,GAAqB,EAAa,GAAG,CAAsB,CAAC,CACtF,CACA,SAAS,GAAqB,GAAG,EAAQ,CACvC,IAAM,EAAY,EAAO,GACzB,GAAI,EAAO,SAAW,EAAG,OAAO,EAChC,IAAM,MAAoB,CACxB,IAAM,EAAa,EAAO,IAAK,IAAkB,CAC/C,SAAU,EAAa,EACvB,UAAW,EAAa,SAC1B,EAAE,EACF,OAAO,SAA2B,EAAgB,CAChD,IAAM,EAAa,EAAW,QAAQ,EAAa,CAAE,WAAU,eAAgB,CAE7E,IAAM,EADa,EAAS,CACE,CAAC,CAAC,UAAU,KAC1C,MAAO,CAAE,GAAG,EAAa,GAAG,CAAa,CAC3C,EAAG,CAAC,CAAC,EACL,OAAOA,EAAM,aAAe,EAAG,UAAU,EAAU,aAAc,CAAW,GAAI,CAAC,CAAU,CAAC,CAC9F,CACF,EAEA,MADA,GAAY,UAAY,EAAU,UAC3B,CACT,CC5EmB,OAAO,OAAW,KAAe,OAAO,UAAY,OAAO,SAAS,cACvF,SAAS,EAAqB,EAAsB,EAAiB,CAAE,2BAA2B,IAAS,CAAC,EAAG,CAC7G,OAAO,SAAqB,EAAO,CAEjC,GADA,IAAuB,CAAK,EACxB,IAA6B,IAAS,CAAC,EAAM,iBAC/C,OAAO,IAAkB,CAAK,CAElC,CACF,CCPA,IAAI,GAAmB,YAAY,SAAWC,EAAM,oBAAwB,CAC5E,ECAI,GAAqBC,EAAM,oBAA6CC,GAC5E,SAAS,GAAqB,CAC5B,OACA,cACA,eAAiB,CACjB,EACA,UACC,CACD,GAAM,CAAC,EAAkB,EAAqB,GAAe,GAAqB,CAChF,cACA,UACF,CAAC,EACK,EAAe,IAAS,IAAK,GAC7B,EAAQ,EAAe,EAAO,EAC1B,CACR,IAAM,EAAkBD,EAAM,OAAO,IAAS,IAAK,EAAC,EACpD,EAAM,cAAgB,CACpB,IAAM,EAAgB,EAAgB,QAClC,IAAkB,GAGpB,QAAQ,KACN,GAAG,EAAO,oBAHC,EAAgB,aAAe,eAGP,MAF1B,EAAe,aAAe,eAEK,2KAC9C,EAEF,EAAgB,QAAU,CAC5B,EAAG,CAAC,EAAc,CAAM,CAAC,CAC3B,CAcA,MAAO,CAAC,EAbSA,EAAM,YACpB,GAAc,CACb,GAAI,EAAc,CAChB,IAAM,EAASE,GAAW,CAAS,EAAI,EAAU,CAAI,EAAI,EACrD,IAAW,GACb,EAAY,UAAU,CAAM,CAEhC,MACE,EAAoB,CAAS,CAEjC,EACA,CAAC,EAAc,EAAM,EAAqB,CAAW,CAEjC,CAAC,CACzB,CACA,SAAS,GAAqB,CAC5B,cACA,YACC,CACD,GAAM,CAAC,EAAO,GAAYF,EAAM,SAAS,CAAW,EAC9C,EAAeA,EAAM,OAAO,CAAK,EACjC,EAAcA,EAAM,OAAO,CAAQ,EAUzC,OATA,OAAyB,CACvB,EAAY,QAAU,CACxB,EAAG,CAAC,CAAQ,CAAC,EACb,EAAM,cAAgB,CAChB,EAAa,UAAY,IAC3B,EAAY,UAAU,CAAK,EAC3B,EAAa,QAAU,EAE3B,EAAG,CAAC,EAAO,CAAY,CAAC,EACjB,CAAC,EAAO,EAAU,CAAW,CACtC,CACA,SAASE,GAAW,EAAO,CACzB,OAAO,OAAO,GAAU,UAC1B,CChEA,SAAS,GAAY,EAAO,CAC1B,IAAM,EAAMC,EAAM,OAAO,CAAE,QAAO,SAAU,CAAM,CAAC,EACnD,OAAOA,EAAM,aACP,EAAI,QAAQ,QAAU,IACxB,EAAI,QAAQ,SAAW,EAAI,QAAQ,MACnC,EAAI,QAAQ,MAAQ,GAEf,EAAI,QAAQ,UAClB,CAAC,CAAK,CAAC,CACZ,CCRA,SAAS,GAAQ,EAAS,CACxB,GAAM,CAAC,EAAM,GAAWC,EAAM,SAAS,IAAK,EAAC,EA+B7C,OA9BA,OAAsB,CACpB,GAAI,EAAS,CACX,EAAQ,CAAE,MAAO,EAAQ,YAAa,OAAQ,EAAQ,YAAa,CAAC,EACpE,IAAM,EAAiB,IAAI,eAAgB,GAAY,CAIrD,GAHI,CAAC,MAAM,QAAQ,CAAO,GAGtB,CAAC,EAAQ,OACX,OAEF,IAAM,EAAQ,EAAQ,GAClB,EACA,EACJ,GAAI,kBAAmB,EAAO,CAC5B,IAAM,EAAkB,EAAM,cACxB,EAAa,MAAM,QAAQ,CAAe,EAAI,EAAgB,GAAK,EACzE,EAAQ,EAAW,WACnB,EAAS,EAAW,SACtB,KACE,GAAQ,EAAQ,YAChB,EAAS,EAAQ,aAEnB,EAAQ,CAAE,QAAO,QAAO,CAAC,CAC3B,CAAC,EAED,OADA,EAAe,QAAQ,EAAS,CAAE,IAAK,YAAa,CAAC,MACxC,EAAe,UAAU,CAAO,CAC/C,MACE,EAAQ,IAAK,EAAC,CAElB,EAAG,CAAC,CAAO,CAAC,EACL,CACT,CC5BA,SAAS,GAAgB,EAAc,EAAS,CAC9C,OAAOC,EAAM,YAAY,EAAO,IACZ,EAAQ,EAAM,CAAC,IACb,EACnB,CAAY,CACjB,CAGA,IAAI,GAAY,GAAU,CACxB,GAAM,CAAE,UAAS,YAAa,EACxB,EAAW,GAAY,CAAO,EAC9B,EAAQ,OAAO,GAAa,WAAa,EAAS,CAAE,QAAS,EAAS,SAAU,CAAC,EAAIC,EAAO,SAAS,KAAK,CAAQ,EAClH,EAAM,GAAsB,EAAS,IAAKC,GAAc,CAAK,CAAC,EAEpE,OADmB,OAAO,GAAa,YAClB,EAAS,UAAYD,EAAO,aAAa,EAAO,CAAE,KAAI,CAAC,EAAI,IAClF,EACA,GAAS,YAAc,WACvB,SAAS,GAAY,EAAS,CAC5B,GAAM,CAAC,EAAM,GAAWA,EAAO,SAAS,EAClC,EAAYA,EAAO,OAAO,IAAI,EAC9B,EAAiBA,EAAO,OAAO,CAAO,EACtC,EAAuBA,EAAO,OAAO,MAAM,EAE3C,CAAC,EAAO,GAAQ,GADD,EAAU,UAAY,YACS,CAClD,QAAS,CACP,QAAS,YACT,cAAe,kBACjB,EACA,iBAAkB,CAChB,MAAO,UACP,cAAe,WACjB,EACA,UAAW,CACT,MAAO,SACT,CACF,CAAC,EAiED,OAhEA,EAAO,cAAgB,CACrB,IAAM,EAAuB,GAAiB,EAAU,OAAO,EAC/D,EAAqB,QAAU,IAAU,UAAY,EAAuB,MAC9E,EAAG,CAAC,CAAK,CAAC,EACV,OAAsB,CACpB,IAAM,EAAS,EAAU,QACnB,EAAa,EAAe,QAElC,GAD0B,IAAe,EAClB,CACrB,IAAM,EAAoB,EAAqB,QACzC,EAAuB,GAAiB,CAAM,EAChD,EACF,EAAK,OAAO,EACH,IAAyB,QAAU,GAAQ,UAAY,OAChE,EAAK,SAAS,EAIZ,EADE,GADgB,IAAsB,EAEnC,gBAEA,SAAS,EAGlB,EAAe,QAAU,CAC3B,CACF,EAAG,CAAC,EAAS,CAAI,CAAC,EAClB,OAAsB,CACpB,GAAI,EAAM,CACR,IAAI,EACE,EAAc,EAAK,cAAc,aAAe,OAChD,EAAsB,GAAU,CAEpC,IAAM,EADuB,GAAiB,EAAU,OACV,CAAC,CAAC,SAAS,IAAI,OAAO,EAAM,aAAa,CAAC,EACxF,GAAI,EAAM,SAAW,GAAQ,IAC3B,EAAK,eAAe,EAChB,CAAC,EAAe,SAAS,CAC3B,IAAM,EAAkB,EAAK,MAAM,kBACnC,EAAK,MAAM,kBAAoB,WAC/B,EAAY,EAAY,eAAiB,CACnC,EAAK,MAAM,oBAAsB,aACnC,EAAK,MAAM,kBAAoB,EAEnC,CAAC,CACH,CAEJ,EACM,EAAwB,GAAU,CAClC,EAAM,SAAW,IACnB,EAAqB,QAAU,GAAiB,EAAU,OAAO,EAErE,EAIA,OAHA,EAAK,iBAAiB,iBAAkB,CAAoB,EAC5D,EAAK,iBAAiB,kBAAmB,CAAkB,EAC3D,EAAK,iBAAiB,eAAgB,CAAkB,MAC3C,CACX,EAAY,aAAa,CAAS,EAClC,EAAK,oBAAoB,iBAAkB,CAAoB,EAC/D,EAAK,oBAAoB,kBAAmB,CAAkB,EAC9D,EAAK,oBAAoB,eAAgB,CAAkB,CAC7D,CACF,MACE,EAAK,eAAe,CAExB,EAAG,CAAC,EAAM,CAAI,CAAC,EACR,CACL,UAAW,CAAC,UAAW,kBAAkB,CAAC,CAAC,SAAS,CAAK,EACzD,IAAKA,EAAO,YAAa,GAAU,CACjC,EAAU,QAAU,EAAQ,iBAAiB,CAAK,EAAI,KACtD,EAAQ,CAAK,CACf,EAAG,CAAC,CAAC,CACP,CACF,CACA,SAAS,GAAO,EAAK,EAAO,CAC1B,GAAI,OAAO,GAAQ,WACjB,OAAO,EAAI,CAAK,EACP,GAAQ,OACjB,EAAI,QAAU,EAElB,CACA,SAAS,GAAsB,GAAG,EAAM,CACtC,IAAM,EAAUA,EAAO,OAAO,CAAI,EAElC,MADA,GAAQ,QAAU,EACXA,EAAO,YAAa,GAAS,CAClC,IAAM,EAAc,EAAQ,QACxB,EAAa,GACX,EAAW,EAAY,IAAK,GAAQ,CACxC,IAAM,EAAU,GAAO,EAAK,CAAI,EAIhC,MAHI,CAAC,GAAc,OAAO,GAAY,aACpC,EAAa,IAER,CACT,CAAC,EACD,GAAI,EACF,UAAa,CACX,IAAK,IAAI,EAAI,EAAG,EAAI,EAAS,OAAQ,IAAK,CACxC,IAAM,EAAU,EAAS,GACrB,OAAO,GAAY,WACrB,EAAQ,EAER,GAAO,EAAY,GAAI,IAAI,CAE/B,CACF,CAEJ,EAAG,CAAC,CAAC,CACP,CACA,SAAS,GAAiB,EAAQ,CAChC,OAAO,GAAQ,eAAiB,MAClC,CACA,SAASC,GAAc,EAAS,CAC9B,IAAI,EAAS,OAAO,yBAAyB,EAAQ,MAAO,KAAK,CAAC,EAAE,IAChE,EAAU,GAAU,mBAAoB,GAAU,EAAO,eAS7D,OARI,EACK,EAAQ,KAEjB,EAAS,OAAO,yBAAyB,EAAS,KAAK,CAAC,EAAE,IAC1D,EAAU,GAAU,mBAAoB,GAAU,EAAO,eACrD,EACK,EAAQ,MAAM,IAEhB,EAAQ,MAAM,KAAO,EAAQ,IACtC,CCjKA,SAAS,GAAW,EAAW,CAC7B,IAAM,EAAQC,EAAM,YAAY,EAAO,IAAiB,CACtD,GAAI,CAAE,WAAU,GAAG,GAAc,EAC7B,EAAmB,KACnB,EAAe,GACb,EAAc,CAAC,EACjB,GAAgB,CAAQ,GAAK,OAAO,IAAQ,aAC9C,EAAW,GAAI,EAAS,QAAQ,GAElC,EAAM,SAAS,QAAQ,EAAW,GAAmB,CACnD,GAAI,GAAY,CAAc,EAAG,CAC/B,EAAe,GACf,IAAM,EAAY,EACd,EAAQ,UAAW,EAAU,MAAQ,EAAU,MAAM,MAAQ,EAAU,MAAM,SAC7E,GAAgB,CAAK,GAAK,OAAO,IAAQ,aAC3C,EAAQ,GAAI,EAAM,QAAQ,GAE5B,EAAmB,GAAiC,EAAW,CAAK,EACpE,EAAY,KAAK,GAAkB,OAAO,QAAQ,CACpD,MACE,EAAY,KAAK,CAAc,CAEnC,CAAC,EACG,EACF,EAAmBA,EAAM,aAAa,EAAkB,IAAK,GAAG,CAAW,EAM3E,CAAC,GAAgBA,EAAM,SAAS,MAAM,CAAQ,IAAM,GAAKA,EAAM,eAAe,CAAQ,IAEtF,EAAmB,GAErB,IAAM,EAAsB,EAAmB,GAAc,CAAgB,EAAI,IAAK,GAChF,EAAc,EAAgB,EAAc,CAAmB,EACrE,GAAI,CAAC,EAAkB,CACrB,GAAI,GAAY,IAAa,EAC3B,MAAU,MACR,EAAe,GAAqB,CAAS,EAAI,GAAgB,CAAS,CAC5E,EAEF,OAAO,CACT,CACA,IAAM,EAAc,GAAW,EAAW,EAAiB,OAAS,CAAC,CAAC,EAItE,OAHI,EAAiB,OAASA,EAAM,WAClC,EAAY,IAAM,EAAe,EAAc,GAE1CA,EAAM,aAAa,EAAkB,CAAW,CACzD,CAAC,EAED,MADA,GAAM,YAAc,GAAG,EAAU,OAC1B,CACT,CAEA,IAAI,GAAuB,OAAO,IAAI,iBAAiB,EAEvD,SAAS,GAAgB,EAAW,CAClC,IAAM,EAAc,GAAU,UAAW,EAAQ,EAAM,SAAS,EAAM,KAAK,EAAI,EAAM,SAGrF,MAFA,GAAW,YAAc,GAAG,EAAU,YACtC,EAAW,UAAY,GAChB,CACT,CAEA,IAAI,IAAoC,EAAW,IAAU,CAC3D,GAAI,UAAW,EAAU,MAAO,CAC9B,IAAM,EAAS,EAAU,MAAM,MAE/B,OADKA,EAAM,eAAe,CAAM,EACzBA,EAAM,aAAa,EAAQ,IAAK,GAAG,EAAU,MAAM,SAAS,EAAO,MAAM,QAAQ,CAAC,EAD/C,IAE5C,CACA,OAAOA,EAAM,eAAe,CAAK,EAAI,EAAQ,IAC/C,EACA,SAAS,GAAW,EAAW,EAAY,CACzC,IAAM,EAAgB,CAAE,GAAG,CAAW,EACtC,IAAK,IAAM,KAAY,EAAY,CACjC,IAAM,EAAgB,EAAU,GAC1B,EAAiB,EAAW,GAChB,WAAW,KAAK,CACtB,EACN,GAAiB,EACnB,EAAc,IAAa,GAAG,IAAS,CACrC,IAAM,EAAS,EAAe,GAAG,CAAI,EAErC,OADA,EAAc,GAAG,CAAI,EACd,CACT,EACS,IACT,EAAc,GAAY,GAEnB,IAAa,QACtB,EAAc,GAAY,CAAE,GAAG,EAAe,GAAG,CAAe,EACvD,IAAa,cACtB,EAAc,GAAY,CAAC,EAAe,CAAc,CAAC,CAAC,OAAO,OAAO,CAAC,CAAC,KAAK,GAAG,EAEtF,CACA,MAAO,CAAE,GAAG,EAAW,GAAG,CAAc,CAC1C,CACA,SAAS,GAAc,EAAS,CAC9B,IAAI,EAAS,OAAO,yBAAyB,EAAQ,MAAO,KAAK,CAAC,EAAE,IAChE,EAAU,GAAU,mBAAoB,GAAU,EAAO,eAS7D,OARI,EACK,EAAQ,KAEjB,EAAS,OAAO,yBAAyB,EAAS,KAAK,CAAC,EAAE,IAC1D,EAAU,GAAU,mBAAoB,GAAU,EAAO,eACrD,EACK,EAAQ,MAAM,IAEhB,EAAQ,MAAM,KAAO,EAAQ,IACtC,CACA,SAAS,GAAY,EAAO,CAC1B,OAAOA,EAAM,eAAe,CAAK,GAAK,OAAO,EAAM,MAAS,YAAc,cAAe,EAAM,MAAQ,EAAM,KAAK,YAAc,EAClI,CACA,IAAI,GAAkB,OAAO,IAAI,YAAY,EAC7C,SAAS,GAAgB,EAAS,CAChC,OAA0B,OAAO,GAAY,YAAtC,GAAkD,aAAc,GAAW,EAAQ,WAAa,IAAmB,aAAc,GAAW,GAAc,EAAQ,QAAQ,CACnL,CACA,SAAS,GAAc,EAAO,CAC5B,OAAO,OAAO,GAAU,YAAY,GAAkB,SAAU,CAClE,CACA,IAAI,GAAmB,GACd,GAAG,EAAU,4FAElB,GAAwB,GACnB,GAAG,EAAU,yGAElB,GAAMA,EAAM,ICxGZ,EAAY,CAlBd,IACA,SACA,MACA,OACA,KACA,KACA,MACA,QACA,QACA,KACA,MACA,KACA,IACA,SACA,OACA,MACA,IAEkB,CAAC,CAAC,QAAQ,EAAW,IAAS,CAChD,IAAM,EAAO,GAAW,aAAa,GAAM,EACrC,EAAOC,EAAM,YAAY,EAAO,IAAiB,CACrD,GAAM,CAAE,UAAS,GAAG,GAAmB,EACjC,EAAO,EAAU,EAAO,EAI9B,OAHI,OAAO,OAAW,MACpB,OAAO,OAAO,IAAI,UAAU,GAAK,KAEZ,EAAA,EAAA,IAAA,CAAI,EAAM,CAAE,GAAG,EAAgB,IAAK,CAAa,CAAC,CAC3E,CAAC,EAED,MADA,GAAK,YAAc,aAAa,IACzB,CAAE,GAAG,GAAY,GAAO,CAAK,CACtC,EAAG,CAAC,CAAC,EACL,SAAS,GAA4B,EAAQ,EAAO,CAC9C,GAAQ,EAAS,cAAgB,EAAO,cAAc,CAAK,CAAC,CAClE,CC1BA,IAAI,GAAgB,WAChB,CAAC,GAAuB,IAAuB,GAAmB,EAAa,EAC/E,CAAC,GAAsB,IAAsB,GAAsB,EAAa,EACpF,SAAS,GAAiB,EAAO,CAC/B,GAAM,CACJ,kBACA,QAAS,EACT,WACA,iBACA,WACA,OACA,OACA,kBACA,WACA,QAAQ,KAER,8BACE,EACE,CAAC,EAAS,GAAc,GAAqB,CACjD,KAAM,EACN,YAAa,GAAkB,GAC/B,SAAU,EACV,OAAQ,EACV,CAAC,EACK,CAAC,EAAS,GAAcC,EAAM,SAAS,IAAI,EAC3C,CAAC,EAAa,GAAkBA,EAAM,SAAS,IAAI,EACnD,EAAmCA,EAAM,OAAO,EAAK,EACrD,EAAgB,EAAU,CAAC,CAAC,GAAQ,CAAC,CAAC,EAAQ,QAAQ,MAAM,EAEhE,GAEI,EAAU,CACd,UACA,WACA,aACA,UACA,aACA,OACA,OACA,QACA,mCACA,WACA,eAAgBC,GAAgB,CAAc,EAAI,GAAQ,EAC1D,gBACA,cACA,gBACF,EACA,OAAuB,EAAA,EAAA,IAAA,CACrB,GACA,CACE,MAAO,EACP,GAAG,EACH,SAAUC,GAAW,CAA0B,EAAI,EAA2B,CAAO,EAAI,CAC3F,CACF,CACF,CACA,IAAIC,GAAe,kBACf,GAAkBH,EAAM,YACzB,CAAE,kBAAiB,YAAW,UAAS,GAAG,GAAiB,IAAiB,CAC3E,GAAM,CACJ,UACA,QACA,WACA,UACA,WACA,aACA,aACA,mCACA,gBACA,eACE,GAAmBG,GAAc,CAAe,EAC9C,EAAe,EAAgB,EAAc,CAAU,EACvD,EAAyBH,EAAM,OAAO,CAAO,EASnD,OARA,EAAM,cAAgB,CACpB,IAAM,EAAO,GAAS,KACtB,GAAI,EAAM,CACR,IAAM,MAAc,EAAW,EAAuB,OAAO,EAE7D,OADA,EAAK,iBAAiB,QAAS,CAAK,MACvB,EAAK,oBAAoB,QAAS,CAAK,CACtD,CACF,EAAG,CAAC,EAAS,CAAU,CAAC,GACD,EAAA,EAAA,IAAA,CACrB,EAAU,OACV,CACE,KAAM,SACN,KAAM,WACN,eAAgBC,GAAgB,CAAO,EAAI,QAAU,EACrD,gBAAiB,EACjB,aAAcG,GAAS,CAAO,EAC9B,gBAAiB,EAAW,GAAK,IAAK,GACtC,WACA,QACA,GAAG,EACH,IAAK,EACL,UAAW,EAAqB,EAAY,GAAU,CAChD,EAAM,MAAQ,SAAS,EAAM,eAAe,CAClD,CAAC,EACD,QAAS,EAAqB,EAAU,GAAU,CAChD,EAAY,GAAgBH,GAAgB,CAAW,EAAI,GAAO,CAAC,CAAW,EAC1E,GAAe,IACjB,EAAiC,QAAU,EAAM,qBAAqB,EACjE,EAAiC,SAAS,EAAM,gBAAgB,EAEzE,CAAC,CACH,CACF,CACF,CACF,EACA,GAAgB,YAAcE,GAC9B,IAAIE,GAAWL,EAAM,YAClB,EAAO,IAAiB,CACvB,GAAM,CACJ,kBACA,OACA,UACA,iBACA,WACA,WACA,QACA,kBACA,OACA,GAAG,GACD,EACJ,OAAuB,EAAA,EAAA,IAAA,CACrB,GACA,CACE,kBACA,UACA,iBACA,WACA,WACA,kBACA,OACA,OACA,QACA,4BAA6B,CAAE,oBAAoC,EAAA,EAAA,KAAA,CAAKM,EAAAA,SAAU,CAAE,SAAU,EAC5E,EAAA,EAAA,IAAA,CACd,GACA,CACE,GAAG,EACH,IAAK,EACL,iBACF,CACF,EACA,IAAiC,EAAA,EAAA,IAAA,CAC/B,GACA,CACE,iBACF,CACF,CACF,CAAE,CAAC,CACL,CACF,CACF,CACF,EACA,GAAS,YAAc,GACvB,IAAIC,GAAiB,oBACjB,GAAoBP,EAAM,YAC3B,EAAO,IAAiB,CACvB,GAAM,CAAE,kBAAiB,aAAY,GAAG,GAAmB,EACrD,EAAU,GAAmBO,GAAgB,CAAe,EAClE,OAAuB,EAAA,EAAA,IAAA,CACrB,GACA,CACE,QAAS,GAAcN,GAAgB,EAAQ,OAAO,GAAK,EAAQ,UAAY,GAC/E,UAA0B,EAAA,EAAA,IAAA,CACxB,EAAU,KACV,CACE,aAAcG,GAAS,EAAQ,OAAO,EACtC,gBAAiB,EAAQ,SAAW,GAAK,IAAK,GAC9C,GAAG,EACH,IAAK,EACL,MAAO,CAAE,cAAe,OAAQ,GAAG,EAAM,KAAM,CACjD,CACF,CACF,CACF,CACF,CACF,EACA,GAAkB,YAAcG,GAChC,IAAIC,GAAoB,sBACpB,GAAsBR,EAAM,YAC7B,CAAE,kBAAiB,GAAG,GAAS,IAAiB,CAC/C,GAAM,CACJ,UACA,mCACA,UACA,iBACA,WACA,WACA,OACA,QACA,OACA,cACA,kBACE,GAAmBQ,GAAmB,CAAe,EACnD,EAAe,EAAgB,EAAc,CAAc,EAC3D,EAAc,GAAY,CAAO,EACjC,EAAc,GAAQ,CAAO,EACnC,EAAM,cAAgB,CACpB,IAAM,EAAQ,EACd,GAAI,CAAC,EAAO,OACZ,IAAM,EAAa,OAAO,iBAAiB,UAKrC,EAJa,OAAO,yBACxB,EACA,SAE0B,CAAC,CAAC,IACxB,EAAU,CAAC,EAAiC,QAClD,GAAI,IAAgB,GAAW,EAAY,CACzC,IAAM,EAAQ,IAAI,MAAM,QAAS,CAAE,SAAQ,CAAC,EAC5C,EAAM,cAAgBP,GAAgB,CAAO,EAC7C,EAAW,KAAK,EAAOA,GAAgB,CAAO,EAAI,GAAQ,CAAO,EACjE,EAAM,cAAc,CAAK,CAC3B,CACF,EAAG,CAAC,EAAa,EAAa,EAAS,CAAgC,CAAC,EACxE,IAAM,EAAoBD,EAAM,OAAOC,GAAgB,CAAO,EAAI,GAAQ,CAAO,EACjF,OAAuB,EAAA,EAAA,IAAA,CACrB,EAAU,MACV,CACE,KAAM,WACN,cAAe,GACf,eAAgB,GAAkB,EAAkB,QACpD,WACA,WACA,OACA,QACA,OACA,GAAG,EACH,SAAU,GACV,IAAK,EACL,MAAO,CACL,GAAG,EAAM,MACT,GAAG,EACH,SAAU,WACV,cAAe,OACf,QAAS,EACT,OAAQ,EAIR,UAAW,mBACb,CACF,CACF,CACF,CACF,EACA,GAAoB,YAAcO,GAClC,SAASN,GAAW,EAAO,CACzB,OAAO,OAAO,GAAU,UAC1B,CACA,SAASD,GAAgB,EAAS,CAChC,OAAO,IAAY,eACrB,CACA,SAASG,GAAS,EAAS,CACzB,OAAOH,GAAgB,CAAO,EAAI,gBAAkB,EAAU,UAAY,WAC5E,u0KGxQM,IAAqB,CACvB,GAAI,EAAU,MACd,UACA,IACA,IACA,WACA,YACA,YACA,WACA,UACA,IACA,KACA,KACA,KACA,KACA,KACA,KACA,IACA,KACA,KACA,KACA,KACA,KACA,KACA,MACA,OACA,OACA,KACA,YACA,MACA,GAAG,MAGC,EAAA,EAAA,IAAA,CAAC,EAAD,CACS,MACL,UAAW,EACP,GAAU,CACN,UACA,IACA,IACA,WACA,YACA,YACA,WACA,UACA,IACA,KACA,KACA,KACA,KACA,KACA,KACA,IACA,KACA,KACA,KACA,KACA,KACA,KACA,MACA,OACA,OACA,IACJ,CAAC,EACD,CACJ,EACA,GAAI,CACP,CAAA,EAIT,GAAI,YAAc,MCrElB,IAAM,GAAuB,CACzB,YACA,OACA,QACA,UACA,SACA,MAAM,KACN,YACA,GAAG,MAGC,EAAA,EAAA,IAAA,CAAC,GAAD,CACS,MACL,UAAW,EAAG,GAAW,CAAE,YAAW,OAAM,QAAO,UAAS,QAAO,CAAC,EAAG,CAAS,EAChF,GAAI,CACP,CAAA,EAIT,EAAK,YAAc,yCEDb,IAA+B,CAAE,QAAO,KAAI,YAAW,GAAG,KAAY,CACxE,IAAM,GAAA,EAAA,EAAA,MAAA,CAAoB,EACpB,EAAa,IAAO,EAAQ,EAAc,IAAA,IAEh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"}
|