@moondreamsdev/dreamer-ui 1.3.1 → 1.3.3

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.
@@ -1 +1 @@
1
- {"version":3,"file":"components.esm.js","sources":["../src/core/components/button/LoadingDots.tsx","../src/core/components/button/variants.ts","../src/core/components/button/Button.tsx","../src/core/symbols/Check.tsx","../src/core/components/checkbox/hooks.ts","../src/core/components/checkbox/Checkbox.tsx","../src/core/components/input/variants.ts","../src/core/shared/forms/StatusHelpMessage.tsx","../src/core/components/input/Input.tsx","../src/core/components/label/label.tsx","../src/core/components/radiogroup/RadioInput.tsx","../src/core/components/radiogroup/RadioGroupItem.tsx","../src/core/components/radiogroup/hooks.ts","../src/core/components/radiogroup/RadioGroup.tsx","../src/core/components/textarea/hooks.ts","../src/core/components/textarea/variants.ts","../src/core/components/textarea/CharacterCount.tsx","../src/core/components/textarea/Textarea.tsx"],"sourcesContent":["import { useEffect, useState } from 'react';\nimport { join } from '../../util/join';\n\nexport default function LoadingDots() {\n const [activeIndex, setActiveIndex] = useState(0);\n\n useEffect(() => {\n const interval = setInterval(() => {\n setActiveIndex((prevIndex) => (prevIndex + 1) % 3);\n }, 500);\n\n return () => clearInterval(interval);\n }, []);\n\n return (\n <div className='absolute inset-0 inline-flex items-center justify-center gap-x-2 align-middle'>\n {[0, 1, 2].map((index) => (\n <div\n key={index}\n className={join(\n 'rounded-full transition-all duration-500 ease-in-out size-[0.35em] bg-current',\n activeIndex === index && 'transform -translate-y-1'\n )}\n />\n ))}\n </div>\n );\n}\n","export const buttonVariants = {\n base: '',\n primary: 'bg-primary text-primary-foreground hover:bg-primary/85 disabled:bg-muted disabled:text-muted-foreground',\n secondary: 'bg-secondary text-secondary-foreground hover:bg-secondary/85 disabled:bg-muted/80 disabled:text-muted-foreground/80',\n tertiary: 'text-primary hover:text-primary-foreground disabled:text-muted',\n outline: 'border border-primary text-primary hover:border-primary-foreground hover:text-primary-foreground disabled:border-muted disabled:text-muted',\n link: 'underline-offset-4 hover:underline disabled:underline disabled:text-muted',\n danger: 'bg-danger text-danger-foreground hover:bg-danger/85 disabled:bg-muted disabled:text-muted-foreground',\n} as const;\nexport type ButtonVariant = keyof typeof buttonVariants;\n\nexport const sizeVariants = {\n stripped: '',\n fitted: 'size-fit',\n sm: 'px-2 py-1 text-sm',\n md: 'px-4 py-2 text-base',\n lg: 'px-6 py-3 text-lg',\n icon: 'p-1 w-fit aspect-square',\n full: 'p-2 w-full',\n} as const;\nexport type ButtonSize = keyof typeof sizeVariants;\n\nexport const roundedVariants = {\n none: 'rounded-none',\n sm: 'rounded-sm',\n md: 'rounded-md',\n lg: 'rounded-lg',\n full: 'rounded-full',\n} as const;\nexport type ButtonRounded = keyof typeof roundedVariants;\n\nexport interface ButtonVariants {\n variant: ButtonVariant;\n size: ButtonSize;\n rounded: ButtonRounded;\n}\n\nexport const buttonDefaults: ButtonVariants = {\n variant: 'primary',\n size: 'md',\n rounded: 'md',\n} as const;\n","// Button.tsx\nimport { ButtonHTMLAttributes, Ref } from 'react';\nimport { join } from '../../util/join';\nimport LoadingDots from './LoadingDots';\nimport { ButtonSize, ButtonVariants, buttonDefaults, buttonVariants, roundedVariants, sizeVariants } from './variants';\n\ninterface ButtonProps extends Partial<ButtonVariants>, ButtonHTMLAttributes<HTMLButtonElement> {\n ref?: Ref<HTMLButtonElement>;\n loading?: boolean;\n linkTo?: string;\n linkProps?: Omit<React.AnchorHTMLAttributes<HTMLAnchorElement>, 'href'>;\n}\n\nexport default function Button({\n variant = buttonDefaults.variant,\n size,\n rounded = buttonDefaults.rounded,\n loading,\n linkTo,\n linkProps,\n type = 'button',\n className,\n ...rest\n}: ButtonProps) {\n let adjustedSize: ButtonSize;\n if (variant === 'link' && !size) {\n // default links to fitted size\n adjustedSize = 'fitted';\n } else {\n adjustedSize = size || buttonDefaults.size;\n }\n\n const baseClasses =\n 'appearance-none focus:outline-none focus:ring not-disabled:hover:cursor-pointer disabled:opacity-50 disabled:cursor-not-allowed transition-all';\n\n const buttonClasses = join(\n baseClasses,\n buttonVariants[variant],\n sizeVariants[adjustedSize],\n roundedVariants[rounded],\n loading && 'relative pointer-events-none',\n linkTo && 'relative',\n className\n );\n\n return (\n <button\n {...rest}\n role={linkTo ? 'link' : rest.role}\n aria-label={rest['aria-label'] || linkProps?.['aria-label']}\n aria-description={rest['aria-description'] || linkProps?.['aria-description']}\n aria-disabled={rest.disabled || loading}\n aria-busy={loading}\n type={type}\n className={buttonClasses}\n >\n {loading && <LoadingDots />}\n <span className={join(loading && 'invisible')}>{rest.children}</span>\n\n {linkTo && !rest.disabled && (\n <a\n {...linkProps}\n aria-hidden={true} // Hide from screen readers since the button is already accessible\n href={linkTo}\n target={linkProps?.target || '_blank'}\n rel={linkProps?.rel || 'noreferrer'}\n className='absolute inset-0'\n />\n )}\n </button>\n );\n}\n","export default function Check({ size = 15, color = 'currentColor' }: { size?: number, color?: string }) {\n return (\n <svg width={size} height={size} className={'inline'} viewBox='0 0 15 15' xmlns='http://www.w3.org/2000/svg'>\n <path\n d='M11.4669 3.72684C11.7558 3.91574 11.8369 4.30308 11.648 4.59198L7.39799 11.092C7.29783 11.2452 7.13556 11.3467 6.95402 11.3699C6.77247 11.3931 6.58989 11.3355 6.45446 11.2124L3.70446 8.71241C3.44905 8.48022 3.43023 8.08494 3.66242 7.82953C3.89461 7.57412 4.28989 7.55529 4.5453 7.78749L6.75292 9.79441L10.6018 3.90792C10.7907 3.61902 11.178 3.53795 11.4669 3.72684Z'\n fill={color}\n fillRule='evenodd'\n clipRule='evenodd'\n />\n </svg>\n );\n}\n","import { useCallback, useEffect, useState } from 'react';\n\nexport function useFilledBackgroundColor(id: string) {\n const [filledBackgroundColor, setFilledBackgroundColor] = useState<string>('');\n\n const getFirstNonTransparentBackgroundColor = useCallback((element: Element | null): string => {\n let currentElement = element;\n let color = '';\n while (currentElement && !color) {\n const backgroundColor = window.getComputedStyle(currentElement).backgroundColor;\n if (backgroundColor && backgroundColor !== 'transparent' && backgroundColor !== 'rgba(0, 0, 0, 0)') {\n color = backgroundColor;\n }\n currentElement = currentElement.parentElement;\n }\n return color || 'transparent';\n }, []);\n\n useEffect(() => {\n const checkbox = document.getElementById(id);\n if (checkbox) {\n const backgroundColor = getFirstNonTransparentBackgroundColor(checkbox.parentElement);\n setFilledBackgroundColor(backgroundColor);\n }\n }, [id, getFirstNonTransparentBackgroundColor]);\n\n return filledBackgroundColor;\n}\n","import React, { Ref, useEffect, useId, useMemo, useState } from 'react';\nimport Check from '../../symbols/Check';\nimport { join } from '../../util/join';\nimport { useFilledBackgroundColor } from './hooks';\n\nexport interface CheckboxProps extends React.ButtonHTMLAttributes<HTMLButtonElement> {\n ref?: Ref<HTMLButtonElement>;\n size?: number;\n color?: string; // can be adjusted with tailwindcss by using `text-<color>`\n filled?: boolean;\n rounded?: boolean;\n checked?: boolean;\n onCheckedChange?: (checked: boolean) => void;\n}\n\nexport default function Checkbox({\n ref,\n id,\n size = 20,\n color,\n filled = false,\n rounded = true,\n checked = false,\n onCheckedChange,\n disabled,\n className = '',\n ...props\n}: CheckboxProps) {\n const generatedId = useId();\n const checkboxId = useMemo(() => id || `checkbox-${generatedId}`, [id, generatedId]);\n const parentBackgroundColor = useFilledBackgroundColor(checkboxId);\n const [isChecked, setIsChecked] = useState(checked);\n\n useEffect(() => {\n setIsChecked(checked);\n }, [checked]);\n\n const handleChange = () => {\n if (!disabled) {\n setIsChecked(!isChecked);\n onCheckedChange?.(!isChecked);\n }\n };\n\n const handleOnKeyDown = (e: React.KeyboardEvent<HTMLButtonElement>) => {\n if (e.key === ' ') {\n e.preventDefault();\n handleChange();\n }\n };\n\n const checkboxClasses = join(\n 'flex items-center justify-center border outline outline-transparent focus:outline-current focus:outline-offset-2',\n rounded && 'rounded',\n disabled && 'opacity-40 cursor-not-allowed',\n !disabled && 'cursor-pointer',\n className\n );\n\n return (\n <button\n id={checkboxId}\n type='button'\n ref={ref}\n tabIndex={0}\n role='checkbox'\n onClick={handleChange}\n aria-checked={isChecked}\n aria-disabled={disabled}\n onKeyDownCapture={handleOnKeyDown}\n style={{\n width: size,\n height: size,\n color: color,\n backgroundColor: isChecked && filled ? 'currentcolor' : 'transparent',\n }}\n className={checkboxClasses}\n {...props}\n >\n {isChecked && <Check size={size} color={filled ? parentBackgroundColor : undefined} />}\n </button>\n );\n}\n","export const inputVariants = {\n base: '',\n default:\n 'ring ring-transparent focus:ring-primary-foreground not-disabled:data-error:ring-danger not-disabled:data-success:ring-success',\n underline:\n 'border-b border-border focus:border-primary-foreground disabled:border-muted/30 not-disabled:data-error:border-danger not-disabled:data-success:border-success',\n outline:\n 'border border-border focus:border-primary-foreground disabled:border-muted/30 not-disabled:data-error:border-danger not-disabled:data-success:border-success',\n} as const;\nexport type InputVariant = keyof typeof inputVariants;\n\nexport const roundedVariants = {\n none: 'rounded-none',\n sm: 'rounded-sm',\n md: 'rounded-md',\n lg: 'rounded-lg',\n full: 'px-3 rounded-full',\n} as const;\nexport type InputRounded = keyof typeof roundedVariants;\n\nexport interface InputVariants {\n variant: InputVariant;\n rounded: InputRounded;\n}\n\nexport const inputDefaults: InputVariants = {\n variant: 'default',\n rounded: 'none',\n} as const;\n","import { useEffect } from 'react';\nimport { CheckCircled, ExclamationTriangle } from '../../symbols';\nimport { join } from '../../util/join';\n\ninterface StatusHelpMessageProps {\n elementId: string;\n type: 'error' | 'success';\n message?: string;\n}\n\nexport default function StatusHelpMessage({ elementId, type, message }: StatusHelpMessageProps) {\n useEffect(() => {\n const element = document.getElementById(elementId) as HTMLElement;\n if (!element) {\n return;\n }\n if (!message && type === 'error') {\n element.removeAttribute('data-error');\n return;\n }\n if (!message && type === 'success') {\n element.removeAttribute('data-success');\n return;\n }\n\n element.setAttribute('aria-describedby', `${elementId}-${type}-message`);\n element.setAttribute('aria-invalid', type === 'error' ? 'true' : 'false');\n\n if (type === 'error') {\n element.setAttribute('data-error', 'true');\n }\n if (type === 'success') {\n element.setAttribute('data-success', 'true');\n }\n\n return () => {\n element.removeAttribute('aria-describedby');\n element.removeAttribute('aria-invalid');\n element.removeAttribute('data-error');\n element.removeAttribute('data-success');\n };\n }, [elementId, type, message]);\n\n if (!message) {\n return null;\n }\n\n return (\n <small\n className={join(\n 'mt-0.5 text-sm inline-flex items-center gap-1 w-full justify-start',\n type === 'error' && 'text-danger',\n type === 'success' && 'text-success'\n )}\n role='status'\n >\n {type === 'error' ? <ExclamationTriangle /> : <CheckCircled />}\n <span id={`${elementId}-${type}-message`}>{message}</span>\n </small>\n );\n}\n","import { Ref, useId, useState } from 'react';\nimport { EyeClosed, EyeOpened } from '../../symbols';\nimport { join } from '../../util/join';\nimport './styles.css';\nimport { inputDefaults, inputVariants, InputVariants, roundedVariants } from './variants';\nimport { StatusHelpMessage } from '../../shared/forms';\n\ninterface InputProps extends Partial<InputVariants>, React.InputHTMLAttributes<HTMLInputElement> {\n ref?: Ref<HTMLInputElement>;\n displayOnlyMode?: boolean;\n errorMessage?: string;\n successMessage?: string;\n}\n\nexport default function Input({\n variant = inputDefaults.variant,\n rounded,\n displayOnlyMode = false,\n errorMessage,\n successMessage,\n type = 'text',\n className,\n ...rest\n}: InputProps) {\n const id = useId();\n const [showPassword, setShowPassword] = useState(false);\n\n // Default `round` of `md` for `outline` variant\n let adjustedRound = rounded;\n if (variant === 'outline' && !rounded) {\n adjustedRound = 'md';\n }\n adjustedRound = adjustedRound || inputDefaults.rounded;\n\n const baseClasses =\n 'appearance-none w-full focus:outline-none disabled:opacity-50 disabled:cursor-not-allowed placeholder:text-muted/70 hide-number-input-arrows transition-all';\n const fileClasses =\n 'file:mr-2 file:border-0 file:rounded-md file:px-1.5 file:py-1 file:bg-primary hover:file:bg-primary/85 file:text-sm file:font-medium file:text-foreground file:transition-colors';\n\n const inputClasses = join(\n baseClasses,\n fileClasses,\n !displayOnlyMode && inputVariants[variant],\n !displayOnlyMode && roundedVariants[adjustedRound],\n type === 'password' && 'pr-10',\n !displayOnlyMode && 'px-2 py-1',\n displayOnlyMode && 'pointer-events-none',\n className\n );\n\n return (\n <div className={join(displayOnlyMode && 'cursor-text')} style={{ height: rest.height, width: rest.width }}>\n <div className={join(type === 'password' && 'relative')}>\n <input\n {...rest}\n id={id}\n type={type === 'password' && showPassword ? 'text' : type}\n aria-disabled={rest.disabled}\n readOnly={displayOnlyMode}\n aria-readonly={displayOnlyMode || rest['aria-readonly']}\n data-error={errorMessage ? true : undefined}\n data-success={successMessage ? true : undefined}\n className={inputClasses}\n />\n {type === 'password' && (\n <button\n onClick={() => setShowPassword(!showPassword)}\n className='absolute inset-y-0 right-0 px-2 hover:cursor-pointer'\n aria-label='Toggle password visibility'\n data-state={showPassword ? 'visible' : 'hidden'}\n >\n {showPassword ? <EyeOpened size={20} /> : <EyeClosed size={20} />}\n </button>\n )}\n </div>\n {!displayOnlyMode && <StatusHelpMessage elementId={id} type='error' message={errorMessage} />}\n {!displayOnlyMode && <StatusHelpMessage elementId={id} type='success' message={successMessage} />}\n </div>\n );\n}\n","import React, { useId } from 'react';\nimport { QuestionMarkCircled } from '../../symbols';\nimport { join } from '../../util/join';\n\nexport interface LabelProps extends React.LabelHTMLAttributes<HTMLLabelElement> {\n display?: 'block' | 'inline';\n width?: React.CSSProperties['width'];\n required?: boolean;\n helpMessage?: string;\n suffix?: React.ReactNode;\n}\n\nexport function Label({\n display = 'inline',\n width = 'fit-content',\n className = '',\n required,\n helpMessage,\n suffix,\n htmlFor,\n children,\n ...props\n}: LabelProps) {\n const id = useId();\n const labelClasses = join('font-medium', display, className);\n const helpId = helpMessage ? `${htmlFor ?? id}-help` : undefined;\n\n return (\n <div style={{ display: display === 'inline' ? 'inline-flex' : 'flex', width }} className='relative'>\n <label className={labelClasses} htmlFor={htmlFor} {...props}>\n {children}\n {required && (\n <span className='text-red-500 font-medium ml-1' aria-label='required'>\n *\n </span>\n )}\n </label>\n {helpMessage && (\n <span\n className='text-gray-500 ml-1 size-fit -translate-y-1/3'\n aria-describedby={helpId}\n aria-label='Help information'\n title={helpMessage}\n >\n <QuestionMarkCircled />\n </span>\n )}\n {helpMessage && (\n <div id={helpId} className='sr-only'>\n {helpMessage}\n </div>\n )}\n {suffix && <span className='ml-1'>{suffix}</span>}\n </div>\n );\n}\n","import { join } from '../../util/join';\n\nexport type RadioInputProps = {\n itemId: string;\n checked: boolean;\n onChange: () => void;\n name: string;\n disabled?: boolean;\n className?: string;\n};\n\n// Custom RadioInput Component\nexport function RadioInput({ itemId, checked, onChange, name, disabled = false, className = '' }: RadioInputProps) {\n const baseClasses = 'relative inline-flex items-center justify-center rounded-full';\n\n const handleClick = () => {\n if (disabled) return;\n onChange();\n };\n\n const radioClasses = join(\n baseClasses,\n !checked && 'hover:border-current/60',\n !disabled && 'border-current cursor-pointer',\n disabled && 'border-muted/60 cursor-not-allowed',\n className\n );\n return (\n <div\n id={itemId}\n role='radio'\n tabIndex={-1} // necessary so that the radio button can be focused as div is not a focusable element\n aria-checked={checked}\n aria-disabled={disabled}\n aria-description={`Radio button for ${name}`}\n aria-labelledby={`${itemId}-label`}\n onClick={handleClick}\n className={radioClasses}\n style={{\n width: '1em',\n height: '1em',\n padding: '0.1em',\n borderWidth: '0.06em',\n }}\n >\n {checked && (\n <div\n className={join(`size-full aspect-square rounded-full`, disabled && 'bg-muted/60', !disabled && 'bg-current')}\n />\n )}\n </div>\n );\n}\n","import { useId } from 'react';\nimport { join } from '../../util/join';\nimport { RadioInput } from './RadioInput';\n\nexport interface RadioGroupItemProps {\n value: string;\n children: React.ReactNode;\n className?: string;\n isSelected?: boolean;\n onChange?: (value: string) => void;\n disabled?: boolean;\n name?: string;\n hideInput?: boolean;\n description?: string;\n}\n\nexport function RadioGroupItem({\n value,\n children,\n className = '',\n isSelected = false,\n onChange,\n disabled = false,\n hideInput = false,\n description,\n name,\n}: RadioGroupItemProps) {\n const id = useId();\n const itemId = `radio-${id}-${value}`;\n\n const handleChange = () => {\n if (!disabled) {\n onChange?.(value);\n }\n };\n\n return (\n <div\n title={description}\n className={join(\n 'relative flex items-center',\n className,\n // Uses text color for borders\n hideInput &&\n `p-2 border-2 focus-within:border-dashed focus-within:${\n disabled ? 'border-current/50' : 'border-current/80'\n }`,\n hideInput && !isSelected && `border-transparent ${disabled ? '' : 'not-focus-within:hover:border-border/60'}`,\n hideInput && isSelected && 'border-border',\n disabled && 'opacity-60 cursor-not-allowed'\n )}\n style={{\n gap: '0.5em',\n }}\n >\n {!hideInput && (\n <RadioInput\n itemId={itemId}\n name={name || ''}\n checked={isSelected}\n onChange={handleChange}\n disabled={disabled}\n className={join(hideInput && '')}\n />\n )}\n <div\n id={hideInput ? itemId : undefined}\n tabIndex={hideInput ? -1 : undefined}\n role={hideInput ? 'radio' : undefined}\n onClick={hideInput ? handleChange : undefined}\n aria-checked={!hideInput ? undefined : isSelected ? 'true' : 'false'}\n aria-disabled={hideInput ? disabled : undefined}\n aria-description={!hideInput ? undefined : description || `Radio button for ${name}`}\n aria-labelledby={hideInput ? `${itemId}-label` : undefined}\n className={join(hideInput && 'size-full', typeof children === 'object' && 'grow focus:outline-none')}\n >\n <label\n id={`${itemId}-label`}\n onClick={hideInput ? undefined : handleChange}\n className={join(disabled && 'cursor-not-allowed', !disabled && 'cursor-pointer')}\n >\n {children}\n </label>\n </div>\n </div>\n );\n}\n","import { useCallback, useEffect, useState } from 'react';\n\nexport function useRadioFocus(id: string, selectedOptionIndex: number) {\n // Manage state locally to avoid race conditions, which can result in\n // the an option failing to be selected or incorrectly selected\n const [focusedIndex, setFocusedIndex] = useState<number>(selectedOptionIndex);\n const [clickedIndex, setClickedIndex] = useState<number>(-1);\n // Prevent onClicks from triggering focus events and automatically selecting the first option\n const [isMouseDown, setIsMouseDown] = useState<boolean>(false);\n\n const handleClicked = useCallback((options: HTMLElement[], index: number) => {\n const target = options[index] as HTMLElement;\n\n // Check if the target element is disabled\n const isDisabled = target.hasAttribute('disabled') || target.getAttribute('aria-disabled') === 'true';\n if (isDisabled) return;\n\n // Update the selected index\n options[index]?.click();\n setClickedIndex(index);\n }, []);\n\n const setInitialFocus = useCallback(\n (e: Event, options: HTMLElement[]) => {\n e.preventDefault();\n if (isMouseDown) return;\n if (!options.length) return;\n\n const indexToFocus = selectedOptionIndex !== -1 ? selectedOptionIndex : 0;\n options[indexToFocus]?.focus();\n setFocusedIndex(indexToFocus);\n\n // Only update the selected index if one is already set\n if (selectedOptionIndex !== -1) {\n handleClicked(options, indexToFocus);\n }\n },\n [selectedOptionIndex, isMouseDown, handleClicked]\n );\n\n /* Focus preceding element when Shift + Tab is pressed */\n const handleFocusPreceding = useCallback(\n (e: KeyboardEvent) => {\n // If the Shift key is not pressed while tab is entered, do nothing\n if (!e.shiftKey) {\n return;\n }\n\n e.preventDefault();\n const focusableElements = Array.from(\n document.querySelectorAll<HTMLElement>(\n 'a, button, input, textarea, select, details, [tabindex]:not([tabindex=\"-1\"])'\n )\n ).filter((el) => !el.hasAttribute('disabled') && el.tabIndex >= 0);\n const currentIndex = focusableElements.findIndex((el) => el.id === id);\n const previousIndex = currentIndex > 0 ? currentIndex - 1 : focusableElements.length - 1;\n focusableElements[previousIndex]?.focus();\n },\n [id]\n );\n\n const handleKeyboardNavigation = useCallback(\n (e: KeyboardEvent, options: HTMLElement[]) => {\n if (!options.length) return;\n\n // Ensure we only toggle options part of radio group\n const target = e.target as HTMLElement;\n const isGroupOption = options.some((option) => option.id === target.id);\n if (!isGroupOption) return;\n\n const currentIndex = focusedIndex !== -1 ? focusedIndex : 0;\n let newIndex = currentIndex;\n\n switch (e.key) {\n case 'ArrowUp':\n case 'ArrowLeft':\n e.preventDefault();\n newIndex = currentIndex > 0 ? currentIndex - 1 : options.length - 1;\n break;\n\n case 'ArrowDown':\n case 'ArrowRight':\n e.preventDefault();\n newIndex = (currentIndex + 1) % options.length;\n break;\n\n // Select the option when the space key is pressed\n case ' ':\n e.preventDefault();\n handleClicked(options, currentIndex);\n return;\n\n case 'Tab':\n handleFocusPreceding(e);\n return;\n\n default:\n return;\n }\n\n options[newIndex]?.focus();\n setFocusedIndex(newIndex);\n // Only update the selected index if one is already set\n if (clickedIndex !== -1) {\n handleClicked(options, newIndex);\n }\n },\n [focusedIndex, clickedIndex, handleFocusPreceding, handleClicked]\n );\n\n const getRadioOptions = useCallback((): HTMLElement[] => {\n const radioGroup = document.querySelector(`[id=\"${id}\"][role=\"radiogroup\"]`);\n if (!radioGroup) return [];\n\n return Array.from(radioGroup.querySelectorAll('[role=\"radio\"]'));\n }, [id]);\n\n useEffect(() => {\n const radioGroup = document.querySelector(`[id=\"${id}\"][role=\"radiogroup\"]`);\n if (!radioGroup) return;\n\n const options = getRadioOptions();\n const handleFocus = (e: Event) => setInitialFocus(e, options);\n const handleKeyDown = (e: KeyboardEvent) => handleKeyboardNavigation(e, options);\n const handleMouseDown = () => setIsMouseDown(true);\n const handleMouseUp = () => setIsMouseDown(false);\n\n document.addEventListener('keydown', handleKeyDown);\n radioGroup.addEventListener('focus', handleFocus);\n radioGroup.addEventListener('mousedown', handleMouseDown);\n document.addEventListener('mouseup', handleMouseUp); // place on document since mouseup event can occur outside of radio group\n return () => {\n document.removeEventListener('keydown', handleKeyDown);\n radioGroup.removeEventListener('focus', handleFocus);\n radioGroup.removeEventListener('mousedown', handleMouseDown);\n document.removeEventListener('mouseup', handleMouseUp);\n };\n }, [id, getRadioOptions, setInitialFocus, handleKeyboardNavigation]);\n}\n","import React, { useId, useMemo } from 'react';\nimport { join } from '../../util/join';\nimport { RadioGroupItem, RadioGroupItemProps } from './RadioGroupItem';\nimport { useRadioFocus } from './hooks';\n\nexport type RadioOption = { label: string; value: string; disabled?: boolean; description?: string };\n\nexport type RadioGroupProps = {\n options?: (string | RadioOption)[];\n value: string | undefined;\n onChange: (value: string) => void;\n name?: string;\n children?: React.ReactElement<RadioGroupItemProps>[] | React.ReactElement<RadioGroupItemProps>;\n className?: string;\n childrenClassName?: string;\n hideInputs?: boolean;\n};\n\nexport function RadioGroup({\n options = [],\n value,\n onChange,\n name,\n children,\n className = '',\n childrenClassName = '',\n hideInputs = false,\n}: RadioGroupProps) {\n const groupId = useId();\n const groupName = name || `radio-group-${groupId}`;\n useRadioFocus(\n groupName,\n options.findIndex((option) => option === value)\n );\n\n // Check for duplicates if string options are provided\n const processedOptions = useMemo(() => {\n return options.reduce<RadioOption[]>((acc, option) => {\n if (typeof option === 'string') {\n // Check if we already have this string option\n if (!acc.some((item) => item.value === option)) {\n acc.push({ label: option, value: option });\n }\n } else {\n acc.push(option);\n }\n return acc;\n }, []);\n }, [options]);\n\n return (\n <div id={groupName} role='radiogroup' tabIndex={0} className={join(className, 'focus:outline-none')}>\n {/* Render from options prop */}\n {processedOptions.length > 0 &&\n processedOptions.map((option, index) => (\n <RadioGroupItem\n key={`${option.value}-${index}`}\n value={option.value}\n isSelected={value === option.value}\n onChange={onChange}\n name={groupName}\n disabled={option.disabled}\n description={option.description}\n hideInput={hideInputs}\n className={childrenClassName}\n >\n {option.label}\n </RadioGroupItem>\n ))}\n\n {/* Render RadioGroupItem components */}\n {processedOptions.length === 0 &&\n children &&\n React.Children.map(children, (child) => {\n // TypeScript enforces that child is a RadioGroupItem\n if (React.isValidElement(child) && child.type === RadioGroupItem) {\n return (\n <RadioGroupItem\n {...child.props}\n className={join(childrenClassName, child.props.className)}\n hideInput={child.props.hideInput || hideInputs}\n isSelected={value === child.props.value}\n onChange={onChange}\n name={groupName}\n >\n {child.props.children}\n </RadioGroupItem>\n );\n }\n return null;\n })}\n </div>\n );\n}\n","import { useEffect } from 'react';\n\nexport function useAutoExpand(id: string, autoExpand: boolean) {\n useEffect(() => {\n const textarea = document.getElementById(id) as HTMLTextAreaElement;\n if (!textarea) {\n return;\n }\n\n if (!autoExpand) {\n textarea.style.height = 'auto';\n return;\n }\n\n const adjustHeight = () => {\n // necessary to reset the height to `auto` before calculating the new height\n textarea.style.height = 'auto';\n textarea.style.height = `${textarea.scrollHeight}px`;\n };\n\n adjustHeight();\n textarea.addEventListener('input', adjustHeight);\n textarea.addEventListener('resize', adjustHeight);\n window.addEventListener('resize', adjustHeight);\n\n return () => {\n textarea.removeEventListener('input', adjustHeight);\n textarea.removeEventListener('resize', adjustHeight);\n window.removeEventListener('resize', adjustHeight);\n };\n }, [id, autoExpand]);\n}\n","export const textareaVariants = {\n base: '',\n 'left-line':\n 'border-l border-border focus:border-primary-foreground disabled:border-muted/30 not-disabled:data-error:border-danger not-disabled:data-success:border-success',\n outline:\n 'border border-border focus:border-primary-foreground disabled:border-muted/30 not-disabled:data-error:border-danger not-disabled:data-success:border-success',\n} as const;\nexport type TextareaVariant = keyof typeof textareaVariants;\n\nexport const roundedVariants = {\n none: 'rounded-none',\n sm: 'rounded-sm',\n md: 'rounded-md',\n lg: 'rounded-lg',\n full: 'px-3 rounded-full',\n} as const;\nexport type TextareaRounded = keyof typeof roundedVariants;\n\nexport interface TextareaVariants {\n variant: TextareaVariant;\n rounded: TextareaRounded;\n}\n\nexport const textareaDefaults: TextareaVariants = {\n variant: 'outline',\n rounded: 'none',\n} as const;\n","import { useEffect, useState } from 'react';\nimport { join } from '../../util/join';\n\ninterface CharacterCountProps {\n elementId: string;\n maxLength: number;\n}\n\nexport default function CharacterCount({ elementId, maxLength }: CharacterCountProps) {\n const [characterCount, setCharacterCount] = useState(0);\n\n useEffect(() => {\n const textarea = document.getElementById(elementId) as HTMLTextAreaElement;\n if (!textarea) {\n return;\n }\n\n const updateCharacterCount = () => {\n const updatedCharacterCount = textarea.value.length;\n setCharacterCount(updatedCharacterCount);\n const isError = updatedCharacterCount >= maxLength;\n textarea.setAttribute('aria-describedby', `${elementId}-character-count`);\n textarea.setAttribute('aria-invalid', isError ? 'true' : 'false');\n\n if (isError) {\n textarea.setAttribute('data-error', 'true');\n } else {\n textarea.removeAttribute('data-error');\n }\n };\n\n updateCharacterCount();\n textarea.addEventListener('input', updateCharacterCount);\n textarea.setAttribute('maxlength', String(maxLength));\n\n return () => {\n textarea.removeEventListener('input', updateCharacterCount);\n textarea.removeAttribute('maxlength');\n textarea.removeAttribute('aria-describedby');\n textarea.removeAttribute('aria-invalid');\n textarea.removeAttribute('data-error');\n };\n }, [elementId, maxLength]);\n\n return (\n <small\n className={join(\n 'mt-0.5 text-sm inline-flex items-center gap-1 w-full justify-end',\n characterCount >= maxLength && 'text-danger',\n characterCount < maxLength && 'text-current'\n )}\n role='status'\n >\n <span id={`${elementId}-character-count`}>\n {characterCount} / {maxLength} characters\n </span>\n </small>\n );\n}\n","import { Ref, useId } from 'react';\nimport { StatusHelpMessage } from '../../shared/forms';\nimport { join } from '../../util/join';\nimport { useAutoExpand } from './hooks';\nimport './styles.css';\nimport { roundedVariants, textareaDefaults, textareaVariants, TextareaVariants } from './variants';\nimport CharacterCount from './CharacterCount';\n\ninterface TextareaProps extends Partial<TextareaVariants>, React.TextareaHTMLAttributes<HTMLTextAreaElement> {\n ref?: Ref<HTMLTextAreaElement>;\n displayOnlyMode?: boolean;\n errorMessage?: string;\n successMessage?: string;\n hideResizeHandle?: boolean; // only works for Webkit browsers\n autoExpand?: boolean;\n characterLimit?: number;\n}\n\nexport default function Textarea({\n variant = textareaDefaults.variant,\n rounded,\n displayOnlyMode = false,\n errorMessage,\n successMessage,\n hideResizeHandle = false,\n autoExpand = false,\n characterLimit = 0,\n className,\n ...rest\n}: TextareaProps) {\n const id = useId();\n useAutoExpand(id, autoExpand || displayOnlyMode);\n\n // Default `round` of `md` for `outline` variant\n let adjustedRound = rounded;\n if (variant === 'outline' && !rounded) {\n adjustedRound = 'md';\n }\n adjustedRound = adjustedRound || textareaDefaults.rounded;\n\n let adjustedHideResizeHandle = hideResizeHandle;\n if (displayOnlyMode || (variant === 'left-line' && !hideResizeHandle)) {\n adjustedHideResizeHandle = true;\n }\n\n const baseClasses =\n 'appearance-none w-full focus:outline-none disabled:opacity-50 disabled:cursor-not-allowed placeholder:text-muted/70 hide-number-input-arrows transition-all';\n\n const inputClasses = join(\n baseClasses,\n !displayOnlyMode && textareaVariants[variant],\n !displayOnlyMode && roundedVariants[adjustedRound],\n !displayOnlyMode && 'px-2 py-1',\n displayOnlyMode && 'pointer-events-none',\n adjustedHideResizeHandle && 'no-resize-handle',\n\n className\n );\n\n return (\n <div className={join('-space-y-1.5', displayOnlyMode && 'cursor-text')}>\n <textarea\n {...rest}\n id={id}\n aria-disabled={rest.disabled}\n readOnly={displayOnlyMode}\n aria-readonly={displayOnlyMode || rest['aria-readonly']}\n style={{\n resize: autoExpand ? 'none' : undefined,\n }}\n className={inputClasses}\n />\n {characterLimit > 0 && <CharacterCount elementId={id} maxLength={characterLimit} />}\n {!displayOnlyMode && <StatusHelpMessage elementId={id} type='error' message={errorMessage} />}\n {!displayOnlyMode && <StatusHelpMessage elementId={id} type='success' message={successMessage} />}\n </div>\n );\n}\n"],"names":["LoadingDots","activeIndex","setActiveIndex","useState","useEffect","interval","prevIndex","jsx","index","join","buttonVariants","sizeVariants","roundedVariants","buttonDefaults","Button","variant","size","rounded","loading","linkTo","linkProps","type","className","rest","adjustedSize","buttonClasses","jsxs","Check","color","useFilledBackgroundColor","id","filledBackgroundColor","setFilledBackgroundColor","getFirstNonTransparentBackgroundColor","useCallback","element","currentElement","backgroundColor","checkbox","Checkbox","ref","filled","checked","onCheckedChange","disabled","props","generatedId","useId","checkboxId","useMemo","parentBackgroundColor","isChecked","setIsChecked","handleChange","handleOnKeyDown","e","checkboxClasses","inputVariants","inputDefaults","StatusHelpMessage","elementId","message","ExclamationTriangle","CheckCircled","Input","displayOnlyMode","errorMessage","successMessage","showPassword","setShowPassword","adjustedRound","inputClasses","EyeOpened","EyeClosed","Label","display","width","required","helpMessage","suffix","htmlFor","children","labelClasses","helpId","QuestionMarkCircled","RadioInput","itemId","onChange","name","baseClasses","handleClick","radioClasses","RadioGroupItem","value","isSelected","hideInput","description","useRadioFocus","selectedOptionIndex","focusedIndex","setFocusedIndex","clickedIndex","setClickedIndex","isMouseDown","setIsMouseDown","handleClicked","options","target","_a","setInitialFocus","indexToFocus","handleFocusPreceding","focusableElements","el","currentIndex","previousIndex","handleKeyboardNavigation","option","newIndex","getRadioOptions","radioGroup","handleFocus","handleKeyDown","handleMouseDown","handleMouseUp","RadioGroup","childrenClassName","hideInputs","groupId","groupName","processedOptions","acc","item","React","child","useAutoExpand","autoExpand","textarea","adjustHeight","textareaVariants","textareaDefaults","CharacterCount","maxLength","characterCount","setCharacterCount","updateCharacterCount","updatedCharacterCount","isError","Textarea","hideResizeHandle","characterLimit","adjustedHideResizeHandle"],"mappings":"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"}
1
+ {"version":3,"file":"components.esm.js","sources":["../src/core/components/button/LoadingDots.tsx","../src/core/components/button/variants.ts","../src/core/components/button/Button.tsx","../src/core/symbols/Check.tsx","../src/core/components/checkbox/hooks.ts","../src/core/components/checkbox/Checkbox.tsx","../src/core/components/input/variants.ts","../src/core/shared/forms/StatusHelpMessage.tsx","../src/core/components/input/Input.tsx","../src/core/components/label/label.tsx","../src/core/components/radiogroup/RadioInput.tsx","../src/core/components/radiogroup/RadioGroupItem.tsx","../src/core/components/radiogroup/hooks.ts","../src/core/components/radiogroup/RadioGroup.tsx","../src/core/components/textarea/hooks.ts","../src/core/components/textarea/variants.ts","../src/core/components/textarea/CharacterCount.tsx","../src/core/components/textarea/Textarea.tsx","../node_modules/tailwind-variants/dist/chunk-HK3UQQ6K.js","../node_modules/tailwind-variants/dist/chunk-2DBF3ZSA.js","../node_modules/tailwind-variants/dist/index.js","../src/core/components/TestButton/TestButton.tsx"],"sourcesContent":["import { useEffect, useState } from 'react';\nimport { join } from '../../util/join';\n\nexport default function LoadingDots() {\n const [activeIndex, setActiveIndex] = useState(0);\n\n useEffect(() => {\n const interval = setInterval(() => {\n setActiveIndex((prevIndex) => (prevIndex + 1) % 3);\n }, 500);\n\n return () => clearInterval(interval);\n }, []);\n\n return (\n <div className='absolute inset-0 inline-flex items-center justify-center gap-x-2 align-middle'>\n {[0, 1, 2].map((index) => (\n <div\n key={index}\n className={join(\n 'rounded-full transition-all duration-500 ease-in-out size-[0.35em] bg-current',\n activeIndex === index && 'transform -translate-y-1'\n )}\n />\n ))}\n </div>\n );\n}\n","export const buttonVariants = {\n base: '',\n primary: 'bg-primary text-primary-foreground hover:bg-primary/85 disabled:bg-muted disabled:text-muted-foreground',\n secondary: 'bg-secondary text-secondary-foreground hover:bg-secondary/85 disabled:bg-muted/80 disabled:text-muted-foreground/80',\n tertiary: 'text-primary hover:text-primary-foreground disabled:text-muted',\n outline: 'border border-primary text-primary hover:border-primary-foreground hover:text-primary-foreground disabled:border-muted disabled:text-muted',\n link: 'underline-offset-4 hover:underline disabled:underline disabled:text-muted',\n danger: 'bg-danger text-danger-foreground hover:bg-danger/85 disabled:bg-muted disabled:text-muted-foreground',\n} as const;\nexport type ButtonVariant = keyof typeof buttonVariants;\n\nexport const sizeVariants = {\n stripped: '',\n fitted: 'size-fit',\n sm: 'px-2 py-1 text-sm',\n md: 'px-4 py-2 text-base',\n lg: 'px-6 py-3 text-lg',\n icon: 'p-1 w-fit aspect-square',\n full: 'p-2 w-full',\n} as const;\nexport type ButtonSize = keyof typeof sizeVariants;\n\nexport const roundedVariants = {\n none: 'rounded-none',\n sm: 'rounded-sm',\n md: 'rounded-md',\n lg: 'rounded-lg',\n full: 'rounded-full',\n} as const;\nexport type ButtonRounded = keyof typeof roundedVariants;\n\nexport interface ButtonVariants {\n variant: ButtonVariant;\n size: ButtonSize;\n rounded: ButtonRounded;\n}\n\nexport const buttonDefaults: ButtonVariants = {\n variant: 'primary',\n size: 'md',\n rounded: 'md',\n} as const;\n","// Button.tsx\nimport { ButtonHTMLAttributes, Ref } from 'react';\nimport { join } from '../../util/join';\nimport LoadingDots from './LoadingDots';\nimport { ButtonSize, ButtonVariants, buttonDefaults, buttonVariants, roundedVariants, sizeVariants } from './variants';\n\ninterface ButtonProps extends Partial<ButtonVariants>, ButtonHTMLAttributes<HTMLButtonElement> {\n ref?: Ref<HTMLButtonElement>;\n loading?: boolean;\n linkTo?: string;\n linkProps?: Omit<React.AnchorHTMLAttributes<HTMLAnchorElement>, 'href'>;\n}\n\nexport default function Button({\n variant = buttonDefaults.variant,\n size,\n rounded = buttonDefaults.rounded,\n loading,\n linkTo,\n linkProps,\n type = 'button',\n className,\n ...rest\n}: ButtonProps) {\n let adjustedSize: ButtonSize;\n if (variant === 'link' && !size) {\n // default links to fitted size\n adjustedSize = 'fitted';\n } else {\n adjustedSize = size || buttonDefaults.size;\n }\n\n const baseClasses =\n 'appearance-none focus:outline-none focus:ring not-disabled:hover:cursor-pointer disabled:opacity-50 disabled:cursor-not-allowed transition-all';\n\n const buttonClasses = join(\n baseClasses,\n buttonVariants[variant],\n sizeVariants[adjustedSize],\n roundedVariants[rounded],\n loading && 'relative pointer-events-none',\n linkTo && 'relative',\n className\n );\n\n return (\n <button\n {...rest}\n role={linkTo ? 'link' : rest.role}\n aria-label={rest['aria-label'] || linkProps?.['aria-label']}\n aria-description={rest['aria-description'] || linkProps?.['aria-description']}\n aria-disabled={rest.disabled || loading}\n aria-busy={loading}\n type={type}\n className={buttonClasses}\n >\n {loading && <LoadingDots />}\n <span className={join(loading && 'invisible')}>{rest.children}</span>\n\n {linkTo && !rest.disabled && (\n <a\n {...linkProps}\n aria-hidden={true} // Hide from screen readers since the button is already accessible\n href={linkTo}\n target={linkProps?.target || '_blank'}\n rel={linkProps?.rel || 'noreferrer'}\n className='absolute inset-0'\n />\n )}\n </button>\n );\n}\n","export default function Check({ size = 15, color = 'currentColor' }: { size?: number, color?: string }) {\n return (\n <svg width={size} height={size} className={'inline'} viewBox='0 0 15 15' xmlns='http://www.w3.org/2000/svg'>\n <path\n d='M11.4669 3.72684C11.7558 3.91574 11.8369 4.30308 11.648 4.59198L7.39799 11.092C7.29783 11.2452 7.13556 11.3467 6.95402 11.3699C6.77247 11.3931 6.58989 11.3355 6.45446 11.2124L3.70446 8.71241C3.44905 8.48022 3.43023 8.08494 3.66242 7.82953C3.89461 7.57412 4.28989 7.55529 4.5453 7.78749L6.75292 9.79441L10.6018 3.90792C10.7907 3.61902 11.178 3.53795 11.4669 3.72684Z'\n fill={color}\n fillRule='evenodd'\n clipRule='evenodd'\n />\n </svg>\n );\n}\n","import { useCallback, useEffect, useState } from 'react';\n\nexport function useFilledBackgroundColor(id: string) {\n const [filledBackgroundColor, setFilledBackgroundColor] = useState<string>('');\n\n const getFirstNonTransparentBackgroundColor = useCallback((element: Element | null): string => {\n let currentElement = element;\n let color = '';\n while (currentElement && !color) {\n const backgroundColor = window.getComputedStyle(currentElement).backgroundColor;\n if (backgroundColor && backgroundColor !== 'transparent' && backgroundColor !== 'rgba(0, 0, 0, 0)') {\n color = backgroundColor;\n }\n currentElement = currentElement.parentElement;\n }\n return color || 'transparent';\n }, []);\n\n useEffect(() => {\n const checkbox = document.getElementById(id);\n if (checkbox) {\n const backgroundColor = getFirstNonTransparentBackgroundColor(checkbox.parentElement);\n setFilledBackgroundColor(backgroundColor);\n }\n }, [id, getFirstNonTransparentBackgroundColor]);\n\n return filledBackgroundColor;\n}\n","import React, { Ref, useEffect, useId, useMemo, useState } from 'react';\nimport Check from '../../symbols/Check';\nimport { join } from '../../util/join';\nimport { useFilledBackgroundColor } from './hooks';\n\nexport interface CheckboxProps extends React.ButtonHTMLAttributes<HTMLButtonElement> {\n ref?: Ref<HTMLButtonElement>;\n size?: number;\n color?: string; // can be adjusted with tailwindcss by using `text-<color>`\n filled?: boolean;\n rounded?: boolean;\n checked?: boolean;\n onCheckedChange?: (checked: boolean) => void;\n}\n\nexport default function Checkbox({\n ref,\n id,\n size = 20,\n color,\n filled = false,\n rounded = true,\n checked = false,\n onCheckedChange,\n disabled,\n className = '',\n ...props\n}: CheckboxProps) {\n const generatedId = useId();\n const checkboxId = useMemo(() => id || `checkbox-${generatedId}`, [id, generatedId]);\n const parentBackgroundColor = useFilledBackgroundColor(checkboxId);\n const [isChecked, setIsChecked] = useState(checked);\n\n useEffect(() => {\n setIsChecked(checked);\n }, [checked]);\n\n const handleChange = () => {\n if (!disabled) {\n setIsChecked(!isChecked);\n onCheckedChange?.(!isChecked);\n }\n };\n\n const handleOnKeyDown = (e: React.KeyboardEvent<HTMLButtonElement>) => {\n if (e.key === ' ') {\n e.preventDefault();\n handleChange();\n }\n };\n\n const checkboxClasses = join(\n 'flex items-center justify-center border outline outline-transparent focus:outline-current focus:outline-offset-2',\n rounded && 'rounded',\n disabled && 'opacity-40 cursor-not-allowed',\n !disabled && 'cursor-pointer',\n className\n );\n\n return (\n <button\n id={checkboxId}\n type='button'\n ref={ref}\n tabIndex={0}\n role='checkbox'\n onClick={handleChange}\n aria-checked={isChecked}\n aria-disabled={disabled}\n onKeyDownCapture={handleOnKeyDown}\n style={{\n width: size,\n height: size,\n color: color,\n backgroundColor: isChecked && filled ? 'currentcolor' : 'transparent',\n }}\n className={checkboxClasses}\n {...props}\n >\n {isChecked && <Check size={size} color={filled ? parentBackgroundColor : undefined} />}\n </button>\n );\n}\n","export const inputVariants = {\n base: '',\n default:\n 'ring ring-transparent focus:ring-primary-foreground not-disabled:data-error:ring-danger not-disabled:data-success:ring-success',\n underline:\n 'border-b border-border focus:border-primary-foreground disabled:border-muted/30 not-disabled:data-error:border-danger not-disabled:data-success:border-success',\n outline:\n 'border border-border focus:border-primary-foreground disabled:border-muted/30 not-disabled:data-error:border-danger not-disabled:data-success:border-success',\n} as const;\nexport type InputVariant = keyof typeof inputVariants;\n\nexport const roundedVariants = {\n none: 'rounded-none',\n sm: 'rounded-sm',\n md: 'rounded-md',\n lg: 'rounded-lg',\n full: 'px-3 rounded-full',\n} as const;\nexport type InputRounded = keyof typeof roundedVariants;\n\nexport interface InputVariants {\n variant: InputVariant;\n rounded: InputRounded;\n}\n\nexport const inputDefaults: InputVariants = {\n variant: 'default',\n rounded: 'none',\n} as const;\n","import { useEffect } from 'react';\nimport { CheckCircled, ExclamationTriangle } from '../../symbols';\nimport { join } from '../../util/join';\n\ninterface StatusHelpMessageProps {\n elementId: string;\n type: 'error' | 'success';\n message?: string;\n}\n\nexport default function StatusHelpMessage({ elementId, type, message }: StatusHelpMessageProps) {\n useEffect(() => {\n const element = document.getElementById(elementId) as HTMLElement;\n if (!element) {\n return;\n }\n if (!message && type === 'error') {\n element.removeAttribute('data-error');\n return;\n }\n if (!message && type === 'success') {\n element.removeAttribute('data-success');\n return;\n }\n\n element.setAttribute('aria-describedby', `${elementId}-${type}-message`);\n element.setAttribute('aria-invalid', type === 'error' ? 'true' : 'false');\n\n if (type === 'error') {\n element.setAttribute('data-error', 'true');\n }\n if (type === 'success') {\n element.setAttribute('data-success', 'true');\n }\n\n return () => {\n element.removeAttribute('aria-describedby');\n element.removeAttribute('aria-invalid');\n element.removeAttribute('data-error');\n element.removeAttribute('data-success');\n };\n }, [elementId, type, message]);\n\n if (!message) {\n return null;\n }\n\n return (\n <small\n className={join(\n 'mt-0.5 text-sm inline-flex items-center gap-1 w-full justify-start',\n type === 'error' && 'text-danger',\n type === 'success' && 'text-success'\n )}\n role='status'\n >\n {type === 'error' ? <ExclamationTriangle /> : <CheckCircled />}\n <span id={`${elementId}-${type}-message`}>{message}</span>\n </small>\n );\n}\n","import { Ref, useId, useState } from 'react';\nimport { EyeClosed, EyeOpened } from '../../symbols';\nimport { join } from '../../util/join';\nimport './styles.css';\nimport { inputDefaults, inputVariants, InputVariants, roundedVariants } from './variants';\nimport { StatusHelpMessage } from '../../shared/forms';\n\ninterface InputProps extends Partial<InputVariants>, React.InputHTMLAttributes<HTMLInputElement> {\n ref?: Ref<HTMLInputElement>;\n displayOnlyMode?: boolean;\n errorMessage?: string;\n successMessage?: string;\n}\n\nexport default function Input({\n variant = inputDefaults.variant,\n rounded,\n displayOnlyMode = false,\n errorMessage,\n successMessage,\n type = 'text',\n className,\n ...rest\n}: InputProps) {\n const id = useId();\n const [showPassword, setShowPassword] = useState(false);\n\n // Default `round` of `md` for `outline` variant\n let adjustedRound = rounded;\n if (variant === 'outline' && !rounded) {\n adjustedRound = 'md';\n }\n adjustedRound = adjustedRound || inputDefaults.rounded;\n\n const baseClasses =\n 'appearance-none w-full focus:outline-none disabled:opacity-50 disabled:cursor-not-allowed placeholder:text-muted/70 hide-number-input-arrows transition-all';\n const fileClasses =\n 'file:mr-2 file:border-0 file:rounded-md file:px-1.5 file:py-1 file:bg-primary hover:file:bg-primary/85 file:text-sm file:font-medium file:text-foreground file:transition-colors';\n\n const inputClasses = join(\n baseClasses,\n fileClasses,\n !displayOnlyMode && inputVariants[variant],\n !displayOnlyMode && roundedVariants[adjustedRound],\n type === 'password' && 'pr-10',\n !displayOnlyMode && 'px-2 py-1',\n displayOnlyMode && 'pointer-events-none',\n className\n );\n\n return (\n <div className={join(displayOnlyMode && 'cursor-text')} style={{ height: rest.height, width: rest.width }}>\n <div className={join(type === 'password' && 'relative')}>\n <input\n {...rest}\n id={id}\n type={type === 'password' && showPassword ? 'text' : type}\n aria-disabled={rest.disabled}\n readOnly={displayOnlyMode}\n aria-readonly={displayOnlyMode || rest['aria-readonly']}\n data-error={errorMessage ? true : undefined}\n data-success={successMessage ? true : undefined}\n className={inputClasses}\n />\n {type === 'password' && (\n <button\n onClick={() => setShowPassword(!showPassword)}\n className='absolute inset-y-0 right-0 px-2 hover:cursor-pointer'\n aria-label='Toggle password visibility'\n data-state={showPassword ? 'visible' : 'hidden'}\n >\n {showPassword ? <EyeOpened size={20} /> : <EyeClosed size={20} />}\n </button>\n )}\n </div>\n {!displayOnlyMode && <StatusHelpMessage elementId={id} type='error' message={errorMessage} />}\n {!displayOnlyMode && <StatusHelpMessage elementId={id} type='success' message={successMessage} />}\n </div>\n );\n}\n","import React, { useId } from 'react';\nimport { QuestionMarkCircled } from '../../symbols';\nimport { join } from '../../util/join';\n\nexport interface LabelProps extends React.LabelHTMLAttributes<HTMLLabelElement> {\n display?: 'block' | 'inline';\n width?: React.CSSProperties['width'];\n required?: boolean;\n helpMessage?: string;\n suffix?: React.ReactNode;\n}\n\nexport function Label({\n display = 'inline',\n width = 'fit-content',\n className = '',\n required,\n helpMessage,\n suffix,\n htmlFor,\n children,\n ...props\n}: LabelProps) {\n const id = useId();\n const labelClasses = join('font-medium', display, className);\n const helpId = helpMessage ? `${htmlFor ?? id}-help` : undefined;\n\n return (\n <div style={{ display: display === 'inline' ? 'inline-flex' : 'flex', width }} className='relative'>\n <label className={labelClasses} htmlFor={htmlFor} {...props}>\n {children}\n {required && (\n <span className='text-red-500 font-medium ml-1' aria-label='required'>\n *\n </span>\n )}\n </label>\n {helpMessage && (\n <span\n className='text-gray-500 ml-1 size-fit -translate-y-1/3'\n aria-describedby={helpId}\n aria-label='Help information'\n title={helpMessage}\n >\n <QuestionMarkCircled />\n </span>\n )}\n {helpMessage && (\n <div id={helpId} className='sr-only'>\n {helpMessage}\n </div>\n )}\n {suffix && <span className='ml-1'>{suffix}</span>}\n </div>\n );\n}\n","import { join } from '../../util/join';\n\nexport type RadioInputProps = {\n itemId: string;\n checked: boolean;\n onChange: () => void;\n name: string;\n disabled?: boolean;\n className?: string;\n};\n\n// Custom RadioInput Component\nexport function RadioInput({ itemId, checked, onChange, name, disabled = false, className = '' }: RadioInputProps) {\n const baseClasses = 'relative inline-flex items-center justify-center rounded-full';\n\n const handleClick = () => {\n if (disabled) return;\n onChange();\n };\n\n const radioClasses = join(\n baseClasses,\n !checked && 'hover:border-current/60',\n !disabled && 'border-current cursor-pointer',\n disabled && 'border-muted/60 cursor-not-allowed',\n className\n );\n return (\n <div\n id={itemId}\n role='radio'\n tabIndex={-1} // necessary so that the radio button can be focused as div is not a focusable element\n aria-checked={checked}\n aria-disabled={disabled}\n aria-description={`Radio button for ${name}`}\n aria-labelledby={`${itemId}-label`}\n onClick={handleClick}\n className={radioClasses}\n style={{\n width: '1em',\n height: '1em',\n padding: '0.1em',\n borderWidth: '0.06em',\n }}\n >\n {checked && (\n <div\n className={join(`size-full aspect-square rounded-full`, disabled && 'bg-muted/60', !disabled && 'bg-current')}\n />\n )}\n </div>\n );\n}\n","import { useId } from 'react';\nimport { join } from '../../util/join';\nimport { RadioInput } from './RadioInput';\n\nexport interface RadioGroupItemProps {\n value: string;\n children: React.ReactNode;\n className?: string;\n isSelected?: boolean;\n onChange?: (value: string) => void;\n disabled?: boolean;\n name?: string;\n hideInput?: boolean;\n description?: string;\n}\n\nexport function RadioGroupItem({\n value,\n children,\n className = '',\n isSelected = false,\n onChange,\n disabled = false,\n hideInput = false,\n description,\n name,\n}: RadioGroupItemProps) {\n const id = useId();\n const itemId = `radio-${id}-${value}`;\n\n const handleChange = () => {\n if (!disabled) {\n onChange?.(value);\n }\n };\n\n return (\n <div\n title={description}\n className={join(\n 'relative flex items-center',\n className,\n // Uses text color for borders\n hideInput &&\n `p-2 border-2 focus-within:border-dashed focus-within:${\n disabled ? 'border-current/50' : 'border-current/80'\n }`,\n hideInput && !isSelected && `border-transparent ${disabled ? '' : 'not-focus-within:hover:border-border/60'}`,\n hideInput && isSelected && 'border-border',\n disabled && 'opacity-60 cursor-not-allowed'\n )}\n style={{\n gap: '0.5em',\n }}\n >\n {!hideInput && (\n <RadioInput\n itemId={itemId}\n name={name || ''}\n checked={isSelected}\n onChange={handleChange}\n disabled={disabled}\n className={join(hideInput && '')}\n />\n )}\n <div\n id={hideInput ? itemId : undefined}\n tabIndex={hideInput ? -1 : undefined}\n role={hideInput ? 'radio' : undefined}\n onClick={hideInput ? handleChange : undefined}\n aria-checked={!hideInput ? undefined : isSelected ? 'true' : 'false'}\n aria-disabled={hideInput ? disabled : undefined}\n aria-description={!hideInput ? undefined : description || `Radio button for ${name}`}\n aria-labelledby={hideInput ? `${itemId}-label` : undefined}\n className={join(hideInput && 'size-full', typeof children === 'object' && 'grow focus:outline-none')}\n >\n <label\n id={`${itemId}-label`}\n onClick={hideInput ? undefined : handleChange}\n className={join(disabled && 'cursor-not-allowed', !disabled && 'cursor-pointer')}\n >\n {children}\n </label>\n </div>\n </div>\n );\n}\n","import { useCallback, useEffect, useState } from 'react';\n\nexport function useRadioFocus(id: string, selectedOptionIndex: number) {\n // Manage state locally to avoid race conditions, which can result in\n // the an option failing to be selected or incorrectly selected\n const [focusedIndex, setFocusedIndex] = useState<number>(selectedOptionIndex);\n const [clickedIndex, setClickedIndex] = useState<number>(-1);\n // Prevent onClicks from triggering focus events and automatically selecting the first option\n const [isMouseDown, setIsMouseDown] = useState<boolean>(false);\n\n const handleClicked = useCallback((options: HTMLElement[], index: number) => {\n const target = options[index] as HTMLElement;\n\n // Check if the target element is disabled\n const isDisabled = target.hasAttribute('disabled') || target.getAttribute('aria-disabled') === 'true';\n if (isDisabled) return;\n\n // Update the selected index\n options[index]?.click();\n setClickedIndex(index);\n }, []);\n\n const setInitialFocus = useCallback(\n (e: Event, options: HTMLElement[]) => {\n e.preventDefault();\n if (isMouseDown) return;\n if (!options.length) return;\n\n const indexToFocus = selectedOptionIndex !== -1 ? selectedOptionIndex : 0;\n options[indexToFocus]?.focus();\n setFocusedIndex(indexToFocus);\n\n // Only update the selected index if one is already set\n if (selectedOptionIndex !== -1) {\n handleClicked(options, indexToFocus);\n }\n },\n [selectedOptionIndex, isMouseDown, handleClicked]\n );\n\n /* Focus preceding element when Shift + Tab is pressed */\n const handleFocusPreceding = useCallback(\n (e: KeyboardEvent) => {\n // If the Shift key is not pressed while tab is entered, do nothing\n if (!e.shiftKey) {\n return;\n }\n\n e.preventDefault();\n const focusableElements = Array.from(\n document.querySelectorAll<HTMLElement>(\n 'a, button, input, textarea, select, details, [tabindex]:not([tabindex=\"-1\"])'\n )\n ).filter((el) => !el.hasAttribute('disabled') && el.tabIndex >= 0);\n const currentIndex = focusableElements.findIndex((el) => el.id === id);\n const previousIndex = currentIndex > 0 ? currentIndex - 1 : focusableElements.length - 1;\n focusableElements[previousIndex]?.focus();\n },\n [id]\n );\n\n const handleKeyboardNavigation = useCallback(\n (e: KeyboardEvent, options: HTMLElement[]) => {\n if (!options.length) return;\n\n // Ensure we only toggle options part of radio group\n const target = e.target as HTMLElement;\n const isGroupOption = options.some((option) => option.id === target.id);\n if (!isGroupOption) return;\n\n const currentIndex = focusedIndex !== -1 ? focusedIndex : 0;\n let newIndex = currentIndex;\n\n switch (e.key) {\n case 'ArrowUp':\n case 'ArrowLeft':\n e.preventDefault();\n newIndex = currentIndex > 0 ? currentIndex - 1 : options.length - 1;\n break;\n\n case 'ArrowDown':\n case 'ArrowRight':\n e.preventDefault();\n newIndex = (currentIndex + 1) % options.length;\n break;\n\n // Select the option when the space key is pressed\n case ' ':\n e.preventDefault();\n handleClicked(options, currentIndex);\n return;\n\n case 'Tab':\n handleFocusPreceding(e);\n return;\n\n default:\n return;\n }\n\n options[newIndex]?.focus();\n setFocusedIndex(newIndex);\n // Only update the selected index if one is already set\n if (clickedIndex !== -1) {\n handleClicked(options, newIndex);\n }\n },\n [focusedIndex, clickedIndex, handleFocusPreceding, handleClicked]\n );\n\n const getRadioOptions = useCallback((): HTMLElement[] => {\n const radioGroup = document.querySelector(`[id=\"${id}\"][role=\"radiogroup\"]`);\n if (!radioGroup) return [];\n\n return Array.from(radioGroup.querySelectorAll('[role=\"radio\"]'));\n }, [id]);\n\n useEffect(() => {\n const radioGroup = document.querySelector(`[id=\"${id}\"][role=\"radiogroup\"]`);\n if (!radioGroup) return;\n\n const options = getRadioOptions();\n const handleFocus = (e: Event) => setInitialFocus(e, options);\n const handleKeyDown = (e: KeyboardEvent) => handleKeyboardNavigation(e, options);\n const handleMouseDown = () => setIsMouseDown(true);\n const handleMouseUp = () => setIsMouseDown(false);\n\n document.addEventListener('keydown', handleKeyDown);\n radioGroup.addEventListener('focus', handleFocus);\n radioGroup.addEventListener('mousedown', handleMouseDown);\n document.addEventListener('mouseup', handleMouseUp); // place on document since mouseup event can occur outside of radio group\n return () => {\n document.removeEventListener('keydown', handleKeyDown);\n radioGroup.removeEventListener('focus', handleFocus);\n radioGroup.removeEventListener('mousedown', handleMouseDown);\n document.removeEventListener('mouseup', handleMouseUp);\n };\n }, [id, getRadioOptions, setInitialFocus, handleKeyboardNavigation]);\n}\n","import React, { useId, useMemo } from 'react';\nimport { join } from '../../util/join';\nimport { RadioGroupItem, RadioGroupItemProps } from './RadioGroupItem';\nimport { useRadioFocus } from './hooks';\n\nexport type RadioOption = { label: string; value: string; disabled?: boolean; description?: string };\n\nexport type RadioGroupProps = {\n options?: (string | RadioOption)[];\n value: string | undefined;\n onChange: (value: string) => void;\n name?: string;\n children?: React.ReactElement<RadioGroupItemProps>[] | React.ReactElement<RadioGroupItemProps>;\n className?: string;\n childrenClassName?: string;\n hideInputs?: boolean;\n};\n\nexport function RadioGroup({\n options = [],\n value,\n onChange,\n name,\n children,\n className = '',\n childrenClassName = '',\n hideInputs = false,\n}: RadioGroupProps) {\n const groupId = useId();\n const groupName = name || `radio-group-${groupId}`;\n useRadioFocus(\n groupName,\n options.findIndex((option) => option === value)\n );\n\n // Check for duplicates if string options are provided\n const processedOptions = useMemo(() => {\n return options.reduce<RadioOption[]>((acc, option) => {\n if (typeof option === 'string') {\n // Check if we already have this string option\n if (!acc.some((item) => item.value === option)) {\n acc.push({ label: option, value: option });\n }\n } else {\n acc.push(option);\n }\n return acc;\n }, []);\n }, [options]);\n\n return (\n <div id={groupName} role='radiogroup' tabIndex={0} className={join(className, 'focus:outline-none')}>\n {/* Render from options prop */}\n {processedOptions.length > 0 &&\n processedOptions.map((option, index) => (\n <RadioGroupItem\n key={`${option.value}-${index}`}\n value={option.value}\n isSelected={value === option.value}\n onChange={onChange}\n name={groupName}\n disabled={option.disabled}\n description={option.description}\n hideInput={hideInputs}\n className={childrenClassName}\n >\n {option.label}\n </RadioGroupItem>\n ))}\n\n {/* Render RadioGroupItem components */}\n {processedOptions.length === 0 &&\n children &&\n React.Children.map(children, (child) => {\n // TypeScript enforces that child is a RadioGroupItem\n if (React.isValidElement(child) && child.type === RadioGroupItem) {\n return (\n <RadioGroupItem\n {...child.props}\n className={join(childrenClassName, child.props.className)}\n hideInput={child.props.hideInput || hideInputs}\n isSelected={value === child.props.value}\n onChange={onChange}\n name={groupName}\n >\n {child.props.children}\n </RadioGroupItem>\n );\n }\n return null;\n })}\n </div>\n );\n}\n","import { useEffect } from 'react';\n\nexport function useAutoExpand(id: string, autoExpand: boolean) {\n useEffect(() => {\n const textarea = document.getElementById(id) as HTMLTextAreaElement;\n if (!textarea) {\n return;\n }\n\n if (!autoExpand) {\n textarea.style.height = 'auto';\n return;\n }\n\n const adjustHeight = () => {\n // necessary to reset the height to `auto` before calculating the new height\n textarea.style.height = 'auto';\n textarea.style.height = `${textarea.scrollHeight}px`;\n };\n\n adjustHeight();\n textarea.addEventListener('input', adjustHeight);\n textarea.addEventListener('resize', adjustHeight);\n window.addEventListener('resize', adjustHeight);\n\n return () => {\n textarea.removeEventListener('input', adjustHeight);\n textarea.removeEventListener('resize', adjustHeight);\n window.removeEventListener('resize', adjustHeight);\n };\n }, [id, autoExpand]);\n}\n","export const textareaVariants = {\n base: '',\n 'left-line':\n 'border-l border-border focus:border-primary-foreground disabled:border-muted/30 not-disabled:data-error:border-danger not-disabled:data-success:border-success',\n outline:\n 'border border-border focus:border-primary-foreground disabled:border-muted/30 not-disabled:data-error:border-danger not-disabled:data-success:border-success',\n} as const;\nexport type TextareaVariant = keyof typeof textareaVariants;\n\nexport const roundedVariants = {\n none: 'rounded-none',\n sm: 'rounded-sm',\n md: 'rounded-md',\n lg: 'rounded-lg',\n full: 'px-3 rounded-full',\n} as const;\nexport type TextareaRounded = keyof typeof roundedVariants;\n\nexport interface TextareaVariants {\n variant: TextareaVariant;\n rounded: TextareaRounded;\n}\n\nexport const textareaDefaults: TextareaVariants = {\n variant: 'outline',\n rounded: 'none',\n} as const;\n","import { useEffect, useState } from 'react';\nimport { join } from '../../util/join';\n\ninterface CharacterCountProps {\n elementId: string;\n maxLength: number;\n}\n\nexport default function CharacterCount({ elementId, maxLength }: CharacterCountProps) {\n const [characterCount, setCharacterCount] = useState(0);\n\n useEffect(() => {\n const textarea = document.getElementById(elementId) as HTMLTextAreaElement;\n if (!textarea) {\n return;\n }\n\n const updateCharacterCount = () => {\n const updatedCharacterCount = textarea.value.length;\n setCharacterCount(updatedCharacterCount);\n const isError = updatedCharacterCount >= maxLength;\n textarea.setAttribute('aria-describedby', `${elementId}-character-count`);\n textarea.setAttribute('aria-invalid', isError ? 'true' : 'false');\n\n if (isError) {\n textarea.setAttribute('data-error', 'true');\n } else {\n textarea.removeAttribute('data-error');\n }\n };\n\n updateCharacterCount();\n textarea.addEventListener('input', updateCharacterCount);\n textarea.setAttribute('maxlength', String(maxLength));\n\n return () => {\n textarea.removeEventListener('input', updateCharacterCount);\n textarea.removeAttribute('maxlength');\n textarea.removeAttribute('aria-describedby');\n textarea.removeAttribute('aria-invalid');\n textarea.removeAttribute('data-error');\n };\n }, [elementId, maxLength]);\n\n return (\n <small\n className={join(\n 'mt-0.5 text-sm inline-flex items-center gap-1 w-full justify-end',\n characterCount >= maxLength && 'text-danger',\n characterCount < maxLength && 'text-current'\n )}\n role='status'\n >\n <span id={`${elementId}-character-count`}>\n {characterCount} / {maxLength} characters\n </span>\n </small>\n );\n}\n","import { Ref, useId } from 'react';\nimport { StatusHelpMessage } from '../../shared/forms';\nimport { join } from '../../util/join';\nimport { useAutoExpand } from './hooks';\nimport './styles.css';\nimport { roundedVariants, textareaDefaults, textareaVariants, TextareaVariants } from './variants';\nimport CharacterCount from './CharacterCount';\n\ninterface TextareaProps extends Partial<TextareaVariants>, React.TextareaHTMLAttributes<HTMLTextAreaElement> {\n ref?: Ref<HTMLTextAreaElement>;\n displayOnlyMode?: boolean;\n errorMessage?: string;\n successMessage?: string;\n hideResizeHandle?: boolean; // only works for Webkit browsers\n autoExpand?: boolean;\n characterLimit?: number;\n}\n\nexport default function Textarea({\n variant = textareaDefaults.variant,\n rounded,\n displayOnlyMode = false,\n errorMessage,\n successMessage,\n hideResizeHandle = false,\n autoExpand = false,\n characterLimit = 0,\n className,\n ...rest\n}: TextareaProps) {\n const id = useId();\n useAutoExpand(id, autoExpand || displayOnlyMode);\n\n // Default `round` of `md` for `outline` variant\n let adjustedRound = rounded;\n if (variant === 'outline' && !rounded) {\n adjustedRound = 'md';\n }\n adjustedRound = adjustedRound || textareaDefaults.rounded;\n\n let adjustedHideResizeHandle = hideResizeHandle;\n if (displayOnlyMode || (variant === 'left-line' && !hideResizeHandle)) {\n adjustedHideResizeHandle = true;\n }\n\n const baseClasses =\n 'appearance-none w-full focus:outline-none disabled:opacity-50 disabled:cursor-not-allowed placeholder:text-muted/70 hide-number-input-arrows transition-all';\n\n const inputClasses = join(\n baseClasses,\n !displayOnlyMode && textareaVariants[variant],\n !displayOnlyMode && roundedVariants[adjustedRound],\n !displayOnlyMode && 'px-2 py-1',\n displayOnlyMode && 'pointer-events-none',\n adjustedHideResizeHandle && 'no-resize-handle',\n\n className\n );\n\n return (\n <div className={join('-space-y-1.5', displayOnlyMode && 'cursor-text')}>\n <textarea\n {...rest}\n id={id}\n aria-disabled={rest.disabled}\n readOnly={displayOnlyMode}\n aria-readonly={displayOnlyMode || rest['aria-readonly']}\n style={{\n resize: autoExpand ? 'none' : undefined,\n }}\n className={inputClasses}\n />\n {characterLimit > 0 && <CharacterCount elementId={id} maxLength={characterLimit} />}\n {!displayOnlyMode && <StatusHelpMessage elementId={id} type='error' message={errorMessage} />}\n {!displayOnlyMode && <StatusHelpMessage elementId={id} type='success' message={successMessage} />}\n </div>\n );\n}\n","var u=(e=>typeof require<\"u\"?require:typeof Proxy<\"u\"?new Proxy(e,{get:(t,n)=>(typeof require<\"u\"?require:t)[n]}):e)(function(e){if(typeof require<\"u\")return require.apply(this,arguments);throw Error('Dynamic require of \"'+e+'\" is not supported')});var y=e=>e===false?\"false\":e===true?\"true\":e===0?\"0\":e,p=e=>{if(!e||typeof e!=\"object\")return true;for(let t in e)return false;return true},g=(e,t)=>{if(e===t)return true;if(!e||!t)return false;let n=Object.keys(e),r=Object.keys(t);if(n.length!==r.length)return false;for(let s=0;s<n.length;s++){let f=n[s];if(!r.includes(f)||e[f]!==t[f])return false}return true},x=e=>e===true||e===false;function o(e,t){for(let n=0;n<e.length;n++){let r=e[n];Array.isArray(r)?o(r,t):t.push(r);}}function A(e){let t=[];return o(e,t),t}var i=(...e)=>{let t=[];o(e,t);let n=[];for(let r=0;r<t.length;r++)t[r]&&n.push(t[r]);return n},c=(e,t)=>{let n={};for(let r in e){let s=e[r];if(r in t){let f=t[r];Array.isArray(s)||Array.isArray(f)?n[r]=i(f,s):typeof s==\"object\"&&typeof f==\"object\"&&s&&f?n[r]=c(s,f):n[r]=f+\" \"+s;}else n[r]=s;}for(let r in t)r in e||(n[r]=t[r]);return n},l=/\\s+/g,h=e=>!e||typeof e!=\"string\"?e:e.replace(l,\" \").trim();export{u as a,y as b,p as c,g as d,x as e,A as f,i as g,c as h,h as i};","import {a,c}from'./chunk-HK3UQQ6K.js';var r=null,s=null,p=async()=>r||s||(s=import('tailwind-merge').then(t=>(r=t,t)).catch(()=>null),s),m=t=>n=>{if(s&&!r)return n;if(r){let{twMerge:e,extendTailwindMerge:l}=r;return (c(t)?e:l({...t,extend:{theme:t.theme,classGroups:t.classGroups,conflictingClassGroupModifiers:t.conflictingClassGroupModifiers,conflictingClassGroups:t.conflictingClassGroups,...t.extend}}))(n)}try{let{twMerge:e,extendTailwindMerge:l}=a(\"tailwind-merge\");return r={twMerge:e,extendTailwindMerge:l},(c(t)?e:l({...t,extend:{theme:t.theme,classGroups:t.classGroups,conflictingClassGroupModifiers:t.conflictingClassGroupModifiers,conflictingClassGroups:t.conflictingClassGroups,...t.extend}}))(n)}catch{return p(),n}};export{m as a};","import {a}from'./chunk-2DBF3ZSA.js';import {c,h,d,g,b,i}from'./chunk-HK3UQQ6K.js';var st={twMerge:true,twMergeConfig:{},responsiveVariants:false},x=(...l)=>{let u=[];X(l,u);let t=\"\";for(let d=0;d<u.length;d++)u[d]&&(t&&(t+=\" \"),t+=u[d]);return t||void 0};function X(l,u){for(let t=0;t<l.length;t++){let d=l[t];Array.isArray(d)?X(d,u):d&&u.push(d);}}var P=null,B={},F=false,S=(...l)=>u=>{let t=x(l);return !t||!u.twMerge?t:((!P||F)&&(F=false,P=a(B)),P(t)||void 0)},Q=(l,u)=>{for(let t in u)t in l?l[t]=x(l[t],u[t]):l[t]=u[t];return l},rt=(l,u)=>{let{extend:t=null,slots:d$1={},variants:R={},compoundVariants:q=[],compoundSlots:A=[],defaultVariants:L={}}=l,m={...st,...u},M=t?.base?x(t.base,l?.base):l?.base,y=t?.variants&&!c(t.variants)?h(R,t.variants):R,T=t?.defaultVariants&&!c(t.defaultVariants)?{...t.defaultVariants,...L}:L;!c(m.twMergeConfig)&&!d(m.twMergeConfig,B)&&(F=true,B=m.twMergeConfig);let j=c(t?.slots),$=c(d$1)?{}:{base:x(l?.base,j&&t?.base),...d$1},N=j?$:Q({...t?.slots},c($)?{base:l?.base}:$),w=c(t?.compoundVariants)?q:g(t?.compoundVariants,q),V=b$1=>{if(c(y)&&c(d$1)&&j)return S(M,b$1?.class,b$1?.className)(m);if(w&&!Array.isArray(w))throw new TypeError(`The \"compoundVariants\" prop must be an array. Received: ${typeof w}`);if(A&&!Array.isArray(A))throw new TypeError(`The \"compoundSlots\" prop must be an array. Received: ${typeof A}`);let Z=(n,e,s=[],o)=>{let a=s;if(typeof e==\"string\"){let c=i(e).split(\" \");for(let f=0;f<c.length;f++)a.push(`${n}:${c[f]}`);}else if(Array.isArray(e))for(let r=0;r<e.length;r++)a.push(`${n}:${e[r]}`);else if(typeof e==\"object\"&&typeof o==\"string\"&&o in e){let r=e[o];if(r&&typeof r==\"string\"){let f=i(r).split(\" \"),p=[];for(let i=0;i<f.length;i++)p.push(`${n}:${f[i]}`);a[o]=a[o]?a[o].concat(p):p;}else if(Array.isArray(r)&&r.length>0){let c=[];for(let f=0;f<r.length;f++)c.push(`${n}:${r[f]}`);a[o]=c;}}return a},U=(n,e=y,s=null,o=null)=>{let a=e[n];if(!a||c(a))return null;let r=o?.[n]??b$1?.[n];if(r===null)return null;let c$1=b(r),f=Array.isArray(m.responsiveVariants)&&m.responsiveVariants.length>0||m.responsiveVariants===true,p=T?.[n],i=[];if(typeof c$1==\"object\"&&f)for(let[C,G]of Object.entries(c$1)){let nt=a[G];if(C===\"initial\"){p=G;continue}Array.isArray(m.responsiveVariants)&&!m.responsiveVariants.includes(C)||(i=Z(C,nt,i,s));}let v=c$1!=null&&typeof c$1!=\"object\"?c$1:b(p),h=a[v||\"false\"];return typeof i==\"object\"&&typeof s==\"string\"&&i[s]?Q(i,h):i.length>0?(i.push(h),s===\"base\"?i.join(\" \"):i):h},_=()=>{if(!y)return null;let n=Object.keys(y),e=[];for(let s=0;s<n.length;s++){let o=U(n[s],y);o&&e.push(o);}return e},K=(n,e)=>{if(!y||typeof y!=\"object\")return null;let s=[];for(let o in y){let a=U(o,y,n,e),r=n===\"base\"&&typeof a==\"string\"?a:a&&a[n];r&&s.push(r);}return s},W={};for(let n in b$1){let e=b$1[n];e!==void 0&&(W[n]=e);}let z=(n,e)=>{let s=typeof b$1?.[n]==\"object\"?{[n]:b$1[n]?.initial}:{};return {...T,...W,...s,...e}},D=(n=[],e)=>{let s=[],o=n.length;for(let a=0;a<o;a++){let{class:r,className:c,...f}=n[a],p=true,i=z(null,e);for(let v in f){let h=f[v],C=i[v];if(Array.isArray(h)){if(!h.includes(C)){p=false;break}}else {if((h==null||h===false)&&(C==null||C===false))continue;if(C!==h){p=false;break}}}p&&(r&&s.push(r),c&&s.push(c));}return s},tt=n=>{let e=D(w,n);if(!Array.isArray(e))return e;let s={},o=S;for(let a=0;a<e.length;a++){let r=e[a];if(typeof r==\"string\")s.base=o(s.base,r)(m);else if(typeof r==\"object\")for(let c in r)s[c]=o(s[c],r[c])(m);}return s},et=n=>{if(A.length<1)return null;let e={},s=z(null,n);for(let o=0;o<A.length;o++){let{slots:a=[],class:r,className:c$1,...f}=A[o];if(!c(f)){let p=true;for(let i in f){let v=s[i],h=f[i];if(v===void 0||(Array.isArray(h)?!h.includes(v):h!==v)){p=false;break}}if(!p)continue}for(let p=0;p<a.length;p++){let i=a[p];e[i]||(e[i]=[]),e[i].push([r,c$1]);}}return e};if(!c(d$1)||!j){let n={};if(typeof N==\"object\"&&!c(N)){let e=S;for(let s in N)n[s]=o=>{let a=tt(o),r=et(o);return e(N[s],K(s,o),a?a[s]:void 0,r?r[s]:void 0,o?.class,o?.className)(m)};}return n}return S(M,_(),D(w),b$1?.class,b$1?.className)(m)},Y=()=>{if(!(!y||typeof y!=\"object\"))return Object.keys(y)};return V.variantKeys=Y(),V.extend=t,V.base=M,V.slots=N,V.variants=y,V.defaultVariants=T,V.compoundSlots=A,V.compoundVariants=w,V},it=l=>(u,t)=>rt(u,t?h(l,t):l);export{S as cn,x as cnBase,it as createTV,st as defaultConfig,rt as tv};","import React, { ButtonHTMLAttributes, ReactNode } from 'react';\nimport { tv, type VariantProps } from 'tailwind-variants';\n\nexport const testButton = tv({\n base: 'inline-flex items-center max-w-[500px] hover:cursor-pointer',\n variants: {\n size: {\n large: 'h-[44px] py-[12px] px-[16px] gap-1 rounded-lg',\n medium: 'h-[32px] py-[6px] px-[12px] gap-1 rounded-lg',\n small: 'h-[28px] py-[6px] px-[12px] gap-1 rounded-lg',\n },\n design: {\n outline_light:\n 'border border-greyscale-light-2 text-greyscale-light-2 hover:bg-greyscale-light-2 hover:text-greyscale-dark-1 hover:border-0',\n outline_dark:\n 'border border-greyscale-dark-2 text-greyscale-dark-2 hover:bg-greyscale-dark-2 hover:text-greyscale-white hover:border-0',\n filled_light: 'bg-greyscale-light-2 text-greyscale-dark-1 hover:bg-pink hover:text-greyscale-white',\n filled_dark: 'bg-greyscale-dark-2 text-greyscale-white hover:bg-dark-pink hover:text-pink',\n filled_pink: 'bg-pink text-greyscale-white hover:bg-dark-pink hover:text-pink',\n neutral_dark: 'text-greyscale-dark-2 hover:bg-greyscale-light-2 hover:text-greyscale-dark-1',\n neutral_light: 'text-greyscale-light-2 hover:bg-greyscale-light-2 hover:text-greyscale-dark-1',\n },\n disabled: {\n true: 'pointer-events-none',\n },\n },\n compoundVariants: [\n {\n design: ['filled_dark', 'filled_pink'],\n disabled: true,\n class: 'bg-greyscale-light-1 text-greyscale-light-2',\n },\n {\n design: 'filled_light',\n disabled: true,\n class: 'text-greyscale-medium-3 bg-greyscale-light-1',\n },\n {\n design: 'outline_light',\n disabled: true,\n class: 'text-greyscale-medium-3 border-greyscale-medium-3',\n },\n {\n design: 'outline_dark',\n disabled: true,\n class: 'text-greyscale-light-1 border-greyscale-light-1',\n },\n {\n design: 'neutral_dark',\n disabled: true,\n class: 'text-greyscale-light-1',\n },\n {\n design: 'neutral_light',\n disabled: true,\n class: 'text-greyscale-medium-3',\n },\n ],\n});\n\ntype TestButtonVariants = VariantProps<typeof testButton>;\n\nexport interface TestButtonProps\n extends TestButtonVariants,\n Omit<ButtonHTMLAttributes<HTMLButtonElement>, 'className'> {\n label: string;\n icon?: React.ReactNode;\n}\n\nexport const TestButton = ({\n label,\n size,\n design,\n disabled = false,\n icon = undefined,\n ...props\n}: TestButtonProps): ReactNode => {\n return (\n <button\n data-testid={`test-button-${label}`}\n className={testButton({ size: size, design: design, disabled: disabled })}\n {...props}\n >\n {/* optional icon */}\n {icon && <>{icon}</>}\n\n {/* label */}\n <span>{label}</span>\n </button>\n );\n};\n"],"names":["LoadingDots","activeIndex","setActiveIndex","useState","useEffect","interval","prevIndex","jsx","index","join","buttonVariants","sizeVariants","roundedVariants","buttonDefaults","Button","variant","size","rounded","loading","linkTo","linkProps","type","className","rest","adjustedSize","buttonClasses","jsxs","Check","color","useFilledBackgroundColor","id","filledBackgroundColor","setFilledBackgroundColor","getFirstNonTransparentBackgroundColor","useCallback","element","currentElement","backgroundColor","checkbox","Checkbox","ref","filled","checked","onCheckedChange","disabled","props","generatedId","useId","checkboxId","useMemo","parentBackgroundColor","isChecked","setIsChecked","handleChange","handleOnKeyDown","e","checkboxClasses","inputVariants","inputDefaults","StatusHelpMessage","elementId","message","ExclamationTriangle","CheckCircled","Input","displayOnlyMode","errorMessage","successMessage","showPassword","setShowPassword","adjustedRound","inputClasses","EyeOpened","EyeClosed","Label","display","width","required","helpMessage","suffix","htmlFor","children","labelClasses","helpId","QuestionMarkCircled","RadioInput","itemId","onChange","name","baseClasses","handleClick","radioClasses","RadioGroupItem","value","isSelected","hideInput","description","useRadioFocus","selectedOptionIndex","focusedIndex","setFocusedIndex","clickedIndex","setClickedIndex","isMouseDown","setIsMouseDown","handleClicked","options","target","_a","setInitialFocus","indexToFocus","handleFocusPreceding","focusableElements","el","currentIndex","previousIndex","handleKeyboardNavigation","option","newIndex","getRadioOptions","radioGroup","handleFocus","handleKeyDown","handleMouseDown","handleMouseUp","RadioGroup","childrenClassName","hideInputs","groupId","groupName","processedOptions","acc","item","React","child","useAutoExpand","autoExpand","textarea","adjustHeight","textareaVariants","textareaDefaults","CharacterCount","maxLength","characterCount","setCharacterCount","updateCharacterCount","updatedCharacterCount","isError","Textarea","hideResizeHandle","characterLimit","adjustedHideResizeHandle","u","n","y","p","g","r","f","o","i","c","l","h","s","t","m","a","st","x","X","d","P","B","F","S","Q","rt","d$1","R","q","A","L","M","T","j","$","N","w","V","b$1","Z","U","c$1","b","C","G","nt","v","_","K","W","z","D","tt","et","Y","testButton","tv","TestButton","label","design","icon"],"mappings":";;;AAGA,SAAwBA,KAAc;AACpC,QAAM,CAACC,GAAaC,CAAc,IAAIC,EAAS,CAAC;AAEhD,SAAAC,EAAU,MAAM;AACR,UAAAC,IAAW,YAAY,MAAM;AACjC,MAAAH,EAAe,CAACI,OAAeA,IAAY,KAAK,CAAC;AAAA,OAChD,GAAG;AAEC,WAAA,MAAM,cAAcD,CAAQ;AAAA,EACrC,GAAG,EAAE,GAGH,gBAAAE,EAAC,OAAI,EAAA,WAAU,iFACZ,UAAA,CAAC,GAAG,GAAG,CAAC,EAAE,IAAI,CAACC,MACd,gBAAAD;AAAA,IAAC;AAAA,IAAA;AAAA,MAEC,WAAWE;AAAA,QACT;AAAA,QACAR,MAAgBO,KAAS;AAAA,MAAA;AAAA,IAC3B;AAAA,IAJKA;AAAA,EAMR,CAAA,GACH;AAEJ;AC3BO,MAAME,KAAiB;AAAA,EAC5B,MAAM;AAAA,EACN,SAAS;AAAA,EACT,WAAW;AAAA,EACX,UAAU;AAAA,EACV,SAAS;AAAA,EACT,MAAM;AAAA,EACN,QAAQ;AACV,GAGaC,KAAe;AAAA,EAC1B,UAAU;AAAA,EACV,QAAQ;AAAA,EACR,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,MAAM;AAAA,EACN,MAAM;AACR,GAGaC,KAAkB;AAAA,EAC7B,MAAM;AAAA,EACN,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,MAAM;AACR,GASaC,IAAiC;AAAA,EAC5C,SAAS;AAAA,EACT,MAAM;AAAA,EACN,SAAS;AACX;AC5BA,SAAwBC,GAAO;AAAA,EAC7B,SAAAC,IAAUF,EAAe;AAAA,EACzB,MAAAG;AAAA,EACA,SAAAC,IAAUJ,EAAe;AAAA,EACzB,SAAAK;AAAA,EACA,QAAAC;AAAA,EACA,WAAAC;AAAA,EACA,MAAAC,IAAO;AAAA,EACP,WAAAC;AAAA,EACA,GAAGC;AACL,GAAgB;AACV,MAAAC;AACA,EAAAT,MAAY,UAAU,CAACC,IAEVQ,IAAA,WAEfA,IAAeR,KAAQH,EAAe;AAMxC,QAAMY,IAAgBhB;AAAA,IAFpB;AAAA,IAIAC,GAAeK,CAAO;AAAA,IACtBJ,GAAaa,CAAY;AAAA,IACzBZ,GAAgBK,CAAO;AAAA,IACvBC,KAAW;AAAA,IACXC,KAAU;AAAA,IACVG;AAAA,EACF;AAGE,SAAA,gBAAAI;AAAA,IAAC;AAAA,IAAA;AAAA,MACE,GAAGH;AAAA,MACJ,MAAMJ,IAAS,SAASI,EAAK;AAAA,MAC7B,cAAYA,EAAK,YAAY,MAAKH,KAAA,gBAAAA,EAAY;AAAA,MAC9C,oBAAkBG,EAAK,kBAAkB,MAAKH,KAAA,gBAAAA,EAAY;AAAA,MAC1D,iBAAeG,EAAK,YAAYL;AAAA,MAChC,aAAWA;AAAA,MACX,MAAAG;AAAA,MACA,WAAWI;AAAA,MAEV,UAAA;AAAA,QAAAP,uBAAYlB,IAAY,EAAA;AAAA,QACzB,gBAAAO,EAAC,UAAK,WAAWE,EAAKS,KAAW,WAAW,GAAI,YAAK,UAAS;AAAA,QAE7DC,KAAU,CAACI,EAAK,YACf,gBAAAhB;AAAA,UAAC;AAAA,UAAA;AAAA,YACE,GAAGa;AAAA,YACJ,eAAa;AAAA,YACb,MAAMD;AAAA,YACN,SAAQC,KAAA,gBAAAA,EAAW,WAAU;AAAA,YAC7B,MAAKA,KAAA,gBAAAA,EAAW,QAAO;AAAA,YACvB,WAAU;AAAA,UAAA;AAAA,QAAA;AAAA,MACZ;AAAA,IAAA;AAAA,EAEJ;AAEJ;ACvEA,SAAwBO,GAAM,EAAE,MAAAX,IAAO,IAAI,OAAAY,IAAQ,kBAAqD;AAEpG,SAAA,gBAAArB,EAAC,OAAI,EAAA,OAAOS,GAAM,QAAQA,GAAM,WAAW,UAAU,SAAQ,aAAY,OAAM,8BAC7E,UAAA,gBAAAT;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,GAAE;AAAA,MACF,MAAMqB;AAAA,MACN,UAAS;AAAA,MACT,UAAS;AAAA,IAAA;AAAA,EAAA,GAEb;AAEJ;ACTO,SAASC,GAAyBC,GAAY;AACnD,QAAM,CAACC,GAAuBC,CAAwB,IAAI7B,EAAiB,EAAE,GAEvE8B,IAAwCC,EAAY,CAACC,MAAoC;AAC7F,QAAIC,IAAiBD,GACjBP,IAAQ;AACL,WAAAQ,KAAkB,CAACR,KAAO;AAC/B,YAAMS,IAAkB,OAAO,iBAAiBD,CAAc,EAAE;AAChE,MAAIC,KAAmBA,MAAoB,iBAAiBA,MAAoB,uBACtET,IAAAS,IAEVD,IAAiBA,EAAe;AAAA,IAAA;AAElC,WAAOR,KAAS;AAAA,EAClB,GAAG,EAAE;AAEL,SAAAxB,EAAU,MAAM;AACR,UAAAkC,IAAW,SAAS,eAAeR,CAAE;AAC3C,QAAIQ,GAAU;AACN,YAAAD,IAAkBJ,EAAsCK,EAAS,aAAa;AACpF,MAAAN,EAAyBK,CAAe;AAAA,IAAA;AAAA,EAC1C,GACC,CAACP,GAAIG,CAAqC,CAAC,GAEvCF;AACT;ACZA,SAAwBQ,GAAS;AAAA,EAC/B,KAAAC;AAAA,EACA,IAAAV;AAAA,EACA,MAAAd,IAAO;AAAA,EACP,OAAAY;AAAA,EACA,QAAAa,IAAS;AAAA,EACT,SAAAxB,IAAU;AAAA,EACV,SAAAyB,IAAU;AAAA,EACV,iBAAAC;AAAA,EACA,UAAAC;AAAA,EACA,WAAAtB,IAAY;AAAA,EACZ,GAAGuB;AACL,GAAkB;AAChB,QAAMC,IAAcC,EAAM,GACpBC,IAAaC,GAAQ,MAAMnB,KAAM,YAAYgB,CAAW,IAAI,CAAChB,GAAIgB,CAAW,CAAC,GAC7EI,IAAwBrB,GAAyBmB,CAAU,GAC3D,CAACG,GAAWC,CAAY,IAAIjD,EAASuC,CAAO;AAElD,EAAAtC,EAAU,MAAM;AACd,IAAAgD,EAAaV,CAAO;AAAA,EAAA,GACnB,CAACA,CAAO,CAAC;AAEZ,QAAMW,IAAe,MAAM;AACzB,IAAKT,MACHQ,EAAa,CAACD,CAAS,GACvBR,KAAA,QAAAA,EAAkB,CAACQ;AAAA,EAEvB,GAEMG,IAAkB,CAACC,MAA8C;AACjE,IAAAA,EAAE,QAAQ,QACZA,EAAE,eAAe,GACJF,EAAA;AAAA,EAEjB,GAEMG,IAAkB/C;AAAA,IACtB;AAAA,IACAQ,KAAW;AAAA,IACX2B,KAAY;AAAA,IACZ,CAACA,KAAY;AAAA,IACbtB;AAAA,EACF;AAGE,SAAA,gBAAAf;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,IAAIyC;AAAA,MACJ,MAAK;AAAA,MACL,KAAAR;AAAA,MACA,UAAU;AAAA,MACV,MAAK;AAAA,MACL,SAASa;AAAA,MACT,gBAAcF;AAAA,MACd,iBAAeP;AAAA,MACf,kBAAkBU;AAAA,MAClB,OAAO;AAAA,QACL,OAAOtC;AAAA,QACP,QAAQA;AAAA,QACR,OAAAY;AAAA,QACA,iBAAiBuB,KAAaV,IAAS,iBAAiB;AAAA,MAC1D;AAAA,MACA,WAAWe;AAAA,MACV,GAAGX;AAAA,MAEH,eAAc,gBAAAtC,EAAAoB,IAAA,EAAM,MAAAX,GAAY,OAAOyB,IAASS,IAAwB,OAAW,CAAA;AAAA,IAAA;AAAA,EACtF;AAEJ;AClFO,MAAMO,KAAgB;AAAA,EAC3B,MAAM;AAAA,EACN,SACE;AAAA,EACF,WACE;AAAA,EACF,SACE;AACJ,GAGa7C,KAAkB;AAAA,EAC7B,MAAM;AAAA,EACN,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,MAAM;AACR,GAQa8C,KAA+B;AAAA,EAC1C,SAAS;AAAA,EACT,SAAS;AACX;AClBA,SAAwBC,EAAkB,EAAE,WAAAC,GAAW,MAAAvC,GAAM,SAAAwC,KAAmC;AAiC9F,SAhCAzD,EAAU,MAAM;AACR,UAAA+B,IAAU,SAAS,eAAeyB,CAAS;AACjD,QAAKzB,GAGD;AAAA,UAAA,CAAC0B,KAAWxC,MAAS,SAAS;AAChC,QAAAc,EAAQ,gBAAgB,YAAY;AACpC;AAAA,MAAA;AAEE,UAAA,CAAC0B,KAAWxC,MAAS,WAAW;AAClC,QAAAc,EAAQ,gBAAgB,cAAc;AACtC;AAAA,MAAA;AAGF,aAAAA,EAAQ,aAAa,oBAAoB,GAAGyB,CAAS,IAAIvC,CAAI,UAAU,GACvEc,EAAQ,aAAa,gBAAgBd,MAAS,UAAU,SAAS,OAAO,GAEpEA,MAAS,WACHc,EAAA,aAAa,cAAc,MAAM,GAEvCd,MAAS,aACHc,EAAA,aAAa,gBAAgB,MAAM,GAGtC,MAAM;AACX,QAAAA,EAAQ,gBAAgB,kBAAkB,GAC1CA,EAAQ,gBAAgB,cAAc,GACtCA,EAAQ,gBAAgB,YAAY,GACpCA,EAAQ,gBAAgB,cAAc;AAAA,MACxC;AAAA;AAAA,EACC,GAAA,CAACyB,GAAWvC,GAAMwC,CAAO,CAAC,GAExBA,IAKH,gBAAAnC;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,WAAWjB;AAAA,QACT;AAAA,QACAY,MAAS,WAAW;AAAA,QACpBA,MAAS,aAAa;AAAA,MACxB;AAAA,MACA,MAAK;AAAA,MAEJ,UAAA;AAAA,QAAAA,MAAS,UAAU,gBAAAd,EAACuD,IAAoB,CAAA,CAAA,sBAAMC,IAAa,EAAA;AAAA,QAC5D,gBAAAxD,EAAC,UAAK,IAAI,GAAGqD,CAAS,IAAIvC,CAAI,YAAa,UAAQwC,EAAA,CAAA;AAAA,MAAA;AAAA,IAAA;AAAA,EACrD,IAdO;AAgBX;AC9CA,SAAwBG,GAAM;AAAA,EAC5B,SAAAjD,IAAU2C,GAAc;AAAA,EACxB,SAAAzC;AAAA,EACA,iBAAAgD,IAAkB;AAAA,EAClB,cAAAC;AAAA,EACA,gBAAAC;AAAA,EACA,MAAA9C,IAAO;AAAA,EACP,WAAAC;AAAA,EACA,GAAGC;AACL,GAAe;AACb,QAAMO,IAAKiB,EAAM,GACX,CAACqB,GAAcC,CAAe,IAAIlE,EAAS,EAAK;AAGtD,MAAImE,IAAgBrD;AAChB,EAAAF,MAAY,aAAa,CAACE,MACZqD,IAAA,OAElBA,IAAgBA,KAAiBZ,GAAc;AAO/C,QAAMa,IAAe9D;AAAA,IAJnB;AAAA,IAEA;AAAA,IAKA,CAACwD,KAAmBR,GAAc1C,CAAO;AAAA,IACzC,CAACkD,KAAmBrD,GAAgB0D,CAAa;AAAA,IACjDjD,MAAS,cAAc;AAAA,IACvB,CAAC4C,KAAmB;AAAA,IACpBA,KAAmB;AAAA,IACnB3C;AAAA,EACF;AAEA,SACG,gBAAAI,EAAA,OAAA,EAAI,WAAWjB,EAAKwD,KAAmB,aAAa,GAAG,OAAO,EAAE,QAAQ1C,EAAK,QAAQ,OAAOA,EAAK,MAChG,GAAA,UAAA;AAAA,IAAA,gBAAAG,EAAC,SAAI,WAAWjB,EAAKY,MAAS,cAAc,UAAU,GACpD,UAAA;AAAA,MAAA,gBAAAd;AAAA,QAAC;AAAA,QAAA;AAAA,UACE,GAAGgB;AAAA,UACJ,IAAAO;AAAA,UACA,MAAMT,MAAS,cAAc+C,IAAe,SAAS/C;AAAA,UACrD,iBAAeE,EAAK;AAAA,UACpB,UAAU0C;AAAA,UACV,iBAAeA,KAAmB1C,EAAK,eAAe;AAAA,UACtD,cAAY2C,IAAe,KAAO;AAAA,UAClC,gBAAcC,IAAiB,KAAO;AAAA,UACtC,WAAWI;AAAA,QAAA;AAAA,MACb;AAAA,MACClD,MAAS,cACR,gBAAAd;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,SAAS,MAAM8D,EAAgB,CAACD,CAAY;AAAA,UAC5C,WAAU;AAAA,UACV,cAAW;AAAA,UACX,cAAYA,IAAe,YAAY;AAAA,UAEtC,UAAAA,sBAAgBI,IAAU,EAAA,MAAM,GAAI,CAAA,IAAK,gBAAAjE,EAACkE,IAAU,EAAA,MAAM,GAAI,CAAA;AAAA,QAAA;AAAA,MAAA;AAAA,IACjE,GAEJ;AAAA,IACC,CAACR,KAAoB,gBAAA1D,EAAAoD,GAAA,EAAkB,WAAW7B,GAAI,MAAK,SAAQ,SAASoC,GAAc;AAAA,IAC1F,CAACD,KAAoB,gBAAA1D,EAAAoD,GAAA,EAAkB,WAAW7B,GAAI,MAAK,WAAU,SAASqC,EAAgB,CAAA;AAAA,EAAA,GACjG;AAEJ;ACnEO,SAASO,GAAM;AAAA,EACpB,SAAAC,IAAU;AAAA,EACV,OAAAC,IAAQ;AAAA,EACR,WAAAtD,IAAY;AAAA,EACZ,UAAAuD;AAAA,EACA,aAAAC;AAAA,EACA,QAAAC;AAAA,EACA,SAAAC;AAAA,EACA,UAAAC;AAAA,EACA,GAAGpC;AACL,GAAe;AACb,QAAMf,IAAKiB,EAAM,GACXmC,IAAezE,EAAK,eAAekE,GAASrD,CAAS,GACrD6D,IAASL,IAAc,GAAGE,KAAWlD,CAAE,UAAU;AAEvD,SACG,gBAAAJ,EAAA,OAAA,EAAI,OAAO,EAAE,SAASiD,MAAY,WAAW,gBAAgB,QAAQ,OAAAC,EAAA,GAAS,WAAU,YACvF,UAAA;AAAA,IAAA,gBAAAlD,EAAC,SAAM,EAAA,WAAWwD,GAAc,SAAAF,GAAmB,GAAGnC,GACnD,UAAA;AAAA,MAAAoC;AAAA,MACAJ,KACE,gBAAAtE,EAAA,QAAA,EAAK,WAAU,iCAAgC,cAAW,YAAW,UAEtE,IAAA,CAAA;AAAA,IAAA,GAEJ;AAAA,IACCuE,KACC,gBAAAvE;AAAA,MAAC;AAAA,MAAA;AAAA,QACC,WAAU;AAAA,QACV,oBAAkB4E;AAAA,QAClB,cAAW;AAAA,QACX,OAAOL;AAAA,QAEP,4BAACM,IAAoB,CAAA,CAAA;AAAA,MAAA;AAAA,IACvB;AAAA,IAEDN,KACE,gBAAAvE,EAAA,OAAA,EAAI,IAAI4E,GAAQ,WAAU,WACxB,UACHL,GAAA;AAAA,IAEDC,KAAU,gBAAAxE,EAAC,QAAK,EAAA,WAAU,QAAQ,UAAOwE,EAAA,CAAA;AAAA,EAAA,GAC5C;AAEJ;AC3CgB,SAAAM,GAAW,EAAE,QAAAC,GAAQ,SAAA5C,GAAS,UAAA6C,GAAU,MAAAC,GAAM,UAAA5C,IAAW,IAAO,WAAAtB,IAAY,MAAuB;AACjH,QAAMmE,IAAc,iEAEdC,IAAc,MAAM;AACxB,IAAI9C,KACK2C,EAAA;AAAA,EACX,GAEMI,IAAelF;AAAA,IACnBgF;AAAA,IACA,CAAC/C,KAAW;AAAA,IACZ,CAACE,KAAY;AAAA,IACbA,KAAY;AAAA,IACZtB;AAAA,EACF;AAEE,SAAA,gBAAAf;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,IAAI+E;AAAA,MACJ,MAAK;AAAA,MACL,UAAU;AAAA,MACV,gBAAc5C;AAAA,MACd,iBAAeE;AAAA,MACf,oBAAkB,oBAAoB4C,CAAI;AAAA,MAC1C,mBAAiB,GAAGF,CAAM;AAAA,MAC1B,SAASI;AAAA,MACT,WAAWC;AAAA,MACX,OAAO;AAAA,QACL,OAAO;AAAA,QACP,QAAQ;AAAA,QACR,SAAS;AAAA,QACT,aAAa;AAAA,MACf;AAAA,MAEC,UACCjD,KAAA,gBAAAnC;AAAA,QAAC;AAAA,QAAA;AAAA,UACC,WAAWE,EAAK,wCAAwCmC,KAAY,eAAe,CAACA,KAAY,YAAY;AAAA,QAAA;AAAA,MAAA;AAAA,IAC9G;AAAA,EAEJ;AAEJ;ACpCO,SAASgD,EAAe;AAAA,EAC7B,OAAAC;AAAA,EACA,UAAAZ;AAAA,EACA,WAAA3D,IAAY;AAAA,EACZ,YAAAwE,IAAa;AAAA,EACb,UAAAP;AAAA,EACA,UAAA3C,IAAW;AAAA,EACX,WAAAmD,IAAY;AAAA,EACZ,aAAAC;AAAA,EACA,MAAAR;AACF,GAAwB;AAEtB,QAAMF,IAAS,SADJvC,EAAM,CACS,IAAI8C,CAAK,IAE7BxC,IAAe,MAAM;AACzB,IAAKT,KACH2C,KAAA,QAAAA,EAAWM;AAAA,EAEf;AAGE,SAAA,gBAAAnE;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,OAAOsE;AAAA,MACP,WAAWvF;AAAA,QACT;AAAA,QACAa;AAAA;AAAA,QAEAyE,KACE,wDACEnD,IAAW,sBAAsB,mBACnC;AAAA,QACFmD,KAAa,CAACD,KAAc,sBAAsBlD,IAAW,KAAK,yCAAyC;AAAA,QAC3GmD,KAAaD,KAAc;AAAA,QAC3BlD,KAAY;AAAA,MACd;AAAA,MACA,OAAO;AAAA,QACL,KAAK;AAAA,MACP;AAAA,MAEC,UAAA;AAAA,QAAA,CAACmD,KACA,gBAAAxF;AAAA,UAAC8E;AAAA,UAAA;AAAA,YACC,QAAAC;AAAA,YACA,MAAME,KAAQ;AAAA,YACd,SAASM;AAAA,YACT,UAAUzC;AAAA,YACV,UAAAT;AAAA,YACA,WAAWnC,EAAKsF,KAAa,EAAE;AAAA,UAAA;AAAA,QACjC;AAAA,QAEF,gBAAAxF;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,IAAIwF,IAAYT,IAAS;AAAA,YACzB,UAAUS,IAAY,KAAK;AAAA,YAC3B,MAAMA,IAAY,UAAU;AAAA,YAC5B,SAASA,IAAY1C,IAAe;AAAA,YACpC,gBAAe0C,IAAwBD,IAAa,SAAS,UAAlC;AAAA,YAC3B,iBAAeC,IAAYnD,IAAW;AAAA,YACtC,oBAAmBmD,IAAwBC,KAAe,oBAAoBR,CAAI,KAAnD;AAAA,YAC/B,mBAAiBO,IAAY,GAAGT,CAAM,WAAW;AAAA,YACjD,WAAW7E,EAAKsF,KAAa,aAAa,OAAOd,KAAa,YAAY,yBAAyB;AAAA,YAEnG,UAAA,gBAAA1E;AAAA,cAAC;AAAA,cAAA;AAAA,gBACC,IAAI,GAAG+E,CAAM;AAAA,gBACb,SAASS,IAAY,SAAY1C;AAAA,gBACjC,WAAW5C,EAAKmC,KAAY,sBAAsB,CAACA,KAAY,gBAAgB;AAAA,gBAE9E,UAAAqC;AAAA,cAAA;AAAA,YAAA;AAAA,UACH;AAAA,QAAA;AAAA,MACF;AAAA,IAAA;AAAA,EACF;AAEJ;ACpFgB,SAAAgB,GAAcnE,GAAYoE,GAA6B;AAGrE,QAAM,CAACC,GAAcC,CAAe,IAAIjG,EAAiB+F,CAAmB,GACtE,CAACG,GAAcC,CAAe,IAAInG,EAAiB,EAAE,GAErD,CAACoG,GAAaC,CAAc,IAAIrG,EAAkB,EAAK,GAEvDsG,IAAgBvE,EAAY,CAACwE,GAAwBlG,MAAkB;;AACrE,UAAAmG,IAASD,EAAQlG,CAAK;AAI5B,IADmBmG,EAAO,aAAa,UAAU,KAAKA,EAAO,aAAa,eAAe,MAAM,YAIvFC,IAAAF,EAAAlG,CAAK,MAAL,QAAAoG,EAAQ,SAChBN,EAAgB9F,CAAK;AAAA,EACvB,GAAG,EAAE,GAECqG,IAAkB3E;AAAA,IACtB,CAACqB,GAAUmD,MAA2B;;AAGhC,UAFJnD,EAAE,eAAe,GACbgD,KACA,CAACG,EAAQ,OAAQ;AAEf,YAAAI,IAAeZ,MAAwB,KAAKA,IAAsB;AAChE,OAAAU,IAAAF,EAAAI,CAAY,MAAZ,QAAAF,EAAe,SACvBR,EAAgBU,CAAY,GAGxBZ,MAAwB,MAC1BO,EAAcC,GAASI,CAAY;AAAA,IAEvC;AAAA,IACA,CAACZ,GAAqBK,GAAaE,CAAa;AAAA,EAClD,GAGMM,IAAuB7E;AAAA,IAC3B,CAACqB,MAAqB;;AAEhB,UAAA,CAACA,EAAE;AACL;AAGF,MAAAA,EAAE,eAAe;AACjB,YAAMyD,IAAoB,MAAM;AAAA,QAC9B,SAAS;AAAA,UACP;AAAA,QAAA;AAAA,MACF,EACA,OAAO,CAACC,MAAO,CAACA,EAAG,aAAa,UAAU,KAAKA,EAAG,YAAY,CAAC,GAC3DC,IAAeF,EAAkB,UAAU,CAACC,MAAOA,EAAG,OAAOnF,CAAE,GAC/DqF,IAAgBD,IAAe,IAAIA,IAAe,IAAIF,EAAkB,SAAS;AACrE,OAAAJ,IAAAI,EAAAG,CAAa,MAAb,QAAAP,EAAgB;AAAA,IACpC;AAAA,IACA,CAAC9E,CAAE;AAAA,EACL,GAEMsF,IAA2BlF;AAAA,IAC/B,CAACqB,GAAkBmD,MAA2B;;AACxC,UAAA,CAACA,EAAQ,OAAQ;AAGrB,YAAMC,IAASpD,EAAE;AAEjB,UAAI,CADkBmD,EAAQ,KAAK,CAACW,MAAWA,EAAO,OAAOV,EAAO,EAAE,EAClD;AAEd,YAAAO,IAAef,MAAiB,KAAKA,IAAe;AAC1D,UAAImB,IAAWJ;AAEf,cAAQ3D,EAAE,KAAK;AAAA,QACb,KAAK;AAAA,QACL,KAAK;AACH,UAAAA,EAAE,eAAe,GACjB+D,IAAWJ,IAAe,IAAIA,IAAe,IAAIR,EAAQ,SAAS;AAClE;AAAA,QAEF,KAAK;AAAA,QACL,KAAK;AACH,UAAAnD,EAAE,eAAe,GACL+D,KAAAJ,IAAe,KAAKR,EAAQ;AACxC;AAAA;AAAA,QAGF,KAAK;AACH,UAAAnD,EAAE,eAAe,GACjBkD,EAAcC,GAASQ,CAAY;AACnC;AAAA,QAEF,KAAK;AACH,UAAAH,EAAqBxD,CAAC;AACtB;AAAA,QAEF;AACE;AAAA,MAAA;AAGI,OAAAqD,IAAAF,EAAAY,CAAQ,MAAR,QAAAV,EAAW,SACnBR,EAAgBkB,CAAQ,GAEpBjB,MAAiB,MACnBI,EAAcC,GAASY,CAAQ;AAAA,IAEnC;AAAA,IACA,CAACnB,GAAcE,GAAcU,GAAsBN,CAAa;AAAA,EAClE,GAEMc,IAAkBrF,EAAY,MAAqB;AACvD,UAAMsF,IAAa,SAAS,cAAc,QAAQ1F,CAAE,uBAAuB;AACvE,WAAC0F,IAEE,MAAM,KAAKA,EAAW,iBAAiB,gBAAgB,CAAC,IAFvC,CAAC;AAAA,EAEsC,GAC9D,CAAC1F,CAAE,CAAC;AAEP,EAAA1B,EAAU,MAAM;AACd,UAAMoH,IAAa,SAAS,cAAc,QAAQ1F,CAAE,uBAAuB;AAC3E,QAAI,CAAC0F,EAAY;AAEjB,UAAMd,IAAUa,EAAgB,GAC1BE,IAAc,CAAClE,MAAasD,EAAgBtD,GAAGmD,CAAO,GACtDgB,IAAgB,CAACnE,MAAqB6D,EAAyB7D,GAAGmD,CAAO,GACzEiB,IAAkB,MAAMnB,EAAe,EAAI,GAC3CoB,IAAgB,MAAMpB,EAAe,EAAK;AAEvC,oBAAA,iBAAiB,WAAWkB,CAAa,GACvCF,EAAA,iBAAiB,SAASC,CAAW,GACrCD,EAAA,iBAAiB,aAAaG,CAAe,GAC/C,SAAA,iBAAiB,WAAWC,CAAa,GAC3C,MAAM;AACF,eAAA,oBAAoB,WAAWF,CAAa,GAC1CF,EAAA,oBAAoB,SAASC,CAAW,GACxCD,EAAA,oBAAoB,aAAaG,CAAe,GAClD,SAAA,oBAAoB,WAAWC,CAAa;AAAA,IACvD;AAAA,KACC,CAAC9F,GAAIyF,GAAiBV,GAAiBO,CAAwB,CAAC;AACrE;ACxHO,SAASS,GAAW;AAAA,EACzB,SAAAnB,IAAU,CAAC;AAAA,EACX,OAAAb;AAAA,EACA,UAAAN;AAAA,EACA,MAAAC;AAAA,EACA,UAAAP;AAAA,EACA,WAAA3D,IAAY;AAAA,EACZ,mBAAAwG,IAAoB;AAAA,EACpB,YAAAC,IAAa;AACf,GAAoB;AAClB,QAAMC,IAAUjF,EAAM,GAChBkF,IAAYzC,KAAQ,eAAewC,CAAO;AAChD,EAAA/B;AAAA,IACEgC;AAAA,IACAvB,EAAQ,UAAU,CAACW,MAAWA,MAAWxB,CAAK;AAAA,EAChD;AAGM,QAAAqC,IAAmBjF,GAAQ,MACxByD,EAAQ,OAAsB,CAACyB,GAAKd,OACrC,OAAOA,KAAW,WAEfc,EAAI,KAAK,CAACC,MAASA,EAAK,UAAUf,CAAM,KAC3Cc,EAAI,KAAK,EAAE,OAAOd,GAAQ,OAAOA,GAAQ,IAG3Cc,EAAI,KAAKd,CAAM,GAEVc,IACN,EAAE,GACJ,CAACzB,CAAO,CAAC;AAEZ,SACG,gBAAAhF,EAAA,OAAA,EAAI,IAAIuG,GAAW,MAAK,cAAa,UAAU,GAAG,WAAWxH,EAAKa,GAAW,oBAAoB,GAE/F,UAAA;AAAA,IAAA4G,EAAiB,SAAS,KACzBA,EAAiB,IAAI,CAACb,GAAQ7G,MAC5B,gBAAAD;AAAA,MAACqF;AAAA,MAAA;AAAA,QAEC,OAAOyB,EAAO;AAAA,QACd,YAAYxB,MAAUwB,EAAO;AAAA,QAC7B,UAAA9B;AAAA,QACA,MAAM0C;AAAA,QACN,UAAUZ,EAAO;AAAA,QACjB,aAAaA,EAAO;AAAA,QACpB,WAAWU;AAAA,QACX,WAAWD;AAAA,QAEV,UAAOT,EAAA;AAAA,MAAA;AAAA,MAVH,GAAGA,EAAO,KAAK,IAAI7G,CAAK;AAAA,IAAA,CAYhC;AAAA,IAGF0H,EAAiB,WAAW,KAC3BjD,KACAoD,GAAM,SAAS,IAAIpD,GAAU,CAACqD,MAExBD,GAAM,eAAeC,CAAK,KAAKA,EAAM,SAAS1C,IAE9C,gBAAArF;AAAA,MAACqF;AAAA,MAAA;AAAA,QACE,GAAG0C,EAAM;AAAA,QACV,WAAW7H,EAAKqH,GAAmBQ,EAAM,MAAM,SAAS;AAAA,QACxD,WAAWA,EAAM,MAAM,aAAaP;AAAA,QACpC,YAAYlC,MAAUyC,EAAM,MAAM;AAAA,QAClC,UAAA/C;AAAA,QACA,MAAM0C;AAAA,QAEL,YAAM,MAAM;AAAA,MAAA;AAAA,IACf,IAGG,IACR;AAAA,EAAA,GACL;AAEJ;AC3FgB,SAAAM,GAAczG,GAAY0G,GAAqB;AAC7D,EAAApI,EAAU,MAAM;AACR,UAAAqI,IAAW,SAAS,eAAe3G,CAAE;AAC3C,QAAI,CAAC2G;AACH;AAGF,QAAI,CAACD,GAAY;AACf,MAAAC,EAAS,MAAM,SAAS;AACxB;AAAA,IAAA;AAGF,UAAMC,IAAe,MAAM;AAEzB,MAAAD,EAAS,MAAM,SAAS,QACxBA,EAAS,MAAM,SAAS,GAAGA,EAAS,YAAY;AAAA,IAClD;AAEa,WAAAC,EAAA,GACJD,EAAA,iBAAiB,SAASC,CAAY,GACtCD,EAAA,iBAAiB,UAAUC,CAAY,GACzC,OAAA,iBAAiB,UAAUA,CAAY,GAEvC,MAAM;AACF,MAAAD,EAAA,oBAAoB,SAASC,CAAY,GACzCD,EAAA,oBAAoB,UAAUC,CAAY,GAC5C,OAAA,oBAAoB,UAAUA,CAAY;AAAA,IACnD;AAAA,EAAA,GACC,CAAC5G,GAAI0G,CAAU,CAAC;AACrB;AC/BO,MAAMG,KAAmB;AAAA,EAC9B,MAAM;AAAA,EACN,aACE;AAAA,EACF,SACE;AACJ,GAGa/H,KAAkB;AAAA,EAC7B,MAAM;AAAA,EACN,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,IAAI;AAAA,EACJ,MAAM;AACR,GAQagI,KAAqC;AAAA,EAChD,SAAS;AAAA,EACT,SAAS;AACX;AClBA,SAAwBC,GAAe,EAAE,WAAAjF,GAAW,WAAAkF,KAAkC;AACpF,QAAM,CAACC,GAAgBC,CAAiB,IAAI7I,EAAS,CAAC;AAEtD,SAAAC,EAAU,MAAM;AACR,UAAAqI,IAAW,SAAS,eAAe7E,CAAS;AAClD,QAAI,CAAC6E;AACH;AAGF,UAAMQ,IAAuB,MAAM;AAC3B,YAAAC,IAAwBT,EAAS,MAAM;AAC7C,MAAAO,EAAkBE,CAAqB;AACvC,YAAMC,IAAUD,KAAyBJ;AACzC,MAAAL,EAAS,aAAa,oBAAoB,GAAG7E,CAAS,kBAAkB,GACxE6E,EAAS,aAAa,gBAAgBU,IAAU,SAAS,OAAO,GAE5DA,IACOV,EAAA,aAAa,cAAc,MAAM,IAE1CA,EAAS,gBAAgB,YAAY;AAAA,IAEzC;AAEqB,WAAAQ,EAAA,GACZR,EAAA,iBAAiB,SAASQ,CAAoB,GACvDR,EAAS,aAAa,aAAa,OAAOK,CAAS,CAAC,GAE7C,MAAM;AACF,MAAAL,EAAA,oBAAoB,SAASQ,CAAoB,GAC1DR,EAAS,gBAAgB,WAAW,GACpCA,EAAS,gBAAgB,kBAAkB,GAC3CA,EAAS,gBAAgB,cAAc,GACvCA,EAAS,gBAAgB,YAAY;AAAA,IACvC;AAAA,EAAA,GACC,CAAC7E,GAAWkF,CAAS,CAAC,GAGvB,gBAAAvI;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,WAAWE;AAAA,QACT;AAAA,QACAsI,KAAkBD,KAAa;AAAA,QAC/BC,IAAiBD,KAAa;AAAA,MAChC;AAAA,MACA,MAAK;AAAA,MAEL,UAAC,gBAAApH,EAAA,QAAA,EAAK,IAAI,GAAGkC,CAAS,oBACnB,UAAA;AAAA,QAAAmF;AAAA,QAAe;AAAA,QAAID;AAAA,QAAU;AAAA,MAAA,EAChC,CAAA;AAAA,IAAA;AAAA,EACF;AAEJ;ACxCA,SAAwBM,GAAS;AAAA,EAC/B,SAAArI,IAAU6H,GAAiB;AAAA,EAC3B,SAAA3H;AAAA,EACA,iBAAAgD,IAAkB;AAAA,EAClB,cAAAC;AAAA,EACA,gBAAAC;AAAA,EACA,kBAAAkF,IAAmB;AAAA,EACnB,YAAAb,IAAa;AAAA,EACb,gBAAAc,IAAiB;AAAA,EACjB,WAAAhI;AAAA,EACA,GAAGC;AACL,GAAkB;AAChB,QAAMO,IAAKiB,EAAM;AACH,EAAAwF,GAAAzG,GAAI0G,KAAcvE,CAAe;AAG/C,MAAIK,IAAgBrD;AAChB,EAAAF,MAAY,aAAa,CAACE,MACZqD,IAAA,OAElBA,IAAgBA,KAAiBsE,GAAiB;AAElD,MAAIW,IAA2BF;AAC/B,GAAIpF,KAAoBlD,MAAY,eAAe,CAACsI,OACvBE,IAAA;AAM7B,QAAMhF,IAAe9D;AAAA,IAFnB;AAAA,IAIA,CAACwD,KAAmB0E,GAAiB5H,CAAO;AAAA,IAC5C,CAACkD,KAAmBrD,GAAgB0D,CAAa;AAAA,IACjD,CAACL,KAAmB;AAAA,IACpBA,KAAmB;AAAA,IACnBsF,KAA4B;AAAA,IAE5BjI;AAAA,EACF;AAEA,2BACG,OAAI,EAAA,WAAWb,EAAK,gBAAgBwD,KAAmB,aAAa,GACnE,UAAA;AAAA,IAAA,gBAAA1D;AAAA,MAAC;AAAA,MAAA;AAAA,QACE,GAAGgB;AAAA,QACJ,IAAAO;AAAA,QACA,iBAAeP,EAAK;AAAA,QACpB,UAAU0C;AAAA,QACV,iBAAeA,KAAmB1C,EAAK,eAAe;AAAA,QACtD,OAAO;AAAA,UACL,QAAQiH,IAAa,SAAS;AAAA,QAChC;AAAA,QACA,WAAWjE;AAAA,MAAA;AAAA,IACb;AAAA,IACC+E,IAAiB,KAAK,gBAAA/I,EAACsI,MAAe,WAAW/G,GAAI,WAAWwH,GAAgB;AAAA,IAChF,CAACrF,KAAoB,gBAAA1D,EAAAoD,GAAA,EAAkB,WAAW7B,GAAI,MAAK,SAAQ,SAASoC,GAAc;AAAA,IAC1F,CAACD,KAAoB,gBAAA1D,EAAAoD,GAAA,EAAkB,WAAW7B,GAAI,MAAK,WAAU,SAASqC,EAAgB,CAAA;AAAA,EAAA,GACjG;AAEJ;AC7EA,IAAIqF,MAAG,CAAAjG,MAAG,OAAO,UAAQ,MAAI,UAAQ,OAAO,QAAM,MAAI,IAAI,MAAMA,GAAE,EAAC,KAAI,CAAC,GAAEkG,OAAK,OAAO,UAAQ,MAAI,UAAQ,GAAGA,CAAC,EAAC,CAAC,IAAElG,GAAG,SAASA,GAAE;AAAC,MAAG,OAAO,UAAQ,IAAI,QAAO,QAAQ,MAAM,MAAK,SAAS;AAAE,QAAM,MAAM,yBAAuBA,IAAE,oBAAoB;AAAC,CAAC,GAAMmG,KAAE,CAAAnG,MAAGA,MAAI,KAAM,UAAQA,MAAI,KAAK,SAAOA,MAAI,IAAE,MAAIA,GAAEoG,IAAE,CAAApG,MAAG;AAAC,MAAG,CAACA,KAAG,OAAOA,KAAG,SAAS,QAAQ;AAAK,WAAQ,KAAKA,EAAE,QAAQ;AAAM,SAAQ;AAAI,GAAEqG,KAAE,CAACrG,GAAE,MAAI;AAAC,MAAGA,MAAI,EAAE,QAAQ;AAAK,MAAG,CAACA,KAAG,CAAC,EAAE,QAAQ;AAAM,MAAIkG,IAAE,OAAO,KAAKlG,CAAC,GAAEsG,IAAE,OAAO,KAAK,CAAC;AAAE,MAAGJ,EAAE,WAASI,EAAE,OAAO,QAAQ;AAAM,WAAQ,IAAE,GAAE,IAAEJ,EAAE,QAAO,KAAI;AAAC,QAAIK,IAAEL,EAAE,CAAC;AAAE,QAAG,CAACI,EAAE,SAASC,CAAC,KAAGvG,EAAEuG,CAAC,MAAI,EAAEA,CAAC,EAAE,QAAQ;AAAA,EAAK;AAAC,SAAQ;AAAI;AAA2B,SAASC,GAAExG,GAAE,GAAE;AAAC,WAAQkG,IAAE,GAAEA,IAAElG,EAAE,QAAOkG,KAAI;AAAC,QAAII,IAAEtG,EAAEkG,CAAC;AAAE,UAAM,QAAQI,CAAC,IAAEE,GAAEF,GAAE,CAAC,IAAE,EAAE,KAAKA,CAAC;AAAA,EAAE;AAAC;AAAwC,IAAIG,KAAE,IAAIzG,MAAI;AAAC,MAAI,IAAE,CAAA;AAAG,EAAAwG,GAAExG,GAAE,CAAC;AAAE,MAAIkG,IAAE,CAAA;AAAG,WAAQI,IAAE,GAAEA,IAAE,EAAE,QAAOA,IAAI,GAAEA,CAAC,KAAGJ,EAAE,KAAK,EAAEI,CAAC,CAAC;AAAE,SAAOJ;AAAC,GAAEQ,KAAE,CAAC1G,GAAE,MAAI;AAAC,MAAIkG,IAAE,CAAE;AAAC,WAAQI,KAAKtG,GAAE;AAAC,QAAI,IAAEA,EAAEsG,CAAC;AAAE,QAAGA,KAAK,GAAE;AAAC,UAAIC,IAAE,EAAED,CAAC;AAAE,YAAM,QAAQ,CAAC,KAAG,MAAM,QAAQC,CAAC,IAAEL,EAAEI,CAAC,IAAEG,GAAEF,GAAE,CAAC,IAAE,OAAO,KAAG,YAAU,OAAOA,KAAG,YAAU,KAAGA,IAAEL,EAAEI,CAAC,IAAEI,GAAE,GAAEH,CAAC,IAAEL,EAAEI,CAAC,IAAEC,IAAE,MAAI;AAAA,IAAE,MAAM,CAAAL,EAAEI,CAAC,IAAE;AAAA,EAAE;AAAC,WAAQA,KAAK,EAAE,CAAAA,KAAKtG,MAAIkG,EAAEI,CAAC,IAAE,EAAEA,CAAC;AAAG,SAAOJ;AAAC,GAAES,KAAE,QAAOC,KAAE,CAAA5G,MAAG,CAACA,KAAG,OAAOA,KAAG,WAASA,IAAEA,EAAE,QAAQ2G,IAAE,GAAG,EAAE,KAAM,GCAhnCL,IAAE,MAAKO,IAAE,MAAKT,KAAE,YAASE,KAAGO,MAAIA,IAAE,OAAO,yEAAgB,EAAE,KAAK,CAAAC,OAAIR,IAAEQ,GAAEA,EAAE,EAAE,MAAM,MAAI,IAAI,GAAED,IAAGE,KAAE,CAAAD,MAAG,CAAAZ,MAAG;AAAC,MAAGW,KAAG,CAACP,EAAE,QAAOJ;AAAE,MAAGI,GAAE;AAAC,QAAG,EAAC,SAAQ,GAAE,qBAAoBK,EAAC,IAAEL;AAAE,YAAQI,EAAEI,CAAC,IAAE,IAAEH,EAAE,EAAC,GAAGG,GAAE,QAAO,EAAC,OAAMA,EAAE,OAAM,aAAYA,EAAE,aAAY,gCAA+BA,EAAE,gCAA+B,wBAAuBA,EAAE,wBAAuB,GAAGA,EAAE,OAAM,EAAC,CAAC,GAAGZ,CAAC;AAAA,EAAC;AAAC,MAAG;AAAC,QAAG,EAAC,SAAQ,GAAE,qBAAoBS,EAAC,IAAEK,GAAE,gBAAgB;AAAE,WAAOV,IAAE,EAAC,SAAQ,GAAE,qBAAoBK,EAAC,IAAGD,EAAEI,CAAC,IAAE,IAAEH,EAAE,EAAC,GAAGG,GAAE,QAAO,EAAC,OAAMA,EAAE,OAAM,aAAYA,EAAE,aAAY,gCAA+BA,EAAE,gCAA+B,wBAAuBA,EAAE,wBAAuB,GAAGA,EAAE,OAAM,EAAC,CAAC,GAAGZ,CAAC;AAAA,EAAC,QAAM;AAAC,WAAOE,GAAG,GAACF;AAAA,EAAC;AAAC,GCAnoBe,KAAG,EAAC,SAAQ,IAAK,eAAc,CAAA,GAAG,oBAAmB,GAAK,GAAEC,IAAE,IAAIP,MAAI;AAAC,MAAIV,IAAE,CAAE;AAAC,EAAAkB,GAAER,GAAEV,CAAC;AAAE,MAAIa,IAAE;AAAG,WAAQM,IAAE,GAAEA,IAAEnB,EAAE,QAAOmB,IAAI,CAAAnB,EAAEmB,CAAC,MAAIN,MAAIA,KAAG,MAAKA,KAAGb,EAAEmB,CAAC;AAAG,SAAON,KAAG;AAAM;AAAE,SAASK,GAAER,GAAEV,GAAE;AAAC,WAAQa,IAAE,GAAEA,IAAEH,EAAE,QAAOG,KAAI;AAAC,QAAIM,IAAET,EAAEG,CAAC;AAAE,UAAM,QAAQM,CAAC,IAAED,GAAEC,GAAEnB,CAAC,IAAEmB,KAAGnB,EAAE,KAAKmB,CAAC;AAAA,EAAE;AAAC;AAAI,IAACC,IAAE,MAAKC,IAAE,CAAA,GAAGC,IAAE,IAAMC,IAAE,IAAIb,MAAI,CAAAV,MAAG;AAAC,MAAIa,IAAEI,EAAEP,CAAC;AAAE,SAAO,CAACG,KAAG,CAACb,EAAE,UAAQa,MAAI,CAACO,KAAGE,OAAKA,IAAE,IAAMF,IAAEL,GAAEM,CAAC,IAAGD,EAAEP,CAAC,KAAG;AAAO,GAAEW,KAAE,CAACd,GAAEV,MAAI;AAAC,WAAQa,KAAKb,EAAE,CAAAa,KAAKH,IAAEA,EAAEG,CAAC,IAAEI,EAAEP,EAAEG,CAAC,GAAEb,EAAEa,CAAC,CAAC,IAAEH,EAAEG,CAAC,IAAEb,EAAEa,CAAC;AAAE,SAAOH;AAAC,GAAEe,KAAG,CAACf,GAAEV,MAAI;AAAC,MAAG,EAAC,QAAOa,IAAE,MAAK,OAAMa,IAAI,CAAE,GAAC,UAASC,IAAE,CAAE,GAAC,kBAAiBC,IAAE,CAAE,GAAC,eAAcC,IAAE,CAAE,GAAC,iBAAgBC,IAAE,CAAE,EAAA,IAAEpB,GAAEI,IAAE,EAAC,GAAGE,IAAG,GAAGhB,EAAC,GAAE+B,IAAElB,KAAA,QAAAA,EAAG,OAAKI,EAAEJ,EAAE,MAAKH,KAAA,gBAAAA,EAAG,IAAI,IAAEA,KAAA,gBAAAA,EAAG,MAAKR,IAAEW,KAAA,QAAAA,EAAG,YAAU,CAACJ,EAAEI,EAAE,QAAQ,IAAEF,GAAEgB,GAAEd,EAAE,QAAQ,IAAEc,GAAEK,IAAEnB,KAAA,QAAAA,EAAG,mBAAiB,CAACJ,EAAEI,EAAE,eAAe,IAAE,EAAC,GAAGA,EAAE,iBAAgB,GAAGiB,EAAC,IAAEA;AAAE,GAACrB,EAAEK,EAAE,aAAa,KAAG,CAACK,GAAEL,EAAE,eAAcO,CAAC,MAAIC,IAAE,IAAKD,IAAEP,EAAE;AAAe,MAAImB,IAAExB,EAAEI,KAAA,gBAAAA,EAAG,KAAK,GAAEqB,IAAEzB,EAAEiB,CAAG,IAAE,CAAA,IAAG,EAAC,MAAKT,EAAEP,KAAA,gBAAAA,EAAG,MAAKuB,MAAGpB,KAAA,gBAAAA,EAAG,KAAI,GAAE,GAAGa,EAAG,GAAES,IAAEF,IAAEC,IAAEV,GAAE,EAAC,GAAGX,KAAA,gBAAAA,EAAG,MAAK,GAAEJ,EAAEyB,CAAC,IAAE,EAAC,MAAKxB,KAAA,gBAAAA,EAAG,KAAI,IAAEwB,CAAC,GAAEE,IAAE3B,EAAEI,KAAA,gBAAAA,EAAG,gBAAgB,IAAEe,IAAExB,GAAES,KAAA,gBAAAA,EAAG,kBAAiBe,CAAC,GAAES,IAAE,CAAAC,MAAK;AAAC,QAAG7B,EAAEP,CAAC,KAAGO,EAAEiB,CAAG,KAAGO,EAAE,QAAOV,EAAEQ,GAAEO,KAAA,gBAAAA,EAAK,OAAMA,KAAA,gBAAAA,EAAK,SAAS,EAAExB,CAAC;AAAE,QAAGsB,KAAG,CAAC,MAAM,QAAQA,CAAC,EAAE,OAAM,IAAI,UAAU,2DAA2D,OAAOA,CAAC,EAAE;AAAE,QAAGP,KAAG,CAAC,MAAM,QAAQA,CAAC,EAAE,OAAM,IAAI,UAAU,wDAAwD,OAAOA,CAAC,EAAE;AAAE,QAAIU,IAAE,CAACtC,GAAElG,GAAE6G,IAAE,CAAA,GAAGL,MAAI;AAAC,UAAIQ,IAAEH;AAAE,UAAG,OAAO7G,KAAG,UAAS;AAAC,YAAI0G,IAAED,GAAEzG,CAAC,EAAE,MAAM,GAAG;AAAE,iBAAQuG,IAAE,GAAEA,IAAEG,EAAE,QAAOH,IAAI,CAAAS,EAAE,KAAK,GAAGd,CAAC,IAAIQ,EAAEH,CAAC,CAAC,EAAE;AAAA,MAAE,WAAS,MAAM,QAAQvG,CAAC,EAAE,UAAQsG,IAAE,GAAEA,IAAEtG,EAAE,QAAOsG,IAAI,CAAAU,EAAE,KAAK,GAAGd,CAAC,IAAIlG,EAAEsG,CAAC,CAAC,EAAE;AAAA,eAAU,OAAOtG,KAAG,YAAU,OAAOwG,KAAG,YAAUA,KAAKxG,GAAE;AAAC,YAAIsG,IAAEtG,EAAEwG,CAAC;AAAE,YAAGF,KAAG,OAAOA,KAAG,UAAS;AAAC,cAAIC,IAAEE,GAAEH,CAAC,EAAE,MAAM,GAAG,GAAEF,IAAE,CAAA;AAAG,mBAAQK,IAAE,GAAEA,IAAEF,EAAE,QAAOE,IAAI,CAAAL,EAAE,KAAK,GAAGF,CAAC,IAAIK,EAAEE,CAAC,CAAC,EAAE;AAAE,UAAAO,EAAER,CAAC,IAAEQ,EAAER,CAAC,IAAEQ,EAAER,CAAC,EAAE,OAAOJ,CAAC,IAAEA;AAAA,QAAE,WAAS,MAAM,QAAQE,CAAC,KAAGA,EAAE,SAAO,GAAE;AAAC,cAAII,IAAE,CAAA;AAAG,mBAAQH,IAAE,GAAEA,IAAED,EAAE,QAAOC,IAAI,CAAAG,EAAE,KAAK,GAAGR,CAAC,IAAII,EAAEC,CAAC,CAAC,EAAE;AAAE,UAAAS,EAAER,CAAC,IAAEE;AAAA,QAAE;AAAA,MAAC;AAAC,aAAOM;AAAA,IAAC,GAAEyB,IAAE,CAACvC,GAAElG,IAAEmG,GAAEU,IAAE,MAAKL,IAAE,SAAO;AAAC,UAAIQ,IAAEhH,EAAEkG,CAAC;AAAE,UAAG,CAACc,KAAGN,EAAEM,CAAC,EAAE,QAAO;AAAK,UAAIV,KAAEE,KAAA,gBAAAA,EAAIN,QAAIqC,KAAA,gBAAAA,EAAMrC;AAAG,UAAGI,MAAI,KAAK,QAAO;AAAK,UAAIoC,IAAIC,GAAErC,CAAC,GAAEC,IAAE,MAAM,QAAQQ,EAAE,kBAAkB,KAAGA,EAAE,mBAAmB,SAAO,KAAGA,EAAE,uBAAqB,IAAKX,IAAE6B,KAAA,gBAAAA,EAAI/B,IAAGO,IAAE,CAAA;AAAG,UAAG,OAAOiC,KAAK,YAAUnC,EAAE,UAAO,CAACqC,GAAEC,EAAC,KAAI,OAAO,QAAQH,CAAG,GAAE;AAAC,YAAII,KAAG9B,EAAE6B,EAAC;AAAE,YAAGD,MAAI,WAAU;AAAC,UAAAxC,IAAEyC;AAAE;AAAA,QAAQ;AAAC,cAAM,QAAQ9B,EAAE,kBAAkB,KAAG,CAACA,EAAE,mBAAmB,SAAS6B,CAAC,MAAInC,IAAE+B,EAAEI,GAAEE,IAAGrC,GAAEI,CAAC;AAAA,MAAG;AAAC,UAAIkC,IAAEL,KAAK,QAAM,OAAOA,KAAK,WAASA,IAAIC,GAAEvC,CAAC,GAAEQ,IAAEI,EAAE+B,KAAG,OAAO;AAAE,aAAO,OAAOtC,KAAG,YAAU,OAAOI,KAAG,YAAUJ,EAAEI,CAAC,IAAEY,GAAEhB,GAAEG,CAAC,IAAEH,EAAE,SAAO,KAAGA,EAAE,KAAKG,CAAC,GAAEC,MAAI,SAAOJ,EAAE,KAAK,GAAG,IAAEA,KAAGG;AAAA,IAAC,GAAEoC,KAAE,MAAI;AAAC,UAAG,CAAC7C,EAAE,QAAO;AAAK,UAAID,IAAE,OAAO,KAAKC,CAAC,GAAEnG,IAAE,CAAA;AAAG,eAAQ6G,IAAE,GAAEA,IAAEX,EAAE,QAAOW,KAAI;AAAC,YAAIL,IAAEiC,EAAEvC,EAAEW,CAAC,GAAEV,CAAC;AAAE,QAAAK,KAAGxG,EAAE,KAAKwG,CAAC;AAAA,MAAE;AAAC,aAAOxG;AAAA,IAAC,GAAEiJ,KAAE,CAAC/C,GAAElG,MAAI;AAAC,UAAG,CAACmG,KAAG,OAAOA,KAAG,SAAS,QAAO;AAAK,UAAIU,IAAE,CAAE;AAAC,eAAQL,KAAKL,GAAE;AAAC,YAAIa,IAAEyB,EAAEjC,GAAEL,GAAED,GAAElG,CAAC,GAAEsG,IAAEJ,MAAI,UAAQ,OAAOc,KAAG,WAASA,IAAEA,KAAGA,EAAEd,CAAC;AAAE,QAAAI,KAAGO,EAAE,KAAKP,CAAC;AAAA,MAAE;AAAC,aAAOO;AAAA,IAAC,GAAEqC,IAAE,CAAA;AAAG,aAAQhD,KAAKqC,GAAI;AAAC,UAAIvI,IAAEuI,EAAIrC,CAAC;AAAE,MAAAlG,MAAI,WAASkJ,EAAEhD,CAAC,IAAElG;AAAA,IAAG;AAAC,QAAImJ,IAAE,CAACjD,GAAElG,MAAI;;AAAC,UAAI6G,IAAE,QAAO0B,KAAA,gBAAAA,EAAMrC,OAAI,WAAS,EAAC,CAACA,CAAC,IAAE7C,IAAAkF,EAAIrC,CAAC,MAAL,gBAAA7C,EAAQ,QAAO,IAAE,CAAE;AAAC,aAAO,EAAC,GAAG4E,GAAE,GAAGiB,GAAE,GAAGrC,GAAE,GAAG7G,EAAC;AAAA,IAAC,GAAEoJ,KAAE,CAAClD,IAAE,CAAE,GAAClG,MAAI;AAAC,UAAI6G,IAAE,CAAE,GAACL,IAAEN,EAAE;AAAO,eAAQc,IAAE,GAAEA,IAAER,GAAEQ,KAAI;AAAC,YAAG,EAAC,OAAMV,GAAE,WAAUI,GAAE,GAAGH,EAAC,IAAEL,EAAEc,CAAC,GAAEZ,IAAE,IAAKK,IAAE0C,EAAE,MAAKnJ,CAAC;AAAE,iBAAQ+I,KAAKxC,GAAE;AAAC,cAAIK,IAAEL,EAAEwC,CAAC,GAAEH,IAAEnC,EAAEsC,CAAC;AAAE,cAAG,MAAM,QAAQnC,CAAC;AAAG,gBAAG,CAACA,EAAE,SAASgC,CAAC,GAAE;AAAC,cAAAxC,IAAE;AAAM;AAAA,YAAK;AAAA,iBAAO;AAAC,iBAAIQ,KAAG,QAAMA,MAAI,QAASgC,KAAG,QAAMA,MAAI,IAAO;AAAS,gBAAGA,MAAIhC,GAAE;AAAC,cAAAR,IAAE;AAAM;AAAA,YAAK;AAAA,UAAC;AAAA,QAAC;AAAC,QAAAA,MAAIE,KAAGO,EAAE,KAAKP,CAAC,GAAEI,KAAGG,EAAE,KAAKH,CAAC;AAAA,MAAG;AAAC,aAAOG;AAAA,IAAC,GAAEwC,KAAG,CAAAnD,MAAG;AAAC,UAAIlG,IAAEoJ,GAAEf,GAAEnC,CAAC;AAAE,UAAG,CAAC,MAAM,QAAQlG,CAAC,EAAE,QAAOA;AAAE,UAAI6G,IAAE,CAAE,GAACL,IAAEgB;AAAE,eAAQR,IAAE,GAAEA,IAAEhH,EAAE,QAAOgH,KAAI;AAAC,YAAIV,IAAEtG,EAAEgH,CAAC;AAAE,YAAG,OAAOV,KAAG,SAAS,CAAAO,EAAE,OAAKL,EAAEK,EAAE,MAAKP,CAAC,EAAES,CAAC;AAAA,iBAAU,OAAOT,KAAG,SAAS,UAAQI,KAAKJ,EAAE,CAAAO,EAAEH,CAAC,IAAEF,EAAEK,EAAEH,CAAC,GAAEJ,EAAEI,CAAC,CAAC,EAAEK,CAAC;AAAA,MAAE;AAAC,aAAOF;AAAA,IAAC,GAAEyC,KAAG,CAAApD,MAAG;AAAC,UAAG4B,EAAE,SAAO,EAAE,QAAO;AAAK,UAAI9H,IAAE,CAAE,GAAC6G,IAAEsC,EAAE,MAAKjD,CAAC;AAAE,eAAQM,IAAE,GAAEA,IAAEsB,EAAE,QAAOtB,KAAI;AAAC,YAAG,EAAC,OAAMQ,IAAE,CAAE,GAAC,OAAMV,GAAE,WAAUoC,GAAI,GAAGnC,EAAC,IAAEuB,EAAEtB,CAAC;AAAE,YAAG,CAACE,EAAEH,CAAC,GAAE;AAAC,cAAIH,IAAE;AAAK,mBAAQK,KAAKF,GAAE;AAAC,gBAAIwC,IAAElC,EAAEJ,CAAC,GAAEG,IAAEL,EAAEE,CAAC;AAAE,gBAAGsC,MAAI,WAAS,MAAM,QAAQnC,CAAC,IAAE,CAACA,EAAE,SAASmC,CAAC,IAAEnC,MAAImC,IAAG;AAAC,cAAA3C,IAAE;AAAM;AAAA,YAAK;AAAA,UAAC;AAAC,cAAG,CAACA,EAAE;AAAA,QAAQ;AAAC,iBAAQA,IAAE,GAAEA,IAAEY,EAAE,QAAOZ,KAAI;AAAC,cAAIK,IAAEO,EAAEZ,CAAC;AAAE,UAAApG,EAAEyG,CAAC,MAAIzG,EAAEyG,CAAC,IAAE,CAAE,IAAEzG,EAAEyG,CAAC,EAAE,KAAK,CAACH,GAAEoC,CAAG,CAAC;AAAA,QAAE;AAAA,MAAC;AAAC,aAAO1I;AAAA,IAAC;AAAE,QAAG,CAAC0G,EAAEiB,CAAG,KAAG,CAACO,GAAE;AAAC,UAAIhC,IAAE,CAAA;AAAG,UAAG,OAAOkC,KAAG,YAAU,CAAC1B,EAAE0B,CAAC,GAAE;AAAC,YAAIpI,IAAEwH;AAAE,iBAAQX,KAAKuB,EAAE,CAAAlC,EAAEW,CAAC,IAAE,CAAAL,MAAG;AAAC,cAAIQ,IAAEqC,GAAG7C,CAAC,GAAEF,IAAEgD,GAAG9C,CAAC;AAAE,iBAAOxG,EAAEoI,EAAEvB,CAAC,GAAEoC,GAAEpC,GAAEL,CAAC,GAAEQ,IAAEA,EAAEH,CAAC,IAAE,QAAOP,IAAEA,EAAEO,CAAC,IAAE,QAAOL,KAAA,gBAAAA,EAAG,OAAMA,KAAA,gBAAAA,EAAG,SAAS,EAAEO,CAAC;AAAA,QAAC;AAAA,MAAE;AAAC,aAAOb;AAAA,IAAC;AAAC,WAAOsB,EAAEQ,GAAEgB,GAAG,GAACI,GAAEf,CAAC,GAAEE,KAAA,gBAAAA,EAAK,OAAMA,KAAA,gBAAAA,EAAK,SAAS,EAAExB,CAAC;AAAA,EAAC,GAAEwC,IAAE,MAAI;AAAC,QAAG,EAAE,CAACpD,KAAG,OAAOA,KAAG,UAAU,QAAO,OAAO,KAAKA,CAAC;AAAA,EAAC;AAAE,SAAOmC,EAAE,cAAYiB,EAAC,GAAGjB,EAAE,SAAOxB,GAAEwB,EAAE,OAAKN,GAAEM,EAAE,QAAMF,GAAEE,EAAE,WAASnC,GAAEmC,EAAE,kBAAgBL,GAAEK,EAAE,gBAAcR,GAAEQ,EAAE,mBAAiBD,GAAEC;AAAC;ACG1oI,MAAMkB,KAAaC,GAAG;AAAA,EAC3B,MAAM;AAAA,EACN,UAAU;AAAA,IACR,MAAM;AAAA,MACJ,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,OAAO;AAAA,IACT;AAAA,IACA,QAAQ;AAAA,MACN,eACE;AAAA,MACF,cACE;AAAA,MACF,cAAc;AAAA,MACd,aAAa;AAAA,MACb,aAAa;AAAA,MACb,cAAc;AAAA,MACd,eAAe;AAAA,IACjB;AAAA,IACA,UAAU;AAAA,MACR,MAAM;AAAA,IAAA;AAAA,EAEV;AAAA,EACA,kBAAkB;AAAA,IAChB;AAAA,MACE,QAAQ,CAAC,eAAe,aAAa;AAAA,MACrC,UAAU;AAAA,MACV,OAAO;AAAA,IACT;AAAA,IACA;AAAA,MACE,QAAQ;AAAA,MACR,UAAU;AAAA,MACV,OAAO;AAAA,IACT;AAAA,IACA;AAAA,MACE,QAAQ;AAAA,MACR,UAAU;AAAA,MACV,OAAO;AAAA,IACT;AAAA,IACA;AAAA,MACE,QAAQ;AAAA,MACR,UAAU;AAAA,MACV,OAAO;AAAA,IACT;AAAA,IACA;AAAA,MACE,QAAQ;AAAA,MACR,UAAU;AAAA,MACV,OAAO;AAAA,IACT;AAAA,IACA;AAAA,MACE,QAAQ;AAAA,MACR,UAAU;AAAA,MACV,OAAO;AAAA,IAAA;AAAA,EACT;AAEJ,CAAC,GAWYC,KAAa,CAAC;AAAA,EACzB,OAAAC;AAAA,EACA,MAAAlM;AAAA,EACA,QAAAmM;AAAA,EACA,UAAAvK,IAAW;AAAA,EACX,MAAAwK,IAAO;AAAA,EACP,GAAGvK;AACL,MAEI,gBAAAnB;AAAA,EAAC;AAAA,EAAA;AAAA,IACC,eAAa,eAAewL,CAAK;AAAA,IACjC,WAAWH,GAAW,EAAE,MAAA/L,GAAY,QAAAmM,GAAgB,UAAAvK,GAAoB;AAAA,IACvE,GAAGC;AAAA,IAGH,UAAA;AAAA,MAAAuK,6BAAW,UAAKA,EAAA,CAAA;AAAA,MAGjB,gBAAA7M,EAAC,UAAM,UAAM2M,EAAA,CAAA;AAAA,IAAA;AAAA,EAAA;AACf;","x_google_ignoreList":[18,19,20]}
@@ -1,7 +1,7 @@
1
- import './styles.lib.css';
2
1
  export * from './core/components/button';
