bitboss-ui 2.0.171 → 2.0.172

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 (193) hide show
  1. package/dist/components/BaseColorInput/BaseColorInput.vue.d.ts +95 -5
  2. package/dist/components/BaseDatePickerInput/BaseDatePickerInput.vue.d.ts +2 -2
  3. package/dist/components/BbDropdown/BbDropdown.vue.d.ts +12 -6
  4. package/dist/components/BbPopover/BbPopover.vue.d.ts +12 -6
  5. package/dist/components/BbTooltip/BbTooltip.vue.d.ts +12 -6
  6. package/dist/components/CommonPopover.vue.d.ts +5 -4
  7. package/dist/index.css +1 -1
  8. package/dist/index106.js +9 -9
  9. package/dist/index111.js +1 -1
  10. package/dist/index113.js +1 -1
  11. package/dist/index121.js +11 -11
  12. package/dist/index129.js +2 -2
  13. package/dist/index13.js +1 -1
  14. package/dist/index131.js +3 -3
  15. package/dist/index133.js +1 -1
  16. package/dist/index139.js +2 -2
  17. package/dist/index15.js +129 -142
  18. package/dist/index17.js +3 -3
  19. package/dist/index19.js +8 -8
  20. package/dist/index209.js +10 -2
  21. package/dist/index21.js +16 -16
  22. package/dist/index210.js +3 -4
  23. package/dist/index211.js +13 -2
  24. package/dist/index212.js +33 -17
  25. package/dist/index213.js +13 -128
  26. package/dist/index214.js +59 -99
  27. package/dist/index216.js +2 -100
  28. package/dist/index217.js +6 -0
  29. package/dist/index218.js +2 -66
  30. package/dist/index219.js +4 -0
  31. package/dist/index220.js +40 -12
  32. package/dist/index222.js +7 -15
  33. package/dist/index223.js +15 -29
  34. package/dist/index224.js +5 -16
  35. package/dist/index225.js +9 -12
  36. package/dist/index226.js +5 -51
  37. package/dist/index227.js +5 -17
  38. package/dist/index228.js +5 -15
  39. package/dist/index229.js +5 -3
  40. package/dist/index23.js +136 -159
  41. package/dist/index230.js +5 -12
  42. package/dist/index231.js +2 -13
  43. package/dist/index232.js +2 -2
  44. package/dist/index233.js +11 -228
  45. package/dist/index234.js +17 -365
  46. package/dist/index235.js +105 -2
  47. package/dist/index237.js +86 -5
  48. package/dist/index239.js +29 -5
  49. package/dist/index240.js +17 -5
  50. package/dist/index241.js +51 -5
  51. package/dist/index242.js +15 -5
  52. package/dist/index243.js +3 -8
  53. package/dist/index244.js +12 -250
  54. package/dist/index245.js +16 -52
  55. package/dist/index246.js +4 -44
  56. package/dist/index247.js +200 -5
  57. package/dist/index249.js +18 -5
  58. package/dist/index25.js +4 -4
  59. package/dist/index250.js +12 -2
  60. package/dist/index251.js +106 -41
  61. package/dist/index253.js +94 -88
  62. package/dist/index255.js +228 -9
  63. package/dist/index256.js +2 -4
  64. package/dist/index257.js +174 -197
  65. package/dist/index258.js +5 -0
  66. package/dist/index259.js +2 -7
  67. package/dist/index260.js +5 -86
  68. package/dist/index261.js +7 -0
  69. package/dist/index262.js +6 -32
  70. package/dist/index263.js +250 -2
  71. package/dist/index264.js +52 -2
  72. package/dist/index265.js +44 -3
  73. package/dist/index266.js +5 -177
  74. package/dist/index267.js +60 -10
  75. package/dist/index268.js +8 -2
  76. package/dist/index269.js +23 -6
  77. package/dist/index27.js +1 -1
  78. package/dist/index270.js +6 -16
  79. package/dist/index271.js +15 -10
  80. package/dist/index272.js +3 -101
  81. package/dist/index273.js +11 -0
  82. package/dist/index274.js +8 -3
  83. package/dist/index275.js +2 -9
  84. package/dist/index276.js +67 -23
  85. package/dist/index277.js +5 -2
  86. package/dist/index278.js +8 -9
  87. package/dist/index279.js +5 -8
  88. package/dist/index280.js +7 -5
  89. package/dist/index281.js +11 -67
  90. package/dist/index282.js +2 -5
  91. package/dist/index284.js +6 -3
  92. package/dist/index285.js +3 -4
  93. package/dist/index286.js +4 -129
  94. package/dist/index287.js +1 -1
  95. package/dist/index288.js +17 -3
  96. package/dist/index289.js +28 -3
  97. package/dist/index29.js +2 -2
  98. package/dist/index290.js +6 -0
  99. package/dist/index291.js +469 -5
  100. package/dist/index292.js +1 -1
  101. package/dist/index293.js +3 -2
  102. package/dist/index294.js +3 -17
  103. package/dist/index295.js +279 -27
  104. package/dist/index296.js +2 -7
  105. package/dist/index297.js +124 -10
  106. package/dist/index298.js +2 -280
  107. package/dist/index299.js +15 -2
  108. package/dist/index300.js +2 -16
  109. package/dist/index301.js +16 -2
  110. package/dist/index302.js +2 -16
  111. package/dist/index303.js +16 -2
  112. package/dist/index304.js +2 -19
  113. package/dist/index305.js +19 -2
  114. package/dist/index306.js +2 -15
  115. package/dist/index307.js +200 -2
  116. package/dist/index308.js +5 -18
  117. package/dist/index309.js +3 -2
  118. package/dist/index31.js +2 -2
  119. package/dist/index310.js +3 -27
  120. package/dist/index311.js +2 -2
  121. package/dist/index312.js +5 -2
  122. package/dist/index313.js +19 -2
  123. package/dist/index314.js +2 -2
  124. package/dist/index315.js +27 -2
  125. package/dist/index316.js +2 -22
  126. package/dist/index317.js +4 -0
  127. package/dist/index318.js +2 -125
  128. package/dist/index319.js +2 -2
  129. package/dist/index320.js +2 -471
  130. package/dist/index321.js +22 -3
  131. package/dist/index323.js +5 -382
  132. package/dist/index324.js +700 -125
  133. package/dist/index325.js +354 -2
  134. package/dist/index326.js +58 -3
  135. package/dist/index327.js +2 -6
  136. package/dist/index328.js +56 -198
  137. package/dist/index329.js +58 -5
  138. package/dist/index33.js +8 -8
  139. package/dist/index330.js +31 -699
  140. package/dist/index331.js +28 -354
  141. package/dist/index333.js +47 -3
  142. package/dist/index334.js +7 -5
  143. package/dist/index335.js +7 -46
  144. package/dist/index336.js +6 -2
  145. package/dist/index337.js +7 -32
  146. package/dist/index338.js +7 -28
  147. package/dist/index339.js +21 -0
  148. package/dist/index340.js +227 -57
  149. package/dist/index341.js +127 -57
  150. package/dist/index342.js +367 -6
  151. package/dist/index343.js +92 -7
  152. package/dist/index345.js +3 -8
  153. package/dist/index346.js +482 -5
  154. package/dist/index347.js +46 -6
  155. package/dist/index348.js +127 -17
  156. package/dist/index349.js +377 -223
  157. package/dist/index35.js +4 -4
  158. package/dist/index350.js +124 -91
  159. package/dist/index37.js +230 -240
  160. package/dist/index39.js +4 -4
  161. package/dist/index41.js +2 -2
  162. package/dist/index43.js +8 -8
  163. package/dist/index45.js +8 -8
  164. package/dist/index47.js +2 -2
  165. package/dist/index49.js +3 -3
  166. package/dist/index53.js +1 -1
  167. package/dist/index55.js +1 -1
  168. package/dist/index57.js +2 -2
  169. package/dist/index61.js +3 -3
  170. package/dist/index67.js +1 -1
  171. package/dist/index79.js +4 -4
  172. package/dist/index81.js +1 -1
  173. package/dist/index83.js +2 -2
  174. package/dist/index85.js +1 -1
  175. package/dist/index87.js +1 -1
  176. package/dist/index90.js +4 -4
  177. package/dist/index92.js +2 -2
  178. package/dist/index94.js +3 -3
  179. package/package.json +1 -1
  180. package/dist/components/CommonFloating.vue.d.ts +0 -38
  181. package/dist/index236.js +0 -7
  182. package/dist/index238.js +0 -7
  183. package/dist/index248.js +0 -62
  184. package/dist/index252.js +0 -22
  185. package/dist/index283.js +0 -10
  186. package/dist/index322.js +0 -5
  187. package/dist/index332.js +0 -60
  188. package/dist/index344.js +0 -8
  189. package/dist/index351.js +0 -484
  190. package/dist/index353.js +0 -5
  191. package/dist/index354.js +0 -49
  192. package/dist/index355.js +0 -483
  193. package/dist/index356.js +0 -4
