tide-design-system 2.4.2 → 2.4.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (45) hide show
  1. package/README.md +10 -9
  2. package/dist/css/fonts.css +36 -0
  3. package/dist/css/grid-layout.css +34 -0
  4. package/dist/css/main.css +5 -0
  5. package/dist/css/realm/aero.css +25 -0
  6. package/dist/css/realm/atv.css +25 -0
  7. package/dist/css/realm/boatmart.css +25 -0
  8. package/dist/css/realm/cycle.css +24 -0
  9. package/dist/css/realm/equipment.css +25 -0
  10. package/dist/css/realm/pwc.css +25 -0
  11. package/dist/css/realm/rv.css +25 -0
  12. package/dist/css/realm/snow.css +25 -0
  13. package/dist/css/realm/truck.css +25 -0
  14. package/dist/css/reset.css +95 -0
  15. package/dist/css/storybook.css +17 -0
  16. package/dist/css/utilities-base.css +545 -0
  17. package/dist/css/utilities-responsive.css +2737 -0
  18. package/dist/css/utilities.css +16 -0
  19. package/dist/css/variables.css +205 -0
  20. package/dist/style.css +1 -1
  21. package/dist/tide-design-system.cjs +2 -2
  22. package/dist/tide-design-system.esm.d.ts +2 -0
  23. package/dist/tide-design-system.esm.js +5 -5
  24. package/dist/utilities/event.ts +4 -0
  25. package/dist/utilities/format.ts +184 -0
  26. package/dist/utilities/forms.ts +22 -0
  27. package/dist/utilities/storybook.ts +352 -0
  28. package/dist/utilities/validation-deprecated.ts +252 -0
  29. package/dist/utilities/validation.ts +132 -0
  30. package/dist/utilities/viewport.ts +63 -0
  31. package/{src/docs → docs}/integration-full.md +1 -1
  32. package/{src/docs → docs}/integration-partial.md +1 -1
  33. package/docs/token-cheatsheet.md +63 -0
  34. package/package.json +2 -2
  35. package/src/components/TideInputRadioDeprecated.vue +1 -0
  36. package/src/components/TideInputTextDeprecated.vue +1 -0
  37. /package/{src/docs → docs}/assets/native-input-validation.png +0 -0
  38. /package/{src/docs → docs}/development.md +0 -0
  39. /package/{src/docs → docs}/figma.md +0 -0
  40. /package/{src/docs → docs}/forms.md +0 -0
  41. /package/{src/docs → docs}/migration.md +0 -0
  42. /package/{src/docs → docs}/storybook.md +0 -0
  43. /package/{src/docs → docs}/style-guide.md +0 -0
  44. /package/{src/docs → docs}/upgrading.md +0 -0
  45. /package/{src/docs → docs}/workflows.md +0 -0
@@ -2080,7 +2080,7 @@ const Zs = ["for"], js = ["checked", "disabled", "name", "id"], Js = /* @__PURE_
2080
2080
  disabled: { type: Boolean, default: !1 },
2081
2081
  inputId: { default: void 0 },
2082
2082
  label: { default: void 0 },
2083
- name: {},
2083
+ name: { default: void 0 },
2084
2084
  number: { default: void 0 }
2085
2085
  },
2086
2086
  setup(s) {
@@ -2147,7 +2147,7 @@ const Zs = ["for"], js = ["checked", "disabled", "name", "id"], Js = /* @__PURE_
2147
2147
  ], 10, ri)
2148
2148
  ], 2));
2149
2149
  }
2150
- }), nn = /* @__PURE__ */ x(di, [["__scopeId", "data-v-9fc90442"]]), an = {
2150
+ }), nn = /* @__PURE__ */ x(di, [["__scopeId", "data-v-bde66757"]]), an = {
2151
2151
  NUMBER: oe,
2152
2152
  PHONE: vs,
2153
2153
  PRICE: As
@@ -2742,7 +2742,7 @@ const mi = ["for"], gi = ["disabled", "name", "required", "id"], pi = ["label"],
2742
2742
  label: { default: void 0 },
2743
2743
  maxlength: { default: void 0 },
2744
2744
  minlength: { default: void 0 },
2745
- name: {},
2745
+ name: { default: void 0 },
2746
2746
  prefix: { default: void 0 },
2747
2747
  required: { type: Boolean, default: !1 },
2748
2748
  suffix: { default: void 0 },
@@ -2917,7 +2917,7 @@ const mi = ["for"], gi = ["disabled", "name", "required", "id"], pi = ["label"],
2917
2917
  ], 2)) : g("", !0)
2918
2918
  ], 2));
2919
2919
  }
2920
- }), un = /* @__PURE__ */ x(Gi, [["__scopeId", "data-v-fde9724b"]]), xi = ["for"], wi = ["maxlength", "minlength", "name", "required", "rows", "id"], Hi = /* @__PURE__ */ P({
2920
+ }), un = /* @__PURE__ */ x(Gi, [["__scopeId", "data-v-c4cc73ca"]]), xi = ["for"], wi = ["maxlength", "minlength", "name", "required", "rows", "id"], Hi = /* @__PURE__ */ P({
2921
2921
  __name: "TideInputTextarea",
2922
2922
  props: /* @__PURE__ */ ue({
2923
2923
  error: { default: "" },
@@ -4667,4 +4667,4 @@ export {
4667
4667
  ln as VALIDATOR,
4668
4668
  en as useTideForm
4669
4669
  };
4670
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"tide-design-system.esm.js","sources":["../src/types/Orientation.ts","../src/types/Styles.ts","../src/components/TideDivider.vue","../src/types/Realm.ts","../src/types/Size.ts","../src/utilities/format.ts","../src/components/TideIcon.vue","../src/types/Icon.ts","../src/components/TideAccordionItem.vue","../src/types/Element.ts","../src/types/Priority.ts","../src/types/Target.ts","../src/components/TideButtonIcon.vue","../src/types/Alert.ts","../src/components/TideAlert.vue","../src/types/Badge.ts","../src/components/TideBadge.vue","../src/components/TideBadgeTrustedPartner.vue","../src/components/TideBadgeVerifiedVehicle.vue","../src/components/TideBreadCrumbs.vue","../src/components/TideButton.vue","../src/components/TideButtonPagination.vue","../src/components/TideButtonSegmented.vue","../src/types/Card.ts","../src/components/TideCard.vue","../src/components/TideCarousel.vue","../src/components/TideChipAction.vue","../src/components/TideChipFilter.vue","../src/components/TideChipInput.vue","../src/components/TideColumns.vue","../src/types/Image.ts","../src/components/TideImage.vue","../src/components/TideImageBackground.vue","../src/components/TideIndicator.vue","../src/components/TideInputSupportingText.vue","../src/composables/useTideForm.ts","../src/utilities/validation.ts","../src/components/TideInputCheckbox.vue","../src/components/TideInputCheckboxDeprecated.vue","../src/components/TideInputRadio.vue","../src/components/TideInputRadioDeprecated.vue","../src/types/Formatted.ts","../src/types/Validation.ts","../src/components/TideInputSelect.vue","../src/utilities/validation-deprecated.ts","../src/components/TideInputSelectDeprecated.vue","../src/types/TextInput.ts","../src/utilities/forms.ts","../src/components/TideInputText.vue","../src/components/TideInputTextDeprecated.vue","../src/components/TideInputTextarea.vue","../src/components/TideInputTextareaDeprecated.vue","../src/components/TideLink.vue","../src/types/Breakpoint.ts","../src/utilities/viewport.ts","../src/components/TideModal.vue","../src/components/TidePagination.vue","../node_modules/@floating-ui/utils/dist/floating-ui.utils.mjs","../node_modules/@floating-ui/core/dist/floating-ui.core.mjs","../node_modules/@floating-ui/utils/dist/floating-ui.utils.dom.mjs","../node_modules/@floating-ui/dom/dist/floating-ui.dom.mjs","../node_modules/@floating-ui/vue/dist/floating-ui.vue.mjs","../src/utilities/event.ts","../src/components/TidePopover.vue","../src/components/TideSeoLinks.vue","../src/components/TideSheet.vue","../src/components/TideSwitch.vue"],"sourcesContent":["export const ORIENTATION = {\n  HORIZONTAL: 'horizontal',\n  VERTICAL: 'vertical',\n} as const;\n\nexport type Orientation = (typeof ORIENTATION)[keyof typeof ORIENTATION];\n","/* eslint-disable vue/sort-keys */\n\nimport type { Breakpoint } from '@/types/Breakpoint';\n\nexport const CSS = {\n  withBreakpoint: (utilities: string[], breakpoint: Breakpoint): string[] => {\n    return utilities.map((utility) => `${breakpoint}-${utility}`);\n  },\n  ALIGN: {\n    X: {\n      CENTER: 'tide-text-center',\n      JUSTIFY: 'tide-text-justify',\n      LEFT: 'tide-text-left',\n      RIGHT: 'tide-text-right',\n    },\n    Y: {\n      INITIAL: 'tide-align-initial',\n      MIDDLE: 'tide-align-middle',\n    },\n  },\n  AXIS1: {\n    AROUND: 'tide-axis1-around',\n    BETWEEN: 'tide-axis1-between',\n    CENTER: 'tide-axis1-center',\n    END: 'tide-axis1-end',\n    START: 'tide-axis1-start',\n  },\n  AXIS2: {\n    AROUND: 'tide-axis2-around',\n    CENTER: 'tide-axis2-center',\n    END: 'tide-axis2-end',\n    START: 'tide-axis2-start',\n    STRETCH: 'tide-axis2-stretch',\n  },\n  BG: {\n    GLOBAL: {\n      PRIMARY: {\n        ERROR: 'tide-bg-primary-error',\n        INFO: 'tide-bg-primary-info',\n        SUCCESS: 'tide-bg-primary-success',\n        WARNING: 'tide-bg-primary-warning',\n      },\n      SURFACE: {\n        ERROR: 'tide-bg-surface-error',\n        INFO: 'tide-bg-surface-info',\n        SUCCESS: 'tide-bg-surface-success',\n        WARNING: 'tide-bg-surface-warning',\n\n        BLUE: 'tide-bg-surface-blue',\n        GREEN: 'tide-bg-surface-green',\n        LIME: 'tide-bg-surface-lime',\n        ORANGE: 'tide-bg-surface-orange',\n        PURPLE: 'tide-bg-surface-purple',\n        RED: 'tide-bg-surface-red',\n        SALMON: 'tide-bg-surface-salmon',\n        TEAL: 'tide-bg-surface-teal',\n        YELLOW: 'tide-bg-surface-yellow',\n      },\n    },\n    INITIAL: 'tide-bg-initial',\n    BLUR: 'tide-bg-blur',\n    PRIMARY: 'tide-bg-primary',\n    SECONDARY: 'tide-bg-secondary',\n    SURFACE: {\n      ACCENT: 'tide-bg-surface-accent',\n      BRAND: 'tide-bg-surface-brand',\n      DEFAULT: 'tide-bg-surface',\n      FLOATING: 'tide-bg-surface-floating',\n      GRADIENT: 'tide-bg-surface-gradient',\n      VARIANT: 'tide-bg-surface-variant',\n    },\n    TRANSPARENT: {\n      ONE_HUNDRED: 'tide-transparent-100',\n      TWO_HUNDRED: 'tide-transparent-200',\n      THREE_HUNDRED: 'tide-transparent-300',\n      FOUR_HUNDRED: 'tide-transparent-400',\n    },\n  },\n  BORDER: {\n    COLOR: {\n      GLOBAL: {\n        ERROR: 'tide-border-error',\n        INFO: 'tide-border-info',\n        SUCCESS: 'tide-border-success',\n        WARNING: 'tide-border-warning',\n\n        BLUE: 'tide-border-blue',\n        GREEN: 'tide-border-green',\n        LIME: 'tide-border-lime',\n        ORANGE: 'tide-border-orange',\n        PURPLE: 'tide-border-purple',\n        RED: 'tide-border-red',\n        SALMON: 'tide-border-salmon',\n        TEAL: 'tide-border-teal',\n        YELLOW: 'tide-border-yellow',\n      },\n      INITIAL: 'tide-border-color-initial',\n      DEFAULT: 'tide-border',\n      FLOATING: 'tide-border-floating',\n      HIGH: 'tide-border-high',\n      LOW: 'tide-border-low',\n      PRIMARY: 'tide-border-primary',\n    },\n    RADIUS: {\n      ZERO: 'tide-radius-0',\n      QUARTER: 'tide-radius-1/4',\n      HALF: 'tide-radius-1/2',\n      ONE: 'tide-radius-1',\n      FULL: 'tide-radius-full',\n    },\n    STYLE: {\n      DASHED: 'tide-border-dashed',\n      SOLID: 'tide-border-solid',\n    },\n    BOTTOM: {\n      ZERO: 'tide-border-bottom-0',\n      ONE: 'tide-border-bottom-1',\n      TWO: 'tide-border-bottom-2',\n    },\n    FULL: {\n      ZERO: 'tide-border-0',\n      ONE: 'tide-border-1',\n      TWO: 'tide-border-2',\n    },\n    LEFT: {\n      ZERO: 'tide-border-left-0',\n      ONE: 'tide-border-left-1',\n      TWO: 'tide-border-left-2',\n    },\n    RIGHT: {\n      ZERO: 'tide-border-right-0',\n      ONE: 'tide-border-right-1',\n      TWO: 'tide-border-right-2',\n    },\n    TOP: {\n      ZERO: 'tide-border-top-0',\n      ONE: 'tide-border-top-1',\n      TWO: 'tide-border-top-2',\n    },\n  },\n  BOX_SIZING: {\n    BORDER_BOX: 'tide-box-border',\n    CONTENT_BOX: 'tide-box-content',\n  },\n  BREAK_INSIDE: {\n    AVOID_COLUMN: 'tide-break-inside-avoid-column',\n  },\n  BREAK_WORD: {\n    OFF: 'tide-break-initial',\n    ON: 'tide-break-word',\n  },\n  COLUMNS: {\n    INITIAL: 'tide-columns-initial',\n    ONE: 'tide-columns-1',\n    TWO: 'tide-columns-2',\n    THREE: 'tide-columns-3',\n    FOUR: 'tide-columns-4',\n  },\n  CURSOR: {\n    NOT_ALLOWED: 'tide-cursor-not-allowed',\n    POINTER: 'tide-cursor-pointer',\n    TEXT: 'tide-cursor-text',\n  },\n  DISPLAY: {\n    BLOCK: 'tide-display-block',\n    CONTENTS: 'tide-display-contents',\n    FLEX: 'tide-display-flex',\n    GRID: 'tide-display-grid',\n    INITIAL: 'tide-display-initial',\n    INLINE: 'tide-display-inline',\n    INLINE_BLOCK: 'tide-display-inline-block',\n    INLINE_FLEX: 'tide-display-inline-flex',\n    NONE: 'tide-display-none',\n  },\n  ELLIPSIS: 'tide-ellipsis',\n  FLEX: {\n    BASIS: {\n      AUTO: 'tide-flex-basis-auto',\n      ZERO: 'tide-flex-basis-0',\n    },\n    DIRECTION: {\n      COLUMN: 'tide-flex-column',\n      COLUMN_REVERSE: 'tide-flex-column-reverse',\n      ROW: 'tide-flex-row',\n      ROW_REVERSE: 'tide-flex-row-reverse',\n    },\n    GROW: {\n      OFF: 'tide-grow-none',\n      ON: 'tide-grow',\n    },\n    SHRINK: {\n      OFF: 'tide-shrink-none',\n      ON: 'tide-shrink',\n    },\n    WRAP: 'tide-flex-wrap',\n  },\n  FONT: {\n    COLOR: {\n      GLOBAL: {\n        ERROR: 'tide-font-error',\n        INFO: 'tide-font-info',\n        SUCCESS: 'tide-font-success',\n        WARNING: 'tide-font-warning',\n\n        BLUE: 'tide-font-blue',\n        GREEN: 'tide-font-green',\n        LIME: 'tide-font-lime',\n        ORANGE: 'tide-font-orange',\n        PURPLE: 'tide-font-purple',\n        RED: 'tide-font-red',\n        SALMON: 'tide-font-salmon',\n        TEAL: 'tide-font-teal',\n        YELLOW: 'tide-font-yellow',\n\n        PRIMARY: {\n          BLUE: 'tide-font-primary-blue',\n          GREEN: 'tide-font-primary-green',\n          LIME: 'tide-font-primary-lime',\n          ORANGE: 'tide-font-primary-orange',\n          PURPLE: 'tide-font-primary-purple',\n          RED: 'tide-font-primary-red',\n          SALMON: 'tide-font-primary-salmon',\n          TEAL: 'tide-font-primary-teal',\n          YELLOW: 'tide-font-primary-yellow',\n        },\n      },\n      PRIMARY: 'tide-font-on-primary',\n      SECONDARY: 'tide-font-on-secondary',\n      SURFACE: {\n        BRAND: 'tide-font-on-surface-brand',\n        DEFAULT: 'tide-font-on-surface',\n        INVERSE: 'tide-font-on-surface-inverse',\n        VARIANT: 'tide-font-on-surface-variant',\n        VARIANT_INVERSE: 'tide-font-on-surface-variant-inverse',\n      },\n    },\n    ROLE: {\n      DISPLAY_1: 'tide-typography-display-1',\n      HEADLINE_1: 'tide-typography-headline-1',\n      HEADLINE_2: 'tide-typography-headline-2',\n      HEADLINE_3: 'tide-typography-headline-3',\n      TITLE_1: 'tide-typography-title-1',\n      TITLE_2: 'tide-typography-title-2',\n      BODY_1: 'tide-typography-body-1',\n      BODY_2: 'tide-typography-body-2',\n      LABEL_1: 'tide-typography-label-1',\n      LABEL_1_SEMIBOLD: 'tide-typography-label-1-semibold',\n      LABEL_2: 'tide-typography-label-2',\n      LABEL_2_SEMIBOLD: 'tide-typography-label-2-semibold',\n      LABEL_3: 'tide-typography-label-3',\n      LINK_1: 'tide-typography-link-1',\n      LINK_2: 'tide-typography-link-2',\n      LINK_3: 'tide-typography-link-3',\n      BUTTON_1: 'tide-typography-button-1',\n      BUTTON_2: 'tide-typography-button-2',\n    },\n    SIZE: {\n      TWELVE: 'tide-font-12',\n      FOURTEEN: 'tide-font-14',\n      SIXTEEN: 'tide-font-16',\n      TWENTY: 'tide-font-20',\n      TWENTY_FOUR: 'tide-font-24',\n      THIRTY_TWO: 'tide-font-32',\n    },\n    WEIGHT: {\n      FOUR_HUNDRED: 'tide-font-400',\n      FIVE_HUNDRED: 'tide-font-500',\n      SIX_HUNDRED: 'tide-font-600',\n      SEVEN_HUNDRED: 'tide-font-700',\n    },\n  },\n  GAP: {\n    ZERO: 'tide-gap-0',\n    QUARTER: 'tide-gap-1/4',\n    HALF: 'tide-gap-1/2',\n    ONE: 'tide-gap-1',\n    TWO: 'tide-gap-2',\n    FOUR: 'tide-gap-4',\n  },\n  GRID: {\n    FLUID: 'tide-fluid',\n    ITEM: 'tide-grid-item',\n    LAYOUT: 'tide-grid-layout',\n    XL: 'tide-grid-xl',\n  },\n  HEIGHT: {\n    AUTO: 'tide-height-auto',\n    ZERO: 'tide-height-0',\n    FULL: 'tide-height-full',\n    MAX_FULL: 'tide-max-height-full',\n    MIN_ZERO: 'tide-min-height-0',\n  },\n  ISOLATION: {\n    ISOLATE: 'tide-isolate',\n  },\n  LIST_BULLETS: {\n    OFF: 'tide-list-none',\n  },\n  MARGIN: {\n    BOTTOM: {\n      AUTO: 'tide-margin-bottom-auto',\n      ZERO: 'tide-margin-bottom-0',\n      QUARTER: 'tide-margin-bottom-1/4',\n      HALF: 'tide-margin-bottom-1/2',\n      ONE: 'tide-margin-bottom-1',\n      TWO: 'tide-margin-bottom-2',\n      FOUR: 'tide-margin-bottom-4',\n    },\n    FULL: {\n      ZERO: 'tide-margin-0',\n      QUARTER: 'tide-margin-1/4',\n      HALF: 'tide-margin-1/2',\n      ONE: 'tide-margin-1',\n      TWO: 'tide-margin-2',\n      FOUR: 'tide-margin-4',\n    },\n    LEFT: {\n      AUTO: 'tide-margin-left-auto',\n      ZERO: 'tide-margin-left-0',\n      QUARTER: 'tide-margin-left-1/4',\n      HALF: 'tide-margin-left-1/2',\n      ONE: 'tide-margin-left-1',\n      TWO: 'tide-margin-left-2',\n      FOUR: 'tide-margin-left-4',\n    },\n    RIGHT: {\n      AUTO: 'tide-margin-right-auto',\n      ZERO: 'tide-margin-right-0',\n      QUARTER: 'tide-margin-right-1/4',\n      HALF: 'tide-margin-right-1/2',\n      ONE: 'tide-margin-right-1',\n      TWO: 'tide-margin-right-2',\n      FOUR: 'tide-margin-right-4',\n    },\n    TOP: {\n      AUTO: 'tide-margin-top-auto',\n      ZERO: 'tide-margin-top-0',\n      QUARTER: 'tide-margin-top-1/4',\n      HALF: 'tide-margin-top-1/2',\n      ONE: 'tide-margin-top-1',\n      TWO: 'tide-margin-top-2',\n      FOUR: 'tide-margin-top-4',\n    },\n    X: {\n      AUTO: 'tide-margin-x-auto',\n      ZERO: 'tide-margin-x-0',\n      QUARTER: 'tide-margin-x-1/4',\n      HALF: 'tide-margin-x-1/2',\n      ONE: 'tide-margin-x-1',\n      TWO: 'tide-margin-x-2',\n      FOUR: 'tide-margin-x-4',\n    },\n    Y: {\n      ZERO: 'tide-margin-y-0',\n      QUARTER: 'tide-margin-y-1/4',\n      HALF: 'tide-margin-y-1/2',\n      ONE: 'tide-margin-y-1',\n      TWO: 'tide-margin-y-2',\n      FOUR: 'tide-margin-y-4',\n    },\n  },\n  OBJECT: {\n    CENTER: 'tide-object-center',\n    CONTAIN: 'tide-object-contain',\n    COVER: 'tide-object-cover',\n    SCALE_DOWN: 'tide-object-scale-down',\n  },\n  OPACITY: {\n    DISABLED: 'tide-opacity-disabled',\n    OFF: 'tide-opacity-none',\n    ON: 'tide-opacity',\n  },\n  OVERFLOW: {\n    X: {\n      AUTO: 'tide-x-auto',\n      HIDDEN: 'tide-x-hidden',\n      SCROLL: 'tide-x-scroll',\n    },\n    XY: {\n      AUTO: 'tide-xy-auto',\n      HIDDEN: 'tide-xy-hidden',\n    },\n    Y: {\n      AUTO: 'tide-y-auto',\n      HIDDEN: 'tide-y-hidden',\n    },\n  },\n  PADDING: {\n    BOTTOM: {\n      ZERO: 'tide-padding-bottom-0',\n      QUARTER: 'tide-padding-bottom-1/4',\n      HALF: 'tide-padding-bottom-1/2',\n      ONE: 'tide-padding-bottom-1',\n      TWO: 'tide-padding-bottom-2',\n      FOUR: 'tide-padding-bottom-4',\n    },\n    FULL: {\n      ZERO: 'tide-padding-0',\n      QUARTER: 'tide-padding-1/4',\n      HALF: 'tide-padding-1/2',\n      ONE: 'tide-padding-1',\n      TWO: 'tide-padding-2',\n      FOUR: 'tide-padding-4',\n    },\n    LEFT: {\n      ZERO: 'tide-padding-left-0',\n      QUARTER: 'tide-padding-left-1/4',\n      HALF: 'tide-padding-left-1/2',\n      ONE: 'tide-padding-left-1',\n      TWO: 'tide-padding-left-2',\n      FOUR: 'tide-padding-left-4',\n    },\n    RIGHT: {\n      ZERO: 'tide-padding-right-0',\n      QUARTER: 'tide-padding-right-1/4',\n      HALF: 'tide-padding-right-1/2',\n      ONE: 'tide-padding-right-1',\n      TWO: 'tide-padding-right-2',\n      FOUR: 'tide-padding-right-4',\n    },\n    TOP: {\n      ZERO: 'tide-padding-top-0',\n      QUARTER: 'tide-padding-top-1/4',\n      HALF: 'tide-padding-top-1/2',\n      ONE: 'tide-padding-top-1',\n      TWO: 'tide-padding-top-2',\n      FOUR: 'tide-padding-top-4',\n    },\n    X: {\n      ZERO: 'tide-padding-x-0',\n      QUARTER: 'tide-padding-x-1/4',\n      HALF: 'tide-padding-x-1/2',\n      ONE: 'tide-padding-x-1',\n      TWO: 'tide-padding-x-2',\n      FOUR: 'tide-padding-x-4',\n    },\n    Y: {\n      ZERO: 'tide-padding-y-0',\n      QUARTER: 'tide-padding-y-1/4',\n      HALF: 'tide-padding-y-1/2',\n      ONE: 'tide-padding-y-1',\n      TWO: 'tide-padding-y-2',\n      FOUR: 'tide-padding-y-4',\n    },\n  },\n  POINTER_EVENTS: {\n    OFF: 'tide-pointer-events-none',\n    ON: 'tide-pointer-events',\n  },\n  POSITION: {\n    ABSOLUTE: 'tide-position-absolute',\n    FIXED: 'tide-position-fixed',\n    RELATIVE: 'tide-position-relative',\n    STATIC: 'tide-position-static',\n    STICKY: 'tide-position-sticky',\n  },\n  POSITIONING: {\n    BOTTOM: 'tide-bottom-0',\n    LEFT: 'tide-left-0',\n    RIGHT: 'tide-right-0',\n    TOP: 'tide-top-0',\n  },\n  RATIO: {\n    ONE_TO_ONE: 'tide-ratio-1/1',\n    SIXTEEN_TO_NINE: 'tide-ratio-16/9',\n    THREE_TO_TWO: 'tide-ratio-3/2',\n  },\n  SCROLLBAR: {\n    OFF: 'tide-scrollbar-none',\n  },\n  SHADOW: {\n    INITIAL: 'tide-shadow-initial',\n    BOTTOM: 'tide-shadow-bottom',\n    TOP: 'tide-shadow-top',\n    TEXT: 'tide-shadow-text',\n  },\n  SNAP: {\n    ON: 'tide-scroll-snap',\n  },\n  SNAP_ALIGN: {\n    START: 'tide-scroll-snap-start',\n  },\n  STRIKETHROUGH: {\n    OFF: 'tide-strikethrough-none',\n    ON: 'tide-strikethrough',\n  },\n  TEXT_TRANSFORM: {\n    LOWER: 'tide-text-transform-lower',\n    NONE: 'tide-text-transform-none',\n    UPPER: 'tide-text-transform-upper',\n  },\n  UNDERLINE: {\n    HOVER: {\n      ON: 'tide-underline-hover',\n      OFF: 'tide-underline-hover-none',\n    },\n    REST: {\n      ON: 'tide-underline',\n      OFF: 'tide-underline-none',\n    },\n  },\n  USER_SELECT: {\n    INITIAL: 'tide-user-select-initial',\n    NONE: 'tide-user-select-none',\n  },\n  VISIBILITY: {\n    OFF: 'tide-visible-none',\n    ON: 'tide-visible',\n  },\n  WHITESPACE_WRAP: {\n    OFF: 'tide-whitespace-nowrap',\n  },\n  WIDTH: {\n    AUTO: 'tide-width-auto',\n    ZERO: 'tide-width-0',\n    FULL: 'tide-width-full',\n    MAX_FULL: 'tide-max-width-full',\n    MIN_ZERO: 'tide-min-width-0',\n  },\n  Z_INDEX: {\n    INITIAL: 'tide-z-index-initial',\n    ONE: 'tide-z-index-1',\n  },\n} as const;\n","<script lang=\"ts\" setup>\n  import { ORIENTATION } from '@/types/Orientation';\n  import { CSS } from '@/types/Styles';\n\n  import type { Orientation } from '@/types/Orientation';\n\n  type Props = {\n    orientation?: Orientation;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    orientation: ORIENTATION.HORIZONTAL,\n  });\n</script>\n\n<template>\n  <div :class=\"['tide-divider']\">\n    <div\n      :class=\"[\n        CSS.BORDER.COLOR.LOW,\n        props.orientation === ORIENTATION.HORIZONTAL\n          ? [CSS.MARGIN.Y.HALF, CSS.BORDER.BOTTOM.ONE, CSS.WIDTH.FULL]\n          : [CSS.MARGIN.X.HALF, CSS.BORDER.RIGHT.ONE, CSS.HEIGHT.FULL],\n      ]\"\n    />\n  </div>\n</template>\n\n<style scoped>\n  .tide-divider {\n    align-self: stretch;\n  }\n</style>\n","export const REALM = {\n  AERO: 'aero',\n  ATV: 'atv',\n  BOATMART: 'boatmart',\n  CYCLE: 'cycle',\n  EQUIPMENT: 'equipment',\n  PWC: 'pwc',\n  RV: 'rv',\n  SNOW: 'snow',\n  TRUCK: 'truck',\n} as const;\n\nexport type RealmKey = keyof typeof REALM;\nexport type Realm = (typeof REALM)[RealmKey];\n","export const SIZE = {\n  LARGE: 'large',\n  SMALL: 'small',\n} as const;\n\nexport type Size = (typeof SIZE)[keyof typeof SIZE];\n\nexport const SIZE_BUTTON = {\n  LARGE: 'large',\n  SMALL: 'small',\n} as const;\n\nexport type SizeButton = (typeof SIZE)[keyof typeof SIZE];\n","const capitalizeFirst = (string: string) => {\n  return string.charAt(0).toUpperCase() + string.slice(1);\n};\n\nconst formatCamelCase = (input: string): string => {\n  return input && typeof input === 'string'\n    ? input\n        .replace(/^[\\s_-]/, '')\n        .replace(/([a-z]{1})([A-Z]{1})/g, '$1 $2')\n        .replace(/[\\s_-]/g, ' ')\n        .toLowerCase()\n        .split(' ')\n        .map((word, index) => (index === 0 ? word : word.slice(0, 1).toUpperCase() + word.slice(1)))\n        .join('')\n    : input;\n};\n\nconst formatKebabCase = (input: string): string => {\n  return input && typeof input === 'string'\n    ? input\n        .replace(/([a-z]{1})([A-Z]{1})/g, '$1 $2')\n        .toLowerCase()\n        .replace(/[\\s_-]/g, '-')\n    : input;\n};\n\nconst formatLabel = (value: string) => {\n  const labelMap: { [key: string]: string } = {\n    false: 'No',\n    true: 'Yes',\n  };\n  return Object.hasOwn(labelMap, value) ? labelMap[value] : value;\n};\n\nconst formatNumber = (input: number | string): string => {\n  let output = input && typeof input === 'number' ? new Intl.NumberFormat().format(input) : String(input || '');\n  let digits = output;\n\n  if (input && typeof input === 'string') {\n    digits = digits.replace(/\\D/g, '');\n    if (Number(digits)) {\n      output = new Intl.NumberFormat().format(Number(digits));\n    } else {\n      output = '0';\n    }\n  }\n\n  return output;\n};\n\nconst formatPascalCase = (input: string): string => {\n  return input && typeof input === 'string'\n    ? input\n        .replace(/([a-z]{1})([A-Z]{1})/g, '$1 $2')\n        .replace(/[\\s_-]/g, ' ')\n        .toLowerCase()\n        .split(' ')\n        .map((word) => word.slice(0, 1).toUpperCase() + word.slice(1))\n        .join('')\n    : input;\n};\n\nconst formatPhone = (input: number | string): string => {\n  let output = input && typeof input === 'number' ? String(input) : String(input || '');\n  let digits = output;\n  digits = digits.replace(/\\D/g, '');\n\n  switch (digits.length) {\n    case 7:\n      output = `${digits.slice(0, 3)}-${digits.slice(3)}`;\n      break;\n    case 10:\n      output = `${digits.slice(0, 3)}-${digits.slice(3, 6)}-${digits.slice(6)}`;\n      break;\n    case 11:\n      output = `${digits.slice(0, 1)}-${digits.slice(1, 4)}-${digits.slice(4, 7)}-${digits.slice(7)}`;\n      break;\n    default:\n      output = digits;\n      break;\n  }\n\n  return output;\n};\n\nconst formatPrice = (input: number | string): string => {\n  const output = input ? formatNumber(input) : String(input || '0');\n  return `$${output}`;\n};\n\nconst formatQuotes = (value: string) => {\n  if (value.startsWith('\"') && value.endsWith('\"')) {\n    return value.slice(1, -1);\n  } else {\n    return value;\n  }\n};\n\nconst formatSentenceCase = (input: string): string => {\n  let sentenceCase = input;\n\n  if (input && typeof input === 'string') {\n    const lowerCase = input\n      .replace(/([a-z]{1})([A-Z]{1})/g, '$1 $2')\n      .toLowerCase()\n      .replace(/[\\s_-]/g, ' ');\n\n    sentenceCase = lowerCase.slice(0, 1).toUpperCase() + lowerCase.slice(1);\n  }\n\n  return sentenceCase;\n};\n\nconst formatSnakeCase = (input: string): string => {\n  return input && typeof input === 'string'\n    ? input\n        .replace(/([a-z]{1})([A-Z]{1})/g, '$1 $2')\n        .toLowerCase()\n        .replace(/[\\s_-]/g, '_')\n    : input;\n};\n\nconst formatTitleCase = (input: string): string => {\n  return input && typeof input === 'string'\n    ? input\n        .replace(/([a-z]{1})([A-Z]{1})/g, '$1 $2')\n        .toLowerCase()\n        .replace(/[\\s_-]/g, ' ')\n        .split(' ')\n        .map((word) => word.slice(0, 1).toUpperCase() + word.slice(1))\n        .join(' ')\n    : input;\n};\n\nconst formatUrlFromRoot = (url: string) => {\n  const urlFormatted = url.split('.com/');\n\n  return urlFormatted.length > 1 ? `/${urlFormatted[1]}` : url;\n};\n\nconst formatWeight = (input: number | string): string => {\n  const output = input ? formatNumber(input) : String(input || '0');\n  return `${output} lbs`;\n};\n\nconst getArticle = (noun: string, isPlural = false, isDefinite = false) => {\n  const vowels = ['a', 'e', 'i', 'o', 'u'];\n  const isVowelLeading = vowels.includes(noun.charAt(0));\n\n  return isDefinite ? 'the' : isPlural ? 'some' : isVowelLeading ? 'an' : 'a';\n};\n\nconst priceToNumber = (value: string) => {\n  if (Number.isNaN(Number(value))) {\n    value = value.replace('$', '');\n    value = value.replace(/,/g, '');\n  }\n  return parseInt(value, 10);\n};\n\nconst unformatPrice = (input: string): string => {\n  const output = input.replace(/\\$/g, '').replace(/,/g, '');\n  return `${output}`;\n};\n\nexport {\n  capitalizeFirst,\n  formatCamelCase,\n  formatKebabCase,\n  formatLabel,\n  formatNumber,\n  formatPascalCase,\n  formatPhone,\n  formatPrice,\n  formatQuotes,\n  formatSentenceCase,\n  formatSnakeCase,\n  formatTitleCase,\n  formatUrlFromRoot,\n  formatWeight,\n  getArticle,\n  priceToNumber,\n  unformatPrice,\n};\n","<script lang=\"ts\" setup>\n  import { defineAsyncComponent, markRaw, ref, watch } from 'vue';\n\n  import { REALM } from '@/types/Realm';\n  import { SIZE } from '@/types/Size';\n  import { CSS } from '@/types/Styles';\n  import { formatPascalCase } from '@/utilities/format';\n\n  import type { Icon } from '@/types/Icon';\n  import type { Size } from '@/types/Size';\n  import type { Component } from 'vue';\n\n  type Props = {\n    icon: Icon;\n    size?: Size;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    size: SIZE.SMALL,\n  });\n\n  const innerSVG = ref<Component>();\n\n  watch(\n    () => props.icon,\n    async () => {\n      const id: string = props.icon;\n      const name = formatPascalCase(id);\n      const [prefix] = id.split('-');\n      const realmFolder = REALM[prefix?.toUpperCase() as keyof typeof REALM];\n      const component = defineAsyncComponent(() => {\n        if (realmFolder) {\n          return import(`../assets/svg/icons/realm/${realmFolder}/Icon${name}.svg?component`);\n        }\n\n        return import(`../assets/svg/icons/Icon${name}.svg?component`);\n      });\n\n      innerSVG.value = markRaw(component);\n    },\n    { immediate: true }\n  );\n</script>\n\n<template>\n  <div :class=\"['tide-icon', props.size]\">\n    <Component\n      :class=\"[CSS.DISPLAY.BLOCK]\"\n      :data-icon=\"icon\"\n      fill=\"currentColor\"\n      :is=\"innerSVG\"\n      v-if=\"innerSVG\"\n    />\n  </div>\n</template>\n\n<style>\n  .tide-icon {\n    width: 1.5rem;\n    height: 1.5rem;\n  }\n\n  .tide-icon.small {\n    width: 1.25rem;\n    height: 1.25rem;\n  }\n\n  .tide-icon svg {\n    width: 100%;\n    height: 100%;\n  }\n</style>\n","import type { RealmKey } from '@/types/Realm';\n\nexport const ICON = {\n  ACCOUNT_BALANCE: 'account-balance',\n  ACUTE: 'acute',\n  ADD: 'add',\n  AI_DESCRIPTION: 'ai-description',\n  ALIGN_SPACE_EVEN: 'align-space-even',\n  APPLE_PAY: 'apple-pay',\n  ARROW_BACK: 'arrow-back',\n  ARROW_CYCLE: 'arrow-cycle',\n  ARROW_FORWARD: 'arrow-forward',\n  ARROW_RIGHT: 'arrow-right',\n  ASSIGNMENT: 'assignment',\n  ATTACH_MONEY: 'attach-money',\n  AUTO_RENEW: 'auto-renew',\n  AWARD_STAR: 'award-star',\n  BED: 'bed',\n  BOLT: 'bolt',\n  BOOKMARK: 'bookmark',\n  BUNKHOUSE: 'bunkhouse',\n  CALENDAR_MONTH: 'calendar-month',\n  CALL: 'call',\n  CALL_QUALITY: 'call-quality',\n  CAR_RENTAL: 'car-rental',\n  CHECK: 'check',\n  CHEVRON_LEFT: 'chevron-left',\n  CHEVRON_RIGHT: 'chevron-right',\n  CLEAR: 'clear',\n  CLOSE: 'close',\n  CONTRACT: 'contract',\n  CRASH: 'crash',\n  DASHBOARD_CUSTOMIZE: 'dashboard-customize',\n  DELETE: 'delete',\n  DIAMOND: 'diamond',\n  DIRECTIONS_BOAT: 'directions-boat',\n  DOMAIN: 'domain',\n  DRAFT: 'draft',\n  EDIT: 'edit',\n  ENGINE: 'engine',\n  ENGINEERING: 'engineering',\n  ERROR: 'error',\n  EXPAND_CONTENT: 'expand-content',\n  EXPAND_LESS: 'expand-less',\n  EXPAND_MORE: 'expand-more',\n  FACEBOOK: 'facebook',\n  FAVORITE: 'favorite',\n  FAVORITE_FILLED: 'favorite-filled',\n  FLAG: 'flag',\n  FORMAT_BOLD: 'format-bold',\n  FORMAT_ITALIC: 'format-italic',\n  FORMAT_LIST_BULLETED: 'format-list-bulleted',\n  FORUM: 'forum',\n  GAS: 'gas',\n  GAVEL: 'gavel',\n  GEARS: 'gears',\n  GLOBE_LOCATION_PIN: 'globe-location-pin',\n  GOOGLE: 'google',\n  GOOGLE_PAY: 'google-pay',\n  GRID: 'grid',\n  HANDSHAKE: 'handshake',\n  HANDYMAN: 'handyman',\n  HEIGHT: 'height',\n  HELP: 'help',\n  INFO: 'info',\n  INFORMATION: 'information',\n  INSERT_TEXT: 'insert-text',\n  INSTAGRAM: 'instagram',\n  IOS_SHARE: 'ios-share',\n  LAYOUT: 'layout',\n  LEVELLING_JACK: 'levelling-jack',\n  LINKED_IN: 'linked in',\n  LOCAL_SHIPPING: 'local-shipping',\n  LOCK: 'lock',\n  MAIL: 'mail',\n  MENU: 'menu',\n  MONEY_BAG: 'money-bag',\n  MORE_HORIZ: 'more-horiz',\n  NOTIFICATIONS: 'notifications',\n  ODOMETER: 'odometer',\n  OPEN_IN_NEW: 'open-in-new',\n  PALETTE: 'palette',\n  PAYPAL: 'paypal',\n  PERSON: 'person',\n  PERSON_SEARCH: 'person-search',\n  PHOTO_CAMERA: 'photo-camera',\n  PINTEREST: 'pinterest',\n  PLAY_ARROW: 'play-arrow',\n  POLICY: 'policy',\n  POWER: 'power',\n  POWER_OFF: 'power-off',\n  PRIORITY_HIGH: 'priority-high',\n  REMOVE: 'remove',\n  REQUEST_QUOTE: 'request-quote',\n  RESET_WRENCH: 'reset-wrench',\n  ROAD: 'road',\n  ROUNDED_CORNER: 'rounded-corner',\n  RULER: 'ruler',\n  SAILING: 'sailing',\n  SCHOOL: 'school',\n  SEARCH: 'search',\n  SEATING: 'seating',\n  SELL: 'sell',\n  SENSORS: 'sensors',\n  SETTINGS: 'settings',\n  SHARE: 'share',\n  SHIELD_CHECK: 'shield-check',\n  SHOPPING_CART: 'shopping-cart',\n  SLEEPS: 'sleeps',\n  SMS: 'sms',\n  SNOWFLAKE: 'snowflake',\n  STAR: 'star',\n  SUMMARIZE: 'summarize',\n  SWAP_HORIZ: 'swap-horiz',\n  SWAP_VERT: 'swap-vert',\n  THREE_D_ROTATION: 'three-d-rotation',\n  THUMB_UP: 'thumb-up',\n  TRENDING_DOWN: 'trending-down',\n  TROPHY: 'trophy',\n  TUNE: 'tune',\n  TWITTER: 'twitter',\n  UMBRELLA: 'umbrella',\n  VERIFIED: 'verified',\n  VIDEOCAM: 'videocam',\n  VIEW_IN_AR: 'view-in-ar',\n  VISIBILITY: 'visibility',\n  VOLUME_OFF: 'volume-off',\n  VOLUME_ON: 'volume-on',\n  WAREHOUSE: 'warehouse',\n  WARNING: 'warning',\n  WATER: 'water',\n  WEIGHT: 'weight',\n  WIDTH: 'width',\n  WORKSPACE_PREMIUM: 'workspace-premium',\n  WRENCH: 'wrench',\n  YOUTUBE: 'youtube',\n} as const;\n\nexport const ICON_REALM = {\n  ATV: {\n    ATV: 'atv-atv',\n    DUNE_BUGGY: 'atv-dune-buggy',\n    GOLF_CART: 'atv-golf-cart',\n    GO_KART: 'atv-go-kart',\n    SAND_RAIL: 'atv-sand-rail',\n    SIDE_BY_SIDE: 'atv-side-by-side',\n    TRAILER: 'atv-trailer',\n  },\n  BOATMART: {\n    PWC: 'boatmart-pwc',\n    TRAILER: 'boatmart-trailer',\n  },\n  RV: {\n    CLASS_A: 'rv-class-a',\n    CLASS_B: 'rv-class-b',\n    CLASS_C: 'rv-class-c',\n    FIFTH_WHEEL: 'rv-fifth-wheel',\n    FISH_HOUSE: 'rv-fish-house',\n    PARK_MODEL: 'rv-park-model',\n    POP_UP_CAMPER: 'rv-pop-up-camper',\n    TRAVEL_TRAILER: 'rv-travel-trailer',\n    TRUCK_CAMPER: 'rv-truck-camper',\n  },\n} as const;\n\ntype RealmKeysWithIcons = Extract<RealmKey, keyof typeof ICON_REALM>;\ntype RealmIcon = {\n  [RealmKey in RealmKeysWithIcons]: (typeof ICON_REALM)[RealmKey][keyof (typeof ICON_REALM)[RealmKey]];\n}[RealmKeysWithIcons];\n\nexport type GlobalIcon = (typeof ICON)[keyof typeof ICON];\nexport type Icon = GlobalIcon | RealmIcon;\n","<script lang=\"ts\" setup>\n  import TideDivider from '@/components/TideDivider.vue';\n  import TideIcon from '@/components/TideIcon.vue';\n  import { ICON } from '@/types/Icon';\n  import { SIZE } from '@/types/Size';\n  import { CSS } from '@/types/Styles';\n\n  const emit = defineEmits(['toggle']);\n\n  type Props = {\n    hasBottomDivider?: boolean;\n    hasTopDivider?: boolean;\n    isExpanded?: boolean;\n    isOptional?: boolean;\n    label: string;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    hasBottomDivider: false,\n    hasTopDivider: false,\n    isExpanded: false,\n    isOptional: false,\n    label: '',\n  });\n\n  const handleToggleClick = () => {\n    emit('toggle');\n  };\n</script>\n\n<template>\n  <div class=\"tide-accordion-item\">\n    <TideDivider v-if=\"props.hasTopDivider\" />\n\n    <div\n      :class=\"['tide-accordion-head', CSS.DISPLAY.FLEX, CSS.AXIS1.BETWEEN, CSS.PADDING.Y.HALF, CSS.CURSOR.POINTER]\"\n      @click=\"handleToggleClick\"\n    >\n      <div :class=\"[CSS.DISPLAY.FLEX, CSS.AXIS2.CENTER, CSS.GAP.HALF, CSS.FONT.ROLE.LABEL_1_SEMIBOLD]\">\n        <span>{{ props.label }}</span>\n\n        <span\n          :class=\"[CSS.FONT.COLOR.SURFACE.VARIANT]\"\n          v-if=\"props.isOptional\"\n        >\n          (optional)\n        </span>\n      </div>\n\n      <TideIcon\n        :icon=\"isExpanded ? ICON.EXPAND_LESS : ICON.EXPAND_MORE\"\n        :size=\"SIZE.LARGE\"\n      />\n    </div>\n\n    <div :class=\"['tide-accordion-body', props.isExpanded ? 'expanded' : 'collapsed', CSS.DISPLAY.GRID]\">\n      <div :class=\"[CSS.OVERFLOW.Y.HIDDEN, CSS.MARGIN.Y.ONE, CSS.FONT.ROLE.BODY_1, CSS.FONT.COLOR.SURFACE.DEFAULT]\">\n        <slot />\n      </div>\n    </div>\n\n    <TideDivider v-if=\"props.hasBottomDivider\" />\n  </div>\n</template>\n\n<style scoped>\n  .tide-accordion-body {\n    transition: grid-template-rows var(--tide-animate);\n  }\n\n  .tide-accordion-body.expanded {\n    grid-template-rows: 1fr;\n  }\n\n  .tide-accordion-body.collapsed {\n    grid-template-rows: 0fr;\n  }\n</style>\n","export const ELEMENT = {\n  BUTTON: 'button',\n  LINK: 'a',\n} as const;\n\nexport const ELEMENT_TEXT_AS_ICON = {\n  BUTTON: 'button',\n  DIV: 'div',\n  LINK: 'a',\n} as const;\n\nexport type Element = (typeof ELEMENT)[keyof typeof ELEMENT];\nexport type ElementTextAsIcon = (typeof ELEMENT_TEXT_AS_ICON)[keyof typeof ELEMENT_TEXT_AS_ICON];\n","/* eslint-disable vue/sort-keys */\n\nexport const PRIORITY = {\n  PRIMARY: 'primary',\n  SECONDARY: 'secondary',\n  TERTIARY: 'tertiary',\n  QUATERNARY: 'quaternary',\n  FLOATING: 'floating',\n} as const;\n\nexport type Priority = (typeof PRIORITY)[keyof typeof PRIORITY];\n","export const TARGET = {\n  BLANK: '_blank',\n  SELF: undefined,\n} as const;\n\nexport type Target = (typeof TARGET)[keyof typeof TARGET];\n","<script lang=\"ts\" setup>\n  import TideIcon from '@/components/TideIcon.vue';\n  import { ELEMENT } from '@/types/Element';\n  import { PRIORITY } from '@/types/Priority';\n  import { SIZE } from '@/types/Size';\n  import { CSS } from '@/types/Styles';\n  import { TARGET } from '@/types/Target';\n\n  import type { Element } from '@/types/Element';\n  import type { Icon } from '@/types/Icon';\n  import type { Priority } from '@/types/Priority';\n\n  type Props = {\n    disabled?: boolean;\n    element?: Element;\n    href?: string;\n    icon: Icon;\n    isNewTab?: boolean;\n    priority?: Priority;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    disabled: false,\n    element: ELEMENT.BUTTON,\n    href: undefined,\n    icon: undefined,\n    isNewTab: false,\n    priority: PRIORITY.PRIMARY,\n  });\n</script>\n\n<template>\n  <component\n    :aria-label=\"props.icon\"\n    :class=\"[\n      props.element === ELEMENT.LINK ? 'tide-link-as-button-icon' : 'tide-button-icon',\n      props.priority && `tide-button-${props.priority}`,\n      [CSS.DISPLAY.FLEX, CSS.AXIS1.CENTER, CSS.AXIS2.CENTER, CSS.BORDER.RADIUS.FULL, CSS.PADDING.FULL.HALF],\n      props.element === ELEMENT.LINK ? [CSS.UNDERLINE.REST.OFF] : '',\n    ]\"\n    :disabled=\"props.element === ELEMENT.BUTTON && props.disabled\"\n    :href=\"props.element === ELEMENT.LINK && props.href ? props.href : undefined\"\n    :target=\"props.element === ELEMENT.LINK && props.isNewTab ? TARGET.BLANK : TARGET.SELF\"\n    :is=\"props.element === ELEMENT.LINK ? 'a' : 'button'\"\n  >\n    <TideIcon\n      :icon=\"props.icon\"\n      :size=\"SIZE.LARGE\"\n      v-if=\"props.icon\"\n    />\n  </component>\n</template>\n","export const ALERT = {\n  ERROR: 'error',\n  INFO: 'info',\n  SUCCESS: 'success',\n  WARNING: 'warning',\n} as const;\n\nexport type Alert = (typeof ALERT)[keyof typeof ALERT];\n","<script lang=\"ts\" setup>\n  import { computed } from 'vue';\n\n  import TideButtonIcon from '@/components/TideButtonIcon.vue';\n  import TideIcon from '@/components/TideIcon.vue';\n  import { ALERT } from '@/types/Alert';\n  import { ICON } from '@/types/Icon';\n  import { PRIORITY } from '@/types/Priority';\n  import { SIZE } from '@/types/Size';\n  import { CSS } from '@/types/Styles';\n\n  import type { Alert } from '@/types/Alert';\n\n  type Props = {\n    heading?: string;\n    isDismissible?: boolean;\n    isToast?: boolean;\n    type?: Alert;\n  };\n\n  type Emits = {\n    (event: 'close'): void;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    heading: undefined,\n    isDismissible: true,\n    isToast: false,\n    type: ALERT.INFO,\n  });\n\n  const emit = defineEmits<Emits>();\n\n  const iconType = computed(() => {\n    if (props.type === ALERT.ERROR) return ICON.PRIORITY_HIGH;\n    if (props.type === ALERT.SUCCESS) return ICON.CHECK;\n    if (props.type === ALERT.WARNING) return ICON.WARNING;\n    return ICON.INFORMATION;\n  });\n</script>\n\n<template>\n  <div\n    :class=\"[\n      props.type,\n      'tide-alert',\n      CSS.DISPLAY.GRID,\n      CSS.AXIS2.CENTER,\n      CSS.BORDER.RADIUS.HALF,\n      CSS.PADDING.FULL.ONE,\n      !props.isToast && props.type === ALERT.ERROR ? [CSS.BG.GLOBAL.SURFACE.ERROR, CSS.BORDER.COLOR.GLOBAL.ERROR] : '',\n      !props.isToast && props.type === ALERT.INFO ? [CSS.BG.GLOBAL.SURFACE.INFO, CSS.BORDER.COLOR.GLOBAL.INFO] : '',\n      !props.isToast && props.type === ALERT.SUCCESS\n        ? [CSS.BG.GLOBAL.SURFACE.SUCCESS, CSS.BORDER.COLOR.GLOBAL.SUCCESS]\n        : '',\n      !props.isToast && props.type === ALERT.WARNING\n        ? [CSS.BG.GLOBAL.SURFACE.WARNING, CSS.BORDER.COLOR.GLOBAL.WARNING]\n        : '',\n      props.isToast ? [CSS.BG.SECONDARY, CSS.FONT.COLOR.SECONDARY, CSS.SHADOW.BOTTOM] : CSS.BORDER.LEFT.TWO,\n    ]\"\n  >\n    <div\n      :class=\"[\n        'tide-alert-icon',\n        CSS.PADDING.FULL.QUARTER,\n        CSS.BORDER.RADIUS.FULL,\n        CSS.FONT.COLOR.SURFACE.INVERSE,\n        props.type === ALERT.ERROR && CSS.BG.GLOBAL.PRIMARY.ERROR,\n        props.type === ALERT.INFO && CSS.BG.GLOBAL.PRIMARY.INFO,\n        props.type === ALERT.SUCCESS && CSS.BG.GLOBAL.PRIMARY.SUCCESS,\n        props.type === ALERT.WARNING && CSS.BG.GLOBAL.PRIMARY.WARNING,\n      ]\"\n      v-if=\"!props.isToast\"\n    >\n      <TideIcon\n        :icon=\"iconType\"\n        :size=\"SIZE.SMALL\"\n      />\n    </div>\n\n    <div :class=\"['tide-alert-heading', CSS.DISPLAY.FLEX, CSS.AXIS2.CENTER, CSS.FONT.ROLE.LABEL_1_SEMIBOLD]\">\n      {{ props.heading }}\n    </div>\n\n    <TideButtonIcon\n      :class=\"['tide-alert-close', CSS.AXIS2.CENTER, CSS.FONT.COLOR.SURFACE.DEFAULT]\"\n      :icon=\"ICON.CLOSE\"\n      :priority=\"PRIORITY.QUATERNARY\"\n      @click=\"emit('close')\"\n      aria-label=\"Close alert\"\n      v-if=\"isDismissible\"\n    />\n\n    <div :class=\"['tide-alert-body', CSS.FONT.ROLE.BODY_2, !props.isToast && CSS.FONT.COLOR.SURFACE.DEFAULT]\">\n      <slot />\n    </div>\n  </div>\n</template>\n\n<style scoped>\n  .tide-alert {\n    grid-template-areas:\n      'icon heading close'\n      '. body .';\n    grid-template-columns: auto 1fr auto;\n    grid-column-gap: 0.5rem;\n    max-width: 40rem;\n  }\n\n  .tide-alert-icon {\n    grid-area: icon;\n  }\n\n  .tide-alert-heading {\n    grid-area: heading;\n  }\n\n  .tide-alert-close {\n    grid-area: close;\n  }\n\n  .tide-alert-body {\n    grid-area: body;\n  }\n</style>\n","import { CSS } from '@/types/Styles';\n\nexport const BADGE_COLOR = {\n  BLACK: 'black',\n  BLUE: 'blue',\n  GREEN: 'green',\n  LIME: 'lime',\n  ORANGE: 'orange',\n  PURPLE: 'purple',\n  RED: 'red',\n  SALMON: 'salmon',\n  TEAL: 'teal',\n  YELLOW: 'yellow',\n} as const;\n\nexport const BADGE_COLOR_DETAILS: Record<\n  BadgeColor,\n  {\n    borderColor: string;\n    iconColor: string;\n  }\n> = {\n  [BADGE_COLOR.BLACK]: {\n    borderColor: CSS.BORDER.COLOR.HIGH,\n    iconColor: CSS.FONT.COLOR.SURFACE.DEFAULT,\n  },\n  [BADGE_COLOR.BLUE]: {\n    borderColor: CSS.BORDER.COLOR.GLOBAL.BLUE,\n    iconColor: CSS.FONT.COLOR.GLOBAL.PRIMARY.BLUE,\n  },\n  [BADGE_COLOR.GREEN]: {\n    borderColor: CSS.BORDER.COLOR.GLOBAL.GREEN,\n    iconColor: CSS.FONT.COLOR.GLOBAL.PRIMARY.GREEN,\n  },\n  [BADGE_COLOR.LIME]: {\n    borderColor: CSS.BORDER.COLOR.GLOBAL.LIME,\n    iconColor: CSS.FONT.COLOR.GLOBAL.PRIMARY.LIME,\n  },\n  [BADGE_COLOR.ORANGE]: {\n    borderColor: CSS.BORDER.COLOR.GLOBAL.ORANGE,\n    iconColor: CSS.FONT.COLOR.GLOBAL.PRIMARY.ORANGE,\n  },\n  [BADGE_COLOR.PURPLE]: {\n    borderColor: CSS.BORDER.COLOR.GLOBAL.PURPLE,\n    iconColor: CSS.FONT.COLOR.GLOBAL.PRIMARY.PURPLE,\n  },\n  [BADGE_COLOR.RED]: {\n    borderColor: CSS.BORDER.COLOR.GLOBAL.RED,\n    iconColor: CSS.FONT.COLOR.GLOBAL.PRIMARY.RED,\n  },\n  [BADGE_COLOR.SALMON]: {\n    borderColor: CSS.BORDER.COLOR.GLOBAL.SALMON,\n    iconColor: CSS.FONT.COLOR.GLOBAL.PRIMARY.SALMON,\n  },\n  [BADGE_COLOR.TEAL]: {\n    borderColor: CSS.BORDER.COLOR.GLOBAL.TEAL,\n    iconColor: CSS.FONT.COLOR.GLOBAL.PRIMARY.TEAL,\n  },\n  [BADGE_COLOR.YELLOW]: {\n    borderColor: CSS.BORDER.COLOR.GLOBAL.YELLOW,\n    iconColor: CSS.FONT.COLOR.GLOBAL.PRIMARY.YELLOW,\n  },\n};\n\nexport const BADGE_TRUSTED = {\n  YEARS_10: '10',\n  YEARS_15: '15',\n  YEARS_5: '5',\n} as const;\n\nexport type BadgeColor = (typeof BADGE_COLOR)[keyof typeof BADGE_COLOR];\nexport type BadgeTrustedYears = (typeof BADGE_TRUSTED)[keyof typeof BADGE_TRUSTED];\n","<script lang=\"ts\" setup>\n  import TideIcon from '@/components/TideIcon.vue';\n  import { BADGE_COLOR_DETAILS } from '@/types/Badge';\n  import { CSS } from '@/types/Styles';\n\n  import type { BadgeColor } from '@/types/Badge';\n  import type { Icon } from '@/types/Icon';\n\n  type Props = {\n    color?: BadgeColor;\n    iconLeading?: Icon;\n    isFloating?: boolean;\n    label: string;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    color: undefined,\n    iconLeading: undefined,\n    isFloating: false,\n  });\n</script>\n\n<template>\n  <div\n    :class=\"[\n      'tide-badge',\n      props.isFloating || props.color ? [CSS.BG.SURFACE.FLOATING, CSS.SHADOW.BOTTOM] : [CSS.BG.SURFACE.VARIANT],\n      CSS.DISPLAY.INLINE_FLEX,\n      CSS.AXIS2.CENTER,\n      CSS.GAP.QUARTER,\n      CSS.BORDER.RADIUS.QUARTER,\n      CSS.PADDING.Y.QUARTER,\n      CSS.PADDING.X.HALF,\n      props.color && [CSS.BORDER.LEFT.TWO, BADGE_COLOR_DETAILS[props.color].borderColor],\n      CSS.ELLIPSIS,\n      CSS.FONT.ROLE.LABEL_2,\n      CSS.WHITESPACE_WRAP.OFF,\n    ]\"\n  >\n    <TideIcon\n      :class=\"[CSS.FLEX.SHRINK.OFF, props.color && BADGE_COLOR_DETAILS[props.color].iconColor]\"\n      :icon=\"props.iconLeading\"\n      v-if=\"props.iconLeading\"\n    />\n\n    <span :class=\"[CSS.ELLIPSIS]\">{{ props.label }}</span>\n  </div>\n</template>\n","<script lang=\"ts\" setup>\n  import TideIcon from '@/components/TideIcon.vue';\n  import { BADGE_TRUSTED } from '@/types/Badge';\n  import { ICON } from '@/types/Icon';\n  import { CSS } from '@/types/Styles';\n\n  import type { BadgeTrustedYears } from '@/types/Badge';\n\n  type Props = {\n    years?: BadgeTrustedYears;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    years: BADGE_TRUSTED.YEARS_5,\n  });\n</script>\n\n<template>\n  <div\n    :class=\"[\n      'tide-badge-trusted-partner',\n      CSS.FONT.COLOR.SURFACE.BRAND,\n      CSS.DISPLAY.INLINE_FLEX,\n      CSS.AXIS2.CENTER,\n      CSS.GAP.QUARTER,\n      CSS.ELLIPSIS,\n      CSS.FONT.ROLE.LABEL_2,\n      CSS.WHITESPACE_WRAP.OFF,\n    ]\"\n  >\n    <TideIcon\n      :class=\"[CSS.FLEX.SHRINK.OFF]\"\n      :icon=\"ICON.AWARD_STAR\"\n    />\n\n    <div :class=\"[CSS.ELLIPSIS]\">\n      <span>{{ props.years }} year trusted partner</span>\n    </div>\n  </div>\n</template>\n\n<style scoped></style>\n","<script lang=\"ts\" setup>\n  import TideIcon from '@/components/TideIcon.vue';\n  import { ICON } from '@/types/Icon';\n  import { CSS } from '@/types/Styles';\n</script>\n\n<template>\n  <div\n    :class=\"[\n      'tide-badge-verified-vehicle',\n      CSS.BG.SECONDARY,\n      CSS.FONT.ROLE.LABEL_2,\n      CSS.FONT.COLOR.SECONDARY,\n      CSS.DISPLAY.INLINE_FLEX,\n      CSS.AXIS2.CENTER,\n      CSS.GAP.QUARTER,\n      CSS.BORDER.RADIUS.QUARTER,\n      CSS.PADDING.Y.QUARTER,\n      CSS.PADDING.X.HALF,\n      CSS.ELLIPSIS,\n      CSS.WHITESPACE_WRAP.OFF,\n    ]\"\n  >\n    <TideIcon\n      :class=\"[CSS.FLEX.SHRINK.OFF]\"\n      :icon=\"ICON.VERIFIED\"\n    />\n\n    <span :class=\"[CSS.ELLIPSIS]\">Verified vehicle</span>\n  </div>\n</template>\n\n<style scoped>\n  .tide-icon {\n    color: var(--tide-info-primary);\n  }\n</style>\n","<script lang=\"ts\" setup>\n  import TideIcon from '@/components/TideIcon.vue';\n  import { ICON } from '@/types/Icon';\n  import { SIZE } from '@/types/Size';\n  import { CSS } from '@/types/Styles';\n\n  import type { BreadCrumb } from '@/types/BreadCrumb';\n\n  type Props = {\n    breadCrumbs: BreadCrumb[];\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    breadCrumbs: undefined,\n  });\n</script>\n\n<template>\n  <ul :class=\"['tide-bread-crumbs', CSS.DISPLAY.FLEX, CSS.AXIS2.CENTER, CSS.GAP.QUARTER, CSS.LIST_BULLETS.OFF]\">\n    <template\n      :key=\"crumb.label\"\n      v-for=\"(crumb, index) in props.breadCrumbs\"\n    >\n      <li :class=\"[CSS.FONT.ROLE.BODY_2]\">\n        <a\n          :class=\"[CSS.FONT.ROLE.LINK_2, CSS.FONT.COLOR.SURFACE.DEFAULT]\"\n          :data-track=\"crumb.dataTrack || undefined\"\n          :href=\"crumb.url\"\n          v-if=\"crumb.url\"\n        >\n          {{ crumb.label }}\n        </a>\n\n        <span\n          :class=\"[CSS.FONT.ROLE.LABEL_2, CSS.FONT.COLOR.SURFACE.VARIANT]\"\n          :data-track=\"crumb.dataTrack || undefined\"\n          v-else\n        >\n          {{ crumb.label }}\n        </span>\n      </li>\n\n      <li v-if=\"props.breadCrumbs && index < props.breadCrumbs.length - 1\">\n        <TideIcon\n          :icon=\"ICON.ARROW_RIGHT\"\n          :size=\"SIZE.SMALL\"\n        />\n      </li>\n    </template>\n  </ul>\n</template>\n","<script lang=\"ts\" setup>\n  import TideIcon from '@/components/TideIcon.vue';\n  import { ELEMENT } from '@/types/Element';\n  import { PRIORITY } from '@/types/Priority';\n  import { SIZE, SIZE_BUTTON } from '@/types/Size';\n  import { CSS } from '@/types/Styles';\n  import { TARGET } from '@/types/Target';\n\n  import type { Element } from '@/types/Element';\n  import type { Icon } from '@/types/Icon';\n  import type { Priority } from '@/types/Priority';\n  import type { SizeButton } from '@/types/Size';\n\n  type Props = {\n    disabled?: boolean;\n    element?: Element;\n    href?: string;\n    iconLeading?: Icon;\n    iconTrailing?: Icon;\n    isNewTab?: boolean;\n    label: string;\n    priority?: Priority;\n    size?: SizeButton;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    disabled: false,\n    element: ELEMENT.BUTTON,\n    href: undefined,\n    iconLeading: undefined,\n    iconTrailing: undefined,\n    isNewTab: false,\n    label: undefined,\n    priority: PRIORITY.PRIMARY,\n    size: SIZE_BUTTON.LARGE,\n  });\n</script>\n\n<template>\n  <component\n    :class=\"[\n      'tide-button',\n      props.priority && `tide-button-${props.priority}`,\n      props.element === ELEMENT.LINK ? [CSS.DISPLAY.INLINE_FLEX] : [CSS.DISPLAY.FLEX],\n      props.element === ELEMENT.LINK ? CSS.UNDERLINE.REST.OFF : '',\n      size === SIZE_BUTTON.SMALL && [CSS.FONT.ROLE.BUTTON_2, CSS.PADDING.X.ONE, CSS.PADDING.Y.HALF],\n      size === SIZE_BUTTON.LARGE && [CSS.FONT.ROLE.BUTTON_1, CSS.PADDING.X.TWO, CSS.PADDING.Y.ONE],\n      CSS.AXIS1.CENTER,\n      CSS.AXIS2.CENTER,\n      CSS.GAP.HALF,\n      CSS.BORDER.RADIUS.HALF,\n      CSS.FONT.ROLE.LABEL_1_SEMIBOLD,\n    ]\"\n    :disabled=\"props.element === ELEMENT.BUTTON && props.disabled\"\n    :href=\"props.element === ELEMENT.LINK && props.href ? props.href : undefined\"\n    :target=\"props.element === ELEMENT.LINK && props.isNewTab ? TARGET.BLANK : TARGET.SELF\"\n    :is=\"props.element === ELEMENT.LINK ? ELEMENT.LINK : ELEMENT.BUTTON\"\n  >\n    <TideIcon\n      :icon=\"props.iconLeading\"\n      :size=\"size === SIZE_BUTTON.LARGE ? SIZE.LARGE : SIZE.SMALL\"\n      v-if=\"props.iconLeading\"\n    />\n\n    {{ props.label }}\n\n    <TideIcon\n      :icon=\"props.iconTrailing\"\n      :size=\"size === SIZE_BUTTON.LARGE ? SIZE.LARGE : SIZE.SMALL\"\n      v-if=\"props.iconTrailing\"\n    />\n  </component>\n</template>\n","<script lang=\"ts\" setup>\n  import { ELEMENT_TEXT_AS_ICON } from '@/types/Element';\n  import { CSS } from '@/types/Styles';\n\n  import type { ElementTextAsIcon } from '@/types/Element';\n\n  type Props = {\n    disabled?: boolean;\n    element?: ElementTextAsIcon;\n    href?: string;\n    label: string | number;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    disabled: false,\n    element: ELEMENT_TEXT_AS_ICON.BUTTON,\n    href: undefined,\n    label: undefined,\n  });\n</script>\n\n<template>\n  <component\n    :class=\"[\n      props.element === ELEMENT_TEXT_AS_ICON.LINK ? 'tide-link-as-button-icon' : 'tide-button-icon',\n      [CSS.DISPLAY.INLINE_BLOCK, CSS.BORDER.RADIUS.FULL, CSS.PADDING.FULL.HALF],\n      props.element === ELEMENT_TEXT_AS_ICON.LINK ? [CSS.UNDERLINE.REST.OFF] : '',\n      props.element === ELEMENT_TEXT_AS_ICON.DIV ? [CSS.CURSOR.POINTER] : '',\n      [CSS.FONT.ROLE.HEADLINE_3],\n    ]\"\n    :disabled=\"props.element === ELEMENT_TEXT_AS_ICON.BUTTON && props.disabled\"\n    :href=\"props.element === ELEMENT_TEXT_AS_ICON.LINK && props.href ? props.href : undefined\"\n    :is=\"\n      props.element === ELEMENT_TEXT_AS_ICON.LINK\n        ? 'a'\n        : props.element === ELEMENT_TEXT_AS_ICON.BUTTON\n        ? 'button'\n        : 'div'\n    \"\n  >\n    <span :class=\"['label', CSS.DISPLAY.FLEX, CSS.AXIS1.CENTER, CSS.AXIS2.CENTER]\">\n      {{ props.label }}\n    </span>\n  </component>\n</template>\n\n<style scoped>\n  .tide-button-icon,\n  .tide-link-as-button-icon {\n    border: 1px solid var(--tide-white);\n    background: var(--tide-white);\n    color: var(--tide-secondary);\n  }\n\n  .tide-button-icon:not(:disabled):hover,\n  .tide-link-as-button-icon:not(:disabled):hover {\n    border: 1px solid var(--tide-surface-variant);\n    background: var(--tide-surface-variant);\n  }\n\n  .tide-button-icon:disabled,\n  .tide-link-as-button-icon:disabled {\n    border: 1px solid var(--tide-border-high);\n  }\n\n  .tide-button-icon .label,\n  .tide-link-as-button-icon .label {\n    width: 1.5rem;\n    height: 1.5rem;\n  }\n</style>\n","<script lang=\"ts\" setup>\n  import { CSS } from '@/types/Styles';\n\n  import type { Tab } from '@/types/Tab';\n\n  type Props = {\n    activeTab: number;\n    tabs: Tab[];\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    activeTab: 0,\n  });\n\n  const emit = defineEmits(['change']);\n\n  const handleClick = (index: number) => {\n    emit('change', index);\n  };\n</script>\n\n<template>\n  <div\n    :class=\"[\n      'tide-button-segmented',\n      CSS.BG.SURFACE.VARIANT,\n      CSS.DISPLAY.FLEX,\n      CSS.GAP.QUARTER,\n      CSS.BORDER.RADIUS.FULL,\n      CSS.PADDING.FULL.QUARTER,\n      CSS.OVERFLOW.XY.HIDDEN,\n      CSS.WIDTH.FULL,\n    ]\"\n  >\n    <button\n      :class=\"[\n        'tide-button-segmented-tab',\n        index === activeTab\n          ? [CSS.BG.SURFACE.DEFAULT, CSS.FONT.COLOR.SURFACE.DEFAULT, CSS.SHADOW.BOTTOM]\n          : ['inactive', CSS.FONT.COLOR.SURFACE.VARIANT],\n        CSS.FLEX.GROW.ON,\n        CSS.BORDER.FULL.TWO,\n        CSS.BORDER.RADIUS.FULL,\n        CSS.PADDING.Y.QUARTER,\n        CSS.WIDTH.FULL,\n        CSS.FONT.ROLE.BUTTON_1,\n        CSS.WHITESPACE_WRAP.OFF,\n      ]\"\n      :data-track=\"tab.dataTrack || undefined\"\n      :key=\"tab.label\"\n      @click=\"handleClick(index)\"\n      v-for=\"(tab, index) in props.tabs\"\n    >\n      <span :class=\"[CSS.FONT.ROLE.LABEL_2_SEMIBOLD]\">\n        {{ tab.label }}\n      </span>\n\n      <span\n        :class=\"[CSS.FONT.ROLE.LABEL_2_SEMIBOLD]\"\n        v-if=\"tab.count && tab.count > 0\"\n      >\n        ({{ tab.count }})\n      </span>\n    </button>\n  </div>\n</template>\n\n<style scoped>\n  .tide-button-segmented {\n    max-width: 23.3rem;\n  }\n\n  .tide-button-segmented-tab {\n    flex: 1;\n    transition: background-color var(--tide-animate);\n  }\n\n  .inactive:not(:hover) {\n    border-color: var(--tide-surface-variant);\n  }\n\n  .inactive:hover {\n    border-color: var(--tide-border);\n    color: var(--tide-surface-default);\n  }\n</style>\n","export const TYPE_CARD = {\n  ACTIONABLE: 'action',\n  INFORMATIONAL: 'informational',\n  SELECTABLE: 'select',\n} as const;\n\nexport type CardType = (typeof TYPE_CARD)[keyof typeof TYPE_CARD];\n","<script lang=\"ts\" setup>\n  import TideIcon from '@/components/TideIcon.vue';\n  import { TYPE_CARD } from '@/types/Card';\n  import { SIZE } from '@/types/Size';\n  import { CSS } from '@/types/Styles';\n\n  import type { CardType } from '@/types/Card';\n  import type { Icon } from '@/types/Icon';\n\n  type Props = {\n    description?: string;\n    heading: string;\n    icon?: Icon;\n    selected?: boolean;\n    type?: CardType;\n    href?: string;\n  };\n\n  withDefaults(defineProps<Props>(), {\n    description: undefined,\n    href: undefined,\n    icon: undefined,\n    selected: undefined,\n    type: TYPE_CARD.INFORMATIONAL,\n  });\n</script>\n\n<template>\n  <component\n    :class=\"[\n      'tide-card',\n      CSS.BORDER.COLOR.LOW,\n      CSS.BORDER.FULL.ONE,\n      CSS.BORDER.RADIUS.HALF,\n      CSS.DISPLAY.FLEX,\n      CSS.GAP.HALF,\n      CSS.PADDING.FULL.ONE,\n      CSS.WIDTH.FULL,\n      CSS.ALIGN.X.LEFT,\n      CSS.FLEX.DIRECTION.COLUMN,\n      type !== TYPE_CARD.INFORMATIONAL && 'hoverable',\n      type === TYPE_CARD.SELECTABLE && selected && 'selected',\n    ]\"\n    :href=\"href\"\n    :is=\"href ? 'a' : type === TYPE_CARD.INFORMATIONAL ? 'div' : 'button'\"\n  >\n    <TideIcon\n      :class=\"[CSS.FLEX.GROW.OFF, CSS.FLEX.SHRINK.OFF]\"\n      :icon=\"icon\"\n      :size=\"SIZE.SMALL\"\n      v-if=\"icon\"\n    />\n\n    <div :class=\"[CSS.AXIS2.START, CSS.DISPLAY.FLEX, CSS.FLEX.DIRECTION.COLUMN, CSS.GAP.HALF]\">\n      <div :class=\"[CSS.FONT.ROLE.LABEL_1_SEMIBOLD, CSS.FONT.COLOR.SURFACE.DEFAULT]\">\n        {{ heading }}\n      </div>\n\n      <div\n        :class=\"[CSS.FONT.ROLE.LABEL_2, CSS.FONT.COLOR.SURFACE.VARIANT]\"\n        v-if=\"description\"\n      >\n        {{ description }}\n      </div>\n    </div>\n  </component>\n</template>\n\n<style scoped>\n  .tide-card.hoverable:not(.selected):hover {\n    border-color: var(--tide-border-rest);\n  }\n  .tide-card.selected {\n    outline: 2px solid var(--tide-border-high);\n    outline-offset: -2px;\n  }\n</style>\n","<script lang=\"ts\" setup>\n  import { onMounted, onUnmounted, ref } from 'vue';\n\n  import TideButtonIcon from '@/components/TideButtonIcon.vue';\n  import { ICON } from '@/types/Icon';\n  import { PRIORITY } from '@/types/Priority';\n  import { CSS } from '@/types/Styles';\n\n  type Props = {\n    bleed?: number;\n    isFloating?: boolean;\n    isHeadline1?: boolean;\n    isHideawayButtons?: boolean;\n    isScrollByPage?: boolean;\n    isTouchscreen?: boolean;\n    subtitle?: string;\n    title?: string;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    bleed: undefined,\n    isFloating: false,\n    isHeadline1: false,\n    isHideawayButtons: true,\n    isScrollByPage: true,\n    isTouchscreen: undefined,\n    subtitle: undefined,\n    title: undefined,\n  });\n\n  type Emits = {\n    (event: 'slidesAddedToView', slidesInView: number[]): void;\n  };\n\n  const emit = defineEmits<Emits>();\n\n  const containerRef = ref<HTMLDivElement | null>(null);\n  const isFirstSlide = ref<boolean>(true);\n  const isLastSlide = ref<boolean>(false);\n  const showButtons = ref<boolean>(true);\n  const slideObserver = ref<IntersectionObserver | null>(null);\n  const slidesInView = ref<number[]>([]);\n  const slotObserver = ref<MutationObserver | null>(null);\n\n  const slides = ref<HTMLElement[]>([]);\n\n  // TODO: debounce\n  const handleScroll = () => {\n    updateContainerBleed();\n  };\n\n  const observeSlides = () => {\n    const options = {\n      root: containerRef?.value,\n      rootMargin: '0px 1px 0px 0px',\n      threshold: 1,\n    };\n\n    slideObserver.value = new IntersectionObserver((entries) => {\n      let slidesAddedToView: number[] = [];\n\n      entries.forEach((entry) => {\n        const slideIndex = slides.value.indexOf(entry.target as HTMLElement);\n\n        if (entry.isIntersecting) {\n          slidesAddedToView.push(slideIndex);\n          slidesInView.value.push(slideIndex);\n        } else {\n          slidesInView.value = slidesInView.value.filter((slide) => slide !== slideIndex);\n        }\n\n        slidesInView.value.sort((a, b) => a - b);\n      });\n\n      isFirstSlide.value = slidesInView.value.includes(0);\n      isLastSlide.value = slidesInView.value.includes(slides.value.length - 1);\n\n      if (slidesAddedToView.length > 0) emit('slidesAddedToView', slidesAddedToView);\n    }, options);\n\n    slides.value.forEach((child) => {\n      if (slideObserver.value) slideObserver.value.observe(child);\n    });\n  };\n\n  const observeSlot = () => {\n    const observerCallback = () => {\n      if (containerRef.value === null) return;\n\n      slides.value = Array.from(containerRef.value.children) as HTMLElement[];\n      observeSlides();\n    };\n\n    slotObserver.value = new MutationObserver(observerCallback);\n\n    if (containerRef.value) slotObserver.value.observe(containerRef.value, { childList: true });\n  };\n\n  const scrollToOffset = (target: number) => {\n    if (containerRef.value === null) return;\n\n    containerRef.value.scrollTo({\n      behavior: 'smooth',\n      left: target,\n    });\n  };\n\n  const showNextPage = () => {\n    if (slidesInView.value.length === 0) return;\n\n    const nextSlide: number = slidesInView.value[slidesInView.value.length - 1] + 1;\n\n    scrollToOffset(slides.value[nextSlide].offsetLeft);\n  };\n\n  const showPreviousPage = () => {\n    if (slidesInView.value.length === 0) return;\n\n    const previousSlide: number = slidesInView.value[0] - slidesInView.value.length;\n\n    scrollToOffset(slides.value[previousSlide]?.offsetLeft || 0);\n  };\n\n  const showNextSlide = () => {\n    if (slidesInView.value.length === 0) return;\n\n    const nextSlide: number = slidesInView.value.length > 1 ? slidesInView.value[1] : slidesInView.value[0] + 1;\n\n    scrollToOffset(slides.value[nextSlide].offsetLeft);\n  };\n\n  const showPreviousSlide = () => {\n    if (slidesInView.value.length === 0) return;\n\n    const previousSlide: number = slidesInView.value[0] - 1;\n\n    scrollToOffset(slides.value[previousSlide].offsetLeft);\n  };\n\n  const updateContainerBleed = () => {\n    if (containerRef.value === null) return;\n    if (props.bleed == undefined) return;\n\n    if (isLastSlide.value && showButtons.value) {\n      // Prevent gradient from bleeding off left edge in last position.\n      containerRef.value.style.margin = `-${props.bleed}px -${props.bleed}px -${props.bleed}px 0`;\n      containerRef.value.style.padding = `${props.bleed}px ${props.bleed}px ${props.bleed}px 0`;\n    } else {\n      // Prevent gradient from bleeding off right edge in first position.\n      containerRef.value.style.margin = `-${props.bleed}px 0 -${props.bleed}px -${props.bleed}px`;\n      containerRef.value.style.padding = `${props.bleed}px 0 ${props.bleed}px ${props.bleed}px`;\n    }\n  };\n\n  onMounted(() => {\n    if (containerRef.value === null) return;\n\n    slides.value = Array.from(containerRef.value.children) as HTMLElement[];\n\n    observeSlides();\n    observeSlot();\n    updateContainerBleed();\n  });\n\n  onUnmounted(() => {\n    slideObserver.value?.disconnect();\n    slotObserver.value?.disconnect();\n  });\n</script>\n\n<template>\n  <section\n    :class=\"[\n      'tide-carousel',\n      CSS.POSITION.RELATIVE,\n      CSS.DISPLAY.FLEX,\n      CSS.FLEX.DIRECTION.COLUMN,\n      CSS.GAP.ONE,\n      CSS.WIDTH.MAX_FULL,\n    ]\"\n    ref=\"carouselRef\"\n  >\n    <section\n      :class=\"[CSS.DISPLAY.FLEX, props.title ? CSS.AXIS1.BETWEEN : CSS.AXIS1.END, CSS.AXIS2.CENTER, CSS.WIDTH.FULL]\"\n      v-if=\"(!props.isFloating && showButtons) || props.title\"\n    >\n      <div\n        :class=\"[CSS.DISPLAY.FLEX, CSS.FLEX.WRAP, CSS.AXIS2.CENTER, CSS.GAP.ONE]\"\n        v-if=\"props.title\"\n      >\n        <div\n          :class=\"[CSS.WHITESPACE_WRAP.OFF, isHeadline1 ? CSS.FONT.ROLE.HEADLINE_1 : CSS.FONT.ROLE.HEADLINE_2]\"\n          v-if=\"props.title\"\n        >\n          {{ props.title }}\n        </div>\n\n        <div\n          :class=\"[CSS.WHITESPACE_WRAP.OFF, CSS.FONT.ROLE.LABEL_2, CSS.FONT.COLOR.SURFACE.VARIANT]\"\n          v-if=\"props.subtitle\"\n        >\n          {{ props.subtitle }}\n        </div>\n      </div>\n\n      <div\n        :class=\"[CSS.DISPLAY.FLEX, CSS.AXIS2.CENTER, CSS.GAP.ONE]\"\n        v-if=\"!props.isFloating && showButtons\"\n      >\n        <TideButtonIcon\n          :disabled=\"isFirstSlide\"\n          :icon=\"ICON.CHEVRON_LEFT\"\n          :priority=\"PRIORITY.TERTIARY\"\n          @click=\"isScrollByPage ? showPreviousPage() : showPreviousSlide()\"\n        />\n\n        <TideButtonIcon\n          :disabled=\"isLastSlide\"\n          :icon=\"ICON.CHEVRON_RIGHT\"\n          :priority=\"PRIORITY.TERTIARY\"\n          @click=\"isScrollByPage ? showNextPage() : showNextSlide()\"\n        />\n      </div>\n    </section>\n\n    <slot name=\"misc\" />\n\n    <div :class=\"[CSS.POSITION.RELATIVE]\">\n      <ul\n        :class=\"[\n          'tide-carousel-container',\n          props.bleed && 'bleed',\n          CSS.DISPLAY.FLEX,\n          CSS.GAP.ONE,\n          CSS.LIST_BULLETS.OFF,\n          CSS.OVERFLOW.X.SCROLL,\n          CSS.SCROLLBAR.OFF,\n          CSS.SNAP.ON,\n        ]\"\n        ref=\"containerRef\"\n        @scroll=\"handleScroll\"\n      >\n        <slot />\n      </ul>\n\n      <div\n        :class=\"[\n          'tide-carousel-button-overlay',\n          CSS.POSITION.ABSOLUTE,\n          CSS.POSITIONING.TOP,\n          CSS.DISPLAY.FLEX,\n          CSS.AXIS1.BETWEEN,\n          CSS.AXIS2.CENTER,\n          CSS.WIDTH.FULL,\n          CSS.HEIGHT.FULL,\n          CSS.POINTER_EVENTS.OFF,\n          props.isHideawayButtons ? 'hideaway' : '',\n        ]\"\n        v-if=\"isFloating && showButtons\"\n      >\n        <TideButtonIcon\n          :class=\"[CSS.MARGIN.LEFT.ONE, CSS.POINTER_EVENTS.ON]\"\n          :disabled=\"isFirstSlide\"\n          :icon=\"ICON.CHEVRON_LEFT\"\n          :priority=\"PRIORITY.QUATERNARY\"\n          @click=\"isScrollByPage ? showPreviousPage() : showPreviousSlide()\"\n        />\n\n        <TideButtonIcon\n          :class=\"[CSS.MARGIN.RIGHT.ONE, CSS.POINTER_EVENTS.ON]\"\n          :disabled=\"isLastSlide\"\n          :icon=\"ICON.CHEVRON_RIGHT\"\n          :priority=\"PRIORITY.QUATERNARY\"\n          @click=\"isScrollByPage ? showNextPage() : showNextSlide()\"\n        />\n      </div>\n    </div>\n  </section>\n</template>\n\n<style scoped>\n  .tide-carousel-container.bleed {\n    transition: margin var(--tide-animate), padding var(--tide-animate);\n  }\n\n  .tide-carousel-button-overlay.hideaway {\n    opacity: 0;\n  }\n\n  .tide-carousel:hover .tide-carousel-button-overlay.hideaway {\n    opacity: 1;\n  }\n</style>\n","<script lang=\"ts\" setup>\n  import TideIcon from '@/components/TideIcon.vue';\n  import { ELEMENT } from '@/types/Element';\n  import { ICON } from '@/types/Icon';\n  import { CSS } from '@/types/Styles';\n  import { TARGET } from '@/types/Target';\n\n  import type { Element } from '@/types/Element';\n\n  type Props = {\n    element?: Element;\n    href?: string;\n    isNewTab?: boolean;\n    label: string;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    element: ELEMENT.LINK,\n    href: undefined,\n    isNewTab: false,\n  });\n</script>\n\n<template>\n  <component\n    :class=\"[\n      'tide-chip-action',\n      CSS.DISPLAY.FLEX,\n      CSS.AXIS2.CENTER,\n      CSS.GAP.HALF,\n      CSS.BORDER.FULL.ONE,\n      CSS.BORDER.RADIUS.FULL,\n      CSS.PADDING.X.ONE,\n      CSS.PADDING.Y.HALF,\n      CSS.BG.SURFACE.DEFAULT,\n      CSS.FONT.ROLE.LINK_2,\n      CSS.FONT.COLOR.SURFACE.DEFAULT,\n      CSS.UNDERLINE.REST.OFF,\n    ]\"\n    :href=\"props.href\"\n    :target=\"props.isNewTab ? TARGET.BLANK : TARGET.SELF\"\n    :is=\"element\"\n  >\n    <TideIcon :icon=\"ICON.SEARCH\" />\n\n    <span>{{ props.label }}</span>\n  </component>\n</template>\n\n<style scoped>\n  .tide-chip-action:hover {\n    background-color: var(--tide-surface-variant);\n    border-color: var(--tide-border-high);\n  }\n</style>\n","<script lang=\"ts\" setup>\n  import { CSS } from '@/types/Styles';\n\n  type Props = {\n    isActive: boolean;\n    label: string;\n  };\n\n  const props = defineProps<Props>();\n</script>\n\n<template>\n  <button\n    :class=\"[\n      'tide-chip-filter',\n      props.isActive\n        ? [CSS.BG.SECONDARY, CSS.FONT.COLOR.SECONDARY]\n        : [CSS.BG.SURFACE.VARIANT, CSS.FONT.COLOR.SURFACE.DEFAULT],\n      CSS.DISPLAY.FLEX,\n      CSS.AXIS2.CENTER,\n      CSS.GAP.HALF,\n      CSS.BORDER.FULL.ONE,\n      CSS.BORDER.RADIUS.FULL,\n      CSS.PADDING.X.ONE,\n      CSS.PADDING.Y.HALF,\n      CSS.FONT.ROLE.LABEL_2,\n      props.isActive ? 'active' : '',\n    ]\"\n  >\n    <slot />\n    <div :class=\"[CSS.DISPLAY.FLEX, CSS.AXIS1.CENTER, CSS.AXIS2.CENTER, CSS.GAP.HALF]\">\n      <span :class=\"[props.isActive ? '' : 'icon-spacing', CSS.FONT.ROLE.LABEL_1, CSS.WHITESPACE_WRAP.OFF]\">\n        {{ props.label }}\n      </span>\n    </div>\n  </button>\n</template>\n\n<style scoped>\n  /* Border must always exist to prevent resize on hover state, but match background color on rest state to blend in. */\n  .tide-chip-filter {\n    border-color: var(--tide-surface-variant);\n  }\n\n  .tide-chip-filter.active {\n    border-color: var(--tide-secondary);\n  }\n\n  .tide-chip-filter:hover {\n    background-color: var(--tide-surface-variant);\n    border-color: var(--tide-border);\n    color: var(--tide-on-surface);\n  }\n</style>\n","<script lang=\"ts\" setup>\n  import TideIcon from '@/components/TideIcon.vue';\n  import { ICON } from '@/types/Icon';\n  import { CSS } from '@/types/Styles';\n\n  type Props = {\n    label: string;\n  };\n\n  const props = defineProps<Props>();\n</script>\n\n<template>\n  <button\n    :class=\"[\n      'tide-chip-input',\n      CSS.BG.SURFACE.VARIANT,\n      CSS.FONT.COLOR.SURFACE,\n      CSS.DISPLAY.FLEX,\n      CSS.AXIS2.CENTER,\n      CSS.GAP.HALF,\n      CSS.BORDER.FULL.ONE,\n      CSS.BORDER.RADIUS.FULL,\n      CSS.PADDING.X.ONE,\n      CSS.PADDING.Y.HALF,\n      CSS.FONT.ROLE.LABEL_2,\n    ]\"\n  >\n    <span>{{ props.label }}</span>\n\n    <TideIcon :icon=\"ICON.CLOSE\" />\n  </button>\n</template>\n\n<style scoped>\n  .tide-chip-input {\n    border-color: var(--tide-border);\n  }\n\n  .tide-chip-input:hover {\n    border-color: var(--tide-border-high);\n  }\n</style>\n","<script lang=\"ts\" setup>\n  import { CSS } from '@/types/Styles';\n\n  type Props = {\n    heading?: string;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    heading: '',\n  });\n</script>\n\n<template>\n  <section class=\"tide-columns\">\n    <h2 :class=\"[CSS.MARGIN.BOTTOM.HALF]\">\n      {{ props.heading }}\n    </h2>\n\n    <ul :class=\"[CSS.DISPLAY.FLEX, CSS.FLEX.WRAP, CSS.GAP.TWO, CSS.LIST_BULLETS.OFF]\">\n      <li class=\"tide-columns-column\">\n        <slot name=\"section1\" />\n      </li>\n\n      <li class=\"tide-columns-column\">\n        <slot name=\"section2\" />\n      </li>\n\n      <li class=\"tide-columns-column\">\n        <slot name=\"section3\" />\n      </li>\n\n      <li class=\"tide-columns-column\">\n        <slot name=\"section4\" />\n      </li>\n    </ul>\n  </section>\n</template>\n\n<style scoped>\n  .tide-columns-column {\n    width: 100%;\n  }\n\n  @media (min-width: 992px) {\n    .tide-columns-column {\n      width: calc((100% - 2rem) / 2);\n    }\n  }\n\n  @media (min-width: 1232px) {\n    .tide-columns-column {\n      width: calc((100% - 6rem) / 4);\n    }\n  }\n</style>\n","export const OBJECT_FIT = {\n  CONTAIN: 'contain',\n  COVER: 'cover',\n  SCALE_DOWN: 'scale-down',\n} as const;\n\nexport type ObjectFit = (typeof OBJECT_FIT)[keyof typeof OBJECT_FIT];\n","<script lang=\"ts\" setup>\n  import { computed, ref } from 'vue';\n\n  import { OBJECT_FIT } from '@/types/Image';\n  import { CSS } from '@/types/Styles';\n\n  import type { ObjectFit } from '@/types/Image';\n  import type { Source } from '@/types/Source';\n\n  type Props = {\n    alt?: string;\n    height?: string;\n    isLazy?: boolean;\n    objectFit?: ObjectFit;\n    sources?: Source[];\n    src?: string;\n    width?: string;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    alt: '',\n    height: undefined,\n    isLazy: true,\n    objectFit: OBJECT_FIT.COVER,\n    sources: () => [],\n    src: undefined,\n    width: undefined,\n  });\n\n  const picture = ref();\n  const img = ref();\n\n  const imageDefault = 'https://cdn-static.tilabs.io/marketplace/common/image-coming-soon.svg';\n\n  const objectFitClassName = computed<string>(() => {\n    switch (props.objectFit) {\n      case OBJECT_FIT.CONTAIN:\n        return CSS.OBJECT.CONTAIN;\n      case OBJECT_FIT.COVER:\n        return CSS.OBJECT.COVER;\n      case OBJECT_FIT.SCALE_DOWN:\n        return CSS.OBJECT.SCALE_DOWN;\n      default:\n        return OBJECT_FIT.COVER;\n    }\n  });\n\n  const setImageFromDefault = () => {\n    const currentSrc = img.value?.currentSrc;\n    const pictureSource = picture.value?.querySelector(`source[srcset=\"${currentSrc}\"]`);\n\n    if (currentSrc && pictureSource) {\n      pictureSource.srcset = imageDefault;\n    } else if (img.value) {\n      img.value.src = imageDefault;\n    }\n  };\n</script>\n\n<template>\n  <picture\n    :class=\"['tide-image', CSS.DISPLAY.BLOCK]\"\n    ref=\"picture\"\n    :style=\"\n      width || height\n        ? {\n            width: width || undefined,\n            height: height || undefined,\n          }\n        : undefined\n    \"\n  >\n    <source\n      :key=\"source.srcset\"\n      :media=\"`(min-width:${source.media}px)`\"\n      :srcset=\"source.srcset\"\n      v-for=\"source in props.sources\"\n    />\n\n    <img\n      :alt=\"alt\"\n      :class=\"['tide-image-img', CSS.WIDTH.FULL, CSS.HEIGHT.FULL, CSS.OBJECT.CENTER, objectFitClassName]\"\n      :fetchpriority=\"isLazy ? undefined : 'high'\"\n      :loading=\"props.isLazy ? 'lazy' : 'eager'\"\n      ref=\"img\"\n      :src=\"src ?? imageDefault\"\n      @error=\"setImageFromDefault\"\n    />\n  </picture>\n</template>\n\n<style scoped>\n  .tide-image-img {\n    border-radius: inherit;\n  }\n</style>\n","<script lang=\"ts\" setup>\n  import TideImage from '@/components/TideImage.vue';\n  import { OBJECT_FIT } from '@/types/Image';\n  import { CSS } from '@/types/Styles';\n\n  import type { Source } from '@/types/Source';\n\n  type Props = {\n    alt?: string;\n    isLazy?: boolean;\n    sources?: Source[];\n    src?: string;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    alt: '',\n    isLazy: true,\n    sources: () => [],\n    src: undefined,\n  });\n</script>\n\n<template>\n  <div :class=\"['tide-image-background', CSS.POSITION.RELATIVE, CSS.OVERFLOW.XY.HIDDEN, CSS.ISOLATION.ISOLATE]\">\n    <div\n      :class=\"[\n        CSS.POSITION.ABSOLUTE,\n        CSS.HEIGHT.FULL,\n        CSS.WIDTH.FULL,\n        CSS.DISPLAY.FLEX,\n        CSS.AXIS1.CENTER,\n        CSS.AXIS2.CENTER,\n      ]\"\n    >\n      <TideImage\n        :alt=\"props.alt\"\n        :class=\"[CSS.WIDTH.FULL, CSS.HEIGHT.FULL]\"\n        :is-lazy=\"props.isLazy\"\n        :object-fit=\"OBJECT_FIT.COVER\"\n        :sources=\"props.sources\"\n        :src=\"props.src\"\n      />\n    </div>\n\n    <slot />\n  </div>\n</template>\n\n<style scoped>\n  :deep(.tide-image) {\n    z-index: -1;\n  }\n</style>\n","<script lang=\"ts\" setup>\n  import { CSS } from '@/types/Styles';\n\n  type Props = {\n    label?: string | number;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    label: undefined,\n  });\n</script>\n\n<template>\n  <div\n    :class=\"[\n      'tide-indicator',\n      props.label ? '' : 'dot',\n      CSS.DISPLAY.INLINE_BLOCK,\n      CSS.ALIGN.X.CENTER,\n      CSS.BG.GLOBAL.PRIMARY.ERROR,\n      CSS.BORDER.RADIUS.FULL,\n      props.label && props.label.toString().length > 1 ? [CSS.PADDING.X.HALF] : [],\n      props.label\n        ? [CSS.POSITION.RELATIVE, CSS.FONT.ROLE.LABEL_3, CSS.FONT.COLOR.SURFACE.INVERSE]\n        : [CSS.BORDER.FULL.ONE],\n    ]\"\n  >\n    <div\n      :class=\"['tide-indicator-label']\"\n      v-if=\"props.label\"\n    >\n      {{ props.label }}\n    </div>\n  </div>\n</template>\n\n<style scoped>\n  .tide-indicator:not(.dot) {\n    min-width: 1rem;\n    min-height: 1rem;\n  }\n\n  .tide-indicator.dot {\n    border-color: var(--tide-gray-100);\n    width: 10px;\n    height: 10px;\n  }\n\n  .tide-indicator-label {\n    /* Use bottom-weighting to offset the mathematical center to the optical center. */\n    margin-top: -1px;\n  }\n</style>\n","<script setup lang=\"ts\">\n  import TideIcon from '@/components/TideIcon.vue';\n  import { ICON } from '@/types/Icon';\n  import { SIZE } from '@/types/Size';\n  import { CSS } from '@/types/Styles';\n\n  type Props = {\n    isError: boolean;\n    message: string;\n  };\n  defineProps<Props>();\n</script>\n\n<template>\n  <div\n    :class=\"[\n      CSS.DISPLAY.FLEX,\n      CSS.AXIS2.CENTER,\n      CSS.GAP.QUARTER,\n      CSS.FONT.ROLE.LABEL_3,\n      isError ? [CSS.FONT.COLOR.GLOBAL.ERROR] : [CSS.FONT.COLOR.SURFACE.DEFAULT],\n    ]\"\n  >\n    <TideIcon\n      :class=\"[CSS.FLEX.SHRINK.OFF]\"\n      :icon=\"ICON.ERROR\"\n      :size=\"SIZE.SMALL\"\n      v-if=\"isError\"\n    />\n\n    <div>\n      {{ message }}\n    </div>\n  </div>\n</template>\n","import { inject, provide, ref } from 'vue';\n\nimport type { Ref } from 'vue';\n\ntype TideFormContext = {\n  forceShowErrors: Ref<boolean>;\n};\n\nconst FORM_KEY = Symbol('tide-form');\n\nexport const useTideForm = () => {\n  const forceShowErrors = ref<boolean>(false);\n\n  provide<TideFormContext>(FORM_KEY, { forceShowErrors });\n\n  const revealValidationErrors = () => {\n    forceShowErrors.value = true;\n  };\n\n  return { revealValidationErrors };\n};\n\nexport const useFormContext = () => {\n  return inject<TideFormContext>(FORM_KEY);\n};\n","import { formatNumber } from '@/utilities/format';\n\nimport type { ValidationLength, ValidationResult, Validator } from '@/types/Validation';\nimport type { Ref } from 'vue';\n\nexport const errorMessageDefault = 'Please enter a valid value';\n\nexport const VALIDATION_RESULT = {\n  NO_ERROR: {\n    message: '',\n    valid: true,\n  },\n  REQUIRED: {\n    message: 'Please fill out this field',\n    valid: false,\n  },\n} as const;\n\nexport const checkFormat = (format: RegExp, message?: string) => {\n  return (value: string): ValidationResult => {\n    let result: ValidationResult = VALIDATION_RESULT.NO_ERROR;\n\n    if (!value.trim().match(format)) {\n      result = {\n        message: message ?? errorMessageDefault,\n        valid: false,\n      };\n    }\n\n    return result;\n  };\n};\n\nexport const getFieldLengthIsValid = ({ maxlength, minlength, required, value }: ValidationLength) => {\n  const isEmptyAndUnrequired = value.length === 0 && !required;\n  const isTooLong = maxlength && value.length > maxlength;\n  const isTooShort = !isEmptyAndUnrequired && minlength && value.length < minlength;\n  return !isTooShort && !isTooLong;\n};\n\nexport const getFieldValidationResult = ({\n  errorFromProps,\n  maxlength,\n  minlength,\n  required,\n  validators,\n  value,\n}: {\n  errorFromProps: string;\n  maxlength?: number;\n  minlength?: number;\n  required: boolean;\n  validators?: Validator[];\n  value: Ref<string>;\n}): ValidationResult => {\n  // error in props takes precedence over validation error\n  if (errorFromProps !== '')\n    return {\n      message: errorFromProps,\n      valid: false,\n    };\n\n  // custom validator prop errors from have second highest precedence\n  if (validators) {\n    const validation = validateProperty(value.value, validators);\n\n    if (!validation.valid) {\n      return validation;\n    }\n  }\n\n  // all other prop-based errors come last\n  if (required && value.value.trim() === '') {\n    return VALIDATION_RESULT.REQUIRED;\n  }\n\n  if (maxlength || minlength) {\n    const lengthValidation = validateLength({\n      maxlength,\n      minlength,\n      required,\n      value: value.value,\n    });\n\n    if (!lengthValidation.valid) {\n      return lengthValidation;\n    }\n  }\n  return VALIDATION_RESULT.NO_ERROR;\n};\n\nexport const validateLength = ({ maxlength, minlength, required, value }: ValidationLength): ValidationResult => {\n  const response = {\n    message: '',\n    valid: true,\n  };\n\n  response.valid = getFieldLengthIsValid({\n    maxlength,\n    minlength,\n    required,\n    value,\n  });\n\n  if (response.valid) return response;\n\n  response.message = errorMessageDefault;\n\n  if (maxlength && minlength) {\n    response.message = `Enter a value between ${formatNumber(minlength)} and ${formatNumber(maxlength)} characters`;\n  } else if (maxlength) {\n    response.message = `Use ${formatNumber(maxlength)} characters or fewer`;\n  } else if (minlength) {\n    response.message = `Enter at least ${formatNumber(minlength)} characters`;\n  }\n\n  return response;\n};\n\nexport function validateProperty(value: string, validators: ((value: string) => ValidationResult)[]): ValidationResult {\n  for (const validator of validators) {\n    const validation = validator(value);\n    if (!validation.valid) {\n      return validation;\n    }\n  }\n\n  return {\n    message: '',\n    valid: true,\n  };\n}\n","<script lang=\"ts\" setup>\n  import { computed, ref, watch, watchEffect } from 'vue';\n\n  import TideIcon from '@/components/TideIcon.vue';\n  import TideInputSupportingText from '@/components/TideInputSupportingText.vue';\n  import { useFormContext } from '@/composables/useTideForm';\n  import { ICON } from '@/types/Icon';\n  import { SIZE } from '@/types/Size';\n  import { CSS } from '@/types/Styles';\n  import { formatNumber } from '@/utilities/format';\n  import { VALIDATION_RESULT } from '@/utilities/validation';\n\n  import type { ValidationResult } from '@/types/Validation';\n\n  type Props = {\n    disabled?: boolean;\n    error?: string;\n    indeterminate?: boolean;\n    inputId?: string;\n    label: string;\n    name?: string;\n    number?: number;\n    required?: boolean;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    disabled: false,\n    error: '',\n    indeterminate: false,\n    inputId: undefined,\n    label: undefined,\n    name: undefined,\n    number: undefined,\n    required: false,\n  });\n\n  type Emits = {\n    (event: 'valid', valid: boolean): void;\n  };\n  const emit = defineEmits<Emits>();\n\n  const modelValue = defineModel<boolean>({ required: true });\n\n  const formContext = useFormContext();\n\n  const isValidating = ref<boolean>(false);\n  const errorRef = ref<ValidationResult>(VALIDATION_RESULT.NO_ERROR);\n\n  const formattedLabel = computed(() => (props.required ? `${props.label} *` : props.label));\n  const isChecked = computed(() => modelValue.value || props.indeterminate);\n  const showError = computed(() => {\n    if (hasErrorFromProp.value) return true;\n    if (!isValidating.value) return false;\n    return !errorRef.value.valid;\n  });\n  const hasErrorFromProp = computed(() => props.error !== '');\n  const supportingTextMessage = computed(() => showError.value && errorRef.value.message);\n\n  const getCheckboxValidationResult = (): ValidationResult => {\n    if (props.error !== '')\n      return {\n        message: props.error,\n        valid: false,\n      };\n    if (!props.required || isChecked.value) return VALIDATION_RESULT.NO_ERROR;\n    return VALIDATION_RESULT.REQUIRED;\n  };\n\n  watchEffect(() => {\n    errorRef.value = getCheckboxValidationResult();\n  });\n\n  watch(\n    modelValue,\n    () => {\n      if (modelValue.value) isValidating.value = true;\n    },\n    { immediate: true }\n  );\n\n  watch(\n    () => formContext?.forceShowErrors.value,\n    (newValue) => {\n      if (newValue) isValidating.value = true;\n    },\n    { immediate: true }\n  );\n\n  watch(\n    errorRef,\n    () => {\n      emit('valid', errorRef.value.valid);\n    },\n    { deep: true, immediate: true }\n  );\n</script>\n\n<template>\n  <div :class=\"['tide-input-checkbox', CSS.DISPLAY.FLEX, CSS.FLEX.DIRECTION.COLUMN, CSS.GAP.QUARTER]\">\n    <label\n      :class=\"[\n        CSS.AXIS2.CENTER,\n        CSS.DISPLAY.FLEX,\n        CSS.FONT.ROLE.BODY_1,\n        CSS.GAP.HALF,\n        CSS.USER_SELECT.NONE,\n        showError ? CSS.FONT.COLOR.GLOBAL.ERROR : CSS.FONT.COLOR.SURFACE.DEFAULT,\n        disabled ? [CSS.OPACITY.DISABLED, CSS.CURSOR.NOT_ALLOWED] : [CSS.CURSOR.POINTER],\n      ]\"\n      :for=\"inputId\"\n    >\n      <input\n        :checked=\"isChecked\"\n        :class=\"['tide-screen-reader-only']\"\n        :disabled=\"disabled\"\n        :name=\"name\"\n        ref=\"input\"\n        :id=\"inputId\"\n        type=\"checkbox\"\n        v-model=\"modelValue\"\n      />\n\n      <div\n        :class=\"[\n          'tide-input-checkbox-custom',\n          CSS.AXIS1.CENTER,\n          CSS.AXIS2.CENTER,\n          CSS.BORDER.FULL.ONE,\n          CSS.BORDER.RADIUS.QUARTER,\n          CSS.DISPLAY.FLEX,\n          CSS.FLEX.SHRINK.OFF,\n          CSS.POSITION.RELATIVE,\n          isChecked\n            ? [showError ? CSS.BG.GLOBAL.PRIMARY.ERROR : [CSS.BG.SECONDARY, CSS.BORDER.COLOR.HIGH]]\n            : [\n                showError\n                  ? [CSS.BORDER.COLOR.GLOBAL.ERROR, CSS.BG.GLOBAL.SURFACE.ERROR]\n                  : [CSS.BORDER.COLOR.DEFAULT, CSS.BG.SURFACE.DEFAULT],\n              ],\n        ]\"\n      >\n        <TideIcon\n          :class=\"[CSS.FONT.COLOR.SECONDARY]\"\n          :icon=\"indeterminate ? ICON.REMOVE : ICON.CHECK\"\n          :size=\"SIZE.SMALL\"\n          v-if=\"isChecked\"\n        />\n      </div>\n\n      <div\n        :class=\"[CSS.AXIS1.BETWEEN, CSS.DISPLAY.FLEX, CSS.FLEX.GROW.ON, CSS.FONT.ROLE.BODY_1]\"\n        v-if=\"label\"\n      >\n        <span>{{ formattedLabel }}</span>\n\n        <span\n          :class=\"[CSS.FONT.COLOR.SURFACE.VARIANT]\"\n          v-if=\"number\"\n        >\n          ({{ formatNumber(number) }})\n        </span>\n      </div>\n    </label>\n\n    <TideInputSupportingText\n      :message=\"supportingTextMessage\"\n      is-error\n      v-if=\"supportingTextMessage\"\n    />\n  </div>\n</template>\n\n<style scoped>\n  .tide-input-checkbox {\n    align-self: start;\n  }\n\n  .tide-input-checkbox-custom {\n    width: 24px;\n    height: 24px;\n  }\n\n  label:has(input:focus-visible) {\n    outline: auto;\n    outline-offset: 2px;\n  }\n</style>\n","<script lang=\"ts\">\n  /**\n   * @deprecated Use `TideInputCheckbox.vue` imported from 'tide-design-system' npm package instead.\n   */\n  export default {};\n</script>\n\n<script lang=\"ts\" setup>\n  import { computed } from 'vue';\n\n  import TideIcon from '@/components/TideIcon.vue';\n  import { ICON } from '@/types/Icon';\n  import { SIZE } from '@/types/Size';\n  import { CSS } from '@/types/Styles';\n  import { formatNumber } from '@/utilities/format';\n\n  type Props = {\n    checked?: boolean;\n    disabled?: boolean;\n    indeterminate?: boolean;\n    inputId?: string;\n    label?: string;\n    name?: string;\n    number?: number;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    checked: false,\n    disabled: false,\n    indeterminate: false,\n    inputId: undefined,\n    label: undefined,\n    name: undefined,\n    number: undefined,\n  });\n\n  const isChecked = computed(() => props.checked || props.indeterminate);\n</script>\n\n<template>\n  <div\n    :class=\"[\n      'tide-input-checkbox',\n      CSS.DISPLAY.FLEX,\n      CSS.AXIS2.CENTER,\n      CSS.GAP.HALF,\n      CSS.FONT.ROLE.BODY_1,\n      disabled ? ['disabled', CSS.POINTER_EVENTS.OFF] : CSS.CURSOR.POINTER,\n    ]\"\n  >\n    <input\n      :checked=\"isChecked\"\n      :class=\"[CSS.DISPLAY.NONE]\"\n      :disabled=\"props.disabled\"\n      :name=\"props.name\"\n      ref=\"input\"\n      @click.prevent\n      :id=\"props.inputId\"\n      type=\"checkbox\"\n    />\n\n    <div\n      :class=\"[\n        'tide-input-checkbox-custom',\n        CSS.POSITION.RELATIVE,\n        CSS.DISPLAY.FLEX,\n        CSS.AXIS1.CENTER,\n        CSS.AXIS2.CENTER,\n        CSS.FLEX.SHRINK.OFF,\n        CSS.BORDER.FULL.ONE,\n        isChecked ? [CSS.BORDER.COLOR.HIGH, CSS.BG.SECONDARY] : [CSS.BORDER.COLOR.DEFAULT, CSS.BG.SURFACE.DEFAULT],\n        CSS.BORDER.RADIUS.QUARTER,\n        isChecked && 'checked',\n        disabled ? CSS.CURSOR.NOT_ALLOWED : CSS.CURSOR.POINTER,\n      ]\"\n    >\n      <TideIcon\n        :class=\"[CSS.FONT.COLOR.SECONDARY]\"\n        :icon=\"props.indeterminate ? ICON.REMOVE : ICON.CHECK\"\n        :size=\"SIZE.SMALL\"\n        v-if=\"isChecked\"\n      />\n    </div>\n\n    <label\n      :class=\"[\n        CSS.DISPLAY.FLEX,\n        CSS.AXIS1.BETWEEN,\n        CSS.FLEX.GROW.ON,\n        CSS.FONT.ROLE.BODY_1,\n        disabled ? CSS.CURSOR.NOT_ALLOWED : CSS.CURSOR.POINTER,\n      ]\"\n      :for=\"props.inputId\"\n      @click.prevent\n      v-if=\"label\"\n    >\n      <span>{{ label }}</span>\n      <span\n        :class=\"[CSS.FONT.COLOR.SURFACE.VARIANT]\"\n        v-if=\"props.number\"\n      >\n        ({{ formatNumber(props.number) }})\n      </span>\n    </label>\n  </div>\n</template>\n\n<style scoped>\n  .tide-input-checkbox.disabled {\n    opacity: var(--tide-disabled);\n  }\n\n  .tide-input-checkbox-custom {\n    width: 24px;\n    height: 24px;\n  }\n</style>\n","<script lang=\"ts\" setup>\n  import { computed } from 'vue';\n\n  import { CSS } from '@/types/Styles';\n  import { formatNumber } from '@/utilities/format';\n\n  type Props = {\n    disabled?: boolean;\n    inputId?: string;\n    label: string;\n    name: string;\n    number?: number;\n    value: string;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    disabled: false,\n    inputId: undefined,\n    label: undefined,\n    number: undefined,\n  });\n\n  const modelValue = defineModel<string>({ required: true });\n\n  const isChecked = computed(() => modelValue.value === props.value);\n</script>\n\n<template>\n  <label\n    :class=\"[\n      'tide-input-radio',\n      CSS.DISPLAY.FLEX,\n      CSS.AXIS2.CENTER,\n      CSS.GAP.HALF,\n      CSS.USER_SELECT.NONE,\n      props.disabled ? [CSS.OPACITY.DISABLED, CSS.CURSOR.NOT_ALLOWED] : [CSS.CURSOR.POINTER],\n    ]\"\n    :for=\"props.inputId\"\n  >\n    <input\n      :class=\"['tide-screen-reader-only']\"\n      :disabled=\"disabled\"\n      :name=\"name\"\n      :value=\"value\"\n      :id=\"props.inputId\"\n      type=\"radio\"\n      v-model=\"modelValue\"\n    />\n\n    <div\n      :class=\"[\n        'tide-input-radio-custom',\n        CSS.POSITION.RELATIVE,\n        CSS.DISPLAY.FLEX,\n        CSS.AXIS1.CENTER,\n        CSS.AXIS2.CENTER,\n        CSS.BORDER.FULL.ONE,\n        isChecked ? [CSS.BORDER.COLOR.HIGH] : [CSS.BORDER.COLOR.DEFAULT],\n        CSS.BORDER.RADIUS.FULL,\n        CSS.BG.SURFACE.DEFAULT,\n        CSS.CURSOR.POINTER,\n        CSS.POINTER_EVENTS.ON,\n      ]\"\n    >\n      <div :class=\"['tide-input-radio-check', CSS.BORDER.RADIUS.FULL, isChecked && CSS.BG.SECONDARY]\" />\n    </div>\n\n    <div :class=\"[CSS.DISPLAY.FLEX, CSS.FLEX.GROW.ON, CSS.AXIS1.BETWEEN, CSS.FONT.ROLE.BODY_1]\">\n      <span>{{ label }}</span>\n      <span\n        :class=\"[CSS.FONT.COLOR.SURFACE.VARIANT]\"\n        v-if=\"props.number\"\n      >\n        ({{ formatNumber(props.number) }})\n      </span>\n    </div>\n  </label>\n</template>\n\n<style scoped>\n  .tide-input-radio-custom {\n    width: 24px;\n    height: 24px;\n  }\n\n  .tide-input-radio-check {\n    width: 16px;\n    height: 16px;\n  }\n\n  label:has(input:focus-visible) {\n    outline: auto;\n    outline-offset: 2px;\n  }\n</style>\n","<script lang=\"ts\">\n  /**\n   * @deprecated Use `TideInputRadio.vue` imported from 'tide-design-system' npm package instead.\n   */\n  export default {};\n</script>\n\n<script lang=\"ts\" setup>\n  import { ref, watch } from 'vue';\n\n  import { CSS } from '@/types/Styles';\n  import { formatNumber } from '@/utilities/format';\n\n  type Props = {\n    checked?: boolean;\n    disabled?: boolean;\n    inputId?: string;\n    label?: string;\n    name?: string;\n    number?: number;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    checked: false,\n    disabled: false,\n    inputId: undefined,\n    label: undefined,\n    number: undefined,\n  });\n\n  const checked = ref(props.checked);\n\n  watch(\n    () => props.checked,\n    (newValue, oldValue) => {\n      if (newValue !== oldValue || newValue !== checked.value) {\n        checked.value = newValue;\n      }\n    }\n  );\n</script>\n\n<template>\n  <div\n    :class=\"[\n      'tide-input-radio',\n      CSS.DISPLAY.FLEX,\n      CSS.AXIS2.CENTER,\n      CSS.GAP.HALF,\n      CSS.POINTER_EVENTS.OFF,\n      props.disabled && 'disabled',\n    ]\"\n  >\n    <input\n      :checked=\"checked\"\n      :class=\"[CSS.DISPLAY.NONE]\"\n      :id=\"props.inputId\"\n      name=\"\"\n      type=\"radio\"\n      value=\"\"\n    />\n\n    <div\n      :class=\"[\n        'tide-input-radio-custom',\n        CSS.POSITION.RELATIVE,\n        CSS.DISPLAY.FLEX,\n        CSS.AXIS1.CENTER,\n        CSS.AXIS2.CENTER,\n        CSS.BORDER.FULL.ONE,\n        checked ? CSS.BORDER.COLOR.HIGH : CSS.BORDER.COLOR.DEFAULT,\n        CSS.BORDER.RADIUS.FULL,\n        CSS.BG.SURFACE.DEFAULT,\n        CSS.CURSOR.POINTER,\n        CSS.POINTER_EVENTS.ON,\n        checked && 'checked',\n      ]\"\n    >\n      <div :class=\"['tide-input-radio-check', CSS.BORDER.RADIUS.FULL, props.checked && CSS.BG.SECONDARY]\" />\n    </div>\n\n    <label\n      :class=\"[\n        CSS.DISPLAY.FLEX,\n        CSS.FLEX.GROW.ON,\n        CSS.AXIS1.BETWEEN,\n        CSS.FONT.ROLE.BODY_1,\n        CSS.CURSOR.POINTER,\n        CSS.POINTER_EVENTS.ON,\n      ]\"\n      :for=\"props.inputId\"\n    >\n      <span>{{ label }}</span>\n      <span\n        :class=\"[CSS.FONT.COLOR.SURFACE.VARIANT]\"\n        v-if=\"props.number\"\n      >\n        ({{ formatNumber(props.number) }})\n      </span>\n    </label>\n  </div>\n</template>\n\n<style scoped>\n  .tide-input-radio.disabled {\n    opacity: var(--tide-disabled);\n  }\n\n  .tide-input-radio-custom {\n    width: 24px;\n    height: 24px;\n  }\n\n  .tide-input-radio-check {\n    width: 16px;\n    height: 16px;\n  }\n</style>\n","import { formatNumber, formatPhone, formatPrice } from '@/utilities/format';\n\nexport type Formatted = {\n  [key: string]: string | string[] | number;\n};\n\nexport const FORMAT = {\n  NUMBER: formatNumber,\n  PHONE: formatPhone,\n  PRICE: formatPrice,\n} as const;\n\nexport const FORMAT_REGEX = {\n  alpha: /^[a-zA-Z]+$/g,\n  alphaNumberOrEmpty: /^$|^[a-z0-9]+$/i,\n  alphaSpace: /^[a-zA-Z ]+$/g,\n  email:\n    /^(([^<>()[\\]\\\\.,;:\\s@\"]+(\\.[^<>()[\\]\\\\.,;:\\s@\"]+)*)|(\".+\"))@((\\[[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\])|(([a-zA-Z\\-0-9]+\\.)+[a-zA-Z]{2,}))$/,\n  numberFormatted: /^$|(?=.)^\\$?(([1-9][0-9]{0,2}(,[0-9]{3})*)|0)?(\\.[0-9]{1,2})?$/,\n  phone: /^(?:\\d{3}-\\d{3}-\\d{4}|\\d{1}-\\d{3}-\\d{3}-\\d{4})?$/,\n  price: /(?=.)^\\$?(([1-9][0-9]{0,2}(,[0-9]{3})*)|0)?(\\.[0-9]{1,2})?$/,\n};\n","import { FORMAT_REGEX } from '@/types/Formatted';\nimport { checkFormat } from '@/utilities/validation';\n\nexport const VALIDATOR = {\n  ALPHA_NUMBER_EMPTY: checkFormat(FORMAT_REGEX.alphaNumberOrEmpty),\n  ALPHA_SPACE: checkFormat(FORMAT_REGEX.alphaSpace),\n  EMAIL: checkFormat(FORMAT_REGEX.email, 'Enter a valid email address (e.g. name@example.com)'),\n  NUMBER: checkFormat(FORMAT_REGEX.numberFormatted, 'Enter a valid number'),\n  PHONE: checkFormat(FORMAT_REGEX.phone, 'Enter a valid phone number'),\n} as const;\n\nexport type ValidationError = string | boolean;\nexport type ValidationResult = {\n  message: string;\n  valid: boolean;\n};\n\nexport type ValidationLength = {\n  maxlength?: number;\n  minlength?: number;\n  required: boolean;\n  value: string;\n};\n\nexport type Validator = (value: string) => ValidationResult;\n\nexport const ERROR_DISPLAY = {\n  EAGER: 'eager',\n  LAZY: 'lazy',\n} as const;\n\nexport type ErrorDisplay = (typeof ERROR_DISPLAY)[keyof typeof ERROR_DISPLAY];\n","<script lang=\"ts\" setup>\n  import { computed, ref, useId, watch, watchEffect } from 'vue';\n\n  import TideIcon from '@/components/TideIcon.vue';\n  import TideInputSupportingText from '@/components/TideInputSupportingText.vue';\n  import { useFormContext } from '@/composables/useTideForm';\n  import { ICON } from '@/types/Icon';\n  import { SIZE } from '@/types/Size';\n  import { CSS } from '@/types/Styles';\n  import { ERROR_DISPLAY } from '@/types/Validation';\n  import { VALIDATION_RESULT, getFieldValidationResult } from '@/utilities/validation';\n\n  import type { SelectOption, SelectOptionGroup } from '@/types/Select';\n  import type { ErrorDisplay, ValidationResult } from '@/types/Validation';\n\n  type Props = {\n    disabled?: boolean;\n    error?: string;\n    errorDisplay?: ErrorDisplay;\n    label?: string;\n    name?: string;\n    optgroups?: (SelectOption | SelectOptionGroup)[] | readonly (SelectOption | SelectOptionGroup)[];\n    options?: SelectOption[] | readonly SelectOption[];\n    required?: boolean;\n    supportingText?: string;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    disabled: false,\n    error: '',\n    errorDisplay: ERROR_DISPLAY.LAZY,\n    inputId: undefined,\n    label: undefined,\n    name: undefined,\n    optgroups: undefined,\n    options: undefined,\n    required: false,\n    supportingText: undefined,\n  });\n\n  type Emits = {\n    (event: 'valid', isValid: boolean): void;\n  };\n\n  const emit = defineEmits<Emits>();\n\n  const modelValue = defineModel<string>({ required: true });\n\n  const formContext = useFormContext();\n\n  const errorRef = ref<ValidationResult>(VALIDATION_RESULT.NO_ERROR);\n  const hasFocus = ref<boolean>(false);\n  const inputId = useId();\n  const isValidating = ref<boolean>(false);\n  const selectElement = ref<HTMLSelectElement | null>(null);\n\n  const formattedLabel = computed(() => (props.required ? `${props.label} *` : props.label));\n  const showError = computed(() => {\n    if (hasErrorFromProp.value) return true;\n    if (!isValidating.value) return false;\n    return !errorRef.value.valid;\n  });\n  const hasErrorFromProp = computed(() => props.error !== '');\n  const hasMinilabel = computed(() => hasFocus.value || !isEmpty.value);\n  const isEmpty = computed(() => modelValue.value === '');\n  const supportingTextMessage = computed(() => (showError.value && errorRef.value.message) || props.supportingText);\n\n  const expandOptions = () => {\n    const event = new MouseEvent('mousedown');\n    selectElement?.value?.dispatchEvent(event);\n  };\n\n  const handleFocus = () => {\n    hasFocus.value = true;\n    if (props.errorDisplay === ERROR_DISPLAY.EAGER) isValidating.value = true;\n  };\n\n  const handleFocusOut = () => {\n    hasFocus.value = false;\n    if (props.errorDisplay === ERROR_DISPLAY.LAZY) isValidating.value = true;\n  };\n\n  watchEffect(() => {\n    errorRef.value = getFieldValidationResult({\n      errorFromProps: props.error,\n      required: props.required,\n      value: modelValue,\n    });\n  });\n\n  watch(\n    () => formContext?.forceShowErrors.value,\n    (newValue) => {\n      if (newValue) isValidating.value = true;\n    },\n    { immediate: true }\n  );\n\n  watch(\n    errorRef,\n    () => {\n      emit('valid', errorRef.value.valid);\n    },\n    { deep: true, immediate: true }\n  );\n</script>\n\n<template>\n  <div\n    :class=\"[\n      'tide-input-select',\n      CSS.DISPLAY.FLEX,\n      CSS.FLEX.DIRECTION.COLUMN,\n      CSS.GAP.QUARTER,\n      disabled && 'disabled',\n      showError && 'error',\n    ]\"\n  >\n    <div\n      :class=\"[\n        'tide-input-border',\n        CSS.POSITION.RELATIVE,\n        CSS.DISPLAY.FLEX,\n        CSS.AXIS2.CENTER,\n        CSS.GAP.HALF,\n        CSS.BORDER.RADIUS.HALF,\n        CSS.BG.SURFACE.DEFAULT,\n        props.disabled ? CSS.CURSOR.NOT_ALLOWED : '',\n        CSS.OVERFLOW.XY.HIDDEN,\n      ]\"\n      @click=\"expandOptions\"\n    >\n      <div :class=\"[CSS.DISPLAY.FLEX, CSS.FLEX.DIRECTION.COLUMN, CSS.WIDTH.FULL]\">\n        <label\n          :class=\"[\n            hasMinilabel ? ['minilabel', CSS.FONT.ROLE.LABEL_3] : CSS.FONT.ROLE.LABEL_1,\n            CSS.POSITION.ABSOLUTE,\n            CSS.POSITIONING.LEFT,\n            CSS.MARGIN.TOP.HALF,\n            CSS.MARGIN.LEFT.ONE,\n            !showError && CSS.FONT.COLOR.SURFACE.VARIANT,\n            CSS.POINTER_EVENTS.OFF,\n          ]\"\n          :for=\"inputId\"\n          v-if=\"label\"\n        >\n          {{ formattedLabel }}\n        </label>\n\n        <select\n          :class=\"[\n            CSS.PADDING.BOTTOM.HALF,\n            CSS.PADDING.X.ONE,\n            CSS.WIDTH.FULL,\n            disabled && CSS.CURSOR.NOT_ALLOWED,\n            CSS.FONT.ROLE.BODY_1,\n          ]\"\n          :disabled=\"disabled\"\n          :name=\"name\"\n          ref=\"selectElement\"\n          :required=\"required\"\n          @focus=\"handleFocus\"\n          @focusout=\"handleFocusOut\"\n          :id=\"inputId\"\n          v-model=\"modelValue\"\n        >\n          <template v-for=\"optgroup in props.optgroups\">\n            <optgroup\n              :class=\"[CSS.WIDTH.FULL, CSS.BG.SURFACE.DEFAULT]\"\n              :key=\"(optgroup as SelectOptionGroup).label\"\n              :label=\"(optgroup as SelectOptionGroup).label\"\n              v-if=\"(optgroup as SelectOptionGroup).options\"\n            >\n              <option\n                :class=\"[CSS.WIDTH.FULL, CSS.BG.SURFACE.DEFAULT]\"\n                :key=\"option.value\"\n                :value=\"option.value\"\n                v-for=\"option in (optgroup as SelectOptionGroup).options\"\n              >\n                {{ option.label }}\n              </option>\n            </optgroup>\n\n            <option\n              :class=\"[CSS.WIDTH.FULL, CSS.BG.SURFACE.DEFAULT]\"\n              :key=\"(optgroup as SelectOption).value\"\n              :selected=\"modelValue === (optgroup as SelectOption).value ? true : undefined\"\n              :value=\"(optgroup as SelectOption).value\"\n              v-else\n            >\n              {{ (optgroup as SelectOption).label }}\n            </option>\n          </template>\n\n          <option\n            :class=\"[CSS.WIDTH.FULL, CSS.BG.SURFACE.DEFAULT]\"\n            :key=\"option.value\"\n            :selected=\"modelValue === option.value ? true : undefined\"\n            :value=\"option.value\"\n            v-for=\"option in options\"\n          >\n            {{ option.label }}\n          </option>\n        </select>\n      </div>\n\n      <TideIcon\n        :class=\"[CSS.POSITION.ABSOLUTE, CSS.POSITIONING.RIGHT, CSS.MARGIN.RIGHT.ONE, CSS.POINTER_EVENTS.OFF]\"\n        :icon=\"ICON.EXPAND_MORE\"\n        :size=\"SIZE.SMALL\"\n      />\n    </div>\n\n    <TideInputSupportingText\n      :is-error=\"showError\"\n      :message=\"supportingTextMessage\"\n      v-if=\"supportingTextMessage\"\n    />\n  </div>\n</template>\n\n<style scoped>\n  select {\n    appearance: none;\n  }\n\n  label {\n    height: 1.1875rem;\n    transition: font-size var(--tide-animate), transform var(--tide-animate);\n  }\n\n  label:not(.minilabel) {\n    transform: translate(0, calc(9 / 16 * 1rem));\n  }\n\n  .tide-input-select.disabled {\n    opacity: var(--tide-disabled);\n  }\n\n  .tide-input-select.error .tide-input-border {\n    outline-color: var(--tide-error-border);\n    background-color: var(--tide-error-surface);\n  }\n\n  .tide-input-select.error:focus-within .tide-input-border {\n    outline-color: var(--tide-error-border);\n  }\n\n  .tide-input-select:focus-within .tide-input-border {\n    --tide-input-outline-width: var(--tide-border-width-2);\n    outline-color: var(--tide-surface-border-high);\n  }\n\n  .tide-input-border {\n    --tide-input-outline-width: var(--tide-border-width-1);\n    outline: var(--tide-input-outline-width) solid var(--tide-border);\n    outline-offset: calc(var(--tide-input-outline-width) * -1);\n  }\n\n  .tide-input-select.error {\n    color: var(--tide-error-primary);\n  }\n\n  .tide-input-select.error option {\n    color: var(--tide-on-surface);\n  }\n\n  select {\n    padding-top: 27px;\n  }\n</style>\n","import { priceToNumber } from '@/utilities/format';\n\nimport type { StringInput } from '@/types/FormDeprecated';\nimport type { SelectOption } from '@/types/Select';\nimport type { ValidationError, ValidationLength, ValidationResult, Validator } from '@/types/ValidationDeprecated';\nimport type { Ref } from 'vue';\n\n/**\n * @deprecated\n */\ntype RangeData = {\n  min: number | null;\n  max: number | null;\n};\n\n/**\n * @deprecated\n */\nexport const errorMessageDefault = 'Please enter a valid value.';\n\n/**\n * @deprecated\n */\nexport const noError = {\n  message: '',\n  valid: true,\n} as Readonly<ValidationResult>;\n\n/**\n * @deprecated\n */\nexport const checkFormat = (format: RegExp) => {\n  return (value: string): ValidationResult => {\n    let result = noError;\n\n    if (!value.trim().match(format)) {\n      result = {\n        message: errorMessageDefault,\n        valid: false,\n      };\n    }\n\n    return result;\n  };\n};\n\n/**\n * @deprecated\n */\nexport const getErrorMessage = (errorFromProps: ValidationError, errorFromRef: ValidationError) => {\n  // error in props takes precedence over validation error\n  if (typeof errorFromProps === 'string' && errorFromProps.length > 0) return errorFromProps;\n\n  return typeof errorFromRef === 'string' && errorFromRef.length > 0 ? errorFromRef : errorMessageDefault;\n};\n\n/**\n * @deprecated\n */\nexport const getFieldHasError = (errorFromProps: ValidationError, errorFromRef: ValidationError) =>\n  errorFromProps !== false || errorFromRef !== false;\n\n/**\n * @deprecated\n */\nexport const getFieldLengthIsValid = ({ maxlength, minlength, required, value }: ValidationLength) => {\n  const isEmptyAndUnrequired = value.length === 0 && !required;\n  const isTooLong = maxlength && value.length > maxlength;\n  const isTooShort = !isEmptyAndUnrequired && minlength && value.length < minlength;\n\n  return !isTooShort && !isTooLong;\n};\n\n/**\n * @deprecated\n */\nexport const getMaxRangeIsValid = ({ min }: Pick<RangeData, 'min'>, type?: 'price') => {\n  return (value: string): ValidationResult => {\n    let newMax: number | null = type === 'price' ? priceToNumber(value) : Number(value);\n    newMax = !isNaN(newMax) ? newMax : null;\n    if (min && newMax) {\n      if (newMax >= min) {\n        return {\n          message: '',\n          valid: true,\n        };\n      } else {\n        return {\n          message: `Must be greater than min`,\n          valid: false,\n        };\n      }\n    } else {\n      return noError;\n    }\n  };\n};\n\n/**\n * @deprecated\n */\nexport const getMinRangeIsValid = ({ max }: Pick<RangeData, 'max'>, type?: 'price') => {\n  return (value: string): ValidationResult => {\n    let newMin: number | null = type === 'price' ? priceToNumber(value) : Number(value);\n    newMin = !isNaN(newMin) ? newMin : null;\n    if (max && newMin) {\n      if (newMin <= max) {\n        return {\n          message: '',\n          valid: true,\n        };\n      } else {\n        return {\n          message: `Must be less than max`,\n          valid: false,\n        };\n      }\n    } else {\n      return noError;\n    }\n  };\n};\n\n/**\n * @deprecated\n */\nexport const getSelectOptionsFromStrings = (strings: string[]) =>\n  strings.map(\n    (option) =>\n      ({\n        label: option,\n        value: option,\n      } as SelectOption)\n  );\n\n/**\n * @deprecated\n */\nexport const handleFieldValidation = ({\n  error,\n  errorFromProps,\n  maxlength,\n  minlength,\n  required = false,\n  validators,\n  value,\n}: {\n  error: Ref<ValidationError>;\n  errorFromProps: ValidationError;\n  maxlength?: number;\n  minlength?: number;\n  required?: boolean;\n  validators?: Validator[];\n  value?: Ref<string | undefined>;\n}) => {\n  // error in props takes precedence over validation error\n\n  error.value = errorFromProps ? errorFromProps : false;\n\n  if (!error.value && validators) {\n    const validation = validateProperty(value?.value || '', validators);\n\n    if (!validation.valid) {\n      error.value = validation.message;\n    }\n  }\n\n  if (!error.value && (maxlength || minlength)) {\n    const lengthValidation = validateLength({\n      maxlength,\n      minlength,\n      required,\n      value: value?.value || '',\n    });\n\n    if (!lengthValidation.valid) {\n      error.value = lengthValidation.message;\n    }\n  }\n};\n\n/**\n * @deprecated\n */\nexport function validateFieldsFromRefs(fields: { [key: string]: Ref<StringInput | null> }) {\n  let valid = true;\n\n  for (const key in fields) {\n    if (fields[key].value?.required) {\n      const value = fields[key].value?.value;\n      valid = valid && !!value && value.trim() !== '';\n    }\n\n    const error = fields[key].value?.error;\n    valid = valid && !error;\n  }\n\n  return valid;\n}\n\n/**\n * @deprecated\n */\nexport const validateLength = ({\n  maxlength,\n  minlength,\n  required = false,\n  value,\n}: ValidationLength): ValidationResult => {\n  const response = {\n    message: '',\n    valid: true,\n  };\n\n  response.valid = getFieldLengthIsValid({\n    maxlength,\n    minlength,\n    required,\n    value,\n  });\n\n  if (response.valid) return response;\n\n  response.message = errorMessageDefault;\n\n  if (maxlength && minlength) {\n    response.message = `Please enter a value between ${minlength} and ${maxlength} characters in length.`;\n  } else if (maxlength) {\n    response.message = `Please enter a value no more than ${maxlength} characters in length.`;\n  } else if (minlength) {\n    response.message = `Please enter a value no less than ${minlength} characters in length.`;\n  }\n\n  return response;\n};\n\n/**\n * @deprecated\n */\nexport function validateProperty(value: string, validators: ((value: string) => ValidationResult)[]): ValidationResult {\n  for (const validator of validators) {\n    const validation = validator(value);\n    if (!validation.valid) {\n      return validation;\n    }\n  }\n\n  return {\n    message: '',\n    valid: true,\n  };\n}\n","<script lang=\"ts\">\n  /**\n   * @deprecated Use `TideInputSelect.vue` imported from 'tide-design-system' npm package instead.\n   */\n  export default {};\n</script>\n\n<script lang=\"ts\" setup>\n  import { computed, ref, watch } from 'vue';\n\n  import TideIcon from '@/components/TideIcon.vue';\n  import { ICON } from '@/types/Icon';\n  import { SIZE } from '@/types/Size';\n  import { CSS } from '@/types/Styles';\n  import { getErrorMessage, getFieldHasError } from '@/utilities/validation-deprecated';\n\n  import type { SelectField } from '@/types/FieldDeprecated';\n  import type { SelectOption, SelectOptionGroup } from '@/types/Select';\n\n  export interface Props extends SelectField {\n    inputId?: string;\n    supportingText?: string;\n  }\n\n  const props = withDefaults(defineProps<Props>(), {\n    disabled: false,\n    error: false,\n    inputId: undefined,\n    label: undefined,\n    required: false,\n    supportingText: undefined,\n    value: undefined,\n  });\n\n  const error = ref(props.error);\n  const hasFocus = ref(false);\n  const input = ref<HTMLSelectElement | null>(null);\n  const required = ref(props.required);\n  const value = ref<string | undefined>(props.value);\n\n  const errorMessage = computed(() => getErrorMessage(props.error, error.value));\n  const formattedLabel = computed(() => (props.required ? `${props.label} *` : props.label));\n  const hasError = computed(() => (props.required && !value.value) || getFieldHasError(error.value, props.error));\n  const hasMinilabel = computed(() => hasFocus.value || !isEmpty.value);\n  const isEmpty = computed(() => value.value === undefined);\n\n  const expandOptions = () => {\n    const event = new MouseEvent('mousedown');\n    input?.value?.dispatchEvent(event);\n  };\n\n  const handleFocus = () => {\n    hasFocus.value = true;\n  };\n\n  const handleFocusOut = () => {\n    hasFocus.value = false;\n  };\n\n  watch(\n    () => props.value,\n    (newValue, oldValue) => {\n      if (newValue !== oldValue || newValue !== value.value) {\n        value.value = newValue;\n      }\n    }\n  );\n\n  defineExpose({ error, value });\n</script>\n\n<template>\n  <div\n    :class=\"[\n      'tide-input-select',\n      CSS.DISPLAY.FLEX,\n      CSS.FLEX.DIRECTION.COLUMN,\n      CSS.GAP.QUARTER,\n      disabled && 'disabled',\n      hasError && 'error',\n    ]\"\n  >\n    <div\n      :class=\"[\n        'tide-input-border',\n        CSS.POSITION.RELATIVE,\n        CSS.DISPLAY.FLEX,\n        CSS.AXIS2.CENTER,\n        CSS.GAP.HALF,\n        CSS.BORDER.RADIUS.HALF,\n        CSS.BG.SURFACE.DEFAULT,\n        props.disabled ? CSS.CURSOR.NOT_ALLOWED : '',\n        CSS.OVERFLOW.XY.HIDDEN,\n      ]\"\n      @click=\"expandOptions\"\n    >\n      <div :class=\"[CSS.DISPLAY.FLEX, CSS.FLEX.DIRECTION.COLUMN, CSS.WIDTH.FULL]\">\n        <label\n          :class=\"[\n            hasMinilabel ? ['minilabel', CSS.FONT.ROLE.LABEL_3] : CSS.FONT.ROLE.LABEL_1,\n            CSS.POSITION.ABSOLUTE,\n            CSS.POSITIONING.LEFT,\n            CSS.MARGIN.TOP.HALF,\n            CSS.MARGIN.LEFT.ONE,\n            !hasError && CSS.FONT.COLOR.SURFACE.VARIANT,\n            CSS.POINTER_EVENTS.OFF,\n          ]\"\n          :for=\"props.inputId\"\n          v-if=\"label\"\n        >\n          {{ formattedLabel }}\n        </label>\n\n        <select\n          :class=\"[\n            CSS.PADDING.BOTTOM.HALF,\n            CSS.PADDING.X.ONE,\n            CSS.WIDTH.FULL,\n            disabled && CSS.CURSOR.NOT_ALLOWED,\n            CSS.FONT.ROLE.BODY_1,\n          ]\"\n          :disabled=\"disabled\"\n          :name=\"name\"\n          ref=\"input\"\n          :required=\"required\"\n          @focus=\"handleFocus\"\n          @focusout=\"handleFocusOut\"\n          :id=\"props.inputId\"\n          v-model=\"value\"\n        >\n          <template v-for=\"optgroup in props.optgroups\">\n            <optgroup\n              :class=\"[CSS.WIDTH.FULL, CSS.BG.SURFACE.DEFAULT]\"\n              :key=\"(optgroup as SelectOptionGroup).label\"\n              :label=\"(optgroup as SelectOptionGroup).label\"\n              v-if=\"(optgroup as SelectOptionGroup).options\"\n            >\n              <option\n                :class=\"[CSS.WIDTH.FULL, CSS.BG.SURFACE.DEFAULT]\"\n                :key=\"option.value\"\n                :value=\"option.value\"\n                v-for=\"option in (optgroup as SelectOptionGroup).options\"\n              >\n                {{ option.label }}\n              </option>\n            </optgroup>\n\n            <option\n              :class=\"[CSS.WIDTH.FULL, CSS.BG.SURFACE.DEFAULT]\"\n              :key=\"(optgroup as SelectOption).value\"\n              :selected=\"value === (optgroup as SelectOption).value ? true : undefined\"\n              :value=\"(optgroup as SelectOption).value\"\n              v-else\n            >\n              {{ (optgroup as SelectOption).label }}\n            </option>\n          </template>\n\n          <option\n            :class=\"[CSS.WIDTH.FULL, CSS.BG.SURFACE.DEFAULT]\"\n            :key=\"option.value\"\n            :selected=\"value === option.value ? true : undefined\"\n            :value=\"option.value\"\n            v-for=\"option in options\"\n          >\n            {{ option.label }}\n          </option>\n        </select>\n      </div>\n\n      <TideIcon\n        :class=\"[CSS.POSITION.ABSOLUTE, CSS.POSITIONING.RIGHT, CSS.MARGIN.RIGHT.ONE, CSS.POINTER_EVENTS.OFF]\"\n        :icon=\"ICON.EXPAND_MORE\"\n        :size=\"SIZE.SMALL\"\n      />\n    </div>\n\n    <div\n      :class=\"[CSS.DISPLAY.FLEX, CSS.AXIS2.CENTER, CSS.GAP.QUARTER]\"\n      v-if=\"props.supportingText || hasError\"\n    >\n      <TideIcon\n        :class=\"[]\"\n        :icon=\"ICON.ERROR\"\n        :size=\"SIZE.SMALL\"\n        v-if=\"hasError\"\n      />\n\n      <div :class=\"[CSS.FONT.ROLE.LABEL_3]\">\n        {{ hasError ? errorMessage : props.supportingText }}\n      </div>\n    </div>\n  </div>\n</template>\n\n<style scoped>\n  select {\n    appearance: none;\n  }\n\n  label {\n    height: 1.1875rem;\n    transition: font-size var(--tide-animate), transform var(--tide-animate);\n  }\n\n  label:not(.minilabel) {\n    transform: translate(0, calc(9 / 16 * 1rem));\n  }\n\n  .tide-input-select.disabled {\n    opacity: var(--tide-disabled);\n  }\n\n  .tide-input-select.error .tide-input-border {\n    outline-color: var(--tide-error-border);\n    background-color: var(--tide-error-surface);\n  }\n\n  .tide-input-select.error:focus-within .tide-input-border {\n    outline-color: var(--tide-error-border);\n  }\n\n  .tide-input-select:focus-within .tide-input-border {\n    --tide-input-outline-width: var(--tide-border-width-2);\n    outline-color: var(--tide-surface-border-high);\n  }\n\n  .tide-input-border {\n    --tide-input-outline-width: var(--tide-border-width-1);\n    outline: var(--tide-input-outline-width) solid var(--tide-border);\n    outline-offset: calc(var(--tide-input-outline-width) * -1);\n  }\n\n  .tide-input-select.error {\n    color: var(--tide-error-primary);\n  }\n\n  .tide-input-select.error option {\n    color: var(--tide-on-surface);\n  }\n\n  select {\n    padding-top: 27px;\n  }\n</style>\n","export const TEXT_INPUT_TYPE = {\n  DATE: 'date',\n  DATETIME_LOCAL: 'datetime-local',\n  EMAIL: 'email',\n  MONTH: 'month',\n  NUMBER: 'number',\n  PASSWORD: 'password',\n  SEARCH: 'search',\n  TEL: 'tel',\n  TEXT: 'text',\n  TIME: 'time',\n  URL: 'url',\n  WEEK: 'week',\n} as const;\n\nexport type TextInputType = (typeof TEXT_INPUT_TYPE)[keyof typeof TEXT_INPUT_TYPE];\n\nexport const INPUT_MODE = {\n  DECIMAL: 'decimal',\n  EMAIL: 'email',\n  NUMERIC: 'numeric',\n  SEARCH: 'search',\n  TEL: 'tel',\n  TEXT: 'text',\n  URL: 'url',\n} as const;\n\nexport type InputMode = (typeof INPUT_MODE)[keyof typeof INPUT_MODE];\n","import { INPUT_MODE, TEXT_INPUT_TYPE } from '@/types/TextInput';\n\nimport type { InputMode, TextInputType } from '@/types/TextInput';\n\nexport const getTextInputMode = (type: TextInputType, inputmode?: InputMode): InputMode | undefined => {\n  if (inputmode) return inputmode;\n\n  switch (type) {\n    case TEXT_INPUT_TYPE.TEL:\n      return INPUT_MODE.TEL;\n    case TEXT_INPUT_TYPE.SEARCH:\n      return INPUT_MODE.SEARCH;\n    case TEXT_INPUT_TYPE.NUMBER:\n      return INPUT_MODE.NUMERIC;\n    case TEXT_INPUT_TYPE.EMAIL:\n      return INPUT_MODE.EMAIL;\n    case TEXT_INPUT_TYPE.URL:\n      return INPUT_MODE.URL;\n  }\n\n  return undefined;\n};\n","<script setup lang=\"ts\">\n  import { computed, ref, watch, watchEffect } from 'vue';\n\n  import TideIcon from '@/components/TideIcon.vue';\n  import TideInputSupportingText from '@/components/TideInputSupportingText.vue';\n  import { useFormContext } from '@/composables/useTideForm';\n  import { ICON } from '@/types/Icon';\n  import { SIZE } from '@/types/Size';\n  import { CSS } from '@/types/Styles';\n  import { TEXT_INPUT_TYPE } from '@/types/TextInput';\n  import { ERROR_DISPLAY } from '@/types/Validation';\n  import { getTextInputMode } from '@/utilities/forms';\n  import { VALIDATION_RESULT, getFieldValidationResult } from '@/utilities/validation';\n\n  import type { FormValueTransformer } from '@/types/Form';\n  import type { Icon } from '@/types/Icon';\n  import type { InputMode, TextInputType } from '@/types/TextInput';\n  import type { ErrorDisplay, ValidationResult, Validator } from '@/types/Validation';\n\n  type Props = {\n    autocomplete?: boolean;\n    disabled?: boolean;\n    error?: string;\n    errorDisplay?: ErrorDisplay;\n    hasClear?: boolean;\n    iconLeading?: Icon;\n    inputId?: string;\n    inputmode?: InputMode;\n    label?: string;\n    maxlength?: number;\n    minlength?: number;\n    name?: string;\n    prefix?: string;\n    required?: boolean;\n    suffix?: string;\n    supportingText?: string;\n    transformValue?: FormValueTransformer;\n    type?: TextInputType;\n    validators?: Validator[];\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    autocomplete: false,\n    disabled: false,\n    error: '',\n    errorDisplay: ERROR_DISPLAY.LAZY,\n    hasClear: false,\n    iconLeading: undefined,\n    inputId: undefined,\n    inputmode: undefined,\n    label: undefined,\n    maxlength: undefined,\n    minlength: undefined,\n    name: undefined,\n    prefix: undefined,\n    required: false,\n    suffix: undefined,\n    supportingText: undefined,\n    transformValue: undefined,\n    type: TEXT_INPUT_TYPE.TEXT,\n    validators: undefined,\n  });\n\n  type Emits = {\n    (event: 'valid', isValid: boolean): void;\n  };\n  const emit = defineEmits<Emits>();\n\n  const modelValue = defineModel<string>({ required: true });\n\n  const formContext = useFormContext();\n\n  const errorRef = ref<ValidationResult>(VALIDATION_RESULT.NO_ERROR);\n  const hasFocus = ref<boolean>(false);\n  const inputElement = ref<HTMLInputElement | null>(null);\n  const isValidating = ref<boolean>(false);\n  const showPassword = ref<boolean>(false);\n\n  const formattedLabel = computed(() => (props.required && props.label ? `${props.label} *` : props.label));\n  const showError = computed(() => {\n    if (hasErrorFromProp.value) return true;\n    if (!isValidating.value) return false;\n    return !errorRef.value.valid;\n  });\n  const hasErrorFromProp = computed(() => props.error !== '');\n  const hasMinilabel = computed(() => hasFocus.value || !isEmpty.value);\n  const inputModeAttribute = computed<InputMode | undefined>(() => getTextInputMode(props.type, props.inputmode));\n  const inputType = computed(() =>\n    props.type === TEXT_INPUT_TYPE.PASSWORD && showPassword.value === true ? TEXT_INPUT_TYPE.TEXT : props.type\n  );\n  const isEmpty = computed(() => modelValue.value === '');\n  const shouldShowClearButton = computed(\n    () => props.hasClear && modelValue.value && props.type !== TEXT_INPUT_TYPE.PASSWORD\n  );\n  const shouldShowPasswordButton = computed(() => props.type === TEXT_INPUT_TYPE.PASSWORD);\n  const supportingTextMessage = computed(() => (showError.value && errorRef.value.message) || props.supportingText);\n\n  const handleClear = () => {\n    modelValue.value = '';\n    inputElement.value?.focus();\n  };\n\n  const handleFocus = () => {\n    hasFocus.value = true;\n    if (props.errorDisplay === ERROR_DISPLAY.EAGER) isValidating.value = true;\n  };\n\n  const handleFocusOut = () => {\n    hasFocus.value = false;\n    if (props.errorDisplay === ERROR_DISPLAY.LAZY) isValidating.value = true;\n  };\n\n  const handleFieldClick = () => {\n    inputElement.value?.focus();\n  };\n\n  const preventInputFocusLossOnMousedown = (e: MouseEvent) => {\n    if (!hasFocus.value) return;\n    if (e.target !== inputElement.value) e.preventDefault();\n  };\n\n  watchEffect(() => {\n    errorRef.value = getFieldValidationResult({\n      errorFromProps: props.error,\n      maxlength: props.maxlength,\n      minlength: props.minlength,\n      required: props.required,\n      validators: props.validators,\n      value: modelValue,\n    });\n  });\n\n  watch(\n    [modelValue, () => props.transformValue],\n    () => {\n      if (!props.transformValue) return;\n\n      const digits = modelValue.value?.match(/\\d/g)?.join('') || undefined;\n      modelValue.value = digits ? props.transformValue(digits) : '';\n    },\n    { immediate: true }\n  );\n\n  watch(\n    () => formContext?.forceShowErrors.value,\n    (newValue) => {\n      if (newValue) isValidating.value = true;\n    },\n    { immediate: true }\n  );\n\n  watch(\n    errorRef,\n    () => {\n      emit('valid', errorRef.value.valid);\n    },\n    { deep: true, immediate: true }\n  );\n</script>\n\n<template>\n  <div\n    :class=\"[\n      'tide-input-text',\n      CSS.DISPLAY.FLEX,\n      CSS.FLEX.DIRECTION.COLUMN,\n      CSS.GAP.QUARTER,\n      disabled && 'disabled',\n      showError && 'error',\n    ]\"\n  >\n    <label\n      :class=\"[\n        'tide-input-text-field',\n        CSS.DISPLAY.FLEX,\n        CSS.AXIS2.CENTER,\n        CSS.GAP.HALF,\n        CSS.POSITION.RELATIVE,\n        CSS.BORDER.RADIUS.HALF,\n        CSS.BG.SURFACE.DEFAULT,\n        CSS.PADDING.Y.HALF,\n        shouldShowClearButton ? [CSS.PADDING.RIGHT.HALF, CSS.PADDING.LEFT.ONE] : [CSS.PADDING.X.ONE],\n        disabled ? CSS.CURSOR.NOT_ALLOWED : CSS.CURSOR.TEXT,\n      ]\"\n      :for=\"inputId\"\n      @click=\"handleFieldClick\"\n      @mousedown=\"preventInputFocusLossOnMousedown\"\n    >\n      <TideIcon\n        :class=\"[CSS.FONT.COLOR.SURFACE.VARIANT]\"\n        :icon=\"iconLeading\"\n        :size=\"SIZE.SMALL\"\n        v-if=\"iconLeading\"\n      />\n\n      <div :class=\"[CSS.DISPLAY.FLEX, CSS.AXIS2.CENTER, CSS.GAP.QUARTER, CSS.WIDTH.FULL]\">\n        <div\n          :class=\"[\n            'tide-input-text-prefix',\n            CSS.FONT.ROLE.BODY_1,\n            !showError && CSS.FONT.COLOR.SURFACE.VARIANT,\n            hasMinilabel ? '' : 'offset',\n          ]\"\n          v-if=\"prefix\"\n        >\n          {{ prefix }}\n        </div>\n\n        <div :class=\"[CSS.DISPLAY.FLEX, CSS.FLEX.DIRECTION.COLUMN, CSS.WIDTH.FULL]\">\n          <div\n            :class=\"[\n              'tide-input-text-label',\n              hasMinilabel ? ['minilabel', CSS.FONT.ROLE.LABEL_3] : CSS.FONT.ROLE.LABEL_1,\n              !showError && CSS.FONT.COLOR.SURFACE.VARIANT,\n              CSS.CURSOR.TEXT,\n              CSS.POINTER_EVENTS.OFF,\n            ]\"\n            v-if=\"label\"\n          >\n            {{ formattedLabel }}\n          </div>\n\n          <input\n            :autocomplete=\"autocomplete ? 'on' : 'off'\"\n            :class=\"[CSS.WIDTH.FULL, CSS.FONT.ROLE.BODY_1, disabled && CSS.CURSOR.NOT_ALLOWED]\"\n            :disabled=\"disabled\"\n            :inputmode=\"inputModeAttribute\"\n            :maxlength=\"maxlength\"\n            :minlength=\"minlength\"\n            :name=\"name\"\n            ref=\"inputElement\"\n            :required=\"required\"\n            :type=\"inputType\"\n            @focus=\"handleFocus\"\n            @focusout=\"handleFocusOut\"\n            :id=\"inputId\"\n            v-model=\"modelValue\"\n          />\n        </div>\n\n        <div\n          :class=\"[\n            'tide-input-text-suffix',\n            CSS.FONT.ROLE.BODY_1,\n            !showError && CSS.FONT.COLOR.SURFACE.VARIANT,\n            hasMinilabel ? '' : 'offset',\n          ]\"\n          v-if=\"suffix\"\n        >\n          {{ suffix }}\n        </div>\n      </div>\n\n      <button\n        @click=\"handleClear\"\n        v-if=\"shouldShowClearButton\"\n      >\n        <TideIcon\n          :class=\"[CSS.MARGIN.FULL.HALF]\"\n          :icon=\"ICON.CLOSE\"\n          :size=\"SIZE.SMALL\"\n        />\n      </button>\n\n      <button\n        @click=\"showPassword = !showPassword\"\n        v-if=\"shouldShowPasswordButton\"\n      >\n        <TideIcon\n          :class=\"[CSS.MARGIN.FULL.HALF]\"\n          :icon=\"ICON.VISIBILITY\"\n          :size=\"SIZE.SMALL\"\n        />\n      </button>\n    </label>\n\n    <TideInputSupportingText\n      :is-error=\"showError\"\n      :message=\"supportingTextMessage\"\n      v-if=\"supportingTextMessage\"\n    />\n  </div>\n</template>\n\n<style scoped>\n  .tide-input-text-label {\n    height: 1.1875rem;\n    transition: font-size var(--tide-animate), transform var(--tide-animate);\n  }\n\n  .tide-input-text-label:not(.minilabel),\n  .tide-input-text-prefix:not(.offset),\n  .tide-input-text-suffix:not(.offset) {\n    transform: translate(0, calc(9 / 16 * 1rem));\n  }\n\n  .tide-input-text-prefix,\n  .tide-input-text-suffix {\n    transition: transform var(--tide-animate);\n  }\n\n  .tide-input-text.disabled {\n    opacity: var(--tide-disabled);\n  }\n\n  .tide-input-text.error {\n    color: var(--tide-error-primary);\n  }\n\n  .tide-input-text.error .tide-input-text-field {\n    outline-color: var(--tide-error-border);\n    background-color: var(--tide-error-surface);\n  }\n\n  .tide-input-text.error:focus-within .tide-input-text-field {\n    outline-color: var(--tide-error-border);\n  }\n\n  .tide-input-text:focus-within .tide-input-text-field {\n    --tide-input-outline-width: var(--tide-border-width-2);\n    outline-color: var(--tide-surface-border-high);\n  }\n\n  .tide-input-text input {\n    outline: none;\n  }\n\n  .tide-input-text-field {\n    --tide-input-outline-width: var(--tide-border-width-1);\n    outline: var(--tide-input-outline-width) solid var(--tide-border);\n    outline-offset: calc(var(--tide-input-outline-width) * -1);\n    color: var(--tide-surface-foreground);\n  }\n</style>\n","<script lang=\"ts\">\n  /**\n   * @deprecated Use `TideInputText.vue` imported from 'tide-design-system' npm package instead.\n   */\n  export default {};\n</script>\n\n<script lang=\"ts\" setup>\n  import { computed, ref, watch } from 'vue';\n\n  import TideIcon from '@/components/TideIcon.vue';\n  import { ICON } from '@/types/Icon';\n  import { SIZE } from '@/types/Size';\n  import { CSS } from '@/types/Styles';\n  import { TEXT_INPUT_TYPE } from '@/types/TextInput';\n  import { getErrorMessage, getFieldHasError, handleFieldValidation } from '@/utilities/validation-deprecated';\n\n  import type { FormValueTransformer } from '@/types/FormDeprecated';\n  import type { Icon } from '@/types/Icon';\n  import type { TextInputType } from '@/types/TextInput';\n  import type { ValidationError, Validator } from '@/types/ValidationDeprecated';\n\n  type Props = {\n    autocomplete?: boolean;\n    disabled?: boolean;\n    error?: ValidationError;\n    hasClear?: boolean;\n    iconLeading?: Icon;\n    inputId?: string;\n    label?: string;\n    maxlength?: number | undefined;\n    minlength?: number | undefined;\n    name?: string;\n    prefix?: string;\n    required?: boolean;\n    suffix?: string;\n    supportingText?: string;\n    transformValue?: FormValueTransformer;\n    type?: TextInputType;\n    validators?: Validator[];\n    value?: string;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    autocomplete: false,\n    disabled: false,\n    error: false,\n    hasClear: false,\n    iconLeading: undefined,\n    inputId: undefined,\n    label: undefined,\n    maxlength: undefined,\n    minlength: undefined,\n    prefix: undefined,\n    required: false,\n    suffix: undefined,\n    supportingText: undefined,\n    transformValue: undefined,\n    type: TEXT_INPUT_TYPE.TEXT,\n    validators: undefined,\n    value: undefined,\n  });\n\n  const error = ref(props.error);\n  const hasFocus = ref(false);\n  const input = ref<HTMLInputElement | null>(null);\n  const showPassword = ref(false);\n  const value = ref(props.value);\n\n  const errorMessage = computed(() => getErrorMessage(props.error, error.value));\n  const formattedLabel = computed(() => (props.required && props.label ? `${props.label} *` : props.label));\n  const hasClear = computed(() => props.hasClear && value.value);\n  const hasError = computed(\n    () => (props.required && value.value !== undefined && !value.value) || getFieldHasError(error.value, props.error)\n  );\n  const hasMinilabel = computed(() => hasFocus.value || !isEmpty.value);\n  const isEmpty = computed(() => value.value === '' || value.value === undefined);\n  const inputType = computed(() =>\n    props.type === TEXT_INPUT_TYPE.PASSWORD && showPassword.value === true ? TEXT_INPUT_TYPE.TEXT : props.type\n  );\n\n  const handleClear = () => {\n    value.value = '';\n    input.value?.focus();\n  };\n\n  const handleFocus = () => {\n    hasFocus.value = true;\n  };\n\n  const handleFocusOut = () => {\n    hasFocus.value = false;\n\n    if (!value.value) {\n      value.value = '';\n    }\n\n    handleValidation();\n  };\n\n  const handleInput = () => {\n    if (props.transformValue) {\n      const digits = value.value?.match(/\\d/g)?.join('') || undefined;\n\n      value.value = digits ? props.transformValue(digits) : '';\n    }\n  };\n\n  const handleValidation = () => {\n    handleFieldValidation({\n      error,\n      errorFromProps: props.error,\n      maxlength: props.maxlength,\n      minlength: props.minlength,\n      required: props.required,\n      validators: props.validators,\n      value,\n    });\n  };\n\n  const updateValue = (newValue: string) => {\n    value.value = newValue;\n  };\n\n  watch(\n    () => props.value,\n    (newValue, oldValue) => {\n      if (newValue !== oldValue || newValue !== value.value) {\n        value.value = newValue;\n      }\n    }\n  );\n\n  defineExpose({\n    error,\n    required: props.required,\n    updateValue,\n    value,\n  });\n</script>\n\n<template>\n  <div\n    :class=\"[\n      'tide-input-text',\n      CSS.DISPLAY.FLEX,\n      CSS.FLEX.DIRECTION.COLUMN,\n      CSS.GAP.QUARTER,\n      disabled && 'disabled',\n      hasError && 'error',\n    ]\"\n  >\n    <label\n      :class=\"[\n        'tide-input-text-field',\n        CSS.DISPLAY.FLEX,\n        CSS.AXIS2.CENTER,\n        CSS.GAP.HALF,\n        CSS.POSITION.RELATIVE,\n        CSS.BORDER.RADIUS.HALF,\n        CSS.BG.SURFACE.DEFAULT,\n        hasClear ? [CSS.PADDING.RIGHT.HALF, CSS.PADDING.LEFT.ONE] : [CSS.PADDING.X.ONE],\n        CSS.PADDING.Y.HALF,\n        disabled ? CSS.CURSOR.NOT_ALLOWED : CSS.CURSOR.TEXT,\n      ]\"\n      :for=\"inputId\"\n    >\n      <TideIcon\n        :class=\"[CSS.FONT.COLOR.SURFACE.VARIANT]\"\n        :icon=\"iconLeading\"\n        :size=\"SIZE.SMALL\"\n        v-if=\"iconLeading\"\n      />\n\n      <div :class=\"[CSS.DISPLAY.FLEX, CSS.AXIS2.CENTER, CSS.GAP.QUARTER, CSS.WIDTH.FULL]\">\n        <div\n          :class=\"[\n            'tide-input-text-prefix',\n            CSS.FONT.ROLE.BODY_1,\n            !hasError && CSS.FONT.COLOR.SURFACE.VARIANT,\n            hasMinilabel ? '' : 'offset',\n          ]\"\n          v-if=\"prefix\"\n        >\n          {{ prefix }}\n        </div>\n\n        <div :class=\"[CSS.DISPLAY.FLEX, CSS.FLEX.DIRECTION.COLUMN, CSS.WIDTH.FULL]\">\n          <div\n            :class=\"[\n              'tide-input-text-label',\n              hasMinilabel ? ['minilabel', CSS.FONT.ROLE.LABEL_3] : CSS.FONT.ROLE.LABEL_1,\n              !hasError && CSS.FONT.COLOR.SURFACE.VARIANT,\n              CSS.CURSOR.TEXT,\n              CSS.POINTER_EVENTS.OFF,\n            ]\"\n            v-if=\"label\"\n          >\n            {{ formattedLabel }}\n          </div>\n\n          <input\n            :autocomplete=\"autocomplete ? 'on' : 'off'\"\n            :class=\"[CSS.WIDTH.FULL, disabled && CSS.CURSOR.NOT_ALLOWED, CSS.FONT.ROLE.BODY_1]\"\n            :disabled=\"disabled\"\n            :maxlength=\"maxlength\"\n            :minlength=\"minlength\"\n            :name=\"name\"\n            ref=\"input\"\n            :required=\"required\"\n            :type=\"inputType\"\n            @change=\"handleValidation\"\n            @focus=\"handleFocus\"\n            @focusout=\"handleFocusOut\"\n            @input=\"handleInput\"\n            :id=\"inputId\"\n            v-model=\"value\"\n          />\n        </div>\n\n        <div\n          :class=\"[\n            'tide-input-text-suffix',\n            CSS.FONT.ROLE.BODY_1,\n            !hasError && CSS.FONT.COLOR.SURFACE.VARIANT,\n            hasMinilabel ? '' : 'offset',\n          ]\"\n          v-if=\"suffix\"\n        >\n          {{ suffix }}\n        </div>\n      </div>\n\n      <button\n        @click=\"handleClear\"\n        v-if=\"hasClear && type !== TEXT_INPUT_TYPE.PASSWORD\"\n      >\n        <TideIcon\n          :class=\"[CSS.MARGIN.FULL.HALF]\"\n          :icon=\"ICON.CLOSE\"\n          :size=\"SIZE.SMALL\"\n        />\n      </button>\n\n      <button\n        @click=\"showPassword = !showPassword\"\n        v-if=\"type === TEXT_INPUT_TYPE.PASSWORD\"\n      >\n        <TideIcon\n          :class=\"[CSS.MARGIN.FULL.HALF]\"\n          :icon=\"ICON.VISIBILITY\"\n          :size=\"SIZE.SMALL\"\n        />\n      </button>\n    </label>\n\n    <div\n      :class=\"[CSS.DISPLAY.FLEX, CSS.AXIS2.CENTER, CSS.GAP.QUARTER]\"\n      v-if=\"supportingText || hasError\"\n    >\n      <TideIcon\n        :class=\"[]\"\n        :icon=\"ICON.ERROR\"\n        :size=\"SIZE.SMALL\"\n        v-if=\"hasError\"\n      />\n\n      <div :class=\"[CSS.FONT.ROLE.LABEL_3]\">\n        {{ hasError ? errorMessage : supportingText }}\n      </div>\n    </div>\n  </div>\n</template>\n\n<style scoped>\n  .tide-input-text-label {\n    height: 1.1875rem;\n    transition: font-size var(--tide-animate), transform var(--tide-animate);\n  }\n\n  .tide-input-text-label:not(.minilabel),\n  .tide-input-text-prefix:not(.offset),\n  .tide-input-text-suffix:not(.offset) {\n    transform: translate(0, calc(9 / 16 * 1rem));\n  }\n\n  .tide-input-text-prefix,\n  .tide-input-text-suffix {\n    transition: transform var(--tide-animate);\n  }\n\n  .tide-input-text.disabled {\n    opacity: var(--tide-disabled);\n  }\n\n  .tide-input-text.error {\n    color: var(--tide-error-primary);\n  }\n\n  .tide-input-text.error .tide-input-text-field {\n    outline-color: var(--tide-error-border);\n    background-color: var(--tide-error-surface);\n  }\n\n  .tide-input-text.error:focus-within .tide-input-text-field {\n    outline-color: var(--tide-error-border);\n  }\n\n  .tide-input-text:focus-within .tide-input-text-field {\n    --tide-input-outline-width: var(--tide-border-width-2);\n    outline-color: var(--tide-surface-border-high);\n  }\n\n  .tide-input-text input {\n    outline: none;\n  }\n\n  .tide-input-text-field {\n    --tide-input-outline-width: var(--tide-border-width-1);\n    outline: var(--tide-input-outline-width) solid var(--tide-border);\n    outline-offset: calc(var(--tide-input-outline-width) * -1);\n    color: var(--tide-surface-foreground);\n  }\n</style>\n","<script lang=\"ts\" setup>\n  import { computed, ref, watch, watchEffect } from 'vue';\n\n  import TideInputSupportingText from '@/components/TideInputSupportingText.vue';\n  import { useFormContext } from '@/composables/useTideForm';\n  import { CSS } from '@/types/Styles';\n  import { ERROR_DISPLAY } from '@/types/Validation';\n  import { VALIDATION_RESULT, getFieldValidationResult } from '@/utilities/validation';\n\n  import type { ErrorDisplay, ValidationResult, Validator } from '@/types/Validation';\n\n  type Props = {\n    error?: string;\n    errorDisplay?: ErrorDisplay;\n    inputId?: string;\n    label?: string;\n    maxlength?: number | undefined;\n    minlength?: number | undefined;\n    name?: string;\n    required?: boolean;\n    rows?: number;\n    supportingText?: string;\n    validators?: Validator[];\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    error: '',\n    errorDisplay: ERROR_DISPLAY.LAZY,\n    inputId: undefined,\n    label: undefined,\n    maxlength: undefined,\n    minlength: undefined,\n    name: undefined,\n    required: false,\n    rows: 8,\n    supportingText: undefined,\n    validators: undefined,\n  });\n\n  type Emits = {\n    (event: 'valid', isValid: boolean): void;\n  };\n  const emit = defineEmits<Emits>();\n\n  const modelValue = defineModel<string>({ required: true });\n\n  const formContext = useFormContext();\n\n  const errorRef = ref<ValidationResult>(VALIDATION_RESULT.NO_ERROR);\n  const hasFocus = ref<boolean>(false);\n  const isValidating = ref<boolean>(false);\n  const textareaElement = ref<HTMLTextAreaElement | null>(null);\n\n  const formattedLabel = computed(() => (props.required ? `${props.label} *` : props.label));\n  const showError = computed(() => {\n    if (hasErrorFromProp.value) return true;\n    if (!isValidating.value) return false;\n    return !errorRef.value.valid;\n  });\n  const hasErrorFromProp = computed(() => props.error !== '');\n  const hasMinilabel = computed(() => hasFocus.value || !isEmpty.value);\n  const isEmpty = computed(() => modelValue.value === '');\n  const supportingTextMessage = computed(() => (showError.value && errorRef.value.message) || props.supportingText);\n\n  const handleFocus = () => {\n    hasFocus.value = true;\n    if (props.errorDisplay === ERROR_DISPLAY.EAGER) isValidating.value = true;\n  };\n\n  const handleFocusOut = () => {\n    hasFocus.value = false;\n    if (props.errorDisplay === ERROR_DISPLAY.LAZY) isValidating.value = true;\n  };\n\n  const handleFieldClick = () => {\n    textareaElement.value?.focus();\n  };\n\n  const preventTextareaFocusLossOnMousedown = (e: MouseEvent) => {\n    if (!hasFocus.value) return;\n    if (e.target !== textareaElement.value) e.preventDefault();\n  };\n\n  watchEffect(() => {\n    errorRef.value = getFieldValidationResult({\n      errorFromProps: props.error,\n      maxlength: props.maxlength,\n      minlength: props.minlength,\n      required: props.required,\n      validators: props.validators,\n      value: modelValue,\n    });\n  });\n\n  watch(\n    () => formContext?.forceShowErrors.value,\n    (newValue) => {\n      if (newValue) isValidating.value = true;\n    },\n    { immediate: true }\n  );\n\n  watch(\n    errorRef,\n    () => {\n      emit('valid', errorRef.value.valid);\n    },\n    { deep: true, immediate: true }\n  );\n</script>\n\n<template>\n  <div\n    :class=\"['tide-input-textarea', CSS.DISPLAY.FLEX, CSS.FLEX.DIRECTION.COLUMN, CSS.GAP.QUARTER, showError && 'error']\"\n  >\n    <label\n      :class=\"[\n        'tide-input-textarea-field',\n        CSS.GAP.HALF,\n        CSS.POSITION.RELATIVE,\n        CSS.BORDER.RADIUS.HALF,\n        CSS.PADDING.LEFT.ONE,\n        CSS.PADDING.TOP.HALF,\n        CSS.OVERFLOW.XY.HIDDEN,\n        CSS.BG.SURFACE.DEFAULT,\n        CSS.CURSOR.TEXT,\n      ]\"\n      :for=\"inputId\"\n      @click=\"handleFieldClick\"\n      @mousedown=\"preventTextareaFocusLossOnMousedown\"\n    >\n      <div\n        :class=\"[\n          'tide-input-textarea-label',\n          hasMinilabel ? ['minilabel', CSS.FONT.ROLE.LABEL_3] : CSS.FONT.ROLE.LABEL_1,\n          !showError && CSS.FONT.COLOR.SURFACE.VARIANT,\n          CSS.POINTER_EVENTS.OFF,\n        ]\"\n        v-if=\"label\"\n      >\n        {{ formattedLabel }}\n      </div>\n\n      <textarea\n        :class=\"[CSS.DISPLAY.BLOCK, CSS.WIDTH.FULL, CSS.FONT.ROLE.BODY_1]\"\n        :maxlength=\"maxlength\"\n        :minlength=\"minlength\"\n        :name=\"name\"\n        ref=\"textareaElement\"\n        :required=\"required\"\n        :rows=\"rows\"\n        @focus=\"handleFocus\"\n        @focusout=\"handleFocusOut\"\n        :id=\"inputId\"\n        v-model=\"modelValue\"\n      />\n    </label>\n\n    <TideInputSupportingText\n      :is-error=\"showError\"\n      :message=\"supportingTextMessage\"\n      v-if=\"supportingTextMessage\"\n    />\n  </div>\n</template>\n\n<style scoped>\n  textarea {\n    resize: vertical;\n  }\n\n  .tide-input-textarea-label {\n    height: 1.1875rem;\n    transition: font-size var(--tide-animate), transform var(--tide-animate);\n  }\n\n  .tide-input-textarea.error {\n    color: var(--tide-error-primary);\n  }\n\n  .tide-input-textarea.error .tide-input-textarea-field {\n    outline-color: var(--tide-error-border);\n    background-color: var(--tide-error-surface);\n  }\n\n  .tide-input-textarea.error:focus-within .tide-input-textarea-field {\n    outline-color: var(--tide-error-border);\n  }\n\n  .tide-input-textarea:focus-within .tide-input-textarea-field {\n    --tide-input-outline-width: var(--tide-border-width-2);\n    outline-color: var(--tide-surface-border-high);\n  }\n\n  .tide-input-textarea textarea {\n    outline: none;\n  }\n\n  .tide-input-textarea-field {\n    --tide-input-outline-width: var(--tide-border-width-1);\n    outline: var(--tide-input-outline-width) solid var(--tide-border);\n    outline-offset: calc(var(--tide-input-outline-width) * -1);\n    color: var(--tide-surface-foreground);\n  }\n</style>\n","<script lang=\"ts\">\n  /**\n   * @deprecated Use `TideInputTextarea.vue` imported from 'tide-design-system' npm package instead.\n   */\n  export default {};\n</script>\n\n<script lang=\"ts\" setup>\n  import { computed, ref, watch } from 'vue';\n\n  import TideIcon from '@/components/TideIcon.vue';\n  import { ICON } from '@/types/Icon';\n  import { SIZE } from '@/types/Size';\n  import { CSS } from '@/types/Styles';\n  import { getErrorMessage, getFieldHasError, handleFieldValidation } from '@/utilities/validation-deprecated';\n\n  import type { ValidationError } from '@/types/ValidationDeprecated';\n\n  type Props = {\n    error?: ValidationError;\n    inputId?: string;\n    label?: string;\n    maxlength?: number | undefined;\n    minlength?: number | undefined;\n    name?: string;\n    required?: boolean;\n    rows?: number;\n    supportingText?: string;\n    value?: string;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    error: false,\n    inputId: undefined,\n    label: undefined,\n    maxlength: undefined,\n    minlength: undefined,\n    name: undefined,\n    required: false,\n    rows: 8,\n    supportingText: undefined,\n    value: undefined,\n  });\n\n  const error = ref(props.error);\n  const hasFocus = ref(false);\n  const input = ref<HTMLInputElement | null>(null);\n  const value = ref(props.value);\n\n  const errorMessage = computed(() => getErrorMessage(props.error, error.value));\n  const formattedLabel = computed(() => (props.required ? `${props.label} *` : props.label));\n  const hasError = computed(\n    () => (props.required && value.value !== undefined && !value.value) || getFieldHasError(error.value, props.error)\n  );\n  const hasMinilabel = computed(() => hasFocus.value || !isEmpty.value);\n  const isEmpty = computed(() => value.value === '' || value.value === undefined);\n\n  const handleFocus = () => {\n    hasFocus.value = true;\n  };\n\n  const handleFocusOut = () => {\n    hasFocus.value = false;\n\n    if (!value.value) {\n      value.value = '';\n    }\n  };\n\n  const handleValidation = () => {\n    return handleFieldValidation({\n      error,\n      errorFromProps: props.error,\n      maxlength: props.maxlength,\n      minlength: props.minlength,\n      required: props.required,\n      value,\n    });\n  };\n\n  watch(\n    () => props.value,\n    (newValue, oldValue) => {\n      if (newValue !== oldValue || newValue !== value.value) {\n        value.value = newValue;\n      }\n    }\n  );\n\n  defineExpose({\n    error,\n    required: props.required,\n    value,\n  });\n</script>\n\n<template>\n  <div\n    :class=\"['tide-input-textarea', CSS.DISPLAY.FLEX, CSS.FLEX.DIRECTION.COLUMN, CSS.GAP.QUARTER, hasError && 'error']\"\n  >\n    <label\n      :class=\"[\n        'tide-input-textarea-field',\n        CSS.GAP.HALF,\n        CSS.POSITION.RELATIVE,\n        CSS.BORDER.RADIUS.HALF,\n        CSS.PADDING.LEFT.ONE,\n        CSS.PADDING.TOP.HALF,\n        CSS.OVERFLOW.XY.HIDDEN,\n        CSS.BG.SURFACE.DEFAULT,\n        CSS.CURSOR.TEXT,\n      ]\"\n      :for=\"inputId\"\n    >\n      <div\n        :class=\"[\n          'tide-input-textarea-label',\n          hasMinilabel ? ['minilabel', CSS.FONT.ROLE.LABEL_3] : CSS.FONT.ROLE.LABEL_1,\n          !hasError && CSS.FONT.COLOR.SURFACE.VARIANT,\n          CSS.POINTER_EVENTS.OFF,\n        ]\"\n        v-if=\"label\"\n      >\n        {{ formattedLabel }}\n      </div>\n\n      <textarea\n        :class=\"[CSS.DISPLAY.BLOCK, CSS.WIDTH.FULL, CSS.FONT.ROLE.BODY_1]\"\n        :maxlength=\"maxlength\"\n        :minlength=\"minlength\"\n        :name=\"name\"\n        ref=\"input\"\n        :required=\"required\"\n        :rows=\"rows\"\n        @change=\"handleValidation\"\n        @focus=\"handleFocus\"\n        @focusout=\"handleFocusOut\"\n        :id=\"inputId\"\n        v-model=\"value\"\n      />\n    </label>\n\n    <div\n      :class=\"[CSS.DISPLAY.FLEX, CSS.AXIS2.CENTER, CSS.GAP.QUARTER]\"\n      v-if=\"supportingText || hasError\"\n    >\n      <TideIcon\n        :icon=\"ICON.ERROR\"\n        :size=\"SIZE.SMALL\"\n        v-if=\"hasError\"\n      />\n\n      <div :class=\"[CSS.FONT.ROLE.LABEL_3]\">\n        {{ hasError ? errorMessage : supportingText }}\n      </div>\n    </div>\n  </div>\n</template>\n\n<style scoped>\n  textarea {\n    resize: vertical;\n  }\n\n  .tide-input-textarea-label {\n    height: 1.1875rem;\n    transition: font-size var(--tide-animate), transform var(--tide-animate);\n  }\n\n  .tide-input-textarea.error {\n    color: var(--tide-error-primary);\n  }\n\n  .tide-input-textarea.error .tide-input-textarea-field {\n    outline-color: var(--tide-error-border);\n    background-color: var(--tide-error-surface);\n  }\n\n  .tide-input-textarea.error:focus-within .tide-input-textarea-field {\n    outline-color: var(--tide-error-border);\n  }\n\n  .tide-input-textarea:focus-within .tide-input-textarea-field {\n    --tide-input-outline-width: var(--tide-border-width-2);\n    outline-color: var(--tide-surface-border-high);\n  }\n\n  .tide-input-textarea textarea {\n    outline: none;\n  }\n\n  .tide-input-textarea-field {\n    --tide-input-outline-width: var(--tide-border-width-1);\n    outline: var(--tide-input-outline-width) solid var(--tide-border);\n    outline-offset: calc(var(--tide-input-outline-width) * -1);\n    color: var(--tide-surface-foreground);\n  }\n</style>\n","<script lang=\"ts\" setup>\n  import TideIcon from '@/components/TideIcon.vue';\n  import { ELEMENT } from '@/types/Element';\n  import { CSS } from '@/types/Styles';\n  import { TARGET } from '@/types/Target';\n\n  import type { Element } from '@/types/Element';\n  import type { Icon } from '@/types/Icon';\n\n  type Props = {\n    element?: Element;\n    href?: string;\n    iconLeading?: Icon;\n    iconTrailing?: Icon;\n    isNewTab?: boolean;\n    label: string;\n    subtle?: boolean;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    element: ELEMENT.LINK,\n    href: undefined,\n    iconLeading: undefined,\n    iconTrailing: undefined,\n    isNewTab: false,\n    label: undefined,\n    subtle: false,\n  });\n</script>\n\n<template>\n  <component\n    :class=\"[\n      'tide-link',\n      CSS.DISPLAY.INLINE,\n      CSS.ALIGN.X.LEFT,\n      subtle ? [CSS.UNDERLINE.REST.OFF, CSS.UNDERLINE.HOVER.ON] : [CSS.UNDERLINE.REST.ON, CSS.UNDERLINE.HOVER.OFF],\n    ]\"\n    :href=\"props.href\"\n    :target=\"props.isNewTab ? TARGET.BLANK : TARGET.SELF\"\n    :is=\"props.element === ELEMENT.LINK ? ELEMENT.LINK : ELEMENT.BUTTON\"\n  >\n    <TideIcon\n      :class=\"[CSS.DISPLAY.INLINE_BLOCK, CSS.ALIGN.Y.MIDDLE, CSS.MARGIN.RIGHT.QUARTER]\"\n      :icon=\"props.iconLeading\"\n      v-if=\"props.iconLeading\"\n    />\n\n    <span :class=\"[CSS.ALIGN.Y.MIDDLE]\">\n      {{ props.label }}\n    </span>\n\n    <TideIcon\n      :class=\"[CSS.DISPLAY.INLINE_BLOCK, CSS.ALIGN.Y.MIDDLE, CSS.MARGIN.LEFT.QUARTER]\"\n      :icon=\"props.iconTrailing\"\n      v-if=\"props.iconTrailing\"\n    />\n  </component>\n</template>\n","/* eslint-disable vue/sort-keys */\n\nexport const BREAKPOINT = {\n  SM: 'sm',\n  MD: 'md',\n  LG: 'lg',\n  XL: 'xl',\n} as const;\n\nexport const MEDIA = {\n  SM: 768,\n  MD: 992,\n  LG: 1232,\n  XL: 1920,\n};\n\nexport type Breakpoint = (typeof BREAKPOINT)[keyof typeof BREAKPOINT];\nexport type Media = (typeof MEDIA)[keyof typeof MEDIA];\n","import { nextTick } from 'vue';\n\n/**\n * Directly modifies the `<body>` element to apply or remove scroll lock.\n * When `false` is provided, it only unlocks scroll if there are no open\n * HTML dialog elements.\n */\nexport const setScrollLock = async (isLocked: boolean) => {\n  // Cannot be applied to body tag in marketplace repo due to data-css-scope\n  // const BODY_LOCK_CLASS = 'body-scroll-lock';\n\n  const body = document.body;\n\n  if (isLocked) {\n    if (!body.dataset.scrollLockY) {\n      const scrollY = window.scrollY;\n\n      body.dataset.scrollLockY = scrollY.toString();\n      body.style.setProperty('--saved-scroll-y', `${scrollY}px`);\n      body.style.setProperty('inset', '0');\n      body.style.setProperty('margin-top', `calc(0px - var(--saved-scroll-y, 0px))`);\n      body.style.setProperty('overflow-y', 'scroll');\n      body.style.setProperty('position', 'fixed');\n\n      // Cannot be applied to body tag in marketplace repo due to data-css-scope\n      // body.classList.add(BODY_LOCK_CLASS);\n    }\n  } else {\n    await nextTick();\n    if (!document.querySelector('dialog[open]')) {\n      const savedScrollY = parseInt(body.dataset.scrollLockY || '0');\n\n      // Cannot be applied to body tag in marketplace repo due to data-css-scope\n      // body.classList.remove(BODY_LOCK_CLASS);\n\n      body.style.removeProperty('inset');\n      body.style.removeProperty('marginTop');\n      body.style.removeProperty('overflowY');\n      body.style.removeProperty('position');\n      body.style.removeProperty('--saved-scroll-y');\n\n      window.scrollTo({\n        behavior: 'auto',\n        top: savedScrollY,\n      });\n\n      delete body.dataset.scrollLockY;\n    }\n  }\n};\n\nexport const TOP_LAYER_ID = 'tide-top-layer';\n\nexport const initFauxTopLayer = () => {\n  let topLayer = document.getElementById(TOP_LAYER_ID);\n  if (!topLayer) {\n    topLayer = document.createElement('div');\n    topLayer.id = TOP_LAYER_ID;\n    topLayer.setAttribute('data-css-scope', '');\n    document.body.appendChild(topLayer);\n  }\n  topLayer.style.isolation = 'isolate';\n};\n","<script lang=\"ts\" setup>\n  import { nextTick, onMounted, ref, watch } from 'vue';\n\n  import TideButtonIcon from '@/components/TideButtonIcon.vue';\n  import { BREAKPOINT } from '@/types/Breakpoint';\n  import { ICON } from '@/types/Icon';\n  import { PRIORITY } from '@/types/Priority';\n  import { CSS } from '@/types/Styles';\n  import { setScrollLock } from '@/utilities/viewport';\n\n  import type { Ref } from 'vue';\n\n  type Props = {\n    isBackButton?: boolean;\n    isDismissible?: boolean;\n    isOpen: boolean;\n    title?: string;\n    width?: string;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    isBackButton: false,\n    isDismissible: true,\n    title: undefined,\n    width: undefined,\n  });\n\n  type Emits = {\n    (e: 'close'): void;\n    (e: 'back'): void;\n  };\n\n  const emit = defineEmits<Emits>();\n\n  const modalContent: Ref<HTMLDivElement | undefined> = ref();\n  const modalDialog: Ref<HTMLDialogElement | undefined> = ref();\n\n  const triggerNativeDialogOpen = () => {\n    modalDialog.value?.showModal();\n  };\n\n  const triggerNativeDialogClose = () => {\n    modalDialog.value?.close();\n  };\n\n  const scrollContentToTop = () => {\n    nextTick(() => {\n      if (!modalContent.value) return;\n      modalContent.value.scrollTop = 0;\n    });\n  };\n\n  const handleBackdropClick = () => {\n    if (props.isDismissible) emit('close');\n  };\n\n  const handleEscapeKeydown = (e: Event) => {\n    e.preventDefault();\n    if (props.isDismissible) emit('close');\n  };\n\n  watch(\n    () => props.isOpen,\n    (newValue) => {\n      if (!modalDialog.value) return;\n      if (newValue) {\n        triggerNativeDialogOpen();\n        scrollContentToTop();\n      } else {\n        triggerNativeDialogClose();\n      }\n      setScrollLock(newValue);\n    }\n  );\n\n  onMounted(() => {\n    if (props.isOpen) {\n      triggerNativeDialogOpen();\n    }\n  });\n</script>\n\n<template>\n  <dialog\n    :class=\"['tide-modal', CSS.BG.INITIAL, CSS.HEIGHT.FULL, CSS.WIDTH.FULL, CSS.OVERFLOW.XY.HIDDEN]\"\n    ref=\"modalDialog\"\n    :style=\"{ '--modal-width': props.width }\"\n    @click.self=\"handleBackdropClick\"\n    @close.prevent\n    @keydown.escape=\"handleEscapeKeydown\"\n  >\n    <div\n      :class=\"[\n        'tide-modal-body',\n        CSS.BG.SURFACE.DEFAULT,\n        CSS.BORDER.RADIUS.ONE,\n        CSS.DISPLAY.FLEX,\n        CSS.FLEX.DIRECTION.COLUMN,\n        CSS.OVERFLOW.XY.HIDDEN,\n        CSS.POSITION.ABSOLUTE,\n        CSS.POSITIONING.BOTTOM,\n        CSS.SHADOW.TOP,\n        CSS.WIDTH.FULL,\n        CSS.WIDTH.MAX_FULL,\n        CSS.withBreakpoint([CSS.SHADOW.BOTTOM], BREAKPOINT.SM),\n      ]\"\n    >\n      <header\n        :class=\"[\n          'tide-modal-header',\n          CSS.AXIS2.CENTER,\n          CSS.BORDER.BOTTOM.ONE,\n          CSS.BORDER.COLOR.LOW,\n          CSS.DISPLAY.FLEX,\n          CSS.GAP.HALF,\n          CSS.ISOLATION.ISOLATE,\n          CSS.PADDING.Y.ONE,\n          CSS.POSITION.RELATIVE,\n          CSS.Z_INDEX.ONE,\n        ]\"\n      >\n        <TideButtonIcon\n          :icon=\"ICON.CHEVRON_LEFT\"\n          :priority=\"PRIORITY.QUATERNARY\"\n          @click=\"emit('back')\"\n          title=\"Back\"\n          v-if=\"isBackButton\"\n        />\n\n        <div\n          :class=\"[CSS.FONT.ROLE.HEADLINE_2]\"\n          v-text=\"title\"\n        />\n\n        <TideButtonIcon\n          :class=\"[CSS.FLEX.GROW.OFF, CSS.FLEX.SHRINK.OFF, CSS.MARGIN.LEFT.AUTO]\"\n          :icon=\"ICON.CLOSE\"\n          :priority=\"PRIORITY.QUATERNARY\"\n          @click=\"emit('close')\"\n          v-if=\"isDismissible\"\n        />\n      </header>\n\n      <div\n        :class=\"[\n          'tide-modal-content',\n          CSS.DISPLAY.GRID,\n          CSS.ISOLATION.ISOLATE,\n          CSS.OVERFLOW.X.HIDDEN,\n          CSS.OVERFLOW.Y.AUTO,\n          CSS.PADDING.Y.TWO,\n          CSS.WIDTH.FULL,\n        ]\"\n        ref=\"modalContent\"\n      >\n        <slot />\n      </div>\n\n      <footer\n        :class=\"[\n          'tide-modal-footer',\n          CSS.AXIS1.END,\n          CSS.DISPLAY.FLEX,\n          CSS.GAP.TWO,\n          CSS.ISOLATION.ISOLATE,\n          CSS.PADDING.Y.ONE,\n          CSS.SHADOW.TOP,\n        ]\"\n        v-if=\"$slots.footer\"\n      >\n        <slot name=\"footer\" />\n      </footer>\n    </div>\n  </dialog>\n</template>\n\n<style scoped>\n  .tide-modal {\n    --modal-padding-x: 20px;\n    max-width: unset;\n    max-height: unset;\n    place-items: center;\n    display: none;\n    transition: all var(--tide-animate) allow-discrete;\n    transform: translateY(100%);\n  }\n  .tide-modal[open] {\n    display: grid;\n    transform: translateY(0%);\n  }\n  .tide-modal::backdrop {\n    background-color: transparent;\n    transition: all var(--tide-animate) allow-discrete;\n    backdrop-filter: blur(0px);\n  }\n  .tide-modal[open]::backdrop {\n    background-color: var(--tide-transparent-400);\n    backdrop-filter: var(--tide-bg-blur);\n  }\n  @starting-style {\n    .tide-modal[open] {\n      display: grid;\n      transform: translateY(100%);\n    }\n    .tide-modal[open]::backdrop {\n      background-color: transparent;\n      backdrop-filter: var(--tide-bg-blur);\n    }\n  }\n  .tide-modal-body {\n    width: var(--modal-width, 576px);\n    max-height: calc(100% - var(--tide-spacing-2));\n  }\n\n  .tide-modal-header,\n  .tide-modal-footer {\n    padding-inline: var(--modal-padding-x);\n  }\n  .tide-modal-content {\n    grid-template-columns: var(--modal-padding-x) 1fr var(--modal-padding-x);\n  }\n  :where(.tide-modal-content):deep(> :where(*)) {\n    grid-column: 2;\n  }\n\n  @media (max-width: 767px) {\n    .tide-modal-body {\n      border-bottom-left-radius: 0;\n      border-bottom-right-radius: 0;\n    }\n  }\n  @media (min-width: 768px) {\n    .tide-modal {\n      --modal-padding-x: var(--tide-spacing-2);\n    }\n    .tide-modal-body {\n      max-height: 85%;\n      bottom: initial;\n    }\n  }\n</style>\n","<script lang=\"ts\" setup>\n  import { computed, ref } from 'vue';\n\n  import TideButtonIcon from '@/components/TideButtonIcon.vue';\n  import TideButtonPagination from '@/components/TideButtonPagination.vue';\n  import { ICON } from '@/types/Icon';\n  import { PRIORITY } from '@/types/Priority';\n  import { CSS } from '@/types/Styles';\n\n  type Props = {\n    pageCurrent?: number;\n    pageTotal?: number;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    pageCurrent: 1,\n    pageTotal: 1,\n  });\n\n  const emit = defineEmits(['change']);\n\n  const pageCurrent = ref(props.pageCurrent);\n\n  const paginationButtons = computed(() => new Array(props.pageTotal).fill('').map((empty, index) => index + 1));\n\n  const handleClick = (index: number) => {\n    pageCurrent.value = index;\n\n    emit('change', event, index);\n  };\n</script>\n\n<template>\n  <section\n    :class=\"['tide-pagination', CSS.DISPLAY.FLEX, CSS.AXIS1.CENTER, CSS.AXIS2.CENTER, CSS.GAP.QUARTER, CSS.WIDTH.FULL]\"\n  >\n    <TideButtonIcon\n      :disabled=\"pageCurrent === 1\"\n      :icon=\"ICON.CHEVRON_LEFT\"\n      :priority=\"PRIORITY.QUATERNARY\"\n      @click=\"handleClick(pageCurrent - 1)\"\n    />\n\n    <ul :class=\"[CSS.DISPLAY.FLEX, CSS.AXIS2.CENTER, CSS.GAP.QUARTER, CSS.LIST_BULLETS.OFF]\">\n      <li\n        :key=\"paginationButton\"\n        v-for=\"paginationButton in paginationButtons\"\n      >\n        <TideButtonPagination\n          :disabled=\"pageCurrent === paginationButton\"\n          :label=\"paginationButton\"\n          :priority=\"PRIORITY.QUATERNARY\"\n          @click=\"handleClick(paginationButton)\"\n        />\n      </li>\n    </ul>\n\n    <TideButtonIcon\n      :disabled=\"pageCurrent === paginationButtons[paginationButtons.length - 1]\"\n      :icon=\"ICON.CHEVRON_RIGHT\"\n      :priority=\"PRIORITY.QUATERNARY\"\n      @click=\"handleClick(pageCurrent + 1)\"\n    />\n  </section>\n</template>\n\n<style scoped></style>\n","/**\n * Custom positioning reference element.\n * @see https://floating-ui.com/docs/virtual-elements\n */\n\nconst sides = ['top', 'right', 'bottom', 'left'];\nconst alignments = ['start', 'end'];\nconst placements = /*#__PURE__*/sides.reduce((acc, side) => acc.concat(side, side + \"-\" + alignments[0], side + \"-\" + alignments[1]), []);\nconst min = Math.min;\nconst max = Math.max;\nconst round = Math.round;\nconst floor = Math.floor;\nconst createCoords = v => ({\n  x: v,\n  y: v\n});\nconst oppositeSideMap = {\n  left: 'right',\n  right: 'left',\n  bottom: 'top',\n  top: 'bottom'\n};\nconst oppositeAlignmentMap = {\n  start: 'end',\n  end: 'start'\n};\nfunction clamp(start, value, end) {\n  return max(start, min(value, end));\n}\nfunction evaluate(value, param) {\n  return typeof value === 'function' ? value(param) : value;\n}\nfunction getSide(placement) {\n  return placement.split('-')[0];\n}\nfunction getAlignment(placement) {\n  return placement.split('-')[1];\n}\nfunction getOppositeAxis(axis) {\n  return axis === 'x' ? 'y' : 'x';\n}\nfunction getAxisLength(axis) {\n  return axis === 'y' ? 'height' : 'width';\n}\nfunction getSideAxis(placement) {\n  return ['top', 'bottom'].includes(getSide(placement)) ? 'y' : 'x';\n}\nfunction getAlignmentAxis(placement) {\n  return getOppositeAxis(getSideAxis(placement));\n}\nfunction getAlignmentSides(placement, rects, rtl) {\n  if (rtl === void 0) {\n    rtl = false;\n  }\n  const alignment = getAlignment(placement);\n  const alignmentAxis = getAlignmentAxis(placement);\n  const length = getAxisLength(alignmentAxis);\n  let mainAlignmentSide = alignmentAxis === 'x' ? alignment === (rtl ? 'end' : 'start') ? 'right' : 'left' : alignment === 'start' ? 'bottom' : 'top';\n  if (rects.reference[length] > rects.floating[length]) {\n    mainAlignmentSide = getOppositePlacement(mainAlignmentSide);\n  }\n  return [mainAlignmentSide, getOppositePlacement(mainAlignmentSide)];\n}\nfunction getExpandedPlacements(placement) {\n  const oppositePlacement = getOppositePlacement(placement);\n  return [getOppositeAlignmentPlacement(placement), oppositePlacement, getOppositeAlignmentPlacement(oppositePlacement)];\n}\nfunction getOppositeAlignmentPlacement(placement) {\n  return placement.replace(/start|end/g, alignment => oppositeAlignmentMap[alignment]);\n}\nfunction getSideList(side, isStart, rtl) {\n  const lr = ['left', 'right'];\n  const rl = ['right', 'left'];\n  const tb = ['top', 'bottom'];\n  const bt = ['bottom', 'top'];\n  switch (side) {\n    case 'top':\n    case 'bottom':\n      if (rtl) return isStart ? rl : lr;\n      return isStart ? lr : rl;\n    case 'left':\n    case 'right':\n      return isStart ? tb : bt;\n    default:\n      return [];\n  }\n}\nfunction getOppositeAxisPlacements(placement, flipAlignment, direction, rtl) {\n  const alignment = getAlignment(placement);\n  let list = getSideList(getSide(placement), direction === 'start', rtl);\n  if (alignment) {\n    list = list.map(side => side + \"-\" + alignment);\n    if (flipAlignment) {\n      list = list.concat(list.map(getOppositeAlignmentPlacement));\n    }\n  }\n  return list;\n}\nfunction getOppositePlacement(placement) {\n  return placement.replace(/left|right|bottom|top/g, side => oppositeSideMap[side]);\n}\nfunction expandPaddingObject(padding) {\n  return {\n    top: 0,\n    right: 0,\n    bottom: 0,\n    left: 0,\n    ...padding\n  };\n}\nfunction getPaddingObject(padding) {\n  return typeof padding !== 'number' ? expandPaddingObject(padding) : {\n    top: padding,\n    right: padding,\n    bottom: padding,\n    left: padding\n  };\n}\nfunction rectToClientRect(rect) {\n  const {\n    x,\n    y,\n    width,\n    height\n  } = rect;\n  return {\n    width,\n    height,\n    top: y,\n    left: x,\n    right: x + width,\n    bottom: y + height,\n    x,\n    y\n  };\n}\n\nexport { alignments, clamp, createCoords, evaluate, expandPaddingObject, floor, getAlignment, getAlignmentAxis, getAlignmentSides, getAxisLength, getExpandedPlacements, getOppositeAlignmentPlacement, getOppositeAxis, getOppositeAxisPlacements, getOppositePlacement, getPaddingObject, getSide, getSideAxis, max, min, placements, rectToClientRect, round, sides };\n","import { getSideAxis, getAlignmentAxis, getAxisLength, getSide, getAlignment, evaluate, getPaddingObject, rectToClientRect, min, clamp, placements, getAlignmentSides, getOppositeAlignmentPlacement, getOppositePlacement, getExpandedPlacements, getOppositeAxisPlacements, sides, max, getOppositeAxis } from '@floating-ui/utils';\nexport { rectToClientRect } from '@floating-ui/utils';\n\nfunction computeCoordsFromPlacement(_ref, placement, rtl) {\n  let {\n    reference,\n    floating\n  } = _ref;\n  const sideAxis = getSideAxis(placement);\n  const alignmentAxis = getAlignmentAxis(placement);\n  const alignLength = getAxisLength(alignmentAxis);\n  const side = getSide(placement);\n  const isVertical = sideAxis === 'y';\n  const commonX = reference.x + reference.width / 2 - floating.width / 2;\n  const commonY = reference.y + reference.height / 2 - floating.height / 2;\n  const commonAlign = reference[alignLength] / 2 - floating[alignLength] / 2;\n  let coords;\n  switch (side) {\n    case 'top':\n      coords = {\n        x: commonX,\n        y: reference.y - floating.height\n      };\n      break;\n    case 'bottom':\n      coords = {\n        x: commonX,\n        y: reference.y + reference.height\n      };\n      break;\n    case 'right':\n      coords = {\n        x: reference.x + reference.width,\n        y: commonY\n      };\n      break;\n    case 'left':\n      coords = {\n        x: reference.x - floating.width,\n        y: commonY\n      };\n      break;\n    default:\n      coords = {\n        x: reference.x,\n        y: reference.y\n      };\n  }\n  switch (getAlignment(placement)) {\n    case 'start':\n      coords[alignmentAxis] -= commonAlign * (rtl && isVertical ? -1 : 1);\n      break;\n    case 'end':\n      coords[alignmentAxis] += commonAlign * (rtl && isVertical ? -1 : 1);\n      break;\n  }\n  return coords;\n}\n\n/**\n * Computes the `x` and `y` coordinates that will place the floating element\n * next to a given reference element.\n *\n * This export does not have any `platform` interface logic. You will need to\n * write one for the platform you are using Floating UI with.\n */\nconst computePosition = async (reference, floating, config) => {\n  const {\n    placement = 'bottom',\n    strategy = 'absolute',\n    middleware = [],\n    platform\n  } = config;\n  const validMiddleware = middleware.filter(Boolean);\n  const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(floating));\n  let rects = await platform.getElementRects({\n    reference,\n    floating,\n    strategy\n  });\n  let {\n    x,\n    y\n  } = computeCoordsFromPlacement(rects, placement, rtl);\n  let statefulPlacement = placement;\n  let middlewareData = {};\n  let resetCount = 0;\n  for (let i = 0; i < validMiddleware.length; i++) {\n    const {\n      name,\n      fn\n    } = validMiddleware[i];\n    const {\n      x: nextX,\n      y: nextY,\n      data,\n      reset\n    } = await fn({\n      x,\n      y,\n      initialPlacement: placement,\n      placement: statefulPlacement,\n      strategy,\n      middlewareData,\n      rects,\n      platform,\n      elements: {\n        reference,\n        floating\n      }\n    });\n    x = nextX != null ? nextX : x;\n    y = nextY != null ? nextY : y;\n    middlewareData = {\n      ...middlewareData,\n      [name]: {\n        ...middlewareData[name],\n        ...data\n      }\n    };\n    if (reset && resetCount <= 50) {\n      resetCount++;\n      if (typeof reset === 'object') {\n        if (reset.placement) {\n          statefulPlacement = reset.placement;\n        }\n        if (reset.rects) {\n          rects = reset.rects === true ? await platform.getElementRects({\n            reference,\n            floating,\n            strategy\n          }) : reset.rects;\n        }\n        ({\n          x,\n          y\n        } = computeCoordsFromPlacement(rects, statefulPlacement, rtl));\n      }\n      i = -1;\n    }\n  }\n  return {\n    x,\n    y,\n    placement: statefulPlacement,\n    strategy,\n    middlewareData\n  };\n};\n\n/**\n * Resolves with an object of overflow side offsets that determine how much the\n * element is overflowing a given clipping boundary on each side.\n * - positive = overflowing the boundary by that number of pixels\n * - negative = how many pixels left before it will overflow\n * - 0 = lies flush with the boundary\n * @see https://floating-ui.com/docs/detectOverflow\n */\nasync function detectOverflow(state, options) {\n  var _await$platform$isEle;\n  if (options === void 0) {\n    options = {};\n  }\n  const {\n    x,\n    y,\n    platform,\n    rects,\n    elements,\n    strategy\n  } = state;\n  const {\n    boundary = 'clippingAncestors',\n    rootBoundary = 'viewport',\n    elementContext = 'floating',\n    altBoundary = false,\n    padding = 0\n  } = evaluate(options, state);\n  const paddingObject = getPaddingObject(padding);\n  const altContext = elementContext === 'floating' ? 'reference' : 'floating';\n  const element = elements[altBoundary ? altContext : elementContext];\n  const clippingClientRect = rectToClientRect(await platform.getClippingRect({\n    element: ((_await$platform$isEle = await (platform.isElement == null ? void 0 : platform.isElement(element))) != null ? _await$platform$isEle : true) ? element : element.contextElement || (await (platform.getDocumentElement == null ? void 0 : platform.getDocumentElement(elements.floating))),\n    boundary,\n    rootBoundary,\n    strategy\n  }));\n  const rect = elementContext === 'floating' ? {\n    x,\n    y,\n    width: rects.floating.width,\n    height: rects.floating.height\n  } : rects.reference;\n  const offsetParent = await (platform.getOffsetParent == null ? void 0 : platform.getOffsetParent(elements.floating));\n  const offsetScale = (await (platform.isElement == null ? void 0 : platform.isElement(offsetParent))) ? (await (platform.getScale == null ? void 0 : platform.getScale(offsetParent))) || {\n    x: 1,\n    y: 1\n  } : {\n    x: 1,\n    y: 1\n  };\n  const elementClientRect = rectToClientRect(platform.convertOffsetParentRelativeRectToViewportRelativeRect ? await platform.convertOffsetParentRelativeRectToViewportRelativeRect({\n    elements,\n    rect,\n    offsetParent,\n    strategy\n  }) : rect);\n  return {\n    top: (clippingClientRect.top - elementClientRect.top + paddingObject.top) / offsetScale.y,\n    bottom: (elementClientRect.bottom - clippingClientRect.bottom + paddingObject.bottom) / offsetScale.y,\n    left: (clippingClientRect.left - elementClientRect.left + paddingObject.left) / offsetScale.x,\n    right: (elementClientRect.right - clippingClientRect.right + paddingObject.right) / offsetScale.x\n  };\n}\n\n/**\n * Provides data to position an inner element of the floating element so that it\n * appears centered to the reference element.\n * @see https://floating-ui.com/docs/arrow\n */\nconst arrow = options => ({\n  name: 'arrow',\n  options,\n  async fn(state) {\n    const {\n      x,\n      y,\n      placement,\n      rects,\n      platform,\n      elements,\n      middlewareData\n    } = state;\n    // Since `element` is required, we don't Partial<> the type.\n    const {\n      element,\n      padding = 0\n    } = evaluate(options, state) || {};\n    if (element == null) {\n      return {};\n    }\n    const paddingObject = getPaddingObject(padding);\n    const coords = {\n      x,\n      y\n    };\n    const axis = getAlignmentAxis(placement);\n    const length = getAxisLength(axis);\n    const arrowDimensions = await platform.getDimensions(element);\n    const isYAxis = axis === 'y';\n    const minProp = isYAxis ? 'top' : 'left';\n    const maxProp = isYAxis ? 'bottom' : 'right';\n    const clientProp = isYAxis ? 'clientHeight' : 'clientWidth';\n    const endDiff = rects.reference[length] + rects.reference[axis] - coords[axis] - rects.floating[length];\n    const startDiff = coords[axis] - rects.reference[axis];\n    const arrowOffsetParent = await (platform.getOffsetParent == null ? void 0 : platform.getOffsetParent(element));\n    let clientSize = arrowOffsetParent ? arrowOffsetParent[clientProp] : 0;\n\n    // DOM platform can return `window` as the `offsetParent`.\n    if (!clientSize || !(await (platform.isElement == null ? void 0 : platform.isElement(arrowOffsetParent)))) {\n      clientSize = elements.floating[clientProp] || rects.floating[length];\n    }\n    const centerToReference = endDiff / 2 - startDiff / 2;\n\n    // If the padding is large enough that it causes the arrow to no longer be\n    // centered, modify the padding so that it is centered.\n    const largestPossiblePadding = clientSize / 2 - arrowDimensions[length] / 2 - 1;\n    const minPadding = min(paddingObject[minProp], largestPossiblePadding);\n    const maxPadding = min(paddingObject[maxProp], largestPossiblePadding);\n\n    // Make sure the arrow doesn't overflow the floating element if the center\n    // point is outside the floating element's bounds.\n    const min$1 = minPadding;\n    const max = clientSize - arrowDimensions[length] - maxPadding;\n    const center = clientSize / 2 - arrowDimensions[length] / 2 + centerToReference;\n    const offset = clamp(min$1, center, max);\n\n    // If the reference is small enough that the arrow's padding causes it to\n    // to point to nothing for an aligned placement, adjust the offset of the\n    // floating element itself. To ensure `shift()` continues to take action,\n    // a single reset is performed when this is true.\n    const shouldAddOffset = !middlewareData.arrow && getAlignment(placement) != null && center !== offset && rects.reference[length] / 2 - (center < min$1 ? minPadding : maxPadding) - arrowDimensions[length] / 2 < 0;\n    const alignmentOffset = shouldAddOffset ? center < min$1 ? center - min$1 : center - max : 0;\n    return {\n      [axis]: coords[axis] + alignmentOffset,\n      data: {\n        [axis]: offset,\n        centerOffset: center - offset - alignmentOffset,\n        ...(shouldAddOffset && {\n          alignmentOffset\n        })\n      },\n      reset: shouldAddOffset\n    };\n  }\n});\n\nfunction getPlacementList(alignment, autoAlignment, allowedPlacements) {\n  const allowedPlacementsSortedByAlignment = alignment ? [...allowedPlacements.filter(placement => getAlignment(placement) === alignment), ...allowedPlacements.filter(placement => getAlignment(placement) !== alignment)] : allowedPlacements.filter(placement => getSide(placement) === placement);\n  return allowedPlacementsSortedByAlignment.filter(placement => {\n    if (alignment) {\n      return getAlignment(placement) === alignment || (autoAlignment ? getOppositeAlignmentPlacement(placement) !== placement : false);\n    }\n    return true;\n  });\n}\n/**\n * Optimizes the visibility of the floating element by choosing the placement\n * that has the most space available automatically, without needing to specify a\n * preferred placement. Alternative to `flip`.\n * @see https://floating-ui.com/docs/autoPlacement\n */\nconst autoPlacement = function (options) {\n  if (options === void 0) {\n    options = {};\n  }\n  return {\n    name: 'autoPlacement',\n    options,\n    async fn(state) {\n      var _middlewareData$autoP, _middlewareData$autoP2, _placementsThatFitOnE;\n      const {\n        rects,\n        middlewareData,\n        placement,\n        platform,\n        elements\n      } = state;\n      const {\n        crossAxis = false,\n        alignment,\n        allowedPlacements = placements,\n        autoAlignment = true,\n        ...detectOverflowOptions\n      } = evaluate(options, state);\n      const placements$1 = alignment !== undefined || allowedPlacements === placements ? getPlacementList(alignment || null, autoAlignment, allowedPlacements) : allowedPlacements;\n      const overflow = await detectOverflow(state, detectOverflowOptions);\n      const currentIndex = ((_middlewareData$autoP = middlewareData.autoPlacement) == null ? void 0 : _middlewareData$autoP.index) || 0;\n      const currentPlacement = placements$1[currentIndex];\n      if (currentPlacement == null) {\n        return {};\n      }\n      const alignmentSides = getAlignmentSides(currentPlacement, rects, await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating)));\n\n      // Make `computeCoords` start from the right place.\n      if (placement !== currentPlacement) {\n        return {\n          reset: {\n            placement: placements$1[0]\n          }\n        };\n      }\n      const currentOverflows = [overflow[getSide(currentPlacement)], overflow[alignmentSides[0]], overflow[alignmentSides[1]]];\n      const allOverflows = [...(((_middlewareData$autoP2 = middlewareData.autoPlacement) == null ? void 0 : _middlewareData$autoP2.overflows) || []), {\n        placement: currentPlacement,\n        overflows: currentOverflows\n      }];\n      const nextPlacement = placements$1[currentIndex + 1];\n\n      // There are more placements to check.\n      if (nextPlacement) {\n        return {\n          data: {\n            index: currentIndex + 1,\n            overflows: allOverflows\n          },\n          reset: {\n            placement: nextPlacement\n          }\n        };\n      }\n      const placementsSortedByMostSpace = allOverflows.map(d => {\n        const alignment = getAlignment(d.placement);\n        return [d.placement, alignment && crossAxis ?\n        // Check along the mainAxis and main crossAxis side.\n        d.overflows.slice(0, 2).reduce((acc, v) => acc + v, 0) :\n        // Check only the mainAxis.\n        d.overflows[0], d.overflows];\n      }).sort((a, b) => a[1] - b[1]);\n      const placementsThatFitOnEachSide = placementsSortedByMostSpace.filter(d => d[2].slice(0,\n      // Aligned placements should not check their opposite crossAxis\n      // side.\n      getAlignment(d[0]) ? 2 : 3).every(v => v <= 0));\n      const resetPlacement = ((_placementsThatFitOnE = placementsThatFitOnEachSide[0]) == null ? void 0 : _placementsThatFitOnE[0]) || placementsSortedByMostSpace[0][0];\n      if (resetPlacement !== placement) {\n        return {\n          data: {\n            index: currentIndex + 1,\n            overflows: allOverflows\n          },\n          reset: {\n            placement: resetPlacement\n          }\n        };\n      }\n      return {};\n    }\n  };\n};\n\n/**\n * Optimizes the visibility of the floating element by flipping the `placement`\n * in order to keep it in view when the preferred placement(s) will overflow the\n * clipping boundary. Alternative to `autoPlacement`.\n * @see https://floating-ui.com/docs/flip\n */\nconst flip = function (options) {\n  if (options === void 0) {\n    options = {};\n  }\n  return {\n    name: 'flip',\n    options,\n    async fn(state) {\n      var _middlewareData$arrow, _middlewareData$flip;\n      const {\n        placement,\n        middlewareData,\n        rects,\n        initialPlacement,\n        platform,\n        elements\n      } = state;\n      const {\n        mainAxis: checkMainAxis = true,\n        crossAxis: checkCrossAxis = true,\n        fallbackPlacements: specifiedFallbackPlacements,\n        fallbackStrategy = 'bestFit',\n        fallbackAxisSideDirection = 'none',\n        flipAlignment = true,\n        ...detectOverflowOptions\n      } = evaluate(options, state);\n\n      // If a reset by the arrow was caused due to an alignment offset being\n      // added, we should skip any logic now since `flip()` has already done its\n      // work.\n      // https://github.com/floating-ui/floating-ui/issues/2549#issuecomment-1719601643\n      if ((_middlewareData$arrow = middlewareData.arrow) != null && _middlewareData$arrow.alignmentOffset) {\n        return {};\n      }\n      const side = getSide(placement);\n      const initialSideAxis = getSideAxis(initialPlacement);\n      const isBasePlacement = getSide(initialPlacement) === initialPlacement;\n      const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating));\n      const fallbackPlacements = specifiedFallbackPlacements || (isBasePlacement || !flipAlignment ? [getOppositePlacement(initialPlacement)] : getExpandedPlacements(initialPlacement));\n      const hasFallbackAxisSideDirection = fallbackAxisSideDirection !== 'none';\n      if (!specifiedFallbackPlacements && hasFallbackAxisSideDirection) {\n        fallbackPlacements.push(...getOppositeAxisPlacements(initialPlacement, flipAlignment, fallbackAxisSideDirection, rtl));\n      }\n      const placements = [initialPlacement, ...fallbackPlacements];\n      const overflow = await detectOverflow(state, detectOverflowOptions);\n      const overflows = [];\n      let overflowsData = ((_middlewareData$flip = middlewareData.flip) == null ? void 0 : _middlewareData$flip.overflows) || [];\n      if (checkMainAxis) {\n        overflows.push(overflow[side]);\n      }\n      if (checkCrossAxis) {\n        const sides = getAlignmentSides(placement, rects, rtl);\n        overflows.push(overflow[sides[0]], overflow[sides[1]]);\n      }\n      overflowsData = [...overflowsData, {\n        placement,\n        overflows\n      }];\n\n      // One or more sides is overflowing.\n      if (!overflows.every(side => side <= 0)) {\n        var _middlewareData$flip2, _overflowsData$filter;\n        const nextIndex = (((_middlewareData$flip2 = middlewareData.flip) == null ? void 0 : _middlewareData$flip2.index) || 0) + 1;\n        const nextPlacement = placements[nextIndex];\n        if (nextPlacement) {\n          // Try next placement and re-run the lifecycle.\n          return {\n            data: {\n              index: nextIndex,\n              overflows: overflowsData\n            },\n            reset: {\n              placement: nextPlacement\n            }\n          };\n        }\n\n        // First, find the candidates that fit on the mainAxis side of overflow,\n        // then find the placement that fits the best on the main crossAxis side.\n        let resetPlacement = (_overflowsData$filter = overflowsData.filter(d => d.overflows[0] <= 0).sort((a, b) => a.overflows[1] - b.overflows[1])[0]) == null ? void 0 : _overflowsData$filter.placement;\n\n        // Otherwise fallback.\n        if (!resetPlacement) {\n          switch (fallbackStrategy) {\n            case 'bestFit':\n              {\n                var _overflowsData$filter2;\n                const placement = (_overflowsData$filter2 = overflowsData.filter(d => {\n                  if (hasFallbackAxisSideDirection) {\n                    const currentSideAxis = getSideAxis(d.placement);\n                    return currentSideAxis === initialSideAxis ||\n                    // Create a bias to the `y` side axis due to horizontal\n                    // reading directions favoring greater width.\n                    currentSideAxis === 'y';\n                  }\n                  return true;\n                }).map(d => [d.placement, d.overflows.filter(overflow => overflow > 0).reduce((acc, overflow) => acc + overflow, 0)]).sort((a, b) => a[1] - b[1])[0]) == null ? void 0 : _overflowsData$filter2[0];\n                if (placement) {\n                  resetPlacement = placement;\n                }\n                break;\n              }\n            case 'initialPlacement':\n              resetPlacement = initialPlacement;\n              break;\n          }\n        }\n        if (placement !== resetPlacement) {\n          return {\n            reset: {\n              placement: resetPlacement\n            }\n          };\n        }\n      }\n      return {};\n    }\n  };\n};\n\nfunction getSideOffsets(overflow, rect) {\n  return {\n    top: overflow.top - rect.height,\n    right: overflow.right - rect.width,\n    bottom: overflow.bottom - rect.height,\n    left: overflow.left - rect.width\n  };\n}\nfunction isAnySideFullyClipped(overflow) {\n  return sides.some(side => overflow[side] >= 0);\n}\n/**\n * Provides data to hide the floating element in applicable situations, such as\n * when it is not in the same clipping context as the reference element.\n * @see https://floating-ui.com/docs/hide\n */\nconst hide = function (options) {\n  if (options === void 0) {\n    options = {};\n  }\n  return {\n    name: 'hide',\n    options,\n    async fn(state) {\n      const {\n        rects\n      } = state;\n      const {\n        strategy = 'referenceHidden',\n        ...detectOverflowOptions\n      } = evaluate(options, state);\n      switch (strategy) {\n        case 'referenceHidden':\n          {\n            const overflow = await detectOverflow(state, {\n              ...detectOverflowOptions,\n              elementContext: 'reference'\n            });\n            const offsets = getSideOffsets(overflow, rects.reference);\n            return {\n              data: {\n                referenceHiddenOffsets: offsets,\n                referenceHidden: isAnySideFullyClipped(offsets)\n              }\n            };\n          }\n        case 'escaped':\n          {\n            const overflow = await detectOverflow(state, {\n              ...detectOverflowOptions,\n              altBoundary: true\n            });\n            const offsets = getSideOffsets(overflow, rects.floating);\n            return {\n              data: {\n                escapedOffsets: offsets,\n                escaped: isAnySideFullyClipped(offsets)\n              }\n            };\n          }\n        default:\n          {\n            return {};\n          }\n      }\n    }\n  };\n};\n\nfunction getBoundingRect(rects) {\n  const minX = min(...rects.map(rect => rect.left));\n  const minY = min(...rects.map(rect => rect.top));\n  const maxX = max(...rects.map(rect => rect.right));\n  const maxY = max(...rects.map(rect => rect.bottom));\n  return {\n    x: minX,\n    y: minY,\n    width: maxX - minX,\n    height: maxY - minY\n  };\n}\nfunction getRectsByLine(rects) {\n  const sortedRects = rects.slice().sort((a, b) => a.y - b.y);\n  const groups = [];\n  let prevRect = null;\n  for (let i = 0; i < sortedRects.length; i++) {\n    const rect = sortedRects[i];\n    if (!prevRect || rect.y - prevRect.y > prevRect.height / 2) {\n      groups.push([rect]);\n    } else {\n      groups[groups.length - 1].push(rect);\n    }\n    prevRect = rect;\n  }\n  return groups.map(rect => rectToClientRect(getBoundingRect(rect)));\n}\n/**\n * Provides improved positioning for inline reference elements that can span\n * over multiple lines, such as hyperlinks or range selections.\n * @see https://floating-ui.com/docs/inline\n */\nconst inline = function (options) {\n  if (options === void 0) {\n    options = {};\n  }\n  return {\n    name: 'inline',\n    options,\n    async fn(state) {\n      const {\n        placement,\n        elements,\n        rects,\n        platform,\n        strategy\n      } = state;\n      // A MouseEvent's client{X,Y} coords can be up to 2 pixels off a\n      // ClientRect's bounds, despite the event listener being triggered. A\n      // padding of 2 seems to handle this issue.\n      const {\n        padding = 2,\n        x,\n        y\n      } = evaluate(options, state);\n      const nativeClientRects = Array.from((await (platform.getClientRects == null ? void 0 : platform.getClientRects(elements.reference))) || []);\n      const clientRects = getRectsByLine(nativeClientRects);\n      const fallback = rectToClientRect(getBoundingRect(nativeClientRects));\n      const paddingObject = getPaddingObject(padding);\n      function getBoundingClientRect() {\n        // There are two rects and they are disjoined.\n        if (clientRects.length === 2 && clientRects[0].left > clientRects[1].right && x != null && y != null) {\n          // Find the first rect in which the point is fully inside.\n          return clientRects.find(rect => x > rect.left - paddingObject.left && x < rect.right + paddingObject.right && y > rect.top - paddingObject.top && y < rect.bottom + paddingObject.bottom) || fallback;\n        }\n\n        // There are 2 or more connected rects.\n        if (clientRects.length >= 2) {\n          if (getSideAxis(placement) === 'y') {\n            const firstRect = clientRects[0];\n            const lastRect = clientRects[clientRects.length - 1];\n            const isTop = getSide(placement) === 'top';\n            const top = firstRect.top;\n            const bottom = lastRect.bottom;\n            const left = isTop ? firstRect.left : lastRect.left;\n            const right = isTop ? firstRect.right : lastRect.right;\n            const width = right - left;\n            const height = bottom - top;\n            return {\n              top,\n              bottom,\n              left,\n              right,\n              width,\n              height,\n              x: left,\n              y: top\n            };\n          }\n          const isLeftSide = getSide(placement) === 'left';\n          const maxRight = max(...clientRects.map(rect => rect.right));\n          const minLeft = min(...clientRects.map(rect => rect.left));\n          const measureRects = clientRects.filter(rect => isLeftSide ? rect.left === minLeft : rect.right === maxRight);\n          const top = measureRects[0].top;\n          const bottom = measureRects[measureRects.length - 1].bottom;\n          const left = minLeft;\n          const right = maxRight;\n          const width = right - left;\n          const height = bottom - top;\n          return {\n            top,\n            bottom,\n            left,\n            right,\n            width,\n            height,\n            x: left,\n            y: top\n          };\n        }\n        return fallback;\n      }\n      const resetRects = await platform.getElementRects({\n        reference: {\n          getBoundingClientRect\n        },\n        floating: elements.floating,\n        strategy\n      });\n      if (rects.reference.x !== resetRects.reference.x || rects.reference.y !== resetRects.reference.y || rects.reference.width !== resetRects.reference.width || rects.reference.height !== resetRects.reference.height) {\n        return {\n          reset: {\n            rects: resetRects\n          }\n        };\n      }\n      return {};\n    }\n  };\n};\n\n// For type backwards-compatibility, the `OffsetOptions` type was also\n// Derivable.\n\nasync function convertValueToCoords(state, options) {\n  const {\n    placement,\n    platform,\n    elements\n  } = state;\n  const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating));\n  const side = getSide(placement);\n  const alignment = getAlignment(placement);\n  const isVertical = getSideAxis(placement) === 'y';\n  const mainAxisMulti = ['left', 'top'].includes(side) ? -1 : 1;\n  const crossAxisMulti = rtl && isVertical ? -1 : 1;\n  const rawValue = evaluate(options, state);\n\n  // eslint-disable-next-line prefer-const\n  let {\n    mainAxis,\n    crossAxis,\n    alignmentAxis\n  } = typeof rawValue === 'number' ? {\n    mainAxis: rawValue,\n    crossAxis: 0,\n    alignmentAxis: null\n  } : {\n    mainAxis: rawValue.mainAxis || 0,\n    crossAxis: rawValue.crossAxis || 0,\n    alignmentAxis: rawValue.alignmentAxis\n  };\n  if (alignment && typeof alignmentAxis === 'number') {\n    crossAxis = alignment === 'end' ? alignmentAxis * -1 : alignmentAxis;\n  }\n  return isVertical ? {\n    x: crossAxis * crossAxisMulti,\n    y: mainAxis * mainAxisMulti\n  } : {\n    x: mainAxis * mainAxisMulti,\n    y: crossAxis * crossAxisMulti\n  };\n}\n\n/**\n * Modifies the placement by translating the floating element along the\n * specified axes.\n * A number (shorthand for `mainAxis` or distance), or an axes configuration\n * object may be passed.\n * @see https://floating-ui.com/docs/offset\n */\nconst offset = function (options) {\n  if (options === void 0) {\n    options = 0;\n  }\n  return {\n    name: 'offset',\n    options,\n    async fn(state) {\n      var _middlewareData$offse, _middlewareData$arrow;\n      const {\n        x,\n        y,\n        placement,\n        middlewareData\n      } = state;\n      const diffCoords = await convertValueToCoords(state, options);\n\n      // If the placement is the same and the arrow caused an alignment offset\n      // then we don't need to change the positioning coordinates.\n      if (placement === ((_middlewareData$offse = middlewareData.offset) == null ? void 0 : _middlewareData$offse.placement) && (_middlewareData$arrow = middlewareData.arrow) != null && _middlewareData$arrow.alignmentOffset) {\n        return {};\n      }\n      return {\n        x: x + diffCoords.x,\n        y: y + diffCoords.y,\n        data: {\n          ...diffCoords,\n          placement\n        }\n      };\n    }\n  };\n};\n\n/**\n * Optimizes the visibility of the floating element by shifting it in order to\n * keep it in view when it will overflow the clipping boundary.\n * @see https://floating-ui.com/docs/shift\n */\nconst shift = function (options) {\n  if (options === void 0) {\n    options = {};\n  }\n  return {\n    name: 'shift',\n    options,\n    async fn(state) {\n      const {\n        x,\n        y,\n        placement\n      } = state;\n      const {\n        mainAxis: checkMainAxis = true,\n        crossAxis: checkCrossAxis = false,\n        limiter = {\n          fn: _ref => {\n            let {\n              x,\n              y\n            } = _ref;\n            return {\n              x,\n              y\n            };\n          }\n        },\n        ...detectOverflowOptions\n      } = evaluate(options, state);\n      const coords = {\n        x,\n        y\n      };\n      const overflow = await detectOverflow(state, detectOverflowOptions);\n      const crossAxis = getSideAxis(getSide(placement));\n      const mainAxis = getOppositeAxis(crossAxis);\n      let mainAxisCoord = coords[mainAxis];\n      let crossAxisCoord = coords[crossAxis];\n      if (checkMainAxis) {\n        const minSide = mainAxis === 'y' ? 'top' : 'left';\n        const maxSide = mainAxis === 'y' ? 'bottom' : 'right';\n        const min = mainAxisCoord + overflow[minSide];\n        const max = mainAxisCoord - overflow[maxSide];\n        mainAxisCoord = clamp(min, mainAxisCoord, max);\n      }\n      if (checkCrossAxis) {\n        const minSide = crossAxis === 'y' ? 'top' : 'left';\n        const maxSide = crossAxis === 'y' ? 'bottom' : 'right';\n        const min = crossAxisCoord + overflow[minSide];\n        const max = crossAxisCoord - overflow[maxSide];\n        crossAxisCoord = clamp(min, crossAxisCoord, max);\n      }\n      const limitedCoords = limiter.fn({\n        ...state,\n        [mainAxis]: mainAxisCoord,\n        [crossAxis]: crossAxisCoord\n      });\n      return {\n        ...limitedCoords,\n        data: {\n          x: limitedCoords.x - x,\n          y: limitedCoords.y - y,\n          enabled: {\n            [mainAxis]: checkMainAxis,\n            [crossAxis]: checkCrossAxis\n          }\n        }\n      };\n    }\n  };\n};\n/**\n * Built-in `limiter` that will stop `shift()` at a certain point.\n */\nconst limitShift = function (options) {\n  if (options === void 0) {\n    options = {};\n  }\n  return {\n    options,\n    fn(state) {\n      const {\n        x,\n        y,\n        placement,\n        rects,\n        middlewareData\n      } = state;\n      const {\n        offset = 0,\n        mainAxis: checkMainAxis = true,\n        crossAxis: checkCrossAxis = true\n      } = evaluate(options, state);\n      const coords = {\n        x,\n        y\n      };\n      const crossAxis = getSideAxis(placement);\n      const mainAxis = getOppositeAxis(crossAxis);\n      let mainAxisCoord = coords[mainAxis];\n      let crossAxisCoord = coords[crossAxis];\n      const rawOffset = evaluate(offset, state);\n      const computedOffset = typeof rawOffset === 'number' ? {\n        mainAxis: rawOffset,\n        crossAxis: 0\n      } : {\n        mainAxis: 0,\n        crossAxis: 0,\n        ...rawOffset\n      };\n      if (checkMainAxis) {\n        const len = mainAxis === 'y' ? 'height' : 'width';\n        const limitMin = rects.reference[mainAxis] - rects.floating[len] + computedOffset.mainAxis;\n        const limitMax = rects.reference[mainAxis] + rects.reference[len] - computedOffset.mainAxis;\n        if (mainAxisCoord < limitMin) {\n          mainAxisCoord = limitMin;\n        } else if (mainAxisCoord > limitMax) {\n          mainAxisCoord = limitMax;\n        }\n      }\n      if (checkCrossAxis) {\n        var _middlewareData$offse, _middlewareData$offse2;\n        const len = mainAxis === 'y' ? 'width' : 'height';\n        const isOriginSide = ['top', 'left'].includes(getSide(placement));\n        const limitMin = rects.reference[crossAxis] - rects.floating[len] + (isOriginSide ? ((_middlewareData$offse = middlewareData.offset) == null ? void 0 : _middlewareData$offse[crossAxis]) || 0 : 0) + (isOriginSide ? 0 : computedOffset.crossAxis);\n        const limitMax = rects.reference[crossAxis] + rects.reference[len] + (isOriginSide ? 0 : ((_middlewareData$offse2 = middlewareData.offset) == null ? void 0 : _middlewareData$offse2[crossAxis]) || 0) - (isOriginSide ? computedOffset.crossAxis : 0);\n        if (crossAxisCoord < limitMin) {\n          crossAxisCoord = limitMin;\n        } else if (crossAxisCoord > limitMax) {\n          crossAxisCoord = limitMax;\n        }\n      }\n      return {\n        [mainAxis]: mainAxisCoord,\n        [crossAxis]: crossAxisCoord\n      };\n    }\n  };\n};\n\n/**\n * Provides data that allows you to change the size of the floating element —\n * for instance, prevent it from overflowing the clipping boundary or match the\n * width of the reference element.\n * @see https://floating-ui.com/docs/size\n */\nconst size = function (options) {\n  if (options === void 0) {\n    options = {};\n  }\n  return {\n    name: 'size',\n    options,\n    async fn(state) {\n      var _state$middlewareData, _state$middlewareData2;\n      const {\n        placement,\n        rects,\n        platform,\n        elements\n      } = state;\n      const {\n        apply = () => {},\n        ...detectOverflowOptions\n      } = evaluate(options, state);\n      const overflow = await detectOverflow(state, detectOverflowOptions);\n      const side = getSide(placement);\n      const alignment = getAlignment(placement);\n      const isYAxis = getSideAxis(placement) === 'y';\n      const {\n        width,\n        height\n      } = rects.floating;\n      let heightSide;\n      let widthSide;\n      if (side === 'top' || side === 'bottom') {\n        heightSide = side;\n        widthSide = alignment === ((await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating))) ? 'start' : 'end') ? 'left' : 'right';\n      } else {\n        widthSide = side;\n        heightSide = alignment === 'end' ? 'top' : 'bottom';\n      }\n      const maximumClippingHeight = height - overflow.top - overflow.bottom;\n      const maximumClippingWidth = width - overflow.left - overflow.right;\n      const overflowAvailableHeight = min(height - overflow[heightSide], maximumClippingHeight);\n      const overflowAvailableWidth = min(width - overflow[widthSide], maximumClippingWidth);\n      const noShift = !state.middlewareData.shift;\n      let availableHeight = overflowAvailableHeight;\n      let availableWidth = overflowAvailableWidth;\n      if ((_state$middlewareData = state.middlewareData.shift) != null && _state$middlewareData.enabled.x) {\n        availableWidth = maximumClippingWidth;\n      }\n      if ((_state$middlewareData2 = state.middlewareData.shift) != null && _state$middlewareData2.enabled.y) {\n        availableHeight = maximumClippingHeight;\n      }\n      if (noShift && !alignment) {\n        const xMin = max(overflow.left, 0);\n        const xMax = max(overflow.right, 0);\n        const yMin = max(overflow.top, 0);\n        const yMax = max(overflow.bottom, 0);\n        if (isYAxis) {\n          availableWidth = width - 2 * (xMin !== 0 || xMax !== 0 ? xMin + xMax : max(overflow.left, overflow.right));\n        } else {\n          availableHeight = height - 2 * (yMin !== 0 || yMax !== 0 ? yMin + yMax : max(overflow.top, overflow.bottom));\n        }\n      }\n      await apply({\n        ...state,\n        availableWidth,\n        availableHeight\n      });\n      const nextDimensions = await platform.getDimensions(elements.floating);\n      if (width !== nextDimensions.width || height !== nextDimensions.height) {\n        return {\n          reset: {\n            rects: true\n          }\n        };\n      }\n      return {};\n    }\n  };\n};\n\nexport { arrow, autoPlacement, computePosition, detectOverflow, flip, hide, inline, limitShift, offset, shift, size };\n","function hasWindow() {\n  return typeof window !== 'undefined';\n}\nfunction getNodeName(node) {\n  if (isNode(node)) {\n    return (node.nodeName || '').toLowerCase();\n  }\n  // Mocked nodes in testing environments may not be instances of Node. By\n  // returning `#document` an infinite loop won't occur.\n  // https://github.com/floating-ui/floating-ui/issues/2317\n  return '#document';\n}\nfunction getWindow(node) {\n  var _node$ownerDocument;\n  return (node == null || (_node$ownerDocument = node.ownerDocument) == null ? void 0 : _node$ownerDocument.defaultView) || window;\n}\nfunction getDocumentElement(node) {\n  var _ref;\n  return (_ref = (isNode(node) ? node.ownerDocument : node.document) || window.document) == null ? void 0 : _ref.documentElement;\n}\nfunction isNode(value) {\n  if (!hasWindow()) {\n    return false;\n  }\n  return value instanceof Node || value instanceof getWindow(value).Node;\n}\nfunction isElement(value) {\n  if (!hasWindow()) {\n    return false;\n  }\n  return value instanceof Element || value instanceof getWindow(value).Element;\n}\nfunction isHTMLElement(value) {\n  if (!hasWindow()) {\n    return false;\n  }\n  return value instanceof HTMLElement || value instanceof getWindow(value).HTMLElement;\n}\nfunction isShadowRoot(value) {\n  if (!hasWindow() || typeof ShadowRoot === 'undefined') {\n    return false;\n  }\n  return value instanceof ShadowRoot || value instanceof getWindow(value).ShadowRoot;\n}\nfunction isOverflowElement(element) {\n  const {\n    overflow,\n    overflowX,\n    overflowY,\n    display\n  } = getComputedStyle(element);\n  return /auto|scroll|overlay|hidden|clip/.test(overflow + overflowY + overflowX) && !['inline', 'contents'].includes(display);\n}\nfunction isTableElement(element) {\n  return ['table', 'td', 'th'].includes(getNodeName(element));\n}\nfunction isTopLayer(element) {\n  return [':popover-open', ':modal'].some(selector => {\n    try {\n      return element.matches(selector);\n    } catch (e) {\n      return false;\n    }\n  });\n}\nfunction isContainingBlock(elementOrCss) {\n  const webkit = isWebKit();\n  const css = isElement(elementOrCss) ? getComputedStyle(elementOrCss) : elementOrCss;\n\n  // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block\n  // https://drafts.csswg.org/css-transforms-2/#individual-transforms\n  return ['transform', 'translate', 'scale', 'rotate', 'perspective'].some(value => css[value] ? css[value] !== 'none' : false) || (css.containerType ? css.containerType !== 'normal' : false) || !webkit && (css.backdropFilter ? css.backdropFilter !== 'none' : false) || !webkit && (css.filter ? css.filter !== 'none' : false) || ['transform', 'translate', 'scale', 'rotate', 'perspective', 'filter'].some(value => (css.willChange || '').includes(value)) || ['paint', 'layout', 'strict', 'content'].some(value => (css.contain || '').includes(value));\n}\nfunction getContainingBlock(element) {\n  let currentNode = getParentNode(element);\n  while (isHTMLElement(currentNode) && !isLastTraversableNode(currentNode)) {\n    if (isContainingBlock(currentNode)) {\n      return currentNode;\n    } else if (isTopLayer(currentNode)) {\n      return null;\n    }\n    currentNode = getParentNode(currentNode);\n  }\n  return null;\n}\nfunction isWebKit() {\n  if (typeof CSS === 'undefined' || !CSS.supports) return false;\n  return CSS.supports('-webkit-backdrop-filter', 'none');\n}\nfunction isLastTraversableNode(node) {\n  return ['html', 'body', '#document'].includes(getNodeName(node));\n}\nfunction getComputedStyle(element) {\n  return getWindow(element).getComputedStyle(element);\n}\nfunction getNodeScroll(element) {\n  if (isElement(element)) {\n    return {\n      scrollLeft: element.scrollLeft,\n      scrollTop: element.scrollTop\n    };\n  }\n  return {\n    scrollLeft: element.scrollX,\n    scrollTop: element.scrollY\n  };\n}\nfunction getParentNode(node) {\n  if (getNodeName(node) === 'html') {\n    return node;\n  }\n  const result =\n  // Step into the shadow DOM of the parent of a slotted node.\n  node.assignedSlot ||\n  // DOM Element detected.\n  node.parentNode ||\n  // ShadowRoot detected.\n  isShadowRoot(node) && node.host ||\n  // Fallback.\n  getDocumentElement(node);\n  return isShadowRoot(result) ? result.host : result;\n}\nfunction getNearestOverflowAncestor(node) {\n  const parentNode = getParentNode(node);\n  if (isLastTraversableNode(parentNode)) {\n    return node.ownerDocument ? node.ownerDocument.body : node.body;\n  }\n  if (isHTMLElement(parentNode) && isOverflowElement(parentNode)) {\n    return parentNode;\n  }\n  return getNearestOverflowAncestor(parentNode);\n}\nfunction getOverflowAncestors(node, list, traverseIframes) {\n  var _node$ownerDocument2;\n  if (list === void 0) {\n    list = [];\n  }\n  if (traverseIframes === void 0) {\n    traverseIframes = true;\n  }\n  const scrollableAncestor = getNearestOverflowAncestor(node);\n  const isBody = scrollableAncestor === ((_node$ownerDocument2 = node.ownerDocument) == null ? void 0 : _node$ownerDocument2.body);\n  const win = getWindow(scrollableAncestor);\n  if (isBody) {\n    const frameElement = getFrameElement(win);\n    return list.concat(win, win.visualViewport || [], isOverflowElement(scrollableAncestor) ? scrollableAncestor : [], frameElement && traverseIframes ? getOverflowAncestors(frameElement) : []);\n  }\n  return list.concat(scrollableAncestor, getOverflowAncestors(scrollableAncestor, [], traverseIframes));\n}\nfunction getFrameElement(win) {\n  return win.parent && Object.getPrototypeOf(win.parent) ? win.frameElement : null;\n}\n\nexport { getComputedStyle, getContainingBlock, getDocumentElement, getFrameElement, getNearestOverflowAncestor, getNodeName, getNodeScroll, getOverflowAncestors, getParentNode, getWindow, isContainingBlock, isElement, isHTMLElement, isLastTraversableNode, isNode, isOverflowElement, isShadowRoot, isTableElement, isTopLayer, isWebKit };\n","import { rectToClientRect, detectOverflow as detectOverflow$1, offset as offset$1, autoPlacement as autoPlacement$1, shift as shift$1, flip as flip$1, size as size$1, hide as hide$1, arrow as arrow$1, inline as inline$1, limitShift as limitShift$1, computePosition as computePosition$1 } from '@floating-ui/core';\nimport { round, createCoords, max, min, floor } from '@floating-ui/utils';\nimport { getComputedStyle, isHTMLElement, isElement, getWindow, isWebKit, getFrameElement, getNodeScroll, getDocumentElement, isTopLayer, getNodeName, isOverflowElement, getOverflowAncestors, getParentNode, isLastTraversableNode, isContainingBlock, isTableElement, getContainingBlock } from '@floating-ui/utils/dom';\nexport { getOverflowAncestors } from '@floating-ui/utils/dom';\n\nfunction getCssDimensions(element) {\n  const css = getComputedStyle(element);\n  // In testing environments, the `width` and `height` properties are empty\n  // strings for SVG elements, returning NaN. Fallback to `0` in this case.\n  let width = parseFloat(css.width) || 0;\n  let height = parseFloat(css.height) || 0;\n  const hasOffset = isHTMLElement(element);\n  const offsetWidth = hasOffset ? element.offsetWidth : width;\n  const offsetHeight = hasOffset ? element.offsetHeight : height;\n  const shouldFallback = round(width) !== offsetWidth || round(height) !== offsetHeight;\n  if (shouldFallback) {\n    width = offsetWidth;\n    height = offsetHeight;\n  }\n  return {\n    width,\n    height,\n    $: shouldFallback\n  };\n}\n\nfunction unwrapElement(element) {\n  return !isElement(element) ? element.contextElement : element;\n}\n\nfunction getScale(element) {\n  const domElement = unwrapElement(element);\n  if (!isHTMLElement(domElement)) {\n    return createCoords(1);\n  }\n  const rect = domElement.getBoundingClientRect();\n  const {\n    width,\n    height,\n    $\n  } = getCssDimensions(domElement);\n  let x = ($ ? round(rect.width) : rect.width) / width;\n  let y = ($ ? round(rect.height) : rect.height) / height;\n\n  // 0, NaN, or Infinity should always fallback to 1.\n\n  if (!x || !Number.isFinite(x)) {\n    x = 1;\n  }\n  if (!y || !Number.isFinite(y)) {\n    y = 1;\n  }\n  return {\n    x,\n    y\n  };\n}\n\nconst noOffsets = /*#__PURE__*/createCoords(0);\nfunction getVisualOffsets(element) {\n  const win = getWindow(element);\n  if (!isWebKit() || !win.visualViewport) {\n    return noOffsets;\n  }\n  return {\n    x: win.visualViewport.offsetLeft,\n    y: win.visualViewport.offsetTop\n  };\n}\nfunction shouldAddVisualOffsets(element, isFixed, floatingOffsetParent) {\n  if (isFixed === void 0) {\n    isFixed = false;\n  }\n  if (!floatingOffsetParent || isFixed && floatingOffsetParent !== getWindow(element)) {\n    return false;\n  }\n  return isFixed;\n}\n\nfunction getBoundingClientRect(element, includeScale, isFixedStrategy, offsetParent) {\n  if (includeScale === void 0) {\n    includeScale = false;\n  }\n  if (isFixedStrategy === void 0) {\n    isFixedStrategy = false;\n  }\n  const clientRect = element.getBoundingClientRect();\n  const domElement = unwrapElement(element);\n  let scale = createCoords(1);\n  if (includeScale) {\n    if (offsetParent) {\n      if (isElement(offsetParent)) {\n        scale = getScale(offsetParent);\n      }\n    } else {\n      scale = getScale(element);\n    }\n  }\n  const visualOffsets = shouldAddVisualOffsets(domElement, isFixedStrategy, offsetParent) ? getVisualOffsets(domElement) : createCoords(0);\n  let x = (clientRect.left + visualOffsets.x) / scale.x;\n  let y = (clientRect.top + visualOffsets.y) / scale.y;\n  let width = clientRect.width / scale.x;\n  let height = clientRect.height / scale.y;\n  if (domElement) {\n    const win = getWindow(domElement);\n    const offsetWin = offsetParent && isElement(offsetParent) ? getWindow(offsetParent) : offsetParent;\n    let currentWin = win;\n    let currentIFrame = getFrameElement(currentWin);\n    while (currentIFrame && offsetParent && offsetWin !== currentWin) {\n      const iframeScale = getScale(currentIFrame);\n      const iframeRect = currentIFrame.getBoundingClientRect();\n      const css = getComputedStyle(currentIFrame);\n      const left = iframeRect.left + (currentIFrame.clientLeft + parseFloat(css.paddingLeft)) * iframeScale.x;\n      const top = iframeRect.top + (currentIFrame.clientTop + parseFloat(css.paddingTop)) * iframeScale.y;\n      x *= iframeScale.x;\n      y *= iframeScale.y;\n      width *= iframeScale.x;\n      height *= iframeScale.y;\n      x += left;\n      y += top;\n      currentWin = getWindow(currentIFrame);\n      currentIFrame = getFrameElement(currentWin);\n    }\n  }\n  return rectToClientRect({\n    width,\n    height,\n    x,\n    y\n  });\n}\n\n// If <html> has a CSS width greater than the viewport, then this will be\n// incorrect for RTL.\nfunction getWindowScrollBarX(element, rect) {\n  const leftScroll = getNodeScroll(element).scrollLeft;\n  if (!rect) {\n    return getBoundingClientRect(getDocumentElement(element)).left + leftScroll;\n  }\n  return rect.left + leftScroll;\n}\n\nfunction getHTMLOffset(documentElement, scroll, ignoreScrollbarX) {\n  if (ignoreScrollbarX === void 0) {\n    ignoreScrollbarX = false;\n  }\n  const htmlRect = documentElement.getBoundingClientRect();\n  const x = htmlRect.left + scroll.scrollLeft - (ignoreScrollbarX ? 0 :\n  // RTL <body> scrollbar.\n  getWindowScrollBarX(documentElement, htmlRect));\n  const y = htmlRect.top + scroll.scrollTop;\n  return {\n    x,\n    y\n  };\n}\n\nfunction convertOffsetParentRelativeRectToViewportRelativeRect(_ref) {\n  let {\n    elements,\n    rect,\n    offsetParent,\n    strategy\n  } = _ref;\n  const isFixed = strategy === 'fixed';\n  const documentElement = getDocumentElement(offsetParent);\n  const topLayer = elements ? isTopLayer(elements.floating) : false;\n  if (offsetParent === documentElement || topLayer && isFixed) {\n    return rect;\n  }\n  let scroll = {\n    scrollLeft: 0,\n    scrollTop: 0\n  };\n  let scale = createCoords(1);\n  const offsets = createCoords(0);\n  const isOffsetParentAnElement = isHTMLElement(offsetParent);\n  if (isOffsetParentAnElement || !isOffsetParentAnElement && !isFixed) {\n    if (getNodeName(offsetParent) !== 'body' || isOverflowElement(documentElement)) {\n      scroll = getNodeScroll(offsetParent);\n    }\n    if (isHTMLElement(offsetParent)) {\n      const offsetRect = getBoundingClientRect(offsetParent);\n      scale = getScale(offsetParent);\n      offsets.x = offsetRect.x + offsetParent.clientLeft;\n      offsets.y = offsetRect.y + offsetParent.clientTop;\n    }\n  }\n  const htmlOffset = documentElement && !isOffsetParentAnElement && !isFixed ? getHTMLOffset(documentElement, scroll, true) : createCoords(0);\n  return {\n    width: rect.width * scale.x,\n    height: rect.height * scale.y,\n    x: rect.x * scale.x - scroll.scrollLeft * scale.x + offsets.x + htmlOffset.x,\n    y: rect.y * scale.y - scroll.scrollTop * scale.y + offsets.y + htmlOffset.y\n  };\n}\n\nfunction getClientRects(element) {\n  return Array.from(element.getClientRects());\n}\n\n// Gets the entire size of the scrollable document area, even extending outside\n// of the `<html>` and `<body>` rect bounds if horizontally scrollable.\nfunction getDocumentRect(element) {\n  const html = getDocumentElement(element);\n  const scroll = getNodeScroll(element);\n  const body = element.ownerDocument.body;\n  const width = max(html.scrollWidth, html.clientWidth, body.scrollWidth, body.clientWidth);\n  const height = max(html.scrollHeight, html.clientHeight, body.scrollHeight, body.clientHeight);\n  let x = -scroll.scrollLeft + getWindowScrollBarX(element);\n  const y = -scroll.scrollTop;\n  if (getComputedStyle(body).direction === 'rtl') {\n    x += max(html.clientWidth, body.clientWidth) - width;\n  }\n  return {\n    width,\n    height,\n    x,\n    y\n  };\n}\n\nfunction getViewportRect(element, strategy) {\n  const win = getWindow(element);\n  const html = getDocumentElement(element);\n  const visualViewport = win.visualViewport;\n  let width = html.clientWidth;\n  let height = html.clientHeight;\n  let x = 0;\n  let y = 0;\n  if (visualViewport) {\n    width = visualViewport.width;\n    height = visualViewport.height;\n    const visualViewportBased = isWebKit();\n    if (!visualViewportBased || visualViewportBased && strategy === 'fixed') {\n      x = visualViewport.offsetLeft;\n      y = visualViewport.offsetTop;\n    }\n  }\n  return {\n    width,\n    height,\n    x,\n    y\n  };\n}\n\n// Returns the inner client rect, subtracting scrollbars if present.\nfunction getInnerBoundingClientRect(element, strategy) {\n  const clientRect = getBoundingClientRect(element, true, strategy === 'fixed');\n  const top = clientRect.top + element.clientTop;\n  const left = clientRect.left + element.clientLeft;\n  const scale = isHTMLElement(element) ? getScale(element) : createCoords(1);\n  const width = element.clientWidth * scale.x;\n  const height = element.clientHeight * scale.y;\n  const x = left * scale.x;\n  const y = top * scale.y;\n  return {\n    width,\n    height,\n    x,\n    y\n  };\n}\nfunction getClientRectFromClippingAncestor(element, clippingAncestor, strategy) {\n  let rect;\n  if (clippingAncestor === 'viewport') {\n    rect = getViewportRect(element, strategy);\n  } else if (clippingAncestor === 'document') {\n    rect = getDocumentRect(getDocumentElement(element));\n  } else if (isElement(clippingAncestor)) {\n    rect = getInnerBoundingClientRect(clippingAncestor, strategy);\n  } else {\n    const visualOffsets = getVisualOffsets(element);\n    rect = {\n      x: clippingAncestor.x - visualOffsets.x,\n      y: clippingAncestor.y - visualOffsets.y,\n      width: clippingAncestor.width,\n      height: clippingAncestor.height\n    };\n  }\n  return rectToClientRect(rect);\n}\nfunction hasFixedPositionAncestor(element, stopNode) {\n  const parentNode = getParentNode(element);\n  if (parentNode === stopNode || !isElement(parentNode) || isLastTraversableNode(parentNode)) {\n    return false;\n  }\n  return getComputedStyle(parentNode).position === 'fixed' || hasFixedPositionAncestor(parentNode, stopNode);\n}\n\n// A \"clipping ancestor\" is an `overflow` element with the characteristic of\n// clipping (or hiding) child elements. This returns all clipping ancestors\n// of the given element up the tree.\nfunction getClippingElementAncestors(element, cache) {\n  const cachedResult = cache.get(element);\n  if (cachedResult) {\n    return cachedResult;\n  }\n  let result = getOverflowAncestors(element, [], false).filter(el => isElement(el) && getNodeName(el) !== 'body');\n  let currentContainingBlockComputedStyle = null;\n  const elementIsFixed = getComputedStyle(element).position === 'fixed';\n  let currentNode = elementIsFixed ? getParentNode(element) : element;\n\n  // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block\n  while (isElement(currentNode) && !isLastTraversableNode(currentNode)) {\n    const computedStyle = getComputedStyle(currentNode);\n    const currentNodeIsContaining = isContainingBlock(currentNode);\n    if (!currentNodeIsContaining && computedStyle.position === 'fixed') {\n      currentContainingBlockComputedStyle = null;\n    }\n    const shouldDropCurrentNode = elementIsFixed ? !currentNodeIsContaining && !currentContainingBlockComputedStyle : !currentNodeIsContaining && computedStyle.position === 'static' && !!currentContainingBlockComputedStyle && ['absolute', 'fixed'].includes(currentContainingBlockComputedStyle.position) || isOverflowElement(currentNode) && !currentNodeIsContaining && hasFixedPositionAncestor(element, currentNode);\n    if (shouldDropCurrentNode) {\n      // Drop non-containing blocks.\n      result = result.filter(ancestor => ancestor !== currentNode);\n    } else {\n      // Record last containing block for next iteration.\n      currentContainingBlockComputedStyle = computedStyle;\n    }\n    currentNode = getParentNode(currentNode);\n  }\n  cache.set(element, result);\n  return result;\n}\n\n// Gets the maximum area that the element is visible in due to any number of\n// clipping ancestors.\nfunction getClippingRect(_ref) {\n  let {\n    element,\n    boundary,\n    rootBoundary,\n    strategy\n  } = _ref;\n  const elementClippingAncestors = boundary === 'clippingAncestors' ? isTopLayer(element) ? [] : getClippingElementAncestors(element, this._c) : [].concat(boundary);\n  const clippingAncestors = [...elementClippingAncestors, rootBoundary];\n  const firstClippingAncestor = clippingAncestors[0];\n  const clippingRect = clippingAncestors.reduce((accRect, clippingAncestor) => {\n    const rect = getClientRectFromClippingAncestor(element, clippingAncestor, strategy);\n    accRect.top = max(rect.top, accRect.top);\n    accRect.right = min(rect.right, accRect.right);\n    accRect.bottom = min(rect.bottom, accRect.bottom);\n    accRect.left = max(rect.left, accRect.left);\n    return accRect;\n  }, getClientRectFromClippingAncestor(element, firstClippingAncestor, strategy));\n  return {\n    width: clippingRect.right - clippingRect.left,\n    height: clippingRect.bottom - clippingRect.top,\n    x: clippingRect.left,\n    y: clippingRect.top\n  };\n}\n\nfunction getDimensions(element) {\n  const {\n    width,\n    height\n  } = getCssDimensions(element);\n  return {\n    width,\n    height\n  };\n}\n\nfunction getRectRelativeToOffsetParent(element, offsetParent, strategy) {\n  const isOffsetParentAnElement = isHTMLElement(offsetParent);\n  const documentElement = getDocumentElement(offsetParent);\n  const isFixed = strategy === 'fixed';\n  const rect = getBoundingClientRect(element, true, isFixed, offsetParent);\n  let scroll = {\n    scrollLeft: 0,\n    scrollTop: 0\n  };\n  const offsets = createCoords(0);\n  if (isOffsetParentAnElement || !isOffsetParentAnElement && !isFixed) {\n    if (getNodeName(offsetParent) !== 'body' || isOverflowElement(documentElement)) {\n      scroll = getNodeScroll(offsetParent);\n    }\n    if (isOffsetParentAnElement) {\n      const offsetRect = getBoundingClientRect(offsetParent, true, isFixed, offsetParent);\n      offsets.x = offsetRect.x + offsetParent.clientLeft;\n      offsets.y = offsetRect.y + offsetParent.clientTop;\n    } else if (documentElement) {\n      // If the <body> scrollbar appears on the left (e.g. RTL systems). Use\n      // Firefox with layout.scrollbar.side = 3 in about:config to test this.\n      offsets.x = getWindowScrollBarX(documentElement);\n    }\n  }\n  const htmlOffset = documentElement && !isOffsetParentAnElement && !isFixed ? getHTMLOffset(documentElement, scroll) : createCoords(0);\n  const x = rect.left + scroll.scrollLeft - offsets.x - htmlOffset.x;\n  const y = rect.top + scroll.scrollTop - offsets.y - htmlOffset.y;\n  return {\n    x,\n    y,\n    width: rect.width,\n    height: rect.height\n  };\n}\n\nfunction isStaticPositioned(element) {\n  return getComputedStyle(element).position === 'static';\n}\n\nfunction getTrueOffsetParent(element, polyfill) {\n  if (!isHTMLElement(element) || getComputedStyle(element).position === 'fixed') {\n    return null;\n  }\n  if (polyfill) {\n    return polyfill(element);\n  }\n  let rawOffsetParent = element.offsetParent;\n\n  // Firefox returns the <html> element as the offsetParent if it's non-static,\n  // while Chrome and Safari return the <body> element. The <body> element must\n  // be used to perform the correct calculations even if the <html> element is\n  // non-static.\n  if (getDocumentElement(element) === rawOffsetParent) {\n    rawOffsetParent = rawOffsetParent.ownerDocument.body;\n  }\n  return rawOffsetParent;\n}\n\n// Gets the closest ancestor positioned element. Handles some edge cases,\n// such as table ancestors and cross browser bugs.\nfunction getOffsetParent(element, polyfill) {\n  const win = getWindow(element);\n  if (isTopLayer(element)) {\n    return win;\n  }\n  if (!isHTMLElement(element)) {\n    let svgOffsetParent = getParentNode(element);\n    while (svgOffsetParent && !isLastTraversableNode(svgOffsetParent)) {\n      if (isElement(svgOffsetParent) && !isStaticPositioned(svgOffsetParent)) {\n        return svgOffsetParent;\n      }\n      svgOffsetParent = getParentNode(svgOffsetParent);\n    }\n    return win;\n  }\n  let offsetParent = getTrueOffsetParent(element, polyfill);\n  while (offsetParent && isTableElement(offsetParent) && isStaticPositioned(offsetParent)) {\n    offsetParent = getTrueOffsetParent(offsetParent, polyfill);\n  }\n  if (offsetParent && isLastTraversableNode(offsetParent) && isStaticPositioned(offsetParent) && !isContainingBlock(offsetParent)) {\n    return win;\n  }\n  return offsetParent || getContainingBlock(element) || win;\n}\n\nconst getElementRects = async function (data) {\n  const getOffsetParentFn = this.getOffsetParent || getOffsetParent;\n  const getDimensionsFn = this.getDimensions;\n  const floatingDimensions = await getDimensionsFn(data.floating);\n  return {\n    reference: getRectRelativeToOffsetParent(data.reference, await getOffsetParentFn(data.floating), data.strategy),\n    floating: {\n      x: 0,\n      y: 0,\n      width: floatingDimensions.width,\n      height: floatingDimensions.height\n    }\n  };\n};\n\nfunction isRTL(element) {\n  return getComputedStyle(element).direction === 'rtl';\n}\n\nconst platform = {\n  convertOffsetParentRelativeRectToViewportRelativeRect,\n  getDocumentElement,\n  getClippingRect,\n  getOffsetParent,\n  getElementRects,\n  getClientRects,\n  getDimensions,\n  getScale,\n  isElement,\n  isRTL\n};\n\nfunction rectsAreEqual(a, b) {\n  return a.x === b.x && a.y === b.y && a.width === b.width && a.height === b.height;\n}\n\n// https://samthor.au/2021/observing-dom/\nfunction observeMove(element, onMove) {\n  let io = null;\n  let timeoutId;\n  const root = getDocumentElement(element);\n  function cleanup() {\n    var _io;\n    clearTimeout(timeoutId);\n    (_io = io) == null || _io.disconnect();\n    io = null;\n  }\n  function refresh(skip, threshold) {\n    if (skip === void 0) {\n      skip = false;\n    }\n    if (threshold === void 0) {\n      threshold = 1;\n    }\n    cleanup();\n    const elementRectForRootMargin = element.getBoundingClientRect();\n    const {\n      left,\n      top,\n      width,\n      height\n    } = elementRectForRootMargin;\n    if (!skip) {\n      onMove();\n    }\n    if (!width || !height) {\n      return;\n    }\n    const insetTop = floor(top);\n    const insetRight = floor(root.clientWidth - (left + width));\n    const insetBottom = floor(root.clientHeight - (top + height));\n    const insetLeft = floor(left);\n    const rootMargin = -insetTop + \"px \" + -insetRight + \"px \" + -insetBottom + \"px \" + -insetLeft + \"px\";\n    const options = {\n      rootMargin,\n      threshold: max(0, min(1, threshold)) || 1\n    };\n    let isFirstUpdate = true;\n    function handleObserve(entries) {\n      const ratio = entries[0].intersectionRatio;\n      if (ratio !== threshold) {\n        if (!isFirstUpdate) {\n          return refresh();\n        }\n        if (!ratio) {\n          // If the reference is clipped, the ratio is 0. Throttle the refresh\n          // to prevent an infinite loop of updates.\n          timeoutId = setTimeout(() => {\n            refresh(false, 1e-7);\n          }, 1000);\n        } else {\n          refresh(false, ratio);\n        }\n      }\n      if (ratio === 1 && !rectsAreEqual(elementRectForRootMargin, element.getBoundingClientRect())) {\n        // It's possible that even though the ratio is reported as 1, the\n        // element is not actually fully within the IntersectionObserver's root\n        // area anymore. This can happen under performance constraints. This may\n        // be a bug in the browser's IntersectionObserver implementation. To\n        // work around this, we compare the element's bounding rect now with\n        // what it was at the time we created the IntersectionObserver. If they\n        // are not equal then the element moved, so we refresh.\n        refresh();\n      }\n      isFirstUpdate = false;\n    }\n\n    // Older browsers don't support a `document` as the root and will throw an\n    // error.\n    try {\n      io = new IntersectionObserver(handleObserve, {\n        ...options,\n        // Handle <iframe>s\n        root: root.ownerDocument\n      });\n    } catch (e) {\n      io = new IntersectionObserver(handleObserve, options);\n    }\n    io.observe(element);\n  }\n  refresh(true);\n  return cleanup;\n}\n\n/**\n * Automatically updates the position of the floating element when necessary.\n * Should only be called when the floating element is mounted on the DOM or\n * visible on the screen.\n * @returns cleanup function that should be invoked when the floating element is\n * removed from the DOM or hidden from the screen.\n * @see https://floating-ui.com/docs/autoUpdate\n */\nfunction autoUpdate(reference, floating, update, options) {\n  if (options === void 0) {\n    options = {};\n  }\n  const {\n    ancestorScroll = true,\n    ancestorResize = true,\n    elementResize = typeof ResizeObserver === 'function',\n    layoutShift = typeof IntersectionObserver === 'function',\n    animationFrame = false\n  } = options;\n  const referenceEl = unwrapElement(reference);\n  const ancestors = ancestorScroll || ancestorResize ? [...(referenceEl ? getOverflowAncestors(referenceEl) : []), ...getOverflowAncestors(floating)] : [];\n  ancestors.forEach(ancestor => {\n    ancestorScroll && ancestor.addEventListener('scroll', update, {\n      passive: true\n    });\n    ancestorResize && ancestor.addEventListener('resize', update);\n  });\n  const cleanupIo = referenceEl && layoutShift ? observeMove(referenceEl, update) : null;\n  let reobserveFrame = -1;\n  let resizeObserver = null;\n  if (elementResize) {\n    resizeObserver = new ResizeObserver(_ref => {\n      let [firstEntry] = _ref;\n      if (firstEntry && firstEntry.target === referenceEl && resizeObserver) {\n        // Prevent update loops when using the `size` middleware.\n        // https://github.com/floating-ui/floating-ui/issues/1740\n        resizeObserver.unobserve(floating);\n        cancelAnimationFrame(reobserveFrame);\n        reobserveFrame = requestAnimationFrame(() => {\n          var _resizeObserver;\n          (_resizeObserver = resizeObserver) == null || _resizeObserver.observe(floating);\n        });\n      }\n      update();\n    });\n    if (referenceEl && !animationFrame) {\n      resizeObserver.observe(referenceEl);\n    }\n    resizeObserver.observe(floating);\n  }\n  let frameId;\n  let prevRefRect = animationFrame ? getBoundingClientRect(reference) : null;\n  if (animationFrame) {\n    frameLoop();\n  }\n  function frameLoop() {\n    const nextRefRect = getBoundingClientRect(reference);\n    if (prevRefRect && !rectsAreEqual(prevRefRect, nextRefRect)) {\n      update();\n    }\n    prevRefRect = nextRefRect;\n    frameId = requestAnimationFrame(frameLoop);\n  }\n  update();\n  return () => {\n    var _resizeObserver2;\n    ancestors.forEach(ancestor => {\n      ancestorScroll && ancestor.removeEventListener('scroll', update);\n      ancestorResize && ancestor.removeEventListener('resize', update);\n    });\n    cleanupIo == null || cleanupIo();\n    (_resizeObserver2 = resizeObserver) == null || _resizeObserver2.disconnect();\n    resizeObserver = null;\n    if (animationFrame) {\n      cancelAnimationFrame(frameId);\n    }\n  };\n}\n\n/**\n * Resolves with an object of overflow side offsets that determine how much the\n * element is overflowing a given clipping boundary on each side.\n * - positive = overflowing the boundary by that number of pixels\n * - negative = how many pixels left before it will overflow\n * - 0 = lies flush with the boundary\n * @see https://floating-ui.com/docs/detectOverflow\n */\nconst detectOverflow = detectOverflow$1;\n\n/**\n * Modifies the placement by translating the floating element along the\n * specified axes.\n * A number (shorthand for `mainAxis` or distance), or an axes configuration\n * object may be passed.\n * @see https://floating-ui.com/docs/offset\n */\nconst offset = offset$1;\n\n/**\n * Optimizes the visibility of the floating element by choosing the placement\n * that has the most space available automatically, without needing to specify a\n * preferred placement. Alternative to `flip`.\n * @see https://floating-ui.com/docs/autoPlacement\n */\nconst autoPlacement = autoPlacement$1;\n\n/**\n * Optimizes the visibility of the floating element by shifting it in order to\n * keep it in view when it will overflow the clipping boundary.\n * @see https://floating-ui.com/docs/shift\n */\nconst shift = shift$1;\n\n/**\n * Optimizes the visibility of the floating element by flipping the `placement`\n * in order to keep it in view when the preferred placement(s) will overflow the\n * clipping boundary. Alternative to `autoPlacement`.\n * @see https://floating-ui.com/docs/flip\n */\nconst flip = flip$1;\n\n/**\n * Provides data that allows you to change the size of the floating element —\n * for instance, prevent it from overflowing the clipping boundary or match the\n * width of the reference element.\n * @see https://floating-ui.com/docs/size\n */\nconst size = size$1;\n\n/**\n * Provides data to hide the floating element in applicable situations, such as\n * when it is not in the same clipping context as the reference element.\n * @see https://floating-ui.com/docs/hide\n */\nconst hide = hide$1;\n\n/**\n * Provides data to position an inner element of the floating element so that it\n * appears centered to the reference element.\n * @see https://floating-ui.com/docs/arrow\n */\nconst arrow = arrow$1;\n\n/**\n * Provides improved positioning for inline reference elements that can span\n * over multiple lines, such as hyperlinks or range selections.\n * @see https://floating-ui.com/docs/inline\n */\nconst inline = inline$1;\n\n/**\n * Built-in `limiter` that will stop `shift()` at a certain point.\n */\nconst limitShift = limitShift$1;\n\n/**\n * Computes the `x` and `y` coordinates that will place the floating element\n * next to a given reference element.\n */\nconst computePosition = (reference, floating, options) => {\n  // This caches the expensive `getClippingElementAncestors` function so that\n  // multiple lifecycle resets re-use the same result. It only lives for a\n  // single call. If other functions become expensive, we can add them as well.\n  const cache = new Map();\n  const mergedOptions = {\n    platform,\n    ...options\n  };\n  const platformWithCache = {\n    ...mergedOptions.platform,\n    _c: cache\n  };\n  return computePosition$1(reference, floating, {\n    ...mergedOptions,\n    platform: platformWithCache\n  });\n};\n\nexport { arrow, autoPlacement, autoUpdate, computePosition, detectOverflow, flip, hide, inline, limitShift, offset, platform, shift, size };\n","import { arrow as arrow$1, computePosition } from '@floating-ui/dom';\nexport { autoPlacement, autoUpdate, computePosition, detectOverflow, flip, getOverflowAncestors, hide, inline, limitShift, offset, platform, shift, size } from '@floating-ui/dom';\nimport { isNode, getNodeName } from '@floating-ui/utils/dom';\nimport { unref, computed, ref, shallowRef, watch, getCurrentScope, onScopeDispose, shallowReadonly } from 'vue-demi';\n\nfunction isComponentPublicInstance(target) {\n  return target != null && typeof target === 'object' && '$el' in target;\n}\nfunction unwrapElement(target) {\n  if (isComponentPublicInstance(target)) {\n    const element = target.$el;\n    return isNode(element) && getNodeName(element) === '#comment' ? null : element;\n  }\n  return target;\n}\n\nfunction toValue(source) {\n  return typeof source === 'function' ? source() : unref(source);\n}\n\n/**\n * Positions an inner element of the floating element such that it is centered to the reference element.\n * @param options The arrow options.\n * @see https://floating-ui.com/docs/arrow\n */\nfunction arrow(options) {\n  return {\n    name: 'arrow',\n    options,\n    fn(args) {\n      const element = unwrapElement(toValue(options.element));\n      if (element == null) {\n        return {};\n      }\n      return arrow$1({\n        element,\n        padding: options.padding\n      }).fn(args);\n    }\n  };\n}\n\nfunction getDPR(element) {\n  if (typeof window === 'undefined') {\n    return 1;\n  }\n  const win = element.ownerDocument.defaultView || window;\n  return win.devicePixelRatio || 1;\n}\n\nfunction roundByDPR(element, value) {\n  const dpr = getDPR(element);\n  return Math.round(value * dpr) / dpr;\n}\n\n/**\n * Computes the `x` and `y` coordinates that will place the floating element next to a reference element when it is given a certain CSS positioning strategy.\n * @param reference The reference template ref.\n * @param floating The floating template ref.\n * @param options The floating options.\n * @see https://floating-ui.com/docs/vue\n */\nfunction useFloating(reference, floating, options) {\n  if (options === void 0) {\n    options = {};\n  }\n  const whileElementsMountedOption = options.whileElementsMounted;\n  const openOption = computed(() => {\n    var _toValue;\n    return (_toValue = toValue(options.open)) != null ? _toValue : true;\n  });\n  const middlewareOption = computed(() => toValue(options.middleware));\n  const placementOption = computed(() => {\n    var _toValue2;\n    return (_toValue2 = toValue(options.placement)) != null ? _toValue2 : 'bottom';\n  });\n  const strategyOption = computed(() => {\n    var _toValue3;\n    return (_toValue3 = toValue(options.strategy)) != null ? _toValue3 : 'absolute';\n  });\n  const transformOption = computed(() => {\n    var _toValue4;\n    return (_toValue4 = toValue(options.transform)) != null ? _toValue4 : true;\n  });\n  const referenceElement = computed(() => unwrapElement(reference.value));\n  const floatingElement = computed(() => unwrapElement(floating.value));\n  const x = ref(0);\n  const y = ref(0);\n  const strategy = ref(strategyOption.value);\n  const placement = ref(placementOption.value);\n  const middlewareData = shallowRef({});\n  const isPositioned = ref(false);\n  const floatingStyles = computed(() => {\n    const initialStyles = {\n      position: strategy.value,\n      left: '0',\n      top: '0'\n    };\n    if (!floatingElement.value) {\n      return initialStyles;\n    }\n    const xVal = roundByDPR(floatingElement.value, x.value);\n    const yVal = roundByDPR(floatingElement.value, y.value);\n    if (transformOption.value) {\n      return {\n        ...initialStyles,\n        transform: \"translate(\" + xVal + \"px, \" + yVal + \"px)\",\n        ...(getDPR(floatingElement.value) >= 1.5 && {\n          willChange: 'transform'\n        })\n      };\n    }\n    return {\n      position: strategy.value,\n      left: xVal + \"px\",\n      top: yVal + \"px\"\n    };\n  });\n  let whileElementsMountedCleanup;\n  function update() {\n    if (referenceElement.value == null || floatingElement.value == null) {\n      return;\n    }\n    const open = openOption.value;\n    computePosition(referenceElement.value, floatingElement.value, {\n      middleware: middlewareOption.value,\n      placement: placementOption.value,\n      strategy: strategyOption.value\n    }).then(position => {\n      x.value = position.x;\n      y.value = position.y;\n      strategy.value = position.strategy;\n      placement.value = position.placement;\n      middlewareData.value = position.middlewareData;\n      /**\n       * The floating element's position may be recomputed while it's closed\n       * but still mounted (such as when transitioning out). To ensure\n       * `isPositioned` will be `false` initially on the next open, avoid\n       * setting it to `true` when `open === false` (must be specified).\n       */\n      isPositioned.value = open !== false;\n    });\n  }\n  function cleanup() {\n    if (typeof whileElementsMountedCleanup === 'function') {\n      whileElementsMountedCleanup();\n      whileElementsMountedCleanup = undefined;\n    }\n  }\n  function attach() {\n    cleanup();\n    if (whileElementsMountedOption === undefined) {\n      update();\n      return;\n    }\n    if (referenceElement.value != null && floatingElement.value != null) {\n      whileElementsMountedCleanup = whileElementsMountedOption(referenceElement.value, floatingElement.value, update);\n      return;\n    }\n  }\n  function reset() {\n    if (!openOption.value) {\n      isPositioned.value = false;\n    }\n  }\n  watch([middlewareOption, placementOption, strategyOption, openOption], update, {\n    flush: 'sync'\n  });\n  watch([referenceElement, floatingElement], attach, {\n    flush: 'sync'\n  });\n  watch(openOption, reset, {\n    flush: 'sync'\n  });\n  if (getCurrentScope()) {\n    onScopeDispose(cleanup);\n  }\n  return {\n    x: shallowReadonly(x),\n    y: shallowReadonly(y),\n    strategy: shallowReadonly(strategy),\n    placement: shallowReadonly(placement),\n    middlewareData: shallowReadonly(middlewareData),\n    isPositioned: shallowReadonly(isPositioned),\n    floatingStyles,\n    update\n  };\n}\n\nexport { arrow, useFloating };\n","export const isClickOutside = (event: MouseEvent, elements: HTMLElement | HTMLElement[]): boolean => {\n  const targets = Array.isArray(elements) ? elements : [elements];\n  return !targets.some((el) => el.contains(event.target as Node));\n};\n","<script lang=\"ts\" setup>\n  import { autoPlacement, autoUpdate, offset as offsetMiddleware, shift, useFloating } from '@floating-ui/vue';\n  import { computed, onBeforeMount, onMounted, onUnmounted, ref, watch, watchEffect } from 'vue';\n\n  import { CSS } from '@/types/Styles';\n  import { isClickOutside } from '@/utilities/event';\n  import { TOP_LAYER_ID, initFauxTopLayer } from '@/utilities/viewport';\n\n  import type { Ref } from 'vue';\n\n  type Props = {\n    anchorId: string;\n    offset?: number;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    offset: 16,\n  });\n\n  const anchor: Ref<HTMLElement | null> = ref(null);\n  const floating: Ref<HTMLElement | null> = ref(null);\n  const root: Ref<HTMLElement | null> = ref(null);\n  const isHovered = ref(false);\n  const isToggledOpen = ref(false);\n  const middleware = ref([autoPlacement(), offsetMiddleware({ mainAxis: props.offset }), shift({ padding: 16 })]);\n\n  const isShowPopover = computed(() => isHovered.value || isToggledOpen.value);\n\n  const { floatingStyles } = useFloating(anchor, floating, {\n    middleware,\n    strategy: 'fixed',\n    whileElementsMounted: autoUpdate,\n  });\n\n  const handlePermanentOpenBodyClick = (e: MouseEvent) => {\n    if (!anchor.value || !floating.value) return;\n    if (isClickOutside(e, [anchor.value, floating.value])) {\n      isToggledOpen.value = false;\n      e.preventDefault();\n      e.stopImmediatePropagation();\n    }\n  };\n\n  const handleAnchorElementMouseOver = () => {\n    isHovered.value = true;\n  };\n\n  const handleAnchorElementMouseLeave = () => {\n    isHovered.value = false;\n  };\n\n  const handleAnchorElementClick = (e: MouseEvent) => {\n    e.preventDefault();\n    if (isToggledOpen.value) {\n      isToggledOpen.value = false;\n      isHovered.value = false;\n    } else {\n      isToggledOpen.value = true;\n    }\n  };\n\n  const addListenersToAnchorElement = () => {\n    if (!anchor.value) return null;\n    anchor.value.addEventListener('mouseover', handleAnchorElementMouseOver);\n    anchor.value.addEventListener('mouseleave', handleAnchorElementMouseLeave);\n    anchor.value.addEventListener('click', handleAnchorElementClick);\n  };\n\n  const removeListenersFromAnchorElement = () => {\n    if (!anchor.value) return null;\n    anchor.value.removeEventListener('mouseover', handleAnchorElementMouseOver);\n    anchor.value.removeEventListener('mouseleave', handleAnchorElementMouseLeave);\n    anchor.value.removeEventListener('click', handleAnchorElementClick);\n  };\n\n  const handlePermanentOpenBodyKeydown = (e: KeyboardEvent) => {\n    if (e.key === 'Escape') {\n      isToggledOpen.value = false;\n    }\n  };\n\n  const addOpenListenersToRoot = () => {\n    if (!root.value) return;\n    root.value.addEventListener('click', handlePermanentOpenBodyClick, true);\n    root.value.addEventListener('keydown', handlePermanentOpenBodyKeydown);\n  };\n\n  const removeOpenListenersFromRoot = () => {\n    if (!root.value) return;\n    root.value.removeEventListener('click', handlePermanentOpenBodyClick, true);\n    root.value.removeEventListener('keydown', handlePermanentOpenBodyKeydown);\n  };\n\n  const updateAnchorElement = () => {\n    anchor.value = document.getElementById(props.anchorId);\n  };\n\n  watch(\n    () => isToggledOpen.value,\n    (newValue) => {\n      if (newValue) {\n        addOpenListenersToRoot();\n      } else {\n        removeOpenListenersFromRoot();\n      }\n    }\n  );\n\n  watch(\n    () => props.anchorId,\n    () => {\n      removeListenersFromAnchorElement();\n      updateAnchorElement();\n      addListenersToAnchorElement();\n    }\n  );\n\n  watchEffect(() => {\n    middleware.value = [autoPlacement(), offsetMiddleware({ mainAxis: props.offset }), shift({ padding: 16 })];\n  });\n\n  onBeforeMount(() => {\n    initFauxTopLayer();\n  });\n\n  onMounted(() => {\n    updateAnchorElement();\n    root.value = document.documentElement;\n    addListenersToAnchorElement();\n  });\n\n  onUnmounted(() => {\n    removeListenersFromAnchorElement();\n  });\n</script>\n\n<template>\n  <Teleport :to=\"`#${TOP_LAYER_ID}`\">\n    <Transition>\n      <div\n        :class=\"[\n          'tide-popover',\n          CSS.BG.SURFACE.DEFAULT,\n          CSS.BORDER.COLOR.LOW,\n          CSS.BORDER.FULL.ONE,\n          CSS.BORDER.RADIUS.HALF,\n          CSS.FONT.ROLE.BODY_2,\n          CSS.PADDING.FULL.ONE,\n          CSS.SHADOW.BOTTOM,\n        ]\"\n        ref=\"floating\"\n        :style=\"{ ...floatingStyles }\"\n        v-show=\"isShowPopover\"\n      >\n        <slot />\n      </div>\n    </Transition>\n  </Teleport>\n</template>\n\n<style scoped>\n  .tide-popover {\n    max-width: 256px;\n  }\n  .v-enter-from,\n  .v-leave-to {\n    opacity: 0;\n  }\n  .v-enter-active,\n  .v-leave-active {\n    transition: opacity var(--tide-animate);\n  }\n  .v-enter-to,\n  .v-leave-from {\n    opacity: 1;\n  }\n</style>\n","<script lang=\"ts\" setup>\n  import { CSS } from '@/types/Styles';\n  import { TARGET } from '@/types/Target';\n\n  import type { Link } from '@/types/Link';\n\n  type Props = {\n    heading?: string;\n    links: Link[];\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    heading: '',\n  });\n</script>\n\n<template>\n  <section class=\"tide-seo-links\">\n    <h2 :class=\"[CSS.MARGIN.BOTTOM.HALF]\">\n      {{ props.heading }}\n    </h2>\n\n    <ul :class=\"[CSS.DISPLAY.FLEX, CSS.FLEX.WRAP, CSS.GAP.TWO, CSS.LIST_BULLETS.OFF]\">\n      <li\n        :class=\"['tide-seo-link', CSS.DISPLAY.FLEX, CSS.FLEX.DIRECTION.COLUMN, CSS.GAP.QUARTER, CSS.FONT.ROLE.BODY_2]\"\n        :key=\"link.label\"\n        v-for=\"link in props.links\"\n      >\n        <a\n          :class=\"[CSS.UNDERLINE.REST.OFF]\"\n          :href=\"link.url\"\n          :target=\"link.isNewTab ? TARGET.BLANK : TARGET.SELF\"\n        >\n          {{ link.label }}\n        </a>\n      </li>\n    </ul>\n  </section>\n</template>\n\n<style scoped>\n  /* TODO: Refactor to accept breakpoint prop in order to accomplish this with neither custom breakpoints nor dependency on ViewportStore. */\n  .tide-seo-link {\n    width: 100%;\n  }\n\n  @media (min-width: 992px) {\n    .tide-seo-link {\n      width: calc((100% - 2rem) / 2);\n    }\n  }\n\n  @media (min-width: 1232px) {\n    .tide-seo-link {\n      width: calc((100% - 6rem) / 4);\n    }\n  }\n</style>\n","<script lang=\"ts\" setup>\n  import { onBeforeMount, onMounted, ref, watch } from 'vue';\n\n  import TideButtonIcon from '@/components/TideButtonIcon.vue';\n  import { ICON } from '@/types/Icon';\n  import { PRIORITY } from '@/types/Priority';\n  import { CSS } from '@/types/Styles';\n  import { TOP_LAYER_ID, initFauxTopLayer, setScrollLock } from '@/utilities/viewport';\n\n  import TideDivider from './TideDivider.vue';\n\n  import type { Ref } from 'vue';\n\n  type Props = {\n    isOpen: boolean;\n    isBackButton?: boolean;\n  };\n  const props = defineProps<Props>();\n\n  type Emits = {\n    (e: 'back'): void;\n    (e: 'close'): void;\n  };\n\n  const emit = defineEmits<Emits>();\n\n  const dialogElement: Ref<HTMLDialogElement | null> = ref(null);\n\n  const triggerNativeDialogOpen = () => {\n    dialogElement.value?.showModal();\n  };\n\n  const triggerNativeDialogClose = () => {\n    dialogElement.value?.close();\n  };\n\n  const handleBackdropClick = () => {\n    emit('close');\n  };\n\n  const handleEscapeKeydown = (e: Event) => {\n    e.preventDefault();\n    emit('close');\n  };\n\n  watch(\n    () => props.isOpen,\n    (newValue) => {\n      if (!dialogElement.value) return;\n      if (newValue) {\n        triggerNativeDialogOpen();\n      } else {\n        triggerNativeDialogClose();\n      }\n      setScrollLock(newValue);\n    }\n  );\n\n  onBeforeMount(() => {\n    initFauxTopLayer();\n  });\n\n  onMounted(() => {\n    if (props.isOpen) {\n      triggerNativeDialogOpen();\n    }\n  });\n</script>\n\n<template>\n  <Teleport :to=\"`#${TOP_LAYER_ID}`\">\n    <dialog\n      :class=\"['tide-sheet', CSS.BG.INITIAL, CSS.HEIGHT.FULL, CSS.WIDTH.FULL, CSS.OVERFLOW.XY.HIDDEN]\"\n      ref=\"dialogElement\"\n      @click.self=\"handleBackdropClick\"\n      @close.prevent\n      @keydown.escape=\"handleEscapeKeydown\"\n    >\n      <div\n        :class=\"[\n          'tide-sheet-body',\n          CSS.BG.SURFACE.DEFAULT,\n          CSS.DISPLAY.FLEX,\n          CSS.FLEX.DIRECTION.COLUMN,\n          CSS.HEIGHT.FULL,\n          CSS.OVERFLOW.XY.HIDDEN,\n          CSS.WIDTH.FULL,\n        ]\"\n      >\n        <header\n          :class=\"[\n            CSS.DISPLAY.FLEX,\n            CSS.ISOLATION.ISOLATE,\n            CSS.PADDING.TOP.ONE,\n            CSS.PADDING.X.ONE,\n            CSS.POSITION.RELATIVE,\n            CSS.Z_INDEX.ONE,\n          ]\"\n        >\n          <TideButtonIcon\n            :class=\"[CSS.FLEX.GROW.OFF, CSS.FLEX.SHRINK.OFF]\"\n            :icon=\"ICON.CHEVRON_LEFT\"\n            :priority=\"PRIORITY.QUATERNARY\"\n            @click=\"emit('back')\"\n            v-if=\"isBackButton\"\n          />\n\n          <TideButtonIcon\n            :class=\"[CSS.FLEX.GROW.OFF, CSS.FLEX.SHRINK.OFF, CSS.MARGIN.LEFT.AUTO]\"\n            :icon=\"ICON.CLOSE\"\n            :priority=\"PRIORITY.QUATERNARY\"\n            @click=\"emit('close')\"\n          />\n        </header>\n\n        <TideDivider />\n\n        <div\n          :class=\"[\n            'tide-sheet-content',\n            CSS.DISPLAY.GRID,\n            CSS.OVERFLOW.Y.AUTO,\n            CSS.OVERFLOW.X.HIDDEN,\n            CSS.WIDTH.FULL,\n            CSS.PADDING.BOTTOM.ONE,\n            CSS.ISOLATION.ISOLATE,\n          ]\"\n        >\n          <slot />\n        </div>\n      </div>\n    </dialog>\n  </Teleport>\n</template>\n\n<style scoped>\n  .tide-sheet {\n    --sheet-padding-x: var(--tide-spacing-1);\n    max-width: unset;\n    max-height: unset;\n    justify-items: right;\n    display: none;\n    transition: all var(--tide-animate) allow-discrete;\n    transform: translateX(100%);\n  }\n\n  .tide-sheet[open] {\n    display: grid;\n    transform: translateX(0%);\n  }\n\n  .tide-sheet::backdrop {\n    background-color: transparent;\n    transition: all var(--tide-animate) allow-discrete;\n    backdrop-filter: blur(0px);\n  }\n\n  .tide-sheet[open]::backdrop {\n    background-color: var(--tide-transparent-400);\n    backdrop-filter: var(--tide-bg-blur);\n  }\n\n  .tide-sheet-body {\n    max-width: min(calc(100vw - var(--tide-spacing-2)), 311px);\n  }\n\n  .tide-sheet-content {\n    grid-template-columns: var(--sheet-padding-x) 1fr var(--sheet-padding-x);\n  }\n\n  :where(.tide-sheet-content):deep(> :where(*)) {\n    grid-column: 2;\n  }\n\n  @starting-style {\n    .tide-sheet[open] {\n      display: grid;\n      transform: translateX(100%);\n    }\n\n    .tide-sheet[open]::backdrop {\n      background-color: transparent;\n      backdrop-filter: var(--tide-bg-blur);\n    }\n  }\n</style>\n","<script lang=\"ts\" setup>\n  import TideIcon from '@/components/TideIcon.vue';\n  import { ICON } from '@/types/Icon';\n  import { SIZE } from '@/types/Size';\n  import { CSS } from '@/types/Styles';\n\n  type Props = {\n    disabled?: boolean;\n    isActive?: boolean;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    disabled: false,\n    isActive: false,\n  });\n\n  const emit = defineEmits(['change']);\n\n  const handleClick = () => {\n    if (!props.disabled) {\n      emit('change');\n    }\n  };\n</script>\n\n<template>\n  <button\n    :class=\"[\n      'tide-switch',\n      props.isActive ? 'active' : '',\n      CSS.DISPLAY.FLEX,\n      CSS.AXIS2.CENTER,\n      CSS.BORDER.FULL.ONE,\n      CSS.BORDER.RADIUS.FULL,\n      props.isActive ? '' : CSS.BORDER.COLOR.DEFAULT,\n      CSS.OVERFLOW.XY.HIDDEN,\n      props.isActive ? CSS.BG.SECONDARY : CSS.BG.SURFACE.DEFAULT,\n    ]\"\n    :disabled=\"props.disabled\"\n    @click=\"handleClick\"\n    aria-label=\"Switch\"\n  >\n    <div\n      :class=\"[\n        'tide-switch-indicator',\n        CSS.POSITION.RELATIVE,\n        CSS.DISPLAY.FLEX,\n        CSS.AXIS1.CENTER,\n        CSS.AXIS2.CENTER,\n        CSS.BORDER.RADIUS.FULL,\n        props.isActive ? CSS.BG.SURFACE.DEFAULT : CSS.BG.SECONDARY,\n      ]\"\n    >\n      <TideIcon\n        :icon=\"ICON.CHECK\"\n        :size=\"SIZE.LARGE\"\n      />\n    </div>\n  </button>\n</template>\n\n<style scoped>\n  .tide-switch {\n    width: 64px;\n    height: 32px;\n    transition: var(--tide-animate);\n    transition-property: background-color;\n  }\n\n  .tide-switch:disabled {\n    opacity: var(--tide-opacity);\n  }\n\n  .tide-switch.active {\n    border-color: var(--tide-secondary);\n  }\n\n  .tide-switch.active .tide-switch-indicator {\n    left: 36px;\n  }\n\n  .tide-switch-indicator {\n    left: 4px;\n    transition: var(--tide-animate);\n    transition-property: left, border-color, background-color;\n  }\n</style>\n"],"names":["ORIENTATION","CSS","utilities","breakpoint","utility","props","__props","_openBlock","_createElementBlock","_hoisted_1","_createElementVNode","_normalizeClass","_unref","REALM","SIZE","SIZE_BUTTON","formatNumber","input","output","digits","formatPascalCase","word","formatPhone","formatPrice","innerSVG","ref","watch","id","name","prefix","realmFolder","component","defineAsyncComponent","__variableDynamicImportRuntimeHelper","markRaw","_createBlock","_resolveDynamicComponent","ICON","ICON_REALM","emit","__emit","handleToggleClick","TideDivider","_toDisplayString","_createVNode","TideIcon","_renderSlot","_ctx","ELEMENT","ELEMENT_TEXT_AS_ICON","PRIORITY","TARGET","ALERT","iconType","computed","TideButtonIcon","BADGE_COLOR","BADGE_COLOR_DETAILS","BADGE_TRUSTED","_Fragment","crumb","index","_hoisted_2","_hoisted_3","_createTextVNode","handleClick","tab","$event","TYPE_CARD","containerRef","isFirstSlide","isLastSlide","showButtons","slideObserver","slidesInView","slotObserver","slides","handleScroll","updateContainerBleed","observeSlides","options","entries","slidesAddedToView","entry","slideIndex","slide","a","b","child","observeSlot","observerCallback","scrollToOffset","target","showNextPage","nextSlide","showPreviousPage","previousSlide","_a","showNextSlide","showPreviousSlide","onMounted","onUnmounted","_b","_cache","_hoisted_4","_hoisted_5","OBJECT_FIT","imageDefault","picture","img","objectFitClassName","setImageFromDefault","currentSrc","pictureSource","_normalizeStyle","_renderList","source","TideImage","FORM_KEY","useTideForm","forceShowErrors","provide","useFormContext","inject","errorMessageDefault","VALIDATION_RESULT","checkFormat","format","message","value","result","getFieldLengthIsValid","maxlength","minlength","required","isEmptyAndUnrequired","isTooLong","getFieldValidationResult","errorFromProps","validators","validation","validateProperty","lengthValidation","validateLength","response","validator","modelValue","_useModel","formContext","isValidating","errorRef","formattedLabel","isChecked","showError","hasErrorFromProp","supportingTextMessage","getCheckboxValidationResult","watchEffect","newValue","TideInputSupportingText","__default__","checked","oldValue","FORMAT","FORMAT_REGEX","VALIDATOR","ERROR_DISPLAY","hasFocus","inputId","useId","selectElement","hasMinilabel","isEmpty","expandOptions","event","handleFocus","handleFocusOut","optgroup","option","_hoisted_6","getErrorMessage","errorFromRef","getFieldHasError","handleFieldValidation","error","errorMessage","hasError","__expose","TEXT_INPUT_TYPE","INPUT_MODE","getTextInputMode","type","inputmode","inputElement","showPassword","inputModeAttribute","inputType","shouldShowClearButton","shouldShowPasswordButton","handleClear","handleFieldClick","preventInputFocusLossOnMousedown","e","hasClear","handleValidation","handleInput","updateValue","textareaElement","preventTextareaFocusLossOnMousedown","BREAKPOINT","MEDIA","setScrollLock","isLocked","body","scrollY","nextTick","savedScrollY","TOP_LAYER_ID","initFauxTopLayer","topLayer","modalContent","modalDialog","triggerNativeDialogOpen","triggerNativeDialogClose","scrollContentToTop","handleBackdropClick","handleEscapeKeydown","$slots","pageCurrent","paginationButtons","empty","paginationButton","TideButtonPagination","sides","alignments","placements","acc","side","min","max","round","floor","createCoords","v","oppositeSideMap","oppositeAlignmentMap","clamp","start","end","evaluate","param","getSide","placement","getAlignment","getOppositeAxis","axis","getAxisLength","getSideAxis","getAlignmentAxis","getAlignmentSides","rects","rtl","alignment","alignmentAxis","length","mainAlignmentSide","getOppositePlacement","getOppositeAlignmentPlacement","expandPaddingObject","padding","getPaddingObject","rectToClientRect","rect","x","y","width","height","computeCoordsFromPlacement","_ref","reference","floating","sideAxis","alignLength","isVertical","commonX","commonY","commonAlign","coords","computePosition","config","strategy","middleware","platform","validMiddleware","statefulPlacement","middlewareData","resetCount","i","fn","nextX","nextY","data","reset","detectOverflow","state","_await$platform$isEle","elements","boundary","rootBoundary","elementContext","altBoundary","paddingObject","element","clippingClientRect","offsetParent","offsetScale","elementClientRect","getPlacementList","autoAlignment","allowedPlacements","autoPlacement","_middlewareData$autoP","_middlewareData$autoP2","_placementsThatFitOnE","crossAxis","detectOverflowOptions","placements$1","overflow","currentIndex","currentPlacement","alignmentSides","currentOverflows","allOverflows","nextPlacement","placementsSortedByMostSpace","d","resetPlacement","convertValueToCoords","mainAxisMulti","crossAxisMulti","rawValue","mainAxis","offset","_middlewareData$offse","_middlewareData$arrow","diffCoords","shift","checkMainAxis","checkCrossAxis","limiter","mainAxisCoord","crossAxisCoord","minSide","maxSide","limitedCoords","hasWindow","getNodeName","node","isNode","getWindow","_node$ownerDocument","getDocumentElement","isElement","isHTMLElement","isShadowRoot","isOverflowElement","overflowX","overflowY","display","getComputedStyle","isTableElement","isTopLayer","selector","isContainingBlock","elementOrCss","webkit","isWebKit","css","getContainingBlock","currentNode","getParentNode","isLastTraversableNode","getNodeScroll","getNearestOverflowAncestor","parentNode","getOverflowAncestors","list","traverseIframes","_node$ownerDocument2","scrollableAncestor","isBody","win","frameElement","getFrameElement","getCssDimensions","hasOffset","offsetWidth","offsetHeight","shouldFallback","unwrapElement","getScale","domElement","$","noOffsets","getVisualOffsets","shouldAddVisualOffsets","isFixed","floatingOffsetParent","getBoundingClientRect","includeScale","isFixedStrategy","clientRect","scale","visualOffsets","offsetWin","currentWin","currentIFrame","iframeScale","iframeRect","left","top","getWindowScrollBarX","leftScroll","getHTMLOffset","documentElement","scroll","ignoreScrollbarX","htmlRect","convertOffsetParentRelativeRectToViewportRelativeRect","offsets","isOffsetParentAnElement","offsetRect","htmlOffset","getClientRects","getDocumentRect","html","getViewportRect","visualViewport","visualViewportBased","getInnerBoundingClientRect","getClientRectFromClippingAncestor","clippingAncestor","hasFixedPositionAncestor","stopNode","getClippingElementAncestors","cache","cachedResult","el","currentContainingBlockComputedStyle","elementIsFixed","computedStyle","currentNodeIsContaining","ancestor","getClippingRect","clippingAncestors","firstClippingAncestor","clippingRect","accRect","getDimensions","getRectRelativeToOffsetParent","isStaticPositioned","getTrueOffsetParent","polyfill","rawOffsetParent","getOffsetParent","svgOffsetParent","getElementRects","getOffsetParentFn","getDimensionsFn","floatingDimensions","isRTL","rectsAreEqual","observeMove","onMove","io","timeoutId","root","cleanup","_io","refresh","skip","threshold","elementRectForRootMargin","insetTop","insetRight","insetBottom","insetLeft","isFirstUpdate","handleObserve","ratio","autoUpdate","update","ancestorScroll","ancestorResize","elementResize","layoutShift","animationFrame","referenceEl","ancestors","cleanupIo","reobserveFrame","resizeObserver","firstEntry","_resizeObserver","frameId","prevRefRect","frameLoop","nextRefRect","_resizeObserver2","offset$1","autoPlacement$1","shift$1","mergedOptions","platformWithCache","computePosition$1","isComponentPublicInstance","toValue","unref","getDPR","roundByDPR","dpr","useFloating","whileElementsMountedOption","openOption","_toValue","middlewareOption","placementOption","_toValue2","strategyOption","_toValue3","transformOption","_toValue4","referenceElement","floatingElement","shallowRef","isPositioned","floatingStyles","initialStyles","xVal","yVal","whileElementsMountedCleanup","open","position","attach","getCurrentScope","onScopeDispose","shallowReadonly","isClickOutside","anchor","isHovered","isToggledOpen","offsetMiddleware","isShowPopover","handlePermanentOpenBodyClick","handleAnchorElementMouseOver","handleAnchorElementMouseLeave","handleAnchorElementClick","addListenersToAnchorElement","removeListenersFromAnchorElement","handlePermanentOpenBodyKeydown","addOpenListenersToRoot","removeOpenListenersFromRoot","updateAnchorElement","onBeforeMount","_Teleport","_Transition","link","dialogElement"],"mappings":"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","x_google_ignoreList":[57,58,59,60,61]}
4670
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"tide-design-system.esm.js","sources":["../src/types/Orientation.ts","../src/types/Styles.ts","../src/components/TideDivider.vue","../src/types/Realm.ts","../src/types/Size.ts","../src/utilities/format.ts","../src/components/TideIcon.vue","../src/types/Icon.ts","../src/components/TideAccordionItem.vue","../src/types/Element.ts","../src/types/Priority.ts","../src/types/Target.ts","../src/components/TideButtonIcon.vue","../src/types/Alert.ts","../src/components/TideAlert.vue","../src/types/Badge.ts","../src/components/TideBadge.vue","../src/components/TideBadgeTrustedPartner.vue","../src/components/TideBadgeVerifiedVehicle.vue","../src/components/TideBreadCrumbs.vue","../src/components/TideButton.vue","../src/components/TideButtonPagination.vue","../src/components/TideButtonSegmented.vue","../src/types/Card.ts","../src/components/TideCard.vue","../src/components/TideCarousel.vue","../src/components/TideChipAction.vue","../src/components/TideChipFilter.vue","../src/components/TideChipInput.vue","../src/components/TideColumns.vue","../src/types/Image.ts","../src/components/TideImage.vue","../src/components/TideImageBackground.vue","../src/components/TideIndicator.vue","../src/components/TideInputSupportingText.vue","../src/composables/useTideForm.ts","../src/utilities/validation.ts","../src/components/TideInputCheckbox.vue","../src/components/TideInputCheckboxDeprecated.vue","../src/components/TideInputRadio.vue","../src/components/TideInputRadioDeprecated.vue","../src/types/Formatted.ts","../src/types/Validation.ts","../src/components/TideInputSelect.vue","../src/utilities/validation-deprecated.ts","../src/components/TideInputSelectDeprecated.vue","../src/types/TextInput.ts","../src/utilities/forms.ts","../src/components/TideInputText.vue","../src/components/TideInputTextDeprecated.vue","../src/components/TideInputTextarea.vue","../src/components/TideInputTextareaDeprecated.vue","../src/components/TideLink.vue","../src/types/Breakpoint.ts","../src/utilities/viewport.ts","../src/components/TideModal.vue","../src/components/TidePagination.vue","../node_modules/@floating-ui/utils/dist/floating-ui.utils.mjs","../node_modules/@floating-ui/core/dist/floating-ui.core.mjs","../node_modules/@floating-ui/utils/dist/floating-ui.utils.dom.mjs","../node_modules/@floating-ui/dom/dist/floating-ui.dom.mjs","../node_modules/@floating-ui/vue/dist/floating-ui.vue.mjs","../src/utilities/event.ts","../src/components/TidePopover.vue","../src/components/TideSeoLinks.vue","../src/components/TideSheet.vue","../src/components/TideSwitch.vue"],"sourcesContent":["export const ORIENTATION = {\n  HORIZONTAL: 'horizontal',\n  VERTICAL: 'vertical',\n} as const;\n\nexport type Orientation = (typeof ORIENTATION)[keyof typeof ORIENTATION];\n","/* eslint-disable vue/sort-keys */\n\nimport type { Breakpoint } from '@/types/Breakpoint';\n\nexport const CSS = {\n  withBreakpoint: (utilities: string[], breakpoint: Breakpoint): string[] => {\n    return utilities.map((utility) => `${breakpoint}-${utility}`);\n  },\n  ALIGN: {\n    X: {\n      CENTER: 'tide-text-center',\n      JUSTIFY: 'tide-text-justify',\n      LEFT: 'tide-text-left',\n      RIGHT: 'tide-text-right',\n    },\n    Y: {\n      INITIAL: 'tide-align-initial',\n      MIDDLE: 'tide-align-middle',\n    },\n  },\n  AXIS1: {\n    AROUND: 'tide-axis1-around',\n    BETWEEN: 'tide-axis1-between',\n    CENTER: 'tide-axis1-center',\n    END: 'tide-axis1-end',\n    START: 'tide-axis1-start',\n  },\n  AXIS2: {\n    AROUND: 'tide-axis2-around',\n    CENTER: 'tide-axis2-center',\n    END: 'tide-axis2-end',\n    START: 'tide-axis2-start',\n    STRETCH: 'tide-axis2-stretch',\n  },\n  BG: {\n    GLOBAL: {\n      PRIMARY: {\n        ERROR: 'tide-bg-primary-error',\n        INFO: 'tide-bg-primary-info',\n        SUCCESS: 'tide-bg-primary-success',\n        WARNING: 'tide-bg-primary-warning',\n      },\n      SURFACE: {\n        ERROR: 'tide-bg-surface-error',\n        INFO: 'tide-bg-surface-info',\n        SUCCESS: 'tide-bg-surface-success',\n        WARNING: 'tide-bg-surface-warning',\n\n        BLUE: 'tide-bg-surface-blue',\n        GREEN: 'tide-bg-surface-green',\n        LIME: 'tide-bg-surface-lime',\n        ORANGE: 'tide-bg-surface-orange',\n        PURPLE: 'tide-bg-surface-purple',\n        RED: 'tide-bg-surface-red',\n        SALMON: 'tide-bg-surface-salmon',\n        TEAL: 'tide-bg-surface-teal',\n        YELLOW: 'tide-bg-surface-yellow',\n      },\n    },\n    INITIAL: 'tide-bg-initial',\n    BLUR: 'tide-bg-blur',\n    PRIMARY: 'tide-bg-primary',\n    SECONDARY: 'tide-bg-secondary',\n    SURFACE: {\n      ACCENT: 'tide-bg-surface-accent',\n      BRAND: 'tide-bg-surface-brand',\n      DEFAULT: 'tide-bg-surface',\n      FLOATING: 'tide-bg-surface-floating',\n      GRADIENT: 'tide-bg-surface-gradient',\n      VARIANT: 'tide-bg-surface-variant',\n    },\n    TRANSPARENT: {\n      ONE_HUNDRED: 'tide-transparent-100',\n      TWO_HUNDRED: 'tide-transparent-200',\n      THREE_HUNDRED: 'tide-transparent-300',\n      FOUR_HUNDRED: 'tide-transparent-400',\n    },\n  },\n  BORDER: {\n    COLOR: {\n      GLOBAL: {\n        ERROR: 'tide-border-error',\n        INFO: 'tide-border-info',\n        SUCCESS: 'tide-border-success',\n        WARNING: 'tide-border-warning',\n\n        BLUE: 'tide-border-blue',\n        GREEN: 'tide-border-green',\n        LIME: 'tide-border-lime',\n        ORANGE: 'tide-border-orange',\n        PURPLE: 'tide-border-purple',\n        RED: 'tide-border-red',\n        SALMON: 'tide-border-salmon',\n        TEAL: 'tide-border-teal',\n        YELLOW: 'tide-border-yellow',\n      },\n      INITIAL: 'tide-border-color-initial',\n      DEFAULT: 'tide-border',\n      FLOATING: 'tide-border-floating',\n      HIGH: 'tide-border-high',\n      LOW: 'tide-border-low',\n      PRIMARY: 'tide-border-primary',\n    },\n    RADIUS: {\n      ZERO: 'tide-radius-0',\n      QUARTER: 'tide-radius-1/4',\n      HALF: 'tide-radius-1/2',\n      ONE: 'tide-radius-1',\n      FULL: 'tide-radius-full',\n    },\n    STYLE: {\n      DASHED: 'tide-border-dashed',\n      SOLID: 'tide-border-solid',\n    },\n    BOTTOM: {\n      ZERO: 'tide-border-bottom-0',\n      ONE: 'tide-border-bottom-1',\n      TWO: 'tide-border-bottom-2',\n    },\n    FULL: {\n      ZERO: 'tide-border-0',\n      ONE: 'tide-border-1',\n      TWO: 'tide-border-2',\n    },\n    LEFT: {\n      ZERO: 'tide-border-left-0',\n      ONE: 'tide-border-left-1',\n      TWO: 'tide-border-left-2',\n    },\n    RIGHT: {\n      ZERO: 'tide-border-right-0',\n      ONE: 'tide-border-right-1',\n      TWO: 'tide-border-right-2',\n    },\n    TOP: {\n      ZERO: 'tide-border-top-0',\n      ONE: 'tide-border-top-1',\n      TWO: 'tide-border-top-2',\n    },\n  },\n  BOX_SIZING: {\n    BORDER_BOX: 'tide-box-border',\n    CONTENT_BOX: 'tide-box-content',\n  },\n  BREAK_INSIDE: {\n    AVOID_COLUMN: 'tide-break-inside-avoid-column',\n  },\n  BREAK_WORD: {\n    OFF: 'tide-break-initial',\n    ON: 'tide-break-word',\n  },\n  COLUMNS: {\n    INITIAL: 'tide-columns-initial',\n    ONE: 'tide-columns-1',\n    TWO: 'tide-columns-2',\n    THREE: 'tide-columns-3',\n    FOUR: 'tide-columns-4',\n  },\n  CURSOR: {\n    NOT_ALLOWED: 'tide-cursor-not-allowed',\n    POINTER: 'tide-cursor-pointer',\n    TEXT: 'tide-cursor-text',\n  },\n  DISPLAY: {\n    BLOCK: 'tide-display-block',\n    CONTENTS: 'tide-display-contents',\n    FLEX: 'tide-display-flex',\n    GRID: 'tide-display-grid',\n    INITIAL: 'tide-display-initial',\n    INLINE: 'tide-display-inline',\n    INLINE_BLOCK: 'tide-display-inline-block',\n    INLINE_FLEX: 'tide-display-inline-flex',\n    NONE: 'tide-display-none',\n  },\n  ELLIPSIS: 'tide-ellipsis',\n  FLEX: {\n    BASIS: {\n      AUTO: 'tide-flex-basis-auto',\n      ZERO: 'tide-flex-basis-0',\n    },\n    DIRECTION: {\n      COLUMN: 'tide-flex-column',\n      COLUMN_REVERSE: 'tide-flex-column-reverse',\n      ROW: 'tide-flex-row',\n      ROW_REVERSE: 'tide-flex-row-reverse',\n    },\n    GROW: {\n      OFF: 'tide-grow-none',\n      ON: 'tide-grow',\n    },\n    SHRINK: {\n      OFF: 'tide-shrink-none',\n      ON: 'tide-shrink',\n    },\n    WRAP: 'tide-flex-wrap',\n  },\n  FONT: {\n    COLOR: {\n      GLOBAL: {\n        ERROR: 'tide-font-error',\n        INFO: 'tide-font-info',\n        SUCCESS: 'tide-font-success',\n        WARNING: 'tide-font-warning',\n\n        BLUE: 'tide-font-blue',\n        GREEN: 'tide-font-green',\n        LIME: 'tide-font-lime',\n        ORANGE: 'tide-font-orange',\n        PURPLE: 'tide-font-purple',\n        RED: 'tide-font-red',\n        SALMON: 'tide-font-salmon',\n        TEAL: 'tide-font-teal',\n        YELLOW: 'tide-font-yellow',\n\n        PRIMARY: {\n          BLUE: 'tide-font-primary-blue',\n          GREEN: 'tide-font-primary-green',\n          LIME: 'tide-font-primary-lime',\n          ORANGE: 'tide-font-primary-orange',\n          PURPLE: 'tide-font-primary-purple',\n          RED: 'tide-font-primary-red',\n          SALMON: 'tide-font-primary-salmon',\n          TEAL: 'tide-font-primary-teal',\n          YELLOW: 'tide-font-primary-yellow',\n        },\n      },\n      PRIMARY: 'tide-font-on-primary',\n      SECONDARY: 'tide-font-on-secondary',\n      SURFACE: {\n        BRAND: 'tide-font-on-surface-brand',\n        DEFAULT: 'tide-font-on-surface',\n        INVERSE: 'tide-font-on-surface-inverse',\n        VARIANT: 'tide-font-on-surface-variant',\n        VARIANT_INVERSE: 'tide-font-on-surface-variant-inverse',\n      },\n    },\n    ROLE: {\n      DISPLAY_1: 'tide-typography-display-1',\n      HEADLINE_1: 'tide-typography-headline-1',\n      HEADLINE_2: 'tide-typography-headline-2',\n      HEADLINE_3: 'tide-typography-headline-3',\n      TITLE_1: 'tide-typography-title-1',\n      TITLE_2: 'tide-typography-title-2',\n      BODY_1: 'tide-typography-body-1',\n      BODY_2: 'tide-typography-body-2',\n      LABEL_1: 'tide-typography-label-1',\n      LABEL_1_SEMIBOLD: 'tide-typography-label-1-semibold',\n      LABEL_2: 'tide-typography-label-2',\n      LABEL_2_SEMIBOLD: 'tide-typography-label-2-semibold',\n      LABEL_3: 'tide-typography-label-3',\n      LINK_1: 'tide-typography-link-1',\n      LINK_2: 'tide-typography-link-2',\n      LINK_3: 'tide-typography-link-3',\n      BUTTON_1: 'tide-typography-button-1',\n      BUTTON_2: 'tide-typography-button-2',\n    },\n    SIZE: {\n      TWELVE: 'tide-font-12',\n      FOURTEEN: 'tide-font-14',\n      SIXTEEN: 'tide-font-16',\n      TWENTY: 'tide-font-20',\n      TWENTY_FOUR: 'tide-font-24',\n      THIRTY_TWO: 'tide-font-32',\n    },\n    WEIGHT: {\n      FOUR_HUNDRED: 'tide-font-400',\n      FIVE_HUNDRED: 'tide-font-500',\n      SIX_HUNDRED: 'tide-font-600',\n      SEVEN_HUNDRED: 'tide-font-700',\n    },\n  },\n  GAP: {\n    ZERO: 'tide-gap-0',\n    QUARTER: 'tide-gap-1/4',\n    HALF: 'tide-gap-1/2',\n    ONE: 'tide-gap-1',\n    TWO: 'tide-gap-2',\n    FOUR: 'tide-gap-4',\n  },\n  GRID: {\n    FLUID: 'tide-fluid',\n    ITEM: 'tide-grid-item',\n    LAYOUT: 'tide-grid-layout',\n    XL: 'tide-grid-xl',\n  },\n  HEIGHT: {\n    AUTO: 'tide-height-auto',\n    ZERO: 'tide-height-0',\n    FULL: 'tide-height-full',\n    MAX_FULL: 'tide-max-height-full',\n    MIN_ZERO: 'tide-min-height-0',\n  },\n  ISOLATION: {\n    ISOLATE: 'tide-isolate',\n  },\n  LIST_BULLETS: {\n    OFF: 'tide-list-none',\n  },\n  MARGIN: {\n    BOTTOM: {\n      AUTO: 'tide-margin-bottom-auto',\n      ZERO: 'tide-margin-bottom-0',\n      QUARTER: 'tide-margin-bottom-1/4',\n      HALF: 'tide-margin-bottom-1/2',\n      ONE: 'tide-margin-bottom-1',\n      TWO: 'tide-margin-bottom-2',\n      FOUR: 'tide-margin-bottom-4',\n    },\n    FULL: {\n      ZERO: 'tide-margin-0',\n      QUARTER: 'tide-margin-1/4',\n      HALF: 'tide-margin-1/2',\n      ONE: 'tide-margin-1',\n      TWO: 'tide-margin-2',\n      FOUR: 'tide-margin-4',\n    },\n    LEFT: {\n      AUTO: 'tide-margin-left-auto',\n      ZERO: 'tide-margin-left-0',\n      QUARTER: 'tide-margin-left-1/4',\n      HALF: 'tide-margin-left-1/2',\n      ONE: 'tide-margin-left-1',\n      TWO: 'tide-margin-left-2',\n      FOUR: 'tide-margin-left-4',\n    },\n    RIGHT: {\n      AUTO: 'tide-margin-right-auto',\n      ZERO: 'tide-margin-right-0',\n      QUARTER: 'tide-margin-right-1/4',\n      HALF: 'tide-margin-right-1/2',\n      ONE: 'tide-margin-right-1',\n      TWO: 'tide-margin-right-2',\n      FOUR: 'tide-margin-right-4',\n    },\n    TOP: {\n      AUTO: 'tide-margin-top-auto',\n      ZERO: 'tide-margin-top-0',\n      QUARTER: 'tide-margin-top-1/4',\n      HALF: 'tide-margin-top-1/2',\n      ONE: 'tide-margin-top-1',\n      TWO: 'tide-margin-top-2',\n      FOUR: 'tide-margin-top-4',\n    },\n    X: {\n      AUTO: 'tide-margin-x-auto',\n      ZERO: 'tide-margin-x-0',\n      QUARTER: 'tide-margin-x-1/4',\n      HALF: 'tide-margin-x-1/2',\n      ONE: 'tide-margin-x-1',\n      TWO: 'tide-margin-x-2',\n      FOUR: 'tide-margin-x-4',\n    },\n    Y: {\n      ZERO: 'tide-margin-y-0',\n      QUARTER: 'tide-margin-y-1/4',\n      HALF: 'tide-margin-y-1/2',\n      ONE: 'tide-margin-y-1',\n      TWO: 'tide-margin-y-2',\n      FOUR: 'tide-margin-y-4',\n    },\n  },\n  OBJECT: {\n    CENTER: 'tide-object-center',\n    CONTAIN: 'tide-object-contain',\n    COVER: 'tide-object-cover',\n    SCALE_DOWN: 'tide-object-scale-down',\n  },\n  OPACITY: {\n    DISABLED: 'tide-opacity-disabled',\n    OFF: 'tide-opacity-none',\n    ON: 'tide-opacity',\n  },\n  OVERFLOW: {\n    X: {\n      AUTO: 'tide-x-auto',\n      HIDDEN: 'tide-x-hidden',\n      SCROLL: 'tide-x-scroll',\n    },\n    XY: {\n      AUTO: 'tide-xy-auto',\n      HIDDEN: 'tide-xy-hidden',\n    },\n    Y: {\n      AUTO: 'tide-y-auto',\n      HIDDEN: 'tide-y-hidden',\n    },\n  },\n  PADDING: {\n    BOTTOM: {\n      ZERO: 'tide-padding-bottom-0',\n      QUARTER: 'tide-padding-bottom-1/4',\n      HALF: 'tide-padding-bottom-1/2',\n      ONE: 'tide-padding-bottom-1',\n      TWO: 'tide-padding-bottom-2',\n      FOUR: 'tide-padding-bottom-4',\n    },\n    FULL: {\n      ZERO: 'tide-padding-0',\n      QUARTER: 'tide-padding-1/4',\n      HALF: 'tide-padding-1/2',\n      ONE: 'tide-padding-1',\n      TWO: 'tide-padding-2',\n      FOUR: 'tide-padding-4',\n    },\n    LEFT: {\n      ZERO: 'tide-padding-left-0',\n      QUARTER: 'tide-padding-left-1/4',\n      HALF: 'tide-padding-left-1/2',\n      ONE: 'tide-padding-left-1',\n      TWO: 'tide-padding-left-2',\n      FOUR: 'tide-padding-left-4',\n    },\n    RIGHT: {\n      ZERO: 'tide-padding-right-0',\n      QUARTER: 'tide-padding-right-1/4',\n      HALF: 'tide-padding-right-1/2',\n      ONE: 'tide-padding-right-1',\n      TWO: 'tide-padding-right-2',\n      FOUR: 'tide-padding-right-4',\n    },\n    TOP: {\n      ZERO: 'tide-padding-top-0',\n      QUARTER: 'tide-padding-top-1/4',\n      HALF: 'tide-padding-top-1/2',\n      ONE: 'tide-padding-top-1',\n      TWO: 'tide-padding-top-2',\n      FOUR: 'tide-padding-top-4',\n    },\n    X: {\n      ZERO: 'tide-padding-x-0',\n      QUARTER: 'tide-padding-x-1/4',\n      HALF: 'tide-padding-x-1/2',\n      ONE: 'tide-padding-x-1',\n      TWO: 'tide-padding-x-2',\n      FOUR: 'tide-padding-x-4',\n    },\n    Y: {\n      ZERO: 'tide-padding-y-0',\n      QUARTER: 'tide-padding-y-1/4',\n      HALF: 'tide-padding-y-1/2',\n      ONE: 'tide-padding-y-1',\n      TWO: 'tide-padding-y-2',\n      FOUR: 'tide-padding-y-4',\n    },\n  },\n  POINTER_EVENTS: {\n    OFF: 'tide-pointer-events-none',\n    ON: 'tide-pointer-events',\n  },\n  POSITION: {\n    ABSOLUTE: 'tide-position-absolute',\n    FIXED: 'tide-position-fixed',\n    RELATIVE: 'tide-position-relative',\n    STATIC: 'tide-position-static',\n    STICKY: 'tide-position-sticky',\n  },\n  POSITIONING: {\n    BOTTOM: 'tide-bottom-0',\n    LEFT: 'tide-left-0',\n    RIGHT: 'tide-right-0',\n    TOP: 'tide-top-0',\n  },\n  RATIO: {\n    ONE_TO_ONE: 'tide-ratio-1/1',\n    SIXTEEN_TO_NINE: 'tide-ratio-16/9',\n    THREE_TO_TWO: 'tide-ratio-3/2',\n  },\n  SCROLLBAR: {\n    OFF: 'tide-scrollbar-none',\n  },\n  SHADOW: {\n    INITIAL: 'tide-shadow-initial',\n    BOTTOM: 'tide-shadow-bottom',\n    TOP: 'tide-shadow-top',\n    TEXT: 'tide-shadow-text',\n  },\n  SNAP: {\n    ON: 'tide-scroll-snap',\n  },\n  SNAP_ALIGN: {\n    START: 'tide-scroll-snap-start',\n  },\n  STRIKETHROUGH: {\n    OFF: 'tide-strikethrough-none',\n    ON: 'tide-strikethrough',\n  },\n  TEXT_TRANSFORM: {\n    LOWER: 'tide-text-transform-lower',\n    NONE: 'tide-text-transform-none',\n    UPPER: 'tide-text-transform-upper',\n  },\n  UNDERLINE: {\n    HOVER: {\n      ON: 'tide-underline-hover',\n      OFF: 'tide-underline-hover-none',\n    },\n    REST: {\n      ON: 'tide-underline',\n      OFF: 'tide-underline-none',\n    },\n  },\n  USER_SELECT: {\n    INITIAL: 'tide-user-select-initial',\n    NONE: 'tide-user-select-none',\n  },\n  VISIBILITY: {\n    OFF: 'tide-visible-none',\n    ON: 'tide-visible',\n  },\n  WHITESPACE_WRAP: {\n    OFF: 'tide-whitespace-nowrap',\n  },\n  WIDTH: {\n    AUTO: 'tide-width-auto',\n    ZERO: 'tide-width-0',\n    FULL: 'tide-width-full',\n    MAX_FULL: 'tide-max-width-full',\n    MIN_ZERO: 'tide-min-width-0',\n  },\n  Z_INDEX: {\n    INITIAL: 'tide-z-index-initial',\n    ONE: 'tide-z-index-1',\n  },\n} as const;\n","<script lang=\"ts\" setup>\n  import { ORIENTATION } from '@/types/Orientation';\n  import { CSS } from '@/types/Styles';\n\n  import type { Orientation } from '@/types/Orientation';\n\n  type Props = {\n    orientation?: Orientation;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    orientation: ORIENTATION.HORIZONTAL,\n  });\n</script>\n\n<template>\n  <div :class=\"['tide-divider']\">\n    <div\n      :class=\"[\n        CSS.BORDER.COLOR.LOW,\n        props.orientation === ORIENTATION.HORIZONTAL\n          ? [CSS.MARGIN.Y.HALF, CSS.BORDER.BOTTOM.ONE, CSS.WIDTH.FULL]\n          : [CSS.MARGIN.X.HALF, CSS.BORDER.RIGHT.ONE, CSS.HEIGHT.FULL],\n      ]\"\n    />\n  </div>\n</template>\n\n<style scoped>\n  .tide-divider {\n    align-self: stretch;\n  }\n</style>\n","export const REALM = {\n  AERO: 'aero',\n  ATV: 'atv',\n  BOATMART: 'boatmart',\n  CYCLE: 'cycle',\n  EQUIPMENT: 'equipment',\n  PWC: 'pwc',\n  RV: 'rv',\n  SNOW: 'snow',\n  TRUCK: 'truck',\n} as const;\n\nexport type RealmKey = keyof typeof REALM;\nexport type Realm = (typeof REALM)[RealmKey];\n","export const SIZE = {\n  LARGE: 'large',\n  SMALL: 'small',\n} as const;\n\nexport type Size = (typeof SIZE)[keyof typeof SIZE];\n\nexport const SIZE_BUTTON = {\n  LARGE: 'large',\n  SMALL: 'small',\n} as const;\n\nexport type SizeButton = (typeof SIZE)[keyof typeof SIZE];\n","const capitalizeFirst = (string: string) => {\n  return string.charAt(0).toUpperCase() + string.slice(1);\n};\n\nconst formatCamelCase = (input: string): string => {\n  return input && typeof input === 'string'\n    ? input\n        .replace(/^[\\s_-]/, '')\n        .replace(/([a-z]{1})([A-Z]{1})/g, '$1 $2')\n        .replace(/[\\s_-]/g, ' ')\n        .toLowerCase()\n        .split(' ')\n        .map((word, index) => (index === 0 ? word : word.slice(0, 1).toUpperCase() + word.slice(1)))\n        .join('')\n    : input;\n};\n\nconst formatKebabCase = (input: string): string => {\n  return input && typeof input === 'string'\n    ? input\n        .replace(/([a-z]{1})([A-Z]{1})/g, '$1 $2')\n        .toLowerCase()\n        .replace(/[\\s_-]/g, '-')\n    : input;\n};\n\nconst formatLabel = (value: string) => {\n  const labelMap: { [key: string]: string } = {\n    false: 'No',\n    true: 'Yes',\n  };\n  return Object.hasOwn(labelMap, value) ? labelMap[value] : value;\n};\n\nconst formatNumber = (input: number | string): string => {\n  let output = input && typeof input === 'number' ? new Intl.NumberFormat().format(input) : String(input || '');\n  let digits = output;\n\n  if (input && typeof input === 'string') {\n    digits = digits.replace(/\\D/g, '');\n    if (Number(digits)) {\n      output = new Intl.NumberFormat().format(Number(digits));\n    } else {\n      output = '0';\n    }\n  }\n\n  return output;\n};\n\nconst formatPascalCase = (input: string): string => {\n  return input && typeof input === 'string'\n    ? input\n        .replace(/([a-z]{1})([A-Z]{1})/g, '$1 $2')\n        .replace(/[\\s_-]/g, ' ')\n        .toLowerCase()\n        .split(' ')\n        .map((word) => word.slice(0, 1).toUpperCase() + word.slice(1))\n        .join('')\n    : input;\n};\n\nconst formatPhone = (input: number | string): string => {\n  let output = input && typeof input === 'number' ? String(input) : String(input || '');\n  let digits = output;\n  digits = digits.replace(/\\D/g, '');\n\n  switch (digits.length) {\n    case 7:\n      output = `${digits.slice(0, 3)}-${digits.slice(3)}`;\n      break;\n    case 10:\n      output = `${digits.slice(0, 3)}-${digits.slice(3, 6)}-${digits.slice(6)}`;\n      break;\n    case 11:\n      output = `${digits.slice(0, 1)}-${digits.slice(1, 4)}-${digits.slice(4, 7)}-${digits.slice(7)}`;\n      break;\n    default:\n      output = digits;\n      break;\n  }\n\n  return output;\n};\n\nconst formatPrice = (input: number | string): string => {\n  const output = input ? formatNumber(input) : String(input || '0');\n  return `$${output}`;\n};\n\nconst formatQuotes = (value: string) => {\n  if (value.startsWith('\"') && value.endsWith('\"')) {\n    return value.slice(1, -1);\n  } else {\n    return value;\n  }\n};\n\nconst formatSentenceCase = (input: string): string => {\n  let sentenceCase = input;\n\n  if (input && typeof input === 'string') {\n    const lowerCase = input\n      .replace(/([a-z]{1})([A-Z]{1})/g, '$1 $2')\n      .toLowerCase()\n      .replace(/[\\s_-]/g, ' ');\n\n    sentenceCase = lowerCase.slice(0, 1).toUpperCase() + lowerCase.slice(1);\n  }\n\n  return sentenceCase;\n};\n\nconst formatSnakeCase = (input: string): string => {\n  return input && typeof input === 'string'\n    ? input\n        .replace(/([a-z]{1})([A-Z]{1})/g, '$1 $2')\n        .toLowerCase()\n        .replace(/[\\s_-]/g, '_')\n    : input;\n};\n\nconst formatTitleCase = (input: string): string => {\n  return input && typeof input === 'string'\n    ? input\n        .replace(/([a-z]{1})([A-Z]{1})/g, '$1 $2')\n        .toLowerCase()\n        .replace(/[\\s_-]/g, ' ')\n        .split(' ')\n        .map((word) => word.slice(0, 1).toUpperCase() + word.slice(1))\n        .join(' ')\n    : input;\n};\n\nconst formatUrlFromRoot = (url: string) => {\n  const urlFormatted = url.split('.com/');\n\n  return urlFormatted.length > 1 ? `/${urlFormatted[1]}` : url;\n};\n\nconst formatWeight = (input: number | string): string => {\n  const output = input ? formatNumber(input) : String(input || '0');\n  return `${output} lbs`;\n};\n\nconst getArticle = (noun: string, isPlural = false, isDefinite = false) => {\n  const vowels = ['a', 'e', 'i', 'o', 'u'];\n  const isVowelLeading = vowels.includes(noun.charAt(0));\n\n  return isDefinite ? 'the' : isPlural ? 'some' : isVowelLeading ? 'an' : 'a';\n};\n\nconst priceToNumber = (value: string) => {\n  if (Number.isNaN(Number(value))) {\n    value = value.replace('$', '');\n    value = value.replace(/,/g, '');\n  }\n  return parseInt(value, 10);\n};\n\nconst unformatPrice = (input: string): string => {\n  const output = input.replace(/\\$/g, '').replace(/,/g, '');\n  return `${output}`;\n};\n\nexport {\n  capitalizeFirst,\n  formatCamelCase,\n  formatKebabCase,\n  formatLabel,\n  formatNumber,\n  formatPascalCase,\n  formatPhone,\n  formatPrice,\n  formatQuotes,\n  formatSentenceCase,\n  formatSnakeCase,\n  formatTitleCase,\n  formatUrlFromRoot,\n  formatWeight,\n  getArticle,\n  priceToNumber,\n  unformatPrice,\n};\n","<script lang=\"ts\" setup>\n  import { defineAsyncComponent, markRaw, ref, watch } from 'vue';\n\n  import { REALM } from '@/types/Realm';\n  import { SIZE } from '@/types/Size';\n  import { CSS } from '@/types/Styles';\n  import { formatPascalCase } from '@/utilities/format';\n\n  import type { Icon } from '@/types/Icon';\n  import type { Size } from '@/types/Size';\n  import type { Component } from 'vue';\n\n  type Props = {\n    icon: Icon;\n    size?: Size;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    size: SIZE.SMALL,\n  });\n\n  const innerSVG = ref<Component>();\n\n  watch(\n    () => props.icon,\n    async () => {\n      const id: string = props.icon;\n      const name = formatPascalCase(id);\n      const [prefix] = id.split('-');\n      const realmFolder = REALM[prefix?.toUpperCase() as keyof typeof REALM];\n      const component = defineAsyncComponent(() => {\n        if (realmFolder) {\n          return import(`../assets/svg/icons/realm/${realmFolder}/Icon${name}.svg?component`);\n        }\n\n        return import(`../assets/svg/icons/Icon${name}.svg?component`);\n      });\n\n      innerSVG.value = markRaw(component);\n    },\n    { immediate: true }\n  );\n</script>\n\n<template>\n  <div :class=\"['tide-icon', props.size]\">\n    <Component\n      :class=\"[CSS.DISPLAY.BLOCK]\"\n      :data-icon=\"icon\"\n      fill=\"currentColor\"\n      :is=\"innerSVG\"\n      v-if=\"innerSVG\"\n    />\n  </div>\n</template>\n\n<style>\n  .tide-icon {\n    width: 1.5rem;\n    height: 1.5rem;\n  }\n\n  .tide-icon.small {\n    width: 1.25rem;\n    height: 1.25rem;\n  }\n\n  .tide-icon svg {\n    width: 100%;\n    height: 100%;\n  }\n</style>\n","import type { RealmKey } from '@/types/Realm';\n\nexport const ICON = {\n  ACCOUNT_BALANCE: 'account-balance',\n  ACUTE: 'acute',\n  ADD: 'add',\n  AI_DESCRIPTION: 'ai-description',\n  ALIGN_SPACE_EVEN: 'align-space-even',\n  APPLE_PAY: 'apple-pay',\n  ARROW_BACK: 'arrow-back',\n  ARROW_CYCLE: 'arrow-cycle',\n  ARROW_FORWARD: 'arrow-forward',\n  ARROW_RIGHT: 'arrow-right',\n  ASSIGNMENT: 'assignment',\n  ATTACH_MONEY: 'attach-money',\n  AUTO_RENEW: 'auto-renew',\n  AWARD_STAR: 'award-star',\n  BED: 'bed',\n  BOLT: 'bolt',\n  BOOKMARK: 'bookmark',\n  BUNKHOUSE: 'bunkhouse',\n  CALENDAR_MONTH: 'calendar-month',\n  CALL: 'call',\n  CALL_QUALITY: 'call-quality',\n  CAR_RENTAL: 'car-rental',\n  CHECK: 'check',\n  CHEVRON_LEFT: 'chevron-left',\n  CHEVRON_RIGHT: 'chevron-right',\n  CLEAR: 'clear',\n  CLOSE: 'close',\n  CONTRACT: 'contract',\n  CRASH: 'crash',\n  DASHBOARD_CUSTOMIZE: 'dashboard-customize',\n  DELETE: 'delete',\n  DIAMOND: 'diamond',\n  DIRECTIONS_BOAT: 'directions-boat',\n  DOMAIN: 'domain',\n  DRAFT: 'draft',\n  EDIT: 'edit',\n  ENGINE: 'engine',\n  ENGINEERING: 'engineering',\n  ERROR: 'error',\n  EXPAND_CONTENT: 'expand-content',\n  EXPAND_LESS: 'expand-less',\n  EXPAND_MORE: 'expand-more',\n  FACEBOOK: 'facebook',\n  FAVORITE: 'favorite',\n  FAVORITE_FILLED: 'favorite-filled',\n  FLAG: 'flag',\n  FORMAT_BOLD: 'format-bold',\n  FORMAT_ITALIC: 'format-italic',\n  FORMAT_LIST_BULLETED: 'format-list-bulleted',\n  FORUM: 'forum',\n  GAS: 'gas',\n  GAVEL: 'gavel',\n  GEARS: 'gears',\n  GLOBE_LOCATION_PIN: 'globe-location-pin',\n  GOOGLE: 'google',\n  GOOGLE_PAY: 'google-pay',\n  GRID: 'grid',\n  HANDSHAKE: 'handshake',\n  HANDYMAN: 'handyman',\n  HEIGHT: 'height',\n  HELP: 'help',\n  INFO: 'info',\n  INFORMATION: 'information',\n  INSERT_TEXT: 'insert-text',\n  INSTAGRAM: 'instagram',\n  IOS_SHARE: 'ios-share',\n  LAYOUT: 'layout',\n  LEVELLING_JACK: 'levelling-jack',\n  LINKED_IN: 'linked in',\n  LOCAL_SHIPPING: 'local-shipping',\n  LOCK: 'lock',\n  MAIL: 'mail',\n  MENU: 'menu',\n  MONEY_BAG: 'money-bag',\n  MORE_HORIZ: 'more-horiz',\n  NOTIFICATIONS: 'notifications',\n  ODOMETER: 'odometer',\n  OPEN_IN_NEW: 'open-in-new',\n  PALETTE: 'palette',\n  PAYPAL: 'paypal',\n  PERSON: 'person',\n  PERSON_SEARCH: 'person-search',\n  PHOTO_CAMERA: 'photo-camera',\n  PINTEREST: 'pinterest',\n  PLAY_ARROW: 'play-arrow',\n  POLICY: 'policy',\n  POWER: 'power',\n  POWER_OFF: 'power-off',\n  PRIORITY_HIGH: 'priority-high',\n  REMOVE: 'remove',\n  REQUEST_QUOTE: 'request-quote',\n  RESET_WRENCH: 'reset-wrench',\n  ROAD: 'road',\n  ROUNDED_CORNER: 'rounded-corner',\n  RULER: 'ruler',\n  SAILING: 'sailing',\n  SCHOOL: 'school',\n  SEARCH: 'search',\n  SEATING: 'seating',\n  SELL: 'sell',\n  SENSORS: 'sensors',\n  SETTINGS: 'settings',\n  SHARE: 'share',\n  SHIELD_CHECK: 'shield-check',\n  SHOPPING_CART: 'shopping-cart',\n  SLEEPS: 'sleeps',\n  SMS: 'sms',\n  SNOWFLAKE: 'snowflake',\n  STAR: 'star',\n  SUMMARIZE: 'summarize',\n  SWAP_HORIZ: 'swap-horiz',\n  SWAP_VERT: 'swap-vert',\n  THREE_D_ROTATION: 'three-d-rotation',\n  THUMB_UP: 'thumb-up',\n  TRENDING_DOWN: 'trending-down',\n  TROPHY: 'trophy',\n  TUNE: 'tune',\n  TWITTER: 'twitter',\n  UMBRELLA: 'umbrella',\n  VERIFIED: 'verified',\n  VIDEOCAM: 'videocam',\n  VIEW_IN_AR: 'view-in-ar',\n  VISIBILITY: 'visibility',\n  VOLUME_OFF: 'volume-off',\n  VOLUME_ON: 'volume-on',\n  WAREHOUSE: 'warehouse',\n  WARNING: 'warning',\n  WATER: 'water',\n  WEIGHT: 'weight',\n  WIDTH: 'width',\n  WORKSPACE_PREMIUM: 'workspace-premium',\n  WRENCH: 'wrench',\n  YOUTUBE: 'youtube',\n} as const;\n\nexport const ICON_REALM = {\n  ATV: {\n    ATV: 'atv-atv',\n    DUNE_BUGGY: 'atv-dune-buggy',\n    GOLF_CART: 'atv-golf-cart',\n    GO_KART: 'atv-go-kart',\n    SAND_RAIL: 'atv-sand-rail',\n    SIDE_BY_SIDE: 'atv-side-by-side',\n    TRAILER: 'atv-trailer',\n  },\n  BOATMART: {\n    PWC: 'boatmart-pwc',\n    TRAILER: 'boatmart-trailer',\n  },\n  RV: {\n    CLASS_A: 'rv-class-a',\n    CLASS_B: 'rv-class-b',\n    CLASS_C: 'rv-class-c',\n    FIFTH_WHEEL: 'rv-fifth-wheel',\n    FISH_HOUSE: 'rv-fish-house',\n    PARK_MODEL: 'rv-park-model',\n    POP_UP_CAMPER: 'rv-pop-up-camper',\n    TRAVEL_TRAILER: 'rv-travel-trailer',\n    TRUCK_CAMPER: 'rv-truck-camper',\n  },\n} as const;\n\ntype RealmKeysWithIcons = Extract<RealmKey, keyof typeof ICON_REALM>;\ntype RealmIcon = {\n  [RealmKey in RealmKeysWithIcons]: (typeof ICON_REALM)[RealmKey][keyof (typeof ICON_REALM)[RealmKey]];\n}[RealmKeysWithIcons];\n\nexport type GlobalIcon = (typeof ICON)[keyof typeof ICON];\nexport type Icon = GlobalIcon | RealmIcon;\n","<script lang=\"ts\" setup>\n  import TideDivider from '@/components/TideDivider.vue';\n  import TideIcon from '@/components/TideIcon.vue';\n  import { ICON } from '@/types/Icon';\n  import { SIZE } from '@/types/Size';\n  import { CSS } from '@/types/Styles';\n\n  const emit = defineEmits(['toggle']);\n\n  type Props = {\n    hasBottomDivider?: boolean;\n    hasTopDivider?: boolean;\n    isExpanded?: boolean;\n    isOptional?: boolean;\n    label: string;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    hasBottomDivider: false,\n    hasTopDivider: false,\n    isExpanded: false,\n    isOptional: false,\n    label: '',\n  });\n\n  const handleToggleClick = () => {\n    emit('toggle');\n  };\n</script>\n\n<template>\n  <div class=\"tide-accordion-item\">\n    <TideDivider v-if=\"props.hasTopDivider\" />\n\n    <div\n      :class=\"['tide-accordion-head', CSS.DISPLAY.FLEX, CSS.AXIS1.BETWEEN, CSS.PADDING.Y.HALF, CSS.CURSOR.POINTER]\"\n      @click=\"handleToggleClick\"\n    >\n      <div :class=\"[CSS.DISPLAY.FLEX, CSS.AXIS2.CENTER, CSS.GAP.HALF, CSS.FONT.ROLE.LABEL_1_SEMIBOLD]\">\n        <span>{{ props.label }}</span>\n\n        <span\n          :class=\"[CSS.FONT.COLOR.SURFACE.VARIANT]\"\n          v-if=\"props.isOptional\"\n        >\n          (optional)\n        </span>\n      </div>\n\n      <TideIcon\n        :icon=\"isExpanded ? ICON.EXPAND_LESS : ICON.EXPAND_MORE\"\n        :size=\"SIZE.LARGE\"\n      />\n    </div>\n\n    <div :class=\"['tide-accordion-body', props.isExpanded ? 'expanded' : 'collapsed', CSS.DISPLAY.GRID]\">\n      <div :class=\"[CSS.OVERFLOW.Y.HIDDEN, CSS.MARGIN.Y.ONE, CSS.FONT.ROLE.BODY_1, CSS.FONT.COLOR.SURFACE.DEFAULT]\">\n        <slot />\n      </div>\n    </div>\n\n    <TideDivider v-if=\"props.hasBottomDivider\" />\n  </div>\n</template>\n\n<style scoped>\n  .tide-accordion-body {\n    transition: grid-template-rows var(--tide-animate);\n  }\n\n  .tide-accordion-body.expanded {\n    grid-template-rows: 1fr;\n  }\n\n  .tide-accordion-body.collapsed {\n    grid-template-rows: 0fr;\n  }\n</style>\n","export const ELEMENT = {\n  BUTTON: 'button',\n  LINK: 'a',\n} as const;\n\nexport const ELEMENT_TEXT_AS_ICON = {\n  BUTTON: 'button',\n  DIV: 'div',\n  LINK: 'a',\n} as const;\n\nexport type Element = (typeof ELEMENT)[keyof typeof ELEMENT];\nexport type ElementTextAsIcon = (typeof ELEMENT_TEXT_AS_ICON)[keyof typeof ELEMENT_TEXT_AS_ICON];\n","/* eslint-disable vue/sort-keys */\n\nexport const PRIORITY = {\n  PRIMARY: 'primary',\n  SECONDARY: 'secondary',\n  TERTIARY: 'tertiary',\n  QUATERNARY: 'quaternary',\n  FLOATING: 'floating',\n} as const;\n\nexport type Priority = (typeof PRIORITY)[keyof typeof PRIORITY];\n","export const TARGET = {\n  BLANK: '_blank',\n  SELF: undefined,\n} as const;\n\nexport type Target = (typeof TARGET)[keyof typeof TARGET];\n","<script lang=\"ts\" setup>\n  import TideIcon from '@/components/TideIcon.vue';\n  import { ELEMENT } from '@/types/Element';\n  import { PRIORITY } from '@/types/Priority';\n  import { SIZE } from '@/types/Size';\n  import { CSS } from '@/types/Styles';\n  import { TARGET } from '@/types/Target';\n\n  import type { Element } from '@/types/Element';\n  import type { Icon } from '@/types/Icon';\n  import type { Priority } from '@/types/Priority';\n\n  type Props = {\n    disabled?: boolean;\n    element?: Element;\n    href?: string;\n    icon: Icon;\n    isNewTab?: boolean;\n    priority?: Priority;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    disabled: false,\n    element: ELEMENT.BUTTON,\n    href: undefined,\n    icon: undefined,\n    isNewTab: false,\n    priority: PRIORITY.PRIMARY,\n  });\n</script>\n\n<template>\n  <component\n    :aria-label=\"props.icon\"\n    :class=\"[\n      props.element === ELEMENT.LINK ? 'tide-link-as-button-icon' : 'tide-button-icon',\n      props.priority && `tide-button-${props.priority}`,\n      [CSS.DISPLAY.FLEX, CSS.AXIS1.CENTER, CSS.AXIS2.CENTER, CSS.BORDER.RADIUS.FULL, CSS.PADDING.FULL.HALF],\n      props.element === ELEMENT.LINK ? [CSS.UNDERLINE.REST.OFF] : '',\n    ]\"\n    :disabled=\"props.element === ELEMENT.BUTTON && props.disabled\"\n    :href=\"props.element === ELEMENT.LINK && props.href ? props.href : undefined\"\n    :target=\"props.element === ELEMENT.LINK && props.isNewTab ? TARGET.BLANK : TARGET.SELF\"\n    :is=\"props.element === ELEMENT.LINK ? 'a' : 'button'\"\n  >\n    <TideIcon\n      :icon=\"props.icon\"\n      :size=\"SIZE.LARGE\"\n      v-if=\"props.icon\"\n    />\n  </component>\n</template>\n","export const ALERT = {\n  ERROR: 'error',\n  INFO: 'info',\n  SUCCESS: 'success',\n  WARNING: 'warning',\n} as const;\n\nexport type Alert = (typeof ALERT)[keyof typeof ALERT];\n","<script lang=\"ts\" setup>\n  import { computed } from 'vue';\n\n  import TideButtonIcon from '@/components/TideButtonIcon.vue';\n  import TideIcon from '@/components/TideIcon.vue';\n  import { ALERT } from '@/types/Alert';\n  import { ICON } from '@/types/Icon';\n  import { PRIORITY } from '@/types/Priority';\n  import { SIZE } from '@/types/Size';\n  import { CSS } from '@/types/Styles';\n\n  import type { Alert } from '@/types/Alert';\n\n  type Props = {\n    heading?: string;\n    isDismissible?: boolean;\n    isToast?: boolean;\n    type?: Alert;\n  };\n\n  type Emits = {\n    (event: 'close'): void;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    heading: undefined,\n    isDismissible: true,\n    isToast: false,\n    type: ALERT.INFO,\n  });\n\n  const emit = defineEmits<Emits>();\n\n  const iconType = computed(() => {\n    if (props.type === ALERT.ERROR) return ICON.PRIORITY_HIGH;\n    if (props.type === ALERT.SUCCESS) return ICON.CHECK;\n    if (props.type === ALERT.WARNING) return ICON.WARNING;\n    return ICON.INFORMATION;\n  });\n</script>\n\n<template>\n  <div\n    :class=\"[\n      props.type,\n      'tide-alert',\n      CSS.DISPLAY.GRID,\n      CSS.AXIS2.CENTER,\n      CSS.BORDER.RADIUS.HALF,\n      CSS.PADDING.FULL.ONE,\n      !props.isToast && props.type === ALERT.ERROR ? [CSS.BG.GLOBAL.SURFACE.ERROR, CSS.BORDER.COLOR.GLOBAL.ERROR] : '',\n      !props.isToast && props.type === ALERT.INFO ? [CSS.BG.GLOBAL.SURFACE.INFO, CSS.BORDER.COLOR.GLOBAL.INFO] : '',\n      !props.isToast && props.type === ALERT.SUCCESS\n        ? [CSS.BG.GLOBAL.SURFACE.SUCCESS, CSS.BORDER.COLOR.GLOBAL.SUCCESS]\n        : '',\n      !props.isToast && props.type === ALERT.WARNING\n        ? [CSS.BG.GLOBAL.SURFACE.WARNING, CSS.BORDER.COLOR.GLOBAL.WARNING]\n        : '',\n      props.isToast ? [CSS.BG.SECONDARY, CSS.FONT.COLOR.SECONDARY, CSS.SHADOW.BOTTOM] : CSS.BORDER.LEFT.TWO,\n    ]\"\n  >\n    <div\n      :class=\"[\n        'tide-alert-icon',\n        CSS.PADDING.FULL.QUARTER,\n        CSS.BORDER.RADIUS.FULL,\n        CSS.FONT.COLOR.SURFACE.INVERSE,\n        props.type === ALERT.ERROR && CSS.BG.GLOBAL.PRIMARY.ERROR,\n        props.type === ALERT.INFO && CSS.BG.GLOBAL.PRIMARY.INFO,\n        props.type === ALERT.SUCCESS && CSS.BG.GLOBAL.PRIMARY.SUCCESS,\n        props.type === ALERT.WARNING && CSS.BG.GLOBAL.PRIMARY.WARNING,\n      ]\"\n      v-if=\"!props.isToast\"\n    >\n      <TideIcon\n        :icon=\"iconType\"\n        :size=\"SIZE.SMALL\"\n      />\n    </div>\n\n    <div :class=\"['tide-alert-heading', CSS.DISPLAY.FLEX, CSS.AXIS2.CENTER, CSS.FONT.ROLE.LABEL_1_SEMIBOLD]\">\n      {{ props.heading }}\n    </div>\n\n    <TideButtonIcon\n      :class=\"['tide-alert-close', CSS.AXIS2.CENTER, CSS.FONT.COLOR.SURFACE.DEFAULT]\"\n      :icon=\"ICON.CLOSE\"\n      :priority=\"PRIORITY.QUATERNARY\"\n      @click=\"emit('close')\"\n      aria-label=\"Close alert\"\n      v-if=\"isDismissible\"\n    />\n\n    <div :class=\"['tide-alert-body', CSS.FONT.ROLE.BODY_2, !props.isToast && CSS.FONT.COLOR.SURFACE.DEFAULT]\">\n      <slot />\n    </div>\n  </div>\n</template>\n\n<style scoped>\n  .tide-alert {\n    grid-template-areas:\n      'icon heading close'\n      '. body .';\n    grid-template-columns: auto 1fr auto;\n    grid-column-gap: 0.5rem;\n    max-width: 40rem;\n  }\n\n  .tide-alert-icon {\n    grid-area: icon;\n  }\n\n  .tide-alert-heading {\n    grid-area: heading;\n  }\n\n  .tide-alert-close {\n    grid-area: close;\n  }\n\n  .tide-alert-body {\n    grid-area: body;\n  }\n</style>\n","import { CSS } from '@/types/Styles';\n\nexport const BADGE_COLOR = {\n  BLACK: 'black',\n  BLUE: 'blue',\n  GREEN: 'green',\n  LIME: 'lime',\n  ORANGE: 'orange',\n  PURPLE: 'purple',\n  RED: 'red',\n  SALMON: 'salmon',\n  TEAL: 'teal',\n  YELLOW: 'yellow',\n} as const;\n\nexport const BADGE_COLOR_DETAILS: Record<\n  BadgeColor,\n  {\n    borderColor: string;\n    iconColor: string;\n  }\n> = {\n  [BADGE_COLOR.BLACK]: {\n    borderColor: CSS.BORDER.COLOR.HIGH,\n    iconColor: CSS.FONT.COLOR.SURFACE.DEFAULT,\n  },\n  [BADGE_COLOR.BLUE]: {\n    borderColor: CSS.BORDER.COLOR.GLOBAL.BLUE,\n    iconColor: CSS.FONT.COLOR.GLOBAL.PRIMARY.BLUE,\n  },\n  [BADGE_COLOR.GREEN]: {\n    borderColor: CSS.BORDER.COLOR.GLOBAL.GREEN,\n    iconColor: CSS.FONT.COLOR.GLOBAL.PRIMARY.GREEN,\n  },\n  [BADGE_COLOR.LIME]: {\n    borderColor: CSS.BORDER.COLOR.GLOBAL.LIME,\n    iconColor: CSS.FONT.COLOR.GLOBAL.PRIMARY.LIME,\n  },\n  [BADGE_COLOR.ORANGE]: {\n    borderColor: CSS.BORDER.COLOR.GLOBAL.ORANGE,\n    iconColor: CSS.FONT.COLOR.GLOBAL.PRIMARY.ORANGE,\n  },\n  [BADGE_COLOR.PURPLE]: {\n    borderColor: CSS.BORDER.COLOR.GLOBAL.PURPLE,\n    iconColor: CSS.FONT.COLOR.GLOBAL.PRIMARY.PURPLE,\n  },\n  [BADGE_COLOR.RED]: {\n    borderColor: CSS.BORDER.COLOR.GLOBAL.RED,\n    iconColor: CSS.FONT.COLOR.GLOBAL.PRIMARY.RED,\n  },\n  [BADGE_COLOR.SALMON]: {\n    borderColor: CSS.BORDER.COLOR.GLOBAL.SALMON,\n    iconColor: CSS.FONT.COLOR.GLOBAL.PRIMARY.SALMON,\n  },\n  [BADGE_COLOR.TEAL]: {\n    borderColor: CSS.BORDER.COLOR.GLOBAL.TEAL,\n    iconColor: CSS.FONT.COLOR.GLOBAL.PRIMARY.TEAL,\n  },\n  [BADGE_COLOR.YELLOW]: {\n    borderColor: CSS.BORDER.COLOR.GLOBAL.YELLOW,\n    iconColor: CSS.FONT.COLOR.GLOBAL.PRIMARY.YELLOW,\n  },\n};\n\nexport const BADGE_TRUSTED = {\n  YEARS_10: '10',\n  YEARS_15: '15',\n  YEARS_5: '5',\n} as const;\n\nexport type BadgeColor = (typeof BADGE_COLOR)[keyof typeof BADGE_COLOR];\nexport type BadgeTrustedYears = (typeof BADGE_TRUSTED)[keyof typeof BADGE_TRUSTED];\n","<script lang=\"ts\" setup>\n  import TideIcon from '@/components/TideIcon.vue';\n  import { BADGE_COLOR_DETAILS } from '@/types/Badge';\n  import { CSS } from '@/types/Styles';\n\n  import type { BadgeColor } from '@/types/Badge';\n  import type { Icon } from '@/types/Icon';\n\n  type Props = {\n    color?: BadgeColor;\n    iconLeading?: Icon;\n    isFloating?: boolean;\n    label: string;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    color: undefined,\n    iconLeading: undefined,\n    isFloating: false,\n  });\n</script>\n\n<template>\n  <div\n    :class=\"[\n      'tide-badge',\n      props.isFloating || props.color ? [CSS.BG.SURFACE.FLOATING, CSS.SHADOW.BOTTOM] : [CSS.BG.SURFACE.VARIANT],\n      CSS.DISPLAY.INLINE_FLEX,\n      CSS.AXIS2.CENTER,\n      CSS.GAP.QUARTER,\n      CSS.BORDER.RADIUS.QUARTER,\n      CSS.PADDING.Y.QUARTER,\n      CSS.PADDING.X.HALF,\n      props.color && [CSS.BORDER.LEFT.TWO, BADGE_COLOR_DETAILS[props.color].borderColor],\n      CSS.ELLIPSIS,\n      CSS.FONT.ROLE.LABEL_2,\n      CSS.WHITESPACE_WRAP.OFF,\n    ]\"\n  >\n    <TideIcon\n      :class=\"[CSS.FLEX.SHRINK.OFF, props.color && BADGE_COLOR_DETAILS[props.color].iconColor]\"\n      :icon=\"props.iconLeading\"\n      v-if=\"props.iconLeading\"\n    />\n\n    <span :class=\"[CSS.ELLIPSIS]\">{{ props.label }}</span>\n  </div>\n</template>\n","<script lang=\"ts\" setup>\n  import TideIcon from '@/components/TideIcon.vue';\n  import { BADGE_TRUSTED } from '@/types/Badge';\n  import { ICON } from '@/types/Icon';\n  import { CSS } from '@/types/Styles';\n\n  import type { BadgeTrustedYears } from '@/types/Badge';\n\n  type Props = {\n    years?: BadgeTrustedYears;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    years: BADGE_TRUSTED.YEARS_5,\n  });\n</script>\n\n<template>\n  <div\n    :class=\"[\n      'tide-badge-trusted-partner',\n      CSS.FONT.COLOR.SURFACE.BRAND,\n      CSS.DISPLAY.INLINE_FLEX,\n      CSS.AXIS2.CENTER,\n      CSS.GAP.QUARTER,\n      CSS.ELLIPSIS,\n      CSS.FONT.ROLE.LABEL_2,\n      CSS.WHITESPACE_WRAP.OFF,\n    ]\"\n  >\n    <TideIcon\n      :class=\"[CSS.FLEX.SHRINK.OFF]\"\n      :icon=\"ICON.AWARD_STAR\"\n    />\n\n    <div :class=\"[CSS.ELLIPSIS]\">\n      <span>{{ props.years }} year trusted partner</span>\n    </div>\n  </div>\n</template>\n\n<style scoped></style>\n","<script lang=\"ts\" setup>\n  import TideIcon from '@/components/TideIcon.vue';\n  import { ICON } from '@/types/Icon';\n  import { CSS } from '@/types/Styles';\n</script>\n\n<template>\n  <div\n    :class=\"[\n      'tide-badge-verified-vehicle',\n      CSS.BG.SECONDARY,\n      CSS.FONT.ROLE.LABEL_2,\n      CSS.FONT.COLOR.SECONDARY,\n      CSS.DISPLAY.INLINE_FLEX,\n      CSS.AXIS2.CENTER,\n      CSS.GAP.QUARTER,\n      CSS.BORDER.RADIUS.QUARTER,\n      CSS.PADDING.Y.QUARTER,\n      CSS.PADDING.X.HALF,\n      CSS.ELLIPSIS,\n      CSS.WHITESPACE_WRAP.OFF,\n    ]\"\n  >\n    <TideIcon\n      :class=\"[CSS.FLEX.SHRINK.OFF]\"\n      :icon=\"ICON.VERIFIED\"\n    />\n\n    <span :class=\"[CSS.ELLIPSIS]\">Verified vehicle</span>\n  </div>\n</template>\n\n<style scoped>\n  .tide-icon {\n    color: var(--tide-info-primary);\n  }\n</style>\n","<script lang=\"ts\" setup>\n  import TideIcon from '@/components/TideIcon.vue';\n  import { ICON } from '@/types/Icon';\n  import { SIZE } from '@/types/Size';\n  import { CSS } from '@/types/Styles';\n\n  import type { BreadCrumb } from '@/types/BreadCrumb';\n\n  type Props = {\n    breadCrumbs: BreadCrumb[];\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    breadCrumbs: undefined,\n  });\n</script>\n\n<template>\n  <ul :class=\"['tide-bread-crumbs', CSS.DISPLAY.FLEX, CSS.AXIS2.CENTER, CSS.GAP.QUARTER, CSS.LIST_BULLETS.OFF]\">\n    <template\n      :key=\"crumb.label\"\n      v-for=\"(crumb, index) in props.breadCrumbs\"\n    >\n      <li :class=\"[CSS.FONT.ROLE.BODY_2]\">\n        <a\n          :class=\"[CSS.FONT.ROLE.LINK_2, CSS.FONT.COLOR.SURFACE.DEFAULT]\"\n          :data-track=\"crumb.dataTrack || undefined\"\n          :href=\"crumb.url\"\n          v-if=\"crumb.url\"\n        >\n          {{ crumb.label }}\n        </a>\n\n        <span\n          :class=\"[CSS.FONT.ROLE.LABEL_2, CSS.FONT.COLOR.SURFACE.VARIANT]\"\n          :data-track=\"crumb.dataTrack || undefined\"\n          v-else\n        >\n          {{ crumb.label }}\n        </span>\n      </li>\n\n      <li v-if=\"props.breadCrumbs && index < props.breadCrumbs.length - 1\">\n        <TideIcon\n          :icon=\"ICON.ARROW_RIGHT\"\n          :size=\"SIZE.SMALL\"\n        />\n      </li>\n    </template>\n  </ul>\n</template>\n","<script lang=\"ts\" setup>\n  import TideIcon from '@/components/TideIcon.vue';\n  import { ELEMENT } from '@/types/Element';\n  import { PRIORITY } from '@/types/Priority';\n  import { SIZE, SIZE_BUTTON } from '@/types/Size';\n  import { CSS } from '@/types/Styles';\n  import { TARGET } from '@/types/Target';\n\n  import type { Element } from '@/types/Element';\n  import type { Icon } from '@/types/Icon';\n  import type { Priority } from '@/types/Priority';\n  import type { SizeButton } from '@/types/Size';\n\n  type Props = {\n    disabled?: boolean;\n    element?: Element;\n    href?: string;\n    iconLeading?: Icon;\n    iconTrailing?: Icon;\n    isNewTab?: boolean;\n    label: string;\n    priority?: Priority;\n    size?: SizeButton;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    disabled: false,\n    element: ELEMENT.BUTTON,\n    href: undefined,\n    iconLeading: undefined,\n    iconTrailing: undefined,\n    isNewTab: false,\n    label: undefined,\n    priority: PRIORITY.PRIMARY,\n    size: SIZE_BUTTON.LARGE,\n  });\n</script>\n\n<template>\n  <component\n    :class=\"[\n      'tide-button',\n      props.priority && `tide-button-${props.priority}`,\n      props.element === ELEMENT.LINK ? [CSS.DISPLAY.INLINE_FLEX] : [CSS.DISPLAY.FLEX],\n      props.element === ELEMENT.LINK ? CSS.UNDERLINE.REST.OFF : '',\n      size === SIZE_BUTTON.SMALL && [CSS.FONT.ROLE.BUTTON_2, CSS.PADDING.X.ONE, CSS.PADDING.Y.HALF],\n      size === SIZE_BUTTON.LARGE && [CSS.FONT.ROLE.BUTTON_1, CSS.PADDING.X.TWO, CSS.PADDING.Y.ONE],\n      CSS.AXIS1.CENTER,\n      CSS.AXIS2.CENTER,\n      CSS.GAP.HALF,\n      CSS.BORDER.RADIUS.HALF,\n      CSS.FONT.ROLE.LABEL_1_SEMIBOLD,\n    ]\"\n    :disabled=\"props.element === ELEMENT.BUTTON && props.disabled\"\n    :href=\"props.element === ELEMENT.LINK && props.href ? props.href : undefined\"\n    :target=\"props.element === ELEMENT.LINK && props.isNewTab ? TARGET.BLANK : TARGET.SELF\"\n    :is=\"props.element === ELEMENT.LINK ? ELEMENT.LINK : ELEMENT.BUTTON\"\n  >\n    <TideIcon\n      :icon=\"props.iconLeading\"\n      :size=\"size === SIZE_BUTTON.LARGE ? SIZE.LARGE : SIZE.SMALL\"\n      v-if=\"props.iconLeading\"\n    />\n\n    {{ props.label }}\n\n    <TideIcon\n      :icon=\"props.iconTrailing\"\n      :size=\"size === SIZE_BUTTON.LARGE ? SIZE.LARGE : SIZE.SMALL\"\n      v-if=\"props.iconTrailing\"\n    />\n  </component>\n</template>\n","<script lang=\"ts\" setup>\n  import { ELEMENT_TEXT_AS_ICON } from '@/types/Element';\n  import { CSS } from '@/types/Styles';\n\n  import type { ElementTextAsIcon } from '@/types/Element';\n\n  type Props = {\n    disabled?: boolean;\n    element?: ElementTextAsIcon;\n    href?: string;\n    label: string | number;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    disabled: false,\n    element: ELEMENT_TEXT_AS_ICON.BUTTON,\n    href: undefined,\n    label: undefined,\n  });\n</script>\n\n<template>\n  <component\n    :class=\"[\n      props.element === ELEMENT_TEXT_AS_ICON.LINK ? 'tide-link-as-button-icon' : 'tide-button-icon',\n      [CSS.DISPLAY.INLINE_BLOCK, CSS.BORDER.RADIUS.FULL, CSS.PADDING.FULL.HALF],\n      props.element === ELEMENT_TEXT_AS_ICON.LINK ? [CSS.UNDERLINE.REST.OFF] : '',\n      props.element === ELEMENT_TEXT_AS_ICON.DIV ? [CSS.CURSOR.POINTER] : '',\n      [CSS.FONT.ROLE.HEADLINE_3],\n    ]\"\n    :disabled=\"props.element === ELEMENT_TEXT_AS_ICON.BUTTON && props.disabled\"\n    :href=\"props.element === ELEMENT_TEXT_AS_ICON.LINK && props.href ? props.href : undefined\"\n    :is=\"\n      props.element === ELEMENT_TEXT_AS_ICON.LINK\n        ? 'a'\n        : props.element === ELEMENT_TEXT_AS_ICON.BUTTON\n        ? 'button'\n        : 'div'\n    \"\n  >\n    <span :class=\"['label', CSS.DISPLAY.FLEX, CSS.AXIS1.CENTER, CSS.AXIS2.CENTER]\">\n      {{ props.label }}\n    </span>\n  </component>\n</template>\n\n<style scoped>\n  .tide-button-icon,\n  .tide-link-as-button-icon {\n    border: 1px solid var(--tide-white);\n    background: var(--tide-white);\n    color: var(--tide-secondary);\n  }\n\n  .tide-button-icon:not(:disabled):hover,\n  .tide-link-as-button-icon:not(:disabled):hover {\n    border: 1px solid var(--tide-surface-variant);\n    background: var(--tide-surface-variant);\n  }\n\n  .tide-button-icon:disabled,\n  .tide-link-as-button-icon:disabled {\n    border: 1px solid var(--tide-border-high);\n  }\n\n  .tide-button-icon .label,\n  .tide-link-as-button-icon .label {\n    width: 1.5rem;\n    height: 1.5rem;\n  }\n</style>\n","<script lang=\"ts\" setup>\n  import { CSS } from '@/types/Styles';\n\n  import type { Tab } from '@/types/Tab';\n\n  type Props = {\n    activeTab: number;\n    tabs: Tab[];\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    activeTab: 0,\n  });\n\n  const emit = defineEmits(['change']);\n\n  const handleClick = (index: number) => {\n    emit('change', index);\n  };\n</script>\n\n<template>\n  <div\n    :class=\"[\n      'tide-button-segmented',\n      CSS.BG.SURFACE.VARIANT,\n      CSS.DISPLAY.FLEX,\n      CSS.GAP.QUARTER,\n      CSS.BORDER.RADIUS.FULL,\n      CSS.PADDING.FULL.QUARTER,\n      CSS.OVERFLOW.XY.HIDDEN,\n      CSS.WIDTH.FULL,\n    ]\"\n  >\n    <button\n      :class=\"[\n        'tide-button-segmented-tab',\n        index === activeTab\n          ? [CSS.BG.SURFACE.DEFAULT, CSS.FONT.COLOR.SURFACE.DEFAULT, CSS.SHADOW.BOTTOM]\n          : ['inactive', CSS.FONT.COLOR.SURFACE.VARIANT],\n        CSS.FLEX.GROW.ON,\n        CSS.BORDER.FULL.TWO,\n        CSS.BORDER.RADIUS.FULL,\n        CSS.PADDING.Y.QUARTER,\n        CSS.WIDTH.FULL,\n        CSS.FONT.ROLE.BUTTON_1,\n        CSS.WHITESPACE_WRAP.OFF,\n      ]\"\n      :data-track=\"tab.dataTrack || undefined\"\n      :key=\"tab.label\"\n      @click=\"handleClick(index)\"\n      v-for=\"(tab, index) in props.tabs\"\n    >\n      <span :class=\"[CSS.FONT.ROLE.LABEL_2_SEMIBOLD]\">\n        {{ tab.label }}\n      </span>\n\n      <span\n        :class=\"[CSS.FONT.ROLE.LABEL_2_SEMIBOLD]\"\n        v-if=\"tab.count && tab.count > 0\"\n      >\n        ({{ tab.count }})\n      </span>\n    </button>\n  </div>\n</template>\n\n<style scoped>\n  .tide-button-segmented {\n    max-width: 23.3rem;\n  }\n\n  .tide-button-segmented-tab {\n    flex: 1;\n    transition: background-color var(--tide-animate);\n  }\n\n  .inactive:not(:hover) {\n    border-color: var(--tide-surface-variant);\n  }\n\n  .inactive:hover {\n    border-color: var(--tide-border);\n    color: var(--tide-surface-default);\n  }\n</style>\n","export const TYPE_CARD = {\n  ACTIONABLE: 'action',\n  INFORMATIONAL: 'informational',\n  SELECTABLE: 'select',\n} as const;\n\nexport type CardType = (typeof TYPE_CARD)[keyof typeof TYPE_CARD];\n","<script lang=\"ts\" setup>\n  import TideIcon from '@/components/TideIcon.vue';\n  import { TYPE_CARD } from '@/types/Card';\n  import { SIZE } from '@/types/Size';\n  import { CSS } from '@/types/Styles';\n\n  import type { CardType } from '@/types/Card';\n  import type { Icon } from '@/types/Icon';\n\n  type Props = {\n    description?: string;\n    heading: string;\n    icon?: Icon;\n    selected?: boolean;\n    type?: CardType;\n    href?: string;\n  };\n\n  withDefaults(defineProps<Props>(), {\n    description: undefined,\n    href: undefined,\n    icon: undefined,\n    selected: undefined,\n    type: TYPE_CARD.INFORMATIONAL,\n  });\n</script>\n\n<template>\n  <component\n    :class=\"[\n      'tide-card',\n      CSS.BORDER.COLOR.LOW,\n      CSS.BORDER.FULL.ONE,\n      CSS.BORDER.RADIUS.HALF,\n      CSS.DISPLAY.FLEX,\n      CSS.GAP.HALF,\n      CSS.PADDING.FULL.ONE,\n      CSS.WIDTH.FULL,\n      CSS.ALIGN.X.LEFT,\n      CSS.FLEX.DIRECTION.COLUMN,\n      type !== TYPE_CARD.INFORMATIONAL && 'hoverable',\n      type === TYPE_CARD.SELECTABLE && selected && 'selected',\n    ]\"\n    :href=\"href\"\n    :is=\"href ? 'a' : type === TYPE_CARD.INFORMATIONAL ? 'div' : 'button'\"\n  >\n    <TideIcon\n      :class=\"[CSS.FLEX.GROW.OFF, CSS.FLEX.SHRINK.OFF]\"\n      :icon=\"icon\"\n      :size=\"SIZE.SMALL\"\n      v-if=\"icon\"\n    />\n\n    <div :class=\"[CSS.AXIS2.START, CSS.DISPLAY.FLEX, CSS.FLEX.DIRECTION.COLUMN, CSS.GAP.HALF]\">\n      <div :class=\"[CSS.FONT.ROLE.LABEL_1_SEMIBOLD, CSS.FONT.COLOR.SURFACE.DEFAULT]\">\n        {{ heading }}\n      </div>\n\n      <div\n        :class=\"[CSS.FONT.ROLE.LABEL_2, CSS.FONT.COLOR.SURFACE.VARIANT]\"\n        v-if=\"description\"\n      >\n        {{ description }}\n      </div>\n    </div>\n  </component>\n</template>\n\n<style scoped>\n  .tide-card.hoverable:not(.selected):hover {\n    border-color: var(--tide-border-rest);\n  }\n  .tide-card.selected {\n    outline: 2px solid var(--tide-border-high);\n    outline-offset: -2px;\n  }\n</style>\n","<script lang=\"ts\" setup>\n  import { onMounted, onUnmounted, ref } from 'vue';\n\n  import TideButtonIcon from '@/components/TideButtonIcon.vue';\n  import { ICON } from '@/types/Icon';\n  import { PRIORITY } from '@/types/Priority';\n  import { CSS } from '@/types/Styles';\n\n  type Props = {\n    bleed?: number;\n    isFloating?: boolean;\n    isHeadline1?: boolean;\n    isHideawayButtons?: boolean;\n    isScrollByPage?: boolean;\n    isTouchscreen?: boolean;\n    subtitle?: string;\n    title?: string;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    bleed: undefined,\n    isFloating: false,\n    isHeadline1: false,\n    isHideawayButtons: true,\n    isScrollByPage: true,\n    isTouchscreen: undefined,\n    subtitle: undefined,\n    title: undefined,\n  });\n\n  type Emits = {\n    (event: 'slidesAddedToView', slidesInView: number[]): void;\n  };\n\n  const emit = defineEmits<Emits>();\n\n  const containerRef = ref<HTMLDivElement | null>(null);\n  const isFirstSlide = ref<boolean>(true);\n  const isLastSlide = ref<boolean>(false);\n  const showButtons = ref<boolean>(true);\n  const slideObserver = ref<IntersectionObserver | null>(null);\n  const slidesInView = ref<number[]>([]);\n  const slotObserver = ref<MutationObserver | null>(null);\n\n  const slides = ref<HTMLElement[]>([]);\n\n  // TODO: debounce\n  const handleScroll = () => {\n    updateContainerBleed();\n  };\n\n  const observeSlides = () => {\n    const options = {\n      root: containerRef?.value,\n      rootMargin: '0px 1px 0px 0px',\n      threshold: 1,\n    };\n\n    slideObserver.value = new IntersectionObserver((entries) => {\n      let slidesAddedToView: number[] = [];\n\n      entries.forEach((entry) => {\n        const slideIndex = slides.value.indexOf(entry.target as HTMLElement);\n\n        if (entry.isIntersecting) {\n          slidesAddedToView.push(slideIndex);\n          slidesInView.value.push(slideIndex);\n        } else {\n          slidesInView.value = slidesInView.value.filter((slide) => slide !== slideIndex);\n        }\n\n        slidesInView.value.sort((a, b) => a - b);\n      });\n\n      isFirstSlide.value = slidesInView.value.includes(0);\n      isLastSlide.value = slidesInView.value.includes(slides.value.length - 1);\n\n      if (slidesAddedToView.length > 0) emit('slidesAddedToView', slidesAddedToView);\n    }, options);\n\n    slides.value.forEach((child) => {\n      if (slideObserver.value) slideObserver.value.observe(child);\n    });\n  };\n\n  const observeSlot = () => {\n    const observerCallback = () => {\n      if (containerRef.value === null) return;\n\n      slides.value = Array.from(containerRef.value.children) as HTMLElement[];\n      observeSlides();\n    };\n\n    slotObserver.value = new MutationObserver(observerCallback);\n\n    if (containerRef.value) slotObserver.value.observe(containerRef.value, { childList: true });\n  };\n\n  const scrollToOffset = (target: number) => {\n    if (containerRef.value === null) return;\n\n    containerRef.value.scrollTo({\n      behavior: 'smooth',\n      left: target,\n    });\n  };\n\n  const showNextPage = () => {\n    if (slidesInView.value.length === 0) return;\n\n    const nextSlide: number = slidesInView.value[slidesInView.value.length - 1] + 1;\n\n    scrollToOffset(slides.value[nextSlide].offsetLeft);\n  };\n\n  const showPreviousPage = () => {\n    if (slidesInView.value.length === 0) return;\n\n    const previousSlide: number = slidesInView.value[0] - slidesInView.value.length;\n\n    scrollToOffset(slides.value[previousSlide]?.offsetLeft || 0);\n  };\n\n  const showNextSlide = () => {\n    if (slidesInView.value.length === 0) return;\n\n    const nextSlide: number = slidesInView.value.length > 1 ? slidesInView.value[1] : slidesInView.value[0] + 1;\n\n    scrollToOffset(slides.value[nextSlide].offsetLeft);\n  };\n\n  const showPreviousSlide = () => {\n    if (slidesInView.value.length === 0) return;\n\n    const previousSlide: number = slidesInView.value[0] - 1;\n\n    scrollToOffset(slides.value[previousSlide].offsetLeft);\n  };\n\n  const updateContainerBleed = () => {\n    if (containerRef.value === null) return;\n    if (props.bleed == undefined) return;\n\n    if (isLastSlide.value && showButtons.value) {\n      // Prevent gradient from bleeding off left edge in last position.\n      containerRef.value.style.margin = `-${props.bleed}px -${props.bleed}px -${props.bleed}px 0`;\n      containerRef.value.style.padding = `${props.bleed}px ${props.bleed}px ${props.bleed}px 0`;\n    } else {\n      // Prevent gradient from bleeding off right edge in first position.\n      containerRef.value.style.margin = `-${props.bleed}px 0 -${props.bleed}px -${props.bleed}px`;\n      containerRef.value.style.padding = `${props.bleed}px 0 ${props.bleed}px ${props.bleed}px`;\n    }\n  };\n\n  onMounted(() => {\n    if (containerRef.value === null) return;\n\n    slides.value = Array.from(containerRef.value.children) as HTMLElement[];\n\n    observeSlides();\n    observeSlot();\n    updateContainerBleed();\n  });\n\n  onUnmounted(() => {\n    slideObserver.value?.disconnect();\n    slotObserver.value?.disconnect();\n  });\n</script>\n\n<template>\n  <section\n    :class=\"[\n      'tide-carousel',\n      CSS.POSITION.RELATIVE,\n      CSS.DISPLAY.FLEX,\n      CSS.FLEX.DIRECTION.COLUMN,\n      CSS.GAP.ONE,\n      CSS.WIDTH.MAX_FULL,\n    ]\"\n    ref=\"carouselRef\"\n  >\n    <section\n      :class=\"[CSS.DISPLAY.FLEX, props.title ? CSS.AXIS1.BETWEEN : CSS.AXIS1.END, CSS.AXIS2.CENTER, CSS.WIDTH.FULL]\"\n      v-if=\"(!props.isFloating && showButtons) || props.title\"\n    >\n      <div\n        :class=\"[CSS.DISPLAY.FLEX, CSS.FLEX.WRAP, CSS.AXIS2.CENTER, CSS.GAP.ONE]\"\n        v-if=\"props.title\"\n      >\n        <div\n          :class=\"[CSS.WHITESPACE_WRAP.OFF, isHeadline1 ? CSS.FONT.ROLE.HEADLINE_1 : CSS.FONT.ROLE.HEADLINE_2]\"\n          v-if=\"props.title\"\n        >\n          {{ props.title }}\n        </div>\n\n        <div\n          :class=\"[CSS.WHITESPACE_WRAP.OFF, CSS.FONT.ROLE.LABEL_2, CSS.FONT.COLOR.SURFACE.VARIANT]\"\n          v-if=\"props.subtitle\"\n        >\n          {{ props.subtitle }}\n        </div>\n      </div>\n\n      <div\n        :class=\"[CSS.DISPLAY.FLEX, CSS.AXIS2.CENTER, CSS.GAP.ONE]\"\n        v-if=\"!props.isFloating && showButtons\"\n      >\n        <TideButtonIcon\n          :disabled=\"isFirstSlide\"\n          :icon=\"ICON.CHEVRON_LEFT\"\n          :priority=\"PRIORITY.TERTIARY\"\n          @click=\"isScrollByPage ? showPreviousPage() : showPreviousSlide()\"\n        />\n\n        <TideButtonIcon\n          :disabled=\"isLastSlide\"\n          :icon=\"ICON.CHEVRON_RIGHT\"\n          :priority=\"PRIORITY.TERTIARY\"\n          @click=\"isScrollByPage ? showNextPage() : showNextSlide()\"\n        />\n      </div>\n    </section>\n\n    <slot name=\"misc\" />\n\n    <div :class=\"[CSS.POSITION.RELATIVE]\">\n      <ul\n        :class=\"[\n          'tide-carousel-container',\n          props.bleed && 'bleed',\n          CSS.DISPLAY.FLEX,\n          CSS.GAP.ONE,\n          CSS.LIST_BULLETS.OFF,\n          CSS.OVERFLOW.X.SCROLL,\n          CSS.SCROLLBAR.OFF,\n          CSS.SNAP.ON,\n        ]\"\n        ref=\"containerRef\"\n        @scroll=\"handleScroll\"\n      >\n        <slot />\n      </ul>\n\n      <div\n        :class=\"[\n          'tide-carousel-button-overlay',\n          CSS.POSITION.ABSOLUTE,\n          CSS.POSITIONING.TOP,\n          CSS.DISPLAY.FLEX,\n          CSS.AXIS1.BETWEEN,\n          CSS.AXIS2.CENTER,\n          CSS.WIDTH.FULL,\n          CSS.HEIGHT.FULL,\n          CSS.POINTER_EVENTS.OFF,\n          props.isHideawayButtons ? 'hideaway' : '',\n        ]\"\n        v-if=\"isFloating && showButtons\"\n      >\n        <TideButtonIcon\n          :class=\"[CSS.MARGIN.LEFT.ONE, CSS.POINTER_EVENTS.ON]\"\n          :disabled=\"isFirstSlide\"\n          :icon=\"ICON.CHEVRON_LEFT\"\n          :priority=\"PRIORITY.QUATERNARY\"\n          @click=\"isScrollByPage ? showPreviousPage() : showPreviousSlide()\"\n        />\n\n        <TideButtonIcon\n          :class=\"[CSS.MARGIN.RIGHT.ONE, CSS.POINTER_EVENTS.ON]\"\n          :disabled=\"isLastSlide\"\n          :icon=\"ICON.CHEVRON_RIGHT\"\n          :priority=\"PRIORITY.QUATERNARY\"\n          @click=\"isScrollByPage ? showNextPage() : showNextSlide()\"\n        />\n      </div>\n    </div>\n  </section>\n</template>\n\n<style scoped>\n  .tide-carousel-container.bleed {\n    transition: margin var(--tide-animate), padding var(--tide-animate);\n  }\n\n  .tide-carousel-button-overlay.hideaway {\n    opacity: 0;\n  }\n\n  .tide-carousel:hover .tide-carousel-button-overlay.hideaway {\n    opacity: 1;\n  }\n</style>\n","<script lang=\"ts\" setup>\n  import TideIcon from '@/components/TideIcon.vue';\n  import { ELEMENT } from '@/types/Element';\n  import { ICON } from '@/types/Icon';\n  import { CSS } from '@/types/Styles';\n  import { TARGET } from '@/types/Target';\n\n  import type { Element } from '@/types/Element';\n\n  type Props = {\n    element?: Element;\n    href?: string;\n    isNewTab?: boolean;\n    label: string;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    element: ELEMENT.LINK,\n    href: undefined,\n    isNewTab: false,\n  });\n</script>\n\n<template>\n  <component\n    :class=\"[\n      'tide-chip-action',\n      CSS.DISPLAY.FLEX,\n      CSS.AXIS2.CENTER,\n      CSS.GAP.HALF,\n      CSS.BORDER.FULL.ONE,\n      CSS.BORDER.RADIUS.FULL,\n      CSS.PADDING.X.ONE,\n      CSS.PADDING.Y.HALF,\n      CSS.BG.SURFACE.DEFAULT,\n      CSS.FONT.ROLE.LINK_2,\n      CSS.FONT.COLOR.SURFACE.DEFAULT,\n      CSS.UNDERLINE.REST.OFF,\n    ]\"\n    :href=\"props.href\"\n    :target=\"props.isNewTab ? TARGET.BLANK : TARGET.SELF\"\n    :is=\"element\"\n  >\n    <TideIcon :icon=\"ICON.SEARCH\" />\n\n    <span>{{ props.label }}</span>\n  </component>\n</template>\n\n<style scoped>\n  .tide-chip-action:hover {\n    background-color: var(--tide-surface-variant);\n    border-color: var(--tide-border-high);\n  }\n</style>\n","<script lang=\"ts\" setup>\n  import { CSS } from '@/types/Styles';\n\n  type Props = {\n    isActive: boolean;\n    label: string;\n  };\n\n  const props = defineProps<Props>();\n</script>\n\n<template>\n  <button\n    :class=\"[\n      'tide-chip-filter',\n      props.isActive\n        ? [CSS.BG.SECONDARY, CSS.FONT.COLOR.SECONDARY]\n        : [CSS.BG.SURFACE.VARIANT, CSS.FONT.COLOR.SURFACE.DEFAULT],\n      CSS.DISPLAY.FLEX,\n      CSS.AXIS2.CENTER,\n      CSS.GAP.HALF,\n      CSS.BORDER.FULL.ONE,\n      CSS.BORDER.RADIUS.FULL,\n      CSS.PADDING.X.ONE,\n      CSS.PADDING.Y.HALF,\n      CSS.FONT.ROLE.LABEL_2,\n      props.isActive ? 'active' : '',\n    ]\"\n  >\n    <slot />\n    <div :class=\"[CSS.DISPLAY.FLEX, CSS.AXIS1.CENTER, CSS.AXIS2.CENTER, CSS.GAP.HALF]\">\n      <span :class=\"[props.isActive ? '' : 'icon-spacing', CSS.FONT.ROLE.LABEL_1, CSS.WHITESPACE_WRAP.OFF]\">\n        {{ props.label }}\n      </span>\n    </div>\n  </button>\n</template>\n\n<style scoped>\n  /* Border must always exist to prevent resize on hover state, but match background color on rest state to blend in. */\n  .tide-chip-filter {\n    border-color: var(--tide-surface-variant);\n  }\n\n  .tide-chip-filter.active {\n    border-color: var(--tide-secondary);\n  }\n\n  .tide-chip-filter:hover {\n    background-color: var(--tide-surface-variant);\n    border-color: var(--tide-border);\n    color: var(--tide-on-surface);\n  }\n</style>\n","<script lang=\"ts\" setup>\n  import TideIcon from '@/components/TideIcon.vue';\n  import { ICON } from '@/types/Icon';\n  import { CSS } from '@/types/Styles';\n\n  type Props = {\n    label: string;\n  };\n\n  const props = defineProps<Props>();\n</script>\n\n<template>\n  <button\n    :class=\"[\n      'tide-chip-input',\n      CSS.BG.SURFACE.VARIANT,\n      CSS.FONT.COLOR.SURFACE,\n      CSS.DISPLAY.FLEX,\n      CSS.AXIS2.CENTER,\n      CSS.GAP.HALF,\n      CSS.BORDER.FULL.ONE,\n      CSS.BORDER.RADIUS.FULL,\n      CSS.PADDING.X.ONE,\n      CSS.PADDING.Y.HALF,\n      CSS.FONT.ROLE.LABEL_2,\n    ]\"\n  >\n    <span>{{ props.label }}</span>\n\n    <TideIcon :icon=\"ICON.CLOSE\" />\n  </button>\n</template>\n\n<style scoped>\n  .tide-chip-input {\n    border-color: var(--tide-border);\n  }\n\n  .tide-chip-input:hover {\n    border-color: var(--tide-border-high);\n  }\n</style>\n","<script lang=\"ts\" setup>\n  import { CSS } from '@/types/Styles';\n\n  type Props = {\n    heading?: string;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    heading: '',\n  });\n</script>\n\n<template>\n  <section class=\"tide-columns\">\n    <h2 :class=\"[CSS.MARGIN.BOTTOM.HALF]\">\n      {{ props.heading }}\n    </h2>\n\n    <ul :class=\"[CSS.DISPLAY.FLEX, CSS.FLEX.WRAP, CSS.GAP.TWO, CSS.LIST_BULLETS.OFF]\">\n      <li class=\"tide-columns-column\">\n        <slot name=\"section1\" />\n      </li>\n\n      <li class=\"tide-columns-column\">\n        <slot name=\"section2\" />\n      </li>\n\n      <li class=\"tide-columns-column\">\n        <slot name=\"section3\" />\n      </li>\n\n      <li class=\"tide-columns-column\">\n        <slot name=\"section4\" />\n      </li>\n    </ul>\n  </section>\n</template>\n\n<style scoped>\n  .tide-columns-column {\n    width: 100%;\n  }\n\n  @media (min-width: 992px) {\n    .tide-columns-column {\n      width: calc((100% - 2rem) / 2);\n    }\n  }\n\n  @media (min-width: 1232px) {\n    .tide-columns-column {\n      width: calc((100% - 6rem) / 4);\n    }\n  }\n</style>\n","export const OBJECT_FIT = {\n  CONTAIN: 'contain',\n  COVER: 'cover',\n  SCALE_DOWN: 'scale-down',\n} as const;\n\nexport type ObjectFit = (typeof OBJECT_FIT)[keyof typeof OBJECT_FIT];\n","<script lang=\"ts\" setup>\n  import { computed, ref } from 'vue';\n\n  import { OBJECT_FIT } from '@/types/Image';\n  import { CSS } from '@/types/Styles';\n\n  import type { ObjectFit } from '@/types/Image';\n  import type { Source } from '@/types/Source';\n\n  type Props = {\n    alt?: string;\n    height?: string;\n    isLazy?: boolean;\n    objectFit?: ObjectFit;\n    sources?: Source[];\n    src?: string;\n    width?: string;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    alt: '',\n    height: undefined,\n    isLazy: true,\n    objectFit: OBJECT_FIT.COVER,\n    sources: () => [],\n    src: undefined,\n    width: undefined,\n  });\n\n  const picture = ref();\n  const img = ref();\n\n  const imageDefault = 'https://cdn-static.tilabs.io/marketplace/common/image-coming-soon.svg';\n\n  const objectFitClassName = computed<string>(() => {\n    switch (props.objectFit) {\n      case OBJECT_FIT.CONTAIN:\n        return CSS.OBJECT.CONTAIN;\n      case OBJECT_FIT.COVER:\n        return CSS.OBJECT.COVER;\n      case OBJECT_FIT.SCALE_DOWN:\n        return CSS.OBJECT.SCALE_DOWN;\n      default:\n        return OBJECT_FIT.COVER;\n    }\n  });\n\n  const setImageFromDefault = () => {\n    const currentSrc = img.value?.currentSrc;\n    const pictureSource = picture.value?.querySelector(`source[srcset=\"${currentSrc}\"]`);\n\n    if (currentSrc && pictureSource) {\n      pictureSource.srcset = imageDefault;\n    } else if (img.value) {\n      img.value.src = imageDefault;\n    }\n  };\n</script>\n\n<template>\n  <picture\n    :class=\"['tide-image', CSS.DISPLAY.BLOCK]\"\n    ref=\"picture\"\n    :style=\"\n      width || height\n        ? {\n            width: width || undefined,\n            height: height || undefined,\n          }\n        : undefined\n    \"\n  >\n    <source\n      :key=\"source.srcset\"\n      :media=\"`(min-width:${source.media}px)`\"\n      :srcset=\"source.srcset\"\n      v-for=\"source in props.sources\"\n    />\n\n    <img\n      :alt=\"alt\"\n      :class=\"['tide-image-img', CSS.WIDTH.FULL, CSS.HEIGHT.FULL, CSS.OBJECT.CENTER, objectFitClassName]\"\n      :fetchpriority=\"isLazy ? undefined : 'high'\"\n      :loading=\"props.isLazy ? 'lazy' : 'eager'\"\n      ref=\"img\"\n      :src=\"src ?? imageDefault\"\n      @error=\"setImageFromDefault\"\n    />\n  </picture>\n</template>\n\n<style scoped>\n  .tide-image-img {\n    border-radius: inherit;\n  }\n</style>\n","<script lang=\"ts\" setup>\n  import TideImage from '@/components/TideImage.vue';\n  import { OBJECT_FIT } from '@/types/Image';\n  import { CSS } from '@/types/Styles';\n\n  import type { Source } from '@/types/Source';\n\n  type Props = {\n    alt?: string;\n    isLazy?: boolean;\n    sources?: Source[];\n    src?: string;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    alt: '',\n    isLazy: true,\n    sources: () => [],\n    src: undefined,\n  });\n</script>\n\n<template>\n  <div :class=\"['tide-image-background', CSS.POSITION.RELATIVE, CSS.OVERFLOW.XY.HIDDEN, CSS.ISOLATION.ISOLATE]\">\n    <div\n      :class=\"[\n        CSS.POSITION.ABSOLUTE,\n        CSS.HEIGHT.FULL,\n        CSS.WIDTH.FULL,\n        CSS.DISPLAY.FLEX,\n        CSS.AXIS1.CENTER,\n        CSS.AXIS2.CENTER,\n      ]\"\n    >\n      <TideImage\n        :alt=\"props.alt\"\n        :class=\"[CSS.WIDTH.FULL, CSS.HEIGHT.FULL]\"\n        :is-lazy=\"props.isLazy\"\n        :object-fit=\"OBJECT_FIT.COVER\"\n        :sources=\"props.sources\"\n        :src=\"props.src\"\n      />\n    </div>\n\n    <slot />\n  </div>\n</template>\n\n<style scoped>\n  :deep(.tide-image) {\n    z-index: -1;\n  }\n</style>\n","<script lang=\"ts\" setup>\n  import { CSS } from '@/types/Styles';\n\n  type Props = {\n    label?: string | number;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    label: undefined,\n  });\n</script>\n\n<template>\n  <div\n    :class=\"[\n      'tide-indicator',\n      props.label ? '' : 'dot',\n      CSS.DISPLAY.INLINE_BLOCK,\n      CSS.ALIGN.X.CENTER,\n      CSS.BG.GLOBAL.PRIMARY.ERROR,\n      CSS.BORDER.RADIUS.FULL,\n      props.label && props.label.toString().length > 1 ? [CSS.PADDING.X.HALF] : [],\n      props.label\n        ? [CSS.POSITION.RELATIVE, CSS.FONT.ROLE.LABEL_3, CSS.FONT.COLOR.SURFACE.INVERSE]\n        : [CSS.BORDER.FULL.ONE],\n    ]\"\n  >\n    <div\n      :class=\"['tide-indicator-label']\"\n      v-if=\"props.label\"\n    >\n      {{ props.label }}\n    </div>\n  </div>\n</template>\n\n<style scoped>\n  .tide-indicator:not(.dot) {\n    min-width: 1rem;\n    min-height: 1rem;\n  }\n\n  .tide-indicator.dot {\n    border-color: var(--tide-gray-100);\n    width: 10px;\n    height: 10px;\n  }\n\n  .tide-indicator-label {\n    /* Use bottom-weighting to offset the mathematical center to the optical center. */\n    margin-top: -1px;\n  }\n</style>\n","<script setup lang=\"ts\">\n  import TideIcon from '@/components/TideIcon.vue';\n  import { ICON } from '@/types/Icon';\n  import { SIZE } from '@/types/Size';\n  import { CSS } from '@/types/Styles';\n\n  type Props = {\n    isError: boolean;\n    message: string;\n  };\n  defineProps<Props>();\n</script>\n\n<template>\n  <div\n    :class=\"[\n      CSS.DISPLAY.FLEX,\n      CSS.AXIS2.CENTER,\n      CSS.GAP.QUARTER,\n      CSS.FONT.ROLE.LABEL_3,\n      isError ? [CSS.FONT.COLOR.GLOBAL.ERROR] : [CSS.FONT.COLOR.SURFACE.DEFAULT],\n    ]\"\n  >\n    <TideIcon\n      :class=\"[CSS.FLEX.SHRINK.OFF]\"\n      :icon=\"ICON.ERROR\"\n      :size=\"SIZE.SMALL\"\n      v-if=\"isError\"\n    />\n\n    <div>\n      {{ message }}\n    </div>\n  </div>\n</template>\n","import { inject, provide, ref } from 'vue';\n\nimport type { Ref } from 'vue';\n\ntype TideFormContext = {\n  forceShowErrors: Ref<boolean>;\n};\n\nconst FORM_KEY = Symbol('tide-form');\n\nexport const useTideForm = () => {\n  const forceShowErrors = ref<boolean>(false);\n\n  provide<TideFormContext>(FORM_KEY, { forceShowErrors });\n\n  const revealValidationErrors = () => {\n    forceShowErrors.value = true;\n  };\n\n  return { revealValidationErrors };\n};\n\nexport const useFormContext = () => {\n  return inject<TideFormContext>(FORM_KEY);\n};\n","import { formatNumber } from '@/utilities/format';\n\nimport type { ValidationLength, ValidationResult, Validator } from '@/types/Validation';\nimport type { Ref } from 'vue';\n\nexport const errorMessageDefault = 'Please enter a valid value';\n\nexport const VALIDATION_RESULT = {\n  NO_ERROR: {\n    message: '',\n    valid: true,\n  },\n  REQUIRED: {\n    message: 'Please fill out this field',\n    valid: false,\n  },\n} as const;\n\nexport const checkFormat = (format: RegExp, message?: string) => {\n  return (value: string): ValidationResult => {\n    let result: ValidationResult = VALIDATION_RESULT.NO_ERROR;\n\n    if (!value.trim().match(format)) {\n      result = {\n        message: message ?? errorMessageDefault,\n        valid: false,\n      };\n    }\n\n    return result;\n  };\n};\n\nexport const getFieldLengthIsValid = ({ maxlength, minlength, required, value }: ValidationLength) => {\n  const isEmptyAndUnrequired = value.length === 0 && !required;\n  const isTooLong = maxlength && value.length > maxlength;\n  const isTooShort = !isEmptyAndUnrequired && minlength && value.length < minlength;\n  return !isTooShort && !isTooLong;\n};\n\nexport const getFieldValidationResult = ({\n  errorFromProps,\n  maxlength,\n  minlength,\n  required,\n  validators,\n  value,\n}: {\n  errorFromProps: string;\n  maxlength?: number;\n  minlength?: number;\n  required: boolean;\n  validators?: Validator[];\n  value: Ref<string>;\n}): ValidationResult => {\n  // error in props takes precedence over validation error\n  if (errorFromProps !== '')\n    return {\n      message: errorFromProps,\n      valid: false,\n    };\n\n  // custom validator prop errors from have second highest precedence\n  if (validators) {\n    const validation = validateProperty(value.value, validators);\n\n    if (!validation.valid) {\n      return validation;\n    }\n  }\n\n  // all other prop-based errors come last\n  if (required && value.value.trim() === '') {\n    return VALIDATION_RESULT.REQUIRED;\n  }\n\n  if (maxlength || minlength) {\n    const lengthValidation = validateLength({\n      maxlength,\n      minlength,\n      required,\n      value: value.value,\n    });\n\n    if (!lengthValidation.valid) {\n      return lengthValidation;\n    }\n  }\n  return VALIDATION_RESULT.NO_ERROR;\n};\n\nexport const validateLength = ({ maxlength, minlength, required, value }: ValidationLength): ValidationResult => {\n  const response = {\n    message: '',\n    valid: true,\n  };\n\n  response.valid = getFieldLengthIsValid({\n    maxlength,\n    minlength,\n    required,\n    value,\n  });\n\n  if (response.valid) return response;\n\n  response.message = errorMessageDefault;\n\n  if (maxlength && minlength) {\n    response.message = `Enter a value between ${formatNumber(minlength)} and ${formatNumber(maxlength)} characters`;\n  } else if (maxlength) {\n    response.message = `Use ${formatNumber(maxlength)} characters or fewer`;\n  } else if (minlength) {\n    response.message = `Enter at least ${formatNumber(minlength)} characters`;\n  }\n\n  return response;\n};\n\nexport function validateProperty(value: string, validators: ((value: string) => ValidationResult)[]): ValidationResult {\n  for (const validator of validators) {\n    const validation = validator(value);\n    if (!validation.valid) {\n      return validation;\n    }\n  }\n\n  return {\n    message: '',\n    valid: true,\n  };\n}\n","<script lang=\"ts\" setup>\n  import { computed, ref, watch, watchEffect } from 'vue';\n\n  import TideIcon from '@/components/TideIcon.vue';\n  import TideInputSupportingText from '@/components/TideInputSupportingText.vue';\n  import { useFormContext } from '@/composables/useTideForm';\n  import { ICON } from '@/types/Icon';\n  import { SIZE } from '@/types/Size';\n  import { CSS } from '@/types/Styles';\n  import { formatNumber } from '@/utilities/format';\n  import { VALIDATION_RESULT } from '@/utilities/validation';\n\n  import type { ValidationResult } from '@/types/Validation';\n\n  type Props = {\n    disabled?: boolean;\n    error?: string;\n    indeterminate?: boolean;\n    inputId?: string;\n    label: string;\n    name?: string;\n    number?: number;\n    required?: boolean;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    disabled: false,\n    error: '',\n    indeterminate: false,\n    inputId: undefined,\n    label: undefined,\n    name: undefined,\n    number: undefined,\n    required: false,\n  });\n\n  type Emits = {\n    (event: 'valid', valid: boolean): void;\n  };\n  const emit = defineEmits<Emits>();\n\n  const modelValue = defineModel<boolean>({ required: true });\n\n  const formContext = useFormContext();\n\n  const isValidating = ref<boolean>(false);\n  const errorRef = ref<ValidationResult>(VALIDATION_RESULT.NO_ERROR);\n\n  const formattedLabel = computed(() => (props.required ? `${props.label} *` : props.label));\n  const isChecked = computed(() => modelValue.value || props.indeterminate);\n  const showError = computed(() => {\n    if (hasErrorFromProp.value) return true;\n    if (!isValidating.value) return false;\n    return !errorRef.value.valid;\n  });\n  const hasErrorFromProp = computed(() => props.error !== '');\n  const supportingTextMessage = computed(() => showError.value && errorRef.value.message);\n\n  const getCheckboxValidationResult = (): ValidationResult => {\n    if (props.error !== '')\n      return {\n        message: props.error,\n        valid: false,\n      };\n    if (!props.required || isChecked.value) return VALIDATION_RESULT.NO_ERROR;\n    return VALIDATION_RESULT.REQUIRED;\n  };\n\n  watchEffect(() => {\n    errorRef.value = getCheckboxValidationResult();\n  });\n\n  watch(\n    modelValue,\n    () => {\n      if (modelValue.value) isValidating.value = true;\n    },\n    { immediate: true }\n  );\n\n  watch(\n    () => formContext?.forceShowErrors.value,\n    (newValue) => {\n      if (newValue) isValidating.value = true;\n    },\n    { immediate: true }\n  );\n\n  watch(\n    errorRef,\n    () => {\n      emit('valid', errorRef.value.valid);\n    },\n    { deep: true, immediate: true }\n  );\n</script>\n\n<template>\n  <div :class=\"['tide-input-checkbox', CSS.DISPLAY.FLEX, CSS.FLEX.DIRECTION.COLUMN, CSS.GAP.QUARTER]\">\n    <label\n      :class=\"[\n        CSS.AXIS2.CENTER,\n        CSS.DISPLAY.FLEX,\n        CSS.FONT.ROLE.BODY_1,\n        CSS.GAP.HALF,\n        CSS.USER_SELECT.NONE,\n        showError ? CSS.FONT.COLOR.GLOBAL.ERROR : CSS.FONT.COLOR.SURFACE.DEFAULT,\n        disabled ? [CSS.OPACITY.DISABLED, CSS.CURSOR.NOT_ALLOWED] : [CSS.CURSOR.POINTER],\n      ]\"\n      :for=\"inputId\"\n    >\n      <input\n        :checked=\"isChecked\"\n        :class=\"['tide-screen-reader-only']\"\n        :disabled=\"disabled\"\n        :name=\"name\"\n        ref=\"input\"\n        :id=\"inputId\"\n        type=\"checkbox\"\n        v-model=\"modelValue\"\n      />\n\n      <div\n        :class=\"[\n          'tide-input-checkbox-custom',\n          CSS.AXIS1.CENTER,\n          CSS.AXIS2.CENTER,\n          CSS.BORDER.FULL.ONE,\n          CSS.BORDER.RADIUS.QUARTER,\n          CSS.DISPLAY.FLEX,\n          CSS.FLEX.SHRINK.OFF,\n          CSS.POSITION.RELATIVE,\n          isChecked\n            ? [showError ? CSS.BG.GLOBAL.PRIMARY.ERROR : [CSS.BG.SECONDARY, CSS.BORDER.COLOR.HIGH]]\n            : [\n                showError\n                  ? [CSS.BORDER.COLOR.GLOBAL.ERROR, CSS.BG.GLOBAL.SURFACE.ERROR]\n                  : [CSS.BORDER.COLOR.DEFAULT, CSS.BG.SURFACE.DEFAULT],\n              ],\n        ]\"\n      >\n        <TideIcon\n          :class=\"[CSS.FONT.COLOR.SECONDARY]\"\n          :icon=\"indeterminate ? ICON.REMOVE : ICON.CHECK\"\n          :size=\"SIZE.SMALL\"\n          v-if=\"isChecked\"\n        />\n      </div>\n\n      <div\n        :class=\"[CSS.AXIS1.BETWEEN, CSS.DISPLAY.FLEX, CSS.FLEX.GROW.ON, CSS.FONT.ROLE.BODY_1]\"\n        v-if=\"label\"\n      >\n        <span>{{ formattedLabel }}</span>\n\n        <span\n          :class=\"[CSS.FONT.COLOR.SURFACE.VARIANT]\"\n          v-if=\"number\"\n        >\n          ({{ formatNumber(number) }})\n        </span>\n      </div>\n    </label>\n\n    <TideInputSupportingText\n      :message=\"supportingTextMessage\"\n      is-error\n      v-if=\"supportingTextMessage\"\n    />\n  </div>\n</template>\n\n<style scoped>\n  .tide-input-checkbox {\n    align-self: start;\n  }\n\n  .tide-input-checkbox-custom {\n    width: 24px;\n    height: 24px;\n  }\n\n  label:has(input:focus-visible) {\n    outline: auto;\n    outline-offset: 2px;\n  }\n</style>\n","<script lang=\"ts\">\n  /**\n   * @deprecated Use `TideInputCheckbox.vue` imported from 'tide-design-system' npm package instead.\n   */\n  export default {};\n</script>\n\n<script lang=\"ts\" setup>\n  import { computed } from 'vue';\n\n  import TideIcon from '@/components/TideIcon.vue';\n  import { ICON } from '@/types/Icon';\n  import { SIZE } from '@/types/Size';\n  import { CSS } from '@/types/Styles';\n  import { formatNumber } from '@/utilities/format';\n\n  type Props = {\n    checked?: boolean;\n    disabled?: boolean;\n    indeterminate?: boolean;\n    inputId?: string;\n    label?: string;\n    name?: string;\n    number?: number;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    checked: false,\n    disabled: false,\n    indeterminate: false,\n    inputId: undefined,\n    label: undefined,\n    name: undefined,\n    number: undefined,\n  });\n\n  const isChecked = computed(() => props.checked || props.indeterminate);\n</script>\n\n<template>\n  <div\n    :class=\"[\n      'tide-input-checkbox',\n      CSS.DISPLAY.FLEX,\n      CSS.AXIS2.CENTER,\n      CSS.GAP.HALF,\n      CSS.FONT.ROLE.BODY_1,\n      disabled ? ['disabled', CSS.POINTER_EVENTS.OFF] : CSS.CURSOR.POINTER,\n    ]\"\n  >\n    <input\n      :checked=\"isChecked\"\n      :class=\"[CSS.DISPLAY.NONE]\"\n      :disabled=\"props.disabled\"\n      :name=\"props.name\"\n      ref=\"input\"\n      @click.prevent\n      :id=\"props.inputId\"\n      type=\"checkbox\"\n    />\n\n    <div\n      :class=\"[\n        'tide-input-checkbox-custom',\n        CSS.POSITION.RELATIVE,\n        CSS.DISPLAY.FLEX,\n        CSS.AXIS1.CENTER,\n        CSS.AXIS2.CENTER,\n        CSS.FLEX.SHRINK.OFF,\n        CSS.BORDER.FULL.ONE,\n        isChecked ? [CSS.BORDER.COLOR.HIGH, CSS.BG.SECONDARY] : [CSS.BORDER.COLOR.DEFAULT, CSS.BG.SURFACE.DEFAULT],\n        CSS.BORDER.RADIUS.QUARTER,\n        isChecked && 'checked',\n        disabled ? CSS.CURSOR.NOT_ALLOWED : CSS.CURSOR.POINTER,\n      ]\"\n    >\n      <TideIcon\n        :class=\"[CSS.FONT.COLOR.SECONDARY]\"\n        :icon=\"props.indeterminate ? ICON.REMOVE : ICON.CHECK\"\n        :size=\"SIZE.SMALL\"\n        v-if=\"isChecked\"\n      />\n    </div>\n\n    <label\n      :class=\"[\n        CSS.DISPLAY.FLEX,\n        CSS.AXIS1.BETWEEN,\n        CSS.FLEX.GROW.ON,\n        CSS.FONT.ROLE.BODY_1,\n        disabled ? CSS.CURSOR.NOT_ALLOWED : CSS.CURSOR.POINTER,\n      ]\"\n      :for=\"props.inputId\"\n      @click.prevent\n      v-if=\"label\"\n    >\n      <span>{{ label }}</span>\n      <span\n        :class=\"[CSS.FONT.COLOR.SURFACE.VARIANT]\"\n        v-if=\"props.number\"\n      >\n        ({{ formatNumber(props.number) }})\n      </span>\n    </label>\n  </div>\n</template>\n\n<style scoped>\n  .tide-input-checkbox.disabled {\n    opacity: var(--tide-disabled);\n  }\n\n  .tide-input-checkbox-custom {\n    width: 24px;\n    height: 24px;\n  }\n</style>\n","<script lang=\"ts\" setup>\n  import { computed } from 'vue';\n\n  import { CSS } from '@/types/Styles';\n  import { formatNumber } from '@/utilities/format';\n\n  type Props = {\n    disabled?: boolean;\n    inputId?: string;\n    label: string;\n    name: string;\n    number?: number;\n    value: string;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    disabled: false,\n    inputId: undefined,\n    label: undefined,\n    number: undefined,\n  });\n\n  const modelValue = defineModel<string>({ required: true });\n\n  const isChecked = computed(() => modelValue.value === props.value);\n</script>\n\n<template>\n  <label\n    :class=\"[\n      'tide-input-radio',\n      CSS.DISPLAY.FLEX,\n      CSS.AXIS2.CENTER,\n      CSS.GAP.HALF,\n      CSS.USER_SELECT.NONE,\n      props.disabled ? [CSS.OPACITY.DISABLED, CSS.CURSOR.NOT_ALLOWED] : [CSS.CURSOR.POINTER],\n    ]\"\n    :for=\"props.inputId\"\n  >\n    <input\n      :class=\"['tide-screen-reader-only']\"\n      :disabled=\"disabled\"\n      :name=\"name\"\n      :value=\"value\"\n      :id=\"props.inputId\"\n      type=\"radio\"\n      v-model=\"modelValue\"\n    />\n\n    <div\n      :class=\"[\n        'tide-input-radio-custom',\n        CSS.POSITION.RELATIVE,\n        CSS.DISPLAY.FLEX,\n        CSS.AXIS1.CENTER,\n        CSS.AXIS2.CENTER,\n        CSS.BORDER.FULL.ONE,\n        isChecked ? [CSS.BORDER.COLOR.HIGH] : [CSS.BORDER.COLOR.DEFAULT],\n        CSS.BORDER.RADIUS.FULL,\n        CSS.BG.SURFACE.DEFAULT,\n        CSS.CURSOR.POINTER,\n        CSS.POINTER_EVENTS.ON,\n      ]\"\n    >\n      <div :class=\"['tide-input-radio-check', CSS.BORDER.RADIUS.FULL, isChecked && CSS.BG.SECONDARY]\" />\n    </div>\n\n    <div :class=\"[CSS.DISPLAY.FLEX, CSS.FLEX.GROW.ON, CSS.AXIS1.BETWEEN, CSS.FONT.ROLE.BODY_1]\">\n      <span>{{ label }}</span>\n      <span\n        :class=\"[CSS.FONT.COLOR.SURFACE.VARIANT]\"\n        v-if=\"props.number\"\n      >\n        ({{ formatNumber(props.number) }})\n      </span>\n    </div>\n  </label>\n</template>\n\n<style scoped>\n  .tide-input-radio-custom {\n    width: 24px;\n    height: 24px;\n  }\n\n  .tide-input-radio-check {\n    width: 16px;\n    height: 16px;\n  }\n\n  label:has(input:focus-visible) {\n    outline: auto;\n    outline-offset: 2px;\n  }\n</style>\n","<script lang=\"ts\">\n  /**\n   * @deprecated Use `TideInputRadio.vue` imported from 'tide-design-system' npm package instead.\n   */\n  export default {};\n</script>\n\n<script lang=\"ts\" setup>\n  import { ref, watch } from 'vue';\n\n  import { CSS } from '@/types/Styles';\n  import { formatNumber } from '@/utilities/format';\n\n  type Props = {\n    checked?: boolean;\n    disabled?: boolean;\n    inputId?: string;\n    label?: string;\n    name?: string;\n    number?: number;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    checked: false,\n    disabled: false,\n    inputId: undefined,\n    label: undefined,\n    name: undefined,\n    number: undefined,\n  });\n\n  const checked = ref(props.checked);\n\n  watch(\n    () => props.checked,\n    (newValue, oldValue) => {\n      if (newValue !== oldValue || newValue !== checked.value) {\n        checked.value = newValue;\n      }\n    }\n  );\n</script>\n\n<template>\n  <div\n    :class=\"[\n      'tide-input-radio',\n      CSS.DISPLAY.FLEX,\n      CSS.AXIS2.CENTER,\n      CSS.GAP.HALF,\n      CSS.POINTER_EVENTS.OFF,\n      props.disabled && 'disabled',\n    ]\"\n  >\n    <input\n      :checked=\"checked\"\n      :class=\"[CSS.DISPLAY.NONE]\"\n      :id=\"props.inputId\"\n      name=\"\"\n      type=\"radio\"\n      value=\"\"\n    />\n\n    <div\n      :class=\"[\n        'tide-input-radio-custom',\n        CSS.POSITION.RELATIVE,\n        CSS.DISPLAY.FLEX,\n        CSS.AXIS1.CENTER,\n        CSS.AXIS2.CENTER,\n        CSS.BORDER.FULL.ONE,\n        checked ? CSS.BORDER.COLOR.HIGH : CSS.BORDER.COLOR.DEFAULT,\n        CSS.BORDER.RADIUS.FULL,\n        CSS.BG.SURFACE.DEFAULT,\n        CSS.CURSOR.POINTER,\n        CSS.POINTER_EVENTS.ON,\n        checked && 'checked',\n      ]\"\n    >\n      <div :class=\"['tide-input-radio-check', CSS.BORDER.RADIUS.FULL, props.checked && CSS.BG.SECONDARY]\" />\n    </div>\n\n    <label\n      :class=\"[\n        CSS.DISPLAY.FLEX,\n        CSS.FLEX.GROW.ON,\n        CSS.AXIS1.BETWEEN,\n        CSS.FONT.ROLE.BODY_1,\n        CSS.CURSOR.POINTER,\n        CSS.POINTER_EVENTS.ON,\n      ]\"\n      :for=\"props.inputId\"\n    >\n      <span>{{ label }}</span>\n      <span\n        :class=\"[CSS.FONT.COLOR.SURFACE.VARIANT]\"\n        v-if=\"props.number\"\n      >\n        ({{ formatNumber(props.number) }})\n      </span>\n    </label>\n  </div>\n</template>\n\n<style scoped>\n  .tide-input-radio.disabled {\n    opacity: var(--tide-disabled);\n  }\n\n  .tide-input-radio-custom {\n    width: 24px;\n    height: 24px;\n  }\n\n  .tide-input-radio-check {\n    width: 16px;\n    height: 16px;\n  }\n</style>\n","import { formatNumber, formatPhone, formatPrice } from '@/utilities/format';\n\nexport type Formatted = {\n  [key: string]: string | string[] | number;\n};\n\nexport const FORMAT = {\n  NUMBER: formatNumber,\n  PHONE: formatPhone,\n  PRICE: formatPrice,\n} as const;\n\nexport const FORMAT_REGEX = {\n  alpha: /^[a-zA-Z]+$/g,\n  alphaNumberOrEmpty: /^$|^[a-z0-9]+$/i,\n  alphaSpace: /^[a-zA-Z ]+$/g,\n  email:\n    /^(([^<>()[\\]\\\\.,;:\\s@\"]+(\\.[^<>()[\\]\\\\.,;:\\s@\"]+)*)|(\".+\"))@((\\[[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\])|(([a-zA-Z\\-0-9]+\\.)+[a-zA-Z]{2,}))$/,\n  numberFormatted: /^$|(?=.)^\\$?(([1-9][0-9]{0,2}(,[0-9]{3})*)|0)?(\\.[0-9]{1,2})?$/,\n  phone: /^(?:\\d{3}-\\d{3}-\\d{4}|\\d{1}-\\d{3}-\\d{3}-\\d{4})?$/,\n  price: /(?=.)^\\$?(([1-9][0-9]{0,2}(,[0-9]{3})*)|0)?(\\.[0-9]{1,2})?$/,\n};\n","import { FORMAT_REGEX } from '@/types/Formatted';\nimport { checkFormat } from '@/utilities/validation';\n\nexport const VALIDATOR = {\n  ALPHA_NUMBER_EMPTY: checkFormat(FORMAT_REGEX.alphaNumberOrEmpty),\n  ALPHA_SPACE: checkFormat(FORMAT_REGEX.alphaSpace),\n  EMAIL: checkFormat(FORMAT_REGEX.email, 'Enter a valid email address (e.g. name@example.com)'),\n  NUMBER: checkFormat(FORMAT_REGEX.numberFormatted, 'Enter a valid number'),\n  PHONE: checkFormat(FORMAT_REGEX.phone, 'Enter a valid phone number'),\n} as const;\n\nexport type ValidationError = string | boolean;\nexport type ValidationResult = {\n  message: string;\n  valid: boolean;\n};\n\nexport type ValidationLength = {\n  maxlength?: number;\n  minlength?: number;\n  required: boolean;\n  value: string;\n};\n\nexport type Validator = (value: string) => ValidationResult;\n\nexport const ERROR_DISPLAY = {\n  EAGER: 'eager',\n  LAZY: 'lazy',\n} as const;\n\nexport type ErrorDisplay = (typeof ERROR_DISPLAY)[keyof typeof ERROR_DISPLAY];\n","<script lang=\"ts\" setup>\n  import { computed, ref, useId, watch, watchEffect } from 'vue';\n\n  import TideIcon from '@/components/TideIcon.vue';\n  import TideInputSupportingText from '@/components/TideInputSupportingText.vue';\n  import { useFormContext } from '@/composables/useTideForm';\n  import { ICON } from '@/types/Icon';\n  import { SIZE } from '@/types/Size';\n  import { CSS } from '@/types/Styles';\n  import { ERROR_DISPLAY } from '@/types/Validation';\n  import { VALIDATION_RESULT, getFieldValidationResult } from '@/utilities/validation';\n\n  import type { SelectOption, SelectOptionGroup } from '@/types/Select';\n  import type { ErrorDisplay, ValidationResult } from '@/types/Validation';\n\n  type Props = {\n    disabled?: boolean;\n    error?: string;\n    errorDisplay?: ErrorDisplay;\n    label?: string;\n    name?: string;\n    optgroups?: (SelectOption | SelectOptionGroup)[] | readonly (SelectOption | SelectOptionGroup)[];\n    options?: SelectOption[] | readonly SelectOption[];\n    required?: boolean;\n    supportingText?: string;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    disabled: false,\n    error: '',\n    errorDisplay: ERROR_DISPLAY.LAZY,\n    inputId: undefined,\n    label: undefined,\n    name: undefined,\n    optgroups: undefined,\n    options: undefined,\n    required: false,\n    supportingText: undefined,\n  });\n\n  type Emits = {\n    (event: 'valid', isValid: boolean): void;\n  };\n\n  const emit = defineEmits<Emits>();\n\n  const modelValue = defineModel<string>({ required: true });\n\n  const formContext = useFormContext();\n\n  const errorRef = ref<ValidationResult>(VALIDATION_RESULT.NO_ERROR);\n  const hasFocus = ref<boolean>(false);\n  const inputId = useId();\n  const isValidating = ref<boolean>(false);\n  const selectElement = ref<HTMLSelectElement | null>(null);\n\n  const formattedLabel = computed(() => (props.required ? `${props.label} *` : props.label));\n  const showError = computed(() => {\n    if (hasErrorFromProp.value) return true;\n    if (!isValidating.value) return false;\n    return !errorRef.value.valid;\n  });\n  const hasErrorFromProp = computed(() => props.error !== '');\n  const hasMinilabel = computed(() => hasFocus.value || !isEmpty.value);\n  const isEmpty = computed(() => modelValue.value === '');\n  const supportingTextMessage = computed(() => (showError.value && errorRef.value.message) || props.supportingText);\n\n  const expandOptions = () => {\n    const event = new MouseEvent('mousedown');\n    selectElement?.value?.dispatchEvent(event);\n  };\n\n  const handleFocus = () => {\n    hasFocus.value = true;\n    if (props.errorDisplay === ERROR_DISPLAY.EAGER) isValidating.value = true;\n  };\n\n  const handleFocusOut = () => {\n    hasFocus.value = false;\n    if (props.errorDisplay === ERROR_DISPLAY.LAZY) isValidating.value = true;\n  };\n\n  watchEffect(() => {\n    errorRef.value = getFieldValidationResult({\n      errorFromProps: props.error,\n      required: props.required,\n      value: modelValue,\n    });\n  });\n\n  watch(\n    () => formContext?.forceShowErrors.value,\n    (newValue) => {\n      if (newValue) isValidating.value = true;\n    },\n    { immediate: true }\n  );\n\n  watch(\n    errorRef,\n    () => {\n      emit('valid', errorRef.value.valid);\n    },\n    { deep: true, immediate: true }\n  );\n</script>\n\n<template>\n  <div\n    :class=\"[\n      'tide-input-select',\n      CSS.DISPLAY.FLEX,\n      CSS.FLEX.DIRECTION.COLUMN,\n      CSS.GAP.QUARTER,\n      disabled && 'disabled',\n      showError && 'error',\n    ]\"\n  >\n    <div\n      :class=\"[\n        'tide-input-border',\n        CSS.POSITION.RELATIVE,\n        CSS.DISPLAY.FLEX,\n        CSS.AXIS2.CENTER,\n        CSS.GAP.HALF,\n        CSS.BORDER.RADIUS.HALF,\n        CSS.BG.SURFACE.DEFAULT,\n        props.disabled ? CSS.CURSOR.NOT_ALLOWED : '',\n        CSS.OVERFLOW.XY.HIDDEN,\n      ]\"\n      @click=\"expandOptions\"\n    >\n      <div :class=\"[CSS.DISPLAY.FLEX, CSS.FLEX.DIRECTION.COLUMN, CSS.WIDTH.FULL]\">\n        <label\n          :class=\"[\n            hasMinilabel ? ['minilabel', CSS.FONT.ROLE.LABEL_3] : CSS.FONT.ROLE.LABEL_1,\n            CSS.POSITION.ABSOLUTE,\n            CSS.POSITIONING.LEFT,\n            CSS.MARGIN.TOP.HALF,\n            CSS.MARGIN.LEFT.ONE,\n            !showError && CSS.FONT.COLOR.SURFACE.VARIANT,\n            CSS.POINTER_EVENTS.OFF,\n          ]\"\n          :for=\"inputId\"\n          v-if=\"label\"\n        >\n          {{ formattedLabel }}\n        </label>\n\n        <select\n          :class=\"[\n            CSS.PADDING.BOTTOM.HALF,\n            CSS.PADDING.X.ONE,\n            CSS.WIDTH.FULL,\n            disabled && CSS.CURSOR.NOT_ALLOWED,\n            CSS.FONT.ROLE.BODY_1,\n          ]\"\n          :disabled=\"disabled\"\n          :name=\"name\"\n          ref=\"selectElement\"\n          :required=\"required\"\n          @focus=\"handleFocus\"\n          @focusout=\"handleFocusOut\"\n          :id=\"inputId\"\n          v-model=\"modelValue\"\n        >\n          <template v-for=\"optgroup in props.optgroups\">\n            <optgroup\n              :class=\"[CSS.WIDTH.FULL, CSS.BG.SURFACE.DEFAULT]\"\n              :key=\"(optgroup as SelectOptionGroup).label\"\n              :label=\"(optgroup as SelectOptionGroup).label\"\n              v-if=\"(optgroup as SelectOptionGroup).options\"\n            >\n              <option\n                :class=\"[CSS.WIDTH.FULL, CSS.BG.SURFACE.DEFAULT]\"\n                :key=\"option.value\"\n                :value=\"option.value\"\n                v-for=\"option in (optgroup as SelectOptionGroup).options\"\n              >\n                {{ option.label }}\n              </option>\n            </optgroup>\n\n            <option\n              :class=\"[CSS.WIDTH.FULL, CSS.BG.SURFACE.DEFAULT]\"\n              :key=\"(optgroup as SelectOption).value\"\n              :selected=\"modelValue === (optgroup as SelectOption).value ? true : undefined\"\n              :value=\"(optgroup as SelectOption).value\"\n              v-else\n            >\n              {{ (optgroup as SelectOption).label }}\n            </option>\n          </template>\n\n          <option\n            :class=\"[CSS.WIDTH.FULL, CSS.BG.SURFACE.DEFAULT]\"\n            :key=\"option.value\"\n            :selected=\"modelValue === option.value ? true : undefined\"\n            :value=\"option.value\"\n            v-for=\"option in options\"\n          >\n            {{ option.label }}\n          </option>\n        </select>\n      </div>\n\n      <TideIcon\n        :class=\"[CSS.POSITION.ABSOLUTE, CSS.POSITIONING.RIGHT, CSS.MARGIN.RIGHT.ONE, CSS.POINTER_EVENTS.OFF]\"\n        :icon=\"ICON.EXPAND_MORE\"\n        :size=\"SIZE.SMALL\"\n      />\n    </div>\n\n    <TideInputSupportingText\n      :is-error=\"showError\"\n      :message=\"supportingTextMessage\"\n      v-if=\"supportingTextMessage\"\n    />\n  </div>\n</template>\n\n<style scoped>\n  select {\n    appearance: none;\n  }\n\n  label {\n    height: 1.1875rem;\n    transition: font-size var(--tide-animate), transform var(--tide-animate);\n  }\n\n  label:not(.minilabel) {\n    transform: translate(0, calc(9 / 16 * 1rem));\n  }\n\n  .tide-input-select.disabled {\n    opacity: var(--tide-disabled);\n  }\n\n  .tide-input-select.error .tide-input-border {\n    outline-color: var(--tide-error-border);\n    background-color: var(--tide-error-surface);\n  }\n\n  .tide-input-select.error:focus-within .tide-input-border {\n    outline-color: var(--tide-error-border);\n  }\n\n  .tide-input-select:focus-within .tide-input-border {\n    --tide-input-outline-width: var(--tide-border-width-2);\n    outline-color: var(--tide-surface-border-high);\n  }\n\n  .tide-input-border {\n    --tide-input-outline-width: var(--tide-border-width-1);\n    outline: var(--tide-input-outline-width) solid var(--tide-border);\n    outline-offset: calc(var(--tide-input-outline-width) * -1);\n  }\n\n  .tide-input-select.error {\n    color: var(--tide-error-primary);\n  }\n\n  .tide-input-select.error option {\n    color: var(--tide-on-surface);\n  }\n\n  select {\n    padding-top: 27px;\n  }\n</style>\n","import { priceToNumber } from '@/utilities/format';\n\nimport type { StringInput } from '@/types/FormDeprecated';\nimport type { SelectOption } from '@/types/Select';\nimport type { ValidationError, ValidationLength, ValidationResult, Validator } from '@/types/ValidationDeprecated';\nimport type { Ref } from 'vue';\n\n/**\n * @deprecated\n */\ntype RangeData = {\n  min: number | null;\n  max: number | null;\n};\n\n/**\n * @deprecated\n */\nexport const errorMessageDefault = 'Please enter a valid value.';\n\n/**\n * @deprecated\n */\nexport const noError = {\n  message: '',\n  valid: true,\n} as Readonly<ValidationResult>;\n\n/**\n * @deprecated\n */\nexport const checkFormat = (format: RegExp) => {\n  return (value: string): ValidationResult => {\n    let result = noError;\n\n    if (!value.trim().match(format)) {\n      result = {\n        message: errorMessageDefault,\n        valid: false,\n      };\n    }\n\n    return result;\n  };\n};\n\n/**\n * @deprecated\n */\nexport const getErrorMessage = (errorFromProps: ValidationError, errorFromRef: ValidationError) => {\n  // error in props takes precedence over validation error\n  if (typeof errorFromProps === 'string' && errorFromProps.length > 0) return errorFromProps;\n\n  return typeof errorFromRef === 'string' && errorFromRef.length > 0 ? errorFromRef : errorMessageDefault;\n};\n\n/**\n * @deprecated\n */\nexport const getFieldHasError = (errorFromProps: ValidationError, errorFromRef: ValidationError) =>\n  errorFromProps !== false || errorFromRef !== false;\n\n/**\n * @deprecated\n */\nexport const getFieldLengthIsValid = ({ maxlength, minlength, required, value }: ValidationLength) => {\n  const isEmptyAndUnrequired = value.length === 0 && !required;\n  const isTooLong = maxlength && value.length > maxlength;\n  const isTooShort = !isEmptyAndUnrequired && minlength && value.length < minlength;\n\n  return !isTooShort && !isTooLong;\n};\n\n/**\n * @deprecated\n */\nexport const getMaxRangeIsValid = ({ min }: Pick<RangeData, 'min'>, type?: 'price') => {\n  return (value: string): ValidationResult => {\n    let newMax: number | null = type === 'price' ? priceToNumber(value) : Number(value);\n    newMax = !isNaN(newMax) ? newMax : null;\n    if (min && newMax) {\n      if (newMax >= min) {\n        return {\n          message: '',\n          valid: true,\n        };\n      } else {\n        return {\n          message: `Must be greater than min`,\n          valid: false,\n        };\n      }\n    } else {\n      return noError;\n    }\n  };\n};\n\n/**\n * @deprecated\n */\nexport const getMinRangeIsValid = ({ max }: Pick<RangeData, 'max'>, type?: 'price') => {\n  return (value: string): ValidationResult => {\n    let newMin: number | null = type === 'price' ? priceToNumber(value) : Number(value);\n    newMin = !isNaN(newMin) ? newMin : null;\n    if (max && newMin) {\n      if (newMin <= max) {\n        return {\n          message: '',\n          valid: true,\n        };\n      } else {\n        return {\n          message: `Must be less than max`,\n          valid: false,\n        };\n      }\n    } else {\n      return noError;\n    }\n  };\n};\n\n/**\n * @deprecated\n */\nexport const getSelectOptionsFromStrings = (strings: string[]) =>\n  strings.map(\n    (option) =>\n      ({\n        label: option,\n        value: option,\n      } as SelectOption)\n  );\n\n/**\n * @deprecated\n */\nexport const handleFieldValidation = ({\n  error,\n  errorFromProps,\n  maxlength,\n  minlength,\n  required = false,\n  validators,\n  value,\n}: {\n  error: Ref<ValidationError>;\n  errorFromProps: ValidationError;\n  maxlength?: number;\n  minlength?: number;\n  required?: boolean;\n  validators?: Validator[];\n  value?: Ref<string | undefined>;\n}) => {\n  // error in props takes precedence over validation error\n\n  error.value = errorFromProps ? errorFromProps : false;\n\n  if (!error.value && validators) {\n    const validation = validateProperty(value?.value || '', validators);\n\n    if (!validation.valid) {\n      error.value = validation.message;\n    }\n  }\n\n  if (!error.value && (maxlength || minlength)) {\n    const lengthValidation = validateLength({\n      maxlength,\n      minlength,\n      required,\n      value: value?.value || '',\n    });\n\n    if (!lengthValidation.valid) {\n      error.value = lengthValidation.message;\n    }\n  }\n};\n\n/**\n * @deprecated\n */\nexport function validateFieldsFromRefs(fields: { [key: string]: Ref<StringInput | null> }) {\n  let valid = true;\n\n  for (const key in fields) {\n    if (fields[key].value?.required) {\n      const value = fields[key].value?.value;\n      valid = valid && !!value && value.trim() !== '';\n    }\n\n    const error = fields[key].value?.error;\n    valid = valid && !error;\n  }\n\n  return valid;\n}\n\n/**\n * @deprecated\n */\nexport const validateLength = ({\n  maxlength,\n  minlength,\n  required = false,\n  value,\n}: ValidationLength): ValidationResult => {\n  const response = {\n    message: '',\n    valid: true,\n  };\n\n  response.valid = getFieldLengthIsValid({\n    maxlength,\n    minlength,\n    required,\n    value,\n  });\n\n  if (response.valid) return response;\n\n  response.message = errorMessageDefault;\n\n  if (maxlength && minlength) {\n    response.message = `Please enter a value between ${minlength} and ${maxlength} characters in length.`;\n  } else if (maxlength) {\n    response.message = `Please enter a value no more than ${maxlength} characters in length.`;\n  } else if (minlength) {\n    response.message = `Please enter a value no less than ${minlength} characters in length.`;\n  }\n\n  return response;\n};\n\n/**\n * @deprecated\n */\nexport function validateProperty(value: string, validators: ((value: string) => ValidationResult)[]): ValidationResult {\n  for (const validator of validators) {\n    const validation = validator(value);\n    if (!validation.valid) {\n      return validation;\n    }\n  }\n\n  return {\n    message: '',\n    valid: true,\n  };\n}\n","<script lang=\"ts\">\n  /**\n   * @deprecated Use `TideInputSelect.vue` imported from 'tide-design-system' npm package instead.\n   */\n  export default {};\n</script>\n\n<script lang=\"ts\" setup>\n  import { computed, ref, watch } from 'vue';\n\n  import TideIcon from '@/components/TideIcon.vue';\n  import { ICON } from '@/types/Icon';\n  import { SIZE } from '@/types/Size';\n  import { CSS } from '@/types/Styles';\n  import { getErrorMessage, getFieldHasError } from '@/utilities/validation-deprecated';\n\n  import type { SelectField } from '@/types/FieldDeprecated';\n  import type { SelectOption, SelectOptionGroup } from '@/types/Select';\n\n  export interface Props extends SelectField {\n    inputId?: string;\n    supportingText?: string;\n  }\n\n  const props = withDefaults(defineProps<Props>(), {\n    disabled: false,\n    error: false,\n    inputId: undefined,\n    label: undefined,\n    required: false,\n    supportingText: undefined,\n    value: undefined,\n  });\n\n  const error = ref(props.error);\n  const hasFocus = ref(false);\n  const input = ref<HTMLSelectElement | null>(null);\n  const required = ref(props.required);\n  const value = ref<string | undefined>(props.value);\n\n  const errorMessage = computed(() => getErrorMessage(props.error, error.value));\n  const formattedLabel = computed(() => (props.required ? `${props.label} *` : props.label));\n  const hasError = computed(() => (props.required && !value.value) || getFieldHasError(error.value, props.error));\n  const hasMinilabel = computed(() => hasFocus.value || !isEmpty.value);\n  const isEmpty = computed(() => value.value === undefined);\n\n  const expandOptions = () => {\n    const event = new MouseEvent('mousedown');\n    input?.value?.dispatchEvent(event);\n  };\n\n  const handleFocus = () => {\n    hasFocus.value = true;\n  };\n\n  const handleFocusOut = () => {\n    hasFocus.value = false;\n  };\n\n  watch(\n    () => props.value,\n    (newValue, oldValue) => {\n      if (newValue !== oldValue || newValue !== value.value) {\n        value.value = newValue;\n      }\n    }\n  );\n\n  defineExpose({ error, value });\n</script>\n\n<template>\n  <div\n    :class=\"[\n      'tide-input-select',\n      CSS.DISPLAY.FLEX,\n      CSS.FLEX.DIRECTION.COLUMN,\n      CSS.GAP.QUARTER,\n      disabled && 'disabled',\n      hasError && 'error',\n    ]\"\n  >\n    <div\n      :class=\"[\n        'tide-input-border',\n        CSS.POSITION.RELATIVE,\n        CSS.DISPLAY.FLEX,\n        CSS.AXIS2.CENTER,\n        CSS.GAP.HALF,\n        CSS.BORDER.RADIUS.HALF,\n        CSS.BG.SURFACE.DEFAULT,\n        props.disabled ? CSS.CURSOR.NOT_ALLOWED : '',\n        CSS.OVERFLOW.XY.HIDDEN,\n      ]\"\n      @click=\"expandOptions\"\n    >\n      <div :class=\"[CSS.DISPLAY.FLEX, CSS.FLEX.DIRECTION.COLUMN, CSS.WIDTH.FULL]\">\n        <label\n          :class=\"[\n            hasMinilabel ? ['minilabel', CSS.FONT.ROLE.LABEL_3] : CSS.FONT.ROLE.LABEL_1,\n            CSS.POSITION.ABSOLUTE,\n            CSS.POSITIONING.LEFT,\n            CSS.MARGIN.TOP.HALF,\n            CSS.MARGIN.LEFT.ONE,\n            !hasError && CSS.FONT.COLOR.SURFACE.VARIANT,\n            CSS.POINTER_EVENTS.OFF,\n          ]\"\n          :for=\"props.inputId\"\n          v-if=\"label\"\n        >\n          {{ formattedLabel }}\n        </label>\n\n        <select\n          :class=\"[\n            CSS.PADDING.BOTTOM.HALF,\n            CSS.PADDING.X.ONE,\n            CSS.WIDTH.FULL,\n            disabled && CSS.CURSOR.NOT_ALLOWED,\n            CSS.FONT.ROLE.BODY_1,\n          ]\"\n          :disabled=\"disabled\"\n          :name=\"name\"\n          ref=\"input\"\n          :required=\"required\"\n          @focus=\"handleFocus\"\n          @focusout=\"handleFocusOut\"\n          :id=\"props.inputId\"\n          v-model=\"value\"\n        >\n          <template v-for=\"optgroup in props.optgroups\">\n            <optgroup\n              :class=\"[CSS.WIDTH.FULL, CSS.BG.SURFACE.DEFAULT]\"\n              :key=\"(optgroup as SelectOptionGroup).label\"\n              :label=\"(optgroup as SelectOptionGroup).label\"\n              v-if=\"(optgroup as SelectOptionGroup).options\"\n            >\n              <option\n                :class=\"[CSS.WIDTH.FULL, CSS.BG.SURFACE.DEFAULT]\"\n                :key=\"option.value\"\n                :value=\"option.value\"\n                v-for=\"option in (optgroup as SelectOptionGroup).options\"\n              >\n                {{ option.label }}\n              </option>\n            </optgroup>\n\n            <option\n              :class=\"[CSS.WIDTH.FULL, CSS.BG.SURFACE.DEFAULT]\"\n              :key=\"(optgroup as SelectOption).value\"\n              :selected=\"value === (optgroup as SelectOption).value ? true : undefined\"\n              :value=\"(optgroup as SelectOption).value\"\n              v-else\n            >\n              {{ (optgroup as SelectOption).label }}\n            </option>\n          </template>\n\n          <option\n            :class=\"[CSS.WIDTH.FULL, CSS.BG.SURFACE.DEFAULT]\"\n            :key=\"option.value\"\n            :selected=\"value === option.value ? true : undefined\"\n            :value=\"option.value\"\n            v-for=\"option in options\"\n          >\n            {{ option.label }}\n          </option>\n        </select>\n      </div>\n\n      <TideIcon\n        :class=\"[CSS.POSITION.ABSOLUTE, CSS.POSITIONING.RIGHT, CSS.MARGIN.RIGHT.ONE, CSS.POINTER_EVENTS.OFF]\"\n        :icon=\"ICON.EXPAND_MORE\"\n        :size=\"SIZE.SMALL\"\n      />\n    </div>\n\n    <div\n      :class=\"[CSS.DISPLAY.FLEX, CSS.AXIS2.CENTER, CSS.GAP.QUARTER]\"\n      v-if=\"props.supportingText || hasError\"\n    >\n      <TideIcon\n        :class=\"[]\"\n        :icon=\"ICON.ERROR\"\n        :size=\"SIZE.SMALL\"\n        v-if=\"hasError\"\n      />\n\n      <div :class=\"[CSS.FONT.ROLE.LABEL_3]\">\n        {{ hasError ? errorMessage : props.supportingText }}\n      </div>\n    </div>\n  </div>\n</template>\n\n<style scoped>\n  select {\n    appearance: none;\n  }\n\n  label {\n    height: 1.1875rem;\n    transition: font-size var(--tide-animate), transform var(--tide-animate);\n  }\n\n  label:not(.minilabel) {\n    transform: translate(0, calc(9 / 16 * 1rem));\n  }\n\n  .tide-input-select.disabled {\n    opacity: var(--tide-disabled);\n  }\n\n  .tide-input-select.error .tide-input-border {\n    outline-color: var(--tide-error-border);\n    background-color: var(--tide-error-surface);\n  }\n\n  .tide-input-select.error:focus-within .tide-input-border {\n    outline-color: var(--tide-error-border);\n  }\n\n  .tide-input-select:focus-within .tide-input-border {\n    --tide-input-outline-width: var(--tide-border-width-2);\n    outline-color: var(--tide-surface-border-high);\n  }\n\n  .tide-input-border {\n    --tide-input-outline-width: var(--tide-border-width-1);\n    outline: var(--tide-input-outline-width) solid var(--tide-border);\n    outline-offset: calc(var(--tide-input-outline-width) * -1);\n  }\n\n  .tide-input-select.error {\n    color: var(--tide-error-primary);\n  }\n\n  .tide-input-select.error option {\n    color: var(--tide-on-surface);\n  }\n\n  select {\n    padding-top: 27px;\n  }\n</style>\n","export const TEXT_INPUT_TYPE = {\n  DATE: 'date',\n  DATETIME_LOCAL: 'datetime-local',\n  EMAIL: 'email',\n  MONTH: 'month',\n  NUMBER: 'number',\n  PASSWORD: 'password',\n  SEARCH: 'search',\n  TEL: 'tel',\n  TEXT: 'text',\n  TIME: 'time',\n  URL: 'url',\n  WEEK: 'week',\n} as const;\n\nexport type TextInputType = (typeof TEXT_INPUT_TYPE)[keyof typeof TEXT_INPUT_TYPE];\n\nexport const INPUT_MODE = {\n  DECIMAL: 'decimal',\n  EMAIL: 'email',\n  NUMERIC: 'numeric',\n  SEARCH: 'search',\n  TEL: 'tel',\n  TEXT: 'text',\n  URL: 'url',\n} as const;\n\nexport type InputMode = (typeof INPUT_MODE)[keyof typeof INPUT_MODE];\n","import { INPUT_MODE, TEXT_INPUT_TYPE } from '@/types/TextInput';\n\nimport type { InputMode, TextInputType } from '@/types/TextInput';\n\nexport const getTextInputMode = (type: TextInputType, inputmode?: InputMode): InputMode | undefined => {\n  if (inputmode) return inputmode;\n\n  switch (type) {\n    case TEXT_INPUT_TYPE.TEL:\n      return INPUT_MODE.TEL;\n    case TEXT_INPUT_TYPE.SEARCH:\n      return INPUT_MODE.SEARCH;\n    case TEXT_INPUT_TYPE.NUMBER:\n      return INPUT_MODE.NUMERIC;\n    case TEXT_INPUT_TYPE.EMAIL:\n      return INPUT_MODE.EMAIL;\n    case TEXT_INPUT_TYPE.URL:\n      return INPUT_MODE.URL;\n  }\n\n  return undefined;\n};\n","<script setup lang=\"ts\">\n  import { computed, ref, watch, watchEffect } from 'vue';\n\n  import TideIcon from '@/components/TideIcon.vue';\n  import TideInputSupportingText from '@/components/TideInputSupportingText.vue';\n  import { useFormContext } from '@/composables/useTideForm';\n  import { ICON } from '@/types/Icon';\n  import { SIZE } from '@/types/Size';\n  import { CSS } from '@/types/Styles';\n  import { TEXT_INPUT_TYPE } from '@/types/TextInput';\n  import { ERROR_DISPLAY } from '@/types/Validation';\n  import { getTextInputMode } from '@/utilities/forms';\n  import { VALIDATION_RESULT, getFieldValidationResult } from '@/utilities/validation';\n\n  import type { FormValueTransformer } from '@/types/Form';\n  import type { Icon } from '@/types/Icon';\n  import type { InputMode, TextInputType } from '@/types/TextInput';\n  import type { ErrorDisplay, ValidationResult, Validator } from '@/types/Validation';\n\n  type Props = {\n    autocomplete?: boolean;\n    disabled?: boolean;\n    error?: string;\n    errorDisplay?: ErrorDisplay;\n    hasClear?: boolean;\n    iconLeading?: Icon;\n    inputId?: string;\n    inputmode?: InputMode;\n    label?: string;\n    maxlength?: number;\n    minlength?: number;\n    name?: string;\n    prefix?: string;\n    required?: boolean;\n    suffix?: string;\n    supportingText?: string;\n    transformValue?: FormValueTransformer;\n    type?: TextInputType;\n    validators?: Validator[];\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    autocomplete: false,\n    disabled: false,\n    error: '',\n    errorDisplay: ERROR_DISPLAY.LAZY,\n    hasClear: false,\n    iconLeading: undefined,\n    inputId: undefined,\n    inputmode: undefined,\n    label: undefined,\n    maxlength: undefined,\n    minlength: undefined,\n    name: undefined,\n    prefix: undefined,\n    required: false,\n    suffix: undefined,\n    supportingText: undefined,\n    transformValue: undefined,\n    type: TEXT_INPUT_TYPE.TEXT,\n    validators: undefined,\n  });\n\n  type Emits = {\n    (event: 'valid', isValid: boolean): void;\n  };\n  const emit = defineEmits<Emits>();\n\n  const modelValue = defineModel<string>({ required: true });\n\n  const formContext = useFormContext();\n\n  const errorRef = ref<ValidationResult>(VALIDATION_RESULT.NO_ERROR);\n  const hasFocus = ref<boolean>(false);\n  const inputElement = ref<HTMLInputElement | null>(null);\n  const isValidating = ref<boolean>(false);\n  const showPassword = ref<boolean>(false);\n\n  const formattedLabel = computed(() => (props.required && props.label ? `${props.label} *` : props.label));\n  const showError = computed(() => {\n    if (hasErrorFromProp.value) return true;\n    if (!isValidating.value) return false;\n    return !errorRef.value.valid;\n  });\n  const hasErrorFromProp = computed(() => props.error !== '');\n  const hasMinilabel = computed(() => hasFocus.value || !isEmpty.value);\n  const inputModeAttribute = computed<InputMode | undefined>(() => getTextInputMode(props.type, props.inputmode));\n  const inputType = computed(() =>\n    props.type === TEXT_INPUT_TYPE.PASSWORD && showPassword.value === true ? TEXT_INPUT_TYPE.TEXT : props.type\n  );\n  const isEmpty = computed(() => modelValue.value === '');\n  const shouldShowClearButton = computed(\n    () => props.hasClear && modelValue.value && props.type !== TEXT_INPUT_TYPE.PASSWORD\n  );\n  const shouldShowPasswordButton = computed(() => props.type === TEXT_INPUT_TYPE.PASSWORD);\n  const supportingTextMessage = computed(() => (showError.value && errorRef.value.message) || props.supportingText);\n\n  const handleClear = () => {\n    modelValue.value = '';\n    inputElement.value?.focus();\n  };\n\n  const handleFocus = () => {\n    hasFocus.value = true;\n    if (props.errorDisplay === ERROR_DISPLAY.EAGER) isValidating.value = true;\n  };\n\n  const handleFocusOut = () => {\n    hasFocus.value = false;\n    if (props.errorDisplay === ERROR_DISPLAY.LAZY) isValidating.value = true;\n  };\n\n  const handleFieldClick = () => {\n    inputElement.value?.focus();\n  };\n\n  const preventInputFocusLossOnMousedown = (e: MouseEvent) => {\n    if (!hasFocus.value) return;\n    if (e.target !== inputElement.value) e.preventDefault();\n  };\n\n  watchEffect(() => {\n    errorRef.value = getFieldValidationResult({\n      errorFromProps: props.error,\n      maxlength: props.maxlength,\n      minlength: props.minlength,\n      required: props.required,\n      validators: props.validators,\n      value: modelValue,\n    });\n  });\n\n  watch(\n    [modelValue, () => props.transformValue],\n    () => {\n      if (!props.transformValue) return;\n\n      const digits = modelValue.value?.match(/\\d/g)?.join('') || undefined;\n      modelValue.value = digits ? props.transformValue(digits) : '';\n    },\n    { immediate: true }\n  );\n\n  watch(\n    () => formContext?.forceShowErrors.value,\n    (newValue) => {\n      if (newValue) isValidating.value = true;\n    },\n    { immediate: true }\n  );\n\n  watch(\n    errorRef,\n    () => {\n      emit('valid', errorRef.value.valid);\n    },\n    { deep: true, immediate: true }\n  );\n</script>\n\n<template>\n  <div\n    :class=\"[\n      'tide-input-text',\n      CSS.DISPLAY.FLEX,\n      CSS.FLEX.DIRECTION.COLUMN,\n      CSS.GAP.QUARTER,\n      disabled && 'disabled',\n      showError && 'error',\n    ]\"\n  >\n    <label\n      :class=\"[\n        'tide-input-text-field',\n        CSS.DISPLAY.FLEX,\n        CSS.AXIS2.CENTER,\n        CSS.GAP.HALF,\n        CSS.POSITION.RELATIVE,\n        CSS.BORDER.RADIUS.HALF,\n        CSS.BG.SURFACE.DEFAULT,\n        CSS.PADDING.Y.HALF,\n        shouldShowClearButton ? [CSS.PADDING.RIGHT.HALF, CSS.PADDING.LEFT.ONE] : [CSS.PADDING.X.ONE],\n        disabled ? CSS.CURSOR.NOT_ALLOWED : CSS.CURSOR.TEXT,\n      ]\"\n      :for=\"inputId\"\n      @click=\"handleFieldClick\"\n      @mousedown=\"preventInputFocusLossOnMousedown\"\n    >\n      <TideIcon\n        :class=\"[CSS.FONT.COLOR.SURFACE.VARIANT]\"\n        :icon=\"iconLeading\"\n        :size=\"SIZE.SMALL\"\n        v-if=\"iconLeading\"\n      />\n\n      <div :class=\"[CSS.DISPLAY.FLEX, CSS.AXIS2.CENTER, CSS.GAP.QUARTER, CSS.WIDTH.FULL]\">\n        <div\n          :class=\"[\n            'tide-input-text-prefix',\n            CSS.FONT.ROLE.BODY_1,\n            !showError && CSS.FONT.COLOR.SURFACE.VARIANT,\n            hasMinilabel ? '' : 'offset',\n          ]\"\n          v-if=\"prefix\"\n        >\n          {{ prefix }}\n        </div>\n\n        <div :class=\"[CSS.DISPLAY.FLEX, CSS.FLEX.DIRECTION.COLUMN, CSS.WIDTH.FULL]\">\n          <div\n            :class=\"[\n              'tide-input-text-label',\n              hasMinilabel ? ['minilabel', CSS.FONT.ROLE.LABEL_3] : CSS.FONT.ROLE.LABEL_1,\n              !showError && CSS.FONT.COLOR.SURFACE.VARIANT,\n              CSS.CURSOR.TEXT,\n              CSS.POINTER_EVENTS.OFF,\n            ]\"\n            v-if=\"label\"\n          >\n            {{ formattedLabel }}\n          </div>\n\n          <input\n            :autocomplete=\"autocomplete ? 'on' : 'off'\"\n            :class=\"[CSS.WIDTH.FULL, CSS.FONT.ROLE.BODY_1, disabled && CSS.CURSOR.NOT_ALLOWED]\"\n            :disabled=\"disabled\"\n            :inputmode=\"inputModeAttribute\"\n            :maxlength=\"maxlength\"\n            :minlength=\"minlength\"\n            :name=\"name\"\n            ref=\"inputElement\"\n            :required=\"required\"\n            :type=\"inputType\"\n            @focus=\"handleFocus\"\n            @focusout=\"handleFocusOut\"\n            :id=\"inputId\"\n            v-model=\"modelValue\"\n          />\n        </div>\n\n        <div\n          :class=\"[\n            'tide-input-text-suffix',\n            CSS.FONT.ROLE.BODY_1,\n            !showError && CSS.FONT.COLOR.SURFACE.VARIANT,\n            hasMinilabel ? '' : 'offset',\n          ]\"\n          v-if=\"suffix\"\n        >\n          {{ suffix }}\n        </div>\n      </div>\n\n      <button\n        @click=\"handleClear\"\n        v-if=\"shouldShowClearButton\"\n      >\n        <TideIcon\n          :class=\"[CSS.MARGIN.FULL.HALF]\"\n          :icon=\"ICON.CLOSE\"\n          :size=\"SIZE.SMALL\"\n        />\n      </button>\n\n      <button\n        @click=\"showPassword = !showPassword\"\n        v-if=\"shouldShowPasswordButton\"\n      >\n        <TideIcon\n          :class=\"[CSS.MARGIN.FULL.HALF]\"\n          :icon=\"ICON.VISIBILITY\"\n          :size=\"SIZE.SMALL\"\n        />\n      </button>\n    </label>\n\n    <TideInputSupportingText\n      :is-error=\"showError\"\n      :message=\"supportingTextMessage\"\n      v-if=\"supportingTextMessage\"\n    />\n  </div>\n</template>\n\n<style scoped>\n  .tide-input-text-label {\n    height: 1.1875rem;\n    transition: font-size var(--tide-animate), transform var(--tide-animate);\n  }\n\n  .tide-input-text-label:not(.minilabel),\n  .tide-input-text-prefix:not(.offset),\n  .tide-input-text-suffix:not(.offset) {\n    transform: translate(0, calc(9 / 16 * 1rem));\n  }\n\n  .tide-input-text-prefix,\n  .tide-input-text-suffix {\n    transition: transform var(--tide-animate);\n  }\n\n  .tide-input-text.disabled {\n    opacity: var(--tide-disabled);\n  }\n\n  .tide-input-text.error {\n    color: var(--tide-error-primary);\n  }\n\n  .tide-input-text.error .tide-input-text-field {\n    outline-color: var(--tide-error-border);\n    background-color: var(--tide-error-surface);\n  }\n\n  .tide-input-text.error:focus-within .tide-input-text-field {\n    outline-color: var(--tide-error-border);\n  }\n\n  .tide-input-text:focus-within .tide-input-text-field {\n    --tide-input-outline-width: var(--tide-border-width-2);\n    outline-color: var(--tide-surface-border-high);\n  }\n\n  .tide-input-text input {\n    outline: none;\n  }\n\n  .tide-input-text-field {\n    --tide-input-outline-width: var(--tide-border-width-1);\n    outline: var(--tide-input-outline-width) solid var(--tide-border);\n    outline-offset: calc(var(--tide-input-outline-width) * -1);\n    color: var(--tide-surface-foreground);\n  }\n</style>\n","<script lang=\"ts\">\n  /**\n   * @deprecated Use `TideInputText.vue` imported from 'tide-design-system' npm package instead.\n   */\n  export default {};\n</script>\n\n<script lang=\"ts\" setup>\n  import { computed, ref, watch } from 'vue';\n\n  import TideIcon from '@/components/TideIcon.vue';\n  import { ICON } from '@/types/Icon';\n  import { SIZE } from '@/types/Size';\n  import { CSS } from '@/types/Styles';\n  import { TEXT_INPUT_TYPE } from '@/types/TextInput';\n  import { getErrorMessage, getFieldHasError, handleFieldValidation } from '@/utilities/validation-deprecated';\n\n  import type { FormValueTransformer } from '@/types/FormDeprecated';\n  import type { Icon } from '@/types/Icon';\n  import type { TextInputType } from '@/types/TextInput';\n  import type { ValidationError, Validator } from '@/types/ValidationDeprecated';\n\n  type Props = {\n    autocomplete?: boolean;\n    disabled?: boolean;\n    error?: ValidationError;\n    hasClear?: boolean;\n    iconLeading?: Icon;\n    inputId?: string;\n    label?: string;\n    maxlength?: number | undefined;\n    minlength?: number | undefined;\n    name?: string;\n    prefix?: string;\n    required?: boolean;\n    suffix?: string;\n    supportingText?: string;\n    transformValue?: FormValueTransformer;\n    type?: TextInputType;\n    validators?: Validator[];\n    value?: string;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    autocomplete: false,\n    disabled: false,\n    error: false,\n    hasClear: false,\n    iconLeading: undefined,\n    inputId: undefined,\n    label: undefined,\n    maxlength: undefined,\n    minlength: undefined,\n    name: undefined,\n    prefix: undefined,\n    required: false,\n    suffix: undefined,\n    supportingText: undefined,\n    transformValue: undefined,\n    type: TEXT_INPUT_TYPE.TEXT,\n    validators: undefined,\n    value: undefined,\n  });\n\n  const error = ref(props.error);\n  const hasFocus = ref(false);\n  const input = ref<HTMLInputElement | null>(null);\n  const showPassword = ref(false);\n  const value = ref(props.value);\n\n  const errorMessage = computed(() => getErrorMessage(props.error, error.value));\n  const formattedLabel = computed(() => (props.required && props.label ? `${props.label} *` : props.label));\n  const hasClear = computed(() => props.hasClear && value.value);\n  const hasError = computed(\n    () => (props.required && value.value !== undefined && !value.value) || getFieldHasError(error.value, props.error)\n  );\n  const hasMinilabel = computed(() => hasFocus.value || !isEmpty.value);\n  const isEmpty = computed(() => value.value === '' || value.value === undefined);\n  const inputType = computed(() =>\n    props.type === TEXT_INPUT_TYPE.PASSWORD && showPassword.value === true ? TEXT_INPUT_TYPE.TEXT : props.type\n  );\n\n  const handleClear = () => {\n    value.value = '';\n    input.value?.focus();\n  };\n\n  const handleFocus = () => {\n    hasFocus.value = true;\n  };\n\n  const handleFocusOut = () => {\n    hasFocus.value = false;\n\n    if (!value.value) {\n      value.value = '';\n    }\n\n    handleValidation();\n  };\n\n  const handleInput = () => {\n    if (props.transformValue) {\n      const digits = value.value?.match(/\\d/g)?.join('') || undefined;\n\n      value.value = digits ? props.transformValue(digits) : '';\n    }\n  };\n\n  const handleValidation = () => {\n    handleFieldValidation({\n      error,\n      errorFromProps: props.error,\n      maxlength: props.maxlength,\n      minlength: props.minlength,\n      required: props.required,\n      validators: props.validators,\n      value,\n    });\n  };\n\n  const updateValue = (newValue: string) => {\n    value.value = newValue;\n  };\n\n  watch(\n    () => props.value,\n    (newValue, oldValue) => {\n      if (newValue !== oldValue || newValue !== value.value) {\n        value.value = newValue;\n      }\n    }\n  );\n\n  defineExpose({\n    error,\n    required: props.required,\n    updateValue,\n    value,\n  });\n</script>\n\n<template>\n  <div\n    :class=\"[\n      'tide-input-text',\n      CSS.DISPLAY.FLEX,\n      CSS.FLEX.DIRECTION.COLUMN,\n      CSS.GAP.QUARTER,\n      disabled && 'disabled',\n      hasError && 'error',\n    ]\"\n  >\n    <label\n      :class=\"[\n        'tide-input-text-field',\n        CSS.DISPLAY.FLEX,\n        CSS.AXIS2.CENTER,\n        CSS.GAP.HALF,\n        CSS.POSITION.RELATIVE,\n        CSS.BORDER.RADIUS.HALF,\n        CSS.BG.SURFACE.DEFAULT,\n        hasClear ? [CSS.PADDING.RIGHT.HALF, CSS.PADDING.LEFT.ONE] : [CSS.PADDING.X.ONE],\n        CSS.PADDING.Y.HALF,\n        disabled ? CSS.CURSOR.NOT_ALLOWED : CSS.CURSOR.TEXT,\n      ]\"\n      :for=\"inputId\"\n    >\n      <TideIcon\n        :class=\"[CSS.FONT.COLOR.SURFACE.VARIANT]\"\n        :icon=\"iconLeading\"\n        :size=\"SIZE.SMALL\"\n        v-if=\"iconLeading\"\n      />\n\n      <div :class=\"[CSS.DISPLAY.FLEX, CSS.AXIS2.CENTER, CSS.GAP.QUARTER, CSS.WIDTH.FULL]\">\n        <div\n          :class=\"[\n            'tide-input-text-prefix',\n            CSS.FONT.ROLE.BODY_1,\n            !hasError && CSS.FONT.COLOR.SURFACE.VARIANT,\n            hasMinilabel ? '' : 'offset',\n          ]\"\n          v-if=\"prefix\"\n        >\n          {{ prefix }}\n        </div>\n\n        <div :class=\"[CSS.DISPLAY.FLEX, CSS.FLEX.DIRECTION.COLUMN, CSS.WIDTH.FULL]\">\n          <div\n            :class=\"[\n              'tide-input-text-label',\n              hasMinilabel ? ['minilabel', CSS.FONT.ROLE.LABEL_3] : CSS.FONT.ROLE.LABEL_1,\n              !hasError && CSS.FONT.COLOR.SURFACE.VARIANT,\n              CSS.CURSOR.TEXT,\n              CSS.POINTER_EVENTS.OFF,\n            ]\"\n            v-if=\"label\"\n          >\n            {{ formattedLabel }}\n          </div>\n\n          <input\n            :autocomplete=\"autocomplete ? 'on' : 'off'\"\n            :class=\"[CSS.WIDTH.FULL, disabled && CSS.CURSOR.NOT_ALLOWED, CSS.FONT.ROLE.BODY_1]\"\n            :disabled=\"disabled\"\n            :maxlength=\"maxlength\"\n            :minlength=\"minlength\"\n            :name=\"name\"\n            ref=\"input\"\n            :required=\"required\"\n            :type=\"inputType\"\n            @change=\"handleValidation\"\n            @focus=\"handleFocus\"\n            @focusout=\"handleFocusOut\"\n            @input=\"handleInput\"\n            :id=\"inputId\"\n            v-model=\"value\"\n          />\n        </div>\n\n        <div\n          :class=\"[\n            'tide-input-text-suffix',\n            CSS.FONT.ROLE.BODY_1,\n            !hasError && CSS.FONT.COLOR.SURFACE.VARIANT,\n            hasMinilabel ? '' : 'offset',\n          ]\"\n          v-if=\"suffix\"\n        >\n          {{ suffix }}\n        </div>\n      </div>\n\n      <button\n        @click=\"handleClear\"\n        v-if=\"hasClear && type !== TEXT_INPUT_TYPE.PASSWORD\"\n      >\n        <TideIcon\n          :class=\"[CSS.MARGIN.FULL.HALF]\"\n          :icon=\"ICON.CLOSE\"\n          :size=\"SIZE.SMALL\"\n        />\n      </button>\n\n      <button\n        @click=\"showPassword = !showPassword\"\n        v-if=\"type === TEXT_INPUT_TYPE.PASSWORD\"\n      >\n        <TideIcon\n          :class=\"[CSS.MARGIN.FULL.HALF]\"\n          :icon=\"ICON.VISIBILITY\"\n          :size=\"SIZE.SMALL\"\n        />\n      </button>\n    </label>\n\n    <div\n      :class=\"[CSS.DISPLAY.FLEX, CSS.AXIS2.CENTER, CSS.GAP.QUARTER]\"\n      v-if=\"supportingText || hasError\"\n    >\n      <TideIcon\n        :class=\"[]\"\n        :icon=\"ICON.ERROR\"\n        :size=\"SIZE.SMALL\"\n        v-if=\"hasError\"\n      />\n\n      <div :class=\"[CSS.FONT.ROLE.LABEL_3]\">\n        {{ hasError ? errorMessage : supportingText }}\n      </div>\n    </div>\n  </div>\n</template>\n\n<style scoped>\n  .tide-input-text-label {\n    height: 1.1875rem;\n    transition: font-size var(--tide-animate), transform var(--tide-animate);\n  }\n\n  .tide-input-text-label:not(.minilabel),\n  .tide-input-text-prefix:not(.offset),\n  .tide-input-text-suffix:not(.offset) {\n    transform: translate(0, calc(9 / 16 * 1rem));\n  }\n\n  .tide-input-text-prefix,\n  .tide-input-text-suffix {\n    transition: transform var(--tide-animate);\n  }\n\n  .tide-input-text.disabled {\n    opacity: var(--tide-disabled);\n  }\n\n  .tide-input-text.error {\n    color: var(--tide-error-primary);\n  }\n\n  .tide-input-text.error .tide-input-text-field {\n    outline-color: var(--tide-error-border);\n    background-color: var(--tide-error-surface);\n  }\n\n  .tide-input-text.error:focus-within .tide-input-text-field {\n    outline-color: var(--tide-error-border);\n  }\n\n  .tide-input-text:focus-within .tide-input-text-field {\n    --tide-input-outline-width: var(--tide-border-width-2);\n    outline-color: var(--tide-surface-border-high);\n  }\n\n  .tide-input-text input {\n    outline: none;\n  }\n\n  .tide-input-text-field {\n    --tide-input-outline-width: var(--tide-border-width-1);\n    outline: var(--tide-input-outline-width) solid var(--tide-border);\n    outline-offset: calc(var(--tide-input-outline-width) * -1);\n    color: var(--tide-surface-foreground);\n  }\n</style>\n","<script lang=\"ts\" setup>\n  import { computed, ref, watch, watchEffect } from 'vue';\n\n  import TideInputSupportingText from '@/components/TideInputSupportingText.vue';\n  import { useFormContext } from '@/composables/useTideForm';\n  import { CSS } from '@/types/Styles';\n  import { ERROR_DISPLAY } from '@/types/Validation';\n  import { VALIDATION_RESULT, getFieldValidationResult } from '@/utilities/validation';\n\n  import type { ErrorDisplay, ValidationResult, Validator } from '@/types/Validation';\n\n  type Props = {\n    error?: string;\n    errorDisplay?: ErrorDisplay;\n    inputId?: string;\n    label?: string;\n    maxlength?: number | undefined;\n    minlength?: number | undefined;\n    name?: string;\n    required?: boolean;\n    rows?: number;\n    supportingText?: string;\n    validators?: Validator[];\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    error: '',\n    errorDisplay: ERROR_DISPLAY.LAZY,\n    inputId: undefined,\n    label: undefined,\n    maxlength: undefined,\n    minlength: undefined,\n    name: undefined,\n    required: false,\n    rows: 8,\n    supportingText: undefined,\n    validators: undefined,\n  });\n\n  type Emits = {\n    (event: 'valid', isValid: boolean): void;\n  };\n  const emit = defineEmits<Emits>();\n\n  const modelValue = defineModel<string>({ required: true });\n\n  const formContext = useFormContext();\n\n  const errorRef = ref<ValidationResult>(VALIDATION_RESULT.NO_ERROR);\n  const hasFocus = ref<boolean>(false);\n  const isValidating = ref<boolean>(false);\n  const textareaElement = ref<HTMLTextAreaElement | null>(null);\n\n  const formattedLabel = computed(() => (props.required ? `${props.label} *` : props.label));\n  const showError = computed(() => {\n    if (hasErrorFromProp.value) return true;\n    if (!isValidating.value) return false;\n    return !errorRef.value.valid;\n  });\n  const hasErrorFromProp = computed(() => props.error !== '');\n  const hasMinilabel = computed(() => hasFocus.value || !isEmpty.value);\n  const isEmpty = computed(() => modelValue.value === '');\n  const supportingTextMessage = computed(() => (showError.value && errorRef.value.message) || props.supportingText);\n\n  const handleFocus = () => {\n    hasFocus.value = true;\n    if (props.errorDisplay === ERROR_DISPLAY.EAGER) isValidating.value = true;\n  };\n\n  const handleFocusOut = () => {\n    hasFocus.value = false;\n    if (props.errorDisplay === ERROR_DISPLAY.LAZY) isValidating.value = true;\n  };\n\n  const handleFieldClick = () => {\n    textareaElement.value?.focus();\n  };\n\n  const preventTextareaFocusLossOnMousedown = (e: MouseEvent) => {\n    if (!hasFocus.value) return;\n    if (e.target !== textareaElement.value) e.preventDefault();\n  };\n\n  watchEffect(() => {\n    errorRef.value = getFieldValidationResult({\n      errorFromProps: props.error,\n      maxlength: props.maxlength,\n      minlength: props.minlength,\n      required: props.required,\n      validators: props.validators,\n      value: modelValue,\n    });\n  });\n\n  watch(\n    () => formContext?.forceShowErrors.value,\n    (newValue) => {\n      if (newValue) isValidating.value = true;\n    },\n    { immediate: true }\n  );\n\n  watch(\n    errorRef,\n    () => {\n      emit('valid', errorRef.value.valid);\n    },\n    { deep: true, immediate: true }\n  );\n</script>\n\n<template>\n  <div\n    :class=\"['tide-input-textarea', CSS.DISPLAY.FLEX, CSS.FLEX.DIRECTION.COLUMN, CSS.GAP.QUARTER, showError && 'error']\"\n  >\n    <label\n      :class=\"[\n        'tide-input-textarea-field',\n        CSS.GAP.HALF,\n        CSS.POSITION.RELATIVE,\n        CSS.BORDER.RADIUS.HALF,\n        CSS.PADDING.LEFT.ONE,\n        CSS.PADDING.TOP.HALF,\n        CSS.OVERFLOW.XY.HIDDEN,\n        CSS.BG.SURFACE.DEFAULT,\n        CSS.CURSOR.TEXT,\n      ]\"\n      :for=\"inputId\"\n      @click=\"handleFieldClick\"\n      @mousedown=\"preventTextareaFocusLossOnMousedown\"\n    >\n      <div\n        :class=\"[\n          'tide-input-textarea-label',\n          hasMinilabel ? ['minilabel', CSS.FONT.ROLE.LABEL_3] : CSS.FONT.ROLE.LABEL_1,\n          !showError && CSS.FONT.COLOR.SURFACE.VARIANT,\n          CSS.POINTER_EVENTS.OFF,\n        ]\"\n        v-if=\"label\"\n      >\n        {{ formattedLabel }}\n      </div>\n\n      <textarea\n        :class=\"[CSS.DISPLAY.BLOCK, CSS.WIDTH.FULL, CSS.FONT.ROLE.BODY_1]\"\n        :maxlength=\"maxlength\"\n        :minlength=\"minlength\"\n        :name=\"name\"\n        ref=\"textareaElement\"\n        :required=\"required\"\n        :rows=\"rows\"\n        @focus=\"handleFocus\"\n        @focusout=\"handleFocusOut\"\n        :id=\"inputId\"\n        v-model=\"modelValue\"\n      />\n    </label>\n\n    <TideInputSupportingText\n      :is-error=\"showError\"\n      :message=\"supportingTextMessage\"\n      v-if=\"supportingTextMessage\"\n    />\n  </div>\n</template>\n\n<style scoped>\n  textarea {\n    resize: vertical;\n  }\n\n  .tide-input-textarea-label {\n    height: 1.1875rem;\n    transition: font-size var(--tide-animate), transform var(--tide-animate);\n  }\n\n  .tide-input-textarea.error {\n    color: var(--tide-error-primary);\n  }\n\n  .tide-input-textarea.error .tide-input-textarea-field {\n    outline-color: var(--tide-error-border);\n    background-color: var(--tide-error-surface);\n  }\n\n  .tide-input-textarea.error:focus-within .tide-input-textarea-field {\n    outline-color: var(--tide-error-border);\n  }\n\n  .tide-input-textarea:focus-within .tide-input-textarea-field {\n    --tide-input-outline-width: var(--tide-border-width-2);\n    outline-color: var(--tide-surface-border-high);\n  }\n\n  .tide-input-textarea textarea {\n    outline: none;\n  }\n\n  .tide-input-textarea-field {\n    --tide-input-outline-width: var(--tide-border-width-1);\n    outline: var(--tide-input-outline-width) solid var(--tide-border);\n    outline-offset: calc(var(--tide-input-outline-width) * -1);\n    color: var(--tide-surface-foreground);\n  }\n</style>\n","<script lang=\"ts\">\n  /**\n   * @deprecated Use `TideInputTextarea.vue` imported from 'tide-design-system' npm package instead.\n   */\n  export default {};\n</script>\n\n<script lang=\"ts\" setup>\n  import { computed, ref, watch } from 'vue';\n\n  import TideIcon from '@/components/TideIcon.vue';\n  import { ICON } from '@/types/Icon';\n  import { SIZE } from '@/types/Size';\n  import { CSS } from '@/types/Styles';\n  import { getErrorMessage, getFieldHasError, handleFieldValidation } from '@/utilities/validation-deprecated';\n\n  import type { ValidationError } from '@/types/ValidationDeprecated';\n\n  type Props = {\n    error?: ValidationError;\n    inputId?: string;\n    label?: string;\n    maxlength?: number | undefined;\n    minlength?: number | undefined;\n    name?: string;\n    required?: boolean;\n    rows?: number;\n    supportingText?: string;\n    value?: string;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    error: false,\n    inputId: undefined,\n    label: undefined,\n    maxlength: undefined,\n    minlength: undefined,\n    name: undefined,\n    required: false,\n    rows: 8,\n    supportingText: undefined,\n    value: undefined,\n  });\n\n  const error = ref(props.error);\n  const hasFocus = ref(false);\n  const input = ref<HTMLInputElement | null>(null);\n  const value = ref(props.value);\n\n  const errorMessage = computed(() => getErrorMessage(props.error, error.value));\n  const formattedLabel = computed(() => (props.required ? `${props.label} *` : props.label));\n  const hasError = computed(\n    () => (props.required && value.value !== undefined && !value.value) || getFieldHasError(error.value, props.error)\n  );\n  const hasMinilabel = computed(() => hasFocus.value || !isEmpty.value);\n  const isEmpty = computed(() => value.value === '' || value.value === undefined);\n\n  const handleFocus = () => {\n    hasFocus.value = true;\n  };\n\n  const handleFocusOut = () => {\n    hasFocus.value = false;\n\n    if (!value.value) {\n      value.value = '';\n    }\n  };\n\n  const handleValidation = () => {\n    return handleFieldValidation({\n      error,\n      errorFromProps: props.error,\n      maxlength: props.maxlength,\n      minlength: props.minlength,\n      required: props.required,\n      value,\n    });\n  };\n\n  watch(\n    () => props.value,\n    (newValue, oldValue) => {\n      if (newValue !== oldValue || newValue !== value.value) {\n        value.value = newValue;\n      }\n    }\n  );\n\n  defineExpose({\n    error,\n    required: props.required,\n    value,\n  });\n</script>\n\n<template>\n  <div\n    :class=\"['tide-input-textarea', CSS.DISPLAY.FLEX, CSS.FLEX.DIRECTION.COLUMN, CSS.GAP.QUARTER, hasError && 'error']\"\n  >\n    <label\n      :class=\"[\n        'tide-input-textarea-field',\n        CSS.GAP.HALF,\n        CSS.POSITION.RELATIVE,\n        CSS.BORDER.RADIUS.HALF,\n        CSS.PADDING.LEFT.ONE,\n        CSS.PADDING.TOP.HALF,\n        CSS.OVERFLOW.XY.HIDDEN,\n        CSS.BG.SURFACE.DEFAULT,\n        CSS.CURSOR.TEXT,\n      ]\"\n      :for=\"inputId\"\n    >\n      <div\n        :class=\"[\n          'tide-input-textarea-label',\n          hasMinilabel ? ['minilabel', CSS.FONT.ROLE.LABEL_3] : CSS.FONT.ROLE.LABEL_1,\n          !hasError && CSS.FONT.COLOR.SURFACE.VARIANT,\n          CSS.POINTER_EVENTS.OFF,\n        ]\"\n        v-if=\"label\"\n      >\n        {{ formattedLabel }}\n      </div>\n\n      <textarea\n        :class=\"[CSS.DISPLAY.BLOCK, CSS.WIDTH.FULL, CSS.FONT.ROLE.BODY_1]\"\n        :maxlength=\"maxlength\"\n        :minlength=\"minlength\"\n        :name=\"name\"\n        ref=\"input\"\n        :required=\"required\"\n        :rows=\"rows\"\n        @change=\"handleValidation\"\n        @focus=\"handleFocus\"\n        @focusout=\"handleFocusOut\"\n        :id=\"inputId\"\n        v-model=\"value\"\n      />\n    </label>\n\n    <div\n      :class=\"[CSS.DISPLAY.FLEX, CSS.AXIS2.CENTER, CSS.GAP.QUARTER]\"\n      v-if=\"supportingText || hasError\"\n    >\n      <TideIcon\n        :icon=\"ICON.ERROR\"\n        :size=\"SIZE.SMALL\"\n        v-if=\"hasError\"\n      />\n\n      <div :class=\"[CSS.FONT.ROLE.LABEL_3]\">\n        {{ hasError ? errorMessage : supportingText }}\n      </div>\n    </div>\n  </div>\n</template>\n\n<style scoped>\n  textarea {\n    resize: vertical;\n  }\n\n  .tide-input-textarea-label {\n    height: 1.1875rem;\n    transition: font-size var(--tide-animate), transform var(--tide-animate);\n  }\n\n  .tide-input-textarea.error {\n    color: var(--tide-error-primary);\n  }\n\n  .tide-input-textarea.error .tide-input-textarea-field {\n    outline-color: var(--tide-error-border);\n    background-color: var(--tide-error-surface);\n  }\n\n  .tide-input-textarea.error:focus-within .tide-input-textarea-field {\n    outline-color: var(--tide-error-border);\n  }\n\n  .tide-input-textarea:focus-within .tide-input-textarea-field {\n    --tide-input-outline-width: var(--tide-border-width-2);\n    outline-color: var(--tide-surface-border-high);\n  }\n\n  .tide-input-textarea textarea {\n    outline: none;\n  }\n\n  .tide-input-textarea-field {\n    --tide-input-outline-width: var(--tide-border-width-1);\n    outline: var(--tide-input-outline-width) solid var(--tide-border);\n    outline-offset: calc(var(--tide-input-outline-width) * -1);\n    color: var(--tide-surface-foreground);\n  }\n</style>\n","<script lang=\"ts\" setup>\n  import TideIcon from '@/components/TideIcon.vue';\n  import { ELEMENT } from '@/types/Element';\n  import { CSS } from '@/types/Styles';\n  import { TARGET } from '@/types/Target';\n\n  import type { Element } from '@/types/Element';\n  import type { Icon } from '@/types/Icon';\n\n  type Props = {\n    element?: Element;\n    href?: string;\n    iconLeading?: Icon;\n    iconTrailing?: Icon;\n    isNewTab?: boolean;\n    label: string;\n    subtle?: boolean;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    element: ELEMENT.LINK,\n    href: undefined,\n    iconLeading: undefined,\n    iconTrailing: undefined,\n    isNewTab: false,\n    label: undefined,\n    subtle: false,\n  });\n</script>\n\n<template>\n  <component\n    :class=\"[\n      'tide-link',\n      CSS.DISPLAY.INLINE,\n      CSS.ALIGN.X.LEFT,\n      subtle ? [CSS.UNDERLINE.REST.OFF, CSS.UNDERLINE.HOVER.ON] : [CSS.UNDERLINE.REST.ON, CSS.UNDERLINE.HOVER.OFF],\n    ]\"\n    :href=\"props.href\"\n    :target=\"props.isNewTab ? TARGET.BLANK : TARGET.SELF\"\n    :is=\"props.element === ELEMENT.LINK ? ELEMENT.LINK : ELEMENT.BUTTON\"\n  >\n    <TideIcon\n      :class=\"[CSS.DISPLAY.INLINE_BLOCK, CSS.ALIGN.Y.MIDDLE, CSS.MARGIN.RIGHT.QUARTER]\"\n      :icon=\"props.iconLeading\"\n      v-if=\"props.iconLeading\"\n    />\n\n    <span :class=\"[CSS.ALIGN.Y.MIDDLE]\">\n      {{ props.label }}\n    </span>\n\n    <TideIcon\n      :class=\"[CSS.DISPLAY.INLINE_BLOCK, CSS.ALIGN.Y.MIDDLE, CSS.MARGIN.LEFT.QUARTER]\"\n      :icon=\"props.iconTrailing\"\n      v-if=\"props.iconTrailing\"\n    />\n  </component>\n</template>\n","/* eslint-disable vue/sort-keys */\n\nexport const BREAKPOINT = {\n  SM: 'sm',\n  MD: 'md',\n  LG: 'lg',\n  XL: 'xl',\n} as const;\n\nexport const MEDIA = {\n  SM: 768,\n  MD: 992,\n  LG: 1232,\n  XL: 1920,\n};\n\nexport type Breakpoint = (typeof BREAKPOINT)[keyof typeof BREAKPOINT];\nexport type Media = (typeof MEDIA)[keyof typeof MEDIA];\n","import { nextTick } from 'vue';\n\n/**\n * Directly modifies the `<body>` element to apply or remove scroll lock.\n * When `false` is provided, it only unlocks scroll if there are no open\n * HTML dialog elements.\n */\nexport const setScrollLock = async (isLocked: boolean) => {\n  // Cannot be applied to body tag in marketplace repo due to data-css-scope\n  // const BODY_LOCK_CLASS = 'body-scroll-lock';\n\n  const body = document.body;\n\n  if (isLocked) {\n    if (!body.dataset.scrollLockY) {\n      const scrollY = window.scrollY;\n\n      body.dataset.scrollLockY = scrollY.toString();\n      body.style.setProperty('--saved-scroll-y', `${scrollY}px`);\n      body.style.setProperty('inset', '0');\n      body.style.setProperty('margin-top', `calc(0px - var(--saved-scroll-y, 0px))`);\n      body.style.setProperty('overflow-y', 'scroll');\n      body.style.setProperty('position', 'fixed');\n\n      // Cannot be applied to body tag in marketplace repo due to data-css-scope\n      // body.classList.add(BODY_LOCK_CLASS);\n    }\n  } else {\n    await nextTick();\n    if (!document.querySelector('dialog[open]')) {\n      const savedScrollY = parseInt(body.dataset.scrollLockY || '0');\n\n      // Cannot be applied to body tag in marketplace repo due to data-css-scope\n      // body.classList.remove(BODY_LOCK_CLASS);\n\n      body.style.removeProperty('inset');\n      body.style.removeProperty('marginTop');\n      body.style.removeProperty('overflowY');\n      body.style.removeProperty('position');\n      body.style.removeProperty('--saved-scroll-y');\n\n      window.scrollTo({\n        behavior: 'auto',\n        top: savedScrollY,\n      });\n\n      delete body.dataset.scrollLockY;\n    }\n  }\n};\n\nexport const TOP_LAYER_ID = 'tide-top-layer';\n\nexport const initFauxTopLayer = () => {\n  let topLayer = document.getElementById(TOP_LAYER_ID);\n  if (!topLayer) {\n    topLayer = document.createElement('div');\n    topLayer.id = TOP_LAYER_ID;\n    topLayer.setAttribute('data-css-scope', '');\n    document.body.appendChild(topLayer);\n  }\n  topLayer.style.isolation = 'isolate';\n};\n","<script lang=\"ts\" setup>\n  import { nextTick, onMounted, ref, watch } from 'vue';\n\n  import TideButtonIcon from '@/components/TideButtonIcon.vue';\n  import { BREAKPOINT } from '@/types/Breakpoint';\n  import { ICON } from '@/types/Icon';\n  import { PRIORITY } from '@/types/Priority';\n  import { CSS } from '@/types/Styles';\n  import { setScrollLock } from '@/utilities/viewport';\n\n  import type { Ref } from 'vue';\n\n  type Props = {\n    isBackButton?: boolean;\n    isDismissible?: boolean;\n    isOpen: boolean;\n    title?: string;\n    width?: string;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    isBackButton: false,\n    isDismissible: true,\n    title: undefined,\n    width: undefined,\n  });\n\n  type Emits = {\n    (e: 'close'): void;\n    (e: 'back'): void;\n  };\n\n  const emit = defineEmits<Emits>();\n\n  const modalContent: Ref<HTMLDivElement | undefined> = ref();\n  const modalDialog: Ref<HTMLDialogElement | undefined> = ref();\n\n  const triggerNativeDialogOpen = () => {\n    modalDialog.value?.showModal();\n  };\n\n  const triggerNativeDialogClose = () => {\n    modalDialog.value?.close();\n  };\n\n  const scrollContentToTop = () => {\n    nextTick(() => {\n      if (!modalContent.value) return;\n      modalContent.value.scrollTop = 0;\n    });\n  };\n\n  const handleBackdropClick = () => {\n    if (props.isDismissible) emit('close');\n  };\n\n  const handleEscapeKeydown = (e: Event) => {\n    e.preventDefault();\n    if (props.isDismissible) emit('close');\n  };\n\n  watch(\n    () => props.isOpen,\n    (newValue) => {\n      if (!modalDialog.value) return;\n      if (newValue) {\n        triggerNativeDialogOpen();\n        scrollContentToTop();\n      } else {\n        triggerNativeDialogClose();\n      }\n      setScrollLock(newValue);\n    }\n  );\n\n  onMounted(() => {\n    if (props.isOpen) {\n      triggerNativeDialogOpen();\n    }\n  });\n</script>\n\n<template>\n  <dialog\n    :class=\"['tide-modal', CSS.BG.INITIAL, CSS.HEIGHT.FULL, CSS.WIDTH.FULL, CSS.OVERFLOW.XY.HIDDEN]\"\n    ref=\"modalDialog\"\n    :style=\"{ '--modal-width': props.width }\"\n    @click.self=\"handleBackdropClick\"\n    @close.prevent\n    @keydown.escape=\"handleEscapeKeydown\"\n  >\n    <div\n      :class=\"[\n        'tide-modal-body',\n        CSS.BG.SURFACE.DEFAULT,\n        CSS.BORDER.RADIUS.ONE,\n        CSS.DISPLAY.FLEX,\n        CSS.FLEX.DIRECTION.COLUMN,\n        CSS.OVERFLOW.XY.HIDDEN,\n        CSS.POSITION.ABSOLUTE,\n        CSS.POSITIONING.BOTTOM,\n        CSS.SHADOW.TOP,\n        CSS.WIDTH.FULL,\n        CSS.WIDTH.MAX_FULL,\n        CSS.withBreakpoint([CSS.SHADOW.BOTTOM], BREAKPOINT.SM),\n      ]\"\n    >\n      <header\n        :class=\"[\n          'tide-modal-header',\n          CSS.AXIS2.CENTER,\n          CSS.BORDER.BOTTOM.ONE,\n          CSS.BORDER.COLOR.LOW,\n          CSS.DISPLAY.FLEX,\n          CSS.GAP.HALF,\n          CSS.ISOLATION.ISOLATE,\n          CSS.PADDING.Y.ONE,\n          CSS.POSITION.RELATIVE,\n          CSS.Z_INDEX.ONE,\n        ]\"\n      >\n        <TideButtonIcon\n          :icon=\"ICON.CHEVRON_LEFT\"\n          :priority=\"PRIORITY.QUATERNARY\"\n          @click=\"emit('back')\"\n          title=\"Back\"\n          v-if=\"isBackButton\"\n        />\n\n        <div\n          :class=\"[CSS.FONT.ROLE.HEADLINE_2]\"\n          v-text=\"title\"\n        />\n\n        <TideButtonIcon\n          :class=\"[CSS.FLEX.GROW.OFF, CSS.FLEX.SHRINK.OFF, CSS.MARGIN.LEFT.AUTO]\"\n          :icon=\"ICON.CLOSE\"\n          :priority=\"PRIORITY.QUATERNARY\"\n          @click=\"emit('close')\"\n          v-if=\"isDismissible\"\n        />\n      </header>\n\n      <div\n        :class=\"[\n          'tide-modal-content',\n          CSS.DISPLAY.GRID,\n          CSS.ISOLATION.ISOLATE,\n          CSS.OVERFLOW.X.HIDDEN,\n          CSS.OVERFLOW.Y.AUTO,\n          CSS.PADDING.Y.TWO,\n          CSS.WIDTH.FULL,\n        ]\"\n        ref=\"modalContent\"\n      >\n        <slot />\n      </div>\n\n      <footer\n        :class=\"[\n          'tide-modal-footer',\n          CSS.AXIS1.END,\n          CSS.DISPLAY.FLEX,\n          CSS.GAP.TWO,\n          CSS.ISOLATION.ISOLATE,\n          CSS.PADDING.Y.ONE,\n          CSS.SHADOW.TOP,\n        ]\"\n        v-if=\"$slots.footer\"\n      >\n        <slot name=\"footer\" />\n      </footer>\n    </div>\n  </dialog>\n</template>\n\n<style scoped>\n  .tide-modal {\n    --modal-padding-x: 20px;\n    max-width: unset;\n    max-height: unset;\n    place-items: center;\n    display: none;\n    transition: all var(--tide-animate) allow-discrete;\n    transform: translateY(100%);\n  }\n  .tide-modal[open] {\n    display: grid;\n    transform: translateY(0%);\n  }\n  .tide-modal::backdrop {\n    background-color: transparent;\n    transition: all var(--tide-animate) allow-discrete;\n    backdrop-filter: blur(0px);\n  }\n  .tide-modal[open]::backdrop {\n    background-color: var(--tide-transparent-400);\n    backdrop-filter: var(--tide-bg-blur);\n  }\n  @starting-style {\n    .tide-modal[open] {\n      display: grid;\n      transform: translateY(100%);\n    }\n    .tide-modal[open]::backdrop {\n      background-color: transparent;\n      backdrop-filter: var(--tide-bg-blur);\n    }\n  }\n  .tide-modal-body {\n    width: var(--modal-width, 576px);\n    max-height: calc(100% - var(--tide-spacing-2));\n  }\n\n  .tide-modal-header,\n  .tide-modal-footer {\n    padding-inline: var(--modal-padding-x);\n  }\n  .tide-modal-content {\n    grid-template-columns: var(--modal-padding-x) 1fr var(--modal-padding-x);\n  }\n  :where(.tide-modal-content):deep(> :where(*)) {\n    grid-column: 2;\n  }\n\n  @media (max-width: 767px) {\n    .tide-modal-body {\n      border-bottom-left-radius: 0;\n      border-bottom-right-radius: 0;\n    }\n  }\n  @media (min-width: 768px) {\n    .tide-modal {\n      --modal-padding-x: var(--tide-spacing-2);\n    }\n    .tide-modal-body {\n      max-height: 85%;\n      bottom: initial;\n    }\n  }\n</style>\n","<script lang=\"ts\" setup>\n  import { computed, ref } from 'vue';\n\n  import TideButtonIcon from '@/components/TideButtonIcon.vue';\n  import TideButtonPagination from '@/components/TideButtonPagination.vue';\n  import { ICON } from '@/types/Icon';\n  import { PRIORITY } from '@/types/Priority';\n  import { CSS } from '@/types/Styles';\n\n  type Props = {\n    pageCurrent?: number;\n    pageTotal?: number;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    pageCurrent: 1,\n    pageTotal: 1,\n  });\n\n  const emit = defineEmits(['change']);\n\n  const pageCurrent = ref(props.pageCurrent);\n\n  const paginationButtons = computed(() => new Array(props.pageTotal).fill('').map((empty, index) => index + 1));\n\n  const handleClick = (index: number) => {\n    pageCurrent.value = index;\n\n    emit('change', event, index);\n  };\n</script>\n\n<template>\n  <section\n    :class=\"['tide-pagination', CSS.DISPLAY.FLEX, CSS.AXIS1.CENTER, CSS.AXIS2.CENTER, CSS.GAP.QUARTER, CSS.WIDTH.FULL]\"\n  >\n    <TideButtonIcon\n      :disabled=\"pageCurrent === 1\"\n      :icon=\"ICON.CHEVRON_LEFT\"\n      :priority=\"PRIORITY.QUATERNARY\"\n      @click=\"handleClick(pageCurrent - 1)\"\n    />\n\n    <ul :class=\"[CSS.DISPLAY.FLEX, CSS.AXIS2.CENTER, CSS.GAP.QUARTER, CSS.LIST_BULLETS.OFF]\">\n      <li\n        :key=\"paginationButton\"\n        v-for=\"paginationButton in paginationButtons\"\n      >\n        <TideButtonPagination\n          :disabled=\"pageCurrent === paginationButton\"\n          :label=\"paginationButton\"\n          :priority=\"PRIORITY.QUATERNARY\"\n          @click=\"handleClick(paginationButton)\"\n        />\n      </li>\n    </ul>\n\n    <TideButtonIcon\n      :disabled=\"pageCurrent === paginationButtons[paginationButtons.length - 1]\"\n      :icon=\"ICON.CHEVRON_RIGHT\"\n      :priority=\"PRIORITY.QUATERNARY\"\n      @click=\"handleClick(pageCurrent + 1)\"\n    />\n  </section>\n</template>\n\n<style scoped></style>\n","/**\n * Custom positioning reference element.\n * @see https://floating-ui.com/docs/virtual-elements\n */\n\nconst sides = ['top', 'right', 'bottom', 'left'];\nconst alignments = ['start', 'end'];\nconst placements = /*#__PURE__*/sides.reduce((acc, side) => acc.concat(side, side + \"-\" + alignments[0], side + \"-\" + alignments[1]), []);\nconst min = Math.min;\nconst max = Math.max;\nconst round = Math.round;\nconst floor = Math.floor;\nconst createCoords = v => ({\n  x: v,\n  y: v\n});\nconst oppositeSideMap = {\n  left: 'right',\n  right: 'left',\n  bottom: 'top',\n  top: 'bottom'\n};\nconst oppositeAlignmentMap = {\n  start: 'end',\n  end: 'start'\n};\nfunction clamp(start, value, end) {\n  return max(start, min(value, end));\n}\nfunction evaluate(value, param) {\n  return typeof value === 'function' ? value(param) : value;\n}\nfunction getSide(placement) {\n  return placement.split('-')[0];\n}\nfunction getAlignment(placement) {\n  return placement.split('-')[1];\n}\nfunction getOppositeAxis(axis) {\n  return axis === 'x' ? 'y' : 'x';\n}\nfunction getAxisLength(axis) {\n  return axis === 'y' ? 'height' : 'width';\n}\nfunction getSideAxis(placement) {\n  return ['top', 'bottom'].includes(getSide(placement)) ? 'y' : 'x';\n}\nfunction getAlignmentAxis(placement) {\n  return getOppositeAxis(getSideAxis(placement));\n}\nfunction getAlignmentSides(placement, rects, rtl) {\n  if (rtl === void 0) {\n    rtl = false;\n  }\n  const alignment = getAlignment(placement);\n  const alignmentAxis = getAlignmentAxis(placement);\n  const length = getAxisLength(alignmentAxis);\n  let mainAlignmentSide = alignmentAxis === 'x' ? alignment === (rtl ? 'end' : 'start') ? 'right' : 'left' : alignment === 'start' ? 'bottom' : 'top';\n  if (rects.reference[length] > rects.floating[length]) {\n    mainAlignmentSide = getOppositePlacement(mainAlignmentSide);\n  }\n  return [mainAlignmentSide, getOppositePlacement(mainAlignmentSide)];\n}\nfunction getExpandedPlacements(placement) {\n  const oppositePlacement = getOppositePlacement(placement);\n  return [getOppositeAlignmentPlacement(placement), oppositePlacement, getOppositeAlignmentPlacement(oppositePlacement)];\n}\nfunction getOppositeAlignmentPlacement(placement) {\n  return placement.replace(/start|end/g, alignment => oppositeAlignmentMap[alignment]);\n}\nfunction getSideList(side, isStart, rtl) {\n  const lr = ['left', 'right'];\n  const rl = ['right', 'left'];\n  const tb = ['top', 'bottom'];\n  const bt = ['bottom', 'top'];\n  switch (side) {\n    case 'top':\n    case 'bottom':\n      if (rtl) return isStart ? rl : lr;\n      return isStart ? lr : rl;\n    case 'left':\n    case 'right':\n      return isStart ? tb : bt;\n    default:\n      return [];\n  }\n}\nfunction getOppositeAxisPlacements(placement, flipAlignment, direction, rtl) {\n  const alignment = getAlignment(placement);\n  let list = getSideList(getSide(placement), direction === 'start', rtl);\n  if (alignment) {\n    list = list.map(side => side + \"-\" + alignment);\n    if (flipAlignment) {\n      list = list.concat(list.map(getOppositeAlignmentPlacement));\n    }\n  }\n  return list;\n}\nfunction getOppositePlacement(placement) {\n  return placement.replace(/left|right|bottom|top/g, side => oppositeSideMap[side]);\n}\nfunction expandPaddingObject(padding) {\n  return {\n    top: 0,\n    right: 0,\n    bottom: 0,\n    left: 0,\n    ...padding\n  };\n}\nfunction getPaddingObject(padding) {\n  return typeof padding !== 'number' ? expandPaddingObject(padding) : {\n    top: padding,\n    right: padding,\n    bottom: padding,\n    left: padding\n  };\n}\nfunction rectToClientRect(rect) {\n  const {\n    x,\n    y,\n    width,\n    height\n  } = rect;\n  return {\n    width,\n    height,\n    top: y,\n    left: x,\n    right: x + width,\n    bottom: y + height,\n    x,\n    y\n  };\n}\n\nexport { alignments, clamp, createCoords, evaluate, expandPaddingObject, floor, getAlignment, getAlignmentAxis, getAlignmentSides, getAxisLength, getExpandedPlacements, getOppositeAlignmentPlacement, getOppositeAxis, getOppositeAxisPlacements, getOppositePlacement, getPaddingObject, getSide, getSideAxis, max, min, placements, rectToClientRect, round, sides };\n","import { getSideAxis, getAlignmentAxis, getAxisLength, getSide, getAlignment, evaluate, getPaddingObject, rectToClientRect, min, clamp, placements, getAlignmentSides, getOppositeAlignmentPlacement, getOppositePlacement, getExpandedPlacements, getOppositeAxisPlacements, sides, max, getOppositeAxis } from '@floating-ui/utils';\nexport { rectToClientRect } from '@floating-ui/utils';\n\nfunction computeCoordsFromPlacement(_ref, placement, rtl) {\n  let {\n    reference,\n    floating\n  } = _ref;\n  const sideAxis = getSideAxis(placement);\n  const alignmentAxis = getAlignmentAxis(placement);\n  const alignLength = getAxisLength(alignmentAxis);\n  const side = getSide(placement);\n  const isVertical = sideAxis === 'y';\n  const commonX = reference.x + reference.width / 2 - floating.width / 2;\n  const commonY = reference.y + reference.height / 2 - floating.height / 2;\n  const commonAlign = reference[alignLength] / 2 - floating[alignLength] / 2;\n  let coords;\n  switch (side) {\n    case 'top':\n      coords = {\n        x: commonX,\n        y: reference.y - floating.height\n      };\n      break;\n    case 'bottom':\n      coords = {\n        x: commonX,\n        y: reference.y + reference.height\n      };\n      break;\n    case 'right':\n      coords = {\n        x: reference.x + reference.width,\n        y: commonY\n      };\n      break;\n    case 'left':\n      coords = {\n        x: reference.x - floating.width,\n        y: commonY\n      };\n      break;\n    default:\n      coords = {\n        x: reference.x,\n        y: reference.y\n      };\n  }\n  switch (getAlignment(placement)) {\n    case 'start':\n      coords[alignmentAxis] -= commonAlign * (rtl && isVertical ? -1 : 1);\n      break;\n    case 'end':\n      coords[alignmentAxis] += commonAlign * (rtl && isVertical ? -1 : 1);\n      break;\n  }\n  return coords;\n}\n\n/**\n * Computes the `x` and `y` coordinates that will place the floating element\n * next to a given reference element.\n *\n * This export does not have any `platform` interface logic. You will need to\n * write one for the platform you are using Floating UI with.\n */\nconst computePosition = async (reference, floating, config) => {\n  const {\n    placement = 'bottom',\n    strategy = 'absolute',\n    middleware = [],\n    platform\n  } = config;\n  const validMiddleware = middleware.filter(Boolean);\n  const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(floating));\n  let rects = await platform.getElementRects({\n    reference,\n    floating,\n    strategy\n  });\n  let {\n    x,\n    y\n  } = computeCoordsFromPlacement(rects, placement, rtl);\n  let statefulPlacement = placement;\n  let middlewareData = {};\n  let resetCount = 0;\n  for (let i = 0; i < validMiddleware.length; i++) {\n    const {\n      name,\n      fn\n    } = validMiddleware[i];\n    const {\n      x: nextX,\n      y: nextY,\n      data,\n      reset\n    } = await fn({\n      x,\n      y,\n      initialPlacement: placement,\n      placement: statefulPlacement,\n      strategy,\n      middlewareData,\n      rects,\n      platform,\n      elements: {\n        reference,\n        floating\n      }\n    });\n    x = nextX != null ? nextX : x;\n    y = nextY != null ? nextY : y;\n    middlewareData = {\n      ...middlewareData,\n      [name]: {\n        ...middlewareData[name],\n        ...data\n      }\n    };\n    if (reset && resetCount <= 50) {\n      resetCount++;\n      if (typeof reset === 'object') {\n        if (reset.placement) {\n          statefulPlacement = reset.placement;\n        }\n        if (reset.rects) {\n          rects = reset.rects === true ? await platform.getElementRects({\n            reference,\n            floating,\n            strategy\n          }) : reset.rects;\n        }\n        ({\n          x,\n          y\n        } = computeCoordsFromPlacement(rects, statefulPlacement, rtl));\n      }\n      i = -1;\n    }\n  }\n  return {\n    x,\n    y,\n    placement: statefulPlacement,\n    strategy,\n    middlewareData\n  };\n};\n\n/**\n * Resolves with an object of overflow side offsets that determine how much the\n * element is overflowing a given clipping boundary on each side.\n * - positive = overflowing the boundary by that number of pixels\n * - negative = how many pixels left before it will overflow\n * - 0 = lies flush with the boundary\n * @see https://floating-ui.com/docs/detectOverflow\n */\nasync function detectOverflow(state, options) {\n  var _await$platform$isEle;\n  if (options === void 0) {\n    options = {};\n  }\n  const {\n    x,\n    y,\n    platform,\n    rects,\n    elements,\n    strategy\n  } = state;\n  const {\n    boundary = 'clippingAncestors',\n    rootBoundary = 'viewport',\n    elementContext = 'floating',\n    altBoundary = false,\n    padding = 0\n  } = evaluate(options, state);\n  const paddingObject = getPaddingObject(padding);\n  const altContext = elementContext === 'floating' ? 'reference' : 'floating';\n  const element = elements[altBoundary ? altContext : elementContext];\n  const clippingClientRect = rectToClientRect(await platform.getClippingRect({\n    element: ((_await$platform$isEle = await (platform.isElement == null ? void 0 : platform.isElement(element))) != null ? _await$platform$isEle : true) ? element : element.contextElement || (await (platform.getDocumentElement == null ? void 0 : platform.getDocumentElement(elements.floating))),\n    boundary,\n    rootBoundary,\n    strategy\n  }));\n  const rect = elementContext === 'floating' ? {\n    x,\n    y,\n    width: rects.floating.width,\n    height: rects.floating.height\n  } : rects.reference;\n  const offsetParent = await (platform.getOffsetParent == null ? void 0 : platform.getOffsetParent(elements.floating));\n  const offsetScale = (await (platform.isElement == null ? void 0 : platform.isElement(offsetParent))) ? (await (platform.getScale == null ? void 0 : platform.getScale(offsetParent))) || {\n    x: 1,\n    y: 1\n  } : {\n    x: 1,\n    y: 1\n  };\n  const elementClientRect = rectToClientRect(platform.convertOffsetParentRelativeRectToViewportRelativeRect ? await platform.convertOffsetParentRelativeRectToViewportRelativeRect({\n    elements,\n    rect,\n    offsetParent,\n    strategy\n  }) : rect);\n  return {\n    top: (clippingClientRect.top - elementClientRect.top + paddingObject.top) / offsetScale.y,\n    bottom: (elementClientRect.bottom - clippingClientRect.bottom + paddingObject.bottom) / offsetScale.y,\n    left: (clippingClientRect.left - elementClientRect.left + paddingObject.left) / offsetScale.x,\n    right: (elementClientRect.right - clippingClientRect.right + paddingObject.right) / offsetScale.x\n  };\n}\n\n/**\n * Provides data to position an inner element of the floating element so that it\n * appears centered to the reference element.\n * @see https://floating-ui.com/docs/arrow\n */\nconst arrow = options => ({\n  name: 'arrow',\n  options,\n  async fn(state) {\n    const {\n      x,\n      y,\n      placement,\n      rects,\n      platform,\n      elements,\n      middlewareData\n    } = state;\n    // Since `element` is required, we don't Partial<> the type.\n    const {\n      element,\n      padding = 0\n    } = evaluate(options, state) || {};\n    if (element == null) {\n      return {};\n    }\n    const paddingObject = getPaddingObject(padding);\n    const coords = {\n      x,\n      y\n    };\n    const axis = getAlignmentAxis(placement);\n    const length = getAxisLength(axis);\n    const arrowDimensions = await platform.getDimensions(element);\n    const isYAxis = axis === 'y';\n    const minProp = isYAxis ? 'top' : 'left';\n    const maxProp = isYAxis ? 'bottom' : 'right';\n    const clientProp = isYAxis ? 'clientHeight' : 'clientWidth';\n    const endDiff = rects.reference[length] + rects.reference[axis] - coords[axis] - rects.floating[length];\n    const startDiff = coords[axis] - rects.reference[axis];\n    const arrowOffsetParent = await (platform.getOffsetParent == null ? void 0 : platform.getOffsetParent(element));\n    let clientSize = arrowOffsetParent ? arrowOffsetParent[clientProp] : 0;\n\n    // DOM platform can return `window` as the `offsetParent`.\n    if (!clientSize || !(await (platform.isElement == null ? void 0 : platform.isElement(arrowOffsetParent)))) {\n      clientSize = elements.floating[clientProp] || rects.floating[length];\n    }\n    const centerToReference = endDiff / 2 - startDiff / 2;\n\n    // If the padding is large enough that it causes the arrow to no longer be\n    // centered, modify the padding so that it is centered.\n    const largestPossiblePadding = clientSize / 2 - arrowDimensions[length] / 2 - 1;\n    const minPadding = min(paddingObject[minProp], largestPossiblePadding);\n    const maxPadding = min(paddingObject[maxProp], largestPossiblePadding);\n\n    // Make sure the arrow doesn't overflow the floating element if the center\n    // point is outside the floating element's bounds.\n    const min$1 = minPadding;\n    const max = clientSize - arrowDimensions[length] - maxPadding;\n    const center = clientSize / 2 - arrowDimensions[length] / 2 + centerToReference;\n    const offset = clamp(min$1, center, max);\n\n    // If the reference is small enough that the arrow's padding causes it to\n    // to point to nothing for an aligned placement, adjust the offset of the\n    // floating element itself. To ensure `shift()` continues to take action,\n    // a single reset is performed when this is true.\n    const shouldAddOffset = !middlewareData.arrow && getAlignment(placement) != null && center !== offset && rects.reference[length] / 2 - (center < min$1 ? minPadding : maxPadding) - arrowDimensions[length] / 2 < 0;\n    const alignmentOffset = shouldAddOffset ? center < min$1 ? center - min$1 : center - max : 0;\n    return {\n      [axis]: coords[axis] + alignmentOffset,\n      data: {\n        [axis]: offset,\n        centerOffset: center - offset - alignmentOffset,\n        ...(shouldAddOffset && {\n          alignmentOffset\n        })\n      },\n      reset: shouldAddOffset\n    };\n  }\n});\n\nfunction getPlacementList(alignment, autoAlignment, allowedPlacements) {\n  const allowedPlacementsSortedByAlignment = alignment ? [...allowedPlacements.filter(placement => getAlignment(placement) === alignment), ...allowedPlacements.filter(placement => getAlignment(placement) !== alignment)] : allowedPlacements.filter(placement => getSide(placement) === placement);\n  return allowedPlacementsSortedByAlignment.filter(placement => {\n    if (alignment) {\n      return getAlignment(placement) === alignment || (autoAlignment ? getOppositeAlignmentPlacement(placement) !== placement : false);\n    }\n    return true;\n  });\n}\n/**\n * Optimizes the visibility of the floating element by choosing the placement\n * that has the most space available automatically, without needing to specify a\n * preferred placement. Alternative to `flip`.\n * @see https://floating-ui.com/docs/autoPlacement\n */\nconst autoPlacement = function (options) {\n  if (options === void 0) {\n    options = {};\n  }\n  return {\n    name: 'autoPlacement',\n    options,\n    async fn(state) {\n      var _middlewareData$autoP, _middlewareData$autoP2, _placementsThatFitOnE;\n      const {\n        rects,\n        middlewareData,\n        placement,\n        platform,\n        elements\n      } = state;\n      const {\n        crossAxis = false,\n        alignment,\n        allowedPlacements = placements,\n        autoAlignment = true,\n        ...detectOverflowOptions\n      } = evaluate(options, state);\n      const placements$1 = alignment !== undefined || allowedPlacements === placements ? getPlacementList(alignment || null, autoAlignment, allowedPlacements) : allowedPlacements;\n      const overflow = await detectOverflow(state, detectOverflowOptions);\n      const currentIndex = ((_middlewareData$autoP = middlewareData.autoPlacement) == null ? void 0 : _middlewareData$autoP.index) || 0;\n      const currentPlacement = placements$1[currentIndex];\n      if (currentPlacement == null) {\n        return {};\n      }\n      const alignmentSides = getAlignmentSides(currentPlacement, rects, await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating)));\n\n      // Make `computeCoords` start from the right place.\n      if (placement !== currentPlacement) {\n        return {\n          reset: {\n            placement: placements$1[0]\n          }\n        };\n      }\n      const currentOverflows = [overflow[getSide(currentPlacement)], overflow[alignmentSides[0]], overflow[alignmentSides[1]]];\n      const allOverflows = [...(((_middlewareData$autoP2 = middlewareData.autoPlacement) == null ? void 0 : _middlewareData$autoP2.overflows) || []), {\n        placement: currentPlacement,\n        overflows: currentOverflows\n      }];\n      const nextPlacement = placements$1[currentIndex + 1];\n\n      // There are more placements to check.\n      if (nextPlacement) {\n        return {\n          data: {\n            index: currentIndex + 1,\n            overflows: allOverflows\n          },\n          reset: {\n            placement: nextPlacement\n          }\n        };\n      }\n      const placementsSortedByMostSpace = allOverflows.map(d => {\n        const alignment = getAlignment(d.placement);\n        return [d.placement, alignment && crossAxis ?\n        // Check along the mainAxis and main crossAxis side.\n        d.overflows.slice(0, 2).reduce((acc, v) => acc + v, 0) :\n        // Check only the mainAxis.\n        d.overflows[0], d.overflows];\n      }).sort((a, b) => a[1] - b[1]);\n      const placementsThatFitOnEachSide = placementsSortedByMostSpace.filter(d => d[2].slice(0,\n      // Aligned placements should not check their opposite crossAxis\n      // side.\n      getAlignment(d[0]) ? 2 : 3).every(v => v <= 0));\n      const resetPlacement = ((_placementsThatFitOnE = placementsThatFitOnEachSide[0]) == null ? void 0 : _placementsThatFitOnE[0]) || placementsSortedByMostSpace[0][0];\n      if (resetPlacement !== placement) {\n        return {\n          data: {\n            index: currentIndex + 1,\n            overflows: allOverflows\n          },\n          reset: {\n            placement: resetPlacement\n          }\n        };\n      }\n      return {};\n    }\n  };\n};\n\n/**\n * Optimizes the visibility of the floating element by flipping the `placement`\n * in order to keep it in view when the preferred placement(s) will overflow the\n * clipping boundary. Alternative to `autoPlacement`.\n * @see https://floating-ui.com/docs/flip\n */\nconst flip = function (options) {\n  if (options === void 0) {\n    options = {};\n  }\n  return {\n    name: 'flip',\n    options,\n    async fn(state) {\n      var _middlewareData$arrow, _middlewareData$flip;\n      const {\n        placement,\n        middlewareData,\n        rects,\n        initialPlacement,\n        platform,\n        elements\n      } = state;\n      const {\n        mainAxis: checkMainAxis = true,\n        crossAxis: checkCrossAxis = true,\n        fallbackPlacements: specifiedFallbackPlacements,\n        fallbackStrategy = 'bestFit',\n        fallbackAxisSideDirection = 'none',\n        flipAlignment = true,\n        ...detectOverflowOptions\n      } = evaluate(options, state);\n\n      // If a reset by the arrow was caused due to an alignment offset being\n      // added, we should skip any logic now since `flip()` has already done its\n      // work.\n      // https://github.com/floating-ui/floating-ui/issues/2549#issuecomment-1719601643\n      if ((_middlewareData$arrow = middlewareData.arrow) != null && _middlewareData$arrow.alignmentOffset) {\n        return {};\n      }\n      const side = getSide(placement);\n      const initialSideAxis = getSideAxis(initialPlacement);\n      const isBasePlacement = getSide(initialPlacement) === initialPlacement;\n      const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating));\n      const fallbackPlacements = specifiedFallbackPlacements || (isBasePlacement || !flipAlignment ? [getOppositePlacement(initialPlacement)] : getExpandedPlacements(initialPlacement));\n      const hasFallbackAxisSideDirection = fallbackAxisSideDirection !== 'none';\n      if (!specifiedFallbackPlacements && hasFallbackAxisSideDirection) {\n        fallbackPlacements.push(...getOppositeAxisPlacements(initialPlacement, flipAlignment, fallbackAxisSideDirection, rtl));\n      }\n      const placements = [initialPlacement, ...fallbackPlacements];\n      const overflow = await detectOverflow(state, detectOverflowOptions);\n      const overflows = [];\n      let overflowsData = ((_middlewareData$flip = middlewareData.flip) == null ? void 0 : _middlewareData$flip.overflows) || [];\n      if (checkMainAxis) {\n        overflows.push(overflow[side]);\n      }\n      if (checkCrossAxis) {\n        const sides = getAlignmentSides(placement, rects, rtl);\n        overflows.push(overflow[sides[0]], overflow[sides[1]]);\n      }\n      overflowsData = [...overflowsData, {\n        placement,\n        overflows\n      }];\n\n      // One or more sides is overflowing.\n      if (!overflows.every(side => side <= 0)) {\n        var _middlewareData$flip2, _overflowsData$filter;\n        const nextIndex = (((_middlewareData$flip2 = middlewareData.flip) == null ? void 0 : _middlewareData$flip2.index) || 0) + 1;\n        const nextPlacement = placements[nextIndex];\n        if (nextPlacement) {\n          // Try next placement and re-run the lifecycle.\n          return {\n            data: {\n              index: nextIndex,\n              overflows: overflowsData\n            },\n            reset: {\n              placement: nextPlacement\n            }\n          };\n        }\n\n        // First, find the candidates that fit on the mainAxis side of overflow,\n        // then find the placement that fits the best on the main crossAxis side.\n        let resetPlacement = (_overflowsData$filter = overflowsData.filter(d => d.overflows[0] <= 0).sort((a, b) => a.overflows[1] - b.overflows[1])[0]) == null ? void 0 : _overflowsData$filter.placement;\n\n        // Otherwise fallback.\n        if (!resetPlacement) {\n          switch (fallbackStrategy) {\n            case 'bestFit':\n              {\n                var _overflowsData$filter2;\n                const placement = (_overflowsData$filter2 = overflowsData.filter(d => {\n                  if (hasFallbackAxisSideDirection) {\n                    const currentSideAxis = getSideAxis(d.placement);\n                    return currentSideAxis === initialSideAxis ||\n                    // Create a bias to the `y` side axis due to horizontal\n                    // reading directions favoring greater width.\n                    currentSideAxis === 'y';\n                  }\n                  return true;\n                }).map(d => [d.placement, d.overflows.filter(overflow => overflow > 0).reduce((acc, overflow) => acc + overflow, 0)]).sort((a, b) => a[1] - b[1])[0]) == null ? void 0 : _overflowsData$filter2[0];\n                if (placement) {\n                  resetPlacement = placement;\n                }\n                break;\n              }\n            case 'initialPlacement':\n              resetPlacement = initialPlacement;\n              break;\n          }\n        }\n        if (placement !== resetPlacement) {\n          return {\n            reset: {\n              placement: resetPlacement\n            }\n          };\n        }\n      }\n      return {};\n    }\n  };\n};\n\nfunction getSideOffsets(overflow, rect) {\n  return {\n    top: overflow.top - rect.height,\n    right: overflow.right - rect.width,\n    bottom: overflow.bottom - rect.height,\n    left: overflow.left - rect.width\n  };\n}\nfunction isAnySideFullyClipped(overflow) {\n  return sides.some(side => overflow[side] >= 0);\n}\n/**\n * Provides data to hide the floating element in applicable situations, such as\n * when it is not in the same clipping context as the reference element.\n * @see https://floating-ui.com/docs/hide\n */\nconst hide = function (options) {\n  if (options === void 0) {\n    options = {};\n  }\n  return {\n    name: 'hide',\n    options,\n    async fn(state) {\n      const {\n        rects\n      } = state;\n      const {\n        strategy = 'referenceHidden',\n        ...detectOverflowOptions\n      } = evaluate(options, state);\n      switch (strategy) {\n        case 'referenceHidden':\n          {\n            const overflow = await detectOverflow(state, {\n              ...detectOverflowOptions,\n              elementContext: 'reference'\n            });\n            const offsets = getSideOffsets(overflow, rects.reference);\n            return {\n              data: {\n                referenceHiddenOffsets: offsets,\n                referenceHidden: isAnySideFullyClipped(offsets)\n              }\n            };\n          }\n        case 'escaped':\n          {\n            const overflow = await detectOverflow(state, {\n              ...detectOverflowOptions,\n              altBoundary: true\n            });\n            const offsets = getSideOffsets(overflow, rects.floating);\n            return {\n              data: {\n                escapedOffsets: offsets,\n                escaped: isAnySideFullyClipped(offsets)\n              }\n            };\n          }\n        default:\n          {\n            return {};\n          }\n      }\n    }\n  };\n};\n\nfunction getBoundingRect(rects) {\n  const minX = min(...rects.map(rect => rect.left));\n  const minY = min(...rects.map(rect => rect.top));\n  const maxX = max(...rects.map(rect => rect.right));\n  const maxY = max(...rects.map(rect => rect.bottom));\n  return {\n    x: minX,\n    y: minY,\n    width: maxX - minX,\n    height: maxY - minY\n  };\n}\nfunction getRectsByLine(rects) {\n  const sortedRects = rects.slice().sort((a, b) => a.y - b.y);\n  const groups = [];\n  let prevRect = null;\n  for (let i = 0; i < sortedRects.length; i++) {\n    const rect = sortedRects[i];\n    if (!prevRect || rect.y - prevRect.y > prevRect.height / 2) {\n      groups.push([rect]);\n    } else {\n      groups[groups.length - 1].push(rect);\n    }\n    prevRect = rect;\n  }\n  return groups.map(rect => rectToClientRect(getBoundingRect(rect)));\n}\n/**\n * Provides improved positioning for inline reference elements that can span\n * over multiple lines, such as hyperlinks or range selections.\n * @see https://floating-ui.com/docs/inline\n */\nconst inline = function (options) {\n  if (options === void 0) {\n    options = {};\n  }\n  return {\n    name: 'inline',\n    options,\n    async fn(state) {\n      const {\n        placement,\n        elements,\n        rects,\n        platform,\n        strategy\n      } = state;\n      // A MouseEvent's client{X,Y} coords can be up to 2 pixels off a\n      // ClientRect's bounds, despite the event listener being triggered. A\n      // padding of 2 seems to handle this issue.\n      const {\n        padding = 2,\n        x,\n        y\n      } = evaluate(options, state);\n      const nativeClientRects = Array.from((await (platform.getClientRects == null ? void 0 : platform.getClientRects(elements.reference))) || []);\n      const clientRects = getRectsByLine(nativeClientRects);\n      const fallback = rectToClientRect(getBoundingRect(nativeClientRects));\n      const paddingObject = getPaddingObject(padding);\n      function getBoundingClientRect() {\n        // There are two rects and they are disjoined.\n        if (clientRects.length === 2 && clientRects[0].left > clientRects[1].right && x != null && y != null) {\n          // Find the first rect in which the point is fully inside.\n          return clientRects.find(rect => x > rect.left - paddingObject.left && x < rect.right + paddingObject.right && y > rect.top - paddingObject.top && y < rect.bottom + paddingObject.bottom) || fallback;\n        }\n\n        // There are 2 or more connected rects.\n        if (clientRects.length >= 2) {\n          if (getSideAxis(placement) === 'y') {\n            const firstRect = clientRects[0];\n            const lastRect = clientRects[clientRects.length - 1];\n            const isTop = getSide(placement) === 'top';\n            const top = firstRect.top;\n            const bottom = lastRect.bottom;\n            const left = isTop ? firstRect.left : lastRect.left;\n            const right = isTop ? firstRect.right : lastRect.right;\n            const width = right - left;\n            const height = bottom - top;\n            return {\n              top,\n              bottom,\n              left,\n              right,\n              width,\n              height,\n              x: left,\n              y: top\n            };\n          }\n          const isLeftSide = getSide(placement) === 'left';\n          const maxRight = max(...clientRects.map(rect => rect.right));\n          const minLeft = min(...clientRects.map(rect => rect.left));\n          const measureRects = clientRects.filter(rect => isLeftSide ? rect.left === minLeft : rect.right === maxRight);\n          const top = measureRects[0].top;\n          const bottom = measureRects[measureRects.length - 1].bottom;\n          const left = minLeft;\n          const right = maxRight;\n          const width = right - left;\n          const height = bottom - top;\n          return {\n            top,\n            bottom,\n            left,\n            right,\n            width,\n            height,\n            x: left,\n            y: top\n          };\n        }\n        return fallback;\n      }\n      const resetRects = await platform.getElementRects({\n        reference: {\n          getBoundingClientRect\n        },\n        floating: elements.floating,\n        strategy\n      });\n      if (rects.reference.x !== resetRects.reference.x || rects.reference.y !== resetRects.reference.y || rects.reference.width !== resetRects.reference.width || rects.reference.height !== resetRects.reference.height) {\n        return {\n          reset: {\n            rects: resetRects\n          }\n        };\n      }\n      return {};\n    }\n  };\n};\n\n// For type backwards-compatibility, the `OffsetOptions` type was also\n// Derivable.\n\nasync function convertValueToCoords(state, options) {\n  const {\n    placement,\n    platform,\n    elements\n  } = state;\n  const rtl = await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating));\n  const side = getSide(placement);\n  const alignment = getAlignment(placement);\n  const isVertical = getSideAxis(placement) === 'y';\n  const mainAxisMulti = ['left', 'top'].includes(side) ? -1 : 1;\n  const crossAxisMulti = rtl && isVertical ? -1 : 1;\n  const rawValue = evaluate(options, state);\n\n  // eslint-disable-next-line prefer-const\n  let {\n    mainAxis,\n    crossAxis,\n    alignmentAxis\n  } = typeof rawValue === 'number' ? {\n    mainAxis: rawValue,\n    crossAxis: 0,\n    alignmentAxis: null\n  } : {\n    mainAxis: rawValue.mainAxis || 0,\n    crossAxis: rawValue.crossAxis || 0,\n    alignmentAxis: rawValue.alignmentAxis\n  };\n  if (alignment && typeof alignmentAxis === 'number') {\n    crossAxis = alignment === 'end' ? alignmentAxis * -1 : alignmentAxis;\n  }\n  return isVertical ? {\n    x: crossAxis * crossAxisMulti,\n    y: mainAxis * mainAxisMulti\n  } : {\n    x: mainAxis * mainAxisMulti,\n    y: crossAxis * crossAxisMulti\n  };\n}\n\n/**\n * Modifies the placement by translating the floating element along the\n * specified axes.\n * A number (shorthand for `mainAxis` or distance), or an axes configuration\n * object may be passed.\n * @see https://floating-ui.com/docs/offset\n */\nconst offset = function (options) {\n  if (options === void 0) {\n    options = 0;\n  }\n  return {\n    name: 'offset',\n    options,\n    async fn(state) {\n      var _middlewareData$offse, _middlewareData$arrow;\n      const {\n        x,\n        y,\n        placement,\n        middlewareData\n      } = state;\n      const diffCoords = await convertValueToCoords(state, options);\n\n      // If the placement is the same and the arrow caused an alignment offset\n      // then we don't need to change the positioning coordinates.\n      if (placement === ((_middlewareData$offse = middlewareData.offset) == null ? void 0 : _middlewareData$offse.placement) && (_middlewareData$arrow = middlewareData.arrow) != null && _middlewareData$arrow.alignmentOffset) {\n        return {};\n      }\n      return {\n        x: x + diffCoords.x,\n        y: y + diffCoords.y,\n        data: {\n          ...diffCoords,\n          placement\n        }\n      };\n    }\n  };\n};\n\n/**\n * Optimizes the visibility of the floating element by shifting it in order to\n * keep it in view when it will overflow the clipping boundary.\n * @see https://floating-ui.com/docs/shift\n */\nconst shift = function (options) {\n  if (options === void 0) {\n    options = {};\n  }\n  return {\n    name: 'shift',\n    options,\n    async fn(state) {\n      const {\n        x,\n        y,\n        placement\n      } = state;\n      const {\n        mainAxis: checkMainAxis = true,\n        crossAxis: checkCrossAxis = false,\n        limiter = {\n          fn: _ref => {\n            let {\n              x,\n              y\n            } = _ref;\n            return {\n              x,\n              y\n            };\n          }\n        },\n        ...detectOverflowOptions\n      } = evaluate(options, state);\n      const coords = {\n        x,\n        y\n      };\n      const overflow = await detectOverflow(state, detectOverflowOptions);\n      const crossAxis = getSideAxis(getSide(placement));\n      const mainAxis = getOppositeAxis(crossAxis);\n      let mainAxisCoord = coords[mainAxis];\n      let crossAxisCoord = coords[crossAxis];\n      if (checkMainAxis) {\n        const minSide = mainAxis === 'y' ? 'top' : 'left';\n        const maxSide = mainAxis === 'y' ? 'bottom' : 'right';\n        const min = mainAxisCoord + overflow[minSide];\n        const max = mainAxisCoord - overflow[maxSide];\n        mainAxisCoord = clamp(min, mainAxisCoord, max);\n      }\n      if (checkCrossAxis) {\n        const minSide = crossAxis === 'y' ? 'top' : 'left';\n        const maxSide = crossAxis === 'y' ? 'bottom' : 'right';\n        const min = crossAxisCoord + overflow[minSide];\n        const max = crossAxisCoord - overflow[maxSide];\n        crossAxisCoord = clamp(min, crossAxisCoord, max);\n      }\n      const limitedCoords = limiter.fn({\n        ...state,\n        [mainAxis]: mainAxisCoord,\n        [crossAxis]: crossAxisCoord\n      });\n      return {\n        ...limitedCoords,\n        data: {\n          x: limitedCoords.x - x,\n          y: limitedCoords.y - y,\n          enabled: {\n            [mainAxis]: checkMainAxis,\n            [crossAxis]: checkCrossAxis\n          }\n        }\n      };\n    }\n  };\n};\n/**\n * Built-in `limiter` that will stop `shift()` at a certain point.\n */\nconst limitShift = function (options) {\n  if (options === void 0) {\n    options = {};\n  }\n  return {\n    options,\n    fn(state) {\n      const {\n        x,\n        y,\n        placement,\n        rects,\n        middlewareData\n      } = state;\n      const {\n        offset = 0,\n        mainAxis: checkMainAxis = true,\n        crossAxis: checkCrossAxis = true\n      } = evaluate(options, state);\n      const coords = {\n        x,\n        y\n      };\n      const crossAxis = getSideAxis(placement);\n      const mainAxis = getOppositeAxis(crossAxis);\n      let mainAxisCoord = coords[mainAxis];\n      let crossAxisCoord = coords[crossAxis];\n      const rawOffset = evaluate(offset, state);\n      const computedOffset = typeof rawOffset === 'number' ? {\n        mainAxis: rawOffset,\n        crossAxis: 0\n      } : {\n        mainAxis: 0,\n        crossAxis: 0,\n        ...rawOffset\n      };\n      if (checkMainAxis) {\n        const len = mainAxis === 'y' ? 'height' : 'width';\n        const limitMin = rects.reference[mainAxis] - rects.floating[len] + computedOffset.mainAxis;\n        const limitMax = rects.reference[mainAxis] + rects.reference[len] - computedOffset.mainAxis;\n        if (mainAxisCoord < limitMin) {\n          mainAxisCoord = limitMin;\n        } else if (mainAxisCoord > limitMax) {\n          mainAxisCoord = limitMax;\n        }\n      }\n      if (checkCrossAxis) {\n        var _middlewareData$offse, _middlewareData$offse2;\n        const len = mainAxis === 'y' ? 'width' : 'height';\n        const isOriginSide = ['top', 'left'].includes(getSide(placement));\n        const limitMin = rects.reference[crossAxis] - rects.floating[len] + (isOriginSide ? ((_middlewareData$offse = middlewareData.offset) == null ? void 0 : _middlewareData$offse[crossAxis]) || 0 : 0) + (isOriginSide ? 0 : computedOffset.crossAxis);\n        const limitMax = rects.reference[crossAxis] + rects.reference[len] + (isOriginSide ? 0 : ((_middlewareData$offse2 = middlewareData.offset) == null ? void 0 : _middlewareData$offse2[crossAxis]) || 0) - (isOriginSide ? computedOffset.crossAxis : 0);\n        if (crossAxisCoord < limitMin) {\n          crossAxisCoord = limitMin;\n        } else if (crossAxisCoord > limitMax) {\n          crossAxisCoord = limitMax;\n        }\n      }\n      return {\n        [mainAxis]: mainAxisCoord,\n        [crossAxis]: crossAxisCoord\n      };\n    }\n  };\n};\n\n/**\n * Provides data that allows you to change the size of the floating element —\n * for instance, prevent it from overflowing the clipping boundary or match the\n * width of the reference element.\n * @see https://floating-ui.com/docs/size\n */\nconst size = function (options) {\n  if (options === void 0) {\n    options = {};\n  }\n  return {\n    name: 'size',\n    options,\n    async fn(state) {\n      var _state$middlewareData, _state$middlewareData2;\n      const {\n        placement,\n        rects,\n        platform,\n        elements\n      } = state;\n      const {\n        apply = () => {},\n        ...detectOverflowOptions\n      } = evaluate(options, state);\n      const overflow = await detectOverflow(state, detectOverflowOptions);\n      const side = getSide(placement);\n      const alignment = getAlignment(placement);\n      const isYAxis = getSideAxis(placement) === 'y';\n      const {\n        width,\n        height\n      } = rects.floating;\n      let heightSide;\n      let widthSide;\n      if (side === 'top' || side === 'bottom') {\n        heightSide = side;\n        widthSide = alignment === ((await (platform.isRTL == null ? void 0 : platform.isRTL(elements.floating))) ? 'start' : 'end') ? 'left' : 'right';\n      } else {\n        widthSide = side;\n        heightSide = alignment === 'end' ? 'top' : 'bottom';\n      }\n      const maximumClippingHeight = height - overflow.top - overflow.bottom;\n      const maximumClippingWidth = width - overflow.left - overflow.right;\n      const overflowAvailableHeight = min(height - overflow[heightSide], maximumClippingHeight);\n      const overflowAvailableWidth = min(width - overflow[widthSide], maximumClippingWidth);\n      const noShift = !state.middlewareData.shift;\n      let availableHeight = overflowAvailableHeight;\n      let availableWidth = overflowAvailableWidth;\n      if ((_state$middlewareData = state.middlewareData.shift) != null && _state$middlewareData.enabled.x) {\n        availableWidth = maximumClippingWidth;\n      }\n      if ((_state$middlewareData2 = state.middlewareData.shift) != null && _state$middlewareData2.enabled.y) {\n        availableHeight = maximumClippingHeight;\n      }\n      if (noShift && !alignment) {\n        const xMin = max(overflow.left, 0);\n        const xMax = max(overflow.right, 0);\n        const yMin = max(overflow.top, 0);\n        const yMax = max(overflow.bottom, 0);\n        if (isYAxis) {\n          availableWidth = width - 2 * (xMin !== 0 || xMax !== 0 ? xMin + xMax : max(overflow.left, overflow.right));\n        } else {\n          availableHeight = height - 2 * (yMin !== 0 || yMax !== 0 ? yMin + yMax : max(overflow.top, overflow.bottom));\n        }\n      }\n      await apply({\n        ...state,\n        availableWidth,\n        availableHeight\n      });\n      const nextDimensions = await platform.getDimensions(elements.floating);\n      if (width !== nextDimensions.width || height !== nextDimensions.height) {\n        return {\n          reset: {\n            rects: true\n          }\n        };\n      }\n      return {};\n    }\n  };\n};\n\nexport { arrow, autoPlacement, computePosition, detectOverflow, flip, hide, inline, limitShift, offset, shift, size };\n","function hasWindow() {\n  return typeof window !== 'undefined';\n}\nfunction getNodeName(node) {\n  if (isNode(node)) {\n    return (node.nodeName || '').toLowerCase();\n  }\n  // Mocked nodes in testing environments may not be instances of Node. By\n  // returning `#document` an infinite loop won't occur.\n  // https://github.com/floating-ui/floating-ui/issues/2317\n  return '#document';\n}\nfunction getWindow(node) {\n  var _node$ownerDocument;\n  return (node == null || (_node$ownerDocument = node.ownerDocument) == null ? void 0 : _node$ownerDocument.defaultView) || window;\n}\nfunction getDocumentElement(node) {\n  var _ref;\n  return (_ref = (isNode(node) ? node.ownerDocument : node.document) || window.document) == null ? void 0 : _ref.documentElement;\n}\nfunction isNode(value) {\n  if (!hasWindow()) {\n    return false;\n  }\n  return value instanceof Node || value instanceof getWindow(value).Node;\n}\nfunction isElement(value) {\n  if (!hasWindow()) {\n    return false;\n  }\n  return value instanceof Element || value instanceof getWindow(value).Element;\n}\nfunction isHTMLElement(value) {\n  if (!hasWindow()) {\n    return false;\n  }\n  return value instanceof HTMLElement || value instanceof getWindow(value).HTMLElement;\n}\nfunction isShadowRoot(value) {\n  if (!hasWindow() || typeof ShadowRoot === 'undefined') {\n    return false;\n  }\n  return value instanceof ShadowRoot || value instanceof getWindow(value).ShadowRoot;\n}\nfunction isOverflowElement(element) {\n  const {\n    overflow,\n    overflowX,\n    overflowY,\n    display\n  } = getComputedStyle(element);\n  return /auto|scroll|overlay|hidden|clip/.test(overflow + overflowY + overflowX) && !['inline', 'contents'].includes(display);\n}\nfunction isTableElement(element) {\n  return ['table', 'td', 'th'].includes(getNodeName(element));\n}\nfunction isTopLayer(element) {\n  return [':popover-open', ':modal'].some(selector => {\n    try {\n      return element.matches(selector);\n    } catch (e) {\n      return false;\n    }\n  });\n}\nfunction isContainingBlock(elementOrCss) {\n  const webkit = isWebKit();\n  const css = isElement(elementOrCss) ? getComputedStyle(elementOrCss) : elementOrCss;\n\n  // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block\n  // https://drafts.csswg.org/css-transforms-2/#individual-transforms\n  return ['transform', 'translate', 'scale', 'rotate', 'perspective'].some(value => css[value] ? css[value] !== 'none' : false) || (css.containerType ? css.containerType !== 'normal' : false) || !webkit && (css.backdropFilter ? css.backdropFilter !== 'none' : false) || !webkit && (css.filter ? css.filter !== 'none' : false) || ['transform', 'translate', 'scale', 'rotate', 'perspective', 'filter'].some(value => (css.willChange || '').includes(value)) || ['paint', 'layout', 'strict', 'content'].some(value => (css.contain || '').includes(value));\n}\nfunction getContainingBlock(element) {\n  let currentNode = getParentNode(element);\n  while (isHTMLElement(currentNode) && !isLastTraversableNode(currentNode)) {\n    if (isContainingBlock(currentNode)) {\n      return currentNode;\n    } else if (isTopLayer(currentNode)) {\n      return null;\n    }\n    currentNode = getParentNode(currentNode);\n  }\n  return null;\n}\nfunction isWebKit() {\n  if (typeof CSS === 'undefined' || !CSS.supports) return false;\n  return CSS.supports('-webkit-backdrop-filter', 'none');\n}\nfunction isLastTraversableNode(node) {\n  return ['html', 'body', '#document'].includes(getNodeName(node));\n}\nfunction getComputedStyle(element) {\n  return getWindow(element).getComputedStyle(element);\n}\nfunction getNodeScroll(element) {\n  if (isElement(element)) {\n    return {\n      scrollLeft: element.scrollLeft,\n      scrollTop: element.scrollTop\n    };\n  }\n  return {\n    scrollLeft: element.scrollX,\n    scrollTop: element.scrollY\n  };\n}\nfunction getParentNode(node) {\n  if (getNodeName(node) === 'html') {\n    return node;\n  }\n  const result =\n  // Step into the shadow DOM of the parent of a slotted node.\n  node.assignedSlot ||\n  // DOM Element detected.\n  node.parentNode ||\n  // ShadowRoot detected.\n  isShadowRoot(node) && node.host ||\n  // Fallback.\n  getDocumentElement(node);\n  return isShadowRoot(result) ? result.host : result;\n}\nfunction getNearestOverflowAncestor(node) {\n  const parentNode = getParentNode(node);\n  if (isLastTraversableNode(parentNode)) {\n    return node.ownerDocument ? node.ownerDocument.body : node.body;\n  }\n  if (isHTMLElement(parentNode) && isOverflowElement(parentNode)) {\n    return parentNode;\n  }\n  return getNearestOverflowAncestor(parentNode);\n}\nfunction getOverflowAncestors(node, list, traverseIframes) {\n  var _node$ownerDocument2;\n  if (list === void 0) {\n    list = [];\n  }\n  if (traverseIframes === void 0) {\n    traverseIframes = true;\n  }\n  const scrollableAncestor = getNearestOverflowAncestor(node);\n  const isBody = scrollableAncestor === ((_node$ownerDocument2 = node.ownerDocument) == null ? void 0 : _node$ownerDocument2.body);\n  const win = getWindow(scrollableAncestor);\n  if (isBody) {\n    const frameElement = getFrameElement(win);\n    return list.concat(win, win.visualViewport || [], isOverflowElement(scrollableAncestor) ? scrollableAncestor : [], frameElement && traverseIframes ? getOverflowAncestors(frameElement) : []);\n  }\n  return list.concat(scrollableAncestor, getOverflowAncestors(scrollableAncestor, [], traverseIframes));\n}\nfunction getFrameElement(win) {\n  return win.parent && Object.getPrototypeOf(win.parent) ? win.frameElement : null;\n}\n\nexport { getComputedStyle, getContainingBlock, getDocumentElement, getFrameElement, getNearestOverflowAncestor, getNodeName, getNodeScroll, getOverflowAncestors, getParentNode, getWindow, isContainingBlock, isElement, isHTMLElement, isLastTraversableNode, isNode, isOverflowElement, isShadowRoot, isTableElement, isTopLayer, isWebKit };\n","import { rectToClientRect, detectOverflow as detectOverflow$1, offset as offset$1, autoPlacement as autoPlacement$1, shift as shift$1, flip as flip$1, size as size$1, hide as hide$1, arrow as arrow$1, inline as inline$1, limitShift as limitShift$1, computePosition as computePosition$1 } from '@floating-ui/core';\nimport { round, createCoords, max, min, floor } from '@floating-ui/utils';\nimport { getComputedStyle, isHTMLElement, isElement, getWindow, isWebKit, getFrameElement, getNodeScroll, getDocumentElement, isTopLayer, getNodeName, isOverflowElement, getOverflowAncestors, getParentNode, isLastTraversableNode, isContainingBlock, isTableElement, getContainingBlock } from '@floating-ui/utils/dom';\nexport { getOverflowAncestors } from '@floating-ui/utils/dom';\n\nfunction getCssDimensions(element) {\n  const css = getComputedStyle(element);\n  // In testing environments, the `width` and `height` properties are empty\n  // strings for SVG elements, returning NaN. Fallback to `0` in this case.\n  let width = parseFloat(css.width) || 0;\n  let height = parseFloat(css.height) || 0;\n  const hasOffset = isHTMLElement(element);\n  const offsetWidth = hasOffset ? element.offsetWidth : width;\n  const offsetHeight = hasOffset ? element.offsetHeight : height;\n  const shouldFallback = round(width) !== offsetWidth || round(height) !== offsetHeight;\n  if (shouldFallback) {\n    width = offsetWidth;\n    height = offsetHeight;\n  }\n  return {\n    width,\n    height,\n    $: shouldFallback\n  };\n}\n\nfunction unwrapElement(element) {\n  return !isElement(element) ? element.contextElement : element;\n}\n\nfunction getScale(element) {\n  const domElement = unwrapElement(element);\n  if (!isHTMLElement(domElement)) {\n    return createCoords(1);\n  }\n  const rect = domElement.getBoundingClientRect();\n  const {\n    width,\n    height,\n    $\n  } = getCssDimensions(domElement);\n  let x = ($ ? round(rect.width) : rect.width) / width;\n  let y = ($ ? round(rect.height) : rect.height) / height;\n\n  // 0, NaN, or Infinity should always fallback to 1.\n\n  if (!x || !Number.isFinite(x)) {\n    x = 1;\n  }\n  if (!y || !Number.isFinite(y)) {\n    y = 1;\n  }\n  return {\n    x,\n    y\n  };\n}\n\nconst noOffsets = /*#__PURE__*/createCoords(0);\nfunction getVisualOffsets(element) {\n  const win = getWindow(element);\n  if (!isWebKit() || !win.visualViewport) {\n    return noOffsets;\n  }\n  return {\n    x: win.visualViewport.offsetLeft,\n    y: win.visualViewport.offsetTop\n  };\n}\nfunction shouldAddVisualOffsets(element, isFixed, floatingOffsetParent) {\n  if (isFixed === void 0) {\n    isFixed = false;\n  }\n  if (!floatingOffsetParent || isFixed && floatingOffsetParent !== getWindow(element)) {\n    return false;\n  }\n  return isFixed;\n}\n\nfunction getBoundingClientRect(element, includeScale, isFixedStrategy, offsetParent) {\n  if (includeScale === void 0) {\n    includeScale = false;\n  }\n  if (isFixedStrategy === void 0) {\n    isFixedStrategy = false;\n  }\n  const clientRect = element.getBoundingClientRect();\n  const domElement = unwrapElement(element);\n  let scale = createCoords(1);\n  if (includeScale) {\n    if (offsetParent) {\n      if (isElement(offsetParent)) {\n        scale = getScale(offsetParent);\n      }\n    } else {\n      scale = getScale(element);\n    }\n  }\n  const visualOffsets = shouldAddVisualOffsets(domElement, isFixedStrategy, offsetParent) ? getVisualOffsets(domElement) : createCoords(0);\n  let x = (clientRect.left + visualOffsets.x) / scale.x;\n  let y = (clientRect.top + visualOffsets.y) / scale.y;\n  let width = clientRect.width / scale.x;\n  let height = clientRect.height / scale.y;\n  if (domElement) {\n    const win = getWindow(domElement);\n    const offsetWin = offsetParent && isElement(offsetParent) ? getWindow(offsetParent) : offsetParent;\n    let currentWin = win;\n    let currentIFrame = getFrameElement(currentWin);\n    while (currentIFrame && offsetParent && offsetWin !== currentWin) {\n      const iframeScale = getScale(currentIFrame);\n      const iframeRect = currentIFrame.getBoundingClientRect();\n      const css = getComputedStyle(currentIFrame);\n      const left = iframeRect.left + (currentIFrame.clientLeft + parseFloat(css.paddingLeft)) * iframeScale.x;\n      const top = iframeRect.top + (currentIFrame.clientTop + parseFloat(css.paddingTop)) * iframeScale.y;\n      x *= iframeScale.x;\n      y *= iframeScale.y;\n      width *= iframeScale.x;\n      height *= iframeScale.y;\n      x += left;\n      y += top;\n      currentWin = getWindow(currentIFrame);\n      currentIFrame = getFrameElement(currentWin);\n    }\n  }\n  return rectToClientRect({\n    width,\n    height,\n    x,\n    y\n  });\n}\n\n// If <html> has a CSS width greater than the viewport, then this will be\n// incorrect for RTL.\nfunction getWindowScrollBarX(element, rect) {\n  const leftScroll = getNodeScroll(element).scrollLeft;\n  if (!rect) {\n    return getBoundingClientRect(getDocumentElement(element)).left + leftScroll;\n  }\n  return rect.left + leftScroll;\n}\n\nfunction getHTMLOffset(documentElement, scroll, ignoreScrollbarX) {\n  if (ignoreScrollbarX === void 0) {\n    ignoreScrollbarX = false;\n  }\n  const htmlRect = documentElement.getBoundingClientRect();\n  const x = htmlRect.left + scroll.scrollLeft - (ignoreScrollbarX ? 0 :\n  // RTL <body> scrollbar.\n  getWindowScrollBarX(documentElement, htmlRect));\n  const y = htmlRect.top + scroll.scrollTop;\n  return {\n    x,\n    y\n  };\n}\n\nfunction convertOffsetParentRelativeRectToViewportRelativeRect(_ref) {\n  let {\n    elements,\n    rect,\n    offsetParent,\n    strategy\n  } = _ref;\n  const isFixed = strategy === 'fixed';\n  const documentElement = getDocumentElement(offsetParent);\n  const topLayer = elements ? isTopLayer(elements.floating) : false;\n  if (offsetParent === documentElement || topLayer && isFixed) {\n    return rect;\n  }\n  let scroll = {\n    scrollLeft: 0,\n    scrollTop: 0\n  };\n  let scale = createCoords(1);\n  const offsets = createCoords(0);\n  const isOffsetParentAnElement = isHTMLElement(offsetParent);\n  if (isOffsetParentAnElement || !isOffsetParentAnElement && !isFixed) {\n    if (getNodeName(offsetParent) !== 'body' || isOverflowElement(documentElement)) {\n      scroll = getNodeScroll(offsetParent);\n    }\n    if (isHTMLElement(offsetParent)) {\n      const offsetRect = getBoundingClientRect(offsetParent);\n      scale = getScale(offsetParent);\n      offsets.x = offsetRect.x + offsetParent.clientLeft;\n      offsets.y = offsetRect.y + offsetParent.clientTop;\n    }\n  }\n  const htmlOffset = documentElement && !isOffsetParentAnElement && !isFixed ? getHTMLOffset(documentElement, scroll, true) : createCoords(0);\n  return {\n    width: rect.width * scale.x,\n    height: rect.height * scale.y,\n    x: rect.x * scale.x - scroll.scrollLeft * scale.x + offsets.x + htmlOffset.x,\n    y: rect.y * scale.y - scroll.scrollTop * scale.y + offsets.y + htmlOffset.y\n  };\n}\n\nfunction getClientRects(element) {\n  return Array.from(element.getClientRects());\n}\n\n// Gets the entire size of the scrollable document area, even extending outside\n// of the `<html>` and `<body>` rect bounds if horizontally scrollable.\nfunction getDocumentRect(element) {\n  const html = getDocumentElement(element);\n  const scroll = getNodeScroll(element);\n  const body = element.ownerDocument.body;\n  const width = max(html.scrollWidth, html.clientWidth, body.scrollWidth, body.clientWidth);\n  const height = max(html.scrollHeight, html.clientHeight, body.scrollHeight, body.clientHeight);\n  let x = -scroll.scrollLeft + getWindowScrollBarX(element);\n  const y = -scroll.scrollTop;\n  if (getComputedStyle(body).direction === 'rtl') {\n    x += max(html.clientWidth, body.clientWidth) - width;\n  }\n  return {\n    width,\n    height,\n    x,\n    y\n  };\n}\n\nfunction getViewportRect(element, strategy) {\n  const win = getWindow(element);\n  const html = getDocumentElement(element);\n  const visualViewport = win.visualViewport;\n  let width = html.clientWidth;\n  let height = html.clientHeight;\n  let x = 0;\n  let y = 0;\n  if (visualViewport) {\n    width = visualViewport.width;\n    height = visualViewport.height;\n    const visualViewportBased = isWebKit();\n    if (!visualViewportBased || visualViewportBased && strategy === 'fixed') {\n      x = visualViewport.offsetLeft;\n      y = visualViewport.offsetTop;\n    }\n  }\n  return {\n    width,\n    height,\n    x,\n    y\n  };\n}\n\n// Returns the inner client rect, subtracting scrollbars if present.\nfunction getInnerBoundingClientRect(element, strategy) {\n  const clientRect = getBoundingClientRect(element, true, strategy === 'fixed');\n  const top = clientRect.top + element.clientTop;\n  const left = clientRect.left + element.clientLeft;\n  const scale = isHTMLElement(element) ? getScale(element) : createCoords(1);\n  const width = element.clientWidth * scale.x;\n  const height = element.clientHeight * scale.y;\n  const x = left * scale.x;\n  const y = top * scale.y;\n  return {\n    width,\n    height,\n    x,\n    y\n  };\n}\nfunction getClientRectFromClippingAncestor(element, clippingAncestor, strategy) {\n  let rect;\n  if (clippingAncestor === 'viewport') {\n    rect = getViewportRect(element, strategy);\n  } else if (clippingAncestor === 'document') {\n    rect = getDocumentRect(getDocumentElement(element));\n  } else if (isElement(clippingAncestor)) {\n    rect = getInnerBoundingClientRect(clippingAncestor, strategy);\n  } else {\n    const visualOffsets = getVisualOffsets(element);\n    rect = {\n      x: clippingAncestor.x - visualOffsets.x,\n      y: clippingAncestor.y - visualOffsets.y,\n      width: clippingAncestor.width,\n      height: clippingAncestor.height\n    };\n  }\n  return rectToClientRect(rect);\n}\nfunction hasFixedPositionAncestor(element, stopNode) {\n  const parentNode = getParentNode(element);\n  if (parentNode === stopNode || !isElement(parentNode) || isLastTraversableNode(parentNode)) {\n    return false;\n  }\n  return getComputedStyle(parentNode).position === 'fixed' || hasFixedPositionAncestor(parentNode, stopNode);\n}\n\n// A \"clipping ancestor\" is an `overflow` element with the characteristic of\n// clipping (or hiding) child elements. This returns all clipping ancestors\n// of the given element up the tree.\nfunction getClippingElementAncestors(element, cache) {\n  const cachedResult = cache.get(element);\n  if (cachedResult) {\n    return cachedResult;\n  }\n  let result = getOverflowAncestors(element, [], false).filter(el => isElement(el) && getNodeName(el) !== 'body');\n  let currentContainingBlockComputedStyle = null;\n  const elementIsFixed = getComputedStyle(element).position === 'fixed';\n  let currentNode = elementIsFixed ? getParentNode(element) : element;\n\n  // https://developer.mozilla.org/en-US/docs/Web/CSS/Containing_block#identifying_the_containing_block\n  while (isElement(currentNode) && !isLastTraversableNode(currentNode)) {\n    const computedStyle = getComputedStyle(currentNode);\n    const currentNodeIsContaining = isContainingBlock(currentNode);\n    if (!currentNodeIsContaining && computedStyle.position === 'fixed') {\n      currentContainingBlockComputedStyle = null;\n    }\n    const shouldDropCurrentNode = elementIsFixed ? !currentNodeIsContaining && !currentContainingBlockComputedStyle : !currentNodeIsContaining && computedStyle.position === 'static' && !!currentContainingBlockComputedStyle && ['absolute', 'fixed'].includes(currentContainingBlockComputedStyle.position) || isOverflowElement(currentNode) && !currentNodeIsContaining && hasFixedPositionAncestor(element, currentNode);\n    if (shouldDropCurrentNode) {\n      // Drop non-containing blocks.\n      result = result.filter(ancestor => ancestor !== currentNode);\n    } else {\n      // Record last containing block for next iteration.\n      currentContainingBlockComputedStyle = computedStyle;\n    }\n    currentNode = getParentNode(currentNode);\n  }\n  cache.set(element, result);\n  return result;\n}\n\n// Gets the maximum area that the element is visible in due to any number of\n// clipping ancestors.\nfunction getClippingRect(_ref) {\n  let {\n    element,\n    boundary,\n    rootBoundary,\n    strategy\n  } = _ref;\n  const elementClippingAncestors = boundary === 'clippingAncestors' ? isTopLayer(element) ? [] : getClippingElementAncestors(element, this._c) : [].concat(boundary);\n  const clippingAncestors = [...elementClippingAncestors, rootBoundary];\n  const firstClippingAncestor = clippingAncestors[0];\n  const clippingRect = clippingAncestors.reduce((accRect, clippingAncestor) => {\n    const rect = getClientRectFromClippingAncestor(element, clippingAncestor, strategy);\n    accRect.top = max(rect.top, accRect.top);\n    accRect.right = min(rect.right, accRect.right);\n    accRect.bottom = min(rect.bottom, accRect.bottom);\n    accRect.left = max(rect.left, accRect.left);\n    return accRect;\n  }, getClientRectFromClippingAncestor(element, firstClippingAncestor, strategy));\n  return {\n    width: clippingRect.right - clippingRect.left,\n    height: clippingRect.bottom - clippingRect.top,\n    x: clippingRect.left,\n    y: clippingRect.top\n  };\n}\n\nfunction getDimensions(element) {\n  const {\n    width,\n    height\n  } = getCssDimensions(element);\n  return {\n    width,\n    height\n  };\n}\n\nfunction getRectRelativeToOffsetParent(element, offsetParent, strategy) {\n  const isOffsetParentAnElement = isHTMLElement(offsetParent);\n  const documentElement = getDocumentElement(offsetParent);\n  const isFixed = strategy === 'fixed';\n  const rect = getBoundingClientRect(element, true, isFixed, offsetParent);\n  let scroll = {\n    scrollLeft: 0,\n    scrollTop: 0\n  };\n  const offsets = createCoords(0);\n  if (isOffsetParentAnElement || !isOffsetParentAnElement && !isFixed) {\n    if (getNodeName(offsetParent) !== 'body' || isOverflowElement(documentElement)) {\n      scroll = getNodeScroll(offsetParent);\n    }\n    if (isOffsetParentAnElement) {\n      const offsetRect = getBoundingClientRect(offsetParent, true, isFixed, offsetParent);\n      offsets.x = offsetRect.x + offsetParent.clientLeft;\n      offsets.y = offsetRect.y + offsetParent.clientTop;\n    } else if (documentElement) {\n      // If the <body> scrollbar appears on the left (e.g. RTL systems). Use\n      // Firefox with layout.scrollbar.side = 3 in about:config to test this.\n      offsets.x = getWindowScrollBarX(documentElement);\n    }\n  }\n  const htmlOffset = documentElement && !isOffsetParentAnElement && !isFixed ? getHTMLOffset(documentElement, scroll) : createCoords(0);\n  const x = rect.left + scroll.scrollLeft - offsets.x - htmlOffset.x;\n  const y = rect.top + scroll.scrollTop - offsets.y - htmlOffset.y;\n  return {\n    x,\n    y,\n    width: rect.width,\n    height: rect.height\n  };\n}\n\nfunction isStaticPositioned(element) {\n  return getComputedStyle(element).position === 'static';\n}\n\nfunction getTrueOffsetParent(element, polyfill) {\n  if (!isHTMLElement(element) || getComputedStyle(element).position === 'fixed') {\n    return null;\n  }\n  if (polyfill) {\n    return polyfill(element);\n  }\n  let rawOffsetParent = element.offsetParent;\n\n  // Firefox returns the <html> element as the offsetParent if it's non-static,\n  // while Chrome and Safari return the <body> element. The <body> element must\n  // be used to perform the correct calculations even if the <html> element is\n  // non-static.\n  if (getDocumentElement(element) === rawOffsetParent) {\n    rawOffsetParent = rawOffsetParent.ownerDocument.body;\n  }\n  return rawOffsetParent;\n}\n\n// Gets the closest ancestor positioned element. Handles some edge cases,\n// such as table ancestors and cross browser bugs.\nfunction getOffsetParent(element, polyfill) {\n  const win = getWindow(element);\n  if (isTopLayer(element)) {\n    return win;\n  }\n  if (!isHTMLElement(element)) {\n    let svgOffsetParent = getParentNode(element);\n    while (svgOffsetParent && !isLastTraversableNode(svgOffsetParent)) {\n      if (isElement(svgOffsetParent) && !isStaticPositioned(svgOffsetParent)) {\n        return svgOffsetParent;\n      }\n      svgOffsetParent = getParentNode(svgOffsetParent);\n    }\n    return win;\n  }\n  let offsetParent = getTrueOffsetParent(element, polyfill);\n  while (offsetParent && isTableElement(offsetParent) && isStaticPositioned(offsetParent)) {\n    offsetParent = getTrueOffsetParent(offsetParent, polyfill);\n  }\n  if (offsetParent && isLastTraversableNode(offsetParent) && isStaticPositioned(offsetParent) && !isContainingBlock(offsetParent)) {\n    return win;\n  }\n  return offsetParent || getContainingBlock(element) || win;\n}\n\nconst getElementRects = async function (data) {\n  const getOffsetParentFn = this.getOffsetParent || getOffsetParent;\n  const getDimensionsFn = this.getDimensions;\n  const floatingDimensions = await getDimensionsFn(data.floating);\n  return {\n    reference: getRectRelativeToOffsetParent(data.reference, await getOffsetParentFn(data.floating), data.strategy),\n    floating: {\n      x: 0,\n      y: 0,\n      width: floatingDimensions.width,\n      height: floatingDimensions.height\n    }\n  };\n};\n\nfunction isRTL(element) {\n  return getComputedStyle(element).direction === 'rtl';\n}\n\nconst platform = {\n  convertOffsetParentRelativeRectToViewportRelativeRect,\n  getDocumentElement,\n  getClippingRect,\n  getOffsetParent,\n  getElementRects,\n  getClientRects,\n  getDimensions,\n  getScale,\n  isElement,\n  isRTL\n};\n\nfunction rectsAreEqual(a, b) {\n  return a.x === b.x && a.y === b.y && a.width === b.width && a.height === b.height;\n}\n\n// https://samthor.au/2021/observing-dom/\nfunction observeMove(element, onMove) {\n  let io = null;\n  let timeoutId;\n  const root = getDocumentElement(element);\n  function cleanup() {\n    var _io;\n    clearTimeout(timeoutId);\n    (_io = io) == null || _io.disconnect();\n    io = null;\n  }\n  function refresh(skip, threshold) {\n    if (skip === void 0) {\n      skip = false;\n    }\n    if (threshold === void 0) {\n      threshold = 1;\n    }\n    cleanup();\n    const elementRectForRootMargin = element.getBoundingClientRect();\n    const {\n      left,\n      top,\n      width,\n      height\n    } = elementRectForRootMargin;\n    if (!skip) {\n      onMove();\n    }\n    if (!width || !height) {\n      return;\n    }\n    const insetTop = floor(top);\n    const insetRight = floor(root.clientWidth - (left + width));\n    const insetBottom = floor(root.clientHeight - (top + height));\n    const insetLeft = floor(left);\n    const rootMargin = -insetTop + \"px \" + -insetRight + \"px \" + -insetBottom + \"px \" + -insetLeft + \"px\";\n    const options = {\n      rootMargin,\n      threshold: max(0, min(1, threshold)) || 1\n    };\n    let isFirstUpdate = true;\n    function handleObserve(entries) {\n      const ratio = entries[0].intersectionRatio;\n      if (ratio !== threshold) {\n        if (!isFirstUpdate) {\n          return refresh();\n        }\n        if (!ratio) {\n          // If the reference is clipped, the ratio is 0. Throttle the refresh\n          // to prevent an infinite loop of updates.\n          timeoutId = setTimeout(() => {\n            refresh(false, 1e-7);\n          }, 1000);\n        } else {\n          refresh(false, ratio);\n        }\n      }\n      if (ratio === 1 && !rectsAreEqual(elementRectForRootMargin, element.getBoundingClientRect())) {\n        // It's possible that even though the ratio is reported as 1, the\n        // element is not actually fully within the IntersectionObserver's root\n        // area anymore. This can happen under performance constraints. This may\n        // be a bug in the browser's IntersectionObserver implementation. To\n        // work around this, we compare the element's bounding rect now with\n        // what it was at the time we created the IntersectionObserver. If they\n        // are not equal then the element moved, so we refresh.\n        refresh();\n      }\n      isFirstUpdate = false;\n    }\n\n    // Older browsers don't support a `document` as the root and will throw an\n    // error.\n    try {\n      io = new IntersectionObserver(handleObserve, {\n        ...options,\n        // Handle <iframe>s\n        root: root.ownerDocument\n      });\n    } catch (e) {\n      io = new IntersectionObserver(handleObserve, options);\n    }\n    io.observe(element);\n  }\n  refresh(true);\n  return cleanup;\n}\n\n/**\n * Automatically updates the position of the floating element when necessary.\n * Should only be called when the floating element is mounted on the DOM or\n * visible on the screen.\n * @returns cleanup function that should be invoked when the floating element is\n * removed from the DOM or hidden from the screen.\n * @see https://floating-ui.com/docs/autoUpdate\n */\nfunction autoUpdate(reference, floating, update, options) {\n  if (options === void 0) {\n    options = {};\n  }\n  const {\n    ancestorScroll = true,\n    ancestorResize = true,\n    elementResize = typeof ResizeObserver === 'function',\n    layoutShift = typeof IntersectionObserver === 'function',\n    animationFrame = false\n  } = options;\n  const referenceEl = unwrapElement(reference);\n  const ancestors = ancestorScroll || ancestorResize ? [...(referenceEl ? getOverflowAncestors(referenceEl) : []), ...getOverflowAncestors(floating)] : [];\n  ancestors.forEach(ancestor => {\n    ancestorScroll && ancestor.addEventListener('scroll', update, {\n      passive: true\n    });\n    ancestorResize && ancestor.addEventListener('resize', update);\n  });\n  const cleanupIo = referenceEl && layoutShift ? observeMove(referenceEl, update) : null;\n  let reobserveFrame = -1;\n  let resizeObserver = null;\n  if (elementResize) {\n    resizeObserver = new ResizeObserver(_ref => {\n      let [firstEntry] = _ref;\n      if (firstEntry && firstEntry.target === referenceEl && resizeObserver) {\n        // Prevent update loops when using the `size` middleware.\n        // https://github.com/floating-ui/floating-ui/issues/1740\n        resizeObserver.unobserve(floating);\n        cancelAnimationFrame(reobserveFrame);\n        reobserveFrame = requestAnimationFrame(() => {\n          var _resizeObserver;\n          (_resizeObserver = resizeObserver) == null || _resizeObserver.observe(floating);\n        });\n      }\n      update();\n    });\n    if (referenceEl && !animationFrame) {\n      resizeObserver.observe(referenceEl);\n    }\n    resizeObserver.observe(floating);\n  }\n  let frameId;\n  let prevRefRect = animationFrame ? getBoundingClientRect(reference) : null;\n  if (animationFrame) {\n    frameLoop();\n  }\n  function frameLoop() {\n    const nextRefRect = getBoundingClientRect(reference);\n    if (prevRefRect && !rectsAreEqual(prevRefRect, nextRefRect)) {\n      update();\n    }\n    prevRefRect = nextRefRect;\n    frameId = requestAnimationFrame(frameLoop);\n  }\n  update();\n  return () => {\n    var _resizeObserver2;\n    ancestors.forEach(ancestor => {\n      ancestorScroll && ancestor.removeEventListener('scroll', update);\n      ancestorResize && ancestor.removeEventListener('resize', update);\n    });\n    cleanupIo == null || cleanupIo();\n    (_resizeObserver2 = resizeObserver) == null || _resizeObserver2.disconnect();\n    resizeObserver = null;\n    if (animationFrame) {\n      cancelAnimationFrame(frameId);\n    }\n  };\n}\n\n/**\n * Resolves with an object of overflow side offsets that determine how much the\n * element is overflowing a given clipping boundary on each side.\n * - positive = overflowing the boundary by that number of pixels\n * - negative = how many pixels left before it will overflow\n * - 0 = lies flush with the boundary\n * @see https://floating-ui.com/docs/detectOverflow\n */\nconst detectOverflow = detectOverflow$1;\n\n/**\n * Modifies the placement by translating the floating element along the\n * specified axes.\n * A number (shorthand for `mainAxis` or distance), or an axes configuration\n * object may be passed.\n * @see https://floating-ui.com/docs/offset\n */\nconst offset = offset$1;\n\n/**\n * Optimizes the visibility of the floating element by choosing the placement\n * that has the most space available automatically, without needing to specify a\n * preferred placement. Alternative to `flip`.\n * @see https://floating-ui.com/docs/autoPlacement\n */\nconst autoPlacement = autoPlacement$1;\n\n/**\n * Optimizes the visibility of the floating element by shifting it in order to\n * keep it in view when it will overflow the clipping boundary.\n * @see https://floating-ui.com/docs/shift\n */\nconst shift = shift$1;\n\n/**\n * Optimizes the visibility of the floating element by flipping the `placement`\n * in order to keep it in view when the preferred placement(s) will overflow the\n * clipping boundary. Alternative to `autoPlacement`.\n * @see https://floating-ui.com/docs/flip\n */\nconst flip = flip$1;\n\n/**\n * Provides data that allows you to change the size of the floating element —\n * for instance, prevent it from overflowing the clipping boundary or match the\n * width of the reference element.\n * @see https://floating-ui.com/docs/size\n */\nconst size = size$1;\n\n/**\n * Provides data to hide the floating element in applicable situations, such as\n * when it is not in the same clipping context as the reference element.\n * @see https://floating-ui.com/docs/hide\n */\nconst hide = hide$1;\n\n/**\n * Provides data to position an inner element of the floating element so that it\n * appears centered to the reference element.\n * @see https://floating-ui.com/docs/arrow\n */\nconst arrow = arrow$1;\n\n/**\n * Provides improved positioning for inline reference elements that can span\n * over multiple lines, such as hyperlinks or range selections.\n * @see https://floating-ui.com/docs/inline\n */\nconst inline = inline$1;\n\n/**\n * Built-in `limiter` that will stop `shift()` at a certain point.\n */\nconst limitShift = limitShift$1;\n\n/**\n * Computes the `x` and `y` coordinates that will place the floating element\n * next to a given reference element.\n */\nconst computePosition = (reference, floating, options) => {\n  // This caches the expensive `getClippingElementAncestors` function so that\n  // multiple lifecycle resets re-use the same result. It only lives for a\n  // single call. If other functions become expensive, we can add them as well.\n  const cache = new Map();\n  const mergedOptions = {\n    platform,\n    ...options\n  };\n  const platformWithCache = {\n    ...mergedOptions.platform,\n    _c: cache\n  };\n  return computePosition$1(reference, floating, {\n    ...mergedOptions,\n    platform: platformWithCache\n  });\n};\n\nexport { arrow, autoPlacement, autoUpdate, computePosition, detectOverflow, flip, hide, inline, limitShift, offset, platform, shift, size };\n","import { arrow as arrow$1, computePosition } from '@floating-ui/dom';\nexport { autoPlacement, autoUpdate, computePosition, detectOverflow, flip, getOverflowAncestors, hide, inline, limitShift, offset, platform, shift, size } from '@floating-ui/dom';\nimport { isNode, getNodeName } from '@floating-ui/utils/dom';\nimport { unref, computed, ref, shallowRef, watch, getCurrentScope, onScopeDispose, shallowReadonly } from 'vue-demi';\n\nfunction isComponentPublicInstance(target) {\n  return target != null && typeof target === 'object' && '$el' in target;\n}\nfunction unwrapElement(target) {\n  if (isComponentPublicInstance(target)) {\n    const element = target.$el;\n    return isNode(element) && getNodeName(element) === '#comment' ? null : element;\n  }\n  return target;\n}\n\nfunction toValue(source) {\n  return typeof source === 'function' ? source() : unref(source);\n}\n\n/**\n * Positions an inner element of the floating element such that it is centered to the reference element.\n * @param options The arrow options.\n * @see https://floating-ui.com/docs/arrow\n */\nfunction arrow(options) {\n  return {\n    name: 'arrow',\n    options,\n    fn(args) {\n      const element = unwrapElement(toValue(options.element));\n      if (element == null) {\n        return {};\n      }\n      return arrow$1({\n        element,\n        padding: options.padding\n      }).fn(args);\n    }\n  };\n}\n\nfunction getDPR(element) {\n  if (typeof window === 'undefined') {\n    return 1;\n  }\n  const win = element.ownerDocument.defaultView || window;\n  return win.devicePixelRatio || 1;\n}\n\nfunction roundByDPR(element, value) {\n  const dpr = getDPR(element);\n  return Math.round(value * dpr) / dpr;\n}\n\n/**\n * Computes the `x` and `y` coordinates that will place the floating element next to a reference element when it is given a certain CSS positioning strategy.\n * @param reference The reference template ref.\n * @param floating The floating template ref.\n * @param options The floating options.\n * @see https://floating-ui.com/docs/vue\n */\nfunction useFloating(reference, floating, options) {\n  if (options === void 0) {\n    options = {};\n  }\n  const whileElementsMountedOption = options.whileElementsMounted;\n  const openOption = computed(() => {\n    var _toValue;\n    return (_toValue = toValue(options.open)) != null ? _toValue : true;\n  });\n  const middlewareOption = computed(() => toValue(options.middleware));\n  const placementOption = computed(() => {\n    var _toValue2;\n    return (_toValue2 = toValue(options.placement)) != null ? _toValue2 : 'bottom';\n  });\n  const strategyOption = computed(() => {\n    var _toValue3;\n    return (_toValue3 = toValue(options.strategy)) != null ? _toValue3 : 'absolute';\n  });\n  const transformOption = computed(() => {\n    var _toValue4;\n    return (_toValue4 = toValue(options.transform)) != null ? _toValue4 : true;\n  });\n  const referenceElement = computed(() => unwrapElement(reference.value));\n  const floatingElement = computed(() => unwrapElement(floating.value));\n  const x = ref(0);\n  const y = ref(0);\n  const strategy = ref(strategyOption.value);\n  const placement = ref(placementOption.value);\n  const middlewareData = shallowRef({});\n  const isPositioned = ref(false);\n  const floatingStyles = computed(() => {\n    const initialStyles = {\n      position: strategy.value,\n      left: '0',\n      top: '0'\n    };\n    if (!floatingElement.value) {\n      return initialStyles;\n    }\n    const xVal = roundByDPR(floatingElement.value, x.value);\n    const yVal = roundByDPR(floatingElement.value, y.value);\n    if (transformOption.value) {\n      return {\n        ...initialStyles,\n        transform: \"translate(\" + xVal + \"px, \" + yVal + \"px)\",\n        ...(getDPR(floatingElement.value) >= 1.5 && {\n          willChange: 'transform'\n        })\n      };\n    }\n    return {\n      position: strategy.value,\n      left: xVal + \"px\",\n      top: yVal + \"px\"\n    };\n  });\n  let whileElementsMountedCleanup;\n  function update() {\n    if (referenceElement.value == null || floatingElement.value == null) {\n      return;\n    }\n    const open = openOption.value;\n    computePosition(referenceElement.value, floatingElement.value, {\n      middleware: middlewareOption.value,\n      placement: placementOption.value,\n      strategy: strategyOption.value\n    }).then(position => {\n      x.value = position.x;\n      y.value = position.y;\n      strategy.value = position.strategy;\n      placement.value = position.placement;\n      middlewareData.value = position.middlewareData;\n      /**\n       * The floating element's position may be recomputed while it's closed\n       * but still mounted (such as when transitioning out). To ensure\n       * `isPositioned` will be `false` initially on the next open, avoid\n       * setting it to `true` when `open === false` (must be specified).\n       */\n      isPositioned.value = open !== false;\n    });\n  }\n  function cleanup() {\n    if (typeof whileElementsMountedCleanup === 'function') {\n      whileElementsMountedCleanup();\n      whileElementsMountedCleanup = undefined;\n    }\n  }\n  function attach() {\n    cleanup();\n    if (whileElementsMountedOption === undefined) {\n      update();\n      return;\n    }\n    if (referenceElement.value != null && floatingElement.value != null) {\n      whileElementsMountedCleanup = whileElementsMountedOption(referenceElement.value, floatingElement.value, update);\n      return;\n    }\n  }\n  function reset() {\n    if (!openOption.value) {\n      isPositioned.value = false;\n    }\n  }\n  watch([middlewareOption, placementOption, strategyOption, openOption], update, {\n    flush: 'sync'\n  });\n  watch([referenceElement, floatingElement], attach, {\n    flush: 'sync'\n  });\n  watch(openOption, reset, {\n    flush: 'sync'\n  });\n  if (getCurrentScope()) {\n    onScopeDispose(cleanup);\n  }\n  return {\n    x: shallowReadonly(x),\n    y: shallowReadonly(y),\n    strategy: shallowReadonly(strategy),\n    placement: shallowReadonly(placement),\n    middlewareData: shallowReadonly(middlewareData),\n    isPositioned: shallowReadonly(isPositioned),\n    floatingStyles,\n    update\n  };\n}\n\nexport { arrow, useFloating };\n","export const isClickOutside = (event: MouseEvent, elements: HTMLElement | HTMLElement[]): boolean => {\n  const targets = Array.isArray(elements) ? elements : [elements];\n  return !targets.some((el) => el.contains(event.target as Node));\n};\n","<script lang=\"ts\" setup>\n  import { autoPlacement, autoUpdate, offset as offsetMiddleware, shift, useFloating } from '@floating-ui/vue';\n  import { computed, onBeforeMount, onMounted, onUnmounted, ref, watch, watchEffect } from 'vue';\n\n  import { CSS } from '@/types/Styles';\n  import { isClickOutside } from '@/utilities/event';\n  import { TOP_LAYER_ID, initFauxTopLayer } from '@/utilities/viewport';\n\n  import type { Ref } from 'vue';\n\n  type Props = {\n    anchorId: string;\n    offset?: number;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    offset: 16,\n  });\n\n  const anchor: Ref<HTMLElement | null> = ref(null);\n  const floating: Ref<HTMLElement | null> = ref(null);\n  const root: Ref<HTMLElement | null> = ref(null);\n  const isHovered = ref(false);\n  const isToggledOpen = ref(false);\n  const middleware = ref([autoPlacement(), offsetMiddleware({ mainAxis: props.offset }), shift({ padding: 16 })]);\n\n  const isShowPopover = computed(() => isHovered.value || isToggledOpen.value);\n\n  const { floatingStyles } = useFloating(anchor, floating, {\n    middleware,\n    strategy: 'fixed',\n    whileElementsMounted: autoUpdate,\n  });\n\n  const handlePermanentOpenBodyClick = (e: MouseEvent) => {\n    if (!anchor.value || !floating.value) return;\n    if (isClickOutside(e, [anchor.value, floating.value])) {\n      isToggledOpen.value = false;\n      e.preventDefault();\n      e.stopImmediatePropagation();\n    }\n  };\n\n  const handleAnchorElementMouseOver = () => {\n    isHovered.value = true;\n  };\n\n  const handleAnchorElementMouseLeave = () => {\n    isHovered.value = false;\n  };\n\n  const handleAnchorElementClick = (e: MouseEvent) => {\n    e.preventDefault();\n    if (isToggledOpen.value) {\n      isToggledOpen.value = false;\n      isHovered.value = false;\n    } else {\n      isToggledOpen.value = true;\n    }\n  };\n\n  const addListenersToAnchorElement = () => {\n    if (!anchor.value) return null;\n    anchor.value.addEventListener('mouseover', handleAnchorElementMouseOver);\n    anchor.value.addEventListener('mouseleave', handleAnchorElementMouseLeave);\n    anchor.value.addEventListener('click', handleAnchorElementClick);\n  };\n\n  const removeListenersFromAnchorElement = () => {\n    if (!anchor.value) return null;\n    anchor.value.removeEventListener('mouseover', handleAnchorElementMouseOver);\n    anchor.value.removeEventListener('mouseleave', handleAnchorElementMouseLeave);\n    anchor.value.removeEventListener('click', handleAnchorElementClick);\n  };\n\n  const handlePermanentOpenBodyKeydown = (e: KeyboardEvent) => {\n    if (e.key === 'Escape') {\n      isToggledOpen.value = false;\n    }\n  };\n\n  const addOpenListenersToRoot = () => {\n    if (!root.value) return;\n    root.value.addEventListener('click', handlePermanentOpenBodyClick, true);\n    root.value.addEventListener('keydown', handlePermanentOpenBodyKeydown);\n  };\n\n  const removeOpenListenersFromRoot = () => {\n    if (!root.value) return;\n    root.value.removeEventListener('click', handlePermanentOpenBodyClick, true);\n    root.value.removeEventListener('keydown', handlePermanentOpenBodyKeydown);\n  };\n\n  const updateAnchorElement = () => {\n    anchor.value = document.getElementById(props.anchorId);\n  };\n\n  watch(\n    () => isToggledOpen.value,\n    (newValue) => {\n      if (newValue) {\n        addOpenListenersToRoot();\n      } else {\n        removeOpenListenersFromRoot();\n      }\n    }\n  );\n\n  watch(\n    () => props.anchorId,\n    () => {\n      removeListenersFromAnchorElement();\n      updateAnchorElement();\n      addListenersToAnchorElement();\n    }\n  );\n\n  watchEffect(() => {\n    middleware.value = [autoPlacement(), offsetMiddleware({ mainAxis: props.offset }), shift({ padding: 16 })];\n  });\n\n  onBeforeMount(() => {\n    initFauxTopLayer();\n  });\n\n  onMounted(() => {\n    updateAnchorElement();\n    root.value = document.documentElement;\n    addListenersToAnchorElement();\n  });\n\n  onUnmounted(() => {\n    removeListenersFromAnchorElement();\n  });\n</script>\n\n<template>\n  <Teleport :to=\"`#${TOP_LAYER_ID}`\">\n    <Transition>\n      <div\n        :class=\"[\n          'tide-popover',\n          CSS.BG.SURFACE.DEFAULT,\n          CSS.BORDER.COLOR.LOW,\n          CSS.BORDER.FULL.ONE,\n          CSS.BORDER.RADIUS.HALF,\n          CSS.FONT.ROLE.BODY_2,\n          CSS.PADDING.FULL.ONE,\n          CSS.SHADOW.BOTTOM,\n        ]\"\n        ref=\"floating\"\n        :style=\"{ ...floatingStyles }\"\n        v-show=\"isShowPopover\"\n      >\n        <slot />\n      </div>\n    </Transition>\n  </Teleport>\n</template>\n\n<style scoped>\n  .tide-popover {\n    max-width: 256px;\n  }\n  .v-enter-from,\n  .v-leave-to {\n    opacity: 0;\n  }\n  .v-enter-active,\n  .v-leave-active {\n    transition: opacity var(--tide-animate);\n  }\n  .v-enter-to,\n  .v-leave-from {\n    opacity: 1;\n  }\n</style>\n","<script lang=\"ts\" setup>\n  import { CSS } from '@/types/Styles';\n  import { TARGET } from '@/types/Target';\n\n  import type { Link } from '@/types/Link';\n\n  type Props = {\n    heading?: string;\n    links: Link[];\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    heading: '',\n  });\n</script>\n\n<template>\n  <section class=\"tide-seo-links\">\n    <h2 :class=\"[CSS.MARGIN.BOTTOM.HALF]\">\n      {{ props.heading }}\n    </h2>\n\n    <ul :class=\"[CSS.DISPLAY.FLEX, CSS.FLEX.WRAP, CSS.GAP.TWO, CSS.LIST_BULLETS.OFF]\">\n      <li\n        :class=\"['tide-seo-link', CSS.DISPLAY.FLEX, CSS.FLEX.DIRECTION.COLUMN, CSS.GAP.QUARTER, CSS.FONT.ROLE.BODY_2]\"\n        :key=\"link.label\"\n        v-for=\"link in props.links\"\n      >\n        <a\n          :class=\"[CSS.UNDERLINE.REST.OFF]\"\n          :href=\"link.url\"\n          :target=\"link.isNewTab ? TARGET.BLANK : TARGET.SELF\"\n        >\n          {{ link.label }}\n        </a>\n      </li>\n    </ul>\n  </section>\n</template>\n\n<style scoped>\n  /* TODO: Refactor to accept breakpoint prop in order to accomplish this with neither custom breakpoints nor dependency on ViewportStore. */\n  .tide-seo-link {\n    width: 100%;\n  }\n\n  @media (min-width: 992px) {\n    .tide-seo-link {\n      width: calc((100% - 2rem) / 2);\n    }\n  }\n\n  @media (min-width: 1232px) {\n    .tide-seo-link {\n      width: calc((100% - 6rem) / 4);\n    }\n  }\n</style>\n","<script lang=\"ts\" setup>\n  import { onBeforeMount, onMounted, ref, watch } from 'vue';\n\n  import TideButtonIcon from '@/components/TideButtonIcon.vue';\n  import { ICON } from '@/types/Icon';\n  import { PRIORITY } from '@/types/Priority';\n  import { CSS } from '@/types/Styles';\n  import { TOP_LAYER_ID, initFauxTopLayer, setScrollLock } from '@/utilities/viewport';\n\n  import TideDivider from './TideDivider.vue';\n\n  import type { Ref } from 'vue';\n\n  type Props = {\n    isOpen: boolean;\n    isBackButton?: boolean;\n  };\n  const props = defineProps<Props>();\n\n  type Emits = {\n    (e: 'back'): void;\n    (e: 'close'): void;\n  };\n\n  const emit = defineEmits<Emits>();\n\n  const dialogElement: Ref<HTMLDialogElement | null> = ref(null);\n\n  const triggerNativeDialogOpen = () => {\n    dialogElement.value?.showModal();\n  };\n\n  const triggerNativeDialogClose = () => {\n    dialogElement.value?.close();\n  };\n\n  const handleBackdropClick = () => {\n    emit('close');\n  };\n\n  const handleEscapeKeydown = (e: Event) => {\n    e.preventDefault();\n    emit('close');\n  };\n\n  watch(\n    () => props.isOpen,\n    (newValue) => {\n      if (!dialogElement.value) return;\n      if (newValue) {\n        triggerNativeDialogOpen();\n      } else {\n        triggerNativeDialogClose();\n      }\n      setScrollLock(newValue);\n    }\n  );\n\n  onBeforeMount(() => {\n    initFauxTopLayer();\n  });\n\n  onMounted(() => {\n    if (props.isOpen) {\n      triggerNativeDialogOpen();\n    }\n  });\n</script>\n\n<template>\n  <Teleport :to=\"`#${TOP_LAYER_ID}`\">\n    <dialog\n      :class=\"['tide-sheet', CSS.BG.INITIAL, CSS.HEIGHT.FULL, CSS.WIDTH.FULL, CSS.OVERFLOW.XY.HIDDEN]\"\n      ref=\"dialogElement\"\n      @click.self=\"handleBackdropClick\"\n      @close.prevent\n      @keydown.escape=\"handleEscapeKeydown\"\n    >\n      <div\n        :class=\"[\n          'tide-sheet-body',\n          CSS.BG.SURFACE.DEFAULT,\n          CSS.DISPLAY.FLEX,\n          CSS.FLEX.DIRECTION.COLUMN,\n          CSS.HEIGHT.FULL,\n          CSS.OVERFLOW.XY.HIDDEN,\n          CSS.WIDTH.FULL,\n        ]\"\n      >\n        <header\n          :class=\"[\n            CSS.DISPLAY.FLEX,\n            CSS.ISOLATION.ISOLATE,\n            CSS.PADDING.TOP.ONE,\n            CSS.PADDING.X.ONE,\n            CSS.POSITION.RELATIVE,\n            CSS.Z_INDEX.ONE,\n          ]\"\n        >\n          <TideButtonIcon\n            :class=\"[CSS.FLEX.GROW.OFF, CSS.FLEX.SHRINK.OFF]\"\n            :icon=\"ICON.CHEVRON_LEFT\"\n            :priority=\"PRIORITY.QUATERNARY\"\n            @click=\"emit('back')\"\n            v-if=\"isBackButton\"\n          />\n\n          <TideButtonIcon\n            :class=\"[CSS.FLEX.GROW.OFF, CSS.FLEX.SHRINK.OFF, CSS.MARGIN.LEFT.AUTO]\"\n            :icon=\"ICON.CLOSE\"\n            :priority=\"PRIORITY.QUATERNARY\"\n            @click=\"emit('close')\"\n          />\n        </header>\n\n        <TideDivider />\n\n        <div\n          :class=\"[\n            'tide-sheet-content',\n            CSS.DISPLAY.GRID,\n            CSS.OVERFLOW.Y.AUTO,\n            CSS.OVERFLOW.X.HIDDEN,\n            CSS.WIDTH.FULL,\n            CSS.PADDING.BOTTOM.ONE,\n            CSS.ISOLATION.ISOLATE,\n          ]\"\n        >\n          <slot />\n        </div>\n      </div>\n    </dialog>\n  </Teleport>\n</template>\n\n<style scoped>\n  .tide-sheet {\n    --sheet-padding-x: var(--tide-spacing-1);\n    max-width: unset;\n    max-height: unset;\n    justify-items: right;\n    display: none;\n    transition: all var(--tide-animate) allow-discrete;\n    transform: translateX(100%);\n  }\n\n  .tide-sheet[open] {\n    display: grid;\n    transform: translateX(0%);\n  }\n\n  .tide-sheet::backdrop {\n    background-color: transparent;\n    transition: all var(--tide-animate) allow-discrete;\n    backdrop-filter: blur(0px);\n  }\n\n  .tide-sheet[open]::backdrop {\n    background-color: var(--tide-transparent-400);\n    backdrop-filter: var(--tide-bg-blur);\n  }\n\n  .tide-sheet-body {\n    max-width: min(calc(100vw - var(--tide-spacing-2)), 311px);\n  }\n\n  .tide-sheet-content {\n    grid-template-columns: var(--sheet-padding-x) 1fr var(--sheet-padding-x);\n  }\n\n  :where(.tide-sheet-content):deep(> :where(*)) {\n    grid-column: 2;\n  }\n\n  @starting-style {\n    .tide-sheet[open] {\n      display: grid;\n      transform: translateX(100%);\n    }\n\n    .tide-sheet[open]::backdrop {\n      background-color: transparent;\n      backdrop-filter: var(--tide-bg-blur);\n    }\n  }\n</style>\n","<script lang=\"ts\" setup>\n  import TideIcon from '@/components/TideIcon.vue';\n  import { ICON } from '@/types/Icon';\n  import { SIZE } from '@/types/Size';\n  import { CSS } from '@/types/Styles';\n\n  type Props = {\n    disabled?: boolean;\n    isActive?: boolean;\n  };\n\n  const props = withDefaults(defineProps<Props>(), {\n    disabled: false,\n    isActive: false,\n  });\n\n  const emit = defineEmits(['change']);\n\n  const handleClick = () => {\n    if (!props.disabled) {\n      emit('change');\n    }\n  };\n</script>\n\n<template>\n  <button\n    :class=\"[\n      'tide-switch',\n      props.isActive ? 'active' : '',\n      CSS.DISPLAY.FLEX,\n      CSS.AXIS2.CENTER,\n      CSS.BORDER.FULL.ONE,\n      CSS.BORDER.RADIUS.FULL,\n      props.isActive ? '' : CSS.BORDER.COLOR.DEFAULT,\n      CSS.OVERFLOW.XY.HIDDEN,\n      props.isActive ? CSS.BG.SECONDARY : CSS.BG.SURFACE.DEFAULT,\n    ]\"\n    :disabled=\"props.disabled\"\n    @click=\"handleClick\"\n    aria-label=\"Switch\"\n  >\n    <div\n      :class=\"[\n        'tide-switch-indicator',\n        CSS.POSITION.RELATIVE,\n        CSS.DISPLAY.FLEX,\n        CSS.AXIS1.CENTER,\n        CSS.AXIS2.CENTER,\n        CSS.BORDER.RADIUS.FULL,\n        props.isActive ? CSS.BG.SURFACE.DEFAULT : CSS.BG.SECONDARY,\n      ]\"\n    >\n      <TideIcon\n        :icon=\"ICON.CHECK\"\n        :size=\"SIZE.LARGE\"\n      />\n    </div>\n  </button>\n</template>\n\n<style scoped>\n  .tide-switch {\n    width: 64px;\n    height: 32px;\n    transition: var(--tide-animate);\n    transition-property: background-color;\n  }\n\n  .tide-switch:disabled {\n    opacity: var(--tide-opacity);\n  }\n\n  .tide-switch.active {\n    border-color: var(--tide-secondary);\n  }\n\n  .tide-switch.active .tide-switch-indicator {\n    left: 36px;\n  }\n\n  .tide-switch-indicator {\n    left: 4px;\n    transition: var(--tide-animate);\n    transition-property: left, border-color, background-color;\n  }\n</style>\n"],"names":["ORIENTATION","CSS","utilities","breakpoint","utility","props","__props","_openBlock","_createElementBlock","_hoisted_1","_createElementVNode","_normalizeClass","_unref","REALM","SIZE","SIZE_BUTTON","formatNumber","input","output","digits","formatPascalCase","word","formatPhone","formatPrice","innerSVG","ref","watch","id","name","prefix","realmFolder","component","defineAsyncComponent","__variableDynamicImportRuntimeHelper","markRaw","_createBlock","_resolveDynamicComponent","ICON","ICON_REALM","emit","__emit","handleToggleClick","TideDivider","_toDisplayString","_createVNode","TideIcon","_renderSlot","_ctx","ELEMENT","ELEMENT_TEXT_AS_ICON","PRIORITY","TARGET","ALERT","iconType","computed","TideButtonIcon","BADGE_COLOR","BADGE_COLOR_DETAILS","BADGE_TRUSTED","_Fragment","crumb","index","_hoisted_2","_hoisted_3","_createTextVNode","handleClick","tab","$event","TYPE_CARD","containerRef","isFirstSlide","isLastSlide","showButtons","slideObserver","slidesInView","slotObserver","slides","handleScroll","updateContainerBleed","observeSlides","options","entries","slidesAddedToView","entry","slideIndex","slide","a","b","child","observeSlot","observerCallback","scrollToOffset","target","showNextPage","nextSlide","showPreviousPage","previousSlide","_a","showNextSlide","showPreviousSlide","onMounted","onUnmounted","_b","_cache","_hoisted_4","_hoisted_5","OBJECT_FIT","imageDefault","picture","img","objectFitClassName","setImageFromDefault","currentSrc","pictureSource","_normalizeStyle","_renderList","source","TideImage","FORM_KEY","useTideForm","forceShowErrors","provide","useFormContext","inject","errorMessageDefault","VALIDATION_RESULT","checkFormat","format","message","value","result","getFieldLengthIsValid","maxlength","minlength","required","isEmptyAndUnrequired","isTooLong","getFieldValidationResult","errorFromProps","validators","validation","validateProperty","lengthValidation","validateLength","response","validator","modelValue","_useModel","formContext","isValidating","errorRef","formattedLabel","isChecked","showError","hasErrorFromProp","supportingTextMessage","getCheckboxValidationResult","watchEffect","newValue","TideInputSupportingText","__default__","checked","oldValue","FORMAT","FORMAT_REGEX","VALIDATOR","ERROR_DISPLAY","hasFocus","inputId","useId","selectElement","hasMinilabel","isEmpty","expandOptions","event","handleFocus","handleFocusOut","optgroup","option","_hoisted_6","getErrorMessage","errorFromRef","getFieldHasError","handleFieldValidation","error","errorMessage","hasError","__expose","TEXT_INPUT_TYPE","INPUT_MODE","getTextInputMode","type","inputmode","inputElement","showPassword","inputModeAttribute","inputType","shouldShowClearButton","shouldShowPasswordButton","handleClear","handleFieldClick","preventInputFocusLossOnMousedown","e","hasClear","handleValidation","handleInput","updateValue","textareaElement","preventTextareaFocusLossOnMousedown","BREAKPOINT","MEDIA","setScrollLock","isLocked","body","scrollY","nextTick","savedScrollY","TOP_LAYER_ID","initFauxTopLayer","topLayer","modalContent","modalDialog","triggerNativeDialogOpen","triggerNativeDialogClose","scrollContentToTop","handleBackdropClick","handleEscapeKeydown","$slots","pageCurrent","paginationButtons","empty","paginationButton","TideButtonPagination","sides","alignments","placements","acc","side","min","max","round","floor","createCoords","v","oppositeSideMap","oppositeAlignmentMap","clamp","start","end","evaluate","param","getSide","placement","getAlignment","getOppositeAxis","axis","getAxisLength","getSideAxis","getAlignmentAxis","getAlignmentSides","rects","rtl","alignment","alignmentAxis","length","mainAlignmentSide","getOppositePlacement","getOppositeAlignmentPlacement","expandPaddingObject","padding","getPaddingObject","rectToClientRect","rect","x","y","width","height","computeCoordsFromPlacement","_ref","reference","floating","sideAxis","alignLength","isVertical","commonX","commonY","commonAlign","coords","computePosition","config","strategy","middleware","platform","validMiddleware","statefulPlacement","middlewareData","resetCount","i","fn","nextX","nextY","data","reset","detectOverflow","state","_await$platform$isEle","elements","boundary","rootBoundary","elementContext","altBoundary","paddingObject","element","clippingClientRect","offsetParent","offsetScale","elementClientRect","getPlacementList","autoAlignment","allowedPlacements","autoPlacement","_middlewareData$autoP","_middlewareData$autoP2","_placementsThatFitOnE","crossAxis","detectOverflowOptions","placements$1","overflow","currentIndex","currentPlacement","alignmentSides","currentOverflows","allOverflows","nextPlacement","placementsSortedByMostSpace","d","resetPlacement","convertValueToCoords","mainAxisMulti","crossAxisMulti","rawValue","mainAxis","offset","_middlewareData$offse","_middlewareData$arrow","diffCoords","shift","checkMainAxis","checkCrossAxis","limiter","mainAxisCoord","crossAxisCoord","minSide","maxSide","limitedCoords","hasWindow","getNodeName","node","isNode","getWindow","_node$ownerDocument","getDocumentElement","isElement","isHTMLElement","isShadowRoot","isOverflowElement","overflowX","overflowY","display","getComputedStyle","isTableElement","isTopLayer","selector","isContainingBlock","elementOrCss","webkit","isWebKit","css","getContainingBlock","currentNode","getParentNode","isLastTraversableNode","getNodeScroll","getNearestOverflowAncestor","parentNode","getOverflowAncestors","list","traverseIframes","_node$ownerDocument2","scrollableAncestor","isBody","win","frameElement","getFrameElement","getCssDimensions","hasOffset","offsetWidth","offsetHeight","shouldFallback","unwrapElement","getScale","domElement","$","noOffsets","getVisualOffsets","shouldAddVisualOffsets","isFixed","floatingOffsetParent","getBoundingClientRect","includeScale","isFixedStrategy","clientRect","scale","visualOffsets","offsetWin","currentWin","currentIFrame","iframeScale","iframeRect","left","top","getWindowScrollBarX","leftScroll","getHTMLOffset","documentElement","scroll","ignoreScrollbarX","htmlRect","convertOffsetParentRelativeRectToViewportRelativeRect","offsets","isOffsetParentAnElement","offsetRect","htmlOffset","getClientRects","getDocumentRect","html","getViewportRect","visualViewport","visualViewportBased","getInnerBoundingClientRect","getClientRectFromClippingAncestor","clippingAncestor","hasFixedPositionAncestor","stopNode","getClippingElementAncestors","cache","cachedResult","el","currentContainingBlockComputedStyle","elementIsFixed","computedStyle","currentNodeIsContaining","ancestor","getClippingRect","clippingAncestors","firstClippingAncestor","clippingRect","accRect","getDimensions","getRectRelativeToOffsetParent","isStaticPositioned","getTrueOffsetParent","polyfill","rawOffsetParent","getOffsetParent","svgOffsetParent","getElementRects","getOffsetParentFn","getDimensionsFn","floatingDimensions","isRTL","rectsAreEqual","observeMove","onMove","io","timeoutId","root","cleanup","_io","refresh","skip","threshold","elementRectForRootMargin","insetTop","insetRight","insetBottom","insetLeft","isFirstUpdate","handleObserve","ratio","autoUpdate","update","ancestorScroll","ancestorResize","elementResize","layoutShift","animationFrame","referenceEl","ancestors","cleanupIo","reobserveFrame","resizeObserver","firstEntry","_resizeObserver","frameId","prevRefRect","frameLoop","nextRefRect","_resizeObserver2","offset$1","autoPlacement$1","shift$1","mergedOptions","platformWithCache","computePosition$1","isComponentPublicInstance","toValue","unref","getDPR","roundByDPR","dpr","useFloating","whileElementsMountedOption","openOption","_toValue","middlewareOption","placementOption","_toValue2","strategyOption","_toValue3","transformOption","_toValue4","referenceElement","floatingElement","shallowRef","isPositioned","floatingStyles","initialStyles","xVal","yVal","whileElementsMountedCleanup","open","position","attach","getCurrentScope","onScopeDispose","shallowReadonly","isClickOutside","anchor","isHovered","isToggledOpen","offsetMiddleware","isShowPopover","handlePermanentOpenBodyClick","handleAnchorElementMouseOver","handleAnchorElementMouseLeave","handleAnchorElementClick","addListenersToAnchorElement","removeListenersFromAnchorElement","handlePermanentOpenBodyKeydown","addOpenListenersToRoot","removeOpenListenersFromRoot","updateAnchorElement","onBeforeMount","_Teleport","_Transition","link","dialogElement"],"mappings":"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","x_google_ignoreList":[57,58,59,60,61]}