3
2
  export * from './core/components/checkbox';
4
3
  export * from './core/components/input';
5
4
  export * from './core/components/label';
6
5
  export * from './core/components/radiogroup';
7
6
  export * from './core/components/textarea';
7
+ export * from './core/components/TestButton';
@@ -0,0 +1,64 @@
1
+ import React, { ButtonHTMLAttributes, ReactNode } from 'react';
2
+ import { type VariantProps } from 'tailwind-variants';
3
+ export declare const testButton: import("tailwind-variants").TVReturnType<{
4
+ size: {
5
+ large: string;
6
+ medium: string;
7
+ small: string;
8
+ };
9
+ design: {
10
+ outline_light: string;
11
+ outline_dark: string;
12
+ filled_light: string;
13
+ filled_dark: string;
14
+ filled_pink: string;
15
+ neutral_dark: string;
16
+ neutral_light: string;
17
+ };
18
+ disabled: {
19
+ true: string;
20
+ };
21
+ }, undefined, string, {
22
+ size: {
23
+ large: string;
24
+ medium: string;
25
+ small: string;
26
+ };
27
+ design: {
28
+ outline_light: string;
29
+ outline_dark: string;
30
+ filled_light: string;
31
+ filled_dark: string;
32
+ filled_pink: string;
33
+ neutral_dark: string;
34
+ neutral_light: string;
35
+ };
36
+ disabled: {
37
+ true: string;
38
+ };
39
+ }, undefined, import("tailwind-variants").TVReturnType<{
40
+ size: {
41
+ large: string;
42
+ medium: string;
43
+ small: string;
44
+ };
45
+ design: {
46
+ outline_light: string;
47
+ outline_dark: string;
48
+ filled_light: string;
49
+ filled_dark: string;
50
+ filled_pink: string;
51
+ neutral_dark: string;
52
+ neutral_light: string;
53
+ };
54
+ disabled: {
55
+ true: string;
56
+ };
57
+ }, undefined, string, unknown, unknown, undefined>>;
58
+ type TestButtonVariants = VariantProps<typeof testButton>;
59
+ export interface TestButtonProps extends TestButtonVariants, Omit<ButtonHTMLAttributes<HTMLButtonElement>, 'className'> {
60
+ label: string;
61
+ icon?: React.ReactNode;
62
+ }
63
+ export declare const TestButton: ({ label, size, design, disabled, icon, ...props }: TestButtonProps) => ReactNode;
64
+ export {};
@@ -0,0 +1 @@
1
+ export * from './TestButton';
@@ -1,4 +1,3 @@
1
- import './styles.lib.css';
2
1
  export * from './core/symbols';