package/dist/index235.js CHANGED
@@ -1,4 +1,107 @@
1
- const o = (e) => typeof e == "boolean" ? e : e === "true";
1
+ import { defineComponent as C, mergeModels as M, useModel as P, ref as n, watch as B, computed as x, createBlock as b, openBlock as c, resolveDynamicComponent as v, normalizeStyle as A, normalizeClass as D, unref as s, withCtx as g, renderSlot as w, mergeProps as y, createElementVNode as h } from "vue";
2
+ import { useFloating as V, arrow as S } from "./index341.js";
3
+ import { flip as z, offset as E, shift as F, autoUpdate as N } from "./index342.js";
4
+ const U = { class: "bb-common-popover__bubble" }, I = /* @__PURE__ */ C({
5
+ __name: "CommonPopover",
6
+ props: /* @__PURE__ */ M({
7
+ arrowPadding: {},
8
+ offset: {},
9
+ block: { type: Boolean },
10
+ padding: {},
11
+ placement: {},
12
+ transitionDuration: { default: 250 },
13
+ containerAttributes: {},
14
+ dialog: { type: Boolean },
15
+ tag: { default: "span" }
16
+ }, {
17
+ modelValue: { type: Boolean, default: !1 },
18
+ modelModifiers: {}
19
+ }),
20
+ emits: ["update:modelValue"],
21
+ setup(i) {
22
+ const o = i, t = P(i, "modelValue"), p = n(), a = n(), d = n(), { floatingStyles: k, placement: _, middlewareData: r } = V(
23
+ p,
24
+ a,
25
+ {
26
+ placement: o.placement,
27
+ whileElementsMounted: N,
28
+ middleware: [
29
+ z(),
30
+ E(o.offset),
31
+ F({ padding: o.padding }),
32
+ S({
33
+ element: d,
34
+ padding: o.arrowPadding
35
+ })
36
+ ],
37
+ strategy: "fixed"
38
+ }
39
+ );
40
+ B(t, (e) => {
41
+ e ? a.value && (o.dialog ? a.value.showModal() : a.value.showPopover()) : a.value && (o.dialog ? a.value.close() : a.value.hidePopover());
42
+ });
43
+ const $ = x(() => {
44
+ if (r.value.arrow) {
45
+ const { x: e, y: l } = r.value.arrow;
46
+ return {
47
+ style: {
48
+ left: `${e}px`,
49
+ top: `${l}px`
50
+ }
51
+ };
52
+ }
53
+ });
54
+ return (e, l) => (c(), b(v(e.dialog ? "div" : e.tag), {
55
+ ref_key: "wrapper",
56
+ ref: p,
57
+ class: D(["bb-common-popover", {
58
+ "bb-common-popover--open": t.value,
59
+ "bb-common-popover--block": o.block,
60
+ [`bb-common-popover--${s(_)}`]: !0
61
+ }]),
62
+ style: A({
63
+ "--transition-duration": `${o.transitionDuration}ms`
64
+ })
65
+ }, {
66
+ default: g(() => {
67
+ var m, u, f;
68
+ return [
69
+ w(e.$slots, "activator"),
70
+ (c(), b(v(e.dialog ? "dialog" : e.tag), y({
71
+ ref_key: "content",
72
+ ref: a,
73
+ class: ["bb-common-popover__bubble-container", {
74
+ "bb-common-popover__bubble-container--open": t.value
75
+ }],
76
+ popover: "manual",
77
+ style: {
78
+ ...((m = e.containerAttributes) == null ? void 0 : m.style) ?? {},
79
+ ...s(k),
80
+ "--arrow-offset-x": Math.round(((f = (u = s(r)) == null ? void 0 : u.arrow) == null ? void 0 : f.x) ?? 0) + "px",
81
+ "--page-padding": `${e.padding}px`
82
+ },
83
+ tabindex: t.value ? void 0 : -1
84
+ }, e.containerAttributes, {
85
+ onClose: l[0] || (l[0] = (j) => t.value = !1)
86
+ }), {
87
+ default: g(() => [
88
+ h("span", y({
89
+ ref_key: "bubblearrow",
90
+ ref: d,
91
+ class: "bb-common-popover__arrow"
92
+ }, $.value), null, 16),
93
+ h("span", U, [
94
+ w(e.$slots, "default")
95
+ ])
96
+ ]),
97
+ _: 3
98
+ }, 16, ["class", "style", "tabindex"]))
99
+ ];
100
+ }),
101
+ _: 3
102
+ }, 8, ["class", "style"]));
103
+ }
104
+ });
2
105
  export {
3
- o as booleanishToBoolean
106
+ I as default
4
107
  };
