bitboss-ui 2.0.3 → 2.0.5

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 (261) hide show
  1. package/dist/components/BaseDatePicker/BaseDatePicker.vue.d.ts +10 -99
  2. package/dist/components/BaseDatePicker/BaseDatePickerHeader.vue.d.ts +24 -0
  3. package/dist/components/BaseDatePicker/BaseDatePickerInputDaySelector.vue.d.ts +56 -0
  4. package/dist/components/BaseDatePicker/BaseDatePickerMonthSelector.vue.d.ts +21 -0
  5. package/dist/components/BaseDatePicker/BaseDatePickerYearSelector.vue.d.ts +21 -0
  6. package/dist/components/BaseDatePickerInput/BaseDatePickerInput.vue.d.ts +1 -46
  7. package/dist/components/BbDatePickerInput/BbDatePickerInput.vue.d.ts +1 -47
  8. package/dist/components/BbTab/BbTab.vue.d.ts +9 -0
  9. package/dist/components/Transitions/Slide.vue.d.ts +43 -0
  10. package/dist/components/Transitions/SlideBack.vue.d.ts +43 -0
  11. package/dist/composables/useLogger.d.ts +1 -0
  12. package/dist/index103.js +150 -126
  13. package/dist/index103.js.map +1 -1
  14. package/dist/index105.js +5 -5
  15. package/dist/index113.js +1 -1
  16. package/dist/index115.js +5 -5
  17. package/dist/index115.js.map +1 -1
  18. package/dist/index117.js +1 -1
  19. package/dist/index12.js +1 -1
  20. package/dist/index121.js +1 -1
  21. package/dist/index122.js +1 -1
  22. package/dist/index123.js +1 -1
  23. package/dist/index125.js +1 -1
  24. package/dist/index128.js +1 -1
  25. package/dist/index14.js +3 -3
  26. package/dist/index16.js +2 -2
  27. package/dist/index18.js +176 -482
  28. package/dist/index18.js.map +1 -1
  29. package/dist/index198.js +3 -5
  30. package/dist/index198.js.map +1 -1
  31. package/dist/index199.js +5 -158
  32. package/dist/index199.js.map +1 -1
  33. package/dist/index20.js +199 -190
  34. package/dist/index20.js.map +1 -1
  35. package/dist/index200.js +16 -84
  36. package/dist/index200.js.map +1 -1
  37. package/dist/{index223.js → index201.js} +3 -3
  38. package/dist/{index223.js.map → index201.js.map} +1 -1
  39. package/dist/index202.js +19 -3
  40. package/dist/index202.js.map +1 -1
  41. package/dist/index203.js +19 -3
  42. package/dist/index203.js.map +1 -1
  43. package/dist/index204.js +26 -34
  44. package/dist/index204.js.map +1 -1
  45. package/dist/index205.js +3 -6
  46. package/dist/index205.js.map +1 -1
  47. package/dist/index206.js +2 -7
  48. package/dist/index206.js.map +1 -1
  49. package/dist/index207.js +8 -2
  50. package/dist/index207.js.map +1 -1
  51. package/dist/index208.js +245 -122
  52. package/dist/index208.js.map +1 -1
  53. package/dist/index210.js +51 -122
  54. package/dist/index210.js.map +1 -1
  55. package/dist/index211.js +37 -19
  56. package/dist/index211.js.map +1 -1
  57. package/dist/index212.js +5 -2
  58. package/dist/index212.js.map +1 -1
  59. package/dist/index213.js +41 -2
  60. package/dist/index213.js.map +1 -1
  61. package/dist/index214.js +2 -174
  62. package/dist/index214.js.map +1 -1
  63. package/dist/index215.js +4 -42
  64. package/dist/index215.js.map +1 -1
  65. package/dist/index216.js +5 -0
  66. package/dist/index216.js.map +1 -0
  67. package/dist/index217.js +2 -13
  68. package/dist/index217.js.map +1 -1
  69. package/dist/index218.js +42 -369
  70. package/dist/index218.js.map +1 -1
  71. package/dist/index22.js +5 -5
  72. package/dist/index220.js +13 -4
  73. package/dist/index220.js.map +1 -1
  74. package/dist/index221.js +158 -2
  75. package/dist/index221.js.map +1 -1
  76. package/dist/index222.js +84 -16
  77. package/dist/index222.js.map +1 -1
  78. package/dist/index224.js +3 -19
  79. package/dist/index224.js.map +1 -1
  80. package/dist/index225.js +34 -26
  81. package/dist/index225.js.map +1 -1
  82. package/dist/index226.js +6 -8
  83. package/dist/index226.js.map +1 -1
  84. package/dist/index227.js +7 -2
  85. package/dist/index227.js.map +1 -1
  86. package/dist/index228.js +126 -3
  87. package/dist/index228.js.map +1 -1
  88. package/dist/index229.js +123 -3
  89. package/dist/index229.js.map +1 -1
  90. package/dist/index230.js +2 -18
  91. package/dist/index230.js.map +1 -1
  92. package/dist/index231.js +173 -105
  93. package/dist/index231.js.map +1 -1
  94. package/dist/index232.js +8 -0
  95. package/dist/index232.js.map +1 -0
  96. package/dist/index233.js +367 -98
  97. package/dist/index233.js.map +1 -1
  98. package/dist/index234.js +6 -0
  99. package/dist/index234.js.map +1 -0
  100. package/dist/index235.js +17 -9
  101. package/dist/index235.js.map +1 -1
  102. package/dist/index236.js +106 -3
  103. package/dist/index236.js.map +1 -1
  104. package/dist/index238.js +100 -23
  105. package/dist/index238.js.map +1 -1
  106. package/dist/index24.js +1 -1
  107. package/dist/index240.js +2 -16
  108. package/dist/index240.js.map +1 -1
  109. package/dist/index241.js +10 -9
  110. package/dist/index241.js.map +1 -1
  111. package/dist/index242.js +3 -3
  112. package/dist/index242.js.map +1 -1
  113. package/dist/index243.js +224 -12
  114. package/dist/index243.js.map +1 -1
  115. package/dist/index244.js +280 -8
  116. package/dist/index244.js.map +1 -1
  117. package/dist/index245.js +6 -9
  118. package/dist/index245.js.map +1 -1
  119. package/dist/index246.js +2 -17
  120. package/dist/index246.js.map +1 -1
  121. package/dist/index247.js +2 -224
  122. package/dist/index247.js.map +1 -1
  123. package/dist/index248.js +2 -431
  124. package/dist/index248.js.map +1 -1
  125. package/dist/index249.js +2 -89
  126. package/dist/index249.js.map +1 -1
  127. package/dist/index250.js +2 -281
  128. package/dist/index250.js.map +1 -1
  129. package/dist/index251.js +2 -6
  130. package/dist/index251.js.map +1 -1
  131. package/dist/index252.js +3 -2
  132. package/dist/index252.js.map +1 -1
  133. package/dist/index253.js +2 -2
  134. package/dist/index254.js +2 -2
  135. package/dist/index255.js +2 -126
  136. package/dist/index255.js.map +1 -1
  137. package/dist/index256.js +28 -3
  138. package/dist/index256.js.map +1 -1
  139. package/dist/index257.js +25 -0
  140. package/dist/index257.js.map +1 -0
  141. package/dist/index259.js +6 -3
  142. package/dist/index259.js.map +1 -1
  143. package/dist/index26.js +3 -3
  144. package/dist/index260.js +4 -2
  145. package/dist/index260.js.map +1 -1
  146. package/dist/index261.js +8 -68
  147. package/dist/index261.js.map +1 -1
  148. package/dist/index262.js +23 -200
  149. package/dist/index262.js.map +1 -1
  150. package/dist/index263.js +3 -5
  151. package/dist/index263.js.map +1 -1
  152. package/dist/index265.js +6 -127
  153. package/dist/index265.js.map +1 -1
  154. package/dist/index266.js +16 -2
  155. package/dist/index266.js.map +1 -1
  156. package/dist/index267.js +9 -2
  157. package/dist/index267.js.map +1 -1
  158. package/dist/index268.js +3 -2
  159. package/dist/index268.js.map +1 -1
  160. package/dist/index269.js +12 -2
  161. package/dist/index269.js.map +1 -1
  162. package/dist/index270.js +7 -26
  163. package/dist/index270.js.map +1 -1
  164. package/dist/index271.js +9 -3
  165. package/dist/index271.js.map +1 -1
  166. package/dist/index272.js +17 -3
  167. package/dist/index272.js.map +1 -1
  168. package/dist/index273.js +426 -206
  169. package/dist/index273.js.map +1 -1
  170. package/dist/index274.js +92 -0
  171. package/dist/index274.js.map +1 -0
  172. package/dist/index275.js +2 -4
  173. package/dist/index275.js.map +1 -1
  174. package/dist/index276.js +69 -4
  175. package/dist/index276.js.map +1 -1
  176. package/dist/index277.js +5 -59
  177. package/dist/index277.js.map +1 -1
  178. package/dist/index278.js +200 -15
  179. package/dist/index278.js.map +1 -1
  180. package/dist/index279.js +2 -35
  181. package/dist/index279.js.map +1 -1
  182. package/dist/index28.js +2 -2
  183. package/dist/index280.js +125 -10
  184. package/dist/index280.js.map +1 -1
  185. package/dist/index281.js +21 -1
  186. package/dist/index281.js.map +1 -1
  187. package/dist/{index264.js → index283.js} +2 -2
  188. package/dist/{index264.js.map → index283.js.map} +1 -1
  189. package/dist/index284.js +123 -417
  190. package/dist/index284.js.map +1 -1
  191. package/dist/index285.js +3 -47
  192. package/dist/index285.js.map +1 -1
  193. package/dist/index286.js +6 -0
  194. package/dist/index286.js.map +1 -0
  195. package/dist/index287.js +214 -0
  196. package/dist/index287.js.map +1 -0
  197. package/dist/index289.js +18 -0
  198. package/dist/index289.js.map +1 -0
  199. package/dist/index290.js +10 -0
  200. package/dist/index290.js.map +1 -0
  201. package/dist/index291.js +22 -0
  202. package/dist/index291.js.map +1 -0
  203. package/dist/index292.js +10 -0
  204. package/dist/index292.js.map +1 -0
  205. package/dist/index293.js +7 -0
  206. package/dist/index293.js.map +1 -0
  207. package/dist/index294.js +7 -0
  208. package/dist/index294.js.map +1 -0
  209. package/dist/index295.js +62 -0
  210. package/dist/index295.js.map +1 -0
  211. package/dist/index296.js +38 -0
  212. package/dist/index296.js.map +1 -0
  213. package/dist/index297.js +14 -0
  214. package/dist/index297.js.map +1 -0
  215. package/dist/index298.js +5 -0
  216. package/dist/index298.js.map +1 -0
  217. package/dist/{index282.js → index299.js} +3 -3
  218. package/dist/{index282.js.map → index299.js.map} +1 -1
  219. package/dist/index30.js +2 -2
  220. package/dist/index301.js +424 -0
  221. package/dist/index301.js.map +1 -0
  222. package/dist/index302.js +50 -0
  223. package/dist/index302.js.map +1 -0
  224. package/dist/index32.js +3 -3
  225. package/dist/index34.js +44 -42
  226. package/dist/index34.js.map +1 -1
  227. package/dist/index36.js +4 -4
  228. package/dist/index38.js +2 -2
  229. package/dist/index40.js +2 -2
  230. package/dist/index42.js +6 -6
  231. package/dist/index44.js +2 -2
  232. package/dist/index46.js +2 -2
  233. package/dist/index52.js +1 -1
  234. package/dist/index54.js +1 -1
  235. package/dist/index58.js +2 -2
  236. package/dist/index66.js +16 -23
  237. package/dist/index66.js.map +1 -1
  238. package/dist/index70.js +4 -4
  239. package/dist/index74.js +2 -2
  240. package/dist/index76.js +1 -1
  241. package/dist/index79.js +2 -2
  242. package/dist/index81.js +1 -1
  243. package/dist/index83.js +3 -3
  244. package/dist/index85.js +1 -1
  245. package/dist/style.css +1 -1
  246. package/dist/utilities/functions/chunk.d.ts +1 -0
  247. package/dist/utilities/functions/negative.d.ts +1 -0
  248. package/dist/utilities/functions/pipe.d.ts +3 -0
  249. package/dist/utilities/functions/range.d.ts +1 -0
  250. package/dist/utilities/functions/sort.d.ts +6 -0
  251. package/package.json +2 -2
  252. package/dist/index209.js +0 -8
  253. package/dist/index209.js.map +0 -1
  254. package/dist/index219.js +0 -5
  255. package/dist/index219.js.map +0 -1
  256. package/dist/index237.js +0 -12
  257. package/dist/index237.js.map +0 -1
  258. package/dist/index239.js +0 -9
  259. package/dist/index239.js.map +0 -1
  260. package/dist/index258.js +0 -10
  261. package/dist/index258.js.map +0 -1
package/dist/index34.js CHANGED
@@ -1,27 +1,27 @@
1
- import { defineComponent as Me, defineAsyncComponent as Ne, ref as m, computed as y, toRef as I, openBlock as b, createBlock as $, normalizeClass as W, withCtx as s, renderSlot as p, unref as r, createVNode as F, createElementVNode as S, createElementBlock as M, Fragment as R, createCommentVNode as J, withDirectives as xe, isRef as He, withModifiers as c, withKeys as g, vModelDynamic as Pe, renderList as _e, mergeProps as Y, Teleport as ze, normalizeStyle as Qe, nextTick as Ke } from "vue";
1
+ import { defineComponent as Me, defineAsyncComponent as Ne, ref as m, computed as y, toRef as I, openBlock as b, createBlock as $, normalizeClass as W, withCtx as r, renderSlot as p, unref as s, createVNode as F, createElementVNode as S, createElementBlock as M, Fragment as R, createCommentVNode as J, withDirectives as xe, isRef as He, withModifiers as c, withKeys as g, vModelDynamic as Pe, renderList as _e, mergeProps as Y, Teleport as ze, normalizeStyle as Qe, nextTick as Ke } from "vue";
2
2
  /* empty css */
3
3
  import { useId as Ue } from "./index7.js";
4
4
  import { useMobile as We } from "./index8.js";
5
5
  import Re from "./index122.js";
6
6
  /* empty css */
7
7
  import { isNotNil as Je } from "./index129.js";
8
- import { last as Ye } from "./index213.js";
9
- import { matchAnyKey as j } from "./index230.js";
10
- import { useFloating as je } from "./index208.js";
8
+ import { last as Ye } from "./index206.js";
9
+ import { matchAnyKey as j } from "./index235.js";
10
+ import { useFloating as je } from "./index228.js";
11
11
  import { useIntersectionObserver as Ge } from "./index127.js";
12
- import { useLogger as Xe } from "./index198.js";
13
- import { useOptions as Ze } from "./index199.js";
12
+ import { useLogger as Xe } from "./index207.js";
13
+ import { useOptions as Ze } from "./index221.js";
14
14
  import { wait as T } from "./index126.js";
15
- import { when as et } from "./index220.js";
16
- import tt from "./index231.js";
15
+ import { when as et } from "./index215.js";
16
+ import tt from "./index236.js";
17
17
  /* empty css */
18
- import ot from "./index233.js";
18
+ import ot from "./index238.js";
19
19
  /* empty css */
20
- import nt from "./index215.js";
20
+ import nt from "./index218.js";
21
21
  /* empty css */
