@leaflink/stash 42.5.0 → 42.5.1

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 (223) hide show
  1. package/README.md +24 -3
  2. package/dist/ActionsDropdown.js +15 -20
  3. package/dist/ActionsDropdown.js.map +1 -1
  4. package/dist/AddressSelect.js +34 -45
  5. package/dist/AddressSelect.js.map +1 -1
  6. package/dist/Alert.js +11 -13
  7. package/dist/Alert.js.map +1 -1
  8. package/dist/AppNavigationItem.js +4 -6
  9. package/dist/AppNavigationItem.js.map +1 -1
  10. package/dist/AppTopbar.js +13 -15
  11. package/dist/AppTopbar.js.map +1 -1
  12. package/dist/ButtonGroup.js +12 -14
  13. package/dist/ButtonGroup.js.map +1 -1
  14. package/dist/CardMedia.js +9 -11
  15. package/dist/CardMedia.js.map +1 -1
  16. package/dist/Carousel.js +41 -44
  17. package/dist/Carousel.js.map +1 -1
  18. package/dist/Checkbox.js +9 -11
  19. package/dist/Checkbox.js.map +1 -1
  20. package/dist/ChevronToggle.js +2 -4
  21. package/dist/ChevronToggle.js.map +1 -1
  22. package/dist/Chip.js +4 -6
  23. package/dist/Chip.js.map +1 -1
  24. package/dist/ContextSwitcher.js +12 -17
  25. package/dist/ContextSwitcher.js.map +1 -1
  26. package/dist/Copy.js +19 -24
  27. package/dist/Copy.js.map +1 -1
  28. package/dist/CurrencyInput.js +8 -13
  29. package/dist/CurrencyInput.js.map +1 -1
  30. package/dist/DataView.js +48 -59
  31. package/dist/DataView.js.map +1 -1
  32. package/dist/DataViewFilters.js +87 -97
  33. package/dist/DataViewFilters.js.map +1 -1
  34. package/dist/DataViewSortButton.js +14 -18
  35. package/dist/DataViewSortButton.js.map +1 -1
  36. package/dist/DataViewToolbar.js +12 -14
  37. package/dist/DataViewToolbar.js.map +1 -1
  38. package/dist/DatePicker.js +8 -18
  39. package/dist/DatePicker.js.map +1 -1
  40. package/dist/Dialog.js +6 -9
  41. package/dist/Dialog.js.map +1 -1
  42. package/dist/Dropdown.js +15 -20
  43. package/dist/Dropdown.js.map +1 -1
  44. package/dist/EmptyState.js +10 -13
  45. package/dist/EmptyState.js.map +1 -1
  46. package/dist/Field.js +3 -6
  47. package/dist/Field.js.map +1 -1
  48. package/dist/{Field.vue_vue_type_script_setup_true_lang-c864abd3.js → Field.vue_vue_type_script_setup_true_lang-475832fe.js} +2 -2
  49. package/dist/{Field.vue_vue_type_script_setup_true_lang-c864abd3.js.map → Field.vue_vue_type_script_setup_true_lang-475832fe.js.map} +1 -1
  50. package/dist/FileUpload.js +27 -30
  51. package/dist/FileUpload.js.map +1 -1
  52. package/dist/FilterChip.js +10 -13
  53. package/dist/FilterChip.js.map +1 -1
  54. package/dist/FilterDrawerItem.js +5 -8
  55. package/dist/FilterDrawerItem.js.map +1 -1
  56. package/dist/FilterDropdown.js +73 -88
  57. package/dist/FilterDropdown.js.map +1 -1
  58. package/dist/FilterSelect.js +15 -18
  59. package/dist/FilterSelect.js.map +1 -1
  60. package/dist/Filters.js +67 -78
  61. package/dist/Filters.js.map +1 -1
  62. package/dist/HttpError.js +4 -7
  63. package/dist/HttpError.js.map +1 -1
  64. package/dist/Icon.js +236 -14
  65. package/dist/Icon.js.map +1 -1
  66. package/dist/Icon.vue.d.ts +2 -2
  67. package/dist/Icon.vue_used_vue_type_style_index_0_lang.module-eb359559.js +11 -0
  68. package/dist/Icon.vue_used_vue_type_style_index_0_lang.module-eb359559.js.map +1 -0
  69. package/dist/IconLabel.js +4 -6
  70. package/dist/IconLabel.js.map +1 -1
  71. package/dist/Illustration.js +6 -8
  72. package/dist/Illustration.js.map +1 -1
  73. package/dist/Image.js +39 -49
  74. package/dist/Image.js.map +1 -1
  75. package/dist/InlineEdit.js +10 -12
  76. package/dist/InlineEdit.js.map +1 -1
  77. package/dist/Input.js +50 -55
  78. package/dist/Input.js.map +1 -1
  79. package/dist/InputOptions.js +20 -29
  80. package/dist/InputOptions.js.map +1 -1
  81. package/dist/Label.js +1 -4
  82. package/dist/Label.js.map +1 -1
  83. package/dist/LicenseChip.js +7 -9
  84. package/dist/LicenseChip.js.map +1 -1
  85. package/dist/ListItem.js +11 -13
  86. package/dist/ListItem.js.map +1 -1
  87. package/dist/ListView.js +47 -58
  88. package/dist/ListView.js.map +1 -1
  89. package/dist/Metric.js +6 -8
  90. package/dist/Metric.js.map +1 -1
  91. package/dist/Modal.js +16 -19
  92. package/dist/Modal.js.map +1 -1
  93. package/dist/Modals.js +16 -26
  94. package/dist/Modals.js.map +1 -1
  95. package/dist/ModalsPlugin.js +12 -22
  96. package/dist/ModalsPlugin.js.map +1 -1
  97. package/dist/ObfuscateText.js +7 -9
  98. package/dist/ObfuscateText.js.map +1 -1
  99. package/dist/PageNavigation.js +25 -29
  100. package/dist/PageNavigation.js.map +1 -1
  101. package/dist/Paginate.js +29 -31
  102. package/dist/Paginate.js.map +1 -1
  103. package/dist/QuickAction.js +13 -15
  104. package/dist/QuickAction.js.map +1 -1
  105. package/dist/RadioGroup.js +86 -89
  106. package/dist/RadioGroup.js.map +1 -1
  107. package/dist/SearchBar.js +18 -20
  108. package/dist/SearchBar.js.map +1 -1
  109. package/dist/Select.js +13 -23
  110. package/dist/Select.js.map +1 -1
  111. package/dist/SelectStatus.js +26 -36
  112. package/dist/SelectStatus.js.map +1 -1
  113. package/dist/Step.js +19 -21
  114. package/dist/Step.js.map +1 -1
  115. package/dist/Switch.js +8 -10
  116. package/dist/Switch.js.map +1 -1
  117. package/dist/Tab.js +25 -30
  118. package/dist/Tab.js.map +1 -1
  119. package/dist/Table.js +19 -21
  120. package/dist/Table.js.map +1 -1
  121. package/dist/TableCell.js +21 -22
  122. package/dist/TableCell.js.map +1 -1
  123. package/dist/TableHeaderCell.js +4 -4
  124. package/dist/TableHeaderRow.js +7 -9
  125. package/dist/TableHeaderRow.js.map +1 -1
  126. package/dist/TableRow.js +22 -24
  127. package/dist/TableRow.js.map +1 -1
  128. package/dist/Tabs.js +11 -16
  129. package/dist/Tabs.js.map +1 -1
  130. package/dist/{Tabs.vue_vue_type_script_setup_true_lang-ba383fda.js → Tabs.vue_vue_type_script_setup_true_lang-aca4f8b8.js} +3 -3
  131. package/dist/{Tabs.vue_vue_type_script_setup_true_lang-ba383fda.js.map → Tabs.vue_vue_type_script_setup_true_lang-aca4f8b8.js.map} +1 -1
  132. package/dist/Textarea.js +10 -13
  133. package/dist/Textarea.js.map +1 -1
  134. package/dist/Toast.js +8 -10
  135. package/dist/Toast.js.map +1 -1
  136. package/dist/Toasts.js +14 -25
  137. package/dist/Toasts.js.map +1 -1
  138. package/dist/ToastsPlugin.js +14 -25
  139. package/dist/ToastsPlugin.js.map +1 -1
  140. package/dist/components.css +1 -1
  141. package/dist/index.js +53 -62
  142. package/dist/index.js.map +1 -1
  143. package/dist/locale.js +12 -15
  144. package/dist/locale.js.map +1 -1
  145. package/dist/{searchFuzzy-13c124f8.js → searchFuzzy-74a7de1c.js} +2 -2
  146. package/dist/{searchFuzzy-13c124f8.js.map → searchFuzzy-74a7de1c.js.map} +1 -1
  147. package/dist/storage.js +6 -11
  148. package/dist/storage.js.map +1 -1
  149. package/dist/tooltip.js +21 -26
  150. package/dist/tooltip.js.map +1 -1
  151. package/dist/useGoogleMaps.js +91 -226
  152. package/dist/useGoogleMaps.js.map +1 -1
  153. package/dist/useModals.js +21 -31
  154. package/dist/useModals.js.map +1 -1
  155. package/dist/useSearch.js +17 -22
  156. package/dist/useSearch.js.map +1 -1
  157. package/dist/useToasts.js +25 -36
  158. package/dist/useToasts.js.map +1 -1
  159. package/dist/useValidation.js +79 -108
  160. package/dist/useValidation.js.map +1 -1
  161. package/dist/utils/calculateElementOverflow.js +9 -14
  162. package/dist/utils/calculateElementOverflow.js.map +1 -1
  163. package/dist/utils/createQueryString.js +9 -15
  164. package/dist/utils/createQueryString.js.map +1 -1
  165. package/dist/utils/helpers.js +46 -59
  166. package/dist/utils/helpers.js.map +1 -1
  167. package/dist/utils/i18n.js +17 -20
  168. package/dist/utils/i18n.js.map +1 -1
  169. package/dist/utils/searchFuzzy.js +7 -12
  170. package/dist/utils/searchFuzzy.js.map +1 -1
  171. package/dist/utils/storage.js +10 -15
  172. package/dist/utils/storage.js.map +1 -1
  173. package/dist/viewable.js +26 -34
  174. package/dist/viewable.js.map +1 -1
  175. package/package.json +2 -4
  176. package/dist/Icon.vue_used_vue_type_style_index_0_lang.module-d2507af3.js +0 -243
  177. package/dist/Icon.vue_used_vue_type_style_index_0_lang.module-d2507af3.js.map +0 -1
  178. package/dist/_MapCache-65811284.js +0 -188
  179. package/dist/_MapCache-65811284.js.map +0 -1
  180. package/dist/_Uint8Array-06e4d083.js +0 -66
  181. package/dist/_Uint8Array-06e4d083.js.map +0 -1
  182. package/dist/_baseAssignValue-dd1499b4.js +0 -22
  183. package/dist/_baseAssignValue-dd1499b4.js.map +0 -1
  184. package/dist/_baseIsEqual-d594c87f.js +0 -171
  185. package/dist/_baseIsEqual-d594c87f.js.map +0 -1
  186. package/dist/_createCompounder-ae01a723.js +0 -245
  187. package/dist/_createCompounder-ae01a723.js.map +0 -1
  188. package/dist/_getAllKeys-5e735d41.js +0 -44
  189. package/dist/_getAllKeys-5e735d41.js.map +0 -1
  190. package/dist/_getPrototype-3e6fccd6.js +0 -7
  191. package/dist/_getPrototype-3e6fccd6.js.map +0 -1
  192. package/dist/_getTag-4db47fa6.js +0 -47
  193. package/dist/_getTag-4db47fa6.js.map +0 -1
  194. package/dist/_initCloneObject-161353b9.js +0 -88
  195. package/dist/_initCloneObject-161353b9.js.map +0 -1
  196. package/dist/_overArg-6d920d99.js +0 -9
  197. package/dist/_overArg-6d920d99.js.map +0 -1
  198. package/dist/capitalize-667d9f60.js +0 -42
  199. package/dist/capitalize-667d9f60.js.map +0 -1
  200. package/dist/cloneDeep-5bc375b0.js +0 -146
  201. package/dist/cloneDeep-5bc375b0.js.map +0 -1
  202. package/dist/debounce-6aca1ca9.js +0 -86
  203. package/dist/debounce-6aca1ca9.js.map +0 -1
  204. package/dist/get-27d90892.js +0 -66
  205. package/dist/get-27d90892.js.map +0 -1
  206. package/dist/identity-452d03fd.js +0 -20
  207. package/dist/identity-452d03fd.js.map +0 -1
  208. package/dist/isArrayLike-09233e52.js +0 -61
  209. package/dist/isArrayLike-09233e52.js.map +0 -1
  210. package/dist/isEmpty-2fbad344.js +0 -23
  211. package/dist/isEmpty-2fbad344.js.map +0 -1
  212. package/dist/isEqual-fca467fb.js +0 -8
  213. package/dist/isEqual-fca467fb.js.map +0 -1
  214. package/dist/isObjectLike-54341556.js +0 -39
  215. package/dist/isObjectLike-54341556.js.map +0 -1
  216. package/dist/isPlainObject-55c7f916.js +0 -16
  217. package/dist/isPlainObject-55c7f916.js.map +0 -1
  218. package/dist/merge-b14fad9d.js +0 -124
  219. package/dist/merge-b14fad9d.js.map +0 -1
  220. package/dist/toString-7d5bf363.js +0 -29
  221. package/dist/toString-7d5bf363.js.map +0 -1
  222. package/dist/uniqueId-847efe53.js +0 -10
  223. package/dist/uniqueId-847efe53.js.map +0 -1