package/dist/index237.js CHANGED
@@ -1,7 +1,88 @@
1
- import { getDefaultExportFromCjs as r } from "./index327.js";
2
- import { __require as e } from "./index300.js";
3
- var t = e();
4
- const m = /* @__PURE__ */ r(t);
1
+ import { defineComponent as h, createElementBlock as n, openBlock as s, normalizeClass as r, createElementVNode as l, renderSlot as t, createCommentVNode as p, createTextVNode as o, toDisplayString as d, unref as b, Fragment as m, renderList as u } from "vue";
2
+ import { useLocale as g } from "./index211.js";
3
+ const k = { class: "bb-cr-container__container" }, y = {
4
+ key: 0,
5
+ class: "bb-cr-container__loading-container"
6
+ }, $ = {
7
+ key: 1,
8
+ class: "bb-cr-container__no-data-container"
9
+ }, C = /* @__PURE__ */ h({
10
+ __name: "OptionsContainer",
11
+ props: {
12
+ direction: {},
13
+ hasErrors: { type: Boolean },
14
+ hideLabel: { type: Boolean },
15
+ loadingText: {},
16
+ loading: { type: Boolean },
17
+ noDataText: {},
18
+ options: {}
19
+ },
20
+ setup(f) {
21
+ const { t: i } = g();
22
+ return (a, T) => (s(), n("span", {
23
+ ref: "container",
24
+ class: r(["bb-cr-container", {
25
+ "bb-cr-container--errors": a.hasErrors,
26
+ "bb-cr-container--horizontal": a.direction === "horizontal",
27
+ "bb-cr-container--vertical": a.direction === "vertical"
28
+ }])
29
+ }, [
30
+ l("span", k, [
31
+ t(a.$slots, "prepend"),
32
+ !a.options.length && a.loading ? (s(), n("span", y, [
33
+ t(a.$slots, "loading", {}, () => [
34
+ o(d(a.loadingText || b(i)("common.loadingText")), 1)
35
+ ])
36
+ ])) : a.options.length ? p("", !0) : (s(), n("span", $, [
37
+ t(a.$slots, "no-data", {}, () => [
38
+ o(d(a.noDataText || b(i)("common.noDataText")), 1)
39
+ ])
40
+ ])),
41
+ (s(!0), n(m, null, u(a.options, (e, c) => (s(), n(m, {
42
+ key: (e == null ? void 0 : e.valueHash) || c
43
+ }, [
44
+ t(a.$slots, "option:prepend", {
45
+ id: e.valueHash,
46
+ checked: !!e.selected,
47
+ disabled: !!e.disabled,
48
+ item: e.item,
49
+ text: e.text
50
+ }),
51
+ l("label", {
52
+ class: r(["bb-cr-container-option", { "bb-base-radio-selected": e.selected }])
53
+ }, [
54
+ t(a.$slots, "input", {
55
+ index: c,
56
+ option: e
57
+ }),
58
+ l("span", {
59
+ class: r({
60
+ "bb-cr-container-option__text": !0,
61
+ "sr-only": a.hideLabel
62
+ })
63
+ }, [
64
+ t(a.$slots, "label", {
65
+ checked: !!e.selected,
66
+ item: e.item,
67
+ text: e.text
68
+ }, () => [
69
+ o(d(e.text), 1)
70
+ ])
71
+ ], 2)
72
+ ], 2),
73
+ t(a.$slots, "option:append", {
74
+ id: e.valueHash,
75
+ checked: !!e.selected,
76
+ disabled: !!e.disabled,
77
+ item: e.item,
78
+ text: e.text
79
+ })
80
+ ], 64))), 128)),
81
+ t(a.$slots, "append")
82
+ ])
83
+ ], 2));
84
+ }
85
+ });
5
86
  export {
6
- m as default
87
+ C as default
7
88
  };