3
2
  export { Slot } from './core/utilities/Slot';
4
3
  export { join } from './core/util/join';
package/dist/styles.css CHANGED
@@ -1 +1 @@
1
- @layer theme,base,components,utilities;@layer theme{@theme default{ --font-sans: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"; --font-serif: ui-serif, Georgia, Cambria, "Times New Roman", Times, serif; --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; --color-red-50: oklch(.971 .013 17.38); --color-red-100: oklch(.936 .032 17.717); --color-red-200: oklch(.885 .062 18.334); --color-red-300: oklch(.808 .114 19.571); --color-red-400: oklch(.704 .191 22.216); --color-red-500: oklch(.637 .237 25.331); --color-red-600: oklch(.577 .245 27.325); --color-red-700: oklch(.505 .213 27.518); --color-red-800: oklch(.444 .177 26.899); --color-red-900: oklch(.396 .141 25.723); --color-red-950: oklch(.258 .092 26.042); --color-orange-50: oklch(.98 .016 73.684); --color-orange-100: oklch(.954 .038 75.164); --color-orange-200: oklch(.901 .076 70.697); --color-orange-300: oklch(.837 .128 66.29); --color-orange-400: oklch(.75 .183 55.934); --color-orange-500: oklch(.705 .213 47.604); --color-orange-600: oklch(.646 .222 41.116); --color-orange-700: oklch(.553 .195 38.402); --color-orange-800: oklch(.47 .157 37.304); --color-orange-900: oklch(.408 .123 38.172); --color-orange-950: oklch(.266 .079 36.259); --color-amber-50: oklch(.987 .022 95.277); --color-amber-100: oklch(.962 .059 95.617); --color-amber-200: oklch(.924 .12 95.746); --color-amber-300: oklch(.879 .169 91.605); --color-amber-400: oklch(.828 .189 84.429); --color-amber-500: oklch(.769 .188 70.08); --color-amber-600: oklch(.666 .179 58.318); --color-amber-700: oklch(.555 .163 48.998); --color-amber-800: oklch(.473 .137 46.201); --color-amber-900: oklch(.414 .112 45.904); --color-amber-950: oklch(.279 .077 45.635); --color-yellow-50: oklch(.987 .026 102.212); --color-yellow-100: oklch(.973 .071 103.193); --color-yellow-200: oklch(.945 .129 101.54); --color-yellow-300: oklch(.905 .182 98.111); --color-yellow-400: oklch(.852 .199 91.936); --color-yellow-500: oklch(.795 .184 86.047); --color-yellow-600: oklch(.681 .162 75.834); --color-yellow-700: oklch(.554 .135 66.442); --color-yellow-800: oklch(.476 .114 61.907); --color-yellow-900: oklch(.421 .095 57.708); --color-yellow-950: oklch(.286 .066 53.813); --color-lime-50: oklch(.986 .031 120.757); --color-lime-100: oklch(.967 .067 122.328); --color-lime-200: oklch(.938 .127 124.321); --color-lime-300: oklch(.897 .196 126.665); --color-lime-400: oklch(.841 .238 128.85); --color-lime-500: oklch(.768 .233 130.85); --color-lime-600: oklch(.648 .2 131.684); --color-lime-700: oklch(.532 .157 131.589); --color-lime-800: oklch(.453 .124 130.933); --color-lime-900: oklch(.405 .101 131.063); --color-lime-950: oklch(.274 .072 132.109); --color-green-50: oklch(.982 .018 155.826); --color-green-100: oklch(.962 .044 156.743); --color-green-200: oklch(.925 .084 155.995); --color-green-300: oklch(.871 .15 154.449); --color-green-400: oklch(.792 .209 151.711); --color-green-500: oklch(.723 .219 149.579); --color-green-600: oklch(.627 .194 149.214); --color-green-700: oklch(.527 .154 150.069); --color-green-800: oklch(.448 .119 151.328); --color-green-900: oklch(.393 .095 152.535); --color-green-950: oklch(.266 .065 152.934); --color-emerald-50: oklch(.979 .021 166.113); --color-emerald-100: oklch(.95 .052 163.051); --color-emerald-200: oklch(.905 .093 164.15); --color-emerald-300: oklch(.845 .143 164.978); --color-emerald-400: oklch(.765 .177 163.223); --color-emerald-500: oklch(.696 .17 162.48); --color-emerald-600: oklch(.596 .145 163.225); --color-emerald-700: oklch(.508 .118 165.612); --color-emerald-800: oklch(.432 .095 166.913); --color-emerald-900: oklch(.378 .077 168.94); --color-emerald-950: oklch(.262 .051 172.552); --color-teal-50: oklch(.984 .014 180.72); --color-teal-100: oklch(.953 .051 180.801); --color-teal-200: oklch(.91 .096 180.426); --color-teal-300: oklch(.855 .138 181.071); --color-teal-400: oklch(.777 .152 181.912); --color-teal-500: oklch(.704 .14 182.503); --color-teal-600: oklch(.6 .118 184.704); --color-teal-700: oklch(.511 .096 186.391); --color-teal-800: oklch(.437 .078 188.216); --color-teal-900: oklch(.386 .063 188.416); --color-teal-950: oklch(.277 .046 192.524); --color-cyan-50: oklch(.984 .019 200.873); --color-cyan-100: oklch(.956 .045 203.388); --color-cyan-200: oklch(.917 .08 205.041); --color-cyan-300: oklch(.865 .127 207.078); --color-cyan-400: oklch(.789 .154 211.53); --color-cyan-500: oklch(.715 .143 215.221); --color-cyan-600: oklch(.609 .126 221.723); --color-cyan-700: oklch(.52 .105 223.128); --color-cyan-800: oklch(.45 .085 224.283); --color-cyan-900: oklch(.398 .07 227.392); --color-cyan-950: oklch(.302 .056 229.695); --color-sky-50: oklch(.977 .013 236.62); --color-sky-100: oklch(.951 .026 236.824); --color-sky-200: oklch(.901 .058 230.902); --color-sky-300: oklch(.828 .111 230.318); --color-sky-400: oklch(.746 .16 232.661); --color-sky-500: oklch(.685 .169 237.323); --color-sky-600: oklch(.588 .158 241.966); --color-sky-700: oklch(.5 .134 242.749); --color-sky-800: oklch(.443 .11 240.79); --color-sky-900: oklch(.391 .09 240.876); --color-sky-950: oklch(.293 .066 243.157); --color-blue-50: oklch(.97 .014 254.604); --color-blue-100: oklch(.932 .032 255.585); --color-blue-200: oklch(.882 .059 254.128); --color-blue-300: oklch(.809 .105 251.813); --color-blue-400: oklch(.707 .165 254.624); --color-blue-500: oklch(.623 .214 259.815); --color-blue-600: oklch(.546 .245 262.881); --color-blue-700: oklch(.488 .243 264.376); --color-blue-800: oklch(.424 .199 265.638); --color-blue-900: oklch(.379 .146 265.522); --color-blue-950: oklch(.282 .091 267.935); --color-indigo-50: oklch(.962 .018 272.314); --color-indigo-100: oklch(.93 .034 272.788); --color-indigo-200: oklch(.87 .065 274.039); --color-indigo-300: oklch(.785 .115 274.713); --color-indigo-400: oklch(.673 .182 276.935); --color-indigo-500: oklch(.585 .233 277.117); --color-indigo-600: oklch(.511 .262 276.966); --color-indigo-700: oklch(.457 .24 277.023); --color-indigo-800: oklch(.398 .195 277.366); --color-indigo-900: oklch(.359 .144 278.697); --color-indigo-950: oklch(.257 .09 281.288); --color-violet-50: oklch(.969 .016 293.756); --color-violet-100: oklch(.943 .029 294.588); --color-violet-200: oklch(.894 .057 293.283); --color-violet-300: oklch(.811 .111 293.571); --color-violet-400: oklch(.702 .183 293.541); --color-violet-500: oklch(.606 .25 292.717); --color-violet-600: oklch(.541 .281 293.009); --color-violet-700: oklch(.491 .27 292.581); --color-violet-800: oklch(.432 .232 292.759); --color-violet-900: oklch(.38 .189 293.745); --color-violet-950: oklch(.283 .141 291.089); --color-purple-50: oklch(.977 .014 308.299); --color-purple-100: oklch(.946 .033 307.174); --color-purple-200: oklch(.902 .063 306.703); --color-purple-300: oklch(.827 .119 306.383); --color-purple-400: oklch(.714 .203 305.504); --color-purple-500: oklch(.627 .265 303.9); --color-purple-600: oklch(.558 .288 302.321); --color-purple-700: oklch(.496 .265 301.924); --color-purple-800: oklch(.438 .218 303.724); --color-purple-900: oklch(.381 .176 304.987); --color-purple-950: oklch(.291 .149 302.717); --color-fuchsia-50: oklch(.977 .017 320.058); --color-fuchsia-100: oklch(.952 .037 318.852); --color-fuchsia-200: oklch(.903 .076 319.62); --color-fuchsia-300: oklch(.833 .145 321.434); --color-fuchsia-400: oklch(.74 .238 322.16); --color-fuchsia-500: oklch(.667 .295 322.15); --color-fuchsia-600: oklch(.591 .293 322.896); --color-fuchsia-700: oklch(.518 .253 323.949); --color-fuchsia-800: oklch(.452 .211 324.591); --color-fuchsia-900: oklch(.401 .17 325.612); --color-fuchsia-950: oklch(.293 .136 325.661); --color-pink-50: oklch(.971 .014 343.198); --color-pink-100: oklch(.948 .028 342.258); --color-pink-200: oklch(.899 .061 343.231); --color-pink-300: oklch(.823 .12 346.018); --color-pink-400: oklch(.718 .202 349.761); --color-pink-500: oklch(.656 .241 354.308); --color-pink-600: oklch(.592 .249 .584); --color-pink-700: oklch(.525 .223 3.958); --color-pink-800: oklch(.459 .187 3.815); --color-pink-900: oklch(.408 .153 2.432); --color-pink-950: oklch(.284 .109 3.907); --color-rose-50: oklch(.969 .015 12.422); --color-rose-100: oklch(.941 .03 12.58); --color-rose-200: oklch(.892 .058 10.001); --color-rose-300: oklch(.81 .117 11.638); --color-rose-400: oklch(.712 .194 13.428); --color-rose-500: oklch(.645 .246 16.439); --color-rose-600: oklch(.586 .253 17.585); --color-rose-700: oklch(.514 .222 16.935); --color-rose-800: oklch(.455 .188 13.697); --color-rose-900: oklch(.41 .159 10.272); --color-rose-950: oklch(.271 .105 12.094); --color-slate-50: oklch(.984 .003 247.858); --color-slate-100: oklch(.968 .007 247.896); --color-slate-200: oklch(.929 .013 255.508); --color-slate-300: oklch(.869 .022 252.894); --color-slate-400: oklch(.704 .04 256.788); --color-slate-500: oklch(.554 .046 257.417); --color-slate-600: oklch(.446 .043 257.281); --color-slate-700: oklch(.372 .044 257.287); --color-slate-800: oklch(.279 .041 260.031); --color-slate-900: oklch(.208 .042 265.755); --color-slate-950: oklch(.129 .042 264.695); --color-gray-50: oklch(.985 .002 247.839); --color-gray-100: oklch(.967 .003 264.542); --color-gray-200: oklch(.928 .006 264.531); --color-gray-300: oklch(.872 .01 258.338); --color-gray-400: oklch(.707 .022 261.325); --color-gray-500: oklch(.551 .027 264.364); --color-gray-600: oklch(.446 .03 256.802); --color-gray-700: oklch(.373 .034 259.733); --color-gray-800: oklch(.278 .033 256.848); --color-gray-900: oklch(.21 .034 264.665); --color-gray-950: oklch(.13 .028 261.692); --color-zinc-50: oklch(.985 0 0); --color-zinc-100: oklch(.967 .001 286.375); --color-zinc-200: oklch(.92 .004 286.32); --color-zinc-300: oklch(.871 .006 286.286); --color-zinc-400: oklch(.705 .015 286.067); --color-zinc-500: oklch(.552 .016 285.938); --color-zinc-600: oklch(.442 .017 285.786); --color-zinc-700: oklch(.37 .013 285.805); --color-zinc-800: oklch(.274 .006 286.033); --color-zinc-900: oklch(.21 .006 285.885); --color-zinc-950: oklch(.141 .005 285.823); --color-neutral-50: oklch(.985 0 0); --color-neutral-100: oklch(.97 0 0); --color-neutral-200: oklch(.922 0 0); --color-neutral-300: oklch(.87 0 0); --color-neutral-400: oklch(.708 0 0); --color-neutral-500: oklch(.556 0 0); --color-neutral-600: oklch(.439 0 0); --color-neutral-700: oklch(.371 0 0); --color-neutral-800: oklch(.269 0 0); --color-neutral-900: oklch(.205 0 0); --color-neutral-950: oklch(.145 0 0); --color-stone-50: oklch(.985 .001 106.423); --color-stone-100: oklch(.97 .001 106.424); --color-stone-200: oklch(.923 .003 48.717); --color-stone-300: oklch(.869 .005 56.366); --color-stone-400: oklch(.709 .01 56.259); --color-stone-500: oklch(.553 .013 58.071); --color-stone-600: oklch(.444 .011 73.639); --color-stone-700: oklch(.374 .01 67.558); --color-stone-800: oklch(.268 .007 34.298); --color-stone-900: oklch(.216 .006 56.043); --color-stone-950: oklch(.147 .004 49.25); --color-black: #000; --color-white: #fff; --spacing: .25rem; --breakpoint-sm: 40rem; --breakpoint-md: 48rem; --breakpoint-lg: 64rem; --breakpoint-xl: 80rem; --breakpoint-2xl: 96rem; --container-3xs: 16rem; --container-2xs: 18rem; --container-xs: 20rem; --container-sm: 24rem; --container-md: 28rem; --container-lg: 32rem; --container-xl: 36rem; --container-2xl: 42rem; --container-3xl: 48rem; --container-4xl: 56rem; --container-5xl: 64rem; --container-6xl: 72rem; --container-7xl: 80rem; --text-xs: .75rem; --text-xs--line-height: calc(1 / .75); --text-sm: .875rem; --text-sm--line-height: calc(1.25 / .875); --text-base: 1rem; --text-base--line-height: 1.5 ; --text-lg: 1.125rem; --text-lg--line-height: calc(1.75 / 1.125); --text-xl: 1.25rem; --text-xl--line-height: calc(1.75 / 1.25); --text-2xl: 1.5rem; --text-2xl--line-height: calc(2 / 1.5); --text-3xl: 1.875rem; --text-3xl--line-height: 1.2 ; --text-4xl: 2.25rem; --text-4xl--line-height: calc(2.5 / 2.25); --text-5xl: 3rem; --text-5xl--line-height: 1; --text-6xl: 3.75rem; --text-6xl--line-height: 1; --text-7xl: 4.5rem; --text-7xl--line-height: 1; --text-8xl: 6rem; --text-8xl--line-height: 1; --text-9xl: 8rem; --text-9xl--line-height: 1; --font-weight-thin: 100; --font-weight-extralight: 200; --font-weight-light: 300; --font-weight-normal: 400; --font-weight-medium: 500; --font-weight-semibold: 600; --font-weight-bold: 700; --font-weight-extrabold: 800; --font-weight-black: 900; --tracking-tighter: -.05em; --tracking-tight: -.025em; --tracking-normal: 0em; --tracking-wide: .025em; --tracking-wider: .05em; --tracking-widest: .1em; --leading-tight: 1.25; --leading-snug: 1.375; --leading-normal: 1.5; --leading-relaxed: 1.625; --leading-loose: 2; --radius-xs: .125rem; --radius-sm: .25rem; --radius-md: .375rem; --radius-lg: .5rem; --radius-xl: .75rem; --radius-2xl: 1rem; --radius-3xl: 1.5rem; --radius-4xl: 2rem; --shadow-2xs: 0 1px rgb(0 0 0 / .05); --shadow-xs: 0 1px 2px 0 rgb(0 0 0 / .05); --shadow-sm: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1); --shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1); --shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1); --shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1); --shadow-2xl: 0 25px 50px -12px rgb(0 0 0 / .25); --inset-shadow-2xs: inset 0 1px rgb(0 0 0 / .05); --inset-shadow-xs: inset 0 1px 1px rgb(0 0 0 / .05); --inset-shadow-sm: inset 0 2px 4px rgb(0 0 0 / .05); --drop-shadow-xs: 0 1px 1px rgb(0 0 0 / .05); --drop-shadow-sm: 0 1px 2px rgb(0 0 0 / .15); --drop-shadow-md: 0 3px 3px rgb(0 0 0 / .12); --drop-shadow-lg: 0 4px 4px rgb(0 0 0 / .15); --drop-shadow-xl: 0 9px 7px rgb(0 0 0 / .1); --drop-shadow-2xl: 0 25px 25px rgb(0 0 0 / .15); --ease-in: cubic-bezier(.4, 0, 1, 1); --ease-out: cubic-bezier(0, 0, .2, 1); --ease-in-out: cubic-bezier(.4, 0, .2, 1); --animate-spin: spin 1s linear infinite; --animate-ping: ping 1s cubic-bezier(0, 0, .2, 1) infinite; --animate-pulse: pulse 2s cubic-bezier(.4, 0, .6, 1) infinite; --animate-bounce: bounce 1s infinite; @keyframes spin { to { transform: rotate(360deg); } } @keyframes ping { 75%, 100% { transform: scale(2); opacity: 0; } } @keyframes pulse { 50% { opacity: .5; } } @keyframes bounce { 0%, 100% { transform: translateY(-25%); animation-timing-function: cubic-bezier(.8, 0, 1, 1); } 50% { transform: none; animation-timing-function: cubic-bezier(0, 0, .2, 1); } } --blur-xs: 4px; --blur-sm: 8px; --blur-md: 12px; --blur-lg: 16px; --blur-xl: 24px; --blur-2xl: 40px; --blur-3xl: 64px; --perspective-dramatic: 100px; --perspective-near: 300px; --perspective-normal: 500px; --perspective-midrange: 800px; --perspective-distant: 1200px; --aspect-video: 16 / 9; --default-transition-duration: .15s; --default-transition-timing-function: cubic-bezier(.4, 0, .2, 1); --default-font-family: var(--font-sans); --default-font-feature-settings: var(--font-sans--font-feature-settings); --default-font-variation-settings: var( --font-sans--font-variation-settings ); --default-mono-font-family: var(--font-mono); --default-mono-font-feature-settings: var( --font-mono--font-feature-settings ); --default-mono-font-variation-settings: var( --font-mono--font-variation-settings ); }@theme default inline reference{ --blur: 8px; --shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1); --shadow-inner: inset 0 2px 4px 0 rgb(0 0 0 / .05); --drop-shadow: 0 1px 2px rgb(0 0 0 / .1), 0 1px 1px rgb(0 0 0 / .06); --radius: .25rem; --max-width-prose: 65ch; }}@layer base{*,:after,:before,::backdrop,::file-selector-button{box-sizing:border-box;margin:0;padding:0;border:0 solid}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;font-family:var( --default-font-family, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji" );font-feature-settings:var(--default-font-feature-settings, normal);font-variation-settings:var( --default-font-variation-settings, normal );-webkit-tap-highlight-color:transparent}body{line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var( --default-mono-font-family, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace );font-feature-settings:var( --default-mono-font-feature-settings, normal );font-variation-settings:var( --default-mono-font-variation-settings, normal );font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea,::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;border-radius:0;background-color:transparent;opacity:1}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1;color:color-mix(in oklab,currentColor 50%,transparent)}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit,::-webkit-datetime-edit-year-field,::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field,::-webkit-datetime-edit-second-field,::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-meridiem-field{padding-block:0}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]),::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer utilities{@tailwind utilities;}@utility page{@apply min-h-screen w-screen;}@theme colors{ --color-background-light: var(--color-slate-100); --color-background-dark: var(--color-slate-900); --color-foreground-light: var(--color-slate-900); --color-foreground-dark: var(--color-slate-100); --color-accent-medium: var(--color-violet-400); --color-primary: var(--color-violet-400); --color-primary-foreground: var(--color-white); --color-secondary: var(--color-violet-200); --color-secondary-foreground: var(--color-black); --color-danger: var(--color-red-500); --color-danger-foreground: var(--color-white); --color-muted: var(--color-gray-200); --color-muted-foreground: var(--color-gray-800); --color-success: var(--color-green-500); --color-border: var( --color-slate-600 ); }.hide-number-input-arrows::-webkit-outer-spin-button,.hide-number-input-arrows::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.hide-number-input-arrows{-moz-appearance:textfield}.no-resize-handle::-webkit-resizer{display:none}
1
+ .hide-number-input-arrows::-webkit-outer-spin-button,.hide-number-input-arrows::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.hide-number-input-arrows{-moz-appearance:textfield}.no-resize-handle::-webkit-resizer{display:none}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@moondreamsdev/dreamer-ui",
3
- "version": "1.3.1",
3
+ "version": "1.3.3",
4
4
  "type": "module",
