@duro-app/ui 0.7.0 → 0.8.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/components/Cluster/Cluster.d.ts +11 -0
- package/dist/components/Cluster/Cluster.d.ts.map +1 -0
- package/dist/components/Cluster/Cluster.stories.d.ts +9 -0
- package/dist/components/Cluster/Cluster.stories.d.ts.map +1 -0
- package/dist/components/Cluster/styles.css.d.ts +54 -0
- package/dist/components/Cluster/styles.css.d.ts.map +1 -0
- package/dist/components/Grid/Grid.d.ts +11 -0
- package/dist/components/Grid/Grid.d.ts.map +1 -0
- package/dist/components/Grid/Grid.stories.d.ts +10 -0
- package/dist/components/Grid/Grid.stories.d.ts.map +1 -0
- package/dist/components/Grid/styles.css.d.ts +52 -0
- package/dist/components/Grid/styles.css.d.ts.map +1 -0
- package/dist/components/Heading/Heading.d.ts +12 -0
- package/dist/components/Heading/Heading.d.ts.map +1 -0
- package/dist/components/Heading/styles.css.d.ts +22 -0
- package/dist/components/Heading/styles.css.d.ts.map +1 -0
- package/dist/components/Inline/Inline.d.ts +11 -0
- package/dist/components/Inline/Inline.d.ts.map +1 -0
- package/dist/components/Inline/Inline.stories.d.ts +10 -0
- package/dist/components/Inline/Inline.stories.d.ts.map +1 -0
- package/dist/components/Inline/styles.css.d.ts +60 -0
- package/dist/components/Inline/styles.css.d.ts.map +1 -0
- package/dist/components/InputGroup/InputGroup.d.ts +2 -1
- package/dist/components/InputGroup/InputGroup.d.ts.map +1 -1
- package/dist/components/InputGroup/styles.css.d.ts +4 -0
- package/dist/components/InputGroup/styles.css.d.ts.map +1 -1
- package/dist/components/Stack/Stack.d.ts +10 -0
- package/dist/components/Stack/Stack.d.ts.map +1 -0
- package/dist/components/Stack/Stack.stories.d.ts +11 -0
- package/dist/components/Stack/Stack.stories.d.ts.map +1 -0
- package/dist/components/Stack/styles.css.d.ts +44 -0
- package/dist/components/Stack/styles.css.d.ts.map +1 -0
- package/dist/components/Text/Text.d.ts +15 -0
- package/dist/components/Text/Text.d.ts.map +1 -0
- package/dist/components/Text/styles.css.d.ts +48 -0
- package/dist/components/Text/styles.css.d.ts.map +1 -0
- package/dist/docs/Spacing.stories.d.ts +8 -0
- package/dist/docs/Spacing.stories.d.ts.map +1 -0
- package/dist/docs/Typography.stories.d.ts +10 -0
- package/dist/docs/Typography.stories.d.ts.map +1 -0
- package/dist/docs/helpers.d.ts +22 -0
- package/dist/docs/helpers.d.ts.map +1 -0
- package/dist/hooks/useContainerQuery.d.ts +11 -0
- package/dist/hooks/useContainerQuery.d.ts.map +1 -0
- package/dist/index.css +1 -1
- package/dist/index.d.ts +8 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1737 -920
- package/dist/index.js.map +1 -1
- package/package.json +2 -2
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["../../../node_modules/.pnpm/react-strict-dom@0.0.55_postcss@8.5.6_react-dom@19.2.4_react@19.2.4__react-native@0.84._1278be21509893d955b57d0db9435779/node_modules/react-strict-dom/dist/web/runtime.js","../src/components/Alert/styles.css.ts","../src/components/Alert/Alert.tsx","../src/components/Badge/styles.css.ts","../src/components/Badge/Badge.tsx","../src/components/Button/styles.css.ts","../src/components/Button/Button.tsx","../src/components/Card/styles.css.ts","../src/components/Card/Card.tsx","../src/components/Checkbox/styles.css.ts","../src/components/Checkbox/Checkbox.tsx","../src/components/EmptyState/styles.css.ts","../src/components/EmptyState/EmptyState.tsx","../src/components/Field/FieldContext.ts","../src/components/Field/styles.css.ts","../src/components/Field/Field.tsx","../src/components/InputGroup/InputGroupContext.ts","../src/components/Input/styles.css.ts","../src/components/Input/Input.tsx","../src/components/InputGroup/styles.css.ts","../src/components/InputGroup/InputGroup.tsx","../src/components/LinkButton/styles.css.ts","../src/components/LinkButton/LinkButton.tsx","../src/components/Menu/styles.css.ts","../src/components/Menu/MenuContext.ts","../src/components/Menu/useMenuRoot.ts","../src/components/Menu/Menu.tsx","../src/components/ScrollArea/styles.css.ts","../src/components/ScrollArea/ScrollAreaContext.ts","../src/components/ScrollArea/useScrollAreaRoot.ts","../src/components/ScrollArea/ScrollArea.tsx","../src/components/Select/styles.css.ts","../src/components/Select/SelectContext.ts","../src/hooks/useControllableValue.ts","../src/components/Select/useSelectRoot.ts","../src/components/Select/Select.tsx","../src/components/SideNav/styles.css.ts","../src/components/SideNav/SideNavContext.ts","../src/components/SideNav/SideNav.tsx","../src/components/Spinner/styles.css.ts","../src/components/Spinner/Spinner.tsx","../src/components/StatusIcon/styles.css.ts","../src/components/StatusIcon/StatusIcon.tsx","../src/components/Table/styles.css.ts","../src/components/Table/Table.tsx","../src/components/Tabs/styles.css.ts","../src/components/Tabs/TabsContext.ts","../src/components/Tabs/useTabsRoot.ts","../src/components/Tabs/Tabs.tsx","../src/components/Textarea/styles.css.ts","../src/components/Textarea/Textarea.tsx","../../tokens/dist/index.js","../src/components/ThemeProvider/ThemeProvider.tsx","../src/components/Tooltip/styles.css.ts","../src/components/Tooltip/Tooltip.tsx"],"sourcesContent":["/**\n * @license react-strict-dom\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\nimport * as stylex from '@stylexjs/stylex';\n\nvar styleq$1 = {};\n\nObject.defineProperty(styleq$1, \"__esModule\", {\n value: true\n});\nvar styleq_2 = styleq$1.styleq = void 0;\nvar cache = new WeakMap();\nvar compiledKey = '$$css';\nfunction createStyleq(options) {\n var disableCache;\n var disableMix;\n var transform;\n if (options != null) {\n disableCache = options.disableCache === true;\n disableMix = options.disableMix === true;\n transform = options.transform;\n }\n return function styleq() {\n var definedProperties = [];\n var className = '';\n var inlineStyle = null;\n var debugString = '';\n var nextCache = disableCache ? null : cache;\n var styles = new Array(arguments.length);\n for (var i = 0; i < arguments.length; i++) {\n styles[i] = arguments[i];\n }\n while (styles.length > 0) {\n var possibleStyle = styles.pop();\n if (possibleStyle == null || possibleStyle === false) {\n continue;\n }\n if (Array.isArray(possibleStyle)) {\n for (var _i = 0; _i < possibleStyle.length; _i++) {\n styles.push(possibleStyle[_i]);\n }\n continue;\n }\n var style = transform != null ? transform(possibleStyle) : possibleStyle;\n if (style.$$css != null) {\n var classNameChunk = '';\n if (nextCache != null && nextCache.has(style)) {\n var cacheEntry = nextCache.get(style);\n if (cacheEntry != null) {\n classNameChunk = cacheEntry[0];\n debugString = cacheEntry[2];\n definedProperties.push.apply(definedProperties, cacheEntry[1]);\n nextCache = cacheEntry[3];\n }\n } else {\n var definedPropertiesChunk = [];\n for (var prop in style) {\n var value = style[prop];\n if (prop === compiledKey) {\n var compiledKeyValue = style[prop];\n if (compiledKeyValue !== true) {\n debugString = debugString ? compiledKeyValue + '; ' + debugString : compiledKeyValue;\n }\n continue;\n }\n if (typeof value === 'string' || value === null) {\n if (!definedProperties.includes(prop)) {\n definedProperties.push(prop);\n if (nextCache != null) {\n definedPropertiesChunk.push(prop);\n }\n if (typeof value === 'string') {\n classNameChunk += classNameChunk ? ' ' + value : value;\n }\n }\n } else {\n console.error(\"styleq: \".concat(prop, \" typeof \").concat(String(value), \" is not \\\"string\\\" or \\\"null\\\".\"));\n }\n }\n if (nextCache != null) {\n var weakMap = new WeakMap();\n nextCache.set(style, [classNameChunk, definedPropertiesChunk, debugString, weakMap]);\n nextCache = weakMap;\n }\n }\n if (classNameChunk) {\n className = className ? classNameChunk + ' ' + className : classNameChunk;\n }\n } else {\n if (disableMix) {\n if (inlineStyle == null) {\n inlineStyle = {};\n }\n inlineStyle = Object.assign({}, style, inlineStyle);\n } else {\n var subStyle = null;\n for (var _prop in style) {\n var _value = style[_prop];\n if (_value !== undefined) {\n if (!definedProperties.includes(_prop)) {\n if (_value != null) {\n if (inlineStyle == null) {\n inlineStyle = {};\n }\n if (subStyle == null) {\n subStyle = {};\n }\n subStyle[_prop] = _value;\n }\n definedProperties.push(_prop);\n nextCache = null;\n }\n }\n }\n if (subStyle != null) {\n inlineStyle = Object.assign(subStyle, inlineStyle);\n }\n }\n }\n }\n var styleProps = [className, inlineStyle, debugString];\n return styleProps;\n };\n}\nvar styleq = styleq_2 = styleq$1.styleq = createStyleq();\nstyleq.factory = createStyleq;\n\nconst optimizedStyleq = styleq_2.factory({\n disableMix: true\n});\nfunction merge(...styles) {\n const [className, style, dataStyleSrc] = optimizedStyleq(styles);\n const result = {};\n if (className != null && className !== '') {\n result.className = className;\n }\n if (style != null) {\n result.style = style;\n }\n if (dataStyleSrc != null && dataStyleSrc !== '') {\n const chunks = dataStyleSrc.split(';');\n const pathsMap = {};\n for (const chunk of chunks) {\n const trimmed = chunk.trim();\n const [path, line] = trimmed.split(':');\n if (line != null) {\n pathsMap[path] = pathsMap[path] != null ? `${pathsMap[path]},${line}` : line;\n }\n }\n result['data-style-src'] = Object.keys(pathsMap).map(path => `${path}:${pathsMap[path]}`).join('; ');\n }\n return result;\n}\n\nconst styles = stylex.create({\n block: {\n margin: 0,\n padding: 0\n },\n inline: {\n margin: 0,\n padding: 0,\n textDecoration: 'none',\n textAlign: 'inherit',\n wordWrap: 'break-word'\n },\n inlineblock: {\n borderStyle: 'solid',\n margin: 0,\n padding: 0\n },\n button: {\n borderWidth: 1\n },\n codePre: {\n fontFamily: 'monospace, \"monospace\"',\n fontSize: '1em',\n overflow: 'auto'\n },\n heading: {\n fontSize: '1.5rem',\n wordWrap: 'break-word'\n },\n hr: {\n backgroundColor: 'black',\n borderStyle: 'none',\n borderWidth: 0,\n boxSizing: 'border-box',\n height: 1\n },\n img: {\n aspectRatio: 'attr(width) / attr(height)',\n height: 'auto',\n maxWidth: '100%'\n },\n input: {\n borderWidth: 1,\n borderStyle: 'solid'\n },\n list: {\n listStyle: 'none'\n },\n strong: {\n fontWeight: 'bold'\n },\n textarea: {\n borderWidth: 1,\n borderStyle: 'solid',\n resize: 'vertical'\n }\n});\nconst a = styles.inline;\nconst article = styles.block;\nconst aside = styles.block;\nconst b = styles.inline;\nconst bdi = styles.inline;\nconst bdo = styles.inline;\nconst blockquote = styles.block;\nconst br = null;\nconst button = [styles.inlineblock, styles.button];\nconst code = [styles.inline, styles.codePre];\nconst del = null;\nconst div = styles.block;\nconst em = styles.inline;\nconst fieldset = styles.block;\nconst footer = styles.block;\nconst form = styles.block;\nconst heading = [styles.block, styles.heading];\nconst header = styles.block;\nconst hr = [styles.block, styles.hr];\nconst i = styles.inline;\nconst img = styles.img;\nconst input = [styles.inlineblock, styles.input];\nconst ins = null;\nconst kbd = null;\nconst label = styles.inline;\nconst li = styles.block;\nconst main = styles.block;\nconst mark = styles.inline;\nconst nav = styles.block;\nconst ol = [styles.list, styles.block];\nconst optgroup = null;\nconst option = null;\nconst p = styles.block;\nconst pre = [styles.block, styles.codePre];\nconst s = null;\nconst section = styles.block;\nconst select = styles.inlineblock;\nconst span = styles.inline;\nconst strong = [styles.inline, styles.strong];\nconst sub = styles.inline;\nconst sup = styles.inline;\nconst textarea = [styles.inlineblock, styles.textarea];\nconst u = null;\nconst ul = [styles.list, styles.block];\nconst defaultStyles = {\n a: a,\n article: article,\n aside: aside,\n b: b,\n bdi: bdi,\n bdo: bdo,\n blockquote: blockquote,\n br: br,\n button: button,\n code: code,\n del: del,\n div: div,\n em: em,\n fieldset: fieldset,\n footer: footer,\n form: form,\n h1: heading,\n h2: heading,\n h3: heading,\n h4: heading,\n h5: heading,\n h6: heading,\n header: header,\n hr: hr,\n i: i,\n img: img,\n input: input,\n ins: ins,\n kbd: kbd,\n label: label,\n li: li,\n main: main,\n mark: mark,\n nav: nav,\n ol: ol,\n optgroup: optgroup,\n option: option,\n p: p,\n pre: pre,\n s: s,\n section: section,\n select: select,\n span: span,\n strong: strong,\n sub: sub,\n sup: sup,\n textarea: textarea,\n u: u,\n ul: ul\n};\n\nexport { defaultStyles, merge };\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n base: {\n padding: spacing.md,\n borderRadius: radii.sm,\n borderWidth: 1,\n borderStyle: 'solid',\n fontSize: typography.fontSizeSm,\n lineHeight: typography.lineHeight,\n },\n error: {\n backgroundColor: colors.errorBg,\n borderColor: colors.errorBorder,\n color: colors.errorText,\n },\n success: {\n backgroundColor: colors.successBg,\n borderColor: colors.successBorder,\n color: colors.successText,\n },\n warning: {\n backgroundColor: colors.warningBg,\n borderColor: colors.warningBorder,\n color: colors.warningText,\n },\n info: {\n backgroundColor: colors.infoBg,\n borderColor: colors.infoBorder,\n color: colors.infoText,\n },\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\nexport type AlertVariant = 'error' | 'success' | 'warning' | 'info'\n\ninterface AlertProps {\n variant?: AlertVariant\n children: ReactNode\n}\n\nexport function Alert({variant = 'info', children}: AlertProps) {\n return (\n <html.div role=\"alert\" style={[styles.base, styles[variant]]}>\n {children}\n </html.div>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n base: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n fontFamily: typography.fontFamily,\n fontWeight: typography.fontWeightMedium,\n lineHeight: 1,\n borderRadius: radii.full,\n whiteSpace: 'nowrap',\n },\n sizeMd: {\n paddingTop: spacing.xs,\n paddingBottom: spacing.xs,\n paddingLeft: spacing.sm,\n paddingRight: spacing.sm,\n fontSize: typography.fontSizeXs,\n },\n sizeSm: {\n paddingTop: 2,\n paddingBottom: 2,\n paddingLeft: spacing.xs,\n paddingRight: spacing.xs,\n fontSize: '0.625rem',\n },\n default: {\n backgroundColor: colors.bgCardHover,\n color: colors.textMuted,\n },\n success: {\n backgroundColor: colors.successBg,\n color: colors.successText,\n },\n warning: {\n backgroundColor: colors.warningBg,\n color: colors.warningText,\n },\n error: {\n backgroundColor: colors.errorBg,\n color: colors.errorText,\n },\n info: {\n backgroundColor: colors.infoBg,\n color: colors.infoText,\n },\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\nexport type BadgeVariant = 'default' | 'success' | 'warning' | 'error' | 'info'\nexport type BadgeSize = 'sm' | 'md'\n\ninterface BadgeProps {\n variant?: BadgeVariant\n size?: BadgeSize\n children: ReactNode\n}\n\nconst sizeMap = {\n sm: styles.sizeSm,\n md: styles.sizeMd,\n} as const\n\nexport function Badge({variant = 'default', size = 'md', children}: BadgeProps) {\n return <html.span style={[styles.base, sizeMap[size], styles[variant]]}>{children}</html.span>\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n base: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n gap: spacing.sm,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n fontWeight: typography.fontWeightMedium,\n lineHeight: typography.lineHeight,\n borderRadius: radii.sm,\n borderWidth: 1,\n borderStyle: 'solid',\n cursor: 'pointer',\n transitionProperty: 'background-color, border-color, color, opacity',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n textDecoration: 'none',\n outlineWidth: {\n default: 0,\n ':focus-visible': 2,\n },\n outlineStyle: {\n default: 'none',\n ':focus-visible': 'solid',\n },\n outlineColor: {\n default: 'transparent',\n ':focus-visible': colors.accent,\n },\n outlineOffset: {\n default: 0,\n ':focus-visible': 2,\n },\n },\n sizeDefault: {\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n },\n sizeSmall: {\n paddingTop: spacing.xs,\n paddingBottom: spacing.xs,\n paddingLeft: spacing.sm,\n paddingRight: spacing.sm,\n fontSize: typography.fontSizeXs,\n },\n primary: {\n backgroundColor: {\n default: colors.accent,\n ':hover': colors.accentHover,\n ':active': colors.accentHover,\n },\n borderColor: {\n default: colors.accent,\n ':hover': colors.accentHover,\n },\n color: colors.accentContrast,\n },\n secondary: {\n backgroundColor: {\n default: 'transparent',\n ':hover': colors.bgCardHover,\n },\n borderColor: colors.border,\n color: colors.textMuted,\n },\n link: {\n backgroundColor: 'transparent',\n borderColor: 'transparent',\n color: {\n default: colors.accent,\n ':hover': colors.accentHover,\n },\n textDecoration: {\n default: 'none',\n ':hover': 'underline',\n },\n paddingLeft: 0,\n paddingRight: 0,\n },\n danger: {\n backgroundColor: {\n default: colors.error,\n ':hover': colors.errorHover,\n ':active': colors.errorHover,\n },\n borderColor: {\n default: colors.error,\n ':hover': colors.errorHover,\n },\n color: colors.errorContrast,\n },\n fullWidth: {\n width: '100%',\n },\n disabled: {\n opacity: 0.5,\n cursor: 'not-allowed',\n },\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\nexport type ButtonVariant = 'primary' | 'secondary' | 'link' | 'danger'\nexport type ButtonSize = 'default' | 'small'\n\ninterface ButtonProps {\n variant?: ButtonVariant\n size?: ButtonSize\n fullWidth?: boolean\n disabled?: boolean\n type?: 'button' | 'submit'\n onClick?: () => void\n children: ReactNode\n}\n\nconst sizeMap = {\n default: styles.sizeDefault,\n small: styles.sizeSmall,\n} as const\n\nexport function Button({\n variant = 'primary',\n size = 'default',\n fullWidth = false,\n disabled = false,\n type = 'button',\n onClick,\n children,\n}: ButtonProps) {\n return (\n <html.button\n type={type}\n disabled={disabled}\n onClick={onClick}\n style={[\n styles.base,\n sizeMap[size],\n styles[variant],\n fullWidth && styles.fullWidth,\n disabled && styles.disabled,\n ]}\n >\n {children}\n </html.button>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\nimport {shadows} from '@duro-app/tokens/tokens/shadows.css'\n\nexport const styles = css.create({\n base: {\n backgroundColor: colors.bgCard,\n color: colors.text,\n fontFamily: typography.fontFamily,\n },\n // Variants\n elevated: {\n borderRadius: radii.lg,\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: colors.border,\n boxShadow: shadows.md,\n },\n outlined: {\n borderRadius: radii.md,\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: colors.border,\n },\n filled: {\n borderRadius: radii.md,\n },\n interactive: {\n borderRadius: radii.md,\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: {\n default: colors.border,\n ':hover': colors.accent,\n },\n backgroundColor: {\n default: colors.bgCard,\n ':hover': colors.bgCardHover,\n },\n cursor: 'pointer',\n transitionProperty: 'background-color, border-color, transform',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n transform: {\n default: 'translateY(0)',\n ':hover': 'translateY(-2px)',\n },\n },\n // Sizes (padding)\n sizeDefault: {\n padding: spacing.lg,\n },\n sizeCompact: {\n padding: spacing.md,\n },\n sizeFull: {\n padding: spacing.xl,\n },\n // Header\n header: {\n fontSize: typography.fontSizeLg,\n fontWeight: typography.fontWeightSemibold,\n marginBottom: spacing.md,\n },\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\nexport type CardVariant = 'elevated' | 'outlined' | 'filled' | 'interactive'\nexport type CardSize = 'default' | 'compact' | 'full'\n\ninterface CardProps {\n variant?: CardVariant\n size?: CardSize\n header?: string\n onClick?: () => void\n children: ReactNode\n}\n\nconst sizeMap = {\n default: styles.sizeDefault,\n compact: styles.sizeCompact,\n full: styles.sizeFull,\n} as const\n\nexport function Card({\n variant = 'outlined',\n size = 'default',\n header,\n onClick,\n children,\n}: CardProps) {\n return (\n <html.div onClick={onClick} style={[styles.base, styles[variant], sizeMap[size]]}>\n {header && <html.div style={styles.header}>{header}</html.div>}\n {children}\n </html.div>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n root: {\n display: 'inline-flex',\n alignItems: 'center',\n gap: spacing.sm,\n cursor: 'pointer',\n fontSize: typography.fontSizeSm,\n color: colors.text,\n lineHeight: typography.lineHeight,\n },\n rootDisabled: {\n opacity: 0.5,\n cursor: 'not-allowed',\n },\n box: {\n width: 18,\n height: 18,\n borderWidth: 1,\n borderStyle: 'solid',\n borderRadius: radii.sm,\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n flexShrink: 0,\n transitionProperty: 'background-color, border-color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n },\n boxUnchecked: {\n backgroundColor: colors.bg,\n borderColor: {\n default: colors.border,\n ':hover': colors.textMuted,\n },\n },\n boxChecked: {\n backgroundColor: colors.accent,\n borderColor: colors.accent,\n },\n check: {\n width: 12,\n height: 12,\n color: colors.accentContrast,\n },\n input: {\n position: 'absolute',\n width: 1,\n height: 1,\n opacity: 0,\n overflow: 'hidden',\n },\n})\n","import {type ReactNode, useState, useCallback} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\ninterface CheckboxProps {\n name?: string\n value?: string\n checked?: boolean\n defaultChecked?: boolean\n disabled?: boolean\n onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void\n children?: ReactNode\n}\n\nexport function Checkbox({\n name,\n value,\n checked: controlledChecked,\n defaultChecked = false,\n disabled = false,\n onChange,\n children,\n}: CheckboxProps) {\n const isControlled = controlledChecked !== undefined\n const [internalChecked, setInternalChecked] = useState(defaultChecked)\n const isChecked = isControlled ? controlledChecked : internalChecked\n\n const handleChange = useCallback(\n (e: React.ChangeEvent<HTMLInputElement>) => {\n if (!isControlled) {\n setInternalChecked(e.target.checked)\n }\n onChange?.(e)\n },\n [isControlled, onChange],\n )\n\n return (\n <html.label style={[styles.root, disabled && styles.rootDisabled]}>\n <html.input\n type=\"checkbox\"\n name={name}\n value={value}\n checked={isControlled ? controlledChecked : undefined}\n defaultChecked={!isControlled ? defaultChecked : undefined}\n disabled={disabled}\n onChange={handleChange}\n style={styles.input}\n />\n <html.span\n style={[styles.box, isChecked ? styles.boxChecked : styles.boxUnchecked]}\n aria-hidden\n >\n <svg\n width={12}\n height={12}\n viewBox=\"0 0 12 12\"\n fill=\"none\"\n style={{opacity: isChecked ? 1 : 0}}\n >\n <polyline\n points=\"2.5 6 5 8.5 9.5 3.5\"\n stroke=\"currentColor\"\n strokeWidth={1.5}\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n </html.span>\n {children && <html.span>{children}</html.span>}\n </html.label>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n root: {\n display: 'flex',\n flexDirection: 'column',\n alignItems: 'center',\n justifyContent: 'center',\n gap: spacing.sm,\n paddingTop: spacing.xl,\n paddingBottom: spacing.xl,\n textAlign: 'center',\n },\n message: {\n fontSize: typography.fontSizeSm,\n color: colors.textMuted,\n lineHeight: typography.lineHeight,\n },\n action: {\n marginTop: spacing.sm,\n },\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\ninterface EmptyStateProps {\n message: string\n icon?: ReactNode\n action?: ReactNode\n}\n\nexport function EmptyState({message, icon, action}: EmptyStateProps) {\n return (\n <html.div style={styles.root}>\n {icon}\n <html.p style={styles.message}>{message}</html.p>\n {action && <html.div style={styles.action}>{action}</html.div>}\n </html.div>\n )\n}\n","import {createContext, useContext} from 'react'\n\ninterface FieldContextValue {\n controlId: string\n descriptionId: string\n errorId: string\n invalid: boolean\n}\n\nexport const FieldContext = createContext<FieldContextValue | null>(null)\n\nexport function useFieldContext() {\n return useContext(FieldContext)\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n root: {\n display: 'flex',\n flexDirection: 'column',\n gap: spacing.xs,\n },\n label: {\n fontSize: typography.fontSizeSm,\n fontWeight: typography.fontWeightMedium,\n color: colors.text,\n },\n description: {\n fontSize: typography.fontSizeXs,\n color: colors.textMuted,\n },\n error: {\n fontSize: typography.fontSizeXs,\n color: colors.error,\n },\n})\n","import {type ReactNode, useId, useMemo} from 'react'\nimport {html} from 'react-strict-dom'\nimport {FieldContext, useFieldContext} from './FieldContext'\nimport {styles} from './styles.css'\n\n// --- Root ---\ninterface RootProps {\n invalid?: boolean\n children: ReactNode\n}\n\nfunction Root({invalid = false, children}: RootProps) {\n const id = useId()\n const ctx = useMemo(\n () => ({\n controlId: `${id}-control`,\n descriptionId: `${id}-description`,\n errorId: `${id}-error`,\n invalid,\n }),\n [id, invalid],\n )\n\n return (\n <FieldContext.Provider value={ctx}>\n <html.div style={styles.root}>{children}</html.div>\n </FieldContext.Provider>\n )\n}\n\n// --- Label ---\ninterface LabelProps {\n children: ReactNode\n}\n\nfunction Label({children}: LabelProps) {\n const ctx = useFieldContext()\n return (\n <html.label for={ctx?.controlId} style={styles.label}>\n {children}\n </html.label>\n )\n}\n\n// --- Description ---\ninterface DescriptionProps {\n children: ReactNode\n}\n\nfunction Description({children}: DescriptionProps) {\n const ctx = useFieldContext()\n return (\n <html.span id={ctx?.descriptionId} style={styles.description}>\n {children}\n </html.span>\n )\n}\n\n// --- Error ---\ninterface ErrorProps {\n children?: ReactNode\n}\n\nfunction Error({children}: ErrorProps) {\n const ctx = useFieldContext()\n if (!ctx?.invalid && !children) return null\n\n return (\n <html.span id={ctx?.errorId} role=\"alert\" style={styles.error}>\n {children}\n </html.span>\n )\n}\n\nexport const Field = {\n Root,\n Label,\n Description,\n Error,\n}\n","import {createContext, useContext} from 'react'\n\ninterface InputGroupContextValue {\n inGroup: boolean\n}\n\nexport const InputGroupContext = createContext<InputGroupContextValue | null>(null)\n\nexport function useInputGroupContext() {\n return useContext(InputGroupContext)\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n base: {\n width: '100%',\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n lineHeight: typography.lineHeight,\n color: colors.text,\n backgroundColor: colors.bg,\n borderWidth: 1,\n borderStyle: 'solid',\n borderRadius: radii.sm,\n transitionProperty: 'border-color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n outlineWidth: {\n default: 0,\n ':focus-visible': 2,\n },\n outlineStyle: {\n default: 'none',\n ':focus-visible': 'solid',\n },\n outlineColor: {\n default: 'transparent',\n ':focus-visible': colors.accent,\n },\n outlineOffset: {\n default: 0,\n ':focus-visible': 1,\n },\n },\n default: {\n borderColor: {\n default: colors.border,\n ':hover': colors.textMuted,\n ':focus': colors.accent,\n },\n },\n error: {\n borderColor: {\n default: colors.error,\n ':focus': colors.error,\n },\n },\n inGroup: {\n borderWidth: 0,\n borderRadius: 0,\n outlineWidth: 0,\n },\n})\n","import {html} from 'react-strict-dom'\nimport {useFieldContext} from '../Field/FieldContext'\nimport {useInputGroupContext} from '../InputGroup/InputGroupContext'\nimport {styles} from './styles.css'\n\ntype StrictInputProps = React.ComponentProps<typeof html.input>\nexport type InputType = NonNullable<StrictInputProps['type']>\n\nexport type InputVariant = 'default' | 'error'\n\ninterface InputProps {\n variant?: InputVariant\n type?: InputType\n name?: string\n placeholder?: string\n required?: boolean\n minLength?: number\n pattern?: string\n autoComplete?:\n | 'on'\n | 'off'\n | 'email'\n | 'username'\n | 'current-password'\n | 'new-password'\n | 'name'\n | 'tel'\n | 'url'\n value?: string\n defaultValue?: string\n disabled?: boolean\n onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void\n}\n\nexport function Input({\n variant = 'default',\n type = 'text',\n name,\n placeholder,\n required,\n minLength,\n pattern,\n autoComplete,\n value,\n defaultValue,\n disabled,\n onChange,\n}: InputProps) {\n const ctx = useFieldContext()\n const groupCtx = useInputGroupContext()\n\n // react-strict-dom omits web-only `pattern` from its types, but the\n // underlying DOM element supports it. Type-assert to pass it through.\n const extraProps = pattern !== undefined ? {pattern} : undefined\n\n return (\n <html.input\n id={ctx?.controlId}\n type={type}\n name={name}\n placeholder={placeholder}\n required={required}\n minLength={minLength}\n autoComplete={autoComplete}\n value={value}\n defaultValue={defaultValue}\n disabled={disabled}\n aria-describedby={\n ctx ? `${ctx.descriptionId} ${ctx.invalid ? ctx.errorId : ''}`.trim() : undefined\n }\n aria-invalid={ctx?.invalid || variant === 'error' || undefined}\n onChange={onChange}\n style={[styles.base, styles[variant], groupCtx?.inGroup && styles.inGroup]}\n {...(extraProps as Record<string, unknown>)}\n />\n )\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n wrapper: {\n display: 'flex',\n alignItems: 'stretch',\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: {\n default: colors.border,\n ':focus-within': colors.accent,\n },\n borderRadius: radii.sm,\n overflow: 'hidden',\n transitionProperty: 'border-color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n },\n addon: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n flexShrink: 0,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n backgroundColor: colors.bgCardHover,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n color: colors.textMuted,\n userSelect: 'none',\n borderWidth: 0,\n },\n addonStart: {\n borderRightWidth: 1,\n borderRightStyle: 'solid',\n borderRightColor: colors.border,\n },\n addonEnd: {\n borderLeftWidth: 1,\n borderLeftStyle: 'solid',\n borderLeftColor: colors.border,\n },\n addonClickable: {\n cursor: 'pointer',\n backgroundColor: {\n default: colors.bgCardHover,\n ':hover': colors.bgCard,\n ':active': colors.bg,\n },\n transitionProperty: 'background-color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n },\n})\n","import type {ReactNode} from 'react'\nimport {useMemo} from 'react'\nimport {html} from 'react-strict-dom'\nimport {InputGroupContext} from './InputGroupContext'\nimport {styles} from './styles.css'\n\n// --- Root ---\ninterface RootProps {\n children: ReactNode\n}\n\nfunction Root({children}: RootProps) {\n const ctx = useMemo(() => ({inGroup: true}), [])\n\n return (\n <InputGroupContext.Provider value={ctx}>\n <html.div style={styles.wrapper}>{children}</html.div>\n </InputGroupContext.Provider>\n )\n}\n\n// --- Addon ---\ninterface AddonProps {\n position?: 'start' | 'end'\n onClick?: () => void\n children: ReactNode\n}\n\nfunction Addon({position = 'end', onClick, children}: AddonProps) {\n const positionStyle = position === 'start' ? styles.addonStart : styles.addonEnd\n const style = [styles.addon, positionStyle, onClick && styles.addonClickable]\n\n if (onClick) {\n return (\n <html.button type=\"button\" onClick={onClick} style={style}>\n {children}\n </html.button>\n )\n }\n\n return <html.span style={style}>{children}</html.span>\n}\n\nexport const InputGroup = {\n Root,\n Addon,\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n base: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n gap: spacing.sm,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n fontWeight: typography.fontWeightMedium,\n lineHeight: typography.lineHeight,\n borderRadius: radii.sm,\n cursor: 'pointer',\n textDecoration: 'none',\n transitionProperty: 'background-color, border-color, color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n },\n sizeDefault: {\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n },\n sizeSmall: {\n paddingTop: spacing.xs,\n paddingBottom: spacing.xs,\n paddingLeft: spacing.sm,\n paddingRight: spacing.sm,\n fontSize: typography.fontSizeXs,\n },\n primary: {\n backgroundColor: {\n default: colors.accent,\n ':hover': colors.accentHover,\n },\n color: colors.accentContrast,\n },\n secondary: {\n backgroundColor: {\n default: 'transparent',\n ':hover': colors.bgCardHover,\n },\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: colors.border,\n color: colors.textMuted,\n },\n fullWidth: {\n width: '100%',\n },\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\nexport type LinkButtonVariant = 'primary' | 'secondary'\nexport type LinkButtonSize = 'default' | 'small'\n\ninterface LinkButtonProps {\n href: string\n variant?: LinkButtonVariant\n size?: LinkButtonSize\n fullWidth?: boolean\n target?: '_blank' | '_self'\n rel?: string\n children: ReactNode\n}\n\nconst sizeMap = {\n default: styles.sizeDefault,\n small: styles.sizeSmall,\n} as const\n\nexport function LinkButton({\n href,\n variant = 'primary',\n size = 'default',\n fullWidth = false,\n target,\n rel,\n children,\n}: LinkButtonProps) {\n return (\n <html.a\n href={href}\n target={target}\n rel={rel}\n style={[styles.base, sizeMap[size], styles[variant], fullWidth && styles.fullWidth]}\n >\n {children}\n </html.a>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\nimport {shadows} from '@duro-app/tokens/tokens/shadows.css'\n\nexport const styles = css.create({\n root: {\n position: 'relative',\n display: 'inline-flex',\n },\n trigger: {\n display: 'inline-flex',\n alignItems: 'center',\n gap: spacing.sm,\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n color: colors.text,\n backgroundColor: {\n default: 'transparent',\n ':hover': colors.bgCardHover,\n },\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: colors.border,\n borderRadius: radii.sm,\n cursor: 'pointer',\n transitionProperty: 'background-color, border-color',\n transitionDuration: '150ms',\n },\n backdrop: {\n position: 'fixed',\n top: 0,\n left: 0,\n right: 0,\n bottom: 0,\n zIndex: 49,\n },\n popup: {\n position: 'absolute',\n top: '100%',\n left: 0,\n marginTop: spacing.xs,\n backgroundColor: colors.bgCard,\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: colors.border,\n borderRadius: radii.sm,\n boxShadow: shadows.md,\n paddingTop: spacing.xs,\n paddingBottom: spacing.xs,\n minWidth: 160,\n zIndex: 50,\n },\n popupEnd: {\n left: 'auto',\n right: 0,\n },\n item: {\n display: 'flex',\n alignItems: 'center',\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontSize: typography.fontSizeSm,\n fontFamily: typography.fontFamily,\n color: colors.text,\n borderRadius: radii.sm,\n cursor: 'pointer',\n backgroundColor: 'transparent',\n transitionProperty: 'background-color',\n transitionDuration: '150ms',\n },\n itemHighlighted: {\n backgroundColor: colors.bgCardHover,\n },\n linkItem: {\n textDecoration: 'none',\n color: {\n default: colors.text,\n ':hover': colors.text,\n },\n },\n})\n","import {createContext, useContext} from 'react'\n\nexport interface MenuContextValue {\n open: boolean\n toggle: () => void\n close: () => void\n menuId: string\n highlightedId: string | null\n setHighlightedId: (id: string | null) => void\n registerItem: (id: string, element: HTMLElement) => () => void\n triggerRef: React.RefObject<HTMLButtonElement | null>\n}\n\nexport const MenuContext = createContext<MenuContextValue | null>(null)\n\nexport function useMenu() {\n const ctx = useContext(MenuContext)\n if (!ctx) throw new Error('Menu compound components must be used within Menu.Root')\n return ctx\n}\n","import {useState, useCallback, useRef, useId, useEffect} from 'react'\nimport type {MenuContextValue} from './MenuContext'\n\nexport function useMenuRoot() {\n const [open, setOpen] = useState(false)\n const [highlightedId, setHighlightedId] = useState<string | null>(null)\n const menuId = useId()\n const rootRef = useRef<HTMLDivElement>(null)\n const triggerRef = useRef<HTMLButtonElement | null>(null)\n const itemsRef = useRef(new Map<string, HTMLElement>())\n const orderRef = useRef<string[]>([])\n const needsInitialHighlightRef = useRef(false)\n\n const close = useCallback(() => {\n setOpen(false)\n setHighlightedId(null)\n needsInitialHighlightRef.current = false\n triggerRef.current?.focus()\n }, [])\n\n const toggle = useCallback(() => {\n setOpen((prev) => {\n if (!prev) {\n needsInitialHighlightRef.current = true\n } else {\n setHighlightedId(null)\n needsInitialHighlightRef.current = false\n }\n return !prev\n })\n }, [])\n\n // Highlight the first item after items register on open.\n // Child effects (item registration) run before this parent effect,\n // so orderRef is populated by the time this runs.\n useEffect(() => {\n if (open && needsInitialHighlightRef.current) {\n needsInitialHighlightRef.current = false\n const order = orderRef.current\n if (order.length > 0) {\n setHighlightedId(order[0])\n }\n }\n }, [open])\n\n const registerItem = useCallback((id: string, element: HTMLElement) => {\n itemsRef.current.set(id, element)\n const map = itemsRef.current\n const ids = [...map.keys()]\n ids.sort((a, b) => {\n const elA = map.get(a)\n const elB = map.get(b)\n if (!elA || !elB) return 0\n return elA.compareDocumentPosition(elB) & Node.DOCUMENT_POSITION_FOLLOWING ? -1 : 1\n })\n orderRef.current = ids\n return () => {\n itemsRef.current.delete(id)\n orderRef.current = orderRef.current.filter((i) => i !== id)\n }\n }, [])\n\n // Native keydown for full KeyboardEvent access (preventDefault)\n useEffect(() => {\n const root = rootRef.current\n if (!root || !open) return\n\n function handleKeyDown(e: KeyboardEvent) {\n const order = orderRef.current\n if (order.length === 0) return\n\n switch (e.key) {\n case 'ArrowDown': {\n e.preventDefault()\n setHighlightedId((prev) => {\n const idx = prev ? order.indexOf(prev) : -1\n return order[(idx + 1) % order.length]\n })\n break\n }\n case 'ArrowUp': {\n e.preventDefault()\n setHighlightedId((prev) => {\n const idx = prev ? order.indexOf(prev) : 0\n return order[(idx - 1 + order.length) % order.length]\n })\n break\n }\n case 'Home': {\n e.preventDefault()\n setHighlightedId(order[0])\n break\n }\n case 'End': {\n e.preventDefault()\n setHighlightedId(order[order.length - 1])\n break\n }\n case 'Enter':\n case ' ': {\n e.preventDefault()\n const items = itemsRef.current\n setHighlightedId((prev) => {\n if (prev) {\n const el = items.get(prev)\n el?.click()\n }\n return prev\n })\n break\n }\n case 'Escape':\n case 'Tab': {\n close()\n break\n }\n }\n }\n\n root.addEventListener('keydown', handleKeyDown)\n return () => root.removeEventListener('keydown', handleKeyDown)\n }, [open, close])\n\n const ctx: MenuContextValue = {\n open,\n toggle,\n close,\n menuId,\n highlightedId,\n setHighlightedId,\n registerItem,\n triggerRef,\n }\n\n return {ctx, rootRef}\n}\n","import {type ReactNode, useRef, useId, useEffect} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\nimport {MenuContext, useMenu} from './MenuContext'\nimport {useMenuRoot} from './useMenuRoot'\n\n// --- Root ---\ninterface RootProps {\n children: ReactNode\n}\n\nfunction Root({children}: RootProps) {\n const {ctx, rootRef} = useMenuRoot()\n\n return (\n <MenuContext.Provider value={ctx}>\n <html.div ref={rootRef} style={styles.root}>\n {children}\n </html.div>\n </MenuContext.Provider>\n )\n}\n\n// --- Trigger ---\nfunction Trigger({children}: {children: ReactNode}) {\n const {open, toggle, menuId, triggerRef} = useMenu()\n const localRef = useRef<HTMLButtonElement>(null)\n\n // Sync local ref to context triggerRef\n useEffect(() => {\n triggerRef.current = localRef.current\n })\n\n return (\n <html.button\n ref={localRef}\n type=\"button\"\n onClick={toggle}\n aria-expanded={open}\n aria-haspopup=\"menu\"\n aria-controls={open ? menuId : undefined}\n style={styles.trigger}\n >\n {children}\n </html.button>\n )\n}\n\n// --- Popup ---\ninterface PopupProps {\n children: ReactNode\n align?: 'start' | 'end'\n}\n\nfunction Popup({children, align = 'start'}: PopupProps) {\n const {open, close, menuId, highlightedId} = useMenu()\n\n if (!open) return null\n\n return (\n <>\n <html.div style={styles.backdrop} onClick={close} />\n <html.div\n id={menuId}\n role=\"menu\"\n aria-activedescendant={highlightedId ?? undefined}\n style={[styles.popup, align === 'end' && styles.popupEnd]}\n >\n {children}\n </html.div>\n </>\n )\n}\n\n// --- Item ---\ninterface ItemProps {\n onClick?: () => void\n children: ReactNode\n}\n\nfunction Item({onClick, children}: ItemProps) {\n const {close, highlightedId, setHighlightedId, registerItem} = useMenu()\n const id = useId()\n const ref = useRef<HTMLDivElement>(null)\n const isHighlighted = highlightedId === id\n\n useEffect(() => {\n const el = ref.current\n if (!el) return\n return registerItem(id, el)\n }, [id, registerItem])\n\n const handleClick = () => {\n onClick?.()\n close()\n }\n\n return (\n <html.div\n ref={ref}\n id={id}\n role=\"menuitem\"\n onClick={handleClick}\n onPointerEnter={() => setHighlightedId(id)}\n style={[styles.item, isHighlighted && styles.itemHighlighted]}\n >\n {children}\n </html.div>\n )\n}\n\n// --- LinkItem ---\ninterface LinkItemProps {\n href: string\n children: ReactNode\n}\n\nfunction LinkItem({href, children}: LinkItemProps) {\n const {close, highlightedId, setHighlightedId, registerItem} = useMenu()\n const id = useId()\n const ref = useRef<HTMLAnchorElement>(null)\n const isHighlighted = highlightedId === id\n\n useEffect(() => {\n const el = ref.current\n if (!el) return\n return registerItem(id, el)\n }, [id, registerItem])\n\n return (\n <html.a\n ref={ref}\n id={id}\n href={href}\n onClick={close}\n role=\"menuitem\"\n onPointerEnter={() => setHighlightedId(id)}\n style={[styles.item, styles.linkItem, isHighlighted && styles.itemHighlighted]}\n >\n {children}\n </html.a>\n )\n}\n\nexport const Menu = {\n Root,\n Trigger,\n Popup,\n Item,\n LinkItem,\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {radii} from '@duro-app/tokens/tokens/spacing.css'\n\nexport const styles = css.create({\n root: {\n position: 'relative',\n overflow: 'hidden',\n },\n viewport: {\n width: '100%',\n height: '100%',\n overflowX: 'auto',\n overflowY: 'auto',\n // Hide native scrollbar\n scrollbarWidth: 'none',\n },\n content: {\n minWidth: '100%',\n minHeight: '100%',\n },\n scrollbar: {\n position: 'absolute',\n zIndex: 1,\n display: 'flex',\n touchAction: 'none',\n userSelect: 'none',\n transitionProperty: 'opacity',\n transitionDuration: '200ms',\n transitionTimingFunction: 'ease',\n },\n scrollbarVertical: {\n top: 0,\n right: 0,\n bottom: 0,\n width: 8,\n flexDirection: 'column',\n paddingTop: 2,\n paddingBottom: 2,\n paddingRight: 2,\n },\n scrollbarHorizontal: {\n left: 0,\n right: 0,\n bottom: 0,\n height: 8,\n flexDirection: 'row',\n paddingLeft: 2,\n paddingRight: 2,\n paddingBottom: 2,\n },\n scrollbarHidden: {\n opacity: 0,\n },\n scrollbarVisible: {\n opacity: 1,\n },\n thumb: {\n position: 'relative',\n flex: 1,\n backgroundColor: {\n default: colors.border,\n ':hover': colors.textMuted,\n },\n borderRadius: radii.full,\n transitionProperty: 'background-color',\n transitionDuration: '150ms',\n },\n // Dynamic styles — simple identifier params only (StyleX constraint)\n viewportMaxHeight: (maxHeight: number | string) => ({\n maxHeight,\n }),\n thumbVertical: (height: string, transform: string) => ({\n height,\n transform,\n }),\n thumbHorizontal: (width: string, transform: string) => ({\n width,\n transform,\n }),\n})\n","import {createContext, useContext} from 'react'\n\nexport interface ScrollAreaContextValue {\n viewportRef: React.RefObject<HTMLDivElement | null>\n contentRef: React.RefObject<HTMLDivElement | null>\n scrollTop: number\n scrollLeft: number\n scrollHeight: number\n scrollWidth: number\n clientHeight: number\n clientWidth: number\n scrolling: boolean\n}\n\nexport const ScrollAreaContext = createContext<ScrollAreaContextValue | null>(null)\n\nexport function useScrollArea() {\n const ctx = useContext(ScrollAreaContext)\n if (!ctx) throw new Error('ScrollArea compound components must be used within ScrollArea.Root')\n return ctx\n}\n","import {useState, useCallback, useRef, useEffect} from 'react'\nimport type {ScrollAreaContextValue} from './ScrollAreaContext'\n\nexport function useScrollAreaRoot(): ScrollAreaContextValue {\n const viewportRef = useRef<HTMLDivElement | null>(null)\n const contentRef = useRef<HTMLDivElement | null>(null)\n const [scrollTop, setScrollTop] = useState(0)\n const [scrollLeft, setScrollLeft] = useState(0)\n const [scrollHeight, setScrollHeight] = useState(0)\n const [scrollWidth, setScrollWidth] = useState(0)\n const [clientHeight, setClientHeight] = useState(0)\n const [clientWidth, setClientWidth] = useState(0)\n const [scrolling, setScrolling] = useState(false)\n const scrollTimerRef = useRef<ReturnType<typeof setTimeout> | null>(null)\n\n const handleScroll = useCallback(() => {\n const vp = viewportRef.current\n if (!vp) return\n\n setScrollTop(vp.scrollTop)\n setScrollLeft(vp.scrollLeft)\n setScrollHeight(vp.scrollHeight)\n setScrollWidth(vp.scrollWidth)\n setClientHeight(vp.clientHeight)\n setClientWidth(vp.clientWidth)\n setScrolling(true)\n\n if (scrollTimerRef.current) clearTimeout(scrollTimerRef.current)\n scrollTimerRef.current = setTimeout(() => setScrolling(false), 1000)\n }, [])\n\n // Observe viewport size changes\n useEffect(() => {\n const vp = viewportRef.current\n if (!vp) return\n\n const observer = new ResizeObserver(() => {\n setScrollHeight(vp.scrollHeight)\n setScrollWidth(vp.scrollWidth)\n setClientHeight(vp.clientHeight)\n setClientWidth(vp.clientWidth)\n })\n observer.observe(vp)\n // Initial measurement\n setScrollHeight(vp.scrollHeight)\n setScrollWidth(vp.scrollWidth)\n setClientHeight(vp.clientHeight)\n setClientWidth(vp.clientWidth)\n\n return () => observer.disconnect()\n }, [])\n\n // Attach scroll listener directly to ensure we capture it\n useEffect(() => {\n const vp = viewportRef.current\n if (!vp) return\n vp.addEventListener('scroll', handleScroll, {passive: true})\n return () => vp.removeEventListener('scroll', handleScroll)\n }, [handleScroll])\n\n return {\n viewportRef,\n contentRef,\n scrollTop,\n scrollLeft,\n scrollHeight,\n scrollWidth,\n clientHeight,\n clientWidth,\n scrolling,\n }\n}\n","import {type ReactNode, useRef, useCallback} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\nimport {ScrollAreaContext, useScrollArea} from './ScrollAreaContext'\nimport {useScrollAreaRoot} from './useScrollAreaRoot'\n\n// --- Root ---\n\ninterface RootProps {\n children: ReactNode\n}\n\nfunction Root({children}: RootProps) {\n const ctx = useScrollAreaRoot()\n\n return (\n <ScrollAreaContext.Provider value={ctx}>\n <html.div style={styles.root}>{children}</html.div>\n </ScrollAreaContext.Provider>\n )\n}\n\n// --- Viewport ---\n\ninterface ViewportProps {\n children: ReactNode\n maxHeight?: number | string\n}\n\nfunction Viewport({children, maxHeight}: ViewportProps) {\n const {viewportRef} = useScrollArea()\n\n return (\n <html.div\n ref={viewportRef}\n style={[styles.viewport, maxHeight != null && styles.viewportMaxHeight(maxHeight)]}\n >\n {children}\n </html.div>\n )\n}\n\n// --- Content ---\n\ninterface ContentProps {\n children: ReactNode\n}\n\nfunction Content({children}: ContentProps) {\n const {contentRef} = useScrollArea()\n return (\n <html.div ref={contentRef} style={styles.content}>\n {children}\n </html.div>\n )\n}\n\n// --- Scrollbar ---\n\ntype ScrollbarOrientation = 'vertical' | 'horizontal'\n\ninterface ScrollbarProps {\n orientation?: ScrollbarOrientation\n children: ReactNode\n}\n\nfunction Scrollbar({orientation = 'vertical', children}: ScrollbarProps) {\n const {scrolling, scrollHeight, scrollWidth, clientHeight, clientWidth} = useScrollArea()\n\n // Hide scrollbar when content fits\n const hasOverflow =\n orientation === 'vertical' ? scrollHeight > clientHeight : scrollWidth > clientWidth\n\n if (!hasOverflow) return null\n\n return (\n <html.div\n style={[\n styles.scrollbar,\n orientation === 'vertical' ? styles.scrollbarVertical : styles.scrollbarHorizontal,\n scrolling ? styles.scrollbarVisible : styles.scrollbarHidden,\n ]}\n >\n {children}\n </html.div>\n )\n}\n\n// --- Thumb ---\n\ninterface ThumbProps {\n orientation?: ScrollbarOrientation\n}\n\nfunction Thumb({orientation = 'vertical'}: ThumbProps) {\n const {viewportRef, scrollTop, scrollLeft, scrollHeight, scrollWidth, clientHeight, clientWidth} =\n useScrollArea()\n const draggingRef = useRef(false)\n const startPosRef = useRef(0)\n const startScrollRef = useRef(0)\n\n const isVertical = orientation === 'vertical'\n\n const thumbSizePercent = isVertical\n ? Math.max((clientHeight / scrollHeight) * 100, 10)\n : Math.max((clientWidth / scrollWidth) * 100, 10)\n\n const maxScroll = isVertical ? scrollHeight - clientHeight : scrollWidth - clientWidth\n const trackSize = isVertical ? clientHeight : clientWidth\n const thumbPixelSize = (thumbSizePercent / 100) * trackSize\n const scrollOffset = isVertical ? scrollTop : scrollLeft\n const thumbOffset = maxScroll > 0 ? (scrollOffset / maxScroll) * (trackSize - thumbPixelSize) : 0\n\n const thumbStyle = isVertical\n ? styles.thumbVertical(`${thumbSizePercent}%`, `translateY(${thumbOffset}px)`)\n : styles.thumbHorizontal(`${thumbSizePercent}%`, `translateX(${thumbOffset}px)`)\n\n const handlePointerDown = useCallback(\n (e: React.PointerEvent) => {\n e.preventDefault()\n draggingRef.current = true\n startPosRef.current = isVertical ? e.clientY : e.clientX\n startScrollRef.current = isVertical\n ? (viewportRef.current?.scrollTop ?? 0)\n : (viewportRef.current?.scrollLeft ?? 0)\n ;(e.target as HTMLElement).setPointerCapture(e.pointerId)\n },\n [isVertical, viewportRef],\n )\n\n const handlePointerMove = useCallback(\n (e: React.PointerEvent) => {\n if (!draggingRef.current) return\n const vp = viewportRef.current\n if (!vp) return\n\n const delta = (isVertical ? e.clientY : e.clientX) - startPosRef.current\n const scrollRatio = maxScroll / (trackSize - thumbPixelSize)\n const scrollDelta = delta * scrollRatio\n\n if (isVertical) {\n vp.scrollTop = startScrollRef.current + scrollDelta\n } else {\n vp.scrollLeft = startScrollRef.current + scrollDelta\n }\n },\n [isVertical, maxScroll, trackSize, thumbPixelSize, viewportRef],\n )\n\n const handlePointerUp = useCallback(() => {\n draggingRef.current = false\n }, [])\n\n return (\n <html.div\n onPointerDown={handlePointerDown}\n onPointerMove={handlePointerMove}\n onPointerUp={handlePointerUp}\n style={[styles.thumb, thumbStyle]}\n />\n )\n}\n\nexport const ScrollArea = {\n Root,\n Viewport,\n Content,\n Scrollbar,\n Thumb,\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\nimport {shadows} from '@duro-app/tokens/tokens/shadows.css'\n\nexport const styles = css.create({\n root: {\n position: 'relative',\n display: 'inline-flex',\n },\n trigger: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'space-between',\n gap: spacing.sm,\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n color: colors.text,\n backgroundColor: colors.bgCard,\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: {\n default: colors.border,\n ':hover': colors.accent,\n },\n borderRadius: radii.sm,\n cursor: 'pointer',\n transitionProperty: 'border-color',\n transitionDuration: '150ms',\n },\n value: {\n color: colors.text,\n },\n placeholder: {\n color: colors.textMuted,\n },\n icon: {\n display: 'flex',\n alignItems: 'center',\n color: colors.textMuted,\n },\n backdrop: {\n position: 'fixed',\n top: 0,\n left: 0,\n right: 0,\n bottom: 0,\n zIndex: 49,\n },\n popup: {\n position: 'absolute',\n top: '100%',\n left: 0,\n marginTop: spacing.xs,\n backgroundColor: colors.bgCard,\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: colors.border,\n borderRadius: radii.sm,\n boxShadow: shadows.md,\n paddingTop: spacing.xs,\n paddingBottom: spacing.xs,\n minWidth: 120,\n zIndex: 50,\n },\n item: {\n display: 'flex',\n alignItems: 'center',\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontSize: typography.fontSizeSm,\n fontFamily: typography.fontFamily,\n color: colors.text,\n borderRadius: radii.sm,\n cursor: 'pointer',\n backgroundColor: 'transparent',\n transitionProperty: 'background-color',\n transitionDuration: '150ms',\n },\n itemSelected: {\n color: colors.accent,\n fontWeight: typography.fontWeightMedium,\n },\n itemHighlighted: {\n backgroundColor: colors.bgCardHover,\n },\n hidden: {\n display: 'none',\n },\n})\n","import {createContext, useContext} from 'react'\n\nexport interface SelectContextValue {\n open: boolean\n toggle: () => void\n close: () => void\n value: string | null\n setValue: (value: string) => void\n labels: Record<string, string>\n registerLabel: (value: string, label: string) => void\n listboxId: string\n highlightedId: string | null\n setHighlightedId: (id: string | null) => void\n registerItem: (id: string, value: string, element: HTMLElement) => () => void\n triggerRef: React.RefObject<HTMLButtonElement | null>\n}\n\nexport const SelectContext = createContext<SelectContextValue | null>(null)\n\nexport function useSelect() {\n const ctx = useContext(SelectContext)\n if (!ctx) throw new Error('Select compound components must be used within Select.Root')\n return ctx\n}\n","import {useState, useCallback} from 'react'\n\nexport function useControllableValue<T>(\n controlledValue: T | undefined,\n defaultValue: T,\n onChange?: (value: T) => void,\n) {\n const [internal, setInternal] = useState(defaultValue)\n const value = controlledValue !== undefined ? controlledValue : internal\n const setValue = useCallback(\n (v: T) => {\n if (controlledValue === undefined) setInternal(v)\n onChange?.(v)\n },\n [controlledValue, onChange],\n )\n return [value, setValue] as const\n}\n","import {useState, useCallback, useMemo, useRef, useId, useEffect} from 'react'\nimport {useControllableValue} from '../../hooks/useControllableValue'\nimport type {SelectContextValue} from './SelectContext'\n\ninterface UseSelectRootOptions {\n defaultValue?: string\n value?: string\n onValueChange?: (value: string | null) => void\n}\n\nexport function useSelectRoot({\n defaultValue,\n value: controlledValue,\n onValueChange,\n}: UseSelectRootOptions) {\n const [value, setValue] = useControllableValue<string | null>(\n controlledValue,\n defaultValue ?? null,\n onValueChange,\n )\n const [open, setOpen] = useState(false)\n const [labels, setLabels] = useState<Record<string, string>>({})\n const [highlightedId, setHighlightedId] = useState<string | null>(null)\n const listboxId = useId()\n const rootRef = useRef<HTMLDivElement>(null)\n const triggerRef = useRef<HTMLButtonElement | null>(null)\n const itemsRef = useRef(new Map<string, {value: string; element: HTMLElement}>())\n const orderRef = useRef<string[]>([])\n\n const close = useCallback(() => {\n setOpen(false)\n setHighlightedId(null)\n triggerRef.current?.focus()\n }, [])\n\n const toggle = useCallback(() => {\n setOpen((prev) => {\n if (!prev) {\n const items = itemsRef.current\n const order = orderRef.current\n let found: string | null = null\n for (const id of order) {\n const item = items.get(id)\n if (item && item.value === value) {\n found = id\n break\n }\n }\n setHighlightedId(found ?? (order.length > 0 ? order[0] : null))\n } else {\n setHighlightedId(null)\n }\n return !prev\n })\n }, [value])\n\n const registerLabel = useCallback((v: string, label: string) => {\n setLabels((prev) => {\n if (prev[v] === label) return prev\n return {...prev, [v]: label}\n })\n }, [])\n\n const registerItem = useCallback((id: string, itemValue: string, element: HTMLElement) => {\n itemsRef.current.set(id, {value: itemValue, element})\n const map = itemsRef.current\n const ids = [...map.keys()]\n ids.sort((a, b) => {\n const elA = map.get(a)?.element\n const elB = map.get(b)?.element\n if (!elA || !elB) return 0\n return elA.compareDocumentPosition(elB) & Node.DOCUMENT_POSITION_FOLLOWING ? -1 : 1\n })\n orderRef.current = ids\n return () => {\n itemsRef.current.delete(id)\n orderRef.current = orderRef.current.filter((i) => i !== id)\n }\n }, [])\n\n // Native keydown for full KeyboardEvent access (preventDefault)\n useEffect(() => {\n const root = rootRef.current\n if (!root || !open) return\n\n function handleKeyDown(e: KeyboardEvent) {\n const order = orderRef.current\n const items = itemsRef.current\n if (order.length === 0) return\n\n switch (e.key) {\n case 'ArrowDown': {\n e.preventDefault()\n setHighlightedId((prev) => {\n const idx = prev ? order.indexOf(prev) : -1\n return order[(idx + 1) % order.length]\n })\n break\n }\n case 'ArrowUp': {\n e.preventDefault()\n setHighlightedId((prev) => {\n const idx = prev ? order.indexOf(prev) : 0\n return order[(idx - 1 + order.length) % order.length]\n })\n break\n }\n case 'Home': {\n e.preventDefault()\n setHighlightedId(order[0])\n break\n }\n case 'End': {\n e.preventDefault()\n setHighlightedId(order[order.length - 1])\n break\n }\n case 'Enter':\n case ' ': {\n e.preventDefault()\n setHighlightedId((prev) => {\n if (prev) {\n const item = items.get(prev)\n if (item) {\n setValue(item.value)\n close()\n }\n }\n return prev\n })\n break\n }\n case 'Escape':\n case 'Tab': {\n close()\n break\n }\n }\n }\n\n root.addEventListener('keydown', handleKeyDown)\n return () => root.removeEventListener('keydown', handleKeyDown)\n }, [open, close, setValue])\n\n const ctx: SelectContextValue = useMemo(\n () => ({\n open,\n toggle,\n close,\n value,\n setValue,\n labels,\n registerLabel,\n listboxId,\n highlightedId,\n setHighlightedId,\n registerItem,\n triggerRef,\n }),\n [\n open,\n toggle,\n close,\n value,\n setValue,\n labels,\n registerLabel,\n listboxId,\n highlightedId,\n setHighlightedId,\n registerItem,\n ],\n )\n\n return {ctx, rootRef}\n}\n","import {type ReactNode, useRef, useId, useEffect} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\nimport {SelectContext, useSelect} from './SelectContext'\nimport {useSelectRoot} from './useSelectRoot'\n\n// --- Root ---\ninterface RootProps {\n name?: string\n defaultValue?: string\n value?: string\n onValueChange?: (value: string | null) => void\n children: ReactNode\n}\n\nfunction Root({name, defaultValue, value, onValueChange, children}: RootProps) {\n const {ctx, rootRef} = useSelectRoot({defaultValue, value, onValueChange})\n\n return (\n <SelectContext.Provider value={ctx}>\n <html.div ref={rootRef} style={styles.root}>\n {name && <html.input type=\"hidden\" name={name} value={ctx.value ?? ''} />}\n {children}\n </html.div>\n </SelectContext.Provider>\n )\n}\n\n// --- Trigger ---\nfunction Trigger({children}: {children: ReactNode}) {\n const {open, toggle, listboxId, highlightedId, triggerRef} = useSelect()\n const localRef = useRef<HTMLButtonElement>(null)\n\n // Sync local ref to context triggerRef\n useEffect(() => {\n triggerRef.current = localRef.current\n })\n\n return (\n <html.button\n ref={localRef}\n type=\"button\"\n role={'combobox' as 'listbox'}\n onClick={toggle}\n aria-expanded={open}\n aria-haspopup=\"listbox\"\n aria-controls={open ? listboxId : undefined}\n aria-activedescendant={highlightedId ?? undefined}\n style={styles.trigger}\n >\n {children}\n </html.button>\n )\n}\n\n// --- Value ---\nfunction Value({placeholder}: {placeholder?: string}) {\n const {value, labels} = useSelect()\n const display = value ? (labels[value] ?? value) : null\n\n return (\n <html.span style={display ? styles.value : styles.placeholder}>\n {display ?? placeholder}\n </html.span>\n )\n}\n\n// --- Icon ---\nfunction Icon({children}: {children?: ReactNode}) {\n return (\n <html.span style={styles.icon}>\n {children ?? (\n <svg\n width=\"12\"\n height=\"12\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n aria-hidden=\"true\"\n >\n <path d=\"M6 9l6 6 6-6\" />\n </svg>\n )}\n </html.span>\n )\n}\n\n// --- Popup ---\nfunction Popup({children}: {children: ReactNode}) {\n const {open, close, listboxId} = useSelect()\n\n return (\n <>\n {open && <html.div style={styles.backdrop} onClick={close} />}\n <html.div\n id={listboxId}\n role=\"listbox\"\n aria-hidden={!open}\n style={[styles.popup, !open && styles.hidden]}\n >\n {children}\n </html.div>\n </>\n )\n}\n\n// --- Item ---\ninterface ItemProps {\n value: string\n children: ReactNode\n}\n\nfunction Item({value: itemValue, children}: ItemProps) {\n const {\n value: selectedValue,\n setValue,\n close,\n registerLabel,\n highlightedId,\n setHighlightedId,\n registerItem,\n } = useSelect()\n const id = useId()\n const ref = useRef<HTMLDivElement>(null)\n const isSelected = selectedValue === itemValue\n const isHighlighted = highlightedId === id\n\n // Register label from DOM text content (works with both string and JSX children)\n useEffect(() => {\n const el = ref.current\n if (!el) return\n const text = el.textContent\n if (text) registerLabel(itemValue, text)\n }, [itemValue, registerLabel])\n\n useEffect(() => {\n const el = ref.current\n if (!el) return\n return registerItem(id, itemValue, el)\n }, [id, itemValue, registerItem])\n\n const handleClick = () => {\n setValue(itemValue)\n close()\n }\n\n return (\n <html.div\n ref={ref}\n id={id}\n role=\"option\"\n aria-selected={isSelected}\n onClick={handleClick}\n onPointerEnter={() => setHighlightedId(id)}\n style={[\n styles.item,\n isSelected && styles.itemSelected,\n isHighlighted && styles.itemHighlighted,\n ]}\n >\n {children}\n </html.div>\n )\n}\n\n// --- ItemText ---\nfunction ItemText({children}: {children: ReactNode}) {\n return <html.span>{children}</html.span>\n}\n\nexport const Select = {\n Root,\n Trigger,\n Value,\n Icon,\n Popup,\n Item,\n ItemText,\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n root: {\n display: 'flex',\n flexDirection: 'column',\n gap: 0,\n },\n group: {\n display: 'flex',\n flexDirection: 'column',\n },\n groupTrigger: {\n display: 'flex',\n alignItems: 'center',\n gap: spacing.xs,\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeXs,\n fontWeight: typography.fontWeightSemibold,\n textTransform: 'uppercase' as const,\n letterSpacing: '0.05em',\n color: {\n default: colors.textMuted,\n ':hover': colors.text,\n },\n backgroundColor: 'transparent',\n borderWidth: 0,\n cursor: 'pointer',\n transitionProperty: 'color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n },\n groupTriggerActive: {\n color: colors.text,\n },\n chevron: {\n display: 'inline-flex',\n alignItems: 'center',\n transitionProperty: 'transform',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n },\n chevronOpen: {\n transform: 'rotate(90deg)',\n },\n item: {\n display: 'flex',\n alignItems: 'center',\n paddingTop: '6px',\n paddingBottom: '6px',\n paddingLeft: spacing.lg,\n paddingRight: spacing.md,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n fontWeight: typography.fontWeightNormal,\n color: {\n default: colors.textMuted,\n ':hover': colors.text,\n },\n backgroundColor: {\n default: 'transparent',\n ':hover': colors.bgCardHover,\n },\n borderWidth: 0,\n borderRadius: radii.sm,\n cursor: 'pointer',\n transitionProperty: 'color, background-color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n textAlign: 'left' as const,\n outlineWidth: {\n default: 0,\n ':focus-visible': 2,\n },\n outlineStyle: {\n default: 'none',\n ':focus-visible': 'solid',\n },\n outlineColor: {\n default: 'transparent',\n ':focus-visible': colors.accent,\n },\n },\n itemActive: {\n color: colors.accent,\n fontWeight: typography.fontWeightMedium,\n },\n})\n","import {createContext, useContext} from 'react'\n\nexport interface SideNavContextValue {\n activeValue: string | null\n onSelect: (value: string) => void\n expandedGroups: Set<string>\n toggleGroup: (group: string) => void\n registerItem: (value: string) => () => void\n orderRef: React.RefObject<string[]>\n}\n\nexport const SideNavContext = createContext<SideNavContextValue | null>(null)\n\nexport function useSideNav() {\n const ctx = useContext(SideNavContext)\n if (!ctx) throw new Error('SideNav compound components must be used within SideNav.Root')\n return ctx\n}\n","import {type ReactNode, useState, useCallback, useRef, useEffect} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\nimport {useControllableValue} from '../../hooks/useControllableValue'\nimport {SideNavContext, useSideNav} from './SideNavContext'\n\n// --- Root ---\n\ninterface RootProps {\n children: ReactNode\n value?: string\n defaultValue?: string\n onValueChange?: (value: string) => void\n}\n\nfunction Root({children, value: controlledValue, defaultValue, onValueChange}: RootProps) {\n const [activeValue, onSelect] = useControllableValue<string | null>(\n controlledValue,\n defaultValue ?? null,\n onValueChange\n ? (v) => {\n if (v !== null) onValueChange(v)\n }\n : undefined,\n )\n const [expandedGroups, setExpandedGroups] = useState<Set<string>>(new Set())\n const orderRef = useRef<string[]>([])\n\n const toggleGroup = useCallback((group: string) => {\n setExpandedGroups((prev) => {\n const next = new Set(prev)\n if (next.has(group)) {\n next.delete(group)\n } else {\n next.add(group)\n }\n return next\n })\n }, [])\n\n const registerItem = useCallback((value: string) => {\n if (!orderRef.current.includes(value)) {\n orderRef.current.push(value)\n }\n return () => {\n orderRef.current = orderRef.current.filter((v) => v !== value)\n }\n }, [])\n\n // Auto-expand group containing active value\n useEffect(() => {\n if (activeValue) {\n setExpandedGroups((prev) => {\n // We don't know which group it belongs to here — Group handles this\n return prev\n })\n }\n }, [activeValue])\n\n return (\n <SideNavContext.Provider\n value={{activeValue, onSelect, expandedGroups, toggleGroup, registerItem, orderRef}}\n >\n <html.nav role=\"navigation\" style={styles.root}>\n {children}\n </html.nav>\n </SideNavContext.Provider>\n )\n}\n\n// --- Group ---\n\ninterface GroupProps {\n children: ReactNode\n label: string\n groupKey?: string\n defaultExpanded?: boolean\n}\n\nfunction Group({children, label, groupKey, defaultExpanded}: GroupProps) {\n const key = groupKey ?? label\n const {expandedGroups, toggleGroup, activeValue} = useSideNav()\n const isExpanded = expandedGroups.has(key)\n const groupRef = useRef<HTMLDivElement>(null)\n\n // Auto-expand if this group contains the active item\n useEffect(() => {\n if (!activeValue || expandedGroups.has(key)) return\n const el = groupRef.current\n if (!el) return\n const activeBtn = el.querySelector(`[data-nav-value=\"${activeValue}\"]`)\n if (activeBtn) {\n toggleGroup(key)\n }\n }, [activeValue, key, expandedGroups, toggleGroup])\n\n // Expand on first render if defaultExpanded\n useEffect(() => {\n if (defaultExpanded && !expandedGroups.has(key)) {\n toggleGroup(key)\n }\n // Only run on mount\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [])\n\n const hasActiveChild = (() => {\n if (!activeValue || !groupRef.current) return false\n return !!groupRef.current.querySelector(`[data-nav-value=\"${activeValue}\"]`)\n })()\n\n return (\n <html.div ref={groupRef} style={styles.group}>\n <html.button\n type=\"button\"\n onClick={() => toggleGroup(key)}\n style={[styles.groupTrigger, hasActiveChild && styles.groupTriggerActive]}\n aria-expanded={isExpanded}\n >\n <html.span style={[styles.chevron, isExpanded && styles.chevronOpen]}>\n <svg\n width={10}\n height={10}\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth={2.5}\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n >\n <path d=\"M9 18l6-6-6-6\" />\n </svg>\n </html.span>\n {label}\n </html.button>\n {isExpanded && children}\n </html.div>\n )\n}\n\n// --- Item ---\n\ninterface ItemProps {\n value: string\n children: ReactNode\n}\n\nfunction Item({value, children}: ItemProps) {\n const {activeValue, onSelect, registerItem} = useSideNav()\n const isActive = activeValue === value\n\n useEffect(() => {\n return registerItem(value)\n }, [value, registerItem])\n\n return (\n <html.button\n type=\"button\"\n data-nav-value={value}\n onClick={() => onSelect(value)}\n style={[styles.item, isActive && styles.itemActive]}\n aria-current={isActive ? 'page' : undefined}\n >\n {children}\n </html.button>\n )\n}\n\nexport const SideNav = {\n Root,\n Group,\n Item,\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\n\nconst spin = css.keyframes({\n '0%': {transform: 'rotate(0deg)'},\n '100%': {transform: 'rotate(360deg)'},\n})\n\nexport const styles = css.create({\n root: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n },\n spinner: {\n borderRadius: '50%',\n borderStyle: 'solid',\n borderColor: colors.border,\n borderTopColor: colors.accent,\n animationName: spin,\n animationDuration: '0.6s',\n animationTimingFunction: 'linear',\n animationIterationCount: 'infinite',\n },\n sm: {\n width: 16,\n height: 16,\n borderWidth: 2,\n },\n md: {\n width: 24,\n height: 24,\n borderWidth: 2,\n },\n lg: {\n width: 40,\n height: 40,\n borderWidth: 3,\n },\n srOnly: {\n position: 'absolute',\n width: 1,\n height: 1,\n overflow: 'hidden',\n clip: 'rect(0, 0, 0, 0)',\n },\n})\n","import {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\nexport type SpinnerSize = 'sm' | 'md' | 'lg'\n\ninterface SpinnerProps {\n size?: SpinnerSize\n label?: string\n}\n\nconst sizeMap = {\n sm: styles.sm,\n md: styles.md,\n lg: styles.lg,\n} as const\n\nexport function Spinner({size = 'md', label = 'Loading'}: SpinnerProps) {\n return (\n <html.div role=\"status\" style={styles.root}>\n <html.div style={[styles.spinner, sizeMap[size]]} aria-hidden />\n <html.span style={styles.srOnly}>{label}</html.span>\n </html.div>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing} from '@duro-app/tokens/tokens/spacing.css'\n\nexport const styles = css.create({\n root: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n marginBottom: spacing.md,\n },\n error: {\n color: colors.error,\n },\n success: {\n color: colors.success,\n },\n warning: {\n color: colors.warning,\n },\n muted: {\n color: colors.textMuted,\n },\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\nexport type StatusIconName = 'x-circle' | 'check-circle' | 'check-done' | 'clock' | 'forbidden'\nexport type StatusIconVariant = 'error' | 'success' | 'warning' | 'muted'\n\nconst icons: Record<StatusIconName, ReactNode> = {\n 'x-circle': (\n <>\n <circle cx=\"12\" cy=\"12\" r=\"10\" />\n <line x1=\"15\" y1=\"9\" x2=\"9\" y2=\"15\" />\n <line x1=\"9\" y1=\"9\" x2=\"15\" y2=\"15\" />\n </>\n ),\n 'check-circle': (\n <>\n <circle cx=\"12\" cy=\"12\" r=\"10\" />\n <polyline points=\"16 10 11 15 8 12\" />\n </>\n ),\n 'check-done': (\n <>\n <path d=\"M22 11.08V12a10 10 0 1 1-5.93-9.14\" />\n <polyline points=\"22 4 12 14.01 9 11.01\" />\n </>\n ),\n clock: (\n <>\n <circle cx=\"12\" cy=\"12\" r=\"10\" />\n <polyline points=\"12 6 12 12 16 14\" />\n </>\n ),\n forbidden: (\n <>\n <circle cx=\"12\" cy=\"12\" r=\"10\" />\n <line x1=\"4.93\" y1=\"4.93\" x2=\"19.07\" y2=\"19.07\" />\n </>\n ),\n}\n\ninterface StatusIconProps {\n name: StatusIconName\n size?: number\n variant?: StatusIconVariant\n}\n\nexport function StatusIcon({name, size = 48, variant = 'muted'}: StatusIconProps) {\n return (\n <html.div style={[styles.root, styles[variant]]}>\n <svg\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth={2}\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n width={size}\n height={size}\n >\n {icons[name]}\n </svg>\n </html.div>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n // Root\n root: {\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: colors.border,\n borderRadius: radii.md,\n overflow: 'hidden',\n backgroundColor: colors.bgCard,\n fontFamily: typography.fontFamily,\n color: colors.text,\n },\n\n // Header group\n header: {\n backgroundColor: colors.bgCard,\n },\n\n // Row\n row: {\n display: 'grid',\n borderBottomWidth: 1,\n borderBottomStyle: 'solid',\n borderBottomColor: colors.border,\n },\n rowLastChild: {\n borderBottomWidth: 0,\n },\n bodyRow: {\n backgroundColor: {\n default: 'transparent',\n ':hover': colors.bgCardHover,\n },\n transitionProperty: 'background-color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n },\n\n // Header cell\n headerCell: {\n fontWeight: typography.fontWeightSemibold,\n color: colors.textMuted,\n textAlign: 'start',\n },\n\n // Body cell\n cell: {\n color: colors.text,\n display: 'flex',\n alignItems: 'center',\n },\n\n // Size: sm\n cellSm: {\n paddingTop: spacing.xs,\n paddingBottom: spacing.xs,\n paddingLeft: spacing.sm,\n paddingRight: spacing.sm,\n fontSize: typography.fontSizeXs,\n },\n // Size: md\n cellMd: {\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontSize: typography.fontSizeSm,\n },\n\n // Variant: striped (even body rows)\n stripedEven: {\n backgroundColor: {\n default: colors.bgCardHover,\n ':hover': colors.bgCardHover,\n },\n },\n\n // Variant: bordered (cells get side borders)\n borderedCell: {\n borderRightWidth: 1,\n borderRightStyle: 'solid',\n borderRightColor: colors.border,\n },\n borderedCellLast: {\n borderRightWidth: 0,\n },\n\n // Dynamic styles — simple identifier params only (StyleX constraint)\n gridColumns: (columns: number) => ({\n gridTemplateColumns: `repeat(${columns}, 1fr)`,\n }),\n})\n","import {type ReactNode, createContext, useContext, Children} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\n// --- Types ---\n\nexport type TableVariant = 'default' | 'striped' | 'bordered'\nexport type TableSize = 'sm' | 'md'\n\n// --- Context ---\n\ninterface TableContextValue {\n variant: TableVariant\n size: TableSize\n columns: number\n isHeader: boolean\n}\n\nconst TableContext = createContext<TableContextValue | null>(null)\n\nfunction useTable() {\n const ctx = useContext(TableContext)\n if (!ctx) throw new Error('Table compound components must be used within Table.Root')\n return ctx\n}\n\n// --- HeaderContext (to distinguish header vs body rowgroup) ---\n\nconst HeaderContext = createContext(false)\n\n// --- Root ---\n\ninterface RootProps {\n children: ReactNode\n variant?: TableVariant\n size?: TableSize\n columns: number\n}\n\nfunction Root({children, variant = 'default', size = 'md', columns}: RootProps) {\n return (\n <TableContext.Provider value={{variant, size, columns, isHeader: false}}>\n <html.div role=\"table\" style={styles.root}>\n {children}\n </html.div>\n </TableContext.Provider>\n )\n}\n\n// --- Header ---\n\nfunction Header({children}: {children: ReactNode}) {\n return (\n <HeaderContext.Provider value={true}>\n <html.div role=\"rowgroup\" style={styles.header}>\n {children}\n </html.div>\n </HeaderContext.Provider>\n )\n}\n\n// --- Body ---\n\nfunction Body({children}: {children: ReactNode}) {\n const {variant} = useTable()\n const childArray = Children.toArray(children)\n\n return (\n <HeaderContext.Provider value={false}>\n <html.div role=\"rowgroup\">\n {childArray.map((child, index) => {\n if (variant === 'striped') {\n return (\n <RowIndexContext.Provider key={index} value={index}>\n {child}\n </RowIndexContext.Provider>\n )\n }\n return child\n })}\n </html.div>\n </HeaderContext.Provider>\n )\n}\n\n// Row index context for striped variant\nconst RowIndexContext = createContext<number>(-1)\n\n// --- Row ---\n\nfunction Row({children}: {children: ReactNode}) {\n const {variant, columns} = useTable()\n const isHeader = useContext(HeaderContext)\n const rowIndex = useContext(RowIndexContext)\n const isEvenRow = rowIndex >= 0 && rowIndex % 2 === 1\n const childArray = Children.toArray(children)\n const isLastRow = false // handled by CSS or parent\n\n return (\n <html.div\n role=\"row\"\n style={[\n styles.row,\n styles.gridColumns(columns),\n !isHeader && styles.bodyRow,\n !isHeader && variant === 'striped' && isEvenRow && styles.stripedEven,\n ]}\n >\n {variant === 'bordered'\n ? childArray.map((child, index) => (\n <CellIndexContext.Provider key={index} value={{index, total: childArray.length}}>\n {child}\n </CellIndexContext.Provider>\n ))\n : children}\n </html.div>\n )\n}\n\n// Cell index context for bordered variant\nconst CellIndexContext = createContext<{index: number; total: number}>({\n index: 0,\n total: 0,\n})\n\n// --- HeaderCell ---\n\nfunction HeaderCell({children}: {children: ReactNode}) {\n const {size, variant} = useTable()\n const {index, total} = useContext(CellIndexContext)\n const isLast = variant === 'bordered' && index === total - 1\n\n return (\n <html.div\n role=\"columnheader\"\n style={[\n styles.headerCell,\n size === 'sm' ? styles.cellSm : styles.cellMd,\n variant === 'bordered' && styles.borderedCell,\n isLast && styles.borderedCellLast,\n ]}\n >\n {children}\n </html.div>\n )\n}\n\n// --- Cell ---\n\nfunction Cell({children}: {children: ReactNode}) {\n const {size, variant} = useTable()\n const {index, total} = useContext(CellIndexContext)\n const isLast = variant === 'bordered' && index === total - 1\n\n return (\n <html.div\n role=\"cell\"\n style={[\n styles.cell,\n size === 'sm' ? styles.cellSm : styles.cellMd,\n variant === 'bordered' && styles.borderedCell,\n isLast && styles.borderedCellLast,\n ]}\n >\n {children}\n </html.div>\n )\n}\n\n// --- Export ---\n\nexport const Table = {\n Root,\n Header,\n Body,\n Row,\n HeaderCell,\n Cell,\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n root: {\n display: 'flex',\n flexDirection: 'column',\n },\n rootVertical: {\n flexDirection: 'row',\n },\n list: {\n display: 'flex',\n flexDirection: 'row',\n borderBottomWidth: 1,\n borderBottomStyle: 'solid',\n borderBottomColor: colors.border,\n gap: spacing.xs,\n },\n listVertical: {\n flexDirection: 'column',\n borderBottomWidth: 0,\n borderRightWidth: 1,\n borderRightStyle: 'solid',\n borderRightColor: colors.border,\n gap: 0,\n },\n tab: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n fontWeight: typography.fontWeightMedium,\n color: {\n default: colors.textMuted,\n ':hover': colors.text,\n },\n backgroundColor: 'transparent',\n borderWidth: 0,\n borderBottomWidth: 2,\n borderBottomStyle: 'solid',\n borderBottomColor: 'transparent',\n cursor: 'pointer',\n transitionProperty: 'color, border-color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n outlineWidth: {\n default: 0,\n ':focus-visible': 2,\n },\n outlineStyle: {\n default: 'none',\n ':focus-visible': 'solid',\n },\n outlineColor: {\n default: 'transparent',\n ':focus-visible': colors.accent,\n },\n outlineOffset: {\n default: 0,\n ':focus-visible': -2,\n },\n },\n tabVertical: {\n justifyContent: 'flex-start',\n borderBottomWidth: 0,\n borderRightWidth: 2,\n borderRightStyle: 'solid',\n borderRightColor: 'transparent',\n },\n tabActiveHorizontal: {\n color: colors.text,\n borderBottomColor: colors.accent,\n },\n tabActiveVertical: {\n color: colors.text,\n borderRightColor: colors.accent,\n },\n tabDisabled: {\n opacity: 0.5,\n cursor: 'not-allowed',\n color: colors.textMuted,\n },\n panel: {\n paddingTop: spacing.md,\n },\n panelVertical: {\n paddingTop: 0,\n paddingLeft: spacing.md,\n },\n})\n","import {createContext, useContext} from 'react'\n\nexport type Orientation = 'horizontal' | 'vertical'\n\nexport interface TabsContextValue {\n activeValue: string | null\n onSelect: (value: string) => void\n orientation: Orientation\n registerTab: (value: string, disabled: boolean) => () => void\n tabsRef: React.RefObject<Map<string, boolean>>\n orderRef: React.RefObject<string[]>\n}\n\nexport const TabsContext = createContext<TabsContextValue | null>(null)\n\nexport function useTabs() {\n const ctx = useContext(TabsContext)\n if (!ctx) throw new Error('Tabs compound components must be used within Tabs.Root')\n return ctx\n}\n","import {useCallback, useRef} from 'react'\nimport {useControllableValue} from '../../hooks/useControllableValue'\nimport type {Orientation, TabsContextValue} from './TabsContext'\n\ninterface UseTabsRootOptions {\n value?: string\n defaultValue?: string\n onValueChange?: (value: string) => void\n orientation?: Orientation\n}\n\nexport function useTabsRoot({\n value: controlledValue,\n defaultValue,\n onValueChange,\n orientation = 'horizontal',\n}: UseTabsRootOptions): TabsContextValue {\n const [activeValue, onSelect] = useControllableValue<string | null>(\n controlledValue,\n defaultValue ?? null,\n onValueChange\n ? (v) => {\n if (v !== null) onValueChange(v)\n }\n : undefined,\n )\n const tabsRef = useRef(new Map<string, boolean>())\n const orderRef = useRef<string[]>([])\n\n const registerTab = useCallback((value: string, disabled: boolean) => {\n tabsRef.current.set(value, disabled)\n if (!orderRef.current.includes(value)) {\n orderRef.current.push(value)\n }\n return () => {\n tabsRef.current.delete(value)\n orderRef.current = orderRef.current.filter((v) => v !== value)\n }\n }, [])\n\n return {activeValue, onSelect, orientation, registerTab, tabsRef, orderRef}\n}\n","import {type ReactNode, useRef, useId, useEffect} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\nimport {TabsContext, useTabs} from './TabsContext'\nimport {useTabsRoot} from './useTabsRoot'\n\n// --- Root ---\n\ninterface RootProps {\n children: ReactNode\n value?: string\n defaultValue?: string\n onValueChange?: (value: string) => void\n orientation?: 'horizontal' | 'vertical'\n}\n\nfunction Root({\n children,\n value,\n defaultValue,\n onValueChange,\n orientation = 'horizontal',\n}: RootProps) {\n const ctx = useTabsRoot({value, defaultValue, onValueChange, orientation})\n\n return (\n <TabsContext.Provider value={ctx}>\n <html.div style={[styles.root, orientation === 'vertical' && styles.rootVertical]}>\n {children}\n </html.div>\n </TabsContext.Provider>\n )\n}\n\n// --- List ---\n\ninterface ListProps {\n children: ReactNode\n}\n\nfunction List({children}: ListProps) {\n const {orientation, activeValue, onSelect, tabsRef, orderRef} = useTabs()\n const listRef = useRef<HTMLDivElement>(null)\n\n useEffect(() => {\n const el = listRef.current\n if (!el) return\n\n function handleKeyDown(this: HTMLElement, e: KeyboardEvent) {\n const order = orderRef.current\n const tabs = tabsRef.current\n if (order.length === 0) return\n const listEl = this\n\n const prevKey = orientation === 'horizontal' ? 'ArrowLeft' : 'ArrowUp'\n const nextKey = orientation === 'horizontal' ? 'ArrowRight' : 'ArrowDown'\n\n let targetValue: string | null = null\n\n switch (e.key) {\n case nextKey: {\n e.preventDefault()\n const currentIdx = activeValue ? order.indexOf(activeValue) : -1\n for (let i = 1; i <= order.length; i++) {\n const idx = (currentIdx + i) % order.length\n const val = order[idx]\n if (!tabs.get(val)) {\n targetValue = val\n break\n }\n }\n break\n }\n case prevKey: {\n e.preventDefault()\n const currentIdx = activeValue ? order.indexOf(activeValue) : 0\n for (let i = 1; i <= order.length; i++) {\n const idx = (currentIdx - i + order.length) % order.length\n const val = order[idx]\n if (!tabs.get(val)) {\n targetValue = val\n break\n }\n }\n break\n }\n case 'Home': {\n e.preventDefault()\n for (const val of order) {\n if (!tabs.get(val)) {\n targetValue = val\n break\n }\n }\n break\n }\n case 'End': {\n e.preventDefault()\n for (let i = order.length - 1; i >= 0; i--) {\n if (!tabs.get(order[i])) {\n targetValue = order[i]\n break\n }\n }\n break\n }\n }\n\n if (targetValue) {\n onSelect(targetValue)\n // Focus the newly activated tab button\n const tabEl = listEl.querySelector(\n `[data-tab-value=\"${targetValue}\"]`,\n ) as HTMLElement | null\n tabEl?.focus()\n }\n }\n\n el.addEventListener('keydown', handleKeyDown)\n return () => el.removeEventListener('keydown', handleKeyDown)\n }, [orientation, activeValue, onSelect, tabsRef, orderRef])\n\n return (\n <html.div\n ref={listRef}\n role=\"tablist\"\n aria-orientation={orientation}\n style={[styles.list, orientation === 'vertical' && styles.listVertical]}\n >\n {children}\n </html.div>\n )\n}\n\n// --- Tab ---\n\ninterface TabProps {\n value: string\n disabled?: boolean\n children: ReactNode\n}\n\nfunction Tab({value, disabled = false, children}: TabProps) {\n const {activeValue, onSelect, orientation, registerTab} = useTabs()\n const isActive = activeValue === value\n const tabId = useId()\n const panelId = `${tabId}-panel`\n\n useEffect(() => {\n return registerTab(value, disabled)\n }, [value, disabled, registerTab])\n\n const handleClick = () => {\n if (!disabled) {\n onSelect(value)\n }\n }\n\n return (\n <html.button\n type=\"button\"\n role=\"tab\"\n id={tabId}\n aria-selected={isActive}\n aria-controls={panelId}\n aria-disabled={disabled || undefined}\n data-tab-value={value}\n tabIndex={isActive ? 0 : -1}\n onClick={handleClick}\n style={[\n styles.tab,\n orientation === 'vertical' && styles.tabVertical,\n isActive &&\n (orientation === 'vertical' ? styles.tabActiveVertical : styles.tabActiveHorizontal),\n disabled && styles.tabDisabled,\n ]}\n >\n {children}\n </html.button>\n )\n}\n\n// --- Panel ---\n\ninterface PanelProps {\n value: string\n children: ReactNode\n}\n\nfunction Panel({value, children}: PanelProps) {\n const {activeValue, orientation} = useTabs()\n\n if (activeValue !== value) return null\n\n return (\n <html.div\n role=\"tabpanel\"\n style={[styles.panel, orientation === 'vertical' && styles.panelVertical]}\n >\n {children}\n </html.div>\n )\n}\n\nexport const Tabs = {\n Root,\n List,\n Tab,\n Panel,\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n base: {\n width: '100%',\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n lineHeight: typography.lineHeight,\n color: colors.text,\n backgroundColor: colors.bg,\n borderWidth: 1,\n borderStyle: 'solid',\n borderRadius: radii.sm,\n resize: 'vertical' as const,\n transitionProperty: 'border-color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n outlineWidth: {\n default: 0,\n ':focus-visible': 2,\n },\n outlineStyle: {\n default: 'none',\n ':focus-visible': 'solid',\n },\n outlineColor: {\n default: 'transparent',\n ':focus-visible': colors.accent,\n },\n outlineOffset: {\n default: 0,\n ':focus-visible': 1,\n },\n },\n default: {\n borderColor: {\n default: colors.border,\n ':hover': colors.textMuted,\n ':focus': colors.accent,\n },\n },\n error: {\n borderColor: {\n default: colors.error,\n ':focus': colors.error,\n },\n },\n})\n","import {html} from 'react-strict-dom'\nimport {useFieldContext} from '../Field/FieldContext'\nimport {styles} from './styles.css'\n\nexport type TextareaVariant = 'default' | 'error'\n\ninterface TextareaProps {\n variant?: TextareaVariant\n name?: string\n placeholder?: string\n required?: boolean\n rows?: number\n value?: string\n defaultValue?: string\n disabled?: boolean\n onChange?: (e: React.ChangeEvent<HTMLTextAreaElement>) => void\n}\n\nexport function Textarea({\n variant = 'default',\n name,\n placeholder,\n required,\n rows = 3,\n value,\n defaultValue,\n disabled,\n onChange,\n}: TextareaProps) {\n const ctx = useFieldContext()\n\n return (\n <html.textarea\n id={ctx?.controlId}\n name={name}\n placeholder={placeholder}\n required={required}\n rows={rows}\n value={value}\n defaultValue={defaultValue}\n disabled={disabled}\n aria-describedby={\n ctx ? `${ctx.descriptionId} ${ctx.invalid ? ctx.errorId : ''}`.trim() : undefined\n }\n aria-invalid={ctx?.invalid || variant === 'error' || undefined}\n onChange={onChange}\n style={[styles.base, styles[variant]]}\n />\n )\n}\n","const r = {\n bg: \"var(--bg-xqkwqtp)\",\n bgCard: \"var(--bgCard-xj2l5r)\",\n bgCardHover: \"var(--bgCardHover-xlxk7vw)\",\n text: \"var(--text-xlpbogt)\",\n textMuted: \"var(--textMuted-x651nu9)\",\n accent: \"var(--accent-xw7wp3v)\",\n accentHover: \"var(--accentHover-x18fqoz)\",\n accentContrast: \"var(--accentContrast-x3gzxyp)\",\n border: \"var(--border-x1drj1pb)\",\n error: \"var(--error-x13gdhh0)\",\n errorHover: \"var(--errorHover-x7eyu03)\",\n errorBg: \"var(--errorBg-xrl8836)\",\n errorBorder: \"var(--errorBorder-x1a6pjl)\",\n errorText: \"var(--errorText-xf51nwe)\",\n errorContrast: \"var(--errorContrast-x1lvjkah)\",\n success: \"var(--success-x197pe5n)\",\n successBg: \"var(--successBg-xzjukav)\",\n successBorder: \"var(--successBorder-x1my3ygc)\",\n successText: \"var(--successText-x46dg9e)\",\n warning: \"var(--warning-x1gq0pyw)\",\n warningBg: \"var(--warningBg-xtnxqss)\",\n warningBorder: \"var(--warningBorder-x1ev2mr5)\",\n warningText: \"var(--warningText-x1lgjghx)\",\n infoBg: \"var(--infoBg-xho8jir)\",\n infoBorder: \"var(--infoBorder-xnevk3x)\",\n infoText: \"var(--infoText-x19pseus)\",\n __varGroupHash__: \"xjvd03b\"\n}, a = {\n xs: \"var(--xs-xxfyjsd)\",\n sm: \"var(--sm-xbh8y7f)\",\n md: \"var(--md-x3pkb85)\",\n lg: \"var(--lg-x34mutn)\",\n xl: \"var(--xl-xttpygj)\",\n xxl: \"var(--xxl-xbe9eha)\",\n __varGroupHash__: \"x6uc9q\"\n}, e = {\n sm: \"var(--sm-x1bhtfs5)\",\n md: \"var(--md-xx2g89g)\",\n lg: \"var(--lg-xwd56yl)\",\n full: \"var(--full-x9vxdtd)\",\n __varGroupHash__: \"xw3ffwm\"\n}, t = {\n fontFamily: \"var(--fontFamily-xvrmnat)\",\n fontSizeXs: \"var(--fontSizeXs-x1w5m325)\",\n fontSizeSm: \"var(--fontSizeSm-x1bjjs4u)\",\n fontSizeMd: \"var(--fontSizeMd-xq8d99q)\",\n fontSizeLg: \"var(--fontSizeLg-x18ngplw)\",\n fontSizeXl: \"var(--fontSizeXl-x1b1mqsu)\",\n fontSizeHeading: \"var(--fontSizeHeading-x1stydh2)\",\n fontWeightNormal: \"var(--fontWeightNormal-x1y1cayu)\",\n fontWeightMedium: \"var(--fontWeightMedium-xaw13ft)\",\n fontWeightSemibold: \"var(--fontWeightSemibold-xg6c7xe)\",\n fontWeightBold: \"var(--fontWeightBold-x1pjkvwg)\",\n lineHeight: \"var(--lineHeight-x1gubzd5)\",\n __varGroupHash__: \"xs62swl\"\n}, x = {\n sm: \"var(--sm-x17hhtln)\",\n md: \"var(--md-x1oyt0aw)\",\n lg: \"var(--lg-x1mxd62i)\",\n __varGroupHash__: \"x13v825q\"\n}, o = {\n xjvd03b: \"x18itf25 xjvd03b\",\n $$css: !0\n}, v = {\n x13v825q: \"xv9ibj0 x13v825q\",\n $$css: !0\n}, n = {\n xjvd03b: \"x1qgt5a2 xjvd03b\",\n $$css: !0\n}, s = {\n x13v825q: \"x15e39jv x13v825q\",\n $$css: !0\n};\nexport {\n r as colors,\n s as highContrastShadows,\n n as highContrastTheme,\n v as lightShadows,\n o as lightTheme,\n e as radii,\n x as shadows,\n a as spacing,\n t as typography\n};\n//# sourceMappingURL=index.js.map\n","import type {ReactNode} from 'react'\nimport {css, html} from 'react-strict-dom'\nimport {lightTheme, lightShadows, highContrastTheme, highContrastShadows} from '@duro-app/tokens'\n\nexport type ThemeName = 'dark' | 'light' | 'high-contrast'\n\ninterface ThemeProviderProps {\n theme?: ThemeName\n children: ReactNode\n}\n\nconst themeMap: Partial<Record<ThemeName, readonly [typeof lightTheme, typeof lightShadows]>> = {\n light: [lightTheme, lightShadows],\n 'high-contrast': [highContrastTheme, highContrastShadows],\n}\n\nconst styles = css.create({\n root: {\n display: 'contents',\n },\n})\n\n// react-strict-dom's style prop rejects Theme<VarGroup<{named keys}>> because the\n// concrete VarGroup lacks the generic index signature. This is a known typing gap.\ntype DivStyle = Parameters<typeof html.div>[0]['style']\n\nexport function ThemeProvider({theme = 'dark', children}: ThemeProviderProps) {\n const overrides = themeMap[theme]\n const themeStyles = [overrides?.[0], overrides?.[1], styles.root] as DivStyle\n\n return <html.div style={themeStyles}>{children}</html.div>\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\nimport {shadows} from '@duro-app/tokens/tokens/shadows.css'\n\nexport const styles = css.create({\n root: {\n position: 'relative',\n display: 'inline-flex',\n },\n popup: {\n position: 'absolute',\n zIndex: 50,\n paddingTop: spacing.xs,\n paddingBottom: spacing.xs,\n paddingLeft: spacing.sm,\n paddingRight: spacing.sm,\n backgroundColor: colors.bgCard,\n color: colors.text,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeXs,\n lineHeight: typography.lineHeight,\n borderRadius: radii.sm,\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: colors.border,\n boxShadow: shadows.md,\n whiteSpace: 'nowrap',\n pointerEvents: 'none',\n },\n top: {\n bottom: '100%',\n left: '50%',\n transform: 'translateX(-50%)',\n marginBottom: spacing.xs,\n },\n bottom: {\n top: '100%',\n left: '50%',\n transform: 'translateX(-50%)',\n marginTop: spacing.xs,\n },\n left: {\n right: '100%',\n top: '50%',\n transform: 'translateY(-50%)',\n marginRight: spacing.xs,\n },\n right: {\n left: '100%',\n top: '50%',\n transform: 'translateY(-50%)',\n marginLeft: spacing.xs,\n },\n})\n","import {\n type ReactNode,\n createContext,\n useContext,\n useState,\n useRef,\n useCallback,\n useId,\n} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\n// --- Context ---\n\ntype Placement = 'top' | 'bottom' | 'left' | 'right'\n\ninterface TooltipContextValue {\n open: boolean\n show: () => void\n hide: () => void\n tooltipId: string\n placement: Placement\n}\n\nconst TooltipContext = createContext<TooltipContextValue | null>(null)\n\nfunction useTooltip() {\n const ctx = useContext(TooltipContext)\n if (!ctx) throw new Error('Tooltip compound components must be used within Tooltip.Root')\n return ctx\n}\n\n// --- Root ---\n\ninterface RootProps {\n children: ReactNode\n content: ReactNode\n placement?: Placement\n delay?: number\n}\n\nfunction Root({children, content, placement = 'top', delay = 300}: RootProps) {\n const [open, setOpen] = useState(false)\n const tooltipId = useId()\n const timerRef = useRef<ReturnType<typeof setTimeout> | null>(null)\n\n const show = useCallback(() => {\n if (timerRef.current) clearTimeout(timerRef.current)\n timerRef.current = setTimeout(() => setOpen(true), delay)\n }, [delay])\n\n const hide = useCallback(() => {\n if (timerRef.current) clearTimeout(timerRef.current)\n timerRef.current = null\n setOpen(false)\n }, [])\n\n return (\n <TooltipContext.Provider value={{open, show, hide, tooltipId, placement}}>\n <html.div style={styles.root}>\n {children}\n {open && (\n <html.div id={tooltipId} role=\"tooltip\" style={[styles.popup, styles[placement]]}>\n {content}\n </html.div>\n )}\n </html.div>\n </TooltipContext.Provider>\n )\n}\n\n// --- Trigger ---\n\ninterface TriggerProps {\n children: ReactNode\n}\n\nfunction Trigger({children}: TriggerProps) {\n const {open, show, hide, tooltipId} = useTooltip()\n\n return (\n <html.div\n onPointerEnter={show}\n onPointerLeave={hide}\n onFocus={show}\n onBlur={hide}\n aria-describedby={open ? tooltipId : undefined}\n >\n {children}\n </html.div>\n )\n}\n\nexport const Tooltip = {\n Root,\n Trigger,\n}\n"],"names":["styleq$1","styleq_2","cache","compiledKey","createStyleq","options","disableCache","disableMix","transform","definedProperties","className","inlineStyle","debugString","nextCache","styles","i","possibleStyle","_i","style","classNameChunk","cacheEntry","definedPropertiesChunk","prop","value","compiledKeyValue","weakMap","subStyle","_prop","_value","styleProps","styleq","optimizedStyleq","merge","dataStyleSrc","result","chunks","pathsMap","chunk","trimmed","path","line","a","button","div","input","label","nav","p","span","textarea","defaultStyles","base","kmVPX3","kaIpWk","kMzoRj","ksu8eU","kGuDYH","kLWn49","$$css","error","kWkggS","kVAM5u","kMwMTN","success","warning","info","Alert","variant","children","jsx","_rsdMerge","_rsdDefaultStyles","k1xSpc","kGNEyG","kjj79g","kMv6JI","k63SB2","khDVqt","sizeMd","kLKAdn","kGO01o","kE3dHu","kpe85a","sizeSm","default","sizeMap","sm","md","Badge","size","kOIVth","kkrTdU","k1ekBW","kIyJzY","kAMwcw","kybGjl","kMeerF","k3XXqK","kjBf7l","kInvED","sizeDefault","sizeSmall","primary","secondary","link","danger","fullWidth","kzqmXN","disabled","kSiTet","small","Button","type","onClick","elevated","kGVxlE","outlined","filled","interactive","k3aq6I","sizeCompact","sizeFull","header","k1K539","compact","full","Card","jsxs","root","rootDisabled","box","kZKoxP","kmuXW","boxUnchecked","boxChecked","kVAEAm","kVQacm","Checkbox","name","checked","controlledChecked","defaultChecked","onChange","isControlled","undefined","internalChecked","setInternalChecked","useState","isChecked","handleChange","useCallback","e","target","opacity","kXwgrk","k9WMMc","message","action","keoZOQ","EmptyState","icon","FieldContext","createContext","useFieldContext","useContext","description","Root","invalid","id","useId","ctx","useMemo","controlId","descriptionId","errorId","Label","Description","Error","Field","InputGroupContext","useInputGroupContext","inGroup","Input","placeholder","required","minLength","pattern","autoComplete","defaultValue","groupCtx","extraProps","trim","wrapper","addon","kfSwDN","addonStart","kWqL5O","kSWEuD","k26BEO","addonEnd","kZ1KPB","k4WBpm","kaZRDh","addonClickable","Addon","position","positionStyle","InputGroup","LinkButton","href","rel","trigger","backdrop","k87sOh","kbCHJM","kCIrl2","krVfgx","kY2c9j","popup","k7Eaqz","popupEnd","item","itemHighlighted","linkItem","MenuContext","useMenu","useMenuRoot","open","setOpen","highlightedId","setHighlightedId","menuId","rootRef","useRef","triggerRef","itemsRef","Map","orderRef","needsInitialHighlightRef","close","current","focus","toggle","prev","useEffect","order","length","registerItem","element","set","map","ids","keys","sort","b","elA","get","elB","compareDocumentPosition","Node","DOCUMENT_POSITION_FOLLOWING","delete","filter","handleKeyDown","key","preventDefault","idx","indexOf","items","click","addEventListener","removeEventListener","Trigger","localRef","Popup","align","Fragment","Item","ref","isHighlighted","el","handleClick","LinkItem","Menu","viewport","kXHlph","kORKVm","k5wCbM","content","kAzted","scrollbar","kFalU9","scrollbarVertical","scrollbarHorizontal","scrollbarHidden","scrollbarVisible","thumb","kUk6DE","viewportMaxHeight","maxHeight","kskxy","val","thumbVertical","height","thumbHorizontal","width","ScrollAreaContext","useScrollArea","useScrollAreaRoot","viewportRef","contentRef","scrollTop","setScrollTop","scrollLeft","setScrollLeft","scrollHeight","setScrollHeight","scrollWidth","setScrollWidth","clientHeight","setClientHeight","clientWidth","setClientWidth","scrolling","setScrolling","scrollTimerRef","handleScroll","vp","clearTimeout","setTimeout","observer","ResizeObserver","observe","disconnect","passive","Viewport","Content","Scrollbar","orientation","Thumb","draggingRef","startPosRef","startScrollRef","isVertical","thumbSizePercent","Math","max","maxScroll","trackSize","thumbPixelSize","scrollOffset","thumbOffset","thumbStyle","handlePointerDown","clientY","clientX","setPointerCapture","pointerId","handlePointerMove","delta","scrollRatio","scrollDelta","handlePointerUp","ScrollArea","itemSelected","hidden","SelectContext","useSelect","useControllableValue","controlledValue","internal","setInternal","setValue","v","useSelectRoot","onValueChange","labels","setLabels","listboxId","found","registerLabel","itemValue","Value","display","Icon","selectedValue","isSelected","text","textContent","ItemText","Select","group","groupTrigger","kP9fke","kb6lSQ","groupTriggerActive","chevron","chevronOpen","itemActive","SideNavContext","useSideNav","activeValue","onSelect","expandedGroups","setExpandedGroups","Set","toggleGroup","next","has","add","includes","push","Group","groupKey","defaultExpanded","isExpanded","groupRef","querySelector","hasActiveChild","isActive","SideNav","spinner","kLZC3w","kKVMdj","k44tkh","kyAemX","ko0y90","lg","srOnly","kMcinP","Spinner","muted","icons","clock","forbidden","StatusIcon","_temp","kumcoG","row","kt9PQ7","kfdmCh","kL6WhQ","rowLastChild","bodyRow","headerCell","cell","cellSm","cellMd","stripedEven","borderedCell","borderedCellLast","gridColumns","columns","TableContext","useTable","HeaderContext","isHeader","Header","Body","childArray","Children","toArray","child","index","RowIndexContext","Row","rowIndex","isEvenRow","CellIndexContext","total","HeaderCell","isLast","Cell","Table","rootVertical","list","listVertical","tab","tabVertical","tabActiveHorizontal","tabActiveVertical","tabDisabled","panel","panelVertical","TabsContext","useTabs","useTabsRoot","tabsRef","registerTab","List","listRef","tabs","listEl","prevKey","nextKey","targetValue","currentIdx","Tab","tabId","panelId","Panel","Tabs","kHenm0","Textarea","rows","r","bg","bgCard","bgCardHover","textMuted","accent","accentHover","accentContrast","border","errorHover","errorBg","errorBorder","errorText","errorContrast","successBg","successBorder","successText","warningBg","warningBorder","warningText","infoBg","infoBorder","infoText","__varGroupHash__","themeMap","light","lightTheme","lightShadows","highContrastTheme","highContrastShadows","ThemeProvider","theme","overrides","themeStyles","kfzvcC","top","bottom","left","km5ZXQ","right","koQZXg","TooltipContext","useTooltip","placement","delay","tooltipId","timerRef","show","hide","Tooltip"],"mappings":"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","x_google_ignoreList":[0]}
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../node_modules/.pnpm/react-strict-dom@0.0.55_postcss@8.5.6_react-dom@19.2.4_react@19.2.4__react-native@0.84._1278be21509893d955b57d0db9435779/node_modules/react-strict-dom/dist/web/runtime.js","../src/components/Alert/styles.css.ts","../src/components/Alert/Alert.tsx","../src/components/Badge/styles.css.ts","../src/components/Badge/Badge.tsx","../src/components/Button/styles.css.ts","../src/components/Button/Button.tsx","../src/components/Card/styles.css.ts","../src/components/Card/Card.tsx","../src/components/Checkbox/styles.css.ts","../src/components/Checkbox/Checkbox.tsx","../src/components/EmptyState/styles.css.ts","../src/components/EmptyState/EmptyState.tsx","../../tokens/src/tokens/type-presets.css.ts","../src/components/Heading/styles.css.ts","../src/components/Heading/Heading.tsx","../src/components/Field/FieldContext.ts","../src/components/Field/styles.css.ts","../src/components/Field/Field.tsx","../src/components/InputGroup/InputGroupContext.ts","../src/components/Input/styles.css.ts","../src/components/Input/Input.tsx","../src/components/InputGroup/styles.css.ts","../src/components/InputGroup/InputGroup.tsx","../src/components/LinkButton/styles.css.ts","../src/components/LinkButton/LinkButton.tsx","../src/components/Menu/styles.css.ts","../src/components/Menu/MenuContext.ts","../src/components/Menu/useMenuRoot.ts","../src/components/Menu/Menu.tsx","../src/components/ScrollArea/styles.css.ts","../src/components/ScrollArea/ScrollAreaContext.ts","../src/components/ScrollArea/useScrollAreaRoot.ts","../src/components/ScrollArea/ScrollArea.tsx","../src/components/Select/styles.css.ts","../src/components/Select/SelectContext.ts","../src/hooks/useControllableValue.ts","../src/components/Select/useSelectRoot.ts","../src/components/Select/Select.tsx","../src/components/SideNav/styles.css.ts","../src/components/SideNav/SideNavContext.ts","../src/components/SideNav/SideNav.tsx","../src/components/Spinner/styles.css.ts","../src/components/Spinner/Spinner.tsx","../src/components/StatusIcon/styles.css.ts","../src/components/StatusIcon/StatusIcon.tsx","../src/components/Table/styles.css.ts","../src/components/Table/Table.tsx","../src/components/Tabs/styles.css.ts","../src/components/Tabs/TabsContext.ts","../src/components/Tabs/useTabsRoot.ts","../src/components/Tabs/Tabs.tsx","../src/components/Textarea/styles.css.ts","../src/components/Textarea/Textarea.tsx","../../tokens/dist/index.js","../src/components/ThemeProvider/ThemeProvider.tsx","../src/components/Text/styles.css.ts","../src/components/Text/Text.tsx","../src/components/Tooltip/styles.css.ts","../src/components/Tooltip/Tooltip.tsx","../src/components/Stack/styles.css.ts","../src/components/Stack/Stack.tsx","../src/components/Inline/styles.css.ts","../src/components/Inline/Inline.tsx","../src/components/Cluster/styles.css.ts","../src/components/Cluster/Cluster.tsx","../src/components/Grid/styles.css.ts","../src/components/Grid/Grid.tsx","../src/hooks/useContainerQuery.ts"],"sourcesContent":["/**\n * @license react-strict-dom\n * Copyright (c) Meta Platforms, Inc. and affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\nimport * as stylex from '@stylexjs/stylex';\n\nvar styleq$1 = {};\n\nObject.defineProperty(styleq$1, \"__esModule\", {\n value: true\n});\nvar styleq_2 = styleq$1.styleq = void 0;\nvar cache = new WeakMap();\nvar compiledKey = '$$css';\nfunction createStyleq(options) {\n var disableCache;\n var disableMix;\n var transform;\n if (options != null) {\n disableCache = options.disableCache === true;\n disableMix = options.disableMix === true;\n transform = options.transform;\n }\n return function styleq() {\n var definedProperties = [];\n var className = '';\n var inlineStyle = null;\n var debugString = '';\n var nextCache = disableCache ? null : cache;\n var styles = new Array(arguments.length);\n for (var i = 0; i < arguments.length; i++) {\n styles[i] = arguments[i];\n }\n while (styles.length > 0) {\n var possibleStyle = styles.pop();\n if (possibleStyle == null || possibleStyle === false) {\n continue;\n }\n if (Array.isArray(possibleStyle)) {\n for (var _i = 0; _i < possibleStyle.length; _i++) {\n styles.push(possibleStyle[_i]);\n }\n continue;\n }\n var style = transform != null ? transform(possibleStyle) : possibleStyle;\n if (style.$$css != null) {\n var classNameChunk = '';\n if (nextCache != null && nextCache.has(style)) {\n var cacheEntry = nextCache.get(style);\n if (cacheEntry != null) {\n classNameChunk = cacheEntry[0];\n debugString = cacheEntry[2];\n definedProperties.push.apply(definedProperties, cacheEntry[1]);\n nextCache = cacheEntry[3];\n }\n } else {\n var definedPropertiesChunk = [];\n for (var prop in style) {\n var value = style[prop];\n if (prop === compiledKey) {\n var compiledKeyValue = style[prop];\n if (compiledKeyValue !== true) {\n debugString = debugString ? compiledKeyValue + '; ' + debugString : compiledKeyValue;\n }\n continue;\n }\n if (typeof value === 'string' || value === null) {\n if (!definedProperties.includes(prop)) {\n definedProperties.push(prop);\n if (nextCache != null) {\n definedPropertiesChunk.push(prop);\n }\n if (typeof value === 'string') {\n classNameChunk += classNameChunk ? ' ' + value : value;\n }\n }\n } else {\n console.error(\"styleq: \".concat(prop, \" typeof \").concat(String(value), \" is not \\\"string\\\" or \\\"null\\\".\"));\n }\n }\n if (nextCache != null) {\n var weakMap = new WeakMap();\n nextCache.set(style, [classNameChunk, definedPropertiesChunk, debugString, weakMap]);\n nextCache = weakMap;\n }\n }\n if (classNameChunk) {\n className = className ? classNameChunk + ' ' + className : classNameChunk;\n }\n } else {\n if (disableMix) {\n if (inlineStyle == null) {\n inlineStyle = {};\n }\n inlineStyle = Object.assign({}, style, inlineStyle);\n } else {\n var subStyle = null;\n for (var _prop in style) {\n var _value = style[_prop];\n if (_value !== undefined) {\n if (!definedProperties.includes(_prop)) {\n if (_value != null) {\n if (inlineStyle == null) {\n inlineStyle = {};\n }\n if (subStyle == null) {\n subStyle = {};\n }\n subStyle[_prop] = _value;\n }\n definedProperties.push(_prop);\n nextCache = null;\n }\n }\n }\n if (subStyle != null) {\n inlineStyle = Object.assign(subStyle, inlineStyle);\n }\n }\n }\n }\n var styleProps = [className, inlineStyle, debugString];\n return styleProps;\n };\n}\nvar styleq = styleq_2 = styleq$1.styleq = createStyleq();\nstyleq.factory = createStyleq;\n\nconst optimizedStyleq = styleq_2.factory({\n disableMix: true\n});\nfunction merge(...styles) {\n const [className, style, dataStyleSrc] = optimizedStyleq(styles);\n const result = {};\n if (className != null && className !== '') {\n result.className = className;\n }\n if (style != null) {\n result.style = style;\n }\n if (dataStyleSrc != null && dataStyleSrc !== '') {\n const chunks = dataStyleSrc.split(';');\n const pathsMap = {};\n for (const chunk of chunks) {\n const trimmed = chunk.trim();\n const [path, line] = trimmed.split(':');\n if (line != null) {\n pathsMap[path] = pathsMap[path] != null ? `${pathsMap[path]},${line}` : line;\n }\n }\n result['data-style-src'] = Object.keys(pathsMap).map(path => `${path}:${pathsMap[path]}`).join('; ');\n }\n return result;\n}\n\nconst styles = stylex.create({\n block: {\n margin: 0,\n padding: 0\n },\n inline: {\n margin: 0,\n padding: 0,\n textDecoration: 'none',\n textAlign: 'inherit',\n wordWrap: 'break-word'\n },\n inlineblock: {\n borderStyle: 'solid',\n margin: 0,\n padding: 0\n },\n button: {\n borderWidth: 1\n },\n codePre: {\n fontFamily: 'monospace, \"monospace\"',\n fontSize: '1em',\n overflow: 'auto'\n },\n heading: {\n fontSize: '1.5rem',\n wordWrap: 'break-word'\n },\n hr: {\n backgroundColor: 'black',\n borderStyle: 'none',\n borderWidth: 0,\n boxSizing: 'border-box',\n height: 1\n },\n img: {\n aspectRatio: 'attr(width) / attr(height)',\n height: 'auto',\n maxWidth: '100%'\n },\n input: {\n borderWidth: 1,\n borderStyle: 'solid'\n },\n list: {\n listStyle: 'none'\n },\n strong: {\n fontWeight: 'bold'\n },\n textarea: {\n borderWidth: 1,\n borderStyle: 'solid',\n resize: 'vertical'\n }\n});\nconst a = styles.inline;\nconst article = styles.block;\nconst aside = styles.block;\nconst b = styles.inline;\nconst bdi = styles.inline;\nconst bdo = styles.inline;\nconst blockquote = styles.block;\nconst br = null;\nconst button = [styles.inlineblock, styles.button];\nconst code = [styles.inline, styles.codePre];\nconst del = null;\nconst div = styles.block;\nconst em = styles.inline;\nconst fieldset = styles.block;\nconst footer = styles.block;\nconst form = styles.block;\nconst heading = [styles.block, styles.heading];\nconst header = styles.block;\nconst hr = [styles.block, styles.hr];\nconst i = styles.inline;\nconst img = styles.img;\nconst input = [styles.inlineblock, styles.input];\nconst ins = null;\nconst kbd = null;\nconst label = styles.inline;\nconst li = styles.block;\nconst main = styles.block;\nconst mark = styles.inline;\nconst nav = styles.block;\nconst ol = [styles.list, styles.block];\nconst optgroup = null;\nconst option = null;\nconst p = styles.block;\nconst pre = [styles.block, styles.codePre];\nconst s = null;\nconst section = styles.block;\nconst select = styles.inlineblock;\nconst span = styles.inline;\nconst strong = [styles.inline, styles.strong];\nconst sub = styles.inline;\nconst sup = styles.inline;\nconst textarea = [styles.inlineblock, styles.textarea];\nconst u = null;\nconst ul = [styles.list, styles.block];\nconst defaultStyles = {\n a: a,\n article: article,\n aside: aside,\n b: b,\n bdi: bdi,\n bdo: bdo,\n blockquote: blockquote,\n br: br,\n button: button,\n code: code,\n del: del,\n div: div,\n em: em,\n fieldset: fieldset,\n footer: footer,\n form: form,\n h1: heading,\n h2: heading,\n h3: heading,\n h4: heading,\n h5: heading,\n h6: heading,\n header: header,\n hr: hr,\n i: i,\n img: img,\n input: input,\n ins: ins,\n kbd: kbd,\n label: label,\n li: li,\n main: main,\n mark: mark,\n nav: nav,\n ol: ol,\n optgroup: optgroup,\n option: option,\n p: p,\n pre: pre,\n s: s,\n section: section,\n select: select,\n span: span,\n strong: strong,\n sub: sub,\n sup: sup,\n textarea: textarea,\n u: u,\n ul: ul\n};\n\nexport { defaultStyles, merge };\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n base: {\n padding: spacing.md,\n borderRadius: radii.sm,\n borderWidth: 1,\n borderStyle: 'solid',\n fontSize: typography.fontSizeSm,\n lineHeight: typography.lineHeight,\n },\n error: {\n backgroundColor: colors.errorBg,\n borderColor: colors.errorBorder,\n color: colors.errorText,\n },\n success: {\n backgroundColor: colors.successBg,\n borderColor: colors.successBorder,\n color: colors.successText,\n },\n warning: {\n backgroundColor: colors.warningBg,\n borderColor: colors.warningBorder,\n color: colors.warningText,\n },\n info: {\n backgroundColor: colors.infoBg,\n borderColor: colors.infoBorder,\n color: colors.infoText,\n },\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\nexport type AlertVariant = 'error' | 'success' | 'warning' | 'info'\n\ninterface AlertProps {\n variant?: AlertVariant\n children: ReactNode\n}\n\nexport function Alert({variant = 'info', children}: AlertProps) {\n return (\n <html.div role=\"alert\" style={[styles.base, styles[variant]]}>\n {children}\n </html.div>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n base: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n fontFamily: typography.fontFamily,\n fontWeight: typography.fontWeightMedium,\n lineHeight: 1,\n borderRadius: radii.full,\n whiteSpace: 'nowrap',\n },\n sizeMd: {\n paddingTop: spacing.xs,\n paddingBottom: spacing.xs,\n paddingLeft: spacing.sm,\n paddingRight: spacing.sm,\n fontSize: typography.fontSizeXs,\n },\n sizeSm: {\n paddingTop: 2,\n paddingBottom: 2,\n paddingLeft: spacing.xs,\n paddingRight: spacing.xs,\n fontSize: '0.625rem',\n },\n default: {\n backgroundColor: colors.bgCardHover,\n color: colors.textMuted,\n },\n success: {\n backgroundColor: colors.successBg,\n color: colors.successText,\n },\n warning: {\n backgroundColor: colors.warningBg,\n color: colors.warningText,\n },\n error: {\n backgroundColor: colors.errorBg,\n color: colors.errorText,\n },\n info: {\n backgroundColor: colors.infoBg,\n color: colors.infoText,\n },\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\nexport type BadgeVariant = 'default' | 'success' | 'warning' | 'error' | 'info'\nexport type BadgeSize = 'sm' | 'md'\n\ninterface BadgeProps {\n variant?: BadgeVariant\n size?: BadgeSize\n children: ReactNode\n}\n\nconst sizeMap = {\n sm: styles.sizeSm,\n md: styles.sizeMd,\n} as const\n\nexport function Badge({variant = 'default', size = 'md', children}: BadgeProps) {\n return <html.span style={[styles.base, sizeMap[size], styles[variant]]}>{children}</html.span>\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n base: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n gap: spacing.sm,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n fontWeight: typography.fontWeightMedium,\n lineHeight: typography.lineHeight,\n borderRadius: radii.sm,\n borderWidth: 1,\n borderStyle: 'solid',\n cursor: 'pointer',\n transitionProperty: 'background-color, border-color, color, opacity',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n textDecoration: 'none',\n outlineWidth: {\n default: 0,\n ':focus-visible': 2,\n },\n outlineStyle: {\n default: 'none',\n ':focus-visible': 'solid',\n },\n outlineColor: {\n default: 'transparent',\n ':focus-visible': colors.accent,\n },\n outlineOffset: {\n default: 0,\n ':focus-visible': 2,\n },\n },\n sizeDefault: {\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n },\n sizeSmall: {\n paddingTop: spacing.xs,\n paddingBottom: spacing.xs,\n paddingLeft: spacing.sm,\n paddingRight: spacing.sm,\n fontSize: typography.fontSizeXs,\n },\n primary: {\n backgroundColor: {\n default: colors.accent,\n ':hover': colors.accentHover,\n ':active': colors.accentHover,\n },\n borderColor: {\n default: colors.accent,\n ':hover': colors.accentHover,\n },\n color: colors.accentContrast,\n },\n secondary: {\n backgroundColor: {\n default: 'transparent',\n ':hover': colors.bgCardHover,\n },\n borderColor: colors.border,\n color: colors.textMuted,\n },\n link: {\n backgroundColor: 'transparent',\n borderColor: 'transparent',\n color: {\n default: colors.accent,\n ':hover': colors.accentHover,\n },\n textDecoration: {\n default: 'none',\n ':hover': 'underline',\n },\n paddingLeft: 0,\n paddingRight: 0,\n },\n danger: {\n backgroundColor: {\n default: colors.error,\n ':hover': colors.errorHover,\n ':active': colors.errorHover,\n },\n borderColor: {\n default: colors.error,\n ':hover': colors.errorHover,\n },\n color: colors.errorContrast,\n },\n fullWidth: {\n width: '100%',\n },\n disabled: {\n opacity: 0.5,\n cursor: 'not-allowed',\n },\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\nexport type ButtonVariant = 'primary' | 'secondary' | 'link' | 'danger'\nexport type ButtonSize = 'default' | 'small'\n\ninterface ButtonProps {\n variant?: ButtonVariant\n size?: ButtonSize\n fullWidth?: boolean\n disabled?: boolean\n type?: 'button' | 'submit'\n onClick?: () => void\n children: ReactNode\n}\n\nconst sizeMap = {\n default: styles.sizeDefault,\n small: styles.sizeSmall,\n} as const\n\nexport function Button({\n variant = 'primary',\n size = 'default',\n fullWidth = false,\n disabled = false,\n type = 'button',\n onClick,\n children,\n}: ButtonProps) {\n return (\n <html.button\n type={type}\n disabled={disabled}\n onClick={onClick}\n style={[\n styles.base,\n sizeMap[size],\n styles[variant],\n fullWidth && styles.fullWidth,\n disabled && styles.disabled,\n ]}\n >\n {children}\n </html.button>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\nimport {shadows} from '@duro-app/tokens/tokens/shadows.css'\n\nexport const styles = css.create({\n base: {\n backgroundColor: colors.bgCard,\n color: colors.text,\n fontFamily: typography.fontFamily,\n },\n // Variants\n elevated: {\n borderRadius: radii.lg,\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: colors.border,\n boxShadow: shadows.md,\n },\n outlined: {\n borderRadius: radii.md,\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: colors.border,\n },\n filled: {\n borderRadius: radii.md,\n },\n interactive: {\n borderRadius: radii.md,\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: {\n default: colors.border,\n ':hover': colors.accent,\n },\n backgroundColor: {\n default: colors.bgCard,\n ':hover': colors.bgCardHover,\n },\n cursor: 'pointer',\n transitionProperty: 'background-color, border-color, transform',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n transform: {\n default: 'translateY(0)',\n ':hover': 'translateY(-2px)',\n },\n },\n // Sizes (padding)\n sizeDefault: {\n padding: spacing.lg,\n },\n sizeCompact: {\n padding: spacing.md,\n },\n sizeFull: {\n padding: spacing.xl,\n },\n // Header\n header: {\n fontSize: typography.fontSizeLg,\n fontWeight: typography.fontWeightSemibold,\n marginBottom: spacing.md,\n },\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\nexport type CardVariant = 'elevated' | 'outlined' | 'filled' | 'interactive'\nexport type CardSize = 'default' | 'compact' | 'full'\n\ninterface CardProps {\n variant?: CardVariant\n size?: CardSize\n header?: string\n onClick?: () => void\n children: ReactNode\n}\n\nconst sizeMap = {\n default: styles.sizeDefault,\n compact: styles.sizeCompact,\n full: styles.sizeFull,\n} as const\n\nexport function Card({\n variant = 'outlined',\n size = 'default',\n header,\n onClick,\n children,\n}: CardProps) {\n return (\n <html.div onClick={onClick} style={[styles.base, styles[variant], sizeMap[size]]}>\n {header && <html.div style={styles.header}>{header}</html.div>}\n {children}\n </html.div>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n root: {\n display: 'inline-flex',\n alignItems: 'center',\n gap: spacing.sm,\n cursor: 'pointer',\n fontSize: typography.fontSizeSm,\n color: colors.text,\n lineHeight: typography.lineHeight,\n },\n rootDisabled: {\n opacity: 0.5,\n cursor: 'not-allowed',\n },\n box: {\n width: 18,\n height: 18,\n borderWidth: 1,\n borderStyle: 'solid',\n borderRadius: radii.sm,\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n flexShrink: 0,\n transitionProperty: 'background-color, border-color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n },\n boxUnchecked: {\n backgroundColor: colors.bg,\n borderColor: {\n default: colors.border,\n ':hover': colors.textMuted,\n },\n },\n boxChecked: {\n backgroundColor: colors.accent,\n borderColor: colors.accent,\n },\n check: {\n width: 12,\n height: 12,\n color: colors.accentContrast,\n },\n input: {\n position: 'absolute',\n width: 1,\n height: 1,\n opacity: 0,\n overflow: 'hidden',\n },\n})\n","import {type ReactNode, useState, useCallback} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\ninterface CheckboxProps {\n name?: string\n value?: string\n checked?: boolean\n defaultChecked?: boolean\n disabled?: boolean\n onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void\n children?: ReactNode\n}\n\nexport function Checkbox({\n name,\n value,\n checked: controlledChecked,\n defaultChecked = false,\n disabled = false,\n onChange,\n children,\n}: CheckboxProps) {\n const isControlled = controlledChecked !== undefined\n const [internalChecked, setInternalChecked] = useState(defaultChecked)\n const isChecked = isControlled ? controlledChecked : internalChecked\n\n const handleChange = useCallback(\n (e: React.ChangeEvent<HTMLInputElement>) => {\n if (!isControlled) {\n setInternalChecked(e.target.checked)\n }\n onChange?.(e)\n },\n [isControlled, onChange],\n )\n\n return (\n <html.label style={[styles.root, disabled && styles.rootDisabled]}>\n <html.input\n type=\"checkbox\"\n name={name}\n value={value}\n checked={isControlled ? controlledChecked : undefined}\n defaultChecked={!isControlled ? defaultChecked : undefined}\n disabled={disabled}\n onChange={handleChange}\n style={styles.input}\n />\n <html.span\n style={[styles.box, isChecked ? styles.boxChecked : styles.boxUnchecked]}\n aria-hidden\n >\n <svg\n width={12}\n height={12}\n viewBox=\"0 0 12 12\"\n fill=\"none\"\n style={{opacity: isChecked ? 1 : 0}}\n >\n <polyline\n points=\"2.5 6 5 8.5 9.5 3.5\"\n stroke=\"currentColor\"\n strokeWidth={1.5}\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </svg>\n </html.span>\n {children && <html.span>{children}</html.span>}\n </html.label>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n root: {\n display: 'flex',\n flexDirection: 'column',\n alignItems: 'center',\n justifyContent: 'center',\n gap: spacing.sm,\n paddingTop: spacing.xl,\n paddingBottom: spacing.xl,\n textAlign: 'center',\n },\n message: {\n fontSize: typography.fontSizeSm,\n color: colors.textMuted,\n lineHeight: typography.lineHeight,\n },\n action: {\n marginTop: spacing.sm,\n },\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\ninterface EmptyStateProps {\n message: string\n icon?: ReactNode\n action?: ReactNode\n}\n\nexport function EmptyState({message, icon, action}: EmptyStateProps) {\n return (\n <html.div style={styles.root}>\n {icon}\n <html.p style={styles.message}>{message}</html.p>\n {action && <html.div style={styles.action}>{action}</html.div>}\n </html.div>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {typography, typeScale} from './typography.css'\n\nexport const typePresets = css.create({\n // Body\n bodySm: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.fontSize3,\n lineHeight: typeScale.lineHeight3,\n fontWeight: typography.fontWeightNormal,\n letterSpacing: typeScale.letterSpacingNormal,\n },\n bodyMd: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.fontSize4,\n lineHeight: typeScale.lineHeight4,\n fontWeight: typography.fontWeightNormal,\n letterSpacing: typeScale.letterSpacingNormal,\n },\n bodyLg: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.fontSize5,\n lineHeight: typeScale.lineHeight5,\n fontWeight: typography.fontWeightNormal,\n letterSpacing: typeScale.letterSpacingNormal,\n },\n\n // UI\n caption: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.fontSize1,\n lineHeight: typeScale.lineHeight1,\n fontWeight: typography.fontWeightNormal,\n letterSpacing: typeScale.letterSpacingWide,\n },\n label: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.fontSize3,\n lineHeight: typeScale.lineHeight3,\n fontWeight: typography.fontWeightMedium,\n letterSpacing: typeScale.letterSpacingNormal,\n },\n code: {\n fontFamily: typography.fontFamilyMono,\n fontSize: typeScale.fontSize3,\n lineHeight: typeScale.lineHeight3,\n fontWeight: typography.fontWeightNormal,\n letterSpacing: typeScale.letterSpacingNormal,\n },\n overline: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.fontSize1,\n lineHeight: typeScale.lineHeight1,\n fontWeight: typography.fontWeightSemibold,\n letterSpacing: typeScale.letterSpacingWide,\n textTransform: 'uppercase' as const,\n },\n\n // Heading\n headingSm: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.fontSize6,\n lineHeight: typeScale.lineHeight6,\n fontWeight: typography.fontWeightSemibold,\n letterSpacing: typeScale.letterSpacingTight,\n },\n headingMd: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.fontSize7,\n lineHeight: typeScale.lineHeight7,\n fontWeight: typography.fontWeightSemibold,\n letterSpacing: typeScale.letterSpacingTight,\n },\n headingLg: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.fontSize8,\n lineHeight: typeScale.lineHeight8,\n fontWeight: typography.fontWeightBold,\n letterSpacing: typeScale.letterSpacingTight,\n },\n headingXl: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.fontSize9,\n lineHeight: typeScale.lineHeight9,\n fontWeight: typography.fontWeightBold,\n letterSpacing: typeScale.letterSpacingTight,\n },\n\n // Display (fluid)\n displaySm: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.displaySm,\n lineHeight: 1.2,\n fontWeight: typography.fontWeightBold,\n letterSpacing: typeScale.letterSpacingTight,\n },\n displayMd: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.displayMd,\n lineHeight: 1.15,\n fontWeight: typography.fontWeightBold,\n letterSpacing: typeScale.letterSpacingTight,\n },\n displayLg: {\n fontFamily: typography.fontFamily,\n fontSize: typeScale.displayLg,\n lineHeight: 1.1,\n fontWeight: typography.fontWeightBold,\n letterSpacing: typeScale.letterSpacingTight,\n },\n})\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\n\nexport const styles = css.create({\n // Colors\n default: {\n color: colors.text,\n },\n muted: {\n color: colors.textMuted,\n },\n accent: {\n color: colors.accent,\n },\n\n // Alignment\n alignStart: {\n textAlign: 'start',\n },\n alignCenter: {\n textAlign: 'center',\n },\n alignEnd: {\n textAlign: 'end',\n },\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {typePresets} from '@duro-app/tokens/tokens/type-presets.css'\nimport {styles} from './styles.css'\n\nexport type HeadingVariant =\n | 'displayLg' | 'displayMd' | 'displaySm'\n | 'headingXl' | 'headingLg' | 'headingMd' | 'headingSm'\n\ninterface HeadingProps {\n level: 1 | 2 | 3 | 4 | 5 | 6\n variant?: HeadingVariant\n color?: 'default' | 'muted' | 'accent'\n align?: 'start' | 'center' | 'end'\n children: ReactNode\n}\n\nconst defaultVariantMap: Record<number, HeadingVariant> = {\n 1: 'headingXl',\n 2: 'headingLg',\n 3: 'headingMd',\n 4: 'headingSm',\n 5: 'headingSm',\n 6: 'headingSm',\n}\n\nconst alignMap = {\n start: styles.alignStart,\n center: styles.alignCenter,\n end: styles.alignEnd,\n} as const\n\nexport function Heading({\n level,\n variant,\n color = 'default',\n align,\n children,\n}: HeadingProps) {\n const resolvedVariant = variant ?? defaultVariantMap[level]\n const style = [\n typePresets[resolvedVariant],\n styles[color],\n align && alignMap[align],\n ]\n\n if (level === 1) return <html.h1 style={style}>{children}</html.h1>\n if (level === 2) return <html.h2 style={style}>{children}</html.h2>\n if (level === 3) return <html.h3 style={style}>{children}</html.h3>\n if (level === 4) return <html.h4 style={style}>{children}</html.h4>\n if (level === 5) return <html.h5 style={style}>{children}</html.h5>\n return <html.h6 style={style}>{children}</html.h6>\n}\n","import {createContext, useContext} from 'react'\n\ninterface FieldContextValue {\n controlId: string\n descriptionId: string\n errorId: string\n invalid: boolean\n}\n\nexport const FieldContext = createContext<FieldContextValue | null>(null)\n\nexport function useFieldContext() {\n return useContext(FieldContext)\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n root: {\n display: 'flex',\n flexDirection: 'column',\n gap: spacing.xs,\n },\n label: {\n fontSize: typography.fontSizeSm,\n fontWeight: typography.fontWeightMedium,\n color: colors.text,\n },\n description: {\n fontSize: typography.fontSizeXs,\n color: colors.textMuted,\n },\n error: {\n fontSize: typography.fontSizeXs,\n color: colors.error,\n },\n})\n","import {type ReactNode, useId, useMemo} from 'react'\nimport {html} from 'react-strict-dom'\nimport {FieldContext, useFieldContext} from './FieldContext'\nimport {styles} from './styles.css'\n\n// --- Root ---\ninterface RootProps {\n invalid?: boolean\n children: ReactNode\n}\n\nfunction Root({invalid = false, children}: RootProps) {\n const id = useId()\n const ctx = useMemo(\n () => ({\n controlId: `${id}-control`,\n descriptionId: `${id}-description`,\n errorId: `${id}-error`,\n invalid,\n }),\n [id, invalid],\n )\n\n return (\n <FieldContext.Provider value={ctx}>\n <html.div style={styles.root}>{children}</html.div>\n </FieldContext.Provider>\n )\n}\n\n// --- Label ---\ninterface LabelProps {\n children: ReactNode\n}\n\nfunction Label({children}: LabelProps) {\n const ctx = useFieldContext()\n return (\n <html.label for={ctx?.controlId} style={styles.label}>\n {children}\n </html.label>\n )\n}\n\n// --- Description ---\ninterface DescriptionProps {\n children: ReactNode\n}\n\nfunction Description({children}: DescriptionProps) {\n const ctx = useFieldContext()\n return (\n <html.span id={ctx?.descriptionId} style={styles.description}>\n {children}\n </html.span>\n )\n}\n\n// --- Error ---\ninterface ErrorProps {\n children?: ReactNode\n}\n\nfunction Error({children}: ErrorProps) {\n const ctx = useFieldContext()\n if (!ctx?.invalid && !children) return null\n\n return (\n <html.span id={ctx?.errorId} role=\"alert\" style={styles.error}>\n {children}\n </html.span>\n )\n}\n\nexport const Field = {\n Root,\n Label,\n Description,\n Error,\n}\n","import {createContext, useContext} from 'react'\n\ninterface InputGroupContextValue {\n inGroup: boolean\n}\n\nexport const InputGroupContext = createContext<InputGroupContextValue | null>(null)\n\nexport function useInputGroupContext() {\n return useContext(InputGroupContext)\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n base: {\n width: '100%',\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n lineHeight: typography.lineHeight,\n color: colors.text,\n backgroundColor: colors.bg,\n borderWidth: 1,\n borderStyle: 'solid',\n borderRadius: radii.sm,\n transitionProperty: 'border-color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n outlineWidth: {\n default: 0,\n ':focus-visible': 2,\n },\n outlineStyle: {\n default: 'none',\n ':focus-visible': 'solid',\n },\n outlineColor: {\n default: 'transparent',\n ':focus-visible': colors.accent,\n },\n outlineOffset: {\n default: 0,\n ':focus-visible': 1,\n },\n },\n default: {\n borderColor: {\n default: colors.border,\n ':hover': colors.textMuted,\n ':focus': colors.accent,\n },\n },\n error: {\n borderColor: {\n default: colors.error,\n ':focus': colors.error,\n },\n },\n inGroup: {\n borderWidth: 0,\n borderRadius: 0,\n outlineWidth: 0,\n },\n})\n","import {html} from 'react-strict-dom'\nimport {useFieldContext} from '../Field/FieldContext'\nimport {useInputGroupContext} from '../InputGroup/InputGroupContext'\nimport {styles} from './styles.css'\n\ntype StrictInputProps = React.ComponentProps<typeof html.input>\nexport type InputType = NonNullable<StrictInputProps['type']>\n\nexport type InputVariant = 'default' | 'error'\n\ninterface InputProps {\n variant?: InputVariant\n type?: InputType\n name?: string\n placeholder?: string\n required?: boolean\n minLength?: number\n pattern?: string\n autoComplete?:\n | 'on'\n | 'off'\n | 'email'\n | 'username'\n | 'current-password'\n | 'new-password'\n | 'name'\n | 'tel'\n | 'url'\n value?: string\n defaultValue?: string\n disabled?: boolean\n onChange?: (e: React.ChangeEvent<HTMLInputElement>) => void\n}\n\nexport function Input({\n variant = 'default',\n type = 'text',\n name,\n placeholder,\n required,\n minLength,\n pattern,\n autoComplete,\n value,\n defaultValue,\n disabled,\n onChange,\n}: InputProps) {\n const ctx = useFieldContext()\n const groupCtx = useInputGroupContext()\n\n // react-strict-dom omits web-only `pattern` from its types, but the\n // underlying DOM element supports it. Type-assert to pass it through.\n const extraProps = pattern !== undefined ? {pattern} : undefined\n\n return (\n <html.input\n id={ctx?.controlId}\n type={type}\n name={name}\n placeholder={placeholder}\n required={required}\n minLength={minLength}\n autoComplete={autoComplete}\n value={value}\n defaultValue={defaultValue}\n disabled={disabled}\n aria-describedby={\n ctx ? `${ctx.descriptionId} ${ctx.invalid ? ctx.errorId : ''}`.trim() : undefined\n }\n aria-invalid={ctx?.invalid || variant === 'error' || undefined}\n onChange={onChange}\n style={[styles.base, styles[variant], groupCtx?.inGroup && styles.inGroup]}\n {...(extraProps as Record<string, unknown>)}\n />\n )\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n wrapper: {\n display: 'flex',\n alignItems: 'stretch',\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: {\n default: colors.border,\n ':focus-within': colors.accent,\n },\n borderRadius: radii.sm,\n overflow: 'hidden',\n transitionProperty: 'border-color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n },\n addon: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n flexShrink: 0,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n backgroundColor: colors.bgCardHover,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n color: colors.textMuted,\n userSelect: 'none',\n borderWidth: 0,\n },\n addonStart: {\n borderRightWidth: 1,\n borderRightStyle: 'solid',\n borderRightColor: colors.border,\n },\n addonEnd: {\n borderLeftWidth: 1,\n borderLeftStyle: 'solid',\n borderLeftColor: colors.border,\n },\n addonClickable: {\n cursor: 'pointer',\n backgroundColor: {\n default: colors.bgCardHover,\n ':hover': colors.bgCard,\n ':active': colors.bg,\n },\n transitionProperty: 'background-color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n },\n addonDisabled: {\n opacity: 0.4,\n cursor: 'not-allowed',\n },\n})\n","import type {ReactNode} from 'react'\nimport {useMemo} from 'react'\nimport {html} from 'react-strict-dom'\nimport {InputGroupContext} from './InputGroupContext'\nimport {styles} from './styles.css'\n\n// --- Root ---\ninterface RootProps {\n children: ReactNode\n}\n\nfunction Root({children}: RootProps) {\n const ctx = useMemo(() => ({inGroup: true}), [])\n\n return (\n <InputGroupContext.Provider value={ctx}>\n <html.div style={styles.wrapper}>{children}</html.div>\n </InputGroupContext.Provider>\n )\n}\n\n// --- Addon ---\ninterface AddonProps {\n position?: 'start' | 'end'\n onClick?: () => void\n disabled?: boolean\n children: ReactNode\n}\n\nfunction Addon({position = 'end', onClick, disabled, children}: AddonProps) {\n const positionStyle = position === 'start' ? styles.addonStart : styles.addonEnd\n const style = [\n styles.addon,\n positionStyle,\n onClick && !disabled && styles.addonClickable,\n disabled && styles.addonDisabled,\n ]\n\n if (onClick) {\n return (\n <html.button type=\"button\" onClick={onClick} disabled={disabled} style={style}>\n {children}\n </html.button>\n )\n }\n\n return <html.span style={style}>{children}</html.span>\n}\n\nexport const InputGroup = {\n Root,\n Addon,\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n base: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n gap: spacing.sm,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n fontWeight: typography.fontWeightMedium,\n lineHeight: typography.lineHeight,\n borderRadius: radii.sm,\n cursor: 'pointer',\n textDecoration: 'none',\n transitionProperty: 'background-color, border-color, color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n },\n sizeDefault: {\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n },\n sizeSmall: {\n paddingTop: spacing.xs,\n paddingBottom: spacing.xs,\n paddingLeft: spacing.sm,\n paddingRight: spacing.sm,\n fontSize: typography.fontSizeXs,\n },\n primary: {\n backgroundColor: {\n default: colors.accent,\n ':hover': colors.accentHover,\n },\n color: colors.accentContrast,\n },\n secondary: {\n backgroundColor: {\n default: 'transparent',\n ':hover': colors.bgCardHover,\n },\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: colors.border,\n color: colors.textMuted,\n },\n fullWidth: {\n width: '100%',\n },\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\nexport type LinkButtonVariant = 'primary' | 'secondary'\nexport type LinkButtonSize = 'default' | 'small'\n\ninterface LinkButtonProps {\n href: string\n variant?: LinkButtonVariant\n size?: LinkButtonSize\n fullWidth?: boolean\n target?: '_blank' | '_self'\n rel?: string\n children: ReactNode\n}\n\nconst sizeMap = {\n default: styles.sizeDefault,\n small: styles.sizeSmall,\n} as const\n\nexport function LinkButton({\n href,\n variant = 'primary',\n size = 'default',\n fullWidth = false,\n target,\n rel,\n children,\n}: LinkButtonProps) {\n return (\n <html.a\n href={href}\n target={target}\n rel={rel}\n style={[styles.base, sizeMap[size], styles[variant], fullWidth && styles.fullWidth]}\n >\n {children}\n </html.a>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\nimport {shadows} from '@duro-app/tokens/tokens/shadows.css'\n\nexport const styles = css.create({\n root: {\n position: 'relative',\n display: 'inline-flex',\n },\n trigger: {\n display: 'inline-flex',\n alignItems: 'center',\n gap: spacing.sm,\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n color: colors.text,\n backgroundColor: {\n default: 'transparent',\n ':hover': colors.bgCardHover,\n },\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: colors.border,\n borderRadius: radii.sm,\n cursor: 'pointer',\n transitionProperty: 'background-color, border-color',\n transitionDuration: '150ms',\n },\n backdrop: {\n position: 'fixed',\n top: 0,\n left: 0,\n right: 0,\n bottom: 0,\n zIndex: 49,\n },\n popup: {\n position: 'absolute',\n top: '100%',\n left: 0,\n marginTop: spacing.xs,\n backgroundColor: colors.bgCard,\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: colors.border,\n borderRadius: radii.sm,\n boxShadow: shadows.md,\n paddingTop: spacing.xs,\n paddingBottom: spacing.xs,\n minWidth: 160,\n zIndex: 50,\n },\n popupEnd: {\n left: 'auto',\n right: 0,\n },\n item: {\n display: 'flex',\n alignItems: 'center',\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontSize: typography.fontSizeSm,\n fontFamily: typography.fontFamily,\n color: colors.text,\n borderRadius: radii.sm,\n cursor: 'pointer',\n backgroundColor: 'transparent',\n transitionProperty: 'background-color',\n transitionDuration: '150ms',\n },\n itemHighlighted: {\n backgroundColor: colors.bgCardHover,\n },\n linkItem: {\n textDecoration: 'none',\n color: {\n default: colors.text,\n ':hover': colors.text,\n },\n },\n})\n","import {createContext, useContext} from 'react'\n\nexport interface MenuContextValue {\n open: boolean\n toggle: () => void\n close: () => void\n menuId: string\n highlightedId: string | null\n setHighlightedId: (id: string | null) => void\n registerItem: (id: string, element: HTMLElement) => () => void\n triggerRef: React.RefObject<HTMLButtonElement | null>\n}\n\nexport const MenuContext = createContext<MenuContextValue | null>(null)\n\nexport function useMenu() {\n const ctx = useContext(MenuContext)\n if (!ctx) throw new Error('Menu compound components must be used within Menu.Root')\n return ctx\n}\n","import {useState, useCallback, useRef, useId, useEffect} from 'react'\nimport type {MenuContextValue} from './MenuContext'\n\nexport function useMenuRoot() {\n const [open, setOpen] = useState(false)\n const [highlightedId, setHighlightedId] = useState<string | null>(null)\n const menuId = useId()\n const rootRef = useRef<HTMLDivElement>(null)\n const triggerRef = useRef<HTMLButtonElement | null>(null)\n const itemsRef = useRef(new Map<string, HTMLElement>())\n const orderRef = useRef<string[]>([])\n const needsInitialHighlightRef = useRef(false)\n\n const close = useCallback(() => {\n setOpen(false)\n setHighlightedId(null)\n needsInitialHighlightRef.current = false\n triggerRef.current?.focus()\n }, [])\n\n const toggle = useCallback(() => {\n setOpen((prev) => {\n if (!prev) {\n needsInitialHighlightRef.current = true\n } else {\n setHighlightedId(null)\n needsInitialHighlightRef.current = false\n }\n return !prev\n })\n }, [])\n\n // Highlight the first item after items register on open.\n // Child effects (item registration) run before this parent effect,\n // so orderRef is populated by the time this runs.\n useEffect(() => {\n if (open && needsInitialHighlightRef.current) {\n needsInitialHighlightRef.current = false\n const order = orderRef.current\n if (order.length > 0) {\n setHighlightedId(order[0])\n }\n }\n }, [open])\n\n const registerItem = useCallback((id: string, element: HTMLElement) => {\n itemsRef.current.set(id, element)\n const map = itemsRef.current\n const ids = [...map.keys()]\n ids.sort((a, b) => {\n const elA = map.get(a)\n const elB = map.get(b)\n if (!elA || !elB) return 0\n return elA.compareDocumentPosition(elB) & Node.DOCUMENT_POSITION_FOLLOWING ? -1 : 1\n })\n orderRef.current = ids\n return () => {\n itemsRef.current.delete(id)\n orderRef.current = orderRef.current.filter((i) => i !== id)\n }\n }, [])\n\n // Native keydown for full KeyboardEvent access (preventDefault)\n useEffect(() => {\n const root = rootRef.current\n if (!root || !open) return\n\n function handleKeyDown(e: KeyboardEvent) {\n const order = orderRef.current\n if (order.length === 0) return\n\n switch (e.key) {\n case 'ArrowDown': {\n e.preventDefault()\n setHighlightedId((prev) => {\n const idx = prev ? order.indexOf(prev) : -1\n return order[(idx + 1) % order.length]\n })\n break\n }\n case 'ArrowUp': {\n e.preventDefault()\n setHighlightedId((prev) => {\n const idx = prev ? order.indexOf(prev) : 0\n return order[(idx - 1 + order.length) % order.length]\n })\n break\n }\n case 'Home': {\n e.preventDefault()\n setHighlightedId(order[0])\n break\n }\n case 'End': {\n e.preventDefault()\n setHighlightedId(order[order.length - 1])\n break\n }\n case 'Enter':\n case ' ': {\n e.preventDefault()\n const items = itemsRef.current\n setHighlightedId((prev) => {\n if (prev) {\n const el = items.get(prev)\n el?.click()\n }\n return prev\n })\n break\n }\n case 'Escape':\n case 'Tab': {\n close()\n break\n }\n }\n }\n\n root.addEventListener('keydown', handleKeyDown)\n return () => root.removeEventListener('keydown', handleKeyDown)\n }, [open, close])\n\n const ctx: MenuContextValue = {\n open,\n toggle,\n close,\n menuId,\n highlightedId,\n setHighlightedId,\n registerItem,\n triggerRef,\n }\n\n return {ctx, rootRef}\n}\n","import {type ReactNode, useRef, useId, useEffect} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\nimport {MenuContext, useMenu} from './MenuContext'\nimport {useMenuRoot} from './useMenuRoot'\n\n// --- Root ---\ninterface RootProps {\n children: ReactNode\n}\n\nfunction Root({children}: RootProps) {\n const {ctx, rootRef} = useMenuRoot()\n\n return (\n <MenuContext.Provider value={ctx}>\n <html.div ref={rootRef} style={styles.root}>\n {children}\n </html.div>\n </MenuContext.Provider>\n )\n}\n\n// --- Trigger ---\nfunction Trigger({children}: {children: ReactNode}) {\n const {open, toggle, menuId, triggerRef} = useMenu()\n const localRef = useRef<HTMLButtonElement>(null)\n\n // Sync local ref to context triggerRef\n useEffect(() => {\n triggerRef.current = localRef.current\n })\n\n return (\n <html.button\n ref={localRef}\n type=\"button\"\n onClick={toggle}\n aria-expanded={open}\n aria-haspopup=\"menu\"\n aria-controls={open ? menuId : undefined}\n style={styles.trigger}\n >\n {children}\n </html.button>\n )\n}\n\n// --- Popup ---\ninterface PopupProps {\n children: ReactNode\n align?: 'start' | 'end'\n}\n\nfunction Popup({children, align = 'start'}: PopupProps) {\n const {open, close, menuId, highlightedId} = useMenu()\n\n if (!open) return null\n\n return (\n <>\n <html.div style={styles.backdrop} onClick={close} />\n <html.div\n id={menuId}\n role=\"menu\"\n aria-activedescendant={highlightedId ?? undefined}\n style={[styles.popup, align === 'end' && styles.popupEnd]}\n >\n {children}\n </html.div>\n </>\n )\n}\n\n// --- Item ---\ninterface ItemProps {\n onClick?: () => void\n children: ReactNode\n}\n\nfunction Item({onClick, children}: ItemProps) {\n const {close, highlightedId, setHighlightedId, registerItem} = useMenu()\n const id = useId()\n const ref = useRef<HTMLDivElement>(null)\n const isHighlighted = highlightedId === id\n\n useEffect(() => {\n const el = ref.current\n if (!el) return\n return registerItem(id, el)\n }, [id, registerItem])\n\n const handleClick = () => {\n onClick?.()\n close()\n }\n\n return (\n <html.div\n ref={ref}\n id={id}\n role=\"menuitem\"\n onClick={handleClick}\n onPointerEnter={() => setHighlightedId(id)}\n style={[styles.item, isHighlighted && styles.itemHighlighted]}\n >\n {children}\n </html.div>\n )\n}\n\n// --- LinkItem ---\ninterface LinkItemProps {\n href: string\n children: ReactNode\n}\n\nfunction LinkItem({href, children}: LinkItemProps) {\n const {close, highlightedId, setHighlightedId, registerItem} = useMenu()\n const id = useId()\n const ref = useRef<HTMLAnchorElement>(null)\n const isHighlighted = highlightedId === id\n\n useEffect(() => {\n const el = ref.current\n if (!el) return\n return registerItem(id, el)\n }, [id, registerItem])\n\n return (\n <html.a\n ref={ref}\n id={id}\n href={href}\n onClick={close}\n role=\"menuitem\"\n onPointerEnter={() => setHighlightedId(id)}\n style={[styles.item, styles.linkItem, isHighlighted && styles.itemHighlighted]}\n >\n {children}\n </html.a>\n )\n}\n\nexport const Menu = {\n Root,\n Trigger,\n Popup,\n Item,\n LinkItem,\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {radii} from '@duro-app/tokens/tokens/spacing.css'\n\nexport const styles = css.create({\n root: {\n position: 'relative',\n overflow: 'hidden',\n },\n viewport: {\n width: '100%',\n height: '100%',\n overflowX: 'auto',\n overflowY: 'auto',\n // Hide native scrollbar\n scrollbarWidth: 'none',\n },\n content: {\n minWidth: '100%',\n minHeight: '100%',\n },\n scrollbar: {\n position: 'absolute',\n zIndex: 1,\n display: 'flex',\n touchAction: 'none',\n userSelect: 'none',\n transitionProperty: 'opacity',\n transitionDuration: '200ms',\n transitionTimingFunction: 'ease',\n },\n scrollbarVertical: {\n top: 0,\n right: 0,\n bottom: 0,\n width: 8,\n flexDirection: 'column',\n paddingTop: 2,\n paddingBottom: 2,\n paddingRight: 2,\n },\n scrollbarHorizontal: {\n left: 0,\n right: 0,\n bottom: 0,\n height: 8,\n flexDirection: 'row',\n paddingLeft: 2,\n paddingRight: 2,\n paddingBottom: 2,\n },\n scrollbarHidden: {\n opacity: 0,\n },\n scrollbarVisible: {\n opacity: 1,\n },\n thumb: {\n position: 'relative',\n flex: 1,\n backgroundColor: {\n default: colors.border,\n ':hover': colors.textMuted,\n },\n borderRadius: radii.full,\n transitionProperty: 'background-color',\n transitionDuration: '150ms',\n },\n // Dynamic styles — simple identifier params only (StyleX constraint)\n viewportMaxHeight: (maxHeight: number | string) => ({\n maxHeight,\n }),\n thumbVertical: (height: string, transform: string) => ({\n height,\n transform,\n }),\n thumbHorizontal: (width: string, transform: string) => ({\n width,\n transform,\n }),\n})\n","import {createContext, useContext} from 'react'\n\nexport interface ScrollAreaContextValue {\n viewportRef: React.RefObject<HTMLDivElement | null>\n contentRef: React.RefObject<HTMLDivElement | null>\n scrollTop: number\n scrollLeft: number\n scrollHeight: number\n scrollWidth: number\n clientHeight: number\n clientWidth: number\n scrolling: boolean\n}\n\nexport const ScrollAreaContext = createContext<ScrollAreaContextValue | null>(null)\n\nexport function useScrollArea() {\n const ctx = useContext(ScrollAreaContext)\n if (!ctx) throw new Error('ScrollArea compound components must be used within ScrollArea.Root')\n return ctx\n}\n","import {useState, useCallback, useRef, useEffect} from 'react'\nimport type {ScrollAreaContextValue} from './ScrollAreaContext'\n\nexport function useScrollAreaRoot(): ScrollAreaContextValue {\n const viewportRef = useRef<HTMLDivElement | null>(null)\n const contentRef = useRef<HTMLDivElement | null>(null)\n const [scrollTop, setScrollTop] = useState(0)\n const [scrollLeft, setScrollLeft] = useState(0)\n const [scrollHeight, setScrollHeight] = useState(0)\n const [scrollWidth, setScrollWidth] = useState(0)\n const [clientHeight, setClientHeight] = useState(0)\n const [clientWidth, setClientWidth] = useState(0)\n const [scrolling, setScrolling] = useState(false)\n const scrollTimerRef = useRef<ReturnType<typeof setTimeout> | null>(null)\n\n const handleScroll = useCallback(() => {\n const vp = viewportRef.current\n if (!vp) return\n\n setScrollTop(vp.scrollTop)\n setScrollLeft(vp.scrollLeft)\n setScrollHeight(vp.scrollHeight)\n setScrollWidth(vp.scrollWidth)\n setClientHeight(vp.clientHeight)\n setClientWidth(vp.clientWidth)\n setScrolling(true)\n\n if (scrollTimerRef.current) clearTimeout(scrollTimerRef.current)\n scrollTimerRef.current = setTimeout(() => setScrolling(false), 1000)\n }, [])\n\n // Observe viewport size changes\n useEffect(() => {\n const vp = viewportRef.current\n if (!vp) return\n\n const observer = new ResizeObserver(() => {\n setScrollHeight(vp.scrollHeight)\n setScrollWidth(vp.scrollWidth)\n setClientHeight(vp.clientHeight)\n setClientWidth(vp.clientWidth)\n })\n observer.observe(vp)\n // Initial measurement\n setScrollHeight(vp.scrollHeight)\n setScrollWidth(vp.scrollWidth)\n setClientHeight(vp.clientHeight)\n setClientWidth(vp.clientWidth)\n\n return () => observer.disconnect()\n }, [])\n\n // Attach scroll listener directly to ensure we capture it\n useEffect(() => {\n const vp = viewportRef.current\n if (!vp) return\n vp.addEventListener('scroll', handleScroll, {passive: true})\n return () => vp.removeEventListener('scroll', handleScroll)\n }, [handleScroll])\n\n return {\n viewportRef,\n contentRef,\n scrollTop,\n scrollLeft,\n scrollHeight,\n scrollWidth,\n clientHeight,\n clientWidth,\n scrolling,\n }\n}\n","import {type ReactNode, useRef, useCallback} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\nimport {ScrollAreaContext, useScrollArea} from './ScrollAreaContext'\nimport {useScrollAreaRoot} from './useScrollAreaRoot'\n\n// --- Root ---\n\ninterface RootProps {\n children: ReactNode\n}\n\nfunction Root({children}: RootProps) {\n const ctx = useScrollAreaRoot()\n\n return (\n <ScrollAreaContext.Provider value={ctx}>\n <html.div style={styles.root}>{children}</html.div>\n </ScrollAreaContext.Provider>\n )\n}\n\n// --- Viewport ---\n\ninterface ViewportProps {\n children: ReactNode\n maxHeight?: number | string\n}\n\nfunction Viewport({children, maxHeight}: ViewportProps) {\n const {viewportRef} = useScrollArea()\n\n return (\n <html.div\n ref={viewportRef}\n style={[styles.viewport, maxHeight != null && styles.viewportMaxHeight(maxHeight)]}\n >\n {children}\n </html.div>\n )\n}\n\n// --- Content ---\n\ninterface ContentProps {\n children: ReactNode\n}\n\nfunction Content({children}: ContentProps) {\n const {contentRef} = useScrollArea()\n return (\n <html.div ref={contentRef} style={styles.content}>\n {children}\n </html.div>\n )\n}\n\n// --- Scrollbar ---\n\ntype ScrollbarOrientation = 'vertical' | 'horizontal'\n\ninterface ScrollbarProps {\n orientation?: ScrollbarOrientation\n children: ReactNode\n}\n\nfunction Scrollbar({orientation = 'vertical', children}: ScrollbarProps) {\n const {scrolling, scrollHeight, scrollWidth, clientHeight, clientWidth} = useScrollArea()\n\n // Hide scrollbar when content fits\n const hasOverflow =\n orientation === 'vertical' ? scrollHeight > clientHeight : scrollWidth > clientWidth\n\n if (!hasOverflow) return null\n\n return (\n <html.div\n style={[\n styles.scrollbar,\n orientation === 'vertical' ? styles.scrollbarVertical : styles.scrollbarHorizontal,\n scrolling ? styles.scrollbarVisible : styles.scrollbarHidden,\n ]}\n >\n {children}\n </html.div>\n )\n}\n\n// --- Thumb ---\n\ninterface ThumbProps {\n orientation?: ScrollbarOrientation\n}\n\nfunction Thumb({orientation = 'vertical'}: ThumbProps) {\n const {viewportRef, scrollTop, scrollLeft, scrollHeight, scrollWidth, clientHeight, clientWidth} =\n useScrollArea()\n const draggingRef = useRef(false)\n const startPosRef = useRef(0)\n const startScrollRef = useRef(0)\n\n const isVertical = orientation === 'vertical'\n\n const thumbSizePercent = isVertical\n ? Math.max((clientHeight / scrollHeight) * 100, 10)\n : Math.max((clientWidth / scrollWidth) * 100, 10)\n\n const maxScroll = isVertical ? scrollHeight - clientHeight : scrollWidth - clientWidth\n const trackSize = isVertical ? clientHeight : clientWidth\n const thumbPixelSize = (thumbSizePercent / 100) * trackSize\n const scrollOffset = isVertical ? scrollTop : scrollLeft\n const thumbOffset = maxScroll > 0 ? (scrollOffset / maxScroll) * (trackSize - thumbPixelSize) : 0\n\n const thumbStyle = isVertical\n ? styles.thumbVertical(`${thumbSizePercent}%`, `translateY(${thumbOffset}px)`)\n : styles.thumbHorizontal(`${thumbSizePercent}%`, `translateX(${thumbOffset}px)`)\n\n const handlePointerDown = useCallback(\n (e: React.PointerEvent) => {\n e.preventDefault()\n draggingRef.current = true\n startPosRef.current = isVertical ? e.clientY : e.clientX\n startScrollRef.current = isVertical\n ? (viewportRef.current?.scrollTop ?? 0)\n : (viewportRef.current?.scrollLeft ?? 0)\n ;(e.target as HTMLElement).setPointerCapture(e.pointerId)\n },\n [isVertical, viewportRef],\n )\n\n const handlePointerMove = useCallback(\n (e: React.PointerEvent) => {\n if (!draggingRef.current) return\n const vp = viewportRef.current\n if (!vp) return\n\n const delta = (isVertical ? e.clientY : e.clientX) - startPosRef.current\n const scrollRatio = maxScroll / (trackSize - thumbPixelSize)\n const scrollDelta = delta * scrollRatio\n\n if (isVertical) {\n vp.scrollTop = startScrollRef.current + scrollDelta\n } else {\n vp.scrollLeft = startScrollRef.current + scrollDelta\n }\n },\n [isVertical, maxScroll, trackSize, thumbPixelSize, viewportRef],\n )\n\n const handlePointerUp = useCallback(() => {\n draggingRef.current = false\n }, [])\n\n return (\n <html.div\n onPointerDown={handlePointerDown}\n onPointerMove={handlePointerMove}\n onPointerUp={handlePointerUp}\n style={[styles.thumb, thumbStyle]}\n />\n )\n}\n\nexport const ScrollArea = {\n Root,\n Viewport,\n Content,\n Scrollbar,\n Thumb,\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\nimport {shadows} from '@duro-app/tokens/tokens/shadows.css'\n\nexport const styles = css.create({\n root: {\n position: 'relative',\n display: 'inline-flex',\n },\n trigger: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'space-between',\n gap: spacing.sm,\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n color: colors.text,\n backgroundColor: colors.bgCard,\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: {\n default: colors.border,\n ':hover': colors.accent,\n },\n borderRadius: radii.sm,\n cursor: 'pointer',\n transitionProperty: 'border-color',\n transitionDuration: '150ms',\n },\n value: {\n color: colors.text,\n },\n placeholder: {\n color: colors.textMuted,\n },\n icon: {\n display: 'flex',\n alignItems: 'center',\n color: colors.textMuted,\n },\n backdrop: {\n position: 'fixed',\n top: 0,\n left: 0,\n right: 0,\n bottom: 0,\n zIndex: 49,\n },\n popup: {\n position: 'absolute',\n top: '100%',\n left: 0,\n marginTop: spacing.xs,\n backgroundColor: colors.bgCard,\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: colors.border,\n borderRadius: radii.sm,\n boxShadow: shadows.md,\n paddingTop: spacing.xs,\n paddingBottom: spacing.xs,\n minWidth: 120,\n zIndex: 50,\n },\n item: {\n display: 'flex',\n alignItems: 'center',\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontSize: typography.fontSizeSm,\n fontFamily: typography.fontFamily,\n color: colors.text,\n borderRadius: radii.sm,\n cursor: 'pointer',\n backgroundColor: 'transparent',\n transitionProperty: 'background-color',\n transitionDuration: '150ms',\n },\n itemSelected: {\n color: colors.accent,\n fontWeight: typography.fontWeightMedium,\n },\n itemHighlighted: {\n backgroundColor: colors.bgCardHover,\n },\n hidden: {\n display: 'none',\n },\n})\n","import {createContext, useContext} from 'react'\n\nexport interface SelectContextValue {\n open: boolean\n toggle: () => void\n close: () => void\n value: string | null\n setValue: (value: string) => void\n labels: Record<string, string>\n registerLabel: (value: string, label: string) => void\n listboxId: string\n highlightedId: string | null\n setHighlightedId: (id: string | null) => void\n registerItem: (id: string, value: string, element: HTMLElement) => () => void\n triggerRef: React.RefObject<HTMLButtonElement | null>\n}\n\nexport const SelectContext = createContext<SelectContextValue | null>(null)\n\nexport function useSelect() {\n const ctx = useContext(SelectContext)\n if (!ctx) throw new Error('Select compound components must be used within Select.Root')\n return ctx\n}\n","import {useState, useCallback} from 'react'\n\nexport function useControllableValue<T>(\n controlledValue: T | undefined,\n defaultValue: T,\n onChange?: (value: T) => void,\n) {\n const [internal, setInternal] = useState(defaultValue)\n const value = controlledValue !== undefined ? controlledValue : internal\n const setValue = useCallback(\n (v: T) => {\n if (controlledValue === undefined) setInternal(v)\n onChange?.(v)\n },\n [controlledValue, onChange],\n )\n return [value, setValue] as const\n}\n","import {useState, useCallback, useMemo, useRef, useId, useEffect} from 'react'\nimport {useControllableValue} from '../../hooks/useControllableValue'\nimport type {SelectContextValue} from './SelectContext'\n\ninterface UseSelectRootOptions {\n defaultValue?: string\n value?: string\n onValueChange?: (value: string | null) => void\n}\n\nexport function useSelectRoot({\n defaultValue,\n value: controlledValue,\n onValueChange,\n}: UseSelectRootOptions) {\n const [value, setValue] = useControllableValue<string | null>(\n controlledValue,\n defaultValue ?? null,\n onValueChange,\n )\n const [open, setOpen] = useState(false)\n const [labels, setLabels] = useState<Record<string, string>>({})\n const [highlightedId, setHighlightedId] = useState<string | null>(null)\n const listboxId = useId()\n const rootRef = useRef<HTMLDivElement>(null)\n const triggerRef = useRef<HTMLButtonElement | null>(null)\n const itemsRef = useRef(new Map<string, {value: string; element: HTMLElement}>())\n const orderRef = useRef<string[]>([])\n\n const close = useCallback(() => {\n setOpen(false)\n setHighlightedId(null)\n triggerRef.current?.focus()\n }, [])\n\n const toggle = useCallback(() => {\n setOpen((prev) => {\n if (!prev) {\n const items = itemsRef.current\n const order = orderRef.current\n let found: string | null = null\n for (const id of order) {\n const item = items.get(id)\n if (item && item.value === value) {\n found = id\n break\n }\n }\n setHighlightedId(found ?? (order.length > 0 ? order[0] : null))\n } else {\n setHighlightedId(null)\n }\n return !prev\n })\n }, [value])\n\n const registerLabel = useCallback((v: string, label: string) => {\n setLabels((prev) => {\n if (prev[v] === label) return prev\n return {...prev, [v]: label}\n })\n }, [])\n\n const registerItem = useCallback((id: string, itemValue: string, element: HTMLElement) => {\n itemsRef.current.set(id, {value: itemValue, element})\n const map = itemsRef.current\n const ids = [...map.keys()]\n ids.sort((a, b) => {\n const elA = map.get(a)?.element\n const elB = map.get(b)?.element\n if (!elA || !elB) return 0\n return elA.compareDocumentPosition(elB) & Node.DOCUMENT_POSITION_FOLLOWING ? -1 : 1\n })\n orderRef.current = ids\n return () => {\n itemsRef.current.delete(id)\n orderRef.current = orderRef.current.filter((i) => i !== id)\n }\n }, [])\n\n // Native keydown for full KeyboardEvent access (preventDefault)\n useEffect(() => {\n const root = rootRef.current\n if (!root || !open) return\n\n function handleKeyDown(e: KeyboardEvent) {\n const order = orderRef.current\n const items = itemsRef.current\n if (order.length === 0) return\n\n switch (e.key) {\n case 'ArrowDown': {\n e.preventDefault()\n setHighlightedId((prev) => {\n const idx = prev ? order.indexOf(prev) : -1\n return order[(idx + 1) % order.length]\n })\n break\n }\n case 'ArrowUp': {\n e.preventDefault()\n setHighlightedId((prev) => {\n const idx = prev ? order.indexOf(prev) : 0\n return order[(idx - 1 + order.length) % order.length]\n })\n break\n }\n case 'Home': {\n e.preventDefault()\n setHighlightedId(order[0])\n break\n }\n case 'End': {\n e.preventDefault()\n setHighlightedId(order[order.length - 1])\n break\n }\n case 'Enter':\n case ' ': {\n e.preventDefault()\n setHighlightedId((prev) => {\n if (prev) {\n const item = items.get(prev)\n if (item) {\n setValue(item.value)\n close()\n }\n }\n return prev\n })\n break\n }\n case 'Escape':\n case 'Tab': {\n close()\n break\n }\n }\n }\n\n root.addEventListener('keydown', handleKeyDown)\n return () => root.removeEventListener('keydown', handleKeyDown)\n }, [open, close, setValue])\n\n const ctx: SelectContextValue = useMemo(\n () => ({\n open,\n toggle,\n close,\n value,\n setValue,\n labels,\n registerLabel,\n listboxId,\n highlightedId,\n setHighlightedId,\n registerItem,\n triggerRef,\n }),\n [\n open,\n toggle,\n close,\n value,\n setValue,\n labels,\n registerLabel,\n listboxId,\n highlightedId,\n setHighlightedId,\n registerItem,\n ],\n )\n\n return {ctx, rootRef}\n}\n","import {type ReactNode, useRef, useId, useEffect} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\nimport {SelectContext, useSelect} from './SelectContext'\nimport {useSelectRoot} from './useSelectRoot'\n\n// --- Root ---\ninterface RootProps {\n name?: string\n defaultValue?: string\n value?: string\n onValueChange?: (value: string | null) => void\n children: ReactNode\n}\n\nfunction Root({name, defaultValue, value, onValueChange, children}: RootProps) {\n const {ctx, rootRef} = useSelectRoot({defaultValue, value, onValueChange})\n\n return (\n <SelectContext.Provider value={ctx}>\n <html.div ref={rootRef} style={styles.root}>\n {name && <html.input type=\"hidden\" name={name} value={ctx.value ?? ''} />}\n {children}\n </html.div>\n </SelectContext.Provider>\n )\n}\n\n// --- Trigger ---\nfunction Trigger({children}: {children: ReactNode}) {\n const {open, toggle, listboxId, highlightedId, triggerRef} = useSelect()\n const localRef = useRef<HTMLButtonElement>(null)\n\n // Sync local ref to context triggerRef\n useEffect(() => {\n triggerRef.current = localRef.current\n })\n\n return (\n <html.button\n ref={localRef}\n type=\"button\"\n role={'combobox' as 'listbox'}\n onClick={toggle}\n aria-expanded={open}\n aria-haspopup=\"listbox\"\n aria-controls={open ? listboxId : undefined}\n aria-activedescendant={highlightedId ?? undefined}\n style={styles.trigger}\n >\n {children}\n </html.button>\n )\n}\n\n// --- Value ---\nfunction Value({placeholder}: {placeholder?: string}) {\n const {value, labels} = useSelect()\n const display = value ? (labels[value] ?? value) : null\n\n return (\n <html.span style={display ? styles.value : styles.placeholder}>\n {display ?? placeholder}\n </html.span>\n )\n}\n\n// --- Icon ---\nfunction Icon({children}: {children?: ReactNode}) {\n return (\n <html.span style={styles.icon}>\n {children ?? (\n <svg\n width=\"12\"\n height=\"12\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n aria-hidden=\"true\"\n >\n <path d=\"M6 9l6 6 6-6\" />\n </svg>\n )}\n </html.span>\n )\n}\n\n// --- Popup ---\nfunction Popup({children}: {children: ReactNode}) {\n const {open, close, listboxId} = useSelect()\n\n return (\n <>\n {open && <html.div style={styles.backdrop} onClick={close} />}\n <html.div\n id={listboxId}\n role=\"listbox\"\n aria-hidden={!open}\n style={[styles.popup, !open && styles.hidden]}\n >\n {children}\n </html.div>\n </>\n )\n}\n\n// --- Item ---\ninterface ItemProps {\n value: string\n children: ReactNode\n}\n\nfunction Item({value: itemValue, children}: ItemProps) {\n const {\n value: selectedValue,\n setValue,\n close,\n registerLabel,\n highlightedId,\n setHighlightedId,\n registerItem,\n } = useSelect()\n const id = useId()\n const ref = useRef<HTMLDivElement>(null)\n const isSelected = selectedValue === itemValue\n const isHighlighted = highlightedId === id\n\n // Register label from DOM text content (works with both string and JSX children)\n useEffect(() => {\n const el = ref.current\n if (!el) return\n const text = el.textContent\n if (text) registerLabel(itemValue, text)\n }, [itemValue, registerLabel])\n\n useEffect(() => {\n const el = ref.current\n if (!el) return\n return registerItem(id, itemValue, el)\n }, [id, itemValue, registerItem])\n\n const handleClick = () => {\n setValue(itemValue)\n close()\n }\n\n return (\n <html.div\n ref={ref}\n id={id}\n role=\"option\"\n aria-selected={isSelected}\n onClick={handleClick}\n onPointerEnter={() => setHighlightedId(id)}\n style={[\n styles.item,\n isSelected && styles.itemSelected,\n isHighlighted && styles.itemHighlighted,\n ]}\n >\n {children}\n </html.div>\n )\n}\n\n// --- ItemText ---\nfunction ItemText({children}: {children: ReactNode}) {\n return <html.span>{children}</html.span>\n}\n\nexport const Select = {\n Root,\n Trigger,\n Value,\n Icon,\n Popup,\n Item,\n ItemText,\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n root: {\n display: 'flex',\n flexDirection: 'column',\n gap: 0,\n },\n group: {\n display: 'flex',\n flexDirection: 'column',\n },\n groupTrigger: {\n display: 'flex',\n alignItems: 'center',\n gap: spacing.xs,\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeXs,\n fontWeight: typography.fontWeightSemibold,\n textTransform: 'uppercase' as const,\n letterSpacing: '0.05em',\n color: {\n default: colors.textMuted,\n ':hover': colors.text,\n },\n backgroundColor: 'transparent',\n borderWidth: 0,\n cursor: 'pointer',\n transitionProperty: 'color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n },\n groupTriggerActive: {\n color: colors.text,\n },\n chevron: {\n display: 'inline-flex',\n alignItems: 'center',\n transitionProperty: 'transform',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n },\n chevronOpen: {\n transform: 'rotate(90deg)',\n },\n item: {\n display: 'flex',\n alignItems: 'center',\n paddingTop: '6px',\n paddingBottom: '6px',\n paddingLeft: spacing.lg,\n paddingRight: spacing.md,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n fontWeight: typography.fontWeightNormal,\n color: {\n default: colors.textMuted,\n ':hover': colors.text,\n },\n backgroundColor: {\n default: 'transparent',\n ':hover': colors.bgCardHover,\n },\n borderWidth: 0,\n borderRadius: radii.sm,\n cursor: 'pointer',\n transitionProperty: 'color, background-color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n textAlign: 'left' as const,\n outlineWidth: {\n default: 0,\n ':focus-visible': 2,\n },\n outlineStyle: {\n default: 'none',\n ':focus-visible': 'solid',\n },\n outlineColor: {\n default: 'transparent',\n ':focus-visible': colors.accent,\n },\n },\n itemActive: {\n color: colors.accent,\n fontWeight: typography.fontWeightMedium,\n },\n})\n","import {createContext, useContext} from 'react'\n\nexport interface SideNavContextValue {\n activeValue: string | null\n onSelect: (value: string) => void\n expandedGroups: Set<string>\n toggleGroup: (group: string) => void\n registerItem: (value: string) => () => void\n orderRef: React.RefObject<string[]>\n}\n\nexport const SideNavContext = createContext<SideNavContextValue | null>(null)\n\nexport function useSideNav() {\n const ctx = useContext(SideNavContext)\n if (!ctx) throw new Error('SideNav compound components must be used within SideNav.Root')\n return ctx\n}\n","import {type ReactNode, useState, useCallback, useRef, useEffect} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\nimport {useControllableValue} from '../../hooks/useControllableValue'\nimport {SideNavContext, useSideNav} from './SideNavContext'\n\n// --- Root ---\n\ninterface RootProps {\n children: ReactNode\n value?: string\n defaultValue?: string\n onValueChange?: (value: string) => void\n}\n\nfunction Root({children, value: controlledValue, defaultValue, onValueChange}: RootProps) {\n const [activeValue, onSelect] = useControllableValue<string | null>(\n controlledValue,\n defaultValue ?? null,\n onValueChange\n ? (v) => {\n if (v !== null) onValueChange(v)\n }\n : undefined,\n )\n const [expandedGroups, setExpandedGroups] = useState<Set<string>>(new Set())\n const orderRef = useRef<string[]>([])\n\n const toggleGroup = useCallback((group: string) => {\n setExpandedGroups((prev) => {\n const next = new Set(prev)\n if (next.has(group)) {\n next.delete(group)\n } else {\n next.add(group)\n }\n return next\n })\n }, [])\n\n const registerItem = useCallback((value: string) => {\n if (!orderRef.current.includes(value)) {\n orderRef.current.push(value)\n }\n return () => {\n orderRef.current = orderRef.current.filter((v) => v !== value)\n }\n }, [])\n\n // Auto-expand group containing active value\n useEffect(() => {\n if (activeValue) {\n setExpandedGroups((prev) => {\n // We don't know which group it belongs to here — Group handles this\n return prev\n })\n }\n }, [activeValue])\n\n return (\n <SideNavContext.Provider\n value={{activeValue, onSelect, expandedGroups, toggleGroup, registerItem, orderRef}}\n >\n <html.nav role=\"navigation\" style={styles.root}>\n {children}\n </html.nav>\n </SideNavContext.Provider>\n )\n}\n\n// --- Group ---\n\ninterface GroupProps {\n children: ReactNode\n label: string\n groupKey?: string\n defaultExpanded?: boolean\n}\n\nfunction Group({children, label, groupKey, defaultExpanded}: GroupProps) {\n const key = groupKey ?? label\n const {expandedGroups, toggleGroup, activeValue} = useSideNav()\n const isExpanded = expandedGroups.has(key)\n const groupRef = useRef<HTMLDivElement>(null)\n\n // Auto-expand if this group contains the active item\n useEffect(() => {\n if (!activeValue || expandedGroups.has(key)) return\n const el = groupRef.current\n if (!el) return\n const activeBtn = el.querySelector(`[data-nav-value=\"${activeValue}\"]`)\n if (activeBtn) {\n toggleGroup(key)\n }\n }, [activeValue, key, expandedGroups, toggleGroup])\n\n // Expand on first render if defaultExpanded\n useEffect(() => {\n if (defaultExpanded && !expandedGroups.has(key)) {\n toggleGroup(key)\n }\n // Only run on mount\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [])\n\n const hasActiveChild = (() => {\n if (!activeValue || !groupRef.current) return false\n return !!groupRef.current.querySelector(`[data-nav-value=\"${activeValue}\"]`)\n })()\n\n return (\n <html.div ref={groupRef} style={styles.group}>\n <html.button\n type=\"button\"\n onClick={() => toggleGroup(key)}\n style={[styles.groupTrigger, hasActiveChild && styles.groupTriggerActive]}\n aria-expanded={isExpanded}\n >\n <html.span style={[styles.chevron, isExpanded && styles.chevronOpen]}>\n <svg\n width={10}\n height={10}\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth={2.5}\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n >\n <path d=\"M9 18l6-6-6-6\" />\n </svg>\n </html.span>\n {label}\n </html.button>\n {isExpanded && children}\n </html.div>\n )\n}\n\n// --- Item ---\n\ninterface ItemProps {\n value: string\n children: ReactNode\n}\n\nfunction Item({value, children}: ItemProps) {\n const {activeValue, onSelect, registerItem} = useSideNav()\n const isActive = activeValue === value\n\n useEffect(() => {\n return registerItem(value)\n }, [value, registerItem])\n\n return (\n <html.button\n type=\"button\"\n data-nav-value={value}\n onClick={() => onSelect(value)}\n style={[styles.item, isActive && styles.itemActive]}\n aria-current={isActive ? 'page' : undefined}\n >\n {children}\n </html.button>\n )\n}\n\nexport const SideNav = {\n Root,\n Group,\n Item,\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\n\nconst spin = css.keyframes({\n '0%': {transform: 'rotate(0deg)'},\n '100%': {transform: 'rotate(360deg)'},\n})\n\nexport const styles = css.create({\n root: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n },\n spinner: {\n borderRadius: '50%',\n borderStyle: 'solid',\n borderColor: colors.border,\n borderTopColor: colors.accent,\n animationName: spin,\n animationDuration: '0.6s',\n animationTimingFunction: 'linear',\n animationIterationCount: 'infinite',\n },\n sm: {\n width: 16,\n height: 16,\n borderWidth: 2,\n },\n md: {\n width: 24,\n height: 24,\n borderWidth: 2,\n },\n lg: {\n width: 40,\n height: 40,\n borderWidth: 3,\n },\n srOnly: {\n position: 'absolute',\n width: 1,\n height: 1,\n overflow: 'hidden',\n clip: 'rect(0, 0, 0, 0)',\n },\n})\n","import {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\nexport type SpinnerSize = 'sm' | 'md' | 'lg'\n\ninterface SpinnerProps {\n size?: SpinnerSize\n label?: string\n}\n\nconst sizeMap = {\n sm: styles.sm,\n md: styles.md,\n lg: styles.lg,\n} as const\n\nexport function Spinner({size = 'md', label = 'Loading'}: SpinnerProps) {\n return (\n <html.div role=\"status\" style={styles.root}>\n <html.div style={[styles.spinner, sizeMap[size]]} aria-hidden />\n <html.span style={styles.srOnly}>{label}</html.span>\n </html.div>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing} from '@duro-app/tokens/tokens/spacing.css'\n\nexport const styles = css.create({\n root: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n marginBottom: spacing.md,\n },\n error: {\n color: colors.error,\n },\n success: {\n color: colors.success,\n },\n warning: {\n color: colors.warning,\n },\n muted: {\n color: colors.textMuted,\n },\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\nexport type StatusIconName = 'x-circle' | 'check-circle' | 'check-done' | 'clock' | 'forbidden'\nexport type StatusIconVariant = 'error' | 'success' | 'warning' | 'muted'\n\nconst icons: Record<StatusIconName, ReactNode> = {\n 'x-circle': (\n <>\n <circle cx=\"12\" cy=\"12\" r=\"10\" />\n <line x1=\"15\" y1=\"9\" x2=\"9\" y2=\"15\" />\n <line x1=\"9\" y1=\"9\" x2=\"15\" y2=\"15\" />\n </>\n ),\n 'check-circle': (\n <>\n <circle cx=\"12\" cy=\"12\" r=\"10\" />\n <polyline points=\"16 10 11 15 8 12\" />\n </>\n ),\n 'check-done': (\n <>\n <path d=\"M22 11.08V12a10 10 0 1 1-5.93-9.14\" />\n <polyline points=\"22 4 12 14.01 9 11.01\" />\n </>\n ),\n clock: (\n <>\n <circle cx=\"12\" cy=\"12\" r=\"10\" />\n <polyline points=\"12 6 12 12 16 14\" />\n </>\n ),\n forbidden: (\n <>\n <circle cx=\"12\" cy=\"12\" r=\"10\" />\n <line x1=\"4.93\" y1=\"4.93\" x2=\"19.07\" y2=\"19.07\" />\n </>\n ),\n}\n\ninterface StatusIconProps {\n name: StatusIconName\n size?: number\n variant?: StatusIconVariant\n}\n\nexport function StatusIcon({name, size = 48, variant = 'muted'}: StatusIconProps) {\n return (\n <html.div style={[styles.root, styles[variant]]}>\n <svg\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth={2}\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n width={size}\n height={size}\n >\n {icons[name]}\n </svg>\n </html.div>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n // Root\n root: {\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: colors.border,\n borderRadius: radii.md,\n overflow: 'hidden',\n backgroundColor: colors.bgCard,\n fontFamily: typography.fontFamily,\n color: colors.text,\n },\n\n // Header group\n header: {\n backgroundColor: colors.bgCard,\n },\n\n // Row\n row: {\n display: 'grid',\n borderBottomWidth: 1,\n borderBottomStyle: 'solid',\n borderBottomColor: colors.border,\n },\n rowLastChild: {\n borderBottomWidth: 0,\n },\n bodyRow: {\n backgroundColor: {\n default: 'transparent',\n ':hover': colors.bgCardHover,\n },\n transitionProperty: 'background-color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n },\n\n // Header cell\n headerCell: {\n fontWeight: typography.fontWeightSemibold,\n color: colors.textMuted,\n textAlign: 'start',\n },\n\n // Body cell\n cell: {\n color: colors.text,\n display: 'flex',\n alignItems: 'center',\n },\n\n // Size: sm\n cellSm: {\n paddingTop: spacing.xs,\n paddingBottom: spacing.xs,\n paddingLeft: spacing.sm,\n paddingRight: spacing.sm,\n fontSize: typography.fontSizeXs,\n },\n // Size: md\n cellMd: {\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontSize: typography.fontSizeSm,\n },\n\n // Variant: striped (even body rows)\n stripedEven: {\n backgroundColor: {\n default: colors.bgCardHover,\n ':hover': colors.bgCardHover,\n },\n },\n\n // Variant: bordered (cells get side borders)\n borderedCell: {\n borderRightWidth: 1,\n borderRightStyle: 'solid',\n borderRightColor: colors.border,\n },\n borderedCellLast: {\n borderRightWidth: 0,\n },\n\n // Dynamic styles — simple identifier params only (StyleX constraint)\n gridColumns: (columns: number) => ({\n gridTemplateColumns: `repeat(${columns}, 1fr)`,\n }),\n})\n","import {type ReactNode, createContext, useContext, Children} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\n// --- Types ---\n\nexport type TableVariant = 'default' | 'striped' | 'bordered'\nexport type TableSize = 'sm' | 'md'\n\n// --- Context ---\n\ninterface TableContextValue {\n variant: TableVariant\n size: TableSize\n columns: number\n isHeader: boolean\n}\n\nconst TableContext = createContext<TableContextValue | null>(null)\n\nfunction useTable() {\n const ctx = useContext(TableContext)\n if (!ctx) throw new Error('Table compound components must be used within Table.Root')\n return ctx\n}\n\n// --- HeaderContext (to distinguish header vs body rowgroup) ---\n\nconst HeaderContext = createContext(false)\n\n// --- Root ---\n\ninterface RootProps {\n children: ReactNode\n variant?: TableVariant\n size?: TableSize\n columns: number\n}\n\nfunction Root({children, variant = 'default', size = 'md', columns}: RootProps) {\n return (\n <TableContext.Provider value={{variant, size, columns, isHeader: false}}>\n <html.div role=\"table\" style={styles.root}>\n {children}\n </html.div>\n </TableContext.Provider>\n )\n}\n\n// --- Header ---\n\nfunction Header({children}: {children: ReactNode}) {\n return (\n <HeaderContext.Provider value={true}>\n <html.div role=\"rowgroup\" style={styles.header}>\n {children}\n </html.div>\n </HeaderContext.Provider>\n )\n}\n\n// --- Body ---\n\nfunction Body({children}: {children: ReactNode}) {\n const {variant} = useTable()\n const childArray = Children.toArray(children)\n\n return (\n <HeaderContext.Provider value={false}>\n <html.div role=\"rowgroup\">\n {childArray.map((child, index) => {\n if (variant === 'striped') {\n return (\n <RowIndexContext.Provider key={index} value={index}>\n {child}\n </RowIndexContext.Provider>\n )\n }\n return child\n })}\n </html.div>\n </HeaderContext.Provider>\n )\n}\n\n// Row index context for striped variant\nconst RowIndexContext = createContext<number>(-1)\n\n// --- Row ---\n\nfunction Row({children}: {children: ReactNode}) {\n const {variant, columns} = useTable()\n const isHeader = useContext(HeaderContext)\n const rowIndex = useContext(RowIndexContext)\n const isEvenRow = rowIndex >= 0 && rowIndex % 2 === 1\n const childArray = Children.toArray(children)\n const isLastRow = false // handled by CSS or parent\n\n return (\n <html.div\n role=\"row\"\n style={[\n styles.row,\n styles.gridColumns(columns),\n !isHeader && styles.bodyRow,\n !isHeader && variant === 'striped' && isEvenRow && styles.stripedEven,\n ]}\n >\n {variant === 'bordered'\n ? childArray.map((child, index) => (\n <CellIndexContext.Provider key={index} value={{index, total: childArray.length}}>\n {child}\n </CellIndexContext.Provider>\n ))\n : children}\n </html.div>\n )\n}\n\n// Cell index context for bordered variant\nconst CellIndexContext = createContext<{index: number; total: number}>({\n index: 0,\n total: 0,\n})\n\n// --- HeaderCell ---\n\nfunction HeaderCell({children}: {children: ReactNode}) {\n const {size, variant} = useTable()\n const {index, total} = useContext(CellIndexContext)\n const isLast = variant === 'bordered' && index === total - 1\n\n return (\n <html.div\n role=\"columnheader\"\n style={[\n styles.headerCell,\n size === 'sm' ? styles.cellSm : styles.cellMd,\n variant === 'bordered' && styles.borderedCell,\n isLast && styles.borderedCellLast,\n ]}\n >\n {children}\n </html.div>\n )\n}\n\n// --- Cell ---\n\nfunction Cell({children}: {children: ReactNode}) {\n const {size, variant} = useTable()\n const {index, total} = useContext(CellIndexContext)\n const isLast = variant === 'bordered' && index === total - 1\n\n return (\n <html.div\n role=\"cell\"\n style={[\n styles.cell,\n size === 'sm' ? styles.cellSm : styles.cellMd,\n variant === 'bordered' && styles.borderedCell,\n isLast && styles.borderedCellLast,\n ]}\n >\n {children}\n </html.div>\n )\n}\n\n// --- Export ---\n\nexport const Table = {\n Root,\n Header,\n Body,\n Row,\n HeaderCell,\n Cell,\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n root: {\n display: 'flex',\n flexDirection: 'column',\n },\n rootVertical: {\n flexDirection: 'row',\n },\n list: {\n display: 'flex',\n flexDirection: 'row',\n borderBottomWidth: 1,\n borderBottomStyle: 'solid',\n borderBottomColor: colors.border,\n gap: spacing.xs,\n },\n listVertical: {\n flexDirection: 'column',\n borderBottomWidth: 0,\n borderRightWidth: 1,\n borderRightStyle: 'solid',\n borderRightColor: colors.border,\n gap: 0,\n },\n tab: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n fontWeight: typography.fontWeightMedium,\n color: {\n default: colors.textMuted,\n ':hover': colors.text,\n },\n backgroundColor: 'transparent',\n borderWidth: 0,\n borderBottomWidth: 2,\n borderBottomStyle: 'solid',\n borderBottomColor: 'transparent',\n cursor: 'pointer',\n transitionProperty: 'color, border-color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n outlineWidth: {\n default: 0,\n ':focus-visible': 2,\n },\n outlineStyle: {\n default: 'none',\n ':focus-visible': 'solid',\n },\n outlineColor: {\n default: 'transparent',\n ':focus-visible': colors.accent,\n },\n outlineOffset: {\n default: 0,\n ':focus-visible': -2,\n },\n },\n tabVertical: {\n justifyContent: 'flex-start',\n borderBottomWidth: 0,\n borderRightWidth: 2,\n borderRightStyle: 'solid',\n borderRightColor: 'transparent',\n },\n tabActiveHorizontal: {\n color: colors.text,\n borderBottomColor: colors.accent,\n },\n tabActiveVertical: {\n color: colors.text,\n borderRightColor: colors.accent,\n },\n tabDisabled: {\n opacity: 0.5,\n cursor: 'not-allowed',\n color: colors.textMuted,\n },\n panel: {\n paddingTop: spacing.md,\n },\n panelVertical: {\n paddingTop: 0,\n paddingLeft: spacing.md,\n },\n})\n","import {createContext, useContext} from 'react'\n\nexport type Orientation = 'horizontal' | 'vertical'\n\nexport interface TabsContextValue {\n activeValue: string | null\n onSelect: (value: string) => void\n orientation: Orientation\n registerTab: (value: string, disabled: boolean) => () => void\n tabsRef: React.RefObject<Map<string, boolean>>\n orderRef: React.RefObject<string[]>\n}\n\nexport const TabsContext = createContext<TabsContextValue | null>(null)\n\nexport function useTabs() {\n const ctx = useContext(TabsContext)\n if (!ctx) throw new Error('Tabs compound components must be used within Tabs.Root')\n return ctx\n}\n","import {useCallback, useRef} from 'react'\nimport {useControllableValue} from '../../hooks/useControllableValue'\nimport type {Orientation, TabsContextValue} from './TabsContext'\n\ninterface UseTabsRootOptions {\n value?: string\n defaultValue?: string\n onValueChange?: (value: string) => void\n orientation?: Orientation\n}\n\nexport function useTabsRoot({\n value: controlledValue,\n defaultValue,\n onValueChange,\n orientation = 'horizontal',\n}: UseTabsRootOptions): TabsContextValue {\n const [activeValue, onSelect] = useControllableValue<string | null>(\n controlledValue,\n defaultValue ?? null,\n onValueChange\n ? (v) => {\n if (v !== null) onValueChange(v)\n }\n : undefined,\n )\n const tabsRef = useRef(new Map<string, boolean>())\n const orderRef = useRef<string[]>([])\n\n const registerTab = useCallback((value: string, disabled: boolean) => {\n tabsRef.current.set(value, disabled)\n if (!orderRef.current.includes(value)) {\n orderRef.current.push(value)\n }\n return () => {\n tabsRef.current.delete(value)\n orderRef.current = orderRef.current.filter((v) => v !== value)\n }\n }, [])\n\n return {activeValue, onSelect, orientation, registerTab, tabsRef, orderRef}\n}\n","import {type ReactNode, useRef, useId, useEffect} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\nimport {TabsContext, useTabs} from './TabsContext'\nimport {useTabsRoot} from './useTabsRoot'\n\n// --- Root ---\n\ninterface RootProps {\n children: ReactNode\n value?: string\n defaultValue?: string\n onValueChange?: (value: string) => void\n orientation?: 'horizontal' | 'vertical'\n}\n\nfunction Root({\n children,\n value,\n defaultValue,\n onValueChange,\n orientation = 'horizontal',\n}: RootProps) {\n const ctx = useTabsRoot({value, defaultValue, onValueChange, orientation})\n\n return (\n <TabsContext.Provider value={ctx}>\n <html.div style={[styles.root, orientation === 'vertical' && styles.rootVertical]}>\n {children}\n </html.div>\n </TabsContext.Provider>\n )\n}\n\n// --- List ---\n\ninterface ListProps {\n children: ReactNode\n}\n\nfunction List({children}: ListProps) {\n const {orientation, activeValue, onSelect, tabsRef, orderRef} = useTabs()\n const listRef = useRef<HTMLDivElement>(null)\n\n useEffect(() => {\n const el = listRef.current\n if (!el) return\n\n function handleKeyDown(this: HTMLElement, e: KeyboardEvent) {\n const order = orderRef.current\n const tabs = tabsRef.current\n if (order.length === 0) return\n const listEl = this\n\n const prevKey = orientation === 'horizontal' ? 'ArrowLeft' : 'ArrowUp'\n const nextKey = orientation === 'horizontal' ? 'ArrowRight' : 'ArrowDown'\n\n let targetValue: string | null = null\n\n switch (e.key) {\n case nextKey: {\n e.preventDefault()\n const currentIdx = activeValue ? order.indexOf(activeValue) : -1\n for (let i = 1; i <= order.length; i++) {\n const idx = (currentIdx + i) % order.length\n const val = order[idx]\n if (!tabs.get(val)) {\n targetValue = val\n break\n }\n }\n break\n }\n case prevKey: {\n e.preventDefault()\n const currentIdx = activeValue ? order.indexOf(activeValue) : 0\n for (let i = 1; i <= order.length; i++) {\n const idx = (currentIdx - i + order.length) % order.length\n const val = order[idx]\n if (!tabs.get(val)) {\n targetValue = val\n break\n }\n }\n break\n }\n case 'Home': {\n e.preventDefault()\n for (const val of order) {\n if (!tabs.get(val)) {\n targetValue = val\n break\n }\n }\n break\n }\n case 'End': {\n e.preventDefault()\n for (let i = order.length - 1; i >= 0; i--) {\n if (!tabs.get(order[i])) {\n targetValue = order[i]\n break\n }\n }\n break\n }\n }\n\n if (targetValue) {\n onSelect(targetValue)\n // Focus the newly activated tab button\n const tabEl = listEl.querySelector(\n `[data-tab-value=\"${targetValue}\"]`,\n ) as HTMLElement | null\n tabEl?.focus()\n }\n }\n\n el.addEventListener('keydown', handleKeyDown)\n return () => el.removeEventListener('keydown', handleKeyDown)\n }, [orientation, activeValue, onSelect, tabsRef, orderRef])\n\n return (\n <html.div\n ref={listRef}\n role=\"tablist\"\n aria-orientation={orientation}\n style={[styles.list, orientation === 'vertical' && styles.listVertical]}\n >\n {children}\n </html.div>\n )\n}\n\n// --- Tab ---\n\ninterface TabProps {\n value: string\n disabled?: boolean\n children: ReactNode\n}\n\nfunction Tab({value, disabled = false, children}: TabProps) {\n const {activeValue, onSelect, orientation, registerTab} = useTabs()\n const isActive = activeValue === value\n const tabId = useId()\n const panelId = `${tabId}-panel`\n\n useEffect(() => {\n return registerTab(value, disabled)\n }, [value, disabled, registerTab])\n\n const handleClick = () => {\n if (!disabled) {\n onSelect(value)\n }\n }\n\n return (\n <html.button\n type=\"button\"\n role=\"tab\"\n id={tabId}\n aria-selected={isActive}\n aria-controls={panelId}\n aria-disabled={disabled || undefined}\n data-tab-value={value}\n tabIndex={isActive ? 0 : -1}\n onClick={handleClick}\n style={[\n styles.tab,\n orientation === 'vertical' && styles.tabVertical,\n isActive &&\n (orientation === 'vertical' ? styles.tabActiveVertical : styles.tabActiveHorizontal),\n disabled && styles.tabDisabled,\n ]}\n >\n {children}\n </html.button>\n )\n}\n\n// --- Panel ---\n\ninterface PanelProps {\n value: string\n children: ReactNode\n}\n\nfunction Panel({value, children}: PanelProps) {\n const {activeValue, orientation} = useTabs()\n\n if (activeValue !== value) return null\n\n return (\n <html.div\n role=\"tabpanel\"\n style={[styles.panel, orientation === 'vertical' && styles.panelVertical]}\n >\n {children}\n </html.div>\n )\n}\n\nexport const Tabs = {\n Root,\n List,\n Tab,\n Panel,\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n base: {\n width: '100%',\n paddingTop: spacing.sm,\n paddingBottom: spacing.sm,\n paddingLeft: spacing.md,\n paddingRight: spacing.md,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeSm,\n lineHeight: typography.lineHeight,\n color: colors.text,\n backgroundColor: colors.bg,\n borderWidth: 1,\n borderStyle: 'solid',\n borderRadius: radii.sm,\n resize: 'vertical' as const,\n transitionProperty: 'border-color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n outlineWidth: {\n default: 0,\n ':focus-visible': 2,\n },\n outlineStyle: {\n default: 'none',\n ':focus-visible': 'solid',\n },\n outlineColor: {\n default: 'transparent',\n ':focus-visible': colors.accent,\n },\n outlineOffset: {\n default: 0,\n ':focus-visible': 1,\n },\n },\n default: {\n borderColor: {\n default: colors.border,\n ':hover': colors.textMuted,\n ':focus': colors.accent,\n },\n },\n error: {\n borderColor: {\n default: colors.error,\n ':focus': colors.error,\n },\n },\n})\n","import {html} from 'react-strict-dom'\nimport {useFieldContext} from '../Field/FieldContext'\nimport {styles} from './styles.css'\n\nexport type TextareaVariant = 'default' | 'error'\n\ninterface TextareaProps {\n variant?: TextareaVariant\n name?: string\n placeholder?: string\n required?: boolean\n rows?: number\n value?: string\n defaultValue?: string\n disabled?: boolean\n onChange?: (e: React.ChangeEvent<HTMLTextAreaElement>) => void\n}\n\nexport function Textarea({\n variant = 'default',\n name,\n placeholder,\n required,\n rows = 3,\n value,\n defaultValue,\n disabled,\n onChange,\n}: TextareaProps) {\n const ctx = useFieldContext()\n\n return (\n <html.textarea\n id={ctx?.controlId}\n name={name}\n placeholder={placeholder}\n required={required}\n rows={rows}\n value={value}\n defaultValue={defaultValue}\n disabled={disabled}\n aria-describedby={\n ctx ? `${ctx.descriptionId} ${ctx.invalid ? ctx.errorId : ''}`.trim() : undefined\n }\n aria-invalid={ctx?.invalid || variant === 'error' || undefined}\n onChange={onChange}\n style={[styles.base, styles[variant]]}\n />\n )\n}\n","const e = {\n bg: \"var(--bg-xqkwqtp)\",\n bgCard: \"var(--bgCard-xj2l5r)\",\n bgCardHover: \"var(--bgCardHover-xlxk7vw)\",\n text: \"var(--text-xlpbogt)\",\n textMuted: \"var(--textMuted-x651nu9)\",\n accent: \"var(--accent-xw7wp3v)\",\n accentHover: \"var(--accentHover-x18fqoz)\",\n accentContrast: \"var(--accentContrast-x3gzxyp)\",\n border: \"var(--border-x1drj1pb)\",\n error: \"var(--error-x13gdhh0)\",\n errorHover: \"var(--errorHover-x7eyu03)\",\n errorBg: \"var(--errorBg-xrl8836)\",\n errorBorder: \"var(--errorBorder-x1a6pjl)\",\n errorText: \"var(--errorText-xf51nwe)\",\n errorContrast: \"var(--errorContrast-x1lvjkah)\",\n success: \"var(--success-x197pe5n)\",\n successBg: \"var(--successBg-xzjukav)\",\n successBorder: \"var(--successBorder-x1my3ygc)\",\n successText: \"var(--successText-x46dg9e)\",\n warning: \"var(--warning-x1gq0pyw)\",\n warningBg: \"var(--warningBg-xtnxqss)\",\n warningBorder: \"var(--warningBorder-x1ev2mr5)\",\n warningText: \"var(--warningText-x1lgjghx)\",\n infoBg: \"var(--infoBg-xho8jir)\",\n infoBorder: \"var(--infoBorder-xnevk3x)\",\n infoText: \"var(--infoText-x19pseus)\",\n __varGroupHash__: \"xjvd03b\"\n}, t = {\n xs: \"var(--xs-xxfyjsd)\",\n sm: \"var(--sm-xbh8y7f)\",\n ms: \"var(--ms-x13y09zs)\",\n md: \"var(--md-x3pkb85)\",\n lg: \"var(--lg-x34mutn)\",\n xl: \"var(--xl-xttpygj)\",\n xxl: \"var(--xxl-xbe9eha)\",\n xxxl: \"var(--xxxl-xroalp5)\",\n __varGroupHash__: \"x6uc9q\"\n}, n = {\n sm: \"var(--sm-x1bhtfs5)\",\n md: \"var(--md-xx2g89g)\",\n lg: \"var(--lg-xwd56yl)\",\n full: \"var(--full-x9vxdtd)\",\n __varGroupHash__: \"xw3ffwm\"\n}, i = {\n stackXs: \"var(--stackXs-x1qfrfo2)\",\n stackSm: \"var(--stackSm-x2rk1ut)\",\n stackMd: \"var(--stackMd-xhblkt4)\",\n stackLg: \"var(--stackLg-xeue779)\",\n stackXl: \"var(--stackXl-x7sbbgu)\",\n inlineXs: \"var(--inlineXs-xq4tp4f)\",\n inlineSm: \"var(--inlineSm-x2o8bbf)\",\n inlineMd: \"var(--inlineMd-x1oalkxi)\",\n inlineLg: \"var(--inlineLg-xz69o43)\",\n containerSm: \"var(--containerSm-x3nosus)\",\n containerMd: \"var(--containerMd-x170dvin)\",\n containerLg: \"var(--containerLg-x1n6aasq)\",\n __varGroupHash__: \"x16nfoyr\"\n}, r = {\n fontFamily: \"var(--fontFamily-xvrmnat)\",\n fontFamilyMono: \"var(--fontFamilyMono-x1bzqfky)\",\n fontSizeXs: \"var(--fontSizeXs-x1w5m325)\",\n fontSizeSm: \"var(--fontSizeSm-x1bjjs4u)\",\n fontSizeMd: \"var(--fontSizeMd-xq8d99q)\",\n fontSizeLg: \"var(--fontSizeLg-x18ngplw)\",\n fontSizeXl: \"var(--fontSizeXl-x1b1mqsu)\",\n fontSizeHeading: \"var(--fontSizeHeading-x1stydh2)\",\n fontWeightNormal: \"var(--fontWeightNormal-x1y1cayu)\",\n fontWeightMedium: \"var(--fontWeightMedium-xaw13ft)\",\n fontWeightSemibold: \"var(--fontWeightSemibold-xg6c7xe)\",\n fontWeightBold: \"var(--fontWeightBold-x1pjkvwg)\",\n lineHeight: \"var(--lineHeight-x1gubzd5)\",\n __varGroupHash__: \"xs62swl\"\n}, a = {\n fontSize1: \"var(--fontSize1-xx27tux)\",\n fontSize2: \"var(--fontSize2-x5hag8h)\",\n fontSize3: \"var(--fontSize3-x1mf6j39)\",\n fontSize4: \"var(--fontSize4-xh0hch2)\",\n fontSize5: \"var(--fontSize5-xcllv62)\",\n fontSize6: \"var(--fontSize6-xo5veds)\",\n fontSize7: \"var(--fontSize7-x1j85tz8)\",\n fontSize8: \"var(--fontSize8-x17zhits)\",\n fontSize9: \"var(--fontSize9-xveysf7)\",\n lineHeight1: \"var(--lineHeight1-x17o1wol)\",\n lineHeight2: \"var(--lineHeight2-xinpx5n)\",\n lineHeight3: \"var(--lineHeight3-x1163vpm)\",\n lineHeight4: \"var(--lineHeight4-x1y0jdbp)\",\n lineHeight5: \"var(--lineHeight5-xjln4cz)\",\n lineHeight6: \"var(--lineHeight6-x1h1b5wo)\",\n lineHeight7: \"var(--lineHeight7-xx3gx0p)\",\n lineHeight8: \"var(--lineHeight8-xk1f09j)\",\n lineHeight9: \"var(--lineHeight9-xshcxhh)\",\n displaySm: \"var(--displaySm-x5inqzv)\",\n displayMd: \"var(--displayMd-x1oektom)\",\n displayLg: \"var(--displayLg-x6qsr1u)\",\n letterSpacingTight: \"var(--letterSpacingTight-xmavxfk)\",\n letterSpacingNormal: \"var(--letterSpacingNormal-x1ih41v1)\",\n letterSpacingWide: \"var(--letterSpacingWide-xt8z9rj)\",\n __varGroupHash__: \"x4cj49w\"\n}, o = {\n bodySm: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-x1hn3ytp\",\n \"lineHeight-kLWn49\": \"lineHeight-xzs5d81\",\n \"fontWeight-k63SB2\": \"fontWeight-xrec02b\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-x2e73ve\",\n $$css: \"tokens/type-presets.css.ts:6\"\n },\n bodyMd: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-xfzcsg9\",\n \"lineHeight-kLWn49\": \"lineHeight-x80sjjd\",\n \"fontWeight-k63SB2\": \"fontWeight-xrec02b\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-x2e73ve\",\n $$css: \"tokens/type-presets.css.ts:13\"\n },\n bodyLg: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-x1kws70c\",\n \"lineHeight-kLWn49\": \"lineHeight-x1487en2\",\n \"fontWeight-k63SB2\": \"fontWeight-xrec02b\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-x2e73ve\",\n $$css: \"tokens/type-presets.css.ts:20\"\n },\n caption: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-x19zw8p8\",\n \"lineHeight-kLWn49\": \"lineHeight-xsnwo96\",\n \"fontWeight-k63SB2\": \"fontWeight-xrec02b\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-x121swot\",\n $$css: \"tokens/type-presets.css.ts:29\"\n },\n label: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-x1hn3ytp\",\n \"lineHeight-kLWn49\": \"lineHeight-xzs5d81\",\n \"fontWeight-k63SB2\": \"fontWeight-x120ksxs\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-x2e73ve\",\n $$css: \"tokens/type-presets.css.ts:36\"\n },\n code: {\n \"fontFamily-kMv6JI\": \"fontFamily-x1kygxdj\",\n \"fontSize-kGuDYH\": \"fontSize-x1hn3ytp\",\n \"lineHeight-kLWn49\": \"lineHeight-xzs5d81\",\n \"fontWeight-k63SB2\": \"fontWeight-xrec02b\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-x2e73ve\",\n $$css: \"tokens/type-presets.css.ts:43\"\n },\n overline: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-x19zw8p8\",\n \"lineHeight-kLWn49\": \"lineHeight-xsnwo96\",\n \"fontWeight-k63SB2\": \"fontWeight-x1x12jc5\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-x121swot\",\n \"textTransform-kP9fke\": \"textTransform-xtvhhri\",\n $$css: \"tokens/type-presets.css.ts:50\"\n },\n headingSm: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-xtv95mj\",\n \"lineHeight-kLWn49\": \"lineHeight-xyb71hx\",\n \"fontWeight-k63SB2\": \"fontWeight-x1x12jc5\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-xql2p2a\",\n $$css: \"tokens/type-presets.css.ts:60\"\n },\n headingMd: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-x1qndi8g\",\n \"lineHeight-kLWn49\": \"lineHeight-x17ovj3u\",\n \"fontWeight-k63SB2\": \"fontWeight-x1x12jc5\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-xql2p2a\",\n $$css: \"tokens/type-presets.css.ts:67\"\n },\n headingLg: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-xo0rcgw\",\n \"lineHeight-kLWn49\": \"lineHeight-x18micsl\",\n \"fontWeight-k63SB2\": \"fontWeight-xhkckuk\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-xql2p2a\",\n $$css: \"tokens/type-presets.css.ts:74\"\n },\n headingXl: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-x6ugw34\",\n \"lineHeight-kLWn49\": \"lineHeight-x1f79cfb\",\n \"fontWeight-k63SB2\": \"fontWeight-xhkckuk\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-xql2p2a\",\n $$css: \"tokens/type-presets.css.ts:81\"\n },\n displaySm: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-x1lwaixd\",\n \"lineHeight-kLWn49\": \"lineHeight-x1u7k74\",\n \"fontWeight-k63SB2\": \"fontWeight-xhkckuk\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-xql2p2a\",\n $$css: \"tokens/type-presets.css.ts:90\"\n },\n displayMd: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-xrqn33v\",\n \"lineHeight-kLWn49\": \"lineHeight-x1uo3zyz\",\n \"fontWeight-k63SB2\": \"fontWeight-xhkckuk\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-xql2p2a\",\n $$css: \"tokens/type-presets.css.ts:97\"\n },\n displayLg: {\n \"fontFamily-kMv6JI\": \"fontFamily-xce2pww\",\n \"fontSize-kGuDYH\": \"fontSize-x1s08cw3\",\n \"lineHeight-kLWn49\": \"lineHeight-x1159mfc\",\n \"fontWeight-k63SB2\": \"fontWeight-xhkckuk\",\n \"letterSpacing-kb6lSQ\": \"letterSpacing-xql2p2a\",\n $$css: \"tokens/type-presets.css.ts:104\"\n }\n}, s = {\n sm: \"var(--sm-x17hhtln)\",\n md: \"var(--md-x1oyt0aw)\",\n lg: \"var(--lg-x1mxd62i)\",\n __varGroupHash__: \"x13v825q\"\n}, x = {\n xjvd03b: \"x18itf25 xjvd03b\",\n $$css: !0\n}, l = {\n x13v825q: \"xv9ibj0 x13v825q\",\n $$css: !0\n}, g = {\n xjvd03b: \"x1qgt5a2 xjvd03b\",\n $$css: !0\n}, c = {\n x13v825q: \"x15e39jv x13v825q\",\n $$css: !0\n};\nexport {\n e as colors,\n c as highContrastShadows,\n g as highContrastTheme,\n i as layoutSpacing,\n l as lightShadows,\n x as lightTheme,\n n as radii,\n s as shadows,\n t as spacing,\n o as typePresets,\n a as typeScale,\n r as typography\n};\n//# sourceMappingURL=index.js.map\n","import type {ReactNode} from 'react'\nimport {css, html} from 'react-strict-dom'\nimport {lightTheme, lightShadows, highContrastTheme, highContrastShadows} from '@duro-app/tokens'\n\nexport type ThemeName = 'dark' | 'light' | 'high-contrast'\n\ninterface ThemeProviderProps {\n theme?: ThemeName\n children: ReactNode\n}\n\nconst themeMap: Partial<Record<ThemeName, readonly [typeof lightTheme, typeof lightShadows]>> = {\n light: [lightTheme, lightShadows],\n 'high-contrast': [highContrastTheme, highContrastShadows],\n}\n\nconst styles = css.create({\n root: {\n display: 'contents',\n },\n})\n\n// react-strict-dom's style prop rejects Theme<VarGroup<{named keys}>> because the\n// concrete VarGroup lacks the generic index signature. This is a known typing gap.\ntype DivStyle = Parameters<typeof html.div>[0]['style']\n\nexport function ThemeProvider({theme = 'dark', children}: ThemeProviderProps) {\n const overrides = themeMap[theme]\n const themeStyles = [overrides?.[0], overrides?.[1], styles.root] as DivStyle\n\n return <html.div style={themeStyles}>{children}</html.div>\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\n\nexport const styles = css.create({\n // Colors\n default: {\n color: colors.text,\n },\n muted: {\n color: colors.textMuted,\n },\n accent: {\n color: colors.accent,\n },\n error: {\n color: colors.errorText,\n },\n success: {\n color: colors.successText,\n },\n warning: {\n color: colors.warningText,\n },\n\n // Weight overrides\n weightNormal: {\n fontWeight: typography.fontWeightNormal,\n },\n weightMedium: {\n fontWeight: typography.fontWeightMedium,\n },\n weightSemibold: {\n fontWeight: typography.fontWeightSemibold,\n },\n weightBold: {\n fontWeight: typography.fontWeightBold,\n },\n\n // Alignment\n alignStart: {\n textAlign: 'start',\n },\n alignCenter: {\n textAlign: 'center',\n },\n alignEnd: {\n textAlign: 'end',\n },\n\n // Truncate\n truncate: {\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n },\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {typePresets} from '@duro-app/tokens/tokens/type-presets.css'\nimport {styles} from './styles.css'\n\nexport type TextVariant = 'bodySm' | 'bodyMd' | 'bodyLg' | 'caption' | 'label' | 'code' | 'overline'\nexport type TextColor = 'default' | 'muted' | 'accent' | 'error' | 'success' | 'warning'\n\ninterface TextProps {\n variant?: TextVariant\n color?: TextColor\n weight?: 'normal' | 'medium' | 'semibold' | 'bold'\n align?: 'start' | 'center' | 'end'\n truncate?: boolean\n as?: 'span' | 'p' | 'div'\n children: ReactNode\n}\n\nconst weightMap = {\n normal: styles.weightNormal,\n medium: styles.weightMedium,\n semibold: styles.weightSemibold,\n bold: styles.weightBold,\n} as const\n\nconst alignMap = {\n start: styles.alignStart,\n center: styles.alignCenter,\n end: styles.alignEnd,\n} as const\n\nexport function Text({\n variant = 'bodyMd',\n color = 'default',\n weight,\n align,\n truncate,\n as = 'span',\n children,\n}: TextProps) {\n const style = [\n typePresets[variant],\n styles[color],\n weight && weightMap[weight],\n align && alignMap[align],\n truncate && styles.truncate,\n ]\n\n if (as === 'p') return <html.p style={style}>{children}</html.p>\n if (as === 'div') return <html.div style={style}>{children}</html.div>\n return <html.span style={style}>{children}</html.span>\n}\n","import {css} from 'react-strict-dom'\nimport {colors} from '@duro-app/tokens/tokens/colors.css'\nimport {spacing, radii} from '@duro-app/tokens/tokens/spacing.css'\nimport {typography} from '@duro-app/tokens/tokens/typography.css'\nimport {shadows} from '@duro-app/tokens/tokens/shadows.css'\n\nexport const styles = css.create({\n root: {\n position: 'relative',\n display: 'inline-flex',\n },\n popup: {\n position: 'absolute',\n zIndex: 50,\n paddingTop: spacing.xs,\n paddingBottom: spacing.xs,\n paddingLeft: spacing.sm,\n paddingRight: spacing.sm,\n backgroundColor: colors.bgCard,\n color: colors.text,\n fontFamily: typography.fontFamily,\n fontSize: typography.fontSizeXs,\n lineHeight: typography.lineHeight,\n borderRadius: radii.sm,\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: colors.border,\n boxShadow: shadows.md,\n whiteSpace: 'nowrap',\n pointerEvents: 'none',\n },\n top: {\n bottom: '100%',\n left: '50%',\n transform: 'translateX(-50%)',\n marginBottom: spacing.xs,\n },\n bottom: {\n top: '100%',\n left: '50%',\n transform: 'translateX(-50%)',\n marginTop: spacing.xs,\n },\n left: {\n right: '100%',\n top: '50%',\n transform: 'translateY(-50%)',\n marginRight: spacing.xs,\n },\n right: {\n left: '100%',\n top: '50%',\n transform: 'translateY(-50%)',\n marginLeft: spacing.xs,\n },\n})\n","import {\n type ReactNode,\n createContext,\n useContext,\n useState,\n useRef,\n useCallback,\n useId,\n} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\n// --- Context ---\n\ntype Placement = 'top' | 'bottom' | 'left' | 'right'\n\ninterface TooltipContextValue {\n open: boolean\n show: () => void\n hide: () => void\n tooltipId: string\n placement: Placement\n}\n\nconst TooltipContext = createContext<TooltipContextValue | null>(null)\n\nfunction useTooltip() {\n const ctx = useContext(TooltipContext)\n if (!ctx) throw new Error('Tooltip compound components must be used within Tooltip.Root')\n return ctx\n}\n\n// --- Root ---\n\ninterface RootProps {\n children: ReactNode\n content: ReactNode\n placement?: Placement\n delay?: number\n}\n\nfunction Root({children, content, placement = 'top', delay = 300}: RootProps) {\n const [open, setOpen] = useState(false)\n const tooltipId = useId()\n const timerRef = useRef<ReturnType<typeof setTimeout> | null>(null)\n\n const show = useCallback(() => {\n if (timerRef.current) clearTimeout(timerRef.current)\n timerRef.current = setTimeout(() => setOpen(true), delay)\n }, [delay])\n\n const hide = useCallback(() => {\n if (timerRef.current) clearTimeout(timerRef.current)\n timerRef.current = null\n setOpen(false)\n }, [])\n\n return (\n <TooltipContext.Provider value={{open, show, hide, tooltipId, placement}}>\n <html.div style={styles.root}>\n {children}\n {open && (\n <html.div id={tooltipId} role=\"tooltip\" style={[styles.popup, styles[placement]]}>\n {content}\n </html.div>\n )}\n </html.div>\n </TooltipContext.Provider>\n )\n}\n\n// --- Trigger ---\n\ninterface TriggerProps {\n children: ReactNode\n}\n\nfunction Trigger({children}: TriggerProps) {\n const {open, show, hide, tooltipId} = useTooltip()\n\n return (\n <html.div\n onPointerEnter={show}\n onPointerLeave={hide}\n onFocus={show}\n onBlur={hide}\n aria-describedby={open ? tooltipId : undefined}\n >\n {children}\n </html.div>\n )\n}\n\nexport const Tooltip = {\n Root,\n Trigger,\n}\n","import {css} from 'react-strict-dom'\nimport {spacing} from '@duro-app/tokens/tokens/spacing.css'\n\nexport const styles = css.create({\n base: {\n display: 'flex',\n flexDirection: 'column',\n },\n alignStart: {alignItems: 'flex-start'},\n alignCenter: {alignItems: 'center'},\n alignEnd: {alignItems: 'flex-end'},\n alignStretch: {alignItems: 'stretch'},\n gapXs: {gap: spacing.xs},\n gapSm: {gap: spacing.sm},\n gapMs: {gap: spacing.ms},\n gapMd: {gap: spacing.md},\n gapLg: {gap: spacing.lg},\n gapXl: {gap: spacing.xl},\n gapXxl: {gap: spacing.xxl},\n gapXxxl: {gap: spacing.xxxl},\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\n\nexport type SpacingKey = 'xs' | 'sm' | 'ms' | 'md' | 'lg' | 'xl' | 'xxl' | 'xxxl'\n\ninterface StackProps {\n gap?: SpacingKey\n align?: 'start' | 'center' | 'end' | 'stretch'\n children: ReactNode\n}\n\nconst gapMap = {\n xs: styles.gapXs,\n sm: styles.gapSm,\n ms: styles.gapMs,\n md: styles.gapMd,\n lg: styles.gapLg,\n xl: styles.gapXl,\n xxl: styles.gapXxl,\n xxxl: styles.gapXxxl,\n} as const\n\nconst alignMap = {\n start: styles.alignStart,\n center: styles.alignCenter,\n end: styles.alignEnd,\n stretch: styles.alignStretch,\n} as const\n\nexport function Stack({gap = 'md', align = 'stretch', children}: StackProps) {\n return (\n <html.div style={[styles.base, gapMap[gap], alignMap[align]]}>\n {children}\n </html.div>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {spacing} from '@duro-app/tokens/tokens/spacing.css'\n\nexport const styles = css.create({\n base: {\n display: 'flex',\n flexDirection: 'row',\n flexWrap: 'nowrap',\n },\n alignStart: {alignItems: 'flex-start'},\n alignCenter: {alignItems: 'center'},\n alignEnd: {alignItems: 'flex-end'},\n alignBaseline: {alignItems: 'baseline'},\n alignStretch: {alignItems: 'stretch'},\n justifyStart: {justifyContent: 'flex-start'},\n justifyCenter: {justifyContent: 'center'},\n justifyEnd: {justifyContent: 'flex-end'},\n justifyBetween: {justifyContent: 'space-between'},\n gapXs: {gap: spacing.xs},\n gapSm: {gap: spacing.sm},\n gapMs: {gap: spacing.ms},\n gapMd: {gap: spacing.md},\n gapLg: {gap: spacing.lg},\n gapXl: {gap: spacing.xl},\n gapXxl: {gap: spacing.xxl},\n gapXxxl: {gap: spacing.xxxl},\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\nimport type {SpacingKey} from '../Stack/Stack'\n\ninterface InlineProps {\n gap?: SpacingKey\n align?: 'start' | 'center' | 'end' | 'baseline' | 'stretch'\n justify?: 'start' | 'center' | 'end' | 'between'\n children: ReactNode\n}\n\nconst gapMap = {\n xs: styles.gapXs,\n sm: styles.gapSm,\n ms: styles.gapMs,\n md: styles.gapMd,\n lg: styles.gapLg,\n xl: styles.gapXl,\n xxl: styles.gapXxl,\n xxxl: styles.gapXxxl,\n} as const\n\nconst alignMap = {\n start: styles.alignStart,\n center: styles.alignCenter,\n end: styles.alignEnd,\n baseline: styles.alignBaseline,\n stretch: styles.alignStretch,\n} as const\n\nconst justifyMap = {\n start: styles.justifyStart,\n center: styles.justifyCenter,\n end: styles.justifyEnd,\n between: styles.justifyBetween,\n} as const\n\nexport function Inline({\n gap = 'sm',\n align = 'center',\n justify = 'start',\n children,\n}: InlineProps) {\n return (\n <html.div style={[styles.base, gapMap[gap], alignMap[align], justifyMap[justify]]}>\n {children}\n </html.div>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {spacing} from '@duro-app/tokens/tokens/spacing.css'\n\nexport const styles = css.create({\n base: {\n display: 'flex',\n flexDirection: 'row',\n flexWrap: 'wrap',\n },\n alignStart: {alignItems: 'flex-start'},\n alignCenter: {alignItems: 'center'},\n alignEnd: {alignItems: 'flex-end'},\n justifyStart: {justifyContent: 'flex-start'},\n justifyCenter: {justifyContent: 'center'},\n justifyEnd: {justifyContent: 'flex-end'},\n justifyBetween: {justifyContent: 'space-between'},\n gapXs: {gap: spacing.xs},\n gapSm: {gap: spacing.sm},\n gapMs: {gap: spacing.ms},\n gapMd: {gap: spacing.md},\n gapLg: {gap: spacing.lg},\n gapXl: {gap: spacing.xl},\n gapXxl: {gap: spacing.xxl},\n gapXxxl: {gap: spacing.xxxl},\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\nimport type {SpacingKey} from '../Stack/Stack'\n\ninterface ClusterProps {\n gap?: SpacingKey\n align?: 'start' | 'center' | 'end'\n justify?: 'start' | 'center' | 'end' | 'between'\n children: ReactNode\n}\n\nconst gapMap = {\n xs: styles.gapXs,\n sm: styles.gapSm,\n ms: styles.gapMs,\n md: styles.gapMd,\n lg: styles.gapLg,\n xl: styles.gapXl,\n xxl: styles.gapXxl,\n xxxl: styles.gapXxxl,\n} as const\n\nconst alignMap = {\n start: styles.alignStart,\n center: styles.alignCenter,\n end: styles.alignEnd,\n} as const\n\nconst justifyMap = {\n start: styles.justifyStart,\n center: styles.justifyCenter,\n end: styles.justifyEnd,\n between: styles.justifyBetween,\n} as const\n\nexport function Cluster({\n gap = 'sm',\n align = 'start',\n justify = 'start',\n children,\n}: ClusterProps) {\n return (\n <html.div style={[styles.base, gapMap[gap], alignMap[align], justifyMap[justify]]}>\n {children}\n </html.div>\n )\n}\n","import {css} from 'react-strict-dom'\nimport {spacing} from '@duro-app/tokens/tokens/spacing.css'\n\nexport const styles = css.create({\n base: {\n display: 'grid',\n },\n col1: {gridTemplateColumns: '1fr'},\n col2: {gridTemplateColumns: 'repeat(2, 1fr)'},\n col3: {gridTemplateColumns: 'repeat(3, 1fr)'},\n col4: {gridTemplateColumns: 'repeat(4, 1fr)'},\n col5: {gridTemplateColumns: 'repeat(5, 1fr)'},\n col6: {gridTemplateColumns: 'repeat(6, 1fr)'},\n autoFit: (minWidth: string) => ({\n gridTemplateColumns: `repeat(auto-fit, minmax(${minWidth}, 1fr))`,\n }),\n gapXs: {gap: spacing.xs},\n gapSm: {gap: spacing.sm},\n gapMs: {gap: spacing.ms},\n gapMd: {gap: spacing.md},\n gapLg: {gap: spacing.lg},\n gapXl: {gap: spacing.xl},\n gapXxl: {gap: spacing.xxl},\n gapXxxl: {gap: spacing.xxxl},\n})\n","import type {ReactNode} from 'react'\nimport {html} from 'react-strict-dom'\nimport {styles} from './styles.css'\nimport type {SpacingKey} from '../Stack/Stack'\n\ninterface GridProps {\n gap?: SpacingKey\n columns?: 1 | 2 | 3 | 4 | 5 | 6\n minColumnWidth?: string\n children: ReactNode\n}\n\nconst gapMap = {\n xs: styles.gapXs,\n sm: styles.gapSm,\n ms: styles.gapMs,\n md: styles.gapMd,\n lg: styles.gapLg,\n xl: styles.gapXl,\n xxl: styles.gapXxl,\n xxxl: styles.gapXxxl,\n} as const\n\nconst columnsMap = {\n 1: styles.col1,\n 2: styles.col2,\n 3: styles.col3,\n 4: styles.col4,\n 5: styles.col5,\n 6: styles.col6,\n} as const\n\nexport function Grid({gap = 'md', columns, minColumnWidth, children}: GridProps) {\n const columnStyle = minColumnWidth\n ? styles.autoFit(minColumnWidth)\n : columns\n ? columnsMap[columns]\n : undefined\n\n return (\n <html.div style={[styles.base, gapMap[gap], columnStyle]}>\n {children}\n </html.div>\n )\n}\n","import {useRef, useState, useEffect} from 'react'\n\nexport type ContainerSize = 'compact' | 'default' | 'spacious'\n\ninterface UseContainerQueryOptions {\n compactBelow?: number\n spaciousAbove?: number\n}\n\nexport function useContainerQuery<T extends HTMLElement = HTMLElement>(\n options: UseContainerQueryOptions = {},\n): {\n ref: React.RefObject<T | null>\n size: ContainerSize\n} {\n const {compactBelow = 480, spaciousAbove = 768} = options\n const ref = useRef<T | null>(null)\n const [size, setSize] = useState<ContainerSize>('default')\n\n useEffect(() => {\n const element = ref.current\n if (!element) return\n\n let rafId: number | null = null\n\n const observer = new ResizeObserver((entries) => {\n if (rafId !== null) cancelAnimationFrame(rafId)\n\n rafId = requestAnimationFrame(() => {\n const entry = entries[0]\n if (!entry) return\n\n const width = entry.contentBoxSize?.[0]?.inlineSize ?? entry.contentRect.width\n\n if (width < compactBelow) {\n setSize('compact')\n } else if (width >= spaciousAbove) {\n setSize('spacious')\n } else {\n setSize('default')\n }\n })\n })\n\n observer.observe(element)\n\n return () => {\n observer.disconnect()\n if (rafId !== null) cancelAnimationFrame(rafId)\n }\n }, [compactBelow, spaciousAbove])\n\n return {ref, size}\n}\n"],"names":["styleq$1","styleq_2","cache","compiledKey","createStyleq","options","disableCache","disableMix","transform","definedProperties","className","inlineStyle","debugString","nextCache","styles","i","possibleStyle","_i","style","classNameChunk","cacheEntry","definedPropertiesChunk","prop","value","compiledKeyValue","weakMap","subStyle","_prop","_value","styleProps","styleq","optimizedStyleq","merge","dataStyleSrc","result","chunks","pathsMap","chunk","trimmed","path","line","a","button","div","heading","input","label","nav","p","span","textarea","defaultStyles","base","kmVPX3","kaIpWk","kMzoRj","ksu8eU","kGuDYH","kLWn49","$$css","error","kWkggS","kVAM5u","kMwMTN","success","warning","info","Alert","variant","children","jsx","_rsdMerge","_rsdDefaultStyles","k1xSpc","kGNEyG","kjj79g","kMv6JI","k63SB2","khDVqt","sizeMd","kLKAdn","kGO01o","kE3dHu","kpe85a","sizeSm","default","sizeMap","sm","md","Badge","size","kOIVth","kkrTdU","k1ekBW","kIyJzY","kAMwcw","kybGjl","kMeerF","k3XXqK","kjBf7l","kInvED","sizeDefault","sizeSmall","primary","secondary","link","danger","fullWidth","kzqmXN","disabled","kSiTet","small","Button","type","onClick","elevated","kGVxlE","outlined","filled","interactive","k3aq6I","sizeCompact","sizeFull","header","k1K539","compact","full","Card","jsxs","root","rootDisabled","box","kZKoxP","kmuXW","boxUnchecked","boxChecked","kVAEAm","kVQacm","Checkbox","name","checked","controlledChecked","defaultChecked","onChange","isControlled","undefined","internalChecked","setInternalChecked","useState","isChecked","handleChange","useCallback","e","target","opacity","kXwgrk","k9WMMc","message","action","keoZOQ","EmptyState","icon","typePresets","bodySm","kb6lSQ","bodyMd","bodyLg","caption","code","overline","kP9fke","headingSm","headingMd","headingLg","headingXl","displaySm","displayMd","displayLg","muted","accent","alignStart","alignCenter","alignEnd","defaultVariantMap","alignMap","start","center","end","Heading","level","color","align","resolvedVariant","h1","h2","h3","h4","h5","h6","FieldContext","createContext","useFieldContext","useContext","description","Root","invalid","id","useId","ctx","useMemo","controlId","descriptionId","errorId","Label","Description","Error","Field","InputGroupContext","useInputGroupContext","inGroup","Input","placeholder","required","minLength","pattern","autoComplete","defaultValue","groupCtx","extraProps","trim","wrapper","addon","kfSwDN","addonStart","kWqL5O","kSWEuD","k26BEO","addonEnd","kZ1KPB","k4WBpm","kaZRDh","addonClickable","addonDisabled","Addon","position","positionStyle","InputGroup","LinkButton","href","rel","trigger","backdrop","k87sOh","kbCHJM","kCIrl2","krVfgx","kY2c9j","popup","k7Eaqz","popupEnd","item","itemHighlighted","linkItem","MenuContext","useMenu","useMenuRoot","open","setOpen","highlightedId","setHighlightedId","menuId","rootRef","useRef","triggerRef","itemsRef","Map","orderRef","needsInitialHighlightRef","close","current","focus","toggle","prev","useEffect","order","length","registerItem","element","set","map","ids","keys","sort","b","elA","get","elB","compareDocumentPosition","Node","DOCUMENT_POSITION_FOLLOWING","delete","filter","handleKeyDown","key","preventDefault","idx","indexOf","items","click","addEventListener","removeEventListener","Trigger","localRef","Popup","Fragment","Item","ref","isHighlighted","el","handleClick","LinkItem","Menu","viewport","kXHlph","kORKVm","k5wCbM","content","kAzted","scrollbar","kFalU9","scrollbarVertical","scrollbarHorizontal","scrollbarHidden","scrollbarVisible","thumb","kUk6DE","viewportMaxHeight","maxHeight","kskxy","val","thumbVertical","height","thumbHorizontal","width","ScrollAreaContext","useScrollArea","useScrollAreaRoot","viewportRef","contentRef","scrollTop","setScrollTop","scrollLeft","setScrollLeft","scrollHeight","setScrollHeight","scrollWidth","setScrollWidth","clientHeight","setClientHeight","clientWidth","setClientWidth","scrolling","setScrolling","scrollTimerRef","handleScroll","vp","clearTimeout","setTimeout","observer","ResizeObserver","observe","disconnect","passive","Viewport","Content","Scrollbar","orientation","Thumb","draggingRef","startPosRef","startScrollRef","isVertical","thumbSizePercent","Math","max","maxScroll","trackSize","thumbPixelSize","scrollOffset","thumbOffset","thumbStyle","handlePointerDown","clientY","clientX","setPointerCapture","pointerId","handlePointerMove","delta","scrollRatio","scrollDelta","handlePointerUp","ScrollArea","itemSelected","hidden","SelectContext","useSelect","useControllableValue","controlledValue","internal","setInternal","setValue","v","useSelectRoot","onValueChange","labels","setLabels","listboxId","found","registerLabel","itemValue","Value","display","Icon","selectedValue","isSelected","text","textContent","ItemText","Select","group","groupTrigger","groupTriggerActive","chevron","chevronOpen","itemActive","SideNavContext","useSideNav","activeValue","onSelect","expandedGroups","setExpandedGroups","Set","toggleGroup","next","has","add","includes","push","Group","groupKey","defaultExpanded","isExpanded","groupRef","querySelector","hasActiveChild","isActive","SideNav","spinner","kLZC3w","kKVMdj","k44tkh","kyAemX","ko0y90","lg","srOnly","kMcinP","Spinner","icons","clock","forbidden","StatusIcon","_temp","kumcoG","row","kt9PQ7","kfdmCh","kL6WhQ","rowLastChild","bodyRow","headerCell","cell","cellSm","cellMd","stripedEven","borderedCell","borderedCellLast","gridColumns","columns","TableContext","useTable","HeaderContext","isHeader","Header","Body","childArray","Children","toArray","child","index","RowIndexContext","Row","rowIndex","isEvenRow","CellIndexContext","total","HeaderCell","isLast","Cell","Table","rootVertical","list","listVertical","tab","tabVertical","tabActiveHorizontal","tabActiveVertical","tabDisabled","panel","panelVertical","TabsContext","useTabs","useTabsRoot","tabsRef","registerTab","List","listRef","tabs","listEl","prevKey","nextKey","targetValue","currentIdx","Tab","tabId","panelId","Panel","Tabs","kHenm0","Textarea","rows","bg","bgCard","bgCardHover","textMuted","accentHover","accentContrast","border","errorHover","errorBg","errorBorder","errorText","errorContrast","successBg","successBorder","successText","warningBg","warningBorder","warningText","infoBg","infoBorder","infoText","__varGroupHash__","themeMap","light","lightTheme","lightShadows","highContrastTheme","highContrastShadows","ThemeProvider","theme","overrides","themeStyles","weightNormal","weightMedium","weightSemibold","weightBold","truncate","kg5iWk","weightMap","normal","medium","semibold","bold","Text","weight","as","kfzvcC","top","bottom","left","km5ZXQ","right","koQZXg","TooltipContext","useTooltip","placement","delay","tooltipId","timerRef","show","hide","Tooltip","alignStretch","gapXs","gapSm","gapMs","gapMd","gapLg","gapXl","gapXxl","gapXxxl","gapMap","xs","ms","xl","xxl","xxxl","stretch","Stack","gap","kwnvtZ","alignBaseline","justifyStart","justifyCenter","justifyEnd","justifyBetween","baseline","justifyMap","between","Inline","justify","Cluster","col1","col2","col3","col4","col5","col6","autoFit","minWidth","columnsMap","Grid","minColumnWidth","columnStyle","useContainerQuery","compactBelow","spaciousAbove","setSize","rafId","entries","cancelAnimationFrame","requestAnimationFrame","entry","contentBoxSize","inlineSize","contentRect"],"mappings":"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","x_google_ignoreList":[0]}
|