package/dist/index239.js CHANGED
@@ -1,7 +1,31 @@
1
- import { getDefaultExportFromCjs as r } from "./index327.js";
2
- import { __require as t } from "./index304.js";
3
- var o = t();
4
- const a = /* @__PURE__ */ r(o);
1
+ import { ref as a, computed as s, unref as v } from "vue";
2
+ import { useDebounceFn as f } from "./index206.js";
3
+ const p = (u) => {
4
+ const e = a(0), r = s(() => v(u.items)), t = a([]), n = async (...l) => {
5
+ if (Array.isArray(r.value))
6
+ t.value = r.value;
7
+ else if (typeof r.value == "function") {
8
+ const i = ++e.value;
9
+ try {
10
+ const o = await r.value(...l);
11
+ if (i < e.value) {
12
+ e.value--;
13
+ return;
14
+ } else
15
+ t.value = o;
16
+ } catch (o) {
17
+ console.error(o);
18
+ }
19
+ e.value--;
20
+ }
21
+ }, c = f(n, u.debounce || 0);
22
+ return {
23
+ getter: n,
24
+ debouncedGetter: c,
25
+ items: t,
26
+ loading: s(() => !!e.value)
27
+ };
28
+ };
5
29
  export {
6
- a as default
30
+ p as useItemsGetter
7
31
  };