package/dist/Image.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"Image.js","sources":["../src/components/Image/providers/utils.ts","../src/components/Image/providers/cloudinary.ts","../src/components/Image/providers/static.ts","../src/components/Image/providers/index.ts","../src/components/Image/Image.vue"],"sourcesContent":["export interface ImageModifiers {\n format?: string;\n height?: number;\n width?: number;\n [key: string]: any /* eslint-disable-line @typescript-eslint/no-explicit-any */;\n}\n\nexport type ParamFormatter = (key: string, value: string) => string;\n\nexport type ParamMapper = { [key: string]: string } | ((key: string) => string);\n\nexport interface ProviderUrlBuilder {\n keyMap?: ParamMapper;\n formatter?: ParamFormatter;\n joinWith?: string;\n valueMap?: {\n [key: string]: ParamMapper;\n };\n}\n\nfunction createMapper(map: any) {\n /* eslint-disable-line @typescript-eslint/no-explicit-any */\n return (key: string) => {\n return map[key] || key;\n };\n}\n\n/**\n * Builds the parameterized Cloudinary url\n */\nexport function buildProviderUrl({\n formatter = (key, value) => `${key}=${value}`,\n keyMap,\n joinWith = '/',\n valueMap = {},\n}: ProviderUrlBuilder = {}) {\n const keyMapper = typeof keyMap === 'function' ? keyMap : createMapper(keyMap);\n\n Object.keys(valueMap).forEach((valueKey) => {\n if (typeof valueMap[valueKey] !== 'function') {\n valueMap[valueKey] = createMapper(valueMap[valueKey]);\n }\n });\n\n return (modifiers: { [key: string]: string } = {}) => {\n const operations = Object.entries(modifiers).map(([key, value]) => {\n const mapper = valueMap[key];\n const newKey = keyMapper(key);\n let newVal = value;\n\n if (typeof mapper === 'function') {\n newVal = mapper(modifiers[key]);\n }\n\n return formatter(newKey, newVal);\n });\n\n return operations.join(joinWith);\n };\n}\n\n/**\n * Checks if a (sub)domain is included in a list of acceptable domains\n * @param str the (sub)domain to check\n * @param domains an array of valid domains\n */\nexport function isDomainValid(str = '', domains: string[] = []): boolean {\n const url = new URL(str);\n const host = url.host;\n\n return domains.some((domain) => {\n if (domain === host) {\n return true;\n }\n\n return domain.endsWith(`.${host}`);\n });\n}\n","import merge from 'lodash-es/merge';\n\nimport { IMAGE_PROVIDER_URLS } from '../../../constants';\nimport { buildProviderUrl, ImageModifiers } from './utils';\n\nconst BASE_URL = IMAGE_PROVIDER_URLS.CLOUDINARY;\n\nconst convertHextoRGBFormat = (value: string) => (value.startsWith('#') ? value.replace('#', 'rgb_') : value);\n\n/**\n * Parameters (option and value pairs) that can be used in the <transformations> segment of the Cloudinary transformation URL.\n * Options and their respective values are connected by an underscore (eg `w_250` for width of 250px.).\n * Multiple parameters are comma separated (eg. `w_250,h_250`).\n *\n * `keyMap` maps the option to its option prefix.\n * `valueMap` is used for grouping options using the same `keyMap` value under a 'category', allowing for easier usage and custom labelling in the component context.\n *\n * Transformation URL structure:\n * https://cloudinary.com/documentation/transformation_reference\n *\n * Transformation URL parameters (options and values):\n * https://cloudinary.com/documentation/image_transformations#transformation_url_syntax\n *\n */\nexport const operationsGenerator = buildProviderUrl({\n keyMap: {\n fit: 'c',\n width: 'w',\n height: 'h',\n format: 'f',\n quality: 'q',\n background: 'b',\n dpr: 'dpr',\n },\n valueMap: {\n fit: {\n fill: 'fill',\n inside: 'pad',\n outside: 'lpad',\n cover: 'fit',\n contain: 'scale',\n },\n format: {\n jpeg: 'jpg',\n },\n background(value: string) {\n return convertHextoRGBFormat(value);\n },\n },\n joinWith: ',',\n formatter: (key, value) => `${key}_${value}`,\n});\n\n// Note: Not configurable via Image props (for now).\nconst defaultModifiers = {\n // defaulting to maintain original image format to reduce transformations\n // format: 'auto',\n quality: 'auto',\n};\n\nexport function getImageUrl(src: string, modifiers: Partial<ImageModifiers> = {}): string {\n const mergeModifiers = merge(defaultModifiers, modifiers);\n const operations = operationsGenerator(mergeModifiers);\n\n return `${BASE_URL}/${operations}/${src}`;\n}\n","export function getImageUrl(src = ''): string {\n return src;\n}\n","import * as cloudinary from './cloudinary';\nimport * as staticProvider from './static';\n\nexport default {\n cloudinary,\n static: staticProvider,\n};\n","<script lang=\"ts\">\n export const PRESET_SIZES = {\n xsmall: {\n alwaysIncluded: false,\n width: 160,\n },\n small: {\n alwaysIncluded: true,\n width: 338,\n },\n medium: {\n alwaysIncluded: true,\n width: 676,\n },\n large: {\n alwaysIncluded: true,\n width: 1352,\n },\n xlarge: {\n alwaysIncluded: false,\n width: 2704,\n },\n } as const;\n\n export enum ImageRadiuses {\n None = 'none',\n Rounded = 'rounded',\n }\n</script>\n\n<script setup lang=\"ts\">\n import { computed, inject, useAttrs } from 'vue';\n\n import { StashImageProviders, StashProvideState } from '../../../types/misc';\n import { CSS_VARS } from '../../constants';\n import { getCssVar } from '../../utils/helpers';\n import providers from './providers';\n import { ImageModifiers, isDomainValid } from './providers/utils';\n\n // interface ImagePresetSizes {\n // [size: string]: {\n // alwaysIncluded: boolean;\n // width: number;\n // }\n // }\n\n export interface ImageSizeVariant {\n media: string;\n preset?: keyof typeof PRESET_SIZES;\n screenMinWidth: number;\n size: string;\n }\n\n export type ImageRadius = `${ImageRadiuses}`;\n\n export interface ImageProps {\n /**\n * The path to the image you want to embed.\n */\n src: string;\n\n /**\n * Native srcset attribute.\n * One or more strings separated by commas, indicating possible image sources\n * Can only be used with provider=static, otherwise it's ignored and auto-generated with `sizes` usage\n */\n srcset?: string;\n\n /**\n * For specifying responsive sizes\n */\n sizes?: string;\n\n /**\n * Where the image is served from.\n * Optional, and when provided it forces the provider used.\n *\n * The provider is otherwise inherited from the Stash config `stashOptions.images.provider`, which defaults to `cloudinary`.\n *\n * When not provided, the provider is also inferred by `isStatic`:\n * - `static` for relative/absolute paths (`img/foo.jpg` or `/static/img/bar.jpg`), or when whitelisted absolute URLs are used (included in `staticOptions.images.staticDomains`).\n */\n provider?: StashImageProviders | null;\n\n /**\n * For applying border radius\n */\n radius?: ImageRadius;\n\n /**\n * TODO - https://leaflink.atlassian.net/browse/GRO-204\n * A custom function used to resolve a URL string for the image\n */\n // loader?: () => string;\n }\n\n const PROVIDERS = {\n CLOUDINARY: 'cloudinary',\n STATIC: 'static',\n };\n const BREAKPOINTS = {\n md: getCssVar(CSS_VARS.SCREEN_MD),\n lg: getCssVar(CSS_VARS.SCREEN_LG),\n };\n const stashOptions = inject<StashProvideState>('stashOptions');\n const props = withDefaults(defineProps<ImageProps>(), {\n src: '',\n srcset: '',\n sizes: '',\n provider: null,\n radius: 'none',\n // loader: undefined, // TODO - https://leaflink.atlassian.net/browse/GRO-204\n });\n\n const attrs = computed(() => {\n const { src, ...attrs } = useAttrs();\n\n attrs.sizes = imgSizes.value;\n attrs.srcset = imgSrcset.value;\n\n return attrs;\n });\n\n const staticDomains = computed(() => stashOptions?.images?.staticDomains || []);\n\n const isStaticUrl = computed(() => {\n // return true if not an absolute url\n try {\n new URL(props.src);\n } catch (e) {\n return true;\n }\n\n // true if domain is whitelisted for static usage\n return isDomainValid(props.src, staticDomains.value);\n });\n\n const computedProvider = computed(() => {\n if (props.provider) {\n return props.provider;\n }\n\n if (stashOptions?.images?.provider && stashOptions.images.provider !== PROVIDERS.STATIC && !isStaticUrl.value) {\n return stashOptions.images.provider;\n }\n\n return PROVIDERS.STATIC;\n });\n\n const isStatic = computed(() => computedProvider.value === PROVIDERS.STATIC);\n\n const imgProvider = computed(() => providers[computedProvider.value]);\n\n const imgSrc = computed(() =>\n isStatic.value ? getProviderImage() : getProviderImage({ width: PRESET_SIZES.medium.width }),\n );\n\n const imgSizes = computed(() => (props.sizes || !isStatic.value ? getSizes() : undefined));\n\n const imgSrcset = computed(() => (props.sizes && !props.srcset && !isStatic.value ? getSources() : props.srcset));\n\n const parsedSizes = computed(() => {\n if (props.sizes) {\n return parseSizes(props.sizes);\n }\n\n if (!isStatic.value) {\n return parseSizes('lg:large');\n }\n\n return [];\n });\n\n function getProviderImage(modifiers: ImageModifiers = {}) {\n return imgProvider.value.getImageUrl(props.src, modifiers);\n }\n\n function getSources() {\n const appliedPresets = Object.entries(PRESET_SIZES).reduce((obj, [key, entry]) => {\n const isPreset = !!parsedSizes.value.find((size) => size.preset === key);\n\n if (isPreset || entry.alwaysIncluded) {\n obj[key] = entry;\n }\n\n return obj;\n }, {} as typeof PRESET_SIZES);\n\n return Object.values(appliedPresets)\n .map((size) => {\n const width = size.width;\n const src = getProviderImage({ width });\n\n return `${src} ${size.width}w`;\n })\n .join(', ');\n }\n\n function getSizes() {\n return parsedSizes.value.map((v) => `${v.media ? v.media + ' ' : ''}${v.size}`).join(', ');\n }\n\n function parseSizes(providedSizes: string) {\n const variants: ImageSizeVariant[] = [];\n const sizes = {\n default: '100vw',\n };\n\n // parse sizes and convert to object\n if (typeof providedSizes === 'string') {\n const definitions = providedSizes.split(/[\\s]+/).filter((size) => size);\n\n for (const entry of definitions) {\n const size = entry.split(':');\n\n if (size.length !== 2) {\n sizes['default'] = size[0].trim();\n continue;\n }\n\n sizes[size[0].trim()] = size[1].trim();\n }\n } else {\n throw new Error('`sizes` needs to be a string');\n }\n\n for (const key in sizes) {\n const screenMinWidth = parseInt(BREAKPOINTS[key] || 0);\n const sizeValue = sizes[key];\n const presetKey = PRESET_SIZES[sizeValue] ? sizeValue : undefined;\n let size = String(presetKey ? PRESET_SIZES[sizeValue].width : sizeValue);\n const isFluid = size.endsWith('vw');\n\n // default integers to pixels\n if (!isFluid && /^\\d+$/.test(size)) {\n size = `${size}px`;\n }\n\n // ignore invalid size\n if (!isFluid && !size.endsWith('px')) {\n continue;\n }\n\n const variant = {\n media: screenMinWidth ? `(min-width: ${screenMinWidth}px)` : '',\n preset: presetKey,\n screenMinWidth,\n size,\n };\n\n variants.push(variant);\n }\n\n variants.sort((v1, v2) => (v1.screenMinWidth > v2.screenMinWidth ? -1 : 1));\n\n return variants;\n }\n</script>\n\n<template>\n <img\n ref=\"img\"\n :key=\"imgSrc\"\n data-test=\"stash-image\"\n :class=\"{\n rounded: props.radius === ImageRadiuses.Rounded,\n }\"\n :src=\"imgSrc\"\n v-bind=\"attrs\"\n />\n</template>\n"],"names":["createMapper","map","key","buildProviderUrl","formatter","value","keyMap","joinWith","valueMap","keyMapper","valueKey","modifiers","mapper","newKey","newVal","isDomainValid","str","domains","host","domain","BASE_URL","IMAGE_PROVIDER_URLS","convertHextoRGBFormat","operationsGenerator","defaultModifiers","getImageUrl","src","mergeModifiers","merge","operations","providers","cloudinary","staticProvider","PRESET_SIZES","ImageRadiuses","PROVIDERS","BREAKPOINTS","getCssVar","CSS_VARS","stashOptions","inject","attrs","computed","useAttrs","imgSizes","imgSrcset","staticDomains","_a","isStaticUrl","props","computedProvider","isStatic","imgProvider","imgSrc","getProviderImage","getSizes","getSources","parsedSizes","parseSizes","appliedPresets","obj","entry","size","width","v","providedSizes","variants","sizes","definitions","screenMinWidth","sizeValue","presetKey","isFluid","variant","v1","v2"],"mappings":"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"}
1
+ {"version":3,"file":"Image.js","sources":["../src/components/Image/providers/utils.ts","../src/components/Image/providers/cloudinary.ts","../src/components/Image/providers/static.ts","../src/components/Image/providers/index.ts","../src/components/Image/Image.vue"],"sourcesContent":["export interface ImageModifiers {\n format?: string;\n height?: number;\n width?: number;\n [key: string]: any /* eslint-disable-line @typescript-eslint/no-explicit-any */;\n}\n\nexport type ParamFormatter = (key: string, value: string) => string;\n\nexport type ParamMapper = { [key: string]: string } | ((key: string) => string);\n\nexport interface ProviderUrlBuilder {\n keyMap?: ParamMapper;\n formatter?: ParamFormatter;\n joinWith?: string;\n valueMap?: {\n [key: string]: ParamMapper;\n };\n}\n\nfunction createMapper(map: any) {\n /* eslint-disable-line @typescript-eslint/no-explicit-any */\n return (key: string) => {\n return map[key] || key;\n };\n}\n\n/**\n * Builds the parameterized Cloudinary url\n */\nexport function buildProviderUrl({\n formatter = (key, value) => `${key}=${value}`,\n keyMap,\n joinWith = '/',\n valueMap = {},\n}: ProviderUrlBuilder = {}) {\n const keyMapper = typeof keyMap === 'function' ? keyMap : createMapper(keyMap);\n\n Object.keys(valueMap).forEach((valueKey) => {\n if (typeof valueMap[valueKey] !== 'function') {\n valueMap[valueKey] = createMapper(valueMap[valueKey]);\n }\n });\n\n return (modifiers: { [key: string]: string } = {}) => {\n const operations = Object.entries(modifiers).map(([key, value]) => {\n const mapper = valueMap[key];\n const newKey = keyMapper(key);\n let newVal = value;\n\n if (typeof mapper === 'function') {\n newVal = mapper(modifiers[key]);\n }\n\n return formatter(newKey, newVal);\n });\n\n return operations.join(joinWith);\n };\n}\n\n/**\n * Checks if a (sub)domain is included in a list of acceptable domains\n * @param str the (sub)domain to check\n * @param domains an array of valid domains\n */\nexport function isDomainValid(str = '', domains: string[] = []): boolean {\n const url = new URL(str);\n const host = url.host;\n\n return domains.some((domain) => {\n if (domain === host) {\n return true;\n }\n\n return domain.endsWith(`.${host}`);\n });\n}\n","import merge from 'lodash-es/merge';\n\nimport { IMAGE_PROVIDER_URLS } from '../../../constants';\nimport { buildProviderUrl, ImageModifiers } from './utils';\n\nconst BASE_URL = IMAGE_PROVIDER_URLS.CLOUDINARY;\n\nconst convertHextoRGBFormat = (value: string) => (value.startsWith('#') ? value.replace('#', 'rgb_') : value);\n\n/**\n * Parameters (option and value pairs) that can be used in the <transformations> segment of the Cloudinary transformation URL.\n * Options and their respective values are connected by an underscore (eg `w_250` for width of 250px.).\n * Multiple parameters are comma separated (eg. `w_250,h_250`).\n *\n * `keyMap` maps the option to its option prefix.\n * `valueMap` is used for grouping options using the same `keyMap` value under a 'category', allowing for easier usage and custom labelling in the component context.\n *\n * Transformation URL structure:\n * https://cloudinary.com/documentation/transformation_reference\n *\n * Transformation URL parameters (options and values):\n * https://cloudinary.com/documentation/image_transformations#transformation_url_syntax\n *\n */\nexport const operationsGenerator = buildProviderUrl({\n keyMap: {\n fit: 'c',\n width: 'w',\n height: 'h',\n format: 'f',\n quality: 'q',\n background: 'b',\n dpr: 'dpr',\n },\n valueMap: {\n fit: {\n fill: 'fill',\n inside: 'pad',\n outside: 'lpad',\n cover: 'fit',\n contain: 'scale',\n },\n format: {\n jpeg: 'jpg',\n },\n background(value: string) {\n return convertHextoRGBFormat(value);\n },\n },\n joinWith: ',',\n formatter: (key, value) => `${key}_${value}`,\n});\n\n// Note: Not configurable via Image props (for now).\nconst defaultModifiers = {\n // defaulting to maintain original image format to reduce transformations\n // format: 'auto',\n quality: 'auto',\n};\n\nexport function getImageUrl(src: string, modifiers: Partial<ImageModifiers> = {}): string {\n const mergeModifiers = merge(defaultModifiers, modifiers);\n const operations = operationsGenerator(mergeModifiers);\n\n return `${BASE_URL}/${operations}/${src}`;\n}\n","export function getImageUrl(src = ''): string {\n return src;\n}\n","import * as cloudinary from './cloudinary';\nimport * as staticProvider from './static';\n\nexport default {\n cloudinary,\n static: staticProvider,\n};\n","<script lang=\"ts\">\n export const PRESET_SIZES = {\n xsmall: {\n alwaysIncluded: false,\n width: 160,\n },\n small: {\n alwaysIncluded: true,\n width: 338,\n },\n medium: {\n alwaysIncluded: true,\n width: 676,\n },\n large: {\n alwaysIncluded: true,\n width: 1352,\n },\n xlarge: {\n alwaysIncluded: false,\n width: 2704,\n },\n } as const;\n\n export enum ImageRadiuses {\n None = 'none',\n Rounded = 'rounded',\n }\n</script>\n\n<script setup lang=\"ts\">\n import { computed, inject, useAttrs } from 'vue';\n\n import { StashImageProviders, StashProvideState } from '../../../types/misc';\n import { CSS_VARS } from '../../constants';\n import { getCssVar } from '../../utils/helpers';\n import providers from './providers';\n import { ImageModifiers, isDomainValid } from './providers/utils';\n\n // interface ImagePresetSizes {\n // [size: string]: {\n // alwaysIncluded: boolean;\n // width: number;\n // }\n // }\n\n export interface ImageSizeVariant {\n media: string;\n preset?: keyof typeof PRESET_SIZES;\n screenMinWidth: number;\n size: string;\n }\n\n export type ImageRadius = `${ImageRadiuses}`;\n\n export interface ImageProps {\n /**\n * The path to the image you want to embed.\n */\n src: string;\n\n /**\n * Native srcset attribute.\n * One or more strings separated by commas, indicating possible image sources\n * Can only be used with provider=static, otherwise it's ignored and auto-generated with `sizes` usage\n */\n srcset?: string;\n\n /**\n * For specifying responsive sizes\n */\n sizes?: string;\n\n /**\n * Where the image is served from.\n * Optional, and when provided it forces the provider used.\n *\n * The provider is otherwise inherited from the Stash config `stashOptions.images.provider`, which defaults to `cloudinary`.\n *\n * When not provided, the provider is also inferred by `isStatic`:\n * - `static` for relative/absolute paths (`img/foo.jpg` or `/static/img/bar.jpg`), or when whitelisted absolute URLs are used (included in `staticOptions.images.staticDomains`).\n */\n provider?: StashImageProviders | null;\n\n /**\n * For applying border radius\n */\n radius?: ImageRadius;\n\n /**\n * TODO - https://leaflink.atlassian.net/browse/GRO-204\n * A custom function used to resolve a URL string for the image\n */\n // loader?: () => string;\n }\n\n const PROVIDERS = {\n CLOUDINARY: 'cloudinary',\n STATIC: 'static',\n };\n const BREAKPOINTS = {\n md: getCssVar(CSS_VARS.SCREEN_MD),\n lg: getCssVar(CSS_VARS.SCREEN_LG),\n };\n const stashOptions = inject<StashProvideState>('stashOptions');\n const props = withDefaults(defineProps<ImageProps>(), {\n src: '',\n srcset: '',\n sizes: '',\n provider: null,\n radius: 'none',\n // loader: undefined, // TODO - https://leaflink.atlassian.net/browse/GRO-204\n });\n\n const attrs = computed(() => {\n const { src, ...attrs } = useAttrs();\n\n attrs.sizes = imgSizes.value;\n attrs.srcset = imgSrcset.value;\n\n return attrs;\n });\n\n const staticDomains = computed(() => stashOptions?.images?.staticDomains || []);\n\n const isStaticUrl = computed(() => {\n // return true if not an absolute url\n try {\n new URL(props.src);\n } catch (e) {\n return true;\n }\n\n // true if domain is whitelisted for static usage\n return isDomainValid(props.src, staticDomains.value);\n });\n\n const computedProvider = computed(() => {\n if (props.provider) {\n return props.provider;\n }\n\n if (stashOptions?.images?.provider && stashOptions.images.provider !== PROVIDERS.STATIC && !isStaticUrl.value) {\n return stashOptions.images.provider;\n }\n\n return PROVIDERS.STATIC;\n });\n\n const isStatic = computed(() => computedProvider.value === PROVIDERS.STATIC);\n\n const imgProvider = computed(() => providers[computedProvider.value]);\n\n const imgSrc = computed(() =>\n isStatic.value ? getProviderImage() : getProviderImage({ width: PRESET_SIZES.medium.width }),\n );\n\n const imgSizes = computed(() => (props.sizes || !isStatic.value ? getSizes() : undefined));\n\n const imgSrcset = computed(() => (props.sizes && !props.srcset && !isStatic.value ? getSources() : props.srcset));\n\n const parsedSizes = computed(() => {\n if (props.sizes) {\n return parseSizes(props.sizes);\n }\n\n if (!isStatic.value) {\n return parseSizes('lg:large');\n }\n\n return [];\n });\n\n function getProviderImage(modifiers: ImageModifiers = {}) {\n return imgProvider.value.getImageUrl(props.src, modifiers);\n }\n\n function getSources() {\n const appliedPresets = Object.entries(PRESET_SIZES).reduce((obj, [key, entry]) => {\n const isPreset = !!parsedSizes.value.find((size) => size.preset === key);\n\n if (isPreset || entry.alwaysIncluded) {\n obj[key] = entry;\n }\n\n return obj;\n }, {} as typeof PRESET_SIZES);\n\n return Object.values(appliedPresets)\n .map((size) => {\n const width = size.width;\n const src = getProviderImage({ width });\n\n return `${src} ${size.width}w`;\n })\n .join(', ');\n }\n\n function getSizes() {\n return parsedSizes.value.map((v) => `${v.media ? v.media + ' ' : ''}${v.size}`).join(', ');\n }\n\n function parseSizes(providedSizes: string) {\n const variants: ImageSizeVariant[] = [];\n const sizes = {\n default: '100vw',\n };\n\n // parse sizes and convert to object\n if (typeof providedSizes === 'string') {\n const definitions = providedSizes.split(/[\\s]+/).filter((size) => size);\n\n for (const entry of definitions) {\n const size = entry.split(':');\n\n if (size.length !== 2) {\n sizes['default'] = size[0].trim();\n continue;\n }\n\n sizes[size[0].trim()] = size[1].trim();\n }\n } else {\n throw new Error('`sizes` needs to be a string');\n }\n\n for (const key in sizes) {\n const screenMinWidth = parseInt(BREAKPOINTS[key] || 0);\n const sizeValue = sizes[key];\n const presetKey = PRESET_SIZES[sizeValue] ? sizeValue : undefined;\n let size = String(presetKey ? PRESET_SIZES[sizeValue].width : sizeValue);\n const isFluid = size.endsWith('vw');\n\n // default integers to pixels\n if (!isFluid && /^\\d+$/.test(size)) {\n size = `${size}px`;\n }\n\n // ignore invalid size\n if (!isFluid && !size.endsWith('px')) {\n continue;\n }\n\n const variant = {\n media: screenMinWidth ? `(min-width: ${screenMinWidth}px)` : '',\n preset: presetKey,\n screenMinWidth,\n size,\n };\n\n variants.push(variant);\n }\n\n variants.sort((v1, v2) => (v1.screenMinWidth > v2.screenMinWidth ? -1 : 1));\n\n return variants;\n }\n</script>\n\n<template>\n <img\n ref=\"img\"\n :key=\"imgSrc\"\n data-test=\"stash-image\"\n :class=\"{\n rounded: props.radius === ImageRadiuses.Rounded,\n }\"\n :src=\"imgSrc\"\n v-bind=\"attrs\"\n />\n</template>\n"],"names":["createMapper","map","key","buildProviderUrl","formatter","value","keyMap","joinWith","valueMap","keyMapper","valueKey","modifiers","mapper","newKey","newVal","isDomainValid","str","domains","host","domain","BASE_URL","IMAGE_PROVIDER_URLS","convertHextoRGBFormat","operationsGenerator","defaultModifiers","getImageUrl","src","mergeModifiers","merge","operations","providers","cloudinary","staticProvider","PRESET_SIZES","ImageRadiuses","PROVIDERS","BREAKPOINTS","getCssVar","CSS_VARS","stashOptions","inject","attrs","computed","useAttrs","imgSizes","imgSrcset","staticDomains","_a","isStaticUrl","props","computedProvider","isStatic","imgProvider","imgSrc","getProviderImage","getSizes","getSources","parsedSizes","parseSizes","appliedPresets","obj","entry","size","width","v","providedSizes","variants","sizes","definitions","screenMinWidth","sizeValue","presetKey","isFluid","variant","v1","v2"],"mappings":"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"}
@@ -1,23 +1,21 @@
1
- import { defineComponent as S, useSlots as T, useAttrs as B, ref as r, computed as n, watch as N, openBlock as m, createElementBlock as c, normalizeClass as $, unref as O, createElementVNode as P, createVNode as z, mergeProps as D, withKeys as f, createSlots as F, withCtx as v, renderSlot as V, toDisplayString as U, createCommentVNode as j } from "vue";
1
+ import { defineComponent as S, useSlots as T, useAttrs as B, ref as r, computed as n, watch as N, openBlock as c, createElementBlock as m, normalizeClass as $, unref as O, createElementVNode as P, createVNode as z, mergeProps as D, withKeys as f, createSlots as F, withCtx as v, renderSlot as V, toDisplayString as U, createCommentVNode as j } from "vue";
2
2
  import { percent as q, money as G } from "./utils/i18n.js";