5
5
  "description": "A collection of Tailwind CSS components for React",
6
6
  "main": "dist/index.js",
@@ -17,7 +17,7 @@
17
17
  "require": "./dist/index.js"
18
18
  },
19
19
  "./components": {
20
- "types": "./dist/components.lib.d.ts",
20
+ "types": "./dist/components.lib.d.ts",
21
21
  "import": "./dist/components.esm.js",
22
22
  "require": "./dist/components.js"
23
23
  },
@@ -54,15 +54,18 @@
54
54
  },
55
55
  "devDependencies": {
56
56
  "@eslint/js": "^9.21.0",
57
+ "@tailwindcss/postcss": "^4.1.11",
57
58
  "@tailwindcss/vite": "^4.0.9",
58
59
  "@types/react": "^19.0.10",
59
60
  "@types/react-dom": "^19.0.4",
60
61
  "@vitejs/plugin-react-swc": "^3.8.0",
62
+ "autoprefixer": "^10.4.21",
61
63
  "eslint": "^9.21.0",
62
64
  "eslint-plugin-react-hooks": "^5.1.0",
63
65
  "eslint-plugin-react-refresh": "^0.4.19",
64
66
  "glob": "^11.0.3",
65
67
  "globals": "^15.15.0",
68
+ "postcss": "^8.5.6",
66
69
  "react": "^19.0.0",
67
70
  "react-dom": "^19.0.0",
68
71
  "tailwindcss": "^4.0.9",
@@ -70,5 +73,8 @@
70
73
  "typescript-eslint": "^8.24.1",
71
74
  "vite": "^6.2.0",
72
75
  "vite-plugin-dts": "^3.9.1"
76
+ },
77
+ "dependencies": {
78
+ "tailwind-variants": "^2.1.0"
73
79
  }