package/dist/index240.js CHANGED
@@ -1,7 +1,19 @@
1
- import { getDefaultExportFromCjs as r } from "./index327.js";
2
- import { __require as e } from "./index306.js";
3
- var o = e();
4
- const m = /* @__PURE__ */ r(o);
1
+ import { computed as i, unref as m } from "vue";
2
+ import { hash as s } from "./index243.js";
3
+ const p = ({ items: a, key: r }) => {
4
+ const n = i(() => {
5
+ const t = {}, c = new Array().concat(m(a));
6
+ for (let e = 0; e < c.length; e++) {
7
+ const o = c[e], u = r ? String(o[r]) : s(o);
8
+ t[u] = o;
9
+ }
10
+ return t;
11
+ });
12
+ return {
13
+ data: n,
14
+ get: (t) => r ? n.value[String(t[r])] : n.value[s(t)]
15
+ };
16
+ };
5
17
  export {
6
- m as default
18
+ p as useIndexById
7
19
  };
package/dist/index241.js CHANGED
@@ -1,7 +1,53 @@
1
- import { getDefaultExportFromCjs as e } from "./index327.js";
2
- import { __require as r } from "./index308.js";
3
- var o = r();
4
- const p = /* @__PURE__ */ e(o);
1
+ import { computed as l, unref as o } from "vue";
2
+ import { useItemText as x } from "./index288.js";
3
+ import { useItemValue as w } from "./index273.js";
4
+ import { hash as y } from "./index243.js";
5
+ import { useLogger as D } from "./index262.js";
6
+ const { getItemText: O } = x(), { getItemValue: V } = w(), { warn: H } = D(), T = (u, c, m, a, d, r) => r ? !1 : !!(c || u.disabled || a && d >= a), q = ({
7
+ items: u,
8
+ disabled: c,
9
+ selectable: m,
10
+ itemText: a,
11
+ itemValue: d,
12
+ selectedIndexedByHash: r,
13
+ max: b = 1 / 0
14
+ }) => {
15
+ const v = l(() => o(c)), p = l(() => o(u)), h = l(
16
+ () => Object.keys(r.value).length
17
+ ), g = o(b), f = (e) => {
18
+ const n = V(e, o(d)), t = y(n), i = O(e, o(a)), s = r.value[t] !== void 0, I = T(
19
+ e,
20
+ v.value,
21
+ m,
22
+ g,
23
+ h.value,
24
+ s
25
+ );
26
+ return {
27
+ item: e,
28
+ text: i,
29
+ value: n,
30
+ valueHash: t,
31
+ selected: s,
32
+ disabled: o(I)
33
+ };
34
+ };
35
+ return {
36
+ options: l(() => {
37
+ const e = [], n = /* @__PURE__ */ new Set();
38
+ for (let t = 0; t < p.value.length; t++) {
39
+ const i = p.value[t];
40
+ i.disabled && H(
41
+ "Disabling an item by passing a disabled option to the item itself is deprecated and will be removed in a future version. Use the `disabled` prop or the `selectable` iteratee prop instead."
42
+ );
43
+ const s = f(i);
44
+ n.has(s.valueHash) || (n.add(s.valueHash), e.push(s));
45
+ }
46
+ return e;
47
+ }),
48
+ createOption: f
49
+ };
50
+ };
5
51
  export {
6
- p as default
52
+ q as useBaseOptions
7
53
  };
