@7pmlabs/design-system 2.0.8 → 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-system173.js
DELETED
|
@@ -1,185 +0,0 @@
|
|
|
1
|
-
import { useComponentId as e } from "./design-system10.js";
|
|
2
|
-
import { Fragment as t, computed as n, createElementBlock as r, createElementVNode as i, defineComponent as a, mergeModels as o, normalizeClass as s, openBlock as c, ref as l, renderList as u, renderSlot as d, unref as f, useModel as p, watch as m } from "vue";
|
|
3
|
-
//#region src/components/BRate/BRate.vue?vue&type=script&setup=true&lang.ts
|
|
4
|
-
var h = [
|
|
5
|
-
"aria-label",
|
|
6
|
-
"aria-disabled",
|
|
7
|
-
"aria-valuenow",
|
|
8
|
-
"aria-valuemax",
|
|
9
|
-
"aria-valuetext",
|
|
10
|
-
"tabindex"
|
|
11
|
-
], g = [
|
|
12
|
-
"title",
|
|
13
|
-
"onMousemove",
|
|
14
|
-
"onClick"
|
|
15
|
-
], _ = {
|
|
16
|
-
class: "b-rate__star-first",
|
|
17
|
-
"aria-hidden": "true"
|
|
18
|
-
}, v = ["data-character"], y = {
|
|
19
|
-
key: 1,
|
|
20
|
-
class: "b-rate__icon",
|
|
21
|
-
viewBox: "0 0 24 24",
|
|
22
|
-
fill: "currentColor",
|
|
23
|
-
"aria-hidden": "true"
|
|
24
|
-
}, b = {
|
|
25
|
-
class: "b-rate__star-second",
|
|
26
|
-
"aria-hidden": "true"
|
|
27
|
-
}, x = ["data-character"], S = {
|
|
28
|
-
key: 1,
|
|
29
|
-
class: "b-rate__icon",
|
|
30
|
-
viewBox: "0 0 24 24",
|
|
31
|
-
fill: "currentColor",
|
|
32
|
-
"aria-hidden": "true"
|
|
33
|
-
}, C = ["name", "value"], w = /* @__PURE__ */ a({
|
|
34
|
-
__name: "BRate",
|
|
35
|
-
props: /* @__PURE__ */ o({
|
|
36
|
-
allowClear: {
|
|
37
|
-
type: Boolean,
|
|
38
|
-
default: !0
|
|
39
|
-
},
|
|
40
|
-
allowHalf: {
|
|
41
|
-
type: Boolean,
|
|
42
|
-
default: !1
|
|
43
|
-
},
|
|
44
|
-
count: { default: 5 },
|
|
45
|
-
disabled: {
|
|
46
|
-
type: Boolean,
|
|
47
|
-
default: !1
|
|
48
|
-
},
|
|
49
|
-
keyboard: {
|
|
50
|
-
type: Boolean,
|
|
51
|
-
default: !0
|
|
52
|
-
},
|
|
53
|
-
size: { default: "default" },
|
|
54
|
-
tooltips: { default: () => [] },
|
|
55
|
-
character: {}
|
|
56
|
-
}, {
|
|
57
|
-
modelValue: { default: 0 },
|
|
58
|
-
modelModifiers: {}
|
|
59
|
-
}),
|
|
60
|
-
emits: /* @__PURE__ */ o([
|
|
61
|
-
"hover-change",
|
|
62
|
-
"change",
|
|
63
|
-
"focus",
|
|
64
|
-
"blur",
|
|
65
|
-
"keydown"
|
|
66
|
-
], ["update:modelValue"]),
|
|
67
|
-
setup(a, { expose: o, emit: w }) {
|
|
68
|
-
let T = p(a, "modelValue"), E = w, { componentUID: D } = e(), O = l(0), k = l(!1), A = l(0), j = n(() => O.value > 0 ? O.value : T.value), M = n(() => {
|
|
69
|
-
let e = [];
|
|
70
|
-
for (let t = 1; t <= a.count; t++) e.push({
|
|
71
|
-
index: t,
|
|
72
|
-
value: t
|
|
73
|
-
});
|
|
74
|
-
return e;
|
|
75
|
-
});
|
|
76
|
-
function N(e) {
|
|
77
|
-
let t = j.value;
|
|
78
|
-
return e <= Math.floor(t) ? "full" : a.allowHalf && e - .5 <= t && e > t ? "half" : "zero";
|
|
79
|
-
}
|
|
80
|
-
function P(e, t) {
|
|
81
|
-
if (a.disabled) return;
|
|
82
|
-
let n = t && a.allowHalf ? e - .5 : e;
|
|
83
|
-
a.allowClear && n === T.value ? (T.value = 0, E("change", 0)) : (T.value = n, E("change", n));
|
|
84
|
-
}
|
|
85
|
-
function F(e, t) {
|
|
86
|
-
if (a.disabled) return;
|
|
87
|
-
let n = t.currentTarget.getBoundingClientRect(), r = t.clientX - n.left < n.width / 2, i;
|
|
88
|
-
i = a.allowHalf && r ? e - .5 : e, i !== O.value && (O.value = i, E("hover-change", i));
|
|
89
|
-
}
|
|
90
|
-
function I() {
|
|
91
|
-
a.disabled || (O.value = 0, E("hover-change", 0));
|
|
92
|
-
}
|
|
93
|
-
function L() {
|
|
94
|
-
k.value = !0, A.value = Math.ceil(T.value) || 1, E("focus");
|
|
95
|
-
}
|
|
96
|
-
function R() {
|
|
97
|
-
k.value = !1, A.value = 0, E("blur");
|
|
98
|
-
}
|
|
99
|
-
function z(e) {
|
|
100
|
-
if (a.disabled || !a.keyboard) return;
|
|
101
|
-
E("keydown", e);
|
|
102
|
-
let t = a.allowHalf ? .5 : 1;
|
|
103
|
-
switch (e.key) {
|
|
104
|
-
case "ArrowRight":
|
|
105
|
-
case "ArrowUp": {
|
|
106
|
-
e.preventDefault();
|
|
107
|
-
let n = Math.min(T.value + t, a.count);
|
|
108
|
-
T.value = n, A.value = Math.ceil(n), E("change", n);
|
|
109
|
-
break;
|
|
110
|
-
}
|
|
111
|
-
case "ArrowLeft":
|
|
112
|
-
case "ArrowDown": {
|
|
113
|
-
e.preventDefault();
|
|
114
|
-
let n = Math.max(T.value - t, 0);
|
|
115
|
-
T.value = n, A.value = Math.ceil(n) || 1, E("change", n);
|
|
116
|
-
break;
|
|
117
|
-
}
|
|
118
|
-
case "Enter":
|
|
119
|
-
case " ":
|
|
120
|
-
e.preventDefault(), a.allowClear && A.value === Math.ceil(T.value) && (T.value = 0, E("change", 0));
|
|
121
|
-
break;
|
|
122
|
-
}
|
|
123
|
-
}
|
|
124
|
-
let B = l(null);
|
|
125
|
-
function V() {
|
|
126
|
-
B.value?.focus();
|
|
127
|
-
}
|
|
128
|
-
function H() {
|
|
129
|
-
B.value?.blur();
|
|
130
|
-
}
|
|
131
|
-
return o({
|
|
132
|
-
focus: V,
|
|
133
|
-
blur: H
|
|
134
|
-
}), m(O, (e) => {
|
|
135
|
-
e === 0 && (A.value = Math.ceil(T.value) || 0);
|
|
136
|
-
}), (e, n) => (c(), r("div", {
|
|
137
|
-
ref_key: "rootRef",
|
|
138
|
-
ref: B,
|
|
139
|
-
class: s(["b-rate", [`b-rate--${a.size}`, {
|
|
140
|
-
"b-rate--disabled": a.disabled,
|
|
141
|
-
"b-rate--focused": k.value
|
|
142
|
-
}]]),
|
|
143
|
-
role: "slider",
|
|
144
|
-
"aria-label": e.$attrs["aria-label"] || "Rating",
|
|
145
|
-
"aria-disabled": a.disabled || void 0,
|
|
146
|
-
"aria-valuenow": T.value,
|
|
147
|
-
"aria-valuemin": 0,
|
|
148
|
-
"aria-valuemax": a.count,
|
|
149
|
-
"aria-valuetext": `${T.value} out of ${a.count} stars`,
|
|
150
|
-
tabindex: a.disabled ? -1 : 0,
|
|
151
|
-
onMouseleave: I,
|
|
152
|
-
onFocus: L,
|
|
153
|
-
onBlur: R,
|
|
154
|
-
onKeydown: z
|
|
155
|
-
}, [(c(!0), r(t, null, u(M.value, (t) => (c(), r("div", {
|
|
156
|
-
key: t.index,
|
|
157
|
-
class: s(["b-rate__star", {
|
|
158
|
-
"b-rate__star--full": N(t.index) === "full",
|
|
159
|
-
"b-rate__star--half": N(t.index) === "half",
|
|
160
|
-
"b-rate__star--zero": N(t.index) === "zero",
|
|
161
|
-
"b-rate__star--active": O.value > 0,
|
|
162
|
-
"b-rate__star--focused": k.value && A.value === t.index
|
|
163
|
-
}]),
|
|
164
|
-
title: a.tooltips[t.index - 1] || void 0,
|
|
165
|
-
onMousemove: (e) => F(t.index, e),
|
|
166
|
-
onClick: (e) => P(t.index, a.allowHalf && e.offsetX < e.currentTarget.offsetWidth / 2)
|
|
167
|
-
}, [i("div", _, [d(e.$slots, "character", { index: t.index }, () => [a.character ? (c(), r("span", {
|
|
168
|
-
key: 0,
|
|
169
|
-
class: "b-rate__character",
|
|
170
|
-
"data-character": a.character
|
|
171
|
-
}, null, 8, v)) : (c(), r("svg", y, [...n[0] ||= [i("path", { d: "M12 2l3.09 6.26L22 9.27l-5 4.87 1.18 6.88L12 17.77l-6.18 3.25L7 14.14 2 9.27l6.91-1.01L12 2z" }, null, -1)]]))], !0)]), i("div", b, [d(e.$slots, "character", { index: t.index }, () => [a.character ? (c(), r("span", {
|
|
172
|
-
key: 0,
|
|
173
|
-
class: "b-rate__character",
|
|
174
|
-
"data-character": a.character
|
|
175
|
-
}, null, 8, x)) : (c(), r("svg", S, [...n[1] ||= [i("path", { d: "M12 2l3.09 6.26L22 9.27l-5 4.87 1.18 6.88L12 17.77l-6.18 3.25L7 14.14 2 9.27l6.91-1.01L12 2z" }, null, -1)]]))], !0)])], 42, g))), 128)), i("input", {
|
|
176
|
-
type: "hidden",
|
|
177
|
-
name: `b-rate-${f(D)}`,
|
|
178
|
-
value: T.value
|
|
179
|
-
}, null, 8, C)], 42, h));
|
|
180
|
-
}
|
|
181
|
-
});
|
|
182
|
-
//#endregion
|
|
183
|
-
export { w as default };
|
|
184
|
-
|
|
185
|
-
//# sourceMappingURL=design-system173.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"design-system173.js","names":["$attrs"],"sources":["../src/components/BRate/BRate.vue"],"sourcesContent":["<script lang=\"ts\" setup>\nimport { useComponentId } from '@/composables/useComponentId.ts';\nimport { computed, ref, watch } from 'vue';\n\n//#region Props\nconst {\n allowClear = true,\n allowHalf = false,\n count = 5,\n disabled = false,\n keyboard = true,\n size = 'default',\n tooltips = [],\n character,\n} = defineProps<{\n /** Whether to allow clearing the value when clicking the same star again. */\n allowClear?: boolean;\n /** Whether to allow half-star selection. */\n allowHalf?: boolean;\n /** Total number of stars. */\n count?: number;\n /** If true, the component is read-only and cannot be interacted with. */\n disabled?: boolean;\n /** Whether keyboard navigation is enabled. */\n keyboard?: boolean;\n /** Size of the stars. */\n size?: 'small' | 'default' | 'large';\n /** Array of tooltip strings displayed on hover for each star. */\n tooltips?: string[];\n /** Custom character/icon rendered as each star. Receives `{ index }`. */\n character?: string;\n}>();\n\n/**\n * The current rating value.\n * Supports v-model for controlled usage.\n */\nconst model = defineModel<number>({ default: 0 });\n\nconst emit = defineEmits<{\n 'hover-change': [value: number];\n change: [value: number];\n focus: [];\n blur: [];\n keydown: [event: KeyboardEvent];\n}>();\n//#endregion\n\n//#region Internal state\nconst { componentUID } = useComponentId();\nconst hoverValue = ref(0);\nconst isFocused = ref(false);\nconst focusedIndex = ref(0);\n\nconst currentValue = computed(() =>\n hoverValue.value > 0 ? hoverValue.value : model.value,\n);\n\nconst stars = computed(() => {\n const items: { index: number; value: number }[] = [];\n for (let i = 1; i <= count; i++) {\n items.push({ index: i, value: i });\n }\n return items;\n});\n//#endregion\n\n//#region Star state\nfunction getStarState(index: number): 'full' | 'half' | 'zero' {\n const val = currentValue.value;\n if (index <= Math.floor(val)) return 'full';\n if (allowHalf && index - 0.5 <= val && index > val) return 'half';\n return 'zero';\n}\n//#endregion\n\n//#region Handlers\nfunction handleClick(index: number, isHalf: boolean) {\n if (disabled) return;\n\n const newValue = isHalf && allowHalf ? index - 0.5 : index;\n\n if (allowClear && newValue === model.value) {\n model.value = 0;\n emit('change', 0);\n } else {\n model.value = newValue;\n emit('change', newValue);\n }\n}\n\nfunction handleMouseMove(index: number, event: MouseEvent) {\n if (disabled) return;\n\n const target = event.currentTarget as HTMLElement;\n const rect = target.getBoundingClientRect();\n const isLeftHalf = event.clientX - rect.left < rect.width / 2;\n\n let newHoverValue: number;\n if (allowHalf && isLeftHalf) {\n newHoverValue = index - 0.5;\n } else {\n newHoverValue = index;\n }\n\n if (newHoverValue !== hoverValue.value) {\n hoverValue.value = newHoverValue;\n emit('hover-change', newHoverValue);\n }\n}\n\nfunction handleMouseLeave() {\n if (disabled) return;\n hoverValue.value = 0;\n emit('hover-change', 0);\n}\n\nfunction handleFocus() {\n isFocused.value = true;\n focusedIndex.value = Math.ceil(model.value) || 1;\n emit('focus');\n}\n\nfunction handleBlur() {\n isFocused.value = false;\n focusedIndex.value = 0;\n emit('blur');\n}\n\nfunction handleKeyDown(event: KeyboardEvent) {\n if (disabled || !keyboard) return;\n emit('keydown', event);\n\n const step = allowHalf ? 0.5 : 1;\n\n switch (event.key) {\n case 'ArrowRight':\n case 'ArrowUp': {\n event.preventDefault();\n const next = Math.min(model.value + step, count);\n model.value = next;\n focusedIndex.value = Math.ceil(next);\n emit('change', next);\n break;\n }\n case 'ArrowLeft':\n case 'ArrowDown': {\n event.preventDefault();\n const prev = Math.max(model.value - step, 0);\n model.value = prev;\n focusedIndex.value = Math.ceil(prev) || 1;\n emit('change', prev);\n break;\n }\n case 'Enter':\n case ' ': {\n event.preventDefault();\n if (allowClear && focusedIndex.value === Math.ceil(model.value)) {\n model.value = 0;\n emit('change', 0);\n }\n break;\n }\n }\n}\n//#endregion\n\n//#region Expose\nconst rootRef = ref<HTMLElement | null>(null);\n\nfunction focus() {\n rootRef.value?.focus();\n}\n\nfunction blur() {\n rootRef.value?.blur();\n}\n\ndefineExpose({ focus, blur });\n//#endregion\n\n//#region Watch hover for tooltip\nwatch(hoverValue, (val) => {\n if (val === 0) {\n focusedIndex.value = Math.ceil(model.value) || 0;\n }\n});\n//#endregion\n</script>\n\n<template>\n <div\n ref=\"rootRef\"\n class=\"b-rate\"\n :class=\"[\n `b-rate--${size}`,\n {\n 'b-rate--disabled': disabled,\n 'b-rate--focused': isFocused,\n },\n ]\"\n role=\"slider\"\n :aria-label=\"$attrs['aria-label'] as string || 'Rating'\"\n :aria-disabled=\"disabled || undefined\"\n :aria-valuenow=\"model\"\n :aria-valuemin=\"0\"\n :aria-valuemax=\"count\"\n :aria-valuetext=\"`${model} out of ${count} stars`\"\n :tabindex=\"disabled ? -1 : 0\"\n @mouseleave=\"handleMouseLeave\"\n @focus=\"handleFocus\"\n @blur=\"handleBlur\"\n @keydown=\"handleKeyDown\"\n >\n <div\n v-for=\"star in stars\"\n :key=\"star.index\"\n class=\"b-rate__star\"\n :class=\"{\n 'b-rate__star--full': getStarState(star.index) === 'full',\n 'b-rate__star--half': getStarState(star.index) === 'half',\n 'b-rate__star--zero': getStarState(star.index) === 'zero',\n 'b-rate__star--active': hoverValue > 0,\n 'b-rate__star--focused': isFocused && focusedIndex === star.index,\n }\"\n :title=\"tooltips[star.index - 1] || undefined\"\n @mousemove=\"(e) => handleMouseMove(star.index, e)\"\n @click=\"(e) => handleClick(star.index, allowHalf && (e.offsetX < (e.currentTarget as HTMLElement).offsetWidth / 2))\"\n >\n <div class=\"b-rate__star-first\" aria-hidden=\"true\">\n <slot name=\"character\" :index=\"star.index\">\n <span v-if=\"character\" class=\"b-rate__character\" :data-character=\"character\" />\n <svg\n v-else\n class=\"b-rate__icon\"\n viewBox=\"0 0 24 24\"\n fill=\"currentColor\"\n aria-hidden=\"true\"\n >\n <path\n d=\"M12 2l3.09 6.26L22 9.27l-5 4.87 1.18 6.88L12 17.77l-6.18 3.25L7 14.14 2 9.27l6.91-1.01L12 2z\"\n />\n </svg>\n </slot>\n </div>\n <div class=\"b-rate__star-second\" aria-hidden=\"true\">\n <slot name=\"character\" :index=\"star.index\">\n <span v-if=\"character\" class=\"b-rate__character\" :data-character=\"character\" />\n <svg\n v-else\n class=\"b-rate__icon\"\n viewBox=\"0 0 24 24\"\n fill=\"currentColor\"\n aria-hidden=\"true\"\n >\n <path\n d=\"M12 2l3.09 6.26L22 9.27l-5 4.87 1.18 6.88L12 17.77l-6.18 3.25L7 14.14 2 9.27l6.91-1.01L12 2z\"\n />\n </svg>\n </slot>\n </div>\n </div>\n\n <input\n type=\"hidden\"\n :name=\"`b-rate-${componentUID}`\"\n :value=\"model\"\n />\n </div>\n</template>\n\n<style scoped>\n.b-rate {\n --b-rate-star-bg: rgba(0, 0, 0, 0.06);\n --b-rate-star-color: #fadb14;\n --b-rate-star-hover-scale: scale(1.1);\n --b-rate-star-size: 20px;\n\n display: inline-flex;\n gap: 8px;\n align-items: center;\n outline: none;\n cursor: pointer;\n line-height: 1;\n}\n\n.b-rate--small {\n --b-rate-star-size: 15px;\n gap: 6px;\n}\n\n.b-rate--large {\n --b-rate-star-size: 25px;\n gap: 10px;\n}\n\n.b-rate--disabled {\n cursor: not-allowed;\n opacity: 0.65;\n}\n\n.b-rate:focus-visible {\n outline: 2px solid var(--b-rate-star-color);\n outline-offset: 4px;\n border-radius: 2px;\n}\n\n.b-rate__star {\n position: relative;\n display: inline-flex;\n width: var(--b-rate-star-size);\n height: var(--b-rate-star-size);\n cursor: pointer;\n transition: transform 0.15s ease;\n}\n\n.b-rate--disabled .b-rate__star {\n cursor: not-allowed;\n}\n\n.b-rate__star:not(.b-rate--disabled .b-rate__star):hover {\n transform: var(--b-rate-star-hover-scale);\n}\n\n.b-rate__star--focused {\n outline: 2px solid var(--b-rate-star-color);\n outline-offset: 2px;\n border-radius: 2px;\n}\n\n.b-rate__star-first,\n.b-rate__star-second {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n display: flex;\n align-items: center;\n justify-content: flex-start;\n user-select: none;\n}\n\n.b-rate__star-first {\n width: 50%;\n overflow: hidden;\n z-index: 1;\n}\n\n.b-rate__star-second {\n z-index: 0;\n}\n\n/* Zero state: both halves use background color */\n.b-rate__star--zero .b-rate__star-first,\n.b-rate__star--zero .b-rate__star-second {\n color: var(--b-rate-star-bg);\n}\n\n/* Full state: both halves use active color */\n.b-rate__star--full .b-rate__star-first,\n.b-rate__star--full .b-rate__star-second {\n color: var(--b-rate-star-color);\n}\n\n/* Half state: first half active, second half background */\n.b-rate__star--half .b-rate__star-first {\n color: var(--b-rate-star-color);\n}\n\n.b-rate__star--half .b-rate__star-second {\n color: var(--b-rate-star-bg);\n}\n\n.b-rate__icon {\n width: var(--b-rate-star-size);\n height: var(--b-rate-star-size);\n flex-shrink: 0;\n display: block;\n}\n\n.b-rate__character {\n font-size: var(--b-rate-star-size);\n line-height: 1;\n white-space: nowrap;\n}\n\n.b-rate__character::before {\n content: attr(data-character);\n}\n\n/* Dark mode */\n[data-prefers-color='dark'] .b-rate {\n --b-rate-star-bg: rgba(255, 255, 255, 0.12);\n --b-rate-star-color: #fadb14;\n}\n\n@media (prefers-color-scheme: dark) {\n [data-prefers-color='system'] .b-rate {\n --b-rate-star-bg: rgba(255, 255, 255, 0.12);\n --b-rate-star-color: #fadb14;\n }\n}\n\n/* Reduced motion */\n@media (prefers-reduced-motion: reduce) {\n .b-rate__star {\n transition: none;\n }\n}\n</style>\n"],"mappings":"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"}
|
package/dist/design-system176.js
DELETED
|
@@ -1,118 +0,0 @@
|
|
|
1
|
-
import { Fragment as e, computed as t, createCommentVNode as n, createElementBlock as r, createElementVNode as i, createTextVNode as a, defineComponent as o, nextTick as s, normalizeClass as c, normalizeStyle as l, onMounted as u, openBlock as d, ref as f, renderList as p, renderSlot as m, toDisplayString as h, watch as g } from "vue";
|
|
2
|
-
//#region src/components/BSegmented/BSegmented.vue?vue&type=script&setup=true&lang.ts
|
|
3
|
-
var _ = ["aria-disabled"], v = [
|
|
4
|
-
"aria-label",
|
|
5
|
-
"aria-checked",
|
|
6
|
-
"aria-disabled",
|
|
7
|
-
"tabindex",
|
|
8
|
-
"onClick",
|
|
9
|
-
"onKeydown"
|
|
10
|
-
], y = { class: "b-segmented__item-inner" }, b = {
|
|
11
|
-
key: 0,
|
|
12
|
-
class: "b-segmented__item-icon",
|
|
13
|
-
"aria-hidden": "true"
|
|
14
|
-
}, x = { class: "b-segmented__item-label" }, S = /* @__PURE__ */ o({
|
|
15
|
-
__name: "BSegmented",
|
|
16
|
-
props: {
|
|
17
|
-
modelValue: {},
|
|
18
|
-
defaultValue: {},
|
|
19
|
-
options: { default: () => [] },
|
|
20
|
-
disabled: {
|
|
21
|
-
type: Boolean,
|
|
22
|
-
default: !1
|
|
23
|
-
},
|
|
24
|
-
size: { default: "default" },
|
|
25
|
-
block: {
|
|
26
|
-
type: Boolean,
|
|
27
|
-
default: !1
|
|
28
|
-
}
|
|
29
|
-
},
|
|
30
|
-
emits: ["update:modelValue", "change"],
|
|
31
|
-
setup(o, { emit: S }) {
|
|
32
|
-
let C = S, w = t(() => o.options.map((e) => typeof e == "string" || typeof e == "number" ? {
|
|
33
|
-
label: String(e),
|
|
34
|
-
value: e,
|
|
35
|
-
disabled: !1
|
|
36
|
-
} : {
|
|
37
|
-
label: String(e.label ?? e.value),
|
|
38
|
-
value: e.value,
|
|
39
|
-
disabled: e.disabled ?? !1,
|
|
40
|
-
icon: e.icon
|
|
41
|
-
})), T = t(() => o.modelValue !== void 0), E = f(o.modelValue ?? o.defaultValue ?? w.value[0]?.value);
|
|
42
|
-
g(() => o.modelValue, (e) => {
|
|
43
|
-
e !== void 0 && (E.value = e);
|
|
44
|
-
}), g(w, (e) => {
|
|
45
|
-
E.value === void 0 && e.length > 0 && (E.value = e[0].value);
|
|
46
|
-
});
|
|
47
|
-
let D = t(() => T.value ? o.modelValue : E.value), O = f(null), k = f(null);
|
|
48
|
-
function A(e) {
|
|
49
|
-
if (!O.value) return;
|
|
50
|
-
let t = O.value.querySelectorAll(".b-segmented__item")[e];
|
|
51
|
-
if (!t) return;
|
|
52
|
-
let n = O.value.getBoundingClientRect().left, { left: r, width: i } = t.getBoundingClientRect();
|
|
53
|
-
k.value = {
|
|
54
|
-
transform: `translateX(${r - n}px)`,
|
|
55
|
-
width: `${i}px`
|
|
56
|
-
};
|
|
57
|
-
}
|
|
58
|
-
let j = t(() => w.value.findIndex((e) => e.value === D.value));
|
|
59
|
-
g(j, async (e) => {
|
|
60
|
-
e < 0 || (await s(), A(e));
|
|
61
|
-
}, { immediate: !1 }), u(() => {
|
|
62
|
-
j.value >= 0 && A(j.value);
|
|
63
|
-
});
|
|
64
|
-
function M(e) {
|
|
65
|
-
o.disabled || e.disabled || e.value !== D.value && (T.value || (E.value = e.value), C("update:modelValue", e.value), C("change", e.value));
|
|
66
|
-
}
|
|
67
|
-
function N(e, t) {
|
|
68
|
-
(e.key === "Enter" || e.key === " ") && (e.preventDefault(), M(t)), (e.key === "ArrowRight" || e.key === "ArrowDown") && (e.preventDefault(), P(1)), (e.key === "ArrowLeft" || e.key === "ArrowUp") && (e.preventDefault(), P(-1));
|
|
69
|
-
}
|
|
70
|
-
function P(e) {
|
|
71
|
-
if (!O.value) return;
|
|
72
|
-
let t = Array.from(O.value.querySelectorAll(".b-segmented__item:not([aria-disabled=\"true\"])")), n = document.activeElement, r = t.indexOf(n);
|
|
73
|
-
if (r < 0) {
|
|
74
|
-
t[0]?.focus();
|
|
75
|
-
return;
|
|
76
|
-
}
|
|
77
|
-
t[(r + e + t.length) % t.length]?.focus();
|
|
78
|
-
}
|
|
79
|
-
let F = t(() => ["b-segmented", {
|
|
80
|
-
"b-segmented--disabled": o.disabled,
|
|
81
|
-
"b-segmented--block": o.block,
|
|
82
|
-
"b-segmented--small": o.size === "small",
|
|
83
|
-
"b-segmented--large": o.size === "large"
|
|
84
|
-
}]);
|
|
85
|
-
return (t, s) => (d(), r("div", {
|
|
86
|
-
ref_key: "rootRef",
|
|
87
|
-
ref: O,
|
|
88
|
-
class: c(F.value),
|
|
89
|
-
role: "group",
|
|
90
|
-
"aria-disabled": o.disabled ? "true" : void 0
|
|
91
|
-
}, [k.value ? (d(), r("div", {
|
|
92
|
-
key: 0,
|
|
93
|
-
class: "b-segmented__thumb",
|
|
94
|
-
"aria-hidden": "true",
|
|
95
|
-
style: l({
|
|
96
|
-
transform: k.value.transform,
|
|
97
|
-
width: k.value.width
|
|
98
|
-
})
|
|
99
|
-
}, null, 4)) : n("", !0), (d(!0), r(e, null, p(w.value, (e) => (d(), r("div", {
|
|
100
|
-
key: String(e.value),
|
|
101
|
-
class: c(["b-segmented__item", {
|
|
102
|
-
"b-segmented__item--selected": e.value === D.value,
|
|
103
|
-
"b-segmented__item--disabled": e.disabled || o.disabled
|
|
104
|
-
}]),
|
|
105
|
-
role: "radio",
|
|
106
|
-
"aria-label": e.label,
|
|
107
|
-
"aria-checked": e.value === D.value,
|
|
108
|
-
"aria-disabled": e.disabled || o.disabled ? "true" : void 0,
|
|
109
|
-
tabindex: o.disabled || e.disabled ? -1 : e.value === D.value ? 0 : -1,
|
|
110
|
-
onClick: (t) => M(e),
|
|
111
|
-
onKeydown: (t) => N(t, e)
|
|
112
|
-
}, [i("div", y, [e.icon ? (d(), r("span", b, h(e.icon), 1)) : n("", !0), i("span", x, [m(t.$slots, "label", { option: e }, () => [a(h(e.label), 1)])])])], 42, v))), 128))], 10, _));
|
|
113
|
-
}
|
|
114
|
-
});
|
|
115
|
-
//#endregion
|
|
116
|
-
export { S as default };
|
|
117
|
-
|
|
118
|
-
//# sourceMappingURL=design-system176.js.map
|