3
3
  import H from "./Input.js";
4
4
  import "./constants.js";
5
5
  import "./locale.js";
6
- import "./get-27d90892.js";
7
- import "./isObjectLike-54341556.js";
8
- import "./toString-7d5bf363.js";
9
- import "./_MapCache-65811284.js";
10
- import "./Field.vue_vue_type_script_setup_true_lang-c864abd3.js";
11
- import "./uniqueId-847efe53.js";
6
+ import "lodash-es/get";
7
+ import "lodash-es/isNil";
8
+ import "./Field.vue_vue_type_script_setup_true_lang-475832fe.js";
9
+ import "lodash-es/uniqueId";
12
10
  import "./Label.vue_vue_type_script_setup_true_lang-1d29d98a.js";
13
11
  import "./Icon.js";
14
- import "./Icon.vue_used_vue_type_style_index_0_lang.module-d2507af3.js";
15
12
  import "./index-79ce320f.js";
13
+ import "./Icon.vue_used_vue_type_style_index_0_lang.module-eb359559.js";
16
14
  import "./_plugin-vue_export-helper-dad06003.js";
17
15
  const J = { class: "stash-inline-edit__input-wrapper" }, L = {
18
16
  key: 0,
19
17
  class: "tw-pl-3 tw-mt-1 tw-text-ice-700 tw-inline-block tw-line-through"
20
- }, se = /* @__PURE__ */ S({
18
+ }, ue = /* @__PURE__ */ S({
21
19
  name: "ll-inline-edit",
22
20
  inheritAttrs: !1,
23
21
  __name: "InlineEdit",
@@ -71,7 +69,7 @@ const J = { class: "stash-inline-edit__input-wrapper" }, L = {
71
69
  function s() {
72
70
  o.value && o.value.inputEl.blur();
73
71
  }
74
- return (t, a) => (m(), c("div", {
72
+ return (t, a) => (c(), m("div", {
75
73
  class: $(["stash-inline-edit", O(p).class]),
76
74
  "data-test": "stash-inline-edit"
77
75
  }, [
@@ -108,11 +106,11 @@ const J = { class: "stash-inline-edit__input-wrapper" }, L = {
108
106
  } : void 0
109
107
  ]), 1040, ["modelValue", "error-text", "hint-text", "label", "placeholder", "type", "onKeydown", "onKeyup"])
110
108
  ]),
111
- _.value ? (m(), c("span", L, U(x.value), 1)) : j("", !0)
109
+ _.value ? (c(), m("span", L, U(x.value), 1)) : j("", !0)
112
110
  ], 2));
113
111
  }
114
112
  });
115
113
  export {
116
- se as default
114
+ ue as default
117
115
  };