package/dist/index242.js CHANGED
@@ -1,7 +1,17 @@
1
- import { getDefaultExportFromCjs as e } from "./index327.js";
2
- import { __require as r } from "./index310.js";
3
- var o = r();
4
- const f = /* @__PURE__ */ e(o);
1
+ import { isNil as f } from "./index256.js";
2
+ import { computed as t, unref as o } from "vue";
3
+ const a = ({ modelValue: e, iteratee: h, multiple: u }) => {
4
+ const i = t(
5
+ () => new Array().concat(o(e))
6
+ ), s = t(() => i.value.reduce(
7
+ (r, n) => (h(n) ? r.coherent.push(n) : r.incoherent.push(n), r),
8
+ { coherent: [], incoherent: [] }
9
+ )), c = t(() => u && !o(e).length || !u && f(o(e)) ? !0 : !s.value.incoherent.length);
10
+ return {
11
+ status: s,
12
+ coherent: c
13
+ };
14
+ };
5
15
  export {
6
- f as default
16
+ a as useCoherence
7
17
  };
package/dist/index243.js CHANGED
@@ -1,10 +1,5 @@
1
- const o = "bitboss-ui | ", e = () => ({
2
- warn: (r) => console.warn(`${o}${r}`),
3
- error: (r) => console.error(`${o}${r}`),
4
- throw: (r) => {
5
- throw new Error(`${o}${r}`);
6
- }
7
- });
1
+ import { hash as o } from "./index289.js";
2
+ const t = (r, h = "bb") => `${h}${o(r)}`;
8
3
  export {
9
- e as useLogger
4
+ t as hash
10
5
  };
