@qasa/qds-ui 0.25.0 → 0.25.2

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/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/qds-provider.tsx","../src/theme/foundations/breakpoints.ts","../src/theme/foundations/colors.ts","../src/styles/css-utils.ts","../src/styles/common-styles.ts","../src/theme/foundations/spacing.ts","../src/theme/foundations/z-index.ts","../src/theme/foundations/sizes.ts","../src/theme/foundations/radius.ts","../src/theme/foundations/shadows.ts","../src/theme/foundations/typography.ts","../src/theme/foundations/index.ts","../src/theme/theme.ts","../src/utils/object.ts","../src/theme/theme-tools.ts","../src/i18n/locale-context.tsx","../src/components/toast/toast-provider.tsx","../src/components/toast/toast-store.ts","../src/components/toast/toast.tsx","../src/components/icon/create-icon.tsx","../src/components/icon/create-lucide-icon.tsx","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/shared/src/utils.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/defaultAttributes.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/Icon.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/createLucideIcon.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/arrow-down.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/arrow-left.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/arrow-right.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/arrow-up.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/bell-off.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/bell.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/bookmark.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/calendar.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/camera.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/check.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/chevron-down.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/chevron-left.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/chevron-right.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/chevron-up.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/circle-alert.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/circle-check.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/circle-help.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/circle-x.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/ellipsis-vertical.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/ellipsis.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/globe.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/heart.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/history.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/house.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/image.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/info.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/list-filter.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/list.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/log-out.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/map-pin.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/map.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/menu.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/message-circle.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/minus.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/pen.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/plus.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/search.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/settings-2.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/settings.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/share.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/star.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/trash-2.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/triangle-alert.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/user-round.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/x.ts","../src/components/icon/icons.tsx","../src/components/toast/toast-styles.tsx","../src/components/avatar/avatar.tsx","../src/styles/responsive.ts","../src/components/button/button.tsx","../src/components/loading-dots/loading-dots.tsx","../src/components/button/button-styles.tsx","../src/components/button/button-icon.tsx","../src/components/display-text/display-text.tsx","../src/components/checkbox/checkbox.tsx","../src/hooks/use-breakpoint.ts","../src/hooks/use-breakpoint-value.ts","../src/hooks/use-form-field.ts","../src/hooks/use-stable-id.ts","../src/hooks/use-safe-layout-effect.ts","../src/utils/html-attributes.ts","../src/components/_internal/form-parts.tsx","../src/components/divider/divider.tsx","../src/components/dropdown-menu/dropdown-menu.tsx","../src/components/dropdown-menu/dropdown-menu-content.tsx","../src/components/dropdown-menu/dropdown-menu-divider.tsx","../src/components/dropdown-menu/dropdown-menu-item.tsx","../src/components/dropdown-menu/dropdown-menu-trigger.tsx","../src/components/heading/heading.tsx","../src/components/hint-box/hint-box.tsx","../src/components/icon-button/icon-button.tsx","../src/components/icon-button/icon-button-styles.tsx","../src/components/text-field/text-field.tsx","../src/i18n/locales.ts","../src/i18n/use-translation.tsx","../src/components/label/label.tsx","../src/components/primitives/input-base/input-base.tsx","../src/components/link/link.tsx","../src/components/paragraph/paragraph.tsx","../src/components/primitives/select-base/select-base.tsx","../src/components/primitives/textarea-base/textarea-base.tsx","../src/components/radio-group/radio-group.tsx","../src/components/radio-group/radio-group-context.tsx","../src/components/radio-group/radio-card/radio-card.tsx","../src/components/radio-group/radio-indicator.tsx","../src/components/radio-group/radio-group-label.tsx","../src/utils/merge-refs.ts","../src/components/radio-group/radio-button/radio-button.tsx","../src/components/select/select.tsx","../src/components/select/select-option.tsx","../src/components/spacer/spacer.tsx","../src/components/stack/stack.tsx","../src/components/stack/stack.utils.tsx","../src/components/switch/switch.tsx","../src/components/textarea/textarea.tsx"],"names":["ThemeProvider","CacheProvider","createCache","breakpoints","core","colors","createStyleVariants","styles","theme","createStyle","pxToRem","px","getFormFieldBaseStyles","radii","typography","spacing","__spreadProps","__spreadValues","zIndices","sizes","shadows","fontStacks","foundations","mediaQueries","objectKeys","obj","overrideTypography","overrides","result","group","override","typographyGroup","key","deepMerge","target","source","overrideTheme","createContext","useContext","jsx","LocaleContext","LocaleProvider","language","children","useLocale","context","ToastPrimitive","useSyncExternalStore","styled","AnimatePresence","flushSync","ToastStore","subscriber","index","toast","_a","id","text","options","toastStore","motion","Children","forwardRef","StyledSvg","color","createIcon","viewBox","pathDefinition","displayName","path","Component","props","forwardedRef","size","rest","__objRest","useTheme","createLucideIcon","Icon","ref","_b","resolvedColor","toKebabCase","string","mergeClasses","classes","className","array","defaultAttributes","strokeWidth","absoluteStrokeWidth","iconNode","createElement","tag","attrs","iconName","__iconNode","ArrowDown","ArrowLeft","ArrowRight","ArrowUp","BellOff","Bell","Bookmark","Calendar","Camera","Check","ChevronDown","ChevronLeft","ChevronRight","ChevronUp","CircleAlert","CircleCheck","CircleHelp","CircleX","EllipsisVertical","Ellipsis","Globe","Heart","History","House","Image","Info","ListFilter","List","LogOut","MapPin","Map","Menu","MessageCircle","Minus","Pen","Plus","Search","Settings2","Settings","Share","Star","Trash2","TriangleAlert","UserRound","X","AlertCircleIcon","AlertTriangleIcon","ArrowDownIcon","ArrowLeftIcon","ArrowRightIcon","ArrowUpIcon","BellIcon","BellOffIcon","BookmarkIcon","CalendarIcon","CameraIcon","CheckCircleIcon","CheckIcon","ChevronDownIcon","ChevronLeftIcon","ChevronRightIcon","ChevronUpIcon","GlobeIcon","HeartFilledIcon","HeartIcon","HelpCircleIcon","HistoryIcon","HomeIcon","ImageIcon","InfoIcon","ListIcon","ListFilterIcon","LogOutIcon","MapIcon","MapPinIcon","MenuIcon","MessageCircleIcon","MinusIcon","MoreHorizontalIcon","MoreVerticalIcon","PenIcon","PlusIcon","SearchIcon","SettingsIcon","ShareIcon","SlidersIcon","StarFilledIcon","StarIcon","TrashIcon","UserIcon","XCircleIcon","XIcon","getVariantStyles","jsxs","Wrapper","variant","Title","IconWrapper","ICON_MAP","Toast","Viewport","ToastProvider","toasts","isOpen","fallbackEmotionCache","QdsProvider","themeOverrides","emotionCache","locale","resolvedTheme","isPropValid","AvatarPrimitive","isResponsiveProp","value","objectEntries","toMediaQueries","prop","styleFn","base","cssObject","breakpoint","mediaQuery","SIZE_MAP","ICON_SIZE_MAP","TEXT_SIZE_MAP","getInitials","name","names","firstName","lastName","AvatarRoot","currentValue","AvatarImage","AvatarFallback","FallbackText","avatarSize","roundToTwoDecimals","num","StyledIcon","Avatar","src","restProps","keyframes","ANIMATION_DURATION","ANIMATION_STAGGER_DELAY","getSizeStyles","scaleAnimation","Dot","LoadingDots","NOT_DISABLED","ICON_GAP","ICON_OFFSET","IconLeftContainer","buttonSize","iconSize","IconRightContainer","ButtonIcon","placement","StyledButton","isFullWidth","ButtonLoadingDots","ContentContainer","isHidden","Button","as","type","sizeProp","isLoading","isDisabled","hasHtmlDisabledProp","iconLeft","iconRight","StyledDisplayText","textAlign","textWrap","DisplayText","CheckboxPrimitive","useEffect","useState","breakpointsArray","MEDIA_QUERIES","nextValue","media","getMatchingBreakpoint","matchingBreakpoint","useBreakpoint","params","ssr","initialBreakpoint","currentBreakpoint","setCurrentBreakpoint","matchMediaArray","handleChange","useBreakpointValue","values","breakpointValue","breakpointNames","currentBreakpointIndex","i","useCallback","React","useLayoutEffect","useSafeLayoutEffect","useReactId","count","useStableId","fixedId","setId","reactId","useFormField","idProp","helperText","errorMessage","isInvalid","isRequired","errorMessageId","helperTextId","getLabelProps","forwardedProps","getHelperTextProps","getErrorMessageProps","getFieldProps","ariaDescribedByIds","dataAttr","condition","ariaAttr","FieldWrapper","FormField","ErrorMessage","HelperText","CheckboxContainer","CheckboxRoot","LabelText","SupportingTextContainer","Checkbox","label","hasHtmlDefaultCheckedAttr","isDefaultCheckedProp","isCheckedProp","hasHtmlCheckedAttr","isDisabledProp","hasHtmlDisabledAttr","isRequiredProp","hasHtmlRequiredAttr","ariaLabelledByProp","ariaDescribedByProp","labelId","isDefaultChecked","isChecked","ariaLabelledBy","helperTextElement","hasError","errorMessageElement","ariaDescribedBy","ev","StyledDivider","orientation","borderCssKey","Divider","DropdownPrimitive","slideUpAndFadeIn","slideRightAndFadeIn","slideDownAndFadeIn","slideLeftAndFadeIn","slideUpAndFadeOut","slideRightAndFadeOut","slideDownAndFadeOut","slideLeftAndFadeOut","StyledContent","DropdownMenuContent","sideOffset","StyledSeparator","DropdownMenuDivider","StyledItem","TextContainer","DropdownMenuItem","disabled","DropdownTriggerPrimitive","DropdownMenuTrigger","DropdownMenuRoot","onOpenChange","defaultOpen","DropdownMenu","StyledHeading","numberOfLines","Heading","HintRoot","HintBox","IconButton","ariaLabel","useRef","en","sv","fi","fr","nb","locales","useTranslation","currentLanguage","StyledLabel","Label","onMouseDown","event","StyledInput","InputBase","InputContainer","isPositionRelative","OptionalText","Suffix","TextField","isOptionalProp","suffix","getInputProps","suffixWidth","setSuffixWidth","suffixRef","t","hasSuffix","isOptional","StyledLink","Link","href","isExternal","StyledParagraph","Paragraph","SelectWrapper","SelectIconWrapper","StyledSelect","SelectBase","placeholder","StyledTextarea","resize","minRows","baseStyles","paddingVertical","minHeight","TextareaBase","RadioGroupPrimitive","RadioGroupContext","RadioGroupProvider","useRadioGroupContext","consumerName","StyledRadioIndicator","RadioIndicator","RadioItem","RadioCard","onMouseEnter","onMouseLeave","isHovered","setIsHovered","assignRef","mergeRefs","refs","node","RadioGroupLabel","labelRefCallback","RadioButtonContainer","RadioButton","isGroupDisabled","StyledRadioGroupRoot","RadioGroupRoot","labelElement","setLabelElement","RadioGroup","SelectOption","SelectRoot","getSelectProps","Select","StyledSpan","axis","resolvedValue","Spacer","Fragment","isValidElement","getValidChildren","child","StyledStack","wrap","gap","justifyContent","alignItems","direction","Stack","divider","resolvedChildren","validChildren","currentDivider","RadixSwitch","Switch","onCheckedChange","hasHelperText","SwitchWrapper","SwitchTexts","SwitchLabel","SwitchHelperText","SwitchRoot","SwitchThumb","Textarea","getTextareaProps"],"mappings":"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","sourcesContent":["import { ThemeProvider, CacheProvider, type EmotionCache } from '@emotion/react'\nimport type { ReactNode } from 'react'\nimport createCache from '@emotion/cache'\n\nimport type { ThemeOverrides } from './theme'\nimport { overrideTheme, theme } from './theme'\nimport { LocaleProvider } from './i18n/locale-context'\nimport type { LanguageCode } from './i18n/locales'\nimport { ToastProvider } from './components/toast/toast-provider'\n\nconst fallbackEmotionCache = createCache({ key: 'qds' })\ninterface QdsProviderProps {\n children: ReactNode\n themeOverrides?: ThemeOverrides\n emotionCache?: EmotionCache\n locale: LanguageCode\n}\n\nexport function QdsProvider({ children, themeOverrides, emotionCache, locale }: QdsProviderProps) {\n const resolvedTheme = themeOverrides ? overrideTheme(themeOverrides) : theme\n\n const cache = emotionCache || fallbackEmotionCache\n\n return (\n <LocaleProvider language={locale || 'en'}>\n <CacheProvider value={cache}>\n <ThemeProvider theme={resolvedTheme}>\n <ToastProvider>{children}</ToastProvider>\n </ThemeProvider>\n </CacheProvider>\n </LocaleProvider>\n )\n}\n","export const breakpoints = {\n base: 0,\n sm: 480,\n md: 768,\n lg: 1024,\n xl: 1280,\n '2xl': 1536,\n} as const\n","const core = {\n black: '#000000',\n white: '#ffffff',\n\n gray90: '#26261D',\n gray80: '#424236',\n gray70: '#545448',\n gray60: '#78786C',\n gray50: '#A3A396',\n gray40: '#D6D6CD',\n gray30: '#E5E5DF',\n gray20: '#F0F0EB',\n gray10: '#F9F9F6',\n pink: '#FF84B6',\n uiPink: '#FF99C2',\n uiPinkDark: '#FF84B6',\n uiPinkLight: '#FFA3C8',\n\n brown: '#342620',\n brownDark: '#2A1E1A',\n brownLight: '#3C2F29',\n\n offWhite: '#F0F0EB',\n offWhiteDark: '#E0E0D6',\n offWhiteLight: '#F6F6F3',\n\n softPink: '#FFE8F0',\n\n warmYellow: '#FFD66C',\n\n softYellow: '#FFF8CC',\n\n red90: '#8A1100',\n red80: '#A81400',\n red70: '#C21700',\n red60: '#DE1B00',\n red50: '#EF452E',\n red40: '#F47E6E',\n red30: '#F8B2A8',\n red20: '#FAD8D4',\n red10: '#FEF3F1',\n\n green90: '#00661D',\n green80: '#007D23',\n green70: '#009029',\n green60: '#00A62F',\n green50: '#30B757',\n green40: '#66CA82',\n green30: '#A1DEB2',\n green20: '#D1EFDA',\n green10: '#F5FBF7',\n\n blue90: '#00288E',\n blue80: '#0039CC',\n blue70: '#0045F6',\n blue60: '#3370FF',\n blue50: '#578FFF',\n blue40: '#80AEFF',\n blue30: '#BDD7FF',\n blue20: '#DBEBFF',\n blue10: '#F0F7FF',\n\n yellow90: '#9B6D00',\n yellow80: '#C58B00',\n yellow70: '#E29F00',\n yellow60: '#F3AB00',\n yellow50: '#F5B92B',\n yellow40: '#F7C652',\n yellow30: '#F9D682',\n yellow20: '#FBE6B2',\n yellow10: '#FEF7E5',\n\n blackAlpha5: 'rgba(0, 0, 0, 0.05)',\n blackAlpha10: 'rgba(0, 0, 0, 0.1)',\n blackAlpha20: 'rgba(0, 0, 0, 0.2)',\n}\n\nexport const colors = {\n core,\n bg: {\n default: core.white,\n brandPrimary: core.uiPink,\n brandPrimaryHover: core.uiPinkLight,\n brandPrimaryActive: core.uiPinkDark,\n brandSecondary: core.brown,\n brandSecondaryHover: core.brownLight,\n brandSecondaryActive: core.brownDark,\n brandTertiary: core.offWhite,\n brandTertiaryHover: core.offWhiteLight,\n brandTertiaryActive: core.offWhiteDark,\n negative: core.red60,\n warning: core.yellow60,\n positive: core.green60,\n inset: core.gray10,\n backdrop: core.blackAlpha20,\n },\n text: {\n strong: core.black,\n default: core.brown,\n subtle: core.gray60,\n disabled: core.gray50,\n negative: core.red60,\n warning: core.yellow90,\n positive: core.green70,\n onBrandPrimary: core.brown,\n onBrandSecondary: core.offWhite,\n onBrandTertiary: core.brown,\n },\n icon: {\n default: core.brown,\n strong: core.black,\n subtle: core.gray60,\n disabled: core.gray50,\n negative: core.red60,\n warning: core.yellow70,\n positive: core.green70,\n onBrandPrimary: core.brown,\n onBrandSecondary: core.offWhite,\n onBrandTertiary: core.brown,\n },\n border: {\n default: core.gray30,\n defaultHover: core.gray40,\n defaultSelected: core.brown,\n strong: core.gray40,\n subtle: core.gray20,\n negative: core.red60,\n warning: core.yellow60,\n positive: core.green60,\n },\n}\n","import type { CSSObject } from '@emotion/react'\n\nimport type { Theme } from '../theme'\n\ntype NamedStyles = Record<string, CSSObject>\ntype StyleInterpolation<T> = (theme: Theme) => T\n// TODO: Make `createstyleVariants`and `createStyle` accept a regular object instead of a function.\n// And infer if the return requires a theme or not.\n\n/**\n * Creates a collection of named style rules.\n */\nexport function createStyleVariants<T extends NamedStyles>(styles: StyleInterpolation<T>) {\n return (theme: Theme) => styles(theme)\n}\n\n/**\n * Create a style object. Useful for creating styles that depend on the theme.\n */\nexport function createStyle<T extends CSSObject>(styles: StyleInterpolation<T>) {\n return (theme: Theme) => styles(theme)\n}\n\nexport type VariantProps<T extends ReturnType<typeof createStyle | typeof createStyleVariants>> =\n keyof ReturnType<T>\n\n/**\n * Converts css `px` unit to `rem`.\n * Assumes the root font size is 16px.\n */\nexport const pxToRem = (px: number) => `${px / 16}rem`\n","import { createStyle } from './css-utils'\n\nexport const getFormFieldBaseStyles = createStyle(({ colors, radii, typography, spacing }) => ({\n width: '100%',\n minWidth: 0,\n appearance: 'none',\n paddingLeft: spacing['4x'],\n paddingRight: spacing['4x'],\n border: `1px solid ${colors.border.default}`,\n borderRadius: radii.sm,\n backgroundColor: colors.bg.default,\n color: colors.text.default,\n WebkitTouchCallout: 'none',\n WebkitTapHighlightColor: 'transparent',\n '&::-webkit-date-and-time-value': {\n textAlign: 'left',\n },\n alignItems: 'center',\n ...typography.body.md,\n\n '&::placeholder': {\n color: colors.text.disabled,\n },\n '&:hover': {\n borderColor: colors.border.defaultHover,\n },\n '&:focus': {\n outline: 0,\n borderColor: colors.border.defaultSelected,\n boxShadow: `0 0 0 1px ${colors.border.defaultSelected}`,\n },\n '&[aria-invalid=\"true\"]': {\n borderColor: colors.border.negative,\n\n '&:focus': {\n boxShadow: `0 0 0 1px ${colors.border.negative}`,\n },\n },\n '&[disabled], &:disabled, &[data-disabled]': {\n opacity: 0.4,\n borderColor: colors.border.default,\n },\n\n transitionProperty: 'opacity, border-color, box-shadow',\n transitionDuration: '120ms',\n transitionTimingFunction: 'ease',\n}))\n","import { pxToRem } from '../../styles'\n\nexport const spacing = {\n /** 0rem (0px) */\n '0x': pxToRem(0),\n /** 0.25rem (4px) */\n '1x': pxToRem(4),\n /** 0.5rem (8px) */\n '2x': pxToRem(8),\n /** 0.75rem (12px) */\n '3x': pxToRem(12),\n /** 1rem (16px) */\n '4x': pxToRem(16),\n /** 1.25rem (20px) */\n '5x': pxToRem(20),\n /** 1.5rem (24px) */\n '6x': pxToRem(24),\n /** 2rem (32px) */\n '8x': pxToRem(32),\n /** 2.5rem (40px) */\n '10x': pxToRem(40),\n /** 3rem (48px) */\n '12x': pxToRem(48),\n /** 3.5rem (56px) */\n '14x': pxToRem(56),\n /** 4rem (64px) */\n '16x': pxToRem(64),\n /** 5rem (80px) */\n '20x': pxToRem(80),\n /** 6rem (96px) */\n '24x': pxToRem(96),\n}\n","export const zIndices = {\n /** -1 */\n hide: -1,\n /** auto */\n auto: 'auto',\n /** 0 */\n base: 0,\n /** 10 */\n docked: 10,\n /** 1000 */\n dropdown: 1000,\n /** 1100 */\n sticky: 1100,\n /** 1200 */\n banner: 1200,\n /** 1300 */\n overlay: 1300,\n /** 1400 */\n modal: 1400,\n /** 1500 */\n popover: 1500,\n /** 1600 */\n skipLink: 1600,\n /** 1700 */\n toast: 1700,\n /** 1800 */\n tooltip: 1800,\n}\n","import { pxToRem } from '../../styles'\n\nimport { spacing } from './spacing'\n\nexport const sizes = {\n ...spacing,\n 112: pxToRem(112),\n 128: pxToRem(128),\n 144: pxToRem(144),\n 160: pxToRem(160),\n 176: pxToRem(176),\n 192: pxToRem(192),\n 224: pxToRem(224),\n 256: pxToRem(256),\n 288: pxToRem(288),\n 320: pxToRem(320),\n 384: pxToRem(384),\n 448: pxToRem(448),\n 512: pxToRem(512),\n 576: pxToRem(576),\n 672: pxToRem(672),\n 768: pxToRem(768),\n 896: pxToRem(896),\n 1024: pxToRem(1024),\n}\n","export const radii = {\n /** 0px */\n none: '0px',\n /** 6px */\n '2xs': '6px',\n /** 8px */\n xs: '8px',\n /** 12px */\n sm: '12px',\n /** 16px */\n md: '16px',\n /** 24px */\n lg: '24px',\n /** 32px */\n xl: '32px',\n /** 48px */\n '2xl': '48px',\n /** 9999px */\n full: '9999px',\n}\n","export const shadows = {\n none: 'none',\n sm: '0px 0.9px 2.1px 0px rgba(0, 0, 0, 0.0197), 0px 2.1px 5px 0px rgba(0, 0, 0, 0.0283), 0px 3.9px 9.4px 0px rgba(0, 0, 0, 0.035)',\n md: '0px 0.9px 2.1px 0px rgba(0, 0, 0, 0.0197), 0px 2.1px 5px 0px rgba(0, 0, 0, 0.0283), 0px 3.9px 9.4px 0px rgba(0, 0, 0, 0.035), 0px 7px 16.8px 0px rgba(0, 0, 0, 0.0417)',\n lg: '0px 0.9px 2.1px 0px rgba(0, 0, 0, 0.0197), 0px 2.1px 5px 0px rgba(0, 0, 0, 0.0283), 0px 3.9px 9.4px 0px rgba(0, 0, 0, 0.035), 0px 7px 16.8px 0px rgba(0, 0, 0, 0.0417), 0px 13px 31.3px 0px rgba(0, 0, 0, 0.0503)',\n xl: '0px 0.9px 2.1px 0px rgba(0, 0, 0, 0.0197), 0px 2.1px 5px 0px rgba(0, 0, 0, 0.0283), 0px 3.9px 9.4px 0px rgba(0, 0, 0, 0.035), 0px 7px 16.8px 0px rgba(0, 0, 0, 0.0417), 0px 13px 31.3px 0px rgba(0, 0, 0, 0.0503), 0px 31px 75px 0px rgba(0, 0, 0, 0.07)',\n}\n","import { pxToRem } from '../../styles'\n\nconst fontStacks = {\n display: [\n 'var(--font-family-display)',\n 'Helvetica',\n '-apple-system',\n 'BlinkMacSystemFont',\n 'Roboto',\n '\"Helvetica Neue\"',\n 'sans-serif',\n ].join(','),\n sans: [\n 'var(--font-family-sans)',\n 'Helvetica',\n '-apple-system',\n 'BlinkMacSystemFont',\n 'Roboto',\n '\"Helvetica Neue\"',\n 'sans-serif',\n ].join(','),\n}\n\nexport const typography = {\n display: {\n '3xl': {\n fontFamily: fontStacks.display,\n fontWeight: '700',\n fontSize: pxToRem(80),\n lineHeight: pxToRem(80),\n letterSpacing: '-0.06em',\n fontFeatureSettings: \"'ss05' on\",\n },\n '2xl': {\n fontFamily: fontStacks.display,\n fontWeight: '700',\n fontSize: pxToRem(72),\n lineHeight: pxToRem(72),\n letterSpacing: '-0.06em',\n fontFeatureSettings: \"'ss05' on\",\n },\n xl: {\n fontFamily: fontStacks.display,\n fontWeight: '700',\n fontSize: pxToRem(64),\n lineHeight: pxToRem(64),\n letterSpacing: '-0.05em',\n fontFeatureSettings: \"'ss05' on\",\n },\n lg: {\n fontFamily: fontStacks.display,\n fontWeight: '700',\n fontSize: pxToRem(56),\n lineHeight: pxToRem(56),\n letterSpacing: '-0.05em',\n fontFeatureSettings: \"'ss05' on\",\n },\n md: {\n fontFamily: fontStacks.display,\n fontWeight: '700',\n fontSize: pxToRem(48),\n lineHeight: pxToRem(48),\n letterSpacing: '-0.04em',\n fontFeatureSettings: \"'ss05' on\",\n },\n sm: {\n fontFamily: fontStacks.display,\n fontWeight: '700',\n fontSize: pxToRem(40),\n lineHeight: pxToRem(44),\n letterSpacing: '-0.04em',\n fontFeatureSettings: \"'ss05' on\",\n },\n xs: {\n fontFamily: fontStacks.display,\n fontWeight: '700',\n fontSize: pxToRem(32),\n lineHeight: pxToRem(36),\n letterSpacing: '-0.03em',\n fontFeatureSettings: \"'ss05' on\",\n },\n '2xs': {\n fontFamily: fontStacks.display,\n fontWeight: '700',\n fontSize: pxToRem(28),\n lineHeight: pxToRem(32),\n letterSpacing: '-0.03em',\n fontFeatureSettings: \"'ss05' on\",\n },\n },\n title: {\n lg: {\n fontFamily: fontStacks.sans,\n fontWeight: '700',\n fontSize: pxToRem(32),\n lineHeight: pxToRem(36),\n letterSpacing: '-0.02em',\n },\n md: {\n fontFamily: fontStacks.sans,\n fontWeight: '700',\n fontSize: pxToRem(24),\n lineHeight: pxToRem(28),\n letterSpacing: '-0.02em',\n },\n sm: {\n fontFamily: fontStacks.sans,\n fontWeight: '700',\n fontSize: pxToRem(20),\n lineHeight: pxToRem(24),\n letterSpacing: '-0.02em',\n },\n xs: {\n fontFamily: fontStacks.sans,\n fontWeight: '700',\n fontSize: pxToRem(18),\n lineHeight: pxToRem(22),\n letterSpacing: '-0.015em',\n },\n '2xs': {\n fontFamily: fontStacks.sans,\n fontWeight: '700',\n fontSize: pxToRem(16),\n lineHeight: pxToRem(20),\n letterSpacing: '-0.01em',\n },\n '3xs': {\n fontFamily: fontStacks.sans,\n fontWeight: '700',\n fontSize: pxToRem(14),\n lineHeight: pxToRem(18),\n letterSpacing: '-0.005em',\n },\n },\n body: {\n xl: {\n fontFamily: fontStacks.sans,\n fontWeight: '400',\n fontSize: pxToRem(20),\n lineHeight: pxToRem(28),\n letterSpacing: '-0.02em',\n },\n lg: {\n fontFamily: fontStacks.sans,\n fontWeight: '400',\n fontSize: pxToRem(18),\n lineHeight: pxToRem(26),\n letterSpacing: '-0.02em',\n },\n md: {\n fontFamily: fontStacks.sans,\n fontWeight: '400',\n fontSize: pxToRem(16),\n lineHeight: pxToRem(24),\n letterSpacing: '-0.01em',\n },\n sm: {\n fontFamily: fontStacks.sans,\n fontWeight: '400',\n fontSize: pxToRem(14),\n lineHeight: pxToRem(20),\n letterSpacing: '-0.01em',\n },\n xs: {\n fontFamily: fontStacks.sans,\n fontWeight: '400',\n fontSize: pxToRem(12),\n lineHeight: pxToRem(16),\n letterSpacing: '0',\n },\n },\n label: {\n md: {\n fontFamily: fontStacks.sans,\n fontWeight: '500',\n fontSize: pxToRem(16),\n lineHeight: pxToRem(20),\n letterSpacing: '-0.02em',\n },\n sm: {\n fontFamily: fontStacks.sans,\n fontWeight: '500',\n fontSize: pxToRem(14),\n lineHeight: pxToRem(18),\n letterSpacing: '-0.01em',\n },\n },\n button: {\n md: {\n fontFamily: fontStacks.sans,\n fontWeight: '700',\n fontSize: pxToRem(16),\n lineHeight: pxToRem(18),\n letterSpacing: '-0.01em',\n },\n sm: {\n fontFamily: fontStacks.sans,\n fontWeight: '700',\n fontSize: pxToRem(14),\n lineHeight: pxToRem(16),\n letterSpacing: '-0.01em',\n },\n },\n caption: {\n md: {\n fontFamily: fontStacks.sans,\n fontWeight: '700',\n fontSize: pxToRem(12),\n lineHeight: pxToRem(12),\n letterSpacing: '0',\n },\n sm: {\n fontFamily: fontStacks.sans,\n fontWeight: '700',\n fontSize: pxToRem(10),\n lineHeight: pxToRem(10),\n letterSpacing: '0',\n },\n },\n}\n","/**\n * ------ IMPORTANT ------\n * Do not change or add to the contents of this file\n * without consulting with the design team.\n *\n * These are values that make up our brand and even\n * minor changes greatly affects our visual identity.\n *\n * The foundations are losely based on Styled System Theme Specification\n * @see https://styled-system.com/theme-specification/\n * -----------------------\n */\n\nimport { breakpoints } from './breakpoints'\nimport { colors } from './colors'\nimport { spacing } from './spacing'\nimport { zIndices } from './z-index'\nimport { sizes } from './sizes'\nimport { radii } from './radius'\nimport { shadows } from './shadows'\nimport { typography } from './typography'\n\nexport const foundations = {\n spacing,\n breakpoints,\n zIndices,\n colors,\n sizes,\n radii,\n shadows,\n typography,\n}\n","import { foundations } from './foundations'\n\nconst mediaQueries = {\n smUp: `@media(min-width: ${foundations.breakpoints.sm}px)`,\n mdUp: `@media(min-width: ${foundations.breakpoints.md}px)`,\n lgUp: `@media(min-width: ${foundations.breakpoints.lg}px)`,\n xlUp: `@media(min-width: ${foundations.breakpoints.xl}px)`,\n '2xlUp': `@media(min-width: ${foundations.breakpoints['2xl']}px)`,\n} as const\n\nexport const theme = { ...foundations, mediaQueries }\nexport type Theme = typeof theme\n","export const objectKeys = <T extends object>(obj: T): (keyof T)[] => {\n return Object.keys(obj) as (keyof T)[]\n}\n","import type { LegitimateAny, PartialRecord } from '../types'\nimport { objectKeys } from '../utils/object'\n\nimport type { Theme } from './theme'\nimport { theme } from './theme'\n\ntype DeepPartial<T> = { [P in keyof T]?: DeepPartial<T[P]> }\n\ninterface TypographyOverride {\n fontFamily?: string\n fontWeight?: '100' | '200' | '300' | '400' | '500' | '600' | '700' | '800' | '900'\n}\n\ntype TypographyOverrides = PartialRecord<keyof Theme['typography'], TypographyOverride>\n\nconst overrideTypography = (overrides: TypographyOverrides): Theme['typography'] => {\n const result = Object.assign({}, theme.typography)\n\n objectKeys(result).forEach((group) => {\n const override = overrides[group]\n if (override) {\n const typographyGroup = result[group]\n objectKeys(typographyGroup).forEach((key) => {\n typographyGroup[key].fontFamily = override.fontFamily || typographyGroup[key].fontFamily\n typographyGroup[key].fontWeight = override.fontWeight || typographyGroup[key].fontWeight\n })\n }\n })\n\n return result\n}\n\nconst deepMerge = <T extends Record<string, LegitimateAny>>(\n target: T,\n source: DeepPartial<T>,\n): T => {\n const result = Object.assign({}, target)\n\n objectKeys(source).forEach((key) => {\n if (typeof source[key] === 'object') {\n result[key] = deepMerge(result[key], source[key])\n } else {\n // @ts-expect-error\n result[key] = source[key]\n }\n })\n\n return result\n}\n\nexport interface ThemeOverrides {\n colors?: DeepPartial<Theme['colors']>\n typography?: TypographyOverrides\n}\n\nexport const overrideTheme = (overrides: ThemeOverrides) => {\n let typography = theme.typography\n let colors = theme.colors\n\n if (overrides.typography) {\n typography = overrideTypography(overrides.typography)\n }\n\n if (overrides.colors) {\n colors = deepMerge(theme.colors, overrides.colors)\n }\n\n return { ...theme, typography, colors }\n}\n","import { createContext, useContext } from 'react'\n\nimport type { LanguageCode } from './locales'\n\ninterface LocaleContextValue {\n currentLanguage: LanguageCode\n}\n\nconst LocaleContext = createContext<LocaleContextValue | undefined>(undefined)\n\ninterface LocaleProviderProps {\n language: LanguageCode\n children: React.ReactNode\n}\nexport function LocaleProvider({ language, children }: LocaleProviderProps) {\n return (\n <LocaleContext.Provider value={{ currentLanguage: language }}>\n {children}\n </LocaleContext.Provider>\n )\n}\n\nexport function useLocale() {\n const context = useContext(LocaleContext)\n if (!context) {\n throw new Error('useLocale must be used within a LocaleProvider')\n }\n\n return context\n}\n","import * as ToastPrimitive from '@radix-ui/react-toast'\nimport { useSyncExternalStore } from 'react'\nimport type { ReactNode } from 'react'\nimport styled from '@emotion/styled'\nimport { AnimatePresence } from 'motion/react'\n\nimport { toastStore } from './toast-store'\nimport { Toast } from './toast'\n\n/**\n * We style a separate div as a child for Radix Viewport in order to meet the QDS accessibility requirements\n * Radix uses <ol> and <li> elements for Toast elements in combination with role=\"status\", which is not allowed according to a11y standards\n * @see https://github.com/radix-ui/primitives/issues/1750\n */\nconst Viewport = styled.div(({ theme }) => ({\n position: 'fixed',\n bottom: theme.spacing['12x'],\n left: '50%',\n transform: 'translateX(-50%)',\n zIndex: theme.zIndices.toast,\n display: 'flex',\n flexDirection: 'column',\n gap: theme.spacing['2x'],\n width: `calc(100vw - ${theme.spacing['8x']})`,\n [theme.mediaQueries.smUp]: {\n width: theme.sizes[320],\n },\n}))\n\nexport function ToastProvider({ children }: { children: ReactNode }) {\n const toasts = useSyncExternalStore(\n toastStore.subscribe,\n toastStore.getSnapshot,\n toastStore.getSnapshot,\n )\n\n return (\n <ToastPrimitive.Provider>\n {children}\n <AnimatePresence>\n {toasts.map(({ id, text, variant }) => (\n <Toast\n key={id}\n text={text}\n variant={variant}\n onOpenChange={(isOpen) => {\n if (!isOpen) {\n toastStore.remove(id)\n }\n }}\n />\n ))}\n </AnimatePresence>\n <ToastPrimitive.Viewport asChild>\n <Viewport />\n </ToastPrimitive.Viewport>\n </ToastPrimitive.Provider>\n )\n}\n","import { flushSync } from 'react-dom'\n\nimport type { ToastVariant } from './toast-styles'\n\ntype Id = number | string\ninterface Toast {\n id: Id\n /**\n * The text for the toast\n */\n text: string\n /**\n * Sets the style variant of the toast, currently supports 'neutral' and 'negative'\n * @default 'neutral'\n */\n variant?: ToastVariant\n}\ninterface ToastOptions {\n /**\n * Unique identifier for the toast (can be used for removing it prematurely). If a toast with this\n * identifier already exists it will be removed before the new toast is added.\n * @default a random unique id will be set and returned\n */\n id?: Id\n}\n\ntype Subscriber = () => void\nclass ToastStore {\n toasts: Toast[]\n subscribers: Subscriber[]\n id: number\n\n constructor() {\n this.subscribers = []\n this.toasts = []\n this.id = 0\n }\n\n subscribe = (subscriber: Subscriber) => {\n this.subscribers.push(subscriber)\n\n return () => {\n const index = this.subscribers.indexOf(subscriber)\n this.subscribers.splice(index, 1)\n }\n }\n\n notify = () => {\n this.subscribers.forEach((subscriber) => subscriber())\n }\n\n add = (toast: Omit<Toast, 'id'> & ToastOptions) => {\n /*\n * Update to use the window.crypto.randomUUIC() method here after some time when we are sure that all the relevant browsers support it.\n */\n this.id = this.id + 1\n const id = toast.id ?? this.id\n if (toast.id) {\n // NOTE: if the toast.id is set we remove any toast with the same identifier\n this.toasts = this.toasts.filter((toast) => toast.id !== id)\n // we use flushSync to prevent batched state updates which would cause React to update the old\n // toast instead of removing it and adding a new one\n flushSync(() => {\n this.notify()\n })\n }\n this.toasts = [...this.toasts, { ...toast, id }]\n this.notify()\n\n return id\n }\n\n addNeutral = (text: string, options?: ToastOptions) => {\n return this.add({ text, variant: 'neutral', ...options })\n }\n\n addError = (text: string, options?: ToastOptions) => {\n return this.add({ text, variant: 'error', ...options })\n }\n\n remove = (id: Id) => {\n this.toasts = [...this.toasts.filter((toast) => toast.id !== id)]\n this.notify()\n }\n\n removeAll = () => {\n this.toasts = []\n this.notify()\n }\n\n getSnapshot = () => {\n return this.toasts\n }\n}\n\nexport const toastStore = new ToastStore()\n\nexport const toast = Object.assign(toastStore.addNeutral, {\n error: toastStore.addError,\n remove: toastStore.remove,\n removeAll: toastStore.removeAll,\n})\n","import * as ToastPrimitive from '@radix-ui/react-toast'\nimport styled from '@emotion/styled'\nimport { motion } from 'motion/react'\n\nimport type { HTMLQdsProps } from '../../types'\nimport { AlertCircleIcon } from '../icon'\n\nimport { getVariantStyles } from './toast-styles'\nimport type { ToastVariant } from './toast-styles'\n\n/**\n * We style a separate div as a child for Radix Toast.Root in order to meet the QDS accessibility requirements & animate it\n * Radix uses <ol> and <li> elements for Toast elements in combination with role=\"status\", which is not allowed according to a11y standards\n * @see https://github.com/radix-ui/primitives/issues/1750\n */\nconst Wrapper = styled(motion.div)<{ variant: ToastVariant }>(({ theme, variant }) => ({\n borderRadius: theme.radii.md,\n paddingInline: theme.spacing['4x'],\n paddingBlock: theme.spacing['3x'],\n display: 'flex',\n flexDirection: 'row',\n gap: theme.spacing['3x'],\n boxShadow: theme.shadows.lg,\n ...getVariantStyles(theme)[variant],\n}))\n\nconst Title = styled(ToastPrimitive.Title)(({ theme }) => ({\n ...theme.typography.label.md,\n}))\n\nconst IconWrapper = styled.div({\n marginTop: 1,\n flexShrink: 0,\n})\n\nconst ICON_MAP = {\n neutral: undefined,\n error: AlertCircleIcon,\n}\n\ninterface ToastOptions {\n text: string\n variant?: ToastVariant\n}\n\ntype OmittedProps = 'children'\ninterface ToastProps extends Omit<HTMLQdsProps<'div'>, OmittedProps>, ToastOptions {}\n\nexport function Toast(props: ToastProps & ToastPrimitive.ToastProps) {\n const { text, variant = 'neutral', ...rest } = props\n\n const Icon = ICON_MAP[variant]\n\n return (\n <ToastPrimitive.Root asChild forceMount {...rest}>\n <Wrapper\n variant={variant}\n layout\n initial={{ opacity: 0, y: 20 }}\n animate={{ opacity: 1, y: 0 }}\n exit={{ opacity: 0 }}\n transition={{ y: { type: 'spring', bounce: 0.1 } }}\n >\n {Icon && (\n <IconWrapper>\n <Icon size={16} color=\"onBrandSecondary\" />\n </IconWrapper>\n )}\n <Title>{text}</Title>\n </Wrapper>\n </ToastPrimitive.Root>\n )\n}\n","/**\n * This function is heavily inspired by the `createIcon` function from\n * Chakra UI (https://chakra-ui.com/).\n */\n\nimport styled from '@emotion/styled'\nimport { Children, forwardRef } from 'react'\n\nimport type { IconOptions, IconProps } from './icon.types'\n\nconst StyledSvg = styled.svg<IconOptions>(({ theme, color = 'default' }) => ({\n color: color === 'currentColor' ? 'currentcolor' : theme.colors.icon[color],\n display: 'inline-block',\n lineHeight: '1em',\n}))\n\nexport interface CreateIconOptions {\n /**\n * The `svg`'s `viewBox` attribute\n */\n viewBox: string\n /**\n * If the `svg` has a single path, simply copy the path's `d` attribute\n */\n d?: string\n /**\n * The `svg` path or group element\n *\n * @example\n * ```jsx\n * createIcon({\n * viewBox: '0 0 512 512',\n * path: [\n * <circle cx=\"50\" cy=\"50\" r=\"50\" />,\n * <path d=\"M10 10\" />,\n * ],\n * displayName: 'ExampleIcon',\n * })\n * ```\n */\n path?: React.ReactElement | React.ReactElement[]\n /**\n * The display name of the icon. Useful for debugging\n * and internal use.\n */\n displayName?: string\n}\n\n/**\n * Helper function to create an icon component.\n */\nexport const createIcon = (options: CreateIconOptions) => {\n const { viewBox, d: pathDefinition, displayName = 'UnnamedIcon' } = options\n const path = Children.toArray(options.path)\n\n const Component = forwardRef<SVGSVGElement, IconProps>((props, forwardedRef) => {\n const { size = 24, ...rest } = props\n return (\n <StyledSvg\n ref={forwardedRef}\n xmlns=\"http://www.w3.org/2000/svg\"\n width={size}\n height={size}\n focusable=\"false\"\n viewBox={viewBox}\n fill=\"currentColor\"\n {...rest}\n >\n {path.length ? path : <path fill=\"currentColor\" d={pathDefinition} />}\n </StyledSvg>\n )\n })\n\n Component.displayName = displayName\n\n return Component\n}\n","import { useTheme } from '@emotion/react'\nimport type { LucideIcon } from 'lucide-react'\nimport { forwardRef } from 'react'\n\nimport type { IconProps } from './icon.types'\n\nexport const createLucideIcon = (Icon: LucideIcon) => {\n const Component = forwardRef<SVGSVGElement, IconProps>(\n ({ size = 24, color = 'default', ...props }, ref) => {\n const theme = useTheme()\n const resolvedColor = color === 'currentColor' ? 'currentcolor' : theme.colors.icon[color]\n\n return (\n <Icon\n ref={ref}\n size={size}\n strokeWidth={2}\n // Always keep a minimum stroke width of 2px\n absoluteStrokeWidth={size < 24}\n color={resolvedColor}\n {...props}\n />\n )\n },\n )\n\n Component.displayName = Icon.displayName\n\n return Component\n}\n","import { CamelToPascal } from './utility-types';\n\n/**\n * Converts string to kebab case\n *\n * @param {string} string\n * @returns {string} A kebabized string\n */\nexport const toKebabCase = (string: string) =>\n string.replace(/([a-z0-9])([A-Z])/g, '$1-$2').toLowerCase();\n\n/**\n * Converts string to camel case\n *\n * @param {string} string\n * @returns {string} A camelized string\n */\nexport const toCamelCase = <T extends string>(string: T) =>\n string.replace(/^([A-Z])|[\\s-_]+(\\w)/g, (match, p1, p2) =>\n p2 ? p2.toUpperCase() : p1.toLowerCase(),\n );\n\n/**\n * Converts string to pascal case\n *\n * @param {string} string\n * @returns {string} A pascalized string\n */\nexport const toPascalCase = <T extends string>(string: T): CamelToPascal<T> => {\n const camelCase = toCamelCase(string);\n\n return (camelCase.charAt(0).toUpperCase() + camelCase.slice(1)) as CamelToPascal<T>;\n};\n\n/**\n * Merges classes into a single string\n *\n * @param {array} classes\n * @returns {string} A string of classes\n */\nexport const mergeClasses = <ClassType = string | undefined | null>(...classes: ClassType[]) =>\n classes\n .filter((className, index, array) => {\n return (\n Boolean(className) &&\n (className as string).trim() !== '' &&\n array.indexOf(className) === index\n );\n })\n .join(' ')\n .trim();\n","export default {\n xmlns: 'http://www.w3.org/2000/svg',\n width: 24,\n height: 24,\n viewBox: '0 0 24 24',\n fill: 'none',\n stroke: 'currentColor',\n strokeWidth: 2,\n strokeLinecap: 'round',\n strokeLinejoin: 'round',\n};\n","import { createElement, forwardRef } from 'react';\nimport defaultAttributes from './defaultAttributes';\nimport { IconNode, LucideProps } from './types';\nimport { mergeClasses } from '@lucide/shared';\n\ninterface IconComponentProps extends LucideProps {\n iconNode: IconNode;\n}\n\n/**\n * Lucide icon component\n *\n * @component Icon\n * @param {object} props\n * @param {string} props.color - The color of the icon\n * @param {number} props.size - The size of the icon\n * @param {number} props.strokeWidth - The stroke width of the icon\n * @param {boolean} props.absoluteStrokeWidth - Whether to use absolute stroke width\n * @param {string} props.className - The class name of the icon\n * @param {IconNode} props.children - The children of the icon\n * @param {IconNode} props.iconNode - The icon node of the icon\n *\n * @returns {ForwardRefExoticComponent} LucideIcon\n */\nconst Icon = forwardRef<SVGSVGElement, IconComponentProps>(\n (\n {\n color = 'currentColor',\n size = 24,\n strokeWidth = 2,\n absoluteStrokeWidth,\n className = '',\n children,\n iconNode,\n ...rest\n },\n ref,\n ) => {\n return createElement(\n 'svg',\n {\n ref,\n ...defaultAttributes,\n width: size,\n height: size,\n stroke: color,\n strokeWidth: absoluteStrokeWidth ? (Number(strokeWidth) * 24) / Number(size) : strokeWidth,\n className: mergeClasses('lucide', className),\n ...rest,\n },\n [\n ...iconNode.map(([tag, attrs]) => createElement(tag, attrs)),\n ...(Array.isArray(children) ? children : [children]),\n ],\n );\n },\n);\n\nexport default Icon;\n","import { createElement, forwardRef } from 'react';\nimport { mergeClasses, toKebabCase } from '@lucide/shared';\nimport { IconNode, LucideProps } from './types';\nimport Icon from './Icon';\n\n/**\n * Create a Lucide icon component\n * @param {string} iconName\n * @param {array} iconNode\n * @returns {ForwardRefExoticComponent} LucideIcon\n */\nconst createLucideIcon = (iconName: string, iconNode: IconNode) => {\n const Component = forwardRef<SVGSVGElement, LucideProps>(({ className, ...props }, ref) =>\n createElement(Icon, {\n ref,\n iconNode,\n className: mergeClasses(`lucide-${toKebabCase(iconName)}`, className),\n ...props,\n }),\n );\n\n Component.displayName = `${iconName}`;\n\n return Component;\n};\n\nexport default createLucideIcon;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'M12 5v14', key: 's699le' }],\n ['path', { d: 'm19 12-7 7-7-7', key: '1idqje' }],\n];\n\n/**\n * @component @name ArrowDown\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/arrow-down\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst ArrowDown = createLucideIcon('ArrowDown', __iconNode);\n\nexport default ArrowDown;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'm12 19-7-7 7-7', key: '1l729n' }],\n ['path', { d: 'M19 12H5', key: 'x3x0zl' }],\n];\n\n/**\n * @component @name ArrowLeft\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/arrow-left\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst ArrowLeft = createLucideIcon('ArrowLeft', __iconNode);\n\nexport default ArrowLeft;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'M5 12h14', key: '1ays0h' }],\n ['path', { d: 'm12 5 7 7-7 7', key: 'xquz4c' }],\n];\n\n/**\n * @component @name ArrowRight\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/arrow-right\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst ArrowRight = createLucideIcon('ArrowRight', __iconNode);\n\nexport default ArrowRight;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'm5 12 7-7 7 7', key: 'hav0vg' }],\n ['path', { d: 'M12 19V5', key: 'x0mq9r' }],\n];\n\n/**\n * @component @name ArrowUp\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/arrow-up\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst ArrowUp = createLucideIcon('ArrowUp', __iconNode);\n\nexport default ArrowUp;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'M10.268 21a2 2 0 0 0 3.464 0', key: 'vwvbt9' }],\n [\n 'path',\n {\n d: 'M17 17H4a1 1 0 0 1-.74-1.673C4.59 13.956 6 12.499 6 8a6 6 0 0 1 .258-1.742',\n key: '178tsu',\n },\n ],\n ['path', { d: 'm2 2 20 20', key: '1ooewy' }],\n ['path', { d: 'M8.668 3.01A6 6 0 0 1 18 8c0 2.687.77 4.653 1.707 6.05', key: '1hqiys' }],\n];\n\n/**\n * @component @name BellOff\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/bell-off\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst BellOff = createLucideIcon('BellOff', __iconNode);\n\nexport default BellOff;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'M10.268 21a2 2 0 0 0 3.464 0', key: 'vwvbt9' }],\n [\n 'path',\n {\n d: 'M3.262 15.326A1 1 0 0 0 4 17h16a1 1 0 0 0 .74-1.673C19.41 13.956 18 12.499 18 8A6 6 0 0 0 6 8c0 4.499-1.411 5.956-2.738 7.326',\n key: '11g9vi',\n },\n ],\n];\n\n/**\n * @component @name Bell\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/bell\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Bell = createLucideIcon('Bell', __iconNode);\n\nexport default Bell;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'm19 21-7-4-7 4V5a2 2 0 0 1 2-2h10a2 2 0 0 1 2 2v16z', key: '1fy3hk' }],\n];\n\n/**\n * @component @name Bookmark\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/bookmark\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Bookmark = createLucideIcon('Bookmark', __iconNode);\n\nexport default Bookmark;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'M8 2v4', key: '1cmpym' }],\n ['path', { d: 'M16 2v4', key: '4m81vk' }],\n ['rect', { width: '18', height: '18', x: '3', y: '4', rx: '2', key: '1hopcy' }],\n ['path', { d: 'M3 10h18', key: '8toen8' }],\n];\n\n/**\n * @component @name Calendar\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/calendar\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Calendar = createLucideIcon('Calendar', __iconNode);\n\nexport default Calendar;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n [\n 'path',\n {\n d: 'M14.5 4h-5L7 7H4a2 2 0 0 0-2 2v9a2 2 0 0 0 2 2h16a2 2 0 0 0 2-2V9a2 2 0 0 0-2-2h-3l-2.5-3z',\n key: '1tc9qg',\n },\n ],\n ['circle', { cx: '12', cy: '13', r: '3', key: '1vg3eu' }],\n];\n\n/**\n * @component @name Camera\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/camera\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Camera = createLucideIcon('Camera', __iconNode);\n\nexport default Camera;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [['path', { d: 'M20 6 9 17l-5-5', key: '1gmf2c' }]];\n\n/**\n * @component @name Check\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/check\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Check = createLucideIcon('Check', __iconNode);\n\nexport default Check;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [['path', { d: 'm6 9 6 6 6-6', key: 'qrunsl' }]];\n\n/**\n * @component @name ChevronDown\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/chevron-down\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst ChevronDown = createLucideIcon('ChevronDown', __iconNode);\n\nexport default ChevronDown;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [['path', { d: 'm15 18-6-6 6-6', key: '1wnfg3' }]];\n\n/**\n * @component @name ChevronLeft\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/chevron-left\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst ChevronLeft = createLucideIcon('ChevronLeft', __iconNode);\n\nexport default ChevronLeft;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [['path', { d: 'm9 18 6-6-6-6', key: 'mthhwq' }]];\n\n/**\n * @component @name ChevronRight\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/chevron-right\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst ChevronRight = createLucideIcon('ChevronRight', __iconNode);\n\nexport default ChevronRight;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [['path', { d: 'm18 15-6-6-6 6', key: '153udz' }]];\n\n/**\n * @component @name ChevronUp\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/chevron-up\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst ChevronUp = createLucideIcon('ChevronUp', __iconNode);\n\nexport default ChevronUp;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['circle', { cx: '12', cy: '12', r: '10', key: '1mglay' }],\n ['line', { x1: '12', x2: '12', y1: '8', y2: '12', key: '1pkeuh' }],\n ['line', { x1: '12', x2: '12.01', y1: '16', y2: '16', key: '4dfq90' }],\n];\n\n/**\n * @component @name CircleAlert\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/circle-alert\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst CircleAlert = createLucideIcon('CircleAlert', __iconNode);\n\nexport default CircleAlert;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['circle', { cx: '12', cy: '12', r: '10', key: '1mglay' }],\n ['path', { d: 'm9 12 2 2 4-4', key: 'dzmm74' }],\n];\n\n/**\n * @component @name CircleCheck\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/circle-check\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst CircleCheck = createLucideIcon('CircleCheck', __iconNode);\n\nexport default CircleCheck;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['circle', { cx: '12', cy: '12', r: '10', key: '1mglay' }],\n ['path', { d: 'M9.09 9a3 3 0 0 1 5.83 1c0 2-3 3-3 3', key: '1u773s' }],\n ['path', { d: 'M12 17h.01', key: 'p32p05' }],\n];\n\n/**\n * @component @name CircleHelp\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/circle-help\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst CircleHelp = createLucideIcon('CircleHelp', __iconNode);\n\nexport default CircleHelp;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['circle', { cx: '12', cy: '12', r: '10', key: '1mglay' }],\n ['path', { d: 'm15 9-6 6', key: '1uzhvr' }],\n ['path', { d: 'm9 9 6 6', key: 'z0biqf' }],\n];\n\n/**\n * @component @name CircleX\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/circle-x\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst CircleX = createLucideIcon('CircleX', __iconNode);\n\nexport default CircleX;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['circle', { cx: '12', cy: '12', r: '1', key: '41hilf' }],\n ['circle', { cx: '12', cy: '5', r: '1', key: 'gxeob9' }],\n ['circle', { cx: '12', cy: '19', r: '1', key: 'lyex9k' }],\n];\n\n/**\n * @component @name EllipsisVertical\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/ellipsis-vertical\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst EllipsisVertical = createLucideIcon('EllipsisVertical', __iconNode);\n\nexport default EllipsisVertical;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['circle', { cx: '12', cy: '12', r: '1', key: '41hilf' }],\n ['circle', { cx: '19', cy: '12', r: '1', key: '1wjl8i' }],\n ['circle', { cx: '5', cy: '12', r: '1', key: '1pcz8c' }],\n];\n\n/**\n * @component @name Ellipsis\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/ellipsis\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Ellipsis = createLucideIcon('Ellipsis', __iconNode);\n\nexport default Ellipsis;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['circle', { cx: '12', cy: '12', r: '10', key: '1mglay' }],\n ['path', { d: 'M12 2a14.5 14.5 0 0 0 0 20 14.5 14.5 0 0 0 0-20', key: '13o1zl' }],\n ['path', { d: 'M2 12h20', key: '9i4pu4' }],\n];\n\n/**\n * @component @name Globe\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/globe\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Globe = createLucideIcon('Globe', __iconNode);\n\nexport default Globe;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n [\n 'path',\n {\n d: 'M19 14c1.49-1.46 3-3.21 3-5.5A5.5 5.5 0 0 0 16.5 3c-1.76 0-3 .5-4.5 2-1.5-1.5-2.74-2-4.5-2A5.5 5.5 0 0 0 2 8.5c0 2.3 1.5 4.05 3 5.5l7 7Z',\n key: 'c3ymky',\n },\n ],\n];\n\n/**\n * @component @name Heart\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/heart\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Heart = createLucideIcon('Heart', __iconNode);\n\nexport default Heart;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'M3 12a9 9 0 1 0 9-9 9.75 9.75 0 0 0-6.74 2.74L3 8', key: '1357e3' }],\n ['path', { d: 'M3 3v5h5', key: '1xhq8a' }],\n ['path', { d: 'M12 7v5l4 2', key: '1fdv2h' }],\n];\n\n/**\n * @component @name History\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/history\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst History = createLucideIcon('History', __iconNode);\n\nexport default History;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'M15 21v-8a1 1 0 0 0-1-1h-4a1 1 0 0 0-1 1v8', key: '5wwlr5' }],\n [\n 'path',\n {\n d: 'M3 10a2 2 0 0 1 .709-1.528l7-5.999a2 2 0 0 1 2.582 0l7 5.999A2 2 0 0 1 21 10v9a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2z',\n key: '1d0kgt',\n },\n ],\n];\n\n/**\n * @component @name House\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/house\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst House = createLucideIcon('House', __iconNode);\n\nexport default House;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['rect', { width: '18', height: '18', x: '3', y: '3', rx: '2', ry: '2', key: '1m3agn' }],\n ['circle', { cx: '9', cy: '9', r: '2', key: 'af1f0g' }],\n ['path', { d: 'm21 15-3.086-3.086a2 2 0 0 0-2.828 0L6 21', key: '1xmnt7' }],\n];\n\n/**\n * @component @name Image\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/image\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Image = createLucideIcon('Image', __iconNode);\n\nexport default Image;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['circle', { cx: '12', cy: '12', r: '10', key: '1mglay' }],\n ['path', { d: 'M12 16v-4', key: '1dtifu' }],\n ['path', { d: 'M12 8h.01', key: 'e9boi3' }],\n];\n\n/**\n * @component @name Info\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/info\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Info = createLucideIcon('Info', __iconNode);\n\nexport default Info;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'M3 6h18', key: 'd0wm0j' }],\n ['path', { d: 'M7 12h10', key: 'b7w52i' }],\n ['path', { d: 'M10 18h4', key: '1ulq68' }],\n];\n\n/**\n * @component @name ListFilter\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/list-filter\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst ListFilter = createLucideIcon('ListFilter', __iconNode);\n\nexport default ListFilter;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'M3 12h.01', key: 'nlz23k' }],\n ['path', { d: 'M3 18h.01', key: '1tta3j' }],\n ['path', { d: 'M3 6h.01', key: '1rqtza' }],\n ['path', { d: 'M8 12h13', key: '1za7za' }],\n ['path', { d: 'M8 18h13', key: '1lx6n3' }],\n ['path', { d: 'M8 6h13', key: 'ik3vkj' }],\n];\n\n/**\n * @component @name List\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/list\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst List = createLucideIcon('List', __iconNode);\n\nexport default List;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'M9 21H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h4', key: '1uf3rs' }],\n ['polyline', { points: '16 17 21 12 16 7', key: '1gabdz' }],\n ['line', { x1: '21', x2: '9', y1: '12', y2: '12', key: '1uyos4' }],\n];\n\n/**\n * @component @name LogOut\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/log-out\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst LogOut = createLucideIcon('LogOut', __iconNode);\n\nexport default LogOut;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n [\n 'path',\n {\n d: 'M20 10c0 4.993-5.539 10.193-7.399 11.799a1 1 0 0 1-1.202 0C9.539 20.193 4 14.993 4 10a8 8 0 0 1 16 0',\n key: '1r0f0z',\n },\n ],\n ['circle', { cx: '12', cy: '10', r: '3', key: 'ilqhr7' }],\n];\n\n/**\n * @component @name MapPin\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/map-pin\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst MapPin = createLucideIcon('MapPin', __iconNode);\n\nexport default MapPin;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n [\n 'path',\n {\n d: 'M14.106 5.553a2 2 0 0 0 1.788 0l3.659-1.83A1 1 0 0 1 21 4.619v12.764a1 1 0 0 1-.553.894l-4.553 2.277a2 2 0 0 1-1.788 0l-4.212-2.106a2 2 0 0 0-1.788 0l-3.659 1.83A1 1 0 0 1 3 19.381V6.618a1 1 0 0 1 .553-.894l4.553-2.277a2 2 0 0 1 1.788 0z',\n key: '169xi5',\n },\n ],\n ['path', { d: 'M15 5.764v15', key: '1pn4in' }],\n ['path', { d: 'M9 3.236v15', key: '1uimfh' }],\n];\n\n/**\n * @component @name Map\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/map\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Map = createLucideIcon('Map', __iconNode);\n\nexport default Map;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['line', { x1: '4', x2: '20', y1: '12', y2: '12', key: '1e0a9i' }],\n ['line', { x1: '4', x2: '20', y1: '6', y2: '6', key: '1owob3' }],\n ['line', { x1: '4', x2: '20', y1: '18', y2: '18', key: 'yk5zj1' }],\n];\n\n/**\n * @component @name Menu\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/menu\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Menu = createLucideIcon('Menu', __iconNode);\n\nexport default Menu;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'M7.9 20A9 9 0 1 0 4 16.1L2 22Z', key: 'vv11sd' }],\n];\n\n/**\n * @component @name MessageCircle\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/message-circle\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst MessageCircle = createLucideIcon('MessageCircle', __iconNode);\n\nexport default MessageCircle;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [['path', { d: 'M5 12h14', key: '1ays0h' }]];\n\n/**\n * @component @name Minus\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/minus\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Minus = createLucideIcon('Minus', __iconNode);\n\nexport default Minus;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n [\n 'path',\n {\n d: 'M21.174 6.812a1 1 0 0 0-3.986-3.987L3.842 16.174a2 2 0 0 0-.5.83l-1.321 4.352a.5.5 0 0 0 .623.622l4.353-1.32a2 2 0 0 0 .83-.497z',\n key: '1a8usu',\n },\n ],\n];\n\n/**\n * @component @name Pen\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/pen\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Pen = createLucideIcon('Pen', __iconNode);\n\nexport default Pen;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'M5 12h14', key: '1ays0h' }],\n ['path', { d: 'M12 5v14', key: 's699le' }],\n];\n\n/**\n * @component @name Plus\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/plus\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Plus = createLucideIcon('Plus', __iconNode);\n\nexport default Plus;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['circle', { cx: '11', cy: '11', r: '8', key: '4ej97u' }],\n ['path', { d: 'm21 21-4.3-4.3', key: '1qie3q' }],\n];\n\n/**\n * @component @name Search\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/search\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Search = createLucideIcon('Search', __iconNode);\n\nexport default Search;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'M20 7h-9', key: '3s1dr2' }],\n ['path', { d: 'M14 17H5', key: 'gfn3mx' }],\n ['circle', { cx: '17', cy: '17', r: '3', key: '18b49y' }],\n ['circle', { cx: '7', cy: '7', r: '3', key: 'dfmy0x' }],\n];\n\n/**\n * @component @name Settings2\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/settings-2\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Settings2 = createLucideIcon('Settings2', __iconNode);\n\nexport default Settings2;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n [\n 'path',\n {\n d: 'M12.22 2h-.44a2 2 0 0 0-2 2v.18a2 2 0 0 1-1 1.73l-.43.25a2 2 0 0 1-2 0l-.15-.08a2 2 0 0 0-2.73.73l-.22.38a2 2 0 0 0 .73 2.73l.15.1a2 2 0 0 1 1 1.72v.51a2 2 0 0 1-1 1.74l-.15.09a2 2 0 0 0-.73 2.73l.22.38a2 2 0 0 0 2.73.73l.15-.08a2 2 0 0 1 2 0l.43.25a2 2 0 0 1 1 1.73V20a2 2 0 0 0 2 2h.44a2 2 0 0 0 2-2v-.18a2 2 0 0 1 1-1.73l.43-.25a2 2 0 0 1 2 0l.15.08a2 2 0 0 0 2.73-.73l.22-.39a2 2 0 0 0-.73-2.73l-.15-.08a2 2 0 0 1-1-1.74v-.5a2 2 0 0 1 1-1.74l.15-.09a2 2 0 0 0 .73-2.73l-.22-.38a2 2 0 0 0-2.73-.73l-.15.08a2 2 0 0 1-2 0l-.43-.25a2 2 0 0 1-1-1.73V4a2 2 0 0 0-2-2z',\n key: '1qme2f',\n },\n ],\n ['circle', { cx: '12', cy: '12', r: '3', key: '1v7zrd' }],\n];\n\n/**\n * @component @name Settings\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/settings\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Settings = createLucideIcon('Settings', __iconNode);\n\nexport default Settings;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'M4 12v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2v-8', key: '1b2hhj' }],\n ['polyline', { points: '16 6 12 2 8 6', key: 'm901s6' }],\n ['line', { x1: '12', x2: '12', y1: '2', y2: '15', key: '1p0rca' }],\n];\n\n/**\n * @component @name Share\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/share\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Share = createLucideIcon('Share', __iconNode);\n\nexport default Share;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n [\n 'path',\n {\n d: 'M11.525 2.295a.53.53 0 0 1 .95 0l2.31 4.679a2.123 2.123 0 0 0 1.595 1.16l5.166.756a.53.53 0 0 1 .294.904l-3.736 3.638a2.123 2.123 0 0 0-.611 1.878l.882 5.14a.53.53 0 0 1-.771.56l-4.618-2.428a2.122 2.122 0 0 0-1.973 0L6.396 21.01a.53.53 0 0 1-.77-.56l.881-5.139a2.122 2.122 0 0 0-.611-1.879L2.16 9.795a.53.53 0 0 1 .294-.906l5.165-.755a2.122 2.122 0 0 0 1.597-1.16z',\n key: 'r04s7s',\n },\n ],\n];\n\n/**\n * @component @name Star\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/star\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Star = createLucideIcon('Star', __iconNode);\n\nexport default Star;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'M3 6h18', key: 'd0wm0j' }],\n ['path', { d: 'M19 6v14c0 1-1 2-2 2H7c-1 0-2-1-2-2V6', key: '4alrt4' }],\n ['path', { d: 'M8 6V4c0-1 1-2 2-2h4c1 0 2 1 2 2v2', key: 'v07s0e' }],\n ['line', { x1: '10', x2: '10', y1: '11', y2: '17', key: '1uufr5' }],\n ['line', { x1: '14', x2: '14', y1: '11', y2: '17', key: 'xtxkd' }],\n];\n\n/**\n * @component @name Trash2\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/trash-2\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Trash2 = createLucideIcon('Trash2', __iconNode);\n\nexport default Trash2;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n [\n 'path',\n {\n d: 'm21.73 18-8-14a2 2 0 0 0-3.48 0l-8 14A2 2 0 0 0 4 21h16a2 2 0 0 0 1.73-3',\n key: 'wmoenq',\n },\n ],\n ['path', { d: 'M12 9v4', key: 'juzpu7' }],\n ['path', { d: 'M12 17h.01', key: 'p32p05' }],\n];\n\n/**\n * @component @name TriangleAlert\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/triangle-alert\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst TriangleAlert = createLucideIcon('TriangleAlert', __iconNode);\n\nexport default TriangleAlert;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['circle', { cx: '12', cy: '8', r: '5', key: '1hypcn' }],\n ['path', { d: 'M20 21a8 8 0 0 0-16 0', key: 'rfgkzh' }],\n];\n\n/**\n * @component @name UserRound\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/user-round\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst UserRound = createLucideIcon('UserRound', __iconNode);\n\nexport default UserRound;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'M18 6 6 18', key: '1bl5f8' }],\n ['path', { d: 'm6 6 12 12', key: 'd8bk6v' }],\n];\n\n/**\n * @component @name X\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/x\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst X = createLucideIcon('X', __iconNode);\n\nexport default X;\n","import {\n AlertCircle,\n AlertTriangle,\n ArrowDown,\n ArrowLeft,\n ArrowRight,\n ArrowUp,\n Bell,\n BellOff,\n Bookmark,\n Calendar,\n Camera,\n Check,\n CheckCircle2,\n ChevronDown,\n ChevronLeft,\n ChevronRight,\n ChevronUp,\n Globe,\n Heart,\n HelpCircle,\n History,\n Home,\n Image,\n Info,\n List,\n ListFilter,\n LogOut,\n Map,\n MapPin,\n Menu,\n MessageCircle,\n Minus,\n MoreHorizontal,\n MoreVertical,\n Pen,\n Plus,\n Search,\n Settings,\n Settings2,\n Share,\n Star,\n Trash2,\n UserRound,\n X,\n XCircle,\n} from 'lucide-react'\n\nimport { createIcon } from './create-icon'\nimport { createLucideIcon } from './create-lucide-icon'\n\nexport const AlertCircleIcon = createLucideIcon(AlertCircle)\nexport const AlertTriangleIcon = createLucideIcon(AlertTriangle)\nexport const ArrowDownIcon = createLucideIcon(ArrowDown)\nexport const ArrowLeftIcon = createLucideIcon(ArrowLeft)\nexport const ArrowRightIcon = createLucideIcon(ArrowRight)\nexport const ArrowUpIcon = createLucideIcon(ArrowUp)\nexport const BellIcon = createLucideIcon(Bell)\nexport const BellOffIcon = createLucideIcon(BellOff)\nexport const BookmarkIcon = createLucideIcon(Bookmark)\nexport const CalendarIcon = createLucideIcon(Calendar)\nexport const CameraIcon = createLucideIcon(Camera)\nexport const CheckCircleIcon = createLucideIcon(CheckCircle2)\nexport const CheckIcon = createLucideIcon(Check)\nexport const ChevronDownIcon = createLucideIcon(ChevronDown)\nexport const ChevronLeftIcon = createLucideIcon(ChevronLeft)\nexport const ChevronRightIcon = createLucideIcon(ChevronRight)\nexport const ChevronUpIcon = createLucideIcon(ChevronUp)\nexport const GlobeIcon = createLucideIcon(Globe)\n/* Custom icon based on Lucide's heart icon. */\nexport const HeartFilledIcon = createIcon({\n viewBox: '0 0 24 24',\n d: 'M2.90381 3.90381C4.12279 2.68482 5.77609 2 7.5 2C8.48018 2 9.37318 2.14018 10.2468 2.52068C10.8597 2.78762 11.4321 3.15937 12 3.63935C12.5679 3.15937 13.1403 2.78762 13.7532 2.52068C14.6268 2.14018 15.5198 2 16.5 2C18.2239 2 19.8772 2.68482 21.0962 3.90381C22.3152 5.12279 23 6.77609 23 8.5C23 11.2418 21.1906 13.2531 19.7035 14.7107L12.7071 21.7071C12.3166 22.0976 11.6834 22.0976 11.2929 21.7071L4.29885 14.7131C2.79442 13.258 1 11.2494 1 8.5C1 6.77609 1.68482 5.12279 2.90381 3.90381Z',\n displayName: 'HeartFilledIcon',\n})\nexport const HeartIcon = createLucideIcon(Heart)\nexport const HelpCircleIcon = createLucideIcon(HelpCircle)\nexport const HistoryIcon = createLucideIcon(History)\nexport const HomeIcon = createLucideIcon(Home)\nexport const ImageIcon = createLucideIcon(Image)\nexport const InfoIcon = createLucideIcon(Info)\nexport const ListIcon = createLucideIcon(List)\nexport const ListFilterIcon = createLucideIcon(ListFilter)\nexport const LogOutIcon = createLucideIcon(LogOut)\nexport const MapIcon = createLucideIcon(Map)\nexport const MapPinIcon = createLucideIcon(MapPin)\nexport const MenuIcon = createLucideIcon(Menu)\nexport const MessageCircleIcon = createLucideIcon(MessageCircle)\nexport const MinusIcon = createLucideIcon(Minus)\nexport const MoreHorizontalIcon = createLucideIcon(MoreHorizontal)\nexport const MoreVerticalIcon = createLucideIcon(MoreVertical)\nexport const PenIcon = createLucideIcon(Pen)\nexport const PlusIcon = createLucideIcon(Plus)\nexport const SearchIcon = createLucideIcon(Search)\nexport const SettingsIcon = createLucideIcon(Settings)\nexport const ShareIcon = createLucideIcon(Share)\nexport const SlidersIcon = createLucideIcon(Settings2)\n/* Custom icon based on Lucide's star icon. */\nexport const StarFilledIcon = createIcon({\n viewBox: '0 0 24 24',\n d: 'M12 1C12.3806 1 12.7282 1.21607 12.8967 1.55738L15.7543 7.34647L22.1446 8.28051C22.5212 8.33555 22.8339 8.59956 22.9512 8.96157C23.0686 9.32358 22.9703 9.72083 22.6977 9.98636L18.0745 14.4894L19.1656 20.851C19.23 21.2261 19.0757 21.6053 18.7677 21.8291C18.4598 22.0528 18.0515 22.0823 17.7145 21.9051L12 18.8998L6.28545 21.9051C5.94853 22.0823 5.54024 22.0528 5.23226 21.8291C4.92429 21.6053 4.77004 21.2261 4.83439 20.851L5.92548 14.4894L1.30227 9.98636C1.02965 9.72083 0.931375 9.32358 1.04875 8.96157C1.16613 8.59956 1.47881 8.33555 1.85537 8.28051L8.24574 7.34647L11.1033 1.55738C11.2718 1.21607 11.6194 1 12 1Z',\n displayName: 'StarFilledIcon',\n})\n\nexport const StarIcon = createLucideIcon(Star)\nexport const TrashIcon = createLucideIcon(Trash2)\nexport const UserIcon = createLucideIcon(UserRound)\nexport const XCircleIcon = createLucideIcon(XCircle)\nexport const XIcon = createLucideIcon(X)\n","import { createStyleVariants } from '../../styles'\nimport type { VariantProps } from '../../styles'\n\nexport const getVariantStyles = createStyleVariants(({ colors }) => ({\n neutral: {\n background: colors.core.black,\n color: colors.core.white,\n },\n error: {\n background: colors.bg.negative,\n color: colors.core.white,\n },\n}))\nexport type ToastVariant = VariantProps<typeof getVariantStyles>\n","import styled from '@emotion/styled'\nimport isPropValid from '@emotion/is-prop-valid'\nimport { forwardRef } from 'react'\nimport { UserRound } from 'lucide-react'\nimport * as AvatarPrimitive from '@radix-ui/react-avatar'\n\nimport type { HTMLQdsProps } from '../../types'\nimport { toMediaQueries, type ResponsiveProp } from '../../styles/responsive'\n\nconst SIZE_MAP = {\n xs: 32,\n sm: 40,\n md: 48,\n lg: 64,\n xl: 96,\n '2xl': 128,\n}\n\ntype AvatarSize = keyof typeof SIZE_MAP\n\nconst ICON_SIZE_MAP = {\n xs: 14,\n sm: 16,\n md: 20,\n lg: 32,\n xl: 48,\n '2xl': 64,\n}\n\nconst TEXT_SIZE_MAP = {\n xs: 12,\n sm: 16,\n md: 20,\n lg: 28,\n xl: 40,\n '2xl': 56,\n}\n\nconst getInitials = (name: string) => {\n const names = name.trim().split(/\\s+/)\n\n const firstName = names[0]\n const lastName = names.length > 1 ? names[names.length - 1] : ''\n\n // `charAt(0)` returns empty string if name is empty\n return `${firstName.charAt(0)}${lastName.charAt(0)}`.toUpperCase()\n}\n\ninterface WrapperProps {\n size: ResponsiveProp<AvatarSize>\n}\nconst AvatarRoot = styled(AvatarPrimitive.Root)<WrapperProps>(({ theme, size }) => ({\n ...toMediaQueries(size, (currentValue) => ({\n width: SIZE_MAP[currentValue],\n height: SIZE_MAP[currentValue],\n })),\n flexShrink: 0,\n borderRadius: theme.radii.full,\n background: theme.colors.core.gray20,\n overflow: 'hidden',\n display: 'flex',\n justifyContent: 'center',\n alignItems: 'center',\n boxShadow: `0 0 0 1px ${theme.colors.core.blackAlpha5}`,\n color: theme.colors.text.subtle,\n}))\n\nconst AvatarImage = styled(AvatarPrimitive.Image)({\n width: '100%',\n height: '100%',\n objectFit: 'cover',\n})\n\nconst AvatarFallback = styled(AvatarPrimitive.Fallback)(({ theme }) => ({\n color: theme.colors.text.subtle,\n}))\n\ninterface FallbackTextProps {\n avatarSize: ResponsiveProp<AvatarSize>\n}\nconst FallbackText = styled.span<FallbackTextProps>(({ avatarSize }) => ({\n fontWeight: 'bold',\n ...toMediaQueries(avatarSize, (currentValue) => ({\n fontSize: TEXT_SIZE_MAP[currentValue],\n })),\n // To optically align the text in the center\n paddingTop: '0.08em',\n display: 'block',\n // User should never need to select this text\n // so shouldn't cause any accessibility issues\n userSelect: 'none',\n}))\n\nconst roundToTwoDecimals = (num: number) => Math.round(num * 100) / 100\n\ninterface IconProps {\n avatarSize: ResponsiveProp<AvatarSize>\n}\nconst StyledIcon = styled(UserRound, { shouldForwardProp: isPropValid })<IconProps>(\n ({ avatarSize }) => ({\n ...toMediaQueries(avatarSize, (currentValue) => {\n const size = ICON_SIZE_MAP[currentValue]\n\n return {\n width: size,\n height: size,\n // Always set a minimum stroke width of 2px.\n // If the size is less than 24px, scale the stroke width up\n // to compensate for the scaling down of the icon.\n ...(size < 24 && {\n strokeWidth: roundToTwoDecimals((24 / size) * 2),\n }),\n }\n }),\n }),\n)\n\ninterface AvatarOptions {\n /**\n * Source url of the image to display. If not passed\n * it will display a fallback icon.\n */\n src?: string\n /**\n * Name of the user. Used to generate the initials\n * if no image is provided, but also for accessibility.\n */\n name?: string\n /**\n * Size of the avatar\n * @default 'md'\n */\n size?: ResponsiveProp<AvatarSize>\n}\n\nexport interface AvatarProps extends HTMLQdsProps<'span'>, AvatarOptions {}\nexport const Avatar = forwardRef<HTMLSpanElement, AvatarProps>((props, forwardedRef) => {\n const { src, name, size = 'md', ...restProps } = props\n return (\n <AvatarRoot ref={forwardedRef} size={size} {...restProps}>\n <AvatarImage src={src} alt={name} />\n <AvatarFallback delayMs={src ? 200 : undefined}>\n {name ? (\n <FallbackText avatarSize={size}>{getInitials(name)}</FallbackText>\n ) : (\n <StyledIcon avatarSize={size} role=\"img\" aria-label={name} />\n )}\n </AvatarFallback>\n </AvatarRoot>\n )\n})\n","import type { CSSObject } from '@emotion/react'\n\nimport { theme, type Theme } from '../theme'\nimport type { PartialRecord } from '../types'\n\ntype BreakpointsConfig<T> = PartialRecord<keyof Theme['breakpoints'], T> & { base: T }\nexport type ResponsiveProp<T> = T | BreakpointsConfig<T>\n\nfunction isResponsiveProp<T>(value: ResponsiveProp<T>): value is BreakpointsConfig<T> {\n return value && typeof value === 'object' && 'base' in value\n}\n\n/**\n * More strictly typed version of Object.entries\n */\nconst objectEntries = <T extends object>(obj: T) => Object.entries(obj) as [keyof T, T[keyof T]][]\n\n/**\n *\n * @param prop Responsive prop\n * @param styleFn Function that returns a CSSObject based on the value of the prop\n * for a given breakpoint.\n *\n * Example:\n * ```ts\n * toMediaQueries(variant, (currentValue) => ({\n * background: currentValue === 'primary' ? 'pink' : 'blue',\n * }))\n * ```\n * @returns CSSObject\n */\nexport const toMediaQueries = <T>(prop: ResponsiveProp<T>, styleFn: (value: T) => CSSObject) => {\n if (!isResponsiveProp(prop)) {\n return styleFn(prop)\n }\n\n const { base, ...breakpoints } = prop\n\n /**\n * Due to some very hard to debug issue,\n * we need to use `let` and reassign the value.\n * Else it leads to messed up CSS styles in SSR.\n * I have no clue, but if it works, it works.\n */\n let cssObject = styleFn(base)\n\n objectEntries(breakpoints).forEach(([breakpoint, value]) => {\n const mediaQuery = theme.mediaQueries[`${breakpoint}Up`]\n\n if (value) {\n cssObject = {\n ...cssObject,\n [mediaQuery]: styleFn(value),\n }\n }\n })\n\n return cssObject\n}\n","import styled from '@emotion/styled'\nimport { forwardRef } from 'react'\nimport isPropValid from '@emotion/is-prop-valid'\n\nimport type * as Polymorphic from '../../utils/polymorphic'\nimport { LoadingDots } from '../loading-dots'\nimport { toMediaQueries, type ResponsiveProp } from '../../styles/responsive'\n\nimport type { ButtonSize, ButtonVariant } from './button-styles'\nimport { getSizeStyles, getVariantStyles } from './button-styles'\nimport type { ButtonOptions } from './button-types'\nimport { ButtonIcon } from './button-icon'\n\ninterface StyledButtonProps {\n size: ResponsiveProp<ButtonSize>\n variant: ButtonVariant\n isFullWidth: boolean\n}\nconst StyledButton = styled('button', { shouldForwardProp: isPropValid })<StyledButtonProps>(\n ({ theme, size, variant, isFullWidth }) => ({\n borderRadius: theme.radii.full,\n display: 'inline-flex',\n justifyContent: 'center',\n alignItems: 'center',\n position: 'relative',\n flexShrink: 0,\n WebkitTouchCallout: 'none',\n WebkitTapHighlightColor: 'transparent',\n userSelect: 'none',\n transitionProperty: 'box-shadow, transform, opacity, background-color, color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n\n '&[disabled]': {\n opacity: 0.4,\n },\n\n '&:not([disabled]):active': {\n transform: 'scale(0.97)',\n },\n ...toMediaQueries(size, (currentValue) => getSizeStyles(theme)[currentValue]),\n ...getVariantStyles(theme)[variant],\n ...(isFullWidth && { width: '100%' }),\n }),\n)\n\nconst ButtonLoadingDots = styled(LoadingDots)({\n position: 'absolute',\n color: 'currentColor',\n})\n\ninterface ContentContainerProps {\n isHidden: boolean\n}\nconst ContentContainer = styled.span<ContentContainerProps>(({ isHidden }) => ({\n opacity: isHidden ? 0 : 1,\n display: 'flex',\n alignItems: 'center',\n}))\n\ntype PolymorphicButton = Polymorphic.ForwardRefComponent<'button', ButtonOptions>\nexport type ButtonProps = Polymorphic.PropsOf<PolymorphicButton>\n\nexport const Button = forwardRef((props, forwardedRef) => {\n const {\n as,\n children,\n // Only default the `type` if not using the as prop\n type = as ? undefined : 'button',\n size: sizeProp = 'md',\n variant = 'secondary',\n isFullWidth = false,\n isLoading = false,\n isDisabled = false,\n disabled: hasHtmlDisabledProp,\n iconLeft,\n iconRight,\n ...rest\n } = props\n\n const shouldBeDisabled = isDisabled || hasHtmlDisabledProp || isLoading\n\n return (\n <StyledButton\n as={as}\n ref={forwardedRef}\n variant={variant}\n size={sizeProp}\n isFullWidth={isFullWidth}\n disabled={shouldBeDisabled}\n type={type}\n {...rest}\n >\n <ContentContainer isHidden={isLoading}>\n {iconLeft && <ButtonIcon buttonSize={sizeProp} icon={iconLeft} placement=\"left\" />}\n {children}\n {iconRight && <ButtonIcon buttonSize={sizeProp} icon={iconRight} placement=\"right\" />}\n </ContentContainer>\n {isLoading && <ButtonLoadingDots size=\"sm\" data-testid=\"button-spinner\" />}\n </StyledButton>\n )\n}) as PolymorphicButton\n","import { keyframes } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { forwardRef } from 'react'\n\nimport type { VariantProps } from '../../styles'\nimport { createStyleVariants, pxToRem } from '../../styles'\nimport type { HTMLQdsProps } from '../../types'\nimport type { ResponsiveProp } from '../../styles/responsive'\nimport { toMediaQueries } from '../../styles/responsive'\n\nconst ANIMATION_DURATION = 1200\nconst ANIMATION_STAGGER_DELAY = 160\n\nconst getSizeStyles = createStyleVariants(() => ({\n sm: { fontSize: pxToRem(8) },\n md: { fontSize: pxToRem(16) },\n}))\ntype LoadingDotsSize = VariantProps<typeof getSizeStyles>\n\nconst Wrapper = styled.span<{ size: ResponsiveProp<LoadingDotsSize> }>(({ theme, size }) => ({\n color: theme.colors.core.brown,\n display: 'inline-flex',\n ...toMediaQueries(size, (currentValue) => getSizeStyles(theme)[currentValue]),\n // Odd value but it works better with the animation\n gap: pxToRem(6),\n}))\nconst scaleAnimation = keyframes({\n '0%, 80%, 100%': { transform: 'scale(0)' },\n '40%': { transform: 'scale(1)' },\n})\nconst Dot = styled.span({\n display: 'block',\n width: '1em',\n height: '1em',\n background: 'currentColor',\n borderRadius: 999,\n\n animationDuration: `${ANIMATION_DURATION}ms`,\n animationTimingFunction: 'ease-in-out',\n animationIterationCount: 'infinite',\n animationFillMode: 'both',\n '&:nth-of-type(2)': { animationDelay: `${ANIMATION_STAGGER_DELAY}ms` },\n '&:nth-of-type(3)': { animationDelay: `${ANIMATION_STAGGER_DELAY * 2}ms` },\n animationName: scaleAnimation,\n})\n\ninterface LoadingDotsOptions {\n size?: ResponsiveProp<LoadingDotsSize>\n}\n\nexport interface LoadingDotsProps extends HTMLQdsProps<'span'>, LoadingDotsOptions {}\n\nexport const LoadingDots = forwardRef<HTMLSpanElement, LoadingDotsProps>((props, forwardedRef) => {\n const { size = 'md', ...restProps } = props\n\n return (\n <Wrapper ref={forwardedRef} size={size} {...restProps}>\n <Dot />\n <Dot />\n <Dot />\n </Wrapper>\n )\n})\n","import type { VariantProps } from '../../styles'\nimport { pxToRem, createStyleVariants } from '../../styles'\n\n// Can't use :enabled cause it doesn't work when rendered as a link\nconst NOT_DISABLED = ':not([disabled])'\n\nexport const getSizeStyles = createStyleVariants(({ typography, spacing }) => ({\n xs: {\n height: pxToRem(32),\n paddingLeft: spacing['4x'],\n paddingRight: spacing['4x'],\n ...typography.button.sm,\n },\n sm: {\n height: pxToRem(40),\n paddingLeft: spacing['5x'],\n paddingRight: spacing['5x'],\n ...typography.button.sm,\n },\n md: {\n height: pxToRem(48),\n paddingLeft: spacing['6x'],\n paddingRight: spacing['6x'],\n ...typography.button.md,\n },\n lg: {\n height: pxToRem(56),\n paddingLeft: spacing['8x'],\n paddingRight: spacing['8x'],\n ...typography.button.md,\n },\n xl: {\n height: pxToRem(64),\n paddingLeft: spacing['8x'],\n paddingRight: spacing['8x'],\n ...typography.button.md,\n },\n}))\nexport type ButtonSize = VariantProps<typeof getSizeStyles>\n\nexport const getVariantStyles = createStyleVariants(({ colors }) => ({\n primary: {\n background: colors.bg.brandPrimary,\n color: colors.text.onBrandPrimary,\n [NOT_DISABLED]: {\n '@media(hover: hover)': {\n ':hover': {\n background: colors.bg.brandPrimaryHover,\n },\n },\n ':active': {\n background: colors.bg.brandPrimaryActive,\n },\n },\n },\n secondary: {\n background: colors.bg.brandSecondary,\n color: colors.text.onBrandSecondary,\n [NOT_DISABLED]: {\n '@media(hover: hover)': {\n ':hover': {\n background: colors.bg.brandSecondaryHover,\n },\n },\n ':active': {\n background: colors.bg.brandSecondaryActive,\n },\n },\n },\n tertiary: {\n background: colors.bg.brandTertiary,\n color: colors.text.onBrandTertiary,\n [NOT_DISABLED]: {\n '@media(hover: hover)': {\n ':hover': {\n background: colors.bg.brandTertiaryHover,\n },\n },\n ':active': {\n background: colors.bg.brandTertiaryActive,\n },\n },\n },\n}))\nexport type ButtonVariant = VariantProps<typeof getVariantStyles>\n","import styled from '@emotion/styled'\nimport type { ElementType } from 'react'\n\nimport type { Theme } from '../../theme'\nimport type { IconProps } from '../icon'\nimport { toMediaQueries, type ResponsiveProp } from '../../styles/responsive'\n\nimport type { ButtonSize } from './button-styles'\n\nconst roundToTwoDecimals = (num: number) => Math.round(num * 100) / 100\n\nconst ICON_SIZE_MAP = {\n xs: 16,\n sm: 16,\n md: 20,\n lg: 20,\n xl: 20,\n} as const\n\nconst ICON_GAP: Record<ButtonSize, keyof Theme['spacing']> = {\n xs: '2x',\n sm: '3x',\n md: '3x',\n lg: '4x',\n xl: '4x',\n}\nconst ICON_OFFSET: Record<ButtonSize, keyof Theme['spacing']> = {\n xs: '1x',\n sm: '1x',\n md: '1x',\n lg: '2x',\n xl: '2x',\n}\n\ninterface IconContainerProps {\n buttonSize: ResponsiveProp<ButtonSize>\n}\n\nconst IconLeftContainer = styled.span<IconContainerProps>(({ theme, buttonSize }) => ({\n flexShrink: 0,\n ...toMediaQueries(buttonSize, (currentValue) => {\n const iconSize = ICON_SIZE_MAP[currentValue]\n return {\n marginLeft: `-${theme.spacing[ICON_OFFSET[currentValue]]}`,\n marginRight: theme.spacing[ICON_GAP[currentValue]],\n\n '> svg': {\n width: iconSize,\n height: iconSize,\n // Always set a minimum stroke width of 2px.\n // If the size is less than 24px, scale the stroke width up\n // to compensate for the scaling down of the icon.\n ...(iconSize < 24 && {\n strokeWidth: roundToTwoDecimals((24 / iconSize) * 2),\n }),\n },\n }\n }),\n}))\nconst IconRightContainer = styled.span<IconContainerProps>(({ theme, buttonSize }) => ({\n flexShrink: 0,\n ...toMediaQueries(buttonSize, (currentValue) => {\n const iconSize = ICON_SIZE_MAP[currentValue]\n return {\n marginRight: `-${theme.spacing[ICON_OFFSET[currentValue]]}`,\n marginLeft: theme.spacing[ICON_GAP[currentValue]],\n\n '> svg': {\n width: iconSize,\n height: iconSize,\n // Always set a minimum stroke width of 2px.\n // If the size is less than 24px, scale the stroke width up\n // to compensate for the scaling down of the icon.\n ...(iconSize < 24 && {\n strokeWidth: roundToTwoDecimals((24 / iconSize) * 2),\n }),\n },\n }\n }),\n}))\n\ninterface ButtonIconProps {\n buttonSize: ResponsiveProp<ButtonSize>\n icon: ElementType<IconProps>\n placement: 'left' | 'right'\n}\nexport function ButtonIcon({ buttonSize, icon: Icon, placement }: ButtonIconProps) {\n const Container = placement === 'left' ? IconLeftContainer : IconRightContainer\n return (\n <Container buttonSize={buttonSize}>\n <Icon aria-hidden=\"true\" color=\"currentColor\" />\n </Container>\n )\n}\n","import styled from '@emotion/styled'\nimport isPropValid from '@emotion/is-prop-valid'\nimport { forwardRef } from 'react'\n\nimport type * as Polymorphic from '../../utils/polymorphic'\nimport type { Theme } from '../../theme'\nimport type { ResponsiveProp } from '../../styles/responsive'\nimport { toMediaQueries } from '../../styles/responsive'\n\ntype DisplaySize = keyof Theme['typography']['display']\n\ntype DisplayTextAlign = 'left' | 'center' | 'right'\ntype DisplayTextWrap = 'pretty' | 'balance' | 'wrap' | 'nowrap' | 'stable'\n\ninterface StyledDisplayTextProps {\n size: ResponsiveProp<DisplaySize>\n textAlign: DisplayTextAlign\n textWrap: DisplayTextWrap\n}\n\nconst StyledDisplayText = styled('h2', { shouldForwardProp: isPropValid })<StyledDisplayTextProps>(\n ({ theme, size, textAlign, textWrap }) => ({\n margin: 0,\n ...toMediaQueries(size, (currentValue) => theme.typography.display[currentValue]),\n color: theme.colors.text.default,\n textAlign,\n textWrap,\n overflowWrap: 'break-word',\n wordWrap: 'break-word',\n }),\n)\n\ninterface DisplayTextOptions {\n /**\n * Sets the visual size of the display text.\n * To override the rendered tag, use the `as` prop.\n *\n * @default 'md'\n */\n size?: ResponsiveProp<DisplaySize>\n /**\n * Sets the text alignment\n *\n * @default 'left'\n */\n textAlign?: DisplayTextAlign\n /**\n * Sets the text wrapping\n *\n * See [MDN Docs](https://developer.mozilla.org/en-US/docs/Web/CSS/text-wrap)\n *\n * @default 'pretty'\n */\n textWrap?: DisplayTextWrap\n}\n\ntype DisplayTextComponent = Polymorphic.ForwardRefComponent<'h2', DisplayTextOptions>\nexport type DisplayTextProps = Polymorphic.PropsOf<DisplayTextComponent>\n\nexport const DisplayText = forwardRef((props, forwardedRef) => {\n const { as, children, size = 'md', textAlign = 'left', textWrap = 'pretty', ...rest } = props\n return (\n <StyledDisplayText\n as={as}\n ref={forwardedRef}\n size={size}\n textAlign={textAlign}\n textWrap={textWrap}\n {...rest}\n >\n {children}\n </StyledDisplayText>\n )\n}) as DisplayTextComponent\n","import styled from '@emotion/styled'\nimport type { ReactElement } from 'react'\nimport { forwardRef } from 'react'\nimport * as CheckboxPrimitive from '@radix-ui/react-checkbox'\nimport { Check } from 'lucide-react'\n\nimport { pxToRem } from '../../styles'\nimport { useStableId } from '../../hooks'\nimport { ariaAttr, dataAttr } from '../../utils/html-attributes'\nimport { ErrorMessage, HelperText } from '../_internal'\n\nconst Wrapper = styled.div({\n width: '100%',\n display: 'flex',\n flexDirection: 'column',\n})\n\nconst CheckboxContainer = styled.label(({ theme }) => ({\n width: '100%',\n display: 'grid',\n gridTemplateColumns: 'auto 1fr',\n alignItems: 'start',\n gap: theme.spacing['3x'],\n position: 'relative',\n cursor: 'pointer',\n WebkitTapHighlightColor: 'transparent',\n WebkitTouchCallout: 'none',\n // Right now not all browsers support the `:has` pseudo-class\n // But we also set the cursor to `not-allowed` in the nested elements\n // so this just makes it so the gap between the checkbox and the text\n // doesn't have the cursor. In the future we should be able to rely\n // on this completely\n '&:has([role=\"checkbox\"][data-disabled])': {\n cursor: 'not-allowed',\n },\n}))\n\nconst CheckboxRoot = styled(CheckboxPrimitive.Root)(({ theme }) => ({\n position: 'relative',\n WebkitTapHighlightColor: 'transparent',\n WebkitTouchCallout: 'none',\n // We use margin to align the checkbox with the text\n // since `align-items: center` wouldn't work when the text wraps\n marginTop: pxToRem(1),\n display: 'flex',\n justifyContent: 'center',\n alignItems: 'center',\n width: pxToRem(20),\n height: pxToRem(20),\n flexShrink: 0,\n border: '2px solid',\n borderColor: theme.colors.border.strong,\n borderRadius: theme.radii['2xs'],\n color: 'transparent',\n transitionProperty: 'background-color, color',\n transitionDuration: '80ms',\n transitionTimingFunction: 'ease',\n '&[data-state=\"checked\"]': {\n backgroundColor: theme.colors.border.strong,\n color: theme.colors.core.brown,\n '&[aria-invalid=\"true\"]': {\n borderColor: theme.colors.border.negative,\n },\n },\n '&[data-state=\"unchecked\"]': {\n backgroundColor: theme.colors.bg.default,\n '@media(hover: hover)': {\n '&:hover': {\n backgroundColor: theme.colors.bg.inset,\n color: theme.colors.core.gray20,\n },\n },\n '&[aria-invalid=\"true\"]': {\n borderColor: theme.colors.border.negative,\n },\n },\n\n '&[data-disabled], &:disabled, &[disabled]': {\n opacity: 0.4,\n '&[data-state=\"unchecked\"]': {\n backgroundColor: theme.colors.bg.default,\n '&:hover': {\n color: 'transparent',\n },\n },\n '&[data-state=\"checked\"]': {\n backgroundColor: theme.colors.border.strong,\n },\n },\n}))\n\nconst LabelText = styled.span(({ theme }) => ({\n ...theme.typography.body.md,\n '&[data-disabled], &:disabled': {\n opacity: 0.4,\n cursor: 'not-allowed',\n },\n}))\n\nconst SupportingTextContainer = styled.div(({ theme }) => ({\n display: 'flex', // Removes line-height from making it too tall\n marginLeft: theme.spacing['8x'],\n}))\n\ninterface CheckboxOptions {\n /**\n * The label for the checkbox. Accepts a string, or a React component for rendering links within the label.\n *\n * @example\n * ```jsx\n * <Checkbox label=\"I agree to the terms and conditions\" />\n * ```\n *\n * @example\n * ```jsx\n * <Checkbox\n * label={\n * <>\n * I agree to <Link href=\"/terms\">the terms and conditions</Link>\n * </>\n * }\n * />\n * ```\n */\n label: string | ReactElement<unknown>\n /**\n * Text that provides additional guidance to the user\n */\n helperText?: string\n /**\n * The checked state of the checkbox when it is initially rendered. Use when you do not need to control its checked state.\n */\n isDefaultChecked?: boolean\n /**\n * The checked state of the checkbox when it is initially rendered. Use when you do not need to control its checked state.\n */\n defaultChecked?: boolean // NOTE: We redeclare this type from Radix because we don't want to support indeterminate state\n /**\n * The controlled checked state of the checkbox. Must be used in conjunction with `onCheckedChange`.\n */\n isChecked?: boolean\n /**\n * The controlled checked state of the checkbox. Must be used in conjunction with `onCheckedChange`.\n */\n checked?: boolean // NOTE: We redeclare this type from Radix because we don't want to support indeterminate state\n /**\n * Event handler called when the checked state of the checkbox changes.\n */\n onCheckedChange?: (checked: boolean) => void\n /**\n * If `true` the checkbox will render in its invalid state.\n * @default false\n */\n isInvalid?: boolean\n /**\n * The error message to display if `isInvalid` is `true`\n */\n errorMessage?: string\n /**\n * If `true` it prevents the user from interacting with the checkbox.\n * @default false\n */\n isDisabled?: boolean\n /**\n * If `true` the user must check the checkbox before the owning form can be submitted.\n * @default false\n */\n isRequired?: boolean\n /**\n * The name of the checkbox. Submitted with its owning form as part of a name/value pair.\n */\n name?: string\n /**\n * The value given as data when submitted with a `name`.\n */\n value?: string\n}\n\nexport type CheckboxProps = Omit<\n CheckboxPrimitive.CheckboxProps,\n 'asChild' | 'children' | 'checked' | 'defaultChecked' | keyof CheckboxOptions\n> &\n CheckboxOptions\n\nexport const Checkbox = forwardRef<HTMLButtonElement, CheckboxProps>((props, forwardedRef) => {\n const {\n label,\n helperText,\n id: idProp,\n defaultChecked: hasHtmlDefaultCheckedAttr,\n isDefaultChecked: isDefaultCheckedProp,\n isChecked: isCheckedProp,\n checked: hasHtmlCheckedAttr,\n isDisabled: isDisabledProp,\n disabled: hasHtmlDisabledAttr,\n isRequired: isRequiredProp,\n required: hasHtmlRequiredAttr,\n isInvalid,\n errorMessage,\n 'aria-labelledby': ariaLabelledByProp,\n 'aria-describedby': ariaDescribedByProp,\n ...restProps\n } = props\n const id = useStableId(idProp)\n\n const labelId = `${id}-label`\n\n const isDefaultChecked = isDefaultCheckedProp ?? hasHtmlDefaultCheckedAttr\n const isChecked = isCheckedProp ?? hasHtmlCheckedAttr\n const isDisabled = isDisabledProp ?? hasHtmlDisabledAttr\n const isRequired = isRequiredProp ?? hasHtmlRequiredAttr\n\n const ariaLabelledBy = [labelId, ariaLabelledByProp].filter(Boolean).join(' ')\n\n const hasHelperText = Boolean(helperText)\n const helperTextId = hasHelperText ? `${id}-helper` : undefined\n\n const helperTextElement = helperText && (\n <SupportingTextContainer>\n <HelperText id={helperTextId} data-disabled={dataAttr(isDisabled)}>\n {helperText}\n </HelperText>\n </SupportingTextContainer>\n )\n\n const hasError = isInvalid && errorMessage\n const errorMessageId = hasError ? `${id}-error` : undefined\n\n const errorMessageElement = hasError && (\n <SupportingTextContainer>\n <ErrorMessage id={errorMessageId} role=\"alert\" aria-live=\"polite\">\n {errorMessage}\n </ErrorMessage>\n </SupportingTextContainer>\n )\n\n const ariaDescribedBy =\n [errorMessageId, !hasError && helperTextId, ariaDescribedByProp].filter(Boolean).join(' ') ||\n undefined\n\n return (\n <Wrapper>\n <CheckboxContainer>\n <CheckboxRoot\n id={id}\n ref={forwardedRef}\n defaultChecked={isDefaultChecked}\n checked={isChecked}\n disabled={isDisabled}\n required={isRequired}\n aria-invalid={ariaAttr(isInvalid)}\n aria-labelledby={ariaLabelledBy}\n aria-describedby={ariaDescribedBy}\n {...restProps}\n >\n <CheckboxPrimitive.Indicator forceMount>\n <Check\n size={12}\n strokeWidth={3}\n absoluteStrokeWidth\n aria-hidden=\"true\"\n role=\"presentation\"\n />\n </CheckboxPrimitive.Indicator>\n </CheckboxRoot>\n <LabelText\n id={labelId}\n data-disabled={dataAttr(isDisabled)}\n onMouseDown={(ev) => {\n // prevent text selection when double clicking label\n if (ev.detail > 1) {\n ev.preventDefault()\n }\n }}\n >\n {label}\n </LabelText>\n </CheckboxContainer>\n {errorMessageElement || helperTextElement}\n </Wrapper>\n )\n})\n","import { useEffect, useState } from 'react'\n\nimport { theme } from '../theme'\nimport type { Theme } from '../theme'\n\ntype Breakpoints = Theme['breakpoints']\n\nconst breakpointsArray = Object.entries(theme.breakpoints).map(([name, value]) => ({\n name: name as keyof Breakpoints,\n breakpoint: value,\n}))\n\nconst MEDIA_QUERIES = breakpointsArray.map(({ name, breakpoint }, index) => {\n const nextValue = breakpointsArray?.[index + 1]?.breakpoint\n const media = nextValue\n ? `(min-width: ${breakpoint}px) and (max-width: ${nextValue - 1}px)`\n : `(min-width: ${breakpoint}px)`\n\n return {\n name,\n media,\n }\n})\n\nconst getMatchingBreakpoint = () => {\n const matchingBreakpoint = MEDIA_QUERIES.find(({ media }) => {\n return window.matchMedia(media).matches\n })\n // Since the breakpoints cover all screen sizes we should always get a match,\n // but to be safe we return 'base' as a fallback.\n return matchingBreakpoint?.name || 'base'\n}\n\nexport interface UseBreakpointOptions {\n /**\n * If `true` the initial value will be `base` instead of the current breakpoint.\n * This is to support hydration when using server side rendering.\n *\n * @default false\n */\n ssr?: boolean\n}\n\n/**\n * Hook for getting the current breakpoint.\n */\nexport function useBreakpoint(params?: UseBreakpointOptions) {\n // eslint-disable-next-line @typescript-eslint/naming-convention\n const { ssr = false } = params || {}\n const initialBreakpoint = ssr ? 'base' : getMatchingBreakpoint\n const [currentBreakpoint, setCurrentBreakpoint] = useState<keyof Breakpoints>(initialBreakpoint)\n\n useEffect(() => {\n const matchMediaArray = MEDIA_QUERIES.map(({ media }) => window.matchMedia(media))\n\n const handleChange = () => {\n // Instead of checking the value from the matchMedia listeners event we just use it\n // as trigger to know when the current breakpoint should be updated.\n // This is because each separate query has its own event listener which\n // can lead to incorrect intermediate states where no breakpoint is matching.\n setCurrentBreakpoint(getMatchingBreakpoint())\n }\n\n // Update the current breakpoint on the first render.\n // After that the event listeners will take care of updating the state.\n handleChange()\n\n matchMediaArray.forEach((mediaQuery) => {\n if (typeof mediaQuery.addListener === 'function') {\n // Safari < 14 fallback\n mediaQuery.addListener(handleChange)\n } else {\n mediaQuery.addEventListener('change', handleChange)\n }\n })\n\n return () => {\n matchMediaArray.forEach((mediaQuery) => {\n if (typeof mediaQuery.addListener === 'function') {\n mediaQuery.removeListener(handleChange)\n } else {\n mediaQuery.removeEventListener('change', handleChange)\n }\n })\n }\n }, [])\n\n return { currentBreakpoint }\n}\n","import type { Theme } from '../theme'\nimport { breakpoints } from '../theme/foundations/breakpoints'\nimport type { PartialRecord } from '../types'\n\nimport type { UseBreakpointOptions } from './use-breakpoint'\nimport { useBreakpoint } from './use-breakpoint'\n\ntype Breakpoints = Theme['breakpoints']\ntype BreakpointsConfig<T> = PartialRecord<keyof Breakpoints, T> & { base: T }\nexport type UseBreakpointValueProps<T> = BreakpointsConfig<T>\n\n/**\n * Hook for getting a value based on the current breakpoint.\n *\n * @example\n * const width = useBreakpointValue({ base: '150px', md: '250px' })\n */\nexport function useBreakpointValue<T>(\n values: UseBreakpointValueProps<T>,\n options?: UseBreakpointOptions,\n) {\n const { currentBreakpoint } = useBreakpoint(options)\n let breakpointValue\n\n if (currentBreakpoint in values) {\n breakpointValue = values[currentBreakpoint]\n } else {\n const breakpointNames = Object.keys(breakpoints) as (keyof Breakpoints)[]\n const currentBreakpointIndex = breakpointNames.indexOf(currentBreakpoint)\n for (let i = currentBreakpointIndex; i >= 0; i--) {\n const key = breakpointNames[i]\n if (key in values) {\n breakpointValue = values[key]\n break\n }\n }\n }\n /* Assert since a value will always be found in loop */\n return breakpointValue as T\n}\n","import type { ElementType } from 'react'\nimport { useCallback } from 'react'\n\nimport type { HTMLQdsProps, LegitimateAny } from '../types'\n\nimport { useStableId } from './use-stable-id'\n\ntype FormFieldElement = 'input' | 'select' | 'textarea'\n\ntype PropGetter<T extends ElementType = LegitimateAny> = (\n props?: HTMLQdsProps<T>,\n) => Record<string, unknown>\n\ninterface FormFieldOptions {\n /**\n * The label for the form field\n */\n label: string\n /**\n * The error message to display if `isInvalid` is `true`\n */\n errorMessage?: string\n /**\n * Text that provides additional guidance to the user\n */\n helperText?: string\n /**\n * If `true`, the form field will be invalid\n */\n isInvalid?: boolean\n /**\n * If `true`, the form field will be disabled\n */\n isDisabled?: boolean\n /**\n * If `true` the form field will be required\n */\n isRequired?: boolean\n}\n\ntype OmittedProps = 'children' | 'readOnly' | 'size'\nexport type UseFormFieldProps<T extends FormFieldElement> = Omit<HTMLQdsProps<T>, OmittedProps> &\n FormFieldOptions\n\n/**\n * Custom hook that returns props for a form field's label, input, helper text and error message.\n * Meant to be used in conjunction with the `Input`, `Select` or `Textarea` component.\n *\n * Used internally by `TextField`, `Select` and `Textarea`.\n */\nexport const useFormField = <T extends FormFieldElement>(props: UseFormFieldProps<T>) => {\n const { id: idProp, isDisabled, helperText, errorMessage, isInvalid, isRequired } = props\n const id = useStableId(idProp)\n\n const errorMessageId = `${id}-error`\n const helperTextId = `${id}-helper`\n\n const getLabelProps = useCallback<PropGetter<'label'>>(\n (forwardedProps) => ({\n ...forwardedProps,\n htmlFor: id,\n 'data-disabled': isDisabled ? '' : undefined,\n }),\n [id, isDisabled],\n )\n\n const getHelperTextProps = useCallback<PropGetter<'div'>>(\n (forwardedProps) => ({\n ...forwardedProps,\n id: helperTextId,\n 'data-disabled': isDisabled ? '' : undefined,\n }),\n [helperTextId, isDisabled],\n )\n\n const getErrorMessageProps = useCallback<PropGetter<'div'>>(\n (forwardedProps) => ({\n ...forwardedProps,\n id: errorMessageId,\n 'aria-live': 'polite',\n }),\n [errorMessageId],\n )\n\n const getFieldProps = useCallback<PropGetter<T>>(\n (forwardedProps) => {\n const ariaDescribedByIds: string[] = []\n\n // Error message must be described first in all scenarios.\n if (Boolean(errorMessage) && isInvalid) {\n ariaDescribedByIds.push(errorMessageId)\n } else if (helperText) {\n ariaDescribedByIds.push(helperTextId)\n }\n\n if (forwardedProps?.['aria-describedby']) {\n ariaDescribedByIds.push(forwardedProps['aria-describedby'])\n }\n\n return {\n ...forwardedProps,\n 'aria-describedby': ariaDescribedByIds.join(' ') || undefined,\n id: forwardedProps?.id ?? id,\n isDisabled,\n isRequired,\n 'aria-invalid': isInvalid ? true : undefined,\n }\n },\n [errorMessage, errorMessageId, helperText, helperTextId, id, isDisabled, isInvalid, isRequired],\n )\n\n return {\n getLabelProps,\n /**\n * Props to be spread on the input, select or textarea element.\n * Function accepts an optional object of props to be merged with the returned props.\n */\n getFieldProps,\n getHelperTextProps,\n getErrorMessageProps,\n }\n}\n","import React, { useState } from 'react'\n\nimport type { LegitimateAny } from '../types'\n\nimport { useSafeLayoutEffect } from './use-safe-layout-effect'\n\n/**\n * This is basically a copy of Radix UI's `useId` hook.\n */\n\n// We `toString()` to prevent bundlers from trying to `import { useId } from 'react';`\nconst useReactId = (React as LegitimateAny)['useId'.toString()] || (() => undefined)\nlet count = 0\n\n/**\n * Returns a stable ID that is unique to the component instance.\n */\nexport function useStableId(fixedId?: string | null): string {\n const [id, setId] = useState<string | undefined>(useReactId())\n // React versions older than 18 will have client-side ids only.\n useSafeLayoutEffect(() => {\n if (!fixedId) setId((reactId) => reactId ?? String(count++))\n }, [fixedId])\n return fixedId || (id ? `qds-${id}` : '')\n}\n","import { useLayoutEffect } from 'react'\n\n/**\n * On the server, React emits a warning when calling `useLayoutEffect`.\n * This is because neither `useLayoutEffect` nor `useEffect` run on the server.\n * We use this safe version which suppresses the warning by replacing it with a noop on the server.\n *\n * See: https://reactjs.org/docs/hooks-reference.html#uselayouteffect\n */\nexport const useSafeLayoutEffect = globalThis?.document ? useLayoutEffect : () => undefined\n","type Booleanish = boolean | 'true' | 'false'\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const dataAttr = (condition: boolean | undefined) =>\n (condition ? '' : undefined) as Booleanish\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const ariaAttr = (condition: boolean | undefined) =>\n (condition ? 'true' : undefined) as Booleanish\n","import styled from '@emotion/styled'\nimport type { PropsWithChildren } from 'react'\n\nconst FieldWrapper = styled.div(({ theme }) => ({\n position: 'relative',\n display: 'flex',\n flexDirection: 'column',\n gap: theme.spacing['2x'],\n width: '100%',\n}))\n\nexport function FormField({ children }: PropsWithChildren) {\n return <FieldWrapper role=\"group\">{children}</FieldWrapper>\n}\n\nexport const ErrorMessage = styled.div(({ theme }) => ({\n ...theme.typography.body.sm,\n color: theme.colors.text.negative,\n}))\n\n// We use a `<span>` since our radio buttons render as `<button>`\n// through Radix. And only phrasing content is allowed inside a `<button>`.\n// See: https://validator.nu/#textarea\nexport const HelperText = styled.span(({ theme }) => ({\n ...theme.typography.body.sm,\n color: theme.colors.text.subtle,\n '&[data-disabled]': {\n opacity: 0.4,\n },\n}))\n","import styled from '@emotion/styled'\nimport { forwardRef } from 'react'\n\nimport type { HTMLQdsProps } from '../../types'\n\nconst StyledDivider = styled.span<Required<DividerOptions>>(({ theme, orientation }) => {\n const borderCssKey = orientation === 'horizontal' ? 'borderTop' : 'borderLeft'\n const sizeCssKey = orientation === 'horizontal' ? 'width' : 'height'\n return {\n display: 'block',\n [sizeCssKey]: '100%',\n flexShrink: 0,\n [borderCssKey]: `1px solid ${theme.colors.border.default}`,\n }\n})\n\ninterface DividerOptions {\n /**\n * The orientation of the divider.\n *\n * @default 'horizontal'\n */\n orientation?: 'horizontal' | 'vertical'\n}\n\nexport interface DividerProps extends HTMLQdsProps<'span'>, DividerOptions {}\nexport const Divider = forwardRef<HTMLDivElement, DividerProps>((props, forwardedRef) => {\n const { orientation = 'horizontal', ...restProps } = props\n return (\n <StyledDivider ref={forwardedRef} orientation={orientation} role=\"separator\" {...restProps} />\n )\n})\n","import * as DropdownPrimitive from '@radix-ui/react-dropdown-menu'\nimport type { ReactNode } from 'react'\n\nimport { DropdownMenuContent, type DropdownMenuContentProps } from './dropdown-menu-content'\nimport { DropdownMenuDivider, type DropdownMenuDividerProps } from './dropdown-menu-divider'\nimport { DropdownMenuItem, type DropdownMenuItemProps } from './dropdown-menu-item'\nimport type { DropdownMenuTriggerProps } from './dropdown-menu-trigger'\nimport { DropdownMenuTrigger } from './dropdown-menu-trigger'\n\ninterface DropdownMenuRootProps {\n children: ReactNode\n /**\n * If `true` the dropdown menu will be open\n */\n isOpen?: boolean\n /**\n * The open state of the submenu when it is initially rendered.\n * Use when you do not need to control its open state.\n */\n defaultOpen?: boolean\n /**\n * Callback invoked open state changes\n */\n onOpenChange?: (isOpen: boolean) => void\n}\n\nfunction DropdownMenuRoot(props: DropdownMenuRootProps) {\n //eslint-disable-next-line @typescript-eslint/naming-convention\n const { children, isOpen, onOpenChange, defaultOpen = false } = props\n return (\n <DropdownPrimitive.Root\n defaultOpen={defaultOpen}\n open={isOpen}\n onOpenChange={onOpenChange}\n modal\n >\n {children}\n </DropdownPrimitive.Root>\n )\n}\n\nexport const DropdownMenu = Object.assign(DropdownMenuRoot, {\n Trigger: DropdownMenuTrigger,\n Content: DropdownMenuContent,\n Item: DropdownMenuItem,\n Divider: DropdownMenuDivider,\n})\n\nexport type {\n DropdownMenuRootProps,\n DropdownMenuTriggerProps,\n DropdownMenuContentProps,\n DropdownMenuItemProps,\n DropdownMenuDividerProps,\n}\n","import { keyframes } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport * as DropdownPrimitive from '@radix-ui/react-dropdown-menu'\nimport { forwardRef } from 'react'\n\nimport type { HTMLQdsProps } from '../../types'\n\nconst slideUpAndFadeIn = keyframes({\n '0%': { opacity: 0, transform: 'translateY(4px) scale(0.94)' },\n '100%': { opacity: 1, transform: 'translateY(0)' },\n})\n\nconst slideRightAndFadeIn = keyframes({\n '0%': { opacity: 0, transform: 'translateX(-4px) scale(0.94)' },\n '100%': { opacity: 1, transform: 'translateX(0)' },\n})\n\nconst slideDownAndFadeIn = keyframes({\n '0%': { opacity: 0, transform: 'translateY(-4px) scale(0.94)' },\n '100%': { opacity: 1, transform: 'translateY(0)' },\n})\n\nconst slideLeftAndFadeIn = keyframes({\n '0%': { opacity: 0, transform: 'translateX(4px) scale(0.94)' },\n '100%': { opacity: 1, transform: 'translateX(0)' },\n})\nconst slideUpAndFadeOut = keyframes({\n '0%': { opacity: 1, transform: 'translateY(0px)' },\n '100%': { opacity: 0, transform: 'translateY(-4px) scale(0.94)' },\n})\n\nconst slideRightAndFadeOut = keyframes({\n '0%': { opacity: 1, transform: 'translateX(0px)' },\n '100%': { opacity: 0, transform: 'translateX(4px) scale(0.94)' },\n})\n\nconst slideDownAndFadeOut = keyframes({\n '0%': { opacity: 1, transform: 'translateY(0)' },\n '100%': { opacity: 0, transform: 'translateY(4px) scale(0.94)' },\n})\n\nconst slideLeftAndFadeOut = keyframes({\n '0%': { opacity: 1, transform: 'translateX(0)' },\n '100%': { opacity: 0, transform: 'translateX(-4px) scale(0.94)' },\n})\n\nconst StyledContent = styled(DropdownPrimitive.Content)(({ theme }) => ({\n background: theme.colors.bg.default,\n minWidth: theme.sizes[192],\n maxWidth: theme.sizes[288],\n borderRadius: theme.radii.md,\n boxShadow: theme.shadows.md,\n padding: theme.spacing['2x'],\n '@media (prefers-reduced-motion: no-preference)': {\n transformOrigin: 'var(--radix-dropdown-menu-content-transform-origin)',\n animationDuration: '240ms',\n animationTimingFunction: 'cubic-bezier(0.16, 1, 0.3, 1)',\n willChange: 'transform, opacity',\n '&[data-state=\"open\"]': {\n '&[data-side=\"top\"]': { animationName: slideUpAndFadeIn },\n '&[data-side=\"right\"]': { animationName: slideRightAndFadeIn },\n '&[data-side=\"bottom\"]': { animationName: slideDownAndFadeIn },\n '&[data-side=\"left\"]': { animationName: slideLeftAndFadeIn },\n },\n '&[data-state=\"closed\"]': {\n animationDuration: '180ms',\n '&[data-side=\"top\"]': { animationName: slideDownAndFadeOut },\n '&[data-side=\"right\"]': { animationName: slideLeftAndFadeOut },\n '&[data-side=\"bottom\"]': { animationName: slideUpAndFadeOut },\n '&[data-side=\"left\"]': { animationName: slideRightAndFadeOut },\n },\n },\n}))\n\ntype PrimitiveContentProps = DropdownPrimitive.DropdownMenuContentProps\n\ninterface DropdownMenuContentOptions {\n /**\n * Event handler called when focus moves to the trigger after closing.\n * It can be prevented by calling `event.preventDefault`.\n */\n onCloseAutofocus?: PrimitiveContentProps['onCloseAutoFocus']\n /**\n * Event handler called when the escape key is down.\n * It can be prevented by calling `event.preventDefault`.\n */\n onEscapeKeyDown?: PrimitiveContentProps['onEscapeKeyDown']\n /**\n * Event handler called when a pointer event occurs outside the bounds of the component.\n * It can be prevented by calling `event.preventDefault`.\n */\n onPointerDownOutside?: PrimitiveContentProps['onPointerDownOutside']\n /**\n * Event handler called when focus moves outside the bounds of the component.\n * It can be prevented by calling `event.preventDefault`.\n */\n onFocusOutside?: PrimitiveContentProps['onFocusOutside']\n /**\n * Event handler called when an interaction (pointer or focus event) happens outside the bounds of the component.\n * It can be prevented by calling `event.preventDefault`.\n */\n onInteractOutside?: PrimitiveContentProps['onInteractOutside']\n /**\n * The preferred side of the trigger to render against when open.\n * Will be reversed when collisions occur and `avoidCollisions` is enabled.\n *\n * @default \"bottom\"\n */\n side?: PrimitiveContentProps['side']\n /**\n * The distance in pixels from the trigger.\n *\n * @default 8\n */\n sideOffset?: PrimitiveContentProps['sideOffset']\n /**\n * The preferred alignment against the trigger. May change when collisions occur.\n *\n * @default \"center\"\n */\n align?: PrimitiveContentProps['align']\n /**\n * The element used as the collision boundary.\n * By default this is the viewport, though you can provide additional element(s) to be included in this check.\n *\n * @default []\n */\n collisionBoundary?: PrimitiveContentProps['collisionBoundary']\n /**\n * Whether to hide the content when the trigger becomes fully occluded.\n *\n * @default false\n */\n hideWhenDetached?: PrimitiveContentProps['hideWhenDetached']\n}\n\nexport interface DropdownMenuContentProps extends HTMLQdsProps<'div'>, DropdownMenuContentOptions {}\n\nexport const DropdownMenuContent = forwardRef<HTMLDivElement, DropdownMenuContentProps>(\n (props, forwardedRef) => {\n const { children, sideOffset = 8, ...restProps } = props\n\n return (\n <DropdownPrimitive.Portal>\n <StyledContent\n collisionPadding={16}\n ref={forwardedRef}\n sideOffset={sideOffset}\n {...restProps}\n >\n {children}\n </StyledContent>\n </DropdownPrimitive.Portal>\n )\n },\n)\n","import { forwardRef } from 'react'\nimport * as DropdownPrimitive from '@radix-ui/react-dropdown-menu'\nimport styled from '@emotion/styled'\n\nimport type { HTMLQdsProps } from '../../types'\n\nconst StyledSeparator = styled(DropdownPrimitive.Separator)(({ theme }) => ({\n height: 1,\n background: theme.colors.border.subtle,\n marginTop: theme.spacing['1x'],\n marginBottom: theme.spacing['1x'],\n marginLeft: `-${theme.spacing['2x']}`,\n marginRight: `-${theme.spacing['2x']}`,\n}))\n\nexport type DropdownMenuDividerProps = HTMLQdsProps<'div'>\nexport const DropdownMenuDivider = forwardRef<HTMLDivElement, DropdownMenuDividerProps>(\n (props, forwardedRef) => {\n return <StyledSeparator ref={forwardedRef} {...props} />\n },\n)\n","import type { ElementType } from 'react'\nimport { forwardRef } from 'react'\nimport * as DropdownPrimitive from '@radix-ui/react-dropdown-menu'\nimport styled from '@emotion/styled'\n\nimport type { IconProps } from '../icon'\nimport { pxToRem } from '../../styles'\n\nconst StyledItem = styled(DropdownPrimitive.Item)(({ theme }) => ({\n ...theme.typography.label.sm,\n color: theme.colors.text.default,\n height: pxToRem(40),\n borderRadius: theme.radii.xs,\n display: 'flex',\n alignItems: 'center',\n gap: theme.spacing['3x'],\n paddingLeft: theme.spacing['3x'],\n paddingRight: theme.spacing['3x'],\n cursor: 'pointer',\n outline: 'none',\n userSelect: 'none',\n '&[data-highlighted]': {\n background: theme.colors.core.gray10,\n },\n ':not([data-disabled])': {\n ':active': {\n background: theme.colors.core.gray20,\n },\n },\n '&[data-disabled]': {\n opacity: 0.4,\n cursor: 'not-allowed',\n },\n}))\nconst TextContainer = styled.span({\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n overflow: 'hidden',\n})\n\ninterface DropdownMenuItemOptions {\n /**\n * If `true`, the item will be disabled\n */\n isDisabled?: boolean\n /**\n * Event handler called when the user selects an item (via mouse or keyboard).\n * Calling `event.preventDefault` in this handler will prevent the dropdown from closing when selecting that item.\n */\n onSelect?: (event: Event) => void\n /**\n * Optional text used for typeahead purposes.\n * By default the typeahead behavior will use the `.textContent` of the item.\n * Use this when the content is complex, or you have non-textual content inside.\n */\n textValue?: string\n /**\n * Optional icon to display on the left side of the item content.\n */\n icon?: ElementType<IconProps>\n}\nexport interface DropdownMenuItemProps\n extends Omit<DropdownPrimitive.DropdownMenuItemProps, 'asChild' | keyof DropdownMenuItemOptions>,\n DropdownMenuItemOptions {}\n\nexport const DropdownMenuItem = forwardRef<HTMLDivElement, DropdownMenuItemProps>(\n (props, forwardedRef) => {\n // eslint-disable-next-line @typescript-eslint/naming-convention\n const { children, disabled, isDisabled, icon: Icon, ...restProps } = props\n return (\n <StyledItem ref={forwardedRef} disabled={disabled || isDisabled} {...restProps}>\n {Icon && <Icon color=\"default\" size={16} aria-hidden />}\n <TextContainer>{children}</TextContainer>\n </StyledItem>\n )\n },\n)\n","import * as DropdownTriggerPrimitive from '@radix-ui/react-dropdown-menu'\nimport { forwardRef } from 'react'\n\nimport type * as Polymorphic from '../../utils/polymorphic'\n\ntype DropdownTriggerComponent = Polymorphic.ForwardRefComponent<'button'>\n\nexport type DropdownMenuTriggerProps = Polymorphic.PropsOf<DropdownTriggerComponent>\n\nexport const DropdownMenuTrigger = forwardRef((props, forwardedRef) => {\n const { children, as, ...restProps } = props\n const Component = as || 'button'\n\n return (\n <DropdownTriggerPrimitive.Trigger ref={forwardedRef} asChild>\n <Component {...restProps}>{children}</Component>\n </DropdownTriggerPrimitive.Trigger>\n )\n}) as DropdownTriggerComponent\n","import styled from '@emotion/styled'\nimport isPropValid from '@emotion/is-prop-valid'\nimport { forwardRef } from 'react'\n\nimport type * as Polymorphic from '../../utils/polymorphic'\nimport type { Theme } from '../../theme'\nimport type { ResponsiveProp } from '../../styles/responsive'\nimport { toMediaQueries } from '../../styles/responsive'\n\ntype HeadingSize = keyof Theme['typography']['title']\ntype HeadingColor = keyof Theme['colors']['text']\n\ninterface StyledHeadingProps {\n size: ResponsiveProp<HeadingSize>\n color: HeadingColor\n numberOfLines?: number\n textAlign?: 'left' | 'center' | 'right'\n}\nconst StyledHeading = styled('h2', { shouldForwardProp: isPropValid })<StyledHeadingProps>(\n ({ theme, size, color, numberOfLines, textAlign }) => ({\n margin: 0,\n ...toMediaQueries(size, (currentValue) => theme.typography.title[currentValue]),\n color: theme.colors.text[color],\n textAlign,\n overflowWrap: 'break-word',\n wordWrap: 'break-word',\n ...(numberOfLines && {\n display: '-webkit-box',\n WebkitBoxOrient: 'vertical',\n WebkitLineClamp: numberOfLines,\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n }),\n }),\n)\n\ninterface HeadingOptions {\n /**\n * Sets the visual size of the heading.\n * To override the rendered tag, use the `as` prop.\n *\n * @default 'md'\n */\n size?: ResponsiveProp<HeadingSize>\n /**\n * Sets the color of the heading\n * @default 'default'\n */\n color?: HeadingColor\n /**\n * Truncates the heading after a specific number of lines\n */\n numberOfLines?: number\n /**\n * Alignment of the heading\n * @default 'left'\n */\n textAlign?: 'left' | 'center' | 'right'\n}\n\ntype HeadingComponent = Polymorphic.ForwardRefComponent<'h2', HeadingOptions>\nexport type HeadingProps = Polymorphic.PropsOf<HeadingComponent>\n\nexport const Heading = forwardRef((props, forwardedRef) => {\n const { as, children, size = 'md', color = 'default', textAlign = 'left', ...rest } = props\n\n return (\n <StyledHeading\n as={as}\n ref={forwardedRef}\n textAlign={textAlign}\n size={size}\n color={color}\n {...rest}\n >\n {children}\n </StyledHeading>\n )\n}) as HeadingComponent\n","import { forwardRef } from 'react'\nimport styled from '@emotion/styled'\n\nimport type { HTMLQdsProps } from '../../types'\n\nconst Wrapper = styled.aside(({ theme }) => ({\n backgroundColor: theme.colors.bg.inset,\n borderRadius: theme.radii.md,\n paddingInline: theme.spacing['5x'],\n paddingBlock: theme.spacing['4x'],\n ...theme.typography.body.sm,\n}))\n\nexport type HintBoxTitleProps = HTMLQdsProps<'span'>\n\nconst Title = styled.p(({ theme }) => ({\n ...theme.typography.title['3xs'],\n marginBottom: theme.spacing['1x'],\n}))\n\nexport type HintBoxProps = HTMLQdsProps<'aside'>\n\nconst HintRoot = forwardRef<HTMLElement, HintBoxProps>((props, forwardedRef) => {\n const { children, ...rest } = props\n return (\n <Wrapper ref={forwardedRef} {...rest}>\n {children}\n </Wrapper>\n )\n})\n\nexport const HintBox = Object.assign(HintRoot, { Title })\n","import type { ElementType } from 'react'\nimport { forwardRef } from 'react'\nimport styled from '@emotion/styled'\nimport isPropValid from '@emotion/is-prop-valid'\n\nimport type { VariantProps } from '../../styles'\nimport type { IconProps } from '../icon'\nimport type * as Polymorphic from '../../utils/polymorphic'\nimport { toMediaQueries, type ResponsiveProp } from '../../styles/responsive'\n\nimport { getSizeStyles, getVariantStyles } from './icon-button-styles'\n\nconst roundToTwoDecimals = (num: number) => Math.round(num * 100) / 100\n\nconst ICON_SIZE_MAP = {\n xs: 16,\n sm: 20,\n md: 20,\n} as const\n\ninterface StyledButtonProps {\n size: ResponsiveProp<IconButtonSize>\n variant: IconButtonVariant\n}\nconst StyledButton = styled('button', { shouldForwardProp: isPropValid })<StyledButtonProps>(\n ({ theme, size: iconSize, variant }) => ({\n borderRadius: theme.radii.full,\n display: 'inline-flex',\n justifyContent: 'center',\n alignItems: 'center',\n position: 'relative',\n flexShrink: 0,\n WebkitTouchCallout: 'none',\n WebkitTapHighlightColor: 'transparent',\n userSelect: 'none',\n transitionProperty: 'box-shadow, transform, opacity, background-color, color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n\n '&[disabled]': {\n opacity: 0.4,\n },\n '&:not([disabled]):active': {\n transform: 'scale(0.97)',\n },\n ...toMediaQueries(iconSize, (currentValue) => {\n const iconSize = ICON_SIZE_MAP[currentValue]\n return {\n ...getSizeStyles(theme)[currentValue],\n '> svg': {\n width: iconSize,\n height: iconSize,\n // Always set a minimum stroke width of 2px.\n // If the size is less than 24px, scale the stroke width up\n // to compensate for the scaling down of the icon.\n ...(iconSize < 24 && {\n strokeWidth: roundToTwoDecimals((24 / iconSize) * 2),\n }),\n },\n }\n }),\n ...getVariantStyles(theme)[variant],\n }),\n)\n\ntype IconButtonSize = VariantProps<typeof getSizeStyles>\ntype IconButtonVariant = VariantProps<typeof getVariantStyles>\ninterface IconButtonOptions {\n icon: ElementType<IconProps>\n /**\n * A visually hidden label read by screen readers.\n *\n */\n label: string\n /**\n * Defines the size of the button\n */\n size?: ResponsiveProp<IconButtonSize>\n /**\n * Sets the style variant of the button\n */\n variant?: IconButtonVariant\n /**\n * If `true` the button will be disabled\n */\n isDisabled?: boolean\n}\n\ntype IconButtonComponent = Polymorphic.ForwardRefComponent<'button', IconButtonOptions>\nexport type IconButtonProps = Polymorphic.PropsOf<IconButtonComponent>\n\nexport const IconButton = forwardRef((props, forwardedRef) => {\n const {\n as,\n icon: Icon,\n label,\n 'aria-label': ariaLabel = label,\n variant = 'white',\n size = 'md',\n type = 'button',\n isDisabled = false,\n ...restProps\n } = props\n return (\n <StyledButton\n as={as}\n ref={forwardedRef}\n aria-label={ariaLabel}\n variant={variant}\n size={size}\n disabled={isDisabled}\n type={type}\n {...restProps}\n >\n <Icon aria-hidden=\"true\" color=\"currentColor\" />\n </StyledButton>\n )\n}) as IconButtonComponent\n","import { pxToRem, createStyleVariants } from '../../styles'\n\n// Can't use :enabled cause it doesn't work when rendered as a link\nconst NOT_DISABLED = ':not([disabled])'\n\nexport const getSizeStyles = createStyleVariants(() => ({\n xs: {\n width: pxToRem(32),\n height: pxToRem(32),\n },\n sm: {\n width: pxToRem(40),\n height: pxToRem(40),\n },\n md: {\n width: pxToRem(48),\n height: pxToRem(48),\n },\n}))\n\n// These are the exact same styles as the `Button` variant styles.\n// Maybe we can share them somehow in the future but there isn't any good abstraction yet\n// so I'll keep some duplicated styles here for now. -- Hugo (2022-07-03)\nexport const getVariantStyles = createStyleVariants(({ colors }) => ({\n primary: {\n background: colors.bg.brandPrimary,\n color: colors.text.onBrandPrimary,\n [NOT_DISABLED]: {\n // This prevents hover styles from displaying instead\n // of active styles on touch devices\n '@media(hover: hover)': {\n ':hover': {\n background: colors.bg.brandPrimaryHover,\n },\n },\n ':active': {\n background: colors.bg.brandPrimaryActive,\n },\n },\n },\n secondary: {\n background: colors.bg.brandSecondary,\n color: colors.text.onBrandSecondary,\n [NOT_DISABLED]: {\n '@media(hover: hover)': {\n ':hover': {\n background: colors.bg.brandSecondaryHover,\n },\n },\n ':active': {\n background: colors.bg.brandSecondaryActive,\n },\n },\n },\n tertiary: {\n background: colors.bg.brandTertiary,\n color: colors.text.onBrandTertiary,\n [NOT_DISABLED]: {\n '@media(hover: hover)': {\n ':hover': {\n background: colors.bg.brandTertiaryHover,\n },\n },\n ':active': {\n background: colors.bg.brandTertiaryActive,\n },\n },\n },\n\n ghost: {\n color: colors.text.default,\n [NOT_DISABLED]: {\n '@media(hover: hover)': {\n ':hover': {\n background: colors.core.blackAlpha5,\n },\n },\n ':active': {\n background: colors.core.blackAlpha10,\n },\n },\n },\n white: {\n background: colors.bg.default,\n color: colors.text.default,\n [NOT_DISABLED]: {\n '@media(hover: hover)': {\n ':hover': {\n background: colors.core.gray10,\n },\n },\n ':active': {\n background: colors.core.gray20,\n },\n },\n },\n}))\n","import styled from '@emotion/styled'\nimport { forwardRef, useRef, useState } from 'react'\n\nimport { useFormField, useSafeLayoutEffect } from '../../hooks'\nimport { useTranslation } from '../../i18n/use-translation'\nimport { dataAttr } from '../../utils/html-attributes'\nimport type { HTMLQdsProps } from '../../types'\nimport { Label } from '../label'\nimport type { InputBaseOptions } from '../primitives/input-base'\nimport { InputBase } from '../primitives/input-base'\nimport { ErrorMessage, FormField, HelperText } from '../_internal'\n\ninterface InputContainerProps {\n isPositionRelative: boolean\n}\nconst InputContainer = styled.div<InputContainerProps>(({ isPositionRelative }) => ({\n width: '100%',\n position: isPositionRelative ? 'relative' : undefined,\n}))\n\nconst OptionalText = styled.span(({ theme }) => ({\n ...theme.typography.body.sm,\n color: theme.colors.text.subtle,\n}))\n\nconst Suffix = styled.div(({ theme }) => ({\n ...theme.typography.body.md,\n position: 'absolute',\n height: '100%',\n top: 0,\n right: 0,\n display: 'flex',\n alignItems: 'center',\n paddingLeft: theme.spacing['4x'],\n paddingRight: theme.spacing['4x'],\n pointerEvents: 'none',\n '&[data-disabled]': {\n opacity: 0.4,\n },\n}))\n\ninterface TextFieldOptions extends InputBaseOptions {\n /**\n * The label for the input\n */\n label: string\n /**\n * The error message to display if `isInvalid` is `true`\n */\n errorMessage?: string\n /**\n * If `true`, the input will display an optional indicator.\n * If the `isRequired` prop is also `true`, this prop will be ignored.\n */\n isOptional?: boolean\n /**\n * Text that provides additional guidance to the user\n */\n helperText?: string\n /**\n * Suffixed text to display after the input.\n * This is useful for e.g. displaying units of measurement.\n */\n suffix?: string\n}\n\ntype OmittedProps = 'children' | 'readOnly' | 'size'\n\nexport interface TextFieldProps\n extends Omit<HTMLQdsProps<'input'>, OmittedProps>,\n TextFieldOptions {}\n\nexport const TextField = forwardRef<HTMLInputElement, TextFieldProps>((props, forwardedRef) => {\n const {\n label,\n isInvalid,\n isDisabled,\n isRequired,\n isOptional: isOptionalProp,\n errorMessage,\n helperText,\n suffix,\n ...restProps\n } = props\n const {\n getLabelProps,\n getFieldProps: getInputProps,\n getErrorMessageProps,\n getHelperTextProps,\n } = useFormField<'input'>(props)\n\n const [suffixWidth, setSuffixWidth] = useState<number | undefined>(undefined)\n const suffixRef = useRef<HTMLDivElement>(null)\n const { t } = useTranslation()\n\n useSafeLayoutEffect(() => {\n setSuffixWidth(suffixRef.current?.offsetWidth)\n }, [suffix])\n\n const helperTextElement = helperText ? (\n <HelperText {...getHelperTextProps()}>{helperText}</HelperText>\n ) : null\n\n const shouldShowErrorMessage = isInvalid && errorMessage\n const errorMessageElement = shouldShowErrorMessage ? (\n <ErrorMessage {...getErrorMessageProps()}>{errorMessage}</ErrorMessage>\n ) : null\n\n const hasSuffix = Boolean(suffix)\n\n const isOptional = Boolean(!isRequired && isOptionalProp)\n\n return (\n <FormField>\n <Label {...getLabelProps()}>\n {label}\n {isOptional && <OptionalText>{` (${t('optional')})`}</OptionalText>}\n </Label>\n\n <InputContainer isPositionRelative={hasSuffix}>\n <InputBase\n ref={forwardedRef}\n {...getInputProps({ ...restProps, style: { paddingRight: suffixWidth } })}\n />\n {hasSuffix && (\n <Suffix ref={suffixRef} aria-hidden=\"true\" data-disabled={dataAttr(isDisabled)}>\n {suffix}\n </Suffix>\n )}\n </InputContainer>\n {errorMessageElement || helperTextElement}\n </FormField>\n )\n})\n","const SUPPORTED_LANGUAGE_CODES = ['en', 'sv', 'fi', 'fr', 'nb'] as const\n\nexport type LanguageCode = (typeof SUPPORTED_LANGUAGE_CODES)[number]\n\nexport interface Resource {\n close: string\n optional: string\n}\nconst en: Resource = {\n close: 'Close',\n optional: 'Optional',\n}\n\nconst sv: Resource = {\n close: 'Stäng',\n optional: 'Valfritt',\n}\n\nconst fi: Resource = {\n close: 'Sulje',\n optional: 'Valinnainen',\n}\n\nconst fr: Resource = {\n close: 'Fermer',\n optional: 'Facultatif',\n}\n\nconst nb: Resource = {\n close: 'Steng',\n optional: 'Valgfri',\n}\n\nexport const locales: Record<LanguageCode, Resource> = {\n en,\n sv,\n fi,\n fr,\n nb,\n}\n","import { useLocale } from './locale-context'\nimport type { Resource } from './locales'\nimport { locales } from './locales'\n\ntype I18nKey = keyof Resource\n\nexport function useTranslation() {\n const { currentLanguage } = useLocale()\n\n const t = (key: I18nKey) => locales[currentLanguage][key]\n\n return { t }\n}\n","import styled from '@emotion/styled'\nimport isPropValid from '@emotion/is-prop-valid'\nimport { forwardRef } from 'react'\n\nimport type { VariantProps } from '../../styles'\nimport { createStyleVariants } from '../../styles'\nimport type * as Polymorphic from '../../utils/polymorphic'\nimport type { Theme } from '../../theme'\nimport type { ResponsiveProp } from '../../styles/responsive'\nimport { toMediaQueries } from '../../styles/responsive'\n\nconst getSizeStyles = createStyleVariants(({ typography }) => ({\n sm: {\n ...typography.label.sm,\n },\n md: {\n ...typography.label.md,\n },\n}))\n\ntype LabelSize = VariantProps<typeof getSizeStyles>\ntype LabelColor = keyof Theme['colors']['text']\n\ninterface StyledLabelProps {\n size: ResponsiveProp<LabelSize>\n color: LabelColor\n}\nconst StyledLabel = styled('label', { shouldForwardProp: isPropValid })<StyledLabelProps>(\n ({ theme, color, size }) => ({\n display: 'block',\n color: theme.colors.text[color],\n cursor: 'default',\n WebkitTouchCallout: 'none',\n WebkitTapHighlightColor: 'transparent',\n ...toMediaQueries(size, (currentValue) => getSizeStyles(theme)[currentValue]),\n '&[data-disabled]': {\n opacity: 0.4,\n },\n }),\n)\n\ninterface LabelOptions {\n /**\n * Size of the label\n */\n size?: ResponsiveProp<LabelSize>\n /**\n * Sets the color of the label\n * @default 'default'\n */\n color?: LabelColor\n}\n\ntype LabelComponent = Polymorphic.ForwardRefComponent<'label', LabelOptions>\nexport type LabelProps = Polymorphic.PropsOf<LabelComponent>\n\nexport const Label = forwardRef((props, forwardedRef) => {\n const { as, children, color = 'default', size = 'md', onMouseDown, ...restProps } = props\n return (\n <StyledLabel\n as={as}\n ref={forwardedRef}\n {...restProps}\n size={size}\n color={color}\n onMouseDown={(event) => {\n onMouseDown && onMouseDown(event)\n // prevent text selection when double clicking label\n if (!event.defaultPrevented && event.detail > 1) {\n event.preventDefault()\n }\n }}\n >\n {children}\n </StyledLabel>\n )\n}) as LabelComponent\n","import styled from '@emotion/styled'\nimport { forwardRef } from 'react'\n\nimport { getFormFieldBaseStyles } from '../../../styles'\nimport type { HTMLQdsProps } from '../../../types'\nimport { ariaAttr } from '../../../utils/html-attributes'\n\nconst StyledInput = styled('input')(({ theme }) => ({\n ...getFormFieldBaseStyles(theme),\n height: 48,\n}))\n\nexport interface InputBaseOptions {\n /**\n * If `true`, the input will be invalid\n */\n isInvalid?: boolean\n /**\n * If `true`, the input will be disabled\n */\n isDisabled?: boolean\n /**\n * If `true` the input will be required\n */\n isRequired?: boolean\n}\n\ntype OmittedProps = 'children' | 'readOnly' | 'size' | 'disabled' | 'required'\nexport interface InputBaseProps\n extends Omit<HTMLQdsProps<'input'>, OmittedProps>,\n InputBaseOptions {}\n\nexport const InputBase = forwardRef<HTMLInputElement, InputBaseProps>((props, forwardedRef) => {\n const { isInvalid, isDisabled, isRequired, ...restProps } = props\n\n return (\n <StyledInput\n ref={forwardedRef}\n aria-invalid={ariaAttr(isInvalid)}\n disabled={isDisabled}\n required={isRequired}\n {...restProps}\n />\n )\n})\n","import { forwardRef } from 'react'\nimport styled from '@emotion/styled'\nimport isPropValid from '@emotion/is-prop-valid'\n\nimport type * as Polymorphic from '../../utils/polymorphic'\n\nconst StyledLink = styled('a', { shouldForwardProp: isPropValid })(({ theme }) => ({\n WebkitTouchCallout: 'none',\n WebkitTapHighlightColor: 'transparent',\n ...theme.typography.body.md,\n WebkitAppearance: 'none',\n transitionProperty: 'box-shadow, transform, opacity, background-color, color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n flexShrink: 0,\n fontSize: 'inherit',\n color: 'inherit',\n textDecoration: 'underline',\n}))\n\ninterface LinkOptions {\n /**\n * The URL to link to.\n */\n href?: string\n /**\n * If `true`, the link will open in new tab\n */\n isExternal?: boolean\n}\n\ntype LinkComponent = Polymorphic.ForwardRefComponent<'a', LinkOptions>\nexport type LinkProps = Polymorphic.PropsOf<LinkComponent>\n\nexport const Link = forwardRef((props, forwardedRef) => {\n const { children, href, isExternal = false, ...restProps } = props\n const externalProps = isExternal ? { target: '_blank', rel: 'noopener noreferrer' } : {}\n return (\n <StyledLink ref={forwardedRef} href={href} {...externalProps} {...restProps}>\n {children}\n </StyledLink>\n )\n}) as LinkComponent\n","import styled from '@emotion/styled'\nimport isPropValid from '@emotion/is-prop-valid'\nimport { forwardRef } from 'react'\n\nimport type { VariantProps } from '../../styles'\nimport { createStyleVariants } from '../../styles'\nimport type { Theme } from '../../theme'\nimport type * as Polymorphic from '../../utils/polymorphic'\nimport { toMediaQueries, type ResponsiveProp } from '../../styles/responsive'\n\nconst getSizeStyles = createStyleVariants(({ typography }) => ({\n xs: typography.body.xs,\n sm: typography.body.sm,\n md: typography.body.md,\n lg: typography.body.lg,\n xl: typography.body.xl,\n}))\n\ntype ParagraphSize = VariantProps<typeof getSizeStyles>\ntype ParagraphColor = keyof Theme['colors']['text']\n\ninterface StyledParagraphProps {\n size: ResponsiveProp<ParagraphSize>\n color: ParagraphColor\n numberOfLines?: number\n textAlign?: 'left' | 'center' | 'right'\n}\n\nconst StyledParagraph = styled('p', { shouldForwardProp: isPropValid })<StyledParagraphProps>(\n ({ theme, size, color, numberOfLines, textAlign }) => ({\n margin: 0,\n ...toMediaQueries(size, (currentValue) => getSizeStyles(theme)[currentValue]),\n color: theme.colors.text[color],\n textAlign,\n overflowWrap: 'break-word',\n wordWrap: 'break-word',\n\n ...(numberOfLines && {\n display: '-webkit-box',\n WebkitBoxOrient: 'vertical',\n WebkitLineClamp: numberOfLines,\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n }),\n }),\n)\n\ninterface ParagraphOptions {\n /**\n * Sets the visual size of the text\n * @default 'md'\n */\n size?: ResponsiveProp<ParagraphSize>\n /**\n * Sets the color of the text\n * @default 'normal'\n */\n color?: ParagraphColor\n /**\n * Truncates the text after a specific number of lines\n */\n numberOfLines?: number\n /**\n * Alignment of the paragraph\n * @default 'left'\n */\n textAlign?: 'left' | 'center' | 'right'\n}\n\ntype ParagraphComponent = Polymorphic.ForwardRefComponent<'p', ParagraphOptions>\nexport type ParagraphProps = Polymorphic.PropsOf<ParagraphComponent>\n\nexport const Paragraph = forwardRef((props, forwardedRef) => {\n const { children, size = 'md', color = 'default', textAlign = 'left', ...rest } = props\n return (\n <StyledParagraph ref={forwardedRef} size={size} color={color} textAlign={textAlign} {...rest}>\n {children}\n </StyledParagraph>\n )\n}) as ParagraphComponent\n","import styled from '@emotion/styled'\nimport { forwardRef } from 'react'\n\nimport { getFormFieldBaseStyles } from '../../../styles'\nimport type { HTMLQdsProps } from '../../../types'\nimport { ChevronDownIcon } from '../../icon'\n\nexport interface SelectBaseOptions {\n /**\n * The placeholder for the select. We render an `<option/>` element that has\n * empty value.\n *\n * ```jsx\n * <option value=\"\">{placeholder}</option>\n * ```\n */\n placeholder?: string\n /**\n * If `true`, the select will be invalid\n */\n isInvalid?: boolean\n /**\n * If `true`, the select will be disabled\n */\n isDisabled?: boolean\n /**\n * If `true` the select will be required\n */\n isRequired?: boolean\n}\n\nconst SelectWrapper = styled.div({\n width: '100%',\n height: 'fit-content',\n position: 'relative',\n})\nconst SelectIconWrapper = styled.div({\n pointerEvents: 'none',\n position: 'absolute',\n height: '100%',\n width: 48,\n right: 0,\n top: 0,\n color: 'currentcolor',\n display: 'inline-flex',\n justifyContent: 'center',\n alignItems: 'center',\n '&[data-disabled]': {\n opacity: 0.4,\n },\n})\n\nconst StyledSelect = styled.select(({ theme }) => ({\n ...getFormFieldBaseStyles(theme),\n height: 48,\n // Ensure the text doesn't end up behind the icon\n paddingRight: 40,\n}))\n\ntype OmittedProps = 'readOnly' | 'size' | 'multiple' | 'disabled' | 'required'\n\ninterface SelectBaseProps extends Omit<HTMLQdsProps<'select'>, OmittedProps>, SelectBaseOptions {}\n\nexport const SelectBase = forwardRef<HTMLSelectElement, SelectBaseProps>((props, forwardedRef) => {\n const { placeholder, children, isInvalid, isDisabled, isRequired, ...restProps } = props\n\n return (\n <SelectWrapper>\n <StyledSelect\n ref={forwardedRef}\n aria-invalid={isInvalid ? true : undefined}\n disabled={isDisabled}\n required={isRequired}\n {...restProps}\n >\n {placeholder && <option value=\"\">{placeholder}</option>}\n {children}\n </StyledSelect>\n <SelectIconWrapper data-disabled={isDisabled ? '' : undefined}>\n <ChevronDownIcon role=\"presentation\" aria-hidden=\"true\" size={16} />\n </SelectIconWrapper>\n </SelectWrapper>\n )\n})\n","import styled from '@emotion/styled'\nimport { forwardRef } from 'react'\n\nimport { getFormFieldBaseStyles } from '../../../styles'\nimport type { HTMLQdsProps } from '../../../types'\nimport { ariaAttr } from '../../../utils/html-attributes'\n\nconst StyledTextarea = styled.textarea<{ resize: ResizeProp; minRows: MinRowsProp }>(\n ({ theme, resize, minRows }) => {\n const baseStyles = getFormFieldBaseStyles(theme)\n const paddingVertical = theme.spacing['3x']\n const minHeight = `calc(${baseStyles.lineHeight} * ${minRows} + ${paddingVertical} * 2 + 2px)` // + 2px for border\n\n return {\n ...baseStyles,\n paddingTop: paddingVertical,\n paddingBottom: paddingVertical,\n scrollPaddingBlockEnd: paddingVertical,\n resize,\n minHeight,\n }\n },\n)\n\ntype ResizeProp = 'none' | 'both' | 'horizontal' | 'vertical'\ntype MinRowsProp = number\nexport interface TextareaBaseOptions {\n /**\n * If `true`, the textarea will be invalid\n */\n isInvalid?: boolean\n /**\n * If `true`, the textarea will be disabled\n */\n isDisabled?: boolean\n /**\n * If `true` the textarea will be required\n */\n isRequired?: boolean\n /**\n * The resize behavior of the textarea\n *\n * @default 'vertical'\n */\n resize?: ResizeProp\n /**\n * The minimum number of rows to display without requiring scrolling or resizing.\n * To disabled resizing use the `resize` prop.\n *\n * @default 3\n */\n minRows?: MinRowsProp\n}\n\ntype OmittedProps = 'children' | 'readOnly' | 'size' | 'disabled' | 'required' | 'rows' | 'cols'\nexport interface TextareaBaseProps\n extends Omit<HTMLQdsProps<'textarea'>, OmittedProps>,\n TextareaBaseOptions {}\n\nexport const TextareaBase = forwardRef<HTMLTextAreaElement, TextareaBaseProps>(\n (props, forwardedRef) => {\n const {\n isInvalid,\n isDisabled,\n isRequired,\n resize = 'vertical',\n minRows = 3,\n ...restProps\n } = props\n\n return (\n <StyledTextarea\n ref={forwardedRef}\n aria-invalid={ariaAttr(isInvalid)}\n disabled={isDisabled}\n required={isRequired}\n resize={resize}\n minRows={minRows}\n {...restProps}\n />\n )\n },\n)\n","import { forwardRef, useCallback, useState } from 'react'\nimport * as RadioGroupPrimitive from '@radix-ui/react-radio-group'\nimport styled from '@emotion/styled'\n\nimport { ErrorMessage } from '../_internal'\nimport { useStableId } from '../../hooks'\nimport { ariaAttr } from '../../utils/html-attributes'\n\nimport { RadioGroupProvider } from './radio-group-context'\nimport { RadioCard } from './radio-card'\nimport type { RadioCardProps } from './radio-card'\nimport type { RadioButtonProps } from './radio-button'\nimport { RadioGroupLabel } from './radio-group-label'\nimport type { RadioGroupLabelProps } from './radio-group-label'\nimport { RadioButton } from './radio-button'\n\nconst StyledRadioGroupRoot = styled(RadioGroupPrimitive.Root)(({ theme }) => ({\n width: '100%',\n display: 'flex',\n flexDirection: 'column',\n gap: theme.spacing['3x'],\n}))\n\ninterface RadioGroupOptions {\n /**\n * The value of the radio item that should be checked when initially rendered.\n * Use when you do not need to control the state of the radio items.\n */\n defaultValue?: string\n /**\n * The controlled value of the radio item to check.\n * Should be used in conjunction with `onValueChange`.\n */\n value?: string\n /**\n * Event handler called when the value changes.\n */\n onValueChange?: (value: string) => void\n /**\n * The name of the group. Submitted with its owning form as part of a name/value pair.\n */\n name?: string\n /**\n * If `true` all child radio items will be disabled.\n * @default false\n */\n isDisabled?: boolean\n /**\n * If `true` the user must check a radio item before the owning form can be submitted.\n * @default false\n */\n isRequired?: boolean\n /**\n * If `true` the radio group will be invalid.\n * @default false\n */\n isInvalid?: boolean\n /**\n * The error message to display if `isInvalid` is `true`\n */\n errorMessage?: string\n}\n\nexport interface RadioGroupProps\n // We omit some props and define them ourselves so that we can have\n // JS doc descriptions for them.\n extends Omit<RadioGroupPrimitive.RadioGroupProps, 'asChild' | keyof RadioGroupOptions>,\n RadioGroupOptions {}\n\nconst RadioGroupRoot = forwardRef<HTMLDivElement, RadioGroupProps>((props, forwardedRef) => {\n const {\n children,\n id: idProp,\n disabled: hasHtmlDisabledAttr,\n isDisabled: isDisabledProp,\n required: hasHtmlRequiredAttr,\n isRequired: isRequiredProp,\n 'aria-labelledby': ariaLabelledByProp,\n 'aria-describedby': ariaDescribedByProp,\n isInvalid,\n errorMessage,\n ...restProps\n } = props\n\n const isDisabled = isDisabledProp ?? hasHtmlDisabledAttr\n const isRequired = isRequiredProp ?? hasHtmlRequiredAttr\n\n const id = useStableId(idProp)\n\n const hasError = isInvalid && errorMessage\n const errorMessageId = hasError ? `${id}-error` : undefined\n\n const [labelElement, setLabelElement] = useState<HTMLElement | null>(null)\n\n const labelRefCallback = useCallback((node: HTMLElement | null) => setLabelElement(node), [])\n const labelId = labelElement?.id\n\n const errorMessageElement = hasError ? (\n <ErrorMessage id={errorMessageId} role=\"alert\" aria-live=\"polite\">\n {errorMessage}\n </ErrorMessage>\n ) : null\n\n const ariaLabelledBy = [labelId, ariaLabelledByProp].filter(Boolean).join(' ') || undefined\n // Error message should be described first in all scenarios.\n const ariaDescribedBy =\n [errorMessageId, ariaDescribedByProp].filter(Boolean).join(' ') || undefined\n\n return (\n <RadioGroupProvider\n value={{\n labelRefCallback,\n isDisabled,\n errorMessageId,\n }}\n >\n <StyledRadioGroupRoot\n ref={forwardedRef}\n id={id}\n disabled={isDisabled}\n required={isRequired}\n aria-invalid={ariaAttr(isInvalid)}\n aria-labelledby={ariaLabelledBy}\n aria-describedby={ariaDescribedBy}\n {...restProps}\n >\n {children}\n {errorMessageElement}\n </StyledRadioGroupRoot>\n </RadioGroupProvider>\n )\n})\n\nexport const RadioGroup = Object.assign(RadioGroupRoot, {\n Card: RadioCard,\n Button: RadioButton,\n Label: RadioGroupLabel,\n})\n\nexport type { RadioGroupLabelProps, RadioCardProps, RadioButtonProps }\n","import { createContext, useContext } from 'react'\n\ninterface RadioGroupContextValue {\n labelRefCallback: (node: HTMLElement | null) => void\n isDisabled: boolean | undefined\n errorMessageId?: string\n}\nconst RadioGroupContext = createContext<RadioGroupContextValue | null>(null)\n\ninterface RadioGroupProviderProps {\n value: RadioGroupContextValue\n children: React.ReactNode\n}\nexport function RadioGroupProvider({ value, children }: RadioGroupProviderProps) {\n return <RadioGroupContext.Provider value={value}>{children}</RadioGroupContext.Provider>\n}\n\ninterface UseRadioGroupContextProps {\n consumerName: string\n}\n\nexport const useRadioGroupContext = ({ consumerName }: UseRadioGroupContextProps) => {\n const context = useContext(RadioGroupContext)\n if (!context) {\n throw new Error(`\\`${consumerName}\\` must be used within \\`RadioGroup\\``)\n }\n return context\n}\n","import styled from '@emotion/styled'\nimport * as RadioGroupPrimitive from '@radix-ui/react-radio-group'\nimport { forwardRef, useState } from 'react'\n\nimport { useStableId } from '../../../hooks'\nimport { pxToRem } from '../../../styles'\nimport { dataAttr } from '../../../utils/html-attributes'\nimport { HelperText } from '../../_internal'\nimport { RadioIndicator } from '../radio-indicator'\nimport { useRadioGroupContext } from '../radio-group-context'\n\nconst RadioItem = styled(RadioGroupPrimitive.Item)(({ theme }) => ({\n width: '100%',\n textAlign: 'left',\n background: theme.colors.bg.default,\n paddingLeft: theme.spacing['5x'],\n paddingRight: theme.spacing['5x'],\n // Odd padding value, but without it the text is not vertically centered.\n // Logic is (height - line height - border top - border bottom) / 2\n // So (56 - 20 - 1 - 1) / 2 = 17\n paddingTop: pxToRem(17),\n paddingBottom: pxToRem(17),\n minHeight: pxToRem(56),\n justifyContent: 'center',\n border: '1px solid',\n borderColor: theme.colors.border.default,\n borderRadius: theme.radii.md,\n display: 'grid',\n gridTemplateColumns: `1fr min-content`,\n alignItems: 'start',\n // Needed to align the content to the top when the cards are\n // places in a grid with varying intrinsic heights\n alignContent: 'start',\n columnGap: theme.spacing['3x'],\n rowGap: theme.spacing['1x'],\n boxShadow: 'none',\n transitionProperty: 'background, border-color, box-shadow, transform, outline',\n transitionDuration: '120ms',\n transitionTimingFunction: 'ease-out',\n '&[data-state=\"checked\"]': {\n borderColor: theme.colors.border.defaultSelected,\n boxShadow: `inset 0 0 0 1px ${theme.colors.border.defaultSelected}`,\n background: theme.colors.bg.inset,\n ':active': {\n transform: 'scale(0.995)',\n },\n },\n '&[data-state=\"unchecked\"]': {\n '@media(hover: hover)': {\n ':hover': {\n borderColor: theme.colors.border.defaultHover,\n background: theme.colors.bg.inset,\n },\n },\n ':active': {\n transform: 'scale(0.98)',\n },\n },\n outlineOffset: 0,\n outline: '0 solid transparent',\n ':focus-visible': {\n outlineColor: theme.colors.border.defaultSelected,\n outlineWidth: 2,\n outlineStyle: 'solid',\n outlineOffset: 3,\n },\n '&[data-disabled], &:disabled, &[disabled]': {\n opacity: 0.4,\n '&[data-state=\"unchecked\"]': {\n ':hover': {\n background: theme.colors.bg.default,\n borderColor: theme.colors.border.default,\n },\n },\n ':active': {\n transform: 'none',\n },\n },\n\n WebkitTouchCallout: 'none',\n WebkitTapHighlightColor: 'transparent',\n}))\n\ninterface RadioCardOptions {\n /**\n * The label for the radio card\n */\n label: string\n /**\n * Text that provides additional guidance to the user\n */\n helperText?: string\n /**\n * If `true` the user must check the radio item before the owning form can be submitted.\n * @default false\n */\n isRequired?: boolean\n /**\n * If `true` it prevents the user from interacting with the radio item.\n * @default false\n */\n isDisabled?: boolean\n}\n\nexport interface RadioCardProps\n extends Omit<RadioGroupPrimitive.RadioGroupItemProps, 'asChild' | keyof RadioCardOptions>,\n RadioCardOptions {}\n\nconst Label = styled.span(({ theme }) => ({\n ...theme.typography.label.md,\n}))\n\nexport const RadioCard = forwardRef<HTMLButtonElement, RadioCardProps>((props, forwardedRef) => {\n const {\n label,\n helperText,\n disabled: hasHtmlDisabledAttr,\n isDisabled: isDisabledProp,\n required: hasHtmlRequiredAttr,\n isRequired: isRequiredProp,\n id: idProp,\n 'aria-describedby': ariaDescribedByProp,\n onMouseEnter,\n onMouseLeave,\n ...rest\n } = props\n const [isHovered, setIsHovered] = useState(false)\n\n const { errorMessageId } = useRadioGroupContext({ consumerName: 'RadioCard' })\n const id = useStableId(idProp)\n const labelId = `${id}-label`\n const hasHelperText = Boolean(helperText)\n const helperTextId = hasHelperText ? `${id}-helper-text` : undefined\n\n const ariaDescribedBy =\n [errorMessageId, helperTextId, ariaDescribedByProp].filter(Boolean).join(' ') || undefined\n\n const helperTextElement = helperText ? (\n <HelperText id={helperTextId}>{helperText}</HelperText>\n ) : null\n\n const isDisabled = isDisabledProp ?? hasHtmlDisabledAttr\n const isRequired = isRequiredProp ?? hasHtmlRequiredAttr\n\n return (\n <RadioItem\n ref={forwardedRef}\n disabled={isDisabled}\n // For some reason if we pass e.g. `required={undefined}` it will override\n // the `required` attribute from the `RadioGroup`. Seems to be something with\n // how Radix handles the state internally.\n {...(isRequired && { required: true })}\n aria-labelledby={labelId}\n aria-describedby={ariaDescribedBy}\n onMouseEnter={(ev) => {\n setIsHovered(true)\n onMouseEnter?.(ev)\n }}\n onMouseLeave={(ev) => {\n setIsHovered(false)\n onMouseLeave?.(ev)\n }}\n {...rest}\n >\n <Label id={labelId}>{label}</Label>\n <RadioIndicator data-hover={dataAttr(isHovered)} />\n {helperTextElement}\n </RadioItem>\n )\n})\n","import styled from '@emotion/styled'\nimport * as RadioGroupPrimitive from '@radix-ui/react-radio-group'\nimport { forwardRef } from 'react'\n\nimport { pxToRem } from '../../styles'\n\nconst StyledRadioIndicator = styled(RadioGroupPrimitive.Indicator)(({ theme }) => ({\n background: theme.colors.bg.default,\n border: '2px solid',\n borderColor: theme.colors.border.strong,\n width: pxToRem(20),\n height: pxToRem(20),\n flexShrink: 0,\n borderRadius: theme.radii.full,\n transitionProperty: 'background',\n transitionDuration: '120ms',\n transitionTimingFunction: 'ease-out',\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n '&::after': {\n content: '\"\"',\n display: 'block',\n width: pxToRem(10),\n height: pxToRem(10),\n borderRadius: theme.radii.full,\n background: theme.colors.border.strong,\n transform: 'scale(0.5)',\n opacity: 0,\n transitionProperty: 'transform, opacity',\n transitionDuration: '120ms',\n transitionTimingFunction: 'ease-out',\n transformOrigin: 'center',\n },\n '&[data-state=\"unchecked\"]': {\n '@media(hover: hover)': {\n '&:not(&[data-disabled])[data-hover]::after': {\n transform: 'scale(0.8)', // Resolves to 8px\n opacity: 1,\n },\n },\n },\n\n '&[data-state=\"checked\"]': {\n background: theme.colors.border.strong,\n '&::after': {\n opacity: 1,\n transform: 'scale(1)',\n background: theme.colors.border.defaultSelected,\n },\n },\n}))\n\ntype RadioIndicatorProps = Omit<\n RadioGroupPrimitive.RadioGroupIndicatorProps,\n 'asChild' | 'forceMount'\n>\n/**\n * Styled Radix `RadioIndicator` component.\n * @see Docs https://www.radix-ui.com/primitives/docs/components/radio-group#indicator\n * @internal Not to be used outside the library.\n */\nexport const RadioIndicator = forwardRef<HTMLSpanElement, RadioIndicatorProps>(\n (props, forwardedRef) => <StyledRadioIndicator ref={forwardedRef} forceMount {...props} />,\n)\n","import styled from '@emotion/styled'\nimport { forwardRef } from 'react'\n\nimport { useStableId } from '../../hooks'\nimport { mergeRefs } from '../../utils/merge-refs'\nimport type { HTMLQdsProps } from '../../types'\nimport { dataAttr } from '../../utils/html-attributes'\n\nimport { useRadioGroupContext } from './radio-group-context'\n\nconst Label = styled.span(({ theme }) => ({\n ...theme.typography.label.md,\n '&[data-disabled]': {\n opacity: 0.4,\n },\n}))\n\nexport type RadioGroupLabelProps = HTMLQdsProps<'span'>\n\nexport const RadioGroupLabel = forwardRef<HTMLSpanElement, RadioGroupLabelProps>(\n (props, forwardedRef) => {\n const { id: idProp, ...restProps } = props\n const id = useStableId(idProp)\n const { labelRefCallback, isDisabled } = useRadioGroupContext({\n consumerName: 'RadioGroupLabel',\n })\n\n return (\n <Label\n ref={mergeRefs(labelRefCallback, forwardedRef)}\n id={id}\n data-disabled={dataAttr(isDisabled)}\n {...restProps}\n />\n )\n },\n)\n","import type { MutableRefObject, RefCallback } from 'react'\n\nimport type { LegitimateAny } from '../types'\n\ntype ReactRef<T> = RefCallback<T> | MutableRefObject<T>\ntype Maybe<T> = T | null | undefined\n\nfunction assignRef<T = LegitimateAny>(ref: Maybe<ReactRef<T>>, value: T) {\n // eslint-disable-next-line eqeqeq\n if (ref == null) return\n\n if (typeof ref === 'function') {\n ref(value)\n return\n }\n\n ref.current = value\n}\n\nexport const mergeRefs = <T>(...refs: Maybe<ReactRef<T>>[]) => {\n return (node: T | null) => {\n refs.forEach((ref) => assignRef(ref, node))\n }\n}\n","import styled from '@emotion/styled'\nimport { forwardRef, useState } from 'react'\nimport * as RadioGroupPrimitive from '@radix-ui/react-radio-group'\n\nimport { useStableId } from '../../../hooks'\nimport { dataAttr } from '../../../utils/html-attributes'\nimport { useRadioGroupContext } from '../radio-group-context'\nimport { RadioIndicator } from '../radio-indicator'\n\nconst RadioButtonContainer = styled.label(({ theme }) => ({\n display: 'grid',\n gridTemplateColumns: 'auto 1fr',\n alignItems: 'start',\n gap: theme.spacing['3x'],\n cursor: 'pointer',\n WebkitTapHighlightColor: 'transparent',\n WebkitTouchCallout: 'none',\n '&:has([role=\"radio\"][data-disabled])': {\n cursor: 'not-allowed',\n },\n}))\n\nconst RadioItem = styled(RadioGroupPrimitive.Item)(({ theme }) => ({\n borderRadius: theme.radii.full,\n transitionProperty: 'outline',\n transitionDuration: '120ms',\n transitionTimingFunction: 'ease-out',\n outlineOffset: 0,\n outline: '0 solid transparent',\n ':focus-visible': {\n outlineColor: theme.colors.border.defaultSelected,\n outlineWidth: 2,\n outlineStyle: 'solid',\n outlineOffset: 3,\n },\n '&[data-disabled], &:disabled, &[disabled]': {\n opacity: 0.4,\n },\n\n WebkitTouchCallout: 'none',\n WebkitTapHighlightColor: 'transparent',\n}))\n\ninterface RadioButtonOptions {\n /**\n * The label for the radio button\n */\n label: string\n /**\n * If `true` the user must check the radio item before the owning form can be submitted.\n * @default false\n */\n isRequired?: boolean\n /**\n * If `true` it prevents the user from interacting with the radio item.\n * @default false\n */\n isDisabled?: boolean\n}\n\nexport interface RadioButtonProps\n extends Omit<RadioGroupPrimitive.RadioGroupItemProps, 'asChild' | keyof RadioButtonOptions>,\n RadioButtonOptions {}\n\nconst Label = styled.span(({ theme }) => ({\n ...theme.typography.body.md,\n '&[data-disabled]': {\n opacity: 0.4,\n },\n}))\n\nexport const RadioButton = forwardRef<HTMLButtonElement, RadioButtonProps>(\n (props, forwardedRef) => {\n const {\n label,\n disabled: hasHtmlDisabledAttr,\n isDisabled: isDisabledProp,\n required: hasHtmlRequiredAttr,\n isRequired: isRequiredProp,\n id: idProp,\n 'aria-describedby': ariaDescribedByProp,\n onMouseEnter,\n onMouseLeave,\n ...rest\n } = props\n const [isHovered, setIsHovered] = useState(false)\n\n const id = useStableId(idProp)\n const labelId = `${id}-label`\n\n const { errorMessageId, isDisabled: isGroupDisabled } = useRadioGroupContext({\n consumerName: 'RadioButton',\n })\n\n const ariaDescribedBy =\n [errorMessageId, ariaDescribedByProp].filter(Boolean).join(' ') || undefined\n\n const isDisabled = isDisabledProp ?? hasHtmlDisabledAttr ?? isGroupDisabled\n const isRequired = isRequiredProp ?? hasHtmlRequiredAttr\n\n return (\n <RadioButtonContainer>\n <RadioItem\n ref={forwardedRef}\n disabled={isDisabled}\n // For some reason if we pass e.g. `required={undefined}` it will override\n // the `required` attribute from the `RadioGroup`. Seems to be something with\n // how Radix handles the state internally.\n {...(isRequired && { required: true })}\n aria-labelledby={labelId}\n aria-describedby={ariaDescribedBy}\n onMouseEnter={(ev) => {\n setIsHovered(true)\n onMouseEnter?.(ev)\n }}\n onMouseLeave={(ev) => {\n setIsHovered(false)\n onMouseLeave?.(ev)\n }}\n {...rest}\n >\n <RadioIndicator data-hover={dataAttr(isHovered)} />\n </RadioItem>\n <Label\n id={labelId}\n data-disabled={dataAttr(isDisabled)}\n onMouseEnter={() => setIsHovered(true)}\n onMouseLeave={() => setIsHovered(false)}\n onMouseDown={(ev) => {\n // prevent text selection when double clicking label\n if (ev.detail > 1) {\n ev.preventDefault()\n }\n }}\n >\n {label}\n </Label>\n </RadioButtonContainer>\n )\n },\n)\n","import { forwardRef } from 'react'\nimport styled from '@emotion/styled'\n\nimport { useFormField } from '../../hooks'\nimport type { HTMLQdsProps } from '../../types'\nimport { Label } from '../label'\nimport type { SelectBaseOptions } from '../primitives/select-base'\nimport { SelectBase } from '../primitives/select-base'\nimport { ErrorMessage, FormField, HelperText } from '../_internal'\nimport { useTranslation } from '../../i18n/use-translation'\n\nimport type { SelectOptionProps } from './select-option'\nimport { SelectOption } from './select-option'\n\nconst OptionalText = styled.span(({ theme }) => ({\n ...theme.typography.body.sm,\n color: theme.colors.text.subtle,\n}))\n\ninterface SelectOptions extends SelectBaseOptions {\n /**\n * The label for the select field\n */\n label: string\n /**\n * The error message to display if `isInvalid` is `true`\n */\n errorMessage?: string\n /**\n * Text that provides additional guidance to the user\n */\n helperText?: string\n /**\n * If `true`, the select field will display an optional indicator.\n * If the `isRequired` prop is also `true`, this prop will be ignored.\n */\n isOptional?: boolean\n}\n\ntype OmittedProps = 'readOnly' | 'size'\n\nexport interface SelectProps extends Omit<HTMLQdsProps<'select'>, OmittedProps>, SelectOptions {}\n\nconst SelectRoot = forwardRef<HTMLSelectElement, SelectProps>((props, forwardedRef) => {\n const {\n children,\n label,\n isInvalid,\n errorMessage,\n helperText,\n isRequired,\n isOptional: isOptionalProp,\n ...restProps\n } = props\n const {\n getLabelProps,\n getFieldProps: getSelectProps,\n getErrorMessageProps,\n getHelperTextProps,\n } = useFormField(props)\n const { t } = useTranslation()\n\n const helperTextElement = helperText ? (\n <HelperText {...getHelperTextProps()}>{helperText}</HelperText>\n ) : null\n\n const shouldShowErrorMessage = isInvalid && errorMessage\n const errorMessageElement = shouldShowErrorMessage ? (\n <ErrorMessage {...getErrorMessageProps()}>{errorMessage}</ErrorMessage>\n ) : null\n\n const isOptional = Boolean(!isRequired && isOptionalProp)\n\n return (\n <FormField>\n <Label {...getLabelProps()}>\n {label}\n {isOptional && <OptionalText>{` (${t('optional')})`}</OptionalText>}\n </Label>\n <SelectBase ref={forwardedRef} {...getSelectProps(restProps)}>\n {children}\n </SelectBase>\n {errorMessageElement || helperTextElement}\n </FormField>\n )\n})\n\nexport const Select = Object.assign(SelectRoot, { Option: SelectOption })\nexport type { SelectOptionProps }\n","import { forwardRef } from 'react'\n\nimport type { HTMLQdsProps } from '../../types'\n\ninterface SelectOptionOptions {\n isDisabled?: boolean\n}\n\ntype OmittedProps = 'disabled' | 'label'\nexport interface SelectOptionProps\n extends Omit<HTMLQdsProps<'option'>, OmittedProps>,\n SelectOptionOptions {}\n\nexport const SelectOption = forwardRef<HTMLOptionElement, SelectOptionProps>(\n (props, forwardedRef) => {\n const { children, isDisabled, ...restProps } = props\n return (\n <option ref={forwardedRef} disabled={isDisabled} {...restProps}>\n {children}\n </option>\n )\n },\n)\n","import { forwardRef } from 'react'\nimport styled from '@emotion/styled'\n\nimport type { Theme } from '../../theme'\nimport type { HTMLQdsProps } from '../../types'\nimport type { ResponsiveProp } from '../../styles/responsive'\nimport { toMediaQueries } from '../../styles/responsive'\n\ntype Spacing = keyof Theme['spacing']\n\nconst StyledSpan = styled.span<Required<SpacerOptions>>(({ axis, size, theme }) => ({\n display: 'block',\n\n ...toMediaQueries(size, (currentValue) => {\n const resolvedValue = theme.spacing[currentValue]\n return {\n width: axis === 'x' ? resolvedValue : 1,\n minWidth: axis === 'x' ? resolvedValue : 1,\n height: axis === 'y' ? resolvedValue : 1,\n minHeight: axis === 'y' ? resolvedValue : 1,\n }\n }),\n}))\n\ninterface SpacerOptions {\n axis?: 'x' | 'y'\n size: ResponsiveProp<Spacing>\n}\n\nexport interface SpacerProps extends HTMLQdsProps<'span'>, SpacerOptions {}\nexport const Spacer = forwardRef<HTMLSpanElement, SpacerProps>((props, forwardedRef) => {\n const { axis = 'y', size, ...restProps } = props\n\n return <StyledSpan ref={forwardedRef} aria-hidden=\"true\" size={size} axis={axis} {...restProps} />\n})\n","import type { ReactNode } from 'react'\nimport { Fragment, forwardRef } from 'react'\nimport styled from '@emotion/styled'\nimport isPropValid from '@emotion/is-prop-valid'\n\nimport type { Merge } from '../../types'\nimport type { Theme } from '../../theme'\nimport type * as Polymorphic from '../../utils/polymorphic'\nimport type { ResponsiveProp } from '../../styles/responsive'\nimport { toMediaQueries } from '../../styles/responsive'\n\nimport { getValidChildren } from './stack.utils'\nimport type { AlignItems, FlexDirection, JustifyContent, FlexWrap } from './stack.types'\n\ntype StyledStackProps = Merge<\n StackOptions,\n {\n direction: ResponsiveProp<FlexDirection>\n justifyContent: ResponsiveProp<JustifyContent>\n alignItems: ResponsiveProp<AlignItems>\n gap: ResponsiveProp<GapProp>\n }\n>\nconst StyledStack = styled('div', { shouldForwardProp: isPropValid })<StyledStackProps>(\n ({ theme, wrap, gap }) => ({\n display: 'flex',\n flexWrap: wrap,\n ...toMediaQueries(gap, (currentValue) => ({ gap: theme.spacing[currentValue] })),\n }),\n ({ justifyContent }) => ({\n ...toMediaQueries(justifyContent, (currentValue) => ({ justifyContent: currentValue })),\n }),\n ({ alignItems }) => ({\n ...toMediaQueries(alignItems, (currentValue) => ({ alignItems: currentValue })),\n }),\n // Note that this has to be a separate object to avoid\n // the media queries from `expandResponsiveProp` to be overridden\n // when both direction and gap are responsive\n ({ direction }) => ({\n ...toMediaQueries(direction, (currentValue) => ({ flexDirection: currentValue })),\n }),\n)\n\ntype GapProp = keyof Theme['spacing']\ninterface StackOptions {\n /**\n * The direction of the stack.\n * @default 'column'\n */\n direction?: ResponsiveProp<FlexDirection>\n /**\n * The CSS `justify-content` property.\n * Controls the alignment of items on the main axis.\n */\n justifyContent?: ResponsiveProp<JustifyContent>\n /**\n * The CSS `align-items` property.\n * Controls the alignment of items on the cross axis.\n */\n alignItems?: ResponsiveProp<AlignItems>\n /**\n * The CSS `flex-wrap` property.\n * Controls whether children can wrap onto multiple lines.\n * @default 'nowrap'\n */\n wrap?: FlexWrap\n /**\n * The gap between each child element.\n */\n gap?: ResponsiveProp<GapProp>\n /**\n * A divider element to be rendered between each child element.\n *\n * _Note: For the divider to be rendered, the child elements can't be loose strings or numbers.\n * Wrap them in a `div` or other element._\n */\n divider?: ReactNode\n}\n\ntype StackComponent = Polymorphic.ForwardRefComponent<'div', StackOptions>\nexport type StackProps = Polymorphic.PropsOf<StackComponent>\n\nexport const Stack = forwardRef((props, forwardedRef) => {\n const {\n as,\n children,\n direction = 'column',\n justifyContent = 'flex-start',\n alignItems = 'stretch',\n divider,\n gap = '0x',\n ...restProps\n } = props\n\n const hasDivider = Boolean(divider)\n\n const resolvedChildren = !hasDivider\n ? children\n : getValidChildren(children).map((child, index, validChildren) => {\n // Prefer provided child key and fallback to index\n const key = typeof child.key !== 'undefined' ? child.key : index\n const isLast = index + 1 === validChildren.length\n\n const currentDivider = isLast ? null : divider\n\n return (\n <Fragment key={key}>\n {child}\n {currentDivider}\n </Fragment>\n )\n })\n\n return (\n <StyledStack\n as={as}\n ref={forwardedRef}\n direction={direction}\n justifyContent={justifyContent}\n alignItems={alignItems}\n gap={gap}\n {...restProps}\n >\n {resolvedChildren}\n </StyledStack>\n )\n}) as StackComponent\n","import type { ReactElement, ReactNode } from 'react'\nimport { Children, isValidElement } from 'react'\n\n/**\n * Gets only the valid children of a component,\n * and ignores any nullish or falsy child.\n */\nexport function getValidChildren(children: ReactNode) {\n return Children.toArray(children).filter((child) => isValidElement(child)) as ReactElement[]\n}\n","import styled from '@emotion/styled'\nimport * as RadixSwitch from '@radix-ui/react-switch'\nimport { CheckIcon } from 'lucide-react'\nimport { forwardRef } from 'react'\n\nimport { useStableId } from '../../hooks'\nimport { pxToRem } from '../../styles'\nimport { Label } from '../label'\n\ninterface SwitchOptions {\n /**\n * The label for the switch\n */\n label: string\n /**\n * The text that appears below the label\n * to provide additional guidance to the user\n */\n helperText?: string\n /**\n * The checked state of the checkbox when it is initially rendered. Use when you do not need to control its checked state.\n */\n isDefaultChecked?: boolean\n /**\n * If `true`, the switch will be checked\n */\n isChecked?: boolean\n /**\n * If `true`, the switch will be disabled and\n * cannot be interacted with\n */\n isDisabled?: boolean\n /**\n * If `true`, indicates that the switch is required\n */\n isRequired?: boolean\n onCheckedChange?: (isChecked: boolean) => void\n}\n\nexport interface SwitchProps\n extends Omit<RadixSwitch.SwitchProps, 'asChild' | keyof SwitchOptions>,\n SwitchOptions {}\n\nexport const Switch = forwardRef<HTMLButtonElement, SwitchProps>((props, forwardedRef) => {\n const {\n id: idProp,\n label,\n helperText,\n defaultChecked: hasHtmlDefaultCheckedAttr,\n isDefaultChecked: isDefaultCheckedProp,\n isChecked: isCheckedProp,\n checked: hasHtmlCheckedAttr,\n disabled: hasHtmlDisabledAttr,\n isDisabled: isDisabledProp,\n isRequired: isRequiredProp,\n required: hasHtmlRequiredAttr,\n 'aria-labelledby': ariaLabelledByProp,\n 'aria-describedby': ariaDescribedByProp,\n onCheckedChange,\n ...restProps\n } = props\n\n const id = useStableId(idProp)\n\n const isDefaultChecked = isDefaultCheckedProp || hasHtmlDefaultCheckedAttr\n const isChecked = isCheckedProp || hasHtmlCheckedAttr\n const isDisabled = isDisabledProp || hasHtmlDisabledAttr\n const isRequired = isRequiredProp || hasHtmlRequiredAttr\n\n const labelId = `${id}-label`\n const ariaLabelledBy = [labelId, ariaLabelledByProp].filter(Boolean).join(' ')\n\n const hasHelperText = Boolean(helperText)\n const helperTextId = hasHelperText ? `${id}-helper-text` : undefined\n const ariaDescribedBy = [helperTextId, ariaDescribedByProp].filter(Boolean).join(' ') || undefined\n\n return (\n <SwitchWrapper>\n <SwitchTexts>\n <SwitchLabel id={labelId} htmlFor={id} data-disabled={isDisabled ? '' : undefined}>\n {label}\n </SwitchLabel>\n {hasHelperText && (\n <SwitchHelperText id={helperTextId} data-disabled={isDisabled ? '' : undefined}>\n {helperText}\n </SwitchHelperText>\n )}\n </SwitchTexts>\n <SwitchRoot\n id={id}\n ref={forwardedRef}\n defaultChecked={isDefaultChecked}\n checked={isChecked}\n disabled={isDisabled}\n required={isRequired}\n aria-labelledby={ariaLabelledBy}\n aria-describedby={ariaDescribedBy}\n onCheckedChange={(isChecked) => onCheckedChange?.(isChecked)}\n {...restProps}\n >\n <SwitchThumb>\n <CheckIcon data-part=\"switch-icon\" size={12} absoluteStrokeWidth strokeWidth={2} />\n </SwitchThumb>\n </SwitchRoot>\n </SwitchWrapper>\n )\n})\n\nconst SwitchLabel = styled(Label)(() => ({\n marginTop: pxToRem(6),\n}))\n\nconst SwitchHelperText = styled.div(({ theme }) => ({\n flexGrow: 1,\n flexShrink: 1,\n color: theme.colors.text.subtle,\n cursor: 'default',\n ...theme.typography.body.sm,\n '&[data-disabled]': {\n opacity: 0.4,\n },\n}))\n\nconst SwitchWrapper = styled.div(({ theme }) => ({\n display: 'flex',\n gap: theme.spacing['4x'],\n alignItems: 'start',\n}))\n\nconst SwitchTexts = styled.div(({ theme }) => ({\n display: 'flex',\n flexDirection: 'column',\n flexGrow: 1,\n flexShrink: 1,\n justifyContent: 'space-between',\n gap: theme.sizes['2x'],\n}))\n\nconst SwitchRoot = styled(RadixSwitch.Root)(({ theme }) => ({\n flexGrow: 0,\n flexShrink: 0,\n flexBasis: 'auto',\n width: pxToRem(56),\n height: pxToRem(32),\n backgroundColor: theme.colors.core.gray40,\n transition: 'background-color 200ms',\n borderRadius: theme.radii.full,\n '&:hover:not([data-disabled])': {\n backgroundColor: theme.colors.core.gray30,\n },\n '&[data-disabled]': {\n opacity: 0.4,\n },\n '&[data-state=\"checked\"]': {\n backgroundColor: theme.colors.bg.brandSecondary,\n '[data-part=\"switch-icon\"]': {\n opacity: 1,\n },\n },\n '&:hover[data-state=\"checked\"]': {\n backgroundColor: theme.colors.bg.brandSecondaryHover,\n },\n '[data-part=\"switch-icon\"]': {\n opacity: 0,\n transition: 'opacity 200ms',\n },\n}))\n\nconst SwitchThumb = styled(RadixSwitch.Thumb)(({ theme }) => ({\n display: 'flex',\n flexGrow: 0,\n flexShrink: 0,\n flexBasis: 'auto',\n justifyContent: 'center',\n alignItems: 'center',\n width: theme.sizes['6x'],\n height: theme.sizes['6x'],\n boxShadow: theme.shadows.sm,\n backgroundColor: theme.colors.bg.default,\n borderRadius: theme.radii.full,\n transition: 'transform 300ms',\n transform: `translateX(${pxToRem(4)})`,\n willChange: 'transform',\n '&[data-state=\"checked\"]': {\n transform: `translateX(${pxToRem(28)})`,\n },\n '&[data-disabled]': {\n boxShadow: theme.shadows.none,\n },\n}))\n","import { forwardRef } from 'react'\nimport styled from '@emotion/styled'\n\nimport { useFormField } from '../../hooks'\nimport type { HTMLQdsProps } from '../../types'\nimport { Label } from '../label'\nimport type { TextareaBaseOptions } from '../primitives/textarea-base'\nimport { TextareaBase } from '../primitives/textarea-base'\nimport { ErrorMessage, FormField, HelperText } from '../_internal'\nimport { useTranslation } from '../../i18n/use-translation'\n\nconst OptionalText = styled.span(({ theme }) => ({\n ...theme.typography.body.sm,\n color: theme.colors.text.subtle,\n}))\n\ninterface TextareaOptions extends TextareaBaseOptions {\n /**\n * The label for the textarea field\n */\n label: string\n /**\n * The error message to display if `isInvalid` is `true`\n */\n errorMessage?: string\n /**\n * Text that provides additional guidance to the user\n */\n helperText?: string\n /**\n * If `true`, the input will display an optional indicator.\n * If the `isRequired` prop is also `true`, this prop will be ignored.\n */\n isOptional?: boolean\n}\n\ntype OmittedProps = 'children' | 'readOnly' | 'size'\n\nexport interface TextareaProps\n extends Omit<HTMLQdsProps<'textarea'>, OmittedProps>,\n TextareaOptions {}\n\nexport const Textarea = forwardRef<HTMLTextAreaElement, TextareaProps>((props, forwardedRef) => {\n const {\n label,\n isInvalid,\n errorMessage,\n helperText,\n isRequired,\n isOptional: isOptionalProp,\n ...restProps\n } = props\n const {\n getLabelProps,\n getFieldProps: getTextareaProps,\n getErrorMessageProps,\n getHelperTextProps,\n } = useFormField<'textarea'>(props)\n const { t } = useTranslation()\n\n const helperTextElement = helperText ? (\n <HelperText {...getHelperTextProps()}>{helperText}</HelperText>\n ) : null\n\n const shouldShowErrorMessage = isInvalid && errorMessage\n const errorMessageElement = shouldShowErrorMessage ? (\n <ErrorMessage {...getErrorMessageProps()}>{errorMessage}</ErrorMessage>\n ) : null\n\n const isOptional = Boolean(!isRequired && isOptionalProp)\n\n return (\n <FormField>\n <Label {...getLabelProps()}>\n {label}\n {isOptional && <OptionalText>{` (${t('optional')})`}</OptionalText>}\n </Label>\n <TextareaBase ref={forwardedRef} {...getTextareaProps(restProps)} />\n {errorMessageElement || helperTextElement}\n </FormField>\n )\n})\n"]}
1
+ {"version":3,"sources":["../src/qds-provider.tsx","../src/theme/foundations/breakpoints.ts","../src/theme/foundations/colors.ts","../src/styles/css-utils.ts","../src/styles/common-styles.ts","../src/theme/foundations/spacing.ts","../src/theme/foundations/z-index.ts","../src/theme/foundations/sizes.ts","../src/theme/foundations/radius.ts","../src/theme/foundations/shadows.ts","../src/theme/foundations/typography.ts","../src/theme/foundations/index.ts","../src/theme/theme.ts","../src/utils/object.ts","../src/theme/theme-tools.ts","../src/i18n/locale-context.tsx","../src/components/toast/toast-provider.tsx","../src/components/toast/toast-store.ts","../src/components/toast/toast.tsx","../src/components/icon/create-icon.tsx","../src/components/icon/create-lucide-icon.tsx","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/shared/src/utils.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/defaultAttributes.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/Icon.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/createLucideIcon.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/arrow-down.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/arrow-left.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/arrow-right.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/arrow-up.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/bell-off.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/bell.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/bookmark.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/calendar.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/camera.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/check.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/chevron-down.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/chevron-left.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/chevron-right.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/chevron-up.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/circle-alert.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/circle-check.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/circle-help.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/circle-x.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/ellipsis-vertical.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/ellipsis.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/globe.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/heart.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/history.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/house.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/image.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/info.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/list-filter.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/list.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/log-out.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/map-pin.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/map.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/menu.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/message-circle.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/minus.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/pen.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/plus.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/search.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/settings-2.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/settings.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/share.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/star.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/trash-2.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/triangle-alert.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/user-round.ts","../../../node_modules/.pnpm/lucide-react@0.475.0_react@19.0.0/node_modules/lucide-react/src/icons/x.ts","../src/components/icon/icons.tsx","../src/components/toast/toast-styles.tsx","../src/components/avatar/avatar.tsx","../src/styles/responsive.ts","../src/components/button/button.tsx","../src/components/loading-dots/loading-dots.tsx","../src/components/button/button-styles.tsx","../src/components/button/button-icon.tsx","../src/components/display-text/display-text.tsx","../src/components/checkbox/checkbox.tsx","../src/hooks/use-breakpoint.ts","../src/hooks/use-breakpoint-value.ts","../src/hooks/use-form-field.ts","../src/hooks/use-stable-id.ts","../src/hooks/use-safe-layout-effect.ts","../src/utils/html-attributes.ts","../src/components/_internal/form-parts.tsx","../src/components/divider/divider.tsx","../src/components/dropdown-menu/dropdown-menu.tsx","../src/components/dropdown-menu/dropdown-menu-content.tsx","../src/components/dropdown-menu/dropdown-menu-divider.tsx","../src/components/dropdown-menu/dropdown-menu-item.tsx","../src/components/dropdown-menu/dropdown-menu-trigger.tsx","../src/components/heading/heading.tsx","../src/components/hint-box/hint-box.tsx","../src/components/icon-button/icon-button.tsx","../src/components/icon-button/icon-button-styles.tsx","../src/components/text-field/text-field.tsx","../src/i18n/locales.ts","../src/i18n/use-translation.tsx","../src/components/label/label.tsx","../src/components/primitives/input-base/input-base.tsx","../src/components/link/link.tsx","../src/components/paragraph/paragraph.tsx","../src/components/primitives/select-base/select-base.tsx","../src/components/primitives/textarea-base/textarea-base.tsx","../src/components/radio-group/radio-group.tsx","../src/components/radio-group/radio-group-context.tsx","../src/components/radio-group/radio-card/radio-card.tsx","../src/components/radio-group/radio-indicator.tsx","../src/components/radio-group/radio-group-label.tsx","../src/utils/merge-refs.ts","../src/components/radio-group/radio-button/radio-button.tsx","../src/components/select/select.tsx","../src/components/select/select-option.tsx","../src/components/spacer/spacer.tsx","../src/components/stack/stack.tsx","../src/components/stack/stack.utils.tsx","../src/components/switch/switch.tsx","../src/components/textarea/textarea.tsx"],"names":["ThemeProvider","CacheProvider","createCache","breakpoints","core","colors","createStyleVariants","styles","theme","createStyle","pxToRem","px","getFormFieldBaseStyles","radii","typography","spacing","__spreadProps","__spreadValues","zIndices","sizes","shadows","fontStacks","foundations","mediaQueries","objectKeys","obj","overrideTypography","overrides","result","group","override","typographyGroup","key","deepMerge","target","source","overrideTheme","createContext","useContext","jsx","LocaleContext","LocaleProvider","language","children","useLocale","context","ToastPrimitive","useSyncExternalStore","styled","AnimatePresence","flushSync","ToastStore","subscriber","index","toast","_a","id","text","options","toastStore","motion","Children","forwardRef","StyledSvg","color","createIcon","viewBox","pathDefinition","displayName","path","Component","props","forwardedRef","size","rest","__objRest","useTheme","createLucideIcon","Icon","ref","_b","resolvedColor","toKebabCase","string","mergeClasses","classes","className","array","defaultAttributes","strokeWidth","absoluteStrokeWidth","iconNode","createElement","tag","attrs","iconName","__iconNode","ArrowDown","ArrowLeft","ArrowRight","ArrowUp","BellOff","Bell","Bookmark","Calendar","Camera","Check","ChevronDown","ChevronLeft","ChevronRight","ChevronUp","CircleAlert","CircleCheck","CircleHelp","CircleX","EllipsisVertical","Ellipsis","Globe","Heart","History","House","Image","Info","ListFilter","List","LogOut","MapPin","Map","Menu","MessageCircle","Minus","Pen","Plus","Search","Settings2","Settings","Share","Star","Trash2","TriangleAlert","UserRound","X","AlertCircleIcon","AlertTriangleIcon","ArrowDownIcon","ArrowLeftIcon","ArrowRightIcon","ArrowUpIcon","BellIcon","BellOffIcon","BookmarkIcon","CalendarIcon","CameraIcon","CheckCircleIcon","CheckIcon","ChevronDownIcon","ChevronLeftIcon","ChevronRightIcon","ChevronUpIcon","GlobeIcon","HeartFilledIcon","HeartIcon","HelpCircleIcon","HistoryIcon","HomeIcon","ImageIcon","InfoIcon","ListIcon","ListFilterIcon","LogOutIcon","MapIcon","MapPinIcon","MenuIcon","MessageCircleIcon","MinusIcon","MoreHorizontalIcon","MoreVerticalIcon","PenIcon","PlusIcon","SearchIcon","SettingsIcon","ShareIcon","SlidersIcon","StarFilledIcon","StarIcon","TrashIcon","UserIcon","XCircleIcon","XIcon","getVariantStyles","jsxs","Wrapper","variant","Title","IconWrapper","ICON_MAP","Toast","Viewport","ToastProvider","toasts","isOpen","fallbackEmotionCache","QdsProvider","themeOverrides","emotionCache","locale","resolvedTheme","isPropValid","AvatarPrimitive","isResponsiveProp","value","objectEntries","toMediaQueries","prop","styleFn","base","cssObject","breakpoint","mediaQuery","SIZE_MAP","ICON_SIZE_MAP","TEXT_SIZE_MAP","getInitials","name","names","firstName","lastName","AvatarRoot","currentValue","AvatarImage","AvatarFallback","FallbackText","avatarSize","roundToTwoDecimals","num","StyledIcon","Avatar","src","restProps","keyframes","ANIMATION_DURATION","ANIMATION_STAGGER_DELAY","getSizeStyles","scaleAnimation","Dot","LoadingDots","NOT_DISABLED","ICON_GAP","ICON_OFFSET","IconLeftContainer","buttonSize","iconSize","IconRightContainer","ButtonIcon","placement","StyledButton","isFullWidth","ButtonLoadingDots","ContentContainer","isHidden","Button","as","type","sizeProp","isLoading","isDisabled","hasHtmlDisabledProp","iconLeft","iconRight","StyledDisplayText","textAlign","textWrap","DisplayText","CheckboxPrimitive","useEffect","useState","breakpointsArray","MEDIA_QUERIES","nextValue","media","getMatchingBreakpoint","matchingBreakpoint","useBreakpoint","params","ssr","initialBreakpoint","currentBreakpoint","setCurrentBreakpoint","matchMediaArray","handleChange","useBreakpointValue","values","breakpointValue","breakpointNames","currentBreakpointIndex","i","useCallback","React","useLayoutEffect","useSafeLayoutEffect","useReactId","count","useStableId","fixedId","setId","reactId","useFormField","idProp","helperText","errorMessage","isInvalid","isRequired","errorMessageId","helperTextId","getLabelProps","forwardedProps","getHelperTextProps","getErrorMessageProps","getFieldProps","ariaDescribedByIds","dataAttr","condition","ariaAttr","FieldWrapper","FormField","ErrorMessage","HelperText","CheckboxContainer","CheckboxRoot","LabelText","SupportingTextContainer","Checkbox","label","hasHtmlDefaultCheckedAttr","isDefaultCheckedProp","isCheckedProp","hasHtmlCheckedAttr","isDisabledProp","hasHtmlDisabledAttr","isRequiredProp","hasHtmlRequiredAttr","ariaLabelledByProp","ariaDescribedByProp","labelId","isDefaultChecked","isChecked","ariaLabelledBy","helperTextElement","hasError","errorMessageElement","ariaDescribedBy","ev","StyledDivider","orientation","borderCssKey","Divider","DropdownPrimitive","slideUpAndFadeIn","slideRightAndFadeIn","slideDownAndFadeIn","slideLeftAndFadeIn","slideUpAndFadeOut","slideRightAndFadeOut","slideDownAndFadeOut","slideLeftAndFadeOut","StyledContent","DropdownMenuContent","sideOffset","StyledSeparator","DropdownMenuDivider","StyledItem","TextContainer","DropdownMenuItem","disabled","DropdownTriggerPrimitive","DropdownMenuTrigger","DropdownMenuRoot","onOpenChange","defaultOpen","DropdownMenu","StyledHeading","numberOfLines","Heading","HintRoot","HintBox","IconButton","ariaLabel","useRef","en","sv","fi","fr","nb","locales","useTranslation","currentLanguage","StyledLabel","Label","onMouseDown","event","StyledInput","InputBase","InputContainer","isPositionRelative","OptionalText","Suffix","TextField","isOptionalProp","suffix","getInputProps","suffixWidth","setSuffixWidth","suffixRef","t","hasSuffix","isOptional","StyledLink","Link","href","isExternal","StyledParagraph","Paragraph","SelectWrapper","SelectIconWrapper","StyledSelect","SelectBase","placeholder","StyledTextarea","resize","minRows","baseStyles","paddingVertical","minHeight","TextareaBase","RadioGroupPrimitive","RadioGroupContext","RadioGroupProvider","useRadioGroupContext","consumerName","StyledRadioIndicator","RadioIndicator","RadioItem","RadioCard","onMouseEnter","onMouseLeave","isHovered","setIsHovered","assignRef","mergeRefs","refs","node","RadioGroupLabel","labelRefCallback","RadioButtonContainer","RadioButton","isGroupDisabled","StyledRadioGroupRoot","RadioGroupRoot","labelElement","setLabelElement","RadioGroup","SelectOption","SelectRoot","getSelectProps","Select","StyledSpan","axis","resolvedValue","Spacer","Fragment","isValidElement","getValidChildren","child","StyledStack","wrap","gap","justifyContent","alignItems","direction","Stack","divider","resolvedChildren","validChildren","currentDivider","RadixSwitch","Switch","onCheckedChange","hasHelperText","SwitchWrapper","SwitchTexts","SwitchLabel","SwitchHelperText","SwitchRoot","SwitchThumb","Textarea","getTextareaProps"],"mappings":"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","sourcesContent":["import { ThemeProvider, CacheProvider, type EmotionCache } from '@emotion/react'\nimport type { ReactNode } from 'react'\nimport createCache from '@emotion/cache'\n\nimport type { ThemeOverrides } from './theme'\nimport { overrideTheme, theme } from './theme'\nimport { LocaleProvider } from './i18n/locale-context'\nimport type { LanguageCode } from './i18n/locales'\nimport { ToastProvider } from './components/toast/toast-provider'\n\nconst fallbackEmotionCache = createCache({ key: 'qds' })\ninterface QdsProviderProps {\n children: ReactNode\n themeOverrides?: ThemeOverrides\n emotionCache?: EmotionCache\n locale: LanguageCode\n}\n\nexport function QdsProvider({ children, themeOverrides, emotionCache, locale }: QdsProviderProps) {\n const resolvedTheme = themeOverrides ? overrideTheme(themeOverrides) : theme\n\n const cache = emotionCache || fallbackEmotionCache\n\n return (\n <LocaleProvider language={locale || 'en'}>\n <CacheProvider value={cache}>\n <ThemeProvider theme={resolvedTheme}>\n <ToastProvider>{children}</ToastProvider>\n </ThemeProvider>\n </CacheProvider>\n </LocaleProvider>\n )\n}\n","export const breakpoints = {\n base: 0,\n sm: 480,\n md: 768,\n lg: 1024,\n xl: 1280,\n '2xl': 1536,\n} as const\n","const core = {\n black: '#000000',\n white: '#ffffff',\n\n gray90: '#26261D',\n gray80: '#424236',\n gray70: '#545448',\n gray60: '#78786C',\n gray50: '#A3A396',\n gray40: '#D6D6CD',\n gray30: '#E5E5DF',\n gray20: '#F0F0EB',\n gray10: '#F9F9F6',\n pink: '#FF84B6',\n uiPink: '#FF99C2',\n uiPinkDark: '#FF84B6',\n uiPinkLight: '#FFA3C8',\n\n brown: '#342620',\n brownDark: '#2A1E1A',\n brownLight: '#3C2F29',\n\n offWhite: '#F0F0EB',\n offWhiteDark: '#E0E0D6',\n offWhiteLight: '#F6F6F3',\n\n softPink: '#FFE8F0',\n\n warmYellow: '#FFD66C',\n\n softYellow: '#FFF8CC',\n\n red90: '#8A1100',\n red80: '#A81400',\n red70: '#C21700',\n red60: '#DE1B00',\n red50: '#EF452E',\n red40: '#F47E6E',\n red30: '#F8B2A8',\n red20: '#FAD8D4',\n red10: '#FEF3F1',\n\n green90: '#00661D',\n green80: '#007D23',\n green70: '#009029',\n green60: '#00A62F',\n green50: '#30B757',\n green40: '#66CA82',\n green30: '#A1DEB2',\n green20: '#D1EFDA',\n green10: '#F5FBF7',\n\n blue90: '#00288E',\n blue80: '#0039CC',\n blue70: '#0045F6',\n blue60: '#3370FF',\n blue50: '#578FFF',\n blue40: '#80AEFF',\n blue30: '#BDD7FF',\n blue20: '#DBEBFF',\n blue10: '#F0F7FF',\n\n yellow90: '#9B6D00',\n yellow80: '#C58B00',\n yellow70: '#E29F00',\n yellow60: '#F3AB00',\n yellow50: '#F5B92B',\n yellow40: '#F7C652',\n yellow30: '#F9D682',\n yellow20: '#FBE6B2',\n yellow10: '#FEF7E5',\n\n blackAlpha5: 'rgba(0, 0, 0, 0.05)',\n blackAlpha10: 'rgba(0, 0, 0, 0.1)',\n blackAlpha20: 'rgba(0, 0, 0, 0.2)',\n}\n\nexport const colors = {\n core,\n bg: {\n default: core.white,\n brandPrimary: core.uiPink,\n brandPrimaryHover: core.uiPinkLight,\n brandPrimaryActive: core.uiPinkDark,\n brandSecondary: core.brown,\n brandSecondaryHover: core.brownLight,\n brandSecondaryActive: core.brownDark,\n brandTertiary: core.offWhite,\n brandTertiaryHover: core.offWhiteLight,\n brandTertiaryActive: core.offWhiteDark,\n negative: core.red60,\n warning: core.yellow60,\n positive: core.green60,\n inset: core.gray10,\n backdrop: core.blackAlpha20,\n },\n text: {\n strong: core.black,\n default: core.brown,\n subtle: core.gray60,\n disabled: core.gray50,\n negative: core.red60,\n warning: core.yellow90,\n positive: core.green70,\n onBrandPrimary: core.brown,\n onBrandSecondary: core.offWhite,\n onBrandTertiary: core.brown,\n },\n icon: {\n default: core.brown,\n strong: core.black,\n subtle: core.gray60,\n disabled: core.gray50,\n negative: core.red60,\n warning: core.yellow70,\n positive: core.green70,\n onBrandPrimary: core.brown,\n onBrandSecondary: core.offWhite,\n onBrandTertiary: core.brown,\n },\n border: {\n default: core.gray30,\n defaultHover: core.gray40,\n defaultSelected: core.brown,\n strong: core.gray40,\n subtle: core.gray20,\n negative: core.red60,\n warning: core.yellow60,\n positive: core.green60,\n },\n}\n","import type { CSSObject } from '@emotion/react'\n\nimport type { Theme } from '../theme'\n\ntype NamedStyles = Record<string, CSSObject>\ntype StyleInterpolation<T> = (theme: Theme) => T\n// TODO: Make `createstyleVariants`and `createStyle` accept a regular object instead of a function.\n// And infer if the return requires a theme or not.\n\n/**\n * Creates a collection of named style rules.\n */\nexport function createStyleVariants<T extends NamedStyles>(styles: StyleInterpolation<T>) {\n return (theme: Theme) => styles(theme)\n}\n\n/**\n * Create a style object. Useful for creating styles that depend on the theme.\n */\nexport function createStyle<T extends CSSObject>(styles: StyleInterpolation<T>) {\n return (theme: Theme) => styles(theme)\n}\n\nexport type VariantProps<T extends ReturnType<typeof createStyle | typeof createStyleVariants>> =\n keyof ReturnType<T>\n\n/**\n * Converts css `px` unit to `rem`.\n * Assumes the root font size is 16px.\n */\nexport const pxToRem = (px: number) => `${px / 16}rem`\n","import { createStyle } from './css-utils'\n\nexport const getFormFieldBaseStyles = createStyle(({ colors, radii, typography, spacing }) => ({\n width: '100%',\n minWidth: 0,\n appearance: 'none',\n paddingLeft: spacing['4x'],\n paddingRight: spacing['4x'],\n border: `1px solid ${colors.border.default}`,\n borderRadius: radii.sm,\n backgroundColor: colors.bg.default,\n color: colors.text.default,\n WebkitTouchCallout: 'none',\n WebkitTapHighlightColor: 'transparent',\n '&::-webkit-date-and-time-value': {\n textAlign: 'left',\n },\n alignItems: 'center',\n ...typography.body.md,\n\n '&::placeholder': {\n color: colors.text.disabled,\n },\n '&:hover': {\n borderColor: colors.border.defaultHover,\n },\n '&:focus': {\n outline: 0,\n borderColor: colors.border.defaultSelected,\n boxShadow: `0 0 0 1px ${colors.border.defaultSelected}`,\n },\n '&[aria-invalid=\"true\"]': {\n borderColor: colors.border.negative,\n\n '&:focus': {\n boxShadow: `0 0 0 1px ${colors.border.negative}`,\n },\n },\n '&[disabled], &:disabled, &[data-disabled]': {\n opacity: 0.4,\n borderColor: colors.border.default,\n },\n\n transitionProperty: 'opacity, border-color, box-shadow',\n transitionDuration: '120ms',\n transitionTimingFunction: 'ease',\n}))\n","import { pxToRem } from '../../styles'\n\nexport const spacing = {\n /** 0rem (0px) */\n '0x': pxToRem(0),\n /** 0.25rem (4px) */\n '1x': pxToRem(4),\n /** 0.5rem (8px) */\n '2x': pxToRem(8),\n /** 0.75rem (12px) */\n '3x': pxToRem(12),\n /** 1rem (16px) */\n '4x': pxToRem(16),\n /** 1.25rem (20px) */\n '5x': pxToRem(20),\n /** 1.5rem (24px) */\n '6x': pxToRem(24),\n /** 2rem (32px) */\n '8x': pxToRem(32),\n /** 2.5rem (40px) */\n '10x': pxToRem(40),\n /** 3rem (48px) */\n '12x': pxToRem(48),\n /** 3.5rem (56px) */\n '14x': pxToRem(56),\n /** 4rem (64px) */\n '16x': pxToRem(64),\n /** 5rem (80px) */\n '20x': pxToRem(80),\n /** 6rem (96px) */\n '24x': pxToRem(96),\n}\n","export const zIndices = {\n /** -1 */\n hide: -1,\n /** auto */\n auto: 'auto',\n /** 0 */\n base: 0,\n /** 10 */\n docked: 10,\n /** 1000 */\n dropdown: 1000,\n /** 1100 */\n sticky: 1100,\n /** 1200 */\n banner: 1200,\n /** 1300 */\n overlay: 1300,\n /** 1400 */\n modal: 1400,\n /** 1500 */\n popover: 1500,\n /** 1600 */\n skipLink: 1600,\n /** 1700 */\n toast: 1700,\n /** 1800 */\n tooltip: 1800,\n}\n","import { pxToRem } from '../../styles'\n\nimport { spacing } from './spacing'\n\nexport const sizes = {\n ...spacing,\n 112: pxToRem(112),\n 128: pxToRem(128),\n 144: pxToRem(144),\n 160: pxToRem(160),\n 176: pxToRem(176),\n 192: pxToRem(192),\n 224: pxToRem(224),\n 256: pxToRem(256),\n 288: pxToRem(288),\n 320: pxToRem(320),\n 384: pxToRem(384),\n 448: pxToRem(448),\n 512: pxToRem(512),\n 576: pxToRem(576),\n 672: pxToRem(672),\n 768: pxToRem(768),\n 896: pxToRem(896),\n 1024: pxToRem(1024),\n}\n","export const radii = {\n /** 0px */\n none: '0px',\n /** 6px */\n '2xs': '6px',\n /** 8px */\n xs: '8px',\n /** 12px */\n sm: '12px',\n /** 16px */\n md: '16px',\n /** 24px */\n lg: '24px',\n /** 32px */\n xl: '32px',\n /** 48px */\n '2xl': '48px',\n /** 9999px */\n full: '9999px',\n}\n","export const shadows = {\n none: 'none',\n sm: '0px 0.9px 2.1px 0px rgba(0, 0, 0, 0.0197), 0px 2.1px 5px 0px rgba(0, 0, 0, 0.0283), 0px 3.9px 9.4px 0px rgba(0, 0, 0, 0.035)',\n md: '0px 0.9px 2.1px 0px rgba(0, 0, 0, 0.0197), 0px 2.1px 5px 0px rgba(0, 0, 0, 0.0283), 0px 3.9px 9.4px 0px rgba(0, 0, 0, 0.035), 0px 7px 16.8px 0px rgba(0, 0, 0, 0.0417)',\n lg: '0px 0.9px 2.1px 0px rgba(0, 0, 0, 0.0197), 0px 2.1px 5px 0px rgba(0, 0, 0, 0.0283), 0px 3.9px 9.4px 0px rgba(0, 0, 0, 0.035), 0px 7px 16.8px 0px rgba(0, 0, 0, 0.0417), 0px 13px 31.3px 0px rgba(0, 0, 0, 0.0503)',\n xl: '0px 0.9px 2.1px 0px rgba(0, 0, 0, 0.0197), 0px 2.1px 5px 0px rgba(0, 0, 0, 0.0283), 0px 3.9px 9.4px 0px rgba(0, 0, 0, 0.035), 0px 7px 16.8px 0px rgba(0, 0, 0, 0.0417), 0px 13px 31.3px 0px rgba(0, 0, 0, 0.0503), 0px 31px 75px 0px rgba(0, 0, 0, 0.07)',\n}\n","import { pxToRem } from '../../styles'\n\nconst fontStacks = {\n display: [\n 'var(--font-family-display)',\n 'Helvetica',\n '-apple-system',\n 'BlinkMacSystemFont',\n 'Roboto',\n '\"Helvetica Neue\"',\n 'sans-serif',\n ].join(','),\n sans: [\n 'var(--font-family-sans)',\n 'Helvetica',\n '-apple-system',\n 'BlinkMacSystemFont',\n 'Roboto',\n '\"Helvetica Neue\"',\n 'sans-serif',\n ].join(','),\n}\n\nexport const typography = {\n display: {\n '3xl': {\n fontFamily: fontStacks.display,\n fontWeight: '700',\n fontSize: pxToRem(80),\n lineHeight: pxToRem(80),\n letterSpacing: '-0.06em',\n fontFeatureSettings: \"'ss05' on\",\n },\n '2xl': {\n fontFamily: fontStacks.display,\n fontWeight: '700',\n fontSize: pxToRem(72),\n lineHeight: pxToRem(72),\n letterSpacing: '-0.06em',\n fontFeatureSettings: \"'ss05' on\",\n },\n xl: {\n fontFamily: fontStacks.display,\n fontWeight: '700',\n fontSize: pxToRem(64),\n lineHeight: pxToRem(64),\n letterSpacing: '-0.05em',\n fontFeatureSettings: \"'ss05' on\",\n },\n lg: {\n fontFamily: fontStacks.display,\n fontWeight: '700',\n fontSize: pxToRem(56),\n lineHeight: pxToRem(56),\n letterSpacing: '-0.05em',\n fontFeatureSettings: \"'ss05' on\",\n },\n md: {\n fontFamily: fontStacks.display,\n fontWeight: '700',\n fontSize: pxToRem(48),\n lineHeight: pxToRem(48),\n letterSpacing: '-0.04em',\n fontFeatureSettings: \"'ss05' on\",\n },\n sm: {\n fontFamily: fontStacks.display,\n fontWeight: '700',\n fontSize: pxToRem(40),\n lineHeight: pxToRem(44),\n letterSpacing: '-0.04em',\n fontFeatureSettings: \"'ss05' on\",\n },\n xs: {\n fontFamily: fontStacks.display,\n fontWeight: '700',\n fontSize: pxToRem(32),\n lineHeight: pxToRem(36),\n letterSpacing: '-0.03em',\n fontFeatureSettings: \"'ss05' on\",\n },\n '2xs': {\n fontFamily: fontStacks.display,\n fontWeight: '700',\n fontSize: pxToRem(28),\n lineHeight: pxToRem(32),\n letterSpacing: '-0.03em',\n fontFeatureSettings: \"'ss05' on\",\n },\n },\n title: {\n lg: {\n fontFamily: fontStacks.sans,\n fontWeight: '700',\n fontSize: pxToRem(32),\n lineHeight: pxToRem(36),\n letterSpacing: '-0.02em',\n },\n md: {\n fontFamily: fontStacks.sans,\n fontWeight: '700',\n fontSize: pxToRem(24),\n lineHeight: pxToRem(28),\n letterSpacing: '-0.02em',\n },\n sm: {\n fontFamily: fontStacks.sans,\n fontWeight: '700',\n fontSize: pxToRem(20),\n lineHeight: pxToRem(24),\n letterSpacing: '-0.02em',\n },\n xs: {\n fontFamily: fontStacks.sans,\n fontWeight: '700',\n fontSize: pxToRem(18),\n lineHeight: pxToRem(22),\n letterSpacing: '-0.015em',\n },\n '2xs': {\n fontFamily: fontStacks.sans,\n fontWeight: '700',\n fontSize: pxToRem(16),\n lineHeight: pxToRem(20),\n letterSpacing: '-0.01em',\n },\n '3xs': {\n fontFamily: fontStacks.sans,\n fontWeight: '700',\n fontSize: pxToRem(14),\n lineHeight: pxToRem(18),\n letterSpacing: '-0.005em',\n },\n },\n body: {\n xl: {\n fontFamily: fontStacks.sans,\n fontWeight: '400',\n fontSize: pxToRem(20),\n lineHeight: pxToRem(28),\n letterSpacing: '-0.02em',\n },\n lg: {\n fontFamily: fontStacks.sans,\n fontWeight: '400',\n fontSize: pxToRem(18),\n lineHeight: pxToRem(26),\n letterSpacing: '-0.02em',\n },\n md: {\n fontFamily: fontStacks.sans,\n fontWeight: '400',\n fontSize: pxToRem(16),\n lineHeight: pxToRem(24),\n letterSpacing: '-0.01em',\n },\n sm: {\n fontFamily: fontStacks.sans,\n fontWeight: '400',\n fontSize: pxToRem(14),\n lineHeight: pxToRem(20),\n letterSpacing: '-0.01em',\n },\n xs: {\n fontFamily: fontStacks.sans,\n fontWeight: '400',\n fontSize: pxToRem(12),\n lineHeight: pxToRem(16),\n letterSpacing: '0',\n },\n },\n label: {\n md: {\n fontFamily: fontStacks.sans,\n fontWeight: '500',\n fontSize: pxToRem(16),\n lineHeight: pxToRem(20),\n letterSpacing: '-0.02em',\n },\n sm: {\n fontFamily: fontStacks.sans,\n fontWeight: '500',\n fontSize: pxToRem(14),\n lineHeight: pxToRem(18),\n letterSpacing: '-0.01em',\n },\n },\n button: {\n md: {\n fontFamily: fontStacks.sans,\n fontWeight: '700',\n fontSize: pxToRem(16),\n lineHeight: pxToRem(18),\n letterSpacing: '-0.01em',\n },\n sm: {\n fontFamily: fontStacks.sans,\n fontWeight: '700',\n fontSize: pxToRem(14),\n lineHeight: pxToRem(16),\n letterSpacing: '-0.01em',\n },\n },\n caption: {\n md: {\n fontFamily: fontStacks.sans,\n fontWeight: '700',\n fontSize: pxToRem(12),\n lineHeight: pxToRem(12),\n letterSpacing: '0',\n },\n sm: {\n fontFamily: fontStacks.sans,\n fontWeight: '700',\n fontSize: pxToRem(10),\n lineHeight: pxToRem(10),\n letterSpacing: '0',\n },\n },\n}\n","/**\n * ------ IMPORTANT ------\n * Do not change or add to the contents of this file\n * without consulting with the design team.\n *\n * These are values that make up our brand and even\n * minor changes greatly affects our visual identity.\n *\n * The foundations are losely based on Styled System Theme Specification\n * @see https://styled-system.com/theme-specification/\n * -----------------------\n */\n\nimport { breakpoints } from './breakpoints'\nimport { colors } from './colors'\nimport { spacing } from './spacing'\nimport { zIndices } from './z-index'\nimport { sizes } from './sizes'\nimport { radii } from './radius'\nimport { shadows } from './shadows'\nimport { typography } from './typography'\n\nexport const foundations = {\n spacing,\n breakpoints,\n zIndices,\n colors,\n sizes,\n radii,\n shadows,\n typography,\n}\n","import { foundations } from './foundations'\n\nconst mediaQueries = {\n smUp: `@media(min-width: ${foundations.breakpoints.sm}px)`,\n mdUp: `@media(min-width: ${foundations.breakpoints.md}px)`,\n lgUp: `@media(min-width: ${foundations.breakpoints.lg}px)`,\n xlUp: `@media(min-width: ${foundations.breakpoints.xl}px)`,\n '2xlUp': `@media(min-width: ${foundations.breakpoints['2xl']}px)`,\n} as const\n\nexport const theme = { ...foundations, mediaQueries }\nexport type Theme = typeof theme\n","export const objectKeys = <T extends object>(obj: T): (keyof T)[] => {\n return Object.keys(obj) as (keyof T)[]\n}\n","import type { LegitimateAny, PartialRecord } from '../types'\nimport { objectKeys } from '../utils/object'\n\nimport type { Theme } from './theme'\nimport { theme } from './theme'\n\ntype DeepPartial<T> = { [P in keyof T]?: DeepPartial<T[P]> }\n\ninterface TypographyOverride {\n fontFamily?: string\n fontWeight?: '100' | '200' | '300' | '400' | '500' | '600' | '700' | '800' | '900'\n}\n\ntype TypographyOverrides = PartialRecord<keyof Theme['typography'], TypographyOverride>\n\nconst overrideTypography = (overrides: TypographyOverrides): Theme['typography'] => {\n const result = Object.assign({}, theme.typography)\n\n objectKeys(result).forEach((group) => {\n const override = overrides[group]\n if (override) {\n const typographyGroup = result[group]\n objectKeys(typographyGroup).forEach((key) => {\n typographyGroup[key].fontFamily = override.fontFamily || typographyGroup[key].fontFamily\n typographyGroup[key].fontWeight = override.fontWeight || typographyGroup[key].fontWeight\n })\n }\n })\n\n return result\n}\n\nconst deepMerge = <T extends Record<string, LegitimateAny>>(\n target: T,\n source: DeepPartial<T>,\n): T => {\n const result = Object.assign({}, target)\n\n objectKeys(source).forEach((key) => {\n if (typeof source[key] === 'object') {\n result[key] = deepMerge(result[key], source[key])\n } else {\n // @ts-expect-error\n result[key] = source[key]\n }\n })\n\n return result\n}\n\nexport interface ThemeOverrides {\n colors?: DeepPartial<Theme['colors']>\n typography?: TypographyOverrides\n}\n\nexport const overrideTheme = (overrides: ThemeOverrides) => {\n let typography = theme.typography\n let colors = theme.colors\n\n if (overrides.typography) {\n typography = overrideTypography(overrides.typography)\n }\n\n if (overrides.colors) {\n colors = deepMerge(theme.colors, overrides.colors)\n }\n\n return { ...theme, typography, colors }\n}\n","import { createContext, useContext } from 'react'\n\nimport type { LanguageCode } from './locales'\n\ninterface LocaleContextValue {\n currentLanguage: LanguageCode\n}\n\nconst LocaleContext = createContext<LocaleContextValue | undefined>(undefined)\n\ninterface LocaleProviderProps {\n language: LanguageCode\n children: React.ReactNode\n}\nexport function LocaleProvider({ language, children }: LocaleProviderProps) {\n return (\n <LocaleContext.Provider value={{ currentLanguage: language }}>\n {children}\n </LocaleContext.Provider>\n )\n}\n\nexport function useLocale() {\n const context = useContext(LocaleContext)\n if (!context) {\n throw new Error('useLocale must be used within a LocaleProvider')\n }\n\n return context\n}\n","import * as ToastPrimitive from '@radix-ui/react-toast'\nimport { useSyncExternalStore } from 'react'\nimport type { ReactNode } from 'react'\nimport styled from '@emotion/styled'\nimport { AnimatePresence } from 'motion/react'\n\nimport { toastStore } from './toast-store'\nimport { Toast } from './toast'\n\n/**\n * We style a separate div as a child for Radix Viewport in order to meet the QDS accessibility requirements\n * Radix uses <ol> and <li> elements for Toast elements in combination with role=\"status\", which is not allowed according to a11y standards\n * @see https://github.com/radix-ui/primitives/issues/1750\n */\nconst Viewport = styled.div(({ theme }) => ({\n position: 'fixed',\n bottom: theme.spacing['12x'],\n left: '50%',\n transform: 'translateX(-50%)',\n zIndex: theme.zIndices.toast,\n display: 'flex',\n flexDirection: 'column',\n gap: theme.spacing['2x'],\n width: `calc(100vw - ${theme.spacing['8x']})`,\n [theme.mediaQueries.smUp]: {\n width: theme.sizes[320],\n },\n}))\n\nexport function ToastProvider({ children }: { children: ReactNode }) {\n const toasts = useSyncExternalStore(\n toastStore.subscribe,\n toastStore.getSnapshot,\n toastStore.getSnapshot,\n )\n\n return (\n <ToastPrimitive.Provider>\n {children}\n <AnimatePresence>\n {toasts.map(({ id, text, variant }) => (\n <Toast\n key={id}\n text={text}\n variant={variant}\n onOpenChange={(isOpen) => {\n if (!isOpen) {\n toastStore.remove(id)\n }\n }}\n />\n ))}\n </AnimatePresence>\n <ToastPrimitive.Viewport asChild>\n <Viewport />\n </ToastPrimitive.Viewport>\n </ToastPrimitive.Provider>\n )\n}\n","import { flushSync } from 'react-dom'\n\nimport type { ToastVariant } from './toast-styles'\n\ntype Id = number | string\ninterface Toast {\n id: Id\n /**\n * The text for the toast\n */\n text: string\n /**\n * Sets the style variant of the toast, currently supports 'neutral' and 'negative'\n * @default 'neutral'\n */\n variant?: ToastVariant\n}\ninterface ToastOptions {\n /**\n * Unique identifier for the toast (can be used for removing it prematurely). If a toast with this\n * identifier already exists it will be removed before the new toast is added.\n * @default a random unique id will be set and returned\n */\n id?: Id\n}\n\ntype Subscriber = () => void\nclass ToastStore {\n toasts: Toast[]\n subscribers: Subscriber[]\n id: number\n\n constructor() {\n this.subscribers = []\n this.toasts = []\n this.id = 0\n }\n\n subscribe = (subscriber: Subscriber) => {\n this.subscribers.push(subscriber)\n\n return () => {\n const index = this.subscribers.indexOf(subscriber)\n this.subscribers.splice(index, 1)\n }\n }\n\n notify = () => {\n this.subscribers.forEach((subscriber) => subscriber())\n }\n\n add = (toast: Omit<Toast, 'id'> & ToastOptions) => {\n /*\n * Update to use the window.crypto.randomUUIC() method here after some time when we are sure that all the relevant browsers support it.\n */\n this.id = this.id + 1\n const id = toast.id ?? this.id\n if (toast.id) {\n // NOTE: if the toast.id is set we remove any toast with the same identifier\n this.toasts = this.toasts.filter((toast) => toast.id !== id)\n // we use flushSync to prevent batched state updates which would cause React to update the old\n // toast instead of removing it and adding a new one\n flushSync(() => {\n this.notify()\n })\n }\n this.toasts = [...this.toasts, { ...toast, id }]\n this.notify()\n\n return id\n }\n\n addNeutral = (text: string, options?: ToastOptions) => {\n return this.add({ text, variant: 'neutral', ...options })\n }\n\n addError = (text: string, options?: ToastOptions) => {\n return this.add({ text, variant: 'error', ...options })\n }\n\n remove = (id: Id) => {\n this.toasts = [...this.toasts.filter((toast) => toast.id !== id)]\n this.notify()\n }\n\n removeAll = () => {\n this.toasts = []\n this.notify()\n }\n\n getSnapshot = () => {\n return this.toasts\n }\n}\n\nexport const toastStore = new ToastStore()\n\nexport const toast = Object.assign(toastStore.addNeutral, {\n error: toastStore.addError,\n remove: toastStore.remove,\n removeAll: toastStore.removeAll,\n})\n","import * as ToastPrimitive from '@radix-ui/react-toast'\nimport styled from '@emotion/styled'\nimport { motion } from 'motion/react'\n\nimport type { HTMLQdsProps } from '../../types'\nimport { AlertCircleIcon } from '../icon'\n\nimport { getVariantStyles } from './toast-styles'\nimport type { ToastVariant } from './toast-styles'\n\n/**\n * We style a separate div as a child for Radix Toast.Root in order to meet the QDS accessibility requirements & animate it\n * Radix uses <ol> and <li> elements for Toast elements in combination with role=\"status\", which is not allowed according to a11y standards\n * @see https://github.com/radix-ui/primitives/issues/1750\n */\nconst Wrapper = styled(motion.div)<{ variant: ToastVariant }>(({ theme, variant }) => ({\n borderRadius: theme.radii.md,\n paddingInline: theme.spacing['4x'],\n paddingBlock: theme.spacing['3x'],\n display: 'flex',\n flexDirection: 'row',\n gap: theme.spacing['3x'],\n boxShadow: theme.shadows.lg,\n ...getVariantStyles(theme)[variant],\n}))\n\nconst Title = styled(ToastPrimitive.Title)(({ theme }) => ({\n ...theme.typography.label.md,\n}))\n\nconst IconWrapper = styled.div({\n marginTop: 1,\n flexShrink: 0,\n})\n\nconst ICON_MAP = {\n neutral: undefined,\n error: AlertCircleIcon,\n}\n\ninterface ToastOptions {\n text: string\n variant?: ToastVariant\n}\n\ntype OmittedProps = 'children'\ninterface ToastProps extends Omit<HTMLQdsProps<'div'>, OmittedProps>, ToastOptions {}\n\nexport function Toast(props: ToastProps & ToastPrimitive.ToastProps) {\n const { text, variant = 'neutral', ...rest } = props\n\n const Icon = ICON_MAP[variant]\n\n return (\n <ToastPrimitive.Root asChild forceMount {...rest}>\n <Wrapper\n variant={variant}\n layout\n initial={{ opacity: 0, y: 20 }}\n animate={{ opacity: 1, y: 0 }}\n exit={{ opacity: 0 }}\n transition={{ y: { type: 'spring', bounce: 0.1 } }}\n >\n {Icon && (\n <IconWrapper>\n <Icon size={16} color=\"onBrandSecondary\" />\n </IconWrapper>\n )}\n <Title>{text}</Title>\n </Wrapper>\n </ToastPrimitive.Root>\n )\n}\n","/**\n * This function is heavily inspired by the `createIcon` function from\n * Chakra UI (https://chakra-ui.com/).\n */\n\nimport styled from '@emotion/styled'\nimport { Children, forwardRef } from 'react'\n\nimport type { IconOptions, IconProps } from './icon.types'\n\nconst StyledSvg = styled.svg<IconOptions>(({ theme, color = 'default' }) => ({\n color: color === 'currentColor' ? 'currentcolor' : theme.colors.icon[color],\n display: 'inline-block',\n lineHeight: '1em',\n}))\n\nexport interface CreateIconOptions {\n /**\n * The `svg`'s `viewBox` attribute\n */\n viewBox: string\n /**\n * If the `svg` has a single path, simply copy the path's `d` attribute\n */\n d?: string\n /**\n * The `svg` path or group element\n *\n * @example\n * ```jsx\n * createIcon({\n * viewBox: '0 0 512 512',\n * path: [\n * <circle cx=\"50\" cy=\"50\" r=\"50\" />,\n * <path d=\"M10 10\" />,\n * ],\n * displayName: 'ExampleIcon',\n * })\n * ```\n */\n path?: React.ReactElement | React.ReactElement[]\n /**\n * The display name of the icon. Useful for debugging\n * and internal use.\n */\n displayName?: string\n}\n\n/**\n * Helper function to create an icon component.\n */\nexport const createIcon = (options: CreateIconOptions) => {\n const { viewBox, d: pathDefinition, displayName = 'UnnamedIcon' } = options\n const path = Children.toArray(options.path)\n\n const Component = forwardRef<SVGSVGElement, IconProps>((props, forwardedRef) => {\n const { size = 24, ...rest } = props\n return (\n <StyledSvg\n ref={forwardedRef}\n xmlns=\"http://www.w3.org/2000/svg\"\n width={size}\n height={size}\n focusable=\"false\"\n viewBox={viewBox}\n fill=\"currentColor\"\n {...rest}\n >\n {path.length ? path : <path fill=\"currentColor\" d={pathDefinition} />}\n </StyledSvg>\n )\n })\n\n Component.displayName = displayName\n\n return Component\n}\n","import { useTheme } from '@emotion/react'\nimport type { LucideIcon } from 'lucide-react'\nimport { forwardRef } from 'react'\n\nimport type { IconProps } from './icon.types'\n\nexport const createLucideIcon = (Icon: LucideIcon) => {\n const Component = forwardRef<SVGSVGElement, IconProps>(\n ({ size = 24, color = 'default', ...props }, ref) => {\n const theme = useTheme()\n const resolvedColor = color === 'currentColor' ? 'currentcolor' : theme.colors.icon[color]\n\n return (\n <Icon\n ref={ref}\n size={size}\n strokeWidth={2}\n // Always keep a minimum stroke width of 2px\n absoluteStrokeWidth={size < 24}\n color={resolvedColor}\n {...props}\n />\n )\n },\n )\n\n Component.displayName = Icon.displayName\n\n return Component\n}\n","import { CamelToPascal } from './utility-types';\n\n/**\n * Converts string to kebab case\n *\n * @param {string} string\n * @returns {string} A kebabized string\n */\nexport const toKebabCase = (string: string) =>\n string.replace(/([a-z0-9])([A-Z])/g, '$1-$2').toLowerCase();\n\n/**\n * Converts string to camel case\n *\n * @param {string} string\n * @returns {string} A camelized string\n */\nexport const toCamelCase = <T extends string>(string: T) =>\n string.replace(/^([A-Z])|[\\s-_]+(\\w)/g, (match, p1, p2) =>\n p2 ? p2.toUpperCase() : p1.toLowerCase(),\n );\n\n/**\n * Converts string to pascal case\n *\n * @param {string} string\n * @returns {string} A pascalized string\n */\nexport const toPascalCase = <T extends string>(string: T): CamelToPascal<T> => {\n const camelCase = toCamelCase(string);\n\n return (camelCase.charAt(0).toUpperCase() + camelCase.slice(1)) as CamelToPascal<T>;\n};\n\n/**\n * Merges classes into a single string\n *\n * @param {array} classes\n * @returns {string} A string of classes\n */\nexport const mergeClasses = <ClassType = string | undefined | null>(...classes: ClassType[]) =>\n classes\n .filter((className, index, array) => {\n return (\n Boolean(className) &&\n (className as string).trim() !== '' &&\n array.indexOf(className) === index\n );\n })\n .join(' ')\n .trim();\n","export default {\n xmlns: 'http://www.w3.org/2000/svg',\n width: 24,\n height: 24,\n viewBox: '0 0 24 24',\n fill: 'none',\n stroke: 'currentColor',\n strokeWidth: 2,\n strokeLinecap: 'round',\n strokeLinejoin: 'round',\n};\n","import { createElement, forwardRef } from 'react';\nimport defaultAttributes from './defaultAttributes';\nimport { IconNode, LucideProps } from './types';\nimport { mergeClasses } from '@lucide/shared';\n\ninterface IconComponentProps extends LucideProps {\n iconNode: IconNode;\n}\n\n/**\n * Lucide icon component\n *\n * @component Icon\n * @param {object} props\n * @param {string} props.color - The color of the icon\n * @param {number} props.size - The size of the icon\n * @param {number} props.strokeWidth - The stroke width of the icon\n * @param {boolean} props.absoluteStrokeWidth - Whether to use absolute stroke width\n * @param {string} props.className - The class name of the icon\n * @param {IconNode} props.children - The children of the icon\n * @param {IconNode} props.iconNode - The icon node of the icon\n *\n * @returns {ForwardRefExoticComponent} LucideIcon\n */\nconst Icon = forwardRef<SVGSVGElement, IconComponentProps>(\n (\n {\n color = 'currentColor',\n size = 24,\n strokeWidth = 2,\n absoluteStrokeWidth,\n className = '',\n children,\n iconNode,\n ...rest\n },\n ref,\n ) => {\n return createElement(\n 'svg',\n {\n ref,\n ...defaultAttributes,\n width: size,\n height: size,\n stroke: color,\n strokeWidth: absoluteStrokeWidth ? (Number(strokeWidth) * 24) / Number(size) : strokeWidth,\n className: mergeClasses('lucide', className),\n ...rest,\n },\n [\n ...iconNode.map(([tag, attrs]) => createElement(tag, attrs)),\n ...(Array.isArray(children) ? children : [children]),\n ],\n );\n },\n);\n\nexport default Icon;\n","import { createElement, forwardRef } from 'react';\nimport { mergeClasses, toKebabCase } from '@lucide/shared';\nimport { IconNode, LucideProps } from './types';\nimport Icon from './Icon';\n\n/**\n * Create a Lucide icon component\n * @param {string} iconName\n * @param {array} iconNode\n * @returns {ForwardRefExoticComponent} LucideIcon\n */\nconst createLucideIcon = (iconName: string, iconNode: IconNode) => {\n const Component = forwardRef<SVGSVGElement, LucideProps>(({ className, ...props }, ref) =>\n createElement(Icon, {\n ref,\n iconNode,\n className: mergeClasses(`lucide-${toKebabCase(iconName)}`, className),\n ...props,\n }),\n );\n\n Component.displayName = `${iconName}`;\n\n return Component;\n};\n\nexport default createLucideIcon;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'M12 5v14', key: 's699le' }],\n ['path', { d: 'm19 12-7 7-7-7', key: '1idqje' }],\n];\n\n/**\n * @component @name ArrowDown\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/arrow-down\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst ArrowDown = createLucideIcon('ArrowDown', __iconNode);\n\nexport default ArrowDown;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'm12 19-7-7 7-7', key: '1l729n' }],\n ['path', { d: 'M19 12H5', key: 'x3x0zl' }],\n];\n\n/**\n * @component @name ArrowLeft\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/arrow-left\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst ArrowLeft = createLucideIcon('ArrowLeft', __iconNode);\n\nexport default ArrowLeft;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'M5 12h14', key: '1ays0h' }],\n ['path', { d: 'm12 5 7 7-7 7', key: 'xquz4c' }],\n];\n\n/**\n * @component @name ArrowRight\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/arrow-right\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst ArrowRight = createLucideIcon('ArrowRight', __iconNode);\n\nexport default ArrowRight;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'm5 12 7-7 7 7', key: 'hav0vg' }],\n ['path', { d: 'M12 19V5', key: 'x0mq9r' }],\n];\n\n/**\n * @component @name ArrowUp\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/arrow-up\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst ArrowUp = createLucideIcon('ArrowUp', __iconNode);\n\nexport default ArrowUp;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'M10.268 21a2 2 0 0 0 3.464 0', key: 'vwvbt9' }],\n [\n 'path',\n {\n d: 'M17 17H4a1 1 0 0 1-.74-1.673C4.59 13.956 6 12.499 6 8a6 6 0 0 1 .258-1.742',\n key: '178tsu',\n },\n ],\n ['path', { d: 'm2 2 20 20', key: '1ooewy' }],\n ['path', { d: 'M8.668 3.01A6 6 0 0 1 18 8c0 2.687.77 4.653 1.707 6.05', key: '1hqiys' }],\n];\n\n/**\n * @component @name BellOff\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/bell-off\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst BellOff = createLucideIcon('BellOff', __iconNode);\n\nexport default BellOff;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'M10.268 21a2 2 0 0 0 3.464 0', key: 'vwvbt9' }],\n [\n 'path',\n {\n d: 'M3.262 15.326A1 1 0 0 0 4 17h16a1 1 0 0 0 .74-1.673C19.41 13.956 18 12.499 18 8A6 6 0 0 0 6 8c0 4.499-1.411 5.956-2.738 7.326',\n key: '11g9vi',\n },\n ],\n];\n\n/**\n * @component @name Bell\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/bell\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Bell = createLucideIcon('Bell', __iconNode);\n\nexport default Bell;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'm19 21-7-4-7 4V5a2 2 0 0 1 2-2h10a2 2 0 0 1 2 2v16z', key: '1fy3hk' }],\n];\n\n/**\n * @component @name Bookmark\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/bookmark\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Bookmark = createLucideIcon('Bookmark', __iconNode);\n\nexport default Bookmark;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'M8 2v4', key: '1cmpym' }],\n ['path', { d: 'M16 2v4', key: '4m81vk' }],\n ['rect', { width: '18', height: '18', x: '3', y: '4', rx: '2', key: '1hopcy' }],\n ['path', { d: 'M3 10h18', key: '8toen8' }],\n];\n\n/**\n * @component @name Calendar\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/calendar\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Calendar = createLucideIcon('Calendar', __iconNode);\n\nexport default Calendar;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n [\n 'path',\n {\n d: 'M14.5 4h-5L7 7H4a2 2 0 0 0-2 2v9a2 2 0 0 0 2 2h16a2 2 0 0 0 2-2V9a2 2 0 0 0-2-2h-3l-2.5-3z',\n key: '1tc9qg',\n },\n ],\n ['circle', { cx: '12', cy: '13', r: '3', key: '1vg3eu' }],\n];\n\n/**\n * @component @name Camera\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/camera\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Camera = createLucideIcon('Camera', __iconNode);\n\nexport default Camera;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [['path', { d: 'M20 6 9 17l-5-5', key: '1gmf2c' }]];\n\n/**\n * @component @name Check\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/check\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Check = createLucideIcon('Check', __iconNode);\n\nexport default Check;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [['path', { d: 'm6 9 6 6 6-6', key: 'qrunsl' }]];\n\n/**\n * @component @name ChevronDown\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/chevron-down\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst ChevronDown = createLucideIcon('ChevronDown', __iconNode);\n\nexport default ChevronDown;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [['path', { d: 'm15 18-6-6 6-6', key: '1wnfg3' }]];\n\n/**\n * @component @name ChevronLeft\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/chevron-left\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst ChevronLeft = createLucideIcon('ChevronLeft', __iconNode);\n\nexport default ChevronLeft;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [['path', { d: 'm9 18 6-6-6-6', key: 'mthhwq' }]];\n\n/**\n * @component @name ChevronRight\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/chevron-right\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst ChevronRight = createLucideIcon('ChevronRight', __iconNode);\n\nexport default ChevronRight;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [['path', { d: 'm18 15-6-6-6 6', key: '153udz' }]];\n\n/**\n * @component @name ChevronUp\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/chevron-up\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst ChevronUp = createLucideIcon('ChevronUp', __iconNode);\n\nexport default ChevronUp;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['circle', { cx: '12', cy: '12', r: '10', key: '1mglay' }],\n ['line', { x1: '12', x2: '12', y1: '8', y2: '12', key: '1pkeuh' }],\n ['line', { x1: '12', x2: '12.01', y1: '16', y2: '16', key: '4dfq90' }],\n];\n\n/**\n * @component @name CircleAlert\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/circle-alert\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst CircleAlert = createLucideIcon('CircleAlert', __iconNode);\n\nexport default CircleAlert;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['circle', { cx: '12', cy: '12', r: '10', key: '1mglay' }],\n ['path', { d: 'm9 12 2 2 4-4', key: 'dzmm74' }],\n];\n\n/**\n * @component @name CircleCheck\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/circle-check\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst CircleCheck = createLucideIcon('CircleCheck', __iconNode);\n\nexport default CircleCheck;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['circle', { cx: '12', cy: '12', r: '10', key: '1mglay' }],\n ['path', { d: 'M9.09 9a3 3 0 0 1 5.83 1c0 2-3 3-3 3', key: '1u773s' }],\n ['path', { d: 'M12 17h.01', key: 'p32p05' }],\n];\n\n/**\n * @component @name CircleHelp\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/circle-help\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst CircleHelp = createLucideIcon('CircleHelp', __iconNode);\n\nexport default CircleHelp;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['circle', { cx: '12', cy: '12', r: '10', key: '1mglay' }],\n ['path', { d: 'm15 9-6 6', key: '1uzhvr' }],\n ['path', { d: 'm9 9 6 6', key: 'z0biqf' }],\n];\n\n/**\n * @component @name CircleX\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/circle-x\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst CircleX = createLucideIcon('CircleX', __iconNode);\n\nexport default CircleX;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['circle', { cx: '12', cy: '12', r: '1', key: '41hilf' }],\n ['circle', { cx: '12', cy: '5', r: '1', key: 'gxeob9' }],\n ['circle', { cx: '12', cy: '19', r: '1', key: 'lyex9k' }],\n];\n\n/**\n * @component @name EllipsisVertical\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/ellipsis-vertical\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst EllipsisVertical = createLucideIcon('EllipsisVertical', __iconNode);\n\nexport default EllipsisVertical;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['circle', { cx: '12', cy: '12', r: '1', key: '41hilf' }],\n ['circle', { cx: '19', cy: '12', r: '1', key: '1wjl8i' }],\n ['circle', { cx: '5', cy: '12', r: '1', key: '1pcz8c' }],\n];\n\n/**\n * @component @name Ellipsis\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/ellipsis\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Ellipsis = createLucideIcon('Ellipsis', __iconNode);\n\nexport default Ellipsis;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['circle', { cx: '12', cy: '12', r: '10', key: '1mglay' }],\n ['path', { d: 'M12 2a14.5 14.5 0 0 0 0 20 14.5 14.5 0 0 0 0-20', key: '13o1zl' }],\n ['path', { d: 'M2 12h20', key: '9i4pu4' }],\n];\n\n/**\n * @component @name Globe\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/globe\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Globe = createLucideIcon('Globe', __iconNode);\n\nexport default Globe;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n [\n 'path',\n {\n d: 'M19 14c1.49-1.46 3-3.21 3-5.5A5.5 5.5 0 0 0 16.5 3c-1.76 0-3 .5-4.5 2-1.5-1.5-2.74-2-4.5-2A5.5 5.5 0 0 0 2 8.5c0 2.3 1.5 4.05 3 5.5l7 7Z',\n key: 'c3ymky',\n },\n ],\n];\n\n/**\n * @component @name Heart\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/heart\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Heart = createLucideIcon('Heart', __iconNode);\n\nexport default Heart;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'M3 12a9 9 0 1 0 9-9 9.75 9.75 0 0 0-6.74 2.74L3 8', key: '1357e3' }],\n ['path', { d: 'M3 3v5h5', key: '1xhq8a' }],\n ['path', { d: 'M12 7v5l4 2', key: '1fdv2h' }],\n];\n\n/**\n * @component @name History\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/history\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst History = createLucideIcon('History', __iconNode);\n\nexport default History;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'M15 21v-8a1 1 0 0 0-1-1h-4a1 1 0 0 0-1 1v8', key: '5wwlr5' }],\n [\n 'path',\n {\n d: 'M3 10a2 2 0 0 1 .709-1.528l7-5.999a2 2 0 0 1 2.582 0l7 5.999A2 2 0 0 1 21 10v9a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2z',\n key: '1d0kgt',\n },\n ],\n];\n\n/**\n * @component @name House\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/house\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst House = createLucideIcon('House', __iconNode);\n\nexport default House;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['rect', { width: '18', height: '18', x: '3', y: '3', rx: '2', ry: '2', key: '1m3agn' }],\n ['circle', { cx: '9', cy: '9', r: '2', key: 'af1f0g' }],\n ['path', { d: 'm21 15-3.086-3.086a2 2 0 0 0-2.828 0L6 21', key: '1xmnt7' }],\n];\n\n/**\n * @component @name Image\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/image\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Image = createLucideIcon('Image', __iconNode);\n\nexport default Image;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['circle', { cx: '12', cy: '12', r: '10', key: '1mglay' }],\n ['path', { d: 'M12 16v-4', key: '1dtifu' }],\n ['path', { d: 'M12 8h.01', key: 'e9boi3' }],\n];\n\n/**\n * @component @name Info\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/info\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Info = createLucideIcon('Info', __iconNode);\n\nexport default Info;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'M3 6h18', key: 'd0wm0j' }],\n ['path', { d: 'M7 12h10', key: 'b7w52i' }],\n ['path', { d: 'M10 18h4', key: '1ulq68' }],\n];\n\n/**\n * @component @name ListFilter\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/list-filter\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst ListFilter = createLucideIcon('ListFilter', __iconNode);\n\nexport default ListFilter;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'M3 12h.01', key: 'nlz23k' }],\n ['path', { d: 'M3 18h.01', key: '1tta3j' }],\n ['path', { d: 'M3 6h.01', key: '1rqtza' }],\n ['path', { d: 'M8 12h13', key: '1za7za' }],\n ['path', { d: 'M8 18h13', key: '1lx6n3' }],\n ['path', { d: 'M8 6h13', key: 'ik3vkj' }],\n];\n\n/**\n * @component @name List\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/list\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst List = createLucideIcon('List', __iconNode);\n\nexport default List;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'M9 21H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h4', key: '1uf3rs' }],\n ['polyline', { points: '16 17 21 12 16 7', key: '1gabdz' }],\n ['line', { x1: '21', x2: '9', y1: '12', y2: '12', key: '1uyos4' }],\n];\n\n/**\n * @component @name LogOut\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/log-out\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst LogOut = createLucideIcon('LogOut', __iconNode);\n\nexport default LogOut;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n [\n 'path',\n {\n d: 'M20 10c0 4.993-5.539 10.193-7.399 11.799a1 1 0 0 1-1.202 0C9.539 20.193 4 14.993 4 10a8 8 0 0 1 16 0',\n key: '1r0f0z',\n },\n ],\n ['circle', { cx: '12', cy: '10', r: '3', key: 'ilqhr7' }],\n];\n\n/**\n * @component @name MapPin\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/map-pin\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst MapPin = createLucideIcon('MapPin', __iconNode);\n\nexport default MapPin;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n [\n 'path',\n {\n d: 'M14.106 5.553a2 2 0 0 0 1.788 0l3.659-1.83A1 1 0 0 1 21 4.619v12.764a1 1 0 0 1-.553.894l-4.553 2.277a2 2 0 0 1-1.788 0l-4.212-2.106a2 2 0 0 0-1.788 0l-3.659 1.83A1 1 0 0 1 3 19.381V6.618a1 1 0 0 1 .553-.894l4.553-2.277a2 2 0 0 1 1.788 0z',\n key: '169xi5',\n },\n ],\n ['path', { d: 'M15 5.764v15', key: '1pn4in' }],\n ['path', { d: 'M9 3.236v15', key: '1uimfh' }],\n];\n\n/**\n * @component @name Map\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/map\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Map = createLucideIcon('Map', __iconNode);\n\nexport default Map;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['line', { x1: '4', x2: '20', y1: '12', y2: '12', key: '1e0a9i' }],\n ['line', { x1: '4', x2: '20', y1: '6', y2: '6', key: '1owob3' }],\n ['line', { x1: '4', x2: '20', y1: '18', y2: '18', key: 'yk5zj1' }],\n];\n\n/**\n * @component @name Menu\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/menu\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Menu = createLucideIcon('Menu', __iconNode);\n\nexport default Menu;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'M7.9 20A9 9 0 1 0 4 16.1L2 22Z', key: 'vv11sd' }],\n];\n\n/**\n * @component @name MessageCircle\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/message-circle\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst MessageCircle = createLucideIcon('MessageCircle', __iconNode);\n\nexport default MessageCircle;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [['path', { d: 'M5 12h14', key: '1ays0h' }]];\n\n/**\n * @component @name Minus\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/minus\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Minus = createLucideIcon('Minus', __iconNode);\n\nexport default Minus;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n [\n 'path',\n {\n d: 'M21.174 6.812a1 1 0 0 0-3.986-3.987L3.842 16.174a2 2 0 0 0-.5.83l-1.321 4.352a.5.5 0 0 0 .623.622l4.353-1.32a2 2 0 0 0 .83-.497z',\n key: '1a8usu',\n },\n ],\n];\n\n/**\n * @component @name Pen\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/pen\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Pen = createLucideIcon('Pen', __iconNode);\n\nexport default Pen;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'M5 12h14', key: '1ays0h' }],\n ['path', { d: 'M12 5v14', key: 's699le' }],\n];\n\n/**\n * @component @name Plus\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/plus\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Plus = createLucideIcon('Plus', __iconNode);\n\nexport default Plus;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['circle', { cx: '11', cy: '11', r: '8', key: '4ej97u' }],\n ['path', { d: 'm21 21-4.3-4.3', key: '1qie3q' }],\n];\n\n/**\n * @component @name Search\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/search\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Search = createLucideIcon('Search', __iconNode);\n\nexport default Search;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'M20 7h-9', key: '3s1dr2' }],\n ['path', { d: 'M14 17H5', key: 'gfn3mx' }],\n ['circle', { cx: '17', cy: '17', r: '3', key: '18b49y' }],\n ['circle', { cx: '7', cy: '7', r: '3', key: 'dfmy0x' }],\n];\n\n/**\n * @component @name Settings2\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/settings-2\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Settings2 = createLucideIcon('Settings2', __iconNode);\n\nexport default Settings2;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n [\n 'path',\n {\n d: 'M12.22 2h-.44a2 2 0 0 0-2 2v.18a2 2 0 0 1-1 1.73l-.43.25a2 2 0 0 1-2 0l-.15-.08a2 2 0 0 0-2.73.73l-.22.38a2 2 0 0 0 .73 2.73l.15.1a2 2 0 0 1 1 1.72v.51a2 2 0 0 1-1 1.74l-.15.09a2 2 0 0 0-.73 2.73l.22.38a2 2 0 0 0 2.73.73l.15-.08a2 2 0 0 1 2 0l.43.25a2 2 0 0 1 1 1.73V20a2 2 0 0 0 2 2h.44a2 2 0 0 0 2-2v-.18a2 2 0 0 1 1-1.73l.43-.25a2 2 0 0 1 2 0l.15.08a2 2 0 0 0 2.73-.73l.22-.39a2 2 0 0 0-.73-2.73l-.15-.08a2 2 0 0 1-1-1.74v-.5a2 2 0 0 1 1-1.74l.15-.09a2 2 0 0 0 .73-2.73l-.22-.38a2 2 0 0 0-2.73-.73l-.15.08a2 2 0 0 1-2 0l-.43-.25a2 2 0 0 1-1-1.73V4a2 2 0 0 0-2-2z',\n key: '1qme2f',\n },\n ],\n ['circle', { cx: '12', cy: '12', r: '3', key: '1v7zrd' }],\n];\n\n/**\n * @component @name Settings\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/settings\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Settings = createLucideIcon('Settings', __iconNode);\n\nexport default Settings;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'M4 12v8a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2v-8', key: '1b2hhj' }],\n ['polyline', { points: '16 6 12 2 8 6', key: 'm901s6' }],\n ['line', { x1: '12', x2: '12', y1: '2', y2: '15', key: '1p0rca' }],\n];\n\n/**\n * @component @name Share\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/share\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Share = createLucideIcon('Share', __iconNode);\n\nexport default Share;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n [\n 'path',\n {\n d: 'M11.525 2.295a.53.53 0 0 1 .95 0l2.31 4.679a2.123 2.123 0 0 0 1.595 1.16l5.166.756a.53.53 0 0 1 .294.904l-3.736 3.638a2.123 2.123 0 0 0-.611 1.878l.882 5.14a.53.53 0 0 1-.771.56l-4.618-2.428a2.122 2.122 0 0 0-1.973 0L6.396 21.01a.53.53 0 0 1-.77-.56l.881-5.139a2.122 2.122 0 0 0-.611-1.879L2.16 9.795a.53.53 0 0 1 .294-.906l5.165-.755a2.122 2.122 0 0 0 1.597-1.16z',\n key: 'r04s7s',\n },\n ],\n];\n\n/**\n * @component @name Star\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/star\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Star = createLucideIcon('Star', __iconNode);\n\nexport default Star;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'M3 6h18', key: 'd0wm0j' }],\n ['path', { d: 'M19 6v14c0 1-1 2-2 2H7c-1 0-2-1-2-2V6', key: '4alrt4' }],\n ['path', { d: 'M8 6V4c0-1 1-2 2-2h4c1 0 2 1 2 2v2', key: 'v07s0e' }],\n ['line', { x1: '10', x2: '10', y1: '11', y2: '17', key: '1uufr5' }],\n ['line', { x1: '14', x2: '14', y1: '11', y2: '17', key: 'xtxkd' }],\n];\n\n/**\n * @component @name Trash2\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/trash-2\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst Trash2 = createLucideIcon('Trash2', __iconNode);\n\nexport default Trash2;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n [\n 'path',\n {\n d: 'm21.73 18-8-14a2 2 0 0 0-3.48 0l-8 14A2 2 0 0 0 4 21h16a2 2 0 0 0 1.73-3',\n key: 'wmoenq',\n },\n ],\n ['path', { d: 'M12 9v4', key: 'juzpu7' }],\n ['path', { d: 'M12 17h.01', key: 'p32p05' }],\n];\n\n/**\n * @component @name TriangleAlert\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/triangle-alert\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst TriangleAlert = createLucideIcon('TriangleAlert', __iconNode);\n\nexport default TriangleAlert;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['circle', { cx: '12', cy: '8', r: '5', key: '1hypcn' }],\n ['path', { d: 'M20 21a8 8 0 0 0-16 0', key: 'rfgkzh' }],\n];\n\n/**\n * @component @name UserRound\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/user-round\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst UserRound = createLucideIcon('UserRound', __iconNode);\n\nexport default UserRound;\n","import createLucideIcon from '../createLucideIcon';\nimport { IconNode } from '../types';\n\nexport const __iconNode: IconNode = [\n ['path', { d: 'M18 6 6 18', key: '1bl5f8' }],\n ['path', { d: 'm6 6 12 12', key: 'd8bk6v' }],\n];\n\n/**\n * @component @name X\n * @description Lucide SVG icon component, renders SVG Element with children.\n *\n * @preview ![img]() - https://lucide.dev/icons/x\n * @see https://lucide.dev/guide/packages/lucide-react - Documentation\n *\n * @param {Object} props - Lucide icons props and any valid SVG attribute\n * @returns {JSX.Element} JSX Element\n *\n */\nconst X = createLucideIcon('X', __iconNode);\n\nexport default X;\n","import {\n AlertCircle,\n AlertTriangle,\n ArrowDown,\n ArrowLeft,\n ArrowRight,\n ArrowUp,\n Bell,\n BellOff,\n Bookmark,\n Calendar,\n Camera,\n Check,\n CheckCircle2,\n ChevronDown,\n ChevronLeft,\n ChevronRight,\n ChevronUp,\n Globe,\n Heart,\n HelpCircle,\n History,\n Home,\n Image,\n Info,\n List,\n ListFilter,\n LogOut,\n Map,\n MapPin,\n Menu,\n MessageCircle,\n Minus,\n MoreHorizontal,\n MoreVertical,\n Pen,\n Plus,\n Search,\n Settings,\n Settings2,\n Share,\n Star,\n Trash2,\n UserRound,\n X,\n XCircle,\n} from 'lucide-react'\n\nimport { createIcon } from './create-icon'\nimport { createLucideIcon } from './create-lucide-icon'\n\nexport const AlertCircleIcon = createLucideIcon(AlertCircle)\nexport const AlertTriangleIcon = createLucideIcon(AlertTriangle)\nexport const ArrowDownIcon = createLucideIcon(ArrowDown)\nexport const ArrowLeftIcon = createLucideIcon(ArrowLeft)\nexport const ArrowRightIcon = createLucideIcon(ArrowRight)\nexport const ArrowUpIcon = createLucideIcon(ArrowUp)\nexport const BellIcon = createLucideIcon(Bell)\nexport const BellOffIcon = createLucideIcon(BellOff)\nexport const BookmarkIcon = createLucideIcon(Bookmark)\nexport const CalendarIcon = createLucideIcon(Calendar)\nexport const CameraIcon = createLucideIcon(Camera)\nexport const CheckCircleIcon = createLucideIcon(CheckCircle2)\nexport const CheckIcon = createLucideIcon(Check)\nexport const ChevronDownIcon = createLucideIcon(ChevronDown)\nexport const ChevronLeftIcon = createLucideIcon(ChevronLeft)\nexport const ChevronRightIcon = createLucideIcon(ChevronRight)\nexport const ChevronUpIcon = createLucideIcon(ChevronUp)\nexport const GlobeIcon = createLucideIcon(Globe)\n/* Custom icon based on Lucide's heart icon. */\nexport const HeartFilledIcon = createIcon({\n viewBox: '0 0 24 24',\n d: 'M2.90381 3.90381C4.12279 2.68482 5.77609 2 7.5 2C8.48018 2 9.37318 2.14018 10.2468 2.52068C10.8597 2.78762 11.4321 3.15937 12 3.63935C12.5679 3.15937 13.1403 2.78762 13.7532 2.52068C14.6268 2.14018 15.5198 2 16.5 2C18.2239 2 19.8772 2.68482 21.0962 3.90381C22.3152 5.12279 23 6.77609 23 8.5C23 11.2418 21.1906 13.2531 19.7035 14.7107L12.7071 21.7071C12.3166 22.0976 11.6834 22.0976 11.2929 21.7071L4.29885 14.7131C2.79442 13.258 1 11.2494 1 8.5C1 6.77609 1.68482 5.12279 2.90381 3.90381Z',\n displayName: 'HeartFilledIcon',\n})\nexport const HeartIcon = createLucideIcon(Heart)\nexport const HelpCircleIcon = createLucideIcon(HelpCircle)\nexport const HistoryIcon = createLucideIcon(History)\nexport const HomeIcon = createLucideIcon(Home)\nexport const ImageIcon = createLucideIcon(Image)\nexport const InfoIcon = createLucideIcon(Info)\nexport const ListIcon = createLucideIcon(List)\nexport const ListFilterIcon = createLucideIcon(ListFilter)\nexport const LogOutIcon = createLucideIcon(LogOut)\nexport const MapIcon = createLucideIcon(Map)\nexport const MapPinIcon = createLucideIcon(MapPin)\nexport const MenuIcon = createLucideIcon(Menu)\nexport const MessageCircleIcon = createLucideIcon(MessageCircle)\nexport const MinusIcon = createLucideIcon(Minus)\nexport const MoreHorizontalIcon = createLucideIcon(MoreHorizontal)\nexport const MoreVerticalIcon = createLucideIcon(MoreVertical)\nexport const PenIcon = createLucideIcon(Pen)\nexport const PlusIcon = createLucideIcon(Plus)\nexport const SearchIcon = createLucideIcon(Search)\nexport const SettingsIcon = createLucideIcon(Settings)\nexport const ShareIcon = createLucideIcon(Share)\nexport const SlidersIcon = createLucideIcon(Settings2)\n/* Custom icon based on Lucide's star icon. */\nexport const StarFilledIcon = createIcon({\n viewBox: '0 0 24 24',\n d: 'M12 1C12.3806 1 12.7282 1.21607 12.8967 1.55738L15.7543 7.34647L22.1446 8.28051C22.5212 8.33555 22.8339 8.59956 22.9512 8.96157C23.0686 9.32358 22.9703 9.72083 22.6977 9.98636L18.0745 14.4894L19.1656 20.851C19.23 21.2261 19.0757 21.6053 18.7677 21.8291C18.4598 22.0528 18.0515 22.0823 17.7145 21.9051L12 18.8998L6.28545 21.9051C5.94853 22.0823 5.54024 22.0528 5.23226 21.8291C4.92429 21.6053 4.77004 21.2261 4.83439 20.851L5.92548 14.4894L1.30227 9.98636C1.02965 9.72083 0.931375 9.32358 1.04875 8.96157C1.16613 8.59956 1.47881 8.33555 1.85537 8.28051L8.24574 7.34647L11.1033 1.55738C11.2718 1.21607 11.6194 1 12 1Z',\n displayName: 'StarFilledIcon',\n})\n\nexport const StarIcon = createLucideIcon(Star)\nexport const TrashIcon = createLucideIcon(Trash2)\nexport const UserIcon = createLucideIcon(UserRound)\nexport const XCircleIcon = createLucideIcon(XCircle)\nexport const XIcon = createLucideIcon(X)\n","import { createStyleVariants } from '../../styles'\nimport type { VariantProps } from '../../styles'\n\nexport const getVariantStyles = createStyleVariants(({ colors }) => ({\n neutral: {\n background: colors.core.black,\n color: colors.core.white,\n },\n error: {\n background: colors.bg.negative,\n color: colors.core.white,\n },\n}))\nexport type ToastVariant = VariantProps<typeof getVariantStyles>\n","import styled from '@emotion/styled'\nimport isPropValid from '@emotion/is-prop-valid'\nimport { forwardRef } from 'react'\nimport { UserRound } from 'lucide-react'\nimport * as AvatarPrimitive from '@radix-ui/react-avatar'\n\nimport type { HTMLQdsProps } from '../../types'\nimport { toMediaQueries, type ResponsiveProp } from '../../styles/responsive'\n\nconst SIZE_MAP = {\n xs: 32,\n sm: 40,\n md: 48,\n lg: 64,\n xl: 96,\n '2xl': 128,\n}\n\ntype AvatarSize = keyof typeof SIZE_MAP\n\nconst ICON_SIZE_MAP = {\n xs: 14,\n sm: 16,\n md: 20,\n lg: 32,\n xl: 48,\n '2xl': 64,\n}\n\nconst TEXT_SIZE_MAP = {\n xs: 12,\n sm: 16,\n md: 20,\n lg: 28,\n xl: 40,\n '2xl': 56,\n}\n\nconst getInitials = (name: string) => {\n const names = name.trim().split(/\\s+/)\n\n const firstName = names[0]\n const lastName = names.length > 1 ? names[names.length - 1] : ''\n\n // `charAt(0)` returns empty string if name is empty\n return `${firstName.charAt(0)}${lastName.charAt(0)}`.toUpperCase()\n}\n\ninterface WrapperProps {\n size: ResponsiveProp<AvatarSize>\n}\nconst AvatarRoot = styled(AvatarPrimitive.Root)<WrapperProps>(({ theme, size }) => ({\n ...toMediaQueries(size, (currentValue) => ({\n width: SIZE_MAP[currentValue],\n height: SIZE_MAP[currentValue],\n })),\n flexShrink: 0,\n borderRadius: theme.radii.full,\n background: theme.colors.core.gray20,\n overflow: 'hidden',\n display: 'flex',\n justifyContent: 'center',\n alignItems: 'center',\n boxShadow: `0 0 0 1px ${theme.colors.core.blackAlpha5}`,\n color: theme.colors.text.subtle,\n}))\n\nconst AvatarImage = styled(AvatarPrimitive.Image)({\n width: '100%',\n height: '100%',\n objectFit: 'cover',\n})\n\nconst AvatarFallback = styled(AvatarPrimitive.Fallback)(({ theme }) => ({\n color: theme.colors.text.subtle,\n}))\n\ninterface FallbackTextProps {\n avatarSize: ResponsiveProp<AvatarSize>\n}\nconst FallbackText = styled.span<FallbackTextProps>(({ avatarSize }) => ({\n fontWeight: 'bold',\n ...toMediaQueries(avatarSize, (currentValue) => ({\n fontSize: TEXT_SIZE_MAP[currentValue],\n })),\n // To optically align the text in the center\n paddingTop: '0.08em',\n display: 'block',\n // User should never need to select this text\n // so shouldn't cause any accessibility issues\n userSelect: 'none',\n}))\n\nconst roundToTwoDecimals = (num: number) => Math.round(num * 100) / 100\n\ninterface IconProps {\n avatarSize: ResponsiveProp<AvatarSize>\n}\nconst StyledIcon = styled(UserRound, { shouldForwardProp: isPropValid })<IconProps>(\n ({ avatarSize }) => ({\n ...toMediaQueries(avatarSize, (currentValue) => {\n const size = ICON_SIZE_MAP[currentValue]\n\n return {\n width: size,\n height: size,\n // Always set a minimum stroke width of 2px.\n // If the size is less than 24px, scale the stroke width up\n // to compensate for the scaling down of the icon.\n ...(size < 24 && {\n strokeWidth: roundToTwoDecimals((24 / size) * 2),\n }),\n }\n }),\n }),\n)\n\ninterface AvatarOptions {\n /**\n * Source url of the image to display. If not passed\n * it will display a fallback icon.\n */\n src?: string\n /**\n * Name of the user. Used to generate the initials\n * if no image is provided, but also for accessibility.\n */\n name?: string\n /**\n * Size of the avatar\n * @default 'md'\n */\n size?: ResponsiveProp<AvatarSize>\n}\n\nexport interface AvatarProps extends HTMLQdsProps<'span'>, AvatarOptions {}\nexport const Avatar = forwardRef<HTMLSpanElement, AvatarProps>((props, forwardedRef) => {\n const { src, name, size = 'md', ...restProps } = props\n return (\n <AvatarRoot ref={forwardedRef} size={size} {...restProps}>\n <AvatarImage src={src} alt={name} />\n <AvatarFallback delayMs={src ? 200 : undefined}>\n {name ? (\n <FallbackText avatarSize={size}>{getInitials(name)}</FallbackText>\n ) : (\n <StyledIcon avatarSize={size} role=\"img\" aria-label={name} />\n )}\n </AvatarFallback>\n </AvatarRoot>\n )\n})\n","import type { CSSObject } from '@emotion/react'\n\nimport { theme, type Theme } from '../theme'\nimport type { PartialRecord } from '../types'\n\ntype BreakpointsConfig<T> = PartialRecord<keyof Theme['breakpoints'], T> & { base: T }\nexport type ResponsiveProp<T> = T | BreakpointsConfig<T>\n\nfunction isResponsiveProp<T>(value: ResponsiveProp<T>): value is BreakpointsConfig<T> {\n return value && typeof value === 'object' && 'base' in value\n}\n\n/**\n * More strictly typed version of Object.entries\n */\nconst objectEntries = <T extends object>(obj: T) => Object.entries(obj) as [keyof T, T[keyof T]][]\n\n/**\n *\n * @param prop Responsive prop\n * @param styleFn Function that returns a CSSObject based on the value of the prop\n * for a given breakpoint.\n *\n * Example:\n * ```ts\n * toMediaQueries(variant, (currentValue) => ({\n * background: currentValue === 'primary' ? 'pink' : 'blue',\n * }))\n * ```\n * @returns CSSObject\n */\nexport const toMediaQueries = <T>(prop: ResponsiveProp<T>, styleFn: (value: T) => CSSObject) => {\n if (!isResponsiveProp(prop)) {\n return styleFn(prop)\n }\n\n const { base, ...breakpoints } = prop\n\n /**\n * Due to some very hard to debug issue,\n * we need to use `let` and reassign the value.\n * Else it leads to messed up CSS styles in SSR.\n * I have no clue, but if it works, it works.\n */\n let cssObject = styleFn(base)\n\n objectEntries(breakpoints).forEach(([breakpoint, value]) => {\n const mediaQuery = theme.mediaQueries[`${breakpoint}Up`]\n\n if (value) {\n cssObject = {\n ...cssObject,\n [mediaQuery]: styleFn(value),\n }\n }\n })\n\n return cssObject\n}\n","import styled from '@emotion/styled'\nimport { forwardRef } from 'react'\nimport isPropValid from '@emotion/is-prop-valid'\n\nimport type * as Polymorphic from '../../utils/polymorphic'\nimport { LoadingDots } from '../loading-dots'\nimport { toMediaQueries, type ResponsiveProp } from '../../styles/responsive'\n\nimport type { ButtonSize, ButtonVariant } from './button-styles'\nimport { getSizeStyles, getVariantStyles } from './button-styles'\nimport type { ButtonOptions } from './button-types'\nimport { ButtonIcon } from './button-icon'\n\ninterface StyledButtonProps {\n size: ResponsiveProp<ButtonSize>\n variant: ButtonVariant\n isFullWidth: boolean\n}\nconst StyledButton = styled('button', { shouldForwardProp: isPropValid })<StyledButtonProps>(\n ({ theme, size, variant, isFullWidth }) => ({\n borderRadius: theme.radii.full,\n display: 'inline-flex',\n justifyContent: 'center',\n alignItems: 'center',\n position: 'relative',\n flexShrink: 0,\n WebkitTouchCallout: 'none',\n WebkitTapHighlightColor: 'transparent',\n userSelect: 'none',\n transitionProperty: 'box-shadow, transform, opacity, background-color, color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n\n '&[disabled]': {\n opacity: 0.4,\n },\n\n '&:not([disabled]):active': {\n transform: 'scale(0.97)',\n },\n ...toMediaQueries(size, (currentValue) => getSizeStyles(theme)[currentValue]),\n ...getVariantStyles(theme)[variant],\n ...(isFullWidth && { width: '100%' }),\n }),\n)\n\nconst ButtonLoadingDots = styled(LoadingDots)({\n position: 'absolute',\n color: 'currentColor',\n})\n\ninterface ContentContainerProps {\n isHidden: boolean\n}\nconst ContentContainer = styled.span<ContentContainerProps>(({ isHidden }) => ({\n opacity: isHidden ? 0 : 1,\n display: 'flex',\n alignItems: 'center',\n}))\n\ntype PolymorphicButton = Polymorphic.ForwardRefComponent<'button', ButtonOptions>\nexport type ButtonProps = Polymorphic.PropsOf<PolymorphicButton>\n\nexport const Button = forwardRef((props, forwardedRef) => {\n const {\n as,\n children,\n // Only default the `type` if not using the as prop\n type = as ? undefined : 'button',\n size: sizeProp = 'md',\n variant = 'secondary',\n isFullWidth = false,\n isLoading = false,\n isDisabled = false,\n disabled: hasHtmlDisabledProp,\n iconLeft,\n iconRight,\n ...rest\n } = props\n\n const shouldBeDisabled = isDisabled || hasHtmlDisabledProp || isLoading\n\n return (\n <StyledButton\n as={as}\n ref={forwardedRef}\n variant={variant}\n size={sizeProp}\n isFullWidth={isFullWidth}\n disabled={shouldBeDisabled}\n type={type}\n {...rest}\n >\n <ContentContainer isHidden={isLoading}>\n {iconLeft && <ButtonIcon buttonSize={sizeProp} icon={iconLeft} placement=\"left\" />}\n {children}\n {iconRight && <ButtonIcon buttonSize={sizeProp} icon={iconRight} placement=\"right\" />}\n </ContentContainer>\n {isLoading && <ButtonLoadingDots size=\"sm\" data-testid=\"button-spinner\" />}\n </StyledButton>\n )\n}) as PolymorphicButton\n","import { keyframes } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { forwardRef } from 'react'\n\nimport type { VariantProps } from '../../styles'\nimport { createStyleVariants, pxToRem } from '../../styles'\nimport type { HTMLQdsProps } from '../../types'\nimport type { ResponsiveProp } from '../../styles/responsive'\nimport { toMediaQueries } from '../../styles/responsive'\n\nconst ANIMATION_DURATION = 1200\nconst ANIMATION_STAGGER_DELAY = 160\n\nconst getSizeStyles = createStyleVariants(() => ({\n sm: { fontSize: pxToRem(8) },\n md: { fontSize: pxToRem(16) },\n}))\ntype LoadingDotsSize = VariantProps<typeof getSizeStyles>\n\nconst Wrapper = styled.span<{ size: ResponsiveProp<LoadingDotsSize> }>(({ theme, size }) => ({\n color: theme.colors.core.brown,\n display: 'inline-flex',\n ...toMediaQueries(size, (currentValue) => getSizeStyles(theme)[currentValue]),\n // Odd value but it works better with the animation\n gap: pxToRem(6),\n}))\nconst scaleAnimation = keyframes({\n '0%, 80%, 100%': { transform: 'scale(0)' },\n '40%': { transform: 'scale(1)' },\n})\nconst Dot = styled.span({\n display: 'block',\n width: '1em',\n height: '1em',\n background: 'currentColor',\n borderRadius: 999,\n\n animationDuration: `${ANIMATION_DURATION}ms`,\n animationTimingFunction: 'ease-in-out',\n animationIterationCount: 'infinite',\n animationFillMode: 'both',\n '&:nth-of-type(2)': { animationDelay: `${ANIMATION_STAGGER_DELAY}ms` },\n '&:nth-of-type(3)': { animationDelay: `${ANIMATION_STAGGER_DELAY * 2}ms` },\n animationName: scaleAnimation,\n})\n\ninterface LoadingDotsOptions {\n size?: ResponsiveProp<LoadingDotsSize>\n}\n\nexport interface LoadingDotsProps extends HTMLQdsProps<'span'>, LoadingDotsOptions {}\n\nexport const LoadingDots = forwardRef<HTMLSpanElement, LoadingDotsProps>((props, forwardedRef) => {\n const { size = 'md', ...restProps } = props\n\n return (\n <Wrapper ref={forwardedRef} size={size} {...restProps}>\n <Dot />\n <Dot />\n <Dot />\n </Wrapper>\n )\n})\n","import type { VariantProps } from '../../styles'\nimport { pxToRem, createStyleVariants } from '../../styles'\n\n// Can't use :enabled cause it doesn't work when rendered as a link\nconst NOT_DISABLED = ':not([disabled])'\n\nexport const getSizeStyles = createStyleVariants(({ typography, spacing }) => ({\n xs: {\n height: pxToRem(32),\n paddingLeft: spacing['4x'],\n paddingRight: spacing['4x'],\n ...typography.button.sm,\n },\n sm: {\n height: pxToRem(40),\n paddingLeft: spacing['5x'],\n paddingRight: spacing['5x'],\n ...typography.button.sm,\n },\n md: {\n height: pxToRem(48),\n paddingLeft: spacing['6x'],\n paddingRight: spacing['6x'],\n ...typography.button.md,\n },\n lg: {\n height: pxToRem(56),\n paddingLeft: spacing['8x'],\n paddingRight: spacing['8x'],\n ...typography.button.md,\n },\n xl: {\n height: pxToRem(64),\n paddingLeft: spacing['8x'],\n paddingRight: spacing['8x'],\n ...typography.button.md,\n },\n}))\nexport type ButtonSize = VariantProps<typeof getSizeStyles>\n\nexport const getVariantStyles = createStyleVariants(({ colors }) => ({\n primary: {\n background: colors.bg.brandPrimary,\n color: colors.text.onBrandPrimary,\n [NOT_DISABLED]: {\n '@media(hover: hover)': {\n ':hover': {\n background: colors.bg.brandPrimaryHover,\n },\n },\n ':active': {\n background: colors.bg.brandPrimaryActive,\n },\n },\n },\n secondary: {\n background: colors.bg.brandSecondary,\n color: colors.text.onBrandSecondary,\n [NOT_DISABLED]: {\n '@media(hover: hover)': {\n ':hover': {\n background: colors.bg.brandSecondaryHover,\n },\n },\n ':active': {\n background: colors.bg.brandSecondaryActive,\n },\n },\n },\n tertiary: {\n background: colors.bg.brandTertiary,\n color: colors.text.onBrandTertiary,\n [NOT_DISABLED]: {\n '@media(hover: hover)': {\n ':hover': {\n background: colors.bg.brandTertiaryHover,\n },\n },\n ':active': {\n background: colors.bg.brandTertiaryActive,\n },\n },\n },\n}))\nexport type ButtonVariant = VariantProps<typeof getVariantStyles>\n","import styled from '@emotion/styled'\nimport type { ElementType } from 'react'\n\nimport type { Theme } from '../../theme'\nimport type { IconProps } from '../icon'\nimport { toMediaQueries, type ResponsiveProp } from '../../styles/responsive'\n\nimport type { ButtonSize } from './button-styles'\n\nconst roundToTwoDecimals = (num: number) => Math.round(num * 100) / 100\n\nconst ICON_SIZE_MAP = {\n xs: 16,\n sm: 16,\n md: 20,\n lg: 20,\n xl: 20,\n} as const\n\nconst ICON_GAP: Record<ButtonSize, keyof Theme['spacing']> = {\n xs: '2x',\n sm: '3x',\n md: '3x',\n lg: '4x',\n xl: '4x',\n}\nconst ICON_OFFSET: Record<ButtonSize, keyof Theme['spacing']> = {\n xs: '1x',\n sm: '1x',\n md: '1x',\n lg: '2x',\n xl: '2x',\n}\n\ninterface IconContainerProps {\n buttonSize: ResponsiveProp<ButtonSize>\n}\n\nconst IconLeftContainer = styled.span<IconContainerProps>(({ theme, buttonSize }) => ({\n flexShrink: 0,\n ...toMediaQueries(buttonSize, (currentValue) => {\n const iconSize = ICON_SIZE_MAP[currentValue]\n return {\n marginLeft: `-${theme.spacing[ICON_OFFSET[currentValue]]}`,\n marginRight: theme.spacing[ICON_GAP[currentValue]],\n\n '> svg': {\n width: iconSize,\n height: iconSize,\n // Always set a minimum stroke width of 2px.\n // If the size is less than 24px, scale the stroke width up\n // to compensate for the scaling down of the icon.\n ...(iconSize < 24 && {\n strokeWidth: roundToTwoDecimals((24 / iconSize) * 2),\n }),\n },\n }\n }),\n}))\nconst IconRightContainer = styled.span<IconContainerProps>(({ theme, buttonSize }) => ({\n flexShrink: 0,\n ...toMediaQueries(buttonSize, (currentValue) => {\n const iconSize = ICON_SIZE_MAP[currentValue]\n return {\n marginRight: `-${theme.spacing[ICON_OFFSET[currentValue]]}`,\n marginLeft: theme.spacing[ICON_GAP[currentValue]],\n\n '> svg': {\n width: iconSize,\n height: iconSize,\n // Always set a minimum stroke width of 2px.\n // If the size is less than 24px, scale the stroke width up\n // to compensate for the scaling down of the icon.\n ...(iconSize < 24 && {\n strokeWidth: roundToTwoDecimals((24 / iconSize) * 2),\n }),\n },\n }\n }),\n}))\n\ninterface ButtonIconProps {\n buttonSize: ResponsiveProp<ButtonSize>\n icon: ElementType<IconProps>\n placement: 'left' | 'right'\n}\nexport function ButtonIcon({ buttonSize, icon: Icon, placement }: ButtonIconProps) {\n const Container = placement === 'left' ? IconLeftContainer : IconRightContainer\n return (\n <Container buttonSize={buttonSize}>\n <Icon aria-hidden=\"true\" color=\"currentColor\" />\n </Container>\n )\n}\n","import styled from '@emotion/styled'\nimport isPropValid from '@emotion/is-prop-valid'\nimport { forwardRef } from 'react'\n\nimport type * as Polymorphic from '../../utils/polymorphic'\nimport type { Theme } from '../../theme'\nimport type { ResponsiveProp } from '../../styles/responsive'\nimport { toMediaQueries } from '../../styles/responsive'\n\ntype DisplaySize = keyof Theme['typography']['display']\n\ntype DisplayTextAlign = 'left' | 'center' | 'right'\ntype DisplayTextWrap = 'pretty' | 'balance' | 'wrap' | 'nowrap' | 'stable'\n\ninterface StyledDisplayTextProps {\n size: ResponsiveProp<DisplaySize>\n textAlign: DisplayTextAlign\n textWrap: DisplayTextWrap\n}\n\nconst StyledDisplayText = styled('h2', { shouldForwardProp: isPropValid })<StyledDisplayTextProps>(\n ({ theme, size, textAlign, textWrap }) => ({\n margin: 0,\n ...toMediaQueries(size, (currentValue) => theme.typography.display[currentValue]),\n color: theme.colors.text.default,\n textAlign,\n textWrap,\n overflowWrap: 'break-word',\n wordWrap: 'break-word',\n }),\n)\n\ninterface DisplayTextOptions {\n /**\n * Sets the visual size of the display text.\n * To override the rendered tag, use the `as` prop.\n *\n * @default 'md'\n */\n size?: ResponsiveProp<DisplaySize>\n /**\n * Sets the text alignment\n *\n * @default 'left'\n */\n textAlign?: DisplayTextAlign\n /**\n * Sets the text wrapping\n *\n * See [MDN Docs](https://developer.mozilla.org/en-US/docs/Web/CSS/text-wrap)\n *\n * @default 'pretty'\n */\n textWrap?: DisplayTextWrap\n}\n\ntype DisplayTextComponent = Polymorphic.ForwardRefComponent<'h2', DisplayTextOptions>\nexport type DisplayTextProps = Polymorphic.PropsOf<DisplayTextComponent>\n\nexport const DisplayText = forwardRef((props, forwardedRef) => {\n const { as, children, size = 'md', textAlign = 'left', textWrap = 'pretty', ...rest } = props\n return (\n <StyledDisplayText\n as={as}\n ref={forwardedRef}\n size={size}\n textAlign={textAlign}\n textWrap={textWrap}\n {...rest}\n >\n {children}\n </StyledDisplayText>\n )\n}) as DisplayTextComponent\n","import styled from '@emotion/styled'\nimport type { ReactElement } from 'react'\nimport { forwardRef } from 'react'\nimport * as CheckboxPrimitive from '@radix-ui/react-checkbox'\nimport { Check } from 'lucide-react'\n\nimport { pxToRem } from '../../styles'\nimport { useStableId } from '../../hooks'\nimport { ariaAttr, dataAttr } from '../../utils/html-attributes'\nimport { ErrorMessage, HelperText } from '../_internal'\n\nconst Wrapper = styled.div({\n width: '100%',\n display: 'flex',\n flexDirection: 'column',\n})\n\nconst CheckboxContainer = styled.label(({ theme }) => ({\n width: '100%',\n display: 'grid',\n gridTemplateColumns: 'auto 1fr',\n alignItems: 'start',\n gap: theme.spacing['3x'],\n position: 'relative',\n cursor: 'pointer',\n WebkitTapHighlightColor: 'transparent',\n WebkitTouchCallout: 'none',\n // Right now not all browsers support the `:has` pseudo-class\n // But we also set the cursor to `not-allowed` in the nested elements\n // so this just makes it so the gap between the checkbox and the text\n // doesn't have the cursor. In the future we should be able to rely\n // on this completely\n '&:has([role=\"checkbox\"][data-disabled])': {\n cursor: 'not-allowed',\n },\n}))\n\nconst CheckboxRoot = styled(CheckboxPrimitive.Root)(({ theme }) => ({\n position: 'relative',\n WebkitTapHighlightColor: 'transparent',\n WebkitTouchCallout: 'none',\n // We use margin to align the checkbox with the text\n // since `align-items: center` wouldn't work when the text wraps\n marginTop: pxToRem(1),\n display: 'flex',\n justifyContent: 'center',\n alignItems: 'center',\n width: pxToRem(20),\n height: pxToRem(20),\n flexShrink: 0,\n border: '2px solid',\n borderColor: theme.colors.border.strong,\n borderRadius: theme.radii['2xs'],\n color: 'transparent',\n transitionProperty: 'background-color, color',\n transitionDuration: '80ms',\n transitionTimingFunction: 'ease',\n '&[data-state=\"checked\"]': {\n backgroundColor: theme.colors.border.strong,\n color: theme.colors.core.brown,\n '&[aria-invalid=\"true\"]': {\n borderColor: theme.colors.border.negative,\n },\n },\n '&[data-state=\"unchecked\"]': {\n backgroundColor: theme.colors.bg.default,\n '@media(hover: hover)': {\n '&:hover': {\n backgroundColor: theme.colors.bg.inset,\n color: theme.colors.core.gray20,\n },\n },\n '&[aria-invalid=\"true\"]': {\n borderColor: theme.colors.border.negative,\n },\n },\n\n '&[data-disabled], &:disabled, &[disabled]': {\n opacity: 0.4,\n '&[data-state=\"unchecked\"]': {\n backgroundColor: theme.colors.bg.default,\n '&:hover': {\n color: 'transparent',\n },\n },\n '&[data-state=\"checked\"]': {\n backgroundColor: theme.colors.border.strong,\n },\n },\n}))\n\nconst LabelText = styled.span(({ theme }) => ({\n ...theme.typography.body.md,\n '&[data-disabled], &:disabled': {\n opacity: 0.4,\n cursor: 'not-allowed',\n },\n}))\n\nconst SupportingTextContainer = styled.div(({ theme }) => ({\n display: 'flex', // Removes line-height from making it too tall\n marginLeft: theme.spacing['8x'],\n}))\n\ninterface CheckboxOptions {\n /**\n * The label for the checkbox. Accepts a string, or a React component for rendering links within the label.\n *\n * @example\n * ```jsx\n * <Checkbox label=\"I agree to the terms and conditions\" />\n * ```\n *\n * @example\n * ```jsx\n * <Checkbox\n * label={\n * <>\n * I agree to <Link href=\"/terms\">the terms and conditions</Link>\n * </>\n * }\n * />\n * ```\n */\n label: string | ReactElement<unknown>\n /**\n * Text that provides additional guidance to the user\n */\n helperText?: string\n /**\n * The checked state of the checkbox when it is initially rendered. Use when you do not need to control its checked state.\n */\n isDefaultChecked?: boolean\n /**\n * The checked state of the checkbox when it is initially rendered. Use when you do not need to control its checked state.\n */\n defaultChecked?: boolean // NOTE: We redeclare this type from Radix because we don't want to support indeterminate state\n /**\n * The controlled checked state of the checkbox. Must be used in conjunction with `onCheckedChange`.\n */\n isChecked?: boolean\n /**\n * The controlled checked state of the checkbox. Must be used in conjunction with `onCheckedChange`.\n */\n checked?: boolean // NOTE: We redeclare this type from Radix because we don't want to support indeterminate state\n /**\n * Event handler called when the checked state of the checkbox changes.\n */\n onCheckedChange?: (checked: boolean) => void\n /**\n * If `true` the checkbox will render in its invalid state.\n * @default false\n */\n isInvalid?: boolean\n /**\n * The error message to display if `isInvalid` is `true`\n */\n errorMessage?: string\n /**\n * If `true` it prevents the user from interacting with the checkbox.\n * @default false\n */\n isDisabled?: boolean\n /**\n * If `true` the user must check the checkbox before the owning form can be submitted.\n * @default false\n */\n isRequired?: boolean\n /**\n * The name of the checkbox. Submitted with its owning form as part of a name/value pair.\n */\n name?: string\n /**\n * The value given as data when submitted with a `name`.\n */\n value?: string\n}\n\nexport type CheckboxProps = Omit<\n CheckboxPrimitive.CheckboxProps,\n 'asChild' | 'children' | 'checked' | 'defaultChecked' | keyof CheckboxOptions\n> &\n CheckboxOptions\n\nexport const Checkbox = forwardRef<HTMLButtonElement, CheckboxProps>((props, forwardedRef) => {\n const {\n label,\n helperText,\n id: idProp,\n defaultChecked: hasHtmlDefaultCheckedAttr,\n isDefaultChecked: isDefaultCheckedProp,\n isChecked: isCheckedProp,\n checked: hasHtmlCheckedAttr,\n isDisabled: isDisabledProp,\n disabled: hasHtmlDisabledAttr,\n isRequired: isRequiredProp,\n required: hasHtmlRequiredAttr,\n isInvalid,\n errorMessage,\n 'aria-labelledby': ariaLabelledByProp,\n 'aria-describedby': ariaDescribedByProp,\n ...restProps\n } = props\n const id = useStableId(idProp)\n\n const labelId = `${id}-label`\n\n const isDefaultChecked = isDefaultCheckedProp ?? hasHtmlDefaultCheckedAttr\n const isChecked = isCheckedProp ?? hasHtmlCheckedAttr\n const isDisabled = isDisabledProp ?? hasHtmlDisabledAttr\n const isRequired = isRequiredProp ?? hasHtmlRequiredAttr\n\n const ariaLabelledBy = [labelId, ariaLabelledByProp].filter(Boolean).join(' ')\n\n const hasHelperText = Boolean(helperText)\n const helperTextId = hasHelperText ? `${id}-helper` : undefined\n\n const helperTextElement = helperText && (\n <SupportingTextContainer>\n <HelperText id={helperTextId} data-disabled={dataAttr(isDisabled)}>\n {helperText}\n </HelperText>\n </SupportingTextContainer>\n )\n\n const hasError = isInvalid && errorMessage\n const errorMessageId = hasError ? `${id}-error` : undefined\n\n const errorMessageElement = hasError && (\n <SupportingTextContainer>\n <ErrorMessage id={errorMessageId} role=\"alert\" aria-live=\"polite\">\n {errorMessage}\n </ErrorMessage>\n </SupportingTextContainer>\n )\n\n const ariaDescribedBy =\n [errorMessageId, !hasError && helperTextId, ariaDescribedByProp].filter(Boolean).join(' ') ||\n undefined\n\n return (\n <Wrapper>\n <CheckboxContainer>\n <CheckboxRoot\n id={id}\n ref={forwardedRef}\n defaultChecked={isDefaultChecked}\n checked={isChecked}\n disabled={isDisabled}\n required={isRequired}\n aria-invalid={ariaAttr(isInvalid)}\n aria-labelledby={ariaLabelledBy}\n aria-describedby={ariaDescribedBy}\n {...restProps}\n >\n <CheckboxPrimitive.Indicator forceMount>\n <Check\n size={12}\n strokeWidth={3}\n absoluteStrokeWidth\n aria-hidden=\"true\"\n role=\"presentation\"\n />\n </CheckboxPrimitive.Indicator>\n </CheckboxRoot>\n <LabelText\n id={labelId}\n data-disabled={dataAttr(isDisabled)}\n onMouseDown={(ev) => {\n // prevent text selection when double clicking label\n if (ev.detail > 1) {\n ev.preventDefault()\n }\n }}\n >\n {label}\n </LabelText>\n </CheckboxContainer>\n {errorMessageElement || helperTextElement}\n </Wrapper>\n )\n})\n","import { useEffect, useState } from 'react'\n\nimport { theme } from '../theme'\nimport type { Theme } from '../theme'\n\ntype Breakpoints = Theme['breakpoints']\n\nconst breakpointsArray = Object.entries(theme.breakpoints).map(([name, value]) => ({\n name: name as keyof Breakpoints,\n breakpoint: value,\n}))\n\nconst MEDIA_QUERIES = breakpointsArray.map(({ name, breakpoint }, index) => {\n const nextValue = breakpointsArray?.[index + 1]?.breakpoint\n const media = nextValue\n ? `(min-width: ${breakpoint}px) and (max-width: ${nextValue - 1}px)`\n : `(min-width: ${breakpoint}px)`\n\n return {\n name,\n media,\n }\n})\n\nconst getMatchingBreakpoint = () => {\n const matchingBreakpoint = MEDIA_QUERIES.find(({ media }) => {\n return window.matchMedia(media).matches\n })\n // Since the breakpoints cover all screen sizes we should always get a match,\n // but to be safe we return 'base' as a fallback.\n return matchingBreakpoint?.name || 'base'\n}\n\nexport interface UseBreakpointOptions {\n /**\n * If `true` the initial value will be `base` instead of the current breakpoint.\n * This is to support hydration when using server side rendering.\n *\n * @default false\n */\n ssr?: boolean\n}\n\n/**\n * Hook for getting the current breakpoint.\n */\nexport function useBreakpoint(params?: UseBreakpointOptions) {\n // eslint-disable-next-line @typescript-eslint/naming-convention\n const { ssr = false } = params || {}\n const initialBreakpoint = ssr ? 'base' : getMatchingBreakpoint\n const [currentBreakpoint, setCurrentBreakpoint] = useState<keyof Breakpoints>(initialBreakpoint)\n\n useEffect(() => {\n const matchMediaArray = MEDIA_QUERIES.map(({ media }) => window.matchMedia(media))\n\n const handleChange = () => {\n // Instead of checking the value from the matchMedia listeners event we just use it\n // as trigger to know when the current breakpoint should be updated.\n // This is because each separate query has its own event listener which\n // can lead to incorrect intermediate states where no breakpoint is matching.\n setCurrentBreakpoint(getMatchingBreakpoint())\n }\n\n // Update the current breakpoint on the first render.\n // After that the event listeners will take care of updating the state.\n handleChange()\n\n matchMediaArray.forEach((mediaQuery) => {\n if (typeof mediaQuery.addListener === 'function') {\n // Safari < 14 fallback\n mediaQuery.addListener(handleChange)\n } else {\n mediaQuery.addEventListener('change', handleChange)\n }\n })\n\n return () => {\n matchMediaArray.forEach((mediaQuery) => {\n if (typeof mediaQuery.addListener === 'function') {\n mediaQuery.removeListener(handleChange)\n } else {\n mediaQuery.removeEventListener('change', handleChange)\n }\n })\n }\n }, [])\n\n return { currentBreakpoint }\n}\n","import type { Theme } from '../theme'\nimport { breakpoints } from '../theme/foundations/breakpoints'\nimport type { PartialRecord } from '../types'\n\nimport type { UseBreakpointOptions } from './use-breakpoint'\nimport { useBreakpoint } from './use-breakpoint'\n\ntype Breakpoints = Theme['breakpoints']\ntype BreakpointsConfig<T> = PartialRecord<keyof Breakpoints, T> & { base: T }\nexport type UseBreakpointValueProps<T> = BreakpointsConfig<T>\n\n/**\n * Hook for getting a value based on the current breakpoint.\n *\n * @example\n * const width = useBreakpointValue({ base: '150px', md: '250px' })\n */\nexport function useBreakpointValue<T>(\n values: UseBreakpointValueProps<T>,\n options?: UseBreakpointOptions,\n) {\n const { currentBreakpoint } = useBreakpoint(options)\n let breakpointValue\n\n if (currentBreakpoint in values) {\n breakpointValue = values[currentBreakpoint]\n } else {\n const breakpointNames = Object.keys(breakpoints) as (keyof Breakpoints)[]\n const currentBreakpointIndex = breakpointNames.indexOf(currentBreakpoint)\n for (let i = currentBreakpointIndex; i >= 0; i--) {\n const key = breakpointNames[i]\n if (key in values) {\n breakpointValue = values[key]\n break\n }\n }\n }\n /* Assert since a value will always be found in loop */\n return breakpointValue as T\n}\n","import type { ElementType } from 'react'\nimport { useCallback } from 'react'\n\nimport type { HTMLQdsProps, LegitimateAny } from '../types'\n\nimport { useStableId } from './use-stable-id'\n\ntype FormFieldElement = 'input' | 'select' | 'textarea'\n\ntype PropGetter<T extends ElementType = LegitimateAny> = (\n props?: HTMLQdsProps<T>,\n) => Record<string, unknown>\n\ninterface FormFieldOptions {\n /**\n * The label for the form field\n */\n label: string\n /**\n * The error message to display if `isInvalid` is `true`\n */\n errorMessage?: string\n /**\n * Text that provides additional guidance to the user\n */\n helperText?: string\n /**\n * If `true`, the form field will be invalid\n */\n isInvalid?: boolean\n /**\n * If `true`, the form field will be disabled\n */\n isDisabled?: boolean\n /**\n * If `true` the form field will be required\n */\n isRequired?: boolean\n}\n\ntype OmittedProps = 'children' | 'readOnly' | 'size'\nexport type UseFormFieldProps<T extends FormFieldElement> = Omit<HTMLQdsProps<T>, OmittedProps> &\n FormFieldOptions\n\n/**\n * Custom hook that returns props for a form field's label, input, helper text and error message.\n * Meant to be used in conjunction with the `Input`, `Select` or `Textarea` component.\n *\n * Used internally by `TextField`, `Select` and `Textarea`.\n */\nexport const useFormField = <T extends FormFieldElement>(props: UseFormFieldProps<T>) => {\n const { id: idProp, isDisabled, helperText, errorMessage, isInvalid, isRequired } = props\n const id = useStableId(idProp)\n\n const errorMessageId = `${id}-error`\n const helperTextId = `${id}-helper`\n\n const getLabelProps = useCallback<PropGetter<'label'>>(\n (forwardedProps) => ({\n ...forwardedProps,\n htmlFor: id,\n 'data-disabled': isDisabled ? '' : undefined,\n }),\n [id, isDisabled],\n )\n\n const getHelperTextProps = useCallback<PropGetter<'div'>>(\n (forwardedProps) => ({\n ...forwardedProps,\n id: helperTextId,\n 'data-disabled': isDisabled ? '' : undefined,\n }),\n [helperTextId, isDisabled],\n )\n\n const getErrorMessageProps = useCallback<PropGetter<'div'>>(\n (forwardedProps) => ({\n ...forwardedProps,\n id: errorMessageId,\n 'aria-live': 'polite',\n }),\n [errorMessageId],\n )\n\n const getFieldProps = useCallback<PropGetter<T>>(\n (forwardedProps) => {\n const ariaDescribedByIds: string[] = []\n\n // Error message must be described first in all scenarios.\n if (Boolean(errorMessage) && isInvalid) {\n ariaDescribedByIds.push(errorMessageId)\n } else if (helperText) {\n ariaDescribedByIds.push(helperTextId)\n }\n\n if (forwardedProps?.['aria-describedby']) {\n ariaDescribedByIds.push(forwardedProps['aria-describedby'])\n }\n\n return {\n ...forwardedProps,\n 'aria-describedby': ariaDescribedByIds.join(' ') || undefined,\n id: forwardedProps?.id ?? id,\n isDisabled,\n isRequired,\n 'aria-invalid': isInvalid ? true : undefined,\n }\n },\n [errorMessage, errorMessageId, helperText, helperTextId, id, isDisabled, isInvalid, isRequired],\n )\n\n return {\n getLabelProps,\n /**\n * Props to be spread on the input, select or textarea element.\n * Function accepts an optional object of props to be merged with the returned props.\n */\n getFieldProps,\n getHelperTextProps,\n getErrorMessageProps,\n }\n}\n","import React, { useState } from 'react'\n\nimport type { LegitimateAny } from '../types'\n\nimport { useSafeLayoutEffect } from './use-safe-layout-effect'\n\n/**\n * This is basically a copy of Radix UI's `useId` hook.\n */\n\n// We `toString()` to prevent bundlers from trying to `import { useId } from 'react';`\nconst useReactId = (React as LegitimateAny)['useId'.toString()] || (() => undefined)\nlet count = 0\n\n/**\n * Returns a stable ID that is unique to the component instance.\n */\nexport function useStableId(fixedId?: string | null): string {\n const [id, setId] = useState<string | undefined>(useReactId())\n // React versions older than 18 will have client-side ids only.\n useSafeLayoutEffect(() => {\n if (!fixedId) setId((reactId) => reactId ?? String(count++))\n }, [fixedId])\n return fixedId || (id ? `qds-${id}` : '')\n}\n","import { useLayoutEffect } from 'react'\n\n/**\n * On the server, React emits a warning when calling `useLayoutEffect`.\n * This is because neither `useLayoutEffect` nor `useEffect` run on the server.\n * We use this safe version which suppresses the warning by replacing it with a noop on the server.\n *\n * See: https://reactjs.org/docs/hooks-reference.html#uselayouteffect\n */\nexport const useSafeLayoutEffect = globalThis?.document ? useLayoutEffect : () => undefined\n","type Booleanish = boolean | 'true' | 'false'\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const dataAttr = (condition: boolean | undefined) =>\n (condition ? '' : undefined) as Booleanish\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const ariaAttr = (condition: boolean | undefined) =>\n (condition ? 'true' : undefined) as Booleanish\n","import styled from '@emotion/styled'\nimport type { PropsWithChildren } from 'react'\n\nconst FieldWrapper = styled.div(({ theme }) => ({\n position: 'relative',\n display: 'flex',\n flexDirection: 'column',\n gap: theme.spacing['2x'],\n width: '100%',\n}))\n\nexport function FormField({ children }: PropsWithChildren) {\n return <FieldWrapper role=\"group\">{children}</FieldWrapper>\n}\n\nexport const ErrorMessage = styled.div(({ theme }) => ({\n ...theme.typography.body.sm,\n color: theme.colors.text.negative,\n}))\n\n// We use a `<span>` since our radio buttons render as `<button>`\n// through Radix. And only phrasing content is allowed inside a `<button>`.\n// See: https://validator.nu/#textarea\nexport const HelperText = styled.span(({ theme }) => ({\n ...theme.typography.body.sm,\n color: theme.colors.text.subtle,\n '&[data-disabled]': {\n opacity: 0.4,\n },\n}))\n","import styled from '@emotion/styled'\nimport { forwardRef } from 'react'\n\nimport type { HTMLQdsProps } from '../../types'\n\nconst StyledDivider = styled.span<Required<DividerOptions>>(({ theme, orientation }) => {\n const borderCssKey = orientation === 'horizontal' ? 'borderTop' : 'borderLeft'\n const sizeCssKey = orientation === 'horizontal' ? 'width' : 'height'\n return {\n display: 'block',\n [sizeCssKey]: '100%',\n flexShrink: 0,\n [borderCssKey]: `1px solid ${theme.colors.border.default}`,\n }\n})\n\ninterface DividerOptions {\n /**\n * The orientation of the divider.\n *\n * @default 'horizontal'\n */\n orientation?: 'horizontal' | 'vertical'\n}\n\nexport interface DividerProps extends HTMLQdsProps<'span'>, DividerOptions {}\nexport const Divider = forwardRef<HTMLDivElement, DividerProps>((props, forwardedRef) => {\n const { orientation = 'horizontal', ...restProps } = props\n return (\n <StyledDivider ref={forwardedRef} orientation={orientation} role=\"separator\" {...restProps} />\n )\n})\n","import * as DropdownPrimitive from '@radix-ui/react-dropdown-menu'\nimport type { ReactNode } from 'react'\n\nimport { DropdownMenuContent, type DropdownMenuContentProps } from './dropdown-menu-content'\nimport { DropdownMenuDivider, type DropdownMenuDividerProps } from './dropdown-menu-divider'\nimport { DropdownMenuItem, type DropdownMenuItemProps } from './dropdown-menu-item'\nimport type { DropdownMenuTriggerProps } from './dropdown-menu-trigger'\nimport { DropdownMenuTrigger } from './dropdown-menu-trigger'\n\ninterface DropdownMenuRootProps {\n children: ReactNode\n /**\n * If `true` the dropdown menu will be open\n */\n isOpen?: boolean\n /**\n * The open state of the submenu when it is initially rendered.\n * Use when you do not need to control its open state.\n */\n defaultOpen?: boolean\n /**\n * Callback invoked open state changes\n */\n onOpenChange?: (isOpen: boolean) => void\n}\n\nfunction DropdownMenuRoot(props: DropdownMenuRootProps) {\n //eslint-disable-next-line @typescript-eslint/naming-convention\n const { children, isOpen, onOpenChange, defaultOpen = false } = props\n return (\n <DropdownPrimitive.Root\n defaultOpen={defaultOpen}\n open={isOpen}\n onOpenChange={onOpenChange}\n modal\n >\n {children}\n </DropdownPrimitive.Root>\n )\n}\n\nexport const DropdownMenu = Object.assign(DropdownMenuRoot, {\n Trigger: DropdownMenuTrigger,\n Content: DropdownMenuContent,\n Item: DropdownMenuItem,\n Divider: DropdownMenuDivider,\n})\n\nexport type {\n DropdownMenuRootProps,\n DropdownMenuTriggerProps,\n DropdownMenuContentProps,\n DropdownMenuItemProps,\n DropdownMenuDividerProps,\n}\n","import { keyframes } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport * as DropdownPrimitive from '@radix-ui/react-dropdown-menu'\nimport { forwardRef } from 'react'\n\nimport type { HTMLQdsProps } from '../../types'\n\nconst slideUpAndFadeIn = keyframes({\n '0%': { opacity: 0, transform: 'translateY(4px) scale(0.94)' },\n '100%': { opacity: 1, transform: 'translateY(0)' },\n})\n\nconst slideRightAndFadeIn = keyframes({\n '0%': { opacity: 0, transform: 'translateX(-4px) scale(0.94)' },\n '100%': { opacity: 1, transform: 'translateX(0)' },\n})\n\nconst slideDownAndFadeIn = keyframes({\n '0%': { opacity: 0, transform: 'translateY(-4px) scale(0.94)' },\n '100%': { opacity: 1, transform: 'translateY(0)' },\n})\n\nconst slideLeftAndFadeIn = keyframes({\n '0%': { opacity: 0, transform: 'translateX(4px) scale(0.94)' },\n '100%': { opacity: 1, transform: 'translateX(0)' },\n})\nconst slideUpAndFadeOut = keyframes({\n '0%': { opacity: 1, transform: 'translateY(0px)' },\n '100%': { opacity: 0, transform: 'translateY(-4px) scale(0.94)' },\n})\n\nconst slideRightAndFadeOut = keyframes({\n '0%': { opacity: 1, transform: 'translateX(0px)' },\n '100%': { opacity: 0, transform: 'translateX(4px) scale(0.94)' },\n})\n\nconst slideDownAndFadeOut = keyframes({\n '0%': { opacity: 1, transform: 'translateY(0)' },\n '100%': { opacity: 0, transform: 'translateY(4px) scale(0.94)' },\n})\n\nconst slideLeftAndFadeOut = keyframes({\n '0%': { opacity: 1, transform: 'translateX(0)' },\n '100%': { opacity: 0, transform: 'translateX(-4px) scale(0.94)' },\n})\n\nconst StyledContent = styled(DropdownPrimitive.Content)(({ theme }) => ({\n background: theme.colors.bg.default,\n minWidth: theme.sizes[192],\n maxWidth: theme.sizes[288],\n borderRadius: theme.radii.md,\n boxShadow: theme.shadows.md,\n padding: theme.spacing['2x'],\n '@media (prefers-reduced-motion: no-preference)': {\n transformOrigin: 'var(--radix-dropdown-menu-content-transform-origin)',\n animationDuration: '240ms',\n animationTimingFunction: 'cubic-bezier(0.16, 1, 0.3, 1)',\n willChange: 'transform, opacity',\n '&[data-state=\"open\"]': {\n '&[data-side=\"top\"]': { animationName: slideUpAndFadeIn },\n '&[data-side=\"right\"]': { animationName: slideRightAndFadeIn },\n '&[data-side=\"bottom\"]': { animationName: slideDownAndFadeIn },\n '&[data-side=\"left\"]': { animationName: slideLeftAndFadeIn },\n },\n '&[data-state=\"closed\"]': {\n animationDuration: '180ms',\n '&[data-side=\"top\"]': { animationName: slideDownAndFadeOut },\n '&[data-side=\"right\"]': { animationName: slideLeftAndFadeOut },\n '&[data-side=\"bottom\"]': { animationName: slideUpAndFadeOut },\n '&[data-side=\"left\"]': { animationName: slideRightAndFadeOut },\n },\n },\n}))\n\ntype PrimitiveContentProps = DropdownPrimitive.DropdownMenuContentProps\n\ninterface DropdownMenuContentOptions {\n /**\n * Event handler called when focus moves to the trigger after closing.\n * It can be prevented by calling `event.preventDefault`.\n */\n onCloseAutofocus?: PrimitiveContentProps['onCloseAutoFocus']\n /**\n * Event handler called when the escape key is down.\n * It can be prevented by calling `event.preventDefault`.\n */\n onEscapeKeyDown?: PrimitiveContentProps['onEscapeKeyDown']\n /**\n * Event handler called when a pointer event occurs outside the bounds of the component.\n * It can be prevented by calling `event.preventDefault`.\n */\n onPointerDownOutside?: PrimitiveContentProps['onPointerDownOutside']\n /**\n * Event handler called when focus moves outside the bounds of the component.\n * It can be prevented by calling `event.preventDefault`.\n */\n onFocusOutside?: PrimitiveContentProps['onFocusOutside']\n /**\n * Event handler called when an interaction (pointer or focus event) happens outside the bounds of the component.\n * It can be prevented by calling `event.preventDefault`.\n */\n onInteractOutside?: PrimitiveContentProps['onInteractOutside']\n /**\n * The preferred side of the trigger to render against when open.\n * Will be reversed when collisions occur and `avoidCollisions` is enabled.\n *\n * @default \"bottom\"\n */\n side?: PrimitiveContentProps['side']\n /**\n * The distance in pixels from the trigger.\n *\n * @default 8\n */\n sideOffset?: PrimitiveContentProps['sideOffset']\n /**\n * The preferred alignment against the trigger. May change when collisions occur.\n *\n * @default \"center\"\n */\n align?: PrimitiveContentProps['align']\n /**\n * The element used as the collision boundary.\n * By default this is the viewport, though you can provide additional element(s) to be included in this check.\n *\n * @default []\n */\n collisionBoundary?: PrimitiveContentProps['collisionBoundary']\n /**\n * Whether to hide the content when the trigger becomes fully occluded.\n *\n * @default false\n */\n hideWhenDetached?: PrimitiveContentProps['hideWhenDetached']\n}\n\nexport interface DropdownMenuContentProps extends HTMLQdsProps<'div'>, DropdownMenuContentOptions {}\n\nexport const DropdownMenuContent = forwardRef<HTMLDivElement, DropdownMenuContentProps>(\n (props, forwardedRef) => {\n const { children, sideOffset = 8, ...restProps } = props\n\n return (\n <DropdownPrimitive.Portal>\n <StyledContent\n collisionPadding={16}\n ref={forwardedRef}\n sideOffset={sideOffset}\n {...restProps}\n >\n {children}\n </StyledContent>\n </DropdownPrimitive.Portal>\n )\n },\n)\n","import { forwardRef } from 'react'\nimport * as DropdownPrimitive from '@radix-ui/react-dropdown-menu'\nimport styled from '@emotion/styled'\n\nimport type { HTMLQdsProps } from '../../types'\n\nconst StyledSeparator = styled(DropdownPrimitive.Separator)(({ theme }) => ({\n height: 1,\n background: theme.colors.border.subtle,\n marginTop: theme.spacing['1x'],\n marginBottom: theme.spacing['1x'],\n marginLeft: `-${theme.spacing['2x']}`,\n marginRight: `-${theme.spacing['2x']}`,\n}))\n\nexport type DropdownMenuDividerProps = HTMLQdsProps<'div'>\nexport const DropdownMenuDivider = forwardRef<HTMLDivElement, DropdownMenuDividerProps>(\n (props, forwardedRef) => {\n return <StyledSeparator ref={forwardedRef} {...props} />\n },\n)\n","import type { ElementType } from 'react'\nimport { forwardRef } from 'react'\nimport * as DropdownPrimitive from '@radix-ui/react-dropdown-menu'\nimport styled from '@emotion/styled'\n\nimport type { IconProps } from '../icon'\nimport { pxToRem } from '../../styles'\n\nconst StyledItem = styled(DropdownPrimitive.Item)(({ theme }) => ({\n ...theme.typography.label.sm,\n color: theme.colors.text.default,\n height: pxToRem(40),\n borderRadius: theme.radii.xs,\n display: 'flex',\n alignItems: 'center',\n gap: theme.spacing['3x'],\n paddingLeft: theme.spacing['3x'],\n paddingRight: theme.spacing['3x'],\n cursor: 'pointer',\n outline: 'none',\n userSelect: 'none',\n '&[data-highlighted]': {\n background: theme.colors.core.gray10,\n },\n ':not([data-disabled])': {\n ':active': {\n background: theme.colors.core.gray20,\n },\n },\n '&[data-disabled]': {\n opacity: 0.4,\n cursor: 'not-allowed',\n },\n}))\nconst TextContainer = styled.span({\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n overflow: 'hidden',\n})\n\ninterface DropdownMenuItemOptions {\n /**\n * If `true`, the item will be disabled\n */\n isDisabled?: boolean\n /**\n * Event handler called when the user selects an item (via mouse or keyboard).\n * Calling `event.preventDefault` in this handler will prevent the dropdown from closing when selecting that item.\n */\n onSelect?: (event: Event) => void\n /**\n * Optional text used for typeahead purposes.\n * By default the typeahead behavior will use the `.textContent` of the item.\n * Use this when the content is complex, or you have non-textual content inside.\n */\n textValue?: string\n /**\n * Optional icon to display on the left side of the item content.\n */\n icon?: ElementType<IconProps>\n}\nexport interface DropdownMenuItemProps\n extends Omit<DropdownPrimitive.DropdownMenuItemProps, 'asChild' | keyof DropdownMenuItemOptions>,\n DropdownMenuItemOptions {}\n\nexport const DropdownMenuItem = forwardRef<HTMLDivElement, DropdownMenuItemProps>(\n (props, forwardedRef) => {\n // eslint-disable-next-line @typescript-eslint/naming-convention\n const { children, disabled, isDisabled, icon: Icon, ...restProps } = props\n return (\n <StyledItem ref={forwardedRef} disabled={disabled || isDisabled} {...restProps}>\n {Icon && <Icon color=\"default\" size={16} aria-hidden />}\n <TextContainer>{children}</TextContainer>\n </StyledItem>\n )\n },\n)\n","import * as DropdownTriggerPrimitive from '@radix-ui/react-dropdown-menu'\nimport { forwardRef } from 'react'\n\nimport type * as Polymorphic from '../../utils/polymorphic'\n\ntype DropdownTriggerComponent = Polymorphic.ForwardRefComponent<'button'>\n\nexport type DropdownMenuTriggerProps = Polymorphic.PropsOf<DropdownTriggerComponent>\n\nexport const DropdownMenuTrigger = forwardRef((props, forwardedRef) => {\n const { children, as, ...restProps } = props\n const Component = as || 'button'\n\n return (\n <DropdownTriggerPrimitive.Trigger ref={forwardedRef} asChild>\n <Component {...restProps}>{children}</Component>\n </DropdownTriggerPrimitive.Trigger>\n )\n}) as DropdownTriggerComponent\n","import styled from '@emotion/styled'\nimport isPropValid from '@emotion/is-prop-valid'\nimport { forwardRef } from 'react'\n\nimport type * as Polymorphic from '../../utils/polymorphic'\nimport type { Theme } from '../../theme'\nimport type { ResponsiveProp } from '../../styles/responsive'\nimport { toMediaQueries } from '../../styles/responsive'\n\ntype HeadingSize = keyof Theme['typography']['title']\ntype HeadingColor = keyof Theme['colors']['text']\n\ninterface StyledHeadingProps {\n size: ResponsiveProp<HeadingSize>\n color: HeadingColor\n numberOfLines?: number\n textAlign?: 'left' | 'center' | 'right'\n}\nconst StyledHeading = styled('h2', { shouldForwardProp: isPropValid })<StyledHeadingProps>(\n ({ theme, size, color, numberOfLines, textAlign }) => ({\n margin: 0,\n ...toMediaQueries(size, (currentValue) => theme.typography.title[currentValue]),\n color: theme.colors.text[color],\n textAlign,\n overflowWrap: 'break-word',\n wordWrap: 'break-word',\n ...(numberOfLines && {\n display: '-webkit-box',\n WebkitBoxOrient: 'vertical',\n WebkitLineClamp: numberOfLines,\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n }),\n }),\n)\n\ninterface HeadingOptions {\n /**\n * Sets the visual size of the heading.\n * To override the rendered tag, use the `as` prop.\n *\n * @default 'md'\n */\n size?: ResponsiveProp<HeadingSize>\n /**\n * Sets the color of the heading\n * @default 'default'\n */\n color?: HeadingColor\n /**\n * Truncates the heading after a specific number of lines\n */\n numberOfLines?: number\n /**\n * Alignment of the heading\n * @default 'left'\n */\n textAlign?: 'left' | 'center' | 'right'\n}\n\ntype HeadingComponent = Polymorphic.ForwardRefComponent<'h2', HeadingOptions>\nexport type HeadingProps = Polymorphic.PropsOf<HeadingComponent>\n\nexport const Heading = forwardRef((props, forwardedRef) => {\n const { as, children, size = 'md', color = 'default', textAlign = 'left', ...rest } = props\n\n return (\n <StyledHeading\n as={as}\n ref={forwardedRef}\n textAlign={textAlign}\n size={size}\n color={color}\n {...rest}\n >\n {children}\n </StyledHeading>\n )\n}) as HeadingComponent\n","import { forwardRef } from 'react'\nimport styled from '@emotion/styled'\n\nimport type { HTMLQdsProps } from '../../types'\n\nconst Wrapper = styled.aside(({ theme }) => ({\n backgroundColor: theme.colors.bg.inset,\n borderRadius: theme.radii.md,\n paddingInline: theme.spacing['5x'],\n paddingBlock: theme.spacing['4x'],\n ...theme.typography.body.sm,\n}))\n\nexport type HintBoxTitleProps = HTMLQdsProps<'span'>\n\nconst Title = styled.p(({ theme }) => ({\n ...theme.typography.title['3xs'],\n marginBottom: theme.spacing['1x'],\n}))\n\nexport type HintBoxProps = HTMLQdsProps<'aside'>\n\nconst HintRoot = forwardRef<HTMLElement, HintBoxProps>((props, forwardedRef) => {\n const { children, ...rest } = props\n return (\n <Wrapper ref={forwardedRef} {...rest}>\n {children}\n </Wrapper>\n )\n})\n\nexport const HintBox = Object.assign(HintRoot, { Title })\n","import type { ElementType } from 'react'\nimport { forwardRef } from 'react'\nimport styled from '@emotion/styled'\nimport isPropValid from '@emotion/is-prop-valid'\n\nimport type { VariantProps } from '../../styles'\nimport type { IconProps } from '../icon'\nimport type * as Polymorphic from '../../utils/polymorphic'\nimport { toMediaQueries, type ResponsiveProp } from '../../styles/responsive'\n\nimport { getSizeStyles, getVariantStyles } from './icon-button-styles'\n\nconst roundToTwoDecimals = (num: number) => Math.round(num * 100) / 100\n\nconst ICON_SIZE_MAP = {\n xs: 16,\n sm: 20,\n md: 20,\n} as const\n\ninterface StyledButtonProps {\n size: ResponsiveProp<IconButtonSize>\n variant: IconButtonVariant\n}\nconst StyledButton = styled('button', { shouldForwardProp: isPropValid })<StyledButtonProps>(\n ({ theme, size: iconSize, variant }) => ({\n borderRadius: theme.radii.full,\n display: 'inline-flex',\n justifyContent: 'center',\n alignItems: 'center',\n position: 'relative',\n flexShrink: 0,\n WebkitTouchCallout: 'none',\n WebkitTapHighlightColor: 'transparent',\n userSelect: 'none',\n transitionProperty: 'box-shadow, transform, opacity, background-color, color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n\n '&[disabled]': {\n opacity: 0.4,\n },\n '&:not([disabled]):active': {\n transform: 'scale(0.97)',\n },\n ...toMediaQueries(iconSize, (currentValue) => {\n const iconSize = ICON_SIZE_MAP[currentValue]\n return {\n ...getSizeStyles(theme)[currentValue],\n '> svg': {\n width: iconSize,\n height: iconSize,\n // Always set a minimum stroke width of 2px.\n // If the size is less than 24px, scale the stroke width up\n // to compensate for the scaling down of the icon.\n ...(iconSize < 24 && {\n strokeWidth: roundToTwoDecimals((24 / iconSize) * 2),\n }),\n },\n }\n }),\n ...getVariantStyles(theme)[variant],\n }),\n)\n\ntype IconButtonSize = VariantProps<typeof getSizeStyles>\ntype IconButtonVariant = VariantProps<typeof getVariantStyles>\ninterface IconButtonOptions {\n icon: ElementType<IconProps>\n /**\n * A visually hidden label read by screen readers.\n *\n */\n label: string\n /**\n * Defines the size of the button\n */\n size?: ResponsiveProp<IconButtonSize>\n /**\n * Sets the style variant of the button\n */\n variant?: IconButtonVariant\n /**\n * If `true` the button will be disabled\n */\n isDisabled?: boolean\n}\n\ntype IconButtonComponent = Polymorphic.ForwardRefComponent<'button', IconButtonOptions>\nexport type IconButtonProps = Polymorphic.PropsOf<IconButtonComponent>\n\nexport const IconButton = forwardRef((props, forwardedRef) => {\n const {\n as,\n icon: Icon,\n label,\n 'aria-label': ariaLabel = label,\n variant = 'white',\n size = 'md',\n // Only default the `type` if not using the as prop\n type = as ? undefined : 'button',\n isDisabled = false,\n ...restProps\n } = props\n return (\n <StyledButton\n as={as}\n ref={forwardedRef}\n aria-label={ariaLabel}\n variant={variant}\n size={size}\n disabled={isDisabled}\n type={type}\n {...restProps}\n >\n <Icon aria-hidden=\"true\" color=\"currentColor\" />\n </StyledButton>\n )\n}) as IconButtonComponent\n","import { pxToRem, createStyleVariants } from '../../styles'\n\n// Can't use :enabled cause it doesn't work when rendered as a link\nconst NOT_DISABLED = ':not([disabled])'\n\nexport const getSizeStyles = createStyleVariants(() => ({\n xs: {\n width: pxToRem(32),\n height: pxToRem(32),\n },\n sm: {\n width: pxToRem(40),\n height: pxToRem(40),\n },\n md: {\n width: pxToRem(48),\n height: pxToRem(48),\n },\n}))\n\n// These are the exact same styles as the `Button` variant styles.\n// Maybe we can share them somehow in the future but there isn't any good abstraction yet\n// so I'll keep some duplicated styles here for now. -- Hugo (2022-07-03)\nexport const getVariantStyles = createStyleVariants(({ colors }) => ({\n primary: {\n background: colors.bg.brandPrimary,\n color: colors.text.onBrandPrimary,\n [NOT_DISABLED]: {\n // This prevents hover styles from displaying instead\n // of active styles on touch devices\n '@media(hover: hover)': {\n ':hover': {\n background: colors.bg.brandPrimaryHover,\n },\n },\n ':active': {\n background: colors.bg.brandPrimaryActive,\n },\n },\n },\n secondary: {\n background: colors.bg.brandSecondary,\n color: colors.text.onBrandSecondary,\n [NOT_DISABLED]: {\n '@media(hover: hover)': {\n ':hover': {\n background: colors.bg.brandSecondaryHover,\n },\n },\n ':active': {\n background: colors.bg.brandSecondaryActive,\n },\n },\n },\n tertiary: {\n background: colors.bg.brandTertiary,\n color: colors.text.onBrandTertiary,\n [NOT_DISABLED]: {\n '@media(hover: hover)': {\n ':hover': {\n background: colors.bg.brandTertiaryHover,\n },\n },\n ':active': {\n background: colors.bg.brandTertiaryActive,\n },\n },\n },\n\n ghost: {\n color: colors.text.default,\n [NOT_DISABLED]: {\n '@media(hover: hover)': {\n ':hover': {\n background: colors.core.blackAlpha5,\n },\n },\n ':active': {\n background: colors.core.blackAlpha10,\n },\n },\n },\n white: {\n background: colors.bg.default,\n color: colors.text.default,\n [NOT_DISABLED]: {\n '@media(hover: hover)': {\n ':hover': {\n background: colors.core.gray10,\n },\n },\n ':active': {\n background: colors.core.gray20,\n },\n },\n },\n}))\n","import styled from '@emotion/styled'\nimport { forwardRef, useRef, useState } from 'react'\n\nimport { useFormField, useSafeLayoutEffect } from '../../hooks'\nimport { useTranslation } from '../../i18n/use-translation'\nimport { dataAttr } from '../../utils/html-attributes'\nimport type { HTMLQdsProps } from '../../types'\nimport { Label } from '../label'\nimport type { InputBaseOptions } from '../primitives/input-base'\nimport { InputBase } from '../primitives/input-base'\nimport { ErrorMessage, FormField, HelperText } from '../_internal'\n\ninterface InputContainerProps {\n isPositionRelative: boolean\n}\nconst InputContainer = styled.div<InputContainerProps>(({ isPositionRelative }) => ({\n width: '100%',\n position: isPositionRelative ? 'relative' : undefined,\n}))\n\nconst OptionalText = styled.span(({ theme }) => ({\n ...theme.typography.body.sm,\n color: theme.colors.text.subtle,\n}))\n\nconst Suffix = styled.div(({ theme }) => ({\n ...theme.typography.body.md,\n position: 'absolute',\n height: '100%',\n top: 0,\n right: 0,\n display: 'flex',\n alignItems: 'center',\n paddingLeft: theme.spacing['4x'],\n paddingRight: theme.spacing['4x'],\n pointerEvents: 'none',\n '&[data-disabled]': {\n opacity: 0.4,\n },\n}))\n\ninterface TextFieldOptions extends InputBaseOptions {\n /**\n * The label for the input\n */\n label: string\n /**\n * The error message to display if `isInvalid` is `true`\n */\n errorMessage?: string\n /**\n * If `true`, the input will display an optional indicator.\n * If the `isRequired` prop is also `true`, this prop will be ignored.\n */\n isOptional?: boolean\n /**\n * Text that provides additional guidance to the user\n */\n helperText?: string\n /**\n * Suffixed text to display after the input.\n * This is useful for e.g. displaying units of measurement.\n */\n suffix?: string\n}\n\ntype OmittedProps = 'children' | 'readOnly' | 'size'\n\nexport interface TextFieldProps\n extends Omit<HTMLQdsProps<'input'>, OmittedProps>,\n TextFieldOptions {}\n\nexport const TextField = forwardRef<HTMLInputElement, TextFieldProps>((props, forwardedRef) => {\n const {\n label,\n isInvalid,\n isDisabled,\n isRequired,\n isOptional: isOptionalProp,\n errorMessage,\n helperText,\n suffix,\n ...restProps\n } = props\n const {\n getLabelProps,\n getFieldProps: getInputProps,\n getErrorMessageProps,\n getHelperTextProps,\n } = useFormField<'input'>(props)\n\n const [suffixWidth, setSuffixWidth] = useState<number | undefined>(undefined)\n const suffixRef = useRef<HTMLDivElement>(null)\n const { t } = useTranslation()\n\n useSafeLayoutEffect(() => {\n setSuffixWidth(suffixRef.current?.offsetWidth)\n }, [suffix])\n\n const helperTextElement = helperText ? (\n <HelperText {...getHelperTextProps()}>{helperText}</HelperText>\n ) : null\n\n const shouldShowErrorMessage = isInvalid && errorMessage\n const errorMessageElement = shouldShowErrorMessage ? (\n <ErrorMessage {...getErrorMessageProps()}>{errorMessage}</ErrorMessage>\n ) : null\n\n const hasSuffix = Boolean(suffix)\n\n const isOptional = Boolean(!isRequired && isOptionalProp)\n\n return (\n <FormField>\n <Label {...getLabelProps()}>\n {label}\n {isOptional && <OptionalText>{` (${t('optional')})`}</OptionalText>}\n </Label>\n\n <InputContainer isPositionRelative={hasSuffix}>\n <InputBase\n ref={forwardedRef}\n {...getInputProps({ ...restProps, style: { paddingRight: suffixWidth } })}\n />\n {hasSuffix && (\n <Suffix ref={suffixRef} aria-hidden=\"true\" data-disabled={dataAttr(isDisabled)}>\n {suffix}\n </Suffix>\n )}\n </InputContainer>\n {errorMessageElement || helperTextElement}\n </FormField>\n )\n})\n","const SUPPORTED_LANGUAGE_CODES = ['en', 'sv', 'fi', 'fr', 'nb'] as const\n\nexport type LanguageCode = (typeof SUPPORTED_LANGUAGE_CODES)[number]\n\nexport interface Resource {\n close: string\n optional: string\n}\nconst en: Resource = {\n close: 'Close',\n optional: 'Optional',\n}\n\nconst sv: Resource = {\n close: 'Stäng',\n optional: 'Valfritt',\n}\n\nconst fi: Resource = {\n close: 'Sulje',\n optional: 'Valinnainen',\n}\n\nconst fr: Resource = {\n close: 'Fermer',\n optional: 'Facultatif',\n}\n\nconst nb: Resource = {\n close: 'Steng',\n optional: 'Valgfri',\n}\n\nexport const locales: Record<LanguageCode, Resource> = {\n en,\n sv,\n fi,\n fr,\n nb,\n}\n","import { useLocale } from './locale-context'\nimport type { Resource } from './locales'\nimport { locales } from './locales'\n\ntype I18nKey = keyof Resource\n\nexport function useTranslation() {\n const { currentLanguage } = useLocale()\n\n const t = (key: I18nKey) => locales[currentLanguage][key]\n\n return { t }\n}\n","import styled from '@emotion/styled'\nimport isPropValid from '@emotion/is-prop-valid'\nimport { forwardRef } from 'react'\n\nimport type { VariantProps } from '../../styles'\nimport { createStyleVariants } from '../../styles'\nimport type * as Polymorphic from '../../utils/polymorphic'\nimport type { Theme } from '../../theme'\nimport type { ResponsiveProp } from '../../styles/responsive'\nimport { toMediaQueries } from '../../styles/responsive'\n\nconst getSizeStyles = createStyleVariants(({ typography }) => ({\n sm: {\n ...typography.label.sm,\n },\n md: {\n ...typography.label.md,\n },\n}))\n\ntype LabelSize = VariantProps<typeof getSizeStyles>\ntype LabelColor = keyof Theme['colors']['text']\n\ninterface StyledLabelProps {\n size: ResponsiveProp<LabelSize>\n color: LabelColor\n}\nconst StyledLabel = styled('label', { shouldForwardProp: isPropValid })<StyledLabelProps>(\n ({ theme, color, size }) => ({\n display: 'block',\n color: theme.colors.text[color],\n cursor: 'default',\n WebkitTouchCallout: 'none',\n WebkitTapHighlightColor: 'transparent',\n ...toMediaQueries(size, (currentValue) => getSizeStyles(theme)[currentValue]),\n '&[data-disabled]': {\n opacity: 0.4,\n },\n }),\n)\n\ninterface LabelOptions {\n /**\n * Size of the label\n */\n size?: ResponsiveProp<LabelSize>\n /**\n * Sets the color of the label\n * @default 'default'\n */\n color?: LabelColor\n}\n\ntype LabelComponent = Polymorphic.ForwardRefComponent<'label', LabelOptions>\nexport type LabelProps = Polymorphic.PropsOf<LabelComponent>\n\nexport const Label = forwardRef((props, forwardedRef) => {\n const { as, children, color = 'default', size = 'md', onMouseDown, ...restProps } = props\n return (\n <StyledLabel\n as={as}\n ref={forwardedRef}\n {...restProps}\n size={size}\n color={color}\n onMouseDown={(event) => {\n onMouseDown && onMouseDown(event)\n // prevent text selection when double clicking label\n if (!event.defaultPrevented && event.detail > 1) {\n event.preventDefault()\n }\n }}\n >\n {children}\n </StyledLabel>\n )\n}) as LabelComponent\n","import styled from '@emotion/styled'\nimport { forwardRef } from 'react'\n\nimport { getFormFieldBaseStyles } from '../../../styles'\nimport type { HTMLQdsProps } from '../../../types'\nimport { ariaAttr } from '../../../utils/html-attributes'\n\nconst StyledInput = styled('input')(({ theme }) => ({\n ...getFormFieldBaseStyles(theme),\n height: 48,\n}))\n\nexport interface InputBaseOptions {\n /**\n * If `true`, the input will be invalid\n */\n isInvalid?: boolean\n /**\n * If `true`, the input will be disabled\n */\n isDisabled?: boolean\n /**\n * If `true` the input will be required\n */\n isRequired?: boolean\n}\n\ntype OmittedProps = 'children' | 'readOnly' | 'size' | 'disabled' | 'required'\nexport interface InputBaseProps\n extends Omit<HTMLQdsProps<'input'>, OmittedProps>,\n InputBaseOptions {}\n\nexport const InputBase = forwardRef<HTMLInputElement, InputBaseProps>((props, forwardedRef) => {\n const { isInvalid, isDisabled, isRequired, ...restProps } = props\n\n return (\n <StyledInput\n ref={forwardedRef}\n aria-invalid={ariaAttr(isInvalid)}\n disabled={isDisabled}\n required={isRequired}\n {...restProps}\n />\n )\n})\n","import { forwardRef } from 'react'\nimport styled from '@emotion/styled'\nimport isPropValid from '@emotion/is-prop-valid'\n\nimport type * as Polymorphic from '../../utils/polymorphic'\n\nconst StyledLink = styled('a', { shouldForwardProp: isPropValid })(({ theme }) => ({\n WebkitTouchCallout: 'none',\n WebkitTapHighlightColor: 'transparent',\n ...theme.typography.body.md,\n WebkitAppearance: 'none',\n transitionProperty: 'box-shadow, transform, opacity, background-color, color',\n transitionDuration: '150ms',\n transitionTimingFunction: 'ease',\n flexShrink: 0,\n fontSize: 'inherit',\n color: 'inherit',\n textDecoration: 'underline',\n}))\n\ninterface LinkOptions {\n /**\n * The URL to link to.\n */\n href?: string\n /**\n * If `true`, the link will open in new tab\n */\n isExternal?: boolean\n}\n\ntype LinkComponent = Polymorphic.ForwardRefComponent<'a', LinkOptions>\nexport type LinkProps = Polymorphic.PropsOf<LinkComponent>\n\nexport const Link = forwardRef((props, forwardedRef) => {\n const { children, href, isExternal = false, ...restProps } = props\n const externalProps = isExternal ? { target: '_blank', rel: 'noopener noreferrer' } : {}\n return (\n <StyledLink ref={forwardedRef} href={href} {...externalProps} {...restProps}>\n {children}\n </StyledLink>\n )\n}) as LinkComponent\n","import styled from '@emotion/styled'\nimport isPropValid from '@emotion/is-prop-valid'\nimport { forwardRef } from 'react'\n\nimport type { VariantProps } from '../../styles'\nimport { createStyleVariants } from '../../styles'\nimport type { Theme } from '../../theme'\nimport type * as Polymorphic from '../../utils/polymorphic'\nimport { toMediaQueries, type ResponsiveProp } from '../../styles/responsive'\n\nconst getSizeStyles = createStyleVariants(({ typography }) => ({\n xs: typography.body.xs,\n sm: typography.body.sm,\n md: typography.body.md,\n lg: typography.body.lg,\n xl: typography.body.xl,\n}))\n\ntype ParagraphSize = VariantProps<typeof getSizeStyles>\ntype ParagraphColor = keyof Theme['colors']['text']\n\ninterface StyledParagraphProps {\n size: ResponsiveProp<ParagraphSize>\n color: ParagraphColor\n numberOfLines?: number\n textAlign?: 'left' | 'center' | 'right'\n}\n\nconst StyledParagraph = styled('p', { shouldForwardProp: isPropValid })<StyledParagraphProps>(\n ({ theme, size, color, numberOfLines, textAlign }) => ({\n margin: 0,\n ...toMediaQueries(size, (currentValue) => getSizeStyles(theme)[currentValue]),\n color: theme.colors.text[color],\n textAlign,\n overflowWrap: 'break-word',\n wordWrap: 'break-word',\n\n ...(numberOfLines && {\n display: '-webkit-box',\n WebkitBoxOrient: 'vertical',\n WebkitLineClamp: numberOfLines,\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n }),\n }),\n)\n\ninterface ParagraphOptions {\n /**\n * Sets the visual size of the text\n * @default 'md'\n */\n size?: ResponsiveProp<ParagraphSize>\n /**\n * Sets the color of the text\n * @default 'normal'\n */\n color?: ParagraphColor\n /**\n * Truncates the text after a specific number of lines\n */\n numberOfLines?: number\n /**\n * Alignment of the paragraph\n * @default 'left'\n */\n textAlign?: 'left' | 'center' | 'right'\n}\n\ntype ParagraphComponent = Polymorphic.ForwardRefComponent<'p', ParagraphOptions>\nexport type ParagraphProps = Polymorphic.PropsOf<ParagraphComponent>\n\nexport const Paragraph = forwardRef((props, forwardedRef) => {\n const { children, size = 'md', color = 'default', textAlign = 'left', ...rest } = props\n return (\n <StyledParagraph ref={forwardedRef} size={size} color={color} textAlign={textAlign} {...rest}>\n {children}\n </StyledParagraph>\n )\n}) as ParagraphComponent\n","import styled from '@emotion/styled'\nimport { forwardRef } from 'react'\n\nimport { getFormFieldBaseStyles } from '../../../styles'\nimport type { HTMLQdsProps } from '../../../types'\nimport { ChevronDownIcon } from '../../icon'\n\nexport interface SelectBaseOptions {\n /**\n * The placeholder for the select. We render an `<option/>` element that has\n * empty value.\n *\n * ```jsx\n * <option value=\"\">{placeholder}</option>\n * ```\n */\n placeholder?: string\n /**\n * If `true`, the select will be invalid\n */\n isInvalid?: boolean\n /**\n * If `true`, the select will be disabled\n */\n isDisabled?: boolean\n /**\n * If `true` the select will be required\n */\n isRequired?: boolean\n}\n\nconst SelectWrapper = styled.div({\n width: '100%',\n height: 'fit-content',\n position: 'relative',\n})\nconst SelectIconWrapper = styled.div({\n pointerEvents: 'none',\n position: 'absolute',\n height: '100%',\n width: 48,\n right: 0,\n top: 0,\n color: 'currentcolor',\n display: 'inline-flex',\n justifyContent: 'center',\n alignItems: 'center',\n '&[data-disabled]': {\n opacity: 0.4,\n },\n})\n\nconst StyledSelect = styled.select(({ theme }) => ({\n ...getFormFieldBaseStyles(theme),\n height: 48,\n // Ensure the text doesn't end up behind the icon\n paddingRight: 40,\n}))\n\ntype OmittedProps = 'readOnly' | 'size' | 'multiple' | 'disabled' | 'required'\n\ninterface SelectBaseProps extends Omit<HTMLQdsProps<'select'>, OmittedProps>, SelectBaseOptions {}\n\nexport const SelectBase = forwardRef<HTMLSelectElement, SelectBaseProps>((props, forwardedRef) => {\n const { placeholder, children, isInvalid, isDisabled, isRequired, ...restProps } = props\n\n return (\n <SelectWrapper>\n <StyledSelect\n ref={forwardedRef}\n aria-invalid={isInvalid ? true : undefined}\n disabled={isDisabled}\n required={isRequired}\n {...restProps}\n >\n {placeholder && <option value=\"\">{placeholder}</option>}\n {children}\n </StyledSelect>\n <SelectIconWrapper data-disabled={isDisabled ? '' : undefined}>\n <ChevronDownIcon role=\"presentation\" aria-hidden=\"true\" size={16} />\n </SelectIconWrapper>\n </SelectWrapper>\n )\n})\n","import styled from '@emotion/styled'\nimport { forwardRef } from 'react'\n\nimport { getFormFieldBaseStyles } from '../../../styles'\nimport type { HTMLQdsProps } from '../../../types'\nimport { ariaAttr } from '../../../utils/html-attributes'\n\nconst StyledTextarea = styled.textarea<{ resize: ResizeProp; minRows: MinRowsProp }>(\n ({ theme, resize, minRows }) => {\n const baseStyles = getFormFieldBaseStyles(theme)\n const paddingVertical = theme.spacing['3x']\n const minHeight = `calc(${baseStyles.lineHeight} * ${minRows} + ${paddingVertical} * 2 + 2px)` // + 2px for border\n\n return {\n ...baseStyles,\n paddingTop: paddingVertical,\n paddingBottom: paddingVertical,\n scrollPaddingBlockEnd: paddingVertical,\n resize,\n minHeight,\n }\n },\n)\n\ntype ResizeProp = 'none' | 'both' | 'horizontal' | 'vertical'\ntype MinRowsProp = number\nexport interface TextareaBaseOptions {\n /**\n * If `true`, the textarea will be invalid\n */\n isInvalid?: boolean\n /**\n * If `true`, the textarea will be disabled\n */\n isDisabled?: boolean\n /**\n * If `true` the textarea will be required\n */\n isRequired?: boolean\n /**\n * The resize behavior of the textarea\n *\n * @default 'vertical'\n */\n resize?: ResizeProp\n /**\n * The minimum number of rows to display without requiring scrolling or resizing.\n * To disabled resizing use the `resize` prop.\n *\n * @default 3\n */\n minRows?: MinRowsProp\n}\n\ntype OmittedProps = 'children' | 'readOnly' | 'size' | 'disabled' | 'required' | 'rows' | 'cols'\nexport interface TextareaBaseProps\n extends Omit<HTMLQdsProps<'textarea'>, OmittedProps>,\n TextareaBaseOptions {}\n\nexport const TextareaBase = forwardRef<HTMLTextAreaElement, TextareaBaseProps>(\n (props, forwardedRef) => {\n const {\n isInvalid,\n isDisabled,\n isRequired,\n resize = 'vertical',\n minRows = 3,\n ...restProps\n } = props\n\n return (\n <StyledTextarea\n ref={forwardedRef}\n aria-invalid={ariaAttr(isInvalid)}\n disabled={isDisabled}\n required={isRequired}\n resize={resize}\n minRows={minRows}\n {...restProps}\n />\n )\n },\n)\n","import { forwardRef, useCallback, useState } from 'react'\nimport * as RadioGroupPrimitive from '@radix-ui/react-radio-group'\nimport styled from '@emotion/styled'\n\nimport { ErrorMessage } from '../_internal'\nimport { useStableId } from '../../hooks'\nimport { ariaAttr } from '../../utils/html-attributes'\n\nimport { RadioGroupProvider } from './radio-group-context'\nimport { RadioCard } from './radio-card'\nimport type { RadioCardProps } from './radio-card'\nimport type { RadioButtonProps } from './radio-button'\nimport { RadioGroupLabel } from './radio-group-label'\nimport type { RadioGroupLabelProps } from './radio-group-label'\nimport { RadioButton } from './radio-button'\n\nconst StyledRadioGroupRoot = styled(RadioGroupPrimitive.Root)(({ theme }) => ({\n width: '100%',\n display: 'flex',\n flexDirection: 'column',\n gap: theme.spacing['3x'],\n}))\n\ninterface RadioGroupOptions {\n /**\n * The value of the radio item that should be checked when initially rendered.\n * Use when you do not need to control the state of the radio items.\n */\n defaultValue?: string\n /**\n * The controlled value of the radio item to check.\n * Should be used in conjunction with `onValueChange`.\n */\n value?: string\n /**\n * Event handler called when the value changes.\n */\n onValueChange?: (value: string) => void\n /**\n * The name of the group. Submitted with its owning form as part of a name/value pair.\n */\n name?: string\n /**\n * If `true` all child radio items will be disabled.\n * @default false\n */\n isDisabled?: boolean\n /**\n * If `true` the user must check a radio item before the owning form can be submitted.\n * @default false\n */\n isRequired?: boolean\n /**\n * If `true` the radio group will be invalid.\n * @default false\n */\n isInvalid?: boolean\n /**\n * The error message to display if `isInvalid` is `true`\n */\n errorMessage?: string\n}\n\nexport interface RadioGroupProps\n // We omit some props and define them ourselves so that we can have\n // JS doc descriptions for them.\n extends Omit<RadioGroupPrimitive.RadioGroupProps, 'asChild' | keyof RadioGroupOptions>,\n RadioGroupOptions {}\n\nconst RadioGroupRoot = forwardRef<HTMLDivElement, RadioGroupProps>((props, forwardedRef) => {\n const {\n children,\n id: idProp,\n disabled: hasHtmlDisabledAttr,\n isDisabled: isDisabledProp,\n required: hasHtmlRequiredAttr,\n isRequired: isRequiredProp,\n 'aria-labelledby': ariaLabelledByProp,\n 'aria-describedby': ariaDescribedByProp,\n isInvalid,\n errorMessage,\n ...restProps\n } = props\n\n const isDisabled = isDisabledProp ?? hasHtmlDisabledAttr\n const isRequired = isRequiredProp ?? hasHtmlRequiredAttr\n\n const id = useStableId(idProp)\n\n const hasError = isInvalid && errorMessage\n const errorMessageId = hasError ? `${id}-error` : undefined\n\n const [labelElement, setLabelElement] = useState<HTMLElement | null>(null)\n\n const labelRefCallback = useCallback((node: HTMLElement | null) => setLabelElement(node), [])\n const labelId = labelElement?.id\n\n const errorMessageElement = hasError ? (\n <ErrorMessage id={errorMessageId} role=\"alert\" aria-live=\"polite\">\n {errorMessage}\n </ErrorMessage>\n ) : null\n\n const ariaLabelledBy = [labelId, ariaLabelledByProp].filter(Boolean).join(' ') || undefined\n // Error message should be described first in all scenarios.\n const ariaDescribedBy =\n [errorMessageId, ariaDescribedByProp].filter(Boolean).join(' ') || undefined\n\n return (\n <RadioGroupProvider\n value={{\n labelRefCallback,\n isDisabled,\n errorMessageId,\n }}\n >\n <StyledRadioGroupRoot\n ref={forwardedRef}\n id={id}\n disabled={isDisabled}\n required={isRequired}\n aria-invalid={ariaAttr(isInvalid)}\n aria-labelledby={ariaLabelledBy}\n aria-describedby={ariaDescribedBy}\n {...restProps}\n >\n {children}\n {errorMessageElement}\n </StyledRadioGroupRoot>\n </RadioGroupProvider>\n )\n})\n\nexport const RadioGroup = Object.assign(RadioGroupRoot, {\n Card: RadioCard,\n Button: RadioButton,\n Label: RadioGroupLabel,\n})\n\nexport type { RadioGroupLabelProps, RadioCardProps, RadioButtonProps }\n","import { createContext, useContext } from 'react'\n\ninterface RadioGroupContextValue {\n labelRefCallback: (node: HTMLElement | null) => void\n isDisabled: boolean | undefined\n errorMessageId?: string\n}\nconst RadioGroupContext = createContext<RadioGroupContextValue | null>(null)\n\ninterface RadioGroupProviderProps {\n value: RadioGroupContextValue\n children: React.ReactNode\n}\nexport function RadioGroupProvider({ value, children }: RadioGroupProviderProps) {\n return <RadioGroupContext.Provider value={value}>{children}</RadioGroupContext.Provider>\n}\n\ninterface UseRadioGroupContextProps {\n consumerName: string\n}\n\nexport const useRadioGroupContext = ({ consumerName }: UseRadioGroupContextProps) => {\n const context = useContext(RadioGroupContext)\n if (!context) {\n throw new Error(`\\`${consumerName}\\` must be used within \\`RadioGroup\\``)\n }\n return context\n}\n","import styled from '@emotion/styled'\nimport * as RadioGroupPrimitive from '@radix-ui/react-radio-group'\nimport { forwardRef, useState } from 'react'\n\nimport { useStableId } from '../../../hooks'\nimport { pxToRem } from '../../../styles'\nimport { dataAttr } from '../../../utils/html-attributes'\nimport { HelperText } from '../../_internal'\nimport { RadioIndicator } from '../radio-indicator'\nimport { useRadioGroupContext } from '../radio-group-context'\n\nconst RadioItem = styled(RadioGroupPrimitive.Item)(({ theme }) => ({\n width: '100%',\n textAlign: 'left',\n background: theme.colors.bg.default,\n paddingLeft: theme.spacing['5x'],\n paddingRight: theme.spacing['5x'],\n // Odd padding value, but without it the text is not vertically centered.\n // Logic is (height - line height - border top - border bottom) / 2\n // So (56 - 20 - 1 - 1) / 2 = 17\n paddingTop: pxToRem(17),\n paddingBottom: pxToRem(17),\n minHeight: pxToRem(56),\n justifyContent: 'center',\n border: '1px solid',\n borderColor: theme.colors.border.default,\n borderRadius: theme.radii.md,\n display: 'grid',\n gridTemplateColumns: `1fr min-content`,\n alignItems: 'start',\n // Needed to align the content to the top when the cards are\n // places in a grid with varying intrinsic heights\n alignContent: 'start',\n columnGap: theme.spacing['3x'],\n rowGap: theme.spacing['1x'],\n boxShadow: 'none',\n transitionProperty: 'background, border-color, box-shadow, transform, outline',\n transitionDuration: '120ms',\n transitionTimingFunction: 'ease-out',\n '&[data-state=\"checked\"]': {\n borderColor: theme.colors.border.defaultSelected,\n boxShadow: `inset 0 0 0 1px ${theme.colors.border.defaultSelected}`,\n background: theme.colors.bg.inset,\n ':active': {\n transform: 'scale(0.995)',\n },\n },\n '&[data-state=\"unchecked\"]': {\n '@media(hover: hover)': {\n ':hover': {\n borderColor: theme.colors.border.defaultHover,\n background: theme.colors.bg.inset,\n },\n },\n ':active': {\n transform: 'scale(0.98)',\n },\n },\n outlineOffset: 0,\n outline: '0 solid transparent',\n ':focus-visible': {\n outlineColor: theme.colors.border.defaultSelected,\n outlineWidth: 2,\n outlineStyle: 'solid',\n outlineOffset: 3,\n },\n '&[data-disabled], &:disabled, &[disabled]': {\n opacity: 0.4,\n '&[data-state=\"unchecked\"]': {\n ':hover': {\n background: theme.colors.bg.default,\n borderColor: theme.colors.border.default,\n },\n },\n ':active': {\n transform: 'none',\n },\n },\n\n WebkitTouchCallout: 'none',\n WebkitTapHighlightColor: 'transparent',\n}))\n\ninterface RadioCardOptions {\n /**\n * The label for the radio card\n */\n label: string\n /**\n * Text that provides additional guidance to the user\n */\n helperText?: string\n /**\n * If `true` the user must check the radio item before the owning form can be submitted.\n * @default false\n */\n isRequired?: boolean\n /**\n * If `true` it prevents the user from interacting with the radio item.\n * @default false\n */\n isDisabled?: boolean\n}\n\nexport interface RadioCardProps\n extends Omit<RadioGroupPrimitive.RadioGroupItemProps, 'asChild' | keyof RadioCardOptions>,\n RadioCardOptions {}\n\nconst Label = styled.span(({ theme }) => ({\n ...theme.typography.label.md,\n}))\n\nexport const RadioCard = forwardRef<HTMLButtonElement, RadioCardProps>((props, forwardedRef) => {\n const {\n label,\n helperText,\n disabled: hasHtmlDisabledAttr,\n isDisabled: isDisabledProp,\n required: hasHtmlRequiredAttr,\n isRequired: isRequiredProp,\n id: idProp,\n 'aria-describedby': ariaDescribedByProp,\n onMouseEnter,\n onMouseLeave,\n ...rest\n } = props\n const [isHovered, setIsHovered] = useState(false)\n\n const { errorMessageId } = useRadioGroupContext({ consumerName: 'RadioCard' })\n const id = useStableId(idProp)\n const labelId = `${id}-label`\n const hasHelperText = Boolean(helperText)\n const helperTextId = hasHelperText ? `${id}-helper-text` : undefined\n\n const ariaDescribedBy =\n [errorMessageId, helperTextId, ariaDescribedByProp].filter(Boolean).join(' ') || undefined\n\n const helperTextElement = helperText ? (\n <HelperText id={helperTextId}>{helperText}</HelperText>\n ) : null\n\n const isDisabled = isDisabledProp ?? hasHtmlDisabledAttr\n const isRequired = isRequiredProp ?? hasHtmlRequiredAttr\n\n return (\n <RadioItem\n ref={forwardedRef}\n disabled={isDisabled}\n // For some reason if we pass e.g. `required={undefined}` it will override\n // the `required` attribute from the `RadioGroup`. Seems to be something with\n // how Radix handles the state internally.\n {...(isRequired && { required: true })}\n aria-labelledby={labelId}\n aria-describedby={ariaDescribedBy}\n onMouseEnter={(ev) => {\n setIsHovered(true)\n onMouseEnter?.(ev)\n }}\n onMouseLeave={(ev) => {\n setIsHovered(false)\n onMouseLeave?.(ev)\n }}\n {...rest}\n >\n <Label id={labelId}>{label}</Label>\n <RadioIndicator data-hover={dataAttr(isHovered)} />\n {helperTextElement}\n </RadioItem>\n )\n})\n","import styled from '@emotion/styled'\nimport * as RadioGroupPrimitive from '@radix-ui/react-radio-group'\nimport { forwardRef } from 'react'\n\nimport { pxToRem } from '../../styles'\n\nconst StyledRadioIndicator = styled(RadioGroupPrimitive.Indicator)(({ theme }) => ({\n background: theme.colors.bg.default,\n border: '2px solid',\n borderColor: theme.colors.border.strong,\n width: pxToRem(20),\n height: pxToRem(20),\n flexShrink: 0,\n borderRadius: theme.radii.full,\n transitionProperty: 'background',\n transitionDuration: '120ms',\n transitionTimingFunction: 'ease-out',\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n '&::after': {\n content: '\"\"',\n display: 'block',\n width: pxToRem(10),\n height: pxToRem(10),\n borderRadius: theme.radii.full,\n background: theme.colors.border.strong,\n transform: 'scale(0.5)',\n opacity: 0,\n transitionProperty: 'transform, opacity',\n transitionDuration: '120ms',\n transitionTimingFunction: 'ease-out',\n transformOrigin: 'center',\n },\n '&[data-state=\"unchecked\"]': {\n '@media(hover: hover)': {\n '&:not(&[data-disabled])[data-hover]::after': {\n transform: 'scale(0.8)', // Resolves to 8px\n opacity: 1,\n },\n },\n },\n\n '&[data-state=\"checked\"]': {\n background: theme.colors.border.strong,\n '&::after': {\n opacity: 1,\n transform: 'scale(1)',\n background: theme.colors.border.defaultSelected,\n },\n },\n}))\n\ntype RadioIndicatorProps = Omit<\n RadioGroupPrimitive.RadioGroupIndicatorProps,\n 'asChild' | 'forceMount'\n>\n/**\n * Styled Radix `RadioIndicator` component.\n * @see Docs https://www.radix-ui.com/primitives/docs/components/radio-group#indicator\n * @internal Not to be used outside the library.\n */\nexport const RadioIndicator = forwardRef<HTMLSpanElement, RadioIndicatorProps>(\n (props, forwardedRef) => <StyledRadioIndicator ref={forwardedRef} forceMount {...props} />,\n)\n","import styled from '@emotion/styled'\nimport { forwardRef } from 'react'\n\nimport { useStableId } from '../../hooks'\nimport { mergeRefs } from '../../utils/merge-refs'\nimport type { HTMLQdsProps } from '../../types'\nimport { dataAttr } from '../../utils/html-attributes'\n\nimport { useRadioGroupContext } from './radio-group-context'\n\nconst Label = styled.span(({ theme }) => ({\n ...theme.typography.label.md,\n '&[data-disabled]': {\n opacity: 0.4,\n },\n}))\n\nexport type RadioGroupLabelProps = HTMLQdsProps<'span'>\n\nexport const RadioGroupLabel = forwardRef<HTMLSpanElement, RadioGroupLabelProps>(\n (props, forwardedRef) => {\n const { id: idProp, ...restProps } = props\n const id = useStableId(idProp)\n const { labelRefCallback, isDisabled } = useRadioGroupContext({\n consumerName: 'RadioGroupLabel',\n })\n\n return (\n <Label\n ref={mergeRefs(labelRefCallback, forwardedRef)}\n id={id}\n data-disabled={dataAttr(isDisabled)}\n {...restProps}\n />\n )\n },\n)\n","import type { MutableRefObject, RefCallback } from 'react'\n\nimport type { LegitimateAny } from '../types'\n\ntype ReactRef<T> = RefCallback<T> | MutableRefObject<T>\ntype Maybe<T> = T | null | undefined\n\nfunction assignRef<T = LegitimateAny>(ref: Maybe<ReactRef<T>>, value: T) {\n // eslint-disable-next-line eqeqeq\n if (ref == null) return\n\n if (typeof ref === 'function') {\n ref(value)\n return\n }\n\n ref.current = value\n}\n\nexport const mergeRefs = <T>(...refs: Maybe<ReactRef<T>>[]) => {\n return (node: T | null) => {\n refs.forEach((ref) => assignRef(ref, node))\n }\n}\n","import styled from '@emotion/styled'\nimport { forwardRef, useState } from 'react'\nimport * as RadioGroupPrimitive from '@radix-ui/react-radio-group'\n\nimport { useStableId } from '../../../hooks'\nimport { dataAttr } from '../../../utils/html-attributes'\nimport { useRadioGroupContext } from '../radio-group-context'\nimport { RadioIndicator } from '../radio-indicator'\n\nconst RadioButtonContainer = styled.label(({ theme }) => ({\n display: 'grid',\n gridTemplateColumns: 'auto 1fr',\n alignItems: 'start',\n gap: theme.spacing['3x'],\n cursor: 'pointer',\n WebkitTapHighlightColor: 'transparent',\n WebkitTouchCallout: 'none',\n '&:has([role=\"radio\"][data-disabled])': {\n cursor: 'not-allowed',\n },\n}))\n\nconst RadioItem = styled(RadioGroupPrimitive.Item)(({ theme }) => ({\n borderRadius: theme.radii.full,\n transitionProperty: 'outline',\n transitionDuration: '120ms',\n transitionTimingFunction: 'ease-out',\n outlineOffset: 0,\n outline: '0 solid transparent',\n ':focus-visible': {\n outlineColor: theme.colors.border.defaultSelected,\n outlineWidth: 2,\n outlineStyle: 'solid',\n outlineOffset: 3,\n },\n '&[data-disabled], &:disabled, &[disabled]': {\n opacity: 0.4,\n },\n\n WebkitTouchCallout: 'none',\n WebkitTapHighlightColor: 'transparent',\n}))\n\ninterface RadioButtonOptions {\n /**\n * The label for the radio button\n */\n label: string\n /**\n * If `true` the user must check the radio item before the owning form can be submitted.\n * @default false\n */\n isRequired?: boolean\n /**\n * If `true` it prevents the user from interacting with the radio item.\n * @default false\n */\n isDisabled?: boolean\n}\n\nexport interface RadioButtonProps\n extends Omit<RadioGroupPrimitive.RadioGroupItemProps, 'asChild' | keyof RadioButtonOptions>,\n RadioButtonOptions {}\n\nconst Label = styled.span(({ theme }) => ({\n ...theme.typography.body.md,\n '&[data-disabled]': {\n opacity: 0.4,\n },\n}))\n\nexport const RadioButton = forwardRef<HTMLButtonElement, RadioButtonProps>(\n (props, forwardedRef) => {\n const {\n label,\n disabled: hasHtmlDisabledAttr,\n isDisabled: isDisabledProp,\n required: hasHtmlRequiredAttr,\n isRequired: isRequiredProp,\n id: idProp,\n 'aria-describedby': ariaDescribedByProp,\n onMouseEnter,\n onMouseLeave,\n ...rest\n } = props\n const [isHovered, setIsHovered] = useState(false)\n\n const id = useStableId(idProp)\n const labelId = `${id}-label`\n\n const { errorMessageId, isDisabled: isGroupDisabled } = useRadioGroupContext({\n consumerName: 'RadioButton',\n })\n\n const ariaDescribedBy =\n [errorMessageId, ariaDescribedByProp].filter(Boolean).join(' ') || undefined\n\n const isDisabled = isDisabledProp ?? hasHtmlDisabledAttr ?? isGroupDisabled\n const isRequired = isRequiredProp ?? hasHtmlRequiredAttr\n\n return (\n <RadioButtonContainer>\n <RadioItem\n ref={forwardedRef}\n disabled={isDisabled}\n // For some reason if we pass e.g. `required={undefined}` it will override\n // the `required` attribute from the `RadioGroup`. Seems to be something with\n // how Radix handles the state internally.\n {...(isRequired && { required: true })}\n aria-labelledby={labelId}\n aria-describedby={ariaDescribedBy}\n onMouseEnter={(ev) => {\n setIsHovered(true)\n onMouseEnter?.(ev)\n }}\n onMouseLeave={(ev) => {\n setIsHovered(false)\n onMouseLeave?.(ev)\n }}\n {...rest}\n >\n <RadioIndicator data-hover={dataAttr(isHovered)} />\n </RadioItem>\n <Label\n id={labelId}\n data-disabled={dataAttr(isDisabled)}\n onMouseEnter={() => setIsHovered(true)}\n onMouseLeave={() => setIsHovered(false)}\n onMouseDown={(ev) => {\n // prevent text selection when double clicking label\n if (ev.detail > 1) {\n ev.preventDefault()\n }\n }}\n >\n {label}\n </Label>\n </RadioButtonContainer>\n )\n },\n)\n","import { forwardRef } from 'react'\nimport styled from '@emotion/styled'\n\nimport { useFormField } from '../../hooks'\nimport type { HTMLQdsProps } from '../../types'\nimport { Label } from '../label'\nimport type { SelectBaseOptions } from '../primitives/select-base'\nimport { SelectBase } from '../primitives/select-base'\nimport { ErrorMessage, FormField, HelperText } from '../_internal'\nimport { useTranslation } from '../../i18n/use-translation'\n\nimport type { SelectOptionProps } from './select-option'\nimport { SelectOption } from './select-option'\n\nconst OptionalText = styled.span(({ theme }) => ({\n ...theme.typography.body.sm,\n color: theme.colors.text.subtle,\n}))\n\ninterface SelectOptions extends SelectBaseOptions {\n /**\n * The label for the select field\n */\n label: string\n /**\n * The error message to display if `isInvalid` is `true`\n */\n errorMessage?: string\n /**\n * Text that provides additional guidance to the user\n */\n helperText?: string\n /**\n * If `true`, the select field will display an optional indicator.\n * If the `isRequired` prop is also `true`, this prop will be ignored.\n */\n isOptional?: boolean\n}\n\ntype OmittedProps = 'readOnly' | 'size'\n\nexport interface SelectProps extends Omit<HTMLQdsProps<'select'>, OmittedProps>, SelectOptions {}\n\nconst SelectRoot = forwardRef<HTMLSelectElement, SelectProps>((props, forwardedRef) => {\n const {\n children,\n label,\n isInvalid,\n errorMessage,\n helperText,\n isRequired,\n isOptional: isOptionalProp,\n ...restProps\n } = props\n const {\n getLabelProps,\n getFieldProps: getSelectProps,\n getErrorMessageProps,\n getHelperTextProps,\n } = useFormField(props)\n const { t } = useTranslation()\n\n const helperTextElement = helperText ? (\n <HelperText {...getHelperTextProps()}>{helperText}</HelperText>\n ) : null\n\n const shouldShowErrorMessage = isInvalid && errorMessage\n const errorMessageElement = shouldShowErrorMessage ? (\n <ErrorMessage {...getErrorMessageProps()}>{errorMessage}</ErrorMessage>\n ) : null\n\n const isOptional = Boolean(!isRequired && isOptionalProp)\n\n return (\n <FormField>\n <Label {...getLabelProps()}>\n {label}\n {isOptional && <OptionalText>{` (${t('optional')})`}</OptionalText>}\n </Label>\n <SelectBase ref={forwardedRef} {...getSelectProps(restProps)}>\n {children}\n </SelectBase>\n {errorMessageElement || helperTextElement}\n </FormField>\n )\n})\n\nexport const Select = Object.assign(SelectRoot, { Option: SelectOption })\nexport type { SelectOptionProps }\n","import { forwardRef } from 'react'\n\nimport type { HTMLQdsProps } from '../../types'\n\ninterface SelectOptionOptions {\n isDisabled?: boolean\n}\n\ntype OmittedProps = 'disabled' | 'label'\nexport interface SelectOptionProps\n extends Omit<HTMLQdsProps<'option'>, OmittedProps>,\n SelectOptionOptions {}\n\nexport const SelectOption = forwardRef<HTMLOptionElement, SelectOptionProps>(\n (props, forwardedRef) => {\n const { children, isDisabled, ...restProps } = props\n return (\n <option ref={forwardedRef} disabled={isDisabled} {...restProps}>\n {children}\n </option>\n )\n },\n)\n","import { forwardRef } from 'react'\nimport styled from '@emotion/styled'\n\nimport type { Theme } from '../../theme'\nimport type { HTMLQdsProps } from '../../types'\nimport type { ResponsiveProp } from '../../styles/responsive'\nimport { toMediaQueries } from '../../styles/responsive'\n\ntype Spacing = keyof Theme['spacing']\n\nconst StyledSpan = styled.span<Required<SpacerOptions>>(({ axis, size, theme }) => ({\n display: 'block',\n\n ...toMediaQueries(size, (currentValue) => {\n const resolvedValue = theme.spacing[currentValue]\n return {\n width: axis === 'x' ? resolvedValue : 1,\n minWidth: axis === 'x' ? resolvedValue : 1,\n height: axis === 'y' ? resolvedValue : 1,\n minHeight: axis === 'y' ? resolvedValue : 1,\n }\n }),\n}))\n\ninterface SpacerOptions {\n axis?: 'x' | 'y'\n size: ResponsiveProp<Spacing>\n}\n\nexport interface SpacerProps extends HTMLQdsProps<'span'>, SpacerOptions {}\nexport const Spacer = forwardRef<HTMLSpanElement, SpacerProps>((props, forwardedRef) => {\n const { axis = 'y', size, ...restProps } = props\n\n return <StyledSpan ref={forwardedRef} aria-hidden=\"true\" size={size} axis={axis} {...restProps} />\n})\n","import type { ReactNode } from 'react'\nimport { Fragment, forwardRef } from 'react'\nimport styled from '@emotion/styled'\nimport isPropValid from '@emotion/is-prop-valid'\n\nimport type { Merge } from '../../types'\nimport type { Theme } from '../../theme'\nimport type * as Polymorphic from '../../utils/polymorphic'\nimport type { ResponsiveProp } from '../../styles/responsive'\nimport { toMediaQueries } from '../../styles/responsive'\n\nimport { getValidChildren } from './stack.utils'\nimport type { AlignItems, FlexDirection, JustifyContent, FlexWrap } from './stack.types'\n\ntype StyledStackProps = Merge<\n StackOptions,\n {\n direction: ResponsiveProp<FlexDirection>\n justifyContent: ResponsiveProp<JustifyContent>\n alignItems: ResponsiveProp<AlignItems>\n gap: ResponsiveProp<GapProp>\n }\n>\nconst StyledStack = styled('div', { shouldForwardProp: isPropValid })<StyledStackProps>(\n ({ theme, wrap, gap }) => ({\n display: 'flex',\n flexWrap: wrap,\n ...toMediaQueries(gap, (currentValue) => ({ gap: theme.spacing[currentValue] })),\n }),\n ({ justifyContent }) => ({\n ...toMediaQueries(justifyContent, (currentValue) => ({ justifyContent: currentValue })),\n }),\n ({ alignItems }) => ({\n ...toMediaQueries(alignItems, (currentValue) => ({ alignItems: currentValue })),\n }),\n // Note that this has to be a separate object to avoid\n // the media queries from `expandResponsiveProp` to be overridden\n // when both direction and gap are responsive\n ({ direction }) => ({\n ...toMediaQueries(direction, (currentValue) => ({ flexDirection: currentValue })),\n }),\n)\n\ntype GapProp = keyof Theme['spacing']\ninterface StackOptions {\n /**\n * The direction of the stack.\n * @default 'column'\n */\n direction?: ResponsiveProp<FlexDirection>\n /**\n * The CSS `justify-content` property.\n * Controls the alignment of items on the main axis.\n */\n justifyContent?: ResponsiveProp<JustifyContent>\n /**\n * The CSS `align-items` property.\n * Controls the alignment of items on the cross axis.\n */\n alignItems?: ResponsiveProp<AlignItems>\n /**\n * The CSS `flex-wrap` property.\n * Controls whether children can wrap onto multiple lines.\n * @default 'nowrap'\n */\n wrap?: FlexWrap\n /**\n * The gap between each child element.\n */\n gap?: ResponsiveProp<GapProp>\n /**\n * A divider element to be rendered between each child element.\n *\n * _Note: For the divider to be rendered, the child elements can't be loose strings or numbers.\n * Wrap them in a `div` or other element._\n */\n divider?: ReactNode\n}\n\ntype StackComponent = Polymorphic.ForwardRefComponent<'div', StackOptions>\nexport type StackProps = Polymorphic.PropsOf<StackComponent>\n\nexport const Stack = forwardRef((props, forwardedRef) => {\n const {\n as,\n children,\n direction = 'column',\n justifyContent = 'flex-start',\n alignItems = 'stretch',\n divider,\n gap = '0x',\n ...restProps\n } = props\n\n const hasDivider = Boolean(divider)\n\n const resolvedChildren = !hasDivider\n ? children\n : getValidChildren(children).map((child, index, validChildren) => {\n // Prefer provided child key and fallback to index\n const key = typeof child.key !== 'undefined' ? child.key : index\n const isLast = index + 1 === validChildren.length\n\n const currentDivider = isLast ? null : divider\n\n return (\n <Fragment key={key}>\n {child}\n {currentDivider}\n </Fragment>\n )\n })\n\n return (\n <StyledStack\n as={as}\n ref={forwardedRef}\n direction={direction}\n justifyContent={justifyContent}\n alignItems={alignItems}\n gap={gap}\n {...restProps}\n >\n {resolvedChildren}\n </StyledStack>\n )\n}) as StackComponent\n","import type { ReactElement, ReactNode } from 'react'\nimport { Children, isValidElement } from 'react'\n\n/**\n * Gets only the valid children of a component,\n * and ignores any nullish or falsy child.\n */\nexport function getValidChildren(children: ReactNode) {\n return Children.toArray(children).filter((child) => isValidElement(child)) as ReactElement[]\n}\n","import styled from '@emotion/styled'\nimport * as RadixSwitch from '@radix-ui/react-switch'\nimport { CheckIcon } from 'lucide-react'\nimport { forwardRef } from 'react'\n\nimport { useStableId } from '../../hooks'\nimport { pxToRem } from '../../styles'\nimport { Label } from '../label'\n\ninterface SwitchOptions {\n /**\n * The label for the switch\n */\n label: string\n /**\n * The text that appears below the label\n * to provide additional guidance to the user\n */\n helperText?: string\n /**\n * The checked state of the checkbox when it is initially rendered. Use when you do not need to control its checked state.\n */\n isDefaultChecked?: boolean\n /**\n * If `true`, the switch will be checked\n */\n isChecked?: boolean\n /**\n * If `true`, the switch will be disabled and\n * cannot be interacted with\n */\n isDisabled?: boolean\n /**\n * If `true`, indicates that the switch is required\n */\n isRequired?: boolean\n onCheckedChange?: (isChecked: boolean) => void\n}\n\nexport interface SwitchProps\n extends Omit<RadixSwitch.SwitchProps, 'asChild' | keyof SwitchOptions>,\n SwitchOptions {}\n\nexport const Switch = forwardRef<HTMLButtonElement, SwitchProps>((props, forwardedRef) => {\n const {\n id: idProp,\n label,\n helperText,\n defaultChecked: hasHtmlDefaultCheckedAttr,\n isDefaultChecked: isDefaultCheckedProp,\n isChecked: isCheckedProp,\n checked: hasHtmlCheckedAttr,\n disabled: hasHtmlDisabledAttr,\n isDisabled: isDisabledProp,\n isRequired: isRequiredProp,\n required: hasHtmlRequiredAttr,\n 'aria-labelledby': ariaLabelledByProp,\n 'aria-describedby': ariaDescribedByProp,\n onCheckedChange,\n ...restProps\n } = props\n\n const id = useStableId(idProp)\n\n const isDefaultChecked = isDefaultCheckedProp || hasHtmlDefaultCheckedAttr\n const isChecked = isCheckedProp || hasHtmlCheckedAttr\n const isDisabled = isDisabledProp || hasHtmlDisabledAttr\n const isRequired = isRequiredProp || hasHtmlRequiredAttr\n\n const labelId = `${id}-label`\n const ariaLabelledBy = [labelId, ariaLabelledByProp].filter(Boolean).join(' ')\n\n const hasHelperText = Boolean(helperText)\n const helperTextId = hasHelperText ? `${id}-helper-text` : undefined\n const ariaDescribedBy = [helperTextId, ariaDescribedByProp].filter(Boolean).join(' ') || undefined\n\n return (\n <SwitchWrapper>\n <SwitchTexts>\n <SwitchLabel id={labelId} htmlFor={id} data-disabled={isDisabled ? '' : undefined}>\n {label}\n </SwitchLabel>\n {hasHelperText && (\n <SwitchHelperText id={helperTextId} data-disabled={isDisabled ? '' : undefined}>\n {helperText}\n </SwitchHelperText>\n )}\n </SwitchTexts>\n <SwitchRoot\n id={id}\n ref={forwardedRef}\n defaultChecked={isDefaultChecked}\n checked={isChecked}\n disabled={isDisabled}\n required={isRequired}\n aria-labelledby={ariaLabelledBy}\n aria-describedby={ariaDescribedBy}\n onCheckedChange={(isChecked) => onCheckedChange?.(isChecked)}\n {...restProps}\n >\n <SwitchThumb>\n <CheckIcon data-part=\"switch-icon\" size={12} absoluteStrokeWidth strokeWidth={2} />\n </SwitchThumb>\n </SwitchRoot>\n </SwitchWrapper>\n )\n})\n\nconst SwitchLabel = styled(Label)(() => ({\n marginTop: pxToRem(6),\n}))\n\nconst SwitchHelperText = styled.div(({ theme }) => ({\n flexGrow: 1,\n flexShrink: 1,\n color: theme.colors.text.subtle,\n cursor: 'default',\n ...theme.typography.body.sm,\n '&[data-disabled]': {\n opacity: 0.4,\n },\n}))\n\nconst SwitchWrapper = styled.div(({ theme }) => ({\n display: 'flex',\n gap: theme.spacing['4x'],\n alignItems: 'start',\n}))\n\nconst SwitchTexts = styled.div(({ theme }) => ({\n display: 'flex',\n flexDirection: 'column',\n flexGrow: 1,\n flexShrink: 1,\n justifyContent: 'space-between',\n gap: theme.sizes['2x'],\n}))\n\nconst SwitchRoot = styled(RadixSwitch.Root)(({ theme }) => ({\n flexGrow: 0,\n flexShrink: 0,\n flexBasis: 'auto',\n width: pxToRem(56),\n height: pxToRem(32),\n backgroundColor: theme.colors.core.gray40,\n transition: 'background-color 200ms',\n borderRadius: theme.radii.full,\n '&:hover:not([data-disabled])': {\n backgroundColor: theme.colors.core.gray30,\n },\n '&[data-disabled]': {\n opacity: 0.4,\n },\n '&[data-state=\"checked\"]': {\n backgroundColor: theme.colors.bg.brandSecondary,\n '[data-part=\"switch-icon\"]': {\n opacity: 1,\n },\n },\n '&:hover[data-state=\"checked\"]': {\n backgroundColor: theme.colors.bg.brandSecondaryHover,\n },\n '[data-part=\"switch-icon\"]': {\n opacity: 0,\n transition: 'opacity 200ms',\n },\n}))\n\nconst SwitchThumb = styled(RadixSwitch.Thumb)(({ theme }) => ({\n display: 'flex',\n flexGrow: 0,\n flexShrink: 0,\n flexBasis: 'auto',\n justifyContent: 'center',\n alignItems: 'center',\n width: theme.sizes['6x'],\n height: theme.sizes['6x'],\n boxShadow: theme.shadows.sm,\n backgroundColor: theme.colors.bg.default,\n borderRadius: theme.radii.full,\n transition: 'transform 300ms',\n transform: `translateX(${pxToRem(4)})`,\n willChange: 'transform',\n '&[data-state=\"checked\"]': {\n transform: `translateX(${pxToRem(28)})`,\n },\n '&[data-disabled]': {\n boxShadow: theme.shadows.none,\n },\n}))\n","import { forwardRef } from 'react'\nimport styled from '@emotion/styled'\n\nimport { useFormField } from '../../hooks'\nimport type { HTMLQdsProps } from '../../types'\nimport { Label } from '../label'\nimport type { TextareaBaseOptions } from '../primitives/textarea-base'\nimport { TextareaBase } from '../primitives/textarea-base'\nimport { ErrorMessage, FormField, HelperText } from '../_internal'\nimport { useTranslation } from '../../i18n/use-translation'\n\nconst OptionalText = styled.span(({ theme }) => ({\n ...theme.typography.body.sm,\n color: theme.colors.text.subtle,\n}))\n\ninterface TextareaOptions extends TextareaBaseOptions {\n /**\n * The label for the textarea field\n */\n label: string\n /**\n * The error message to display if `isInvalid` is `true`\n */\n errorMessage?: string\n /**\n * Text that provides additional guidance to the user\n */\n helperText?: string\n /**\n * If `true`, the input will display an optional indicator.\n * If the `isRequired` prop is also `true`, this prop will be ignored.\n */\n isOptional?: boolean\n}\n\ntype OmittedProps = 'children' | 'readOnly' | 'size'\n\nexport interface TextareaProps\n extends Omit<HTMLQdsProps<'textarea'>, OmittedProps>,\n TextareaOptions {}\n\nexport const Textarea = forwardRef<HTMLTextAreaElement, TextareaProps>((props, forwardedRef) => {\n const {\n label,\n isInvalid,\n errorMessage,\n helperText,\n isRequired,\n isOptional: isOptionalProp,\n ...restProps\n } = props\n const {\n getLabelProps,\n getFieldProps: getTextareaProps,\n getErrorMessageProps,\n getHelperTextProps,\n } = useFormField<'textarea'>(props)\n const { t } = useTranslation()\n\n const helperTextElement = helperText ? (\n <HelperText {...getHelperTextProps()}>{helperText}</HelperText>\n ) : null\n\n const shouldShowErrorMessage = isInvalid && errorMessage\n const errorMessageElement = shouldShowErrorMessage ? (\n <ErrorMessage {...getErrorMessageProps()}>{errorMessage}</ErrorMessage>\n ) : null\n\n const isOptional = Boolean(!isRequired && isOptionalProp)\n\n return (\n <FormField>\n <Label {...getLabelProps()}>\n {label}\n {isOptional && <OptionalText>{` (${t('optional')})`}</OptionalText>}\n </Label>\n <TextareaBase ref={forwardedRef} {...getTextareaProps(restProps)} />\n {errorMessageElement || helperTextElement}\n </FormField>\n )\n})\n"]}