118
116
  //# sourceMappingURL=InlineEdit.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"InlineEdit.js","sources":["../src/components/InlineEdit/InlineEdit.vue"],"sourcesContent":["<script setup lang=\"ts\">\n import { computed, ref, useAttrs, useSlots, watch } from 'vue';\n\n import { money, percent } from '../../utils/i18n';\n import Input from '../Input/Input.vue';\n\n defineOptions({\n name: 'll-inline-edit',\n inheritAttrs: false,\n });\n\n export interface InlineEditProps {\n /**\n * Formats the value displayed.\n * Options: currency, percent\n */\n format?: 'currency' | 'percent' | '';\n\n /**\n * DOM `type` property to be passed to `ll-input`.\n * Use type=\"number\" for localized numbers\n */\n type?: string;\n\n /**\n * The current value for the component.\n */\n modelValue?: string | number;\n\n /**\n * Used to display a crossed out value below the component\n * if the current `modelValue` does not match `oldValue`.\n */\n oldValue?: string | number;\n\n /**\n * Label to render for the input\n */\n label?: string;\n\n /**\n * Placeholder for the input\n */\n placeholder?: string;\n\n /**\n * Error text to display. Replaces `hintText` (if provided) & adds error styling.\n */\n errorText?: string;\n\n /**\n * Hint text to display below the input\n */\n hintText?: string;\n }\n\n const slots = useSlots();\n const attrs = useAttrs();\n\n const props = withDefaults(defineProps<InlineEditProps>(), {\n format: '',\n type: 'text',\n modelValue: undefined,\n oldValue: undefined,\n label: ' ',\n placeholder: '',\n errorText: '',\n hintText: '',\n });\n\n const emit =\n defineEmits<{\n /**\n * Emitted when the value is updated\n */\n (e: 'update:model-value', value: string | number | undefined): void;\n }>();\n\n const editing = ref(false);\n\n // this value gets set once and never changes\n const originalValue = ref<InlineEditProps['oldValue']>(props.oldValue || props.modelValue);\n\n // the _current_ value. This is a temporary value, used while editing\n const internalValue = ref<InlineEditProps['modelValue']>(props.modelValue);\n\n const inputAttrs = computed(() => {\n const tempAttrs = { ...attrs };\n\n delete tempAttrs.class;\n return tempAttrs;\n });\n\n const formattedOriginalValue = computed(() => formatValue(originalValue.value || ''));\n\n const showOldValue = computed(() => {\n return 1 && (props.oldValue || props.oldValue === 0) && props.oldValue !== internalValue.value;\n });\n\n const isAppended = computed(() => {\n return !!slots.append;\n });\n\n const isPrepended = computed(() => {\n return !!slots.prepend;\n });\n\n watch(\n () => props.modelValue,\n (newVal?: string | number, oldVal?: string | number) => {\n if (newVal !== oldVal) {\n internalValue.value = newVal;\n }\n },\n );\n\n function dismiss() {\n internalValue.value = props.modelValue || props.oldValue;\n editing.value = false;\n blurInput();\n }\n\n /**\n * Toggles edit state on\n */\n function edit() {\n editing.value = true;\n focusInput();\n }\n\n /**\n * Formats the value based on `format`\n */\n function formatValue(value: string | number) {\n switch (props.format) {\n case 'currency':\n return money({\n amount: value as number,\n });\n case 'percent':\n return percent((value as number) / 100);\n default:\n return value;\n }\n }\n\n /**\n * This method saves the current value of the input field by `$emit`ing.\n * If the new value is empty, it reverts `internalValue` to the original value.\n */\n function save() {\n internalValue.value = !(internalValue.value === '') ? internalValue.value : originalValue.value;\n\n emit('update:model-value', internalValue.value);\n editing.value = false;\n blurInput();\n }\n\n const llInput = ref();\n\n function focusInput() {\n if (llInput.value) {\n llInput.value.inputEl.focus();\n }\n }\n\n function blurInput() {\n if (llInput.value) {\n llInput.value.inputEl.blur();\n }\n }\n</script>\n\n<template>\n <div class=\"stash-inline-edit\" :class=\"attrs.class\" data-test=\"stash-inline-edit\">\n <div class=\"stash-inline-edit__input-wrapper\">\n <Input\n ref=\"llInput\"\n v-model=\"internalValue\"\n :error-text=\"props.errorText\"\n :hint-text=\"props.hintText\"\n :label=\"props.label\"\n :placeholder=\"`${props.placeholder || originalValue}`\"\n :type=\"props.type\"\n v-bind=\"inputAttrs\"\n @blur=\"save\"\n @focus=\"edit\"\n @keydown.esc=\"dismiss\"\n @keyup.enter=\"blurInput\"\n >\n <template v-if=\"isPrepended\" #prepend>\n <!-- @slot renders content on the left side of the input -->\n <slot name=\"prepend\"> </slot>\n </template>\n\n <template v-if=\"isAppended\" #append>\n <!-- @slot renders content on the right side of the input -->\n <slot name=\"append\"> </slot>\n </template>\n </Input>\n </div>\n\n <span v-if=\"showOldValue\" class=\"tw-pl-3 tw-mt-1 tw-text-ice-700 tw-inline-block tw-line-through\">\n {{ formattedOriginalValue }}\n </span>\n </div>\n</template>\n"],"names":["slots","useSlots","attrs","useAttrs","editing","ref","originalValue","props","internalValue","inputAttrs","computed","tempAttrs","formattedOriginalValue","formatValue","showOldValue","isAppended","isPrepended","watch","newVal","oldVal","dismiss","blurInput","edit","focusInput","value","money","percent","save","emit","llInput"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iBAwDQA,IAAQC,KACRC,IAAQC,KAqBRC,IAAUC,EAAI,EAAK,GAGnBC,IAAgBD,EAAiCE,EAAM,YAAYA,EAAM,UAAU,GAGnFC,IAAgBH,EAAmCE,EAAM,UAAU,GAEnEE,IAAaC,EAAS,MAAM;AAC1B,YAAAC,IAAY,EAAE,GAAGT;AAEvB,oBAAOS,EAAU,OACVA;AAAA,IAAA,CACR,GAEKC,IAAyBF,EAAS,MAAMG,EAAYP,EAAc,SAAS,EAAE,CAAC,GAE9EQ,IAAeJ,EAAS,OACfH,EAAM,YAAYA,EAAM,aAAa,MAAMA,EAAM,aAAaC,EAAc,KAC1F,GAEKO,IAAaL,EAAS,MACnB,CAAC,CAACV,EAAM,MAChB,GAEKgB,IAAcN,EAAS,MACpB,CAAC,CAACV,EAAM,OAChB;AAED,IAAAiB;AAAA,MACE,MAAMV,EAAM;AAAA,MACZ,CAACW,GAA0BC,MAA6B;AACtD,QAAID,MAAWC,MACbX,EAAc,QAAQU;AAAA,MAE1B;AAAA,IAAA;AAGF,aAASE,IAAU;AACH,MAAAZ,EAAA,QAAQD,EAAM,cAAcA,EAAM,UAChDH,EAAQ,QAAQ,IACNiB;IACZ;AAKA,aAASC,IAAO;AACd,MAAAlB,EAAQ,QAAQ,IACLmB;IACb;AAKA,aAASV,EAAYW,GAAwB;AAC3C,cAAQjB,EAAM,QAAQ;AAAA,QACpB,KAAK;AACH,iBAAOkB,EAAM;AAAA,YACX,QAAQD;AAAA,UAAA,CACT;AAAA,QACH,KAAK;AACI,iBAAAE,EAASF,IAAmB,GAAG;AAAA,QACxC;AACS,iBAAAA;AAAA,MACX;AAAA,IACF;AAMA,aAASG,IAAO;AACd,MAAAnB,EAAc,QAAUA,EAAc,UAAU,KAAMA,EAAc,QAAQF,EAAc,OAErFsB,EAAA,sBAAsBpB,EAAc,KAAK,GAC9CJ,EAAQ,QAAQ,IACNiB;IACZ;AAEA,UAAMQ,IAAUxB;AAEhB,aAASkB,IAAa;AACpB,MAAIM,EAAQ,SACFA,EAAA,MAAM,QAAQ;IAE1B;AAEA,aAASR,IAAY;AACnB,MAAIQ,EAAQ,SACFA,EAAA,MAAM,QAAQ;IAE1B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"InlineEdit.js","sources":["../src/components/InlineEdit/InlineEdit.vue"],"sourcesContent":["<script setup lang=\"ts\">\n import { computed, ref, useAttrs, useSlots, watch } from 'vue';\n\n import { money, percent } from '../../utils/i18n';\n import Input from '../Input/Input.vue';\n\n defineOptions({\n name: 'll-inline-edit',\n inheritAttrs: false,\n });\n\n export interface InlineEditProps {\n /**\n * Formats the value displayed.\n * Options: currency, percent\n */\n format?: 'currency' | 'percent' | '';\n\n /**\n * DOM `type` property to be passed to `ll-input`.\n * Use type=\"number\" for localized numbers\n */\n type?: string;\n\n /**\n * The current value for the component.\n */\n modelValue?: string | number;\n\n /**\n * Used to display a crossed out value below the component\n * if the current `modelValue` does not match `oldValue`.\n */\n oldValue?: string | number;\n\n /**\n * Label to render for the input\n */\n label?: string;\n\n /**\n * Placeholder for the input\n */\n placeholder?: string;\n\n /**\n * Error text to display. Replaces `hintText` (if provided) & adds error styling.\n */\n errorText?: string;\n\n /**\n * Hint text to display below the input\n */\n hintText?: string;\n }\n\n const slots = useSlots();\n const attrs = useAttrs();\n\n const props = withDefaults(defineProps<InlineEditProps>(), {\n format: '',\n type: 'text',\n modelValue: undefined,\n oldValue: undefined,\n label: ' ',\n placeholder: '',\n errorText: '',\n hintText: '',\n });\n\n const emit =\n defineEmits<{\n /**\n * Emitted when the value is updated\n */\n (e: 'update:model-value', value: string | number | undefined): void;\n }>();\n\n const editing = ref(false);\n\n // this value gets set once and never changes\n const originalValue = ref<InlineEditProps['oldValue']>(props.oldValue || props.modelValue);\n\n // the _current_ value. This is a temporary value, used while editing\n const internalValue = ref<InlineEditProps['modelValue']>(props.modelValue);\n\n const inputAttrs = computed(() => {\n const tempAttrs = { ...attrs };\n\n delete tempAttrs.class;\n return tempAttrs;\n });\n\n const formattedOriginalValue = computed(() => formatValue(originalValue.value || ''));\n\n const showOldValue = computed(() => {\n return 1 && (props.oldValue || props.oldValue === 0) && props.oldValue !== internalValue.value;\n });\n\n const isAppended = computed(() => {\n return !!slots.append;\n });\n\n const isPrepended = computed(() => {\n return !!slots.prepend;\n });\n\n watch(\n () => props.modelValue,\n (newVal?: string | number, oldVal?: string | number) => {\n if (newVal !== oldVal) {\n internalValue.value = newVal;\n }\n },\n );\n\n function dismiss() {\n internalValue.value = props.modelValue || props.oldValue;\n editing.value = false;\n blurInput();\n }\n\n /**\n * Toggles edit state on\n */\n function edit() {\n editing.value = true;\n focusInput();\n }\n\n /**\n * Formats the value based on `format`\n */\n function formatValue(value: string | number) {\n switch (props.format) {\n case 'currency':\n return money({\n amount: value as number,\n });\n case 'percent':\n return percent((value as number) / 100);\n default:\n return value;\n }\n }\n\n /**\n * This method saves the current value of the input field by `$emit`ing.\n * If the new value is empty, it reverts `internalValue` to the original value.\n */\n function save() {\n internalValue.value = !(internalValue.value === '') ? internalValue.value : originalValue.value;\n\n emit('update:model-value', internalValue.value);\n editing.value = false;\n blurInput();\n }\n\n const llInput = ref();\n\n function focusInput() {\n if (llInput.value) {\n llInput.value.inputEl.focus();\n }\n }\n\n function blurInput() {\n if (llInput.value) {\n llInput.value.inputEl.blur();\n }\n }\n</script>\n\n<template>\n <div class=\"stash-inline-edit\" :class=\"attrs.class\" data-test=\"stash-inline-edit\">\n <div class=\"stash-inline-edit__input-wrapper\">\n <Input\n ref=\"llInput\"\n v-model=\"internalValue\"\n :error-text=\"props.errorText\"\n :hint-text=\"props.hintText\"\n :label=\"props.label\"\n :placeholder=\"`${props.placeholder || originalValue}`\"\n :type=\"props.type\"\n v-bind=\"inputAttrs\"\n @blur=\"save\"\n @focus=\"edit\"\n @keydown.esc=\"dismiss\"\n @keyup.enter=\"blurInput\"\n >\n <template v-if=\"isPrepended\" #prepend>\n <!-- @slot renders content on the left side of the input -->\n <slot name=\"prepend\"> </slot>\n </template>\n\n <template v-if=\"isAppended\" #append>\n <!-- @slot renders content on the right side of the input -->\n <slot name=\"append\"> </slot>\n </template>\n </Input>\n </div>\n\n <span v-if=\"showOldValue\" class=\"tw-pl-3 tw-mt-1 tw-text-ice-700 tw-inline-block tw-line-through\">\n {{ formattedOriginalValue }}\n </span>\n </div>\n</template>\n"],"names":["slots","useSlots","attrs","useAttrs","editing","ref","originalValue","props","internalValue","inputAttrs","computed","tempAttrs","formattedOriginalValue","formatValue","showOldValue","isAppended","isPrepended","watch","newVal","oldVal","dismiss","blurInput","edit","focusInput","value","money","percent","save","emit","llInput"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iBAwDQA,IAAQC,KACRC,IAAQC,KAqBRC,IAAUC,EAAI,EAAK,GAGnBC,IAAgBD,EAAiCE,EAAM,YAAYA,EAAM,UAAU,GAGnFC,IAAgBH,EAAmCE,EAAM,UAAU,GAEnEE,IAAaC,EAAS,MAAM;AAC1B,YAAAC,IAAY,EAAE,GAAGT;AAEvB,oBAAOS,EAAU,OACVA;AAAA,IAAA,CACR,GAEKC,IAAyBF,EAAS,MAAMG,EAAYP,EAAc,SAAS,EAAE,CAAC,GAE9EQ,IAAeJ,EAAS,OACfH,EAAM,YAAYA,EAAM,aAAa,MAAMA,EAAM,aAAaC,EAAc,KAC1F,GAEKO,IAAaL,EAAS,MACnB,CAAC,CAACV,EAAM,MAChB,GAEKgB,IAAcN,EAAS,MACpB,CAAC,CAACV,EAAM,OAChB;AAED,IAAAiB;AAAA,MACE,MAAMV,EAAM;AAAA,MACZ,CAACW,GAA0BC,MAA6B;AACtD,QAAID,MAAWC,MACbX,EAAc,QAAQU;AAAA,MAE1B;AAAA,IAAA;AAGF,aAASE,IAAU;AACH,MAAAZ,EAAA,QAAQD,EAAM,cAAcA,EAAM,UAChDH,EAAQ,QAAQ,IACNiB;IACZ;AAKA,aAASC,IAAO;AACd,MAAAlB,EAAQ,QAAQ,IACLmB;IACb;AAKA,aAASV,EAAYW,GAAwB;AAC3C,cAAQjB,EAAM,QAAQ;AAAA,QACpB,KAAK;AACH,iBAAOkB,EAAM;AAAA,YACX,QAAQD;AAAA,UAAA,CACT;AAAA,QACH,KAAK;AACI,iBAAAE,EAASF,IAAmB,GAAG;AAAA,QACxC;AACS,iBAAAA;AAAA,MACX;AAAA,IACF;AAMA,aAASG,IAAO;AACd,MAAAnB,EAAc,QAAUA,EAAc,UAAU,KAAMA,EAAc,QAAQF,EAAc,OAErFsB,EAAA,sBAAsBpB,EAAc,KAAK,GAC9CJ,EAAQ,QAAQ,IACNiB;IACZ;AAEA,UAAMQ,IAAUxB;AAEhB,aAASkB,IAAa;AACpB,MAAIM,EAAQ,SACFA,EAAA,MAAM,QAAQ;IAE1B;AAEA,aAASR,IAAY;AACnB,MAAIQ,EAAQ,SACFA,EAAA,MAAM,QAAQ;IAE1B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
package/dist/Input.js CHANGED
@@ -1,21 +1,16 @@
1
- import { defineComponent as P, useSlots as U, useCssModule as G, useAttrs as L, ref as v, computed as y, watchEffect as O, onMounted as W, openBlock as m, createBlock as V, mergeProps as k, unref as o, createSlots as j, withCtx as N, createElementVNode as x, withDirectives as q, vModelDynamic as H, createElementBlock as C, normalizeClass as I, renderSlot as b, createCommentVNode as $ } from "vue";
2
- import { convertDecimal as B, sanitizeDecimal as J, decimalSeparator as _ } from "./utils/i18n.js";
3
- import { _ as K } from "./Field.vue_vue_type_script_setup_true_lang-c864abd3.js";
1
+ import { defineComponent as P, useSlots as U, useCssModule as G, useAttrs as L, ref as f, computed as v, watchEffect as O, onMounted as W, openBlock as m, createBlock as g, mergeProps as V, unref as o, createSlots as j, withCtx as k, createElementVNode as N, withDirectives as q, vModelDynamic as H, createElementBlock as x, normalizeClass as C, renderSlot as y, createCommentVNode as I } from "vue";
2
+ import $ from "lodash-es/isNil";
3
+ import { convertDecimal as B, sanitizeDecimal as J, decimalSeparator as b } from "./utils/i18n.js";
4
+ import { _ as K } from "./Field.vue_vue_type_script_setup_true_lang-475832fe.js";
4
5
  import Q from "./Icon.js";
5
6
  import { _ as R } from "./_plugin-vue_export-helper-dad06003.js";
6
7
  import "./constants.js";
7
8
  import "./locale.js";
8
- import "./get-27d90892.js";
9
- import "./isObjectLike-54341556.js";
10
- import "./toString-7d5bf363.js";
11
- import "./_MapCache-65811284.js";
12
- import "./uniqueId-847efe53.js";
9
+ import "lodash-es/get";
10
+ import "lodash-es/uniqueId";
13
11
  import "./Label.vue_vue_type_script_setup_true_lang-1d29d98a.js";
14
- import "./Icon.vue_used_vue_type_style_index_0_lang.module-d2507af3.js";
15
12
  import "./index-79ce320f.js";