package/dist/index244.js CHANGED
@@ -1,252 +1,14 @@
1
- import { defineComponent as le, ref as A, computed as _, watch as ce, createElementBlock as c, openBlock as u, withKeys as f, normalizeClass as k, withModifiers as p, createVNode as ue, withCtx as fe, createElementVNode as M, Fragment as O, renderList as S, toDisplayString as C, renderSlot as L, nextTick as pe } from "vue";
2
- import { chunk as be } from "./index347.js";
3
- import { identity as T } from "./index250.js";
4
- import { isNotNil as me } from "./index140.js";
5
- import { last as ge } from "./index211.js";
6
- import { sort as E } from "./index348.js";
7
- import b from "./index236.js";
8
- import he from "./index247.js";
9
- const ye = ["onKeydown"], _e = { class: "bb-base-date-picker__header-container" }, ke = ["abbr"], Oe = ["id", "disabled", "tabindex"], Ce = /* @__PURE__ */ le({
10
- __name: "BaseDatePickerInputDaySelector",
11
- props: {
12
- cursor: {},
13
- current: { type: Boolean },
14
- disabled: { type: Boolean },
15
- firstDayOfWeek: {},
16
- id: {},
17
- modelValue: {},
18
- max: {},
19
- min: {},
20
- selectable: { type: Function },
21
- range: { type: Boolean },
22
- multiple: { type: Boolean },
23
- readonly: { type: Boolean }
24
- },
25
- emits: ["update:modelValue", "update:cursor"],
26
- setup(N, { emit: x }) {
27
- const a = N, s = x, g = A(null), R = b().startOf("day"), m = _(() => {
28
- let e = 1 / 0, r = -1 / 0, o = {};
29
- return a.modelValue && [].concat(a.modelValue).filter(T).map((i) => b(i).startOf("day")).map((i) => i.valueOf()).forEach((i, h) => {
30
- i < e && (e = i), i > r && (r = i), o[i] = h;
31
- }), {
32
- min: e,
33
- max: r,
34
- index: (t) => o[t.valueOf()],
35
- selected: (t) => me(o[t.valueOf()]),
36
- isFirstOfRange: (t) => t.valueOf() === e,
37
- isLastOfRange: (t) => t.valueOf() === r,
38
- isBetween: (t) => t.valueOf() > e && t.valueOf() < r
39
- };
40
- }), K = _(() => new Array(7).fill("").map((e, r) => b().day((r + a.firstDayOfWeek) % 7)).map((e) => ({
41
- accessibleLabel: e.format("dddd"),
42
- label: e.format("dd").slice(0, 1).toUpperCase(),
43
- id: e.toISOString(),
44
- original: e
45
- }))), v = _(() => {
46
- const e = a.cursor.year().toString(), r = a.cursor.month().toString();
47
- let t = a.cursor.clone().startOf("month").clone().startOf("week"), h = a.cursor.clone().endOf("month").clone().endOf("week"), Z = b(a.cursor).startOf("day"), D = [];
48
- for (let n = t; n.isBefore(h); n = n.add(1, "day"))
49
- D.push(n.clone());
50
- const ee = D.map((n) => {
51
- const y = n.toISOString(), te = n.week().toString();
52
- let re = m.value.selected(n);
53
- const B = a.range && m.value.isFirstOfRange(n), I = a.range && m.value.isLastOfRange(n), ae = a.range && !B && !I && m.value.isBetween(n), oe = n.month().toString() === r && n.year().toString() === e, ne = n.isSame(R), se = n.isSame(Z), ie = d(n), de = n.get("D").toString();
54
- return {
55
- buttonId: [a.id, y].filter(T).join("_"),
56
- current: se,
57
- disabled: ie,
58
- first: B,
59
- highlighted: oe,
60
- id: y,
61
- label: de,
62
- last: I,
63
- middle: ae,
64
- original: n,
65
- selected: re,
66
- slotName: y,
67
- today: ne,
68
- week: te
69
- };
70
- });
71
- return be(ee, 7);
72
- }), d = (e) => {
73
- let r = !0;
74
- return a.min && r && (r = e.isSameOrAfter(b(a.min).startOf("day"))), a.max && r && (r = e.isSameOrBefore(b(a.max).startOf("day"))), typeof a.selectable == "function" && r && (r = a.selectable(e.toDate())), !r;
75
- }, w = A("left"), F = (e, r) => {
76
- e && r && (w.value = e.isBefore(r) ? "left" : "right");
77
- };
78
- ce(
79
- () => a.cursor,
80
- (e, r) => {
81
- F(e, r);
82
- }
83
- );
84
- const V = (e) => s("update:cursor", e), l = async () => {
85
- if (!g.value) return;
86
- await pe();
87
- const e = ge([
88
- ...g.value.querySelectorAll(
89
- ".bb-base-date-picker__date--current button"
90
- )
91
- ]);
92
- e instanceof HTMLElement && e.focus();
93
- }, H = (e) => {
94
- if (!a.readonly && e.target instanceof HTMLButtonElement) {
95
- const [, r] = e.target.id.split("_"), o = b(r);
96
- if (a.cursor.month() !== o.month()) {
97
- V(o);
98
- return;
99
- }
100
- const t = v.value.flat().find((i) => i.id === r);
101
- if (t.disabled) return;
102
- V(o), P(t);
103
- }
104
- }, P = (e) => {
105
- a.range ? U(e) : a.multiple ? j(e) : W(e);
106
- }, U = (e) => {
107
- if (!Array.isArray(a.modelValue)) return;
108
- const r = e.original.toISOString();
109
- if (a.modelValue.length !== 1) s("update:modelValue", [r]);
110
- else {
111
- const o = E([a.modelValue[0], e.original.toISOString()]);
112
- s("update:modelValue", o);
113
- }
114
- }, j = (e) => {
115
- if (Array.isArray(a.modelValue))
116
- if (e.selected) {
117
- const r = e.original.toISOString(), o = a.modelValue.filter((t) => t !== r);
118
- s("update:modelValue", o);
119
- } else {
120
- const r = E([...a.modelValue, e.original.toISOString()]);
121
- s("update:modelValue", r);
122
- }
123
- }, W = (e) => {
124
- e.selected ? s("update:modelValue", null) : s("update:modelValue", e.original.toISOString());
125
- }, $ = () => {
126
- const e = a.cursor.clone().add(1, "day");
127
- d(e) || (s("update:cursor", e), l());
128
- }, q = () => {
129
- const e = a.cursor.clone().subtract(1, "day");
130
- d(e) || (s("update:cursor", e), l());
131
- }, z = () => {
132
- const e = a.cursor.clone().subtract(1, "week");
133
- d(e) || (s("update:cursor", e), l());
134
- }, G = () => {
135
- const e = a.cursor.clone().add(1, "week");
136
- d(e) || (s("update:cursor", e), l());
137
- }, J = () => {
138
- const e = a.cursor.clone().endOf("week");
139
- d(e) || (s("update:cursor", e), l());
140
- }, Q = () => {
141
- const e = a.cursor.clone().startOf("week");
142
- d(e) || (s("update:cursor", e), l());
143
- }, X = (e) => {
144
- if (e.shiftKey) {
145
- const r = a.cursor.clone().subtract(1, "year");
146
- if (d(r)) return;
147
- s("update:cursor", r);
148
- } else {
149
- const r = a.cursor.clone().subtract(1, "month");
150
- if (d(r)) return;
151
- s("update:cursor", r);
152
- }
153
- l();
154
- }, Y = (e) => {
155
- if (e.shiftKey) {
156
- const r = a.cursor.clone().add(1, "year");
157
- if (d(r)) return;
158
- s("update:cursor", r);
159
- } else {
160
- const r = a.cursor.clone().add(1, "month");
161
- if (d(r)) return;
162
- s("update:cursor", r);
163
- }
164
- l();
165
- };
166
- return (e, r) => (u(), c("div", {
167
- ref_key: "calendar",
168
- ref: g,
169
- class: k(["bb-base-date-picker__days-selector", { "bb-base-date-picker__days-selector--hidden": !e.current }]),
170
- onKeydown: [
171
- f(p(G, ["prevent"]), ["down"]),
172
- f(p(J, ["prevent"]), ["end"]),
173
- f(p(Q, ["prevent"]), ["home"]),
174
- f(p(q, ["prevent"]), ["left"]),
175
- f(p(Y, ["prevent"]), ["page-down"]),
176
- f(p(X, ["prevent"]), ["page-up"]),
177
- f(p($, ["prevent"]), ["right"]),
178
- f(p(z, ["prevent"]), ["up"])
179
- ]
180
- }, [
181
- ue(he, {
182
- direction: w.value,
183
- gap: 30
184
- }, {
185
- default: fe(() => [
186
- (u(), c("div", {
187
- key: e.cursor.month().toString(),
188
- class: "bb-base-date-picker__month"
189
- }, [
190
- M("div", _e, [
191
- (u(!0), c(O, null, S(K.value, (o) => (u(), c("div", {
192
- key: o.id,
193
- abbr: o.accessibleLabel,
194
- class: "bb-base-date-picker__header-cell"
195
- }, C(o.label), 9, ke))), 128))
196
- ]),
197
- (u(!0), c(O, null, S(v.value, (o) => (u(), c("div", {
198
- key: o[0].id,
199
- class: "bb-base-date-picker__week"
200
- }, [
201
- (u(!0), c(O, null, S(o, (t) => (u(), c("div", {
202
- key: t.id,
203
- class: k({
204
- "bb-base-date-picker__date--current": t.current,
205
- "bb-base-date-picker__date--disabled": e.disabled || t.disabled,
206
- "bb-base-date-picker__date--first": t.first,
207
- "bb-base-date-picker__date--highlighted": t.highlighted,
208
- "bb-base-date-picker__date--last": t.last,
209
- "bb-base-date-picker__date--middle": t.middle,
210
- "bb-base-date-picker__date--selected": t.selected,
211
- "bb-base-date-picker__date--today": t.today,
212
- "bb-base-date-picker__date": !0
213
- })
214
- }, [
215
- M("button", {
216
- id: t.buttonId,
217
- class: k("bb-base-date-picker__date-button"),
218
- disabled: e.disabled || t.disabled,
219
- tabindex: Number(t.current) - 1,
220
- type: "button",
221
- onClick: H
222
- }, C(t.label), 9, Oe),
223
- L(e.$slots, "day", {
224
- first: t.first,
225
- highlighted: t.highlighted,
226
- item: t.original,
227
- label: t.label,
228
- last: t.last,
229
- middle: t.middle,
230
- selected: t.selected
231
- }),
232
- L(e.$slots, t.slotName, {
233
- first: t.first,
234
- highlighted: t.highlighted,
235
- item: t.original,
236
- label: t.label,
237
- last: t.last,
238
- middle: t.middle,
239
- selected: t.selected
240
- })
241
- ], 2))), 128))
242
- ]))), 128))
243
- ]))
244
- ]),
245
- _: 3
246
- }, 8, ["direction"])
247
- ], 42, ye));
248
- }
249
- });
1
+ import { hash as e } from "./index243.js";
2
+ import { debouncedWatch as s } from "./index206.js";
3
+ const n = (o, c, h) => {
4
+ s(
5
+ o,
6
+ (r, t) => {
7
+ e(r) !== e(t) && c(r, t);
8
+ },
9
+ h
10
+ );
11
+ };
250
12
  export {
251
- Ce as default
13
+ n as useHashedWatcher
252
14
  };