@7pmlabs/design-system 2.0.9 → 2.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +4 -4
- package/dist/design-system.css +1 -1
- package/dist/design-system.js +65 -59
- package/dist/design-system100.js +1 -1
- package/dist/design-system100.js.map +1 -1
- package/dist/design-system101.js +87 -53
- package/dist/design-system101.js.map +1 -1
- package/dist/design-system103.js +5 -13
- package/dist/design-system103.js.map +1 -1
- package/dist/design-system104.js +53 -108
- package/dist/design-system104.js.map +1 -1
- package/dist/{design-system102.js → design-system105.js} +1 -1
- package/dist/{design-system102.js.map → design-system105.js.map} +1 -1
- package/dist/design-system106.js +13 -6
- package/dist/design-system106.js.map +1 -1
- package/dist/design-system107.js +93 -190
- package/dist/design-system107.js.map +1 -1
- package/dist/design-system109.js +2 -2
- package/dist/design-system109.js.map +1 -1
- package/dist/design-system110.js +183 -484
- package/dist/design-system110.js.map +1 -1
- package/dist/design-system112.js +5 -4
- package/dist/design-system112.js.map +1 -1
- package/dist/design-system113.js +507 -7
- package/dist/design-system113.js.map +1 -1
- package/dist/design-system115.js +8 -0
- package/dist/design-system115.js.map +1 -0
- package/dist/design-system116.js +7 -6
- package/dist/design-system116.js.map +1 -1
- package/dist/design-system117.js +154 -169
- package/dist/design-system117.js.map +1 -1
- package/dist/design-system119.js +2 -2
- package/dist/design-system119.js.map +1 -1
- package/dist/design-system120.js +210 -149
- package/dist/design-system120.js.map +1 -1
- package/dist/design-system122.js +5 -4
- package/dist/design-system122.js.map +1 -1
- package/dist/design-system123.js +160 -9
- package/dist/design-system123.js.map +1 -1
- package/dist/design-system125.js +8 -0
- package/dist/design-system125.js.map +1 -0
- package/dist/design-system126.js +176 -6
- package/dist/design-system126.js.map +1 -1
- package/dist/design-system128.js +8 -0
- package/dist/design-system128.js.map +1 -0
- package/dist/design-system129.js +213 -5
- package/dist/design-system129.js.map +1 -1
- package/dist/design-system131.js +5 -90
- package/dist/design-system131.js.map +1 -1
- package/dist/design-system132.js +166 -0
- package/dist/design-system132.js.map +1 -0
- package/dist/design-system134.js +5 -42
- package/dist/design-system134.js.map +1 -1
- package/dist/design-system135.js +12 -0
- package/dist/design-system135.js.map +1 -0
- package/dist/design-system136.js +274 -5
- package/dist/design-system136.js.map +1 -1
- package/dist/design-system138.js +9 -0
- package/dist/{design-system124.js.map → design-system138.js.map} +1 -1
- package/dist/design-system139.js +16 -5
- package/dist/design-system139.js.map +1 -1
- package/dist/design-system141.js +8 -0
- package/dist/{design-system127.js.map → design-system141.js.map} +1 -1
- package/dist/design-system142.js +12 -5
- package/dist/design-system142.js.map +1 -1
- package/dist/design-system143.js +78 -83
- package/dist/design-system143.js.map +1 -1
- package/dist/design-system145.js +1 -1
- package/dist/design-system145.js.map +1 -1
- package/dist/design-system146.js +42 -9
- package/dist/design-system146.js.map +1 -1
- package/dist/design-system148.js +3 -2
- package/dist/design-system148.js.map +1 -1
- package/dist/design-system149.js +230 -18
- package/dist/design-system149.js.map +1 -1
- package/dist/design-system151.js +5 -158
- package/dist/design-system151.js.map +1 -1
- package/dist/{design-system140.js → design-system152.js} +6 -6
- package/dist/{design-system140.js.map → design-system152.js.map} +1 -1
- package/dist/design-system154.js +5 -307
- package/dist/design-system154.js.map +1 -1
- package/dist/design-system155.js +98 -0
- package/dist/design-system155.js.map +1 -0
- package/dist/design-system157.js +5 -240
- package/dist/design-system157.js.map +1 -1
- package/dist/design-system158.js +12 -0
- package/dist/design-system158.js.map +1 -0
- package/dist/design-system159.js +37 -5
- package/dist/design-system159.js.map +1 -1
- package/dist/design-system160.js +4 -189
- package/dist/design-system160.js.map +1 -1
- package/dist/design-system161.js +24 -0
- package/dist/{design-system150.js.map → design-system161.js.map} +1 -1
- package/dist/design-system162.js +2 -3
- package/dist/design-system162.js.map +1 -1
- package/dist/design-system163.js +158 -3
- package/dist/design-system163.js.map +1 -1
- package/dist/{design-system153.js → design-system165.js} +2 -2
- package/dist/{design-system153.js.map → design-system165.js.map} +1 -1
- package/dist/design-system166.js +307 -6
- package/dist/design-system166.js.map +1 -1
- package/dist/{design-system156.js → design-system168.js} +2 -2
- package/dist/{design-system156.js.map → design-system168.js.map} +1 -1
- package/dist/design-system169.js +167 -6
- package/dist/design-system169.js.map +1 -1
- package/dist/design-system171.js +8 -0
- package/dist/design-system171.js.map +1 -0
- package/dist/design-system172.js +240 -6
- package/dist/design-system172.js.map +1 -1
- package/dist/design-system174.js +8 -0
- package/dist/design-system174.js.map +1 -0
- package/dist/design-system175.js +189 -6
- package/dist/design-system175.js.map +1 -1
- package/dist/design-system177.js +8 -0
- package/dist/design-system177.js.map +1 -0
- package/dist/design-system178.js +3 -5
- package/dist/design-system178.js.map +1 -1
- package/dist/design-system179.js +58 -11
- package/dist/design-system179.js.map +1 -1
- package/dist/design-system181.js +9 -0
- package/dist/design-system181.js.map +1 -0
- package/dist/design-system182.js +56 -6
- package/dist/design-system182.js.map +1 -1
- package/dist/design-system184.js +9 -0
- package/dist/{design-system167.js.map → design-system184.js.map} +1 -1
- package/dist/design-system185.js +69 -5
- package/dist/design-system185.js.map +1 -1
- package/dist/design-system187.js +9 -0
- package/dist/{design-system170.js.map → design-system187.js.map} +1 -1
- package/dist/design-system188.js +182 -5
- package/dist/design-system188.js.map +1 -1
- package/dist/design-system190.js +9 -0
- package/dist/design-system190.js.map +1 -0
- package/dist/design-system191.js +115 -5
- package/dist/design-system191.js.map +1 -1
- package/dist/design-system193.js +8 -0
- package/dist/{design-system176.js.map → design-system193.js.map} +1 -1
- package/dist/design-system194.js +11 -5
- package/dist/design-system194.js.map +1 -1
- package/dist/design-system195.js +453 -24
- package/dist/design-system195.js.map +1 -1
- package/dist/design-system197.js +5 -4
- package/dist/design-system197.js.map +1 -1
- package/dist/design-system198.js +20 -16
- package/dist/design-system198.js.map +1 -1
- package/dist/design-system200.js +1 -1
- package/dist/design-system200.js.map +1 -1
- package/dist/design-system201.js +70 -314
- package/dist/design-system201.js.map +1 -1
- package/dist/design-system203.js +1 -1
- package/dist/design-system203.js.map +1 -1
- package/dist/design-system204.js +24 -89
- package/dist/design-system204.js.map +1 -1
- package/dist/design-system206.js +1 -1
- package/dist/design-system206.js.map +1 -1
- package/dist/design-system207.js +26 -17
- package/dist/design-system207.js.map +1 -1
- package/dist/design-system209.js +5 -3
- package/dist/design-system209.js.map +1 -1
- package/dist/design-system210.js +22 -408
- package/dist/design-system210.js.map +1 -1
- package/dist/design-system212.js +1 -1
- package/dist/design-system212.js.map +1 -1
- package/dist/design-system213.js +24 -52
- package/dist/design-system213.js.map +1 -1
- package/dist/design-system215.js +1 -1
- package/dist/design-system215.js.map +1 -1
- package/dist/design-system216.js +329 -85
- package/dist/design-system216.js.map +1 -1
- package/dist/design-system218.js +5 -108
- package/dist/design-system218.js.map +1 -1
- package/dist/design-system219.js +103 -0
- package/dist/design-system219.js.map +1 -0
- package/dist/design-system221.js +5 -106
- package/dist/design-system221.js.map +1 -1
- package/dist/design-system222.js +22 -0
- package/dist/{design-system208.js.map → design-system222.js.map} +1 -1
- package/dist/design-system223.js +4 -6
- package/dist/design-system223.js.map +1 -1
- package/dist/design-system224.js +3 -737
- package/dist/design-system224.js.map +1 -1
- package/dist/design-system225.js +422 -0
- package/dist/design-system225.js.map +1 -0
- package/dist/design-system227.js +5 -11
- package/dist/design-system227.js.map +1 -1
- package/dist/design-system228.js +51 -517
- package/dist/design-system228.js.map +1 -1
- package/dist/design-system230.js +1 -1
- package/dist/design-system230.js.map +1 -1
- package/dist/design-system231.js +88 -3
- package/dist/design-system231.js.map +1 -1
- package/dist/design-system232.js +4 -46
- package/dist/design-system232.js.map +1 -1
- package/dist/design-system233.js +108 -4
- package/dist/design-system233.js.map +1 -1
- package/dist/{design-system220.js → design-system235.js} +2 -2
- package/dist/{design-system220.js.map → design-system235.js.map} +1 -1
- package/dist/design-system236.js +106 -5
- package/dist/design-system236.js.map +1 -1
- package/dist/design-system238.js +9 -0
- package/dist/design-system238.js.map +1 -0
- package/dist/design-system239.js +737 -5
- package/dist/design-system239.js.map +1 -1
- package/dist/{design-system226.js → design-system241.js} +2 -2
- package/dist/{design-system226.js.map → design-system241.js.map} +1 -1
- package/dist/design-system242.js +3 -5
- package/dist/design-system242.js.map +1 -1
- package/dist/design-system243.js +42 -50
- package/dist/design-system243.js.map +1 -1
- package/dist/design-system244.js +1 -1
- package/dist/design-system244.js.map +1 -1
- package/dist/design-system245.js +254 -141
- package/dist/design-system245.js.map +1 -1
- package/dist/design-system247.js +1 -1
- package/dist/design-system247.js.map +1 -1
- package/dist/design-system248.js +119 -7
- package/dist/design-system248.js.map +1 -1
- package/dist/design-system250.js +8 -0
- package/dist/design-system250.js.map +1 -0
- package/dist/design-system251.js +172 -5
- package/dist/design-system251.js.map +1 -1
- package/dist/design-system253.js +8 -0
- package/dist/design-system253.js.map +1 -0
- package/dist/design-system254.js +11 -6
- package/dist/design-system254.js.map +1 -1
- package/dist/design-system255.js +525 -9
- package/dist/design-system255.js.map +1 -1
- package/dist/design-system257.js +8 -0
- package/dist/design-system257.js.map +1 -0
- package/dist/design-system258.js +112 -6
- package/dist/design-system258.js.map +1 -1
- package/dist/design-system260.js +5 -374
- package/dist/design-system260.js.map +1 -1
- package/dist/design-system261.js +57 -0
- package/dist/design-system261.js.map +1 -0
- package/dist/design-system262.js +4 -6
- package/dist/design-system262.js.map +1 -1
- package/dist/design-system263.js +173 -0
- package/dist/design-system263.js.map +1 -0
- package/dist/design-system265.js +8 -0
- package/dist/design-system265.js.map +1 -0
- package/dist/design-system266.js +10 -0
- package/dist/design-system266.js.map +1 -0
- package/dist/{design-system249.js → design-system267.js} +2 -2
- package/dist/{design-system249.js.map → design-system267.js.map} +1 -1
- package/dist/design-system269.js +8 -0
- package/dist/design-system269.js.map +1 -0
- package/dist/{design-system252.js → design-system270.js} +1 -1
- package/dist/{design-system252.js.map → design-system270.js.map} +1 -1
- package/dist/design-system272.js +9 -0
- package/dist/design-system272.js.map +1 -0
- package/dist/design-system273.js +12 -0
- package/dist/design-system273.js.map +1 -0
- package/dist/{design-system256.js → design-system274.js} +2 -2
- package/dist/{design-system256.js.map → design-system274.js.map} +1 -1
- package/dist/design-system276.js +9 -0
- package/dist/design-system276.js.map +1 -0
- package/dist/{design-system259.js → design-system277.js} +1 -1
- package/dist/{design-system259.js.map → design-system277.js.map} +1 -1
- package/dist/design-system278.js +377 -0
- package/dist/design-system278.js.map +1 -0
- package/dist/design-system280.js +9 -0
- package/dist/design-system280.js.map +1 -0
- package/dist/design-system69.js +182 -13
- package/dist/design-system69.js.map +1 -1
- package/dist/design-system71.js +8 -0
- package/dist/design-system71.js.map +1 -0
- package/dist/design-system72.js +13 -5
- package/dist/design-system72.js.map +1 -1
- package/dist/design-system73.js +677 -139
- package/dist/design-system73.js.map +1 -1
- package/dist/design-system75.js +1 -1
- package/dist/design-system75.js.map +1 -1
- package/dist/design-system76.js +152 -23
- package/dist/design-system76.js.map +1 -1
- package/dist/design-system78.js +5 -49
- package/dist/design-system78.js.map +1 -1
- package/dist/design-system79.js +32 -0
- package/dist/design-system79.js.map +1 -0
- package/dist/design-system80.js +2 -3
- package/dist/design-system80.js.map +1 -1
- package/dist/design-system81.js +38 -188
- package/dist/design-system81.js.map +1 -1
- package/dist/design-system83.js +1 -1
- package/dist/design-system83.js.map +1 -1
- package/dist/design-system84.js +199 -7
- package/dist/design-system84.js.map +1 -1
- package/dist/design-system86.js +8 -0
- package/dist/design-system86.js.map +1 -0
- package/dist/design-system87.js +7 -5
- package/dist/design-system87.js.map +1 -1
- package/dist/design-system88.js +264 -48
- package/dist/design-system88.js.map +1 -1
- package/dist/design-system90.js +1 -1
- package/dist/design-system90.js.map +1 -1
- package/dist/design-system91.js +57 -11
- package/dist/design-system91.js.map +1 -1
- package/dist/design-system93.js +8 -0
- package/dist/design-system93.js.map +1 -0
- package/dist/design-system94.js +11 -5
- package/dist/design-system94.js.map +1 -1
- package/dist/design-system95.js +92 -59
- package/dist/design-system95.js.map +1 -1
- package/dist/design-system97.js +1 -1
- package/dist/design-system97.js.map +1 -1
- package/dist/design-system98.js +56 -78
- package/dist/design-system98.js.map +1 -1
- package/dist/types/components/BContextMenu/BContextMenu.spec.d.ts +1 -0
- package/dist/types/components/BContextMenu/BContextMenu.vue.d.ts +42 -0
- package/dist/types/components/BContextMenu/index.d.ts +2 -0
- package/dist/types/components/BContextMenu/types.d.ts +23 -0
- package/dist/types/components/BInputTags/BInputTags.spec.d.ts +1 -0
- package/dist/types/components/BInputTags/BInputTags.vue.d.ts +54 -0
- package/dist/types/components/BInputTags/index.d.ts +1 -0
- package/dist/types/components/BLink/BLink.spec.d.ts +1 -0
- package/dist/types/components/BLink/BLink.vue.d.ts +100 -0
- package/dist/types/components/BLink/index.d.ts +1 -0
- package/dist/types/components/BListbox/BListbox.spec.d.ts +1 -0
- package/dist/types/components/BListbox/BListbox.vue.d.ts +52 -0
- package/dist/types/components/BListbox/index.d.ts +1 -0
- package/dist/types/components/BModal/BModal.spec.d.ts +1 -0
- package/dist/types/components/BPinInput/BPinInput.spec.d.ts +1 -0
- package/dist/types/components/BPinInput/BPinInput.vue.d.ts +43 -0
- package/dist/types/components/BPinInput/index.d.ts +1 -0
- package/dist/types/components/BProgress/BProgress.vue.d.ts +47 -2
- package/dist/types/components/BTextarea/BTextarea.spec.d.ts +1 -0
- package/dist/types/components/BTextarea/BTextarea.vue.d.ts +77 -0
- package/dist/types/components/BTextarea/index.d.ts +1 -0
- package/dist/types/components/index.d.ts +7 -1
- package/package.json +1 -1
- package/dist/design-system114.js +0 -212
- package/dist/design-system114.js.map +0 -1
- package/dist/design-system124.js +0 -277
- package/dist/design-system127.js +0 -19
- package/dist/design-system130.js +0 -15
- package/dist/design-system130.js.map +0 -1
- package/dist/design-system133.js +0 -8
- package/dist/design-system133.js.map +0 -1
- package/dist/design-system137.js +0 -236
- package/dist/design-system137.js.map +0 -1
- package/dist/design-system147.js +0 -40
- package/dist/design-system147.js.map +0 -1
- package/dist/design-system150.js +0 -7
- package/dist/design-system164.js +0 -61
- package/dist/design-system164.js.map +0 -1
- package/dist/design-system167.js +0 -59
- package/dist/design-system170.js +0 -72
- package/dist/design-system173.js +0 -185
- package/dist/design-system173.js.map +0 -1
- package/dist/design-system176.js +0 -118
- package/dist/design-system180.js +0 -465
- package/dist/design-system180.js.map +0 -1
- package/dist/design-system183.js +0 -38
- package/dist/design-system183.js.map +0 -1
- package/dist/design-system186.js +0 -91
- package/dist/design-system186.js.map +0 -1
- package/dist/design-system189.js +0 -38
- package/dist/design-system189.js.map +0 -1
- package/dist/design-system192.js +0 -31
- package/dist/design-system192.js.map +0 -1
- package/dist/design-system208.js +0 -7
- package/dist/design-system217.js +0 -7
- package/dist/design-system217.js.map +0 -1
- package/dist/design-system234.js +0 -286
- package/dist/design-system234.js.map +0 -1
- package/dist/design-system237.js +0 -122
- package/dist/design-system237.js.map +0 -1
- package/dist/design-system240.js +0 -115
- package/dist/design-system240.js.map +0 -1
- package/dist/design-system70.js +0 -699
- package/dist/design-system70.js.map +0 -1
- package/dist/design-system77.js +0 -7
- package/dist/design-system77.js.map +0 -1
- package/dist/design-system85.js +0 -276
- package/dist/design-system85.js.map +0 -1
- package/dist/design-system92.js +0 -102
- package/dist/design-system92.js.map +0 -1
package/dist/design-system129.js
CHANGED
|
@@ -1,8 +1,216 @@
|
|
|
1
|
-
import e from "./design-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
1
|
+
import { BCommonSize as e } from "./design-system3.js";
|
|
2
|
+
import { useComponentId as t } from "./design-system10.js";
|
|
3
|
+
import { Fragment as n, computed as r, createElementBlock as i, createElementVNode as a, defineComponent as o, mergeModels as s, nextTick as ee, normalizeClass as c, openBlock as l, ref as u, renderList as d, toDisplayString as f, useAttrs as p, useModel as m, watch as h } from "vue";
|
|
4
|
+
//#region src/components/BListbox/BListbox.vue?vue&type=script&setup=true&lang.ts
|
|
5
|
+
var g = [
|
|
6
|
+
"id",
|
|
7
|
+
"tabindex",
|
|
8
|
+
"aria-label",
|
|
9
|
+
"aria-multiselectable",
|
|
10
|
+
"aria-disabled",
|
|
11
|
+
"aria-activedescendant"
|
|
12
|
+
], _ = {
|
|
13
|
+
key: 0,
|
|
14
|
+
role: "presentation",
|
|
15
|
+
class: "b-listbox__group"
|
|
16
|
+
}, v = {
|
|
17
|
+
class: "b-listbox__group-label",
|
|
18
|
+
"aria-hidden": !0
|
|
19
|
+
}, y = ["aria-label"], b = [
|
|
20
|
+
"id",
|
|
21
|
+
"aria-selected",
|
|
22
|
+
"aria-disabled",
|
|
23
|
+
"onClick",
|
|
24
|
+
"onMouseenter"
|
|
25
|
+
], te = [
|
|
26
|
+
"id",
|
|
27
|
+
"aria-selected",
|
|
28
|
+
"aria-disabled",
|
|
29
|
+
"onClick",
|
|
30
|
+
"onMouseenter"
|
|
31
|
+
], x = /* @__PURE__ */ o({
|
|
32
|
+
__name: "BListbox",
|
|
33
|
+
props: /* @__PURE__ */ s({
|
|
34
|
+
options: {},
|
|
35
|
+
multiple: { type: Boolean },
|
|
36
|
+
disabled: { type: Boolean },
|
|
37
|
+
size: {},
|
|
38
|
+
valueKey: {},
|
|
39
|
+
labelKey: {},
|
|
40
|
+
id: {}
|
|
41
|
+
}, {
|
|
42
|
+
modelValue: { default: null },
|
|
43
|
+
modelModifiers: {}
|
|
44
|
+
}),
|
|
45
|
+
emits: /* @__PURE__ */ s(["change"], ["update:modelValue"]),
|
|
46
|
+
setup(o, { expose: s, emit: x }) {
|
|
47
|
+
let S = o, C = x, w = m(o, "modelValue"), T = r(() => S.options ?? []), E = r(() => S.multiple ?? !1), D = r(() => S.disabled ?? !1), O = r(() => S.size ?? e.Medium), k = r(() => S.valueKey ?? "value"), A = r(() => S.labelKey ?? "label"), { componentUID: j } = t(), M = r(() => S.id ?? `b-listbox-${j.value}`), N = (e) => `${M.value}-option-${e}`, P = u(null), F = u(-1), I = u(""), L = null, R = (e) => {
|
|
48
|
+
let t = e[k.value];
|
|
49
|
+
return t === void 0 ? e.value : t;
|
|
50
|
+
}, z = (e) => {
|
|
51
|
+
let t = e[A.value];
|
|
52
|
+
return typeof t == "string" && t.length > 0 ? t : e.label;
|
|
53
|
+
}, B = (e) => {
|
|
54
|
+
let t = R(e);
|
|
55
|
+
return E.value ? Array.isArray(w.value) && w.value.includes(t) : w.value === t;
|
|
56
|
+
}, V = (e) => e ? !!e.disabled || D.value : !0, H = r(() => {
|
|
57
|
+
let e = [], t = null;
|
|
58
|
+
return T.value.forEach((n, r) => {
|
|
59
|
+
let i = {
|
|
60
|
+
type: "option",
|
|
61
|
+
option: n,
|
|
62
|
+
index: r,
|
|
63
|
+
group: n.group
|
|
64
|
+
};
|
|
65
|
+
n.group ? ((!t || t.group !== n.group) && (t = {
|
|
66
|
+
type: "group",
|
|
67
|
+
group: n.group,
|
|
68
|
+
rows: []
|
|
69
|
+
}, e.push(t)), t.rows.push(i)) : (t = null, e.push(i));
|
|
70
|
+
}), e;
|
|
71
|
+
}), U = (e) => {
|
|
72
|
+
let t = T.value[e];
|
|
73
|
+
if (!t || V(t)) return;
|
|
74
|
+
let n = R(t);
|
|
75
|
+
if (E.value) {
|
|
76
|
+
let e = Array.isArray(w.value) ? [...w.value] : [], t = e.indexOf(n);
|
|
77
|
+
t === -1 ? e.push(n) : e.splice(t, 1), w.value = e, C("change", e);
|
|
78
|
+
} else w.value = n, C("change", n);
|
|
79
|
+
}, W = (e, t) => {
|
|
80
|
+
let n = T.value;
|
|
81
|
+
if (n.length === 0) return -1;
|
|
82
|
+
let r = e;
|
|
83
|
+
for (let e = 0; e < n.length; e++) if (r = (r + t + n.length) % n.length, !V(n[r])) return r;
|
|
84
|
+
return -1;
|
|
85
|
+
}, G = () => {
|
|
86
|
+
let e = T.value;
|
|
87
|
+
for (let t = 0; t < e.length; t++) if (!V(e[t])) return t;
|
|
88
|
+
return -1;
|
|
89
|
+
}, K = () => {
|
|
90
|
+
let e = T.value;
|
|
91
|
+
for (let t = e.length - 1; t >= 0; t--) if (!V(e[t])) return t;
|
|
92
|
+
return -1;
|
|
93
|
+
}, q = () => {
|
|
94
|
+
let e = T.value;
|
|
95
|
+
(F.value === -1 || V(e[F.value])) && (F.value = G());
|
|
96
|
+
}, J = async () => {
|
|
97
|
+
if (await ee(), F.value < 0 || !P.value) return;
|
|
98
|
+
let e = typeof CSS < "u" && typeof CSS.escape == "function" ? CSS.escape : (e) => e.replace(/[^a-zA-Z0-9_-]/g, "\\$&"), t = P.value.querySelector(`#${e(N(F.value))}`);
|
|
99
|
+
if (t && typeof t.scrollIntoView == "function") try {
|
|
100
|
+
t.scrollIntoView({ block: "nearest" });
|
|
101
|
+
} catch {}
|
|
102
|
+
}, Y = (e) => {
|
|
103
|
+
L && clearTimeout(L), I.value += e.toLowerCase(), L = setTimeout(() => {
|
|
104
|
+
I.value = "";
|
|
105
|
+
}, 500);
|
|
106
|
+
let t = T.value, n = I.value, r = F.value === -1 ? 0 : F.value + (n.length === 1 ? 1 : 0);
|
|
107
|
+
for (let e = 0; e < t.length; e++) {
|
|
108
|
+
let i = (r + e) % t.length, a = t[i];
|
|
109
|
+
if (!V(a) && z(a).toLowerCase().startsWith(n)) {
|
|
110
|
+
F.value = i, J();
|
|
111
|
+
return;
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
}, X = (e) => {
|
|
115
|
+
if (!D.value && T.value.length !== 0) switch (e.key) {
|
|
116
|
+
case "ArrowDown": {
|
|
117
|
+
e.preventDefault();
|
|
118
|
+
let t = W(F.value === -1 ? -1 : F.value, 1);
|
|
119
|
+
t !== -1 && (F.value = t), J();
|
|
120
|
+
break;
|
|
121
|
+
}
|
|
122
|
+
case "ArrowUp": {
|
|
123
|
+
e.preventDefault();
|
|
124
|
+
let t = W(F.value === -1 ? 0 : F.value, -1);
|
|
125
|
+
t !== -1 && (F.value = t), J();
|
|
126
|
+
break;
|
|
127
|
+
}
|
|
128
|
+
case "Home":
|
|
129
|
+
e.preventDefault(), F.value = G(), J();
|
|
130
|
+
break;
|
|
131
|
+
case "End":
|
|
132
|
+
e.preventDefault(), F.value = K(), J();
|
|
133
|
+
break;
|
|
134
|
+
case "Enter":
|
|
135
|
+
case " ":
|
|
136
|
+
e.preventDefault(), q(), F.value !== -1 && U(F.value);
|
|
137
|
+
break;
|
|
138
|
+
default: e.key.length === 1 && !e.ctrlKey && !e.metaKey && !e.altKey && (e.preventDefault(), Y(e.key));
|
|
139
|
+
}
|
|
140
|
+
}, Z = (e) => {
|
|
141
|
+
D.value || V(T.value[e]) || (F.value = e, U(e));
|
|
142
|
+
}, Q = (e) => {
|
|
143
|
+
D.value || V(T.value[e]) || (F.value = e);
|
|
144
|
+
}, ne = () => {
|
|
145
|
+
if (F.value === -1) {
|
|
146
|
+
let e = T.value.findIndex((e) => B(e) && !V(e));
|
|
147
|
+
F.value = e === -1 ? G() : e;
|
|
148
|
+
}
|
|
149
|
+
};
|
|
150
|
+
s({
|
|
151
|
+
focus: () => {
|
|
152
|
+
P.value?.focus();
|
|
153
|
+
},
|
|
154
|
+
focusOption: (e) => {
|
|
155
|
+
let t = T.value.findIndex((t) => R(t) === e);
|
|
156
|
+
t !== -1 && !V(T.value[t]) && (F.value = t, P.value?.focus(), J());
|
|
157
|
+
}
|
|
158
|
+
}), h(() => T.value.length, (e) => {
|
|
159
|
+
F.value >= e && (F.value = -1);
|
|
160
|
+
});
|
|
161
|
+
let re = r(() => F.value >= 0 ? N(F.value) : void 0), $ = p(), ie = r(() => {
|
|
162
|
+
if (!($["aria-label"] || $["aria-labelledby"])) return "Options";
|
|
163
|
+
});
|
|
164
|
+
return (e, t) => (l(), i("ul", {
|
|
165
|
+
id: M.value,
|
|
166
|
+
ref_key: "listboxRef",
|
|
167
|
+
ref: P,
|
|
168
|
+
role: "listbox",
|
|
169
|
+
class: c(["b-listbox", [`b-listbox--${O.value}`, {
|
|
170
|
+
"b-listbox--disabled": D.value,
|
|
171
|
+
"b-listbox--multiple": E.value
|
|
172
|
+
}]]),
|
|
173
|
+
tabindex: D.value ? -1 : 0,
|
|
174
|
+
"aria-label": ie.value,
|
|
175
|
+
"aria-multiselectable": E.value || void 0,
|
|
176
|
+
"aria-disabled": D.value || void 0,
|
|
177
|
+
"aria-activedescendant": re.value,
|
|
178
|
+
onKeydown: X,
|
|
179
|
+
onFocus: ne
|
|
180
|
+
}, [(l(!0), i(n, null, d(H.value, (e, t) => (l(), i(n, { key: t }, [e.type === "group" ? (l(), i("li", _, [a("span", v, f(e.group), 1), a("ul", {
|
|
181
|
+
role: "group",
|
|
182
|
+
"aria-label": e.group,
|
|
183
|
+
class: "b-listbox__group-list"
|
|
184
|
+
}, [(l(!0), i(n, null, d(e.rows, (e) => (l(), i("li", {
|
|
185
|
+
id: N(e.index),
|
|
186
|
+
key: e.index,
|
|
187
|
+
role: "option",
|
|
188
|
+
class: c(["b-listbox__option", {
|
|
189
|
+
"b-listbox__option--selected": B(e.option),
|
|
190
|
+
"b-listbox__option--active": F.value === e.index,
|
|
191
|
+
"b-listbox__option--disabled": V(e.option)
|
|
192
|
+
}]),
|
|
193
|
+
"aria-selected": B(e.option),
|
|
194
|
+
"aria-disabled": V(e.option) || void 0,
|
|
195
|
+
onClick: (t) => Z(e.index),
|
|
196
|
+
onMouseenter: (t) => Q(e.index)
|
|
197
|
+
}, f(z(e.option)), 43, b))), 128))], 8, y)])) : (l(), i("li", {
|
|
198
|
+
id: N(e.index),
|
|
199
|
+
key: `opt-${e.index}`,
|
|
200
|
+
role: "option",
|
|
201
|
+
class: c(["b-listbox__option", {
|
|
202
|
+
"b-listbox__option--selected": B(e.option),
|
|
203
|
+
"b-listbox__option--active": F.value === e.index,
|
|
204
|
+
"b-listbox__option--disabled": V(e.option)
|
|
205
|
+
}]),
|
|
206
|
+
"aria-selected": B(e.option),
|
|
207
|
+
"aria-disabled": V(e.option) || void 0,
|
|
208
|
+
onClick: (t) => Z(e.index),
|
|
209
|
+
onMouseenter: (t) => Q(e.index)
|
|
210
|
+
}, f(z(e.option)), 43, te))], 64))), 128))], 42, g));
|
|
211
|
+
}
|
|
212
|
+
});
|
|
5
213
|
//#endregion
|
|
6
|
-
export {
|
|
214
|
+
export { x as default };
|
|
7
215
|
|
|
8
216
|
//# sourceMappingURL=design-system129.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"design-system129.js","names":[],"sources":["../src/components/BMenu/BMenuDivider.vue"],"sourcesContent":["<script setup lang=\"ts\">\n// ─────────────────────────────────────────────\n// Props\n// ─────────────────────────────────────────────\nconst { dashed = false } = defineProps<{\n /** Whether divider line is dashed. @default false */\n dashed?: boolean;\n}>();\n</script>\n\n<template>\n <li :class=\"['b-menu-divider', { 'b-menu-divider--dashed': dashed }]\" role=\"separator\" />\n</template>\n\n<style>\n/* ─────────────────────────────────────────────\n BMenuDivider\n ───────────────────────────────────────────── */\n.b-menu-divider {\n height: 1px;\n margin: 4px 12px;\n background: rgba(5, 5, 5, 0.06);\n list-style: none;\n}\n\n.b-menu-divider--dashed {\n background: none;\n border-top: 1px dashed rgba(5, 5, 5, 0.06);\n}\n\n[data-prefers-color='dark'] .b-menu-divider,\n.b-menu--dark .b-menu-divider {\n background: rgba(253, 253, 253, 0.12);\n}\n\n[data-prefers-color='dark'] .b-menu-divider--dashed,\n.b-menu--dark .b-menu-divider--dashed {\n background: none;\n border-top-color: rgba(253, 253, 253, 0.12);\n}\n\n@media (prefers-color-scheme: dark) {\n [data-prefers-color='system'] .b-menu-divider {\n background: rgba(253, 253, 253, 0.12);\n }\n\n [data-prefers-color='system'] .b-menu-divider--dashed {\n background: none;\n border-top-color: rgba(253, 253, 253, 0.12);\n }\n}\n</style>\n"],"mappings":""}
|
|
1
|
+
{"version":3,"file":"design-system129.js","names":[],"sources":["../src/components/BListbox/BListbox.vue"],"sourcesContent":["<script setup lang=\"ts\" generic=\"T\">\nimport { useComponentId } from '@/composables/useComponentId.ts';\nimport { BCommonSize } from '@/types.ts';\nimport { computed, nextTick, ref, useAttrs, watch } from 'vue';\n\nexport interface BListboxOption<V> {\n /** Display label for the option. */\n label: string;\n /** Value associated with the option. */\n value: V;\n /** Whether the option is disabled and skipped by keyboard navigation. */\n disabled?: boolean;\n /** Optional group label — adjacent options sharing the same group are wrapped together. */\n group?: string;\n}\n\nconst props = defineProps<{\n /** Array of selectable options. */\n options?: BListboxOption<T>[];\n /** Whether multiple options can be selected at once. */\n multiple?: boolean;\n /** Disables the entire listbox — no keyboard nav, no selection. */\n disabled?: boolean;\n /** Visual size preset. */\n size?: `${BCommonSize}`;\n /** Property name on each option that holds the value. Defaults to `'value'`. */\n valueKey?: string;\n /** Property name on each option that holds the label. Defaults to `'label'`. */\n labelKey?: string;\n /** Optional id for the root listbox element. Auto-generated if omitted. */\n id?: string;\n}>();\n\nconst emit = defineEmits<{\n /** Emitted whenever the selection changes. Single value or array depending on `multiple`. */\n change: [value: T | T[]];\n}>();\n\nconst model = defineModel<T | T[] | null>({ default: null });\n\n// ─── Reactive accessors with defaults ───\nconst optionList = computed<BListboxOption<T>[]>(() => props.options ?? []);\nconst isMultiple = computed(() => props.multiple ?? false);\nconst isDisabled = computed(() => props.disabled ?? false);\nconst sizeClass = computed(() => props.size ?? BCommonSize.Medium);\nconst valueKeyName = computed(() => props.valueKey ?? 'value');\nconst labelKeyName = computed(() => props.labelKey ?? 'label');\n\nconst { componentUID } = useComponentId();\nconst listboxId = computed(() => props.id ?? `b-listbox-${componentUID.value}`);\nconst optionId = (index: number) => `${listboxId.value}-option-${index}`;\n\nconst listboxRef = ref<HTMLUListElement | null>(null);\nconst activeIndex = ref<number>(-1);\n\n// Type-ahead buffer\nconst typeAheadBuffer = ref('');\nlet typeAheadTimer: ReturnType<typeof setTimeout> | null = null;\n\n// ─────────────────────────────────────────────\n// Helpers\n// ─────────────────────────────────────────────\nconst getOptionValue = (opt: BListboxOption<T>): T => {\n const key = valueKeyName.value;\n const fromKey = (opt as unknown as Record<string, T>)[key];\n return fromKey !== undefined ? fromKey : opt.value;\n};\n\nconst getOptionLabel = (opt: BListboxOption<T>): string => {\n const key = labelKeyName.value;\n const raw = (opt as unknown as Record<string, unknown>)[key];\n if (typeof raw === 'string' && raw.length > 0) return raw;\n return opt.label;\n};\n\nconst isOptionSelected = (opt: BListboxOption<T>): boolean => {\n const v = getOptionValue(opt);\n if (isMultiple.value) {\n return Array.isArray(model.value) && model.value.includes(v);\n }\n return model.value === v;\n};\n\nconst isOptionDisabled = (opt: BListboxOption<T> | undefined): boolean => {\n if (!opt) return true;\n return !!opt.disabled || isDisabled.value;\n};\n\n// ─────────────────────────────────────────────\n// Grouped rendering structure\n// ─────────────────────────────────────────────\ninterface RenderRow {\n type: 'option';\n option: BListboxOption<T>;\n index: number;\n group?: string;\n}\ninterface RenderGroup {\n type: 'group';\n group: string;\n rows: RenderRow[];\n}\ntype RenderItem = RenderGroup | RenderRow;\n\nconst renderItems = computed<RenderItem[]>(() => {\n const result: RenderItem[] = [];\n let currentGroup: RenderGroup | null = null;\n optionList.value.forEach((opt, index) => {\n const row: RenderRow = { type: 'option', option: opt, index, group: opt.group };\n if (opt.group) {\n if (!currentGroup || currentGroup.group !== opt.group) {\n currentGroup = { type: 'group', group: opt.group, rows: [] };\n result.push(currentGroup);\n }\n currentGroup.rows.push(row);\n } else {\n currentGroup = null;\n result.push(row);\n }\n });\n return result;\n});\n\n// ─────────────────────────────────────────────\n// Selection\n// ─────────────────────────────────────────────\nconst selectIndex = (index: number) => {\n const opt = optionList.value[index];\n if (!opt || isOptionDisabled(opt)) return;\n const v = getOptionValue(opt);\n\n if (isMultiple.value) {\n const current = Array.isArray(model.value) ? [...model.value] : [];\n const i = current.indexOf(v);\n if (i === -1) {\n current.push(v);\n } else {\n current.splice(i, 1);\n }\n model.value = current;\n emit('change', current);\n } else {\n model.value = v;\n emit('change', v);\n }\n};\n\n// ─────────────────────────────────────────────\n// Keyboard navigation\n// ─────────────────────────────────────────────\nconst findNextEnabled = (from: number, dir: 1 | -1): number => {\n const list = optionList.value;\n if (list.length === 0) return -1;\n let i = from;\n for (let n = 0; n < list.length; n++) {\n i = (i + dir + list.length) % list.length;\n if (!isOptionDisabled(list[i])) return i;\n }\n return -1;\n};\n\nconst findFirstEnabled = (): number => {\n const list = optionList.value;\n for (let i = 0; i < list.length; i++) {\n if (!isOptionDisabled(list[i])) return i;\n }\n return -1;\n};\n\nconst findLastEnabled = (): number => {\n const list = optionList.value;\n for (let i = list.length - 1; i >= 0; i--) {\n if (!isOptionDisabled(list[i])) return i;\n }\n return -1;\n};\n\nconst ensureActiveIndex = () => {\n const list = optionList.value;\n if (activeIndex.value === -1 || isOptionDisabled(list[activeIndex.value])) {\n activeIndex.value = findFirstEnabled();\n }\n};\n\nconst scrollActiveIntoView = async () => {\n await nextTick();\n if (activeIndex.value < 0) return;\n if (!listboxRef.value) return;\n const escape = typeof CSS !== 'undefined' && typeof CSS.escape === 'function'\n ? CSS.escape\n : (s: string) => s.replace(/[^a-zA-Z0-9_-]/g, '\\\\$&');\n const el = listboxRef.value.querySelector<HTMLElement>(`#${escape(optionId(activeIndex.value))}`);\n // jsdom and some embedded environments don't implement scrollIntoView — guard so a\n // missing method (or a freak runtime error inside it) never propagates as an unhandled rejection.\n if (el && typeof el.scrollIntoView === 'function') {\n try {\n el.scrollIntoView({ block: 'nearest' });\n } catch {\n /* no-op — non-critical UX nicety */\n }\n }\n};\n\nconst handleTypeAhead = (char: string) => {\n if (typeAheadTimer) clearTimeout(typeAheadTimer);\n typeAheadBuffer.value += char.toLowerCase();\n typeAheadTimer = setTimeout(() => {\n typeAheadBuffer.value = '';\n }, 500);\n\n const list = optionList.value;\n const buf = typeAheadBuffer.value;\n // For the first char of a new buffer, search starting AFTER the current active index;\n // for continued buffers, re-evaluate from the active index so the prefix still matches.\n const start = activeIndex.value === -1 ? 0 : activeIndex.value + (buf.length === 1 ? 1 : 0);\n for (let n = 0; n < list.length; n++) {\n const i = (start + n) % list.length;\n const opt = list[i];\n if (isOptionDisabled(opt)) continue;\n const lbl = getOptionLabel(opt).toLowerCase();\n if (lbl.startsWith(buf)) {\n activeIndex.value = i;\n void scrollActiveIntoView();\n return;\n }\n }\n};\n\nconst handleKeydown = (e: KeyboardEvent) => {\n if (isDisabled.value) return;\n if (optionList.value.length === 0) return;\n\n switch (e.key) {\n case 'ArrowDown': {\n e.preventDefault();\n const from = activeIndex.value === -1 ? -1 : activeIndex.value;\n const next = findNextEnabled(from, 1);\n if (next !== -1) activeIndex.value = next;\n void scrollActiveIntoView();\n break;\n }\n case 'ArrowUp': {\n e.preventDefault();\n const from = activeIndex.value === -1 ? 0 : activeIndex.value;\n const next = findNextEnabled(from, -1);\n if (next !== -1) activeIndex.value = next;\n void scrollActiveIntoView();\n break;\n }\n case 'Home': {\n e.preventDefault();\n activeIndex.value = findFirstEnabled();\n void scrollActiveIntoView();\n break;\n }\n case 'End': {\n e.preventDefault();\n activeIndex.value = findLastEnabled();\n void scrollActiveIntoView();\n break;\n }\n case 'Enter':\n case ' ': {\n e.preventDefault();\n ensureActiveIndex();\n if (activeIndex.value !== -1) selectIndex(activeIndex.value);\n break;\n }\n default: {\n if (e.key.length === 1 && !e.ctrlKey && !e.metaKey && !e.altKey) {\n e.preventDefault();\n handleTypeAhead(e.key);\n }\n }\n }\n};\n\n// ─────────────────────────────────────────────\n// Mouse interaction\n// ─────────────────────────────────────────────\nconst handleOptionClick = (index: number) => {\n if (isDisabled.value) return;\n if (isOptionDisabled(optionList.value[index])) return;\n activeIndex.value = index;\n selectIndex(index);\n};\n\nconst handleOptionMouseEnter = (index: number) => {\n if (isDisabled.value) return;\n if (isOptionDisabled(optionList.value[index])) return;\n activeIndex.value = index;\n};\n\n// ─────────────────────────────────────────────\n// Focus management\n// ─────────────────────────────────────────────\nconst handleFocus = () => {\n if (activeIndex.value === -1) {\n const selectedIdx = optionList.value.findIndex(\n (o) => isOptionSelected(o) && !isOptionDisabled(o),\n );\n activeIndex.value = selectedIdx !== -1 ? selectedIdx : findFirstEnabled();\n }\n};\n\nconst focus = () => {\n listboxRef.value?.focus();\n};\n\nconst focusOption = (value: T) => {\n const idx = optionList.value.findIndex((o) => getOptionValue(o) === value);\n if (idx !== -1 && !isOptionDisabled(optionList.value[idx])) {\n activeIndex.value = idx;\n listboxRef.value?.focus();\n void scrollActiveIntoView();\n }\n};\n\ndefineExpose({ focus, focusOption });\n\n// Reset active index if it becomes invalid after option list changes.\nwatch(\n () => optionList.value.length,\n (len) => {\n if (activeIndex.value >= len) activeIndex.value = -1;\n },\n);\n\n// Computed aria-activedescendant id\nconst activeDescendantId = computed(() =>\n activeIndex.value >= 0 ? optionId(activeIndex.value) : undefined,\n);\n\n/**\n * `role=\"listbox\"` requires an accessible name. Default to a generic \"Options\"\n * label; consumers override via fallthrough `aria-label` / `aria-labelledby`.\n */\nconst attrs = useAttrs();\nconst fallbackAriaLabel = computed(() => {\n if (attrs['aria-label'] || attrs['aria-labelledby']) return undefined;\n return 'Options';\n});\n</script>\n\n<template>\n <ul\n :id=\"listboxId\"\n ref=\"listboxRef\"\n role=\"listbox\"\n class=\"b-listbox\"\n :class=\"[\n `b-listbox--${sizeClass}`,\n {\n 'b-listbox--disabled': isDisabled,\n 'b-listbox--multiple': isMultiple,\n },\n ]\"\n :tabindex=\"isDisabled ? -1 : 0\"\n :aria-label=\"fallbackAriaLabel\"\n :aria-multiselectable=\"isMultiple || undefined\"\n :aria-disabled=\"isDisabled || undefined\"\n :aria-activedescendant=\"activeDescendantId\"\n @keydown=\"handleKeydown\"\n @focus=\"handleFocus\"\n >\n <template v-for=\"(item, idx) in renderItems\" :key=\"idx\">\n <!-- Group wrapper -->\n <li v-if=\"item.type === 'group'\" role=\"presentation\" class=\"b-listbox__group\">\n <span class=\"b-listbox__group-label\" :aria-hidden=\"true\">{{ item.group }}</span>\n <ul role=\"group\" :aria-label=\"item.group\" class=\"b-listbox__group-list\">\n <li\n v-for=\"row in item.rows\"\n :id=\"optionId(row.index)\"\n :key=\"row.index\"\n role=\"option\"\n class=\"b-listbox__option\"\n :class=\"{\n 'b-listbox__option--selected': isOptionSelected(row.option),\n 'b-listbox__option--active': activeIndex === row.index,\n 'b-listbox__option--disabled': isOptionDisabled(row.option),\n }\"\n :aria-selected=\"isOptionSelected(row.option)\"\n :aria-disabled=\"isOptionDisabled(row.option) || undefined\"\n @click=\"handleOptionClick(row.index)\"\n @mouseenter=\"handleOptionMouseEnter(row.index)\"\n >\n {{ getOptionLabel(row.option) }}\n </li>\n </ul>\n </li>\n\n <!-- Plain option -->\n <li\n v-else\n :id=\"optionId(item.index)\"\n :key=\"`opt-${item.index}`\"\n role=\"option\"\n class=\"b-listbox__option\"\n :class=\"{\n 'b-listbox__option--selected': isOptionSelected(item.option),\n 'b-listbox__option--active': activeIndex === item.index,\n 'b-listbox__option--disabled': isOptionDisabled(item.option),\n }\"\n :aria-selected=\"isOptionSelected(item.option)\"\n :aria-disabled=\"isOptionDisabled(item.option) || undefined\"\n @click=\"handleOptionClick(item.index)\"\n @mouseenter=\"handleOptionMouseEnter(item.index)\"\n >\n {{ getOptionLabel(item.option) }}\n </li>\n </template>\n </ul>\n</template>\n\n<style>\n.b-listbox {\n /* Component tokens — defined on the component root, never on :root */\n --b-listbox-bg: #ffffff;\n --b-listbox-fg: rgba(0, 0, 0, 0.88);\n --b-listbox-border-color: #d9d9d9;\n --b-listbox-radius: 6px;\n --b-listbox-option-padding-x: 12px;\n --b-listbox-option-padding-y: 6px;\n --b-listbox-option-bg-hover: rgba(0, 0, 0, 0.04);\n --b-listbox-option-bg-active: rgba(0, 0, 0, 0.06);\n --b-listbox-option-bg-selected: oklch(95% 0.04 240);\n --b-listbox-option-fg-selected: oklch(45% 0.18 258);\n --b-listbox-font-size: 14px;\n --b-listbox-group-label-color: rgba(0, 0, 0, 0.65);\n --b-listbox-disabled-color: rgba(0, 0, 0, 0.25);\n --b-listbox-focus-ring: 0 0 0 2px rgba(5, 145, 255, 0.2);\n --b-listbox-transition-duration: 150ms;\n\n list-style: none;\n margin: 0;\n padding: 4px 0;\n background: var(--b-listbox-bg);\n color: var(--b-listbox-fg);\n border: 1px solid var(--b-listbox-border-color);\n border-radius: var(--b-listbox-radius);\n font-size: var(--b-listbox-font-size);\n outline: none;\n max-height: 320px;\n overflow-y: auto;\n user-select: none;\n}\n\n.b-listbox--sm {\n --b-listbox-font-size: 13px;\n --b-listbox-option-padding-x: 10px;\n --b-listbox-option-padding-y: 4px;\n}\n\n.b-listbox--lg {\n --b-listbox-font-size: 16px;\n --b-listbox-option-padding-x: 14px;\n --b-listbox-option-padding-y: 8px;\n}\n\n.b-listbox:focus-visible {\n box-shadow: var(--b-listbox-focus-ring);\n}\n\n.b-listbox--disabled {\n cursor: not-allowed;\n opacity: 0.6;\n}\n\n/* ── Option ── */\n.b-listbox__option {\n padding: var(--b-listbox-option-padding-y) var(--b-listbox-option-padding-x);\n cursor: pointer;\n display: block;\n line-height: 1.5;\n transition:\n background-color var(--b-listbox-transition-duration) ease,\n color var(--b-listbox-transition-duration) ease;\n}\n\n.b-listbox__option--active {\n background-color: var(--b-listbox-option-bg-active);\n}\n\n.b-listbox__option--selected {\n background-color: var(--b-listbox-option-bg-selected);\n color: var(--b-listbox-option-fg-selected);\n font-weight: 500;\n}\n\n.b-listbox__option--disabled {\n cursor: not-allowed;\n color: var(--b-listbox-disabled-color);\n background-color: transparent;\n}\n\n.b-listbox__option:not(.b-listbox__option--disabled):hover {\n background-color: var(--b-listbox-option-bg-hover);\n}\n\n/* ── Group ── */\n.b-listbox__group {\n display: block;\n padding: 0;\n}\n\n.b-listbox__group-label {\n display: block;\n padding: 6px var(--b-listbox-option-padding-x) 4px;\n color: var(--b-listbox-group-label-color);\n font-size: 0.85em;\n font-weight: 600;\n text-transform: uppercase;\n letter-spacing: 0.04em;\n}\n\n.b-listbox__group-list {\n list-style: none;\n margin: 0;\n padding: 0;\n}\n\n/* ── Dark mode ── */\n[data-prefers-color='dark'] .b-listbox {\n --b-listbox-bg: #141414;\n --b-listbox-fg: rgba(255, 255, 255, 0.88);\n --b-listbox-border-color: #424242;\n --b-listbox-option-bg-hover: rgba(255, 255, 255, 0.08);\n --b-listbox-option-bg-active: rgba(255, 255, 255, 0.12);\n --b-listbox-option-bg-selected: oklch(28% 0.08 258);\n --b-listbox-option-fg-selected: oklch(80% 0.14 258);\n --b-listbox-group-label-color: rgba(255, 255, 255, 0.45);\n --b-listbox-disabled-color: rgba(255, 255, 255, 0.25);\n --b-listbox-focus-ring: 0 0 0 2px rgba(22, 104, 220, 0.3);\n}\n\n@media (prefers-color-scheme: dark) {\n [data-prefers-color='system'] .b-listbox {\n --b-listbox-bg: #141414;\n --b-listbox-fg: rgba(255, 255, 255, 0.88);\n --b-listbox-border-color: #424242;\n --b-listbox-option-bg-hover: rgba(255, 255, 255, 0.08);\n --b-listbox-option-bg-active: rgba(255, 255, 255, 0.12);\n --b-listbox-option-bg-selected: oklch(28% 0.08 258);\n --b-listbox-option-fg-selected: oklch(80% 0.14 258);\n --b-listbox-group-label-color: rgba(255, 255, 255, 0.45);\n --b-listbox-disabled-color: rgba(255, 255, 255, 0.25);\n --b-listbox-focus-ring: 0 0 0 2px rgba(22, 104, 220, 0.3);\n }\n}\n\n/* ── Reduced motion ── */\n@media (prefers-reduced-motion: reduce) {\n .b-listbox__option {\n transition: none;\n }\n}\n</style>\n"],"mappings":"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"}
|
package/dist/design-system131.js
CHANGED
|
@@ -1,93 +1,8 @@
|
|
|
1
|
-
import
|
|
2
|
-
|
|
3
|
-
//#region src/components/
|
|
4
|
-
var
|
|
5
|
-
"role",
|
|
6
|
-
"tabindex",
|
|
7
|
-
"aria-disabled",
|
|
8
|
-
"aria-checked",
|
|
9
|
-
"title",
|
|
10
|
-
"data-menu-key"
|
|
11
|
-
], g = {
|
|
12
|
-
key: 0,
|
|
13
|
-
class: "b-menu-item__icon",
|
|
14
|
-
"aria-hidden": "true"
|
|
15
|
-
}, _ = {
|
|
16
|
-
key: 1,
|
|
17
|
-
class: "b-menu-item__label"
|
|
18
|
-
}, v = {
|
|
19
|
-
key: 2,
|
|
20
|
-
class: "b-menu-item__extra"
|
|
21
|
-
}, y = /* @__PURE__ */ o({
|
|
22
|
-
__name: "BMenuItem",
|
|
23
|
-
props: {
|
|
24
|
-
itemKey: {},
|
|
25
|
-
label: { default: "" },
|
|
26
|
-
icon: { default: () => void 0 },
|
|
27
|
-
disabled: {
|
|
28
|
-
type: Boolean,
|
|
29
|
-
default: !1
|
|
30
|
-
},
|
|
31
|
-
danger: {
|
|
32
|
-
type: Boolean,
|
|
33
|
-
default: !1
|
|
34
|
-
},
|
|
35
|
-
extra: { default: () => void 0 },
|
|
36
|
-
title: { default: () => void 0 }
|
|
37
|
-
},
|
|
38
|
-
setup(o) {
|
|
39
|
-
let y = s(e), b = s(t, null), x = n(() => (b?.level ?? 0) + 1), S = n(() => [...b?.keyPath ?? [], o.itemKey]);
|
|
40
|
-
u(() => {
|
|
41
|
-
y.registerKeyPath(o.itemKey, S.value);
|
|
42
|
-
});
|
|
43
|
-
let C = n(() => y.selectedKeys.value.includes(o.itemKey)), w = n(() => y.selectable.value ? y.multiple.value ? "menuitemcheckbox" : "menuitemradio" : "menuitem"), T = n(() => {
|
|
44
|
-
if (y.mode.value === "inline" && !y.inlineCollapsed.value) return `${x.value * y.inlineIndent.value}px`;
|
|
45
|
-
}), E = n(() => ["b-menu-item", {
|
|
46
|
-
"b-menu-item--selected": C.value,
|
|
47
|
-
"b-menu-item--disabled": o.disabled,
|
|
48
|
-
"b-menu-item--danger": o.danger,
|
|
49
|
-
"b-menu-item--collapsed": y.inlineCollapsed.value,
|
|
50
|
-
"b-menu-item--horizontal": y.mode.value === "horizontal"
|
|
51
|
-
}]);
|
|
52
|
-
function D(e) {
|
|
53
|
-
if (o.disabled) return;
|
|
54
|
-
let t = {
|
|
55
|
-
key: o.itemKey,
|
|
56
|
-
keyPath: S.value,
|
|
57
|
-
domEvent: e
|
|
58
|
-
};
|
|
59
|
-
y.onItemClick(t);
|
|
60
|
-
}
|
|
61
|
-
function O(e) {
|
|
62
|
-
if (!o.disabled && (e.key === "Enter" || e.key === " ")) {
|
|
63
|
-
e.preventDefault();
|
|
64
|
-
let t = {
|
|
65
|
-
key: o.itemKey,
|
|
66
|
-
keyPath: S.value,
|
|
67
|
-
domEvent: e
|
|
68
|
-
};
|
|
69
|
-
y.onItemClick(t);
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
return (e, t) => (d(), i("li", {
|
|
73
|
-
class: c(E.value),
|
|
74
|
-
style: l({ paddingInlineStart: T.value }),
|
|
75
|
-
role: w.value,
|
|
76
|
-
tabindex: o.disabled ? -1 : 0,
|
|
77
|
-
"aria-disabled": o.disabled || void 0,
|
|
78
|
-
"aria-checked": m(y).selectable.value ? C.value : void 0,
|
|
79
|
-
title: o.title ?? (m(y).inlineCollapsed.value ? o.label : void 0),
|
|
80
|
-
"data-menu-key": o.itemKey,
|
|
81
|
-
onClick: D,
|
|
82
|
-
onKeydown: O
|
|
83
|
-
}, [
|
|
84
|
-
o.icon || e.$slots.icon ? (d(), i("span", g, [f(e.$slots, "icon", {}, () => [a(p(o.icon), 1)])])) : r("", !0),
|
|
85
|
-
m(y).inlineCollapsed.value ? r("", !0) : (d(), i("span", _, [f(e.$slots, "default", {}, () => [a(p(o.label), 1)])])),
|
|
86
|
-
o.extra && !m(y).inlineCollapsed.value ? (d(), i("span", v, [f(e.$slots, "extra", {}, () => [a(p(o.extra), 1)])])) : r("", !0)
|
|
87
|
-
], 46, h));
|
|
88
|
-
}
|
|
89
|
-
});
|
|
1
|
+
import e from "./design-system129.js";
|
|
2
|
+
/* empty css */
|
|
3
|
+
//#region src/components/BListbox/BListbox.vue
|
|
4
|
+
var t = e;
|
|
90
5
|
//#endregion
|
|
91
|
-
export {
|
|
6
|
+
export { t as default };
|
|
92
7
|
|
|
93
8
|
//# sourceMappingURL=design-system131.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"design-system131.js","names":["$slots"],"sources":["../src/components/BMenu/BMenuItem.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { computed, inject, onMounted } from 'vue';\nimport {\n BMenuContextKey,\n BMenuSubMenuContextKey,\n type BMenuClickInfo,\n type BMenuContext,\n type BMenuSubMenuContext,\n} from './types';\n\n// ─────────────────────────────────────────────\n// Props\n// ─────────────────────────────────────────────\nconst {\n itemKey,\n label = '',\n icon = undefined,\n disabled = false,\n danger = false,\n extra = undefined,\n title = undefined,\n} = defineProps<{\n /** Unique key identifying this menu item. */\n itemKey: string;\n /** Display label text. */\n label?: string;\n /** Icon name rendered before the label. */\n icon?: string;\n /** Whether the item is disabled. @default false */\n disabled?: boolean;\n /** Display with danger (red) styling. @default false */\n danger?: boolean;\n /** Extra content at the right side. */\n extra?: string;\n /** Tooltip title when collapsed. */\n title?: string;\n}>();\n\ndefineSlots<{\n default?(): unknown;\n icon?(): unknown;\n extra?(): unknown;\n}>();\n\n// ─────────────────────────────────────────────\n// Inject context\n// ─────────────────────────────────────────────\nconst menu = inject<BMenuContext>(BMenuContextKey)!;\nconst subMenuCtx = inject<BMenuSubMenuContext | null>(BMenuSubMenuContextKey, null);\n\nconst level = computed(() => (subMenuCtx?.level ?? 0) + 1);\nconst keyPath = computed(() => [...(subMenuCtx?.keyPath ?? []), itemKey]);\n\n// Register key path with root menu\nonMounted(() => {\n menu.registerKeyPath(itemKey, keyPath.value);\n});\n\n// ─────────────────────────────────────────────\n// Computed\n// ─────────────────────────────────────────────\nconst isSelected = computed(() => menu.selectedKeys.value.includes(itemKey));\n\nconst itemRole = computed(() => {\n if (!menu.selectable.value) return 'menuitem';\n return menu.multiple.value ? 'menuitemcheckbox' : 'menuitemradio';\n});\n\nconst paddingLeft = computed(() => {\n if (menu.mode.value !== 'inline') return undefined;\n if (menu.inlineCollapsed.value) return undefined;\n return `${level.value * menu.inlineIndent.value}px`;\n});\n\nconst itemClasses = computed(() => [\n 'b-menu-item',\n {\n 'b-menu-item--selected': isSelected.value,\n 'b-menu-item--disabled': disabled,\n 'b-menu-item--danger': danger,\n 'b-menu-item--collapsed': menu.inlineCollapsed.value,\n 'b-menu-item--horizontal': menu.mode.value === 'horizontal',\n },\n]);\n\n// ─────────────────────────────────────────────\n// Handlers\n// ─────────────────────────────────────────────\nfunction handleClick(e: MouseEvent) {\n if (disabled) return;\n\n const info: BMenuClickInfo = {\n key: itemKey,\n keyPath: keyPath.value,\n domEvent: e,\n };\n menu.onItemClick(info);\n}\n\nfunction handleKeydown(e: KeyboardEvent) {\n if (disabled) return;\n\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault();\n const info: BMenuClickInfo = {\n key: itemKey,\n keyPath: keyPath.value,\n domEvent: e,\n };\n menu.onItemClick(info);\n }\n}\n</script>\n\n<template>\n <li\n :class=\"itemClasses\"\n :style=\"{ paddingInlineStart: paddingLeft }\"\n :role=\"itemRole\"\n :tabindex=\"disabled ? -1 : 0\"\n :aria-disabled=\"disabled || undefined\"\n :aria-checked=\"menu.selectable.value ? isSelected : undefined\"\n :title=\"title ?? (menu.inlineCollapsed.value ? label : undefined)\"\n :data-menu-key=\"itemKey\"\n @click=\"handleClick\"\n @keydown=\"handleKeydown\"\n >\n <span v-if=\"icon || $slots.icon\" class=\"b-menu-item__icon\" aria-hidden=\"true\">\n <slot name=\"icon\">{{ icon }}</slot>\n </span>\n <span v-if=\"!menu.inlineCollapsed.value\" class=\"b-menu-item__label\">\n <slot>{{ label }}</slot>\n </span>\n <span v-if=\"extra && !menu.inlineCollapsed.value\" class=\"b-menu-item__extra\">\n <slot name=\"extra\">{{ extra }}</slot>\n </span>\n </li>\n</template>\n\n<style>\n/* ─────────────────────────────────────────────\n BMenuItem\n ───────────────────────────────────────────── */\n.b-menu-item {\n display: flex;\n align-items: center;\n height: var(--b-menu-item-height);\n margin-block: var(--b-menu-item-margin-block);\n margin-inline: var(--b-menu-item-margin-inline);\n padding-inline: var(--b-menu-item-padding-inline);\n border-radius: var(--b-menu-item-border-radius);\n color: var(--b-menu-item-color);\n cursor: pointer;\n user-select: none;\n list-style: none;\n outline: none;\n position: relative;\n transition:\n background var(--b-menu-transition-duration),\n color var(--b-menu-transition-duration),\n padding var(--b-menu-transition-duration);\n box-sizing: border-box;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n\n.b-menu-item:hover:not(.b-menu-item--disabled) {\n background: var(--b-menu-item-hover-bg);\n color: var(--b-menu-item-hover-color);\n}\n\n.b-menu-item:focus-visible {\n outline: 2px solid #1677ff;\n outline-offset: -2px;\n}\n\n/* ── Selected ── */\n.b-menu-item--selected {\n background: var(--b-menu-item-selected-bg);\n color: var(--b-menu-item-selected-color);\n font-weight: 500;\n}\n\n/* ── Disabled ── */\n.b-menu-item--disabled {\n color: var(--b-menu-item-disabled-color);\n cursor: not-allowed;\n}\n\n/* ── Danger ── */\n.b-menu-item--danger {\n color: var(--b-menu-danger-item-color);\n}\n\n.b-menu-item--danger:hover:not(.b-menu-item--disabled) {\n color: var(--b-menu-danger-item-hover-color);\n background: var(--b-menu-danger-item-active-bg);\n}\n\n.b-menu-item--danger.b-menu-item--selected {\n background: var(--b-menu-danger-item-selected-bg);\n color: var(--b-menu-danger-item-selected-color);\n}\n\n/* ── Collapsed ── */\n.b-menu-item--collapsed {\n justify-content: center;\n padding-inline: 0;\n}\n\n.b-menu-item--collapsed .b-menu-item__icon {\n font-size: var(--b-menu-collapsed-icon-size);\n margin-inline-end: 0;\n}\n\n/* ── Horizontal mode ── */\n.b-menu-item--horizontal {\n margin-block: 0;\n border-radius: var(--b-menu-horizontal-item-border-radius);\n height: auto;\n line-height: var(--b-menu-horizontal-line-height);\n position: relative;\n}\n\n.b-menu-item--horizontal::after {\n content: '';\n position: absolute;\n bottom: 0;\n left: var(--b-menu-item-padding-inline);\n right: var(--b-menu-item-padding-inline);\n height: var(--b-menu-active-bar-height);\n background: transparent;\n transition: background var(--b-menu-transition-duration);\n}\n\n.b-menu-item--horizontal:hover:not(.b-menu-item--disabled) {\n background: var(--b-menu-horizontal-item-hover-bg);\n color: var(--b-menu-horizontal-item-hover-color);\n}\n\n.b-menu-item--horizontal.b-menu-item--selected {\n background: var(--b-menu-horizontal-item-selected-bg);\n color: var(--b-menu-horizontal-item-selected-color);\n}\n\n.b-menu-item--horizontal.b-menu-item--selected::after {\n background: var(--b-menu-horizontal-item-selected-color);\n}\n\n/* ─────────────────────────────────────────────\n Icon & Label\n ───────────────────────────────────────────── */\n.b-menu-item__icon {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n flex-shrink: 0;\n font-size: var(--b-menu-icon-size);\n margin-inline-end: var(--b-menu-icon-margin-inline-end);\n}\n\n.b-menu-item__label {\n flex: 1;\n min-width: 0;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n\n.b-menu-item__extra {\n margin-inline-start: auto;\n padding-inline-start: 8px;\n color: var(--b-menu-group-title-color);\n font-size: 12px;\n}\n\n/* ── Reduced motion ── */\n@media (prefers-reduced-motion: reduce) {\n .b-menu-item {\n transition: none;\n }\n\n .b-menu-item--horizontal::after {\n transition: none;\n }\n}\n</style>\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA+CA,IAAM,IAAO,EAAqB,EAAgB,EAC5C,IAAa,EAAmC,GAAwB,KAAK,EAE7E,IAAQ,SAAgB,GAAY,SAAS,KAAK,EAAE,EACpD,IAAU,QAAe,CAAC,GAAI,GAAY,WAAW,EAAE,EAAG,EAAA,QAAQ,CAAC;AAGzE,UAAgB;AACd,KAAK,gBAAgB,EAAA,SAAS,EAAQ,MAAM;IAC5C;EAKF,IAAM,IAAa,QAAe,EAAK,aAAa,MAAM,SAAS,EAAA,QAAQ,CAAC,EAEtE,IAAW,QACV,EAAK,WAAW,QACd,EAAK,SAAS,QAAQ,qBAAqB,kBADf,WAEnC,EAEI,IAAc,QAAe;AAC7B,SAAK,KAAK,UAAU,YACpB,GAAK,gBAAgB,MACzB,QAAO,GAAG,EAAM,QAAQ,EAAK,aAAa,MAAM;IAChD,EAEI,IAAc,QAAe,CACjC,eACA;GACE,yBAAyB,EAAW;GACpC,yBAAyB,EAAA;GACzB,uBAAuB,EAAA;GACvB,0BAA0B,EAAK,gBAAgB;GAC/C,2BAA2B,EAAK,KAAK,UAAU;GAChD,CACF,CAAC;EAKF,SAAS,EAAY,GAAe;AAClC,OAAI,EAAA,SAAU;GAEd,IAAM,IAAuB;IAC3B,KAAK,EAAA;IACL,SAAS,EAAQ;IACjB,UAAU;IACX;AACD,KAAK,YAAY,EAAK;;EAGxB,SAAS,EAAc,GAAkB;AACnC,UAAA,aAEA,EAAE,QAAQ,WAAW,EAAE,QAAQ,MAAK;AACtC,MAAE,gBAAgB;IAClB,IAAM,IAAuB;KAC3B,KAAK,EAAA;KACL,SAAS,EAAQ;KACjB,UAAU;KACX;AACD,MAAK,YAAY,EAAK;;;yBAMxB,EAqBK,MAAA;GApBF,OAAK,EAAE,EAAA,MAAW;GAClB,OAAK,EAAA,EAAA,oBAAwB,EAAA,OAAW,CAAA;GACxC,MAAM,EAAA;GACN,UAAU,EAAA,WAAQ,KAAA;GAClB,iBAAe,EAAA,YAAY,KAAA;GAC3B,gBAAc,EAAA,EAAI,CAAC,WAAW,QAAQ,EAAA,QAAa,KAAA;GACnD,OAAO,EAAA,UAAU,EAAA,EAAI,CAAC,gBAAgB,QAAQ,EAAA,QAAQ,KAAA;GACtD,iBAAe,EAAA;GACf,SAAO;GACP,WAAS;;GAEE,EAAA,QAAQA,EAAAA,OAAO,QAAA,GAAA,EAA3B,EAEO,QAFP,GAEO,CADL,EAAmC,EAAA,QAAA,QAAA,EAAA,QAAA,CAAA,EAAA,EAAd,EAAA,KAAI,EAAA,EAAA,CAAA,CAAA,CAAA,CAAA,IAAA,EAAA,IAAA,GAAA;GAEd,EAAA,EAAI,CAAC,gBAAgB,QAClB,EAAA,IAAA,GAAA,IADkB,GAAA,EAAlC,EAEO,QAFP,GAEO,CADL,EAAwB,EAAA,QAAA,WAAA,EAAA,QAAA,CAAA,EAAA,EAAf,EAAA,MAAK,EAAA,EAAA,CAAA,CAAA,CAAA,CAAA;GAEJ,EAAA,SAAK,CAAK,EAAA,EAAI,CAAC,gBAAgB,SAAA,GAAA,EAA3C,EAEO,QAFP,GAEO,CADL,EAAqC,EAAA,QAAA,SAAA,EAAA,QAAA,CAAA,EAAA,EAAf,EAAA,MAAK,EAAA,EAAA,CAAA,CAAA,CAAA,CAAA,IAAA,EAAA,IAAA,GAAA"}
|
|
1
|
+
{"version":3,"file":"design-system131.js","names":[],"sources":["../src/components/BListbox/BListbox.vue"],"sourcesContent":["<script setup lang=\"ts\" generic=\"T\">\nimport { useComponentId } from '@/composables/useComponentId.ts';\nimport { BCommonSize } from '@/types.ts';\nimport { computed, nextTick, ref, useAttrs, watch } from 'vue';\n\nexport interface BListboxOption<V> {\n /** Display label for the option. */\n label: string;\n /** Value associated with the option. */\n value: V;\n /** Whether the option is disabled and skipped by keyboard navigation. */\n disabled?: boolean;\n /** Optional group label — adjacent options sharing the same group are wrapped together. */\n group?: string;\n}\n\nconst props = defineProps<{\n /** Array of selectable options. */\n options?: BListboxOption<T>[];\n /** Whether multiple options can be selected at once. */\n multiple?: boolean;\n /** Disables the entire listbox — no keyboard nav, no selection. */\n disabled?: boolean;\n /** Visual size preset. */\n size?: `${BCommonSize}`;\n /** Property name on each option that holds the value. Defaults to `'value'`. */\n valueKey?: string;\n /** Property name on each option that holds the label. Defaults to `'label'`. */\n labelKey?: string;\n /** Optional id for the root listbox element. Auto-generated if omitted. */\n id?: string;\n}>();\n\nconst emit = defineEmits<{\n /** Emitted whenever the selection changes. Single value or array depending on `multiple`. */\n change: [value: T | T[]];\n}>();\n\nconst model = defineModel<T | T[] | null>({ default: null });\n\n// ─── Reactive accessors with defaults ───\nconst optionList = computed<BListboxOption<T>[]>(() => props.options ?? []);\nconst isMultiple = computed(() => props.multiple ?? false);\nconst isDisabled = computed(() => props.disabled ?? false);\nconst sizeClass = computed(() => props.size ?? BCommonSize.Medium);\nconst valueKeyName = computed(() => props.valueKey ?? 'value');\nconst labelKeyName = computed(() => props.labelKey ?? 'label');\n\nconst { componentUID } = useComponentId();\nconst listboxId = computed(() => props.id ?? `b-listbox-${componentUID.value}`);\nconst optionId = (index: number) => `${listboxId.value}-option-${index}`;\n\nconst listboxRef = ref<HTMLUListElement | null>(null);\nconst activeIndex = ref<number>(-1);\n\n// Type-ahead buffer\nconst typeAheadBuffer = ref('');\nlet typeAheadTimer: ReturnType<typeof setTimeout> | null = null;\n\n// ─────────────────────────────────────────────\n// Helpers\n// ─────────────────────────────────────────────\nconst getOptionValue = (opt: BListboxOption<T>): T => {\n const key = valueKeyName.value;\n const fromKey = (opt as unknown as Record<string, T>)[key];\n return fromKey !== undefined ? fromKey : opt.value;\n};\n\nconst getOptionLabel = (opt: BListboxOption<T>): string => {\n const key = labelKeyName.value;\n const raw = (opt as unknown as Record<string, unknown>)[key];\n if (typeof raw === 'string' && raw.length > 0) return raw;\n return opt.label;\n};\n\nconst isOptionSelected = (opt: BListboxOption<T>): boolean => {\n const v = getOptionValue(opt);\n if (isMultiple.value) {\n return Array.isArray(model.value) && model.value.includes(v);\n }\n return model.value === v;\n};\n\nconst isOptionDisabled = (opt: BListboxOption<T> | undefined): boolean => {\n if (!opt) return true;\n return !!opt.disabled || isDisabled.value;\n};\n\n// ─────────────────────────────────────────────\n// Grouped rendering structure\n// ─────────────────────────────────────────────\ninterface RenderRow {\n type: 'option';\n option: BListboxOption<T>;\n index: number;\n group?: string;\n}\ninterface RenderGroup {\n type: 'group';\n group: string;\n rows: RenderRow[];\n}\ntype RenderItem = RenderGroup | RenderRow;\n\nconst renderItems = computed<RenderItem[]>(() => {\n const result: RenderItem[] = [];\n let currentGroup: RenderGroup | null = null;\n optionList.value.forEach((opt, index) => {\n const row: RenderRow = { type: 'option', option: opt, index, group: opt.group };\n if (opt.group) {\n if (!currentGroup || currentGroup.group !== opt.group) {\n currentGroup = { type: 'group', group: opt.group, rows: [] };\n result.push(currentGroup);\n }\n currentGroup.rows.push(row);\n } else {\n currentGroup = null;\n result.push(row);\n }\n });\n return result;\n});\n\n// ─────────────────────────────────────────────\n// Selection\n// ─────────────────────────────────────────────\nconst selectIndex = (index: number) => {\n const opt = optionList.value[index];\n if (!opt || isOptionDisabled(opt)) return;\n const v = getOptionValue(opt);\n\n if (isMultiple.value) {\n const current = Array.isArray(model.value) ? [...model.value] : [];\n const i = current.indexOf(v);\n if (i === -1) {\n current.push(v);\n } else {\n current.splice(i, 1);\n }\n model.value = current;\n emit('change', current);\n } else {\n model.value = v;\n emit('change', v);\n }\n};\n\n// ─────────────────────────────────────────────\n// Keyboard navigation\n// ─────────────────────────────────────────────\nconst findNextEnabled = (from: number, dir: 1 | -1): number => {\n const list = optionList.value;\n if (list.length === 0) return -1;\n let i = from;\n for (let n = 0; n < list.length; n++) {\n i = (i + dir + list.length) % list.length;\n if (!isOptionDisabled(list[i])) return i;\n }\n return -1;\n};\n\nconst findFirstEnabled = (): number => {\n const list = optionList.value;\n for (let i = 0; i < list.length; i++) {\n if (!isOptionDisabled(list[i])) return i;\n }\n return -1;\n};\n\nconst findLastEnabled = (): number => {\n const list = optionList.value;\n for (let i = list.length - 1; i >= 0; i--) {\n if (!isOptionDisabled(list[i])) return i;\n }\n return -1;\n};\n\nconst ensureActiveIndex = () => {\n const list = optionList.value;\n if (activeIndex.value === -1 || isOptionDisabled(list[activeIndex.value])) {\n activeIndex.value = findFirstEnabled();\n }\n};\n\nconst scrollActiveIntoView = async () => {\n await nextTick();\n if (activeIndex.value < 0) return;\n if (!listboxRef.value) return;\n const escape = typeof CSS !== 'undefined' && typeof CSS.escape === 'function'\n ? CSS.escape\n : (s: string) => s.replace(/[^a-zA-Z0-9_-]/g, '\\\\$&');\n const el = listboxRef.value.querySelector<HTMLElement>(`#${escape(optionId(activeIndex.value))}`);\n // jsdom and some embedded environments don't implement scrollIntoView — guard so a\n // missing method (or a freak runtime error inside it) never propagates as an unhandled rejection.\n if (el && typeof el.scrollIntoView === 'function') {\n try {\n el.scrollIntoView({ block: 'nearest' });\n } catch {\n /* no-op — non-critical UX nicety */\n }\n }\n};\n\nconst handleTypeAhead = (char: string) => {\n if (typeAheadTimer) clearTimeout(typeAheadTimer);\n typeAheadBuffer.value += char.toLowerCase();\n typeAheadTimer = setTimeout(() => {\n typeAheadBuffer.value = '';\n }, 500);\n\n const list = optionList.value;\n const buf = typeAheadBuffer.value;\n // For the first char of a new buffer, search starting AFTER the current active index;\n // for continued buffers, re-evaluate from the active index so the prefix still matches.\n const start = activeIndex.value === -1 ? 0 : activeIndex.value + (buf.length === 1 ? 1 : 0);\n for (let n = 0; n < list.length; n++) {\n const i = (start + n) % list.length;\n const opt = list[i];\n if (isOptionDisabled(opt)) continue;\n const lbl = getOptionLabel(opt).toLowerCase();\n if (lbl.startsWith(buf)) {\n activeIndex.value = i;\n void scrollActiveIntoView();\n return;\n }\n }\n};\n\nconst handleKeydown = (e: KeyboardEvent) => {\n if (isDisabled.value) return;\n if (optionList.value.length === 0) return;\n\n switch (e.key) {\n case 'ArrowDown': {\n e.preventDefault();\n const from = activeIndex.value === -1 ? -1 : activeIndex.value;\n const next = findNextEnabled(from, 1);\n if (next !== -1) activeIndex.value = next;\n void scrollActiveIntoView();\n break;\n }\n case 'ArrowUp': {\n e.preventDefault();\n const from = activeIndex.value === -1 ? 0 : activeIndex.value;\n const next = findNextEnabled(from, -1);\n if (next !== -1) activeIndex.value = next;\n void scrollActiveIntoView();\n break;\n }\n case 'Home': {\n e.preventDefault();\n activeIndex.value = findFirstEnabled();\n void scrollActiveIntoView();\n break;\n }\n case 'End': {\n e.preventDefault();\n activeIndex.value = findLastEnabled();\n void scrollActiveIntoView();\n break;\n }\n case 'Enter':\n case ' ': {\n e.preventDefault();\n ensureActiveIndex();\n if (activeIndex.value !== -1) selectIndex(activeIndex.value);\n break;\n }\n default: {\n if (e.key.length === 1 && !e.ctrlKey && !e.metaKey && !e.altKey) {\n e.preventDefault();\n handleTypeAhead(e.key);\n }\n }\n }\n};\n\n// ─────────────────────────────────────────────\n// Mouse interaction\n// ─────────────────────────────────────────────\nconst handleOptionClick = (index: number) => {\n if (isDisabled.value) return;\n if (isOptionDisabled(optionList.value[index])) return;\n activeIndex.value = index;\n selectIndex(index);\n};\n\nconst handleOptionMouseEnter = (index: number) => {\n if (isDisabled.value) return;\n if (isOptionDisabled(optionList.value[index])) return;\n activeIndex.value = index;\n};\n\n// ─────────────────────────────────────────────\n// Focus management\n// ─────────────────────────────────────────────\nconst handleFocus = () => {\n if (activeIndex.value === -1) {\n const selectedIdx = optionList.value.findIndex(\n (o) => isOptionSelected(o) && !isOptionDisabled(o),\n );\n activeIndex.value = selectedIdx !== -1 ? selectedIdx : findFirstEnabled();\n }\n};\n\nconst focus = () => {\n listboxRef.value?.focus();\n};\n\nconst focusOption = (value: T) => {\n const idx = optionList.value.findIndex((o) => getOptionValue(o) === value);\n if (idx !== -1 && !isOptionDisabled(optionList.value[idx])) {\n activeIndex.value = idx;\n listboxRef.value?.focus();\n void scrollActiveIntoView();\n }\n};\n\ndefineExpose({ focus, focusOption });\n\n// Reset active index if it becomes invalid after option list changes.\nwatch(\n () => optionList.value.length,\n (len) => {\n if (activeIndex.value >= len) activeIndex.value = -1;\n },\n);\n\n// Computed aria-activedescendant id\nconst activeDescendantId = computed(() =>\n activeIndex.value >= 0 ? optionId(activeIndex.value) : undefined,\n);\n\n/**\n * `role=\"listbox\"` requires an accessible name. Default to a generic \"Options\"\n * label; consumers override via fallthrough `aria-label` / `aria-labelledby`.\n */\nconst attrs = useAttrs();\nconst fallbackAriaLabel = computed(() => {\n if (attrs['aria-label'] || attrs['aria-labelledby']) return undefined;\n return 'Options';\n});\n</script>\n\n<template>\n <ul\n :id=\"listboxId\"\n ref=\"listboxRef\"\n role=\"listbox\"\n class=\"b-listbox\"\n :class=\"[\n `b-listbox--${sizeClass}`,\n {\n 'b-listbox--disabled': isDisabled,\n 'b-listbox--multiple': isMultiple,\n },\n ]\"\n :tabindex=\"isDisabled ? -1 : 0\"\n :aria-label=\"fallbackAriaLabel\"\n :aria-multiselectable=\"isMultiple || undefined\"\n :aria-disabled=\"isDisabled || undefined\"\n :aria-activedescendant=\"activeDescendantId\"\n @keydown=\"handleKeydown\"\n @focus=\"handleFocus\"\n >\n <template v-for=\"(item, idx) in renderItems\" :key=\"idx\">\n <!-- Group wrapper -->\n <li v-if=\"item.type === 'group'\" role=\"presentation\" class=\"b-listbox__group\">\n <span class=\"b-listbox__group-label\" :aria-hidden=\"true\">{{ item.group }}</span>\n <ul role=\"group\" :aria-label=\"item.group\" class=\"b-listbox__group-list\">\n <li\n v-for=\"row in item.rows\"\n :id=\"optionId(row.index)\"\n :key=\"row.index\"\n role=\"option\"\n class=\"b-listbox__option\"\n :class=\"{\n 'b-listbox__option--selected': isOptionSelected(row.option),\n 'b-listbox__option--active': activeIndex === row.index,\n 'b-listbox__option--disabled': isOptionDisabled(row.option),\n }\"\n :aria-selected=\"isOptionSelected(row.option)\"\n :aria-disabled=\"isOptionDisabled(row.option) || undefined\"\n @click=\"handleOptionClick(row.index)\"\n @mouseenter=\"handleOptionMouseEnter(row.index)\"\n >\n {{ getOptionLabel(row.option) }}\n </li>\n </ul>\n </li>\n\n <!-- Plain option -->\n <li\n v-else\n :id=\"optionId(item.index)\"\n :key=\"`opt-${item.index}`\"\n role=\"option\"\n class=\"b-listbox__option\"\n :class=\"{\n 'b-listbox__option--selected': isOptionSelected(item.option),\n 'b-listbox__option--active': activeIndex === item.index,\n 'b-listbox__option--disabled': isOptionDisabled(item.option),\n }\"\n :aria-selected=\"isOptionSelected(item.option)\"\n :aria-disabled=\"isOptionDisabled(item.option) || undefined\"\n @click=\"handleOptionClick(item.index)\"\n @mouseenter=\"handleOptionMouseEnter(item.index)\"\n >\n {{ getOptionLabel(item.option) }}\n </li>\n </template>\n </ul>\n</template>\n\n<style>\n.b-listbox {\n /* Component tokens — defined on the component root, never on :root */\n --b-listbox-bg: #ffffff;\n --b-listbox-fg: rgba(0, 0, 0, 0.88);\n --b-listbox-border-color: #d9d9d9;\n --b-listbox-radius: 6px;\n --b-listbox-option-padding-x: 12px;\n --b-listbox-option-padding-y: 6px;\n --b-listbox-option-bg-hover: rgba(0, 0, 0, 0.04);\n --b-listbox-option-bg-active: rgba(0, 0, 0, 0.06);\n --b-listbox-option-bg-selected: oklch(95% 0.04 240);\n --b-listbox-option-fg-selected: oklch(45% 0.18 258);\n --b-listbox-font-size: 14px;\n --b-listbox-group-label-color: rgba(0, 0, 0, 0.65);\n --b-listbox-disabled-color: rgba(0, 0, 0, 0.25);\n --b-listbox-focus-ring: 0 0 0 2px rgba(5, 145, 255, 0.2);\n --b-listbox-transition-duration: 150ms;\n\n list-style: none;\n margin: 0;\n padding: 4px 0;\n background: var(--b-listbox-bg);\n color: var(--b-listbox-fg);\n border: 1px solid var(--b-listbox-border-color);\n border-radius: var(--b-listbox-radius);\n font-size: var(--b-listbox-font-size);\n outline: none;\n max-height: 320px;\n overflow-y: auto;\n user-select: none;\n}\n\n.b-listbox--sm {\n --b-listbox-font-size: 13px;\n --b-listbox-option-padding-x: 10px;\n --b-listbox-option-padding-y: 4px;\n}\n\n.b-listbox--lg {\n --b-listbox-font-size: 16px;\n --b-listbox-option-padding-x: 14px;\n --b-listbox-option-padding-y: 8px;\n}\n\n.b-listbox:focus-visible {\n box-shadow: var(--b-listbox-focus-ring);\n}\n\n.b-listbox--disabled {\n cursor: not-allowed;\n opacity: 0.6;\n}\n\n/* ── Option ── */\n.b-listbox__option {\n padding: var(--b-listbox-option-padding-y) var(--b-listbox-option-padding-x);\n cursor: pointer;\n display: block;\n line-height: 1.5;\n transition:\n background-color var(--b-listbox-transition-duration) ease,\n color var(--b-listbox-transition-duration) ease;\n}\n\n.b-listbox__option--active {\n background-color: var(--b-listbox-option-bg-active);\n}\n\n.b-listbox__option--selected {\n background-color: var(--b-listbox-option-bg-selected);\n color: var(--b-listbox-option-fg-selected);\n font-weight: 500;\n}\n\n.b-listbox__option--disabled {\n cursor: not-allowed;\n color: var(--b-listbox-disabled-color);\n background-color: transparent;\n}\n\n.b-listbox__option:not(.b-listbox__option--disabled):hover {\n background-color: var(--b-listbox-option-bg-hover);\n}\n\n/* ── Group ── */\n.b-listbox__group {\n display: block;\n padding: 0;\n}\n\n.b-listbox__group-label {\n display: block;\n padding: 6px var(--b-listbox-option-padding-x) 4px;\n color: var(--b-listbox-group-label-color);\n font-size: 0.85em;\n font-weight: 600;\n text-transform: uppercase;\n letter-spacing: 0.04em;\n}\n\n.b-listbox__group-list {\n list-style: none;\n margin: 0;\n padding: 0;\n}\n\n/* ── Dark mode ── */\n[data-prefers-color='dark'] .b-listbox {\n --b-listbox-bg: #141414;\n --b-listbox-fg: rgba(255, 255, 255, 0.88);\n --b-listbox-border-color: #424242;\n --b-listbox-option-bg-hover: rgba(255, 255, 255, 0.08);\n --b-listbox-option-bg-active: rgba(255, 255, 255, 0.12);\n --b-listbox-option-bg-selected: oklch(28% 0.08 258);\n --b-listbox-option-fg-selected: oklch(80% 0.14 258);\n --b-listbox-group-label-color: rgba(255, 255, 255, 0.45);\n --b-listbox-disabled-color: rgba(255, 255, 255, 0.25);\n --b-listbox-focus-ring: 0 0 0 2px rgba(22, 104, 220, 0.3);\n}\n\n@media (prefers-color-scheme: dark) {\n [data-prefers-color='system'] .b-listbox {\n --b-listbox-bg: #141414;\n --b-listbox-fg: rgba(255, 255, 255, 0.88);\n --b-listbox-border-color: #424242;\n --b-listbox-option-bg-hover: rgba(255, 255, 255, 0.08);\n --b-listbox-option-bg-active: rgba(255, 255, 255, 0.12);\n --b-listbox-option-bg-selected: oklch(28% 0.08 258);\n --b-listbox-option-fg-selected: oklch(80% 0.14 258);\n --b-listbox-group-label-color: rgba(255, 255, 255, 0.45);\n --b-listbox-disabled-color: rgba(255, 255, 255, 0.25);\n --b-listbox-focus-ring: 0 0 0 2px rgba(22, 104, 220, 0.3);\n }\n}\n\n/* ── Reduced motion ── */\n@media (prefers-reduced-motion: reduce) {\n .b-listbox__option {\n transition: none;\n }\n}\n</style>\n"],"mappings":""}
|
|
@@ -0,0 +1,166 @@
|
|
|
1
|
+
import { Fragment as e, computed as t, createElementBlock as n, defineComponent as r, normalizeClass as i, normalizeStyle as a, onBeforeUnmount as o, onMounted as s, openBlock as c, ref as l, renderList as u, renderSlot as d, watch as f } from "vue";
|
|
2
|
+
//#region src/components/BMasonry/BMasonry.vue?vue&type=script&setup=true&lang.ts
|
|
3
|
+
var p = ["data-masonry-key"], m = /* @__PURE__ */ r({
|
|
4
|
+
__name: "BMasonry",
|
|
5
|
+
props: {
|
|
6
|
+
columns: { default: 3 },
|
|
7
|
+
gutter: { default: 0 },
|
|
8
|
+
items: { default: () => [] },
|
|
9
|
+
fresh: {
|
|
10
|
+
type: Boolean,
|
|
11
|
+
default: !1
|
|
12
|
+
},
|
|
13
|
+
classNames: { type: [Object, Function] },
|
|
14
|
+
styles: { type: [Object, Function] }
|
|
15
|
+
},
|
|
16
|
+
emits: ["layoutChange"],
|
|
17
|
+
setup(r, { emit: m }) {
|
|
18
|
+
let h = m, g = {
|
|
19
|
+
xs: 0,
|
|
20
|
+
sm: 576,
|
|
21
|
+
md: 768,
|
|
22
|
+
lg: 992,
|
|
23
|
+
xl: 1200,
|
|
24
|
+
xxl: 1600
|
|
25
|
+
};
|
|
26
|
+
function _(e, t) {
|
|
27
|
+
if (typeof e == "number") return Math.max(1, e);
|
|
28
|
+
let n = Object.keys(g).sort((e, t) => g[t] - g[e]);
|
|
29
|
+
for (let r of n) if (t >= g[r] && e[r] !== void 0) return Math.max(1, e[r]);
|
|
30
|
+
let r = Object.keys(e).sort((e, t) => g[e] - g[t])[0];
|
|
31
|
+
return r ? Math.max(1, e[r]) : 1;
|
|
32
|
+
}
|
|
33
|
+
let v = l(null), y = l(0), b = null;
|
|
34
|
+
function x() {
|
|
35
|
+
v.value && (y.value = v.value.offsetWidth);
|
|
36
|
+
}
|
|
37
|
+
let S = l({}), C = null, w = l(/* @__PURE__ */ new Map());
|
|
38
|
+
function T(e, t) {
|
|
39
|
+
if (t) w.value.set(e, t), r.fresh && C && C.observe(t);
|
|
40
|
+
else {
|
|
41
|
+
let t = w.value.get(e);
|
|
42
|
+
t && C && C.unobserve(t), w.value.delete(e);
|
|
43
|
+
let n = { ...S.value };
|
|
44
|
+
delete n[e], S.value = n;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
function E() {
|
|
48
|
+
!r.fresh || typeof ResizeObserver > "u" || (C = new ResizeObserver((e) => {
|
|
49
|
+
for (let t of e) {
|
|
50
|
+
let e = t.target.dataset.masonryKey;
|
|
51
|
+
if (e !== void 0) {
|
|
52
|
+
let n = t.contentRect.height;
|
|
53
|
+
S.value[e] !== n && (S.value = {
|
|
54
|
+
...S.value,
|
|
55
|
+
[e]: n
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
}), w.value.forEach((e) => C.observe(e)));
|
|
60
|
+
}
|
|
61
|
+
let D = t(() => _(r.columns, y.value)), O = t(() => {
|
|
62
|
+
let e = r.gutter;
|
|
63
|
+
if (Array.isArray(e)) return [_(e[0], y.value), _(e[1], y.value)];
|
|
64
|
+
let t = _(e, y.value);
|
|
65
|
+
return [t, t];
|
|
66
|
+
}), k = t(() => {
|
|
67
|
+
let e = D.value, t = Array.from({ length: e }, () => []), n = Array(e).fill(0), [, i] = O.value;
|
|
68
|
+
for (let a = 0; a < r.items.length; a++) {
|
|
69
|
+
let o = r.items[a], s;
|
|
70
|
+
s = o.column === void 0 ? n.indexOf(Math.min(...n)) : Math.max(0, Math.min(e - 1, o.column - 1)), t[s].push({
|
|
71
|
+
item: o,
|
|
72
|
+
originalIndex: a
|
|
73
|
+
});
|
|
74
|
+
let c = S.value[o.key] ?? o.height ?? 0;
|
|
75
|
+
n[s] += c + (t[s].length > 1 ? i : 0);
|
|
76
|
+
}
|
|
77
|
+
return t;
|
|
78
|
+
});
|
|
79
|
+
f(t(() => {
|
|
80
|
+
let e = D.value, t = {};
|
|
81
|
+
for (let e = 0; e < r.items.length; e++) {
|
|
82
|
+
let n = r.items[e], i = k.value.findIndex((e) => e.some((e) => e.item.key === n.key));
|
|
83
|
+
i >= 0 && (t[n.key] = i);
|
|
84
|
+
}
|
|
85
|
+
return {
|
|
86
|
+
columns: e,
|
|
87
|
+
columnMap: t
|
|
88
|
+
};
|
|
89
|
+
}), (e) => {
|
|
90
|
+
h("layoutChange", e);
|
|
91
|
+
}, { immediate: !0 });
|
|
92
|
+
function A(e, t) {
|
|
93
|
+
let n = ["b-masonry__item"];
|
|
94
|
+
if (!r.classNames) return n;
|
|
95
|
+
if (typeof r.classNames == "function") {
|
|
96
|
+
let i = r.classNames(e, t);
|
|
97
|
+
i && n.push(...Array.isArray(i) ? i : [i]);
|
|
98
|
+
} else if (typeof r.classNames.item == "function") {
|
|
99
|
+
let i = r.classNames.item(e, t);
|
|
100
|
+
i && n.push(...Array.isArray(i) ? i : [i]);
|
|
101
|
+
} else typeof r.classNames.item == "string" && n.push(r.classNames.item);
|
|
102
|
+
return n;
|
|
103
|
+
}
|
|
104
|
+
function j(e, t) {
|
|
105
|
+
return r.styles ? typeof r.styles == "function" ? r.styles(e, t) ?? {} : typeof r.styles.item == "function" ? r.styles.item(e, t) ?? {} : r.styles.item && typeof r.styles.item == "object" ? r.styles.item : {} : {};
|
|
106
|
+
}
|
|
107
|
+
function M(e) {
|
|
108
|
+
let t = ["b-masonry__column"];
|
|
109
|
+
return !r.classNames || typeof r.classNames == "function" || r.classNames.column && t.push(r.classNames.column), t;
|
|
110
|
+
}
|
|
111
|
+
function N(e) {
|
|
112
|
+
return !r.styles || typeof r.styles == "function" ? {} : r.styles.column ?? {};
|
|
113
|
+
}
|
|
114
|
+
let P = t(() => {
|
|
115
|
+
let e = ["b-masonry"];
|
|
116
|
+
return !r.classNames || typeof r.classNames == "function" || r.classNames.root && e.push(r.classNames.root), e;
|
|
117
|
+
}), F = t(() => {
|
|
118
|
+
let e = {
|
|
119
|
+
"--b-masonry-columns": String(D.value),
|
|
120
|
+
"--b-masonry-col-gap": `${O.value[0]}px`,
|
|
121
|
+
"--b-masonry-row-gap": `${O.value[1]}px`
|
|
122
|
+
};
|
|
123
|
+
if (r.styles && typeof r.styles == "object" && "root" in r.styles) {
|
|
124
|
+
let t = r.styles;
|
|
125
|
+
t.root && Object.assign(e, t.root);
|
|
126
|
+
}
|
|
127
|
+
return e;
|
|
128
|
+
});
|
|
129
|
+
return s(() => {
|
|
130
|
+
x(), typeof ResizeObserver < "u" ? (b = new ResizeObserver(() => x()), v.value && b.observe(v.value)) : window.addEventListener("resize", x), r.fresh && E();
|
|
131
|
+
}), f(() => r.fresh, (e) => {
|
|
132
|
+
e ? E() : (C?.disconnect(), C = null, S.value = {});
|
|
133
|
+
}), o(() => {
|
|
134
|
+
b?.disconnect(), C?.disconnect(), window.removeEventListener("resize", x);
|
|
135
|
+
}), (t, r) => (c(), n("div", {
|
|
136
|
+
ref_key: "rootEl",
|
|
137
|
+
ref: v,
|
|
138
|
+
class: i(P.value),
|
|
139
|
+
style: a(F.value),
|
|
140
|
+
role: "list",
|
|
141
|
+
"aria-label": "Masonry layout"
|
|
142
|
+
}, [(c(!0), n(e, null, u(k.value, (r, o) => (c(), n("div", {
|
|
143
|
+
key: o,
|
|
144
|
+
class: i(M(o)),
|
|
145
|
+
style: a(N(o)),
|
|
146
|
+
role: "presentation"
|
|
147
|
+
}, [(c(!0), n(e, null, u(r, ({ item: e, originalIndex: r }) => (c(), n("div", {
|
|
148
|
+
key: e.key,
|
|
149
|
+
ref_for: !0,
|
|
150
|
+
ref: (t) => T(e.key, t),
|
|
151
|
+
"data-masonry-key": e.key,
|
|
152
|
+
class: i(A(e, o)),
|
|
153
|
+
style: a(j(e, o)),
|
|
154
|
+
role: "listitem"
|
|
155
|
+
}, [t.$slots.item ? d(t.$slots, "item", {
|
|
156
|
+
key: 0,
|
|
157
|
+
item: e,
|
|
158
|
+
index: r,
|
|
159
|
+
column: o
|
|
160
|
+
}) : d(t.$slots, "default", { key: 1 })], 14, p))), 128))], 6))), 128))], 6));
|
|
161
|
+
}
|
|
162
|
+
});
|
|
163
|
+
//#endregion
|
|
164
|
+
export { m as default };
|
|
165
|
+
|
|
166
|
+
//# sourceMappingURL=design-system132.js.map
|