74
80
  }
package/dist/vite.svg DELETED
@@ -1 +0,0 @@
1
- <svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" aria-hidden="true" role="img" class="iconify iconify--logos" width="31.88" height="32" preserveAspectRatio="xMidYMid meet" viewBox="0 0 256 257"><defs><linearGradient id="IconifyId1813088fe1fbc01fb466" x1="-.828%" x2="57.636%" y1="7.652%" y2="78.411%"><stop offset="0%" stop-color="#41D1FF"></stop><stop offset="100%" stop-color="#BD34FE"></stop></linearGradient><linearGradient id="IconifyId1813088fe1fbc01fb467" x1="43.376%" x2="50.316%" y1="2.242%" y2="89.03%"><stop offset="0%" stop-color="#FFEA83"></stop><stop offset="8.333%" stop-color="#FFDD35"></stop><stop offset="100%" stop-color="#FFA800"></stop></linearGradient></defs><path fill="url(#IconifyId1813088fe1fbc01fb466)" d="M255.153 37.938L134.897 252.976c-2.483 4.44-8.862 4.466-11.382.048L.875 37.958c-2.746-4.814 1.371-10.646 6.827-9.67l120.385 21.517a6.537 6.537 0 0 0 2.322-.004l117.867-21.483c5.438-.991 9.574 4.796 6.877 9.62Z"></path><path fill="url(#IconifyId1813088fe1fbc01fb467)" d="M185.432.063L96.44 17.501a3.268 3.268 0 0 0-2.634 3.014l-5.474 92.456a3.268 3.268 0 0 0 3.997 3.378l24.777-5.718c2.318-.535 4.413 1.507 3.936 3.838l-7.361 36.047c-.495 2.426 1.782 4.5 4.151 3.78l15.304-4.649c2.372-.72 4.652 1.36 4.15 3.788l-11.698 56.621c-.732 3.542 3.979 5.473 5.943 2.437l1.313-2.028l72.516-144.72c1.215-2.423-.88-5.186-3.54-4.672l-25.505 4.922c-2.396.462-4.435-1.77-3.759-4.114l16.646-57.705c.677-2.35-1.37-4.583-3.769-4.113Z"></path></svg>