@nubisco/ui 1.0.5 → 1.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","names":["$emit","$slots","$slots","is","id","tabIndex","format","escapeHtml","toDisplayString","errorMessages","format","baseCompile","initFeatureFlags","errorMessages","warnMessages","getWarnMessage","VERSION","toDisplayString","escapeHtml","format","getCurrentInstance","$slots","$emit","$slots","$slots","$attrs"],"sources":["../src/components/AiLabel.d.ts","../src/components/AiLabel.vue","../src/components/AiLabel.vue","../src/components/Badge.d.ts","../src/components/Badge.vue","../src/components/Badge.vue","../src/components/Breadcrumbs.vue","../src/components/Breadcrumbs.vue","../src/types/Size.d.ts","../src/components/Button.d.ts","../src/utils/kebab2camel.helper.ts","../src/components/Icon.d.ts","../src/utils/str2kebab.helper.ts","../src/composables/useStableId.composable.ts","../src/components/Icon.vue","../src/components/Icon.vue","../src/components/Button.vue","../src/components/Button.vue","../src/components/Checkbox.vue","../src/components/Checkbox.vue","../src/components/ColorStrip.vue","../src/components/ColorStrip.vue","../src/types/Variants.d.ts","../src/components/FileUploader.d.ts","../src/components/FileUploader.vue","../src/components/FileUploader.vue","../src/components/Flag.vue","../src/components/Flag.vue","../src/components/Form.vue","../src/components/Form.vue","../src/components/Grid.d.ts","../src/components/Grid.vue","../src/components/Grid.vue","../node_modules/.pnpm/@intlify+shared@11.3.0/node_modules/@intlify/shared/dist/shared.mjs","../node_modules/.pnpm/@intlify+message-compiler@11.3.0/node_modules/@intlify/message-compiler/dist/message-compiler.mjs","../node_modules/.pnpm/@intlify+core-base@11.3.0/node_modules/@intlify/core-base/dist/core-base.mjs","../node_modules/.pnpm/vue-i18n@11.3.0_vue@3.5.30_typescript@5.9.3_/node_modules/vue-i18n/dist/vue-i18n.mjs","../src/components/ImageCropper.d.ts","../src/components/ImageCropper.vue","../src/components/ImageCropper.vue","../src/components/JsonTree.vue","../src/components/JsonTree.vue","../src/components/Label.d.ts","../src/components/Label.vue","../src/components/Label.vue","../src/components/Message.d.ts","../src/components/Message.vue","../src/components/Message.vue","../src/components/Modal.vue","../src/components/Modal.vue","../src/components/NumberInput.vue","../src/components/NumberInput.vue","../src/components/Panel.vue","../src/components/Panel.vue","../src/components/Radio.d.ts","../src/components/Radio.vue","../src/components/Radio.vue","../src/components/Select.vue","../src/components/Select.vue","../src/components/Slider.vue","../src/components/Slider.vue","../src/components/Switch.d.ts","../src/components/Switch.vue","../src/components/Switch.vue","../src/components/TextInput.vue","../src/components/TextInput.vue","../src/components/Toast.vue","../src/components/Toast.vue","../src/components/index.ts","../src/utils/escapeHtml.helper.ts","../src/directives/ToolTip.directive.ts","../src/directives/index.ts","../src/labs.ts","../src/main.ts"],"sourcesContent":["enum EAiLabelVariant {\n Default = 'default',\n Inline = 'inline',\n}\n\n// #region EAiLabelSize\nenum EAiLabelSize {\n Small = 'sm',\n Medium = 'md',\n Large = 'lg',\n}\n// #endregion EAiLabelSize\n\ninterface IAiLabelProps {\n variant?: EAiLabelVariant\n size?: EAiLabelSize\n}\n\nexport { EAiLabelVariant, EAiLabelSize, IAiLabelProps }\n","<template>\n <NbGrid\n is=\"button\"\n align=\"center\"\n v-bind=\"{ ...(variant === EAiLabelVariant.Inline && { gap: 'sm' }) }\"\n justify=\"center\"\n :class=\"classes\"\n >\n <div v-if=\"variant === EAiLabelVariant.Inline\" class=\"nb-ai-label--dot\" />\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 256 256\">\n <path\n d=\"M 104.301 197.8 L 94.501 162.4 L 53.101 162.4 L 43.501 197.8 L 17.101 197.8 L 56.301 58.2 L 92.701 58.2 L 132.101 197.8 L 104.301 197.8 Z M 74.701 84 L 73.101 84 L 57.701 141 L 90.101 141 L 74.701 84 Z M 150.099 197.8 L 150.099 178.2 L 181.499 178.2 L 181.499 77.8 L 150.099 77.8 L 150.099 58.2 L 238.899 58.2 L 238.899 77.8 L 207.499 77.8 L 207.499 178.2 L 238.899 178.2 L 238.899 197.8 L 150.099 197.8 Z\"\n fill=\"currentColor\"\n />\n </svg>\n </NbGrid>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed } from 'vue'\nimport { EAiLabelVariant, EAiLabelSize, IAiLabelProps } from './AiLabel.d'\n\nconst props = withDefaults(defineProps<IAiLabelProps>(), {\n variant: EAiLabelVariant.Default,\n size: EAiLabelSize.Medium,\n})\n\nconst classes = computed(() => {\n return {\n 'nb-ai-label': true,\n [`nb-ai-label__${props.variant}`]: true,\n [`nb-ai-label__${props.size}`]: true,\n }\n})\n</script>\n\n<style lang=\"scss\" scoped>\n.nb-ai-label {\n width: calc(var(--nb-base-unit) * 4);\n height: calc(var(--nb-base-unit) * 4);\n border: solid 1px black;\n &--dot {\n width: var(--nb-base-unit);\n height: var(--nb-base-unit);\n background: black;\n }\n svg {\n width: calc(var(--nb-base-unit) * 2);\n height: calc(var(--nb-base-unit) * 2);\n }\n &__default {\n &:hover {\n background: black;\n color: white;\n cursor: pointer;\n }\n &:focus {\n outline: solid 2px var(--nb-c-primary);\n outline-offset: -2px;\n }\n }\n &__inline {\n border: none;\n height: calc(var(--nb-base-unit) * 2);\n width: fit-content;\n padding: calc(var(--nb-base-unit) / 4);\n position: relative;\n\n svg {\n width: calc(var(--nb-base-unit) * 2);\n height: calc(var(--nb-base-unit) * 2);\n }\n &:hover {\n outline: solid 1px black;\n cursor: pointer;\n }\n &:focus {\n outline: solid 2px var(--nb-c-primary);\n }\n }\n &__default {\n }\n\n &__small {\n }\n\n &__large {\n }\n}\n</style>\n","<template>\n <NbGrid\n is=\"button\"\n align=\"center\"\n v-bind=\"{ ...(variant === EAiLabelVariant.Inline && { gap: 'sm' }) }\"\n justify=\"center\"\n :class=\"classes\"\n >\n <div v-if=\"variant === EAiLabelVariant.Inline\" class=\"nb-ai-label--dot\" />\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 256 256\">\n <path\n d=\"M 104.301 197.8 L 94.501 162.4 L 53.101 162.4 L 43.501 197.8 L 17.101 197.8 L 56.301 58.2 L 92.701 58.2 L 132.101 197.8 L 104.301 197.8 Z M 74.701 84 L 73.101 84 L 57.701 141 L 90.101 141 L 74.701 84 Z M 150.099 197.8 L 150.099 178.2 L 181.499 178.2 L 181.499 77.8 L 150.099 77.8 L 150.099 58.2 L 238.899 58.2 L 238.899 77.8 L 207.499 77.8 L 207.499 178.2 L 238.899 178.2 L 238.899 197.8 L 150.099 197.8 Z\"\n fill=\"currentColor\"\n />\n </svg>\n </NbGrid>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed } from 'vue'\nimport { EAiLabelVariant, EAiLabelSize, IAiLabelProps } from './AiLabel.d'\n\nconst props = withDefaults(defineProps<IAiLabelProps>(), {\n variant: EAiLabelVariant.Default,\n size: EAiLabelSize.Medium,\n})\n\nconst classes = computed(() => {\n return {\n 'nb-ai-label': true,\n [`nb-ai-label__${props.variant}`]: true,\n [`nb-ai-label__${props.size}`]: true,\n }\n})\n</script>\n\n<style lang=\"scss\" scoped>\n.nb-ai-label {\n width: calc(var(--nb-base-unit) * 4);\n height: calc(var(--nb-base-unit) * 4);\n border: solid 1px black;\n &--dot {\n width: var(--nb-base-unit);\n height: var(--nb-base-unit);\n background: black;\n }\n svg {\n width: calc(var(--nb-base-unit) * 2);\n height: calc(var(--nb-base-unit) * 2);\n }\n &__default {\n &:hover {\n background: black;\n color: white;\n cursor: pointer;\n }\n &:focus {\n outline: solid 2px var(--nb-c-primary);\n outline-offset: -2px;\n }\n }\n &__inline {\n border: none;\n height: calc(var(--nb-base-unit) * 2);\n width: fit-content;\n padding: calc(var(--nb-base-unit) / 4);\n position: relative;\n\n svg {\n width: calc(var(--nb-base-unit) * 2);\n height: calc(var(--nb-base-unit) * 2);\n }\n &:hover {\n outline: solid 1px black;\n cursor: pointer;\n }\n &:focus {\n outline: solid 2px var(--nb-c-primary);\n }\n }\n &__default {\n }\n\n &__small {\n }\n\n &__large {\n }\n}\n</style>\n","// FIXME replace the variant with the existing variants\nenum EBadgeVariant {\n Grey = 'grey',\n Blue = 'blue',\n Orange = 'orange',\n Green = 'green',\n Red = 'red',\n Purple = 'purple',\n Primary = 'primary',\n}\n\nenum EBadgeSize {\n Small = 'sm',\n Medium = 'md',\n}\n\ninterface IBadgeProps {\n variant?: EBadgeVariant\n size?: EBadgeSize\n dot?: boolean\n}\n\nexport { EBadgeVariant, EBadgeSize, IBadgeProps }\n","<template>\n <span :class=\"['nb-badge', `nb-badge--${variant}`, `nb-badge--${size}`]\">\n <span v-if=\"dot\" class=\"nb-badge__dot\" />\n <slot />\n </span>\n</template>\n\n<script setup lang=\"ts\">\nimport { EBadgeVariant, EBadgeSize, IBadgeProps } from './Badge.d'\n\nwithDefaults(defineProps<IBadgeProps>(), {\n variant: EBadgeVariant.Grey,\n size: EBadgeSize.Medium,\n dot: false,\n})\n</script>\n\n<style scoped lang=\"scss\">\n.nb-badge {\n display: inline-flex;\n align-items: center;\n gap: 4px;\n font-weight: 500;\n border-radius: 999px;\n white-space: nowrap;\n line-height: 1;\n\n &--sm {\n padding: 2px 7px;\n font-size: 10px;\n }\n &--md {\n padding: 3px 9px;\n font-size: 11px;\n }\n\n /* Variants */\n &--grey {\n background: #e8e8ee;\n color: #555566;\n }\n &--blue {\n background: #dbeafe;\n color: #1d4ed8;\n }\n &--orange {\n background: #fef3c7;\n color: #92400e;\n }\n &--green {\n background: #d1fae5;\n color: #065f46;\n }\n &--red {\n background: #fee2e2;\n color: #991b1b;\n }\n &--purple {\n background: var(--nb-c-grape-hyacinth-100, #eeedf9);\n color: var(--nb-c-grape-hyacinth-600, #444480);\n }\n &--primary {\n background: var(--nb-c-grape-hyacinth-500, #5856a9);\n color: #fff;\n }\n\n &__dot {\n width: 6px;\n height: 6px;\n border-radius: 50%;\n background: currentColor;\n flex-shrink: 0;\n }\n}\n</style>\n","<template>\n <span :class=\"['nb-badge', `nb-badge--${variant}`, `nb-badge--${size}`]\">\n <span v-if=\"dot\" class=\"nb-badge__dot\" />\n <slot />\n </span>\n</template>\n\n<script setup lang=\"ts\">\nimport { EBadgeVariant, EBadgeSize, IBadgeProps } from './Badge.d'\n\nwithDefaults(defineProps<IBadgeProps>(), {\n variant: EBadgeVariant.Grey,\n size: EBadgeSize.Medium,\n dot: false,\n})\n</script>\n\n<style scoped lang=\"scss\">\n.nb-badge {\n display: inline-flex;\n align-items: center;\n gap: 4px;\n font-weight: 500;\n border-radius: 999px;\n white-space: nowrap;\n line-height: 1;\n\n &--sm {\n padding: 2px 7px;\n font-size: 10px;\n }\n &--md {\n padding: 3px 9px;\n font-size: 11px;\n }\n\n /* Variants */\n &--grey {\n background: #e8e8ee;\n color: #555566;\n }\n &--blue {\n background: #dbeafe;\n color: #1d4ed8;\n }\n &--orange {\n background: #fef3c7;\n color: #92400e;\n }\n &--green {\n background: #d1fae5;\n color: #065f46;\n }\n &--red {\n background: #fee2e2;\n color: #991b1b;\n }\n &--purple {\n background: var(--nb-c-grape-hyacinth-100, #eeedf9);\n color: var(--nb-c-grape-hyacinth-600, #444480);\n }\n &--primary {\n background: var(--nb-c-grape-hyacinth-500, #5856a9);\n color: #fff;\n }\n\n &__dot {\n width: 6px;\n height: 6px;\n border-radius: 50%;\n background: currentColor;\n flex-shrink: 0;\n }\n}\n</style>\n","<template>\n <nav class=\"nb-breadcrumbs\" aria-label=\"breadcrumb\">\n <!-- Brand prefix (title + subtitle) -->\n <span v-if=\"title || subtitle\" class=\"nb-breadcrumbs__brand\">\n <span v-if=\"title\" class=\"nb-breadcrumbs__title\">{{ title }}</span>\n <span v-if=\"subtitle\" class=\"nb-breadcrumbs__subtitle\">{{\n subtitle\n }}</span>\n </span>\n\n <!-- Separator between brand and crumbs (only when both exist) -->\n <NbIcon\n v-if=\"(title || subtitle) && hasDefaultSlot\"\n name=\"caret-right\"\n size=\"sm\"\n class=\"nb-breadcrumbs__sep\"\n />\n\n <!-- Crumb items injected via default slot -->\n <span v-if=\"hasDefaultSlot\" class=\"nb-breadcrumbs__crumbs\">\n <slot />\n </span>\n </nav>\n</template>\n\n<script setup lang=\"ts\">\nimport { useSlots, computed } from 'vue'\n\ndefineProps<{\n /** Text rendered before the subtitle in regular weight. */\n title?: string\n /** Text rendered after the title in bold weight. */\n subtitle?: string\n}>()\n\nconst slots = useSlots()\nconst hasDefaultSlot = computed(() => !!slots.default?.())\n</script>\n\n<style lang=\"scss\" scoped>\n.nb-breadcrumbs {\n display: inline-flex;\n align-items: center;\n gap: 0.35rem;\n font-size: 0.9rem;\n line-height: 1;\n}\n\n.nb-breadcrumbs__brand {\n display: inline-flex;\n align-items: baseline;\n gap: 0.3em;\n}\n\n.nb-breadcrumbs__title {\n font-weight: 400;\n color: var(--nb-c-text-primary, #1a1a2e);\n}\n\n.nb-breadcrumbs__subtitle {\n font-weight: 700;\n color: var(--nb-c-text-primary, #1a1a2e);\n}\n\n.nb-breadcrumbs__sep {\n color: var(--nb-c-text-tertiary, #d1d5db);\n flex-shrink: 0;\n}\n\n.nb-breadcrumbs__crumbs {\n display: inline-flex;\n align-items: center;\n gap: 0.35rem;\n font-weight: 700;\n color: var(--nb-c-text-primary, #1a1a2e);\n}\n</style>\n","<template>\n <nav class=\"nb-breadcrumbs\" aria-label=\"breadcrumb\">\n <!-- Brand prefix (title + subtitle) -->\n <span v-if=\"title || subtitle\" class=\"nb-breadcrumbs__brand\">\n <span v-if=\"title\" class=\"nb-breadcrumbs__title\">{{ title }}</span>\n <span v-if=\"subtitle\" class=\"nb-breadcrumbs__subtitle\">{{\n subtitle\n }}</span>\n </span>\n\n <!-- Separator between brand and crumbs (only when both exist) -->\n <NbIcon\n v-if=\"(title || subtitle) && hasDefaultSlot\"\n name=\"caret-right\"\n size=\"sm\"\n class=\"nb-breadcrumbs__sep\"\n />\n\n <!-- Crumb items injected via default slot -->\n <span v-if=\"hasDefaultSlot\" class=\"nb-breadcrumbs__crumbs\">\n <slot />\n </span>\n </nav>\n</template>\n\n<script setup lang=\"ts\">\nimport { useSlots, computed } from 'vue'\n\ndefineProps<{\n /** Text rendered before the subtitle in regular weight. */\n title?: string\n /** Text rendered after the title in bold weight. */\n subtitle?: string\n}>()\n\nconst slots = useSlots()\nconst hasDefaultSlot = computed(() => !!slots.default?.())\n</script>\n\n<style lang=\"scss\" scoped>\n.nb-breadcrumbs {\n display: inline-flex;\n align-items: center;\n gap: 0.35rem;\n font-size: 0.9rem;\n line-height: 1;\n}\n\n.nb-breadcrumbs__brand {\n display: inline-flex;\n align-items: baseline;\n gap: 0.3em;\n}\n\n.nb-breadcrumbs__title {\n font-weight: 400;\n color: var(--nb-c-text-primary, #1a1a2e);\n}\n\n.nb-breadcrumbs__subtitle {\n font-weight: 700;\n color: var(--nb-c-text-primary, #1a1a2e);\n}\n\n.nb-breadcrumbs__sep {\n color: var(--nb-c-text-tertiary, #d1d5db);\n flex-shrink: 0;\n}\n\n.nb-breadcrumbs__crumbs {\n display: inline-flex;\n align-items: center;\n gap: 0.35rem;\n font-weight: 700;\n color: var(--nb-c-text-primary, #1a1a2e);\n}\n</style>\n","// #region ESize\n// String-based size tokens (for CSS classes, spacing scales, etc.)\nexport enum ESize {\n ExtraExtraSmall = 'xxs',\n ExtraSmall = 'xs',\n Small = 'sm',\n Medium = 'md',\n Large = 'lg',\n ExtraLarge = 'xl',\n ExtraExtraLarge = 'xxl',\n}\n// #endregion ESize\n\n// #region ESizeShort\nexport enum ESizeShort {\n Small = 'sm',\n Medium = 'md',\n Large = 'lg',\n}\n// #endregion ESizeShort\n\n// #region ESizePixel\n// Numeric size values in pixels (for icons, images, components with fixed dimensions)\nexport enum ESizePixel {\n ExtraExtraSmall = 8,\n ExtraSmall = 12,\n Small = 14,\n Medium = 16,\n Large = 20,\n ExtraLarge = 60,\n ExtraExtraLarge = 92,\n}\n// #endregion ESizePixel\n","import { ESizeShort } from '@/types/Size.d'\n\nenum EButtonType {\n Button = 'button',\n Submit = 'submit',\n Reset = 'reset',\n}\n\ninterface IButtonProps {\n variant?: string\n outlined?: boolean\n size?: ESizeShort\n disabled?: boolean\n loading?: boolean\n /** Icon name passed directly to NbIcon. Rendered in the trailing padding area. Hidden while loading. */\n icon?: string\n /** Native button type. Ignored when `href` is provided. */\n type?: EButtonType\n /** When provided the component renders as an `<a>` element instead of `<button>`. */\n href?: string\n /** Forwarded to the `<a>` element. Only used when `href` is set. */\n target?: string\n /** Forwarded to the `<a>` element. Only used when `href` is set. */\n rel?: string\n}\n\nexport { EButtonType, IButtonProps }\n","/**\n * Converts kebab-case tokens to lower camelCase.\n */\nexport function kebab2camel(str: string): string {\n return str.toLowerCase().replace(/-([a-z0-9])/g, (g) => {\n return g[1].toUpperCase()\n })\n}\n\nexport default kebab2camel\n","import { ESize } from '@/types/Size.d'\n\nenum EAnimation {\n SwingRight = 'swing-right',\n Wobble = 'wobble',\n Expand = 'expand',\n Refresh = 'refresh',\n Heart = 'heart',\n Undo = 'undo',\n Italic = 'italic',\n Cog = 'cog',\n Wrench = 'wrench',\n Mouse = 'mouse-pointer',\n Magic = 'magic',\n Lock = 'lock',\n Unlock = 'unlock',\n Hourglass = 'hourglass',\n Eraser = 'eraser',\n Rocket = 'rocket',\n Times = 'times',\n}\n\nenum EAnimationMode {\n Hover = 'hover',\n Always = 'always',\n}\n\nenum EWeight {\n Thin = 'thin',\n Light = 'light',\n Regular = 'regular',\n Bold = 'bold',\n Fill = 'fill',\n Duotone = 'duotone',\n}\n\nenum EIconSize {\n XXL = 92,\n XL = 60,\n LG = 20,\n MD = 16,\n SM = 14,\n XS = 12,\n XXS = 8,\n}\n\ninterface IIconProps {\n name: string\n size?: ESize | string | number\n animation?: EAnimation | null\n animationMode?: EAnimationMode\n color?: string\n weight?: EWeight\n title?: string\n clickable?: boolean\n hoverable?: boolean\n}\n\nexport { EAnimation, EAnimationMode, EWeight, EIconSize, IIconProps }\n","/**\n * Normalizes an identifier-like string into kebab-case.\n * Handles camelCase, PascalCase, snake_case, and whitespace-delimited input.\n */\nexport function str2kebab(source: string): string {\n return source\n .replace(/(?<=[A-Z0-9])([A-Z])(?=[a-z])/g, ' $1')\n .replace(/_/g, ' ')\n .replace(/([a-z])([A-Z])/g, '$1-$2')\n .replace(/\\s+/g, '-')\n .toLowerCase()\n}\n\nexport default str2kebab\n","import { getCurrentInstance, useId } from 'vue'\nimport str2kebab from '@/utils/str2kebab.helper'\n\n/**\n * Returns a stable, deterministic element ID for any component that needs one.\n *\n * Resolution order:\n * 1. `props.id` — honored as-is when explicitly provided.\n * 2. `{component-slug}-{name-slug}` — when `props.name` is set.\n * e.g. NbTextInput + `name=\"billingEmail\"` → `\"nb-text-input-billing-email\"`\n * 3. `{component-slug}-{vue-uid}` — positional fallback via Vue's `useId()`.\n * e.g. `\"nb-select-v3\"` (SSR-safe, unique within the app instance)\n *\n * The resulting IDs are meaningful in analytics / tracking pipelines: the\n * component type is always present as a prefix, and the field name (when\n * available) makes the target immediately identifiable.\n *\n * @example\n * // Inside a component setup()\n * const elementId = useStableId(props) // props carries id? and name?\n */\n// #region useStableId\nexport function useStableId(props: { id?: string; name?: string }): string {\n if (props.id) return props.id\n\n const instance = getCurrentInstance()\n const componentSlug = str2kebab(instance?.type?.__name ?? 'component')\n\n if (props.name) {\n return `${componentSlug}-${str2kebab(props.name)}`\n }\n\n return `${componentSlug}-${useId()}`\n}\n// #endregion useStableId\n","<template>\n <i\n :class=\"classes\"\n :style=\"styles\"\n v-bind=\"attributes\"\n :title=\"title\"\n @click=\"!clickable ? undefined : emit('click', $event)\"\n >\n <component :is=\"iconComponent\" aria-hidden=\"true\" />\n </i>\n</template>\n\n<script setup lang=\"ts\">\n// @ts-expect-error virtual module provided by icons vite plugin\nimport icons from 'virtual:icons'\nimport { computed } from 'vue'\nimport kebab2camel from '@/utils/kebab2camel.helper'\nimport { ESize } from '@/types/Size.d'\nimport { EAnimationMode, EWeight, EIconSize, IIconProps } from './Icon.d'\nimport { useStableId } from '@/composables/useStableId.composable'\n\nconst props = withDefaults(defineProps<IIconProps>(), {\n size: ESize.Medium,\n animation: null,\n animationMode: EAnimationMode.Always,\n color: undefined,\n weight: EWeight.Regular,\n title: undefined,\n clickable: false,\n hoverable: false,\n})\n\nconst emit = defineEmits(['click'])\n\nconst componentInternalId = useStableId(props)\n\nconst attributes = computed(() => {\n const iconSize =\n typeof props.size === 'number'\n ? props.size\n : (EIconSize as unknown as Record<string, number>)[\n String(props.size).toUpperCase()\n ] || EIconSize.MD\n\n return {\n ...{ id: componentInternalId },\n ...(props.size && {\n width: `${iconSize}px`,\n height: `${iconSize}px`,\n }),\n ...(props.clickable && { role: 'button' }),\n }\n})\n\nconst iconComponent = computed(() => {\n const iconKey = kebab2camel(`i-${props.name}`)\n const iconSet = (icons as Record<string, any>)[iconKey]\n return iconSet?.[props.weight] || iconSet?.regular\n})\n\nconst classes = computed(() => {\n return {\n 'nb-icon': true,\n ...(props.name && { [props.name]: true }),\n [`nb-icon-${props.size}`]: [\n 'xxs',\n 'xs',\n 'sm',\n 'md',\n 'lg',\n 'xl',\n 'xxl',\n ].includes(String(props.size)),\n [`nb-icon-animation-${props.animationMode}-${props.animation}`]:\n props.animation,\n hoverable:\n props.hoverable || (props.animation && props.animationMode === 'hover'),\n 'box-clickable': props.clickable,\n }\n})\n\nconst styles = computed(() => {\n return {\n ...(props.color && { color: props.color }),\n ...(typeof props.size === 'number' && {\n maxWidth: `${props.size}px`,\n maxHeight: `${props.size}px`,\n height: `${props.size}px`,\n width: `${props.size}px`,\n }),\n ...(typeof props.size === 'string' &&\n !['xxs', 'xs', 'sm', 'md', 'lg', 'xl', 'xxl'].includes(props.size) && {\n maxWidth: props.size,\n maxHeight: props.size,\n height: props.size,\n width: props.size,\n }),\n }\n})\n</script>\n\n<style lang=\"scss\" scoped>\n.nb-icon {\n display: flex;\n line-height: 1em;\n position: relative;\n &:not(.hoverable):not(.box-clickable) {\n pointer-events: none;\n }\n\n svg {\n width: 100%;\n height: 100%;\n display: block;\n }\n\n &-xxl {\n max-width: var(--nb-font-size-92);\n max-height: var(--nb-font-size-92);\n height: var(--nb-font-size-92);\n width: var(--nb-font-size-92);\n }\n &-xl {\n max-width: var(--nb-font-size-60);\n max-height: var(--nb-font-size-60);\n height: var(--nb-font-size-60);\n width: var(--nb-font-size-60);\n }\n &-lg {\n max-width: var(--nb-font-size-20);\n max-height: var(--nb-font-size-20);\n height: var(--nb-font-size-20);\n width: var(--nb-font-size-20);\n }\n &-md {\n max-width: var(--nb-font-size-16);\n max-height: var(--nb-font-size-16);\n height: var(--nb-font-size-16);\n width: var(--nb-font-size-16);\n }\n &-sm {\n max-width: var(--nb-font-size-14);\n max-height: var(--nb-font-size-14);\n height: var(--nb-font-size-14);\n width: var(--nb-font-size-14);\n }\n &-xs {\n max-width: var(--nb-font-size-12);\n max-height: var(--nb-font-size-12);\n height: var(--nb-font-size-12);\n width: var(--nb-font-size-12);\n }\n &-xxs {\n max-width: var(--nb-font-size-8);\n max-height: var(--nb-font-size-8);\n height: var(--nb-font-size-8);\n width: var(--nb-font-size-8);\n }\n\n // animations\n &-animation-hover-swing-right:hover {\n animation: swing-right 0.5s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-swing-right {\n animation: swing-right 0.5s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-wobble:hover {\n animation: wobble 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-wobble {\n animation: wobble 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-expand:hover {\n animation: expand 0.5s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-expand {\n animation: expand 0.5s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-refresh:hover {\n animation: refresh 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-refresh {\n animation: refresh 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-heart:hover {\n animation: heart 0.5s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-heart {\n animation: heart 0.5s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-undo:hover {\n animation: undo 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-undo {\n animation: undo 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-italic:hover {\n animation: italic 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-italic {\n animation: italic 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-cog:hover {\n animation: cog 5s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-cog {\n animation: cog 5s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-wrench:hover {\n transform-origin: 79% 26%;\n animation: wrench 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-wrench {\n transform-origin: 79% 26%;\n animation: wrench 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-mouse-pointer:hover {\n animation: mouse-pointer 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-mouse-pointer {\n animation: mouse-pointer 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-magic:hover {\n animation: magic 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-magic {\n animation: magic 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-lock:hover {\n animation: lock 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-lock {\n animation: lock 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-unlock:hover {\n transform-origin: 75% 25%;\n animation: unlock 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-unlock {\n transform-origin: 75% 25%;\n animation: unlock 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-hourglass:hover {\n animation: hourglass 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-hourglass {\n animation: hourglass 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-eraser:hover {\n animation: eraser 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-eraser {\n animation: eraser 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-rocket:hover {\n animation: rocket 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-rocket {\n animation: rocket 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-times:hover {\n animation: times 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-times {\n animation: times 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n\n @keyframes swing-right {\n 0% {\n transform: scale(1.5) translateX(0);\n }\n 33% {\n transform: scale(1.5) translateX(-5px);\n }\n 66% {\n transform: scale(1.5) translateX(5px);\n }\n 100% {\n transform: scale(1.5) translateX(0);\n }\n }\n @keyframes wobble {\n 0% {\n transform: scale(1.5) translate(0, 0);\n }\n 20% {\n transform: scale(1.5) translate(-5px, 5px);\n }\n 40% {\n transform: scale(1.5) translate(-5px, -5px);\n }\n 60% {\n transform: scale(1.5) translate(5px, 5px);\n }\n 80% {\n transform: scale(1.5) translate(5px, -5px);\n }\n 100% {\n transform: scale(1.5) translate(0, 0);\n }\n }\n @keyframes expand {\n 0% {\n transform: scale(1.5) translate(0, 0);\n }\n 25% {\n transform: scale(1.5) translate(-5px, 5px);\n }\n 50% {\n transform: scale(2) translate(0, 0);\n }\n 75% {\n transform: scale(1.5) translate(5px, -5px);\n }\n 100% {\n transform: scale(1.5) translate(0, 0);\n }\n }\n @keyframes refresh {\n from {\n transform: scale(1.5) rotate(0);\n }\n to {\n transform: scale(1.5) rotate(360deg);\n }\n }\n @keyframes heart {\n 0% {\n transform: scale(1.5);\n }\n 20% {\n transform: scale(2);\n }\n 30% {\n transform: scale(1.5);\n }\n 40% {\n transform: scale(2);\n }\n 100% {\n transform: scale(1.5);\n }\n }\n @keyframes undo {\n 0% {\n transform: scale(1.5) translateX(0) rotate(0);\n }\n 33% {\n transform: scale(1.5) translateX(10px) rotate(0);\n }\n 66% {\n transform: scale(1.5) translateX(-10px) rotate(-360deg);\n }\n 100% {\n transform: scale(1.5) translateX(0) rotate(-360deg);\n }\n }\n @keyframes italic {\n 0% {\n transform: scale(1.5) skewX(0);\n }\n 50% {\n transform: scale(1.5) skewX(12deg);\n }\n 100% {\n transform: scale(1.5) skewX(0);\n }\n }\n @keyframes cog {\n 0% {\n transform: scale(1.5) rotate(0);\n }\n 10% {\n transform: scale(1.5) rotate(45deg);\n }\n 17% {\n transform: scale(1.5) rotate(45deg);\n }\n 20% {\n transform: scale(1.5) rotate(90deg);\n }\n 27% {\n transform: scale(1.5) rotate(90deg);\n }\n 30% {\n transform: scale(1.5) rotate(135deg);\n }\n 37% {\n transform: scale(1.5) rotate(135deg);\n }\n 40% {\n transform: scale(1.5) rotate(180deg);\n }\n 47% {\n transform: scale(1.5) rotate(180deg);\n }\n 50% {\n transform: scale(1.5) rotate(225deg);\n }\n 57% {\n transform: scale(1.5) rotate(225deg);\n }\n 60% {\n transform: scale(1.5) rotate(270deg);\n }\n 67% {\n transform: scale(1.5) rotate(270deg);\n }\n 70% {\n transform: scale(1.5) rotate(315deg);\n }\n 77% {\n transform: scale(1.5) rotate(315deg);\n }\n 80% {\n transform: scale(1.5) rotate(360deg);\n }\n 100% {\n transform: scale(1.5) rotate(360deg);\n }\n }\n @keyframes wrench {\n 0% {\n transform: scale(1.5) rotate(0);\n }\n 20% {\n transform: scale(1.5) rotate(30deg);\n }\n 30% {\n transform: scale(1.5) rotate(-20deg);\n }\n 50% {\n transform: scale(1.5) rotate(30deg);\n }\n 60% {\n transform: scale(1.5) rotate(-20deg);\n }\n 100% {\n transform: scale(1.5) rotate(0);\n }\n }\n @keyframes mouse-pointer {\n 0% {\n transform: scale(1.5);\n }\n 20% {\n transform: scale(1.5);\n }\n 22.5% {\n transform: scale(1.2);\n }\n 32.5% {\n transform: scale(1.2);\n }\n 35% {\n transform: scale(1.5);\n }\n 100% {\n transform: scale(1.5);\n }\n }\n @keyframes magic {\n 0% {\n transform: scale(1.5) translate(0, 0) rotate(0);\n }\n 10% {\n transform: scale(1.5) translate(-5px, 2.5px) rotate(-10deg);\n }\n 20% {\n transform: scale(1.5) translate(-10px, 0) rotate(-20deg);\n }\n 30% {\n transform: scale(1.5) translate(-5px, -2.5px) rotate(-30deg);\n }\n 40% {\n transform: scale(1.5) translate(0, 0) rotate(-20deg);\n }\n 50% {\n transform: scale(1.5) translate(5px, 2.5px) rotate(-10deg);\n }\n 60% {\n transform: scale(1.5) translate(10px, 0) rotate(0);\n }\n 70% {\n transform: scale(1.5) translate(5px, -2.5px) rotate(10deg);\n }\n 100% {\n transform: scale(1.5) translate(0, 0) rotate(0);\n }\n }\n @keyframes lock {\n 0% {\n transform: scale(1.5) translateY(0);\n }\n 20% {\n transform: scale(1.5) translateY(-5px);\n }\n 30% {\n transform: scale(1.5) translateY(5px);\n }\n 50% {\n transform: scale(1.5) translateY(-5px);\n }\n 60% {\n transform: scale(1.5) translateY(5px);\n }\n 100% {\n transform: scale(1.5) translateY(0);\n }\n }\n @keyframes unlock {\n 0% {\n transform: scale(1.5) rotate(-15deg);\n }\n 15% {\n transform: scale(1.5) rotate(-40deg);\n }\n 30% {\n transform: scale(1.5) rotate(5deg);\n }\n 45% {\n transform: scale(1.5) rotate(-30deg);\n }\n 60% {\n transform: scale(1.5) rotate(-5deg);\n }\n 75% {\n transform: scale(1.5) rotate(-20deg);\n }\n 90% {\n transform: scale(1.5) rotate(-15deg);\n }\n 100% {\n transform: scale(1.5) rotate(-15deg);\n }\n }\n @keyframes hourglass {\n 0% {\n transform: scale(1.5) rotate(0);\n }\n 35% {\n transform: scale(1.5) rotate(180deg);\n }\n 65% {\n transform: scale(1.5) rotate(180deg);\n }\n 100% {\n transform: scale(1.5) rotate(0);\n }\n }\n @keyframes eraser {\n 0% {\n transform: scale(1.5) translate(0, 0);\n }\n 15% {\n transform: scale(1.5) translate(-10px, -5px);\n }\n 30% {\n transform: scale(1.5) translate(-10px, 5px);\n }\n 45% {\n transform: scale(1.5) translate(-5px, -5px);\n }\n 60% {\n transform: scale(1.5) translate(-5px, 5px);\n }\n 75% {\n transform: scale(1.5) translate(0, 0);\n }\n 100% {\n transform: scale(1.5) translate(10px, 0);\n }\n }\n @keyframes rocket {\n 0% {\n transform: scale(1.5) translate(0, 0);\n opacity: 1;\n }\n 5% {\n transform: scale(1.5) translate(2px, 0);\n opacity: 1;\n }\n 10% {\n transform: scale(1.5) translate(1px, -2px);\n opacity: 1;\n }\n 15% {\n transform: scale(1.5) translate(3px, -1px);\n opacity: 1;\n }\n 20% {\n transform: scale(1.5) translate(2px, -3px);\n opacity: 1;\n }\n 25% {\n transform: scale(1.5) translate(4px, -2px);\n opacity: 1;\n }\n 50% {\n transform: scale(1.5) translate(10px, -10px);\n opacity: 0;\n }\n 51% {\n transform: scale(1.5) translate(-10px, 10px);\n opacity: 0;\n }\n 100% {\n transform: scale(1.5) translate(0, 0);\n opacity: 1;\n }\n }\n @keyframes times {\n 0% {\n transform: scale(1.5) translateX(0);\n }\n 15% {\n transform: scale(1.5) translateX(5px);\n }\n 30% {\n transform: scale(1.5) translateX(-5px);\n }\n 45% {\n transform: scale(1.5) translateX(3px);\n }\n 60% {\n transform: scale(1.5) translateX(-3px);\n }\n 75% {\n transform: scale(1.5) translateX(0);\n }\n 100% {\n transform: scale(1.5) translateX(0);\n }\n }\n}\n</style>\n","<template>\n <i\n :class=\"classes\"\n :style=\"styles\"\n v-bind=\"attributes\"\n :title=\"title\"\n @click=\"!clickable ? undefined : emit('click', $event)\"\n >\n <component :is=\"iconComponent\" aria-hidden=\"true\" />\n </i>\n</template>\n\n<script setup lang=\"ts\">\n// @ts-expect-error virtual module provided by icons vite plugin\nimport icons from 'virtual:icons'\nimport { computed } from 'vue'\nimport kebab2camel from '@/utils/kebab2camel.helper'\nimport { ESize } from '@/types/Size.d'\nimport { EAnimationMode, EWeight, EIconSize, IIconProps } from './Icon.d'\nimport { useStableId } from '@/composables/useStableId.composable'\n\nconst props = withDefaults(defineProps<IIconProps>(), {\n size: ESize.Medium,\n animation: null,\n animationMode: EAnimationMode.Always,\n color: undefined,\n weight: EWeight.Regular,\n title: undefined,\n clickable: false,\n hoverable: false,\n})\n\nconst emit = defineEmits(['click'])\n\nconst componentInternalId = useStableId(props)\n\nconst attributes = computed(() => {\n const iconSize =\n typeof props.size === 'number'\n ? props.size\n : (EIconSize as unknown as Record<string, number>)[\n String(props.size).toUpperCase()\n ] || EIconSize.MD\n\n return {\n ...{ id: componentInternalId },\n ...(props.size && {\n width: `${iconSize}px`,\n height: `${iconSize}px`,\n }),\n ...(props.clickable && { role: 'button' }),\n }\n})\n\nconst iconComponent = computed(() => {\n const iconKey = kebab2camel(`i-${props.name}`)\n const iconSet = (icons as Record<string, any>)[iconKey]\n return iconSet?.[props.weight] || iconSet?.regular\n})\n\nconst classes = computed(() => {\n return {\n 'nb-icon': true,\n ...(props.name && { [props.name]: true }),\n [`nb-icon-${props.size}`]: [\n 'xxs',\n 'xs',\n 'sm',\n 'md',\n 'lg',\n 'xl',\n 'xxl',\n ].includes(String(props.size)),\n [`nb-icon-animation-${props.animationMode}-${props.animation}`]:\n props.animation,\n hoverable:\n props.hoverable || (props.animation && props.animationMode === 'hover'),\n 'box-clickable': props.clickable,\n }\n})\n\nconst styles = computed(() => {\n return {\n ...(props.color && { color: props.color }),\n ...(typeof props.size === 'number' && {\n maxWidth: `${props.size}px`,\n maxHeight: `${props.size}px`,\n height: `${props.size}px`,\n width: `${props.size}px`,\n }),\n ...(typeof props.size === 'string' &&\n !['xxs', 'xs', 'sm', 'md', 'lg', 'xl', 'xxl'].includes(props.size) && {\n maxWidth: props.size,\n maxHeight: props.size,\n height: props.size,\n width: props.size,\n }),\n }\n})\n</script>\n\n<style lang=\"scss\" scoped>\n.nb-icon {\n display: flex;\n line-height: 1em;\n position: relative;\n &:not(.hoverable):not(.box-clickable) {\n pointer-events: none;\n }\n\n svg {\n width: 100%;\n height: 100%;\n display: block;\n }\n\n &-xxl {\n max-width: var(--nb-font-size-92);\n max-height: var(--nb-font-size-92);\n height: var(--nb-font-size-92);\n width: var(--nb-font-size-92);\n }\n &-xl {\n max-width: var(--nb-font-size-60);\n max-height: var(--nb-font-size-60);\n height: var(--nb-font-size-60);\n width: var(--nb-font-size-60);\n }\n &-lg {\n max-width: var(--nb-font-size-20);\n max-height: var(--nb-font-size-20);\n height: var(--nb-font-size-20);\n width: var(--nb-font-size-20);\n }\n &-md {\n max-width: var(--nb-font-size-16);\n max-height: var(--nb-font-size-16);\n height: var(--nb-font-size-16);\n width: var(--nb-font-size-16);\n }\n &-sm {\n max-width: var(--nb-font-size-14);\n max-height: var(--nb-font-size-14);\n height: var(--nb-font-size-14);\n width: var(--nb-font-size-14);\n }\n &-xs {\n max-width: var(--nb-font-size-12);\n max-height: var(--nb-font-size-12);\n height: var(--nb-font-size-12);\n width: var(--nb-font-size-12);\n }\n &-xxs {\n max-width: var(--nb-font-size-8);\n max-height: var(--nb-font-size-8);\n height: var(--nb-font-size-8);\n width: var(--nb-font-size-8);\n }\n\n // animations\n &-animation-hover-swing-right:hover {\n animation: swing-right 0.5s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-swing-right {\n animation: swing-right 0.5s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-wobble:hover {\n animation: wobble 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-wobble {\n animation: wobble 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-expand:hover {\n animation: expand 0.5s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-expand {\n animation: expand 0.5s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-refresh:hover {\n animation: refresh 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-refresh {\n animation: refresh 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-heart:hover {\n animation: heart 0.5s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-heart {\n animation: heart 0.5s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-undo:hover {\n animation: undo 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-undo {\n animation: undo 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-italic:hover {\n animation: italic 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-italic {\n animation: italic 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-cog:hover {\n animation: cog 5s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-cog {\n animation: cog 5s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-wrench:hover {\n transform-origin: 79% 26%;\n animation: wrench 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-wrench {\n transform-origin: 79% 26%;\n animation: wrench 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-mouse-pointer:hover {\n animation: mouse-pointer 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-mouse-pointer {\n animation: mouse-pointer 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-magic:hover {\n animation: magic 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-magic {\n animation: magic 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-lock:hover {\n animation: lock 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-lock {\n animation: lock 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-unlock:hover {\n transform-origin: 75% 25%;\n animation: unlock 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-unlock {\n transform-origin: 75% 25%;\n animation: unlock 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-hourglass:hover {\n animation: hourglass 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-hourglass {\n animation: hourglass 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-eraser:hover {\n animation: eraser 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-eraser {\n animation: eraser 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-rocket:hover {\n animation: rocket 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-rocket {\n animation: rocket 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-times:hover {\n animation: times 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-times {\n animation: times 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n\n @keyframes swing-right {\n 0% {\n transform: scale(1.5) translateX(0);\n }\n 33% {\n transform: scale(1.5) translateX(-5px);\n }\n 66% {\n transform: scale(1.5) translateX(5px);\n }\n 100% {\n transform: scale(1.5) translateX(0);\n }\n }\n @keyframes wobble {\n 0% {\n transform: scale(1.5) translate(0, 0);\n }\n 20% {\n transform: scale(1.5) translate(-5px, 5px);\n }\n 40% {\n transform: scale(1.5) translate(-5px, -5px);\n }\n 60% {\n transform: scale(1.5) translate(5px, 5px);\n }\n 80% {\n transform: scale(1.5) translate(5px, -5px);\n }\n 100% {\n transform: scale(1.5) translate(0, 0);\n }\n }\n @keyframes expand {\n 0% {\n transform: scale(1.5) translate(0, 0);\n }\n 25% {\n transform: scale(1.5) translate(-5px, 5px);\n }\n 50% {\n transform: scale(2) translate(0, 0);\n }\n 75% {\n transform: scale(1.5) translate(5px, -5px);\n }\n 100% {\n transform: scale(1.5) translate(0, 0);\n }\n }\n @keyframes refresh {\n from {\n transform: scale(1.5) rotate(0);\n }\n to {\n transform: scale(1.5) rotate(360deg);\n }\n }\n @keyframes heart {\n 0% {\n transform: scale(1.5);\n }\n 20% {\n transform: scale(2);\n }\n 30% {\n transform: scale(1.5);\n }\n 40% {\n transform: scale(2);\n }\n 100% {\n transform: scale(1.5);\n }\n }\n @keyframes undo {\n 0% {\n transform: scale(1.5) translateX(0) rotate(0);\n }\n 33% {\n transform: scale(1.5) translateX(10px) rotate(0);\n }\n 66% {\n transform: scale(1.5) translateX(-10px) rotate(-360deg);\n }\n 100% {\n transform: scale(1.5) translateX(0) rotate(-360deg);\n }\n }\n @keyframes italic {\n 0% {\n transform: scale(1.5) skewX(0);\n }\n 50% {\n transform: scale(1.5) skewX(12deg);\n }\n 100% {\n transform: scale(1.5) skewX(0);\n }\n }\n @keyframes cog {\n 0% {\n transform: scale(1.5) rotate(0);\n }\n 10% {\n transform: scale(1.5) rotate(45deg);\n }\n 17% {\n transform: scale(1.5) rotate(45deg);\n }\n 20% {\n transform: scale(1.5) rotate(90deg);\n }\n 27% {\n transform: scale(1.5) rotate(90deg);\n }\n 30% {\n transform: scale(1.5) rotate(135deg);\n }\n 37% {\n transform: scale(1.5) rotate(135deg);\n }\n 40% {\n transform: scale(1.5) rotate(180deg);\n }\n 47% {\n transform: scale(1.5) rotate(180deg);\n }\n 50% {\n transform: scale(1.5) rotate(225deg);\n }\n 57% {\n transform: scale(1.5) rotate(225deg);\n }\n 60% {\n transform: scale(1.5) rotate(270deg);\n }\n 67% {\n transform: scale(1.5) rotate(270deg);\n }\n 70% {\n transform: scale(1.5) rotate(315deg);\n }\n 77% {\n transform: scale(1.5) rotate(315deg);\n }\n 80% {\n transform: scale(1.5) rotate(360deg);\n }\n 100% {\n transform: scale(1.5) rotate(360deg);\n }\n }\n @keyframes wrench {\n 0% {\n transform: scale(1.5) rotate(0);\n }\n 20% {\n transform: scale(1.5) rotate(30deg);\n }\n 30% {\n transform: scale(1.5) rotate(-20deg);\n }\n 50% {\n transform: scale(1.5) rotate(30deg);\n }\n 60% {\n transform: scale(1.5) rotate(-20deg);\n }\n 100% {\n transform: scale(1.5) rotate(0);\n }\n }\n @keyframes mouse-pointer {\n 0% {\n transform: scale(1.5);\n }\n 20% {\n transform: scale(1.5);\n }\n 22.5% {\n transform: scale(1.2);\n }\n 32.5% {\n transform: scale(1.2);\n }\n 35% {\n transform: scale(1.5);\n }\n 100% {\n transform: scale(1.5);\n }\n }\n @keyframes magic {\n 0% {\n transform: scale(1.5) translate(0, 0) rotate(0);\n }\n 10% {\n transform: scale(1.5) translate(-5px, 2.5px) rotate(-10deg);\n }\n 20% {\n transform: scale(1.5) translate(-10px, 0) rotate(-20deg);\n }\n 30% {\n transform: scale(1.5) translate(-5px, -2.5px) rotate(-30deg);\n }\n 40% {\n transform: scale(1.5) translate(0, 0) rotate(-20deg);\n }\n 50% {\n transform: scale(1.5) translate(5px, 2.5px) rotate(-10deg);\n }\n 60% {\n transform: scale(1.5) translate(10px, 0) rotate(0);\n }\n 70% {\n transform: scale(1.5) translate(5px, -2.5px) rotate(10deg);\n }\n 100% {\n transform: scale(1.5) translate(0, 0) rotate(0);\n }\n }\n @keyframes lock {\n 0% {\n transform: scale(1.5) translateY(0);\n }\n 20% {\n transform: scale(1.5) translateY(-5px);\n }\n 30% {\n transform: scale(1.5) translateY(5px);\n }\n 50% {\n transform: scale(1.5) translateY(-5px);\n }\n 60% {\n transform: scale(1.5) translateY(5px);\n }\n 100% {\n transform: scale(1.5) translateY(0);\n }\n }\n @keyframes unlock {\n 0% {\n transform: scale(1.5) rotate(-15deg);\n }\n 15% {\n transform: scale(1.5) rotate(-40deg);\n }\n 30% {\n transform: scale(1.5) rotate(5deg);\n }\n 45% {\n transform: scale(1.5) rotate(-30deg);\n }\n 60% {\n transform: scale(1.5) rotate(-5deg);\n }\n 75% {\n transform: scale(1.5) rotate(-20deg);\n }\n 90% {\n transform: scale(1.5) rotate(-15deg);\n }\n 100% {\n transform: scale(1.5) rotate(-15deg);\n }\n }\n @keyframes hourglass {\n 0% {\n transform: scale(1.5) rotate(0);\n }\n 35% {\n transform: scale(1.5) rotate(180deg);\n }\n 65% {\n transform: scale(1.5) rotate(180deg);\n }\n 100% {\n transform: scale(1.5) rotate(0);\n }\n }\n @keyframes eraser {\n 0% {\n transform: scale(1.5) translate(0, 0);\n }\n 15% {\n transform: scale(1.5) translate(-10px, -5px);\n }\n 30% {\n transform: scale(1.5) translate(-10px, 5px);\n }\n 45% {\n transform: scale(1.5) translate(-5px, -5px);\n }\n 60% {\n transform: scale(1.5) translate(-5px, 5px);\n }\n 75% {\n transform: scale(1.5) translate(0, 0);\n }\n 100% {\n transform: scale(1.5) translate(10px, 0);\n }\n }\n @keyframes rocket {\n 0% {\n transform: scale(1.5) translate(0, 0);\n opacity: 1;\n }\n 5% {\n transform: scale(1.5) translate(2px, 0);\n opacity: 1;\n }\n 10% {\n transform: scale(1.5) translate(1px, -2px);\n opacity: 1;\n }\n 15% {\n transform: scale(1.5) translate(3px, -1px);\n opacity: 1;\n }\n 20% {\n transform: scale(1.5) translate(2px, -3px);\n opacity: 1;\n }\n 25% {\n transform: scale(1.5) translate(4px, -2px);\n opacity: 1;\n }\n 50% {\n transform: scale(1.5) translate(10px, -10px);\n opacity: 0;\n }\n 51% {\n transform: scale(1.5) translate(-10px, 10px);\n opacity: 0;\n }\n 100% {\n transform: scale(1.5) translate(0, 0);\n opacity: 1;\n }\n }\n @keyframes times {\n 0% {\n transform: scale(1.5) translateX(0);\n }\n 15% {\n transform: scale(1.5) translateX(5px);\n }\n 30% {\n transform: scale(1.5) translateX(-5px);\n }\n 45% {\n transform: scale(1.5) translateX(3px);\n }\n 60% {\n transform: scale(1.5) translateX(-3px);\n }\n 75% {\n transform: scale(1.5) translateX(0);\n }\n 100% {\n transform: scale(1.5) translateX(0);\n }\n }\n}\n</style>\n","<template>\n <component\n :is=\"href ? 'a' : 'button'\"\n :class=\"[\n 'nb-button',\n `nb-button--${variant}`,\n `nb-button--${size}`,\n { 'nb-button--outlined': outlined },\n { 'nb-button--loading': loading },\n { 'nb-button--icon-only': isIconOnly },\n ]\"\n :href=\"href ?? undefined\"\n :target=\"href ? target : undefined\"\n :rel=\"href ? rel : undefined\"\n :disabled=\"!href ? disabled || loading : undefined\"\n :aria-disabled=\"href && (disabled || loading) ? true : undefined\"\n :type=\"!href ? type : undefined\"\n @click=\"disabled || loading ? undefined : $emit('click', $event)\"\n >\n <slot />\n <div v-if=\"loading || icon\" class=\"nb-button__decorations\">\n <span v-if=\"loading\" class=\"nb-button__spinner\" aria-hidden=\"true\" />\n <NbIcon\n v-else-if=\"icon\"\n :name=\"icon\"\n :size=\"iconSize\"\n class=\"nb-button__icon\"\n />\n </div>\n </component>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed, useSlots } from 'vue'\nimport { ESizeShort } from '@/types/Size.d'\nimport { EButtonType, IButtonProps } from './Button.d'\nimport NbIcon from './Icon.vue'\n\nconst props = withDefaults(defineProps<IButtonProps>(), {\n variant: undefined,\n outlined: false,\n size: ESizeShort.Medium,\n disabled: false,\n loading: false,\n icon: undefined,\n type: EButtonType.Button,\n href: undefined,\n target: undefined,\n rel: undefined,\n})\n\ndefineEmits<{ click: [event: MouseEvent] }>()\n\nconst slots = useSlots()\nconst isIconOnly = computed(\n () => !slots.default && !!(props.icon || props.loading),\n)\n\nconst iconSizeMap: Record<string, number> = {\n xxs: 10,\n xs: 12,\n sm: 12,\n md: 14,\n lg: 16,\n xl: 16,\n xxl: 20,\n}\nconst iconSize = computed(() => iconSizeMap[props.size ?? 'md'] ?? 14)\n</script>\n\n<style scoped lang=\"scss\">\n.nb-button {\n display: inline-flex;\n align-items: center;\n justify-content: flex-start;\n gap: 6px;\n border: none;\n font-family: inherit;\n font-weight: 500;\n cursor: pointer;\n transition:\n background 0.15s,\n opacity 0.15s,\n box-shadow 0.15s;\n white-space: nowrap;\n outline: none;\n\n &:focus-visible {\n outline: 1px solid var(--nb-c-focus-ring);\n outline-offset: -2px;\n }\n line-height: 1;\n position: relative;\n text-decoration: none;\n background: var(--nb-c-contrast);\n color: var(--nb-c-surface);\n padding-inline: calc(var(--nb-base-unit) * 2) calc(var(--nb-base-unit) * 8);\n &--xxs {\n height: calc(var(--nb-base-unit) * 2);\n padding-block: 0;\n font-size: var(--nb-font-size-12);\n --nb-button-icon-size: var(--nb-font-size-12);\n --nb-button-padding-end: calc(var(--nb-base-unit) * 5);\n }\n &--xs {\n height: calc(var(--nb-base-unit) * 3);\n font-size: var(--nb-font-size-12);\n --nb-button-icon-size: var(--nb-font-size-12);\n --nb-button-padding-end: calc(var(--nb-base-unit) * 5);\n }\n &--sm {\n height: calc(var(--nb-base-unit) * 4);\n font-size: var(--nb-font-size-12);\n --nb-button-icon-size: var(--nb-font-size-12);\n --nb-button-padding-end: calc(var(--nb-base-unit) * 5);\n }\n &--md {\n height: calc(var(--nb-base-unit) * 5);\n font-size: var(--nb-font-size-14);\n --nb-button-icon-size: var(--nb-font-size-14);\n --nb-button-padding-end: calc(var(--nb-base-unit) * 5);\n }\n &--lg {\n height: calc(var(--nb-base-unit) * 6);\n font-size: var(--nb-font-size-14);\n --nb-button-icon-size: var(--nb-font-size-14);\n --nb-button-padding-end: calc(var(--nb-base-unit) * 5);\n }\n &--xl {\n height: calc(var(--nb-base-unit) * 8);\n padding-block: 14px;\n font-size: var(--nb-font-size-16);\n align-items: flex-start;\n --nb-button-icon-size: var(--nb-font-size-16);\n --nb-button-padding-end: calc(var(--nb-base-unit) * 6);\n .nb-button__decorations {\n padding-top: calc(var(--nb-base-unit) * 2);\n align-items: start;\n }\n }\n &--xxl {\n height: calc(var(--nb-base-unit) * 16);\n padding-block: 14px;\n font-size: var(--nb-font-size-32);\n align-items: flex-start;\n --nb-button-icon-size: var(--nb-font-size-32);\n --nb-button-padding-end: calc(var(--nb-base-unit) * 8);\n .nb-button__decorations {\n padding-top: calc(var(--nb-base-unit) * 3);\n align-items: start;\n }\n }\n\n // Icon-only: no slot content → square button, icon centered and slightly larger\n &--icon-only {\n padding: 0;\n align-items: center;\n justify-content: center;\n\n &.nb-button--xxs {\n width: 16px;\n --nb-button-icon-size: 12px;\n }\n &.nb-button--xs {\n width: 24px;\n --nb-button-icon-size: 14px;\n }\n &.nb-button--sm {\n width: 32px;\n --nb-button-icon-size: 16px;\n }\n &.nb-button--md {\n width: 40px;\n --nb-button-icon-size: 18px;\n }\n &.nb-button--lg {\n width: 48px;\n --nb-button-icon-size: 20px;\n }\n &.nb-button--xl {\n width: 48px;\n --nb-button-icon-size: 20px;\n }\n &.nb-button--xxl {\n width: 64px;\n --nb-button-icon-size: 26px;\n }\n\n .nb-button__decorations {\n inset: 0;\n width: auto;\n padding-top: 0;\n align-items: center;\n }\n }\n\n /* Primary: dark brand */\n &--primary {\n background: var(--nb-c-primary);\n color: var(--nb-c-primary-a11y);\n &:hover:not(:disabled) {\n background: var(--nb-c-primary-hover);\n color: var(--nb-c-primary-hover-a11y);\n }\n &:active:not(:disabled) {\n background: var(--nb-c-primary-active);\n color: var(--nb-c-primary-active-a11y);\n }\n &:focus-visible {\n outline-color: var(--nb-c-primary-hover-a11y);\n }\n }\n\n /* Secondary: subtle border */\n &--secondary {\n background: var(--nb-c-secondary);\n color: var(--nb-c-secondary-a11y);\n &:hover:not(:disabled) {\n background: var(--nb-c-secondary-hover);\n color: var(--nb-c-secondary-hover-a11y);\n }\n &:active:not(:disabled) {\n background: var(--nb-c-secondary-active);\n color: var(--nb-c-secondary-active-a11y);\n }\n &:focus-visible {\n outline-color: var(--nb-c-secondary-hover-a11y);\n }\n }\n\n /* Ghost: transparent */\n &--ghost {\n background: transparent;\n color: var(--nb-c-contrast);\n border-bottom: 1px solid transparent;\n padding-inline: calc(var(--nb-base-unit) * 2) calc(var(--nb-base-unit) * 2);\n --nb-button-padding-end: auto;\n &:hover:not(:disabled) {\n background: var(--nb-c-primary-hover);\n color: var(--nb-c-primary-hover-a11y);\n border-color: var(--nb-c-grape-hyacinth-200);\n }\n &:active:not(:disabled) {\n background: var(--nb-c-primary-active);\n color: var(--nb-c-primary-active-a11y);\n }\n &:focus-visible {\n outline-color: var(--nb-c-contrast);\n }\n }\n\n /* Warning: red */\n &--warning {\n background: var(--nb-c-warning);\n color: var(--nb-c-warning-a11y);\n &:hover:not(:disabled) {\n background: var(--nb-c-warning-hover);\n color: var(--nb-c-warning-hover-a11y);\n }\n &:active:not(:disabled) {\n background: var(--nb-c-warning-active);\n color: var(--nb-c-warning-active-a11y);\n }\n &:focus-visible {\n outline-color: var(--nb-c-warning-hover-a11y);\n }\n }\n\n /* Danger: red */\n &--danger {\n background: var(--nb-c-danger);\n color: var(--nb-c-danger-a11y);\n &:hover:not(:disabled) {\n background: var(--nb-c-danger-hover);\n color: var(--nb-c-danger-hover-a11y);\n }\n &:active:not(:disabled) {\n background: var(--nb-c-danger-active);\n color: var(--nb-c-danger-active-a11y);\n }\n &:focus-visible {\n outline-color: var(--nb-c-danger-hover-a11y);\n }\n }\n\n /* Success: green */\n &--success {\n background: var(--nb-c-success);\n color: var(--nb-c-success-a11y);\n &:hover:not(:disabled) {\n background: var(--nb-c-success-hover);\n color: var(--nb-c-success-hover-a11y);\n }\n &:active:not(:disabled) {\n background: var(--nb-c-success-active);\n color: var(--nb-c-success-active-a11y);\n }\n &:focus-visible {\n outline-color: var(--nb-c-success-hover-a11y);\n }\n }\n\n &--info {\n background: var(--nb-c-info);\n color: var(--nb-c-info-a11y);\n &:hover:not(:disabled) {\n background: var(--nb-c-info-hover);\n color: var(--nb-c-info-hover-a11y);\n }\n &:active:not(:disabled) {\n background: var(--nb-c-info-active);\n color: var(--nb-c-info-active-a11y);\n }\n &:focus-visible {\n outline-color: var(--nb-c-info-hover-a11y);\n }\n }\n\n &:disabled,\n &[aria-disabled='true'] {\n opacity: 0.45;\n cursor: not-allowed;\n pointer-events: none;\n &:focus-visible {\n outline-color: transparent;\n }\n }\n\n // Outlined modifier: transparent background, colored border and text\n // Applied to all variants except ghost (which has no bg by design)\n &--outlined:not(&--ghost) {\n background: transparent;\n color: var(--nb-c-contrast);\n border: 1px solid currentColor;\n }\n\n &--outlined {\n &.nb-button--primary {\n color: var(--nb-c-primary);\n &:hover:not(:disabled) {\n color: var(--nb-c-primary);\n background: color-mix(in srgb, var(--nb-c-primary) 8%, transparent);\n }\n &:active:not(:disabled) {\n background: color-mix(in srgb, var(--nb-c-primary) 14%, transparent);\n }\n &:focus-visible {\n outline-color: var(--nb-c-primary);\n }\n }\n &.nb-button--secondary {\n color: var(--nb-c-secondary);\n &:hover:not(:disabled) {\n color: var(--nb-c-secondary);\n background: color-mix(in srgb, var(--nb-c-secondary) 8%, transparent);\n }\n &:active:not(:disabled) {\n background: color-mix(in srgb, var(--nb-c-secondary) 14%, transparent);\n }\n &:focus-visible {\n outline-color: var(--nb-c-secondary);\n }\n }\n &.nb-button--danger {\n color: var(--nb-c-danger);\n &:hover:not(:disabled) {\n color: var(--nb-c-danger);\n background: color-mix(in srgb, var(--nb-c-danger) 8%, transparent);\n }\n &:active:not(:disabled) {\n background: color-mix(in srgb, var(--nb-c-danger) 14%, transparent);\n }\n &:focus-visible {\n outline-color: var(--nb-c-danger);\n }\n }\n &.nb-button--warning {\n color: var(--nb-c-warning);\n &:hover:not(:disabled) {\n color: var(--nb-c-warning);\n background: color-mix(in srgb, var(--nb-c-warning) 8%, transparent);\n }\n &:active:not(:disabled) {\n background: color-mix(in srgb, var(--nb-c-warning) 14%, transparent);\n }\n &:focus-visible {\n outline-color: var(--nb-c-warning);\n }\n }\n &.nb-button--success {\n color: var(--nb-c-success);\n &:hover:not(:disabled) {\n color: var(--nb-c-success);\n background: color-mix(in srgb, var(--nb-c-success) 8%, transparent);\n }\n &:active:not(:disabled) {\n background: color-mix(in srgb, var(--nb-c-success) 14%, transparent);\n }\n &:focus-visible {\n outline-color: var(--nb-c-success);\n }\n }\n &.nb-button--info {\n color: var(--nb-c-info);\n &:hover:not(:disabled) {\n color: var(--nb-c-info);\n background: color-mix(in srgb, var(--nb-c-info) 8%, transparent);\n }\n &:active:not(:disabled) {\n background: color-mix(in srgb, var(--nb-c-info) 14%, transparent);\n }\n &:focus-visible {\n outline-color: var(--nb-c-info);\n }\n }\n }\n\n &--loading {\n cursor: wait;\n pointer-events: none;\n }\n\n &__decorations {\n position: absolute;\n right: 0;\n top: 0;\n bottom: 0;\n width: var(--nb-button-padding-end);\n display: flex;\n align-items: center;\n justify-content: center;\n pointer-events: none;\n }\n\n &__spinner {\n width: var(--nb-button-icon-size, 14px);\n height: var(--nb-button-icon-size, 14px);\n border: 2px solid currentColor;\n border-top-color: transparent;\n border-radius: 50%;\n animation: nb-spin 0.6s linear infinite;\n }\n\n @keyframes nb-spin {\n to {\n transform: rotate(360deg);\n }\n }\n}\n</style>\n","<template>\n <component\n :is=\"href ? 'a' : 'button'\"\n :class=\"[\n 'nb-button',\n `nb-button--${variant}`,\n `nb-button--${size}`,\n { 'nb-button--outlined': outlined },\n { 'nb-button--loading': loading },\n { 'nb-button--icon-only': isIconOnly },\n ]\"\n :href=\"href ?? undefined\"\n :target=\"href ? target : undefined\"\n :rel=\"href ? rel : undefined\"\n :disabled=\"!href ? disabled || loading : undefined\"\n :aria-disabled=\"href && (disabled || loading) ? true : undefined\"\n :type=\"!href ? type : undefined\"\n @click=\"disabled || loading ? undefined : $emit('click', $event)\"\n >\n <slot />\n <div v-if=\"loading || icon\" class=\"nb-button__decorations\">\n <span v-if=\"loading\" class=\"nb-button__spinner\" aria-hidden=\"true\" />\n <NbIcon\n v-else-if=\"icon\"\n :name=\"icon\"\n :size=\"iconSize\"\n class=\"nb-button__icon\"\n />\n </div>\n </component>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed, useSlots } from 'vue'\nimport { ESizeShort } from '@/types/Size.d'\nimport { EButtonType, IButtonProps } from './Button.d'\nimport NbIcon from './Icon.vue'\n\nconst props = withDefaults(defineProps<IButtonProps>(), {\n variant: undefined,\n outlined: false,\n size: ESizeShort.Medium,\n disabled: false,\n loading: false,\n icon: undefined,\n type: EButtonType.Button,\n href: undefined,\n target: undefined,\n rel: undefined,\n})\n\ndefineEmits<{ click: [event: MouseEvent] }>()\n\nconst slots = useSlots()\nconst isIconOnly = computed(\n () => !slots.default && !!(props.icon || props.loading),\n)\n\nconst iconSizeMap: Record<string, number> = {\n xxs: 10,\n xs: 12,\n sm: 12,\n md: 14,\n lg: 16,\n xl: 16,\n xxl: 20,\n}\nconst iconSize = computed(() => iconSizeMap[props.size ?? 'md'] ?? 14)\n</script>\n\n<style scoped lang=\"scss\">\n.nb-button {\n display: inline-flex;\n align-items: center;\n justify-content: flex-start;\n gap: 6px;\n border: none;\n font-family: inherit;\n font-weight: 500;\n cursor: pointer;\n transition:\n background 0.15s,\n opacity 0.15s,\n box-shadow 0.15s;\n white-space: nowrap;\n outline: none;\n\n &:focus-visible {\n outline: 1px solid var(--nb-c-focus-ring);\n outline-offset: -2px;\n }\n line-height: 1;\n position: relative;\n text-decoration: none;\n background: var(--nb-c-contrast);\n color: var(--nb-c-surface);\n padding-inline: calc(var(--nb-base-unit) * 2) calc(var(--nb-base-unit) * 8);\n &--xxs {\n height: calc(var(--nb-base-unit) * 2);\n padding-block: 0;\n font-size: var(--nb-font-size-12);\n --nb-button-icon-size: var(--nb-font-size-12);\n --nb-button-padding-end: calc(var(--nb-base-unit) * 5);\n }\n &--xs {\n height: calc(var(--nb-base-unit) * 3);\n font-size: var(--nb-font-size-12);\n --nb-button-icon-size: var(--nb-font-size-12);\n --nb-button-padding-end: calc(var(--nb-base-unit) * 5);\n }\n &--sm {\n height: calc(var(--nb-base-unit) * 4);\n font-size: var(--nb-font-size-12);\n --nb-button-icon-size: var(--nb-font-size-12);\n --nb-button-padding-end: calc(var(--nb-base-unit) * 5);\n }\n &--md {\n height: calc(var(--nb-base-unit) * 5);\n font-size: var(--nb-font-size-14);\n --nb-button-icon-size: var(--nb-font-size-14);\n --nb-button-padding-end: calc(var(--nb-base-unit) * 5);\n }\n &--lg {\n height: calc(var(--nb-base-unit) * 6);\n font-size: var(--nb-font-size-14);\n --nb-button-icon-size: var(--nb-font-size-14);\n --nb-button-padding-end: calc(var(--nb-base-unit) * 5);\n }\n &--xl {\n height: calc(var(--nb-base-unit) * 8);\n padding-block: 14px;\n font-size: var(--nb-font-size-16);\n align-items: flex-start;\n --nb-button-icon-size: var(--nb-font-size-16);\n --nb-button-padding-end: calc(var(--nb-base-unit) * 6);\n .nb-button__decorations {\n padding-top: calc(var(--nb-base-unit) * 2);\n align-items: start;\n }\n }\n &--xxl {\n height: calc(var(--nb-base-unit) * 16);\n padding-block: 14px;\n font-size: var(--nb-font-size-32);\n align-items: flex-start;\n --nb-button-icon-size: var(--nb-font-size-32);\n --nb-button-padding-end: calc(var(--nb-base-unit) * 8);\n .nb-button__decorations {\n padding-top: calc(var(--nb-base-unit) * 3);\n align-items: start;\n }\n }\n\n // Icon-only: no slot content → square button, icon centered and slightly larger\n &--icon-only {\n padding: 0;\n align-items: center;\n justify-content: center;\n\n &.nb-button--xxs {\n width: 16px;\n --nb-button-icon-size: 12px;\n }\n &.nb-button--xs {\n width: 24px;\n --nb-button-icon-size: 14px;\n }\n &.nb-button--sm {\n width: 32px;\n --nb-button-icon-size: 16px;\n }\n &.nb-button--md {\n width: 40px;\n --nb-button-icon-size: 18px;\n }\n &.nb-button--lg {\n width: 48px;\n --nb-button-icon-size: 20px;\n }\n &.nb-button--xl {\n width: 48px;\n --nb-button-icon-size: 20px;\n }\n &.nb-button--xxl {\n width: 64px;\n --nb-button-icon-size: 26px;\n }\n\n .nb-button__decorations {\n inset: 0;\n width: auto;\n padding-top: 0;\n align-items: center;\n }\n }\n\n /* Primary: dark brand */\n &--primary {\n background: var(--nb-c-primary);\n color: var(--nb-c-primary-a11y);\n &:hover:not(:disabled) {\n background: var(--nb-c-primary-hover);\n color: var(--nb-c-primary-hover-a11y);\n }\n &:active:not(:disabled) {\n background: var(--nb-c-primary-active);\n color: var(--nb-c-primary-active-a11y);\n }\n &:focus-visible {\n outline-color: var(--nb-c-primary-hover-a11y);\n }\n }\n\n /* Secondary: subtle border */\n &--secondary {\n background: var(--nb-c-secondary);\n color: var(--nb-c-secondary-a11y);\n &:hover:not(:disabled) {\n background: var(--nb-c-secondary-hover);\n color: var(--nb-c-secondary-hover-a11y);\n }\n &:active:not(:disabled) {\n background: var(--nb-c-secondary-active);\n color: var(--nb-c-secondary-active-a11y);\n }\n &:focus-visible {\n outline-color: var(--nb-c-secondary-hover-a11y);\n }\n }\n\n /* Ghost: transparent */\n &--ghost {\n background: transparent;\n color: var(--nb-c-contrast);\n border-bottom: 1px solid transparent;\n padding-inline: calc(var(--nb-base-unit) * 2) calc(var(--nb-base-unit) * 2);\n --nb-button-padding-end: auto;\n &:hover:not(:disabled) {\n background: var(--nb-c-primary-hover);\n color: var(--nb-c-primary-hover-a11y);\n border-color: var(--nb-c-grape-hyacinth-200);\n }\n &:active:not(:disabled) {\n background: var(--nb-c-primary-active);\n color: var(--nb-c-primary-active-a11y);\n }\n &:focus-visible {\n outline-color: var(--nb-c-contrast);\n }\n }\n\n /* Warning: red */\n &--warning {\n background: var(--nb-c-warning);\n color: var(--nb-c-warning-a11y);\n &:hover:not(:disabled) {\n background: var(--nb-c-warning-hover);\n color: var(--nb-c-warning-hover-a11y);\n }\n &:active:not(:disabled) {\n background: var(--nb-c-warning-active);\n color: var(--nb-c-warning-active-a11y);\n }\n &:focus-visible {\n outline-color: var(--nb-c-warning-hover-a11y);\n }\n }\n\n /* Danger: red */\n &--danger {\n background: var(--nb-c-danger);\n color: var(--nb-c-danger-a11y);\n &:hover:not(:disabled) {\n background: var(--nb-c-danger-hover);\n color: var(--nb-c-danger-hover-a11y);\n }\n &:active:not(:disabled) {\n background: var(--nb-c-danger-active);\n color: var(--nb-c-danger-active-a11y);\n }\n &:focus-visible {\n outline-color: var(--nb-c-danger-hover-a11y);\n }\n }\n\n /* Success: green */\n &--success {\n background: var(--nb-c-success);\n color: var(--nb-c-success-a11y);\n &:hover:not(:disabled) {\n background: var(--nb-c-success-hover);\n color: var(--nb-c-success-hover-a11y);\n }\n &:active:not(:disabled) {\n background: var(--nb-c-success-active);\n color: var(--nb-c-success-active-a11y);\n }\n &:focus-visible {\n outline-color: var(--nb-c-success-hover-a11y);\n }\n }\n\n &--info {\n background: var(--nb-c-info);\n color: var(--nb-c-info-a11y);\n &:hover:not(:disabled) {\n background: var(--nb-c-info-hover);\n color: var(--nb-c-info-hover-a11y);\n }\n &:active:not(:disabled) {\n background: var(--nb-c-info-active);\n color: var(--nb-c-info-active-a11y);\n }\n &:focus-visible {\n outline-color: var(--nb-c-info-hover-a11y);\n }\n }\n\n &:disabled,\n &[aria-disabled='true'] {\n opacity: 0.45;\n cursor: not-allowed;\n pointer-events: none;\n &:focus-visible {\n outline-color: transparent;\n }\n }\n\n // Outlined modifier: transparent background, colored border and text\n // Applied to all variants except ghost (which has no bg by design)\n &--outlined:not(&--ghost) {\n background: transparent;\n color: var(--nb-c-contrast);\n border: 1px solid currentColor;\n }\n\n &--outlined {\n &.nb-button--primary {\n color: var(--nb-c-primary);\n &:hover:not(:disabled) {\n color: var(--nb-c-primary);\n background: color-mix(in srgb, var(--nb-c-primary) 8%, transparent);\n }\n &:active:not(:disabled) {\n background: color-mix(in srgb, var(--nb-c-primary) 14%, transparent);\n }\n &:focus-visible {\n outline-color: var(--nb-c-primary);\n }\n }\n &.nb-button--secondary {\n color: var(--nb-c-secondary);\n &:hover:not(:disabled) {\n color: var(--nb-c-secondary);\n background: color-mix(in srgb, var(--nb-c-secondary) 8%, transparent);\n }\n &:active:not(:disabled) {\n background: color-mix(in srgb, var(--nb-c-secondary) 14%, transparent);\n }\n &:focus-visible {\n outline-color: var(--nb-c-secondary);\n }\n }\n &.nb-button--danger {\n color: var(--nb-c-danger);\n &:hover:not(:disabled) {\n color: var(--nb-c-danger);\n background: color-mix(in srgb, var(--nb-c-danger) 8%, transparent);\n }\n &:active:not(:disabled) {\n background: color-mix(in srgb, var(--nb-c-danger) 14%, transparent);\n }\n &:focus-visible {\n outline-color: var(--nb-c-danger);\n }\n }\n &.nb-button--warning {\n color: var(--nb-c-warning);\n &:hover:not(:disabled) {\n color: var(--nb-c-warning);\n background: color-mix(in srgb, var(--nb-c-warning) 8%, transparent);\n }\n &:active:not(:disabled) {\n background: color-mix(in srgb, var(--nb-c-warning) 14%, transparent);\n }\n &:focus-visible {\n outline-color: var(--nb-c-warning);\n }\n }\n &.nb-button--success {\n color: var(--nb-c-success);\n &:hover:not(:disabled) {\n color: var(--nb-c-success);\n background: color-mix(in srgb, var(--nb-c-success) 8%, transparent);\n }\n &:active:not(:disabled) {\n background: color-mix(in srgb, var(--nb-c-success) 14%, transparent);\n }\n &:focus-visible {\n outline-color: var(--nb-c-success);\n }\n }\n &.nb-button--info {\n color: var(--nb-c-info);\n &:hover:not(:disabled) {\n color: var(--nb-c-info);\n background: color-mix(in srgb, var(--nb-c-info) 8%, transparent);\n }\n &:active:not(:disabled) {\n background: color-mix(in srgb, var(--nb-c-info) 14%, transparent);\n }\n &:focus-visible {\n outline-color: var(--nb-c-info);\n }\n }\n }\n\n &--loading {\n cursor: wait;\n pointer-events: none;\n }\n\n &__decorations {\n position: absolute;\n right: 0;\n top: 0;\n bottom: 0;\n width: var(--nb-button-padding-end);\n display: flex;\n align-items: center;\n justify-content: center;\n pointer-events: none;\n }\n\n &__spinner {\n width: var(--nb-button-icon-size, 14px);\n height: var(--nb-button-icon-size, 14px);\n border: 2px solid currentColor;\n border-top-color: transparent;\n border-radius: 50%;\n animation: nb-spin 0.6s linear infinite;\n }\n\n @keyframes nb-spin {\n to {\n transform: rotate(360deg);\n }\n }\n}\n</style>\n","<template>\n <label :class=\"['nb-checkbox', { 'nb-checkbox--disabled': disabled }]\">\n <span class=\"nb-checkbox__control\">\n <input\n type=\"checkbox\"\n :checked=\"modelValue\"\n :disabled=\"disabled\"\n :indeterminate=\"indeterminate\"\n class=\"nb-checkbox__input\"\n @change=\"handleChange\"\n />\n <span class=\"nb-checkbox__box\">\n <svg\n v-if=\"modelValue && !indeterminate\"\n class=\"nb-checkbox__check\"\n viewBox=\"0 0 10 8\"\n fill=\"none\"\n >\n <path\n d=\"M1 4l3 3 5-6\"\n stroke=\"currentColor\"\n stroke-width=\"1.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n />\n </svg>\n <span v-if=\"indeterminate\" class=\"nb-checkbox__dash\" />\n </span>\n </span>\n <span v-if=\"label\" class=\"nb-checkbox__label\">{{ label }}</span>\n <slot v-else />\n </label>\n</template>\n\n<script setup lang=\"ts\">\nimport { ICheckboxProps } from './Checkbox.d'\n\nconst props = withDefaults(defineProps<ICheckboxProps>(), {\n id: 'checkbox',\n modelValue: false,\n disabled: false,\n indeterminate: false,\n})\n\nconst emit = defineEmits<{ 'update:modelValue': [value: boolean] }>()\n\nfunction handleChange(e: Event) {\n if (!props.disabled) {\n emit('update:modelValue', (e.target as HTMLInputElement).checked)\n }\n}\n</script>\n\n<style scoped lang=\"scss\">\n.nb-checkbox {\n display: inline-flex;\n align-items: center;\n gap: 8px;\n cursor: pointer;\n user-select: none;\n\n &--disabled {\n opacity: 0.5;\n cursor: not-allowed;\n }\n\n &__control {\n position: relative;\n flex-shrink: 0;\n }\n\n &__input {\n position: absolute;\n opacity: 0;\n width: 0;\n height: 0;\n pointer-events: none;\n }\n\n &__box {\n display: flex;\n align-items: center;\n justify-content: center;\n width: 16px;\n height: 16px;\n border: 1.5px solid var(--nb-c-border, #d0d0d0);\n border-radius: 4px;\n transition:\n background 0.15s,\n border-color 0.15s,\n box-shadow 0.15s;\n color: #fff;\n }\n\n &__check {\n width: 10px;\n height: 8px;\n }\n\n &__dash {\n width: 8px;\n height: 1.5px;\n background: currentColor;\n border-radius: 1px;\n }\n\n &__label {\n font-size: 13px;\n color: var(--nb-c-text, #1a1a2e);\n line-height: 1.4;\n }\n\n /* Checked / indeterminate state */\n &__input:checked ~ &__box,\n &__input:indeterminate ~ &__box {\n background: var(--nb-c-grape-hyacinth-500, #5856a9);\n border-color: var(--nb-c-grape-hyacinth-500, #5856a9);\n }\n\n /* Focus ring */\n &__input:focus-visible ~ &__box {\n box-shadow: 0 0 0 3px var(--nb-c-grape-hyacinth-200, #d6d5f2);\n }\n\n &:hover:not(.nb-checkbox--disabled) &__box {\n border-color: var(--nb-c-grape-hyacinth-400, #7b79c0);\n }\n}\n</style>\n","<template>\n <label :class=\"['nb-checkbox', { 'nb-checkbox--disabled': disabled }]\">\n <span class=\"nb-checkbox__control\">\n <input\n type=\"checkbox\"\n :checked=\"modelValue\"\n :disabled=\"disabled\"\n :indeterminate=\"indeterminate\"\n class=\"nb-checkbox__input\"\n @change=\"handleChange\"\n />\n <span class=\"nb-checkbox__box\">\n <svg\n v-if=\"modelValue && !indeterminate\"\n class=\"nb-checkbox__check\"\n viewBox=\"0 0 10 8\"\n fill=\"none\"\n >\n <path\n d=\"M1 4l3 3 5-6\"\n stroke=\"currentColor\"\n stroke-width=\"1.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n />\n </svg>\n <span v-if=\"indeterminate\" class=\"nb-checkbox__dash\" />\n </span>\n </span>\n <span v-if=\"label\" class=\"nb-checkbox__label\">{{ label }}</span>\n <slot v-else />\n </label>\n</template>\n\n<script setup lang=\"ts\">\nimport { ICheckboxProps } from './Checkbox.d'\n\nconst props = withDefaults(defineProps<ICheckboxProps>(), {\n id: 'checkbox',\n modelValue: false,\n disabled: false,\n indeterminate: false,\n})\n\nconst emit = defineEmits<{ 'update:modelValue': [value: boolean] }>()\n\nfunction handleChange(e: Event) {\n if (!props.disabled) {\n emit('update:modelValue', (e.target as HTMLInputElement).checked)\n }\n}\n</script>\n\n<style scoped lang=\"scss\">\n.nb-checkbox {\n display: inline-flex;\n align-items: center;\n gap: 8px;\n cursor: pointer;\n user-select: none;\n\n &--disabled {\n opacity: 0.5;\n cursor: not-allowed;\n }\n\n &__control {\n position: relative;\n flex-shrink: 0;\n }\n\n &__input {\n position: absolute;\n opacity: 0;\n width: 0;\n height: 0;\n pointer-events: none;\n }\n\n &__box {\n display: flex;\n align-items: center;\n justify-content: center;\n width: 16px;\n height: 16px;\n border: 1.5px solid var(--nb-c-border, #d0d0d0);\n border-radius: 4px;\n transition:\n background 0.15s,\n border-color 0.15s,\n box-shadow 0.15s;\n color: #fff;\n }\n\n &__check {\n width: 10px;\n height: 8px;\n }\n\n &__dash {\n width: 8px;\n height: 1.5px;\n background: currentColor;\n border-radius: 1px;\n }\n\n &__label {\n font-size: 13px;\n color: var(--nb-c-text, #1a1a2e);\n line-height: 1.4;\n }\n\n /* Checked / indeterminate state */\n &__input:checked ~ &__box,\n &__input:indeterminate ~ &__box {\n background: var(--nb-c-grape-hyacinth-500, #5856a9);\n border-color: var(--nb-c-grape-hyacinth-500, #5856a9);\n }\n\n /* Focus ring */\n &__input:focus-visible ~ &__box {\n box-shadow: 0 0 0 3px var(--nb-c-grape-hyacinth-200, #d6d5f2);\n }\n\n &:hover:not(.nb-checkbox--disabled) &__box {\n border-color: var(--nb-c-grape-hyacinth-400, #7b79c0);\n }\n}\n</style>\n","<template>\n <div\n :class=\"['nb-color-strip-wrapper', `nb-color-strip-wrapper--${variant}`]\"\n >\n <!-- DEFAULT variant: label above via NbLabel -->\n <template v-if=\"variant === 'default'\">\n <slot v-if=\"$slots.label\" name=\"label\" />\n <NbLabel v-else-if=\"label\" :for=\"colorStripId\" :disabled=\"false\">\n {{ label }}\n </NbLabel>\n </template>\n\n <!-- FLUID variant: label inside the field box -->\n <div\n v-if=\"variant === 'fluid' && (label || $slots.label)\"\n class=\"nb-color-strip-wrapper__inner-header\"\n >\n <slot v-if=\"$slots.label\" name=\"label\" />\n <label v-else class=\"nb-color-strip-wrapper__inner-label\">{{\n label\n }}</label>\n </div>\n\n <!-- Strip (always rendered) -->\n <NbGrid\n :id=\"colorStripId\"\n dir=\"row\"\n gap=\"xs\"\n :class=\"classes\"\n :shrink=\"false\"\n :style=\"stripStyle\"\n >\n <NbGrid\n is=\"button\"\n v-for=\"option in optionsToRender\"\n :key=\"`option-${option.id || option.value}`\"\n align=\"center\"\n justify=\"center\"\n :class=\"buttonClasses(option)\"\n :style=\"buttonStyle(option)\"\n :disabled=\"option.disabled\"\n @click=\"!onlyView && selectOption(option.value)\"\n >\n <NbIcon\n v-if=\"!onlyView && isSelected(option.value) && !isNullOption(option)\"\n name=\"check-light\"\n :color=\"getContrastingColor(option)\"\n />\n <NbIcon\n v-if=\"isNullOption(option)\"\n name=\"empty\"\n :weight=\"getNullOptionWeight(option)\"\n />\n </NbGrid>\n </NbGrid>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed, ref, watch } from 'vue'\nimport { useId } from 'vue'\nimport { IColorStripProps, IOption } from './ColorStrip'\n\nconst props = withDefaults(defineProps<IColorStripProps>(), {\n options: () => ['#DCDCDC', '#C0C0C0', '#808080'],\n onlyView: false,\n allowMultiple: false,\n wrap: false,\n showNull: false,\n label: undefined,\n id: undefined,\n variant: 'default',\n})\n\nconst autoId = `nb-color-strip-${useId()}`\nconst colorStripId = computed(() => props.id ?? autoId)\n\nconst model = defineModel<any>({\n set: (val) => val,\n})\n\nconst normalizedOptions = computed<IOption[]>(() => {\n return props.options.map((item) => {\n if (typeof item === 'string') {\n return {\n value: item,\n color: item,\n }\n } else {\n return {\n ...item,\n color: item.color || '#FFFFFF',\n value: item.value !== undefined ? item.value : item.color,\n }\n }\n })\n})\n\nconst nullOption: IOption = {\n id: 'null-option',\n value: null as unknown as string | number,\n color: 'transparent',\n label: 'None',\n}\n\nconst hasNullState = ref(model.value == null)\n\nwatch(\n () => model.value,\n (value) => {\n if (value == null) {\n hasNullState.value = true\n }\n },\n)\n\nconst shouldShowNullOption = computed(() => {\n if (props.allowMultiple) return false\n\n return props.showNull || hasNullState.value\n})\n\nconst optionsToRender = computed<IOption[]>(() => {\n if (shouldShowNullOption.value) {\n return [nullOption, ...normalizedOptions.value]\n }\n\n return normalizedOptions.value\n})\n\nconst COLOR_DIAMETER_PX = 30\nconst WRAP_GAP_PX = 8\n\nconst stripStyle = computed(() => {\n if (!props.wrap) {\n return {\n maxWidth: 'none',\n flexWrap: 'nowrap',\n }\n }\n\n const colorCount = optionsToRender.value.length\n if (colorCount <= 0) return undefined\n\n const columns = Math.ceil(Math.sqrt(colorCount))\n const maxWidth = columns * COLOR_DIAMETER_PX + (columns - 1) * WRAP_GAP_PX\n\n return {\n maxWidth: `${maxWidth}px`,\n flexWrap: 'wrap',\n }\n})\n\nconst classes = computed(() => ({\n 'nb-color-strip': true,\n 'only-view': props.onlyView,\n}))\n\nconst isSelected = (value: string | number | null | undefined) => {\n if (props.onlyView) return false\n\n if (value === null) {\n return model.value == null\n }\n\n if (value === undefined) return false\n\n if (props.allowMultiple) {\n return Array.isArray(model.value) && model.value.includes(value)\n } else {\n return model.value === value\n }\n}\n\nconst buttonClasses = (option: IOption) => ({\n 'nb-color-strip-color': true,\n 'nb-color-strip-color-null': isNullOption(option),\n selected: !props.onlyView && isSelected(option.value),\n})\n\nconst buttonStyle = (option: IOption) => {\n if (isNullOption(option)) return undefined\n\n return {\n backgroundColor: option.color,\n }\n}\n\nconst isNullOption = (option: IOption) => option.id === 'null-option'\n\nconst getNullOptionWeight = (option: IOption): any => {\n return isSelected(option.value) ? 'duotone' : 'regular'\n}\n\nconst selectOption = (value: string | number | null | undefined) => {\n if (value === undefined) return\n\n if (!props.allowMultiple && value === null) {\n model.value = null\n return\n }\n\n if (props.allowMultiple) {\n const current = Array.isArray(model.value) ? model.value.slice() : []\n const index = current.indexOf(value)\n if (index !== -1) {\n current.splice(index, 1)\n } else {\n current.push(value)\n }\n model.value = current\n } else {\n model.value = value\n }\n}\n\n// Utility function to get contrast color\nfunction getContrastingColor(option: string | IOption): string {\n const color = typeof option === 'string' ? option : option.color\n const resolvedColor =\n color && color.startsWith('var(')\n ? getComputedStyle(document.documentElement)\n .getPropertyValue(color.slice(4, -1).trim())\n .trim()\n : color\n\n const { r, g, b } = hexToRgb(resolvedColor || '#FFFFFF')\n // Calculate luminance according to WCAG\n const luminance = (0.299 * r + 0.587 * g + 0.114 * b) / 255\n return luminance > 0.5 ? 'black' : 'white'\n}\n\nfunction hexToRgb(hex: string) {\n let cleanHex = hex.replace('#', '')\n if (cleanHex.length === 3) {\n cleanHex = cleanHex\n .split('')\n .map((c) => c + c)\n .join('')\n }\n const num = parseInt(cleanHex, 16)\n return {\n r: (num >> 16) & 255,\n g: (num >> 8) & 255,\n b: num & 255,\n }\n}\n</script>\n\n<style lang=\"scss\" scoped>\n$nb-color-diameter: 30px;\n\n.nb-color-strip-wrapper {\n display: flex;\n flex-direction: column;\n gap: 4px;\n\n // ── Fluid variant ──────────────────────────────────────────────────────────\n &--fluid {\n justify-content: space-between;\n gap: 0;\n background: var(--nb-c-field-bg);\n border-bottom: 1px solid var(--nb-c-field-border);\n padding-top: 8px;\n min-height: calc(var(--nb-base-unit) * 8);\n\n .nb-color-strip {\n padding: 0 var(--nb-field-padding-h) 6px;\n }\n }\n}\n\n// ── Fluid inner header ────────────────────────────────────────────────────────\n.nb-color-strip-wrapper__inner-header {\n display: flex;\n align-items: center;\n padding: 0 var(--nb-field-padding-h);\n margin-bottom: 4px;\n}\n\n.nb-color-strip-wrapper__inner-label {\n flex: 1;\n min-width: 0;\n font-family: var(--nb-font-family-sans);\n font-size: var(--nb-font-size-12);\n font-weight: 500;\n color: var(--nb-c-text-muted);\n letter-spacing: 0.02em;\n cursor: default;\n user-select: none;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n\n// ── Strip ─────────────────────────────────────────────────────────────────────\n.nb-color-strip {\n display: flex;\n flex-wrap: wrap;\n max-width: calc(#{$nb-color-diameter} * 8 + 8px * 7);\n\n :deep(button) {\n position: relative;\n width: $nb-color-diameter;\n height: $nb-color-diameter;\n border: 1px solid transparent;\n cursor: pointer;\n padding: 0;\n transition:\n border 0.2s,\n box-shadow 0.2s;\n\n &:disabled {\n cursor: not-allowed;\n opacity: 0.6;\n }\n\n &:focus,\n &:focus-visible,\n &.selected {\n border: 1px solid var(--nb-c-surface);\n outline: 0;\n\n &:before {\n content: '';\n position: absolute;\n top: calc(var(--nb-base-unit) / -2);\n left: calc(var(--nb-base-unit) / -2);\n right: calc(var(--nb-base-unit) / -2);\n bottom: calc(var(--nb-base-unit) / -2);\n border: 2px solid var(--nb-c-primary);\n }\n }\n\n &.nb-color-strip-color-null {\n border-color: var(--nb-c-primary);\n color: var(--nb-c-primary);\n }\n }\n}\n\n.only-view {\n :deep(button) {\n cursor: initial;\n\n &:focus,\n &:focus-visible,\n &.selected {\n border-color: transparent;\n outline: initial;\n\n &:before {\n content: none;\n }\n }\n }\n}\n</style>\n","<template>\n <div\n :class=\"['nb-color-strip-wrapper', `nb-color-strip-wrapper--${variant}`]\"\n >\n <!-- DEFAULT variant: label above via NbLabel -->\n <template v-if=\"variant === 'default'\">\n <slot v-if=\"$slots.label\" name=\"label\" />\n <NbLabel v-else-if=\"label\" :for=\"colorStripId\" :disabled=\"false\">\n {{ label }}\n </NbLabel>\n </template>\n\n <!-- FLUID variant: label inside the field box -->\n <div\n v-if=\"variant === 'fluid' && (label || $slots.label)\"\n class=\"nb-color-strip-wrapper__inner-header\"\n >\n <slot v-if=\"$slots.label\" name=\"label\" />\n <label v-else class=\"nb-color-strip-wrapper__inner-label\">{{\n label\n }}</label>\n </div>\n\n <!-- Strip (always rendered) -->\n <NbGrid\n :id=\"colorStripId\"\n dir=\"row\"\n gap=\"xs\"\n :class=\"classes\"\n :shrink=\"false\"\n :style=\"stripStyle\"\n >\n <NbGrid\n is=\"button\"\n v-for=\"option in optionsToRender\"\n :key=\"`option-${option.id || option.value}`\"\n align=\"center\"\n justify=\"center\"\n :class=\"buttonClasses(option)\"\n :style=\"buttonStyle(option)\"\n :disabled=\"option.disabled\"\n @click=\"!onlyView && selectOption(option.value)\"\n >\n <NbIcon\n v-if=\"!onlyView && isSelected(option.value) && !isNullOption(option)\"\n name=\"check-light\"\n :color=\"getContrastingColor(option)\"\n />\n <NbIcon\n v-if=\"isNullOption(option)\"\n name=\"empty\"\n :weight=\"getNullOptionWeight(option)\"\n />\n </NbGrid>\n </NbGrid>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed, ref, watch } from 'vue'\nimport { useId } from 'vue'\nimport { IColorStripProps, IOption } from './ColorStrip'\n\nconst props = withDefaults(defineProps<IColorStripProps>(), {\n options: () => ['#DCDCDC', '#C0C0C0', '#808080'],\n onlyView: false,\n allowMultiple: false,\n wrap: false,\n showNull: false,\n label: undefined,\n id: undefined,\n variant: 'default',\n})\n\nconst autoId = `nb-color-strip-${useId()}`\nconst colorStripId = computed(() => props.id ?? autoId)\n\nconst model = defineModel<any>({\n set: (val) => val,\n})\n\nconst normalizedOptions = computed<IOption[]>(() => {\n return props.options.map((item) => {\n if (typeof item === 'string') {\n return {\n value: item,\n color: item,\n }\n } else {\n return {\n ...item,\n color: item.color || '#FFFFFF',\n value: item.value !== undefined ? item.value : item.color,\n }\n }\n })\n})\n\nconst nullOption: IOption = {\n id: 'null-option',\n value: null as unknown as string | number,\n color: 'transparent',\n label: 'None',\n}\n\nconst hasNullState = ref(model.value == null)\n\nwatch(\n () => model.value,\n (value) => {\n if (value == null) {\n hasNullState.value = true\n }\n },\n)\n\nconst shouldShowNullOption = computed(() => {\n if (props.allowMultiple) return false\n\n return props.showNull || hasNullState.value\n})\n\nconst optionsToRender = computed<IOption[]>(() => {\n if (shouldShowNullOption.value) {\n return [nullOption, ...normalizedOptions.value]\n }\n\n return normalizedOptions.value\n})\n\nconst COLOR_DIAMETER_PX = 30\nconst WRAP_GAP_PX = 8\n\nconst stripStyle = computed(() => {\n if (!props.wrap) {\n return {\n maxWidth: 'none',\n flexWrap: 'nowrap',\n }\n }\n\n const colorCount = optionsToRender.value.length\n if (colorCount <= 0) return undefined\n\n const columns = Math.ceil(Math.sqrt(colorCount))\n const maxWidth = columns * COLOR_DIAMETER_PX + (columns - 1) * WRAP_GAP_PX\n\n return {\n maxWidth: `${maxWidth}px`,\n flexWrap: 'wrap',\n }\n})\n\nconst classes = computed(() => ({\n 'nb-color-strip': true,\n 'only-view': props.onlyView,\n}))\n\nconst isSelected = (value: string | number | null | undefined) => {\n if (props.onlyView) return false\n\n if (value === null) {\n return model.value == null\n }\n\n if (value === undefined) return false\n\n if (props.allowMultiple) {\n return Array.isArray(model.value) && model.value.includes(value)\n } else {\n return model.value === value\n }\n}\n\nconst buttonClasses = (option: IOption) => ({\n 'nb-color-strip-color': true,\n 'nb-color-strip-color-null': isNullOption(option),\n selected: !props.onlyView && isSelected(option.value),\n})\n\nconst buttonStyle = (option: IOption) => {\n if (isNullOption(option)) return undefined\n\n return {\n backgroundColor: option.color,\n }\n}\n\nconst isNullOption = (option: IOption) => option.id === 'null-option'\n\nconst getNullOptionWeight = (option: IOption): any => {\n return isSelected(option.value) ? 'duotone' : 'regular'\n}\n\nconst selectOption = (value: string | number | null | undefined) => {\n if (value === undefined) return\n\n if (!props.allowMultiple && value === null) {\n model.value = null\n return\n }\n\n if (props.allowMultiple) {\n const current = Array.isArray(model.value) ? model.value.slice() : []\n const index = current.indexOf(value)\n if (index !== -1) {\n current.splice(index, 1)\n } else {\n current.push(value)\n }\n model.value = current\n } else {\n model.value = value\n }\n}\n\n// Utility function to get contrast color\nfunction getContrastingColor(option: string | IOption): string {\n const color = typeof option === 'string' ? option : option.color\n const resolvedColor =\n color && color.startsWith('var(')\n ? getComputedStyle(document.documentElement)\n .getPropertyValue(color.slice(4, -1).trim())\n .trim()\n : color\n\n const { r, g, b } = hexToRgb(resolvedColor || '#FFFFFF')\n // Calculate luminance according to WCAG\n const luminance = (0.299 * r + 0.587 * g + 0.114 * b) / 255\n return luminance > 0.5 ? 'black' : 'white'\n}\n\nfunction hexToRgb(hex: string) {\n let cleanHex = hex.replace('#', '')\n if (cleanHex.length === 3) {\n cleanHex = cleanHex\n .split('')\n .map((c) => c + c)\n .join('')\n }\n const num = parseInt(cleanHex, 16)\n return {\n r: (num >> 16) & 255,\n g: (num >> 8) & 255,\n b: num & 255,\n }\n}\n</script>\n\n<style lang=\"scss\" scoped>\n$nb-color-diameter: 30px;\n\n.nb-color-strip-wrapper {\n display: flex;\n flex-direction: column;\n gap: 4px;\n\n // ── Fluid variant ──────────────────────────────────────────────────────────\n &--fluid {\n justify-content: space-between;\n gap: 0;\n background: var(--nb-c-field-bg);\n border-bottom: 1px solid var(--nb-c-field-border);\n padding-top: 8px;\n min-height: calc(var(--nb-base-unit) * 8);\n\n .nb-color-strip {\n padding: 0 var(--nb-field-padding-h) 6px;\n }\n }\n}\n\n// ── Fluid inner header ────────────────────────────────────────────────────────\n.nb-color-strip-wrapper__inner-header {\n display: flex;\n align-items: center;\n padding: 0 var(--nb-field-padding-h);\n margin-bottom: 4px;\n}\n\n.nb-color-strip-wrapper__inner-label {\n flex: 1;\n min-width: 0;\n font-family: var(--nb-font-family-sans);\n font-size: var(--nb-font-size-12);\n font-weight: 500;\n color: var(--nb-c-text-muted);\n letter-spacing: 0.02em;\n cursor: default;\n user-select: none;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n\n// ── Strip ─────────────────────────────────────────────────────────────────────\n.nb-color-strip {\n display: flex;\n flex-wrap: wrap;\n max-width: calc(#{$nb-color-diameter} * 8 + 8px * 7);\n\n :deep(button) {\n position: relative;\n width: $nb-color-diameter;\n height: $nb-color-diameter;\n border: 1px solid transparent;\n cursor: pointer;\n padding: 0;\n transition:\n border 0.2s,\n box-shadow 0.2s;\n\n &:disabled {\n cursor: not-allowed;\n opacity: 0.6;\n }\n\n &:focus,\n &:focus-visible,\n &.selected {\n border: 1px solid var(--nb-c-surface);\n outline: 0;\n\n &:before {\n content: '';\n position: absolute;\n top: calc(var(--nb-base-unit) / -2);\n left: calc(var(--nb-base-unit) / -2);\n right: calc(var(--nb-base-unit) / -2);\n bottom: calc(var(--nb-base-unit) / -2);\n border: 2px solid var(--nb-c-primary);\n }\n }\n\n &.nb-color-strip-color-null {\n border-color: var(--nb-c-primary);\n color: var(--nb-c-primary);\n }\n }\n}\n\n.only-view {\n :deep(button) {\n cursor: initial;\n\n &:focus,\n &:focus-visible,\n &.selected {\n border-color: transparent;\n outline: initial;\n\n &:before {\n content: none;\n }\n }\n }\n}\n</style>\n","// #region EVariant\nenum EVariant {\n Primary = 'primary',\n Secondary = 'secondary',\n Ghost = 'ghost',\n Danger = 'danger',\n Success = 'success',\n Warning = 'warning',\n}\n// #endregion EVariant\n\nexport { EVariant }\n","import { IDefaultProps } from '@/types/Props.d'\nimport { EVariant } from '@/types/Variants.d'\n\nenum EFileUploaderStatus {\n Idle = 'idle',\n Loading = 'loading',\n Success = 'success',\n}\n\ninterface IFileItem {\n file: File\n status: EFileUploaderStatus\n error?: string\n}\n\ninterface IFileUploaderProps extends IDefaultProps {\n heading?: string\n description?: string\n buttonLabel?: string\n variant?: EVariant\n accept?: string\n multiple?: boolean\n maxSize?: number\n disabled?: boolean\n}\n\nexport { EFileUploaderStatus, IFileItem, IFileUploaderProps }\n","<template>\n <div\n class=\"nb-file-uploader\"\n @dragenter.prevent=\"onDragEnter\"\n @dragover.prevent\n @dragleave.prevent=\"onDragLeave\"\n @drop.prevent=\"onDrop\"\n >\n <p v-if=\"heading\" class=\"nb-file-uploader__heading\">{{ heading }}</p>\n <p v-if=\"description\" class=\"nb-file-uploader__description\">\n {{ description }}\n </p>\n\n <!-- Drag-over state: replaces the button with a visual drop zone -->\n <div\n v-if=\"isDragging\"\n class=\"nb-file-uploader__dropzone\"\n :class=\"`nb-file-uploader__dropzone--${variant}`\"\n >\n <span class=\"nb-file-uploader__drop-label\">\n Drag and drop files here<br />or click to upload\n </span>\n </div>\n\n <NbButton\n v-else\n class=\"nb-file-uploader__btn\"\n :variant=\"variant\"\n @click.stop=\"openFilePicker\"\n >\n {{ buttonLabel }}\n </NbButton>\n\n <input\n ref=\"inputRef\"\n type=\"file\"\n class=\"nb-file-uploader__input\"\n :accept=\"accept\"\n :multiple=\"multiple\"\n @change=\"onFileInputChange\"\n />\n\n <ul v-if=\"files.length\" class=\"nb-file-uploader__list\">\n <li\n v-for=\"(item, i) in files\"\n :key=\"i\"\n class=\"nb-file-uploader__item\"\n :class=\"{\n 'nb-file-uploader__item--error': item.error,\n 'nb-file-uploader__item--success': item.status === 'success',\n }\"\n >\n <span class=\"nb-file-uploader__name\">{{ item.file.name }}</span>\n\n <span class=\"nb-file-uploader__status\">\n <NbIcon\n v-if=\"item.status === 'loading'\"\n name=\"circle-notch\"\n class=\"nb-file-uploader__spinner\"\n />\n <NbIcon\n v-else-if=\"item.status === 'success'\"\n name=\"check-circle-fill\"\n class=\"nb-file-uploader__check\"\n />\n <NbIcon\n v-if=\"item.error\"\n name=\"warning-circle-fill\"\n class=\"nb-file-uploader__warn\"\n />\n <button\n v-if=\"item.status !== 'loading'\"\n class=\"nb-file-uploader__remove\"\n type=\"button\"\n :aria-label=\"`Remove ${item.file.name}`\"\n @click=\"removeFile(i)\"\n >\n <NbIcon name=\"x\" />\n </button>\n </span>\n\n <div v-if=\"item.error\" class=\"nb-file-uploader__error\">\n {{ item.error }}\n </div>\n </li>\n </ul>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { ref } from 'vue'\nimport { EVariant } from '@/types/Variants.d'\nimport {\n EFileUploaderStatus,\n IFileItem,\n IFileUploaderProps,\n} from './FileUploader.d'\nimport NbButton from './Button.vue'\nimport NbIcon from './Icon.vue'\n\nconst props = withDefaults(defineProps<IFileUploaderProps>(), {\n buttonLabel: 'Add file',\n variant: EVariant.Primary,\n multiple: false,\n})\n\nconst emit = defineEmits<{\n /** Emitted whenever the file list changes. */\n (e: 'change', files: File[]): void\n /** Emitted when a file is removed. */\n (e: 'remove', file: File): void\n}>()\n\nconst inputRef = ref<HTMLInputElement | null>(null)\nconst files = ref<IFileItem[]>([])\nconst isDragging = ref(false)\nlet dragCounter = 0\n\nfunction openFilePicker() {\n inputRef.value?.click()\n}\n\nfunction validateFile(file: File): string | undefined {\n if (props.maxSize && file.size > props.maxSize) {\n return `File exceeds size limit.`\n }\n if (props.accept) {\n const exts = props.accept.split(',').map((a) => a.trim().toLowerCase())\n const name = file.name.toLowerCase()\n const matched = exts.some((ext) => {\n if (ext.startsWith('.')) return name.endsWith(ext)\n if (ext.includes('/'))\n return (\n file.type === ext || file.type.startsWith(ext.replaceAll('*', ''))\n )\n return false\n })\n if (!matched) return `File type not accepted.`\n }\n}\n\nfunction addFiles(rawFiles: FileList | File[]) {\n const list = Array.from(rawFiles)\n if (!props.multiple) {\n files.value = []\n }\n for (const file of list) {\n const error = validateFile(file)\n files.value.push({ file, status: EFileUploaderStatus.Idle, error })\n }\n emit(\n 'change',\n files.value.filter((f) => !f.error).map((f) => f.file),\n )\n}\n\nfunction onFileInputChange(event: Event) {\n const input = event.target as HTMLInputElement\n if (input.files?.length) {\n addFiles(input.files)\n input.value = ''\n }\n}\n\nfunction onDragEnter() {\n dragCounter++\n isDragging.value = true\n}\n\nfunction onDragLeave() {\n dragCounter--\n if (dragCounter <= 0) {\n dragCounter = 0\n isDragging.value = false\n }\n}\n\nfunction onDrop(event: DragEvent) {\n dragCounter = 0\n isDragging.value = false\n const dropped = event.dataTransfer?.files\n if (dropped?.length) addFiles(dropped)\n}\n\nfunction removeFile(index: number) {\n const removed = files.value[index]\n files.value.splice(index, 1)\n emit('remove', removed.file)\n emit(\n 'change',\n files.value.filter((f) => !f.error).map((f) => f.file),\n )\n}\n\n/** Programmatically set file status (useful after async upload). */\nfunction setFileStatus(\n index: number,\n status: IFileItem['status'],\n error?: string,\n) {\n if (files.value[index]) {\n files.value[index].status = status\n files.value[index].error = error\n }\n}\n\ndefineExpose({ files, setFileStatus })\n</script>\n\n<style scoped lang=\"scss\">\n.nb-file-uploader {\n display: flex;\n flex-direction: column;\n gap: 0.75rem;\n\n &__heading {\n margin: 0;\n font-weight: 600;\n font-size: 1rem;\n color: var(--nb-c-text);\n }\n\n &__description {\n margin: 0;\n font-size: 0.875rem;\n color: var(--nb-c-text-secondary, #6b7280);\n border-left: 3px solid var(--nb-c-border, #e5e7eb);\n padding-left: 0.75rem;\n line-height: 1.5;\n }\n\n &__input {\n display: none;\n }\n\n &__btn {\n align-self: flex-start;\n }\n\n // Drop zone: shown only while dragging (v-if controlled)\n &__dropzone {\n display: flex;\n align-items: center;\n justify-content: center;\n padding: 2rem 1.5rem;\n border: 2px dashed var(--nb-c-border, #d1d5db);\n border-radius: 6px;\n cursor: pointer;\n text-align: center;\n transition:\n border-color 0.15s,\n background 0.15s;\n\n &--primary {\n background: color-mix(in srgb, var(--nb-c-primary) 6%, transparent);\n border-color: color-mix(in srgb, var(--nb-c-primary) 60%, transparent);\n .nb-file-uploader__drop-label {\n color: var(--nb-c-primary);\n }\n }\n &--secondary {\n background: color-mix(in srgb, var(--nb-c-secondary) 6%, transparent);\n border-color: color-mix(in srgb, var(--nb-c-secondary) 60%, transparent);\n .nb-file-uploader__drop-label {\n color: var(--nb-c-secondary);\n }\n }\n &--danger {\n background: color-mix(in srgb, var(--nb-c-danger) 6%, transparent);\n border-color: color-mix(in srgb, var(--nb-c-danger) 60%, transparent);\n .nb-file-uploader__drop-label {\n color: var(--nb-c-danger);\n }\n }\n &--success {\n background: color-mix(in srgb, var(--nb-c-success) 6%, transparent);\n border-color: color-mix(in srgb, var(--nb-c-success) 60%, transparent);\n .nb-file-uploader__drop-label {\n color: var(--nb-c-success);\n }\n }\n &--warning {\n background: color-mix(in srgb, var(--nb-c-warning) 6%, transparent);\n border-color: color-mix(in srgb, var(--nb-c-warning) 60%, transparent);\n .nb-file-uploader__drop-label {\n color: var(--nb-c-warning);\n }\n }\n }\n\n &__drop-label {\n font-size: 0.9rem;\n line-height: 1.6;\n pointer-events: none;\n }\n\n &__list {\n list-style: none;\n margin: 0;\n padding: 0;\n display: flex;\n flex-direction: column;\n gap: 0.5rem;\n }\n\n &__item {\n display: grid;\n grid-template-columns: 1fr auto;\n grid-template-rows: auto auto;\n align-items: center;\n background: var(--nb-c-surface, #f3f4f6);\n border: 1px solid transparent;\n border-radius: 4px;\n padding: 0.6rem 0.875rem;\n font-size: 0.9rem;\n color: var(--nb-c-text);\n transition: border-color 0.15s;\n\n &--error {\n border-color: var(--nb-c-danger);\n }\n }\n\n &__name {\n grid-column: 1;\n grid-row: 1;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n padding-right: 0.5rem;\n }\n\n &__status {\n grid-column: 2;\n grid-row: 1;\n display: flex;\n align-items: center;\n gap: 0.25rem;\n }\n\n &__error {\n grid-column: 1 / -1;\n grid-row: 2;\n font-size: 0.8125rem;\n color: var(--nb-c-danger);\n padding-top: 0.35rem;\n border-top: 1px solid var(--nb-c-border, #e5e7eb);\n margin-top: 0.35rem;\n }\n\n &__remove {\n background: none;\n border: none;\n padding: 0;\n cursor: pointer;\n color: var(--nb-c-text-secondary, #6b7280);\n display: flex;\n align-items: center;\n line-height: 1;\n\n &:hover {\n color: var(--nb-c-text);\n }\n }\n\n &__spinner {\n animation: nb-spin 0.8s linear infinite;\n color: var(--nb-c-primary);\n }\n\n &__check {\n color: var(--nb-c-primary);\n }\n\n &__warn {\n color: var(--nb-c-danger);\n }\n}\n\n@keyframes nb-spin {\n to {\n transform: rotate(360deg);\n }\n}\n</style>\n","<template>\n <div\n class=\"nb-file-uploader\"\n @dragenter.prevent=\"onDragEnter\"\n @dragover.prevent\n @dragleave.prevent=\"onDragLeave\"\n @drop.prevent=\"onDrop\"\n >\n <p v-if=\"heading\" class=\"nb-file-uploader__heading\">{{ heading }}</p>\n <p v-if=\"description\" class=\"nb-file-uploader__description\">\n {{ description }}\n </p>\n\n <!-- Drag-over state: replaces the button with a visual drop zone -->\n <div\n v-if=\"isDragging\"\n class=\"nb-file-uploader__dropzone\"\n :class=\"`nb-file-uploader__dropzone--${variant}`\"\n >\n <span class=\"nb-file-uploader__drop-label\">\n Drag and drop files here<br />or click to upload\n </span>\n </div>\n\n <NbButton\n v-else\n class=\"nb-file-uploader__btn\"\n :variant=\"variant\"\n @click.stop=\"openFilePicker\"\n >\n {{ buttonLabel }}\n </NbButton>\n\n <input\n ref=\"inputRef\"\n type=\"file\"\n class=\"nb-file-uploader__input\"\n :accept=\"accept\"\n :multiple=\"multiple\"\n @change=\"onFileInputChange\"\n />\n\n <ul v-if=\"files.length\" class=\"nb-file-uploader__list\">\n <li\n v-for=\"(item, i) in files\"\n :key=\"i\"\n class=\"nb-file-uploader__item\"\n :class=\"{\n 'nb-file-uploader__item--error': item.error,\n 'nb-file-uploader__item--success': item.status === 'success',\n }\"\n >\n <span class=\"nb-file-uploader__name\">{{ item.file.name }}</span>\n\n <span class=\"nb-file-uploader__status\">\n <NbIcon\n v-if=\"item.status === 'loading'\"\n name=\"circle-notch\"\n class=\"nb-file-uploader__spinner\"\n />\n <NbIcon\n v-else-if=\"item.status === 'success'\"\n name=\"check-circle-fill\"\n class=\"nb-file-uploader__check\"\n />\n <NbIcon\n v-if=\"item.error\"\n name=\"warning-circle-fill\"\n class=\"nb-file-uploader__warn\"\n />\n <button\n v-if=\"item.status !== 'loading'\"\n class=\"nb-file-uploader__remove\"\n type=\"button\"\n :aria-label=\"`Remove ${item.file.name}`\"\n @click=\"removeFile(i)\"\n >\n <NbIcon name=\"x\" />\n </button>\n </span>\n\n <div v-if=\"item.error\" class=\"nb-file-uploader__error\">\n {{ item.error }}\n </div>\n </li>\n </ul>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { ref } from 'vue'\nimport { EVariant } from '@/types/Variants.d'\nimport {\n EFileUploaderStatus,\n IFileItem,\n IFileUploaderProps,\n} from './FileUploader.d'\nimport NbButton from './Button.vue'\nimport NbIcon from './Icon.vue'\n\nconst props = withDefaults(defineProps<IFileUploaderProps>(), {\n buttonLabel: 'Add file',\n variant: EVariant.Primary,\n multiple: false,\n})\n\nconst emit = defineEmits<{\n /** Emitted whenever the file list changes. */\n (e: 'change', files: File[]): void\n /** Emitted when a file is removed. */\n (e: 'remove', file: File): void\n}>()\n\nconst inputRef = ref<HTMLInputElement | null>(null)\nconst files = ref<IFileItem[]>([])\nconst isDragging = ref(false)\nlet dragCounter = 0\n\nfunction openFilePicker() {\n inputRef.value?.click()\n}\n\nfunction validateFile(file: File): string | undefined {\n if (props.maxSize && file.size > props.maxSize) {\n return `File exceeds size limit.`\n }\n if (props.accept) {\n const exts = props.accept.split(',').map((a) => a.trim().toLowerCase())\n const name = file.name.toLowerCase()\n const matched = exts.some((ext) => {\n if (ext.startsWith('.')) return name.endsWith(ext)\n if (ext.includes('/'))\n return (\n file.type === ext || file.type.startsWith(ext.replaceAll('*', ''))\n )\n return false\n })\n if (!matched) return `File type not accepted.`\n }\n}\n\nfunction addFiles(rawFiles: FileList | File[]) {\n const list = Array.from(rawFiles)\n if (!props.multiple) {\n files.value = []\n }\n for (const file of list) {\n const error = validateFile(file)\n files.value.push({ file, status: EFileUploaderStatus.Idle, error })\n }\n emit(\n 'change',\n files.value.filter((f) => !f.error).map((f) => f.file),\n )\n}\n\nfunction onFileInputChange(event: Event) {\n const input = event.target as HTMLInputElement\n if (input.files?.length) {\n addFiles(input.files)\n input.value = ''\n }\n}\n\nfunction onDragEnter() {\n dragCounter++\n isDragging.value = true\n}\n\nfunction onDragLeave() {\n dragCounter--\n if (dragCounter <= 0) {\n dragCounter = 0\n isDragging.value = false\n }\n}\n\nfunction onDrop(event: DragEvent) {\n dragCounter = 0\n isDragging.value = false\n const dropped = event.dataTransfer?.files\n if (dropped?.length) addFiles(dropped)\n}\n\nfunction removeFile(index: number) {\n const removed = files.value[index]\n files.value.splice(index, 1)\n emit('remove', removed.file)\n emit(\n 'change',\n files.value.filter((f) => !f.error).map((f) => f.file),\n )\n}\n\n/** Programmatically set file status (useful after async upload). */\nfunction setFileStatus(\n index: number,\n status: IFileItem['status'],\n error?: string,\n) {\n if (files.value[index]) {\n files.value[index].status = status\n files.value[index].error = error\n }\n}\n\ndefineExpose({ files, setFileStatus })\n</script>\n\n<style scoped lang=\"scss\">\n.nb-file-uploader {\n display: flex;\n flex-direction: column;\n gap: 0.75rem;\n\n &__heading {\n margin: 0;\n font-weight: 600;\n font-size: 1rem;\n color: var(--nb-c-text);\n }\n\n &__description {\n margin: 0;\n font-size: 0.875rem;\n color: var(--nb-c-text-secondary, #6b7280);\n border-left: 3px solid var(--nb-c-border, #e5e7eb);\n padding-left: 0.75rem;\n line-height: 1.5;\n }\n\n &__input {\n display: none;\n }\n\n &__btn {\n align-self: flex-start;\n }\n\n // Drop zone: shown only while dragging (v-if controlled)\n &__dropzone {\n display: flex;\n align-items: center;\n justify-content: center;\n padding: 2rem 1.5rem;\n border: 2px dashed var(--nb-c-border, #d1d5db);\n border-radius: 6px;\n cursor: pointer;\n text-align: center;\n transition:\n border-color 0.15s,\n background 0.15s;\n\n &--primary {\n background: color-mix(in srgb, var(--nb-c-primary) 6%, transparent);\n border-color: color-mix(in srgb, var(--nb-c-primary) 60%, transparent);\n .nb-file-uploader__drop-label {\n color: var(--nb-c-primary);\n }\n }\n &--secondary {\n background: color-mix(in srgb, var(--nb-c-secondary) 6%, transparent);\n border-color: color-mix(in srgb, var(--nb-c-secondary) 60%, transparent);\n .nb-file-uploader__drop-label {\n color: var(--nb-c-secondary);\n }\n }\n &--danger {\n background: color-mix(in srgb, var(--nb-c-danger) 6%, transparent);\n border-color: color-mix(in srgb, var(--nb-c-danger) 60%, transparent);\n .nb-file-uploader__drop-label {\n color: var(--nb-c-danger);\n }\n }\n &--success {\n background: color-mix(in srgb, var(--nb-c-success) 6%, transparent);\n border-color: color-mix(in srgb, var(--nb-c-success) 60%, transparent);\n .nb-file-uploader__drop-label {\n color: var(--nb-c-success);\n }\n }\n &--warning {\n background: color-mix(in srgb, var(--nb-c-warning) 6%, transparent);\n border-color: color-mix(in srgb, var(--nb-c-warning) 60%, transparent);\n .nb-file-uploader__drop-label {\n color: var(--nb-c-warning);\n }\n }\n }\n\n &__drop-label {\n font-size: 0.9rem;\n line-height: 1.6;\n pointer-events: none;\n }\n\n &__list {\n list-style: none;\n margin: 0;\n padding: 0;\n display: flex;\n flex-direction: column;\n gap: 0.5rem;\n }\n\n &__item {\n display: grid;\n grid-template-columns: 1fr auto;\n grid-template-rows: auto auto;\n align-items: center;\n background: var(--nb-c-surface, #f3f4f6);\n border: 1px solid transparent;\n border-radius: 4px;\n padding: 0.6rem 0.875rem;\n font-size: 0.9rem;\n color: var(--nb-c-text);\n transition: border-color 0.15s;\n\n &--error {\n border-color: var(--nb-c-danger);\n }\n }\n\n &__name {\n grid-column: 1;\n grid-row: 1;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n padding-right: 0.5rem;\n }\n\n &__status {\n grid-column: 2;\n grid-row: 1;\n display: flex;\n align-items: center;\n gap: 0.25rem;\n }\n\n &__error {\n grid-column: 1 / -1;\n grid-row: 2;\n font-size: 0.8125rem;\n color: var(--nb-c-danger);\n padding-top: 0.35rem;\n border-top: 1px solid var(--nb-c-border, #e5e7eb);\n margin-top: 0.35rem;\n }\n\n &__remove {\n background: none;\n border: none;\n padding: 0;\n cursor: pointer;\n color: var(--nb-c-text-secondary, #6b7280);\n display: flex;\n align-items: center;\n line-height: 1;\n\n &:hover {\n color: var(--nb-c-text);\n }\n }\n\n &__spinner {\n animation: nb-spin 0.8s linear infinite;\n color: var(--nb-c-primary);\n }\n\n &__check {\n color: var(--nb-c-primary);\n }\n\n &__warn {\n color: var(--nb-c-danger);\n }\n}\n\n@keyframes nb-spin {\n to {\n transform: rotate(360deg);\n }\n}\n</style>\n","<template>\n <i\n :class=\"classes\"\n :style=\"styles\"\n v-bind=\"attributes\"\n @click=\"!clickable ? undefined : emit('click', $event)\"\n >\n <component\n :is=\"flagComponent\"\n v-if=\"flagComponent\"\n :aria-hidden=\"true\"\n :width=\"attributes.width\"\n :height=\"attributes.height\"\n :style=\"styles\"\n />\n </i>\n</template>\n\n<script setup lang=\"ts\">\n// @ts-expect-error virtual module provided by flags vite plugin\nimport flags from 'virtual:flags'\nimport { computed } from 'vue'\nimport kebab2camel from '@/utils/kebab2camel.helper'\nimport { ESizePixel, IFlagProps } from './Flag.d'\nimport { useStableId } from '@/composables/useStableId.composable'\n\nconst props = withDefaults(defineProps<IFlagProps>(), {\n name: undefined,\n size: ESizePixel.Medium,\n clickable: false,\n})\n\nconst emit = defineEmits(['click'])\n\nconst componentInternalId = useStableId(props)\n\nconst classes = computed(() => {\n return {\n 'nb-flag': true,\n ...(props.name && { [`nb-flag--${props.name}`]: true }),\n [`nb-flag--${props.size}`]:\n typeof props.size === 'string' && ['sm', 'md', 'lg'].includes(props.size),\n 'box-clickable': props.clickable,\n }\n})\n\nconst styles = computed(() => {\n return {\n ...(typeof props.size === 'number' && {\n maxWidth: `${props.size}px`,\n maxHeight: `${props.size}px`,\n height: `${props.size}px`,\n width: `${props.size}px`,\n }),\n ...(typeof props.size === 'string' &&\n !['sm', 'md', 'lg'].includes(props.size) && {\n maxWidth: props.size,\n maxHeight: props.size,\n height: props.size,\n width: props.size,\n }),\n }\n})\n\nconst attributes = computed(() => {\n const flagSize =\n typeof props.size === 'number'\n ? props.size\n : (ESizePixel as unknown as Record<string, number>)[\n String(props.size).toUpperCase()\n ] || ESizePixel.Medium\n\n return {\n ...{ id: componentInternalId },\n ...(props.size && {\n width: `${flagSize}px`,\n height: `${flagSize}px`,\n }),\n ...(props.clickable && { role: 'button' }),\n }\n})\n\nconst flagComponent = computed(() => {\n return flags[kebab2camel(`f-${props.name.replaceAll('_', '-')}`)]\n})\n</script>\n\n<style lang=\"scss\" scoped>\n.nb-flag {\n display: flex;\n line-height: 1em;\n position: relative;\n height: fit-content;\n\n &:not(.box-clickable) {\n pointer-events: none;\n }\n\n &--lg {\n max-width: 32px;\n max-height: 32px;\n width: 32px;\n }\n &--md {\n max-width: 20px;\n max-height: 20px;\n width: 20px;\n }\n &--sm {\n max-width: 16px;\n max-height: 16px;\n width: 16px;\n }\n}\n</style>\n","<template>\n <i\n :class=\"classes\"\n :style=\"styles\"\n v-bind=\"attributes\"\n @click=\"!clickable ? undefined : emit('click', $event)\"\n >\n <component\n :is=\"flagComponent\"\n v-if=\"flagComponent\"\n :aria-hidden=\"true\"\n :width=\"attributes.width\"\n :height=\"attributes.height\"\n :style=\"styles\"\n />\n </i>\n</template>\n\n<script setup lang=\"ts\">\n// @ts-expect-error virtual module provided by flags vite plugin\nimport flags from 'virtual:flags'\nimport { computed } from 'vue'\nimport kebab2camel from '@/utils/kebab2camel.helper'\nimport { ESizePixel, IFlagProps } from './Flag.d'\nimport { useStableId } from '@/composables/useStableId.composable'\n\nconst props = withDefaults(defineProps<IFlagProps>(), {\n name: undefined,\n size: ESizePixel.Medium,\n clickable: false,\n})\n\nconst emit = defineEmits(['click'])\n\nconst componentInternalId = useStableId(props)\n\nconst classes = computed(() => {\n return {\n 'nb-flag': true,\n ...(props.name && { [`nb-flag--${props.name}`]: true }),\n [`nb-flag--${props.size}`]:\n typeof props.size === 'string' && ['sm', 'md', 'lg'].includes(props.size),\n 'box-clickable': props.clickable,\n }\n})\n\nconst styles = computed(() => {\n return {\n ...(typeof props.size === 'number' && {\n maxWidth: `${props.size}px`,\n maxHeight: `${props.size}px`,\n height: `${props.size}px`,\n width: `${props.size}px`,\n }),\n ...(typeof props.size === 'string' &&\n !['sm', 'md', 'lg'].includes(props.size) && {\n maxWidth: props.size,\n maxHeight: props.size,\n height: props.size,\n width: props.size,\n }),\n }\n})\n\nconst attributes = computed(() => {\n const flagSize =\n typeof props.size === 'number'\n ? props.size\n : (ESizePixel as unknown as Record<string, number>)[\n String(props.size).toUpperCase()\n ] || ESizePixel.Medium\n\n return {\n ...{ id: componentInternalId },\n ...(props.size && {\n width: `${flagSize}px`,\n height: `${flagSize}px`,\n }),\n ...(props.clickable && { role: 'button' }),\n }\n})\n\nconst flagComponent = computed(() => {\n return flags[kebab2camel(`f-${props.name.replaceAll('_', '-')}`)]\n})\n</script>\n\n<style lang=\"scss\" scoped>\n.nb-flag {\n display: flex;\n line-height: 1em;\n position: relative;\n height: fit-content;\n\n &:not(.box-clickable) {\n pointer-events: none;\n }\n\n &--lg {\n max-width: 32px;\n max-height: 32px;\n width: 32px;\n }\n &--md {\n max-width: 20px;\n max-height: 20px;\n width: 20px;\n }\n &--sm {\n max-width: 16px;\n max-height: 16px;\n width: 16px;\n }\n}\n</style>\n","<template>\n <NbGrid is=\"form\" dir=\"col\" gap=\"md\" class=\"nb-form\">\n <NbGrid is=\"h4\" v-if=\"title\" class=\"nb-form--header\">\n {{ title }}\n </NbGrid>\n <NbGrid is=\"p\" v-if=\"$slots.message\" class=\"nb-form--message\">\n <slot name=\"message\" />\n </NbGrid>\n <NbGrid\n is=\"div\"\n v-if=\"$slots.default\"\n dir=\"col\"\n gap=\"sm\"\n class=\"nb-form--body\"\n >\n <slot />\n </NbGrid>\n <NbGrid\n is=\"footer\"\n v-if=\"$slots.footer\"\n class=\"nb-form--footer\"\n justify=\"end\"\n >\n <slot name=\"footer\" />\n </NbGrid>\n </NbGrid>\n</template>\n\n<script lang=\"ts\" setup>\nimport { IFormProps } from './Form.d'\n\nwithDefaults(defineProps<IFormProps>(), {\n title: undefined,\n})\n</script>\n\n<style lang=\"scss\" scoped></style>\n","<template>\n <NbGrid is=\"form\" dir=\"col\" gap=\"md\" class=\"nb-form\">\n <NbGrid is=\"h4\" v-if=\"title\" class=\"nb-form--header\">\n {{ title }}\n </NbGrid>\n <NbGrid is=\"p\" v-if=\"$slots.message\" class=\"nb-form--message\">\n <slot name=\"message\" />\n </NbGrid>\n <NbGrid\n is=\"div\"\n v-if=\"$slots.default\"\n dir=\"col\"\n gap=\"sm\"\n class=\"nb-form--body\"\n >\n <slot />\n </NbGrid>\n <NbGrid\n is=\"footer\"\n v-if=\"$slots.footer\"\n class=\"nb-form--footer\"\n justify=\"end\"\n >\n <slot name=\"footer\" />\n </NbGrid>\n </NbGrid>\n</template>\n\n<script lang=\"ts\" setup>\nimport { IFormProps } from './Form.d'\n\nwithDefaults(defineProps<IFormProps>(), {\n title: undefined,\n})\n</script>\n\n<style lang=\"scss\" scoped></style>\n","import type { PropType } from 'vue'\n\n// Breakpoint type with short names\nexport type TBreakpoint = 'sm' | 'md' | 'lg' | 'xl' | 'xxl'\n\n// Grid direction types\nexport type TGridType = 'row' | 'col' | 'row-reverse' | 'col-reverse'\nexport type TGridTypeResponsive = Partial<Record<TBreakpoint, TGridType>>\n\n// Alignment types\nexport type TGridAlign = 'start' | 'end' | 'center' | 'baseline' | 'stretch'\nexport type TGridAlignResponsive = Partial<Record<TBreakpoint, TGridAlign>>\n\n// Justify types\nexport type TGridJustify =\n | 'around'\n | 'between'\n | 'center'\n | 'end'\n | 'evenly'\n | 'start'\nexport type TGridJustifyResponsive = Partial<Record<TBreakpoint, TGridJustify>>\n\n// Wrap types\nexport type TGridWrap = 'nowrap' | 'wrap' | 'reverse'\nexport type TGridWrapResponsive = Partial<Record<TBreakpoint, TGridWrap>>\n\n// Gap types\nexport type TGapSize = 'xxs' | 'xs' | 'sm' | 'md' | 'lg' | 'xl' | 'xxl'\nexport type TGridGap = TGapSize | Partial<Record<TBreakpoint, TGapSize>>\n\n// Grid columns (1-16)\nexport type TGridColumns =\n | 1\n | 2\n | 3\n | 4\n | 5\n | 6\n | 7\n | 8\n | 9\n | 10\n | 11\n | 12\n | 13\n | 14\n | 15\n | 16\nexport type TGridColumnsResponsive = Partial<Record<TBreakpoint, TGridColumns>>\n\n// Grid shift (0-15)\nexport type TGridShift =\n | 0\n | 1\n | 2\n | 3\n | 4\n | 5\n | 6\n | 7\n | 8\n | 9\n | 10\n | 11\n | 12\n | 13\n | 14\n | 15\nexport type TGridShiftResponsive = Partial<Record<TBreakpoint, TGridShift>>\n\n// Boolean responsive type (for first, last, reverse)\nexport type TBooleanResponsive = boolean | TBreakpoint[]\n\n// Grid mode\nexport type TGridMode = 'wide' | 'narrow' | 'condensed'\n\n// Class collection type\nexport type TClassCollection = Record<string, boolean>\n\n// Handler context for class generation\nexport interface IHandlerContext {\n collection: TClassCollection\n breakpoint?: string\n classMap?: Record<string, string>\n}\n\n// Component props interface\nexport interface IGridProps {\n id?: string | null\n is?: string\n dir?: TGridType | TGridTypeResponsive\n align?: TGridAlign | TGridAlignResponsive | null\n justify?: TGridJustify | TGridJustifyResponsive | null\n gap?: TGridGap | null\n grid?: TGridColumns | TGridColumnsResponsive | null\n shift?: TGridShift | TGridShiftResponsive | null\n wrap?: TGridWrap | TGridWrapResponsive | null\n first?: TBooleanResponsive | null\n last?: TBooleanResponsive | null\n visible?: boolean | Partial<Record<TBreakpoint, boolean>> | null\n reverse?: TBooleanResponsive\n grow?: boolean | null\n flex?: boolean | null\n shrink?: boolean | null\n distributed?: boolean\n mode?: TGridMode\n tabIndex?: string | null\n}\n\n// Prop definitions for defineProps\nexport const gridPropDefinitions = {\n id: {\n type: String as PropType<string>,\n default: null,\n },\n\n is: {\n type: String as PropType<string>,\n default: 'div',\n },\n\n dir: {\n type: [String, Object] as PropType<TGridType | TGridTypeResponsive>,\n default: 'row',\n validator: (value: TGridType | TGridTypeResponsive): boolean => {\n if (typeof value === 'string') {\n return (['row', 'col', 'row-reverse', 'col-reverse'] as const).includes(\n value as TGridType,\n )\n }\n return Object.values(value).every((v) =>\n (['row', 'col', 'row-reverse', 'col-reverse'] as const).includes(\n v as TGridType,\n ),\n )\n },\n },\n\n align: {\n type: [String, Object] as PropType<TGridAlign | TGridAlignResponsive>,\n default: null,\n validator: (value: TGridAlign | TGridAlignResponsive): boolean => {\n if (value == null) return true\n if (typeof value === 'string') {\n return (\n ['start', 'end', 'center', 'baseline', 'stretch'] as const\n ).includes(value as TGridAlign)\n }\n return Object.values(value).every((v) =>\n (['start', 'end', 'center', 'baseline', 'stretch'] as const).includes(\n v as TGridAlign,\n ),\n )\n },\n },\n\n justify: {\n type: [String, Object] as PropType<TGridJustify | TGridJustifyResponsive>,\n default: null,\n validator: (value: TGridJustify | TGridJustifyResponsive): boolean => {\n if (value == null) return true\n if (typeof value === 'string') {\n return (\n ['around', 'between', 'center', 'end', 'evenly', 'start'] as const\n ).includes(value as TGridJustify)\n }\n return Object.values(value).every((v) =>\n (\n ['around', 'between', 'center', 'end', 'evenly', 'start'] as const\n ).includes(v as TGridJustify),\n )\n },\n },\n\n gap: {\n type: [String, Object] as PropType<TGridGap>,\n default: null,\n validator: (value: TGridGap): boolean => {\n if (value == null) return true\n const validSizes = ['xxs', 'xs', 'sm', 'md', 'lg', 'xl', 'xxl'] as const\n if (typeof value === 'string') {\n return validSizes.includes(value as TGapSize)\n }\n return Object.values(value).every((v) =>\n validSizes.includes(v as TGapSize),\n )\n },\n },\n\n grid: {\n type: [Number, String, Object] as PropType<\n TGridColumns | TGridColumnsResponsive\n >,\n default: null,\n validator: (value: TGridColumns | TGridColumnsResponsive): boolean => {\n if (value == null) return true\n const isValidColumn = (v: number | string) => {\n const num = typeof v === 'string' ? parseInt(v, 10) : v\n return num >= 1 && num <= 16 && !isNaN(num)\n }\n\n if (typeof value === 'number' || typeof value === 'string') {\n return isValidColumn(value)\n }\n return Object.values(value).every(isValidColumn)\n },\n },\n\n shift: {\n type: [Number, String, Object] as PropType<\n TGridShift | TGridShiftResponsive\n >,\n default: null,\n validator: (value: TGridShift | TGridShiftResponsive): boolean => {\n if (value == null) return true\n const isValidShift = (v: number | string) => {\n const num = typeof v === 'string' ? parseInt(v, 10) : v\n return num >= 0 && num <= 15 && !isNaN(num)\n }\n\n if (typeof value === 'number' || typeof value === 'string') {\n return isValidShift(value)\n }\n return Object.values(value).every(isValidShift)\n },\n },\n\n wrap: {\n type: [String, Object] as PropType<TGridWrap | TGridWrapResponsive>,\n default: null,\n validator: (value: TGridWrap | TGridWrapResponsive): boolean => {\n if (value == null) return true\n if (typeof value === 'string') {\n return (['nowrap', 'wrap', 'reverse'] as const).includes(\n value as TGridWrap,\n )\n }\n return Object.values(value).every((v) =>\n (['nowrap', 'wrap', 'reverse'] as const).includes(v as TGridWrap),\n )\n },\n },\n\n first: {\n type: [Boolean, Array] as PropType<TBooleanResponsive>,\n default: null,\n validator: (value: TBooleanResponsive): boolean => {\n if (value == null) return true\n if (typeof value === 'boolean') return true\n const validBreakpoints = ['sm', 'md', 'lg', 'xl', 'xxl'] as const\n return value.every((bp) => validBreakpoints.includes(bp as TBreakpoint))\n },\n },\n\n last: {\n type: [Boolean, Array] as PropType<TBooleanResponsive>,\n default: null,\n validator: (value: TBooleanResponsive): boolean => {\n if (value == null) return true\n if (typeof value === 'boolean') return true\n const validBreakpoints = ['sm', 'md', 'lg', 'xl', 'xxl'] as const\n return value.every((bp) => validBreakpoints.includes(bp as TBreakpoint))\n },\n },\n\n visible: {\n type: [Boolean, Object] as PropType<\n boolean | Partial<Record<TBreakpoint, boolean>>\n >,\n default: null,\n },\n\n reverse: {\n type: [Boolean, Array] as PropType<TBooleanResponsive>,\n default: false,\n validator: (value: TBooleanResponsive): boolean => {\n if (value == null) return true\n if (typeof value === 'boolean') return true\n const validBreakpoints = ['sm', 'md', 'lg', 'xl', 'xxl'] as const\n return value.every((bp) => validBreakpoints.includes(bp as TBreakpoint))\n },\n },\n\n grow: {\n type: Boolean as PropType<boolean>,\n default: null,\n },\n\n flex: {\n type: Boolean as PropType<boolean>,\n default: null,\n },\n\n shrink: {\n type: Boolean as PropType<boolean>,\n default: null,\n },\n\n distributed: {\n type: Boolean as PropType<boolean>,\n default: false,\n },\n\n mode: {\n type: String as PropType<TGridMode>,\n default: 'wide',\n validator: (value: string): boolean => {\n return (['wide', 'narrow', 'condensed'] as const).includes(\n value as TGridMode,\n )\n },\n },\n\n tabIndex: {\n type: String as PropType<string>,\n default: null,\n },\n}\n","<template>\n <component\n :is=\"is\"\n :id=\"id\"\n ref=\"root\"\n :class=\"classes\"\n :tabindex=\"(tabIndex ?? !focusableElements.includes(is)) ? '-1' : '0'\"\n >\n <slot />\n </component>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed, ref } from 'vue'\nimport { gridPropDefinitions } from './Grid.d'\nimport type {\n TClassCollection,\n IHandlerContext,\n TGridType,\n TGridAlign,\n TGridJustify,\n TGridWrap,\n TBreakpoint,\n} from './Grid.d'\n\n// Focusable HTML elements\nconst focusableElements = [\n 'a',\n 'button',\n 'input',\n 'textarea',\n 'select',\n 'details',\n 'iframe',\n 'object',\n 'embed',\n 'area',\n 'audio',\n 'video',\n]\n\n// Component ref\nconst root = ref<HTMLElement>()\nconst getRef = () => root.value\n\ndefineExpose({\n getRef,\n})\n\n// Define props\nconst props = defineProps(gridPropDefinitions)\n\n// ============================================================================\n// Utility Functions\n// ============================================================================\n\n/**\n * Normalizes breakpoint names from camelCase to kebab-case\n * Example: 'mediumLarge' -> 'medium-large'\n */\nconst normalizeBreakpoint = (breakpoint: string): string =>\n breakpoint.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase()\n\n// ============================================================================\n// Individual Property Handlers\n// ============================================================================\n\n/**\n * Handles direction prop (row, col, row-reverse, col-reverse)\n */\nfunction handleDirection(value: TGridType, ctx: IHandlerContext): void {\n const { collection, breakpoint } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n\n // Skip base 'row' for responsive breakpoints (row is default)\n if (breakpoint && value === 'row') {\n return\n }\n\n collection[`${prefix}${value}`] = true\n}\n\n/**\n * Handles align prop (start, end, center, baseline, stretch)\n */\nfunction handleAlign(value: TGridAlign, ctx: IHandlerContext): void {\n const { collection, breakpoint, classMap } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n const mappedValue = classMap?.[value] ?? value\n\n collection[`${prefix}align-${mappedValue}`] = true\n}\n\n/**\n * Handles justify prop (around, between, center, end, evenly, start)\n */\nfunction handleJustify(value: TGridJustify, ctx: IHandlerContext): void {\n const { collection, breakpoint, classMap } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n const mappedValue = classMap?.[value] ?? value\n\n collection[`${prefix}justify-${mappedValue}`] = true\n}\n\n/**\n * Handles gap prop (xxs, xs, s, m, l, xl, xxl)\n */\nfunction handleGap(value: string, ctx: IHandlerContext): void {\n const { collection, breakpoint } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n\n collection[`${prefix}gap-${value}`] = true\n}\n\n/**\n * Handles grid prop (1-16 columns)\n */\nfunction handleGrid(value: number | string, ctx: IHandlerContext): void {\n const { collection, breakpoint } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n\n collection[`${prefix}grid-${value}`] = true\n}\n\n/**\n * Handles shift prop (0-15 columns offset)\n */\nfunction handleShift(value: number | string, ctx: IHandlerContext): void {\n const { collection, breakpoint } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n\n collection[`${prefix}shift-${value}`] = true\n}\n\n/**\n * Handles wrap prop (nowrap, wrap, reverse)\n */\nfunction handleWrap(value: TGridWrap, ctx: IHandlerContext): void {\n const { collection, breakpoint } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n\n collection[`${prefix}${value}`] = true\n}\n\n/**\n * Handles reverse prop\n */\nfunction handleReverse(value: boolean, ctx: IHandlerContext): void {\n if (!value) return\n\n const { collection, breakpoint } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n\n collection[`${prefix}reverse`] = true\n}\n\n/**\n * Handles order props (first, last)\n */\nfunction handleOrder(\n value: boolean,\n ctx: IHandlerContext,\n type: 'first' | 'last',\n): void {\n if (!value) return\n\n const { collection, breakpoint } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n\n collection[`${prefix}${type}`] = true\n}\n\n/**\n * Handles visible prop\n */\nfunction handleVisible(value: boolean, ctx: IHandlerContext): void {\n const { collection, breakpoint } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n\n collection[`${prefix}${value ? 'visible' : 'hidden'}`] = true\n}\n\n// ============================================================================\n// Responsive Property Processor\n// ============================================================================\n\n/**\n * Generic processor for responsive props\n * Handles: simple values, arrays (breakpoint lists), and responsive objects\n */\nfunction processResponsiveProp<T>(\n prop: T | Partial<Record<TBreakpoint, T>> | TBreakpoint[] | null | undefined,\n handler: (value: T, ctx: IHandlerContext) => void,\n classMap?: Record<string, string>,\n): TClassCollection {\n const collection: TClassCollection = {}\n\n if (prop == null) return collection\n\n // Simple value (string, number, boolean)\n if (\n typeof prop === 'string' ||\n typeof prop === 'number' ||\n typeof prop === 'boolean'\n ) {\n handler(prop as T, { collection, classMap })\n return collection\n }\n\n // Array of breakpoints (for boolean responsive props like first: ['s', 'm'])\n if (Array.isArray(prop)) {\n prop.forEach((breakpoint) => {\n const normBp = normalizeBreakpoint(breakpoint as string)\n handler(true as T, { collection, breakpoint: normBp, classMap })\n })\n return collection\n }\n\n // Object (responsive prop with breakpoint keys)\n if (typeof prop === 'object') {\n Object.entries(prop).forEach(([breakpoint, value]) => {\n if (value != null) {\n const normBp = normalizeBreakpoint(breakpoint)\n handler(value as T, { collection, breakpoint: normBp, classMap })\n }\n })\n }\n\n return collection\n}\n\n// ============================================================================\n// Main Class Generator\n// ============================================================================\n\n/**\n * Generates all CSS classes based on component props\n * Clean and declarative approach using separate handlers\n */\nconst generateGridClasses = (props: any): TClassCollection => {\n // Class mapping for semantic aliases\n const alignClassMap: Record<string, string> = {\n top: 'start',\n bottom: 'end',\n center: 'center',\n stretch: 'stretch',\n baseline: 'base',\n }\n\n const justifyClassMap: Record<string, string> = {\n left: 'start',\n right: 'end',\n center: 'center',\n between: 'between',\n around: 'around',\n evenly: 'evenly',\n }\n\n return {\n 'nb-grid': true,\n ...processResponsiveProp(props.dir, handleDirection),\n ...processResponsiveProp(props.align, handleAlign, alignClassMap),\n ...processResponsiveProp(props.justify, handleJustify, justifyClassMap),\n ...processResponsiveProp(props.gap, handleGap),\n ...processResponsiveProp(props.grid, handleGrid),\n ...processResponsiveProp(props.shift, handleShift),\n ...processResponsiveProp(props.wrap, handleWrap),\n ...processResponsiveProp(props.reverse, handleReverse),\n ...processResponsiveProp(props.first, (val, ctx) =>\n handleOrder(val, ctx, 'first'),\n ),\n ...processResponsiveProp(props.last, (val, ctx) =>\n handleOrder(val, ctx, 'last'),\n ),\n ...processResponsiveProp(props.visible, handleVisible),\n ...(props.flex ? { flex: true } : {}),\n ...(props.distributed ? { distributed: true } : {}),\n ...(props.mode ? { [props.mode]: true } : {}),\n ...(props.grow ? { grow: true } : {}),\n ...(props.shrink !== null && props.shrink !== undefined\n ? { [`shrink-${props.shrink ? '1' : '0'}`]: true }\n : {}),\n }\n}\n\n// Computed property for reactive class generation\nconst classes = computed(() => generateGridClasses(props))\n</script>\n","<template>\n <component\n :is=\"is\"\n :id=\"id\"\n ref=\"root\"\n :class=\"classes\"\n :tabindex=\"(tabIndex ?? !focusableElements.includes(is)) ? '-1' : '0'\"\n >\n <slot />\n </component>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed, ref } from 'vue'\nimport { gridPropDefinitions } from './Grid.d'\nimport type {\n TClassCollection,\n IHandlerContext,\n TGridType,\n TGridAlign,\n TGridJustify,\n TGridWrap,\n TBreakpoint,\n} from './Grid.d'\n\n// Focusable HTML elements\nconst focusableElements = [\n 'a',\n 'button',\n 'input',\n 'textarea',\n 'select',\n 'details',\n 'iframe',\n 'object',\n 'embed',\n 'area',\n 'audio',\n 'video',\n]\n\n// Component ref\nconst root = ref<HTMLElement>()\nconst getRef = () => root.value\n\ndefineExpose({\n getRef,\n})\n\n// Define props\nconst props = defineProps(gridPropDefinitions)\n\n// ============================================================================\n// Utility Functions\n// ============================================================================\n\n/**\n * Normalizes breakpoint names from camelCase to kebab-case\n * Example: 'mediumLarge' -> 'medium-large'\n */\nconst normalizeBreakpoint = (breakpoint: string): string =>\n breakpoint.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase()\n\n// ============================================================================\n// Individual Property Handlers\n// ============================================================================\n\n/**\n * Handles direction prop (row, col, row-reverse, col-reverse)\n */\nfunction handleDirection(value: TGridType, ctx: IHandlerContext): void {\n const { collection, breakpoint } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n\n // Skip base 'row' for responsive breakpoints (row is default)\n if (breakpoint && value === 'row') {\n return\n }\n\n collection[`${prefix}${value}`] = true\n}\n\n/**\n * Handles align prop (start, end, center, baseline, stretch)\n */\nfunction handleAlign(value: TGridAlign, ctx: IHandlerContext): void {\n const { collection, breakpoint, classMap } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n const mappedValue = classMap?.[value] ?? value\n\n collection[`${prefix}align-${mappedValue}`] = true\n}\n\n/**\n * Handles justify prop (around, between, center, end, evenly, start)\n */\nfunction handleJustify(value: TGridJustify, ctx: IHandlerContext): void {\n const { collection, breakpoint, classMap } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n const mappedValue = classMap?.[value] ?? value\n\n collection[`${prefix}justify-${mappedValue}`] = true\n}\n\n/**\n * Handles gap prop (xxs, xs, s, m, l, xl, xxl)\n */\nfunction handleGap(value: string, ctx: IHandlerContext): void {\n const { collection, breakpoint } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n\n collection[`${prefix}gap-${value}`] = true\n}\n\n/**\n * Handles grid prop (1-16 columns)\n */\nfunction handleGrid(value: number | string, ctx: IHandlerContext): void {\n const { collection, breakpoint } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n\n collection[`${prefix}grid-${value}`] = true\n}\n\n/**\n * Handles shift prop (0-15 columns offset)\n */\nfunction handleShift(value: number | string, ctx: IHandlerContext): void {\n const { collection, breakpoint } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n\n collection[`${prefix}shift-${value}`] = true\n}\n\n/**\n * Handles wrap prop (nowrap, wrap, reverse)\n */\nfunction handleWrap(value: TGridWrap, ctx: IHandlerContext): void {\n const { collection, breakpoint } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n\n collection[`${prefix}${value}`] = true\n}\n\n/**\n * Handles reverse prop\n */\nfunction handleReverse(value: boolean, ctx: IHandlerContext): void {\n if (!value) return\n\n const { collection, breakpoint } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n\n collection[`${prefix}reverse`] = true\n}\n\n/**\n * Handles order props (first, last)\n */\nfunction handleOrder(\n value: boolean,\n ctx: IHandlerContext,\n type: 'first' | 'last',\n): void {\n if (!value) return\n\n const { collection, breakpoint } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n\n collection[`${prefix}${type}`] = true\n}\n\n/**\n * Handles visible prop\n */\nfunction handleVisible(value: boolean, ctx: IHandlerContext): void {\n const { collection, breakpoint } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n\n collection[`${prefix}${value ? 'visible' : 'hidden'}`] = true\n}\n\n// ============================================================================\n// Responsive Property Processor\n// ============================================================================\n\n/**\n * Generic processor for responsive props\n * Handles: simple values, arrays (breakpoint lists), and responsive objects\n */\nfunction processResponsiveProp<T>(\n prop: T | Partial<Record<TBreakpoint, T>> | TBreakpoint[] | null | undefined,\n handler: (value: T, ctx: IHandlerContext) => void,\n classMap?: Record<string, string>,\n): TClassCollection {\n const collection: TClassCollection = {}\n\n if (prop == null) return collection\n\n // Simple value (string, number, boolean)\n if (\n typeof prop === 'string' ||\n typeof prop === 'number' ||\n typeof prop === 'boolean'\n ) {\n handler(prop as T, { collection, classMap })\n return collection\n }\n\n // Array of breakpoints (for boolean responsive props like first: ['s', 'm'])\n if (Array.isArray(prop)) {\n prop.forEach((breakpoint) => {\n const normBp = normalizeBreakpoint(breakpoint as string)\n handler(true as T, { collection, breakpoint: normBp, classMap })\n })\n return collection\n }\n\n // Object (responsive prop with breakpoint keys)\n if (typeof prop === 'object') {\n Object.entries(prop).forEach(([breakpoint, value]) => {\n if (value != null) {\n const normBp = normalizeBreakpoint(breakpoint)\n handler(value as T, { collection, breakpoint: normBp, classMap })\n }\n })\n }\n\n return collection\n}\n\n// ============================================================================\n// Main Class Generator\n// ============================================================================\n\n/**\n * Generates all CSS classes based on component props\n * Clean and declarative approach using separate handlers\n */\nconst generateGridClasses = (props: any): TClassCollection => {\n // Class mapping for semantic aliases\n const alignClassMap: Record<string, string> = {\n top: 'start',\n bottom: 'end',\n center: 'center',\n stretch: 'stretch',\n baseline: 'base',\n }\n\n const justifyClassMap: Record<string, string> = {\n left: 'start',\n right: 'end',\n center: 'center',\n between: 'between',\n around: 'around',\n evenly: 'evenly',\n }\n\n return {\n 'nb-grid': true,\n ...processResponsiveProp(props.dir, handleDirection),\n ...processResponsiveProp(props.align, handleAlign, alignClassMap),\n ...processResponsiveProp(props.justify, handleJustify, justifyClassMap),\n ...processResponsiveProp(props.gap, handleGap),\n ...processResponsiveProp(props.grid, handleGrid),\n ...processResponsiveProp(props.shift, handleShift),\n ...processResponsiveProp(props.wrap, handleWrap),\n ...processResponsiveProp(props.reverse, handleReverse),\n ...processResponsiveProp(props.first, (val, ctx) =>\n handleOrder(val, ctx, 'first'),\n ),\n ...processResponsiveProp(props.last, (val, ctx) =>\n handleOrder(val, ctx, 'last'),\n ),\n ...processResponsiveProp(props.visible, handleVisible),\n ...(props.flex ? { flex: true } : {}),\n ...(props.distributed ? { distributed: true } : {}),\n ...(props.mode ? { [props.mode]: true } : {}),\n ...(props.grow ? { grow: true } : {}),\n ...(props.shrink !== null && props.shrink !== undefined\n ? { [`shrink-${props.shrink ? '1' : '0'}`]: true }\n : {}),\n }\n}\n\n// Computed property for reactive class generation\nconst classes = computed(() => generateGridClasses(props))\n</script>\n","/*!\n * shared v11.3.0\n * (c) 2026 kazuya kawaguchi\n * Released under the MIT License.\n */\nfunction warn(msg, err) {\n if (typeof console !== 'undefined') {\n console.warn(`[intlify] ` + msg);\n /* istanbul ignore if */\n if (err) {\n console.warn(err.stack);\n }\n }\n}\nconst hasWarned = {};\nfunction warnOnce(msg) {\n if (!hasWarned[msg]) {\n hasWarned[msg] = true;\n warn(msg);\n }\n}\n\n/**\n * Original Utilities\n * written by kazuya kawaguchi\n */\nconst inBrowser = typeof window !== 'undefined';\nlet mark;\nlet measure;\nif ((process.env.NODE_ENV !== 'production')) {\n const perf = inBrowser && window.performance;\n if (perf &&\n perf.mark &&\n perf.measure &&\n perf.clearMarks &&\n // @ts-ignore browser compat\n perf.clearMeasures) {\n mark = (tag) => {\n perf.mark(tag);\n };\n measure = (name, startTag, endTag) => {\n perf.measure(name, startTag, endTag);\n perf.clearMarks(startTag);\n perf.clearMarks(endTag);\n };\n }\n}\nconst RE_ARGS = /\\{([0-9a-zA-Z]+)\\}/g;\n/* eslint-disable */\nfunction format(message, ...args) {\n if (args.length === 1 && isObject(args[0])) {\n args = args[0];\n }\n if (!args || !args.hasOwnProperty) {\n args = {};\n }\n return message.replace(RE_ARGS, (match, identifier) => {\n return args.hasOwnProperty(identifier) ? args[identifier] : '';\n });\n}\nconst makeSymbol = (name, shareable = false) => !shareable ? Symbol(name) : Symbol.for(name);\nconst generateFormatCacheKey = (locale, key, source) => friendlyJSONstringify({ l: locale, k: key, s: source });\nconst friendlyJSONstringify = (json) => JSON.stringify(json)\n .replace(/\\u2028/g, '\\\\u2028')\n .replace(/\\u2029/g, '\\\\u2029')\n .replace(/\\u0027/g, '\\\\u0027');\nconst isNumber = (val) => typeof val === 'number' && isFinite(val);\nconst isDate = (val) => toTypeString(val) === '[object Date]';\nconst isRegExp = (val) => toTypeString(val) === '[object RegExp]';\nconst isEmptyObject = (val) => isPlainObject(val) && Object.keys(val).length === 0;\nconst assign = Object.assign;\nconst _create = Object.create;\nconst create = (obj = null) => _create(obj);\nlet _globalThis;\nconst getGlobalThis = () => {\n // prettier-ignore\n return (_globalThis ||\n (_globalThis =\n typeof globalThis !== 'undefined'\n ? globalThis\n : typeof self !== 'undefined'\n ? self\n : typeof window !== 'undefined'\n ? window\n : typeof global !== 'undefined'\n ? global\n : create()));\n};\nfunction escapeHtml(rawText) {\n return rawText\n .replace(/&/g, '&amp;') // escape `&` first to avoid double escaping\n .replace(/</g, '&lt;')\n .replace(/>/g, '&gt;')\n .replace(/\"/g, '&quot;')\n .replace(/'/g, '&apos;')\n .replace(/\\//g, '&#x2F;') // escape `/` to prevent closing tags or JavaScript URLs\n .replace(/=/g, '&#x3D;'); // escape `=` to prevent attribute injection\n}\nfunction escapeAttributeValue(value) {\n return value\n .replace(/&(?![a-zA-Z0-9#]{2,6};)/g, '&amp;') // escape unescaped `&`\n .replace(/\"/g, '&quot;')\n .replace(/'/g, '&apos;')\n .replace(/</g, '&lt;')\n .replace(/>/g, '&gt;');\n}\nfunction sanitizeTranslatedHtml(html) {\n // Escape dangerous characters in attribute values\n // Process attributes with double quotes\n html = html.replace(/(\\w+)\\s*=\\s*\"([^\"]*)\"/g, (_, attrName, attrValue) => `${attrName}=\"${escapeAttributeValue(attrValue)}\"`);\n // Process attributes with single quotes\n html = html.replace(/(\\w+)\\s*=\\s*'([^']*)'/g, (_, attrName, attrValue) => `${attrName}='${escapeAttributeValue(attrValue)}'`);\n // Detect and neutralize event handler attributes\n const eventHandlerPattern = /\\s*on\\w+\\s*=\\s*[\"']?[^\"'>]+[\"']?/gi;\n if (eventHandlerPattern.test(html)) {\n if ((process.env.NODE_ENV !== 'production')) {\n warn('Potentially dangerous event handlers detected in translation. ' +\n 'Consider removing onclick, onerror, etc. from your translation messages.');\n }\n // Neutralize event handler attributes by escaping 'on'\n html = html.replace(/(\\s+)(on)(\\w+\\s*=)/gi, '$1&#111;n$3');\n }\n // Disable javascript: URLs in various contexts\n const javascriptUrlPattern = [\n // In href, src, action, formaction attributes\n /(\\s+(?:href|src|action|formaction)\\s*=\\s*[\"']?)\\s*javascript:/gi,\n // In style attributes within url()\n /(style\\s*=\\s*[\"'][^\"']*url\\s*\\(\\s*)javascript:/gi\n ];\n javascriptUrlPattern.forEach(pattern => {\n html = html.replace(pattern, '$1javascript&#58;');\n });\n return html;\n}\nconst hasOwnProperty = Object.prototype.hasOwnProperty;\nfunction hasOwn(obj, key) {\n return hasOwnProperty.call(obj, key);\n}\n/* eslint-enable */\n/**\n * Useful Utilities By Evan you\n * Modified by kazuya kawaguchi\n * MIT License\n * https://github.com/vuejs/vue-next/blob/master/packages/shared/src/index.ts\n * https://github.com/vuejs/vue-next/blob/master/packages/shared/src/codeframe.ts\n */\nconst isArray = Array.isArray;\nconst isFunction = (val) => typeof val === 'function';\nconst isString = (val) => typeof val === 'string';\nconst isBoolean = (val) => typeof val === 'boolean';\nconst isSymbol = (val) => typeof val === 'symbol';\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst isObject = (val) => val !== null && typeof val === 'object';\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst isPromise = (val) => {\n return isObject(val) && isFunction(val.then) && isFunction(val.catch);\n};\nconst objectToString = Object.prototype.toString;\nconst toTypeString = (value) => objectToString.call(value);\nconst isPlainObject = (val) => toTypeString(val) === '[object Object]';\n// for converting list and named values to displayed strings.\nconst toDisplayString = (val) => {\n return val == null\n ? ''\n : isArray(val) || (isPlainObject(val) && val.toString === objectToString)\n ? JSON.stringify(val, null, 2)\n : String(val);\n};\nfunction join(items, separator = '') {\n return items.reduce((str, item, index) => (index === 0 ? str + item : str + separator + item), '');\n}\nconst RANGE = 2;\nfunction generateCodeFrame(source, start = 0, end = source.length) {\n const lines = source.split(/\\r?\\n/);\n let count = 0;\n const res = [];\n for (let i = 0; i < lines.length; i++) {\n count += lines[i].length + 1;\n if (count >= start) {\n for (let j = i - RANGE; j <= i + RANGE || end > count; j++) {\n if (j < 0 || j >= lines.length)\n continue;\n const line = j + 1;\n res.push(`${line}${' '.repeat(3 - String(line).length)}| ${lines[j]}`);\n const lineLength = lines[j].length;\n if (j === i) {\n // push underline\n const pad = start - (count - lineLength) + 1;\n const length = Math.max(1, end > count ? lineLength - pad : end - start);\n res.push(` | ` + ' '.repeat(pad) + '^'.repeat(length));\n }\n else if (j > i) {\n if (end > count) {\n const length = Math.max(Math.min(end - count, lineLength), 1);\n res.push(` | ` + '^'.repeat(length));\n }\n count += lineLength + 1;\n }\n }\n break;\n }\n }\n return res.join('\\n');\n}\n\n/**\n * Event emitter, forked from the below:\n * - original repository url: https://github.com/developit/mitt\n * - code url: https://github.com/developit/mitt/blob/master/src/index.ts\n * - author: Jason Miller (https://github.com/developit)\n * - license: MIT\n */\n/**\n * Create a event emitter\n *\n * @returns An event emitter\n */\nfunction createEmitter() {\n const events = new Map();\n const emitter = {\n events,\n on(event, handler) {\n const handlers = events.get(event);\n const added = handlers && handlers.push(handler);\n if (!added) {\n events.set(event, [handler]);\n }\n },\n off(event, handler) {\n const handlers = events.get(event);\n if (handlers) {\n handlers.splice(handlers.indexOf(handler) >>> 0, 1);\n }\n },\n emit(event, payload) {\n (events.get(event) || [])\n .slice()\n .map(handler => handler(payload));\n (events.get('*') || [])\n .slice()\n .map(handler => handler(event, payload));\n }\n };\n return emitter;\n}\n\nconst isNotObjectOrIsArray = (val) => !isObject(val) || isArray(val);\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction deepCopy(src, des) {\n // src and des should both be objects, and none of them can be a array\n if (isNotObjectOrIsArray(src) || isNotObjectOrIsArray(des)) {\n throw new Error('Invalid value');\n }\n const stack = [{ src, des }];\n while (stack.length) {\n const { src, des } = stack.pop();\n // using `Object.keys` which skips prototype properties\n Object.keys(src).forEach(key => {\n if (key === '__proto__') {\n return;\n }\n // if src[key] is an object/array, set des[key]\n // to empty object/array to prevent setting by reference\n if (isObject(src[key]) && !isObject(des[key])) {\n des[key] = Array.isArray(src[key]) ? [] : create();\n }\n if (isNotObjectOrIsArray(des[key]) || isNotObjectOrIsArray(src[key])) {\n // replace with src[key] when:\n // src[key] or des[key] is not an object, or\n // src[key] or des[key] is an array\n des[key] = src[key];\n }\n else {\n // src[key] and des[key] are both objects, merge them\n stack.push({ src: src[key], des: des[key] });\n }\n });\n }\n}\n\nexport { assign, create, createEmitter, deepCopy, escapeHtml, format, friendlyJSONstringify, generateCodeFrame, generateFormatCacheKey, getGlobalThis, hasOwn, inBrowser, isArray, isBoolean, isDate, isEmptyObject, isFunction, isNumber, isObject, isPlainObject, isPromise, isRegExp, isString, isSymbol, join, makeSymbol, mark, measure, objectToString, sanitizeTranslatedHtml, toDisplayString, toTypeString, warn, warnOnce };\n","/*!\n * message-compiler v11.3.0\n * (c) 2026 kazuya kawaguchi\n * Released under the MIT License.\n */\nimport { format, assign, join, isString } from '@intlify/shared';\n\nconst LOCATION_STUB = {\n start: { line: 1, column: 1, offset: 0 },\n end: { line: 1, column: 1, offset: 0 }\n};\nfunction createPosition(line, column, offset) {\n return { line, column, offset };\n}\nfunction createLocation(start, end, source) {\n const loc = { start, end };\n if (source != null) {\n loc.source = source;\n }\n return loc;\n}\n\nconst CompileErrorCodes = {\n // tokenizer error codes\n EXPECTED_TOKEN: 1,\n INVALID_TOKEN_IN_PLACEHOLDER: 2,\n UNTERMINATED_SINGLE_QUOTE_IN_PLACEHOLDER: 3,\n UNKNOWN_ESCAPE_SEQUENCE: 4,\n INVALID_UNICODE_ESCAPE_SEQUENCE: 5,\n UNBALANCED_CLOSING_BRACE: 6,\n UNTERMINATED_CLOSING_BRACE: 7,\n EMPTY_PLACEHOLDER: 8,\n NOT_ALLOW_NEST_PLACEHOLDER: 9,\n INVALID_LINKED_FORMAT: 10,\n // parser error codes\n MUST_HAVE_MESSAGES_IN_PLURAL: 11,\n UNEXPECTED_EMPTY_LINKED_MODIFIER: 12,\n UNEXPECTED_EMPTY_LINKED_KEY: 13,\n UNEXPECTED_LEXICAL_ANALYSIS: 14,\n // generator error codes\n UNHANDLED_CODEGEN_NODE_TYPE: 15,\n // minifier error codes\n UNHANDLED_MINIFIER_NODE_TYPE: 16\n};\n// Special value for higher-order compilers to pick up the last code\n// to avoid collision of error codes.\n// This should always be kept as the last item.\nconst COMPILE_ERROR_CODES_EXTEND_POINT = 17;\n/** @internal */\nconst errorMessages = {\n // tokenizer error messages\n [CompileErrorCodes.EXPECTED_TOKEN]: `Expected token: '{0}'`,\n [CompileErrorCodes.INVALID_TOKEN_IN_PLACEHOLDER]: `Invalid token in placeholder: '{0}'`,\n [CompileErrorCodes.UNTERMINATED_SINGLE_QUOTE_IN_PLACEHOLDER]: `Unterminated single quote in placeholder`,\n [CompileErrorCodes.UNKNOWN_ESCAPE_SEQUENCE]: `Unknown escape sequence: \\\\{0}`,\n [CompileErrorCodes.INVALID_UNICODE_ESCAPE_SEQUENCE]: `Invalid unicode escape sequence: {0}`,\n [CompileErrorCodes.UNBALANCED_CLOSING_BRACE]: `Unbalanced closing brace`,\n [CompileErrorCodes.UNTERMINATED_CLOSING_BRACE]: `Unterminated closing brace`,\n [CompileErrorCodes.EMPTY_PLACEHOLDER]: `Empty placeholder`,\n [CompileErrorCodes.NOT_ALLOW_NEST_PLACEHOLDER]: `Not allowed nest placeholder`,\n [CompileErrorCodes.INVALID_LINKED_FORMAT]: `Invalid linked format`,\n // parser error messages\n [CompileErrorCodes.MUST_HAVE_MESSAGES_IN_PLURAL]: `Plural must have messages`,\n [CompileErrorCodes.UNEXPECTED_EMPTY_LINKED_MODIFIER]: `Unexpected empty linked modifier`,\n [CompileErrorCodes.UNEXPECTED_EMPTY_LINKED_KEY]: `Unexpected empty linked key`,\n [CompileErrorCodes.UNEXPECTED_LEXICAL_ANALYSIS]: `Unexpected lexical analysis in token: '{0}'`,\n // generator error messages\n [CompileErrorCodes.UNHANDLED_CODEGEN_NODE_TYPE]: `unhandled codegen node type: '{0}'`,\n // minimizer error messages\n [CompileErrorCodes.UNHANDLED_MINIFIER_NODE_TYPE]: `unhandled mimifier node type: '{0}'`\n};\nfunction createCompileError(code, loc, options = {}) {\n const { domain, messages, args } = options;\n const msg = (process.env.NODE_ENV !== 'production')\n ? format((messages || errorMessages)[code] || '', ...(args || []))\n : code;\n const error = new SyntaxError(String(msg));\n error.code = code;\n if (loc) {\n error.location = loc;\n }\n error.domain = domain;\n return error;\n}\n/** @internal */\nfunction defaultOnError(error) {\n throw error;\n}\n\n// eslint-disable-next-line no-useless-escape\nconst RE_HTML_TAG = /<\\/?[\\w\\s=\"/.':;#-\\/]+>/;\nconst detectHtmlTag = (source) => RE_HTML_TAG.test(source);\n\nconst CHAR_SP = ' ';\nconst CHAR_CR = '\\r';\nconst CHAR_LF = '\\n';\nconst CHAR_LS = String.fromCharCode(0x2028);\nconst CHAR_PS = String.fromCharCode(0x2029);\nfunction createScanner(str) {\n const _buf = str;\n let _index = 0;\n let _line = 1;\n let _column = 1;\n let _peekOffset = 0;\n const isCRLF = (index) => _buf[index] === CHAR_CR && _buf[index + 1] === CHAR_LF;\n const isLF = (index) => _buf[index] === CHAR_LF;\n const isPS = (index) => _buf[index] === CHAR_PS;\n const isLS = (index) => _buf[index] === CHAR_LS;\n const isLineEnd = (index) => isCRLF(index) || isLF(index) || isPS(index) || isLS(index);\n const index = () => _index;\n const line = () => _line;\n const column = () => _column;\n const peekOffset = () => _peekOffset;\n const charAt = (offset) => isCRLF(offset) || isPS(offset) || isLS(offset) ? CHAR_LF : _buf[offset];\n const currentChar = () => charAt(_index);\n const currentPeek = () => charAt(_index + _peekOffset);\n function next() {\n _peekOffset = 0;\n if (isLineEnd(_index)) {\n _line++;\n _column = 0;\n }\n if (isCRLF(_index)) {\n _index++;\n }\n _index++;\n _column++;\n return _buf[_index];\n }\n function peek() {\n if (isCRLF(_index + _peekOffset)) {\n _peekOffset++;\n }\n _peekOffset++;\n return _buf[_index + _peekOffset];\n }\n function reset() {\n _index = 0;\n _line = 1;\n _column = 1;\n _peekOffset = 0;\n }\n function resetPeek(offset = 0) {\n _peekOffset = offset;\n }\n function skipToPeek() {\n const target = _index + _peekOffset;\n while (target !== _index) {\n next();\n }\n _peekOffset = 0;\n }\n return {\n index,\n line,\n column,\n peekOffset,\n charAt,\n currentChar,\n currentPeek,\n next,\n peek,\n reset,\n resetPeek,\n skipToPeek\n };\n}\n\nconst EOF = undefined;\nconst DOT = '.';\nconst LITERAL_DELIMITER = \"'\";\nconst ERROR_DOMAIN$3 = 'tokenizer';\nfunction createTokenizer(source, options = {}) {\n const location = options.location !== false;\n const _scnr = createScanner(source);\n const currentOffset = () => _scnr.index();\n const currentPosition = () => createPosition(_scnr.line(), _scnr.column(), _scnr.index());\n const _initLoc = currentPosition();\n const _initOffset = currentOffset();\n const _context = {\n currentType: 13 /* TokenTypes.EOF */,\n offset: _initOffset,\n startLoc: _initLoc,\n endLoc: _initLoc,\n lastType: 13 /* TokenTypes.EOF */,\n lastOffset: _initOffset,\n lastStartLoc: _initLoc,\n lastEndLoc: _initLoc,\n braceNest: 0,\n inLinked: false,\n text: ''\n };\n const context = () => _context;\n const { onError } = options;\n function emitError(code, pos, offset, ...args) {\n const ctx = context();\n pos.column += offset;\n pos.offset += offset;\n if (onError) {\n const loc = location ? createLocation(ctx.startLoc, pos) : null;\n const err = createCompileError(code, loc, {\n domain: ERROR_DOMAIN$3,\n args\n });\n onError(err);\n }\n }\n function getToken(context, type, value) {\n context.endLoc = currentPosition();\n context.currentType = type;\n const token = { type };\n if (location) {\n token.loc = createLocation(context.startLoc, context.endLoc);\n }\n if (value != null) {\n token.value = value;\n }\n return token;\n }\n const getEndToken = (context) => getToken(context, 13 /* TokenTypes.EOF */);\n function eat(scnr, ch) {\n if (scnr.currentChar() === ch) {\n scnr.next();\n return ch;\n }\n else {\n emitError(CompileErrorCodes.EXPECTED_TOKEN, currentPosition(), 0, ch);\n return '';\n }\n }\n function peekSpaces(scnr) {\n let buf = '';\n while (scnr.currentPeek() === CHAR_SP || scnr.currentPeek() === CHAR_LF) {\n buf += scnr.currentPeek();\n scnr.peek();\n }\n return buf;\n }\n function skipSpaces(scnr) {\n const buf = peekSpaces(scnr);\n scnr.skipToPeek();\n return buf;\n }\n function isIdentifierStart(ch) {\n if (ch === EOF) {\n return false;\n }\n const cc = ch.charCodeAt(0);\n return ((cc >= 97 && cc <= 122) || // a-z\n (cc >= 65 && cc <= 90) || // A-Z\n cc === 95 // _\n );\n }\n function isNumberStart(ch) {\n if (ch === EOF) {\n return false;\n }\n const cc = ch.charCodeAt(0);\n return cc >= 48 && cc <= 57; // 0-9\n }\n function isNamedIdentifierStart(scnr, context) {\n const { currentType } = context;\n if (currentType !== 2 /* TokenTypes.BraceLeft */) {\n return false;\n }\n peekSpaces(scnr);\n const ret = isIdentifierStart(scnr.currentPeek());\n scnr.resetPeek();\n return ret;\n }\n function isListIdentifierStart(scnr, context) {\n const { currentType } = context;\n if (currentType !== 2 /* TokenTypes.BraceLeft */) {\n return false;\n }\n peekSpaces(scnr);\n const ch = scnr.currentPeek() === '-' ? scnr.peek() : scnr.currentPeek();\n const ret = isNumberStart(ch);\n scnr.resetPeek();\n return ret;\n }\n function isLiteralStart(scnr, context) {\n const { currentType } = context;\n if (currentType !== 2 /* TokenTypes.BraceLeft */) {\n return false;\n }\n peekSpaces(scnr);\n const ret = scnr.currentPeek() === LITERAL_DELIMITER;\n scnr.resetPeek();\n return ret;\n }\n function isLinkedDotStart(scnr, context) {\n const { currentType } = context;\n if (currentType !== 7 /* TokenTypes.LinkedAlias */) {\n return false;\n }\n peekSpaces(scnr);\n const ret = scnr.currentPeek() === \".\" /* TokenChars.LinkedDot */;\n scnr.resetPeek();\n return ret;\n }\n function isLinkedModifierStart(scnr, context) {\n const { currentType } = context;\n if (currentType !== 8 /* TokenTypes.LinkedDot */) {\n return false;\n }\n peekSpaces(scnr);\n const ret = isIdentifierStart(scnr.currentPeek());\n scnr.resetPeek();\n return ret;\n }\n function isLinkedDelimiterStart(scnr, context) {\n const { currentType } = context;\n if (!(currentType === 7 /* TokenTypes.LinkedAlias */ ||\n currentType === 11 /* TokenTypes.LinkedModifier */)) {\n return false;\n }\n peekSpaces(scnr);\n const ret = scnr.currentPeek() === \":\" /* TokenChars.LinkedDelimiter */;\n scnr.resetPeek();\n return ret;\n }\n function isLinkedReferStart(scnr, context) {\n const { currentType } = context;\n if (currentType !== 9 /* TokenTypes.LinkedDelimiter */) {\n return false;\n }\n const fn = () => {\n const ch = scnr.currentPeek();\n if (ch === \"{\" /* TokenChars.BraceLeft */) {\n return isIdentifierStart(scnr.peek());\n }\n else if (ch === \"@\" /* TokenChars.LinkedAlias */ ||\n ch === \"|\" /* TokenChars.Pipe */ ||\n ch === \":\" /* TokenChars.LinkedDelimiter */ ||\n ch === \".\" /* TokenChars.LinkedDot */ ||\n ch === CHAR_SP ||\n !ch) {\n return false;\n }\n else if (ch === CHAR_LF) {\n scnr.peek();\n return fn();\n }\n else {\n // other characters\n return isTextStart(scnr, false);\n }\n };\n const ret = fn();\n scnr.resetPeek();\n return ret;\n }\n function isPluralStart(scnr) {\n peekSpaces(scnr);\n const ret = scnr.currentPeek() === \"|\" /* TokenChars.Pipe */;\n scnr.resetPeek();\n return ret;\n }\n function isTextStart(scnr, reset = true) {\n const fn = (hasSpace = false, prev = '') => {\n const ch = scnr.currentPeek();\n if (ch === \"{\" /* TokenChars.BraceLeft */) {\n return hasSpace;\n }\n else if (ch === \"@\" /* TokenChars.LinkedAlias */ || !ch) {\n return hasSpace;\n }\n else if (ch === \"|\" /* TokenChars.Pipe */) {\n return !(prev === CHAR_SP || prev === CHAR_LF);\n }\n else if (ch === CHAR_SP) {\n scnr.peek();\n return fn(true, CHAR_SP);\n }\n else if (ch === CHAR_LF) {\n scnr.peek();\n return fn(true, CHAR_LF);\n }\n else {\n return true;\n }\n };\n const ret = fn();\n reset && scnr.resetPeek();\n return ret;\n }\n function takeChar(scnr, fn) {\n const ch = scnr.currentChar();\n if (ch === EOF) {\n return EOF;\n }\n if (fn(ch)) {\n scnr.next();\n return ch;\n }\n return null;\n }\n function isIdentifier(ch) {\n const cc = ch.charCodeAt(0);\n return ((cc >= 97 && cc <= 122) || // a-z\n (cc >= 65 && cc <= 90) || // A-Z\n (cc >= 48 && cc <= 57) || // 0-9\n cc === 95 || // _\n cc === 36 // $\n );\n }\n function takeIdentifierChar(scnr) {\n return takeChar(scnr, isIdentifier);\n }\n function isNamedIdentifier(ch) {\n const cc = ch.charCodeAt(0);\n return ((cc >= 97 && cc <= 122) || // a-z\n (cc >= 65 && cc <= 90) || // A-Z\n (cc >= 48 && cc <= 57) || // 0-9\n cc === 95 || // _\n cc === 36 || // $\n cc === 45 // -\n );\n }\n function takeNamedIdentifierChar(scnr) {\n return takeChar(scnr, isNamedIdentifier);\n }\n function isDigit(ch) {\n const cc = ch.charCodeAt(0);\n return cc >= 48 && cc <= 57; // 0-9\n }\n function takeDigit(scnr) {\n return takeChar(scnr, isDigit);\n }\n function isHexDigit(ch) {\n const cc = ch.charCodeAt(0);\n return ((cc >= 48 && cc <= 57) || // 0-9\n (cc >= 65 && cc <= 70) || // A-F\n (cc >= 97 && cc <= 102)); // a-f\n }\n function takeHexDigit(scnr) {\n return takeChar(scnr, isHexDigit);\n }\n function getDigits(scnr) {\n let ch = '';\n let num = '';\n while ((ch = takeDigit(scnr))) {\n num += ch;\n }\n return num;\n }\n function readText(scnr) {\n let buf = '';\n while (true) {\n const ch = scnr.currentChar();\n if (ch === '\\\\') {\n const nextCh = scnr.peek();\n if (nextCh === \"{\" /* TokenChars.BraceLeft */ ||\n nextCh === \"}\" /* TokenChars.BraceRight */ ||\n nextCh === \"@\" /* TokenChars.LinkedAlias */ ||\n nextCh === \"|\" /* TokenChars.Pipe */ ||\n nextCh === '\\\\') {\n buf += ch + nextCh;\n scnr.next();\n scnr.next();\n }\n else {\n scnr.resetPeek();\n buf += ch;\n scnr.next();\n }\n }\n else if (ch === \"{\" /* TokenChars.BraceLeft */ ||\n ch === \"}\" /* TokenChars.BraceRight */ ||\n ch === \"@\" /* TokenChars.LinkedAlias */ ||\n ch === \"|\" /* TokenChars.Pipe */ ||\n !ch) {\n break;\n }\n else if (ch === CHAR_SP || ch === CHAR_LF) {\n if (isTextStart(scnr)) {\n buf += ch;\n scnr.next();\n }\n else if (isPluralStart(scnr)) {\n break;\n }\n else {\n buf += ch;\n scnr.next();\n }\n }\n else {\n buf += ch;\n scnr.next();\n }\n }\n return buf;\n }\n function readNamedIdentifier(scnr) {\n skipSpaces(scnr);\n let ch = '';\n let name = '';\n while ((ch = takeNamedIdentifierChar(scnr))) {\n name += ch;\n }\n // Check if takeNamedIdentifierChar stoped because of invalid characters\n const currentChar = scnr.currentChar();\n if (currentChar &&\n currentChar !== '}' &&\n currentChar !== EOF &&\n currentChar !== CHAR_SP &&\n currentChar !== CHAR_LF &&\n currentChar !== '\\u3000') {\n const invalidPart = readInvalidIdentifier(scnr);\n emitError(CompileErrorCodes.INVALID_TOKEN_IN_PLACEHOLDER, currentPosition(), 0, name + invalidPart);\n return name + invalidPart;\n }\n if (scnr.currentChar() === EOF) {\n emitError(CompileErrorCodes.UNTERMINATED_CLOSING_BRACE, currentPosition(), 0);\n }\n return name;\n }\n function readListIdentifier(scnr) {\n skipSpaces(scnr);\n let value = '';\n if (scnr.currentChar() === '-') {\n scnr.next();\n value += `-${getDigits(scnr)}`;\n }\n else {\n value += getDigits(scnr);\n }\n if (scnr.currentChar() === EOF) {\n emitError(CompileErrorCodes.UNTERMINATED_CLOSING_BRACE, currentPosition(), 0);\n }\n return value;\n }\n function isLiteral(ch) {\n return ch !== LITERAL_DELIMITER && ch !== CHAR_LF;\n }\n function readLiteral(scnr) {\n skipSpaces(scnr);\n // eslint-disable-next-line no-useless-escape\n eat(scnr, `\\'`);\n let ch = '';\n let literal = '';\n while ((ch = takeChar(scnr, isLiteral))) {\n if (ch === '\\\\') {\n literal += readEscapeSequence(scnr);\n }\n else {\n literal += ch;\n }\n }\n const current = scnr.currentChar();\n if (current === CHAR_LF || current === EOF) {\n emitError(CompileErrorCodes.UNTERMINATED_SINGLE_QUOTE_IN_PLACEHOLDER, currentPosition(), 0);\n // TODO: Is it correct really?\n if (current === CHAR_LF) {\n scnr.next();\n // eslint-disable-next-line no-useless-escape\n eat(scnr, `\\'`);\n }\n return literal;\n }\n // eslint-disable-next-line no-useless-escape\n eat(scnr, `\\'`);\n return literal;\n }\n function readEscapeSequence(scnr) {\n const ch = scnr.currentChar();\n switch (ch) {\n case '\\\\':\n case `\\'`: // eslint-disable-line no-useless-escape\n scnr.next();\n return `\\\\${ch}`;\n case 'u':\n return readUnicodeEscapeSequence(scnr, ch, 4);\n case 'U':\n return readUnicodeEscapeSequence(scnr, ch, 6);\n default:\n emitError(CompileErrorCodes.UNKNOWN_ESCAPE_SEQUENCE, currentPosition(), 0, ch);\n return '';\n }\n }\n function readUnicodeEscapeSequence(scnr, unicode, digits) {\n eat(scnr, unicode);\n let sequence = '';\n for (let i = 0; i < digits; i++) {\n const ch = takeHexDigit(scnr);\n if (!ch) {\n emitError(CompileErrorCodes.INVALID_UNICODE_ESCAPE_SEQUENCE, currentPosition(), 0, `\\\\${unicode}${sequence}${scnr.currentChar()}`);\n break;\n }\n sequence += ch;\n }\n return `\\\\${unicode}${sequence}`;\n }\n function isInvalidIdentifier(ch) {\n return (ch !== \"{\" /* TokenChars.BraceLeft */ &&\n ch !== \"}\" /* TokenChars.BraceRight */ &&\n ch !== CHAR_SP &&\n ch !== CHAR_LF);\n }\n function readInvalidIdentifier(scnr) {\n skipSpaces(scnr);\n let ch = '';\n let identifiers = '';\n while ((ch = takeChar(scnr, isInvalidIdentifier))) {\n identifiers += ch;\n }\n return identifiers;\n }\n function readLinkedModifier(scnr) {\n let ch = '';\n let name = '';\n while ((ch = takeIdentifierChar(scnr))) {\n name += ch;\n }\n return name;\n }\n function readLinkedRefer(scnr) {\n const fn = (buf) => {\n const ch = scnr.currentChar();\n if (ch === \"{\" /* TokenChars.BraceLeft */ ||\n ch === \"@\" /* TokenChars.LinkedAlias */ ||\n ch === \"|\" /* TokenChars.Pipe */ ||\n ch === \"(\" /* TokenChars.ParenLeft */ ||\n ch === \")\" /* TokenChars.ParenRight */ ||\n !ch) {\n return buf;\n }\n else if (ch === CHAR_SP) {\n return buf;\n }\n else if (ch === CHAR_LF || ch === DOT) {\n buf += ch;\n scnr.next();\n return fn(buf);\n }\n else {\n buf += ch;\n scnr.next();\n return fn(buf);\n }\n };\n return fn('');\n }\n function readPlural(scnr) {\n skipSpaces(scnr);\n const plural = eat(scnr, \"|\" /* TokenChars.Pipe */);\n skipSpaces(scnr);\n return plural;\n }\n // TODO: We need refactoring of token parsing ...\n function readTokenInPlaceholder(scnr, context) {\n let token = null;\n const ch = scnr.currentChar();\n switch (ch) {\n case \"{\" /* TokenChars.BraceLeft */:\n if (context.braceNest >= 1) {\n emitError(CompileErrorCodes.NOT_ALLOW_NEST_PLACEHOLDER, currentPosition(), 0);\n }\n scnr.next();\n token = getToken(context, 2 /* TokenTypes.BraceLeft */, \"{\" /* TokenChars.BraceLeft */);\n skipSpaces(scnr);\n context.braceNest++;\n return token;\n case \"}\" /* TokenChars.BraceRight */:\n if (context.braceNest > 0 &&\n context.currentType === 2 /* TokenTypes.BraceLeft */) {\n emitError(CompileErrorCodes.EMPTY_PLACEHOLDER, currentPosition(), 0);\n }\n scnr.next();\n token = getToken(context, 3 /* TokenTypes.BraceRight */, \"}\" /* TokenChars.BraceRight */);\n context.braceNest--;\n context.braceNest > 0 && skipSpaces(scnr);\n if (context.inLinked && context.braceNest === 0) {\n context.inLinked = false;\n }\n return token;\n case \"@\" /* TokenChars.LinkedAlias */:\n if (context.braceNest > 0) {\n emitError(CompileErrorCodes.UNTERMINATED_CLOSING_BRACE, currentPosition(), 0);\n }\n token = readTokenInLinked(scnr, context) || getEndToken(context);\n context.braceNest = 0;\n return token;\n default: {\n let validNamedIdentifier = true;\n let validListIdentifier = true;\n let validLiteral = true;\n if (isPluralStart(scnr)) {\n if (context.braceNest > 0) {\n emitError(CompileErrorCodes.UNTERMINATED_CLOSING_BRACE, currentPosition(), 0);\n }\n token = getToken(context, 1 /* TokenTypes.Pipe */, readPlural(scnr));\n // reset\n context.braceNest = 0;\n context.inLinked = false;\n return token;\n }\n if (context.braceNest > 0 &&\n (context.currentType === 4 /* TokenTypes.Named */ ||\n context.currentType === 5 /* TokenTypes.List */ ||\n context.currentType === 6 /* TokenTypes.Literal */)) {\n emitError(CompileErrorCodes.UNTERMINATED_CLOSING_BRACE, currentPosition(), 0);\n context.braceNest = 0;\n return readToken(scnr, context);\n }\n if ((validNamedIdentifier = isNamedIdentifierStart(scnr, context))) {\n token = getToken(context, 4 /* TokenTypes.Named */, readNamedIdentifier(scnr));\n skipSpaces(scnr);\n return token;\n }\n if ((validListIdentifier = isListIdentifierStart(scnr, context))) {\n token = getToken(context, 5 /* TokenTypes.List */, readListIdentifier(scnr));\n skipSpaces(scnr);\n return token;\n }\n if ((validLiteral = isLiteralStart(scnr, context))) {\n token = getToken(context, 6 /* TokenTypes.Literal */, readLiteral(scnr));\n skipSpaces(scnr);\n return token;\n }\n if (!validNamedIdentifier && !validListIdentifier && !validLiteral) {\n // TODO: we should be re-designed invalid cases, when we will extend message syntax near the future ...\n token = getToken(context, 12 /* TokenTypes.InvalidPlace */, readInvalidIdentifier(scnr));\n emitError(CompileErrorCodes.INVALID_TOKEN_IN_PLACEHOLDER, currentPosition(), 0, token.value);\n skipSpaces(scnr);\n return token;\n }\n break;\n }\n }\n return token;\n }\n // TODO: We need refactoring of token parsing ...\n function readTokenInLinked(scnr, context) {\n const { currentType } = context;\n let token = null;\n const ch = scnr.currentChar();\n if ((currentType === 7 /* TokenTypes.LinkedAlias */ ||\n currentType === 8 /* TokenTypes.LinkedDot */ ||\n currentType === 11 /* TokenTypes.LinkedModifier */ ||\n currentType === 9 /* TokenTypes.LinkedDelimiter */) &&\n (ch === CHAR_LF || ch === CHAR_SP)) {\n emitError(CompileErrorCodes.INVALID_LINKED_FORMAT, currentPosition(), 0);\n }\n switch (ch) {\n case \"@\" /* TokenChars.LinkedAlias */:\n scnr.next();\n token = getToken(context, 7 /* TokenTypes.LinkedAlias */, \"@\" /* TokenChars.LinkedAlias */);\n context.inLinked = true;\n return token;\n case \".\" /* TokenChars.LinkedDot */:\n skipSpaces(scnr);\n scnr.next();\n return getToken(context, 8 /* TokenTypes.LinkedDot */, \".\" /* TokenChars.LinkedDot */);\n case \":\" /* TokenChars.LinkedDelimiter */:\n skipSpaces(scnr);\n scnr.next();\n return getToken(context, 9 /* TokenTypes.LinkedDelimiter */, \":\" /* TokenChars.LinkedDelimiter */);\n default:\n if (isPluralStart(scnr)) {\n token = getToken(context, 1 /* TokenTypes.Pipe */, readPlural(scnr));\n // reset\n context.braceNest = 0;\n context.inLinked = false;\n return token;\n }\n if (isLinkedDotStart(scnr, context) ||\n isLinkedDelimiterStart(scnr, context)) {\n skipSpaces(scnr);\n return readTokenInLinked(scnr, context);\n }\n if (isLinkedModifierStart(scnr, context)) {\n skipSpaces(scnr);\n return getToken(context, 11 /* TokenTypes.LinkedModifier */, readLinkedModifier(scnr));\n }\n if (isLinkedReferStart(scnr, context)) {\n skipSpaces(scnr);\n if (ch === \"{\" /* TokenChars.BraceLeft */) {\n // scan the placeholder\n return readTokenInPlaceholder(scnr, context) || token;\n }\n else {\n return getToken(context, 10 /* TokenTypes.LinkedKey */, readLinkedRefer(scnr));\n }\n }\n if (currentType === 7 /* TokenTypes.LinkedAlias */) {\n emitError(CompileErrorCodes.INVALID_LINKED_FORMAT, currentPosition(), 0);\n }\n context.braceNest = 0;\n context.inLinked = false;\n return readToken(scnr, context);\n }\n }\n // TODO: We need refactoring of token parsing ...\n function readToken(scnr, context) {\n let token = { type: 13 /* TokenTypes.EOF */ };\n if (context.braceNest > 0) {\n return readTokenInPlaceholder(scnr, context) || getEndToken(context);\n }\n if (context.inLinked) {\n return readTokenInLinked(scnr, context) || getEndToken(context);\n }\n const ch = scnr.currentChar();\n switch (ch) {\n case \"{\" /* TokenChars.BraceLeft */:\n return readTokenInPlaceholder(scnr, context) || getEndToken(context);\n case \"}\" /* TokenChars.BraceRight */:\n emitError(CompileErrorCodes.UNBALANCED_CLOSING_BRACE, currentPosition(), 0);\n scnr.next();\n return getToken(context, 3 /* TokenTypes.BraceRight */, \"}\" /* TokenChars.BraceRight */);\n case \"@\" /* TokenChars.LinkedAlias */:\n return readTokenInLinked(scnr, context) || getEndToken(context);\n default: {\n if (isPluralStart(scnr)) {\n token = getToken(context, 1 /* TokenTypes.Pipe */, readPlural(scnr));\n // reset\n context.braceNest = 0;\n context.inLinked = false;\n return token;\n }\n if (isTextStart(scnr)) {\n return getToken(context, 0 /* TokenTypes.Text */, readText(scnr));\n }\n break;\n }\n }\n return token;\n }\n function nextToken() {\n const { currentType, offset, startLoc, endLoc } = _context;\n _context.lastType = currentType;\n _context.lastOffset = offset;\n _context.lastStartLoc = startLoc;\n _context.lastEndLoc = endLoc;\n _context.offset = currentOffset();\n _context.startLoc = currentPosition();\n if (_scnr.currentChar() === EOF) {\n return getToken(_context, 13 /* TokenTypes.EOF */);\n }\n return readToken(_scnr, _context);\n }\n return {\n nextToken,\n currentOffset,\n currentPosition,\n context\n };\n}\n\nconst ERROR_DOMAIN$2 = 'parser';\n// Backslash backslash, backslash quote, uHHHH, UHHHHHH.\nconst KNOWN_ESCAPES = /(?:\\\\\\\\|\\\\'|\\\\u([0-9a-fA-F]{4})|\\\\U([0-9a-fA-F]{6}))/g;\n// Text context escape sequences: \\\\, \\@, \\{, \\}, \\|\nconst TEXT_ESCAPES = /\\\\([\\\\@{}|])/g;\nfunction fromTextEscapeSequence(_match, char) {\n return char;\n}\nfunction fromEscapeSequence(match, codePoint4, codePoint6) {\n switch (match) {\n case `\\\\\\\\`:\n return `\\\\`;\n // eslint-disable-next-line no-useless-escape\n case `\\\\\\'`:\n // eslint-disable-next-line no-useless-escape\n return `\\'`;\n default: {\n const codePoint = parseInt(codePoint4 || codePoint6, 16);\n if (codePoint <= 0xd7ff || codePoint >= 0xe000) {\n return String.fromCodePoint(codePoint);\n }\n // invalid ...\n // Replace them with U+FFFD REPLACEMENT CHARACTER.\n return '�';\n }\n }\n}\nfunction createParser(options = {}) {\n const location = options.location !== false;\n const { onError } = options;\n function emitError(tokenzer, code, start, offset, ...args) {\n const end = tokenzer.currentPosition();\n end.offset += offset;\n end.column += offset;\n if (onError) {\n const loc = location ? createLocation(start, end) : null;\n const err = createCompileError(code, loc, {\n domain: ERROR_DOMAIN$2,\n args\n });\n onError(err);\n }\n }\n function startNode(type, offset, loc) {\n const node = { type };\n if (location) {\n node.start = offset;\n node.end = offset;\n node.loc = { start: loc, end: loc };\n }\n return node;\n }\n function endNode(node, offset, pos, type) {\n if (location) {\n node.end = offset;\n if (node.loc) {\n node.loc.end = pos;\n }\n }\n }\n function parseText(tokenizer, value) {\n const context = tokenizer.context();\n const node = startNode(3 /* NodeTypes.Text */, context.offset, context.startLoc);\n node.value = value.replace(TEXT_ESCAPES, fromTextEscapeSequence);\n endNode(node, tokenizer.currentOffset(), tokenizer.currentPosition());\n return node;\n }\n function parseList(tokenizer, index) {\n const context = tokenizer.context();\n const { lastOffset: offset, lastStartLoc: loc } = context; // get brace left loc\n const node = startNode(5 /* NodeTypes.List */, offset, loc);\n node.index = parseInt(index, 10);\n tokenizer.nextToken(); // skip brach right\n endNode(node, tokenizer.currentOffset(), tokenizer.currentPosition());\n return node;\n }\n function parseNamed(tokenizer, key) {\n const context = tokenizer.context();\n const { lastOffset: offset, lastStartLoc: loc } = context; // get brace left loc\n const node = startNode(4 /* NodeTypes.Named */, offset, loc);\n node.key = key;\n tokenizer.nextToken(); // skip brach right\n endNode(node, tokenizer.currentOffset(), tokenizer.currentPosition());\n return node;\n }\n function parseLiteral(tokenizer, value) {\n const context = tokenizer.context();\n const { lastOffset: offset, lastStartLoc: loc } = context; // get brace left loc\n const node = startNode(9 /* NodeTypes.Literal */, offset, loc);\n node.value = value.replace(KNOWN_ESCAPES, fromEscapeSequence);\n tokenizer.nextToken(); // skip brach right\n endNode(node, tokenizer.currentOffset(), tokenizer.currentPosition());\n return node;\n }\n function parseLinkedModifier(tokenizer) {\n const token = tokenizer.nextToken();\n const context = tokenizer.context();\n const { lastOffset: offset, lastStartLoc: loc } = context; // get linked dot loc\n const node = startNode(8 /* NodeTypes.LinkedModifier */, offset, loc);\n if (token.type !== 11 /* TokenTypes.LinkedModifier */) {\n // empty modifier\n emitError(tokenizer, CompileErrorCodes.UNEXPECTED_EMPTY_LINKED_MODIFIER, context.lastStartLoc, 0);\n node.value = '';\n endNode(node, offset, loc);\n return {\n nextConsumeToken: token,\n node\n };\n }\n // check token\n if (token.value == null) {\n emitError(tokenizer, CompileErrorCodes.UNEXPECTED_LEXICAL_ANALYSIS, context.lastStartLoc, 0, getTokenCaption(token));\n }\n node.value = token.value || '';\n endNode(node, tokenizer.currentOffset(), tokenizer.currentPosition());\n return {\n node\n };\n }\n function parseLinkedKey(tokenizer, value) {\n const context = tokenizer.context();\n const node = startNode(7 /* NodeTypes.LinkedKey */, context.offset, context.startLoc);\n node.value = value;\n endNode(node, tokenizer.currentOffset(), tokenizer.currentPosition());\n return node;\n }\n function parseLinked(tokenizer) {\n const context = tokenizer.context();\n const linkedNode = startNode(6 /* NodeTypes.Linked */, context.offset, context.startLoc);\n let token = tokenizer.nextToken();\n if (token.type === 8 /* TokenTypes.LinkedDot */) {\n const parsed = parseLinkedModifier(tokenizer);\n linkedNode.modifier = parsed.node;\n token = parsed.nextConsumeToken || tokenizer.nextToken();\n }\n // asset check token\n if (token.type !== 9 /* TokenTypes.LinkedDelimiter */) {\n emitError(tokenizer, CompileErrorCodes.UNEXPECTED_LEXICAL_ANALYSIS, context.lastStartLoc, 0, getTokenCaption(token));\n }\n token = tokenizer.nextToken();\n // skip brace left\n if (token.type === 2 /* TokenTypes.BraceLeft */) {\n token = tokenizer.nextToken();\n }\n switch (token.type) {\n case 10 /* TokenTypes.LinkedKey */:\n if (token.value == null) {\n emitError(tokenizer, CompileErrorCodes.UNEXPECTED_LEXICAL_ANALYSIS, context.lastStartLoc, 0, getTokenCaption(token));\n }\n linkedNode.key = parseLinkedKey(tokenizer, token.value || '');\n break;\n case 4 /* TokenTypes.Named */:\n if (token.value == null) {\n emitError(tokenizer, CompileErrorCodes.UNEXPECTED_LEXICAL_ANALYSIS, context.lastStartLoc, 0, getTokenCaption(token));\n }\n linkedNode.key = parseNamed(tokenizer, token.value || '');\n break;\n case 5 /* TokenTypes.List */:\n if (token.value == null) {\n emitError(tokenizer, CompileErrorCodes.UNEXPECTED_LEXICAL_ANALYSIS, context.lastStartLoc, 0, getTokenCaption(token));\n }\n linkedNode.key = parseList(tokenizer, token.value || '');\n break;\n case 6 /* TokenTypes.Literal */:\n if (token.value == null) {\n emitError(tokenizer, CompileErrorCodes.UNEXPECTED_LEXICAL_ANALYSIS, context.lastStartLoc, 0, getTokenCaption(token));\n }\n linkedNode.key = parseLiteral(tokenizer, token.value || '');\n break;\n default: {\n // empty key\n emitError(tokenizer, CompileErrorCodes.UNEXPECTED_EMPTY_LINKED_KEY, context.lastStartLoc, 0);\n const nextContext = tokenizer.context();\n const emptyLinkedKeyNode = startNode(7 /* NodeTypes.LinkedKey */, nextContext.offset, nextContext.startLoc);\n emptyLinkedKeyNode.value = '';\n endNode(emptyLinkedKeyNode, nextContext.offset, nextContext.startLoc);\n linkedNode.key = emptyLinkedKeyNode;\n endNode(linkedNode, nextContext.offset, nextContext.startLoc);\n return {\n nextConsumeToken: token,\n node: linkedNode\n };\n }\n }\n endNode(linkedNode, tokenizer.currentOffset(), tokenizer.currentPosition());\n return {\n node: linkedNode\n };\n }\n function parseMessage(tokenizer) {\n const context = tokenizer.context();\n const startOffset = context.currentType === 1 /* TokenTypes.Pipe */\n ? tokenizer.currentOffset()\n : context.offset;\n const startLoc = context.currentType === 1 /* TokenTypes.Pipe */\n ? context.endLoc\n : context.startLoc;\n const node = startNode(2 /* NodeTypes.Message */, startOffset, startLoc);\n node.items = [];\n let nextToken = null;\n do {\n const token = nextToken || tokenizer.nextToken();\n nextToken = null;\n switch (token.type) {\n case 0 /* TokenTypes.Text */:\n if (token.value == null) {\n emitError(tokenizer, CompileErrorCodes.UNEXPECTED_LEXICAL_ANALYSIS, context.lastStartLoc, 0, getTokenCaption(token));\n }\n node.items.push(parseText(tokenizer, token.value || ''));\n break;\n case 5 /* TokenTypes.List */:\n if (token.value == null) {\n emitError(tokenizer, CompileErrorCodes.UNEXPECTED_LEXICAL_ANALYSIS, context.lastStartLoc, 0, getTokenCaption(token));\n }\n node.items.push(parseList(tokenizer, token.value || ''));\n break;\n case 4 /* TokenTypes.Named */:\n if (token.value == null) {\n emitError(tokenizer, CompileErrorCodes.UNEXPECTED_LEXICAL_ANALYSIS, context.lastStartLoc, 0, getTokenCaption(token));\n }\n node.items.push(parseNamed(tokenizer, token.value || ''));\n break;\n case 6 /* TokenTypes.Literal */:\n if (token.value == null) {\n emitError(tokenizer, CompileErrorCodes.UNEXPECTED_LEXICAL_ANALYSIS, context.lastStartLoc, 0, getTokenCaption(token));\n }\n node.items.push(parseLiteral(tokenizer, token.value || ''));\n break;\n case 7 /* TokenTypes.LinkedAlias */: {\n const parsed = parseLinked(tokenizer);\n node.items.push(parsed.node);\n nextToken = parsed.nextConsumeToken || null;\n break;\n }\n }\n } while (context.currentType !== 13 /* TokenTypes.EOF */ &&\n context.currentType !== 1 /* TokenTypes.Pipe */);\n // adjust message node loc\n const endOffset = context.currentType === 1 /* TokenTypes.Pipe */\n ? context.lastOffset\n : tokenizer.currentOffset();\n const endLoc = context.currentType === 1 /* TokenTypes.Pipe */\n ? context.lastEndLoc\n : tokenizer.currentPosition();\n endNode(node, endOffset, endLoc);\n return node;\n }\n function parsePlural(tokenizer, offset, loc, msgNode) {\n const context = tokenizer.context();\n let hasEmptyMessage = msgNode.items.length === 0;\n const node = startNode(1 /* NodeTypes.Plural */, offset, loc);\n node.cases = [];\n node.cases.push(msgNode);\n do {\n const msg = parseMessage(tokenizer);\n if (!hasEmptyMessage) {\n hasEmptyMessage = msg.items.length === 0;\n }\n node.cases.push(msg);\n } while (context.currentType !== 13 /* TokenTypes.EOF */);\n if (hasEmptyMessage) {\n emitError(tokenizer, CompileErrorCodes.MUST_HAVE_MESSAGES_IN_PLURAL, loc, 0);\n }\n endNode(node, tokenizer.currentOffset(), tokenizer.currentPosition());\n return node;\n }\n function parseResource(tokenizer) {\n const context = tokenizer.context();\n const { offset, startLoc } = context;\n const msgNode = parseMessage(tokenizer);\n if (context.currentType === 13 /* TokenTypes.EOF */) {\n return msgNode;\n }\n else {\n return parsePlural(tokenizer, offset, startLoc, msgNode);\n }\n }\n function parse(source) {\n const tokenizer = createTokenizer(source, assign({}, options));\n const context = tokenizer.context();\n const node = startNode(0 /* NodeTypes.Resource */, context.offset, context.startLoc);\n if (location && node.loc) {\n node.loc.source = source;\n }\n node.body = parseResource(tokenizer);\n if (options.onCacheKey) {\n node.cacheKey = options.onCacheKey(source);\n }\n // assert whether achieved to EOF\n if (context.currentType !== 13 /* TokenTypes.EOF */) {\n emitError(tokenizer, CompileErrorCodes.UNEXPECTED_LEXICAL_ANALYSIS, context.lastStartLoc, 0, source[context.offset] || '');\n }\n endNode(node, tokenizer.currentOffset(), tokenizer.currentPosition());\n return node;\n }\n return { parse };\n}\nfunction getTokenCaption(token) {\n if (token.type === 13 /* TokenTypes.EOF */) {\n return 'EOF';\n }\n const name = (token.value || '').replace(/\\r?\\n/gu, '\\\\n');\n return name.length > 10 ? name.slice(0, 9) + '…' : name;\n}\n\nfunction createTransformer(ast, options = {} // eslint-disable-line\n) {\n const _context = {\n ast,\n helpers: new Set()\n };\n const context = () => _context;\n const helper = (name) => {\n _context.helpers.add(name);\n return name;\n };\n return { context, helper };\n}\nfunction traverseNodes(nodes, transformer) {\n for (let i = 0; i < nodes.length; i++) {\n traverseNode(nodes[i], transformer);\n }\n}\nfunction traverseNode(node, transformer) {\n // TODO: if we need pre-hook of transform, should be implemented to here\n switch (node.type) {\n case 1 /* NodeTypes.Plural */:\n traverseNodes(node.cases, transformer);\n transformer.helper(\"plural\" /* HelperNameMap.PLURAL */);\n break;\n case 2 /* NodeTypes.Message */:\n traverseNodes(node.items, transformer);\n break;\n case 6 /* NodeTypes.Linked */: {\n const linked = node;\n traverseNode(linked.key, transformer);\n transformer.helper(\"linked\" /* HelperNameMap.LINKED */);\n transformer.helper(\"type\" /* HelperNameMap.TYPE */);\n break;\n }\n case 5 /* NodeTypes.List */:\n transformer.helper(\"interpolate\" /* HelperNameMap.INTERPOLATE */);\n transformer.helper(\"list\" /* HelperNameMap.LIST */);\n break;\n case 4 /* NodeTypes.Named */:\n transformer.helper(\"interpolate\" /* HelperNameMap.INTERPOLATE */);\n transformer.helper(\"named\" /* HelperNameMap.NAMED */);\n break;\n }\n // TODO: if we need post-hook of transform, should be implemented to here\n}\n// transform AST\nfunction transform(ast, options = {} // eslint-disable-line\n) {\n const transformer = createTransformer(ast);\n transformer.helper(\"normalize\" /* HelperNameMap.NORMALIZE */);\n // traverse\n ast.body && traverseNode(ast.body, transformer);\n // set meta information\n const context = transformer.context();\n ast.helpers = Array.from(context.helpers);\n}\n\nfunction optimize(ast) {\n const body = ast.body;\n if (body.type === 2 /* NodeTypes.Message */) {\n optimizeMessageNode(body);\n }\n else {\n body.cases.forEach(c => optimizeMessageNode(c));\n }\n return ast;\n}\nfunction optimizeMessageNode(message) {\n if (message.items.length === 1) {\n const item = message.items[0];\n if (item.type === 3 /* NodeTypes.Text */ || item.type === 9 /* NodeTypes.Literal */) {\n message.static = item.value;\n delete item.value; // optimization for size\n }\n }\n else {\n const values = [];\n for (let i = 0; i < message.items.length; i++) {\n const item = message.items[i];\n if (!(item.type === 3 /* NodeTypes.Text */ || item.type === 9 /* NodeTypes.Literal */)) {\n break;\n }\n if (item.value == null) {\n break;\n }\n values.push(item.value);\n }\n if (values.length === message.items.length) {\n message.static = join(values);\n for (let i = 0; i < message.items.length; i++) {\n const item = message.items[i];\n if (item.type === 3 /* NodeTypes.Text */ || item.type === 9 /* NodeTypes.Literal */) {\n delete item.value; // optimization for size\n }\n }\n }\n }\n}\n\nconst ERROR_DOMAIN$1 = 'minifier';\n/* eslint-disable @typescript-eslint/no-explicit-any */\nfunction minify(node) {\n node.t = node.type;\n switch (node.type) {\n case 0 /* NodeTypes.Resource */: {\n const resource = node;\n minify(resource.body);\n resource.b = resource.body;\n delete resource.body;\n break;\n }\n case 1 /* NodeTypes.Plural */: {\n const plural = node;\n const cases = plural.cases;\n for (let i = 0; i < cases.length; i++) {\n minify(cases[i]);\n }\n plural.c = cases;\n delete plural.cases;\n break;\n }\n case 2 /* NodeTypes.Message */: {\n const message = node;\n const items = message.items;\n for (let i = 0; i < items.length; i++) {\n minify(items[i]);\n }\n message.i = items;\n delete message.items;\n if (message.static) {\n message.s = message.static;\n delete message.static;\n }\n break;\n }\n case 3 /* NodeTypes.Text */:\n case 9 /* NodeTypes.Literal */:\n case 8 /* NodeTypes.LinkedModifier */:\n case 7 /* NodeTypes.LinkedKey */: {\n const valueNode = node;\n if (valueNode.value) {\n valueNode.v = valueNode.value;\n delete valueNode.value;\n }\n break;\n }\n case 6 /* NodeTypes.Linked */: {\n const linked = node;\n minify(linked.key);\n linked.k = linked.key;\n delete linked.key;\n if (linked.modifier) {\n minify(linked.modifier);\n linked.m = linked.modifier;\n delete linked.modifier;\n }\n break;\n }\n case 5 /* NodeTypes.List */: {\n const list = node;\n list.i = list.index;\n delete list.index;\n break;\n }\n case 4 /* NodeTypes.Named */: {\n const named = node;\n named.k = named.key;\n delete named.key;\n break;\n }\n default:\n if ((process.env.NODE_ENV !== 'production')) {\n throw createCompileError(CompileErrorCodes.UNHANDLED_MINIFIER_NODE_TYPE, null, {\n domain: ERROR_DOMAIN$1,\n args: [node.type]\n });\n }\n }\n delete node.type;\n}\n/* eslint-enable @typescript-eslint/no-explicit-any */\n\n// eslint-disable-next-line @typescript-eslint/triple-slash-reference\n/// <reference types=\"source-map-js\" />\nconst ERROR_DOMAIN = 'parser';\nfunction createCodeGenerator(ast, options) {\n const { sourceMap, filename, breakLineCode, needIndent: _needIndent } = options;\n const location = options.location !== false;\n const _context = {\n filename,\n code: '',\n column: 1,\n line: 1,\n offset: 0,\n map: undefined,\n breakLineCode,\n needIndent: _needIndent,\n indentLevel: 0\n };\n if (location && ast.loc) {\n _context.source = ast.loc.source;\n }\n const context = () => _context;\n function push(code, node) {\n _context.code += code;\n }\n function _newline(n, withBreakLine = true) {\n const _breakLineCode = withBreakLine ? breakLineCode : '';\n push(_needIndent ? _breakLineCode + ` `.repeat(n) : _breakLineCode);\n }\n function indent(withNewLine = true) {\n const level = ++_context.indentLevel;\n withNewLine && _newline(level);\n }\n function deindent(withNewLine = true) {\n const level = --_context.indentLevel;\n withNewLine && _newline(level);\n }\n function newline() {\n _newline(_context.indentLevel);\n }\n const helper = (key) => `_${key}`;\n const needIndent = () => _context.needIndent;\n return {\n context,\n push,\n indent,\n deindent,\n newline,\n helper,\n needIndent\n };\n}\nfunction generateLinkedNode(generator, node) {\n const { helper } = generator;\n generator.push(`${helper(\"linked\" /* HelperNameMap.LINKED */)}(`);\n generateNode(generator, node.key);\n if (node.modifier) {\n generator.push(`, `);\n generateNode(generator, node.modifier);\n generator.push(`, _type`);\n }\n else {\n generator.push(`, undefined, _type`);\n }\n generator.push(`)`);\n}\nfunction generateMessageNode(generator, node) {\n const { helper, needIndent } = generator;\n generator.push(`${helper(\"normalize\" /* HelperNameMap.NORMALIZE */)}([`);\n generator.indent(needIndent());\n const length = node.items.length;\n for (let i = 0; i < length; i++) {\n generateNode(generator, node.items[i]);\n if (i === length - 1) {\n break;\n }\n generator.push(', ');\n }\n generator.deindent(needIndent());\n generator.push('])');\n}\nfunction generatePluralNode(generator, node) {\n const { helper, needIndent } = generator;\n if (node.cases.length > 1) {\n generator.push(`${helper(\"plural\" /* HelperNameMap.PLURAL */)}([`);\n generator.indent(needIndent());\n const length = node.cases.length;\n for (let i = 0; i < length; i++) {\n generateNode(generator, node.cases[i]);\n if (i === length - 1) {\n break;\n }\n generator.push(', ');\n }\n generator.deindent(needIndent());\n generator.push(`])`);\n }\n}\nfunction generateResource(generator, node) {\n if (node.body) {\n generateNode(generator, node.body);\n }\n else {\n generator.push('null');\n }\n}\nfunction generateNode(generator, node) {\n const { helper } = generator;\n switch (node.type) {\n case 0 /* NodeTypes.Resource */:\n generateResource(generator, node);\n break;\n case 1 /* NodeTypes.Plural */:\n generatePluralNode(generator, node);\n break;\n case 2 /* NodeTypes.Message */:\n generateMessageNode(generator, node);\n break;\n case 6 /* NodeTypes.Linked */:\n generateLinkedNode(generator, node);\n break;\n case 8 /* NodeTypes.LinkedModifier */:\n generator.push(JSON.stringify(node.value), node);\n break;\n case 7 /* NodeTypes.LinkedKey */:\n generator.push(JSON.stringify(node.value), node);\n break;\n case 5 /* NodeTypes.List */:\n generator.push(`${helper(\"interpolate\" /* HelperNameMap.INTERPOLATE */)}(${helper(\"list\" /* HelperNameMap.LIST */)}(${node.index}))`, node);\n break;\n case 4 /* NodeTypes.Named */:\n generator.push(`${helper(\"interpolate\" /* HelperNameMap.INTERPOLATE */)}(${helper(\"named\" /* HelperNameMap.NAMED */)}(${JSON.stringify(node.key)}))`, node);\n break;\n case 9 /* NodeTypes.Literal */:\n generator.push(JSON.stringify(node.value), node);\n break;\n case 3 /* NodeTypes.Text */:\n generator.push(JSON.stringify(node.value), node);\n break;\n default:\n if ((process.env.NODE_ENV !== 'production')) {\n throw createCompileError(CompileErrorCodes.UNHANDLED_CODEGEN_NODE_TYPE, null, {\n domain: ERROR_DOMAIN,\n args: [node.type]\n });\n }\n }\n}\n// generate code from AST\nconst generate = (ast, options = {}) => {\n const mode = isString(options.mode) ? options.mode : 'normal';\n const filename = isString(options.filename)\n ? options.filename\n : 'message.intl';\n const sourceMap = !!options.sourceMap;\n // prettier-ignore\n const breakLineCode = options.breakLineCode != null\n ? options.breakLineCode\n : mode === 'arrow'\n ? ';'\n : '\\n';\n const needIndent = options.needIndent ? options.needIndent : mode !== 'arrow';\n const helpers = ast.helpers || [];\n const generator = createCodeGenerator(ast, {\n mode,\n filename,\n sourceMap,\n breakLineCode,\n needIndent\n });\n generator.push(mode === 'normal' ? `function __msg__ (ctx) {` : `(ctx) => {`);\n generator.indent(needIndent);\n if (helpers.length > 0) {\n generator.push(`const { ${join(helpers.map(s => `${s}: _${s}`), ', ')} } = ctx`);\n generator.newline();\n }\n generator.push(`return `);\n generateNode(generator, ast);\n generator.deindent(needIndent);\n generator.push(`}`);\n delete ast.helpers;\n const { code, map } = generator.context();\n return {\n ast,\n code,\n map: map ? map.toJSON() : undefined // eslint-disable-line @typescript-eslint/no-explicit-any\n };\n};\n\nfunction baseCompile(source, options = {}) {\n const assignedOptions = assign({}, options);\n const jit = !!assignedOptions.jit;\n const enalbeMinify = !!assignedOptions.minify;\n const enambeOptimize = assignedOptions.optimize == null ? true : assignedOptions.optimize;\n // parse source codes\n const parser = createParser(assignedOptions);\n const ast = parser.parse(source);\n if (!jit) {\n // transform ASTs\n transform(ast, assignedOptions);\n // generate javascript codes\n return generate(ast, assignedOptions);\n }\n else {\n // optimize ASTs\n enambeOptimize && optimize(ast);\n // minimize ASTs\n enalbeMinify && minify(ast);\n // In JIT mode, no ast transform, no code generation.\n return { ast, code: '' };\n }\n}\n\nexport { COMPILE_ERROR_CODES_EXTEND_POINT, CompileErrorCodes, ERROR_DOMAIN$2 as ERROR_DOMAIN, LOCATION_STUB, baseCompile, createCompileError, createLocation, createParser, createPosition, defaultOnError, detectHtmlTag, errorMessages };\n","/*!\n * core-base v11.3.0\n * (c) 2026 kazuya kawaguchi\n * Released under the MIT License.\n */\nimport { getGlobalThis, isObject, hasOwn, isNumber, create, isString, isBoolean, warn, format as format$1, isFunction, isPromise, isArray, isPlainObject, assign, isRegExp, warnOnce, isDate, isEmptyObject, join, toDisplayString, sanitizeTranslatedHtml, escapeHtml, inBrowser, mark, measure, generateCodeFrame, generateFormatCacheKey } from '@intlify/shared';\nimport { detectHtmlTag, defaultOnError, baseCompile as baseCompile$1, COMPILE_ERROR_CODES_EXTEND_POINT, createCompileError } from '@intlify/message-compiler';\nexport { CompileErrorCodes, createCompileError } from '@intlify/message-compiler';\n\n/**\n * This is only called in esm-bundler builds.\n * istanbul-ignore-next\n */\nfunction initFeatureFlags() {\n if (typeof __INTLIFY_PROD_DEVTOOLS__ !== 'boolean') {\n getGlobalThis().__INTLIFY_PROD_DEVTOOLS__ = false;\n }\n if (typeof __INTLIFY_DROP_MESSAGE_COMPILER__ !== 'boolean') {\n getGlobalThis().__INTLIFY_DROP_MESSAGE_COMPILER__ = false;\n }\n}\n\nfunction isMessageAST(val) {\n return (isObject(val) &&\n resolveType(val) === 0 &&\n (hasOwn(val, 'b') || hasOwn(val, 'body')));\n}\nconst PROPS_BODY = ['b', 'body'];\nfunction resolveBody(node) {\n return resolveProps(node, PROPS_BODY);\n}\nconst PROPS_CASES = ['c', 'cases'];\nfunction resolveCases(node) {\n return resolveProps(node, PROPS_CASES, []);\n}\nconst PROPS_STATIC = ['s', 'static'];\nfunction resolveStatic(node) {\n return resolveProps(node, PROPS_STATIC);\n}\nconst PROPS_ITEMS = ['i', 'items'];\nfunction resolveItems(node) {\n return resolveProps(node, PROPS_ITEMS, []);\n}\nconst PROPS_TYPE = ['t', 'type'];\nfunction resolveType(node) {\n return resolveProps(node, PROPS_TYPE);\n}\nconst PROPS_VALUE = ['v', 'value'];\nfunction resolveValue$1(node, type) {\n const resolved = resolveProps(node, PROPS_VALUE);\n if (resolved != null) {\n return resolved;\n }\n else {\n throw createUnhandleNodeError(type);\n }\n}\nconst PROPS_MODIFIER = ['m', 'modifier'];\nfunction resolveLinkedModifier(node) {\n return resolveProps(node, PROPS_MODIFIER);\n}\nconst PROPS_KEY = ['k', 'key'];\nfunction resolveLinkedKey(node) {\n const resolved = resolveProps(node, PROPS_KEY);\n if (resolved) {\n return resolved;\n }\n else {\n throw createUnhandleNodeError(6 /* NodeTypes.Linked */);\n }\n}\nfunction resolveProps(node, props, defaultValue) {\n for (let i = 0; i < props.length; i++) {\n const prop = props[i];\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n if (hasOwn(node, prop) && node[prop] != null) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return node[prop];\n }\n }\n return defaultValue;\n}\nconst AST_NODE_PROPS_KEYS = [\n ...PROPS_BODY,\n ...PROPS_CASES,\n ...PROPS_STATIC,\n ...PROPS_ITEMS,\n ...PROPS_KEY,\n ...PROPS_MODIFIER,\n ...PROPS_VALUE,\n ...PROPS_TYPE\n];\nfunction createUnhandleNodeError(type) {\n return new Error(`unhandled node type: ${type}`);\n}\n\nfunction format(ast) {\n const msg = (ctx) => formatParts(ctx, ast);\n return msg;\n}\nfunction formatParts(ctx, ast) {\n const body = resolveBody(ast);\n if (body == null) {\n throw createUnhandleNodeError(0 /* NodeTypes.Resource */);\n }\n const type = resolveType(body);\n if (type === 1 /* NodeTypes.Plural */) {\n const plural = body;\n const cases = resolveCases(plural);\n return ctx.plural(cases.reduce((messages, c) => [\n ...messages,\n formatMessageParts(ctx, c)\n ], []));\n }\n else {\n return formatMessageParts(ctx, body);\n }\n}\nfunction formatMessageParts(ctx, node) {\n const static_ = resolveStatic(node);\n if (static_ != null) {\n return ctx.type === 'text'\n ? static_\n : ctx.normalize([static_]);\n }\n else {\n const messages = resolveItems(node).reduce((acm, c) => [...acm, formatMessagePart(ctx, c)], []);\n return ctx.normalize(messages);\n }\n}\nfunction formatMessagePart(ctx, node) {\n const type = resolveType(node);\n switch (type) {\n case 3 /* NodeTypes.Text */: {\n return resolveValue$1(node, type);\n }\n case 9 /* NodeTypes.Literal */: {\n return resolveValue$1(node, type);\n }\n case 4 /* NodeTypes.Named */: {\n const named = node;\n if (hasOwn(named, 'k') && named.k) {\n return ctx.interpolate(ctx.named(named.k));\n }\n if (hasOwn(named, 'key') && named.key) {\n return ctx.interpolate(ctx.named(named.key));\n }\n throw createUnhandleNodeError(type);\n }\n case 5 /* NodeTypes.List */: {\n const list = node;\n if (hasOwn(list, 'i') && isNumber(list.i)) {\n return ctx.interpolate(ctx.list(list.i));\n }\n if (hasOwn(list, 'index') && isNumber(list.index)) {\n return ctx.interpolate(ctx.list(list.index));\n }\n throw createUnhandleNodeError(type);\n }\n case 6 /* NodeTypes.Linked */: {\n const linked = node;\n const modifier = resolveLinkedModifier(linked);\n const key = resolveLinkedKey(linked);\n return ctx.linked(formatMessagePart(ctx, key), modifier ? formatMessagePart(ctx, modifier) : undefined, ctx.type);\n }\n case 7 /* NodeTypes.LinkedKey */: {\n return resolveValue$1(node, type);\n }\n case 8 /* NodeTypes.LinkedModifier */: {\n return resolveValue$1(node, type);\n }\n default:\n throw new Error(`unhandled node on format message part: ${type}`);\n }\n}\n\nconst WARN_MESSAGE = `Detected HTML in '{source}' message. Recommend not using HTML messages to avoid XSS.`;\nfunction checkHtmlMessage(source, warnHtmlMessage) {\n if (warnHtmlMessage && detectHtmlTag(source)) {\n warn(format$1(WARN_MESSAGE, { source }));\n }\n}\nconst defaultOnCacheKey = (message) => message;\nlet compileCache = create();\nfunction clearCompileCache() {\n compileCache = create();\n}\nfunction baseCompile(message, options = {}) {\n // error detecting on compile\n let detectError = false;\n const onError = options.onError || defaultOnError;\n options.onError = (err) => {\n detectError = true;\n onError(err);\n };\n // compile with mesasge-compiler\n return { ...baseCompile$1(message, options), detectError };\n}\n/* #__NO_SIDE_EFFECTS__ */\nfunction compile(message, context) {\n if ((!__INTLIFY_DROP_MESSAGE_COMPILER__) &&\n isString(message)) {\n // check HTML message\n const warnHtmlMessage = isBoolean(context.warnHtmlMessage)\n ? context.warnHtmlMessage\n : true;\n (process.env.NODE_ENV !== 'production') && checkHtmlMessage(message, warnHtmlMessage);\n // check caches\n const onCacheKey = context.onCacheKey || defaultOnCacheKey;\n const cacheKey = onCacheKey(message);\n const cached = compileCache[cacheKey];\n if (cached) {\n return cached;\n }\n // compile with JIT mode\n const { ast, detectError } = baseCompile(message, {\n ...context,\n location: (process.env.NODE_ENV !== 'production'),\n jit: true\n });\n // compose message function from AST\n const msg = format(ast);\n // if occurred compile error, don't cache\n return !detectError\n ? (compileCache[cacheKey] = msg)\n : msg;\n }\n else {\n if ((process.env.NODE_ENV !== 'production') && !isMessageAST(message)) {\n warn(`the message that is resolve with key '${context.key}' is not supported for jit compilation`);\n return (() => message);\n }\n // AST case (passed from bundler)\n const cacheKey = message.cacheKey;\n if (cacheKey) {\n const cached = compileCache[cacheKey];\n if (cached) {\n return cached;\n }\n // compose message function from message (AST)\n return (compileCache[cacheKey] =\n format(message));\n }\n else {\n return format(message);\n }\n }\n}\n\nlet devtools = null;\nfunction setDevToolsHook(hook) {\n devtools = hook;\n}\nfunction getDevToolsHook() {\n return devtools;\n}\nfunction initI18nDevTools(i18n, version, meta) {\n // TODO: queue if devtools is undefined\n devtools &&\n devtools.emit('i18n:init', {\n timestamp: Date.now(),\n i18n,\n version,\n meta\n });\n}\nconst translateDevTools = \n/* #__PURE__*/ createDevToolsHook('function:translate');\nfunction createDevToolsHook(hook) {\n return (payloads) => devtools && devtools.emit(hook, payloads);\n}\n\nconst CoreErrorCodes = {\n INVALID_ARGUMENT: COMPILE_ERROR_CODES_EXTEND_POINT, // 17\n INVALID_DATE_ARGUMENT: 18,\n INVALID_ISO_DATE_ARGUMENT: 19,\n NOT_SUPPORT_NON_STRING_MESSAGE: 20,\n NOT_SUPPORT_LOCALE_PROMISE_VALUE: 21,\n NOT_SUPPORT_LOCALE_ASYNC_FUNCTION: 22,\n NOT_SUPPORT_LOCALE_TYPE: 23\n};\nconst CORE_ERROR_CODES_EXTEND_POINT = 24;\nfunction createCoreError(code) {\n return createCompileError(code, null, (process.env.NODE_ENV !== 'production') ? { messages: errorMessages } : undefined);\n}\n/** @internal */\nconst errorMessages = {\n [CoreErrorCodes.INVALID_ARGUMENT]: 'Invalid arguments',\n [CoreErrorCodes.INVALID_DATE_ARGUMENT]: 'The date provided is an invalid Date object.' +\n 'Make sure your Date represents a valid date.',\n [CoreErrorCodes.INVALID_ISO_DATE_ARGUMENT]: 'The argument provided is not a valid ISO date string',\n [CoreErrorCodes.NOT_SUPPORT_NON_STRING_MESSAGE]: 'Not support non-string message',\n [CoreErrorCodes.NOT_SUPPORT_LOCALE_PROMISE_VALUE]: 'cannot support promise value',\n [CoreErrorCodes.NOT_SUPPORT_LOCALE_ASYNC_FUNCTION]: 'cannot support async function',\n [CoreErrorCodes.NOT_SUPPORT_LOCALE_TYPE]: 'cannot support locale type'\n};\n\n/** @internal */\nfunction getLocale(context, options) {\n return options.locale != null\n ? resolveLocale(options.locale)\n : resolveLocale(context.locale);\n}\nlet _resolveLocale;\n/** @internal */\nfunction resolveLocale(locale) {\n if (isString(locale)) {\n return locale;\n }\n else {\n if (isFunction(locale)) {\n if (locale.resolvedOnce && _resolveLocale != null) {\n return _resolveLocale;\n }\n else if (locale.constructor.name === 'Function') {\n const resolve = locale();\n if (isPromise(resolve)) {\n throw createCoreError(CoreErrorCodes.NOT_SUPPORT_LOCALE_PROMISE_VALUE);\n }\n return (_resolveLocale = resolve);\n }\n else {\n throw createCoreError(CoreErrorCodes.NOT_SUPPORT_LOCALE_ASYNC_FUNCTION);\n }\n }\n else {\n throw createCoreError(CoreErrorCodes.NOT_SUPPORT_LOCALE_TYPE);\n }\n }\n}\n/**\n * Fallback with simple implemenation\n *\n * @remarks\n * A fallback locale function implemented with a simple fallback algorithm.\n *\n * Basically, it returns the value as specified in the `fallbackLocale` props, and is processed with the fallback inside intlify.\n *\n * @param ctx - A {@link CoreContext | context}\n * @param fallback - A {@link FallbackLocale | fallback locale}\n * @param start - A starting {@link Locale | locale}\n *\n * @returns Fallback locales\n *\n * @VueI18nGeneral\n */\nfunction fallbackWithSimple(ctx, fallback, start) {\n // prettier-ignore\n return [...new Set([\n start,\n ...(isArray(fallback)\n ? fallback\n : isObject(fallback)\n ? Object.keys(fallback)\n : isString(fallback)\n ? [fallback]\n : [start])\n ])];\n}\n/**\n * Fallback with locale chain\n *\n * @remarks\n * A fallback locale function implemented with a fallback chain algorithm. It's used in VueI18n as default.\n *\n * @param ctx - A {@link CoreContext | context}\n * @param fallback - A {@link FallbackLocale | fallback locale}\n * @param start - A starting {@link Locale | locale}\n *\n * @returns Fallback locales\n *\n * @VueI18nSee [Fallbacking](../guide/essentials/fallback)\n *\n * @VueI18nGeneral\n */\nfunction fallbackWithLocaleChain(ctx, fallback, start) {\n const startLocale = isString(start) ? start : DEFAULT_LOCALE;\n const context = ctx;\n if (!context.__localeChainCache) {\n context.__localeChainCache = new Map();\n }\n let chain = context.__localeChainCache.get(startLocale);\n if (!chain) {\n chain = [];\n // first block defined by start\n let block = [start];\n // while any intervening block found\n while (isArray(block)) {\n block = appendBlockToChain(chain, block, fallback);\n }\n // prettier-ignore\n // last block defined by default\n const defaults = isArray(fallback) || !isPlainObject(fallback)\n ? fallback\n : fallback['default']\n ? fallback['default']\n : null;\n // convert defaults to array\n block = isString(defaults) ? [defaults] : defaults;\n if (isArray(block)) {\n appendBlockToChain(chain, block, false);\n }\n context.__localeChainCache.set(startLocale, chain);\n }\n return chain;\n}\nfunction appendBlockToChain(chain, block, blocks) {\n let follow = true;\n for (let i = 0; i < block.length && isBoolean(follow); i++) {\n const locale = block[i];\n if (isString(locale)) {\n follow = appendLocaleToChain(chain, block[i], blocks);\n }\n }\n return follow;\n}\nfunction appendLocaleToChain(chain, locale, blocks) {\n let follow;\n const tokens = locale.split('-');\n do {\n const target = tokens.join('-');\n follow = appendItemToChain(chain, target, blocks);\n tokens.splice(-1, 1);\n } while (tokens.length && follow === true);\n return follow;\n}\nfunction appendItemToChain(chain, target, blocks) {\n let follow = false;\n if (!chain.includes(target)) {\n follow = true;\n if (target) {\n follow = target[target.length - 1] !== '!';\n const locale = target.replace(/!/g, '');\n chain.push(locale);\n if ((isArray(blocks) || isPlainObject(blocks)) &&\n blocks[locale] // eslint-disable-line @typescript-eslint/no-explicit-any\n ) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n follow = blocks[locale];\n }\n }\n }\n return follow;\n}\n\nconst pathStateMachine = [];\npathStateMachine[0 /* States.BEFORE_PATH */] = {\n [\"w\" /* PathCharTypes.WORKSPACE */]: [0 /* States.BEFORE_PATH */],\n [\"i\" /* PathCharTypes.IDENT */]: [3 /* States.IN_IDENT */, 0 /* Actions.APPEND */],\n [\"[\" /* PathCharTypes.LEFT_BRACKET */]: [4 /* States.IN_SUB_PATH */],\n [\"o\" /* PathCharTypes.END_OF_FAIL */]: [7 /* States.AFTER_PATH */]\n};\npathStateMachine[1 /* States.IN_PATH */] = {\n [\"w\" /* PathCharTypes.WORKSPACE */]: [1 /* States.IN_PATH */],\n [\".\" /* PathCharTypes.DOT */]: [2 /* States.BEFORE_IDENT */],\n [\"[\" /* PathCharTypes.LEFT_BRACKET */]: [4 /* States.IN_SUB_PATH */],\n [\"o\" /* PathCharTypes.END_OF_FAIL */]: [7 /* States.AFTER_PATH */]\n};\npathStateMachine[2 /* States.BEFORE_IDENT */] = {\n [\"w\" /* PathCharTypes.WORKSPACE */]: [2 /* States.BEFORE_IDENT */],\n [\"i\" /* PathCharTypes.IDENT */]: [3 /* States.IN_IDENT */, 0 /* Actions.APPEND */],\n [\"0\" /* PathCharTypes.ZERO */]: [3 /* States.IN_IDENT */, 0 /* Actions.APPEND */]\n};\npathStateMachine[3 /* States.IN_IDENT */] = {\n [\"i\" /* PathCharTypes.IDENT */]: [3 /* States.IN_IDENT */, 0 /* Actions.APPEND */],\n [\"0\" /* PathCharTypes.ZERO */]: [3 /* States.IN_IDENT */, 0 /* Actions.APPEND */],\n [\"w\" /* PathCharTypes.WORKSPACE */]: [1 /* States.IN_PATH */, 1 /* Actions.PUSH */],\n [\".\" /* PathCharTypes.DOT */]: [2 /* States.BEFORE_IDENT */, 1 /* Actions.PUSH */],\n [\"[\" /* PathCharTypes.LEFT_BRACKET */]: [4 /* States.IN_SUB_PATH */, 1 /* Actions.PUSH */],\n [\"o\" /* PathCharTypes.END_OF_FAIL */]: [7 /* States.AFTER_PATH */, 1 /* Actions.PUSH */]\n};\npathStateMachine[4 /* States.IN_SUB_PATH */] = {\n [\"'\" /* PathCharTypes.SINGLE_QUOTE */]: [5 /* States.IN_SINGLE_QUOTE */, 0 /* Actions.APPEND */],\n [\"\\\"\" /* PathCharTypes.DOUBLE_QUOTE */]: [6 /* States.IN_DOUBLE_QUOTE */, 0 /* Actions.APPEND */],\n [\"[\" /* PathCharTypes.LEFT_BRACKET */]: [\n 4 /* States.IN_SUB_PATH */,\n 2 /* Actions.INC_SUB_PATH_DEPTH */\n ],\n [\"]\" /* PathCharTypes.RIGHT_BRACKET */]: [1 /* States.IN_PATH */, 3 /* Actions.PUSH_SUB_PATH */],\n [\"o\" /* PathCharTypes.END_OF_FAIL */]: 8 /* States.ERROR */,\n [\"l\" /* PathCharTypes.ELSE */]: [4 /* States.IN_SUB_PATH */, 0 /* Actions.APPEND */]\n};\npathStateMachine[5 /* States.IN_SINGLE_QUOTE */] = {\n [\"'\" /* PathCharTypes.SINGLE_QUOTE */]: [4 /* States.IN_SUB_PATH */, 0 /* Actions.APPEND */],\n [\"o\" /* PathCharTypes.END_OF_FAIL */]: 8 /* States.ERROR */,\n [\"l\" /* PathCharTypes.ELSE */]: [5 /* States.IN_SINGLE_QUOTE */, 0 /* Actions.APPEND */]\n};\npathStateMachine[6 /* States.IN_DOUBLE_QUOTE */] = {\n [\"\\\"\" /* PathCharTypes.DOUBLE_QUOTE */]: [4 /* States.IN_SUB_PATH */, 0 /* Actions.APPEND */],\n [\"o\" /* PathCharTypes.END_OF_FAIL */]: 8 /* States.ERROR */,\n [\"l\" /* PathCharTypes.ELSE */]: [6 /* States.IN_DOUBLE_QUOTE */, 0 /* Actions.APPEND */]\n};\n/**\n * Check if an expression is a literal value.\n */\nconst literalValueRE = /^\\s?(?:true|false|-?[\\d.]+|'[^']*'|\"[^\"]*\")\\s?$/;\nfunction isLiteral(exp) {\n return literalValueRE.test(exp);\n}\n/**\n * Strip quotes from a string\n */\nfunction stripQuotes(str) {\n const a = str.charCodeAt(0);\n const b = str.charCodeAt(str.length - 1);\n return a === b && (a === 0x22 || a === 0x27) ? str.slice(1, -1) : str;\n}\n/**\n * Determine the type of a character in a keypath.\n */\nfunction getPathCharType(ch) {\n if (ch === undefined || ch === null) {\n return \"o\" /* PathCharTypes.END_OF_FAIL */;\n }\n const code = ch.charCodeAt(0);\n switch (code) {\n case 0x5b: // [\n case 0x5d: // ]\n case 0x2e: // .\n case 0x22: // \"\n case 0x27: // '\n return ch;\n case 0x5f: // _\n case 0x24: // $\n case 0x2d: // -\n return \"i\" /* PathCharTypes.IDENT */;\n case 0x09: // Tab (HT)\n case 0x0a: // Newline (LF)\n case 0x0d: // Return (CR)\n case 0xa0: // No-break space (NBSP)\n case 0xfeff: // Byte Order Mark (BOM)\n case 0x2028: // Line Separator (LS)\n case 0x2029: // Paragraph Separator (PS)\n return \"w\" /* PathCharTypes.WORKSPACE */;\n }\n return \"i\" /* PathCharTypes.IDENT */;\n}\n/**\n * Format a subPath, return its plain form if it is\n * a literal string or number. Otherwise prepend the\n * dynamic indicator (*).\n */\nfunction formatSubPath(path) {\n const trimmed = path.trim();\n // invalid leading 0\n if (path.charAt(0) === '0' && isNaN(parseInt(path))) {\n return false;\n }\n return isLiteral(trimmed)\n ? stripQuotes(trimmed)\n : \"*\" /* PathCharTypes.ASTARISK */ + trimmed;\n}\n/**\n * Parse a string path into an array of segments\n */\nfunction parse(path) {\n const keys = [];\n let index = -1;\n let mode = 0 /* States.BEFORE_PATH */;\n let subPathDepth = 0;\n let c;\n let key; // eslint-disable-line\n let newChar;\n let type;\n let transition;\n let action;\n let typeMap;\n const actions = [];\n actions[0 /* Actions.APPEND */] = () => {\n if (key === undefined) {\n key = newChar;\n }\n else {\n key += newChar;\n }\n };\n actions[1 /* Actions.PUSH */] = () => {\n if (key !== undefined) {\n keys.push(key);\n key = undefined;\n }\n };\n actions[2 /* Actions.INC_SUB_PATH_DEPTH */] = () => {\n actions[0 /* Actions.APPEND */]();\n subPathDepth++;\n };\n actions[3 /* Actions.PUSH_SUB_PATH */] = () => {\n if (subPathDepth > 0) {\n subPathDepth--;\n mode = 4 /* States.IN_SUB_PATH */;\n actions[0 /* Actions.APPEND */]();\n }\n else {\n subPathDepth = 0;\n if (key === undefined) {\n return false;\n }\n key = formatSubPath(key);\n if (key === false) {\n return false;\n }\n else {\n actions[1 /* Actions.PUSH */]();\n }\n }\n };\n function maybeUnescapeQuote() {\n const nextChar = path[index + 1];\n if ((mode === 5 /* States.IN_SINGLE_QUOTE */ &&\n nextChar === \"'\" /* PathCharTypes.SINGLE_QUOTE */) ||\n (mode === 6 /* States.IN_DOUBLE_QUOTE */ &&\n nextChar === \"\\\"\" /* PathCharTypes.DOUBLE_QUOTE */)) {\n index++;\n newChar = '\\\\' + nextChar;\n actions[0 /* Actions.APPEND */]();\n return true;\n }\n }\n while (mode !== null) {\n index++;\n c = path[index];\n if (c === '\\\\' && maybeUnescapeQuote()) {\n continue;\n }\n type = getPathCharType(c);\n typeMap = pathStateMachine[mode];\n transition = typeMap[type] || typeMap[\"l\" /* PathCharTypes.ELSE */] || 8 /* States.ERROR */;\n // check parse error\n if (transition === 8 /* States.ERROR */) {\n return;\n }\n mode = transition[0];\n if (transition[1] !== undefined) {\n action = actions[transition[1]];\n if (action) {\n newChar = c;\n if (action() === false) {\n return;\n }\n }\n }\n // check parse finish\n if (mode === 7 /* States.AFTER_PATH */) {\n return keys;\n }\n }\n}\n// path token cache\nconst cache = new Map();\n/**\n * key-value message resolver\n *\n * @remarks\n * Resolves messages with the key-value structure. Note that messages with a hierarchical structure such as objects cannot be resolved\n *\n * @param obj - A target object to be resolved with path\n * @param path - A {@link Path | path} to resolve the value of message\n *\n * @returns A resolved {@link PathValue | path value}\n *\n * @VueI18nGeneral\n */\nfunction resolveWithKeyValue(obj, path) {\n return isObject(obj) ? obj[path] : null;\n}\n/**\n * message resolver\n *\n * @remarks\n * Resolves messages. messages with a hierarchical structure such as objects can be resolved. This resolver is used in VueI18n as default.\n *\n * @param obj - A target object to be resolved with path\n * @param path - A {@link Path | path} to resolve the value of message\n *\n * @returns A resolved {@link PathValue | path value}\n *\n * @VueI18nGeneral\n */\nfunction resolveValue(obj, path) {\n // check object\n if (!isObject(obj)) {\n return null;\n }\n // parse path\n let hit = cache.get(path);\n if (!hit) {\n hit = parse(path);\n if (hit) {\n cache.set(path, hit);\n }\n }\n // check hit\n if (!hit) {\n return null;\n }\n // resolve path value\n const len = hit.length;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any -- for generic object\n let last = obj;\n let i = 0;\n while (i < len) {\n const key = hit[i];\n /**\n * NOTE:\n * if `key` is intlify message format AST node key and `last` is intlify message format AST, skip it.\n * because the AST node is not a key-value structure.\n */\n if (AST_NODE_PROPS_KEYS.includes(key) && isMessageAST(last)) {\n return null;\n }\n if (!isObject(last)) {\n return null;\n }\n if (!hasOwn(last, key)) {\n return null;\n }\n const val = last[key];\n if (val === undefined) {\n return null;\n }\n if (isFunction(last)) {\n return null;\n }\n last = val;\n i++;\n }\n return last;\n}\n\nconst CoreWarnCodes = {\n NOT_FOUND_KEY: 1,\n FALLBACK_TO_TRANSLATE: 2,\n CANNOT_FORMAT_NUMBER: 3,\n FALLBACK_TO_NUMBER_FORMAT: 4,\n CANNOT_FORMAT_DATE: 5,\n FALLBACK_TO_DATE_FORMAT: 6,\n EXPERIMENTAL_CUSTOM_MESSAGE_COMPILER: 7,\n INVALID_NUMBER_ARGUMENT: 8,\n INVALID_DATE_ARGUMENT: 9\n};\nconst CORE_WARN_CODES_EXTEND_POINT = 10;\n/** @internal */\nconst warnMessages = {\n [CoreWarnCodes.NOT_FOUND_KEY]: `Not found '{key}' key in '{locale}' locale messages.`,\n [CoreWarnCodes.FALLBACK_TO_TRANSLATE]: `Fall back to translate '{key}' key with '{target}' locale.`,\n [CoreWarnCodes.CANNOT_FORMAT_NUMBER]: `Cannot format a number value due to not supported Intl.NumberFormat.`,\n [CoreWarnCodes.FALLBACK_TO_NUMBER_FORMAT]: `Fall back to number format '{key}' key with '{target}' locale.`,\n [CoreWarnCodes.CANNOT_FORMAT_DATE]: `Cannot format a date value due to not supported Intl.DateTimeFormat.`,\n [CoreWarnCodes.FALLBACK_TO_DATE_FORMAT]: `Fall back to datetime format '{key}' key with '{target}' locale.`,\n [CoreWarnCodes.EXPERIMENTAL_CUSTOM_MESSAGE_COMPILER]: `This project is using Custom Message Compiler, which is an experimental feature. It may receive breaking changes or be removed in the future.`,\n [CoreWarnCodes.INVALID_NUMBER_ARGUMENT]: `Invalid argument for number formatting: expected a number but received '{value}'.`,\n [CoreWarnCodes.INVALID_DATE_ARGUMENT]: `Invalid argument for datetime formatting: expected a Date, number, or ISO string but received '{value}'.`\n};\nfunction getWarnMessage(code, ...args) {\n return format$1(warnMessages[code], ...args);\n}\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n/**\n * Intlify core-base version\n * @internal\n */\nconst VERSION = '11.3.0';\nconst NOT_REOSLVED = -1;\nconst DEFAULT_LOCALE = 'en-US';\nconst MISSING_RESOLVE_VALUE = '';\nconst capitalize = (str) => `${str.charAt(0).toLocaleUpperCase()}${str.substr(1)}`;\nfunction getDefaultLinkedModifiers() {\n return {\n upper: (val, type) => {\n // prettier-ignore\n return type === 'text' && isString(val)\n ? val.toUpperCase()\n : type === 'vnode' && isObject(val) && '__v_isVNode' in val\n ? val.children.toUpperCase()\n : val;\n },\n lower: (val, type) => {\n // prettier-ignore\n return type === 'text' && isString(val)\n ? val.toLowerCase()\n : type === 'vnode' && isObject(val) && '__v_isVNode' in val\n ? val.children.toLowerCase()\n : val;\n },\n capitalize: (val, type) => {\n // prettier-ignore\n return (type === 'text' && isString(val)\n ? capitalize(val)\n : type === 'vnode' && isObject(val) && '__v_isVNode' in val\n ? capitalize(val.children)\n : val);\n }\n };\n}\nlet _compiler;\nfunction registerMessageCompiler(compiler) {\n _compiler = compiler;\n}\nlet _resolver;\n/**\n * Register the message resolver\n *\n * @param resolver - A {@link MessageResolver} function\n *\n * @VueI18nGeneral\n */\nfunction registerMessageResolver(resolver) {\n _resolver = resolver;\n}\nlet _fallbacker;\n/**\n * Register the locale fallbacker\n *\n * @param fallbacker - A {@link LocaleFallbacker} function\n *\n * @VueI18nGeneral\n */\nfunction registerLocaleFallbacker(fallbacker) {\n _fallbacker = fallbacker;\n}\n// Additional Meta for Intlify DevTools\nlet _additionalMeta = null;\n/* #__NO_SIDE_EFFECTS__ */\nconst setAdditionalMeta = (meta) => {\n _additionalMeta = meta;\n};\n/* #__NO_SIDE_EFFECTS__ */\nconst getAdditionalMeta = () => _additionalMeta;\nlet _fallbackContext = null;\nconst setFallbackContext = (context) => {\n _fallbackContext = context;\n};\nconst getFallbackContext = () => _fallbackContext;\n// ID for CoreContext\nlet _cid = 0;\nfunction createCoreContext(options = {}) {\n // setup options\n const onWarn = isFunction(options.onWarn) ? options.onWarn : warn;\n const version = isString(options.version) ? options.version : VERSION;\n const locale = isString(options.locale) || isFunction(options.locale)\n ? options.locale\n : DEFAULT_LOCALE;\n const _locale = isFunction(locale) ? DEFAULT_LOCALE : locale;\n const fallbackLocale = isArray(options.fallbackLocale) ||\n isPlainObject(options.fallbackLocale) ||\n isString(options.fallbackLocale) ||\n options.fallbackLocale === false\n ? options.fallbackLocale\n : _locale;\n const messages = isPlainObject(options.messages)\n ? options.messages\n : createResources(_locale);\n const datetimeFormats = isPlainObject(options.datetimeFormats)\n ? options.datetimeFormats\n : createResources(_locale)\n ;\n const numberFormats = isPlainObject(options.numberFormats)\n ? options.numberFormats\n : createResources(_locale)\n ;\n const modifiers = assign(create(), options.modifiers, getDefaultLinkedModifiers());\n const pluralRules = options.pluralRules || create();\n const missing = isFunction(options.missing) ? options.missing : null;\n const missingWarn = isBoolean(options.missingWarn) || isRegExp(options.missingWarn)\n ? options.missingWarn\n : true;\n const fallbackWarn = isBoolean(options.fallbackWarn) || isRegExp(options.fallbackWarn)\n ? options.fallbackWarn\n : true;\n const fallbackFormat = !!options.fallbackFormat;\n const unresolving = !!options.unresolving;\n const postTranslation = isFunction(options.postTranslation)\n ? options.postTranslation\n : null;\n const processor = isPlainObject(options.processor) ? options.processor : null;\n const warnHtmlMessage = isBoolean(options.warnHtmlMessage)\n ? options.warnHtmlMessage\n : true;\n const escapeParameter = !!options.escapeParameter;\n const messageCompiler = isFunction(options.messageCompiler)\n ? options.messageCompiler\n : _compiler;\n if ((process.env.NODE_ENV !== 'production') &&\n !false &&\n !false &&\n isFunction(options.messageCompiler)) {\n warnOnce(getWarnMessage(CoreWarnCodes.EXPERIMENTAL_CUSTOM_MESSAGE_COMPILER));\n }\n const messageResolver = isFunction(options.messageResolver)\n ? options.messageResolver\n : _resolver || resolveWithKeyValue;\n const localeFallbacker = isFunction(options.localeFallbacker)\n ? options.localeFallbacker\n : _fallbacker || fallbackWithSimple;\n const fallbackContext = isObject(options.fallbackContext)\n ? options.fallbackContext\n : undefined;\n // setup internal options\n const internalOptions = options;\n const __datetimeFormatters = isObject(internalOptions.__datetimeFormatters)\n ? internalOptions.__datetimeFormatters\n : new Map()\n ;\n const __numberFormatters = isObject(internalOptions.__numberFormatters)\n ? internalOptions.__numberFormatters\n : new Map()\n ;\n const __meta = isObject(internalOptions.__meta) ? internalOptions.__meta : {};\n _cid++;\n const context = {\n version,\n cid: _cid,\n locale,\n fallbackLocale,\n messages,\n modifiers,\n pluralRules,\n missing,\n missingWarn,\n fallbackWarn,\n fallbackFormat,\n unresolving,\n postTranslation,\n processor,\n warnHtmlMessage,\n escapeParameter,\n messageCompiler,\n messageResolver,\n localeFallbacker,\n fallbackContext,\n onWarn,\n __meta\n };\n {\n context.datetimeFormats = datetimeFormats;\n context.numberFormats = numberFormats;\n context.__datetimeFormatters = __datetimeFormatters;\n context.__numberFormatters = __numberFormatters;\n }\n // for vue-devtools timeline event\n if ((process.env.NODE_ENV !== 'production')) {\n context.__v_emitter =\n internalOptions.__v_emitter != null\n ? internalOptions.__v_emitter\n : undefined;\n }\n // NOTE: experimental !!\n if ((process.env.NODE_ENV !== 'production') || __INTLIFY_PROD_DEVTOOLS__) {\n initI18nDevTools(context, version, __meta);\n }\n return context;\n}\nconst createResources = (locale) => ({ [locale]: create() });\n/** @internal */\nfunction isTranslateFallbackWarn(fallback, key) {\n return fallback instanceof RegExp ? fallback.test(key) : fallback;\n}\n/** @internal */\nfunction isTranslateMissingWarn(missing, key) {\n return missing instanceof RegExp ? missing.test(key) : missing;\n}\n/** @internal */\nfunction handleMissing(context, key, locale, missingWarn, type) {\n const { missing, onWarn } = context;\n // for vue-devtools timeline event\n if ((process.env.NODE_ENV !== 'production')) {\n const emitter = context.__v_emitter;\n if (emitter) {\n emitter.emit('missing', {\n locale,\n key,\n type,\n groupId: `${type}:${key}`\n });\n }\n }\n if (missing !== null) {\n const ret = missing(context, locale, key, type);\n return isString(ret) ? ret : key;\n }\n else {\n if ((process.env.NODE_ENV !== 'production') && isTranslateMissingWarn(missingWarn, key)) {\n onWarn(getWarnMessage(CoreWarnCodes.NOT_FOUND_KEY, { key, locale }));\n }\n return key;\n }\n}\n/** @internal */\nfunction updateFallbackLocale(ctx, locale, fallback) {\n const context = ctx;\n context.__localeChainCache = new Map();\n ctx.localeFallbacker(ctx, fallback, locale);\n}\n/** @internal */\nfunction isAlmostSameLocale(locale, compareLocale) {\n if (locale === compareLocale)\n return false;\n return locale.split('-')[0] === compareLocale.split('-')[0];\n}\n/** @internal */\nfunction isImplicitFallback(targetLocale, locales) {\n const index = locales.indexOf(targetLocale);\n if (index === -1) {\n return false;\n }\n for (let i = index + 1; i < locales.length; i++) {\n if (isAlmostSameLocale(targetLocale, locales[i])) {\n return true;\n }\n }\n return false;\n}\n/* eslint-enable @typescript-eslint/no-explicit-any */\n\nconst intlDefined = typeof Intl !== 'undefined';\nconst Availabilities = {\n dateTimeFormat: intlDefined && typeof Intl.DateTimeFormat !== 'undefined',\n numberFormat: intlDefined && typeof Intl.NumberFormat !== 'undefined'\n};\n\n// implementation of `datetime` function\nfunction datetime(context, ...args) {\n const { datetimeFormats, unresolving, fallbackLocale, onWarn, localeFallbacker } = context;\n const { __datetimeFormatters } = context;\n if ((process.env.NODE_ENV !== 'production') && !Availabilities.dateTimeFormat) {\n onWarn(getWarnMessage(CoreWarnCodes.CANNOT_FORMAT_DATE));\n return MISSING_RESOLVE_VALUE;\n }\n if (!isString(args[0]) && !isDate(args[0]) && !isNumber(args[0])) {\n if ((process.env.NODE_ENV !== 'production')) {\n onWarn(getWarnMessage(CoreWarnCodes.INVALID_DATE_ARGUMENT, {\n value: String(args[0])\n }));\n }\n return MISSING_RESOLVE_VALUE;\n }\n const [key, value, options, overrides] = parseDateTimeArgs(...args);\n const missingWarn = isBoolean(options.missingWarn)\n ? options.missingWarn\n : context.missingWarn;\n const fallbackWarn = isBoolean(options.fallbackWarn)\n ? options.fallbackWarn\n : context.fallbackWarn;\n const part = !!options.part;\n const locale = getLocale(context, options);\n const locales = localeFallbacker(context, // eslint-disable-line @typescript-eslint/no-explicit-any\n fallbackLocale, locale);\n if (!isString(key) || key === '') {\n return new Intl.DateTimeFormat(locale.replace(/!/g, ''), overrides).format(value);\n }\n // resolve format\n let datetimeFormat = {};\n let targetLocale;\n let format = null;\n let from = locale;\n let to = null;\n const type = 'datetime format';\n for (let i = 0; i < locales.length; i++) {\n targetLocale = to = locales[i];\n if ((process.env.NODE_ENV !== 'production') &&\n locale !== targetLocale &&\n isTranslateFallbackWarn(fallbackWarn, key)) {\n onWarn(getWarnMessage(CoreWarnCodes.FALLBACK_TO_DATE_FORMAT, {\n key,\n target: targetLocale\n }));\n }\n // for vue-devtools timeline event\n if ((process.env.NODE_ENV !== 'production') && locale !== targetLocale) {\n const emitter = context.__v_emitter;\n if (emitter) {\n emitter.emit('fallback', {\n type,\n key,\n from,\n to,\n groupId: `${type}:${key}`\n });\n }\n }\n datetimeFormat =\n datetimeFormats[targetLocale] || {};\n format = datetimeFormat[key];\n if (isPlainObject(format))\n break;\n handleMissing(context, key, targetLocale, missingWarn, type); // eslint-disable-line @typescript-eslint/no-explicit-any\n from = to;\n }\n // checking format and target locale\n if (!isPlainObject(format) || !isString(targetLocale)) {\n return unresolving ? NOT_REOSLVED : key;\n }\n let id = `${targetLocale}__${key}`;\n if (!isEmptyObject(overrides)) {\n id = `${id}__${JSON.stringify(overrides)}`;\n }\n let formatter = __datetimeFormatters.get(id);\n if (!formatter) {\n formatter = new Intl.DateTimeFormat(targetLocale, assign({}, format, overrides));\n __datetimeFormatters.set(id, formatter);\n }\n return !part ? formatter.format(value) : formatter.formatToParts(value);\n}\n/** @internal */\nconst DATETIME_FORMAT_OPTIONS_KEYS = [\n 'localeMatcher',\n 'weekday',\n 'era',\n 'year',\n 'month',\n 'day',\n 'hour',\n 'minute',\n 'second',\n 'timeZoneName',\n 'formatMatcher',\n 'hour12',\n 'timeZone',\n 'dateStyle',\n 'timeStyle',\n 'calendar',\n 'dayPeriod',\n 'numberingSystem',\n 'hourCycle',\n 'fractionalSecondDigits'\n];\n/** @internal */\nfunction parseDateTimeArgs(...args) {\n const [arg1, arg2, arg3, arg4] = args;\n const options = create();\n let overrides = create();\n let value;\n if (isString(arg1)) {\n // Only allow ISO strings - other date formats are often supported,\n // but may cause different results in different browsers.\n const matches = arg1.match(/(\\d{4}-\\d{2}-\\d{2})(T|\\s)?(.*)/);\n if (!matches) {\n throw createCoreError(CoreErrorCodes.INVALID_ISO_DATE_ARGUMENT);\n }\n // Some browsers can not parse the iso datetime separated by space,\n // this is a compromise solution by replace the 'T'/' ' with 'T'\n const dateTime = matches[3]\n ? matches[3].trim().startsWith('T')\n ? `${matches[1].trim()}${matches[3].trim()}`\n : `${matches[1].trim()}T${matches[3].trim()}`\n : matches[1].trim();\n value = new Date(dateTime);\n try {\n // This will fail if the date is not valid\n value.toISOString();\n }\n catch {\n throw createCoreError(CoreErrorCodes.INVALID_ISO_DATE_ARGUMENT);\n }\n }\n else if (isDate(arg1)) {\n if (isNaN(arg1.getTime())) {\n throw createCoreError(CoreErrorCodes.INVALID_DATE_ARGUMENT);\n }\n value = arg1;\n }\n else if (isNumber(arg1)) {\n value = arg1;\n }\n else {\n throw createCoreError(CoreErrorCodes.INVALID_ARGUMENT);\n }\n if (isString(arg2)) {\n options.key = arg2;\n }\n else if (isPlainObject(arg2)) {\n Object.keys(arg2).forEach(key => {\n if (DATETIME_FORMAT_OPTIONS_KEYS.includes(key)) {\n overrides[key] = arg2[key];\n }\n else {\n options[key] = arg2[key];\n }\n });\n }\n if (isString(arg3)) {\n options.locale = arg3;\n }\n else if (isPlainObject(arg3)) {\n overrides = arg3;\n }\n if (isPlainObject(arg4)) {\n overrides = arg4;\n }\n return [options.key || '', value, options, overrides];\n}\n/** @internal */\nfunction clearDateTimeFormat(ctx, locale, format) {\n const context = ctx;\n for (const key in format) {\n const id = `${locale}__${key}`;\n if (!context.__datetimeFormatters.has(id)) {\n continue;\n }\n context.__datetimeFormatters.delete(id);\n }\n}\n\n// implementation of `number` function\nfunction number(context, ...args) {\n const { numberFormats, unresolving, fallbackLocale, onWarn, localeFallbacker } = context;\n const { __numberFormatters } = context;\n if ((process.env.NODE_ENV !== 'production') && !Availabilities.numberFormat) {\n onWarn(getWarnMessage(CoreWarnCodes.CANNOT_FORMAT_NUMBER));\n return MISSING_RESOLVE_VALUE;\n }\n if (!isNumber(args[0])) {\n if ((process.env.NODE_ENV !== 'production')) {\n onWarn(getWarnMessage(CoreWarnCodes.INVALID_NUMBER_ARGUMENT, {\n value: String(args[0])\n }));\n }\n return MISSING_RESOLVE_VALUE;\n }\n const [key, value, options, overrides] = parseNumberArgs(...args);\n const missingWarn = isBoolean(options.missingWarn)\n ? options.missingWarn\n : context.missingWarn;\n const fallbackWarn = isBoolean(options.fallbackWarn)\n ? options.fallbackWarn\n : context.fallbackWarn;\n const part = !!options.part;\n const locale = getLocale(context, options);\n const locales = localeFallbacker(context, // eslint-disable-line @typescript-eslint/no-explicit-any\n fallbackLocale, locale);\n if (!isString(key) || key === '') {\n return new Intl.NumberFormat(locale.replace(/!/g, ''), overrides).format(value);\n }\n // resolve format\n let numberFormat = {};\n let targetLocale;\n let format = null;\n let from = locale;\n let to = null;\n const type = 'number format';\n for (let i = 0; i < locales.length; i++) {\n targetLocale = to = locales[i];\n if ((process.env.NODE_ENV !== 'production') &&\n locale !== targetLocale &&\n isTranslateFallbackWarn(fallbackWarn, key)) {\n onWarn(getWarnMessage(CoreWarnCodes.FALLBACK_TO_NUMBER_FORMAT, {\n key,\n target: targetLocale\n }));\n }\n // for vue-devtools timeline event\n if ((process.env.NODE_ENV !== 'production') && locale !== targetLocale) {\n const emitter = context.__v_emitter;\n if (emitter) {\n emitter.emit('fallback', {\n type,\n key,\n from,\n to,\n groupId: `${type}:${key}`\n });\n }\n }\n numberFormat =\n numberFormats[targetLocale] || {};\n format = numberFormat[key];\n if (isPlainObject(format))\n break;\n handleMissing(context, key, targetLocale, missingWarn, type); // eslint-disable-line @typescript-eslint/no-explicit-any\n from = to;\n }\n // checking format and target locale\n if (!isPlainObject(format) || !isString(targetLocale)) {\n return unresolving ? NOT_REOSLVED : key;\n }\n let id = `${targetLocale}__${key}`;\n if (!isEmptyObject(overrides)) {\n id = `${id}__${JSON.stringify(overrides)}`;\n }\n let formatter = __numberFormatters.get(id);\n if (!formatter) {\n formatter = new Intl.NumberFormat(targetLocale, assign({}, format, overrides));\n __numberFormatters.set(id, formatter);\n }\n return !part ? formatter.format(value) : formatter.formatToParts(value);\n}\n/** @internal */\nconst NUMBER_FORMAT_OPTIONS_KEYS = [\n 'localeMatcher',\n 'style',\n 'currency',\n 'currencyDisplay',\n 'currencySign',\n 'useGrouping',\n 'minimumIntegerDigits',\n 'minimumFractionDigits',\n 'maximumFractionDigits',\n 'minimumSignificantDigits',\n 'maximumSignificantDigits',\n 'compactDisplay',\n 'notation',\n 'signDisplay',\n 'unit',\n 'unitDisplay',\n 'roundingMode',\n 'roundingPriority',\n 'roundingIncrement',\n 'trailingZeroDisplay'\n];\n/** @internal */\nfunction parseNumberArgs(...args) {\n const [arg1, arg2, arg3, arg4] = args;\n const options = create();\n let overrides = create();\n if (!isNumber(arg1)) {\n throw createCoreError(CoreErrorCodes.INVALID_ARGUMENT);\n }\n const value = arg1;\n if (isString(arg2)) {\n options.key = arg2;\n }\n else if (isPlainObject(arg2)) {\n Object.keys(arg2).forEach(key => {\n if (NUMBER_FORMAT_OPTIONS_KEYS.includes(key)) {\n overrides[key] = arg2[key];\n }\n else {\n options[key] = arg2[key];\n }\n });\n }\n if (isString(arg3)) {\n options.locale = arg3;\n }\n else if (isPlainObject(arg3)) {\n overrides = arg3;\n }\n if (isPlainObject(arg4)) {\n overrides = arg4;\n }\n return [options.key || '', value, options, overrides];\n}\n/** @internal */\nfunction clearNumberFormat(ctx, locale, format) {\n const context = ctx;\n for (const key in format) {\n const id = `${locale}__${key}`;\n if (!context.__numberFormatters.has(id)) {\n continue;\n }\n context.__numberFormatters.delete(id);\n }\n}\n\nconst DEFAULT_MODIFIER = (str) => str;\nconst DEFAULT_MESSAGE = (ctx) => ''; // eslint-disable-line\nconst DEFAULT_MESSAGE_DATA_TYPE = 'text';\nconst DEFAULT_NORMALIZE = (values) => values.length === 0 ? '' : join(values);\nconst DEFAULT_INTERPOLATE = toDisplayString;\nfunction pluralDefault(choice, choicesLength) {\n choice = Math.abs(choice);\n // singular (0) | plural (1)\n if (choicesLength === 2) {\n // prettier-ignore\n return choice === 1\n ? 0\n : 1;\n }\n // zero (0) | singular (1) | plural (2)\n return Math.min(choice, 2);\n}\nfunction getPluralIndex(options) {\n // prettier-ignore\n const index = isNumber(options.pluralIndex)\n ? options.pluralIndex\n : -1;\n return isNumber(options.named?.count)\n ? options.named.count\n : isNumber(options.named?.n)\n ? options.named.n\n : index;\n}\nfunction createMessageContext(options = {}) {\n const locale = options.locale;\n const pluralIndex = getPluralIndex(options);\n const pluralRule = isString(locale) && isFunction(options.pluralRules?.[locale])\n ? options.pluralRules[locale]\n : pluralDefault;\n const orgPluralRule = pluralRule === pluralDefault ? undefined : pluralDefault;\n const plural = (messages) => messages[pluralRule(pluralIndex, messages.length, orgPluralRule)];\n const _list = options.list || [];\n const list = (index) => _list[index];\n const _named = options.named || create(); // eslint-disable-line @typescript-eslint/no-explicit-any\n // normalize named\n if (isNumber(options.pluralIndex)) {\n _named.count ||= options.pluralIndex;\n _named.n ||= options.pluralIndex;\n }\n const named = (key) => _named[key];\n function message(key, useLinked) {\n // prettier-ignore\n const msg = isFunction(options.messages)\n ? options.messages(key, !!useLinked)\n : isObject(options.messages)\n ? options.messages[key]\n : false;\n return !msg\n ? options.parent\n ? options.parent.message(key) // resolve from parent messages\n : DEFAULT_MESSAGE\n : msg;\n }\n const _modifier = (name) => options.modifiers\n ? options.modifiers[name]\n : DEFAULT_MODIFIER;\n const normalize = isFunction(options.processor?.normalize)\n ? options.processor.normalize\n : DEFAULT_NORMALIZE;\n const interpolate = isFunction(options.processor?.interpolate)\n ? options.processor.interpolate\n : DEFAULT_INTERPOLATE;\n const type = isString(options.processor?.type)\n ? options.processor.type\n : DEFAULT_MESSAGE_DATA_TYPE;\n const linked = (key, ...args) => {\n const [arg1, arg2] = args;\n let type = 'text';\n let modifier = '';\n if (args.length === 1) {\n if (isObject(arg1)) {\n modifier = arg1.modifier || modifier;\n type = arg1.type || type;\n }\n else if (isString(arg1)) {\n modifier = arg1 || modifier;\n }\n }\n else if (args.length === 2) {\n if (isString(arg1)) {\n modifier = arg1 || modifier;\n }\n if (isString(arg2)) {\n type = arg2 || type;\n }\n }\n const ret = message(key, true)(ctx);\n // If the linked message is not resolved (empty string), fall back to the key itself\n const resolved = ret === '' || ret === undefined ? key : ret;\n const msg = \n // The message in vnode resolved with linked are returned as an array by processor.nomalize\n type === 'vnode' && isArray(resolved) && modifier\n ? resolved[0]\n : resolved;\n return modifier ? _modifier(modifier)(msg, type) : msg;\n };\n const ctx = {\n [\"list\" /* HelperNameMap.LIST */]: list,\n [\"named\" /* HelperNameMap.NAMED */]: named,\n [\"plural\" /* HelperNameMap.PLURAL */]: plural,\n [\"linked\" /* HelperNameMap.LINKED */]: linked,\n [\"message\" /* HelperNameMap.MESSAGE */]: message,\n [\"type\" /* HelperNameMap.TYPE */]: type,\n [\"interpolate\" /* HelperNameMap.INTERPOLATE */]: interpolate,\n [\"normalize\" /* HelperNameMap.NORMALIZE */]: normalize,\n [\"values\" /* HelperNameMap.VALUES */]: assign(create(), _list, _named)\n };\n return ctx;\n}\n\nconst NOOP_MESSAGE_FUNCTION = () => '';\nconst isMessageFunction = (val) => isFunction(val);\n// implementation of `translate` function\nfunction translate(context, ...args) {\n const { fallbackFormat, postTranslation, unresolving, messageCompiler, fallbackLocale, messages } = context;\n const [key, options] = parseTranslateArgs(...args);\n const missingWarn = isBoolean(options.missingWarn)\n ? options.missingWarn\n : context.missingWarn;\n const fallbackWarn = isBoolean(options.fallbackWarn)\n ? options.fallbackWarn\n : context.fallbackWarn;\n const escapeParameter = isBoolean(options.escapeParameter)\n ? options.escapeParameter\n : context.escapeParameter;\n const resolvedMessage = !!options.resolvedMessage;\n // prettier-ignore\n const defaultMsgOrKey = isString(options.default) || isBoolean(options.default) // default by function option\n ? !isBoolean(options.default)\n ? options.default\n : (!messageCompiler ? () => key : key)\n : fallbackFormat // default by `fallbackFormat` option\n ? (!messageCompiler ? () => key : key)\n : null;\n const enableDefaultMsg = fallbackFormat ||\n (defaultMsgOrKey != null &&\n (isString(defaultMsgOrKey) || isFunction(defaultMsgOrKey)));\n const locale = getLocale(context, options);\n // escape params\n escapeParameter && escapeParams(options);\n // resolve message format\n // eslint-disable-next-line prefer-const\n let [formatScope, targetLocale, message] = !resolvedMessage\n ? resolveMessageFormat(context, key, locale, fallbackLocale, fallbackWarn, missingWarn)\n : [\n key,\n locale,\n messages[locale] || create()\n ];\n // NOTE:\n // Fix to work around `ssrTransfrom` bug in Vite.\n // https://github.com/vitejs/vite/issues/4306\n // To get around this, use temporary variables.\n // https://github.com/nuxt/framework/issues/1461#issuecomment-954606243\n let format = formatScope;\n // if you use default message, set it as message format!\n let cacheBaseKey = key;\n if (!resolvedMessage &&\n !(isString(format) ||\n isMessageAST(format) ||\n isMessageFunction(format))) {\n if (enableDefaultMsg) {\n format = defaultMsgOrKey;\n cacheBaseKey = format;\n }\n }\n // checking message format and target locale\n if (!resolvedMessage &&\n (!(isString(format) ||\n isMessageAST(format) ||\n isMessageFunction(format)) ||\n !isString(targetLocale))) {\n return unresolving ? NOT_REOSLVED : key;\n }\n // TODO: refactor\n if ((process.env.NODE_ENV !== 'production') && isString(format) && context.messageCompiler == null) {\n warn(`The message format compilation is not supported in this build. ` +\n `Because message compiler isn't included. ` +\n `You need to pre-compilation all message format. ` +\n `So translate function return '${key}'.`);\n return key;\n }\n // setup compile error detecting\n let occurred = false;\n const onError = () => {\n occurred = true;\n };\n // compile message format\n const msg = !isMessageFunction(format)\n ? compileMessageFormat(context, key, targetLocale, format, cacheBaseKey, onError)\n : format;\n // if occurred compile error, return the message format\n if (occurred) {\n return format;\n }\n // evaluate message with context\n const ctxOptions = getMessageContextOptions(context, targetLocale, message, options);\n const msgContext = createMessageContext(ctxOptions);\n const messaged = evaluateMessage(context, msg, msgContext);\n // if use post translation option, proceed it with handler\n let ret = postTranslation\n ? postTranslation(messaged, key)\n : messaged;\n // apply HTML sanitization for security\n if (escapeParameter && isString(ret)) {\n ret = sanitizeTranslatedHtml(ret);\n }\n // NOTE: experimental !!\n if ((process.env.NODE_ENV !== 'production') || __INTLIFY_PROD_DEVTOOLS__) {\n // prettier-ignore\n const payloads = {\n timestamp: Date.now(),\n key: isString(key)\n ? key\n : isMessageFunction(format)\n ? format.key\n : '',\n locale: targetLocale || (isMessageFunction(format)\n ? format.locale\n : ''),\n format: isString(format)\n ? format\n : isMessageFunction(format)\n ? format.source\n : '',\n message: ret\n };\n payloads.meta = assign({}, context.__meta, getAdditionalMeta() || {});\n translateDevTools(payloads);\n }\n return ret;\n}\nfunction escapeParams(options) {\n if (isArray(options.list)) {\n options.list = options.list.map(item => isString(item) ? escapeHtml(item) : item);\n }\n else if (isObject(options.named)) {\n Object.keys(options.named).forEach(key => {\n if (isString(options.named[key])) {\n options.named[key] = escapeHtml(options.named[key]);\n }\n });\n }\n}\nfunction resolveMessageFormat(context, key, locale, fallbackLocale, fallbackWarn, missingWarn) {\n const { messages, onWarn, messageResolver: resolveValue, localeFallbacker } = context;\n const locales = localeFallbacker(context, fallbackLocale, locale); // eslint-disable-line @typescript-eslint/no-explicit-any\n let message = create();\n let targetLocale;\n let format = null;\n let from = locale;\n let to = null;\n const type = 'translate';\n for (let i = 0; i < locales.length; i++) {\n targetLocale = to = locales[i];\n if ((process.env.NODE_ENV !== 'production') &&\n locale !== targetLocale &&\n !isAlmostSameLocale(locale, targetLocale) &&\n isTranslateFallbackWarn(fallbackWarn, key)) {\n onWarn(getWarnMessage(CoreWarnCodes.FALLBACK_TO_TRANSLATE, {\n key,\n target: targetLocale\n }));\n }\n // for vue-devtools timeline event\n if ((process.env.NODE_ENV !== 'production') && locale !== targetLocale) {\n const emitter = context.__v_emitter;\n if (emitter) {\n emitter.emit('fallback', {\n type,\n key,\n from,\n to,\n groupId: `${type}:${key}`\n });\n }\n }\n message =\n messages[targetLocale] || create();\n // for vue-devtools timeline event\n let start = null;\n let startTag;\n let endTag;\n if ((process.env.NODE_ENV !== 'production') && inBrowser) {\n start = window.performance.now();\n startTag = 'intlify-message-resolve-start';\n endTag = 'intlify-message-resolve-end';\n mark && mark(startTag);\n }\n if ((format = resolveValue(message, key)) === null) {\n // if null, resolve with object key path\n format = message[key]; // eslint-disable-line @typescript-eslint/no-explicit-any\n }\n // for vue-devtools timeline event\n if ((process.env.NODE_ENV !== 'production') && inBrowser) {\n const end = window.performance.now();\n const emitter = context.__v_emitter;\n if (emitter && start && format) {\n emitter.emit('message-resolve', {\n type: 'message-resolve',\n key,\n message: format,\n time: end - start,\n groupId: `${type}:${key}`\n });\n }\n if (startTag && endTag && mark && measure) {\n mark(endTag);\n measure('intlify message resolve', startTag, endTag);\n }\n }\n if (isString(format) || isMessageAST(format) || isMessageFunction(format)) {\n break;\n }\n if (!isImplicitFallback(targetLocale, locales)) {\n const missingRet = handleMissing(context, // eslint-disable-line @typescript-eslint/no-explicit-any\n key, targetLocale, missingWarn, type);\n if (missingRet !== key) {\n format = missingRet;\n }\n }\n from = to;\n }\n return [format, targetLocale, message];\n}\nfunction compileMessageFormat(context, key, targetLocale, format, cacheBaseKey, onError) {\n const { messageCompiler, warnHtmlMessage } = context;\n if (isMessageFunction(format)) {\n const msg = format;\n msg.locale = msg.locale || targetLocale;\n msg.key = msg.key || key;\n return msg;\n }\n if (messageCompiler == null) {\n const msg = (() => format);\n msg.locale = targetLocale;\n msg.key = key;\n return msg;\n }\n // for vue-devtools timeline event\n let start = null;\n let startTag;\n let endTag;\n if ((process.env.NODE_ENV !== 'production') && inBrowser) {\n start = window.performance.now();\n startTag = 'intlify-message-compilation-start';\n endTag = 'intlify-message-compilation-end';\n mark && mark(startTag);\n }\n const msg = messageCompiler(format, getCompileContext(context, targetLocale, cacheBaseKey, format, warnHtmlMessage, onError));\n // for vue-devtools timeline event\n if ((process.env.NODE_ENV !== 'production') && inBrowser) {\n const end = window.performance.now();\n const emitter = context.__v_emitter;\n if (emitter && start) {\n emitter.emit('message-compilation', {\n type: 'message-compilation',\n message: format,\n time: end - start,\n groupId: `${'translate'}:${key}`\n });\n }\n if (startTag && endTag && mark && measure) {\n mark(endTag);\n measure('intlify message compilation', startTag, endTag);\n }\n }\n msg.locale = targetLocale;\n msg.key = key;\n msg.source = format;\n return msg;\n}\nfunction evaluateMessage(context, msg, msgCtx) {\n // for vue-devtools timeline event\n let start = null;\n let startTag;\n let endTag;\n if ((process.env.NODE_ENV !== 'production') && inBrowser) {\n start = window.performance.now();\n startTag = 'intlify-message-evaluation-start';\n endTag = 'intlify-message-evaluation-end';\n mark && mark(startTag);\n }\n const messaged = msg(msgCtx);\n // for vue-devtools timeline event\n if ((process.env.NODE_ENV !== 'production') && inBrowser) {\n const end = window.performance.now();\n const emitter = context.__v_emitter;\n if (emitter && start) {\n emitter.emit('message-evaluation', {\n type: 'message-evaluation',\n value: messaged,\n time: end - start,\n groupId: `${'translate'}:${msg.key}`\n });\n }\n if (startTag && endTag && mark && measure) {\n mark(endTag);\n measure('intlify message evaluation', startTag, endTag);\n }\n }\n return messaged;\n}\n/** @internal */\nfunction parseTranslateArgs(...args) {\n const [arg1, arg2, arg3] = args;\n const options = create();\n if (!isString(arg1) &&\n !isNumber(arg1) &&\n !isMessageFunction(arg1) &&\n !isMessageAST(arg1)) {\n throw createCoreError(CoreErrorCodes.INVALID_ARGUMENT);\n }\n // prettier-ignore\n const key = isNumber(arg1)\n ? String(arg1)\n : isMessageFunction(arg1)\n ? arg1\n : arg1;\n if (isNumber(arg2)) {\n options.plural = arg2;\n }\n else if (isString(arg2)) {\n options.default = arg2;\n }\n else if (isPlainObject(arg2) && !isEmptyObject(arg2)) {\n options.named = arg2;\n }\n else if (isArray(arg2)) {\n options.list = arg2;\n }\n if (isNumber(arg3)) {\n options.plural = arg3;\n }\n else if (isString(arg3)) {\n options.default = arg3;\n }\n else if (isPlainObject(arg3)) {\n assign(options, arg3);\n }\n return [key, options];\n}\nfunction getCompileContext(context, locale, key, source, warnHtmlMessage, onError) {\n return {\n locale,\n key,\n warnHtmlMessage,\n onError: (err) => {\n onError && onError(err);\n if ((process.env.NODE_ENV !== 'production')) {\n const _source = getSourceForCodeFrame(source);\n const codeFrame = err.location &&\n _source &&\n generateCodeFrame(_source, err.location.start.offset, err.location.end.offset);\n const emitter = context.__v_emitter;\n if (emitter && _source) {\n emitter.emit('compile-error', {\n message: _source,\n error: err.message,\n start: err.location && err.location.start.offset,\n end: err.location && err.location.end.offset,\n groupId: `${'translate'}:${key}`\n });\n }\n const message = `Message compilation error: ${err.message}`;\n throw new SyntaxError(codeFrame ? `${message}\\n${codeFrame}` : message);\n }\n throw err;\n },\n onCacheKey: (source) => generateFormatCacheKey(locale, key, source)\n };\n}\nfunction getSourceForCodeFrame(source) {\n if (isString(source)) {\n return source;\n }\n else {\n if (source.loc && source.loc.source) {\n return source.loc.source;\n }\n }\n}\nfunction getMessageContextOptions(context, locale, message, options) {\n const { modifiers, pluralRules, messageResolver: resolveValue, fallbackLocale, fallbackWarn, missingWarn, fallbackContext } = context;\n const resolveMessage = (key, useLinked) => {\n let val = resolveValue(message, key);\n // fallback\n if (val == null && (fallbackContext || useLinked)) {\n const [, , message] = resolveMessageFormat(fallbackContext || context, // NOTE: if has fallbackContext, fallback to root, else if use linked, fallback to local context\n key, locale, fallbackLocale, fallbackWarn, missingWarn);\n val = resolveValue(message, key);\n }\n if (isString(val) || isMessageAST(val)) {\n let occurred = false;\n const onError = () => {\n occurred = true;\n };\n const msg = compileMessageFormat(context, key, locale, val, key, onError);\n return !occurred\n ? msg\n : NOOP_MESSAGE_FUNCTION;\n }\n else if (isMessageFunction(val)) {\n return val;\n }\n else {\n // TODO: should be implemented warning message\n return NOOP_MESSAGE_FUNCTION;\n }\n };\n const ctxOptions = {\n locale,\n modifiers,\n pluralRules,\n messages: resolveMessage\n };\n if (context.processor) {\n ctxOptions.processor = context.processor;\n }\n if (options.list) {\n ctxOptions.list = options.list;\n }\n if (options.named) {\n ctxOptions.named = options.named;\n }\n if (isNumber(options.plural)) {\n ctxOptions.pluralIndex = options.plural;\n }\n return ctxOptions;\n}\n\n{\n initFeatureFlags();\n}\n\nexport { AST_NODE_PROPS_KEYS, CORE_ERROR_CODES_EXTEND_POINT, CORE_WARN_CODES_EXTEND_POINT, CoreErrorCodes, CoreWarnCodes, DATETIME_FORMAT_OPTIONS_KEYS, DEFAULT_LOCALE, DEFAULT_MESSAGE_DATA_TYPE, MISSING_RESOLVE_VALUE, NOT_REOSLVED, NUMBER_FORMAT_OPTIONS_KEYS, VERSION, clearCompileCache, clearDateTimeFormat, clearNumberFormat, compile, createCoreContext, createCoreError, createMessageContext, datetime, fallbackWithLocaleChain, fallbackWithSimple, getAdditionalMeta, getDevToolsHook, getFallbackContext, getLocale, getWarnMessage, handleMissing, initI18nDevTools, isAlmostSameLocale, isImplicitFallback, isMessageAST, isMessageFunction, isTranslateFallbackWarn, isTranslateMissingWarn, number, parse, parseDateTimeArgs, parseNumberArgs, parseTranslateArgs, registerLocaleFallbacker, registerMessageCompiler, registerMessageResolver, resolveLocale, resolveValue, resolveWithKeyValue, setAdditionalMeta, setDevToolsHook, setFallbackContext, translate, translateDevTools, updateFallbackLocale };\n","/*!\n * vue-i18n v11.3.0\n * (c) 2026 kazuya kawaguchi\n * Released under the MIT License.\n */\nimport { CORE_ERROR_CODES_EXTEND_POINT, createCompileError, CORE_WARN_CODES_EXTEND_POINT, isMessageAST, AST_NODE_PROPS_KEYS, DEFAULT_LOCALE, updateFallbackLocale, setFallbackContext, createCoreContext, clearDateTimeFormat, clearNumberFormat, setAdditionalMeta, getFallbackContext, NOT_REOSLVED, isTranslateFallbackWarn, isTranslateMissingWarn, parseTranslateArgs, translate, MISSING_RESOLVE_VALUE, parseDateTimeArgs, datetime, parseNumberArgs, number, fallbackWithLocaleChain, isMessageFunction, NUMBER_FORMAT_OPTIONS_KEYS, DATETIME_FORMAT_OPTIONS_KEYS, registerMessageCompiler, compile, registerMessageResolver, resolveValue, registerLocaleFallbacker, setDevToolsHook } from '@intlify/core-base';\nimport { getGlobalThis, makeSymbol, format, isObject, create, isPlainObject, isArray, deepCopy, isString, hasOwn, warn, isBoolean, isRegExp, isFunction, inBrowser, assign, isNumber, createEmitter, warnOnce, isEmptyObject } from '@intlify/shared';\nimport * as Vue from 'vue';\nimport { createVNode, Text, computed, watch, ref, shallowRef, Fragment, defineComponent, h, effectScope, inject, onMounted, onUnmounted, isRef } from 'vue';\nimport { setupDevtoolsPlugin } from '@vue/devtools-api';\n\n/**\n * Vue I18n Version\n *\n * @remarks\n * Semver format. Same format as the package.json `version` field.\n *\n * @VueI18nGeneral\n */\nconst VERSION = '11.3.0';\n/**\n * This is only called in esm-bundler builds.\n * istanbul-ignore-next\n */\nfunction initFeatureFlags() {\n if (typeof __VUE_I18N_FULL_INSTALL__ !== 'boolean') {\n getGlobalThis().__VUE_I18N_FULL_INSTALL__ = true;\n }\n if (typeof __VUE_I18N_LEGACY_API__ !== 'boolean') {\n getGlobalThis().__VUE_I18N_LEGACY_API__ = true;\n }\n if (typeof __INTLIFY_DROP_MESSAGE_COMPILER__ !== 'boolean') {\n getGlobalThis().__INTLIFY_DROP_MESSAGE_COMPILER__ = false;\n }\n if (typeof __INTLIFY_PROD_DEVTOOLS__ !== 'boolean') {\n getGlobalThis().__INTLIFY_PROD_DEVTOOLS__ = false;\n }\n}\n\nconst I18nErrorCodes = {\n // composer module errors\n UNEXPECTED_RETURN_TYPE: CORE_ERROR_CODES_EXTEND_POINT, // 24\n // legacy module errors\n INVALID_ARGUMENT: 25,\n // i18n module errors\n MUST_BE_CALL_SETUP_TOP: 26,\n NOT_INSTALLED: 27,\n // directive module errors\n REQUIRED_VALUE: 28,\n INVALID_VALUE: 29,\n // vue-devtools errors\n CANNOT_SETUP_VUE_DEVTOOLS_PLUGIN: 30,\n NOT_INSTALLED_WITH_PROVIDE: 31,\n // unexpected error\n UNEXPECTED_ERROR: 32,\n // not compatible legacy vue-i18n constructor\n NOT_COMPATIBLE_LEGACY_VUE_I18N: 33,\n // Not available Compostion API in Legacy API mode. Please make sure that the legacy API mode is working properly\n NOT_AVAILABLE_COMPOSITION_IN_LEGACY: 34\n};\nfunction createI18nError(code, ...args) {\n return createCompileError(code, null, (process.env.NODE_ENV !== 'production') ? { messages: errorMessages, args } : undefined);\n}\nconst errorMessages = {\n [I18nErrorCodes.UNEXPECTED_RETURN_TYPE]: 'Unexpected return type in composer',\n [I18nErrorCodes.INVALID_ARGUMENT]: 'Invalid argument',\n [I18nErrorCodes.MUST_BE_CALL_SETUP_TOP]: 'Must be called at the top of a `setup` function',\n [I18nErrorCodes.NOT_INSTALLED]: 'Need to install with `app.use` function',\n [I18nErrorCodes.UNEXPECTED_ERROR]: 'Unexpected error',\n [I18nErrorCodes.REQUIRED_VALUE]: `Required in value: {0}`,\n [I18nErrorCodes.INVALID_VALUE]: `Invalid value`,\n [I18nErrorCodes.CANNOT_SETUP_VUE_DEVTOOLS_PLUGIN]: `Cannot setup vue-devtools plugin`,\n [I18nErrorCodes.NOT_INSTALLED_WITH_PROVIDE]: 'Need to install with `provide` function',\n [I18nErrorCodes.NOT_COMPATIBLE_LEGACY_VUE_I18N]: 'Not compatible legacy VueI18n.',\n [I18nErrorCodes.NOT_AVAILABLE_COMPOSITION_IN_LEGACY]: 'Not available Compostion API in Legacy API mode. Please make sure that the legacy API mode is working properly'\n};\n\nconst TranslateVNodeSymbol = \n/* #__PURE__*/ makeSymbol('__translateVNode');\nconst DatetimePartsSymbol = /* #__PURE__*/ makeSymbol('__datetimeParts');\nconst NumberPartsSymbol = /* #__PURE__*/ makeSymbol('__numberParts');\nconst EnableEmitter = /* #__PURE__*/ makeSymbol('__enableEmitter');\nconst DisableEmitter = /* #__PURE__*/ makeSymbol('__disableEmitter');\nconst SetPluralRulesSymbol = makeSymbol('__setPluralRules');\nmakeSymbol('__intlifyMeta');\nconst InejctWithOptionSymbol = \n/* #__PURE__*/ makeSymbol('__injectWithOption');\nconst DisposeSymbol = /* #__PURE__*/ makeSymbol('__dispose');\n\nconst I18nWarnCodes = {\n FALLBACK_TO_ROOT: CORE_WARN_CODES_EXTEND_POINT, // 10\n NOT_FOUND_PARENT_SCOPE: (CORE_WARN_CODES_EXTEND_POINT + 1),\n IGNORE_OBJ_FLATTEN: (CORE_WARN_CODES_EXTEND_POINT + 2),\n /**\n * @deprecated will be removed at vue-i18n v12\n */\n DEPRECATE_LEGACY_MODE: (CORE_WARN_CODES_EXTEND_POINT + 3),\n /**\n * @deprecated will be removed at vue-i18n v12\n */\n DEPRECATE_TRANSLATE_CUSTOME_DIRECTIVE: (CORE_WARN_CODES_EXTEND_POINT +\n 4),\n // duplicate `useI18n` calling\n DUPLICATE_USE_I18N_CALLING: (CORE_WARN_CODES_EXTEND_POINT + 5)\n};\nconst warnMessages = {\n [I18nWarnCodes.FALLBACK_TO_ROOT]: `Fall back to {type} '{key}' with root locale.`,\n [I18nWarnCodes.NOT_FOUND_PARENT_SCOPE]: `Not found parent scope. use the global scope.`,\n [I18nWarnCodes.IGNORE_OBJ_FLATTEN]: `Ignore object flatten: '{key}' key has an string value`,\n /**\n * @deprecated will be removed at vue-i18n v12\n */\n [I18nWarnCodes.DEPRECATE_LEGACY_MODE]: `Legacy API mode has been deprecated in v11. Use Composition API mode instead.\\nAbout how to use the Composition API mode, see https://vue-i18n.intlify.dev/guide/advanced/composition.html`,\n /**\n * @deprecated will be removed at vue-i18n v12\n */\n [I18nWarnCodes.DEPRECATE_TRANSLATE_CUSTOME_DIRECTIVE]: `'v-t' has been deprecated in v11. Use translate APIs ('t' or '$t') instead.`,\n [I18nWarnCodes.DUPLICATE_USE_I18N_CALLING]: \"Duplicate `useI18n` calling by local scope. Please don't call it on local scope, due to it does not work properly in component.\"\n};\nfunction getWarnMessage(code, ...args) {\n return format(warnMessages[code], ...args);\n}\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n/**\n * Transform flat json in obj to normal json in obj\n */\nfunction handleFlatJson(obj) {\n // check obj\n if (!isObject(obj)) {\n return obj;\n }\n if (isMessageAST(obj)) {\n return obj;\n }\n for (const key in obj) {\n // check key\n if (!hasOwn(obj, key)) {\n continue;\n }\n // handle for normal json\n if (!key.includes('.')) {\n // recursive process value if value is also a object\n if (isObject(obj[key])) {\n handleFlatJson(obj[key]);\n }\n }\n // handle for flat json, transform to normal json\n else {\n // go to the last object\n const subKeys = key.split('.');\n const lastIndex = subKeys.length - 1;\n let currentObj = obj;\n let hasStringValue = false;\n for (let i = 0; i < lastIndex; i++) {\n if (subKeys[i] === '__proto__') {\n throw new Error(`unsafe key: ${subKeys[i]}`);\n }\n if (!(subKeys[i] in currentObj)) {\n currentObj[subKeys[i]] = create();\n }\n if (!isObject(currentObj[subKeys[i]])) {\n (process.env.NODE_ENV !== 'production') &&\n warn(getWarnMessage(I18nWarnCodes.IGNORE_OBJ_FLATTEN, {\n key: subKeys[i]\n }));\n hasStringValue = true;\n break;\n }\n currentObj = currentObj[subKeys[i]];\n }\n // update last object value, delete old property\n if (!hasStringValue) {\n if (!isMessageAST(currentObj)) {\n currentObj[subKeys[lastIndex]] = obj[key];\n delete obj[key];\n }\n else {\n /**\n * NOTE:\n * if the last object is a message AST and subKeys[lastIndex] has message AST prop key, ignore to copy and key deletion\n */\n if (!AST_NODE_PROPS_KEYS.includes(subKeys[lastIndex])) {\n delete obj[key];\n }\n }\n }\n // recursive process value if value is also a object\n if (!isMessageAST(currentObj)) {\n const target = currentObj[subKeys[lastIndex]];\n if (isObject(target)) {\n handleFlatJson(target);\n }\n }\n }\n }\n return obj;\n}\nfunction getLocaleMessages(locale, options) {\n const { messages, __i18n, messageResolver, flatJson } = options;\n // prettier-ignore\n const ret = (isPlainObject(messages)\n ? messages\n : isArray(__i18n)\n ? create()\n : { [locale]: create() });\n // merge locale messages of i18n custom block\n if (isArray(__i18n)) {\n __i18n.forEach(custom => {\n if ('locale' in custom && 'resource' in custom) {\n const { locale, resource } = custom;\n if (locale) {\n ret[locale] = ret[locale] || create();\n deepCopy(resource, ret[locale]);\n }\n else {\n deepCopy(resource, ret);\n }\n }\n else {\n isString(custom) && deepCopy(JSON.parse(custom), ret);\n }\n });\n }\n // handle messages for flat json\n if (messageResolver == null && flatJson) {\n for (const key in ret) {\n if (hasOwn(ret, key)) {\n handleFlatJson(ret[key]);\n }\n }\n }\n return ret;\n}\nfunction getComponentOptions(instance) {\n return instance.type;\n}\nfunction adjustI18nResources(gl, options, componentOptions) {\n // prettier-ignore\n let messages = isObject(options.messages)\n ? options.messages\n : create();\n if ('__i18nGlobal' in componentOptions) {\n messages = getLocaleMessages(gl.locale.value, {\n messages,\n __i18n: componentOptions.__i18nGlobal\n });\n }\n // merge locale messages\n const locales = Object.keys(messages);\n if (locales.length) {\n locales.forEach(locale => {\n gl.mergeLocaleMessage(locale, messages[locale]);\n });\n }\n {\n // merge datetime formats\n if (isObject(options.datetimeFormats)) {\n const locales = Object.keys(options.datetimeFormats);\n if (locales.length) {\n locales.forEach(locale => {\n gl.mergeDateTimeFormat(locale, options.datetimeFormats[locale]);\n });\n }\n }\n // merge number formats\n if (isObject(options.numberFormats)) {\n const locales = Object.keys(options.numberFormats);\n if (locales.length) {\n locales.forEach(locale => {\n gl.mergeNumberFormat(locale, options.numberFormats[locale]);\n });\n }\n }\n }\n}\nfunction createTextNode(key) {\n return createVNode(Text, null, key, 0);\n}\nfunction getCurrentInstance() {\n // NOTE(kazupon): avoid bundler warning\n const key = 'currentInstance';\n if (key in Vue) {\n return Vue[key];\n }\n else {\n return Vue.getCurrentInstance();\n }\n}\n/* eslint-enable @typescript-eslint/no-explicit-any */\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n// extend VNode interface\nconst DEVTOOLS_META = '__INTLIFY_META__';\nconst NOOP_RETURN_ARRAY = () => [];\nconst NOOP_RETURN_FALSE = () => false;\nlet composerID = 0;\nfunction defineCoreMissingHandler(missing) {\n return ((ctx, locale, key, type) => {\n return missing(locale, key, getCurrentInstance() || undefined, type);\n });\n}\n// for Intlify DevTools\n/* #__NO_SIDE_EFFECTS__ */\nconst getMetaInfo = () => {\n const instance = getCurrentInstance();\n let meta = null;\n return instance && (meta = getComponentOptions(instance)[DEVTOOLS_META])\n ? { [DEVTOOLS_META]: meta }\n : null;\n};\n/**\n * Create composer interface factory\n *\n * @internal\n */\nfunction createComposer(options = {}) {\n const { __root, __injectWithOption } = options;\n const _isGlobal = __root === undefined;\n const flatJson = options.flatJson;\n const _ref = inBrowser ? ref : shallowRef;\n let _inheritLocale = isBoolean(options.inheritLocale)\n ? options.inheritLocale\n : true;\n const _locale = _ref(\n // prettier-ignore\n __root && _inheritLocale\n ? __root.locale.value\n : isString(options.locale)\n ? options.locale\n : DEFAULT_LOCALE);\n const _fallbackLocale = _ref(\n // prettier-ignore\n __root && _inheritLocale\n ? __root.fallbackLocale.value\n : isString(options.fallbackLocale) ||\n isArray(options.fallbackLocale) ||\n isPlainObject(options.fallbackLocale) ||\n options.fallbackLocale === false\n ? options.fallbackLocale\n : _locale.value);\n const _messages = _ref(getLocaleMessages(_locale.value, options));\n // prettier-ignore\n const _datetimeFormats = _ref(isPlainObject(options.datetimeFormats)\n ? options.datetimeFormats\n : { [_locale.value]: {} })\n ;\n // prettier-ignore\n const _numberFormats = _ref(isPlainObject(options.numberFormats)\n ? options.numberFormats\n : { [_locale.value]: {} })\n ;\n // warning suppress options\n // prettier-ignore\n let _missingWarn = __root\n ? __root.missingWarn\n : isBoolean(options.missingWarn) || isRegExp(options.missingWarn)\n ? options.missingWarn\n : true;\n // prettier-ignore\n let _fallbackWarn = __root\n ? __root.fallbackWarn\n : isBoolean(options.fallbackWarn) || isRegExp(options.fallbackWarn)\n ? options.fallbackWarn\n : true;\n // prettier-ignore\n let _fallbackRoot = __root\n ? __root.fallbackRoot\n : isBoolean(options.fallbackRoot)\n ? options.fallbackRoot\n : true;\n // configure fall back to root\n let _fallbackFormat = !!options.fallbackFormat;\n // runtime missing\n let _missing = isFunction(options.missing) ? options.missing : null;\n let _runtimeMissing = isFunction(options.missing)\n ? defineCoreMissingHandler(options.missing)\n : null;\n // postTranslation handler\n let _postTranslation = isFunction(options.postTranslation)\n ? options.postTranslation\n : null;\n // prettier-ignore\n let _warnHtmlMessage = __root\n ? __root.warnHtmlMessage\n : isBoolean(options.warnHtmlMessage)\n ? options.warnHtmlMessage\n : true;\n let _escapeParameter = !!options.escapeParameter;\n // custom linked modifiers\n // prettier-ignore\n const _modifiers = __root\n ? __root.modifiers\n : isPlainObject(options.modifiers)\n ? options.modifiers\n : {};\n // pluralRules\n let _pluralRules = options.pluralRules || (__root && __root.pluralRules);\n // runtime context\n // eslint-disable-next-line prefer-const\n let _context;\n const getCoreContext = () => {\n _isGlobal && setFallbackContext(null);\n const ctxOptions = {\n version: VERSION,\n locale: _locale.value,\n fallbackLocale: _fallbackLocale.value,\n messages: _messages.value,\n modifiers: _modifiers,\n pluralRules: _pluralRules,\n missing: _runtimeMissing === null ? undefined : _runtimeMissing,\n missingWarn: _missingWarn,\n fallbackWarn: _fallbackWarn,\n fallbackFormat: _fallbackFormat,\n unresolving: true,\n postTranslation: _postTranslation === null ? undefined : _postTranslation,\n warnHtmlMessage: _warnHtmlMessage,\n escapeParameter: _escapeParameter,\n messageResolver: options.messageResolver,\n messageCompiler: options.messageCompiler,\n __meta: { framework: 'vue' }\n };\n {\n ctxOptions.datetimeFormats = _datetimeFormats.value;\n ctxOptions.numberFormats = _numberFormats.value;\n ctxOptions.__datetimeFormatters = isPlainObject(_context)\n ? _context.__datetimeFormatters\n : undefined;\n ctxOptions.__numberFormatters = isPlainObject(_context)\n ? _context.__numberFormatters\n : undefined;\n }\n if ((process.env.NODE_ENV !== 'production')) {\n ctxOptions.__v_emitter = isPlainObject(_context)\n ? _context.__v_emitter\n : undefined;\n }\n const ctx = createCoreContext(ctxOptions);\n _isGlobal && setFallbackContext(ctx);\n return ctx;\n };\n _context = getCoreContext();\n updateFallbackLocale(_context, _locale.value, _fallbackLocale.value);\n // track reactivity\n function trackReactivityValues() {\n return [\n _locale.value,\n _fallbackLocale.value,\n _messages.value,\n _datetimeFormats.value,\n _numberFormats.value\n ]\n ;\n }\n // locale\n const locale = computed({\n get: () => _locale.value,\n set: val => {\n _context.locale = val;\n _locale.value = val;\n }\n });\n // fallbackLocale\n const fallbackLocale = computed({\n get: () => _fallbackLocale.value,\n set: val => {\n _context.fallbackLocale = val;\n _fallbackLocale.value = val;\n updateFallbackLocale(_context, _locale.value, val);\n }\n });\n // messages\n const messages = computed(() => _messages.value);\n // datetimeFormats\n const datetimeFormats = /* #__PURE__*/ computed(() => _datetimeFormats.value);\n // numberFormats\n const numberFormats = /* #__PURE__*/ computed(() => _numberFormats.value);\n // getPostTranslationHandler\n function getPostTranslationHandler() {\n return isFunction(_postTranslation) ? _postTranslation : null;\n }\n // setPostTranslationHandler\n function setPostTranslationHandler(handler) {\n _postTranslation = handler;\n _context.postTranslation = handler;\n }\n // getMissingHandler\n function getMissingHandler() {\n return _missing;\n }\n // setMissingHandler\n function setMissingHandler(handler) {\n if (handler !== null) {\n _runtimeMissing = defineCoreMissingHandler(handler);\n }\n _missing = handler;\n _context.missing = _runtimeMissing;\n }\n function isResolvedTranslateMessage(type, arg) {\n return type !== 'translate' || !arg.resolvedMessage;\n }\n const wrapWithDeps = (fn, argumentParser, warnType, fallbackSuccess, fallbackFail, successCondition) => {\n trackReactivityValues(); // track reactive dependency\n // NOTE: experimental !!\n let ret;\n try {\n if ((process.env.NODE_ENV !== 'production') || __INTLIFY_PROD_DEVTOOLS__) {\n setAdditionalMeta(getMetaInfo());\n }\n if (!_isGlobal) {\n _context.fallbackContext = __root\n ? getFallbackContext()\n : undefined;\n }\n ret = fn(_context);\n }\n finally {\n if ((process.env.NODE_ENV !== 'production') || __INTLIFY_PROD_DEVTOOLS__) {\n setAdditionalMeta(null);\n }\n if (!_isGlobal) {\n _context.fallbackContext = undefined;\n }\n }\n if ((warnType !== 'translate exists' && // for not `te` (e.g `t`)\n isNumber(ret) &&\n ret === NOT_REOSLVED) ||\n (warnType === 'translate exists' && !ret) // for `te`\n ) {\n const [key, arg2] = argumentParser();\n if ((process.env.NODE_ENV !== 'production') &&\n __root &&\n isString(key) &&\n isResolvedTranslateMessage(warnType, arg2)) {\n if (_fallbackRoot &&\n (isTranslateFallbackWarn(_fallbackWarn, key) ||\n isTranslateMissingWarn(_missingWarn, key))) {\n warn(getWarnMessage(I18nWarnCodes.FALLBACK_TO_ROOT, {\n key,\n type: warnType\n }));\n }\n // for vue-devtools timeline event\n if ((process.env.NODE_ENV !== 'production')) {\n const { __v_emitter: emitter } = _context;\n if (emitter && _fallbackRoot) {\n emitter.emit('fallback', {\n type: warnType,\n key,\n to: 'global',\n groupId: `${warnType}:${key}`\n });\n }\n }\n }\n return __root && _fallbackRoot\n ? fallbackSuccess(__root)\n : fallbackFail(key);\n }\n else if (successCondition(ret)) {\n return ret;\n }\n else {\n /* istanbul ignore next */\n throw createI18nError(I18nErrorCodes.UNEXPECTED_RETURN_TYPE);\n }\n };\n // t\n function t(...args) {\n return wrapWithDeps(context => Reflect.apply(translate, null, [context, ...args]), () => parseTranslateArgs(...args), 'translate', root => Reflect.apply(root.t, root, [...args]), key => key, val => isString(val));\n }\n // rt\n function rt(...args) {\n const [arg1, arg2, arg3] = args;\n if (arg3 && !isObject(arg3)) {\n throw createI18nError(I18nErrorCodes.INVALID_ARGUMENT);\n }\n return t(...[arg1, arg2, assign({ resolvedMessage: true }, arg3 || {})]);\n }\n // d\n function d(...args) {\n return wrapWithDeps(context => Reflect.apply(datetime, null, [context, ...args]), () => parseDateTimeArgs(...args), 'datetime format', root => Reflect.apply(root.d, root, [...args]), () => MISSING_RESOLVE_VALUE, val => isString(val) || isArray(val));\n }\n // n\n function n(...args) {\n return wrapWithDeps(context => Reflect.apply(number, null, [context, ...args]), () => parseNumberArgs(...args), 'number format', root => Reflect.apply(root.n, root, [...args]), () => MISSING_RESOLVE_VALUE, val => isString(val) || isArray(val));\n }\n // for custom processor\n function normalize(values) {\n return values.map(val => isString(val) || isNumber(val) || isBoolean(val)\n ? createTextNode(String(val))\n : val);\n }\n const interpolate = (val) => val;\n const processor = {\n normalize,\n interpolate,\n type: 'vnode'\n };\n // translateVNode, using for `i18n-t` component\n function translateVNode(...args) {\n return wrapWithDeps(context => {\n let ret;\n const _context = context;\n try {\n _context.processor = processor;\n ret = Reflect.apply(translate, null, [_context, ...args]);\n }\n finally {\n _context.processor = null;\n }\n return ret;\n }, () => parseTranslateArgs(...args), 'translate', root => root[TranslateVNodeSymbol](...args), key => [createTextNode(key)], val => isArray(val));\n }\n // numberParts, using for `i18n-n` component\n function numberParts(...args) {\n return wrapWithDeps(context => Reflect.apply(number, null, [context, ...args]), () => parseNumberArgs(...args), 'number format', root => root[NumberPartsSymbol](...args), NOOP_RETURN_ARRAY, val => isString(val) || isArray(val));\n }\n // datetimeParts, using for `i18n-d` component\n function datetimeParts(...args) {\n return wrapWithDeps(context => Reflect.apply(datetime, null, [context, ...args]), () => parseDateTimeArgs(...args), 'datetime format', root => root[DatetimePartsSymbol](...args), NOOP_RETURN_ARRAY, val => isString(val) || isArray(val));\n }\n function setPluralRules(rules) {\n _pluralRules = rules;\n _context.pluralRules = _pluralRules;\n }\n // te\n function te(key, locale) {\n return wrapWithDeps(() => {\n if (!key) {\n return false;\n }\n const targetLocale = isString(locale) ? locale : _locale.value;\n // When locale is explicitly specified, check only that locale (no fallback chain)\n // When locale is not specified, check the fallback locale chain\n const locales = isString(locale)\n ? [targetLocale]\n : fallbackWithLocaleChain(_context, _fallbackLocale.value, targetLocale);\n for (let i = 0; i < locales.length; i++) {\n const message = getLocaleMessage(locales[i]);\n let resolved = _context.messageResolver(message, key);\n // if null, resolve with object key path (for flat keys containing dots)\n if (resolved === null) {\n resolved = message[key];\n }\n if (isMessageAST(resolved) ||\n isMessageFunction(resolved) ||\n isString(resolved)) {\n return true;\n }\n }\n return false;\n }, () => [key], 'translate exists', root => {\n return Reflect.apply(root.te, root, [key, locale]);\n }, NOOP_RETURN_FALSE, val => isBoolean(val));\n }\n function resolveMessages(key) {\n let messages = null;\n const locales = fallbackWithLocaleChain(_context, _fallbackLocale.value, _locale.value);\n for (let i = 0; i < locales.length; i++) {\n const targetLocaleMessages = _messages.value[locales[i]] || {};\n const messageValue = _context.messageResolver(targetLocaleMessages, key);\n if (messageValue != null) {\n messages = messageValue;\n break;\n }\n }\n return messages;\n }\n // tm\n function tm(key) {\n const messages = resolveMessages(key);\n // prettier-ignore\n return messages != null\n ? messages\n : __root\n ? __root.tm(key) || {}\n : {};\n }\n // getLocaleMessage\n function getLocaleMessage(locale) {\n return (_messages.value[locale] || {});\n }\n // setLocaleMessage\n function setLocaleMessage(locale, message) {\n if (flatJson) {\n const _message = { [locale]: message };\n for (const key in _message) {\n if (hasOwn(_message, key)) {\n handleFlatJson(_message[key]);\n }\n }\n message = _message[locale];\n }\n _messages.value[locale] = message;\n _context.messages = _messages.value;\n }\n // mergeLocaleMessage\n function mergeLocaleMessage(locale, message) {\n _messages.value[locale] = _messages.value[locale] || {};\n const _message = { [locale]: message };\n if (flatJson) {\n for (const key in _message) {\n if (hasOwn(_message, key)) {\n handleFlatJson(_message[key]);\n }\n }\n }\n message = _message[locale];\n deepCopy(message, _messages.value[locale]);\n _context.messages = _messages.value;\n }\n // getDateTimeFormat\n function getDateTimeFormat(locale) {\n return _datetimeFormats.value[locale] || {};\n }\n // setDateTimeFormat\n function setDateTimeFormat(locale, format) {\n _datetimeFormats.value[locale] = format;\n _context.datetimeFormats = _datetimeFormats.value;\n clearDateTimeFormat(_context, locale, format);\n }\n // mergeDateTimeFormat\n function mergeDateTimeFormat(locale, format) {\n _datetimeFormats.value[locale] = assign(_datetimeFormats.value[locale] || {}, format);\n _context.datetimeFormats = _datetimeFormats.value;\n clearDateTimeFormat(_context, locale, format);\n }\n // getNumberFormat\n function getNumberFormat(locale) {\n return _numberFormats.value[locale] || {};\n }\n // setNumberFormat\n function setNumberFormat(locale, format) {\n _numberFormats.value[locale] = format;\n _context.numberFormats = _numberFormats.value;\n clearNumberFormat(_context, locale, format);\n }\n // mergeNumberFormat\n function mergeNumberFormat(locale, format) {\n _numberFormats.value[locale] = assign(_numberFormats.value[locale] || {}, format);\n _context.numberFormats = _numberFormats.value;\n clearNumberFormat(_context, locale, format);\n }\n // for debug\n composerID++;\n // watch root locale & fallbackLocale\n if (__root && inBrowser) {\n watch(__root.locale, (val) => {\n if (_inheritLocale) {\n _locale.value = val;\n _context.locale = val;\n updateFallbackLocale(_context, _locale.value, _fallbackLocale.value);\n }\n });\n watch(__root.fallbackLocale, (val) => {\n if (_inheritLocale) {\n _fallbackLocale.value = val;\n _context.fallbackLocale = val;\n updateFallbackLocale(_context, _locale.value, _fallbackLocale.value);\n }\n });\n }\n // define basic composition API!\n const composer = {\n id: composerID,\n locale,\n fallbackLocale,\n get inheritLocale() {\n return _inheritLocale;\n },\n set inheritLocale(val) {\n _inheritLocale = val;\n if (val && __root) {\n _locale.value = __root.locale.value;\n _fallbackLocale.value = __root.fallbackLocale.value;\n updateFallbackLocale(_context, _locale.value, _fallbackLocale.value);\n }\n },\n get availableLocales() {\n return Object.keys(_messages.value).sort();\n },\n messages,\n get modifiers() {\n return _modifiers;\n },\n get pluralRules() {\n return _pluralRules || {};\n },\n get isGlobal() {\n return _isGlobal;\n },\n get missingWarn() {\n return _missingWarn;\n },\n set missingWarn(val) {\n _missingWarn = val;\n _context.missingWarn = _missingWarn;\n },\n get fallbackWarn() {\n return _fallbackWarn;\n },\n set fallbackWarn(val) {\n _fallbackWarn = val;\n _context.fallbackWarn = _fallbackWarn;\n },\n get fallbackRoot() {\n return _fallbackRoot;\n },\n set fallbackRoot(val) {\n _fallbackRoot = val;\n },\n get fallbackFormat() {\n return _fallbackFormat;\n },\n set fallbackFormat(val) {\n _fallbackFormat = val;\n _context.fallbackFormat = _fallbackFormat;\n },\n get warnHtmlMessage() {\n return _warnHtmlMessage;\n },\n set warnHtmlMessage(val) {\n _warnHtmlMessage = val;\n _context.warnHtmlMessage = val;\n },\n get escapeParameter() {\n return _escapeParameter;\n },\n set escapeParameter(val) {\n _escapeParameter = val;\n _context.escapeParameter = val;\n },\n t,\n getLocaleMessage,\n setLocaleMessage,\n mergeLocaleMessage,\n getPostTranslationHandler,\n setPostTranslationHandler,\n getMissingHandler,\n setMissingHandler,\n [SetPluralRulesSymbol]: setPluralRules\n };\n {\n composer.datetimeFormats = datetimeFormats;\n composer.numberFormats = numberFormats;\n composer.rt = rt;\n composer.te = te;\n composer.tm = tm;\n composer.d = d;\n composer.n = n;\n composer.getDateTimeFormat = getDateTimeFormat;\n composer.setDateTimeFormat = setDateTimeFormat;\n composer.mergeDateTimeFormat = mergeDateTimeFormat;\n composer.getNumberFormat = getNumberFormat;\n composer.setNumberFormat = setNumberFormat;\n composer.mergeNumberFormat = mergeNumberFormat;\n composer[InejctWithOptionSymbol] = __injectWithOption;\n composer[TranslateVNodeSymbol] = translateVNode;\n composer[DatetimePartsSymbol] = datetimeParts;\n composer[NumberPartsSymbol] = numberParts;\n }\n // for vue-devtools timeline event\n if ((process.env.NODE_ENV !== 'production')) {\n composer[EnableEmitter] = (emitter) => {\n _context.__v_emitter = emitter;\n };\n composer[DisableEmitter] = () => {\n _context.__v_emitter = undefined;\n };\n }\n return composer;\n}\n/* eslint-enable @typescript-eslint/no-explicit-any */\n\nconst VUE_I18N_COMPONENT_TYPES = 'vue-i18n: composer properties';\nconst VueDevToolsLabels = {\n 'vue-devtools-plugin-vue-i18n': 'Vue I18n DevTools',\n 'vue-i18n-resource-inspector': 'Vue I18n DevTools',\n 'vue-i18n-timeline': 'Vue I18n'\n};\nconst VueDevToolsPlaceholders = {\n 'vue-i18n-resource-inspector': 'Search for scopes ...'\n};\nconst VueDevToolsTimelineColors = {\n 'vue-i18n-timeline': 0xffcd19\n};\nlet devtoolsApi;\nasync function enableDevTools(app, i18n) {\n return new Promise((resolve, reject) => {\n try {\n setupDevtoolsPlugin({\n id: 'vue-devtools-plugin-vue-i18n',\n label: VueDevToolsLabels['vue-devtools-plugin-vue-i18n'],\n packageName: 'vue-i18n',\n homepage: 'https://vue-i18n.intlify.dev',\n logo: 'https://vue-i18n.intlify.dev/vue-i18n-devtools-logo.png',\n componentStateTypes: [VUE_I18N_COMPONENT_TYPES],\n app: app // eslint-disable-line @typescript-eslint/no-explicit-any\n }, api => {\n devtoolsApi = api;\n api.on.visitComponentTree(({ componentInstance, treeNode }) => {\n updateComponentTreeTags(componentInstance, treeNode, i18n);\n });\n api.on.inspectComponent(({ componentInstance, instanceData }) => {\n if (componentInstance.__VUE_I18N__ && instanceData) {\n if (i18n.mode === 'legacy') {\n // ignore global scope on legacy mode\n if (componentInstance.__VUE_I18N__ !==\n i18n.global.__composer) {\n inspectComposer(instanceData, componentInstance.__VUE_I18N__);\n }\n }\n else {\n inspectComposer(instanceData, componentInstance.__VUE_I18N__);\n }\n }\n });\n api.addInspector({\n id: 'vue-i18n-resource-inspector',\n label: VueDevToolsLabels['vue-i18n-resource-inspector'],\n icon: 'language',\n treeFilterPlaceholder: VueDevToolsPlaceholders['vue-i18n-resource-inspector']\n });\n api.on.getInspectorTree(payload => {\n if (payload.app === app &&\n payload.inspectorId === 'vue-i18n-resource-inspector') {\n registerScope(payload, i18n);\n }\n });\n const roots = new Map();\n api.on.getInspectorState(async (payload) => {\n if (payload.app === app &&\n payload.inspectorId === 'vue-i18n-resource-inspector') {\n api.unhighlightElement();\n inspectScope(payload, i18n);\n if (payload.nodeId === 'global') {\n if (!roots.has(payload.app)) {\n const [root] = await api.getComponentInstances(payload.app);\n roots.set(payload.app, root);\n }\n api.highlightElement(roots.get(payload.app));\n }\n else {\n const instance = getComponentInstance(payload.nodeId, i18n);\n instance && api.highlightElement(instance);\n }\n }\n });\n api.on.editInspectorState(payload => {\n if (payload.app === app &&\n payload.inspectorId === 'vue-i18n-resource-inspector') {\n editScope(payload, i18n);\n }\n });\n api.addTimelineLayer({\n id: 'vue-i18n-timeline',\n label: VueDevToolsLabels['vue-i18n-timeline'],\n color: VueDevToolsTimelineColors['vue-i18n-timeline']\n });\n resolve(true);\n });\n }\n catch (e) {\n console.error(e);\n // eslint-disable-next-line @typescript-eslint/prefer-promise-reject-errors\n reject(false);\n }\n });\n}\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction getI18nScopeLable(instance) {\n return (instance.type.name ||\n instance.type.displayName ||\n instance.type.__file ||\n 'Anonymous');\n}\nfunction updateComponentTreeTags(instance, // eslint-disable-line @typescript-eslint/no-explicit-any\ntreeNode, i18n) {\n // prettier-ignore\n const global = i18n.mode === 'composition'\n ? i18n.global\n : i18n.global.__composer;\n if (instance && instance.__VUE_I18N__) {\n // add custom tags local scope only\n if (instance.__VUE_I18N__ !== global) {\n const tag = {\n label: `i18n (${getI18nScopeLable(instance)} Scope)`,\n textColor: 0x000000,\n backgroundColor: 0xffcd19\n };\n treeNode.tags.push(tag);\n }\n }\n}\nfunction inspectComposer(instanceData, composer) {\n const type = VUE_I18N_COMPONENT_TYPES;\n instanceData.state.push({\n type,\n key: 'locale',\n editable: true,\n value: composer.locale.value\n });\n instanceData.state.push({\n type,\n key: 'availableLocales',\n editable: false,\n value: composer.availableLocales\n });\n instanceData.state.push({\n type,\n key: 'fallbackLocale',\n editable: true,\n value: composer.fallbackLocale.value\n });\n instanceData.state.push({\n type,\n key: 'inheritLocale',\n editable: true,\n value: composer.inheritLocale\n });\n instanceData.state.push({\n type,\n key: 'messages',\n editable: false,\n value: getLocaleMessageValue(composer.messages.value)\n });\n {\n instanceData.state.push({\n type,\n key: 'datetimeFormats',\n editable: false,\n value: composer.datetimeFormats.value\n });\n instanceData.state.push({\n type,\n key: 'numberFormats',\n editable: false,\n value: composer.numberFormats.value\n });\n }\n}\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction getLocaleMessageValue(messages) {\n const value = {};\n Object.keys(messages).forEach((key) => {\n const v = messages[key];\n if (isFunction(v) && 'source' in v) {\n value[key] = getMessageFunctionDetails(v);\n }\n else if (isMessageAST(v) && v.loc && v.loc.source) {\n value[key] = v.loc.source;\n }\n else if (isObject(v)) {\n value[key] = getLocaleMessageValue(v);\n }\n else {\n value[key] = v;\n }\n });\n return value;\n}\nconst ESC = {\n '<': '&lt;',\n '>': '&gt;',\n '\"': '&quot;',\n '&': '&amp;'\n};\nfunction escape(s) {\n return s.replace(/[<>\"&]/g, escapeChar);\n}\nfunction escapeChar(a) {\n return ESC[a] || a;\n}\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction getMessageFunctionDetails(func) {\n const argString = func.source ? `(\"${escape(func.source)}\")` : `(?)`;\n return {\n _custom: {\n type: 'function',\n display: `<span>ƒ</span> ${argString}`\n }\n };\n}\nfunction registerScope(payload, i18n) {\n payload.rootNodes.push({\n id: 'global',\n label: 'Global Scope'\n });\n // prettier-ignore\n const global = i18n.mode === 'composition'\n ? i18n.global\n : i18n.global.__composer;\n for (const [keyInstance, instance] of i18n.__instances) {\n // prettier-ignore\n const composer = i18n.mode === 'composition'\n ? instance\n : instance.__composer;\n if (global === composer) {\n continue;\n }\n payload.rootNodes.push({\n id: composer.id.toString(),\n label: `${getI18nScopeLable(keyInstance)} Scope`\n });\n }\n}\nfunction getComponentInstance(nodeId, i18n) {\n let instance = null;\n if (nodeId !== 'global') {\n for (const [component, composer] of i18n.__instances.entries()) {\n if (composer.id.toString() === nodeId) {\n instance = component;\n break;\n }\n }\n }\n return instance;\n}\nfunction getComposer$2(nodeId, i18n) {\n if (nodeId === 'global') {\n return i18n.mode === 'composition'\n ? i18n.global\n : i18n.global.__composer;\n }\n else {\n const instance = Array.from(i18n.__instances.values()).find(item => item.id.toString() === nodeId);\n if (instance) {\n return i18n.mode === 'composition'\n ? instance\n : instance.__composer;\n }\n else {\n return null;\n }\n }\n}\nfunction inspectScope(payload, i18n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\n) {\n const composer = getComposer$2(payload.nodeId, i18n);\n if (composer) {\n // TODO:\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n payload.state = makeScopeInspectState(composer);\n }\n return null;\n}\nfunction makeScopeInspectState(composer) {\n const state = {};\n const localeType = 'Locale related info';\n const localeStates = [\n {\n type: localeType,\n key: 'locale',\n editable: true,\n value: composer.locale.value\n },\n {\n type: localeType,\n key: 'fallbackLocale',\n editable: true,\n value: composer.fallbackLocale.value\n },\n {\n type: localeType,\n key: 'availableLocales',\n editable: false,\n value: composer.availableLocales\n },\n {\n type: localeType,\n key: 'inheritLocale',\n editable: true,\n value: composer.inheritLocale\n }\n ];\n state[localeType] = localeStates;\n const localeMessagesType = 'Locale messages info';\n const localeMessagesStates = [\n {\n type: localeMessagesType,\n key: 'messages',\n editable: false,\n value: getLocaleMessageValue(composer.messages.value)\n }\n ];\n state[localeMessagesType] = localeMessagesStates;\n {\n const datetimeFormatsType = 'Datetime formats info';\n const datetimeFormatsStates = [\n {\n type: datetimeFormatsType,\n key: 'datetimeFormats',\n editable: false,\n value: composer.datetimeFormats.value\n }\n ];\n state[datetimeFormatsType] = datetimeFormatsStates;\n const numberFormatsType = 'Datetime formats info';\n const numberFormatsStates = [\n {\n type: numberFormatsType,\n key: 'numberFormats',\n editable: false,\n value: composer.numberFormats.value\n }\n ];\n state[numberFormatsType] = numberFormatsStates;\n }\n return state;\n}\nfunction addTimelineEvent(event, payload) {\n if (devtoolsApi) {\n let groupId;\n if (payload && 'groupId' in payload) {\n groupId = payload.groupId;\n delete payload.groupId;\n }\n devtoolsApi.addTimelineEvent({\n layerId: 'vue-i18n-timeline',\n event: {\n title: event,\n groupId,\n time: Date.now(),\n meta: {},\n data: payload || {},\n logType: event === 'compile-error'\n ? 'error'\n : event === 'fallback' || event === 'missing'\n ? 'warning'\n : 'default'\n }\n });\n }\n}\nfunction editScope(payload, i18n) {\n const composer = getComposer$2(payload.nodeId, i18n);\n if (composer) {\n const [field] = payload.path;\n if (field === 'locale' && isString(payload.state.value)) {\n composer.locale.value = payload.state.value;\n }\n else if (field === 'fallbackLocale' &&\n (isString(payload.state.value) ||\n isArray(payload.state.value) ||\n isObject(payload.state.value))) {\n composer.fallbackLocale.value = payload.state.value;\n }\n else if (field === 'inheritLocale' && isBoolean(payload.state.value)) {\n composer.inheritLocale = payload.state.value;\n }\n }\n}\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n/**\n * Convert to I18n Composer Options from VueI18n Options\n *\n * @internal\n */\nfunction convertComposerOptions(options) {\n const locale = isString(options.locale) ? options.locale : DEFAULT_LOCALE;\n const fallbackLocale = isString(options.fallbackLocale) ||\n isArray(options.fallbackLocale) ||\n isPlainObject(options.fallbackLocale) ||\n options.fallbackLocale === false\n ? options.fallbackLocale\n : locale;\n const missing = isFunction(options.missing) ? options.missing : undefined;\n const missingWarn = isBoolean(options.silentTranslationWarn) ||\n isRegExp(options.silentTranslationWarn)\n ? !options.silentTranslationWarn\n : true;\n const fallbackWarn = isBoolean(options.silentFallbackWarn) ||\n isRegExp(options.silentFallbackWarn)\n ? !options.silentFallbackWarn\n : true;\n const fallbackRoot = isBoolean(options.fallbackRoot)\n ? options.fallbackRoot\n : true;\n const fallbackFormat = !!options.formatFallbackMessages;\n const modifiers = isPlainObject(options.modifiers) ? options.modifiers : {};\n const pluralizationRules = options.pluralizationRules;\n const postTranslation = isFunction(options.postTranslation)\n ? options.postTranslation\n : undefined;\n const warnHtmlMessage = isString(options.warnHtmlInMessage)\n ? options.warnHtmlInMessage !== 'off'\n : true;\n const escapeParameter = !!options.escapeParameterHtml;\n const inheritLocale = isBoolean(options.sync) ? options.sync : true;\n let messages = options.messages;\n if (isPlainObject(options.sharedMessages)) {\n const sharedMessages = options.sharedMessages;\n const locales = Object.keys(sharedMessages);\n messages = locales.reduce((messages, locale) => {\n const message = messages[locale] || (messages[locale] = {});\n assign(message, sharedMessages[locale]);\n return messages;\n }, (messages || {}));\n }\n const { __i18n, __root, __injectWithOption } = options;\n const datetimeFormats = options.datetimeFormats;\n const numberFormats = options.numberFormats;\n const flatJson = options.flatJson;\n return {\n locale,\n fallbackLocale,\n messages,\n flatJson,\n datetimeFormats,\n numberFormats,\n missing,\n missingWarn,\n fallbackWarn,\n fallbackRoot,\n fallbackFormat,\n modifiers,\n pluralRules: pluralizationRules,\n postTranslation,\n warnHtmlMessage,\n escapeParameter,\n messageResolver: options.messageResolver,\n inheritLocale,\n __i18n,\n __root,\n __injectWithOption\n };\n}\n/**\n * create VueI18n interface factory\n *\n * @internal\n *\n * @deprecated will be removed at vue-i18n v12\n */\nfunction createVueI18n(options = {}) {\n const composer = createComposer(convertComposerOptions(options));\n const { __extender } = options;\n // defines VueI18n\n const vueI18n = {\n // id\n id: composer.id,\n // locale\n get locale() {\n return composer.locale.value;\n },\n set locale(val) {\n composer.locale.value = val;\n },\n // fallbackLocale\n get fallbackLocale() {\n return composer.fallbackLocale.value;\n },\n set fallbackLocale(val) {\n composer.fallbackLocale.value = val;\n },\n // messages\n get messages() {\n return composer.messages.value;\n },\n // datetimeFormats\n get datetimeFormats() {\n return composer.datetimeFormats.value;\n },\n // numberFormats\n get numberFormats() {\n return composer.numberFormats.value;\n },\n // availableLocales\n get availableLocales() {\n return composer.availableLocales;\n },\n // missing\n get missing() {\n return composer.getMissingHandler();\n },\n set missing(handler) {\n composer.setMissingHandler(handler);\n },\n // silentTranslationWarn\n get silentTranslationWarn() {\n return isBoolean(composer.missingWarn)\n ? !composer.missingWarn\n : composer.missingWarn;\n },\n set silentTranslationWarn(val) {\n composer.missingWarn = isBoolean(val) ? !val : val;\n },\n // silentFallbackWarn\n get silentFallbackWarn() {\n return isBoolean(composer.fallbackWarn)\n ? !composer.fallbackWarn\n : composer.fallbackWarn;\n },\n set silentFallbackWarn(val) {\n composer.fallbackWarn = isBoolean(val) ? !val : val;\n },\n // modifiers\n get modifiers() {\n return composer.modifiers;\n },\n // formatFallbackMessages\n get formatFallbackMessages() {\n return composer.fallbackFormat;\n },\n set formatFallbackMessages(val) {\n composer.fallbackFormat = val;\n },\n // postTranslation\n get postTranslation() {\n return composer.getPostTranslationHandler();\n },\n set postTranslation(handler) {\n composer.setPostTranslationHandler(handler);\n },\n // sync\n get sync() {\n return composer.inheritLocale;\n },\n set sync(val) {\n composer.inheritLocale = val;\n },\n // warnInHtmlMessage\n get warnHtmlInMessage() {\n return composer.warnHtmlMessage ? 'warn' : 'off';\n },\n set warnHtmlInMessage(val) {\n composer.warnHtmlMessage = val !== 'off';\n },\n // escapeParameterHtml\n get escapeParameterHtml() {\n return composer.escapeParameter;\n },\n set escapeParameterHtml(val) {\n composer.escapeParameter = val;\n },\n // pluralizationRules\n get pluralizationRules() {\n return composer.pluralRules || {};\n },\n // for internal\n __composer: composer,\n // t\n t(...args) {\n return Reflect.apply(composer.t, composer, [...args]);\n },\n // rt\n rt(...args) {\n return Reflect.apply(composer.rt, composer, [...args]);\n },\n // te\n te(key, locale) {\n return composer.te(key, locale);\n },\n // tm\n tm(key) {\n return composer.tm(key);\n },\n // getLocaleMessage\n getLocaleMessage(locale) {\n return composer.getLocaleMessage(locale);\n },\n // setLocaleMessage\n setLocaleMessage(locale, message) {\n composer.setLocaleMessage(locale, message);\n },\n // mergeLocaleMessage\n mergeLocaleMessage(locale, message) {\n composer.mergeLocaleMessage(locale, message);\n },\n // d\n d(...args) {\n return Reflect.apply(composer.d, composer, [...args]);\n },\n // getDateTimeFormat\n getDateTimeFormat(locale) {\n return composer.getDateTimeFormat(locale);\n },\n // setDateTimeFormat\n setDateTimeFormat(locale, format) {\n composer.setDateTimeFormat(locale, format);\n },\n // mergeDateTimeFormat\n mergeDateTimeFormat(locale, format) {\n composer.mergeDateTimeFormat(locale, format);\n },\n // n\n n(...args) {\n return Reflect.apply(composer.n, composer, [...args]);\n },\n // getNumberFormat\n getNumberFormat(locale) {\n return composer.getNumberFormat(locale);\n },\n // setNumberFormat\n setNumberFormat(locale, format) {\n composer.setNumberFormat(locale, format);\n },\n // mergeNumberFormat\n mergeNumberFormat(locale, format) {\n composer.mergeNumberFormat(locale, format);\n }\n };\n vueI18n.__extender = __extender;\n // for vue-devtools timeline event\n if ((process.env.NODE_ENV !== 'production')) {\n vueI18n.__enableEmitter = (emitter) => {\n const __composer = composer;\n __composer[EnableEmitter] && __composer[EnableEmitter](emitter);\n };\n vueI18n.__disableEmitter = () => {\n const __composer = composer;\n __composer[DisableEmitter] && __composer[DisableEmitter]();\n };\n }\n return vueI18n;\n}\n/* eslint-enable @typescript-eslint/no-explicit-any */\n\n/**\n * Supports compatibility for legacy vue-i18n APIs\n * This mixin is used when we use vue-i18n@v9.x or later\n */\nfunction defineMixin(vuei18n, composer, i18n) {\n return {\n beforeCreate() {\n const instance = getCurrentInstance();\n /* istanbul ignore if */\n if (!instance) {\n throw createI18nError(I18nErrorCodes.UNEXPECTED_ERROR);\n }\n const options = this.$options;\n if (options.i18n) {\n const optionsI18n = options.i18n;\n if (options.__i18n) {\n optionsI18n.__i18n = options.__i18n;\n }\n optionsI18n.__root = composer;\n if (this === this.$root) {\n // merge option and gttach global\n this.$i18n = mergeToGlobal(vuei18n, optionsI18n);\n }\n else {\n optionsI18n.__injectWithOption = true;\n optionsI18n.__extender = i18n.__vueI18nExtend;\n // atttach local VueI18n instance\n this.$i18n = createVueI18n(optionsI18n);\n // extend VueI18n instance\n const _vueI18n = this.$i18n;\n if (_vueI18n.__extender) {\n _vueI18n.__disposer = _vueI18n.__extender(this.$i18n);\n }\n }\n }\n else if (options.__i18n) {\n if (this === this.$root) {\n // merge option and gttach global\n this.$i18n = mergeToGlobal(vuei18n, options);\n }\n else {\n // atttach local VueI18n instance\n this.$i18n = createVueI18n({\n __i18n: options.__i18n,\n __injectWithOption: true,\n __extender: i18n.__vueI18nExtend,\n __root: composer\n });\n // extend VueI18n instance\n const _vueI18n = this.$i18n;\n if (_vueI18n.__extender) {\n _vueI18n.__disposer = _vueI18n.__extender(this.$i18n);\n }\n }\n }\n else {\n // attach global VueI18n instance\n this.$i18n = vuei18n;\n }\n if (options.__i18nGlobal) {\n adjustI18nResources(composer, options, options);\n }\n // defines vue-i18n legacy APIs\n this.$t = (...args) => this.$i18n.t(...args);\n this.$rt = (...args) => this.$i18n.rt(...args);\n this.$te = (key, locale) => this.$i18n.te(key, locale);\n this.$d = (...args) => this.$i18n.d(...args);\n this.$n = (...args) => this.$i18n.n(...args);\n this.$tm = (key) => this.$i18n.tm(key);\n i18n.__setInstance(instance, this.$i18n);\n },\n mounted() {\n /* istanbul ignore if */\n if (((process.env.NODE_ENV !== 'production') || __VUE_PROD_DEVTOOLS__) &&\n !false &&\n this.$i18n) {\n const instance = getCurrentInstance();\n if (!instance) {\n return;\n }\n const _vueI18n = this.$i18n;\n instance.__VUE_I18N__ = _vueI18n.__composer;\n const emitter = (this.__v_emitter =\n createEmitter());\n _vueI18n.__enableEmitter && _vueI18n.__enableEmitter(emitter);\n emitter.on('*', addTimelineEvent);\n }\n },\n unmounted() {\n const instance = getCurrentInstance();\n /* istanbul ignore if */\n if (!instance) {\n throw createI18nError(I18nErrorCodes.UNEXPECTED_ERROR);\n }\n const _vueI18n = this.$i18n;\n /* istanbul ignore if */\n if (((process.env.NODE_ENV !== 'production') || __VUE_PROD_DEVTOOLS__) &&\n !false &&\n instance.__VUE_I18N__) {\n if (this.__v_emitter) {\n this.__v_emitter.off('*', addTimelineEvent);\n delete this.__v_emitter;\n }\n if (this.$i18n) {\n _vueI18n.__disableEmitter && _vueI18n.__disableEmitter();\n delete instance.__VUE_I18N__;\n }\n }\n delete this.$t;\n delete this.$rt;\n delete this.$te;\n delete this.$d;\n delete this.$n;\n delete this.$tm;\n if (_vueI18n.__disposer) {\n _vueI18n.__disposer();\n delete _vueI18n.__disposer;\n delete _vueI18n.__extender;\n }\n i18n.__deleteInstance(instance);\n delete this.$i18n;\n }\n };\n}\nfunction mergeToGlobal(g, options) {\n g.locale = options.locale || g.locale;\n g.fallbackLocale = options.fallbackLocale || g.fallbackLocale;\n g.missing = options.missing || g.missing;\n g.silentTranslationWarn =\n options.silentTranslationWarn || g.silentFallbackWarn;\n g.silentFallbackWarn = options.silentFallbackWarn || g.silentFallbackWarn;\n g.formatFallbackMessages =\n options.formatFallbackMessages || g.formatFallbackMessages;\n g.postTranslation = options.postTranslation || g.postTranslation;\n g.warnHtmlInMessage = options.warnHtmlInMessage || g.warnHtmlInMessage;\n g.escapeParameterHtml = options.escapeParameterHtml || g.escapeParameterHtml;\n g.sync = options.sync || g.sync;\n g.__composer[SetPluralRulesSymbol](options.pluralizationRules || g.pluralizationRules);\n const messages = getLocaleMessages(g.locale, {\n messages: options.messages,\n __i18n: options.__i18n\n });\n Object.keys(messages).forEach(locale => g.mergeLocaleMessage(locale, messages[locale]));\n if (options.datetimeFormats) {\n Object.keys(options.datetimeFormats).forEach(locale => g.mergeDateTimeFormat(locale, options.datetimeFormats[locale]));\n }\n if (options.numberFormats) {\n Object.keys(options.numberFormats).forEach(locale => g.mergeNumberFormat(locale, options.numberFormats[locale]));\n }\n return g;\n}\n\nconst baseFormatProps = {\n tag: {\n type: [String, Object]\n },\n locale: {\n type: String\n },\n scope: {\n type: String,\n // NOTE: avoid https://github.com/microsoft/rushstack/issues/1050\n validator: (val /* ComponentI18nScope */) => val === 'parent' || val === 'global',\n default: 'parent' /* ComponentI18nScope */\n },\n i18n: {\n type: Object\n }\n};\n\nfunction getInterpolateArg(\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\n{ slots }, // SetupContext,\nkeys) {\n if (keys.length === 1 && keys[0] === 'default') {\n // default slot with list\n const ret = slots.default ? slots.default() : [];\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return ret.reduce((slot, current) => {\n return [\n ...slot,\n // prettier-ignore\n ...(current.type === Fragment ? current.children : [current])\n ];\n }, []);\n }\n else {\n // named slots\n return keys.reduce((arg, key) => {\n const slot = slots[key];\n if (slot) {\n arg[key] = slot();\n }\n return arg;\n }, create());\n }\n}\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction getFragmentableTag() {\n return Fragment;\n}\n\nconst TranslationImpl = /*#__PURE__*/ defineComponent({\n /* eslint-disable */\n name: 'i18n-t',\n props: assign({\n keypath: {\n type: String,\n required: true\n },\n plural: {\n type: [Number, String],\n validator: (val) => isNumber(val) || !isNaN(val)\n }\n }, baseFormatProps),\n /* eslint-enable */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n setup(props, context) {\n const { slots, attrs } = context;\n // NOTE: avoid https://github.com/microsoft/rushstack/issues/1050\n const i18n = props.i18n ||\n useI18n({\n useScope: props.scope,\n __useComponent: true\n });\n return () => {\n const keys = Object.keys(slots).filter(key => key[0] !== '_');\n const options = create();\n if (props.locale) {\n options.locale = props.locale;\n }\n if (props.plural !== undefined) {\n options.plural = isString(props.plural) ? +props.plural : props.plural;\n }\n const arg = getInterpolateArg(context, keys);\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const children = i18n[TranslateVNodeSymbol](props.keypath, arg, options);\n const assignedAttrs = assign(create(), attrs);\n const tag = isString(props.tag) || isObject(props.tag)\n ? props.tag\n : getFragmentableTag();\n return h(tag, assignedAttrs, children);\n };\n }\n});\n/**\n * export the public type for h/tsx inference\n * also to avoid inline import() in generated d.ts files\n */\n/**\n * Translation Component\n *\n * @remarks\n * See the following items for property about details\n *\n * @VueI18nSee [TranslationProps](component#translationprops)\n * @VueI18nSee [BaseFormatProps](component#baseformatprops)\n * @VueI18nSee [Component Interpolation](../guide/advanced/component)\n *\n * @example\n * ```html\n * <div id=\"app\">\n * <!-- ... -->\n * <i18n keypath=\"term\" tag=\"label\" for=\"tos\">\n * <a :href=\"url\" target=\"_blank\">{{ $t('tos') }}</a>\n * </i18n>\n * <!-- ... -->\n * </div>\n * ```\n * ```js\n * import { createApp } from 'vue'\n * import { createI18n } from 'vue-i18n'\n *\n * const messages = {\n * en: {\n * tos: 'Term of Service',\n * term: 'I accept xxx {0}.'\n * },\n * ja: {\n * tos: '利用規約',\n * term: '私は xxx の{0}に同意します。'\n * }\n * }\n *\n * const i18n = createI18n({\n * locale: 'en',\n * messages\n * })\n *\n * const app = createApp({\n * data: {\n * url: '/term'\n * }\n * }).use(i18n).mount('#app')\n * ```\n *\n * @VueI18nComponent\n */\nconst Translation = TranslationImpl;\nconst I18nT = Translation;\n\nfunction isVNode(target) {\n return isArray(target) && !isString(target[0]);\n}\nfunction renderFormatter(props, context, slotKeys, partFormatter) {\n const { slots, attrs } = context;\n return () => {\n const options = { part: true };\n let overrides = create();\n if (props.locale) {\n options.locale = props.locale;\n }\n if (isString(props.format)) {\n options.key = props.format;\n }\n else if (isObject(props.format)) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n if (isString(props.format.key)) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n options.key = props.format.key;\n }\n // Filter out number format options only\n overrides = Object.keys(props.format).reduce((options, prop) => {\n return slotKeys.includes(prop)\n ? assign(create(), options, { [prop]: props.format[prop] }) // eslint-disable-line @typescript-eslint/no-explicit-any\n : options;\n }, create());\n }\n const parts = partFormatter(...[props.value, options, overrides]);\n let children = [options.key];\n if (isArray(parts)) {\n children = parts.map((part, index) => {\n const slot = slots[part.type];\n const node = slot\n ? slot({ [part.type]: part.value, index, parts })\n : [part.value];\n if (isVNode(node)) {\n node[0].key = `${part.type}-${index}`;\n }\n return node;\n });\n }\n else if (isString(parts)) {\n children = [parts];\n }\n const assignedAttrs = assign(create(), attrs);\n const tag = isString(props.tag) || isObject(props.tag)\n ? props.tag\n : getFragmentableTag();\n return h(tag, assignedAttrs, children);\n };\n}\n\nconst NumberFormatImpl = /*#__PURE__*/ defineComponent({\n /* eslint-disable */\n name: 'i18n-n',\n props: assign({\n value: {\n type: Number,\n required: true\n },\n format: {\n type: [String, Object]\n }\n }, baseFormatProps),\n /* eslint-enable */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n setup(props, context) {\n const i18n = props.i18n ||\n useI18n({\n useScope: props.scope,\n __useComponent: true\n });\n return renderFormatter(props, context, NUMBER_FORMAT_OPTIONS_KEYS, (...args) => \n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n i18n[NumberPartsSymbol](...args));\n }\n});\n/**\n * export the public type for h/tsx inference\n * also to avoid inline import() in generated d.ts files\n */\n/**\n * Number Format Component\n *\n * @remarks\n * See the following items for property about details\n *\n * @VueI18nSee [FormattableProps](component#formattableprops)\n * @VueI18nSee [BaseFormatProps](component#baseformatprops)\n * @VueI18nSee [Custom Formatting](../guide/essentials/number#custom-formatting)\n *\n * @VueI18nDanger\n * Not supported IE, due to no support `Intl.NumberFormat#formatToParts` in [IE](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl/NumberFormat/formatToParts)\n *\n * If you want to use it, you need to use [polyfill](https://github.com/formatjs/formatjs/tree/main/packages/intl-numberformat)\n *\n * @VueI18nComponent\n */\nconst NumberFormat = NumberFormatImpl;\nconst I18nN = NumberFormat;\n\nfunction getComposer$1(i18n, instance) {\n const i18nInternal = i18n;\n if (i18n.mode === 'composition') {\n return (i18nInternal.__getInstance(instance) || i18n.global);\n }\n else {\n const vueI18n = i18nInternal.__getInstance(instance);\n return vueI18n != null\n ? vueI18n.__composer\n : i18n.global.__composer;\n }\n}\n/**\n * @deprecated will be removed at vue-i18n v12\n */\nfunction vTDirective(i18n) {\n const _process = (binding) => {\n if ((process.env.NODE_ENV !== 'production')) {\n warnOnce(getWarnMessage(I18nWarnCodes.DEPRECATE_TRANSLATE_CUSTOME_DIRECTIVE));\n }\n const { instance, value } = binding;\n /* istanbul ignore if */\n if (!instance || !instance.$) {\n throw createI18nError(I18nErrorCodes.UNEXPECTED_ERROR);\n }\n const composer = getComposer$1(i18n, instance.$);\n const parsedValue = parseValue(value);\n return [\n Reflect.apply(composer.t, composer, [...makeParams(parsedValue)]),\n composer\n ];\n };\n const register = (el, binding) => {\n const [textContent, composer] = _process(binding);\n if (inBrowser) {\n el.__i18nWatcher = watch(composer.locale, () => {\n binding.instance && binding.instance.$forceUpdate();\n });\n }\n el.__composer = composer;\n el.textContent = textContent;\n };\n const unregister = (el) => {\n if (inBrowser && el.__i18nWatcher) {\n el.__i18nWatcher();\n el.__i18nWatcher = undefined;\n delete el.__i18nWatcher;\n }\n if (el.__composer) {\n el.__composer = undefined;\n delete el.__composer;\n }\n };\n const update = (el, { value }) => {\n if (el.__composer) {\n const composer = el.__composer;\n const parsedValue = parseValue(value);\n el.textContent = Reflect.apply(composer.t, composer, [\n ...makeParams(parsedValue)\n ]);\n }\n };\n const getSSRProps = (binding) => {\n const [textContent] = _process(binding);\n return { textContent };\n };\n return {\n created: register,\n unmounted: unregister,\n beforeUpdate: update,\n getSSRProps\n };\n}\nfunction parseValue(value) {\n if (isString(value)) {\n return { path: value };\n }\n else if (isPlainObject(value)) {\n if (!('path' in value)) {\n throw createI18nError(I18nErrorCodes.REQUIRED_VALUE, 'path');\n }\n return value;\n }\n else {\n throw createI18nError(I18nErrorCodes.INVALID_VALUE);\n }\n}\nfunction makeParams(value) {\n const { path, locale, args, choice, plural } = value;\n const options = {};\n const named = args || {};\n if (isString(locale)) {\n options.locale = locale;\n }\n if (isNumber(choice)) {\n options.plural = choice;\n }\n if (isNumber(plural)) {\n options.plural = plural;\n }\n return [path, named, options];\n}\n\nfunction apply(app, i18n, ...options) {\n const pluginOptions = isPlainObject(options[0])\n ? options[0]\n : {};\n const globalInstall = isBoolean(pluginOptions.globalInstall)\n ? pluginOptions.globalInstall\n : true;\n if (globalInstall) {\n [Translation.name, 'I18nT'].forEach(name => app.component(name, Translation));\n [NumberFormat.name, 'I18nN'].forEach(name => app.component(name, NumberFormat));\n [DatetimeFormat.name, 'I18nD'].forEach(name => app.component(name, DatetimeFormat));\n }\n // install directive\n {\n app.directive('t', vTDirective(i18n));\n }\n}\n\n/**\n * Injection key for {@link useI18n}\n *\n * @remarks\n * The global injection key for I18n instances with `useI18n`. this injection key is used in Web Components.\n * Specify the i18n instance created by {@link createI18n} together with `provide` function.\n *\n * @VueI18nGeneral\n */\nconst I18nInjectionKey = \n/* #__PURE__*/ makeSymbol('global-vue-i18n');\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction createI18n(options = {}) {\n // prettier-ignore\n const __legacyMode = __VUE_I18N_LEGACY_API__ && isBoolean(options.legacy)\n ? options.legacy\n : __VUE_I18N_LEGACY_API__;\n if ((process.env.NODE_ENV !== 'production') && __legacyMode) {\n warnOnce(getWarnMessage(I18nWarnCodes.DEPRECATE_LEGACY_MODE));\n }\n // prettier-ignore\n const __globalInjection = isBoolean(options.globalInjection)\n ? options.globalInjection\n : true;\n const __instances = new Map();\n const [globalScope, __global] = createGlobal(options, __legacyMode);\n const symbol = /* #__PURE__*/ makeSymbol((process.env.NODE_ENV !== 'production') ? 'vue-i18n' : '');\n function __getInstance(component) {\n return __instances.get(component) || null;\n }\n function __setInstance(component, instance) {\n __instances.set(component, instance);\n }\n function __deleteInstance(component) {\n __instances.delete(component);\n }\n const i18n = {\n // mode\n get mode() {\n return __VUE_I18N_LEGACY_API__ && __legacyMode\n ? 'legacy'\n : 'composition';\n },\n // install plugin\n async install(app, ...options) {\n if (((process.env.NODE_ENV !== 'production') || __VUE_PROD_DEVTOOLS__) && !false) {\n app.__VUE_I18N__ = i18n;\n }\n // setup global provider\n app.__VUE_I18N_SYMBOL__ = symbol;\n app.provide(app.__VUE_I18N_SYMBOL__, i18n);\n // set composer & vuei18n extend hook options from plugin options\n if (isPlainObject(options[0])) {\n const opts = options[0];\n i18n.__composerExtend =\n opts.__composerExtend;\n i18n.__vueI18nExtend =\n opts.__vueI18nExtend;\n }\n // global method and properties injection for Composition API\n let globalReleaseHandler = null;\n if (!__legacyMode && __globalInjection) {\n globalReleaseHandler = injectGlobalFields(app, i18n.global);\n }\n // install built-in components and directive\n if (__VUE_I18N_FULL_INSTALL__) {\n apply(app, i18n, ...options);\n }\n // setup mixin for Legacy API\n if (__VUE_I18N_LEGACY_API__ && __legacyMode) {\n app.mixin(defineMixin(__global, __global.__composer, i18n));\n }\n // release global scope\n const unmountApp = app.unmount;\n app.unmount = () => {\n globalReleaseHandler && globalReleaseHandler();\n i18n.dispose();\n unmountApp();\n };\n // setup vue-devtools plugin\n if (((process.env.NODE_ENV !== 'production') || __VUE_PROD_DEVTOOLS__) && !false) {\n const ret = await enableDevTools(app, i18n);\n if (!ret) {\n throw createI18nError(I18nErrorCodes.CANNOT_SETUP_VUE_DEVTOOLS_PLUGIN);\n }\n const emitter = createEmitter();\n if (__legacyMode) {\n const _vueI18n = __global;\n _vueI18n.__enableEmitter && _vueI18n.__enableEmitter(emitter);\n }\n else {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const _composer = __global;\n _composer[EnableEmitter] && _composer[EnableEmitter](emitter);\n }\n emitter.on('*', addTimelineEvent);\n }\n },\n // global accessor\n get global() {\n return __global;\n },\n dispose() {\n globalScope.stop();\n },\n // @internal\n __instances,\n // @internal\n __getInstance,\n // @internal\n __setInstance,\n // @internal\n __deleteInstance\n };\n return i18n;\n}\nfunction useI18n(options = {}) {\n const instance = getCurrentInstance();\n if (instance == null) {\n throw createI18nError(I18nErrorCodes.MUST_BE_CALL_SETUP_TOP);\n }\n if (!instance.isCE &&\n instance.appContext.app != null &&\n !instance.appContext.app.__VUE_I18N_SYMBOL__) {\n throw createI18nError(I18nErrorCodes.NOT_INSTALLED);\n }\n const i18n = getI18nInstance(instance);\n const gl = getGlobalComposer(i18n);\n const componentOptions = getComponentOptions(instance);\n const scope = getScope(options, componentOptions);\n if (scope === 'global') {\n adjustI18nResources(gl, options, componentOptions);\n return gl;\n }\n if (scope === 'parent') {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let composer = getComposer(i18n, instance, options.__useComponent);\n if (composer == null) {\n if ((process.env.NODE_ENV !== 'production')) {\n warn(getWarnMessage(I18nWarnCodes.NOT_FOUND_PARENT_SCOPE));\n }\n composer = gl;\n }\n return composer;\n }\n const i18nInternal = i18n;\n let composer = i18nInternal.__getInstance(instance);\n if (composer == null) {\n const composerOptions = assign({}, options);\n if ('__i18n' in componentOptions) {\n composerOptions.__i18n = componentOptions.__i18n;\n }\n if (gl) {\n composerOptions.__root = gl;\n }\n composer = createComposer(composerOptions);\n if (i18nInternal.__composerExtend) {\n composer[DisposeSymbol] =\n i18nInternal.__composerExtend(composer);\n }\n setupLifeCycle(i18nInternal, instance, composer);\n i18nInternal.__setInstance(instance, composer);\n }\n else {\n if ((process.env.NODE_ENV !== 'production') && scope === 'local') {\n warn(getWarnMessage(I18nWarnCodes.DUPLICATE_USE_I18N_CALLING));\n }\n }\n return composer;\n}\nfunction createGlobal(options, legacyMode) {\n const scope = effectScope();\n const obj = __VUE_I18N_LEGACY_API__ && legacyMode\n ? scope.run(() => createVueI18n(options))\n : scope.run(() => createComposer(options));\n if (obj == null) {\n throw createI18nError(I18nErrorCodes.UNEXPECTED_ERROR);\n }\n return [scope, obj];\n}\nfunction getI18nInstance(instance) {\n const i18n = inject(!instance.isCE\n ? instance.appContext.app.__VUE_I18N_SYMBOL__\n : I18nInjectionKey);\n /* istanbul ignore if */\n if (!i18n) {\n throw createI18nError(!instance.isCE\n ? I18nErrorCodes.UNEXPECTED_ERROR\n : I18nErrorCodes.NOT_INSTALLED_WITH_PROVIDE);\n }\n return i18n;\n}\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction getScope(options, componentOptions) {\n // prettier-ignore\n return isEmptyObject(options)\n ? ('__i18n' in componentOptions)\n ? 'local'\n : 'global'\n : !options.useScope\n ? 'local'\n : options.useScope;\n}\nfunction getGlobalComposer(i18n) {\n // prettier-ignore\n return i18n.mode === 'composition'\n ? i18n.global\n : i18n.global.__composer;\n}\nfunction getComposer(i18n, target, useComponent = false) {\n let composer = null;\n const root = target.root;\n let current = getParentComponentInstance(target, useComponent);\n while (current != null) {\n const i18nInternal = i18n;\n if (i18n.mode === 'composition') {\n composer = i18nInternal.__getInstance(current);\n }\n else {\n if (__VUE_I18N_LEGACY_API__) {\n const vueI18n = i18nInternal.__getInstance(current);\n if (vueI18n != null) {\n composer = vueI18n\n .__composer;\n if (useComponent &&\n composer &&\n !composer[InejctWithOptionSymbol] // eslint-disable-line @typescript-eslint/no-explicit-any\n ) {\n composer = null;\n }\n }\n }\n }\n if (composer != null) {\n break;\n }\n if (root === current) {\n break;\n }\n current = current.parent;\n }\n return composer;\n}\nfunction getParentComponentInstance(target, useComponent = false) {\n if (target == null) {\n return null;\n }\n // if `useComponent: true` will be specified, we get lexical scope owner instance for use-case slots\n return !useComponent\n ? target.parent\n : target.vnode.ctx || target.parent; // eslint-disable-line @typescript-eslint/no-explicit-any\n}\nfunction setupLifeCycle(i18n, target, composer) {\n let emitter = null;\n onMounted(() => {\n // inject composer instance to DOM for intlify-devtools\n if (((process.env.NODE_ENV !== 'production') || __VUE_PROD_DEVTOOLS__) && !false) {\n target.__VUE_I18N__ = composer;\n emitter = createEmitter();\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const _composer = composer;\n _composer[EnableEmitter] && _composer[EnableEmitter](emitter);\n emitter.on('*', addTimelineEvent);\n }\n }, target);\n onUnmounted(() => {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const _composer = composer;\n // remove composer instance from DOM for intlify-devtools\n if (((process.env.NODE_ENV !== 'production') || __VUE_PROD_DEVTOOLS__) && !false) {\n emitter && emitter.off('*', addTimelineEvent);\n _composer[DisableEmitter] && _composer[DisableEmitter]();\n delete target.__VUE_I18N__;\n }\n i18n.__deleteInstance(target);\n // dispose extended resources\n const dispose = _composer[DisposeSymbol];\n if (dispose) {\n dispose();\n delete _composer[DisposeSymbol];\n }\n }, target);\n}\nconst globalExportProps = [\n 'locale',\n 'fallbackLocale',\n 'availableLocales'\n];\nconst globalExportMethods = ['t', 'rt', 'd', 'n', 'tm', 'te']\n ;\nfunction injectGlobalFields(app, composer) {\n const i18n = Object.create(null);\n globalExportProps.forEach(prop => {\n const desc = Object.getOwnPropertyDescriptor(composer, prop);\n if (!desc) {\n throw createI18nError(I18nErrorCodes.UNEXPECTED_ERROR);\n }\n const wrap = isRef(desc.value) // check computed props\n ? {\n get() {\n return desc.value.value;\n },\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n set(val) {\n desc.value.value = val;\n }\n }\n : {\n get() {\n return desc.get && desc.get();\n }\n };\n Object.defineProperty(i18n, prop, wrap);\n });\n app.config.globalProperties.$i18n = i18n;\n globalExportMethods.forEach(method => {\n const desc = Object.getOwnPropertyDescriptor(composer, method);\n if (!desc || !desc.value) {\n throw createI18nError(I18nErrorCodes.UNEXPECTED_ERROR);\n }\n Object.defineProperty(app.config.globalProperties, `$${method}`, desc);\n });\n const dispose = () => {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n delete app.config.globalProperties.$i18n;\n globalExportMethods.forEach(method => {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n delete app.config.globalProperties[`$${method}`];\n });\n };\n return dispose;\n}\n\nconst DatetimeFormatImpl = /* #__PURE__*/ defineComponent({\n /* eslint-disable */\n name: 'i18n-d',\n props: assign({\n value: {\n type: [Number, Date],\n required: true\n },\n format: {\n type: [String, Object]\n }\n }, baseFormatProps),\n /* eslint-enable */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n setup(props, context) {\n const i18n = props.i18n ||\n useI18n({\n useScope: props.scope,\n __useComponent: true\n });\n return renderFormatter(props, context, DATETIME_FORMAT_OPTIONS_KEYS, (...args) => \n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n i18n[DatetimePartsSymbol](...args));\n }\n});\n/**\n * Datetime Format Component\n *\n * @remarks\n * See the following items for property about details\n *\n * @VueI18nSee [FormattableProps](component#formattableprops)\n * @VueI18nSee [BaseFormatProps](component#baseformatprops)\n * @VueI18nSee [Custom Formatting](../guide/essentials/datetime#custom-formatting)\n *\n * @VueI18nDanger\n * Not supported IE, due to no support `Intl.DateTimeFormat#formatToParts` in [IE](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl/DateTimeFormat/formatToParts)\n *\n * If you want to use it, you need to use [polyfill](https://github.com/formatjs/formatjs/tree/main/packages/intl-datetimeformat)\n *\n * @VueI18nComponent\n */\nconst DatetimeFormat = DatetimeFormatImpl;\nconst I18nD = DatetimeFormat;\n\n{\n initFeatureFlags();\n}\n// register message compiler at vue-i18n\nregisterMessageCompiler(compile);\n// register message resolver at vue-i18n\nregisterMessageResolver(resolveValue);\n// register fallback locale at vue-i18n\nregisterLocaleFallbacker(fallbackWithLocaleChain);\n// NOTE: experimental !!\nif ((process.env.NODE_ENV !== 'production') || __INTLIFY_PROD_DEVTOOLS__) {\n const target = getGlobalThis();\n target.__INTLIFY__ = true;\n setDevToolsHook(target.__INTLIFY_DEVTOOLS_GLOBAL_HOOK__);\n}\nif ((process.env.NODE_ENV !== 'production')) ;\n\nexport { DatetimeFormat, I18nD, I18nInjectionKey, I18nN, I18nT, NumberFormat, Translation, VERSION, createI18n, useI18n, vTDirective };\n","interface ICropRect {\n x: number\n y: number\n width: number\n height: number\n}\n\nenum EHandleName {\n TopLeft = 'top-left',\n Top = 'top',\n TopRight = 'top-right',\n Right = 'right',\n BottomRight = 'bottom-right',\n Bottom = 'bottom',\n BottomLeft = 'bottom-left',\n Left = 'left',\n}\n\ninterface IImageCropperProps {\n image?: File\n cropAsCircle?: boolean\n outputAsCircle?: boolean\n lockAspectRatio?: boolean\n showPreview?: boolean\n}\n\nexport { ICropRect, EHandleName, IImageCropperProps }\n","<template>\n <div class=\"nb-image-cropper\">\n <div\n class=\"canvas-container\"\n @mousedown=\"onCanvasMouseDown\"\n @mousemove=\"onMouseMove\"\n @mouseup=\"onMouseUp\"\n @mouseleave=\"onMouseUp\"\n @touchstart=\"onCanvasMouseDown\"\n @touchmove=\"onMouseMove\"\n @touchend=\"onMouseUp\"\n >\n <canvas ref=\"canvas\"></canvas>\n <div\n v-for=\"handle in handles\"\n :key=\"handle.name\"\n :class=\"['resize-handle', handle.name]\"\n :style=\"handlePositions[handle.name]\"\n @mousedown.stop=\"startResize($event, handle.name)\"\n @touchstart.stop=\"startResize($event, handle.name)\"\n ></div>\n </div>\n <NbGrid\n v-if=\"showPreview && croppedImageUrl && cropGeometry\"\n class=\"cropped-image-preview\"\n >\n <NbGrid is=\"ul\" dir=\"col\" justify=\"center\" gap=\"sm\">\n <li>\n <strong>{{ t('common.X') }}</strong> {{ cropGeometry.x.toFixed(0) }}\n </li>\n <li>\n <strong>{{ t('common.Y') }}</strong> {{ cropGeometry.y.toFixed(0) }}\n </li>\n <li>\n <strong>{{ t('common.WIDTH') }}</strong>\n {{ cropGeometry.width.toFixed(0) }}\n </li>\n <li>\n <strong>{{ t('common.HEIGHT') }}</strong>\n {{ cropGeometry.height.toFixed(0) }}\n </li>\n </NbGrid>\n <img :src=\"croppedImageUrl\" :alt=\"t('common.IMAGE_THUMBNAIL')\" />\n </NbGrid>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { ref, onMounted, computed, watch, onBeforeUnmount } from 'vue'\nimport { useI18n } from 'vue-i18n'\nimport { ICropRect, EHandleName, IImageCropperProps } from './ImageCropper.d'\n\nconst { t } = useI18n({})\n\nconst props = withDefaults(defineProps<IImageCropperProps>(), {\n cropAsCircle: false,\n outputAsCircle: false,\n lockAspectRatio: false,\n showPreview: false,\n})\n\nconst emit = defineEmits<{\n crop: [payload: { blob: Blob; geometry: ICropRect }]\n}>()\n\nconst canvas = ref<HTMLCanvasElement | null>(null)\nlet ctx: CanvasRenderingContext2D | null = null\nconst img = new Image()\nlet sourceImageUrl: string | null = null\n\nconst DISPLAY_WIDTH = 700\nconst DISPLAY_HEIGHT = 400\nlet scale = { x: 1, y: 1 }\n\nconst cropRect = ref<ICropRect>({ x: 50, y: 50, width: 200, height: 200 })\nconst croppedImageUrl = ref<string | null>(null)\nconst cropGeometry = ref<ICropRect | null>(null)\n\nlet isDragging = false\nlet isDraggingCrop = false\nlet dragStart = { x: 0, y: 0 }\n\nlet isResizing = false\nlet resizeStart = { x: 0, y: 0 }\nlet initialCropRect = { x: 0, y: 0, width: 0, height: 0 }\nlet currentHandle: EHandleName | null = null\nlet isShiftPressed = false\n\nconst handles: Array<{ name: EHandleName }> = [\n { name: EHandleName.TopLeft },\n { name: EHandleName.Top },\n { name: EHandleName.TopRight },\n { name: EHandleName.Right },\n { name: EHandleName.BottomRight },\n { name: EHandleName.Bottom },\n { name: EHandleName.BottomLeft },\n { name: EHandleName.Left },\n]\n\nconst loadImage = () => {\n if (!props.image) {\n console.error('No image file provided')\n return\n }\n\n if (sourceImageUrl) {\n URL.revokeObjectURL(sourceImageUrl)\n sourceImageUrl = null\n }\n\n img.onload = () => {\n const { drawWidth, drawHeight } = calculateScale()\n\n if (canvas.value) {\n // Set canvas size to match the rendered image dimensions.\n canvas.value.width = drawWidth\n canvas.value.height = drawHeight\n\n const offsetX = (canvas.value.width - img.width * scale.x) / 2\n const offsetY = (canvas.value.height - img.height * scale.y) / 2\n\n // if cropping as a circle or locking the aspect ratio, use a square crop.\n if (props.cropAsCircle || props.lockAspectRatio) {\n const minDimension = Math.min(img.width * scale.x, img.height * scale.y)\n const initialCropSize = minDimension * 0.5\n cropRect.value = {\n x: offsetX + (img.width * scale.x - initialCropSize) / 2,\n y: offsetY + (img.height * scale.y - initialCropSize) / 2,\n width: initialCropSize,\n height: initialCropSize,\n }\n } else {\n // otherwise, set initial crop to 50% of the image dimensions.\n cropRect.value = {\n x: offsetX + (img.width * scale.x * 0.5 - img.width * scale.x * 0.25),\n y:\n offsetY +\n (img.height * scale.y * 0.5 - img.height * scale.y * 0.25),\n width: img.width * scale.x * 0.5,\n height: img.height * scale.y * 0.5,\n }\n }\n\n drawImage()\n cropImage()\n }\n }\n img.onerror = () => {\n console.error('Failed to load image')\n }\n sourceImageUrl = URL.createObjectURL(props.image)\n img.src = sourceImageUrl\n}\n\nonMounted(() => {\n if (canvas.value) {\n ctx = canvas.value.getContext('2d')\n if (ctx) {\n // enable antialiasing for smoother drawing\n ctx.imageSmoothingEnabled = true\n ctx.imageSmoothingQuality = 'high'\n }\n if (props.image) {\n loadImage()\n }\n }\n})\n\nonBeforeUnmount(() => {\n if (sourceImageUrl) {\n URL.revokeObjectURL(sourceImageUrl)\n sourceImageUrl = null\n }\n const currentPreviewUrl = croppedImageUrl.value\n if (currentPreviewUrl) {\n URL.revokeObjectURL(currentPreviewUrl)\n croppedImageUrl.value = null\n }\n})\n\nwatch(\n () => props.image,\n (newImage) => {\n if (newImage) {\n loadImage()\n }\n },\n)\n\n// watch for prop changes that affect the crop area\nwatch(\n () => [props.cropAsCircle, props.outputAsCircle, props.lockAspectRatio],\n () => {\n if (canvas.value && ctx) {\n // redraw the canvas to reflect prop changes\n drawImage()\n }\n },\n)\n\nconst calculateScale = () => {\n const aspectRatio = img.width / img.height\n let drawWidth = DISPLAY_WIDTH\n let drawHeight = DISPLAY_HEIGHT\n\n if (aspectRatio > DISPLAY_WIDTH / DISPLAY_HEIGHT) {\n drawHeight = DISPLAY_WIDTH / aspectRatio\n } else {\n drawWidth = DISPLAY_HEIGHT * aspectRatio\n }\n\n scale.x = drawWidth / img.width\n scale.y = drawHeight / img.height\n return { drawWidth, drawHeight }\n}\n\nconst drawImage = () => {\n if (ctx && canvas.value) {\n ctx.clearRect(0, 0, canvas.value.width, canvas.value.height)\n // center the image on the canvas\n const offsetX = (canvas.value.width - img.width * scale.x) / 2\n const offsetY = (canvas.value.height - img.height * scale.y) / 2\n ctx.drawImage(\n img,\n 0,\n 0,\n img.width,\n img.height,\n offsetX,\n offsetY,\n img.width * scale.x,\n img.height * scale.y,\n )\n drawOverlay()\n }\n}\n\nconst drawOverlay = () => {\n if (ctx && canvas.value) {\n ctx.save()\n\n // draw the dimming overlay\n ctx.beginPath()\n if (props.cropAsCircle) {\n ctx.arc(\n cropRect.value.x + cropRect.value.width / 2,\n cropRect.value.y + cropRect.value.height / 2,\n cropRect.value.width / 2,\n 0,\n Math.PI * 2,\n )\n } else {\n ctx.rect(\n cropRect.value.x,\n cropRect.value.y,\n cropRect.value.width,\n cropRect.value.height,\n )\n }\n ctx.rect(0, 0, canvas.value.width, canvas.value.height)\n ctx.clip('evenodd')\n ctx.fillStyle = 'rgba(0, 0, 0, 0.5)'\n ctx.fillRect(0, 0, canvas.value.width, canvas.value.height)\n\n // draw the crop area outline\n ctx.restore()\n ctx.save()\n ctx.strokeStyle = 'rgba(255, 255, 255, 0.8)'\n ctx.lineWidth = 1\n ctx.setLineDash([5, 5])\n // disable antialiasing for crisp outlines\n ctx.imageSmoothingEnabled = false\n\n if (props.cropAsCircle) {\n ctx.beginPath()\n ctx.arc(\n cropRect.value.x + cropRect.value.width / 2,\n cropRect.value.y + cropRect.value.height / 2,\n cropRect.value.width / 2,\n 0,\n Math.PI * 2,\n )\n ctx.stroke()\n } else {\n ctx.strokeRect(\n cropRect.value.x,\n cropRect.value.y,\n cropRect.value.width,\n cropRect.value.height,\n )\n }\n\n ctx.restore()\n }\n}\n\n// compute handle positions based on crop area shape\nconst handlePositions = computed<\n Record<EHandleName, { left: string; top: string }>\n>(() => {\n if (props.cropAsCircle) {\n // for circle, position handles at the circle's boundary points\n const centerX = cropRect.value.x + cropRect.value.width / 2\n const centerY = cropRect.value.y + cropRect.value.height / 2\n const radius = cropRect.value.width / 2\n\n return {\n 'top-left': {\n left: `${centerX - radius - 5}px`,\n top: `${centerY - radius - 5}px`,\n },\n top: { left: `${centerX - 5}px`, top: `${centerY - radius - 5}px` },\n 'top-right': {\n left: `${centerX + radius - 5}px`,\n top: `${centerY - radius - 5}px`,\n },\n right: { left: `${centerX + radius - 5}px`, top: `${centerY - 5}px` },\n 'bottom-right': {\n left: `${centerX + radius - 5}px`,\n top: `${centerY + radius - 5}px`,\n },\n bottom: { left: `${centerX - 5}px`, top: `${centerY + radius - 5}px` },\n 'bottom-left': {\n left: `${centerX - radius - 5}px`,\n top: `${centerY + radius - 5}px`,\n },\n left: { left: `${centerX - radius - 5}px`, top: `${centerY - 5}px` },\n }\n } else {\n // for rectangle, position handles at corners and edges\n return {\n 'top-left': {\n left: `${cropRect.value.x - 5}px`,\n top: `${cropRect.value.y - 5}px`,\n },\n top: {\n left: `${cropRect.value.x + cropRect.value.width / 2 - 5}px`,\n top: `${cropRect.value.y - 5}px`,\n },\n 'top-right': {\n left: `${cropRect.value.x + cropRect.value.width - 5}px`,\n top: `${cropRect.value.y - 5}px`,\n },\n right: {\n left: `${cropRect.value.x + cropRect.value.width - 5}px`,\n top: `${cropRect.value.y + cropRect.value.height / 2 - 5}px`,\n },\n 'bottom-right': {\n left: `${cropRect.value.x + cropRect.value.width - 5}px`,\n top: `${cropRect.value.y + cropRect.value.height - 5}px`,\n },\n bottom: {\n left: `${cropRect.value.x + cropRect.value.width / 2 - 5}px`,\n top: `${cropRect.value.y + cropRect.value.height - 5}px`,\n },\n 'bottom-left': {\n left: `${cropRect.value.x - 5}px`,\n top: `${cropRect.value.y + cropRect.value.height - 5}px`,\n },\n left: {\n left: `${cropRect.value.x - 5}px`,\n top: `${cropRect.value.y + cropRect.value.height / 2 - 5}px`,\n },\n }\n }\n})\n\nconst getClientCoordinates = (event: MouseEvent | TouchEvent) => {\n if ('touches' in event && event.touches.length > 0) {\n const touch = event.touches[0]\n return { clientX: touch.clientX, clientY: touch.clientY }\n } else if ('clientX' in event && 'clientY' in event) {\n return { clientX: event.clientX, clientY: event.clientY }\n }\n return { clientX: 0, clientY: 0 }\n}\n\nconst getCanvasPoint = (event: MouseEvent | TouchEvent) => {\n const canvasEl = canvas.value\n if (!canvasEl) return null\n const { clientX, clientY } = getClientCoordinates(event)\n const { left, top } = canvasEl.getBoundingClientRect()\n return { x: clientX - left, y: clientY - top }\n}\n\nconst onCanvasMouseDown = (event: MouseEvent | TouchEvent) => {\n event.preventDefault()\n const point = getCanvasPoint(event)\n if (!point) return\n const { x, y } = point\n if (isInCropArea(x, y)) {\n isDraggingCrop = true\n isDragging = true\n dragStart = { x: x - cropRect.value.x, y: y - cropRect.value.y }\n }\n}\n\nconst onMouseMove = (event: MouseEvent | TouchEvent) => {\n if (isDraggingCrop) {\n onDrag(event)\n } else if (isResizing) {\n onResize(event)\n }\n}\n\nconst onMouseUp = () => {\n if (isDraggingCrop) {\n endDrag()\n isDraggingCrop = false\n cropImage()\n }\n if (isResizing) {\n endResize()\n cropImage()\n }\n // reset drag state to ensure clean state\n isDragging = false\n isDraggingCrop = false\n}\n\nconst onDrag = (event: MouseEvent | TouchEvent) => {\n if (isDragging) {\n const point = getCanvasPoint(event)\n if (!point) return\n const { x, y } = point\n\n // use Math.floor to avoid off-by-one issues when dragging to top/left edges.\n cropRect.value.x = Math.floor(x - dragStart.x)\n cropRect.value.y = Math.floor(y - dragStart.y)\n // don't constrain during drag, let it move freely\n drawImage()\n }\n}\n\nconst endDrag = () => {\n if (isDragging) {\n // apply constraints only when dragging ends\n constrainCropRect()\n drawImage()\n isDragging = false\n }\n}\n\nconst startResize = (\n event: MouseEvent | TouchEvent,\n handleName: EHandleName,\n) => {\n event.preventDefault()\n const point = getCanvasPoint(event)\n if (!point) return\n isResizing = true\n currentHandle = handleName\n resizeStart = { x: point.x, y: point.y }\n initialCropRect = { ...cropRect.value }\n isShiftPressed = event instanceof MouseEvent && event.shiftKey\n}\n\nconst onResize = (event: MouseEvent | TouchEvent) => {\n if (!isResizing) return\n\n // in lockAspectRatio mode, perform a symmetric resize (keeping center fixed)\n if (props.lockAspectRatio && canvas.value) {\n const point = getCanvasPoint(event)\n if (!point) return\n const { x, y } = point\n const centerX = initialCropRect.x + initialCropRect.width / 2\n const centerY = initialCropRect.y + initialCropRect.height / 2\n\n if (props.cropAsCircle) {\n // for circle mode with locked aspect ratio, enforce square\n const halfSize = Math.max(Math.abs(x - centerX), Math.abs(y - centerY))\n const newSize = halfSize * 2\n cropRect.value = {\n x: centerX - halfSize,\n y: centerY - halfSize,\n width: newSize,\n height: newSize,\n }\n } else {\n // for rectangle mode with locked aspect ratio, maintain original aspect ratio\n const aspectRatio = initialCropRect.width / initialCropRect.height\n const dx = Math.abs(x - centerX)\n const newWidth = Math.max(dx * 2, 50)\n const newHeight = newWidth / aspectRatio\n cropRect.value = {\n x: centerX - newWidth / 2,\n y: centerY - newHeight / 2,\n width: newWidth,\n height: newHeight,\n }\n }\n // don't constrain during resize, let it grow beyond bounds\n drawImage()\n return\n }\n\n // non-locked (free) resizing\n const point = getCanvasPoint(event)\n if (!point) return\n const { x, y } = point\n const dx = x - resizeStart.x\n const dy = y - resizeStart.y\n\n isShiftPressed = event instanceof MouseEvent && event.shiftKey\n\n const newCropRect = { ...initialCropRect }\n\n switch (currentHandle) {\n case 'top-left':\n newCropRect.x += dx\n newCropRect.y += dy\n newCropRect.width -= dx\n newCropRect.height -= dy\n break\n case 'top':\n newCropRect.y += dy\n newCropRect.height -= dy\n break\n case 'top-right':\n newCropRect.y += dy\n newCropRect.width += dx\n newCropRect.height -= dy\n break\n case 'right':\n newCropRect.width += dx\n break\n case 'bottom-right':\n newCropRect.width += dx\n newCropRect.height += dy\n break\n case 'bottom':\n newCropRect.height += dy\n break\n case 'bottom-left':\n newCropRect.x += dx\n newCropRect.width -= dx\n newCropRect.height += dy\n break\n case 'left':\n newCropRect.x += dx\n newCropRect.width -= dx\n break\n }\n\n // prevent negative dimensions\n if (newCropRect.width < 50) newCropRect.width = 50\n if (newCropRect.height < 50) newCropRect.height = 50\n\n if (isShiftPressed && currentHandle) {\n const aspectRatio = initialCropRect.width / initialCropRect.height\n if (['left', 'right'].includes(currentHandle)) {\n newCropRect.height = newCropRect.width / aspectRatio\n if (currentHandle === 'left') {\n newCropRect.y =\n initialCropRect.y - (newCropRect.height - initialCropRect.height) / 2\n }\n } else if (['top', 'bottom'].includes(currentHandle)) {\n newCropRect.width = newCropRect.height * aspectRatio\n if (currentHandle === 'top') {\n newCropRect.x =\n initialCropRect.x - (newCropRect.width - initialCropRect.width) / 2\n }\n }\n }\n\n cropRect.value = newCropRect\n // don't constrain during resize, let it grow beyond bounds\n drawImage()\n}\n\nconst endResize = () => {\n if (isResizing) {\n // apply constraints only when resizing ends\n constrainCropRect()\n drawImage()\n isResizing = false\n currentHandle = null\n }\n}\n\nconst isInCropArea = (x: number, y: number) => {\n if (props.cropAsCircle) {\n const centerX = cropRect.value.x + cropRect.value.width / 2\n const centerY = cropRect.value.y + cropRect.value.height / 2\n const radius = cropRect.value.width / 2\n const dx = x - centerX\n const dy = y - centerY\n return dx * dx + dy * dy <= radius * radius\n } else {\n // add a small tolerance for better drag detection\n const tolerance = 2\n return (\n x >= cropRect.value.x - tolerance &&\n x <= cropRect.value.x + cropRect.value.width + tolerance &&\n y >= cropRect.value.y - tolerance &&\n y <= cropRect.value.y + cropRect.value.height + tolerance\n )\n }\n}\n\nconst constrainCropRect = () => {\n const maxX = canvas.value!.width\n const maxY = canvas.value!.height\n\n // ensure minimum size\n if (cropRect.value.width < 50) cropRect.value.width = 50\n if (cropRect.value.height < 50) cropRect.value.height = 50\n\n // if lockAspectRatio is true, enforce aspect ratio constraints\n if (props.lockAspectRatio) {\n if (props.cropAsCircle) {\n // for circle mode with locked aspect ratio, enforce square\n cropRect.value.height = cropRect.value.width\n } else {\n // for rectangle mode with locked aspect ratio, maintain original aspect ratio\n const aspectRatio = initialCropRect.width / initialCropRect.height\n cropRect.value.height = cropRect.value.width / aspectRatio\n }\n } else if (isShiftPressed) {\n // when shift is pressed, maintain aspect ratio temporarily\n const aspectRatio = initialCropRect.width / initialCropRect.height\n cropRect.value.height = cropRect.value.width / aspectRatio\n }\n\n // for circle or locked aspect ratio, maintain the aspect ratio when constraining\n if (props.cropAsCircle || props.lockAspectRatio) {\n const aspectRatio = cropRect.value.width / cropRect.value.height\n\n // if the crop area is too large, scale it down while maintaining aspect ratio\n if (cropRect.value.width > maxX || cropRect.value.height > maxY) {\n if (cropRect.value.width > cropRect.value.height) {\n cropRect.value.width = maxX\n cropRect.value.height = maxX / aspectRatio\n } else {\n cropRect.value.height = maxY\n cropRect.value.width = maxY * aspectRatio\n }\n }\n\n // ensure it stays within bounds, only move if it's actually outside\n if (cropRect.value.x < 0) cropRect.value.x = 0\n if (cropRect.value.y < 0) cropRect.value.y = 0\n if (cropRect.value.x + cropRect.value.width > maxX) {\n cropRect.value.x = maxX - cropRect.value.width\n }\n if (cropRect.value.y + cropRect.value.height > maxY) {\n cropRect.value.y = maxY - cropRect.value.height\n }\n } else {\n // for free resize, use the original logic\n // constrain position to keep crop area within canvas bounds\n if (cropRect.value.x < 0) cropRect.value.x = 0\n if (cropRect.value.y < 0) cropRect.value.y = 0\n\n // if crop area is larger than canvas, center it\n if (cropRect.value.width > maxX) {\n cropRect.value.width = maxX\n cropRect.value.x = 0\n }\n if (cropRect.value.height > maxY) {\n cropRect.value.height = maxY\n cropRect.value.y = 0\n }\n\n // ensure crop area doesn't extend beyond canvas bounds\n if (cropRect.value.x + cropRect.value.width > maxX) {\n cropRect.value.x = maxX - cropRect.value.width\n }\n if (cropRect.value.y + cropRect.value.height > maxY) {\n cropRect.value.y = maxY - cropRect.value.height\n }\n }\n}\n\nconst cropImage = () => {\n if (canvas.value && ctx) {\n const offsetX = (canvas.value.width - img.width * scale.x) / 2\n const offsetY = (canvas.value.height - img.height * scale.y) / 2\n\n const sx = (cropRect.value.x - offsetX) / scale.x\n const sy = (cropRect.value.y - offsetY) / scale.y\n const sWidth = cropRect.value.width / scale.x\n const sHeight = cropRect.value.height / scale.y\n\n const geometry = {\n x: Math.round(sx),\n y: Math.round(sy),\n width: Math.round(sWidth),\n height: Math.round(sHeight),\n }\n\n // clamp the crop area to the actual image bounds\n const clampedSX = Math.max(0, Math.min(geometry.x, img.width))\n const clampedSY = Math.max(0, Math.min(geometry.y, img.height))\n const clampedSWidth = Math.min(geometry.width, img.width - clampedSX)\n const clampedSHeight = Math.min(geometry.height, img.height - clampedSY)\n\n const croppedCanvas = document.createElement('canvas')\n croppedCanvas.width = clampedSWidth\n croppedCanvas.height = clampedSHeight\n const croppedCtx = croppedCanvas.getContext('2d')\n if (croppedCtx) {\n croppedCtx.drawImage(\n img,\n clampedSX,\n clampedSY,\n clampedSWidth,\n clampedSHeight,\n 0,\n 0,\n clampedSWidth,\n clampedSHeight,\n )\n\n if (props.cropAsCircle && props.outputAsCircle) {\n croppedCtx.globalCompositeOperation = 'destination-in'\n croppedCtx.beginPath()\n croppedCtx.arc(\n clampedSWidth / 2,\n clampedSHeight / 2,\n clampedSWidth / 2,\n 0,\n Math.PI * 2,\n )\n croppedCtx.closePath()\n croppedCtx.fill()\n croppedCtx.globalCompositeOperation = 'source-over'\n }\n\n // expose the cropped image via the `crop` event\n croppedCanvas.toBlob(\n (blob) => {\n if (blob) {\n const oldPreviewUrl = croppedImageUrl.value\n if (oldPreviewUrl) {\n URL.revokeObjectURL(oldPreviewUrl)\n }\n croppedImageUrl.value = URL.createObjectURL(blob)\n cropGeometry.value = geometry\n emit('crop', { blob, geometry })\n }\n },\n 'image/jpeg',\n 0.8,\n )\n }\n }\n}\n\nwatch(\n () => props,\n () => {\n cropImage()\n },\n { deep: true },\n)\n</script>\n\n<style lang=\"scss\" scoped>\n$handle-size: 10px;\n$handle-offset: -7px;\n$border-color: black;\n$background-color: white;\n\n.nb-image-cropper {\n position: relative;\n user-select: none;\n display: inline-block;\n max-width: 100%;\n height: auto;\n overflow: hidden;\n\n .canvas-container {\n position: relative;\n display: inline-block;\n width: 100%;\n height: auto;\n\n canvas {\n display: block;\n max-width: 100%;\n height: auto;\n }\n }\n\n .resize-handle {\n position: absolute;\n width: 10px;\n height: 10px;\n background: white;\n border: 1px solid black;\n z-index: 1;\n\n &.top-left {\n cursor: nwse-resize;\n }\n\n &.top {\n cursor: ns-resize;\n }\n\n &.top-right {\n cursor: nesw-resize;\n }\n\n &.right {\n cursor: ew-resize;\n }\n\n &.bottom-right {\n cursor: nwse-resize;\n }\n\n &.bottom {\n cursor: ns-resize;\n }\n\n &.bottom-left {\n cursor: nesw-resize;\n }\n\n &.left {\n cursor: ew-resize;\n }\n }\n\n .cropped-image-preview {\n position: absolute;\n right: calc(var(--nb-base-unit, 8px) * 2);\n bottom: calc(var(--nb-base-unit, 8px) * 2);\n border-radius: var(--nb-border-radius-sm, 6px);\n overflow: hidden;\n height: calc(var(--nb-base-unit, 8px) * 14);\n margin-top: 20px;\n border: dotted 1px var(--nb-c-component-border, #e0e0e0);\n background: var(--nb-c-backdrop, #fff);\n user-select: none;\n pointer-events: none;\n ul {\n min-width: calc(var(--nb-base-unit, 8px) * 9);\n background: black;\n color: white;\n font-size: var(--nb-font-size-10, 10px);\n padding: calc(var(--nb-base-unit, 8px) / 2);\n line-height: var(--nb-font-size-14, 14px);\n }\n img {\n width: 100%;\n height: 100%;\n object-fit: contain;\n object-position: center;\n }\n }\n}\n</style>\n","<template>\n <div class=\"nb-image-cropper\">\n <div\n class=\"canvas-container\"\n @mousedown=\"onCanvasMouseDown\"\n @mousemove=\"onMouseMove\"\n @mouseup=\"onMouseUp\"\n @mouseleave=\"onMouseUp\"\n @touchstart=\"onCanvasMouseDown\"\n @touchmove=\"onMouseMove\"\n @touchend=\"onMouseUp\"\n >\n <canvas ref=\"canvas\"></canvas>\n <div\n v-for=\"handle in handles\"\n :key=\"handle.name\"\n :class=\"['resize-handle', handle.name]\"\n :style=\"handlePositions[handle.name]\"\n @mousedown.stop=\"startResize($event, handle.name)\"\n @touchstart.stop=\"startResize($event, handle.name)\"\n ></div>\n </div>\n <NbGrid\n v-if=\"showPreview && croppedImageUrl && cropGeometry\"\n class=\"cropped-image-preview\"\n >\n <NbGrid is=\"ul\" dir=\"col\" justify=\"center\" gap=\"sm\">\n <li>\n <strong>{{ t('common.X') }}</strong> {{ cropGeometry.x.toFixed(0) }}\n </li>\n <li>\n <strong>{{ t('common.Y') }}</strong> {{ cropGeometry.y.toFixed(0) }}\n </li>\n <li>\n <strong>{{ t('common.WIDTH') }}</strong>\n {{ cropGeometry.width.toFixed(0) }}\n </li>\n <li>\n <strong>{{ t('common.HEIGHT') }}</strong>\n {{ cropGeometry.height.toFixed(0) }}\n </li>\n </NbGrid>\n <img :src=\"croppedImageUrl\" :alt=\"t('common.IMAGE_THUMBNAIL')\" />\n </NbGrid>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { ref, onMounted, computed, watch, onBeforeUnmount } from 'vue'\nimport { useI18n } from 'vue-i18n'\nimport { ICropRect, EHandleName, IImageCropperProps } from './ImageCropper.d'\n\nconst { t } = useI18n({})\n\nconst props = withDefaults(defineProps<IImageCropperProps>(), {\n cropAsCircle: false,\n outputAsCircle: false,\n lockAspectRatio: false,\n showPreview: false,\n})\n\nconst emit = defineEmits<{\n crop: [payload: { blob: Blob; geometry: ICropRect }]\n}>()\n\nconst canvas = ref<HTMLCanvasElement | null>(null)\nlet ctx: CanvasRenderingContext2D | null = null\nconst img = new Image()\nlet sourceImageUrl: string | null = null\n\nconst DISPLAY_WIDTH = 700\nconst DISPLAY_HEIGHT = 400\nlet scale = { x: 1, y: 1 }\n\nconst cropRect = ref<ICropRect>({ x: 50, y: 50, width: 200, height: 200 })\nconst croppedImageUrl = ref<string | null>(null)\nconst cropGeometry = ref<ICropRect | null>(null)\n\nlet isDragging = false\nlet isDraggingCrop = false\nlet dragStart = { x: 0, y: 0 }\n\nlet isResizing = false\nlet resizeStart = { x: 0, y: 0 }\nlet initialCropRect = { x: 0, y: 0, width: 0, height: 0 }\nlet currentHandle: EHandleName | null = null\nlet isShiftPressed = false\n\nconst handles: Array<{ name: EHandleName }> = [\n { name: EHandleName.TopLeft },\n { name: EHandleName.Top },\n { name: EHandleName.TopRight },\n { name: EHandleName.Right },\n { name: EHandleName.BottomRight },\n { name: EHandleName.Bottom },\n { name: EHandleName.BottomLeft },\n { name: EHandleName.Left },\n]\n\nconst loadImage = () => {\n if (!props.image) {\n console.error('No image file provided')\n return\n }\n\n if (sourceImageUrl) {\n URL.revokeObjectURL(sourceImageUrl)\n sourceImageUrl = null\n }\n\n img.onload = () => {\n const { drawWidth, drawHeight } = calculateScale()\n\n if (canvas.value) {\n // Set canvas size to match the rendered image dimensions.\n canvas.value.width = drawWidth\n canvas.value.height = drawHeight\n\n const offsetX = (canvas.value.width - img.width * scale.x) / 2\n const offsetY = (canvas.value.height - img.height * scale.y) / 2\n\n // if cropping as a circle or locking the aspect ratio, use a square crop.\n if (props.cropAsCircle || props.lockAspectRatio) {\n const minDimension = Math.min(img.width * scale.x, img.height * scale.y)\n const initialCropSize = minDimension * 0.5\n cropRect.value = {\n x: offsetX + (img.width * scale.x - initialCropSize) / 2,\n y: offsetY + (img.height * scale.y - initialCropSize) / 2,\n width: initialCropSize,\n height: initialCropSize,\n }\n } else {\n // otherwise, set initial crop to 50% of the image dimensions.\n cropRect.value = {\n x: offsetX + (img.width * scale.x * 0.5 - img.width * scale.x * 0.25),\n y:\n offsetY +\n (img.height * scale.y * 0.5 - img.height * scale.y * 0.25),\n width: img.width * scale.x * 0.5,\n height: img.height * scale.y * 0.5,\n }\n }\n\n drawImage()\n cropImage()\n }\n }\n img.onerror = () => {\n console.error('Failed to load image')\n }\n sourceImageUrl = URL.createObjectURL(props.image)\n img.src = sourceImageUrl\n}\n\nonMounted(() => {\n if (canvas.value) {\n ctx = canvas.value.getContext('2d')\n if (ctx) {\n // enable antialiasing for smoother drawing\n ctx.imageSmoothingEnabled = true\n ctx.imageSmoothingQuality = 'high'\n }\n if (props.image) {\n loadImage()\n }\n }\n})\n\nonBeforeUnmount(() => {\n if (sourceImageUrl) {\n URL.revokeObjectURL(sourceImageUrl)\n sourceImageUrl = null\n }\n const currentPreviewUrl = croppedImageUrl.value\n if (currentPreviewUrl) {\n URL.revokeObjectURL(currentPreviewUrl)\n croppedImageUrl.value = null\n }\n})\n\nwatch(\n () => props.image,\n (newImage) => {\n if (newImage) {\n loadImage()\n }\n },\n)\n\n// watch for prop changes that affect the crop area\nwatch(\n () => [props.cropAsCircle, props.outputAsCircle, props.lockAspectRatio],\n () => {\n if (canvas.value && ctx) {\n // redraw the canvas to reflect prop changes\n drawImage()\n }\n },\n)\n\nconst calculateScale = () => {\n const aspectRatio = img.width / img.height\n let drawWidth = DISPLAY_WIDTH\n let drawHeight = DISPLAY_HEIGHT\n\n if (aspectRatio > DISPLAY_WIDTH / DISPLAY_HEIGHT) {\n drawHeight = DISPLAY_WIDTH / aspectRatio\n } else {\n drawWidth = DISPLAY_HEIGHT * aspectRatio\n }\n\n scale.x = drawWidth / img.width\n scale.y = drawHeight / img.height\n return { drawWidth, drawHeight }\n}\n\nconst drawImage = () => {\n if (ctx && canvas.value) {\n ctx.clearRect(0, 0, canvas.value.width, canvas.value.height)\n // center the image on the canvas\n const offsetX = (canvas.value.width - img.width * scale.x) / 2\n const offsetY = (canvas.value.height - img.height * scale.y) / 2\n ctx.drawImage(\n img,\n 0,\n 0,\n img.width,\n img.height,\n offsetX,\n offsetY,\n img.width * scale.x,\n img.height * scale.y,\n )\n drawOverlay()\n }\n}\n\nconst drawOverlay = () => {\n if (ctx && canvas.value) {\n ctx.save()\n\n // draw the dimming overlay\n ctx.beginPath()\n if (props.cropAsCircle) {\n ctx.arc(\n cropRect.value.x + cropRect.value.width / 2,\n cropRect.value.y + cropRect.value.height / 2,\n cropRect.value.width / 2,\n 0,\n Math.PI * 2,\n )\n } else {\n ctx.rect(\n cropRect.value.x,\n cropRect.value.y,\n cropRect.value.width,\n cropRect.value.height,\n )\n }\n ctx.rect(0, 0, canvas.value.width, canvas.value.height)\n ctx.clip('evenodd')\n ctx.fillStyle = 'rgba(0, 0, 0, 0.5)'\n ctx.fillRect(0, 0, canvas.value.width, canvas.value.height)\n\n // draw the crop area outline\n ctx.restore()\n ctx.save()\n ctx.strokeStyle = 'rgba(255, 255, 255, 0.8)'\n ctx.lineWidth = 1\n ctx.setLineDash([5, 5])\n // disable antialiasing for crisp outlines\n ctx.imageSmoothingEnabled = false\n\n if (props.cropAsCircle) {\n ctx.beginPath()\n ctx.arc(\n cropRect.value.x + cropRect.value.width / 2,\n cropRect.value.y + cropRect.value.height / 2,\n cropRect.value.width / 2,\n 0,\n Math.PI * 2,\n )\n ctx.stroke()\n } else {\n ctx.strokeRect(\n cropRect.value.x,\n cropRect.value.y,\n cropRect.value.width,\n cropRect.value.height,\n )\n }\n\n ctx.restore()\n }\n}\n\n// compute handle positions based on crop area shape\nconst handlePositions = computed<\n Record<EHandleName, { left: string; top: string }>\n>(() => {\n if (props.cropAsCircle) {\n // for circle, position handles at the circle's boundary points\n const centerX = cropRect.value.x + cropRect.value.width / 2\n const centerY = cropRect.value.y + cropRect.value.height / 2\n const radius = cropRect.value.width / 2\n\n return {\n 'top-left': {\n left: `${centerX - radius - 5}px`,\n top: `${centerY - radius - 5}px`,\n },\n top: { left: `${centerX - 5}px`, top: `${centerY - radius - 5}px` },\n 'top-right': {\n left: `${centerX + radius - 5}px`,\n top: `${centerY - radius - 5}px`,\n },\n right: { left: `${centerX + radius - 5}px`, top: `${centerY - 5}px` },\n 'bottom-right': {\n left: `${centerX + radius - 5}px`,\n top: `${centerY + radius - 5}px`,\n },\n bottom: { left: `${centerX - 5}px`, top: `${centerY + radius - 5}px` },\n 'bottom-left': {\n left: `${centerX - radius - 5}px`,\n top: `${centerY + radius - 5}px`,\n },\n left: { left: `${centerX - radius - 5}px`, top: `${centerY - 5}px` },\n }\n } else {\n // for rectangle, position handles at corners and edges\n return {\n 'top-left': {\n left: `${cropRect.value.x - 5}px`,\n top: `${cropRect.value.y - 5}px`,\n },\n top: {\n left: `${cropRect.value.x + cropRect.value.width / 2 - 5}px`,\n top: `${cropRect.value.y - 5}px`,\n },\n 'top-right': {\n left: `${cropRect.value.x + cropRect.value.width - 5}px`,\n top: `${cropRect.value.y - 5}px`,\n },\n right: {\n left: `${cropRect.value.x + cropRect.value.width - 5}px`,\n top: `${cropRect.value.y + cropRect.value.height / 2 - 5}px`,\n },\n 'bottom-right': {\n left: `${cropRect.value.x + cropRect.value.width - 5}px`,\n top: `${cropRect.value.y + cropRect.value.height - 5}px`,\n },\n bottom: {\n left: `${cropRect.value.x + cropRect.value.width / 2 - 5}px`,\n top: `${cropRect.value.y + cropRect.value.height - 5}px`,\n },\n 'bottom-left': {\n left: `${cropRect.value.x - 5}px`,\n top: `${cropRect.value.y + cropRect.value.height - 5}px`,\n },\n left: {\n left: `${cropRect.value.x - 5}px`,\n top: `${cropRect.value.y + cropRect.value.height / 2 - 5}px`,\n },\n }\n }\n})\n\nconst getClientCoordinates = (event: MouseEvent | TouchEvent) => {\n if ('touches' in event && event.touches.length > 0) {\n const touch = event.touches[0]\n return { clientX: touch.clientX, clientY: touch.clientY }\n } else if ('clientX' in event && 'clientY' in event) {\n return { clientX: event.clientX, clientY: event.clientY }\n }\n return { clientX: 0, clientY: 0 }\n}\n\nconst getCanvasPoint = (event: MouseEvent | TouchEvent) => {\n const canvasEl = canvas.value\n if (!canvasEl) return null\n const { clientX, clientY } = getClientCoordinates(event)\n const { left, top } = canvasEl.getBoundingClientRect()\n return { x: clientX - left, y: clientY - top }\n}\n\nconst onCanvasMouseDown = (event: MouseEvent | TouchEvent) => {\n event.preventDefault()\n const point = getCanvasPoint(event)\n if (!point) return\n const { x, y } = point\n if (isInCropArea(x, y)) {\n isDraggingCrop = true\n isDragging = true\n dragStart = { x: x - cropRect.value.x, y: y - cropRect.value.y }\n }\n}\n\nconst onMouseMove = (event: MouseEvent | TouchEvent) => {\n if (isDraggingCrop) {\n onDrag(event)\n } else if (isResizing) {\n onResize(event)\n }\n}\n\nconst onMouseUp = () => {\n if (isDraggingCrop) {\n endDrag()\n isDraggingCrop = false\n cropImage()\n }\n if (isResizing) {\n endResize()\n cropImage()\n }\n // reset drag state to ensure clean state\n isDragging = false\n isDraggingCrop = false\n}\n\nconst onDrag = (event: MouseEvent | TouchEvent) => {\n if (isDragging) {\n const point = getCanvasPoint(event)\n if (!point) return\n const { x, y } = point\n\n // use Math.floor to avoid off-by-one issues when dragging to top/left edges.\n cropRect.value.x = Math.floor(x - dragStart.x)\n cropRect.value.y = Math.floor(y - dragStart.y)\n // don't constrain during drag, let it move freely\n drawImage()\n }\n}\n\nconst endDrag = () => {\n if (isDragging) {\n // apply constraints only when dragging ends\n constrainCropRect()\n drawImage()\n isDragging = false\n }\n}\n\nconst startResize = (\n event: MouseEvent | TouchEvent,\n handleName: EHandleName,\n) => {\n event.preventDefault()\n const point = getCanvasPoint(event)\n if (!point) return\n isResizing = true\n currentHandle = handleName\n resizeStart = { x: point.x, y: point.y }\n initialCropRect = { ...cropRect.value }\n isShiftPressed = event instanceof MouseEvent && event.shiftKey\n}\n\nconst onResize = (event: MouseEvent | TouchEvent) => {\n if (!isResizing) return\n\n // in lockAspectRatio mode, perform a symmetric resize (keeping center fixed)\n if (props.lockAspectRatio && canvas.value) {\n const point = getCanvasPoint(event)\n if (!point) return\n const { x, y } = point\n const centerX = initialCropRect.x + initialCropRect.width / 2\n const centerY = initialCropRect.y + initialCropRect.height / 2\n\n if (props.cropAsCircle) {\n // for circle mode with locked aspect ratio, enforce square\n const halfSize = Math.max(Math.abs(x - centerX), Math.abs(y - centerY))\n const newSize = halfSize * 2\n cropRect.value = {\n x: centerX - halfSize,\n y: centerY - halfSize,\n width: newSize,\n height: newSize,\n }\n } else {\n // for rectangle mode with locked aspect ratio, maintain original aspect ratio\n const aspectRatio = initialCropRect.width / initialCropRect.height\n const dx = Math.abs(x - centerX)\n const newWidth = Math.max(dx * 2, 50)\n const newHeight = newWidth / aspectRatio\n cropRect.value = {\n x: centerX - newWidth / 2,\n y: centerY - newHeight / 2,\n width: newWidth,\n height: newHeight,\n }\n }\n // don't constrain during resize, let it grow beyond bounds\n drawImage()\n return\n }\n\n // non-locked (free) resizing\n const point = getCanvasPoint(event)\n if (!point) return\n const { x, y } = point\n const dx = x - resizeStart.x\n const dy = y - resizeStart.y\n\n isShiftPressed = event instanceof MouseEvent && event.shiftKey\n\n const newCropRect = { ...initialCropRect }\n\n switch (currentHandle) {\n case 'top-left':\n newCropRect.x += dx\n newCropRect.y += dy\n newCropRect.width -= dx\n newCropRect.height -= dy\n break\n case 'top':\n newCropRect.y += dy\n newCropRect.height -= dy\n break\n case 'top-right':\n newCropRect.y += dy\n newCropRect.width += dx\n newCropRect.height -= dy\n break\n case 'right':\n newCropRect.width += dx\n break\n case 'bottom-right':\n newCropRect.width += dx\n newCropRect.height += dy\n break\n case 'bottom':\n newCropRect.height += dy\n break\n case 'bottom-left':\n newCropRect.x += dx\n newCropRect.width -= dx\n newCropRect.height += dy\n break\n case 'left':\n newCropRect.x += dx\n newCropRect.width -= dx\n break\n }\n\n // prevent negative dimensions\n if (newCropRect.width < 50) newCropRect.width = 50\n if (newCropRect.height < 50) newCropRect.height = 50\n\n if (isShiftPressed && currentHandle) {\n const aspectRatio = initialCropRect.width / initialCropRect.height\n if (['left', 'right'].includes(currentHandle)) {\n newCropRect.height = newCropRect.width / aspectRatio\n if (currentHandle === 'left') {\n newCropRect.y =\n initialCropRect.y - (newCropRect.height - initialCropRect.height) / 2\n }\n } else if (['top', 'bottom'].includes(currentHandle)) {\n newCropRect.width = newCropRect.height * aspectRatio\n if (currentHandle === 'top') {\n newCropRect.x =\n initialCropRect.x - (newCropRect.width - initialCropRect.width) / 2\n }\n }\n }\n\n cropRect.value = newCropRect\n // don't constrain during resize, let it grow beyond bounds\n drawImage()\n}\n\nconst endResize = () => {\n if (isResizing) {\n // apply constraints only when resizing ends\n constrainCropRect()\n drawImage()\n isResizing = false\n currentHandle = null\n }\n}\n\nconst isInCropArea = (x: number, y: number) => {\n if (props.cropAsCircle) {\n const centerX = cropRect.value.x + cropRect.value.width / 2\n const centerY = cropRect.value.y + cropRect.value.height / 2\n const radius = cropRect.value.width / 2\n const dx = x - centerX\n const dy = y - centerY\n return dx * dx + dy * dy <= radius * radius\n } else {\n // add a small tolerance for better drag detection\n const tolerance = 2\n return (\n x >= cropRect.value.x - tolerance &&\n x <= cropRect.value.x + cropRect.value.width + tolerance &&\n y >= cropRect.value.y - tolerance &&\n y <= cropRect.value.y + cropRect.value.height + tolerance\n )\n }\n}\n\nconst constrainCropRect = () => {\n const maxX = canvas.value!.width\n const maxY = canvas.value!.height\n\n // ensure minimum size\n if (cropRect.value.width < 50) cropRect.value.width = 50\n if (cropRect.value.height < 50) cropRect.value.height = 50\n\n // if lockAspectRatio is true, enforce aspect ratio constraints\n if (props.lockAspectRatio) {\n if (props.cropAsCircle) {\n // for circle mode with locked aspect ratio, enforce square\n cropRect.value.height = cropRect.value.width\n } else {\n // for rectangle mode with locked aspect ratio, maintain original aspect ratio\n const aspectRatio = initialCropRect.width / initialCropRect.height\n cropRect.value.height = cropRect.value.width / aspectRatio\n }\n } else if (isShiftPressed) {\n // when shift is pressed, maintain aspect ratio temporarily\n const aspectRatio = initialCropRect.width / initialCropRect.height\n cropRect.value.height = cropRect.value.width / aspectRatio\n }\n\n // for circle or locked aspect ratio, maintain the aspect ratio when constraining\n if (props.cropAsCircle || props.lockAspectRatio) {\n const aspectRatio = cropRect.value.width / cropRect.value.height\n\n // if the crop area is too large, scale it down while maintaining aspect ratio\n if (cropRect.value.width > maxX || cropRect.value.height > maxY) {\n if (cropRect.value.width > cropRect.value.height) {\n cropRect.value.width = maxX\n cropRect.value.height = maxX / aspectRatio\n } else {\n cropRect.value.height = maxY\n cropRect.value.width = maxY * aspectRatio\n }\n }\n\n // ensure it stays within bounds, only move if it's actually outside\n if (cropRect.value.x < 0) cropRect.value.x = 0\n if (cropRect.value.y < 0) cropRect.value.y = 0\n if (cropRect.value.x + cropRect.value.width > maxX) {\n cropRect.value.x = maxX - cropRect.value.width\n }\n if (cropRect.value.y + cropRect.value.height > maxY) {\n cropRect.value.y = maxY - cropRect.value.height\n }\n } else {\n // for free resize, use the original logic\n // constrain position to keep crop area within canvas bounds\n if (cropRect.value.x < 0) cropRect.value.x = 0\n if (cropRect.value.y < 0) cropRect.value.y = 0\n\n // if crop area is larger than canvas, center it\n if (cropRect.value.width > maxX) {\n cropRect.value.width = maxX\n cropRect.value.x = 0\n }\n if (cropRect.value.height > maxY) {\n cropRect.value.height = maxY\n cropRect.value.y = 0\n }\n\n // ensure crop area doesn't extend beyond canvas bounds\n if (cropRect.value.x + cropRect.value.width > maxX) {\n cropRect.value.x = maxX - cropRect.value.width\n }\n if (cropRect.value.y + cropRect.value.height > maxY) {\n cropRect.value.y = maxY - cropRect.value.height\n }\n }\n}\n\nconst cropImage = () => {\n if (canvas.value && ctx) {\n const offsetX = (canvas.value.width - img.width * scale.x) / 2\n const offsetY = (canvas.value.height - img.height * scale.y) / 2\n\n const sx = (cropRect.value.x - offsetX) / scale.x\n const sy = (cropRect.value.y - offsetY) / scale.y\n const sWidth = cropRect.value.width / scale.x\n const sHeight = cropRect.value.height / scale.y\n\n const geometry = {\n x: Math.round(sx),\n y: Math.round(sy),\n width: Math.round(sWidth),\n height: Math.round(sHeight),\n }\n\n // clamp the crop area to the actual image bounds\n const clampedSX = Math.max(0, Math.min(geometry.x, img.width))\n const clampedSY = Math.max(0, Math.min(geometry.y, img.height))\n const clampedSWidth = Math.min(geometry.width, img.width - clampedSX)\n const clampedSHeight = Math.min(geometry.height, img.height - clampedSY)\n\n const croppedCanvas = document.createElement('canvas')\n croppedCanvas.width = clampedSWidth\n croppedCanvas.height = clampedSHeight\n const croppedCtx = croppedCanvas.getContext('2d')\n if (croppedCtx) {\n croppedCtx.drawImage(\n img,\n clampedSX,\n clampedSY,\n clampedSWidth,\n clampedSHeight,\n 0,\n 0,\n clampedSWidth,\n clampedSHeight,\n )\n\n if (props.cropAsCircle && props.outputAsCircle) {\n croppedCtx.globalCompositeOperation = 'destination-in'\n croppedCtx.beginPath()\n croppedCtx.arc(\n clampedSWidth / 2,\n clampedSHeight / 2,\n clampedSWidth / 2,\n 0,\n Math.PI * 2,\n )\n croppedCtx.closePath()\n croppedCtx.fill()\n croppedCtx.globalCompositeOperation = 'source-over'\n }\n\n // expose the cropped image via the `crop` event\n croppedCanvas.toBlob(\n (blob) => {\n if (blob) {\n const oldPreviewUrl = croppedImageUrl.value\n if (oldPreviewUrl) {\n URL.revokeObjectURL(oldPreviewUrl)\n }\n croppedImageUrl.value = URL.createObjectURL(blob)\n cropGeometry.value = geometry\n emit('crop', { blob, geometry })\n }\n },\n 'image/jpeg',\n 0.8,\n )\n }\n }\n}\n\nwatch(\n () => props,\n () => {\n cropImage()\n },\n { deep: true },\n)\n</script>\n\n<style lang=\"scss\" scoped>\n$handle-size: 10px;\n$handle-offset: -7px;\n$border-color: black;\n$background-color: white;\n\n.nb-image-cropper {\n position: relative;\n user-select: none;\n display: inline-block;\n max-width: 100%;\n height: auto;\n overflow: hidden;\n\n .canvas-container {\n position: relative;\n display: inline-block;\n width: 100%;\n height: auto;\n\n canvas {\n display: block;\n max-width: 100%;\n height: auto;\n }\n }\n\n .resize-handle {\n position: absolute;\n width: 10px;\n height: 10px;\n background: white;\n border: 1px solid black;\n z-index: 1;\n\n &.top-left {\n cursor: nwse-resize;\n }\n\n &.top {\n cursor: ns-resize;\n }\n\n &.top-right {\n cursor: nesw-resize;\n }\n\n &.right {\n cursor: ew-resize;\n }\n\n &.bottom-right {\n cursor: nwse-resize;\n }\n\n &.bottom {\n cursor: ns-resize;\n }\n\n &.bottom-left {\n cursor: nesw-resize;\n }\n\n &.left {\n cursor: ew-resize;\n }\n }\n\n .cropped-image-preview {\n position: absolute;\n right: calc(var(--nb-base-unit, 8px) * 2);\n bottom: calc(var(--nb-base-unit, 8px) * 2);\n border-radius: var(--nb-border-radius-sm, 6px);\n overflow: hidden;\n height: calc(var(--nb-base-unit, 8px) * 14);\n margin-top: 20px;\n border: dotted 1px var(--nb-c-component-border, #e0e0e0);\n background: var(--nb-c-backdrop, #fff);\n user-select: none;\n pointer-events: none;\n ul {\n min-width: calc(var(--nb-base-unit, 8px) * 9);\n background: black;\n color: white;\n font-size: var(--nb-font-size-10, 10px);\n padding: calc(var(--nb-base-unit, 8px) / 2);\n line-height: var(--nb-font-size-14, 14px);\n }\n img {\n width: 100%;\n height: 100%;\n object-fit: contain;\n object-position: center;\n }\n }\n}\n</style>\n","<template>\n <div :class=\"classes\">\n <div :class=\"togglerClasses\" @click=\"toggleCollapse\" />\n <div class=\"content\" :class=\"{ editable: editable, editor: inputActive }\">\n <div class=\"title\" :class=\"{ editor: inputActive }\">\n {{ title }}\n <span v-if=\"isNode(localModel)\" class=\"type\">\n {{\n isArray(localModel)\n ? `[ ${localModel.length} items ]`\n : `{ ${localModel && typeof localModel === 'object' ? Object.keys(localModel).length : 0} properties }`\n }}\n </span>\n </div>\n <div v-if=\"!isNode(localModel)\" class=\"data\">\n <span\n v-if=\"!isBoolean(localModel)\"\n v-show=\"!inputActive\"\n :class=\"{ value: true, 'value--null': isNull(localModel) }\"\n @dblclick=\"() => (inputActive = editable)\"\n >\n {{ isNull(localModel) ? nullString : localModel }}\n </span>\n <input\n v-if=\"!isBoolean(localModel) && inputActive\"\n v-model=\"localModel\"\n @keyup.enter=\"() => (inputActive = false)\"\n @blur=\"() => (inputActive = false)\"\n />\n <span\n v-if=\"isBoolean(localModel)\"\n class=\"boolean\"\n @click=\"() => (localModel = !localModel)\"\n >{{ !localModel ? i18n.strFalse : i18n.strTrue }}</span\n >\n <div class=\"controls\" />\n </div>\n <div v-if=\"localModel && isNode(localModel)\">\n <NbJsonTree\n v-for=\"(_, indexKey) in localModel\"\n :key=\"indexKey\"\n v-model=\"asIndexable(localModel)[indexKey]\"\n :title=\"`${indexKey}`\"\n :class=\"{ colapsed: colapsed }\"\n :loaded=\"true\"\n :root=\"false\"\n :editable=\"editable\"\n />\n </div>\n </div>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { ref, computed } from 'vue'\nimport type { IJsonTreeProps, TJsonValue } from './JsonTree.d'\n\nconst nullString = 'null'\n\nconst props = withDefaults(defineProps<IJsonTreeProps>(), {\n title: null,\n modelValue: null,\n root: true,\n editable: false,\n startCollapsed: false,\n})\n\nconst emit = defineEmits(['update:modelValue'])\n\nconst localModel = computed({\n get() {\n return props.modelValue\n },\n set(value) {\n if (props.editable) {\n emit('update:modelValue', value)\n }\n },\n})\n\n// internal state\nconst colapsed = ref(props.startCollapsed)\nconst inputActive = ref(false)\nconst i18n = ref({\n strBoolean: 'boolean',\n strString: 'string',\n strNumber: 'number',\n strObject: 'object',\n strArray: 'array',\n strNull: 'null',\n strFalse: 'false',\n strTrue: 'true',\n})\n\n// computed\nconst classes = computed(() => {\n return {\n 'nb-json-tree': true,\n node: isNode(localModel.value),\n leaf: !isNode(localModel.value),\n root: props.root,\n }\n})\n\nconst togglerClasses = computed(() => {\n return {\n toggler: true,\n node: isNode(localModel.value),\n colapse: !colapsed.value,\n expand: colapsed.value,\n }\n})\n\n// methods\nconst toggleCollapse = () => (colapsed.value = !colapsed.value)\nconst isNode = (value: TJsonValue) =>\n value instanceof Object || Array.isArray(value)\nconst isArray = (value: TJsonValue) => Array.isArray(value)\nconst isNull = (value: TJsonValue) => value === null\nconst isBoolean = (value: TJsonValue): value is boolean =>\n typeof value === 'boolean'\nconst asIndexable = (v: TJsonValue): Record<string | number, TJsonValue> =>\n (v as Record<string | number, TJsonValue>) ?? {}\n</script>\n\n<style lang=\"scss\">\n:root {\n --nb-json-tree-sprite: url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4KPHN2ZyB2aWV3Qm94PSIwIDAgMTMyIDExMiIgd2lkdGg9IjEzMnB4IiBoZWlnaHQ9IjExMnB4IiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPgogIDxnPgogICAgPHRpdGxlPm1pbnVzPC90aXRsZT4KICAgIDxyZWN0IHN0eWxlPSJzdHJva2U6IHJnYig2MCwgNjAsIDYwKTsgc3Ryb2tlLWxpbmVjYXA6IHJvdW5kOyBzdHJva2UtbGluZWpvaW46IHJvdW5kIiB4PSI0IiB5PSI5IiB3aWR0aD0iMTIiIGhlaWdodD0iMTIiIHJ4PSIxIiByeT0iMSIvPgogICAgPGxpbmUgc3R5bGU9InN0cm9rZS13aWR0aDogMnB4OyBzdHJva2UtbGluZWNhcDogcm91bmQ7IHN0cm9rZTogcmdiKDE1NiwgMTU2LCAxNTYpOyIgeDE9IjgiIHkxPSIxNSIgeDI9IjEyIiB5Mj0iMTUiPgogICAgICA8dGl0bGU+bWludXM8L3RpdGxlPgogICAgPC9saW5lPgogIDwvZz4KICA8Zz4KICAgIDx0aXRsZT5wbHVzPC90aXRsZT4KICAgIDxyZWN0IHN0eWxlPSJmaWxsOiAjM0QzRDNEOyBzdHJva2U6ICMzRDNEM0Q7IHN0cm9rZS1saW5lY2FwOiByb3VuZDsgc3Ryb2tlLWxpbmVqb2luOiByb3VuZCIgeD0iMzciIHk9IjkiIHdpZHRoPSIxMiIgaGVpZ2h0PSIxMiIgcng9IjEiIHJ5PSIxIi8+CiAgICA8Zz4KICAgICAgPHRpdGxlPnBsdXM8L3RpdGxlPgogICAgICA8bGluZSBzdHlsZT0ic3Ryb2tlLXdpZHRoOiAycHg7IHN0cm9rZS1saW5lY2FwOiByb3VuZDsgZmlsbDogIzNEM0QzRDsgc3Ryb2tlOiAjRUJFQkVCOyIgeDE9IjQwIiB5MT0iMTUiIHgyPSI0NiIgeTI9IjE1Ij4KICAgICAgICA8dGl0bGU+bWludXM8L3RpdGxlPgogICAgICA8L2xpbmU+CiAgICAgIDxsaW5lIHN0eWxlPSJzdHJva2Utd2lkdGg6IDJweDsgc3Ryb2tlLWxpbmVjYXA6IHJvdW5kOyBmaWxsOiAjM0QzRDNEOyBzdHJva2U6ICNFQkVCRUI7IiB4MT0iNDMiIHkxPSIxMiIgeDI9IjQzIiB5Mj0iMTgiPgogICAgICAgIDx0aXRsZT5taW51czwvdGl0bGU+CiAgICAgIDwvbGluZT4KICAgIDwvZz4KICA8L2c+CiAgPGxpbmUgc3R5bGU9InN0cm9rZS1kYXNoYXJyYXk6IDE7IHN0cm9rZS1saW5lam9pbjogcm91bmQ7IHN0cm9rZTogcmdiKDI1NSwgMjU1LCAyNTUpOyIgeDE9IjE3IiB5MT0iMTUiIHgyPSIzMSIgeTI9IjE1Ii8+CiAgPGxpbmUgc3R5bGU9InN0cm9rZS1kYXNoYXJyYXk6IDE7IHN0cm9rZS1saW5lam9pbjogcm91bmQ7IHN0cm9rZTogcmdiKDI1NSwgMjU1LCAyNTUpOyIgeDE9IjUwIiB5MT0iMTUiIHgyPSI2NSIgeTI9IjE1Ii8+CiAgPGxpbmUgc3R5bGU9InN0cm9rZS1kYXNoYXJyYXk6IDE7IHN0cm9rZS1saW5lam9pbjogcm91bmQ7IHN0cm9rZTogcmdiKDI1NSwgMjU1LCAyNTUpOyIgeDE9Ijc3IiB5MT0iMTUiIHgyPSI5OSIgeTI9IjE1Ii8+CiAgPGxpbmUgc3R5bGU9InN0cm9rZS1kYXNoYXJyYXk6IDE7IHN0cm9rZS1saW5lam9pbjogcm91bmQ7IHN0cm9rZTogcmdiKDI1NSwgMjU1LCAyNTUpOyIgeDE9IjEwOC41IiB5MT0iMC41IiB4Mj0iMTA4LjUiIHkyPSIxMTEuNSIvPgo8L3N2Zz4=');\n}\n.nb-json-tree {\n display: flex;\n font-family: var(--nb-font-family-sans);\n font-weight: var(--nb-front-weight-regular);\n font-size: var(--nb-font-size-14);\n text-align: left;\n line-height: 24px;\n background: var(--nb-json-tree-sprite);\n background-color: transparent;\n background-repeat: no-repeat;\n // color: var(--nb-c-surface);\n &:not(.root) {\n background-repeat: repeat-y;\n background-position: -99px 0px;\n }\n\n &.root,\n &:last-child {\n background-repeat: no-repeat;\n background-position: -99px -96px;\n }\n\n .toggler {\n display: block;\n width: 24px;\n height: 24px;\n flex-shrink: 0;\n cursor: pointer;\n background-position: -66px 0px;\n background-image: var(--nb-json-tree-sprite);\n background-color: transparent;\n background-repeat: no-repeat;\n }\n\n &.colapsed {\n display: none;\n }\n\n .content {\n display: flex;\n box-sizing: border-box;\n padding: 1px 5px;\n width: 100%;\n .title {\n font-weight: 500;\n }\n }\n\n &.node {\n .toggler.node {\n &.colapse {\n background-position: 0px 0px;\n }\n &.expand {\n background-position: -33px 0px;\n }\n }\n .content {\n flex-direction: column;\n\n .title {\n display: flex;\n flex-direction: row;\n flex-shrink: 0;\n span {\n font-family: var(--nb-font-family-mono);\n font-weight: var(--nb-json-tree-sprite);\n margin-left: 5px;\n color: var(--nb-c-primary);\n text-transform: capitalize;\n }\n }\n }\n }\n\n &.leaf {\n .content {\n flex-direction: row;\n border-bottom: solid 1px transparent;\n\n .title {\n cursor: pointer;\n &:after {\n content: ': ';\n margin-right: 5px;\n }\n }\n\n .data {\n display: flex;\n flex-grow: 1;\n overflow-x: hidden;\n position: relative;\n span {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow-x: hidden;\n width: auto;\n &.value--null {\n color: var(--nb-c-text-faded);\n }\n }\n input {\n border: 0;\n outline: 0;\n padding: 0;\n font-size: 14px;\n width: 100%;\n background: transparent;\n }\n .boolean {\n cursor: pointer;\n }\n }\n\n &.editable {\n .data {\n span {\n &.value {\n cursor: text;\n }\n &.boolean {\n cursor: pointer;\n }\n }\n }\n &:hover {\n border-bottom: dotted 1px var(--nb-c-primary);\n }\n }\n\n &.editor {\n background: var(--nb-c-panel-background);\n border-bottom: solid 1px var(--nb-c-component-border);\n }\n }\n }\n}\n</style>\n","<template>\n <div :class=\"classes\">\n <div :class=\"togglerClasses\" @click=\"toggleCollapse\" />\n <div class=\"content\" :class=\"{ editable: editable, editor: inputActive }\">\n <div class=\"title\" :class=\"{ editor: inputActive }\">\n {{ title }}\n <span v-if=\"isNode(localModel)\" class=\"type\">\n {{\n isArray(localModel)\n ? `[ ${localModel.length} items ]`\n : `{ ${localModel && typeof localModel === 'object' ? Object.keys(localModel).length : 0} properties }`\n }}\n </span>\n </div>\n <div v-if=\"!isNode(localModel)\" class=\"data\">\n <span\n v-if=\"!isBoolean(localModel)\"\n v-show=\"!inputActive\"\n :class=\"{ value: true, 'value--null': isNull(localModel) }\"\n @dblclick=\"() => (inputActive = editable)\"\n >\n {{ isNull(localModel) ? nullString : localModel }}\n </span>\n <input\n v-if=\"!isBoolean(localModel) && inputActive\"\n v-model=\"localModel\"\n @keyup.enter=\"() => (inputActive = false)\"\n @blur=\"() => (inputActive = false)\"\n />\n <span\n v-if=\"isBoolean(localModel)\"\n class=\"boolean\"\n @click=\"() => (localModel = !localModel)\"\n >{{ !localModel ? i18n.strFalse : i18n.strTrue }}</span\n >\n <div class=\"controls\" />\n </div>\n <div v-if=\"localModel && isNode(localModel)\">\n <NbJsonTree\n v-for=\"(_, indexKey) in localModel\"\n :key=\"indexKey\"\n v-model=\"asIndexable(localModel)[indexKey]\"\n :title=\"`${indexKey}`\"\n :class=\"{ colapsed: colapsed }\"\n :loaded=\"true\"\n :root=\"false\"\n :editable=\"editable\"\n />\n </div>\n </div>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { ref, computed } from 'vue'\nimport type { IJsonTreeProps, TJsonValue } from './JsonTree.d'\n\nconst nullString = 'null'\n\nconst props = withDefaults(defineProps<IJsonTreeProps>(), {\n title: null,\n modelValue: null,\n root: true,\n editable: false,\n startCollapsed: false,\n})\n\nconst emit = defineEmits(['update:modelValue'])\n\nconst localModel = computed({\n get() {\n return props.modelValue\n },\n set(value) {\n if (props.editable) {\n emit('update:modelValue', value)\n }\n },\n})\n\n// internal state\nconst colapsed = ref(props.startCollapsed)\nconst inputActive = ref(false)\nconst i18n = ref({\n strBoolean: 'boolean',\n strString: 'string',\n strNumber: 'number',\n strObject: 'object',\n strArray: 'array',\n strNull: 'null',\n strFalse: 'false',\n strTrue: 'true',\n})\n\n// computed\nconst classes = computed(() => {\n return {\n 'nb-json-tree': true,\n node: isNode(localModel.value),\n leaf: !isNode(localModel.value),\n root: props.root,\n }\n})\n\nconst togglerClasses = computed(() => {\n return {\n toggler: true,\n node: isNode(localModel.value),\n colapse: !colapsed.value,\n expand: colapsed.value,\n }\n})\n\n// methods\nconst toggleCollapse = () => (colapsed.value = !colapsed.value)\nconst isNode = (value: TJsonValue) =>\n value instanceof Object || Array.isArray(value)\nconst isArray = (value: TJsonValue) => Array.isArray(value)\nconst isNull = (value: TJsonValue) => value === null\nconst isBoolean = (value: TJsonValue): value is boolean =>\n typeof value === 'boolean'\nconst asIndexable = (v: TJsonValue): Record<string | number, TJsonValue> =>\n (v as Record<string | number, TJsonValue>) ?? {}\n</script>\n\n<style lang=\"scss\">\n:root {\n --nb-json-tree-sprite: url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4KPHN2ZyB2aWV3Qm94PSIwIDAgMTMyIDExMiIgd2lkdGg9IjEzMnB4IiBoZWlnaHQ9IjExMnB4IiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPgogIDxnPgogICAgPHRpdGxlPm1pbnVzPC90aXRsZT4KICAgIDxyZWN0IHN0eWxlPSJzdHJva2U6IHJnYig2MCwgNjAsIDYwKTsgc3Ryb2tlLWxpbmVjYXA6IHJvdW5kOyBzdHJva2UtbGluZWpvaW46IHJvdW5kIiB4PSI0IiB5PSI5IiB3aWR0aD0iMTIiIGhlaWdodD0iMTIiIHJ4PSIxIiByeT0iMSIvPgogICAgPGxpbmUgc3R5bGU9InN0cm9rZS13aWR0aDogMnB4OyBzdHJva2UtbGluZWNhcDogcm91bmQ7IHN0cm9rZTogcmdiKDE1NiwgMTU2LCAxNTYpOyIgeDE9IjgiIHkxPSIxNSIgeDI9IjEyIiB5Mj0iMTUiPgogICAgICA8dGl0bGU+bWludXM8L3RpdGxlPgogICAgPC9saW5lPgogIDwvZz4KICA8Zz4KICAgIDx0aXRsZT5wbHVzPC90aXRsZT4KICAgIDxyZWN0IHN0eWxlPSJmaWxsOiAjM0QzRDNEOyBzdHJva2U6ICMzRDNEM0Q7IHN0cm9rZS1saW5lY2FwOiByb3VuZDsgc3Ryb2tlLWxpbmVqb2luOiByb3VuZCIgeD0iMzciIHk9IjkiIHdpZHRoPSIxMiIgaGVpZ2h0PSIxMiIgcng9IjEiIHJ5PSIxIi8+CiAgICA8Zz4KICAgICAgPHRpdGxlPnBsdXM8L3RpdGxlPgogICAgICA8bGluZSBzdHlsZT0ic3Ryb2tlLXdpZHRoOiAycHg7IHN0cm9rZS1saW5lY2FwOiByb3VuZDsgZmlsbDogIzNEM0QzRDsgc3Ryb2tlOiAjRUJFQkVCOyIgeDE9IjQwIiB5MT0iMTUiIHgyPSI0NiIgeTI9IjE1Ij4KICAgICAgICA8dGl0bGU+bWludXM8L3RpdGxlPgogICAgICA8L2xpbmU+CiAgICAgIDxsaW5lIHN0eWxlPSJzdHJva2Utd2lkdGg6IDJweDsgc3Ryb2tlLWxpbmVjYXA6IHJvdW5kOyBmaWxsOiAjM0QzRDNEOyBzdHJva2U6ICNFQkVCRUI7IiB4MT0iNDMiIHkxPSIxMiIgeDI9IjQzIiB5Mj0iMTgiPgogICAgICAgIDx0aXRsZT5taW51czwvdGl0bGU+CiAgICAgIDwvbGluZT4KICAgIDwvZz4KICA8L2c+CiAgPGxpbmUgc3R5bGU9InN0cm9rZS1kYXNoYXJyYXk6IDE7IHN0cm9rZS1saW5lam9pbjogcm91bmQ7IHN0cm9rZTogcmdiKDI1NSwgMjU1LCAyNTUpOyIgeDE9IjE3IiB5MT0iMTUiIHgyPSIzMSIgeTI9IjE1Ii8+CiAgPGxpbmUgc3R5bGU9InN0cm9rZS1kYXNoYXJyYXk6IDE7IHN0cm9rZS1saW5lam9pbjogcm91bmQ7IHN0cm9rZTogcmdiKDI1NSwgMjU1LCAyNTUpOyIgeDE9IjUwIiB5MT0iMTUiIHgyPSI2NSIgeTI9IjE1Ii8+CiAgPGxpbmUgc3R5bGU9InN0cm9rZS1kYXNoYXJyYXk6IDE7IHN0cm9rZS1saW5lam9pbjogcm91bmQ7IHN0cm9rZTogcmdiKDI1NSwgMjU1LCAyNTUpOyIgeDE9Ijc3IiB5MT0iMTUiIHgyPSI5OSIgeTI9IjE1Ii8+CiAgPGxpbmUgc3R5bGU9InN0cm9rZS1kYXNoYXJyYXk6IDE7IHN0cm9rZS1saW5lam9pbjogcm91bmQ7IHN0cm9rZTogcmdiKDI1NSwgMjU1LCAyNTUpOyIgeDE9IjEwOC41IiB5MT0iMC41IiB4Mj0iMTA4LjUiIHkyPSIxMTEuNSIvPgo8L3N2Zz4=');\n}\n.nb-json-tree {\n display: flex;\n font-family: var(--nb-font-family-sans);\n font-weight: var(--nb-front-weight-regular);\n font-size: var(--nb-font-size-14);\n text-align: left;\n line-height: 24px;\n background: var(--nb-json-tree-sprite);\n background-color: transparent;\n background-repeat: no-repeat;\n // color: var(--nb-c-surface);\n &:not(.root) {\n background-repeat: repeat-y;\n background-position: -99px 0px;\n }\n\n &.root,\n &:last-child {\n background-repeat: no-repeat;\n background-position: -99px -96px;\n }\n\n .toggler {\n display: block;\n width: 24px;\n height: 24px;\n flex-shrink: 0;\n cursor: pointer;\n background-position: -66px 0px;\n background-image: var(--nb-json-tree-sprite);\n background-color: transparent;\n background-repeat: no-repeat;\n }\n\n &.colapsed {\n display: none;\n }\n\n .content {\n display: flex;\n box-sizing: border-box;\n padding: 1px 5px;\n width: 100%;\n .title {\n font-weight: 500;\n }\n }\n\n &.node {\n .toggler.node {\n &.colapse {\n background-position: 0px 0px;\n }\n &.expand {\n background-position: -33px 0px;\n }\n }\n .content {\n flex-direction: column;\n\n .title {\n display: flex;\n flex-direction: row;\n flex-shrink: 0;\n span {\n font-family: var(--nb-font-family-mono);\n font-weight: var(--nb-json-tree-sprite);\n margin-left: 5px;\n color: var(--nb-c-primary);\n text-transform: capitalize;\n }\n }\n }\n }\n\n &.leaf {\n .content {\n flex-direction: row;\n border-bottom: solid 1px transparent;\n\n .title {\n cursor: pointer;\n &:after {\n content: ': ';\n margin-right: 5px;\n }\n }\n\n .data {\n display: flex;\n flex-grow: 1;\n overflow-x: hidden;\n position: relative;\n span {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow-x: hidden;\n width: auto;\n &.value--null {\n color: var(--nb-c-text-faded);\n }\n }\n input {\n border: 0;\n outline: 0;\n padding: 0;\n font-size: 14px;\n width: 100%;\n background: transparent;\n }\n .boolean {\n cursor: pointer;\n }\n }\n\n &.editable {\n .data {\n span {\n &.value {\n cursor: text;\n }\n &.boolean {\n cursor: pointer;\n }\n }\n }\n &:hover {\n border-bottom: dotted 1px var(--nb-c-primary);\n }\n }\n\n &.editor {\n background: var(--nb-c-panel-background);\n border-bottom: solid 1px var(--nb-c-component-border);\n }\n }\n }\n}\n</style>\n","enum ELabelSize {\n Small = 'sm',\n Medium = 'md',\n}\n\ninterface ILabelProps {\n htmlFor?: string\n required?: boolean\n disabled?: boolean\n // Visual size of the label text\n size?: ELabelSize\n}\n\nexport { ELabelSize, ILabelProps }\n","<template>\n <label\n :for=\"htmlFor\"\n :class=\"[\n 'nb-label',\n `nb-label--${size}`,\n { 'nb-label--required': required, 'nb-label--disabled': disabled },\n ]\"\n >\n <slot />\n <span v-if=\"required\" class=\"nb-label__asterisk\" aria-hidden=\"true\">*</span>\n <!-- Optional trailing content: badges, status pills, extra info -->\n <slot name=\"suffix\" />\n </label>\n</template>\n\n<script setup lang=\"ts\">\nimport { ELabelSize, ILabelProps } from './Label.d'\n\nwithDefaults(defineProps<ILabelProps>(), {\n htmlFor: undefined,\n required: false,\n disabled: false,\n size: ELabelSize.Medium,\n})\n</script>\n\n<style scoped lang=\"scss\">\n.nb-label {\n display: inline-flex;\n align-items: center;\n gap: 4px;\n font-family: var(--nb-font-family-sans);\n font-weight: 500;\n color: var(--nb-c-text-muted);\n cursor: default;\n user-select: none;\n\n &--sm {\n font-size: var(--nb-font-size-12);\n letter-spacing: 0.02em;\n }\n &--md {\n font-size: var(--nb-font-size-12);\n }\n\n &--disabled {\n opacity: 0.45;\n }\n\n &__asterisk {\n color: var(--nb-c-danger);\n font-size: 1em;\n line-height: 1;\n }\n}\n</style>\n","<template>\n <label\n :for=\"htmlFor\"\n :class=\"[\n 'nb-label',\n `nb-label--${size}`,\n { 'nb-label--required': required, 'nb-label--disabled': disabled },\n ]\"\n >\n <slot />\n <span v-if=\"required\" class=\"nb-label__asterisk\" aria-hidden=\"true\">*</span>\n <!-- Optional trailing content: badges, status pills, extra info -->\n <slot name=\"suffix\" />\n </label>\n</template>\n\n<script setup lang=\"ts\">\nimport { ELabelSize, ILabelProps } from './Label.d'\n\nwithDefaults(defineProps<ILabelProps>(), {\n htmlFor: undefined,\n required: false,\n disabled: false,\n size: ELabelSize.Medium,\n})\n</script>\n\n<style scoped lang=\"scss\">\n.nb-label {\n display: inline-flex;\n align-items: center;\n gap: 4px;\n font-family: var(--nb-font-family-sans);\n font-weight: 500;\n color: var(--nb-c-text-muted);\n cursor: default;\n user-select: none;\n\n &--sm {\n font-size: var(--nb-font-size-12);\n letter-spacing: 0.02em;\n }\n &--md {\n font-size: var(--nb-font-size-12);\n }\n\n &--disabled {\n opacity: 0.45;\n }\n\n &__asterisk {\n color: var(--nb-c-danger);\n font-size: 1em;\n line-height: 1;\n }\n}\n</style>\n","enum EMessageVariant {\n Error = 'error',\n Warning = 'warning',\n Helper = 'helper',\n}\n\ninterface IMessageProps {\n variant?: `${EMessageVariant}`\n /**\n * Icon-only mode: hides the text and shows only an icon.\n * On hover, the message text appears via a CSS tooltip.\n * Used in the TextInput `fluid` variant.\n */\n iconOnly?: boolean\n}\n\nexport { EMessageVariant, IMessageProps }\n","<template>\n <div\n :class=\"[\n 'nb-message',\n `nb-message--${props.variant}`,\n { 'nb-message--icon-only': props.iconOnly },\n ]\"\n role=\"status\"\n :aria-live=\"props.variant === 'error' ? 'assertive' : 'polite'\"\n >\n <NbIcon\n :name=\"iconMap[props.variant]\"\n :size=\"14\"\n class=\"nb-message__icon\"\n />\n <span v-if=\"!props.iconOnly\" class=\"nb-message__text\"><slot /></span>\n <!-- CSS-powered tooltip shown on hover in icon-only mode -->\n <span v-if=\"props.iconOnly\" class=\"nb-message__tooltip\" aria-hidden=\"true\"\n ><slot\n /></span>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { EMessageVariant, IMessageProps } from './Message.d'\n\nconst props = withDefaults(defineProps<IMessageProps>(), {\n variant: EMessageVariant.Helper,\n iconOnly: false,\n})\n\nconst iconMap = {\n error: 'warning-circle',\n warning: 'warning',\n helper: 'info',\n} as const\n</script>\n\n<style scoped lang=\"scss\">\n.nb-message {\n display: inline-flex;\n align-items: center;\n gap: calc(var(--nb-base-unit) / 2);\n font-family: var(--nb-font-family-sans);\n font-size: var(--nb-font-size-12);\n line-height: 1.4;\n\n &--error {\n color: var(--nb-c-danger);\n }\n &--warning {\n color: var(--nb-c-warning);\n }\n &--helper {\n color: var(--nb-c-text-subtle);\n }\n\n &__icon {\n flex-shrink: 0;\n }\n\n &__text {\n flex: 1;\n }\n\n /* Icon-only: hide text, show CSS tooltip on hover */\n &--icon-only {\n position: relative;\n cursor: default;\n\n .nb-message__text {\n display: none;\n }\n\n &:hover .nb-message__tooltip,\n &:focus-within .nb-message__tooltip {\n opacity: 1;\n visibility: visible;\n transform: translateX(-50%) translateY(0);\n }\n }\n\n &__tooltip {\n position: absolute;\n bottom: calc(100% + 8px);\n left: 50%;\n transform: translateX(-50%) translateY(4px);\n background: var(--nb-c-plain-black-800, #1f2937);\n color: #fff;\n padding: 6px 10px;\n border-radius: 4px;\n font-size: 11px;\n font-weight: 400;\n white-space: nowrap;\n max-width: 220px;\n text-overflow: ellipsis;\n overflow: hidden;\n opacity: 0;\n visibility: hidden;\n transform: translateX(-50%) translateY(4px);\n transition:\n opacity 0.15s ease,\n transform 0.15s ease,\n visibility 0.15s ease;\n pointer-events: none;\n z-index: var(--nb-zindex-tooltip, 401);\n\n &::after {\n content: '';\n position: absolute;\n top: 100%;\n left: 50%;\n transform: translateX(-50%);\n border: 5px solid transparent;\n border-top-color: var(--nb-c-plain-black-800, #1f2937);\n }\n }\n}\n</style>\n","<template>\n <div\n :class=\"[\n 'nb-message',\n `nb-message--${props.variant}`,\n { 'nb-message--icon-only': props.iconOnly },\n ]\"\n role=\"status\"\n :aria-live=\"props.variant === 'error' ? 'assertive' : 'polite'\"\n >\n <NbIcon\n :name=\"iconMap[props.variant]\"\n :size=\"14\"\n class=\"nb-message__icon\"\n />\n <span v-if=\"!props.iconOnly\" class=\"nb-message__text\"><slot /></span>\n <!-- CSS-powered tooltip shown on hover in icon-only mode -->\n <span v-if=\"props.iconOnly\" class=\"nb-message__tooltip\" aria-hidden=\"true\"\n ><slot\n /></span>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { EMessageVariant, IMessageProps } from './Message.d'\n\nconst props = withDefaults(defineProps<IMessageProps>(), {\n variant: EMessageVariant.Helper,\n iconOnly: false,\n})\n\nconst iconMap = {\n error: 'warning-circle',\n warning: 'warning',\n helper: 'info',\n} as const\n</script>\n\n<style scoped lang=\"scss\">\n.nb-message {\n display: inline-flex;\n align-items: center;\n gap: calc(var(--nb-base-unit) / 2);\n font-family: var(--nb-font-family-sans);\n font-size: var(--nb-font-size-12);\n line-height: 1.4;\n\n &--error {\n color: var(--nb-c-danger);\n }\n &--warning {\n color: var(--nb-c-warning);\n }\n &--helper {\n color: var(--nb-c-text-subtle);\n }\n\n &__icon {\n flex-shrink: 0;\n }\n\n &__text {\n flex: 1;\n }\n\n /* Icon-only: hide text, show CSS tooltip on hover */\n &--icon-only {\n position: relative;\n cursor: default;\n\n .nb-message__text {\n display: none;\n }\n\n &:hover .nb-message__tooltip,\n &:focus-within .nb-message__tooltip {\n opacity: 1;\n visibility: visible;\n transform: translateX(-50%) translateY(0);\n }\n }\n\n &__tooltip {\n position: absolute;\n bottom: calc(100% + 8px);\n left: 50%;\n transform: translateX(-50%) translateY(4px);\n background: var(--nb-c-plain-black-800, #1f2937);\n color: #fff;\n padding: 6px 10px;\n border-radius: 4px;\n font-size: 11px;\n font-weight: 400;\n white-space: nowrap;\n max-width: 220px;\n text-overflow: ellipsis;\n overflow: hidden;\n opacity: 0;\n visibility: hidden;\n transform: translateX(-50%) translateY(4px);\n transition:\n opacity 0.15s ease,\n transform 0.15s ease,\n visibility 0.15s ease;\n pointer-events: none;\n z-index: var(--nb-zindex-tooltip, 401);\n\n &::after {\n content: '';\n position: absolute;\n top: 100%;\n left: 50%;\n transform: translateX(-50%);\n border: 5px solid transparent;\n border-top-color: var(--nb-c-plain-black-800, #1f2937);\n }\n }\n}\n</style>\n","<template>\n <Teleport to=\"body\">\n <Transition name=\"nb-modal\">\n <div v-if=\"open\" class=\"nb-modal--overlay\" @click.self=\"onOverlayClick\">\n <div\n class=\"nb-modal--content\"\n role=\"dialog\"\n aria-modal=\"true\"\n :style=\"{ maxWidth: sizes[size] }\"\n @click.stop\n >\n <header v-if=\"$slots.header || title\" class=\"nb-modal--header\">\n <span class=\"nb-modal--title\">\n <slot name=\"header\">{{ title }}</slot>\n </span>\n <button\n class=\"nb-modal--close\"\n aria-label=\"Close\"\n @click=\"emit('close')\"\n >\n <NbIcon name=\"x\" />\n </button>\n </header>\n <main class=\"nb-modal--body\">\n <slot />\n </main>\n <NbGrid\n is=\"footer\"\n v-if=\"$slots.footer\"\n justify=\"end\"\n class=\"nb-modal--footer\"\n distributed\n >\n <slot name=\"footer\" />\n </NbGrid>\n </div>\n </div>\n </Transition>\n </Teleport>\n</template>\n\n<script setup lang=\"ts\">\nimport { watch, onMounted, onUnmounted } from 'vue'\nimport { ESizeShort } from '@/types/Size.d'\nimport type { IModalProps } from './Modal.d'\n\nconst props = withDefaults(defineProps<IModalProps>(), {\n title: undefined,\n open: false,\n size: ESizeShort.Medium,\n closeOnOverlay: true,\n})\n\nconst emit = defineEmits<{ close: [] }>()\n\nconst sizes = { sm: '400px', md: '520px', lg: '720px', xl: '960px' }\n\nfunction onOverlayClick() {\n if (props.closeOnOverlay) emit('close')\n}\n\n// Trap focus / prevent body scroll\nwatch(\n () => props.open,\n (val) => {\n document.body.style.overflow = val ? 'hidden' : ''\n },\n)\n\nonUnmounted(() => {\n document.body.style.overflow = ''\n})\n\nfunction onKeydown(e: KeyboardEvent) {\n if (e.key === 'Escape' && props.open) emit('close')\n}\n\nonMounted(() => {\n document.addEventListener('keydown', onKeydown)\n})\nonUnmounted(() => {\n document.removeEventListener('keydown', onKeydown)\n})\n</script>\n\n<style scoped lang=\"scss\">\n.nb-modal--overlay {\n position: fixed;\n inset: 0;\n background: rgba(0, 0, 0, 0.45);\n display: flex;\n align-items: center;\n justify-content: center;\n z-index: var(--nb-z-modal, 301);\n padding: 20px;\n}\n\n.nb-modal--content {\n background: var(--nb-c-bg, var(--nb-c-surface));\n box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);\n width: 100%;\n max-height: 90vh;\n display: flex;\n flex-direction: column;\n overflow: hidden;\n\n --parent-radius: 8px;\n}\n\n.nb-modal--header {\n display: flex;\n align-items: center;\n justify-content: space-between;\n flex-shrink: 0;\n}\n\n.nb-modal--title {\n padding: 16px 20px;\n font-size: 15px;\n font-weight: 600;\n color: var(--nb-c-text, #1a1a2e);\n}\n\n.nb-modal--close {\n width: calc(var(--nb-base-unit) * 7);\n height: calc(var(--nb-base-unit) * 7);\n border: none;\n background: transparent;\n font-size: 20px;\n line-height: 1;\n color: var(--nb-c-text-muted);\n cursor: pointer;\n display: flex;\n align-items: center;\n justify-content: center;\n transition:\n background 0.15s,\n color 0.15s;\n flex-shrink: 0;\n\n &:hover {\n background: var(--nb-c-bg-soft);\n color: var(--nb-c-text);\n }\n}\n\n.nb-modal--body {\n padding: 20px;\n overflow-y: auto;\n flex: 1;\n color: var(--nb-c-text, #1a1a2e);\n}\n\n.nb-modal--footer {\n :deep(> :only-child) {\n max-width: 50%;\n }\n}\n\n/* Transitions */\n.nb-modal-enter-active,\n.nb-modal-leave-active {\n transition:\n opacity 0.2s,\n transform 0.2s;\n .nb-modal--content {\n transition:\n opacity 0.2s,\n transform 0.2s;\n }\n}\n.nb-modal-enter-from {\n opacity: 0;\n .nb-modal--content {\n transform: scale(0.96) translateY(-8px);\n opacity: 0;\n }\n}\n.nb-modal-leave-to {\n opacity: 0;\n .nb-modal--content {\n transform: scale(0.96) translateY(-8px);\n opacity: 0;\n }\n}\n</style>\n","<template>\n <Teleport to=\"body\">\n <Transition name=\"nb-modal\">\n <div v-if=\"open\" class=\"nb-modal--overlay\" @click.self=\"onOverlayClick\">\n <div\n class=\"nb-modal--content\"\n role=\"dialog\"\n aria-modal=\"true\"\n :style=\"{ maxWidth: sizes[size] }\"\n @click.stop\n >\n <header v-if=\"$slots.header || title\" class=\"nb-modal--header\">\n <span class=\"nb-modal--title\">\n <slot name=\"header\">{{ title }}</slot>\n </span>\n <button\n class=\"nb-modal--close\"\n aria-label=\"Close\"\n @click=\"emit('close')\"\n >\n <NbIcon name=\"x\" />\n </button>\n </header>\n <main class=\"nb-modal--body\">\n <slot />\n </main>\n <NbGrid\n is=\"footer\"\n v-if=\"$slots.footer\"\n justify=\"end\"\n class=\"nb-modal--footer\"\n distributed\n >\n <slot name=\"footer\" />\n </NbGrid>\n </div>\n </div>\n </Transition>\n </Teleport>\n</template>\n\n<script setup lang=\"ts\">\nimport { watch, onMounted, onUnmounted } from 'vue'\nimport { ESizeShort } from '@/types/Size.d'\nimport type { IModalProps } from './Modal.d'\n\nconst props = withDefaults(defineProps<IModalProps>(), {\n title: undefined,\n open: false,\n size: ESizeShort.Medium,\n closeOnOverlay: true,\n})\n\nconst emit = defineEmits<{ close: [] }>()\n\nconst sizes = { sm: '400px', md: '520px', lg: '720px', xl: '960px' }\n\nfunction onOverlayClick() {\n if (props.closeOnOverlay) emit('close')\n}\n\n// Trap focus / prevent body scroll\nwatch(\n () => props.open,\n (val) => {\n document.body.style.overflow = val ? 'hidden' : ''\n },\n)\n\nonUnmounted(() => {\n document.body.style.overflow = ''\n})\n\nfunction onKeydown(e: KeyboardEvent) {\n if (e.key === 'Escape' && props.open) emit('close')\n}\n\nonMounted(() => {\n document.addEventListener('keydown', onKeydown)\n})\nonUnmounted(() => {\n document.removeEventListener('keydown', onKeydown)\n})\n</script>\n\n<style scoped lang=\"scss\">\n.nb-modal--overlay {\n position: fixed;\n inset: 0;\n background: rgba(0, 0, 0, 0.45);\n display: flex;\n align-items: center;\n justify-content: center;\n z-index: var(--nb-z-modal, 301);\n padding: 20px;\n}\n\n.nb-modal--content {\n background: var(--nb-c-bg, var(--nb-c-surface));\n box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);\n width: 100%;\n max-height: 90vh;\n display: flex;\n flex-direction: column;\n overflow: hidden;\n\n --parent-radius: 8px;\n}\n\n.nb-modal--header {\n display: flex;\n align-items: center;\n justify-content: space-between;\n flex-shrink: 0;\n}\n\n.nb-modal--title {\n padding: 16px 20px;\n font-size: 15px;\n font-weight: 600;\n color: var(--nb-c-text, #1a1a2e);\n}\n\n.nb-modal--close {\n width: calc(var(--nb-base-unit) * 7);\n height: calc(var(--nb-base-unit) * 7);\n border: none;\n background: transparent;\n font-size: 20px;\n line-height: 1;\n color: var(--nb-c-text-muted);\n cursor: pointer;\n display: flex;\n align-items: center;\n justify-content: center;\n transition:\n background 0.15s,\n color 0.15s;\n flex-shrink: 0;\n\n &:hover {\n background: var(--nb-c-bg-soft);\n color: var(--nb-c-text);\n }\n}\n\n.nb-modal--body {\n padding: 20px;\n overflow-y: auto;\n flex: 1;\n color: var(--nb-c-text, #1a1a2e);\n}\n\n.nb-modal--footer {\n :deep(> :only-child) {\n max-width: 50%;\n }\n}\n\n/* Transitions */\n.nb-modal-enter-active,\n.nb-modal-leave-active {\n transition:\n opacity 0.2s,\n transform 0.2s;\n .nb-modal--content {\n transition:\n opacity 0.2s,\n transform 0.2s;\n }\n}\n.nb-modal-enter-from {\n opacity: 0;\n .nb-modal--content {\n transform: scale(0.96) translateY(-8px);\n opacity: 0;\n }\n}\n.nb-modal-leave-to {\n opacity: 0;\n .nb-modal--content {\n transform: scale(0.96) translateY(-8px);\n opacity: 0;\n }\n}\n</style>\n","<template>\n <div :class=\"rootClasses\">\n <!-- DEFAULT variant -->\n <template v-if=\"variant === 'default'\">\n <NbLabel\n v-if=\"label\"\n :for=\"inputId\"\n :required=\"required\"\n :disabled=\"disabled\"\n >{{ label }}</NbLabel\n >\n\n <div class=\"nb-number-input__field-wrapper\" :class=\"wrapperClasses\">\n <input\n :id=\"inputId\"\n ref=\"inputRef\"\n type=\"number\"\n class=\"nb-number-input__field\"\n :placeholder=\"placeholder\"\n :min=\"min\"\n :max=\"max\"\n :step=\"step\"\n :disabled=\"disabled\"\n :required=\"required\"\n @input=\"onInput\"\n @blur=\"onBlur\"\n @keydown.enter.prevent=\"() => inputRef?.blur()\"\n @focus=\"focused = true\"\n />\n\n <NbMessage\n v-if=\"error\"\n variant=\"error\"\n :icon-only=\"true\"\n class=\"nb-number-input__status\"\n >{{ error }}</NbMessage\n >\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n :icon-only=\"true\"\n class=\"nb-number-input__status\"\n >{{ warning }}</NbMessage\n >\n\n <div class=\"nb-number-input__steppers\">\n <button\n type=\"button\"\n class=\"nb-number-input__stepper\"\n :class=\"{ 'nb-number-input__stepper--at-limit': isAtMin }\"\n :disabled=\"disabled\"\n aria-label=\"Decrease\"\n @mousedown.prevent\n @click=\"decrement\"\n >\n <NbIcon name=\"minus\" :size=\"16\" />\n </button>\n <button\n type=\"button\"\n class=\"nb-number-input__stepper\"\n :class=\"{ 'nb-number-input__stepper--at-limit': isAtMax }\"\n :disabled=\"disabled\"\n aria-label=\"Increase\"\n @mousedown.prevent\n @click=\"increment\"\n >\n <NbIcon name=\"plus\" :size=\"16\" />\n </button>\n </div>\n </div>\n\n <NbMessage\n v-if=\"error\"\n variant=\"error\"\n class=\"nb-number-input__message\"\n >{{ error }}</NbMessage\n >\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n class=\"nb-number-input__message\"\n >{{ warning }}</NbMessage\n >\n <NbMessage\n v-else-if=\"helper\"\n variant=\"helper\"\n class=\"nb-number-input__message\"\n >{{ helper }}</NbMessage\n >\n </template>\n\n <!-- FLUID variant -->\n <template v-else-if=\"variant === 'fluid'\">\n <div class=\"nb-number-input__field-wrapper\" :class=\"wrapperClasses\">\n <div v-if=\"label\" class=\"nb-number-input__inner-header\">\n <label :for=\"inputId\" class=\"nb-number-input__inner-label\">\n {{ label }}\n <span\n v-if=\"required\"\n class=\"nb-number-input__asterisk\"\n aria-hidden=\"true\"\n >*</span\n >\n </label>\n <NbMessage\n v-if=\"helper && !error && !warning\"\n variant=\"helper\"\n :icon-only=\"true\"\n class=\"nb-number-input__inner-message\"\n >{{ helper }}</NbMessage\n >\n </div>\n\n <div class=\"nb-number-input__fluid-row\">\n <input\n :id=\"inputId\"\n ref=\"inputRef\"\n type=\"number\"\n class=\"nb-number-input__field\"\n :placeholder=\"placeholder\"\n :min=\"min\"\n :max=\"max\"\n :step=\"step\"\n :disabled=\"disabled\"\n :required=\"required\"\n @input=\"onInput\"\n @blur=\"onBlur\"\n @keydown.enter.prevent=\"() => inputRef?.blur()\"\n @focus=\"focused = true\"\n />\n\n <NbMessage\n v-if=\"error\"\n variant=\"error\"\n :icon-only=\"true\"\n class=\"nb-number-input__status\"\n >{{ error }}</NbMessage\n >\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n :icon-only=\"true\"\n class=\"nb-number-input__status\"\n >{{ warning }}</NbMessage\n >\n\n <div class=\"nb-number-input__steppers\">\n <button\n type=\"button\"\n class=\"nb-number-input__stepper\"\n :class=\"{ 'nb-number-input__stepper--at-limit': isAtMin }\"\n :disabled=\"disabled\"\n aria-label=\"Decrease\"\n @mousedown.prevent\n @click=\"decrement\"\n >\n <NbIcon name=\"minus\" :size=\"16\" />\n </button>\n <button\n type=\"button\"\n class=\"nb-number-input__stepper\"\n :class=\"{ 'nb-number-input__stepper--at-limit': isAtMax }\"\n :disabled=\"disabled\"\n aria-label=\"Increase\"\n @mousedown.prevent\n @click=\"increment\"\n >\n <NbIcon name=\"plus\" :size=\"16\" />\n </button>\n </div>\n </div>\n </div>\n\n <NbMessage\n v-if=\"error\"\n variant=\"error\"\n class=\"nb-number-input__fluid-message\"\n >{{ error }}</NbMessage\n >\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n class=\"nb-number-input__fluid-message\"\n >{{ warning }}</NbMessage\n >\n </template>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed, onMounted, ref, useId, watch } from 'vue'\nimport type { IFieldComponent } from '@/types/Props.d'\nimport NbLabel from './Label.vue'\nimport NbMessage from './Message.vue'\nimport NbIcon from './Icon.vue'\n\nexport interface INumberInputProps extends IFieldComponent {\n modelValue?: number | null\n min?: number\n max?: number\n step?: number\n}\n\nconst props = withDefaults(defineProps<INumberInputProps>(), {\n modelValue: null,\n label: '',\n placeholder: '',\n helper: '',\n error: '',\n warning: '',\n min: undefined,\n max: undefined,\n step: 1,\n variant: 'default',\n size: 'md',\n disabled: false,\n required: false,\n id: undefined,\n})\n\nconst emit = defineEmits<{\n 'update:modelValue': [value: number | null]\n change: [value: number | null]\n}>()\n\nconst inputRef = ref<HTMLInputElement | null>(null)\nconst focused = ref(false)\n\nconst autoId = `nb-number-input-${useId()}`\nconst inputId = computed(() => props.id ?? autoId)\n\nconst isAtMin = computed(\n () =>\n props.min !== undefined &&\n props.modelValue !== null &&\n props.modelValue !== undefined &&\n props.modelValue <= props.min,\n)\nconst isAtMax = computed(\n () =>\n props.max !== undefined &&\n props.modelValue !== null &&\n props.modelValue !== undefined &&\n props.modelValue >= props.max,\n)\n\nfunction clamp(value: number): number {\n let v = value\n if (props.min !== undefined) v = Math.max(props.min, v)\n if (props.max !== undefined) v = Math.min(props.max, v)\n return v\n}\n\nfunction syncDisplay(val: number | null | undefined) {\n if (!inputRef.value) return\n inputRef.value.value = val !== null && val !== undefined ? String(val) : ''\n}\n\nonMounted(() => syncDisplay(props.modelValue))\n\nwatch(\n () => props.modelValue,\n (val) => {\n if (!focused.value) syncDisplay(val)\n },\n)\n\nfunction increment() {\n const current = props.modelValue ?? 0\n const next = clamp(current + props.step)\n emit('update:modelValue', next)\n emit('change', next)\n syncDisplay(next)\n}\n\nfunction decrement() {\n const current = props.modelValue ?? 0\n const next = clamp(current - props.step)\n emit('update:modelValue', next)\n emit('change', next)\n syncDisplay(next)\n}\n\nfunction onInput() {\n if (!inputRef.value) return\n const raw = inputRef.value.value\n if (raw === '') {\n emit('update:modelValue', null)\n } else {\n const num = parseFloat(raw)\n if (!isNaN(num)) emit('update:modelValue', num)\n }\n}\n\nfunction onBlur() {\n focused.value = false\n if (!inputRef.value) return\n const raw = inputRef.value.value\n if (raw === '') {\n emit('update:modelValue', null)\n emit('change', null)\n return\n }\n const num = parseFloat(raw)\n if (!isNaN(num)) {\n const clamped = clamp(num)\n emit('update:modelValue', clamped)\n emit('change', clamped)\n syncDisplay(clamped)\n }\n}\n\nconst rootClasses = computed(() => [\n 'nb-number-input',\n `nb-number-input--${props.variant}`,\n `nb-number-input--${props.size}`,\n {\n 'nb-number-input--error': !!props.error,\n 'nb-number-input--warning': !props.error && !!props.warning,\n 'nb-number-input--disabled': props.disabled,\n },\n])\n\nconst wrapperClasses = computed(() => ({\n 'nb-number-input__field-wrapper--focused': focused.value,\n 'nb-number-input__field-wrapper--error': !!props.error,\n 'nb-number-input__field-wrapper--warning': !props.error && !!props.warning,\n 'nb-number-input__field-wrapper--disabled': props.disabled,\n}))\n\ndefineExpose({ focus: () => inputRef.value?.focus() })\n</script>\n\n<style scoped lang=\"scss\">\n.nb-number-input {\n display: flex;\n flex-direction: column;\n flex: 1;\n gap: 6px;\n font-family: var(--nb-font-family-sans, sans-serif);\n --field-h: var(--nb-field-height-md);\n\n &--sm {\n --field-h: var(--nb-field-height-sm);\n }\n &--md {\n --field-h: var(--nb-field-height-md);\n }\n &--lg {\n --field-h: var(--nb-field-height-lg);\n }\n\n &__field-wrapper {\n position: relative;\n display: flex;\n align-items: stretch;\n background: var(--nb-c-field-bg);\n border-bottom: 1px solid var(--nb-c-field-border);\n height: var(--field-h);\n box-sizing: border-box;\n transition:\n border-color 0.15s,\n box-shadow 0.15s;\n\n &--focused {\n outline: 2px solid var(--nb-c-primary);\n outline-offset: -2px;\n }\n\n &--error {\n border: 1px solid var(--nb-c-danger);\n box-shadow: none;\n }\n\n &--warning {\n border: 1px solid var(--nb-c-warning);\n box-shadow: none;\n }\n\n &--disabled {\n opacity: var(--nb-field-disabled-opacity);\n cursor: not-allowed;\n }\n }\n\n &__field {\n flex: 1;\n min-width: 0;\n height: 100%;\n padding: 0 var(--nb-field-padding-h);\n background: transparent;\n border: none;\n outline: none;\n font-family: inherit;\n font-size: var(--nb-field-font-size);\n font-weight: 400;\n color: var(--nb-c-text);\n\n // Hide native number spinners\n appearance: none;\n -moz-appearance: textfield;\n\n &::-webkit-outer-spin-button,\n &::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0;\n }\n\n &:disabled {\n cursor: not-allowed;\n }\n }\n\n &__status {\n flex-shrink: 0;\n display: flex;\n align-items: center;\n padding: 0 4px;\n }\n\n &__steppers {\n display: flex;\n align-items: stretch;\n flex-shrink: 0;\n }\n\n &__stepper {\n display: flex;\n align-items: center;\n justify-content: center;\n width: 40px;\n background: transparent;\n border: none;\n cursor: pointer;\n color: var(--nb-c-text);\n transition: background 0.15s;\n padding: 0;\n flex-shrink: 0;\n position: relative;\n\n &::before {\n content: '';\n position: absolute;\n left: 0;\n top: 25%;\n bottom: 25%;\n width: 1px;\n background: var(--nb-c-field-border);\n }\n\n &:hover:not(:disabled):not(.nb-number-input__stepper--at-limit) {\n background: var(--nb-c-discrete);\n }\n\n &:disabled {\n cursor: not-allowed;\n }\n\n &--at-limit {\n opacity: var(--nb-field-disabled-opacity);\n cursor: not-allowed;\n }\n }\n\n &__message,\n &__fluid-message {\n font-size: var(--nb-font-size-12);\n }\n\n // FLUID variant\n &--fluid {\n .nb-number-input__field-wrapper {\n // When a label is present inside: expand to column layout\n &:has(.nb-number-input__inner-header) {\n flex: 1;\n flex-direction: column;\n align-items: stretch;\n justify-content: space-between;\n height: auto;\n min-height: calc(var(--nb-base-unit) * 8);\n padding-top: 8px;\n }\n }\n\n .nb-number-input__inner-header {\n display: flex;\n align-items: center;\n gap: 4px;\n padding: 0 var(--nb-field-padding-h);\n margin-bottom: 4px;\n }\n\n .nb-number-input__inner-label {\n flex: 1;\n min-width: 0;\n font-size: var(--nb-font-size-12);\n font-weight: 500;\n color: var(--nb-c-text-muted);\n text-transform: uppercase;\n letter-spacing: 0.02em;\n cursor: default;\n user-select: none;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n\n .nb-number-input__asterisk {\n color: var(--nb-c-danger);\n }\n\n .nb-number-input__fluid-row {\n display: flex;\n align-items: center;\n flex: 1;\n }\n\n .nb-number-input__field {\n height: auto;\n flex: 1;\n padding: 6px var(--nb-field-padding-h) 10px;\n font-size: 15px;\n }\n\n .nb-number-input__steppers {\n align-self: stretch;\n }\n\n .nb-number-input__stepper {\n height: 100%;\n }\n }\n}\n</style>\n","<template>\n <div :class=\"rootClasses\">\n <!-- DEFAULT variant -->\n <template v-if=\"variant === 'default'\">\n <NbLabel\n v-if=\"label\"\n :for=\"inputId\"\n :required=\"required\"\n :disabled=\"disabled\"\n >{{ label }}</NbLabel\n >\n\n <div class=\"nb-number-input__field-wrapper\" :class=\"wrapperClasses\">\n <input\n :id=\"inputId\"\n ref=\"inputRef\"\n type=\"number\"\n class=\"nb-number-input__field\"\n :placeholder=\"placeholder\"\n :min=\"min\"\n :max=\"max\"\n :step=\"step\"\n :disabled=\"disabled\"\n :required=\"required\"\n @input=\"onInput\"\n @blur=\"onBlur\"\n @keydown.enter.prevent=\"() => inputRef?.blur()\"\n @focus=\"focused = true\"\n />\n\n <NbMessage\n v-if=\"error\"\n variant=\"error\"\n :icon-only=\"true\"\n class=\"nb-number-input__status\"\n >{{ error }}</NbMessage\n >\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n :icon-only=\"true\"\n class=\"nb-number-input__status\"\n >{{ warning }}</NbMessage\n >\n\n <div class=\"nb-number-input__steppers\">\n <button\n type=\"button\"\n class=\"nb-number-input__stepper\"\n :class=\"{ 'nb-number-input__stepper--at-limit': isAtMin }\"\n :disabled=\"disabled\"\n aria-label=\"Decrease\"\n @mousedown.prevent\n @click=\"decrement\"\n >\n <NbIcon name=\"minus\" :size=\"16\" />\n </button>\n <button\n type=\"button\"\n class=\"nb-number-input__stepper\"\n :class=\"{ 'nb-number-input__stepper--at-limit': isAtMax }\"\n :disabled=\"disabled\"\n aria-label=\"Increase\"\n @mousedown.prevent\n @click=\"increment\"\n >\n <NbIcon name=\"plus\" :size=\"16\" />\n </button>\n </div>\n </div>\n\n <NbMessage\n v-if=\"error\"\n variant=\"error\"\n class=\"nb-number-input__message\"\n >{{ error }}</NbMessage\n >\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n class=\"nb-number-input__message\"\n >{{ warning }}</NbMessage\n >\n <NbMessage\n v-else-if=\"helper\"\n variant=\"helper\"\n class=\"nb-number-input__message\"\n >{{ helper }}</NbMessage\n >\n </template>\n\n <!-- FLUID variant -->\n <template v-else-if=\"variant === 'fluid'\">\n <div class=\"nb-number-input__field-wrapper\" :class=\"wrapperClasses\">\n <div v-if=\"label\" class=\"nb-number-input__inner-header\">\n <label :for=\"inputId\" class=\"nb-number-input__inner-label\">\n {{ label }}\n <span\n v-if=\"required\"\n class=\"nb-number-input__asterisk\"\n aria-hidden=\"true\"\n >*</span\n >\n </label>\n <NbMessage\n v-if=\"helper && !error && !warning\"\n variant=\"helper\"\n :icon-only=\"true\"\n class=\"nb-number-input__inner-message\"\n >{{ helper }}</NbMessage\n >\n </div>\n\n <div class=\"nb-number-input__fluid-row\">\n <input\n :id=\"inputId\"\n ref=\"inputRef\"\n type=\"number\"\n class=\"nb-number-input__field\"\n :placeholder=\"placeholder\"\n :min=\"min\"\n :max=\"max\"\n :step=\"step\"\n :disabled=\"disabled\"\n :required=\"required\"\n @input=\"onInput\"\n @blur=\"onBlur\"\n @keydown.enter.prevent=\"() => inputRef?.blur()\"\n @focus=\"focused = true\"\n />\n\n <NbMessage\n v-if=\"error\"\n variant=\"error\"\n :icon-only=\"true\"\n class=\"nb-number-input__status\"\n >{{ error }}</NbMessage\n >\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n :icon-only=\"true\"\n class=\"nb-number-input__status\"\n >{{ warning }}</NbMessage\n >\n\n <div class=\"nb-number-input__steppers\">\n <button\n type=\"button\"\n class=\"nb-number-input__stepper\"\n :class=\"{ 'nb-number-input__stepper--at-limit': isAtMin }\"\n :disabled=\"disabled\"\n aria-label=\"Decrease\"\n @mousedown.prevent\n @click=\"decrement\"\n >\n <NbIcon name=\"minus\" :size=\"16\" />\n </button>\n <button\n type=\"button\"\n class=\"nb-number-input__stepper\"\n :class=\"{ 'nb-number-input__stepper--at-limit': isAtMax }\"\n :disabled=\"disabled\"\n aria-label=\"Increase\"\n @mousedown.prevent\n @click=\"increment\"\n >\n <NbIcon name=\"plus\" :size=\"16\" />\n </button>\n </div>\n </div>\n </div>\n\n <NbMessage\n v-if=\"error\"\n variant=\"error\"\n class=\"nb-number-input__fluid-message\"\n >{{ error }}</NbMessage\n >\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n class=\"nb-number-input__fluid-message\"\n >{{ warning }}</NbMessage\n >\n </template>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed, onMounted, ref, useId, watch } from 'vue'\nimport type { IFieldComponent } from '@/types/Props.d'\nimport NbLabel from './Label.vue'\nimport NbMessage from './Message.vue'\nimport NbIcon from './Icon.vue'\n\nexport interface INumberInputProps extends IFieldComponent {\n modelValue?: number | null\n min?: number\n max?: number\n step?: number\n}\n\nconst props = withDefaults(defineProps<INumberInputProps>(), {\n modelValue: null,\n label: '',\n placeholder: '',\n helper: '',\n error: '',\n warning: '',\n min: undefined,\n max: undefined,\n step: 1,\n variant: 'default',\n size: 'md',\n disabled: false,\n required: false,\n id: undefined,\n})\n\nconst emit = defineEmits<{\n 'update:modelValue': [value: number | null]\n change: [value: number | null]\n}>()\n\nconst inputRef = ref<HTMLInputElement | null>(null)\nconst focused = ref(false)\n\nconst autoId = `nb-number-input-${useId()}`\nconst inputId = computed(() => props.id ?? autoId)\n\nconst isAtMin = computed(\n () =>\n props.min !== undefined &&\n props.modelValue !== null &&\n props.modelValue !== undefined &&\n props.modelValue <= props.min,\n)\nconst isAtMax = computed(\n () =>\n props.max !== undefined &&\n props.modelValue !== null &&\n props.modelValue !== undefined &&\n props.modelValue >= props.max,\n)\n\nfunction clamp(value: number): number {\n let v = value\n if (props.min !== undefined) v = Math.max(props.min, v)\n if (props.max !== undefined) v = Math.min(props.max, v)\n return v\n}\n\nfunction syncDisplay(val: number | null | undefined) {\n if (!inputRef.value) return\n inputRef.value.value = val !== null && val !== undefined ? String(val) : ''\n}\n\nonMounted(() => syncDisplay(props.modelValue))\n\nwatch(\n () => props.modelValue,\n (val) => {\n if (!focused.value) syncDisplay(val)\n },\n)\n\nfunction increment() {\n const current = props.modelValue ?? 0\n const next = clamp(current + props.step)\n emit('update:modelValue', next)\n emit('change', next)\n syncDisplay(next)\n}\n\nfunction decrement() {\n const current = props.modelValue ?? 0\n const next = clamp(current - props.step)\n emit('update:modelValue', next)\n emit('change', next)\n syncDisplay(next)\n}\n\nfunction onInput() {\n if (!inputRef.value) return\n const raw = inputRef.value.value\n if (raw === '') {\n emit('update:modelValue', null)\n } else {\n const num = parseFloat(raw)\n if (!isNaN(num)) emit('update:modelValue', num)\n }\n}\n\nfunction onBlur() {\n focused.value = false\n if (!inputRef.value) return\n const raw = inputRef.value.value\n if (raw === '') {\n emit('update:modelValue', null)\n emit('change', null)\n return\n }\n const num = parseFloat(raw)\n if (!isNaN(num)) {\n const clamped = clamp(num)\n emit('update:modelValue', clamped)\n emit('change', clamped)\n syncDisplay(clamped)\n }\n}\n\nconst rootClasses = computed(() => [\n 'nb-number-input',\n `nb-number-input--${props.variant}`,\n `nb-number-input--${props.size}`,\n {\n 'nb-number-input--error': !!props.error,\n 'nb-number-input--warning': !props.error && !!props.warning,\n 'nb-number-input--disabled': props.disabled,\n },\n])\n\nconst wrapperClasses = computed(() => ({\n 'nb-number-input__field-wrapper--focused': focused.value,\n 'nb-number-input__field-wrapper--error': !!props.error,\n 'nb-number-input__field-wrapper--warning': !props.error && !!props.warning,\n 'nb-number-input__field-wrapper--disabled': props.disabled,\n}))\n\ndefineExpose({ focus: () => inputRef.value?.focus() })\n</script>\n\n<style scoped lang=\"scss\">\n.nb-number-input {\n display: flex;\n flex-direction: column;\n flex: 1;\n gap: 6px;\n font-family: var(--nb-font-family-sans, sans-serif);\n --field-h: var(--nb-field-height-md);\n\n &--sm {\n --field-h: var(--nb-field-height-sm);\n }\n &--md {\n --field-h: var(--nb-field-height-md);\n }\n &--lg {\n --field-h: var(--nb-field-height-lg);\n }\n\n &__field-wrapper {\n position: relative;\n display: flex;\n align-items: stretch;\n background: var(--nb-c-field-bg);\n border-bottom: 1px solid var(--nb-c-field-border);\n height: var(--field-h);\n box-sizing: border-box;\n transition:\n border-color 0.15s,\n box-shadow 0.15s;\n\n &--focused {\n outline: 2px solid var(--nb-c-primary);\n outline-offset: -2px;\n }\n\n &--error {\n border: 1px solid var(--nb-c-danger);\n box-shadow: none;\n }\n\n &--warning {\n border: 1px solid var(--nb-c-warning);\n box-shadow: none;\n }\n\n &--disabled {\n opacity: var(--nb-field-disabled-opacity);\n cursor: not-allowed;\n }\n }\n\n &__field {\n flex: 1;\n min-width: 0;\n height: 100%;\n padding: 0 var(--nb-field-padding-h);\n background: transparent;\n border: none;\n outline: none;\n font-family: inherit;\n font-size: var(--nb-field-font-size);\n font-weight: 400;\n color: var(--nb-c-text);\n\n // Hide native number spinners\n appearance: none;\n -moz-appearance: textfield;\n\n &::-webkit-outer-spin-button,\n &::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0;\n }\n\n &:disabled {\n cursor: not-allowed;\n }\n }\n\n &__status {\n flex-shrink: 0;\n display: flex;\n align-items: center;\n padding: 0 4px;\n }\n\n &__steppers {\n display: flex;\n align-items: stretch;\n flex-shrink: 0;\n }\n\n &__stepper {\n display: flex;\n align-items: center;\n justify-content: center;\n width: 40px;\n background: transparent;\n border: none;\n cursor: pointer;\n color: var(--nb-c-text);\n transition: background 0.15s;\n padding: 0;\n flex-shrink: 0;\n position: relative;\n\n &::before {\n content: '';\n position: absolute;\n left: 0;\n top: 25%;\n bottom: 25%;\n width: 1px;\n background: var(--nb-c-field-border);\n }\n\n &:hover:not(:disabled):not(.nb-number-input__stepper--at-limit) {\n background: var(--nb-c-discrete);\n }\n\n &:disabled {\n cursor: not-allowed;\n }\n\n &--at-limit {\n opacity: var(--nb-field-disabled-opacity);\n cursor: not-allowed;\n }\n }\n\n &__message,\n &__fluid-message {\n font-size: var(--nb-font-size-12);\n }\n\n // FLUID variant\n &--fluid {\n .nb-number-input__field-wrapper {\n // When a label is present inside: expand to column layout\n &:has(.nb-number-input__inner-header) {\n flex: 1;\n flex-direction: column;\n align-items: stretch;\n justify-content: space-between;\n height: auto;\n min-height: calc(var(--nb-base-unit) * 8);\n padding-top: 8px;\n }\n }\n\n .nb-number-input__inner-header {\n display: flex;\n align-items: center;\n gap: 4px;\n padding: 0 var(--nb-field-padding-h);\n margin-bottom: 4px;\n }\n\n .nb-number-input__inner-label {\n flex: 1;\n min-width: 0;\n font-size: var(--nb-font-size-12);\n font-weight: 500;\n color: var(--nb-c-text-muted);\n text-transform: uppercase;\n letter-spacing: 0.02em;\n cursor: default;\n user-select: none;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n\n .nb-number-input__asterisk {\n color: var(--nb-c-danger);\n }\n\n .nb-number-input__fluid-row {\n display: flex;\n align-items: center;\n flex: 1;\n }\n\n .nb-number-input__field {\n height: auto;\n flex: 1;\n padding: 6px var(--nb-field-padding-h) 10px;\n font-size: 15px;\n }\n\n .nb-number-input__steppers {\n align-self: stretch;\n }\n\n .nb-number-input__stepper {\n height: 100%;\n }\n }\n}\n</style>\n","<template>\n <div class=\"nb-panel\">\n <slot />\n </div>\n</template>\n\n<script setup lang=\"ts\">\n// No props — Panel is a plain surface container\n</script>\n\n<style lang=\"scss\" scoped>\n.nb-panel {\n background: var(--nb-c-surface, #fff);\n border: 1px solid var(--nb-c-border, #ddd);\n padding: 12px;\n border-radius: 8px;\n}\n</style>\n","<template>\n <div class=\"nb-panel\">\n <slot />\n </div>\n</template>\n\n<script setup lang=\"ts\">\n// No props — Panel is a plain surface container\n</script>\n\n<style lang=\"scss\" scoped>\n.nb-panel {\n background: var(--nb-c-surface, #fff);\n border: 1px solid var(--nb-c-border, #ddd);\n padding: 12px;\n border-radius: 8px;\n}\n</style>\n","import {\n IHumanInputComponent,\n IWithLabel,\n IWithMessages,\n} from '@/types/Props.d'\n\ninterface IRadioOption {\n label: string\n value: string\n disabled?: boolean\n}\n\nenum ERadioDirection {\n Horizontal = 'horizontal',\n Vertical = 'vertical',\n}\n\ninterface IRadioProps extends IHumanInputComponent, IWithLabel, IWithMessages {\n modelValue?: string\n options: IRadioOption[]\n /** Required for native radio-button grouping via the HTML `name` attribute. */\n name: string\n direction?: ERadioDirection\n /** Makes options visible but non-interactive. */\n readonly?: boolean\n}\n\nexport { IRadioOption, ERadioDirection, IRadioProps }\n","<template>\n <div :class=\"rootClasses\">\n <NbLabel v-if=\"label\">{{ label }}</NbLabel>\n\n <div :class=\"['nb-radio__group', `nb-radio__group--${direction}`]\">\n <label\n v-for=\"option in options\"\n :key=\"option.value\"\n :class=\"optionClasses(option)\"\n >\n <span class=\"nb-radio__control\">\n <input\n type=\"radio\"\n :name=\"name\"\n :value=\"option.value\"\n :checked=\"modelValue === option.value\"\n :disabled=\"disabled || option.disabled\"\n :readonly=\"readonly\"\n class=\"nb-radio__input\"\n @change=\"!readonly && $emit('update:modelValue', option.value)\"\n />\n <span class=\"nb-radio__circle\">\n <span v-if=\"modelValue === option.value\" class=\"nb-radio__dot\" />\n </span>\n </span>\n <span class=\"nb-radio__text\">{{ option.label }}</span>\n </label>\n </div>\n\n <NbMessage v-if=\"error\" variant=\"error\" class=\"nb-radio__message\">{{\n error\n }}</NbMessage>\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n class=\"nb-radio__message\"\n >{{ warning }}</NbMessage\n >\n <NbMessage v-else-if=\"helper\" variant=\"helper\" class=\"nb-radio__message\">{{\n helper\n }}</NbMessage>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed } from 'vue'\nimport { ERadioDirection, IRadioProps, IRadioOption } from './Radio.d'\n\nconst props = withDefaults(defineProps<IRadioProps>(), {\n id: 'radio',\n direction: ERadioDirection.Vertical,\n disabled: false,\n readonly: false,\n error: undefined,\n warning: undefined,\n helper: undefined,\n})\n\ndefineEmits<{ 'update:modelValue': [value: string] }>()\n\nconst rootClasses = computed(() => [\n 'nb-radio',\n {\n 'nb-radio--error': !!props.error,\n 'nb-radio--warning': !props.error && !!props.warning,\n 'nb-radio--disabled': props.disabled,\n 'nb-radio--readonly': props.readonly,\n },\n])\n\nfunction optionClasses(option: IRadioOption) {\n return [\n 'nb-radio__option',\n {\n 'nb-radio__option--disabled': props.disabled || option.disabled,\n 'nb-radio__option--readonly': props.readonly,\n },\n ]\n}\n</script>\n\n<style scoped lang=\"scss\">\n.nb-radio {\n display: inline-flex;\n flex-direction: column;\n gap: 6px;\n font-family: var(--nb-font-family-sans);\n\n // ── Group label ─────────────────────────────────────────────────────────────\n // NbLabel handles its own styling; gap above handles spacing\n\n // ── Options group ───────────────────────────────────────────────────────────\n &__group {\n display: flex;\n gap: 4px;\n\n &--vertical {\n flex-direction: column;\n }\n\n &--horizontal {\n flex-direction: row;\n flex-wrap: wrap;\n gap: 12px;\n }\n }\n\n // ── Single option row ────────────────────────────────────────────────────────\n &__option {\n display: inline-flex;\n align-items: center;\n gap: 10px;\n cursor: pointer;\n user-select: none;\n min-height: 28px;\n\n &--disabled {\n opacity: var(--nb-field-disabled-opacity, 0.45);\n cursor: not-allowed;\n pointer-events: none;\n }\n\n &--readonly {\n cursor: default;\n pointer-events: none;\n }\n }\n\n // ── Custom control ───────────────────────────────────────────────────────────\n &__control {\n position: relative;\n flex-shrink: 0;\n display: flex;\n align-items: center;\n justify-content: center;\n }\n\n // Native input: hidden but still focusable\n &__input {\n position: absolute;\n opacity: 0;\n width: 0;\n height: 0;\n pointer-events: none;\n }\n\n // ── Circle ───────────────────────────────────────────────────────────────────\n &__circle {\n display: flex;\n align-items: center;\n justify-content: center;\n width: 18px;\n height: 18px;\n border: 1.5px solid var(--nb-c-field-border);\n border-radius: 50%;\n transition:\n border-color 0.15s,\n box-shadow 0.15s;\n }\n\n // ── Dot (selected indicator) ──────────────────────────────────────────────────\n &__dot {\n width: 8px;\n height: 8px;\n border-radius: 50%;\n background: var(--nb-c-contrast);\n animation: nb-radio-pop 0.12s ease;\n }\n\n // ── Option label text ─────────────────────────────────────────────────────────\n &__text {\n font-size: var(--nb-font-size-14);\n color: var(--nb-c-text);\n line-height: 1.4;\n }\n\n // ── Message ───────────────────────────────────────────────────────────────────\n &__message {\n font-size: var(--nb-font-size-12);\n }\n\n // ── Hover ─────────────────────────────────────────────────────────────────────\n &__option:not(&__option--disabled):not(&__option--readonly):hover &__circle {\n border-color: var(--nb-c-primary);\n }\n\n // ── Focus ring ────────────────────────────────────────────────────────────────\n &__input:focus-visible ~ &__circle {\n box-shadow: 0 0 0 2px var(--nb-c-primary);\n }\n\n // ── Checked: dark border + dark dot ──────────────────────────────────────────\n &__input:checked ~ &__circle {\n border-color: var(--nb-c-contrast);\n }\n\n // ── Error state: danger border + danger dot ───────────────────────────────────\n &--error {\n .nb-radio__circle {\n border-color: var(--nb-c-danger);\n }\n\n .nb-radio__input:checked ~ .nb-radio__circle {\n border-color: var(--nb-c-danger);\n }\n\n .nb-radio__dot {\n background: var(--nb-c-danger);\n }\n\n .nb-radio__option:not(.nb-radio__option--disabled):hover .nb-radio__circle {\n border-color: color-mix(\n in srgb,\n var(--nb-c-danger) 80%,\n var(--nb-c-contrast)\n );\n }\n }\n\n // ── Disabled (group-level) ────────────────────────────────────────────────────\n &--disabled {\n .nb-radio__group {\n opacity: var(--nb-field-disabled-opacity, 0.45);\n pointer-events: none;\n }\n }\n\n // ── Read-only ─────────────────────────────────────────────────────────────────\n &--readonly {\n .nb-radio__circle {\n background: transparent;\n }\n\n .nb-radio__input:not(:checked) ~ .nb-radio__circle {\n border-color: color-mix(\n in srgb,\n var(--nb-c-field-border) 100%,\n transparent\n );\n opacity: 0.6;\n }\n }\n\n @keyframes nb-radio-pop {\n from {\n transform: scale(0);\n }\n to {\n transform: scale(1);\n }\n }\n}\n</style>\n","<template>\n <div :class=\"rootClasses\">\n <NbLabel v-if=\"label\">{{ label }}</NbLabel>\n\n <div :class=\"['nb-radio__group', `nb-radio__group--${direction}`]\">\n <label\n v-for=\"option in options\"\n :key=\"option.value\"\n :class=\"optionClasses(option)\"\n >\n <span class=\"nb-radio__control\">\n <input\n type=\"radio\"\n :name=\"name\"\n :value=\"option.value\"\n :checked=\"modelValue === option.value\"\n :disabled=\"disabled || option.disabled\"\n :readonly=\"readonly\"\n class=\"nb-radio__input\"\n @change=\"!readonly && $emit('update:modelValue', option.value)\"\n />\n <span class=\"nb-radio__circle\">\n <span v-if=\"modelValue === option.value\" class=\"nb-radio__dot\" />\n </span>\n </span>\n <span class=\"nb-radio__text\">{{ option.label }}</span>\n </label>\n </div>\n\n <NbMessage v-if=\"error\" variant=\"error\" class=\"nb-radio__message\">{{\n error\n }}</NbMessage>\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n class=\"nb-radio__message\"\n >{{ warning }}</NbMessage\n >\n <NbMessage v-else-if=\"helper\" variant=\"helper\" class=\"nb-radio__message\">{{\n helper\n }}</NbMessage>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed } from 'vue'\nimport { ERadioDirection, IRadioProps, IRadioOption } from './Radio.d'\n\nconst props = withDefaults(defineProps<IRadioProps>(), {\n id: 'radio',\n direction: ERadioDirection.Vertical,\n disabled: false,\n readonly: false,\n error: undefined,\n warning: undefined,\n helper: undefined,\n})\n\ndefineEmits<{ 'update:modelValue': [value: string] }>()\n\nconst rootClasses = computed(() => [\n 'nb-radio',\n {\n 'nb-radio--error': !!props.error,\n 'nb-radio--warning': !props.error && !!props.warning,\n 'nb-radio--disabled': props.disabled,\n 'nb-radio--readonly': props.readonly,\n },\n])\n\nfunction optionClasses(option: IRadioOption) {\n return [\n 'nb-radio__option',\n {\n 'nb-radio__option--disabled': props.disabled || option.disabled,\n 'nb-radio__option--readonly': props.readonly,\n },\n ]\n}\n</script>\n\n<style scoped lang=\"scss\">\n.nb-radio {\n display: inline-flex;\n flex-direction: column;\n gap: 6px;\n font-family: var(--nb-font-family-sans);\n\n // ── Group label ─────────────────────────────────────────────────────────────\n // NbLabel handles its own styling; gap above handles spacing\n\n // ── Options group ───────────────────────────────────────────────────────────\n &__group {\n display: flex;\n gap: 4px;\n\n &--vertical {\n flex-direction: column;\n }\n\n &--horizontal {\n flex-direction: row;\n flex-wrap: wrap;\n gap: 12px;\n }\n }\n\n // ── Single option row ────────────────────────────────────────────────────────\n &__option {\n display: inline-flex;\n align-items: center;\n gap: 10px;\n cursor: pointer;\n user-select: none;\n min-height: 28px;\n\n &--disabled {\n opacity: var(--nb-field-disabled-opacity, 0.45);\n cursor: not-allowed;\n pointer-events: none;\n }\n\n &--readonly {\n cursor: default;\n pointer-events: none;\n }\n }\n\n // ── Custom control ───────────────────────────────────────────────────────────\n &__control {\n position: relative;\n flex-shrink: 0;\n display: flex;\n align-items: center;\n justify-content: center;\n }\n\n // Native input: hidden but still focusable\n &__input {\n position: absolute;\n opacity: 0;\n width: 0;\n height: 0;\n pointer-events: none;\n }\n\n // ── Circle ───────────────────────────────────────────────────────────────────\n &__circle {\n display: flex;\n align-items: center;\n justify-content: center;\n width: 18px;\n height: 18px;\n border: 1.5px solid var(--nb-c-field-border);\n border-radius: 50%;\n transition:\n border-color 0.15s,\n box-shadow 0.15s;\n }\n\n // ── Dot (selected indicator) ──────────────────────────────────────────────────\n &__dot {\n width: 8px;\n height: 8px;\n border-radius: 50%;\n background: var(--nb-c-contrast);\n animation: nb-radio-pop 0.12s ease;\n }\n\n // ── Option label text ─────────────────────────────────────────────────────────\n &__text {\n font-size: var(--nb-font-size-14);\n color: var(--nb-c-text);\n line-height: 1.4;\n }\n\n // ── Message ───────────────────────────────────────────────────────────────────\n &__message {\n font-size: var(--nb-font-size-12);\n }\n\n // ── Hover ─────────────────────────────────────────────────────────────────────\n &__option:not(&__option--disabled):not(&__option--readonly):hover &__circle {\n border-color: var(--nb-c-primary);\n }\n\n // ── Focus ring ────────────────────────────────────────────────────────────────\n &__input:focus-visible ~ &__circle {\n box-shadow: 0 0 0 2px var(--nb-c-primary);\n }\n\n // ── Checked: dark border + dark dot ──────────────────────────────────────────\n &__input:checked ~ &__circle {\n border-color: var(--nb-c-contrast);\n }\n\n // ── Error state: danger border + danger dot ───────────────────────────────────\n &--error {\n .nb-radio__circle {\n border-color: var(--nb-c-danger);\n }\n\n .nb-radio__input:checked ~ .nb-radio__circle {\n border-color: var(--nb-c-danger);\n }\n\n .nb-radio__dot {\n background: var(--nb-c-danger);\n }\n\n .nb-radio__option:not(.nb-radio__option--disabled):hover .nb-radio__circle {\n border-color: color-mix(\n in srgb,\n var(--nb-c-danger) 80%,\n var(--nb-c-contrast)\n );\n }\n }\n\n // ── Disabled (group-level) ────────────────────────────────────────────────────\n &--disabled {\n .nb-radio__group {\n opacity: var(--nb-field-disabled-opacity, 0.45);\n pointer-events: none;\n }\n }\n\n // ── Read-only ─────────────────────────────────────────────────────────────────\n &--readonly {\n .nb-radio__circle {\n background: transparent;\n }\n\n .nb-radio__input:not(:checked) ~ .nb-radio__circle {\n border-color: color-mix(\n in srgb,\n var(--nb-c-field-border) 100%,\n transparent\n );\n opacity: 0.6;\n }\n }\n\n @keyframes nb-radio-pop {\n from {\n transform: scale(0);\n }\n to {\n transform: scale(1);\n }\n }\n}\n</style>\n","<template>\n <div ref=\"rootRef\" :class=\"rootClasses\" @keydown=\"onKeydown\">\n <!-- DEFAULT variant -->\n <template v-if=\"variant === 'default'\">\n <slot v-if=\"$slots.label\" name=\"label\" />\n <NbLabel\n v-else-if=\"label\"\n :for=\"inputId\"\n :required=\"required\"\n :disabled=\"disabled\"\n >{{ label }}</NbLabel\n >\n\n <button\n :id=\"inputId\"\n ref=\"triggerRef\"\n type=\"button\"\n class=\"nb-select__trigger\"\n role=\"combobox\"\n :aria-expanded=\"isOpen\"\n :aria-haspopup=\"'listbox'\"\n :aria-disabled=\"disabled || undefined\"\n :aria-required=\"required || undefined\"\n :disabled=\"disabled || undefined\"\n @click=\"toggleDropdown\"\n @focus=\"focused = true\"\n @blur=\"focused = false\"\n >\n <span\n :class=\"[\n 'nb-select__value',\n { 'nb-select__value--placeholder': !displayValue },\n ]\"\n >\n {{ displayValue || placeholder }}\n </span>\n <NbMessage\n v-if=\"error\"\n variant=\"error\"\n :icon-only=\"true\"\n class=\"nb-select__status-icon\"\n >{{ error }}</NbMessage\n >\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n :icon-only=\"true\"\n class=\"nb-select__status-icon\"\n >{{ warning }}</NbMessage\n >\n <NbGrid align=\"center\" justify=\"center\" class=\"nb-select__caret\">\n <NbIcon :name=\"isOpen ? 'caret-up' : 'caret-down'\" :size=\"16\" />\n </NbGrid>\n </button>\n\n <NbMessage v-if=\"error\" variant=\"error\" class=\"nb-select__message\">{{\n error\n }}</NbMessage>\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n class=\"nb-select__message\"\n >{{ warning }}</NbMessage\n >\n <NbMessage\n v-else-if=\"helper\"\n variant=\"helper\"\n class=\"nb-select__message\"\n >{{ helper }}</NbMessage\n >\n </template>\n\n <!-- FLUID variant -->\n <template v-else-if=\"variant === 'fluid'\">\n <button\n :id=\"inputId\"\n ref=\"triggerRef\"\n type=\"button\"\n class=\"nb-select__trigger\"\n role=\"combobox\"\n :aria-expanded=\"isOpen\"\n :aria-haspopup=\"'listbox'\"\n :aria-disabled=\"disabled || undefined\"\n :aria-required=\"required || undefined\"\n :disabled=\"disabled || undefined\"\n @click=\"toggleDropdown\"\n @focus=\"focused = true\"\n @blur=\"focused = false\"\n >\n <NbGrid\n v-if=\"label || $slots.label\"\n dir=\"row\"\n align=\"center\"\n gap=\"xs\"\n class=\"nb-select__inner-header\"\n >\n <slot v-if=\"$slots.label\" name=\"label\" />\n <label v-else class=\"nb-select__inner-label\">\n {{ label }}\n <span v-if=\"required\" class=\"nb-select__asterisk\" aria-hidden=\"true\"\n >*</span\n >\n </label>\n <NbMessage\n v-if=\"helper && !error && !warning\"\n variant=\"helper\"\n :icon-only=\"true\"\n class=\"nb-select__inner-message\"\n >{{ helper }}</NbMessage\n >\n </NbGrid>\n <NbGrid dir=\"row\" align=\"end\" flex class=\"nb-select__value-row\">\n <span\n :class=\"[\n 'nb-select__value',\n { 'nb-select__value--placeholder': !displayValue },\n ]\"\n >\n {{ displayValue || placeholder }}\n </span>\n <NbGrid align=\"center\" justify=\"center\" class=\"nb-select__caret\">\n <NbIcon :name=\"isOpen ? 'caret-up' : 'caret-down'\" :size=\"16\" />\n </NbGrid>\n </NbGrid>\n </button>\n\n <NbMessage\n v-if=\"error\"\n variant=\"error\"\n class=\"nb-select__fluid-message\"\n >{{ error }}</NbMessage\n >\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n class=\"nb-select__fluid-message\"\n >{{ warning }}</NbMessage\n >\n </template>\n </div>\n\n <!-- Dropdown teleported to body to escape overflow:hidden parents -->\n <Teleport to=\"body\">\n <div\n v-if=\"isOpen\"\n ref=\"dropdownRef\"\n class=\"nb-select__dropdown\"\n :style=\"dropdownStyle\"\n role=\"listbox\"\n :aria-multiselectable=\"multiple || undefined\"\n >\n <div\n v-for=\"(option, idx) in options\"\n :key=\"option.value\"\n :class=\"[\n 'nb-select__option',\n {\n 'nb-select__option--selected': isSelected(option.value),\n 'nb-select__option--highlighted': highlighted === idx,\n 'nb-select__option--disabled': option.disabled,\n },\n ]\"\n role=\"option\"\n :aria-selected=\"isSelected(option.value)\"\n :aria-disabled=\"option.disabled || undefined\"\n @mouseenter=\"highlighted = idx\"\n @click=\"selectOption(option)\"\n >\n <span\n v-if=\"multiple\"\n class=\"nb-select__option-check\"\n aria-hidden=\"true\"\n >\n <svg\n v-if=\"isSelected(option.value)\"\n viewBox=\"0 0 10 8\"\n fill=\"none\"\n width=\"10\"\n height=\"8\"\n >\n <path\n d=\"M1 4l3 3 5-6\"\n stroke=\"currentColor\"\n stroke-width=\"1.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n />\n </svg>\n </span>\n <span class=\"nb-select__option-label\">{{ option.label }}</span>\n </div>\n <div v-if=\"!options || options.length === 0\" class=\"nb-select__empty\">\n No options\n </div>\n </div>\n </Teleport>\n</template>\n\n<script setup lang=\"ts\">\nimport { ref, computed, watch, nextTick, onBeforeUnmount, useId } from 'vue'\nimport { ISelectOption, ISelectProps } from './Select'\n\nconst props = withDefaults(defineProps<ISelectProps>(), {\n modelValue: null,\n options: () => [],\n multiple: false,\n variant: 'default',\n size: 'md',\n label: '',\n placeholder: 'Select…',\n helper: '',\n error: '',\n warning: '',\n disabled: false,\n required: false,\n id: undefined,\n name: '',\n})\n\nconst emit = defineEmits<{\n 'update:modelValue': [value: string | number | Array<string | number> | null]\n change: [value: string | number | Array<string | number> | null]\n}>()\n\nconst isOpen = ref(false)\nconst focused = ref(false)\nconst highlighted = ref(-1)\nconst rootRef = ref<HTMLElement | null>(null)\nconst triggerRef = ref<HTMLElement | null>(null)\nconst dropdownRef = ref<HTMLElement | null>(null)\nconst dropdownStyle = ref({\n position: 'fixed' as const,\n top: '0px',\n left: '0px',\n width: '0px',\n zIndex: '9999',\n})\n\nconst autoId = `nb-select-${useId()}`\nconst inputId = computed(() => props.id ?? autoId)\n\nconst selectedValues = computed<Array<string | number>>(() => {\n if (props.modelValue == null) return []\n return Array.isArray(props.modelValue) ? props.modelValue : [props.modelValue]\n})\n\nconst displayValue = computed(() => {\n if (selectedValues.value.length === 0) return ''\n const opts = props.options ?? []\n if (props.multiple) {\n if (selectedValues.value.length === 1) {\n return (\n opts.find((o) => o.value === selectedValues.value[0])?.label ??\n String(selectedValues.value[0])\n )\n }\n if (selectedValues.value.length === 2) {\n return selectedValues.value\n .map((v) => opts.find((o) => o.value === v)?.label ?? String(v))\n .join(', ')\n }\n return `${selectedValues.value.length} selected`\n }\n return (\n opts.find((o) => o.value === selectedValues.value[0])?.label ??\n String(selectedValues.value[0])\n )\n})\n\nfunction isSelected(value: string | number) {\n return selectedValues.value.includes(value)\n}\n\nfunction selectOption(option: ISelectOption) {\n if (option.disabled) return\n let next: string | number | Array<string | number> | null\n if (props.multiple) {\n const arr = [...selectedValues.value]\n const idx = arr.indexOf(option.value)\n if (idx >= 0) arr.splice(idx, 1)\n else arr.push(option.value)\n next = arr\n } else {\n next = option.value\n closeDropdown()\n }\n emit('update:modelValue', next)\n emit('change', next)\n}\n\nfunction updateDropdownPosition() {\n if (!triggerRef.value) return\n const rect = triggerRef.value.getBoundingClientRect()\n dropdownStyle.value = {\n position: 'fixed',\n top: `${rect.bottom}px`,\n left: `${rect.left}px`,\n width: `${rect.width}px`,\n zIndex: '9999',\n }\n}\n\nfunction openDropdown() {\n if (props.disabled) return\n isOpen.value = true\n updateDropdownPosition()\n const opts = props.options ?? []\n highlighted.value =\n selectedValues.value.length > 0\n ? Math.max(\n 0,\n opts.findIndex((o) => o.value === selectedValues.value[0]),\n )\n : -1\n nextTick(scrollToHighlighted)\n}\n\nfunction closeDropdown() {\n isOpen.value = false\n highlighted.value = -1\n}\n\nfunction toggleDropdown() {\n if (isOpen.value) closeDropdown()\n else openDropdown()\n}\n\nfunction onClickOutside(e: MouseEvent) {\n const target = e.target as Node\n const inRoot = rootRef.value?.contains(target) ?? false\n const inDropdown = dropdownRef.value?.contains(target) ?? false\n if (!inRoot && !inDropdown) closeDropdown()\n}\n\nfunction onScrollOrResize() {\n if (isOpen.value) updateDropdownPosition()\n}\n\nwatch(isOpen, (val) => {\n if (val) {\n document.addEventListener('mousedown', onClickOutside)\n window.addEventListener('scroll', onScrollOrResize, true)\n window.addEventListener('resize', onScrollOrResize)\n } else {\n document.removeEventListener('mousedown', onClickOutside)\n window.removeEventListener('scroll', onScrollOrResize, true)\n window.removeEventListener('resize', onScrollOrResize)\n }\n})\n\nonBeforeUnmount(() => {\n document.removeEventListener('mousedown', onClickOutside)\n window.removeEventListener('scroll', onScrollOrResize, true)\n window.removeEventListener('resize', onScrollOrResize)\n})\n\nfunction onKeydown(e: KeyboardEvent) {\n const opts = props.options ?? []\n if (!isOpen.value) {\n if (e.key === 'Enter' || e.key === ' ' || e.key === 'ArrowDown') {\n e.preventDefault()\n openDropdown()\n }\n return\n }\n if (e.key === 'Escape') {\n closeDropdown()\n e.preventDefault()\n } else if (e.key === 'Tab') {\n closeDropdown()\n } else if (e.key === 'ArrowDown') {\n e.preventDefault()\n highlighted.value = Math.min(highlighted.value + 1, opts.length - 1)\n scrollToHighlighted()\n } else if (e.key === 'ArrowUp') {\n e.preventDefault()\n highlighted.value = Math.max(highlighted.value - 1, 0)\n scrollToHighlighted()\n } else if ((e.key === 'Enter' || e.key === ' ') && highlighted.value >= 0) {\n e.preventDefault()\n selectOption(opts[highlighted.value])\n }\n}\n\nfunction scrollToHighlighted() {\n nextTick(() => {\n if (!dropdownRef.value || highlighted.value < 0) return\n const item =\n dropdownRef.value.querySelectorAll<HTMLElement>('.nb-select__option')[\n highlighted.value\n ]\n item?.scrollIntoView({ block: 'nearest' })\n })\n}\n\nconst rootClasses = computed(() => [\n 'nb-select',\n `nb-select--${props.variant}`,\n `nb-select--${props.size}`,\n {\n 'nb-select--open': isOpen.value,\n 'nb-select--focused': focused.value && !isOpen.value,\n 'nb-select--error': !!props.error,\n 'nb-select--warning': !props.error && !!props.warning,\n 'nb-select--multiple': props.multiple,\n },\n])\n\ndefineExpose({\n open: openDropdown,\n close: closeDropdown,\n})\n</script>\n\n<style lang=\"scss\">\n// Dropdown is teleported to body: cannot use scoped styles\n.nb-select__dropdown {\n background: var(--nb-c-field-bg, var(--nb-c-french-gray-100, #f4f4f4));\n border: 1px solid\n var(--nb-c-field-border, var(--nb-c-french-gray-500, #a7a7a7));\n max-height: 240px;\n overflow-y: auto;\n overscroll-behavior: contain;\n box-sizing: border-box;\n box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);\n}\n\n.nb-select__option {\n display: flex;\n align-items: center;\n gap: 8px;\n padding: 10px 16px;\n font-size: 14px;\n font-weight: 400;\n color: var(--nb-c-text, #161616);\n cursor: pointer;\n position: relative;\n transition: background 0.1s;\n\n &::after {\n content: '';\n position: absolute;\n bottom: 0;\n left: 16px;\n right: 16px;\n height: 1px;\n background: var(--nb-c-component-plain-border);\n }\n\n &:last-child::after {\n display: none;\n }\n\n &--highlighted {\n background: color-mix(in srgb, var(--nb-c-primary) 8%, transparent);\n }\n\n &--selected {\n background: var(--nb-c-primary, #5856a9);\n color: var(--nb-c-surface);\n font-weight: 500;\n\n .nb-select__option-check {\n color: var(--nb-c-surface);\n }\n }\n\n &--selected.nb-select__option--highlighted {\n background: color-mix(in srgb, var(--nb-c-primary, #5856a9) 85%, black);\n }\n\n &--disabled {\n opacity: 0.45;\n cursor: not-allowed;\n }\n}\n\n.nb-select__option-check {\n width: 14px;\n flex-shrink: 0;\n color: var(--nb-c-primary, #5856a9);\n display: flex;\n align-items: center;\n}\n\n.nb-select__option-label {\n flex: 1;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n}\n\n.nb-select__empty {\n padding: 12px 16px;\n font-size: 14px;\n color: var(--nb-c-text-subtle, var(--nb-c-nouveau-gray-500, #6b7280));\n text-align: center;\n}\n\n.nb-select {\n position: relative;\n display: flex;\n flex-direction: column;\n gap: 6px;\n font-family: var(--nb-font-family-sans, sans-serif);\n --field-h: var(--nb-field-height-md);\n\n &--sm {\n --field-h: var(--nb-field-height-sm);\n }\n &--md {\n --field-h: var(--nb-field-height-md);\n }\n &--lg {\n --field-h: var(--nb-field-height-lg);\n }\n\n &__trigger {\n position: relative;\n display: flex;\n align-items: center;\n width: 100%;\n height: var(--field-h);\n padding: 0 var(--nb-field-padding-h);\n gap: 8px;\n background: var(--nb-c-field-bg);\n border: none;\n border-bottom: 1px solid var(--nb-c-field-border);\n border-radius: 0;\n cursor: pointer;\n user-select: none;\n font: inherit;\n text-align: left;\n appearance: none;\n transition:\n border-color 0.15s,\n box-shadow 0.15s,\n background 0.15s;\n outline: none;\n box-sizing: border-box;\n\n &:hover:not(:disabled) {\n background: color-mix(\n in srgb,\n var(--nb-c-field-border) 15%,\n var(--nb-c-field-bg)\n );\n border-bottom-color: color-mix(\n in srgb,\n var(--nb-c-primary) 50%,\n var(--nb-c-field-border)\n );\n }\n\n &:disabled {\n opacity: var(--nb-field-disabled-opacity);\n cursor: not-allowed;\n }\n }\n\n &--focused &__trigger {\n outline: 2px solid var(--nb-c-primary);\n outline-offset: -2px;\n }\n\n &--open &__trigger {\n outline: none;\n }\n\n &--error &__trigger {\n border: 1px solid var(--nb-c-danger);\n box-shadow: none;\n }\n\n &--warning &__trigger {\n border: 1px solid var(--nb-c-warning);\n box-shadow: none;\n }\n\n &__value {\n flex: 1;\n min-width: 0;\n font-size: var(--nb-c-field-font-size);\n font-weight: 400;\n line-height: 1.5;\n color: var(--nb-c-text);\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n\n &--placeholder {\n color: var(--nb-c-text-subtle);\n }\n }\n\n &__status-icon {\n flex-shrink: 0;\n .nb-message__tooltip {\n z-index: calc(var(--nb-zindex-tooltip, 401) + 1);\n }\n }\n\n &__caret {\n flex-shrink: 0;\n color: var(--nb-c-field-border);\n transition: color 0.15s;\n\n .nb-select--open & {\n color: var(--nb-c-primary);\n }\n .nb-select--error & {\n color: var(--nb-c-danger);\n }\n .nb-select--warning & {\n color: var(--nb-c-warning);\n }\n }\n\n &__message,\n &__fluid-message {\n font-size: var(--nb-font-size-12);\n }\n\n &--fluid {\n .nb-select__trigger {\n flex: 1;\n flex-direction: column;\n align-items: stretch;\n justify-content: space-between;\n height: auto;\n min-height: calc(var(--nb-base-unit) * 8);\n padding: calc(var(--nb-base-unit) * 1) 0 0;\n gap: 0;\n }\n\n .nb-select__inner-header {\n padding: 0 var(--nb-field-padding-h);\n margin-bottom: 4px;\n }\n\n .nb-select__inner-label {\n flex: 1;\n min-width: 0;\n font-size: var(--nb-font-size-12);\n font-weight: 500;\n color: var(--nb-c-text-muted);\n letter-spacing: 0.02em;\n cursor: default;\n user-select: none;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n\n .nb-select__asterisk {\n color: var(--nb-c-danger);\n }\n\n .nb-select__inner-message {\n flex-shrink: 0;\n }\n\n .nb-select__value-row {\n padding: 0 0 10px;\n }\n\n .nb-select__value {\n flex: 1;\n padding: 0 var(--nb-field-padding-h);\n font-size: var(--nb-font-size-14);\n }\n\n .nb-select__caret {\n position: static;\n width: auto;\n height: auto;\n padding: 0 var(--nb-field-padding-h);\n }\n }\n}\n</style>\n","<template>\n <div ref=\"rootRef\" :class=\"rootClasses\" @keydown=\"onKeydown\">\n <!-- DEFAULT variant -->\n <template v-if=\"variant === 'default'\">\n <slot v-if=\"$slots.label\" name=\"label\" />\n <NbLabel\n v-else-if=\"label\"\n :for=\"inputId\"\n :required=\"required\"\n :disabled=\"disabled\"\n >{{ label }}</NbLabel\n >\n\n <button\n :id=\"inputId\"\n ref=\"triggerRef\"\n type=\"button\"\n class=\"nb-select__trigger\"\n role=\"combobox\"\n :aria-expanded=\"isOpen\"\n :aria-haspopup=\"'listbox'\"\n :aria-disabled=\"disabled || undefined\"\n :aria-required=\"required || undefined\"\n :disabled=\"disabled || undefined\"\n @click=\"toggleDropdown\"\n @focus=\"focused = true\"\n @blur=\"focused = false\"\n >\n <span\n :class=\"[\n 'nb-select__value',\n { 'nb-select__value--placeholder': !displayValue },\n ]\"\n >\n {{ displayValue || placeholder }}\n </span>\n <NbMessage\n v-if=\"error\"\n variant=\"error\"\n :icon-only=\"true\"\n class=\"nb-select__status-icon\"\n >{{ error }}</NbMessage\n >\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n :icon-only=\"true\"\n class=\"nb-select__status-icon\"\n >{{ warning }}</NbMessage\n >\n <NbGrid align=\"center\" justify=\"center\" class=\"nb-select__caret\">\n <NbIcon :name=\"isOpen ? 'caret-up' : 'caret-down'\" :size=\"16\" />\n </NbGrid>\n </button>\n\n <NbMessage v-if=\"error\" variant=\"error\" class=\"nb-select__message\">{{\n error\n }}</NbMessage>\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n class=\"nb-select__message\"\n >{{ warning }}</NbMessage\n >\n <NbMessage\n v-else-if=\"helper\"\n variant=\"helper\"\n class=\"nb-select__message\"\n >{{ helper }}</NbMessage\n >\n </template>\n\n <!-- FLUID variant -->\n <template v-else-if=\"variant === 'fluid'\">\n <button\n :id=\"inputId\"\n ref=\"triggerRef\"\n type=\"button\"\n class=\"nb-select__trigger\"\n role=\"combobox\"\n :aria-expanded=\"isOpen\"\n :aria-haspopup=\"'listbox'\"\n :aria-disabled=\"disabled || undefined\"\n :aria-required=\"required || undefined\"\n :disabled=\"disabled || undefined\"\n @click=\"toggleDropdown\"\n @focus=\"focused = true\"\n @blur=\"focused = false\"\n >\n <NbGrid\n v-if=\"label || $slots.label\"\n dir=\"row\"\n align=\"center\"\n gap=\"xs\"\n class=\"nb-select__inner-header\"\n >\n <slot v-if=\"$slots.label\" name=\"label\" />\n <label v-else class=\"nb-select__inner-label\">\n {{ label }}\n <span v-if=\"required\" class=\"nb-select__asterisk\" aria-hidden=\"true\"\n >*</span\n >\n </label>\n <NbMessage\n v-if=\"helper && !error && !warning\"\n variant=\"helper\"\n :icon-only=\"true\"\n class=\"nb-select__inner-message\"\n >{{ helper }}</NbMessage\n >\n </NbGrid>\n <NbGrid dir=\"row\" align=\"end\" flex class=\"nb-select__value-row\">\n <span\n :class=\"[\n 'nb-select__value',\n { 'nb-select__value--placeholder': !displayValue },\n ]\"\n >\n {{ displayValue || placeholder }}\n </span>\n <NbGrid align=\"center\" justify=\"center\" class=\"nb-select__caret\">\n <NbIcon :name=\"isOpen ? 'caret-up' : 'caret-down'\" :size=\"16\" />\n </NbGrid>\n </NbGrid>\n </button>\n\n <NbMessage\n v-if=\"error\"\n variant=\"error\"\n class=\"nb-select__fluid-message\"\n >{{ error }}</NbMessage\n >\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n class=\"nb-select__fluid-message\"\n >{{ warning }}</NbMessage\n >\n </template>\n </div>\n\n <!-- Dropdown teleported to body to escape overflow:hidden parents -->\n <Teleport to=\"body\">\n <div\n v-if=\"isOpen\"\n ref=\"dropdownRef\"\n class=\"nb-select__dropdown\"\n :style=\"dropdownStyle\"\n role=\"listbox\"\n :aria-multiselectable=\"multiple || undefined\"\n >\n <div\n v-for=\"(option, idx) in options\"\n :key=\"option.value\"\n :class=\"[\n 'nb-select__option',\n {\n 'nb-select__option--selected': isSelected(option.value),\n 'nb-select__option--highlighted': highlighted === idx,\n 'nb-select__option--disabled': option.disabled,\n },\n ]\"\n role=\"option\"\n :aria-selected=\"isSelected(option.value)\"\n :aria-disabled=\"option.disabled || undefined\"\n @mouseenter=\"highlighted = idx\"\n @click=\"selectOption(option)\"\n >\n <span\n v-if=\"multiple\"\n class=\"nb-select__option-check\"\n aria-hidden=\"true\"\n >\n <svg\n v-if=\"isSelected(option.value)\"\n viewBox=\"0 0 10 8\"\n fill=\"none\"\n width=\"10\"\n height=\"8\"\n >\n <path\n d=\"M1 4l3 3 5-6\"\n stroke=\"currentColor\"\n stroke-width=\"1.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n />\n </svg>\n </span>\n <span class=\"nb-select__option-label\">{{ option.label }}</span>\n </div>\n <div v-if=\"!options || options.length === 0\" class=\"nb-select__empty\">\n No options\n </div>\n </div>\n </Teleport>\n</template>\n\n<script setup lang=\"ts\">\nimport { ref, computed, watch, nextTick, onBeforeUnmount, useId } from 'vue'\nimport { ISelectOption, ISelectProps } from './Select'\n\nconst props = withDefaults(defineProps<ISelectProps>(), {\n modelValue: null,\n options: () => [],\n multiple: false,\n variant: 'default',\n size: 'md',\n label: '',\n placeholder: 'Select…',\n helper: '',\n error: '',\n warning: '',\n disabled: false,\n required: false,\n id: undefined,\n name: '',\n})\n\nconst emit = defineEmits<{\n 'update:modelValue': [value: string | number | Array<string | number> | null]\n change: [value: string | number | Array<string | number> | null]\n}>()\n\nconst isOpen = ref(false)\nconst focused = ref(false)\nconst highlighted = ref(-1)\nconst rootRef = ref<HTMLElement | null>(null)\nconst triggerRef = ref<HTMLElement | null>(null)\nconst dropdownRef = ref<HTMLElement | null>(null)\nconst dropdownStyle = ref({\n position: 'fixed' as const,\n top: '0px',\n left: '0px',\n width: '0px',\n zIndex: '9999',\n})\n\nconst autoId = `nb-select-${useId()}`\nconst inputId = computed(() => props.id ?? autoId)\n\nconst selectedValues = computed<Array<string | number>>(() => {\n if (props.modelValue == null) return []\n return Array.isArray(props.modelValue) ? props.modelValue : [props.modelValue]\n})\n\nconst displayValue = computed(() => {\n if (selectedValues.value.length === 0) return ''\n const opts = props.options ?? []\n if (props.multiple) {\n if (selectedValues.value.length === 1) {\n return (\n opts.find((o) => o.value === selectedValues.value[0])?.label ??\n String(selectedValues.value[0])\n )\n }\n if (selectedValues.value.length === 2) {\n return selectedValues.value\n .map((v) => opts.find((o) => o.value === v)?.label ?? String(v))\n .join(', ')\n }\n return `${selectedValues.value.length} selected`\n }\n return (\n opts.find((o) => o.value === selectedValues.value[0])?.label ??\n String(selectedValues.value[0])\n )\n})\n\nfunction isSelected(value: string | number) {\n return selectedValues.value.includes(value)\n}\n\nfunction selectOption(option: ISelectOption) {\n if (option.disabled) return\n let next: string | number | Array<string | number> | null\n if (props.multiple) {\n const arr = [...selectedValues.value]\n const idx = arr.indexOf(option.value)\n if (idx >= 0) arr.splice(idx, 1)\n else arr.push(option.value)\n next = arr\n } else {\n next = option.value\n closeDropdown()\n }\n emit('update:modelValue', next)\n emit('change', next)\n}\n\nfunction updateDropdownPosition() {\n if (!triggerRef.value) return\n const rect = triggerRef.value.getBoundingClientRect()\n dropdownStyle.value = {\n position: 'fixed',\n top: `${rect.bottom}px`,\n left: `${rect.left}px`,\n width: `${rect.width}px`,\n zIndex: '9999',\n }\n}\n\nfunction openDropdown() {\n if (props.disabled) return\n isOpen.value = true\n updateDropdownPosition()\n const opts = props.options ?? []\n highlighted.value =\n selectedValues.value.length > 0\n ? Math.max(\n 0,\n opts.findIndex((o) => o.value === selectedValues.value[0]),\n )\n : -1\n nextTick(scrollToHighlighted)\n}\n\nfunction closeDropdown() {\n isOpen.value = false\n highlighted.value = -1\n}\n\nfunction toggleDropdown() {\n if (isOpen.value) closeDropdown()\n else openDropdown()\n}\n\nfunction onClickOutside(e: MouseEvent) {\n const target = e.target as Node\n const inRoot = rootRef.value?.contains(target) ?? false\n const inDropdown = dropdownRef.value?.contains(target) ?? false\n if (!inRoot && !inDropdown) closeDropdown()\n}\n\nfunction onScrollOrResize() {\n if (isOpen.value) updateDropdownPosition()\n}\n\nwatch(isOpen, (val) => {\n if (val) {\n document.addEventListener('mousedown', onClickOutside)\n window.addEventListener('scroll', onScrollOrResize, true)\n window.addEventListener('resize', onScrollOrResize)\n } else {\n document.removeEventListener('mousedown', onClickOutside)\n window.removeEventListener('scroll', onScrollOrResize, true)\n window.removeEventListener('resize', onScrollOrResize)\n }\n})\n\nonBeforeUnmount(() => {\n document.removeEventListener('mousedown', onClickOutside)\n window.removeEventListener('scroll', onScrollOrResize, true)\n window.removeEventListener('resize', onScrollOrResize)\n})\n\nfunction onKeydown(e: KeyboardEvent) {\n const opts = props.options ?? []\n if (!isOpen.value) {\n if (e.key === 'Enter' || e.key === ' ' || e.key === 'ArrowDown') {\n e.preventDefault()\n openDropdown()\n }\n return\n }\n if (e.key === 'Escape') {\n closeDropdown()\n e.preventDefault()\n } else if (e.key === 'Tab') {\n closeDropdown()\n } else if (e.key === 'ArrowDown') {\n e.preventDefault()\n highlighted.value = Math.min(highlighted.value + 1, opts.length - 1)\n scrollToHighlighted()\n } else if (e.key === 'ArrowUp') {\n e.preventDefault()\n highlighted.value = Math.max(highlighted.value - 1, 0)\n scrollToHighlighted()\n } else if ((e.key === 'Enter' || e.key === ' ') && highlighted.value >= 0) {\n e.preventDefault()\n selectOption(opts[highlighted.value])\n }\n}\n\nfunction scrollToHighlighted() {\n nextTick(() => {\n if (!dropdownRef.value || highlighted.value < 0) return\n const item =\n dropdownRef.value.querySelectorAll<HTMLElement>('.nb-select__option')[\n highlighted.value\n ]\n item?.scrollIntoView({ block: 'nearest' })\n })\n}\n\nconst rootClasses = computed(() => [\n 'nb-select',\n `nb-select--${props.variant}`,\n `nb-select--${props.size}`,\n {\n 'nb-select--open': isOpen.value,\n 'nb-select--focused': focused.value && !isOpen.value,\n 'nb-select--error': !!props.error,\n 'nb-select--warning': !props.error && !!props.warning,\n 'nb-select--multiple': props.multiple,\n },\n])\n\ndefineExpose({\n open: openDropdown,\n close: closeDropdown,\n})\n</script>\n\n<style lang=\"scss\">\n// Dropdown is teleported to body: cannot use scoped styles\n.nb-select__dropdown {\n background: var(--nb-c-field-bg, var(--nb-c-french-gray-100, #f4f4f4));\n border: 1px solid\n var(--nb-c-field-border, var(--nb-c-french-gray-500, #a7a7a7));\n max-height: 240px;\n overflow-y: auto;\n overscroll-behavior: contain;\n box-sizing: border-box;\n box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);\n}\n\n.nb-select__option {\n display: flex;\n align-items: center;\n gap: 8px;\n padding: 10px 16px;\n font-size: 14px;\n font-weight: 400;\n color: var(--nb-c-text, #161616);\n cursor: pointer;\n position: relative;\n transition: background 0.1s;\n\n &::after {\n content: '';\n position: absolute;\n bottom: 0;\n left: 16px;\n right: 16px;\n height: 1px;\n background: var(--nb-c-component-plain-border);\n }\n\n &:last-child::after {\n display: none;\n }\n\n &--highlighted {\n background: color-mix(in srgb, var(--nb-c-primary) 8%, transparent);\n }\n\n &--selected {\n background: var(--nb-c-primary, #5856a9);\n color: var(--nb-c-surface);\n font-weight: 500;\n\n .nb-select__option-check {\n color: var(--nb-c-surface);\n }\n }\n\n &--selected.nb-select__option--highlighted {\n background: color-mix(in srgb, var(--nb-c-primary, #5856a9) 85%, black);\n }\n\n &--disabled {\n opacity: 0.45;\n cursor: not-allowed;\n }\n}\n\n.nb-select__option-check {\n width: 14px;\n flex-shrink: 0;\n color: var(--nb-c-primary, #5856a9);\n display: flex;\n align-items: center;\n}\n\n.nb-select__option-label {\n flex: 1;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n}\n\n.nb-select__empty {\n padding: 12px 16px;\n font-size: 14px;\n color: var(--nb-c-text-subtle, var(--nb-c-nouveau-gray-500, #6b7280));\n text-align: center;\n}\n\n.nb-select {\n position: relative;\n display: flex;\n flex-direction: column;\n gap: 6px;\n font-family: var(--nb-font-family-sans, sans-serif);\n --field-h: var(--nb-field-height-md);\n\n &--sm {\n --field-h: var(--nb-field-height-sm);\n }\n &--md {\n --field-h: var(--nb-field-height-md);\n }\n &--lg {\n --field-h: var(--nb-field-height-lg);\n }\n\n &__trigger {\n position: relative;\n display: flex;\n align-items: center;\n width: 100%;\n height: var(--field-h);\n padding: 0 var(--nb-field-padding-h);\n gap: 8px;\n background: var(--nb-c-field-bg);\n border: none;\n border-bottom: 1px solid var(--nb-c-field-border);\n border-radius: 0;\n cursor: pointer;\n user-select: none;\n font: inherit;\n text-align: left;\n appearance: none;\n transition:\n border-color 0.15s,\n box-shadow 0.15s,\n background 0.15s;\n outline: none;\n box-sizing: border-box;\n\n &:hover:not(:disabled) {\n background: color-mix(\n in srgb,\n var(--nb-c-field-border) 15%,\n var(--nb-c-field-bg)\n );\n border-bottom-color: color-mix(\n in srgb,\n var(--nb-c-primary) 50%,\n var(--nb-c-field-border)\n );\n }\n\n &:disabled {\n opacity: var(--nb-field-disabled-opacity);\n cursor: not-allowed;\n }\n }\n\n &--focused &__trigger {\n outline: 2px solid var(--nb-c-primary);\n outline-offset: -2px;\n }\n\n &--open &__trigger {\n outline: none;\n }\n\n &--error &__trigger {\n border: 1px solid var(--nb-c-danger);\n box-shadow: none;\n }\n\n &--warning &__trigger {\n border: 1px solid var(--nb-c-warning);\n box-shadow: none;\n }\n\n &__value {\n flex: 1;\n min-width: 0;\n font-size: var(--nb-c-field-font-size);\n font-weight: 400;\n line-height: 1.5;\n color: var(--nb-c-text);\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n\n &--placeholder {\n color: var(--nb-c-text-subtle);\n }\n }\n\n &__status-icon {\n flex-shrink: 0;\n .nb-message__tooltip {\n z-index: calc(var(--nb-zindex-tooltip, 401) + 1);\n }\n }\n\n &__caret {\n flex-shrink: 0;\n color: var(--nb-c-field-border);\n transition: color 0.15s;\n\n .nb-select--open & {\n color: var(--nb-c-primary);\n }\n .nb-select--error & {\n color: var(--nb-c-danger);\n }\n .nb-select--warning & {\n color: var(--nb-c-warning);\n }\n }\n\n &__message,\n &__fluid-message {\n font-size: var(--nb-font-size-12);\n }\n\n &--fluid {\n .nb-select__trigger {\n flex: 1;\n flex-direction: column;\n align-items: stretch;\n justify-content: space-between;\n height: auto;\n min-height: calc(var(--nb-base-unit) * 8);\n padding: calc(var(--nb-base-unit) * 1) 0 0;\n gap: 0;\n }\n\n .nb-select__inner-header {\n padding: 0 var(--nb-field-padding-h);\n margin-bottom: 4px;\n }\n\n .nb-select__inner-label {\n flex: 1;\n min-width: 0;\n font-size: var(--nb-font-size-12);\n font-weight: 500;\n color: var(--nb-c-text-muted);\n letter-spacing: 0.02em;\n cursor: default;\n user-select: none;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n\n .nb-select__asterisk {\n color: var(--nb-c-danger);\n }\n\n .nb-select__inner-message {\n flex-shrink: 0;\n }\n\n .nb-select__value-row {\n padding: 0 0 10px;\n }\n\n .nb-select__value {\n flex: 1;\n padding: 0 var(--nb-field-padding-h);\n font-size: var(--nb-font-size-14);\n }\n\n .nb-select__caret {\n position: static;\n width: auto;\n height: auto;\n padding: 0 var(--nb-field-padding-h);\n }\n }\n}\n</style>\n","<template>\n <div :class=\"rootClasses\">\n <!-- DEFAULT variant: label above -->\n <NbLabel v-if=\"variant === 'default' && label\" class=\"nb-slider__label\">{{\n label\n }}</NbLabel>\n\n <!-- Field box: display:contents in default (passthrough), styled in fluid -->\n <div class=\"nb-slider__field-box\">\n <!-- FLUID variant: label inside the box -->\n <div v-if=\"variant === 'fluid' && label\" class=\"nb-slider__inner-header\">\n <label class=\"nb-slider__inner-label\">{{ label }}</label>\n </div>\n\n <NbGrid dir=\"row\" align=\"center\" gap=\"sm\" class=\"nb-slider__row\">\n <!-- Range: low number input on the left -->\n <NbNumberInput\n v-if=\"range && showInput\"\n :size=\"variant === 'fluid' ? 'sm' : size\"\n :model-value=\"lowValue\"\n :min=\"min\"\n :max=\"highValue\"\n :step=\"step\"\n :disabled=\"disabled\"\n class=\"nb-slider__input\"\n @update:model-value=\"onLowInputChange\"\n @change=\"onLowInputChange\"\n />\n\n <!-- Track area -->\n <NbGrid\n dir=\"col\"\n justify=\"end\"\n gap=\"xs\"\n class=\"nb-slider__track-area\"\n :class=\"trackAreaClasses\"\n grow\n >\n <div\n ref=\"trackRef\"\n class=\"nb-slider__track\"\n @mousedown=\"onTrackMousedown\"\n @touchstart.passive=\"onTrackTouchstart\"\n >\n <!-- Filled segment -->\n <div class=\"nb-slider__track__fill\" :style=\"fillStyle\" />\n\n <!-- Single handle (circle) -->\n <div\n v-if=\"!range\"\n class=\"nb-slider__track__handle\"\n :style=\"{ left: `${valueToPercent(singleValue)}%` }\"\n @mousedown.stop=\"onHandleMousedown(null, $event)\"\n @touchstart.stop.passive=\"onHandleTouchstart(null, $event)\"\n />\n\n <!-- Range handles (triangles) -->\n <template v-else>\n <div\n class=\"nb-slider__track__handle nb-slider__track__handle--low\"\n :style=\"{ left: `${valueToPercent(lowValue)}%` }\"\n @mousedown.stop=\"onHandleMousedown('low', $event)\"\n @touchstart.stop.passive=\"onHandleTouchstart('low', $event)\"\n />\n <div\n class=\"nb-slider__track__handle nb-slider__track__handle--high\"\n :style=\"{ left: `${valueToPercent(highValue)}%` }\"\n @mousedown.stop=\"onHandleMousedown('high', $event)\"\n @touchstart.stop.passive=\"onHandleTouchstart('high', $event)\"\n />\n <div class=\"nb-slider__tick\" />\n </template>\n </div>\n\n <!-- Min / max labels below track -->\n <div class=\"nb-slider__track-labels\">\n <span class=\"nb-slider__track-label\">{{ min }}</span>\n <span class=\"nb-slider__track-label\">{{ max }}</span>\n </div>\n </NbGrid>\n\n <!-- Single slider: number input on the right -->\n <!-- Range: high number input on the right -->\n <NbNumberInput\n v-if=\"showInput\"\n :size=\"variant === 'fluid' ? 'sm' : size\"\n :model-value=\"range ? highValue : singleValue\"\n :min=\"range ? lowValue : min\"\n :max=\"max\"\n :step=\"step\"\n :disabled=\"disabled\"\n class=\"nb-slider__input\"\n @update:model-value=\"\n range ? onHighInputChange($event) : onSingleInputChange($event)\n \"\n @change=\"\n range ? onHighInputChange($event) : onSingleInputChange($event)\n \"\n />\n </NbGrid>\n </div>\n <!-- /__field-box -->\n\n <!-- Messages below -->\n <NbMessage v-if=\"error\" variant=\"error\" class=\"nb-slider__message\">{{\n error\n }}</NbMessage>\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n class=\"nb-slider__message\"\n >{{ warning }}</NbMessage\n >\n <NbMessage v-else-if=\"helper\" variant=\"helper\" class=\"nb-slider__message\">{{\n helper\n }}</NbMessage>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed, onBeforeUnmount, ref } from 'vue'\nimport { ESizeShort } from '@/types/Size.d'\nimport type { ISliderProps, TActiveHandle } from './Slider.d'\n\nconst props = withDefaults(defineProps<ISliderProps>(), {\n min: 0,\n max: 100,\n step: 1,\n range: false,\n disabled: false,\n showInput: true,\n size: ESizeShort.Medium,\n variant: 'default',\n})\n\nconst emit = defineEmits<{\n 'update:modelValue': [value: number | [number, number]]\n change: [value: number | [number, number]]\n}>()\n\nconst trackRef = ref<HTMLElement | null>(null)\n\nconst activeHandle = ref<TActiveHandle>(null)\n\n// Derived values\nconst singleValue = computed<number>(() => {\n if (\n props.range ||\n props.modelValue === null ||\n props.modelValue === undefined\n ) {\n return props.min ?? 0\n }\n if (Array.isArray(props.modelValue))\n return (props.modelValue[0] as number) ?? props.min ?? 0\n return props.modelValue as number\n})\n\nconst lowValue = computed<number>(() => {\n if (!props.range || !Array.isArray(props.modelValue)) return props.min ?? 0\n return (props.modelValue as [number, number])[0] ?? props.min ?? 0\n})\n\nconst highValue = computed<number>(() => {\n if (!props.range || !Array.isArray(props.modelValue)) return props.max ?? 100\n return (props.modelValue as [number, number])[1] ?? props.max ?? 100\n})\n\n// Track helpers\nfunction valueToPercent(v: number): number {\n const minV = props.min ?? 0\n const maxV = props.max ?? 100\n if (maxV === minV) return 0\n return ((v - minV) / (maxV - minV)) * 100\n}\n\nfunction percentToValue(pct: number): number {\n const minV = props.min ?? 0\n const maxV = props.max ?? 100\n const stepV = props.step ?? 1\n const raw = minV + (pct / 100) * (maxV - minV)\n const stepped = Math.round(raw / stepV) * stepV\n return Math.max(minV, Math.min(maxV, stepped))\n}\n\nfunction getPercentFromEvent(e: MouseEvent | TouchEvent): number {\n if (!trackRef.value) return 0\n const rect = trackRef.value.getBoundingClientRect()\n const clientX = 'touches' in e ? e.touches[0].clientX : e.clientX\n return Math.max(0, Math.min(100, ((clientX - rect.left) / rect.width) * 100))\n}\n\n// Fill style\nconst fillStyle = computed(() => {\n if (!props.range) {\n return { left: '0%', width: `${valueToPercent(singleValue.value)}%` }\n }\n const leftPct = valueToPercent(lowValue.value)\n const rightPct = valueToPercent(highValue.value)\n return { left: `${leftPct}%`, width: `${rightPct - leftPct}%` }\n})\n\n// Emit helpers\nfunction emitSingle(value: number) {\n emit('update:modelValue', value)\n}\n\nfunction emitRange(low: number, high: number) {\n emit('update:modelValue', [low, high])\n}\n\n// Input change handlers\nfunction onSingleInputChange(val: number | null) {\n if (val === null) return\n const minV = props.min ?? 0\n const maxV = props.max ?? 100\n emitSingle(Math.max(minV, Math.min(maxV, val)))\n}\n\nfunction onLowInputChange(val: number | null) {\n if (val === null) return\n const minV = props.min ?? 0\n const clamped = Math.max(minV, Math.min(highValue.value, val))\n emitRange(clamped, highValue.value)\n}\n\nfunction onHighInputChange(val: number | null) {\n if (val === null) return\n const maxV = props.max ?? 100\n const clamped = Math.max(lowValue.value, Math.min(maxV, val))\n emitRange(lowValue.value, clamped)\n}\n\n// Drag handling\nfunction resolveHandle(pct: number): TActiveHandle {\n if (!props.range) return null\n const lowPct = valueToPercent(lowValue.value)\n const highPct = valueToPercent(highValue.value)\n return Math.abs(pct - lowPct) <= Math.abs(pct - highPct) ? 'low' : 'high'\n}\n\nfunction applyDrag(pct: number) {\n const val = percentToValue(pct)\n if (!props.range) {\n emitSingle(val)\n return\n }\n if (activeHandle.value === 'low') {\n const clamped = Math.min(val, highValue.value)\n emitRange(clamped, highValue.value)\n } else {\n const clamped = Math.max(val, lowValue.value)\n emitRange(lowValue.value, clamped)\n }\n}\n\nfunction onMousemove(e: MouseEvent) {\n if (props.disabled) return\n applyDrag(getPercentFromEvent(e))\n}\n\nfunction onMouseup(e: MouseEvent) {\n if (!props.disabled) {\n const val = props.range\n ? ([lowValue.value, highValue.value] as [number, number])\n : singleValue.value\n emit('change', val)\n applyDrag(getPercentFromEvent(e))\n }\n stopDrag()\n}\n\nfunction onTouchmove(e: TouchEvent) {\n if (props.disabled) return\n applyDrag(getPercentFromEvent(e))\n}\n\nfunction onTouchend(e: TouchEvent) {\n if (!props.disabled) {\n const val = props.range\n ? ([lowValue.value, highValue.value] as [number, number])\n : singleValue.value\n emit('change', val)\n applyDrag(getPercentFromEvent(e))\n }\n stopTouchDrag()\n}\n\nfunction startDrag() {\n document.addEventListener('mousemove', onMousemove)\n document.addEventListener('mouseup', onMouseup)\n}\n\nfunction stopDrag() {\n activeHandle.value = null\n document.removeEventListener('mousemove', onMousemove)\n document.removeEventListener('mouseup', onMouseup)\n}\n\nfunction startTouchDrag() {\n document.addEventListener('touchmove', onTouchmove, { passive: true })\n document.addEventListener('touchend', onTouchend)\n}\n\nfunction stopTouchDrag() {\n activeHandle.value = null\n document.removeEventListener('touchmove', onTouchmove)\n document.removeEventListener('touchend', onTouchend)\n}\n\nfunction onTrackMousedown(e: MouseEvent) {\n if (props.disabled) return\n const pct = getPercentFromEvent(e)\n activeHandle.value = resolveHandle(pct)\n applyDrag(pct)\n startDrag()\n}\n\nfunction onTrackTouchstart(e: TouchEvent) {\n if (props.disabled) return\n const pct = getPercentFromEvent(e)\n activeHandle.value = resolveHandle(pct)\n applyDrag(pct)\n startTouchDrag()\n}\n\nfunction onHandleMousedown(handle: TActiveHandle, _e: MouseEvent) {\n if (props.disabled) return\n activeHandle.value = props.range ? handle : null\n startDrag()\n}\n\nfunction onHandleTouchstart(handle: TActiveHandle, _e: TouchEvent) {\n if (props.disabled) return\n activeHandle.value = props.range ? handle : null\n startTouchDrag()\n}\n\nonBeforeUnmount(() => {\n stopDrag()\n stopTouchDrag()\n})\n\n// CSS classes\nconst rootClasses = computed(() => [\n 'nb-slider',\n `nb-slider--${props.size}`,\n `nb-slider--${props.variant}`,\n {\n 'nb-slider--range': props.range,\n 'nb-slider--disabled': props.disabled,\n 'nb-slider--error': !!props.error,\n 'nb-slider--warning': !props.error && !!props.warning,\n },\n])\n\nconst trackAreaClasses = computed(() => ({\n 'nb-slider__track-area--error': !!props.error,\n 'nb-slider__track-area--warning': !props.error && !!props.warning,\n}))\n</script>\n\n<style scoped lang=\"scss\">\n.nb-slider {\n display: flex;\n flex-direction: column;\n flex: 1;\n gap: 6px;\n font-family: var(--nb-font-family-sans, sans-serif);\n\n &--disabled {\n opacity: var(--nb-field-disabled-opacity);\n pointer-events: none;\n }\n\n &__label {\n // label sits outside the row, handled by NbLabel default layout\n }\n\n // ── Field box: invisible passthrough in default, field container in fluid ──\n &__field-box {\n display: contents; // default: children participate directly in .nb-slider's flex\n }\n\n // ── Fluid variant ───────────────────────────────────────────────────────────\n &--fluid {\n gap: 4px;\n\n .nb-slider__field-box {\n display: flex;\n flex: 1;\n flex-direction: column;\n justify-content: space-between;\n background: var(--nb-c-field-bg);\n border-bottom: 1px solid var(--nb-c-field-border);\n padding-top: calc(var(--nb-base-unit) * 1);\n min-height: calc(var(--nb-base-unit) * 8);\n }\n\n .nb-slider__inner-header {\n display: flex;\n align-items: center;\n padding: 0 var(--nb-field-padding-h);\n margin-bottom: 4px;\n }\n\n .nb-slider__inner-label {\n flex: 1;\n min-width: 0;\n font-family: var(--nb-font-family-sans);\n font-size: var(--nb-font-size-12);\n font-weight: 500;\n color: var(--nb-c-text-muted);\n letter-spacing: 0.02em;\n cursor: default;\n user-select: none;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n\n .nb-slider__row {\n padding: 0 var(--nb-field-padding-h) 4px;\n }\n\n // Strip the inner NbNumberInput's own field-box appearance\n .nb-slider__input :deep(.nb-number-input__field-wrapper) {\n background: transparent;\n border-bottom: none;\n }\n }\n\n &__row {\n // layout owned by NbGrid (dir=\"row\", align=\"center\", gap=\"sm\")\n }\n\n &__input {\n flex: 0 0 auto;\n width: 160px;\n }\n\n // Track area: fills remaining space\n &__track-area {\n // flex: 1;\n min-width: 80px;\n // display: flex;\n // flex-direction: column;\n // justify-content: center;\n // gap: 3px;\n\n // Colored underline below track for error/warning\n &--error .nb-slider__track::after {\n content: '';\n position: absolute;\n bottom: -4px;\n left: 0;\n right: 0;\n height: 2px;\n background: var(--nb-c-danger);\n }\n\n &--warning .nb-slider__track::after {\n content: '';\n position: absolute;\n bottom: -4px;\n left: 0;\n right: 0;\n height: 2px;\n background: var(--nb-c-warning);\n }\n }\n\n // Track\n &__track {\n position: relative;\n height: 2px;\n background: var(--nb-c-field-border);\n cursor: pointer;\n margin: 5px 0;\n\n &__fill {\n position: absolute;\n height: 2px;\n background: var(--nb-c-text);\n top: 0;\n pointer-events: none;\n }\n\n &__handle {\n position: absolute;\n width: 14px;\n height: 14px;\n border-radius: 50%;\n background: var(--nb-c-text);\n top: 50%;\n transform: translate(-50%, -50%);\n cursor: grab;\n z-index: 1;\n\n &:active {\n cursor: grabbing;\n }\n\n &--low {\n border-radius: 0;\n clip-path: polygon(0 50%, 100% 0, 100% 100%);\n }\n\n &--high {\n border-radius: 0;\n clip-path: polygon(100% 50%, 0 0, 0 100%);\n }\n }\n }\n\n &__tick {\n position: absolute;\n left: 50%;\n top: 50%;\n transform: translate(-50%, -50%);\n width: 1px;\n height: 8px;\n background: var(--nb-c-field-border);\n pointer-events: none;\n }\n\n &__track-labels {\n display: flex;\n justify-content: space-between;\n }\n\n &__track-label {\n font-size: 11px;\n color: var(--nb-c-field-border);\n line-height: 1;\n user-select: none;\n }\n\n &__message {\n font-size: 11px;\n }\n}\n</style>\n","<template>\n <div :class=\"rootClasses\">\n <!-- DEFAULT variant: label above -->\n <NbLabel v-if=\"variant === 'default' && label\" class=\"nb-slider__label\">{{\n label\n }}</NbLabel>\n\n <!-- Field box: display:contents in default (passthrough), styled in fluid -->\n <div class=\"nb-slider__field-box\">\n <!-- FLUID variant: label inside the box -->\n <div v-if=\"variant === 'fluid' && label\" class=\"nb-slider__inner-header\">\n <label class=\"nb-slider__inner-label\">{{ label }}</label>\n </div>\n\n <NbGrid dir=\"row\" align=\"center\" gap=\"sm\" class=\"nb-slider__row\">\n <!-- Range: low number input on the left -->\n <NbNumberInput\n v-if=\"range && showInput\"\n :size=\"variant === 'fluid' ? 'sm' : size\"\n :model-value=\"lowValue\"\n :min=\"min\"\n :max=\"highValue\"\n :step=\"step\"\n :disabled=\"disabled\"\n class=\"nb-slider__input\"\n @update:model-value=\"onLowInputChange\"\n @change=\"onLowInputChange\"\n />\n\n <!-- Track area -->\n <NbGrid\n dir=\"col\"\n justify=\"end\"\n gap=\"xs\"\n class=\"nb-slider__track-area\"\n :class=\"trackAreaClasses\"\n grow\n >\n <div\n ref=\"trackRef\"\n class=\"nb-slider__track\"\n @mousedown=\"onTrackMousedown\"\n @touchstart.passive=\"onTrackTouchstart\"\n >\n <!-- Filled segment -->\n <div class=\"nb-slider__track__fill\" :style=\"fillStyle\" />\n\n <!-- Single handle (circle) -->\n <div\n v-if=\"!range\"\n class=\"nb-slider__track__handle\"\n :style=\"{ left: `${valueToPercent(singleValue)}%` }\"\n @mousedown.stop=\"onHandleMousedown(null, $event)\"\n @touchstart.stop.passive=\"onHandleTouchstart(null, $event)\"\n />\n\n <!-- Range handles (triangles) -->\n <template v-else>\n <div\n class=\"nb-slider__track__handle nb-slider__track__handle--low\"\n :style=\"{ left: `${valueToPercent(lowValue)}%` }\"\n @mousedown.stop=\"onHandleMousedown('low', $event)\"\n @touchstart.stop.passive=\"onHandleTouchstart('low', $event)\"\n />\n <div\n class=\"nb-slider__track__handle nb-slider__track__handle--high\"\n :style=\"{ left: `${valueToPercent(highValue)}%` }\"\n @mousedown.stop=\"onHandleMousedown('high', $event)\"\n @touchstart.stop.passive=\"onHandleTouchstart('high', $event)\"\n />\n <div class=\"nb-slider__tick\" />\n </template>\n </div>\n\n <!-- Min / max labels below track -->\n <div class=\"nb-slider__track-labels\">\n <span class=\"nb-slider__track-label\">{{ min }}</span>\n <span class=\"nb-slider__track-label\">{{ max }}</span>\n </div>\n </NbGrid>\n\n <!-- Single slider: number input on the right -->\n <!-- Range: high number input on the right -->\n <NbNumberInput\n v-if=\"showInput\"\n :size=\"variant === 'fluid' ? 'sm' : size\"\n :model-value=\"range ? highValue : singleValue\"\n :min=\"range ? lowValue : min\"\n :max=\"max\"\n :step=\"step\"\n :disabled=\"disabled\"\n class=\"nb-slider__input\"\n @update:model-value=\"\n range ? onHighInputChange($event) : onSingleInputChange($event)\n \"\n @change=\"\n range ? onHighInputChange($event) : onSingleInputChange($event)\n \"\n />\n </NbGrid>\n </div>\n <!-- /__field-box -->\n\n <!-- Messages below -->\n <NbMessage v-if=\"error\" variant=\"error\" class=\"nb-slider__message\">{{\n error\n }}</NbMessage>\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n class=\"nb-slider__message\"\n >{{ warning }}</NbMessage\n >\n <NbMessage v-else-if=\"helper\" variant=\"helper\" class=\"nb-slider__message\">{{\n helper\n }}</NbMessage>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed, onBeforeUnmount, ref } from 'vue'\nimport { ESizeShort } from '@/types/Size.d'\nimport type { ISliderProps, TActiveHandle } from './Slider.d'\n\nconst props = withDefaults(defineProps<ISliderProps>(), {\n min: 0,\n max: 100,\n step: 1,\n range: false,\n disabled: false,\n showInput: true,\n size: ESizeShort.Medium,\n variant: 'default',\n})\n\nconst emit = defineEmits<{\n 'update:modelValue': [value: number | [number, number]]\n change: [value: number | [number, number]]\n}>()\n\nconst trackRef = ref<HTMLElement | null>(null)\n\nconst activeHandle = ref<TActiveHandle>(null)\n\n// Derived values\nconst singleValue = computed<number>(() => {\n if (\n props.range ||\n props.modelValue === null ||\n props.modelValue === undefined\n ) {\n return props.min ?? 0\n }\n if (Array.isArray(props.modelValue))\n return (props.modelValue[0] as number) ?? props.min ?? 0\n return props.modelValue as number\n})\n\nconst lowValue = computed<number>(() => {\n if (!props.range || !Array.isArray(props.modelValue)) return props.min ?? 0\n return (props.modelValue as [number, number])[0] ?? props.min ?? 0\n})\n\nconst highValue = computed<number>(() => {\n if (!props.range || !Array.isArray(props.modelValue)) return props.max ?? 100\n return (props.modelValue as [number, number])[1] ?? props.max ?? 100\n})\n\n// Track helpers\nfunction valueToPercent(v: number): number {\n const minV = props.min ?? 0\n const maxV = props.max ?? 100\n if (maxV === minV) return 0\n return ((v - minV) / (maxV - minV)) * 100\n}\n\nfunction percentToValue(pct: number): number {\n const minV = props.min ?? 0\n const maxV = props.max ?? 100\n const stepV = props.step ?? 1\n const raw = minV + (pct / 100) * (maxV - minV)\n const stepped = Math.round(raw / stepV) * stepV\n return Math.max(minV, Math.min(maxV, stepped))\n}\n\nfunction getPercentFromEvent(e: MouseEvent | TouchEvent): number {\n if (!trackRef.value) return 0\n const rect = trackRef.value.getBoundingClientRect()\n const clientX = 'touches' in e ? e.touches[0].clientX : e.clientX\n return Math.max(0, Math.min(100, ((clientX - rect.left) / rect.width) * 100))\n}\n\n// Fill style\nconst fillStyle = computed(() => {\n if (!props.range) {\n return { left: '0%', width: `${valueToPercent(singleValue.value)}%` }\n }\n const leftPct = valueToPercent(lowValue.value)\n const rightPct = valueToPercent(highValue.value)\n return { left: `${leftPct}%`, width: `${rightPct - leftPct}%` }\n})\n\n// Emit helpers\nfunction emitSingle(value: number) {\n emit('update:modelValue', value)\n}\n\nfunction emitRange(low: number, high: number) {\n emit('update:modelValue', [low, high])\n}\n\n// Input change handlers\nfunction onSingleInputChange(val: number | null) {\n if (val === null) return\n const minV = props.min ?? 0\n const maxV = props.max ?? 100\n emitSingle(Math.max(minV, Math.min(maxV, val)))\n}\n\nfunction onLowInputChange(val: number | null) {\n if (val === null) return\n const minV = props.min ?? 0\n const clamped = Math.max(minV, Math.min(highValue.value, val))\n emitRange(clamped, highValue.value)\n}\n\nfunction onHighInputChange(val: number | null) {\n if (val === null) return\n const maxV = props.max ?? 100\n const clamped = Math.max(lowValue.value, Math.min(maxV, val))\n emitRange(lowValue.value, clamped)\n}\n\n// Drag handling\nfunction resolveHandle(pct: number): TActiveHandle {\n if (!props.range) return null\n const lowPct = valueToPercent(lowValue.value)\n const highPct = valueToPercent(highValue.value)\n return Math.abs(pct - lowPct) <= Math.abs(pct - highPct) ? 'low' : 'high'\n}\n\nfunction applyDrag(pct: number) {\n const val = percentToValue(pct)\n if (!props.range) {\n emitSingle(val)\n return\n }\n if (activeHandle.value === 'low') {\n const clamped = Math.min(val, highValue.value)\n emitRange(clamped, highValue.value)\n } else {\n const clamped = Math.max(val, lowValue.value)\n emitRange(lowValue.value, clamped)\n }\n}\n\nfunction onMousemove(e: MouseEvent) {\n if (props.disabled) return\n applyDrag(getPercentFromEvent(e))\n}\n\nfunction onMouseup(e: MouseEvent) {\n if (!props.disabled) {\n const val = props.range\n ? ([lowValue.value, highValue.value] as [number, number])\n : singleValue.value\n emit('change', val)\n applyDrag(getPercentFromEvent(e))\n }\n stopDrag()\n}\n\nfunction onTouchmove(e: TouchEvent) {\n if (props.disabled) return\n applyDrag(getPercentFromEvent(e))\n}\n\nfunction onTouchend(e: TouchEvent) {\n if (!props.disabled) {\n const val = props.range\n ? ([lowValue.value, highValue.value] as [number, number])\n : singleValue.value\n emit('change', val)\n applyDrag(getPercentFromEvent(e))\n }\n stopTouchDrag()\n}\n\nfunction startDrag() {\n document.addEventListener('mousemove', onMousemove)\n document.addEventListener('mouseup', onMouseup)\n}\n\nfunction stopDrag() {\n activeHandle.value = null\n document.removeEventListener('mousemove', onMousemove)\n document.removeEventListener('mouseup', onMouseup)\n}\n\nfunction startTouchDrag() {\n document.addEventListener('touchmove', onTouchmove, { passive: true })\n document.addEventListener('touchend', onTouchend)\n}\n\nfunction stopTouchDrag() {\n activeHandle.value = null\n document.removeEventListener('touchmove', onTouchmove)\n document.removeEventListener('touchend', onTouchend)\n}\n\nfunction onTrackMousedown(e: MouseEvent) {\n if (props.disabled) return\n const pct = getPercentFromEvent(e)\n activeHandle.value = resolveHandle(pct)\n applyDrag(pct)\n startDrag()\n}\n\nfunction onTrackTouchstart(e: TouchEvent) {\n if (props.disabled) return\n const pct = getPercentFromEvent(e)\n activeHandle.value = resolveHandle(pct)\n applyDrag(pct)\n startTouchDrag()\n}\n\nfunction onHandleMousedown(handle: TActiveHandle, _e: MouseEvent) {\n if (props.disabled) return\n activeHandle.value = props.range ? handle : null\n startDrag()\n}\n\nfunction onHandleTouchstart(handle: TActiveHandle, _e: TouchEvent) {\n if (props.disabled) return\n activeHandle.value = props.range ? handle : null\n startTouchDrag()\n}\n\nonBeforeUnmount(() => {\n stopDrag()\n stopTouchDrag()\n})\n\n// CSS classes\nconst rootClasses = computed(() => [\n 'nb-slider',\n `nb-slider--${props.size}`,\n `nb-slider--${props.variant}`,\n {\n 'nb-slider--range': props.range,\n 'nb-slider--disabled': props.disabled,\n 'nb-slider--error': !!props.error,\n 'nb-slider--warning': !props.error && !!props.warning,\n },\n])\n\nconst trackAreaClasses = computed(() => ({\n 'nb-slider__track-area--error': !!props.error,\n 'nb-slider__track-area--warning': !props.error && !!props.warning,\n}))\n</script>\n\n<style scoped lang=\"scss\">\n.nb-slider {\n display: flex;\n flex-direction: column;\n flex: 1;\n gap: 6px;\n font-family: var(--nb-font-family-sans, sans-serif);\n\n &--disabled {\n opacity: var(--nb-field-disabled-opacity);\n pointer-events: none;\n }\n\n &__label {\n // label sits outside the row, handled by NbLabel default layout\n }\n\n // ── Field box: invisible passthrough in default, field container in fluid ──\n &__field-box {\n display: contents; // default: children participate directly in .nb-slider's flex\n }\n\n // ── Fluid variant ───────────────────────────────────────────────────────────\n &--fluid {\n gap: 4px;\n\n .nb-slider__field-box {\n display: flex;\n flex: 1;\n flex-direction: column;\n justify-content: space-between;\n background: var(--nb-c-field-bg);\n border-bottom: 1px solid var(--nb-c-field-border);\n padding-top: calc(var(--nb-base-unit) * 1);\n min-height: calc(var(--nb-base-unit) * 8);\n }\n\n .nb-slider__inner-header {\n display: flex;\n align-items: center;\n padding: 0 var(--nb-field-padding-h);\n margin-bottom: 4px;\n }\n\n .nb-slider__inner-label {\n flex: 1;\n min-width: 0;\n font-family: var(--nb-font-family-sans);\n font-size: var(--nb-font-size-12);\n font-weight: 500;\n color: var(--nb-c-text-muted);\n letter-spacing: 0.02em;\n cursor: default;\n user-select: none;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n\n .nb-slider__row {\n padding: 0 var(--nb-field-padding-h) 4px;\n }\n\n // Strip the inner NbNumberInput's own field-box appearance\n .nb-slider__input :deep(.nb-number-input__field-wrapper) {\n background: transparent;\n border-bottom: none;\n }\n }\n\n &__row {\n // layout owned by NbGrid (dir=\"row\", align=\"center\", gap=\"sm\")\n }\n\n &__input {\n flex: 0 0 auto;\n width: 160px;\n }\n\n // Track area: fills remaining space\n &__track-area {\n // flex: 1;\n min-width: 80px;\n // display: flex;\n // flex-direction: column;\n // justify-content: center;\n // gap: 3px;\n\n // Colored underline below track for error/warning\n &--error .nb-slider__track::after {\n content: '';\n position: absolute;\n bottom: -4px;\n left: 0;\n right: 0;\n height: 2px;\n background: var(--nb-c-danger);\n }\n\n &--warning .nb-slider__track::after {\n content: '';\n position: absolute;\n bottom: -4px;\n left: 0;\n right: 0;\n height: 2px;\n background: var(--nb-c-warning);\n }\n }\n\n // Track\n &__track {\n position: relative;\n height: 2px;\n background: var(--nb-c-field-border);\n cursor: pointer;\n margin: 5px 0;\n\n &__fill {\n position: absolute;\n height: 2px;\n background: var(--nb-c-text);\n top: 0;\n pointer-events: none;\n }\n\n &__handle {\n position: absolute;\n width: 14px;\n height: 14px;\n border-radius: 50%;\n background: var(--nb-c-text);\n top: 50%;\n transform: translate(-50%, -50%);\n cursor: grab;\n z-index: 1;\n\n &:active {\n cursor: grabbing;\n }\n\n &--low {\n border-radius: 0;\n clip-path: polygon(0 50%, 100% 0, 100% 100%);\n }\n\n &--high {\n border-radius: 0;\n clip-path: polygon(100% 50%, 0 0, 0 100%);\n }\n }\n }\n\n &__tick {\n position: absolute;\n left: 50%;\n top: 50%;\n transform: translate(-50%, -50%);\n width: 1px;\n height: 8px;\n background: var(--nb-c-field-border);\n pointer-events: none;\n }\n\n &__track-labels {\n display: flex;\n justify-content: space-between;\n }\n\n &__track-label {\n font-size: 11px;\n color: var(--nb-c-field-border);\n line-height: 1;\n user-select: none;\n }\n\n &__message {\n font-size: 11px;\n }\n}\n</style>\n","import { IHumanInputComponent, IWithLabel } from '@/types/Props.d'\n\nenum ESwitchSize {\n Small = 'sm',\n Medium = 'md',\n Large = 'lg',\n}\n\nenum ESwitchVariant {\n Primary = 'primary',\n Secondary = 'secondary',\n}\n\ninterface ISwitchProps extends IHumanInputComponent, IWithLabel {\n modelValue?: boolean\n variant?: ESwitchVariant\n size?: ESwitchSize\n}\n\nexport { ESwitchSize, ESwitchVariant, ISwitchProps }\n","<template>\n <NbGrid :id=\"componentInternalId\" :class=\"classes\" align=\"center\" gap=\"sm\">\n <span v-if=\"label\" class=\"nb-switch-label\">\n {{ label }}\n </span>\n <label\n :for=\"`${componentInternalId}-input`\"\n :class=\"wrapperClasses\"\n v-bind=\"attributes\"\n @click.stop\n >\n <input\n :id=\"`${componentInternalId}-input`\"\n v-model=\"model\"\n :name=\"name\"\n type=\"checkbox\"\n :disabled=\"disabled\"\n />\n <div class=\"slider round\" />\n </label>\n </NbGrid>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed } from 'vue'\nimport type { PropType } from 'vue'\nimport { ESwitchSize, ESwitchVariant } from './Switch.d'\nimport { useStableId } from '@/composables/useStableId.composable'\n\nconst model = defineModel<boolean>()\n\nconst props = defineProps({\n id: {\n type: String,\n default: () => null,\n },\n label: {\n type: String,\n default: '',\n },\n size: {\n type: String as PropType<ESwitchSize>,\n default: ESwitchSize.Medium,\n validator: (value: ESwitchSize) =>\n Object.values(ESwitchSize).includes(value),\n },\n verbose: Boolean,\n name: {\n type: String,\n required: true,\n },\n disabled: Boolean,\n variant: {\n type: String as PropType<ESwitchVariant>,\n default: ESwitchVariant.Primary,\n validator: (value: ESwitchVariant) =>\n Object.values(ESwitchVariant).includes(value),\n },\n})\n\nconst componentInternalId = useStableId(props)\n\nconst attributes = computed(() => ({\n 'aria-disabled': props.disabled,\n}))\n\nconst classes = computed(() => ({\n 'nb-switch': true,\n disabled: props.disabled,\n}))\n\nconst wrapperClasses = computed(() => ({\n 'nb-switch-wrapper': true,\n verbose: props.verbose,\n [props.size]: true,\n [`nb-${props.variant}`]: true,\n}))\n</script>\n\n<style lang=\"scss\" scoped>\n.nb-switch {\n &-wrapper {\n position: relative;\n display: inline-block;\n width: calc(var(--nb-base-unit) * 4);\n height: calc(var(--nb-base-unit) * 2);\n cursor: pointer;\n .slider {\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n background-color: var(--nb-c-component-inactive);\n transition: 0.3s;\n border-radius: calc(var(--nb-base-unit) * 4);\n &:before {\n position: absolute;\n content: '';\n height: calc(var(--nb-base-unit) * 1);\n width: calc(var(--nb-base-unit) * 1);\n left: calc(var(--nb-base-unit) / 2);\n bottom: calc(var(--nb-base-unit) / 2);\n background-color: var(--nb-c-white);\n border-radius: 50%;\n transition: transform 0.3s;\n }\n }\n &[aria-disabled='true'] {\n * {\n cursor: not-allowed;\n }\n input + .slider {\n background-color: var(--nb-c-component-disabled);\n }\n }\n input {\n display: none;\n &:checked + .slider {\n &:before {\n -webkit-transform: translateX(calc(var(--nb-base-unit) * 2));\n -ms-transform: translateX(calc(var(--nb-base-unit) * 2));\n transform: translateX(calc(var(--nb-base-unit) * 2));\n }\n }\n &:focus + .slider {\n box-shadow: 0 0 1px var(--nb-c-component-active);\n }\n }\n &:not([aria-disabled='true']) {\n input {\n + .slider {\n background-color: var(--nb-c-component-inactive);\n }\n &:checked + .slider {\n background-color: var(--nb-c-primary);\n }\n }\n\n &.nb-secondary input:checked + .slider {\n background-color: var(--nb-c-success);\n }\n }\n &.verbose {\n &.sm {\n width: calc(var(--nb-base-unit) * 5.5);\n height: calc(var(--nb-base-unit) * 2);\n .slider {\n &:before {\n height: calc(var(--nb-base-unit) * 1);\n width: calc(var(--nb-base-unit) * 1);\n left: calc(var(--nb-base-unit) / 2);\n bottom: calc(var(--nb-base-unit) / 2);\n border-radius: calc(var(--nb-base-unit) * 4);\n }\n &:after {\n content: 'OFF';\n position: absolute;\n top: calc(var(--nb-base-unit) / 2);\n right: calc(var(--nb-base-unit) - 2px);\n font-weight: var(--nb-font-weight-bold);\n font-size: var(--nb-font-size-10);\n letter-spacing: 0.4px;\n color: var(--nb-c-white);\n line-height: calc(var(--nb-base-unit) * 1);\n }\n }\n input {\n &:checked + .slider {\n &:before {\n -webkit-transform: translateX(calc(var(--nb-base-unit) * 3.4));\n -ms-transform: translateX(calc(var(--nb-base-unit) * 3.4));\n transform: translateX(calc(var(--nb-base-unit) * 3.4));\n }\n &:after {\n content: 'ON';\n left: calc(var(--nb-base-unit) - 2px);\n }\n }\n }\n }\n &.md {\n width: calc(var(--nb-base-unit) * 8);\n height: calc(var(--nb-base-unit) * 3);\n .slider {\n &:before {\n height: calc(var(--nb-base-unit) * 1.5);\n width: calc(var(--nb-base-unit) * 1.5);\n left: var(--nb-base-unit);\n bottom: calc(var(--nb-base-unit) / 1.3);\n border-radius: calc(var(--nb-base-unit) * 8);\n }\n &:after {\n content: 'OFF';\n position: absolute;\n top: calc(var(--nb-base-unit) / 2);\n right: calc(var(--nb-base-unit) * 1);\n font-weight: var(--nb-font-weight-bold);\n font-size: var(--nb-font-size-12);\n color: var(--nb-c-white);\n line-height: calc(var(--nb-base-unit) * 2);\n }\n }\n input {\n &:checked + .slider {\n &:before {\n -webkit-transform: translateX(calc(var(--nb-base-unit) * 4));\n -ms-transform: translateX(calc(var(--nb-base-unit) * 4));\n transform: translateX(calc(var(--nb-base-unit) * 4));\n }\n &:after {\n content: 'ON';\n left: calc(var(--nb-base-unit) * 1);\n }\n }\n }\n }\n &.lg {\n width: calc(var(--nb-base-unit) * 8);\n height: calc(var(--nb-base-unit) * 4);\n .slider {\n &:before {\n height: calc(var(--nb-base-unit) * 2);\n width: calc(var(--nb-base-unit) * 2);\n left: var(--nb-base-unit);\n bottom: var(--nb-base-unit);\n border-radius: calc(var(--nb-base-unit) * 8);\n }\n &:after {\n content: 'OFF';\n position: absolute;\n top: calc(var(--nb-base-unit) / 2);\n right: calc(var(--nb-base-unit) * 1);\n font-weight: var(--nb-font-weight-bold);\n font-size: var(--nb-font-size-12);\n color: var(--nb-c-white);\n line-height: calc(var(--nb-base-unit) * 3);\n }\n }\n input {\n &:checked + .slider {\n &:before {\n -webkit-transform: translateX(calc(var(--nb-base-unit) * 4));\n -ms-transform: translateX(calc(var(--nb-base-unit) * 4));\n transform: translateX(calc(var(--nb-base-unit) * 4));\n }\n &:after {\n content: 'ON';\n left: calc(var(--nb-base-unit) * 1);\n }\n }\n }\n }\n }\n }\n *-label {\n font-size: var(--nb-font-size-14);\n }\n}\n</style>\n","<template>\n <NbGrid :id=\"componentInternalId\" :class=\"classes\" align=\"center\" gap=\"sm\">\n <span v-if=\"label\" class=\"nb-switch-label\">\n {{ label }}\n </span>\n <label\n :for=\"`${componentInternalId}-input`\"\n :class=\"wrapperClasses\"\n v-bind=\"attributes\"\n @click.stop\n >\n <input\n :id=\"`${componentInternalId}-input`\"\n v-model=\"model\"\n :name=\"name\"\n type=\"checkbox\"\n :disabled=\"disabled\"\n />\n <div class=\"slider round\" />\n </label>\n </NbGrid>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed } from 'vue'\nimport type { PropType } from 'vue'\nimport { ESwitchSize, ESwitchVariant } from './Switch.d'\nimport { useStableId } from '@/composables/useStableId.composable'\n\nconst model = defineModel<boolean>()\n\nconst props = defineProps({\n id: {\n type: String,\n default: () => null,\n },\n label: {\n type: String,\n default: '',\n },\n size: {\n type: String as PropType<ESwitchSize>,\n default: ESwitchSize.Medium,\n validator: (value: ESwitchSize) =>\n Object.values(ESwitchSize).includes(value),\n },\n verbose: Boolean,\n name: {\n type: String,\n required: true,\n },\n disabled: Boolean,\n variant: {\n type: String as PropType<ESwitchVariant>,\n default: ESwitchVariant.Primary,\n validator: (value: ESwitchVariant) =>\n Object.values(ESwitchVariant).includes(value),\n },\n})\n\nconst componentInternalId = useStableId(props)\n\nconst attributes = computed(() => ({\n 'aria-disabled': props.disabled,\n}))\n\nconst classes = computed(() => ({\n 'nb-switch': true,\n disabled: props.disabled,\n}))\n\nconst wrapperClasses = computed(() => ({\n 'nb-switch-wrapper': true,\n verbose: props.verbose,\n [props.size]: true,\n [`nb-${props.variant}`]: true,\n}))\n</script>\n\n<style lang=\"scss\" scoped>\n.nb-switch {\n &-wrapper {\n position: relative;\n display: inline-block;\n width: calc(var(--nb-base-unit) * 4);\n height: calc(var(--nb-base-unit) * 2);\n cursor: pointer;\n .slider {\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n background-color: var(--nb-c-component-inactive);\n transition: 0.3s;\n border-radius: calc(var(--nb-base-unit) * 4);\n &:before {\n position: absolute;\n content: '';\n height: calc(var(--nb-base-unit) * 1);\n width: calc(var(--nb-base-unit) * 1);\n left: calc(var(--nb-base-unit) / 2);\n bottom: calc(var(--nb-base-unit) / 2);\n background-color: var(--nb-c-white);\n border-radius: 50%;\n transition: transform 0.3s;\n }\n }\n &[aria-disabled='true'] {\n * {\n cursor: not-allowed;\n }\n input + .slider {\n background-color: var(--nb-c-component-disabled);\n }\n }\n input {\n display: none;\n &:checked + .slider {\n &:before {\n -webkit-transform: translateX(calc(var(--nb-base-unit) * 2));\n -ms-transform: translateX(calc(var(--nb-base-unit) * 2));\n transform: translateX(calc(var(--nb-base-unit) * 2));\n }\n }\n &:focus + .slider {\n box-shadow: 0 0 1px var(--nb-c-component-active);\n }\n }\n &:not([aria-disabled='true']) {\n input {\n + .slider {\n background-color: var(--nb-c-component-inactive);\n }\n &:checked + .slider {\n background-color: var(--nb-c-primary);\n }\n }\n\n &.nb-secondary input:checked + .slider {\n background-color: var(--nb-c-success);\n }\n }\n &.verbose {\n &.sm {\n width: calc(var(--nb-base-unit) * 5.5);\n height: calc(var(--nb-base-unit) * 2);\n .slider {\n &:before {\n height: calc(var(--nb-base-unit) * 1);\n width: calc(var(--nb-base-unit) * 1);\n left: calc(var(--nb-base-unit) / 2);\n bottom: calc(var(--nb-base-unit) / 2);\n border-radius: calc(var(--nb-base-unit) * 4);\n }\n &:after {\n content: 'OFF';\n position: absolute;\n top: calc(var(--nb-base-unit) / 2);\n right: calc(var(--nb-base-unit) - 2px);\n font-weight: var(--nb-font-weight-bold);\n font-size: var(--nb-font-size-10);\n letter-spacing: 0.4px;\n color: var(--nb-c-white);\n line-height: calc(var(--nb-base-unit) * 1);\n }\n }\n input {\n &:checked + .slider {\n &:before {\n -webkit-transform: translateX(calc(var(--nb-base-unit) * 3.4));\n -ms-transform: translateX(calc(var(--nb-base-unit) * 3.4));\n transform: translateX(calc(var(--nb-base-unit) * 3.4));\n }\n &:after {\n content: 'ON';\n left: calc(var(--nb-base-unit) - 2px);\n }\n }\n }\n }\n &.md {\n width: calc(var(--nb-base-unit) * 8);\n height: calc(var(--nb-base-unit) * 3);\n .slider {\n &:before {\n height: calc(var(--nb-base-unit) * 1.5);\n width: calc(var(--nb-base-unit) * 1.5);\n left: var(--nb-base-unit);\n bottom: calc(var(--nb-base-unit) / 1.3);\n border-radius: calc(var(--nb-base-unit) * 8);\n }\n &:after {\n content: 'OFF';\n position: absolute;\n top: calc(var(--nb-base-unit) / 2);\n right: calc(var(--nb-base-unit) * 1);\n font-weight: var(--nb-font-weight-bold);\n font-size: var(--nb-font-size-12);\n color: var(--nb-c-white);\n line-height: calc(var(--nb-base-unit) * 2);\n }\n }\n input {\n &:checked + .slider {\n &:before {\n -webkit-transform: translateX(calc(var(--nb-base-unit) * 4));\n -ms-transform: translateX(calc(var(--nb-base-unit) * 4));\n transform: translateX(calc(var(--nb-base-unit) * 4));\n }\n &:after {\n content: 'ON';\n left: calc(var(--nb-base-unit) * 1);\n }\n }\n }\n }\n &.lg {\n width: calc(var(--nb-base-unit) * 8);\n height: calc(var(--nb-base-unit) * 4);\n .slider {\n &:before {\n height: calc(var(--nb-base-unit) * 2);\n width: calc(var(--nb-base-unit) * 2);\n left: var(--nb-base-unit);\n bottom: var(--nb-base-unit);\n border-radius: calc(var(--nb-base-unit) * 8);\n }\n &:after {\n content: 'OFF';\n position: absolute;\n top: calc(var(--nb-base-unit) / 2);\n right: calc(var(--nb-base-unit) * 1);\n font-weight: var(--nb-font-weight-bold);\n font-size: var(--nb-font-size-12);\n color: var(--nb-c-white);\n line-height: calc(var(--nb-base-unit) * 3);\n }\n }\n input {\n &:checked + .slider {\n &:before {\n -webkit-transform: translateX(calc(var(--nb-base-unit) * 4));\n -ms-transform: translateX(calc(var(--nb-base-unit) * 4));\n transform: translateX(calc(var(--nb-base-unit) * 4));\n }\n &:after {\n content: 'ON';\n left: calc(var(--nb-base-unit) * 1);\n }\n }\n }\n }\n }\n }\n *-label {\n font-size: var(--nb-font-size-14);\n }\n}\n</style>\n","<template>\n <NbGrid\n dir=\"col\"\n gap=\"xs\"\n :class=\"[\n 'nb-text-input',\n `nb-text-input--${variant}`,\n `nb-text-input--${size}`,\n { 'nb-text-input--multiline': multiline },\n ]\"\n >\n <!-- ── DEFAULT variant ───────────────────────────────────── -->\n <template v-if=\"variant === 'default'\">\n <!-- Label row: either a custom #label slot or the built-in NbLabel -->\n <slot v-if=\"$slots.label\" name=\"label\" />\n <NbLabel\n v-else-if=\"label\"\n :for=\"inputId\"\n :required=\"required\"\n :disabled=\"disabled\"\n >\n {{ label }}\n </NbLabel>\n\n <div class=\"nb-text-input__field-wrapper\" :class=\"wrapperClasses\">\n <slot name=\"leading\" />\n\n <!-- ░░ OVERLAY MODE (highlight function provided) ░░░░░░░░ -->\n <!-- CSS Grid overlap: mirror and transparent field share the same grid cell,\n guaranteeing identical bounding boxes and pixel-perfect caret alignment. -->\n <div v-if=\"useOverlay\" class=\"nb-text-input__overlay-wrap\">\n <!-- eslint-disable-next-line vue/no-v-html -->\n <div\n ref=\"mirrorRef\"\n class=\"nb-text-input__mirror\"\n aria-hidden=\"true\"\n v-html=\"mirrorHtml\"\n />\n\n <textarea\n v-if=\"multiline\"\n :id=\"inputId\"\n ref=\"nativeRef\"\n v-bind=\"$attrs\"\n class=\"nb-text-input__field--transparent\"\n :value=\"model\"\n :placeholder=\"placeholder\"\n :disabled=\"disabled\"\n :readonly=\"readonly\"\n :name=\"name\"\n :maxlength=\"maxlength\"\n spellcheck=\"false\"\n autocomplete=\"off\"\n autocorrect=\"off\"\n @input=\"model = ($event.target as HTMLTextAreaElement).value\"\n @focus=\"focused = true\"\n @blur=\"focused = false\"\n @scroll=\"syncScroll\"\n />\n <input\n v-else\n :id=\"inputId\"\n ref=\"nativeRef\"\n v-bind=\"$attrs\"\n type=\"text\"\n class=\"nb-text-input__field--transparent\"\n :value=\"model\"\n :placeholder=\"placeholder\"\n :disabled=\"disabled\"\n :readonly=\"readonly\"\n :name=\"name\"\n :maxlength=\"maxlength\"\n spellcheck=\"false\"\n @input=\"model = ($event.target as HTMLInputElement).value\"\n @focus=\"focused = true\"\n @blur=\"focused = false\"\n />\n </div>\n\n <!-- ░░ NORMAL MODE ░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░ -->\n <template v-else>\n <textarea\n v-if=\"multiline\"\n :id=\"inputId\"\n ref=\"nativeRef\"\n v-bind=\"$attrs\"\n v-model=\"model\"\n class=\"nb-text-input__field\"\n :placeholder=\"placeholder\"\n :disabled=\"disabled\"\n :readonly=\"readonly\"\n :name=\"name\"\n :maxlength=\"maxlength\"\n :rows=\"rows\"\n @focus=\"focused = true\"\n @blur=\"focused = false\"\n />\n <input\n v-else\n :id=\"inputId\"\n ref=\"nativeRef\"\n v-bind=\"$attrs\"\n v-model=\"model\"\n class=\"nb-text-input__field\"\n :type=\"type\"\n :placeholder=\"placeholder\"\n :disabled=\"disabled\"\n :readonly=\"readonly\"\n :required=\"required\"\n :name=\"name\"\n :min=\"min\"\n :max=\"max\"\n :step=\"step\"\n :maxlength=\"maxlength\"\n @focus=\"focused = true\"\n @blur=\"focused = false\"\n />\n </template>\n\n <slot name=\"trailing\" />\n\n <!-- Actions: buttons rendered inside the field at the trailing edge\n (AI suggest, password toggle, clear, etc.) -->\n <div v-if=\"$slots.actions\" class=\"nb-text-input__actions\">\n <slot name=\"actions\" />\n </div>\n </div>\n\n <NbMessage\n v-if=\"hasMessage\"\n :variant=\"messageVariant\"\n class=\"nb-text-input__message\"\n >\n {{ messageText }}\n </NbMessage>\n\n <!-- Dropdowns / popovers anchored to the component root -->\n <slot name=\"dropdown\" />\n </template>\n\n <!-- ── FLUID variant ─────────────────────────────────────── -->\n <template v-else-if=\"variant === 'fluid'\">\n <div class=\"nb-text-input__field-wrapper\" :class=\"wrapperClasses\">\n <div v-if=\"label || $slots.label\" class=\"nb-text-input__inner-header\">\n <slot v-if=\"$slots.label\" name=\"label\" />\n <label\n v-else\n :for=\"inputId\"\n class=\"nb-text-input__inner-label\"\n :class=\"{ 'nb-text-input__inner-label--required': required }\"\n >\n {{ label }}\n <span\n v-if=\"required\"\n class=\"nb-text-input__asterisk\"\n aria-hidden=\"true\"\n >*</span\n >\n </label>\n <NbMessage\n v-if=\"hasMessage\"\n :variant=\"messageVariant\"\n icon-only\n class=\"nb-text-input__inner-message\"\n >\n {{ messageText }}\n </NbMessage>\n </div>\n\n <input\n :id=\"inputId\"\n ref=\"nativeRef\"\n v-bind=\"$attrs\"\n v-model=\"model\"\n class=\"nb-text-input__field\"\n :type=\"type\"\n :placeholder=\"placeholder\"\n :disabled=\"disabled\"\n :readonly=\"readonly\"\n :required=\"required\"\n :name=\"name\"\n :min=\"min\"\n :max=\"max\"\n :step=\"step\"\n :maxlength=\"maxlength\"\n @focus=\"focused = true\"\n @blur=\"focused = false\"\n />\n </div>\n </template>\n </NbGrid>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed, nextTick, ref, useId, watch } from 'vue'\nimport type { IReadableFieldComponent } from '@/types/Props.d'\nimport NbLabel from './Label.vue'\nimport NbMessage from './Message.vue'\n\n// Ensure $attrs (class, style, event listeners, native attrs) flow to the native element\ndefineOptions({ inheritAttrs: false })\n\nexport interface ITextInputProps extends IReadableFieldComponent {\n /** Native input type forwarded to the `<input>` element. */\n type?: string\n min?: string | number\n max?: string | number\n step?: string | number\n maxlength?: number\n /** Render a <textarea> instead of <input> */\n multiline?: boolean\n /** Initial row count (multiline only, without highlight) */\n rows?: number\n /**\n * Syntax-highlight function. Receives the raw text value, must return an HTML string.\n * When provided, an overlay mirror is rendered below the (transparent) input/textarea\n * so the highlights show through. The highlight span styles must be supplied by the consumer.\n *\n * @example\n * :highlight=\"(t) => t.replace(/(\\{[^}]+\\})/g, '<span class=\\\"hl-var\\\">$1</span>')\"\n */\n highlight?: (text: string) => string\n}\n\nconst props = withDefaults(defineProps<ITextInputProps>(), {\n variant: 'default',\n size: 'md',\n type: 'text',\n label: '',\n placeholder: '',\n helper: '',\n error: '',\n warning: '',\n disabled: false,\n readonly: false,\n required: false,\n id: undefined,\n name: '',\n min: undefined,\n max: undefined,\n step: undefined,\n maxlength: undefined,\n multiline: false,\n rows: 3,\n highlight: undefined,\n})\n\nconst model = defineModel<string>({ default: '' })\n\nconst nativeRef = ref<HTMLInputElement | HTMLTextAreaElement | null>(null)\nconst mirrorRef = ref<HTMLDivElement | null>(null)\n\n// Expose the native element so consumers (e.g. TranslationEditor) can access\n// selectionStart, setSelectionRange, focus, blur, etc.\ndefineExpose({\n focus: () => nativeRef.value?.focus(),\n blur: () => nativeRef.value?.blur(),\n nativeEl: nativeRef,\n})\n\nconst focused = ref(false)\n\n// Stable generated ID per instance\nconst autoId = `nb-input-${useId()}`\nconst inputId = computed(() => props.id ?? autoId)\n\n// Overlay mode: active when a highlight function is provided\nconst useOverlay = computed(() => !!props.highlight)\n\n// The mirror div HTML: trailing newline prevents the container collapsing on the last line\nconst mirrorHtml = computed(() => {\n if (!props.highlight) return ''\n const text = String(model.value ?? '')\n const highlighted = props.highlight(text)\n return highlighted + '\\n'\n})\n\n// Keep mirror scroll in sync with the textarea scroll\nfunction syncScroll() {\n if (mirrorRef.value && nativeRef.value) {\n mirrorRef.value.scrollTop = nativeRef.value.scrollTop\n }\n}\n\nwatch(mirrorHtml, () => nextTick(syncScroll))\n\nconst messageVariant = computed(() => {\n if (props.error) return 'error'\n if (props.warning) return 'warning'\n return 'helper'\n})\n\nconst messageText = computed(\n () => props.error ?? props.warning ?? props.helper ?? '',\n)\nconst hasMessage = computed(() => !!messageText.value)\n\nconst wrapperClasses = computed(() => ({\n 'nb-text-input__field-wrapper--focused': focused.value,\n 'nb-text-input__field-wrapper--error': !!props.error,\n 'nb-text-input__field-wrapper--warning': !props.error && !!props.warning,\n 'nb-text-input__field-wrapper--disabled': props.disabled,\n 'nb-text-input__field-wrapper--readonly': props.readonly,\n 'nb-text-input__field-wrapper--overlay': useOverlay.value,\n 'nb-text-input__field-wrapper--multiline': props.multiline,\n}))\n</script>\n\n<style scoped lang=\"scss\">\n.nb-text-input {\n font-family: var(--nb-font-family-sans);\n --field-h: var(--nb-field-height-md);\n\n &--sm {\n --field-h: var(--nb-field-height-sm);\n }\n &--md {\n --field-h: var(--nb-field-height-md);\n }\n &--lg {\n --field-h: var(--nb-field-height-lg);\n }\n\n // ─── Field wrapper ────────────────────────────────────────\n &__field-wrapper {\n position: relative;\n display: flex;\n align-items: center;\n background: var(--nb-c-field-bg);\n // Always 1px border: never changes width, so no layout shift on focus\n border-bottom: 1px solid var(--nb-c-field-border);\n transition:\n border-color 0.15s,\n box-shadow 0.15s;\n\n &--focused {\n outline: 2px solid var(--nb-c-primary);\n outline-offset: -2px;\n }\n\n &--error {\n border-bottom-color: var(--nb-c-danger);\n box-shadow: inset 0 -1px 0 0 var(--nb-c-danger);\n }\n\n &--warning {\n border-bottom-color: var(--nb-c-warning);\n box-shadow: inset 0 -1px 0 0 var(--nb-c-warning);\n }\n\n &--disabled {\n opacity: var(--nb-field-disabled-opacity);\n cursor: not-allowed;\n }\n\n &--readonly {\n background: transparent;\n }\n\n &--multiline {\n align-items: stretch;\n }\n }\n\n // ─── Native input / textarea (normal mode) ────────────────\n &__field {\n flex: 1;\n min-width: 0;\n height: var(--field-h);\n padding: 0 var(--nb-field-padding-h);\n background: transparent;\n border: none;\n outline: none;\n font-family: inherit;\n font-size: var(--nb-field-font-size);\n font-weight: 400;\n color: var(--nb-c-text);\n line-height: var(--nb-field-line-height);\n\n &::placeholder {\n color: var(--nb-c-text-subtle);\n }\n &:disabled {\n cursor: not-allowed;\n }\n &:read-only {\n cursor: default;\n }\n }\n\n // ─── Overlay wrap: CSS Grid overlap ─────────────────────\n // Mirror and transparent input share the SAME grid cell, which guarantees\n // identical bounding boxes, padding, and line-height → caret aligns perfectly.\n &__overlay-wrap {\n flex: 1;\n min-width: 0;\n display: grid;\n }\n\n &__mirror,\n &__field--transparent {\n grid-area: 1 / 1; // overlap in the same grid cell\n font-family: inherit;\n font-size: var(--nb-field-font-size);\n font-weight: 400;\n line-height: var(--nb-field-line-height);\n word-break: break-word;\n overflow-wrap: break-word;\n }\n\n &__mirror {\n color: var(--nb-c-text);\n pointer-events: none;\n user-select: none;\n overflow: hidden;\n }\n\n &__field--transparent {\n background: transparent;\n color: transparent;\n caret-color: var(--nb-c-text);\n border: none;\n outline: none;\n resize: none;\n overflow: hidden;\n z-index: 1; // caret must sit above mirror\n width: 100%; // fill grid cell\n }\n\n // Single-line overlay: fixed height, text centred via line-height trick\n &:not(.nb-text-input--multiline) {\n .nb-text-input__mirror,\n .nb-text-input__field--transparent {\n height: var(--field-h);\n padding: 0 var(--nb-field-padding-h);\n // line-height = height centres single-line text identically in mirror and input\n line-height: var(--field-h);\n white-space: pre;\n overflow: hidden;\n }\n }\n\n // Multiline overlay + non-overlay textarea\n &--multiline {\n .nb-text-input__field-wrapper {\n align-items: stretch;\n }\n\n // Overlay: padding top/bottom, height driven by mirror content\n .nb-text-input__mirror,\n .nb-text-input__field--transparent {\n padding: 8px var(--nb-field-padding-h);\n white-space: pre-wrap;\n min-height: 80px;\n overflow-y: auto;\n }\n\n // Normal (non-overlay) textarea\n .nb-text-input__field {\n height: auto;\n min-height: 80px;\n padding: 8px var(--nb-field-padding-h);\n resize: vertical;\n overflow: auto;\n }\n }\n\n // Buttons rendered inside the field at the trailing edge (AI suggest, eye, clear…)\n &__actions {\n display: flex;\n align-items: center;\n padding: 0 8px;\n gap: 4px;\n flex-shrink: 0;\n z-index: 2; // above the transparent overlay input\n }\n\n // ─── Bottom message ───────────────────────────────────────\n &__message {\n font-size: var(--nb-font-size-12);\n }\n\n // ─── DEFAULT variant ──────────────────────────────────────\n &--default {\n position: relative; // anchor for #dropdown slot\n }\n\n // ─── FLUID variant ────────────────────────────────────────\n &--fluid {\n .nb-text-input__field-wrapper {\n box-sizing: border-box;\n flex: 1;\n flex-direction: column;\n align-items: stretch;\n justify-content: space-between;\n min-height: calc(var(--nb-base-unit) * 8);\n padding-top: 8px;\n }\n\n .nb-text-input__inner-header {\n display: flex;\n align-items: center;\n gap: 4px;\n padding: 0 var(--nb-field-padding-h);\n margin-bottom: 4px;\n }\n\n .nb-text-input__inner-label {\n display: flex;\n align-items: center;\n gap: 4px;\n flex: 1;\n min-width: 0;\n font-size: var(--nb-font-size-12);\n font-weight: 500;\n color: var(--nb-c-text-muted);\n letter-spacing: 0.02em;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n cursor: default;\n user-select: none;\n }\n\n .nb-text-input__asterisk {\n color: var(--nb-c-danger);\n }\n\n .nb-text-input__field {\n height: auto;\n flex: 1;\n padding: 0 var(--nb-field-padding-h) 10px;\n font-size: var(--nb-font-size-14);\n }\n }\n}\n</style>\n","<template>\n <NbGrid\n dir=\"col\"\n gap=\"xs\"\n :class=\"[\n 'nb-text-input',\n `nb-text-input--${variant}`,\n `nb-text-input--${size}`,\n { 'nb-text-input--multiline': multiline },\n ]\"\n >\n <!-- ── DEFAULT variant ───────────────────────────────────── -->\n <template v-if=\"variant === 'default'\">\n <!-- Label row: either a custom #label slot or the built-in NbLabel -->\n <slot v-if=\"$slots.label\" name=\"label\" />\n <NbLabel\n v-else-if=\"label\"\n :for=\"inputId\"\n :required=\"required\"\n :disabled=\"disabled\"\n >\n {{ label }}\n </NbLabel>\n\n <div class=\"nb-text-input__field-wrapper\" :class=\"wrapperClasses\">\n <slot name=\"leading\" />\n\n <!-- ░░ OVERLAY MODE (highlight function provided) ░░░░░░░░ -->\n <!-- CSS Grid overlap: mirror and transparent field share the same grid cell,\n guaranteeing identical bounding boxes and pixel-perfect caret alignment. -->\n <div v-if=\"useOverlay\" class=\"nb-text-input__overlay-wrap\">\n <!-- eslint-disable-next-line vue/no-v-html -->\n <div\n ref=\"mirrorRef\"\n class=\"nb-text-input__mirror\"\n aria-hidden=\"true\"\n v-html=\"mirrorHtml\"\n />\n\n <textarea\n v-if=\"multiline\"\n :id=\"inputId\"\n ref=\"nativeRef\"\n v-bind=\"$attrs\"\n class=\"nb-text-input__field--transparent\"\n :value=\"model\"\n :placeholder=\"placeholder\"\n :disabled=\"disabled\"\n :readonly=\"readonly\"\n :name=\"name\"\n :maxlength=\"maxlength\"\n spellcheck=\"false\"\n autocomplete=\"off\"\n autocorrect=\"off\"\n @input=\"model = ($event.target as HTMLTextAreaElement).value\"\n @focus=\"focused = true\"\n @blur=\"focused = false\"\n @scroll=\"syncScroll\"\n />\n <input\n v-else\n :id=\"inputId\"\n ref=\"nativeRef\"\n v-bind=\"$attrs\"\n type=\"text\"\n class=\"nb-text-input__field--transparent\"\n :value=\"model\"\n :placeholder=\"placeholder\"\n :disabled=\"disabled\"\n :readonly=\"readonly\"\n :name=\"name\"\n :maxlength=\"maxlength\"\n spellcheck=\"false\"\n @input=\"model = ($event.target as HTMLInputElement).value\"\n @focus=\"focused = true\"\n @blur=\"focused = false\"\n />\n </div>\n\n <!-- ░░ NORMAL MODE ░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░ -->\n <template v-else>\n <textarea\n v-if=\"multiline\"\n :id=\"inputId\"\n ref=\"nativeRef\"\n v-bind=\"$attrs\"\n v-model=\"model\"\n class=\"nb-text-input__field\"\n :placeholder=\"placeholder\"\n :disabled=\"disabled\"\n :readonly=\"readonly\"\n :name=\"name\"\n :maxlength=\"maxlength\"\n :rows=\"rows\"\n @focus=\"focused = true\"\n @blur=\"focused = false\"\n />\n <input\n v-else\n :id=\"inputId\"\n ref=\"nativeRef\"\n v-bind=\"$attrs\"\n v-model=\"model\"\n class=\"nb-text-input__field\"\n :type=\"type\"\n :placeholder=\"placeholder\"\n :disabled=\"disabled\"\n :readonly=\"readonly\"\n :required=\"required\"\n :name=\"name\"\n :min=\"min\"\n :max=\"max\"\n :step=\"step\"\n :maxlength=\"maxlength\"\n @focus=\"focused = true\"\n @blur=\"focused = false\"\n />\n </template>\n\n <slot name=\"trailing\" />\n\n <!-- Actions: buttons rendered inside the field at the trailing edge\n (AI suggest, password toggle, clear, etc.) -->\n <div v-if=\"$slots.actions\" class=\"nb-text-input__actions\">\n <slot name=\"actions\" />\n </div>\n </div>\n\n <NbMessage\n v-if=\"hasMessage\"\n :variant=\"messageVariant\"\n class=\"nb-text-input__message\"\n >\n {{ messageText }}\n </NbMessage>\n\n <!-- Dropdowns / popovers anchored to the component root -->\n <slot name=\"dropdown\" />\n </template>\n\n <!-- ── FLUID variant ─────────────────────────────────────── -->\n <template v-else-if=\"variant === 'fluid'\">\n <div class=\"nb-text-input__field-wrapper\" :class=\"wrapperClasses\">\n <div v-if=\"label || $slots.label\" class=\"nb-text-input__inner-header\">\n <slot v-if=\"$slots.label\" name=\"label\" />\n <label\n v-else\n :for=\"inputId\"\n class=\"nb-text-input__inner-label\"\n :class=\"{ 'nb-text-input__inner-label--required': required }\"\n >\n {{ label }}\n <span\n v-if=\"required\"\n class=\"nb-text-input__asterisk\"\n aria-hidden=\"true\"\n >*</span\n >\n </label>\n <NbMessage\n v-if=\"hasMessage\"\n :variant=\"messageVariant\"\n icon-only\n class=\"nb-text-input__inner-message\"\n >\n {{ messageText }}\n </NbMessage>\n </div>\n\n <input\n :id=\"inputId\"\n ref=\"nativeRef\"\n v-bind=\"$attrs\"\n v-model=\"model\"\n class=\"nb-text-input__field\"\n :type=\"type\"\n :placeholder=\"placeholder\"\n :disabled=\"disabled\"\n :readonly=\"readonly\"\n :required=\"required\"\n :name=\"name\"\n :min=\"min\"\n :max=\"max\"\n :step=\"step\"\n :maxlength=\"maxlength\"\n @focus=\"focused = true\"\n @blur=\"focused = false\"\n />\n </div>\n </template>\n </NbGrid>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed, nextTick, ref, useId, watch } from 'vue'\nimport type { IReadableFieldComponent } from '@/types/Props.d'\nimport NbLabel from './Label.vue'\nimport NbMessage from './Message.vue'\n\n// Ensure $attrs (class, style, event listeners, native attrs) flow to the native element\ndefineOptions({ inheritAttrs: false })\n\nexport interface ITextInputProps extends IReadableFieldComponent {\n /** Native input type forwarded to the `<input>` element. */\n type?: string\n min?: string | number\n max?: string | number\n step?: string | number\n maxlength?: number\n /** Render a <textarea> instead of <input> */\n multiline?: boolean\n /** Initial row count (multiline only, without highlight) */\n rows?: number\n /**\n * Syntax-highlight function. Receives the raw text value, must return an HTML string.\n * When provided, an overlay mirror is rendered below the (transparent) input/textarea\n * so the highlights show through. The highlight span styles must be supplied by the consumer.\n *\n * @example\n * :highlight=\"(t) => t.replace(/(\\{[^}]+\\})/g, '<span class=\\\"hl-var\\\">$1</span>')\"\n */\n highlight?: (text: string) => string\n}\n\nconst props = withDefaults(defineProps<ITextInputProps>(), {\n variant: 'default',\n size: 'md',\n type: 'text',\n label: '',\n placeholder: '',\n helper: '',\n error: '',\n warning: '',\n disabled: false,\n readonly: false,\n required: false,\n id: undefined,\n name: '',\n min: undefined,\n max: undefined,\n step: undefined,\n maxlength: undefined,\n multiline: false,\n rows: 3,\n highlight: undefined,\n})\n\nconst model = defineModel<string>({ default: '' })\n\nconst nativeRef = ref<HTMLInputElement | HTMLTextAreaElement | null>(null)\nconst mirrorRef = ref<HTMLDivElement | null>(null)\n\n// Expose the native element so consumers (e.g. TranslationEditor) can access\n// selectionStart, setSelectionRange, focus, blur, etc.\ndefineExpose({\n focus: () => nativeRef.value?.focus(),\n blur: () => nativeRef.value?.blur(),\n nativeEl: nativeRef,\n})\n\nconst focused = ref(false)\n\n// Stable generated ID per instance\nconst autoId = `nb-input-${useId()}`\nconst inputId = computed(() => props.id ?? autoId)\n\n// Overlay mode: active when a highlight function is provided\nconst useOverlay = computed(() => !!props.highlight)\n\n// The mirror div HTML: trailing newline prevents the container collapsing on the last line\nconst mirrorHtml = computed(() => {\n if (!props.highlight) return ''\n const text = String(model.value ?? '')\n const highlighted = props.highlight(text)\n return highlighted + '\\n'\n})\n\n// Keep mirror scroll in sync with the textarea scroll\nfunction syncScroll() {\n if (mirrorRef.value && nativeRef.value) {\n mirrorRef.value.scrollTop = nativeRef.value.scrollTop\n }\n}\n\nwatch(mirrorHtml, () => nextTick(syncScroll))\n\nconst messageVariant = computed(() => {\n if (props.error) return 'error'\n if (props.warning) return 'warning'\n return 'helper'\n})\n\nconst messageText = computed(\n () => props.error ?? props.warning ?? props.helper ?? '',\n)\nconst hasMessage = computed(() => !!messageText.value)\n\nconst wrapperClasses = computed(() => ({\n 'nb-text-input__field-wrapper--focused': focused.value,\n 'nb-text-input__field-wrapper--error': !!props.error,\n 'nb-text-input__field-wrapper--warning': !props.error && !!props.warning,\n 'nb-text-input__field-wrapper--disabled': props.disabled,\n 'nb-text-input__field-wrapper--readonly': props.readonly,\n 'nb-text-input__field-wrapper--overlay': useOverlay.value,\n 'nb-text-input__field-wrapper--multiline': props.multiline,\n}))\n</script>\n\n<style scoped lang=\"scss\">\n.nb-text-input {\n font-family: var(--nb-font-family-sans);\n --field-h: var(--nb-field-height-md);\n\n &--sm {\n --field-h: var(--nb-field-height-sm);\n }\n &--md {\n --field-h: var(--nb-field-height-md);\n }\n &--lg {\n --field-h: var(--nb-field-height-lg);\n }\n\n // ─── Field wrapper ────────────────────────────────────────\n &__field-wrapper {\n position: relative;\n display: flex;\n align-items: center;\n background: var(--nb-c-field-bg);\n // Always 1px border: never changes width, so no layout shift on focus\n border-bottom: 1px solid var(--nb-c-field-border);\n transition:\n border-color 0.15s,\n box-shadow 0.15s;\n\n &--focused {\n outline: 2px solid var(--nb-c-primary);\n outline-offset: -2px;\n }\n\n &--error {\n border-bottom-color: var(--nb-c-danger);\n box-shadow: inset 0 -1px 0 0 var(--nb-c-danger);\n }\n\n &--warning {\n border-bottom-color: var(--nb-c-warning);\n box-shadow: inset 0 -1px 0 0 var(--nb-c-warning);\n }\n\n &--disabled {\n opacity: var(--nb-field-disabled-opacity);\n cursor: not-allowed;\n }\n\n &--readonly {\n background: transparent;\n }\n\n &--multiline {\n align-items: stretch;\n }\n }\n\n // ─── Native input / textarea (normal mode) ────────────────\n &__field {\n flex: 1;\n min-width: 0;\n height: var(--field-h);\n padding: 0 var(--nb-field-padding-h);\n background: transparent;\n border: none;\n outline: none;\n font-family: inherit;\n font-size: var(--nb-field-font-size);\n font-weight: 400;\n color: var(--nb-c-text);\n line-height: var(--nb-field-line-height);\n\n &::placeholder {\n color: var(--nb-c-text-subtle);\n }\n &:disabled {\n cursor: not-allowed;\n }\n &:read-only {\n cursor: default;\n }\n }\n\n // ─── Overlay wrap: CSS Grid overlap ─────────────────────\n // Mirror and transparent input share the SAME grid cell, which guarantees\n // identical bounding boxes, padding, and line-height → caret aligns perfectly.\n &__overlay-wrap {\n flex: 1;\n min-width: 0;\n display: grid;\n }\n\n &__mirror,\n &__field--transparent {\n grid-area: 1 / 1; // overlap in the same grid cell\n font-family: inherit;\n font-size: var(--nb-field-font-size);\n font-weight: 400;\n line-height: var(--nb-field-line-height);\n word-break: break-word;\n overflow-wrap: break-word;\n }\n\n &__mirror {\n color: var(--nb-c-text);\n pointer-events: none;\n user-select: none;\n overflow: hidden;\n }\n\n &__field--transparent {\n background: transparent;\n color: transparent;\n caret-color: var(--nb-c-text);\n border: none;\n outline: none;\n resize: none;\n overflow: hidden;\n z-index: 1; // caret must sit above mirror\n width: 100%; // fill grid cell\n }\n\n // Single-line overlay: fixed height, text centred via line-height trick\n &:not(.nb-text-input--multiline) {\n .nb-text-input__mirror,\n .nb-text-input__field--transparent {\n height: var(--field-h);\n padding: 0 var(--nb-field-padding-h);\n // line-height = height centres single-line text identically in mirror and input\n line-height: var(--field-h);\n white-space: pre;\n overflow: hidden;\n }\n }\n\n // Multiline overlay + non-overlay textarea\n &--multiline {\n .nb-text-input__field-wrapper {\n align-items: stretch;\n }\n\n // Overlay: padding top/bottom, height driven by mirror content\n .nb-text-input__mirror,\n .nb-text-input__field--transparent {\n padding: 8px var(--nb-field-padding-h);\n white-space: pre-wrap;\n min-height: 80px;\n overflow-y: auto;\n }\n\n // Normal (non-overlay) textarea\n .nb-text-input__field {\n height: auto;\n min-height: 80px;\n padding: 8px var(--nb-field-padding-h);\n resize: vertical;\n overflow: auto;\n }\n }\n\n // Buttons rendered inside the field at the trailing edge (AI suggest, eye, clear…)\n &__actions {\n display: flex;\n align-items: center;\n padding: 0 8px;\n gap: 4px;\n flex-shrink: 0;\n z-index: 2; // above the transparent overlay input\n }\n\n // ─── Bottom message ───────────────────────────────────────\n &__message {\n font-size: var(--nb-font-size-12);\n }\n\n // ─── DEFAULT variant ──────────────────────────────────────\n &--default {\n position: relative; // anchor for #dropdown slot\n }\n\n // ─── FLUID variant ────────────────────────────────────────\n &--fluid {\n .nb-text-input__field-wrapper {\n box-sizing: border-box;\n flex: 1;\n flex-direction: column;\n align-items: stretch;\n justify-content: space-between;\n min-height: calc(var(--nb-base-unit) * 8);\n padding-top: 8px;\n }\n\n .nb-text-input__inner-header {\n display: flex;\n align-items: center;\n gap: 4px;\n padding: 0 var(--nb-field-padding-h);\n margin-bottom: 4px;\n }\n\n .nb-text-input__inner-label {\n display: flex;\n align-items: center;\n gap: 4px;\n flex: 1;\n min-width: 0;\n font-size: var(--nb-font-size-12);\n font-weight: 500;\n color: var(--nb-c-text-muted);\n letter-spacing: 0.02em;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n cursor: default;\n user-select: none;\n }\n\n .nb-text-input__asterisk {\n color: var(--nb-c-danger);\n }\n\n .nb-text-input__field {\n height: auto;\n flex: 1;\n padding: 0 var(--nb-field-padding-h) 10px;\n font-size: var(--nb-font-size-14);\n }\n }\n}\n</style>\n","<script setup lang=\"ts\">\nimport { ref, onMounted, onUnmounted, watch } from 'vue'\nimport NbIcon from './Icon.vue'\n\nexport type TToastVariant = 'success' | 'error' | 'warning' | 'info'\n\nexport interface IToastCta {\n label: string\n action: () => void\n}\n\nconst props = withDefaults(\n defineProps<{\n variant?: TToastVariant\n title?: string\n message: string\n duration?: number\n cta?: IToastCta\n }>(),\n {\n variant: 'info',\n title: undefined,\n duration: 4000,\n cta: undefined,\n },\n)\n\nconst emit = defineEmits<{ close: [] }>()\n\nconst paused = ref(false)\n\nconst iconMap: Record<TToastVariant, string> = {\n success: 'check-circle',\n error: 'warning-circle',\n warning: 'warning',\n info: 'info',\n}\n\nlet timer: ReturnType<typeof setTimeout> | null = null\nlet remaining = props.duration ?? 0\nlet startedAt = 0\n\nfunction startTimer() {\n if (!remaining) return\n startedAt = Date.now()\n timer = setTimeout(() => emit('close'), remaining)\n}\n\nfunction pauseProgress() {\n if (!remaining || paused.value) return\n paused.value = true\n if (timer) clearTimeout(timer)\n remaining -= Date.now() - startedAt\n}\n\nfunction resumeProgress() {\n if (!remaining || !paused.value) return\n paused.value = false\n startTimer()\n}\n\nonMounted(startTimer)\nonUnmounted(() => {\n if (timer) clearTimeout(timer)\n})\n\nwatch(\n () => props.duration,\n (val) => {\n if (timer) clearTimeout(timer)\n remaining = val ?? 0\n startTimer()\n },\n)\n</script>\n\n<template>\n <div\n :class=\"['nb-toast', `nb-toast--${variant}`]\"\n role=\"alert\"\n :aria-live=\"variant === 'error' ? 'assertive' : 'polite'\"\n @mouseenter=\"pauseProgress\"\n @mouseleave=\"resumeProgress\"\n >\n <div class=\"nb-toast__icon\">\n <NbIcon :name=\"iconMap[variant!]\" :size=\"16\" />\n </div>\n <div class=\"nb-toast__body\">\n <p v-if=\"title\" class=\"nb-toast__title\">{{ title }}</p>\n <p class=\"nb-toast__message\">{{ message }}</p>\n <button\n v-if=\"cta\"\n class=\"nb-toast__cta\"\n @click=\"\n () => {\n cta && cta.action()\n emit('close')\n }\n \"\n >\n {{ cta.label }}\n </button>\n </div>\n <button class=\"nb-toast__close\" aria-label=\"Close\" @click=\"emit('close')\">\n <NbIcon name=\"x\" :size=\"14\" />\n </button>\n <div\n v-if=\"duration\"\n ref=\"progressRef\"\n class=\"nb-toast__progress\"\n :style=\"{\n animationDuration: `${duration}ms`,\n animationPlayState: paused ? 'paused' : 'running',\n }\"\n />\n </div>\n</template>\n\n<style scoped lang=\"scss\">\n.nb-toast {\n position: relative;\n display: flex;\n align-items: flex-start;\n gap: 10px;\n padding: 12px 14px;\n background: var(--nb-c-bg, #fff);\n border: 1px solid var(--nb-c-border, #e5e7eb);\n border-radius: 10px;\n box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);\n min-width: 280px;\n max-width: 380px;\n overflow: hidden;\n font-family: var(--nb-font-family-sans, sans-serif);\n\n &--success .nb-toast__icon {\n color: var(--nb-c-success, #4acf7b);\n }\n &--error .nb-toast__icon {\n color: var(--nb-c-danger, #dc2626);\n }\n &--warning .nb-toast__icon {\n color: var(--nb-c-warning, #d97706);\n }\n &--info .nb-toast__icon {\n color: var(--nb-c-primary, #5856a9);\n }\n\n &--success {\n border-left: 3px solid var(--nb-c-success, #4acf7b);\n }\n &--error {\n border-left: 3px solid var(--nb-c-danger, #dc2626);\n }\n &--warning {\n border-left: 3px solid var(--nb-c-warning, #d97706);\n }\n &--info {\n border-left: 3px solid var(--nb-c-primary, #5856a9);\n }\n}\n\n.nb-toast__icon {\n flex-shrink: 0;\n margin-top: 1px;\n}\n\n.nb-toast__body {\n flex: 1;\n min-width: 0;\n display: flex;\n flex-direction: column;\n gap: 2px;\n}\n\n.nb-toast__title {\n margin: 0;\n font-size: 13px;\n font-weight: 600;\n color: var(--nb-c-text, #1a1a2e);\n line-height: 1.4;\n}\n\n.nb-toast__message {\n margin: 0;\n font-size: 13px;\n color: var(--nb-c-text-muted, #6b7280);\n line-height: 1.5;\n}\n\n.nb-toast__cta {\n margin-top: 6px;\n padding: 0;\n border: none;\n background: none;\n font-size: 12px;\n font-weight: 600;\n color: var(--nb-c-primary, #5856a9);\n cursor: pointer;\n text-align: left;\n line-height: 1;\n\n &:hover {\n text-decoration: underline;\n }\n}\n\n.nb-toast__close {\n flex-shrink: 0;\n display: flex;\n align-items: center;\n justify-content: center;\n width: 22px;\n height: 22px;\n border: none;\n background: transparent;\n border-radius: 4px;\n color: var(--nb-c-text-subtle, #9ca3af);\n cursor: pointer;\n transition:\n background 0.15s,\n color 0.15s;\n margin-top: -1px;\n\n &:hover {\n background: var(--nb-c-bg-subtle, #f3f4f6);\n color: var(--nb-c-text, #1a1a2e);\n }\n}\n\n.nb-toast__progress {\n position: absolute;\n bottom: 0;\n left: 0;\n height: 2px;\n width: 100%;\n background: currentColor;\n opacity: 0.25;\n transform-origin: left;\n animation: nb-toast-progress linear forwards;\n}\n\n@keyframes nb-toast-progress {\n from {\n transform: scaleX(1);\n }\n to {\n transform: scaleX(0);\n }\n}\n</style>\n","<script setup lang=\"ts\">\nimport { ref, onMounted, onUnmounted, watch } from 'vue'\nimport NbIcon from './Icon.vue'\n\nexport type TToastVariant = 'success' | 'error' | 'warning' | 'info'\n\nexport interface IToastCta {\n label: string\n action: () => void\n}\n\nconst props = withDefaults(\n defineProps<{\n variant?: TToastVariant\n title?: string\n message: string\n duration?: number\n cta?: IToastCta\n }>(),\n {\n variant: 'info',\n title: undefined,\n duration: 4000,\n cta: undefined,\n },\n)\n\nconst emit = defineEmits<{ close: [] }>()\n\nconst paused = ref(false)\n\nconst iconMap: Record<TToastVariant, string> = {\n success: 'check-circle',\n error: 'warning-circle',\n warning: 'warning',\n info: 'info',\n}\n\nlet timer: ReturnType<typeof setTimeout> | null = null\nlet remaining = props.duration ?? 0\nlet startedAt = 0\n\nfunction startTimer() {\n if (!remaining) return\n startedAt = Date.now()\n timer = setTimeout(() => emit('close'), remaining)\n}\n\nfunction pauseProgress() {\n if (!remaining || paused.value) return\n paused.value = true\n if (timer) clearTimeout(timer)\n remaining -= Date.now() - startedAt\n}\n\nfunction resumeProgress() {\n if (!remaining || !paused.value) return\n paused.value = false\n startTimer()\n}\n\nonMounted(startTimer)\nonUnmounted(() => {\n if (timer) clearTimeout(timer)\n})\n\nwatch(\n () => props.duration,\n (val) => {\n if (timer) clearTimeout(timer)\n remaining = val ?? 0\n startTimer()\n },\n)\n</script>\n\n<template>\n <div\n :class=\"['nb-toast', `nb-toast--${variant}`]\"\n role=\"alert\"\n :aria-live=\"variant === 'error' ? 'assertive' : 'polite'\"\n @mouseenter=\"pauseProgress\"\n @mouseleave=\"resumeProgress\"\n >\n <div class=\"nb-toast__icon\">\n <NbIcon :name=\"iconMap[variant!]\" :size=\"16\" />\n </div>\n <div class=\"nb-toast__body\">\n <p v-if=\"title\" class=\"nb-toast__title\">{{ title }}</p>\n <p class=\"nb-toast__message\">{{ message }}</p>\n <button\n v-if=\"cta\"\n class=\"nb-toast__cta\"\n @click=\"\n () => {\n cta && cta.action()\n emit('close')\n }\n \"\n >\n {{ cta.label }}\n </button>\n </div>\n <button class=\"nb-toast__close\" aria-label=\"Close\" @click=\"emit('close')\">\n <NbIcon name=\"x\" :size=\"14\" />\n </button>\n <div\n v-if=\"duration\"\n ref=\"progressRef\"\n class=\"nb-toast__progress\"\n :style=\"{\n animationDuration: `${duration}ms`,\n animationPlayState: paused ? 'paused' : 'running',\n }\"\n />\n </div>\n</template>\n\n<style scoped lang=\"scss\">\n.nb-toast {\n position: relative;\n display: flex;\n align-items: flex-start;\n gap: 10px;\n padding: 12px 14px;\n background: var(--nb-c-bg, #fff);\n border: 1px solid var(--nb-c-border, #e5e7eb);\n border-radius: 10px;\n box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);\n min-width: 280px;\n max-width: 380px;\n overflow: hidden;\n font-family: var(--nb-font-family-sans, sans-serif);\n\n &--success .nb-toast__icon {\n color: var(--nb-c-success, #4acf7b);\n }\n &--error .nb-toast__icon {\n color: var(--nb-c-danger, #dc2626);\n }\n &--warning .nb-toast__icon {\n color: var(--nb-c-warning, #d97706);\n }\n &--info .nb-toast__icon {\n color: var(--nb-c-primary, #5856a9);\n }\n\n &--success {\n border-left: 3px solid var(--nb-c-success, #4acf7b);\n }\n &--error {\n border-left: 3px solid var(--nb-c-danger, #dc2626);\n }\n &--warning {\n border-left: 3px solid var(--nb-c-warning, #d97706);\n }\n &--info {\n border-left: 3px solid var(--nb-c-primary, #5856a9);\n }\n}\n\n.nb-toast__icon {\n flex-shrink: 0;\n margin-top: 1px;\n}\n\n.nb-toast__body {\n flex: 1;\n min-width: 0;\n display: flex;\n flex-direction: column;\n gap: 2px;\n}\n\n.nb-toast__title {\n margin: 0;\n font-size: 13px;\n font-weight: 600;\n color: var(--nb-c-text, #1a1a2e);\n line-height: 1.4;\n}\n\n.nb-toast__message {\n margin: 0;\n font-size: 13px;\n color: var(--nb-c-text-muted, #6b7280);\n line-height: 1.5;\n}\n\n.nb-toast__cta {\n margin-top: 6px;\n padding: 0;\n border: none;\n background: none;\n font-size: 12px;\n font-weight: 600;\n color: var(--nb-c-primary, #5856a9);\n cursor: pointer;\n text-align: left;\n line-height: 1;\n\n &:hover {\n text-decoration: underline;\n }\n}\n\n.nb-toast__close {\n flex-shrink: 0;\n display: flex;\n align-items: center;\n justify-content: center;\n width: 22px;\n height: 22px;\n border: none;\n background: transparent;\n border-radius: 4px;\n color: var(--nb-c-text-subtle, #9ca3af);\n cursor: pointer;\n transition:\n background 0.15s,\n color 0.15s;\n margin-top: -1px;\n\n &:hover {\n background: var(--nb-c-bg-subtle, #f3f4f6);\n color: var(--nb-c-text, #1a1a2e);\n }\n}\n\n.nb-toast__progress {\n position: absolute;\n bottom: 0;\n left: 0;\n height: 2px;\n width: 100%;\n background: currentColor;\n opacity: 0.25;\n transform-origin: left;\n animation: nb-toast-progress linear forwards;\n}\n\n@keyframes nb-toast-progress {\n from {\n transform: scaleX(1);\n }\n to {\n transform: scaleX(0);\n }\n}\n</style>\n","import type { App } from 'vue'\n\nconst components: Record<string, any> = import.meta.glob('./**/*.vue', {\n eager: true,\n})\n\nexport default {\n install(app: App) {\n Object.keys(components).forEach((key) => {\n if (key.includes('/labs/')) return\n\n const name = `Nb${key.replace(/(.+\\/)(\\w+)(\\.vue)$/, '$2')}`\n const component = components[key]\n app.component(name, component.default)\n })\n },\n}\n","export function escapeHtml(unsafe: string): string {\n if (!unsafe) return unsafe\n\n // Define allowed tags (`b|em|strong|br|p`) with optional `style` and `class` attributes\n const allowedTagsPattern =\n '<\\\\/?\\\\s*(?:b|em|strong|br|p)(?:\\\\s+(?:style=\"[^\"]*\"|class=\"[^\"]*\"))*\\\\s*>'\n\n // Regex to match an exact allowed tag\n const exactAllowedTagRegex = new RegExp(`^${allowedTagsPattern}$`, 'i')\n\n // Regex to split while capturing allowed tags\n const splitRegex = new RegExp(`(${allowedTagsPattern})`, 'gi')\n\n const parts = unsafe.split(splitRegex)\n\n return parts\n .map((part) => {\n // If the part is exactly an allowed tag, return it unchanged\n if (exactAllowedTagRegex.test(part)) {\n return part\n }\n // Otherwise, escape special characters and convert newlines to <br>\n return part\n .replaceAll(/&(?!amp;|lt;|gt;|quot;|#039;)/g, '&amp;')\n .replaceAll('<', '&lt;')\n .replaceAll('>', '&gt;')\n .replaceAll('\"', '&quot;')\n .replaceAll(\"'\", '&#039;')\n .replaceAll('\\n', '<br>')\n })\n .join('')\n}\n","import type { App, DirectiveBinding } from 'vue'\nimport { escapeHtml } from '@/utils/escapeHtml.helper'\nimport type { IComponentContent } from '@/types/ContentRenderer'\n\ntype TTooltipEl = HTMLElement & {\n __showTooltip__?: () => void\n __hideTooltip__?: (delay?: number) => void\n __mouseMove__?: (e: MouseEvent) => void\n __showHandler__?: EventListener\n __hideHandler__?: EventListener\n __mouseX__?: number\n __mouseY__?: number\n __tooltipBinding__?: ITooltipOptions\n __showTimer__?: ReturnType<typeof setTimeout>\n tooltipElement?: HTMLSpanElement\n}\n\nexport interface ITooltipOptions {\n body?: string | Array<IComponentContent>\n header?: string | Array<IComponentContent>\n tip?: string | Array<IComponentContent>\n flavor?: string\n delay?: number\n animationTime?: number\n position?: 'top' | 'bottom' | 'left' | 'right' | 'cursor'\n followCursor?: boolean\n overflowOnly?: boolean\n classExtra?: string\n}\n\nconst registeredTooltips = new Set() // Store active tooltips globally\n\n/**\n * Converts complex content structure (IComponentContent array) to HTML string\n * Supports both 'children' and 'content' properties for compatibility\n */\nconst renderComplexContent = (\n content: Array<IComponentContent> | IComponentContent | any,\n): string => {\n if (Array.isArray(content)) {\n return content.map((item) => renderComplexContent(item)).join('')\n }\n\n if (!content || typeof content !== 'object' || !content.component) {\n return ''\n }\n\n const { component, props = {}, children, content: contentProp } = content\n // Support both 'children' and 'content' properties\n const childContent = children !== undefined ? children : contentProp\n\n const propsStr = Object.entries(props)\n .map(([key, value]) => `${key}=\"${escapeHtml(String(value))}\"`)\n .join(' ')\n\n const childrenHtml = Array.isArray(childContent)\n ? renderComplexContent(childContent)\n : childContent !== undefined\n ? escapeHtml(String(childContent))\n : ''\n\n return `<${component}${propsStr ? ` ${propsStr}` : ''}>${childrenHtml}</${component}>`\n}\n\n/**\n * Renders tooltip content - supports both string and complex content structure\n */\nconst renderTooltipContent = (\n content: string | Array<IComponentContent> | undefined,\n): string => {\n if (!content) return ''\n\n if (typeof content === 'string') {\n return escapeHtml(content)\n }\n\n if (Array.isArray(content)) {\n return renderComplexContent(content)\n }\n\n return ''\n}\n\nconst tooltipDirective = (app: App) => {\n const router = app.config.globalProperties.$router\n\n if (router) {\n router.beforeEach(() => {\n registeredTooltips.forEach((el: any) => el?.__hideTooltip__?.(0))\n registeredTooltips.clear()\n })\n }\n\n app.directive('nb-tooltip', {\n mounted(el: TTooltipEl, binding: DirectiveBinding<ITooltipOptions>) {\n let hideTimer: ReturnType<typeof setTimeout> | undefined = undefined\n\n el.__showTooltip__ = () => {\n clearTimeout(hideTimer)\n if (el.__tooltipBinding__) showTooltip(el, el.__tooltipBinding__)\n }\n\n el.__hideTooltip__ = (delay = 150) => {\n // set optimal hide delay by default (150ms)\n hideTimer = setTimeout(() => {\n hideTooltip(el, delay <= 0)\n }, delay)\n }\n\n el.__mouseMove__ = (event: MouseEvent) => {\n el.__mouseX__ = event.clientX\n el.__mouseY__ = event.clientY\n if (binding.value?.followCursor) {\n positionTooltip(\n el,\n el.tooltipElement,\n el.__tooltipBinding__?.position,\n )\n }\n }\n\n el.__tooltipBinding__ = binding.value\n\n el.__showHandler__ = () => el.__showTooltip__?.()\n el.__hideHandler__ = () => el.__hideTooltip__?.()\n\n el.addEventListener('mouseenter', el.__showHandler__)\n el.addEventListener('mouseleave', el.__hideHandler__)\n el.addEventListener('mousemove', el.__mouseMove__ as EventListener)\n window.addEventListener('scroll', el.__hideHandler__)\n },\n\n updated(el: TTooltipEl, binding: DirectiveBinding<ITooltipOptions>) {\n el.__tooltipBinding__ = binding.value\n if (!binding.value) {\n hideTooltip(el, true)\n } else if (el.tooltipElement) {\n updateTooltip(el, binding.value)\n }\n },\n\n unmounted(el: TTooltipEl) {\n hideTooltip(el, true)\n if (el.__showHandler__)\n el.removeEventListener('mouseenter', el.__showHandler__)\n if (el.__hideHandler__)\n el.removeEventListener('mouseleave', el.__hideHandler__)\n if (el.__hideHandler__)\n window.removeEventListener('scroll', el.__hideHandler__)\n },\n })\n}\n\nconst createTooltipContent = ({\n header = '',\n body = '',\n tip = '',\n}: Partial<Pick<ITooltipOptions, 'header' | 'body' | 'tip'>>) => {\n return `\n <div class=\"nb-tooltip-content\">\n <div class=\"nb-tooltip-header\">${renderTooltipContent(header)}</div>\n <div class=\"nb-tooltip-body\">${renderTooltipContent(body)}</div>\n <div class=\"nb-tooltip-tip\">${renderTooltipContent(tip)}</div>\n </div>\n `\n}\n\nconst showTooltip = (\n el: TTooltipEl,\n {\n header,\n body,\n tip,\n flavor = 'default',\n delay = 400,\n animationTime = 300,\n position,\n overflowOnly,\n classExtra,\n }: ITooltipOptions,\n) => {\n // Check if tooltip already exists, and remove it if it does\n const existingTooltip = el.tooltipElement\n if (existingTooltip) {\n existingTooltip.remove()\n }\n\n if (overflowOnly) {\n const rect = el.getBoundingClientRect()\n const isOverflowing = Math.round(rect.width) < Math.round(el.scrollWidth)\n if (!isOverflowing) {\n return\n }\n }\n\n if (!(body || header || tip)) {\n return\n }\n\n el.__showTimer__ = setTimeout(() => {\n const tooltip = document.createElement('span')\n tooltip.style.transition = `opacity ${animationTime}ms ease-in-out`\n tooltip.className = `nb-tooltip nb-tooltip-${position} ${flavor ? `nb-tooltip-flavor-${flavor}` : ''} ${classExtra || ''}`\n tooltip.innerHTML = createTooltipContent({ header, body, tip })\n tooltip.style.animation = `tooltipAppear ${animationTime}ms ease-in-out forwards`\n\n el.tooltipElement = tooltip\n registeredTooltips.add(el) // Register active tooltip\n\n document.body.appendChild(tooltip)\n positionTooltip(el, tooltip, position)\n }, delay) // ← optimal show delay (400ms)\n}\n\nconst hideTooltip = (el: TTooltipEl, immediate = false) => {\n // Retrieve tooltip element from the memoized property\n const tooltip = el.tooltipElement\n\n clearTimeout(el.__showTimer__)\n\n if (tooltip) {\n if (immediate) {\n tooltip.remove()\n } else {\n tooltip.style.animation = `tooltipDisappear 200ms ease-in-out forwards`\n setTimeout(() => {\n tooltip.remove()\n }, 200)\n }\n registeredTooltips.delete(el) // Remove from active tooltips\n }\n}\n\nconst updateTooltip = (\n el: TTooltipEl,\n { header, body, tip, position }: ITooltipOptions,\n) => {\n // Retrieve tooltip element from the memoized property\n const tooltip = el.tooltipElement\n\n if (tooltip) {\n tooltip.innerHTML = createTooltipContent({\n header,\n body,\n tip,\n })\n positionTooltip(el, tooltip, position)\n }\n}\n\nconst positionTooltip = (\n el: TTooltipEl,\n tooltip: HTMLSpanElement | undefined,\n position: ITooltipOptions['position'],\n) => {\n const gap = 4\n const rect = el.getBoundingClientRect()\n const tooltipRect = tooltip?.getBoundingClientRect()\n const tooltipWidth = tooltipRect?.width || 0\n const tooltipHeight = tooltipRect?.height || 0\n const parentScrollTop = el.scrollTop\n const parentScrollLeft = el.scrollLeft\n let top, left\n\n switch (position) {\n case 'top':\n top = rect.top - (tooltipHeight + gap * 2) - parentScrollTop // space for \"arrow\" which is 7.6 px\n left =\n rect.left +\n rect.width / 2 -\n (tooltipWidth / 2 + gap / 2) -\n parentScrollLeft\n break\n case 'bottom':\n top = rect.bottom + gap - parentScrollTop\n left =\n rect.left +\n rect.width / 2 -\n (tooltipWidth / 2 + gap / 2) -\n parentScrollLeft\n break\n case 'left':\n top = rect.top + rect.height / 2 - tooltipHeight / 2 - parentScrollTop\n left = rect.left - (tooltipWidth + gap * 2) - parentScrollLeft\n break\n case 'right':\n top = rect.top + rect.height / 2 - tooltipHeight / 2 - parentScrollTop\n left = rect.right + gap - parentScrollLeft\n break\n case 'cursor':\n default:\n top = (el.__mouseY__ ?? 0) + gap\n left = (el.__mouseX__ ?? 0) + gap\n break\n }\n\n if (tooltip) {\n tooltip.style.top = `${top}px`\n tooltip.style.left = `${left}px`\n }\n}\n\nexport default tooltipDirective\n","import type { App } from 'vue'\n\ntype TDirectiveModule = { default: (app: App) => void }\n\nconst modules = import.meta.glob<TDirectiveModule>('./**/*.ts', { eager: true })\n\nexport default {\n install(app: App) {\n Object.values(modules).forEach((mod) => {\n if (typeof mod.default === 'function') {\n mod.default(app)\n }\n })\n },\n}\n","import type { App } from 'vue'\n\nconst labsComponents: Record<string, any> = import.meta.glob(\n './components/labs/**/*.vue',\n { eager: true },\n)\n\nexport default {\n install(app: App) {\n Object.keys(labsComponents).forEach((key) => {\n const name = `Nb${key.replace(/(.+\\/)(\\w+)(\\.vue)$/, '$2')}`\n const component = labsComponents[key]\n app.component(name, component.default)\n })\n },\n}\n","import type { App } from 'vue'\nimport components from './components/index'\nimport directives from './directives/index'\n\nexport default {\n install(app: App) {\n app.use(components)\n app.use(directives)\n },\n}\n\n// Named exports for tree-shakeable individual imports\nexport { default as NbBreadcrumbs } from './components/Breadcrumbs.vue'\nexport { default as NbBadge } from './components/Badge.vue'\nexport { default as NbButton } from './components/Button.vue'\nexport { default as NbCheckbox } from './components/Checkbox.vue'\nexport { default as NbColorStrip } from './components/ColorStrip.vue'\nexport { default as NbFlag } from './components/Flag.vue'\nexport { default as NbGrid } from './components/Grid.vue'\nexport { default as NbIcon } from './components/Icon.vue'\nexport { default as NbJsonTree } from './components/JsonTree.vue'\nexport { default as NbLabel } from './components/Label.vue'\nexport { default as NbMessage } from './components/Message.vue'\nexport { default as NbModal } from './components/Modal.vue'\nexport { default as NbPanel } from './components/Panel.vue'\nexport { default as NbToast } from './components/Toast.vue'\nexport type { TToastVariant, IToastCta } from './components/Toast.vue'\nexport { default as NbRadio } from './components/Radio.vue'\nexport { default as NbNumberInput } from './components/NumberInput.vue'\nexport { default as NbSlider } from './components/Slider.vue'\nexport { default as NbSelect } from './components/Select.vue'\nexport { default as NbTextInput } from './components/TextInput.vue'\nexport type { ISelectOption, ISelectProps } from './components/Select.d'\n\n// Directives\nexport { default as nbTooltipDirective } from './directives/ToolTip.directive'\n\n// Labs plugin (experimental components)\nexport { default as NubiscoUILabs } from './labs'\n"],"x_google_ignoreList":[33,34,35,36],"mappings":"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;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;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"}
1
+ {"version":3,"file":"index.mjs","names":["$emit","$slots","$slots","is","id","tabIndex","format","escapeHtml","toDisplayString","errorMessages","format","baseCompile","initFeatureFlags","errorMessages","warnMessages","getWarnMessage","VERSION","toDisplayString","escapeHtml","format","getCurrentInstance","$slots","$emit","$slots","$slots","$attrs"],"sources":["../src/components/AiLabel.d.ts","../src/components/AiLabel.vue","../src/components/AiLabel.vue","../src/components/Badge.d.ts","../src/components/Badge.vue","../src/components/Badge.vue","../src/components/Breadcrumbs.vue","../src/components/Breadcrumbs.vue","../src/types/Size.d.ts","../src/components/Button.d.ts","../src/utils/kebab2camel.helper.ts","../src/components/Icon.d.ts","../src/utils/str2kebab.helper.ts","../src/composables/useStableId.composable.ts","../src/components/Icon.vue","../src/components/Icon.vue","../src/components/Button.vue","../src/components/Button.vue","../src/components/Checkbox.vue","../src/components/Checkbox.vue","../src/components/ColorStrip.vue","../src/components/ColorStrip.vue","../src/types/Variants.d.ts","../src/components/FileUploader.d.ts","../src/components/FileUploader.vue","../src/components/FileUploader.vue","../src/components/Flag.vue","../src/components/Flag.vue","../src/components/Form.vue","../src/components/Form.vue","../src/components/Grid.d.ts","../src/components/Grid.vue","../src/components/Grid.vue","../node_modules/.pnpm/@intlify+shared@11.3.0/node_modules/@intlify/shared/dist/shared.mjs","../node_modules/.pnpm/@intlify+message-compiler@11.3.0/node_modules/@intlify/message-compiler/dist/message-compiler.mjs","../node_modules/.pnpm/@intlify+core-base@11.3.0/node_modules/@intlify/core-base/dist/core-base.mjs","../node_modules/.pnpm/vue-i18n@11.3.0_vue@3.5.30_typescript@5.9.3_/node_modules/vue-i18n/dist/vue-i18n.mjs","../src/components/ImageCropper.d.ts","../src/components/ImageCropper.vue","../src/components/ImageCropper.vue","../src/components/JsonTree.vue","../src/components/JsonTree.vue","../src/components/Label.d.ts","../src/components/Label.vue","../src/components/Label.vue","../src/components/Message.d.ts","../src/components/Message.vue","../src/components/Message.vue","../src/components/Modal.vue","../src/components/Modal.vue","../src/components/NumberInput.vue","../src/components/NumberInput.vue","../src/components/Panel.vue","../src/components/Panel.vue","../src/components/Radio.d.ts","../src/components/Radio.vue","../src/components/Radio.vue","../src/components/Select.vue","../src/components/Select.vue","../src/components/Slider.vue","../src/components/Slider.vue","../src/components/Switch.d.ts","../src/components/Switch.vue","../src/components/Switch.vue","../src/components/TextInput.vue","../src/components/TextInput.vue","../src/components/Toast.vue","../src/components/Toast.vue","../src/components/index.ts","../src/utils/escapeHtml.helper.ts","../src/directives/ToolTip.directive.ts","../src/directives/index.ts","../src/labs.ts","../src/main.ts"],"sourcesContent":["enum EAiLabelVariant {\n Default = 'default',\n Inline = 'inline',\n}\n\n// #region EAiLabelSize\nenum EAiLabelSize {\n Small = 'sm',\n Medium = 'md',\n Large = 'lg',\n}\n// #endregion EAiLabelSize\n\ninterface IAiLabelProps {\n variant?: EAiLabelVariant\n size?: EAiLabelSize\n}\n\nexport { EAiLabelVariant, EAiLabelSize, IAiLabelProps }\n","<template>\n <NbGrid\n is=\"button\"\n align=\"center\"\n v-bind=\"{ ...(variant === EAiLabelVariant.Inline && { gap: 'sm' }) }\"\n justify=\"center\"\n :class=\"classes\"\n >\n <div v-if=\"variant === EAiLabelVariant.Inline\" class=\"nb-ai-label--dot\" />\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 256 256\">\n <path\n d=\"M 104.301 197.8 L 94.501 162.4 L 53.101 162.4 L 43.501 197.8 L 17.101 197.8 L 56.301 58.2 L 92.701 58.2 L 132.101 197.8 L 104.301 197.8 Z M 74.701 84 L 73.101 84 L 57.701 141 L 90.101 141 L 74.701 84 Z M 150.099 197.8 L 150.099 178.2 L 181.499 178.2 L 181.499 77.8 L 150.099 77.8 L 150.099 58.2 L 238.899 58.2 L 238.899 77.8 L 207.499 77.8 L 207.499 178.2 L 238.899 178.2 L 238.899 197.8 L 150.099 197.8 Z\"\n fill=\"currentColor\"\n />\n </svg>\n </NbGrid>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed } from 'vue'\nimport { EAiLabelVariant, EAiLabelSize, IAiLabelProps } from './AiLabel.d'\n\nconst props = withDefaults(defineProps<IAiLabelProps>(), {\n variant: EAiLabelVariant.Default,\n size: EAiLabelSize.Medium,\n})\n\nconst classes = computed(() => {\n return {\n 'nb-ai-label': true,\n [`nb-ai-label__${props.variant}`]: true,\n [`nb-ai-label__${props.size}`]: true,\n }\n})\n</script>\n\n<style lang=\"scss\" scoped>\n.nb-ai-label {\n width: calc(var(--nb-base-unit) * 4);\n height: calc(var(--nb-base-unit) * 4);\n border: solid 1px black;\n &--dot {\n width: var(--nb-base-unit);\n height: var(--nb-base-unit);\n background: black;\n }\n svg {\n width: calc(var(--nb-base-unit) * 2);\n height: calc(var(--nb-base-unit) * 2);\n }\n &__default {\n &:hover {\n background: black;\n color: white;\n cursor: pointer;\n }\n &:focus {\n outline: solid 2px var(--nb-c-primary);\n outline-offset: -2px;\n }\n }\n &__inline {\n border: none;\n height: calc(var(--nb-base-unit) * 2);\n width: fit-content;\n padding: calc(var(--nb-base-unit) / 4);\n position: relative;\n\n svg {\n width: calc(var(--nb-base-unit) * 2);\n height: calc(var(--nb-base-unit) * 2);\n }\n &:hover {\n outline: solid 1px black;\n cursor: pointer;\n }\n &:focus {\n outline: solid 2px var(--nb-c-primary);\n }\n }\n &__default {\n }\n\n &__small {\n }\n\n &__large {\n }\n}\n</style>\n","<template>\n <NbGrid\n is=\"button\"\n align=\"center\"\n v-bind=\"{ ...(variant === EAiLabelVariant.Inline && { gap: 'sm' }) }\"\n justify=\"center\"\n :class=\"classes\"\n >\n <div v-if=\"variant === EAiLabelVariant.Inline\" class=\"nb-ai-label--dot\" />\n <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 256 256\">\n <path\n d=\"M 104.301 197.8 L 94.501 162.4 L 53.101 162.4 L 43.501 197.8 L 17.101 197.8 L 56.301 58.2 L 92.701 58.2 L 132.101 197.8 L 104.301 197.8 Z M 74.701 84 L 73.101 84 L 57.701 141 L 90.101 141 L 74.701 84 Z M 150.099 197.8 L 150.099 178.2 L 181.499 178.2 L 181.499 77.8 L 150.099 77.8 L 150.099 58.2 L 238.899 58.2 L 238.899 77.8 L 207.499 77.8 L 207.499 178.2 L 238.899 178.2 L 238.899 197.8 L 150.099 197.8 Z\"\n fill=\"currentColor\"\n />\n </svg>\n </NbGrid>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed } from 'vue'\nimport { EAiLabelVariant, EAiLabelSize, IAiLabelProps } from './AiLabel.d'\n\nconst props = withDefaults(defineProps<IAiLabelProps>(), {\n variant: EAiLabelVariant.Default,\n size: EAiLabelSize.Medium,\n})\n\nconst classes = computed(() => {\n return {\n 'nb-ai-label': true,\n [`nb-ai-label__${props.variant}`]: true,\n [`nb-ai-label__${props.size}`]: true,\n }\n})\n</script>\n\n<style lang=\"scss\" scoped>\n.nb-ai-label {\n width: calc(var(--nb-base-unit) * 4);\n height: calc(var(--nb-base-unit) * 4);\n border: solid 1px black;\n &--dot {\n width: var(--nb-base-unit);\n height: var(--nb-base-unit);\n background: black;\n }\n svg {\n width: calc(var(--nb-base-unit) * 2);\n height: calc(var(--nb-base-unit) * 2);\n }\n &__default {\n &:hover {\n background: black;\n color: white;\n cursor: pointer;\n }\n &:focus {\n outline: solid 2px var(--nb-c-primary);\n outline-offset: -2px;\n }\n }\n &__inline {\n border: none;\n height: calc(var(--nb-base-unit) * 2);\n width: fit-content;\n padding: calc(var(--nb-base-unit) / 4);\n position: relative;\n\n svg {\n width: calc(var(--nb-base-unit) * 2);\n height: calc(var(--nb-base-unit) * 2);\n }\n &:hover {\n outline: solid 1px black;\n cursor: pointer;\n }\n &:focus {\n outline: solid 2px var(--nb-c-primary);\n }\n }\n &__default {\n }\n\n &__small {\n }\n\n &__large {\n }\n}\n</style>\n","// FIXME replace the variant with the existing variants\nenum EBadgeVariant {\n Grey = 'grey',\n Blue = 'blue',\n Orange = 'orange',\n Green = 'green',\n Red = 'red',\n Purple = 'purple',\n Primary = 'primary',\n}\n\nenum EBadgeSize {\n Small = 'sm',\n Medium = 'md',\n}\n\ninterface IBadgeProps {\n variant?: EBadgeVariant\n size?: EBadgeSize\n dot?: boolean\n}\n\nexport { EBadgeVariant, EBadgeSize, IBadgeProps }\n","<template>\n <span :class=\"['nb-badge', `nb-badge--${variant}`, `nb-badge--${size}`]\">\n <span v-if=\"dot\" class=\"nb-badge__dot\" />\n <slot />\n </span>\n</template>\n\n<script setup lang=\"ts\">\nimport { EBadgeVariant, EBadgeSize, IBadgeProps } from './Badge.d'\n\nwithDefaults(defineProps<IBadgeProps>(), {\n variant: EBadgeVariant.Grey,\n size: EBadgeSize.Medium,\n dot: false,\n})\n</script>\n\n<style scoped lang=\"scss\">\n.nb-badge {\n display: inline-flex;\n align-items: center;\n gap: 4px;\n font-weight: 500;\n border-radius: 999px;\n white-space: nowrap;\n line-height: 1;\n\n &--sm {\n padding: 2px 7px;\n font-size: 10px;\n }\n &--md {\n padding: 3px 9px;\n font-size: 11px;\n }\n\n /* Variants */\n &--grey {\n background: #e8e8ee;\n color: #555566;\n }\n &--blue {\n background: #dbeafe;\n color: #1d4ed8;\n }\n &--orange {\n background: #fef3c7;\n color: #92400e;\n }\n &--green {\n background: #d1fae5;\n color: #065f46;\n }\n &--red {\n background: #fee2e2;\n color: #991b1b;\n }\n &--purple {\n background: var(--nb-c-grape-hyacinth-100, #eeedf9);\n color: var(--nb-c-grape-hyacinth-600, #444480);\n }\n &--primary {\n background: var(--nb-c-grape-hyacinth-500, #5856a9);\n color: #fff;\n }\n\n &__dot {\n width: 6px;\n height: 6px;\n border-radius: 50%;\n background: currentColor;\n flex-shrink: 0;\n }\n}\n</style>\n","<template>\n <span :class=\"['nb-badge', `nb-badge--${variant}`, `nb-badge--${size}`]\">\n <span v-if=\"dot\" class=\"nb-badge__dot\" />\n <slot />\n </span>\n</template>\n\n<script setup lang=\"ts\">\nimport { EBadgeVariant, EBadgeSize, IBadgeProps } from './Badge.d'\n\nwithDefaults(defineProps<IBadgeProps>(), {\n variant: EBadgeVariant.Grey,\n size: EBadgeSize.Medium,\n dot: false,\n})\n</script>\n\n<style scoped lang=\"scss\">\n.nb-badge {\n display: inline-flex;\n align-items: center;\n gap: 4px;\n font-weight: 500;\n border-radius: 999px;\n white-space: nowrap;\n line-height: 1;\n\n &--sm {\n padding: 2px 7px;\n font-size: 10px;\n }\n &--md {\n padding: 3px 9px;\n font-size: 11px;\n }\n\n /* Variants */\n &--grey {\n background: #e8e8ee;\n color: #555566;\n }\n &--blue {\n background: #dbeafe;\n color: #1d4ed8;\n }\n &--orange {\n background: #fef3c7;\n color: #92400e;\n }\n &--green {\n background: #d1fae5;\n color: #065f46;\n }\n &--red {\n background: #fee2e2;\n color: #991b1b;\n }\n &--purple {\n background: var(--nb-c-grape-hyacinth-100, #eeedf9);\n color: var(--nb-c-grape-hyacinth-600, #444480);\n }\n &--primary {\n background: var(--nb-c-grape-hyacinth-500, #5856a9);\n color: #fff;\n }\n\n &__dot {\n width: 6px;\n height: 6px;\n border-radius: 50%;\n background: currentColor;\n flex-shrink: 0;\n }\n}\n</style>\n","<template>\n <nav class=\"nb-breadcrumbs\" aria-label=\"breadcrumb\">\n <!-- Brand prefix (title + subtitle) -->\n <span v-if=\"title || subtitle\" class=\"nb-breadcrumbs__brand\">\n <span v-if=\"title\" class=\"nb-breadcrumbs__title\">{{ title }}</span>\n <span v-if=\"subtitle\" class=\"nb-breadcrumbs__subtitle\">{{\n subtitle\n }}</span>\n </span>\n\n <!-- Separator between brand and crumbs (only when both exist) -->\n <NbIcon\n v-if=\"(title || subtitle) && hasDefaultSlot\"\n name=\"caret-right\"\n size=\"sm\"\n class=\"nb-breadcrumbs__sep\"\n />\n\n <!-- Crumb items injected via default slot -->\n <span v-if=\"hasDefaultSlot\" class=\"nb-breadcrumbs__crumbs\">\n <slot />\n </span>\n </nav>\n</template>\n\n<script setup lang=\"ts\">\nimport { useSlots, computed } from 'vue'\n\ndefineProps<{\n /** Text rendered before the subtitle in regular weight. */\n title?: string\n /** Text rendered after the title in bold weight. */\n subtitle?: string\n}>()\n\nconst slots = useSlots()\nconst hasDefaultSlot = computed(() => !!slots.default?.())\n</script>\n\n<style lang=\"scss\" scoped>\n.nb-breadcrumbs {\n display: inline-flex;\n align-items: center;\n gap: 0.35rem;\n font-size: 0.9rem;\n line-height: 1;\n}\n\n.nb-breadcrumbs__brand {\n display: inline-flex;\n align-items: baseline;\n gap: 0.3em;\n}\n\n.nb-breadcrumbs__title {\n font-weight: 400;\n color: var(--nb-c-text-primary, #1a1a2e);\n}\n\n.nb-breadcrumbs__subtitle {\n font-weight: 700;\n color: var(--nb-c-text-primary, #1a1a2e);\n}\n\n.nb-breadcrumbs__sep {\n color: var(--nb-c-text-tertiary, #d1d5db);\n flex-shrink: 0;\n}\n\n.nb-breadcrumbs__crumbs {\n display: inline-flex;\n align-items: center;\n gap: 0.35rem;\n font-weight: 700;\n color: var(--nb-c-text-primary, #1a1a2e);\n}\n</style>\n","<template>\n <nav class=\"nb-breadcrumbs\" aria-label=\"breadcrumb\">\n <!-- Brand prefix (title + subtitle) -->\n <span v-if=\"title || subtitle\" class=\"nb-breadcrumbs__brand\">\n <span v-if=\"title\" class=\"nb-breadcrumbs__title\">{{ title }}</span>\n <span v-if=\"subtitle\" class=\"nb-breadcrumbs__subtitle\">{{\n subtitle\n }}</span>\n </span>\n\n <!-- Separator between brand and crumbs (only when both exist) -->\n <NbIcon\n v-if=\"(title || subtitle) && hasDefaultSlot\"\n name=\"caret-right\"\n size=\"sm\"\n class=\"nb-breadcrumbs__sep\"\n />\n\n <!-- Crumb items injected via default slot -->\n <span v-if=\"hasDefaultSlot\" class=\"nb-breadcrumbs__crumbs\">\n <slot />\n </span>\n </nav>\n</template>\n\n<script setup lang=\"ts\">\nimport { useSlots, computed } from 'vue'\n\ndefineProps<{\n /** Text rendered before the subtitle in regular weight. */\n title?: string\n /** Text rendered after the title in bold weight. */\n subtitle?: string\n}>()\n\nconst slots = useSlots()\nconst hasDefaultSlot = computed(() => !!slots.default?.())\n</script>\n\n<style lang=\"scss\" scoped>\n.nb-breadcrumbs {\n display: inline-flex;\n align-items: center;\n gap: 0.35rem;\n font-size: 0.9rem;\n line-height: 1;\n}\n\n.nb-breadcrumbs__brand {\n display: inline-flex;\n align-items: baseline;\n gap: 0.3em;\n}\n\n.nb-breadcrumbs__title {\n font-weight: 400;\n color: var(--nb-c-text-primary, #1a1a2e);\n}\n\n.nb-breadcrumbs__subtitle {\n font-weight: 700;\n color: var(--nb-c-text-primary, #1a1a2e);\n}\n\n.nb-breadcrumbs__sep {\n color: var(--nb-c-text-tertiary, #d1d5db);\n flex-shrink: 0;\n}\n\n.nb-breadcrumbs__crumbs {\n display: inline-flex;\n align-items: center;\n gap: 0.35rem;\n font-weight: 700;\n color: var(--nb-c-text-primary, #1a1a2e);\n}\n</style>\n","// #region ESize\n// String-based size tokens (for CSS classes, spacing scales, etc.)\nexport enum ESize {\n ExtraExtraSmall = 'xxs',\n ExtraSmall = 'xs',\n Small = 'sm',\n Medium = 'md',\n Large = 'lg',\n ExtraLarge = 'xl',\n ExtraExtraLarge = 'xxl',\n}\n// #endregion ESize\n\n// #region ESizeShort\nexport enum ESizeShort {\n Small = 'sm',\n Medium = 'md',\n Large = 'lg',\n}\n// #endregion ESizeShort\n\n// #region ESizePixel\n// Numeric size values in pixels (for icons, images, components with fixed dimensions)\nexport enum ESizePixel {\n ExtraExtraSmall = 8,\n ExtraSmall = 12,\n Small = 14,\n Medium = 16,\n Large = 20,\n ExtraLarge = 60,\n ExtraExtraLarge = 92,\n}\n// #endregion ESizePixel\n","import { ESizeShort } from '@/types/Size.d'\n\nenum EButtonType {\n Button = 'button',\n Submit = 'submit',\n Reset = 'reset',\n}\n\ninterface IButtonProps {\n variant?: string\n outlined?: boolean\n size?: ESizeShort\n disabled?: boolean\n loading?: boolean\n /** Icon name passed directly to NbIcon. Rendered in the trailing padding area. Hidden while loading. */\n icon?: string\n /** Native button type. Ignored when `href` is provided. */\n type?: EButtonType\n /** When provided the component renders as an `<a>` element instead of `<button>`. */\n href?: string\n /** Forwarded to the `<a>` element. Only used when `href` is set. */\n target?: string\n /** Forwarded to the `<a>` element. Only used when `href` is set. */\n rel?: string\n}\n\nexport { EButtonType, IButtonProps }\n","/**\n * Converts kebab-case tokens to lower camelCase.\n */\nexport function kebab2camel(str: string): string {\n return str.toLowerCase().replace(/-([a-z0-9])/g, (g) => {\n return g[1].toUpperCase()\n })\n}\n\nexport default kebab2camel\n","import { ESize } from '@/types/Size.d'\n\nenum EAnimation {\n SwingRight = 'swing-right',\n Wobble = 'wobble',\n Expand = 'expand',\n Refresh = 'refresh',\n Heart = 'heart',\n Undo = 'undo',\n Italic = 'italic',\n Cog = 'cog',\n Wrench = 'wrench',\n Mouse = 'mouse-pointer',\n Magic = 'magic',\n Lock = 'lock',\n Unlock = 'unlock',\n Hourglass = 'hourglass',\n Eraser = 'eraser',\n Rocket = 'rocket',\n Times = 'times',\n}\n\nenum EAnimationMode {\n Hover = 'hover',\n Always = 'always',\n}\n\nenum EWeight {\n Thin = 'thin',\n Light = 'light',\n Regular = 'regular',\n Bold = 'bold',\n Fill = 'fill',\n Duotone = 'duotone',\n}\n\nenum EIconSize {\n XXL = 92,\n XL = 60,\n LG = 20,\n MD = 16,\n SM = 14,\n XS = 12,\n XXS = 8,\n}\n\ninterface IIconProps {\n name: string\n size?: ESize | string | number\n animation?: EAnimation | null\n animationMode?: EAnimationMode\n color?: string\n weight?: EWeight\n title?: string\n clickable?: boolean\n hoverable?: boolean\n}\n\nexport { EAnimation, EAnimationMode, EWeight, EIconSize, IIconProps }\n","/**\n * Normalizes an identifier-like string into kebab-case.\n * Handles camelCase, PascalCase, snake_case, and whitespace-delimited input.\n */\nexport function str2kebab(source: string): string {\n return source\n .replace(/(?<=[A-Z0-9])([A-Z])(?=[a-z])/g, ' $1')\n .replace(/_/g, ' ')\n .replace(/([a-z])([A-Z])/g, '$1-$2')\n .replace(/\\s+/g, '-')\n .toLowerCase()\n}\n\nexport default str2kebab\n","import { getCurrentInstance, useId } from 'vue'\nimport str2kebab from '@/utils/str2kebab.helper'\n\n/**\n * Returns a stable, deterministic element ID for any component that needs one.\n *\n * Resolution order:\n * 1. `props.id` — honored as-is when explicitly provided.\n * 2. `{component-slug}-{name-slug}` — when `props.name` is set.\n * e.g. NbTextInput + `name=\"billingEmail\"` → `\"nb-text-input-billing-email\"`\n * 3. `{component-slug}-{vue-uid}` — positional fallback via Vue's `useId()`.\n * e.g. `\"nb-select-v3\"` (SSR-safe, unique within the app instance)\n *\n * The resulting IDs are meaningful in analytics / tracking pipelines: the\n * component type is always present as a prefix, and the field name (when\n * available) makes the target immediately identifiable.\n *\n * @example\n * // Inside a component setup()\n * const elementId = useStableId(props) // props carries id? and name?\n */\n// #region useStableId\nexport function useStableId(props: { id?: string; name?: string }): string {\n if (props.id) return props.id\n\n const instance = getCurrentInstance()\n const componentSlug = str2kebab(instance?.type?.__name ?? 'component')\n\n if (props.name) {\n return `${componentSlug}-${str2kebab(props.name)}`\n }\n\n return `${componentSlug}-${useId()}`\n}\n// #endregion useStableId\n","<template>\n <i\n :class=\"classes\"\n :style=\"styles\"\n v-bind=\"attributes\"\n :title=\"title\"\n @click=\"!clickable ? undefined : emit('click', $event)\"\n >\n <component :is=\"iconComponent\" aria-hidden=\"true\" />\n </i>\n</template>\n\n<script setup lang=\"ts\">\n// @ts-expect-error virtual module provided by icons vite plugin\nimport icons from 'virtual:icons'\nimport { computed } from 'vue'\nimport kebab2camel from '@/utils/kebab2camel.helper'\nimport { ESize } from '@/types/Size.d'\nimport { EAnimationMode, EWeight, EIconSize, IIconProps } from './Icon.d'\nimport { useStableId } from '@/composables/useStableId.composable'\n\nconst props = withDefaults(defineProps<IIconProps>(), {\n size: ESize.Medium,\n animation: null,\n animationMode: EAnimationMode.Always,\n color: undefined,\n weight: EWeight.Regular,\n title: undefined,\n clickable: false,\n hoverable: false,\n})\n\nconst emit = defineEmits(['click'])\n\nconst componentInternalId = useStableId(props)\n\nconst attributes = computed(() => {\n const iconSize =\n typeof props.size === 'number'\n ? props.size\n : (EIconSize as unknown as Record<string, number>)[\n String(props.size).toUpperCase()\n ] || EIconSize.MD\n\n return {\n ...{ id: componentInternalId },\n ...(props.size && {\n width: `${iconSize}px`,\n height: `${iconSize}px`,\n }),\n ...(props.clickable && { role: 'button' }),\n }\n})\n\nconst iconComponent = computed(() => {\n const iconKey = kebab2camel(`i-${props.name}`)\n const iconSet = (icons as Record<string, any>)[iconKey]\n return iconSet?.[props.weight] || iconSet?.regular\n})\n\nconst classes = computed(() => {\n return {\n 'nb-icon': true,\n ...(props.name && { [props.name]: true }),\n [`nb-icon-${props.size}`]: [\n 'xxs',\n 'xs',\n 'sm',\n 'md',\n 'lg',\n 'xl',\n 'xxl',\n ].includes(String(props.size)),\n [`nb-icon-animation-${props.animationMode}-${props.animation}`]:\n props.animation,\n hoverable:\n props.hoverable || (props.animation && props.animationMode === 'hover'),\n 'box-clickable': props.clickable,\n }\n})\n\nconst styles = computed(() => {\n return {\n ...(props.color && { color: props.color }),\n ...(typeof props.size === 'number' && {\n maxWidth: `${props.size}px`,\n maxHeight: `${props.size}px`,\n height: `${props.size}px`,\n width: `${props.size}px`,\n }),\n ...(typeof props.size === 'string' &&\n !['xxs', 'xs', 'sm', 'md', 'lg', 'xl', 'xxl'].includes(props.size) && {\n maxWidth: props.size,\n maxHeight: props.size,\n height: props.size,\n width: props.size,\n }),\n }\n})\n</script>\n\n<style lang=\"scss\" scoped>\n.nb-icon {\n display: flex;\n line-height: 1em;\n position: relative;\n &:not(.hoverable):not(.box-clickable) {\n pointer-events: none;\n }\n\n svg {\n width: 100%;\n height: 100%;\n display: block;\n }\n\n &-xxl {\n max-width: var(--nb-font-size-92);\n max-height: var(--nb-font-size-92);\n height: var(--nb-font-size-92);\n width: var(--nb-font-size-92);\n }\n &-xl {\n max-width: var(--nb-font-size-60);\n max-height: var(--nb-font-size-60);\n height: var(--nb-font-size-60);\n width: var(--nb-font-size-60);\n }\n &-lg {\n max-width: var(--nb-font-size-20);\n max-height: var(--nb-font-size-20);\n height: var(--nb-font-size-20);\n width: var(--nb-font-size-20);\n }\n &-md {\n max-width: var(--nb-font-size-16);\n max-height: var(--nb-font-size-16);\n height: var(--nb-font-size-16);\n width: var(--nb-font-size-16);\n }\n &-sm {\n max-width: var(--nb-font-size-14);\n max-height: var(--nb-font-size-14);\n height: var(--nb-font-size-14);\n width: var(--nb-font-size-14);\n }\n &-xs {\n max-width: var(--nb-font-size-12);\n max-height: var(--nb-font-size-12);\n height: var(--nb-font-size-12);\n width: var(--nb-font-size-12);\n }\n &-xxs {\n max-width: var(--nb-font-size-8);\n max-height: var(--nb-font-size-8);\n height: var(--nb-font-size-8);\n width: var(--nb-font-size-8);\n }\n\n // animations\n &-animation-hover-swing-right:hover {\n animation: swing-right 0.5s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-swing-right {\n animation: swing-right 0.5s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-wobble:hover {\n animation: wobble 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-wobble {\n animation: wobble 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-expand:hover {\n animation: expand 0.5s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-expand {\n animation: expand 0.5s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-refresh:hover {\n animation: refresh 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-refresh {\n animation: refresh 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-heart:hover {\n animation: heart 0.5s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-heart {\n animation: heart 0.5s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-undo:hover {\n animation: undo 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-undo {\n animation: undo 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-italic:hover {\n animation: italic 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-italic {\n animation: italic 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-cog:hover {\n animation: cog 5s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-cog {\n animation: cog 5s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-wrench:hover {\n transform-origin: 79% 26%;\n animation: wrench 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-wrench {\n transform-origin: 79% 26%;\n animation: wrench 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-mouse-pointer:hover {\n animation: mouse-pointer 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-mouse-pointer {\n animation: mouse-pointer 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-magic:hover {\n animation: magic 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-magic {\n animation: magic 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-lock:hover {\n animation: lock 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-lock {\n animation: lock 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-unlock:hover {\n transform-origin: 75% 25%;\n animation: unlock 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-unlock {\n transform-origin: 75% 25%;\n animation: unlock 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-hourglass:hover {\n animation: hourglass 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-hourglass {\n animation: hourglass 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-eraser:hover {\n animation: eraser 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-eraser {\n animation: eraser 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-rocket:hover {\n animation: rocket 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-rocket {\n animation: rocket 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-times:hover {\n animation: times 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-times {\n animation: times 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n\n @keyframes swing-right {\n 0% {\n transform: scale(1.5) translateX(0);\n }\n 33% {\n transform: scale(1.5) translateX(-5px);\n }\n 66% {\n transform: scale(1.5) translateX(5px);\n }\n 100% {\n transform: scale(1.5) translateX(0);\n }\n }\n @keyframes wobble {\n 0% {\n transform: scale(1.5) translate(0, 0);\n }\n 20% {\n transform: scale(1.5) translate(-5px, 5px);\n }\n 40% {\n transform: scale(1.5) translate(-5px, -5px);\n }\n 60% {\n transform: scale(1.5) translate(5px, 5px);\n }\n 80% {\n transform: scale(1.5) translate(5px, -5px);\n }\n 100% {\n transform: scale(1.5) translate(0, 0);\n }\n }\n @keyframes expand {\n 0% {\n transform: scale(1.5) translate(0, 0);\n }\n 25% {\n transform: scale(1.5) translate(-5px, 5px);\n }\n 50% {\n transform: scale(2) translate(0, 0);\n }\n 75% {\n transform: scale(1.5) translate(5px, -5px);\n }\n 100% {\n transform: scale(1.5) translate(0, 0);\n }\n }\n @keyframes refresh {\n from {\n transform: scale(1.5) rotate(0);\n }\n to {\n transform: scale(1.5) rotate(360deg);\n }\n }\n @keyframes heart {\n 0% {\n transform: scale(1.5);\n }\n 20% {\n transform: scale(2);\n }\n 30% {\n transform: scale(1.5);\n }\n 40% {\n transform: scale(2);\n }\n 100% {\n transform: scale(1.5);\n }\n }\n @keyframes undo {\n 0% {\n transform: scale(1.5) translateX(0) rotate(0);\n }\n 33% {\n transform: scale(1.5) translateX(10px) rotate(0);\n }\n 66% {\n transform: scale(1.5) translateX(-10px) rotate(-360deg);\n }\n 100% {\n transform: scale(1.5) translateX(0) rotate(-360deg);\n }\n }\n @keyframes italic {\n 0% {\n transform: scale(1.5) skewX(0);\n }\n 50% {\n transform: scale(1.5) skewX(12deg);\n }\n 100% {\n transform: scale(1.5) skewX(0);\n }\n }\n @keyframes cog {\n 0% {\n transform: scale(1.5) rotate(0);\n }\n 10% {\n transform: scale(1.5) rotate(45deg);\n }\n 17% {\n transform: scale(1.5) rotate(45deg);\n }\n 20% {\n transform: scale(1.5) rotate(90deg);\n }\n 27% {\n transform: scale(1.5) rotate(90deg);\n }\n 30% {\n transform: scale(1.5) rotate(135deg);\n }\n 37% {\n transform: scale(1.5) rotate(135deg);\n }\n 40% {\n transform: scale(1.5) rotate(180deg);\n }\n 47% {\n transform: scale(1.5) rotate(180deg);\n }\n 50% {\n transform: scale(1.5) rotate(225deg);\n }\n 57% {\n transform: scale(1.5) rotate(225deg);\n }\n 60% {\n transform: scale(1.5) rotate(270deg);\n }\n 67% {\n transform: scale(1.5) rotate(270deg);\n }\n 70% {\n transform: scale(1.5) rotate(315deg);\n }\n 77% {\n transform: scale(1.5) rotate(315deg);\n }\n 80% {\n transform: scale(1.5) rotate(360deg);\n }\n 100% {\n transform: scale(1.5) rotate(360deg);\n }\n }\n @keyframes wrench {\n 0% {\n transform: scale(1.5) rotate(0);\n }\n 20% {\n transform: scale(1.5) rotate(30deg);\n }\n 30% {\n transform: scale(1.5) rotate(-20deg);\n }\n 50% {\n transform: scale(1.5) rotate(30deg);\n }\n 60% {\n transform: scale(1.5) rotate(-20deg);\n }\n 100% {\n transform: scale(1.5) rotate(0);\n }\n }\n @keyframes mouse-pointer {\n 0% {\n transform: scale(1.5);\n }\n 20% {\n transform: scale(1.5);\n }\n 22.5% {\n transform: scale(1.2);\n }\n 32.5% {\n transform: scale(1.2);\n }\n 35% {\n transform: scale(1.5);\n }\n 100% {\n transform: scale(1.5);\n }\n }\n @keyframes magic {\n 0% {\n transform: scale(1.5) translate(0, 0) rotate(0);\n }\n 10% {\n transform: scale(1.5) translate(-5px, 2.5px) rotate(-10deg);\n }\n 20% {\n transform: scale(1.5) translate(-10px, 0) rotate(-20deg);\n }\n 30% {\n transform: scale(1.5) translate(-5px, -2.5px) rotate(-30deg);\n }\n 40% {\n transform: scale(1.5) translate(0, 0) rotate(-20deg);\n }\n 50% {\n transform: scale(1.5) translate(5px, 2.5px) rotate(-10deg);\n }\n 60% {\n transform: scale(1.5) translate(10px, 0) rotate(0);\n }\n 70% {\n transform: scale(1.5) translate(5px, -2.5px) rotate(10deg);\n }\n 100% {\n transform: scale(1.5) translate(0, 0) rotate(0);\n }\n }\n @keyframes lock {\n 0% {\n transform: scale(1.5) translateY(0);\n }\n 20% {\n transform: scale(1.5) translateY(-5px);\n }\n 30% {\n transform: scale(1.5) translateY(5px);\n }\n 50% {\n transform: scale(1.5) translateY(-5px);\n }\n 60% {\n transform: scale(1.5) translateY(5px);\n }\n 100% {\n transform: scale(1.5) translateY(0);\n }\n }\n @keyframes unlock {\n 0% {\n transform: scale(1.5) rotate(-15deg);\n }\n 15% {\n transform: scale(1.5) rotate(-40deg);\n }\n 30% {\n transform: scale(1.5) rotate(5deg);\n }\n 45% {\n transform: scale(1.5) rotate(-30deg);\n }\n 60% {\n transform: scale(1.5) rotate(-5deg);\n }\n 75% {\n transform: scale(1.5) rotate(-20deg);\n }\n 90% {\n transform: scale(1.5) rotate(-15deg);\n }\n 100% {\n transform: scale(1.5) rotate(-15deg);\n }\n }\n @keyframes hourglass {\n 0% {\n transform: scale(1.5) rotate(0);\n }\n 35% {\n transform: scale(1.5) rotate(180deg);\n }\n 65% {\n transform: scale(1.5) rotate(180deg);\n }\n 100% {\n transform: scale(1.5) rotate(0);\n }\n }\n @keyframes eraser {\n 0% {\n transform: scale(1.5) translate(0, 0);\n }\n 15% {\n transform: scale(1.5) translate(-10px, -5px);\n }\n 30% {\n transform: scale(1.5) translate(-10px, 5px);\n }\n 45% {\n transform: scale(1.5) translate(-5px, -5px);\n }\n 60% {\n transform: scale(1.5) translate(-5px, 5px);\n }\n 75% {\n transform: scale(1.5) translate(0, 0);\n }\n 100% {\n transform: scale(1.5) translate(10px, 0);\n }\n }\n @keyframes rocket {\n 0% {\n transform: scale(1.5) translate(0, 0);\n opacity: 1;\n }\n 5% {\n transform: scale(1.5) translate(2px, 0);\n opacity: 1;\n }\n 10% {\n transform: scale(1.5) translate(1px, -2px);\n opacity: 1;\n }\n 15% {\n transform: scale(1.5) translate(3px, -1px);\n opacity: 1;\n }\n 20% {\n transform: scale(1.5) translate(2px, -3px);\n opacity: 1;\n }\n 25% {\n transform: scale(1.5) translate(4px, -2px);\n opacity: 1;\n }\n 50% {\n transform: scale(1.5) translate(10px, -10px);\n opacity: 0;\n }\n 51% {\n transform: scale(1.5) translate(-10px, 10px);\n opacity: 0;\n }\n 100% {\n transform: scale(1.5) translate(0, 0);\n opacity: 1;\n }\n }\n @keyframes times {\n 0% {\n transform: scale(1.5) translateX(0);\n }\n 15% {\n transform: scale(1.5) translateX(5px);\n }\n 30% {\n transform: scale(1.5) translateX(-5px);\n }\n 45% {\n transform: scale(1.5) translateX(3px);\n }\n 60% {\n transform: scale(1.5) translateX(-3px);\n }\n 75% {\n transform: scale(1.5) translateX(0);\n }\n 100% {\n transform: scale(1.5) translateX(0);\n }\n }\n}\n</style>\n","<template>\n <i\n :class=\"classes\"\n :style=\"styles\"\n v-bind=\"attributes\"\n :title=\"title\"\n @click=\"!clickable ? undefined : emit('click', $event)\"\n >\n <component :is=\"iconComponent\" aria-hidden=\"true\" />\n </i>\n</template>\n\n<script setup lang=\"ts\">\n// @ts-expect-error virtual module provided by icons vite plugin\nimport icons from 'virtual:icons'\nimport { computed } from 'vue'\nimport kebab2camel from '@/utils/kebab2camel.helper'\nimport { ESize } from '@/types/Size.d'\nimport { EAnimationMode, EWeight, EIconSize, IIconProps } from './Icon.d'\nimport { useStableId } from '@/composables/useStableId.composable'\n\nconst props = withDefaults(defineProps<IIconProps>(), {\n size: ESize.Medium,\n animation: null,\n animationMode: EAnimationMode.Always,\n color: undefined,\n weight: EWeight.Regular,\n title: undefined,\n clickable: false,\n hoverable: false,\n})\n\nconst emit = defineEmits(['click'])\n\nconst componentInternalId = useStableId(props)\n\nconst attributes = computed(() => {\n const iconSize =\n typeof props.size === 'number'\n ? props.size\n : (EIconSize as unknown as Record<string, number>)[\n String(props.size).toUpperCase()\n ] || EIconSize.MD\n\n return {\n ...{ id: componentInternalId },\n ...(props.size && {\n width: `${iconSize}px`,\n height: `${iconSize}px`,\n }),\n ...(props.clickable && { role: 'button' }),\n }\n})\n\nconst iconComponent = computed(() => {\n const iconKey = kebab2camel(`i-${props.name}`)\n const iconSet = (icons as Record<string, any>)[iconKey]\n return iconSet?.[props.weight] || iconSet?.regular\n})\n\nconst classes = computed(() => {\n return {\n 'nb-icon': true,\n ...(props.name && { [props.name]: true }),\n [`nb-icon-${props.size}`]: [\n 'xxs',\n 'xs',\n 'sm',\n 'md',\n 'lg',\n 'xl',\n 'xxl',\n ].includes(String(props.size)),\n [`nb-icon-animation-${props.animationMode}-${props.animation}`]:\n props.animation,\n hoverable:\n props.hoverable || (props.animation && props.animationMode === 'hover'),\n 'box-clickable': props.clickable,\n }\n})\n\nconst styles = computed(() => {\n return {\n ...(props.color && { color: props.color }),\n ...(typeof props.size === 'number' && {\n maxWidth: `${props.size}px`,\n maxHeight: `${props.size}px`,\n height: `${props.size}px`,\n width: `${props.size}px`,\n }),\n ...(typeof props.size === 'string' &&\n !['xxs', 'xs', 'sm', 'md', 'lg', 'xl', 'xxl'].includes(props.size) && {\n maxWidth: props.size,\n maxHeight: props.size,\n height: props.size,\n width: props.size,\n }),\n }\n})\n</script>\n\n<style lang=\"scss\" scoped>\n.nb-icon {\n display: flex;\n line-height: 1em;\n position: relative;\n &:not(.hoverable):not(.box-clickable) {\n pointer-events: none;\n }\n\n svg {\n width: 100%;\n height: 100%;\n display: block;\n }\n\n &-xxl {\n max-width: var(--nb-font-size-92);\n max-height: var(--nb-font-size-92);\n height: var(--nb-font-size-92);\n width: var(--nb-font-size-92);\n }\n &-xl {\n max-width: var(--nb-font-size-60);\n max-height: var(--nb-font-size-60);\n height: var(--nb-font-size-60);\n width: var(--nb-font-size-60);\n }\n &-lg {\n max-width: var(--nb-font-size-20);\n max-height: var(--nb-font-size-20);\n height: var(--nb-font-size-20);\n width: var(--nb-font-size-20);\n }\n &-md {\n max-width: var(--nb-font-size-16);\n max-height: var(--nb-font-size-16);\n height: var(--nb-font-size-16);\n width: var(--nb-font-size-16);\n }\n &-sm {\n max-width: var(--nb-font-size-14);\n max-height: var(--nb-font-size-14);\n height: var(--nb-font-size-14);\n width: var(--nb-font-size-14);\n }\n &-xs {\n max-width: var(--nb-font-size-12);\n max-height: var(--nb-font-size-12);\n height: var(--nb-font-size-12);\n width: var(--nb-font-size-12);\n }\n &-xxs {\n max-width: var(--nb-font-size-8);\n max-height: var(--nb-font-size-8);\n height: var(--nb-font-size-8);\n width: var(--nb-font-size-8);\n }\n\n // animations\n &-animation-hover-swing-right:hover {\n animation: swing-right 0.5s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-swing-right {\n animation: swing-right 0.5s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-wobble:hover {\n animation: wobble 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-wobble {\n animation: wobble 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-expand:hover {\n animation: expand 0.5s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-expand {\n animation: expand 0.5s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-refresh:hover {\n animation: refresh 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-refresh {\n animation: refresh 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-heart:hover {\n animation: heart 0.5s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-heart {\n animation: heart 0.5s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-undo:hover {\n animation: undo 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-undo {\n animation: undo 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-italic:hover {\n animation: italic 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-italic {\n animation: italic 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-cog:hover {\n animation: cog 5s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-cog {\n animation: cog 5s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-wrench:hover {\n transform-origin: 79% 26%;\n animation: wrench 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-wrench {\n transform-origin: 79% 26%;\n animation: wrench 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-mouse-pointer:hover {\n animation: mouse-pointer 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-mouse-pointer {\n animation: mouse-pointer 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-magic:hover {\n animation: magic 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-magic {\n animation: magic 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-lock:hover {\n animation: lock 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-lock {\n animation: lock 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-unlock:hover {\n transform-origin: 75% 25%;\n animation: unlock 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-unlock {\n transform-origin: 75% 25%;\n animation: unlock 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-hourglass:hover {\n animation: hourglass 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-hourglass {\n animation: hourglass 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-eraser:hover {\n animation: eraser 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-eraser {\n animation: eraser 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-rocket:hover {\n animation: rocket 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-rocket {\n animation: rocket 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-hover-times:hover {\n animation: times 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n &-animation-always-times {\n animation: times 1s cubic-bezier(0.36, 0.07, 0.57, 0.99) infinite;\n }\n\n @keyframes swing-right {\n 0% {\n transform: scale(1.5) translateX(0);\n }\n 33% {\n transform: scale(1.5) translateX(-5px);\n }\n 66% {\n transform: scale(1.5) translateX(5px);\n }\n 100% {\n transform: scale(1.5) translateX(0);\n }\n }\n @keyframes wobble {\n 0% {\n transform: scale(1.5) translate(0, 0);\n }\n 20% {\n transform: scale(1.5) translate(-5px, 5px);\n }\n 40% {\n transform: scale(1.5) translate(-5px, -5px);\n }\n 60% {\n transform: scale(1.5) translate(5px, 5px);\n }\n 80% {\n transform: scale(1.5) translate(5px, -5px);\n }\n 100% {\n transform: scale(1.5) translate(0, 0);\n }\n }\n @keyframes expand {\n 0% {\n transform: scale(1.5) translate(0, 0);\n }\n 25% {\n transform: scale(1.5) translate(-5px, 5px);\n }\n 50% {\n transform: scale(2) translate(0, 0);\n }\n 75% {\n transform: scale(1.5) translate(5px, -5px);\n }\n 100% {\n transform: scale(1.5) translate(0, 0);\n }\n }\n @keyframes refresh {\n from {\n transform: scale(1.5) rotate(0);\n }\n to {\n transform: scale(1.5) rotate(360deg);\n }\n }\n @keyframes heart {\n 0% {\n transform: scale(1.5);\n }\n 20% {\n transform: scale(2);\n }\n 30% {\n transform: scale(1.5);\n }\n 40% {\n transform: scale(2);\n }\n 100% {\n transform: scale(1.5);\n }\n }\n @keyframes undo {\n 0% {\n transform: scale(1.5) translateX(0) rotate(0);\n }\n 33% {\n transform: scale(1.5) translateX(10px) rotate(0);\n }\n 66% {\n transform: scale(1.5) translateX(-10px) rotate(-360deg);\n }\n 100% {\n transform: scale(1.5) translateX(0) rotate(-360deg);\n }\n }\n @keyframes italic {\n 0% {\n transform: scale(1.5) skewX(0);\n }\n 50% {\n transform: scale(1.5) skewX(12deg);\n }\n 100% {\n transform: scale(1.5) skewX(0);\n }\n }\n @keyframes cog {\n 0% {\n transform: scale(1.5) rotate(0);\n }\n 10% {\n transform: scale(1.5) rotate(45deg);\n }\n 17% {\n transform: scale(1.5) rotate(45deg);\n }\n 20% {\n transform: scale(1.5) rotate(90deg);\n }\n 27% {\n transform: scale(1.5) rotate(90deg);\n }\n 30% {\n transform: scale(1.5) rotate(135deg);\n }\n 37% {\n transform: scale(1.5) rotate(135deg);\n }\n 40% {\n transform: scale(1.5) rotate(180deg);\n }\n 47% {\n transform: scale(1.5) rotate(180deg);\n }\n 50% {\n transform: scale(1.5) rotate(225deg);\n }\n 57% {\n transform: scale(1.5) rotate(225deg);\n }\n 60% {\n transform: scale(1.5) rotate(270deg);\n }\n 67% {\n transform: scale(1.5) rotate(270deg);\n }\n 70% {\n transform: scale(1.5) rotate(315deg);\n }\n 77% {\n transform: scale(1.5) rotate(315deg);\n }\n 80% {\n transform: scale(1.5) rotate(360deg);\n }\n 100% {\n transform: scale(1.5) rotate(360deg);\n }\n }\n @keyframes wrench {\n 0% {\n transform: scale(1.5) rotate(0);\n }\n 20% {\n transform: scale(1.5) rotate(30deg);\n }\n 30% {\n transform: scale(1.5) rotate(-20deg);\n }\n 50% {\n transform: scale(1.5) rotate(30deg);\n }\n 60% {\n transform: scale(1.5) rotate(-20deg);\n }\n 100% {\n transform: scale(1.5) rotate(0);\n }\n }\n @keyframes mouse-pointer {\n 0% {\n transform: scale(1.5);\n }\n 20% {\n transform: scale(1.5);\n }\n 22.5% {\n transform: scale(1.2);\n }\n 32.5% {\n transform: scale(1.2);\n }\n 35% {\n transform: scale(1.5);\n }\n 100% {\n transform: scale(1.5);\n }\n }\n @keyframes magic {\n 0% {\n transform: scale(1.5) translate(0, 0) rotate(0);\n }\n 10% {\n transform: scale(1.5) translate(-5px, 2.5px) rotate(-10deg);\n }\n 20% {\n transform: scale(1.5) translate(-10px, 0) rotate(-20deg);\n }\n 30% {\n transform: scale(1.5) translate(-5px, -2.5px) rotate(-30deg);\n }\n 40% {\n transform: scale(1.5) translate(0, 0) rotate(-20deg);\n }\n 50% {\n transform: scale(1.5) translate(5px, 2.5px) rotate(-10deg);\n }\n 60% {\n transform: scale(1.5) translate(10px, 0) rotate(0);\n }\n 70% {\n transform: scale(1.5) translate(5px, -2.5px) rotate(10deg);\n }\n 100% {\n transform: scale(1.5) translate(0, 0) rotate(0);\n }\n }\n @keyframes lock {\n 0% {\n transform: scale(1.5) translateY(0);\n }\n 20% {\n transform: scale(1.5) translateY(-5px);\n }\n 30% {\n transform: scale(1.5) translateY(5px);\n }\n 50% {\n transform: scale(1.5) translateY(-5px);\n }\n 60% {\n transform: scale(1.5) translateY(5px);\n }\n 100% {\n transform: scale(1.5) translateY(0);\n }\n }\n @keyframes unlock {\n 0% {\n transform: scale(1.5) rotate(-15deg);\n }\n 15% {\n transform: scale(1.5) rotate(-40deg);\n }\n 30% {\n transform: scale(1.5) rotate(5deg);\n }\n 45% {\n transform: scale(1.5) rotate(-30deg);\n }\n 60% {\n transform: scale(1.5) rotate(-5deg);\n }\n 75% {\n transform: scale(1.5) rotate(-20deg);\n }\n 90% {\n transform: scale(1.5) rotate(-15deg);\n }\n 100% {\n transform: scale(1.5) rotate(-15deg);\n }\n }\n @keyframes hourglass {\n 0% {\n transform: scale(1.5) rotate(0);\n }\n 35% {\n transform: scale(1.5) rotate(180deg);\n }\n 65% {\n transform: scale(1.5) rotate(180deg);\n }\n 100% {\n transform: scale(1.5) rotate(0);\n }\n }\n @keyframes eraser {\n 0% {\n transform: scale(1.5) translate(0, 0);\n }\n 15% {\n transform: scale(1.5) translate(-10px, -5px);\n }\n 30% {\n transform: scale(1.5) translate(-10px, 5px);\n }\n 45% {\n transform: scale(1.5) translate(-5px, -5px);\n }\n 60% {\n transform: scale(1.5) translate(-5px, 5px);\n }\n 75% {\n transform: scale(1.5) translate(0, 0);\n }\n 100% {\n transform: scale(1.5) translate(10px, 0);\n }\n }\n @keyframes rocket {\n 0% {\n transform: scale(1.5) translate(0, 0);\n opacity: 1;\n }\n 5% {\n transform: scale(1.5) translate(2px, 0);\n opacity: 1;\n }\n 10% {\n transform: scale(1.5) translate(1px, -2px);\n opacity: 1;\n }\n 15% {\n transform: scale(1.5) translate(3px, -1px);\n opacity: 1;\n }\n 20% {\n transform: scale(1.5) translate(2px, -3px);\n opacity: 1;\n }\n 25% {\n transform: scale(1.5) translate(4px, -2px);\n opacity: 1;\n }\n 50% {\n transform: scale(1.5) translate(10px, -10px);\n opacity: 0;\n }\n 51% {\n transform: scale(1.5) translate(-10px, 10px);\n opacity: 0;\n }\n 100% {\n transform: scale(1.5) translate(0, 0);\n opacity: 1;\n }\n }\n @keyframes times {\n 0% {\n transform: scale(1.5) translateX(0);\n }\n 15% {\n transform: scale(1.5) translateX(5px);\n }\n 30% {\n transform: scale(1.5) translateX(-5px);\n }\n 45% {\n transform: scale(1.5) translateX(3px);\n }\n 60% {\n transform: scale(1.5) translateX(-3px);\n }\n 75% {\n transform: scale(1.5) translateX(0);\n }\n 100% {\n transform: scale(1.5) translateX(0);\n }\n }\n}\n</style>\n","<template>\n <component\n :is=\"href ? 'a' : 'button'\"\n :class=\"[\n 'nb-button',\n `nb-button--${variant}`,\n `nb-button--${size}`,\n { 'nb-button--outlined': outlined },\n { 'nb-button--loading': loading },\n { 'nb-button--icon-only': isIconOnly },\n ]\"\n :href=\"href ?? undefined\"\n :target=\"href ? target : undefined\"\n :rel=\"href ? rel : undefined\"\n :disabled=\"!href ? disabled || loading : undefined\"\n :aria-disabled=\"href && (disabled || loading) ? true : undefined\"\n :type=\"!href ? type : undefined\"\n @click=\"disabled || loading ? undefined : $emit('click', $event)\"\n >\n <slot />\n <div v-if=\"loading || icon\" class=\"nb-button__decorations\">\n <span v-if=\"loading\" class=\"nb-button__spinner\" aria-hidden=\"true\" />\n <NbIcon\n v-else-if=\"icon\"\n :name=\"icon\"\n :size=\"iconSize\"\n class=\"nb-button__icon\"\n />\n </div>\n </component>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed, useSlots } from 'vue'\nimport { ESizeShort } from '@/types/Size.d'\nimport { EButtonType, IButtonProps } from './Button.d'\nimport NbIcon from './Icon.vue'\n\nconst props = withDefaults(defineProps<IButtonProps>(), {\n variant: undefined,\n outlined: false,\n size: ESizeShort.Medium,\n disabled: false,\n loading: false,\n icon: undefined,\n type: EButtonType.Button,\n href: undefined,\n target: undefined,\n rel: undefined,\n})\n\ndefineEmits<{ click: [event: MouseEvent] }>()\n\nconst slots = useSlots()\nconst isIconOnly = computed(\n () => !slots.default && !!(props.icon || props.loading),\n)\n\nconst iconSizeMap: Record<string, number> = {\n xxs: 10,\n xs: 12,\n sm: 12,\n md: 14,\n lg: 16,\n xl: 16,\n xxl: 20,\n}\nconst iconSize = computed(() => iconSizeMap[props.size ?? 'md'] ?? 14)\n</script>\n\n<style scoped lang=\"scss\">\n.nb-button {\n display: inline-flex;\n align-items: center;\n justify-content: flex-start;\n gap: 6px;\n border: none;\n font-family: inherit;\n font-weight: 500;\n cursor: pointer;\n transition:\n background 0.15s,\n opacity 0.15s,\n box-shadow 0.15s;\n white-space: nowrap;\n outline: none;\n\n &:focus-visible {\n outline: 1px solid var(--nb-c-focus-ring);\n outline-offset: -2px;\n }\n line-height: 1;\n position: relative;\n text-decoration: none;\n background: var(--nb-c-contrast);\n color: var(--nb-c-surface);\n padding-inline: calc(var(--nb-base-unit) * 2) calc(var(--nb-base-unit) * 8);\n &--xxs {\n height: calc(var(--nb-base-unit) * 2);\n padding-block: 0;\n font-size: var(--nb-font-size-12);\n --nb-button-icon-size: var(--nb-font-size-12);\n --nb-button-padding-end: calc(var(--nb-base-unit) * 5);\n }\n &--xs {\n height: calc(var(--nb-base-unit) * 3);\n font-size: var(--nb-font-size-12);\n --nb-button-icon-size: var(--nb-font-size-12);\n --nb-button-padding-end: calc(var(--nb-base-unit) * 5);\n }\n &--sm {\n height: calc(var(--nb-base-unit) * 4);\n font-size: var(--nb-font-size-12);\n --nb-button-icon-size: var(--nb-font-size-12);\n --nb-button-padding-end: calc(var(--nb-base-unit) * 5);\n }\n &--md {\n height: calc(var(--nb-base-unit) * 5);\n font-size: var(--nb-font-size-14);\n --nb-button-icon-size: var(--nb-font-size-14);\n --nb-button-padding-end: calc(var(--nb-base-unit) * 5);\n }\n &--lg {\n height: calc(var(--nb-base-unit) * 6);\n font-size: var(--nb-font-size-14);\n --nb-button-icon-size: var(--nb-font-size-14);\n --nb-button-padding-end: calc(var(--nb-base-unit) * 5);\n }\n &--xl {\n height: calc(var(--nb-base-unit) * 8);\n padding-block: 14px;\n font-size: var(--nb-font-size-16);\n align-items: flex-start;\n --nb-button-icon-size: var(--nb-font-size-16);\n --nb-button-padding-end: calc(var(--nb-base-unit) * 6);\n .nb-button__decorations {\n padding-top: calc(var(--nb-base-unit) * 2);\n align-items: start;\n }\n }\n &--xxl {\n height: calc(var(--nb-base-unit) * 16);\n padding-block: 14px;\n font-size: var(--nb-font-size-32);\n align-items: flex-start;\n --nb-button-icon-size: var(--nb-font-size-32);\n --nb-button-padding-end: calc(var(--nb-base-unit) * 8);\n .nb-button__decorations {\n padding-top: calc(var(--nb-base-unit) * 3);\n align-items: start;\n }\n }\n\n // Icon-only: no slot content → square button, icon centered and slightly larger\n &--icon-only {\n padding: 0;\n align-items: center;\n justify-content: center;\n\n &.nb-button--xxs {\n width: 16px;\n --nb-button-icon-size: 12px;\n }\n &.nb-button--xs {\n width: 24px;\n --nb-button-icon-size: 14px;\n }\n &.nb-button--sm {\n width: 32px;\n --nb-button-icon-size: 16px;\n }\n &.nb-button--md {\n width: 40px;\n --nb-button-icon-size: 18px;\n }\n &.nb-button--lg {\n width: 48px;\n --nb-button-icon-size: 20px;\n }\n &.nb-button--xl {\n width: 48px;\n --nb-button-icon-size: 20px;\n }\n &.nb-button--xxl {\n width: 64px;\n --nb-button-icon-size: 26px;\n }\n\n .nb-button__decorations {\n inset: 0;\n width: auto;\n padding-top: 0;\n align-items: center;\n }\n }\n\n /* Primary: dark brand */\n &--primary {\n background: var(--nb-c-primary);\n color: var(--nb-c-primary-a11y);\n &:hover:not(:disabled) {\n background: var(--nb-c-primary-hover);\n color: var(--nb-c-primary-hover-a11y);\n }\n &:active:not(:disabled) {\n background: var(--nb-c-primary-active);\n color: var(--nb-c-primary-active-a11y);\n }\n &:focus-visible {\n outline-color: var(--nb-c-primary-hover-a11y);\n }\n }\n\n /* Secondary: subtle border */\n &--secondary {\n background: var(--nb-c-secondary);\n color: var(--nb-c-secondary-a11y);\n &:hover:not(:disabled) {\n background: var(--nb-c-secondary-hover);\n color: var(--nb-c-secondary-hover-a11y);\n }\n &:active:not(:disabled) {\n background: var(--nb-c-secondary-active);\n color: var(--nb-c-secondary-active-a11y);\n }\n &:focus-visible {\n outline-color: var(--nb-c-secondary-hover-a11y);\n }\n }\n\n /* Ghost: transparent */\n &--ghost {\n background: transparent;\n color: var(--nb-c-contrast);\n border-bottom: 1px solid transparent;\n padding-inline: calc(var(--nb-base-unit) * 2) calc(var(--nb-base-unit) * 2);\n --nb-button-padding-end: auto;\n &:hover:not(:disabled) {\n background: var(--nb-c-primary-hover);\n color: var(--nb-c-primary-hover-a11y);\n border-color: var(--nb-c-grape-hyacinth-200);\n }\n &:active:not(:disabled) {\n background: var(--nb-c-primary-active);\n color: var(--nb-c-primary-active-a11y);\n }\n &:focus-visible {\n outline-color: var(--nb-c-contrast);\n }\n }\n\n /* Warning: red */\n &--warning {\n background: var(--nb-c-warning);\n color: var(--nb-c-warning-a11y);\n &:hover:not(:disabled) {\n background: var(--nb-c-warning-hover);\n color: var(--nb-c-warning-hover-a11y);\n }\n &:active:not(:disabled) {\n background: var(--nb-c-warning-active);\n color: var(--nb-c-warning-active-a11y);\n }\n &:focus-visible {\n outline-color: var(--nb-c-warning-hover-a11y);\n }\n }\n\n /* Danger: red */\n &--danger {\n background: var(--nb-c-danger);\n color: var(--nb-c-danger-a11y);\n &:hover:not(:disabled) {\n background: var(--nb-c-danger-hover);\n color: var(--nb-c-danger-hover-a11y);\n }\n &:active:not(:disabled) {\n background: var(--nb-c-danger-active);\n color: var(--nb-c-danger-active-a11y);\n }\n &:focus-visible {\n outline-color: var(--nb-c-danger-hover-a11y);\n }\n }\n\n /* Success: green */\n &--success {\n background: var(--nb-c-success);\n color: var(--nb-c-success-a11y);\n &:hover:not(:disabled) {\n background: var(--nb-c-success-hover);\n color: var(--nb-c-success-hover-a11y);\n }\n &:active:not(:disabled) {\n background: var(--nb-c-success-active);\n color: var(--nb-c-success-active-a11y);\n }\n &:focus-visible {\n outline-color: var(--nb-c-success-hover-a11y);\n }\n }\n\n &--info {\n background: var(--nb-c-info);\n color: var(--nb-c-info-a11y);\n &:hover:not(:disabled) {\n background: var(--nb-c-info-hover);\n color: var(--nb-c-info-hover-a11y);\n }\n &:active:not(:disabled) {\n background: var(--nb-c-info-active);\n color: var(--nb-c-info-active-a11y);\n }\n &:focus-visible {\n outline-color: var(--nb-c-info-hover-a11y);\n }\n }\n\n &:disabled,\n &[aria-disabled='true'] {\n opacity: 0.45;\n cursor: not-allowed;\n pointer-events: none;\n &:focus-visible {\n outline-color: transparent;\n }\n }\n\n // Outlined modifier: transparent background, colored border and text\n // Applied to all variants except ghost (which has no bg by design)\n &--outlined:not(&--ghost) {\n background: transparent;\n color: var(--nb-c-contrast);\n border: 1px solid currentColor;\n }\n\n &--outlined {\n &.nb-button--primary {\n color: var(--nb-c-primary);\n &:hover:not(:disabled) {\n color: var(--nb-c-primary);\n background: color-mix(in srgb, var(--nb-c-primary) 8%, transparent);\n }\n &:active:not(:disabled) {\n background: color-mix(in srgb, var(--nb-c-primary) 14%, transparent);\n }\n &:focus-visible {\n outline-color: var(--nb-c-primary);\n }\n }\n &.nb-button--secondary {\n color: var(--nb-c-secondary);\n &:hover:not(:disabled) {\n color: var(--nb-c-secondary);\n background: color-mix(in srgb, var(--nb-c-secondary) 8%, transparent);\n }\n &:active:not(:disabled) {\n background: color-mix(in srgb, var(--nb-c-secondary) 14%, transparent);\n }\n &:focus-visible {\n outline-color: var(--nb-c-secondary);\n }\n }\n &.nb-button--danger {\n color: var(--nb-c-danger);\n &:hover:not(:disabled) {\n color: var(--nb-c-danger);\n background: color-mix(in srgb, var(--nb-c-danger) 8%, transparent);\n }\n &:active:not(:disabled) {\n background: color-mix(in srgb, var(--nb-c-danger) 14%, transparent);\n }\n &:focus-visible {\n outline-color: var(--nb-c-danger);\n }\n }\n &.nb-button--warning {\n color: var(--nb-c-warning);\n &:hover:not(:disabled) {\n color: var(--nb-c-warning);\n background: color-mix(in srgb, var(--nb-c-warning) 8%, transparent);\n }\n &:active:not(:disabled) {\n background: color-mix(in srgb, var(--nb-c-warning) 14%, transparent);\n }\n &:focus-visible {\n outline-color: var(--nb-c-warning);\n }\n }\n &.nb-button--success {\n color: var(--nb-c-success);\n &:hover:not(:disabled) {\n color: var(--nb-c-success);\n background: color-mix(in srgb, var(--nb-c-success) 8%, transparent);\n }\n &:active:not(:disabled) {\n background: color-mix(in srgb, var(--nb-c-success) 14%, transparent);\n }\n &:focus-visible {\n outline-color: var(--nb-c-success);\n }\n }\n &.nb-button--info {\n color: var(--nb-c-info);\n &:hover:not(:disabled) {\n color: var(--nb-c-info);\n background: color-mix(in srgb, var(--nb-c-info) 8%, transparent);\n }\n &:active:not(:disabled) {\n background: color-mix(in srgb, var(--nb-c-info) 14%, transparent);\n }\n &:focus-visible {\n outline-color: var(--nb-c-info);\n }\n }\n }\n\n &--loading {\n cursor: wait;\n pointer-events: none;\n }\n\n &__decorations {\n position: absolute;\n right: 0;\n top: 0;\n bottom: 0;\n width: var(--nb-button-padding-end);\n display: flex;\n align-items: center;\n justify-content: center;\n pointer-events: none;\n }\n\n &__spinner {\n width: var(--nb-button-icon-size, 14px);\n height: var(--nb-button-icon-size, 14px);\n border: 2px solid currentColor;\n border-top-color: transparent;\n border-radius: 50%;\n animation: nb-spin 0.6s linear infinite;\n }\n\n @keyframes nb-spin {\n to {\n transform: rotate(360deg);\n }\n }\n}\n</style>\n","<template>\n <component\n :is=\"href ? 'a' : 'button'\"\n :class=\"[\n 'nb-button',\n `nb-button--${variant}`,\n `nb-button--${size}`,\n { 'nb-button--outlined': outlined },\n { 'nb-button--loading': loading },\n { 'nb-button--icon-only': isIconOnly },\n ]\"\n :href=\"href ?? undefined\"\n :target=\"href ? target : undefined\"\n :rel=\"href ? rel : undefined\"\n :disabled=\"!href ? disabled || loading : undefined\"\n :aria-disabled=\"href && (disabled || loading) ? true : undefined\"\n :type=\"!href ? type : undefined\"\n @click=\"disabled || loading ? undefined : $emit('click', $event)\"\n >\n <slot />\n <div v-if=\"loading || icon\" class=\"nb-button__decorations\">\n <span v-if=\"loading\" class=\"nb-button__spinner\" aria-hidden=\"true\" />\n <NbIcon\n v-else-if=\"icon\"\n :name=\"icon\"\n :size=\"iconSize\"\n class=\"nb-button__icon\"\n />\n </div>\n </component>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed, useSlots } from 'vue'\nimport { ESizeShort } from '@/types/Size.d'\nimport { EButtonType, IButtonProps } from './Button.d'\nimport NbIcon from './Icon.vue'\n\nconst props = withDefaults(defineProps<IButtonProps>(), {\n variant: undefined,\n outlined: false,\n size: ESizeShort.Medium,\n disabled: false,\n loading: false,\n icon: undefined,\n type: EButtonType.Button,\n href: undefined,\n target: undefined,\n rel: undefined,\n})\n\ndefineEmits<{ click: [event: MouseEvent] }>()\n\nconst slots = useSlots()\nconst isIconOnly = computed(\n () => !slots.default && !!(props.icon || props.loading),\n)\n\nconst iconSizeMap: Record<string, number> = {\n xxs: 10,\n xs: 12,\n sm: 12,\n md: 14,\n lg: 16,\n xl: 16,\n xxl: 20,\n}\nconst iconSize = computed(() => iconSizeMap[props.size ?? 'md'] ?? 14)\n</script>\n\n<style scoped lang=\"scss\">\n.nb-button {\n display: inline-flex;\n align-items: center;\n justify-content: flex-start;\n gap: 6px;\n border: none;\n font-family: inherit;\n font-weight: 500;\n cursor: pointer;\n transition:\n background 0.15s,\n opacity 0.15s,\n box-shadow 0.15s;\n white-space: nowrap;\n outline: none;\n\n &:focus-visible {\n outline: 1px solid var(--nb-c-focus-ring);\n outline-offset: -2px;\n }\n line-height: 1;\n position: relative;\n text-decoration: none;\n background: var(--nb-c-contrast);\n color: var(--nb-c-surface);\n padding-inline: calc(var(--nb-base-unit) * 2) calc(var(--nb-base-unit) * 8);\n &--xxs {\n height: calc(var(--nb-base-unit) * 2);\n padding-block: 0;\n font-size: var(--nb-font-size-12);\n --nb-button-icon-size: var(--nb-font-size-12);\n --nb-button-padding-end: calc(var(--nb-base-unit) * 5);\n }\n &--xs {\n height: calc(var(--nb-base-unit) * 3);\n font-size: var(--nb-font-size-12);\n --nb-button-icon-size: var(--nb-font-size-12);\n --nb-button-padding-end: calc(var(--nb-base-unit) * 5);\n }\n &--sm {\n height: calc(var(--nb-base-unit) * 4);\n font-size: var(--nb-font-size-12);\n --nb-button-icon-size: var(--nb-font-size-12);\n --nb-button-padding-end: calc(var(--nb-base-unit) * 5);\n }\n &--md {\n height: calc(var(--nb-base-unit) * 5);\n font-size: var(--nb-font-size-14);\n --nb-button-icon-size: var(--nb-font-size-14);\n --nb-button-padding-end: calc(var(--nb-base-unit) * 5);\n }\n &--lg {\n height: calc(var(--nb-base-unit) * 6);\n font-size: var(--nb-font-size-14);\n --nb-button-icon-size: var(--nb-font-size-14);\n --nb-button-padding-end: calc(var(--nb-base-unit) * 5);\n }\n &--xl {\n height: calc(var(--nb-base-unit) * 8);\n padding-block: 14px;\n font-size: var(--nb-font-size-16);\n align-items: flex-start;\n --nb-button-icon-size: var(--nb-font-size-16);\n --nb-button-padding-end: calc(var(--nb-base-unit) * 6);\n .nb-button__decorations {\n padding-top: calc(var(--nb-base-unit) * 2);\n align-items: start;\n }\n }\n &--xxl {\n height: calc(var(--nb-base-unit) * 16);\n padding-block: 14px;\n font-size: var(--nb-font-size-32);\n align-items: flex-start;\n --nb-button-icon-size: var(--nb-font-size-32);\n --nb-button-padding-end: calc(var(--nb-base-unit) * 8);\n .nb-button__decorations {\n padding-top: calc(var(--nb-base-unit) * 3);\n align-items: start;\n }\n }\n\n // Icon-only: no slot content → square button, icon centered and slightly larger\n &--icon-only {\n padding: 0;\n align-items: center;\n justify-content: center;\n\n &.nb-button--xxs {\n width: 16px;\n --nb-button-icon-size: 12px;\n }\n &.nb-button--xs {\n width: 24px;\n --nb-button-icon-size: 14px;\n }\n &.nb-button--sm {\n width: 32px;\n --nb-button-icon-size: 16px;\n }\n &.nb-button--md {\n width: 40px;\n --nb-button-icon-size: 18px;\n }\n &.nb-button--lg {\n width: 48px;\n --nb-button-icon-size: 20px;\n }\n &.nb-button--xl {\n width: 48px;\n --nb-button-icon-size: 20px;\n }\n &.nb-button--xxl {\n width: 64px;\n --nb-button-icon-size: 26px;\n }\n\n .nb-button__decorations {\n inset: 0;\n width: auto;\n padding-top: 0;\n align-items: center;\n }\n }\n\n /* Primary: dark brand */\n &--primary {\n background: var(--nb-c-primary);\n color: var(--nb-c-primary-a11y);\n &:hover:not(:disabled) {\n background: var(--nb-c-primary-hover);\n color: var(--nb-c-primary-hover-a11y);\n }\n &:active:not(:disabled) {\n background: var(--nb-c-primary-active);\n color: var(--nb-c-primary-active-a11y);\n }\n &:focus-visible {\n outline-color: var(--nb-c-primary-hover-a11y);\n }\n }\n\n /* Secondary: subtle border */\n &--secondary {\n background: var(--nb-c-secondary);\n color: var(--nb-c-secondary-a11y);\n &:hover:not(:disabled) {\n background: var(--nb-c-secondary-hover);\n color: var(--nb-c-secondary-hover-a11y);\n }\n &:active:not(:disabled) {\n background: var(--nb-c-secondary-active);\n color: var(--nb-c-secondary-active-a11y);\n }\n &:focus-visible {\n outline-color: var(--nb-c-secondary-hover-a11y);\n }\n }\n\n /* Ghost: transparent */\n &--ghost {\n background: transparent;\n color: var(--nb-c-contrast);\n border-bottom: 1px solid transparent;\n padding-inline: calc(var(--nb-base-unit) * 2) calc(var(--nb-base-unit) * 2);\n --nb-button-padding-end: auto;\n &:hover:not(:disabled) {\n background: var(--nb-c-primary-hover);\n color: var(--nb-c-primary-hover-a11y);\n border-color: var(--nb-c-grape-hyacinth-200);\n }\n &:active:not(:disabled) {\n background: var(--nb-c-primary-active);\n color: var(--nb-c-primary-active-a11y);\n }\n &:focus-visible {\n outline-color: var(--nb-c-contrast);\n }\n }\n\n /* Warning: red */\n &--warning {\n background: var(--nb-c-warning);\n color: var(--nb-c-warning-a11y);\n &:hover:not(:disabled) {\n background: var(--nb-c-warning-hover);\n color: var(--nb-c-warning-hover-a11y);\n }\n &:active:not(:disabled) {\n background: var(--nb-c-warning-active);\n color: var(--nb-c-warning-active-a11y);\n }\n &:focus-visible {\n outline-color: var(--nb-c-warning-hover-a11y);\n }\n }\n\n /* Danger: red */\n &--danger {\n background: var(--nb-c-danger);\n color: var(--nb-c-danger-a11y);\n &:hover:not(:disabled) {\n background: var(--nb-c-danger-hover);\n color: var(--nb-c-danger-hover-a11y);\n }\n &:active:not(:disabled) {\n background: var(--nb-c-danger-active);\n color: var(--nb-c-danger-active-a11y);\n }\n &:focus-visible {\n outline-color: var(--nb-c-danger-hover-a11y);\n }\n }\n\n /* Success: green */\n &--success {\n background: var(--nb-c-success);\n color: var(--nb-c-success-a11y);\n &:hover:not(:disabled) {\n background: var(--nb-c-success-hover);\n color: var(--nb-c-success-hover-a11y);\n }\n &:active:not(:disabled) {\n background: var(--nb-c-success-active);\n color: var(--nb-c-success-active-a11y);\n }\n &:focus-visible {\n outline-color: var(--nb-c-success-hover-a11y);\n }\n }\n\n &--info {\n background: var(--nb-c-info);\n color: var(--nb-c-info-a11y);\n &:hover:not(:disabled) {\n background: var(--nb-c-info-hover);\n color: var(--nb-c-info-hover-a11y);\n }\n &:active:not(:disabled) {\n background: var(--nb-c-info-active);\n color: var(--nb-c-info-active-a11y);\n }\n &:focus-visible {\n outline-color: var(--nb-c-info-hover-a11y);\n }\n }\n\n &:disabled,\n &[aria-disabled='true'] {\n opacity: 0.45;\n cursor: not-allowed;\n pointer-events: none;\n &:focus-visible {\n outline-color: transparent;\n }\n }\n\n // Outlined modifier: transparent background, colored border and text\n // Applied to all variants except ghost (which has no bg by design)\n &--outlined:not(&--ghost) {\n background: transparent;\n color: var(--nb-c-contrast);\n border: 1px solid currentColor;\n }\n\n &--outlined {\n &.nb-button--primary {\n color: var(--nb-c-primary);\n &:hover:not(:disabled) {\n color: var(--nb-c-primary);\n background: color-mix(in srgb, var(--nb-c-primary) 8%, transparent);\n }\n &:active:not(:disabled) {\n background: color-mix(in srgb, var(--nb-c-primary) 14%, transparent);\n }\n &:focus-visible {\n outline-color: var(--nb-c-primary);\n }\n }\n &.nb-button--secondary {\n color: var(--nb-c-secondary);\n &:hover:not(:disabled) {\n color: var(--nb-c-secondary);\n background: color-mix(in srgb, var(--nb-c-secondary) 8%, transparent);\n }\n &:active:not(:disabled) {\n background: color-mix(in srgb, var(--nb-c-secondary) 14%, transparent);\n }\n &:focus-visible {\n outline-color: var(--nb-c-secondary);\n }\n }\n &.nb-button--danger {\n color: var(--nb-c-danger);\n &:hover:not(:disabled) {\n color: var(--nb-c-danger);\n background: color-mix(in srgb, var(--nb-c-danger) 8%, transparent);\n }\n &:active:not(:disabled) {\n background: color-mix(in srgb, var(--nb-c-danger) 14%, transparent);\n }\n &:focus-visible {\n outline-color: var(--nb-c-danger);\n }\n }\n &.nb-button--warning {\n color: var(--nb-c-warning);\n &:hover:not(:disabled) {\n color: var(--nb-c-warning);\n background: color-mix(in srgb, var(--nb-c-warning) 8%, transparent);\n }\n &:active:not(:disabled) {\n background: color-mix(in srgb, var(--nb-c-warning) 14%, transparent);\n }\n &:focus-visible {\n outline-color: var(--nb-c-warning);\n }\n }\n &.nb-button--success {\n color: var(--nb-c-success);\n &:hover:not(:disabled) {\n color: var(--nb-c-success);\n background: color-mix(in srgb, var(--nb-c-success) 8%, transparent);\n }\n &:active:not(:disabled) {\n background: color-mix(in srgb, var(--nb-c-success) 14%, transparent);\n }\n &:focus-visible {\n outline-color: var(--nb-c-success);\n }\n }\n &.nb-button--info {\n color: var(--nb-c-info);\n &:hover:not(:disabled) {\n color: var(--nb-c-info);\n background: color-mix(in srgb, var(--nb-c-info) 8%, transparent);\n }\n &:active:not(:disabled) {\n background: color-mix(in srgb, var(--nb-c-info) 14%, transparent);\n }\n &:focus-visible {\n outline-color: var(--nb-c-info);\n }\n }\n }\n\n &--loading {\n cursor: wait;\n pointer-events: none;\n }\n\n &__decorations {\n position: absolute;\n right: 0;\n top: 0;\n bottom: 0;\n width: var(--nb-button-padding-end);\n display: flex;\n align-items: center;\n justify-content: center;\n pointer-events: none;\n }\n\n &__spinner {\n width: var(--nb-button-icon-size, 14px);\n height: var(--nb-button-icon-size, 14px);\n border: 2px solid currentColor;\n border-top-color: transparent;\n border-radius: 50%;\n animation: nb-spin 0.6s linear infinite;\n }\n\n @keyframes nb-spin {\n to {\n transform: rotate(360deg);\n }\n }\n}\n</style>\n","<template>\n <label :class=\"['nb-checkbox', { 'nb-checkbox--disabled': disabled }]\">\n <span class=\"nb-checkbox__control\">\n <input\n type=\"checkbox\"\n :checked=\"modelValue\"\n :disabled=\"disabled\"\n :indeterminate=\"indeterminate\"\n class=\"nb-checkbox__input\"\n @change=\"handleChange\"\n />\n <span class=\"nb-checkbox__box\">\n <svg\n v-if=\"modelValue && !indeterminate\"\n class=\"nb-checkbox__check\"\n viewBox=\"0 0 10 8\"\n fill=\"none\"\n >\n <path\n d=\"M1 4l3 3 5-6\"\n stroke=\"currentColor\"\n stroke-width=\"1.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n />\n </svg>\n <span v-if=\"indeterminate\" class=\"nb-checkbox__dash\" />\n </span>\n </span>\n <span v-if=\"label\" class=\"nb-checkbox__label\">{{ label }}</span>\n <slot v-else />\n </label>\n</template>\n\n<script setup lang=\"ts\">\nimport { ICheckboxProps } from './Checkbox.d'\n\nconst props = withDefaults(defineProps<ICheckboxProps>(), {\n id: 'checkbox',\n modelValue: false,\n disabled: false,\n indeterminate: false,\n})\n\nconst emit = defineEmits<{ 'update:modelValue': [value: boolean] }>()\n\nfunction handleChange(e: Event) {\n if (!props.disabled) {\n emit('update:modelValue', (e.target as HTMLInputElement).checked)\n }\n}\n</script>\n\n<style scoped lang=\"scss\">\n.nb-checkbox {\n display: inline-flex;\n align-items: center;\n gap: 8px;\n cursor: pointer;\n user-select: none;\n\n &--disabled {\n opacity: 0.5;\n cursor: not-allowed;\n }\n\n &__control {\n position: relative;\n flex-shrink: 0;\n }\n\n &__input {\n position: absolute;\n opacity: 0;\n width: 0;\n height: 0;\n pointer-events: none;\n }\n\n &__box {\n display: flex;\n align-items: center;\n justify-content: center;\n width: 16px;\n height: 16px;\n border: 1.5px solid var(--nb-c-border, #d0d0d0);\n border-radius: 4px;\n transition:\n background 0.15s,\n border-color 0.15s,\n box-shadow 0.15s;\n color: #fff;\n }\n\n &__check {\n width: 10px;\n height: 8px;\n }\n\n &__dash {\n width: 8px;\n height: 1.5px;\n background: currentColor;\n border-radius: 1px;\n }\n\n &__label {\n font-size: 13px;\n color: var(--nb-c-text, #1a1a2e);\n line-height: 1.4;\n }\n\n /* Checked / indeterminate state */\n &__input:checked ~ &__box,\n &__input:indeterminate ~ &__box {\n background: var(--nb-c-grape-hyacinth-500, #5856a9);\n border-color: var(--nb-c-grape-hyacinth-500, #5856a9);\n }\n\n /* Focus ring */\n &__input:focus-visible ~ &__box {\n box-shadow: 0 0 0 3px var(--nb-c-grape-hyacinth-200, #d6d5f2);\n }\n\n &:hover:not(.nb-checkbox--disabled) &__box {\n border-color: var(--nb-c-grape-hyacinth-400, #7b79c0);\n }\n}\n</style>\n","<template>\n <label :class=\"['nb-checkbox', { 'nb-checkbox--disabled': disabled }]\">\n <span class=\"nb-checkbox__control\">\n <input\n type=\"checkbox\"\n :checked=\"modelValue\"\n :disabled=\"disabled\"\n :indeterminate=\"indeterminate\"\n class=\"nb-checkbox__input\"\n @change=\"handleChange\"\n />\n <span class=\"nb-checkbox__box\">\n <svg\n v-if=\"modelValue && !indeterminate\"\n class=\"nb-checkbox__check\"\n viewBox=\"0 0 10 8\"\n fill=\"none\"\n >\n <path\n d=\"M1 4l3 3 5-6\"\n stroke=\"currentColor\"\n stroke-width=\"1.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n />\n </svg>\n <span v-if=\"indeterminate\" class=\"nb-checkbox__dash\" />\n </span>\n </span>\n <span v-if=\"label\" class=\"nb-checkbox__label\">{{ label }}</span>\n <slot v-else />\n </label>\n</template>\n\n<script setup lang=\"ts\">\nimport { ICheckboxProps } from './Checkbox.d'\n\nconst props = withDefaults(defineProps<ICheckboxProps>(), {\n id: 'checkbox',\n modelValue: false,\n disabled: false,\n indeterminate: false,\n})\n\nconst emit = defineEmits<{ 'update:modelValue': [value: boolean] }>()\n\nfunction handleChange(e: Event) {\n if (!props.disabled) {\n emit('update:modelValue', (e.target as HTMLInputElement).checked)\n }\n}\n</script>\n\n<style scoped lang=\"scss\">\n.nb-checkbox {\n display: inline-flex;\n align-items: center;\n gap: 8px;\n cursor: pointer;\n user-select: none;\n\n &--disabled {\n opacity: 0.5;\n cursor: not-allowed;\n }\n\n &__control {\n position: relative;\n flex-shrink: 0;\n }\n\n &__input {\n position: absolute;\n opacity: 0;\n width: 0;\n height: 0;\n pointer-events: none;\n }\n\n &__box {\n display: flex;\n align-items: center;\n justify-content: center;\n width: 16px;\n height: 16px;\n border: 1.5px solid var(--nb-c-border, #d0d0d0);\n border-radius: 4px;\n transition:\n background 0.15s,\n border-color 0.15s,\n box-shadow 0.15s;\n color: #fff;\n }\n\n &__check {\n width: 10px;\n height: 8px;\n }\n\n &__dash {\n width: 8px;\n height: 1.5px;\n background: currentColor;\n border-radius: 1px;\n }\n\n &__label {\n font-size: 13px;\n color: var(--nb-c-text, #1a1a2e);\n line-height: 1.4;\n }\n\n /* Checked / indeterminate state */\n &__input:checked ~ &__box,\n &__input:indeterminate ~ &__box {\n background: var(--nb-c-grape-hyacinth-500, #5856a9);\n border-color: var(--nb-c-grape-hyacinth-500, #5856a9);\n }\n\n /* Focus ring */\n &__input:focus-visible ~ &__box {\n box-shadow: 0 0 0 3px var(--nb-c-grape-hyacinth-200, #d6d5f2);\n }\n\n &:hover:not(.nb-checkbox--disabled) &__box {\n border-color: var(--nb-c-grape-hyacinth-400, #7b79c0);\n }\n}\n</style>\n","<template>\n <div\n :class=\"['nb-color-strip-wrapper', `nb-color-strip-wrapper--${variant}`]\"\n >\n <!-- DEFAULT variant: label above via NbLabel -->\n <template v-if=\"variant === 'default'\">\n <slot v-if=\"$slots.label\" name=\"label\" />\n <NbLabel v-else-if=\"label\" :for=\"colorStripId\" :disabled=\"false\">\n {{ label }}\n </NbLabel>\n </template>\n\n <!-- FLUID variant: label inside the field box -->\n <div\n v-if=\"variant === 'fluid' && (label || $slots.label)\"\n class=\"nb-color-strip-wrapper__inner-header\"\n >\n <slot v-if=\"$slots.label\" name=\"label\" />\n <label v-else class=\"nb-color-strip-wrapper__inner-label\">{{\n label\n }}</label>\n </div>\n\n <!-- Strip (always rendered) -->\n <NbGrid\n :id=\"colorStripId\"\n dir=\"row\"\n gap=\"xs\"\n :class=\"classes\"\n :shrink=\"false\"\n :style=\"stripStyle\"\n >\n <NbGrid\n is=\"button\"\n v-for=\"option in optionsToRender\"\n :key=\"`option-${option.id || option.value}`\"\n align=\"center\"\n justify=\"center\"\n :class=\"buttonClasses(option)\"\n :style=\"buttonStyle(option)\"\n :disabled=\"option.disabled\"\n @click=\"!onlyView && selectOption(option.value)\"\n >\n <NbIcon\n v-if=\"!onlyView && isSelected(option.value) && !isNullOption(option)\"\n name=\"check-light\"\n :color=\"getContrastingColor(option)\"\n />\n <NbIcon\n v-if=\"isNullOption(option)\"\n name=\"empty\"\n :weight=\"getNullOptionWeight(option)\"\n />\n </NbGrid>\n </NbGrid>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed, ref, watch } from 'vue'\nimport { useId } from 'vue'\nimport { IColorStripProps, IOption } from './ColorStrip'\n\nconst props = withDefaults(defineProps<IColorStripProps>(), {\n options: () => ['#DCDCDC', '#C0C0C0', '#808080'],\n onlyView: false,\n allowMultiple: false,\n wrap: false,\n showNull: false,\n label: undefined,\n id: undefined,\n variant: 'default',\n})\n\nconst autoId = `nb-color-strip-${useId()}`\nconst colorStripId = computed(() => props.id ?? autoId)\n\nconst model = defineModel<any>({\n set: (val) => val,\n})\n\nconst normalizedOptions = computed<IOption[]>(() => {\n return props.options.map((item) => {\n if (typeof item === 'string') {\n return {\n value: item,\n color: item,\n }\n } else {\n return {\n ...item,\n color: item.color || '#FFFFFF',\n value: item.value !== undefined ? item.value : item.color,\n }\n }\n })\n})\n\nconst nullOption: IOption = {\n id: 'null-option',\n value: null as unknown as string | number,\n color: 'transparent',\n label: 'None',\n}\n\nconst hasNullState = ref(model.value == null)\n\nwatch(\n () => model.value,\n (value) => {\n if (value == null) {\n hasNullState.value = true\n }\n },\n)\n\nconst shouldShowNullOption = computed(() => {\n if (props.allowMultiple) return false\n\n return props.showNull || hasNullState.value\n})\n\nconst optionsToRender = computed<IOption[]>(() => {\n if (shouldShowNullOption.value) {\n return [nullOption, ...normalizedOptions.value]\n }\n\n return normalizedOptions.value\n})\n\nconst COLOR_DIAMETER_PX = 30\nconst WRAP_GAP_PX = 8\n\nconst stripStyle = computed(() => {\n if (!props.wrap) {\n return {\n maxWidth: 'none',\n flexWrap: 'nowrap',\n }\n }\n\n const colorCount = optionsToRender.value.length\n if (colorCount <= 0) return undefined\n\n const columns = Math.ceil(Math.sqrt(colorCount))\n const maxWidth = columns * COLOR_DIAMETER_PX + (columns - 1) * WRAP_GAP_PX\n\n return {\n maxWidth: `${maxWidth}px`,\n flexWrap: 'wrap',\n }\n})\n\nconst classes = computed(() => ({\n 'nb-color-strip': true,\n 'only-view': props.onlyView,\n}))\n\nconst isSelected = (value: string | number | null | undefined) => {\n if (props.onlyView) return false\n\n if (value === null) {\n return model.value == null\n }\n\n if (value === undefined) return false\n\n if (props.allowMultiple) {\n return Array.isArray(model.value) && model.value.includes(value)\n } else {\n return model.value === value\n }\n}\n\nconst buttonClasses = (option: IOption) => ({\n 'nb-color-strip-color': true,\n 'nb-color-strip-color-null': isNullOption(option),\n selected: !props.onlyView && isSelected(option.value),\n})\n\nconst buttonStyle = (option: IOption) => {\n if (isNullOption(option)) return undefined\n\n return {\n backgroundColor: option.color,\n }\n}\n\nconst isNullOption = (option: IOption) => option.id === 'null-option'\n\nconst getNullOptionWeight = (option: IOption): any => {\n return isSelected(option.value) ? 'duotone' : 'regular'\n}\n\nconst selectOption = (value: string | number | null | undefined) => {\n if (value === undefined) return\n\n if (!props.allowMultiple && value === null) {\n model.value = null\n return\n }\n\n if (props.allowMultiple) {\n const current = Array.isArray(model.value) ? model.value.slice() : []\n const index = current.indexOf(value)\n if (index !== -1) {\n current.splice(index, 1)\n } else {\n current.push(value)\n }\n model.value = current\n } else {\n model.value = value\n }\n}\n\n// Utility function to get contrast color\nfunction getContrastingColor(option: string | IOption): string {\n const color = typeof option === 'string' ? option : option.color\n const resolvedColor =\n color && color.startsWith('var(')\n ? getComputedStyle(document.documentElement)\n .getPropertyValue(color.slice(4, -1).trim())\n .trim()\n : color\n\n const { r, g, b } = hexToRgb(resolvedColor || '#FFFFFF')\n // Calculate luminance according to WCAG\n const luminance = (0.299 * r + 0.587 * g + 0.114 * b) / 255\n return luminance > 0.5 ? 'black' : 'white'\n}\n\nfunction hexToRgb(hex: string) {\n let cleanHex = hex.replace('#', '')\n if (cleanHex.length === 3) {\n cleanHex = cleanHex\n .split('')\n .map((c) => c + c)\n .join('')\n }\n const num = parseInt(cleanHex, 16)\n return {\n r: (num >> 16) & 255,\n g: (num >> 8) & 255,\n b: num & 255,\n }\n}\n</script>\n\n<style lang=\"scss\" scoped>\n$nb-color-diameter: 30px;\n\n.nb-color-strip-wrapper {\n display: flex;\n flex-direction: column;\n gap: 4px;\n\n // ── Fluid variant ──────────────────────────────────────────────────────────\n &--fluid {\n justify-content: space-between;\n gap: 0;\n background: var(--nb-c-field-bg);\n border-bottom: 1px solid var(--nb-c-field-border);\n padding-top: 8px;\n min-height: calc(var(--nb-base-unit) * 8);\n\n .nb-color-strip {\n padding: 0 var(--nb-field-padding-h) 6px;\n }\n }\n}\n\n// ── Fluid inner header ────────────────────────────────────────────────────────\n.nb-color-strip-wrapper__inner-header {\n display: flex;\n align-items: center;\n padding: 0 var(--nb-field-padding-h);\n margin-bottom: 4px;\n}\n\n.nb-color-strip-wrapper__inner-label {\n flex: 1;\n min-width: 0;\n font-family: var(--nb-font-family-sans);\n font-size: var(--nb-font-size-12);\n font-weight: 500;\n color: var(--nb-c-text-muted);\n letter-spacing: 0.02em;\n cursor: default;\n user-select: none;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n\n// ── Strip ─────────────────────────────────────────────────────────────────────\n.nb-color-strip {\n display: flex;\n flex-wrap: wrap;\n max-width: calc(#{$nb-color-diameter} * 8 + 8px * 7);\n\n :deep(button) {\n position: relative;\n width: $nb-color-diameter;\n height: $nb-color-diameter;\n border: 1px solid transparent;\n cursor: pointer;\n padding: 0;\n transition:\n border 0.2s,\n box-shadow 0.2s;\n\n &:disabled {\n cursor: not-allowed;\n opacity: 0.6;\n }\n\n &:focus,\n &:focus-visible,\n &.selected {\n border: 1px solid var(--nb-c-surface);\n outline: 0;\n\n &:before {\n content: '';\n position: absolute;\n top: calc(var(--nb-base-unit) / -2);\n left: calc(var(--nb-base-unit) / -2);\n right: calc(var(--nb-base-unit) / -2);\n bottom: calc(var(--nb-base-unit) / -2);\n border: 2px solid var(--nb-c-primary);\n }\n }\n\n &.nb-color-strip-color-null {\n border-color: var(--nb-c-primary);\n color: var(--nb-c-primary);\n }\n }\n}\n\n.only-view {\n :deep(button) {\n cursor: initial;\n\n &:focus,\n &:focus-visible,\n &.selected {\n border-color: transparent;\n outline: initial;\n\n &:before {\n content: none;\n }\n }\n }\n}\n</style>\n","<template>\n <div\n :class=\"['nb-color-strip-wrapper', `nb-color-strip-wrapper--${variant}`]\"\n >\n <!-- DEFAULT variant: label above via NbLabel -->\n <template v-if=\"variant === 'default'\">\n <slot v-if=\"$slots.label\" name=\"label\" />\n <NbLabel v-else-if=\"label\" :for=\"colorStripId\" :disabled=\"false\">\n {{ label }}\n </NbLabel>\n </template>\n\n <!-- FLUID variant: label inside the field box -->\n <div\n v-if=\"variant === 'fluid' && (label || $slots.label)\"\n class=\"nb-color-strip-wrapper__inner-header\"\n >\n <slot v-if=\"$slots.label\" name=\"label\" />\n <label v-else class=\"nb-color-strip-wrapper__inner-label\">{{\n label\n }}</label>\n </div>\n\n <!-- Strip (always rendered) -->\n <NbGrid\n :id=\"colorStripId\"\n dir=\"row\"\n gap=\"xs\"\n :class=\"classes\"\n :shrink=\"false\"\n :style=\"stripStyle\"\n >\n <NbGrid\n is=\"button\"\n v-for=\"option in optionsToRender\"\n :key=\"`option-${option.id || option.value}`\"\n align=\"center\"\n justify=\"center\"\n :class=\"buttonClasses(option)\"\n :style=\"buttonStyle(option)\"\n :disabled=\"option.disabled\"\n @click=\"!onlyView && selectOption(option.value)\"\n >\n <NbIcon\n v-if=\"!onlyView && isSelected(option.value) && !isNullOption(option)\"\n name=\"check-light\"\n :color=\"getContrastingColor(option)\"\n />\n <NbIcon\n v-if=\"isNullOption(option)\"\n name=\"empty\"\n :weight=\"getNullOptionWeight(option)\"\n />\n </NbGrid>\n </NbGrid>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed, ref, watch } from 'vue'\nimport { useId } from 'vue'\nimport { IColorStripProps, IOption } from './ColorStrip'\n\nconst props = withDefaults(defineProps<IColorStripProps>(), {\n options: () => ['#DCDCDC', '#C0C0C0', '#808080'],\n onlyView: false,\n allowMultiple: false,\n wrap: false,\n showNull: false,\n label: undefined,\n id: undefined,\n variant: 'default',\n})\n\nconst autoId = `nb-color-strip-${useId()}`\nconst colorStripId = computed(() => props.id ?? autoId)\n\nconst model = defineModel<any>({\n set: (val) => val,\n})\n\nconst normalizedOptions = computed<IOption[]>(() => {\n return props.options.map((item) => {\n if (typeof item === 'string') {\n return {\n value: item,\n color: item,\n }\n } else {\n return {\n ...item,\n color: item.color || '#FFFFFF',\n value: item.value !== undefined ? item.value : item.color,\n }\n }\n })\n})\n\nconst nullOption: IOption = {\n id: 'null-option',\n value: null as unknown as string | number,\n color: 'transparent',\n label: 'None',\n}\n\nconst hasNullState = ref(model.value == null)\n\nwatch(\n () => model.value,\n (value) => {\n if (value == null) {\n hasNullState.value = true\n }\n },\n)\n\nconst shouldShowNullOption = computed(() => {\n if (props.allowMultiple) return false\n\n return props.showNull || hasNullState.value\n})\n\nconst optionsToRender = computed<IOption[]>(() => {\n if (shouldShowNullOption.value) {\n return [nullOption, ...normalizedOptions.value]\n }\n\n return normalizedOptions.value\n})\n\nconst COLOR_DIAMETER_PX = 30\nconst WRAP_GAP_PX = 8\n\nconst stripStyle = computed(() => {\n if (!props.wrap) {\n return {\n maxWidth: 'none',\n flexWrap: 'nowrap',\n }\n }\n\n const colorCount = optionsToRender.value.length\n if (colorCount <= 0) return undefined\n\n const columns = Math.ceil(Math.sqrt(colorCount))\n const maxWidth = columns * COLOR_DIAMETER_PX + (columns - 1) * WRAP_GAP_PX\n\n return {\n maxWidth: `${maxWidth}px`,\n flexWrap: 'wrap',\n }\n})\n\nconst classes = computed(() => ({\n 'nb-color-strip': true,\n 'only-view': props.onlyView,\n}))\n\nconst isSelected = (value: string | number | null | undefined) => {\n if (props.onlyView) return false\n\n if (value === null) {\n return model.value == null\n }\n\n if (value === undefined) return false\n\n if (props.allowMultiple) {\n return Array.isArray(model.value) && model.value.includes(value)\n } else {\n return model.value === value\n }\n}\n\nconst buttonClasses = (option: IOption) => ({\n 'nb-color-strip-color': true,\n 'nb-color-strip-color-null': isNullOption(option),\n selected: !props.onlyView && isSelected(option.value),\n})\n\nconst buttonStyle = (option: IOption) => {\n if (isNullOption(option)) return undefined\n\n return {\n backgroundColor: option.color,\n }\n}\n\nconst isNullOption = (option: IOption) => option.id === 'null-option'\n\nconst getNullOptionWeight = (option: IOption): any => {\n return isSelected(option.value) ? 'duotone' : 'regular'\n}\n\nconst selectOption = (value: string | number | null | undefined) => {\n if (value === undefined) return\n\n if (!props.allowMultiple && value === null) {\n model.value = null\n return\n }\n\n if (props.allowMultiple) {\n const current = Array.isArray(model.value) ? model.value.slice() : []\n const index = current.indexOf(value)\n if (index !== -1) {\n current.splice(index, 1)\n } else {\n current.push(value)\n }\n model.value = current\n } else {\n model.value = value\n }\n}\n\n// Utility function to get contrast color\nfunction getContrastingColor(option: string | IOption): string {\n const color = typeof option === 'string' ? option : option.color\n const resolvedColor =\n color && color.startsWith('var(')\n ? getComputedStyle(document.documentElement)\n .getPropertyValue(color.slice(4, -1).trim())\n .trim()\n : color\n\n const { r, g, b } = hexToRgb(resolvedColor || '#FFFFFF')\n // Calculate luminance according to WCAG\n const luminance = (0.299 * r + 0.587 * g + 0.114 * b) / 255\n return luminance > 0.5 ? 'black' : 'white'\n}\n\nfunction hexToRgb(hex: string) {\n let cleanHex = hex.replace('#', '')\n if (cleanHex.length === 3) {\n cleanHex = cleanHex\n .split('')\n .map((c) => c + c)\n .join('')\n }\n const num = parseInt(cleanHex, 16)\n return {\n r: (num >> 16) & 255,\n g: (num >> 8) & 255,\n b: num & 255,\n }\n}\n</script>\n\n<style lang=\"scss\" scoped>\n$nb-color-diameter: 30px;\n\n.nb-color-strip-wrapper {\n display: flex;\n flex-direction: column;\n gap: 4px;\n\n // ── Fluid variant ──────────────────────────────────────────────────────────\n &--fluid {\n justify-content: space-between;\n gap: 0;\n background: var(--nb-c-field-bg);\n border-bottom: 1px solid var(--nb-c-field-border);\n padding-top: 8px;\n min-height: calc(var(--nb-base-unit) * 8);\n\n .nb-color-strip {\n padding: 0 var(--nb-field-padding-h) 6px;\n }\n }\n}\n\n// ── Fluid inner header ────────────────────────────────────────────────────────\n.nb-color-strip-wrapper__inner-header {\n display: flex;\n align-items: center;\n padding: 0 var(--nb-field-padding-h);\n margin-bottom: 4px;\n}\n\n.nb-color-strip-wrapper__inner-label {\n flex: 1;\n min-width: 0;\n font-family: var(--nb-font-family-sans);\n font-size: var(--nb-font-size-12);\n font-weight: 500;\n color: var(--nb-c-text-muted);\n letter-spacing: 0.02em;\n cursor: default;\n user-select: none;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n\n// ── Strip ─────────────────────────────────────────────────────────────────────\n.nb-color-strip {\n display: flex;\n flex-wrap: wrap;\n max-width: calc(#{$nb-color-diameter} * 8 + 8px * 7);\n\n :deep(button) {\n position: relative;\n width: $nb-color-diameter;\n height: $nb-color-diameter;\n border: 1px solid transparent;\n cursor: pointer;\n padding: 0;\n transition:\n border 0.2s,\n box-shadow 0.2s;\n\n &:disabled {\n cursor: not-allowed;\n opacity: 0.6;\n }\n\n &:focus,\n &:focus-visible,\n &.selected {\n border: 1px solid var(--nb-c-surface);\n outline: 0;\n\n &:before {\n content: '';\n position: absolute;\n top: calc(var(--nb-base-unit) / -2);\n left: calc(var(--nb-base-unit) / -2);\n right: calc(var(--nb-base-unit) / -2);\n bottom: calc(var(--nb-base-unit) / -2);\n border: 2px solid var(--nb-c-primary);\n }\n }\n\n &.nb-color-strip-color-null {\n border-color: var(--nb-c-primary);\n color: var(--nb-c-primary);\n }\n }\n}\n\n.only-view {\n :deep(button) {\n cursor: initial;\n\n &:focus,\n &:focus-visible,\n &.selected {\n border-color: transparent;\n outline: initial;\n\n &:before {\n content: none;\n }\n }\n }\n}\n</style>\n","// #region EVariant\nenum EVariant {\n Primary = 'primary',\n Secondary = 'secondary',\n Ghost = 'ghost',\n Danger = 'danger',\n Success = 'success',\n Warning = 'warning',\n}\n// #endregion EVariant\n\nexport { EVariant }\n","import { IDefaultProps } from '@/types/Props.d'\nimport { EVariant } from '@/types/Variants.d'\n\nenum EFileUploaderStatus {\n Idle = 'idle',\n Loading = 'loading',\n Success = 'success',\n}\n\ninterface IFileItem {\n file: File\n status: EFileUploaderStatus\n error?: string\n}\n\ninterface IFileUploaderProps extends IDefaultProps {\n heading?: string\n description?: string\n buttonLabel?: string\n variant?: EVariant\n accept?: string\n multiple?: boolean\n maxSize?: number\n disabled?: boolean\n}\n\nexport { EFileUploaderStatus, IFileItem, IFileUploaderProps }\n","<template>\n <div\n class=\"nb-file-uploader\"\n @dragenter.prevent=\"onDragEnter\"\n @dragover.prevent\n @dragleave.prevent=\"onDragLeave\"\n @drop.prevent=\"onDrop\"\n >\n <p v-if=\"heading\" class=\"nb-file-uploader__heading\">{{ heading }}</p>\n <p v-if=\"description\" class=\"nb-file-uploader__description\">\n {{ description }}\n </p>\n\n <!-- Drag-over state: replaces the button with a visual drop zone -->\n <div\n v-if=\"isDragging\"\n class=\"nb-file-uploader__dropzone\"\n :class=\"`nb-file-uploader__dropzone--${variant}`\"\n >\n <span class=\"nb-file-uploader__drop-label\">\n Drag and drop files here<br />or click to upload\n </span>\n </div>\n\n <NbButton\n v-else\n class=\"nb-file-uploader__btn\"\n :variant=\"variant\"\n @click.stop=\"openFilePicker\"\n >\n {{ buttonLabel }}\n </NbButton>\n\n <input\n ref=\"inputRef\"\n type=\"file\"\n class=\"nb-file-uploader__input\"\n :accept=\"accept\"\n :multiple=\"multiple\"\n @change=\"onFileInputChange\"\n />\n\n <ul v-if=\"files.length\" class=\"nb-file-uploader__list\">\n <li\n v-for=\"(item, i) in files\"\n :key=\"i\"\n class=\"nb-file-uploader__item\"\n :class=\"{\n 'nb-file-uploader__item--error': item.error,\n 'nb-file-uploader__item--success': item.status === 'success',\n }\"\n >\n <span class=\"nb-file-uploader__name\">{{ item.file.name }}</span>\n\n <span class=\"nb-file-uploader__status\">\n <NbIcon\n v-if=\"item.status === 'loading'\"\n name=\"circle-notch\"\n class=\"nb-file-uploader__spinner\"\n />\n <NbIcon\n v-else-if=\"item.status === 'success'\"\n name=\"check-circle-fill\"\n class=\"nb-file-uploader__check\"\n />\n <NbIcon\n v-if=\"item.error\"\n name=\"warning-circle-fill\"\n class=\"nb-file-uploader__warn\"\n />\n <button\n v-if=\"item.status !== 'loading'\"\n class=\"nb-file-uploader__remove\"\n type=\"button\"\n :aria-label=\"`Remove ${item.file.name}`\"\n @click=\"removeFile(i)\"\n >\n <NbIcon name=\"x\" />\n </button>\n </span>\n\n <div v-if=\"item.error\" class=\"nb-file-uploader__error\">\n {{ item.error }}\n </div>\n </li>\n </ul>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { ref } from 'vue'\nimport { EVariant } from '@/types/Variants.d'\nimport {\n EFileUploaderStatus,\n IFileItem,\n IFileUploaderProps,\n} from './FileUploader.d'\nimport NbButton from './Button.vue'\nimport NbIcon from './Icon.vue'\n\nconst props = withDefaults(defineProps<IFileUploaderProps>(), {\n buttonLabel: 'Add file',\n variant: EVariant.Primary,\n multiple: false,\n})\n\nconst emit = defineEmits<{\n /** Emitted whenever the file list changes. */\n (e: 'change', files: File[]): void\n /** Emitted when a file is removed. */\n (e: 'remove', file: File): void\n}>()\n\nconst inputRef = ref<HTMLInputElement | null>(null)\nconst files = ref<IFileItem[]>([])\nconst isDragging = ref(false)\nlet dragCounter = 0\n\nfunction openFilePicker() {\n inputRef.value?.click()\n}\n\nfunction validateFile(file: File): string | undefined {\n if (props.maxSize && file.size > props.maxSize) {\n return `File exceeds size limit.`\n }\n if (props.accept) {\n const exts = props.accept.split(',').map((a) => a.trim().toLowerCase())\n const name = file.name.toLowerCase()\n const matched = exts.some((ext) => {\n if (ext.startsWith('.')) return name.endsWith(ext)\n if (ext.includes('/'))\n return (\n file.type === ext || file.type.startsWith(ext.replaceAll('*', ''))\n )\n return false\n })\n if (!matched) return `File type not accepted.`\n }\n}\n\nfunction addFiles(rawFiles: FileList | File[]) {\n const list = Array.from(rawFiles)\n if (!props.multiple) {\n files.value = []\n }\n for (const file of list) {\n const error = validateFile(file)\n files.value.push({ file, status: EFileUploaderStatus.Idle, error })\n }\n emit(\n 'change',\n files.value.filter((f) => !f.error).map((f) => f.file),\n )\n}\n\nfunction onFileInputChange(event: Event) {\n const input = event.target as HTMLInputElement\n if (input.files?.length) {\n addFiles(input.files)\n input.value = ''\n }\n}\n\nfunction onDragEnter() {\n dragCounter++\n isDragging.value = true\n}\n\nfunction onDragLeave() {\n dragCounter--\n if (dragCounter <= 0) {\n dragCounter = 0\n isDragging.value = false\n }\n}\n\nfunction onDrop(event: DragEvent) {\n dragCounter = 0\n isDragging.value = false\n const dropped = event.dataTransfer?.files\n if (dropped?.length) addFiles(dropped)\n}\n\nfunction removeFile(index: number) {\n const removed = files.value[index]\n files.value.splice(index, 1)\n emit('remove', removed.file)\n emit(\n 'change',\n files.value.filter((f) => !f.error).map((f) => f.file),\n )\n}\n\n/** Programmatically set file status (useful after async upload). */\nfunction setFileStatus(\n index: number,\n status: IFileItem['status'],\n error?: string,\n) {\n if (files.value[index]) {\n files.value[index].status = status\n files.value[index].error = error\n }\n}\n\ndefineExpose({ files, setFileStatus })\n</script>\n\n<style scoped lang=\"scss\">\n.nb-file-uploader {\n display: flex;\n flex-direction: column;\n gap: 0.75rem;\n\n &__heading {\n margin: 0;\n font-weight: 600;\n font-size: 1rem;\n color: var(--nb-c-text);\n }\n\n &__description {\n margin: 0;\n font-size: 0.875rem;\n color: var(--nb-c-text-secondary, #6b7280);\n border-left: 3px solid var(--nb-c-border, #e5e7eb);\n padding-left: 0.75rem;\n line-height: 1.5;\n }\n\n &__input {\n display: none;\n }\n\n &__btn {\n align-self: flex-start;\n }\n\n // Drop zone: shown only while dragging (v-if controlled)\n &__dropzone {\n display: flex;\n align-items: center;\n justify-content: center;\n padding: 2rem 1.5rem;\n border: 2px dashed var(--nb-c-border, #d1d5db);\n border-radius: 6px;\n cursor: pointer;\n text-align: center;\n transition:\n border-color 0.15s,\n background 0.15s;\n\n &--primary {\n background: color-mix(in srgb, var(--nb-c-primary) 6%, transparent);\n border-color: color-mix(in srgb, var(--nb-c-primary) 60%, transparent);\n .nb-file-uploader__drop-label {\n color: var(--nb-c-primary);\n }\n }\n &--secondary {\n background: color-mix(in srgb, var(--nb-c-secondary) 6%, transparent);\n border-color: color-mix(in srgb, var(--nb-c-secondary) 60%, transparent);\n .nb-file-uploader__drop-label {\n color: var(--nb-c-secondary);\n }\n }\n &--danger {\n background: color-mix(in srgb, var(--nb-c-danger) 6%, transparent);\n border-color: color-mix(in srgb, var(--nb-c-danger) 60%, transparent);\n .nb-file-uploader__drop-label {\n color: var(--nb-c-danger);\n }\n }\n &--success {\n background: color-mix(in srgb, var(--nb-c-success) 6%, transparent);\n border-color: color-mix(in srgb, var(--nb-c-success) 60%, transparent);\n .nb-file-uploader__drop-label {\n color: var(--nb-c-success);\n }\n }\n &--warning {\n background: color-mix(in srgb, var(--nb-c-warning) 6%, transparent);\n border-color: color-mix(in srgb, var(--nb-c-warning) 60%, transparent);\n .nb-file-uploader__drop-label {\n color: var(--nb-c-warning);\n }\n }\n }\n\n &__drop-label {\n font-size: 0.9rem;\n line-height: 1.6;\n pointer-events: none;\n }\n\n &__list {\n list-style: none;\n margin: 0;\n padding: 0;\n display: flex;\n flex-direction: column;\n gap: 0.5rem;\n }\n\n &__item {\n display: grid;\n grid-template-columns: 1fr auto;\n grid-template-rows: auto auto;\n align-items: center;\n background: var(--nb-c-surface, #f3f4f6);\n border: 1px solid transparent;\n border-radius: 4px;\n padding: 0.6rem 0.875rem;\n font-size: 0.9rem;\n color: var(--nb-c-text);\n transition: border-color 0.15s;\n\n &--error {\n border-color: var(--nb-c-danger);\n }\n }\n\n &__name {\n grid-column: 1;\n grid-row: 1;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n padding-right: 0.5rem;\n }\n\n &__status {\n grid-column: 2;\n grid-row: 1;\n display: flex;\n align-items: center;\n gap: 0.25rem;\n }\n\n &__error {\n grid-column: 1 / -1;\n grid-row: 2;\n font-size: 0.8125rem;\n color: var(--nb-c-danger);\n padding-top: 0.35rem;\n border-top: 1px solid var(--nb-c-border, #e5e7eb);\n margin-top: 0.35rem;\n }\n\n &__remove {\n background: none;\n border: none;\n padding: 0;\n cursor: pointer;\n color: var(--nb-c-text-secondary, #6b7280);\n display: flex;\n align-items: center;\n line-height: 1;\n\n &:hover {\n color: var(--nb-c-text);\n }\n }\n\n &__spinner {\n animation: nb-spin 0.8s linear infinite;\n color: var(--nb-c-primary);\n }\n\n &__check {\n color: var(--nb-c-primary);\n }\n\n &__warn {\n color: var(--nb-c-danger);\n }\n}\n\n@keyframes nb-spin {\n to {\n transform: rotate(360deg);\n }\n}\n</style>\n","<template>\n <div\n class=\"nb-file-uploader\"\n @dragenter.prevent=\"onDragEnter\"\n @dragover.prevent\n @dragleave.prevent=\"onDragLeave\"\n @drop.prevent=\"onDrop\"\n >\n <p v-if=\"heading\" class=\"nb-file-uploader__heading\">{{ heading }}</p>\n <p v-if=\"description\" class=\"nb-file-uploader__description\">\n {{ description }}\n </p>\n\n <!-- Drag-over state: replaces the button with a visual drop zone -->\n <div\n v-if=\"isDragging\"\n class=\"nb-file-uploader__dropzone\"\n :class=\"`nb-file-uploader__dropzone--${variant}`\"\n >\n <span class=\"nb-file-uploader__drop-label\">\n Drag and drop files here<br />or click to upload\n </span>\n </div>\n\n <NbButton\n v-else\n class=\"nb-file-uploader__btn\"\n :variant=\"variant\"\n @click.stop=\"openFilePicker\"\n >\n {{ buttonLabel }}\n </NbButton>\n\n <input\n ref=\"inputRef\"\n type=\"file\"\n class=\"nb-file-uploader__input\"\n :accept=\"accept\"\n :multiple=\"multiple\"\n @change=\"onFileInputChange\"\n />\n\n <ul v-if=\"files.length\" class=\"nb-file-uploader__list\">\n <li\n v-for=\"(item, i) in files\"\n :key=\"i\"\n class=\"nb-file-uploader__item\"\n :class=\"{\n 'nb-file-uploader__item--error': item.error,\n 'nb-file-uploader__item--success': item.status === 'success',\n }\"\n >\n <span class=\"nb-file-uploader__name\">{{ item.file.name }}</span>\n\n <span class=\"nb-file-uploader__status\">\n <NbIcon\n v-if=\"item.status === 'loading'\"\n name=\"circle-notch\"\n class=\"nb-file-uploader__spinner\"\n />\n <NbIcon\n v-else-if=\"item.status === 'success'\"\n name=\"check-circle-fill\"\n class=\"nb-file-uploader__check\"\n />\n <NbIcon\n v-if=\"item.error\"\n name=\"warning-circle-fill\"\n class=\"nb-file-uploader__warn\"\n />\n <button\n v-if=\"item.status !== 'loading'\"\n class=\"nb-file-uploader__remove\"\n type=\"button\"\n :aria-label=\"`Remove ${item.file.name}`\"\n @click=\"removeFile(i)\"\n >\n <NbIcon name=\"x\" />\n </button>\n </span>\n\n <div v-if=\"item.error\" class=\"nb-file-uploader__error\">\n {{ item.error }}\n </div>\n </li>\n </ul>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { ref } from 'vue'\nimport { EVariant } from '@/types/Variants.d'\nimport {\n EFileUploaderStatus,\n IFileItem,\n IFileUploaderProps,\n} from './FileUploader.d'\nimport NbButton from './Button.vue'\nimport NbIcon from './Icon.vue'\n\nconst props = withDefaults(defineProps<IFileUploaderProps>(), {\n buttonLabel: 'Add file',\n variant: EVariant.Primary,\n multiple: false,\n})\n\nconst emit = defineEmits<{\n /** Emitted whenever the file list changes. */\n (e: 'change', files: File[]): void\n /** Emitted when a file is removed. */\n (e: 'remove', file: File): void\n}>()\n\nconst inputRef = ref<HTMLInputElement | null>(null)\nconst files = ref<IFileItem[]>([])\nconst isDragging = ref(false)\nlet dragCounter = 0\n\nfunction openFilePicker() {\n inputRef.value?.click()\n}\n\nfunction validateFile(file: File): string | undefined {\n if (props.maxSize && file.size > props.maxSize) {\n return `File exceeds size limit.`\n }\n if (props.accept) {\n const exts = props.accept.split(',').map((a) => a.trim().toLowerCase())\n const name = file.name.toLowerCase()\n const matched = exts.some((ext) => {\n if (ext.startsWith('.')) return name.endsWith(ext)\n if (ext.includes('/'))\n return (\n file.type === ext || file.type.startsWith(ext.replaceAll('*', ''))\n )\n return false\n })\n if (!matched) return `File type not accepted.`\n }\n}\n\nfunction addFiles(rawFiles: FileList | File[]) {\n const list = Array.from(rawFiles)\n if (!props.multiple) {\n files.value = []\n }\n for (const file of list) {\n const error = validateFile(file)\n files.value.push({ file, status: EFileUploaderStatus.Idle, error })\n }\n emit(\n 'change',\n files.value.filter((f) => !f.error).map((f) => f.file),\n )\n}\n\nfunction onFileInputChange(event: Event) {\n const input = event.target as HTMLInputElement\n if (input.files?.length) {\n addFiles(input.files)\n input.value = ''\n }\n}\n\nfunction onDragEnter() {\n dragCounter++\n isDragging.value = true\n}\n\nfunction onDragLeave() {\n dragCounter--\n if (dragCounter <= 0) {\n dragCounter = 0\n isDragging.value = false\n }\n}\n\nfunction onDrop(event: DragEvent) {\n dragCounter = 0\n isDragging.value = false\n const dropped = event.dataTransfer?.files\n if (dropped?.length) addFiles(dropped)\n}\n\nfunction removeFile(index: number) {\n const removed = files.value[index]\n files.value.splice(index, 1)\n emit('remove', removed.file)\n emit(\n 'change',\n files.value.filter((f) => !f.error).map((f) => f.file),\n )\n}\n\n/** Programmatically set file status (useful after async upload). */\nfunction setFileStatus(\n index: number,\n status: IFileItem['status'],\n error?: string,\n) {\n if (files.value[index]) {\n files.value[index].status = status\n files.value[index].error = error\n }\n}\n\ndefineExpose({ files, setFileStatus })\n</script>\n\n<style scoped lang=\"scss\">\n.nb-file-uploader {\n display: flex;\n flex-direction: column;\n gap: 0.75rem;\n\n &__heading {\n margin: 0;\n font-weight: 600;\n font-size: 1rem;\n color: var(--nb-c-text);\n }\n\n &__description {\n margin: 0;\n font-size: 0.875rem;\n color: var(--nb-c-text-secondary, #6b7280);\n border-left: 3px solid var(--nb-c-border, #e5e7eb);\n padding-left: 0.75rem;\n line-height: 1.5;\n }\n\n &__input {\n display: none;\n }\n\n &__btn {\n align-self: flex-start;\n }\n\n // Drop zone: shown only while dragging (v-if controlled)\n &__dropzone {\n display: flex;\n align-items: center;\n justify-content: center;\n padding: 2rem 1.5rem;\n border: 2px dashed var(--nb-c-border, #d1d5db);\n border-radius: 6px;\n cursor: pointer;\n text-align: center;\n transition:\n border-color 0.15s,\n background 0.15s;\n\n &--primary {\n background: color-mix(in srgb, var(--nb-c-primary) 6%, transparent);\n border-color: color-mix(in srgb, var(--nb-c-primary) 60%, transparent);\n .nb-file-uploader__drop-label {\n color: var(--nb-c-primary);\n }\n }\n &--secondary {\n background: color-mix(in srgb, var(--nb-c-secondary) 6%, transparent);\n border-color: color-mix(in srgb, var(--nb-c-secondary) 60%, transparent);\n .nb-file-uploader__drop-label {\n color: var(--nb-c-secondary);\n }\n }\n &--danger {\n background: color-mix(in srgb, var(--nb-c-danger) 6%, transparent);\n border-color: color-mix(in srgb, var(--nb-c-danger) 60%, transparent);\n .nb-file-uploader__drop-label {\n color: var(--nb-c-danger);\n }\n }\n &--success {\n background: color-mix(in srgb, var(--nb-c-success) 6%, transparent);\n border-color: color-mix(in srgb, var(--nb-c-success) 60%, transparent);\n .nb-file-uploader__drop-label {\n color: var(--nb-c-success);\n }\n }\n &--warning {\n background: color-mix(in srgb, var(--nb-c-warning) 6%, transparent);\n border-color: color-mix(in srgb, var(--nb-c-warning) 60%, transparent);\n .nb-file-uploader__drop-label {\n color: var(--nb-c-warning);\n }\n }\n }\n\n &__drop-label {\n font-size: 0.9rem;\n line-height: 1.6;\n pointer-events: none;\n }\n\n &__list {\n list-style: none;\n margin: 0;\n padding: 0;\n display: flex;\n flex-direction: column;\n gap: 0.5rem;\n }\n\n &__item {\n display: grid;\n grid-template-columns: 1fr auto;\n grid-template-rows: auto auto;\n align-items: center;\n background: var(--nb-c-surface, #f3f4f6);\n border: 1px solid transparent;\n border-radius: 4px;\n padding: 0.6rem 0.875rem;\n font-size: 0.9rem;\n color: var(--nb-c-text);\n transition: border-color 0.15s;\n\n &--error {\n border-color: var(--nb-c-danger);\n }\n }\n\n &__name {\n grid-column: 1;\n grid-row: 1;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n padding-right: 0.5rem;\n }\n\n &__status {\n grid-column: 2;\n grid-row: 1;\n display: flex;\n align-items: center;\n gap: 0.25rem;\n }\n\n &__error {\n grid-column: 1 / -1;\n grid-row: 2;\n font-size: 0.8125rem;\n color: var(--nb-c-danger);\n padding-top: 0.35rem;\n border-top: 1px solid var(--nb-c-border, #e5e7eb);\n margin-top: 0.35rem;\n }\n\n &__remove {\n background: none;\n border: none;\n padding: 0;\n cursor: pointer;\n color: var(--nb-c-text-secondary, #6b7280);\n display: flex;\n align-items: center;\n line-height: 1;\n\n &:hover {\n color: var(--nb-c-text);\n }\n }\n\n &__spinner {\n animation: nb-spin 0.8s linear infinite;\n color: var(--nb-c-primary);\n }\n\n &__check {\n color: var(--nb-c-primary);\n }\n\n &__warn {\n color: var(--nb-c-danger);\n }\n}\n\n@keyframes nb-spin {\n to {\n transform: rotate(360deg);\n }\n}\n</style>\n","<template>\n <i\n :class=\"classes\"\n :style=\"styles\"\n v-bind=\"attributes\"\n @click=\"!clickable ? undefined : emit('click', $event)\"\n >\n <component\n :is=\"flagComponent\"\n v-if=\"flagComponent\"\n :aria-hidden=\"true\"\n :width=\"attributes.width\"\n :height=\"attributes.height\"\n :style=\"styles\"\n />\n </i>\n</template>\n\n<script setup lang=\"ts\">\n// @ts-expect-error virtual module provided by flags vite plugin\nimport flags from 'virtual:flags'\nimport { computed } from 'vue'\nimport kebab2camel from '@/utils/kebab2camel.helper'\nimport { ESizePixel, IFlagProps } from './Flag.d'\nimport { useStableId } from '@/composables/useStableId.composable'\n\nconst props = withDefaults(defineProps<IFlagProps>(), {\n name: undefined,\n size: ESizePixel.Medium,\n clickable: false,\n})\n\nconst emit = defineEmits(['click'])\n\nconst componentInternalId = useStableId(props)\n\nconst classes = computed(() => {\n return {\n 'nb-flag': true,\n ...(props.name && { [`nb-flag--${props.name}`]: true }),\n [`nb-flag--${props.size}`]:\n typeof props.size === 'string' && ['sm', 'md', 'lg'].includes(props.size),\n 'box-clickable': props.clickable,\n }\n})\n\nconst styles = computed(() => {\n return {\n ...(typeof props.size === 'number' && {\n maxWidth: `${props.size}px`,\n maxHeight: `${props.size}px`,\n height: `${props.size}px`,\n width: `${props.size}px`,\n }),\n ...(typeof props.size === 'string' &&\n !['sm', 'md', 'lg'].includes(props.size) && {\n maxWidth: props.size,\n maxHeight: props.size,\n height: props.size,\n width: props.size,\n }),\n }\n})\n\nconst attributes = computed(() => {\n const flagSize =\n typeof props.size === 'number'\n ? props.size\n : (ESizePixel as unknown as Record<string, number>)[\n String(props.size).toUpperCase()\n ] || ESizePixel.Medium\n\n return {\n ...{ id: componentInternalId },\n ...(props.size && {\n width: `${flagSize}px`,\n height: `${flagSize}px`,\n }),\n ...(props.clickable && { role: 'button' }),\n }\n})\n\nconst flagComponent = computed(() => {\n return flags[kebab2camel(`f-${props.name.replaceAll('_', '-')}`)]\n})\n</script>\n\n<style lang=\"scss\" scoped>\n.nb-flag {\n display: flex;\n line-height: 1em;\n position: relative;\n height: fit-content;\n\n &:not(.box-clickable) {\n pointer-events: none;\n }\n\n &--lg {\n max-width: 32px;\n max-height: 32px;\n width: 32px;\n }\n &--md {\n max-width: 20px;\n max-height: 20px;\n width: 20px;\n }\n &--sm {\n max-width: 16px;\n max-height: 16px;\n width: 16px;\n }\n}\n</style>\n","<template>\n <i\n :class=\"classes\"\n :style=\"styles\"\n v-bind=\"attributes\"\n @click=\"!clickable ? undefined : emit('click', $event)\"\n >\n <component\n :is=\"flagComponent\"\n v-if=\"flagComponent\"\n :aria-hidden=\"true\"\n :width=\"attributes.width\"\n :height=\"attributes.height\"\n :style=\"styles\"\n />\n </i>\n</template>\n\n<script setup lang=\"ts\">\n// @ts-expect-error virtual module provided by flags vite plugin\nimport flags from 'virtual:flags'\nimport { computed } from 'vue'\nimport kebab2camel from '@/utils/kebab2camel.helper'\nimport { ESizePixel, IFlagProps } from './Flag.d'\nimport { useStableId } from '@/composables/useStableId.composable'\n\nconst props = withDefaults(defineProps<IFlagProps>(), {\n name: undefined,\n size: ESizePixel.Medium,\n clickable: false,\n})\n\nconst emit = defineEmits(['click'])\n\nconst componentInternalId = useStableId(props)\n\nconst classes = computed(() => {\n return {\n 'nb-flag': true,\n ...(props.name && { [`nb-flag--${props.name}`]: true }),\n [`nb-flag--${props.size}`]:\n typeof props.size === 'string' && ['sm', 'md', 'lg'].includes(props.size),\n 'box-clickable': props.clickable,\n }\n})\n\nconst styles = computed(() => {\n return {\n ...(typeof props.size === 'number' && {\n maxWidth: `${props.size}px`,\n maxHeight: `${props.size}px`,\n height: `${props.size}px`,\n width: `${props.size}px`,\n }),\n ...(typeof props.size === 'string' &&\n !['sm', 'md', 'lg'].includes(props.size) && {\n maxWidth: props.size,\n maxHeight: props.size,\n height: props.size,\n width: props.size,\n }),\n }\n})\n\nconst attributes = computed(() => {\n const flagSize =\n typeof props.size === 'number'\n ? props.size\n : (ESizePixel as unknown as Record<string, number>)[\n String(props.size).toUpperCase()\n ] || ESizePixel.Medium\n\n return {\n ...{ id: componentInternalId },\n ...(props.size && {\n width: `${flagSize}px`,\n height: `${flagSize}px`,\n }),\n ...(props.clickable && { role: 'button' }),\n }\n})\n\nconst flagComponent = computed(() => {\n return flags[kebab2camel(`f-${props.name.replaceAll('_', '-')}`)]\n})\n</script>\n\n<style lang=\"scss\" scoped>\n.nb-flag {\n display: flex;\n line-height: 1em;\n position: relative;\n height: fit-content;\n\n &:not(.box-clickable) {\n pointer-events: none;\n }\n\n &--lg {\n max-width: 32px;\n max-height: 32px;\n width: 32px;\n }\n &--md {\n max-width: 20px;\n max-height: 20px;\n width: 20px;\n }\n &--sm {\n max-width: 16px;\n max-height: 16px;\n width: 16px;\n }\n}\n</style>\n","<template>\n <NbGrid is=\"form\" dir=\"col\" gap=\"md\" class=\"nb-form\">\n <NbGrid is=\"h4\" v-if=\"title\" class=\"nb-form--header\">\n {{ title }}\n </NbGrid>\n <NbGrid is=\"p\" v-if=\"$slots.message\" class=\"nb-form--message\">\n <slot name=\"message\" />\n </NbGrid>\n <NbGrid\n is=\"div\"\n v-if=\"$slots.default\"\n dir=\"col\"\n gap=\"sm\"\n class=\"nb-form--body\"\n >\n <slot />\n </NbGrid>\n <NbGrid\n is=\"footer\"\n v-if=\"$slots.footer\"\n class=\"nb-form--footer\"\n justify=\"end\"\n >\n <slot name=\"footer\" />\n </NbGrid>\n </NbGrid>\n</template>\n\n<script lang=\"ts\" setup>\nimport { IFormProps } from './Form.d'\n\nwithDefaults(defineProps<IFormProps>(), {\n title: undefined,\n})\n</script>\n\n<style lang=\"scss\" scoped></style>\n","<template>\n <NbGrid is=\"form\" dir=\"col\" gap=\"md\" class=\"nb-form\">\n <NbGrid is=\"h4\" v-if=\"title\" class=\"nb-form--header\">\n {{ title }}\n </NbGrid>\n <NbGrid is=\"p\" v-if=\"$slots.message\" class=\"nb-form--message\">\n <slot name=\"message\" />\n </NbGrid>\n <NbGrid\n is=\"div\"\n v-if=\"$slots.default\"\n dir=\"col\"\n gap=\"sm\"\n class=\"nb-form--body\"\n >\n <slot />\n </NbGrid>\n <NbGrid\n is=\"footer\"\n v-if=\"$slots.footer\"\n class=\"nb-form--footer\"\n justify=\"end\"\n >\n <slot name=\"footer\" />\n </NbGrid>\n </NbGrid>\n</template>\n\n<script lang=\"ts\" setup>\nimport { IFormProps } from './Form.d'\n\nwithDefaults(defineProps<IFormProps>(), {\n title: undefined,\n})\n</script>\n\n<style lang=\"scss\" scoped></style>\n","import type { PropType } from 'vue'\n\n// Breakpoint names — mobile-first (min-width)\nexport type TBreakpoint = 'sm' | 'md' | 'lg' | 'xl' | 'xxl'\n\n// Grid direction types\nexport type TGridType = 'row' | 'col' | 'row-reverse' | 'col-reverse'\nexport type TGridTypeResponsive = Partial<Record<TBreakpoint, TGridType>>\nexport type TGridTypeFn = () => TGridType\nexport type TGridTypeInput = TGridType | TGridTypeResponsive | TGridTypeFn\n\n// Alignment types\nexport type TGridAlign = 'start' | 'end' | 'center' | 'baseline' | 'stretch'\nexport type TGridAlignResponsive = Partial<Record<TBreakpoint, TGridAlign>>\nexport type TGridAlignFn = () => TGridAlign\nexport type TGridAlignInput = TGridAlign | TGridAlignResponsive | TGridAlignFn\n\n// Justify types\nexport type TGridJustify =\n | 'around'\n | 'between'\n | 'center'\n | 'end'\n | 'evenly'\n | 'start'\nexport type TGridJustifyResponsive = Partial<Record<TBreakpoint, TGridJustify>>\nexport type TGridJustifyFn = () => TGridJustify\nexport type TGridJustifyInput =\n | TGridJustify\n | TGridJustifyResponsive\n | TGridJustifyFn\n\n// Wrap types\nexport type TGridWrap = 'nowrap' | 'wrap' | 'reverse'\nexport type TGridWrapResponsive = Partial<Record<TBreakpoint, TGridWrap>>\nexport type TGridWrapFn = () => TGridWrap\nexport type TGridWrapInput = TGridWrap | TGridWrapResponsive | TGridWrapFn\n\n// Gap types\nexport type TGapSize = 'xxs' | 'xs' | 'sm' | 'md' | 'lg' | 'xl' | 'xxl'\nexport type TGridGap = TGapSize | Partial<Record<TBreakpoint, TGapSize>>\nexport type TGridGapFn = () => TGapSize\nexport type TGridGapInput =\n | TGapSize\n | Partial<Record<TBreakpoint, TGapSize>>\n | TGridGapFn\n\n// Grid columns (1-16)\nexport type TGridColumns =\n | 1\n | 2\n | 3\n | 4\n | 5\n | 6\n | 7\n | 8\n | 9\n | 10\n | 11\n | 12\n | 13\n | 14\n | 15\n | 16\nexport type TGridColumnsResponsive = Partial<Record<TBreakpoint, TGridColumns>>\nexport type TGridColumnsFn = () => TGridColumns\nexport type TGridColumnsInput =\n | TGridColumns\n | TGridColumnsResponsive\n | TGridColumnsFn\n\n// Grid shift (0-15)\nexport type TGridShift =\n | 0\n | 1\n | 2\n | 3\n | 4\n | 5\n | 6\n | 7\n | 8\n | 9\n | 10\n | 11\n | 12\n | 13\n | 14\n | 15\nexport type TGridShiftResponsive = Partial<Record<TBreakpoint, TGridShift>>\nexport type TGridShiftFn = () => TGridShift\nexport type TGridShiftInput = TGridShift | TGridShiftResponsive | TGridShiftFn\n\n// Visible types\nexport type TGridVisibleResponsive = Partial<Record<TBreakpoint, boolean>>\nexport type TGridVisibleFn = () => boolean\nexport type TGridVisibleInput =\n | boolean\n | TGridVisibleResponsive\n | TGridVisibleFn\n\n// Boolean responsive type (for first, last, reverse — array of breakpoints, not objects)\nexport type TBooleanResponsive = boolean | TBreakpoint[]\n\n// Grid mode\nexport type TGridMode = 'wide' | 'narrow' | 'condensed'\n\n// Class collection type\nexport type TClassCollection = Record<string, boolean>\n\n// Handler context for class generation\nexport interface IHandlerContext {\n collection: TClassCollection\n breakpoint?: string\n classMap?: Record<string, string>\n}\n\n// Component props interface\nexport interface IGridProps {\n id?: string | null\n is?: string\n dir?: TGridTypeInput\n align?: TGridAlignInput | null\n justify?: TGridJustifyInput | null\n gap?: TGridGapInput | null\n grid?: TGridColumnsInput | null\n shift?: TGridShiftInput | null\n wrap?: TGridWrapInput | null\n first?: TBooleanResponsive | null\n last?: TBooleanResponsive | null\n visible?: TGridVisibleInput | null\n reverse?: TBooleanResponsive\n grow?: boolean | null\n flex?: boolean | null\n shrink?: boolean | null\n distributed?: boolean\n mode?: TGridMode\n tabIndex?: string | null\n}\n\n// Prop definitions for defineProps\nexport const gridPropDefinitions = {\n id: {\n type: String as PropType<string>,\n default: null,\n },\n\n is: {\n type: String as PropType<string>,\n default: 'div',\n },\n\n dir: {\n type: [String, Object, Function] as PropType<TGridTypeInput>,\n default: 'row',\n validator: (value: TGridTypeInput): boolean => {\n if (typeof value === 'function') return true\n if (typeof value === 'string') {\n return (['row', 'col', 'row-reverse', 'col-reverse'] as const).includes(\n value as TGridType,\n )\n }\n return Object.values(value).every((v) =>\n (['row', 'col', 'row-reverse', 'col-reverse'] as const).includes(\n v as TGridType,\n ),\n )\n },\n },\n\n align: {\n type: [String, Object, Function] as PropType<TGridAlignInput>,\n default: null,\n validator: (value: TGridAlignInput): boolean => {\n if (value == null || typeof value === 'function') return true\n if (typeof value === 'string') {\n return (\n ['start', 'end', 'center', 'baseline', 'stretch'] as const\n ).includes(value as TGridAlign)\n }\n return Object.values(value).every((v) =>\n (['start', 'end', 'center', 'baseline', 'stretch'] as const).includes(\n v as TGridAlign,\n ),\n )\n },\n },\n\n justify: {\n type: [String, Object, Function] as PropType<TGridJustifyInput>,\n default: null,\n validator: (value: TGridJustifyInput): boolean => {\n if (value == null || typeof value === 'function') return true\n if (typeof value === 'string') {\n return (\n ['around', 'between', 'center', 'end', 'evenly', 'start'] as const\n ).includes(value as TGridJustify)\n }\n return Object.values(value).every((v) =>\n (\n ['around', 'between', 'center', 'end', 'evenly', 'start'] as const\n ).includes(v as TGridJustify),\n )\n },\n },\n\n gap: {\n type: [String, Object, Function] as PropType<TGridGapInput>,\n default: null,\n validator: (value: TGridGapInput): boolean => {\n if (value == null || typeof value === 'function') return true\n const validSizes = ['xxs', 'xs', 'sm', 'md', 'lg', 'xl', 'xxl'] as const\n if (typeof value === 'string') {\n return validSizes.includes(value as TGapSize)\n }\n return Object.values(value).every((v) =>\n validSizes.includes(v as TGapSize),\n )\n },\n },\n\n grid: {\n type: [Number, String, Object, Function] as PropType<TGridColumnsInput>,\n default: null,\n validator: (value: TGridColumnsInput): boolean => {\n if (value == null || typeof value === 'function') return true\n const isValidColumn = (v: number | string) => {\n const num = typeof v === 'string' ? parseInt(v, 10) : v\n return num >= 1 && num <= 16 && !isNaN(num)\n }\n\n if (typeof value === 'number' || typeof value === 'string') {\n return isValidColumn(value)\n }\n return Object.values(value).every(isValidColumn)\n },\n },\n\n shift: {\n type: [Number, String, Object, Function] as PropType<TGridShiftInput>,\n default: null,\n validator: (value: TGridShiftInput): boolean => {\n if (value == null || typeof value === 'function') return true\n const isValidShift = (v: number | string) => {\n const num = typeof v === 'string' ? parseInt(v, 10) : v\n return num >= 0 && num <= 15 && !isNaN(num)\n }\n\n if (typeof value === 'number' || typeof value === 'string') {\n return isValidShift(value)\n }\n return Object.values(value).every(isValidShift)\n },\n },\n\n wrap: {\n type: [String, Object, Function] as PropType<TGridWrapInput>,\n default: null,\n validator: (value: TGridWrapInput): boolean => {\n if (value == null || typeof value === 'function') return true\n if (typeof value === 'string') {\n return (['nowrap', 'wrap', 'reverse'] as const).includes(\n value as TGridWrap,\n )\n }\n return Object.values(value).every((v) =>\n (['nowrap', 'wrap', 'reverse'] as const).includes(v as TGridWrap),\n )\n },\n },\n\n first: {\n type: [Boolean, Array] as PropType<TBooleanResponsive>,\n default: null,\n validator: (value: TBooleanResponsive): boolean => {\n if (value == null) return true\n if (typeof value === 'boolean') return true\n const validBreakpoints = ['sm', 'md', 'lg', 'xl', 'xxl'] as const\n return value.every((bp) => validBreakpoints.includes(bp as TBreakpoint))\n },\n },\n\n last: {\n type: [Boolean, Array] as PropType<TBooleanResponsive>,\n default: null,\n validator: (value: TBooleanResponsive): boolean => {\n if (value == null) return true\n if (typeof value === 'boolean') return true\n const validBreakpoints = ['sm', 'md', 'lg', 'xl', 'xxl'] as const\n return value.every((bp) => validBreakpoints.includes(bp as TBreakpoint))\n },\n },\n\n visible: {\n type: [Boolean, Object, Function] as PropType<TGridVisibleInput>,\n default: null,\n },\n\n reverse: {\n type: [Boolean, Array] as PropType<TBooleanResponsive>,\n default: false,\n validator: (value: TBooleanResponsive): boolean => {\n if (value == null) return true\n if (typeof value === 'boolean') return true\n const validBreakpoints = ['sm', 'md', 'lg', 'xl', 'xxl'] as const\n return value.every((bp) => validBreakpoints.includes(bp as TBreakpoint))\n },\n },\n\n grow: {\n type: Boolean as PropType<boolean>,\n default: null,\n },\n\n flex: {\n type: Boolean as PropType<boolean>,\n default: null,\n },\n\n shrink: {\n type: Boolean as PropType<boolean>,\n default: null,\n },\n\n distributed: {\n type: Boolean as PropType<boolean>,\n default: false,\n },\n\n mode: {\n type: String as PropType<TGridMode>,\n default: 'wide',\n validator: (value: string): boolean => {\n return (['wide', 'narrow', 'condensed'] as const).includes(\n value as TGridMode,\n )\n },\n },\n\n tabIndex: {\n type: String as PropType<string>,\n default: null,\n },\n}\n","<template>\n <component\n :is=\"is\"\n :id=\"id\"\n ref=\"root\"\n :class=\"classes\"\n :tabindex=\"(tabIndex ?? !focusableElements.includes(is)) ? '-1' : '0'\"\n >\n <slot />\n </component>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed, ref } from 'vue'\nimport { gridPropDefinitions } from './Grid.d'\nimport type {\n TClassCollection,\n IHandlerContext,\n TGridType,\n TGridAlign,\n TGridJustify,\n TGridWrap,\n TBreakpoint,\n} from './Grid.d'\n\n// Focusable HTML elements\nconst focusableElements = [\n 'a',\n 'button',\n 'input',\n 'textarea',\n 'select',\n 'details',\n 'iframe',\n 'object',\n 'embed',\n 'area',\n 'audio',\n 'video',\n]\n\n// Component ref\nconst root = ref<HTMLElement>()\nconst getRef = () => root.value\n\ndefineExpose({\n getRef,\n})\n\n// Define props\nconst props = defineProps(gridPropDefinitions)\n\n// ============================================================================\n// Utility Functions\n// ============================================================================\n\n/**\n * Normalizes breakpoint names from camelCase to kebab-case\n * Example: 'mediumLarge' -> 'medium-large'\n */\nconst normalizeBreakpoint = (breakpoint: string): string =>\n breakpoint.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase()\n\n// ============================================================================\n// Individual Property Handlers\n// ============================================================================\n\n/**\n * Handles direction prop (row, col, row-reverse, col-reverse)\n */\nfunction handleDirection(value: TGridType, ctx: IHandlerContext): void {\n const { collection, breakpoint } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n\n // Skip base 'row' for responsive breakpoints (row is default)\n if (breakpoint && value === 'row') {\n return\n }\n\n collection[`${prefix}${value}`] = true\n}\n\n/**\n * Handles align prop (start, end, center, baseline, stretch)\n */\nfunction handleAlign(value: TGridAlign, ctx: IHandlerContext): void {\n const { collection, breakpoint, classMap } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n const mappedValue = classMap?.[value] ?? value\n\n collection[`${prefix}align-${mappedValue}`] = true\n}\n\n/**\n * Handles justify prop (around, between, center, end, evenly, start)\n */\nfunction handleJustify(value: TGridJustify, ctx: IHandlerContext): void {\n const { collection, breakpoint, classMap } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n const mappedValue = classMap?.[value] ?? value\n\n collection[`${prefix}justify-${mappedValue}`] = true\n}\n\n/**\n * Handles gap prop (xxs, xs, sm, md, lg, xl, xxl)\n */\nfunction handleGap(value: string, ctx: IHandlerContext): void {\n const { collection, breakpoint } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n\n collection[`${prefix}gap-${value}`] = true\n}\n\n/**\n * Handles grid prop (1-16 columns)\n */\nfunction handleGrid(value: number | string, ctx: IHandlerContext): void {\n const { collection, breakpoint } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n\n collection[`${prefix}grid-${value}`] = true\n}\n\n/**\n * Handles shift prop (0-15 columns offset)\n */\nfunction handleShift(value: number | string, ctx: IHandlerContext): void {\n const { collection, breakpoint } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n\n collection[`${prefix}shift-${value}`] = true\n}\n\n/**\n * Handles wrap prop (nowrap, wrap, reverse)\n */\nfunction handleWrap(value: TGridWrap, ctx: IHandlerContext): void {\n const { collection, breakpoint } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n\n collection[`${prefix}${value}`] = true\n}\n\n/**\n * Handles reverse prop\n */\nfunction handleReverse(value: boolean, ctx: IHandlerContext): void {\n if (!value) return\n\n const { collection, breakpoint } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n\n collection[`${prefix}reverse`] = true\n}\n\n/**\n * Handles order props (first, last)\n */\nfunction handleOrder(\n value: boolean,\n ctx: IHandlerContext,\n type: 'first' | 'last',\n): void {\n if (!value) return\n\n const { collection, breakpoint } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n\n collection[`${prefix}${type}`] = true\n}\n\n/**\n * Handles visible prop\n */\nfunction handleVisible(value: boolean, ctx: IHandlerContext): void {\n const { collection, breakpoint } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n\n collection[`${prefix}${value ? 'visible' : 'hidden'}`] = true\n}\n\n// ============================================================================\n// Responsive Property Processor\n// ============================================================================\n\n/**\n * Generic processor for responsive props.\n * Handles three input modes:\n * 1. Scalar value — applies at all breakpoints: dir=\"col\"\n * 2. Breakpoint map — per-breakpoint object: :dir=\"{ sm: 'col', md: 'row' }\"\n * 3. Function — called at render time; reactive deps are tracked by the\n * parent computed(): :dir=\"() => isNavOpen ? 'col' : 'row'\"\n *\n * Array form is also accepted for boolean props (first, last, reverse):\n * :first=\"['sm', 'md']\"\n */\nfunction processResponsiveProp<T>(\n prop:\n | T\n | Partial<Record<TBreakpoint, T>>\n | TBreakpoint[]\n | (() => T)\n | null\n | undefined,\n handler: (value: T, ctx: IHandlerContext) => void,\n classMap?: Record<string, string>,\n): TClassCollection {\n const collection: TClassCollection = {}\n\n if (prop == null) return collection\n\n // Function — call it; Vue's reactivity tracks deps inside the parent computed\n if (typeof prop === 'function') {\n const value = (prop as () => T)()\n if (value != null) {\n handler(value, { collection, classMap })\n }\n return collection\n }\n\n // Simple value (string, number, boolean)\n if (\n typeof prop === 'string' ||\n typeof prop === 'number' ||\n typeof prop === 'boolean'\n ) {\n handler(prop as T, { collection, classMap })\n return collection\n }\n\n // Array of breakpoints (for boolean props like first: ['sm', 'md'])\n if (Array.isArray(prop)) {\n prop.forEach((breakpoint) => {\n const normBp = normalizeBreakpoint(breakpoint as string)\n handler(true as T, { collection, breakpoint: normBp, classMap })\n })\n return collection\n }\n\n // Object (responsive map with breakpoint keys)\n if (typeof prop === 'object') {\n Object.entries(prop).forEach(([breakpoint, value]) => {\n if (value != null) {\n const normBp = normalizeBreakpoint(breakpoint)\n handler(value as T, { collection, breakpoint: normBp, classMap })\n }\n })\n }\n\n return collection\n}\n\n// ============================================================================\n// Main Class Generator\n// ============================================================================\n\n/**\n * Generates all CSS classes based on component props\n * Clean and declarative approach using separate handlers\n */\nconst generateGridClasses = (props: any): TClassCollection => {\n // Class mapping for semantic aliases\n const alignClassMap: Record<string, string> = {\n top: 'start',\n bottom: 'end',\n center: 'center',\n stretch: 'stretch',\n baseline: 'base',\n }\n\n const justifyClassMap: Record<string, string> = {\n left: 'start',\n right: 'end',\n center: 'center',\n between: 'between',\n around: 'around',\n evenly: 'evenly',\n }\n\n return {\n 'nb-grid': true,\n ...processResponsiveProp(props.dir, handleDirection),\n ...processResponsiveProp(props.align, handleAlign, alignClassMap),\n ...processResponsiveProp(props.justify, handleJustify, justifyClassMap),\n ...processResponsiveProp(props.gap, handleGap),\n ...processResponsiveProp(props.grid, handleGrid),\n ...processResponsiveProp(props.shift, handleShift),\n ...processResponsiveProp(props.wrap, handleWrap),\n ...processResponsiveProp(props.reverse, handleReverse),\n ...processResponsiveProp(props.first, (val, ctx) =>\n handleOrder(val, ctx, 'first'),\n ),\n ...processResponsiveProp(props.last, (val, ctx) =>\n handleOrder(val, ctx, 'last'),\n ),\n ...processResponsiveProp(props.visible, handleVisible),\n ...(props.flex ? { flex: true } : {}),\n ...(props.distributed ? { distributed: true } : {}),\n ...(props.mode ? { [props.mode]: true } : {}),\n ...(props.grow ? { grow: true } : {}),\n ...(props.shrink !== null && props.shrink !== undefined\n ? { [`shrink-${props.shrink ? '1' : '0'}`]: true }\n : {}),\n }\n}\n\n// Computed property for reactive class generation\nconst classes = computed(() => generateGridClasses(props))\n</script>\n","<template>\n <component\n :is=\"is\"\n :id=\"id\"\n ref=\"root\"\n :class=\"classes\"\n :tabindex=\"(tabIndex ?? !focusableElements.includes(is)) ? '-1' : '0'\"\n >\n <slot />\n </component>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed, ref } from 'vue'\nimport { gridPropDefinitions } from './Grid.d'\nimport type {\n TClassCollection,\n IHandlerContext,\n TGridType,\n TGridAlign,\n TGridJustify,\n TGridWrap,\n TBreakpoint,\n} from './Grid.d'\n\n// Focusable HTML elements\nconst focusableElements = [\n 'a',\n 'button',\n 'input',\n 'textarea',\n 'select',\n 'details',\n 'iframe',\n 'object',\n 'embed',\n 'area',\n 'audio',\n 'video',\n]\n\n// Component ref\nconst root = ref<HTMLElement>()\nconst getRef = () => root.value\n\ndefineExpose({\n getRef,\n})\n\n// Define props\nconst props = defineProps(gridPropDefinitions)\n\n// ============================================================================\n// Utility Functions\n// ============================================================================\n\n/**\n * Normalizes breakpoint names from camelCase to kebab-case\n * Example: 'mediumLarge' -> 'medium-large'\n */\nconst normalizeBreakpoint = (breakpoint: string): string =>\n breakpoint.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase()\n\n// ============================================================================\n// Individual Property Handlers\n// ============================================================================\n\n/**\n * Handles direction prop (row, col, row-reverse, col-reverse)\n */\nfunction handleDirection(value: TGridType, ctx: IHandlerContext): void {\n const { collection, breakpoint } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n\n // Skip base 'row' for responsive breakpoints (row is default)\n if (breakpoint && value === 'row') {\n return\n }\n\n collection[`${prefix}${value}`] = true\n}\n\n/**\n * Handles align prop (start, end, center, baseline, stretch)\n */\nfunction handleAlign(value: TGridAlign, ctx: IHandlerContext): void {\n const { collection, breakpoint, classMap } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n const mappedValue = classMap?.[value] ?? value\n\n collection[`${prefix}align-${mappedValue}`] = true\n}\n\n/**\n * Handles justify prop (around, between, center, end, evenly, start)\n */\nfunction handleJustify(value: TGridJustify, ctx: IHandlerContext): void {\n const { collection, breakpoint, classMap } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n const mappedValue = classMap?.[value] ?? value\n\n collection[`${prefix}justify-${mappedValue}`] = true\n}\n\n/**\n * Handles gap prop (xxs, xs, sm, md, lg, xl, xxl)\n */\nfunction handleGap(value: string, ctx: IHandlerContext): void {\n const { collection, breakpoint } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n\n collection[`${prefix}gap-${value}`] = true\n}\n\n/**\n * Handles grid prop (1-16 columns)\n */\nfunction handleGrid(value: number | string, ctx: IHandlerContext): void {\n const { collection, breakpoint } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n\n collection[`${prefix}grid-${value}`] = true\n}\n\n/**\n * Handles shift prop (0-15 columns offset)\n */\nfunction handleShift(value: number | string, ctx: IHandlerContext): void {\n const { collection, breakpoint } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n\n collection[`${prefix}shift-${value}`] = true\n}\n\n/**\n * Handles wrap prop (nowrap, wrap, reverse)\n */\nfunction handleWrap(value: TGridWrap, ctx: IHandlerContext): void {\n const { collection, breakpoint } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n\n collection[`${prefix}${value}`] = true\n}\n\n/**\n * Handles reverse prop\n */\nfunction handleReverse(value: boolean, ctx: IHandlerContext): void {\n if (!value) return\n\n const { collection, breakpoint } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n\n collection[`${prefix}reverse`] = true\n}\n\n/**\n * Handles order props (first, last)\n */\nfunction handleOrder(\n value: boolean,\n ctx: IHandlerContext,\n type: 'first' | 'last',\n): void {\n if (!value) return\n\n const { collection, breakpoint } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n\n collection[`${prefix}${type}`] = true\n}\n\n/**\n * Handles visible prop\n */\nfunction handleVisible(value: boolean, ctx: IHandlerContext): void {\n const { collection, breakpoint } = ctx\n const prefix = breakpoint ? `${breakpoint}-` : ''\n\n collection[`${prefix}${value ? 'visible' : 'hidden'}`] = true\n}\n\n// ============================================================================\n// Responsive Property Processor\n// ============================================================================\n\n/**\n * Generic processor for responsive props.\n * Handles three input modes:\n * 1. Scalar value — applies at all breakpoints: dir=\"col\"\n * 2. Breakpoint map — per-breakpoint object: :dir=\"{ sm: 'col', md: 'row' }\"\n * 3. Function — called at render time; reactive deps are tracked by the\n * parent computed(): :dir=\"() => isNavOpen ? 'col' : 'row'\"\n *\n * Array form is also accepted for boolean props (first, last, reverse):\n * :first=\"['sm', 'md']\"\n */\nfunction processResponsiveProp<T>(\n prop:\n | T\n | Partial<Record<TBreakpoint, T>>\n | TBreakpoint[]\n | (() => T)\n | null\n | undefined,\n handler: (value: T, ctx: IHandlerContext) => void,\n classMap?: Record<string, string>,\n): TClassCollection {\n const collection: TClassCollection = {}\n\n if (prop == null) return collection\n\n // Function — call it; Vue's reactivity tracks deps inside the parent computed\n if (typeof prop === 'function') {\n const value = (prop as () => T)()\n if (value != null) {\n handler(value, { collection, classMap })\n }\n return collection\n }\n\n // Simple value (string, number, boolean)\n if (\n typeof prop === 'string' ||\n typeof prop === 'number' ||\n typeof prop === 'boolean'\n ) {\n handler(prop as T, { collection, classMap })\n return collection\n }\n\n // Array of breakpoints (for boolean props like first: ['sm', 'md'])\n if (Array.isArray(prop)) {\n prop.forEach((breakpoint) => {\n const normBp = normalizeBreakpoint(breakpoint as string)\n handler(true as T, { collection, breakpoint: normBp, classMap })\n })\n return collection\n }\n\n // Object (responsive map with breakpoint keys)\n if (typeof prop === 'object') {\n Object.entries(prop).forEach(([breakpoint, value]) => {\n if (value != null) {\n const normBp = normalizeBreakpoint(breakpoint)\n handler(value as T, { collection, breakpoint: normBp, classMap })\n }\n })\n }\n\n return collection\n}\n\n// ============================================================================\n// Main Class Generator\n// ============================================================================\n\n/**\n * Generates all CSS classes based on component props\n * Clean and declarative approach using separate handlers\n */\nconst generateGridClasses = (props: any): TClassCollection => {\n // Class mapping for semantic aliases\n const alignClassMap: Record<string, string> = {\n top: 'start',\n bottom: 'end',\n center: 'center',\n stretch: 'stretch',\n baseline: 'base',\n }\n\n const justifyClassMap: Record<string, string> = {\n left: 'start',\n right: 'end',\n center: 'center',\n between: 'between',\n around: 'around',\n evenly: 'evenly',\n }\n\n return {\n 'nb-grid': true,\n ...processResponsiveProp(props.dir, handleDirection),\n ...processResponsiveProp(props.align, handleAlign, alignClassMap),\n ...processResponsiveProp(props.justify, handleJustify, justifyClassMap),\n ...processResponsiveProp(props.gap, handleGap),\n ...processResponsiveProp(props.grid, handleGrid),\n ...processResponsiveProp(props.shift, handleShift),\n ...processResponsiveProp(props.wrap, handleWrap),\n ...processResponsiveProp(props.reverse, handleReverse),\n ...processResponsiveProp(props.first, (val, ctx) =>\n handleOrder(val, ctx, 'first'),\n ),\n ...processResponsiveProp(props.last, (val, ctx) =>\n handleOrder(val, ctx, 'last'),\n ),\n ...processResponsiveProp(props.visible, handleVisible),\n ...(props.flex ? { flex: true } : {}),\n ...(props.distributed ? { distributed: true } : {}),\n ...(props.mode ? { [props.mode]: true } : {}),\n ...(props.grow ? { grow: true } : {}),\n ...(props.shrink !== null && props.shrink !== undefined\n ? { [`shrink-${props.shrink ? '1' : '0'}`]: true }\n : {}),\n }\n}\n\n// Computed property for reactive class generation\nconst classes = computed(() => generateGridClasses(props))\n</script>\n","/*!\n * shared v11.3.0\n * (c) 2026 kazuya kawaguchi\n * Released under the MIT License.\n */\nfunction warn(msg, err) {\n if (typeof console !== 'undefined') {\n console.warn(`[intlify] ` + msg);\n /* istanbul ignore if */\n if (err) {\n console.warn(err.stack);\n }\n }\n}\nconst hasWarned = {};\nfunction warnOnce(msg) {\n if (!hasWarned[msg]) {\n hasWarned[msg] = true;\n warn(msg);\n }\n}\n\n/**\n * Original Utilities\n * written by kazuya kawaguchi\n */\nconst inBrowser = typeof window !== 'undefined';\nlet mark;\nlet measure;\nif ((process.env.NODE_ENV !== 'production')) {\n const perf = inBrowser && window.performance;\n if (perf &&\n perf.mark &&\n perf.measure &&\n perf.clearMarks &&\n // @ts-ignore browser compat\n perf.clearMeasures) {\n mark = (tag) => {\n perf.mark(tag);\n };\n measure = (name, startTag, endTag) => {\n perf.measure(name, startTag, endTag);\n perf.clearMarks(startTag);\n perf.clearMarks(endTag);\n };\n }\n}\nconst RE_ARGS = /\\{([0-9a-zA-Z]+)\\}/g;\n/* eslint-disable */\nfunction format(message, ...args) {\n if (args.length === 1 && isObject(args[0])) {\n args = args[0];\n }\n if (!args || !args.hasOwnProperty) {\n args = {};\n }\n return message.replace(RE_ARGS, (match, identifier) => {\n return args.hasOwnProperty(identifier) ? args[identifier] : '';\n });\n}\nconst makeSymbol = (name, shareable = false) => !shareable ? Symbol(name) : Symbol.for(name);\nconst generateFormatCacheKey = (locale, key, source) => friendlyJSONstringify({ l: locale, k: key, s: source });\nconst friendlyJSONstringify = (json) => JSON.stringify(json)\n .replace(/\\u2028/g, '\\\\u2028')\n .replace(/\\u2029/g, '\\\\u2029')\n .replace(/\\u0027/g, '\\\\u0027');\nconst isNumber = (val) => typeof val === 'number' && isFinite(val);\nconst isDate = (val) => toTypeString(val) === '[object Date]';\nconst isRegExp = (val) => toTypeString(val) === '[object RegExp]';\nconst isEmptyObject = (val) => isPlainObject(val) && Object.keys(val).length === 0;\nconst assign = Object.assign;\nconst _create = Object.create;\nconst create = (obj = null) => _create(obj);\nlet _globalThis;\nconst getGlobalThis = () => {\n // prettier-ignore\n return (_globalThis ||\n (_globalThis =\n typeof globalThis !== 'undefined'\n ? globalThis\n : typeof self !== 'undefined'\n ? self\n : typeof window !== 'undefined'\n ? window\n : typeof global !== 'undefined'\n ? global\n : create()));\n};\nfunction escapeHtml(rawText) {\n return rawText\n .replace(/&/g, '&amp;') // escape `&` first to avoid double escaping\n .replace(/</g, '&lt;')\n .replace(/>/g, '&gt;')\n .replace(/\"/g, '&quot;')\n .replace(/'/g, '&apos;')\n .replace(/\\//g, '&#x2F;') // escape `/` to prevent closing tags or JavaScript URLs\n .replace(/=/g, '&#x3D;'); // escape `=` to prevent attribute injection\n}\nfunction escapeAttributeValue(value) {\n return value\n .replace(/&(?![a-zA-Z0-9#]{2,6};)/g, '&amp;') // escape unescaped `&`\n .replace(/\"/g, '&quot;')\n .replace(/'/g, '&apos;')\n .replace(/</g, '&lt;')\n .replace(/>/g, '&gt;');\n}\nfunction sanitizeTranslatedHtml(html) {\n // Escape dangerous characters in attribute values\n // Process attributes with double quotes\n html = html.replace(/(\\w+)\\s*=\\s*\"([^\"]*)\"/g, (_, attrName, attrValue) => `${attrName}=\"${escapeAttributeValue(attrValue)}\"`);\n // Process attributes with single quotes\n html = html.replace(/(\\w+)\\s*=\\s*'([^']*)'/g, (_, attrName, attrValue) => `${attrName}='${escapeAttributeValue(attrValue)}'`);\n // Detect and neutralize event handler attributes\n const eventHandlerPattern = /\\s*on\\w+\\s*=\\s*[\"']?[^\"'>]+[\"']?/gi;\n if (eventHandlerPattern.test(html)) {\n if ((process.env.NODE_ENV !== 'production')) {\n warn('Potentially dangerous event handlers detected in translation. ' +\n 'Consider removing onclick, onerror, etc. from your translation messages.');\n }\n // Neutralize event handler attributes by escaping 'on'\n html = html.replace(/(\\s+)(on)(\\w+\\s*=)/gi, '$1&#111;n$3');\n }\n // Disable javascript: URLs in various contexts\n const javascriptUrlPattern = [\n // In href, src, action, formaction attributes\n /(\\s+(?:href|src|action|formaction)\\s*=\\s*[\"']?)\\s*javascript:/gi,\n // In style attributes within url()\n /(style\\s*=\\s*[\"'][^\"']*url\\s*\\(\\s*)javascript:/gi\n ];\n javascriptUrlPattern.forEach(pattern => {\n html = html.replace(pattern, '$1javascript&#58;');\n });\n return html;\n}\nconst hasOwnProperty = Object.prototype.hasOwnProperty;\nfunction hasOwn(obj, key) {\n return hasOwnProperty.call(obj, key);\n}\n/* eslint-enable */\n/**\n * Useful Utilities By Evan you\n * Modified by kazuya kawaguchi\n * MIT License\n * https://github.com/vuejs/vue-next/blob/master/packages/shared/src/index.ts\n * https://github.com/vuejs/vue-next/blob/master/packages/shared/src/codeframe.ts\n */\nconst isArray = Array.isArray;\nconst isFunction = (val) => typeof val === 'function';\nconst isString = (val) => typeof val === 'string';\nconst isBoolean = (val) => typeof val === 'boolean';\nconst isSymbol = (val) => typeof val === 'symbol';\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst isObject = (val) => val !== null && typeof val === 'object';\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst isPromise = (val) => {\n return isObject(val) && isFunction(val.then) && isFunction(val.catch);\n};\nconst objectToString = Object.prototype.toString;\nconst toTypeString = (value) => objectToString.call(value);\nconst isPlainObject = (val) => toTypeString(val) === '[object Object]';\n// for converting list and named values to displayed strings.\nconst toDisplayString = (val) => {\n return val == null\n ? ''\n : isArray(val) || (isPlainObject(val) && val.toString === objectToString)\n ? JSON.stringify(val, null, 2)\n : String(val);\n};\nfunction join(items, separator = '') {\n return items.reduce((str, item, index) => (index === 0 ? str + item : str + separator + item), '');\n}\nconst RANGE = 2;\nfunction generateCodeFrame(source, start = 0, end = source.length) {\n const lines = source.split(/\\r?\\n/);\n let count = 0;\n const res = [];\n for (let i = 0; i < lines.length; i++) {\n count += lines[i].length + 1;\n if (count >= start) {\n for (let j = i - RANGE; j <= i + RANGE || end > count; j++) {\n if (j < 0 || j >= lines.length)\n continue;\n const line = j + 1;\n res.push(`${line}${' '.repeat(3 - String(line).length)}| ${lines[j]}`);\n const lineLength = lines[j].length;\n if (j === i) {\n // push underline\n const pad = start - (count - lineLength) + 1;\n const length = Math.max(1, end > count ? lineLength - pad : end - start);\n res.push(` | ` + ' '.repeat(pad) + '^'.repeat(length));\n }\n else if (j > i) {\n if (end > count) {\n const length = Math.max(Math.min(end - count, lineLength), 1);\n res.push(` | ` + '^'.repeat(length));\n }\n count += lineLength + 1;\n }\n }\n break;\n }\n }\n return res.join('\\n');\n}\n\n/**\n * Event emitter, forked from the below:\n * - original repository url: https://github.com/developit/mitt\n * - code url: https://github.com/developit/mitt/blob/master/src/index.ts\n * - author: Jason Miller (https://github.com/developit)\n * - license: MIT\n */\n/**\n * Create a event emitter\n *\n * @returns An event emitter\n */\nfunction createEmitter() {\n const events = new Map();\n const emitter = {\n events,\n on(event, handler) {\n const handlers = events.get(event);\n const added = handlers && handlers.push(handler);\n if (!added) {\n events.set(event, [handler]);\n }\n },\n off(event, handler) {\n const handlers = events.get(event);\n if (handlers) {\n handlers.splice(handlers.indexOf(handler) >>> 0, 1);\n }\n },\n emit(event, payload) {\n (events.get(event) || [])\n .slice()\n .map(handler => handler(payload));\n (events.get('*') || [])\n .slice()\n .map(handler => handler(event, payload));\n }\n };\n return emitter;\n}\n\nconst isNotObjectOrIsArray = (val) => !isObject(val) || isArray(val);\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction deepCopy(src, des) {\n // src and des should both be objects, and none of them can be a array\n if (isNotObjectOrIsArray(src) || isNotObjectOrIsArray(des)) {\n throw new Error('Invalid value');\n }\n const stack = [{ src, des }];\n while (stack.length) {\n const { src, des } = stack.pop();\n // using `Object.keys` which skips prototype properties\n Object.keys(src).forEach(key => {\n if (key === '__proto__') {\n return;\n }\n // if src[key] is an object/array, set des[key]\n // to empty object/array to prevent setting by reference\n if (isObject(src[key]) && !isObject(des[key])) {\n des[key] = Array.isArray(src[key]) ? [] : create();\n }\n if (isNotObjectOrIsArray(des[key]) || isNotObjectOrIsArray(src[key])) {\n // replace with src[key] when:\n // src[key] or des[key] is not an object, or\n // src[key] or des[key] is an array\n des[key] = src[key];\n }\n else {\n // src[key] and des[key] are both objects, merge them\n stack.push({ src: src[key], des: des[key] });\n }\n });\n }\n}\n\nexport { assign, create, createEmitter, deepCopy, escapeHtml, format, friendlyJSONstringify, generateCodeFrame, generateFormatCacheKey, getGlobalThis, hasOwn, inBrowser, isArray, isBoolean, isDate, isEmptyObject, isFunction, isNumber, isObject, isPlainObject, isPromise, isRegExp, isString, isSymbol, join, makeSymbol, mark, measure, objectToString, sanitizeTranslatedHtml, toDisplayString, toTypeString, warn, warnOnce };\n","/*!\n * message-compiler v11.3.0\n * (c) 2026 kazuya kawaguchi\n * Released under the MIT License.\n */\nimport { format, assign, join, isString } from '@intlify/shared';\n\nconst LOCATION_STUB = {\n start: { line: 1, column: 1, offset: 0 },\n end: { line: 1, column: 1, offset: 0 }\n};\nfunction createPosition(line, column, offset) {\n return { line, column, offset };\n}\nfunction createLocation(start, end, source) {\n const loc = { start, end };\n if (source != null) {\n loc.source = source;\n }\n return loc;\n}\n\nconst CompileErrorCodes = {\n // tokenizer error codes\n EXPECTED_TOKEN: 1,\n INVALID_TOKEN_IN_PLACEHOLDER: 2,\n UNTERMINATED_SINGLE_QUOTE_IN_PLACEHOLDER: 3,\n UNKNOWN_ESCAPE_SEQUENCE: 4,\n INVALID_UNICODE_ESCAPE_SEQUENCE: 5,\n UNBALANCED_CLOSING_BRACE: 6,\n UNTERMINATED_CLOSING_BRACE: 7,\n EMPTY_PLACEHOLDER: 8,\n NOT_ALLOW_NEST_PLACEHOLDER: 9,\n INVALID_LINKED_FORMAT: 10,\n // parser error codes\n MUST_HAVE_MESSAGES_IN_PLURAL: 11,\n UNEXPECTED_EMPTY_LINKED_MODIFIER: 12,\n UNEXPECTED_EMPTY_LINKED_KEY: 13,\n UNEXPECTED_LEXICAL_ANALYSIS: 14,\n // generator error codes\n UNHANDLED_CODEGEN_NODE_TYPE: 15,\n // minifier error codes\n UNHANDLED_MINIFIER_NODE_TYPE: 16\n};\n// Special value for higher-order compilers to pick up the last code\n// to avoid collision of error codes.\n// This should always be kept as the last item.\nconst COMPILE_ERROR_CODES_EXTEND_POINT = 17;\n/** @internal */\nconst errorMessages = {\n // tokenizer error messages\n [CompileErrorCodes.EXPECTED_TOKEN]: `Expected token: '{0}'`,\n [CompileErrorCodes.INVALID_TOKEN_IN_PLACEHOLDER]: `Invalid token in placeholder: '{0}'`,\n [CompileErrorCodes.UNTERMINATED_SINGLE_QUOTE_IN_PLACEHOLDER]: `Unterminated single quote in placeholder`,\n [CompileErrorCodes.UNKNOWN_ESCAPE_SEQUENCE]: `Unknown escape sequence: \\\\{0}`,\n [CompileErrorCodes.INVALID_UNICODE_ESCAPE_SEQUENCE]: `Invalid unicode escape sequence: {0}`,\n [CompileErrorCodes.UNBALANCED_CLOSING_BRACE]: `Unbalanced closing brace`,\n [CompileErrorCodes.UNTERMINATED_CLOSING_BRACE]: `Unterminated closing brace`,\n [CompileErrorCodes.EMPTY_PLACEHOLDER]: `Empty placeholder`,\n [CompileErrorCodes.NOT_ALLOW_NEST_PLACEHOLDER]: `Not allowed nest placeholder`,\n [CompileErrorCodes.INVALID_LINKED_FORMAT]: `Invalid linked format`,\n // parser error messages\n [CompileErrorCodes.MUST_HAVE_MESSAGES_IN_PLURAL]: `Plural must have messages`,\n [CompileErrorCodes.UNEXPECTED_EMPTY_LINKED_MODIFIER]: `Unexpected empty linked modifier`,\n [CompileErrorCodes.UNEXPECTED_EMPTY_LINKED_KEY]: `Unexpected empty linked key`,\n [CompileErrorCodes.UNEXPECTED_LEXICAL_ANALYSIS]: `Unexpected lexical analysis in token: '{0}'`,\n // generator error messages\n [CompileErrorCodes.UNHANDLED_CODEGEN_NODE_TYPE]: `unhandled codegen node type: '{0}'`,\n // minimizer error messages\n [CompileErrorCodes.UNHANDLED_MINIFIER_NODE_TYPE]: `unhandled mimifier node type: '{0}'`\n};\nfunction createCompileError(code, loc, options = {}) {\n const { domain, messages, args } = options;\n const msg = (process.env.NODE_ENV !== 'production')\n ? format((messages || errorMessages)[code] || '', ...(args || []))\n : code;\n const error = new SyntaxError(String(msg));\n error.code = code;\n if (loc) {\n error.location = loc;\n }\n error.domain = domain;\n return error;\n}\n/** @internal */\nfunction defaultOnError(error) {\n throw error;\n}\n\n// eslint-disable-next-line no-useless-escape\nconst RE_HTML_TAG = /<\\/?[\\w\\s=\"/.':;#-\\/]+>/;\nconst detectHtmlTag = (source) => RE_HTML_TAG.test(source);\n\nconst CHAR_SP = ' ';\nconst CHAR_CR = '\\r';\nconst CHAR_LF = '\\n';\nconst CHAR_LS = String.fromCharCode(0x2028);\nconst CHAR_PS = String.fromCharCode(0x2029);\nfunction createScanner(str) {\n const _buf = str;\n let _index = 0;\n let _line = 1;\n let _column = 1;\n let _peekOffset = 0;\n const isCRLF = (index) => _buf[index] === CHAR_CR && _buf[index + 1] === CHAR_LF;\n const isLF = (index) => _buf[index] === CHAR_LF;\n const isPS = (index) => _buf[index] === CHAR_PS;\n const isLS = (index) => _buf[index] === CHAR_LS;\n const isLineEnd = (index) => isCRLF(index) || isLF(index) || isPS(index) || isLS(index);\n const index = () => _index;\n const line = () => _line;\n const column = () => _column;\n const peekOffset = () => _peekOffset;\n const charAt = (offset) => isCRLF(offset) || isPS(offset) || isLS(offset) ? CHAR_LF : _buf[offset];\n const currentChar = () => charAt(_index);\n const currentPeek = () => charAt(_index + _peekOffset);\n function next() {\n _peekOffset = 0;\n if (isLineEnd(_index)) {\n _line++;\n _column = 0;\n }\n if (isCRLF(_index)) {\n _index++;\n }\n _index++;\n _column++;\n return _buf[_index];\n }\n function peek() {\n if (isCRLF(_index + _peekOffset)) {\n _peekOffset++;\n }\n _peekOffset++;\n return _buf[_index + _peekOffset];\n }\n function reset() {\n _index = 0;\n _line = 1;\n _column = 1;\n _peekOffset = 0;\n }\n function resetPeek(offset = 0) {\n _peekOffset = offset;\n }\n function skipToPeek() {\n const target = _index + _peekOffset;\n while (target !== _index) {\n next();\n }\n _peekOffset = 0;\n }\n return {\n index,\n line,\n column,\n peekOffset,\n charAt,\n currentChar,\n currentPeek,\n next,\n peek,\n reset,\n resetPeek,\n skipToPeek\n };\n}\n\nconst EOF = undefined;\nconst DOT = '.';\nconst LITERAL_DELIMITER = \"'\";\nconst ERROR_DOMAIN$3 = 'tokenizer';\nfunction createTokenizer(source, options = {}) {\n const location = options.location !== false;\n const _scnr = createScanner(source);\n const currentOffset = () => _scnr.index();\n const currentPosition = () => createPosition(_scnr.line(), _scnr.column(), _scnr.index());\n const _initLoc = currentPosition();\n const _initOffset = currentOffset();\n const _context = {\n currentType: 13 /* TokenTypes.EOF */,\n offset: _initOffset,\n startLoc: _initLoc,\n endLoc: _initLoc,\n lastType: 13 /* TokenTypes.EOF */,\n lastOffset: _initOffset,\n lastStartLoc: _initLoc,\n lastEndLoc: _initLoc,\n braceNest: 0,\n inLinked: false,\n text: ''\n };\n const context = () => _context;\n const { onError } = options;\n function emitError(code, pos, offset, ...args) {\n const ctx = context();\n pos.column += offset;\n pos.offset += offset;\n if (onError) {\n const loc = location ? createLocation(ctx.startLoc, pos) : null;\n const err = createCompileError(code, loc, {\n domain: ERROR_DOMAIN$3,\n args\n });\n onError(err);\n }\n }\n function getToken(context, type, value) {\n context.endLoc = currentPosition();\n context.currentType = type;\n const token = { type };\n if (location) {\n token.loc = createLocation(context.startLoc, context.endLoc);\n }\n if (value != null) {\n token.value = value;\n }\n return token;\n }\n const getEndToken = (context) => getToken(context, 13 /* TokenTypes.EOF */);\n function eat(scnr, ch) {\n if (scnr.currentChar() === ch) {\n scnr.next();\n return ch;\n }\n else {\n emitError(CompileErrorCodes.EXPECTED_TOKEN, currentPosition(), 0, ch);\n return '';\n }\n }\n function peekSpaces(scnr) {\n let buf = '';\n while (scnr.currentPeek() === CHAR_SP || scnr.currentPeek() === CHAR_LF) {\n buf += scnr.currentPeek();\n scnr.peek();\n }\n return buf;\n }\n function skipSpaces(scnr) {\n const buf = peekSpaces(scnr);\n scnr.skipToPeek();\n return buf;\n }\n function isIdentifierStart(ch) {\n if (ch === EOF) {\n return false;\n }\n const cc = ch.charCodeAt(0);\n return ((cc >= 97 && cc <= 122) || // a-z\n (cc >= 65 && cc <= 90) || // A-Z\n cc === 95 // _\n );\n }\n function isNumberStart(ch) {\n if (ch === EOF) {\n return false;\n }\n const cc = ch.charCodeAt(0);\n return cc >= 48 && cc <= 57; // 0-9\n }\n function isNamedIdentifierStart(scnr, context) {\n const { currentType } = context;\n if (currentType !== 2 /* TokenTypes.BraceLeft */) {\n return false;\n }\n peekSpaces(scnr);\n const ret = isIdentifierStart(scnr.currentPeek());\n scnr.resetPeek();\n return ret;\n }\n function isListIdentifierStart(scnr, context) {\n const { currentType } = context;\n if (currentType !== 2 /* TokenTypes.BraceLeft */) {\n return false;\n }\n peekSpaces(scnr);\n const ch = scnr.currentPeek() === '-' ? scnr.peek() : scnr.currentPeek();\n const ret = isNumberStart(ch);\n scnr.resetPeek();\n return ret;\n }\n function isLiteralStart(scnr, context) {\n const { currentType } = context;\n if (currentType !== 2 /* TokenTypes.BraceLeft */) {\n return false;\n }\n peekSpaces(scnr);\n const ret = scnr.currentPeek() === LITERAL_DELIMITER;\n scnr.resetPeek();\n return ret;\n }\n function isLinkedDotStart(scnr, context) {\n const { currentType } = context;\n if (currentType !== 7 /* TokenTypes.LinkedAlias */) {\n return false;\n }\n peekSpaces(scnr);\n const ret = scnr.currentPeek() === \".\" /* TokenChars.LinkedDot */;\n scnr.resetPeek();\n return ret;\n }\n function isLinkedModifierStart(scnr, context) {\n const { currentType } = context;\n if (currentType !== 8 /* TokenTypes.LinkedDot */) {\n return false;\n }\n peekSpaces(scnr);\n const ret = isIdentifierStart(scnr.currentPeek());\n scnr.resetPeek();\n return ret;\n }\n function isLinkedDelimiterStart(scnr, context) {\n const { currentType } = context;\n if (!(currentType === 7 /* TokenTypes.LinkedAlias */ ||\n currentType === 11 /* TokenTypes.LinkedModifier */)) {\n return false;\n }\n peekSpaces(scnr);\n const ret = scnr.currentPeek() === \":\" /* TokenChars.LinkedDelimiter */;\n scnr.resetPeek();\n return ret;\n }\n function isLinkedReferStart(scnr, context) {\n const { currentType } = context;\n if (currentType !== 9 /* TokenTypes.LinkedDelimiter */) {\n return false;\n }\n const fn = () => {\n const ch = scnr.currentPeek();\n if (ch === \"{\" /* TokenChars.BraceLeft */) {\n return isIdentifierStart(scnr.peek());\n }\n else if (ch === \"@\" /* TokenChars.LinkedAlias */ ||\n ch === \"|\" /* TokenChars.Pipe */ ||\n ch === \":\" /* TokenChars.LinkedDelimiter */ ||\n ch === \".\" /* TokenChars.LinkedDot */ ||\n ch === CHAR_SP ||\n !ch) {\n return false;\n }\n else if (ch === CHAR_LF) {\n scnr.peek();\n return fn();\n }\n else {\n // other characters\n return isTextStart(scnr, false);\n }\n };\n const ret = fn();\n scnr.resetPeek();\n return ret;\n }\n function isPluralStart(scnr) {\n peekSpaces(scnr);\n const ret = scnr.currentPeek() === \"|\" /* TokenChars.Pipe */;\n scnr.resetPeek();\n return ret;\n }\n function isTextStart(scnr, reset = true) {\n const fn = (hasSpace = false, prev = '') => {\n const ch = scnr.currentPeek();\n if (ch === \"{\" /* TokenChars.BraceLeft */) {\n return hasSpace;\n }\n else if (ch === \"@\" /* TokenChars.LinkedAlias */ || !ch) {\n return hasSpace;\n }\n else if (ch === \"|\" /* TokenChars.Pipe */) {\n return !(prev === CHAR_SP || prev === CHAR_LF);\n }\n else if (ch === CHAR_SP) {\n scnr.peek();\n return fn(true, CHAR_SP);\n }\n else if (ch === CHAR_LF) {\n scnr.peek();\n return fn(true, CHAR_LF);\n }\n else {\n return true;\n }\n };\n const ret = fn();\n reset && scnr.resetPeek();\n return ret;\n }\n function takeChar(scnr, fn) {\n const ch = scnr.currentChar();\n if (ch === EOF) {\n return EOF;\n }\n if (fn(ch)) {\n scnr.next();\n return ch;\n }\n return null;\n }\n function isIdentifier(ch) {\n const cc = ch.charCodeAt(0);\n return ((cc >= 97 && cc <= 122) || // a-z\n (cc >= 65 && cc <= 90) || // A-Z\n (cc >= 48 && cc <= 57) || // 0-9\n cc === 95 || // _\n cc === 36 // $\n );\n }\n function takeIdentifierChar(scnr) {\n return takeChar(scnr, isIdentifier);\n }\n function isNamedIdentifier(ch) {\n const cc = ch.charCodeAt(0);\n return ((cc >= 97 && cc <= 122) || // a-z\n (cc >= 65 && cc <= 90) || // A-Z\n (cc >= 48 && cc <= 57) || // 0-9\n cc === 95 || // _\n cc === 36 || // $\n cc === 45 // -\n );\n }\n function takeNamedIdentifierChar(scnr) {\n return takeChar(scnr, isNamedIdentifier);\n }\n function isDigit(ch) {\n const cc = ch.charCodeAt(0);\n return cc >= 48 && cc <= 57; // 0-9\n }\n function takeDigit(scnr) {\n return takeChar(scnr, isDigit);\n }\n function isHexDigit(ch) {\n const cc = ch.charCodeAt(0);\n return ((cc >= 48 && cc <= 57) || // 0-9\n (cc >= 65 && cc <= 70) || // A-F\n (cc >= 97 && cc <= 102)); // a-f\n }\n function takeHexDigit(scnr) {\n return takeChar(scnr, isHexDigit);\n }\n function getDigits(scnr) {\n let ch = '';\n let num = '';\n while ((ch = takeDigit(scnr))) {\n num += ch;\n }\n return num;\n }\n function readText(scnr) {\n let buf = '';\n while (true) {\n const ch = scnr.currentChar();\n if (ch === '\\\\') {\n const nextCh = scnr.peek();\n if (nextCh === \"{\" /* TokenChars.BraceLeft */ ||\n nextCh === \"}\" /* TokenChars.BraceRight */ ||\n nextCh === \"@\" /* TokenChars.LinkedAlias */ ||\n nextCh === \"|\" /* TokenChars.Pipe */ ||\n nextCh === '\\\\') {\n buf += ch + nextCh;\n scnr.next();\n scnr.next();\n }\n else {\n scnr.resetPeek();\n buf += ch;\n scnr.next();\n }\n }\n else if (ch === \"{\" /* TokenChars.BraceLeft */ ||\n ch === \"}\" /* TokenChars.BraceRight */ ||\n ch === \"@\" /* TokenChars.LinkedAlias */ ||\n ch === \"|\" /* TokenChars.Pipe */ ||\n !ch) {\n break;\n }\n else if (ch === CHAR_SP || ch === CHAR_LF) {\n if (isTextStart(scnr)) {\n buf += ch;\n scnr.next();\n }\n else if (isPluralStart(scnr)) {\n break;\n }\n else {\n buf += ch;\n scnr.next();\n }\n }\n else {\n buf += ch;\n scnr.next();\n }\n }\n return buf;\n }\n function readNamedIdentifier(scnr) {\n skipSpaces(scnr);\n let ch = '';\n let name = '';\n while ((ch = takeNamedIdentifierChar(scnr))) {\n name += ch;\n }\n // Check if takeNamedIdentifierChar stoped because of invalid characters\n const currentChar = scnr.currentChar();\n if (currentChar &&\n currentChar !== '}' &&\n currentChar !== EOF &&\n currentChar !== CHAR_SP &&\n currentChar !== CHAR_LF &&\n currentChar !== '\\u3000') {\n const invalidPart = readInvalidIdentifier(scnr);\n emitError(CompileErrorCodes.INVALID_TOKEN_IN_PLACEHOLDER, currentPosition(), 0, name + invalidPart);\n return name + invalidPart;\n }\n if (scnr.currentChar() === EOF) {\n emitError(CompileErrorCodes.UNTERMINATED_CLOSING_BRACE, currentPosition(), 0);\n }\n return name;\n }\n function readListIdentifier(scnr) {\n skipSpaces(scnr);\n let value = '';\n if (scnr.currentChar() === '-') {\n scnr.next();\n value += `-${getDigits(scnr)}`;\n }\n else {\n value += getDigits(scnr);\n }\n if (scnr.currentChar() === EOF) {\n emitError(CompileErrorCodes.UNTERMINATED_CLOSING_BRACE, currentPosition(), 0);\n }\n return value;\n }\n function isLiteral(ch) {\n return ch !== LITERAL_DELIMITER && ch !== CHAR_LF;\n }\n function readLiteral(scnr) {\n skipSpaces(scnr);\n // eslint-disable-next-line no-useless-escape\n eat(scnr, `\\'`);\n let ch = '';\n let literal = '';\n while ((ch = takeChar(scnr, isLiteral))) {\n if (ch === '\\\\') {\n literal += readEscapeSequence(scnr);\n }\n else {\n literal += ch;\n }\n }\n const current = scnr.currentChar();\n if (current === CHAR_LF || current === EOF) {\n emitError(CompileErrorCodes.UNTERMINATED_SINGLE_QUOTE_IN_PLACEHOLDER, currentPosition(), 0);\n // TODO: Is it correct really?\n if (current === CHAR_LF) {\n scnr.next();\n // eslint-disable-next-line no-useless-escape\n eat(scnr, `\\'`);\n }\n return literal;\n }\n // eslint-disable-next-line no-useless-escape\n eat(scnr, `\\'`);\n return literal;\n }\n function readEscapeSequence(scnr) {\n const ch = scnr.currentChar();\n switch (ch) {\n case '\\\\':\n case `\\'`: // eslint-disable-line no-useless-escape\n scnr.next();\n return `\\\\${ch}`;\n case 'u':\n return readUnicodeEscapeSequence(scnr, ch, 4);\n case 'U':\n return readUnicodeEscapeSequence(scnr, ch, 6);\n default:\n emitError(CompileErrorCodes.UNKNOWN_ESCAPE_SEQUENCE, currentPosition(), 0, ch);\n return '';\n }\n }\n function readUnicodeEscapeSequence(scnr, unicode, digits) {\n eat(scnr, unicode);\n let sequence = '';\n for (let i = 0; i < digits; i++) {\n const ch = takeHexDigit(scnr);\n if (!ch) {\n emitError(CompileErrorCodes.INVALID_UNICODE_ESCAPE_SEQUENCE, currentPosition(), 0, `\\\\${unicode}${sequence}${scnr.currentChar()}`);\n break;\n }\n sequence += ch;\n }\n return `\\\\${unicode}${sequence}`;\n }\n function isInvalidIdentifier(ch) {\n return (ch !== \"{\" /* TokenChars.BraceLeft */ &&\n ch !== \"}\" /* TokenChars.BraceRight */ &&\n ch !== CHAR_SP &&\n ch !== CHAR_LF);\n }\n function readInvalidIdentifier(scnr) {\n skipSpaces(scnr);\n let ch = '';\n let identifiers = '';\n while ((ch = takeChar(scnr, isInvalidIdentifier))) {\n identifiers += ch;\n }\n return identifiers;\n }\n function readLinkedModifier(scnr) {\n let ch = '';\n let name = '';\n while ((ch = takeIdentifierChar(scnr))) {\n name += ch;\n }\n return name;\n }\n function readLinkedRefer(scnr) {\n const fn = (buf) => {\n const ch = scnr.currentChar();\n if (ch === \"{\" /* TokenChars.BraceLeft */ ||\n ch === \"@\" /* TokenChars.LinkedAlias */ ||\n ch === \"|\" /* TokenChars.Pipe */ ||\n ch === \"(\" /* TokenChars.ParenLeft */ ||\n ch === \")\" /* TokenChars.ParenRight */ ||\n !ch) {\n return buf;\n }\n else if (ch === CHAR_SP) {\n return buf;\n }\n else if (ch === CHAR_LF || ch === DOT) {\n buf += ch;\n scnr.next();\n return fn(buf);\n }\n else {\n buf += ch;\n scnr.next();\n return fn(buf);\n }\n };\n return fn('');\n }\n function readPlural(scnr) {\n skipSpaces(scnr);\n const plural = eat(scnr, \"|\" /* TokenChars.Pipe */);\n skipSpaces(scnr);\n return plural;\n }\n // TODO: We need refactoring of token parsing ...\n function readTokenInPlaceholder(scnr, context) {\n let token = null;\n const ch = scnr.currentChar();\n switch (ch) {\n case \"{\" /* TokenChars.BraceLeft */:\n if (context.braceNest >= 1) {\n emitError(CompileErrorCodes.NOT_ALLOW_NEST_PLACEHOLDER, currentPosition(), 0);\n }\n scnr.next();\n token = getToken(context, 2 /* TokenTypes.BraceLeft */, \"{\" /* TokenChars.BraceLeft */);\n skipSpaces(scnr);\n context.braceNest++;\n return token;\n case \"}\" /* TokenChars.BraceRight */:\n if (context.braceNest > 0 &&\n context.currentType === 2 /* TokenTypes.BraceLeft */) {\n emitError(CompileErrorCodes.EMPTY_PLACEHOLDER, currentPosition(), 0);\n }\n scnr.next();\n token = getToken(context, 3 /* TokenTypes.BraceRight */, \"}\" /* TokenChars.BraceRight */);\n context.braceNest--;\n context.braceNest > 0 && skipSpaces(scnr);\n if (context.inLinked && context.braceNest === 0) {\n context.inLinked = false;\n }\n return token;\n case \"@\" /* TokenChars.LinkedAlias */:\n if (context.braceNest > 0) {\n emitError(CompileErrorCodes.UNTERMINATED_CLOSING_BRACE, currentPosition(), 0);\n }\n token = readTokenInLinked(scnr, context) || getEndToken(context);\n context.braceNest = 0;\n return token;\n default: {\n let validNamedIdentifier = true;\n let validListIdentifier = true;\n let validLiteral = true;\n if (isPluralStart(scnr)) {\n if (context.braceNest > 0) {\n emitError(CompileErrorCodes.UNTERMINATED_CLOSING_BRACE, currentPosition(), 0);\n }\n token = getToken(context, 1 /* TokenTypes.Pipe */, readPlural(scnr));\n // reset\n context.braceNest = 0;\n context.inLinked = false;\n return token;\n }\n if (context.braceNest > 0 &&\n (context.currentType === 4 /* TokenTypes.Named */ ||\n context.currentType === 5 /* TokenTypes.List */ ||\n context.currentType === 6 /* TokenTypes.Literal */)) {\n emitError(CompileErrorCodes.UNTERMINATED_CLOSING_BRACE, currentPosition(), 0);\n context.braceNest = 0;\n return readToken(scnr, context);\n }\n if ((validNamedIdentifier = isNamedIdentifierStart(scnr, context))) {\n token = getToken(context, 4 /* TokenTypes.Named */, readNamedIdentifier(scnr));\n skipSpaces(scnr);\n return token;\n }\n if ((validListIdentifier = isListIdentifierStart(scnr, context))) {\n token = getToken(context, 5 /* TokenTypes.List */, readListIdentifier(scnr));\n skipSpaces(scnr);\n return token;\n }\n if ((validLiteral = isLiteralStart(scnr, context))) {\n token = getToken(context, 6 /* TokenTypes.Literal */, readLiteral(scnr));\n skipSpaces(scnr);\n return token;\n }\n if (!validNamedIdentifier && !validListIdentifier && !validLiteral) {\n // TODO: we should be re-designed invalid cases, when we will extend message syntax near the future ...\n token = getToken(context, 12 /* TokenTypes.InvalidPlace */, readInvalidIdentifier(scnr));\n emitError(CompileErrorCodes.INVALID_TOKEN_IN_PLACEHOLDER, currentPosition(), 0, token.value);\n skipSpaces(scnr);\n return token;\n }\n break;\n }\n }\n return token;\n }\n // TODO: We need refactoring of token parsing ...\n function readTokenInLinked(scnr, context) {\n const { currentType } = context;\n let token = null;\n const ch = scnr.currentChar();\n if ((currentType === 7 /* TokenTypes.LinkedAlias */ ||\n currentType === 8 /* TokenTypes.LinkedDot */ ||\n currentType === 11 /* TokenTypes.LinkedModifier */ ||\n currentType === 9 /* TokenTypes.LinkedDelimiter */) &&\n (ch === CHAR_LF || ch === CHAR_SP)) {\n emitError(CompileErrorCodes.INVALID_LINKED_FORMAT, currentPosition(), 0);\n }\n switch (ch) {\n case \"@\" /* TokenChars.LinkedAlias */:\n scnr.next();\n token = getToken(context, 7 /* TokenTypes.LinkedAlias */, \"@\" /* TokenChars.LinkedAlias */);\n context.inLinked = true;\n return token;\n case \".\" /* TokenChars.LinkedDot */:\n skipSpaces(scnr);\n scnr.next();\n return getToken(context, 8 /* TokenTypes.LinkedDot */, \".\" /* TokenChars.LinkedDot */);\n case \":\" /* TokenChars.LinkedDelimiter */:\n skipSpaces(scnr);\n scnr.next();\n return getToken(context, 9 /* TokenTypes.LinkedDelimiter */, \":\" /* TokenChars.LinkedDelimiter */);\n default:\n if (isPluralStart(scnr)) {\n token = getToken(context, 1 /* TokenTypes.Pipe */, readPlural(scnr));\n // reset\n context.braceNest = 0;\n context.inLinked = false;\n return token;\n }\n if (isLinkedDotStart(scnr, context) ||\n isLinkedDelimiterStart(scnr, context)) {\n skipSpaces(scnr);\n return readTokenInLinked(scnr, context);\n }\n if (isLinkedModifierStart(scnr, context)) {\n skipSpaces(scnr);\n return getToken(context, 11 /* TokenTypes.LinkedModifier */, readLinkedModifier(scnr));\n }\n if (isLinkedReferStart(scnr, context)) {\n skipSpaces(scnr);\n if (ch === \"{\" /* TokenChars.BraceLeft */) {\n // scan the placeholder\n return readTokenInPlaceholder(scnr, context) || token;\n }\n else {\n return getToken(context, 10 /* TokenTypes.LinkedKey */, readLinkedRefer(scnr));\n }\n }\n if (currentType === 7 /* TokenTypes.LinkedAlias */) {\n emitError(CompileErrorCodes.INVALID_LINKED_FORMAT, currentPosition(), 0);\n }\n context.braceNest = 0;\n context.inLinked = false;\n return readToken(scnr, context);\n }\n }\n // TODO: We need refactoring of token parsing ...\n function readToken(scnr, context) {\n let token = { type: 13 /* TokenTypes.EOF */ };\n if (context.braceNest > 0) {\n return readTokenInPlaceholder(scnr, context) || getEndToken(context);\n }\n if (context.inLinked) {\n return readTokenInLinked(scnr, context) || getEndToken(context);\n }\n const ch = scnr.currentChar();\n switch (ch) {\n case \"{\" /* TokenChars.BraceLeft */:\n return readTokenInPlaceholder(scnr, context) || getEndToken(context);\n case \"}\" /* TokenChars.BraceRight */:\n emitError(CompileErrorCodes.UNBALANCED_CLOSING_BRACE, currentPosition(), 0);\n scnr.next();\n return getToken(context, 3 /* TokenTypes.BraceRight */, \"}\" /* TokenChars.BraceRight */);\n case \"@\" /* TokenChars.LinkedAlias */:\n return readTokenInLinked(scnr, context) || getEndToken(context);\n default: {\n if (isPluralStart(scnr)) {\n token = getToken(context, 1 /* TokenTypes.Pipe */, readPlural(scnr));\n // reset\n context.braceNest = 0;\n context.inLinked = false;\n return token;\n }\n if (isTextStart(scnr)) {\n return getToken(context, 0 /* TokenTypes.Text */, readText(scnr));\n }\n break;\n }\n }\n return token;\n }\n function nextToken() {\n const { currentType, offset, startLoc, endLoc } = _context;\n _context.lastType = currentType;\n _context.lastOffset = offset;\n _context.lastStartLoc = startLoc;\n _context.lastEndLoc = endLoc;\n _context.offset = currentOffset();\n _context.startLoc = currentPosition();\n if (_scnr.currentChar() === EOF) {\n return getToken(_context, 13 /* TokenTypes.EOF */);\n }\n return readToken(_scnr, _context);\n }\n return {\n nextToken,\n currentOffset,\n currentPosition,\n context\n };\n}\n\nconst ERROR_DOMAIN$2 = 'parser';\n// Backslash backslash, backslash quote, uHHHH, UHHHHHH.\nconst KNOWN_ESCAPES = /(?:\\\\\\\\|\\\\'|\\\\u([0-9a-fA-F]{4})|\\\\U([0-9a-fA-F]{6}))/g;\n// Text context escape sequences: \\\\, \\@, \\{, \\}, \\|\nconst TEXT_ESCAPES = /\\\\([\\\\@{}|])/g;\nfunction fromTextEscapeSequence(_match, char) {\n return char;\n}\nfunction fromEscapeSequence(match, codePoint4, codePoint6) {\n switch (match) {\n case `\\\\\\\\`:\n return `\\\\`;\n // eslint-disable-next-line no-useless-escape\n case `\\\\\\'`:\n // eslint-disable-next-line no-useless-escape\n return `\\'`;\n default: {\n const codePoint = parseInt(codePoint4 || codePoint6, 16);\n if (codePoint <= 0xd7ff || codePoint >= 0xe000) {\n return String.fromCodePoint(codePoint);\n }\n // invalid ...\n // Replace them with U+FFFD REPLACEMENT CHARACTER.\n return '�';\n }\n }\n}\nfunction createParser(options = {}) {\n const location = options.location !== false;\n const { onError } = options;\n function emitError(tokenzer, code, start, offset, ...args) {\n const end = tokenzer.currentPosition();\n end.offset += offset;\n end.column += offset;\n if (onError) {\n const loc = location ? createLocation(start, end) : null;\n const err = createCompileError(code, loc, {\n domain: ERROR_DOMAIN$2,\n args\n });\n onError(err);\n }\n }\n function startNode(type, offset, loc) {\n const node = { type };\n if (location) {\n node.start = offset;\n node.end = offset;\n node.loc = { start: loc, end: loc };\n }\n return node;\n }\n function endNode(node, offset, pos, type) {\n if (location) {\n node.end = offset;\n if (node.loc) {\n node.loc.end = pos;\n }\n }\n }\n function parseText(tokenizer, value) {\n const context = tokenizer.context();\n const node = startNode(3 /* NodeTypes.Text */, context.offset, context.startLoc);\n node.value = value.replace(TEXT_ESCAPES, fromTextEscapeSequence);\n endNode(node, tokenizer.currentOffset(), tokenizer.currentPosition());\n return node;\n }\n function parseList(tokenizer, index) {\n const context = tokenizer.context();\n const { lastOffset: offset, lastStartLoc: loc } = context; // get brace left loc\n const node = startNode(5 /* NodeTypes.List */, offset, loc);\n node.index = parseInt(index, 10);\n tokenizer.nextToken(); // skip brach right\n endNode(node, tokenizer.currentOffset(), tokenizer.currentPosition());\n return node;\n }\n function parseNamed(tokenizer, key) {\n const context = tokenizer.context();\n const { lastOffset: offset, lastStartLoc: loc } = context; // get brace left loc\n const node = startNode(4 /* NodeTypes.Named */, offset, loc);\n node.key = key;\n tokenizer.nextToken(); // skip brach right\n endNode(node, tokenizer.currentOffset(), tokenizer.currentPosition());\n return node;\n }\n function parseLiteral(tokenizer, value) {\n const context = tokenizer.context();\n const { lastOffset: offset, lastStartLoc: loc } = context; // get brace left loc\n const node = startNode(9 /* NodeTypes.Literal */, offset, loc);\n node.value = value.replace(KNOWN_ESCAPES, fromEscapeSequence);\n tokenizer.nextToken(); // skip brach right\n endNode(node, tokenizer.currentOffset(), tokenizer.currentPosition());\n return node;\n }\n function parseLinkedModifier(tokenizer) {\n const token = tokenizer.nextToken();\n const context = tokenizer.context();\n const { lastOffset: offset, lastStartLoc: loc } = context; // get linked dot loc\n const node = startNode(8 /* NodeTypes.LinkedModifier */, offset, loc);\n if (token.type !== 11 /* TokenTypes.LinkedModifier */) {\n // empty modifier\n emitError(tokenizer, CompileErrorCodes.UNEXPECTED_EMPTY_LINKED_MODIFIER, context.lastStartLoc, 0);\n node.value = '';\n endNode(node, offset, loc);\n return {\n nextConsumeToken: token,\n node\n };\n }\n // check token\n if (token.value == null) {\n emitError(tokenizer, CompileErrorCodes.UNEXPECTED_LEXICAL_ANALYSIS, context.lastStartLoc, 0, getTokenCaption(token));\n }\n node.value = token.value || '';\n endNode(node, tokenizer.currentOffset(), tokenizer.currentPosition());\n return {\n node\n };\n }\n function parseLinkedKey(tokenizer, value) {\n const context = tokenizer.context();\n const node = startNode(7 /* NodeTypes.LinkedKey */, context.offset, context.startLoc);\n node.value = value;\n endNode(node, tokenizer.currentOffset(), tokenizer.currentPosition());\n return node;\n }\n function parseLinked(tokenizer) {\n const context = tokenizer.context();\n const linkedNode = startNode(6 /* NodeTypes.Linked */, context.offset, context.startLoc);\n let token = tokenizer.nextToken();\n if (token.type === 8 /* TokenTypes.LinkedDot */) {\n const parsed = parseLinkedModifier(tokenizer);\n linkedNode.modifier = parsed.node;\n token = parsed.nextConsumeToken || tokenizer.nextToken();\n }\n // asset check token\n if (token.type !== 9 /* TokenTypes.LinkedDelimiter */) {\n emitError(tokenizer, CompileErrorCodes.UNEXPECTED_LEXICAL_ANALYSIS, context.lastStartLoc, 0, getTokenCaption(token));\n }\n token = tokenizer.nextToken();\n // skip brace left\n if (token.type === 2 /* TokenTypes.BraceLeft */) {\n token = tokenizer.nextToken();\n }\n switch (token.type) {\n case 10 /* TokenTypes.LinkedKey */:\n if (token.value == null) {\n emitError(tokenizer, CompileErrorCodes.UNEXPECTED_LEXICAL_ANALYSIS, context.lastStartLoc, 0, getTokenCaption(token));\n }\n linkedNode.key = parseLinkedKey(tokenizer, token.value || '');\n break;\n case 4 /* TokenTypes.Named */:\n if (token.value == null) {\n emitError(tokenizer, CompileErrorCodes.UNEXPECTED_LEXICAL_ANALYSIS, context.lastStartLoc, 0, getTokenCaption(token));\n }\n linkedNode.key = parseNamed(tokenizer, token.value || '');\n break;\n case 5 /* TokenTypes.List */:\n if (token.value == null) {\n emitError(tokenizer, CompileErrorCodes.UNEXPECTED_LEXICAL_ANALYSIS, context.lastStartLoc, 0, getTokenCaption(token));\n }\n linkedNode.key = parseList(tokenizer, token.value || '');\n break;\n case 6 /* TokenTypes.Literal */:\n if (token.value == null) {\n emitError(tokenizer, CompileErrorCodes.UNEXPECTED_LEXICAL_ANALYSIS, context.lastStartLoc, 0, getTokenCaption(token));\n }\n linkedNode.key = parseLiteral(tokenizer, token.value || '');\n break;\n default: {\n // empty key\n emitError(tokenizer, CompileErrorCodes.UNEXPECTED_EMPTY_LINKED_KEY, context.lastStartLoc, 0);\n const nextContext = tokenizer.context();\n const emptyLinkedKeyNode = startNode(7 /* NodeTypes.LinkedKey */, nextContext.offset, nextContext.startLoc);\n emptyLinkedKeyNode.value = '';\n endNode(emptyLinkedKeyNode, nextContext.offset, nextContext.startLoc);\n linkedNode.key = emptyLinkedKeyNode;\n endNode(linkedNode, nextContext.offset, nextContext.startLoc);\n return {\n nextConsumeToken: token,\n node: linkedNode\n };\n }\n }\n endNode(linkedNode, tokenizer.currentOffset(), tokenizer.currentPosition());\n return {\n node: linkedNode\n };\n }\n function parseMessage(tokenizer) {\n const context = tokenizer.context();\n const startOffset = context.currentType === 1 /* TokenTypes.Pipe */\n ? tokenizer.currentOffset()\n : context.offset;\n const startLoc = context.currentType === 1 /* TokenTypes.Pipe */\n ? context.endLoc\n : context.startLoc;\n const node = startNode(2 /* NodeTypes.Message */, startOffset, startLoc);\n node.items = [];\n let nextToken = null;\n do {\n const token = nextToken || tokenizer.nextToken();\n nextToken = null;\n switch (token.type) {\n case 0 /* TokenTypes.Text */:\n if (token.value == null) {\n emitError(tokenizer, CompileErrorCodes.UNEXPECTED_LEXICAL_ANALYSIS, context.lastStartLoc, 0, getTokenCaption(token));\n }\n node.items.push(parseText(tokenizer, token.value || ''));\n break;\n case 5 /* TokenTypes.List */:\n if (token.value == null) {\n emitError(tokenizer, CompileErrorCodes.UNEXPECTED_LEXICAL_ANALYSIS, context.lastStartLoc, 0, getTokenCaption(token));\n }\n node.items.push(parseList(tokenizer, token.value || ''));\n break;\n case 4 /* TokenTypes.Named */:\n if (token.value == null) {\n emitError(tokenizer, CompileErrorCodes.UNEXPECTED_LEXICAL_ANALYSIS, context.lastStartLoc, 0, getTokenCaption(token));\n }\n node.items.push(parseNamed(tokenizer, token.value || ''));\n break;\n case 6 /* TokenTypes.Literal */:\n if (token.value == null) {\n emitError(tokenizer, CompileErrorCodes.UNEXPECTED_LEXICAL_ANALYSIS, context.lastStartLoc, 0, getTokenCaption(token));\n }\n node.items.push(parseLiteral(tokenizer, token.value || ''));\n break;\n case 7 /* TokenTypes.LinkedAlias */: {\n const parsed = parseLinked(tokenizer);\n node.items.push(parsed.node);\n nextToken = parsed.nextConsumeToken || null;\n break;\n }\n }\n } while (context.currentType !== 13 /* TokenTypes.EOF */ &&\n context.currentType !== 1 /* TokenTypes.Pipe */);\n // adjust message node loc\n const endOffset = context.currentType === 1 /* TokenTypes.Pipe */\n ? context.lastOffset\n : tokenizer.currentOffset();\n const endLoc = context.currentType === 1 /* TokenTypes.Pipe */\n ? context.lastEndLoc\n : tokenizer.currentPosition();\n endNode(node, endOffset, endLoc);\n return node;\n }\n function parsePlural(tokenizer, offset, loc, msgNode) {\n const context = tokenizer.context();\n let hasEmptyMessage = msgNode.items.length === 0;\n const node = startNode(1 /* NodeTypes.Plural */, offset, loc);\n node.cases = [];\n node.cases.push(msgNode);\n do {\n const msg = parseMessage(tokenizer);\n if (!hasEmptyMessage) {\n hasEmptyMessage = msg.items.length === 0;\n }\n node.cases.push(msg);\n } while (context.currentType !== 13 /* TokenTypes.EOF */);\n if (hasEmptyMessage) {\n emitError(tokenizer, CompileErrorCodes.MUST_HAVE_MESSAGES_IN_PLURAL, loc, 0);\n }\n endNode(node, tokenizer.currentOffset(), tokenizer.currentPosition());\n return node;\n }\n function parseResource(tokenizer) {\n const context = tokenizer.context();\n const { offset, startLoc } = context;\n const msgNode = parseMessage(tokenizer);\n if (context.currentType === 13 /* TokenTypes.EOF */) {\n return msgNode;\n }\n else {\n return parsePlural(tokenizer, offset, startLoc, msgNode);\n }\n }\n function parse(source) {\n const tokenizer = createTokenizer(source, assign({}, options));\n const context = tokenizer.context();\n const node = startNode(0 /* NodeTypes.Resource */, context.offset, context.startLoc);\n if (location && node.loc) {\n node.loc.source = source;\n }\n node.body = parseResource(tokenizer);\n if (options.onCacheKey) {\n node.cacheKey = options.onCacheKey(source);\n }\n // assert whether achieved to EOF\n if (context.currentType !== 13 /* TokenTypes.EOF */) {\n emitError(tokenizer, CompileErrorCodes.UNEXPECTED_LEXICAL_ANALYSIS, context.lastStartLoc, 0, source[context.offset] || '');\n }\n endNode(node, tokenizer.currentOffset(), tokenizer.currentPosition());\n return node;\n }\n return { parse };\n}\nfunction getTokenCaption(token) {\n if (token.type === 13 /* TokenTypes.EOF */) {\n return 'EOF';\n }\n const name = (token.value || '').replace(/\\r?\\n/gu, '\\\\n');\n return name.length > 10 ? name.slice(0, 9) + '…' : name;\n}\n\nfunction createTransformer(ast, options = {} // eslint-disable-line\n) {\n const _context = {\n ast,\n helpers: new Set()\n };\n const context = () => _context;\n const helper = (name) => {\n _context.helpers.add(name);\n return name;\n };\n return { context, helper };\n}\nfunction traverseNodes(nodes, transformer) {\n for (let i = 0; i < nodes.length; i++) {\n traverseNode(nodes[i], transformer);\n }\n}\nfunction traverseNode(node, transformer) {\n // TODO: if we need pre-hook of transform, should be implemented to here\n switch (node.type) {\n case 1 /* NodeTypes.Plural */:\n traverseNodes(node.cases, transformer);\n transformer.helper(\"plural\" /* HelperNameMap.PLURAL */);\n break;\n case 2 /* NodeTypes.Message */:\n traverseNodes(node.items, transformer);\n break;\n case 6 /* NodeTypes.Linked */: {\n const linked = node;\n traverseNode(linked.key, transformer);\n transformer.helper(\"linked\" /* HelperNameMap.LINKED */);\n transformer.helper(\"type\" /* HelperNameMap.TYPE */);\n break;\n }\n case 5 /* NodeTypes.List */:\n transformer.helper(\"interpolate\" /* HelperNameMap.INTERPOLATE */);\n transformer.helper(\"list\" /* HelperNameMap.LIST */);\n break;\n case 4 /* NodeTypes.Named */:\n transformer.helper(\"interpolate\" /* HelperNameMap.INTERPOLATE */);\n transformer.helper(\"named\" /* HelperNameMap.NAMED */);\n break;\n }\n // TODO: if we need post-hook of transform, should be implemented to here\n}\n// transform AST\nfunction transform(ast, options = {} // eslint-disable-line\n) {\n const transformer = createTransformer(ast);\n transformer.helper(\"normalize\" /* HelperNameMap.NORMALIZE */);\n // traverse\n ast.body && traverseNode(ast.body, transformer);\n // set meta information\n const context = transformer.context();\n ast.helpers = Array.from(context.helpers);\n}\n\nfunction optimize(ast) {\n const body = ast.body;\n if (body.type === 2 /* NodeTypes.Message */) {\n optimizeMessageNode(body);\n }\n else {\n body.cases.forEach(c => optimizeMessageNode(c));\n }\n return ast;\n}\nfunction optimizeMessageNode(message) {\n if (message.items.length === 1) {\n const item = message.items[0];\n if (item.type === 3 /* NodeTypes.Text */ || item.type === 9 /* NodeTypes.Literal */) {\n message.static = item.value;\n delete item.value; // optimization for size\n }\n }\n else {\n const values = [];\n for (let i = 0; i < message.items.length; i++) {\n const item = message.items[i];\n if (!(item.type === 3 /* NodeTypes.Text */ || item.type === 9 /* NodeTypes.Literal */)) {\n break;\n }\n if (item.value == null) {\n break;\n }\n values.push(item.value);\n }\n if (values.length === message.items.length) {\n message.static = join(values);\n for (let i = 0; i < message.items.length; i++) {\n const item = message.items[i];\n if (item.type === 3 /* NodeTypes.Text */ || item.type === 9 /* NodeTypes.Literal */) {\n delete item.value; // optimization for size\n }\n }\n }\n }\n}\n\nconst ERROR_DOMAIN$1 = 'minifier';\n/* eslint-disable @typescript-eslint/no-explicit-any */\nfunction minify(node) {\n node.t = node.type;\n switch (node.type) {\n case 0 /* NodeTypes.Resource */: {\n const resource = node;\n minify(resource.body);\n resource.b = resource.body;\n delete resource.body;\n break;\n }\n case 1 /* NodeTypes.Plural */: {\n const plural = node;\n const cases = plural.cases;\n for (let i = 0; i < cases.length; i++) {\n minify(cases[i]);\n }\n plural.c = cases;\n delete plural.cases;\n break;\n }\n case 2 /* NodeTypes.Message */: {\n const message = node;\n const items = message.items;\n for (let i = 0; i < items.length; i++) {\n minify(items[i]);\n }\n message.i = items;\n delete message.items;\n if (message.static) {\n message.s = message.static;\n delete message.static;\n }\n break;\n }\n case 3 /* NodeTypes.Text */:\n case 9 /* NodeTypes.Literal */:\n case 8 /* NodeTypes.LinkedModifier */:\n case 7 /* NodeTypes.LinkedKey */: {\n const valueNode = node;\n if (valueNode.value) {\n valueNode.v = valueNode.value;\n delete valueNode.value;\n }\n break;\n }\n case 6 /* NodeTypes.Linked */: {\n const linked = node;\n minify(linked.key);\n linked.k = linked.key;\n delete linked.key;\n if (linked.modifier) {\n minify(linked.modifier);\n linked.m = linked.modifier;\n delete linked.modifier;\n }\n break;\n }\n case 5 /* NodeTypes.List */: {\n const list = node;\n list.i = list.index;\n delete list.index;\n break;\n }\n case 4 /* NodeTypes.Named */: {\n const named = node;\n named.k = named.key;\n delete named.key;\n break;\n }\n default:\n if ((process.env.NODE_ENV !== 'production')) {\n throw createCompileError(CompileErrorCodes.UNHANDLED_MINIFIER_NODE_TYPE, null, {\n domain: ERROR_DOMAIN$1,\n args: [node.type]\n });\n }\n }\n delete node.type;\n}\n/* eslint-enable @typescript-eslint/no-explicit-any */\n\n// eslint-disable-next-line @typescript-eslint/triple-slash-reference\n/// <reference types=\"source-map-js\" />\nconst ERROR_DOMAIN = 'parser';\nfunction createCodeGenerator(ast, options) {\n const { sourceMap, filename, breakLineCode, needIndent: _needIndent } = options;\n const location = options.location !== false;\n const _context = {\n filename,\n code: '',\n column: 1,\n line: 1,\n offset: 0,\n map: undefined,\n breakLineCode,\n needIndent: _needIndent,\n indentLevel: 0\n };\n if (location && ast.loc) {\n _context.source = ast.loc.source;\n }\n const context = () => _context;\n function push(code, node) {\n _context.code += code;\n }\n function _newline(n, withBreakLine = true) {\n const _breakLineCode = withBreakLine ? breakLineCode : '';\n push(_needIndent ? _breakLineCode + ` `.repeat(n) : _breakLineCode);\n }\n function indent(withNewLine = true) {\n const level = ++_context.indentLevel;\n withNewLine && _newline(level);\n }\n function deindent(withNewLine = true) {\n const level = --_context.indentLevel;\n withNewLine && _newline(level);\n }\n function newline() {\n _newline(_context.indentLevel);\n }\n const helper = (key) => `_${key}`;\n const needIndent = () => _context.needIndent;\n return {\n context,\n push,\n indent,\n deindent,\n newline,\n helper,\n needIndent\n };\n}\nfunction generateLinkedNode(generator, node) {\n const { helper } = generator;\n generator.push(`${helper(\"linked\" /* HelperNameMap.LINKED */)}(`);\n generateNode(generator, node.key);\n if (node.modifier) {\n generator.push(`, `);\n generateNode(generator, node.modifier);\n generator.push(`, _type`);\n }\n else {\n generator.push(`, undefined, _type`);\n }\n generator.push(`)`);\n}\nfunction generateMessageNode(generator, node) {\n const { helper, needIndent } = generator;\n generator.push(`${helper(\"normalize\" /* HelperNameMap.NORMALIZE */)}([`);\n generator.indent(needIndent());\n const length = node.items.length;\n for (let i = 0; i < length; i++) {\n generateNode(generator, node.items[i]);\n if (i === length - 1) {\n break;\n }\n generator.push(', ');\n }\n generator.deindent(needIndent());\n generator.push('])');\n}\nfunction generatePluralNode(generator, node) {\n const { helper, needIndent } = generator;\n if (node.cases.length > 1) {\n generator.push(`${helper(\"plural\" /* HelperNameMap.PLURAL */)}([`);\n generator.indent(needIndent());\n const length = node.cases.length;\n for (let i = 0; i < length; i++) {\n generateNode(generator, node.cases[i]);\n if (i === length - 1) {\n break;\n }\n generator.push(', ');\n }\n generator.deindent(needIndent());\n generator.push(`])`);\n }\n}\nfunction generateResource(generator, node) {\n if (node.body) {\n generateNode(generator, node.body);\n }\n else {\n generator.push('null');\n }\n}\nfunction generateNode(generator, node) {\n const { helper } = generator;\n switch (node.type) {\n case 0 /* NodeTypes.Resource */:\n generateResource(generator, node);\n break;\n case 1 /* NodeTypes.Plural */:\n generatePluralNode(generator, node);\n break;\n case 2 /* NodeTypes.Message */:\n generateMessageNode(generator, node);\n break;\n case 6 /* NodeTypes.Linked */:\n generateLinkedNode(generator, node);\n break;\n case 8 /* NodeTypes.LinkedModifier */:\n generator.push(JSON.stringify(node.value), node);\n break;\n case 7 /* NodeTypes.LinkedKey */:\n generator.push(JSON.stringify(node.value), node);\n break;\n case 5 /* NodeTypes.List */:\n generator.push(`${helper(\"interpolate\" /* HelperNameMap.INTERPOLATE */)}(${helper(\"list\" /* HelperNameMap.LIST */)}(${node.index}))`, node);\n break;\n case 4 /* NodeTypes.Named */:\n generator.push(`${helper(\"interpolate\" /* HelperNameMap.INTERPOLATE */)}(${helper(\"named\" /* HelperNameMap.NAMED */)}(${JSON.stringify(node.key)}))`, node);\n break;\n case 9 /* NodeTypes.Literal */:\n generator.push(JSON.stringify(node.value), node);\n break;\n case 3 /* NodeTypes.Text */:\n generator.push(JSON.stringify(node.value), node);\n break;\n default:\n if ((process.env.NODE_ENV !== 'production')) {\n throw createCompileError(CompileErrorCodes.UNHANDLED_CODEGEN_NODE_TYPE, null, {\n domain: ERROR_DOMAIN,\n args: [node.type]\n });\n }\n }\n}\n// generate code from AST\nconst generate = (ast, options = {}) => {\n const mode = isString(options.mode) ? options.mode : 'normal';\n const filename = isString(options.filename)\n ? options.filename\n : 'message.intl';\n const sourceMap = !!options.sourceMap;\n // prettier-ignore\n const breakLineCode = options.breakLineCode != null\n ? options.breakLineCode\n : mode === 'arrow'\n ? ';'\n : '\\n';\n const needIndent = options.needIndent ? options.needIndent : mode !== 'arrow';\n const helpers = ast.helpers || [];\n const generator = createCodeGenerator(ast, {\n mode,\n filename,\n sourceMap,\n breakLineCode,\n needIndent\n });\n generator.push(mode === 'normal' ? `function __msg__ (ctx) {` : `(ctx) => {`);\n generator.indent(needIndent);\n if (helpers.length > 0) {\n generator.push(`const { ${join(helpers.map(s => `${s}: _${s}`), ', ')} } = ctx`);\n generator.newline();\n }\n generator.push(`return `);\n generateNode(generator, ast);\n generator.deindent(needIndent);\n generator.push(`}`);\n delete ast.helpers;\n const { code, map } = generator.context();\n return {\n ast,\n code,\n map: map ? map.toJSON() : undefined // eslint-disable-line @typescript-eslint/no-explicit-any\n };\n};\n\nfunction baseCompile(source, options = {}) {\n const assignedOptions = assign({}, options);\n const jit = !!assignedOptions.jit;\n const enalbeMinify = !!assignedOptions.minify;\n const enambeOptimize = assignedOptions.optimize == null ? true : assignedOptions.optimize;\n // parse source codes\n const parser = createParser(assignedOptions);\n const ast = parser.parse(source);\n if (!jit) {\n // transform ASTs\n transform(ast, assignedOptions);\n // generate javascript codes\n return generate(ast, assignedOptions);\n }\n else {\n // optimize ASTs\n enambeOptimize && optimize(ast);\n // minimize ASTs\n enalbeMinify && minify(ast);\n // In JIT mode, no ast transform, no code generation.\n return { ast, code: '' };\n }\n}\n\nexport { COMPILE_ERROR_CODES_EXTEND_POINT, CompileErrorCodes, ERROR_DOMAIN$2 as ERROR_DOMAIN, LOCATION_STUB, baseCompile, createCompileError, createLocation, createParser, createPosition, defaultOnError, detectHtmlTag, errorMessages };\n","/*!\n * core-base v11.3.0\n * (c) 2026 kazuya kawaguchi\n * Released under the MIT License.\n */\nimport { getGlobalThis, isObject, hasOwn, isNumber, create, isString, isBoolean, warn, format as format$1, isFunction, isPromise, isArray, isPlainObject, assign, isRegExp, warnOnce, isDate, isEmptyObject, join, toDisplayString, sanitizeTranslatedHtml, escapeHtml, inBrowser, mark, measure, generateCodeFrame, generateFormatCacheKey } from '@intlify/shared';\nimport { detectHtmlTag, defaultOnError, baseCompile as baseCompile$1, COMPILE_ERROR_CODES_EXTEND_POINT, createCompileError } from '@intlify/message-compiler';\nexport { CompileErrorCodes, createCompileError } from '@intlify/message-compiler';\n\n/**\n * This is only called in esm-bundler builds.\n * istanbul-ignore-next\n */\nfunction initFeatureFlags() {\n if (typeof __INTLIFY_PROD_DEVTOOLS__ !== 'boolean') {\n getGlobalThis().__INTLIFY_PROD_DEVTOOLS__ = false;\n }\n if (typeof __INTLIFY_DROP_MESSAGE_COMPILER__ !== 'boolean') {\n getGlobalThis().__INTLIFY_DROP_MESSAGE_COMPILER__ = false;\n }\n}\n\nfunction isMessageAST(val) {\n return (isObject(val) &&\n resolveType(val) === 0 &&\n (hasOwn(val, 'b') || hasOwn(val, 'body')));\n}\nconst PROPS_BODY = ['b', 'body'];\nfunction resolveBody(node) {\n return resolveProps(node, PROPS_BODY);\n}\nconst PROPS_CASES = ['c', 'cases'];\nfunction resolveCases(node) {\n return resolveProps(node, PROPS_CASES, []);\n}\nconst PROPS_STATIC = ['s', 'static'];\nfunction resolveStatic(node) {\n return resolveProps(node, PROPS_STATIC);\n}\nconst PROPS_ITEMS = ['i', 'items'];\nfunction resolveItems(node) {\n return resolveProps(node, PROPS_ITEMS, []);\n}\nconst PROPS_TYPE = ['t', 'type'];\nfunction resolveType(node) {\n return resolveProps(node, PROPS_TYPE);\n}\nconst PROPS_VALUE = ['v', 'value'];\nfunction resolveValue$1(node, type) {\n const resolved = resolveProps(node, PROPS_VALUE);\n if (resolved != null) {\n return resolved;\n }\n else {\n throw createUnhandleNodeError(type);\n }\n}\nconst PROPS_MODIFIER = ['m', 'modifier'];\nfunction resolveLinkedModifier(node) {\n return resolveProps(node, PROPS_MODIFIER);\n}\nconst PROPS_KEY = ['k', 'key'];\nfunction resolveLinkedKey(node) {\n const resolved = resolveProps(node, PROPS_KEY);\n if (resolved) {\n return resolved;\n }\n else {\n throw createUnhandleNodeError(6 /* NodeTypes.Linked */);\n }\n}\nfunction resolveProps(node, props, defaultValue) {\n for (let i = 0; i < props.length; i++) {\n const prop = props[i];\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n if (hasOwn(node, prop) && node[prop] != null) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return node[prop];\n }\n }\n return defaultValue;\n}\nconst AST_NODE_PROPS_KEYS = [\n ...PROPS_BODY,\n ...PROPS_CASES,\n ...PROPS_STATIC,\n ...PROPS_ITEMS,\n ...PROPS_KEY,\n ...PROPS_MODIFIER,\n ...PROPS_VALUE,\n ...PROPS_TYPE\n];\nfunction createUnhandleNodeError(type) {\n return new Error(`unhandled node type: ${type}`);\n}\n\nfunction format(ast) {\n const msg = (ctx) => formatParts(ctx, ast);\n return msg;\n}\nfunction formatParts(ctx, ast) {\n const body = resolveBody(ast);\n if (body == null) {\n throw createUnhandleNodeError(0 /* NodeTypes.Resource */);\n }\n const type = resolveType(body);\n if (type === 1 /* NodeTypes.Plural */) {\n const plural = body;\n const cases = resolveCases(plural);\n return ctx.plural(cases.reduce((messages, c) => [\n ...messages,\n formatMessageParts(ctx, c)\n ], []));\n }\n else {\n return formatMessageParts(ctx, body);\n }\n}\nfunction formatMessageParts(ctx, node) {\n const static_ = resolveStatic(node);\n if (static_ != null) {\n return ctx.type === 'text'\n ? static_\n : ctx.normalize([static_]);\n }\n else {\n const messages = resolveItems(node).reduce((acm, c) => [...acm, formatMessagePart(ctx, c)], []);\n return ctx.normalize(messages);\n }\n}\nfunction formatMessagePart(ctx, node) {\n const type = resolveType(node);\n switch (type) {\n case 3 /* NodeTypes.Text */: {\n return resolveValue$1(node, type);\n }\n case 9 /* NodeTypes.Literal */: {\n return resolveValue$1(node, type);\n }\n case 4 /* NodeTypes.Named */: {\n const named = node;\n if (hasOwn(named, 'k') && named.k) {\n return ctx.interpolate(ctx.named(named.k));\n }\n if (hasOwn(named, 'key') && named.key) {\n return ctx.interpolate(ctx.named(named.key));\n }\n throw createUnhandleNodeError(type);\n }\n case 5 /* NodeTypes.List */: {\n const list = node;\n if (hasOwn(list, 'i') && isNumber(list.i)) {\n return ctx.interpolate(ctx.list(list.i));\n }\n if (hasOwn(list, 'index') && isNumber(list.index)) {\n return ctx.interpolate(ctx.list(list.index));\n }\n throw createUnhandleNodeError(type);\n }\n case 6 /* NodeTypes.Linked */: {\n const linked = node;\n const modifier = resolveLinkedModifier(linked);\n const key = resolveLinkedKey(linked);\n return ctx.linked(formatMessagePart(ctx, key), modifier ? formatMessagePart(ctx, modifier) : undefined, ctx.type);\n }\n case 7 /* NodeTypes.LinkedKey */: {\n return resolveValue$1(node, type);\n }\n case 8 /* NodeTypes.LinkedModifier */: {\n return resolveValue$1(node, type);\n }\n default:\n throw new Error(`unhandled node on format message part: ${type}`);\n }\n}\n\nconst WARN_MESSAGE = `Detected HTML in '{source}' message. Recommend not using HTML messages to avoid XSS.`;\nfunction checkHtmlMessage(source, warnHtmlMessage) {\n if (warnHtmlMessage && detectHtmlTag(source)) {\n warn(format$1(WARN_MESSAGE, { source }));\n }\n}\nconst defaultOnCacheKey = (message) => message;\nlet compileCache = create();\nfunction clearCompileCache() {\n compileCache = create();\n}\nfunction baseCompile(message, options = {}) {\n // error detecting on compile\n let detectError = false;\n const onError = options.onError || defaultOnError;\n options.onError = (err) => {\n detectError = true;\n onError(err);\n };\n // compile with mesasge-compiler\n return { ...baseCompile$1(message, options), detectError };\n}\n/* #__NO_SIDE_EFFECTS__ */\nfunction compile(message, context) {\n if ((!__INTLIFY_DROP_MESSAGE_COMPILER__) &&\n isString(message)) {\n // check HTML message\n const warnHtmlMessage = isBoolean(context.warnHtmlMessage)\n ? context.warnHtmlMessage\n : true;\n (process.env.NODE_ENV !== 'production') && checkHtmlMessage(message, warnHtmlMessage);\n // check caches\n const onCacheKey = context.onCacheKey || defaultOnCacheKey;\n const cacheKey = onCacheKey(message);\n const cached = compileCache[cacheKey];\n if (cached) {\n return cached;\n }\n // compile with JIT mode\n const { ast, detectError } = baseCompile(message, {\n ...context,\n location: (process.env.NODE_ENV !== 'production'),\n jit: true\n });\n // compose message function from AST\n const msg = format(ast);\n // if occurred compile error, don't cache\n return !detectError\n ? (compileCache[cacheKey] = msg)\n : msg;\n }\n else {\n if ((process.env.NODE_ENV !== 'production') && !isMessageAST(message)) {\n warn(`the message that is resolve with key '${context.key}' is not supported for jit compilation`);\n return (() => message);\n }\n // AST case (passed from bundler)\n const cacheKey = message.cacheKey;\n if (cacheKey) {\n const cached = compileCache[cacheKey];\n if (cached) {\n return cached;\n }\n // compose message function from message (AST)\n return (compileCache[cacheKey] =\n format(message));\n }\n else {\n return format(message);\n }\n }\n}\n\nlet devtools = null;\nfunction setDevToolsHook(hook) {\n devtools = hook;\n}\nfunction getDevToolsHook() {\n return devtools;\n}\nfunction initI18nDevTools(i18n, version, meta) {\n // TODO: queue if devtools is undefined\n devtools &&\n devtools.emit('i18n:init', {\n timestamp: Date.now(),\n i18n,\n version,\n meta\n });\n}\nconst translateDevTools = \n/* #__PURE__*/ createDevToolsHook('function:translate');\nfunction createDevToolsHook(hook) {\n return (payloads) => devtools && devtools.emit(hook, payloads);\n}\n\nconst CoreErrorCodes = {\n INVALID_ARGUMENT: COMPILE_ERROR_CODES_EXTEND_POINT, // 17\n INVALID_DATE_ARGUMENT: 18,\n INVALID_ISO_DATE_ARGUMENT: 19,\n NOT_SUPPORT_NON_STRING_MESSAGE: 20,\n NOT_SUPPORT_LOCALE_PROMISE_VALUE: 21,\n NOT_SUPPORT_LOCALE_ASYNC_FUNCTION: 22,\n NOT_SUPPORT_LOCALE_TYPE: 23\n};\nconst CORE_ERROR_CODES_EXTEND_POINT = 24;\nfunction createCoreError(code) {\n return createCompileError(code, null, (process.env.NODE_ENV !== 'production') ? { messages: errorMessages } : undefined);\n}\n/** @internal */\nconst errorMessages = {\n [CoreErrorCodes.INVALID_ARGUMENT]: 'Invalid arguments',\n [CoreErrorCodes.INVALID_DATE_ARGUMENT]: 'The date provided is an invalid Date object.' +\n 'Make sure your Date represents a valid date.',\n [CoreErrorCodes.INVALID_ISO_DATE_ARGUMENT]: 'The argument provided is not a valid ISO date string',\n [CoreErrorCodes.NOT_SUPPORT_NON_STRING_MESSAGE]: 'Not support non-string message',\n [CoreErrorCodes.NOT_SUPPORT_LOCALE_PROMISE_VALUE]: 'cannot support promise value',\n [CoreErrorCodes.NOT_SUPPORT_LOCALE_ASYNC_FUNCTION]: 'cannot support async function',\n [CoreErrorCodes.NOT_SUPPORT_LOCALE_TYPE]: 'cannot support locale type'\n};\n\n/** @internal */\nfunction getLocale(context, options) {\n return options.locale != null\n ? resolveLocale(options.locale)\n : resolveLocale(context.locale);\n}\nlet _resolveLocale;\n/** @internal */\nfunction resolveLocale(locale) {\n if (isString(locale)) {\n return locale;\n }\n else {\n if (isFunction(locale)) {\n if (locale.resolvedOnce && _resolveLocale != null) {\n return _resolveLocale;\n }\n else if (locale.constructor.name === 'Function') {\n const resolve = locale();\n if (isPromise(resolve)) {\n throw createCoreError(CoreErrorCodes.NOT_SUPPORT_LOCALE_PROMISE_VALUE);\n }\n return (_resolveLocale = resolve);\n }\n else {\n throw createCoreError(CoreErrorCodes.NOT_SUPPORT_LOCALE_ASYNC_FUNCTION);\n }\n }\n else {\n throw createCoreError(CoreErrorCodes.NOT_SUPPORT_LOCALE_TYPE);\n }\n }\n}\n/**\n * Fallback with simple implemenation\n *\n * @remarks\n * A fallback locale function implemented with a simple fallback algorithm.\n *\n * Basically, it returns the value as specified in the `fallbackLocale` props, and is processed with the fallback inside intlify.\n *\n * @param ctx - A {@link CoreContext | context}\n * @param fallback - A {@link FallbackLocale | fallback locale}\n * @param start - A starting {@link Locale | locale}\n *\n * @returns Fallback locales\n *\n * @VueI18nGeneral\n */\nfunction fallbackWithSimple(ctx, fallback, start) {\n // prettier-ignore\n return [...new Set([\n start,\n ...(isArray(fallback)\n ? fallback\n : isObject(fallback)\n ? Object.keys(fallback)\n : isString(fallback)\n ? [fallback]\n : [start])\n ])];\n}\n/**\n * Fallback with locale chain\n *\n * @remarks\n * A fallback locale function implemented with a fallback chain algorithm. It's used in VueI18n as default.\n *\n * @param ctx - A {@link CoreContext | context}\n * @param fallback - A {@link FallbackLocale | fallback locale}\n * @param start - A starting {@link Locale | locale}\n *\n * @returns Fallback locales\n *\n * @VueI18nSee [Fallbacking](../guide/essentials/fallback)\n *\n * @VueI18nGeneral\n */\nfunction fallbackWithLocaleChain(ctx, fallback, start) {\n const startLocale = isString(start) ? start : DEFAULT_LOCALE;\n const context = ctx;\n if (!context.__localeChainCache) {\n context.__localeChainCache = new Map();\n }\n let chain = context.__localeChainCache.get(startLocale);\n if (!chain) {\n chain = [];\n // first block defined by start\n let block = [start];\n // while any intervening block found\n while (isArray(block)) {\n block = appendBlockToChain(chain, block, fallback);\n }\n // prettier-ignore\n // last block defined by default\n const defaults = isArray(fallback) || !isPlainObject(fallback)\n ? fallback\n : fallback['default']\n ? fallback['default']\n : null;\n // convert defaults to array\n block = isString(defaults) ? [defaults] : defaults;\n if (isArray(block)) {\n appendBlockToChain(chain, block, false);\n }\n context.__localeChainCache.set(startLocale, chain);\n }\n return chain;\n}\nfunction appendBlockToChain(chain, block, blocks) {\n let follow = true;\n for (let i = 0; i < block.length && isBoolean(follow); i++) {\n const locale = block[i];\n if (isString(locale)) {\n follow = appendLocaleToChain(chain, block[i], blocks);\n }\n }\n return follow;\n}\nfunction appendLocaleToChain(chain, locale, blocks) {\n let follow;\n const tokens = locale.split('-');\n do {\n const target = tokens.join('-');\n follow = appendItemToChain(chain, target, blocks);\n tokens.splice(-1, 1);\n } while (tokens.length && follow === true);\n return follow;\n}\nfunction appendItemToChain(chain, target, blocks) {\n let follow = false;\n if (!chain.includes(target)) {\n follow = true;\n if (target) {\n follow = target[target.length - 1] !== '!';\n const locale = target.replace(/!/g, '');\n chain.push(locale);\n if ((isArray(blocks) || isPlainObject(blocks)) &&\n blocks[locale] // eslint-disable-line @typescript-eslint/no-explicit-any\n ) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n follow = blocks[locale];\n }\n }\n }\n return follow;\n}\n\nconst pathStateMachine = [];\npathStateMachine[0 /* States.BEFORE_PATH */] = {\n [\"w\" /* PathCharTypes.WORKSPACE */]: [0 /* States.BEFORE_PATH */],\n [\"i\" /* PathCharTypes.IDENT */]: [3 /* States.IN_IDENT */, 0 /* Actions.APPEND */],\n [\"[\" /* PathCharTypes.LEFT_BRACKET */]: [4 /* States.IN_SUB_PATH */],\n [\"o\" /* PathCharTypes.END_OF_FAIL */]: [7 /* States.AFTER_PATH */]\n};\npathStateMachine[1 /* States.IN_PATH */] = {\n [\"w\" /* PathCharTypes.WORKSPACE */]: [1 /* States.IN_PATH */],\n [\".\" /* PathCharTypes.DOT */]: [2 /* States.BEFORE_IDENT */],\n [\"[\" /* PathCharTypes.LEFT_BRACKET */]: [4 /* States.IN_SUB_PATH */],\n [\"o\" /* PathCharTypes.END_OF_FAIL */]: [7 /* States.AFTER_PATH */]\n};\npathStateMachine[2 /* States.BEFORE_IDENT */] = {\n [\"w\" /* PathCharTypes.WORKSPACE */]: [2 /* States.BEFORE_IDENT */],\n [\"i\" /* PathCharTypes.IDENT */]: [3 /* States.IN_IDENT */, 0 /* Actions.APPEND */],\n [\"0\" /* PathCharTypes.ZERO */]: [3 /* States.IN_IDENT */, 0 /* Actions.APPEND */]\n};\npathStateMachine[3 /* States.IN_IDENT */] = {\n [\"i\" /* PathCharTypes.IDENT */]: [3 /* States.IN_IDENT */, 0 /* Actions.APPEND */],\n [\"0\" /* PathCharTypes.ZERO */]: [3 /* States.IN_IDENT */, 0 /* Actions.APPEND */],\n [\"w\" /* PathCharTypes.WORKSPACE */]: [1 /* States.IN_PATH */, 1 /* Actions.PUSH */],\n [\".\" /* PathCharTypes.DOT */]: [2 /* States.BEFORE_IDENT */, 1 /* Actions.PUSH */],\n [\"[\" /* PathCharTypes.LEFT_BRACKET */]: [4 /* States.IN_SUB_PATH */, 1 /* Actions.PUSH */],\n [\"o\" /* PathCharTypes.END_OF_FAIL */]: [7 /* States.AFTER_PATH */, 1 /* Actions.PUSH */]\n};\npathStateMachine[4 /* States.IN_SUB_PATH */] = {\n [\"'\" /* PathCharTypes.SINGLE_QUOTE */]: [5 /* States.IN_SINGLE_QUOTE */, 0 /* Actions.APPEND */],\n [\"\\\"\" /* PathCharTypes.DOUBLE_QUOTE */]: [6 /* States.IN_DOUBLE_QUOTE */, 0 /* Actions.APPEND */],\n [\"[\" /* PathCharTypes.LEFT_BRACKET */]: [\n 4 /* States.IN_SUB_PATH */,\n 2 /* Actions.INC_SUB_PATH_DEPTH */\n ],\n [\"]\" /* PathCharTypes.RIGHT_BRACKET */]: [1 /* States.IN_PATH */, 3 /* Actions.PUSH_SUB_PATH */],\n [\"o\" /* PathCharTypes.END_OF_FAIL */]: 8 /* States.ERROR */,\n [\"l\" /* PathCharTypes.ELSE */]: [4 /* States.IN_SUB_PATH */, 0 /* Actions.APPEND */]\n};\npathStateMachine[5 /* States.IN_SINGLE_QUOTE */] = {\n [\"'\" /* PathCharTypes.SINGLE_QUOTE */]: [4 /* States.IN_SUB_PATH */, 0 /* Actions.APPEND */],\n [\"o\" /* PathCharTypes.END_OF_FAIL */]: 8 /* States.ERROR */,\n [\"l\" /* PathCharTypes.ELSE */]: [5 /* States.IN_SINGLE_QUOTE */, 0 /* Actions.APPEND */]\n};\npathStateMachine[6 /* States.IN_DOUBLE_QUOTE */] = {\n [\"\\\"\" /* PathCharTypes.DOUBLE_QUOTE */]: [4 /* States.IN_SUB_PATH */, 0 /* Actions.APPEND */],\n [\"o\" /* PathCharTypes.END_OF_FAIL */]: 8 /* States.ERROR */,\n [\"l\" /* PathCharTypes.ELSE */]: [6 /* States.IN_DOUBLE_QUOTE */, 0 /* Actions.APPEND */]\n};\n/**\n * Check if an expression is a literal value.\n */\nconst literalValueRE = /^\\s?(?:true|false|-?[\\d.]+|'[^']*'|\"[^\"]*\")\\s?$/;\nfunction isLiteral(exp) {\n return literalValueRE.test(exp);\n}\n/**\n * Strip quotes from a string\n */\nfunction stripQuotes(str) {\n const a = str.charCodeAt(0);\n const b = str.charCodeAt(str.length - 1);\n return a === b && (a === 0x22 || a === 0x27) ? str.slice(1, -1) : str;\n}\n/**\n * Determine the type of a character in a keypath.\n */\nfunction getPathCharType(ch) {\n if (ch === undefined || ch === null) {\n return \"o\" /* PathCharTypes.END_OF_FAIL */;\n }\n const code = ch.charCodeAt(0);\n switch (code) {\n case 0x5b: // [\n case 0x5d: // ]\n case 0x2e: // .\n case 0x22: // \"\n case 0x27: // '\n return ch;\n case 0x5f: // _\n case 0x24: // $\n case 0x2d: // -\n return \"i\" /* PathCharTypes.IDENT */;\n case 0x09: // Tab (HT)\n case 0x0a: // Newline (LF)\n case 0x0d: // Return (CR)\n case 0xa0: // No-break space (NBSP)\n case 0xfeff: // Byte Order Mark (BOM)\n case 0x2028: // Line Separator (LS)\n case 0x2029: // Paragraph Separator (PS)\n return \"w\" /* PathCharTypes.WORKSPACE */;\n }\n return \"i\" /* PathCharTypes.IDENT */;\n}\n/**\n * Format a subPath, return its plain form if it is\n * a literal string or number. Otherwise prepend the\n * dynamic indicator (*).\n */\nfunction formatSubPath(path) {\n const trimmed = path.trim();\n // invalid leading 0\n if (path.charAt(0) === '0' && isNaN(parseInt(path))) {\n return false;\n }\n return isLiteral(trimmed)\n ? stripQuotes(trimmed)\n : \"*\" /* PathCharTypes.ASTARISK */ + trimmed;\n}\n/**\n * Parse a string path into an array of segments\n */\nfunction parse(path) {\n const keys = [];\n let index = -1;\n let mode = 0 /* States.BEFORE_PATH */;\n let subPathDepth = 0;\n let c;\n let key; // eslint-disable-line\n let newChar;\n let type;\n let transition;\n let action;\n let typeMap;\n const actions = [];\n actions[0 /* Actions.APPEND */] = () => {\n if (key === undefined) {\n key = newChar;\n }\n else {\n key += newChar;\n }\n };\n actions[1 /* Actions.PUSH */] = () => {\n if (key !== undefined) {\n keys.push(key);\n key = undefined;\n }\n };\n actions[2 /* Actions.INC_SUB_PATH_DEPTH */] = () => {\n actions[0 /* Actions.APPEND */]();\n subPathDepth++;\n };\n actions[3 /* Actions.PUSH_SUB_PATH */] = () => {\n if (subPathDepth > 0) {\n subPathDepth--;\n mode = 4 /* States.IN_SUB_PATH */;\n actions[0 /* Actions.APPEND */]();\n }\n else {\n subPathDepth = 0;\n if (key === undefined) {\n return false;\n }\n key = formatSubPath(key);\n if (key === false) {\n return false;\n }\n else {\n actions[1 /* Actions.PUSH */]();\n }\n }\n };\n function maybeUnescapeQuote() {\n const nextChar = path[index + 1];\n if ((mode === 5 /* States.IN_SINGLE_QUOTE */ &&\n nextChar === \"'\" /* PathCharTypes.SINGLE_QUOTE */) ||\n (mode === 6 /* States.IN_DOUBLE_QUOTE */ &&\n nextChar === \"\\\"\" /* PathCharTypes.DOUBLE_QUOTE */)) {\n index++;\n newChar = '\\\\' + nextChar;\n actions[0 /* Actions.APPEND */]();\n return true;\n }\n }\n while (mode !== null) {\n index++;\n c = path[index];\n if (c === '\\\\' && maybeUnescapeQuote()) {\n continue;\n }\n type = getPathCharType(c);\n typeMap = pathStateMachine[mode];\n transition = typeMap[type] || typeMap[\"l\" /* PathCharTypes.ELSE */] || 8 /* States.ERROR */;\n // check parse error\n if (transition === 8 /* States.ERROR */) {\n return;\n }\n mode = transition[0];\n if (transition[1] !== undefined) {\n action = actions[transition[1]];\n if (action) {\n newChar = c;\n if (action() === false) {\n return;\n }\n }\n }\n // check parse finish\n if (mode === 7 /* States.AFTER_PATH */) {\n return keys;\n }\n }\n}\n// path token cache\nconst cache = new Map();\n/**\n * key-value message resolver\n *\n * @remarks\n * Resolves messages with the key-value structure. Note that messages with a hierarchical structure such as objects cannot be resolved\n *\n * @param obj - A target object to be resolved with path\n * @param path - A {@link Path | path} to resolve the value of message\n *\n * @returns A resolved {@link PathValue | path value}\n *\n * @VueI18nGeneral\n */\nfunction resolveWithKeyValue(obj, path) {\n return isObject(obj) ? obj[path] : null;\n}\n/**\n * message resolver\n *\n * @remarks\n * Resolves messages. messages with a hierarchical structure such as objects can be resolved. This resolver is used in VueI18n as default.\n *\n * @param obj - A target object to be resolved with path\n * @param path - A {@link Path | path} to resolve the value of message\n *\n * @returns A resolved {@link PathValue | path value}\n *\n * @VueI18nGeneral\n */\nfunction resolveValue(obj, path) {\n // check object\n if (!isObject(obj)) {\n return null;\n }\n // parse path\n let hit = cache.get(path);\n if (!hit) {\n hit = parse(path);\n if (hit) {\n cache.set(path, hit);\n }\n }\n // check hit\n if (!hit) {\n return null;\n }\n // resolve path value\n const len = hit.length;\n // eslint-disable-next-line @typescript-eslint/no-explicit-any -- for generic object\n let last = obj;\n let i = 0;\n while (i < len) {\n const key = hit[i];\n /**\n * NOTE:\n * if `key` is intlify message format AST node key and `last` is intlify message format AST, skip it.\n * because the AST node is not a key-value structure.\n */\n if (AST_NODE_PROPS_KEYS.includes(key) && isMessageAST(last)) {\n return null;\n }\n if (!isObject(last)) {\n return null;\n }\n if (!hasOwn(last, key)) {\n return null;\n }\n const val = last[key];\n if (val === undefined) {\n return null;\n }\n if (isFunction(last)) {\n return null;\n }\n last = val;\n i++;\n }\n return last;\n}\n\nconst CoreWarnCodes = {\n NOT_FOUND_KEY: 1,\n FALLBACK_TO_TRANSLATE: 2,\n CANNOT_FORMAT_NUMBER: 3,\n FALLBACK_TO_NUMBER_FORMAT: 4,\n CANNOT_FORMAT_DATE: 5,\n FALLBACK_TO_DATE_FORMAT: 6,\n EXPERIMENTAL_CUSTOM_MESSAGE_COMPILER: 7,\n INVALID_NUMBER_ARGUMENT: 8,\n INVALID_DATE_ARGUMENT: 9\n};\nconst CORE_WARN_CODES_EXTEND_POINT = 10;\n/** @internal */\nconst warnMessages = {\n [CoreWarnCodes.NOT_FOUND_KEY]: `Not found '{key}' key in '{locale}' locale messages.`,\n [CoreWarnCodes.FALLBACK_TO_TRANSLATE]: `Fall back to translate '{key}' key with '{target}' locale.`,\n [CoreWarnCodes.CANNOT_FORMAT_NUMBER]: `Cannot format a number value due to not supported Intl.NumberFormat.`,\n [CoreWarnCodes.FALLBACK_TO_NUMBER_FORMAT]: `Fall back to number format '{key}' key with '{target}' locale.`,\n [CoreWarnCodes.CANNOT_FORMAT_DATE]: `Cannot format a date value due to not supported Intl.DateTimeFormat.`,\n [CoreWarnCodes.FALLBACK_TO_DATE_FORMAT]: `Fall back to datetime format '{key}' key with '{target}' locale.`,\n [CoreWarnCodes.EXPERIMENTAL_CUSTOM_MESSAGE_COMPILER]: `This project is using Custom Message Compiler, which is an experimental feature. It may receive breaking changes or be removed in the future.`,\n [CoreWarnCodes.INVALID_NUMBER_ARGUMENT]: `Invalid argument for number formatting: expected a number but received '{value}'.`,\n [CoreWarnCodes.INVALID_DATE_ARGUMENT]: `Invalid argument for datetime formatting: expected a Date, number, or ISO string but received '{value}'.`\n};\nfunction getWarnMessage(code, ...args) {\n return format$1(warnMessages[code], ...args);\n}\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n/**\n * Intlify core-base version\n * @internal\n */\nconst VERSION = '11.3.0';\nconst NOT_REOSLVED = -1;\nconst DEFAULT_LOCALE = 'en-US';\nconst MISSING_RESOLVE_VALUE = '';\nconst capitalize = (str) => `${str.charAt(0).toLocaleUpperCase()}${str.substr(1)}`;\nfunction getDefaultLinkedModifiers() {\n return {\n upper: (val, type) => {\n // prettier-ignore\n return type === 'text' && isString(val)\n ? val.toUpperCase()\n : type === 'vnode' && isObject(val) && '__v_isVNode' in val\n ? val.children.toUpperCase()\n : val;\n },\n lower: (val, type) => {\n // prettier-ignore\n return type === 'text' && isString(val)\n ? val.toLowerCase()\n : type === 'vnode' && isObject(val) && '__v_isVNode' in val\n ? val.children.toLowerCase()\n : val;\n },\n capitalize: (val, type) => {\n // prettier-ignore\n return (type === 'text' && isString(val)\n ? capitalize(val)\n : type === 'vnode' && isObject(val) && '__v_isVNode' in val\n ? capitalize(val.children)\n : val);\n }\n };\n}\nlet _compiler;\nfunction registerMessageCompiler(compiler) {\n _compiler = compiler;\n}\nlet _resolver;\n/**\n * Register the message resolver\n *\n * @param resolver - A {@link MessageResolver} function\n *\n * @VueI18nGeneral\n */\nfunction registerMessageResolver(resolver) {\n _resolver = resolver;\n}\nlet _fallbacker;\n/**\n * Register the locale fallbacker\n *\n * @param fallbacker - A {@link LocaleFallbacker} function\n *\n * @VueI18nGeneral\n */\nfunction registerLocaleFallbacker(fallbacker) {\n _fallbacker = fallbacker;\n}\n// Additional Meta for Intlify DevTools\nlet _additionalMeta = null;\n/* #__NO_SIDE_EFFECTS__ */\nconst setAdditionalMeta = (meta) => {\n _additionalMeta = meta;\n};\n/* #__NO_SIDE_EFFECTS__ */\nconst getAdditionalMeta = () => _additionalMeta;\nlet _fallbackContext = null;\nconst setFallbackContext = (context) => {\n _fallbackContext = context;\n};\nconst getFallbackContext = () => _fallbackContext;\n// ID for CoreContext\nlet _cid = 0;\nfunction createCoreContext(options = {}) {\n // setup options\n const onWarn = isFunction(options.onWarn) ? options.onWarn : warn;\n const version = isString(options.version) ? options.version : VERSION;\n const locale = isString(options.locale) || isFunction(options.locale)\n ? options.locale\n : DEFAULT_LOCALE;\n const _locale = isFunction(locale) ? DEFAULT_LOCALE : locale;\n const fallbackLocale = isArray(options.fallbackLocale) ||\n isPlainObject(options.fallbackLocale) ||\n isString(options.fallbackLocale) ||\n options.fallbackLocale === false\n ? options.fallbackLocale\n : _locale;\n const messages = isPlainObject(options.messages)\n ? options.messages\n : createResources(_locale);\n const datetimeFormats = isPlainObject(options.datetimeFormats)\n ? options.datetimeFormats\n : createResources(_locale)\n ;\n const numberFormats = isPlainObject(options.numberFormats)\n ? options.numberFormats\n : createResources(_locale)\n ;\n const modifiers = assign(create(), options.modifiers, getDefaultLinkedModifiers());\n const pluralRules = options.pluralRules || create();\n const missing = isFunction(options.missing) ? options.missing : null;\n const missingWarn = isBoolean(options.missingWarn) || isRegExp(options.missingWarn)\n ? options.missingWarn\n : true;\n const fallbackWarn = isBoolean(options.fallbackWarn) || isRegExp(options.fallbackWarn)\n ? options.fallbackWarn\n : true;\n const fallbackFormat = !!options.fallbackFormat;\n const unresolving = !!options.unresolving;\n const postTranslation = isFunction(options.postTranslation)\n ? options.postTranslation\n : null;\n const processor = isPlainObject(options.processor) ? options.processor : null;\n const warnHtmlMessage = isBoolean(options.warnHtmlMessage)\n ? options.warnHtmlMessage\n : true;\n const escapeParameter = !!options.escapeParameter;\n const messageCompiler = isFunction(options.messageCompiler)\n ? options.messageCompiler\n : _compiler;\n if ((process.env.NODE_ENV !== 'production') &&\n !false &&\n !false &&\n isFunction(options.messageCompiler)) {\n warnOnce(getWarnMessage(CoreWarnCodes.EXPERIMENTAL_CUSTOM_MESSAGE_COMPILER));\n }\n const messageResolver = isFunction(options.messageResolver)\n ? options.messageResolver\n : _resolver || resolveWithKeyValue;\n const localeFallbacker = isFunction(options.localeFallbacker)\n ? options.localeFallbacker\n : _fallbacker || fallbackWithSimple;\n const fallbackContext = isObject(options.fallbackContext)\n ? options.fallbackContext\n : undefined;\n // setup internal options\n const internalOptions = options;\n const __datetimeFormatters = isObject(internalOptions.__datetimeFormatters)\n ? internalOptions.__datetimeFormatters\n : new Map()\n ;\n const __numberFormatters = isObject(internalOptions.__numberFormatters)\n ? internalOptions.__numberFormatters\n : new Map()\n ;\n const __meta = isObject(internalOptions.__meta) ? internalOptions.__meta : {};\n _cid++;\n const context = {\n version,\n cid: _cid,\n locale,\n fallbackLocale,\n messages,\n modifiers,\n pluralRules,\n missing,\n missingWarn,\n fallbackWarn,\n fallbackFormat,\n unresolving,\n postTranslation,\n processor,\n warnHtmlMessage,\n escapeParameter,\n messageCompiler,\n messageResolver,\n localeFallbacker,\n fallbackContext,\n onWarn,\n __meta\n };\n {\n context.datetimeFormats = datetimeFormats;\n context.numberFormats = numberFormats;\n context.__datetimeFormatters = __datetimeFormatters;\n context.__numberFormatters = __numberFormatters;\n }\n // for vue-devtools timeline event\n if ((process.env.NODE_ENV !== 'production')) {\n context.__v_emitter =\n internalOptions.__v_emitter != null\n ? internalOptions.__v_emitter\n : undefined;\n }\n // NOTE: experimental !!\n if ((process.env.NODE_ENV !== 'production') || __INTLIFY_PROD_DEVTOOLS__) {\n initI18nDevTools(context, version, __meta);\n }\n return context;\n}\nconst createResources = (locale) => ({ [locale]: create() });\n/** @internal */\nfunction isTranslateFallbackWarn(fallback, key) {\n return fallback instanceof RegExp ? fallback.test(key) : fallback;\n}\n/** @internal */\nfunction isTranslateMissingWarn(missing, key) {\n return missing instanceof RegExp ? missing.test(key) : missing;\n}\n/** @internal */\nfunction handleMissing(context, key, locale, missingWarn, type) {\n const { missing, onWarn } = context;\n // for vue-devtools timeline event\n if ((process.env.NODE_ENV !== 'production')) {\n const emitter = context.__v_emitter;\n if (emitter) {\n emitter.emit('missing', {\n locale,\n key,\n type,\n groupId: `${type}:${key}`\n });\n }\n }\n if (missing !== null) {\n const ret = missing(context, locale, key, type);\n return isString(ret) ? ret : key;\n }\n else {\n if ((process.env.NODE_ENV !== 'production') && isTranslateMissingWarn(missingWarn, key)) {\n onWarn(getWarnMessage(CoreWarnCodes.NOT_FOUND_KEY, { key, locale }));\n }\n return key;\n }\n}\n/** @internal */\nfunction updateFallbackLocale(ctx, locale, fallback) {\n const context = ctx;\n context.__localeChainCache = new Map();\n ctx.localeFallbacker(ctx, fallback, locale);\n}\n/** @internal */\nfunction isAlmostSameLocale(locale, compareLocale) {\n if (locale === compareLocale)\n return false;\n return locale.split('-')[0] === compareLocale.split('-')[0];\n}\n/** @internal */\nfunction isImplicitFallback(targetLocale, locales) {\n const index = locales.indexOf(targetLocale);\n if (index === -1) {\n return false;\n }\n for (let i = index + 1; i < locales.length; i++) {\n if (isAlmostSameLocale(targetLocale, locales[i])) {\n return true;\n }\n }\n return false;\n}\n/* eslint-enable @typescript-eslint/no-explicit-any */\n\nconst intlDefined = typeof Intl !== 'undefined';\nconst Availabilities = {\n dateTimeFormat: intlDefined && typeof Intl.DateTimeFormat !== 'undefined',\n numberFormat: intlDefined && typeof Intl.NumberFormat !== 'undefined'\n};\n\n// implementation of `datetime` function\nfunction datetime(context, ...args) {\n const { datetimeFormats, unresolving, fallbackLocale, onWarn, localeFallbacker } = context;\n const { __datetimeFormatters } = context;\n if ((process.env.NODE_ENV !== 'production') && !Availabilities.dateTimeFormat) {\n onWarn(getWarnMessage(CoreWarnCodes.CANNOT_FORMAT_DATE));\n return MISSING_RESOLVE_VALUE;\n }\n if (!isString(args[0]) && !isDate(args[0]) && !isNumber(args[0])) {\n if ((process.env.NODE_ENV !== 'production')) {\n onWarn(getWarnMessage(CoreWarnCodes.INVALID_DATE_ARGUMENT, {\n value: String(args[0])\n }));\n }\n return MISSING_RESOLVE_VALUE;\n }\n const [key, value, options, overrides] = parseDateTimeArgs(...args);\n const missingWarn = isBoolean(options.missingWarn)\n ? options.missingWarn\n : context.missingWarn;\n const fallbackWarn = isBoolean(options.fallbackWarn)\n ? options.fallbackWarn\n : context.fallbackWarn;\n const part = !!options.part;\n const locale = getLocale(context, options);\n const locales = localeFallbacker(context, // eslint-disable-line @typescript-eslint/no-explicit-any\n fallbackLocale, locale);\n if (!isString(key) || key === '') {\n return new Intl.DateTimeFormat(locale.replace(/!/g, ''), overrides).format(value);\n }\n // resolve format\n let datetimeFormat = {};\n let targetLocale;\n let format = null;\n let from = locale;\n let to = null;\n const type = 'datetime format';\n for (let i = 0; i < locales.length; i++) {\n targetLocale = to = locales[i];\n if ((process.env.NODE_ENV !== 'production') &&\n locale !== targetLocale &&\n isTranslateFallbackWarn(fallbackWarn, key)) {\n onWarn(getWarnMessage(CoreWarnCodes.FALLBACK_TO_DATE_FORMAT, {\n key,\n target: targetLocale\n }));\n }\n // for vue-devtools timeline event\n if ((process.env.NODE_ENV !== 'production') && locale !== targetLocale) {\n const emitter = context.__v_emitter;\n if (emitter) {\n emitter.emit('fallback', {\n type,\n key,\n from,\n to,\n groupId: `${type}:${key}`\n });\n }\n }\n datetimeFormat =\n datetimeFormats[targetLocale] || {};\n format = datetimeFormat[key];\n if (isPlainObject(format))\n break;\n handleMissing(context, key, targetLocale, missingWarn, type); // eslint-disable-line @typescript-eslint/no-explicit-any\n from = to;\n }\n // checking format and target locale\n if (!isPlainObject(format) || !isString(targetLocale)) {\n return unresolving ? NOT_REOSLVED : key;\n }\n let id = `${targetLocale}__${key}`;\n if (!isEmptyObject(overrides)) {\n id = `${id}__${JSON.stringify(overrides)}`;\n }\n let formatter = __datetimeFormatters.get(id);\n if (!formatter) {\n formatter = new Intl.DateTimeFormat(targetLocale, assign({}, format, overrides));\n __datetimeFormatters.set(id, formatter);\n }\n return !part ? formatter.format(value) : formatter.formatToParts(value);\n}\n/** @internal */\nconst DATETIME_FORMAT_OPTIONS_KEYS = [\n 'localeMatcher',\n 'weekday',\n 'era',\n 'year',\n 'month',\n 'day',\n 'hour',\n 'minute',\n 'second',\n 'timeZoneName',\n 'formatMatcher',\n 'hour12',\n 'timeZone',\n 'dateStyle',\n 'timeStyle',\n 'calendar',\n 'dayPeriod',\n 'numberingSystem',\n 'hourCycle',\n 'fractionalSecondDigits'\n];\n/** @internal */\nfunction parseDateTimeArgs(...args) {\n const [arg1, arg2, arg3, arg4] = args;\n const options = create();\n let overrides = create();\n let value;\n if (isString(arg1)) {\n // Only allow ISO strings - other date formats are often supported,\n // but may cause different results in different browsers.\n const matches = arg1.match(/(\\d{4}-\\d{2}-\\d{2})(T|\\s)?(.*)/);\n if (!matches) {\n throw createCoreError(CoreErrorCodes.INVALID_ISO_DATE_ARGUMENT);\n }\n // Some browsers can not parse the iso datetime separated by space,\n // this is a compromise solution by replace the 'T'/' ' with 'T'\n const dateTime = matches[3]\n ? matches[3].trim().startsWith('T')\n ? `${matches[1].trim()}${matches[3].trim()}`\n : `${matches[1].trim()}T${matches[3].trim()}`\n : matches[1].trim();\n value = new Date(dateTime);\n try {\n // This will fail if the date is not valid\n value.toISOString();\n }\n catch {\n throw createCoreError(CoreErrorCodes.INVALID_ISO_DATE_ARGUMENT);\n }\n }\n else if (isDate(arg1)) {\n if (isNaN(arg1.getTime())) {\n throw createCoreError(CoreErrorCodes.INVALID_DATE_ARGUMENT);\n }\n value = arg1;\n }\n else if (isNumber(arg1)) {\n value = arg1;\n }\n else {\n throw createCoreError(CoreErrorCodes.INVALID_ARGUMENT);\n }\n if (isString(arg2)) {\n options.key = arg2;\n }\n else if (isPlainObject(arg2)) {\n Object.keys(arg2).forEach(key => {\n if (DATETIME_FORMAT_OPTIONS_KEYS.includes(key)) {\n overrides[key] = arg2[key];\n }\n else {\n options[key] = arg2[key];\n }\n });\n }\n if (isString(arg3)) {\n options.locale = arg3;\n }\n else if (isPlainObject(arg3)) {\n overrides = arg3;\n }\n if (isPlainObject(arg4)) {\n overrides = arg4;\n }\n return [options.key || '', value, options, overrides];\n}\n/** @internal */\nfunction clearDateTimeFormat(ctx, locale, format) {\n const context = ctx;\n for (const key in format) {\n const id = `${locale}__${key}`;\n if (!context.__datetimeFormatters.has(id)) {\n continue;\n }\n context.__datetimeFormatters.delete(id);\n }\n}\n\n// implementation of `number` function\nfunction number(context, ...args) {\n const { numberFormats, unresolving, fallbackLocale, onWarn, localeFallbacker } = context;\n const { __numberFormatters } = context;\n if ((process.env.NODE_ENV !== 'production') && !Availabilities.numberFormat) {\n onWarn(getWarnMessage(CoreWarnCodes.CANNOT_FORMAT_NUMBER));\n return MISSING_RESOLVE_VALUE;\n }\n if (!isNumber(args[0])) {\n if ((process.env.NODE_ENV !== 'production')) {\n onWarn(getWarnMessage(CoreWarnCodes.INVALID_NUMBER_ARGUMENT, {\n value: String(args[0])\n }));\n }\n return MISSING_RESOLVE_VALUE;\n }\n const [key, value, options, overrides] = parseNumberArgs(...args);\n const missingWarn = isBoolean(options.missingWarn)\n ? options.missingWarn\n : context.missingWarn;\n const fallbackWarn = isBoolean(options.fallbackWarn)\n ? options.fallbackWarn\n : context.fallbackWarn;\n const part = !!options.part;\n const locale = getLocale(context, options);\n const locales = localeFallbacker(context, // eslint-disable-line @typescript-eslint/no-explicit-any\n fallbackLocale, locale);\n if (!isString(key) || key === '') {\n return new Intl.NumberFormat(locale.replace(/!/g, ''), overrides).format(value);\n }\n // resolve format\n let numberFormat = {};\n let targetLocale;\n let format = null;\n let from = locale;\n let to = null;\n const type = 'number format';\n for (let i = 0; i < locales.length; i++) {\n targetLocale = to = locales[i];\n if ((process.env.NODE_ENV !== 'production') &&\n locale !== targetLocale &&\n isTranslateFallbackWarn(fallbackWarn, key)) {\n onWarn(getWarnMessage(CoreWarnCodes.FALLBACK_TO_NUMBER_FORMAT, {\n key,\n target: targetLocale\n }));\n }\n // for vue-devtools timeline event\n if ((process.env.NODE_ENV !== 'production') && locale !== targetLocale) {\n const emitter = context.__v_emitter;\n if (emitter) {\n emitter.emit('fallback', {\n type,\n key,\n from,\n to,\n groupId: `${type}:${key}`\n });\n }\n }\n numberFormat =\n numberFormats[targetLocale] || {};\n format = numberFormat[key];\n if (isPlainObject(format))\n break;\n handleMissing(context, key, targetLocale, missingWarn, type); // eslint-disable-line @typescript-eslint/no-explicit-any\n from = to;\n }\n // checking format and target locale\n if (!isPlainObject(format) || !isString(targetLocale)) {\n return unresolving ? NOT_REOSLVED : key;\n }\n let id = `${targetLocale}__${key}`;\n if (!isEmptyObject(overrides)) {\n id = `${id}__${JSON.stringify(overrides)}`;\n }\n let formatter = __numberFormatters.get(id);\n if (!formatter) {\n formatter = new Intl.NumberFormat(targetLocale, assign({}, format, overrides));\n __numberFormatters.set(id, formatter);\n }\n return !part ? formatter.format(value) : formatter.formatToParts(value);\n}\n/** @internal */\nconst NUMBER_FORMAT_OPTIONS_KEYS = [\n 'localeMatcher',\n 'style',\n 'currency',\n 'currencyDisplay',\n 'currencySign',\n 'useGrouping',\n 'minimumIntegerDigits',\n 'minimumFractionDigits',\n 'maximumFractionDigits',\n 'minimumSignificantDigits',\n 'maximumSignificantDigits',\n 'compactDisplay',\n 'notation',\n 'signDisplay',\n 'unit',\n 'unitDisplay',\n 'roundingMode',\n 'roundingPriority',\n 'roundingIncrement',\n 'trailingZeroDisplay'\n];\n/** @internal */\nfunction parseNumberArgs(...args) {\n const [arg1, arg2, arg3, arg4] = args;\n const options = create();\n let overrides = create();\n if (!isNumber(arg1)) {\n throw createCoreError(CoreErrorCodes.INVALID_ARGUMENT);\n }\n const value = arg1;\n if (isString(arg2)) {\n options.key = arg2;\n }\n else if (isPlainObject(arg2)) {\n Object.keys(arg2).forEach(key => {\n if (NUMBER_FORMAT_OPTIONS_KEYS.includes(key)) {\n overrides[key] = arg2[key];\n }\n else {\n options[key] = arg2[key];\n }\n });\n }\n if (isString(arg3)) {\n options.locale = arg3;\n }\n else if (isPlainObject(arg3)) {\n overrides = arg3;\n }\n if (isPlainObject(arg4)) {\n overrides = arg4;\n }\n return [options.key || '', value, options, overrides];\n}\n/** @internal */\nfunction clearNumberFormat(ctx, locale, format) {\n const context = ctx;\n for (const key in format) {\n const id = `${locale}__${key}`;\n if (!context.__numberFormatters.has(id)) {\n continue;\n }\n context.__numberFormatters.delete(id);\n }\n}\n\nconst DEFAULT_MODIFIER = (str) => str;\nconst DEFAULT_MESSAGE = (ctx) => ''; // eslint-disable-line\nconst DEFAULT_MESSAGE_DATA_TYPE = 'text';\nconst DEFAULT_NORMALIZE = (values) => values.length === 0 ? '' : join(values);\nconst DEFAULT_INTERPOLATE = toDisplayString;\nfunction pluralDefault(choice, choicesLength) {\n choice = Math.abs(choice);\n // singular (0) | plural (1)\n if (choicesLength === 2) {\n // prettier-ignore\n return choice === 1\n ? 0\n : 1;\n }\n // zero (0) | singular (1) | plural (2)\n return Math.min(choice, 2);\n}\nfunction getPluralIndex(options) {\n // prettier-ignore\n const index = isNumber(options.pluralIndex)\n ? options.pluralIndex\n : -1;\n return isNumber(options.named?.count)\n ? options.named.count\n : isNumber(options.named?.n)\n ? options.named.n\n : index;\n}\nfunction createMessageContext(options = {}) {\n const locale = options.locale;\n const pluralIndex = getPluralIndex(options);\n const pluralRule = isString(locale) && isFunction(options.pluralRules?.[locale])\n ? options.pluralRules[locale]\n : pluralDefault;\n const orgPluralRule = pluralRule === pluralDefault ? undefined : pluralDefault;\n const plural = (messages) => messages[pluralRule(pluralIndex, messages.length, orgPluralRule)];\n const _list = options.list || [];\n const list = (index) => _list[index];\n const _named = options.named || create(); // eslint-disable-line @typescript-eslint/no-explicit-any\n // normalize named\n if (isNumber(options.pluralIndex)) {\n _named.count ||= options.pluralIndex;\n _named.n ||= options.pluralIndex;\n }\n const named = (key) => _named[key];\n function message(key, useLinked) {\n // prettier-ignore\n const msg = isFunction(options.messages)\n ? options.messages(key, !!useLinked)\n : isObject(options.messages)\n ? options.messages[key]\n : false;\n return !msg\n ? options.parent\n ? options.parent.message(key) // resolve from parent messages\n : DEFAULT_MESSAGE\n : msg;\n }\n const _modifier = (name) => options.modifiers\n ? options.modifiers[name]\n : DEFAULT_MODIFIER;\n const normalize = isFunction(options.processor?.normalize)\n ? options.processor.normalize\n : DEFAULT_NORMALIZE;\n const interpolate = isFunction(options.processor?.interpolate)\n ? options.processor.interpolate\n : DEFAULT_INTERPOLATE;\n const type = isString(options.processor?.type)\n ? options.processor.type\n : DEFAULT_MESSAGE_DATA_TYPE;\n const linked = (key, ...args) => {\n const [arg1, arg2] = args;\n let type = 'text';\n let modifier = '';\n if (args.length === 1) {\n if (isObject(arg1)) {\n modifier = arg1.modifier || modifier;\n type = arg1.type || type;\n }\n else if (isString(arg1)) {\n modifier = arg1 || modifier;\n }\n }\n else if (args.length === 2) {\n if (isString(arg1)) {\n modifier = arg1 || modifier;\n }\n if (isString(arg2)) {\n type = arg2 || type;\n }\n }\n const ret = message(key, true)(ctx);\n // If the linked message is not resolved (empty string), fall back to the key itself\n const resolved = ret === '' || ret === undefined ? key : ret;\n const msg = \n // The message in vnode resolved with linked are returned as an array by processor.nomalize\n type === 'vnode' && isArray(resolved) && modifier\n ? resolved[0]\n : resolved;\n return modifier ? _modifier(modifier)(msg, type) : msg;\n };\n const ctx = {\n [\"list\" /* HelperNameMap.LIST */]: list,\n [\"named\" /* HelperNameMap.NAMED */]: named,\n [\"plural\" /* HelperNameMap.PLURAL */]: plural,\n [\"linked\" /* HelperNameMap.LINKED */]: linked,\n [\"message\" /* HelperNameMap.MESSAGE */]: message,\n [\"type\" /* HelperNameMap.TYPE */]: type,\n [\"interpolate\" /* HelperNameMap.INTERPOLATE */]: interpolate,\n [\"normalize\" /* HelperNameMap.NORMALIZE */]: normalize,\n [\"values\" /* HelperNameMap.VALUES */]: assign(create(), _list, _named)\n };\n return ctx;\n}\n\nconst NOOP_MESSAGE_FUNCTION = () => '';\nconst isMessageFunction = (val) => isFunction(val);\n// implementation of `translate` function\nfunction translate(context, ...args) {\n const { fallbackFormat, postTranslation, unresolving, messageCompiler, fallbackLocale, messages } = context;\n const [key, options] = parseTranslateArgs(...args);\n const missingWarn = isBoolean(options.missingWarn)\n ? options.missingWarn\n : context.missingWarn;\n const fallbackWarn = isBoolean(options.fallbackWarn)\n ? options.fallbackWarn\n : context.fallbackWarn;\n const escapeParameter = isBoolean(options.escapeParameter)\n ? options.escapeParameter\n : context.escapeParameter;\n const resolvedMessage = !!options.resolvedMessage;\n // prettier-ignore\n const defaultMsgOrKey = isString(options.default) || isBoolean(options.default) // default by function option\n ? !isBoolean(options.default)\n ? options.default\n : (!messageCompiler ? () => key : key)\n : fallbackFormat // default by `fallbackFormat` option\n ? (!messageCompiler ? () => key : key)\n : null;\n const enableDefaultMsg = fallbackFormat ||\n (defaultMsgOrKey != null &&\n (isString(defaultMsgOrKey) || isFunction(defaultMsgOrKey)));\n const locale = getLocale(context, options);\n // escape params\n escapeParameter && escapeParams(options);\n // resolve message format\n // eslint-disable-next-line prefer-const\n let [formatScope, targetLocale, message] = !resolvedMessage\n ? resolveMessageFormat(context, key, locale, fallbackLocale, fallbackWarn, missingWarn)\n : [\n key,\n locale,\n messages[locale] || create()\n ];\n // NOTE:\n // Fix to work around `ssrTransfrom` bug in Vite.\n // https://github.com/vitejs/vite/issues/4306\n // To get around this, use temporary variables.\n // https://github.com/nuxt/framework/issues/1461#issuecomment-954606243\n let format = formatScope;\n // if you use default message, set it as message format!\n let cacheBaseKey = key;\n if (!resolvedMessage &&\n !(isString(format) ||\n isMessageAST(format) ||\n isMessageFunction(format))) {\n if (enableDefaultMsg) {\n format = defaultMsgOrKey;\n cacheBaseKey = format;\n }\n }\n // checking message format and target locale\n if (!resolvedMessage &&\n (!(isString(format) ||\n isMessageAST(format) ||\n isMessageFunction(format)) ||\n !isString(targetLocale))) {\n return unresolving ? NOT_REOSLVED : key;\n }\n // TODO: refactor\n if ((process.env.NODE_ENV !== 'production') && isString(format) && context.messageCompiler == null) {\n warn(`The message format compilation is not supported in this build. ` +\n `Because message compiler isn't included. ` +\n `You need to pre-compilation all message format. ` +\n `So translate function return '${key}'.`);\n return key;\n }\n // setup compile error detecting\n let occurred = false;\n const onError = () => {\n occurred = true;\n };\n // compile message format\n const msg = !isMessageFunction(format)\n ? compileMessageFormat(context, key, targetLocale, format, cacheBaseKey, onError)\n : format;\n // if occurred compile error, return the message format\n if (occurred) {\n return format;\n }\n // evaluate message with context\n const ctxOptions = getMessageContextOptions(context, targetLocale, message, options);\n const msgContext = createMessageContext(ctxOptions);\n const messaged = evaluateMessage(context, msg, msgContext);\n // if use post translation option, proceed it with handler\n let ret = postTranslation\n ? postTranslation(messaged, key)\n : messaged;\n // apply HTML sanitization for security\n if (escapeParameter && isString(ret)) {\n ret = sanitizeTranslatedHtml(ret);\n }\n // NOTE: experimental !!\n if ((process.env.NODE_ENV !== 'production') || __INTLIFY_PROD_DEVTOOLS__) {\n // prettier-ignore\n const payloads = {\n timestamp: Date.now(),\n key: isString(key)\n ? key\n : isMessageFunction(format)\n ? format.key\n : '',\n locale: targetLocale || (isMessageFunction(format)\n ? format.locale\n : ''),\n format: isString(format)\n ? format\n : isMessageFunction(format)\n ? format.source\n : '',\n message: ret\n };\n payloads.meta = assign({}, context.__meta, getAdditionalMeta() || {});\n translateDevTools(payloads);\n }\n return ret;\n}\nfunction escapeParams(options) {\n if (isArray(options.list)) {\n options.list = options.list.map(item => isString(item) ? escapeHtml(item) : item);\n }\n else if (isObject(options.named)) {\n Object.keys(options.named).forEach(key => {\n if (isString(options.named[key])) {\n options.named[key] = escapeHtml(options.named[key]);\n }\n });\n }\n}\nfunction resolveMessageFormat(context, key, locale, fallbackLocale, fallbackWarn, missingWarn) {\n const { messages, onWarn, messageResolver: resolveValue, localeFallbacker } = context;\n const locales = localeFallbacker(context, fallbackLocale, locale); // eslint-disable-line @typescript-eslint/no-explicit-any\n let message = create();\n let targetLocale;\n let format = null;\n let from = locale;\n let to = null;\n const type = 'translate';\n for (let i = 0; i < locales.length; i++) {\n targetLocale = to = locales[i];\n if ((process.env.NODE_ENV !== 'production') &&\n locale !== targetLocale &&\n !isAlmostSameLocale(locale, targetLocale) &&\n isTranslateFallbackWarn(fallbackWarn, key)) {\n onWarn(getWarnMessage(CoreWarnCodes.FALLBACK_TO_TRANSLATE, {\n key,\n target: targetLocale\n }));\n }\n // for vue-devtools timeline event\n if ((process.env.NODE_ENV !== 'production') && locale !== targetLocale) {\n const emitter = context.__v_emitter;\n if (emitter) {\n emitter.emit('fallback', {\n type,\n key,\n from,\n to,\n groupId: `${type}:${key}`\n });\n }\n }\n message =\n messages[targetLocale] || create();\n // for vue-devtools timeline event\n let start = null;\n let startTag;\n let endTag;\n if ((process.env.NODE_ENV !== 'production') && inBrowser) {\n start = window.performance.now();\n startTag = 'intlify-message-resolve-start';\n endTag = 'intlify-message-resolve-end';\n mark && mark(startTag);\n }\n if ((format = resolveValue(message, key)) === null) {\n // if null, resolve with object key path\n format = message[key]; // eslint-disable-line @typescript-eslint/no-explicit-any\n }\n // for vue-devtools timeline event\n if ((process.env.NODE_ENV !== 'production') && inBrowser) {\n const end = window.performance.now();\n const emitter = context.__v_emitter;\n if (emitter && start && format) {\n emitter.emit('message-resolve', {\n type: 'message-resolve',\n key,\n message: format,\n time: end - start,\n groupId: `${type}:${key}`\n });\n }\n if (startTag && endTag && mark && measure) {\n mark(endTag);\n measure('intlify message resolve', startTag, endTag);\n }\n }\n if (isString(format) || isMessageAST(format) || isMessageFunction(format)) {\n break;\n }\n if (!isImplicitFallback(targetLocale, locales)) {\n const missingRet = handleMissing(context, // eslint-disable-line @typescript-eslint/no-explicit-any\n key, targetLocale, missingWarn, type);\n if (missingRet !== key) {\n format = missingRet;\n }\n }\n from = to;\n }\n return [format, targetLocale, message];\n}\nfunction compileMessageFormat(context, key, targetLocale, format, cacheBaseKey, onError) {\n const { messageCompiler, warnHtmlMessage } = context;\n if (isMessageFunction(format)) {\n const msg = format;\n msg.locale = msg.locale || targetLocale;\n msg.key = msg.key || key;\n return msg;\n }\n if (messageCompiler == null) {\n const msg = (() => format);\n msg.locale = targetLocale;\n msg.key = key;\n return msg;\n }\n // for vue-devtools timeline event\n let start = null;\n let startTag;\n let endTag;\n if ((process.env.NODE_ENV !== 'production') && inBrowser) {\n start = window.performance.now();\n startTag = 'intlify-message-compilation-start';\n endTag = 'intlify-message-compilation-end';\n mark && mark(startTag);\n }\n const msg = messageCompiler(format, getCompileContext(context, targetLocale, cacheBaseKey, format, warnHtmlMessage, onError));\n // for vue-devtools timeline event\n if ((process.env.NODE_ENV !== 'production') && inBrowser) {\n const end = window.performance.now();\n const emitter = context.__v_emitter;\n if (emitter && start) {\n emitter.emit('message-compilation', {\n type: 'message-compilation',\n message: format,\n time: end - start,\n groupId: `${'translate'}:${key}`\n });\n }\n if (startTag && endTag && mark && measure) {\n mark(endTag);\n measure('intlify message compilation', startTag, endTag);\n }\n }\n msg.locale = targetLocale;\n msg.key = key;\n msg.source = format;\n return msg;\n}\nfunction evaluateMessage(context, msg, msgCtx) {\n // for vue-devtools timeline event\n let start = null;\n let startTag;\n let endTag;\n if ((process.env.NODE_ENV !== 'production') && inBrowser) {\n start = window.performance.now();\n startTag = 'intlify-message-evaluation-start';\n endTag = 'intlify-message-evaluation-end';\n mark && mark(startTag);\n }\n const messaged = msg(msgCtx);\n // for vue-devtools timeline event\n if ((process.env.NODE_ENV !== 'production') && inBrowser) {\n const end = window.performance.now();\n const emitter = context.__v_emitter;\n if (emitter && start) {\n emitter.emit('message-evaluation', {\n type: 'message-evaluation',\n value: messaged,\n time: end - start,\n groupId: `${'translate'}:${msg.key}`\n });\n }\n if (startTag && endTag && mark && measure) {\n mark(endTag);\n measure('intlify message evaluation', startTag, endTag);\n }\n }\n return messaged;\n}\n/** @internal */\nfunction parseTranslateArgs(...args) {\n const [arg1, arg2, arg3] = args;\n const options = create();\n if (!isString(arg1) &&\n !isNumber(arg1) &&\n !isMessageFunction(arg1) &&\n !isMessageAST(arg1)) {\n throw createCoreError(CoreErrorCodes.INVALID_ARGUMENT);\n }\n // prettier-ignore\n const key = isNumber(arg1)\n ? String(arg1)\n : isMessageFunction(arg1)\n ? arg1\n : arg1;\n if (isNumber(arg2)) {\n options.plural = arg2;\n }\n else if (isString(arg2)) {\n options.default = arg2;\n }\n else if (isPlainObject(arg2) && !isEmptyObject(arg2)) {\n options.named = arg2;\n }\n else if (isArray(arg2)) {\n options.list = arg2;\n }\n if (isNumber(arg3)) {\n options.plural = arg3;\n }\n else if (isString(arg3)) {\n options.default = arg3;\n }\n else if (isPlainObject(arg3)) {\n assign(options, arg3);\n }\n return [key, options];\n}\nfunction getCompileContext(context, locale, key, source, warnHtmlMessage, onError) {\n return {\n locale,\n key,\n warnHtmlMessage,\n onError: (err) => {\n onError && onError(err);\n if ((process.env.NODE_ENV !== 'production')) {\n const _source = getSourceForCodeFrame(source);\n const codeFrame = err.location &&\n _source &&\n generateCodeFrame(_source, err.location.start.offset, err.location.end.offset);\n const emitter = context.__v_emitter;\n if (emitter && _source) {\n emitter.emit('compile-error', {\n message: _source,\n error: err.message,\n start: err.location && err.location.start.offset,\n end: err.location && err.location.end.offset,\n groupId: `${'translate'}:${key}`\n });\n }\n const message = `Message compilation error: ${err.message}`;\n throw new SyntaxError(codeFrame ? `${message}\\n${codeFrame}` : message);\n }\n throw err;\n },\n onCacheKey: (source) => generateFormatCacheKey(locale, key, source)\n };\n}\nfunction getSourceForCodeFrame(source) {\n if (isString(source)) {\n return source;\n }\n else {\n if (source.loc && source.loc.source) {\n return source.loc.source;\n }\n }\n}\nfunction getMessageContextOptions(context, locale, message, options) {\n const { modifiers, pluralRules, messageResolver: resolveValue, fallbackLocale, fallbackWarn, missingWarn, fallbackContext } = context;\n const resolveMessage = (key, useLinked) => {\n let val = resolveValue(message, key);\n // fallback\n if (val == null && (fallbackContext || useLinked)) {\n const [, , message] = resolveMessageFormat(fallbackContext || context, // NOTE: if has fallbackContext, fallback to root, else if use linked, fallback to local context\n key, locale, fallbackLocale, fallbackWarn, missingWarn);\n val = resolveValue(message, key);\n }\n if (isString(val) || isMessageAST(val)) {\n let occurred = false;\n const onError = () => {\n occurred = true;\n };\n const msg = compileMessageFormat(context, key, locale, val, key, onError);\n return !occurred\n ? msg\n : NOOP_MESSAGE_FUNCTION;\n }\n else if (isMessageFunction(val)) {\n return val;\n }\n else {\n // TODO: should be implemented warning message\n return NOOP_MESSAGE_FUNCTION;\n }\n };\n const ctxOptions = {\n locale,\n modifiers,\n pluralRules,\n messages: resolveMessage\n };\n if (context.processor) {\n ctxOptions.processor = context.processor;\n }\n if (options.list) {\n ctxOptions.list = options.list;\n }\n if (options.named) {\n ctxOptions.named = options.named;\n }\n if (isNumber(options.plural)) {\n ctxOptions.pluralIndex = options.plural;\n }\n return ctxOptions;\n}\n\n{\n initFeatureFlags();\n}\n\nexport { AST_NODE_PROPS_KEYS, CORE_ERROR_CODES_EXTEND_POINT, CORE_WARN_CODES_EXTEND_POINT, CoreErrorCodes, CoreWarnCodes, DATETIME_FORMAT_OPTIONS_KEYS, DEFAULT_LOCALE, DEFAULT_MESSAGE_DATA_TYPE, MISSING_RESOLVE_VALUE, NOT_REOSLVED, NUMBER_FORMAT_OPTIONS_KEYS, VERSION, clearCompileCache, clearDateTimeFormat, clearNumberFormat, compile, createCoreContext, createCoreError, createMessageContext, datetime, fallbackWithLocaleChain, fallbackWithSimple, getAdditionalMeta, getDevToolsHook, getFallbackContext, getLocale, getWarnMessage, handleMissing, initI18nDevTools, isAlmostSameLocale, isImplicitFallback, isMessageAST, isMessageFunction, isTranslateFallbackWarn, isTranslateMissingWarn, number, parse, parseDateTimeArgs, parseNumberArgs, parseTranslateArgs, registerLocaleFallbacker, registerMessageCompiler, registerMessageResolver, resolveLocale, resolveValue, resolveWithKeyValue, setAdditionalMeta, setDevToolsHook, setFallbackContext, translate, translateDevTools, updateFallbackLocale };\n","/*!\n * vue-i18n v11.3.0\n * (c) 2026 kazuya kawaguchi\n * Released under the MIT License.\n */\nimport { CORE_ERROR_CODES_EXTEND_POINT, createCompileError, CORE_WARN_CODES_EXTEND_POINT, isMessageAST, AST_NODE_PROPS_KEYS, DEFAULT_LOCALE, updateFallbackLocale, setFallbackContext, createCoreContext, clearDateTimeFormat, clearNumberFormat, setAdditionalMeta, getFallbackContext, NOT_REOSLVED, isTranslateFallbackWarn, isTranslateMissingWarn, parseTranslateArgs, translate, MISSING_RESOLVE_VALUE, parseDateTimeArgs, datetime, parseNumberArgs, number, fallbackWithLocaleChain, isMessageFunction, NUMBER_FORMAT_OPTIONS_KEYS, DATETIME_FORMAT_OPTIONS_KEYS, registerMessageCompiler, compile, registerMessageResolver, resolveValue, registerLocaleFallbacker, setDevToolsHook } from '@intlify/core-base';\nimport { getGlobalThis, makeSymbol, format, isObject, create, isPlainObject, isArray, deepCopy, isString, hasOwn, warn, isBoolean, isRegExp, isFunction, inBrowser, assign, isNumber, createEmitter, warnOnce, isEmptyObject } from '@intlify/shared';\nimport * as Vue from 'vue';\nimport { createVNode, Text, computed, watch, ref, shallowRef, Fragment, defineComponent, h, effectScope, inject, onMounted, onUnmounted, isRef } from 'vue';\nimport { setupDevtoolsPlugin } from '@vue/devtools-api';\n\n/**\n * Vue I18n Version\n *\n * @remarks\n * Semver format. Same format as the package.json `version` field.\n *\n * @VueI18nGeneral\n */\nconst VERSION = '11.3.0';\n/**\n * This is only called in esm-bundler builds.\n * istanbul-ignore-next\n */\nfunction initFeatureFlags() {\n if (typeof __VUE_I18N_FULL_INSTALL__ !== 'boolean') {\n getGlobalThis().__VUE_I18N_FULL_INSTALL__ = true;\n }\n if (typeof __VUE_I18N_LEGACY_API__ !== 'boolean') {\n getGlobalThis().__VUE_I18N_LEGACY_API__ = true;\n }\n if (typeof __INTLIFY_DROP_MESSAGE_COMPILER__ !== 'boolean') {\n getGlobalThis().__INTLIFY_DROP_MESSAGE_COMPILER__ = false;\n }\n if (typeof __INTLIFY_PROD_DEVTOOLS__ !== 'boolean') {\n getGlobalThis().__INTLIFY_PROD_DEVTOOLS__ = false;\n }\n}\n\nconst I18nErrorCodes = {\n // composer module errors\n UNEXPECTED_RETURN_TYPE: CORE_ERROR_CODES_EXTEND_POINT, // 24\n // legacy module errors\n INVALID_ARGUMENT: 25,\n // i18n module errors\n MUST_BE_CALL_SETUP_TOP: 26,\n NOT_INSTALLED: 27,\n // directive module errors\n REQUIRED_VALUE: 28,\n INVALID_VALUE: 29,\n // vue-devtools errors\n CANNOT_SETUP_VUE_DEVTOOLS_PLUGIN: 30,\n NOT_INSTALLED_WITH_PROVIDE: 31,\n // unexpected error\n UNEXPECTED_ERROR: 32,\n // not compatible legacy vue-i18n constructor\n NOT_COMPATIBLE_LEGACY_VUE_I18N: 33,\n // Not available Compostion API in Legacy API mode. Please make sure that the legacy API mode is working properly\n NOT_AVAILABLE_COMPOSITION_IN_LEGACY: 34\n};\nfunction createI18nError(code, ...args) {\n return createCompileError(code, null, (process.env.NODE_ENV !== 'production') ? { messages: errorMessages, args } : undefined);\n}\nconst errorMessages = {\n [I18nErrorCodes.UNEXPECTED_RETURN_TYPE]: 'Unexpected return type in composer',\n [I18nErrorCodes.INVALID_ARGUMENT]: 'Invalid argument',\n [I18nErrorCodes.MUST_BE_CALL_SETUP_TOP]: 'Must be called at the top of a `setup` function',\n [I18nErrorCodes.NOT_INSTALLED]: 'Need to install with `app.use` function',\n [I18nErrorCodes.UNEXPECTED_ERROR]: 'Unexpected error',\n [I18nErrorCodes.REQUIRED_VALUE]: `Required in value: {0}`,\n [I18nErrorCodes.INVALID_VALUE]: `Invalid value`,\n [I18nErrorCodes.CANNOT_SETUP_VUE_DEVTOOLS_PLUGIN]: `Cannot setup vue-devtools plugin`,\n [I18nErrorCodes.NOT_INSTALLED_WITH_PROVIDE]: 'Need to install with `provide` function',\n [I18nErrorCodes.NOT_COMPATIBLE_LEGACY_VUE_I18N]: 'Not compatible legacy VueI18n.',\n [I18nErrorCodes.NOT_AVAILABLE_COMPOSITION_IN_LEGACY]: 'Not available Compostion API in Legacy API mode. Please make sure that the legacy API mode is working properly'\n};\n\nconst TranslateVNodeSymbol = \n/* #__PURE__*/ makeSymbol('__translateVNode');\nconst DatetimePartsSymbol = /* #__PURE__*/ makeSymbol('__datetimeParts');\nconst NumberPartsSymbol = /* #__PURE__*/ makeSymbol('__numberParts');\nconst EnableEmitter = /* #__PURE__*/ makeSymbol('__enableEmitter');\nconst DisableEmitter = /* #__PURE__*/ makeSymbol('__disableEmitter');\nconst SetPluralRulesSymbol = makeSymbol('__setPluralRules');\nmakeSymbol('__intlifyMeta');\nconst InejctWithOptionSymbol = \n/* #__PURE__*/ makeSymbol('__injectWithOption');\nconst DisposeSymbol = /* #__PURE__*/ makeSymbol('__dispose');\n\nconst I18nWarnCodes = {\n FALLBACK_TO_ROOT: CORE_WARN_CODES_EXTEND_POINT, // 10\n NOT_FOUND_PARENT_SCOPE: (CORE_WARN_CODES_EXTEND_POINT + 1),\n IGNORE_OBJ_FLATTEN: (CORE_WARN_CODES_EXTEND_POINT + 2),\n /**\n * @deprecated will be removed at vue-i18n v12\n */\n DEPRECATE_LEGACY_MODE: (CORE_WARN_CODES_EXTEND_POINT + 3),\n /**\n * @deprecated will be removed at vue-i18n v12\n */\n DEPRECATE_TRANSLATE_CUSTOME_DIRECTIVE: (CORE_WARN_CODES_EXTEND_POINT +\n 4),\n // duplicate `useI18n` calling\n DUPLICATE_USE_I18N_CALLING: (CORE_WARN_CODES_EXTEND_POINT + 5)\n};\nconst warnMessages = {\n [I18nWarnCodes.FALLBACK_TO_ROOT]: `Fall back to {type} '{key}' with root locale.`,\n [I18nWarnCodes.NOT_FOUND_PARENT_SCOPE]: `Not found parent scope. use the global scope.`,\n [I18nWarnCodes.IGNORE_OBJ_FLATTEN]: `Ignore object flatten: '{key}' key has an string value`,\n /**\n * @deprecated will be removed at vue-i18n v12\n */\n [I18nWarnCodes.DEPRECATE_LEGACY_MODE]: `Legacy API mode has been deprecated in v11. Use Composition API mode instead.\\nAbout how to use the Composition API mode, see https://vue-i18n.intlify.dev/guide/advanced/composition.html`,\n /**\n * @deprecated will be removed at vue-i18n v12\n */\n [I18nWarnCodes.DEPRECATE_TRANSLATE_CUSTOME_DIRECTIVE]: `'v-t' has been deprecated in v11. Use translate APIs ('t' or '$t') instead.`,\n [I18nWarnCodes.DUPLICATE_USE_I18N_CALLING]: \"Duplicate `useI18n` calling by local scope. Please don't call it on local scope, due to it does not work properly in component.\"\n};\nfunction getWarnMessage(code, ...args) {\n return format(warnMessages[code], ...args);\n}\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n/**\n * Transform flat json in obj to normal json in obj\n */\nfunction handleFlatJson(obj) {\n // check obj\n if (!isObject(obj)) {\n return obj;\n }\n if (isMessageAST(obj)) {\n return obj;\n }\n for (const key in obj) {\n // check key\n if (!hasOwn(obj, key)) {\n continue;\n }\n // handle for normal json\n if (!key.includes('.')) {\n // recursive process value if value is also a object\n if (isObject(obj[key])) {\n handleFlatJson(obj[key]);\n }\n }\n // handle for flat json, transform to normal json\n else {\n // go to the last object\n const subKeys = key.split('.');\n const lastIndex = subKeys.length - 1;\n let currentObj = obj;\n let hasStringValue = false;\n for (let i = 0; i < lastIndex; i++) {\n if (subKeys[i] === '__proto__') {\n throw new Error(`unsafe key: ${subKeys[i]}`);\n }\n if (!(subKeys[i] in currentObj)) {\n currentObj[subKeys[i]] = create();\n }\n if (!isObject(currentObj[subKeys[i]])) {\n (process.env.NODE_ENV !== 'production') &&\n warn(getWarnMessage(I18nWarnCodes.IGNORE_OBJ_FLATTEN, {\n key: subKeys[i]\n }));\n hasStringValue = true;\n break;\n }\n currentObj = currentObj[subKeys[i]];\n }\n // update last object value, delete old property\n if (!hasStringValue) {\n if (!isMessageAST(currentObj)) {\n currentObj[subKeys[lastIndex]] = obj[key];\n delete obj[key];\n }\n else {\n /**\n * NOTE:\n * if the last object is a message AST and subKeys[lastIndex] has message AST prop key, ignore to copy and key deletion\n */\n if (!AST_NODE_PROPS_KEYS.includes(subKeys[lastIndex])) {\n delete obj[key];\n }\n }\n }\n // recursive process value if value is also a object\n if (!isMessageAST(currentObj)) {\n const target = currentObj[subKeys[lastIndex]];\n if (isObject(target)) {\n handleFlatJson(target);\n }\n }\n }\n }\n return obj;\n}\nfunction getLocaleMessages(locale, options) {\n const { messages, __i18n, messageResolver, flatJson } = options;\n // prettier-ignore\n const ret = (isPlainObject(messages)\n ? messages\n : isArray(__i18n)\n ? create()\n : { [locale]: create() });\n // merge locale messages of i18n custom block\n if (isArray(__i18n)) {\n __i18n.forEach(custom => {\n if ('locale' in custom && 'resource' in custom) {\n const { locale, resource } = custom;\n if (locale) {\n ret[locale] = ret[locale] || create();\n deepCopy(resource, ret[locale]);\n }\n else {\n deepCopy(resource, ret);\n }\n }\n else {\n isString(custom) && deepCopy(JSON.parse(custom), ret);\n }\n });\n }\n // handle messages for flat json\n if (messageResolver == null && flatJson) {\n for (const key in ret) {\n if (hasOwn(ret, key)) {\n handleFlatJson(ret[key]);\n }\n }\n }\n return ret;\n}\nfunction getComponentOptions(instance) {\n return instance.type;\n}\nfunction adjustI18nResources(gl, options, componentOptions) {\n // prettier-ignore\n let messages = isObject(options.messages)\n ? options.messages\n : create();\n if ('__i18nGlobal' in componentOptions) {\n messages = getLocaleMessages(gl.locale.value, {\n messages,\n __i18n: componentOptions.__i18nGlobal\n });\n }\n // merge locale messages\n const locales = Object.keys(messages);\n if (locales.length) {\n locales.forEach(locale => {\n gl.mergeLocaleMessage(locale, messages[locale]);\n });\n }\n {\n // merge datetime formats\n if (isObject(options.datetimeFormats)) {\n const locales = Object.keys(options.datetimeFormats);\n if (locales.length) {\n locales.forEach(locale => {\n gl.mergeDateTimeFormat(locale, options.datetimeFormats[locale]);\n });\n }\n }\n // merge number formats\n if (isObject(options.numberFormats)) {\n const locales = Object.keys(options.numberFormats);\n if (locales.length) {\n locales.forEach(locale => {\n gl.mergeNumberFormat(locale, options.numberFormats[locale]);\n });\n }\n }\n }\n}\nfunction createTextNode(key) {\n return createVNode(Text, null, key, 0);\n}\nfunction getCurrentInstance() {\n // NOTE(kazupon): avoid bundler warning\n const key = 'currentInstance';\n if (key in Vue) {\n return Vue[key];\n }\n else {\n return Vue.getCurrentInstance();\n }\n}\n/* eslint-enable @typescript-eslint/no-explicit-any */\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n// extend VNode interface\nconst DEVTOOLS_META = '__INTLIFY_META__';\nconst NOOP_RETURN_ARRAY = () => [];\nconst NOOP_RETURN_FALSE = () => false;\nlet composerID = 0;\nfunction defineCoreMissingHandler(missing) {\n return ((ctx, locale, key, type) => {\n return missing(locale, key, getCurrentInstance() || undefined, type);\n });\n}\n// for Intlify DevTools\n/* #__NO_SIDE_EFFECTS__ */\nconst getMetaInfo = () => {\n const instance = getCurrentInstance();\n let meta = null;\n return instance && (meta = getComponentOptions(instance)[DEVTOOLS_META])\n ? { [DEVTOOLS_META]: meta }\n : null;\n};\n/**\n * Create composer interface factory\n *\n * @internal\n */\nfunction createComposer(options = {}) {\n const { __root, __injectWithOption } = options;\n const _isGlobal = __root === undefined;\n const flatJson = options.flatJson;\n const _ref = inBrowser ? ref : shallowRef;\n let _inheritLocale = isBoolean(options.inheritLocale)\n ? options.inheritLocale\n : true;\n const _locale = _ref(\n // prettier-ignore\n __root && _inheritLocale\n ? __root.locale.value\n : isString(options.locale)\n ? options.locale\n : DEFAULT_LOCALE);\n const _fallbackLocale = _ref(\n // prettier-ignore\n __root && _inheritLocale\n ? __root.fallbackLocale.value\n : isString(options.fallbackLocale) ||\n isArray(options.fallbackLocale) ||\n isPlainObject(options.fallbackLocale) ||\n options.fallbackLocale === false\n ? options.fallbackLocale\n : _locale.value);\n const _messages = _ref(getLocaleMessages(_locale.value, options));\n // prettier-ignore\n const _datetimeFormats = _ref(isPlainObject(options.datetimeFormats)\n ? options.datetimeFormats\n : { [_locale.value]: {} })\n ;\n // prettier-ignore\n const _numberFormats = _ref(isPlainObject(options.numberFormats)\n ? options.numberFormats\n : { [_locale.value]: {} })\n ;\n // warning suppress options\n // prettier-ignore\n let _missingWarn = __root\n ? __root.missingWarn\n : isBoolean(options.missingWarn) || isRegExp(options.missingWarn)\n ? options.missingWarn\n : true;\n // prettier-ignore\n let _fallbackWarn = __root\n ? __root.fallbackWarn\n : isBoolean(options.fallbackWarn) || isRegExp(options.fallbackWarn)\n ? options.fallbackWarn\n : true;\n // prettier-ignore\n let _fallbackRoot = __root\n ? __root.fallbackRoot\n : isBoolean(options.fallbackRoot)\n ? options.fallbackRoot\n : true;\n // configure fall back to root\n let _fallbackFormat = !!options.fallbackFormat;\n // runtime missing\n let _missing = isFunction(options.missing) ? options.missing : null;\n let _runtimeMissing = isFunction(options.missing)\n ? defineCoreMissingHandler(options.missing)\n : null;\n // postTranslation handler\n let _postTranslation = isFunction(options.postTranslation)\n ? options.postTranslation\n : null;\n // prettier-ignore\n let _warnHtmlMessage = __root\n ? __root.warnHtmlMessage\n : isBoolean(options.warnHtmlMessage)\n ? options.warnHtmlMessage\n : true;\n let _escapeParameter = !!options.escapeParameter;\n // custom linked modifiers\n // prettier-ignore\n const _modifiers = __root\n ? __root.modifiers\n : isPlainObject(options.modifiers)\n ? options.modifiers\n : {};\n // pluralRules\n let _pluralRules = options.pluralRules || (__root && __root.pluralRules);\n // runtime context\n // eslint-disable-next-line prefer-const\n let _context;\n const getCoreContext = () => {\n _isGlobal && setFallbackContext(null);\n const ctxOptions = {\n version: VERSION,\n locale: _locale.value,\n fallbackLocale: _fallbackLocale.value,\n messages: _messages.value,\n modifiers: _modifiers,\n pluralRules: _pluralRules,\n missing: _runtimeMissing === null ? undefined : _runtimeMissing,\n missingWarn: _missingWarn,\n fallbackWarn: _fallbackWarn,\n fallbackFormat: _fallbackFormat,\n unresolving: true,\n postTranslation: _postTranslation === null ? undefined : _postTranslation,\n warnHtmlMessage: _warnHtmlMessage,\n escapeParameter: _escapeParameter,\n messageResolver: options.messageResolver,\n messageCompiler: options.messageCompiler,\n __meta: { framework: 'vue' }\n };\n {\n ctxOptions.datetimeFormats = _datetimeFormats.value;\n ctxOptions.numberFormats = _numberFormats.value;\n ctxOptions.__datetimeFormatters = isPlainObject(_context)\n ? _context.__datetimeFormatters\n : undefined;\n ctxOptions.__numberFormatters = isPlainObject(_context)\n ? _context.__numberFormatters\n : undefined;\n }\n if ((process.env.NODE_ENV !== 'production')) {\n ctxOptions.__v_emitter = isPlainObject(_context)\n ? _context.__v_emitter\n : undefined;\n }\n const ctx = createCoreContext(ctxOptions);\n _isGlobal && setFallbackContext(ctx);\n return ctx;\n };\n _context = getCoreContext();\n updateFallbackLocale(_context, _locale.value, _fallbackLocale.value);\n // track reactivity\n function trackReactivityValues() {\n return [\n _locale.value,\n _fallbackLocale.value,\n _messages.value,\n _datetimeFormats.value,\n _numberFormats.value\n ]\n ;\n }\n // locale\n const locale = computed({\n get: () => _locale.value,\n set: val => {\n _context.locale = val;\n _locale.value = val;\n }\n });\n // fallbackLocale\n const fallbackLocale = computed({\n get: () => _fallbackLocale.value,\n set: val => {\n _context.fallbackLocale = val;\n _fallbackLocale.value = val;\n updateFallbackLocale(_context, _locale.value, val);\n }\n });\n // messages\n const messages = computed(() => _messages.value);\n // datetimeFormats\n const datetimeFormats = /* #__PURE__*/ computed(() => _datetimeFormats.value);\n // numberFormats\n const numberFormats = /* #__PURE__*/ computed(() => _numberFormats.value);\n // getPostTranslationHandler\n function getPostTranslationHandler() {\n return isFunction(_postTranslation) ? _postTranslation : null;\n }\n // setPostTranslationHandler\n function setPostTranslationHandler(handler) {\n _postTranslation = handler;\n _context.postTranslation = handler;\n }\n // getMissingHandler\n function getMissingHandler() {\n return _missing;\n }\n // setMissingHandler\n function setMissingHandler(handler) {\n if (handler !== null) {\n _runtimeMissing = defineCoreMissingHandler(handler);\n }\n _missing = handler;\n _context.missing = _runtimeMissing;\n }\n function isResolvedTranslateMessage(type, arg) {\n return type !== 'translate' || !arg.resolvedMessage;\n }\n const wrapWithDeps = (fn, argumentParser, warnType, fallbackSuccess, fallbackFail, successCondition) => {\n trackReactivityValues(); // track reactive dependency\n // NOTE: experimental !!\n let ret;\n try {\n if ((process.env.NODE_ENV !== 'production') || __INTLIFY_PROD_DEVTOOLS__) {\n setAdditionalMeta(getMetaInfo());\n }\n if (!_isGlobal) {\n _context.fallbackContext = __root\n ? getFallbackContext()\n : undefined;\n }\n ret = fn(_context);\n }\n finally {\n if ((process.env.NODE_ENV !== 'production') || __INTLIFY_PROD_DEVTOOLS__) {\n setAdditionalMeta(null);\n }\n if (!_isGlobal) {\n _context.fallbackContext = undefined;\n }\n }\n if ((warnType !== 'translate exists' && // for not `te` (e.g `t`)\n isNumber(ret) &&\n ret === NOT_REOSLVED) ||\n (warnType === 'translate exists' && !ret) // for `te`\n ) {\n const [key, arg2] = argumentParser();\n if ((process.env.NODE_ENV !== 'production') &&\n __root &&\n isString(key) &&\n isResolvedTranslateMessage(warnType, arg2)) {\n if (_fallbackRoot &&\n (isTranslateFallbackWarn(_fallbackWarn, key) ||\n isTranslateMissingWarn(_missingWarn, key))) {\n warn(getWarnMessage(I18nWarnCodes.FALLBACK_TO_ROOT, {\n key,\n type: warnType\n }));\n }\n // for vue-devtools timeline event\n if ((process.env.NODE_ENV !== 'production')) {\n const { __v_emitter: emitter } = _context;\n if (emitter && _fallbackRoot) {\n emitter.emit('fallback', {\n type: warnType,\n key,\n to: 'global',\n groupId: `${warnType}:${key}`\n });\n }\n }\n }\n return __root && _fallbackRoot\n ? fallbackSuccess(__root)\n : fallbackFail(key);\n }\n else if (successCondition(ret)) {\n return ret;\n }\n else {\n /* istanbul ignore next */\n throw createI18nError(I18nErrorCodes.UNEXPECTED_RETURN_TYPE);\n }\n };\n // t\n function t(...args) {\n return wrapWithDeps(context => Reflect.apply(translate, null, [context, ...args]), () => parseTranslateArgs(...args), 'translate', root => Reflect.apply(root.t, root, [...args]), key => key, val => isString(val));\n }\n // rt\n function rt(...args) {\n const [arg1, arg2, arg3] = args;\n if (arg3 && !isObject(arg3)) {\n throw createI18nError(I18nErrorCodes.INVALID_ARGUMENT);\n }\n return t(...[arg1, arg2, assign({ resolvedMessage: true }, arg3 || {})]);\n }\n // d\n function d(...args) {\n return wrapWithDeps(context => Reflect.apply(datetime, null, [context, ...args]), () => parseDateTimeArgs(...args), 'datetime format', root => Reflect.apply(root.d, root, [...args]), () => MISSING_RESOLVE_VALUE, val => isString(val) || isArray(val));\n }\n // n\n function n(...args) {\n return wrapWithDeps(context => Reflect.apply(number, null, [context, ...args]), () => parseNumberArgs(...args), 'number format', root => Reflect.apply(root.n, root, [...args]), () => MISSING_RESOLVE_VALUE, val => isString(val) || isArray(val));\n }\n // for custom processor\n function normalize(values) {\n return values.map(val => isString(val) || isNumber(val) || isBoolean(val)\n ? createTextNode(String(val))\n : val);\n }\n const interpolate = (val) => val;\n const processor = {\n normalize,\n interpolate,\n type: 'vnode'\n };\n // translateVNode, using for `i18n-t` component\n function translateVNode(...args) {\n return wrapWithDeps(context => {\n let ret;\n const _context = context;\n try {\n _context.processor = processor;\n ret = Reflect.apply(translate, null, [_context, ...args]);\n }\n finally {\n _context.processor = null;\n }\n return ret;\n }, () => parseTranslateArgs(...args), 'translate', root => root[TranslateVNodeSymbol](...args), key => [createTextNode(key)], val => isArray(val));\n }\n // numberParts, using for `i18n-n` component\n function numberParts(...args) {\n return wrapWithDeps(context => Reflect.apply(number, null, [context, ...args]), () => parseNumberArgs(...args), 'number format', root => root[NumberPartsSymbol](...args), NOOP_RETURN_ARRAY, val => isString(val) || isArray(val));\n }\n // datetimeParts, using for `i18n-d` component\n function datetimeParts(...args) {\n return wrapWithDeps(context => Reflect.apply(datetime, null, [context, ...args]), () => parseDateTimeArgs(...args), 'datetime format', root => root[DatetimePartsSymbol](...args), NOOP_RETURN_ARRAY, val => isString(val) || isArray(val));\n }\n function setPluralRules(rules) {\n _pluralRules = rules;\n _context.pluralRules = _pluralRules;\n }\n // te\n function te(key, locale) {\n return wrapWithDeps(() => {\n if (!key) {\n return false;\n }\n const targetLocale = isString(locale) ? locale : _locale.value;\n // When locale is explicitly specified, check only that locale (no fallback chain)\n // When locale is not specified, check the fallback locale chain\n const locales = isString(locale)\n ? [targetLocale]\n : fallbackWithLocaleChain(_context, _fallbackLocale.value, targetLocale);\n for (let i = 0; i < locales.length; i++) {\n const message = getLocaleMessage(locales[i]);\n let resolved = _context.messageResolver(message, key);\n // if null, resolve with object key path (for flat keys containing dots)\n if (resolved === null) {\n resolved = message[key];\n }\n if (isMessageAST(resolved) ||\n isMessageFunction(resolved) ||\n isString(resolved)) {\n return true;\n }\n }\n return false;\n }, () => [key], 'translate exists', root => {\n return Reflect.apply(root.te, root, [key, locale]);\n }, NOOP_RETURN_FALSE, val => isBoolean(val));\n }\n function resolveMessages(key) {\n let messages = null;\n const locales = fallbackWithLocaleChain(_context, _fallbackLocale.value, _locale.value);\n for (let i = 0; i < locales.length; i++) {\n const targetLocaleMessages = _messages.value[locales[i]] || {};\n const messageValue = _context.messageResolver(targetLocaleMessages, key);\n if (messageValue != null) {\n messages = messageValue;\n break;\n }\n }\n return messages;\n }\n // tm\n function tm(key) {\n const messages = resolveMessages(key);\n // prettier-ignore\n return messages != null\n ? messages\n : __root\n ? __root.tm(key) || {}\n : {};\n }\n // getLocaleMessage\n function getLocaleMessage(locale) {\n return (_messages.value[locale] || {});\n }\n // setLocaleMessage\n function setLocaleMessage(locale, message) {\n if (flatJson) {\n const _message = { [locale]: message };\n for (const key in _message) {\n if (hasOwn(_message, key)) {\n handleFlatJson(_message[key]);\n }\n }\n message = _message[locale];\n }\n _messages.value[locale] = message;\n _context.messages = _messages.value;\n }\n // mergeLocaleMessage\n function mergeLocaleMessage(locale, message) {\n _messages.value[locale] = _messages.value[locale] || {};\n const _message = { [locale]: message };\n if (flatJson) {\n for (const key in _message) {\n if (hasOwn(_message, key)) {\n handleFlatJson(_message[key]);\n }\n }\n }\n message = _message[locale];\n deepCopy(message, _messages.value[locale]);\n _context.messages = _messages.value;\n }\n // getDateTimeFormat\n function getDateTimeFormat(locale) {\n return _datetimeFormats.value[locale] || {};\n }\n // setDateTimeFormat\n function setDateTimeFormat(locale, format) {\n _datetimeFormats.value[locale] = format;\n _context.datetimeFormats = _datetimeFormats.value;\n clearDateTimeFormat(_context, locale, format);\n }\n // mergeDateTimeFormat\n function mergeDateTimeFormat(locale, format) {\n _datetimeFormats.value[locale] = assign(_datetimeFormats.value[locale] || {}, format);\n _context.datetimeFormats = _datetimeFormats.value;\n clearDateTimeFormat(_context, locale, format);\n }\n // getNumberFormat\n function getNumberFormat(locale) {\n return _numberFormats.value[locale] || {};\n }\n // setNumberFormat\n function setNumberFormat(locale, format) {\n _numberFormats.value[locale] = format;\n _context.numberFormats = _numberFormats.value;\n clearNumberFormat(_context, locale, format);\n }\n // mergeNumberFormat\n function mergeNumberFormat(locale, format) {\n _numberFormats.value[locale] = assign(_numberFormats.value[locale] || {}, format);\n _context.numberFormats = _numberFormats.value;\n clearNumberFormat(_context, locale, format);\n }\n // for debug\n composerID++;\n // watch root locale & fallbackLocale\n if (__root && inBrowser) {\n watch(__root.locale, (val) => {\n if (_inheritLocale) {\n _locale.value = val;\n _context.locale = val;\n updateFallbackLocale(_context, _locale.value, _fallbackLocale.value);\n }\n });\n watch(__root.fallbackLocale, (val) => {\n if (_inheritLocale) {\n _fallbackLocale.value = val;\n _context.fallbackLocale = val;\n updateFallbackLocale(_context, _locale.value, _fallbackLocale.value);\n }\n });\n }\n // define basic composition API!\n const composer = {\n id: composerID,\n locale,\n fallbackLocale,\n get inheritLocale() {\n return _inheritLocale;\n },\n set inheritLocale(val) {\n _inheritLocale = val;\n if (val && __root) {\n _locale.value = __root.locale.value;\n _fallbackLocale.value = __root.fallbackLocale.value;\n updateFallbackLocale(_context, _locale.value, _fallbackLocale.value);\n }\n },\n get availableLocales() {\n return Object.keys(_messages.value).sort();\n },\n messages,\n get modifiers() {\n return _modifiers;\n },\n get pluralRules() {\n return _pluralRules || {};\n },\n get isGlobal() {\n return _isGlobal;\n },\n get missingWarn() {\n return _missingWarn;\n },\n set missingWarn(val) {\n _missingWarn = val;\n _context.missingWarn = _missingWarn;\n },\n get fallbackWarn() {\n return _fallbackWarn;\n },\n set fallbackWarn(val) {\n _fallbackWarn = val;\n _context.fallbackWarn = _fallbackWarn;\n },\n get fallbackRoot() {\n return _fallbackRoot;\n },\n set fallbackRoot(val) {\n _fallbackRoot = val;\n },\n get fallbackFormat() {\n return _fallbackFormat;\n },\n set fallbackFormat(val) {\n _fallbackFormat = val;\n _context.fallbackFormat = _fallbackFormat;\n },\n get warnHtmlMessage() {\n return _warnHtmlMessage;\n },\n set warnHtmlMessage(val) {\n _warnHtmlMessage = val;\n _context.warnHtmlMessage = val;\n },\n get escapeParameter() {\n return _escapeParameter;\n },\n set escapeParameter(val) {\n _escapeParameter = val;\n _context.escapeParameter = val;\n },\n t,\n getLocaleMessage,\n setLocaleMessage,\n mergeLocaleMessage,\n getPostTranslationHandler,\n setPostTranslationHandler,\n getMissingHandler,\n setMissingHandler,\n [SetPluralRulesSymbol]: setPluralRules\n };\n {\n composer.datetimeFormats = datetimeFormats;\n composer.numberFormats = numberFormats;\n composer.rt = rt;\n composer.te = te;\n composer.tm = tm;\n composer.d = d;\n composer.n = n;\n composer.getDateTimeFormat = getDateTimeFormat;\n composer.setDateTimeFormat = setDateTimeFormat;\n composer.mergeDateTimeFormat = mergeDateTimeFormat;\n composer.getNumberFormat = getNumberFormat;\n composer.setNumberFormat = setNumberFormat;\n composer.mergeNumberFormat = mergeNumberFormat;\n composer[InejctWithOptionSymbol] = __injectWithOption;\n composer[TranslateVNodeSymbol] = translateVNode;\n composer[DatetimePartsSymbol] = datetimeParts;\n composer[NumberPartsSymbol] = numberParts;\n }\n // for vue-devtools timeline event\n if ((process.env.NODE_ENV !== 'production')) {\n composer[EnableEmitter] = (emitter) => {\n _context.__v_emitter = emitter;\n };\n composer[DisableEmitter] = () => {\n _context.__v_emitter = undefined;\n };\n }\n return composer;\n}\n/* eslint-enable @typescript-eslint/no-explicit-any */\n\nconst VUE_I18N_COMPONENT_TYPES = 'vue-i18n: composer properties';\nconst VueDevToolsLabels = {\n 'vue-devtools-plugin-vue-i18n': 'Vue I18n DevTools',\n 'vue-i18n-resource-inspector': 'Vue I18n DevTools',\n 'vue-i18n-timeline': 'Vue I18n'\n};\nconst VueDevToolsPlaceholders = {\n 'vue-i18n-resource-inspector': 'Search for scopes ...'\n};\nconst VueDevToolsTimelineColors = {\n 'vue-i18n-timeline': 0xffcd19\n};\nlet devtoolsApi;\nasync function enableDevTools(app, i18n) {\n return new Promise((resolve, reject) => {\n try {\n setupDevtoolsPlugin({\n id: 'vue-devtools-plugin-vue-i18n',\n label: VueDevToolsLabels['vue-devtools-plugin-vue-i18n'],\n packageName: 'vue-i18n',\n homepage: 'https://vue-i18n.intlify.dev',\n logo: 'https://vue-i18n.intlify.dev/vue-i18n-devtools-logo.png',\n componentStateTypes: [VUE_I18N_COMPONENT_TYPES],\n app: app // eslint-disable-line @typescript-eslint/no-explicit-any\n }, api => {\n devtoolsApi = api;\n api.on.visitComponentTree(({ componentInstance, treeNode }) => {\n updateComponentTreeTags(componentInstance, treeNode, i18n);\n });\n api.on.inspectComponent(({ componentInstance, instanceData }) => {\n if (componentInstance.__VUE_I18N__ && instanceData) {\n if (i18n.mode === 'legacy') {\n // ignore global scope on legacy mode\n if (componentInstance.__VUE_I18N__ !==\n i18n.global.__composer) {\n inspectComposer(instanceData, componentInstance.__VUE_I18N__);\n }\n }\n else {\n inspectComposer(instanceData, componentInstance.__VUE_I18N__);\n }\n }\n });\n api.addInspector({\n id: 'vue-i18n-resource-inspector',\n label: VueDevToolsLabels['vue-i18n-resource-inspector'],\n icon: 'language',\n treeFilterPlaceholder: VueDevToolsPlaceholders['vue-i18n-resource-inspector']\n });\n api.on.getInspectorTree(payload => {\n if (payload.app === app &&\n payload.inspectorId === 'vue-i18n-resource-inspector') {\n registerScope(payload, i18n);\n }\n });\n const roots = new Map();\n api.on.getInspectorState(async (payload) => {\n if (payload.app === app &&\n payload.inspectorId === 'vue-i18n-resource-inspector') {\n api.unhighlightElement();\n inspectScope(payload, i18n);\n if (payload.nodeId === 'global') {\n if (!roots.has(payload.app)) {\n const [root] = await api.getComponentInstances(payload.app);\n roots.set(payload.app, root);\n }\n api.highlightElement(roots.get(payload.app));\n }\n else {\n const instance = getComponentInstance(payload.nodeId, i18n);\n instance && api.highlightElement(instance);\n }\n }\n });\n api.on.editInspectorState(payload => {\n if (payload.app === app &&\n payload.inspectorId === 'vue-i18n-resource-inspector') {\n editScope(payload, i18n);\n }\n });\n api.addTimelineLayer({\n id: 'vue-i18n-timeline',\n label: VueDevToolsLabels['vue-i18n-timeline'],\n color: VueDevToolsTimelineColors['vue-i18n-timeline']\n });\n resolve(true);\n });\n }\n catch (e) {\n console.error(e);\n // eslint-disable-next-line @typescript-eslint/prefer-promise-reject-errors\n reject(false);\n }\n });\n}\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction getI18nScopeLable(instance) {\n return (instance.type.name ||\n instance.type.displayName ||\n instance.type.__file ||\n 'Anonymous');\n}\nfunction updateComponentTreeTags(instance, // eslint-disable-line @typescript-eslint/no-explicit-any\ntreeNode, i18n) {\n // prettier-ignore\n const global = i18n.mode === 'composition'\n ? i18n.global\n : i18n.global.__composer;\n if (instance && instance.__VUE_I18N__) {\n // add custom tags local scope only\n if (instance.__VUE_I18N__ !== global) {\n const tag = {\n label: `i18n (${getI18nScopeLable(instance)} Scope)`,\n textColor: 0x000000,\n backgroundColor: 0xffcd19\n };\n treeNode.tags.push(tag);\n }\n }\n}\nfunction inspectComposer(instanceData, composer) {\n const type = VUE_I18N_COMPONENT_TYPES;\n instanceData.state.push({\n type,\n key: 'locale',\n editable: true,\n value: composer.locale.value\n });\n instanceData.state.push({\n type,\n key: 'availableLocales',\n editable: false,\n value: composer.availableLocales\n });\n instanceData.state.push({\n type,\n key: 'fallbackLocale',\n editable: true,\n value: composer.fallbackLocale.value\n });\n instanceData.state.push({\n type,\n key: 'inheritLocale',\n editable: true,\n value: composer.inheritLocale\n });\n instanceData.state.push({\n type,\n key: 'messages',\n editable: false,\n value: getLocaleMessageValue(composer.messages.value)\n });\n {\n instanceData.state.push({\n type,\n key: 'datetimeFormats',\n editable: false,\n value: composer.datetimeFormats.value\n });\n instanceData.state.push({\n type,\n key: 'numberFormats',\n editable: false,\n value: composer.numberFormats.value\n });\n }\n}\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction getLocaleMessageValue(messages) {\n const value = {};\n Object.keys(messages).forEach((key) => {\n const v = messages[key];\n if (isFunction(v) && 'source' in v) {\n value[key] = getMessageFunctionDetails(v);\n }\n else if (isMessageAST(v) && v.loc && v.loc.source) {\n value[key] = v.loc.source;\n }\n else if (isObject(v)) {\n value[key] = getLocaleMessageValue(v);\n }\n else {\n value[key] = v;\n }\n });\n return value;\n}\nconst ESC = {\n '<': '&lt;',\n '>': '&gt;',\n '\"': '&quot;',\n '&': '&amp;'\n};\nfunction escape(s) {\n return s.replace(/[<>\"&]/g, escapeChar);\n}\nfunction escapeChar(a) {\n return ESC[a] || a;\n}\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction getMessageFunctionDetails(func) {\n const argString = func.source ? `(\"${escape(func.source)}\")` : `(?)`;\n return {\n _custom: {\n type: 'function',\n display: `<span>ƒ</span> ${argString}`\n }\n };\n}\nfunction registerScope(payload, i18n) {\n payload.rootNodes.push({\n id: 'global',\n label: 'Global Scope'\n });\n // prettier-ignore\n const global = i18n.mode === 'composition'\n ? i18n.global\n : i18n.global.__composer;\n for (const [keyInstance, instance] of i18n.__instances) {\n // prettier-ignore\n const composer = i18n.mode === 'composition'\n ? instance\n : instance.__composer;\n if (global === composer) {\n continue;\n }\n payload.rootNodes.push({\n id: composer.id.toString(),\n label: `${getI18nScopeLable(keyInstance)} Scope`\n });\n }\n}\nfunction getComponentInstance(nodeId, i18n) {\n let instance = null;\n if (nodeId !== 'global') {\n for (const [component, composer] of i18n.__instances.entries()) {\n if (composer.id.toString() === nodeId) {\n instance = component;\n break;\n }\n }\n }\n return instance;\n}\nfunction getComposer$2(nodeId, i18n) {\n if (nodeId === 'global') {\n return i18n.mode === 'composition'\n ? i18n.global\n : i18n.global.__composer;\n }\n else {\n const instance = Array.from(i18n.__instances.values()).find(item => item.id.toString() === nodeId);\n if (instance) {\n return i18n.mode === 'composition'\n ? instance\n : instance.__composer;\n }\n else {\n return null;\n }\n }\n}\nfunction inspectScope(payload, i18n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\n) {\n const composer = getComposer$2(payload.nodeId, i18n);\n if (composer) {\n // TODO:\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n payload.state = makeScopeInspectState(composer);\n }\n return null;\n}\nfunction makeScopeInspectState(composer) {\n const state = {};\n const localeType = 'Locale related info';\n const localeStates = [\n {\n type: localeType,\n key: 'locale',\n editable: true,\n value: composer.locale.value\n },\n {\n type: localeType,\n key: 'fallbackLocale',\n editable: true,\n value: composer.fallbackLocale.value\n },\n {\n type: localeType,\n key: 'availableLocales',\n editable: false,\n value: composer.availableLocales\n },\n {\n type: localeType,\n key: 'inheritLocale',\n editable: true,\n value: composer.inheritLocale\n }\n ];\n state[localeType] = localeStates;\n const localeMessagesType = 'Locale messages info';\n const localeMessagesStates = [\n {\n type: localeMessagesType,\n key: 'messages',\n editable: false,\n value: getLocaleMessageValue(composer.messages.value)\n }\n ];\n state[localeMessagesType] = localeMessagesStates;\n {\n const datetimeFormatsType = 'Datetime formats info';\n const datetimeFormatsStates = [\n {\n type: datetimeFormatsType,\n key: 'datetimeFormats',\n editable: false,\n value: composer.datetimeFormats.value\n }\n ];\n state[datetimeFormatsType] = datetimeFormatsStates;\n const numberFormatsType = 'Datetime formats info';\n const numberFormatsStates = [\n {\n type: numberFormatsType,\n key: 'numberFormats',\n editable: false,\n value: composer.numberFormats.value\n }\n ];\n state[numberFormatsType] = numberFormatsStates;\n }\n return state;\n}\nfunction addTimelineEvent(event, payload) {\n if (devtoolsApi) {\n let groupId;\n if (payload && 'groupId' in payload) {\n groupId = payload.groupId;\n delete payload.groupId;\n }\n devtoolsApi.addTimelineEvent({\n layerId: 'vue-i18n-timeline',\n event: {\n title: event,\n groupId,\n time: Date.now(),\n meta: {},\n data: payload || {},\n logType: event === 'compile-error'\n ? 'error'\n : event === 'fallback' || event === 'missing'\n ? 'warning'\n : 'default'\n }\n });\n }\n}\nfunction editScope(payload, i18n) {\n const composer = getComposer$2(payload.nodeId, i18n);\n if (composer) {\n const [field] = payload.path;\n if (field === 'locale' && isString(payload.state.value)) {\n composer.locale.value = payload.state.value;\n }\n else if (field === 'fallbackLocale' &&\n (isString(payload.state.value) ||\n isArray(payload.state.value) ||\n isObject(payload.state.value))) {\n composer.fallbackLocale.value = payload.state.value;\n }\n else if (field === 'inheritLocale' && isBoolean(payload.state.value)) {\n composer.inheritLocale = payload.state.value;\n }\n }\n}\n\n/* eslint-disable @typescript-eslint/no-explicit-any */\n/**\n * Convert to I18n Composer Options from VueI18n Options\n *\n * @internal\n */\nfunction convertComposerOptions(options) {\n const locale = isString(options.locale) ? options.locale : DEFAULT_LOCALE;\n const fallbackLocale = isString(options.fallbackLocale) ||\n isArray(options.fallbackLocale) ||\n isPlainObject(options.fallbackLocale) ||\n options.fallbackLocale === false\n ? options.fallbackLocale\n : locale;\n const missing = isFunction(options.missing) ? options.missing : undefined;\n const missingWarn = isBoolean(options.silentTranslationWarn) ||\n isRegExp(options.silentTranslationWarn)\n ? !options.silentTranslationWarn\n : true;\n const fallbackWarn = isBoolean(options.silentFallbackWarn) ||\n isRegExp(options.silentFallbackWarn)\n ? !options.silentFallbackWarn\n : true;\n const fallbackRoot = isBoolean(options.fallbackRoot)\n ? options.fallbackRoot\n : true;\n const fallbackFormat = !!options.formatFallbackMessages;\n const modifiers = isPlainObject(options.modifiers) ? options.modifiers : {};\n const pluralizationRules = options.pluralizationRules;\n const postTranslation = isFunction(options.postTranslation)\n ? options.postTranslation\n : undefined;\n const warnHtmlMessage = isString(options.warnHtmlInMessage)\n ? options.warnHtmlInMessage !== 'off'\n : true;\n const escapeParameter = !!options.escapeParameterHtml;\n const inheritLocale = isBoolean(options.sync) ? options.sync : true;\n let messages = options.messages;\n if (isPlainObject(options.sharedMessages)) {\n const sharedMessages = options.sharedMessages;\n const locales = Object.keys(sharedMessages);\n messages = locales.reduce((messages, locale) => {\n const message = messages[locale] || (messages[locale] = {});\n assign(message, sharedMessages[locale]);\n return messages;\n }, (messages || {}));\n }\n const { __i18n, __root, __injectWithOption } = options;\n const datetimeFormats = options.datetimeFormats;\n const numberFormats = options.numberFormats;\n const flatJson = options.flatJson;\n return {\n locale,\n fallbackLocale,\n messages,\n flatJson,\n datetimeFormats,\n numberFormats,\n missing,\n missingWarn,\n fallbackWarn,\n fallbackRoot,\n fallbackFormat,\n modifiers,\n pluralRules: pluralizationRules,\n postTranslation,\n warnHtmlMessage,\n escapeParameter,\n messageResolver: options.messageResolver,\n inheritLocale,\n __i18n,\n __root,\n __injectWithOption\n };\n}\n/**\n * create VueI18n interface factory\n *\n * @internal\n *\n * @deprecated will be removed at vue-i18n v12\n */\nfunction createVueI18n(options = {}) {\n const composer = createComposer(convertComposerOptions(options));\n const { __extender } = options;\n // defines VueI18n\n const vueI18n = {\n // id\n id: composer.id,\n // locale\n get locale() {\n return composer.locale.value;\n },\n set locale(val) {\n composer.locale.value = val;\n },\n // fallbackLocale\n get fallbackLocale() {\n return composer.fallbackLocale.value;\n },\n set fallbackLocale(val) {\n composer.fallbackLocale.value = val;\n },\n // messages\n get messages() {\n return composer.messages.value;\n },\n // datetimeFormats\n get datetimeFormats() {\n return composer.datetimeFormats.value;\n },\n // numberFormats\n get numberFormats() {\n return composer.numberFormats.value;\n },\n // availableLocales\n get availableLocales() {\n return composer.availableLocales;\n },\n // missing\n get missing() {\n return composer.getMissingHandler();\n },\n set missing(handler) {\n composer.setMissingHandler(handler);\n },\n // silentTranslationWarn\n get silentTranslationWarn() {\n return isBoolean(composer.missingWarn)\n ? !composer.missingWarn\n : composer.missingWarn;\n },\n set silentTranslationWarn(val) {\n composer.missingWarn = isBoolean(val) ? !val : val;\n },\n // silentFallbackWarn\n get silentFallbackWarn() {\n return isBoolean(composer.fallbackWarn)\n ? !composer.fallbackWarn\n : composer.fallbackWarn;\n },\n set silentFallbackWarn(val) {\n composer.fallbackWarn = isBoolean(val) ? !val : val;\n },\n // modifiers\n get modifiers() {\n return composer.modifiers;\n },\n // formatFallbackMessages\n get formatFallbackMessages() {\n return composer.fallbackFormat;\n },\n set formatFallbackMessages(val) {\n composer.fallbackFormat = val;\n },\n // postTranslation\n get postTranslation() {\n return composer.getPostTranslationHandler();\n },\n set postTranslation(handler) {\n composer.setPostTranslationHandler(handler);\n },\n // sync\n get sync() {\n return composer.inheritLocale;\n },\n set sync(val) {\n composer.inheritLocale = val;\n },\n // warnInHtmlMessage\n get warnHtmlInMessage() {\n return composer.warnHtmlMessage ? 'warn' : 'off';\n },\n set warnHtmlInMessage(val) {\n composer.warnHtmlMessage = val !== 'off';\n },\n // escapeParameterHtml\n get escapeParameterHtml() {\n return composer.escapeParameter;\n },\n set escapeParameterHtml(val) {\n composer.escapeParameter = val;\n },\n // pluralizationRules\n get pluralizationRules() {\n return composer.pluralRules || {};\n },\n // for internal\n __composer: composer,\n // t\n t(...args) {\n return Reflect.apply(composer.t, composer, [...args]);\n },\n // rt\n rt(...args) {\n return Reflect.apply(composer.rt, composer, [...args]);\n },\n // te\n te(key, locale) {\n return composer.te(key, locale);\n },\n // tm\n tm(key) {\n return composer.tm(key);\n },\n // getLocaleMessage\n getLocaleMessage(locale) {\n return composer.getLocaleMessage(locale);\n },\n // setLocaleMessage\n setLocaleMessage(locale, message) {\n composer.setLocaleMessage(locale, message);\n },\n // mergeLocaleMessage\n mergeLocaleMessage(locale, message) {\n composer.mergeLocaleMessage(locale, message);\n },\n // d\n d(...args) {\n return Reflect.apply(composer.d, composer, [...args]);\n },\n // getDateTimeFormat\n getDateTimeFormat(locale) {\n return composer.getDateTimeFormat(locale);\n },\n // setDateTimeFormat\n setDateTimeFormat(locale, format) {\n composer.setDateTimeFormat(locale, format);\n },\n // mergeDateTimeFormat\n mergeDateTimeFormat(locale, format) {\n composer.mergeDateTimeFormat(locale, format);\n },\n // n\n n(...args) {\n return Reflect.apply(composer.n, composer, [...args]);\n },\n // getNumberFormat\n getNumberFormat(locale) {\n return composer.getNumberFormat(locale);\n },\n // setNumberFormat\n setNumberFormat(locale, format) {\n composer.setNumberFormat(locale, format);\n },\n // mergeNumberFormat\n mergeNumberFormat(locale, format) {\n composer.mergeNumberFormat(locale, format);\n }\n };\n vueI18n.__extender = __extender;\n // for vue-devtools timeline event\n if ((process.env.NODE_ENV !== 'production')) {\n vueI18n.__enableEmitter = (emitter) => {\n const __composer = composer;\n __composer[EnableEmitter] && __composer[EnableEmitter](emitter);\n };\n vueI18n.__disableEmitter = () => {\n const __composer = composer;\n __composer[DisableEmitter] && __composer[DisableEmitter]();\n };\n }\n return vueI18n;\n}\n/* eslint-enable @typescript-eslint/no-explicit-any */\n\n/**\n * Supports compatibility for legacy vue-i18n APIs\n * This mixin is used when we use vue-i18n@v9.x or later\n */\nfunction defineMixin(vuei18n, composer, i18n) {\n return {\n beforeCreate() {\n const instance = getCurrentInstance();\n /* istanbul ignore if */\n if (!instance) {\n throw createI18nError(I18nErrorCodes.UNEXPECTED_ERROR);\n }\n const options = this.$options;\n if (options.i18n) {\n const optionsI18n = options.i18n;\n if (options.__i18n) {\n optionsI18n.__i18n = options.__i18n;\n }\n optionsI18n.__root = composer;\n if (this === this.$root) {\n // merge option and gttach global\n this.$i18n = mergeToGlobal(vuei18n, optionsI18n);\n }\n else {\n optionsI18n.__injectWithOption = true;\n optionsI18n.__extender = i18n.__vueI18nExtend;\n // atttach local VueI18n instance\n this.$i18n = createVueI18n(optionsI18n);\n // extend VueI18n instance\n const _vueI18n = this.$i18n;\n if (_vueI18n.__extender) {\n _vueI18n.__disposer = _vueI18n.__extender(this.$i18n);\n }\n }\n }\n else if (options.__i18n) {\n if (this === this.$root) {\n // merge option and gttach global\n this.$i18n = mergeToGlobal(vuei18n, options);\n }\n else {\n // atttach local VueI18n instance\n this.$i18n = createVueI18n({\n __i18n: options.__i18n,\n __injectWithOption: true,\n __extender: i18n.__vueI18nExtend,\n __root: composer\n });\n // extend VueI18n instance\n const _vueI18n = this.$i18n;\n if (_vueI18n.__extender) {\n _vueI18n.__disposer = _vueI18n.__extender(this.$i18n);\n }\n }\n }\n else {\n // attach global VueI18n instance\n this.$i18n = vuei18n;\n }\n if (options.__i18nGlobal) {\n adjustI18nResources(composer, options, options);\n }\n // defines vue-i18n legacy APIs\n this.$t = (...args) => this.$i18n.t(...args);\n this.$rt = (...args) => this.$i18n.rt(...args);\n this.$te = (key, locale) => this.$i18n.te(key, locale);\n this.$d = (...args) => this.$i18n.d(...args);\n this.$n = (...args) => this.$i18n.n(...args);\n this.$tm = (key) => this.$i18n.tm(key);\n i18n.__setInstance(instance, this.$i18n);\n },\n mounted() {\n /* istanbul ignore if */\n if (((process.env.NODE_ENV !== 'production') || __VUE_PROD_DEVTOOLS__) &&\n !false &&\n this.$i18n) {\n const instance = getCurrentInstance();\n if (!instance) {\n return;\n }\n const _vueI18n = this.$i18n;\n instance.__VUE_I18N__ = _vueI18n.__composer;\n const emitter = (this.__v_emitter =\n createEmitter());\n _vueI18n.__enableEmitter && _vueI18n.__enableEmitter(emitter);\n emitter.on('*', addTimelineEvent);\n }\n },\n unmounted() {\n const instance = getCurrentInstance();\n /* istanbul ignore if */\n if (!instance) {\n throw createI18nError(I18nErrorCodes.UNEXPECTED_ERROR);\n }\n const _vueI18n = this.$i18n;\n /* istanbul ignore if */\n if (((process.env.NODE_ENV !== 'production') || __VUE_PROD_DEVTOOLS__) &&\n !false &&\n instance.__VUE_I18N__) {\n if (this.__v_emitter) {\n this.__v_emitter.off('*', addTimelineEvent);\n delete this.__v_emitter;\n }\n if (this.$i18n) {\n _vueI18n.__disableEmitter && _vueI18n.__disableEmitter();\n delete instance.__VUE_I18N__;\n }\n }\n delete this.$t;\n delete this.$rt;\n delete this.$te;\n delete this.$d;\n delete this.$n;\n delete this.$tm;\n if (_vueI18n.__disposer) {\n _vueI18n.__disposer();\n delete _vueI18n.__disposer;\n delete _vueI18n.__extender;\n }\n i18n.__deleteInstance(instance);\n delete this.$i18n;\n }\n };\n}\nfunction mergeToGlobal(g, options) {\n g.locale = options.locale || g.locale;\n g.fallbackLocale = options.fallbackLocale || g.fallbackLocale;\n g.missing = options.missing || g.missing;\n g.silentTranslationWarn =\n options.silentTranslationWarn || g.silentFallbackWarn;\n g.silentFallbackWarn = options.silentFallbackWarn || g.silentFallbackWarn;\n g.formatFallbackMessages =\n options.formatFallbackMessages || g.formatFallbackMessages;\n g.postTranslation = options.postTranslation || g.postTranslation;\n g.warnHtmlInMessage = options.warnHtmlInMessage || g.warnHtmlInMessage;\n g.escapeParameterHtml = options.escapeParameterHtml || g.escapeParameterHtml;\n g.sync = options.sync || g.sync;\n g.__composer[SetPluralRulesSymbol](options.pluralizationRules || g.pluralizationRules);\n const messages = getLocaleMessages(g.locale, {\n messages: options.messages,\n __i18n: options.__i18n\n });\n Object.keys(messages).forEach(locale => g.mergeLocaleMessage(locale, messages[locale]));\n if (options.datetimeFormats) {\n Object.keys(options.datetimeFormats).forEach(locale => g.mergeDateTimeFormat(locale, options.datetimeFormats[locale]));\n }\n if (options.numberFormats) {\n Object.keys(options.numberFormats).forEach(locale => g.mergeNumberFormat(locale, options.numberFormats[locale]));\n }\n return g;\n}\n\nconst baseFormatProps = {\n tag: {\n type: [String, Object]\n },\n locale: {\n type: String\n },\n scope: {\n type: String,\n // NOTE: avoid https://github.com/microsoft/rushstack/issues/1050\n validator: (val /* ComponentI18nScope */) => val === 'parent' || val === 'global',\n default: 'parent' /* ComponentI18nScope */\n },\n i18n: {\n type: Object\n }\n};\n\nfunction getInterpolateArg(\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\n{ slots }, // SetupContext,\nkeys) {\n if (keys.length === 1 && keys[0] === 'default') {\n // default slot with list\n const ret = slots.default ? slots.default() : [];\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return ret.reduce((slot, current) => {\n return [\n ...slot,\n // prettier-ignore\n ...(current.type === Fragment ? current.children : [current])\n ];\n }, []);\n }\n else {\n // named slots\n return keys.reduce((arg, key) => {\n const slot = slots[key];\n if (slot) {\n arg[key] = slot();\n }\n return arg;\n }, create());\n }\n}\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction getFragmentableTag() {\n return Fragment;\n}\n\nconst TranslationImpl = /*#__PURE__*/ defineComponent({\n /* eslint-disable */\n name: 'i18n-t',\n props: assign({\n keypath: {\n type: String,\n required: true\n },\n plural: {\n type: [Number, String],\n validator: (val) => isNumber(val) || !isNaN(val)\n }\n }, baseFormatProps),\n /* eslint-enable */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n setup(props, context) {\n const { slots, attrs } = context;\n // NOTE: avoid https://github.com/microsoft/rushstack/issues/1050\n const i18n = props.i18n ||\n useI18n({\n useScope: props.scope,\n __useComponent: true\n });\n return () => {\n const keys = Object.keys(slots).filter(key => key[0] !== '_');\n const options = create();\n if (props.locale) {\n options.locale = props.locale;\n }\n if (props.plural !== undefined) {\n options.plural = isString(props.plural) ? +props.plural : props.plural;\n }\n const arg = getInterpolateArg(context, keys);\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const children = i18n[TranslateVNodeSymbol](props.keypath, arg, options);\n const assignedAttrs = assign(create(), attrs);\n const tag = isString(props.tag) || isObject(props.tag)\n ? props.tag\n : getFragmentableTag();\n return h(tag, assignedAttrs, children);\n };\n }\n});\n/**\n * export the public type for h/tsx inference\n * also to avoid inline import() in generated d.ts files\n */\n/**\n * Translation Component\n *\n * @remarks\n * See the following items for property about details\n *\n * @VueI18nSee [TranslationProps](component#translationprops)\n * @VueI18nSee [BaseFormatProps](component#baseformatprops)\n * @VueI18nSee [Component Interpolation](../guide/advanced/component)\n *\n * @example\n * ```html\n * <div id=\"app\">\n * <!-- ... -->\n * <i18n keypath=\"term\" tag=\"label\" for=\"tos\">\n * <a :href=\"url\" target=\"_blank\">{{ $t('tos') }}</a>\n * </i18n>\n * <!-- ... -->\n * </div>\n * ```\n * ```js\n * import { createApp } from 'vue'\n * import { createI18n } from 'vue-i18n'\n *\n * const messages = {\n * en: {\n * tos: 'Term of Service',\n * term: 'I accept xxx {0}.'\n * },\n * ja: {\n * tos: '利用規約',\n * term: '私は xxx の{0}に同意します。'\n * }\n * }\n *\n * const i18n = createI18n({\n * locale: 'en',\n * messages\n * })\n *\n * const app = createApp({\n * data: {\n * url: '/term'\n * }\n * }).use(i18n).mount('#app')\n * ```\n *\n * @VueI18nComponent\n */\nconst Translation = TranslationImpl;\nconst I18nT = Translation;\n\nfunction isVNode(target) {\n return isArray(target) && !isString(target[0]);\n}\nfunction renderFormatter(props, context, slotKeys, partFormatter) {\n const { slots, attrs } = context;\n return () => {\n const options = { part: true };\n let overrides = create();\n if (props.locale) {\n options.locale = props.locale;\n }\n if (isString(props.format)) {\n options.key = props.format;\n }\n else if (isObject(props.format)) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n if (isString(props.format.key)) {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n options.key = props.format.key;\n }\n // Filter out number format options only\n overrides = Object.keys(props.format).reduce((options, prop) => {\n return slotKeys.includes(prop)\n ? assign(create(), options, { [prop]: props.format[prop] }) // eslint-disable-line @typescript-eslint/no-explicit-any\n : options;\n }, create());\n }\n const parts = partFormatter(...[props.value, options, overrides]);\n let children = [options.key];\n if (isArray(parts)) {\n children = parts.map((part, index) => {\n const slot = slots[part.type];\n const node = slot\n ? slot({ [part.type]: part.value, index, parts })\n : [part.value];\n if (isVNode(node)) {\n node[0].key = `${part.type}-${index}`;\n }\n return node;\n });\n }\n else if (isString(parts)) {\n children = [parts];\n }\n const assignedAttrs = assign(create(), attrs);\n const tag = isString(props.tag) || isObject(props.tag)\n ? props.tag\n : getFragmentableTag();\n return h(tag, assignedAttrs, children);\n };\n}\n\nconst NumberFormatImpl = /*#__PURE__*/ defineComponent({\n /* eslint-disable */\n name: 'i18n-n',\n props: assign({\n value: {\n type: Number,\n required: true\n },\n format: {\n type: [String, Object]\n }\n }, baseFormatProps),\n /* eslint-enable */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n setup(props, context) {\n const i18n = props.i18n ||\n useI18n({\n useScope: props.scope,\n __useComponent: true\n });\n return renderFormatter(props, context, NUMBER_FORMAT_OPTIONS_KEYS, (...args) => \n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n i18n[NumberPartsSymbol](...args));\n }\n});\n/**\n * export the public type for h/tsx inference\n * also to avoid inline import() in generated d.ts files\n */\n/**\n * Number Format Component\n *\n * @remarks\n * See the following items for property about details\n *\n * @VueI18nSee [FormattableProps](component#formattableprops)\n * @VueI18nSee [BaseFormatProps](component#baseformatprops)\n * @VueI18nSee [Custom Formatting](../guide/essentials/number#custom-formatting)\n *\n * @VueI18nDanger\n * Not supported IE, due to no support `Intl.NumberFormat#formatToParts` in [IE](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl/NumberFormat/formatToParts)\n *\n * If you want to use it, you need to use [polyfill](https://github.com/formatjs/formatjs/tree/main/packages/intl-numberformat)\n *\n * @VueI18nComponent\n */\nconst NumberFormat = NumberFormatImpl;\nconst I18nN = NumberFormat;\n\nfunction getComposer$1(i18n, instance) {\n const i18nInternal = i18n;\n if (i18n.mode === 'composition') {\n return (i18nInternal.__getInstance(instance) || i18n.global);\n }\n else {\n const vueI18n = i18nInternal.__getInstance(instance);\n return vueI18n != null\n ? vueI18n.__composer\n : i18n.global.__composer;\n }\n}\n/**\n * @deprecated will be removed at vue-i18n v12\n */\nfunction vTDirective(i18n) {\n const _process = (binding) => {\n if ((process.env.NODE_ENV !== 'production')) {\n warnOnce(getWarnMessage(I18nWarnCodes.DEPRECATE_TRANSLATE_CUSTOME_DIRECTIVE));\n }\n const { instance, value } = binding;\n /* istanbul ignore if */\n if (!instance || !instance.$) {\n throw createI18nError(I18nErrorCodes.UNEXPECTED_ERROR);\n }\n const composer = getComposer$1(i18n, instance.$);\n const parsedValue = parseValue(value);\n return [\n Reflect.apply(composer.t, composer, [...makeParams(parsedValue)]),\n composer\n ];\n };\n const register = (el, binding) => {\n const [textContent, composer] = _process(binding);\n if (inBrowser) {\n el.__i18nWatcher = watch(composer.locale, () => {\n binding.instance && binding.instance.$forceUpdate();\n });\n }\n el.__composer = composer;\n el.textContent = textContent;\n };\n const unregister = (el) => {\n if (inBrowser && el.__i18nWatcher) {\n el.__i18nWatcher();\n el.__i18nWatcher = undefined;\n delete el.__i18nWatcher;\n }\n if (el.__composer) {\n el.__composer = undefined;\n delete el.__composer;\n }\n };\n const update = (el, { value }) => {\n if (el.__composer) {\n const composer = el.__composer;\n const parsedValue = parseValue(value);\n el.textContent = Reflect.apply(composer.t, composer, [\n ...makeParams(parsedValue)\n ]);\n }\n };\n const getSSRProps = (binding) => {\n const [textContent] = _process(binding);\n return { textContent };\n };\n return {\n created: register,\n unmounted: unregister,\n beforeUpdate: update,\n getSSRProps\n };\n}\nfunction parseValue(value) {\n if (isString(value)) {\n return { path: value };\n }\n else if (isPlainObject(value)) {\n if (!('path' in value)) {\n throw createI18nError(I18nErrorCodes.REQUIRED_VALUE, 'path');\n }\n return value;\n }\n else {\n throw createI18nError(I18nErrorCodes.INVALID_VALUE);\n }\n}\nfunction makeParams(value) {\n const { path, locale, args, choice, plural } = value;\n const options = {};\n const named = args || {};\n if (isString(locale)) {\n options.locale = locale;\n }\n if (isNumber(choice)) {\n options.plural = choice;\n }\n if (isNumber(plural)) {\n options.plural = plural;\n }\n return [path, named, options];\n}\n\nfunction apply(app, i18n, ...options) {\n const pluginOptions = isPlainObject(options[0])\n ? options[0]\n : {};\n const globalInstall = isBoolean(pluginOptions.globalInstall)\n ? pluginOptions.globalInstall\n : true;\n if (globalInstall) {\n [Translation.name, 'I18nT'].forEach(name => app.component(name, Translation));\n [NumberFormat.name, 'I18nN'].forEach(name => app.component(name, NumberFormat));\n [DatetimeFormat.name, 'I18nD'].forEach(name => app.component(name, DatetimeFormat));\n }\n // install directive\n {\n app.directive('t', vTDirective(i18n));\n }\n}\n\n/**\n * Injection key for {@link useI18n}\n *\n * @remarks\n * The global injection key for I18n instances with `useI18n`. this injection key is used in Web Components.\n * Specify the i18n instance created by {@link createI18n} together with `provide` function.\n *\n * @VueI18nGeneral\n */\nconst I18nInjectionKey = \n/* #__PURE__*/ makeSymbol('global-vue-i18n');\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction createI18n(options = {}) {\n // prettier-ignore\n const __legacyMode = __VUE_I18N_LEGACY_API__ && isBoolean(options.legacy)\n ? options.legacy\n : __VUE_I18N_LEGACY_API__;\n if ((process.env.NODE_ENV !== 'production') && __legacyMode) {\n warnOnce(getWarnMessage(I18nWarnCodes.DEPRECATE_LEGACY_MODE));\n }\n // prettier-ignore\n const __globalInjection = isBoolean(options.globalInjection)\n ? options.globalInjection\n : true;\n const __instances = new Map();\n const [globalScope, __global] = createGlobal(options, __legacyMode);\n const symbol = /* #__PURE__*/ makeSymbol((process.env.NODE_ENV !== 'production') ? 'vue-i18n' : '');\n function __getInstance(component) {\n return __instances.get(component) || null;\n }\n function __setInstance(component, instance) {\n __instances.set(component, instance);\n }\n function __deleteInstance(component) {\n __instances.delete(component);\n }\n const i18n = {\n // mode\n get mode() {\n return __VUE_I18N_LEGACY_API__ && __legacyMode\n ? 'legacy'\n : 'composition';\n },\n // install plugin\n async install(app, ...options) {\n if (((process.env.NODE_ENV !== 'production') || __VUE_PROD_DEVTOOLS__) && !false) {\n app.__VUE_I18N__ = i18n;\n }\n // setup global provider\n app.__VUE_I18N_SYMBOL__ = symbol;\n app.provide(app.__VUE_I18N_SYMBOL__, i18n);\n // set composer & vuei18n extend hook options from plugin options\n if (isPlainObject(options[0])) {\n const opts = options[0];\n i18n.__composerExtend =\n opts.__composerExtend;\n i18n.__vueI18nExtend =\n opts.__vueI18nExtend;\n }\n // global method and properties injection for Composition API\n let globalReleaseHandler = null;\n if (!__legacyMode && __globalInjection) {\n globalReleaseHandler = injectGlobalFields(app, i18n.global);\n }\n // install built-in components and directive\n if (__VUE_I18N_FULL_INSTALL__) {\n apply(app, i18n, ...options);\n }\n // setup mixin for Legacy API\n if (__VUE_I18N_LEGACY_API__ && __legacyMode) {\n app.mixin(defineMixin(__global, __global.__composer, i18n));\n }\n // release global scope\n const unmountApp = app.unmount;\n app.unmount = () => {\n globalReleaseHandler && globalReleaseHandler();\n i18n.dispose();\n unmountApp();\n };\n // setup vue-devtools plugin\n if (((process.env.NODE_ENV !== 'production') || __VUE_PROD_DEVTOOLS__) && !false) {\n const ret = await enableDevTools(app, i18n);\n if (!ret) {\n throw createI18nError(I18nErrorCodes.CANNOT_SETUP_VUE_DEVTOOLS_PLUGIN);\n }\n const emitter = createEmitter();\n if (__legacyMode) {\n const _vueI18n = __global;\n _vueI18n.__enableEmitter && _vueI18n.__enableEmitter(emitter);\n }\n else {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const _composer = __global;\n _composer[EnableEmitter] && _composer[EnableEmitter](emitter);\n }\n emitter.on('*', addTimelineEvent);\n }\n },\n // global accessor\n get global() {\n return __global;\n },\n dispose() {\n globalScope.stop();\n },\n // @internal\n __instances,\n // @internal\n __getInstance,\n // @internal\n __setInstance,\n // @internal\n __deleteInstance\n };\n return i18n;\n}\nfunction useI18n(options = {}) {\n const instance = getCurrentInstance();\n if (instance == null) {\n throw createI18nError(I18nErrorCodes.MUST_BE_CALL_SETUP_TOP);\n }\n if (!instance.isCE &&\n instance.appContext.app != null &&\n !instance.appContext.app.__VUE_I18N_SYMBOL__) {\n throw createI18nError(I18nErrorCodes.NOT_INSTALLED);\n }\n const i18n = getI18nInstance(instance);\n const gl = getGlobalComposer(i18n);\n const componentOptions = getComponentOptions(instance);\n const scope = getScope(options, componentOptions);\n if (scope === 'global') {\n adjustI18nResources(gl, options, componentOptions);\n return gl;\n }\n if (scope === 'parent') {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let composer = getComposer(i18n, instance, options.__useComponent);\n if (composer == null) {\n if ((process.env.NODE_ENV !== 'production')) {\n warn(getWarnMessage(I18nWarnCodes.NOT_FOUND_PARENT_SCOPE));\n }\n composer = gl;\n }\n return composer;\n }\n const i18nInternal = i18n;\n let composer = i18nInternal.__getInstance(instance);\n if (composer == null) {\n const composerOptions = assign({}, options);\n if ('__i18n' in componentOptions) {\n composerOptions.__i18n = componentOptions.__i18n;\n }\n if (gl) {\n composerOptions.__root = gl;\n }\n composer = createComposer(composerOptions);\n if (i18nInternal.__composerExtend) {\n composer[DisposeSymbol] =\n i18nInternal.__composerExtend(composer);\n }\n setupLifeCycle(i18nInternal, instance, composer);\n i18nInternal.__setInstance(instance, composer);\n }\n else {\n if ((process.env.NODE_ENV !== 'production') && scope === 'local') {\n warn(getWarnMessage(I18nWarnCodes.DUPLICATE_USE_I18N_CALLING));\n }\n }\n return composer;\n}\nfunction createGlobal(options, legacyMode) {\n const scope = effectScope();\n const obj = __VUE_I18N_LEGACY_API__ && legacyMode\n ? scope.run(() => createVueI18n(options))\n : scope.run(() => createComposer(options));\n if (obj == null) {\n throw createI18nError(I18nErrorCodes.UNEXPECTED_ERROR);\n }\n return [scope, obj];\n}\nfunction getI18nInstance(instance) {\n const i18n = inject(!instance.isCE\n ? instance.appContext.app.__VUE_I18N_SYMBOL__\n : I18nInjectionKey);\n /* istanbul ignore if */\n if (!i18n) {\n throw createI18nError(!instance.isCE\n ? I18nErrorCodes.UNEXPECTED_ERROR\n : I18nErrorCodes.NOT_INSTALLED_WITH_PROVIDE);\n }\n return i18n;\n}\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nfunction getScope(options, componentOptions) {\n // prettier-ignore\n return isEmptyObject(options)\n ? ('__i18n' in componentOptions)\n ? 'local'\n : 'global'\n : !options.useScope\n ? 'local'\n : options.useScope;\n}\nfunction getGlobalComposer(i18n) {\n // prettier-ignore\n return i18n.mode === 'composition'\n ? i18n.global\n : i18n.global.__composer;\n}\nfunction getComposer(i18n, target, useComponent = false) {\n let composer = null;\n const root = target.root;\n let current = getParentComponentInstance(target, useComponent);\n while (current != null) {\n const i18nInternal = i18n;\n if (i18n.mode === 'composition') {\n composer = i18nInternal.__getInstance(current);\n }\n else {\n if (__VUE_I18N_LEGACY_API__) {\n const vueI18n = i18nInternal.__getInstance(current);\n if (vueI18n != null) {\n composer = vueI18n\n .__composer;\n if (useComponent &&\n composer &&\n !composer[InejctWithOptionSymbol] // eslint-disable-line @typescript-eslint/no-explicit-any\n ) {\n composer = null;\n }\n }\n }\n }\n if (composer != null) {\n break;\n }\n if (root === current) {\n break;\n }\n current = current.parent;\n }\n return composer;\n}\nfunction getParentComponentInstance(target, useComponent = false) {\n if (target == null) {\n return null;\n }\n // if `useComponent: true` will be specified, we get lexical scope owner instance for use-case slots\n return !useComponent\n ? target.parent\n : target.vnode.ctx || target.parent; // eslint-disable-line @typescript-eslint/no-explicit-any\n}\nfunction setupLifeCycle(i18n, target, composer) {\n let emitter = null;\n onMounted(() => {\n // inject composer instance to DOM for intlify-devtools\n if (((process.env.NODE_ENV !== 'production') || __VUE_PROD_DEVTOOLS__) && !false) {\n target.__VUE_I18N__ = composer;\n emitter = createEmitter();\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const _composer = composer;\n _composer[EnableEmitter] && _composer[EnableEmitter](emitter);\n emitter.on('*', addTimelineEvent);\n }\n }, target);\n onUnmounted(() => {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const _composer = composer;\n // remove composer instance from DOM for intlify-devtools\n if (((process.env.NODE_ENV !== 'production') || __VUE_PROD_DEVTOOLS__) && !false) {\n emitter && emitter.off('*', addTimelineEvent);\n _composer[DisableEmitter] && _composer[DisableEmitter]();\n delete target.__VUE_I18N__;\n }\n i18n.__deleteInstance(target);\n // dispose extended resources\n const dispose = _composer[DisposeSymbol];\n if (dispose) {\n dispose();\n delete _composer[DisposeSymbol];\n }\n }, target);\n}\nconst globalExportProps = [\n 'locale',\n 'fallbackLocale',\n 'availableLocales'\n];\nconst globalExportMethods = ['t', 'rt', 'd', 'n', 'tm', 'te']\n ;\nfunction injectGlobalFields(app, composer) {\n const i18n = Object.create(null);\n globalExportProps.forEach(prop => {\n const desc = Object.getOwnPropertyDescriptor(composer, prop);\n if (!desc) {\n throw createI18nError(I18nErrorCodes.UNEXPECTED_ERROR);\n }\n const wrap = isRef(desc.value) // check computed props\n ? {\n get() {\n return desc.value.value;\n },\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n set(val) {\n desc.value.value = val;\n }\n }\n : {\n get() {\n return desc.get && desc.get();\n }\n };\n Object.defineProperty(i18n, prop, wrap);\n });\n app.config.globalProperties.$i18n = i18n;\n globalExportMethods.forEach(method => {\n const desc = Object.getOwnPropertyDescriptor(composer, method);\n if (!desc || !desc.value) {\n throw createI18nError(I18nErrorCodes.UNEXPECTED_ERROR);\n }\n Object.defineProperty(app.config.globalProperties, `$${method}`, desc);\n });\n const dispose = () => {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n delete app.config.globalProperties.$i18n;\n globalExportMethods.forEach(method => {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n delete app.config.globalProperties[`$${method}`];\n });\n };\n return dispose;\n}\n\nconst DatetimeFormatImpl = /* #__PURE__*/ defineComponent({\n /* eslint-disable */\n name: 'i18n-d',\n props: assign({\n value: {\n type: [Number, Date],\n required: true\n },\n format: {\n type: [String, Object]\n }\n }, baseFormatProps),\n /* eslint-enable */\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n setup(props, context) {\n const i18n = props.i18n ||\n useI18n({\n useScope: props.scope,\n __useComponent: true\n });\n return renderFormatter(props, context, DATETIME_FORMAT_OPTIONS_KEYS, (...args) => \n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n i18n[DatetimePartsSymbol](...args));\n }\n});\n/**\n * Datetime Format Component\n *\n * @remarks\n * See the following items for property about details\n *\n * @VueI18nSee [FormattableProps](component#formattableprops)\n * @VueI18nSee [BaseFormatProps](component#baseformatprops)\n * @VueI18nSee [Custom Formatting](../guide/essentials/datetime#custom-formatting)\n *\n * @VueI18nDanger\n * Not supported IE, due to no support `Intl.DateTimeFormat#formatToParts` in [IE](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl/DateTimeFormat/formatToParts)\n *\n * If you want to use it, you need to use [polyfill](https://github.com/formatjs/formatjs/tree/main/packages/intl-datetimeformat)\n *\n * @VueI18nComponent\n */\nconst DatetimeFormat = DatetimeFormatImpl;\nconst I18nD = DatetimeFormat;\n\n{\n initFeatureFlags();\n}\n// register message compiler at vue-i18n\nregisterMessageCompiler(compile);\n// register message resolver at vue-i18n\nregisterMessageResolver(resolveValue);\n// register fallback locale at vue-i18n\nregisterLocaleFallbacker(fallbackWithLocaleChain);\n// NOTE: experimental !!\nif ((process.env.NODE_ENV !== 'production') || __INTLIFY_PROD_DEVTOOLS__) {\n const target = getGlobalThis();\n target.__INTLIFY__ = true;\n setDevToolsHook(target.__INTLIFY_DEVTOOLS_GLOBAL_HOOK__);\n}\nif ((process.env.NODE_ENV !== 'production')) ;\n\nexport { DatetimeFormat, I18nD, I18nInjectionKey, I18nN, I18nT, NumberFormat, Translation, VERSION, createI18n, useI18n, vTDirective };\n","interface ICropRect {\n x: number\n y: number\n width: number\n height: number\n}\n\nenum EHandleName {\n TopLeft = 'top-left',\n Top = 'top',\n TopRight = 'top-right',\n Right = 'right',\n BottomRight = 'bottom-right',\n Bottom = 'bottom',\n BottomLeft = 'bottom-left',\n Left = 'left',\n}\n\ninterface IImageCropperProps {\n image?: File\n cropAsCircle?: boolean\n outputAsCircle?: boolean\n lockAspectRatio?: boolean\n showPreview?: boolean\n}\n\nexport { ICropRect, EHandleName, IImageCropperProps }\n","<template>\n <div class=\"nb-image-cropper\">\n <div\n class=\"canvas-container\"\n @mousedown=\"onCanvasMouseDown\"\n @mousemove=\"onMouseMove\"\n @mouseup=\"onMouseUp\"\n @mouseleave=\"onMouseUp\"\n @touchstart=\"onCanvasMouseDown\"\n @touchmove=\"onMouseMove\"\n @touchend=\"onMouseUp\"\n >\n <canvas ref=\"canvas\"></canvas>\n <div\n v-for=\"handle in handles\"\n :key=\"handle.name\"\n :class=\"['resize-handle', handle.name]\"\n :style=\"handlePositions[handle.name]\"\n @mousedown.stop=\"startResize($event, handle.name)\"\n @touchstart.stop=\"startResize($event, handle.name)\"\n ></div>\n </div>\n <NbGrid\n v-if=\"showPreview && croppedImageUrl && cropGeometry\"\n class=\"cropped-image-preview\"\n >\n <NbGrid is=\"ul\" dir=\"col\" justify=\"center\" gap=\"sm\">\n <li>\n <strong>{{ t('common.X') }}</strong> {{ cropGeometry.x.toFixed(0) }}\n </li>\n <li>\n <strong>{{ t('common.Y') }}</strong> {{ cropGeometry.y.toFixed(0) }}\n </li>\n <li>\n <strong>{{ t('common.WIDTH') }}</strong>\n {{ cropGeometry.width.toFixed(0) }}\n </li>\n <li>\n <strong>{{ t('common.HEIGHT') }}</strong>\n {{ cropGeometry.height.toFixed(0) }}\n </li>\n </NbGrid>\n <img :src=\"croppedImageUrl\" :alt=\"t('common.IMAGE_THUMBNAIL')\" />\n </NbGrid>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { ref, onMounted, computed, watch, onBeforeUnmount } from 'vue'\nimport { useI18n } from 'vue-i18n'\nimport { ICropRect, EHandleName, IImageCropperProps } from './ImageCropper.d'\n\nconst { t } = useI18n({})\n\nconst props = withDefaults(defineProps<IImageCropperProps>(), {\n cropAsCircle: false,\n outputAsCircle: false,\n lockAspectRatio: false,\n showPreview: false,\n})\n\nconst emit = defineEmits<{\n crop: [payload: { blob: Blob; geometry: ICropRect }]\n}>()\n\nconst canvas = ref<HTMLCanvasElement | null>(null)\nlet ctx: CanvasRenderingContext2D | null = null\nconst img = new Image()\nlet sourceImageUrl: string | null = null\n\nconst DISPLAY_WIDTH = 700\nconst DISPLAY_HEIGHT = 400\nlet scale = { x: 1, y: 1 }\n\nconst cropRect = ref<ICropRect>({ x: 50, y: 50, width: 200, height: 200 })\nconst croppedImageUrl = ref<string | null>(null)\nconst cropGeometry = ref<ICropRect | null>(null)\n\nlet isDragging = false\nlet isDraggingCrop = false\nlet dragStart = { x: 0, y: 0 }\n\nlet isResizing = false\nlet resizeStart = { x: 0, y: 0 }\nlet initialCropRect = { x: 0, y: 0, width: 0, height: 0 }\nlet currentHandle: EHandleName | null = null\nlet isShiftPressed = false\n\nconst handles: Array<{ name: EHandleName }> = [\n { name: EHandleName.TopLeft },\n { name: EHandleName.Top },\n { name: EHandleName.TopRight },\n { name: EHandleName.Right },\n { name: EHandleName.BottomRight },\n { name: EHandleName.Bottom },\n { name: EHandleName.BottomLeft },\n { name: EHandleName.Left },\n]\n\nconst loadImage = () => {\n if (!props.image) {\n console.error('No image file provided')\n return\n }\n\n if (sourceImageUrl) {\n URL.revokeObjectURL(sourceImageUrl)\n sourceImageUrl = null\n }\n\n img.onload = () => {\n const { drawWidth, drawHeight } = calculateScale()\n\n if (canvas.value) {\n // Set canvas size to match the rendered image dimensions.\n canvas.value.width = drawWidth\n canvas.value.height = drawHeight\n\n const offsetX = (canvas.value.width - img.width * scale.x) / 2\n const offsetY = (canvas.value.height - img.height * scale.y) / 2\n\n // if cropping as a circle or locking the aspect ratio, use a square crop.\n if (props.cropAsCircle || props.lockAspectRatio) {\n const minDimension = Math.min(img.width * scale.x, img.height * scale.y)\n const initialCropSize = minDimension * 0.5\n cropRect.value = {\n x: offsetX + (img.width * scale.x - initialCropSize) / 2,\n y: offsetY + (img.height * scale.y - initialCropSize) / 2,\n width: initialCropSize,\n height: initialCropSize,\n }\n } else {\n // otherwise, set initial crop to 50% of the image dimensions.\n cropRect.value = {\n x: offsetX + (img.width * scale.x * 0.5 - img.width * scale.x * 0.25),\n y:\n offsetY +\n (img.height * scale.y * 0.5 - img.height * scale.y * 0.25),\n width: img.width * scale.x * 0.5,\n height: img.height * scale.y * 0.5,\n }\n }\n\n drawImage()\n cropImage()\n }\n }\n img.onerror = () => {\n console.error('Failed to load image')\n }\n sourceImageUrl = URL.createObjectURL(props.image)\n img.src = sourceImageUrl\n}\n\nonMounted(() => {\n if (canvas.value) {\n ctx = canvas.value.getContext('2d')\n if (ctx) {\n // enable antialiasing for smoother drawing\n ctx.imageSmoothingEnabled = true\n ctx.imageSmoothingQuality = 'high'\n }\n if (props.image) {\n loadImage()\n }\n }\n})\n\nonBeforeUnmount(() => {\n if (sourceImageUrl) {\n URL.revokeObjectURL(sourceImageUrl)\n sourceImageUrl = null\n }\n const currentPreviewUrl = croppedImageUrl.value\n if (currentPreviewUrl) {\n URL.revokeObjectURL(currentPreviewUrl)\n croppedImageUrl.value = null\n }\n})\n\nwatch(\n () => props.image,\n (newImage) => {\n if (newImage) {\n loadImage()\n }\n },\n)\n\n// watch for prop changes that affect the crop area\nwatch(\n () => [props.cropAsCircle, props.outputAsCircle, props.lockAspectRatio],\n () => {\n if (canvas.value && ctx) {\n // redraw the canvas to reflect prop changes\n drawImage()\n }\n },\n)\n\nconst calculateScale = () => {\n const aspectRatio = img.width / img.height\n let drawWidth = DISPLAY_WIDTH\n let drawHeight = DISPLAY_HEIGHT\n\n if (aspectRatio > DISPLAY_WIDTH / DISPLAY_HEIGHT) {\n drawHeight = DISPLAY_WIDTH / aspectRatio\n } else {\n drawWidth = DISPLAY_HEIGHT * aspectRatio\n }\n\n scale.x = drawWidth / img.width\n scale.y = drawHeight / img.height\n return { drawWidth, drawHeight }\n}\n\nconst drawImage = () => {\n if (ctx && canvas.value) {\n ctx.clearRect(0, 0, canvas.value.width, canvas.value.height)\n // center the image on the canvas\n const offsetX = (canvas.value.width - img.width * scale.x) / 2\n const offsetY = (canvas.value.height - img.height * scale.y) / 2\n ctx.drawImage(\n img,\n 0,\n 0,\n img.width,\n img.height,\n offsetX,\n offsetY,\n img.width * scale.x,\n img.height * scale.y,\n )\n drawOverlay()\n }\n}\n\nconst drawOverlay = () => {\n if (ctx && canvas.value) {\n ctx.save()\n\n // draw the dimming overlay\n ctx.beginPath()\n if (props.cropAsCircle) {\n ctx.arc(\n cropRect.value.x + cropRect.value.width / 2,\n cropRect.value.y + cropRect.value.height / 2,\n cropRect.value.width / 2,\n 0,\n Math.PI * 2,\n )\n } else {\n ctx.rect(\n cropRect.value.x,\n cropRect.value.y,\n cropRect.value.width,\n cropRect.value.height,\n )\n }\n ctx.rect(0, 0, canvas.value.width, canvas.value.height)\n ctx.clip('evenodd')\n ctx.fillStyle = 'rgba(0, 0, 0, 0.5)'\n ctx.fillRect(0, 0, canvas.value.width, canvas.value.height)\n\n // draw the crop area outline\n ctx.restore()\n ctx.save()\n ctx.strokeStyle = 'rgba(255, 255, 255, 0.8)'\n ctx.lineWidth = 1\n ctx.setLineDash([5, 5])\n // disable antialiasing for crisp outlines\n ctx.imageSmoothingEnabled = false\n\n if (props.cropAsCircle) {\n ctx.beginPath()\n ctx.arc(\n cropRect.value.x + cropRect.value.width / 2,\n cropRect.value.y + cropRect.value.height / 2,\n cropRect.value.width / 2,\n 0,\n Math.PI * 2,\n )\n ctx.stroke()\n } else {\n ctx.strokeRect(\n cropRect.value.x,\n cropRect.value.y,\n cropRect.value.width,\n cropRect.value.height,\n )\n }\n\n ctx.restore()\n }\n}\n\n// compute handle positions based on crop area shape\nconst handlePositions = computed<\n Record<EHandleName, { left: string; top: string }>\n>(() => {\n if (props.cropAsCircle) {\n // for circle, position handles at the circle's boundary points\n const centerX = cropRect.value.x + cropRect.value.width / 2\n const centerY = cropRect.value.y + cropRect.value.height / 2\n const radius = cropRect.value.width / 2\n\n return {\n 'top-left': {\n left: `${centerX - radius - 5}px`,\n top: `${centerY - radius - 5}px`,\n },\n top: { left: `${centerX - 5}px`, top: `${centerY - radius - 5}px` },\n 'top-right': {\n left: `${centerX + radius - 5}px`,\n top: `${centerY - radius - 5}px`,\n },\n right: { left: `${centerX + radius - 5}px`, top: `${centerY - 5}px` },\n 'bottom-right': {\n left: `${centerX + radius - 5}px`,\n top: `${centerY + radius - 5}px`,\n },\n bottom: { left: `${centerX - 5}px`, top: `${centerY + radius - 5}px` },\n 'bottom-left': {\n left: `${centerX - radius - 5}px`,\n top: `${centerY + radius - 5}px`,\n },\n left: { left: `${centerX - radius - 5}px`, top: `${centerY - 5}px` },\n }\n } else {\n // for rectangle, position handles at corners and edges\n return {\n 'top-left': {\n left: `${cropRect.value.x - 5}px`,\n top: `${cropRect.value.y - 5}px`,\n },\n top: {\n left: `${cropRect.value.x + cropRect.value.width / 2 - 5}px`,\n top: `${cropRect.value.y - 5}px`,\n },\n 'top-right': {\n left: `${cropRect.value.x + cropRect.value.width - 5}px`,\n top: `${cropRect.value.y - 5}px`,\n },\n right: {\n left: `${cropRect.value.x + cropRect.value.width - 5}px`,\n top: `${cropRect.value.y + cropRect.value.height / 2 - 5}px`,\n },\n 'bottom-right': {\n left: `${cropRect.value.x + cropRect.value.width - 5}px`,\n top: `${cropRect.value.y + cropRect.value.height - 5}px`,\n },\n bottom: {\n left: `${cropRect.value.x + cropRect.value.width / 2 - 5}px`,\n top: `${cropRect.value.y + cropRect.value.height - 5}px`,\n },\n 'bottom-left': {\n left: `${cropRect.value.x - 5}px`,\n top: `${cropRect.value.y + cropRect.value.height - 5}px`,\n },\n left: {\n left: `${cropRect.value.x - 5}px`,\n top: `${cropRect.value.y + cropRect.value.height / 2 - 5}px`,\n },\n }\n }\n})\n\nconst getClientCoordinates = (event: MouseEvent | TouchEvent) => {\n if ('touches' in event && event.touches.length > 0) {\n const touch = event.touches[0]\n return { clientX: touch.clientX, clientY: touch.clientY }\n } else if ('clientX' in event && 'clientY' in event) {\n return { clientX: event.clientX, clientY: event.clientY }\n }\n return { clientX: 0, clientY: 0 }\n}\n\nconst getCanvasPoint = (event: MouseEvent | TouchEvent) => {\n const canvasEl = canvas.value\n if (!canvasEl) return null\n const { clientX, clientY } = getClientCoordinates(event)\n const { left, top } = canvasEl.getBoundingClientRect()\n return { x: clientX - left, y: clientY - top }\n}\n\nconst onCanvasMouseDown = (event: MouseEvent | TouchEvent) => {\n event.preventDefault()\n const point = getCanvasPoint(event)\n if (!point) return\n const { x, y } = point\n if (isInCropArea(x, y)) {\n isDraggingCrop = true\n isDragging = true\n dragStart = { x: x - cropRect.value.x, y: y - cropRect.value.y }\n }\n}\n\nconst onMouseMove = (event: MouseEvent | TouchEvent) => {\n if (isDraggingCrop) {\n onDrag(event)\n } else if (isResizing) {\n onResize(event)\n }\n}\n\nconst onMouseUp = () => {\n if (isDraggingCrop) {\n endDrag()\n isDraggingCrop = false\n cropImage()\n }\n if (isResizing) {\n endResize()\n cropImage()\n }\n // reset drag state to ensure clean state\n isDragging = false\n isDraggingCrop = false\n}\n\nconst onDrag = (event: MouseEvent | TouchEvent) => {\n if (isDragging) {\n const point = getCanvasPoint(event)\n if (!point) return\n const { x, y } = point\n\n // use Math.floor to avoid off-by-one issues when dragging to top/left edges.\n cropRect.value.x = Math.floor(x - dragStart.x)\n cropRect.value.y = Math.floor(y - dragStart.y)\n // don't constrain during drag, let it move freely\n drawImage()\n }\n}\n\nconst endDrag = () => {\n if (isDragging) {\n // apply constraints only when dragging ends\n constrainCropRect()\n drawImage()\n isDragging = false\n }\n}\n\nconst startResize = (\n event: MouseEvent | TouchEvent,\n handleName: EHandleName,\n) => {\n event.preventDefault()\n const point = getCanvasPoint(event)\n if (!point) return\n isResizing = true\n currentHandle = handleName\n resizeStart = { x: point.x, y: point.y }\n initialCropRect = { ...cropRect.value }\n isShiftPressed = event instanceof MouseEvent && event.shiftKey\n}\n\nconst onResize = (event: MouseEvent | TouchEvent) => {\n if (!isResizing) return\n\n // in lockAspectRatio mode, perform a symmetric resize (keeping center fixed)\n if (props.lockAspectRatio && canvas.value) {\n const point = getCanvasPoint(event)\n if (!point) return\n const { x, y } = point\n const centerX = initialCropRect.x + initialCropRect.width / 2\n const centerY = initialCropRect.y + initialCropRect.height / 2\n\n if (props.cropAsCircle) {\n // for circle mode with locked aspect ratio, enforce square\n const halfSize = Math.max(Math.abs(x - centerX), Math.abs(y - centerY))\n const newSize = halfSize * 2\n cropRect.value = {\n x: centerX - halfSize,\n y: centerY - halfSize,\n width: newSize,\n height: newSize,\n }\n } else {\n // for rectangle mode with locked aspect ratio, maintain original aspect ratio\n const aspectRatio = initialCropRect.width / initialCropRect.height\n const dx = Math.abs(x - centerX)\n const newWidth = Math.max(dx * 2, 50)\n const newHeight = newWidth / aspectRatio\n cropRect.value = {\n x: centerX - newWidth / 2,\n y: centerY - newHeight / 2,\n width: newWidth,\n height: newHeight,\n }\n }\n // don't constrain during resize, let it grow beyond bounds\n drawImage()\n return\n }\n\n // non-locked (free) resizing\n const point = getCanvasPoint(event)\n if (!point) return\n const { x, y } = point\n const dx = x - resizeStart.x\n const dy = y - resizeStart.y\n\n isShiftPressed = event instanceof MouseEvent && event.shiftKey\n\n const newCropRect = { ...initialCropRect }\n\n switch (currentHandle) {\n case 'top-left':\n newCropRect.x += dx\n newCropRect.y += dy\n newCropRect.width -= dx\n newCropRect.height -= dy\n break\n case 'top':\n newCropRect.y += dy\n newCropRect.height -= dy\n break\n case 'top-right':\n newCropRect.y += dy\n newCropRect.width += dx\n newCropRect.height -= dy\n break\n case 'right':\n newCropRect.width += dx\n break\n case 'bottom-right':\n newCropRect.width += dx\n newCropRect.height += dy\n break\n case 'bottom':\n newCropRect.height += dy\n break\n case 'bottom-left':\n newCropRect.x += dx\n newCropRect.width -= dx\n newCropRect.height += dy\n break\n case 'left':\n newCropRect.x += dx\n newCropRect.width -= dx\n break\n }\n\n // prevent negative dimensions\n if (newCropRect.width < 50) newCropRect.width = 50\n if (newCropRect.height < 50) newCropRect.height = 50\n\n if (isShiftPressed && currentHandle) {\n const aspectRatio = initialCropRect.width / initialCropRect.height\n if (['left', 'right'].includes(currentHandle)) {\n newCropRect.height = newCropRect.width / aspectRatio\n if (currentHandle === 'left') {\n newCropRect.y =\n initialCropRect.y - (newCropRect.height - initialCropRect.height) / 2\n }\n } else if (['top', 'bottom'].includes(currentHandle)) {\n newCropRect.width = newCropRect.height * aspectRatio\n if (currentHandle === 'top') {\n newCropRect.x =\n initialCropRect.x - (newCropRect.width - initialCropRect.width) / 2\n }\n }\n }\n\n cropRect.value = newCropRect\n // don't constrain during resize, let it grow beyond bounds\n drawImage()\n}\n\nconst endResize = () => {\n if (isResizing) {\n // apply constraints only when resizing ends\n constrainCropRect()\n drawImage()\n isResizing = false\n currentHandle = null\n }\n}\n\nconst isInCropArea = (x: number, y: number) => {\n if (props.cropAsCircle) {\n const centerX = cropRect.value.x + cropRect.value.width / 2\n const centerY = cropRect.value.y + cropRect.value.height / 2\n const radius = cropRect.value.width / 2\n const dx = x - centerX\n const dy = y - centerY\n return dx * dx + dy * dy <= radius * radius\n } else {\n // add a small tolerance for better drag detection\n const tolerance = 2\n return (\n x >= cropRect.value.x - tolerance &&\n x <= cropRect.value.x + cropRect.value.width + tolerance &&\n y >= cropRect.value.y - tolerance &&\n y <= cropRect.value.y + cropRect.value.height + tolerance\n )\n }\n}\n\nconst constrainCropRect = () => {\n const maxX = canvas.value!.width\n const maxY = canvas.value!.height\n\n // ensure minimum size\n if (cropRect.value.width < 50) cropRect.value.width = 50\n if (cropRect.value.height < 50) cropRect.value.height = 50\n\n // if lockAspectRatio is true, enforce aspect ratio constraints\n if (props.lockAspectRatio) {\n if (props.cropAsCircle) {\n // for circle mode with locked aspect ratio, enforce square\n cropRect.value.height = cropRect.value.width\n } else {\n // for rectangle mode with locked aspect ratio, maintain original aspect ratio\n const aspectRatio = initialCropRect.width / initialCropRect.height\n cropRect.value.height = cropRect.value.width / aspectRatio\n }\n } else if (isShiftPressed) {\n // when shift is pressed, maintain aspect ratio temporarily\n const aspectRatio = initialCropRect.width / initialCropRect.height\n cropRect.value.height = cropRect.value.width / aspectRatio\n }\n\n // for circle or locked aspect ratio, maintain the aspect ratio when constraining\n if (props.cropAsCircle || props.lockAspectRatio) {\n const aspectRatio = cropRect.value.width / cropRect.value.height\n\n // if the crop area is too large, scale it down while maintaining aspect ratio\n if (cropRect.value.width > maxX || cropRect.value.height > maxY) {\n if (cropRect.value.width > cropRect.value.height) {\n cropRect.value.width = maxX\n cropRect.value.height = maxX / aspectRatio\n } else {\n cropRect.value.height = maxY\n cropRect.value.width = maxY * aspectRatio\n }\n }\n\n // ensure it stays within bounds, only move if it's actually outside\n if (cropRect.value.x < 0) cropRect.value.x = 0\n if (cropRect.value.y < 0) cropRect.value.y = 0\n if (cropRect.value.x + cropRect.value.width > maxX) {\n cropRect.value.x = maxX - cropRect.value.width\n }\n if (cropRect.value.y + cropRect.value.height > maxY) {\n cropRect.value.y = maxY - cropRect.value.height\n }\n } else {\n // for free resize, use the original logic\n // constrain position to keep crop area within canvas bounds\n if (cropRect.value.x < 0) cropRect.value.x = 0\n if (cropRect.value.y < 0) cropRect.value.y = 0\n\n // if crop area is larger than canvas, center it\n if (cropRect.value.width > maxX) {\n cropRect.value.width = maxX\n cropRect.value.x = 0\n }\n if (cropRect.value.height > maxY) {\n cropRect.value.height = maxY\n cropRect.value.y = 0\n }\n\n // ensure crop area doesn't extend beyond canvas bounds\n if (cropRect.value.x + cropRect.value.width > maxX) {\n cropRect.value.x = maxX - cropRect.value.width\n }\n if (cropRect.value.y + cropRect.value.height > maxY) {\n cropRect.value.y = maxY - cropRect.value.height\n }\n }\n}\n\nconst cropImage = () => {\n if (canvas.value && ctx) {\n const offsetX = (canvas.value.width - img.width * scale.x) / 2\n const offsetY = (canvas.value.height - img.height * scale.y) / 2\n\n const sx = (cropRect.value.x - offsetX) / scale.x\n const sy = (cropRect.value.y - offsetY) / scale.y\n const sWidth = cropRect.value.width / scale.x\n const sHeight = cropRect.value.height / scale.y\n\n const geometry = {\n x: Math.round(sx),\n y: Math.round(sy),\n width: Math.round(sWidth),\n height: Math.round(sHeight),\n }\n\n // clamp the crop area to the actual image bounds\n const clampedSX = Math.max(0, Math.min(geometry.x, img.width))\n const clampedSY = Math.max(0, Math.min(geometry.y, img.height))\n const clampedSWidth = Math.min(geometry.width, img.width - clampedSX)\n const clampedSHeight = Math.min(geometry.height, img.height - clampedSY)\n\n const croppedCanvas = document.createElement('canvas')\n croppedCanvas.width = clampedSWidth\n croppedCanvas.height = clampedSHeight\n const croppedCtx = croppedCanvas.getContext('2d')\n if (croppedCtx) {\n croppedCtx.drawImage(\n img,\n clampedSX,\n clampedSY,\n clampedSWidth,\n clampedSHeight,\n 0,\n 0,\n clampedSWidth,\n clampedSHeight,\n )\n\n if (props.cropAsCircle && props.outputAsCircle) {\n croppedCtx.globalCompositeOperation = 'destination-in'\n croppedCtx.beginPath()\n croppedCtx.arc(\n clampedSWidth / 2,\n clampedSHeight / 2,\n clampedSWidth / 2,\n 0,\n Math.PI * 2,\n )\n croppedCtx.closePath()\n croppedCtx.fill()\n croppedCtx.globalCompositeOperation = 'source-over'\n }\n\n // expose the cropped image via the `crop` event\n croppedCanvas.toBlob(\n (blob) => {\n if (blob) {\n const oldPreviewUrl = croppedImageUrl.value\n if (oldPreviewUrl) {\n URL.revokeObjectURL(oldPreviewUrl)\n }\n croppedImageUrl.value = URL.createObjectURL(blob)\n cropGeometry.value = geometry\n emit('crop', { blob, geometry })\n }\n },\n 'image/jpeg',\n 0.8,\n )\n }\n }\n}\n\nwatch(\n () => props,\n () => {\n cropImage()\n },\n { deep: true },\n)\n</script>\n\n<style lang=\"scss\" scoped>\n$handle-size: 10px;\n$handle-offset: -7px;\n$border-color: black;\n$background-color: white;\n\n.nb-image-cropper {\n position: relative;\n user-select: none;\n display: inline-block;\n max-width: 100%;\n height: auto;\n overflow: hidden;\n\n .canvas-container {\n position: relative;\n display: inline-block;\n width: 100%;\n height: auto;\n\n canvas {\n display: block;\n max-width: 100%;\n height: auto;\n }\n }\n\n .resize-handle {\n position: absolute;\n width: 10px;\n height: 10px;\n background: white;\n border: 1px solid black;\n z-index: 1;\n\n &.top-left {\n cursor: nwse-resize;\n }\n\n &.top {\n cursor: ns-resize;\n }\n\n &.top-right {\n cursor: nesw-resize;\n }\n\n &.right {\n cursor: ew-resize;\n }\n\n &.bottom-right {\n cursor: nwse-resize;\n }\n\n &.bottom {\n cursor: ns-resize;\n }\n\n &.bottom-left {\n cursor: nesw-resize;\n }\n\n &.left {\n cursor: ew-resize;\n }\n }\n\n .cropped-image-preview {\n position: absolute;\n right: calc(var(--nb-base-unit, 8px) * 2);\n bottom: calc(var(--nb-base-unit, 8px) * 2);\n border-radius: var(--nb-border-radius-sm, 6px);\n overflow: hidden;\n height: calc(var(--nb-base-unit, 8px) * 14);\n margin-top: 20px;\n border: dotted 1px var(--nb-c-component-border, #e0e0e0);\n background: var(--nb-c-backdrop, #fff);\n user-select: none;\n pointer-events: none;\n ul {\n min-width: calc(var(--nb-base-unit, 8px) * 9);\n background: black;\n color: white;\n font-size: var(--nb-font-size-10, 10px);\n padding: calc(var(--nb-base-unit, 8px) / 2);\n line-height: var(--nb-font-size-14, 14px);\n }\n img {\n width: 100%;\n height: 100%;\n object-fit: contain;\n object-position: center;\n }\n }\n}\n</style>\n","<template>\n <div class=\"nb-image-cropper\">\n <div\n class=\"canvas-container\"\n @mousedown=\"onCanvasMouseDown\"\n @mousemove=\"onMouseMove\"\n @mouseup=\"onMouseUp\"\n @mouseleave=\"onMouseUp\"\n @touchstart=\"onCanvasMouseDown\"\n @touchmove=\"onMouseMove\"\n @touchend=\"onMouseUp\"\n >\n <canvas ref=\"canvas\"></canvas>\n <div\n v-for=\"handle in handles\"\n :key=\"handle.name\"\n :class=\"['resize-handle', handle.name]\"\n :style=\"handlePositions[handle.name]\"\n @mousedown.stop=\"startResize($event, handle.name)\"\n @touchstart.stop=\"startResize($event, handle.name)\"\n ></div>\n </div>\n <NbGrid\n v-if=\"showPreview && croppedImageUrl && cropGeometry\"\n class=\"cropped-image-preview\"\n >\n <NbGrid is=\"ul\" dir=\"col\" justify=\"center\" gap=\"sm\">\n <li>\n <strong>{{ t('common.X') }}</strong> {{ cropGeometry.x.toFixed(0) }}\n </li>\n <li>\n <strong>{{ t('common.Y') }}</strong> {{ cropGeometry.y.toFixed(0) }}\n </li>\n <li>\n <strong>{{ t('common.WIDTH') }}</strong>\n {{ cropGeometry.width.toFixed(0) }}\n </li>\n <li>\n <strong>{{ t('common.HEIGHT') }}</strong>\n {{ cropGeometry.height.toFixed(0) }}\n </li>\n </NbGrid>\n <img :src=\"croppedImageUrl\" :alt=\"t('common.IMAGE_THUMBNAIL')\" />\n </NbGrid>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { ref, onMounted, computed, watch, onBeforeUnmount } from 'vue'\nimport { useI18n } from 'vue-i18n'\nimport { ICropRect, EHandleName, IImageCropperProps } from './ImageCropper.d'\n\nconst { t } = useI18n({})\n\nconst props = withDefaults(defineProps<IImageCropperProps>(), {\n cropAsCircle: false,\n outputAsCircle: false,\n lockAspectRatio: false,\n showPreview: false,\n})\n\nconst emit = defineEmits<{\n crop: [payload: { blob: Blob; geometry: ICropRect }]\n}>()\n\nconst canvas = ref<HTMLCanvasElement | null>(null)\nlet ctx: CanvasRenderingContext2D | null = null\nconst img = new Image()\nlet sourceImageUrl: string | null = null\n\nconst DISPLAY_WIDTH = 700\nconst DISPLAY_HEIGHT = 400\nlet scale = { x: 1, y: 1 }\n\nconst cropRect = ref<ICropRect>({ x: 50, y: 50, width: 200, height: 200 })\nconst croppedImageUrl = ref<string | null>(null)\nconst cropGeometry = ref<ICropRect | null>(null)\n\nlet isDragging = false\nlet isDraggingCrop = false\nlet dragStart = { x: 0, y: 0 }\n\nlet isResizing = false\nlet resizeStart = { x: 0, y: 0 }\nlet initialCropRect = { x: 0, y: 0, width: 0, height: 0 }\nlet currentHandle: EHandleName | null = null\nlet isShiftPressed = false\n\nconst handles: Array<{ name: EHandleName }> = [\n { name: EHandleName.TopLeft },\n { name: EHandleName.Top },\n { name: EHandleName.TopRight },\n { name: EHandleName.Right },\n { name: EHandleName.BottomRight },\n { name: EHandleName.Bottom },\n { name: EHandleName.BottomLeft },\n { name: EHandleName.Left },\n]\n\nconst loadImage = () => {\n if (!props.image) {\n console.error('No image file provided')\n return\n }\n\n if (sourceImageUrl) {\n URL.revokeObjectURL(sourceImageUrl)\n sourceImageUrl = null\n }\n\n img.onload = () => {\n const { drawWidth, drawHeight } = calculateScale()\n\n if (canvas.value) {\n // Set canvas size to match the rendered image dimensions.\n canvas.value.width = drawWidth\n canvas.value.height = drawHeight\n\n const offsetX = (canvas.value.width - img.width * scale.x) / 2\n const offsetY = (canvas.value.height - img.height * scale.y) / 2\n\n // if cropping as a circle or locking the aspect ratio, use a square crop.\n if (props.cropAsCircle || props.lockAspectRatio) {\n const minDimension = Math.min(img.width * scale.x, img.height * scale.y)\n const initialCropSize = minDimension * 0.5\n cropRect.value = {\n x: offsetX + (img.width * scale.x - initialCropSize) / 2,\n y: offsetY + (img.height * scale.y - initialCropSize) / 2,\n width: initialCropSize,\n height: initialCropSize,\n }\n } else {\n // otherwise, set initial crop to 50% of the image dimensions.\n cropRect.value = {\n x: offsetX + (img.width * scale.x * 0.5 - img.width * scale.x * 0.25),\n y:\n offsetY +\n (img.height * scale.y * 0.5 - img.height * scale.y * 0.25),\n width: img.width * scale.x * 0.5,\n height: img.height * scale.y * 0.5,\n }\n }\n\n drawImage()\n cropImage()\n }\n }\n img.onerror = () => {\n console.error('Failed to load image')\n }\n sourceImageUrl = URL.createObjectURL(props.image)\n img.src = sourceImageUrl\n}\n\nonMounted(() => {\n if (canvas.value) {\n ctx = canvas.value.getContext('2d')\n if (ctx) {\n // enable antialiasing for smoother drawing\n ctx.imageSmoothingEnabled = true\n ctx.imageSmoothingQuality = 'high'\n }\n if (props.image) {\n loadImage()\n }\n }\n})\n\nonBeforeUnmount(() => {\n if (sourceImageUrl) {\n URL.revokeObjectURL(sourceImageUrl)\n sourceImageUrl = null\n }\n const currentPreviewUrl = croppedImageUrl.value\n if (currentPreviewUrl) {\n URL.revokeObjectURL(currentPreviewUrl)\n croppedImageUrl.value = null\n }\n})\n\nwatch(\n () => props.image,\n (newImage) => {\n if (newImage) {\n loadImage()\n }\n },\n)\n\n// watch for prop changes that affect the crop area\nwatch(\n () => [props.cropAsCircle, props.outputAsCircle, props.lockAspectRatio],\n () => {\n if (canvas.value && ctx) {\n // redraw the canvas to reflect prop changes\n drawImage()\n }\n },\n)\n\nconst calculateScale = () => {\n const aspectRatio = img.width / img.height\n let drawWidth = DISPLAY_WIDTH\n let drawHeight = DISPLAY_HEIGHT\n\n if (aspectRatio > DISPLAY_WIDTH / DISPLAY_HEIGHT) {\n drawHeight = DISPLAY_WIDTH / aspectRatio\n } else {\n drawWidth = DISPLAY_HEIGHT * aspectRatio\n }\n\n scale.x = drawWidth / img.width\n scale.y = drawHeight / img.height\n return { drawWidth, drawHeight }\n}\n\nconst drawImage = () => {\n if (ctx && canvas.value) {\n ctx.clearRect(0, 0, canvas.value.width, canvas.value.height)\n // center the image on the canvas\n const offsetX = (canvas.value.width - img.width * scale.x) / 2\n const offsetY = (canvas.value.height - img.height * scale.y) / 2\n ctx.drawImage(\n img,\n 0,\n 0,\n img.width,\n img.height,\n offsetX,\n offsetY,\n img.width * scale.x,\n img.height * scale.y,\n )\n drawOverlay()\n }\n}\n\nconst drawOverlay = () => {\n if (ctx && canvas.value) {\n ctx.save()\n\n // draw the dimming overlay\n ctx.beginPath()\n if (props.cropAsCircle) {\n ctx.arc(\n cropRect.value.x + cropRect.value.width / 2,\n cropRect.value.y + cropRect.value.height / 2,\n cropRect.value.width / 2,\n 0,\n Math.PI * 2,\n )\n } else {\n ctx.rect(\n cropRect.value.x,\n cropRect.value.y,\n cropRect.value.width,\n cropRect.value.height,\n )\n }\n ctx.rect(0, 0, canvas.value.width, canvas.value.height)\n ctx.clip('evenodd')\n ctx.fillStyle = 'rgba(0, 0, 0, 0.5)'\n ctx.fillRect(0, 0, canvas.value.width, canvas.value.height)\n\n // draw the crop area outline\n ctx.restore()\n ctx.save()\n ctx.strokeStyle = 'rgba(255, 255, 255, 0.8)'\n ctx.lineWidth = 1\n ctx.setLineDash([5, 5])\n // disable antialiasing for crisp outlines\n ctx.imageSmoothingEnabled = false\n\n if (props.cropAsCircle) {\n ctx.beginPath()\n ctx.arc(\n cropRect.value.x + cropRect.value.width / 2,\n cropRect.value.y + cropRect.value.height / 2,\n cropRect.value.width / 2,\n 0,\n Math.PI * 2,\n )\n ctx.stroke()\n } else {\n ctx.strokeRect(\n cropRect.value.x,\n cropRect.value.y,\n cropRect.value.width,\n cropRect.value.height,\n )\n }\n\n ctx.restore()\n }\n}\n\n// compute handle positions based on crop area shape\nconst handlePositions = computed<\n Record<EHandleName, { left: string; top: string }>\n>(() => {\n if (props.cropAsCircle) {\n // for circle, position handles at the circle's boundary points\n const centerX = cropRect.value.x + cropRect.value.width / 2\n const centerY = cropRect.value.y + cropRect.value.height / 2\n const radius = cropRect.value.width / 2\n\n return {\n 'top-left': {\n left: `${centerX - radius - 5}px`,\n top: `${centerY - radius - 5}px`,\n },\n top: { left: `${centerX - 5}px`, top: `${centerY - radius - 5}px` },\n 'top-right': {\n left: `${centerX + radius - 5}px`,\n top: `${centerY - radius - 5}px`,\n },\n right: { left: `${centerX + radius - 5}px`, top: `${centerY - 5}px` },\n 'bottom-right': {\n left: `${centerX + radius - 5}px`,\n top: `${centerY + radius - 5}px`,\n },\n bottom: { left: `${centerX - 5}px`, top: `${centerY + radius - 5}px` },\n 'bottom-left': {\n left: `${centerX - radius - 5}px`,\n top: `${centerY + radius - 5}px`,\n },\n left: { left: `${centerX - radius - 5}px`, top: `${centerY - 5}px` },\n }\n } else {\n // for rectangle, position handles at corners and edges\n return {\n 'top-left': {\n left: `${cropRect.value.x - 5}px`,\n top: `${cropRect.value.y - 5}px`,\n },\n top: {\n left: `${cropRect.value.x + cropRect.value.width / 2 - 5}px`,\n top: `${cropRect.value.y - 5}px`,\n },\n 'top-right': {\n left: `${cropRect.value.x + cropRect.value.width - 5}px`,\n top: `${cropRect.value.y - 5}px`,\n },\n right: {\n left: `${cropRect.value.x + cropRect.value.width - 5}px`,\n top: `${cropRect.value.y + cropRect.value.height / 2 - 5}px`,\n },\n 'bottom-right': {\n left: `${cropRect.value.x + cropRect.value.width - 5}px`,\n top: `${cropRect.value.y + cropRect.value.height - 5}px`,\n },\n bottom: {\n left: `${cropRect.value.x + cropRect.value.width / 2 - 5}px`,\n top: `${cropRect.value.y + cropRect.value.height - 5}px`,\n },\n 'bottom-left': {\n left: `${cropRect.value.x - 5}px`,\n top: `${cropRect.value.y + cropRect.value.height - 5}px`,\n },\n left: {\n left: `${cropRect.value.x - 5}px`,\n top: `${cropRect.value.y + cropRect.value.height / 2 - 5}px`,\n },\n }\n }\n})\n\nconst getClientCoordinates = (event: MouseEvent | TouchEvent) => {\n if ('touches' in event && event.touches.length > 0) {\n const touch = event.touches[0]\n return { clientX: touch.clientX, clientY: touch.clientY }\n } else if ('clientX' in event && 'clientY' in event) {\n return { clientX: event.clientX, clientY: event.clientY }\n }\n return { clientX: 0, clientY: 0 }\n}\n\nconst getCanvasPoint = (event: MouseEvent | TouchEvent) => {\n const canvasEl = canvas.value\n if (!canvasEl) return null\n const { clientX, clientY } = getClientCoordinates(event)\n const { left, top } = canvasEl.getBoundingClientRect()\n return { x: clientX - left, y: clientY - top }\n}\n\nconst onCanvasMouseDown = (event: MouseEvent | TouchEvent) => {\n event.preventDefault()\n const point = getCanvasPoint(event)\n if (!point) return\n const { x, y } = point\n if (isInCropArea(x, y)) {\n isDraggingCrop = true\n isDragging = true\n dragStart = { x: x - cropRect.value.x, y: y - cropRect.value.y }\n }\n}\n\nconst onMouseMove = (event: MouseEvent | TouchEvent) => {\n if (isDraggingCrop) {\n onDrag(event)\n } else if (isResizing) {\n onResize(event)\n }\n}\n\nconst onMouseUp = () => {\n if (isDraggingCrop) {\n endDrag()\n isDraggingCrop = false\n cropImage()\n }\n if (isResizing) {\n endResize()\n cropImage()\n }\n // reset drag state to ensure clean state\n isDragging = false\n isDraggingCrop = false\n}\n\nconst onDrag = (event: MouseEvent | TouchEvent) => {\n if (isDragging) {\n const point = getCanvasPoint(event)\n if (!point) return\n const { x, y } = point\n\n // use Math.floor to avoid off-by-one issues when dragging to top/left edges.\n cropRect.value.x = Math.floor(x - dragStart.x)\n cropRect.value.y = Math.floor(y - dragStart.y)\n // don't constrain during drag, let it move freely\n drawImage()\n }\n}\n\nconst endDrag = () => {\n if (isDragging) {\n // apply constraints only when dragging ends\n constrainCropRect()\n drawImage()\n isDragging = false\n }\n}\n\nconst startResize = (\n event: MouseEvent | TouchEvent,\n handleName: EHandleName,\n) => {\n event.preventDefault()\n const point = getCanvasPoint(event)\n if (!point) return\n isResizing = true\n currentHandle = handleName\n resizeStart = { x: point.x, y: point.y }\n initialCropRect = { ...cropRect.value }\n isShiftPressed = event instanceof MouseEvent && event.shiftKey\n}\n\nconst onResize = (event: MouseEvent | TouchEvent) => {\n if (!isResizing) return\n\n // in lockAspectRatio mode, perform a symmetric resize (keeping center fixed)\n if (props.lockAspectRatio && canvas.value) {\n const point = getCanvasPoint(event)\n if (!point) return\n const { x, y } = point\n const centerX = initialCropRect.x + initialCropRect.width / 2\n const centerY = initialCropRect.y + initialCropRect.height / 2\n\n if (props.cropAsCircle) {\n // for circle mode with locked aspect ratio, enforce square\n const halfSize = Math.max(Math.abs(x - centerX), Math.abs(y - centerY))\n const newSize = halfSize * 2\n cropRect.value = {\n x: centerX - halfSize,\n y: centerY - halfSize,\n width: newSize,\n height: newSize,\n }\n } else {\n // for rectangle mode with locked aspect ratio, maintain original aspect ratio\n const aspectRatio = initialCropRect.width / initialCropRect.height\n const dx = Math.abs(x - centerX)\n const newWidth = Math.max(dx * 2, 50)\n const newHeight = newWidth / aspectRatio\n cropRect.value = {\n x: centerX - newWidth / 2,\n y: centerY - newHeight / 2,\n width: newWidth,\n height: newHeight,\n }\n }\n // don't constrain during resize, let it grow beyond bounds\n drawImage()\n return\n }\n\n // non-locked (free) resizing\n const point = getCanvasPoint(event)\n if (!point) return\n const { x, y } = point\n const dx = x - resizeStart.x\n const dy = y - resizeStart.y\n\n isShiftPressed = event instanceof MouseEvent && event.shiftKey\n\n const newCropRect = { ...initialCropRect }\n\n switch (currentHandle) {\n case 'top-left':\n newCropRect.x += dx\n newCropRect.y += dy\n newCropRect.width -= dx\n newCropRect.height -= dy\n break\n case 'top':\n newCropRect.y += dy\n newCropRect.height -= dy\n break\n case 'top-right':\n newCropRect.y += dy\n newCropRect.width += dx\n newCropRect.height -= dy\n break\n case 'right':\n newCropRect.width += dx\n break\n case 'bottom-right':\n newCropRect.width += dx\n newCropRect.height += dy\n break\n case 'bottom':\n newCropRect.height += dy\n break\n case 'bottom-left':\n newCropRect.x += dx\n newCropRect.width -= dx\n newCropRect.height += dy\n break\n case 'left':\n newCropRect.x += dx\n newCropRect.width -= dx\n break\n }\n\n // prevent negative dimensions\n if (newCropRect.width < 50) newCropRect.width = 50\n if (newCropRect.height < 50) newCropRect.height = 50\n\n if (isShiftPressed && currentHandle) {\n const aspectRatio = initialCropRect.width / initialCropRect.height\n if (['left', 'right'].includes(currentHandle)) {\n newCropRect.height = newCropRect.width / aspectRatio\n if (currentHandle === 'left') {\n newCropRect.y =\n initialCropRect.y - (newCropRect.height - initialCropRect.height) / 2\n }\n } else if (['top', 'bottom'].includes(currentHandle)) {\n newCropRect.width = newCropRect.height * aspectRatio\n if (currentHandle === 'top') {\n newCropRect.x =\n initialCropRect.x - (newCropRect.width - initialCropRect.width) / 2\n }\n }\n }\n\n cropRect.value = newCropRect\n // don't constrain during resize, let it grow beyond bounds\n drawImage()\n}\n\nconst endResize = () => {\n if (isResizing) {\n // apply constraints only when resizing ends\n constrainCropRect()\n drawImage()\n isResizing = false\n currentHandle = null\n }\n}\n\nconst isInCropArea = (x: number, y: number) => {\n if (props.cropAsCircle) {\n const centerX = cropRect.value.x + cropRect.value.width / 2\n const centerY = cropRect.value.y + cropRect.value.height / 2\n const radius = cropRect.value.width / 2\n const dx = x - centerX\n const dy = y - centerY\n return dx * dx + dy * dy <= radius * radius\n } else {\n // add a small tolerance for better drag detection\n const tolerance = 2\n return (\n x >= cropRect.value.x - tolerance &&\n x <= cropRect.value.x + cropRect.value.width + tolerance &&\n y >= cropRect.value.y - tolerance &&\n y <= cropRect.value.y + cropRect.value.height + tolerance\n )\n }\n}\n\nconst constrainCropRect = () => {\n const maxX = canvas.value!.width\n const maxY = canvas.value!.height\n\n // ensure minimum size\n if (cropRect.value.width < 50) cropRect.value.width = 50\n if (cropRect.value.height < 50) cropRect.value.height = 50\n\n // if lockAspectRatio is true, enforce aspect ratio constraints\n if (props.lockAspectRatio) {\n if (props.cropAsCircle) {\n // for circle mode with locked aspect ratio, enforce square\n cropRect.value.height = cropRect.value.width\n } else {\n // for rectangle mode with locked aspect ratio, maintain original aspect ratio\n const aspectRatio = initialCropRect.width / initialCropRect.height\n cropRect.value.height = cropRect.value.width / aspectRatio\n }\n } else if (isShiftPressed) {\n // when shift is pressed, maintain aspect ratio temporarily\n const aspectRatio = initialCropRect.width / initialCropRect.height\n cropRect.value.height = cropRect.value.width / aspectRatio\n }\n\n // for circle or locked aspect ratio, maintain the aspect ratio when constraining\n if (props.cropAsCircle || props.lockAspectRatio) {\n const aspectRatio = cropRect.value.width / cropRect.value.height\n\n // if the crop area is too large, scale it down while maintaining aspect ratio\n if (cropRect.value.width > maxX || cropRect.value.height > maxY) {\n if (cropRect.value.width > cropRect.value.height) {\n cropRect.value.width = maxX\n cropRect.value.height = maxX / aspectRatio\n } else {\n cropRect.value.height = maxY\n cropRect.value.width = maxY * aspectRatio\n }\n }\n\n // ensure it stays within bounds, only move if it's actually outside\n if (cropRect.value.x < 0) cropRect.value.x = 0\n if (cropRect.value.y < 0) cropRect.value.y = 0\n if (cropRect.value.x + cropRect.value.width > maxX) {\n cropRect.value.x = maxX - cropRect.value.width\n }\n if (cropRect.value.y + cropRect.value.height > maxY) {\n cropRect.value.y = maxY - cropRect.value.height\n }\n } else {\n // for free resize, use the original logic\n // constrain position to keep crop area within canvas bounds\n if (cropRect.value.x < 0) cropRect.value.x = 0\n if (cropRect.value.y < 0) cropRect.value.y = 0\n\n // if crop area is larger than canvas, center it\n if (cropRect.value.width > maxX) {\n cropRect.value.width = maxX\n cropRect.value.x = 0\n }\n if (cropRect.value.height > maxY) {\n cropRect.value.height = maxY\n cropRect.value.y = 0\n }\n\n // ensure crop area doesn't extend beyond canvas bounds\n if (cropRect.value.x + cropRect.value.width > maxX) {\n cropRect.value.x = maxX - cropRect.value.width\n }\n if (cropRect.value.y + cropRect.value.height > maxY) {\n cropRect.value.y = maxY - cropRect.value.height\n }\n }\n}\n\nconst cropImage = () => {\n if (canvas.value && ctx) {\n const offsetX = (canvas.value.width - img.width * scale.x) / 2\n const offsetY = (canvas.value.height - img.height * scale.y) / 2\n\n const sx = (cropRect.value.x - offsetX) / scale.x\n const sy = (cropRect.value.y - offsetY) / scale.y\n const sWidth = cropRect.value.width / scale.x\n const sHeight = cropRect.value.height / scale.y\n\n const geometry = {\n x: Math.round(sx),\n y: Math.round(sy),\n width: Math.round(sWidth),\n height: Math.round(sHeight),\n }\n\n // clamp the crop area to the actual image bounds\n const clampedSX = Math.max(0, Math.min(geometry.x, img.width))\n const clampedSY = Math.max(0, Math.min(geometry.y, img.height))\n const clampedSWidth = Math.min(geometry.width, img.width - clampedSX)\n const clampedSHeight = Math.min(geometry.height, img.height - clampedSY)\n\n const croppedCanvas = document.createElement('canvas')\n croppedCanvas.width = clampedSWidth\n croppedCanvas.height = clampedSHeight\n const croppedCtx = croppedCanvas.getContext('2d')\n if (croppedCtx) {\n croppedCtx.drawImage(\n img,\n clampedSX,\n clampedSY,\n clampedSWidth,\n clampedSHeight,\n 0,\n 0,\n clampedSWidth,\n clampedSHeight,\n )\n\n if (props.cropAsCircle && props.outputAsCircle) {\n croppedCtx.globalCompositeOperation = 'destination-in'\n croppedCtx.beginPath()\n croppedCtx.arc(\n clampedSWidth / 2,\n clampedSHeight / 2,\n clampedSWidth / 2,\n 0,\n Math.PI * 2,\n )\n croppedCtx.closePath()\n croppedCtx.fill()\n croppedCtx.globalCompositeOperation = 'source-over'\n }\n\n // expose the cropped image via the `crop` event\n croppedCanvas.toBlob(\n (blob) => {\n if (blob) {\n const oldPreviewUrl = croppedImageUrl.value\n if (oldPreviewUrl) {\n URL.revokeObjectURL(oldPreviewUrl)\n }\n croppedImageUrl.value = URL.createObjectURL(blob)\n cropGeometry.value = geometry\n emit('crop', { blob, geometry })\n }\n },\n 'image/jpeg',\n 0.8,\n )\n }\n }\n}\n\nwatch(\n () => props,\n () => {\n cropImage()\n },\n { deep: true },\n)\n</script>\n\n<style lang=\"scss\" scoped>\n$handle-size: 10px;\n$handle-offset: -7px;\n$border-color: black;\n$background-color: white;\n\n.nb-image-cropper {\n position: relative;\n user-select: none;\n display: inline-block;\n max-width: 100%;\n height: auto;\n overflow: hidden;\n\n .canvas-container {\n position: relative;\n display: inline-block;\n width: 100%;\n height: auto;\n\n canvas {\n display: block;\n max-width: 100%;\n height: auto;\n }\n }\n\n .resize-handle {\n position: absolute;\n width: 10px;\n height: 10px;\n background: white;\n border: 1px solid black;\n z-index: 1;\n\n &.top-left {\n cursor: nwse-resize;\n }\n\n &.top {\n cursor: ns-resize;\n }\n\n &.top-right {\n cursor: nesw-resize;\n }\n\n &.right {\n cursor: ew-resize;\n }\n\n &.bottom-right {\n cursor: nwse-resize;\n }\n\n &.bottom {\n cursor: ns-resize;\n }\n\n &.bottom-left {\n cursor: nesw-resize;\n }\n\n &.left {\n cursor: ew-resize;\n }\n }\n\n .cropped-image-preview {\n position: absolute;\n right: calc(var(--nb-base-unit, 8px) * 2);\n bottom: calc(var(--nb-base-unit, 8px) * 2);\n border-radius: var(--nb-border-radius-sm, 6px);\n overflow: hidden;\n height: calc(var(--nb-base-unit, 8px) * 14);\n margin-top: 20px;\n border: dotted 1px var(--nb-c-component-border, #e0e0e0);\n background: var(--nb-c-backdrop, #fff);\n user-select: none;\n pointer-events: none;\n ul {\n min-width: calc(var(--nb-base-unit, 8px) * 9);\n background: black;\n color: white;\n font-size: var(--nb-font-size-10, 10px);\n padding: calc(var(--nb-base-unit, 8px) / 2);\n line-height: var(--nb-font-size-14, 14px);\n }\n img {\n width: 100%;\n height: 100%;\n object-fit: contain;\n object-position: center;\n }\n }\n}\n</style>\n","<template>\n <div :class=\"classes\">\n <div :class=\"togglerClasses\" @click=\"toggleCollapse\" />\n <div class=\"content\" :class=\"{ editable: editable, editor: inputActive }\">\n <div class=\"title\" :class=\"{ editor: inputActive }\">\n {{ title }}\n <span v-if=\"isNode(localModel)\" class=\"type\">\n {{\n isArray(localModel)\n ? `[ ${localModel.length} items ]`\n : `{ ${localModel && typeof localModel === 'object' ? Object.keys(localModel).length : 0} properties }`\n }}\n </span>\n </div>\n <div v-if=\"!isNode(localModel)\" class=\"data\">\n <span\n v-if=\"!isBoolean(localModel)\"\n v-show=\"!inputActive\"\n :class=\"{ value: true, 'value--null': isNull(localModel) }\"\n @dblclick=\"() => (inputActive = editable)\"\n >\n {{ isNull(localModel) ? nullString : localModel }}\n </span>\n <input\n v-if=\"!isBoolean(localModel) && inputActive\"\n v-model=\"localModel\"\n @keyup.enter=\"() => (inputActive = false)\"\n @blur=\"() => (inputActive = false)\"\n />\n <span\n v-if=\"isBoolean(localModel)\"\n class=\"boolean\"\n @click=\"() => (localModel = !localModel)\"\n >{{ !localModel ? i18n.strFalse : i18n.strTrue }}</span\n >\n <div class=\"controls\" />\n </div>\n <div v-if=\"localModel && isNode(localModel)\">\n <NbJsonTree\n v-for=\"(_, indexKey) in localModel\"\n :key=\"indexKey\"\n v-model=\"asIndexable(localModel)[indexKey]\"\n :title=\"`${indexKey}`\"\n :class=\"{ colapsed: colapsed }\"\n :loaded=\"true\"\n :root=\"false\"\n :editable=\"editable\"\n />\n </div>\n </div>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { ref, computed } from 'vue'\nimport type { IJsonTreeProps, TJsonValue } from './JsonTree.d'\n\nconst nullString = 'null'\n\nconst props = withDefaults(defineProps<IJsonTreeProps>(), {\n title: null,\n modelValue: null,\n root: true,\n editable: false,\n startCollapsed: false,\n})\n\nconst emit = defineEmits(['update:modelValue'])\n\nconst localModel = computed({\n get() {\n return props.modelValue\n },\n set(value) {\n if (props.editable) {\n emit('update:modelValue', value)\n }\n },\n})\n\n// internal state\nconst colapsed = ref(props.startCollapsed)\nconst inputActive = ref(false)\nconst i18n = ref({\n strBoolean: 'boolean',\n strString: 'string',\n strNumber: 'number',\n strObject: 'object',\n strArray: 'array',\n strNull: 'null',\n strFalse: 'false',\n strTrue: 'true',\n})\n\n// computed\nconst classes = computed(() => {\n return {\n 'nb-json-tree': true,\n node: isNode(localModel.value),\n leaf: !isNode(localModel.value),\n root: props.root,\n }\n})\n\nconst togglerClasses = computed(() => {\n return {\n toggler: true,\n node: isNode(localModel.value),\n colapse: !colapsed.value,\n expand: colapsed.value,\n }\n})\n\n// methods\nconst toggleCollapse = () => (colapsed.value = !colapsed.value)\nconst isNode = (value: TJsonValue) =>\n value instanceof Object || Array.isArray(value)\nconst isArray = (value: TJsonValue) => Array.isArray(value)\nconst isNull = (value: TJsonValue) => value === null\nconst isBoolean = (value: TJsonValue): value is boolean =>\n typeof value === 'boolean'\nconst asIndexable = (v: TJsonValue): Record<string | number, TJsonValue> =>\n (v as Record<string | number, TJsonValue>) ?? {}\n</script>\n\n<style lang=\"scss\">\n:root {\n --nb-json-tree-sprite: url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4KPHN2ZyB2aWV3Qm94PSIwIDAgMTMyIDExMiIgd2lkdGg9IjEzMnB4IiBoZWlnaHQ9IjExMnB4IiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPgogIDxnPgogICAgPHRpdGxlPm1pbnVzPC90aXRsZT4KICAgIDxyZWN0IHN0eWxlPSJzdHJva2U6IHJnYig2MCwgNjAsIDYwKTsgc3Ryb2tlLWxpbmVjYXA6IHJvdW5kOyBzdHJva2UtbGluZWpvaW46IHJvdW5kIiB4PSI0IiB5PSI5IiB3aWR0aD0iMTIiIGhlaWdodD0iMTIiIHJ4PSIxIiByeT0iMSIvPgogICAgPGxpbmUgc3R5bGU9InN0cm9rZS13aWR0aDogMnB4OyBzdHJva2UtbGluZWNhcDogcm91bmQ7IHN0cm9rZTogcmdiKDE1NiwgMTU2LCAxNTYpOyIgeDE9IjgiIHkxPSIxNSIgeDI9IjEyIiB5Mj0iMTUiPgogICAgICA8dGl0bGU+bWludXM8L3RpdGxlPgogICAgPC9saW5lPgogIDwvZz4KICA8Zz4KICAgIDx0aXRsZT5wbHVzPC90aXRsZT4KICAgIDxyZWN0IHN0eWxlPSJmaWxsOiAjM0QzRDNEOyBzdHJva2U6ICMzRDNEM0Q7IHN0cm9rZS1saW5lY2FwOiByb3VuZDsgc3Ryb2tlLWxpbmVqb2luOiByb3VuZCIgeD0iMzciIHk9IjkiIHdpZHRoPSIxMiIgaGVpZ2h0PSIxMiIgcng9IjEiIHJ5PSIxIi8+CiAgICA8Zz4KICAgICAgPHRpdGxlPnBsdXM8L3RpdGxlPgogICAgICA8bGluZSBzdHlsZT0ic3Ryb2tlLXdpZHRoOiAycHg7IHN0cm9rZS1saW5lY2FwOiByb3VuZDsgZmlsbDogIzNEM0QzRDsgc3Ryb2tlOiAjRUJFQkVCOyIgeDE9IjQwIiB5MT0iMTUiIHgyPSI0NiIgeTI9IjE1Ij4KICAgICAgICA8dGl0bGU+bWludXM8L3RpdGxlPgogICAgICA8L2xpbmU+CiAgICAgIDxsaW5lIHN0eWxlPSJzdHJva2Utd2lkdGg6IDJweDsgc3Ryb2tlLWxpbmVjYXA6IHJvdW5kOyBmaWxsOiAjM0QzRDNEOyBzdHJva2U6ICNFQkVCRUI7IiB4MT0iNDMiIHkxPSIxMiIgeDI9IjQzIiB5Mj0iMTgiPgogICAgICAgIDx0aXRsZT5taW51czwvdGl0bGU+CiAgICAgIDwvbGluZT4KICAgIDwvZz4KICA8L2c+CiAgPGxpbmUgc3R5bGU9InN0cm9rZS1kYXNoYXJyYXk6IDE7IHN0cm9rZS1saW5lam9pbjogcm91bmQ7IHN0cm9rZTogcmdiKDI1NSwgMjU1LCAyNTUpOyIgeDE9IjE3IiB5MT0iMTUiIHgyPSIzMSIgeTI9IjE1Ii8+CiAgPGxpbmUgc3R5bGU9InN0cm9rZS1kYXNoYXJyYXk6IDE7IHN0cm9rZS1saW5lam9pbjogcm91bmQ7IHN0cm9rZTogcmdiKDI1NSwgMjU1LCAyNTUpOyIgeDE9IjUwIiB5MT0iMTUiIHgyPSI2NSIgeTI9IjE1Ii8+CiAgPGxpbmUgc3R5bGU9InN0cm9rZS1kYXNoYXJyYXk6IDE7IHN0cm9rZS1saW5lam9pbjogcm91bmQ7IHN0cm9rZTogcmdiKDI1NSwgMjU1LCAyNTUpOyIgeDE9Ijc3IiB5MT0iMTUiIHgyPSI5OSIgeTI9IjE1Ii8+CiAgPGxpbmUgc3R5bGU9InN0cm9rZS1kYXNoYXJyYXk6IDE7IHN0cm9rZS1saW5lam9pbjogcm91bmQ7IHN0cm9rZTogcmdiKDI1NSwgMjU1LCAyNTUpOyIgeDE9IjEwOC41IiB5MT0iMC41IiB4Mj0iMTA4LjUiIHkyPSIxMTEuNSIvPgo8L3N2Zz4=');\n}\n.nb-json-tree {\n display: flex;\n font-family: var(--nb-font-family-sans);\n font-weight: var(--nb-front-weight-regular);\n font-size: var(--nb-font-size-14);\n text-align: left;\n line-height: 24px;\n background: var(--nb-json-tree-sprite);\n background-color: transparent;\n background-repeat: no-repeat;\n // color: var(--nb-c-surface);\n &:not(.root) {\n background-repeat: repeat-y;\n background-position: -99px 0px;\n }\n\n &.root,\n &:last-child {\n background-repeat: no-repeat;\n background-position: -99px -96px;\n }\n\n .toggler {\n display: block;\n width: 24px;\n height: 24px;\n flex-shrink: 0;\n cursor: pointer;\n background-position: -66px 0px;\n background-image: var(--nb-json-tree-sprite);\n background-color: transparent;\n background-repeat: no-repeat;\n }\n\n &.colapsed {\n display: none;\n }\n\n .content {\n display: flex;\n box-sizing: border-box;\n padding: 1px 5px;\n width: 100%;\n .title {\n font-weight: 500;\n }\n }\n\n &.node {\n .toggler.node {\n &.colapse {\n background-position: 0px 0px;\n }\n &.expand {\n background-position: -33px 0px;\n }\n }\n .content {\n flex-direction: column;\n\n .title {\n display: flex;\n flex-direction: row;\n flex-shrink: 0;\n span {\n font-family: var(--nb-font-family-mono);\n font-weight: var(--nb-json-tree-sprite);\n margin-left: 5px;\n color: var(--nb-c-primary);\n text-transform: capitalize;\n }\n }\n }\n }\n\n &.leaf {\n .content {\n flex-direction: row;\n border-bottom: solid 1px transparent;\n\n .title {\n cursor: pointer;\n &:after {\n content: ': ';\n margin-right: 5px;\n }\n }\n\n .data {\n display: flex;\n flex-grow: 1;\n overflow-x: hidden;\n position: relative;\n span {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow-x: hidden;\n width: auto;\n &.value--null {\n color: var(--nb-c-text-faded);\n }\n }\n input {\n border: 0;\n outline: 0;\n padding: 0;\n font-size: 14px;\n width: 100%;\n background: transparent;\n }\n .boolean {\n cursor: pointer;\n }\n }\n\n &.editable {\n .data {\n span {\n &.value {\n cursor: text;\n }\n &.boolean {\n cursor: pointer;\n }\n }\n }\n &:hover {\n border-bottom: dotted 1px var(--nb-c-primary);\n }\n }\n\n &.editor {\n background: var(--nb-c-panel-background);\n border-bottom: solid 1px var(--nb-c-component-border);\n }\n }\n }\n}\n</style>\n","<template>\n <div :class=\"classes\">\n <div :class=\"togglerClasses\" @click=\"toggleCollapse\" />\n <div class=\"content\" :class=\"{ editable: editable, editor: inputActive }\">\n <div class=\"title\" :class=\"{ editor: inputActive }\">\n {{ title }}\n <span v-if=\"isNode(localModel)\" class=\"type\">\n {{\n isArray(localModel)\n ? `[ ${localModel.length} items ]`\n : `{ ${localModel && typeof localModel === 'object' ? Object.keys(localModel).length : 0} properties }`\n }}\n </span>\n </div>\n <div v-if=\"!isNode(localModel)\" class=\"data\">\n <span\n v-if=\"!isBoolean(localModel)\"\n v-show=\"!inputActive\"\n :class=\"{ value: true, 'value--null': isNull(localModel) }\"\n @dblclick=\"() => (inputActive = editable)\"\n >\n {{ isNull(localModel) ? nullString : localModel }}\n </span>\n <input\n v-if=\"!isBoolean(localModel) && inputActive\"\n v-model=\"localModel\"\n @keyup.enter=\"() => (inputActive = false)\"\n @blur=\"() => (inputActive = false)\"\n />\n <span\n v-if=\"isBoolean(localModel)\"\n class=\"boolean\"\n @click=\"() => (localModel = !localModel)\"\n >{{ !localModel ? i18n.strFalse : i18n.strTrue }}</span\n >\n <div class=\"controls\" />\n </div>\n <div v-if=\"localModel && isNode(localModel)\">\n <NbJsonTree\n v-for=\"(_, indexKey) in localModel\"\n :key=\"indexKey\"\n v-model=\"asIndexable(localModel)[indexKey]\"\n :title=\"`${indexKey}`\"\n :class=\"{ colapsed: colapsed }\"\n :loaded=\"true\"\n :root=\"false\"\n :editable=\"editable\"\n />\n </div>\n </div>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { ref, computed } from 'vue'\nimport type { IJsonTreeProps, TJsonValue } from './JsonTree.d'\n\nconst nullString = 'null'\n\nconst props = withDefaults(defineProps<IJsonTreeProps>(), {\n title: null,\n modelValue: null,\n root: true,\n editable: false,\n startCollapsed: false,\n})\n\nconst emit = defineEmits(['update:modelValue'])\n\nconst localModel = computed({\n get() {\n return props.modelValue\n },\n set(value) {\n if (props.editable) {\n emit('update:modelValue', value)\n }\n },\n})\n\n// internal state\nconst colapsed = ref(props.startCollapsed)\nconst inputActive = ref(false)\nconst i18n = ref({\n strBoolean: 'boolean',\n strString: 'string',\n strNumber: 'number',\n strObject: 'object',\n strArray: 'array',\n strNull: 'null',\n strFalse: 'false',\n strTrue: 'true',\n})\n\n// computed\nconst classes = computed(() => {\n return {\n 'nb-json-tree': true,\n node: isNode(localModel.value),\n leaf: !isNode(localModel.value),\n root: props.root,\n }\n})\n\nconst togglerClasses = computed(() => {\n return {\n toggler: true,\n node: isNode(localModel.value),\n colapse: !colapsed.value,\n expand: colapsed.value,\n }\n})\n\n// methods\nconst toggleCollapse = () => (colapsed.value = !colapsed.value)\nconst isNode = (value: TJsonValue) =>\n value instanceof Object || Array.isArray(value)\nconst isArray = (value: TJsonValue) => Array.isArray(value)\nconst isNull = (value: TJsonValue) => value === null\nconst isBoolean = (value: TJsonValue): value is boolean =>\n typeof value === 'boolean'\nconst asIndexable = (v: TJsonValue): Record<string | number, TJsonValue> =>\n (v as Record<string | number, TJsonValue>) ?? {}\n</script>\n\n<style lang=\"scss\">\n:root {\n --nb-json-tree-sprite: url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4KPHN2ZyB2aWV3Qm94PSIwIDAgMTMyIDExMiIgd2lkdGg9IjEzMnB4IiBoZWlnaHQ9IjExMnB4IiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPgogIDxnPgogICAgPHRpdGxlPm1pbnVzPC90aXRsZT4KICAgIDxyZWN0IHN0eWxlPSJzdHJva2U6IHJnYig2MCwgNjAsIDYwKTsgc3Ryb2tlLWxpbmVjYXA6IHJvdW5kOyBzdHJva2UtbGluZWpvaW46IHJvdW5kIiB4PSI0IiB5PSI5IiB3aWR0aD0iMTIiIGhlaWdodD0iMTIiIHJ4PSIxIiByeT0iMSIvPgogICAgPGxpbmUgc3R5bGU9InN0cm9rZS13aWR0aDogMnB4OyBzdHJva2UtbGluZWNhcDogcm91bmQ7IHN0cm9rZTogcmdiKDE1NiwgMTU2LCAxNTYpOyIgeDE9IjgiIHkxPSIxNSIgeDI9IjEyIiB5Mj0iMTUiPgogICAgICA8dGl0bGU+bWludXM8L3RpdGxlPgogICAgPC9saW5lPgogIDwvZz4KICA8Zz4KICAgIDx0aXRsZT5wbHVzPC90aXRsZT4KICAgIDxyZWN0IHN0eWxlPSJmaWxsOiAjM0QzRDNEOyBzdHJva2U6ICMzRDNEM0Q7IHN0cm9rZS1saW5lY2FwOiByb3VuZDsgc3Ryb2tlLWxpbmVqb2luOiByb3VuZCIgeD0iMzciIHk9IjkiIHdpZHRoPSIxMiIgaGVpZ2h0PSIxMiIgcng9IjEiIHJ5PSIxIi8+CiAgICA8Zz4KICAgICAgPHRpdGxlPnBsdXM8L3RpdGxlPgogICAgICA8bGluZSBzdHlsZT0ic3Ryb2tlLXdpZHRoOiAycHg7IHN0cm9rZS1saW5lY2FwOiByb3VuZDsgZmlsbDogIzNEM0QzRDsgc3Ryb2tlOiAjRUJFQkVCOyIgeDE9IjQwIiB5MT0iMTUiIHgyPSI0NiIgeTI9IjE1Ij4KICAgICAgICA8dGl0bGU+bWludXM8L3RpdGxlPgogICAgICA8L2xpbmU+CiAgICAgIDxsaW5lIHN0eWxlPSJzdHJva2Utd2lkdGg6IDJweDsgc3Ryb2tlLWxpbmVjYXA6IHJvdW5kOyBmaWxsOiAjM0QzRDNEOyBzdHJva2U6ICNFQkVCRUI7IiB4MT0iNDMiIHkxPSIxMiIgeDI9IjQzIiB5Mj0iMTgiPgogICAgICAgIDx0aXRsZT5taW51czwvdGl0bGU+CiAgICAgIDwvbGluZT4KICAgIDwvZz4KICA8L2c+CiAgPGxpbmUgc3R5bGU9InN0cm9rZS1kYXNoYXJyYXk6IDE7IHN0cm9rZS1saW5lam9pbjogcm91bmQ7IHN0cm9rZTogcmdiKDI1NSwgMjU1LCAyNTUpOyIgeDE9IjE3IiB5MT0iMTUiIHgyPSIzMSIgeTI9IjE1Ii8+CiAgPGxpbmUgc3R5bGU9InN0cm9rZS1kYXNoYXJyYXk6IDE7IHN0cm9rZS1saW5lam9pbjogcm91bmQ7IHN0cm9rZTogcmdiKDI1NSwgMjU1LCAyNTUpOyIgeDE9IjUwIiB5MT0iMTUiIHgyPSI2NSIgeTI9IjE1Ii8+CiAgPGxpbmUgc3R5bGU9InN0cm9rZS1kYXNoYXJyYXk6IDE7IHN0cm9rZS1saW5lam9pbjogcm91bmQ7IHN0cm9rZTogcmdiKDI1NSwgMjU1LCAyNTUpOyIgeDE9Ijc3IiB5MT0iMTUiIHgyPSI5OSIgeTI9IjE1Ii8+CiAgPGxpbmUgc3R5bGU9InN0cm9rZS1kYXNoYXJyYXk6IDE7IHN0cm9rZS1saW5lam9pbjogcm91bmQ7IHN0cm9rZTogcmdiKDI1NSwgMjU1LCAyNTUpOyIgeDE9IjEwOC41IiB5MT0iMC41IiB4Mj0iMTA4LjUiIHkyPSIxMTEuNSIvPgo8L3N2Zz4=');\n}\n.nb-json-tree {\n display: flex;\n font-family: var(--nb-font-family-sans);\n font-weight: var(--nb-front-weight-regular);\n font-size: var(--nb-font-size-14);\n text-align: left;\n line-height: 24px;\n background: var(--nb-json-tree-sprite);\n background-color: transparent;\n background-repeat: no-repeat;\n // color: var(--nb-c-surface);\n &:not(.root) {\n background-repeat: repeat-y;\n background-position: -99px 0px;\n }\n\n &.root,\n &:last-child {\n background-repeat: no-repeat;\n background-position: -99px -96px;\n }\n\n .toggler {\n display: block;\n width: 24px;\n height: 24px;\n flex-shrink: 0;\n cursor: pointer;\n background-position: -66px 0px;\n background-image: var(--nb-json-tree-sprite);\n background-color: transparent;\n background-repeat: no-repeat;\n }\n\n &.colapsed {\n display: none;\n }\n\n .content {\n display: flex;\n box-sizing: border-box;\n padding: 1px 5px;\n width: 100%;\n .title {\n font-weight: 500;\n }\n }\n\n &.node {\n .toggler.node {\n &.colapse {\n background-position: 0px 0px;\n }\n &.expand {\n background-position: -33px 0px;\n }\n }\n .content {\n flex-direction: column;\n\n .title {\n display: flex;\n flex-direction: row;\n flex-shrink: 0;\n span {\n font-family: var(--nb-font-family-mono);\n font-weight: var(--nb-json-tree-sprite);\n margin-left: 5px;\n color: var(--nb-c-primary);\n text-transform: capitalize;\n }\n }\n }\n }\n\n &.leaf {\n .content {\n flex-direction: row;\n border-bottom: solid 1px transparent;\n\n .title {\n cursor: pointer;\n &:after {\n content: ': ';\n margin-right: 5px;\n }\n }\n\n .data {\n display: flex;\n flex-grow: 1;\n overflow-x: hidden;\n position: relative;\n span {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow-x: hidden;\n width: auto;\n &.value--null {\n color: var(--nb-c-text-faded);\n }\n }\n input {\n border: 0;\n outline: 0;\n padding: 0;\n font-size: 14px;\n width: 100%;\n background: transparent;\n }\n .boolean {\n cursor: pointer;\n }\n }\n\n &.editable {\n .data {\n span {\n &.value {\n cursor: text;\n }\n &.boolean {\n cursor: pointer;\n }\n }\n }\n &:hover {\n border-bottom: dotted 1px var(--nb-c-primary);\n }\n }\n\n &.editor {\n background: var(--nb-c-panel-background);\n border-bottom: solid 1px var(--nb-c-component-border);\n }\n }\n }\n}\n</style>\n","enum ELabelSize {\n Small = 'sm',\n Medium = 'md',\n}\n\ninterface ILabelProps {\n htmlFor?: string\n required?: boolean\n disabled?: boolean\n // Visual size of the label text\n size?: ELabelSize\n}\n\nexport { ELabelSize, ILabelProps }\n","<template>\n <label\n :for=\"htmlFor\"\n :class=\"[\n 'nb-label',\n `nb-label--${size}`,\n { 'nb-label--required': required, 'nb-label--disabled': disabled },\n ]\"\n >\n <slot />\n <span v-if=\"required\" class=\"nb-label__asterisk\" aria-hidden=\"true\">*</span>\n <!-- Optional trailing content: badges, status pills, extra info -->\n <slot name=\"suffix\" />\n </label>\n</template>\n\n<script setup lang=\"ts\">\nimport { ELabelSize, ILabelProps } from './Label.d'\n\nwithDefaults(defineProps<ILabelProps>(), {\n htmlFor: undefined,\n required: false,\n disabled: false,\n size: ELabelSize.Medium,\n})\n</script>\n\n<style scoped lang=\"scss\">\n.nb-label {\n display: inline-flex;\n align-items: center;\n gap: 4px;\n font-family: var(--nb-font-family-sans);\n font-weight: 500;\n color: var(--nb-c-text-muted);\n cursor: default;\n user-select: none;\n\n &--sm {\n font-size: var(--nb-font-size-12);\n letter-spacing: 0.02em;\n }\n &--md {\n font-size: var(--nb-font-size-12);\n }\n\n &--disabled {\n opacity: 0.45;\n }\n\n &__asterisk {\n color: var(--nb-c-danger);\n font-size: 1em;\n line-height: 1;\n }\n}\n</style>\n","<template>\n <label\n :for=\"htmlFor\"\n :class=\"[\n 'nb-label',\n `nb-label--${size}`,\n { 'nb-label--required': required, 'nb-label--disabled': disabled },\n ]\"\n >\n <slot />\n <span v-if=\"required\" class=\"nb-label__asterisk\" aria-hidden=\"true\">*</span>\n <!-- Optional trailing content: badges, status pills, extra info -->\n <slot name=\"suffix\" />\n </label>\n</template>\n\n<script setup lang=\"ts\">\nimport { ELabelSize, ILabelProps } from './Label.d'\n\nwithDefaults(defineProps<ILabelProps>(), {\n htmlFor: undefined,\n required: false,\n disabled: false,\n size: ELabelSize.Medium,\n})\n</script>\n\n<style scoped lang=\"scss\">\n.nb-label {\n display: inline-flex;\n align-items: center;\n gap: 4px;\n font-family: var(--nb-font-family-sans);\n font-weight: 500;\n color: var(--nb-c-text-muted);\n cursor: default;\n user-select: none;\n\n &--sm {\n font-size: var(--nb-font-size-12);\n letter-spacing: 0.02em;\n }\n &--md {\n font-size: var(--nb-font-size-12);\n }\n\n &--disabled {\n opacity: 0.45;\n }\n\n &__asterisk {\n color: var(--nb-c-danger);\n font-size: 1em;\n line-height: 1;\n }\n}\n</style>\n","enum EMessageVariant {\n Error = 'error',\n Warning = 'warning',\n Helper = 'helper',\n}\n\ninterface IMessageProps {\n variant?: `${EMessageVariant}`\n /**\n * Icon-only mode: hides the text and shows only an icon.\n * On hover, the message text appears via a CSS tooltip.\n * Used in the TextInput `fluid` variant.\n */\n iconOnly?: boolean\n}\n\nexport { EMessageVariant, IMessageProps }\n","<template>\n <div\n :class=\"[\n 'nb-message',\n `nb-message--${props.variant}`,\n { 'nb-message--icon-only': props.iconOnly },\n ]\"\n role=\"status\"\n :aria-live=\"props.variant === 'error' ? 'assertive' : 'polite'\"\n >\n <NbIcon\n :name=\"iconMap[props.variant]\"\n :size=\"14\"\n class=\"nb-message__icon\"\n />\n <span v-if=\"!props.iconOnly\" class=\"nb-message__text\"><slot /></span>\n <!-- CSS-powered tooltip shown on hover in icon-only mode -->\n <span v-if=\"props.iconOnly\" class=\"nb-message__tooltip\" aria-hidden=\"true\"\n ><slot\n /></span>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { EMessageVariant, IMessageProps } from './Message.d'\n\nconst props = withDefaults(defineProps<IMessageProps>(), {\n variant: EMessageVariant.Helper,\n iconOnly: false,\n})\n\nconst iconMap = {\n error: 'warning-circle',\n warning: 'warning',\n helper: 'info',\n} as const\n</script>\n\n<style scoped lang=\"scss\">\n.nb-message {\n display: inline-flex;\n align-items: center;\n gap: calc(var(--nb-base-unit) / 2);\n font-family: var(--nb-font-family-sans);\n font-size: var(--nb-font-size-12);\n line-height: 1.4;\n\n &--error {\n color: var(--nb-c-danger);\n }\n &--warning {\n color: var(--nb-c-warning);\n }\n &--helper {\n color: var(--nb-c-text-subtle);\n }\n\n &__icon {\n flex-shrink: 0;\n }\n\n &__text {\n flex: 1;\n }\n\n /* Icon-only: hide text, show CSS tooltip on hover */\n &--icon-only {\n position: relative;\n cursor: default;\n\n .nb-message__text {\n display: none;\n }\n\n &:hover .nb-message__tooltip,\n &:focus-within .nb-message__tooltip {\n opacity: 1;\n visibility: visible;\n transform: translateX(-50%) translateY(0);\n }\n }\n\n &__tooltip {\n position: absolute;\n bottom: calc(100% + 8px);\n left: 50%;\n transform: translateX(-50%) translateY(4px);\n background: var(--nb-c-plain-black-800, #1f2937);\n color: #fff;\n padding: 6px 10px;\n border-radius: 4px;\n font-size: 11px;\n font-weight: 400;\n white-space: nowrap;\n max-width: 220px;\n text-overflow: ellipsis;\n overflow: hidden;\n opacity: 0;\n visibility: hidden;\n transform: translateX(-50%) translateY(4px);\n transition:\n opacity 0.15s ease,\n transform 0.15s ease,\n visibility 0.15s ease;\n pointer-events: none;\n z-index: var(--nb-zindex-tooltip, 401);\n\n &::after {\n content: '';\n position: absolute;\n top: 100%;\n left: 50%;\n transform: translateX(-50%);\n border: 5px solid transparent;\n border-top-color: var(--nb-c-plain-black-800, #1f2937);\n }\n }\n}\n</style>\n","<template>\n <div\n :class=\"[\n 'nb-message',\n `nb-message--${props.variant}`,\n { 'nb-message--icon-only': props.iconOnly },\n ]\"\n role=\"status\"\n :aria-live=\"props.variant === 'error' ? 'assertive' : 'polite'\"\n >\n <NbIcon\n :name=\"iconMap[props.variant]\"\n :size=\"14\"\n class=\"nb-message__icon\"\n />\n <span v-if=\"!props.iconOnly\" class=\"nb-message__text\"><slot /></span>\n <!-- CSS-powered tooltip shown on hover in icon-only mode -->\n <span v-if=\"props.iconOnly\" class=\"nb-message__tooltip\" aria-hidden=\"true\"\n ><slot\n /></span>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { EMessageVariant, IMessageProps } from './Message.d'\n\nconst props = withDefaults(defineProps<IMessageProps>(), {\n variant: EMessageVariant.Helper,\n iconOnly: false,\n})\n\nconst iconMap = {\n error: 'warning-circle',\n warning: 'warning',\n helper: 'info',\n} as const\n</script>\n\n<style scoped lang=\"scss\">\n.nb-message {\n display: inline-flex;\n align-items: center;\n gap: calc(var(--nb-base-unit) / 2);\n font-family: var(--nb-font-family-sans);\n font-size: var(--nb-font-size-12);\n line-height: 1.4;\n\n &--error {\n color: var(--nb-c-danger);\n }\n &--warning {\n color: var(--nb-c-warning);\n }\n &--helper {\n color: var(--nb-c-text-subtle);\n }\n\n &__icon {\n flex-shrink: 0;\n }\n\n &__text {\n flex: 1;\n }\n\n /* Icon-only: hide text, show CSS tooltip on hover */\n &--icon-only {\n position: relative;\n cursor: default;\n\n .nb-message__text {\n display: none;\n }\n\n &:hover .nb-message__tooltip,\n &:focus-within .nb-message__tooltip {\n opacity: 1;\n visibility: visible;\n transform: translateX(-50%) translateY(0);\n }\n }\n\n &__tooltip {\n position: absolute;\n bottom: calc(100% + 8px);\n left: 50%;\n transform: translateX(-50%) translateY(4px);\n background: var(--nb-c-plain-black-800, #1f2937);\n color: #fff;\n padding: 6px 10px;\n border-radius: 4px;\n font-size: 11px;\n font-weight: 400;\n white-space: nowrap;\n max-width: 220px;\n text-overflow: ellipsis;\n overflow: hidden;\n opacity: 0;\n visibility: hidden;\n transform: translateX(-50%) translateY(4px);\n transition:\n opacity 0.15s ease,\n transform 0.15s ease,\n visibility 0.15s ease;\n pointer-events: none;\n z-index: var(--nb-zindex-tooltip, 401);\n\n &::after {\n content: '';\n position: absolute;\n top: 100%;\n left: 50%;\n transform: translateX(-50%);\n border: 5px solid transparent;\n border-top-color: var(--nb-c-plain-black-800, #1f2937);\n }\n }\n}\n</style>\n","<template>\n <Teleport to=\"body\">\n <Transition name=\"nb-modal\">\n <div v-if=\"open\" class=\"nb-modal--overlay\" @click.self=\"onOverlayClick\">\n <div\n class=\"nb-modal--content\"\n role=\"dialog\"\n aria-modal=\"true\"\n :style=\"{ maxWidth: sizes[size] }\"\n @click.stop\n >\n <header v-if=\"$slots.header || title\" class=\"nb-modal--header\">\n <span class=\"nb-modal--title\">\n <slot name=\"header\">{{ title }}</slot>\n </span>\n <button\n class=\"nb-modal--close\"\n aria-label=\"Close\"\n @click=\"emit('close')\"\n >\n <NbIcon name=\"x\" />\n </button>\n </header>\n <main class=\"nb-modal--body\">\n <slot />\n </main>\n <NbGrid\n is=\"footer\"\n v-if=\"$slots.footer\"\n justify=\"end\"\n class=\"nb-modal--footer\"\n distributed\n >\n <slot name=\"footer\" />\n </NbGrid>\n </div>\n </div>\n </Transition>\n </Teleport>\n</template>\n\n<script setup lang=\"ts\">\nimport { watch, onMounted, onUnmounted } from 'vue'\nimport { ESizeShort } from '@/types/Size.d'\nimport type { IModalProps } from './Modal.d'\n\nconst props = withDefaults(defineProps<IModalProps>(), {\n title: undefined,\n open: false,\n size: ESizeShort.Medium,\n closeOnOverlay: true,\n})\n\nconst emit = defineEmits<{ close: [] }>()\n\nconst sizes = { sm: '400px', md: '520px', lg: '720px', xl: '960px' }\n\nfunction onOverlayClick() {\n if (props.closeOnOverlay) emit('close')\n}\n\n// Trap focus / prevent body scroll\nwatch(\n () => props.open,\n (val) => {\n document.body.style.overflow = val ? 'hidden' : ''\n },\n)\n\nonUnmounted(() => {\n document.body.style.overflow = ''\n})\n\nfunction onKeydown(e: KeyboardEvent) {\n if (e.key === 'Escape' && props.open) emit('close')\n}\n\nonMounted(() => {\n document.addEventListener('keydown', onKeydown)\n})\nonUnmounted(() => {\n document.removeEventListener('keydown', onKeydown)\n})\n</script>\n\n<style scoped lang=\"scss\">\n.nb-modal--overlay {\n position: fixed;\n inset: 0;\n background: rgba(0, 0, 0, 0.45);\n display: flex;\n align-items: center;\n justify-content: center;\n z-index: var(--nb-z-modal, 301);\n padding: 20px;\n}\n\n.nb-modal--content {\n background: var(--nb-c-bg, var(--nb-c-surface));\n box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);\n width: 100%;\n max-height: 90vh;\n display: flex;\n flex-direction: column;\n overflow: hidden;\n\n --parent-radius: 8px;\n}\n\n.nb-modal--header {\n display: flex;\n align-items: center;\n justify-content: space-between;\n flex-shrink: 0;\n}\n\n.nb-modal--title {\n padding: 16px 20px;\n font-size: 15px;\n font-weight: 600;\n color: var(--nb-c-text, #1a1a2e);\n}\n\n.nb-modal--close {\n width: calc(var(--nb-base-unit) * 7);\n height: calc(var(--nb-base-unit) * 7);\n border: none;\n background: transparent;\n font-size: 20px;\n line-height: 1;\n color: var(--nb-c-text-muted);\n cursor: pointer;\n display: flex;\n align-items: center;\n justify-content: center;\n transition:\n background 0.15s,\n color 0.15s;\n flex-shrink: 0;\n\n &:hover {\n background: var(--nb-c-bg-soft);\n color: var(--nb-c-text);\n }\n}\n\n.nb-modal--body {\n padding: 20px;\n overflow-y: auto;\n flex: 1;\n color: var(--nb-c-text, #1a1a2e);\n}\n\n.nb-modal--footer {\n :deep(> :only-child) {\n max-width: 50%;\n }\n}\n\n/* Transitions */\n.nb-modal-enter-active,\n.nb-modal-leave-active {\n transition:\n opacity 0.2s,\n transform 0.2s;\n .nb-modal--content {\n transition:\n opacity 0.2s,\n transform 0.2s;\n }\n}\n.nb-modal-enter-from {\n opacity: 0;\n .nb-modal--content {\n transform: scale(0.96) translateY(-8px);\n opacity: 0;\n }\n}\n.nb-modal-leave-to {\n opacity: 0;\n .nb-modal--content {\n transform: scale(0.96) translateY(-8px);\n opacity: 0;\n }\n}\n</style>\n","<template>\n <Teleport to=\"body\">\n <Transition name=\"nb-modal\">\n <div v-if=\"open\" class=\"nb-modal--overlay\" @click.self=\"onOverlayClick\">\n <div\n class=\"nb-modal--content\"\n role=\"dialog\"\n aria-modal=\"true\"\n :style=\"{ maxWidth: sizes[size] }\"\n @click.stop\n >\n <header v-if=\"$slots.header || title\" class=\"nb-modal--header\">\n <span class=\"nb-modal--title\">\n <slot name=\"header\">{{ title }}</slot>\n </span>\n <button\n class=\"nb-modal--close\"\n aria-label=\"Close\"\n @click=\"emit('close')\"\n >\n <NbIcon name=\"x\" />\n </button>\n </header>\n <main class=\"nb-modal--body\">\n <slot />\n </main>\n <NbGrid\n is=\"footer\"\n v-if=\"$slots.footer\"\n justify=\"end\"\n class=\"nb-modal--footer\"\n distributed\n >\n <slot name=\"footer\" />\n </NbGrid>\n </div>\n </div>\n </Transition>\n </Teleport>\n</template>\n\n<script setup lang=\"ts\">\nimport { watch, onMounted, onUnmounted } from 'vue'\nimport { ESizeShort } from '@/types/Size.d'\nimport type { IModalProps } from './Modal.d'\n\nconst props = withDefaults(defineProps<IModalProps>(), {\n title: undefined,\n open: false,\n size: ESizeShort.Medium,\n closeOnOverlay: true,\n})\n\nconst emit = defineEmits<{ close: [] }>()\n\nconst sizes = { sm: '400px', md: '520px', lg: '720px', xl: '960px' }\n\nfunction onOverlayClick() {\n if (props.closeOnOverlay) emit('close')\n}\n\n// Trap focus / prevent body scroll\nwatch(\n () => props.open,\n (val) => {\n document.body.style.overflow = val ? 'hidden' : ''\n },\n)\n\nonUnmounted(() => {\n document.body.style.overflow = ''\n})\n\nfunction onKeydown(e: KeyboardEvent) {\n if (e.key === 'Escape' && props.open) emit('close')\n}\n\nonMounted(() => {\n document.addEventListener('keydown', onKeydown)\n})\nonUnmounted(() => {\n document.removeEventListener('keydown', onKeydown)\n})\n</script>\n\n<style scoped lang=\"scss\">\n.nb-modal--overlay {\n position: fixed;\n inset: 0;\n background: rgba(0, 0, 0, 0.45);\n display: flex;\n align-items: center;\n justify-content: center;\n z-index: var(--nb-z-modal, 301);\n padding: 20px;\n}\n\n.nb-modal--content {\n background: var(--nb-c-bg, var(--nb-c-surface));\n box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);\n width: 100%;\n max-height: 90vh;\n display: flex;\n flex-direction: column;\n overflow: hidden;\n\n --parent-radius: 8px;\n}\n\n.nb-modal--header {\n display: flex;\n align-items: center;\n justify-content: space-between;\n flex-shrink: 0;\n}\n\n.nb-modal--title {\n padding: 16px 20px;\n font-size: 15px;\n font-weight: 600;\n color: var(--nb-c-text, #1a1a2e);\n}\n\n.nb-modal--close {\n width: calc(var(--nb-base-unit) * 7);\n height: calc(var(--nb-base-unit) * 7);\n border: none;\n background: transparent;\n font-size: 20px;\n line-height: 1;\n color: var(--nb-c-text-muted);\n cursor: pointer;\n display: flex;\n align-items: center;\n justify-content: center;\n transition:\n background 0.15s,\n color 0.15s;\n flex-shrink: 0;\n\n &:hover {\n background: var(--nb-c-bg-soft);\n color: var(--nb-c-text);\n }\n}\n\n.nb-modal--body {\n padding: 20px;\n overflow-y: auto;\n flex: 1;\n color: var(--nb-c-text, #1a1a2e);\n}\n\n.nb-modal--footer {\n :deep(> :only-child) {\n max-width: 50%;\n }\n}\n\n/* Transitions */\n.nb-modal-enter-active,\n.nb-modal-leave-active {\n transition:\n opacity 0.2s,\n transform 0.2s;\n .nb-modal--content {\n transition:\n opacity 0.2s,\n transform 0.2s;\n }\n}\n.nb-modal-enter-from {\n opacity: 0;\n .nb-modal--content {\n transform: scale(0.96) translateY(-8px);\n opacity: 0;\n }\n}\n.nb-modal-leave-to {\n opacity: 0;\n .nb-modal--content {\n transform: scale(0.96) translateY(-8px);\n opacity: 0;\n }\n}\n</style>\n","<template>\n <div :class=\"rootClasses\">\n <!-- DEFAULT variant -->\n <template v-if=\"variant === 'default'\">\n <NbLabel\n v-if=\"label\"\n :for=\"inputId\"\n :required=\"required\"\n :disabled=\"disabled\"\n >{{ label }}</NbLabel\n >\n\n <div class=\"nb-number-input__field-wrapper\" :class=\"wrapperClasses\">\n <input\n :id=\"inputId\"\n ref=\"inputRef\"\n type=\"number\"\n class=\"nb-number-input__field\"\n :placeholder=\"placeholder\"\n :min=\"min\"\n :max=\"max\"\n :step=\"step\"\n :disabled=\"disabled\"\n :required=\"required\"\n @input=\"onInput\"\n @blur=\"onBlur\"\n @keydown.enter.prevent=\"() => inputRef?.blur()\"\n @focus=\"focused = true\"\n />\n\n <NbMessage\n v-if=\"error\"\n variant=\"error\"\n :icon-only=\"true\"\n class=\"nb-number-input__status\"\n >{{ error }}</NbMessage\n >\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n :icon-only=\"true\"\n class=\"nb-number-input__status\"\n >{{ warning }}</NbMessage\n >\n\n <div class=\"nb-number-input__steppers\">\n <button\n type=\"button\"\n class=\"nb-number-input__stepper\"\n :class=\"{ 'nb-number-input__stepper--at-limit': isAtMin }\"\n :disabled=\"disabled\"\n aria-label=\"Decrease\"\n @mousedown.prevent\n @click=\"decrement\"\n >\n <NbIcon name=\"minus\" :size=\"16\" />\n </button>\n <button\n type=\"button\"\n class=\"nb-number-input__stepper\"\n :class=\"{ 'nb-number-input__stepper--at-limit': isAtMax }\"\n :disabled=\"disabled\"\n aria-label=\"Increase\"\n @mousedown.prevent\n @click=\"increment\"\n >\n <NbIcon name=\"plus\" :size=\"16\" />\n </button>\n </div>\n </div>\n\n <NbMessage\n v-if=\"error\"\n variant=\"error\"\n class=\"nb-number-input__message\"\n >{{ error }}</NbMessage\n >\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n class=\"nb-number-input__message\"\n >{{ warning }}</NbMessage\n >\n <NbMessage\n v-else-if=\"helper\"\n variant=\"helper\"\n class=\"nb-number-input__message\"\n >{{ helper }}</NbMessage\n >\n </template>\n\n <!-- FLUID variant -->\n <template v-else-if=\"variant === 'fluid'\">\n <div class=\"nb-number-input__field-wrapper\" :class=\"wrapperClasses\">\n <div v-if=\"label\" class=\"nb-number-input__inner-header\">\n <label :for=\"inputId\" class=\"nb-number-input__inner-label\">\n {{ label }}\n <span\n v-if=\"required\"\n class=\"nb-number-input__asterisk\"\n aria-hidden=\"true\"\n >*</span\n >\n </label>\n <NbMessage\n v-if=\"helper && !error && !warning\"\n variant=\"helper\"\n :icon-only=\"true\"\n class=\"nb-number-input__inner-message\"\n >{{ helper }}</NbMessage\n >\n </div>\n\n <div class=\"nb-number-input__fluid-row\">\n <input\n :id=\"inputId\"\n ref=\"inputRef\"\n type=\"number\"\n class=\"nb-number-input__field\"\n :placeholder=\"placeholder\"\n :min=\"min\"\n :max=\"max\"\n :step=\"step\"\n :disabled=\"disabled\"\n :required=\"required\"\n @input=\"onInput\"\n @blur=\"onBlur\"\n @keydown.enter.prevent=\"() => inputRef?.blur()\"\n @focus=\"focused = true\"\n />\n\n <NbMessage\n v-if=\"error\"\n variant=\"error\"\n :icon-only=\"true\"\n class=\"nb-number-input__status\"\n >{{ error }}</NbMessage\n >\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n :icon-only=\"true\"\n class=\"nb-number-input__status\"\n >{{ warning }}</NbMessage\n >\n\n <div class=\"nb-number-input__steppers\">\n <button\n type=\"button\"\n class=\"nb-number-input__stepper\"\n :class=\"{ 'nb-number-input__stepper--at-limit': isAtMin }\"\n :disabled=\"disabled\"\n aria-label=\"Decrease\"\n @mousedown.prevent\n @click=\"decrement\"\n >\n <NbIcon name=\"minus\" :size=\"16\" />\n </button>\n <button\n type=\"button\"\n class=\"nb-number-input__stepper\"\n :class=\"{ 'nb-number-input__stepper--at-limit': isAtMax }\"\n :disabled=\"disabled\"\n aria-label=\"Increase\"\n @mousedown.prevent\n @click=\"increment\"\n >\n <NbIcon name=\"plus\" :size=\"16\" />\n </button>\n </div>\n </div>\n </div>\n\n <NbMessage\n v-if=\"error\"\n variant=\"error\"\n class=\"nb-number-input__fluid-message\"\n >{{ error }}</NbMessage\n >\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n class=\"nb-number-input__fluid-message\"\n >{{ warning }}</NbMessage\n >\n </template>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed, onMounted, ref, useId, watch } from 'vue'\nimport type { IFieldComponent } from '@/types/Props.d'\nimport NbLabel from './Label.vue'\nimport NbMessage from './Message.vue'\nimport NbIcon from './Icon.vue'\n\nexport interface INumberInputProps extends IFieldComponent {\n modelValue?: number | null\n min?: number\n max?: number\n step?: number\n}\n\nconst props = withDefaults(defineProps<INumberInputProps>(), {\n modelValue: null,\n label: '',\n placeholder: '',\n helper: '',\n error: '',\n warning: '',\n min: undefined,\n max: undefined,\n step: 1,\n variant: 'default',\n size: 'md',\n disabled: false,\n required: false,\n id: undefined,\n})\n\nconst emit = defineEmits<{\n 'update:modelValue': [value: number | null]\n change: [value: number | null]\n}>()\n\nconst inputRef = ref<HTMLInputElement | null>(null)\nconst focused = ref(false)\n\nconst autoId = `nb-number-input-${useId()}`\nconst inputId = computed(() => props.id ?? autoId)\n\nconst isAtMin = computed(\n () =>\n props.min !== undefined &&\n props.modelValue !== null &&\n props.modelValue !== undefined &&\n props.modelValue <= props.min,\n)\nconst isAtMax = computed(\n () =>\n props.max !== undefined &&\n props.modelValue !== null &&\n props.modelValue !== undefined &&\n props.modelValue >= props.max,\n)\n\nfunction clamp(value: number): number {\n let v = value\n if (props.min !== undefined) v = Math.max(props.min, v)\n if (props.max !== undefined) v = Math.min(props.max, v)\n return v\n}\n\nfunction syncDisplay(val: number | null | undefined) {\n if (!inputRef.value) return\n inputRef.value.value = val !== null && val !== undefined ? String(val) : ''\n}\n\nonMounted(() => syncDisplay(props.modelValue))\n\nwatch(\n () => props.modelValue,\n (val) => {\n if (!focused.value) syncDisplay(val)\n },\n)\n\nfunction increment() {\n const current = props.modelValue ?? 0\n const next = clamp(current + props.step)\n emit('update:modelValue', next)\n emit('change', next)\n syncDisplay(next)\n}\n\nfunction decrement() {\n const current = props.modelValue ?? 0\n const next = clamp(current - props.step)\n emit('update:modelValue', next)\n emit('change', next)\n syncDisplay(next)\n}\n\nfunction onInput() {\n if (!inputRef.value) return\n const raw = inputRef.value.value\n if (raw === '') {\n emit('update:modelValue', null)\n } else {\n const num = parseFloat(raw)\n if (!isNaN(num)) emit('update:modelValue', num)\n }\n}\n\nfunction onBlur() {\n focused.value = false\n if (!inputRef.value) return\n const raw = inputRef.value.value\n if (raw === '') {\n emit('update:modelValue', null)\n emit('change', null)\n return\n }\n const num = parseFloat(raw)\n if (!isNaN(num)) {\n const clamped = clamp(num)\n emit('update:modelValue', clamped)\n emit('change', clamped)\n syncDisplay(clamped)\n }\n}\n\nconst rootClasses = computed(() => [\n 'nb-number-input',\n `nb-number-input--${props.variant}`,\n `nb-number-input--${props.size}`,\n {\n 'nb-number-input--error': !!props.error,\n 'nb-number-input--warning': !props.error && !!props.warning,\n 'nb-number-input--disabled': props.disabled,\n },\n])\n\nconst wrapperClasses = computed(() => ({\n 'nb-number-input__field-wrapper--focused': focused.value,\n 'nb-number-input__field-wrapper--error': !!props.error,\n 'nb-number-input__field-wrapper--warning': !props.error && !!props.warning,\n 'nb-number-input__field-wrapper--disabled': props.disabled,\n}))\n\ndefineExpose({ focus: () => inputRef.value?.focus() })\n</script>\n\n<style scoped lang=\"scss\">\n.nb-number-input {\n display: flex;\n flex-direction: column;\n flex: 1;\n gap: 6px;\n font-family: var(--nb-font-family-sans, sans-serif);\n --field-h: var(--nb-field-height-md);\n\n &--sm {\n --field-h: var(--nb-field-height-sm);\n }\n &--md {\n --field-h: var(--nb-field-height-md);\n }\n &--lg {\n --field-h: var(--nb-field-height-lg);\n }\n\n &__field-wrapper {\n position: relative;\n display: flex;\n align-items: stretch;\n background: var(--nb-c-field-bg);\n border-bottom: 1px solid var(--nb-c-field-border);\n height: var(--field-h);\n box-sizing: border-box;\n transition:\n border-color 0.15s,\n box-shadow 0.15s;\n\n &--focused {\n outline: 2px solid var(--nb-c-primary);\n outline-offset: -2px;\n }\n\n &--error {\n border: 1px solid var(--nb-c-danger);\n box-shadow: none;\n }\n\n &--warning {\n border: 1px solid var(--nb-c-warning);\n box-shadow: none;\n }\n\n &--disabled {\n opacity: var(--nb-field-disabled-opacity);\n cursor: not-allowed;\n }\n }\n\n &__field {\n flex: 1;\n min-width: 0;\n height: 100%;\n padding: 0 var(--nb-field-padding-h);\n background: transparent;\n border: none;\n outline: none;\n font-family: inherit;\n font-size: var(--nb-field-font-size);\n font-weight: 400;\n color: var(--nb-c-text);\n\n // Hide native number spinners\n appearance: none;\n -moz-appearance: textfield;\n\n &::-webkit-outer-spin-button,\n &::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0;\n }\n\n &:disabled {\n cursor: not-allowed;\n }\n }\n\n &__status {\n flex-shrink: 0;\n display: flex;\n align-items: center;\n padding: 0 4px;\n }\n\n &__steppers {\n display: flex;\n align-items: stretch;\n flex-shrink: 0;\n }\n\n &__stepper {\n display: flex;\n align-items: center;\n justify-content: center;\n width: 40px;\n background: transparent;\n border: none;\n cursor: pointer;\n color: var(--nb-c-text);\n transition: background 0.15s;\n padding: 0;\n flex-shrink: 0;\n position: relative;\n\n &::before {\n content: '';\n position: absolute;\n left: 0;\n top: 25%;\n bottom: 25%;\n width: 1px;\n background: var(--nb-c-field-border);\n }\n\n &:hover:not(:disabled):not(.nb-number-input__stepper--at-limit) {\n background: var(--nb-c-discrete);\n }\n\n &:disabled {\n cursor: not-allowed;\n }\n\n &--at-limit {\n opacity: var(--nb-field-disabled-opacity);\n cursor: not-allowed;\n }\n }\n\n &__message,\n &__fluid-message {\n font-size: var(--nb-font-size-12);\n }\n\n // FLUID variant\n &--fluid {\n .nb-number-input__field-wrapper {\n // When a label is present inside: expand to column layout\n &:has(.nb-number-input__inner-header) {\n flex: 1;\n flex-direction: column;\n align-items: stretch;\n justify-content: space-between;\n height: auto;\n min-height: calc(var(--nb-base-unit) * 8);\n padding-top: 8px;\n }\n }\n\n .nb-number-input__inner-header {\n display: flex;\n align-items: center;\n gap: 4px;\n padding: 0 var(--nb-field-padding-h);\n margin-bottom: 4px;\n }\n\n .nb-number-input__inner-label {\n flex: 1;\n min-width: 0;\n font-size: var(--nb-font-size-12);\n font-weight: 500;\n color: var(--nb-c-text-muted);\n text-transform: uppercase;\n letter-spacing: 0.02em;\n cursor: default;\n user-select: none;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n\n .nb-number-input__asterisk {\n color: var(--nb-c-danger);\n }\n\n .nb-number-input__fluid-row {\n display: flex;\n align-items: center;\n flex: 1;\n }\n\n .nb-number-input__field {\n height: auto;\n flex: 1;\n padding: 6px var(--nb-field-padding-h) 10px;\n font-size: 15px;\n }\n\n .nb-number-input__steppers {\n align-self: stretch;\n }\n\n .nb-number-input__stepper {\n height: 100%;\n }\n }\n}\n</style>\n","<template>\n <div :class=\"rootClasses\">\n <!-- DEFAULT variant -->\n <template v-if=\"variant === 'default'\">\n <NbLabel\n v-if=\"label\"\n :for=\"inputId\"\n :required=\"required\"\n :disabled=\"disabled\"\n >{{ label }}</NbLabel\n >\n\n <div class=\"nb-number-input__field-wrapper\" :class=\"wrapperClasses\">\n <input\n :id=\"inputId\"\n ref=\"inputRef\"\n type=\"number\"\n class=\"nb-number-input__field\"\n :placeholder=\"placeholder\"\n :min=\"min\"\n :max=\"max\"\n :step=\"step\"\n :disabled=\"disabled\"\n :required=\"required\"\n @input=\"onInput\"\n @blur=\"onBlur\"\n @keydown.enter.prevent=\"() => inputRef?.blur()\"\n @focus=\"focused = true\"\n />\n\n <NbMessage\n v-if=\"error\"\n variant=\"error\"\n :icon-only=\"true\"\n class=\"nb-number-input__status\"\n >{{ error }}</NbMessage\n >\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n :icon-only=\"true\"\n class=\"nb-number-input__status\"\n >{{ warning }}</NbMessage\n >\n\n <div class=\"nb-number-input__steppers\">\n <button\n type=\"button\"\n class=\"nb-number-input__stepper\"\n :class=\"{ 'nb-number-input__stepper--at-limit': isAtMin }\"\n :disabled=\"disabled\"\n aria-label=\"Decrease\"\n @mousedown.prevent\n @click=\"decrement\"\n >\n <NbIcon name=\"minus\" :size=\"16\" />\n </button>\n <button\n type=\"button\"\n class=\"nb-number-input__stepper\"\n :class=\"{ 'nb-number-input__stepper--at-limit': isAtMax }\"\n :disabled=\"disabled\"\n aria-label=\"Increase\"\n @mousedown.prevent\n @click=\"increment\"\n >\n <NbIcon name=\"plus\" :size=\"16\" />\n </button>\n </div>\n </div>\n\n <NbMessage\n v-if=\"error\"\n variant=\"error\"\n class=\"nb-number-input__message\"\n >{{ error }}</NbMessage\n >\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n class=\"nb-number-input__message\"\n >{{ warning }}</NbMessage\n >\n <NbMessage\n v-else-if=\"helper\"\n variant=\"helper\"\n class=\"nb-number-input__message\"\n >{{ helper }}</NbMessage\n >\n </template>\n\n <!-- FLUID variant -->\n <template v-else-if=\"variant === 'fluid'\">\n <div class=\"nb-number-input__field-wrapper\" :class=\"wrapperClasses\">\n <div v-if=\"label\" class=\"nb-number-input__inner-header\">\n <label :for=\"inputId\" class=\"nb-number-input__inner-label\">\n {{ label }}\n <span\n v-if=\"required\"\n class=\"nb-number-input__asterisk\"\n aria-hidden=\"true\"\n >*</span\n >\n </label>\n <NbMessage\n v-if=\"helper && !error && !warning\"\n variant=\"helper\"\n :icon-only=\"true\"\n class=\"nb-number-input__inner-message\"\n >{{ helper }}</NbMessage\n >\n </div>\n\n <div class=\"nb-number-input__fluid-row\">\n <input\n :id=\"inputId\"\n ref=\"inputRef\"\n type=\"number\"\n class=\"nb-number-input__field\"\n :placeholder=\"placeholder\"\n :min=\"min\"\n :max=\"max\"\n :step=\"step\"\n :disabled=\"disabled\"\n :required=\"required\"\n @input=\"onInput\"\n @blur=\"onBlur\"\n @keydown.enter.prevent=\"() => inputRef?.blur()\"\n @focus=\"focused = true\"\n />\n\n <NbMessage\n v-if=\"error\"\n variant=\"error\"\n :icon-only=\"true\"\n class=\"nb-number-input__status\"\n >{{ error }}</NbMessage\n >\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n :icon-only=\"true\"\n class=\"nb-number-input__status\"\n >{{ warning }}</NbMessage\n >\n\n <div class=\"nb-number-input__steppers\">\n <button\n type=\"button\"\n class=\"nb-number-input__stepper\"\n :class=\"{ 'nb-number-input__stepper--at-limit': isAtMin }\"\n :disabled=\"disabled\"\n aria-label=\"Decrease\"\n @mousedown.prevent\n @click=\"decrement\"\n >\n <NbIcon name=\"minus\" :size=\"16\" />\n </button>\n <button\n type=\"button\"\n class=\"nb-number-input__stepper\"\n :class=\"{ 'nb-number-input__stepper--at-limit': isAtMax }\"\n :disabled=\"disabled\"\n aria-label=\"Increase\"\n @mousedown.prevent\n @click=\"increment\"\n >\n <NbIcon name=\"plus\" :size=\"16\" />\n </button>\n </div>\n </div>\n </div>\n\n <NbMessage\n v-if=\"error\"\n variant=\"error\"\n class=\"nb-number-input__fluid-message\"\n >{{ error }}</NbMessage\n >\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n class=\"nb-number-input__fluid-message\"\n >{{ warning }}</NbMessage\n >\n </template>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed, onMounted, ref, useId, watch } from 'vue'\nimport type { IFieldComponent } from '@/types/Props.d'\nimport NbLabel from './Label.vue'\nimport NbMessage from './Message.vue'\nimport NbIcon from './Icon.vue'\n\nexport interface INumberInputProps extends IFieldComponent {\n modelValue?: number | null\n min?: number\n max?: number\n step?: number\n}\n\nconst props = withDefaults(defineProps<INumberInputProps>(), {\n modelValue: null,\n label: '',\n placeholder: '',\n helper: '',\n error: '',\n warning: '',\n min: undefined,\n max: undefined,\n step: 1,\n variant: 'default',\n size: 'md',\n disabled: false,\n required: false,\n id: undefined,\n})\n\nconst emit = defineEmits<{\n 'update:modelValue': [value: number | null]\n change: [value: number | null]\n}>()\n\nconst inputRef = ref<HTMLInputElement | null>(null)\nconst focused = ref(false)\n\nconst autoId = `nb-number-input-${useId()}`\nconst inputId = computed(() => props.id ?? autoId)\n\nconst isAtMin = computed(\n () =>\n props.min !== undefined &&\n props.modelValue !== null &&\n props.modelValue !== undefined &&\n props.modelValue <= props.min,\n)\nconst isAtMax = computed(\n () =>\n props.max !== undefined &&\n props.modelValue !== null &&\n props.modelValue !== undefined &&\n props.modelValue >= props.max,\n)\n\nfunction clamp(value: number): number {\n let v = value\n if (props.min !== undefined) v = Math.max(props.min, v)\n if (props.max !== undefined) v = Math.min(props.max, v)\n return v\n}\n\nfunction syncDisplay(val: number | null | undefined) {\n if (!inputRef.value) return\n inputRef.value.value = val !== null && val !== undefined ? String(val) : ''\n}\n\nonMounted(() => syncDisplay(props.modelValue))\n\nwatch(\n () => props.modelValue,\n (val) => {\n if (!focused.value) syncDisplay(val)\n },\n)\n\nfunction increment() {\n const current = props.modelValue ?? 0\n const next = clamp(current + props.step)\n emit('update:modelValue', next)\n emit('change', next)\n syncDisplay(next)\n}\n\nfunction decrement() {\n const current = props.modelValue ?? 0\n const next = clamp(current - props.step)\n emit('update:modelValue', next)\n emit('change', next)\n syncDisplay(next)\n}\n\nfunction onInput() {\n if (!inputRef.value) return\n const raw = inputRef.value.value\n if (raw === '') {\n emit('update:modelValue', null)\n } else {\n const num = parseFloat(raw)\n if (!isNaN(num)) emit('update:modelValue', num)\n }\n}\n\nfunction onBlur() {\n focused.value = false\n if (!inputRef.value) return\n const raw = inputRef.value.value\n if (raw === '') {\n emit('update:modelValue', null)\n emit('change', null)\n return\n }\n const num = parseFloat(raw)\n if (!isNaN(num)) {\n const clamped = clamp(num)\n emit('update:modelValue', clamped)\n emit('change', clamped)\n syncDisplay(clamped)\n }\n}\n\nconst rootClasses = computed(() => [\n 'nb-number-input',\n `nb-number-input--${props.variant}`,\n `nb-number-input--${props.size}`,\n {\n 'nb-number-input--error': !!props.error,\n 'nb-number-input--warning': !props.error && !!props.warning,\n 'nb-number-input--disabled': props.disabled,\n },\n])\n\nconst wrapperClasses = computed(() => ({\n 'nb-number-input__field-wrapper--focused': focused.value,\n 'nb-number-input__field-wrapper--error': !!props.error,\n 'nb-number-input__field-wrapper--warning': !props.error && !!props.warning,\n 'nb-number-input__field-wrapper--disabled': props.disabled,\n}))\n\ndefineExpose({ focus: () => inputRef.value?.focus() })\n</script>\n\n<style scoped lang=\"scss\">\n.nb-number-input {\n display: flex;\n flex-direction: column;\n flex: 1;\n gap: 6px;\n font-family: var(--nb-font-family-sans, sans-serif);\n --field-h: var(--nb-field-height-md);\n\n &--sm {\n --field-h: var(--nb-field-height-sm);\n }\n &--md {\n --field-h: var(--nb-field-height-md);\n }\n &--lg {\n --field-h: var(--nb-field-height-lg);\n }\n\n &__field-wrapper {\n position: relative;\n display: flex;\n align-items: stretch;\n background: var(--nb-c-field-bg);\n border-bottom: 1px solid var(--nb-c-field-border);\n height: var(--field-h);\n box-sizing: border-box;\n transition:\n border-color 0.15s,\n box-shadow 0.15s;\n\n &--focused {\n outline: 2px solid var(--nb-c-primary);\n outline-offset: -2px;\n }\n\n &--error {\n border: 1px solid var(--nb-c-danger);\n box-shadow: none;\n }\n\n &--warning {\n border: 1px solid var(--nb-c-warning);\n box-shadow: none;\n }\n\n &--disabled {\n opacity: var(--nb-field-disabled-opacity);\n cursor: not-allowed;\n }\n }\n\n &__field {\n flex: 1;\n min-width: 0;\n height: 100%;\n padding: 0 var(--nb-field-padding-h);\n background: transparent;\n border: none;\n outline: none;\n font-family: inherit;\n font-size: var(--nb-field-font-size);\n font-weight: 400;\n color: var(--nb-c-text);\n\n // Hide native number spinners\n appearance: none;\n -moz-appearance: textfield;\n\n &::-webkit-outer-spin-button,\n &::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0;\n }\n\n &:disabled {\n cursor: not-allowed;\n }\n }\n\n &__status {\n flex-shrink: 0;\n display: flex;\n align-items: center;\n padding: 0 4px;\n }\n\n &__steppers {\n display: flex;\n align-items: stretch;\n flex-shrink: 0;\n }\n\n &__stepper {\n display: flex;\n align-items: center;\n justify-content: center;\n width: 40px;\n background: transparent;\n border: none;\n cursor: pointer;\n color: var(--nb-c-text);\n transition: background 0.15s;\n padding: 0;\n flex-shrink: 0;\n position: relative;\n\n &::before {\n content: '';\n position: absolute;\n left: 0;\n top: 25%;\n bottom: 25%;\n width: 1px;\n background: var(--nb-c-field-border);\n }\n\n &:hover:not(:disabled):not(.nb-number-input__stepper--at-limit) {\n background: var(--nb-c-discrete);\n }\n\n &:disabled {\n cursor: not-allowed;\n }\n\n &--at-limit {\n opacity: var(--nb-field-disabled-opacity);\n cursor: not-allowed;\n }\n }\n\n &__message,\n &__fluid-message {\n font-size: var(--nb-font-size-12);\n }\n\n // FLUID variant\n &--fluid {\n .nb-number-input__field-wrapper {\n // When a label is present inside: expand to column layout\n &:has(.nb-number-input__inner-header) {\n flex: 1;\n flex-direction: column;\n align-items: stretch;\n justify-content: space-between;\n height: auto;\n min-height: calc(var(--nb-base-unit) * 8);\n padding-top: 8px;\n }\n }\n\n .nb-number-input__inner-header {\n display: flex;\n align-items: center;\n gap: 4px;\n padding: 0 var(--nb-field-padding-h);\n margin-bottom: 4px;\n }\n\n .nb-number-input__inner-label {\n flex: 1;\n min-width: 0;\n font-size: var(--nb-font-size-12);\n font-weight: 500;\n color: var(--nb-c-text-muted);\n text-transform: uppercase;\n letter-spacing: 0.02em;\n cursor: default;\n user-select: none;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n\n .nb-number-input__asterisk {\n color: var(--nb-c-danger);\n }\n\n .nb-number-input__fluid-row {\n display: flex;\n align-items: center;\n flex: 1;\n }\n\n .nb-number-input__field {\n height: auto;\n flex: 1;\n padding: 6px var(--nb-field-padding-h) 10px;\n font-size: 15px;\n }\n\n .nb-number-input__steppers {\n align-self: stretch;\n }\n\n .nb-number-input__stepper {\n height: 100%;\n }\n }\n}\n</style>\n","<template>\n <div class=\"nb-panel\">\n <slot />\n </div>\n</template>\n\n<script setup lang=\"ts\">\n// No props — Panel is a plain surface container\n</script>\n\n<style lang=\"scss\" scoped>\n.nb-panel {\n background: var(--nb-c-surface, #fff);\n border: 1px solid var(--nb-c-border, #ddd);\n padding: 12px;\n border-radius: 8px;\n}\n</style>\n","<template>\n <div class=\"nb-panel\">\n <slot />\n </div>\n</template>\n\n<script setup lang=\"ts\">\n// No props — Panel is a plain surface container\n</script>\n\n<style lang=\"scss\" scoped>\n.nb-panel {\n background: var(--nb-c-surface, #fff);\n border: 1px solid var(--nb-c-border, #ddd);\n padding: 12px;\n border-radius: 8px;\n}\n</style>\n","import {\n IHumanInputComponent,\n IWithLabel,\n IWithMessages,\n} from '@/types/Props.d'\n\ninterface IRadioOption {\n label: string\n value: string\n disabled?: boolean\n}\n\nenum ERadioDirection {\n Horizontal = 'horizontal',\n Vertical = 'vertical',\n}\n\ninterface IRadioProps extends IHumanInputComponent, IWithLabel, IWithMessages {\n modelValue?: string\n options: IRadioOption[]\n /** Required for native radio-button grouping via the HTML `name` attribute. */\n name: string\n direction?: ERadioDirection\n /** Makes options visible but non-interactive. */\n readonly?: boolean\n}\n\nexport { IRadioOption, ERadioDirection, IRadioProps }\n","<template>\n <div :class=\"rootClasses\">\n <NbLabel v-if=\"label\">{{ label }}</NbLabel>\n\n <div :class=\"['nb-radio__group', `nb-radio__group--${direction}`]\">\n <label\n v-for=\"option in options\"\n :key=\"option.value\"\n :class=\"optionClasses(option)\"\n >\n <span class=\"nb-radio__control\">\n <input\n type=\"radio\"\n :name=\"name\"\n :value=\"option.value\"\n :checked=\"modelValue === option.value\"\n :disabled=\"disabled || option.disabled\"\n :readonly=\"readonly\"\n class=\"nb-radio__input\"\n @change=\"!readonly && $emit('update:modelValue', option.value)\"\n />\n <span class=\"nb-radio__circle\">\n <span v-if=\"modelValue === option.value\" class=\"nb-radio__dot\" />\n </span>\n </span>\n <span class=\"nb-radio__text\">{{ option.label }}</span>\n </label>\n </div>\n\n <NbMessage v-if=\"error\" variant=\"error\" class=\"nb-radio__message\">{{\n error\n }}</NbMessage>\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n class=\"nb-radio__message\"\n >{{ warning }}</NbMessage\n >\n <NbMessage v-else-if=\"helper\" variant=\"helper\" class=\"nb-radio__message\">{{\n helper\n }}</NbMessage>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed } from 'vue'\nimport { ERadioDirection, IRadioProps, IRadioOption } from './Radio.d'\n\nconst props = withDefaults(defineProps<IRadioProps>(), {\n id: 'radio',\n direction: ERadioDirection.Vertical,\n disabled: false,\n readonly: false,\n error: undefined,\n warning: undefined,\n helper: undefined,\n})\n\ndefineEmits<{ 'update:modelValue': [value: string] }>()\n\nconst rootClasses = computed(() => [\n 'nb-radio',\n {\n 'nb-radio--error': !!props.error,\n 'nb-radio--warning': !props.error && !!props.warning,\n 'nb-radio--disabled': props.disabled,\n 'nb-radio--readonly': props.readonly,\n },\n])\n\nfunction optionClasses(option: IRadioOption) {\n return [\n 'nb-radio__option',\n {\n 'nb-radio__option--disabled': props.disabled || option.disabled,\n 'nb-radio__option--readonly': props.readonly,\n },\n ]\n}\n</script>\n\n<style scoped lang=\"scss\">\n.nb-radio {\n display: inline-flex;\n flex-direction: column;\n gap: 6px;\n font-family: var(--nb-font-family-sans);\n\n // ── Group label ─────────────────────────────────────────────────────────────\n // NbLabel handles its own styling; gap above handles spacing\n\n // ── Options group ───────────────────────────────────────────────────────────\n &__group {\n display: flex;\n gap: 4px;\n\n &--vertical {\n flex-direction: column;\n }\n\n &--horizontal {\n flex-direction: row;\n flex-wrap: wrap;\n gap: 12px;\n }\n }\n\n // ── Single option row ────────────────────────────────────────────────────────\n &__option {\n display: inline-flex;\n align-items: center;\n gap: 10px;\n cursor: pointer;\n user-select: none;\n min-height: 28px;\n\n &--disabled {\n opacity: var(--nb-field-disabled-opacity, 0.45);\n cursor: not-allowed;\n pointer-events: none;\n }\n\n &--readonly {\n cursor: default;\n pointer-events: none;\n }\n }\n\n // ── Custom control ───────────────────────────────────────────────────────────\n &__control {\n position: relative;\n flex-shrink: 0;\n display: flex;\n align-items: center;\n justify-content: center;\n }\n\n // Native input: hidden but still focusable\n &__input {\n position: absolute;\n opacity: 0;\n width: 0;\n height: 0;\n pointer-events: none;\n }\n\n // ── Circle ───────────────────────────────────────────────────────────────────\n &__circle {\n display: flex;\n align-items: center;\n justify-content: center;\n width: 18px;\n height: 18px;\n border: 1.5px solid var(--nb-c-field-border);\n border-radius: 50%;\n transition:\n border-color 0.15s,\n box-shadow 0.15s;\n }\n\n // ── Dot (selected indicator) ──────────────────────────────────────────────────\n &__dot {\n width: 8px;\n height: 8px;\n border-radius: 50%;\n background: var(--nb-c-contrast);\n animation: nb-radio-pop 0.12s ease;\n }\n\n // ── Option label text ─────────────────────────────────────────────────────────\n &__text {\n font-size: var(--nb-font-size-14);\n color: var(--nb-c-text);\n line-height: 1.4;\n }\n\n // ── Message ───────────────────────────────────────────────────────────────────\n &__message {\n font-size: var(--nb-font-size-12);\n }\n\n // ── Hover ─────────────────────────────────────────────────────────────────────\n &__option:not(&__option--disabled):not(&__option--readonly):hover &__circle {\n border-color: var(--nb-c-primary);\n }\n\n // ── Focus ring ────────────────────────────────────────────────────────────────\n &__input:focus-visible ~ &__circle {\n box-shadow: 0 0 0 2px var(--nb-c-primary);\n }\n\n // ── Checked: dark border + dark dot ──────────────────────────────────────────\n &__input:checked ~ &__circle {\n border-color: var(--nb-c-contrast);\n }\n\n // ── Error state: danger border + danger dot ───────────────────────────────────\n &--error {\n .nb-radio__circle {\n border-color: var(--nb-c-danger);\n }\n\n .nb-radio__input:checked ~ .nb-radio__circle {\n border-color: var(--nb-c-danger);\n }\n\n .nb-radio__dot {\n background: var(--nb-c-danger);\n }\n\n .nb-radio__option:not(.nb-radio__option--disabled):hover .nb-radio__circle {\n border-color: color-mix(\n in srgb,\n var(--nb-c-danger) 80%,\n var(--nb-c-contrast)\n );\n }\n }\n\n // ── Disabled (group-level) ────────────────────────────────────────────────────\n &--disabled {\n .nb-radio__group {\n opacity: var(--nb-field-disabled-opacity, 0.45);\n pointer-events: none;\n }\n }\n\n // ── Read-only ─────────────────────────────────────────────────────────────────\n &--readonly {\n .nb-radio__circle {\n background: transparent;\n }\n\n .nb-radio__input:not(:checked) ~ .nb-radio__circle {\n border-color: color-mix(\n in srgb,\n var(--nb-c-field-border) 100%,\n transparent\n );\n opacity: 0.6;\n }\n }\n\n @keyframes nb-radio-pop {\n from {\n transform: scale(0);\n }\n to {\n transform: scale(1);\n }\n }\n}\n</style>\n","<template>\n <div :class=\"rootClasses\">\n <NbLabel v-if=\"label\">{{ label }}</NbLabel>\n\n <div :class=\"['nb-radio__group', `nb-radio__group--${direction}`]\">\n <label\n v-for=\"option in options\"\n :key=\"option.value\"\n :class=\"optionClasses(option)\"\n >\n <span class=\"nb-radio__control\">\n <input\n type=\"radio\"\n :name=\"name\"\n :value=\"option.value\"\n :checked=\"modelValue === option.value\"\n :disabled=\"disabled || option.disabled\"\n :readonly=\"readonly\"\n class=\"nb-radio__input\"\n @change=\"!readonly && $emit('update:modelValue', option.value)\"\n />\n <span class=\"nb-radio__circle\">\n <span v-if=\"modelValue === option.value\" class=\"nb-radio__dot\" />\n </span>\n </span>\n <span class=\"nb-radio__text\">{{ option.label }}</span>\n </label>\n </div>\n\n <NbMessage v-if=\"error\" variant=\"error\" class=\"nb-radio__message\">{{\n error\n }}</NbMessage>\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n class=\"nb-radio__message\"\n >{{ warning }}</NbMessage\n >\n <NbMessage v-else-if=\"helper\" variant=\"helper\" class=\"nb-radio__message\">{{\n helper\n }}</NbMessage>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed } from 'vue'\nimport { ERadioDirection, IRadioProps, IRadioOption } from './Radio.d'\n\nconst props = withDefaults(defineProps<IRadioProps>(), {\n id: 'radio',\n direction: ERadioDirection.Vertical,\n disabled: false,\n readonly: false,\n error: undefined,\n warning: undefined,\n helper: undefined,\n})\n\ndefineEmits<{ 'update:modelValue': [value: string] }>()\n\nconst rootClasses = computed(() => [\n 'nb-radio',\n {\n 'nb-radio--error': !!props.error,\n 'nb-radio--warning': !props.error && !!props.warning,\n 'nb-radio--disabled': props.disabled,\n 'nb-radio--readonly': props.readonly,\n },\n])\n\nfunction optionClasses(option: IRadioOption) {\n return [\n 'nb-radio__option',\n {\n 'nb-radio__option--disabled': props.disabled || option.disabled,\n 'nb-radio__option--readonly': props.readonly,\n },\n ]\n}\n</script>\n\n<style scoped lang=\"scss\">\n.nb-radio {\n display: inline-flex;\n flex-direction: column;\n gap: 6px;\n font-family: var(--nb-font-family-sans);\n\n // ── Group label ─────────────────────────────────────────────────────────────\n // NbLabel handles its own styling; gap above handles spacing\n\n // ── Options group ───────────────────────────────────────────────────────────\n &__group {\n display: flex;\n gap: 4px;\n\n &--vertical {\n flex-direction: column;\n }\n\n &--horizontal {\n flex-direction: row;\n flex-wrap: wrap;\n gap: 12px;\n }\n }\n\n // ── Single option row ────────────────────────────────────────────────────────\n &__option {\n display: inline-flex;\n align-items: center;\n gap: 10px;\n cursor: pointer;\n user-select: none;\n min-height: 28px;\n\n &--disabled {\n opacity: var(--nb-field-disabled-opacity, 0.45);\n cursor: not-allowed;\n pointer-events: none;\n }\n\n &--readonly {\n cursor: default;\n pointer-events: none;\n }\n }\n\n // ── Custom control ───────────────────────────────────────────────────────────\n &__control {\n position: relative;\n flex-shrink: 0;\n display: flex;\n align-items: center;\n justify-content: center;\n }\n\n // Native input: hidden but still focusable\n &__input {\n position: absolute;\n opacity: 0;\n width: 0;\n height: 0;\n pointer-events: none;\n }\n\n // ── Circle ───────────────────────────────────────────────────────────────────\n &__circle {\n display: flex;\n align-items: center;\n justify-content: center;\n width: 18px;\n height: 18px;\n border: 1.5px solid var(--nb-c-field-border);\n border-radius: 50%;\n transition:\n border-color 0.15s,\n box-shadow 0.15s;\n }\n\n // ── Dot (selected indicator) ──────────────────────────────────────────────────\n &__dot {\n width: 8px;\n height: 8px;\n border-radius: 50%;\n background: var(--nb-c-contrast);\n animation: nb-radio-pop 0.12s ease;\n }\n\n // ── Option label text ─────────────────────────────────────────────────────────\n &__text {\n font-size: var(--nb-font-size-14);\n color: var(--nb-c-text);\n line-height: 1.4;\n }\n\n // ── Message ───────────────────────────────────────────────────────────────────\n &__message {\n font-size: var(--nb-font-size-12);\n }\n\n // ── Hover ─────────────────────────────────────────────────────────────────────\n &__option:not(&__option--disabled):not(&__option--readonly):hover &__circle {\n border-color: var(--nb-c-primary);\n }\n\n // ── Focus ring ────────────────────────────────────────────────────────────────\n &__input:focus-visible ~ &__circle {\n box-shadow: 0 0 0 2px var(--nb-c-primary);\n }\n\n // ── Checked: dark border + dark dot ──────────────────────────────────────────\n &__input:checked ~ &__circle {\n border-color: var(--nb-c-contrast);\n }\n\n // ── Error state: danger border + danger dot ───────────────────────────────────\n &--error {\n .nb-radio__circle {\n border-color: var(--nb-c-danger);\n }\n\n .nb-radio__input:checked ~ .nb-radio__circle {\n border-color: var(--nb-c-danger);\n }\n\n .nb-radio__dot {\n background: var(--nb-c-danger);\n }\n\n .nb-radio__option:not(.nb-radio__option--disabled):hover .nb-radio__circle {\n border-color: color-mix(\n in srgb,\n var(--nb-c-danger) 80%,\n var(--nb-c-contrast)\n );\n }\n }\n\n // ── Disabled (group-level) ────────────────────────────────────────────────────\n &--disabled {\n .nb-radio__group {\n opacity: var(--nb-field-disabled-opacity, 0.45);\n pointer-events: none;\n }\n }\n\n // ── Read-only ─────────────────────────────────────────────────────────────────\n &--readonly {\n .nb-radio__circle {\n background: transparent;\n }\n\n .nb-radio__input:not(:checked) ~ .nb-radio__circle {\n border-color: color-mix(\n in srgb,\n var(--nb-c-field-border) 100%,\n transparent\n );\n opacity: 0.6;\n }\n }\n\n @keyframes nb-radio-pop {\n from {\n transform: scale(0);\n }\n to {\n transform: scale(1);\n }\n }\n}\n</style>\n","<template>\n <div ref=\"rootRef\" :class=\"rootClasses\" @keydown=\"onKeydown\">\n <!-- DEFAULT variant -->\n <template v-if=\"variant === 'default'\">\n <slot v-if=\"$slots.label\" name=\"label\" />\n <NbLabel\n v-else-if=\"label\"\n :for=\"inputId\"\n :required=\"required\"\n :disabled=\"disabled\"\n >{{ label }}</NbLabel\n >\n\n <button\n :id=\"inputId\"\n ref=\"triggerRef\"\n type=\"button\"\n class=\"nb-select__trigger\"\n role=\"combobox\"\n :aria-expanded=\"isOpen\"\n :aria-haspopup=\"'listbox'\"\n :aria-disabled=\"disabled || undefined\"\n :aria-required=\"required || undefined\"\n :disabled=\"disabled || undefined\"\n @click=\"toggleDropdown\"\n @focus=\"focused = true\"\n @blur=\"focused = false\"\n >\n <span\n :class=\"[\n 'nb-select__value',\n { 'nb-select__value--placeholder': !displayValue },\n ]\"\n >\n {{ displayValue || placeholder }}\n </span>\n <NbMessage\n v-if=\"error\"\n variant=\"error\"\n :icon-only=\"true\"\n class=\"nb-select__status-icon\"\n >{{ error }}</NbMessage\n >\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n :icon-only=\"true\"\n class=\"nb-select__status-icon\"\n >{{ warning }}</NbMessage\n >\n <NbGrid align=\"center\" justify=\"center\" class=\"nb-select__caret\">\n <NbIcon :name=\"isOpen ? 'caret-up' : 'caret-down'\" :size=\"16\" />\n </NbGrid>\n </button>\n\n <NbMessage v-if=\"error\" variant=\"error\" class=\"nb-select__message\">{{\n error\n }}</NbMessage>\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n class=\"nb-select__message\"\n >{{ warning }}</NbMessage\n >\n <NbMessage\n v-else-if=\"helper\"\n variant=\"helper\"\n class=\"nb-select__message\"\n >{{ helper }}</NbMessage\n >\n </template>\n\n <!-- FLUID variant -->\n <template v-else-if=\"variant === 'fluid'\">\n <button\n :id=\"inputId\"\n ref=\"triggerRef\"\n type=\"button\"\n class=\"nb-select__trigger\"\n role=\"combobox\"\n :aria-expanded=\"isOpen\"\n :aria-haspopup=\"'listbox'\"\n :aria-disabled=\"disabled || undefined\"\n :aria-required=\"required || undefined\"\n :disabled=\"disabled || undefined\"\n @click=\"toggleDropdown\"\n @focus=\"focused = true\"\n @blur=\"focused = false\"\n >\n <NbGrid\n v-if=\"label || $slots.label\"\n dir=\"row\"\n align=\"center\"\n gap=\"xs\"\n class=\"nb-select__inner-header\"\n >\n <slot v-if=\"$slots.label\" name=\"label\" />\n <label v-else class=\"nb-select__inner-label\">\n {{ label }}\n <span v-if=\"required\" class=\"nb-select__asterisk\" aria-hidden=\"true\"\n >*</span\n >\n </label>\n <NbMessage\n v-if=\"helper && !error && !warning\"\n variant=\"helper\"\n :icon-only=\"true\"\n class=\"nb-select__inner-message\"\n >{{ helper }}</NbMessage\n >\n </NbGrid>\n <NbGrid dir=\"row\" align=\"end\" flex class=\"nb-select__value-row\">\n <span\n :class=\"[\n 'nb-select__value',\n { 'nb-select__value--placeholder': !displayValue },\n ]\"\n >\n {{ displayValue || placeholder }}\n </span>\n <NbGrid align=\"center\" justify=\"center\" class=\"nb-select__caret\">\n <NbIcon :name=\"isOpen ? 'caret-up' : 'caret-down'\" :size=\"16\" />\n </NbGrid>\n </NbGrid>\n </button>\n\n <NbMessage\n v-if=\"error\"\n variant=\"error\"\n class=\"nb-select__fluid-message\"\n >{{ error }}</NbMessage\n >\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n class=\"nb-select__fluid-message\"\n >{{ warning }}</NbMessage\n >\n </template>\n </div>\n\n <!-- Dropdown teleported to body to escape overflow:hidden parents -->\n <Teleport to=\"body\">\n <div\n v-if=\"isOpen\"\n ref=\"dropdownRef\"\n class=\"nb-select__dropdown\"\n :style=\"dropdownStyle\"\n role=\"listbox\"\n :aria-multiselectable=\"multiple || undefined\"\n >\n <div\n v-for=\"(option, idx) in options\"\n :key=\"option.value\"\n :class=\"[\n 'nb-select__option',\n {\n 'nb-select__option--selected': isSelected(option.value),\n 'nb-select__option--highlighted': highlighted === idx,\n 'nb-select__option--disabled': option.disabled,\n },\n ]\"\n role=\"option\"\n :aria-selected=\"isSelected(option.value)\"\n :aria-disabled=\"option.disabled || undefined\"\n @mouseenter=\"highlighted = idx\"\n @click=\"selectOption(option)\"\n >\n <span\n v-if=\"multiple\"\n class=\"nb-select__option-check\"\n aria-hidden=\"true\"\n >\n <svg\n v-if=\"isSelected(option.value)\"\n viewBox=\"0 0 10 8\"\n fill=\"none\"\n width=\"10\"\n height=\"8\"\n >\n <path\n d=\"M1 4l3 3 5-6\"\n stroke=\"currentColor\"\n stroke-width=\"1.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n />\n </svg>\n </span>\n <span class=\"nb-select__option-label\">{{ option.label }}</span>\n </div>\n <div v-if=\"!options || options.length === 0\" class=\"nb-select__empty\">\n No options\n </div>\n </div>\n </Teleport>\n</template>\n\n<script setup lang=\"ts\">\nimport { ref, computed, watch, nextTick, onBeforeUnmount, useId } from 'vue'\nimport { ISelectOption, ISelectProps } from './Select'\n\nconst props = withDefaults(defineProps<ISelectProps>(), {\n modelValue: null,\n options: () => [],\n multiple: false,\n variant: 'default',\n size: 'md',\n label: '',\n placeholder: 'Select…',\n helper: '',\n error: '',\n warning: '',\n disabled: false,\n required: false,\n id: undefined,\n name: '',\n})\n\nconst emit = defineEmits<{\n 'update:modelValue': [value: string | number | Array<string | number> | null]\n change: [value: string | number | Array<string | number> | null]\n}>()\n\nconst isOpen = ref(false)\nconst focused = ref(false)\nconst highlighted = ref(-1)\nconst rootRef = ref<HTMLElement | null>(null)\nconst triggerRef = ref<HTMLElement | null>(null)\nconst dropdownRef = ref<HTMLElement | null>(null)\nconst dropdownStyle = ref({\n position: 'fixed' as const,\n top: '0px',\n left: '0px',\n width: '0px',\n zIndex: '9999',\n})\n\nconst autoId = `nb-select-${useId()}`\nconst inputId = computed(() => props.id ?? autoId)\n\nconst selectedValues = computed<Array<string | number>>(() => {\n if (props.modelValue == null) return []\n return Array.isArray(props.modelValue) ? props.modelValue : [props.modelValue]\n})\n\nconst displayValue = computed(() => {\n if (selectedValues.value.length === 0) return ''\n const opts = props.options ?? []\n if (props.multiple) {\n if (selectedValues.value.length === 1) {\n return (\n opts.find((o) => o.value === selectedValues.value[0])?.label ??\n String(selectedValues.value[0])\n )\n }\n if (selectedValues.value.length === 2) {\n return selectedValues.value\n .map((v) => opts.find((o) => o.value === v)?.label ?? String(v))\n .join(', ')\n }\n return `${selectedValues.value.length} selected`\n }\n return (\n opts.find((o) => o.value === selectedValues.value[0])?.label ??\n String(selectedValues.value[0])\n )\n})\n\nfunction isSelected(value: string | number) {\n return selectedValues.value.includes(value)\n}\n\nfunction selectOption(option: ISelectOption) {\n if (option.disabled) return\n let next: string | number | Array<string | number> | null\n if (props.multiple) {\n const arr = [...selectedValues.value]\n const idx = arr.indexOf(option.value)\n if (idx >= 0) arr.splice(idx, 1)\n else arr.push(option.value)\n next = arr\n } else {\n next = option.value\n closeDropdown()\n }\n emit('update:modelValue', next)\n emit('change', next)\n}\n\nfunction updateDropdownPosition() {\n if (!triggerRef.value) return\n const rect = triggerRef.value.getBoundingClientRect()\n dropdownStyle.value = {\n position: 'fixed',\n top: `${rect.bottom}px`,\n left: `${rect.left}px`,\n width: `${rect.width}px`,\n zIndex: '9999',\n }\n}\n\nfunction openDropdown() {\n if (props.disabled) return\n isOpen.value = true\n updateDropdownPosition()\n const opts = props.options ?? []\n highlighted.value =\n selectedValues.value.length > 0\n ? Math.max(\n 0,\n opts.findIndex((o) => o.value === selectedValues.value[0]),\n )\n : -1\n nextTick(scrollToHighlighted)\n}\n\nfunction closeDropdown() {\n isOpen.value = false\n highlighted.value = -1\n}\n\nfunction toggleDropdown() {\n if (isOpen.value) closeDropdown()\n else openDropdown()\n}\n\nfunction onClickOutside(e: MouseEvent) {\n const target = e.target as Node\n const inRoot = rootRef.value?.contains(target) ?? false\n const inDropdown = dropdownRef.value?.contains(target) ?? false\n if (!inRoot && !inDropdown) closeDropdown()\n}\n\nfunction onScrollOrResize() {\n if (isOpen.value) updateDropdownPosition()\n}\n\nwatch(isOpen, (val) => {\n if (val) {\n document.addEventListener('mousedown', onClickOutside)\n window.addEventListener('scroll', onScrollOrResize, true)\n window.addEventListener('resize', onScrollOrResize)\n } else {\n document.removeEventListener('mousedown', onClickOutside)\n window.removeEventListener('scroll', onScrollOrResize, true)\n window.removeEventListener('resize', onScrollOrResize)\n }\n})\n\nonBeforeUnmount(() => {\n document.removeEventListener('mousedown', onClickOutside)\n window.removeEventListener('scroll', onScrollOrResize, true)\n window.removeEventListener('resize', onScrollOrResize)\n})\n\nfunction onKeydown(e: KeyboardEvent) {\n const opts = props.options ?? []\n if (!isOpen.value) {\n if (e.key === 'Enter' || e.key === ' ' || e.key === 'ArrowDown') {\n e.preventDefault()\n openDropdown()\n }\n return\n }\n if (e.key === 'Escape') {\n closeDropdown()\n e.preventDefault()\n } else if (e.key === 'Tab') {\n closeDropdown()\n } else if (e.key === 'ArrowDown') {\n e.preventDefault()\n highlighted.value = Math.min(highlighted.value + 1, opts.length - 1)\n scrollToHighlighted()\n } else if (e.key === 'ArrowUp') {\n e.preventDefault()\n highlighted.value = Math.max(highlighted.value - 1, 0)\n scrollToHighlighted()\n } else if ((e.key === 'Enter' || e.key === ' ') && highlighted.value >= 0) {\n e.preventDefault()\n selectOption(opts[highlighted.value])\n }\n}\n\nfunction scrollToHighlighted() {\n nextTick(() => {\n if (!dropdownRef.value || highlighted.value < 0) return\n const item =\n dropdownRef.value.querySelectorAll<HTMLElement>('.nb-select__option')[\n highlighted.value\n ]\n item?.scrollIntoView({ block: 'nearest' })\n })\n}\n\nconst rootClasses = computed(() => [\n 'nb-select',\n `nb-select--${props.variant}`,\n `nb-select--${props.size}`,\n {\n 'nb-select--open': isOpen.value,\n 'nb-select--focused': focused.value && !isOpen.value,\n 'nb-select--error': !!props.error,\n 'nb-select--warning': !props.error && !!props.warning,\n 'nb-select--multiple': props.multiple,\n },\n])\n\ndefineExpose({\n open: openDropdown,\n close: closeDropdown,\n})\n</script>\n\n<style lang=\"scss\">\n// Dropdown is teleported to body: cannot use scoped styles\n.nb-select__dropdown {\n background: var(--nb-c-field-bg, var(--nb-c-french-gray-100, #f4f4f4));\n border: 1px solid\n var(--nb-c-field-border, var(--nb-c-french-gray-500, #a7a7a7));\n max-height: 240px;\n overflow-y: auto;\n overscroll-behavior: contain;\n box-sizing: border-box;\n box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);\n}\n\n.nb-select__option {\n display: flex;\n align-items: center;\n gap: 8px;\n padding: 10px 16px;\n font-size: 14px;\n font-weight: 400;\n color: var(--nb-c-text, #161616);\n cursor: pointer;\n position: relative;\n transition: background 0.1s;\n\n &::after {\n content: '';\n position: absolute;\n bottom: 0;\n left: 16px;\n right: 16px;\n height: 1px;\n background: var(--nb-c-component-plain-border);\n }\n\n &:last-child::after {\n display: none;\n }\n\n &--highlighted {\n background: color-mix(in srgb, var(--nb-c-primary) 8%, transparent);\n }\n\n &--selected {\n background: var(--nb-c-primary, #5856a9);\n color: var(--nb-c-surface);\n font-weight: 500;\n\n .nb-select__option-check {\n color: var(--nb-c-surface);\n }\n }\n\n &--selected.nb-select__option--highlighted {\n background: color-mix(in srgb, var(--nb-c-primary, #5856a9) 85%, black);\n }\n\n &--disabled {\n opacity: 0.45;\n cursor: not-allowed;\n }\n}\n\n.nb-select__option-check {\n width: 14px;\n flex-shrink: 0;\n color: var(--nb-c-primary, #5856a9);\n display: flex;\n align-items: center;\n}\n\n.nb-select__option-label {\n flex: 1;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n}\n\n.nb-select__empty {\n padding: 12px 16px;\n font-size: 14px;\n color: var(--nb-c-text-subtle, var(--nb-c-nouveau-gray-500, #6b7280));\n text-align: center;\n}\n\n.nb-select {\n position: relative;\n display: flex;\n flex-direction: column;\n gap: 6px;\n font-family: var(--nb-font-family-sans, sans-serif);\n --field-h: var(--nb-field-height-md);\n\n &--sm {\n --field-h: var(--nb-field-height-sm);\n }\n &--md {\n --field-h: var(--nb-field-height-md);\n }\n &--lg {\n --field-h: var(--nb-field-height-lg);\n }\n\n &__trigger {\n position: relative;\n display: flex;\n align-items: center;\n width: 100%;\n height: var(--field-h);\n padding: 0 var(--nb-field-padding-h);\n gap: 8px;\n background: var(--nb-c-field-bg);\n border: none;\n border-bottom: 1px solid var(--nb-c-field-border);\n border-radius: 0;\n cursor: pointer;\n user-select: none;\n font: inherit;\n text-align: left;\n appearance: none;\n transition:\n border-color 0.15s,\n box-shadow 0.15s,\n background 0.15s;\n outline: none;\n box-sizing: border-box;\n\n &:hover:not(:disabled) {\n background: color-mix(\n in srgb,\n var(--nb-c-field-border) 15%,\n var(--nb-c-field-bg)\n );\n border-bottom-color: color-mix(\n in srgb,\n var(--nb-c-primary) 50%,\n var(--nb-c-field-border)\n );\n }\n\n &:disabled {\n opacity: var(--nb-field-disabled-opacity);\n cursor: not-allowed;\n }\n }\n\n &--focused &__trigger {\n outline: 2px solid var(--nb-c-primary);\n outline-offset: -2px;\n }\n\n &--open &__trigger {\n outline: none;\n }\n\n &--error &__trigger {\n border: 1px solid var(--nb-c-danger);\n box-shadow: none;\n }\n\n &--warning &__trigger {\n border: 1px solid var(--nb-c-warning);\n box-shadow: none;\n }\n\n &__value {\n flex: 1;\n min-width: 0;\n font-size: var(--nb-c-field-font-size);\n font-weight: 400;\n line-height: 1.5;\n color: var(--nb-c-text);\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n\n &--placeholder {\n color: var(--nb-c-text-subtle);\n }\n }\n\n &__status-icon {\n flex-shrink: 0;\n .nb-message__tooltip {\n z-index: calc(var(--nb-zindex-tooltip, 401) + 1);\n }\n }\n\n &__caret {\n flex-shrink: 0;\n color: var(--nb-c-field-border);\n transition: color 0.15s;\n\n .nb-select--open & {\n color: var(--nb-c-primary);\n }\n .nb-select--error & {\n color: var(--nb-c-danger);\n }\n .nb-select--warning & {\n color: var(--nb-c-warning);\n }\n }\n\n &__message,\n &__fluid-message {\n font-size: var(--nb-font-size-12);\n }\n\n &--fluid {\n .nb-select__trigger {\n flex: 1;\n flex-direction: column;\n align-items: stretch;\n justify-content: space-between;\n height: auto;\n min-height: calc(var(--nb-base-unit) * 8);\n padding: calc(var(--nb-base-unit) * 1) 0 0;\n gap: 0;\n }\n\n .nb-select__inner-header {\n padding: 0 var(--nb-field-padding-h);\n margin-bottom: 4px;\n }\n\n .nb-select__inner-label {\n flex: 1;\n min-width: 0;\n font-size: var(--nb-font-size-12);\n font-weight: 500;\n color: var(--nb-c-text-muted);\n letter-spacing: 0.02em;\n cursor: default;\n user-select: none;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n\n .nb-select__asterisk {\n color: var(--nb-c-danger);\n }\n\n .nb-select__inner-message {\n flex-shrink: 0;\n }\n\n .nb-select__value-row {\n padding: 0 0 10px;\n }\n\n .nb-select__value {\n flex: 1;\n padding: 0 var(--nb-field-padding-h);\n font-size: var(--nb-font-size-14);\n }\n\n .nb-select__caret {\n position: static;\n width: auto;\n height: auto;\n padding: 0 var(--nb-field-padding-h);\n }\n }\n}\n</style>\n","<template>\n <div ref=\"rootRef\" :class=\"rootClasses\" @keydown=\"onKeydown\">\n <!-- DEFAULT variant -->\n <template v-if=\"variant === 'default'\">\n <slot v-if=\"$slots.label\" name=\"label\" />\n <NbLabel\n v-else-if=\"label\"\n :for=\"inputId\"\n :required=\"required\"\n :disabled=\"disabled\"\n >{{ label }}</NbLabel\n >\n\n <button\n :id=\"inputId\"\n ref=\"triggerRef\"\n type=\"button\"\n class=\"nb-select__trigger\"\n role=\"combobox\"\n :aria-expanded=\"isOpen\"\n :aria-haspopup=\"'listbox'\"\n :aria-disabled=\"disabled || undefined\"\n :aria-required=\"required || undefined\"\n :disabled=\"disabled || undefined\"\n @click=\"toggleDropdown\"\n @focus=\"focused = true\"\n @blur=\"focused = false\"\n >\n <span\n :class=\"[\n 'nb-select__value',\n { 'nb-select__value--placeholder': !displayValue },\n ]\"\n >\n {{ displayValue || placeholder }}\n </span>\n <NbMessage\n v-if=\"error\"\n variant=\"error\"\n :icon-only=\"true\"\n class=\"nb-select__status-icon\"\n >{{ error }}</NbMessage\n >\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n :icon-only=\"true\"\n class=\"nb-select__status-icon\"\n >{{ warning }}</NbMessage\n >\n <NbGrid align=\"center\" justify=\"center\" class=\"nb-select__caret\">\n <NbIcon :name=\"isOpen ? 'caret-up' : 'caret-down'\" :size=\"16\" />\n </NbGrid>\n </button>\n\n <NbMessage v-if=\"error\" variant=\"error\" class=\"nb-select__message\">{{\n error\n }}</NbMessage>\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n class=\"nb-select__message\"\n >{{ warning }}</NbMessage\n >\n <NbMessage\n v-else-if=\"helper\"\n variant=\"helper\"\n class=\"nb-select__message\"\n >{{ helper }}</NbMessage\n >\n </template>\n\n <!-- FLUID variant -->\n <template v-else-if=\"variant === 'fluid'\">\n <button\n :id=\"inputId\"\n ref=\"triggerRef\"\n type=\"button\"\n class=\"nb-select__trigger\"\n role=\"combobox\"\n :aria-expanded=\"isOpen\"\n :aria-haspopup=\"'listbox'\"\n :aria-disabled=\"disabled || undefined\"\n :aria-required=\"required || undefined\"\n :disabled=\"disabled || undefined\"\n @click=\"toggleDropdown\"\n @focus=\"focused = true\"\n @blur=\"focused = false\"\n >\n <NbGrid\n v-if=\"label || $slots.label\"\n dir=\"row\"\n align=\"center\"\n gap=\"xs\"\n class=\"nb-select__inner-header\"\n >\n <slot v-if=\"$slots.label\" name=\"label\" />\n <label v-else class=\"nb-select__inner-label\">\n {{ label }}\n <span v-if=\"required\" class=\"nb-select__asterisk\" aria-hidden=\"true\"\n >*</span\n >\n </label>\n <NbMessage\n v-if=\"helper && !error && !warning\"\n variant=\"helper\"\n :icon-only=\"true\"\n class=\"nb-select__inner-message\"\n >{{ helper }}</NbMessage\n >\n </NbGrid>\n <NbGrid dir=\"row\" align=\"end\" flex class=\"nb-select__value-row\">\n <span\n :class=\"[\n 'nb-select__value',\n { 'nb-select__value--placeholder': !displayValue },\n ]\"\n >\n {{ displayValue || placeholder }}\n </span>\n <NbGrid align=\"center\" justify=\"center\" class=\"nb-select__caret\">\n <NbIcon :name=\"isOpen ? 'caret-up' : 'caret-down'\" :size=\"16\" />\n </NbGrid>\n </NbGrid>\n </button>\n\n <NbMessage\n v-if=\"error\"\n variant=\"error\"\n class=\"nb-select__fluid-message\"\n >{{ error }}</NbMessage\n >\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n class=\"nb-select__fluid-message\"\n >{{ warning }}</NbMessage\n >\n </template>\n </div>\n\n <!-- Dropdown teleported to body to escape overflow:hidden parents -->\n <Teleport to=\"body\">\n <div\n v-if=\"isOpen\"\n ref=\"dropdownRef\"\n class=\"nb-select__dropdown\"\n :style=\"dropdownStyle\"\n role=\"listbox\"\n :aria-multiselectable=\"multiple || undefined\"\n >\n <div\n v-for=\"(option, idx) in options\"\n :key=\"option.value\"\n :class=\"[\n 'nb-select__option',\n {\n 'nb-select__option--selected': isSelected(option.value),\n 'nb-select__option--highlighted': highlighted === idx,\n 'nb-select__option--disabled': option.disabled,\n },\n ]\"\n role=\"option\"\n :aria-selected=\"isSelected(option.value)\"\n :aria-disabled=\"option.disabled || undefined\"\n @mouseenter=\"highlighted = idx\"\n @click=\"selectOption(option)\"\n >\n <span\n v-if=\"multiple\"\n class=\"nb-select__option-check\"\n aria-hidden=\"true\"\n >\n <svg\n v-if=\"isSelected(option.value)\"\n viewBox=\"0 0 10 8\"\n fill=\"none\"\n width=\"10\"\n height=\"8\"\n >\n <path\n d=\"M1 4l3 3 5-6\"\n stroke=\"currentColor\"\n stroke-width=\"1.5\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n />\n </svg>\n </span>\n <span class=\"nb-select__option-label\">{{ option.label }}</span>\n </div>\n <div v-if=\"!options || options.length === 0\" class=\"nb-select__empty\">\n No options\n </div>\n </div>\n </Teleport>\n</template>\n\n<script setup lang=\"ts\">\nimport { ref, computed, watch, nextTick, onBeforeUnmount, useId } from 'vue'\nimport { ISelectOption, ISelectProps } from './Select'\n\nconst props = withDefaults(defineProps<ISelectProps>(), {\n modelValue: null,\n options: () => [],\n multiple: false,\n variant: 'default',\n size: 'md',\n label: '',\n placeholder: 'Select…',\n helper: '',\n error: '',\n warning: '',\n disabled: false,\n required: false,\n id: undefined,\n name: '',\n})\n\nconst emit = defineEmits<{\n 'update:modelValue': [value: string | number | Array<string | number> | null]\n change: [value: string | number | Array<string | number> | null]\n}>()\n\nconst isOpen = ref(false)\nconst focused = ref(false)\nconst highlighted = ref(-1)\nconst rootRef = ref<HTMLElement | null>(null)\nconst triggerRef = ref<HTMLElement | null>(null)\nconst dropdownRef = ref<HTMLElement | null>(null)\nconst dropdownStyle = ref({\n position: 'fixed' as const,\n top: '0px',\n left: '0px',\n width: '0px',\n zIndex: '9999',\n})\n\nconst autoId = `nb-select-${useId()}`\nconst inputId = computed(() => props.id ?? autoId)\n\nconst selectedValues = computed<Array<string | number>>(() => {\n if (props.modelValue == null) return []\n return Array.isArray(props.modelValue) ? props.modelValue : [props.modelValue]\n})\n\nconst displayValue = computed(() => {\n if (selectedValues.value.length === 0) return ''\n const opts = props.options ?? []\n if (props.multiple) {\n if (selectedValues.value.length === 1) {\n return (\n opts.find((o) => o.value === selectedValues.value[0])?.label ??\n String(selectedValues.value[0])\n )\n }\n if (selectedValues.value.length === 2) {\n return selectedValues.value\n .map((v) => opts.find((o) => o.value === v)?.label ?? String(v))\n .join(', ')\n }\n return `${selectedValues.value.length} selected`\n }\n return (\n opts.find((o) => o.value === selectedValues.value[0])?.label ??\n String(selectedValues.value[0])\n )\n})\n\nfunction isSelected(value: string | number) {\n return selectedValues.value.includes(value)\n}\n\nfunction selectOption(option: ISelectOption) {\n if (option.disabled) return\n let next: string | number | Array<string | number> | null\n if (props.multiple) {\n const arr = [...selectedValues.value]\n const idx = arr.indexOf(option.value)\n if (idx >= 0) arr.splice(idx, 1)\n else arr.push(option.value)\n next = arr\n } else {\n next = option.value\n closeDropdown()\n }\n emit('update:modelValue', next)\n emit('change', next)\n}\n\nfunction updateDropdownPosition() {\n if (!triggerRef.value) return\n const rect = triggerRef.value.getBoundingClientRect()\n dropdownStyle.value = {\n position: 'fixed',\n top: `${rect.bottom}px`,\n left: `${rect.left}px`,\n width: `${rect.width}px`,\n zIndex: '9999',\n }\n}\n\nfunction openDropdown() {\n if (props.disabled) return\n isOpen.value = true\n updateDropdownPosition()\n const opts = props.options ?? []\n highlighted.value =\n selectedValues.value.length > 0\n ? Math.max(\n 0,\n opts.findIndex((o) => o.value === selectedValues.value[0]),\n )\n : -1\n nextTick(scrollToHighlighted)\n}\n\nfunction closeDropdown() {\n isOpen.value = false\n highlighted.value = -1\n}\n\nfunction toggleDropdown() {\n if (isOpen.value) closeDropdown()\n else openDropdown()\n}\n\nfunction onClickOutside(e: MouseEvent) {\n const target = e.target as Node\n const inRoot = rootRef.value?.contains(target) ?? false\n const inDropdown = dropdownRef.value?.contains(target) ?? false\n if (!inRoot && !inDropdown) closeDropdown()\n}\n\nfunction onScrollOrResize() {\n if (isOpen.value) updateDropdownPosition()\n}\n\nwatch(isOpen, (val) => {\n if (val) {\n document.addEventListener('mousedown', onClickOutside)\n window.addEventListener('scroll', onScrollOrResize, true)\n window.addEventListener('resize', onScrollOrResize)\n } else {\n document.removeEventListener('mousedown', onClickOutside)\n window.removeEventListener('scroll', onScrollOrResize, true)\n window.removeEventListener('resize', onScrollOrResize)\n }\n})\n\nonBeforeUnmount(() => {\n document.removeEventListener('mousedown', onClickOutside)\n window.removeEventListener('scroll', onScrollOrResize, true)\n window.removeEventListener('resize', onScrollOrResize)\n})\n\nfunction onKeydown(e: KeyboardEvent) {\n const opts = props.options ?? []\n if (!isOpen.value) {\n if (e.key === 'Enter' || e.key === ' ' || e.key === 'ArrowDown') {\n e.preventDefault()\n openDropdown()\n }\n return\n }\n if (e.key === 'Escape') {\n closeDropdown()\n e.preventDefault()\n } else if (e.key === 'Tab') {\n closeDropdown()\n } else if (e.key === 'ArrowDown') {\n e.preventDefault()\n highlighted.value = Math.min(highlighted.value + 1, opts.length - 1)\n scrollToHighlighted()\n } else if (e.key === 'ArrowUp') {\n e.preventDefault()\n highlighted.value = Math.max(highlighted.value - 1, 0)\n scrollToHighlighted()\n } else if ((e.key === 'Enter' || e.key === ' ') && highlighted.value >= 0) {\n e.preventDefault()\n selectOption(opts[highlighted.value])\n }\n}\n\nfunction scrollToHighlighted() {\n nextTick(() => {\n if (!dropdownRef.value || highlighted.value < 0) return\n const item =\n dropdownRef.value.querySelectorAll<HTMLElement>('.nb-select__option')[\n highlighted.value\n ]\n item?.scrollIntoView({ block: 'nearest' })\n })\n}\n\nconst rootClasses = computed(() => [\n 'nb-select',\n `nb-select--${props.variant}`,\n `nb-select--${props.size}`,\n {\n 'nb-select--open': isOpen.value,\n 'nb-select--focused': focused.value && !isOpen.value,\n 'nb-select--error': !!props.error,\n 'nb-select--warning': !props.error && !!props.warning,\n 'nb-select--multiple': props.multiple,\n },\n])\n\ndefineExpose({\n open: openDropdown,\n close: closeDropdown,\n})\n</script>\n\n<style lang=\"scss\">\n// Dropdown is teleported to body: cannot use scoped styles\n.nb-select__dropdown {\n background: var(--nb-c-field-bg, var(--nb-c-french-gray-100, #f4f4f4));\n border: 1px solid\n var(--nb-c-field-border, var(--nb-c-french-gray-500, #a7a7a7));\n max-height: 240px;\n overflow-y: auto;\n overscroll-behavior: contain;\n box-sizing: border-box;\n box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);\n}\n\n.nb-select__option {\n display: flex;\n align-items: center;\n gap: 8px;\n padding: 10px 16px;\n font-size: 14px;\n font-weight: 400;\n color: var(--nb-c-text, #161616);\n cursor: pointer;\n position: relative;\n transition: background 0.1s;\n\n &::after {\n content: '';\n position: absolute;\n bottom: 0;\n left: 16px;\n right: 16px;\n height: 1px;\n background: var(--nb-c-component-plain-border);\n }\n\n &:last-child::after {\n display: none;\n }\n\n &--highlighted {\n background: color-mix(in srgb, var(--nb-c-primary) 8%, transparent);\n }\n\n &--selected {\n background: var(--nb-c-primary, #5856a9);\n color: var(--nb-c-surface);\n font-weight: 500;\n\n .nb-select__option-check {\n color: var(--nb-c-surface);\n }\n }\n\n &--selected.nb-select__option--highlighted {\n background: color-mix(in srgb, var(--nb-c-primary, #5856a9) 85%, black);\n }\n\n &--disabled {\n opacity: 0.45;\n cursor: not-allowed;\n }\n}\n\n.nb-select__option-check {\n width: 14px;\n flex-shrink: 0;\n color: var(--nb-c-primary, #5856a9);\n display: flex;\n align-items: center;\n}\n\n.nb-select__option-label {\n flex: 1;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n}\n\n.nb-select__empty {\n padding: 12px 16px;\n font-size: 14px;\n color: var(--nb-c-text-subtle, var(--nb-c-nouveau-gray-500, #6b7280));\n text-align: center;\n}\n\n.nb-select {\n position: relative;\n display: flex;\n flex-direction: column;\n gap: 6px;\n font-family: var(--nb-font-family-sans, sans-serif);\n --field-h: var(--nb-field-height-md);\n\n &--sm {\n --field-h: var(--nb-field-height-sm);\n }\n &--md {\n --field-h: var(--nb-field-height-md);\n }\n &--lg {\n --field-h: var(--nb-field-height-lg);\n }\n\n &__trigger {\n position: relative;\n display: flex;\n align-items: center;\n width: 100%;\n height: var(--field-h);\n padding: 0 var(--nb-field-padding-h);\n gap: 8px;\n background: var(--nb-c-field-bg);\n border: none;\n border-bottom: 1px solid var(--nb-c-field-border);\n border-radius: 0;\n cursor: pointer;\n user-select: none;\n font: inherit;\n text-align: left;\n appearance: none;\n transition:\n border-color 0.15s,\n box-shadow 0.15s,\n background 0.15s;\n outline: none;\n box-sizing: border-box;\n\n &:hover:not(:disabled) {\n background: color-mix(\n in srgb,\n var(--nb-c-field-border) 15%,\n var(--nb-c-field-bg)\n );\n border-bottom-color: color-mix(\n in srgb,\n var(--nb-c-primary) 50%,\n var(--nb-c-field-border)\n );\n }\n\n &:disabled {\n opacity: var(--nb-field-disabled-opacity);\n cursor: not-allowed;\n }\n }\n\n &--focused &__trigger {\n outline: 2px solid var(--nb-c-primary);\n outline-offset: -2px;\n }\n\n &--open &__trigger {\n outline: none;\n }\n\n &--error &__trigger {\n border: 1px solid var(--nb-c-danger);\n box-shadow: none;\n }\n\n &--warning &__trigger {\n border: 1px solid var(--nb-c-warning);\n box-shadow: none;\n }\n\n &__value {\n flex: 1;\n min-width: 0;\n font-size: var(--nb-c-field-font-size);\n font-weight: 400;\n line-height: 1.5;\n color: var(--nb-c-text);\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n\n &--placeholder {\n color: var(--nb-c-text-subtle);\n }\n }\n\n &__status-icon {\n flex-shrink: 0;\n .nb-message__tooltip {\n z-index: calc(var(--nb-zindex-tooltip, 401) + 1);\n }\n }\n\n &__caret {\n flex-shrink: 0;\n color: var(--nb-c-field-border);\n transition: color 0.15s;\n\n .nb-select--open & {\n color: var(--nb-c-primary);\n }\n .nb-select--error & {\n color: var(--nb-c-danger);\n }\n .nb-select--warning & {\n color: var(--nb-c-warning);\n }\n }\n\n &__message,\n &__fluid-message {\n font-size: var(--nb-font-size-12);\n }\n\n &--fluid {\n .nb-select__trigger {\n flex: 1;\n flex-direction: column;\n align-items: stretch;\n justify-content: space-between;\n height: auto;\n min-height: calc(var(--nb-base-unit) * 8);\n padding: calc(var(--nb-base-unit) * 1) 0 0;\n gap: 0;\n }\n\n .nb-select__inner-header {\n padding: 0 var(--nb-field-padding-h);\n margin-bottom: 4px;\n }\n\n .nb-select__inner-label {\n flex: 1;\n min-width: 0;\n font-size: var(--nb-font-size-12);\n font-weight: 500;\n color: var(--nb-c-text-muted);\n letter-spacing: 0.02em;\n cursor: default;\n user-select: none;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n\n .nb-select__asterisk {\n color: var(--nb-c-danger);\n }\n\n .nb-select__inner-message {\n flex-shrink: 0;\n }\n\n .nb-select__value-row {\n padding: 0 0 10px;\n }\n\n .nb-select__value {\n flex: 1;\n padding: 0 var(--nb-field-padding-h);\n font-size: var(--nb-font-size-14);\n }\n\n .nb-select__caret {\n position: static;\n width: auto;\n height: auto;\n padding: 0 var(--nb-field-padding-h);\n }\n }\n}\n</style>\n","<template>\n <div :class=\"rootClasses\">\n <!-- DEFAULT variant: label above -->\n <NbLabel v-if=\"variant === 'default' && label\" class=\"nb-slider__label\">{{\n label\n }}</NbLabel>\n\n <!-- Field box: display:contents in default (passthrough), styled in fluid -->\n <div class=\"nb-slider__field-box\">\n <!-- FLUID variant: label inside the box -->\n <div v-if=\"variant === 'fluid' && label\" class=\"nb-slider__inner-header\">\n <label class=\"nb-slider__inner-label\">{{ label }}</label>\n </div>\n\n <NbGrid dir=\"row\" align=\"center\" gap=\"sm\" class=\"nb-slider__row\">\n <!-- Range: low number input on the left -->\n <NbNumberInput\n v-if=\"range && showInput\"\n :size=\"variant === 'fluid' ? 'sm' : size\"\n :model-value=\"lowValue\"\n :min=\"min\"\n :max=\"highValue\"\n :step=\"step\"\n :disabled=\"disabled\"\n class=\"nb-slider__input\"\n @update:model-value=\"onLowInputChange\"\n @change=\"onLowInputChange\"\n />\n\n <!-- Track area -->\n <NbGrid\n dir=\"col\"\n justify=\"end\"\n gap=\"xs\"\n class=\"nb-slider__track-area\"\n :class=\"trackAreaClasses\"\n grow\n >\n <div\n ref=\"trackRef\"\n class=\"nb-slider__track\"\n @mousedown=\"onTrackMousedown\"\n @touchstart.passive=\"onTrackTouchstart\"\n >\n <!-- Filled segment -->\n <div class=\"nb-slider__track__fill\" :style=\"fillStyle\" />\n\n <!-- Single handle (circle) -->\n <div\n v-if=\"!range\"\n class=\"nb-slider__track__handle\"\n :style=\"{ left: `${valueToPercent(singleValue)}%` }\"\n @mousedown.stop=\"onHandleMousedown(null, $event)\"\n @touchstart.stop.passive=\"onHandleTouchstart(null, $event)\"\n />\n\n <!-- Range handles (triangles) -->\n <template v-else>\n <div\n class=\"nb-slider__track__handle nb-slider__track__handle--low\"\n :style=\"{ left: `${valueToPercent(lowValue)}%` }\"\n @mousedown.stop=\"onHandleMousedown('low', $event)\"\n @touchstart.stop.passive=\"onHandleTouchstart('low', $event)\"\n />\n <div\n class=\"nb-slider__track__handle nb-slider__track__handle--high\"\n :style=\"{ left: `${valueToPercent(highValue)}%` }\"\n @mousedown.stop=\"onHandleMousedown('high', $event)\"\n @touchstart.stop.passive=\"onHandleTouchstart('high', $event)\"\n />\n <div class=\"nb-slider__tick\" />\n </template>\n </div>\n\n <!-- Min / max labels below track -->\n <div class=\"nb-slider__track-labels\">\n <span class=\"nb-slider__track-label\">{{ min }}</span>\n <span class=\"nb-slider__track-label\">{{ max }}</span>\n </div>\n </NbGrid>\n\n <!-- Single slider: number input on the right -->\n <!-- Range: high number input on the right -->\n <NbNumberInput\n v-if=\"showInput\"\n :size=\"variant === 'fluid' ? 'sm' : size\"\n :model-value=\"range ? highValue : singleValue\"\n :min=\"range ? lowValue : min\"\n :max=\"max\"\n :step=\"step\"\n :disabled=\"disabled\"\n class=\"nb-slider__input\"\n @update:model-value=\"\n range ? onHighInputChange($event) : onSingleInputChange($event)\n \"\n @change=\"\n range ? onHighInputChange($event) : onSingleInputChange($event)\n \"\n />\n </NbGrid>\n </div>\n <!-- /__field-box -->\n\n <!-- Messages below -->\n <NbMessage v-if=\"error\" variant=\"error\" class=\"nb-slider__message\">{{\n error\n }}</NbMessage>\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n class=\"nb-slider__message\"\n >{{ warning }}</NbMessage\n >\n <NbMessage v-else-if=\"helper\" variant=\"helper\" class=\"nb-slider__message\">{{\n helper\n }}</NbMessage>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed, onBeforeUnmount, ref } from 'vue'\nimport { ESizeShort } from '@/types/Size.d'\nimport type { ISliderProps, TActiveHandle } from './Slider.d'\n\nconst props = withDefaults(defineProps<ISliderProps>(), {\n min: 0,\n max: 100,\n step: 1,\n range: false,\n disabled: false,\n showInput: true,\n size: ESizeShort.Medium,\n variant: 'default',\n})\n\nconst emit = defineEmits<{\n 'update:modelValue': [value: number | [number, number]]\n change: [value: number | [number, number]]\n}>()\n\nconst trackRef = ref<HTMLElement | null>(null)\n\nconst activeHandle = ref<TActiveHandle>(null)\n\n// Derived values\nconst singleValue = computed<number>(() => {\n if (\n props.range ||\n props.modelValue === null ||\n props.modelValue === undefined\n ) {\n return props.min ?? 0\n }\n if (Array.isArray(props.modelValue))\n return (props.modelValue[0] as number) ?? props.min ?? 0\n return props.modelValue as number\n})\n\nconst lowValue = computed<number>(() => {\n if (!props.range || !Array.isArray(props.modelValue)) return props.min ?? 0\n return (props.modelValue as [number, number])[0] ?? props.min ?? 0\n})\n\nconst highValue = computed<number>(() => {\n if (!props.range || !Array.isArray(props.modelValue)) return props.max ?? 100\n return (props.modelValue as [number, number])[1] ?? props.max ?? 100\n})\n\n// Track helpers\nfunction valueToPercent(v: number): number {\n const minV = props.min ?? 0\n const maxV = props.max ?? 100\n if (maxV === minV) return 0\n return ((v - minV) / (maxV - minV)) * 100\n}\n\nfunction percentToValue(pct: number): number {\n const minV = props.min ?? 0\n const maxV = props.max ?? 100\n const stepV = props.step ?? 1\n const raw = minV + (pct / 100) * (maxV - minV)\n const stepped = Math.round(raw / stepV) * stepV\n return Math.max(minV, Math.min(maxV, stepped))\n}\n\nfunction getPercentFromEvent(e: MouseEvent | TouchEvent): number {\n if (!trackRef.value) return 0\n const rect = trackRef.value.getBoundingClientRect()\n const clientX = 'touches' in e ? e.touches[0].clientX : e.clientX\n return Math.max(0, Math.min(100, ((clientX - rect.left) / rect.width) * 100))\n}\n\n// Fill style\nconst fillStyle = computed(() => {\n if (!props.range) {\n return { left: '0%', width: `${valueToPercent(singleValue.value)}%` }\n }\n const leftPct = valueToPercent(lowValue.value)\n const rightPct = valueToPercent(highValue.value)\n return { left: `${leftPct}%`, width: `${rightPct - leftPct}%` }\n})\n\n// Emit helpers\nfunction emitSingle(value: number) {\n emit('update:modelValue', value)\n}\n\nfunction emitRange(low: number, high: number) {\n emit('update:modelValue', [low, high])\n}\n\n// Input change handlers\nfunction onSingleInputChange(val: number | null) {\n if (val === null) return\n const minV = props.min ?? 0\n const maxV = props.max ?? 100\n emitSingle(Math.max(minV, Math.min(maxV, val)))\n}\n\nfunction onLowInputChange(val: number | null) {\n if (val === null) return\n const minV = props.min ?? 0\n const clamped = Math.max(minV, Math.min(highValue.value, val))\n emitRange(clamped, highValue.value)\n}\n\nfunction onHighInputChange(val: number | null) {\n if (val === null) return\n const maxV = props.max ?? 100\n const clamped = Math.max(lowValue.value, Math.min(maxV, val))\n emitRange(lowValue.value, clamped)\n}\n\n// Drag handling\nfunction resolveHandle(pct: number): TActiveHandle {\n if (!props.range) return null\n const lowPct = valueToPercent(lowValue.value)\n const highPct = valueToPercent(highValue.value)\n return Math.abs(pct - lowPct) <= Math.abs(pct - highPct) ? 'low' : 'high'\n}\n\nfunction applyDrag(pct: number) {\n const val = percentToValue(pct)\n if (!props.range) {\n emitSingle(val)\n return\n }\n if (activeHandle.value === 'low') {\n const clamped = Math.min(val, highValue.value)\n emitRange(clamped, highValue.value)\n } else {\n const clamped = Math.max(val, lowValue.value)\n emitRange(lowValue.value, clamped)\n }\n}\n\nfunction onMousemove(e: MouseEvent) {\n if (props.disabled) return\n applyDrag(getPercentFromEvent(e))\n}\n\nfunction onMouseup(e: MouseEvent) {\n if (!props.disabled) {\n const val = props.range\n ? ([lowValue.value, highValue.value] as [number, number])\n : singleValue.value\n emit('change', val)\n applyDrag(getPercentFromEvent(e))\n }\n stopDrag()\n}\n\nfunction onTouchmove(e: TouchEvent) {\n if (props.disabled) return\n applyDrag(getPercentFromEvent(e))\n}\n\nfunction onTouchend(e: TouchEvent) {\n if (!props.disabled) {\n const val = props.range\n ? ([lowValue.value, highValue.value] as [number, number])\n : singleValue.value\n emit('change', val)\n applyDrag(getPercentFromEvent(e))\n }\n stopTouchDrag()\n}\n\nfunction startDrag() {\n document.addEventListener('mousemove', onMousemove)\n document.addEventListener('mouseup', onMouseup)\n}\n\nfunction stopDrag() {\n activeHandle.value = null\n document.removeEventListener('mousemove', onMousemove)\n document.removeEventListener('mouseup', onMouseup)\n}\n\nfunction startTouchDrag() {\n document.addEventListener('touchmove', onTouchmove, { passive: true })\n document.addEventListener('touchend', onTouchend)\n}\n\nfunction stopTouchDrag() {\n activeHandle.value = null\n document.removeEventListener('touchmove', onTouchmove)\n document.removeEventListener('touchend', onTouchend)\n}\n\nfunction onTrackMousedown(e: MouseEvent) {\n if (props.disabled) return\n const pct = getPercentFromEvent(e)\n activeHandle.value = resolveHandle(pct)\n applyDrag(pct)\n startDrag()\n}\n\nfunction onTrackTouchstart(e: TouchEvent) {\n if (props.disabled) return\n const pct = getPercentFromEvent(e)\n activeHandle.value = resolveHandle(pct)\n applyDrag(pct)\n startTouchDrag()\n}\n\nfunction onHandleMousedown(handle: TActiveHandle, _e: MouseEvent) {\n if (props.disabled) return\n activeHandle.value = props.range ? handle : null\n startDrag()\n}\n\nfunction onHandleTouchstart(handle: TActiveHandle, _e: TouchEvent) {\n if (props.disabled) return\n activeHandle.value = props.range ? handle : null\n startTouchDrag()\n}\n\nonBeforeUnmount(() => {\n stopDrag()\n stopTouchDrag()\n})\n\n// CSS classes\nconst rootClasses = computed(() => [\n 'nb-slider',\n `nb-slider--${props.size}`,\n `nb-slider--${props.variant}`,\n {\n 'nb-slider--range': props.range,\n 'nb-slider--disabled': props.disabled,\n 'nb-slider--error': !!props.error,\n 'nb-slider--warning': !props.error && !!props.warning,\n },\n])\n\nconst trackAreaClasses = computed(() => ({\n 'nb-slider__track-area--error': !!props.error,\n 'nb-slider__track-area--warning': !props.error && !!props.warning,\n}))\n</script>\n\n<style scoped lang=\"scss\">\n.nb-slider {\n display: flex;\n flex-direction: column;\n flex: 1;\n gap: 6px;\n font-family: var(--nb-font-family-sans, sans-serif);\n\n &--disabled {\n opacity: var(--nb-field-disabled-opacity);\n pointer-events: none;\n }\n\n &__label {\n // label sits outside the row, handled by NbLabel default layout\n }\n\n // ── Field box: invisible passthrough in default, field container in fluid ──\n &__field-box {\n display: contents; // default: children participate directly in .nb-slider's flex\n }\n\n // ── Fluid variant ───────────────────────────────────────────────────────────\n &--fluid {\n gap: 4px;\n\n .nb-slider__field-box {\n display: flex;\n flex: 1;\n flex-direction: column;\n justify-content: space-between;\n background: var(--nb-c-field-bg);\n border-bottom: 1px solid var(--nb-c-field-border);\n padding-top: calc(var(--nb-base-unit) * 1);\n min-height: calc(var(--nb-base-unit) * 8);\n }\n\n .nb-slider__inner-header {\n display: flex;\n align-items: center;\n padding: 0 var(--nb-field-padding-h);\n margin-bottom: 4px;\n }\n\n .nb-slider__inner-label {\n flex: 1;\n min-width: 0;\n font-family: var(--nb-font-family-sans);\n font-size: var(--nb-font-size-12);\n font-weight: 500;\n color: var(--nb-c-text-muted);\n letter-spacing: 0.02em;\n cursor: default;\n user-select: none;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n\n .nb-slider__row {\n padding: 0 var(--nb-field-padding-h) 4px;\n }\n\n // Strip the inner NbNumberInput's own field-box appearance\n .nb-slider__input :deep(.nb-number-input__field-wrapper) {\n background: transparent;\n border-bottom: none;\n }\n }\n\n &__row {\n // layout owned by NbGrid (dir=\"row\", align=\"center\", gap=\"sm\")\n }\n\n &__input {\n flex: 0 0 auto;\n width: 160px;\n }\n\n // Track area: fills remaining space\n &__track-area {\n // flex: 1;\n min-width: 80px;\n // display: flex;\n // flex-direction: column;\n // justify-content: center;\n // gap: 3px;\n\n // Colored underline below track for error/warning\n &--error .nb-slider__track::after {\n content: '';\n position: absolute;\n bottom: -4px;\n left: 0;\n right: 0;\n height: 2px;\n background: var(--nb-c-danger);\n }\n\n &--warning .nb-slider__track::after {\n content: '';\n position: absolute;\n bottom: -4px;\n left: 0;\n right: 0;\n height: 2px;\n background: var(--nb-c-warning);\n }\n }\n\n // Track\n &__track {\n position: relative;\n height: 2px;\n background: var(--nb-c-field-border);\n cursor: pointer;\n margin: 5px 0;\n\n &__fill {\n position: absolute;\n height: 2px;\n background: var(--nb-c-text);\n top: 0;\n pointer-events: none;\n }\n\n &__handle {\n position: absolute;\n width: 14px;\n height: 14px;\n border-radius: 50%;\n background: var(--nb-c-text);\n top: 50%;\n transform: translate(-50%, -50%);\n cursor: grab;\n z-index: 1;\n\n &:active {\n cursor: grabbing;\n }\n\n &--low {\n border-radius: 0;\n clip-path: polygon(0 50%, 100% 0, 100% 100%);\n }\n\n &--high {\n border-radius: 0;\n clip-path: polygon(100% 50%, 0 0, 0 100%);\n }\n }\n }\n\n &__tick {\n position: absolute;\n left: 50%;\n top: 50%;\n transform: translate(-50%, -50%);\n width: 1px;\n height: 8px;\n background: var(--nb-c-field-border);\n pointer-events: none;\n }\n\n &__track-labels {\n display: flex;\n justify-content: space-between;\n }\n\n &__track-label {\n font-size: 11px;\n color: var(--nb-c-field-border);\n line-height: 1;\n user-select: none;\n }\n\n &__message {\n font-size: 11px;\n }\n}\n</style>\n","<template>\n <div :class=\"rootClasses\">\n <!-- DEFAULT variant: label above -->\n <NbLabel v-if=\"variant === 'default' && label\" class=\"nb-slider__label\">{{\n label\n }}</NbLabel>\n\n <!-- Field box: display:contents in default (passthrough), styled in fluid -->\n <div class=\"nb-slider__field-box\">\n <!-- FLUID variant: label inside the box -->\n <div v-if=\"variant === 'fluid' && label\" class=\"nb-slider__inner-header\">\n <label class=\"nb-slider__inner-label\">{{ label }}</label>\n </div>\n\n <NbGrid dir=\"row\" align=\"center\" gap=\"sm\" class=\"nb-slider__row\">\n <!-- Range: low number input on the left -->\n <NbNumberInput\n v-if=\"range && showInput\"\n :size=\"variant === 'fluid' ? 'sm' : size\"\n :model-value=\"lowValue\"\n :min=\"min\"\n :max=\"highValue\"\n :step=\"step\"\n :disabled=\"disabled\"\n class=\"nb-slider__input\"\n @update:model-value=\"onLowInputChange\"\n @change=\"onLowInputChange\"\n />\n\n <!-- Track area -->\n <NbGrid\n dir=\"col\"\n justify=\"end\"\n gap=\"xs\"\n class=\"nb-slider__track-area\"\n :class=\"trackAreaClasses\"\n grow\n >\n <div\n ref=\"trackRef\"\n class=\"nb-slider__track\"\n @mousedown=\"onTrackMousedown\"\n @touchstart.passive=\"onTrackTouchstart\"\n >\n <!-- Filled segment -->\n <div class=\"nb-slider__track__fill\" :style=\"fillStyle\" />\n\n <!-- Single handle (circle) -->\n <div\n v-if=\"!range\"\n class=\"nb-slider__track__handle\"\n :style=\"{ left: `${valueToPercent(singleValue)}%` }\"\n @mousedown.stop=\"onHandleMousedown(null, $event)\"\n @touchstart.stop.passive=\"onHandleTouchstart(null, $event)\"\n />\n\n <!-- Range handles (triangles) -->\n <template v-else>\n <div\n class=\"nb-slider__track__handle nb-slider__track__handle--low\"\n :style=\"{ left: `${valueToPercent(lowValue)}%` }\"\n @mousedown.stop=\"onHandleMousedown('low', $event)\"\n @touchstart.stop.passive=\"onHandleTouchstart('low', $event)\"\n />\n <div\n class=\"nb-slider__track__handle nb-slider__track__handle--high\"\n :style=\"{ left: `${valueToPercent(highValue)}%` }\"\n @mousedown.stop=\"onHandleMousedown('high', $event)\"\n @touchstart.stop.passive=\"onHandleTouchstart('high', $event)\"\n />\n <div class=\"nb-slider__tick\" />\n </template>\n </div>\n\n <!-- Min / max labels below track -->\n <div class=\"nb-slider__track-labels\">\n <span class=\"nb-slider__track-label\">{{ min }}</span>\n <span class=\"nb-slider__track-label\">{{ max }}</span>\n </div>\n </NbGrid>\n\n <!-- Single slider: number input on the right -->\n <!-- Range: high number input on the right -->\n <NbNumberInput\n v-if=\"showInput\"\n :size=\"variant === 'fluid' ? 'sm' : size\"\n :model-value=\"range ? highValue : singleValue\"\n :min=\"range ? lowValue : min\"\n :max=\"max\"\n :step=\"step\"\n :disabled=\"disabled\"\n class=\"nb-slider__input\"\n @update:model-value=\"\n range ? onHighInputChange($event) : onSingleInputChange($event)\n \"\n @change=\"\n range ? onHighInputChange($event) : onSingleInputChange($event)\n \"\n />\n </NbGrid>\n </div>\n <!-- /__field-box -->\n\n <!-- Messages below -->\n <NbMessage v-if=\"error\" variant=\"error\" class=\"nb-slider__message\">{{\n error\n }}</NbMessage>\n <NbMessage\n v-else-if=\"warning\"\n variant=\"warning\"\n class=\"nb-slider__message\"\n >{{ warning }}</NbMessage\n >\n <NbMessage v-else-if=\"helper\" variant=\"helper\" class=\"nb-slider__message\">{{\n helper\n }}</NbMessage>\n </div>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed, onBeforeUnmount, ref } from 'vue'\nimport { ESizeShort } from '@/types/Size.d'\nimport type { ISliderProps, TActiveHandle } from './Slider.d'\n\nconst props = withDefaults(defineProps<ISliderProps>(), {\n min: 0,\n max: 100,\n step: 1,\n range: false,\n disabled: false,\n showInput: true,\n size: ESizeShort.Medium,\n variant: 'default',\n})\n\nconst emit = defineEmits<{\n 'update:modelValue': [value: number | [number, number]]\n change: [value: number | [number, number]]\n}>()\n\nconst trackRef = ref<HTMLElement | null>(null)\n\nconst activeHandle = ref<TActiveHandle>(null)\n\n// Derived values\nconst singleValue = computed<number>(() => {\n if (\n props.range ||\n props.modelValue === null ||\n props.modelValue === undefined\n ) {\n return props.min ?? 0\n }\n if (Array.isArray(props.modelValue))\n return (props.modelValue[0] as number) ?? props.min ?? 0\n return props.modelValue as number\n})\n\nconst lowValue = computed<number>(() => {\n if (!props.range || !Array.isArray(props.modelValue)) return props.min ?? 0\n return (props.modelValue as [number, number])[0] ?? props.min ?? 0\n})\n\nconst highValue = computed<number>(() => {\n if (!props.range || !Array.isArray(props.modelValue)) return props.max ?? 100\n return (props.modelValue as [number, number])[1] ?? props.max ?? 100\n})\n\n// Track helpers\nfunction valueToPercent(v: number): number {\n const minV = props.min ?? 0\n const maxV = props.max ?? 100\n if (maxV === minV) return 0\n return ((v - minV) / (maxV - minV)) * 100\n}\n\nfunction percentToValue(pct: number): number {\n const minV = props.min ?? 0\n const maxV = props.max ?? 100\n const stepV = props.step ?? 1\n const raw = minV + (pct / 100) * (maxV - minV)\n const stepped = Math.round(raw / stepV) * stepV\n return Math.max(minV, Math.min(maxV, stepped))\n}\n\nfunction getPercentFromEvent(e: MouseEvent | TouchEvent): number {\n if (!trackRef.value) return 0\n const rect = trackRef.value.getBoundingClientRect()\n const clientX = 'touches' in e ? e.touches[0].clientX : e.clientX\n return Math.max(0, Math.min(100, ((clientX - rect.left) / rect.width) * 100))\n}\n\n// Fill style\nconst fillStyle = computed(() => {\n if (!props.range) {\n return { left: '0%', width: `${valueToPercent(singleValue.value)}%` }\n }\n const leftPct = valueToPercent(lowValue.value)\n const rightPct = valueToPercent(highValue.value)\n return { left: `${leftPct}%`, width: `${rightPct - leftPct}%` }\n})\n\n// Emit helpers\nfunction emitSingle(value: number) {\n emit('update:modelValue', value)\n}\n\nfunction emitRange(low: number, high: number) {\n emit('update:modelValue', [low, high])\n}\n\n// Input change handlers\nfunction onSingleInputChange(val: number | null) {\n if (val === null) return\n const minV = props.min ?? 0\n const maxV = props.max ?? 100\n emitSingle(Math.max(minV, Math.min(maxV, val)))\n}\n\nfunction onLowInputChange(val: number | null) {\n if (val === null) return\n const minV = props.min ?? 0\n const clamped = Math.max(minV, Math.min(highValue.value, val))\n emitRange(clamped, highValue.value)\n}\n\nfunction onHighInputChange(val: number | null) {\n if (val === null) return\n const maxV = props.max ?? 100\n const clamped = Math.max(lowValue.value, Math.min(maxV, val))\n emitRange(lowValue.value, clamped)\n}\n\n// Drag handling\nfunction resolveHandle(pct: number): TActiveHandle {\n if (!props.range) return null\n const lowPct = valueToPercent(lowValue.value)\n const highPct = valueToPercent(highValue.value)\n return Math.abs(pct - lowPct) <= Math.abs(pct - highPct) ? 'low' : 'high'\n}\n\nfunction applyDrag(pct: number) {\n const val = percentToValue(pct)\n if (!props.range) {\n emitSingle(val)\n return\n }\n if (activeHandle.value === 'low') {\n const clamped = Math.min(val, highValue.value)\n emitRange(clamped, highValue.value)\n } else {\n const clamped = Math.max(val, lowValue.value)\n emitRange(lowValue.value, clamped)\n }\n}\n\nfunction onMousemove(e: MouseEvent) {\n if (props.disabled) return\n applyDrag(getPercentFromEvent(e))\n}\n\nfunction onMouseup(e: MouseEvent) {\n if (!props.disabled) {\n const val = props.range\n ? ([lowValue.value, highValue.value] as [number, number])\n : singleValue.value\n emit('change', val)\n applyDrag(getPercentFromEvent(e))\n }\n stopDrag()\n}\n\nfunction onTouchmove(e: TouchEvent) {\n if (props.disabled) return\n applyDrag(getPercentFromEvent(e))\n}\n\nfunction onTouchend(e: TouchEvent) {\n if (!props.disabled) {\n const val = props.range\n ? ([lowValue.value, highValue.value] as [number, number])\n : singleValue.value\n emit('change', val)\n applyDrag(getPercentFromEvent(e))\n }\n stopTouchDrag()\n}\n\nfunction startDrag() {\n document.addEventListener('mousemove', onMousemove)\n document.addEventListener('mouseup', onMouseup)\n}\n\nfunction stopDrag() {\n activeHandle.value = null\n document.removeEventListener('mousemove', onMousemove)\n document.removeEventListener('mouseup', onMouseup)\n}\n\nfunction startTouchDrag() {\n document.addEventListener('touchmove', onTouchmove, { passive: true })\n document.addEventListener('touchend', onTouchend)\n}\n\nfunction stopTouchDrag() {\n activeHandle.value = null\n document.removeEventListener('touchmove', onTouchmove)\n document.removeEventListener('touchend', onTouchend)\n}\n\nfunction onTrackMousedown(e: MouseEvent) {\n if (props.disabled) return\n const pct = getPercentFromEvent(e)\n activeHandle.value = resolveHandle(pct)\n applyDrag(pct)\n startDrag()\n}\n\nfunction onTrackTouchstart(e: TouchEvent) {\n if (props.disabled) return\n const pct = getPercentFromEvent(e)\n activeHandle.value = resolveHandle(pct)\n applyDrag(pct)\n startTouchDrag()\n}\n\nfunction onHandleMousedown(handle: TActiveHandle, _e: MouseEvent) {\n if (props.disabled) return\n activeHandle.value = props.range ? handle : null\n startDrag()\n}\n\nfunction onHandleTouchstart(handle: TActiveHandle, _e: TouchEvent) {\n if (props.disabled) return\n activeHandle.value = props.range ? handle : null\n startTouchDrag()\n}\n\nonBeforeUnmount(() => {\n stopDrag()\n stopTouchDrag()\n})\n\n// CSS classes\nconst rootClasses = computed(() => [\n 'nb-slider',\n `nb-slider--${props.size}`,\n `nb-slider--${props.variant}`,\n {\n 'nb-slider--range': props.range,\n 'nb-slider--disabled': props.disabled,\n 'nb-slider--error': !!props.error,\n 'nb-slider--warning': !props.error && !!props.warning,\n },\n])\n\nconst trackAreaClasses = computed(() => ({\n 'nb-slider__track-area--error': !!props.error,\n 'nb-slider__track-area--warning': !props.error && !!props.warning,\n}))\n</script>\n\n<style scoped lang=\"scss\">\n.nb-slider {\n display: flex;\n flex-direction: column;\n flex: 1;\n gap: 6px;\n font-family: var(--nb-font-family-sans, sans-serif);\n\n &--disabled {\n opacity: var(--nb-field-disabled-opacity);\n pointer-events: none;\n }\n\n &__label {\n // label sits outside the row, handled by NbLabel default layout\n }\n\n // ── Field box: invisible passthrough in default, field container in fluid ──\n &__field-box {\n display: contents; // default: children participate directly in .nb-slider's flex\n }\n\n // ── Fluid variant ───────────────────────────────────────────────────────────\n &--fluid {\n gap: 4px;\n\n .nb-slider__field-box {\n display: flex;\n flex: 1;\n flex-direction: column;\n justify-content: space-between;\n background: var(--nb-c-field-bg);\n border-bottom: 1px solid var(--nb-c-field-border);\n padding-top: calc(var(--nb-base-unit) * 1);\n min-height: calc(var(--nb-base-unit) * 8);\n }\n\n .nb-slider__inner-header {\n display: flex;\n align-items: center;\n padding: 0 var(--nb-field-padding-h);\n margin-bottom: 4px;\n }\n\n .nb-slider__inner-label {\n flex: 1;\n min-width: 0;\n font-family: var(--nb-font-family-sans);\n font-size: var(--nb-font-size-12);\n font-weight: 500;\n color: var(--nb-c-text-muted);\n letter-spacing: 0.02em;\n cursor: default;\n user-select: none;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n\n .nb-slider__row {\n padding: 0 var(--nb-field-padding-h) 4px;\n }\n\n // Strip the inner NbNumberInput's own field-box appearance\n .nb-slider__input :deep(.nb-number-input__field-wrapper) {\n background: transparent;\n border-bottom: none;\n }\n }\n\n &__row {\n // layout owned by NbGrid (dir=\"row\", align=\"center\", gap=\"sm\")\n }\n\n &__input {\n flex: 0 0 auto;\n width: 160px;\n }\n\n // Track area: fills remaining space\n &__track-area {\n // flex: 1;\n min-width: 80px;\n // display: flex;\n // flex-direction: column;\n // justify-content: center;\n // gap: 3px;\n\n // Colored underline below track for error/warning\n &--error .nb-slider__track::after {\n content: '';\n position: absolute;\n bottom: -4px;\n left: 0;\n right: 0;\n height: 2px;\n background: var(--nb-c-danger);\n }\n\n &--warning .nb-slider__track::after {\n content: '';\n position: absolute;\n bottom: -4px;\n left: 0;\n right: 0;\n height: 2px;\n background: var(--nb-c-warning);\n }\n }\n\n // Track\n &__track {\n position: relative;\n height: 2px;\n background: var(--nb-c-field-border);\n cursor: pointer;\n margin: 5px 0;\n\n &__fill {\n position: absolute;\n height: 2px;\n background: var(--nb-c-text);\n top: 0;\n pointer-events: none;\n }\n\n &__handle {\n position: absolute;\n width: 14px;\n height: 14px;\n border-radius: 50%;\n background: var(--nb-c-text);\n top: 50%;\n transform: translate(-50%, -50%);\n cursor: grab;\n z-index: 1;\n\n &:active {\n cursor: grabbing;\n }\n\n &--low {\n border-radius: 0;\n clip-path: polygon(0 50%, 100% 0, 100% 100%);\n }\n\n &--high {\n border-radius: 0;\n clip-path: polygon(100% 50%, 0 0, 0 100%);\n }\n }\n }\n\n &__tick {\n position: absolute;\n left: 50%;\n top: 50%;\n transform: translate(-50%, -50%);\n width: 1px;\n height: 8px;\n background: var(--nb-c-field-border);\n pointer-events: none;\n }\n\n &__track-labels {\n display: flex;\n justify-content: space-between;\n }\n\n &__track-label {\n font-size: 11px;\n color: var(--nb-c-field-border);\n line-height: 1;\n user-select: none;\n }\n\n &__message {\n font-size: 11px;\n }\n}\n</style>\n","import { IHumanInputComponent, IWithLabel } from '@/types/Props.d'\n\nenum ESwitchSize {\n Small = 'sm',\n Medium = 'md',\n Large = 'lg',\n}\n\nenum ESwitchVariant {\n Primary = 'primary',\n Secondary = 'secondary',\n}\n\ninterface ISwitchProps extends IHumanInputComponent, IWithLabel {\n modelValue?: boolean\n variant?: ESwitchVariant\n size?: ESwitchSize\n}\n\nexport { ESwitchSize, ESwitchVariant, ISwitchProps }\n","<template>\n <NbGrid :id=\"componentInternalId\" :class=\"classes\" align=\"center\" gap=\"sm\">\n <span v-if=\"label\" class=\"nb-switch-label\">\n {{ label }}\n </span>\n <label\n :for=\"`${componentInternalId}-input`\"\n :class=\"wrapperClasses\"\n v-bind=\"attributes\"\n @click.stop\n >\n <input\n :id=\"`${componentInternalId}-input`\"\n v-model=\"model\"\n :name=\"name\"\n type=\"checkbox\"\n :disabled=\"disabled\"\n />\n <div class=\"slider round\" />\n </label>\n </NbGrid>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed } from 'vue'\nimport type { PropType } from 'vue'\nimport { ESwitchSize, ESwitchVariant } from './Switch.d'\nimport { useStableId } from '@/composables/useStableId.composable'\n\nconst model = defineModel<boolean>()\n\nconst props = defineProps({\n id: {\n type: String,\n default: () => null,\n },\n label: {\n type: String,\n default: '',\n },\n size: {\n type: String as PropType<ESwitchSize>,\n default: ESwitchSize.Medium,\n validator: (value: ESwitchSize) =>\n Object.values(ESwitchSize).includes(value),\n },\n verbose: Boolean,\n name: {\n type: String,\n required: true,\n },\n disabled: Boolean,\n variant: {\n type: String as PropType<ESwitchVariant>,\n default: ESwitchVariant.Primary,\n validator: (value: ESwitchVariant) =>\n Object.values(ESwitchVariant).includes(value),\n },\n})\n\nconst componentInternalId = useStableId(props)\n\nconst attributes = computed(() => ({\n 'aria-disabled': props.disabled,\n}))\n\nconst classes = computed(() => ({\n 'nb-switch': true,\n disabled: props.disabled,\n}))\n\nconst wrapperClasses = computed(() => ({\n 'nb-switch-wrapper': true,\n verbose: props.verbose,\n [props.size]: true,\n [`nb-${props.variant}`]: true,\n}))\n</script>\n\n<style lang=\"scss\" scoped>\n.nb-switch {\n &-wrapper {\n position: relative;\n display: inline-block;\n width: calc(var(--nb-base-unit) * 4);\n height: calc(var(--nb-base-unit) * 2);\n cursor: pointer;\n .slider {\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n background-color: var(--nb-c-component-inactive);\n transition: 0.3s;\n border-radius: calc(var(--nb-base-unit) * 4);\n &:before {\n position: absolute;\n content: '';\n height: calc(var(--nb-base-unit) * 1);\n width: calc(var(--nb-base-unit) * 1);\n left: calc(var(--nb-base-unit) / 2);\n bottom: calc(var(--nb-base-unit) / 2);\n background-color: var(--nb-c-white);\n border-radius: 50%;\n transition: transform 0.3s;\n }\n }\n &[aria-disabled='true'] {\n * {\n cursor: not-allowed;\n }\n input + .slider {\n background-color: var(--nb-c-component-disabled);\n }\n }\n input {\n display: none;\n &:checked + .slider {\n &:before {\n -webkit-transform: translateX(calc(var(--nb-base-unit) * 2));\n -ms-transform: translateX(calc(var(--nb-base-unit) * 2));\n transform: translateX(calc(var(--nb-base-unit) * 2));\n }\n }\n &:focus + .slider {\n box-shadow: 0 0 1px var(--nb-c-component-active);\n }\n }\n &:not([aria-disabled='true']) {\n input {\n + .slider {\n background-color: var(--nb-c-component-inactive);\n }\n &:checked + .slider {\n background-color: var(--nb-c-primary);\n }\n }\n\n &.nb-secondary input:checked + .slider {\n background-color: var(--nb-c-success);\n }\n }\n &.verbose {\n &.sm {\n width: calc(var(--nb-base-unit) * 5.5);\n height: calc(var(--nb-base-unit) * 2);\n .slider {\n &:before {\n height: calc(var(--nb-base-unit) * 1);\n width: calc(var(--nb-base-unit) * 1);\n left: calc(var(--nb-base-unit) / 2);\n bottom: calc(var(--nb-base-unit) / 2);\n border-radius: calc(var(--nb-base-unit) * 4);\n }\n &:after {\n content: 'OFF';\n position: absolute;\n top: calc(var(--nb-base-unit) / 2);\n right: calc(var(--nb-base-unit) - 2px);\n font-weight: var(--nb-font-weight-bold);\n font-size: var(--nb-font-size-10);\n letter-spacing: 0.4px;\n color: var(--nb-c-white);\n line-height: calc(var(--nb-base-unit) * 1);\n }\n }\n input {\n &:checked + .slider {\n &:before {\n -webkit-transform: translateX(calc(var(--nb-base-unit) * 3.4));\n -ms-transform: translateX(calc(var(--nb-base-unit) * 3.4));\n transform: translateX(calc(var(--nb-base-unit) * 3.4));\n }\n &:after {\n content: 'ON';\n left: calc(var(--nb-base-unit) - 2px);\n }\n }\n }\n }\n &.md {\n width: calc(var(--nb-base-unit) * 8);\n height: calc(var(--nb-base-unit) * 3);\n .slider {\n &:before {\n height: calc(var(--nb-base-unit) * 1.5);\n width: calc(var(--nb-base-unit) * 1.5);\n left: var(--nb-base-unit);\n bottom: calc(var(--nb-base-unit) / 1.3);\n border-radius: calc(var(--nb-base-unit) * 8);\n }\n &:after {\n content: 'OFF';\n position: absolute;\n top: calc(var(--nb-base-unit) / 2);\n right: calc(var(--nb-base-unit) * 1);\n font-weight: var(--nb-font-weight-bold);\n font-size: var(--nb-font-size-12);\n color: var(--nb-c-white);\n line-height: calc(var(--nb-base-unit) * 2);\n }\n }\n input {\n &:checked + .slider {\n &:before {\n -webkit-transform: translateX(calc(var(--nb-base-unit) * 4));\n -ms-transform: translateX(calc(var(--nb-base-unit) * 4));\n transform: translateX(calc(var(--nb-base-unit) * 4));\n }\n &:after {\n content: 'ON';\n left: calc(var(--nb-base-unit) * 1);\n }\n }\n }\n }\n &.lg {\n width: calc(var(--nb-base-unit) * 8);\n height: calc(var(--nb-base-unit) * 4);\n .slider {\n &:before {\n height: calc(var(--nb-base-unit) * 2);\n width: calc(var(--nb-base-unit) * 2);\n left: var(--nb-base-unit);\n bottom: var(--nb-base-unit);\n border-radius: calc(var(--nb-base-unit) * 8);\n }\n &:after {\n content: 'OFF';\n position: absolute;\n top: calc(var(--nb-base-unit) / 2);\n right: calc(var(--nb-base-unit) * 1);\n font-weight: var(--nb-font-weight-bold);\n font-size: var(--nb-font-size-12);\n color: var(--nb-c-white);\n line-height: calc(var(--nb-base-unit) * 3);\n }\n }\n input {\n &:checked + .slider {\n &:before {\n -webkit-transform: translateX(calc(var(--nb-base-unit) * 4));\n -ms-transform: translateX(calc(var(--nb-base-unit) * 4));\n transform: translateX(calc(var(--nb-base-unit) * 4));\n }\n &:after {\n content: 'ON';\n left: calc(var(--nb-base-unit) * 1);\n }\n }\n }\n }\n }\n }\n *-label {\n font-size: var(--nb-font-size-14);\n }\n}\n</style>\n","<template>\n <NbGrid :id=\"componentInternalId\" :class=\"classes\" align=\"center\" gap=\"sm\">\n <span v-if=\"label\" class=\"nb-switch-label\">\n {{ label }}\n </span>\n <label\n :for=\"`${componentInternalId}-input`\"\n :class=\"wrapperClasses\"\n v-bind=\"attributes\"\n @click.stop\n >\n <input\n :id=\"`${componentInternalId}-input`\"\n v-model=\"model\"\n :name=\"name\"\n type=\"checkbox\"\n :disabled=\"disabled\"\n />\n <div class=\"slider round\" />\n </label>\n </NbGrid>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed } from 'vue'\nimport type { PropType } from 'vue'\nimport { ESwitchSize, ESwitchVariant } from './Switch.d'\nimport { useStableId } from '@/composables/useStableId.composable'\n\nconst model = defineModel<boolean>()\n\nconst props = defineProps({\n id: {\n type: String,\n default: () => null,\n },\n label: {\n type: String,\n default: '',\n },\n size: {\n type: String as PropType<ESwitchSize>,\n default: ESwitchSize.Medium,\n validator: (value: ESwitchSize) =>\n Object.values(ESwitchSize).includes(value),\n },\n verbose: Boolean,\n name: {\n type: String,\n required: true,\n },\n disabled: Boolean,\n variant: {\n type: String as PropType<ESwitchVariant>,\n default: ESwitchVariant.Primary,\n validator: (value: ESwitchVariant) =>\n Object.values(ESwitchVariant).includes(value),\n },\n})\n\nconst componentInternalId = useStableId(props)\n\nconst attributes = computed(() => ({\n 'aria-disabled': props.disabled,\n}))\n\nconst classes = computed(() => ({\n 'nb-switch': true,\n disabled: props.disabled,\n}))\n\nconst wrapperClasses = computed(() => ({\n 'nb-switch-wrapper': true,\n verbose: props.verbose,\n [props.size]: true,\n [`nb-${props.variant}`]: true,\n}))\n</script>\n\n<style lang=\"scss\" scoped>\n.nb-switch {\n &-wrapper {\n position: relative;\n display: inline-block;\n width: calc(var(--nb-base-unit) * 4);\n height: calc(var(--nb-base-unit) * 2);\n cursor: pointer;\n .slider {\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n background-color: var(--nb-c-component-inactive);\n transition: 0.3s;\n border-radius: calc(var(--nb-base-unit) * 4);\n &:before {\n position: absolute;\n content: '';\n height: calc(var(--nb-base-unit) * 1);\n width: calc(var(--nb-base-unit) * 1);\n left: calc(var(--nb-base-unit) / 2);\n bottom: calc(var(--nb-base-unit) / 2);\n background-color: var(--nb-c-white);\n border-radius: 50%;\n transition: transform 0.3s;\n }\n }\n &[aria-disabled='true'] {\n * {\n cursor: not-allowed;\n }\n input + .slider {\n background-color: var(--nb-c-component-disabled);\n }\n }\n input {\n display: none;\n &:checked + .slider {\n &:before {\n -webkit-transform: translateX(calc(var(--nb-base-unit) * 2));\n -ms-transform: translateX(calc(var(--nb-base-unit) * 2));\n transform: translateX(calc(var(--nb-base-unit) * 2));\n }\n }\n &:focus + .slider {\n box-shadow: 0 0 1px var(--nb-c-component-active);\n }\n }\n &:not([aria-disabled='true']) {\n input {\n + .slider {\n background-color: var(--nb-c-component-inactive);\n }\n &:checked + .slider {\n background-color: var(--nb-c-primary);\n }\n }\n\n &.nb-secondary input:checked + .slider {\n background-color: var(--nb-c-success);\n }\n }\n &.verbose {\n &.sm {\n width: calc(var(--nb-base-unit) * 5.5);\n height: calc(var(--nb-base-unit) * 2);\n .slider {\n &:before {\n height: calc(var(--nb-base-unit) * 1);\n width: calc(var(--nb-base-unit) * 1);\n left: calc(var(--nb-base-unit) / 2);\n bottom: calc(var(--nb-base-unit) / 2);\n border-radius: calc(var(--nb-base-unit) * 4);\n }\n &:after {\n content: 'OFF';\n position: absolute;\n top: calc(var(--nb-base-unit) / 2);\n right: calc(var(--nb-base-unit) - 2px);\n font-weight: var(--nb-font-weight-bold);\n font-size: var(--nb-font-size-10);\n letter-spacing: 0.4px;\n color: var(--nb-c-white);\n line-height: calc(var(--nb-base-unit) * 1);\n }\n }\n input {\n &:checked + .slider {\n &:before {\n -webkit-transform: translateX(calc(var(--nb-base-unit) * 3.4));\n -ms-transform: translateX(calc(var(--nb-base-unit) * 3.4));\n transform: translateX(calc(var(--nb-base-unit) * 3.4));\n }\n &:after {\n content: 'ON';\n left: calc(var(--nb-base-unit) - 2px);\n }\n }\n }\n }\n &.md {\n width: calc(var(--nb-base-unit) * 8);\n height: calc(var(--nb-base-unit) * 3);\n .slider {\n &:before {\n height: calc(var(--nb-base-unit) * 1.5);\n width: calc(var(--nb-base-unit) * 1.5);\n left: var(--nb-base-unit);\n bottom: calc(var(--nb-base-unit) / 1.3);\n border-radius: calc(var(--nb-base-unit) * 8);\n }\n &:after {\n content: 'OFF';\n position: absolute;\n top: calc(var(--nb-base-unit) / 2);\n right: calc(var(--nb-base-unit) * 1);\n font-weight: var(--nb-font-weight-bold);\n font-size: var(--nb-font-size-12);\n color: var(--nb-c-white);\n line-height: calc(var(--nb-base-unit) * 2);\n }\n }\n input {\n &:checked + .slider {\n &:before {\n -webkit-transform: translateX(calc(var(--nb-base-unit) * 4));\n -ms-transform: translateX(calc(var(--nb-base-unit) * 4));\n transform: translateX(calc(var(--nb-base-unit) * 4));\n }\n &:after {\n content: 'ON';\n left: calc(var(--nb-base-unit) * 1);\n }\n }\n }\n }\n &.lg {\n width: calc(var(--nb-base-unit) * 8);\n height: calc(var(--nb-base-unit) * 4);\n .slider {\n &:before {\n height: calc(var(--nb-base-unit) * 2);\n width: calc(var(--nb-base-unit) * 2);\n left: var(--nb-base-unit);\n bottom: var(--nb-base-unit);\n border-radius: calc(var(--nb-base-unit) * 8);\n }\n &:after {\n content: 'OFF';\n position: absolute;\n top: calc(var(--nb-base-unit) / 2);\n right: calc(var(--nb-base-unit) * 1);\n font-weight: var(--nb-font-weight-bold);\n font-size: var(--nb-font-size-12);\n color: var(--nb-c-white);\n line-height: calc(var(--nb-base-unit) * 3);\n }\n }\n input {\n &:checked + .slider {\n &:before {\n -webkit-transform: translateX(calc(var(--nb-base-unit) * 4));\n -ms-transform: translateX(calc(var(--nb-base-unit) * 4));\n transform: translateX(calc(var(--nb-base-unit) * 4));\n }\n &:after {\n content: 'ON';\n left: calc(var(--nb-base-unit) * 1);\n }\n }\n }\n }\n }\n }\n *-label {\n font-size: var(--nb-font-size-14);\n }\n}\n</style>\n","<template>\n <NbGrid\n dir=\"col\"\n gap=\"xs\"\n :class=\"[\n 'nb-text-input',\n `nb-text-input--${variant}`,\n `nb-text-input--${size}`,\n { 'nb-text-input--multiline': multiline },\n ]\"\n >\n <!-- ── DEFAULT variant ───────────────────────────────────── -->\n <template v-if=\"variant === 'default'\">\n <!-- Label row: either a custom #label slot or the built-in NbLabel -->\n <slot v-if=\"$slots.label\" name=\"label\" />\n <NbLabel\n v-else-if=\"label\"\n :for=\"inputId\"\n :required=\"required\"\n :disabled=\"disabled\"\n >\n {{ label }}\n </NbLabel>\n\n <div class=\"nb-text-input__field-wrapper\" :class=\"wrapperClasses\">\n <slot name=\"leading\" />\n\n <!-- ░░ OVERLAY MODE (highlight function provided) ░░░░░░░░ -->\n <!-- CSS Grid overlap: mirror and transparent field share the same grid cell,\n guaranteeing identical bounding boxes and pixel-perfect caret alignment. -->\n <div v-if=\"useOverlay\" class=\"nb-text-input__overlay-wrap\">\n <!-- eslint-disable-next-line vue/no-v-html -->\n <div\n ref=\"mirrorRef\"\n class=\"nb-text-input__mirror\"\n aria-hidden=\"true\"\n v-html=\"mirrorHtml\"\n />\n\n <textarea\n v-if=\"multiline\"\n :id=\"inputId\"\n ref=\"nativeRef\"\n v-bind=\"$attrs\"\n class=\"nb-text-input__field--transparent\"\n :value=\"model\"\n :placeholder=\"placeholder\"\n :disabled=\"disabled\"\n :readonly=\"readonly\"\n :name=\"name\"\n :maxlength=\"maxlength\"\n spellcheck=\"false\"\n autocomplete=\"off\"\n autocorrect=\"off\"\n @input=\"model = ($event.target as HTMLTextAreaElement).value\"\n @focus=\"focused = true\"\n @blur=\"focused = false\"\n @scroll=\"syncScroll\"\n />\n <input\n v-else\n :id=\"inputId\"\n ref=\"nativeRef\"\n v-bind=\"$attrs\"\n type=\"text\"\n class=\"nb-text-input__field--transparent\"\n :value=\"model\"\n :placeholder=\"placeholder\"\n :disabled=\"disabled\"\n :readonly=\"readonly\"\n :name=\"name\"\n :maxlength=\"maxlength\"\n spellcheck=\"false\"\n @input=\"model = ($event.target as HTMLInputElement).value\"\n @focus=\"focused = true\"\n @blur=\"focused = false\"\n />\n </div>\n\n <!-- ░░ NORMAL MODE ░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░ -->\n <template v-else>\n <textarea\n v-if=\"multiline\"\n :id=\"inputId\"\n ref=\"nativeRef\"\n v-bind=\"$attrs\"\n v-model=\"model\"\n class=\"nb-text-input__field\"\n :placeholder=\"placeholder\"\n :disabled=\"disabled\"\n :readonly=\"readonly\"\n :name=\"name\"\n :maxlength=\"maxlength\"\n :rows=\"rows\"\n @focus=\"focused = true\"\n @blur=\"focused = false\"\n />\n <input\n v-else\n :id=\"inputId\"\n ref=\"nativeRef\"\n v-bind=\"$attrs\"\n v-model=\"model\"\n class=\"nb-text-input__field\"\n :type=\"type\"\n :placeholder=\"placeholder\"\n :disabled=\"disabled\"\n :readonly=\"readonly\"\n :required=\"required\"\n :name=\"name\"\n :min=\"min\"\n :max=\"max\"\n :step=\"step\"\n :maxlength=\"maxlength\"\n @focus=\"focused = true\"\n @blur=\"focused = false\"\n />\n </template>\n\n <slot name=\"trailing\" />\n\n <!-- Actions: buttons rendered inside the field at the trailing edge\n (AI suggest, password toggle, clear, etc.) -->\n <div v-if=\"$slots.actions\" class=\"nb-text-input__actions\">\n <slot name=\"actions\" />\n </div>\n </div>\n\n <NbMessage\n v-if=\"hasMessage\"\n :variant=\"messageVariant\"\n class=\"nb-text-input__message\"\n >\n {{ messageText }}\n </NbMessage>\n\n <!-- Dropdowns / popovers anchored to the component root -->\n <slot name=\"dropdown\" />\n </template>\n\n <!-- ── FLUID variant ─────────────────────────────────────── -->\n <template v-else-if=\"variant === 'fluid'\">\n <div class=\"nb-text-input__field-wrapper\" :class=\"wrapperClasses\">\n <div v-if=\"label || $slots.label\" class=\"nb-text-input__inner-header\">\n <slot v-if=\"$slots.label\" name=\"label\" />\n <label\n v-else\n :for=\"inputId\"\n class=\"nb-text-input__inner-label\"\n :class=\"{ 'nb-text-input__inner-label--required': required }\"\n >\n {{ label }}\n <span\n v-if=\"required\"\n class=\"nb-text-input__asterisk\"\n aria-hidden=\"true\"\n >*</span\n >\n </label>\n <NbMessage\n v-if=\"hasMessage\"\n :variant=\"messageVariant\"\n icon-only\n class=\"nb-text-input__inner-message\"\n >\n {{ messageText }}\n </NbMessage>\n </div>\n\n <input\n :id=\"inputId\"\n ref=\"nativeRef\"\n v-bind=\"$attrs\"\n v-model=\"model\"\n class=\"nb-text-input__field\"\n :type=\"type\"\n :placeholder=\"placeholder\"\n :disabled=\"disabled\"\n :readonly=\"readonly\"\n :required=\"required\"\n :name=\"name\"\n :min=\"min\"\n :max=\"max\"\n :step=\"step\"\n :maxlength=\"maxlength\"\n @focus=\"focused = true\"\n @blur=\"focused = false\"\n />\n </div>\n </template>\n </NbGrid>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed, nextTick, ref, useId, watch } from 'vue'\nimport type { IReadableFieldComponent } from '@/types/Props.d'\nimport NbLabel from './Label.vue'\nimport NbMessage from './Message.vue'\n\n// Ensure $attrs (class, style, event listeners, native attrs) flow to the native element\ndefineOptions({ inheritAttrs: false })\n\nexport interface ITextInputProps extends IReadableFieldComponent {\n /** Native input type forwarded to the `<input>` element. */\n type?: string\n min?: string | number\n max?: string | number\n step?: string | number\n maxlength?: number\n /** Render a <textarea> instead of <input> */\n multiline?: boolean\n /** Initial row count (multiline only, without highlight) */\n rows?: number\n /**\n * Syntax-highlight function. Receives the raw text value, must return an HTML string.\n * When provided, an overlay mirror is rendered below the (transparent) input/textarea\n * so the highlights show through. The highlight span styles must be supplied by the consumer.\n *\n * @example\n * :highlight=\"(t) => t.replace(/(\\{[^}]+\\})/g, '<span class=\\\"hl-var\\\">$1</span>')\"\n */\n highlight?: (text: string) => string\n}\n\nconst props = withDefaults(defineProps<ITextInputProps>(), {\n variant: 'default',\n size: 'md',\n type: 'text',\n label: '',\n placeholder: '',\n helper: '',\n error: '',\n warning: '',\n disabled: false,\n readonly: false,\n required: false,\n id: undefined,\n name: '',\n min: undefined,\n max: undefined,\n step: undefined,\n maxlength: undefined,\n multiline: false,\n rows: 3,\n highlight: undefined,\n})\n\nconst model = defineModel<string>({ default: '' })\n\nconst nativeRef = ref<HTMLInputElement | HTMLTextAreaElement | null>(null)\nconst mirrorRef = ref<HTMLDivElement | null>(null)\n\n// Expose the native element so consumers (e.g. TranslationEditor) can access\n// selectionStart, setSelectionRange, focus, blur, etc.\ndefineExpose({\n focus: () => nativeRef.value?.focus(),\n blur: () => nativeRef.value?.blur(),\n nativeEl: nativeRef,\n})\n\nconst focused = ref(false)\n\n// Stable generated ID per instance\nconst autoId = `nb-input-${useId()}`\nconst inputId = computed(() => props.id ?? autoId)\n\n// Overlay mode: active when a highlight function is provided\nconst useOverlay = computed(() => !!props.highlight)\n\n// The mirror div HTML: trailing newline prevents the container collapsing on the last line\nconst mirrorHtml = computed(() => {\n if (!props.highlight) return ''\n const text = String(model.value ?? '')\n const highlighted = props.highlight(text)\n return highlighted + '\\n'\n})\n\n// Keep mirror scroll in sync with the textarea scroll\nfunction syncScroll() {\n if (mirrorRef.value && nativeRef.value) {\n mirrorRef.value.scrollTop = nativeRef.value.scrollTop\n }\n}\n\nwatch(mirrorHtml, () => nextTick(syncScroll))\n\nconst messageVariant = computed(() => {\n if (props.error) return 'error'\n if (props.warning) return 'warning'\n return 'helper'\n})\n\nconst messageText = computed(\n () => props.error ?? props.warning ?? props.helper ?? '',\n)\nconst hasMessage = computed(() => !!messageText.value)\n\nconst wrapperClasses = computed(() => ({\n 'nb-text-input__field-wrapper--focused': focused.value,\n 'nb-text-input__field-wrapper--error': !!props.error,\n 'nb-text-input__field-wrapper--warning': !props.error && !!props.warning,\n 'nb-text-input__field-wrapper--disabled': props.disabled,\n 'nb-text-input__field-wrapper--readonly': props.readonly,\n 'nb-text-input__field-wrapper--overlay': useOverlay.value,\n 'nb-text-input__field-wrapper--multiline': props.multiline,\n}))\n</script>\n\n<style scoped lang=\"scss\">\n.nb-text-input {\n font-family: var(--nb-font-family-sans);\n --field-h: var(--nb-field-height-md);\n\n &--sm {\n --field-h: var(--nb-field-height-sm);\n }\n &--md {\n --field-h: var(--nb-field-height-md);\n }\n &--lg {\n --field-h: var(--nb-field-height-lg);\n }\n\n // ─── Field wrapper ────────────────────────────────────────\n &__field-wrapper {\n position: relative;\n display: flex;\n align-items: center;\n background: var(--nb-c-field-bg);\n // Always 1px border: never changes width, so no layout shift on focus\n border-bottom: 1px solid var(--nb-c-field-border);\n transition:\n border-color 0.15s,\n box-shadow 0.15s;\n\n &--focused {\n outline: 2px solid var(--nb-c-primary);\n outline-offset: -2px;\n }\n\n &--error {\n border-bottom-color: var(--nb-c-danger);\n box-shadow: inset 0 -1px 0 0 var(--nb-c-danger);\n }\n\n &--warning {\n border-bottom-color: var(--nb-c-warning);\n box-shadow: inset 0 -1px 0 0 var(--nb-c-warning);\n }\n\n &--disabled {\n opacity: var(--nb-field-disabled-opacity);\n cursor: not-allowed;\n }\n\n &--readonly {\n background: transparent;\n }\n\n &--multiline {\n align-items: stretch;\n }\n }\n\n // ─── Native input / textarea (normal mode) ────────────────\n &__field {\n flex: 1;\n min-width: 0;\n height: var(--field-h);\n padding: 0 var(--nb-field-padding-h);\n background: transparent;\n border: none;\n outline: none;\n font-family: inherit;\n font-size: var(--nb-field-font-size);\n font-weight: 400;\n color: var(--nb-c-text);\n line-height: var(--nb-field-line-height);\n\n &::placeholder {\n color: var(--nb-c-text-subtle);\n }\n &:disabled {\n cursor: not-allowed;\n }\n &:read-only {\n cursor: default;\n }\n }\n\n // ─── Overlay wrap: CSS Grid overlap ─────────────────────\n // Mirror and transparent input share the SAME grid cell, which guarantees\n // identical bounding boxes, padding, and line-height → caret aligns perfectly.\n &__overlay-wrap {\n flex: 1;\n min-width: 0;\n display: grid;\n }\n\n &__mirror,\n &__field--transparent {\n grid-area: 1 / 1; // overlap in the same grid cell\n font-family: inherit;\n font-size: var(--nb-field-font-size);\n font-weight: 400;\n line-height: var(--nb-field-line-height);\n word-break: break-word;\n overflow-wrap: break-word;\n }\n\n &__mirror {\n color: var(--nb-c-text);\n pointer-events: none;\n user-select: none;\n overflow: hidden;\n }\n\n &__field--transparent {\n background: transparent;\n color: transparent;\n caret-color: var(--nb-c-text);\n border: none;\n outline: none;\n resize: none;\n overflow: hidden;\n z-index: 1; // caret must sit above mirror\n width: 100%; // fill grid cell\n }\n\n // Single-line overlay: fixed height, text centred via line-height trick\n &:not(.nb-text-input--multiline) {\n .nb-text-input__mirror,\n .nb-text-input__field--transparent {\n height: var(--field-h);\n padding: 0 var(--nb-field-padding-h);\n // line-height = height centres single-line text identically in mirror and input\n line-height: var(--field-h);\n white-space: pre;\n overflow: hidden;\n }\n }\n\n // Multiline overlay + non-overlay textarea\n &--multiline {\n .nb-text-input__field-wrapper {\n align-items: stretch;\n }\n\n // Overlay: padding top/bottom, height driven by mirror content\n .nb-text-input__mirror,\n .nb-text-input__field--transparent {\n padding: 8px var(--nb-field-padding-h);\n white-space: pre-wrap;\n min-height: 80px;\n overflow-y: auto;\n }\n\n // Normal (non-overlay) textarea\n .nb-text-input__field {\n height: auto;\n min-height: 80px;\n padding: 8px var(--nb-field-padding-h);\n resize: vertical;\n overflow: auto;\n }\n }\n\n // Buttons rendered inside the field at the trailing edge (AI suggest, eye, clear…)\n &__actions {\n display: flex;\n align-items: center;\n padding: 0 8px;\n gap: 4px;\n flex-shrink: 0;\n z-index: 2; // above the transparent overlay input\n }\n\n // ─── Bottom message ───────────────────────────────────────\n &__message {\n font-size: var(--nb-font-size-12);\n }\n\n // ─── DEFAULT variant ──────────────────────────────────────\n &--default {\n position: relative; // anchor for #dropdown slot\n }\n\n // ─── FLUID variant ────────────────────────────────────────\n &--fluid {\n .nb-text-input__field-wrapper {\n box-sizing: border-box;\n flex: 1;\n flex-direction: column;\n align-items: stretch;\n justify-content: space-between;\n min-height: calc(var(--nb-base-unit) * 8);\n padding-top: 8px;\n }\n\n .nb-text-input__inner-header {\n display: flex;\n align-items: center;\n gap: 4px;\n padding: 0 var(--nb-field-padding-h);\n margin-bottom: 4px;\n }\n\n .nb-text-input__inner-label {\n display: flex;\n align-items: center;\n gap: 4px;\n flex: 1;\n min-width: 0;\n font-size: var(--nb-font-size-12);\n font-weight: 500;\n color: var(--nb-c-text-muted);\n letter-spacing: 0.02em;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n cursor: default;\n user-select: none;\n }\n\n .nb-text-input__asterisk {\n color: var(--nb-c-danger);\n }\n\n .nb-text-input__field {\n height: auto;\n flex: 1;\n padding: 0 var(--nb-field-padding-h) 10px;\n font-size: var(--nb-font-size-14);\n }\n }\n}\n</style>\n","<template>\n <NbGrid\n dir=\"col\"\n gap=\"xs\"\n :class=\"[\n 'nb-text-input',\n `nb-text-input--${variant}`,\n `nb-text-input--${size}`,\n { 'nb-text-input--multiline': multiline },\n ]\"\n >\n <!-- ── DEFAULT variant ───────────────────────────────────── -->\n <template v-if=\"variant === 'default'\">\n <!-- Label row: either a custom #label slot or the built-in NbLabel -->\n <slot v-if=\"$slots.label\" name=\"label\" />\n <NbLabel\n v-else-if=\"label\"\n :for=\"inputId\"\n :required=\"required\"\n :disabled=\"disabled\"\n >\n {{ label }}\n </NbLabel>\n\n <div class=\"nb-text-input__field-wrapper\" :class=\"wrapperClasses\">\n <slot name=\"leading\" />\n\n <!-- ░░ OVERLAY MODE (highlight function provided) ░░░░░░░░ -->\n <!-- CSS Grid overlap: mirror and transparent field share the same grid cell,\n guaranteeing identical bounding boxes and pixel-perfect caret alignment. -->\n <div v-if=\"useOverlay\" class=\"nb-text-input__overlay-wrap\">\n <!-- eslint-disable-next-line vue/no-v-html -->\n <div\n ref=\"mirrorRef\"\n class=\"nb-text-input__mirror\"\n aria-hidden=\"true\"\n v-html=\"mirrorHtml\"\n />\n\n <textarea\n v-if=\"multiline\"\n :id=\"inputId\"\n ref=\"nativeRef\"\n v-bind=\"$attrs\"\n class=\"nb-text-input__field--transparent\"\n :value=\"model\"\n :placeholder=\"placeholder\"\n :disabled=\"disabled\"\n :readonly=\"readonly\"\n :name=\"name\"\n :maxlength=\"maxlength\"\n spellcheck=\"false\"\n autocomplete=\"off\"\n autocorrect=\"off\"\n @input=\"model = ($event.target as HTMLTextAreaElement).value\"\n @focus=\"focused = true\"\n @blur=\"focused = false\"\n @scroll=\"syncScroll\"\n />\n <input\n v-else\n :id=\"inputId\"\n ref=\"nativeRef\"\n v-bind=\"$attrs\"\n type=\"text\"\n class=\"nb-text-input__field--transparent\"\n :value=\"model\"\n :placeholder=\"placeholder\"\n :disabled=\"disabled\"\n :readonly=\"readonly\"\n :name=\"name\"\n :maxlength=\"maxlength\"\n spellcheck=\"false\"\n @input=\"model = ($event.target as HTMLInputElement).value\"\n @focus=\"focused = true\"\n @blur=\"focused = false\"\n />\n </div>\n\n <!-- ░░ NORMAL MODE ░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░░ -->\n <template v-else>\n <textarea\n v-if=\"multiline\"\n :id=\"inputId\"\n ref=\"nativeRef\"\n v-bind=\"$attrs\"\n v-model=\"model\"\n class=\"nb-text-input__field\"\n :placeholder=\"placeholder\"\n :disabled=\"disabled\"\n :readonly=\"readonly\"\n :name=\"name\"\n :maxlength=\"maxlength\"\n :rows=\"rows\"\n @focus=\"focused = true\"\n @blur=\"focused = false\"\n />\n <input\n v-else\n :id=\"inputId\"\n ref=\"nativeRef\"\n v-bind=\"$attrs\"\n v-model=\"model\"\n class=\"nb-text-input__field\"\n :type=\"type\"\n :placeholder=\"placeholder\"\n :disabled=\"disabled\"\n :readonly=\"readonly\"\n :required=\"required\"\n :name=\"name\"\n :min=\"min\"\n :max=\"max\"\n :step=\"step\"\n :maxlength=\"maxlength\"\n @focus=\"focused = true\"\n @blur=\"focused = false\"\n />\n </template>\n\n <slot name=\"trailing\" />\n\n <!-- Actions: buttons rendered inside the field at the trailing edge\n (AI suggest, password toggle, clear, etc.) -->\n <div v-if=\"$slots.actions\" class=\"nb-text-input__actions\">\n <slot name=\"actions\" />\n </div>\n </div>\n\n <NbMessage\n v-if=\"hasMessage\"\n :variant=\"messageVariant\"\n class=\"nb-text-input__message\"\n >\n {{ messageText }}\n </NbMessage>\n\n <!-- Dropdowns / popovers anchored to the component root -->\n <slot name=\"dropdown\" />\n </template>\n\n <!-- ── FLUID variant ─────────────────────────────────────── -->\n <template v-else-if=\"variant === 'fluid'\">\n <div class=\"nb-text-input__field-wrapper\" :class=\"wrapperClasses\">\n <div v-if=\"label || $slots.label\" class=\"nb-text-input__inner-header\">\n <slot v-if=\"$slots.label\" name=\"label\" />\n <label\n v-else\n :for=\"inputId\"\n class=\"nb-text-input__inner-label\"\n :class=\"{ 'nb-text-input__inner-label--required': required }\"\n >\n {{ label }}\n <span\n v-if=\"required\"\n class=\"nb-text-input__asterisk\"\n aria-hidden=\"true\"\n >*</span\n >\n </label>\n <NbMessage\n v-if=\"hasMessage\"\n :variant=\"messageVariant\"\n icon-only\n class=\"nb-text-input__inner-message\"\n >\n {{ messageText }}\n </NbMessage>\n </div>\n\n <input\n :id=\"inputId\"\n ref=\"nativeRef\"\n v-bind=\"$attrs\"\n v-model=\"model\"\n class=\"nb-text-input__field\"\n :type=\"type\"\n :placeholder=\"placeholder\"\n :disabled=\"disabled\"\n :readonly=\"readonly\"\n :required=\"required\"\n :name=\"name\"\n :min=\"min\"\n :max=\"max\"\n :step=\"step\"\n :maxlength=\"maxlength\"\n @focus=\"focused = true\"\n @blur=\"focused = false\"\n />\n </div>\n </template>\n </NbGrid>\n</template>\n\n<script setup lang=\"ts\">\nimport { computed, nextTick, ref, useId, watch } from 'vue'\nimport type { IReadableFieldComponent } from '@/types/Props.d'\nimport NbLabel from './Label.vue'\nimport NbMessage from './Message.vue'\n\n// Ensure $attrs (class, style, event listeners, native attrs) flow to the native element\ndefineOptions({ inheritAttrs: false })\n\nexport interface ITextInputProps extends IReadableFieldComponent {\n /** Native input type forwarded to the `<input>` element. */\n type?: string\n min?: string | number\n max?: string | number\n step?: string | number\n maxlength?: number\n /** Render a <textarea> instead of <input> */\n multiline?: boolean\n /** Initial row count (multiline only, without highlight) */\n rows?: number\n /**\n * Syntax-highlight function. Receives the raw text value, must return an HTML string.\n * When provided, an overlay mirror is rendered below the (transparent) input/textarea\n * so the highlights show through. The highlight span styles must be supplied by the consumer.\n *\n * @example\n * :highlight=\"(t) => t.replace(/(\\{[^}]+\\})/g, '<span class=\\\"hl-var\\\">$1</span>')\"\n */\n highlight?: (text: string) => string\n}\n\nconst props = withDefaults(defineProps<ITextInputProps>(), {\n variant: 'default',\n size: 'md',\n type: 'text',\n label: '',\n placeholder: '',\n helper: '',\n error: '',\n warning: '',\n disabled: false,\n readonly: false,\n required: false,\n id: undefined,\n name: '',\n min: undefined,\n max: undefined,\n step: undefined,\n maxlength: undefined,\n multiline: false,\n rows: 3,\n highlight: undefined,\n})\n\nconst model = defineModel<string>({ default: '' })\n\nconst nativeRef = ref<HTMLInputElement | HTMLTextAreaElement | null>(null)\nconst mirrorRef = ref<HTMLDivElement | null>(null)\n\n// Expose the native element so consumers (e.g. TranslationEditor) can access\n// selectionStart, setSelectionRange, focus, blur, etc.\ndefineExpose({\n focus: () => nativeRef.value?.focus(),\n blur: () => nativeRef.value?.blur(),\n nativeEl: nativeRef,\n})\n\nconst focused = ref(false)\n\n// Stable generated ID per instance\nconst autoId = `nb-input-${useId()}`\nconst inputId = computed(() => props.id ?? autoId)\n\n// Overlay mode: active when a highlight function is provided\nconst useOverlay = computed(() => !!props.highlight)\n\n// The mirror div HTML: trailing newline prevents the container collapsing on the last line\nconst mirrorHtml = computed(() => {\n if (!props.highlight) return ''\n const text = String(model.value ?? '')\n const highlighted = props.highlight(text)\n return highlighted + '\\n'\n})\n\n// Keep mirror scroll in sync with the textarea scroll\nfunction syncScroll() {\n if (mirrorRef.value && nativeRef.value) {\n mirrorRef.value.scrollTop = nativeRef.value.scrollTop\n }\n}\n\nwatch(mirrorHtml, () => nextTick(syncScroll))\n\nconst messageVariant = computed(() => {\n if (props.error) return 'error'\n if (props.warning) return 'warning'\n return 'helper'\n})\n\nconst messageText = computed(\n () => props.error ?? props.warning ?? props.helper ?? '',\n)\nconst hasMessage = computed(() => !!messageText.value)\n\nconst wrapperClasses = computed(() => ({\n 'nb-text-input__field-wrapper--focused': focused.value,\n 'nb-text-input__field-wrapper--error': !!props.error,\n 'nb-text-input__field-wrapper--warning': !props.error && !!props.warning,\n 'nb-text-input__field-wrapper--disabled': props.disabled,\n 'nb-text-input__field-wrapper--readonly': props.readonly,\n 'nb-text-input__field-wrapper--overlay': useOverlay.value,\n 'nb-text-input__field-wrapper--multiline': props.multiline,\n}))\n</script>\n\n<style scoped lang=\"scss\">\n.nb-text-input {\n font-family: var(--nb-font-family-sans);\n --field-h: var(--nb-field-height-md);\n\n &--sm {\n --field-h: var(--nb-field-height-sm);\n }\n &--md {\n --field-h: var(--nb-field-height-md);\n }\n &--lg {\n --field-h: var(--nb-field-height-lg);\n }\n\n // ─── Field wrapper ────────────────────────────────────────\n &__field-wrapper {\n position: relative;\n display: flex;\n align-items: center;\n background: var(--nb-c-field-bg);\n // Always 1px border: never changes width, so no layout shift on focus\n border-bottom: 1px solid var(--nb-c-field-border);\n transition:\n border-color 0.15s,\n box-shadow 0.15s;\n\n &--focused {\n outline: 2px solid var(--nb-c-primary);\n outline-offset: -2px;\n }\n\n &--error {\n border-bottom-color: var(--nb-c-danger);\n box-shadow: inset 0 -1px 0 0 var(--nb-c-danger);\n }\n\n &--warning {\n border-bottom-color: var(--nb-c-warning);\n box-shadow: inset 0 -1px 0 0 var(--nb-c-warning);\n }\n\n &--disabled {\n opacity: var(--nb-field-disabled-opacity);\n cursor: not-allowed;\n }\n\n &--readonly {\n background: transparent;\n }\n\n &--multiline {\n align-items: stretch;\n }\n }\n\n // ─── Native input / textarea (normal mode) ────────────────\n &__field {\n flex: 1;\n min-width: 0;\n height: var(--field-h);\n padding: 0 var(--nb-field-padding-h);\n background: transparent;\n border: none;\n outline: none;\n font-family: inherit;\n font-size: var(--nb-field-font-size);\n font-weight: 400;\n color: var(--nb-c-text);\n line-height: var(--nb-field-line-height);\n\n &::placeholder {\n color: var(--nb-c-text-subtle);\n }\n &:disabled {\n cursor: not-allowed;\n }\n &:read-only {\n cursor: default;\n }\n }\n\n // ─── Overlay wrap: CSS Grid overlap ─────────────────────\n // Mirror and transparent input share the SAME grid cell, which guarantees\n // identical bounding boxes, padding, and line-height → caret aligns perfectly.\n &__overlay-wrap {\n flex: 1;\n min-width: 0;\n display: grid;\n }\n\n &__mirror,\n &__field--transparent {\n grid-area: 1 / 1; // overlap in the same grid cell\n font-family: inherit;\n font-size: var(--nb-field-font-size);\n font-weight: 400;\n line-height: var(--nb-field-line-height);\n word-break: break-word;\n overflow-wrap: break-word;\n }\n\n &__mirror {\n color: var(--nb-c-text);\n pointer-events: none;\n user-select: none;\n overflow: hidden;\n }\n\n &__field--transparent {\n background: transparent;\n color: transparent;\n caret-color: var(--nb-c-text);\n border: none;\n outline: none;\n resize: none;\n overflow: hidden;\n z-index: 1; // caret must sit above mirror\n width: 100%; // fill grid cell\n }\n\n // Single-line overlay: fixed height, text centred via line-height trick\n &:not(.nb-text-input--multiline) {\n .nb-text-input__mirror,\n .nb-text-input__field--transparent {\n height: var(--field-h);\n padding: 0 var(--nb-field-padding-h);\n // line-height = height centres single-line text identically in mirror and input\n line-height: var(--field-h);\n white-space: pre;\n overflow: hidden;\n }\n }\n\n // Multiline overlay + non-overlay textarea\n &--multiline {\n .nb-text-input__field-wrapper {\n align-items: stretch;\n }\n\n // Overlay: padding top/bottom, height driven by mirror content\n .nb-text-input__mirror,\n .nb-text-input__field--transparent {\n padding: 8px var(--nb-field-padding-h);\n white-space: pre-wrap;\n min-height: 80px;\n overflow-y: auto;\n }\n\n // Normal (non-overlay) textarea\n .nb-text-input__field {\n height: auto;\n min-height: 80px;\n padding: 8px var(--nb-field-padding-h);\n resize: vertical;\n overflow: auto;\n }\n }\n\n // Buttons rendered inside the field at the trailing edge (AI suggest, eye, clear…)\n &__actions {\n display: flex;\n align-items: center;\n padding: 0 8px;\n gap: 4px;\n flex-shrink: 0;\n z-index: 2; // above the transparent overlay input\n }\n\n // ─── Bottom message ───────────────────────────────────────\n &__message {\n font-size: var(--nb-font-size-12);\n }\n\n // ─── DEFAULT variant ──────────────────────────────────────\n &--default {\n position: relative; // anchor for #dropdown slot\n }\n\n // ─── FLUID variant ────────────────────────────────────────\n &--fluid {\n .nb-text-input__field-wrapper {\n box-sizing: border-box;\n flex: 1;\n flex-direction: column;\n align-items: stretch;\n justify-content: space-between;\n min-height: calc(var(--nb-base-unit) * 8);\n padding-top: 8px;\n }\n\n .nb-text-input__inner-header {\n display: flex;\n align-items: center;\n gap: 4px;\n padding: 0 var(--nb-field-padding-h);\n margin-bottom: 4px;\n }\n\n .nb-text-input__inner-label {\n display: flex;\n align-items: center;\n gap: 4px;\n flex: 1;\n min-width: 0;\n font-size: var(--nb-font-size-12);\n font-weight: 500;\n color: var(--nb-c-text-muted);\n letter-spacing: 0.02em;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n cursor: default;\n user-select: none;\n }\n\n .nb-text-input__asterisk {\n color: var(--nb-c-danger);\n }\n\n .nb-text-input__field {\n height: auto;\n flex: 1;\n padding: 0 var(--nb-field-padding-h) 10px;\n font-size: var(--nb-font-size-14);\n }\n }\n}\n</style>\n","<script setup lang=\"ts\">\nimport { ref, onMounted, onUnmounted, watch } from 'vue'\nimport NbIcon from './Icon.vue'\n\nexport type TToastVariant = 'success' | 'error' | 'warning' | 'info'\n\nexport interface IToastCta {\n label: string\n action: () => void\n}\n\nconst props = withDefaults(\n defineProps<{\n variant?: TToastVariant\n title?: string\n message: string\n duration?: number\n cta?: IToastCta\n }>(),\n {\n variant: 'info',\n title: undefined,\n duration: 4000,\n cta: undefined,\n },\n)\n\nconst emit = defineEmits<{ close: [] }>()\n\nconst paused = ref(false)\n\nconst iconMap: Record<TToastVariant, string> = {\n success: 'check-circle',\n error: 'warning-circle',\n warning: 'warning',\n info: 'info',\n}\n\nlet timer: ReturnType<typeof setTimeout> | null = null\nlet remaining = props.duration ?? 0\nlet startedAt = 0\n\nfunction startTimer() {\n if (!remaining) return\n startedAt = Date.now()\n timer = setTimeout(() => emit('close'), remaining)\n}\n\nfunction pauseProgress() {\n if (!remaining || paused.value) return\n paused.value = true\n if (timer) clearTimeout(timer)\n remaining -= Date.now() - startedAt\n}\n\nfunction resumeProgress() {\n if (!remaining || !paused.value) return\n paused.value = false\n startTimer()\n}\n\nonMounted(startTimer)\nonUnmounted(() => {\n if (timer) clearTimeout(timer)\n})\n\nwatch(\n () => props.duration,\n (val) => {\n if (timer) clearTimeout(timer)\n remaining = val ?? 0\n startTimer()\n },\n)\n</script>\n\n<template>\n <div\n :class=\"['nb-toast', `nb-toast--${variant}`]\"\n role=\"alert\"\n :aria-live=\"variant === 'error' ? 'assertive' : 'polite'\"\n @mouseenter=\"pauseProgress\"\n @mouseleave=\"resumeProgress\"\n >\n <div class=\"nb-toast__icon\">\n <NbIcon :name=\"iconMap[variant!]\" :size=\"16\" />\n </div>\n <div class=\"nb-toast__body\">\n <p v-if=\"title\" class=\"nb-toast__title\">{{ title }}</p>\n <p class=\"nb-toast__message\">{{ message }}</p>\n <button\n v-if=\"cta\"\n class=\"nb-toast__cta\"\n @click=\"\n () => {\n cta && cta.action()\n emit('close')\n }\n \"\n >\n {{ cta.label }}\n </button>\n </div>\n <button class=\"nb-toast__close\" aria-label=\"Close\" @click=\"emit('close')\">\n <NbIcon name=\"x\" :size=\"14\" />\n </button>\n <div\n v-if=\"duration\"\n ref=\"progressRef\"\n class=\"nb-toast__progress\"\n :style=\"{\n animationDuration: `${duration}ms`,\n animationPlayState: paused ? 'paused' : 'running',\n }\"\n />\n </div>\n</template>\n\n<style scoped lang=\"scss\">\n.nb-toast {\n position: relative;\n display: flex;\n align-items: flex-start;\n gap: 10px;\n padding: 12px 14px;\n background: var(--nb-c-bg, #fff);\n border: 1px solid var(--nb-c-border, #e5e7eb);\n border-radius: 10px;\n box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);\n min-width: 280px;\n max-width: 380px;\n overflow: hidden;\n font-family: var(--nb-font-family-sans, sans-serif);\n\n &--success .nb-toast__icon {\n color: var(--nb-c-success, #4acf7b);\n }\n &--error .nb-toast__icon {\n color: var(--nb-c-danger, #dc2626);\n }\n &--warning .nb-toast__icon {\n color: var(--nb-c-warning, #d97706);\n }\n &--info .nb-toast__icon {\n color: var(--nb-c-primary, #5856a9);\n }\n\n &--success {\n border-left: 3px solid var(--nb-c-success, #4acf7b);\n }\n &--error {\n border-left: 3px solid var(--nb-c-danger, #dc2626);\n }\n &--warning {\n border-left: 3px solid var(--nb-c-warning, #d97706);\n }\n &--info {\n border-left: 3px solid var(--nb-c-primary, #5856a9);\n }\n}\n\n.nb-toast__icon {\n flex-shrink: 0;\n margin-top: 1px;\n}\n\n.nb-toast__body {\n flex: 1;\n min-width: 0;\n display: flex;\n flex-direction: column;\n gap: 2px;\n}\n\n.nb-toast__title {\n margin: 0;\n font-size: 13px;\n font-weight: 600;\n color: var(--nb-c-text, #1a1a2e);\n line-height: 1.4;\n}\n\n.nb-toast__message {\n margin: 0;\n font-size: 13px;\n color: var(--nb-c-text-muted, #6b7280);\n line-height: 1.5;\n}\n\n.nb-toast__cta {\n margin-top: 6px;\n padding: 0;\n border: none;\n background: none;\n font-size: 12px;\n font-weight: 600;\n color: var(--nb-c-primary, #5856a9);\n cursor: pointer;\n text-align: left;\n line-height: 1;\n\n &:hover {\n text-decoration: underline;\n }\n}\n\n.nb-toast__close {\n flex-shrink: 0;\n display: flex;\n align-items: center;\n justify-content: center;\n width: 22px;\n height: 22px;\n border: none;\n background: transparent;\n border-radius: 4px;\n color: var(--nb-c-text-subtle, #9ca3af);\n cursor: pointer;\n transition:\n background 0.15s,\n color 0.15s;\n margin-top: -1px;\n\n &:hover {\n background: var(--nb-c-bg-subtle, #f3f4f6);\n color: var(--nb-c-text, #1a1a2e);\n }\n}\n\n.nb-toast__progress {\n position: absolute;\n bottom: 0;\n left: 0;\n height: 2px;\n width: 100%;\n background: currentColor;\n opacity: 0.25;\n transform-origin: left;\n animation: nb-toast-progress linear forwards;\n}\n\n@keyframes nb-toast-progress {\n from {\n transform: scaleX(1);\n }\n to {\n transform: scaleX(0);\n }\n}\n</style>\n","<script setup lang=\"ts\">\nimport { ref, onMounted, onUnmounted, watch } from 'vue'\nimport NbIcon from './Icon.vue'\n\nexport type TToastVariant = 'success' | 'error' | 'warning' | 'info'\n\nexport interface IToastCta {\n label: string\n action: () => void\n}\n\nconst props = withDefaults(\n defineProps<{\n variant?: TToastVariant\n title?: string\n message: string\n duration?: number\n cta?: IToastCta\n }>(),\n {\n variant: 'info',\n title: undefined,\n duration: 4000,\n cta: undefined,\n },\n)\n\nconst emit = defineEmits<{ close: [] }>()\n\nconst paused = ref(false)\n\nconst iconMap: Record<TToastVariant, string> = {\n success: 'check-circle',\n error: 'warning-circle',\n warning: 'warning',\n info: 'info',\n}\n\nlet timer: ReturnType<typeof setTimeout> | null = null\nlet remaining = props.duration ?? 0\nlet startedAt = 0\n\nfunction startTimer() {\n if (!remaining) return\n startedAt = Date.now()\n timer = setTimeout(() => emit('close'), remaining)\n}\n\nfunction pauseProgress() {\n if (!remaining || paused.value) return\n paused.value = true\n if (timer) clearTimeout(timer)\n remaining -= Date.now() - startedAt\n}\n\nfunction resumeProgress() {\n if (!remaining || !paused.value) return\n paused.value = false\n startTimer()\n}\n\nonMounted(startTimer)\nonUnmounted(() => {\n if (timer) clearTimeout(timer)\n})\n\nwatch(\n () => props.duration,\n (val) => {\n if (timer) clearTimeout(timer)\n remaining = val ?? 0\n startTimer()\n },\n)\n</script>\n\n<template>\n <div\n :class=\"['nb-toast', `nb-toast--${variant}`]\"\n role=\"alert\"\n :aria-live=\"variant === 'error' ? 'assertive' : 'polite'\"\n @mouseenter=\"pauseProgress\"\n @mouseleave=\"resumeProgress\"\n >\n <div class=\"nb-toast__icon\">\n <NbIcon :name=\"iconMap[variant!]\" :size=\"16\" />\n </div>\n <div class=\"nb-toast__body\">\n <p v-if=\"title\" class=\"nb-toast__title\">{{ title }}</p>\n <p class=\"nb-toast__message\">{{ message }}</p>\n <button\n v-if=\"cta\"\n class=\"nb-toast__cta\"\n @click=\"\n () => {\n cta && cta.action()\n emit('close')\n }\n \"\n >\n {{ cta.label }}\n </button>\n </div>\n <button class=\"nb-toast__close\" aria-label=\"Close\" @click=\"emit('close')\">\n <NbIcon name=\"x\" :size=\"14\" />\n </button>\n <div\n v-if=\"duration\"\n ref=\"progressRef\"\n class=\"nb-toast__progress\"\n :style=\"{\n animationDuration: `${duration}ms`,\n animationPlayState: paused ? 'paused' : 'running',\n }\"\n />\n </div>\n</template>\n\n<style scoped lang=\"scss\">\n.nb-toast {\n position: relative;\n display: flex;\n align-items: flex-start;\n gap: 10px;\n padding: 12px 14px;\n background: var(--nb-c-bg, #fff);\n border: 1px solid var(--nb-c-border, #e5e7eb);\n border-radius: 10px;\n box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);\n min-width: 280px;\n max-width: 380px;\n overflow: hidden;\n font-family: var(--nb-font-family-sans, sans-serif);\n\n &--success .nb-toast__icon {\n color: var(--nb-c-success, #4acf7b);\n }\n &--error .nb-toast__icon {\n color: var(--nb-c-danger, #dc2626);\n }\n &--warning .nb-toast__icon {\n color: var(--nb-c-warning, #d97706);\n }\n &--info .nb-toast__icon {\n color: var(--nb-c-primary, #5856a9);\n }\n\n &--success {\n border-left: 3px solid var(--nb-c-success, #4acf7b);\n }\n &--error {\n border-left: 3px solid var(--nb-c-danger, #dc2626);\n }\n &--warning {\n border-left: 3px solid var(--nb-c-warning, #d97706);\n }\n &--info {\n border-left: 3px solid var(--nb-c-primary, #5856a9);\n }\n}\n\n.nb-toast__icon {\n flex-shrink: 0;\n margin-top: 1px;\n}\n\n.nb-toast__body {\n flex: 1;\n min-width: 0;\n display: flex;\n flex-direction: column;\n gap: 2px;\n}\n\n.nb-toast__title {\n margin: 0;\n font-size: 13px;\n font-weight: 600;\n color: var(--nb-c-text, #1a1a2e);\n line-height: 1.4;\n}\n\n.nb-toast__message {\n margin: 0;\n font-size: 13px;\n color: var(--nb-c-text-muted, #6b7280);\n line-height: 1.5;\n}\n\n.nb-toast__cta {\n margin-top: 6px;\n padding: 0;\n border: none;\n background: none;\n font-size: 12px;\n font-weight: 600;\n color: var(--nb-c-primary, #5856a9);\n cursor: pointer;\n text-align: left;\n line-height: 1;\n\n &:hover {\n text-decoration: underline;\n }\n}\n\n.nb-toast__close {\n flex-shrink: 0;\n display: flex;\n align-items: center;\n justify-content: center;\n width: 22px;\n height: 22px;\n border: none;\n background: transparent;\n border-radius: 4px;\n color: var(--nb-c-text-subtle, #9ca3af);\n cursor: pointer;\n transition:\n background 0.15s,\n color 0.15s;\n margin-top: -1px;\n\n &:hover {\n background: var(--nb-c-bg-subtle, #f3f4f6);\n color: var(--nb-c-text, #1a1a2e);\n }\n}\n\n.nb-toast__progress {\n position: absolute;\n bottom: 0;\n left: 0;\n height: 2px;\n width: 100%;\n background: currentColor;\n opacity: 0.25;\n transform-origin: left;\n animation: nb-toast-progress linear forwards;\n}\n\n@keyframes nb-toast-progress {\n from {\n transform: scaleX(1);\n }\n to {\n transform: scaleX(0);\n }\n}\n</style>\n","import type { App } from 'vue'\n\nconst components: Record<string, any> = import.meta.glob('./**/*.vue', {\n eager: true,\n})\n\nexport default {\n install(app: App) {\n Object.keys(components).forEach((key) => {\n if (key.includes('/labs/')) return\n\n const name = `Nb${key.replace(/(.+\\/)(\\w+)(\\.vue)$/, '$2')}`\n const component = components[key]\n app.component(name, component.default)\n })\n },\n}\n","export function escapeHtml(unsafe: string): string {\n if (!unsafe) return unsafe\n\n // Define allowed tags (`b|em|strong|br|p`) with optional `style` and `class` attributes\n const allowedTagsPattern =\n '<\\\\/?\\\\s*(?:b|em|strong|br|p)(?:\\\\s+(?:style=\"[^\"]*\"|class=\"[^\"]*\"))*\\\\s*>'\n\n // Regex to match an exact allowed tag\n const exactAllowedTagRegex = new RegExp(`^${allowedTagsPattern}$`, 'i')\n\n // Regex to split while capturing allowed tags\n const splitRegex = new RegExp(`(${allowedTagsPattern})`, 'gi')\n\n const parts = unsafe.split(splitRegex)\n\n return parts\n .map((part) => {\n // If the part is exactly an allowed tag, return it unchanged\n if (exactAllowedTagRegex.test(part)) {\n return part\n }\n // Otherwise, escape special characters and convert newlines to <br>\n return part\n .replaceAll(/&(?!amp;|lt;|gt;|quot;|#039;)/g, '&amp;')\n .replaceAll('<', '&lt;')\n .replaceAll('>', '&gt;')\n .replaceAll('\"', '&quot;')\n .replaceAll(\"'\", '&#039;')\n .replaceAll('\\n', '<br>')\n })\n .join('')\n}\n","import type { App, DirectiveBinding } from 'vue'\nimport { escapeHtml } from '@/utils/escapeHtml.helper'\nimport type { IComponentContent } from '@/types/ContentRenderer'\n\ntype TTooltipEl = HTMLElement & {\n __showTooltip__?: () => void\n __hideTooltip__?: (delay?: number) => void\n __mouseMove__?: (e: MouseEvent) => void\n __showHandler__?: EventListener\n __hideHandler__?: EventListener\n __mouseX__?: number\n __mouseY__?: number\n __tooltipBinding__?: ITooltipOptions\n __showTimer__?: ReturnType<typeof setTimeout>\n tooltipElement?: HTMLSpanElement\n}\n\nexport interface ITooltipOptions {\n body?: string | Array<IComponentContent>\n header?: string | Array<IComponentContent>\n tip?: string | Array<IComponentContent>\n flavor?: string\n delay?: number\n animationTime?: number\n position?: 'top' | 'bottom' | 'left' | 'right' | 'cursor'\n followCursor?: boolean\n overflowOnly?: boolean\n classExtra?: string\n}\n\nconst registeredTooltips = new Set() // Store active tooltips globally\n\n/**\n * Converts complex content structure (IComponentContent array) to HTML string\n * Supports both 'children' and 'content' properties for compatibility\n */\nconst renderComplexContent = (\n content: Array<IComponentContent> | IComponentContent | any,\n): string => {\n if (Array.isArray(content)) {\n return content.map((item) => renderComplexContent(item)).join('')\n }\n\n if (!content || typeof content !== 'object' || !content.component) {\n return ''\n }\n\n const { component, props = {}, children, content: contentProp } = content\n // Support both 'children' and 'content' properties\n const childContent = children !== undefined ? children : contentProp\n\n const propsStr = Object.entries(props)\n .map(([key, value]) => `${key}=\"${escapeHtml(String(value))}\"`)\n .join(' ')\n\n const childrenHtml = Array.isArray(childContent)\n ? renderComplexContent(childContent)\n : childContent !== undefined\n ? escapeHtml(String(childContent))\n : ''\n\n return `<${component}${propsStr ? ` ${propsStr}` : ''}>${childrenHtml}</${component}>`\n}\n\n/**\n * Renders tooltip content - supports both string and complex content structure\n */\nconst renderTooltipContent = (\n content: string | Array<IComponentContent> | undefined,\n): string => {\n if (!content) return ''\n\n if (typeof content === 'string') {\n return escapeHtml(content)\n }\n\n if (Array.isArray(content)) {\n return renderComplexContent(content)\n }\n\n return ''\n}\n\nconst tooltipDirective = (app: App) => {\n const router = app.config.globalProperties.$router\n\n if (router) {\n router.beforeEach(() => {\n registeredTooltips.forEach((el: any) => el?.__hideTooltip__?.(0))\n registeredTooltips.clear()\n })\n }\n\n app.directive('nb-tooltip', {\n mounted(el: TTooltipEl, binding: DirectiveBinding<ITooltipOptions>) {\n let hideTimer: ReturnType<typeof setTimeout> | undefined = undefined\n\n el.__showTooltip__ = () => {\n clearTimeout(hideTimer)\n if (el.__tooltipBinding__) showTooltip(el, el.__tooltipBinding__)\n }\n\n el.__hideTooltip__ = (delay = 150) => {\n // set optimal hide delay by default (150ms)\n hideTimer = setTimeout(() => {\n hideTooltip(el, delay <= 0)\n }, delay)\n }\n\n el.__mouseMove__ = (event: MouseEvent) => {\n el.__mouseX__ = event.clientX\n el.__mouseY__ = event.clientY\n if (binding.value?.followCursor) {\n positionTooltip(\n el,\n el.tooltipElement,\n el.__tooltipBinding__?.position,\n )\n }\n }\n\n el.__tooltipBinding__ = binding.value\n\n el.__showHandler__ = () => el.__showTooltip__?.()\n el.__hideHandler__ = () => el.__hideTooltip__?.()\n\n el.addEventListener('mouseenter', el.__showHandler__)\n el.addEventListener('mouseleave', el.__hideHandler__)\n el.addEventListener('mousemove', el.__mouseMove__ as EventListener)\n window.addEventListener('scroll', el.__hideHandler__)\n },\n\n updated(el: TTooltipEl, binding: DirectiveBinding<ITooltipOptions>) {\n el.__tooltipBinding__ = binding.value\n if (!binding.value) {\n hideTooltip(el, true)\n } else if (el.tooltipElement) {\n updateTooltip(el, binding.value)\n }\n },\n\n unmounted(el: TTooltipEl) {\n hideTooltip(el, true)\n if (el.__showHandler__)\n el.removeEventListener('mouseenter', el.__showHandler__)\n if (el.__hideHandler__)\n el.removeEventListener('mouseleave', el.__hideHandler__)\n if (el.__hideHandler__)\n window.removeEventListener('scroll', el.__hideHandler__)\n },\n })\n}\n\nconst createTooltipContent = ({\n header = '',\n body = '',\n tip = '',\n}: Partial<Pick<ITooltipOptions, 'header' | 'body' | 'tip'>>) => {\n return `\n <div class=\"nb-tooltip-content\">\n <div class=\"nb-tooltip-header\">${renderTooltipContent(header)}</div>\n <div class=\"nb-tooltip-body\">${renderTooltipContent(body)}</div>\n <div class=\"nb-tooltip-tip\">${renderTooltipContent(tip)}</div>\n </div>\n `\n}\n\nconst showTooltip = (\n el: TTooltipEl,\n {\n header,\n body,\n tip,\n flavor = 'default',\n delay = 400,\n animationTime = 300,\n position,\n overflowOnly,\n classExtra,\n }: ITooltipOptions,\n) => {\n // Check if tooltip already exists, and remove it if it does\n const existingTooltip = el.tooltipElement\n if (existingTooltip) {\n existingTooltip.remove()\n }\n\n if (overflowOnly) {\n const rect = el.getBoundingClientRect()\n const isOverflowing = Math.round(rect.width) < Math.round(el.scrollWidth)\n if (!isOverflowing) {\n return\n }\n }\n\n if (!(body || header || tip)) {\n return\n }\n\n el.__showTimer__ = setTimeout(() => {\n const tooltip = document.createElement('span')\n tooltip.style.transition = `opacity ${animationTime}ms ease-in-out`\n tooltip.className = `nb-tooltip nb-tooltip-${position} ${flavor ? `nb-tooltip-flavor-${flavor}` : ''} ${classExtra || ''}`\n tooltip.innerHTML = createTooltipContent({ header, body, tip })\n tooltip.style.animation = `tooltipAppear ${animationTime}ms ease-in-out forwards`\n\n el.tooltipElement = tooltip\n registeredTooltips.add(el) // Register active tooltip\n\n document.body.appendChild(tooltip)\n positionTooltip(el, tooltip, position)\n }, delay) // ← optimal show delay (400ms)\n}\n\nconst hideTooltip = (el: TTooltipEl, immediate = false) => {\n // Retrieve tooltip element from the memoized property\n const tooltip = el.tooltipElement\n\n clearTimeout(el.__showTimer__)\n\n if (tooltip) {\n if (immediate) {\n tooltip.remove()\n } else {\n tooltip.style.animation = `tooltipDisappear 200ms ease-in-out forwards`\n setTimeout(() => {\n tooltip.remove()\n }, 200)\n }\n registeredTooltips.delete(el) // Remove from active tooltips\n }\n}\n\nconst updateTooltip = (\n el: TTooltipEl,\n { header, body, tip, position }: ITooltipOptions,\n) => {\n // Retrieve tooltip element from the memoized property\n const tooltip = el.tooltipElement\n\n if (tooltip) {\n tooltip.innerHTML = createTooltipContent({\n header,\n body,\n tip,\n })\n positionTooltip(el, tooltip, position)\n }\n}\n\nconst positionTooltip = (\n el: TTooltipEl,\n tooltip: HTMLSpanElement | undefined,\n position: ITooltipOptions['position'],\n) => {\n const gap = 4\n const rect = el.getBoundingClientRect()\n const tooltipRect = tooltip?.getBoundingClientRect()\n const tooltipWidth = tooltipRect?.width || 0\n const tooltipHeight = tooltipRect?.height || 0\n const parentScrollTop = el.scrollTop\n const parentScrollLeft = el.scrollLeft\n let top, left\n\n switch (position) {\n case 'top':\n top = rect.top - (tooltipHeight + gap * 2) - parentScrollTop // space for \"arrow\" which is 7.6 px\n left =\n rect.left +\n rect.width / 2 -\n (tooltipWidth / 2 + gap / 2) -\n parentScrollLeft\n break\n case 'bottom':\n top = rect.bottom + gap - parentScrollTop\n left =\n rect.left +\n rect.width / 2 -\n (tooltipWidth / 2 + gap / 2) -\n parentScrollLeft\n break\n case 'left':\n top = rect.top + rect.height / 2 - tooltipHeight / 2 - parentScrollTop\n left = rect.left - (tooltipWidth + gap * 2) - parentScrollLeft\n break\n case 'right':\n top = rect.top + rect.height / 2 - tooltipHeight / 2 - parentScrollTop\n left = rect.right + gap - parentScrollLeft\n break\n case 'cursor':\n default:\n top = (el.__mouseY__ ?? 0) + gap\n left = (el.__mouseX__ ?? 0) + gap\n break\n }\n\n if (tooltip) {\n tooltip.style.top = `${top}px`\n tooltip.style.left = `${left}px`\n }\n}\n\nexport default tooltipDirective\n","import type { App } from 'vue'\n\ntype TDirectiveModule = { default: (app: App) => void }\n\nconst modules = import.meta.glob<TDirectiveModule>('./**/*.ts', { eager: true })\n\nexport default {\n install(app: App) {\n Object.values(modules).forEach((mod) => {\n if (typeof mod.default === 'function') {\n mod.default(app)\n }\n })\n },\n}\n","import type { App } from 'vue'\n\nconst labsComponents: Record<string, any> = import.meta.glob(\n './components/labs/**/*.vue',\n { eager: true },\n)\n\nexport default {\n install(app: App) {\n Object.keys(labsComponents).forEach((key) => {\n const name = `Nb${key.replace(/(.+\\/)(\\w+)(\\.vue)$/, '$2')}`\n const component = labsComponents[key]\n app.component(name, component.default)\n })\n },\n}\n","import type { App } from 'vue'\nimport components from './components/index'\nimport directives from './directives/index'\n\nexport default {\n install(app: App) {\n app.use(components)\n app.use(directives)\n },\n}\n\n// Named exports for tree-shakeable individual imports\nexport { default as NbBreadcrumbs } from './components/Breadcrumbs.vue'\nexport { default as NbBadge } from './components/Badge.vue'\nexport { default as NbButton } from './components/Button.vue'\nexport { default as NbCheckbox } from './components/Checkbox.vue'\nexport { default as NbColorStrip } from './components/ColorStrip.vue'\nexport { default as NbFlag } from './components/Flag.vue'\nexport { default as NbGrid } from './components/Grid.vue'\nexport { default as NbIcon } from './components/Icon.vue'\nexport { default as NbJsonTree } from './components/JsonTree.vue'\nexport { default as NbLabel } from './components/Label.vue'\nexport { default as NbMessage } from './components/Message.vue'\nexport { default as NbModal } from './components/Modal.vue'\nexport { default as NbPanel } from './components/Panel.vue'\nexport { default as NbToast } from './components/Toast.vue'\nexport type { TToastVariant, IToastCta } from './components/Toast.vue'\nexport { default as NbRadio } from './components/Radio.vue'\nexport { default as NbNumberInput } from './components/NumberInput.vue'\nexport { default as NbSlider } from './components/Slider.vue'\nexport { default as NbSelect } from './components/Select.vue'\nexport { default as NbTextInput } from './components/TextInput.vue'\nexport type { ISelectOption, ISelectProps } from './components/Select.d'\n\n// Directives\nexport { default as nbTooltipDirective } from './directives/ToolTip.directive'\n\n// Labs plugin (experimental components)\nexport { default as NubiscoUILabs } from './labs'\n"],"x_google_ignoreList":[33,34,35,36],"mappings":"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;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACHD,SAAgB,GAAY,GAAqB;AAC/C,QAAO,EAAI,aAAa,CAAC,QAAQ,iBAAiB,MACzC,EAAE,GAAG,aAAa,CACzB;;;;ACgBJ,IAAK,KAAL,yBAAA,GAAA;QACE,EAAA,QAAA,SACA,EAAA,SAAA;EAFG,MAAA,EAAA,CAGJ,EAEI,KAAL,yBAAA,GAAA;QACE,EAAA,OAAA,QACA,EAAA,QAAA,SACA,EAAA,UAAA,WACA,EAAA,OAAA,QACA,EAAA,OAAA,QACA,EAAA,UAAA;EANG,MAAA,EAAA,CAOJ,EAEI,KAAL,yBAAA,GAAA;QACE,EAAA,EAAA,MAAA,MAAA,OACA,EAAA,EAAA,KAAA,MAAA,MACA,EAAA,EAAA,KAAA,MAAA,MACA,EAAA,EAAA,KAAA,MAAA,MACA,EAAA,EAAA,KAAA,MAAA,MACA,EAAA,EAAA,KAAA,MAAA,MACA,EAAA,EAAA,MAAA,KAAA;EAPG,MAAA,EAAA,CAQJ;;;ACxCD,SAAgB,GAAU,GAAwB;AAChD,QAAO,EACJ,QAAQ,kCAAkC,MAAM,CAChD,QAAQ,MAAM,IAAI,CAClB,QAAQ,mBAAmB,QAAQ,CACnC,QAAQ,QAAQ,IAAI,CACpB,aAAa;;;;ACYlB,SAAgB,GAAY,GAA+C;AACzE,KAAI,EAAM,GAAI,QAAO,EAAM;CAG3B,IAAM,IAAgB,GADL,GAAoB,EACK,MAAM,UAAU,YAAY;AAMtE,QAJI,EAAM,OACD,GAAG,EAAc,GAAG,GAAU,EAAM,KAAK,KAG3C,GAAG,EAAc,GAAG,IAAO;;;;;;;;;;;;;;;;;;;;;;;;;ECXpC,IAAM,IAAQ,GAWR,IAAO,GAEP,IAAsB,GAAY,EAAK,EAEvC,IAAa,QAAe;GAChC,IAAM,IACJ,OAAO,EAAM,QAAS,WAClB,EAAM,OACL,GACC,OAAO,EAAM,KAAK,CAAC,aAAY,KAC5B,GAAU;AAErB,UAAO;IACA,IAAI;IACT,GAAI,EAAM,QAAQ;KAChB,OAAO,GAAG,EAAS;KACnB,QAAQ,GAAG,EAAS;KACrB;IACD,GAAI,EAAM,aAAa,EAAE,MAAM,UAAU;IAC3C;IACD,EAEK,IAAgB,QAAe;GAEnC,IAAM,IAAW,IADD,GAAY,KAAK,EAAM,OAAM;AAE7C,UAAO,IAAU,EAAM,WAAW,GAAS;IAC5C,EAEK,IAAU,SACP;GACL,WAAW;GACX,GAAI,EAAM,QAAQ,GAAG,EAAM,OAAO,IAAM;IACvC,WAAW,EAAM,SAAS;IACzB;IACA;IACA;IACA;IACA;IACA;IACA;IACD,CAAC,SAAS,OAAO,EAAM,KAAK,CAAC;IAC7B,qBAAqB,EAAM,cAAc,GAAG,EAAM,cACjD,EAAM;GACR,WACE,EAAM,aAAc,EAAM,aAAa,EAAM,kBAAkB;GACjE,iBAAiB,EAAM;GACzB,EACD,EAEK,IAAS,SACN;GACL,GAAI,EAAM,SAAS,EAAE,OAAO,EAAM,OAAO;GACzC,GAAI,OAAO,EAAM,QAAS,YAAY;IACpC,UAAU,GAAG,EAAM,KAAK;IACxB,WAAW,GAAG,EAAM,KAAK;IACzB,QAAQ,GAAG,EAAM,KAAK;IACtB,OAAO,GAAG,EAAM,KAAK;IACtB;GACD,GAAI,OAAO,EAAM,QAAS,YACxB,CAAC;IAAC;IAAO;IAAM;IAAM;IAAM;IAAM;IAAM;IAAM,CAAC,SAAS,EAAM,KAAK,IAAI;IACpE,UAAU,EAAM;IAChB,WAAW,EAAM;IACjB,QAAQ,EAAM;IACd,OAAO,EAAM;IACd;GACL,EACD;yBAjGC,EAQI,KARJ,EAQI;GAPD,OAAO,EAAA;GACP,OAAO,EAAA;KACA,EAAA,OAAU;GACjB,OAAO,EAAA;GACP,SAAK,AAAA,EAAA,QAAA,MAAG,EAAA,YAAwB,EAAI,SAAU,EAAM,GAAhC,KAAA;aAErB,EAAoD,EAApC,EAAA,MAAa,EAAA,EAAE,eAAY,QAAM,CAAA,EAAA,EAAA,IAAA,IAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EE8BrD,IAAM,IAAQ,GAeR,IAAQ,IAAS,EACjB,IAAa,QACX,CAAC,EAAM,WAAW,CAAC,EAAE,EAAM,QAAQ,EAAM,SACjD,EAEM,IAAsC;GAC1C,KAAK;GACL,IAAI;GACJ,IAAI;GACJ,IAAI;GACJ,IAAI;GACJ,IAAI;GACJ,KAAK;GACP,EACM,IAAW,QAAe,EAAY,EAAM,QAAQ,SAAS,GAAE;yBAlEnE,EA4BY,EA3BL,EAAA,OAAI,MAAA,SAAA,EAAA;GACR,OAAK,EAAA;;kBAA2C,EAAA;kBAA+B,EAAA;6BAAuC,EAAA,UAAQ;4BAAkC,EAAA,SAAO;8BAAoC,EAAA,OAAU;;GAQrN,MAAM,EAAA,QAAQ,KAAA;GACd,QAAQ,EAAA,OAAO,EAAA,SAAS,KAAA;GACxB,KAAK,EAAA,OAAO,EAAA,MAAM,KAAA;GAClB,UAAW,EAAA,OAA6B,KAAA,IAAtB,EAAA,YAAY,EAAA;GAC9B,iBAAe,EAAA,SAAS,EAAA,YAAY,EAAA,WAAO,KAAW,KAAA;GACtD,MAAO,EAAA,OAAc,KAAA,IAAP,EAAA;GACd,SAAK,AAAA,EAAA,QAAA,MAAE,EAAA,YAAY,EAAA,UAAU,KAAA,IAAYA,EAAAA,MAAK,SAAU,EAAM;;oBAEvD,CAAR,EAAQ,EAAA,QAAA,WAAA,EAAA,EAAA,KAAA,GAAA,GAAA,EACG,EAAA,WAAW,EAAA,QAAA,GAAA,EAAtB,EAQM,OARN,KAQM,CAPQ,EAAA,WAAA,GAAA,EAAZ,EAAqE,QAArE,IAAqE,IAExD,EAAA,QAAA,GAAA,EADb,EAKE,IAAA;;IAHC,MAAM,EAAA;IACN,MAAM,EAAA;IACP,OAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EEWd,IAAM,IAAQ,GAOR,IAAO;EAEb,SAAS,EAAa,GAAU;AAC9B,GAAK,EAAM,YACT,EAAK,qBAAsB,EAAE,OAA4B,QAAO;;yBA/ClE,EA8BQ,SAAA,EA9BA,OAAK,EAAA,CAAA,eAAA,EAAA,yBAA6C,EAAA,UAAQ,CAAA,CAAA,EAAA,EAAA,CAChE,EA0BO,QA1BP,KA0BO,CAzBL,EAOE,SAAA;GANA,MAAK;GACJ,SAAS,EAAA;GACT,UAAU,EAAA;GACV,eAAe,EAAA;GAChB,OAAM;GACL,UAAQ;qBAEX,EAgBO,QAhBP,KAgBO,CAdG,EAAA,cAAU,CAAK,EAAA,iBAAA,GAAA,EADvB,EAaM,OAbN,KAaM,CAAA,GAAA,AAAA,EAAA,OAAA,CAPJ,EAME,QAAA;GALA,GAAE;GACF,QAAO;GACP,gBAAa;GACb,kBAAe;GACf,mBAAgB;gCAGR,EAAA,iBAAA,GAAA,EAAZ,EAAuD,QAAvD,IAAuD,IAAA,EAAA,IAAA,GAAA,CAAA,CAAA,CAAA,CAAA,EAG/C,EAAA,SAAA,GAAA,EAAZ,EAAgE,QAAhE,KAAgE,EAAf,EAAA,MAAK,EAAA,EAAA,IACtD,EAAe,EAAA,QAAA,WAAA,EAAA,KAAA,GAAA,EAAA,KAAA,GAAA,GAAA,CAAA,EAAA,EAAA;;;;;;;;GEoGb,MAAoB,IACpB,MAAc;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EApEpB,IAAM,IAAQ,GAWR,IAAS,kBAAkB,IAAO,IAClC,IAAe,QAAe,EAAM,MAAM,EAAM,EAEhD,IAAQ,EAAgB,GAAA,cAAC,EAC7B,MAAM,MAAQ,GACf,CAAA,EAEK,IAAoB,QACjB,EAAM,QAAQ,KAAK,MACpB,OAAO,KAAS,WACX;GACL,OAAO;GACP,OAAO;GACT,GAEO;GACL,GAAG;GACH,OAAO,EAAK,SAAS;GACrB,OAAO,EAAK,UAAU,KAAA,IAAyB,EAAK,QAAlB,EAAK;GACzC,CAEH,CACF,EAEK,IAAsB;GAC1B,IAAI;GACJ,OAAO;GACP,OAAO;GACP,OAAO;GACT,EAEM,IAAe,EAAI,EAAM,SAAS,KAAI;AAE5C,WACQ,EAAM,QACX,MAAU;AACT,GAAI,MACF,EAAa,QAAQ;IAG3B;EAEA,IAAM,IAAuB,QACvB,EAAM,gBAAsB,KAEzB,EAAM,YAAY,EAAa,MACvC,EAEK,IAAkB,QAClB,EAAqB,QAChB,CAAC,GAAY,GAAG,EAAkB,MAAK,GAGzC,EAAkB,MAC1B,EAKK,IAAa,QAAe;AAChC,OAAI,CAAC,EAAM,KACT,QAAO;IACL,UAAU;IACV,UAAU;IACZ;GAGF,IAAM,IAAa,EAAgB,MAAM;AACzC,OAAI,KAAc,EAAG;GAErB,IAAM,IAAU,KAAK,KAAK,KAAK,KAAK,EAAW,CAAA;AAG/C,UAAO;IACL,UAAU,GAHK,IAAU,OAAqB,IAAU,KAAK,IAGvC;IACtB,UAAU;IACZ;IACD,EAEK,IAAU,SAAgB;GAC9B,kBAAkB;GAClB,aAAa,EAAM;GACpB,EAAC,EAEI,KAAc,MACd,EAAM,WAAiB,KAEvB,MAAU,OACL,EAAM,SAAS,OAGpB,MAAU,KAAA,IAAkB,KAE5B,EAAM,gBACD,MAAM,QAAQ,EAAM,MAAM,IAAI,EAAM,MAAM,SAAS,EAAK,GAExD,EAAM,UAAU,GAIrB,KAAiB,OAAqB;GAC1C,wBAAwB;GACxB,6BAA6B,EAAa,EAAO;GACjD,UAAU,CAAC,EAAM,YAAY,EAAW,EAAO,MAAM;GACtD,GAEK,KAAe,MAAoB;AACnC,UAAa,EAAO,CAExB,QAAO,EACL,iBAAiB,EAAO,OAC1B;KAGI,KAAgB,MAAoB,EAAO,OAAO,eAElD,MAAuB,MACpB,EAAW,EAAO,MAAM,GAAG,YAAY,WAG1C,KAAgB,MAA8C;AAC9D,aAAU,KAAA,GAEd;QAAI,CAAC,EAAM,iBAAiB,MAAU,MAAM;AAC1C,OAAM,QAAQ;AACd;;AAGF,QAAI,EAAM,eAAe;KACvB,IAAM,IAAU,MAAM,QAAQ,EAAM,MAAM,GAAG,EAAM,MAAM,OAAO,GAAG,EAAC,EAC9D,IAAQ,EAAQ,QAAQ,EAAK;AAMnC,KALI,MAAU,KAGZ,EAAQ,KAAK,EAAK,GAFlB,EAAQ,OAAO,GAAO,EAAC,EAIzB,EAAM,QAAQ;UAEd,GAAM,QAAQ;;;EAKlB,SAAS,GAAoB,GAAkC;GAC7D,IAAM,IAAQ,OAAO,KAAW,WAAW,IAAS,EAAO,OAQrD,EAAE,MAAG,MAAG,SAAM,GANlB,KAAS,EAAM,WAAW,OAAM,GAC5B,iBAAiB,SAAS,gBAAe,CACtC,iBAAiB,EAAM,MAAM,GAAG,GAAG,CAAC,MAAM,CAAA,CAC1C,MAAK,GACR,MAEwC,UAAS;AAGvD,WADmB,OAAQ,IAAI,OAAQ,IAAI,OAAQ,KAAK,MACrC,KAAM,UAAU;;EAGrC,SAAS,EAAS,GAAa;GAC7B,IAAI,IAAW,EAAI,QAAQ,KAAK,GAAE;AAClC,GAAI,EAAS,WAAW,MACtB,IAAW,EACR,MAAM,GAAE,CACR,KAAK,MAAM,IAAI,EAAC,CAChB,KAAK,GAAE;GAEZ,IAAM,IAAM,SAAS,GAAU,GAAE;AACjC,UAAO;IACL,GAAI,KAAO,KAAM;IACjB,GAAI,KAAO,IAAK;IAChB,GAAG,IAAM;IACX;;;;eApPA,EAsDM,OAAA,EArDH,OAAK,EAAA,CAAA,0BAAA,2BAAwD,EAAA,UAAO,CAAA,EAAA,EAAA;IAGrD,EAAA,YAAO,aAAA,GAAA,EAAvB,EAKW,GAAA,EAAA,KAAA,GAAA,EAAA,CAJGC,EAAAA,OAAO,QAAnB,EAAyC,EAAA,QAAA,SAAA,EAAA,KAAA,GAAA,EAAA,KAAA,GAAA,GAAA,GACrB,EAAA,SAAA,GAAA,EAApB,EAEU,GAAA;;KAFkB,KAAK,EAAA;KAAe,UAAU;;sBAC7C,CAAA,EAAA,EAAR,EAAA,MAAK,EAAA,EAAA,CAAA,CAAA;;;IAMJ,EAAA,YAAO,YAAiB,EAAA,SAASA,EAAAA,OAAO,UAAA,GAAA,EADhD,EAQM,OARN,KAQM,CAJQA,EAAAA,OAAO,QAAnB,EAAyC,EAAA,QAAA,SAAA,EAAA,KAAA,GAAA,EAAA,KAAA,GAAA,GAAA,IAAA,GAAA,EACzC,EAEU,SAFV,KAEU,EADR,EAAA,MAAK,EAAA,EAAA,EAAA,CAAA,IAAA,EAAA,IAAA,GAAA;IAKT,EA8BS,GAAA;KA7BN,IAAI,EAAA;KACL,KAAI;KACJ,KAAI;KACH,OAAK,EAAE,EAAA,MAAO;KACd,QAAQ;KACR,OAAK,EAAE,EAAA,MAAU;;sBAIiB,EAAA,EAAA,GAAA,EAFnC,EAqBS,GAAA,MAAA,EAnBU,EAAA,QAAV,YAFT,EAqBS,GAAA;MApBP,IAAG;MAEF,KAAG,UAAY,EAAO,MAAM,EAAO;MACpC,OAAM;MACN,SAAQ;MACP,OAAK,EAAE,EAAc,EAAM,CAAA;MAC3B,OAAK,EAAE,EAAY,EAAM,CAAA;MACzB,UAAU,EAAO;MACjB,UAAK,MAAA,CAAG,EAAA,YAAY,EAAa,EAAO,MAAK;;uBAM5C,CAAA,CAHO,EAAA,YAAY,EAAW,EAAO,MAAK,IAAA,CAAM,EAAa,EAAM,IAAA,GAAA,EADrE,EAIE,GAAA;;OAFA,MAAK;OACJ,OAAO,GAAoB,EAAM;2CAG5B,EAAa,EAAM,IAAA,GAAA,EAD3B,EAIE,GAAA;;OAFA,MAAK;OACJ,QAAQ,GAAoB,EAAM;;;;;;;;;;;;;;;;;;qHElDxC,KAAL,yBAAA,GAAA;QACE,EAAA,UAAA,WACA,EAAA,YAAA,aACA,EAAA,QAAA,SACA,EAAA,SAAA,UACA,EAAA,UAAA,WACA,EAAA,UAAA;EANG,MAAA,EAAA,CAOJ,ECLI,KAAL,yBAAA,GAAA;QACE,EAAA,OAAA,QACA,EAAA,UAAA,WACA,EAAA,UAAA;EAHG,MAAA,EAAA,CAIJ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EC6FD,IAAM,IAAQ,GAMR,IAAO,GAOP,IAAW,EAA6B,KAAI,EAC5C,IAAQ,EAAiB,EAAE,CAAA,EAC3B,IAAa,EAAI,GAAK,EACxB,IAAc;EAElB,SAAS,IAAiB;AACxB,KAAS,OAAO,OAAM;;EAGxB,SAAS,EAAa,GAAgC;AACpD,OAAI,EAAM,WAAW,EAAK,OAAO,EAAM,QACrC,QAAO;AAET,OAAI,EAAM,QAAQ;IAChB,IAAM,IAAO,EAAM,OAAO,MAAM,IAAI,CAAC,KAAK,MAAM,EAAE,MAAM,CAAC,aAAa,CAAA,EAChE,IAAO,EAAK,KAAK,aAAY;AASnC,QAAI,CARY,EAAK,MAAM,MACrB,EAAI,WAAW,IAAI,GAAS,EAAK,SAAS,EAAG,GAC7C,EAAI,SAAS,IAAI,GAEjB,EAAK,SAAS,KAAO,EAAK,KAAK,WAAW,EAAI,WAAW,KAAK,GAAG,CAAA,GAE9D,GACR,CACa,QAAO;;;EAIzB,SAAS,EAAS,GAA6B;GAC7C,IAAM,IAAO,MAAM,KAAK,EAAQ;AAChC,GAAK,EAAM,aACT,EAAM,QAAQ,EAAC;AAEjB,QAAK,IAAM,KAAQ,GAAM;IACvB,IAAM,IAAQ,EAAa,EAAI;AAC/B,MAAM,MAAM,KAAK;KAAE;KAAM,QAAQ,GAAoB;KAAM;KAAO,CAAA;;AAEpE,KACE,UACA,EAAM,MAAM,QAAQ,MAAM,CAAC,EAAE,MAAM,CAAC,KAAK,MAAM,EAAE,KAAK,CACxD;;EAGF,SAAS,EAAkB,GAAc;GACvC,IAAM,IAAQ,EAAM;AACpB,GAAI,EAAM,OAAO,WACf,EAAS,EAAM,MAAK,EACpB,EAAM,QAAQ;;EAIlB,SAAS,IAAc;AAErB,GADA,KACA,EAAW,QAAQ;;EAGrB,SAAS,IAAc;AAErB,GADA,KACI,KAAe,MACjB,IAAc,GACd,EAAW,QAAQ;;EAIvB,SAAS,EAAO,GAAkB;AAEhC,GADA,IAAc,GACd,EAAW,QAAQ;GACnB,IAAM,IAAU,EAAM,cAAc;AACpC,GAAI,GAAS,UAAQ,EAAS,EAAO;;EAGvC,SAAS,EAAW,GAAe;GACjC,IAAM,IAAU,EAAM,MAAM;AAG5B,GAFA,EAAM,MAAM,OAAO,GAAO,EAAC,EAC3B,EAAK,UAAU,EAAQ,KAAI,EAC3B,EACE,UACA,EAAM,MAAM,QAAQ,MAAM,CAAC,EAAE,MAAM,CAAC,KAAK,MAAM,EAAE,KAAK,CACxD;;EAIF,SAAS,EACP,GACA,GACA,GACA;AACA,GAAI,EAAM,MAAM,OACd,EAAM,MAAM,GAAO,SAAS,GAC5B,EAAM,MAAM,GAAO,QAAQ;;SAI/B,EAAa;GAAE;GAAO;GAAe,CAAA,kBA7MnC,EAqFM,OAAA;GApFJ,OAAM;GACL,aAAS,EAAU,GAAW,CAAA,UAAA,CAAA;GAC9B,YAAQ,AAAA,EAAA,OAAA,QAAT,IAAiB,CAAA,UAAA,CAAA;GAChB,aAAS,EAAU,GAAW,CAAA,UAAA,CAAA;GAC9B,QAAI,EAAU,GAAM,CAAA,UAAA,CAAA;;GAEZ,EAAA,WAAA,GAAA,EAAT,EAAqE,KAArE,KAAqE,EAAd,EAAA,QAAO,EAAA,EAAA,IAAA,EAAA,IAAA,GAAA;GACrD,EAAA,eAAA,GAAA,EAAT,EAEI,KAFJ,KAEI,EADC,EAAA,YAAW,EAAA,EAAA,IAAA,EAAA,IAAA,GAAA;GAKR,EAAA,SAAA,GAAA,EADR,EAQM,OAAA;;IANJ,OAAK,EAAA,CAAC,8BAA4B,+BACK,EAAA,UAAO,CAAA;oBAE9C,EAEO,QAAA,EAFD,OAAM,gCAA8B,EAAA;MAAC,4BACjB;IAAA,EAAM,KAAA;MAAA,sBAChC;yBAGF,EAOW,IAAA;;IALT,OAAM;IACL,SAAS,EAAA;IACT,SAAK,EAAO,GAAc,CAAA,OAAA,CAAA;;qBAEV,CAAA,EAAA,EAAd,EAAA,YAAW,EAAA,EAAA,CAAA,CAAA;;;GAGhB,EAOE,SAAA;aANI;IAAJ,KAAI;IACJ,MAAK;IACL,OAAM;IACL,QAAQ,EAAA;IACR,UAAU,EAAA;IACV,UAAQ;;GAGD,EAAA,MAAM,UAAA,GAAA,EAAhB,EA2CK,MA3CL,KA2CK,EAAA,EAAA,GAAA,EA1CH,EAyCK,GAAA,MAAA,EAxCiB,EAAA,QAAZ,GAAM,YADhB,EAyCK,MAAA;IAvCF,KAAK;IACN,OAAK,EAAA,CAAC,0BAAwB;sCACuB,EAAK;wCAAoD,EAAK,WAAM;;;IAKzH,EAAgE,QAAhE,KAAgE,EAAxB,EAAK,KAAK,KAAI,EAAA,EAAA;IAEtD,EAyBO,QAzBP,KAyBO;KAvBG,EAAK,WAAM,aAAA,GAAA,EADnB,EAIE,IAAA;;MAFA,MAAK;MACL,OAAM;WAGK,EAAK,WAAM,aAAA,GAAA,EADxB,EAIE,IAAA;;MAFA,MAAK;MACL,OAAM;;KAGA,EAAK,SAAA,GAAA,EADb,EAIE,IAAA;;MAFA,MAAK;MACL,OAAM;;KAGA,EAAK,WAAM,YAMD,EAAA,IAAA,GAAA,IANC,GAAA,EADnB,EAQS,UAAA;;MANP,OAAM;MACN,MAAK;MACJ,cAAU,UAAY,EAAK,KAAK;MAChC,UAAK,MAAE,EAAW,EAAC;SAEpB,EAAmB,IAAA,EAAX,MAAK,KAAG,CAAA,CAAA,EAAA,GAAA,IAAA;;IAIT,EAAK,SAAA,GAAA,EAAhB,EAEM,OAFN,KAEM,EADD,EAAK,MAAK,EAAA,EAAA,IAAA,EAAA,IAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EExDvB,IAAM,IAAQ,GAMR,IAAO,GAEP,IAAsB,GAAY,EAAK,EAEvC,IAAU,SACP;GACL,WAAW;GACX,GAAI,EAAM,QAAQ,GAAG,YAAY,EAAM,SAAS,IAAM;IACrD,YAAY,EAAM,SACjB,OAAO,EAAM,QAAS,YAAY;IAAC;IAAM;IAAM;IAAK,CAAC,SAAS,EAAM,KAAK;GAC3E,iBAAiB,EAAM;GACzB,EACD,EAEK,IAAS,SACN;GACL,GAAI,OAAO,EAAM,QAAS,YAAY;IACpC,UAAU,GAAG,EAAM,KAAK;IACxB,WAAW,GAAG,EAAM,KAAK;IACzB,QAAQ,GAAG,EAAM,KAAK;IACtB,OAAO,GAAG,EAAM,KAAK;IACtB;GACD,GAAI,OAAO,EAAM,QAAS,YACxB,CAAC;IAAC;IAAM;IAAM;IAAK,CAAC,SAAS,EAAM,KAAK,IAAI;IAC1C,UAAU,EAAM;IAChB,WAAW,EAAM;IACjB,QAAQ,EAAM;IACd,OAAO,EAAM;IACd;GACL,EACD,EAEK,IAAa,QAAe;GAChC,IAAM,IACJ,OAAO,EAAM,QAAS,WAClB,EAAM,OACL,GACC,OAAO,EAAM,KAAK,CAAC,aAAY,KAC5B,GAAW;AAEtB,UAAO;IACA,IAAI;IACT,GAAI,EAAM,QAAQ;KAChB,OAAO,GAAG,EAAS;KACnB,QAAQ,GAAG,EAAS;KACrB;IACD,GAAI,EAAM,aAAa,EAAE,MAAM,UAAU;IAC3C;IACD,EAEK,IAAgB,QACb,IAAM,GAAY,KAAK,EAAM,KAAK,WAAW,KAAK,IAAI,GAAG,EACjE;yBAnFC,EAcI,KAdJ,EAcI;GAbD,OAAO,EAAA;GACP,OAAO,EAAA;KACA,EAAA,OAAU,EACjB,SAAK,AAAA,EAAA,QAAA,MAAG,EAAA,YAAwB,EAAI,SAAU,EAAM,GAAhC,KAAA,GAAgC,CAAA,EAAA,CAI7C,EAAA,SAAA,GAAA,EAFR,EAOE,EANK,EAAA,MAAa,EAAA;;GAEjB,eAAa;GACb,OAAO,EAAA,MAAW;GAClB,QAAQ,EAAA,MAAW;GACnB,OAAK,EAAE,EAAA,MAAM;;;;;;;;;;;;;eEZlB,EAwBS,GAAA;IAxBD,IAAG;IAAO,KAAI;IAAM,KAAI;IAAK,OAAM;;qBAGhC;KAFa,EAAA,SAAA,GAAA,EAAtB,EAES,GAAA;;MAFD,IAAG;MAAkB,OAAM;;uBACtB,CAAA,EAAA,EAAR,EAAA,MAAK,EAAA,EAAA,CAAA,CAAA;;;KAEWC,EAAAA,OAAO,WAAA,GAAA,EAA5B,EAES,GAAA;;MAFD,IAAG;MAA0B,OAAM;;uBAClB,CAAvB,EAAuB,EAAA,QAAA,UAAA,CAAA,CAAA;;;KAIjBA,EAAAA,OAAO,WAAA,GAAA,EAFf,EAQS,GAAA;;MAPP,IAAG;MAEH,KAAI;MACJ,KAAI;MACJ,OAAM;;uBAEE,CAAR,EAAQ,EAAA,QAAA,UAAA,CAAA,CAAA;;;KAIFA,EAAAA,OAAO,UAAA,GAAA,EAFf,EAOS,GAAA;;MANP,IAAG;MAEH,OAAM;MACN,SAAQ;;uBAEc,CAAtB,EAAsB,EAAA,QAAA,SAAA,CAAA,CAAA;;;;;;;;;;QEuHO;EACjC,IAAI;GACF,MAAM;GACN,SAAS;GACV;EAED,IAAI;GACF,MAAM;GACN,SAAS;GACV;EAED,KAAK;GACH,MAAM;IAAC;IAAQ;IAAQ;IAAS;GAChC,SAAS;GACT,YAAY,MACN,OAAO,KAAU,aAAmB,KACpC,OAAO,KAAU,WACX;IAAC;IAAO;IAAO;IAAe;IAAc,CAAW,SAC7D,EACD,GAEI,OAAO,OAAO,EAAM,CAAC,OAAO,MAChC;IAAC;IAAO;IAAO;IAAe;IAAc,CAAW,SACtD,EACD,CACF;GAEJ;EAED,OAAO;GACL,MAAM;IAAC;IAAQ;IAAQ;IAAS;GAChC,SAAS;GACT,YAAY,MACN,KAAS,QAAQ,OAAO,KAAU,aAAmB,KACrD,OAAO,KAAU,WAEjB;IAAC;IAAS;IAAO;IAAU;IAAY;IAAU,CACjD,SAAS,EAAoB,GAE1B,OAAO,OAAO,EAAM,CAAC,OAAO,MAChC;IAAC;IAAS;IAAO;IAAU;IAAY;IAAU,CAAW,SAC3D,EACD,CACF;GAEJ;EAED,SAAS;GACP,MAAM;IAAC;IAAQ;IAAQ;IAAS;GAChC,SAAS;GACT,YAAY,MACN,KAAS,QAAQ,OAAO,KAAU,aAAmB,KACrD,OAAO,KAAU,WAEjB;IAAC;IAAU;IAAW;IAAU;IAAO;IAAU;IAAQ,CACzD,SAAS,EAAsB,GAE5B,OAAO,OAAO,EAAM,CAAC,OAAO,MAE/B;IAAC;IAAU;IAAW;IAAU;IAAO;IAAU;IAAQ,CACzD,SAAS,EAAkB,CAC9B;GAEJ;EAED,KAAK;GACH,MAAM;IAAC;IAAQ;IAAQ;IAAS;GAChC,SAAS;GACT,YAAY,MAAkC;AAC5C,QAAI,KAAS,QAAQ,OAAO,KAAU,WAAY,QAAO;IACzD,IAAM,IAAa;KAAC;KAAO;KAAM;KAAM;KAAM;KAAM;KAAM;KAAM;AAI/D,WAHI,OAAO,KAAU,WACZ,EAAW,SAAS,EAAkB,GAExC,OAAO,OAAO,EAAM,CAAC,OAAO,MACjC,EAAW,SAAS,EAAc,CACnC;;GAEJ;EAED,MAAM;GACJ,MAAM;IAAC;IAAQ;IAAQ;IAAQ;IAAS;GACxC,SAAS;GACT,YAAY,MAAsC;AAChD,QAAI,KAAS,QAAQ,OAAO,KAAU,WAAY,QAAO;IACzD,IAAM,KAAiB,MAAuB;KAC5C,IAAM,IAAM,OAAO,KAAM,WAAW,SAAS,GAAG,GAAG,GAAG;AACtD,YAAO,KAAO,KAAK,KAAO,MAAM,CAAC,MAAM,EAAI;;AAM7C,WAHI,OAAO,KAAU,YAAY,OAAO,KAAU,WACzC,EAAc,EAAM,GAEtB,OAAO,OAAO,EAAM,CAAC,MAAM,EAAc;;GAEnD;EAED,OAAO;GACL,MAAM;IAAC;IAAQ;IAAQ;IAAQ;IAAS;GACxC,SAAS;GACT,YAAY,MAAoC;AAC9C,QAAI,KAAS,QAAQ,OAAO,KAAU,WAAY,QAAO;IACzD,IAAM,KAAgB,MAAuB;KAC3C,IAAM,IAAM,OAAO,KAAM,WAAW,SAAS,GAAG,GAAG,GAAG;AACtD,YAAO,KAAO,KAAK,KAAO,MAAM,CAAC,MAAM,EAAI;;AAM7C,WAHI,OAAO,KAAU,YAAY,OAAO,KAAU,WACzC,EAAa,EAAM,GAErB,OAAO,OAAO,EAAM,CAAC,MAAM,EAAa;;GAElD;EAED,MAAM;GACJ,MAAM;IAAC;IAAQ;IAAQ;IAAS;GAChC,SAAS;GACT,YAAY,MACN,KAAS,QAAQ,OAAO,KAAU,aAAmB,KACrD,OAAO,KAAU,WACX;IAAC;IAAU;IAAQ;IAAU,CAAW,SAC9C,EACD,GAEI,OAAO,OAAO,EAAM,CAAC,OAAO,MAChC;IAAC;IAAU;IAAQ;IAAU,CAAW,SAAS,EAAe,CAClE;GAEJ;EAED,OAAO;GACL,MAAM,CAAC,SAAS,MAAM;GACtB,SAAS;GACT,YAAY,MAAuC;AAEjD,QADI,KAAS,QACT,OAAO,KAAU,UAAW,QAAO;IACvC,IAAM,IAAmB;KAAC;KAAM;KAAM;KAAM;KAAM;KAAM;AACxD,WAAO,EAAM,OAAO,MAAO,EAAiB,SAAS,EAAkB,CAAC;;GAE3E;EAED,MAAM;GACJ,MAAM,CAAC,SAAS,MAAM;GACtB,SAAS;GACT,YAAY,MAAuC;AAEjD,QADI,KAAS,QACT,OAAO,KAAU,UAAW,QAAO;IACvC,IAAM,IAAmB;KAAC;KAAM;KAAM;KAAM;KAAM;KAAM;AACxD,WAAO,EAAM,OAAO,MAAO,EAAiB,SAAS,EAAkB,CAAC;;GAE3E;EAED,SAAS;GACP,MAAM;IAAC;IAAS;IAAQ;IAAS;GACjC,SAAS;GACV;EAED,SAAS;GACP,MAAM,CAAC,SAAS,MAAM;GACtB,SAAS;GACT,YAAY,MAAuC;AAEjD,QADI,KAAS,QACT,OAAO,KAAU,UAAW,QAAO;IACvC,IAAM,IAAmB;KAAC;KAAM;KAAM;KAAM;KAAM;KAAM;AACxD,WAAO,EAAM,OAAO,MAAO,EAAiB,SAAS,EAAkB,CAAC;;GAE3E;EAED,MAAM;GACJ,MAAM;GACN,SAAS;GACV;EAED,MAAM;GACJ,MAAM;GACN,SAAS;GACV;EAED,QAAQ;GACN,MAAM;GACN,SAAS;GACV;EAED,aAAa;GACX,MAAM;GACN,SAAS;GACV;EAED,MAAM;GACJ,MAAM;GACN,SAAS;GACT,YAAY,MACF;IAAC;IAAQ;IAAU;IAAY,CAAW,SAChD,EACD;GAEJ;EAED,UAAU;GACR,MAAM;GACN,SAAS;GACV;EACF;;EC9TD,IAAM,IAAoB;GACxB;GACA;GACA;GACA;GACA;GACA;GACA;GACA;GACA;GACA;GACA;GACA;GACF,EAGM,IAAO,GAAiB;AAG9B,IAAa,EACX,cAHmB,EAAK,OAIzB,CAAA;EAGD,IAAM,IAAQ,GAUR,KAAuB,MAC3B,EAAW,QAAQ,mBAAmB,QAAQ,CAAC,aAAY;EAS7D,SAAS,EAAgB,GAAkB,GAA4B;GACrE,IAAM,EAAE,eAAY,kBAAe,GAC7B,IAAS,IAAa,GAAG,EAAW,KAAK;AAG3C,QAAc,MAAU,UAI5B,EAAW,GAAG,IAAS,OAAW;;EAMpC,SAAS,EAAY,GAAmB,GAA4B;GAClE,IAAM,EAAE,eAAY,eAAY,gBAAa,GACvC,IAAS,IAAa,GAAG,EAAW,KAAK,IACzC,IAAc,IAAW,MAAU;AAEzC,KAAW,GAAG,EAAO,QAAQ,OAAiB;;EAMhD,SAAS,EAAc,GAAqB,GAA4B;GACtE,IAAM,EAAE,eAAY,eAAY,gBAAa,GACvC,IAAS,IAAa,GAAG,EAAW,KAAK,IACzC,IAAc,IAAW,MAAU;AAEzC,KAAW,GAAG,EAAO,UAAU,OAAiB;;EAMlD,SAAS,EAAU,GAAe,GAA4B;GAC5D,IAAM,EAAE,eAAY,kBAAe,GAC7B,IAAS,IAAa,GAAG,EAAW,KAAK;AAE/C,KAAW,GAAG,EAAO,MAAM,OAAW;;EAMxC,SAAS,EAAW,GAAwB,GAA4B;GACtE,IAAM,EAAE,eAAY,kBAAe,GAC7B,IAAS,IAAa,GAAG,EAAW,KAAK;AAE/C,KAAW,GAAG,EAAO,OAAO,OAAW;;EAMzC,SAAS,EAAY,GAAwB,GAA4B;GACvE,IAAM,EAAE,eAAY,kBAAe,GAC7B,IAAS,IAAa,GAAG,EAAW,KAAK;AAE/C,KAAW,GAAG,EAAO,QAAQ,OAAW;;EAM1C,SAAS,EAAW,GAAkB,GAA4B;GAChE,IAAM,EAAE,eAAY,kBAAe,GAC7B,IAAS,IAAa,GAAG,EAAW,KAAK;AAE/C,KAAW,GAAG,IAAS,OAAW;;EAMpC,SAAS,EAAc,GAAgB,GAA4B;AACjE,OAAI,CAAC,EAAO;GAEZ,IAAM,EAAE,eAAY,kBAAe,GAC7B,IAAS,IAAa,GAAG,EAAW,KAAK;AAE/C,KAAW,GAAG,EAAO,YAAY;;EAMnC,SAAS,EACP,GACA,GACA,GACM;AACN,OAAI,CAAC,EAAO;GAEZ,IAAM,EAAE,eAAY,kBAAe,GAC7B,IAAS,IAAa,GAAG,EAAW,KAAK;AAE/C,KAAW,GAAG,IAAS,OAAU;;EAMnC,SAAS,EAAc,GAAgB,GAA4B;GACjE,IAAM,EAAE,eAAY,kBAAe,GAC7B,IAAS,IAAa,GAAG,EAAW,KAAK;AAE/C,KAAW,GAAG,IAAS,IAAQ,YAAY,cAAc;;EAkB3D,SAAS,EACP,GAOA,GACA,GACkB;GAClB,IAAM,IAA+B,EAAC;AAEtC,OAAI,KAAQ,KAAM,QAAO;AAGzB,OAAI,OAAO,KAAS,YAAY;IAC9B,IAAM,IAAS,GAAiB;AAIhC,WAHI,KAAS,QACX,EAAQ,GAAO;KAAE;KAAY;KAAU,CAAA,EAElC;;AAgCT,UA3BE,OAAO,KAAS,YAChB,OAAO,KAAS,YAChB,OAAO,KAAS,aAEhB,EAAQ,GAAW;IAAE;IAAY;IAAU,CAAA,EACpC,KAIL,MAAM,QAAQ,EAAK,IACrB,EAAK,SAAS,MAAe;AAE3B,MAAQ,IAAW;KAAE;KAAY,YADlB,EAAoB,EAAoB;KACF;KAAU,CAAA;KAChE,EACM,MAIL,OAAO,KAAS,YAClB,OAAO,QAAQ,EAAK,CAAC,SAAS,CAAC,GAAY,OAAW;AACpD,IAAI,KAAS,QAEX,EAAQ,GAAY;KAAE;KAAY,YADnB,EAAoB,EAAU;KACS;KAAU,CAAA;KAEnE,EAGI;;EAWT,IAAM,KAAuB,MAAiC;GAE5D,IAAM,IAAwC;IAC5C,KAAK;IACL,QAAQ;IACR,QAAQ;IACR,SAAS;IACT,UAAU;IACZ,EAEM,IAA0C;IAC9C,MAAM;IACN,OAAO;IACP,QAAQ;IACR,SAAS;IACT,QAAQ;IACR,QAAQ;IACV;AAEA,UAAO;IACL,WAAW;IACX,GAAG,EAAsB,EAAM,KAAK,EAAgB;IACpD,GAAG,EAAsB,EAAM,OAAO,GAAa,EAAc;IACjE,GAAG,EAAsB,EAAM,SAAS,GAAe,EAAgB;IACvE,GAAG,EAAsB,EAAM,KAAK,EAAU;IAC9C,GAAG,EAAsB,EAAM,MAAM,EAAW;IAChD,GAAG,EAAsB,EAAM,OAAO,EAAY;IAClD,GAAG,EAAsB,EAAM,MAAM,EAAW;IAChD,GAAG,EAAsB,EAAM,SAAS,EAAc;IACtD,GAAG,EAAsB,EAAM,QAAQ,GAAK,MAC1C,EAAY,GAAK,GAAK,QAAQ,CAC/B;IACD,GAAG,EAAsB,EAAM,OAAO,GAAK,MACzC,EAAY,GAAK,GAAK,OAAO,CAC9B;IACD,GAAG,EAAsB,EAAM,SAAS,EAAc;IACtD,GAAI,EAAM,OAAO,EAAE,MAAM,IAAM,GAAG,EAAE;IACpC,GAAI,EAAM,cAAc,EAAE,aAAa,IAAM,GAAG,EAAE;IAClD,GAAI,EAAM,OAAO,GAAG,EAAM,OAAO,IAAM,GAAG,EAAE;IAC5C,GAAI,EAAM,OAAO,EAAE,MAAM,IAAM,GAAG,EAAE;IACpC,GAAI,EAAM,WAAW,QAAQ,EAAM,WAAW,KAAA,IAC1C,GAAG,UAAU,EAAM,SAAS,MAAM,QAAQ,IAAK,GAC/C,EAAE;IACR;KAII,IAAU,QAAe,EAAoB,EAAM,CAAA;yBAnTvD,EAQY,EAPLC,EAAAA,GAAE,EAAA;GACN,IAAIC,EAAAA;YACD;GAAJ,KAAI;GACH,OAAK,EAAE,EAAA,MAAO;GACd,UAAWC,EAAAA,YAAQ,CAAK,EAAkB,SAASF,EAAAA,GAAE,GAAA,OAAA;;oBAE9C,CAAR,EAAQ,EAAA,QAAA,UAAA,CAAA,CAAA;;;;;;;;;;;AEHZ,SAAS,GAAK,GAAK,GAAK;AACpB,CAAI,OAAO,UAAY,QACnB,QAAQ,KAAK,eAAe,EAAI,EAE5B,KACA,QAAQ,KAAK,EAAI,MAAM;;AAInC,IAAM,KAAY,EAAE;AACpB,SAAS,IAAS,GAAK;AACnB,CAAK,GAAU,OACX,GAAU,KAAO,IACjB,GAAK,EAAI;;AAQjB,IAAM,KAAY,OAAO,SAAW,KAChC,IACA;AACJ,IAAA,QAAA,IAAA,aAA8B,cAAe;CACzC,IAAM,IAAO,MAAa,OAAO;AACjC,CAAI,KACA,EAAK,QACL,EAAK,WACL,EAAK,cAEL,EAAK,kBACL,MAAQ,MAAQ;AACZ,IAAK,KAAK,EAAI;IAElB,MAAW,GAAM,GAAU,MAAW;AAGlC,EAFA,EAAK,QAAQ,GAAM,GAAU,EAAO,EACpC,EAAK,WAAW,EAAS,EACzB,EAAK,WAAW,EAAO;;;AAInC,IAAM,MAAU;AAEhB,SAASG,GAAO,GAAS,GAAG,GAAM;AAO9B,QANI,EAAK,WAAW,KAAK,EAAS,EAAK,GAAG,KACtC,IAAO,EAAK,MAEZ,CAAC,KAAQ,CAAC,EAAK,oBACf,IAAO,EAAE,GAEN,EAAQ,QAAQ,MAAU,GAAO,MAC7B,EAAK,eAAe,EAAW,GAAG,EAAK,KAAc,GAC9D;;AAEN,IAAM,MAAc,GAAM,IAAY,OAAW,IAA2B,OAAO,IAAI,EAAK,GAA/B,OAAO,EAAK,EACnE,OAA0B,GAAQ,GAAK,MAAW,IAAsB;CAAE,GAAG;CAAQ,GAAG;CAAK,GAAG;CAAQ,CAAC,EACzG,OAAyB,MAAS,KAAK,UAAU,EAAK,CACvD,QAAQ,WAAW,UAAU,CAC7B,QAAQ,WAAW,UAAU,CAC7B,QAAQ,WAAW,UAAU,EAC5B,KAAY,MAAQ,OAAO,KAAQ,YAAY,SAAS,EAAI,EAC5D,MAAU,MAAQ,GAAa,EAAI,KAAK,iBACxC,MAAY,MAAQ,GAAa,EAAI,KAAK,mBAC1C,MAAiB,MAAQ,EAAc,EAAI,IAAI,OAAO,KAAK,EAAI,CAAC,WAAW,GAC3E,KAAS,OAAO,QAChB,MAAU,OAAO,QACjB,KAAU,IAAM,SAAS,IAAQ,EAAI,EACvC,KACE,WAEM,AACH,QACG,OAAO,aAAe,MAChB,aACA,OAAO,OAAS,MACZ,OACA,OAAO,SAAW,MACd,SACA,OAAO,SAAW,MACd,SACA,GAAQ;AAEtC,SAASC,GAAW,GAAS;AACzB,QAAO,EACF,QAAQ,MAAM,QAAQ,CACtB,QAAQ,MAAM,OAAO,CACrB,QAAQ,MAAM,OAAO,CACrB,QAAQ,MAAM,SAAS,CACvB,QAAQ,MAAM,SAAS,CACvB,QAAQ,OAAO,SAAS,CACxB,QAAQ,MAAM,SAAS;;AAEhC,SAAS,GAAqB,GAAO;AACjC,QAAO,EACF,QAAQ,4BAA4B,QAAQ,CAC5C,QAAQ,MAAM,SAAS,CACvB,QAAQ,MAAM,SAAS,CACvB,QAAQ,MAAM,OAAO,CACrB,QAAQ,MAAM,OAAO;;AAE9B,SAAS,IAAuB,GAAM;AA0BlC,QAvBA,IAAO,EAAK,QAAQ,2BAA2B,GAAG,GAAU,MAAc,GAAG,EAAS,IAAI,GAAqB,EAAU,CAAC,GAAG,EAE7H,IAAO,EAAK,QAAQ,2BAA2B,GAAG,GAAU,MAAc,GAAG,EAAS,IAAI,GAAqB,EAAU,CAAC,GAAG,EAEjG,qCACJ,KAAK,EAAK,KAC9B,QAAA,IAAA,aAA8B,gBAC1B,GAAK,yIAC0E,EAGnF,IAAO,EAAK,QAAQ,wBAAwB,cAAc,GAGjC,CAEzB,mEAEA,mDACH,CACoB,SAAQ,MAAW;AACpC,MAAO,EAAK,QAAQ,GAAS,oBAAoB;GACnD,EACK;;AAEX,IAAM,MAAiB,OAAO,UAAU;AACxC,SAAS,GAAO,GAAK,GAAK;AACtB,QAAO,IAAe,KAAK,GAAK,EAAI;;AAUxC,IAAM,IAAU,MAAM,SAChB,KAAc,MAAQ,OAAO,KAAQ,YACrC,KAAY,MAAQ,OAAO,KAAQ,UACnC,KAAa,MAAQ,OAAO,KAAQ,WAGpC,KAAY,MAAwB,OAAO,KAAQ,cAA/B,GAEpB,OAAa,MACR,EAAS,EAAI,IAAI,EAAW,EAAI,KAAK,IAAI,EAAW,EAAI,MAAM,EAEnE,KAAiB,OAAO,UAAU,UAClC,MAAgB,MAAU,GAAe,KAAK,EAAM,EACpD,KAAiB,MAAQ,GAAa,EAAI,KAAK,mBAE/CC,OAAmB,MACd,KAAO,OACR,KACA,EAAQ,EAAI,IAAK,EAAc,EAAI,IAAI,EAAI,aAAa,KACpD,KAAK,UAAU,GAAK,MAAM,EAAE,GAC5B,OAAO,EAAI;AAEzB,SAAS,GAAK,GAAO,IAAY,IAAI;AACjC,QAAO,EAAM,QAAQ,GAAK,GAAM,MAAW,MAAU,IAAI,IAAM,IAAO,IAAM,IAAY,GAAO,GAAG;;AAEtG,IAAM,KAAQ;AACd,SAAS,IAAkB,GAAQ,IAAQ,GAAG,IAAM,EAAO,QAAQ;CAC/D,IAAM,IAAQ,EAAO,MAAM,QAAQ,EAC/B,IAAQ,GACN,IAAM,EAAE;AACd,MAAK,IAAI,IAAI,GAAG,IAAI,EAAM,QAAQ,IAE9B,KADA,KAAS,EAAM,GAAG,SAAS,GACvB,KAAS,GAAO;AAChB,OAAK,IAAI,IAAI,IAAI,IAAO,KAAK,IAAI,MAAS,IAAM,GAAO,KAAK;AACxD,OAAI,IAAI,KAAK,KAAK,EAAM,OACpB;GACJ,IAAM,IAAO,IAAI;AACjB,KAAI,KAAK,GAAG,IAAO,IAAI,OAAO,IAAI,OAAO,EAAK,CAAC,OAAO,CAAC,KAAK,EAAM,KAAK;GACvE,IAAM,IAAa,EAAM,GAAG;AAC5B,OAAI,MAAM,GAAG;IAET,IAAM,IAAM,KAAS,IAAQ,KAAc,GACrC,IAAS,KAAK,IAAI,GAAG,IAAM,IAAQ,IAAa,IAAM,IAAM,EAAM;AACxE,MAAI,KAAK,WAAW,IAAI,OAAO,EAAI,GAAG,IAAI,OAAO,EAAO,CAAC;cAEpD,IAAI,GAAG;AACZ,QAAI,IAAM,GAAO;KACb,IAAM,IAAS,KAAK,IAAI,KAAK,IAAI,IAAM,GAAO,EAAW,EAAE,EAAE;AAC7D,OAAI,KAAK,WAAW,IAAI,OAAO,EAAO,CAAC;;AAE3C,SAAS,IAAa;;;AAG9B;;AAGR,QAAO,EAAI,KAAK,KAAK;;AAezB,SAAS,MAAgB;CACrB,IAAM,oBAAS,IAAI,KAAK;AAyBxB,QAxBgB;EACZ;EACA,GAAG,GAAO,GAAS;GACf,IAAM,IAAW,EAAO,IAAI,EAAM;AAElC,GADc,KAAY,EAAS,KAAK,EAAQ,IAE5C,EAAO,IAAI,GAAO,CAAC,EAAQ,CAAC;;EAGpC,IAAI,GAAO,GAAS;GAChB,IAAM,IAAW,EAAO,IAAI,EAAM;AAClC,GAAI,KACA,EAAS,OAAO,EAAS,QAAQ,EAAQ,KAAK,GAAG,EAAE;;EAG3D,KAAK,GAAO,GAAS;AAIjB,IAHC,EAAO,IAAI,EAAM,IAAI,EAAE,EACnB,OAAO,CACP,KAAI,MAAW,EAAQ,EAAQ,CAAC,GACpC,EAAO,IAAI,IAAI,IAAI,EAAE,EACjB,OAAO,CACP,KAAI,MAAW,EAAQ,GAAO,EAAQ,CAAC;;EAEnD;;AAIL,IAAM,MAAwB,MAAQ,CAAC,EAAS,EAAI,IAAI,EAAQ,EAAI;AAEpE,SAAS,GAAS,GAAK,GAAK;AAExB,KAAI,GAAqB,EAAI,IAAI,GAAqB,EAAI,CACtD,OAAU,MAAM,gBAAgB;CAEpC,IAAM,IAAQ,CAAC;EAAE;EAAK;EAAK,CAAC;AAC5B,QAAO,EAAM,SAAQ;EACjB,IAAM,EAAE,QAAK,WAAQ,EAAM,KAAK;AAEhC,SAAO,KAAK,EAAI,CAAC,SAAQ,MAAO;AACxB,SAAQ,gBAKR,EAAS,EAAI,GAAK,IAAI,CAAC,EAAS,EAAI,GAAK,KACzC,EAAI,KAAO,MAAM,QAAQ,EAAI,GAAK,GAAG,EAAE,GAAG,GAAQ,GAElD,GAAqB,EAAI,GAAK,IAAI,GAAqB,EAAI,GAAK,GAIhE,EAAI,KAAO,EAAI,KAIf,EAAM,KAAK;IAAE,KAAK,EAAI;IAAM,KAAK,EAAI;IAAM,CAAC;IAElD;;;;;ACzQV,SAAS,IAAe,GAAM,GAAQ,GAAQ;AAC1C,QAAO;EAAE;EAAM;EAAQ;EAAQ;;AAEnC,SAAS,GAAe,GAAO,GAAK,GAAQ;CACxC,IAAM,IAAM;EAAE;EAAO;EAAK;AAI1B,QAHI,KAAU,SACV,EAAI,SAAS,IAEV;;AAGX,IAAM,IAAoB;CAEtB,gBAAgB;CAChB,8BAA8B;CAC9B,0CAA0C;CAC1C,yBAAyB;CACzB,iCAAiC;CACjC,0BAA0B;CAC1B,4BAA4B;CAC5B,mBAAmB;CACnB,4BAA4B;CAC5B,uBAAuB;CAEvB,8BAA8B;CAC9B,kCAAkC;CAClC,6BAA6B;CAC7B,6BAA6B;CAE7B,6BAA6B;CAE7B,8BAA8B;CACjC,EAMKC,MAAgB;EAEjB,EAAkB,iBAAiB;EACnC,EAAkB,+BAA+B;EACjD,EAAkB,2CAA2C;EAC7D,EAAkB,0BAA0B;EAC5C,EAAkB,kCAAkC;EACpD,EAAkB,2BAA2B;EAC7C,EAAkB,6BAA6B;EAC/C,EAAkB,oBAAoB;EACtC,EAAkB,6BAA6B;EAC/C,EAAkB,wBAAwB;EAE1C,EAAkB,+BAA+B;EACjD,EAAkB,mCAAmC;EACrD,EAAkB,8BAA8B;EAChD,EAAkB,8BAA8B;EAEhD,EAAkB,8BAA8B;EAEhD,EAAkB,+BAA+B;CACrD;AACD,SAAS,GAAmB,GAAM,GAAK,IAAU,EAAE,EAAE;CACjD,IAAM,EAAE,WAAQ,aAAU,YAAS,GAC7B,IAAA,QAAA,IAAA,aAAgC,eAEhC,IADAC,IAAQ,KAAYD,KAAe,MAAS,IAAI,GAAI,KAAQ,EAAE,CAAE,EAEhE,IAAY,YAAY,OAAO,EAAI,CAAC;AAM1C,QALA,EAAM,OAAO,GACT,MACA,EAAM,WAAW,IAErB,EAAM,SAAS,GACR;;AAGX,SAAS,IAAe,GAAO;AAC3B,OAAM;;AAIV,IAAM,MAAc,2BACd,OAAiB,MAAW,IAAY,KAAK,EAAO,EAEpD,KAAU,KACV,MAAU,MACV,KAAU,MACV,MAAU,UACV,MAAU;AAChB,SAAS,IAAc,GAAK;CACxB,IAAM,IAAO,GACT,IAAS,GACT,IAAQ,GACR,IAAU,GACV,IAAc,GACZ,KAAU,MAAU,EAAK,OAAW,OAAW,EAAK,IAAQ,OAAO,IACnE,KAAQ,MAAU,EAAK,OAAW,IAClC,KAAQ,MAAU,EAAK,OAAW,KAClC,KAAQ,MAAU,EAAK,OAAW,KAClC,KAAa,MAAU,EAAO,EAAM,IAAI,EAAK,EAAM,IAAI,EAAK,EAAM,IAAI,EAAK,EAAM,EACjF,UAAc,GACd,UAAa,GACb,UAAe,GACf,UAAmB,GACnB,KAAU,MAAW,EAAO,EAAO,IAAI,EAAK,EAAO,IAAI,EAAK,EAAO,GAAG,KAAU,EAAK,IACrF,UAAoB,EAAO,EAAO,EAClC,UAAoB,EAAO,IAAS,EAAY;CACtD,SAAS,IAAO;AAWZ,SAVA,IAAc,GACV,EAAU,EAAO,KACjB,KACA,IAAU,IAEV,EAAO,EAAO,IACd,KAEJ,KACA,KACO,EAAK;;CAEhB,SAAS,IAAO;AAKZ,SAJI,EAAO,IAAS,EAAY,IAC5B,KAEJ,KACO,EAAK,IAAS;;CAEzB,SAAS,IAAQ;AAIb,EAHA,IAAS,GACT,IAAQ,GACR,IAAU,GACV,IAAc;;CAElB,SAAS,EAAU,IAAS,GAAG;AAC3B,MAAc;;CAElB,SAAS,IAAa;EAClB,IAAM,IAAS,IAAS;AACxB,SAAO,MAAW,GACd,IAAM;AAEV,MAAc;;AAElB,QAAO;EACH;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACH;;AAGL,IAAM,KAAM,KAAA,GAEN,KAAoB,KACpB,MAAiB;AACvB,SAAS,IAAgB,GAAQ,IAAU,EAAE,EAAE;CAC3C,IAAM,IAAW,EAAQ,aAAa,IAChC,IAAQ,IAAc,EAAO,EAC7B,UAAsB,EAAM,OAAO,EACnC,UAAwB,IAAe,EAAM,MAAM,EAAE,EAAM,QAAQ,EAAE,EAAM,OAAO,CAAC,EACnF,IAAW,GAAiB,EAC5B,IAAc,GAAe,EAC7B,IAAW;EACb,aAAa;EACb,QAAQ;EACR,UAAU;EACV,QAAQ;EACR,UAAU;EACV,YAAY;EACZ,cAAc;EACd,YAAY;EACZ,WAAW;EACX,UAAU;EACV,MAAM;EACT,EACK,UAAgB,GAChB,EAAE,eAAY;CACpB,SAAS,EAAU,GAAM,GAAK,GAAQ,GAAG,GAAM;EAC3C,IAAM,IAAM,GAAS;AAGrB,EAFA,EAAI,UAAU,GACd,EAAI,UAAU,GACV,KAMA,EAJY,GAAmB,GADnB,IAAW,GAAe,EAAI,UAAU,EAAI,GAAG,MACjB;GACtC,QAAQ;GACR;GACH,CAAC,CACU;;CAGpB,SAAS,EAAS,GAAS,GAAM,GAAO;AAEpC,EADA,EAAQ,SAAS,GAAiB,EAClC,EAAQ,cAAc;EACtB,IAAM,IAAQ,EAAE,SAAM;AAOtB,SANI,MACA,EAAM,MAAM,GAAe,EAAQ,UAAU,EAAQ,OAAO,GAE5D,KAAS,SACT,EAAM,QAAQ,IAEX;;CAEX,IAAM,KAAe,MAAY,EAAS,GAAS,GAAwB;CAC3E,SAAS,EAAI,GAAM,GAAI;AAOf,SANA,EAAK,aAAa,KAAK,KACvB,EAAK,MAAM,EACJ,MAGP,EAAU,EAAkB,gBAAgB,GAAiB,EAAE,GAAG,EAAG,EAC9D;;CAGf,SAAS,EAAW,GAAM;EACtB,IAAI,IAAM;AACV,SAAO,EAAK,aAAa,KAAK,MAAW,EAAK,aAAa,KAAK,IAE5D,CADA,KAAO,EAAK,aAAa,EACzB,EAAK,MAAM;AAEf,SAAO;;CAEX,SAAS,EAAW,GAAM;EACtB,IAAM,IAAM,EAAW,EAAK;AAE5B,SADA,EAAK,YAAY,EACV;;CAEX,SAAS,EAAkB,GAAI;AAC3B,MAAI,MAAO,GACP,QAAO;EAEX,IAAM,IAAK,EAAG,WAAW,EAAE;AAC3B,SAAS,KAAM,MAAM,KAAM,OACtB,KAAM,MAAM,KAAM,MACnB,MAAO;;CAGf,SAAS,EAAc,GAAI;AACvB,MAAI,MAAO,GACP,QAAO;EAEX,IAAM,IAAK,EAAG,WAAW,EAAE;AAC3B,SAAO,KAAM,MAAM,KAAM;;CAE7B,SAAS,EAAuB,GAAM,GAAS;EAC3C,IAAM,EAAE,mBAAgB;AACxB,MAAI,MAAgB,EAChB,QAAO;AAEX,IAAW,EAAK;EAChB,IAAM,IAAM,EAAkB,EAAK,aAAa,CAAC;AAEjD,SADA,EAAK,WAAW,EACT;;CAEX,SAAS,EAAsB,GAAM,GAAS;EAC1C,IAAM,EAAE,mBAAgB;AACxB,MAAI,MAAgB,EAChB,QAAO;AAEX,IAAW,EAAK;EAEhB,IAAM,IAAM,EADD,EAAK,aAAa,KAAK,MAAM,EAAK,MAAM,GAAG,EAAK,aAAa,CAC3C;AAE7B,SADA,EAAK,WAAW,EACT;;CAEX,SAAS,EAAe,GAAM,GAAS;EACnC,IAAM,EAAE,mBAAgB;AACxB,MAAI,MAAgB,EAChB,QAAO;AAEX,IAAW,EAAK;EAChB,IAAM,IAAM,EAAK,aAAa,KAAK;AAEnC,SADA,EAAK,WAAW,EACT;;CAEX,SAAS,EAAiB,GAAM,GAAS;EACrC,IAAM,EAAE,mBAAgB;AACxB,MAAI,MAAgB,EAChB,QAAO;AAEX,IAAW,EAAK;EAChB,IAAM,IAAM,EAAK,aAAa,KAAK;AAEnC,SADA,EAAK,WAAW,EACT;;CAEX,SAAS,EAAsB,GAAM,GAAS;EAC1C,IAAM,EAAE,mBAAgB;AACxB,MAAI,MAAgB,EAChB,QAAO;AAEX,IAAW,EAAK;EAChB,IAAM,IAAM,EAAkB,EAAK,aAAa,CAAC;AAEjD,SADA,EAAK,WAAW,EACT;;CAEX,SAAS,EAAuB,GAAM,GAAS;EAC3C,IAAM,EAAE,mBAAgB;AACxB,MAAI,EAAE,MAAgB,KAClB,MAAgB,IAChB,QAAO;AAEX,IAAW,EAAK;EAChB,IAAM,IAAM,EAAK,aAAa,KAAK;AAEnC,SADA,EAAK,WAAW,EACT;;CAEX,SAAS,EAAmB,GAAM,GAAS;EACvC,IAAM,EAAE,mBAAgB;AACxB,MAAI,MAAgB,EAChB,QAAO;EAEX,IAAM,UAAW;GACb,IAAM,IAAK,EAAK,aAAa;AAkBzB,UAjBA,MAAO,MACA,EAAkB,EAAK,MAAM,CAAC,GAEhC,MAAO,OACZ,MAAO,OACP,MAAO,OACP,MAAO,OACP,MAAO,MACP,CAAC,IACM,KAEF,MAAO,MACZ,EAAK,MAAM,EACJ,GAAI,IAIJ,EAAY,GAAM,GAAM;KAGjC,IAAM,GAAI;AAEhB,SADA,EAAK,WAAW,EACT;;CAEX,SAAS,EAAc,GAAM;AACzB,IAAW,EAAK;EAChB,IAAM,IAAM,EAAK,aAAa,KAAK;AAEnC,SADA,EAAK,WAAW,EACT;;CAEX,SAAS,EAAY,GAAM,IAAQ,IAAM;EACrC,IAAM,KAAM,IAAW,IAAO,IAAO,OAAO;GACxC,IAAM,IAAK,EAAK,aAAa;AAmBzB,UAlBA,MAAO,OAGF,MAAO,OAAoC,CAAC,IAF1C,IAKF,MAAO,MACL,EAAE,MAAS,MAAW,MAAS,MAEjC,MAAO,MACZ,EAAK,MAAM,EACJ,EAAG,IAAM,GAAQ,IAEnB,MAAO,MACZ,EAAK,MAAM,EACJ,EAAG,IAAM,GAAQ,IAGjB;KAGT,IAAM,GAAI;AAEhB,SADA,KAAS,EAAK,WAAW,EAClB;;CAEX,SAAS,EAAS,GAAM,GAAI;EACxB,IAAM,IAAK,EAAK,aAAa;AAQ7B,SAPI,MAAO,KACA,KAEP,EAAG,EAAG,IACN,EAAK,MAAM,EACJ,KAEJ;;CAEX,SAAS,EAAa,GAAI;EACtB,IAAM,IAAK,EAAG,WAAW,EAAE;AAC3B,SAAS,KAAM,MAAM,KAAM,OACtB,KAAM,MAAM,KAAM,MAClB,KAAM,MAAM,KAAM,MACnB,MAAO,MACP,MAAO;;CAGf,SAAS,GAAmB,GAAM;AAC9B,SAAO,EAAS,GAAM,EAAa;;CAEvC,SAAS,EAAkB,GAAI;EAC3B,IAAM,IAAK,EAAG,WAAW,EAAE;AAC3B,SAAS,KAAM,MAAM,KAAM,OACtB,KAAM,MAAM,KAAM,MAClB,KAAM,MAAM,KAAM,MACnB,MAAO,MACP,MAAO,MACP,MAAO;;CAGf,SAAS,EAAwB,GAAM;AACnC,SAAO,EAAS,GAAM,EAAkB;;CAE5C,SAAS,GAAQ,GAAI;EACjB,IAAM,IAAK,EAAG,WAAW,EAAE;AAC3B,SAAO,KAAM,MAAM,KAAM;;CAE7B,SAAS,EAAU,GAAM;AACrB,SAAO,EAAS,GAAM,GAAQ;;CAElC,SAAS,GAAW,GAAI;EACpB,IAAM,IAAK,EAAG,WAAW,EAAE;AAC3B,SAAS,KAAM,MAAM,KAAM,MACtB,KAAM,MAAM,KAAM,MAClB,KAAM,MAAM,KAAM;;CAE3B,SAAS,EAAa,GAAM;AACxB,SAAO,EAAS,GAAM,GAAW;;CAErC,SAAS,EAAU,GAAM;EACrB,IAAI,IAAK,IACL,IAAM;AACV,SAAQ,IAAK,EAAU,EAAK,EACxB,MAAO;AAEX,SAAO;;CAEX,SAAS,EAAS,GAAM;EACpB,IAAI,IAAM;AACV,WAAa;GACT,IAAM,IAAK,EAAK,aAAa;AAC7B,OAAI,MAAO,MAAM;IACb,IAAM,IAAS,EAAK,MAAM;AAC1B,IAAI,MAAW,OACX,MAAW,OACX,MAAW,OACX,MAAW,OACX,MAAW,QACX,KAAO,IAAK,GACZ,EAAK,MAAM,EACX,EAAK,MAAM,KAGX,EAAK,WAAW,EAChB,KAAO,GACP,EAAK,MAAM;cAGV,MAAO,OACZ,MAAO,OACP,MAAO,OACP,MAAO,OACP,CAAC,EACD;YAEK,MAAO,MAAW,MAAO,GAC9B,KAAI,EAAY,EAAK,CAEjB,CADA,KAAO,GACP,EAAK,MAAM;YAEN,EAAc,EAAK,CACxB;OAIA,CADA,KAAO,GACP,EAAK,MAAM;OAKf,CADA,KAAO,GACP,EAAK,MAAM;;AAGnB,SAAO;;CAEX,SAAS,GAAoB,GAAM;AAC/B,IAAW,EAAK;EAChB,IAAI,IAAK,IACL,IAAO;AACX,SAAQ,IAAK,EAAwB,EAAK,EACtC,MAAQ;EAGZ,IAAM,IAAc,EAAK,aAAa;AACtC,MAAI,KACA,MAAgB,OAChB,MAAgB,MAChB,MAAgB,MAChB,MAAgB,MAChB,MAAgB,KAAU;GAC1B,IAAM,IAAc,EAAsB,EAAK;AAE/C,UADA,EAAU,EAAkB,8BAA8B,GAAiB,EAAE,GAAG,IAAO,EAAY,EAC5F,IAAO;;AAKlB,SAHI,EAAK,aAAa,KAAK,MACvB,EAAU,EAAkB,4BAA4B,GAAiB,EAAE,EAAE,EAE1E;;CAEX,SAAS,GAAmB,GAAM;AAC9B,IAAW,EAAK;EAChB,IAAI,IAAQ;AAWZ,SAVI,EAAK,aAAa,KAAK,OACvB,EAAK,MAAM,EACX,KAAS,IAAI,EAAU,EAAK,MAG5B,KAAS,EAAU,EAAK,EAExB,EAAK,aAAa,KAAK,MACvB,EAAU,EAAkB,4BAA4B,GAAiB,EAAE,EAAE,EAE1E;;CAEX,SAAS,EAAU,GAAI;AACnB,SAAO,MAAO,MAAqB,MAAO;;CAE9C,SAAS,EAAY,GAAM;AAGvB,EAFA,EAAW,EAAK,EAEhB,EAAI,GAAM,IAAK;EACf,IAAI,IAAK,IACL,IAAU;AACd,SAAQ,IAAK,EAAS,GAAM,EAAU,EAClC,CAAI,MAAO,OACP,KAAW,GAAmB,EAAK,GAGnC,KAAW;EAGnB,IAAM,IAAU,EAAK,aAAa;AAalC,SAZI,MAAY,MAAW,MAAY,MACnC,EAAU,EAAkB,0CAA0C,GAAiB,EAAE,EAAE,EAEvF,MAAY,OACZ,EAAK,MAAM,EAEX,EAAI,GAAM,IAAK,GAEZ,MAGX,EAAI,GAAM,IAAK,EACR;;CAEX,SAAS,GAAmB,GAAM;EAC9B,IAAM,IAAK,EAAK,aAAa;AAC7B,UAAQ,GAAR;GACI,KAAK;GACL,KAAK,IAED,QADA,EAAK,MAAM,EACJ,KAAK;GAChB,KAAK,IACD,QAAO,EAA0B,GAAM,GAAI,EAAE;GACjD,KAAK,IACD,QAAO,EAA0B,GAAM,GAAI,EAAE;GACjD,QAEI,QADA,EAAU,EAAkB,yBAAyB,GAAiB,EAAE,GAAG,EAAG,EACvE;;;CAGnB,SAAS,EAA0B,GAAM,GAAS,GAAQ;AACtD,IAAI,GAAM,EAAQ;EAClB,IAAI,IAAW;AACf,OAAK,IAAI,IAAI,GAAG,IAAI,GAAQ,KAAK;GAC7B,IAAM,IAAK,EAAa,EAAK;AAC7B,OAAI,CAAC,GAAI;AACL,MAAU,EAAkB,iCAAiC,GAAiB,EAAE,GAAG,KAAK,IAAU,IAAW,EAAK,aAAa,GAAG;AAClI;;AAEJ,QAAY;;AAEhB,SAAO,KAAK,IAAU;;CAE1B,SAAS,EAAoB,GAAI;AAC7B,SAAQ,MAAO,OACX,MAAO,OACP,MAAO,MACP,MAAO;;CAEf,SAAS,EAAsB,GAAM;AACjC,IAAW,EAAK;EAChB,IAAI,IAAK,IACL,IAAc;AAClB,SAAQ,IAAK,EAAS,GAAM,EAAoB,EAC5C,MAAe;AAEnB,SAAO;;CAEX,SAAS,GAAmB,GAAM;EAC9B,IAAI,IAAK,IACL,IAAO;AACX,SAAQ,IAAK,GAAmB,EAAK,EACjC,MAAQ;AAEZ,SAAO;;CAEX,SAAS,GAAgB,GAAM;EAC3B,IAAM,KAAM,MAAQ;GAChB,IAAM,IAAK,EAAK,aAAa;AAoBzB,UAnBA,MAAO,OACP,MAAO,OACP,MAAO,OACP,MAAO,OACP,MAAO,OACP,CAAC,KAGI,MAAO,KAFL,KAMP,KAAO,GACP,EAAK,MAAM,EACJ,EAAG,EAAI;;AAQtB,SAAO,EAAG,GAAG;;CAEjB,SAAS,GAAW,GAAM;AACtB,IAAW,EAAK;EAChB,IAAM,IAAS,EAAI,GAAM,IAA0B;AAEnD,SADA,EAAW,EAAK,EACT;;CAGX,SAAS,GAAuB,GAAM,GAAS;EAC3C,IAAI,IAAQ;AAEZ,UADW,EAAK,aAAa,EAC7B;GACI,KAAK,IAQD,QAPI,EAAQ,aAAa,KACrB,EAAU,EAAkB,4BAA4B,GAAiB,EAAE,EAAE,EAEjF,EAAK,MAAM,EACX,IAAQ,EAAS,GAAS,GAA8B,IAA+B,EACvF,EAAW,EAAK,EAChB,EAAQ,aACD;GACX,KAAK,IAYD,QAXI,EAAQ,YAAY,KACpB,EAAQ,gBAAgB,KACxB,EAAU,EAAkB,mBAAmB,GAAiB,EAAE,EAAE,EAExE,EAAK,MAAM,EACX,IAAQ,EAAS,GAAS,GAA+B,IAAgC,EACzF,EAAQ,aACR,EAAQ,YAAY,KAAK,EAAW,EAAK,EACrC,EAAQ,YAAY,EAAQ,cAAc,MAC1C,EAAQ,WAAW,KAEhB;GACX,KAAK,IAMD,QALI,EAAQ,YAAY,KACpB,EAAU,EAAkB,4BAA4B,GAAiB,EAAE,EAAE,EAEjF,IAAQ,EAAkB,GAAM,EAAQ,IAAI,EAAY,EAAQ,EAChE,EAAQ,YAAY,GACb;GACX,SAAS;IACL,IAAI,IAAuB,IACvB,IAAsB,IACtB,IAAe;AACnB,QAAI,EAAc,EAAK,CAQnB,QAPI,EAAQ,YAAY,KACpB,EAAU,EAAkB,4BAA4B,GAAiB,EAAE,EAAE,EAEjF,IAAQ,EAAS,GAAS,GAAyB,GAAW,EAAK,CAAC,EAEpE,EAAQ,YAAY,GACpB,EAAQ,WAAW,IACZ;AAEX,QAAI,EAAQ,YAAY,MACnB,EAAQ,gBAAgB,KACrB,EAAQ,gBAAgB,KACxB,EAAQ,gBAAgB,GAG5B,QAFA,EAAU,EAAkB,4BAA4B,GAAiB,EAAE,EAAE,EAC7E,EAAQ,YAAY,GACb,GAAU,GAAM,EAAQ;AAEnC,QAAK,IAAuB,EAAuB,GAAM,EAAQ,CAG7D,QAFA,IAAQ,EAAS,GAAS,GAA0B,GAAoB,EAAK,CAAC,EAC9E,EAAW,EAAK,EACT;AAEX,QAAK,IAAsB,EAAsB,GAAM,EAAQ,CAG3D,QAFA,IAAQ,EAAS,GAAS,GAAyB,GAAmB,EAAK,CAAC,EAC5E,EAAW,EAAK,EACT;AAEX,QAAK,IAAe,EAAe,GAAM,EAAQ,CAG7C,QAFA,IAAQ,EAAS,GAAS,GAA4B,EAAY,EAAK,CAAC,EACxE,EAAW,EAAK,EACT;AAEX,QAAI,CAAC,KAAwB,CAAC,KAAuB,CAAC,EAKlD,QAHA,IAAQ,EAAS,GAAS,IAAkC,EAAsB,EAAK,CAAC,EACxF,EAAU,EAAkB,8BAA8B,GAAiB,EAAE,GAAG,EAAM,MAAM,EAC5F,EAAW,EAAK,EACT;AAEX;;;AAGR,SAAO;;CAGX,SAAS,EAAkB,GAAM,GAAS;EACtC,IAAM,EAAE,mBAAgB,GACpB,IAAQ,MACN,IAAK,EAAK,aAAa;AAQ7B,WAPK,MAAgB,KACjB,MAAgB,KAChB,MAAgB,MAChB,MAAgB,OACf,MAAO,MAAW,MAAO,OAC1B,EAAU,EAAkB,uBAAuB,GAAiB,EAAE,EAAE,EAEpE,GAAR;GACI,KAAK,IAID,QAHA,EAAK,MAAM,EACX,IAAQ,EAAS,GAAS,GAAgC,IAAiC,EAC3F,EAAQ,WAAW,IACZ;GACX,KAAK,IAGD,QAFA,EAAW,EAAK,EAChB,EAAK,MAAM,EACJ,EAAS,GAAS,GAA8B,IAA+B;GAC1F,KAAK,IAGD,QAFA,EAAW,EAAK,EAChB,EAAK,MAAM,EACJ,EAAS,GAAS,GAAoC,IAAqC;GACtG,QAgCI,QA/BI,EAAc,EAAK,IACnB,IAAQ,EAAS,GAAS,GAAyB,GAAW,EAAK,CAAC,EAEpE,EAAQ,YAAY,GACpB,EAAQ,WAAW,IACZ,KAEP,EAAiB,GAAM,EAAQ,IAC/B,EAAuB,GAAM,EAAQ,IACrC,EAAW,EAAK,EACT,EAAkB,GAAM,EAAQ,IAEvC,EAAsB,GAAM,EAAQ,IACpC,EAAW,EAAK,EACT,EAAS,GAAS,IAAoC,GAAmB,EAAK,CAAC,IAEtF,EAAmB,GAAM,EAAQ,IACjC,EAAW,EAAK,EACZ,MAAO,MAEA,GAAuB,GAAM,EAAQ,IAAI,IAGzC,EAAS,GAAS,IAA+B,GAAgB,EAAK,CAAC,KAGlF,MAAgB,KAChB,EAAU,EAAkB,uBAAuB,GAAiB,EAAE,EAAE,EAE5E,EAAQ,YAAY,GACpB,EAAQ,WAAW,IACZ,GAAU,GAAM,EAAQ;;;CAI3C,SAAS,GAAU,GAAM,GAAS;EAC9B,IAAI,IAAQ,EAAE,MAAM,IAAyB;AAC7C,MAAI,EAAQ,YAAY,EACpB,QAAO,GAAuB,GAAM,EAAQ,IAAI,EAAY,EAAQ;AAExE,MAAI,EAAQ,SACR,QAAO,EAAkB,GAAM,EAAQ,IAAI,EAAY,EAAQ;AAGnE,UADW,EAAK,aAAa,EAC7B;GACI,KAAK,IACD,QAAO,GAAuB,GAAM,EAAQ,IAAI,EAAY,EAAQ;GACxE,KAAK,IAGD,QAFA,EAAU,EAAkB,0BAA0B,GAAiB,EAAE,EAAE,EAC3E,EAAK,MAAM,EACJ,EAAS,GAAS,GAA+B,IAAgC;GAC5F,KAAK,IACD,QAAO,EAAkB,GAAM,EAAQ,IAAI,EAAY,EAAQ;GACnE;AACI,QAAI,EAAc,EAAK,CAKnB,QAJA,IAAQ,EAAS,GAAS,GAAyB,GAAW,EAAK,CAAC,EAEpE,EAAQ,YAAY,GACpB,EAAQ,WAAW,IACZ;AAEX,QAAI,EAAY,EAAK,CACjB,QAAO,EAAS,GAAS,GAAyB,EAAS,EAAK,CAAC;AAErE;;AAGR,SAAO;;CAEX,SAAS,KAAY;EACjB,IAAM,EAAE,gBAAa,WAAQ,aAAU,cAAW;AAUlD,SATA,EAAS,WAAW,GACpB,EAAS,aAAa,GACtB,EAAS,eAAe,GACxB,EAAS,aAAa,GACtB,EAAS,SAAS,GAAe,EACjC,EAAS,WAAW,GAAiB,EACjC,EAAM,aAAa,KAAK,KACjB,EAAS,GAAU,GAAwB,GAE/C,GAAU,GAAO,EAAS;;AAErC,QAAO;EACH;EACA;EACA;EACA;EACH;;AAGL,IAAM,MAAiB,UAEjB,MAAgB,yDAEhB,MAAe;AACrB,SAAS,IAAuB,GAAQ,GAAM;AAC1C,QAAO;;AAEX,SAAS,IAAmB,GAAO,GAAY,GAAY;AACvD,SAAQ,GAAR;EACI,KAAK,OACD,QAAO;EAEX,KAAK,MAED,QAAO;EACX,SAAS;GACL,IAAM,IAAY,SAAS,KAAc,GAAY,GAAG;AAMxD,UALI,KAAa,SAAU,KAAa,QAC7B,OAAO,cAAc,EAAU,GAInC;;;;AAInB,SAAS,IAAa,IAAU,EAAE,EAAE;CAChC,IAAM,IAAW,EAAQ,aAAa,IAChC,EAAE,eAAY;CACpB,SAAS,EAAU,GAAU,GAAM,GAAO,GAAQ,GAAG,GAAM;EACvD,IAAM,IAAM,EAAS,iBAAiB;AAGtC,EAFA,EAAI,UAAU,GACd,EAAI,UAAU,GACV,KAMA,EAJY,GAAmB,GADnB,IAAW,GAAe,GAAO,EAAI,GAAG,MACV;GACtC,QAAQ;GACR;GACH,CAAC,CACU;;CAGpB,SAAS,EAAU,GAAM,GAAQ,GAAK;EAClC,IAAM,IAAO,EAAE,SAAM;AAMrB,SALI,MACA,EAAK,QAAQ,GACb,EAAK,MAAM,GACX,EAAK,MAAM;GAAE,OAAO;GAAK,KAAK;GAAK,GAEhC;;CAEX,SAAS,EAAQ,GAAM,GAAQ,GAAK,GAAM;AACtC,EAAI,MACA,EAAK,MAAM,GACP,EAAK,QACL,EAAK,IAAI,MAAM;;CAI3B,SAAS,EAAU,GAAW,GAAO;EACjC,IAAM,IAAU,EAAU,SAAS,EAC7B,IAAO,EAAU,GAAwB,EAAQ,QAAQ,EAAQ,SAAS;AAGhF,SAFA,EAAK,QAAQ,EAAM,QAAQ,KAAc,IAAuB,EAChE,EAAQ,GAAM,EAAU,eAAe,EAAE,EAAU,iBAAiB,CAAC,EAC9D;;CAEX,SAAS,EAAU,GAAW,GAAO;EAEjC,IAAM,EAAE,YAAY,GAAQ,cAAc,MAD1B,EAAU,SAAS,EAE7B,IAAO,EAAU,GAAwB,GAAQ,EAAI;AAI3D,SAHA,EAAK,QAAQ,SAAS,GAAO,GAAG,EAChC,EAAU,WAAW,EACrB,EAAQ,GAAM,EAAU,eAAe,EAAE,EAAU,iBAAiB,CAAC,EAC9D;;CAEX,SAAS,EAAW,GAAW,GAAK;EAEhC,IAAM,EAAE,YAAY,GAAQ,cAAc,MAD1B,EAAU,SAAS,EAE7B,IAAO,EAAU,GAAyB,GAAQ,EAAI;AAI5D,SAHA,EAAK,MAAM,GACX,EAAU,WAAW,EACrB,EAAQ,GAAM,EAAU,eAAe,EAAE,EAAU,iBAAiB,CAAC,EAC9D;;CAEX,SAAS,EAAa,GAAW,GAAO;EAEpC,IAAM,EAAE,YAAY,GAAQ,cAAc,MAD1B,EAAU,SAAS,EAE7B,IAAO,EAAU,GAA2B,GAAQ,EAAI;AAI9D,SAHA,EAAK,QAAQ,EAAM,QAAQ,KAAe,IAAmB,EAC7D,EAAU,WAAW,EACrB,EAAQ,GAAM,EAAU,eAAe,EAAE,EAAU,iBAAiB,CAAC,EAC9D;;CAEX,SAAS,EAAoB,GAAW;EACpC,IAAM,IAAQ,EAAU,WAAW,EAC7B,IAAU,EAAU,SAAS,EAC7B,EAAE,YAAY,GAAQ,cAAc,MAAQ,GAC5C,IAAO,EAAU,GAAkC,GAAQ,EAAI;AAiBrE,SAhBI,EAAM,SAAS,MAWf,EAAM,SACN,EAAU,GAAW,EAAkB,6BAA6B,EAAQ,cAAc,GAAG,GAAgB,EAAM,CAAC,EAExH,EAAK,QAAQ,EAAM,SAAS,IAC5B,EAAQ,GAAM,EAAU,eAAe,EAAE,EAAU,iBAAiB,CAAC,EAC9D,EACH,SACH,KAhBG,EAAU,GAAW,EAAkB,kCAAkC,EAAQ,cAAc,EAAE,EACjG,EAAK,QAAQ,IACb,EAAQ,GAAM,GAAQ,EAAI,EACnB;GACH,kBAAkB;GAClB;GACH;;CAYT,SAAS,EAAe,GAAW,GAAO;EACtC,IAAM,IAAU,EAAU,SAAS,EAC7B,IAAO,EAAU,GAA6B,EAAQ,QAAQ,EAAQ,SAAS;AAGrF,SAFA,EAAK,QAAQ,GACb,EAAQ,GAAM,EAAU,eAAe,EAAE,EAAU,iBAAiB,CAAC,EAC9D;;CAEX,SAAS,EAAY,GAAW;EAC5B,IAAM,IAAU,EAAU,SAAS,EAC7B,IAAa,EAAU,GAA0B,EAAQ,QAAQ,EAAQ,SAAS,EACpF,IAAQ,EAAU,WAAW;AACjC,MAAI,EAAM,SAAS,GAA8B;GAC7C,IAAM,IAAS,EAAoB,EAAU;AAE7C,GADA,EAAW,WAAW,EAAO,MAC7B,IAAQ,EAAO,oBAAoB,EAAU,WAAW;;AAW5D,UARI,EAAM,SAAS,KACf,EAAU,GAAW,EAAkB,6BAA6B,EAAQ,cAAc,GAAG,GAAgB,EAAM,CAAC,EAExH,IAAQ,EAAU,WAAW,EAEzB,EAAM,SAAS,MACf,IAAQ,EAAU,WAAW,GAEzB,EAAM,MAAd;GACI,KAAK;AAID,IAHI,EAAM,SACN,EAAU,GAAW,EAAkB,6BAA6B,EAAQ,cAAc,GAAG,GAAgB,EAAM,CAAC,EAExH,EAAW,MAAM,EAAe,GAAW,EAAM,SAAS,GAAG;AAC7D;GACJ,KAAK;AAID,IAHI,EAAM,SACN,EAAU,GAAW,EAAkB,6BAA6B,EAAQ,cAAc,GAAG,GAAgB,EAAM,CAAC,EAExH,EAAW,MAAM,EAAW,GAAW,EAAM,SAAS,GAAG;AACzD;GACJ,KAAK;AAID,IAHI,EAAM,SACN,EAAU,GAAW,EAAkB,6BAA6B,EAAQ,cAAc,GAAG,GAAgB,EAAM,CAAC,EAExH,EAAW,MAAM,EAAU,GAAW,EAAM,SAAS,GAAG;AACxD;GACJ,KAAK;AAID,IAHI,EAAM,SACN,EAAU,GAAW,EAAkB,6BAA6B,EAAQ,cAAc,GAAG,GAAgB,EAAM,CAAC,EAExH,EAAW,MAAM,EAAa,GAAW,EAAM,SAAS,GAAG;AAC3D;GACJ,SAAS;AAEL,MAAU,GAAW,EAAkB,6BAA6B,EAAQ,cAAc,EAAE;IAC5F,IAAM,IAAc,EAAU,SAAS,EACjC,IAAqB,EAAU,GAA6B,EAAY,QAAQ,EAAY,SAAS;AAK3G,WAJA,EAAmB,QAAQ,IAC3B,EAAQ,GAAoB,EAAY,QAAQ,EAAY,SAAS,EACrE,EAAW,MAAM,GACjB,EAAQ,GAAY,EAAY,QAAQ,EAAY,SAAS,EACtD;KACH,kBAAkB;KAClB,MAAM;KACT;;;AAIT,SADA,EAAQ,GAAY,EAAU,eAAe,EAAE,EAAU,iBAAiB,CAAC,EACpE,EACH,MAAM,GACT;;CAEL,SAAS,EAAa,GAAW;EAC7B,IAAM,IAAU,EAAU,SAAS,EAO7B,IAAO,EAAU,GANH,EAAQ,gBAAgB,IACtC,EAAU,eAAe,GACzB,EAAQ,QACG,EAAQ,gBAAgB,IACnC,EAAQ,SACR,EAAQ,SAC0D;AACxE,IAAK,QAAQ,EAAE;EACf,IAAI,IAAY;AAChB,KAAG;GACC,IAAM,IAAQ,KAAa,EAAU,WAAW;AAEhD,WADA,IAAY,MACJ,EAAM,MAAd;IACI,KAAK;AAID,KAHI,EAAM,SACN,EAAU,GAAW,EAAkB,6BAA6B,EAAQ,cAAc,GAAG,GAAgB,EAAM,CAAC,EAExH,EAAK,MAAM,KAAK,EAAU,GAAW,EAAM,SAAS,GAAG,CAAC;AACxD;IACJ,KAAK;AAID,KAHI,EAAM,SACN,EAAU,GAAW,EAAkB,6BAA6B,EAAQ,cAAc,GAAG,GAAgB,EAAM,CAAC,EAExH,EAAK,MAAM,KAAK,EAAU,GAAW,EAAM,SAAS,GAAG,CAAC;AACxD;IACJ,KAAK;AAID,KAHI,EAAM,SACN,EAAU,GAAW,EAAkB,6BAA6B,EAAQ,cAAc,GAAG,GAAgB,EAAM,CAAC,EAExH,EAAK,MAAM,KAAK,EAAW,GAAW,EAAM,SAAS,GAAG,CAAC;AACzD;IACJ,KAAK;AAID,KAHI,EAAM,SACN,EAAU,GAAW,EAAkB,6BAA6B,EAAQ,cAAc,GAAG,GAAgB,EAAM,CAAC,EAExH,EAAK,MAAM,KAAK,EAAa,GAAW,EAAM,SAAS,GAAG,CAAC;AAC3D;IACJ,KAAK,GAAgC;KACjC,IAAM,IAAS,EAAY,EAAU;AAErC,KADA,EAAK,MAAM,KAAK,EAAO,KAAK,EAC5B,IAAY,EAAO,oBAAoB;AACvC;;;WAGH,EAAQ,gBAAgB,MAC7B,EAAQ,gBAAgB;AAS5B,SADA,EAAQ,GANU,EAAQ,gBAAgB,IACpC,EAAQ,aACR,EAAU,eAAe,EAChB,EAAQ,gBAAgB,IACjC,EAAQ,aACR,EAAU,iBAAiB,CACD,EACzB;;CAEX,SAAS,EAAY,GAAW,GAAQ,GAAK,GAAS;EAClD,IAAM,IAAU,EAAU,SAAS,EAC/B,IAAkB,EAAQ,MAAM,WAAW,GACzC,IAAO,EAAU,GAA0B,GAAQ,EAAI;AAE7D,EADA,EAAK,QAAQ,EAAE,EACf,EAAK,MAAM,KAAK,EAAQ;AACxB,KAAG;GACC,IAAM,IAAM,EAAa,EAAU;AAInC,GAHA,AACI,MAAkB,EAAI,MAAM,WAAW,GAE3C,EAAK,MAAM,KAAK,EAAI;WACf,EAAQ,gBAAgB;AAKjC,SAJI,KACA,EAAU,GAAW,EAAkB,8BAA8B,GAAK,EAAE,EAEhF,EAAQ,GAAM,EAAU,eAAe,EAAE,EAAU,iBAAiB,CAAC,EAC9D;;CAEX,SAAS,EAAc,GAAW;EAC9B,IAAM,IAAU,EAAU,SAAS,EAC7B,EAAE,WAAQ,gBAAa,GACvB,IAAU,EAAa,EAAU;AAKnC,SAJA,EAAQ,gBAAgB,KACjB,IAGA,EAAY,GAAW,GAAQ,GAAU,EAAQ;;CAGhE,SAAS,EAAM,GAAQ;EACnB,IAAM,IAAY,IAAgB,GAAQ,GAAO,EAAE,EAAE,EAAQ,CAAC,EACxD,IAAU,EAAU,SAAS,EAC7B,IAAO,EAAU,GAA4B,EAAQ,QAAQ,EAAQ,SAAS;AAapF,SAZI,KAAY,EAAK,QACjB,EAAK,IAAI,SAAS,IAEtB,EAAK,OAAO,EAAc,EAAU,EAChC,EAAQ,eACR,EAAK,WAAW,EAAQ,WAAW,EAAO,GAG1C,EAAQ,gBAAgB,MACxB,EAAU,GAAW,EAAkB,6BAA6B,EAAQ,cAAc,GAAG,EAAO,EAAQ,WAAW,GAAG,EAE9H,EAAQ,GAAM,EAAU,eAAe,EAAE,EAAU,iBAAiB,CAAC,EAC9D;;AAEX,QAAO,EAAE,UAAO;;AAEpB,SAAS,GAAgB,GAAO;AAC5B,KAAI,EAAM,SAAS,GACf,QAAO;CAEX,IAAM,KAAQ,EAAM,SAAS,IAAI,QAAQ,WAAW,MAAM;AAC1D,QAAO,EAAK,SAAS,KAAK,EAAK,MAAM,GAAG,EAAE,GAAG,MAAM;;AAGvD,SAAS,IAAkB,GAAK,IAAU,EAAE,EAC1C;CACE,IAAM,IAAW;EACb;EACA,yBAAS,IAAI,KAAK;EACrB;AAMD,QAAO;EAAE,eALa;EAKJ,SAJF,OACZ,EAAS,QAAQ,IAAI,EAAK,EACnB;EAEe;;AAE9B,SAAS,GAAc,GAAO,GAAa;AACvC,MAAK,IAAI,IAAI,GAAG,IAAI,EAAM,QAAQ,IAC9B,IAAa,EAAM,IAAI,EAAY;;AAG3C,SAAS,GAAa,GAAM,GAAa;AAErC,SAAQ,EAAK,MAAb;EACI,KAAK;AAED,GADA,GAAc,EAAK,OAAO,EAAY,EACtC,EAAY,OAAO,SAAoC;AACvD;EACJ,KAAK;AACD,MAAc,EAAK,OAAO,EAAY;AACtC;EACJ,KAAK;AAID,GAFA,GADe,EACK,KAAK,EAAY,EACrC,EAAY,OAAO,SAAoC,EACvD,EAAY,OAAO,OAAgC;AACnD;EAEJ,KAAK;AAED,GADA,EAAY,OAAO,cAA8C,EACjE,EAAY,OAAO,OAAgC;AACnD;EACJ,KAAK;AAED,GADA,EAAY,OAAO,cAA8C,EACjE,EAAY,OAAO,QAAkC;AACrD;;;AAKZ,SAAS,IAAU,GAAK,IAAU,EAAE,EAClC;CACE,IAAM,IAAc,IAAkB,EAAI;AAG1C,CAFA,EAAY,OAAO,YAA0C,EAE7D,EAAI,QAAQ,GAAa,EAAI,MAAM,EAAY;CAE/C,IAAM,IAAU,EAAY,SAAS;AACrC,GAAI,UAAU,MAAM,KAAK,EAAQ,QAAQ;;AAG7C,SAAS,IAAS,GAAK;CACnB,IAAM,IAAO,EAAI;AAOjB,QANI,EAAK,SAAS,IACd,GAAoB,EAAK,GAGzB,EAAK,MAAM,SAAQ,MAAK,GAAoB,EAAE,CAAC,EAE5C;;AAEX,SAAS,GAAoB,GAAS;AAClC,KAAI,EAAQ,MAAM,WAAW,GAAG;EAC5B,IAAM,IAAO,EAAQ,MAAM;AAC3B,GAAI,EAAK,SAAS,KAA0B,EAAK,SAAS,OACtD,EAAQ,SAAS,EAAK,OACtB,OAAO,EAAK;QAGf;EACD,IAAM,IAAS,EAAE;AACjB,OAAK,IAAI,IAAI,GAAG,IAAI,EAAQ,MAAM,QAAQ,KAAK;GAC3C,IAAM,IAAO,EAAQ,MAAM;AAI3B,OAHI,EAAE,EAAK,SAAS,KAA0B,EAAK,SAAS,MAGxD,EAAK,SAAS,KACd;AAEJ,KAAO,KAAK,EAAK,MAAM;;AAE3B,MAAI,EAAO,WAAW,EAAQ,MAAM,QAAQ;AACxC,KAAQ,SAAS,GAAK,EAAO;AAC7B,QAAK,IAAI,IAAI,GAAG,IAAI,EAAQ,MAAM,QAAQ,KAAK;IAC3C,IAAM,IAAO,EAAQ,MAAM;AAC3B,KAAI,EAAK,SAAS,KAA0B,EAAK,SAAS,MACtD,OAAO,EAAK;;;;;AAOhC,IAAM,MAAiB;AAEvB,SAAS,GAAO,GAAM;AAElB,SADA,EAAK,IAAI,EAAK,MACN,EAAK,MAAb;EACI,KAAK,GAA4B;GAC7B,IAAM,IAAW;AAGjB,GAFA,GAAO,EAAS,KAAK,EACrB,EAAS,IAAI,EAAS,MACtB,OAAO,EAAS;AAChB;;EAEJ,KAAK,GAA0B;GAC3B,IAAM,IAAS,GACT,IAAQ,EAAO;AACrB,QAAK,IAAI,IAAI,GAAG,IAAI,EAAM,QAAQ,IAC9B,IAAO,EAAM,GAAG;AAGpB,GADA,EAAO,IAAI,GACX,OAAO,EAAO;AACd;;EAEJ,KAAK,GAA2B;GAC5B,IAAM,IAAU,GACV,IAAQ,EAAQ;AACtB,QAAK,IAAI,IAAI,GAAG,IAAI,EAAM,QAAQ,IAC9B,IAAO,EAAM,GAAG;AAIpB,GAFA,EAAQ,IAAI,GACZ,OAAO,EAAQ,OACX,EAAQ,WACR,EAAQ,IAAI,EAAQ,QACpB,OAAO,EAAQ;AAEnB;;EAEJ,KAAK;EACL,KAAK;EACL,KAAK;EACL,KAAK,GAA6B;GAC9B,IAAM,IAAY;AAClB,GAAI,EAAU,UACV,EAAU,IAAI,EAAU,OACxB,OAAO,EAAU;AAErB;;EAEJ,KAAK,GAA0B;GAC3B,IAAM,IAAS;AAIf,GAHA,GAAO,EAAO,IAAI,EAClB,EAAO,IAAI,EAAO,KAClB,OAAO,EAAO,KACV,EAAO,aACP,GAAO,EAAO,SAAS,EACvB,EAAO,IAAI,EAAO,UAClB,OAAO,EAAO;AAElB;;EAEJ,KAAK,GAAwB;GACzB,IAAM,IAAO;AAEb,GADA,EAAK,IAAI,EAAK,OACd,OAAO,EAAK;AACZ;;EAEJ,KAAK,GAAyB;GAC1B,IAAM,IAAQ;AAEd,GADA,EAAM,IAAI,EAAM,KAChB,OAAO,EAAM;AACb;;EAEJ,QACI,KAAA,QAAA,IAAA,aAA8B,aAC1B,OAAM,GAAmB,EAAkB,8BAA8B,MAAM;GAC3E,QAAQ;GACR,MAAM,CAAC,EAAK,KAAK;GACpB,CAAC;;AAGd,QAAO,EAAK;;AAMhB,IAAM,MAAe;AACrB,SAAS,IAAoB,GAAK,GAAS;CACvC,IAAM,EAAE,cAAW,aAAU,kBAAe,YAAY,MAAgB,GAClE,IAAW,EAAQ,aAAa,IAChC,IAAW;EACb;EACA,MAAM;EACN,QAAQ;EACR,MAAM;EACN,QAAQ;EACR,KAAK,KAAA;EACL;EACA,YAAY;EACZ,aAAa;EAChB;AACD,CAAI,KAAY,EAAI,QAChB,EAAS,SAAS,EAAI,IAAI;CAE9B,IAAM,UAAgB;CACtB,SAAS,EAAK,GAAM,GAAM;AACtB,IAAS,QAAQ;;CAErB,SAAS,EAAS,GAAG,IAAgB,IAAM;EACvC,IAAM,IAAiB,IAAgB,IAAgB;AACvD,IAAK,IAAc,IAAiB,KAAK,OAAO,EAAE,GAAG,EAAe;;CAExE,SAAS,EAAO,IAAc,IAAM;EAChC,IAAM,IAAQ,EAAE,EAAS;AACzB,OAAe,EAAS,EAAM;;CAElC,SAAS,EAAS,IAAc,IAAM;EAClC,IAAM,IAAQ,EAAE,EAAS;AACzB,OAAe,EAAS,EAAM;;CAElC,SAAS,IAAU;AACf,IAAS,EAAS,YAAY;;AAIlC,QAAO;EACH;EACA;EACA;EACA;EACA;EACA,SARY,MAAQ,IAAI;EASxB,kBARqB,EAAS;EASjC;;AAEL,SAAS,IAAmB,GAAW,GAAM;CACzC,IAAM,EAAE,cAAW;AAWnB,CAVA,EAAU,KAAK,GAAG,EAAO,SAAoC,CAAC,GAAG,EACjE,GAAa,GAAW,EAAK,IAAI,EAC7B,EAAK,YACL,EAAU,KAAK,KAAK,EACpB,GAAa,GAAW,EAAK,SAAS,EACtC,EAAU,KAAK,UAAU,IAGzB,EAAU,KAAK,qBAAqB,EAExC,EAAU,KAAK,IAAI;;AAEvB,SAAS,IAAoB,GAAW,GAAM;CAC1C,IAAM,EAAE,WAAQ,kBAAe;AAE/B,CADA,EAAU,KAAK,GAAG,EAAO,YAA0C,CAAC,IAAI,EACxE,EAAU,OAAO,GAAY,CAAC;CAC9B,IAAM,IAAS,EAAK,MAAM;AAC1B,MAAK,IAAI,IAAI,GAAG,IAAI,MAChB,GAAa,GAAW,EAAK,MAAM,GAAG,EAClC,MAAM,IAAS,IAFK,IAKxB,GAAU,KAAK,KAAK;AAGxB,CADA,EAAU,SAAS,GAAY,CAAC,EAChC,EAAU,KAAK,KAAK;;AAExB,SAAS,IAAmB,GAAW,GAAM;CACzC,IAAM,EAAE,WAAQ,kBAAe;AAC/B,KAAI,EAAK,MAAM,SAAS,GAAG;AAEvB,EADA,EAAU,KAAK,GAAG,EAAO,SAAoC,CAAC,IAAI,EAClE,EAAU,OAAO,GAAY,CAAC;EAC9B,IAAM,IAAS,EAAK,MAAM;AAC1B,OAAK,IAAI,IAAI,GAAG,IAAI,MAChB,GAAa,GAAW,EAAK,MAAM,GAAG,EAClC,MAAM,IAAS,IAFK,IAKxB,GAAU,KAAK,KAAK;AAGxB,EADA,EAAU,SAAS,GAAY,CAAC,EAChC,EAAU,KAAK,KAAK;;;AAG5B,SAAS,IAAiB,GAAW,GAAM;AACvC,CAAI,EAAK,OACL,GAAa,GAAW,EAAK,KAAK,GAGlC,EAAU,KAAK,OAAO;;AAG9B,SAAS,GAAa,GAAW,GAAM;CACnC,IAAM,EAAE,cAAW;AACnB,SAAQ,EAAK,MAAb;EACI,KAAK;AACD,OAAiB,GAAW,EAAK;AACjC;EACJ,KAAK;AACD,OAAmB,GAAW,EAAK;AACnC;EACJ,KAAK;AACD,OAAoB,GAAW,EAAK;AACpC;EACJ,KAAK;AACD,OAAmB,GAAW,EAAK;AACnC;EACJ,KAAK;AACD,KAAU,KAAK,KAAK,UAAU,EAAK,MAAM,EAAE,EAAK;AAChD;EACJ,KAAK;AACD,KAAU,KAAK,KAAK,UAAU,EAAK,MAAM,EAAE,EAAK;AAChD;EACJ,KAAK;AACD,KAAU,KAAK,GAAG,EAAO,cAA8C,CAAC,GAAG,EAAO,OAAgC,CAAC,GAAG,EAAK,MAAM,KAAK,EAAK;AAC3I;EACJ,KAAK;AACD,KAAU,KAAK,GAAG,EAAO,cAA8C,CAAC,GAAG,EAAO,QAAkC,CAAC,GAAG,KAAK,UAAU,EAAK,IAAI,CAAC,KAAK,EAAK;AAC3J;EACJ,KAAK;AACD,KAAU,KAAK,KAAK,UAAU,EAAK,MAAM,EAAE,EAAK;AAChD;EACJ,KAAK;AACD,KAAU,KAAK,KAAK,UAAU,EAAK,MAAM,EAAE,EAAK;AAChD;EACJ,QACI,KAAA,QAAA,IAAA,aAA8B,aAC1B,OAAM,GAAmB,EAAkB,6BAA6B,MAAM;GAC1E,QAAQ;GACR,MAAM,CAAC,EAAK,KAAK;GACpB,CAAC;;;AAKlB,IAAM,OAAY,GAAK,IAAU,EAAE,KAAK;CACpC,IAAM,IAAO,EAAS,EAAQ,KAAK,GAAG,EAAQ,OAAO,UAC/C,IAAW,EAAS,EAAQ,SAAS,GACrC,EAAQ,WACR,gBACA,IAAY,CAAC,CAAC,EAAQ,WAEtB,IAAgB,EAAQ,iBAAiB,OAEzC,MAAS,UACL,MACA,OAHJ,EAAQ,eAIR,IAAa,EAAQ,aAAa,EAAQ,aAAa,MAAS,SAChE,IAAU,EAAI,WAAW,EAAE,EAC3B,IAAY,IAAoB,GAAK;EACvC;EACA;EACA;EACA;EACA;EACH,CAAC;AAWF,CAVA,EAAU,KAAK,MAAS,WAAW,6BAA6B,aAAa,EAC7E,EAAU,OAAO,EAAW,EACxB,EAAQ,SAAS,MACjB,EAAU,KAAK,WAAW,GAAK,EAAQ,KAAI,MAAK,GAAG,EAAE,KAAK,IAAI,EAAE,KAAK,CAAC,UAAU,EAChF,EAAU,SAAS,GAEvB,EAAU,KAAK,UAAU,EACzB,GAAa,GAAW,EAAI,EAC5B,EAAU,SAAS,EAAW,EAC9B,EAAU,KAAK,IAAI,EACnB,OAAO,EAAI;CACX,IAAM,EAAE,SAAM,WAAQ,EAAU,SAAS;AACzC,QAAO;EACH;EACA;EACA,KAAK,IAAM,EAAI,QAAQ,GAAG,KAAA;EAC7B;;AAGL,SAASE,IAAY,GAAQ,IAAU,EAAE,EAAE;CACvC,IAAM,IAAkB,GAAO,EAAE,EAAE,EAAQ,EACrC,IAAM,CAAC,CAAC,EAAgB,KACxB,IAAe,CAAC,CAAC,EAAgB,QACjC,IAAiB,EAAgB,YAAY,OAAO,KAAO,EAAgB,UAG3E,IADS,IAAa,EAAgB,CACzB,MAAM,EAAO;AAK5B,QAJC,KAQD,KAAkB,IAAS,EAAI,EAE/B,KAAgB,GAAO,EAAI,EAEpB;EAAE;EAAK,MAAM;EAAI,KAVxB,IAAU,GAAK,EAAgB,EAExB,IAAS,GAAK,EAAgB;;;;ACt/C7C,SAASC,MAAmB;AAIxB,CAHI,OAAO,6BAA8B,cACrC,IAAe,CAAC,4BAA4B,KAE5C,OAAO,qCAAsC,cAC7C,IAAe,CAAC,oCAAoC;;AAI5D,SAAS,GAAa,GAAK;AACvB,QAAQ,EAAS,EAAI,IACjB,GAAY,EAAI,KAAK,MACpB,GAAO,GAAK,IAAI,IAAI,GAAO,GAAK,OAAO;;AAEhD,IAAM,KAAa,CAAC,KAAK,OAAO;AAChC,SAAS,IAAY,GAAM;AACvB,QAAO,GAAa,GAAM,GAAW;;AAEzC,IAAM,KAAc,CAAC,KAAK,QAAQ;AAClC,SAAS,IAAa,GAAM;AACxB,QAAO,GAAa,GAAM,IAAa,EAAE,CAAC;;AAE9C,IAAM,KAAe,CAAC,KAAK,SAAS;AACpC,SAAS,IAAc,GAAM;AACzB,QAAO,GAAa,GAAM,GAAa;;AAE3C,IAAM,KAAc,CAAC,KAAK,QAAQ;AAClC,SAAS,IAAa,GAAM;AACxB,QAAO,GAAa,GAAM,IAAa,EAAE,CAAC;;AAE9C,IAAM,KAAa,CAAC,KAAK,OAAO;AAChC,SAAS,GAAY,GAAM;AACvB,QAAO,GAAa,GAAM,GAAW;;AAEzC,IAAM,KAAc,CAAC,KAAK,QAAQ;AAClC,SAAS,GAAe,GAAM,GAAM;CAChC,IAAM,IAAW,GAAa,GAAM,GAAY;AAChD,KAAI,KAAY,KACZ,QAAO;AAGP,OAAM,GAAwB,EAAK;;AAG3C,IAAM,KAAiB,CAAC,KAAK,WAAW;AACxC,SAAS,IAAsB,GAAM;AACjC,QAAO,GAAa,GAAM,GAAe;;AAE7C,IAAM,KAAY,CAAC,KAAK,MAAM;AAC9B,SAAS,IAAiB,GAAM;CAC5B,IAAM,IAAW,GAAa,GAAM,GAAU;AAC9C,KAAI,EACA,QAAO;AAGP,OAAM,GAAwB,EAAyB;;AAG/D,SAAS,GAAa,GAAM,GAAO,GAAc;AAC7C,MAAK,IAAI,IAAI,GAAG,IAAI,EAAM,QAAQ,KAAK;EACnC,IAAM,IAAO,EAAM;AAEnB,MAAI,GAAO,GAAM,EAAK,IAAI,EAAK,MAAS,KAEpC,QAAO,EAAK;;AAGpB,QAAO;;AAEX,IAAM,KAAsB;CACxB,GAAG;CACH,GAAG;CACH,GAAG;CACH,GAAG;CACH,GAAG;CACH,GAAG;CACH,GAAG;CACH,GAAG;CACN;AACD,SAAS,GAAwB,GAAM;AACnC,QAAO,gBAAI,MAAM,wBAAwB,IAAO;;AAGpD,SAAS,GAAO,GAAK;AAEjB,SADa,MAAQ,IAAY,GAAK,EAAI;;AAG9C,SAAS,IAAY,GAAK,GAAK;CAC3B,IAAM,IAAO,IAAY,EAAI;AAC7B,KAAI,KAAQ,KACR,OAAM,GAAwB,EAA2B;AAG7D,KADa,GAAY,EAAK,KACjB,GAA0B;EAEnC,IAAM,IAAQ,IADC,EACmB;AAClC,SAAO,EAAI,OAAO,EAAM,QAAQ,GAAU,MAAM,CAC5C,GAAG,GACH,GAAmB,GAAK,EAAE,CAC7B,EAAE,EAAE,CAAC,CAAC;OAGP,QAAO,GAAmB,GAAK,EAAK;;AAG5C,SAAS,GAAmB,GAAK,GAAM;CACnC,IAAM,IAAU,IAAc,EAAK;AACnC,KAAI,KAAW,KACX,QAAO,EAAI,SAAS,SACd,IACA,EAAI,UAAU,CAAC,EAAQ,CAAC;CAE7B;EACD,IAAM,IAAW,IAAa,EAAK,CAAC,QAAQ,GAAK,MAAM,CAAC,GAAG,GAAK,GAAkB,GAAK,EAAE,CAAC,EAAE,EAAE,CAAC;AAC/F,SAAO,EAAI,UAAU,EAAS;;;AAGtC,SAAS,GAAkB,GAAK,GAAM;CAClC,IAAM,IAAO,GAAY,EAAK;AAC9B,SAAQ,GAAR;EACI,KAAK,EACD,QAAO,GAAe,GAAM,EAAK;EAErC,KAAK,EACD,QAAO,GAAe,GAAM,EAAK;EAErC,KAAK,GAAyB;GAC1B,IAAM,IAAQ;AACd,OAAI,GAAO,GAAO,IAAI,IAAI,EAAM,EAC5B,QAAO,EAAI,YAAY,EAAI,MAAM,EAAM,EAAE,CAAC;AAE9C,OAAI,GAAO,GAAO,MAAM,IAAI,EAAM,IAC9B,QAAO,EAAI,YAAY,EAAI,MAAM,EAAM,IAAI,CAAC;AAEhD,SAAM,GAAwB,EAAK;;EAEvC,KAAK,GAAwB;GACzB,IAAM,IAAO;AACb,OAAI,GAAO,GAAM,IAAI,IAAI,EAAS,EAAK,EAAE,CACrC,QAAO,EAAI,YAAY,EAAI,KAAK,EAAK,EAAE,CAAC;AAE5C,OAAI,GAAO,GAAM,QAAQ,IAAI,EAAS,EAAK,MAAM,CAC7C,QAAO,EAAI,YAAY,EAAI,KAAK,EAAK,MAAM,CAAC;AAEhD,SAAM,GAAwB,EAAK;;EAEvC,KAAK,GAA0B;GAC3B,IAAM,IAAS,GACT,IAAW,IAAsB,EAAO,EACxC,IAAM,IAAiB,EAAO;AACpC,UAAO,EAAI,OAAO,GAAkB,GAAK,EAAI,EAAE,IAAW,GAAkB,GAAK,EAAS,GAAG,KAAA,GAAW,EAAI,KAAK;;EAErH,KAAK,EACD,QAAO,GAAe,GAAM,EAAK;EAErC,KAAK,EACD,QAAO,GAAe,GAAM,EAAK;EAErC,QACI,OAAU,MAAM,0CAA0C,IAAO;;;AAI7E,IAAM,MAAe;AACrB,SAAS,IAAiB,GAAQ,GAAiB;AAC/C,CAAI,KAAmB,IAAc,EAAO,IACxC,GAAK,GAAS,KAAc,EAAE,WAAQ,CAAC,CAAC;;AAGhD,IAAM,OAAqB,MAAY,GACnC,KAAe,GAAQ;AAI3B,SAAS,IAAY,GAAS,IAAU,EAAE,EAAE;CAExC,IAAI,IAAc,IACZ,IAAU,EAAQ,WAAW;AAMnC,QALA,EAAQ,WAAW,MAAQ;AAEvB,EADA,IAAc,IACd,EAAQ,EAAI;IAGT;EAAE,GAAG,IAAc,GAAS,EAAQ;EAAE;EAAa;;;AAG9D,SAAS,IAAQ,GAAS,GAAS;AAC/B,KAAK,CAAC,qCACF,EAAS,EAAQ,EAAE;EAEnB,IAAM,IAAkB,EAAU,EAAQ,gBAAgB,GACpD,EAAQ,kBACR;AACN,UAAA,IAAA,aAA0B,gBAAiB,IAAiB,GAAS,EAAgB;EAGrF,IAAM,KADa,EAAQ,cAAc,KACb,EAAQ,EAC9B,IAAS,GAAa;AAC5B,MAAI,EACA,QAAO;EAGX,IAAM,EAAE,QAAK,mBAAgB,IAAY,GAAS;GAC9C,GAAG;GACH,UAAA,QAAA,IAAA,aAAoC;GACpC,KAAK;GACR,CAAC,EAEI,IAAM,GAAO,EAAI;AAEvB,SAAQ,IAEF,IADC,GAAa,KAAY;QAG/B;AACD,MAAA,QAAA,IAAA,aAA8B,gBAAiB,CAAC,GAAa,EAAQ,CAEjE,QADA,GAAK,yCAAyC,EAAQ,IAAI,wCAAwC,SACpF;EAGlB,IAAM,IAAW,EAAQ;AAWrB,SAVA,IACe,GAAa,OAKpB,GAAa,KACjB,GAAO,EAAQ,IAGZ,GAAO,EAAQ;;;AAKlC,IAAI,KAAW;AACf,SAAS,IAAgB,GAAM;AAC3B,MAAW;;AAKf,SAAS,IAAiB,GAAM,GAAS,GAAM;AAE3C,OACI,GAAS,KAAK,aAAa;EACvB,WAAW,KAAK,KAAK;EACrB;EACA;EACA;EACH,CAAC;;AAEV,IAAM,MACS,oBAAmB,qBAAqB;AACvD,SAAS,IAAmB,GAAM;AAC9B,SAAQ,MAAa,MAAY,GAAS,KAAK,GAAM,EAAS;;AAGlE,IAAM,KAAiB;CACnB,kBAAA;CACA,uBAAuB;CACvB,2BAA2B;CAC3B,gCAAgC;CAChC,kCAAkC;CAClC,mCAAmC;CACnC,yBAAyB;CAC5B;AAED,SAAS,GAAgB,GAAM;AAC3B,QAAO,GAAmB,GAAM,MAAA,QAAA,IAAA,aAAgC,eAA8C,KAAA,IAA9B,EAAE,UAAUC,KAAe,CAAa;;AAG5H,IAAMA,MAAgB;EACjB,GAAe,mBAAmB;EAClC,GAAe,wBAAwB;EAEvC,GAAe,4BAA4B;EAC3C,GAAe,iCAAiC;EAChD,GAAe,mCAAmC;EAClD,GAAe,oCAAoC;EACnD,GAAe,0BAA0B;CAC7C;AAGD,SAAS,GAAU,GAAS,GAAS;AACjC,QAAO,EAAQ,UAAU,OAEnB,GAAc,EAAQ,OAAO,GAD7B,GAAc,EAAQ,OAAO;;AAGvC,IAAI;AAEJ,SAAS,GAAc,GAAQ;AAC3B,KAAI,EAAS,EAAO,CAChB,QAAO;KAGH,EAAW,EAAO,EAClB;MAAI,EAAO,gBAAgB,MAAkB,KACzC,QAAO;MAEF,EAAO,YAAY,SAAS,YAAY;GAC7C,IAAM,IAAU,GAAQ;AACxB,OAAI,IAAU,EAAQ,CAClB,OAAM,GAAgB,GAAe,iCAAiC;AAE1E,UAAQ,KAAiB;QAGzB,OAAM,GAAgB,GAAe,kCAAkC;OAI3E,OAAM,GAAgB,GAAe,wBAAwB;;AAoBzE,SAAS,IAAmB,GAAK,GAAU,GAAO;AAE9C,QAAO,CAAC,GAAG,IAAI,IAAI,CACX,GACA,GAAI,EAAQ,EAAS,GACf,IACA,EAAS,EAAS,GACd,OAAO,KAAK,EAAS,GACrB,EAAS,EAAS,GACd,CAAC,EAAS,GACV,CAAC,EAAM,CACxB,CAAC,CAAC;;AAkBX,SAAS,GAAwB,GAAK,GAAU,GAAO;CACnD,IAAM,IAAc,EAAS,EAAM,GAAG,IAAQ,IACxC,IAAU;AAChB,CACI,EAAQ,uCAAqB,IAAI,KAAK;CAE1C,IAAI,IAAQ,EAAQ,mBAAmB,IAAI,EAAY;AACvD,KAAI,CAAC,GAAO;AACR,MAAQ,EAAE;EAEV,IAAI,IAAQ,CAAC,EAAM;AAEnB,SAAO,EAAQ,EAAM,EACjB,KAAQ,GAAmB,GAAO,GAAO,EAAS;EAItD,IAAM,IAAW,EAAQ,EAAS,IAAI,CAAC,EAAc,EAAS,GACxD,IACA,EAAS,UACL,EAAS,UACT;AAMV,EAJA,IAAQ,EAAS,EAAS,GAAG,CAAC,EAAS,GAAG,GACtC,EAAQ,EAAM,IACd,GAAmB,GAAO,GAAO,GAAM,EAE3C,EAAQ,mBAAmB,IAAI,GAAa,EAAM;;AAEtD,QAAO;;AAEX,SAAS,GAAmB,GAAO,GAAO,GAAQ;CAC9C,IAAI,IAAS;AACb,MAAK,IAAI,IAAI,GAAG,IAAI,EAAM,UAAU,EAAU,EAAO,EAAE,KAAK;EACxD,IAAM,IAAS,EAAM;AACrB,EAAI,EAAS,EAAO,KAChB,IAAS,IAAoB,GAAO,EAAM,IAAI,EAAO;;AAG7D,QAAO;;AAEX,SAAS,IAAoB,GAAO,GAAQ,GAAQ;CAChD,IAAI,GACE,IAAS,EAAO,MAAM,IAAI;AAChC;AAGI,EADA,IAAS,IAAkB,GADZ,EAAO,KAAK,IAAI,EACW,EAAO,EACjD,EAAO,OAAO,IAAI,EAAE;QACf,EAAO,UAAU,MAAW;AACrC,QAAO;;AAEX,SAAS,IAAkB,GAAO,GAAQ,GAAQ;CAC9C,IAAI,IAAS;AACb,KAAI,CAAC,EAAM,SAAS,EAAO,KACvB,IAAS,IACL,IAAQ;AACR,MAAS,EAAO,EAAO,SAAS,OAAO;EACvC,IAAM,IAAS,EAAO,QAAQ,MAAM,GAAG;AAEvC,EADA,EAAM,KAAK,EAAO,GACb,EAAQ,EAAO,IAAI,EAAc,EAAO,KACzC,EAAO,OAGP,IAAS,EAAO;;AAI5B,QAAO;;AAGX,IAAM,KAAmB,EAAE;AAC3B,GAAiB,KAA8B;CAC1C,GAAoC,CAAC,EAA2B;CAChE,GAAgC,CAAC,GAAyB,EAAuB;CACjF,KAAuC,CAAC,EAA2B;CACnE,GAAsC,CAAC,EAA0B;CACrE,EACD,GAAiB,KAA0B;CACtC,GAAoC,CAAC,EAAuB;CAC5D,KAA8B,CAAC,EAA4B;CAC3D,KAAuC,CAAC,EAA2B;CACnE,GAAsC,CAAC,EAA0B;CACrE,EACD,GAAiB,KAA+B;CAC3C,GAAoC,CAAC,EAA4B;CACjE,GAAgC,CAAC,GAAyB,EAAuB;CACjF,GAA+B,CAAC,GAAyB,EAAuB;CACpF,EACD,GAAiB,KAA2B;CACvC,GAAgC,CAAC,GAAyB,EAAuB;CACjF,GAA+B,CAAC,GAAyB,EAAuB;CAChF,GAAoC,CAAC,GAAwB,EAAqB;CAClF,KAA8B,CAAC,GAA6B,EAAqB;CACjF,KAAuC,CAAC,GAA4B,EAAqB;CACzF,GAAsC,CAAC,GAA2B,EAAqB;CAC3F,EACD,GAAiB,KAA8B;CAC1C,KAAuC,CAAC,GAAgC,EAAuB;CAC/F,MAAwC,CAAC,GAAgC,EAAuB;CAChG,KAAuC,CACpC,GACA,EACH;CACA,KAAwC,CAAC,GAAwB,EAA8B;CAC/F,GAAsC;CACtC,GAA+B,CAAC,GAA4B,EAAuB;CACvF,EACD,GAAiB,KAAkC;CAC9C,KAAuC,CAAC,GAA4B,EAAuB;CAC3F,GAAsC;CACtC,GAA+B,CAAC,GAAgC,EAAuB;CAC3F,EACD,GAAiB,KAAkC;CAC9C,MAAwC,CAAC,GAA4B,EAAuB;CAC5F,GAAsC;CACtC,GAA+B,CAAC,GAAgC,EAAuB;CAC3F;AAID,IAAM,MAAiB;AACvB,SAAS,IAAU,GAAK;AACpB,QAAO,IAAe,KAAK,EAAI;;AAKnC,SAAS,IAAY,GAAK;CACtB,IAAM,IAAI,EAAI,WAAW,EAAE;AAE3B,QAAO,MADG,EAAI,WAAW,EAAI,SAAS,EAAE,KACrB,MAAM,MAAQ,MAAM,MAAQ,EAAI,MAAM,GAAG,GAAG,GAAG;;AAKtE,SAAS,IAAgB,GAAI;AACzB,KAAI,KAA2B,KAC3B,QAAO;AAGX,SADa,EAAG,WAAW,EAAE,EAC7B;EACI,KAAK;EACL,KAAK;EACL,KAAK;EACL,KAAK;EACL,KAAK,GACD,QAAO;EACX,KAAK;EACL,KAAK;EACL,KAAK,GACD,QAAO;EACX,KAAK;EACL,KAAK;EACL,KAAK;EACL,KAAK;EACL,KAAK;EACL,KAAK;EACL,KAAK,KACD,QAAO;;AAEf,QAAO;;AAOX,SAAS,IAAc,GAAM;CACzB,IAAM,IAAU,EAAK,MAAM;AAK3B,QAHI,EAAK,OAAO,EAAE,KAAK,OAAO,MAAM,SAAS,EAAK,CAAC,GACxC,KAEJ,IAAU,EAAQ,GACnB,IAAY,EAAQ,GACpB,MAAmC;;AAK7C,SAAS,IAAM,GAAM;CACjB,IAAM,IAAO,EAAE,EACX,IAAQ,IACR,IAAO,GACP,IAAe,GACf,GACA,GACA,GACA,GACA,GACA,GACA,GACE,IAAU,EAAE;AAmBlB,CAlBA,EAAQ,WAAgC;AACpC,EAAI,MAAQ,KAAA,IACR,IAAM,IAGN,KAAO;IAGf,EAAQ,WAA8B;AAClC,EAAI,MAAQ,KAAA,MACR,EAAK,KAAK,EAAI,EACd,IAAM,KAAA;IAGd,EAAQ,WAA4C;AAEhD,EADA,EAAQ,IAAyB,EACjC;IAEJ,EAAQ,WAAuC;AAC3C,MAAI,IAAe,EAGf,CAFA,KACA,IAAO,GACP,EAAQ,IAAyB;OAEhC;AAMD,OALA,IAAe,GACX,MAAQ,KAAA,MAGZ,IAAM,IAAc,EAAI,EACpB,MAAQ,IACR,QAAO;AAGP,KAAQ,IAAuB;;;CAI3C,SAAS,IAAqB;EAC1B,IAAM,IAAW,EAAK,IAAQ;AAC9B,MAAK,MAAS,KACV,MAAa,OACZ,MAAS,KACN,MAAa,KAIjB,QAHA,KACA,IAAU,OAAO,GACjB,EAAQ,IAAyB,EAC1B;;AAGf,QAAO,MAAS,MACZ,UACA,IAAI,EAAK,IACL,QAAM,QAAQ,GAAoB,GAWtC;MARA,IAAO,IAAgB,EAAE,EACzB,IAAU,GAAiB,IAC3B,IAAa,EAAQ,MAAS,EAAQ,KAAiC,GAEnE,MAAe,MAGnB,IAAO,EAAW,IACd,EAAW,OAAO,KAAA,MAClB,IAAS,EAAQ,EAAW,KACxB,MACA,IAAU,GACN,GAAQ,KAAK,MACb;AAKZ,MAAI,MAAS,EACT,QAAO;;;AAKnB,IAAM,qBAAQ,IAAI,KAAK;AAcvB,SAAS,IAAoB,GAAK,GAAM;AACpC,QAAO,EAAS,EAAI,GAAG,EAAI,KAAQ;;AAevC,SAAS,IAAa,GAAK,GAAM;AAE7B,KAAI,CAAC,EAAS,EAAI,CACd,QAAO;CAGX,IAAI,IAAM,GAAM,IAAI,EAAK;AAQzB,KAPK,MACD,IAAM,IAAM,EAAK,EACb,KACA,GAAM,IAAI,GAAM,EAAI,GAIxB,CAAC,EACD,QAAO;CAGX,IAAM,IAAM,EAAI,QAEZ,IAAO,GACP,IAAI;AACR,QAAO,IAAI,IAAK;EACZ,IAAM,IAAM,EAAI;AAYhB,MANI,GAAoB,SAAS,EAAI,IAAI,GAAa,EAAK,IAGvD,CAAC,EAAS,EAAK,IAGf,CAAC,GAAO,GAAM,EAAI,CAClB,QAAO;EAEX,IAAM,IAAM,EAAK;AAIjB,MAHI,MAAQ,KAAA,KAGR,EAAW,EAAK,CAChB,QAAO;AAGX,EADA,IAAO,GACP;;AAEJ,QAAO;;AAGX,IAAM,IAAgB;CAClB,eAAe;CACf,uBAAuB;CACvB,sBAAsB;CACtB,2BAA2B;CAC3B,oBAAoB;CACpB,yBAAyB;CACzB,sCAAsC;CACtC,yBAAyB;CACzB,uBAAuB;CAC1B,EAGKC,MAAe;EAChB,EAAc,gBAAgB;EAC9B,EAAc,wBAAwB;EACtC,EAAc,uBAAuB;EACrC,EAAc,4BAA4B;EAC1C,EAAc,qBAAqB;EACnC,EAAc,0BAA0B;EACxC,EAAc,uCAAuC;EACrD,EAAc,0BAA0B;EACxC,EAAc,wBAAwB;CAC1C;AACD,SAASC,GAAe,GAAM,GAAG,GAAM;AACnC,QAAO,GAASD,IAAa,IAAO,GAAG,EAAK;;AAQhD,IAAME,MAAU,UAEV,KAAiB,SAEjB,MAAc,MAAQ,GAAG,EAAI,OAAO,EAAE,CAAC,mBAAmB,GAAG,EAAI,OAAO,EAAE;AAChF,SAAS,MAA4B;AACjC,QAAO;EACH,QAAQ,GAAK,MAEF,MAAS,UAAU,EAAS,EAAI,GACjC,EAAI,aAAa,GACjB,MAAS,WAAW,EAAS,EAAI,IAAI,iBAAiB,IAClD,EAAI,SAAS,aAAa,GAC1B;EAEd,QAAQ,GAAK,MAEF,MAAS,UAAU,EAAS,EAAI,GACjC,EAAI,aAAa,GACjB,MAAS,WAAW,EAAS,EAAI,IAAI,iBAAiB,IAClD,EAAI,SAAS,aAAa,GAC1B;EAEd,aAAa,GAAK,MAEN,MAAS,UAAU,EAAS,EAAI,GAClC,GAAW,EAAI,GACf,MAAS,WAAW,EAAS,EAAI,IAAI,iBAAiB,IAClD,GAAW,EAAI,SAAS,GACxB;EAEjB;;AAEL,IAAI;AACJ,SAAS,IAAwB,GAAU;AACvC,MAAY;;AAEhB,IAAI;AAQJ,SAAS,IAAwB,GAAU;AACvC,MAAY;;AAEhB,IAAI;AAQJ,SAAS,IAAyB,GAAY;AAC1C,MAAc;;AAGlB,IAAI,MAAkB,MAMhB,uCAA0B,KAC5B,KAAmB,MACjB,MAAsB,MAAY;AACpC,MAAmB;GAEjB,YAA2B,IAE7B,KAAO;AACX,SAAS,IAAkB,IAAU,EAAE,EAAE;CAErC,IAAM,IAAS,EAAW,EAAQ,OAAO,GAAG,EAAQ,SAAS,IACvD,IAAU,EAAS,EAAQ,QAAQ,GAAG,EAAQ,UAAUA,KACxD,IAAS,EAAS,EAAQ,OAAO,IAAI,EAAW,EAAQ,OAAO,GAC/D,EAAQ,SACR,IACA,IAAU,EAAW,EAAO,GAAG,KAAiB,GAChD,IAAiB,EAAQ,EAAQ,eAAe,IAClD,EAAc,EAAQ,eAAe,IACrC,EAAS,EAAQ,eAAe,IAChC,EAAQ,mBAAmB,KACzB,EAAQ,iBACR,GACA,IAAW,EAAc,EAAQ,SAAS,GAC1C,EAAQ,WACR,GAAgB,EAAQ,EACxB,IAAkB,EAAc,EAAQ,gBAAgB,GACpD,EAAQ,kBACR,GAAgB,EAAQ,EAE5B,IAAgB,EAAc,EAAQ,cAAc,GAChD,EAAQ,gBACR,GAAgB,EAAQ,EAE5B,IAAY,GAAO,GAAQ,EAAE,EAAQ,WAAW,KAA2B,CAAC,EAC5E,IAAc,EAAQ,eAAe,GAAQ,EAC7C,IAAU,EAAW,EAAQ,QAAQ,GAAG,EAAQ,UAAU,MAC1D,IAAc,EAAU,EAAQ,YAAY,IAAI,GAAS,EAAQ,YAAY,GAC7E,EAAQ,cACR,IACA,IAAe,EAAU,EAAQ,aAAa,IAAI,GAAS,EAAQ,aAAa,GAChF,EAAQ,eACR,IACA,IAAiB,CAAC,CAAC,EAAQ,gBAC3B,IAAc,CAAC,CAAC,EAAQ,aACxB,IAAkB,EAAW,EAAQ,gBAAgB,GACrD,EAAQ,kBACR,MACA,IAAY,EAAc,EAAQ,UAAU,GAAG,EAAQ,YAAY,MACnE,IAAkB,EAAU,EAAQ,gBAAgB,GACpD,EAAQ,kBACR,IACA,IAAkB,CAAC,CAAC,EAAQ,iBAC5B,IAAkB,EAAW,EAAQ,gBAAgB,GACrD,EAAQ,kBACR;AACN,CAAA,QAAA,IAAA,aAA8B,gBAG1B,EAAW,EAAQ,gBAAgB,IACnC,IAASD,GAAe,EAAc,qCAAqC,CAAC;CAEhF,IAAM,IAAkB,EAAW,EAAQ,gBAAgB,GACrD,EAAQ,kBACR,MAAa,KACb,IAAmB,EAAW,EAAQ,iBAAiB,GACvD,EAAQ,mBACR,MAAe,KACf,IAAkB,EAAS,EAAQ,gBAAgB,GACnD,EAAQ,kBACR,KAAA,GAEA,IAAkB,GAClB,IAAuB,EAAS,EAAgB,qBAAqB,GACjE,EAAgB,uCAChB,IAAI,KAAK,EAEb,IAAqB,EAAS,EAAgB,mBAAmB,GAC7D,EAAgB,qCAChB,IAAI,KAAK,EAEb,IAAS,EAAS,EAAgB,OAAO,GAAG,EAAgB,SAAS,EAAE;AAC7E;CACA,IAAM,IAAU;EACZ;EACA,KAAK;EACL;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACH;AAkBD,QAhBI,EAAQ,kBAAkB,GAC1B,EAAQ,gBAAgB,GACxB,EAAQ,uBAAuB,GAC/B,EAAQ,qBAAqB,GAGjC,QAAA,IAAA,aAA8B,iBAC1B,EAAQ,cACJ,EAAgB,eAAe,OAEzB,KAAA,IADA,EAAgB,eAI9B,QAAA,IAAA,aAA8B,gBAAiB,8BAC3C,IAAiB,GAAS,GAAS,EAAO,EAEvC;;AAEX,IAAM,MAAmB,OAAY,GAAG,IAAS,GAAQ,EAAE;AAE3D,SAAS,GAAwB,GAAU,GAAK;AAC5C,QAAO,aAAoB,SAAS,EAAS,KAAK,EAAI,GAAG;;AAG7D,SAAS,GAAuB,GAAS,GAAK;AAC1C,QAAO,aAAmB,SAAS,EAAQ,KAAK,EAAI,GAAG;;AAG3D,SAAS,GAAc,GAAS,GAAK,GAAQ,GAAa,GAAM;CAC5D,IAAM,EAAE,YAAS,cAAW;AAE5B,KAAA,QAAA,IAAA,aAA8B,cAAe;EACzC,IAAM,IAAU,EAAQ;AACxB,EAAI,KACA,EAAQ,KAAK,WAAW;GACpB;GACA;GACA;GACA,SAAS,GAAG,EAAK,GAAG;GACvB,CAAC;;AAGV,KAAI,MAAY,MAAM;EAClB,IAAM,IAAM,EAAQ,GAAS,GAAQ,GAAK,EAAK;AAC/C,SAAO,EAAS,EAAI,GAAG,IAAM;OAM7B,QAHA,QAAA,IAAA,aAA8B,gBAAiB,GAAuB,GAAa,EAAI,IACnF,EAAOA,GAAe,EAAc,eAAe;EAAE;EAAK;EAAQ,CAAC,CAAC,EAEjE;;AAIf,SAAS,GAAqB,GAAK,GAAQ,GAAU;CACjD,IAAM,IAAU;AAEhB,CADA,EAAQ,qCAAqB,IAAI,KAAK,EACtC,EAAI,iBAAiB,GAAK,GAAU,EAAO;;AAG/C,SAAS,GAAmB,GAAQ,GAAe;AAG/C,QAFI,MAAW,IACJ,KACJ,EAAO,MAAM,IAAI,CAAC,OAAO,EAAc,MAAM,IAAI,CAAC;;AAG7D,SAAS,IAAmB,GAAc,GAAS;CAC/C,IAAM,IAAQ,EAAQ,QAAQ,EAAa;AAC3C,KAAI,MAAU,GACV,QAAO;AAEX,MAAK,IAAI,IAAI,IAAQ,GAAG,IAAI,EAAQ,QAAQ,IACxC,KAAI,GAAmB,GAAc,EAAQ,GAAG,CAC5C,QAAO;AAGf,QAAO;;AAIX,IAAM,KAAc,OAAO,OAAS,KAC9B,KAAiB;CACnB,gBAAgB,MAAsB,KAAK,mBAAmB;CAC9D,cAAc,MAAsB,KAAK,iBAAiB;CAC7D;AAGD,SAAS,GAAS,GAAS,GAAG,GAAM;CAChC,IAAM,EAAE,oBAAiB,gBAAa,mBAAgB,WAAQ,wBAAqB,GAC7E,EAAE,4BAAyB;AACjC,KAAA,QAAA,IAAA,aAA8B,gBAAiB,CAAC,GAAe,eAE3D,QADA,EAAOA,GAAe,EAAc,mBAAmB,CAAC,EACxD;AAEJ,KAAI,CAAC,EAAS,EAAK,GAAG,IAAI,CAAC,GAAO,EAAK,GAAG,IAAI,CAAC,EAAS,EAAK,GAAG,CAM5D,QALA,QAAA,IAAA,aAA8B,gBAC1B,EAAOA,GAAe,EAAc,uBAAuB,EACvD,OAAO,OAAO,EAAK,GAAG,EACzB,CAAC,CAAC,EAEP;CAEJ,IAAM,CAAC,GAAK,GAAO,GAAS,KAAa,GAAkB,GAAG,EAAK,EAC7D,IAAc,EAAU,EAAQ,YAAY,GAC5C,EAAQ,cACR,EAAQ,aACR,IAAe,EAAU,EAAQ,aAAa,GAC9C,EAAQ,eACR,EAAQ,cACR,IAAO,CAAC,CAAC,EAAQ,MACjB,IAAS,GAAU,GAAS,EAAQ,EACpC,IAAU,EAAiB,GACjC,GAAgB,EAAO;AACvB,KAAI,CAAC,EAAS,EAAI,IAAI,MAAQ,GAC1B,QAAO,IAAI,KAAK,eAAe,EAAO,QAAQ,MAAM,GAAG,EAAE,EAAU,CAAC,OAAO,EAAM;CAGrF,IAAI,IAAiB,EAAE,EACnB,GACA,IAAS,MACT,IAAO,GACP,IAAK,MACH,IAAO;AACb,MAAK,IAAI,IAAI,GAAG,IAAI,EAAQ,QAAQ,KAAK;AAWrC,MAVA,IAAe,IAAK,EAAQ,IAC5B,QAAA,IAAA,aAA8B,gBAC1B,MAAW,KACX,GAAwB,GAAc,EAAI,IAC1C,EAAOA,GAAe,EAAc,yBAAyB;GACzD;GACA,QAAQ;GACX,CAAC,CAAC,EAGP,QAAA,IAAA,aAA8B,gBAAiB,MAAW,GAAc;GACpE,IAAM,IAAU,EAAQ;AACxB,GAAI,KACA,EAAQ,KAAK,YAAY;IACrB;IACA;IACA;IACA;IACA,SAAS,GAAG,EAAK,GAAG;IACvB,CAAC;;AAMV,MAHA,IACI,EAAgB,MAAiB,EAAE,EACvC,IAAS,EAAe,IACpB,EAAc,EAAO,CACrB;AAEJ,EADA,GAAc,GAAS,GAAK,GAAc,GAAa,EAAK,EAC5D,IAAO;;AAGX,KAAI,CAAC,EAAc,EAAO,IAAI,CAAC,EAAS,EAAa,CACjD,QAAO,IAAA,KAA6B;CAExC,IAAI,IAAK,GAAG,EAAa,IAAI;AAC7B,CAAK,GAAc,EAAU,KACzB,IAAK,GAAG,EAAG,IAAI,KAAK,UAAU,EAAU;CAE5C,IAAI,IAAY,EAAqB,IAAI,EAAG;AAK5C,QAJK,MACD,IAAY,IAAI,KAAK,eAAe,GAAc,GAAO,EAAE,EAAE,GAAQ,EAAU,CAAC,EAChF,EAAqB,IAAI,GAAI,EAAU,GAEnC,IAAiC,EAAU,cAAc,EAAM,GAAxD,EAAU,OAAO,EAAM;;AAG1C,IAAM,MAA+B;CACjC;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACH;AAED,SAAS,GAAkB,GAAG,GAAM;CAChC,IAAM,CAAC,GAAM,GAAM,GAAM,KAAQ,GAC3B,IAAU,GAAQ,EACpB,IAAY,GAAQ,EACpB;AACJ,KAAI,EAAS,EAAK,EAAE;EAGhB,IAAM,IAAU,EAAK,MAAM,iCAAiC;AAC5D,MAAI,CAAC,EACD,OAAM,GAAgB,GAAe,0BAA0B;EAInE,IAAM,IAAW,EAAQ,KACnB,EAAQ,GAAG,MAAM,CAAC,WAAW,IAAI,GAC7B,GAAG,EAAQ,GAAG,MAAM,GAAG,EAAQ,GAAG,MAAM,KACxC,GAAG,EAAQ,GAAG,MAAM,CAAC,GAAG,EAAQ,GAAG,MAAM,KAC7C,EAAQ,GAAG,MAAM;AACvB,MAAQ,IAAI,KAAK,EAAS;AAC1B,MAAI;AAEA,KAAM,aAAa;UAEjB;AACF,SAAM,GAAgB,GAAe,0BAA0B;;YAG9D,GAAO,EAAK,EAAE;AACnB,MAAI,MAAM,EAAK,SAAS,CAAC,CACrB,OAAM,GAAgB,GAAe,sBAAsB;AAE/D,MAAQ;YAEH,EAAS,EAAK,CACnB,KAAQ;KAGR,OAAM,GAAgB,GAAe,iBAAiB;AAwB1D,QAtBI,EAAS,EAAK,GACd,EAAQ,MAAM,IAET,EAAc,EAAK,IACxB,OAAO,KAAK,EAAK,CAAC,SAAQ,MAAO;AAC7B,EAAI,IAA6B,SAAS,EAAI,GAC1C,EAAU,KAAO,EAAK,KAGtB,EAAQ,KAAO,EAAK;GAE1B,EAEF,EAAS,EAAK,GACd,EAAQ,SAAS,IAEZ,EAAc,EAAK,KACxB,IAAY,IAEZ,EAAc,EAAK,KACnB,IAAY,IAET;EAAC,EAAQ,OAAO;EAAI;EAAO;EAAS;EAAU;;AAGzD,SAAS,GAAoB,GAAK,GAAQ,GAAQ;CAC9C,IAAM,IAAU;AAChB,MAAK,IAAM,KAAO,GAAQ;EACtB,IAAM,IAAK,GAAG,EAAO,IAAI;AACpB,IAAQ,qBAAqB,IAAI,EAAG,IAGzC,EAAQ,qBAAqB,OAAO,EAAG;;;AAK/C,SAAS,GAAO,GAAS,GAAG,GAAM;CAC9B,IAAM,EAAE,kBAAe,gBAAa,mBAAgB,WAAQ,wBAAqB,GAC3E,EAAE,0BAAuB;AAC/B,KAAA,QAAA,IAAA,aAA8B,gBAAiB,CAAC,GAAe,aAE3D,QADA,EAAOA,GAAe,EAAc,qBAAqB,CAAC,EAC1D;AAEJ,KAAI,CAAC,EAAS,EAAK,GAAG,CAMlB,QALA,QAAA,IAAA,aAA8B,gBAC1B,EAAOA,GAAe,EAAc,yBAAyB,EACzD,OAAO,OAAO,EAAK,GAAG,EACzB,CAAC,CAAC,EAEP;CAEJ,IAAM,CAAC,GAAK,GAAO,GAAS,KAAa,GAAgB,GAAG,EAAK,EAC3D,IAAc,EAAU,EAAQ,YAAY,GAC5C,EAAQ,cACR,EAAQ,aACR,IAAe,EAAU,EAAQ,aAAa,GAC9C,EAAQ,eACR,EAAQ,cACR,IAAO,CAAC,CAAC,EAAQ,MACjB,IAAS,GAAU,GAAS,EAAQ,EACpC,IAAU,EAAiB,GACjC,GAAgB,EAAO;AACvB,KAAI,CAAC,EAAS,EAAI,IAAI,MAAQ,GAC1B,QAAO,IAAI,KAAK,aAAa,EAAO,QAAQ,MAAM,GAAG,EAAE,EAAU,CAAC,OAAO,EAAM;CAGnF,IAAI,IAAe,EAAE,EACjB,GACA,IAAS,MACT,IAAO,GACP,IAAK,MACH,IAAO;AACb,MAAK,IAAI,IAAI,GAAG,IAAI,EAAQ,QAAQ,KAAK;AAWrC,MAVA,IAAe,IAAK,EAAQ,IAC5B,QAAA,IAAA,aAA8B,gBAC1B,MAAW,KACX,GAAwB,GAAc,EAAI,IAC1C,EAAOA,GAAe,EAAc,2BAA2B;GAC3D;GACA,QAAQ;GACX,CAAC,CAAC,EAGP,QAAA,IAAA,aAA8B,gBAAiB,MAAW,GAAc;GACpE,IAAM,IAAU,EAAQ;AACxB,GAAI,KACA,EAAQ,KAAK,YAAY;IACrB;IACA;IACA;IACA;IACA,SAAS,GAAG,EAAK,GAAG;IACvB,CAAC;;AAMV,MAHA,IACI,EAAc,MAAiB,EAAE,EACrC,IAAS,EAAa,IAClB,EAAc,EAAO,CACrB;AAEJ,EADA,GAAc,GAAS,GAAK,GAAc,GAAa,EAAK,EAC5D,IAAO;;AAGX,KAAI,CAAC,EAAc,EAAO,IAAI,CAAC,EAAS,EAAa,CACjD,QAAO,IAAA,KAA6B;CAExC,IAAI,IAAK,GAAG,EAAa,IAAI;AAC7B,CAAK,GAAc,EAAU,KACzB,IAAK,GAAG,EAAG,IAAI,KAAK,UAAU,EAAU;CAE5C,IAAI,IAAY,EAAmB,IAAI,EAAG;AAK1C,QAJK,MACD,IAAY,IAAI,KAAK,aAAa,GAAc,GAAO,EAAE,EAAE,GAAQ,EAAU,CAAC,EAC9E,EAAmB,IAAI,GAAI,EAAU,GAEjC,IAAiC,EAAU,cAAc,EAAM,GAAxD,EAAU,OAAO,EAAM;;AAG1C,IAAM,MAA6B;CAC/B;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACH;AAED,SAAS,GAAgB,GAAG,GAAM;CAC9B,IAAM,CAAC,GAAM,GAAM,GAAM,KAAQ,GAC3B,IAAU,GAAQ,EACpB,IAAY,GAAQ;AACxB,KAAI,CAAC,EAAS,EAAK,CACf,OAAM,GAAgB,GAAe,iBAAiB;CAE1D,IAAM,IAAQ;AAuBd,QAtBI,EAAS,EAAK,GACd,EAAQ,MAAM,IAET,EAAc,EAAK,IACxB,OAAO,KAAK,EAAK,CAAC,SAAQ,MAAO;AAC7B,EAAI,IAA2B,SAAS,EAAI,GACxC,EAAU,KAAO,EAAK,KAGtB,EAAQ,KAAO,EAAK;GAE1B,EAEF,EAAS,EAAK,GACd,EAAQ,SAAS,IAEZ,EAAc,EAAK,KACxB,IAAY,IAEZ,EAAc,EAAK,KACnB,IAAY,IAET;EAAC,EAAQ,OAAO;EAAI;EAAO;EAAS;EAAU;;AAGzD,SAAS,GAAkB,GAAK,GAAQ,GAAQ;CAC5C,IAAM,IAAU;AAChB,MAAK,IAAM,KAAO,GAAQ;EACtB,IAAM,IAAK,GAAG,EAAO,IAAI;AACpB,IAAQ,mBAAmB,IAAI,EAAG,IAGvC,EAAQ,mBAAmB,OAAO,EAAG;;;AAI7C,IAAM,OAAoB,MAAQ,GAC5B,OAAmB,MAAQ,IAC3B,MAA4B,QAC5B,OAAqB,MAAW,EAAO,WAAW,IAAI,KAAK,GAAK,EAAO,EACvE,MAAsBE;AAC5B,SAAS,GAAc,GAAQ,GAAe;AAU1C,QATA,IAAS,KAAK,IAAI,EAAO,EAErB,MAAkB,IAEX,MAAW,IACZ,IACA,IAGH,KAAK,IAAI,GAAQ,EAAE;;AAE9B,SAAS,IAAe,GAAS;CAE7B,IAAM,IAAQ,EAAS,EAAQ,YAAY,GACrC,EAAQ,cACR;AACN,QAAO,EAAS,EAAQ,OAAO,MAAM,GAC/B,EAAQ,MAAM,QACd,EAAS,EAAQ,OAAO,EAAE,GACtB,EAAQ,MAAM,IACd;;AAEd,SAAS,IAAqB,IAAU,EAAE,EAAE;CACxC,IAAM,IAAS,EAAQ,QACjB,IAAc,IAAe,EAAQ,EACrC,IAAa,EAAS,EAAO,IAAI,EAAW,EAAQ,cAAc,GAAQ,GAC1E,EAAQ,YAAY,KACpB,IACA,IAAgB,MAAe,KAAgB,KAAA,IAAY,IAC3D,KAAU,MAAa,EAAS,EAAW,GAAa,EAAS,QAAQ,EAAc,GACvF,IAAQ,EAAQ,QAAQ,EAAE,EAC1B,KAAQ,MAAU,EAAM,IACxB,IAAS,EAAQ,SAAS,GAAQ;AAExC,CAAI,EAAS,EAAQ,YAAY,KAC7B,EAAO,UAAU,EAAQ,aACzB,EAAO,MAAM,EAAQ;CAEzB,IAAM,KAAS,MAAQ,EAAO;CAC9B,SAAS,EAAQ,GAAK,GAAW;AAO7B,UALY,EAAW,EAAQ,SAAS,GAClC,EAAQ,SAAS,GAAK,CAAC,CAAC,EAAU,GAClC,EAAS,EAAQ,SAAS,GACtB,EAAQ,SAAS,KACjB,QAEJ,EAAQ,SACJ,EAAQ,OAAO,QAAQ,EAAI,GAC3B;;CAGd,IAAM,KAAa,MAAS,EAAQ,YAC9B,EAAQ,UAAU,KAClB,KACA,IAAY,EAAW,EAAQ,WAAW,UAAU,GACpD,EAAQ,UAAU,YAClB,KACA,IAAc,EAAW,EAAQ,WAAW,YAAY,GACxD,EAAQ,UAAU,cAClB,KAmCA,IAAM;EACP,MAAkC;EAClC,OAAoC;EACpC,QAAsC;EACtC,SAnCW,GAAK,GAAG,MAAS;GAC7B,IAAM,CAAC,GAAM,KAAQ,GACjB,IAAO,QACP,IAAW;AACf,GAAI,EAAK,WAAW,IACZ,EAAS,EAAK,IACd,IAAW,EAAK,YAAY,GAC5B,IAAO,EAAK,QAAQ,KAEf,EAAS,EAAK,KACnB,IAAW,KAAQ,KAGlB,EAAK,WAAW,MACjB,EAAS,EAAK,KACd,IAAW,KAAQ,IAEnB,EAAS,EAAK,KACd,IAAO,KAAQ;GAGvB,IAAM,IAAM,EAAQ,GAAK,GAAK,CAAC,EAAI,EAE7B,IAAW,MAAQ,MAAM,MAAQ,KAAA,IAAY,IAAM,GACnD,IAEN,MAAS,WAAW,EAAQ,EAAS,IAAI,IACnC,EAAS,KACT;AACN,UAAO,IAAW,EAAU,EAAS,CAAC,GAAK,EAAK,GAAG;;EAOlD,SAAwC;EACxC,MAxCQ,EAAS,EAAQ,WAAW,KAAK,GACxC,EAAQ,UAAU,OAClB;EAuCD,aAAgD;EAChD,WAA4C;EAC5C,QAAsC,GAAO,GAAQ,EAAE,GAAO,EAAO;EACzE;AACD,QAAO;;AAGX,IAAM,WAA8B,IAC9B,MAAqB,MAAQ,EAAW,EAAI;AAElD,SAAS,GAAU,GAAS,GAAG,GAAM;CACjC,IAAM,EAAE,mBAAgB,oBAAiB,gBAAa,oBAAiB,mBAAgB,gBAAa,GAC9F,CAAC,GAAK,KAAW,GAAmB,GAAG,EAAK,EAC5C,IAAc,EAAU,EAAQ,YAAY,GAC5C,EAAQ,cACR,EAAQ,aACR,IAAe,EAAU,EAAQ,aAAa,GAC9C,EAAQ,eACR,EAAQ,cACR,IAAkB,EAAU,EAAQ,gBAAgB,GACpD,EAAQ,kBACR,EAAQ,iBACR,IAAkB,CAAC,CAAC,EAAQ,iBAE5B,IAAkB,EAAS,EAAQ,QAAQ,IAAI,EAAU,EAAQ,QAAQ,GACxE,EAAU,EAAQ,QAAQ,GAErB,IAA8B,UAAN,IAD1B,EAAQ,UAEZ,IACM,IAA8B,UAAN,IAC1B,MACJ,IAAmB,KACpB,KAAmB,SACf,EAAS,EAAgB,IAAI,EAAW,EAAgB,GAC3D,IAAS,GAAU,GAAS,EAAQ;AAE1C,MAAmB,IAAa,EAAQ;CAGxC,IAAI,CAAC,GAAa,GAAc,KAAY,IAEtC;EACE;EACA;EACA,EAAS,MAAW,GAAQ;EAC/B,GALC,GAAqB,GAAS,GAAK,GAAQ,GAAgB,GAAc,EAAY,EAWvF,IAAS,GAET,IAAe;AAWnB,KAVI,CAAC,KACD,EAAE,EAAS,EAAO,IACd,GAAa,EAAO,IACpB,GAAkB,EAAO,KACzB,MACA,IAAS,GACT,IAAe,IAInB,CAAC,MACA,EAAE,EAAS,EAAO,IACf,GAAa,EAAO,IACpB,GAAkB,EAAO,KACzB,CAAC,EAAS,EAAa,EAC3B,QAAO,IAAA,KAA6B;AAGxC,KAAA,QAAA,IAAA,aAA8B,gBAAiB,EAAS,EAAO,IAAI,EAAQ,mBAAmB,KAK1F,QAJA,GAAK,yLAGgC,EAAI,IAAI,EACtC;CAGX,IAAI,IAAW,IAKT,IAAO,GAAkB,EAAO,GAEhC,IADA,GAAqB,GAAS,GAAK,GAAc,GAAQ,SALzC;AAClB,MAAW;GAIsE;AAGrF,KAAI,EACA,QAAO;CAKX,IAAM,IAAW,IAAgB,GAAS,GADvB,IADA,IAAyB,GAAS,GAAc,GAAS,EAAQ,CACjC,CACO,EAEtD,IAAM,IACJ,EAAgB,GAAU,EAAI,GAC9B;AAMN,KAJI,KAAmB,EAAS,EAAI,KAChC,IAAM,IAAuB,EAAI,GAGrC,QAAA,IAAA,aAA8B,gBAAiB,2BAA2B;EAEtE,IAAM,IAAW;GACb,WAAW,KAAK,KAAK;GACrB,KAAK,EAAS,EAAI,GACZ,IACA,GAAkB,EAAO,GACrB,EAAO,MACP;GACV,QAAQ,MAAiB,GAAkB,EAAO,GAC5C,EAAO,SACP;GACN,QAAQ,EAAS,EAAO,GAClB,IACA,GAAkB,EAAO,GACrB,EAAO,SACP;GACV,SAAS;GACZ;AAED,EADA,EAAS,OAAO,GAAO,EAAE,EAAE,EAAQ,QAAQ,qBAAmB,IAAI,EAAE,CAAC,EACrE,IAAkB,EAAS;;AAE/B,QAAO;;AAEX,SAAS,IAAa,GAAS;AAC3B,CAAI,EAAQ,EAAQ,KAAK,GACrB,EAAQ,OAAO,EAAQ,KAAK,KAAI,MAAQ,EAAS,EAAK,GAAGC,GAAW,EAAK,GAAG,EAAK,GAE5E,EAAS,EAAQ,MAAM,IAC5B,OAAO,KAAK,EAAQ,MAAM,CAAC,SAAQ,MAAO;AACtC,EAAI,EAAS,EAAQ,MAAM,GAAK,KAC5B,EAAQ,MAAM,KAAOA,GAAW,EAAQ,MAAM,GAAK;GAEzD;;AAGV,SAAS,GAAqB,GAAS,GAAK,GAAQ,GAAgB,GAAc,GAAa;CAC3F,IAAM,EAAE,aAAU,WAAQ,iBAAiB,GAAc,wBAAqB,GACxE,IAAU,EAAiB,GAAS,GAAgB,EAAO,EAC7D,IAAU,GAAQ,EAClB,GACA,IAAS,MACT,IAAO,GACP,IAAK,MACH,IAAO;AACb,MAAK,IAAI,IAAI,GAAG,IAAI,EAAQ,QAAQ,KAAK;AAYrC,MAXA,IAAe,IAAK,EAAQ,IAC5B,QAAA,IAAA,aAA8B,gBAC1B,MAAW,KACX,CAAC,GAAmB,GAAQ,EAAa,IACzC,GAAwB,GAAc,EAAI,IAC1C,EAAOH,GAAe,EAAc,uBAAuB;GACvD;GACA,QAAQ;GACX,CAAC,CAAC,EAGP,QAAA,IAAA,aAA8B,gBAAiB,MAAW,GAAc;GACpE,IAAM,IAAU,EAAQ;AACxB,GAAI,KACA,EAAQ,KAAK,YAAY;IACrB;IACA;IACA;IACA;IACA,SAAS,GAAG,EAAK,GAAG;IACvB,CAAC;;AAGV,MACI,EAAS,MAAiB,GAAQ;EAEtC,IAAI,IAAQ,MACR,GACA;AAYJ,MAXA,QAAA,IAAA,aAA8B,gBAAiB,OAC3C,IAAQ,OAAO,YAAY,KAAK,EAChC,IAAW,iCACX,IAAS,+BACT,MAAQ,GAAK,EAAS,IAErB,IAAS,EAAa,GAAS,EAAI,MAAM,SAE1C,IAAS,EAAQ,KAGrB,QAAA,IAAA,aAA8B,gBAAiB,IAAW;GACtD,IAAM,IAAM,OAAO,YAAY,KAAK,EAC9B,IAAU,EAAQ;AAUxB,GATI,KAAW,KAAS,KACpB,EAAQ,KAAK,mBAAmB;IAC5B,MAAM;IACN;IACA,SAAS;IACT,MAAM,IAAM;IACZ,SAAS,GAAG,EAAK,GAAG;IACvB,CAAC,EAEF,KAAY,KAAU,MAAQ,OAC9B,GAAK,EAAO,EACZ,GAAQ,2BAA2B,GAAU,EAAO;;AAG5D,MAAI,EAAS,EAAO,IAAI,GAAa,EAAO,IAAI,GAAkB,EAAO,CACrE;AAEJ,MAAI,CAAC,IAAmB,GAAc,EAAQ,EAAE;GAC5C,IAAM,IAAa,GAAc,GACjC,GAAK,GAAc,GAAa,EAAK;AACrC,GAAI,MAAe,MACf,IAAS;;AAGjB,MAAO;;AAEX,QAAO;EAAC;EAAQ;EAAc;EAAQ;;AAE1C,SAAS,GAAqB,GAAS,GAAK,GAAc,GAAQ,GAAc,GAAS;CACrF,IAAM,EAAE,oBAAiB,uBAAoB;AAC7C,KAAI,GAAkB,EAAO,EAAE;EAC3B,IAAM,IAAM;AAGZ,SAFA,EAAI,SAAS,EAAI,UAAU,GAC3B,EAAI,MAAM,EAAI,OAAO,GACd;;AAEX,KAAI,KAAmB,MAAM;EACzB,IAAM,WAAa;AAGnB,SAFA,EAAI,SAAS,GACb,EAAI,MAAM,GACH;;CAGX,IAAI,IAAQ,MACR,GACA;AACJ,CAAA,QAAA,IAAA,aAA8B,gBAAiB,OAC3C,IAAQ,OAAO,YAAY,KAAK,EAChC,IAAW,qCACX,IAAS,mCACT,MAAQ,GAAK,EAAS;CAE1B,IAAM,IAAM,EAAgB,GAAQ,IAAkB,GAAS,GAAc,GAAc,GAAQ,GAAiB,EAAQ,CAAC;AAE7H,KAAA,QAAA,IAAA,aAA8B,gBAAiB,IAAW;EACtD,IAAM,IAAM,OAAO,YAAY,KAAK,EAC9B,IAAU,EAAQ;AASxB,EARI,KAAW,KACX,EAAQ,KAAK,uBAAuB;GAChC,MAAM;GACN,SAAS;GACT,MAAM,IAAM;GACZ,SAAS,aAAkB;GAC9B,CAAC,EAEF,KAAY,KAAU,MAAQ,OAC9B,GAAK,EAAO,EACZ,GAAQ,+BAA+B,GAAU,EAAO;;AAMhE,QAHA,EAAI,SAAS,GACb,EAAI,MAAM,GACV,EAAI,SAAS,GACN;;AAEX,SAAS,IAAgB,GAAS,GAAK,GAAQ;CAE3C,IAAI,IAAQ,MACR,GACA;AACJ,CAAA,QAAA,IAAA,aAA8B,gBAAiB,OAC3C,IAAQ,OAAO,YAAY,KAAK,EAChC,IAAW,oCACX,IAAS,kCACT,MAAQ,GAAK,EAAS;CAE1B,IAAM,IAAW,EAAI,EAAO;AAE5B,KAAA,QAAA,IAAA,aAA8B,gBAAiB,IAAW;EACtD,IAAM,IAAM,OAAO,YAAY,KAAK,EAC9B,IAAU,EAAQ;AASxB,EARI,KAAW,KACX,EAAQ,KAAK,sBAAsB;GAC/B,MAAM;GACN,OAAO;GACP,MAAM,IAAM;GACZ,SAAS,aAAkB,EAAI;GAClC,CAAC,EAEF,KAAY,KAAU,MAAQ,OAC9B,GAAK,EAAO,EACZ,GAAQ,8BAA8B,GAAU,EAAO;;AAG/D,QAAO;;AAGX,SAAS,GAAmB,GAAG,GAAM;CACjC,IAAM,CAAC,GAAM,GAAM,KAAQ,GACrB,IAAU,GAAQ;AACxB,KAAI,CAAC,EAAS,EAAK,IACf,CAAC,EAAS,EAAK,IACf,CAAC,GAAkB,EAAK,IACxB,CAAC,GAAa,EAAK,CACnB,OAAM,GAAgB,GAAe,iBAAiB;CAG1D,IAAM,IAAM,EAAS,EAAK,GACpB,OAAO,EAAK,IACZ,GAAkB,EAAK,EACnB;AAuBV,QArBI,EAAS,EAAK,GACd,EAAQ,SAAS,IAEZ,EAAS,EAAK,GACnB,EAAQ,UAAU,IAEb,EAAc,EAAK,IAAI,CAAC,GAAc,EAAK,GAChD,EAAQ,QAAQ,IAEX,EAAQ,EAAK,KAClB,EAAQ,OAAO,IAEf,EAAS,EAAK,GACd,EAAQ,SAAS,IAEZ,EAAS,EAAK,GACnB,EAAQ,UAAU,IAEb,EAAc,EAAK,IACxB,GAAO,GAAS,EAAK,EAElB,CAAC,GAAK,EAAQ;;AAEzB,SAAS,IAAkB,GAAS,GAAQ,GAAK,GAAQ,GAAiB,GAAS;AAC/E,QAAO;EACH;EACA;EACA;EACA,UAAU,MAAQ;AAEd,OADA,KAAW,EAAQ,EAAI,EACvB,QAAA,IAAA,aAA8B,cAAe;IACzC,IAAM,IAAU,IAAsB,EAAO,EACvC,IAAY,EAAI,YAClB,KACA,IAAkB,GAAS,EAAI,SAAS,MAAM,QAAQ,EAAI,SAAS,IAAI,OAAO,EAC5E,IAAU,EAAQ;AACxB,IAAI,KAAW,KACX,EAAQ,KAAK,iBAAiB;KAC1B,SAAS;KACT,OAAO,EAAI;KACX,OAAO,EAAI,YAAY,EAAI,SAAS,MAAM;KAC1C,KAAK,EAAI,YAAY,EAAI,SAAS,IAAI;KACtC,SAAS,aAAkB;KAC9B,CAAC;IAEN,IAAM,IAAU,8BAA8B,EAAI;AAClD,UAAU,YAAY,IAAY,GAAG,EAAQ,IAAI,MAAc,EAAQ;;AAE3E,SAAM;;EAEV,aAAa,MAAW,IAAuB,GAAQ,GAAK,EAAO;EACtE;;AAEL,SAAS,IAAsB,GAAQ;AACnC,KAAI,EAAS,EAAO,CAChB,QAAO;KAGH,EAAO,OAAO,EAAO,IAAI,OACzB,QAAO,EAAO,IAAI;;AAI9B,SAAS,IAAyB,GAAS,GAAQ,GAAS,GAAS;CACjE,IAAM,EAAE,cAAW,gBAAa,iBAAiB,GAAc,mBAAgB,iBAAc,gBAAa,uBAAoB,GA2BxH,IAAa;EACf;EACA;EACA;EACA,WA9BoB,GAAK,MAAc;GACvC,IAAI,IAAM,EAAa,GAAS,EAAI;AAEpC,OAAI,KAAO,SAAS,KAAmB,IAAY;IAC/C,IAAM,KAAK,KAAW,GAAqB,KAAmB,GAC9D,GAAK,GAAQ,GAAgB,GAAc,EAAY;AACvD,QAAM,EAAa,GAAS,EAAI;;AAEpC,OAAI,EAAS,EAAI,IAAI,GAAa,EAAI,EAAE;IACpC,IAAI,IAAW,IAIT,IAAM,GAAqB,GAAS,GAAK,GAAQ,GAAK,SAHtC;AAClB,SAAW;MAE0D;AACzE,WAAQ,IAEF,KADA;cAGD,GAAkB,EAAI,CAC3B,QAAO;OAIP,QAAO;;EAQd;AAaD,QAZI,EAAQ,cACR,EAAW,YAAY,EAAQ,YAE/B,EAAQ,SACR,EAAW,OAAO,EAAQ,OAE1B,EAAQ,UACR,EAAW,QAAQ,EAAQ,QAE3B,EAAS,EAAQ,OAAO,KACxB,EAAW,cAAc,EAAQ,SAE9B;;AAIPH,KAAkB;;;ACj1DtB,IAAM,MAAU;AAKhB,SAAS,MAAmB;AAUxB,CATI,OAAO,6BAA8B,cACrC,IAAe,CAAC,4BAA4B,KAE5C,OAAO,2BAA4B,cACnC,IAAe,CAAC,0BAA0B,KAE1C,OAAO,qCAAsC,cAC7C,IAAe,CAAC,oCAAoC,KAEpD,OAAO,6BAA8B,cACrC,IAAe,CAAC,4BAA4B;;AAIpD,IAAM,IAAiB;CAEnB,wBAAA;CAEA,kBAAkB;CAElB,wBAAwB;CACxB,eAAe;CAEf,gBAAgB;CAChB,eAAe;CAEf,kCAAkC;CAClC,4BAA4B;CAE5B,kBAAkB;CAElB,gCAAgC;CAEhC,qCAAqC;CACxC;AACD,SAAS,GAAgB,GAAM,GAAG,GAAM;AACpC,QAAO,GAAmB,GAAM,MAAA,QAAA,IAAA,aAAgC,eAAoD,KAAA,IAApC;EAAE,UAAU;EAAe;EAAM,CAAa;;AAElI,IAAM,MAAgB;EACjB,EAAe,yBAAyB;EACxC,EAAe,mBAAmB;EAClC,EAAe,yBAAyB;EACxC,EAAe,gBAAgB;EAC/B,EAAe,mBAAmB;EAClC,EAAe,iBAAiB;EAChC,EAAe,gBAAgB;EAC/B,EAAe,mCAAmC;EAClD,EAAe,6BAA6B;EAC5C,EAAe,iCAAiC;EAChD,EAAe,sCAAsC;CACzD,EAEK,KACS,mBAAW,mBAAmB,EACvC,KAAqC,mBAAW,kBAAkB,EAClE,KAAmC,mBAAW,gBAAgB,EAC9D,KAA+B,mBAAW,kBAAkB,EAC5D,KAAgC,mBAAW,mBAAmB,EAC9D,MAAuB,GAAW,mBAAmB;AAC3D,GAAW,gBAAgB;AAC3B,IAAM,KACS,mBAAW,qBAAqB,EACzC,KAA+B,mBAAW,YAAY,EAEtD,KAAgB;CAClB,kBAAA;CACA,wBAAA;CACA,oBAAA;CAIA,uBAAA;CAIA,uCAAA;CAGA,4BAAA;CACH,EACK,MAAe;EAChB,GAAc,mBAAmB;EACjC,GAAc,yBAAyB;EACvC,GAAc,qBAAqB;EAInC,GAAc,wBAAwB;EAItC,GAAc,wCAAwC;EACtD,GAAc,6BAA6B;CAC/C;AACD,SAAS,GAAe,GAAM,GAAG,GAAM;AACnC,QAAOO,GAAO,IAAa,IAAO,GAAG,EAAK;;AAO9C,SAAS,GAAe,GAAK;AAKzB,KAHI,CAAC,EAAS,EAAI,IAGd,GAAa,EAAI,CACjB,QAAO;AAEX,MAAK,IAAM,KAAO,EAET,QAAO,GAAK,EAAI,CAIrB,KAAI,CAAC,EAAI,SAAS,IAAI,EAEd,EAAS,EAAI,GAAK,IAClB,GAAe,EAAI,GAAK;MAI3B;EAED,IAAM,IAAU,EAAI,MAAM,IAAI,EACxB,IAAY,EAAQ,SAAS,GAC/B,IAAa,GACb,IAAiB;AACrB,OAAK,IAAI,IAAI,GAAG,IAAI,GAAW,KAAK;AAChC,OAAI,EAAQ,OAAO,YACf,OAAU,MAAM,eAAe,EAAQ,KAAK;AAKhD,OAHM,EAAQ,MAAM,MAChB,EAAW,EAAQ,MAAM,GAAQ,GAEjC,CAAC,EAAS,EAAW,EAAQ,IAAI,EAAE;AAKnC,IAJA,QAAA,IAAA,aAA0B,gBACtB,GAAK,GAAe,GAAc,oBAAoB,EAClD,KAAK,EAAQ,IAChB,CAAC,CAAC,EACP,IAAiB;AACjB;;AAEJ,OAAa,EAAW,EAAQ;;AAmBpC,MAhBK,MACI,GAAa,EAAW,GASpB,GAAoB,SAAS,EAAQ,GAAW,IACjD,OAAO,EAAI,MATf,EAAW,EAAQ,MAAc,EAAI,IACrC,OAAO,EAAI,MAaf,CAAC,GAAa,EAAW,EAAE;GAC3B,IAAM,IAAS,EAAW,EAAQ;AAClC,GAAI,EAAS,EAAO,IAChB,GAAe,EAAO;;;AAKtC,QAAO;;AAEX,SAAS,GAAkB,GAAQ,GAAS;CACxC,IAAM,EAAE,aAAU,WAAQ,oBAAiB,gBAAa,GAElD,IAAO,EAAc,EAAS,GAC9B,IACA,EAAQ,EAAO,GACX,GAAQ,GACR,GAAG,IAAS,GAAQ,EAAE;AAoBhC,KAlBI,EAAQ,EAAO,IACf,EAAO,SAAQ,MAAU;AACrB,MAAI,YAAY,KAAU,cAAc,GAAQ;GAC5C,IAAM,EAAE,WAAQ,gBAAa;AAC7B,GAAI,KACA,EAAI,KAAU,EAAI,MAAW,GAAQ,EACrC,GAAS,GAAU,EAAI,GAAQ,IAG/B,GAAS,GAAU,EAAI;QAI3B,GAAS,EAAO,IAAI,GAAS,KAAK,MAAM,EAAO,EAAE,EAAI;GAE3D,EAGF,KAAmB,QAAQ,QACtB,IAAM,KAAO,EACd,CAAI,GAAO,GAAK,EAAI,IAChB,GAAe,EAAI,GAAK;AAIpC,QAAO;;AAEX,SAAS,IAAoB,GAAU;AACnC,QAAO,EAAS;;AAEpB,SAAS,IAAoB,GAAI,GAAS,GAAkB;CAExD,IAAI,IAAW,EAAS,EAAQ,SAAS,GACnC,EAAQ,WACR,GAAQ;AACd,CAAI,kBAAkB,MAClB,IAAW,GAAkB,EAAG,OAAO,OAAO;EAC1C;EACA,QAAQ,EAAiB;EAC5B,CAAC;CAGN,IAAM,IAAU,OAAO,KAAK,EAAS;AAQjC,KAPA,EAAQ,UACR,EAAQ,SAAQ,MAAU;AACtB,IAAG,mBAAmB,GAAQ,EAAS,GAAQ;GACjD,EAIE,EAAS,EAAQ,gBAAgB,EAAE;EACnC,IAAM,IAAU,OAAO,KAAK,EAAQ,gBAAgB;AACpD,EAAI,EAAQ,UACR,EAAQ,SAAQ,MAAU;AACtB,KAAG,oBAAoB,GAAQ,EAAQ,gBAAgB,GAAQ;IACjE;;AAIV,KAAI,EAAS,EAAQ,cAAc,EAAE;EACjC,IAAM,IAAU,OAAO,KAAK,EAAQ,cAAc;AAClD,EAAI,EAAQ,UACR,EAAQ,SAAQ,MAAU;AACtB,KAAG,kBAAkB,GAAQ,EAAQ,cAAc,GAAQ;IAC7D;;;AAKlB,SAAS,GAAe,GAAK;AACzB,QAAO,EAAY,GAAM,MAAM,GAAK,EAAE;;AAE1C,SAASC,KAAqB;CAE1B,IAAM,IAAM;AAKR,QAJA,KAAO,IACA,EAAI,KAGJ,EAAI,oBAAoB;;AAOvC,IACM,WAA0B,EAAE,EAC5B,YAA0B,IAC5B,KAAa;AACjB,SAAS,GAAyB,GAAS;AACvC,UAAS,GAAK,GAAQ,GAAK,MAChB,EAAQ,GAAQ,GAAKA,IAAoB,IAAI,KAAA,GAAW,EAAK;;AAiB5E,SAAS,IAAe,IAAU,EAAE,EAAE;CAClC,IAAM,EAAE,WAAQ,0BAAuB,GACjC,IAAY,MAAW,KAAA,GACvB,IAAW,EAAQ,UACnB,IAAO,KAAY,IAAM,IAC3B,IAAiB,EAAU,EAAQ,cAAc,GAC/C,EAAQ,gBACR,IACA,IAAU,EAEhB,KAAU,IACJ,EAAO,OAAO,QACd,EAAS,EAAQ,OAAO,GACpB,EAAQ,SACR,GAAe,EACnB,IAAkB,EAExB,KAAU,IACJ,EAAO,eAAe,QACtB,EAAS,EAAQ,eAAe,IAC9B,EAAQ,EAAQ,eAAe,IAC/B,EAAc,EAAQ,eAAe,IACrC,EAAQ,mBAAmB,KACzB,EAAQ,iBACR,EAAQ,MAAM,EAClB,IAAY,EAAK,GAAkB,EAAQ,OAAO,EAAQ,CAAC,EAE3D,IAAmB,EAAK,EAAc,EAAQ,gBAAgB,GAC1D,EAAQ,kBACR,GAAG,EAAQ,QAAQ,EAAE,EAAE,CAAC,EAG5B,IAAiB,EAAK,EAAc,EAAQ,cAAc,GACtD,EAAQ,gBACR,GAAG,EAAQ,QAAQ,EAAE,EAAE,CAAC,EAI9B,IAAe,IACb,EAAO,cACP,EAAU,EAAQ,YAAY,IAAI,GAAS,EAAQ,YAAY,GAC3D,EAAQ,cACR,IAEN,IAAgB,IACd,EAAO,eACP,EAAU,EAAQ,aAAa,IAAI,GAAS,EAAQ,aAAa,GAC7D,EAAQ,eACR,IAEN,IAAgB,IACd,EAAO,eACP,EAAU,EAAQ,aAAa,GAC3B,EAAQ,eACR,IAEN,IAAkB,CAAC,CAAC,EAAQ,gBAE5B,IAAW,EAAW,EAAQ,QAAQ,GAAG,EAAQ,UAAU,MAC3D,IAAkB,EAAW,EAAQ,QAAQ,GAC3C,GAAyB,EAAQ,QAAQ,GACzC,MAEF,IAAmB,EAAW,EAAQ,gBAAgB,GACpD,EAAQ,kBACR,MAEF,IAAmB,IACjB,EAAO,kBACP,EAAU,EAAQ,gBAAgB,GAC9B,EAAQ,kBACR,IACN,IAAmB,CAAC,CAAC,EAAQ,iBAG3B,IAAa,IACb,EAAO,YACP,EAAc,EAAQ,UAAU,GAC5B,EAAQ,YACR,EAAE,EAER,IAAe,EAAQ,eAAgB,KAAU,EAAO,aAGxD;AA0CJ,CADA,WAxC6B;AACzB,OAAa,GAAmB,KAAK;EACrC,IAAM,IAAa;GACf,SAAS;GACT,QAAQ,EAAQ;GAChB,gBAAgB,EAAgB;GAChC,UAAU,EAAU;GACpB,WAAW;GACX,aAAa;GACb,SAAS,MAAoB,OAAO,KAAA,IAAY;GAChD,aAAa;GACb,cAAc;GACd,gBAAgB;GAChB,aAAa;GACb,iBAAiB,MAAqB,OAAO,KAAA,IAAY;GACzD,iBAAiB;GACjB,iBAAiB;GACjB,iBAAiB,EAAQ;GACzB,iBAAiB,EAAQ;GACzB,QAAQ,EAAE,WAAW,OAAO;GAC/B;AAWD,EATI,EAAW,kBAAkB,EAAiB,OAC9C,EAAW,gBAAgB,EAAe,OAC1C,EAAW,uBAAuB,EAAc,EAAS,GACnD,EAAS,uBACT,KAAA,GACN,EAAW,qBAAqB,EAAc,EAAS,GACjD,EAAS,qBACT,KAAA,GAEV,QAAA,IAAA,aAA8B,iBAC1B,EAAW,cAAc,EAAc,EAAS,GAC1C,EAAS,cACT,KAAA;EAEV,IAAM,IAAM,IAAkB,EAAW;AAEzC,SADA,KAAa,GAAmB,EAAI,EAC7B;KAEgB,EAC3B,GAAqB,GAAU,EAAQ,OAAO,EAAgB,MAAM;CAEpE,SAAS,IAAwB;AAC7B,SAAO;GACC,EAAQ;GACR,EAAgB;GAChB,EAAU;GACV,EAAiB;GACjB,EAAe;GAClB;;CAIT,IAAM,IAAS,EAAS;EACpB,WAAW,EAAQ;EACnB,MAAK,MAAO;AAER,GADA,EAAS,SAAS,GAClB,EAAQ,QAAQ;;EAEvB,CAAC,EAEI,IAAiB,EAAS;EAC5B,WAAW,EAAgB;EAC3B,MAAK,MAAO;AAGR,GAFA,EAAS,iBAAiB,GAC1B,EAAgB,QAAQ,GACxB,GAAqB,GAAU,EAAQ,OAAO,EAAI;;EAEzD,CAAC,EAEI,IAAW,QAAe,EAAU,MAAM,EAE1C,IAAiC,wBAAe,EAAiB,MAAM,EAEvE,IAA+B,wBAAe,EAAe,MAAM;CAEzE,SAAS,KAA4B;AACjC,SAAO,EAAW,EAAiB,GAAG,IAAmB;;CAG7D,SAAS,EAA0B,GAAS;AAExC,EADA,IAAmB,GACnB,EAAS,kBAAkB;;CAG/B,SAAS,KAAoB;AACzB,SAAO;;CAGX,SAAS,EAAkB,GAAS;AAKhC,EAJI,MAAY,SACZ,IAAkB,GAAyB,EAAQ,GAEvD,IAAW,GACX,EAAS,UAAU;;CAEvB,SAAS,EAA2B,GAAM,GAAK;AAC3C,SAAO,MAAS,eAAe,CAAC,EAAI;;CAExC,IAAM,KAAgB,GAAI,GAAgB,GAAU,GAAiB,GAAc,MAAqB;AACpG,KAAuB;EAEvB,IAAI;AACJ,MAAI;AASA,GARA,QAAA,IAAA,aAA8B,gBAAiB,2BAG1C,MACD,EAAS,kBAAkB,IACrB,KAAoB,GACpB,KAAA,IAEV,IAAM,EAAG,EAAS;YAEd;AAIJ,GAHA,QAAA,IAAA,aAA8B,gBAAiB,2BAG1C,MACD,EAAS,kBAAkB,KAAA;;AAGnC,MAAK,MAAa,sBACd,EAAS,EAAI,IACb,MAAA,MACC,MAAa,sBAAsB,CAAC,GACvC;GACE,IAAM,CAAC,GAAK,KAAQ,GAAgB;AACpC,OAAA,QAAA,IAAA,aAA8B,gBAC1B,KACA,EAAS,EAAI,IACb,EAA2B,GAAU,EAAK,KACtC,MACC,GAAwB,GAAe,EAAI,IACxC,GAAuB,GAAc,EAAI,KAC7C,GAAK,GAAe,GAAc,kBAAkB;IAChD;IACA,MAAM;IACT,CAAC,CAAC,EAGP,QAAA,IAAA,aAA8B,eAAe;IACzC,IAAM,EAAE,aAAa,MAAY;AACjC,IAAI,KAAW,KACX,EAAQ,KAAK,YAAY;KACrB,MAAM;KACN;KACA,IAAI;KACJ,SAAS,GAAG,EAAS,GAAG;KAC3B,CAAC;;AAId,UAAO,KAAU,IACX,EAAgB,EAAO,GACvB,EAAa,EAAI;aAElB,EAAiB,EAAI,CAC1B,QAAO;;;AAIP,QAAM,GAAgB,EAAe,uBAAuB;;CAIpE,SAAS,GAAE,GAAG,GAAM;AAChB,SAAO,GAAa,MAAW,QAAQ,MAAM,IAAW,MAAM,CAAC,GAAS,GAAG,EAAK,CAAC,QAAQ,GAAmB,GAAG,EAAK,EAAE,cAAa,MAAQ,QAAQ,MAAM,EAAK,GAAG,GAAM,CAAC,GAAG,EAAK,CAAC,GAAE,MAAO,IAAK,MAAO,EAAS,EAAI,CAAC;;CAGxN,SAAS,EAAG,GAAG,GAAM;EACjB,IAAM,CAAC,GAAM,GAAM,KAAQ;AAC3B,MAAI,KAAQ,CAAC,EAAS,EAAK,CACvB,OAAM,GAAgB,EAAe,iBAAiB;AAE1D,SAAO,GAAM,GAAM,GAAM,GAAO,EAAE,iBAAiB,IAAM,EAAE,KAAQ,EAAE,CAAC,CAAE;;CAG5E,SAAS,EAAE,GAAG,GAAM;AAChB,SAAO,GAAa,MAAW,QAAQ,MAAM,IAAU,MAAM,CAAC,GAAS,GAAG,EAAK,CAAC,QAAQ,GAAkB,GAAG,EAAK,EAAE,oBAAmB,MAAQ,QAAQ,MAAM,EAAK,GAAG,GAAM,CAAC,GAAG,EAAK,CAAC,QAAA,KAA+B,MAAO,EAAS,EAAI,IAAI,EAAQ,EAAI,CAAC;;CAG7P,SAAS,GAAE,GAAG,GAAM;AAChB,SAAO,GAAa,MAAW,QAAQ,MAAM,IAAQ,MAAM,CAAC,GAAS,GAAG,EAAK,CAAC,QAAQ,GAAgB,GAAG,EAAK,EAAE,kBAAiB,MAAQ,QAAQ,MAAM,EAAK,GAAG,GAAM,CAAC,GAAG,EAAK,CAAC,QAAA,KAA+B,MAAO,EAAS,EAAI,IAAI,EAAQ,EAAI,CAAC;;CAGvP,SAAS,EAAU,GAAQ;AACvB,SAAO,EAAO,KAAI,MAAO,EAAS,EAAI,IAAI,EAAS,EAAI,IAAI,EAAU,EAAI,GACnE,GAAe,OAAO,EAAI,CAAC,GAC3B,EAAI;;CAGd,IAAM,IAAY;EACd;EACA,cAHiB,MAAQ;EAIzB,MAAM;EACT;CAED,SAAS,EAAe,GAAG,GAAM;AAC7B,SAAO,GAAa,MAAW;GAC3B,IAAI,GACE,IAAW;AACjB,OAAI;AAEA,IADA,EAAS,YAAY,GACrB,IAAM,QAAQ,MAAM,IAAW,MAAM,CAAC,GAAU,GAAG,EAAK,CAAC;aAErD;AACJ,MAAS,YAAY;;AAEzB,UAAO;WACF,GAAmB,GAAG,EAAK,EAAE,cAAa,MAAQ,EAAK,IAAsB,GAAG,EAAK,GAAE,MAAO,CAAC,GAAe,EAAI,CAAC,GAAE,MAAO,EAAQ,EAAI,CAAC;;CAGtJ,SAAS,GAAY,GAAG,GAAM;AAC1B,SAAO,GAAa,MAAW,QAAQ,MAAM,IAAQ,MAAM,CAAC,GAAS,GAAG,EAAK,CAAC,QAAQ,GAAgB,GAAG,EAAK,EAAE,kBAAiB,MAAQ,EAAK,IAAmB,GAAG,EAAK,EAAE,KAAmB,MAAO,EAAS,EAAI,IAAI,EAAQ,EAAI,CAAC;;CAGvO,SAAS,GAAc,GAAG,GAAM;AAC5B,SAAO,GAAa,MAAW,QAAQ,MAAM,IAAU,MAAM,CAAC,GAAS,GAAG,EAAK,CAAC,QAAQ,GAAkB,GAAG,EAAK,EAAE,oBAAmB,MAAQ,EAAK,IAAqB,GAAG,EAAK,EAAE,KAAmB,MAAO,EAAS,EAAI,IAAI,EAAQ,EAAI,CAAC;;CAE/O,SAAS,GAAe,GAAO;AAE3B,EADA,IAAe,GACf,EAAS,cAAc;;CAG3B,SAAS,GAAG,GAAK,GAAQ;AACrB,SAAO,QAAmB;AACtB,OAAI,CAAC,EACD,QAAO;GAEX,IAAM,IAAe,EAAS,EAAO,GAAG,IAAS,EAAQ,OAGnD,IAAU,EAAS,EAAO,GAC1B,CAAC,EAAa,GACd,GAAwB,GAAU,EAAgB,OAAO,EAAa;AAC5E,QAAK,IAAI,IAAI,GAAG,IAAI,EAAQ,QAAQ,KAAK;IACrC,IAAM,IAAU,GAAiB,EAAQ,GAAG,EACxC,IAAW,EAAS,gBAAgB,GAAS,EAAI;AAKrD,QAHI,MAAa,SACb,IAAW,EAAQ,KAEnB,GAAa,EAAS,IACtB,GAAkB,EAAS,IAC3B,EAAS,EAAS,CAClB,QAAO;;AAGf,UAAO;WACF,CAAC,EAAI,EAAE,qBAAoB,MACzB,QAAQ,MAAM,EAAK,IAAI,GAAM,CAAC,GAAK,EAAO,CAAC,EACnD,MAAmB,MAAO,EAAU,EAAI,CAAC;;CAEhD,SAAS,EAAgB,GAAK;EAC1B,IAAI,IAAW,MACT,IAAU,GAAwB,GAAU,EAAgB,OAAO,EAAQ,MAAM;AACvF,OAAK,IAAI,IAAI,GAAG,IAAI,EAAQ,QAAQ,KAAK;GACrC,IAAM,IAAuB,EAAU,MAAM,EAAQ,OAAO,EAAE,EACxD,IAAe,EAAS,gBAAgB,GAAsB,EAAI;AACxE,OAAI,KAAgB,MAAM;AACtB,QAAW;AACX;;;AAGR,SAAO;;CAGX,SAAS,GAAG,GAAK;AAGb,SAFiB,EAAgB,EAAI,KAI/B,KACI,EAAO,GAAG,EAAI,IACd,EAAE;;CAGhB,SAAS,GAAiB,GAAQ;AAC9B,SAAQ,EAAU,MAAM,MAAW,EAAE;;CAGzC,SAAS,GAAiB,GAAQ,GAAS;AACvC,MAAI,GAAU;GACV,IAAM,IAAW,GAAG,IAAS,GAAS;AACtC,QAAK,IAAM,KAAO,EACd,CAAI,GAAO,GAAU,EAAI,IACrB,GAAe,EAAS,GAAK;AAGrC,OAAU,EAAS;;AAGvB,EADA,EAAU,MAAM,KAAU,GAC1B,EAAS,WAAW,EAAU;;CAGlC,SAAS,GAAmB,GAAQ,GAAS;AACzC,IAAU,MAAM,KAAU,EAAU,MAAM,MAAW,EAAE;EACvD,IAAM,IAAW,GAAG,IAAS,GAAS;AACtC,MAAI,QACK,IAAM,KAAO,EACd,CAAI,GAAO,GAAU,EAAI,IACrB,GAAe,EAAS,GAAK;AAMzC,EAFA,IAAU,EAAS,IACnB,GAAS,GAAS,EAAU,MAAM,GAAQ,EAC1C,EAAS,WAAW,EAAU;;CAGlC,SAAS,GAAkB,GAAQ;AAC/B,SAAO,EAAiB,MAAM,MAAW,EAAE;;CAG/C,SAAS,GAAkB,GAAQ,GAAQ;AAGvC,EAFA,EAAiB,MAAM,KAAU,GACjC,EAAS,kBAAkB,EAAiB,OAC5C,GAAoB,GAAU,GAAQ,EAAO;;CAGjD,SAAS,GAAoB,GAAQ,GAAQ;AAGzC,EAFA,EAAiB,MAAM,KAAU,GAAO,EAAiB,MAAM,MAAW,EAAE,EAAE,EAAO,EACrF,EAAS,kBAAkB,EAAiB,OAC5C,GAAoB,GAAU,GAAQ,EAAO;;CAGjD,SAAS,GAAgB,GAAQ;AAC7B,SAAO,EAAe,MAAM,MAAW,EAAE;;CAG7C,SAAS,GAAgB,GAAQ,GAAQ;AAGrC,EAFA,EAAe,MAAM,KAAU,GAC/B,EAAS,gBAAgB,EAAe,OACxC,GAAkB,GAAU,GAAQ,EAAO;;CAG/C,SAAS,GAAkB,GAAQ,GAAQ;AAGvC,EAFA,EAAe,MAAM,KAAU,GAAO,EAAe,MAAM,MAAW,EAAE,EAAE,EAAO,EACjF,EAAS,gBAAgB,EAAe,OACxC,GAAkB,GAAU,GAAQ,EAAO;;AAK/C,CAFA,MAEI,KAAU,OACV,GAAM,EAAO,SAAS,MAAQ;AAC1B,EAAI,MACA,EAAQ,QAAQ,GAChB,EAAS,SAAS,GAClB,GAAqB,GAAU,EAAQ,OAAO,EAAgB,MAAM;GAE1E,EACF,GAAM,EAAO,iBAAiB,MAAQ;AAClC,EAAI,MACA,EAAgB,QAAQ,GACxB,EAAS,iBAAiB,GAC1B,GAAqB,GAAU,EAAQ,OAAO,EAAgB,MAAM;GAE1E;CAGN,IAAM,IAAW;EACb,IAAI;EACJ;EACA;EACA,IAAI,gBAAgB;AAChB,UAAO;;EAEX,IAAI,cAAc,GAAK;AAEnB,GADA,IAAiB,GACb,KAAO,MACP,EAAQ,QAAQ,EAAO,OAAO,OAC9B,EAAgB,QAAQ,EAAO,eAAe,OAC9C,GAAqB,GAAU,EAAQ,OAAO,EAAgB,MAAM;;EAG5E,IAAI,mBAAmB;AACnB,UAAO,OAAO,KAAK,EAAU,MAAM,CAAC,MAAM;;EAE9C;EACA,IAAI,YAAY;AACZ,UAAO;;EAEX,IAAI,cAAc;AACd,UAAO,KAAgB,EAAE;;EAE7B,IAAI,WAAW;AACX,UAAO;;EAEX,IAAI,cAAc;AACd,UAAO;;EAEX,IAAI,YAAY,GAAK;AAEjB,GADA,IAAe,GACf,EAAS,cAAc;;EAE3B,IAAI,eAAe;AACf,UAAO;;EAEX,IAAI,aAAa,GAAK;AAElB,GADA,IAAgB,GAChB,EAAS,eAAe;;EAE5B,IAAI,eAAe;AACf,UAAO;;EAEX,IAAI,aAAa,GAAK;AAClB,OAAgB;;EAEpB,IAAI,iBAAiB;AACjB,UAAO;;EAEX,IAAI,eAAe,GAAK;AAEpB,GADA,IAAkB,GAClB,EAAS,iBAAiB;;EAE9B,IAAI,kBAAkB;AAClB,UAAO;;EAEX,IAAI,gBAAgB,GAAK;AAErB,GADA,IAAmB,GACnB,EAAS,kBAAkB;;EAE/B,IAAI,kBAAkB;AAClB,UAAO;;EAEX,IAAI,gBAAgB,GAAK;AAErB,GADA,IAAmB,GACnB,EAAS,kBAAkB;;EAE/B;EACA;EACA;EACA;EACA;EACA;EACA;EACA;GACC,MAAuB;EAC3B;AA6BD,QA3BI,EAAS,kBAAkB,GAC3B,EAAS,gBAAgB,GACzB,EAAS,KAAK,GACd,EAAS,KAAK,IACd,EAAS,KAAK,IACd,EAAS,IAAI,GACb,EAAS,IAAI,IACb,EAAS,oBAAoB,IAC7B,EAAS,oBAAoB,IAC7B,EAAS,sBAAsB,IAC/B,EAAS,kBAAkB,IAC3B,EAAS,kBAAkB,IAC3B,EAAS,oBAAoB,IAC7B,EAAS,MAA0B,GACnC,EAAS,MAAwB,GACjC,EAAS,MAAuB,IAChC,EAAS,MAAqB,IAGlC,QAAA,IAAA,aAA8B,iBAC1B,EAAS,OAAkB,MAAY;AACnC,IAAS,cAAc;IAE3B,EAAS,YAAwB;AAC7B,IAAS,cAAc,KAAA;KAGxB;;AAgBX,IAAI;AAqUJ,SAAS,GAAiB,GAAO,GAAS;AACtC,KAAI,IAAa;EACb,IAAI;AAKJ,EAJI,KAAW,aAAa,MACxB,IAAU,EAAQ,SAClB,OAAO,EAAQ,UAEnB,GAAY,iBAAiB;GACzB,SAAS;GACT,OAAO;IACH,OAAO;IACP;IACA,MAAM,KAAK,KAAK;IAChB,MAAM,EAAE;IACR,MAAM,KAAW,EAAE;IACnB,SAAS,MAAU,kBACb,UACA,MAAU,cAAc,MAAU,YAC9B,YACA;IACb;GACJ,CAAC;;;AAwbV,IAAM,KAAkB;CACpB,KAAK,EACD,MAAM,CAAC,QAAQ,OAAO,EACzB;CACD,QAAQ,EACJ,MAAM,QACT;CACD,OAAO;EACH,MAAM;EAEN,YAAY,MAAiC,MAAQ,YAAY,MAAQ;EACzE,SAAS;EACZ;CACD,MAAM,EACF,MAAM,QACT;CACJ;AAqCU,GAAO;CACV,SAAS;EACL,MAAM;EACN,UAAU;EACb;CACD,QAAQ;EACJ,MAAM,CAAC,QAAQ,OAAO;EACtB,YAAY,MAAQ,EAAS,EAAI,IAAI,CAAC,MAAM,EAAI;EACnD;CACJ,EAAE,GAAgB,EA8IZ,GAAO;CACV,OAAO;EACH,MAAM;EACN,UAAU;EACb;CACD,QAAQ,EACJ,MAAM,CAAC,QAAQ,OAAO,EACzB;CACJ,EAAE,GAAgB;AAwKvB,IAAM,MACS,mBAAW,kBAAkB;AA0G5C,SAAS,IAAQ,IAAU,EAAE,EAAE;CAC3B,IAAM,IAAWA,IAAoB;AACrC,KAAI,KAAY,KACZ,OAAM,GAAgB,EAAe,uBAAuB;AAEhE,KAAI,CAAC,EAAS,QACV,EAAS,WAAW,OAAO,QAC3B,CAAC,EAAS,WAAW,IAAI,oBACzB,OAAM,GAAgB,EAAe,cAAc;CAEvD,IAAM,IAAO,IAAgB,EAAS,EAChC,IAAK,IAAkB,EAAK,EAC5B,IAAmB,IAAoB,EAAS,EAChD,IAAQ,IAAS,GAAS,EAAiB;AACjD,KAAI,MAAU,SAEV,QADA,IAAoB,GAAI,GAAS,EAAiB,EAC3C;AAEX,KAAI,MAAU,UAAU;EAEpB,IAAI,IAAW,IAAY,GAAM,GAAU,EAAQ,eAAe;AAOlE,SANA,AAII,OAHA,QAAA,IAAA,aAA8B,gBAC1B,GAAK,GAAe,GAAc,uBAAuB,CAAC,EAEnD,IAER;;CAEX,IAAM,IAAe,GACjB,IAAW,EAAa,cAAc,EAAS;AACnD,KAAI,KAAY,MAAM;EAClB,IAAM,IAAkB,GAAO,EAAE,EAAE,EAAQ;AAa3C,EAZI,YAAY,MACZ,EAAgB,SAAS,EAAiB,SAE1C,MACA,EAAgB,SAAS,IAE7B,IAAW,IAAe,EAAgB,EACtC,EAAa,qBACb,EAAS,MACL,EAAa,iBAAiB,EAAS,GAE/C,IAAe,GAAc,GAAU,EAAS,EAChD,EAAa,cAAc,GAAU,EAAS;iCAGhB,gBAAiB,MAAU,WACrD,GAAK,GAAe,GAAc,2BAA2B,CAAC;AAGtE,QAAO;;AAYX,SAAS,IAAgB,GAAU;CAC/B,IAAM,IAAO,EAAQ,EAAS,OAExB,MADA,EAAS,WAAW,IAAI,oBACP;;AAEvB,KAAI,CAAC,EACD,OAAM,GAAiB,EAAS,OAE1B,EAAe,6BADf,EAAe,iBAC2B;AAEpD,QAAO;;AAGX,SAAS,IAAS,GAAS,GAAkB;AAEzC,QAAO,GAAc,EAAQ,GACtB,YAAY,IACT,UACA,WACH,EAAQ,WAEL,EAAQ,WADR;;AAGd,SAAS,IAAkB,GAAM;AAE7B,QAAO,EAAK,SAAS,gBACf,EAAK,SACL,EAAK,OAAO;;AAEtB,SAAS,IAAY,GAAM,GAAQ,IAAe,IAAO;CACrD,IAAI,IAAW,MACT,IAAO,EAAO,MAChB,IAAU,IAA2B,GAAQ,EAAa;AAC9D,QAAO,KAAW,OAAM;EACpB,IAAM,IAAe;AACrB,MAAI,EAAK,SAAS,cACd,KAAW,EAAa,cAAc,EAAQ;WAG1C,yBAAyB;GACzB,IAAM,IAAU,EAAa,cAAc,EAAQ;AACnD,GAAI,KAAW,SACX,IAAW,EACN,YACD,KACA,KACA,CAAC,EAAS,QAEV,IAAW;;AAQ3B,MAHI,KAAY,QAGZ,MAAS,EACT;AAEJ,MAAU,EAAQ;;AAEtB,QAAO;;AAEX,SAAS,IAA2B,GAAQ,IAAe,IAAO;AAK9D,QAJI,KAAU,OACH,OAGH,KAEF,EAAO,MAAM,OADb,EAAO;;AAGjB,SAAS,IAAe,GAAM,GAAQ,GAAU;CAC5C,IAAI,IAAU;AAYd,CAXA,QAAgB;AAEZ,MAAA,QAAA,IAAA,aAA+B,cAAmD;AAE9E,GADA,EAAO,eAAe,GACtB,IAAU,KAAe;GAEzB,IAAM,IAAY;AAElB,GADA,EAAU,OAAkB,EAAU,IAAe,EAAQ,EAC7D,EAAQ,GAAG,KAAK,GAAiB;;IAEtC,EAAO,EACV,QAAkB;EAEd,IAAM,IAAY;AAOlB,EALA,QAAA,IAAA,aAA+B,iBAC3B,KAAW,EAAQ,IAAI,KAAK,GAAiB,EAC7C,EAAU,OAAmB,EAAU,KAAiB,EACxD,OAAO,EAAO,eAElB,EAAK,iBAAiB,EAAO;EAE7B,IAAM,IAAU,EAAU;AAC1B,EAAI,MACA,GAAS,EACT,OAAO,EAAU;IAEtB,EAAO;;AA2Gd,IApDW,GAAO;CACV,OAAO;EACH,MAAM,CAAC,QAAQ,KAAK;EACpB,UAAU;EACb;CACD,QAAQ,EACJ,MAAM,CAAC,QAAQ,OAAO,EACzB;CACJ,EAAE,GAAgB,EAmCnB,KAAkB,EAGtB,IAAwB,IAAQ,EAEhC,IAAwB,IAAa,EAErC,IAAyB,GAAwB,EAEjD,QAAA,IAAA,aAA8B,gBAAiB,2BAA2B;CACtE,IAAM,IAAS,IAAe;AAE9B,CADA,EAAO,cAAc,IACrB,IAAgB,EAAO,iCAAiC;;AAE5D,QAAA,IAAA;;;AC93EA,IAAK,KAAL,yBAAA,GAAA;QACE,EAAA,UAAA,YACA,EAAA,MAAA,OACA,EAAA,WAAA,aACA,EAAA,QAAA,SACA,EAAA,cAAA,gBACA,EAAA,SAAA,UACA,EAAA,aAAA,eACA,EAAA,OAAA;EARG,MAAA,EAAA,CASJ,oGCsDK,KAAgB,KAChB,KAAiB;;;;;;;;;;;;;;;;;;;;;;;EAnBvB,IAAM,EAAE,SAAM,IAAQ,EAAE,CAAA,EAElB,IAAQ,GAOR,IAAO,GAIP,IAAS,EAA8B,KAAI,EAC7C,IAAuC,MACrC,IAAM,IAAI,OAAM,EAClB,IAAgC,MAIhC,IAAQ;GAAE,GAAG;GAAG,GAAG;GAAE,EAEnB,IAAW,EAAe;GAAE,GAAG;GAAI,GAAG;GAAI,OAAO;GAAK,QAAQ;GAAK,CAAA,EACnE,IAAkB,EAAmB,KAAI,EACzC,IAAe,EAAsB,KAAI,EAE3C,IAAa,IACb,KAAiB,IACjB,KAAY;GAAE,GAAG;GAAG,GAAG;GAAE,EAEzB,IAAa,IACb,KAAc;GAAE,GAAG;GAAG,GAAG;GAAE,EAC3B,IAAkB;GAAE,GAAG;GAAG,GAAG;GAAG,OAAO;GAAG,QAAQ;GAAE,EACpD,IAAoC,MACpC,IAAiB,IAEf,KAAwC;GAC5C,EAAE,MAAM,GAAY,SAAS;GAC7B,EAAE,MAAM,GAAY,KAAK;GACzB,EAAE,MAAM,GAAY,UAAU;GAC9B,EAAE,MAAM,GAAY,OAAO;GAC3B,EAAE,MAAM,GAAY,aAAa;GACjC,EAAE,MAAM,GAAY,QAAQ;GAC5B,EAAE,MAAM,GAAY,YAAY;GAChC,EAAE,MAAM,GAAY,MAAM;GAC5B,EAEM,UAAkB;AACtB,OAAI,CAAC,EAAM,OAAO;AAChB,YAAQ,MAAM,yBAAwB;AACtC;;AAiDF,GA9CA,AAEE,OADA,IAAI,gBAAgB,EAAc,EACjB,OAGnB,EAAI,eAAe;IACjB,IAAM,EAAE,cAAW,kBAAe,IAAe;AAEjD,QAAI,EAAO,OAAO;AAGhB,KADA,EAAO,MAAM,QAAQ,GACrB,EAAO,MAAM,SAAS;KAEtB,IAAM,KAAW,EAAO,MAAM,QAAQ,EAAI,QAAQ,EAAM,KAAK,GACvD,KAAW,EAAO,MAAM,SAAS,EAAI,SAAS,EAAM,KAAK;AAG/D,SAAI,EAAM,gBAAgB,EAAM,iBAAiB;MAE/C,IAAM,IADe,KAAK,IAAI,EAAI,QAAQ,EAAM,GAAG,EAAI,SAAS,EAAM,EAAC,GAChC;AACvC,QAAS,QAAQ;OACf,GAAG,KAAW,EAAI,QAAQ,EAAM,IAAI,KAAmB;OACvD,GAAG,KAAW,EAAI,SAAS,EAAM,IAAI,KAAmB;OACxD,OAAO;OACP,QAAQ;OACV;WAGA,GAAS,QAAQ;MACf,GAAG,KAAW,EAAI,QAAQ,EAAM,IAAI,KAAM,EAAI,QAAQ,EAAM,IAAI;MAChE,GACE,KACC,EAAI,SAAS,EAAM,IAAI,KAAM,EAAI,SAAS,EAAM,IAAI;MACvD,OAAO,EAAI,QAAQ,EAAM,IAAI;MAC7B,QAAQ,EAAI,SAAS,EAAM,IAAI;MACjC;AAIF,KADA,GAAU,EACV,IAAU;;MAGd,EAAI,gBAAgB;AAClB,YAAQ,MAAM,uBAAsB;MAEtC,IAAiB,IAAI,gBAAgB,EAAM,MAAK,EAChD,EAAI,MAAM;;AAuCZ,EApCA,QAAgB;AACd,GAAI,EAAO,UACT,IAAM,EAAO,MAAM,WAAW,KAAI,EAC9B,MAEF,EAAI,wBAAwB,IAC5B,EAAI,wBAAwB,SAE1B,EAAM,SACR,GAAU;IAGf,EAED,QAAsB;AACpB,GAEE,OADA,IAAI,gBAAgB,EAAc,EACjB;GAEnB,IAAM,IAAoB,EAAgB;AAC1C,GAAI,MACF,IAAI,gBAAgB,EAAiB,EACrC,EAAgB,QAAQ;IAE3B,EAED,SACQ,EAAM,QACX,MAAa;AACZ,GAAI,KACF,GAAU;IAGhB,EAGA,SACQ;GAAC,EAAM;GAAc,EAAM;GAAgB,EAAM;GAAgB,QACjE;AACJ,GAAI,EAAO,SAAS,KAElB,GAAU;IAGhB;EAEA,IAAM,WAAuB;GAC3B,IAAM,IAAc,EAAI,QAAQ,EAAI,QAChC,IAAY,IACZ,IAAa;AAUjB,UARI,IAAc,KAAgB,KAChC,IAAa,KAAgB,IAE7B,IAAY,KAAiB,GAG/B,EAAM,IAAI,IAAY,EAAI,OAC1B,EAAM,IAAI,IAAa,EAAI,QACpB;IAAE;IAAW;IAAW;KAG3B,UAAkB;AACtB,OAAI,KAAO,EAAO,OAAO;AACvB,MAAI,UAAU,GAAG,GAAG,EAAO,MAAM,OAAO,EAAO,MAAM,OAAM;IAE3D,IAAM,KAAW,EAAO,MAAM,QAAQ,EAAI,QAAQ,EAAM,KAAK,GACvD,KAAW,EAAO,MAAM,SAAS,EAAI,SAAS,EAAM,KAAK;AAY/D,IAXA,EAAI,UACF,GACA,GACA,GACA,EAAI,OACJ,EAAI,QACJ,GACA,GACA,EAAI,QAAQ,EAAM,GAClB,EAAI,SAAS,EAAM,EACrB,EACA,GAAY;;KAIV,UAAoB;AACxB,GAAI,KAAO,EAAO,UAChB,EAAI,MAAK,EAGT,EAAI,WAAU,EACV,EAAM,eACR,EAAI,IACF,EAAS,MAAM,IAAI,EAAS,MAAM,QAAQ,GAC1C,EAAS,MAAM,IAAI,EAAS,MAAM,SAAS,GAC3C,EAAS,MAAM,QAAQ,GACvB,GACA,KAAK,KAAK,EACZ,GAEA,EAAI,KACF,EAAS,MAAM,GACf,EAAS,MAAM,GACf,EAAS,MAAM,OACf,EAAS,MAAM,OACjB,EAEF,EAAI,KAAK,GAAG,GAAG,EAAO,MAAM,OAAO,EAAO,MAAM,OAAM,EACtD,EAAI,KAAK,UAAS,EAClB,EAAI,YAAY,sBAChB,EAAI,SAAS,GAAG,GAAG,EAAO,MAAM,OAAO,EAAO,MAAM,OAAM,EAG1D,EAAI,SAAQ,EACZ,EAAI,MAAK,EACT,EAAI,cAAc,4BAClB,EAAI,YAAY,GAChB,EAAI,YAAY,CAAC,GAAG,EAAE,CAAA,EAEtB,EAAI,wBAAwB,IAExB,EAAM,gBACR,EAAI,WAAU,EACd,EAAI,IACF,EAAS,MAAM,IAAI,EAAS,MAAM,QAAQ,GAC1C,EAAS,MAAM,IAAI,EAAS,MAAM,SAAS,GAC3C,EAAS,MAAM,QAAQ,GACvB,GACA,KAAK,KAAK,EACZ,EACA,EAAI,QAAO,IAEX,EAAI,WACF,EAAS,MAAM,GACf,EAAS,MAAM,GACf,EAAS,MAAM,OACf,EAAS,MAAM,OACjB,EAGF,EAAI,SAAQ;KAKV,KAAkB,QAEhB;AACN,OAAI,EAAM,cAAc;IAEtB,IAAM,IAAU,EAAS,MAAM,IAAI,EAAS,MAAM,QAAQ,GACpD,IAAU,EAAS,MAAM,IAAI,EAAS,MAAM,SAAS,GACrD,IAAS,EAAS,MAAM,QAAQ;AAEtC,WAAO;KACL,YAAY;MACV,MAAM,GAAG,IAAU,IAAS,EAAE;MAC9B,KAAK,GAAG,IAAU,IAAS,EAAE;MAC9B;KACD,KAAK;MAAE,MAAM,GAAG,IAAU,EAAE;MAAK,KAAK,GAAG,IAAU,IAAS,EAAE;MAAK;KACnE,aAAa;MACX,MAAM,GAAG,IAAU,IAAS,EAAE;MAC9B,KAAK,GAAG,IAAU,IAAS,EAAE;MAC9B;KACD,OAAO;MAAE,MAAM,GAAG,IAAU,IAAS,EAAE;MAAK,KAAK,GAAG,IAAU,EAAE;MAAK;KACrE,gBAAgB;MACd,MAAM,GAAG,IAAU,IAAS,EAAE;MAC9B,KAAK,GAAG,IAAU,IAAS,EAAE;MAC9B;KACD,QAAQ;MAAE,MAAM,GAAG,IAAU,EAAE;MAAK,KAAK,GAAG,IAAU,IAAS,EAAE;MAAK;KACtE,eAAe;MACb,MAAM,GAAG,IAAU,IAAS,EAAE;MAC9B,KAAK,GAAG,IAAU,IAAS,EAAE;MAC9B;KACD,MAAM;MAAE,MAAM,GAAG,IAAU,IAAS,EAAE;MAAK,KAAK,GAAG,IAAU,EAAE;MAAK;KACtE;SAGA,QAAO;IACL,YAAY;KACV,MAAM,GAAG,EAAS,MAAM,IAAI,EAAE;KAC9B,KAAK,GAAG,EAAS,MAAM,IAAI,EAAE;KAC9B;IACD,KAAK;KACH,MAAM,GAAG,EAAS,MAAM,IAAI,EAAS,MAAM,QAAQ,IAAI,EAAE;KACzD,KAAK,GAAG,EAAS,MAAM,IAAI,EAAE;KAC9B;IACD,aAAa;KACX,MAAM,GAAG,EAAS,MAAM,IAAI,EAAS,MAAM,QAAQ,EAAE;KACrD,KAAK,GAAG,EAAS,MAAM,IAAI,EAAE;KAC9B;IACD,OAAO;KACL,MAAM,GAAG,EAAS,MAAM,IAAI,EAAS,MAAM,QAAQ,EAAE;KACrD,KAAK,GAAG,EAAS,MAAM,IAAI,EAAS,MAAM,SAAS,IAAI,EAAE;KAC1D;IACD,gBAAgB;KACd,MAAM,GAAG,EAAS,MAAM,IAAI,EAAS,MAAM,QAAQ,EAAE;KACrD,KAAK,GAAG,EAAS,MAAM,IAAI,EAAS,MAAM,SAAS,EAAE;KACtD;IACD,QAAQ;KACN,MAAM,GAAG,EAAS,MAAM,IAAI,EAAS,MAAM,QAAQ,IAAI,EAAE;KACzD,KAAK,GAAG,EAAS,MAAM,IAAI,EAAS,MAAM,SAAS,EAAE;KACtD;IACD,eAAe;KACb,MAAM,GAAG,EAAS,MAAM,IAAI,EAAE;KAC9B,KAAK,GAAG,EAAS,MAAM,IAAI,EAAS,MAAM,SAAS,EAAE;KACtD;IACD,MAAM;KACJ,MAAM,GAAG,EAAS,MAAM,IAAI,EAAE;KAC9B,KAAK,GAAG,EAAS,MAAM,IAAI,EAAS,MAAM,SAAS,IAAI,EAAE;KAC1D;IACH;IAEH,EAEK,MAAwB,MAAmC;AAC/D,OAAI,aAAa,KAAS,EAAM,QAAQ,SAAS,GAAG;IAClD,IAAM,IAAQ,EAAM,QAAQ;AAC5B,WAAO;KAAE,SAAS,EAAM;KAAS,SAAS,EAAM;KAAQ;cAC/C,aAAa,KAAS,aAAa,EAC5C,QAAO;IAAE,SAAS,EAAM;IAAS,SAAS,EAAM;IAAQ;AAE1D,UAAO;IAAE,SAAS;IAAG,SAAS;IAAE;KAG5B,MAAkB,MAAmC;GACzD,IAAM,IAAW,EAAO;AACxB,OAAI,CAAC,EAAU,QAAO;GACtB,IAAM,EAAE,YAAS,eAAY,GAAqB,EAAK,EACjD,EAAE,SAAM,WAAQ,EAAS,uBAAsB;AACrD,UAAO;IAAE,GAAG,IAAU;IAAM,GAAG,IAAU;IAAI;KAGzC,MAAqB,MAAmC;AAC5D,KAAM,gBAAe;GACrB,IAAM,IAAQ,GAAe,EAAK;AAClC,OAAI,CAAC,EAAO;GACZ,IAAM,EAAE,MAAG,SAAM;AACjB,GAAI,GAAa,GAAG,EAAE,KACpB,KAAiB,IACjB,IAAa,IACb,KAAY;IAAE,GAAG,IAAI,EAAS,MAAM;IAAG,GAAG,IAAI,EAAS,MAAM;IAAE;KAI7D,KAAe,MAAmC;AACtD,GAAI,KACF,GAAO,EAAK,GACH,KACT,GAAS,EAAK;KAIZ,WAAkB;AAYtB,GAXI,OACF,IAAQ,EACR,KAAiB,IACjB,IAAU,GAER,MACF,IAAU,EACV,IAAU,GAGZ,IAAa,IACb,KAAiB;KAGb,MAAU,MAAmC;AACjD,OAAI,GAAY;IACd,IAAM,IAAQ,GAAe,EAAK;AAClC,QAAI,CAAC,EAAO;IACZ,IAAM,EAAE,MAAG,SAAM;AAMjB,IAHA,EAAS,MAAM,IAAI,KAAK,MAAM,IAAI,GAAU,EAAC,EAC7C,EAAS,MAAM,IAAI,KAAK,MAAM,IAAI,GAAU,EAAC,EAE7C,GAAU;;KAIR,WAAgB;AACpB,GAIE,OAFA,IAAkB,EAClB,GAAU,EACG;KAIX,MACJ,GACA,MACG;AACH,KAAM,gBAAe;GACrB,IAAM,IAAQ,GAAe,EAAK;AAC7B,SACL,IAAa,IACb,IAAgB,GAChB,KAAc;IAAE,GAAG,EAAM;IAAG,GAAG,EAAM;IAAE,EACvC,IAAkB,EAAE,GAAG,EAAS,OAAM,EACtC,IAAiB,aAAiB,cAAc,EAAM;KAGlD,MAAY,MAAmC;AACnD,OAAI,CAAC,EAAY;AAGjB,OAAI,EAAM,mBAAmB,EAAO,OAAO;IACzC,IAAM,IAAQ,GAAe,EAAK;AAClC,QAAI,CAAC,EAAO;IACZ,IAAM,EAAE,MAAG,SAAM,GACX,IAAU,EAAgB,IAAI,EAAgB,QAAQ,GACtD,IAAU,EAAgB,IAAI,EAAgB,SAAS;AAE7D,QAAI,EAAM,cAAc;KAEtB,IAAM,IAAW,KAAK,IAAI,KAAK,IAAI,IAAI,EAAQ,EAAE,KAAK,IAAI,IAAI,EAAQ,CAAA,EAChE,IAAU,IAAW;AAC3B,OAAS,QAAQ;MACf,GAAG,IAAU;MACb,GAAG,IAAU;MACb,OAAO;MACP,QAAQ;MACV;WACK;KAEL,IAAM,IAAc,EAAgB,QAAQ,EAAgB,QACtD,IAAK,KAAK,IAAI,IAAI,EAAO,EACzB,IAAW,KAAK,IAAI,IAAK,GAAG,GAAE,EAC9B,IAAY,IAAW;AAC7B,OAAS,QAAQ;MACf,GAAG,IAAU,IAAW;MACxB,GAAG,IAAU,IAAY;MACzB,OAAO;MACP,QAAQ;MACV;;AAGF,OAAU;AACV;;GAIF,IAAM,IAAQ,GAAe,EAAK;AAClC,OAAI,CAAC,EAAO;GACZ,IAAM,EAAE,MAAG,SAAM,GACX,IAAK,IAAI,GAAY,GACrB,IAAK,IAAI,GAAY;AAE3B,OAAiB,aAAiB,cAAc,EAAM;GAEtD,IAAM,IAAc,EAAE,GAAG,GAAgB;AAEzC,WAAQ,GAAR;IACE,KAAK;AAIH,KAHA,EAAY,KAAK,GACjB,EAAY,KAAK,GACjB,EAAY,SAAS,GACrB,EAAY,UAAU;AACtB;IACF,KAAK;AAEH,KADA,EAAY,KAAK,GACjB,EAAY,UAAU;AACtB;IACF,KAAK;AAGH,KAFA,EAAY,KAAK,GACjB,EAAY,SAAS,GACrB,EAAY,UAAU;AACtB;IACF,KAAK;AACH,OAAY,SAAS;AACrB;IACF,KAAK;AAEH,KADA,EAAY,SAAS,GACrB,EAAY,UAAU;AACtB;IACF,KAAK;AACH,OAAY,UAAU;AACtB;IACF,KAAK;AAGH,KAFA,EAAY,KAAK,GACjB,EAAY,SAAS,GACrB,EAAY,UAAU;AACtB;IACF,KAAK;AAEH,KADA,EAAY,KAAK,GACjB,EAAY,SAAS;AACrB;;AAOJ,OAHI,EAAY,QAAQ,OAAI,EAAY,QAAQ,KAC5C,EAAY,SAAS,OAAI,EAAY,SAAS,KAE9C,KAAkB,GAAe;IACnC,IAAM,IAAc,EAAgB,QAAQ,EAAgB;AAC5D,IAAI,CAAC,QAAQ,QAAQ,CAAC,SAAS,EAAc,IAC3C,EAAY,SAAS,EAAY,QAAQ,GACrC,MAAkB,WACpB,EAAY,IACV,EAAgB,KAAK,EAAY,SAAS,EAAgB,UAAU,MAE/D,CAAC,OAAO,SAAS,CAAC,SAAS,EAAc,KAClD,EAAY,QAAQ,EAAY,SAAS,GACrC,MAAkB,UACpB,EAAY,IACV,EAAgB,KAAK,EAAY,QAAQ,EAAgB,SAAS;;AAO1E,GAFA,EAAS,QAAQ,GAEjB,GAAU;KAGN,WAAkB;AACtB,GAAI,MAEF,IAAkB,EAClB,GAAU,EACV,IAAa,IACb,IAAgB;KAId,MAAgB,GAAW,MAAc;AAC7C,OAAI,EAAM,cAAc;IACtB,IAAM,IAAU,EAAS,MAAM,IAAI,EAAS,MAAM,QAAQ,GACpD,IAAU,EAAS,MAAM,IAAI,EAAS,MAAM,SAAS,GACrD,IAAS,EAAS,MAAM,QAAQ,GAChC,IAAK,IAAI,GACT,IAAK,IAAI;AACf,WAAO,IAAK,IAAK,IAAK,KAAM,IAAS;SAIrC,QACE,KAAK,EAAS,MAAM,IAAI,KACxB,KAAK,EAAS,MAAM,IAAI,EAAS,MAAM,QAAQ,KAC/C,KAAK,EAAS,MAAM,IAAI,KACxB,KAAK,EAAS,MAAM,IAAI,EAAS,MAAM,SAAS;KAKhD,WAA0B;GAC9B,IAAM,IAAO,EAAO,MAAO,OACrB,IAAO,EAAO,MAAO;AAO3B,OAJI,EAAS,MAAM,QAAQ,OAAI,EAAS,MAAM,QAAQ,KAClD,EAAS,MAAM,SAAS,OAAI,EAAS,MAAM,SAAS,KAGpD,EAAM,gBACR,KAAI,EAAM,aAER,GAAS,MAAM,SAAS,EAAS,MAAM;QAClC;IAEL,IAAM,IAAc,EAAgB,QAAQ,EAAgB;AAC5D,MAAS,MAAM,SAAS,EAAS,MAAM,QAAQ;;YAExC,GAAgB;IAEzB,IAAM,IAAc,EAAgB,QAAQ,EAAgB;AAC5D,MAAS,MAAM,SAAS,EAAS,MAAM,QAAQ;;AAIjD,OAAI,EAAM,gBAAgB,EAAM,iBAAiB;IAC/C,IAAM,IAAc,EAAS,MAAM,QAAQ,EAAS,MAAM;AAmB1D,KAhBI,EAAS,MAAM,QAAQ,KAAQ,EAAS,MAAM,SAAS,OACrD,EAAS,MAAM,QAAQ,EAAS,MAAM,UACxC,EAAS,MAAM,QAAQ,GACvB,EAAS,MAAM,SAAS,IAAO,MAE/B,EAAS,MAAM,SAAS,GACxB,EAAS,MAAM,QAAQ,IAAO,KAK9B,EAAS,MAAM,IAAI,MAAG,EAAS,MAAM,IAAI,IACzC,EAAS,MAAM,IAAI,MAAG,EAAS,MAAM,IAAI,IACzC,EAAS,MAAM,IAAI,EAAS,MAAM,QAAQ,MAC5C,EAAS,MAAM,IAAI,IAAO,EAAS,MAAM,QAEvC,EAAS,MAAM,IAAI,EAAS,MAAM,SAAS,MAC7C,EAAS,MAAM,IAAI,IAAO,EAAS,MAAM;SAsB3C,CAjBI,EAAS,MAAM,IAAI,MAAG,EAAS,MAAM,IAAI,IACzC,EAAS,MAAM,IAAI,MAAG,EAAS,MAAM,IAAI,IAGzC,EAAS,MAAM,QAAQ,MACzB,EAAS,MAAM,QAAQ,GACvB,EAAS,MAAM,IAAI,IAEjB,EAAS,MAAM,SAAS,MAC1B,EAAS,MAAM,SAAS,GACxB,EAAS,MAAM,IAAI,IAIjB,EAAS,MAAM,IAAI,EAAS,MAAM,QAAQ,MAC5C,EAAS,MAAM,IAAI,IAAO,EAAS,MAAM,QAEvC,EAAS,MAAM,IAAI,EAAS,MAAM,SAAS,MAC7C,EAAS,MAAM,IAAI,IAAO,EAAS,MAAM;KAKzC,WAAkB;AACtB,OAAI,EAAO,SAAS,GAAK;IACvB,IAAM,KAAW,EAAO,MAAM,QAAQ,EAAI,QAAQ,EAAM,KAAK,GACvD,KAAW,EAAO,MAAM,SAAS,EAAI,SAAS,EAAM,KAAK,GAEzD,KAAM,EAAS,MAAM,IAAI,KAAW,EAAM,GAC1C,KAAM,EAAS,MAAM,IAAI,KAAW,EAAM,GAC1C,IAAS,EAAS,MAAM,QAAQ,EAAM,GACtC,IAAU,EAAS,MAAM,SAAS,EAAM,GAExC,IAAW;KACf,GAAG,KAAK,MAAM,EAAG;KACjB,GAAG,KAAK,MAAM,EAAG;KACjB,OAAO,KAAK,MAAM,EAAO;KACzB,QAAQ,KAAK,MAAM,EAAQ;KAC7B,EAGM,IAAY,KAAK,IAAI,GAAG,KAAK,IAAI,EAAS,GAAG,EAAI,MAAM,CAAA,EACvD,IAAY,KAAK,IAAI,GAAG,KAAK,IAAI,EAAS,GAAG,EAAI,OAAO,CAAA,EACxD,IAAgB,KAAK,IAAI,EAAS,OAAO,EAAI,QAAQ,EAAS,EAC9D,IAAiB,KAAK,IAAI,EAAS,QAAQ,EAAI,SAAS,EAAS,EAEjE,IAAgB,SAAS,cAAc,SAAQ;AAErD,IADA,EAAc,QAAQ,GACtB,EAAc,SAAS;IACvB,IAAM,IAAa,EAAc,WAAW,KAAI;AAChD,IAAI,MACF,EAAW,UACT,GACA,GACA,GACA,GACA,GACA,GACA,GACA,GACA,EACF,EAEI,EAAM,gBAAgB,EAAM,mBAC9B,EAAW,2BAA2B,kBACtC,EAAW,WAAU,EACrB,EAAW,IACT,IAAgB,GAChB,IAAiB,GACjB,IAAgB,GAChB,GACA,KAAK,KAAK,EACZ,EACA,EAAW,WAAU,EACrB,EAAW,MAAK,EAChB,EAAW,2BAA2B,gBAIxC,EAAc,QACX,MAAS;AACR,SAAI,GAAM;MACR,IAAM,IAAgB,EAAgB;AAMtC,MALI,KACF,IAAI,gBAAgB,EAAa,EAEnC,EAAgB,QAAQ,IAAI,gBAAgB,EAAI,EAChD,EAAa,QAAQ,GACrB,EAAK,QAAQ;OAAE;OAAM;OAAU,CAAA;;OAGnC,cACA,GACF;;;SAKN,SACQ,SACA;AACJ,OAAU;KAEZ,EAAE,MAAM,IAAM,CAChB;;eAlvBE,EA2CM,OA3CN,KA2CM,CA1CJ,EAmBM,OAAA;IAlBJ,OAAM;IACL,aAAW;IACX,aAAW;IACX,WAAS;IACT,cAAY;IACZ,cAAY;IACZ,aAAW;IACX,YAAU;OAEX,EAA8B,UAAA;aAAlB;IAAJ,KAAI;wBACZ,EAOO,GAAA,MAAA,EANY,KAAV,MADT,EAOO,OAAA;IALJ,KAAK,EAAO;IACZ,OAAK,EAAA,CAAA,iBAAoB,EAAO,KAAI,CAAA;IACpC,OAAK,EAAE,GAAA,MAAgB,EAAO,MAAI;IAClC,aAAS,GAAA,MAAO,GAAY,GAAQ,EAAO,KAAI,EAAA,CAAA,OAAA,CAAA;IAC/C,cAAU,GAAA,MAAO,GAAY,GAAQ,EAAO,KAAI,EAAA,CAAA,OAAA,CAAA;mCAI7C,EAAA,eAAe,EAAA,SAAmB,EAAA,SAAA,GAAA,EAD1C,EAqBS,GAAA;;IAnBP,OAAM;;qBAiBG,CAfT,EAeS,GAAA;KAfD,IAAG;KAAK,KAAI;KAAM,SAAQ;KAAS,KAAI;;sBAGxC;MAFL,EAEK,MAAA,MAAA,CADH,EAAoC,UAAA,MAAA,EAAzB,EAAA,EAAC,CAAA,WAAA,CAAA,EAAA,EAAA,EAAA,EAAwB,MAAC,EAAG,EAAA,MAAa,EAAE,QAAO,EAAA,CAAA,EAAA,EAAA,CAAA,CAAA;MAEhE,EAEK,MAAA,MAAA,CADH,EAAoC,UAAA,MAAA,EAAzB,EAAA,EAAC,CAAA,WAAA,CAAA,EAAA,EAAA,EAAA,EAAwB,MAAC,EAAG,EAAA,MAAa,EAAE,QAAO,EAAA,CAAA,EAAA,EAAA,CAAA,CAAA;MAEhE,EAGK,MAAA,MAAA,CAFH,EAAwC,UAAA,MAAA,EAA7B,EAAA,EAAC,CAAA,eAAA,CAAA,EAAA,EAAA,EAAA,EAA4B,MACxC,EAAG,EAAA,MAAa,MAAM,QAAO,EAAA,CAAA,EAAA,EAAA,CAAA,CAAA;MAE/B,EAGK,MAAA,MAAA,CAFH,EAAyC,UAAA,MAAA,EAA9B,EAAA,EAAC,CAAA,gBAAA,CAAA,EAAA,EAAA,EAAA,EAA6B,MACzC,EAAG,EAAA,MAAa,OAAO,QAAO,EAAA,CAAA,EAAA,EAAA,CAAA,CAAA;;;QAGlC,EAAiE,OAAA;KAA3D,KAAK,EAAA;KAAkB,KAAK,EAAA,EAAC,CAAA,yBAAA;;;;;;;;;;;;qBEenC,MAAa;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAEnB,IAAM,IAAQ,GAQR,IAAO,GAEP,IAAa,EAAS;GAC1B,MAAM;AACJ,WAAO,EAAM;;GAEf,IAAI,GAAO;AACT,IAAI,EAAM,YACR,EAAK,qBAAqB,EAAK;;GAGpC,CAAA,EAGK,IAAW,EAAI,EAAM,eAAc,EACnC,IAAc,EAAI,GAAK,EACvB,IAAO,EAAI;GACf,YAAY;GACZ,WAAW;GACX,WAAW;GACX,WAAW;GACX,UAAU;GACV,SAAS;GACT,UAAU;GACV,SAAS;GACV,CAAA,EAGK,IAAU,SACP;GACL,gBAAgB;GAChB,MAAM,EAAO,EAAW,MAAM;GAC9B,MAAM,CAAC,EAAO,EAAW,MAAM;GAC/B,MAAM,EAAM;GACd,EACD,EAEK,IAAiB,SACd;GACL,SAAS;GACT,MAAM,EAAO,EAAW,MAAM;GAC9B,SAAS,CAAC,EAAS;GACnB,QAAQ,EAAS;GACnB,EACD,EAGK,UAAwB,EAAS,QAAQ,CAAC,EAAS,OACnD,KAAU,MACd,aAAiB,UAAU,MAAM,QAAQ,EAAK,EAC1C,KAAW,MAAsB,MAAM,QAAQ,EAAK,EACpD,KAAU,MAAsB,MAAU,MAC1C,KAAa,MACjB,OAAO,KAAU,WACb,KAAe,MAClB,KAA6C,EAAC;;;eAzH/C,EAiDM,OAAA,EAjDA,OAAK,EAAE,EAAA,MAAO,EAAA,EAAA,CAClB,EAAuD,OAAA;IAAjD,OAAK,EAAE,EAAA,MAAc;IAAG,SAAO;gBACrC,EA8CM,OAAA,EA9CD,OAAK,EAAA,CAAC,WAAS;IAAA,UAAqB,EAAA;IAAQ,QAAU,EAAA;IAAW,CAAA,CAAA,EAAA,EAAA;IACpE,EASM,OAAA,EATD,OAAK,EAAA,CAAC,SAAO,EAAA,QAAmB,EAAA,OAAW,CAAA,CAAA,EAAA,EAAA,CAAA,EAAA,EAC3C,EAAA,MAAK,GAAG,KACX,EAAA,EAAY,EAAO,EAAA,MAAU,IAAA,GAAA,EAA7B,EAMO,QANP,KAMO,EAJH,EAAQ,EAAA,MAAU,GAAA,KAAuB,EAAA,MAAW,OAAM,YAAA,KAAgC,EAAA,SAAU,OAAW,EAAA,SAAU,WAAgB,OAAO,KAAK,EAAA,MAAU,CAAE,SAAM,EAAA,eAAA,EAAA,EAAA,IAAA,EAAA,IAAA,GAAA,CAAA,EAAA,EAAA;IAMjK,EAAO,EAAA,MAAU,gBAAA,GAAA,EAA7B,EAsBM,OAtBN,KAsBM;KApBK,EAAU,EAAA,MAAU,GACP,EAAA,IAAA,GAAA,GADO,GAAA,GAAA,EAD7B,EAOO,QAAA;;MAJJ,OAAK,EAAA;OAAA,OAAA;OAAA,eAAgC,EAAO,EAAA,MAAU;OAAA,CAAA;MACtD,YAAQ,AAAA,EAAA,aAAS,EAAA,QAAc,EAAA;UAE7B,EAAO,EAAA,MAAU,GAAI,MAAa,EAAA,MAAU,EAAA,GAAA,GAAA,CAAA,CAAA,IAAA,CAJtC,EAAA,MAAW,CAAA,CAAA;MAOb,EAAU,EAAA,MAAU,IAAK,EAAA,QAAA,GAAA,GAAA,EADlC,EAKE,SAAA;;+CAHmB,QAAA;MAClB,SAAK,AAAA,EAAA,OAAA,SAAe,EAAA,QAAW,IAAA,CAAA,QAAA,CAAA;MAC/B,QAAI,AAAA,EAAA,aAAS,EAAA,QAAW;0BAFhB,EAAA,MAAU,CAAA,CAAA,GAAA,EAAA,IAAA,GAAA;KAKb,EAAU,EAAA,MAAU,IAAA,GAAA,EAD5B,EAKC,QAAA;;MAHC,OAAM;MACL,SAAK,AAAA,EAAA,aAAS,EAAA,QAAU,CAAI,EAAA;UACxB,EAAA,QAA6B,EAAA,MAAK,UAArB,EAAA,MAAK,SAAuB,EAAA,EAAA,IAAA,EAAA,IAAA,GAAA;cAEhD,EAAwB,OAAA,EAAnB,OAAM,YAAU,EAAA,MAAA,GAAA;;IAEZ,EAAA,SAAc,EAAO,EAAA,MAAU,IAAA,GAAA,EAA1C,EAWM,OAAA,KAAA,EAAA,EAAA,GAAA,EAVJ,EASE,GAAA,MAAA,EARwB,EAAA,QAAhB,GAAG,YADb,EASE,GAAA;KAPC,KAAK;iBACG,EAAY,EAAA,MAAU,CAAE;qCAAZ,EAAA,MAAU,CAAE,KAAQ;KACxC,OAAK,GAAK;KACV,OAAK,EAAA,EAAA,UAAc,EAAA,OAAQ,CAAA;KAC3B,QAAQ;KACR,MAAM;KACN,UAAU,EAAA;;;;;;;;;;;8DE9ChB,KAAL,yBAAA,GAAA;QACE,EAAA,QAAA,MACA,EAAA,SAAA;EAFG,MAAA,EAAA,CAGJ;;;;;;;;;;;;;;;;;;;yBCFC,EAYQ,SAAA;GAXL,KAAK,EAAA;GACL,OAAK,EAAA;;iBAAyC,EAAA;;2BAAsC,EAAA;KAAQ,sBAAwB,EAAA;KAAQ;;;GAM7H,EAAQ,EAAA,QAAA,WAAA,EAAA,EAAA,KAAA,GAAA,GAAA;GACI,EAAA,YAAA,GAAA,EAAZ,EAA4E,QAA5E,KAAoE,IAAC,IAAA,EAAA,IAAA,GAAA;GAErE,EAAsB,EAAA,QAAA,UAAA,EAAA,EAAA,KAAA,GAAA,GAAA;;;qHEZrB,KAAL,yBAAA,GAAA;QACE,EAAA,QAAA,SACA,EAAA,UAAA,WACA,EAAA,SAAA;EAHG,MAAA,EAAA,CAIJ;;;;;;;;;;;;;;;;;ECsBD,IAAM,IAAQ,GAKR,IAAU;GACd,OAAO;GACP,SAAS;GACT,QAAQ;GACT;;;eAlCC,EAmBM,OAAA;IAlBH,OAAK,EAAA;;oBAA6C,EAAM;gCAA4C,EAAM,UAAQ;;IAKnH,MAAK;IACJ,aAAW,EAAM,YAAO,UAAA,cAAA;;IAEzB,EAIE,GAAA;KAHC,MAAM,EAAQ,EAAM;KACpB,MAAM;KACP,OAAM;;IAEK,EAAM,WAA2C,EAAA,IAAA,GAAA,IAA3C,GAAA,EAAnB,EAAqE,QAArE,KAAqE,CAAf,EAAQ,EAAA,QAAA,WAAA,EAAA,EAAA,KAAA,GAAA,GAAA,CAAA,CAAA;IAElD,EAAM,YAAA,GAAA,EAAlB,EAES,QAFT,KAES,CADN,EACD,EAAA,QAAA,WAAA,EAAA,EAAA,KAAA,GAAA,GAAA,CAAA,CAAA,IAAA,EAAA,IAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;EE2BN,IAAM,IAAQ,GAOR,IAAO,GAEP,IAAQ;GAAE,IAAI;GAAS,IAAI;GAAS,IAAI;GAAS,IAAI;GAAQ;EAEnE,SAAS,IAAiB;AACxB,GAAI,EAAM,kBAAgB,EAAK,QAAO;;AAWxC,EAPA,SACQ,EAAM,OACX,MAAQ;AACP,YAAS,KAAK,MAAM,WAAW,IAAM,WAAW;IAEpD,EAEA,QAAkB;AAChB,YAAS,KAAK,MAAM,WAAW;IAChC;EAED,SAAS,EAAU,GAAkB;AACnC,GAAI,EAAE,QAAQ,YAAY,EAAM,QAAM,EAAK,QAAO;;SAGpD,QAAgB;AACd,YAAS,iBAAiB,WAAW,EAAS;IAC/C,EACD,QAAkB;AAChB,YAAS,oBAAoB,WAAW,EAAS;IAClD;;eAjFC,EAqCW,GAAA,EArCD,IAAG,QAAM,EAAA,CACjB,EAmCa,GAAA,EAnCD,MAAK,YAAU,EAAA;qBAkCnB,CAjCK,EAAA,QAAA,GAAA,EAAX,EAiCM,OAAA;;KAjCW,OAAM;KAAqB,SAAK,EAAO,GAAc,CAAA,OAAA,CAAA;QACpE,EA+BM,OAAA;KA9BJ,OAAM;KACN,MAAK;KACL,cAAW;KACV,OAAK,EAAA,EAAA,UAAc,EAAM,EAAA,OAAI,CAAA;KAC7B,SAAK,AAAA,EAAA,OAAA,QAAN,IAAW,CAAA,OAAA,CAAA;;KAEGC,EAAAA,OAAO,UAAU,EAAA,SAAA,GAAA,EAA/B,EAWS,UAXT,KAWS,CAVP,EAEO,QAFP,KAEO,CADL,EAAsC,EAAA,QAAA,UAAA,EAAA,QAAA,CAAA,EAAA,EAAf,EAAA,MAAK,EAAA,EAAA,CAAA,EAAA,GAAA,CAAA,CAAA,EAE9B,EAMS,UAAA;MALP,OAAM;MACN,cAAW;MACV,SAAK,AAAA,EAAA,QAAA,MAAE,EAAI,QAAA;SAEZ,EAAmB,GAAA,EAAX,MAAK,KAAG,CAAA,CAAA,CAAA,CAAA,CAAA,IAAA,EAAA,IAAA,GAAA;KAGpB,EAEO,QAFP,KAEO,CADL,EAAQ,EAAA,QAAA,WAAA,EAAA,EAAA,KAAA,GAAA,GAAA,CAAA,CAAA;KAIFA,EAAAA,OAAO,UAAA,GAAA,EAFf,EAQS,GAAA;;MAPP,IAAG;MAEH,SAAQ;MACR,OAAM;MACN,aAAA;;uBAEsB,CAAtB,EAAsB,EAAA,QAAA,UAAA,EAAA,EAAA,KAAA,GAAA,GAAA,CAAA,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EE0KlC,IAAM,IAAQ,GAiBR,IAAO,GAKP,IAAW,EAA6B,KAAI,EAC5C,IAAU,EAAI,GAAK,EAEnB,IAAS,mBAAmB,IAAO,IACnC,IAAU,QAAe,EAAM,MAAM,EAAM,EAE3C,IAAU,QAEZ,EAAM,QAAQ,KAAA,KACd,EAAM,eAAe,QACrB,EAAM,eAAe,KAAA,KACrB,EAAM,cAAc,EAAM,IAC9B,EACM,IAAU,QAEZ,EAAM,QAAQ,KAAA,KACd,EAAM,eAAe,QACrB,EAAM,eAAe,KAAA,KACrB,EAAM,cAAc,EAAM,IAC9B;EAEA,SAAS,EAAM,GAAuB;GACpC,IAAI,IAAI;AAGR,UAFI,EAAM,QAAQ,KAAA,MAAW,IAAI,KAAK,IAAI,EAAM,KAAK,EAAC,GAClD,EAAM,QAAQ,KAAA,MAAW,IAAI,KAAK,IAAI,EAAM,KAAK,EAAC,GAC/C;;EAGT,SAAS,EAAY,GAAgC;AAC9C,KAAS,UACd,EAAS,MAAM,QAAQ,KAAQ,OAA0C,KAAd,OAAO,EAAI;;AAKxE,EAFA,QAAgB,EAAY,EAAM,WAAW,CAAA,EAE7C,SACQ,EAAM,aACX,MAAQ;AACP,GAAK,EAAQ,SAAO,EAAY,EAAG;IAEvC;EAEA,SAAS,IAAY;GAEnB,IAAM,IAAO,GADG,EAAM,cAAc,KACP,EAAM,KAAI;AAGvC,GAFA,EAAK,qBAAqB,EAAI,EAC9B,EAAK,UAAU,EAAI,EACnB,EAAY,EAAI;;EAGlB,SAAS,IAAY;GAEnB,IAAM,IAAO,GADG,EAAM,cAAc,KACP,EAAM,KAAI;AAGvC,GAFA,EAAK,qBAAqB,EAAI,EAC9B,EAAK,UAAU,EAAI,EACnB,EAAY,EAAI;;EAGlB,SAAS,IAAU;AACjB,OAAI,CAAC,EAAS,MAAO;GACrB,IAAM,IAAM,EAAS,MAAM;AAC3B,OAAI,MAAQ,GACV,GAAK,qBAAqB,KAAI;QACzB;IACL,IAAM,IAAM,WAAW,EAAG;AAC1B,IAAK,MAAM,EAAI,IAAE,EAAK,qBAAqB,EAAG;;;EAIlD,SAAS,IAAS;AAEhB,OADA,EAAQ,QAAQ,IACZ,CAAC,EAAS,MAAO;GACrB,IAAM,IAAM,EAAS,MAAM;AAC3B,OAAI,MAAQ,IAAI;AAEd,IADA,EAAK,qBAAqB,KAAI,EAC9B,EAAK,UAAU,KAAI;AACnB;;GAEF,IAAM,IAAM,WAAW,EAAG;AAC1B,OAAI,CAAC,MAAM,EAAI,EAAE;IACf,IAAM,IAAU,EAAM,EAAG;AAGzB,IAFA,EAAK,qBAAqB,EAAO,EACjC,EAAK,UAAU,EAAO,EACtB,EAAY,EAAO;;;EAIvB,IAAM,IAAc,QAAe;GACjC;GACA,oBAAoB,EAAM;GAC1B,oBAAoB,EAAM;GAC1B;IACE,0BAA0B,CAAC,CAAC,EAAM;IAClC,4BAA4B,CAAC,EAAM,SAAS,CAAC,CAAC,EAAM;IACpD,6BAA6B,EAAM;IACpC;GACF,CAAA,EAEK,KAAiB,SAAgB;GACrC,2CAA2C,EAAQ;GACnD,yCAAyC,CAAC,CAAC,EAAM;GACjD,2CAA2C,CAAC,EAAM,SAAS,CAAC,CAAC,EAAM;GACnE,4CAA4C,EAAM;GACnD,EAAC;SAEF,EAAa,EAAE,aAAa,EAAS,OAAO,OAAO,EAAE,CAAA,kBAzUnD,EAyLM,OAAA,EAzLA,OAAK,EAAE,EAAA,MAAW,EAAA,EAAA,CAEN,EAAA,YAAO,aAAA,GAAA,EAAvB,EAsFW,GAAA,EAAA,KAAA,GAAA,EAAA;GApFD,EAAA,SAAA,GAAA,EADR,EAMC,IAAA;;IAJE,KAAK,EAAA;IACL,UAAU,EAAA;IACV,UAAU,EAAA;;qBACC,CAAA,EAAA,EAAR,EAAA,MAAK,EAAA,EAAA,CAAA,CAAA;;;;;;;GAGX,EAyDM,OAAA,EAzDD,OAAK,EAAA,CAAC,kCAAyC,GAAA,MAAc,CAAA,EAAA,EAAA;IAChE,EAeE,SAAA;KAdC,IAAI,EAAA;cACD;KAAJ,KAAI;KACJ,MAAK;KACL,OAAM;KACL,aAAa,EAAA;KACb,KAAK,EAAA;KACL,KAAK,EAAA;KACL,MAAM,EAAA;KACN,UAAU,EAAA;KACV,UAAU,EAAA;KACH;KACD;KACN,WAAO,AAAA,EAAA,OAAA,GAAA,QAAsB,EAAA,OAAU,MAAI,EAAA,CAAA,UAAA,CAAA,EAAA,CAAA,QAAA,CAAA;KAC3C,SAAK,AAAA,EAAA,QAAA,MAAE,EAAA,QAAO;;IAIT,EAAA,SAAA,GAAA,EADR,EAMC,IAAA;;KAJC,SAAQ;KACP,aAAW;KACZ,OAAM;;sBACM,CAAA,EAAA,EAAR,EAAA,MAAK,EAAA,EAAA,CAAA,CAAA;;UAGE,EAAA,WAAA,GAAA,EADb,EAMC,IAAA;;KAJC,SAAQ;KACP,aAAW;KACZ,OAAM;;sBACQ,CAAA,EAAA,EAAV,EAAA,QAAO,EAAA,EAAA,CAAA,CAAA;;;IAGb,EAuBM,OAvBN,KAuBM,CAtBJ,EAUS,UAAA;KATP,MAAK;KACL,OAAK,EAAA,CAAC,4BAA0B,EAAA,sCACgB,EAAA,OAAO,CAAA,CAAA;KACtD,UAAU,EAAA;KACX,cAAW;KACV,aAAS,AAAA,EAAA,OAAA,QAAV,IAAkB,CAAA,UAAA,CAAA;KACjB,SAAO;QAER,EAAkC,IAAA;KAA1B,MAAK;KAAS,MAAM;mBAE9B,EAUS,UAAA;KATP,MAAK;KACL,OAAK,EAAA,CAAC,4BAA0B,EAAA,sCACgB,EAAA,OAAO,CAAA,CAAA;KACtD,UAAU,EAAA;KACX,cAAW;KACV,aAAS,AAAA,EAAA,OAAA,QAAV,IAAkB,CAAA,UAAA,CAAA;KACjB,SAAO;QAER,EAAiC,IAAA;KAAzB,MAAK;KAAQ,MAAM;;;GAMzB,EAAA,SAAA,GAAA,EADR,EAKC,IAAA;;IAHC,SAAQ;IACR,OAAM;;qBACM,CAAA,EAAA,EAAR,EAAA,MAAK,EAAA,EAAA,CAAA,CAAA;;SAGE,EAAA,WAAA,GAAA,EADb,EAKC,IAAA;;IAHC,SAAQ;IACR,OAAM;;qBACQ,CAAA,EAAA,EAAV,EAAA,QAAO,EAAA,EAAA,CAAA,CAAA;;SAGA,EAAA,UAAA,GAAA,EADb,EAKC,IAAA;;IAHC,SAAQ;IACR,OAAM;;qBACO,CAAA,EAAA,EAAT,EAAA,OAAM,EAAA,EAAA,CAAA,CAAA;;;YAKO,EAAA,YAAO,WAAA,GAAA,EAA5B,EA6FW,GAAA,EAAA,KAAA,GAAA,EAAA,CA5FT,EA8EM,OAAA,EA9ED,OAAK,EAAA,CAAC,kCAAyC,GAAA,MAAc,CAAA,EAAA,EAAA,CACrD,EAAA,SAAA,GAAA,EAAX,EAiBM,OAjBN,KAiBM,CAhBJ,EAQQ,SAAA;GARA,KAAK,EAAA;GAAS,OAAM;UACvB,EAAA,MAAK,GAAG,KACX,EAAA,EACQ,EAAA,YAAA,GAAA,EADR,EAKC,QALD,KAIG,IAAC,IAAA,EAAA,IAAA,GAAA,CAAA,EAAA,GAAA,IAAA,EAIE,EAAA,UAAM,CAAK,EAAA,SAAK,CAAK,EAAA,WAAA,GAAA,EAD7B,EAMC,IAAA;;GAJC,SAAQ;GACP,aAAW;GACZ,OAAM;;oBACO,CAAA,EAAA,EAAT,EAAA,OAAM,EAAA,EAAA,CAAA,CAAA;;kCAId,EAyDM,OAzDN,KAyDM;GAxDJ,EAeE,SAAA;IAdC,IAAI,EAAA;aACD;IAAJ,KAAI;IACJ,MAAK;IACL,OAAM;IACL,aAAa,EAAA;IACb,KAAK,EAAA;IACL,KAAK,EAAA;IACL,MAAM,EAAA;IACN,UAAU,EAAA;IACV,UAAU,EAAA;IACH;IACD;IACN,WAAO,AAAA,EAAA,OAAA,GAAA,QAAsB,EAAA,OAAU,MAAI,EAAA,CAAA,UAAA,CAAA,EAAA,CAAA,QAAA,CAAA;IAC3C,SAAK,AAAA,EAAA,QAAA,MAAE,EAAA,QAAO;;GAIT,EAAA,SAAA,GAAA,EADR,EAMC,IAAA;;IAJC,SAAQ;IACP,aAAW;IACZ,OAAM;;qBACM,CAAA,EAAA,EAAR,EAAA,MAAK,EAAA,EAAA,CAAA,CAAA;;SAGE,EAAA,WAAA,GAAA,EADb,EAMC,IAAA;;IAJC,SAAQ;IACP,aAAW;IACZ,OAAM;;qBACQ,CAAA,EAAA,EAAV,EAAA,QAAO,EAAA,EAAA,CAAA,CAAA;;;GAGb,EAuBM,OAvBN,KAuBM,CAtBJ,EAUS,UAAA;IATP,MAAK;IACL,OAAK,EAAA,CAAC,4BAA0B,EAAA,sCACgB,EAAA,OAAO,CAAA,CAAA;IACtD,UAAU,EAAA;IACX,cAAW;IACV,aAAS,AAAA,EAAA,OAAA,QAAV,IAAkB,CAAA,UAAA,CAAA;IACjB,SAAO;OAER,EAAkC,IAAA;IAA1B,MAAK;IAAS,MAAM;kBAE9B,EAUS,UAAA;IATP,MAAK;IACL,OAAK,EAAA,CAAC,4BAA0B,EAAA,sCACgB,EAAA,OAAO,CAAA,CAAA;IACtD,UAAU,EAAA;IACX,cAAW;IACV,aAAS,AAAA,EAAA,OAAA,QAAV,IAAkB,CAAA,UAAA,CAAA;IACjB,SAAO;OAER,EAAiC,IAAA;IAAzB,MAAK;IAAQ,MAAM;;WAO3B,EAAA,SAAA,GAAA,EADR,EAKC,IAAA;;GAHC,SAAQ;GACR,OAAM;;oBACM,CAAA,EAAA,EAAR,EAAA,MAAK,EAAA,EAAA,CAAA,CAAA;;QAGE,EAAA,WAAA,GAAA,EADb,EAKC,IAAA;;GAHC,SAAQ;GACR,OAAM;;oBACQ,CAAA,EAAA,EAAV,EAAA,QAAO,EAAA,EAAA,CAAA,CAAA;;;;;;;yBEtLjB,EAEM,OAFN,KAEM,CADJ,EAAQ,EAAA,QAAA,WAAA,EAAA,EAAA,KAAA,GAAA,GAAA,CAAA,CAAA;;qHEUP,KAAL,yBAAA,GAAA;QACE,EAAA,aAAA,cACA,EAAA,WAAA;EAFG,MAAA,EAAA,CAGJ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ECiCD,IAAM,IAAQ,GAYR,IAAc,QAAe,CACjC,YACA;GACE,mBAAmB,CAAC,CAAC,EAAM;GAC3B,qBAAqB,CAAC,EAAM,SAAS,CAAC,CAAC,EAAM;GAC7C,sBAAsB,EAAM;GAC5B,sBAAsB,EAAM;GAC7B,CACF,CAAA;EAED,SAAS,EAAc,GAAsB;AAC3C,UAAO,CACL,oBACA;IACE,8BAA8B,EAAM,YAAY,EAAO;IACvD,8BAA8B,EAAM;IACrC,CACH;;;;eA5EA,EAwCM,OAAA,EAxCA,OAAK,EAAE,EAAA,MAAW,EAAA,EAAA;IACP,EAAA,SAAA,GAAA,EAAf,EAA2C,GAAA,EAAA,KAAA,GAAA,EAAA;sBAAV,CAAA,EAAA,EAAR,EAAA,MAAK,EAAA,EAAA,CAAA,CAAA;;;IAE9B,EAuBM,OAAA,EAvBA,OAAK,EAAA,CAAA,mBAAA,oBAA0C,EAAA,YAAS,CAAA,EAAA,EAAA,EAAA,EAAA,GAAA,EAC5D,EAqBQ,GAAA,MAAA,EApBW,EAAA,UAAV,YADT,EAqBQ,SAAA;KAnBL,KAAK,EAAO;KACZ,OAAK,EAAE,EAAc,EAAM,CAAA;QAE5B,EAcO,QAdP,KAcO,CAbL,EASE,SAAA;KARA,MAAK;KACJ,MAAM,EAAA;KACN,OAAO,EAAO;KACd,SAAS,EAAA,eAAe,EAAO;KAC/B,UAAU,EAAA,YAAY,EAAO;KAC7B,UAAU,EAAA;KACX,OAAM;KACL,WAAM,MAAA,CAAG,EAAA,YAAYC,EAAAA,MAAK,qBAAsB,EAAO,MAAK;uBAE/D,EAEO,QAFP,KAEO,CADO,EAAA,eAAe,EAAO,SAAA,GAAA,EAAlC,EAAiE,QAAjE,IAAiE,IAAA,EAAA,IAAA,GAAA,CAAA,CAAA,CAAA,CAAA,EAGrE,EAAsD,QAAtD,KAAsD,EAAtB,EAAO,MAAK,EAAA,EAAA,CAAA,EAAA,EAAA;IAI/B,EAAA,SAAA,GAAA,EAAjB,EAEc,GAAA;;KAFU,SAAQ;KAAQ,OAAM;;sBAE5C,CAAA,EAAA,EADA,EAAA,MAAK,EAAA,EAAA,CAAA,CAAA;;UAGM,EAAA,WAAA,GAAA,EADb,EAKC,GAAA;;KAHC,SAAQ;KACR,OAAM;;sBACQ,CAAA,EAAA,EAAV,EAAA,QAAO,EAAA,EAAA,CAAA,CAAA;;UAES,EAAA,UAAA,GAAA,EAAtB,EAEc,GAAA;;KAFgB,SAAQ;KAAS,OAAM;;sBAEnD,CAAA,EAAA,EADA,EAAA,OAAM,EAAA,EAAA,CAAA,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EEmKZ,IAAM,IAAQ,GAiBR,IAAO,GAKP,IAAS,EAAI,GAAK,EAClB,IAAU,EAAI,GAAK,EACnB,IAAc,EAAI,GAAE,EACpB,IAAU,EAAwB,KAAI,EACtC,IAAa,EAAwB,KAAI,EACzC,IAAc,EAAwB,KAAI,EAC1C,IAAgB,EAAI;GACxB,UAAU;GACV,KAAK;GACL,MAAM;GACN,OAAO;GACP,QAAQ;GACT,CAAA,EAEK,KAAS,aAAa,IAAO,IAC7B,IAAU,QAAe,EAAM,MAAM,GAAM,EAE3C,IAAiB,QACjB,EAAM,cAAc,OAAa,EAAC,GAC/B,MAAM,QAAQ,EAAM,WAAW,GAAG,EAAM,aAAa,CAAC,EAAM,WAAU,CAC9E,EAEK,KAAe,QAAe;AAClC,OAAI,EAAe,MAAM,WAAW,EAAG,QAAO;GAC9C,IAAM,IAAO,EAAM,WAAW,EAAC;AAe/B,UAdI,EAAM,WACJ,EAAe,MAAM,WAAW,IAEhC,EAAK,MAAM,MAAM,EAAE,UAAU,EAAe,MAAM,GAAG,EAAE,SACvD,OAAO,EAAe,MAAM,GAAE,GAG9B,EAAe,MAAM,WAAW,IAC3B,EAAe,MACnB,KAAK,MAAM,EAAK,MAAM,MAAM,EAAE,UAAU,EAAE,EAAE,SAAS,OAAO,EAAE,CAAA,CAC9D,KAAK,KAAI,GAEP,GAAG,EAAe,MAAM,OAAO,aAGtC,EAAK,MAAM,MAAM,EAAE,UAAU,EAAe,MAAM,GAAG,EAAE,SACvD,OAAO,EAAe,MAAM,GAAE;IAEjC;EAED,SAAS,EAAW,GAAwB;AAC1C,UAAO,EAAe,MAAM,SAAS,EAAK;;EAG5C,SAAS,EAAa,GAAuB;AAC3C,OAAI,EAAO,SAAU;GACrB,IAAI;AACJ,OAAI,EAAM,UAAU;IAClB,IAAM,IAAM,CAAC,GAAG,EAAe,MAAK,EAC9B,IAAM,EAAI,QAAQ,EAAO,MAAK;AAGpC,IAFI,KAAO,IAAG,EAAI,OAAO,GAAK,EAAC,GAC1B,EAAI,KAAK,EAAO,MAAK,EAC1B,IAAO;SAGP,CADA,IAAO,EAAO,OACd,GAAc;AAGhB,GADA,EAAK,qBAAqB,EAAI,EAC9B,EAAK,UAAU,EAAI;;EAGrB,SAAS,IAAyB;AAChC,OAAI,CAAC,EAAW,MAAO;GACvB,IAAM,IAAO,EAAW,MAAM,uBAAsB;AACpD,KAAc,QAAQ;IACpB,UAAU;IACV,KAAK,GAAG,EAAK,OAAO;IACpB,MAAM,GAAG,EAAK,KAAK;IACnB,OAAO,GAAG,EAAK,MAAM;IACrB,QAAQ;IACV;;EAGF,SAAS,KAAe;AACtB,OAAI,EAAM,SAAU;AAEpB,GADA,EAAO,QAAQ,IACf,GAAuB;GACvB,IAAM,IAAO,EAAM,WAAW,EAAC;AAQ/B,GAPA,EAAY,QACV,EAAe,MAAM,SAAS,IAC1B,KAAK,IACH,GACA,EAAK,WAAW,MAAM,EAAE,UAAU,EAAe,MAAM,GAAG,CAC5D,GACA,IACN,EAAS,GAAmB;;EAG9B,SAAS,IAAgB;AAEvB,GADA,EAAO,QAAQ,IACf,EAAY,QAAQ;;EAGtB,SAAS,KAAiB;AACxB,GAAI,EAAO,QAAO,GAAc,GAC3B,IAAa;;EAGpB,SAAS,EAAe,GAAe;GACrC,IAAM,IAAS,EAAE,QACX,IAAS,EAAQ,OAAO,SAAS,EAAO,IAAI,IAC5C,IAAa,EAAY,OAAO,SAAS,EAAO,IAAI;AAC1D,GAAI,CAAC,KAAU,CAAC,KAAY,GAAc;;EAG5C,SAAS,IAAmB;AAC1B,GAAI,EAAO,SAAO,GAAuB;;AAe3C,EAZA,GAAM,IAAS,MAAQ;AACrB,GAAI,KACF,SAAS,iBAAiB,aAAa,EAAc,EACrD,OAAO,iBAAiB,UAAU,GAAkB,GAAI,EACxD,OAAO,iBAAiB,UAAU,EAAgB,KAElD,SAAS,oBAAoB,aAAa,EAAc,EACxD,OAAO,oBAAoB,UAAU,GAAkB,GAAI,EAC3D,OAAO,oBAAoB,UAAU,EAAgB;IAExD,EAED,QAAsB;AAGpB,GAFA,SAAS,oBAAoB,aAAa,EAAc,EACxD,OAAO,oBAAoB,UAAU,GAAkB,GAAI,EAC3D,OAAO,oBAAoB,UAAU,EAAgB;IACtD;EAED,SAAS,EAAU,GAAkB;GACnC,IAAM,IAAO,EAAM,WAAW,EAAC;AAC/B,OAAI,CAAC,EAAO,OAAO;AACjB,KAAI,EAAE,QAAQ,WAAW,EAAE,QAAQ,OAAO,EAAE,QAAQ,iBAClD,EAAE,gBAAe,EACjB,IAAa;AAEf;;AAEF,GAAI,EAAE,QAAQ,YACZ,GAAc,EACd,EAAE,gBAAe,IACR,EAAE,QAAQ,QACnB,GAAc,GACL,EAAE,QAAQ,eACnB,EAAE,gBAAe,EACjB,EAAY,QAAQ,KAAK,IAAI,EAAY,QAAQ,GAAG,EAAK,SAAS,EAAC,EACnE,IAAoB,IACX,EAAE,QAAQ,aACnB,EAAE,gBAAe,EACjB,EAAY,QAAQ,KAAK,IAAI,EAAY,QAAQ,GAAG,EAAC,EACrD,IAAoB,KACV,EAAE,QAAQ,WAAW,EAAE,QAAQ,QAAQ,EAAY,SAAS,MACtE,EAAE,gBAAe,EACjB,EAAa,EAAK,EAAY,OAAM;;EAIxC,SAAS,KAAsB;AAC7B,WAAe;AACT,KAAC,EAAY,SAAS,EAAY,QAAQ,KAE5C,EAAY,MAAM,iBAA8B,qBAAqB,CACnE,EAAY,QAEV,eAAe,EAAE,OAAO,WAAW,CAAA;KAC1C;;EAGH,IAAM,KAAc,QAAe;GACjC;GACA,cAAc,EAAM;GACpB,cAAc,EAAM;GACpB;IACE,mBAAmB,EAAO;IAC1B,sBAAsB,EAAQ,SAAS,CAAC,EAAO;IAC/C,oBAAoB,CAAC,CAAC,EAAM;IAC5B,sBAAsB,CAAC,EAAM,SAAS,CAAC,CAAC,EAAM;IAC9C,uBAAuB,EAAM;IAC9B;GACF,CAAA;SAED,EAAa;GACX,MAAM;GACN,OAAO;GACR,CAAA;;2BA1ZC,EA0IM,OAAA;aA1IG;IAAJ,KAAI;IAAW,OAAK,EAAE,GAAA,MAAW;IAAY;OAEhC,EAAA,YAAO,aAAA,GAAA,EAAvB,EAmEW,GAAA,EAAA,KAAA,GAAA,EAAA;IAlEGC,EAAAA,OAAO,QAAnB,EAAyC,EAAA,QAAA,SAAA,EAAA,KAAA,GAAA,CAAA,GAE5B,EAAA,SAAA,GAAA,EADb,EAMC,GAAA;;KAJE,KAAK,EAAA;KACL,UAAU,EAAA;KACV,UAAU,EAAA;;sBACC,CAAA,EAAA,EAAR,EAAA,MAAK,EAAA,EAAA,CAAA,CAAA;;;;;;;IAGX,EAwCS,UAAA;KAvCN,IAAI,EAAA;cACD;KAAJ,KAAI;KACJ,MAAK;KACL,OAAM;KACN,MAAK;KACJ,iBAAe,EAAA;KACf,iBAAe;KACf,iBAAe,EAAA,YAAY,KAAA;KAC3B,iBAAe,EAAA,YAAY,KAAA;KAC3B,UAAU,EAAA,YAAY,KAAA;KACtB,SAAO;KACP,SAAK,AAAA,EAAA,QAAA,MAAE,EAAA,QAAO;KACd,QAAI,AAAA,EAAA,QAAA,MAAE,EAAA,QAAO;;KAEd,EAOO,QAAA,EANJ,OAAK,EAAA,CAAA,oBAAA,EAAA,iCAAA,CAAoF,GAAA,OAAY,CAAA,CAAA,EAAA,EAAA,EAKnG,GAAA,SAAgB,EAAA,YAAW,EAAA,EAAA;KAGxB,EAAA,SAAA,GAAA,EADR,EAMC,GAAA;;MAJC,SAAQ;MACP,aAAW;MACZ,OAAM;;uBACM,CAAA,EAAA,EAAR,EAAA,MAAK,EAAA,EAAA,CAAA,CAAA;;WAGE,EAAA,WAAA,GAAA,EADb,EAMC,GAAA;;MAJC,SAAQ;MACP,aAAW;MACZ,OAAM;;uBACQ,CAAA,EAAA,EAAV,EAAA,QAAO,EAAA,EAAA,CAAA,CAAA;;;KAEb,EAES,GAAA;MAFD,OAAM;MAAS,SAAQ;MAAS,OAAM;;uBACoB,CAAhE,EAAgE,GAAA;OAAvD,MAAM,EAAA,QAAM,aAAA;OAA+B,MAAM;;;;;IAI7C,EAAA,SAAA,GAAA,EAAjB,EAEc,GAAA;;KAFU,SAAQ;KAAQ,OAAM;;sBAE5C,CAAA,EAAA,EADA,EAAA,MAAK,EAAA,EAAA,CAAA,CAAA;;UAGM,EAAA,WAAA,GAAA,EADb,EAKC,GAAA;;KAHC,SAAQ;KACR,OAAM;;sBACQ,CAAA,EAAA,EAAV,EAAA,QAAO,EAAA,EAAA,CAAA,CAAA;;UAGA,EAAA,UAAA,GAAA,EADb,EAKC,GAAA;;KAHC,SAAQ;KACR,OAAM;;sBACO,CAAA,EAAA,EAAT,EAAA,OAAM,EAAA,EAAA,CAAA,CAAA;;;aAKO,EAAA,YAAO,WAAA,GAAA,EAA5B,EAiEW,GAAA,EAAA,KAAA,GAAA,EAAA,CAhET,EAkDS,UAAA;IAjDN,IAAI,EAAA;aACD;IAAJ,KAAI;IACJ,MAAK;IACL,OAAM;IACN,MAAK;IACJ,iBAAe,EAAA;IACf,iBAAe;IACf,iBAAe,EAAA,YAAY,KAAA;IAC3B,iBAAe,EAAA,YAAY,KAAA;IAC3B,UAAU,EAAA,YAAY,KAAA;IACtB,SAAO;IACP,SAAK,AAAA,EAAA,QAAA,MAAE,EAAA,QAAO;IACd,QAAI,AAAA,EAAA,QAAA,MAAE,EAAA,QAAO;OAGN,EAAA,SAASA,EAAAA,OAAO,SAAA,GAAA,EADxB,EAqBS,GAAA;;IAnBP,KAAI;IACJ,OAAM;IACN,KAAI;IACJ,OAAM;;qBAEmC,CAA7BA,EAAAA,OAAO,QAAnB,EAAyC,EAAA,QAAA,SAAA,EAAA,KAAA,GAAA,CAAA,IAAA,GAAA,EACzC,EAKQ,SALR,KAKQ,CAAA,EAAA,EAJH,EAAA,MAAK,GAAG,KACX,EAAA,EAAY,EAAA,YAAA,GAAA,EAAZ,EAEC,QAFD,KACG,IAAC,IAAA,EAAA,IAAA,GAAA,CAAA,CAAA,GAIE,EAAA,UAAM,CAAK,EAAA,SAAK,CAAK,EAAA,WAAA,GAAA,EAD7B,EAMC,GAAA;;KAJC,SAAQ;KACP,aAAW;KACZ,OAAM;;sBACO,CAAA,EAAA,EAAT,EAAA,OAAM,EAAA,EAAA,CAAA,CAAA;;;;oBAGd,EAYS,GAAA;IAZD,KAAI;IAAM,OAAM;IAAM,MAAA;IAAK,OAAM;;qBAQhC,CAPP,EAOO,QAAA,EANJ,OAAK,EAAA,CAAA,oBAAA,EAAA,iCAAA,CAAwF,GAAA,OAAY,CAAA,CAAA,EAAA,EAAA,EAKvG,GAAA,SAAgB,EAAA,YAAW,EAAA,EAAA,EAEhC,EAES,GAAA;KAFD,OAAM;KAAS,SAAQ;KAAS,OAAM;;sBACoB,CAAhE,EAAgE,GAAA;MAAvD,MAAM,EAAA,QAAM,aAAA;MAA+B,MAAM;;;;;kBAMxD,EAAA,SAAA,GAAA,EADR,EAKC,GAAA;;IAHC,SAAQ;IACR,OAAM;;qBACM,CAAA,EAAA,EAAR,EAAA,MAAK,EAAA,EAAA,CAAA,CAAA;;SAGE,EAAA,WAAA,GAAA,EADb,EAKC,GAAA;;IAHC,SAAQ;IACR,OAAM;;qBACQ,CAAA,EAAA,EAAV,EAAA,QAAO,EAAA,EAAA,CAAA,CAAA;;mDAMjB,EAqDW,GAAA,EArDD,IAAG,QAAM,EAAA,CAET,EAAA,SAAA,GAAA,EADR,EAmDM,OAAA;;aAjDA;IAAJ,KAAI;IACJ,OAAM;IACL,OAAK,EAAE,EAAA,MAAa;IACrB,MAAK;IACJ,wBAAsB,EAAA,YAAY,KAAA;eAEnC,EAuCM,GAAA,MAAA,EAtCoB,EAAA,UAAhB,GAAQ,YADlB,EAuCM,OAAA;IArCH,KAAK,EAAO;IACZ,OAAK,EAAA,CAAA,qBAAA;oCAA0F,EAAW,EAAO,MAAK;uCAAiD,EAAA,UAAgB;oCAAgD,EAAO;;IAQ/O,MAAK;IACJ,iBAAe,EAAW,EAAO,MAAK;IACtC,iBAAe,EAAO,YAAY,KAAA;IAClC,eAAU,MAAE,EAAA,QAAc;IAC1B,UAAK,MAAE,EAAa,EAAM;OAGnB,EAAA,YAAA,GAAA,EADR,EAoBO,QApBP,KAoBO,CAdG,EAAW,EAAO,MAAK,IAAA,GAAA,EAD/B,EAcM,OAdN,KAcM,CAAA,GAAA,AAAA,EAAA,OAAA,CAPJ,EAME,QAAA;IALA,GAAE;IACF,QAAO;IACP,gBAAa;IACb,kBAAe;IACf,mBAAgB;gDAItB,EAA+D,QAA/D,KAA+D,EAAtB,EAAO,MAAK,EAAA,EAAA,CAAA,EAAA,IAAA,IAAA,YAE3C,EAAA,WAAW,EAAA,QAAQ,WAAM,KAAA,GAAA,EAArC,EAEM,OAFN,KAAsE,eAEtE,IAAA,EAAA,IAAA,GAAA,CAAA,EAAA,IAAA,IAAA,IAAA,EAAA,IAAA,GAAA,CAAA,CAAA,EAAA,EAAA,GAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EErEN,IAAM,IAAQ,GAWR,IAAO,GAKP,IAAW,EAAwB,KAAI,EAEvC,IAAe,EAAmB,KAAI,EAGtC,IAAc,QAEhB,EAAM,SACN,EAAM,eAAe,QACrB,EAAM,eAAe,KAAA,IAEd,EAAM,OAAO,IAElB,MAAM,QAAQ,EAAM,WAAW,GACzB,EAAM,WAAW,MAAiB,EAAM,OAAO,IAClD,EAAM,WACd,EAEK,IAAW,QACX,CAAC,EAAM,SAAS,CAAC,MAAM,QAAQ,EAAM,WAAW,GAAS,EAAM,OAAO,IAClE,EAAM,WAAgC,MAAM,EAAM,OAAO,EAClE,EAEK,IAAY,QACZ,CAAC,EAAM,SAAS,CAAC,MAAM,QAAQ,EAAM,WAAW,GAAS,EAAM,OAAO,MAClE,EAAM,WAAgC,MAAM,EAAM,OAAO,IAClE;EAGD,SAAS,EAAe,GAAmB;GACzC,IAAM,IAAO,EAAM,OAAO,GACpB,IAAO,EAAM,OAAO;AAE1B,UADI,MAAS,IAAa,KACjB,IAAI,MAAS,IAAO,KAAS;;EAGxC,SAAS,EAAe,GAAqB;GAC3C,IAAM,IAAO,EAAM,OAAO,GACpB,IAAO,EAAM,OAAO,KACpB,IAAQ,EAAM,QAAQ,GACtB,IAAM,IAAQ,IAAM,OAAQ,IAAO,IACnC,IAAU,KAAK,MAAM,IAAM,EAAM,GAAG;AAC1C,UAAO,KAAK,IAAI,GAAM,KAAK,IAAI,GAAM,EAAQ,CAAA;;EAG/C,SAAS,EAAoB,GAAoC;AAC/D,OAAI,CAAC,EAAS,MAAO,QAAO;GAC5B,IAAM,IAAO,EAAS,MAAM,uBAAsB,EAC5C,IAAU,aAAa,IAAI,EAAE,QAAQ,GAAG,UAAU,EAAE;AAC1D,UAAO,KAAK,IAAI,GAAG,KAAK,IAAI,MAAO,IAAU,EAAK,QAAQ,EAAK,QAAS,IAAI,CAAA;;EAI9E,IAAM,IAAY,QAAe;AAC/B,OAAI,CAAC,EAAM,MACT,QAAO;IAAE,MAAM;IAAM,OAAO,GAAG,EAAe,EAAY,MAAM,CAAC;IAAG;GAEtE,IAAM,IAAU,EAAe,EAAS,MAAK,EACvC,IAAW,EAAe,EAAU,MAAK;AAC/C,UAAO;IAAE,MAAM,GAAG,EAAQ;IAAI,OAAO,GAAG,IAAW,EAAQ;IAAG;IAC/D;EAGD,SAAS,EAAW,GAAe;AACjC,KAAK,qBAAqB,EAAK;;EAGjC,SAAS,EAAU,GAAa,GAAc;AAC5C,KAAK,qBAAqB,CAAC,GAAK,EAAK,CAAA;;EAIvC,SAAS,EAAoB,GAAoB;AAC/C,OAAI,MAAQ,KAAM;GAClB,IAAM,IAAO,EAAM,OAAO,GACpB,IAAO,EAAM,OAAO;AAC1B,KAAW,KAAK,IAAI,GAAM,KAAK,IAAI,GAAM,EAAI,CAAC,CAAA;;EAGhD,SAAS,GAAiB,GAAoB;AAC5C,OAAI,MAAQ,KAAM;GAClB,IAAM,IAAO,EAAM,OAAO;AAE1B,KADgB,KAAK,IAAI,GAAM,KAAK,IAAI,EAAU,OAAO,EAAI,CAAA,EAC1C,EAAU,MAAK;;EAGpC,SAAS,EAAkB,GAAoB;AAC7C,OAAI,MAAQ,KAAM;GAClB,IAAM,IAAO,EAAM,OAAO,KACpB,IAAU,KAAK,IAAI,EAAS,OAAO,KAAK,IAAI,GAAM,EAAI,CAAA;AAC5D,KAAU,EAAS,OAAO,EAAO;;EAInC,SAAS,GAAc,GAA4B;AACjD,OAAI,CAAC,EAAM,MAAO,QAAO;GACzB,IAAM,IAAS,EAAe,EAAS,MAAK,EACtC,IAAU,EAAe,EAAU,MAAK;AAC9C,UAAO,KAAK,IAAI,IAAM,EAAO,IAAI,KAAK,IAAI,IAAM,EAAQ,GAAG,QAAQ;;EAGrE,SAAS,EAAU,GAAa;GAC9B,IAAM,IAAM,EAAe,EAAG;AAC9B,OAAI,CAAC,EAAM,OAAO;AAChB,MAAW,EAAG;AACd;;AAEF,OAAI,EAAa,UAAU,MAEzB,GADgB,KAAK,IAAI,GAAK,EAAU,MAAK,EAC1B,EAAU,MAAK;QAC7B;IACL,IAAM,IAAU,KAAK,IAAI,GAAK,EAAS,MAAK;AAC5C,MAAU,EAAS,OAAO,EAAO;;;EAIrC,SAAS,GAAY,GAAe;AAC9B,KAAM,YACV,EAAU,EAAoB,EAAE,CAAA;;EAGlC,SAAS,EAAU,GAAe;AAQhC,GAPK,EAAM,aAIT,EAAK,UAHO,EAAM,QACb,CAAC,EAAS,OAAO,EAAU,MAAM,GAClC,EAAY,MACE,EAClB,EAAU,EAAoB,EAAE,CAAA,GAElC,IAAS;;EAGX,SAAS,EAAY,GAAe;AAC9B,KAAM,YACV,EAAU,EAAoB,EAAE,CAAA;;EAGlC,SAAS,EAAW,GAAe;AAQjC,GAPK,EAAM,aAIT,EAAK,UAHO,EAAM,QACb,CAAC,EAAS,OAAO,EAAU,MAAM,GAClC,EAAY,MACE,EAClB,EAAU,EAAoB,EAAE,CAAA,GAElC,IAAc;;EAGhB,SAAS,KAAY;AAEnB,GADA,SAAS,iBAAiB,aAAa,GAAW,EAClD,SAAS,iBAAiB,WAAW,EAAS;;EAGhD,SAAS,KAAW;AAGlB,GAFA,EAAa,QAAQ,MACrB,SAAS,oBAAoB,aAAa,GAAW,EACrD,SAAS,oBAAoB,WAAW,EAAS;;EAGnD,SAAS,IAAiB;AAExB,GADA,SAAS,iBAAiB,aAAa,GAAa,EAAE,SAAS,IAAM,CAAA,EACrE,SAAS,iBAAiB,YAAY,EAAU;;EAGlD,SAAS,KAAgB;AAGvB,GAFA,EAAa,QAAQ,MACrB,SAAS,oBAAoB,aAAa,EAAW,EACrD,SAAS,oBAAoB,YAAY,EAAU;;EAGrD,SAAS,EAAiB,GAAe;AACvC,OAAI,EAAM,SAAU;GACpB,IAAM,IAAM,EAAoB,EAAC;AAGjC,GAFA,EAAa,QAAQ,GAAc,EAAG,EACtC,EAAU,EAAG,EACb,IAAU;;EAGZ,SAAS,EAAkB,GAAe;AACxC,OAAI,EAAM,SAAU;GACpB,IAAM,IAAM,EAAoB,EAAC;AAGjC,GAFA,EAAa,QAAQ,GAAc,EAAG,EACtC,EAAU,EAAG,EACb,GAAe;;EAGjB,SAAS,GAAkB,GAAuB,GAAgB;AAC5D,KAAM,aACV,EAAa,QAAQ,EAAM,QAAQ,IAAS,MAC5C,IAAU;;EAGZ,SAAS,GAAmB,GAAuB,GAAgB;AAC7D,KAAM,aACV,EAAa,QAAQ,EAAM,QAAQ,IAAS,MAC5C,GAAe;;AAGjB,UAAsB;AAEpB,GADA,IAAS,EACT,IAAc;IACf;EAGD,IAAM,KAAc,QAAe;GACjC;GACA,cAAc,EAAM;GACpB,cAAc,EAAM;GACpB;IACE,oBAAoB,EAAM;IAC1B,uBAAuB,EAAM;IAC7B,oBAAoB,CAAC,CAAC,EAAM;IAC5B,sBAAsB,CAAC,EAAM,SAAS,CAAC,CAAC,EAAM;IAC/C;GACF,CAAA,EAEK,KAAmB,SAAgB;GACvC,gCAAgC,CAAC,CAAC,EAAM;GACxC,kCAAkC,CAAC,EAAM,SAAS,CAAC,CAAC,EAAM;GAC3D,EAAC;;;eAtWA,EAmHM,OAAA,EAnHA,OAAK,EAAE,GAAA,MAAW,EAAA,EAAA;IAEP,EAAA,YAAO,aAAkB,EAAA,SAAA,GAAA,EAAxC,EAEY,GAAA;;KAFmC,OAAM;;sBAEnD,CAAA,EAAA,EADA,EAAA,MAAK,EAAA,EAAA,CAAA,CAAA;;;IAIP,EA4FM,OA5FN,KA4FM,CA1FO,EAAA,YAAO,WAAgB,EAAA,SAAA,GAAA,EAAlC,EAEM,OAFN,KAEM,CADJ,EAAyD,SAAzD,KAAyD,EAAhB,EAAA,MAAK,EAAA,EAAA,CAAA,CAAA,IAAA,EAAA,IAAA,GAAA,EAGhD,EAqFS,GAAA;KArFD,KAAI;KAAM,OAAM;KAAS,KAAI;KAAK,OAAM;;sBAa5C;MAVM,EAAA,SAAS,EAAA,aAAA,GAAA,EADjB,EAWE,GAAA;;OATC,MAAM,EAAA,YAAO,UAAA,OAAsB,EAAA;OACnC,eAAa,EAAA;OACb,KAAK,EAAA;OACL,KAAK,EAAA;OACL,MAAM,EAAA;OACN,UAAU,EAAA;OACX,OAAM;OACL,uBAAoB;OACpB,UAAQ;;;;;;;;;MAIX,EAiDS,GAAA;OAhDP,KAAI;OACJ,SAAQ;OACR,KAAI;OACJ,OAAK,EAAA,CAAC,yBACE,GAAA,MAAgB,CAAA;OACxB,MAAA;;wBAoCM,CAlCN,EAkCM,OAAA;iBAjCA;QAAJ,KAAI;QACJ,OAAM;QACL,aAAW;6BACS;WAGrB,EAAyD,OAAA;QAApD,OAAM;QAA0B,OAAK,EAAE,EAAA,MAAS;oBAI5C,EAAA,cAQT,EAcW,GAAA,EAAA,KAAA,GAAA,EAAA;QAbT,EAKE,OAAA;SAJA,OAAM;SACL,OAAK,EAAA,EAAA,MAAA,GAAa,EAAe,EAAA,MAAQ,CAAA,IAAA,CAAA;SACzC,aAAS,AAAA,EAAA,OAAA,GAAA,MAAO,GAAiB,OAAQ,EAAM,EAAA,CAAA,OAAA,CAAA;gDACtB,GAAkB,OAAQ,EAAM,EAAA,CAAA,OAAA,CAAA;;QAE5D,EAKE,OAAA;SAJA,OAAM;SACL,OAAK,EAAA,EAAA,MAAA,GAAa,EAAe,EAAA,MAAS,CAAA,IAAA,CAAA;SAC1C,aAAS,AAAA,EAAA,OAAA,GAAA,MAAO,GAAiB,QAAS,EAAM,EAAA,CAAA,OAAA,CAAA;gDACvB,GAAkB,QAAS,EAAM,EAAA,CAAA,OAAA,CAAA;;iBAE7D,EAA+B,OAAA,EAA1B,OAAM,mBAAiB,EAAA,MAAA,GAAA;kBArBrB,GAAA,EADT,EAME,OAAA;;QAJA,OAAM;QACL,OAAK,EAAA,EAAA,MAAA,GAAa,EAAe,EAAA,MAAW,CAAA,IAAA,CAAA;QAC5C,aAAS,AAAA,EAAA,OAAA,GAAA,MAAO,GAAiB,MAAO,EAAM,EAAA,CAAA,OAAA,CAAA;+CACrB,GAAkB,MAAO,EAAM,EAAA,CAAA,OAAA,CAAA;6BAsB7D,EAGM,OAHN,KAGM,CAFJ,EAAqD,QAArD,KAAqD,EAAb,EAAA,IAAG,EAAA,EAAA,EAC3C,EAAqD,QAArD,KAAqD,EAAb,EAAA,IAAG,EAAA,EAAA,CAAA,CAAA,CAAA,CAAA;;;MAOvC,EAAA,aAAA,GAAA,EADR,EAeE,GAAA;;OAbC,MAAM,EAAA,YAAO,UAAA,OAAsB,EAAA;OACnC,eAAa,EAAA,QAAQ,EAAA,QAAY,EAAA;OACjC,KAAK,EAAA,QAAQ,EAAA,QAAW,EAAA;OACxB,KAAK,EAAA;OACL,MAAM,EAAA;OACN,UAAU,EAAA;OACX,OAAM;OACL,uBAAkB,AAAA,EAAA,QAAA,MAAe,EAAA,QAAQ,EAAkB,EAAM,GAAI,EAAoB,EAAM;OAG/F,UAAM,AAAA,EAAA,QAAA,MAAe,EAAA,QAAQ,EAAkB,EAAM,GAAI,EAAoB,EAAM;;;;;;;;;;;;IASzE,EAAA,SAAA,GAAA,EAAjB,EAEc,GAAA;;KAFU,SAAQ;KAAQ,OAAM;;sBAE5C,CAAA,EAAA,EADA,EAAA,MAAK,EAAA,EAAA,CAAA,CAAA;;UAGM,EAAA,WAAA,GAAA,EADb,EAKC,GAAA;;KAHC,SAAQ;KACR,OAAM;;sBACQ,CAAA,EAAA,EAAV,EAAA,QAAO,EAAA,EAAA,CAAA,CAAA;;UAES,EAAA,UAAA,GAAA,EAAtB,EAEc,GAAA;;KAFgB,SAAQ;KAAS,OAAM;;sBAEnD,CAAA,EAAA,EADA,EAAA,OAAM,EAAA,EAAA,CAAA,CAAA;;;;;;qHEhHP,KAAL,yBAAA,GAAA;QACE,EAAA,QAAA,MACA,EAAA,SAAA,MACA,EAAA,QAAA;EAHG,MAAA,EAAA,CAIJ,EAEI,KAAL,yBAAA,GAAA;QACE,EAAA,UAAA,WACA,EAAA,YAAA;EAFG,MAAA,EAAA,CAGJ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ECkBD,IAAM,IAAQ,EAAoB,GAAA,aAAC,EAE7B,IAAQ,GA6BR,IAAsB,GAAY,EAAK,EAEvC,IAAa,SAAgB,EACjC,iBAAiB,EAAM,UACxB,EAAC,EAEI,IAAU,SAAgB;GAC9B,aAAa;GACb,UAAU,EAAM;GACjB,EAAC,EAEI,IAAiB,SAAgB;GACrC,qBAAqB;GACrB,SAAS,EAAM;IACd,EAAM,OAAO;IACb,MAAM,EAAM,YAAY;GAC1B,EAAC;;;eA3EA,EAmBS,GAAA;IAnBA,IAAI,EAAA,EAAmB;IAAG,OAAK,EAAE,EAAA,MAAO;IAAE,OAAM;IAAS,KAAI;;qBAG7D,CAFK,EAAA,SAAA,GAAA,EAAZ,EAEO,QAFP,KAEO,EADF,EAAA,MAAK,EAAA,EAAA,IAAA,EAAA,IAAA,GAAA,EAEV,EAcQ,SAdR,EAcQ;KAbL,KAAG,GAAK,EAAA,EAAmB,CAAA;KAC3B,OAAO,EAAA;OACA,EAAA,OAAU,EACjB,SAAK,AAAA,EAAA,OAAA,QAAN,IAAW,CAAA,OAAA,CAAA,EAAA,CAAA,EAAA,CAAA,EAEX,EAME,SAAA;KALC,IAAE,GAAK,EAAA,EAAmB,CAAA;8CACb,QAAA;KACb,MAAM,EAAA;KACP,MAAK;KACJ,UAAU,EAAA;2BAHF,EAAA,MAAK,CAAA,CAAA,EAAA,AAAA,EAAA,OAKhB,EAA4B,OAAA,EAAvB,OAAM,gBAAc,EAAA,MAAA,GAAA,CAAA,EAAA,IAAA,IAAA,CAAA,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EE8M/B,IAAM,IAAQ,GAuBR,IAAQ,EAAmB,GAAA,aAAgB,EAE3C,IAAY,EAAmD,KAAI,EACnE,IAAY,EAA2B,KAAI;AAIjD,IAAa;GACX,aAAa,EAAU,OAAO,OAAO;GACrC,YAAY,EAAU,OAAO,MAAM;GACnC,UAAU;GACX,CAAA;EAED,IAAM,IAAU,EAAI,GAAK,EAGnB,IAAS,YAAY,IAAO,IAC5B,IAAU,QAAe,EAAM,MAAM,EAAM,EAG3C,IAAa,QAAe,CAAC,CAAC,EAAM,UAAS,EAG7C,IAAa,QAAe;AAChC,OAAI,CAAC,EAAM,UAAW,QAAO;GAC7B,IAAM,IAAO,OAAO,EAAM,SAAS,GAAE;AAErC,UADoB,EAAM,UAAU,EAAI,GACnB;IACtB;EAGD,SAAS,IAAa;AACpB,GAAI,EAAU,SAAS,EAAU,UAC/B,EAAU,MAAM,YAAY,EAAU,MAAM;;AAIhD,KAAM,SAAkB,EAAS,EAAW,CAAA;EAE5C,IAAM,IAAiB,QACjB,EAAM,QAAc,UACpB,EAAM,UAAgB,YACnB,SACR,EAEK,IAAc,QACZ,EAAM,SAAS,EAAM,WAAW,EAAM,UAAU,GACxD,EACM,IAAa,QAAe,CAAC,CAAC,EAAY,MAAK,EAE/C,IAAiB,SAAgB;GACrC,yCAAyC,EAAQ;GACjD,uCAAuC,CAAC,CAAC,EAAM;GAC/C,yCAAyC,CAAC,EAAM,SAAS,CAAC,CAAC,EAAM;GACjE,0CAA0C,EAAM;GAChD,0CAA0C,EAAM;GAChD,yCAAyC,EAAW;GACpD,2CAA2C,EAAM;GAClD,EAAC;;;eAhTA,EA6LS,GAAA;IA5LP,KAAI;IACJ,KAAI;IACH,OAAK,EAAA;;uBAAmD,EAAA;uBAAmC,EAAA;mCAA4C,EAAA,WAAS;;;qBAsItI,CA9HK,EAAA,YAAO,aAAA,GAAA,EAAvB,EA8HW,GAAA,EAAA,KAAA,GAAA,EAAA;KA5HGC,EAAAA,OAAO,QAAnB,EAAyC,EAAA,QAAA,SAAA,EAAA,KAAA,GAAA,EAAA,KAAA,GAAA,GAAA,GAE5B,EAAA,SAAA,GAAA,EADb,EAOU,IAAA;;MALP,KAAK,EAAA;MACL,UAAU,EAAA;MACV,UAAU,EAAA;;uBAEA,CAAA,EAAA,EAAR,EAAA,MAAK,EAAA,EAAA,CAAA,CAAA;;;;;;;KAGV,EAsGM,OAAA,EAtGD,OAAK,EAAA,CAAC,gCAAuC,EAAA,MAAc,CAAA,EAAA,EAAA;MAC9D,EAAuB,EAAA,QAAA,WAAA,EAAA,EAAA,KAAA,GAAA,GAAA;MAKZ,EAAA,SAAA,GAAA,EAAX,EA+CM,OA/CN,KA+CM,CA7CJ,EAKE,OAAA;gBAJI;OAAJ,KAAI;OACJ,OAAM;OACN,eAAY;OACZ,WAAQ,EAAA;wBAIF,EAAA,aAAA,GAAA,EADR,EAmBE,YAnBF,EAmBE;;OAjBC,IAAI,EAAA;gBACD;OAAJ,KAAI;SACIC,EAAAA,QAAM;OACd,OAAM;OACL,OAAO,EAAA;OACP,aAAa,EAAA;OACb,UAAU,EAAA;OACV,UAAU,EAAA;OACV,MAAM,EAAA;OACN,WAAW,EAAA;OACZ,YAAW;OACX,cAAa;OACb,aAAY;OACX,SAAK,AAAA,EAAA,QAAA,MAAE,EAAA,QAAS,EAAO,OAA+B;OACtD,SAAK,AAAA,EAAA,QAAA,MAAE,EAAA,QAAO;OACd,QAAI,AAAA,EAAA,QAAA,MAAE,EAAA,QAAO;OACb,UAAQ;kCAEX,EAiBE,SAjBF,EAiBE;;OAfC,IAAI,EAAA;gBACD;OAAJ,KAAI;SACIA,EAAAA,QAAM;OACd,MAAK;OACL,OAAM;OACL,OAAO,EAAA;OACP,aAAa,EAAA;OACb,UAAU,EAAA;OACV,UAAU,EAAA;OACV,MAAM,EAAA;OACN,WAAW,EAAA;OACZ,YAAW;OACV,SAAK,AAAA,EAAA,QAAA,MAAE,EAAA,QAAS,EAAO,OAA4B;OACnD,SAAK,AAAA,EAAA,QAAA,MAAE,EAAA,QAAO;OACd,QAAI,AAAA,EAAA,QAAA,MAAE,EAAA,QAAO;qCAKlB,EAqCW,GAAA,EAAA,KAAA,GAAA,EAAA,CAnCD,EAAA,YAAA,GAAA,GAAA,EADR,EAeE,YAfF,EAeE;;OAbC,IAAI,EAAA;gBACD;OAAJ,KAAI;SACIA,EAAAA,QAAM;gDACA,QAAA;OACd,OAAM;OACL,aAAa,EAAA;OACb,UAAU,EAAA;OACV,UAAU,EAAA;OACV,MAAM,EAAA;OACN,WAAW,EAAA;OACX,MAAM,EAAA;OACN,SAAK,AAAA,EAAA,QAAA,MAAE,EAAA,QAAO;OACd,QAAI,AAAA,EAAA,QAAA,MAAE,EAAA,QAAO;gCATL,EAAA,MAAK,CAAA,CAAA,GAAA,GAAA,GAAA,EAWhB,EAmBE,SAnBF,EAmBE;;OAjBC,IAAI,EAAA;gBACD;OAAJ,KAAI;SACIA,EAAAA,QAAM;gDACA,QAAA;OACd,OAAM;OACL,MAAM,EAAA;OACN,aAAa,EAAA;OACb,UAAU,EAAA;OACV,UAAU,EAAA;OACV,UAAU,EAAA;OACV,MAAM,EAAA;OACN,KAAK,EAAA;OACL,KAAK,EAAA;OACL,MAAM,EAAA;OACN,WAAW,EAAA;OACX,SAAK,AAAA,EAAA,SAAA,MAAE,EAAA,QAAO;OACd,QAAI,AAAA,EAAA,SAAA,MAAE,EAAA,QAAO;gCAbL,EAAA,MAAK,CAAA,CAAA,CAAA,EAAA,GAAA;MAiBlB,EAAwB,EAAA,QAAA,YAAA,EAAA,EAAA,KAAA,GAAA,GAAA;MAIbD,EAAAA,OAAO,WAAA,GAAA,EAAlB,EAEM,OAFN,KAEM,CADJ,EAAuB,EAAA,QAAA,WAAA,EAAA,EAAA,KAAA,GAAA,GAAA,CAAA,CAAA,IAAA,EAAA,IAAA,GAAA;;KAKnB,EAAA,SAAA,GAAA,EADR,EAMY,IAAA;;MAJT,SAAS,EAAA;MACV,OAAM;;uBAEW,CAAA,EAAA,EAAd,EAAA,MAAW,EAAA,EAAA,CAAA,CAAA;;;KAIhB,EAAwB,EAAA,QAAA,YAAA,EAAA,EAAA,KAAA,GAAA,GAAA;cAIL,EAAA,YAAO,WAAA,GAAA,EAC1B,EA8CM,OAAA;;KA9CD,OAAK,EAAA,CAAC,gCAAuC,EAAA,MAAc,CAAA;QACnD,EAAA,SAASA,EAAAA,OAAO,SAAA,GAAA,EAA3B,EAwBM,OAxBN,KAwBM,CAvBQA,EAAAA,OAAO,QAAnB,EAAyC,EAAA,QAAA,SAAA,EAAA,KAAA,GAAA,EAAA,KAAA,GAAA,GAAA,IAAA,GAAA,EACzC,EAaQ,SAAA;;KAXL,KAAK,EAAA;KACN,OAAK,EAAA,CAAC,8BAA4B,EAAA,wCACgB,EAAA,UAAQ,CAAA,CAAA;YAEvD,EAAA,MAAK,GAAG,KACX,EAAA,EACQ,EAAA,YAAA,GAAA,EADR,EAKC,QALD,KAIG,IAAC,IAAA,EAAA,IAAA,GAAA,CAAA,EAAA,IAAA,IAAA,GAIE,EAAA,SAAA,GAAA,EADR,EAOY,IAAA;;KALT,SAAS,EAAA;KACV,aAAA;KACA,OAAM;;sBAEW,CAAA,EAAA,EAAd,EAAA,MAAW,EAAA,EAAA,CAAA,CAAA;;sDAIlB,EAkBE,SAlBF,EAkBE;KAjBC,IAAI,EAAA;cACD;KAAJ,KAAI;OACIC,EAAAA,QAAM;+CACA,QAAA;KACd,OAAM;KACL,MAAM,EAAA;KACN,aAAa,EAAA;KACb,UAAU,EAAA;KACV,UAAU,EAAA;KACV,UAAU,EAAA;KACV,MAAM,EAAA;KACN,KAAK,EAAA;KACL,KAAK,EAAA;KACL,MAAM,EAAA;KACN,WAAW,EAAA;KACX,SAAK,AAAA,EAAA,SAAA,MAAE,EAAA,QAAO;KACd,QAAI,AAAA,EAAA,SAAA,MAAE,EAAA,QAAO;6BAbL,EAAA,MAAK,CAAA,CAAA,CAAA,EAAA,EAAA,IAAA,EAAA,IAAA,GAAA,CAAA,CAAA;;;;;;;;;;;;;;;;;;;EElKxB,IAAM,IAAQ,GAgBR,IAAO,GAEP,IAAS,EAAI,GAAK,EAElB,IAAyC;GAC7C,SAAS;GACT,OAAO;GACP,SAAS;GACT,MAAM;GACR,EAEI,IAA8C,MAC9C,IAAY,EAAM,YAAY,GAC9B,IAAY;EAEhB,SAAS,IAAa;AACf,SACL,IAAY,KAAK,KAAI,EACrB,IAAQ,iBAAiB,EAAK,QAAQ,EAAE,EAAS;;EAGnD,SAAS,IAAgB;AACnB,IAAC,KAAa,EAAO,UACzB,EAAO,QAAQ,IACX,KAAO,aAAa,EAAK,EAC7B,KAAa,KAAK,KAAK,GAAG;;EAG5B,SAAS,IAAiB;AACpB,IAAC,KAAa,CAAC,EAAO,UAC1B,EAAO,QAAQ,IACf,GAAW;;SAGb,EAAU,EAAU,EACpB,QAAkB;AAChB,GAAI,KAAO,aAAa,EAAK;IAC9B,EAED,SACQ,EAAM,WACX,MAAQ;AAGP,GAFI,KAAO,aAAa,EAAK,EAC7B,IAAY,KAAO,GACnB,GAAW;IAEf,kBAIE,EAsCM,OAAA;GArCH,OAAK,EAAA,CAAA,YAAA,aAA4B,EAAA,UAAO,CAAA;GACzC,MAAK;GACJ,aAAW,EAAA,YAAO,UAAA,cAAA;GAClB,cAAY;GACZ,cAAY;;GAEb,EAEM,OAFN,KAEM,CADJ,EAA+C,IAAA;IAAtC,MAAM,EAAQ,EAAA;IAAY,MAAM;;GAE3C,EAeM,OAfN,KAeM;IAdK,EAAA,SAAA,GAAA,EAAT,EAAuD,KAAvD,KAAuD,EAAZ,EAAA,MAAK,EAAA,EAAA,IAAA,EAAA,IAAA,GAAA;IAChD,EAA8C,KAA9C,KAA8C,EAAd,EAAA,QAAO,EAAA,EAAA;IAE/B,EAAA,OAAA,GAAA,EADR,EAWS,UAAA;;KATP,OAAM;KACL,SAAK,AAAA,EAAA,aAAA;AAAiE,MAAhC,EAAA,OAAO,EAAA,IAAI,QAAM,EAAe,EAAI,QAAA;;SAOxE,EAAA,IAAI,MAAK,EAAA,EAAA,IAAA,EAAA,IAAA,GAAA;;GAGhB,EAES,UAAA;IAFD,OAAM;IAAkB,cAAW;IAAS,SAAK,AAAA,EAAA,QAAA,MAAE,EAAI,QAAA;OAC7D,EAA8B,IAAA;IAAtB,MAAK;IAAK,MAAM;;GAGlB,EAAA,YAAA,GAAA,EADR,EAQE,OAAA;;IANA,KAAI;IACJ,OAAM;IACL,OAAK,EAAA;2BAAkC,EAAA,SAAQ;yBAAkC,EAAA,QAAM,WAAA;;;;;qHE5GxF,KAAkC,uBAAA,OAAA;CAAA,iBAAA;CAAA,eAAA;CAAA,qBAAA;CAAA,gBAAA;CAAA,kBAAA;CAAA,oBAAA;CAAA,sBAAA;CAAA,cAAA;CAAA,cAAA;CAAA,cAAA;CAAA,cAAA;CAAA,sBAAA;CAAA,kBAAA;CAAA,eAAA;CAAA,iBAAA;CAAA,eAAA;CAAA,qBAAA;CAAA,eAAA;CAAA,eAAA;CAAA,gBAAA;CAAA,gBAAA;CAAA,gBAAA;CAAA,mBAAA;CAAA,eAAA;CAAA,CAEtC,EAEF,MAAe,EACb,QAAQ,GAAU;AAChB,QAAO,KAAK,GAAW,CAAC,SAAS,MAAQ;AACvC,MAAI,EAAI,SAAS,SAAS,CAAE;EAE5B,IAAM,IAAO,KAAK,EAAI,QAAQ,uBAAuB,KAAK,IACpD,IAAY,GAAW;AAC7B,IAAI,UAAU,GAAM,EAAU,QAAQ;GACtC;GAEL;;;AChBD,SAAgB,GAAW,GAAwB;AACjD,KAAI,CAAC,EAAQ,QAAO;CAGpB,IAAM,IACJ,oFAGI,IAA2B,OAAO,IAAI,EAAmB,IAAI,IAAI,EAGjE,IAAiB,OAAO,IAAI,EAAmB,IAAI,KAAK;AAI9D,QAFc,EAAO,MAAM,EAAW,CAGnC,KAAK,MAEA,EAAqB,KAAK,EAAK,GAC1B,IAGF,EACJ,WAAW,kCAAkC,QAAQ,CACrD,WAAW,KAAK,OAAO,CACvB,WAAW,KAAK,OAAO,CACvB,WAAW,MAAK,SAAS,CACzB,WAAW,KAAK,SAAS,CACzB,WAAW,MAAM,OAAO,CAC3B,CACD,KAAK,GAAG;;;;oDCAP,qBAAqB,IAAI,KAAK,EAM9B,MACJ,MACW;AACX,KAAI,MAAM,QAAQ,EAAQ,CACxB,QAAO,EAAQ,KAAK,MAAS,GAAqB,EAAK,CAAC,CAAC,KAAK,GAAG;AAGnE,KAAI,CAAC,KAAW,OAAO,KAAY,YAAY,CAAC,EAAQ,UACtD,QAAO;CAGT,IAAM,EAAE,cAAW,WAAQ,EAAE,EAAE,aAAU,SAAS,MAAgB,GAE5D,IAAe,MAAa,KAAA,IAAuB,IAAX,GAExC,IAAW,OAAO,QAAQ,EAAM,CACnC,KAAK,CAAC,GAAK,OAAW,GAAG,EAAI,IAAI,GAAW,OAAO,EAAM,CAAC,CAAC,GAAG,CAC9D,KAAK,IAAI,EAEN,IAAe,MAAM,QAAQ,EAAa,GAC5C,GAAqB,EAAa,GAClC,MAAiB,KAAA,IAEf,KADA,GAAW,OAAO,EAAa,CAAC;AAGtC,QAAO,IAAI,IAAY,IAAW,IAAI,MAAa,GAAG,GAAG,EAAa,IAAI,EAAU;GAMhF,MACJ,MAEK,IAED,OAAO,KAAY,WACd,GAAW,EAAQ,GAGxB,MAAM,QAAQ,EAAQ,GACjB,GAAqB,EAAQ,GAG/B,KAVc,IAajB,MAAoB,MAAa;CACrC,IAAM,IAAS,EAAI,OAAO,iBAAiB;AAS3C,CAPI,KACF,EAAO,iBAAiB;AAEtB,EADA,GAAmB,SAAS,MAAY,GAAI,kBAAkB,EAAE,CAAC,EACjE,GAAmB,OAAO;GAC1B,EAGJ,EAAI,UAAU,cAAc;EAC1B,QAAQ,GAAgB,GAA4C;GAClE,IAAI;AAkCJ,GAhCA,EAAG,wBAAwB;AAEzB,IADA,aAAa,EAAU,EACnB,EAAG,sBAAoB,IAAY,GAAI,EAAG,mBAAmB;MAGnE,EAAG,mBAAmB,IAAQ,QAAQ;AAEpC,QAAY,iBAAiB;AAC3B,QAAY,GAAI,KAAS,EAAE;OAC1B,EAAM;MAGX,EAAG,iBAAiB,MAAsB;AAGxC,IAFA,EAAG,aAAa,EAAM,SACtB,EAAG,aAAa,EAAM,SAClB,EAAQ,OAAO,gBACjB,GACE,GACA,EAAG,gBACH,EAAG,oBAAoB,SACxB;MAIL,EAAG,qBAAqB,EAAQ,OAEhC,EAAG,wBAAwB,EAAG,mBAAmB,EACjD,EAAG,wBAAwB,EAAG,mBAAmB,EAEjD,EAAG,iBAAiB,cAAc,EAAG,gBAAgB,EACrD,EAAG,iBAAiB,cAAc,EAAG,gBAAgB,EACrD,EAAG,iBAAiB,aAAa,EAAG,cAA+B,EACnE,OAAO,iBAAiB,UAAU,EAAG,gBAAgB;;EAGvD,QAAQ,GAAgB,GAA4C;AAElE,GADA,EAAG,qBAAqB,EAAQ,OAC3B,EAAQ,QAEF,EAAG,kBACZ,IAAc,GAAI,EAAQ,MAAM,GAFhC,GAAY,GAAI,GAAK;;EAMzB,UAAU,GAAgB;AAMxB,GALA,GAAY,GAAI,GAAK,EACjB,EAAG,mBACL,EAAG,oBAAoB,cAAc,EAAG,gBAAgB,EACtD,EAAG,mBACL,EAAG,oBAAoB,cAAc,EAAG,gBAAgB,EACtD,EAAG,mBACL,OAAO,oBAAoB,UAAU,EAAG,gBAAgB;;EAE7D,CAAC;GAGE,MAAwB,EAC5B,YAAS,IACT,UAAO,IACP,SAAM,SAEC;;uCAE8B,GAAqB,EAAO,CAAC;qCAC/B,GAAqB,EAAK,CAAC;oCAC5B,GAAqB,EAAI,CAAC;;KAKxD,OACJ,GACA,EACE,WACA,SACA,QACA,YAAS,WACT,WAAQ,KACR,mBAAgB,KAChB,aACA,iBACA,oBAEC;CAEH,IAAM,IAAkB,EAAG;AAK3B,KAJI,KACF,EAAgB,QAAQ,EAGtB,GAAc;EAChB,IAAM,IAAO,EAAG,uBAAuB;AAEvC,MAAI,EADkB,KAAK,MAAM,EAAK,MAAM,GAAG,KAAK,MAAM,EAAG,YAAY,EAEvE;;AAIE,OAAQ,KAAU,OAIxB,EAAG,gBAAgB,iBAAiB;EAClC,IAAM,IAAU,SAAS,cAAc,OAAO;AAU9C,EATA,EAAQ,MAAM,aAAa,WAAW,EAAc,iBACpD,EAAQ,YAAY,yBAAyB,EAAS,GAAG,IAAS,qBAAqB,MAAW,GAAG,GAAG,KAAc,MACtH,EAAQ,YAAY,GAAqB;GAAE;GAAQ;GAAM;GAAK,CAAC,EAC/D,EAAQ,MAAM,YAAY,iBAAiB,EAAc,0BAEzD,EAAG,iBAAiB,GACpB,GAAmB,IAAI,EAAG,EAE1B,SAAS,KAAK,YAAY,EAAQ,EAClC,GAAgB,GAAI,GAAS,EAAS;IACrC,EAAM;GAGL,MAAe,GAAgB,IAAY,OAAU;CAEzD,IAAM,IAAU,EAAG;AAInB,CAFA,aAAa,EAAG,cAAc,EAE1B,MACE,IACF,EAAQ,QAAQ,IAEhB,EAAQ,MAAM,YAAY,+CAC1B,iBAAiB;AACf,IAAQ,QAAQ;IACf,IAAI,GAET,GAAmB,OAAO,EAAG;GAI3B,OACJ,GACA,EAAE,WAAQ,SAAM,QAAK,kBAClB;CAEH,IAAM,IAAU,EAAG;AAEnB,CAAI,MACF,EAAQ,YAAY,GAAqB;EACvC;EACA;EACA;EACD,CAAC,EACF,GAAgB,GAAI,GAAS,EAAS;GAIpC,MACJ,GACA,GACA,MACG;CACH,IACM,IAAO,EAAG,uBAAuB,EACjC,IAAc,GAAS,uBAAuB,EAC9C,IAAe,GAAa,SAAS,GACrC,IAAgB,GAAa,UAAU,GACvC,IAAkB,EAAG,WACrB,IAAmB,EAAG,YACxB,GAAK;AAET,SAAQ,GAAR;EACE,KAAK;AAEH,GADA,IAAM,EAAK,OAAO,IAAgB,KAAW,GAC7C,IACE,EAAK,OACL,EAAK,QAAQ,KACZ,IAAe,IAAI,IAAM,KAC1B;AACF;EACF,KAAK;AAEH,GADA,IAAM,EAAK,SAAS,IAAM,GAC1B,IACE,EAAK,OACL,EAAK,QAAQ,KACZ,IAAe,IAAI,IAAM,KAC1B;AACF;EACF,KAAK;AAEH,GADA,IAAM,EAAK,MAAM,EAAK,SAAS,IAAI,IAAgB,IAAI,GACvD,IAAO,EAAK,QAAQ,IAAe,KAAW;AAC9C;EACF,KAAK;AAEH,GADA,IAAM,EAAK,MAAM,EAAK,SAAS,IAAI,IAAgB,IAAI,GACvD,IAAO,EAAK,QAAQ,IAAM;AAC1B;EAEF;AAEE,GADA,KAAO,EAAG,cAAc,KAAK,GAC7B,KAAQ,EAAG,cAAc,KAAK;AAC9B;;AAGJ,CAAI,MACF,EAAQ,MAAM,MAAM,GAAG,EAAI,KAC3B,EAAQ,MAAM,OAAO,GAAG,EAAK;GCtS3B,MAAU,uBAAA,OAAA,EAAA,0BAAA,KAAA,CAAgE,EAEhF,MAAe,EACb,QAAQ,GAAU;AAChB,QAAO,OAAO,IAAQ,CAAC,SAAS,MAAQ;AACtC,EAAI,OAAO,EAAI,WAAY,cACzB,EAAI,QAAQ,EAAI;GAElB;GAEL,ECZK,KAAsC,uBAAA,OAAA,EAAA,CAG3C,EAED,MAAe,EACb,QAAQ,GAAU;AAChB,QAAO,KAAK,GAAe,CAAC,SAAS,MAAQ;EAC3C,IAAM,IAAO,KAAK,EAAI,QAAQ,uBAAuB,KAAK,IACpD,IAAY,GAAe;AACjC,IAAI,UAAU,GAAM,EAAU,QAAQ;GACtC;GAEL,ECXD,MAAe,EACb,QAAQ,GAAU;AAEhB,CADA,EAAI,IAAI,IAAW,EACnB,EAAI,IAAI,IAAW;GAEtB"}