22
- import lt from "./index217.js";
23
- import { waitFor as at } from "./index205.js";
24
- import { autoUpdate as it, flip as rt, offset as st, shift as ut } from "./index218.js";
22
+ import lt from "./index220.js";
23
+ import { waitFor as at } from "./index226.js";
24
+ import { autoUpdate as it, flip as rt, offset as st, shift as ut } from "./index233.js";
25
25
  const pt = { class: "bb-base-select__input-container" }, ct = ["id", "aria-controls", "aria-describedby", "aria-expanded", "autocomplete", "autofocus", "disabled", "inputmode", "placeholder", "readonly", "required", "onKeydown"], dt = /* @__PURE__ */ S("svg", {
26
26
  class: "bb-base-select__chevron",
27
27
  viewBox: "0 0 24 24",
@@ -74,7 +74,7 @@ const pt = { class: "bb-base-select__input-container" }, ct = ["id", "aria-contr
74
74
  const t = G, h = X;
75
75
  if (t.multiple && !Array.isArray(t.modelValue))
76
76
  throw new Error('Multiple is set to "true" but modelValue is not an array.');
77
- const Z = Ne(() => import("./index229.js")), A = m(null), B = m(null), a = m(null), N = m(null), x = m(null), u = y(
77
+ const Z = Ne(() => import("./index234.js")), A = m(null), B = m(null), a = m(null), N = m(null), x = m(null), u = y(
78
78
  () => t.comma ? N.value : x.value
79
79
  ), { isMobile: ee } = We(), te = y(
80
80
  () => t.allowWriting === "not-mobile" && ee.value ? "none" : void 0
@@ -242,53 +242,56 @@ const pt = { class: "bb-base-select__input-container" }, ct = ["id", "aria-contr
242
242
  }),
243
243
  onClick: Ee
244
244
  }, {
245
- "prepend-outer": s(() => [
246
- p(e.$slots, "prepend-outer", { query: r(l) })
245
+ "prepend-outer": r(() => [
246
+ p(e.$slots, "prepend-outer", { query: s(l) })
247
247
  ]),
248
- "append-outer": s(() => [
249
- p(e.$slots, "append-outer", { query: r(l) })
248
+ "append-outer": r(() => [
249
+ p(e.$slots, "append-outer", { query: s(l) })
250
250
  ]),
251
- default: s(() => [
251
+ default: r(() => [
252
252
  F(nt, {
253
253
  ref_key: "innerContainer",
254
254
  ref: B,
255
255
  "append:icon": t["append:icon"],
256
256
  "prepend:icon": t["prepend:icon"]
257
257
  }, {
258
- prepend: s(() => [
259
- p(e.$slots, "prepend", { query: r(l) })
258
+ prepend: r(() => [
259
+ p(e.$slots, "prepend", { query: s(l) })
260
260
  ]),
261
- prefix: s(() => [
261
+ prefix: r(() => [
262
262
  p(e.$slots, "prefix")
263
263
  ]),
264
- suffix: s(() => [
264
+ append: r(() => [
265
+ p(e.$slots, "append", { query: s(l) })
266
+ ]),
267
+ suffix: r(() => [
265
268
  p(e.$slots, "suffix")
266
269
  ]),
267
- default: s(() => [
268
- F(r(Re), { tag: "span" }, {
269
- default: s(() => [
270
+ default: r(() => [
271
+ F(s(Re), { tag: "span" }, {
272
+ default: r(() => [
270
273
  S("span", pt, [
271
274
  e.multiple ? (b(), M(R, { key: 0 }, [
272
275
  e.comma ? (b(), $(ot, {
273
276
  key: 0,
274
277
  ref_key: "commaBox",
275
278
  ref: N,
276
- options: r(v)
279
+ options: s(v)
277
280
  }, null, 8, ["options"])) : (b(), $(tt, {
278
281
  key: 1,
279
282
  ref_key: "chipsBox",
280
283
  ref: x,
281
- options: r(v),
284
+ options: s(v),
282
285
  "onOption:unselected": Q
283
286
  }, null, 8, ["options"]))
284
287
  ], 64)) : J("", !0),
285
288
  xe(S("input", {
286
- id: r(H),
289
+ id: s(H),
287
290
  ref_key: "input",
288
291
  ref: q,
289
292
  "onUpdate:modelValue": o[0] || (o[0] = (n) => He(l) ? l.value = n : null),
290
293
  "aria-autocomplete": "list",
291
- "aria-controls": `${r(H)}_listbox`,
294
+ "aria-controls": `${s(H)}_listbox`,
292
295
  "aria-describedby": e.ariaDescribedby,
293
296
  "aria-expanded": d.value,
294
297
  autocomplete: e.autocomplete,
@@ -316,19 +319,18 @@ const pt = { class: "bb-base-select__input-container" }, ct = ["id", "aria-contr
316
319
  g(c(de, ["stop"]), ["right"])
317
320
  ]
318
321
  }, null, 40, ct), [
319
- [Pe, r(l)]
322
+ [Pe, s(l)]
320
323
  ])
321
324
  ])
322
325
  ]),
323
326
  _: 1
324
327
  }),
325
328
  p(e.$slots, "chevron", {
326
- loading: !!r(P),
329
+ loading: !!s(P),
327
330
  shown: d.value
328
331
  }, () => [
329
332
  dt
330
- ]),
331
- p(e.$slots, "append", { query: r(l) })
333
+ ])
332
334
  ]),
333
335
  _: 3
334
336
  }, 8, ["append:icon", "prepend:icon"]),
@@ -340,7 +342,7 @@ const pt = { class: "bb-base-select__input-container" }, ct = ["id", "aria-contr
340
342
  key: 0,
341
343
  to: "body"
342
344
  }, [
343
- F(r(Z), {
345
+ F(s(Z), {
344
346
  ref_key: "optionsContainer",
345
347
  ref: a,
346
348
  loading: D.value,
@@ -350,19 +352,19 @@ const pt = { class: "bb-base-select__input-container" }, ct = ["id", "aria-contr
350
352
  "onOption:selected": z,
351
353
  "onOption:unselected": Q
352
354
  }, {
353
- "options:prepend": s(() => [
355
+ "options:prepend": r(() => [
354
356
  p(e.$slots, "options:prepend")
355
357
  ]),
356
- loading: s(() => [
357
- p(e.$slots, "loading", { query: r(l) })
358
+ loading: r(() => [
359
+ p(e.$slots, "loading", { query: s(l) })
358
360
  ]),
359
- "no-data": s(() => [
360
- p(e.$slots, "no-data", { query: r(l) })
361
+ "no-data": r(() => [
362
+ p(e.$slots, "no-data", { query: s(l) })
361
363
  ]),
362
- "options:append": s(() => [
364
+ "options:append": r(() => [
363
365
  p(e.$slots, "options:append")
364
366
  ]),
365
- option: s((n) => [
367
+ option: r((n) => [
366
368
  p(e.$slots, "option", Y({
367
369
  hasErrors: e.hasErrors,
368
370
  loading: D.value
@@ -1 +1 @@
1
- {"version":3,"file":"index34.js","sources":["../src/components/BaseSelect/BaseSelect.vue"],"sourcesContent":["<template>\n\t<CommonInputOuterContainer\n\t\tref=\"outerContainer\"\n\t\t:class=\"{\n\t\t\t'bb-base-select': true,\n\t\t\t'bb-base-select--active': active,\n\t\t\t'bb-base-select--shown': shown,\n\t\t\t'bb-base-select--loading': computedLoading,\n\t\t\t'bb-base-select--disabled': disabled,\n\t\t\t'bb-base-select--errors': hasErrors,\n\t\t\t'bb-base-select--readonly': readonly,\n\t\t}\"\n\t\t@click=\"onOuterContainerClick\"\n\t>\n\t\t<template #prepend-outer\n\t\t\t><slot name=\"prepend-outer\" :query=\"query\"></slot\n\t\t></template>\n\n\t\t<CommonInputInnerContainer\n\t\t\tref=\"innerContainer\"\n\t\t\t:append:icon=\"props['append:icon']\"\n\t\t\t:prepend:icon=\"props['prepend:icon']\"\n\t\t>\n\t\t\t<template #prepend><slot name=\"prepend\" :query=\"query\"></slot></template>\n\t\t\t<template #prefix><slot name=\"prefix\" /></template>\n\t\t\t<BbSmoothHeight tag=\"span\">\n\t\t\t\t<span class=\"bb-base-select__input-container\">\n\t\t\t\t\t<template v-if=\"multiple\">\n\t\t\t\t\t\t<template v-if=\"comma\">\n\t\t\t\t\t\t\t<CommaBox ref=\"commaBox\" :options=\"selectedOptions\" />\n\t\t\t\t\t\t</template>\n\t\t\t\t\t\t<template v-else>\n\t\t\t\t\t\t\t<ChipsBox\n\t\t\t\t\t\t\t\tref=\"chipsBox\"\n\t\t\t\t\t\t\t\t:options=\"selectedOptions\"\n\t\t\t\t\t\t\t\t@option:unselected=\"onOptionUnselected\"\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t</template>\n\t\t\t\t\t</template>\n\t\t\t\t\t<input\n\t\t\t\t\t\t:id=\"id\"\n\t\t\t\t\t\tref=\"input\"\n\t\t\t\t\t\tv-model=\"query\"\n\t\t\t\t\t\t:aria-autocomplete=\"'list'\"\n\t\t\t\t\t\t:aria-controls=\"`${id}_listbox`\"\n\t\t\t\t\t\t:aria-describedby=\"ariaDescribedby\"\n\t\t\t\t\t\t:aria-expanded=\"shown\"\n\t\t\t\t\t\t:autocomplete=\"autocomplete\"\n\t\t\t\t\t\t:autofocus=\"autofocus\"\n\t\t\t\t\t\t:class=\"'bb-base-select__text-input'\"\n\t\t\t\t\t\t:disabled=\"disabled\"\n\t\t\t\t\t\t:inputmode=\"inputmode\"\n\t\t\t\t\t\t:placeholder=\"computedPlaceholder\"\n\t\t\t\t\t\t:readonly=\"readonly || !allowWriting\"\n\t\t\t\t\t\t:required=\"\n\t\t\t\t\t\t\t(required && !multiple) || (multiple && !modelValue.length)\n\t\t\t\t\t\t\"\n\t\t\t\t\t\trole=\"combobox\"\n\t\t\t\t\t\t:type=\"'text'\"\n\t\t\t\t\t\t@blur.stop=\"onInputBlur\"\n\t\t\t\t\t\t@change.stop=\"onInputChange\"\n\t\t\t\t\t\t@focus.once.stop=\"onInputFirstFocus\"\n\t\t\t\t\t\t@focus.stop=\"onInputFocus\"\n\t\t\t\t\t\t@input.stop=\"onInputInput\"\n\t\t\t\t\t\t@keydown.stop.delete=\"onBackspace\"\n\t\t\t\t\t\t@keydown.stop.left=\"onArrowLeft\"\n\t\t\t\t\t\t@keydown.stop.prevent.down=\"onArrowDown\"\n\t\t\t\t\t\t@keydown.stop.prevent.enter=\"onEnter\"\n\t\t\t\t\t\t@keydown.stop.prevent.esc=\"onEscape\"\n\t\t\t\t\t\t@keydown.stop.prevent.up=\"onArrowUp\"\n\t\t\t\t\t\t@keydown.stop.right=\"onArrowRight\"\n\t\t\t\t\t/>\n\t\t\t\t</span>\n\t\t\t</BbSmoothHeight>\n\t\t\t<slot :loading=\"!!innerLoading\" name=\"chevron\" :shown=\"shown\">\n\t\t\t\t<svg\n\t\t\t\t\tclass=\"bb-base-select__chevron\"\n\t\t\t\t\tviewBox=\"0 0 24 24\"\n\t\t\t\t\txmlns=\"http://www.w3.org/2000/svg\"\n\t\t\t\t>\n\t\t\t\t\t<path\n\t\t\t\t\t\td=\"M7.41 8.58L12 13.17l4.59-4.59L18 10l-6 6l-6-6z\"\n\t\t\t\t\t\tfill=\"currentColor\"\n\t\t\t\t\t/>\n\t\t\t\t</svg>\n\t\t\t</slot>\n\t\t\t<slot name=\"append\" :query=\"query\"></slot>\n\t\t\t<template #suffix><slot name=\"suffix\" /></template>\n\t\t</CommonInputInnerContainer>\n\t\t<template #append-outer\n\t\t\t><slot name=\"append-outer\" :query=\"query\"></slot\n\t\t></template>\n\t\t<input v-for=\"input in hiddenInputs\" :key=\"input.value\" v-bind=\"input\" />\n\n\t\t<teleport v-if=\"renderListBox\" to=\"body\">\n\t\t\t<ListBox\n\t\t\t\tref=\"optionsContainer\"\n\t\t\t\t:loading=\"computedLoading\"\n\t\t\t\t:open=\"shown\"\n\t\t\t\t:options=\"filteredOptions\"\n\t\t\t\t:style=\"optionsContainerStyles\"\n\t\t\t\t@option:selected=\"onOptionSelected\"\n\t\t\t\t@option:unselected=\"onOptionUnselected\"\n\t\t\t>\n\t\t\t\t<template #options:prepend><slot name=\"options:prepend\" /></template>\n\t\t\t\t<template #loading><slot name=\"loading\" :query=\"query\" /></template>\n\t\t\t\t<template #no-data><slot name=\"no-data\" :query=\"query\" /></template>\n\t\t\t\t<template #options:append><slot name=\"options:append\" /></template>\n\t\t\t\t<template #option=\"data\"\n\t\t\t\t\t><slot\n\t\t\t\t\t\t:has-errors=\"hasErrors\"\n\t\t\t\t\t\t:loading=\"computedLoading\"\n\t\t\t\t\t\tname=\"option\"\n\t\t\t\t\t\tv-bind=\"data\"\n\t\t\t\t/></template>\n\t\t\t</ListBox>\n\t\t</teleport>\n\t</CommonInputOuterContainer>\n</template>\n\n<script setup lang=\"ts\">\nimport { BbSmoothHeight } from '@/index';\nimport { computed, ref, nextTick, defineAsyncComponent } from 'vue';\nimport { isNotNil } from '@/utilities/functions/isNotNil';\nimport { last } from '@/utilities/functions/last';\nimport { matchAnyKey } from '@/utilities/functions/matchAnyKey';\nimport { toRef } from 'vue';\nimport { useFloating, autoUpdate, flip, shift, offset } from '@floating-ui/vue';\nimport { useId } from '@/composables/useId';\nimport { useIntersectionObserver } from '@vueuse/core';\nimport { useLogger } from '@/composables/useLogger';\nimport { useMobile } from '@/composables/useMobile';\nimport { useOptions } from '@/composables/useOptions';\nimport { wait } from '@/utilities/functions/wait';\nimport { when } from '@/utilities/functions/when';\nimport ChipsBox from '../ChipsBox.vue';\nimport CommaBox from '../CommaBox.vue';\nimport CommonInputInnerContainer from '../CommonInputInnerContainer.vue';\nimport CommonInputOuterContainer from '../CommonInputOuterContainer.vue';\nimport type { HTMLAttributes, InputHTMLAttributes } from 'vue';\nimport type { Option as BaseOption } from '@/types/Option';\nimport { waitFor } from '@/utilities/functions/waitFor';\n\nexport type BaseSelectProps = {\n\t/**\n\t * Allows the user to add options to the list by\n\t * inserting text in the input and pressing ENTER.\n\t * The value and text of the option generated is a\n\t * string equal to what has been inserted.\n\t */\n\taddOptions?: boolean;\n\n\t/**\n\t * Allows typing into the input.\n\t */\n\tallowWriting?: boolean | 'not-mobile';\n\n\t/**\n\t * Name of the icon to be added at the end of the input.\n\t */\n\t// eslint-disable-next-line vue/prop-name-casing\n\t'append:icon'?: string;\n\n\t/**\n\t * Guides to the browser as to the type of information expected in the field.\n\t */\n\tariaDescribedby?: InputHTMLAttributes['aria-describedby'];\n\n\t/**\n\t * Guides to the browser as to the type of information expected in the field.\n\t */\n\tautocomplete?: InputHTMLAttributes['autocomplete'];\n\n\t/**\n\t * Sets autofocus on page load.\n\t */\n\tautofocus?: InputHTMLAttributes['autofocus'];\n\n\t/**\n\t * Sets the display model for selected values to a list\n\t * of comma separated string. In this mode the user\n\t * cannot deselect an option by pressing the close button.\n\t */\n\tcomma?: boolean;\n\n\t/**\n\t * Defines an array of dependencies that will trigger actions in the component upon change.\n\t */\n\tdependencies?: any[];\n\n\t/**\n\t * Timeout used to debounce response to changes to dependencies.\n\t */\n\tdepsDebounceTime?: number;\n\n\t/**\n\t * Disables the component\n\t */\n\tdisabled?: boolean;\n\n\t/**\n\t * If coherence is enforce the input cannot have a modelValue that is incoherent with its current items.\n\t *\n\t * e.g. You cannot set v-model to a user that is not present in the items passed.\n\t *\n\t * modelValue will be reset upon incoherence.\n\t */\n\tenforceCoherence?: boolean;\n\n\t/**\n\t * Defines how the filtering should work.\n\t * In any case options are always filtered by the text displayed but\n\t * they can also take into account other properties of the\n\t * passed elements when this property is a string or an array of string.\n\t * E.g. items could be a list of users and you can filter users by email or phone by passing `['email', 'phone']`\n\t * You can also pass false to not filter anything or a function for more granular control.\n\t *\n\t */\n\tfilterBy?:\n\t\t| string\n\t\t| string[]\n\t\t| false\n\t\t| ((value: any, item: any) => boolean)\n\t\t| null;\n\n\t/**\n\t * Define if the component should be in an error state.\n\t * It usually attaches a CSS class for styling purposes.\n\t */\n\thasErrors?: boolean;\n\n\t/**\n\t * The identifier of the component.\n\t */\n\tid?: HTMLAttributes['id'];\n\n\t/**\n\t * Used to retrieve items can be an array or a function.\n\t */\n\titems:\n\t\t| any[]\n\t\t| ((query: string, prefill: boolean, modelValue: any) => Promise<any[]>)\n\t\t| ((query: string, prefill: boolean, modelValue: any) => any[]);\n\n\t/**\n\t * Defines a path that returns a property of the object to use as text or a function that returns a string\n\t */\n\titemText?: string | ((item: any) => string) | undefined;\n\n\t/**\n\t * Defines a path that returns a property of the object to use as value or a function that returns any value\n\t */\n\titemValue?: string | ((item: any) => string) | undefined;\n\n\t/**\n\t * Sets the component in a loading state, usually triggering some visual styles.\n\t */\n\tloading?: boolean;\n\n\t/**\n\t * String displayed while items are being loaded.\n\t */\n\tloadingText?: string;\n\n\t/**\n\t * Used by v-model. Can be any serializable type.\n\t */\n\tmodelValue: any;\n\n\t/**\n\t * Timeout used to debounce response to changes to modelValue.\n\t */\n\tmodelValueDebounceTime?: number;\n\n\t/**\n\t * Allows the selection of multiple items.\n\t */\n\tmultiple?: boolean;\n\n\t/**\n\t * Defines the name of the input.\n\t */\n\tname?: InputHTMLAttributes['name'];\n\n\t/**\n\t * String displayed when there are no items to display.\n\t */\n\tnoDataText?: string;\n\n\t/**\n\t * String displayed when there's no data.\n\t */\n\tplaceholder?: InputHTMLAttributes['placeholder'];\n\n\t/**\n\t * Defines the prefill strategy for the input. By default the input will prefill\n\t * on focus. It can also always prefill with `true` and only prefill on search with `false`.\n\t */\n\tprefill?: boolean | 'focus';\n\n\t/**\n\t * Name of the icon to be added at the start of the input.\n\t */\n\t// eslint-disable-next-line vue/prop-name-casing\n\t'prepend:icon'?: string;\n\n\t/**\n\t * Time to wait when the users stops writing in the input before querying data.\n\t * Especially useful when searching live data on big datasets.\n\t */\n\tqueryDebounceTime?: number;\n\n\t/**\n\t * Sets the input in a readonly state.\n\t */\n\treadonly?: boolean;\n\n\t/**\n\t * Sets the input as required.\n\t */\n\trequired?: boolean;\n\n\t/**\n\t * If `true` when in multiple selection, reset the query immediately\n\t * upon selecting an option. By default the query is\n\t * not reset until focus is lost so the user can search\n\t * for \"Cath\" and select \"Cathy\" and then write more to\n\t * search for \"Catherine\"\n\t */\n\tresetQueryOnOptionSelected?: boolean;\n\n\t/**\n\t * Adds a stash to accumulate selected values. Especially\n\t * useful when searching in a big database of items.\n\t * E.g. if you search for \"John\" and then search for \"Richard\"\n\t * you either always return the previous items or you stash them passing `true` to this option.\n\t */\n\tstash?: boolean;\n\n\t/**\n\t * How long the transition has to last in milliseconds\n\t */\n\ttransitionDuration?: number;\n\n\t/**\n\t * Pass `true` if the dropdown is not updating following movement in the UI, like in modals. Very expensive so use with care.\n\t */\n\tupdateOnAnimationFrame?: boolean;\n};\nexport type BaseSelectEvents = {\n\t(e: 'blur', event: FocusEvent): void;\n\t(e: 'change', event: Event): void;\n\t(e: 'click', event: MouseEvent): void;\n\t(e: 'focus', event: FocusEvent): void;\n\t(e: 'inactive'): void;\n\t(e: 'input', event: Event): void;\n\t(e: 'update:modelValue', value: any): void;\n};\n\nexport type BaseSelectSlots = {\n\tappend?: (props: { query: string }) => any;\n\t'append-outer'?: (props: { query: string }) => any;\n\tchevron?: (props: { loading: boolean; shown: boolean }) => any;\n\tchip?: (props: {\n\t\tdisabled: boolean | undefined;\n\t\thasErrors?: boolean;\n\t\tindex: number;\n\t\titem: any;\n\t\tloading: boolean;\n\t\tmanual: boolean;\n\t\tselected: boolean | undefined;\n\t\ttext: string;\n\t\tvalue: any;\n\t}) => any;\n\tloading?: (props: { query: string }) => any;\n\t'no-data'?: (props: { query: string }) => any;\n\toption?: (props: {\n\t\tdisabled: boolean;\n\t\tfocused: boolean;\n\t\tindex: number;\n\t\thasErrors?: boolean;\n\t\titem: any;\n\t\tloading: boolean;\n\t\tselected: boolean;\n\t\ttext: string;\n\t\tvalue: any;\n\t}) => any;\n\t'option:append'?: (props: { item: any }) => any;\n\t'option:prepend'?: (props: { item: any }) => any;\n\t'options:append'?: (props: object) => any;\n\t'options:prepend'?: (props: object) => any;\n\tprefix?: (props: object) => any;\n\tprepend?: (props: { query: string }) => any;\n\t'prepend-outer'?: (props: { query: string }) => any;\n\tsuffix?: (props: object) => any;\n};\n\nconst props = withDefaults(defineProps<BaseSelectProps>(), {\n\tallowWriting: true,\n\tdepsDebounceTime: 0,\n\tdependencies: () => [],\n\tfilterBy: () => [],\n\tloadingText: 'Caricamento...',\n\tmodelValueDebounceTime: 0,\n\tnoDataText: 'Nessun elemento da visualizzare',\n\tprefill: 'focus',\n\tqueryDebounceTime: 500,\n\ttransitionDuration: 300,\n\tupdateOnAnimationFrame: false,\n});\n\nconst emit = defineEmits<BaseSelectEvents>();\n\ndefineSlots<BaseSelectSlots>();\n\nif (props.multiple && !Array.isArray(props.modelValue)) {\n\tthrow new Error('Multiple is set to \"true\" but modelValue is not an array.');\n}\n\n/**\n * START ELEMENT REFERENCES\n */\nconst ListBox = defineAsyncComponent(() => import('../ListBox.vue'));\nconst outerContainer = ref<InstanceType<\n\ttypeof CommonInputOuterContainer\n> | null>(null);\nconst innerContainer = ref<InstanceType<\n\ttypeof CommonInputInnerContainer\n> | null>(null);\nconst optionsContainer = ref<InstanceType<typeof ListBox> | null>(null);\nconst commaBox = ref<InstanceType<typeof CommaBox> | null>(null);\nconst chipsBox = ref<InstanceType<typeof ChipsBox> | null>(null);\nconst selectedBox = computed(() =>\n\tprops.comma ? commaBox.value : chipsBox.value\n);\n/**\n * END ELEMENT REFERENCES\n */\n\nconst { isMobile } = useMobile();\nconst inputmode = computed(() =>\n\tprops.allowWriting === 'not-mobile' && isMobile.value ? 'none' : undefined\n);\n\n// Always provide an id so that inputs can be focussed by clicking oin the label\nconst id = props.id || useId().id.value;\n\nuseIntersectionObserver(\n\tinnerContainer,\n\t([{ intersectionRatio }]) => {\n\t\tif (intersectionRatio !== 1) {\n\t\t\tclose();\n\t\t}\n\t},\n\t{ threshold: [0, 1] }\n);\n\nconst { floatingStyles } = useFloating(\n\tinnerContainer,\n\toptionsContainer as any,\n\t{\n\t\tplacement: 'bottom',\n\t\twhileElementsMounted: autoUpdate,\n\t\tmiddleware: [flip(), offset(5), shift()],\n\t}\n);\n\nconst optionsContainerStyles = computed(() => {\n\tconst base: Record<string, any> = {\n\t\t...floatingStyles.value,\n\t\tzIndex: '10',\n\t};\n\tif (innerContainer.value) {\n\t\tbase.width = `${innerContainer.value?.$el.clientWidth}px`;\n\t}\n\n\treturn base;\n});\n\n/**\n * START INPUT HANDLING\n */\nconst input = ref<HTMLElement | null>(null);\nconst focusInput = () => {\n\tif (input.value instanceof HTMLInputElement) {\n\t\tinput.value.focus();\n\t}\n};\n\n/**\n * When the focus goes to the input we select the current text\n * so the user can replace or delete it.\n * On top of that if the prefill strategy is to prefill on first focus and options\n * weren't already retrieved by the watcher on mount, we do that\n */\nconst onInputFocus = async (event: FocusEvent) => {\n\temit('focus', event);\n\tsetActive();\n\tdocument.addEventListener('click', onOutsideInteraction);\n\tdocument.addEventListener('focusin', onOutsideInteraction);\n};\n\nconst onInputFirstFocus = () => {\n\tif (props.prefill === 'focus' && !isPrefilling.value && !hasPrefilled.value) {\n\t\tprefillItems();\n\t}\n};\n\nconst onInputBlur = async (event: FocusEvent) => {\n\temit('blur', event);\n};\n\nconst onInputChange = (event: Event) => emit('change', event);\n\n/**\n * Search at every input by the user.\n * When the user deletes the query unselect the current option\n */\nconst onInputInput = (event: Event) => {\n\temit('input', event);\n\tif (query.value === '') {\n\t\tif (!props.multiple) {\n\t\t\tupdateModelValue(null);\n\t\t}\n\t}\n\tselectedBox.value?.blur();\n\tsearchByQuery();\n};\n\n/**\n * On click outside of the container close the panel, remove active state.\n * In multiple selection clear query after a timeout\n */\nconst onOutsideInteraction = async (event: Event) => {\n\tif (event.target instanceof Node) {\n\t\tif (outerContainer.value && optionsContainer.value) {\n\t\t\tif (\n\t\t\t\t!outerContainer.value.$el.contains(event.target) &&\n\t\t\t\t!optionsContainer.value.$el.contains(event.target)\n\t\t\t) {\n\t\t\t\tclose();\n\t\t\t\tsetInactive();\n\t\t\t\tdocument.removeEventListener('click', onOutsideInteraction);\n\t\t\t\tdocument.removeEventListener('focusin', onOutsideInteraction);\n\t\t\t\tawait wait(props.transitionDuration);\n\t\t\t\talignQueryToState();\n\t\t\t\treturn;\n\t\t\t}\n\t\t}\n\t}\n};\n\nconst canProcessKeyboardBindings = computed(() => {\n\tif (props.readonly) return false;\n\tif (props.disabled) return false;\n\tif (computedLoading.value) return false;\n\tif (!selectedBox.value && props.multiple) return false;\n\treturn true;\n});\n\n/**\n * On arrow prevent the page from scrolling.\n * Reset horizontal focus\n * When the panel is open\n * - Focus on the previous option\n * When the panel is closed\n * - focus on the first selected option\n */\nconst onArrowUp = async () => {\n\tif (!canProcessKeyboardBindings.value) {\n\t\treturn;\n\t}\n\t// Reset horizontal focus while moving vertically\n\tselectedBox.value?.blur();\n\tif (shown.value) {\n\t\toptionsContainer.value?.focusPrevious();\n\t} else {\n\t\tawait open();\n\t\tawait wait(props.transitionDuration);\n\t\toptionsContainer.value?.focusLastSelected();\n\t}\n};\n\nconst onArrowDown = async () => {\n\tif (!canProcessKeyboardBindings.value) {\n\t\treturn;\n\t}\n\t// Reset horizontal focus while moving vertically\n\tselectedBox.value?.blur();\n\tif (shown.value) {\n\t\toptionsContainer.value?.focusNext();\n\t} else {\n\t\tawait open();\n\t\tawait wait(props.transitionDuration);\n\t\toptionsContainer.value?.focusFirstSelected();\n\t}\n};\n\nconst onArrowLeft = (event: KeyboardEvent) => {\n\tif (!canProcessKeyboardBindings.value) {\n\t\treturn;\n\t}\n\tif (!props.multiple || query.value) {\n\t\treturn;\n\t}\n\tevent.preventDefault();\n\t// Reset vertical focus while moving horizontally\n\toptionsContainer.value?.blur();\n\tif (!selectedOptions.value.length) return;\n\tselectedBox.value?.focusPrevious();\n\tconst highlightedOption = selectedBox.value?.getHighlighted();\n\tif (highlightedOption) {\n\t\toptionsContainer.value?.focusByHash(highlightedOption.valueHash);\n\t}\n};\n\nconst onArrowRight = (event: KeyboardEvent) => {\n\tif (!canProcessKeyboardBindings.value) {\n\t\treturn;\n\t}\n\tif (!props.multiple || query.value) {\n\t\treturn;\n\t}\n\tevent.preventDefault();\n\t// Reset vertical focus while moving horizontally\n\toptionsContainer.value?.blur();\n\tif (!selectedOptions.value.length) return;\n\tselectedBox.value?.focusNext();\n\tconst highlightedOption = selectedBox.value?.getHighlighted();\n\tif (highlightedOption) {\n\t\toptionsContainer.value?.focusByHash(highlightedOption.valueHash);\n\t}\n};\n\nconst onEnter = async () => {\n\tif (!canProcessKeyboardBindings.value) {\n\t\treturn;\n\t}\n\tif (!shown.value) {\n\t\tawait open();\n\t\tawait wait(props.transitionDuration);\n\t\tif (selectedOptions.value.length) {\n\t\t\toptionsContainer.value?.focusFirstSelected();\n\t\t}\n\t} else if (optionsContainer.value?.getHighlighted()) {\n\t\toptionsContainer.value.confirmOption();\n\t} else if (props.addOptions) {\n\t\tif (props.itemText || props.itemValue) {\n\t\t\tconst { error } = useLogger();\n\t\t\terror(\n\t\t\t\t`Adding an option for mapped items is not supported. You can't create an option while passing \"item-text\" or \"item-value\".`\n\t\t\t);\n\t\t\treturn;\n\t\t}\n\t\tconst text = query.value.trim();\n\t\t// Do not add manual items that are already present\n\t\tif (valueIsSelected(text)) return;\n\t\taddCurrentQueryToManualItems();\n\t\tonOptionSelected(last(manualItems.value)!);\n\t}\n};\n\nconst onEscape = async () => {\n\tif (shown.value) {\n\t\tawait close();\n\t}\n};\n\n/**\n * Delete behavior is different when query is empty\n * If query is empty\n * If no chip is selected - select rightmost chip\n * If a chip is selected - deselect that option\n * If any option remains move focus to that or reset\n */\nconst onBackspace = async () => {\n\tif (\n\t\t!canProcessKeyboardBindings.value ||\n\t\tquery.value ||\n\t\t!selectedOptions.value.length\n\t) {\n\t\treturn;\n\t}\n\tif (selectedBox.value?.getHighlighted()) {\n\t\tselectedBox.value.confirmOption();\n\t}\n\tawait nextTick();\n\tselectedBox.value?.focusPrevious();\n};\n\n/**\n * It should prefill if asked, or\n * when single if modelValue is not null\n * when multiple if modelValue is not empty\n */\nconst shouldPrefill =\n\tprops.prefill === true ||\n\t(!props.multiple && isNotNil(props.modelValue)) ||\n\t(props.multiple && !!props.modelValue.length);\n\nconst {\n\tquery,\n\talignQueryToState,\n\taddCurrentQueryToManualItems,\n\tinnerLoading,\n\toptions,\n\tselectedOptions,\n\tselectOption,\n\tunselectOption,\n\tprefillItems,\n\tisPrefilling,\n\thasPrefilled,\n\tupdateModelValue,\n\tvalueIsSelected,\n\tmanualItems,\n\tsearchByQuery,\n} = useOptions({\n\temit,\n\titemText: props.itemText,\n\titemValue: props.itemValue,\n\tmodelValue: toRef(props, 'modelValue'),\n\tmultiple: props.multiple,\n\tresetQueryOnOptionSelected: props.resetQueryOnOptionSelected,\n\tstash: props.stash,\n\titems: toRef(props, 'items'),\n\tenforceCoherence: props.enforceCoherence,\n\tprefill: shouldPrefill,\n\tmodelValueDebounceTime: props.modelValueDebounceTime,\n\tdependencies: toRef(props, 'dependencies'),\n\tdepsDebounceTime: props.depsDebounceTime,\n\tqueryDebounceTime: props.queryDebounceTime,\n\tdisabled: toRef(props, 'disabled'),\n});\n\nconst computedPlaceholder = computed(() => {\n\tif (selectedOptions.value.length) return '';\n\telse return props.placeholder;\n});\n\nconst computedLoading = computed(() => !!(innerLoading.value || props.loading));\n\n/**\n * Filter options to be displayed based on the current query.\n * If no query is used or when query is set from the inside (after a selection) display all possible options\n */\nconst filteredOptions = computed<BaseOption[]>(() => {\n\tlet base = [];\n\t/** Only filter when a value is being searched not when the query is fully set on a selected option text */\n\tconst queryMatchesASelectedOption = selectedOptions.value.some(\n\t\t(option: BaseOption) => option.text === query.value\n\t);\n\tconst shouldFilter =\n\t\t(props.multiple && query.value) ||\n\t\t(query.value && !queryMatchesASelectedOption && !props.multiple);\n\n\tif (shouldFilter && props.filterBy) {\n\t\tbase = options.value.filter((item: BaseOption) => {\n\t\t\tlet matchedAnything = false;\n\t\t\tif (typeof props.filterBy === 'function')\n\t\t\t\tmatchedAnything = props.filterBy(item.value, item.item);\n\t\t\telse if (Array.isArray(props.filterBy) && props.filterBy.length) {\n\t\t\t\tmatchedAnything =\n\t\t\t\t\tmatchedAnything ||\n\t\t\t\t\tmatchAnyKey(item.item, props.filterBy, query.value.trim());\n\t\t\t}\n\t\t\treturn matchedAnything || matchAnyKey(item, ['text'], query.value.trim());\n\t\t});\n\t\t/** Otherwise default to the whole set of options */\n\t} else base = options.value;\n\n\t/** This is done here so that only visible options are highlighted */\n\treturn base;\n});\n\nconst onOptionSelected = (option: BaseOption) => {\n\tselectOption(option);\n\tfocusInput();\n\tif (!props.multiple) {\n\t\tclose();\n\t}\n};\n\nconst onOptionUnselected = (option: BaseOption) => {\n\tunselectOption(option);\n\tfocusInput();\n};\n\n/**\n * We need the transitions because elements must be hidden and shown\n * to accessibility tools when they are fully closed or fully open,\n * while still being animated for sighted users.\n */\n\n// Option panel is open\nconst shown = ref(false);\n// Option panel il closed\nconst hidden = ref(true);\n\nconst renderListBox = ref(false);\n\nconst open = async () => {\n\trenderListBox.value = true;\n\tawait waitFor(() => !!optionsContainer.value);\n\thidden.value = false;\n\tshown.value = true;\n};\n\nconst close = async () => {\n\tshown.value = false;\n\thidden.value = true;\n\tselectedBox.value?.blur();\n};\n\nconst toggle = () => {\n\tif (shown.value) return close();\n\treturn open();\n};\n\n/**\n * Applies a class when the user is inside this whole component.\n * We cannot use focus within as it doesn't work for elements that are teleported.\n * Also we cannot use the <input/> if we physically move focus to the options so\n * we track it manually.\n */\nconst active = ref(false);\n\nconst setActive = () => {\n\tactive.value = true;\n};\nconst setInactive = () => {\n\tactive.value = false;\n\temit('inactive');\n};\n\n/**\n * When clicking on the outside container seamlessly move focus to the input and open the panel\n */\nconst onOuterContainerClick = (event: MouseEvent) => {\n\tevent.preventDefault();\n\temit('click', event);\n\tif (props.disabled || props.readonly) return;\n\tfocusInput();\n\ttoggle();\n};\n\n/**\n * When using this component for submission we add a bunch of hidden\n * inputs so the submitted inputs are on par with v-model\n */\n/**\n * This is used to keep the value compatible to common html expected values.\n * Convert to string everything that's not but do not double encode strings\n */\nconst makeInputValue = when(\n\t(item: unknown) => typeof item !== 'string',\n\tJSON.stringify\n);\n\nconst hiddenInputs = computed(() => {\n\treturn [].concat(props.modelValue).map((current) => {\n\t\tconst value = makeInputValue(current);\n\t\treturn {\n\t\t\tdisabled: props.disabled,\n\t\t\tname: props.name,\n\t\t\ttype: 'hidden',\n\t\t\tvalue: value,\n\t\t};\n\t});\n});\n</script>\n<style lang=\"postcss\">\n@import '@/assets/css/BaseSelect';\n</style>\n"],"names":["props","__props","emit","__emit","ListBox","defineAsyncComponent","outerContainer","ref","innerContainer","optionsContainer","commaBox","chipsBox","selectedBox","computed","isMobile","useMobile","inputmode","id","useId","useIntersectionObserver","intersectionRatio","close","floatingStyles","useFloating","autoUpdate","flip","offset","shift","optionsContainerStyles","base","_a","input","focusInput","onInputFocus","event","setActive","onOutsideInteraction","onInputFirstFocus","isPrefilling","hasPrefilled","prefillItems","onInputBlur","onInputChange","onInputInput","query","updateModelValue","searchByQuery","setInactive","wait","alignQueryToState","canProcessKeyboardBindings","computedLoading","onArrowUp","shown","_b","open","_c","onArrowDown","onArrowLeft","selectedOptions","highlightedOption","_d","onArrowRight","onEnter","error","useLogger","text","valueIsSelected","addCurrentQueryToManualItems","onOptionSelected","last","manualItems","onEscape","onBackspace","nextTick","shouldPrefill","isNotNil","innerLoading","options","selectOption","unselectOption","useOptions","toRef","computedPlaceholder","filteredOptions","queryMatchesASelectedOption","option","item","matchedAnything","matchAnyKey","onOptionUnselected","hidden","renderListBox","waitFor","toggle","active","onOuterContainerClick","makeInputValue","when","hiddenInputs","current","value"],"mappings":"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"}
1
+ {"version":3,"file":"index34.js","sources":["../src/components/BaseSelect/BaseSelect.vue"],"sourcesContent":["<template>\n\t<CommonInputOuterContainer\n\t\tref=\"outerContainer\"\n\t\t:class=\"{\n\t\t\t'bb-base-select': true,\n\t\t\t'bb-base-select--active': active,\n\t\t\t'bb-base-select--shown': shown,\n\t\t\t'bb-base-select--loading': computedLoading,\n\t\t\t'bb-base-select--disabled': disabled,\n\t\t\t'bb-base-select--errors': hasErrors,\n\t\t\t'bb-base-select--readonly': readonly,\n\t\t}\"\n\t\t@click=\"onOuterContainerClick\"\n\t>\n\t\t<template #prepend-outer\n\t\t\t><slot name=\"prepend-outer\" :query=\"query\"></slot\n\t\t></template>\n\n\t\t<CommonInputInnerContainer\n\t\t\tref=\"innerContainer\"\n\t\t\t:append:icon=\"props['append:icon']\"\n\t\t\t:prepend:icon=\"props['prepend:icon']\"\n\t\t>\n\t\t\t<template #prepend><slot name=\"prepend\" :query=\"query\"></slot></template>\n\t\t\t<template #prefix><slot name=\"prefix\" /></template>\n\t\t\t<BbSmoothHeight tag=\"span\">\n\t\t\t\t<span class=\"bb-base-select__input-container\">\n\t\t\t\t\t<template v-if=\"multiple\">\n\t\t\t\t\t\t<template v-if=\"comma\">\n\t\t\t\t\t\t\t<CommaBox ref=\"commaBox\" :options=\"selectedOptions\" />\n\t\t\t\t\t\t</template>\n\t\t\t\t\t\t<template v-else>\n\t\t\t\t\t\t\t<ChipsBox\n\t\t\t\t\t\t\t\tref=\"chipsBox\"\n\t\t\t\t\t\t\t\t:options=\"selectedOptions\"\n\t\t\t\t\t\t\t\t@option:unselected=\"onOptionUnselected\"\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t</template>\n\t\t\t\t\t</template>\n\t\t\t\t\t<input\n\t\t\t\t\t\t:id=\"id\"\n\t\t\t\t\t\tref=\"input\"\n\t\t\t\t\t\tv-model=\"query\"\n\t\t\t\t\t\t:aria-autocomplete=\"'list'\"\n\t\t\t\t\t\t:aria-controls=\"`${id}_listbox`\"\n\t\t\t\t\t\t:aria-describedby=\"ariaDescribedby\"\n\t\t\t\t\t\t:aria-expanded=\"shown\"\n\t\t\t\t\t\t:autocomplete=\"autocomplete\"\n\t\t\t\t\t\t:autofocus=\"autofocus\"\n\t\t\t\t\t\t:class=\"'bb-base-select__text-input'\"\n\t\t\t\t\t\t:disabled=\"disabled\"\n\t\t\t\t\t\t:inputmode=\"inputmode\"\n\t\t\t\t\t\t:placeholder=\"computedPlaceholder\"\n\t\t\t\t\t\t:readonly=\"readonly || !allowWriting\"\n\t\t\t\t\t\t:required=\"\n\t\t\t\t\t\t\t(required && !multiple) || (multiple && !modelValue.length)\n\t\t\t\t\t\t\"\n\t\t\t\t\t\trole=\"combobox\"\n\t\t\t\t\t\t:type=\"'text'\"\n\t\t\t\t\t\t@blur.stop=\"onInputBlur\"\n\t\t\t\t\t\t@change.stop=\"onInputChange\"\n\t\t\t\t\t\t@focus.once.stop=\"onInputFirstFocus\"\n\t\t\t\t\t\t@focus.stop=\"onInputFocus\"\n\t\t\t\t\t\t@input.stop=\"onInputInput\"\n\t\t\t\t\t\t@keydown.stop.delete=\"onBackspace\"\n\t\t\t\t\t\t@keydown.stop.left=\"onArrowLeft\"\n\t\t\t\t\t\t@keydown.stop.prevent.down=\"onArrowDown\"\n\t\t\t\t\t\t@keydown.stop.prevent.enter=\"onEnter\"\n\t\t\t\t\t\t@keydown.stop.prevent.esc=\"onEscape\"\n\t\t\t\t\t\t@keydown.stop.prevent.up=\"onArrowUp\"\n\t\t\t\t\t\t@keydown.stop.right=\"onArrowRight\"\n\t\t\t\t\t/>\n\t\t\t\t</span>\n\t\t\t</BbSmoothHeight>\n\t\t\t<slot :loading=\"!!innerLoading\" name=\"chevron\" :shown=\"shown\">\n\t\t\t\t<svg\n\t\t\t\t\tclass=\"bb-base-select__chevron\"\n\t\t\t\t\tviewBox=\"0 0 24 24\"\n\t\t\t\t\txmlns=\"http://www.w3.org/2000/svg\"\n\t\t\t\t>\n\t\t\t\t\t<path\n\t\t\t\t\t\td=\"M7.41 8.58L12 13.17l4.59-4.59L18 10l-6 6l-6-6z\"\n\t\t\t\t\t\tfill=\"currentColor\"\n\t\t\t\t\t/>\n\t\t\t\t</svg>\n\t\t\t</slot>\n\t\t\t<template #append><slot name=\"append\" :query=\"query\"></slot></template>\n\n\t\t\t<template #suffix><slot name=\"suffix\" /></template>\n\t\t</CommonInputInnerContainer>\n\t\t<template #append-outer\n\t\t\t><slot name=\"append-outer\" :query=\"query\"></slot\n\t\t></template>\n\t\t<input v-for=\"input in hiddenInputs\" :key=\"input.value\" v-bind=\"input\" />\n\n\t\t<teleport v-if=\"renderListBox\" to=\"body\">\n\t\t\t<ListBox\n\t\t\t\tref=\"optionsContainer\"\n\t\t\t\t:loading=\"computedLoading\"\n\t\t\t\t:open=\"shown\"\n\t\t\t\t:options=\"filteredOptions\"\n\t\t\t\t:style=\"optionsContainerStyles\"\n\t\t\t\t@option:selected=\"onOptionSelected\"\n\t\t\t\t@option:unselected=\"onOptionUnselected\"\n\t\t\t>\n\t\t\t\t<template #options:prepend><slot name=\"options:prepend\" /></template>\n\t\t\t\t<template #loading><slot name=\"loading\" :query=\"query\" /></template>\n\t\t\t\t<template #no-data><slot name=\"no-data\" :query=\"query\" /></template>\n\t\t\t\t<template #options:append><slot name=\"options:append\" /></template>\n\t\t\t\t<template #option=\"data\"\n\t\t\t\t\t><slot\n\t\t\t\t\t\t:has-errors=\"hasErrors\"\n\t\t\t\t\t\t:loading=\"computedLoading\"\n\t\t\t\t\t\tname=\"option\"\n\t\t\t\t\t\tv-bind=\"data\"\n\t\t\t\t/></template>\n\t\t\t</ListBox>\n\t\t</teleport>\n\t</CommonInputOuterContainer>\n</template>\n\n<script setup lang=\"ts\">\nimport { BbSmoothHeight } from '@/index';\nimport { computed, ref, nextTick, defineAsyncComponent } from 'vue';\nimport { isNotNil } from '@/utilities/functions/isNotNil';\nimport { last } from '@/utilities/functions/last';\nimport { matchAnyKey } from '@/utilities/functions/matchAnyKey';\nimport { toRef } from 'vue';\nimport { useFloating, autoUpdate, flip, shift, offset } from '@floating-ui/vue';\nimport { useId } from '@/composables/useId';\nimport { useIntersectionObserver } from '@vueuse/core';\nimport { useLogger } from '@/composables/useLogger';\nimport { useMobile } from '@/composables/useMobile';\nimport { useOptions } from '@/composables/useOptions';\nimport { wait } from '@/utilities/functions/wait';\nimport { when } from '@/utilities/functions/when';\nimport ChipsBox from '../ChipsBox.vue';\nimport CommaBox from '../CommaBox.vue';\nimport CommonInputInnerContainer from '../CommonInputInnerContainer.vue';\nimport CommonInputOuterContainer from '../CommonInputOuterContainer.vue';\nimport type { HTMLAttributes, InputHTMLAttributes } from 'vue';\nimport type { Option as BaseOption } from '@/types/Option';\nimport { waitFor } from '@/utilities/functions/waitFor';\n\nexport type BaseSelectProps = {\n\t/**\n\t * Allows the user to add options to the list by\n\t * inserting text in the input and pressing ENTER.\n\t * The value and text of the option generated is a\n\t * string equal to what has been inserted.\n\t */\n\taddOptions?: boolean;\n\n\t/**\n\t * Allows typing into the input.\n\t */\n\tallowWriting?: boolean | 'not-mobile';\n\n\t/**\n\t * Name of the icon to be added at the end of the input.\n\t */\n\t// eslint-disable-next-line vue/prop-name-casing\n\t'append:icon'?: string;\n\n\t/**\n\t * Guides to the browser as to the type of information expected in the field.\n\t */\n\tariaDescribedby?: InputHTMLAttributes['aria-describedby'];\n\n\t/**\n\t * Guides to the browser as to the type of information expected in the field.\n\t */\n\tautocomplete?: InputHTMLAttributes['autocomplete'];\n\n\t/**\n\t * Sets autofocus on page load.\n\t */\n\tautofocus?: InputHTMLAttributes['autofocus'];\n\n\t/**\n\t * Sets the display model for selected values to a list\n\t * of comma separated string. In this mode the user\n\t * cannot deselect an option by pressing the close button.\n\t */\n\tcomma?: boolean;\n\n\t/**\n\t * Defines an array of dependencies that will trigger actions in the component upon change.\n\t */\n\tdependencies?: any[];\n\n\t/**\n\t * Timeout used to debounce response to changes to dependencies.\n\t */\n\tdepsDebounceTime?: number;\n\n\t/**\n\t * Disables the component\n\t */\n\tdisabled?: boolean;\n\n\t/**\n\t * If coherence is enforce the input cannot have a modelValue that is incoherent with its current items.\n\t *\n\t * e.g. You cannot set v-model to a user that is not present in the items passed.\n\t *\n\t * modelValue will be reset upon incoherence.\n\t */\n\tenforceCoherence?: boolean;\n\n\t/**\n\t * Defines how the filtering should work.\n\t * In any case options are always filtered by the text displayed but\n\t * they can also take into account other properties of the\n\t * passed elements when this property is a string or an array of string.\n\t * E.g. items could be a list of users and you can filter users by email or phone by passing `['email', 'phone']`\n\t * You can also pass false to not filter anything or a function for more granular control.\n\t *\n\t */\n\tfilterBy?:\n\t\t| string\n\t\t| string[]\n\t\t| false\n\t\t| ((value: any, item: any) => boolean)\n\t\t| null;\n\n\t/**\n\t * Define if the component should be in an error state.\n\t * It usually attaches a CSS class for styling purposes.\n\t */\n\thasErrors?: boolean;\n\n\t/**\n\t * The identifier of the component.\n\t */\n\tid?: HTMLAttributes['id'];\n\n\t/**\n\t * Used to retrieve items can be an array or a function.\n\t */\n\titems:\n\t\t| any[]\n\t\t| ((query: string, prefill: boolean, modelValue: any) => Promise<any[]>)\n\t\t| ((query: string, prefill: boolean, modelValue: any) => any[]);\n\n\t/**\n\t * Defines a path that returns a property of the object to use as text or a function that returns a string\n\t */\n\titemText?: string | ((item: any) => string) | undefined;\n\n\t/**\n\t * Defines a path that returns a property of the object to use as value or a function that returns any value\n\t */\n\titemValue?: string | ((item: any) => string) | undefined;\n\n\t/**\n\t * Sets the component in a loading state, usually triggering some visual styles.\n\t */\n\tloading?: boolean;\n\n\t/**\n\t * String displayed while items are being loaded.\n\t */\n\tloadingText?: string;\n\n\t/**\n\t * Used by v-model. Can be any serializable type.\n\t */\n\tmodelValue: any;\n\n\t/**\n\t * Timeout used to debounce response to changes to modelValue.\n\t */\n\tmodelValueDebounceTime?: number;\n\n\t/**\n\t * Allows the selection of multiple items.\n\t */\n\tmultiple?: boolean;\n\n\t/**\n\t * Defines the name of the input.\n\t */\n\tname?: InputHTMLAttributes['name'];\n\n\t/**\n\t * String displayed when there are no items to display.\n\t */\n\tnoDataText?: string;\n\n\t/**\n\t * String displayed when there's no data.\n\t */\n\tplaceholder?: InputHTMLAttributes['placeholder'];\n\n\t/**\n\t * Defines the prefill strategy for the input. By default the input will prefill\n\t * on focus. It can also always prefill with `true` and only prefill on search with `false`.\n\t */\n\tprefill?: boolean | 'focus';\n\n\t/**\n\t * Name of the icon to be added at the start of the input.\n\t */\n\t// eslint-disable-next-line vue/prop-name-casing\n\t'prepend:icon'?: string;\n\n\t/**\n\t * Time to wait when the users stops writing in the input before querying data.\n\t * Especially useful when searching live data on big datasets.\n\t */\n\tqueryDebounceTime?: number;\n\n\t/**\n\t * Sets the input in a readonly state.\n\t */\n\treadonly?: boolean;\n\n\t/**\n\t * Sets the input as required.\n\t */\n\trequired?: boolean;\n\n\t/**\n\t * If `true` when in multiple selection, reset the query immediately\n\t * upon selecting an option. By default the query is\n\t * not reset until focus is lost so the user can search\n\t * for \"Cath\" and select \"Cathy\" and then write more to\n\t * search for \"Catherine\"\n\t */\n\tresetQueryOnOptionSelected?: boolean;\n\n\t/**\n\t * Adds a stash to accumulate selected values. Especially\n\t * useful when searching in a big database of items.\n\t * E.g. if you search for \"John\" and then search for \"Richard\"\n\t * you either always return the previous items or you stash them passing `true` to this option.\n\t */\n\tstash?: boolean;\n\n\t/**\n\t * How long the transition has to last in milliseconds\n\t */\n\ttransitionDuration?: number;\n\n\t/**\n\t * Pass `true` if the dropdown is not updating following movement in the UI, like in modals. Very expensive so use with care.\n\t */\n\tupdateOnAnimationFrame?: boolean;\n};\nexport type BaseSelectEvents = {\n\t(e: 'blur', event: FocusEvent): void;\n\t(e: 'change', event: Event): void;\n\t(e: 'click', event: MouseEvent): void;\n\t(e: 'focus', event: FocusEvent): void;\n\t(e: 'inactive'): void;\n\t(e: 'input', event: Event): void;\n\t(e: 'update:modelValue', value: any): void;\n};\n\nexport type BaseSelectSlots = {\n\tappend?: (props: { query: string }) => any;\n\t'append-outer'?: (props: { query: string }) => any;\n\tchevron?: (props: { loading: boolean; shown: boolean }) => any;\n\tchip?: (props: {\n\t\tdisabled: boolean | undefined;\n\t\thasErrors?: boolean;\n\t\tindex: number;\n\t\titem: any;\n\t\tloading: boolean;\n\t\tmanual: boolean;\n\t\tselected: boolean | undefined;\n\t\ttext: string;\n\t\tvalue: any;\n\t}) => any;\n\tloading?: (props: { query: string }) => any;\n\t'no-data'?: (props: { query: string }) => any;\n\toption?: (props: {\n\t\tdisabled: boolean;\n\t\tfocused: boolean;\n\t\tindex: number;\n\t\thasErrors?: boolean;\n\t\titem: any;\n\t\tloading: boolean;\n\t\tselected: boolean;\n\t\ttext: string;\n\t\tvalue: any;\n\t}) => any;\n\t'option:append'?: (props: { item: any }) => any;\n\t'option:prepend'?: (props: { item: any }) => any;\n\t'options:append'?: (props: object) => any;\n\t'options:prepend'?: (props: object) => any;\n\tprefix?: (props: object) => any;\n\tprepend?: (props: { query: string }) => any;\n\t'prepend-outer'?: (props: { query: string }) => any;\n\tsuffix?: (props: object) => any;\n};\n\nconst props = withDefaults(defineProps<BaseSelectProps>(), {\n\tallowWriting: true,\n\tdepsDebounceTime: 0,\n\tdependencies: () => [],\n\tfilterBy: () => [],\n\tloadingText: 'Caricamento...',\n\tmodelValueDebounceTime: 0,\n\tnoDataText: 'Nessun elemento da visualizzare',\n\tprefill: 'focus',\n\tqueryDebounceTime: 500,\n\ttransitionDuration: 300,\n\tupdateOnAnimationFrame: false,\n});\n\nconst emit = defineEmits<BaseSelectEvents>();\n\ndefineSlots<BaseSelectSlots>();\n\nif (props.multiple && !Array.isArray(props.modelValue)) {\n\tthrow new Error('Multiple is set to \"true\" but modelValue is not an array.');\n}\n\n/**\n * START ELEMENT REFERENCES\n */\nconst ListBox = defineAsyncComponent(() => import('../ListBox.vue'));\nconst outerContainer = ref<InstanceType<\n\ttypeof CommonInputOuterContainer\n> | null>(null);\nconst innerContainer = ref<InstanceType<\n\ttypeof CommonInputInnerContainer\n> | null>(null);\nconst optionsContainer = ref<InstanceType<typeof ListBox> | null>(null);\nconst commaBox = ref<InstanceType<typeof CommaBox> | null>(null);\nconst chipsBox = ref<InstanceType<typeof ChipsBox> | null>(null);\nconst selectedBox = computed(() =>\n\tprops.comma ? commaBox.value : chipsBox.value\n);\n/**\n * END ELEMENT REFERENCES\n */\n\nconst { isMobile } = useMobile();\nconst inputmode = computed(() =>\n\tprops.allowWriting === 'not-mobile' && isMobile.value ? 'none' : undefined\n);\n\n// Always provide an id so that inputs can be focussed by clicking oin the label\nconst id = props.id || useId().id.value;\n\nuseIntersectionObserver(\n\tinnerContainer,\n\t([{ intersectionRatio }]) => {\n\t\tif (intersectionRatio !== 1) {\n\t\t\tclose();\n\t\t}\n\t},\n\t{ threshold: [0, 1] }\n);\n\nconst { floatingStyles } = useFloating(\n\tinnerContainer,\n\toptionsContainer as any,\n\t{\n\t\tplacement: 'bottom',\n\t\twhileElementsMounted: autoUpdate,\n\t\tmiddleware: [flip(), offset(5), shift()],\n\t}\n);\n\nconst optionsContainerStyles = computed(() => {\n\tconst base: Record<string, any> = {\n\t\t...floatingStyles.value,\n\t\tzIndex: '10',\n\t};\n\tif (innerContainer.value) {\n\t\tbase.width = `${innerContainer.value?.$el.clientWidth}px`;\n\t}\n\n\treturn base;\n});\n\n/**\n * START INPUT HANDLING\n */\nconst input = ref<HTMLElement | null>(null);\nconst focusInput = () => {\n\tif (input.value instanceof HTMLInputElement) {\n\t\tinput.value.focus();\n\t}\n};\n\n/**\n * When the focus goes to the input we select the current text\n * so the user can replace or delete it.\n * On top of that if the prefill strategy is to prefill on first focus and options\n * weren't already retrieved by the watcher on mount, we do that\n */\nconst onInputFocus = async (event: FocusEvent) => {\n\temit('focus', event);\n\tsetActive();\n\tdocument.addEventListener('click', onOutsideInteraction);\n\tdocument.addEventListener('focusin', onOutsideInteraction);\n};\n\nconst onInputFirstFocus = () => {\n\tif (props.prefill === 'focus' && !isPrefilling.value && !hasPrefilled.value) {\n\t\tprefillItems();\n\t}\n};\n\nconst onInputBlur = async (event: FocusEvent) => {\n\temit('blur', event);\n};\n\nconst onInputChange = (event: Event) => emit('change', event);\n\n/**\n * Search at every input by the user.\n * When the user deletes the query unselect the current option\n */\nconst onInputInput = (event: Event) => {\n\temit('input', event);\n\tif (query.value === '') {\n\t\tif (!props.multiple) {\n\t\t\tupdateModelValue(null);\n\t\t}\n\t}\n\tselectedBox.value?.blur();\n\tsearchByQuery();\n};\n\n/**\n * On click outside of the container close the panel, remove active state.\n * In multiple selection clear query after a timeout\n */\nconst onOutsideInteraction = async (event: Event) => {\n\tif (event.target instanceof Node) {\n\t\tif (outerContainer.value && optionsContainer.value) {\n\t\t\tif (\n\t\t\t\t!outerContainer.value.$el.contains(event.target) &&\n\t\t\t\t!optionsContainer.value.$el.contains(event.target)\n\t\t\t) {\n\t\t\t\tclose();\n\t\t\t\tsetInactive();\n\t\t\t\tdocument.removeEventListener('click', onOutsideInteraction);\n\t\t\t\tdocument.removeEventListener('focusin', onOutsideInteraction);\n\t\t\t\tawait wait(props.transitionDuration);\n\t\t\t\talignQueryToState();\n\t\t\t\treturn;\n\t\t\t}\n\t\t}\n\t}\n};\n\nconst canProcessKeyboardBindings = computed(() => {\n\tif (props.readonly) return false;\n\tif (props.disabled) return false;\n\tif (computedLoading.value) return false;\n\tif (!selectedBox.value && props.multiple) return false;\n\treturn true;\n});\n\n/**\n * On arrow prevent the page from scrolling.\n * Reset horizontal focus\n * When the panel is open\n * - Focus on the previous option\n * When the panel is closed\n * - focus on the first selected option\n */\nconst onArrowUp = async () => {\n\tif (!canProcessKeyboardBindings.value) {\n\t\treturn;\n\t}\n\t// Reset horizontal focus while moving vertically\n\tselectedBox.value?.blur();\n\tif (shown.value) {\n\t\toptionsContainer.value?.focusPrevious();\n\t} else {\n\t\tawait open();\n\t\tawait wait(props.transitionDuration);\n\t\toptionsContainer.value?.focusLastSelected();\n\t}\n};\n\nconst onArrowDown = async () => {\n\tif (!canProcessKeyboardBindings.value) {\n\t\treturn;\n\t}\n\t// Reset horizontal focus while moving vertically\n\tselectedBox.value?.blur();\n\tif (shown.value) {\n\t\toptionsContainer.value?.focusNext();\n\t} else {\n\t\tawait open();\n\t\tawait wait(props.transitionDuration);\n\t\toptionsContainer.value?.focusFirstSelected();\n\t}\n};\n\nconst onArrowLeft = (event: KeyboardEvent) => {\n\tif (!canProcessKeyboardBindings.value) {\n\t\treturn;\n\t}\n\tif (!props.multiple || query.value) {\n\t\treturn;\n\t}\n\tevent.preventDefault();\n\t// Reset vertical focus while moving horizontally\n\toptionsContainer.value?.blur();\n\tif (!selectedOptions.value.length) return;\n\tselectedBox.value?.focusPrevious();\n\tconst highlightedOption = selectedBox.value?.getHighlighted();\n\tif (highlightedOption) {\n\t\toptionsContainer.value?.focusByHash(highlightedOption.valueHash);\n\t}\n};\n\nconst onArrowRight = (event: KeyboardEvent) => {\n\tif (!canProcessKeyboardBindings.value) {\n\t\treturn;\n\t}\n\tif (!props.multiple || query.value) {\n\t\treturn;\n\t}\n\tevent.preventDefault();\n\t// Reset vertical focus while moving horizontally\n\toptionsContainer.value?.blur();\n\tif (!selectedOptions.value.length) return;\n\tselectedBox.value?.focusNext();\n\tconst highlightedOption = selectedBox.value?.getHighlighted();\n\tif (highlightedOption) {\n\t\toptionsContainer.value?.focusByHash(highlightedOption.valueHash);\n\t}\n};\n\nconst onEnter = async () => {\n\tif (!canProcessKeyboardBindings.value) {\n\t\treturn;\n\t}\n\tif (!shown.value) {\n\t\tawait open();\n\t\tawait wait(props.transitionDuration);\n\t\tif (selectedOptions.value.length) {\n\t\t\toptionsContainer.value?.focusFirstSelected();\n\t\t}\n\t} else if (optionsContainer.value?.getHighlighted()) {\n\t\toptionsContainer.value.confirmOption();\n\t} else if (props.addOptions) {\n\t\tif (props.itemText || props.itemValue) {\n\t\t\tconst { error } = useLogger();\n\t\t\terror(\n\t\t\t\t`Adding an option for mapped items is not supported. You can't create an option while passing \"item-text\" or \"item-value\".`\n\t\t\t);\n\t\t\treturn;\n\t\t}\n\t\tconst text = query.value.trim();\n\t\t// Do not add manual items that are already present\n\t\tif (valueIsSelected(text)) return;\n\t\taddCurrentQueryToManualItems();\n\t\tonOptionSelected(last(manualItems.value)!);\n\t}\n};\n\nconst onEscape = async () => {\n\tif (shown.value) {\n\t\tawait close();\n\t}\n};\n\n/**\n * Delete behavior is different when query is empty\n * If query is empty\n * If no chip is selected - select rightmost chip\n * If a chip is selected - deselect that option\n * If any option remains move focus to that or reset\n */\nconst onBackspace = async () => {\n\tif (\n\t\t!canProcessKeyboardBindings.value ||\n\t\tquery.value ||\n\t\t!selectedOptions.value.length\n\t) {\n\t\treturn;\n\t}\n\tif (selectedBox.value?.getHighlighted()) {\n\t\tselectedBox.value.confirmOption();\n\t}\n\tawait nextTick();\n\tselectedBox.value?.focusPrevious();\n};\n\n/**\n * It should prefill if asked, or\n * when single if modelValue is not null\n * when multiple if modelValue is not empty\n */\nconst shouldPrefill =\n\tprops.prefill === true ||\n\t(!props.multiple && isNotNil(props.modelValue)) ||\n\t(props.multiple && !!props.modelValue.length);\n\nconst {\n\tquery,\n\talignQueryToState,\n\taddCurrentQueryToManualItems,\n\tinnerLoading,\n\toptions,\n\tselectedOptions,\n\tselectOption,\n\tunselectOption,\n\tprefillItems,\n\tisPrefilling,\n\thasPrefilled,\n\tupdateModelValue,\n\tvalueIsSelected,\n\tmanualItems,\n\tsearchByQuery,\n} = useOptions({\n\temit,\n\titemText: props.itemText,\n\titemValue: props.itemValue,\n\tmodelValue: toRef(props, 'modelValue'),\n\tmultiple: props.multiple,\n\tresetQueryOnOptionSelected: props.resetQueryOnOptionSelected,\n\tstash: props.stash,\n\titems: toRef(props, 'items'),\n\tenforceCoherence: props.enforceCoherence,\n\tprefill: shouldPrefill,\n\tmodelValueDebounceTime: props.modelValueDebounceTime,\n\tdependencies: toRef(props, 'dependencies'),\n\tdepsDebounceTime: props.depsDebounceTime,\n\tqueryDebounceTime: props.queryDebounceTime,\n\tdisabled: toRef(props, 'disabled'),\n});\n\nconst computedPlaceholder = computed(() => {\n\tif (selectedOptions.value.length) return '';\n\telse return props.placeholder;\n});\n\nconst computedLoading = computed(() => !!(innerLoading.value || props.loading));\n\n/**\n * Filter options to be displayed based on the current query.\n * If no query is used or when query is set from the inside (after a selection) display all possible options\n */\nconst filteredOptions = computed<BaseOption[]>(() => {\n\tlet base = [];\n\t/** Only filter when a value is being searched not when the query is fully set on a selected option text */\n\tconst queryMatchesASelectedOption = selectedOptions.value.some(\n\t\t(option: BaseOption) => option.text === query.value\n\t);\n\tconst shouldFilter =\n\t\t(props.multiple && query.value) ||\n\t\t(query.value && !queryMatchesASelectedOption && !props.multiple);\n\n\tif (shouldFilter && props.filterBy) {\n\t\tbase = options.value.filter((item: BaseOption) => {\n\t\t\tlet matchedAnything = false;\n\t\t\tif (typeof props.filterBy === 'function')\n\t\t\t\tmatchedAnything = props.filterBy(item.value, item.item);\n\t\t\telse if (Array.isArray(props.filterBy) && props.filterBy.length) {\n\t\t\t\tmatchedAnything =\n\t\t\t\t\tmatchedAnything ||\n\t\t\t\t\tmatchAnyKey(item.item, props.filterBy, query.value.trim());\n\t\t\t}\n\t\t\treturn matchedAnything || matchAnyKey(item, ['text'], query.value.trim());\n\t\t});\n\t\t/** Otherwise default to the whole set of options */\n\t} else base = options.value;\n\n\t/** This is done here so that only visible options are highlighted */\n\treturn base;\n});\n\nconst onOptionSelected = (option: BaseOption) => {\n\tselectOption(option);\n\tfocusInput();\n\tif (!props.multiple) {\n\t\tclose();\n\t}\n};\n\nconst onOptionUnselected = (option: BaseOption) => {\n\tunselectOption(option);\n\tfocusInput();\n};\n\n/**\n * We need the transitions because elements must be hidden and shown\n * to accessibility tools when they are fully closed or fully open,\n * while still being animated for sighted users.\n */\n\n// Option panel is open\nconst shown = ref(false);\n// Option panel il closed\nconst hidden = ref(true);\n\nconst renderListBox = ref(false);\n\nconst open = async () => {\n\trenderListBox.value = true;\n\tawait waitFor(() => !!optionsContainer.value);\n\thidden.value = false;\n\tshown.value = true;\n};\n\nconst close = async () => {\n\tshown.value = false;\n\thidden.value = true;\n\tselectedBox.value?.blur();\n};\n\nconst toggle = () => {\n\tif (shown.value) return close();\n\treturn open();\n};\n\n/**\n * Applies a class when the user is inside this whole component.\n * We cannot use focus within as it doesn't work for elements that are teleported.\n * Also we cannot use the <input/> if we physically move focus to the options so\n * we track it manually.\n */\nconst active = ref(false);\n\nconst setActive = () => {\n\tactive.value = true;\n};\nconst setInactive = () => {\n\tactive.value = false;\n\temit('inactive');\n};\n\n/**\n * When clicking on the outside container seamlessly move focus to the input and open the panel\n */\nconst onOuterContainerClick = (event: MouseEvent) => {\n\tevent.preventDefault();\n\temit('click', event);\n\tif (props.disabled || props.readonly) return;\n\tfocusInput();\n\ttoggle();\n};\n\n/**\n * When using this component for submission we add a bunch of hidden\n * inputs so the submitted inputs are on par with v-model\n */\n/**\n * This is used to keep the value compatible to common html expected values.\n * Convert to string everything that's not but do not double encode strings\n */\nconst makeInputValue = when(\n\t(item: unknown) => typeof item !== 'string',\n\tJSON.stringify\n);\n\nconst hiddenInputs = computed(() => {\n\treturn [].concat(props.modelValue).map((current) => {\n\t\tconst value = makeInputValue(current);\n\t\treturn {\n\t\t\tdisabled: props.disabled,\n\t\t\tname: props.name,\n\t\t\ttype: 'hidden',\n\t\t\tvalue: value,\n\t\t};\n\t});\n});\n</script>\n<style lang=\"postcss\">\n@import '@/assets/css/BaseSelect';\n</style>\n"],"names":["props","__props","emit","__emit","ListBox","defineAsyncComponent","outerContainer","ref","innerContainer","optionsContainer","commaBox","chipsBox","selectedBox","computed","isMobile","useMobile","inputmode","id","useId","useIntersectionObserver","intersectionRatio","close","floatingStyles","useFloating","autoUpdate","flip","offset","shift","optionsContainerStyles","base","_a","input","focusInput","onInputFocus","event","setActive","onOutsideInteraction","onInputFirstFocus","isPrefilling","hasPrefilled","prefillItems","onInputBlur","onInputChange","onInputInput","query","updateModelValue","searchByQuery","setInactive","wait","alignQueryToState","canProcessKeyboardBindings","computedLoading","onArrowUp","shown","_b","open","_c","onArrowDown","onArrowLeft","selectedOptions","highlightedOption","_d","onArrowRight","onEnter","error","useLogger","text","valueIsSelected","addCurrentQueryToManualItems","onOptionSelected","last","manualItems","onEscape","onBackspace","nextTick","shouldPrefill","isNotNil","innerLoading","options","selectOption","unselectOption","useOptions","toRef","computedPlaceholder","filteredOptions","queryMatchesASelectedOption","option","item","matchedAnything","matchAnyKey","onOptionUnselected","hidden","renderListBox","waitFor","toggle","active","onOuterContainerClick","makeInputValue","when","hiddenInputs","current","value"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA8YA,UAAMA,IAAQC,GAcRC,IAAOC;AAIb,QAAIH,EAAM,YAAY,CAAC,MAAM,QAAQA,EAAM,UAAU;AAC9C,YAAA,IAAI,MAAM,2DAA2D;AAM5E,UAAMI,IAAUC,GAAqB,MAAM,OAAO,eAAgB,CAAC,GAC7DC,IAAiBC,EAEb,IAAI,GACRC,IAAiBD,EAEb,IAAI,GACRE,IAAmBF,EAAyC,IAAI,GAChEG,IAAWH,EAA0C,IAAI,GACzDI,IAAWJ,EAA0C,IAAI,GACzDK,IAAcC;AAAA,MAAS,MAC5Bb,EAAM,QAAQU,EAAS,QAAQC,EAAS;AAAA,IAAA,GAMnC,EAAE,UAAAG,OAAaC,MACfC,KAAYH;AAAA,MAAS,MAC1Bb,EAAM,iBAAiB,gBAAgBc,GAAS,QAAQ,SAAS;AAAA,IAAA,GAI5DG,IAAKjB,EAAM,MAAMkB,KAAQ,GAAG;AAElC,IAAAC;AAAA,MACCX;AAAA,MACA,CAAC,CAAC,EAAE,mBAAAY,EAAA,CAAmB,MAAM;AAC5B,QAAIA,MAAsB,KACnBC;MAER;AAAA,MACA,EAAE,WAAW,CAAC,GAAG,CAAC,EAAE;AAAA,IAAA;AAGf,UAAA,EAAE,gBAAAC,OAAmBC;AAAA,MAC1Bf;AAAA,MACAC;AAAA,MACA;AAAA,QACC,WAAW;AAAA,QACX,sBAAsBe;AAAA,QACtB,YAAY,CAACC,GAAK,GAAGC,GAAO,CAAC,GAAGC,IAAO;AAAA,MACxC;AAAA,IAAA,GAGKC,KAAyBf,EAAS,MAAM;;AAC7C,YAAMgB,IAA4B;AAAA,QACjC,GAAGP,GAAe;AAAA,QAClB,QAAQ;AAAA,MAAA;AAET,aAAId,EAAe,UAClBqB,EAAK,QAAQ,IAAGC,IAAAtB,EAAe,UAAf,gBAAAsB,EAAsB,IAAI,WAAW,OAG/CD;AAAA,IAAA,CACP,GAKKE,IAAQxB,EAAwB,IAAI,GACpCyB,IAAa,MAAM;AACpB,MAAAD,EAAM,iBAAiB,oBAC1BA,EAAM,MAAM;IACb,GASKE,KAAe,OAAOC,MAAsB;AACjD,MAAAhC,EAAK,SAASgC,CAAK,GACTC,MACD,SAAA,iBAAiB,SAASC,CAAoB,GAC9C,SAAA,iBAAiB,WAAWA,CAAoB;AAAA,IAAA,GAGpDC,KAAoB,MAAM;AAC3B,MAAArC,EAAM,YAAY,WAAW,CAACsC,GAAa,SAAS,CAACC,GAAa,SACxDC;IACd,GAGKC,KAAc,OAAOP,MAAsB;AAChD,MAAAhC,EAAK,QAAQgC,CAAK;AAAA,IAAA,GAGbQ,KAAgB,CAACR,MAAiBhC,EAAK,UAAUgC,CAAK,GAMtDS,KAAe,CAACT,MAAiB;;AACtC,MAAAhC,EAAK,SAASgC,CAAK,GACfU,EAAM,UAAU,OACd5C,EAAM,YACV6C,GAAiB,IAAI,KAGvBf,IAAAlB,EAAY,UAAZ,QAAAkB,EAAmB,QACLgB;IAAA,GAOTV,IAAuB,OAAOF,MAAiB;AAChD,UAAAA,EAAM,kBAAkB,QACvB5B,EAAe,SAASG,EAAiB,SAE3C,CAACH,EAAe,MAAM,IAAI,SAAS4B,EAAM,MAAM,KAC/C,CAACzB,EAAiB,MAAM,IAAI,SAASyB,EAAM,MAAM,GAChD;AACK,QAAAb,KACM0B,MACH,SAAA,oBAAoB,SAASX,CAAoB,GACjD,SAAA,oBAAoB,WAAWA,CAAoB,GACtD,MAAAY,EAAKhD,EAAM,kBAAkB,GACjBiD;AAClB;AAAA,MACD;AAAA,IAEF,GAGKC,IAA6BrC,EAAS,MACvC,EAAAb,EAAM,YACNA,EAAM,YACNmD,EAAgB,SAChB,CAACvC,EAAY,SAASZ,EAAM,SAEhC,GAUKoD,KAAY,YAAY;;AACzB,MAACF,EAA2B,WAIhCpB,IAAAlB,EAAY,UAAZ,QAAAkB,EAAmB,QACfuB,EAAM,SACTC,IAAA7C,EAAiB,UAAjB,QAAA6C,EAAwB,mBAExB,MAAMC,EAAK,GACL,MAAAP,EAAKhD,EAAM,kBAAkB,IACnCwD,IAAA/C,EAAiB,UAAjB,QAAA+C,EAAwB;AAAA,IACzB,GAGKC,KAAc,YAAY;;AAC3B,MAACP,EAA2B,WAIhCpB,IAAAlB,EAAY,UAAZ,QAAAkB,EAAmB,QACfuB,EAAM,SACTC,IAAA7C,EAAiB,UAAjB,QAAA6C,EAAwB,eAExB,MAAMC,EAAK,GACL,MAAAP,EAAKhD,EAAM,kBAAkB,IACnCwD,IAAA/C,EAAiB,UAAjB,QAAA+C,EAAwB;AAAA,IACzB,GAGKE,KAAc,CAACxB,MAAyB;;AAUzC,UATA,CAACgB,EAA2B,SAG5B,CAAClD,EAAM,YAAY4C,EAAM,UAG7BV,EAAM,eAAe,IAErBJ,IAAArB,EAAiB,UAAjB,QAAAqB,EAAwB,QACpB,CAAC6B,EAAgB,MAAM,QAAQ;AACnC,OAAAL,IAAA1C,EAAY,UAAZ,QAAA0C,EAAmB;AACb,YAAAM,KAAoBJ,IAAA5C,EAAY,UAAZ,gBAAA4C,EAAmB;AAC7C,MAAII,OACcC,IAAApD,EAAA,UAAA,QAAAoD,EAAO,YAAYD,EAAkB;AAAA,IACvD,GAGKE,KAAe,CAAC5B,MAAyB;;AAU1C,UATA,CAACgB,EAA2B,SAG5B,CAAClD,EAAM,YAAY4C,EAAM,UAG7BV,EAAM,eAAe,IAErBJ,IAAArB,EAAiB,UAAjB,QAAAqB,EAAwB,QACpB,CAAC6B,EAAgB,MAAM,QAAQ;AACnC,OAAAL,IAAA1C,EAAY,UAAZ,QAAA0C,EAAmB;AACb,YAAAM,KAAoBJ,IAAA5C,EAAY,UAAZ,gBAAA4C,EAAmB;AAC7C,MAAII,OACcC,IAAApD,EAAA,UAAA,QAAAoD,EAAO,YAAYD,EAAkB;AAAA,IACvD,GAGKG,KAAU,YAAY;;AACvB,UAACb,EAA2B;AAG5B,YAAA,CAACG,EAAM;AACV,gBAAME,EAAK,GACL,MAAAP,EAAKhD,EAAM,kBAAkB,GAC/B2D,EAAgB,MAAM,YACzB7B,IAAArB,EAAiB,UAAjB,QAAAqB,EAAwB;AAAA,kBAEfwB,IAAA7C,EAAiB,UAAjB,QAAA6C,EAAwB;AAClC,UAAA7C,EAAiB,MAAM;iBACbT,EAAM,YAAY;AACxB,cAAAA,EAAM,YAAYA,EAAM,WAAW;AAChC,kBAAA,EAAE,OAAAgE,MAAUC;AAClB,YAAAD;AAAA,cACC;AAAA,YAAA;AAED;AAAA,UACD;AACM,gBAAAE,IAAOtB,EAAM,MAAM,KAAK;AAE1B,cAAAuB,GAAgBD,CAAI,EAAG;AACE,UAAAE,MACZC,EAAAC,GAAKC,GAAY,KAAK,CAAE;AAAA,QAC1C;AAAA;AAAA,IAAA,GAGKC,KAAW,YAAY;AAC5B,MAAInB,EAAM,SACT,MAAMhC,EAAM;AAAA,IACb,GAUKoD,KAAc,YAAY;;AAE9B,MAAA,CAACvB,EAA2B,SAC5BN,EAAM,SACN,CAACe,EAAgB,MAAM,YAIpB7B,IAAAlB,EAAY,UAAZ,QAAAkB,EAAmB,oBACtBlB,EAAY,MAAM,iBAEnB,MAAM8D,GAAS,IACfpB,IAAA1C,EAAY,UAAZ,QAAA0C,EAAmB;AAAA,IAAc,GAQ5BqB,KACL3E,EAAM,YAAY,MACjB,CAACA,EAAM,YAAY4E,GAAS5E,EAAM,UAAU,KAC5CA,EAAM,YAAY,CAAC,CAACA,EAAM,WAAW,QAEjC;AAAA,MACL,OAAA4C;AAAA,MACA,mBAAAK;AAAA,MACA,8BAAAmB;AAAA,MACA,cAAAS;AAAA,MACA,SAAAC;AAAA,MACA,iBAAAnB;AAAA,MACA,cAAAoB;AAAA,MACA,gBAAAC;AAAA,MACA,cAAAxC;AAAA,MACA,cAAAF;AAAA,MACA,cAAAC;AAAA,MACA,kBAAAM;AAAA,MACA,iBAAAsB;AAAA,MACA,aAAAI;AAAA,MACA,eAAAzB;AAAA,QACGmC,GAAW;AAAA,MACd,MAAA/E;AAAA,MACA,UAAUF,EAAM;AAAA,MAChB,WAAWA,EAAM;AAAA,MACjB,YAAYkF,EAAMlF,GAAO,YAAY;AAAA,MACrC,UAAUA,EAAM;AAAA,MAChB,4BAA4BA,EAAM;AAAA,MAClC,OAAOA,EAAM;AAAA,MACb,OAAOkF,EAAMlF,GAAO,OAAO;AAAA,MAC3B,kBAAkBA,EAAM;AAAA,MACxB,SAAS2E;AAAA,MACT,wBAAwB3E,EAAM;AAAA,MAC9B,cAAckF,EAAMlF,GAAO,cAAc;AAAA,MACzC,kBAAkBA,EAAM;AAAA,MACxB,mBAAmBA,EAAM;AAAA,MACzB,UAAUkF,EAAMlF,GAAO,UAAU;AAAA,IAAA,CACjC,GAEKmF,KAAsBtE,EAAS,MAChC8C,EAAgB,MAAM,SAAe,KAC7B3D,EAAM,WAClB,GAEKmD,IAAkBtC,EAAS,MAAM,CAAC,EAAEgE,EAAa,SAAS7E,EAAM,QAAQ,GAMxEoF,KAAkBvE,EAAuB,MAAM;AACpD,UAAIgB,IAAO,CAAA;AAEL,YAAAwD,IAA8B1B,EAAgB,MAAM;AAAA,QACzD,CAAC2B,MAAuBA,EAAO,SAAS1C,EAAM;AAAA,MAAA;AAM3C,cAHF5C,EAAM,YAAY4C,EAAM,SACxBA,EAAM,SAAS,CAACyC,KAA+B,CAACrF,EAAM,aAEpCA,EAAM,WACzB6B,IAAOiD,EAAQ,MAAM,OAAO,CAACS,MAAqB;AACjD,YAAIC,IAAkB;AAClB,eAAA,OAAOxF,EAAM,YAAa,aAC7BwF,IAAkBxF,EAAM,SAASuF,EAAK,OAAOA,EAAK,IAAI,IAC9C,MAAM,QAAQvF,EAAM,QAAQ,KAAKA,EAAM,SAAS,WAEvDwF,IAAAA,KACAC,EAAYF,EAAK,MAAMvF,EAAM,UAAU4C,EAAM,MAAM,KAAM,CAAA,IAEpD4C,KAAmBC,EAAYF,GAAM,CAAC,MAAM,GAAG3C,EAAM,MAAM,KAAA,CAAM;AAAA,MAAA,CACxE,QAEYkC,EAAQ,OAGfjD;AAAA,IAAA,CACP,GAEKwC,IAAmB,CAACiB,MAAuB;AAChD,MAAAP,GAAaO,CAAM,GACRtD,KACNhC,EAAM,YACJqB;IACP,GAGKqE,IAAqB,CAACJ,MAAuB;AAClD,MAAAN,GAAeM,CAAM,GACVtD;IAAA,GAUNqB,IAAQ9C,EAAI,EAAK,GAEjBoF,IAASpF,EAAI,EAAI,GAEjBqF,IAAgBrF,EAAI,EAAK,GAEzBgD,IAAO,YAAY;AACxB,MAAAqC,EAAc,QAAQ,IACtB,MAAMC,GAAQ,MAAM,CAAC,CAACpF,EAAiB,KAAK,GAC5CkF,EAAO,QAAQ,IACftC,EAAM,QAAQ;AAAA,IAAA,GAGThC,IAAQ,YAAY;;AACzB,MAAAgC,EAAM,QAAQ,IACdsC,EAAO,QAAQ,KACf7D,IAAAlB,EAAY,UAAZ,QAAAkB,EAAmB;AAAA,IAAK,GAGnBgE,KAAS,MACVzC,EAAM,QAAchC,MACjBkC,EAAK,GASPwC,IAASxF,EAAI,EAAK,GAElB4B,KAAY,MAAM;AACvB,MAAA4D,EAAO,QAAQ;AAAA,IAAA,GAEVhD,KAAc,MAAM;AACzB,MAAAgD,EAAO,QAAQ,IACf7F,EAAK,UAAU;AAAA,IAAA,GAMV8F,KAAwB,CAAC9D,MAAsB;AAGhD,MAFJA,EAAM,eAAe,GACrBhC,EAAK,SAASgC,CAAK,GACf,EAAAlC,EAAM,YAAYA,EAAM,cACjBgC,KACJ8D;IAAA,GAWFG,KAAiBC;AAAA,MACtB,CAACX,MAAkB,OAAOA,KAAS;AAAA,MACnC,KAAK;AAAA,IAAA,GAGAY,KAAetF,EAAS,MACtB,CAAA,EAAG,OAAOb,EAAM,UAAU,EAAE,IAAI,CAACoG,MAAY;AAC7C,YAAAC,IAAQJ,GAAeG,CAAO;AAC7B,aAAA;AAAA,QACN,UAAUpG,EAAM;AAAA,QAChB,MAAMA,EAAM;AAAA,QACZ,MAAM;AAAA,QACN,OAAAqG;AAAA,MAAA;AAAA,IACD,CACA,CACD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
package/dist/index36.js CHANGED
@@ -1,11 +1,11 @@
1
1
  import { defineComponent as U, ref as d, computed as h, onMounted as W, watch as Z, openBlock as g, createElementBlock as w, mergeProps as T, renderSlot as f, createElementVNode as b, Fragment as ee, renderList as ae, createCommentVNode as H, normalizeProps as re, guardReactiveProps as te, unref as c, normalizeClass as F, normalizeStyle as I } from "vue";
2
- import { clamp as le } from "./index207.js";
3
- import { head as O } from "./index227.js";
4
- import { isCssColor as Y } from "./index219.js";
2
+ import { clamp as le } from "./index217.js";
3
+ import { head as O } from "./index240.js";
4
+ import { isCssColor as Y } from "./index214.js";
5
5
  import { isNil as P } from "./index124.js";
6
6
  import { isNotNil as ne } from "./index129.js";
7
7
  import { transposeValue as y } from "./index125.js";
8
- import { hash as J } from "./index228.js";
8
+ import { hash as J } from "./index205.js";
9
9
  const oe = { class: "bb-base-slider__slider-container" }, ie = {
10
10
  key: 0,
11
11
  class: "bb-base-slider__ticks-container"
package/dist/index38.js CHANGED
@@ -1,6 +1,6 @@
1
1
  import { defineComponent as I, ref as p, computed as n, watch as S, openBlock as h, createElementBlock as f, normalizeProps as r, guardReactiveProps as c, mergeProps as y, createCommentVNode as q, createElementVNode as l, renderSlot as A } from "vue";
2
- import { isCssColor as d } from "./index219.js";
3
- import { when as F } from "./index220.js";
2
+ import { isCssColor as d } from "./index214.js";
3
+ import { when as F } from "./index215.js";
4
4
  const N = { class: "bb-base-switch-container" }, x = /* @__PURE__ */ l("span", { class: "bb-base-switch-container__icon-thumb" }, null, -1), J = [
5
5
  x
6
6
  ], L = /* @__PURE__ */ I({
package/dist/index40.js CHANGED
@@ -1,8 +1,8 @@
1
1
  import { defineComponent as $, ref as p, toRef as l, openBlock as w, createBlock as B, unref as f, withCtx as i, renderSlot as s, normalizeProps as b, guardReactiveProps as h, createVNode as O, mergeProps as v, createSlots as z } from "vue";
2
- import { useOptions as F } from "./index199.js";
2
+ import { useOptions as F } from "./index221.js";
3
3
  import M from "./index38.js";
4
4
  /* empty css */
5
- import S from "./index200.js";
5
+ import S from "./index222.js";
6
6
  /* empty css */
7
7
  const I = /* @__PURE__ */ $({
8
8
  __name: "BaseSwitchGroup",
package/dist/index42.js CHANGED
@@ -3,15 +3,15 @@ import { defineComponent as Z, ref as r, computed as k, toRef as B, openBlock as
3
3
  import ue from "./index122.js";
4
4
  /* empty css */
5
5
  import { isNotNil as se } from "./index129.js";
6
- import { last as de } from "./index213.js";
7
- import { useOptions as pe } from "./index199.js";
8
- import ce from "./index231.js";
6
+ import { last as de } from "./index206.js";
7
+ import { useOptions as pe } from "./index221.js";
8
+ import ce from "./index236.js";
9
9
  /* empty css */
10
- import me from "./index233.js";
10
+ import me from "./index238.js";
11
11
  /* empty css */
12
- import fe from "./index215.js";
12
+ import fe from "./index218.js";
13
13
  /* empty css */
14
- import ve from "./index217.js";
14
+ import ve from "./index220.js";
15
15
  const ye = { class: "bb-base-tag__input-container" }, be = ["id", "aria-describedby", "autocomplete", "autofocus", "disabled", "placeholder", "readonly", "required", "onKeydown"], Ke = /* @__PURE__ */ Z({
16
16
  __name: "BaseTag",
17
17
  props: {
package/dist/index44.js CHANGED
@@ -1,6 +1,6 @@
1
1
  import { defineComponent as w, ref as g, computed as u, onMounted as y, watch as V, nextTick as k, openBlock as x, createBlock as B, normalizeClass as $, withCtx as r, renderSlot as t, createVNode as i, createElementVNode as C, mergeProps as T } from "vue";
2
- import v from "./index217.js";
3
- import E from "./index215.js";
2
+ import v from "./index220.js";
3
+ import E from "./index218.js";
4
4
  /* empty css */
5
5
  import G from "./index122.js";
6
6
  /* empty css */
package/dist/index46.js CHANGED
@@ -1,7 +1,7 @@
1
1
  import { defineComponent as i, computed as c, openBlock as m, createElementBlock as b, Fragment as f, createVNode as r, normalizeClass as y, withCtx as n, renderSlot as t, createElementVNode as p, mergeProps as h } from "vue";
2
- import g from "./index215.js";
2
+ import g from "./index218.js";
3
3
  /* empty css */
4
- import B from "./index217.js";
4
+ import B from "./index220.js";
5
5
  const k = ["id", "aria-describedby", "aria-invalid", "autocomplete", "autofocus", "disabled", "name", "placeholder", "readonly", "required", "type", "value"], w = /* @__PURE__ */ p("span", null, null, -1), q = /* @__PURE__ */ i({
6
6
  __name: "BaseTextInput",
7
7
  props: {
package/dist/index52.js CHANGED
@@ -1,5 +1,5 @@
1
1
  import { defineComponent as z, computed as b, ref as o, onMounted as g, openBlock as l, createElementBlock as i, normalizeProps as h, guardReactiveProps as k, renderSlot as y } from "vue";
2
- import { isCssColor as _ } from "./index219.js";
2
+ import { isCssColor as _ } from "./index214.js";
3
3
  import { wait as C } from "./index126.js";
4
4
  const w = ["alt", "sizes", "src", "srcset"], B = {
5
5
  key: 1,
package/dist/index54.js CHANGED
@@ -1,5 +1,5 @@
1
1
  import { defineComponent as p, useSlots as d, computed as n, openBlock as m, createElementBlock as u, normalizeClass as g, createElementVNode as s, renderSlot as l, mergeProps as f, createTextVNode as _, toDisplayString as y } from "vue";
2
- import { isCssColor as r } from "./index219.js";
2
+ import { isCssColor as r } from "./index214.js";
3
3
  import { isNil as B } from "./index124.js";
4
4
  const C = { class: "bb-badge__wrapper" }, h = { class: "bb-badge__content-inner" }, S = /* @__PURE__ */ p({
5
5
  __name: "BbBadge",
package/dist/index58.js CHANGED
@@ -6,8 +6,8 @@ import r from "./index121.js";
6
6
  /* empty css */
7
7
  import N from "./index123.js";
8
8
  /* empty css */
9
- import { pickBy as $ } from "./index235.js";
10
- import { noop as P } from "./index236.js";
9
+ import { pickBy as $ } from "./index241.js";
10
+ import { noop as P } from "./index242.js";
11
11
  const T = { class: "bb-button__content" }, W = {
12
12
  key: 2,
13
13
  class: "bb-button__loading-label"
package/dist/index66.js CHANGED
@@ -1,9 +1,9 @@
1
- import { defineComponent as v, ref as y, computed as w, openBlock as g, createBlock as B, withCtx as l, renderSlot as n, normalizeProps as s, guardReactiveProps as t, createVNode as k, mergeProps as V, createSlots as $, renderList as P } from "vue";
2
- import q from "./index20.js";
1
+ import { defineComponent as m, ref as c, computed as h, openBlock as f, createBlock as b, withCtx as l, renderSlot as v, normalizeProps as y, guardReactiveProps as w, createVNode as g, mergeProps as B } from "vue";
2
+ import k from "./index20.js";
3
3
  /* empty css */
4
- import L from "./index24.js";
4
+ import V from "./index24.js";
5
5
  /* empty css */
6
- const O = /* @__PURE__ */ v({
6
+ const H = /* @__PURE__ */ m({
7
7
  __name: "BbDatePickerInput",
8
8
  props: {
9
9
  allowWriting: { type: [Boolean, String], default: !0 },
@@ -29,15 +29,15 @@ const O = /* @__PURE__ */ v({
29
29
  placeholder: {},
30
30
  "prepend:icon": {},
31
31
  range: { type: Boolean },
32
- readonly: {},
32
+ readonly: { type: Boolean },
33
33
  required: { type: Boolean },
34
34
  reverse: { type: Boolean },
35
35
  selectable: {},
36
36
  width: {}
37
37
  },
38
38
  emits: ["active", "error", "focus", "inactive", "update:modelValue"],
39
- setup(d, { emit: p }) {
40
- const u = d, o = p, a = y(!1), m = w(() => u.persistentHint || a.value), c = {
39
+ setup(i, { emit: n }) {
40
+ const t = i, o = n, a = c(!1), s = h(() => t.persistentHint || a.value), d = {
41
41
  onError: (e) => o("error", e),
42
42
  onFocus: (e) => o("focus", e),
43
43
  onActive: () => {
@@ -48,7 +48,7 @@ const O = /* @__PURE__ */ v({
48
48
  },
49
49
  "onUpdate:modelValue": (e) => o("update:modelValue", e)
50
50
  };
51
- return (e, W) => (g(), B(L, {
51
+ return (e, P) => (f(), b(V, {
52
52
  id: e.id,
53
53
  class: "bb-date-picker-input",
54
54
  direction: e.direction,
@@ -61,13 +61,13 @@ const O = /* @__PURE__ */ v({
61
61
  "model-value": e.modelValue,
62
62
  name: e.name,
63
63
  reverse: e.reverse,
64
- "show-hint": m.value
64
+ "show-hint": s.value
65
65
  }, {
66
66
  label: l((r) => [
67
- n(e.$slots, "label", s(t(r)))
67
+ v(e.$slots, "label", y(w(r)))
68
68
  ]),
69
- input: l(({ id: r, name: h, hasErrors: f }) => [
70
- k(q, V({
69
+ input: l(({ id: r, name: p, hasErrors: u }) => [
70
+ g(k, B({
71
71
  id: r,
72
72
  "allow-writing": e.allowWriting,
73
73
  "append:icon": e.$props["append:icon"],
@@ -75,12 +75,12 @@ const O = /* @__PURE__ */ v({
75
75
  autofocus: e.autofocus,
76
76
  disabled: e.disabled,
77
77
  "first-day-of-week": e.firstDayOfWeek,
78
- "has-errors": f,
78
+ "has-errors": u,
79
79
  loading: e.loading,
80
80
  max: e.max,
81
81
  min: e.min,
82
82
  "model-value": e.modelValue,
83
- name: h,
83
+ name: p,
84
84
  placeholder: e.placeholder,
85
85
  "prepend:icon": e.$props["prepend:icon"],
86
86
  range: e.range,
@@ -88,20 +88,13 @@ const O = /* @__PURE__ */ v({
88
88
  required: e.required,
89
89
  selectable: e.selectable,
90
90
  width: e.width
91
- }, c), $({ _: 2 }, [
92
- P(e.$slots, (D, i) => ({
93
- name: i,
94
- fn: l((b) => [
95
- n(e.$slots, i, s(t(b)))
96
- ])
97
- }))
98
- ]), 1040, ["id", "allow-writing", "append:icon", "autocomplete", "autofocus", "disabled", "first-day-of-week", "has-errors", "loading", "max", "min", "model-value", "name", "placeholder", "prepend:icon", "range", "readonly", "required", "selectable", "width"])
91
+ }, d), null, 16, ["id", "allow-writing", "append:icon", "autocomplete", "autofocus", "disabled", "first-day-of-week", "has-errors", "loading", "max", "min", "model-value", "name", "placeholder", "prepend:icon", "range", "readonly", "required", "selectable", "width"])
99
92
  ]),
100
93
  _: 3
101
94
  }, 8, ["id", "direction", "errors", "has-errors", "hide-label", "hint", "label", "label-position", "model-value", "name", "reverse", "show-hint"]));
102
95
  }
103
96
  });
104
97
  export {
105
- O as default
98
+ H as default
106
99
  };
107
100
  //# sourceMappingURL=index66.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index66.js","sources":["../src/components/BbDatePickerInput/BbDatePickerInput.vue"],"sourcesContent":["<template>\n\t<BaseInputContainer\n\t\t:id=\"id\"\n\t\tclass=\"bb-date-picker-input\"\n\t\t:direction=\"direction\"\n\t\t:errors=\"errors\"\n\t\t:has-errors=\"hasErrors\"\n\t\t:hide-label=\"hideLabel\"\n\t\t:hint=\"hint\"\n\t\t:label=\"label\"\n\t\t:label-position=\"labelPosition\"\n\t\t:model-value=\"modelValue\"\n\t\t:name=\"name\"\n\t\t:reverse=\"reverse\"\n\t\t:show-hint=\"showHint\"\n\t>\n\t\t<template #label=\"data\"><slot name=\"label\" v-bind=\"data\"></slot></template>\n\t\t<template #input=\"{ id, name, hasErrors }\">\n\t\t\t<BaseDatePickerInput\n\t\t\t\t:id=\"id\"\n\t\t\t\t:allow-writing=\"allowWriting\"\n\t\t\t\t:append:icon=\"$props['append:icon']\"\n\t\t\t\t:autocomplete=\"autocomplete\"\n\t\t\t\t:autofocus=\"autofocus\"\n\t\t\t\t:disabled=\"disabled\"\n\t\t\t\t:first-day-of-week=\"firstDayOfWeek\"\n\t\t\t\t:has-errors=\"hasErrors\"\n\t\t\t\t:loading=\"loading\"\n\t\t\t\t:max=\"max\"\n\t\t\t\t:min=\"min\"\n\t\t\t\t:model-value=\"modelValue\"\n\t\t\t\t:name=\"name\"\n\t\t\t\t:placeholder=\"placeholder\"\n\t\t\t\t:prepend:icon=\"$props['prepend:icon']\"\n\t\t\t\t:range=\"range\"\n\t\t\t\t:readonly=\"readonly\"\n\t\t\t\t:required=\"required\"\n\t\t\t\t:selectable=\"selectable\"\n\t\t\t\t:width=\"width\"\n\t\t\t\tv-bind=\"eventListeners\"\n\t\t\t>\n\t\t\t\t<template v-for=\"(_, name) in $slots\" #[name]=\"data\">\n\t\t\t\t\t<slot :name=\"name\" v-bind=\"data\" />\n\t\t\t\t</template>\n\t\t\t</BaseDatePickerInput>\n\t\t</template>\n\t</BaseInputContainer>\n</template>\n\n<script setup lang=\"ts\">\nimport BaseDatePickerInput from '../BaseDatePickerInput/BaseDatePickerInput.vue';\nimport BaseInputContainer from '../BaseInputContainer/BaseInputContainer.vue';\nimport type { BaseDatePickerInputEvents } from '../BaseDatePickerInput/BaseDatePickerInput.vue';\nimport type { BaseDatePickerSlots } from '../BaseDatePicker/BaseDatePicker.vue';\nimport {\n\tref,\n\ttype HTMLAttributes,\n\ttype InputHTMLAttributes,\n\tcomputed,\n} from 'vue';\nimport type { Locale } from 'dayjs/locale/it';\n\nexport type BbDatePickerInputProps = {\n\t/**\n\t * Allows typing into the input.\n\t */\n\tallowWriting?: boolean | 'not-mobile';\n\n\t/**\n\t * Name of the icon to be added at the end of the input.\n\t */\n\t// eslint-disable-next-line vue/prop-name-casing\n\t'append:icon'?: string;\n\n\t/**\n\t * Guides to the browser as to the type of information expected in the field.\n\t */\n\tautocomplete?: InputHTMLAttributes['autocomplete'];\n\n\t/**\n\t * Sets autofocus on page load.\n\t */\n\tautofocus?: InputHTMLAttributes['autofocus'];\n\n\t/**\n\t * Direction of the layout of the component. Can either be a predefined value or a pattern separated by a space like `xx xxxxx`.\n\t */\n\tdirection?: 'horizontal' | 'vertical' | 'auto' | string;\n\n\t/**\n\t * Disables the component\n\t */\n\tdisabled?: boolean;\n\n\t/**\n\t * Can be a string or an array of string containing the messages to display.\n\t */\n\terrors?: string | string[];\n\n\t/**\n\t * Defines the first day of the week with `0` meaning Sunday and `6` meaning Saturday\n\t */\n\tfirstDayOfWeek?: Locale['weekStart'];\n\n\t/**\n\t * Define if the component should be in an error state.\n\t * It usually attaches a CSS class for styling purposes.\n\t */\n\thasErrors?: boolean;\n\n\t/**\n\t * Visually hides the label of the input while maintaining accessibility.\n\t */\n\thideLabel?: boolean;\n\n\t/**\n\t * Text box to be displayed near the input, usually to indicate instructions.\n\t */\n\thint?: string;\n\n\t/**\n\t * The identifier of the component.\n\t */\n\tid?: HTMLAttributes['id'];\n\n\t/**\n\t * Text content of the label of the element.\n\t */\n\tlabel: string;\n\n\t/**\n\t * Sets the text alignment of the label.\n\t */\n\tlabelPosition?: 'left' | 'center' | 'right';\n\n\t/**\n\t * Sets the component in a loading state, usually triggering some visual styles.\n\t */\n\tloading?: boolean;\n\n\t/**\n\t * Maximum selectable date\n\t */\n\tmax?: Date | string | number;\n\n\t/**\n\t * Minimum selectable date\n\t */\n\tmin?: Date | string | number;\n\n\t/**\n\t * Used by v-model. Can be null, a single string, or an array of strings based on whether a range or single date is needed\n\t */\n\tmodelValue: string | string[] | null;\n\n\t/**\n\t * Defines the name of the input.\n\t */\n\tname?: InputHTMLAttributes['name'];\n\n\t/**\n\t * Keeps the hint displayed.\n\t */\n\tpersistentHint?: boolean;\n\n\t/**\n\t * String displayed when there's no data.\n\t */\n\tplaceholder?: InputHTMLAttributes['placeholder'];\n\n\t/**\n\t * Name of the icon to be added at the start of the input.\n\t */\n\t// eslint-disable-next-line vue/prop-name-casing\n\t'prepend:icon'?: string;\n\n\t/**\n\t * Selects a range of dates between two dates. It selects all of the days between start and end\n\t */\n\trange?: boolean;\n\n\t/**\n\t * Sets the input in a readonly state.\n\t */\n\treadonly?: InputHTMLAttributes['readonly'];\n\n\t/**\n\t * Sets the input as required.\n\t */\n\trequired?: boolean;\n\n\t/**\n\t * Reverses the layout. Applicable in every direction the order of the label and the input is swapped.\n\t */\n\treverse?: boolean;\n\n\t/**\n\t * Function that accepts a `Date` object and returns a boolean. `false` meaning the date cannot be selected\n\t * @param date\n\t */\n\tselectable?: (date: Date) => boolean;\n\n\t/**\n\t * Width of the calendar\n\t */\n\twidth?: number | string;\n};\n\nconst props = withDefaults(defineProps<BbDatePickerInputProps>(), {\n\tallowWriting: true,\n});\n\nexport type BbDatePickerInputEvents = BaseDatePickerInputEvents;\n\nconst emit = defineEmits<BbDatePickerInputEvents>();\n\ndefineSlots<\n\t{\n\t\t'prepend-outer'?: (props: object) => any;\n\t\tprepend?: (props: object) => any;\n\t\tappend?: (props: object) => any;\n\t\t'append-outer'?: (props: object) => any;\n\t\tlabel?: (props: { text: string; hasErrors: boolean }) => any;\n\t} & BaseDatePickerSlots\n>();\n\nconst active = ref(false);\nconst showHint = computed(() => props.persistentHint || active.value);\n\n/**\n * These events are just propagated\n */\nconst eventListeners = {\n\tonError: (message: string) => emit('error', message),\n\tonFocus: (event: FocusEvent) => emit('focus', event),\n\tonActive: () => {\n\t\tactive.value = true;\n\t\temit('active');\n\t},\n\tonInactive: () => {\n\t\tactive.value = false;\n\t\temit('inactive');\n\t},\n\t'onUpdate:modelValue': (value: BbDatePickerInputProps['modelValue']) =>\n\t\temit('update:modelValue', value),\n};\n</script>\n\n<style lang=\"postcss\">\n@import '@/assets/css/BbDatePickerInput';\n</style>\n"],"names":["props","__props","emit","__emit","active","ref","showHint","computed","eventListeners","message","event","value"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAgNA,UAAMA,IAAQC,GAMRC,IAAOC,GAYPC,IAASC,EAAI,EAAK,GAClBC,IAAWC,EAAS,MAAMP,EAAM,kBAAkBI,EAAO,KAAK,GAK9DI,IAAiB;AAAA,MACtB,SAAS,CAACC,MAAoBP,EAAK,SAASO,CAAO;AAAA,MACnD,SAAS,CAACC,MAAsBR,EAAK,SAASQ,CAAK;AAAA,MACnD,UAAU,MAAM;AACf,QAAAN,EAAO,QAAQ,IACfF,EAAK,QAAQ;AAAA,MACd;AAAA,MACA,YAAY,MAAM;AACjB,QAAAE,EAAO,QAAQ,IACfF,EAAK,UAAU;AAAA,MAChB;AAAA,MACA,uBAAuB,CAACS,MACvBT,EAAK,qBAAqBS,CAAK;AAAA,IAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"index66.js","sources":["../src/components/BbDatePickerInput/BbDatePickerInput.vue"],"sourcesContent":["<template>\n\t<BaseInputContainer\n\t\t:id=\"id\"\n\t\tclass=\"bb-date-picker-input\"\n\t\t:direction=\"direction\"\n\t\t:errors=\"errors\"\n\t\t:has-errors=\"hasErrors\"\n\t\t:hide-label=\"hideLabel\"\n\t\t:hint=\"hint\"\n\t\t:label=\"label\"\n\t\t:label-position=\"labelPosition\"\n\t\t:model-value=\"modelValue\"\n\t\t:name=\"name\"\n\t\t:reverse=\"reverse\"\n\t\t:show-hint=\"showHint\"\n\t>\n\t\t<template #label=\"data\"><slot name=\"label\" v-bind=\"data\"></slot></template>\n\t\t<template #input=\"{ id, name, hasErrors }\">\n\t\t\t<BaseDatePickerInput\n\t\t\t\t:id=\"id\"\n\t\t\t\t:allow-writing=\"allowWriting\"\n\t\t\t\t:append:icon=\"$props['append:icon']\"\n\t\t\t\t:autocomplete=\"autocomplete\"\n\t\t\t\t:autofocus=\"autofocus\"\n\t\t\t\t:disabled=\"disabled\"\n\t\t\t\t:first-day-of-week=\"firstDayOfWeek\"\n\t\t\t\t:has-errors=\"hasErrors\"\n\t\t\t\t:loading=\"loading\"\n\t\t\t\t:max=\"max\"\n\t\t\t\t:min=\"min\"\n\t\t\t\t:model-value=\"modelValue\"\n\t\t\t\t:name=\"name\"\n\t\t\t\t:placeholder=\"placeholder\"\n\t\t\t\t:prepend:icon=\"$props['prepend:icon']\"\n\t\t\t\t:range=\"range\"\n\t\t\t\t:readonly=\"readonly\"\n\t\t\t\t:required=\"required\"\n\t\t\t\t:selectable=\"selectable\"\n\t\t\t\t:width=\"width\"\n\t\t\t\tv-bind=\"eventListeners\"\n\t\t\t>\n\t\t\t</BaseDatePickerInput>\n\t\t</template>\n\t</BaseInputContainer>\n</template>\n\n<script setup lang=\"ts\">\nimport BaseDatePickerInput from '../BaseDatePickerInput/BaseDatePickerInput.vue';\nimport BaseInputContainer from '../BaseInputContainer/BaseInputContainer.vue';\nimport type { BaseDatePickerInputEvents } from '../BaseDatePickerInput/BaseDatePickerInput.vue';\nimport {\n\tref,\n\ttype HTMLAttributes,\n\ttype InputHTMLAttributes,\n\tcomputed,\n} from 'vue';\nimport type { Locale } from 'dayjs/locale/it';\n\nexport type BbDatePickerInputProps = {\n\t/**\n\t * Allows typing into the input.\n\t */\n\tallowWriting?: boolean | 'not-mobile';\n\n\t/**\n\t * Name of the icon to be added at the end of the input.\n\t */\n\t// eslint-disable-next-line vue/prop-name-casing\n\t'append:icon'?: string;\n\n\t/**\n\t * Guides to the browser as to the type of information expected in the field.\n\t */\n\tautocomplete?: InputHTMLAttributes['autocomplete'];\n\n\t/**\n\t * Sets autofocus on page load.\n\t */\n\tautofocus?: InputHTMLAttributes['autofocus'];\n\n\t/**\n\t * Direction of the layout of the component. Can either be a predefined value or a pattern separated by a space like `xx xxxxx`.\n\t */\n\tdirection?: 'horizontal' | 'vertical' | 'auto' | string;\n\n\t/**\n\t * Disables the component\n\t */\n\tdisabled?: boolean;\n\n\t/**\n\t * Can be a string or an array of string containing the messages to display.\n\t */\n\terrors?: string | string[];\n\n\t/**\n\t * Defines the first day of the week with `0` meaning Sunday and `6` meaning Saturday\n\t */\n\tfirstDayOfWeek?: Locale['weekStart'];\n\n\t/**\n\t * Define if the component should be in an error state.\n\t * It usually attaches a CSS class for styling purposes.\n\t */\n\thasErrors?: boolean;\n\n\t/**\n\t * Visually hides the label of the input while maintaining accessibility.\n\t */\n\thideLabel?: boolean;\n\n\t/**\n\t * Text box to be displayed near the input, usually to indicate instructions.\n\t */\n\thint?: string;\n\n\t/**\n\t * The identifier of the component.\n\t */\n\tid?: HTMLAttributes['id'];\n\n\t/**\n\t * Text content of the label of the element.\n\t */\n\tlabel: string;\n\n\t/**\n\t * Sets the text alignment of the label.\n\t */\n\tlabelPosition?: 'left' | 'center' | 'right';\n\n\t/**\n\t * Sets the component in a loading state, usually triggering some visual styles.\n\t */\n\tloading?: boolean;\n\n\t/**\n\t * Maximum selectable date\n\t */\n\tmax?: Date | string | number;\n\n\t/**\n\t * Minimum selectable date\n\t */\n\tmin?: Date | string | number;\n\n\t/**\n\t * Used by v-model. Can be null, a single string, or an array of strings based on whether a range or single date is needed\n\t */\n\tmodelValue: string | string[] | null;\n\n\t/**\n\t * Defines the name of the input.\n\t */\n\tname?: InputHTMLAttributes['name'];\n\n\t/**\n\t * Keeps the hint displayed.\n\t */\n\tpersistentHint?: boolean;\n\n\t/**\n\t * String displayed when there's no data.\n\t */\n\tplaceholder?: InputHTMLAttributes['placeholder'];\n\n\t/**\n\t * Name of the icon to be added at the start of the input.\n\t */\n\t// eslint-disable-next-line vue/prop-name-casing\n\t'prepend:icon'?: string;\n\n\t/**\n\t * Selects a range of dates between two dates. It selects all of the days between start and end\n\t */\n\trange?: boolean;\n\n\t/**\n\t * Sets the input in a readonly state.\n\t */\n\treadonly?: boolean;\n\n\t/**\n\t * Sets the input as required.\n\t */\n\trequired?: boolean;\n\n\t/**\n\t * Reverses the layout. Applicable in every direction the order of the label and the input is swapped.\n\t */\n\treverse?: boolean;\n\n\t/**\n\t * Function that accepts a `Date` object and returns a boolean. `false` meaning the date cannot be selected\n\t * @param date\n\t */\n\tselectable?: (date: Date) => boolean;\n\n\t/**\n\t * Width of the calendar\n\t */\n\twidth?: number | string;\n};\n\nconst props = withDefaults(defineProps<BbDatePickerInputProps>(), {\n\tallowWriting: true,\n});\n\nexport type BbDatePickerInputEvents = BaseDatePickerInputEvents;\n\nconst emit = defineEmits<BbDatePickerInputEvents>();\n\ndefineSlots<{\n\t'prepend-outer'?: (props: object) => any;\n\tprepend?: (props: object) => any;\n\tappend?: (props: object) => any;\n\t'append-outer'?: (props: object) => any;\n\tlabel?: (props: { text: string; hasErrors: boolean }) => any;\n}>();\n\nconst active = ref(false);\nconst showHint = computed(() => props.persistentHint || active.value);\n\n/**\n * These events are just propagated\n */\nconst eventListeners = {\n\tonError: (message: string) => emit('error', message),\n\tonFocus: (event: FocusEvent) => emit('focus', event),\n\tonActive: () => {\n\t\tactive.value = true;\n\t\temit('active');\n\t},\n\tonInactive: () => {\n\t\tactive.value = false;\n\t\temit('inactive');\n\t},\n\t'onUpdate:modelValue': (value: BbDatePickerInputProps['modelValue']) =>\n\t\temit('update:modelValue', value),\n};\n</script>\n\n<style lang=\"postcss\">\n@import '@/assets/css/BbDatePickerInput';\n</style>\n"],"names":["props","__props","emit","__emit","active","ref","showHint","computed","eventListeners","message","event","value"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA4MA,UAAMA,IAAQC,GAMRC,IAAOC,GAUPC,IAASC,EAAI,EAAK,GAClBC,IAAWC,EAAS,MAAMP,EAAM,kBAAkBI,EAAO,KAAK,GAK9DI,IAAiB;AAAA,MACtB,SAAS,CAACC,MAAoBP,EAAK,SAASO,CAAO;AAAA,MACnD,SAAS,CAACC,MAAsBR,EAAK,SAASQ,CAAK;AAAA,MACnD,UAAU,MAAM;AACf,QAAAN,EAAO,QAAQ,IACfF,EAAK,QAAQ;AAAA,MACd;AAAA,MACA,YAAY,MAAM;AACjB,QAAAE,EAAO,QAAQ,IACfF,EAAK,UAAU;AAAA,MAChB;AAAA,MACA,uBAAuB,CAACS,MACvBT,EAAK,qBAAqBS,CAAK;AAAA,IAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}