@7pmlabs/design-system 1.0.10 → 1.0.11
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 +57 -6
- package/dist/design-system.css +1 -1
- package/dist/design-system.js +66 -60
- package/dist/design-system100.js +4 -5
- package/dist/design-system100.js.map +1 -1
- package/dist/design-system101.js +53 -506
- package/dist/design-system101.js.map +1 -1
- package/dist/{design-system93.js → design-system102.js} +1 -1
- package/dist/design-system102.js.map +1 -0
- package/dist/design-system103.js +13 -5
- package/dist/design-system103.js.map +1 -1
- package/dist/design-system104.js +109 -7
- package/dist/design-system104.js.map +1 -1
- package/dist/design-system106.js +9 -0
- package/dist/design-system106.js.map +1 -0
- package/dist/design-system107.js +206 -6
- package/dist/design-system107.js.map +1 -1
- package/dist/design-system109.js +9 -0
- package/dist/design-system109.js.map +1 -0
- package/dist/design-system110.js +507 -6
- package/dist/design-system110.js.map +1 -1
- package/dist/design-system112.js +8 -0
- package/dist/design-system112.js.map +1 -0
- package/dist/design-system113.js +7 -5
- package/dist/design-system113.js.map +1 -1
- package/dist/design-system114.js +209 -9
- package/dist/design-system114.js.map +1 -1
- package/dist/design-system116.js +9 -0
- package/dist/design-system116.js.map +1 -0
- package/dist/design-system117.js +224 -6
- package/dist/design-system117.js.map +1 -1
- package/dist/design-system119.js +9 -0
- package/dist/design-system119.js.map +1 -0
- package/dist/design-system12.js.map +1 -1
- package/dist/design-system120.js +163 -5
- package/dist/design-system120.js.map +1 -1
- package/dist/design-system122.js +5 -90
- package/dist/design-system122.js.map +1 -1
- package/dist/design-system123.js +12 -0
- package/dist/design-system123.js.map +1 -0
- package/dist/design-system124.js +274 -5
- package/dist/design-system124.js.map +1 -1
- package/dist/design-system126.js +9 -0
- package/dist/design-system126.js.map +1 -0
- package/dist/design-system127.js +16 -5
- package/dist/design-system127.js.map +1 -1
- package/dist/design-system129.js +8 -0
- package/dist/design-system129.js.map +1 -0
- package/dist/design-system130.js +12 -5
- package/dist/design-system130.js.map +1 -1
- package/dist/design-system131.js +76 -137
- package/dist/design-system131.js.map +1 -1
- package/dist/design-system133.js +1 -1
- package/dist/design-system133.js.map +1 -1
- package/dist/design-system134.js +37 -90
- package/dist/design-system134.js.map +1 -1
- package/dist/design-system136.js +1 -1
- package/dist/design-system136.js.map +1 -1
- package/dist/design-system137.js +226 -20
- package/dist/design-system137.js.map +1 -1
- package/dist/design-system139.js +4 -5
- package/dist/design-system139.js.map +1 -1
- package/dist/design-system140.js +151 -9
- package/dist/design-system140.js.map +1 -1
- package/dist/design-system142.js +3 -2
- package/dist/design-system142.js.map +1 -1
- package/dist/design-system143.js +93 -19
- package/dist/design-system143.js.map +1 -1
- package/dist/design-system145.js +5 -158
- package/dist/design-system145.js.map +1 -1
- package/dist/design-system146.js +12 -0
- package/dist/design-system146.js.map +1 -0
- package/dist/design-system147.js +37 -5
- package/dist/design-system147.js.map +1 -1
- package/dist/design-system148.js +4 -307
- package/dist/design-system148.js.map +1 -1
- package/dist/design-system149.js +24 -0
- package/dist/{design-system144.js.map → design-system149.js.map} +1 -1
- package/dist/design-system150.js +2 -3
- package/dist/design-system150.js.map +1 -1
- package/dist/design-system151.js +131 -213
- package/dist/design-system151.js.map +1 -1
- package/dist/design-system153.js +1 -1
- package/dist/design-system153.js.map +1 -1
- package/dist/design-system154.js +278 -160
- package/dist/design-system154.js.map +1 -1
- package/dist/design-system156.js +1 -1
- package/dist/design-system156.js.map +1 -1
- package/dist/design-system157.js +240 -3
- package/dist/design-system157.js.map +1 -1
- package/dist/design-system159.js +8 -0
- package/dist/design-system159.js.map +1 -0
- package/dist/design-system16.js.map +1 -1
- package/dist/design-system160.js +189 -6
- package/dist/design-system160.js.map +1 -1
- package/dist/design-system162.js +8 -0
- package/dist/design-system162.js.map +1 -0
- package/dist/design-system163.js +3 -6
- package/dist/design-system163.js.map +1 -1
- package/dist/design-system164.js +46 -57
- package/dist/design-system164.js.map +1 -1
- package/dist/design-system166.js +2 -2
- package/dist/design-system166.js.map +1 -1
- package/dist/design-system167.js +44 -170
- package/dist/design-system167.js.map +1 -1
- package/dist/design-system169.js +2 -2
- package/dist/design-system169.js.map +1 -1
- package/dist/design-system170.js +55 -101
- package/dist/design-system170.js.map +1 -1
- package/dist/design-system172.js +5 -4
- package/dist/design-system172.js.map +1 -1
- package/dist/design-system173.js +182 -11
- package/dist/design-system173.js.map +1 -1
- package/dist/design-system175.js +9 -0
- package/dist/design-system175.js.map +1 -0
- package/dist/design-system176.js +115 -6
- package/dist/design-system176.js.map +1 -1
- package/dist/design-system178.js +8 -0
- package/dist/design-system178.js.map +1 -0
- package/dist/design-system179.js +11 -5
- package/dist/design-system179.js.map +1 -1
- package/dist/design-system180.js +444 -70
- package/dist/design-system180.js.map +1 -1
- package/dist/design-system182.js +5 -4
- package/dist/design-system182.js.map +1 -1
- package/dist/design-system183.js +21 -21
- package/dist/design-system183.js.map +1 -1
- package/dist/design-system185.js +1 -1
- package/dist/design-system185.js.map +1 -1
- package/dist/design-system186.js +85 -25
- package/dist/design-system186.js.map +1 -1
- package/dist/design-system188.js +1 -1
- package/dist/design-system188.js.map +1 -1
- package/dist/design-system189.js +7 -5
- package/dist/design-system189.js.map +1 -1
- package/dist/design-system19.js.map +1 -1
- package/dist/design-system191.js +1 -1
- package/dist/design-system191.js.map +1 -1
- package/dist/design-system192.js +20 -23
- package/dist/design-system192.js.map +1 -1
- package/dist/design-system194.js +1 -1
- package/dist/design-system194.js.map +1 -1
- package/dist/design-system195.js +24 -323
- package/dist/design-system195.js.map +1 -1
- package/dist/design-system197.js +1 -1
- package/dist/design-system197.js.map +1 -1
- package/dist/design-system198.js +19 -88
- 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 +330 -17
- package/dist/design-system201.js.map +1 -1
- package/dist/design-system203.js +5 -3
- package/dist/design-system203.js.map +1 -1
- package/dist/design-system204.js +88 -407
- 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 +17 -106
- package/dist/design-system207.js.map +1 -1
- package/dist/{design-system202.js → design-system208.js} +2 -2
- package/dist/{design-system202.js.map → design-system208.js.map} +1 -1
- package/dist/design-system209.js +3 -6
- package/dist/design-system209.js.map +1 -1
- package/dist/design-system210.js +403 -90
- package/dist/design-system210.js.map +1 -1
- package/dist/design-system212.js +4 -5
- package/dist/design-system212.js.map +1 -1
- package/dist/design-system213.js +45 -723
- 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 +88 -11
- package/dist/design-system216.js.map +1 -1
- package/dist/design-system217.js +4 -525
- package/dist/design-system217.js.map +1 -1
- package/dist/design-system218.js +111 -0
- package/dist/design-system218.js.map +1 -0
- package/dist/design-system22.js.map +1 -1
- package/dist/design-system220.js +6 -3
- package/dist/design-system220.js.map +1 -1
- package/dist/design-system221.js +103 -43
- package/dist/design-system221.js.map +1 -1
- package/dist/design-system223.js +6 -283
- package/dist/design-system223.js.map +1 -1
- package/dist/design-system224.js +740 -0
- package/dist/design-system224.js.map +1 -0
- package/dist/design-system226.js +5 -119
- package/dist/design-system226.js.map +1 -1
- package/dist/{design-system60.js → design-system227.js} +6 -8
- package/dist/design-system227.js.map +1 -0
- package/dist/design-system228.js +525 -5
- package/dist/design-system228.js.map +1 -1
- package/dist/{design-system219.js → design-system230.js} +2 -2
- package/dist/{design-system219.js.map → design-system230.js.map} +1 -1
- package/dist/design-system231.js +3 -5
- package/dist/design-system231.js.map +1 -1
- package/dist/design-system232.js +42 -50
- package/dist/design-system232.js.map +1 -1
- package/dist/design-system233.js +1 -1
- package/dist/design-system233.js.map +1 -1
- package/dist/design-system234.js +254 -141
- package/dist/design-system234.js.map +1 -1
- package/dist/design-system236.js +1 -1
- package/dist/design-system236.js.map +1 -1
- package/dist/design-system237.js +119 -7
- package/dist/design-system237.js.map +1 -1
- package/dist/design-system239.js +8 -0
- package/dist/design-system239.js.map +1 -0
- package/dist/design-system240.js +112 -5
- package/dist/design-system240.js.map +1 -1
- package/dist/design-system242.js +8 -0
- package/dist/design-system242.js.map +1 -0
- package/dist/design-system243.js +54 -6
- package/dist/design-system243.js.map +1 -1
- package/dist/design-system244.js +4 -7
- package/dist/design-system244.js.map +1 -1
- package/dist/design-system245.js +139 -343
- package/dist/design-system245.js.map +1 -1
- package/dist/design-system247.js +4 -5
- package/dist/design-system247.js.map +1 -1
- package/dist/design-system248.js +10 -0
- package/dist/design-system248.js.map +1 -0
- package/dist/{design-system238.js → design-system249.js} +2 -2
- package/dist/design-system249.js.map +1 -0
- package/dist/design-system25.js.map +1 -1
- package/dist/design-system251.js +8 -0
- package/dist/design-system251.js.map +1 -0
- package/dist/{design-system241.js → design-system252.js} +1 -1
- package/dist/design-system252.js.map +1 -0
- package/dist/design-system254.js +9 -0
- package/dist/design-system254.js.map +1 -0
- package/dist/design-system255.js +12 -0
- package/dist/design-system255.js.map +1 -0
- package/dist/design-system256.js +769 -0
- package/dist/design-system256.js.map +1 -0
- package/dist/design-system258.js +9 -0
- package/dist/design-system258.js.map +1 -0
- package/dist/design-system259.js +10 -0
- package/dist/design-system259.js.map +1 -0
- package/dist/design-system260.js +377 -0
- package/dist/design-system260.js.map +1 -0
- package/dist/design-system262.js +9 -0
- package/dist/design-system262.js.map +1 -0
- package/dist/design-system28.js.map +1 -1
- package/dist/design-system3.js.map +1 -1
- package/dist/design-system30.js +21 -138
- package/dist/design-system30.js.map +1 -1
- package/dist/design-system32.js +5 -4
- package/dist/design-system32.js.map +1 -1
- package/dist/design-system33.js +488 -14
- package/dist/design-system33.js.map +1 -1
- package/dist/design-system35.js +1 -1
- package/dist/design-system35.js.map +1 -1
- package/dist/design-system36.js +135 -17
- package/dist/design-system36.js.map +1 -1
- package/dist/design-system38.js +1 -1
- package/dist/design-system38.js.map +1 -1
- package/dist/design-system39.js +16 -11
- package/dist/design-system39.js.map +1 -1
- package/dist/design-system4.js.map +1 -1
- package/dist/design-system41.js +8 -0
- package/dist/design-system41.js.map +1 -0
- package/dist/design-system42.js +26 -5
- package/dist/design-system42.js.map +1 -1
- package/dist/design-system44.js +5 -71
- package/dist/design-system44.js.map +1 -1
- package/dist/design-system45.js +353 -0
- package/dist/design-system45.js.map +1 -0
- package/dist/design-system47.js +5 -50
- package/dist/design-system47.js.map +1 -1
- package/dist/design-system48.js +11 -4
- package/dist/design-system48.js.map +1 -1
- package/dist/design-system49.js +476 -3
- package/dist/design-system49.js.map +1 -1
- package/dist/design-system51.js +8 -0
- package/dist/design-system51.js.map +1 -0
- package/dist/design-system52.js +3 -5
- package/dist/design-system52.js.map +1 -1
- package/dist/design-system53.js +56 -83
- package/dist/design-system53.js.map +1 -1
- package/dist/design-system55.js +5 -4
- package/dist/design-system55.js.map +1 -1
- package/dist/design-system56.js +50 -11
- package/dist/design-system56.js.map +1 -1
- package/dist/design-system57.js +4 -591
- package/dist/design-system57.js.map +1 -1
- package/dist/design-system58.js +6 -0
- package/dist/design-system58.js.map +1 -0
- package/dist/design-system59.js +64 -5
- package/dist/design-system59.js.map +1 -1
- package/dist/design-system61.js +5 -696
- package/dist/design-system61.js.map +1 -1
- package/dist/design-system62.js +101 -0
- package/dist/design-system62.js.map +1 -0
- package/dist/design-system64.js +5 -158
- package/dist/design-system64.js.map +1 -1
- package/dist/design-system65.js +14 -0
- package/dist/design-system65.js.map +1 -0
- package/dist/design-system66.js +591 -5
- package/dist/design-system66.js.map +1 -1
- package/dist/design-system68.js +3 -2
- package/dist/design-system68.js.map +1 -1
- package/dist/design-system69.js +13 -49
- package/dist/design-system69.js.map +1 -1
- package/dist/design-system7.js.map +1 -1
- package/dist/design-system70.js +699 -0
- package/dist/{design-system63.js.map → design-system70.js.map} +1 -1
- package/dist/design-system72.js +5 -199
- package/dist/design-system72.js.map +1 -1
- package/dist/design-system73.js +161 -0
- package/dist/design-system73.js.map +1 -0
- package/dist/design-system75.js +5 -7
- package/dist/design-system75.js.map +1 -1
- package/dist/design-system76.js +25 -269
- package/dist/design-system76.js.map +1 -1
- package/dist/design-system77.js +7 -0
- package/dist/design-system77.js.map +1 -0
- package/dist/design-system78.js +49 -5
- package/dist/design-system78.js.map +1 -1
- package/dist/{design-system71.js → design-system80.js} +2 -2
- package/dist/{design-system71.js.map → design-system80.js.map} +1 -1
- package/dist/design-system81.js +199 -5
- package/dist/design-system81.js.map +1 -1
- package/dist/design-system83.js +5 -99
- package/dist/design-system83.js.map +1 -1
- package/dist/design-system84.js +10 -0
- package/dist/design-system84.js.map +1 -0
- package/dist/design-system85.js +273 -5
- package/dist/design-system85.js.map +1 -1
- package/dist/design-system87.js +8 -0
- package/dist/design-system87.js.map +1 -0
- package/dist/design-system88.js +57 -5
- package/dist/design-system88.js.map +1 -1
- package/dist/design-system90.js +8 -0
- package/dist/design-system90.js.map +1 -0
- package/dist/design-system91.js +11 -5
- package/dist/design-system91.js.map +1 -1
- package/dist/design-system92.js +98 -53
- package/dist/design-system92.js.map +1 -1
- package/dist/design-system94.js +5 -13
- package/dist/design-system94.js.map +1 -1
- package/dist/design-system95.js +61 -104
- package/dist/design-system95.js.map +1 -1
- package/dist/design-system97.js +4 -5
- package/dist/design-system97.js.map +1 -1
- package/dist/design-system98.js +80 -198
- package/dist/design-system98.js.map +1 -1
- package/dist/types/components/BCalendar/BCalendar.spec.d.ts +1 -0
- package/dist/types/components/BCalendar/BCalendar.vue.d.ts +114 -0
- package/dist/types/components/BCalendar/index.d.ts +2 -0
- package/dist/types/components/BCalendar/types.d.ts +54 -0
- package/dist/types/components/BCarousel/BCarousel.spec.d.ts +1 -0
- package/dist/types/components/BCarousel/BCarousel.vue.d.ts +133 -0
- package/dist/types/components/BCarousel/index.d.ts +2 -0
- package/dist/types/components/BCarousel/types.d.ts +15 -0
- package/dist/types/components/BPagination/BPagination.vue.d.ts +1 -1
- package/dist/types/components/BStatistic/BStatistic.spec.d.ts +1 -0
- package/dist/types/components/BStatistic/BStatistic.vue.d.ts +44 -0
- package/dist/types/components/BStatistic/BStatisticTimer.vue.d.ts +50 -0
- package/dist/types/components/BStatistic/index.d.ts +3 -0
- package/dist/types/components/BStatistic/types.d.ts +6 -0
- package/dist/types/components/BTreeSelect/BTreeSelect.spec.d.ts +1 -0
- package/dist/types/components/BTreeSelect/BTreeSelect.vue.d.ts +143 -0
- package/dist/types/components/BTreeSelect/index.d.ts +2 -0
- package/dist/types/components/BTreeSelect/types.d.ts +77 -0
- package/dist/types/components/index.d.ts +4 -0
- package/dist/types/types.d.ts +3 -0
- package/package.json +6 -3
- package/dist/design-system105.js +0 -212
- package/dist/design-system105.js.map +0 -1
- package/dist/design-system108.js +0 -227
- package/dist/design-system108.js.map +0 -1
- package/dist/design-system111.js +0 -166
- package/dist/design-system111.js.map +0 -1
- package/dist/design-system115.js +0 -277
- package/dist/design-system115.js.map +0 -1
- package/dist/design-system118.js +0 -19
- package/dist/design-system118.js.map +0 -1
- package/dist/design-system121.js +0 -15
- package/dist/design-system121.js.map +0 -1
- package/dist/design-system125.js +0 -45
- package/dist/design-system125.js.map +0 -1
- package/dist/design-system128.js +0 -236
- package/dist/design-system128.js.map +0 -1
- package/dist/design-system141.js +0 -40
- package/dist/design-system141.js.map +0 -1
- package/dist/design-system144.js +0 -7
- package/dist/design-system158.js +0 -61
- package/dist/design-system158.js.map +0 -1
- package/dist/design-system161.js +0 -59
- package/dist/design-system161.js.map +0 -1
- package/dist/design-system174.js +0 -465
- package/dist/design-system174.js.map +0 -1
- package/dist/design-system177.js +0 -38
- package/dist/design-system177.js.map +0 -1
- package/dist/design-system222.js +0 -7
- package/dist/design-system222.js.map +0 -1
- package/dist/design-system225.js +0 -8
- package/dist/design-system225.js.map +0 -1
- package/dist/design-system229.js +0 -115
- package/dist/design-system229.js.map +0 -1
- package/dist/design-system238.js.map +0 -1
- package/dist/design-system241.js.map +0 -1
- package/dist/design-system40.js +0 -479
- package/dist/design-system40.js.map +0 -1
- package/dist/design-system43.js +0 -6
- package/dist/design-system43.js.map +0 -1
- package/dist/design-system46.js +0 -9
- package/dist/design-system46.js.map +0 -1
- package/dist/design-system50.js +0 -67
- package/dist/design-system50.js.map +0 -1
- package/dist/design-system60.js.map +0 -1
- package/dist/design-system63.js +0 -8
- package/dist/design-system67.js +0 -32
- package/dist/design-system67.js.map +0 -1
- package/dist/design-system74.js +0 -8
- package/dist/design-system74.js.map +0 -1
- package/dist/design-system79.js +0 -60
- package/dist/design-system79.js.map +0 -1
- package/dist/design-system82.js +0 -14
- package/dist/design-system82.js.map +0 -1
- package/dist/design-system86.js +0 -69
- package/dist/design-system86.js.map +0 -1
- package/dist/design-system89.js +0 -91
- package/dist/design-system89.js.map +0 -1
- package/dist/design-system93.js.map +0 -1
package/dist/design-system111.js
DELETED
|
@@ -1,166 +0,0 @@
|
|
|
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-system111.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"design-system111.js","names":[],"sources":["../src/components/BMasonry/BMasonry.vue?vue&type=script&setup=true&lang.ts"],"sourcesContent":["import { defineComponent as _defineComponent } from 'vue'\nimport { renderList as _renderList, Fragment as _Fragment, openBlock as _openBlock, createElementBlock as _createElementBlock, renderSlot as _renderSlot, createCommentVNode as _createCommentVNode, normalizeClass as _normalizeClass, normalizeStyle as _normalizeStyle } from \"vue\"\n\nconst _hoisted_1 = [\"data-masonry-key\"]\n\nimport { computed, onBeforeUnmount, onMounted, ref, watch } from 'vue';\nimport type {\n BMasonryBreakpoint,\n BMasonryClassNames,\n BMasonryItem,\n BMasonryLayoutChangePayload,\n BMasonryResponsive,\n BMasonryStyles,\n} from './types';\n\n// ─── Props ────────────────────────────────────────────────────────────────────\n\n\nexport default /*@__PURE__*/_defineComponent({\n __name: 'BMasonry',\n props: {\n columns: { default: 3 },\n gutter: { default: 0 },\n items: { default: () => ([]) },\n fresh: { type: Boolean, default: false },\n classNames: { type: [Object, Function] },\n styles: { type: [Object, Function] }\n },\n emits: [\"layoutChange\"],\n setup(__props: any, { emit: __emit }) {\n\n\n\n// ─── Emits ────────────────────────────────────────────────────────────────────\n\nconst emit = __emit;\n\n// ─── Slots ────────────────────────────────────────────────────────────────────\n\n\n\n// ─── Responsive helpers ───────────────────────────────────────────────────────\n\nconst BREAKPOINTS: Record<BMasonryBreakpoint, number> = {\n xs: 0,\n sm: 576,\n md: 768,\n lg: 992,\n xl: 1200,\n xxl: 1600,\n};\n\nfunction resolveResponsive(value: BMasonryResponsive, width: number): number {\n if (typeof value === 'number') return Math.max(1, value);\n\n // Breakpoint map — pick the largest breakpoint that still fits\n const keys = (Object.keys(BREAKPOINTS) as BMasonryBreakpoint[]).sort(\n (a, b) => BREAKPOINTS[b] - BREAKPOINTS[a],\n );\n\n for (const bp of keys) {\n if (width >= BREAKPOINTS[bp] && value[bp] !== undefined) {\n return Math.max(1, value[bp]!);\n }\n }\n // Fallback to smallest defined value\n const smallest = (Object.keys(value) as BMasonryBreakpoint[]).sort(\n (a, b) => BREAKPOINTS[a] - BREAKPOINTS[b],\n )[0];\n return smallest ? Math.max(1, value[smallest]!) : 1;\n}\n\n// ─── Container width tracking ─────────────────────────────────────────────────\n\nconst rootEl = ref<HTMLElement | null>(null);\nconst containerWidth = ref(0);\n\nlet containerObserver: ResizeObserver | null = null;\n\nfunction updateWidth() {\n if (rootEl.value) {\n containerWidth.value = rootEl.value.offsetWidth;\n }\n}\n\n// ─── Item height tracking (fresh mode) ────────────────────────────────────────\n\nconst itemHeights = ref<Record<string | number, number>>({});\nlet itemObserver: ResizeObserver | null = null;\nconst itemEls = ref<Map<string | number, Element>>(new Map());\n\nfunction registerItemEl(key: string | number, el: Element | null) {\n if (el) {\n itemEls.value.set(key, el);\n if (__props.fresh && itemObserver) {\n itemObserver.observe(el);\n }\n } else {\n const old = itemEls.value.get(key);\n if (old && itemObserver) itemObserver.unobserve(old);\n itemEls.value.delete(key);\n const next = { ...itemHeights.value };\n delete next[key];\n itemHeights.value = next;\n }\n}\n\nfunction setupItemObserver() {\n if (!__props.fresh || typeof ResizeObserver === 'undefined') return;\n itemObserver = new ResizeObserver((entries) => {\n let changed = false;\n for (const entry of entries) {\n const el = entry.target as HTMLElement;\n const key = el.dataset.masonryKey;\n if (key !== undefined) {\n const h = entry.contentRect.height;\n if (itemHeights.value[key] !== h) {\n itemHeights.value = { ...itemHeights.value, [key]: h };\n changed = true;\n }\n }\n }\n if (changed) {\n // trigger layout recompute (handled reactively via computed)\n }\n });\n // Observe any already-mounted elements\n itemEls.value.forEach((el) => itemObserver!.observe(el));\n}\n\n// ─── Core layout algorithm ────────────────────────────────────────────────────\n\nconst resolvedColumns = computed(() => resolveResponsive(__props.columns, containerWidth.value));\n\nconst resolvedGutter = computed<[number, number]>(() => {\n const g = __props.gutter;\n if (Array.isArray(g)) {\n const colGap = resolveResponsive(g[0] as BMasonryResponsive, containerWidth.value);\n const rowGap = resolveResponsive(g[1] as BMasonryResponsive, containerWidth.value);\n return [colGap, rowGap];\n }\n const v = resolveResponsive(g as BMasonryResponsive, containerWidth.value);\n return [v, v];\n});\n\n/** Distribute items across columns using the \"shortest column first\" strategy. */\nconst columnBuckets = computed<{ item: BMasonryItem; originalIndex: number }[][]>(() => {\n const cols = resolvedColumns.value;\n const buckets: { item: BMasonryItem; originalIndex: number }[][] = Array.from(\n { length: cols },\n () => [],\n );\n const heights = Array<number>(cols).fill(0);\n const [, rowGap] = resolvedGutter.value;\n\n for (let i = 0; i < __props.items.length; i++) {\n const item = __props.items[i];\n let targetCol: number;\n\n if (item.column !== undefined) {\n // Pinned column (1-based → 0-based, clamped)\n targetCol = Math.max(0, Math.min(cols - 1, item.column - 1));\n } else {\n // Shortest column\n targetCol = heights.indexOf(Math.min(...heights));\n }\n\n buckets[targetCol].push({ item, originalIndex: i });\n const h = itemHeights.value[item.key] ?? item.height ?? 0;\n heights[targetCol] += h + (buckets[targetCol].length > 1 ? rowGap : 0);\n }\n\n return buckets;\n});\n\nconst layoutColumnMap = computed(() => {\n const cols = resolvedColumns.value;\n const map: Record<string | number, number> = {};\n for (let i = 0; i < __props.items.length; i++) {\n const item = __props.items[i];\n const bucket = columnBuckets.value.findIndex((b) =>\n b.some((entry) => entry.item.key === item.key),\n );\n if (bucket >= 0) map[item.key] = bucket;\n }\n return { columns: cols, columnMap: map };\n});\n\nwatch(layoutColumnMap, (val) => {\n emit('layoutChange', val);\n}, { immediate: true });\n\n// ─── CSS class/style helpers ──────────────────────────────────────────────────\n\nfunction getItemClasses(item: BMasonryItem, columnIndex: number) {\n const base = ['b-masonry__item'];\n if (!__props.classNames) return base;\n\n if (typeof __props.classNames === 'function') {\n const extra = __props.classNames(item, columnIndex);\n if (extra) base.push(...(Array.isArray(extra) ? extra : [extra as string]));\n } else if (typeof __props.classNames.item === 'function') {\n const extra = __props.classNames.item(item, columnIndex);\n if (extra) base.push(...(Array.isArray(extra) ? extra : [extra as string]));\n } else if (typeof __props.classNames.item === 'string') {\n base.push(__props.classNames.item);\n }\n return base;\n}\n\nfunction getItemStyles(item: BMasonryItem, columnIndex: number): Record<string, string> {\n if (!__props.styles) return {};\n if (typeof __props.styles === 'function') return __props.styles(item, columnIndex) ?? {};\n if (typeof __props.styles.item === 'function') return __props.styles.item(item, columnIndex) ?? {};\n if (__props.styles.item && typeof __props.styles.item === 'object') return __props.styles.item as Record<string, string>;\n return {};\n}\n\nfunction getColumnClasses(_colIndex: number): string[] {\n const base = ['b-masonry__column'];\n if (!__props.classNames || typeof __props.classNames === 'function') return base;\n if (__props.classNames.column) base.push(__props.classNames.column);\n return base;\n}\n\nfunction getColumnStyles(_colIndex: number): Record<string, string> {\n if (!__props.styles || typeof __props.styles === 'function') return {};\n return (__props.styles.column as Record<string, string>) ?? {};\n}\n\nconst rootClasses = computed(() => {\n const base = ['b-masonry'];\n if (!__props.classNames || typeof __props.classNames === 'function') return base;\n if (__props.classNames.root) base.push(__props.classNames.root);\n return base;\n});\n\nconst rootStyles = computed(() => {\n const base: Record<string, string> = {\n '--b-masonry-columns': String(resolvedColumns.value),\n '--b-masonry-col-gap': `${resolvedGutter.value[0]}px`,\n '--b-masonry-row-gap': `${resolvedGutter.value[1]}px`,\n };\n if (__props.styles && typeof __props.styles === 'object' && !('root' in __props.styles) === false) {\n const s = __props.styles as { root?: Record<string, string> };\n if (s.root) Object.assign(base, s.root);\n }\n return base;\n});\n\n// ─── Lifecycle ────────────────────────────────────────────────────────────────\n\nonMounted(() => {\n updateWidth();\n\n if (typeof ResizeObserver !== 'undefined') {\n containerObserver = new ResizeObserver(() => updateWidth());\n if (rootEl.value) containerObserver.observe(rootEl.value);\n } else {\n // SSR / no ResizeObserver: listen to window resize\n window.addEventListener('resize', updateWidth);\n }\n\n if (__props.fresh) setupItemObserver();\n});\n\nwatch(\n () => __props.fresh,\n (enabled) => {\n if (enabled) {\n setupItemObserver();\n } else {\n itemObserver?.disconnect();\n itemObserver = null;\n itemHeights.value = {};\n }\n },\n);\n\nonBeforeUnmount(() => {\n containerObserver?.disconnect();\n itemObserver?.disconnect();\n window.removeEventListener('resize', updateWidth);\n});\n\nreturn (_ctx: any,_cache: any) => {\n return (_openBlock(), _createElementBlock(\"div\", {\n ref_key: \"rootEl\",\n ref: rootEl,\n class: _normalizeClass(rootClasses.value),\n style: _normalizeStyle(rootStyles.value),\n role: \"list\",\n \"aria-label\": \"Masonry layout\"\n }, [\n (_openBlock(true), _createElementBlock(_Fragment, null, _renderList(columnBuckets.value, (bucket, colIdx) => {\n return (_openBlock(), _createElementBlock(\"div\", {\n key: colIdx,\n class: _normalizeClass(getColumnClasses(colIdx)),\n style: _normalizeStyle(getColumnStyles(colIdx)),\n role: \"presentation\"\n }, [\n (_openBlock(true), _createElementBlock(_Fragment, null, _renderList(bucket, ({ item, originalIndex }) => {\n return (_openBlock(), _createElementBlock(\"div\", {\n key: item.key,\n ref_for: true,\n ref: (el) => registerItemEl(item.key, el as Element | null),\n \"data-masonry-key\": item.key,\n class: _normalizeClass(getItemClasses(item, colIdx)),\n style: _normalizeStyle(getItemStyles(item, colIdx)),\n role: \"listitem\"\n }, [\n (_ctx.$slots.item)\n ? _renderSlot(_ctx.$slots, \"item\", {\n key: 0,\n item: item,\n index: originalIndex,\n column: colIdx\n })\n : _renderSlot(_ctx.$slots, \"default\", { key: 1 })\n ], 14, _hoisted_1))\n }), 128))\n ], 6))\n }), 128))\n ], 6))\n}\n}\n\n})"],"mappings":"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"}
|
package/dist/design-system115.js
DELETED
|
@@ -1,277 +0,0 @@
|
|
|
1
|
-
import { BCommonSize as e } from "./design-system3.js";
|
|
2
|
-
import { useComponentId as t } from "./design-system10.js";
|
|
3
|
-
import { BMentionsStatus as n, BMentionsVariant as r } from "./design-system114.js";
|
|
4
|
-
import { Fragment as i, computed as a, createCommentVNode as o, createElementBlock as s, createElementVNode as c, createTextVNode as l, defineComponent as u, mergeModels as d, mergeProps as f, nextTick as p, normalizeClass as m, openBlock as h, ref as g, renderList as _, renderSlot as v, toDisplayString as y, unref as b, useAttrs as ee, useCssVars as x, useModel as te, watch as S, withModifiers as C } from "vue";
|
|
5
|
-
//#region src/components/BMentions/BMentions.vue?vue&type=script&setup=true&lang.ts
|
|
6
|
-
var w = [
|
|
7
|
-
"aria-label",
|
|
8
|
-
"aria-expanded",
|
|
9
|
-
"aria-controls"
|
|
10
|
-
], T = [
|
|
11
|
-
"value",
|
|
12
|
-
"placeholder",
|
|
13
|
-
"disabled",
|
|
14
|
-
"readonly",
|
|
15
|
-
"rows",
|
|
16
|
-
"aria-label",
|
|
17
|
-
"aria-activedescendant"
|
|
18
|
-
], E = ["id", "aria-label"], D = {
|
|
19
|
-
key: 0,
|
|
20
|
-
class: "b-mentions__options"
|
|
21
|
-
}, O = [
|
|
22
|
-
"id",
|
|
23
|
-
"data-active",
|
|
24
|
-
"aria-selected",
|
|
25
|
-
"aria-disabled",
|
|
26
|
-
"onMousedown",
|
|
27
|
-
"onMouseenter"
|
|
28
|
-
], k = {
|
|
29
|
-
key: 1,
|
|
30
|
-
class: "b-mentions__not-found"
|
|
31
|
-
}, A = /* @__PURE__ */ u({
|
|
32
|
-
inheritAttrs: !1,
|
|
33
|
-
__name: "BMentions",
|
|
34
|
-
props: /* @__PURE__ */ d({
|
|
35
|
-
options: { default: () => [] },
|
|
36
|
-
size: { default: () => e.Medium },
|
|
37
|
-
variant: { default: () => r.Outlined },
|
|
38
|
-
placement: {},
|
|
39
|
-
prefix: { default: "@" },
|
|
40
|
-
split: { default: " " },
|
|
41
|
-
autoSize: {
|
|
42
|
-
type: [Boolean, Object],
|
|
43
|
-
default: !1
|
|
44
|
-
},
|
|
45
|
-
allowClear: {
|
|
46
|
-
type: Boolean,
|
|
47
|
-
default: !1
|
|
48
|
-
},
|
|
49
|
-
filterOption: {
|
|
50
|
-
type: [Boolean, Function],
|
|
51
|
-
default: !0
|
|
52
|
-
},
|
|
53
|
-
notFoundContent: { default: "Not Found" },
|
|
54
|
-
disabled: { type: Boolean },
|
|
55
|
-
readOnly: { type: Boolean },
|
|
56
|
-
status: {},
|
|
57
|
-
placeholder: {},
|
|
58
|
-
rows: { default: 3 }
|
|
59
|
-
}, {
|
|
60
|
-
modelValue: { default: "" },
|
|
61
|
-
modelModifiers: {}
|
|
62
|
-
}),
|
|
63
|
-
emits: /* @__PURE__ */ d([
|
|
64
|
-
"change",
|
|
65
|
-
"select",
|
|
66
|
-
"search",
|
|
67
|
-
"focus",
|
|
68
|
-
"blur",
|
|
69
|
-
"clear",
|
|
70
|
-
"resize",
|
|
71
|
-
"popupScroll"
|
|
72
|
-
], ["update:modelValue"]),
|
|
73
|
-
setup(e, { expose: r, emit: u }) {
|
|
74
|
-
x((e) => ({ v21fd39a6: N.value }));
|
|
75
|
-
let d = ee(), A = u, j = te(e, "modelValue"), { componentUID: M } = t(), N = a(() => `--b-mentions-anchor-${M.value}`), P = a(() => `b-mentions-listbox-${M.value}`), F = g(null), I = g(null), L = g(!1), R = g(!1), z = g(-1), B = g(!1), V = g(""), H = g(""), U = g(0), W = a(() => Array.isArray(e.prefix) ? e.prefix : [e.prefix]), G = a(() => {
|
|
76
|
-
let t = H.value.toLowerCase();
|
|
77
|
-
return e.filterOption ? typeof e.filterOption == "function" ? e.options.filter((n) => e.filterOption(t, n)) : t ? e.options.filter((e) => (e.label ?? e.value).toLowerCase().includes(t)) : e.options : e.options;
|
|
78
|
-
}), K = a(() => !B.value || G.value.length === 0 && e.notFoundContent === null ? !1 : R.value), q = (e) => e.label ?? e.value;
|
|
79
|
-
function J() {
|
|
80
|
-
R.value || I.value?.showPopover();
|
|
81
|
-
}
|
|
82
|
-
function Y() {
|
|
83
|
-
R.value && I.value?.hidePopover();
|
|
84
|
-
}
|
|
85
|
-
function X({ newState: e }) {
|
|
86
|
-
let t = e === "open";
|
|
87
|
-
R.value = t, t && G.value.length > 0 ? z.value = 0 : t || (z.value = -1, B.value = !1);
|
|
88
|
-
}
|
|
89
|
-
function Z(t, n) {
|
|
90
|
-
for (let r of W.value) {
|
|
91
|
-
let i = t.slice(0, n), a = i.lastIndexOf(r);
|
|
92
|
-
if (a < 0) continue;
|
|
93
|
-
let o = i.slice(a + r.length);
|
|
94
|
-
if (!/\s/.test(o) && (a === 0 || t[a - 1] === e.split || /\s/.test(t[a - 1]))) return {
|
|
95
|
-
start: a,
|
|
96
|
-
prefix: r
|
|
97
|
-
};
|
|
98
|
-
}
|
|
99
|
-
return null;
|
|
100
|
-
}
|
|
101
|
-
function ne(e, t) {
|
|
102
|
-
let n = Z(e, t);
|
|
103
|
-
n ? (B.value = !0, V.value = n.prefix, U.value = n.start, H.value = e.slice(n.start + n.prefix.length, t), A("search", H.value, n.prefix), p(() => J())) : Q();
|
|
104
|
-
}
|
|
105
|
-
function Q() {
|
|
106
|
-
Y(), B.value = !1, H.value = "", V.value = "", U.value = 0;
|
|
107
|
-
}
|
|
108
|
-
function $(t) {
|
|
109
|
-
if (t.disabled) return;
|
|
110
|
-
let n = F.value;
|
|
111
|
-
if (!n) return;
|
|
112
|
-
let r = j.value ?? "", i = n.selectionStart, a = r.slice(0, U.value), o = r.slice(i), s = `${V.value}${t.value}`, c = o && !o.startsWith(e.split) && e.split, l = `${a}${s}${c ? e.split : ""}${o}`;
|
|
113
|
-
j.value = l, A("change", l), A("select", t, V.value), Q();
|
|
114
|
-
let u = a.length + s.length + (c ? e.split.length : 0);
|
|
115
|
-
p(() => {
|
|
116
|
-
n.focus(), n.setSelectionRange(u, u);
|
|
117
|
-
});
|
|
118
|
-
}
|
|
119
|
-
function re(e) {
|
|
120
|
-
let t = e.target, n = t.value;
|
|
121
|
-
j.value = n, A("change", n);
|
|
122
|
-
let r = t.selectionStart;
|
|
123
|
-
ne(n, r), le();
|
|
124
|
-
}
|
|
125
|
-
function ie(e) {
|
|
126
|
-
L.value = !0, A("focus", e);
|
|
127
|
-
}
|
|
128
|
-
function ae(e) {
|
|
129
|
-
let t = e.relatedTarget;
|
|
130
|
-
I.value?.contains(t) || (L.value = !1, A("blur", e), Q());
|
|
131
|
-
}
|
|
132
|
-
function oe(e) {
|
|
133
|
-
if (K.value) switch (e.key) {
|
|
134
|
-
case "ArrowDown": {
|
|
135
|
-
e.preventDefault();
|
|
136
|
-
let t = G.value;
|
|
137
|
-
if (t.length === 0) return;
|
|
138
|
-
let n = z.value + 1;
|
|
139
|
-
for (let e = 0; e < t.length; e++) {
|
|
140
|
-
let r = (n + e) % t.length;
|
|
141
|
-
if (!t[r].disabled) {
|
|
142
|
-
z.value = r;
|
|
143
|
-
break;
|
|
144
|
-
}
|
|
145
|
-
}
|
|
146
|
-
break;
|
|
147
|
-
}
|
|
148
|
-
case "ArrowUp": {
|
|
149
|
-
e.preventDefault();
|
|
150
|
-
let t = G.value;
|
|
151
|
-
if (t.length === 0) return;
|
|
152
|
-
let n = z.value - 1;
|
|
153
|
-
for (let e = 0; e < t.length; e++) {
|
|
154
|
-
let r = ((n - e) % t.length + t.length) % t.length;
|
|
155
|
-
if (!t[r].disabled) {
|
|
156
|
-
z.value = r;
|
|
157
|
-
break;
|
|
158
|
-
}
|
|
159
|
-
}
|
|
160
|
-
break;
|
|
161
|
-
}
|
|
162
|
-
case "Enter":
|
|
163
|
-
if (e.preventDefault(), z.value >= 0) {
|
|
164
|
-
let e = G.value[z.value];
|
|
165
|
-
e && !e.disabled && $(e);
|
|
166
|
-
}
|
|
167
|
-
break;
|
|
168
|
-
case "Escape":
|
|
169
|
-
e.preventDefault(), Q();
|
|
170
|
-
break;
|
|
171
|
-
}
|
|
172
|
-
}
|
|
173
|
-
function se() {
|
|
174
|
-
j.value = "", A("change", ""), A("clear"), Q(), F.value?.focus();
|
|
175
|
-
}
|
|
176
|
-
function ce(e) {
|
|
177
|
-
A("popupScroll", e);
|
|
178
|
-
}
|
|
179
|
-
function le() {
|
|
180
|
-
if (!e.autoSize || !F.value) return;
|
|
181
|
-
let t = F.value;
|
|
182
|
-
t.style.height = "auto";
|
|
183
|
-
let n = typeof e.autoSize == "object" ? e.autoSize : {}, r = parseFloat(getComputedStyle(t).lineHeight) || 20, i = t.scrollHeight;
|
|
184
|
-
n.minRows && (i = Math.max(i, n.minRows * r)), n.maxRows && (i = Math.min(i, n.maxRows * r)), t.style.height = `${i}px`, A("resize", {
|
|
185
|
-
width: t.offsetWidth,
|
|
186
|
-
height: i
|
|
187
|
-
});
|
|
188
|
-
}
|
|
189
|
-
return S(z, () => {
|
|
190
|
-
p(() => {
|
|
191
|
-
(I.value?.querySelector("[data-active=\"true\"]"))?.scrollIntoView({ block: "nearest" });
|
|
192
|
-
});
|
|
193
|
-
}), S(j, (e) => {
|
|
194
|
-
F.value && F.value.value !== e && (F.value.value = e ?? "");
|
|
195
|
-
}), r({
|
|
196
|
-
focus: () => F.value?.focus(),
|
|
197
|
-
blur: () => F.value?.blur()
|
|
198
|
-
}), (t, r) => (h(), s("div", {
|
|
199
|
-
class: m(["b-mentions", [
|
|
200
|
-
`b-mentions--${e.size}`,
|
|
201
|
-
`b-mentions--${e.variant}`,
|
|
202
|
-
{
|
|
203
|
-
"b-mentions--focused": L.value,
|
|
204
|
-
"b-mentions--disabled": e.disabled,
|
|
205
|
-
"b-mentions--error": e.status === b(n).Error,
|
|
206
|
-
"b-mentions--warning": e.status === b(n).Warning,
|
|
207
|
-
"b-mentions--has-clear": e.allowClear
|
|
208
|
-
}
|
|
209
|
-
]]),
|
|
210
|
-
role: "combobox",
|
|
211
|
-
"aria-label": e.placeholder || "Mentions input",
|
|
212
|
-
"aria-expanded": K.value,
|
|
213
|
-
"aria-haspopup": "listbox",
|
|
214
|
-
"aria-controls": K.value ? P.value : void 0
|
|
215
|
-
}, [
|
|
216
|
-
c("textarea", f({
|
|
217
|
-
ref_key: "textareaRef",
|
|
218
|
-
ref: F
|
|
219
|
-
}, b(d), {
|
|
220
|
-
value: j.value,
|
|
221
|
-
class: "b-mentions__textarea",
|
|
222
|
-
placeholder: e.placeholder,
|
|
223
|
-
disabled: e.disabled,
|
|
224
|
-
readonly: e.readOnly,
|
|
225
|
-
rows: e.autoSize ? void 0 : e.rows,
|
|
226
|
-
"aria-label": e.placeholder || "Mentions input",
|
|
227
|
-
autocomplete: "off",
|
|
228
|
-
"aria-activedescendant": z.value >= 0 ? `${P.value}-option-${z.value}` : void 0,
|
|
229
|
-
"aria-autocomplete": "list",
|
|
230
|
-
onInput: re,
|
|
231
|
-
onFocus: ie,
|
|
232
|
-
onBlur: ae,
|
|
233
|
-
onKeydown: oe
|
|
234
|
-
}), null, 16, T),
|
|
235
|
-
e.allowClear && j.value && !e.disabled ? (h(), s("button", {
|
|
236
|
-
key: 0,
|
|
237
|
-
type: "button",
|
|
238
|
-
class: "b-mentions__clear",
|
|
239
|
-
"aria-label": "Clear input",
|
|
240
|
-
tabindex: "-1",
|
|
241
|
-
onMousedown: C(se, ["prevent"])
|
|
242
|
-
}, null, 32)) : o("", !0),
|
|
243
|
-
B.value || R.value ? (h(), s("div", {
|
|
244
|
-
key: 1,
|
|
245
|
-
ref_key: "menuRef",
|
|
246
|
-
ref: I,
|
|
247
|
-
id: P.value,
|
|
248
|
-
class: "b-mentions__dropdown",
|
|
249
|
-
popover: "manual",
|
|
250
|
-
role: "listbox",
|
|
251
|
-
"aria-label": `Mention suggestions for ${V.value}`,
|
|
252
|
-
onToggle: X,
|
|
253
|
-
onScroll: ce
|
|
254
|
-
}, [G.value.length > 0 ? (h(), s("ul", D, [(h(!0), s(i, null, _(G.value, (e, n) => (h(), s("li", {
|
|
255
|
-
key: e.value,
|
|
256
|
-
id: `${P.value}-option-${n}`,
|
|
257
|
-
class: m(["b-mentions__option", {
|
|
258
|
-
"b-mentions__option--active": n === z.value && !e.disabled,
|
|
259
|
-
"b-mentions__option--disabled": e.disabled
|
|
260
|
-
}]),
|
|
261
|
-
"data-active": n === z.value,
|
|
262
|
-
"aria-selected": n === z.value,
|
|
263
|
-
"aria-disabled": e.disabled ?? !1,
|
|
264
|
-
role: "option",
|
|
265
|
-
onMousedown: C((t) => $(e), ["prevent"]),
|
|
266
|
-
onMouseenter: (e) => z.value = n
|
|
267
|
-
}, [v(t.$slots, "option", {
|
|
268
|
-
option: e,
|
|
269
|
-
index: n
|
|
270
|
-
}, () => [l(y(q(e)), 1)], !0)], 42, O))), 128))])) : e.notFoundContent ? (h(), s("div", k, [v(t.$slots, "notFoundContent", {}, () => [l(y(e.notFoundContent), 1)], !0)])) : o("", !0)], 40, E)) : o("", !0)
|
|
271
|
-
], 10, w));
|
|
272
|
-
}
|
|
273
|
-
});
|
|
274
|
-
//#endregion
|
|
275
|
-
export { A as default };
|
|
276
|
-
|
|
277
|
-
//# sourceMappingURL=design-system115.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"design-system115.js","names":[],"sources":["../src/components/BMentions/BMentions.vue?vue&type=script&setup=true&lang.ts"],"sourcesContent":["import { useModel as _useModel, useCssVars as _useCssVars, mergeModels as _mergeModels, defineComponent as _defineComponent } from 'vue'\nimport { unref as _unref, mergeProps as _mergeProps, createElementVNode as _createElementVNode, withModifiers as _withModifiers, openBlock as _openBlock, createElementBlock as _createElementBlock, createCommentVNode as _createCommentVNode, renderList as _renderList, Fragment as _Fragment, renderSlot as _renderSlot, toDisplayString as _toDisplayString, createTextVNode as _createTextVNode, normalizeClass as _normalizeClass } from \"vue\"\n\nconst _hoisted_1 = [\"aria-label\", \"aria-expanded\", \"aria-controls\"]\nconst _hoisted_2 = [\"value\", \"placeholder\", \"disabled\", \"readonly\", \"rows\", \"aria-label\", \"aria-activedescendant\"]\nconst _hoisted_3 = [\"id\", \"aria-label\"]\nconst _hoisted_4 = {\n key: 0,\n class: \"b-mentions__options\"\n}\nconst _hoisted_5 = [\"id\", \"data-active\", \"aria-selected\", \"aria-disabled\", \"onMousedown\", \"onMouseenter\"]\nconst _hoisted_6 = {\n key: 1,\n class: \"b-mentions__not-found\"\n}\n\nimport { useComponentId } from '@/composables/useComponentId.ts';\nimport { BCommonSize } from '@/types.ts';\nimport { computed, nextTick, ref, useAttrs, watch } from 'vue';\n\nimport { BMentionsStatus, BMentionsVariant, type BMentionsOption } from './types.ts';\n\n\nexport default /*@__PURE__*/_defineComponent({\n ...{ inheritAttrs: false },\n __name: 'BMentions',\n props: /*@__PURE__*/_mergeModels({\n options: { default: () => ([]) },\n size: { default: () => (BCommonSize.Medium) },\n variant: { default: () => (BMentionsVariant.Outlined) },\n placement: {},\n prefix: { default: '@' },\n split: { default: ' ' },\n autoSize: { type: [Boolean, Object], default: false },\n allowClear: { type: Boolean, default: false },\n filterOption: { type: [Boolean, Function], default: true },\n notFoundContent: { default: 'Not Found' },\n disabled: { type: Boolean },\n readOnly: { type: Boolean },\n status: {},\n placeholder: {},\n rows: { default: 3 }\n }, {\n \"modelValue\": { default: '' },\n \"modelModifiers\": {},\n }),\n emits: /*@__PURE__*/_mergeModels([\"change\", \"select\", \"search\", \"focus\", \"blur\", \"clear\", \"resize\", \"popupScroll\"], [\"update:modelValue\"]),\n setup(__props: any, { expose: __expose, emit: __emit }) {\n\n_useCssVars(_ctx => ({\n \"v21fd39a6\": (anchorName.value)\n}))\n\n\n\nconst attrs = useAttrs();\n\n\n\nconst emit = __emit;\n\nconst model = _useModel<string>(__props, \"modelValue\");\n\nconst { componentUID } = useComponentId();\nconst anchorName = computed(() => `--b-mentions-anchor-${componentUID.value}`);\nconst listboxId = computed(() => `b-mentions-listbox-${componentUID.value}`);\n\nconst textareaRef = ref<HTMLTextAreaElement | null>(null);\nconst menuRef = ref<HTMLElement | null>(null);\nconst isFocused = ref(false);\nconst isOpen = ref(false);\nconst activeIndex = ref(-1);\nconst measuring = ref(false);\nconst measurePrefix = ref('');\nconst measureText = ref('');\nconst measureStart = ref(0);\n\nconst prefixes = computed(() => (Array.isArray(__props.prefix) ? __props.prefix : [__props.prefix]));\n\nconst filteredOptions = computed(() => {\n const search = measureText.value.toLowerCase();\n if (!__props.filterOption) return __props.options;\n if (typeof __props.filterOption === 'function') {\n return __props.options.filter((opt) => __props.filterOption(search, opt));\n }\n if (!search) return __props.options;\n return __props.options.filter((opt) => {\n const text = (opt.label ?? opt.value).toLowerCase();\n return text.includes(search);\n });\n});\n\nconst showDropdown = computed(() => {\n if (!measuring.value) return false;\n if (filteredOptions.value.length === 0 && __props.notFoundContent === null) return false;\n return isOpen.value;\n});\n\nconst getOptionLabel = (opt: BMentionsOption) => opt.label ?? opt.value;\n\nfunction openMenu() {\n if (isOpen.value) return;\n menuRef.value?.showPopover();\n}\n\nfunction closeMenu() {\n if (!isOpen.value) return;\n menuRef.value?.hidePopover();\n}\n\nfunction handleToggle({ newState }: ToggleEvent) {\n const nowOpen = newState === 'open';\n isOpen.value = nowOpen;\n if (nowOpen && filteredOptions.value.length > 0) {\n activeIndex.value = 0;\n } else if (!nowOpen) {\n activeIndex.value = -1;\n measuring.value = false;\n }\n}\n\nfunction getLastMeasureIndex(\n text: string,\n cursorPos: number,\n): { start: number; prefix: string } | null {\n for (const p of prefixes.value) {\n const beforeCursor = text.slice(0, cursorPos);\n const lastPrefixIdx = beforeCursor.lastIndexOf(p);\n if (lastPrefixIdx < 0) continue;\n const afterPrefix = beforeCursor.slice(lastPrefixIdx + p.length);\n if (/\\s/.test(afterPrefix)) continue;\n if (\n lastPrefixIdx === 0 ||\n text[lastPrefixIdx - 1] === __props.split ||\n /\\s/.test(text[lastPrefixIdx - 1])\n ) {\n return { start: lastPrefixIdx, prefix: p };\n }\n }\n return null;\n}\n\nfunction startMeasure(text: string, cursorPos: number) {\n const measure = getLastMeasureIndex(text, cursorPos);\n if (measure) {\n measuring.value = true;\n measurePrefix.value = measure.prefix;\n measureStart.value = measure.start;\n measureText.value = text.slice(measure.start + measure.prefix.length, cursorPos);\n emit('search', measureText.value, measure.prefix);\n nextTick(() => openMenu());\n } else {\n stopMeasure();\n }\n}\n\nfunction stopMeasure() {\n closeMenu();\n measuring.value = false;\n measureText.value = '';\n measurePrefix.value = '';\n measureStart.value = 0;\n}\n\nfunction selectOption(opt: BMentionsOption) {\n if (opt.disabled) return;\n\n const textarea = textareaRef.value;\n if (!textarea) return;\n\n const value = model.value ?? '';\n const cursorPos = textarea.selectionStart;\n const beforeMention = value.slice(0, measureStart.value);\n const afterMention = value.slice(cursorPos);\n\n const mentionValue = `${measurePrefix.value}${opt.value}`;\n const needsTrailingSplit = afterMention && !afterMention.startsWith(__props.split) && __props.split;\n const newValue = `${beforeMention}${mentionValue}${needsTrailingSplit ? __props.split : ''}${afterMention}`;\n\n model.value = newValue;\n emit('change', newValue);\n emit('select', opt, measurePrefix.value);\n\n stopMeasure();\n\n const newCursorPos =\n beforeMention.length + mentionValue.length + (needsTrailingSplit ? __props.split.length : 0);\n nextTick(() => {\n textarea.focus();\n textarea.setSelectionRange(newCursorPos, newCursorPos);\n });\n}\n\nfunction handleInput(e: Event) {\n const target = e.target as HTMLTextAreaElement;\n const value = target.value;\n model.value = value;\n emit('change', value);\n\n const cursorPos = target.selectionStart;\n startMeasure(value, cursorPos);\n adjustHeight();\n}\n\nfunction handleFocus(e: FocusEvent) {\n isFocused.value = true;\n emit('focus', e);\n}\n\nfunction handleBlur(e: FocusEvent) {\n const related = e.relatedTarget as HTMLElement | null;\n if (menuRef.value?.contains(related)) return;\n isFocused.value = false;\n emit('blur', e);\n stopMeasure();\n}\n\nfunction handleKeyDown(e: KeyboardEvent) {\n if (!showDropdown.value) return;\n\n switch (e.key) {\n case 'ArrowDown': {\n e.preventDefault();\n const opts = filteredOptions.value;\n if (opts.length === 0) return;\n const next = activeIndex.value + 1;\n for (let i = 0; i < opts.length; i++) {\n const idx = (next + i) % opts.length;\n if (!opts[idx].disabled) {\n activeIndex.value = idx;\n break;\n }\n }\n break;\n }\n case 'ArrowUp': {\n e.preventDefault();\n const opts = filteredOptions.value;\n if (opts.length === 0) return;\n const prev = activeIndex.value - 1;\n for (let i = 0; i < opts.length; i++) {\n const idx = (((prev - i) % opts.length) + opts.length) % opts.length;\n if (!opts[idx].disabled) {\n activeIndex.value = idx;\n break;\n }\n }\n break;\n }\n case 'Enter': {\n e.preventDefault();\n if (activeIndex.value >= 0) {\n const opt = filteredOptions.value[activeIndex.value];\n if (opt && !opt.disabled) {\n selectOption(opt);\n }\n }\n break;\n }\n case 'Escape': {\n e.preventDefault();\n stopMeasure();\n break;\n }\n }\n}\n\nfunction handleClear() {\n model.value = '';\n emit('change', '');\n emit('clear');\n stopMeasure();\n textareaRef.value?.focus();\n}\n\nfunction handlePopupScroll(e: Event) {\n emit('popupScroll', e);\n}\n\nfunction adjustHeight() {\n if (!__props.autoSize || !textareaRef.value) return;\n const textarea = textareaRef.value;\n textarea.style.height = 'auto';\n\n const config = typeof __props.autoSize === 'object' ? __props.autoSize : {};\n const lineHeight = parseFloat(getComputedStyle(textarea).lineHeight) || 20;\n\n let newHeight = textarea.scrollHeight;\n if (config.minRows) {\n newHeight = Math.max(newHeight, config.minRows * lineHeight);\n }\n if (config.maxRows) {\n newHeight = Math.min(newHeight, config.maxRows * lineHeight);\n }\n\n textarea.style.height = `${newHeight}px`;\n emit('resize', { width: textarea.offsetWidth, height: newHeight });\n}\n\nconst scrollActiveIntoView = () => {\n nextTick(() => {\n const active = menuRef.value?.querySelector('[data-active=\"true\"]');\n active?.scrollIntoView({ block: 'nearest' });\n });\n};\n\nwatch(activeIndex, scrollActiveIntoView);\n\nwatch(model, (val) => {\n if (textareaRef.value && textareaRef.value.value !== val) {\n textareaRef.value.value = val ?? '';\n }\n});\n\n__expose({\n focus: () => textareaRef.value?.focus(),\n blur: () => textareaRef.value?.blur(),\n});\n\nreturn (_ctx: any,_cache: any) => {\n return (_openBlock(), _createElementBlock(\"div\", {\n class: _normalizeClass([\"b-mentions\", [\n `b-mentions--${__props.size}`,\n `b-mentions--${__props.variant}`,\n {\n 'b-mentions--focused': isFocused.value,\n 'b-mentions--disabled': __props.disabled,\n 'b-mentions--error': __props.status === _unref(BMentionsStatus).Error,\n 'b-mentions--warning': __props.status === _unref(BMentionsStatus).Warning,\n 'b-mentions--has-clear': __props.allowClear,\n },\n ]]),\n role: \"combobox\",\n \"aria-label\": __props.placeholder || 'Mentions input',\n \"aria-expanded\": showDropdown.value,\n \"aria-haspopup\": 'listbox',\n \"aria-controls\": showDropdown.value ? listboxId.value : undefined\n }, [\n _createElementVNode(\"textarea\", _mergeProps({\n ref_key: \"textareaRef\",\n ref: textareaRef\n }, _unref(attrs), {\n value: model.value,\n class: \"b-mentions__textarea\",\n placeholder: __props.placeholder,\n disabled: __props.disabled,\n readonly: __props.readOnly,\n rows: __props.autoSize ? undefined : __props.rows,\n \"aria-label\": __props.placeholder || 'Mentions input',\n autocomplete: \"off\",\n \"aria-activedescendant\": activeIndex.value >= 0 ? `${listboxId.value}-option-${activeIndex.value}` : undefined,\n \"aria-autocomplete\": \"list\",\n onInput: handleInput,\n onFocus: handleFocus,\n onBlur: handleBlur,\n onKeydown: handleKeyDown\n }), null, 16, _hoisted_2),\n (__props.allowClear && model.value && !__props.disabled)\n ? (_openBlock(), _createElementBlock(\"button\", {\n key: 0,\n type: \"button\",\n class: \"b-mentions__clear\",\n \"aria-label\": \"Clear input\",\n tabindex: \"-1\",\n onMousedown: _withModifiers(handleClear, [\"prevent\"])\n }, null, 32))\n : _createCommentVNode(\"\", true),\n (measuring.value || isOpen.value)\n ? (_openBlock(), _createElementBlock(\"div\", {\n key: 1,\n ref_key: \"menuRef\",\n ref: menuRef,\n id: listboxId.value,\n class: \"b-mentions__dropdown\",\n popover: \"manual\",\n role: \"listbox\",\n \"aria-label\": `Mention suggestions for ${measurePrefix.value}`,\n onToggle: handleToggle,\n onScroll: handlePopupScroll\n }, [\n (filteredOptions.value.length > 0)\n ? (_openBlock(), _createElementBlock(\"ul\", _hoisted_4, [\n (_openBlock(true), _createElementBlock(_Fragment, null, _renderList(filteredOptions.value, (opt, idx) => {\n return (_openBlock(), _createElementBlock(\"li\", {\n key: opt.value,\n id: `${listboxId.value}-option-${idx}`,\n class: _normalizeClass([\"b-mentions__option\", {\n 'b-mentions__option--active': idx === activeIndex.value && !opt.disabled,\n 'b-mentions__option--disabled': opt.disabled,\n }]),\n \"data-active\": idx === activeIndex.value,\n \"aria-selected\": idx === activeIndex.value,\n \"aria-disabled\": opt.disabled ?? false,\n role: \"option\",\n onMousedown: _withModifiers(($event: any) => (selectOption(opt)), [\"prevent\"]),\n onMouseenter: ($event: any) => (activeIndex.value = idx)\n }, [\n _renderSlot(_ctx.$slots, \"option\", {\n option: opt,\n index: idx\n }, () => [\n _createTextVNode(_toDisplayString(getOptionLabel(opt)), 1)\n ], true)\n ], 42, _hoisted_5))\n }), 128))\n ]))\n : (__props.notFoundContent)\n ? (_openBlock(), _createElementBlock(\"div\", _hoisted_6, [\n _renderSlot(_ctx.$slots, \"notFoundContent\", {}, () => [\n _createTextVNode(_toDisplayString(__props.notFoundContent), 1)\n ], true)\n ]))\n : _createCommentVNode(\"\", true)\n ], 40, _hoisted_3))\n : _createCommentVNode(\"\", true)\n ], 10, _hoisted_1))\n}\n}\n\n})"],"mappings":"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"}
|
package/dist/design-system118.js
DELETED
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import { createElementBlock as e, defineComponent as t, normalizeClass as n, openBlock as r } from "vue";
|
|
2
|
-
//#region src/components/BMenu/BMenuDivider.vue?vue&type=script&setup=true&lang.ts
|
|
3
|
-
var i = /* @__PURE__ */ t({
|
|
4
|
-
__name: "BMenuDivider",
|
|
5
|
-
props: { dashed: {
|
|
6
|
-
type: Boolean,
|
|
7
|
-
default: !1
|
|
8
|
-
} },
|
|
9
|
-
setup(t) {
|
|
10
|
-
return (i, a) => (r(), e("li", {
|
|
11
|
-
class: n(["b-menu-divider", { "b-menu-divider--dashed": t.dashed }]),
|
|
12
|
-
role: "separator"
|
|
13
|
-
}, null, 2));
|
|
14
|
-
}
|
|
15
|
-
});
|
|
16
|
-
//#endregion
|
|
17
|
-
export { i as default };
|
|
18
|
-
|
|
19
|
-
//# sourceMappingURL=design-system118.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"design-system118.js","names":[],"sources":["../src/components/BMenu/BMenuDivider.vue?vue&type=script&setup=true&lang.ts"],"sourcesContent":["import { defineComponent as _defineComponent } from 'vue'\nimport { normalizeClass as _normalizeClass, openBlock as _openBlock, createElementBlock as _createElementBlock } from \"vue\"\n\n\nexport default /*@__PURE__*/_defineComponent({\n __name: 'BMenuDivider',\n props: {\n dashed: { type: Boolean, default: false }\n },\n setup(__props: any) {\n\n// ─────────────────────────────────────────────\n// Props\n// ─────────────────────────────────────────────\n\n\nreturn (_ctx: any,_cache: any) => {\n return (_openBlock(), _createElementBlock(\"li\", {\n class: _normalizeClass(['b-menu-divider', { 'b-menu-divider--dashed': __props.dashed }]),\n role: \"separator\"\n }, null, 2))\n}\n}\n\n})"],"mappings":";;AAIA,IAAA,IAA4B,kBAAiB;CAC3C,QAAQ;CACR,OAAO,EACL,QAAQ;EAAE,MAAM;EAAS,SAAS;EAAO,EAC1C;CACD,MAAM,GAAc;AAOtB,UAAQ,GAAU,OACR,GAAY,EAAE,EAAoB,MAAM;GAC9C,OAAO,EAAgB,CAAC,kBAAkB,EAAE,0BAA0B,EAAQ,QAAQ,CAAC,CAAC;GACxF,MAAM;GACP,EAAE,MAAM,EAAE;;CAIZ,CAAA"}
|
package/dist/design-system121.js
DELETED
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
//#region src/components/BMenu/types.ts
|
|
2
|
-
var e = Symbol("BMenuContext"), t = Symbol("BMenuSubMenuContext");
|
|
3
|
-
function n(e) {
|
|
4
|
-
return "children" in e && ("type" in e ? e.type !== "group" : !0);
|
|
5
|
-
}
|
|
6
|
-
function r(e) {
|
|
7
|
-
return "type" in e && e.type === "group";
|
|
8
|
-
}
|
|
9
|
-
function i(e) {
|
|
10
|
-
return "type" in e && e.type === "divider";
|
|
11
|
-
}
|
|
12
|
-
//#endregion
|
|
13
|
-
export { e as BMenuContextKey, t as BMenuSubMenuContextKey, i as isDivider, r as isItemGroup, n as isSubMenu };
|
|
14
|
-
|
|
15
|
-
//# sourceMappingURL=design-system121.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"design-system121.js","names":[],"sources":["../src/components/BMenu/types.ts"],"sourcesContent":["import type { ComputedRef, InjectionKey } from 'vue';\n\n// ─────────────────────────────────────────────\n// Enums & Literals\n// ─────────────────────────────────────────────\nexport type BMenuMode = 'horizontal' | 'vertical' | 'inline';\nexport type BMenuTheme = 'light' | 'dark';\nexport type BMenuTriggerAction = 'hover' | 'click';\n\n// ─────────────────────────────────────────────\n// Item types (data-driven API)\n// ─────────────────────────────────────────────\nexport interface BMenuItemType {\n key: string;\n label?: string;\n icon?: string;\n disabled?: boolean;\n danger?: boolean;\n title?: string;\n extra?: string;\n}\n\nexport interface BMenuSubMenuType {\n key: string;\n label?: string;\n icon?: string;\n disabled?: boolean;\n children?: BMenuItemUnion[];\n popupClassName?: string;\n}\n\nexport interface BMenuItemGroupType {\n type: 'group';\n key?: string;\n label?: string;\n children?: BMenuItemType[];\n}\n\nexport interface BMenuDividerType {\n type: 'divider';\n key?: string;\n dashed?: boolean;\n}\n\nexport type BMenuItemUnion =\n | BMenuItemType\n | BMenuSubMenuType\n | BMenuItemGroupType\n | BMenuDividerType;\n\n// ─────────────────────────────────────────────\n// Event payloads\n// ─────────────────────────────────────────────\nexport interface BMenuClickInfo {\n key: string;\n keyPath: string[];\n domEvent: MouseEvent | KeyboardEvent;\n}\n\nexport interface BMenuSelectInfo {\n key: string;\n keyPath: string[];\n selectedKeys: string[];\n domEvent: MouseEvent | KeyboardEvent;\n}\n\n// ─────────────────────────────────────────────\n// Context (provided by BMenu to children)\n// ─────────────────────────────────────────────\nexport interface BMenuContext {\n mode: ComputedRef<BMenuMode>;\n theme: ComputedRef<BMenuTheme>;\n inlineCollapsed: ComputedRef<boolean>;\n inlineIndent: ComputedRef<number>;\n selectedKeys: ComputedRef<string[]>;\n openKeys: ComputedRef<string[]>;\n multiple: ComputedRef<boolean>;\n selectable: ComputedRef<boolean>;\n triggerSubMenuAction: ComputedRef<BMenuTriggerAction>;\n subMenuOpenDelay: ComputedRef<number>;\n subMenuCloseDelay: ComputedRef<number>;\n onItemClick: (info: BMenuClickInfo) => void;\n onOpenChange: (key: string, open: boolean) => void;\n registerKeyPath: (key: string, path: string[]) => void;\n}\n\nexport const BMenuContextKey: InjectionKey<BMenuContext> = Symbol('BMenuContext');\n\n// ─────────────────────────────────────────────\n// SubMenu context (nesting depth)\n// ─────────────────────────────────────────────\nexport interface BMenuSubMenuContext {\n level: number;\n keyPath: string[];\n}\n\nexport const BMenuSubMenuContextKey: InjectionKey<BMenuSubMenuContext> =\n Symbol('BMenuSubMenuContext');\n\n// ─────────────────────────────────────────────\n// Helpers\n// ─────────────────────────────────────────────\nexport function isSubMenu(item: BMenuItemUnion): item is BMenuSubMenuType {\n return 'children' in item && ('type' in item ? item.type !== 'group' : true);\n}\n\nexport function isItemGroup(item: BMenuItemUnion): item is BMenuItemGroupType {\n return 'type' in item && item.type === 'group';\n}\n\nexport function isDivider(item: BMenuItemUnion): item is BMenuDividerType {\n return 'type' in item && item.type === 'divider';\n}\n\nexport function isMenuItem(item: BMenuItemUnion): item is BMenuItemType {\n return !isSubMenu(item) && !isItemGroup(item) && !isDivider(item);\n}\n"],"mappings":";AAsFA,IAAa,IAA8C,OAAO,eAAe,EAUpE,IACX,OAAO,sBAAsB;AAK/B,SAAgB,EAAU,GAAgD;AACxE,QAAO,cAAc,MAAS,UAAU,IAAO,EAAK,SAAS,UAAU;;AAGzE,SAAgB,EAAY,GAAkD;AAC5E,QAAO,UAAU,KAAQ,EAAK,SAAS;;AAGzC,SAAgB,EAAU,GAAgD;AACxE,QAAO,UAAU,KAAQ,EAAK,SAAS"}
|
package/dist/design-system125.js
DELETED
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
import { BMenuContextKey as e } from "./design-system121.js";
|
|
2
|
-
import t from "./design-system124.js";
|
|
3
|
-
import { Fragment as n, createBlock as r, createCommentVNode as i, createElementBlock as a, createElementVNode as o, createTextVNode as s, defineComponent as c, inject as l, openBlock as u, renderList as d, renderSlot as f, toDisplayString as p, unref as m } from "vue";
|
|
4
|
-
//#region src/components/BMenu/BMenuItemGroup.vue?vue&type=script&setup=true&lang.ts
|
|
5
|
-
var h = {
|
|
6
|
-
class: "b-menu-item-group",
|
|
7
|
-
role: "presentation"
|
|
8
|
-
}, g = {
|
|
9
|
-
key: 0,
|
|
10
|
-
class: "b-menu-item-group__title",
|
|
11
|
-
role: "presentation"
|
|
12
|
-
}, _ = ["aria-label"], v = /* @__PURE__ */ c({
|
|
13
|
-
__name: "BMenuItemGroup",
|
|
14
|
-
props: {
|
|
15
|
-
label: { default: "" },
|
|
16
|
-
children: { default: () => [] }
|
|
17
|
-
},
|
|
18
|
-
setup(c) {
|
|
19
|
-
let v = c, y = l(e);
|
|
20
|
-
return (e, c) => (u(), a("li", h, [m(y).inlineCollapsed.value ? i("", !0) : (u(), a("div", g, [f(e.$slots, "title", {}, () => [s(p(v.label), 1)])])), o("ul", {
|
|
21
|
-
class: "b-menu-item-group__list",
|
|
22
|
-
role: "group",
|
|
23
|
-
"aria-label": v.label
|
|
24
|
-
}, [f(e.$slots, "default", {}, () => [(u(!0), a(n, null, d(v.children, (e) => (u(), r(t, {
|
|
25
|
-
key: e.key,
|
|
26
|
-
"item-key": e.key,
|
|
27
|
-
label: e.label,
|
|
28
|
-
icon: e.icon,
|
|
29
|
-
disabled: e.disabled,
|
|
30
|
-
danger: e.danger,
|
|
31
|
-
extra: e.extra
|
|
32
|
-
}, null, 8, [
|
|
33
|
-
"item-key",
|
|
34
|
-
"label",
|
|
35
|
-
"icon",
|
|
36
|
-
"disabled",
|
|
37
|
-
"danger",
|
|
38
|
-
"extra"
|
|
39
|
-
]))), 128))])], 8, _)]));
|
|
40
|
-
}
|
|
41
|
-
});
|
|
42
|
-
//#endregion
|
|
43
|
-
export { v as default };
|
|
44
|
-
|
|
45
|
-
//# sourceMappingURL=design-system125.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"design-system125.js","names":[],"sources":["../src/components/BMenu/BMenuItemGroup.vue?vue&type=script&setup=true&lang.ts"],"sourcesContent":["import { defineComponent as _defineComponent } from 'vue'\nimport { unref as _unref, renderSlot as _renderSlot, toDisplayString as _toDisplayString, createTextVNode as _createTextVNode, openBlock as _openBlock, createElementBlock as _createElementBlock, createCommentVNode as _createCommentVNode, renderList as _renderList, Fragment as _Fragment, createBlock as _createBlock, createElementVNode as _createElementVNode } from \"vue\"\n\nconst _hoisted_1 = {\n class: \"b-menu-item-group\",\n role: \"presentation\"\n}\nconst _hoisted_2 = {\n key: 0,\n class: \"b-menu-item-group__title\",\n role: \"presentation\"\n}\nconst _hoisted_3 = [\"aria-label\"]\n\nimport { inject } from 'vue';\nimport BMenuItem from './BMenuItem.vue';\nimport { BMenuContextKey, type BMenuContext, type BMenuItemType } from './types';\n\n// ─────────────────────────────────────────────\n// Props\n// ─────────────────────────────────────────────\n\nexport default /*@__PURE__*/_defineComponent({\n __name: 'BMenuItemGroup',\n props: {\n label: { default: '' },\n children: { default: () => [] }\n },\n setup(__props: any) {\n\nconst props = __props;\n\n\n\nconst menu = inject<BMenuContext>(BMenuContextKey)!;\n\nreturn (_ctx: any,_cache: any) => {\n return (_openBlock(), _createElementBlock(\"li\", _hoisted_1, [\n (!_unref(menu).inlineCollapsed.value)\n ? (_openBlock(), _createElementBlock(\"div\", _hoisted_2, [\n _renderSlot(_ctx.$slots, \"title\", {}, () => [\n _createTextVNode(_toDisplayString(props.label), 1)\n ])\n ]))\n : _createCommentVNode(\"\", true),\n _createElementVNode(\"ul\", {\n class: \"b-menu-item-group__list\",\n role: \"group\",\n \"aria-label\": props.label\n }, [\n _renderSlot(_ctx.$slots, \"default\", {}, () => [\n (_openBlock(true), _createElementBlock(_Fragment, null, _renderList(props.children, (item) => {\n return (_openBlock(), _createBlock(BMenuItem, {\n key: item.key,\n \"item-key\": item.key,\n label: item.label,\n icon: item.icon,\n disabled: item.disabled,\n danger: item.danger,\n extra: item.extra\n }, null, 8, [\"item-key\", \"label\", \"icon\", \"disabled\", \"danger\", \"extra\"]))\n }), 128))\n ])\n ], 8, _hoisted_3)\n ]))\n}\n}\n\n})"],"mappings":";;;;AAGA,IAAM,IAAa;CACjB,OAAO;CACP,MAAM;CACP,EACK,IAAa;CACjB,KAAK;CACL,OAAO;CACP,MAAM;CACP,EACK,IAAa,CAAC,aAAa,EAUjC,IAA4B,kBAAiB;CAC3C,QAAQ;CACR,OAAO;EACL,OAAO,EAAE,SAAS,IAAI;EACtB,UAAU,EAAE,eAAe,EAAE,EAAE;EAChC;CACD,MAAM,GAAc;EAEtB,IAAM,IAAQ,GAIR,IAAO,EAAqB,EAAgB;AAElD,UAAQ,GAAU,OACR,GAAY,EAAE,EAAoB,MAAM,GAAY,CACxD,EAAO,EAAK,CAAC,gBAAgB,QAM3B,EAAoB,IAAI,GAAK,IAL5B,GAAY,EAAE,EAAoB,OAAO,GAAY,CACpD,EAAY,EAAK,QAAQ,SAAS,EAAE,QAAQ,CAC1C,EAAiB,EAAiB,EAAM,MAAM,EAAE,EAAE,CACnD,CAAC,CACH,CAAC,GAEN,EAAoB,MAAM;GACxB,OAAO;GACP,MAAM;GACN,cAAc,EAAM;GACrB,EAAE,CACD,EAAY,EAAK,QAAQ,WAAW,EAAE,QAAQ,EAC3C,EAAW,GAAK,EAAE,EAAoB,GAAW,MAAM,EAAY,EAAM,WAAW,OAC3E,GAAY,EAAE,EAAa,GAAW;GAC5C,KAAK,EAAK;GACV,YAAY,EAAK;GACjB,OAAO,EAAK;GACZ,MAAM,EAAK;GACX,UAAU,EAAK;GACf,QAAQ,EAAK;GACb,OAAO,EAAK;GACb,EAAE,MAAM,GAAG;GAAC;GAAY;GAAS;GAAQ;GAAY;GAAU;GAAQ,CAAC,EACzE,EAAE,IAAI,EACT,CAAC,CACH,EAAE,GAAG,EAAW,CAClB,CAAC;;CAIH,CAAA"}
|