16
- function E(c) {
17
- return c == null;
18
- }
13
+ import "./Icon.vue_used_vue_type_style_index_0_lang.module-eb359559.js";
19
14
  const X = { class: "relative" }, Y = ["id", "aria-errormessage", "aria-invalid", "autocomplete", "type"], Z = /* @__PURE__ */ P({
20
15
  name: "ll-input",
21
16
  inheritAttrs: !1,
@@ -33,27 +28,27 @@ const X = { class: "relative" }, Y = ["id", "aria-errormessage", "aria-invalid",
33
28
  type: { default: "text" }
34
29
  },
35
30
  emits: ["update:model-value", "change", "focus", "blur"],
36
- setup(c, { expose: S, emit: d }) {
37
- const n = c, s = U(), l = G(), f = L(), h = v();
38
- S({ inputEl: h });
39
- const r = v(n.modelValue);
40
- n.type === "number" && (n.modelValue || n.modelValue === 0) && (r.value = B(n.modelValue, _));
41
- const p = v(!1), i = y(() => n.type === "number"), D = y(() => {
42
- const t = { ...f };
31
+ setup(E, { expose: S, emit: d }) {
32
+ const n = E, r = U(), s = G(), c = L(), _ = f();
33
+ S({ inputEl: _ });
34
+ const l = f(n.modelValue);
35
+ n.type === "number" && (n.modelValue || n.modelValue === 0) && (l.value = B(n.modelValue, b));
36
+ const p = f(!1), i = v(() => n.type === "number"), D = v(() => {
37
+ const t = { ...c };
43
38
  return delete t.class, t;
44
- }), M = y(() => i.value || n.type === "password" && p.value ? "text" : n.type);
39
+ }), M = v(() => i.value || n.type === "password" && p.value ? "text" : n.type);
45
40
  O(() => {
46
- r.value = g(n.modelValue);
41
+ l.value = w(n.modelValue);
47
42
  });
48
- function w(t = "", a = !1) {
43
+ function h(t = "", a = !1) {
49
44
  if (!i.value)
50
45
  return t;
51
46
  let e = t;
52
- if (E(e) || `${e}`.length === 0)
47
+ if ($(e) || `${e}`.length === 0)
53
48
  return "";
54
- if (_ !== "." && (e = B(e, ".")), a && (e === "." && (e = "0."), e.toString().startsWith("0.")))
49
+ if (b !== "." && (e = B(e, ".")), a && (e === "." && (e = "0."), e.toString().startsWith("0.")))
55
50
  return e;
56
- if (!E(e) && `${e}`.length)
51
+ if (!$(e) && `${e}`.length)
57
52
  e = Intl.NumberFormat("en-US", {
58
53
  style: "decimal",
59
54
  maximumFractionDigits: 7,
@@ -63,42 +58,42 @@ const X = { class: "relative" }, Y = ["id", "aria-errormessage", "aria-invalid",
63
58
  return "";
64
59
  return isNaN(Number(e)) ? "" : parseFloat(e);
65
60
  }
66
- function g(t) {
67
- return i.value ? J(t, _) : t;
61
+ function w(t) {
62
+ return i.value ? J(t, b) : t;
68
63
  }
69
64
  function A() {
70
- const t = i.value ? w(r.value) : r.value;
65
+ const t = i.value ? h(l.value) : l.value;
71
66
  d("change", t);
72
67
  }
73
68
  function F(t) {
74
69
  const a = t.target.value;
75
- r.value = g(a);
76
- const e = i.value ? w(r.value, !0) : a;
70
+ l.value = w(a);
71
+ const e = i.value ? h(l.value, !0) : a;
77
72
  d("update:model-value", e);
78
73
  }
79
74
  return W(() => {
80
75
  if (n.value !== null)
81
76
  throw new Error("ll-input: use :model-value or v-model instead of :value.");
82
- if (f.onInput)
77
+ if (c.onInput)
83
78
  throw new Error("ll-input: use the @update:model-value event instead of @input");
84
- }), (t, a) => (m(), V(K, k(n, {
85
- class: ["stash-input", [o(l).root, o(f).class]],
79
+ }), (t, a) => (m(), g(K, V(n, {
80
+ class: ["stash-input", [o(s).root, o(c).class]],
86
81
  "data-test": "ll-input"
87
82
  }), j({
88
- default: N(({ fieldId: e, fieldErrorId: T, hasError: z }) => [
89
- x("div", X, [
90
- q(x("input", k(D.value, {
83
+ default: k(({ fieldId: e, fieldErrorId: T, hasError: z }) => [
84
+ N("div", X, [
85
+ q(N("input", V(D.value, {
91
86
  id: e,
92
87
  ref_key: "inputEl",
93
- ref: h,
94
- "onUpdate:modelValue": a[0] || (a[0] = (u) => r.value = u),
88
+ ref: _,
89
+ "onUpdate:modelValue": a[0] || (a[0] = (u) => l.value = u),
95
90
  "aria-errormessage": T,
96
91
  "aria-invalid": z,
97
92
  autocomplete: t.autocomplete,
98
93
  class: [
99
- { [o(l)["input-prepended"]]: !!o(s).prepend },
100
- { [o(l)["input-appended"]]: !!o(s).append || n.type === "password" },
101
- { [o(l)["has-error"]]: !!n.errorText }
94
+ { [o(s)["input-prepended"]]: !!o(r).prepend },
95
+ { [o(s)["input-appended"]]: !!o(r).append || n.type === "password" },
96
+ { [o(s)["has-error"]]: !!n.errorText }
102
97
  ],
103
98
  type: M.value,
104
99
  onChange: A,
@@ -106,34 +101,34 @@ const X = { class: "relative" }, Y = ["id", "aria-errormessage", "aria-invalid",
106
101
  onBlur: a[1] || (a[1] = (u) => d("blur", u)),
107
102
  onFocus: a[2] || (a[2] = (u) => d("focus", u))
108
103
  }), null, 16, Y), [
109
- [H, r.value]
104
+ [H, l.value]
110
105
  ]),
111
- o(s).prepend ? (m(), C("div", {
106
+ o(r).prepend ? (m(), x("div", {
112
107
  key: 0,
113
- class: I(["stash-input-prepend font-semibold", [o(l).symbol, o(l)["symbol--prepend"]]])
108
+ class: C(["stash-input-prepend font-semibold", [o(s).symbol, o(s)["symbol--prepend"]]])
114
109
  }, [
115
- b(t.$slots, "prepend")
116
- ], 2)) : $("", !0),
117
- o(s).append || n.type === "password" ? (m(), C("div", {
110
+ y(t.$slots, "prepend")
111
+ ], 2)) : I("", !0),
112
+ o(r).append || n.type === "password" ? (m(), x("div", {
118
113
  key: 1,
119
- class: I(["stash-input-append font-semibold", [o(l).symbol, o(l)["symbol--append"]]])
114
+ class: C(["stash-input-append font-semibold", [o(s).symbol, o(s)["symbol--append"]]])
120
115
  }, [
121
- o(s).append ? b(t.$slots, "append", { key: 0 }) : (m(), V(Q, {
116
+ o(r).append ? y(t.$slots, "append", { key: 0 }) : (m(), g(Q, {
122
117
  key: 1,
123
118
  name: p.value ? "hide" : "show",
124
119
  class: "cursor-pointer",
125
120
  "data-test": p.value ? "hide-password-icon" : "show-password-icon",
126
121
  onClick: a[3] || (a[3] = (u) => p.value = !p.value)
127
122
  }, null, 8, ["name", "data-test"]))
128
- ], 2)) : $("", !0)
123
+ ], 2)) : I("", !0)
129
124
  ])
130
125
  ]),
131
126
  _: 2
132
127
  }, [
133
- o(s).hint ? {
128
+ o(r).hint ? {
134
129
  name: "hint",
135
- fn: N(() => [
136
- b(t.$slots, "hint")
130
+ fn: k(() => [
131
+ y(t.$slots, "hint")
137
132
  ]),
138
133
  key: "0"
139
134
  } : void 0
@@ -149,8 +144,8 @@ const X = { class: "relative" }, Y = ["id", "aria-errormessage", "aria-invalid",
149
144
  "symbol--append": "_symbol--append_178b7_83"
150
145
  }, ne = {
151
146
  $style: oe
152
- }, he = /* @__PURE__ */ R(Z, [["__cssModules", ne]]);
147
+ }, be = /* @__PURE__ */ R(Z, [["__cssModules", ne]]);
153
148
  export {
154
- he as default
149
+ be as default
155
150
  };
156
151
  //# sourceMappingURL=Input.js.map
package/dist/Input.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"Input.js","sources":["../node_modules/lodash-es/isNil.js","../src/components/Input/Input.vue"],"sourcesContent":["/**\n * Checks if `value` is `null` or `undefined`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is nullish, else `false`.\n * @example\n *\n * _.isNil(null);\n * // => true\n *\n * _.isNil(void 0);\n * // => true\n *\n * _.isNil(NaN);\n * // => false\n */\nfunction isNil(value) {\n return value == null;\n}\n\nexport default isNil;\n","<script lang=\"ts\" setup>\n import isNil from 'lodash-es/isNil';\n import { computed, onMounted, ref, useAttrs, useCssModule, useSlots, watchEffect } from 'vue';\n\n import { convertDecimal, decimalSeparator, sanitizeDecimal } from '../../utils/i18n';\n import Field from '../Field/Field.vue';\n import Icon from '../Icon/Icon.vue';\n\n export type InputValue = string | number | undefined;\n\n export interface InputProps {\n /**\n * Adds spacing under the field that is consistent whether or not hint/error text is displayed.\n */\n addBottomSpace?: boolean;\n\n /**\n * Error text to display. Replaces `hintText` (if provided) & adds error styling.\n */\n errorText?: string;\n\n /**\n * Displays text below the input; hidden when the isReadOnly prop is truthy.\n */\n hintText?: string;\n\n /**\n * ID for the Label and Input; must be unique\n */\n id?: string;\n\n /**\n * Label to render above the input.\n */\n label?: string;\n\n /**\n * Show \"(optional)\" to the right of the label text\n */\n showOptionalInLabel?: boolean;\n\n /**\n * Autocomplete takes in a string of off or on\n */\n autocomplete?: string;\n\n /**\n * Value for the input element.\n */\n modelValue?: string | number;\n\n /**\n * @deprecated Use :model-value or v-model instead of :value.\n */\n value?: string | number | null;\n\n /**\n * Input type. Excludes certain types that have a dedicated component.\n *\n * Note: For distinguishing between text & number internally, passing `number`\n * will still render an input with a type of `text` (for localization).\n */\n type?: string extends 'button' | 'checkbox' | 'radio' | 'submit' ? never : string;\n }\n\n defineOptions({\n name: 'll-input',\n inheritAttrs: false,\n });\n\n const props = withDefaults(defineProps<InputProps>(), {\n autocomplete: 'off',\n type: 'text',\n modelValue: '',\n value: null,\n errorText: undefined,\n hintText: undefined,\n label: undefined,\n id: undefined,\n });\n\n const emit =\n defineEmits<{\n /**\n * Emitted when the input value changes.\n */\n (e: 'update:model-value', v: string | number): void;\n /**\n * Emitted when the input value changes.\n */\n (e: 'change', v: string | number): void;\n /**\n * Emitted when the input is focused\n */\n (e: 'focus', evt: Event): void;\n /**\n * Emitted when the input is blurred\n */\n (e: 'blur', evt: Event): void;\n }>();\n\n const slots = useSlots();\n const classes = useCssModule();\n const attrs = useAttrs();\n\n // declare a ref to hold the element reference\n // the name must match template ref value\n const inputEl = ref<HTMLInputElement>();\n\n // this exposes the input ref to any parent that renders the `Input` component\n // and gives it a template ref, giving parent components access to the DOM element.\n defineExpose({ inputEl });\n\n const internalValue = ref<string | number>(props.modelValue);\n\n if (props.type === 'number' && (props.modelValue || props.modelValue === 0)) {\n internalValue.value = convertDecimal(props.modelValue, decimalSeparator);\n }\n\n const showPassword = ref(false);\n\n const isNumber = computed(() => props.type === 'number');\n\n const inputAttrs = computed(() => {\n const tempAttrs = { ...attrs };\n\n delete tempAttrs.class;\n\n return tempAttrs;\n });\n\n const inputType = computed(() => {\n // type 'number' is a special use case and requires\n // that the type be 'text' to support internationalization\n if (isNumber.value) {\n return 'text';\n }\n\n if (props.type === 'password' && showPassword.value) {\n return 'text';\n }\n\n return props.type;\n });\n\n watchEffect(() => {\n internalValue.value = format(props.modelValue);\n });\n\n /**\n * Converts the localized number to a valid number (to emit). i.e. 12,50 > 12.50\n *\n * @param {string|number} value - Number you want to parse.\n * @returns {number|string} number or empty string (for empty input)\n */\n function parseNumber(value: string | number = '', isUserTyping = false): string | number {\n // If this isn't a number input, we shouldn't be calling this function\n if (!isNumber.value) {\n return value;\n }\n\n let tempValue = value;\n\n // If blank, just stop\n if (isNil(tempValue) || `${tempValue}`.length === 0) return '';\n\n // clean out different locale decimals\n if (decimalSeparator !== '.') {\n tempValue = convertDecimal(tempValue, '.');\n }\n\n // If the user is in the middle of an input, let them finish the number\n if (isUserTyping) {\n // Prefix values with a 0 if the user starts with a decimal point\n if (tempValue === '.') tempValue = '0.';\n\n // This is to prevent the parsing from correcting 0. to 0 and causing the value to be reset\n if (tempValue.toString().startsWith('0.')) return tempValue;\n }\n\n // Empty or null values convert to 0 with NumberFormat, so return '';\n if (!isNil(tempValue) && `${tempValue}`.length) {\n tempValue = Intl.NumberFormat('en-US', {\n style: 'decimal',\n maximumFractionDigits: 7,\n useGrouping: false,\n }).format(Number(tempValue));\n } else {\n return '';\n }\n\n // Ensure valid number, otherwise clear value\n return isNaN(Number(tempValue)) ? '' : parseFloat(tempValue);\n }\n\n /**\n * Formats the input based on conditions\n *\n * @param {number|string} value - The value to format.\n */\n function format(value: string | number) {\n if (isNumber.value) {\n return sanitizeDecimal(value, decimalSeparator);\n }\n\n return value;\n }\n\n /**\n * Fire after focusing out of input, if value has changed.\n */\n function handleChange() {\n // Parse the final value on blur\n const parsedValue = isNumber.value ? parseNumber(internalValue.value) : internalValue.value;\n emit('change', parsedValue);\n }\n\n /**\n * Fired when typing on input.\n */\n function handleInput(e: Event) {\n const value = (e.target as HTMLInputElement).value;\n\n // Update the internal value with a sanitized version\n internalValue.value = format(value);\n\n const parsedValue = isNumber.value ? parseNumber(internalValue.value, true) : value;\n\n emit('update:model-value', parsedValue);\n }\n\n onMounted(() => {\n if (props.value !== null) {\n throw new Error('ll-input: use :model-value or v-model instead of :value.');\n }\n\n if (attrs.onInput) {\n throw new Error('ll-input: use the @update:model-value event instead of @input');\n }\n });\n</script>\n\n<template>\n <Field v-bind=\"props\" class=\"stash-input\" :class=\"[classes.root, attrs.class]\" data-test=\"ll-input\">\n <template #default=\"{ fieldId, fieldErrorId, hasError }\">\n <div class=\"relative\">\n <input\n v-bind=\"inputAttrs\"\n :id=\"fieldId\"\n ref=\"inputEl\"\n v-model=\"internalValue\"\n :aria-errormessage=\"fieldErrorId\"\n :aria-invalid=\"hasError\"\n :autocomplete=\"autocomplete\"\n :class=\"[\n { [classes['input-prepended']]: !!slots.prepend },\n { [classes['input-appended']]: !!slots.append || props.type === 'password' },\n { [classes['has-error']]: !!props.errorText },\n ]\"\n :type=\"inputType\"\n @change=\"handleChange\"\n @input=\"handleInput\"\n @blur=\"(evt) => emit('blur', evt)\"\n @focus=\"(evt) => emit('focus', evt)\"\n />\n\n <div\n v-if=\"slots.prepend\"\n class=\"stash-input-prepend font-semibold\"\n :class=\"[classes.symbol, classes['symbol--prepend']]\"\n >\n <!-- @slot renders content on the left side of the input -->\n <slot name=\"prepend\"> </slot>\n </div>\n\n <div\n v-if=\"slots.append || props.type === 'password'\"\n class=\"stash-input-append font-semibold\"\n :class=\"[classes.symbol, classes['symbol--append']]\"\n >\n <!-- @slot renders content on the right side of the input -->\n <slot v-if=\"slots.append\" name=\"append\"></slot>\n <Icon\n v-else\n :name=\"showPassword ? 'hide' : 'show'\"\n class=\"cursor-pointer\"\n :data-test=\"showPassword ? 'hide-password-icon' : 'show-password-icon'\"\n @click=\"showPassword = !showPassword\"\n />\n </div>\n </div>\n </template>\n <template v-if=\"slots.hint\" #hint>\n <slot name=\"hint\"></slot>\n </template>\n </Field>\n</template>\n\n<style module>\n .root {\n position: relative;\n }\n\n .root input {\n background: var(--color-white);\n border: 1px solid var(--color-ice);\n border-radius: var(--border-radius);\n color: var(--color-ice-700);\n display: block;\n height: var(--input-height);\n font-size: var(--input-font-size);\n font-weight: var(--font-weight-normal);\n outline: none;\n padding: 0 var(--ll-space-2);\n width: 100%;\n }\n\n .root input:hover {\n border-color: var(--color-ice);\n }\n\n .root input:active,\n .root input:focus {\n border-color: var(--color-blue);\n }\n\n .root input::placeholder {\n color: var(--color-ice);\n opacity: 1;\n }\n\n .root input.has-error:not(:focus) {\n border-color: var(--color-red);\n }\n\n .root input.input-prepended {\n padding-left: 36px;\n }\n\n .root input.input-appended {\n padding-right: 36px;\n }\n\n .root input[disabled],\n .root input[readonly] {\n background-color: var(--color-ice-200) !important;\n border-color: var(--color-ice) !important;\n color: var(--color-ice-700) !important;\n pointer-events: none;\n }\n\n .root input[disabled]:active,\n .root input[readonly]:active,\n .root input[disabled]:focus,\n .root input[readonly]:focus {\n box-shadow: none !important;\n }\n\n .root input[disabled]::placeholder,\n .root input[readonly]::placeholder {\n text-transform: none;\n }\n\n .symbol {\n align-items: center;\n display: flex;\n height: var(--input-height);\n justify-content: center;\n overflow: hidden;\n position: absolute;\n top: 0;\n width: var(--input-height);\n }\n\n .symbol--prepend {\n border-bottom-left-radius: var(--border-radius);\n border-top-left-radius: var(--border-radius);\n left: 0;\n }\n\n .symbol--append {\n border-bottom-right-radius: var(--border-radius);\n border-top-right-radius: var(--border-radius);\n right: 0;\n }\n</style>\n"],"names":["isNil","value","slots","useSlots","classes","useCssModule","attrs","useAttrs","inputEl","ref","__expose","internalValue","props","convertDecimal","decimalSeparator","showPassword","isNumber","computed","inputAttrs","tempAttrs","inputType","watchEffect","format","parseNumber","isUserTyping","tempValue","sanitizeDecimal","handleChange","parsedValue","emit","handleInput","e","onMounted"],"mappings":";;;;;;;;;;;;;;;AAoBA,SAASA,EAAMC,GAAO;AACpB,SAAOA,KAAS;AAClB;;;;;;;;;;;;;;;;;;;iBC+EQC,IAAQC,KACRC,IAAUC,KACVC,IAAQC,KAIRC,IAAUC;AAIH,IAAAC,EAAA,EAAE,SAAAF,GAAS;AAElB,UAAAG,IAAgBF,EAAqBG,EAAM,UAAU;AAE3D,IAAIA,EAAM,SAAS,aAAaA,EAAM,cAAcA,EAAM,eAAe,OACvED,EAAc,QAAQE,EAAeD,EAAM,YAAYE,CAAgB;AAGnE,UAAAC,IAAeN,EAAI,EAAK,GAExBO,IAAWC,EAAS,MAAML,EAAM,SAAS,QAAQ,GAEjDM,IAAaD,EAAS,MAAM;AAC1B,YAAAE,IAAY,EAAE,GAAGb;AAEvB,oBAAOa,EAAU,OAEVA;AAAA,IAAA,CACR,GAEKC,IAAYH,EAAS,MAGrBD,EAAS,SAITJ,EAAM,SAAS,cAAcG,EAAa,QACrC,SAGFH,EAAM,IACd;AAED,IAAAS,EAAY,MAAM;AACF,MAAAV,EAAA,QAAQW,EAAOV,EAAM,UAAU;AAAA,IAAA,CAC9C;AAQD,aAASW,EAAYtB,IAAyB,IAAIuB,IAAe,IAAwB;AAEnF,UAAA,CAACR,EAAS;AACL,eAAAf;AAGT,UAAIwB,IAAYxB;AAGhB,UAAID,EAAMyB,CAAS,KAAK,GAAGA,CAAS,GAAG,WAAW;AAAU,eAAA;AAQ5D,UALIX,MAAqB,QACXW,IAAAZ,EAAeY,GAAW,GAAG,IAIvCD,MAEEC,MAAc,QAAiBA,IAAA,OAG/BA,EAAU,WAAW,WAAW,IAAI;AAAU,eAAAA;AAIpD,UAAI,CAACzB,EAAMyB,CAAS,KAAK,GAAGA,CAAS,GAAG;AAC1B,QAAAA,IAAA,KAAK,aAAa,SAAS;AAAA,UACrC,OAAO;AAAA,UACP,uBAAuB;AAAA,UACvB,aAAa;AAAA,QACd,CAAA,EAAE,OAAO,OAAOA,CAAS,CAAC;AAAA;AAEpB,eAAA;AAIT,aAAO,MAAM,OAAOA,CAAS,CAAC,IAAI,KAAK,WAAWA,CAAS;AAAA,IAC7D;AAOA,aAASH,EAAOrB,GAAwB;AACtC,aAAIe,EAAS,QACJU,EAAgBzB,GAAOa,CAAgB,IAGzCb;AAAA,IACT;AAKA,aAAS0B,IAAe;AAEtB,YAAMC,IAAcZ,EAAS,QAAQO,EAAYZ,EAAc,KAAK,IAAIA,EAAc;AACtF,MAAAkB,EAAK,UAAUD,CAAW;AAAA,IAC5B;AAKA,aAASE,EAAYC,GAAU;AACvB,YAAA9B,IAAS8B,EAAE,OAA4B;AAG/B,MAAApB,EAAA,QAAQW,EAAOrB,CAAK;AAElC,YAAM2B,IAAcZ,EAAS,QAAQO,EAAYZ,EAAc,OAAO,EAAI,IAAIV;AAE9E,MAAA4B,EAAK,sBAAsBD,CAAW;AAAA,IACxC;AAEA,WAAAI,EAAU,MAAM;AACV,UAAApB,EAAM,UAAU;AACZ,cAAA,IAAI,MAAM,0DAA0D;AAG5E,UAAIN,EAAM;AACF,cAAA,IAAI,MAAM,+DAA+D;AAAA,IACjF,CACD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","x_google_ignoreList":[0]}
1
+ {"version":3,"file":"Input.js","sources":["../src/components/Input/Input.vue"],"sourcesContent":["<script lang=\"ts\" setup>\n import isNil from 'lodash-es/isNil';\n import { computed, onMounted, ref, useAttrs, useCssModule, useSlots, watchEffect } from 'vue';\n\n import { convertDecimal, decimalSeparator, sanitizeDecimal } from '../../utils/i18n';\n import Field from '../Field/Field.vue';\n import Icon from '../Icon/Icon.vue';\n\n export type InputValue = string | number | undefined;\n\n export interface InputProps {\n /**\n * Adds spacing under the field that is consistent whether or not hint/error text is displayed.\n */\n addBottomSpace?: boolean;\n\n /**\n * Error text to display. Replaces `hintText` (if provided) & adds error styling.\n */\n errorText?: string;\n\n /**\n * Displays text below the input; hidden when the isReadOnly prop is truthy.\n */\n hintText?: string;\n\n /**\n * ID for the Label and Input; must be unique\n */\n id?: string;\n\n /**\n * Label to render above the input.\n */\n label?: string;\n\n /**\n * Show \"(optional)\" to the right of the label text\n */\n showOptionalInLabel?: boolean;\n\n /**\n * Autocomplete takes in a string of off or on\n */\n autocomplete?: string;\n\n /**\n * Value for the input element.\n */\n modelValue?: string | number;\n\n /**\n * @deprecated Use :model-value or v-model instead of :value.\n */\n value?: string | number | null;\n\n /**\n * Input type. Excludes certain types that have a dedicated component.\n *\n * Note: For distinguishing between text & number internally, passing `number`\n * will still render an input with a type of `text` (for localization).\n */\n type?: string extends 'button' | 'checkbox' | 'radio' | 'submit' ? never : string;\n }\n\n defineOptions({\n name: 'll-input',\n inheritAttrs: false,\n });\n\n const props = withDefaults(defineProps<InputProps>(), {\n autocomplete: 'off',\n type: 'text',\n modelValue: '',\n value: null,\n errorText: undefined,\n hintText: undefined,\n label: undefined,\n id: undefined,\n });\n\n const emit =\n defineEmits<{\n /**\n * Emitted when the input value changes.\n */\n (e: 'update:model-value', v: string | number): void;\n /**\n * Emitted when the input value changes.\n */\n (e: 'change', v: string | number): void;\n /**\n * Emitted when the input is focused\n */\n (e: 'focus', evt: Event): void;\n /**\n * Emitted when the input is blurred\n */\n (e: 'blur', evt: Event): void;\n }>();\n\n const slots = useSlots();\n const classes = useCssModule();\n const attrs = useAttrs();\n\n // declare a ref to hold the element reference\n // the name must match template ref value\n const inputEl = ref<HTMLInputElement>();\n\n // this exposes the input ref to any parent that renders the `Input` component\n // and gives it a template ref, giving parent components access to the DOM element.\n defineExpose({ inputEl });\n\n const internalValue = ref<string | number>(props.modelValue);\n\n if (props.type === 'number' && (props.modelValue || props.modelValue === 0)) {\n internalValue.value = convertDecimal(props.modelValue, decimalSeparator);\n }\n\n const showPassword = ref(false);\n\n const isNumber = computed(() => props.type === 'number');\n\n const inputAttrs = computed(() => {\n const tempAttrs = { ...attrs };\n\n delete tempAttrs.class;\n\n return tempAttrs;\n });\n\n const inputType = computed(() => {\n // type 'number' is a special use case and requires\n // that the type be 'text' to support internationalization\n if (isNumber.value) {\n return 'text';\n }\n\n if (props.type === 'password' && showPassword.value) {\n return 'text';\n }\n\n return props.type;\n });\n\n watchEffect(() => {\n internalValue.value = format(props.modelValue);\n });\n\n /**\n * Converts the localized number to a valid number (to emit). i.e. 12,50 > 12.50\n *\n * @param {string|number} value - Number you want to parse.\n * @returns {number|string} number or empty string (for empty input)\n */\n function parseNumber(value: string | number = '', isUserTyping = false): string | number {\n // If this isn't a number input, we shouldn't be calling this function\n if (!isNumber.value) {\n return value;\n }\n\n let tempValue = value;\n\n // If blank, just stop\n if (isNil(tempValue) || `${tempValue}`.length === 0) return '';\n\n // clean out different locale decimals\n if (decimalSeparator !== '.') {\n tempValue = convertDecimal(tempValue, '.');\n }\n\n // If the user is in the middle of an input, let them finish the number\n if (isUserTyping) {\n // Prefix values with a 0 if the user starts with a decimal point\n if (tempValue === '.') tempValue = '0.';\n\n // This is to prevent the parsing from correcting 0. to 0 and causing the value to be reset\n if (tempValue.toString().startsWith('0.')) return tempValue;\n }\n\n // Empty or null values convert to 0 with NumberFormat, so return '';\n if (!isNil(tempValue) && `${tempValue}`.length) {\n tempValue = Intl.NumberFormat('en-US', {\n style: 'decimal',\n maximumFractionDigits: 7,\n useGrouping: false,\n }).format(Number(tempValue));\n } else {\n return '';\n }\n\n // Ensure valid number, otherwise clear value\n return isNaN(Number(tempValue)) ? '' : parseFloat(tempValue);\n }\n\n /**\n * Formats the input based on conditions\n *\n * @param {number|string} value - The value to format.\n */\n function format(value: string | number) {\n if (isNumber.value) {\n return sanitizeDecimal(value, decimalSeparator);\n }\n\n return value;\n }\n\n /**\n * Fire after focusing out of input, if value has changed.\n */\n function handleChange() {\n // Parse the final value on blur\n const parsedValue = isNumber.value ? parseNumber(internalValue.value) : internalValue.value;\n emit('change', parsedValue);\n }\n\n /**\n * Fired when typing on input.\n */\n function handleInput(e: Event) {\n const value = (e.target as HTMLInputElement).value;\n\n // Update the internal value with a sanitized version\n internalValue.value = format(value);\n\n const parsedValue = isNumber.value ? parseNumber(internalValue.value, true) : value;\n\n emit('update:model-value', parsedValue);\n }\n\n onMounted(() => {\n if (props.value !== null) {\n throw new Error('ll-input: use :model-value or v-model instead of :value.');\n }\n\n if (attrs.onInput) {\n throw new Error('ll-input: use the @update:model-value event instead of @input');\n }\n });\n</script>\n\n<template>\n <Field v-bind=\"props\" class=\"stash-input\" :class=\"[classes.root, attrs.class]\" data-test=\"ll-input\">\n <template #default=\"{ fieldId, fieldErrorId, hasError }\">\n <div class=\"relative\">\n <input\n v-bind=\"inputAttrs\"\n :id=\"fieldId\"\n ref=\"inputEl\"\n v-model=\"internalValue\"\n :aria-errormessage=\"fieldErrorId\"\n :aria-invalid=\"hasError\"\n :autocomplete=\"autocomplete\"\n :class=\"[\n { [classes['input-prepended']]: !!slots.prepend },\n { [classes['input-appended']]: !!slots.append || props.type === 'password' },\n { [classes['has-error']]: !!props.errorText },\n ]\"\n :type=\"inputType\"\n @change=\"handleChange\"\n @input=\"handleInput\"\n @blur=\"(evt) => emit('blur', evt)\"\n @focus=\"(evt) => emit('focus', evt)\"\n />\n\n <div\n v-if=\"slots.prepend\"\n class=\"stash-input-prepend font-semibold\"\n :class=\"[classes.symbol, classes['symbol--prepend']]\"\n >\n <!-- @slot renders content on the left side of the input -->\n <slot name=\"prepend\"> </slot>\n </div>\n\n <div\n v-if=\"slots.append || props.type === 'password'\"\n class=\"stash-input-append font-semibold\"\n :class=\"[classes.symbol, classes['symbol--append']]\"\n >\n <!-- @slot renders content on the right side of the input -->\n <slot v-if=\"slots.append\" name=\"append\"></slot>\n <Icon\n v-else\n :name=\"showPassword ? 'hide' : 'show'\"\n class=\"cursor-pointer\"\n :data-test=\"showPassword ? 'hide-password-icon' : 'show-password-icon'\"\n @click=\"showPassword = !showPassword\"\n />\n </div>\n </div>\n </template>\n <template v-if=\"slots.hint\" #hint>\n <slot name=\"hint\"></slot>\n </template>\n </Field>\n</template>\n\n<style module>\n .root {\n position: relative;\n }\n\n .root input {\n background: var(--color-white);\n border: 1px solid var(--color-ice);\n border-radius: var(--border-radius);\n color: var(--color-ice-700);\n display: block;\n height: var(--input-height);\n font-size: var(--input-font-size);\n font-weight: var(--font-weight-normal);\n outline: none;\n padding: 0 var(--ll-space-2);\n width: 100%;\n }\n\n .root input:hover {\n border-color: var(--color-ice);\n }\n\n .root input:active,\n .root input:focus {\n border-color: var(--color-blue);\n }\n\n .root input::placeholder {\n color: var(--color-ice);\n opacity: 1;\n }\n\n .root input.has-error:not(:focus) {\n border-color: var(--color-red);\n }\n\n .root input.input-prepended {\n padding-left: 36px;\n }\n\n .root input.input-appended {\n padding-right: 36px;\n }\n\n .root input[disabled],\n .root input[readonly] {\n background-color: var(--color-ice-200) !important;\n border-color: var(--color-ice) !important;\n color: var(--color-ice-700) !important;\n pointer-events: none;\n }\n\n .root input[disabled]:active,\n .root input[readonly]:active,\n .root input[disabled]:focus,\n .root input[readonly]:focus {\n box-shadow: none !important;\n }\n\n .root input[disabled]::placeholder,\n .root input[readonly]::placeholder {\n text-transform: none;\n }\n\n .symbol {\n align-items: center;\n display: flex;\n height: var(--input-height);\n justify-content: center;\n overflow: hidden;\n position: absolute;\n top: 0;\n width: var(--input-height);\n }\n\n .symbol--prepend {\n border-bottom-left-radius: var(--border-radius);\n border-top-left-radius: var(--border-radius);\n left: 0;\n }\n\n .symbol--append {\n border-bottom-right-radius: var(--border-radius);\n border-top-right-radius: var(--border-radius);\n right: 0;\n }\n</style>\n"],"names":["slots","useSlots","classes","useCssModule","attrs","useAttrs","inputEl","ref","__expose","internalValue","props","convertDecimal","decimalSeparator","showPassword","isNumber","computed","inputAttrs","tempAttrs","inputType","watchEffect","format","parseNumber","value","isUserTyping","tempValue","isNil","sanitizeDecimal","handleChange","parsedValue","emit","handleInput","e","onMounted"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iBAqGQA,IAAQC,KACRC,IAAUC,KACVC,IAAQC,KAIRC,IAAUC;AAIH,IAAAC,EAAA,EAAE,SAAAF,GAAS;AAElB,UAAAG,IAAgBF,EAAqBG,EAAM,UAAU;AAE3D,IAAIA,EAAM,SAAS,aAAaA,EAAM,cAAcA,EAAM,eAAe,OACvED,EAAc,QAAQE,EAAeD,EAAM,YAAYE,CAAgB;AAGnE,UAAAC,IAAeN,EAAI,EAAK,GAExBO,IAAWC,EAAS,MAAML,EAAM,SAAS,QAAQ,GAEjDM,IAAaD,EAAS,MAAM;AAC1B,YAAAE,IAAY,EAAE,GAAGb;AAEvB,oBAAOa,EAAU,OAEVA;AAAA,IAAA,CACR,GAEKC,IAAYH,EAAS,MAGrBD,EAAS,SAITJ,EAAM,SAAS,cAAcG,EAAa,QACrC,SAGFH,EAAM,IACd;AAED,IAAAS,EAAY,MAAM;AACF,MAAAV,EAAA,QAAQW,EAAOV,EAAM,UAAU;AAAA,IAAA,CAC9C;AAQD,aAASW,EAAYC,IAAyB,IAAIC,IAAe,IAAwB;AAEnF,UAAA,CAACT,EAAS;AACL,eAAAQ;AAGT,UAAIE,IAAYF;AAGhB,UAAIG,EAAMD,CAAS,KAAK,GAAGA,CAAS,GAAG,WAAW;AAAU,eAAA;AAQ5D,UALIZ,MAAqB,QACXY,IAAAb,EAAea,GAAW,GAAG,IAIvCD,MAEEC,MAAc,QAAiBA,IAAA,OAG/BA,EAAU,WAAW,WAAW,IAAI;AAAU,eAAAA;AAIpD,UAAI,CAACC,EAAMD,CAAS,KAAK,GAAGA,CAAS,GAAG;AAC1B,QAAAA,IAAA,KAAK,aAAa,SAAS;AAAA,UACrC,OAAO;AAAA,UACP,uBAAuB;AAAA,UACvB,aAAa;AAAA,QACd,CAAA,EAAE,OAAO,OAAOA,CAAS,CAAC;AAAA;AAEpB,eAAA;AAIT,aAAO,MAAM,OAAOA,CAAS,CAAC,IAAI,KAAK,WAAWA,CAAS;AAAA,IAC7D;AAOA,aAASJ,EAAOE,GAAwB;AACtC,aAAIR,EAAS,QACJY,EAAgBJ,GAAOV,CAAgB,IAGzCU;AAAA,IACT;AAKA,aAASK,IAAe;AAEtB,YAAMC,IAAcd,EAAS,QAAQO,EAAYZ,EAAc,KAAK,IAAIA,EAAc;AACtF,MAAAoB,EAAK,UAAUD,CAAW;AAAA,IAC5B;AAKA,aAASE,EAAYC,GAAU;AACvB,YAAAT,IAASS,EAAE,OAA4B;AAG/B,MAAAtB,EAAA,QAAQW,EAAOE,CAAK;AAElC,YAAMM,IAAcd,EAAS,QAAQO,EAAYZ,EAAc,OAAO,EAAI,IAAIa;AAE9E,MAAAO,EAAK,sBAAsBD,CAAW;AAAA,IACxC;AAEA,WAAAI,EAAU,MAAM;AACV,UAAAtB,EAAM,UAAU;AACZ,cAAA,IAAI,MAAM,0DAA0D;AAG5E,UAAIN,EAAM;AACF,cAAA,IAAI,MAAM,+DAA+D;AAAA,IACjF,CACD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -1,37 +1,28 @@
1
- import { defineComponent as B, useAttrs as S, useSlots as T, useCssModule as $, ref as m, computed as c, watchEffect as k, watch as v, openBlock as E, createBlock as b, mergeProps as d, createSlots as q, withCtx as f, createElementVNode as A, normalizeClass as M, unref as r, createVNode as h, renderSlot as z } from "vue";
2
- import { _ as F } from "./Field.vue_vue_type_script_setup_true_lang-c864abd3.js";
1
+ import { defineComponent as B, useAttrs as S, useSlots as T, useCssModule as $, ref as m, computed as c, watchEffect as k, watch as v, openBlock as E, createBlock as b, mergeProps as d, createSlots as q, withCtx as f, createElementVNode as A, normalizeClass as M, unref as s, createVNode as h, renderSlot as z } from "vue";
2
+ import { _ as F } from "./Field.vue_vue_type_script_setup_true_lang-475832fe.js";
3
3
  import N from "./Input.js";
4
4
  import O from "./Select.js";
5
5
  import { _ as U } from "./_plugin-vue_export-helper-dad06003.js";
6
- import "./uniqueId-847efe53.js";
7
- import "./toString-7d5bf363.js";
8
- import "./isObjectLike-54341556.js";
6
+ import "lodash-es/uniqueId";
9
7
  import "./Label.vue_vue_type_script_setup_true_lang-1d29d98a.js";
10
8
  import "./locale.js";
11
- import "./get-27d90892.js";
12
- import "./_MapCache-65811284.js";
9
+ import "lodash-es/get";
10
+ import "lodash-es/isNil";
13
11
  import "./utils/i18n.js";
14
12
  import "./constants.js";
15
13
  import "./Icon.js";
16
- import "./Icon.vue_used_vue_type_style_index_0_lang.module-d2507af3.js";
17
14
  import "./index-79ce320f.js";
18
- import "./debounce-6aca1ca9.js";
19
- import "./isEmpty-2fbad344.js";
20
- import "./_getTag-4db47fa6.js";
21
- import "./isArrayLike-09233e52.js";
22
- import "./_overArg-6d920d99.js";
23
- import "./isEqual-fca467fb.js";
24
- import "./_baseIsEqual-d594c87f.js";
25
- import "./_Uint8Array-06e4d083.js";
26
- import "./_getAllKeys-5e735d41.js";
27
- import "./isPlainObject-55c7f916.js";
28
- import "./_getPrototype-3e6fccd6.js";
15
+ import "./Icon.vue_used_vue_type_style_index_0_lang.module-eb359559.js";
16
+ import "lodash-es/debounce";
17
+ import "lodash-es/isEmpty";
18
+ import "lodash-es/isEqual";
19
+ import "lodash-es/isPlainObject";
29
20
  import "./useSearch.js";
30
- import "./searchFuzzy-13c124f8.js";
21
+ import "./searchFuzzy-74a7de1c.js";
31
22
  import "./_commonjsHelpers-10dfc225.js";
32
23
  import "./utils/helpers.js";
33
- import "./capitalize-667d9f60.js";
34
- import "./_createCompounder-ae01a723.js";
24
+ import "lodash-es/camelCase";
25
+ import "lodash-es/isFinite";
35
26
  import "./clickoutside.js";
36
27
  import "./MenusPlugin-5e93f0a5.js";
37
28
  import "./Chip.js";
@@ -52,7 +43,7 @@ const P = {
52
43
  },
53
44
  emits: ["update:model-value", "change"],
54
45
  setup(_, { emit: a }) {
55
- const o = _, u = S(), y = T(), s = $(), n = m(), i = m(!1), t = m(), g = c(() => {
46
+ const o = _, u = S(), y = T(), r = $(), n = m(), i = m(!1), t = m(), g = c(() => {
56
47
  const { disabled: e, placeholder: l } = u;
57
48
  return { disabled: e, placeholder: l };
58
49
  }), V = c(() => {
@@ -112,11 +103,11 @@ const P = {
112
103
  }), q({
113
104
  default: f(({ fieldId: p }) => [
114
105
  A("div", {
115
- class: M(["flex", { [r(s)["has-error"]]: !!o.errorText }])
106
+ class: M(["flex", { [s(r)["has-error"]]: !!o.errorText }])
116
107
  }, [
117
108
  h(N, d(g.value, {
118
109
  id: p,
119
- class: ["flex-1", [r(s).input, { "tw-z-control": i.value }]],
110
+ class: ["flex-1", [s(r).input, { "tw-z-control": i.value }]],
120
111
  type: o.type,
121
112
  "model-value": n.value,
122
113
  onChange: w,
@@ -128,7 +119,7 @@ const P = {
128
119
  single: "",
129
120
  "hide-search": "",
130
121
  "prevent-empty": "",
131
- class: r(s).select,
122
+ class: s(r).select,
132
123
  "no-truncate": e.noTruncate,
133
124
  options: e.options,
134
125
  "model-value": t.value,
@@ -138,7 +129,7 @@ const P = {
138
129
  ]),
139
130
  _: 2
140
131
  }, [
141
- r(y).hint ? {
132
+ s(y).hint ? {
142
133
  name: "hint",
143
134
  fn: f(() => [
144
135
  z(e.$slots, "hint")
@@ -153,8 +144,8 @@ const P = {
153
144
  "has-error": "_has-error_mqotn_26"
154
145
  }, J = {
155
146
  $style: H
156
- }, be = /* @__PURE__ */ U(j, [["__cssModules", J]]);
147
+ }, we = /* @__PURE__ */ U(j, [["__cssModules", J]]);
157
148
  export {
158
- be as default
149
+ we as default
159
150
  };
160
151
  //# sourceMappingURL=InputOptions.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"InputOptions.js","sources":["../src/components/InputOptions/InputOptions.vue"],"sourcesContent":["<script lang=\"ts\">\n export default {\n name: 'll-input-options',\n };\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n type Option = any;\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n type SelectedOption = any;\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n interface InputOptionsProps {\n /**\n * Error text to display. Replaces `hintText` (if provided) & adds error styling\n */\n errorText?: string;\n\n /**\n * Hint text to display below the input\n */\n hintText?: string;\n\n /**\n * Label to render for the datepicker\n */\n label?: string;\n\n /**\n * The current value inclusive of the input & select\n */\n modelValue?: { value: string; option?: SelectedOption };\n\n /**\n * Input type\n */\n type?: string extends 'button' | 'checkbox' | 'radio' | 'submit' ? never : string;\n\n /**\n * Prevents the Selected Option from being truncated, if true\n */\n noTruncate?: boolean;\n\n /**\n * Options for the select\n */\n options?: Option[];\n }\n</script>\n\n<script lang=\"ts\" setup>\n import { computed, ref, useAttrs, useCssModule, useSlots, watch, watchEffect } from 'vue';\n\n import Field from '../Field/Field.vue';\n import Input from '../Input/Input.vue';\n import Select from '../Select/Select.vue';\n\n const props = withDefaults(defineProps<InputOptionsProps>(), {\n modelValue: () => ({ value: '', option: undefined }),\n noTruncate: false,\n options: () => [],\n dataTest: 'll-input-options',\n errorText: undefined,\n hintText: undefined,\n label: undefined,\n type: 'text',\n });\n\n const emit =\n defineEmits<{\n (\n e: 'update:model-value',\n v: { value?: string; option?: SelectedOption; isValueChange: boolean; type: 'input' | 'select' },\n ): void;\n (\n e: 'change',\n v: { value?: string; option?: SelectedOption; isValueChange: boolean; type: 'input' | 'select' },\n ): void;\n }>();\n\n const attrs = useAttrs();\n const slots = useSlots();\n const classes = useCssModule();\n const internalInput = ref<string>();\n const isInputFocused = ref(false);\n const selectedOption = ref<Option | undefined>();\n\n const inputAttrs = computed(() => {\n const { disabled, placeholder } = attrs;\n\n return { disabled, placeholder } as { disabled: boolean; placeholder: string };\n });\n\n const selectAttrs = computed(() => {\n const { disabled, displayBy, trackBy } = attrs;\n\n return { disabled, displayBy, trackBy } as { disabled: boolean; displayBy: string; trackBy: string };\n });\n\n // Input value changed\n function handleInput(val?: string | number) {\n internalInput.value = String(val);\n\n emit('update:model-value', {\n value: internalInput.value,\n option: selectedOption.value,\n isValueChange: true,\n type: 'input',\n });\n }\n\n // Input blurred\n function handleInputChange() {\n emit('change', {\n value: internalInput.value,\n option: selectedOption.value,\n isValueChange: true,\n type: 'input',\n });\n }\n\n function handleSelectChange(val?: Option) {\n selectedOption.value = val;\n\n emit('change', {\n value: internalInput.value,\n option: selectedOption.value,\n isValueChange: false,\n type: 'select',\n });\n emit('update:model-value', {\n value: internalInput.value,\n option: selectedOption.value,\n isValueChange: false,\n type: 'select',\n });\n }\n\n watchEffect(() => {\n if (!selectedOption.value) {\n selectedOption.value = props.options[0];\n }\n });\n\n watch(\n () => props.modelValue.value,\n () => {\n internalInput.value = props.modelValue.value;\n },\n { immediate: true },\n );\n\n watch(\n () => props.modelValue.option,\n () => {\n selectedOption.value = props.modelValue.option;\n },\n { immediate: true },\n );\n\n if (attrs.value) {\n throw new Error('ll-input-options: use :model-value or v-model instead of :value.');\n }\n\n if (attrs.onInput) {\n throw new Error('ll-input-options: use the @update:model-value event instead of @input');\n }\n</script>\n\n<template>\n <Field v-bind=\"props\" class=\"input\" data-test=\"ll-input-options\">\n <template #default=\"{ fieldId }\">\n <div class=\"flex\" :class=\"{ [classes['has-error']]: !!props.errorText }\">\n <Input\n v-bind=\"inputAttrs\"\n :id=\"fieldId\"\n class=\"flex-1\"\n :class=\"[classes.input, { 'tw-z-control': isInputFocused }]\"\n :type=\"props.type\"\n :model-value=\"internalInput\"\n @change=\"handleInputChange\"\n @update:model-value=\"handleInput\"\n @blur=\"isInputFocused = false\"\n @focus=\"isInputFocused = true\"\n />\n\n <Select\n v-bind=\"selectAttrs\"\n single\n hide-search\n prevent-empty\n :class=\"classes.select\"\n :no-truncate=\"noTruncate\"\n :options=\"options\"\n :model-value=\"selectedOption\"\n @update:model-value=\"handleSelectChange\"\n />\n </div>\n </template>\n <template v-if=\"slots.hint\" #hint>\n <slot name=\"hint\"></slot>\n </template>\n </Field>\n</template>\n\n<style module>\n .input {\n display: inline-block;\n /* input border overlaps select border */\n margin-right: -1px;\n }\n\n .input input {\n border-bottom-right-radius: 0;\n border-top-right-radius: 0;\n }\n\n .select {\n min-width: 80px;\n }\n\n .select :global(.stash-select__content) {\n border-bottom-left-radius: 0;\n border-top-left-radius: 0;\n }\n\n .select:global(.stash-select--active .stash-select__content) {\n min-width: 0;\n }\n\n .has-error input,\n .has-error input:hover:not(:focus),\n .has-error :global(.stash-select__content),\n .has-error :global(.stash-select__content:hover:not(:focus)) {\n border-color: var(--color-red);\n }\n</style>\n"],"names":["attrs","useAttrs","slots","useSlots","classes","useCssModule","internalInput","ref","isInputFocused","selectedOption","inputAttrs","computed","disabled","placeholder","selectAttrs","displayBy","trackBy","handleInput","val","emit","handleInputChange","handleSelectChange","watchEffect","props","watch"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AACE,UAAe;AAAA,EACb,MAAM;AACR;;;;;;;;;;;;;iBA6EMA,IAAQC,KACRC,IAAQC,KACRC,IAAUC,KACVC,IAAgBC,KAChBC,IAAiBD,EAAI,EAAK,GAC1BE,IAAiBF,KAEjBG,IAAaC,EAAS,MAAM;AAC1B,YAAA,EAAE,UAAAC,GAAU,aAAAC,EAAgB,IAAAb;AAE3B,aAAA,EAAE,UAAAY,GAAU,aAAAC;IAAY,CAChC,GAEKC,IAAcH,EAAS,MAAM;AACjC,YAAM,EAAE,UAAAC,GAAU,WAAAG,GAAW,SAAAC,EAAA,IAAYhB;AAElC,aAAA,EAAE,UAAAY,GAAU,WAAAG,GAAW,SAAAC;IAAQ,CACvC;AAGD,aAASC,EAAYC,GAAuB;AAC5B,MAAAZ,EAAA,QAAQ,OAAOY,CAAG,GAEhCC,EAAK,sBAAsB;AAAA,QACzB,OAAOb,EAAc;AAAA,QACrB,QAAQG,EAAe;AAAA,QACvB,eAAe;AAAA,QACf,MAAM;AAAA,MAAA,CACP;AAAA,IACH;AAGA,aAASW,IAAoB;AAC3B,MAAAD,EAAK,UAAU;AAAA,QACb,OAAOb,EAAc;AAAA,QACrB,QAAQG,EAAe;AAAA,QACvB,eAAe;AAAA,QACf,MAAM;AAAA,MAAA,CACP;AAAA,IACH;AAEA,aAASY,EAAmBH,GAAc;AACxC,MAAAT,EAAe,QAAQS,GAEvBC,EAAK,UAAU;AAAA,QACb,OAAOb,EAAc;AAAA,QACrB,QAAQG,EAAe;AAAA,QACvB,eAAe;AAAA,QACf,MAAM;AAAA,MAAA,CACP,GACDU,EAAK,sBAAsB;AAAA,QACzB,OAAOb,EAAc;AAAA,QACrB,QAAQG,EAAe;AAAA,QACvB,eAAe;AAAA,QACf,MAAM;AAAA,MAAA,CACP;AAAA,IACH;AAwBA,QAtBAa,EAAY,MAAM;AACZ,MAACb,EAAe,UACHA,EAAA,QAAQc,EAAM,QAAQ,CAAC;AAAA,IACxC,CACD,GAEDC;AAAA,MACE,MAAMD,EAAM,WAAW;AAAA,MACvB,MAAM;AACU,QAAAjB,EAAA,QAAQiB,EAAM,WAAW;AAAA,MACzC;AAAA,MACA,EAAE,WAAW,GAAK;AAAA,IAAA,GAGpBC;AAAA,MACE,MAAMD,EAAM,WAAW;AAAA,MACvB,MAAM;AACW,QAAAd,EAAA,QAAQc,EAAM,WAAW;AAAA,MAC1C;AAAA,MACA,EAAE,WAAW,GAAK;AAAA,IAAA,GAGhBvB,EAAM;AACF,YAAA,IAAI,MAAM,kEAAkE;AAGpF,QAAIA,EAAM;AACF,YAAA,IAAI,MAAM,uEAAuE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"InputOptions.js","sources":["../src/components/InputOptions/InputOptions.vue"],"sourcesContent":["<script lang=\"ts\">\n export default {\n name: 'll-input-options',\n };\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n type Option = any;\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n type SelectedOption = any;\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n interface InputOptionsProps {\n /**\n * Error text to display. Replaces `hintText` (if provided) & adds error styling\n */\n errorText?: string;\n\n /**\n * Hint text to display below the input\n */\n hintText?: string;\n\n /**\n * Label to render for the datepicker\n */\n label?: string;\n\n /**\n * The current value inclusive of the input & select\n */\n modelValue?: { value: string; option?: SelectedOption };\n\n /**\n * Input type\n */\n type?: string extends 'button' | 'checkbox' | 'radio' | 'submit' ? never : string;\n\n /**\n * Prevents the Selected Option from being truncated, if true\n */\n noTruncate?: boolean;\n\n /**\n * Options for the select\n */\n options?: Option[];\n }\n</script>\n\n<script lang=\"ts\" setup>\n import { computed, ref, useAttrs, useCssModule, useSlots, watch, watchEffect } from 'vue';\n\n import Field from '../Field/Field.vue';\n import Input from '../Input/Input.vue';\n import Select from '../Select/Select.vue';\n\n const props = withDefaults(defineProps<InputOptionsProps>(), {\n modelValue: () => ({ value: '', option: undefined }),\n noTruncate: false,\n options: () => [],\n dataTest: 'll-input-options',\n errorText: undefined,\n hintText: undefined,\n label: undefined,\n type: 'text',\n });\n\n const emit =\n defineEmits<{\n (\n e: 'update:model-value',\n v: { value?: string; option?: SelectedOption; isValueChange: boolean; type: 'input' | 'select' },\n ): void;\n (\n e: 'change',\n v: { value?: string; option?: SelectedOption; isValueChange: boolean; type: 'input' | 'select' },\n ): void;\n }>();\n\n const attrs = useAttrs();\n const slots = useSlots();\n const classes = useCssModule();\n const internalInput = ref<string>();\n const isInputFocused = ref(false);\n const selectedOption = ref<Option | undefined>();\n\n const inputAttrs = computed(() => {\n const { disabled, placeholder } = attrs;\n\n return { disabled, placeholder } as { disabled: boolean; placeholder: string };\n });\n\n const selectAttrs = computed(() => {\n const { disabled, displayBy, trackBy } = attrs;\n\n return { disabled, displayBy, trackBy } as { disabled: boolean; displayBy: string; trackBy: string };\n });\n\n // Input value changed\n function handleInput(val?: string | number) {\n internalInput.value = String(val);\n\n emit('update:model-value', {\n value: internalInput.value,\n option: selectedOption.value,\n isValueChange: true,\n type: 'input',\n });\n }\n\n // Input blurred\n function handleInputChange() {\n emit('change', {\n value: internalInput.value,\n option: selectedOption.value,\n isValueChange: true,\n type: 'input',\n });\n }\n\n function handleSelectChange(val?: Option) {\n selectedOption.value = val;\n\n emit('change', {\n value: internalInput.value,\n option: selectedOption.value,\n isValueChange: false,\n type: 'select',\n });\n emit('update:model-value', {\n value: internalInput.value,\n option: selectedOption.value,\n isValueChange: false,\n type: 'select',\n });\n }\n\n watchEffect(() => {\n if (!selectedOption.value) {\n selectedOption.value = props.options[0];\n }\n });\n\n watch(\n () => props.modelValue.value,\n () => {\n internalInput.value = props.modelValue.value;\n },\n { immediate: true },\n );\n\n watch(\n () => props.modelValue.option,\n () => {\n selectedOption.value = props.modelValue.option;\n },\n { immediate: true },\n );\n\n if (attrs.value) {\n throw new Error('ll-input-options: use :model-value or v-model instead of :value.');\n }\n\n if (attrs.onInput) {\n throw new Error('ll-input-options: use the @update:model-value event instead of @input');\n }\n</script>\n\n<template>\n <Field v-bind=\"props\" class=\"input\" data-test=\"ll-input-options\">\n <template #default=\"{ fieldId }\">\n <div class=\"flex\" :class=\"{ [classes['has-error']]: !!props.errorText }\">\n <Input\n v-bind=\"inputAttrs\"\n :id=\"fieldId\"\n class=\"flex-1\"\n :class=\"[classes.input, { 'tw-z-control': isInputFocused }]\"\n :type=\"props.type\"\n :model-value=\"internalInput\"\n @change=\"handleInputChange\"\n @update:model-value=\"handleInput\"\n @blur=\"isInputFocused = false\"\n @focus=\"isInputFocused = true\"\n />\n\n <Select\n v-bind=\"selectAttrs\"\n single\n hide-search\n prevent-empty\n :class=\"classes.select\"\n :no-truncate=\"noTruncate\"\n :options=\"options\"\n :model-value=\"selectedOption\"\n @update:model-value=\"handleSelectChange\"\n />\n </div>\n </template>\n <template v-if=\"slots.hint\" #hint>\n <slot name=\"hint\"></slot>\n </template>\n </Field>\n</template>\n\n<style module>\n .input {\n display: inline-block;\n /* input border overlaps select border */\n margin-right: -1px;\n }\n\n .input input {\n border-bottom-right-radius: 0;\n border-top-right-radius: 0;\n }\n\n .select {\n min-width: 80px;\n }\n\n .select :global(.stash-select__content) {\n border-bottom-left-radius: 0;\n border-top-left-radius: 0;\n }\n\n .select:global(.stash-select--active .stash-select__content) {\n min-width: 0;\n }\n\n .has-error input,\n .has-error input:hover:not(:focus),\n .has-error :global(.stash-select__content),\n .has-error :global(.stash-select__content:hover:not(:focus)) {\n border-color: var(--color-red);\n }\n</style>\n"],"names":["attrs","useAttrs","slots","useSlots","classes","useCssModule","internalInput","ref","isInputFocused","selectedOption","inputAttrs","computed","disabled","placeholder","selectAttrs","displayBy","trackBy","handleInput","val","emit","handleInputChange","handleSelectChange","watchEffect","props","watch"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AACE,UAAe;AAAA,EACb,MAAM;AACR;;;;;;;;;;;;;iBA6EMA,IAAQC,KACRC,IAAQC,KACRC,IAAUC,KACVC,IAAgBC,KAChBC,IAAiBD,EAAI,EAAK,GAC1BE,IAAiBF,KAEjBG,IAAaC,EAAS,MAAM;AAC1B,YAAA,EAAE,UAAAC,GAAU,aAAAC,EAAgB,IAAAb;AAE3B,aAAA,EAAE,UAAAY,GAAU,aAAAC;IAAY,CAChC,GAEKC,IAAcH,EAAS,MAAM;AACjC,YAAM,EAAE,UAAAC,GAAU,WAAAG,GAAW,SAAAC,EAAA,IAAYhB;AAElC,aAAA,EAAE,UAAAY,GAAU,WAAAG,GAAW,SAAAC;IAAQ,CACvC;AAGD,aAASC,EAAYC,GAAuB;AAC5B,MAAAZ,EAAA,QAAQ,OAAOY,CAAG,GAEhCC,EAAK,sBAAsB;AAAA,QACzB,OAAOb,EAAc;AAAA,QACrB,QAAQG,EAAe;AAAA,QACvB,eAAe;AAAA,QACf,MAAM;AAAA,MAAA,CACP;AAAA,IACH;AAGA,aAASW,IAAoB;AAC3B,MAAAD,EAAK,UAAU;AAAA,QACb,OAAOb,EAAc;AAAA,QACrB,QAAQG,EAAe;AAAA,QACvB,eAAe;AAAA,QACf,MAAM;AAAA,MAAA,CACP;AAAA,IACH;AAEA,aAASY,EAAmBH,GAAc;AACxC,MAAAT,EAAe,QAAQS,GAEvBC,EAAK,UAAU;AAAA,QACb,OAAOb,EAAc;AAAA,QACrB,QAAQG,EAAe;AAAA,QACvB,eAAe;AAAA,QACf,MAAM;AAAA,MAAA,CACP,GACDU,EAAK,sBAAsB;AAAA,QACzB,OAAOb,EAAc;AAAA,QACrB,QAAQG,EAAe;AAAA,QACvB,eAAe;AAAA,QACf,MAAM;AAAA,MAAA,CACP;AAAA,IACH;AAwBA,QAtBAa,EAAY,MAAM;AACZ,MAACb,EAAe,UACHA,EAAA,QAAQc,EAAM,QAAQ,CAAC;AAAA,IACxC,CACD,GAEDC;AAAA,MACE,MAAMD,EAAM,WAAW;AAAA,MACvB,MAAM;AACU,QAAAjB,EAAA,QAAQiB,EAAM,WAAW;AAAA,MACzC;AAAA,MACA,EAAE,WAAW,GAAK;AAAA,IAAA,GAGpBC;AAAA,MACE,MAAMD,EAAM,WAAW;AAAA,MACvB,MAAM;AACW,QAAAd,EAAA,QAAQc,EAAM,WAAW;AAAA,MAC1C;AAAA,MACA,EAAE,WAAW,GAAK;AAAA,IAAA,GAGhBvB,EAAM;AACF,YAAA,IAAI,MAAM,kEAAkE;AAGpF,QAAIA,EAAM;AACF,YAAA,IAAI,MAAM,uEAAuE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
package/dist/Label.js CHANGED
@@ -1,10 +1,7 @@
1
1
  import { _ as o } from "./Label.vue_vue_type_script_setup_true_lang-1d29d98a.js";
2
2
  import "vue";
3
3
  import "./locale.js";
4
- import "./get-27d90892.js";
5
- import "./isObjectLike-54341556.js";
6
- import "./toString-7d5bf363.js";
7
- import "./_MapCache-65811284.js";
4
+ import "lodash-es/get";
8
5
  export {
9
6
  o as default
10
7
  };
package/dist/Label.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"Label.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;"}
1
+ {"version":3,"file":"Label.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}