@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
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"design-system151.js","names":["$slots"],"sources":["../src/components/BNotification/BNotification.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { BNotificationPlacement, BNotificationType } from '@/types.ts';\nimport { computed, nextTick, onUnmounted, ref, useId, watch } from 'vue';\n\n// ─────────────────────────────────────────────\n// Props & emits\n// ─────────────────────────────────────────────\nconst {\n type = undefined,\n message = '',\n description = '',\n placement = BNotificationPlacement.TopRight,\n duration = 4.5,\n closable = true,\n showIcon = true,\n icon,\n closeIcon,\n btn,\n modelValue = undefined,\n} = defineProps<{\n /**\n * Notification type - controls the icon and colour scheme.\n * When omitted no type-colour is applied (plain notification).\n */\n type?: `${BNotificationType}`;\n /** Short title / heading of the notification. */\n message?: string;\n /** Optional detailed description below the title. */\n description?: string;\n /**\n * Placement of the notification on the viewport.\n * @default 'top-right'\n */\n placement?: `${BNotificationPlacement}`;\n /**\n * Auto-close delay in seconds. Set to `0` to disable auto-close.\n * @default 4.5\n */\n duration?: number;\n /** Show the close button. @default true */\n closable?: boolean;\n /** Show the built-in status icon when `type` is set. @default true */\n showIcon?: boolean;\n /**\n * Custom icon content - overrides the built-in type icon.\n * Also accepts the `icon` slot.\n */\n icon?: string;\n /**\n * Custom close-icon content.\n * Also accepts the `closeIcon` slot.\n */\n closeIcon?: string;\n /**\n * Custom action button area content.\n * Also accepts the `btn` slot.\n */\n btn?: string;\n /**\n * Controlled visibility - when provided the component operates in\n * controlled mode; otherwise it manages its own visibility.\n * Bind with `v-model`.\n */\n modelValue?: boolean;\n}>();\n\nconst emit = defineEmits<{\n /** Fired synchronously when the notification starts closing. */\n (e: 'close'): void;\n /** Fired after the leave-transition fully completes. */\n (e: 'afterClose'): void;\n /** v-model support */\n (e: 'update:modelValue', value: boolean): void;\n}>();\n\ndefineSlots<{\n /** Overrides the `message` prop - the notification title. */\n message?(): unknown;\n /** Overrides the `description` prop. */\n description?(): unknown;\n /** Overrides the built-in status icon. */\n icon?(): unknown;\n /** Overrides the default close icon. */\n closeIcon?(): unknown;\n /** Action button area rendered below the description. */\n btn?(): unknown;\n}>();\n\n// ─────────────────────────────────────────────\n// Internal state\n// ─────────────────────────────────────────────\nconst notificationId = useId();\nconst titleId = `${notificationId}-title`;\nconst descId = `${notificationId}-desc`;\n\n/** Uncontrolled visibility flag - default closed. */\nconst internalVisible = ref(false);\n\n/** Ref to the notification DOM element for focus return. */\nconst notificationRef = ref<HTMLElement | null>(null);\n\n/** Element that had focus before the notification appeared. */\nconst previousFocusRef = ref<HTMLElement | null>(null);\n\n/**\n * Effective visibility:\n * - controlled → honour `modelValue`\n * - uncontrolled → use `internalVisible`\n */\nconst isVisible = computed(() => (modelValue !== undefined ? modelValue : internalVisible.value));\n\nconst isControlled = computed(() => modelValue !== undefined);\n\n// ─────────────────────────────────────────────\n// Derived state\n// ─────────────────────────────────────────────\n/** ARIA role: 'alert' for error/warning (assertive), 'status' for others. */\nconst ariaRole = computed<'alert' | 'status'>(() =>\n type === BNotificationType.Error || type === BNotificationType.Warning ? 'alert' : 'status',\n);\n\n/** aria-live polarity mirrors the role. */\nconst ariaLive = computed(() => (ariaRole.value === 'alert' ? 'assertive' : 'polite'));\n\n/** Whether to show the icon area (needs type and showIcon). */\nconst showIconArea = computed(() => Boolean(type && showIcon) || Boolean(icon) || false);\n\n/** Whether the description is provided via prop or slot. */\nconst hasDescription = computed(() => Boolean(description));\n\n/** Built-in SVG path for the status icon. */\nconst iconPath = computed(() => {\n switch (type) {\n case BNotificationType.Success:\n return 'M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm-2 14.5-4-4 1.41-1.41L10 13.67l6.59-6.59L18 8.5l-8 8z';\n case BNotificationType.Warning:\n return 'M1 21h22L12 2 1 21zm12-3h-2v-2h2v2zm0-4h-2v-4h2v4z';\n case BNotificationType.Error:\n return 'M12 2C6.47 2 2 6.47 2 12s4.47 10 10 10 10-4.47 10-10S17.53 2 12 2zm5 13.59L15.59 17 12 13.41 8.41 17 7 15.59 10.59 12 7 8.41 8.41 7 12 10.59 15.59 7 17 8.41 13.41 12 17 15.59z';\n default:\n // info (also fallback)\n return 'M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 15h-2v-6h2v6zm0-8h-2V7h2v2z';\n }\n});\n\n// Close icon SVG path (× mark)\nconst closeIconPath =\n 'M19 6.41L17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z';\n\n// ─────────────────────────────────────────────\n// Auto-close timer\n// ─────────────────────────────────────────────\nlet timer: ReturnType<typeof setTimeout> | null = null;\n\nfunction startTimer() {\n clearTimer();\n if (duration > 0) {\n timer = setTimeout(() => {\n close();\n }, duration * 1000);\n }\n}\n\nfunction clearTimer() {\n if (timer !== null) {\n clearTimeout(timer);\n timer = null;\n }\n}\n\n// ─────────────────────────────────────────────\n// Behaviour\n// ─────────────────────────────────────────────\nfunction open() {\n if (isControlled.value) {\n emit('update:modelValue', true);\n } else {\n internalVisible.value = true;\n }\n}\n\nfunction close() {\n emit('close');\n if (isControlled.value) {\n emit('update:modelValue', false);\n } else {\n internalVisible.value = false;\n }\n}\n\nfunction onAfterLeave() {\n // Return focus to the previously-focused element\n if (previousFocusRef.value && document.contains(previousFocusRef.value)) {\n previousFocusRef.value.focus();\n previousFocusRef.value = null;\n }\n emit('afterClose');\n}\n\nfunction onMouseEnter() {\n clearTimer();\n}\n\nfunction onMouseLeave() {\n startTimer();\n}\n\nfunction onKeydown(event: KeyboardEvent) {\n if (event.key === 'Escape' && closable) {\n event.stopPropagation();\n close();\n }\n}\n\n// ─────────────────────────────────────────────\n// Visibility watcher - manage timer + focus\n// ─────────────────────────────────────────────\nwatch(\n isVisible,\n async (visible) => {\n if (visible) {\n // Capture current focus for return-on-close\n previousFocusRef.value = document.activeElement as HTMLElement | null;\n startTimer();\n // Focus the close button (if closable) once the DOM updates\n if (closable) {\n await nextTick();\n const closeBtn =\n notificationRef.value?.querySelector<HTMLElement>('.b-notification__close');\n closeBtn?.focus();\n }\n } else {\n clearTimer();\n }\n },\n { immediate: true },\n);\n\n// ─────────────────────────────────────────────\n// Lifecycle\n// ─────────────────────────────────────────────\nonUnmounted(() => {\n clearTimer();\n});\n\n// Expose open & close for imperative usage\ndefineExpose({ open, close });\n</script>\n\n<template>\n <Teleport to=\"body\">\n <Transition name=\"b-notification-fade\" @after-leave=\"onAfterLeave\">\n <div\n v-if=\"isVisible\"\n :id=\"notificationId\"\n ref=\"notificationRef\"\n class=\"b-notification\"\n :class=\"[\n placement && `b-notification--${placement}`,\n type && `b-notification--${type}`,\n {\n 'b-notification--with-icon': showIconArea,\n 'b-notification--with-description': hasDescription,\n },\n ]\"\n :role=\"ariaRole\"\n :aria-live=\"ariaLive\"\n :aria-atomic=\"true\"\n :aria-labelledby=\"titleId\"\n :aria-describedby=\"hasDescription ? descId : undefined\"\n @mouseenter=\"onMouseEnter\"\n @mouseleave=\"onMouseLeave\"\n @keydown=\"onKeydown\"\n >\n <!-- Icon area -->\n <span v-if=\"showIconArea\" class=\"b-notification__icon\" aria-hidden=\"true\">\n <slot name=\"icon\">\n <!-- Custom icon prop as raw HTML (consumer's responsibility) -->\n <span v-if=\"icon\" v-html=\"icon\" />\n <!-- Built-in type icon -->\n <svg\n v-else-if=\"type\"\n class=\"b-notification__icon-svg\"\n viewBox=\"0 0 24 24\"\n xmlns=\"http://www.w3.org/2000/svg\"\n focusable=\"false\"\n aria-hidden=\"true\"\n >\n <path :d=\"iconPath\" />\n </svg>\n </slot>\n </span>\n\n <!-- Body -->\n <div class=\"b-notification__body\">\n <!-- Title -->\n <div :id=\"titleId\" class=\"b-notification__message\">\n <slot name=\"message\">{{ message }}</slot>\n </div>\n\n <!-- Description -->\n <div\n v-if=\"hasDescription || $slots.description\"\n :id=\"descId\"\n class=\"b-notification__description\"\n >\n <slot name=\"description\">{{ description }}</slot>\n </div>\n\n <!-- Action button area -->\n <div v-if=\"btn || $slots.btn\" class=\"b-notification__btn\">\n <slot name=\"btn\">{{ btn }}</slot>\n </div>\n </div>\n\n <!-- Close button -->\n <button\n v-if=\"closable\"\n type=\"button\"\n class=\"b-notification__close\"\n aria-label=\"Close notification\"\n @click=\"close\"\n >\n <slot name=\"closeIcon\">\n <span v-if=\"closeIcon\" v-html=\"closeIcon\" />\n <svg\n v-else\n class=\"b-notification__close-svg\"\n viewBox=\"0 0 24 24\"\n xmlns=\"http://www.w3.org/2000/svg\"\n focusable=\"false\"\n aria-hidden=\"true\"\n >\n <path :d=\"closeIconPath\" />\n </svg>\n </slot>\n </button>\n </div>\n </Transition>\n </Teleport>\n</template>\n\n<style>\n/* ────────────────────────────────────────────\n CSS Custom Properties (tokens)\n ──────────────────────────────────────────── */\n.b-notification {\n /* Layout */\n --b-notification-width: 22rem;\n --b-notification-padding-v: 1rem;\n --b-notification-padding-h: 1.5rem;\n --b-notification-border-radius: 0.5rem;\n --b-notification-icon-size: 1.5rem;\n --b-notification-gap: 0.75rem;\n --b-notification-close-size: 1rem;\n --b-notification-font-size-title: 1rem;\n --b-notification-font-size-desc: 0.875rem;\n --b-notification-line-height: 1.5;\n --b-notification-z-index: 1010;\n\n /* Offset from viewport edge */\n --b-notification-offset: 1.5rem;\n\n /* Colours (default / plain) */\n --b-notification-bg: #ffffff;\n --b-notification-border-color: oklch(90% 0.02 240);\n --b-notification-title-color: oklch(20% 0.02 240);\n --b-notification-desc-color: oklch(45% 0.02 240);\n --b-notification-close-color: oklch(50% 0.02 240);\n --b-notification-close-hover-color: oklch(20% 0.02 240);\n --b-notification-icon-color: oklch(62.3% 0.214 259.815);\n --b-notification-shadow:\n 0 6px 16px 0 rgba(0, 0, 0, 0.08), 0 3px 6px -4px rgba(0, 0, 0, 0.12),\n 0 9px 28px 8px rgba(0, 0, 0, 0.05);\n\n /* Animation */\n --b-notification-transition-duration: 300ms;\n}\n\n/* ── Variant colour tokens ── */\n.b-notification--success {\n --b-notification-icon-color: oklch(72.3% 0.219 149.579);\n}\n\n.b-notification--info {\n --b-notification-icon-color: oklch(62.3% 0.214 259.815);\n}\n\n.b-notification--warning {\n --b-notification-icon-color: oklch(75% 0.183 55.934);\n}\n\n.b-notification--error {\n --b-notification-icon-color: oklch(63.7% 0.237 25.331);\n}\n\n/* ── Dark mode ── */\n[data-prefers-color='dark'] .b-notification {\n --b-notification-bg: oklch(22% 0.02 240);\n --b-notification-border-color: oklch(35% 0.03 240);\n --b-notification-title-color: oklch(92% 0.02 240);\n --b-notification-desc-color: oklch(70% 0.02 240);\n --b-notification-close-color: oklch(60% 0.02 240);\n --b-notification-close-hover-color: oklch(90% 0.02 240);\n --b-notification-shadow:\n 0 6px 16px 0 rgba(0, 0, 0, 0.32), 0 3px 6px -4px rgba(0, 0, 0, 0.48),\n 0 9px 28px 8px rgba(0, 0, 0, 0.2);\n}\n\n@media (prefers-color-scheme: dark) {\n [data-prefers-color='system'] .b-notification {\n --b-notification-bg: oklch(22% 0.02 240);\n --b-notification-border-color: oklch(35% 0.03 240);\n --b-notification-title-color: oklch(92% 0.02 240);\n --b-notification-desc-color: oklch(70% 0.02 240);\n --b-notification-close-color: oklch(60% 0.02 240);\n --b-notification-close-hover-color: oklch(90% 0.02 240);\n --b-notification-shadow:\n 0 6px 16px 0 rgba(0, 0, 0, 0.32), 0 3px 6px -4px rgba(0, 0, 0, 0.48),\n 0 9px 28px 8px rgba(0, 0, 0, 0.2);\n }\n}\n\n/* ─────────────────────────────────────────────\n Base layout\n ───────────────────────────────────────────── */\n.b-notification {\n position: fixed;\n z-index: var(--b-notification-z-index);\n display: flex;\n align-items: flex-start;\n gap: var(--b-notification-gap);\n width: var(--b-notification-width);\n max-width: calc(100vw - 2 * var(--b-notification-offset));\n padding: var(--b-notification-padding-v) var(--b-notification-padding-h);\n border-radius: var(--b-notification-border-radius);\n background-color: var(--b-notification-bg);\n box-shadow: var(--b-notification-shadow);\n box-sizing: border-box;\n word-break: break-word;\n pointer-events: auto;\n outline: none;\n}\n\n/* ── Placement ── */\n.b-notification--top-right {\n top: var(--b-notification-offset);\n right: var(--b-notification-offset);\n}\n\n.b-notification--top-left {\n top: var(--b-notification-offset);\n left: var(--b-notification-offset);\n}\n\n.b-notification--bottom-right {\n bottom: var(--b-notification-offset);\n right: var(--b-notification-offset);\n}\n\n.b-notification--bottom-left {\n bottom: var(--b-notification-offset);\n left: var(--b-notification-offset);\n}\n\n/* ── Icon area ── */\n.b-notification__icon {\n display: inline-flex;\n flex-shrink: 0;\n align-items: flex-start;\n padding-top: 0.125rem;\n color: var(--b-notification-icon-color);\n line-height: 1;\n}\n\n.b-notification__icon-svg {\n width: var(--b-notification-icon-size);\n height: var(--b-notification-icon-size);\n fill: currentColor;\n display: block;\n}\n\n/* ── Body ── */\n.b-notification__body {\n flex: 1;\n min-width: 0;\n}\n\n/* ── Title ── */\n.b-notification__message {\n font-size: var(--b-notification-font-size-title);\n font-weight: 600;\n line-height: var(--b-notification-line-height);\n color: var(--b-notification-title-color);\n padding-right: 1.5rem; /* space for close button */\n}\n\n/* When no close button, remove the padding */\n.b-notification:not(:has(.b-notification__close)) .b-notification__message {\n padding-right: 0;\n}\n\n/* ── Description ── */\n.b-notification__description {\n margin-top: 0.375rem;\n font-size: var(--b-notification-font-size-desc);\n line-height: var(--b-notification-line-height);\n color: var(--b-notification-desc-color);\n}\n\n/* ── Action button area ── */\n.b-notification__btn {\n margin-top: 0.75rem;\n}\n\n/* ── Close button ── */\n.b-notification__close {\n position: absolute;\n top: 0.875rem;\n right: 1rem;\n display: inline-flex;\n align-items: center;\n justify-content: center;\n padding: 0.125rem;\n background: transparent;\n border: none;\n border-radius: 0.25rem;\n cursor: pointer;\n color: var(--b-notification-close-color);\n line-height: 1;\n transition: color var(--b-notification-transition-duration) ease;\n}\n\n.b-notification__close:hover {\n color: var(--b-notification-close-hover-color);\n}\n\n.b-notification__close:focus-visible {\n outline: 2px solid oklch(62.3% 0.214 259.815);\n outline-offset: 2px;\n}\n\n.b-notification__close-svg {\n width: var(--b-notification-close-size);\n height: var(--b-notification-close-size);\n fill: currentColor;\n display: block;\n}\n\n/* ─────────────────────────────────────────────\n Transition – slide-in + fade per placement\n ───────────────────────────────────────────── */\n.b-notification-fade-enter-active,\n.b-notification-fade-leave-active {\n transition:\n opacity var(--b-notification-transition-duration, 300ms) ease,\n transform var(--b-notification-transition-duration, 300ms) ease;\n}\n\n/* top-right / bottom-right - slide in from right */\n.b-notification--top-right.b-notification-fade-enter-from,\n.b-notification--bottom-right.b-notification-fade-enter-from {\n opacity: 0;\n transform: translateX(100%);\n}\n\n.b-notification--top-right.b-notification-fade-enter-to,\n.b-notification--bottom-right.b-notification-fade-enter-to,\n.b-notification--top-right.b-notification-fade-leave-from,\n.b-notification--bottom-right.b-notification-fade-leave-from {\n opacity: 1;\n transform: translateX(0);\n}\n\n.b-notification--top-right.b-notification-fade-leave-to,\n.b-notification--bottom-right.b-notification-fade-leave-to {\n opacity: 0;\n transform: translateX(100%);\n}\n\n/* top-left / bottom-left - slide in from left */\n.b-notification--top-left.b-notification-fade-enter-from,\n.b-notification--bottom-left.b-notification-fade-enter-from {\n opacity: 0;\n transform: translateX(-100%);\n}\n\n.b-notification--top-left.b-notification-fade-enter-to,\n.b-notification--bottom-left.b-notification-fade-enter-to,\n.b-notification--top-left.b-notification-fade-leave-from,\n.b-notification--bottom-left.b-notification-fade-leave-from {\n opacity: 1;\n transform: translateX(0);\n}\n\n.b-notification--top-left.b-notification-fade-leave-to,\n.b-notification--bottom-left.b-notification-fade-leave-to {\n opacity: 0;\n transform: translateX(-100%);\n}\n\n/* Respect prefers-reduced-motion */\n@media (prefers-reduced-motion: reduce) {\n .b-notification-fade-enter-active,\n .b-notification-fade-leave-active {\n transition: opacity var(--b-notification-transition-duration, 300ms) ease;\n }\n\n .b-notification--top-right.b-notification-fade-enter-from,\n .b-notification--bottom-right.b-notification-fade-enter-from,\n .b-notification--top-left.b-notification-fade-enter-from,\n .b-notification--bottom-left.b-notification-fade-enter-from,\n .b-notification--top-right.b-notification-fade-leave-to,\n .b-notification--bottom-right.b-notification-fade-leave-to,\n .b-notification--top-left.b-notification-fade-leave-to,\n .b-notification--bottom-left.b-notification-fade-leave-to {\n transform: none;\n }\n}\n</style>\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"design-system151.js","names":[],"sources":["../src/components/BMenu/BMenuSubMenu.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { computed, inject, onBeforeUnmount, provide, ref } from 'vue';\nimport BMenuDivider from './BMenuDivider.vue';\nimport BMenuItem from './BMenuItem.vue';\nimport BMenuItemGroup from './BMenuItemGroup.vue';\nimport {\n BMenuContextKey,\n BMenuSubMenuContextKey,\n isDivider,\n isItemGroup,\n isSubMenu,\n type BMenuContext,\n type BMenuItemUnion,\n type BMenuSubMenuContext,\n} from './types';\n\n// ─────────────────────────────────────────────\n// Props\n// ─────────────────────────────────────────────\nconst props = withDefaults(\n defineProps<{\n /** Unique key identifying this submenu. */\n itemKey: string;\n /** Display label of the submenu title. */\n label?: string;\n /** Icon name rendered before the label. */\n icon?: string;\n /** Whether the submenu is disabled. @default false */\n disabled?: boolean;\n /** Child menu items. */\n children?: BMenuItemUnion[];\n /** Extra class for popup container. */\n popupClassName?: string;\n }>(),\n {\n label: '',\n icon: undefined,\n disabled: false,\n children: () => [],\n popupClassName: '',\n },\n);\n\ndefineSlots<{\n default?(): unknown;\n icon?(): unknown;\n title?(): unknown;\n}>();\n\n// ─────────────────────────────────────────────\n// Inject context\n// ─────────────────────────────────────────────\nconst menu = inject<BMenuContext>(BMenuContextKey)!;\nconst parentSubMenu = inject<BMenuSubMenuContext | null>(BMenuSubMenuContextKey, null);\n\nconst level = computed(() => (parentSubMenu?.level ?? 0) + 1);\nconst keyPath = computed(() => [...(parentSubMenu?.keyPath ?? []), props.itemKey]);\n\n// Provide context for children\nprovide<BMenuSubMenuContext>(BMenuSubMenuContextKey, {\n level: level.value,\n keyPath: keyPath.value,\n});\n\n// ─────────────────────────────────────────────\n// Open state\n// ─────────────────────────────────────────────\nconst isOpen = computed(() => menu.openKeys.value.includes(props.itemKey));\n\nconst hasSelectedChild = computed(() => {\n function checkChildren(items: BMenuItemUnion[]): boolean {\n for (const item of items) {\n if ('key' in item && menu.selectedKeys.value.includes(item.key!)) return true;\n if (isSubMenu(item) && item.children) {\n if (checkChildren(item.children)) return true;\n }\n if (isItemGroup(item) && item.children) {\n if (checkChildren(item.children)) return true;\n }\n }\n return false;\n }\n return checkChildren(props.children);\n});\n\n// ─────────────────────────────────────────────\n// Inline indentation\n// ─────────────────────────────────────────────\nconst paddingLeft = computed(() => {\n if (menu.mode.value !== 'inline') return undefined;\n if (menu.inlineCollapsed.value) return undefined;\n return `${level.value * menu.inlineIndent.value}px`;\n});\n\n// ─────────────────────────────────────────────\n// Popup positioning (vertical / horizontal)\n// ─────────────────────────────────────────────\nconst isPopupMode = computed(() => menu.mode.value !== 'inline' || menu.inlineCollapsed.value);\n\nconst titleRef = ref<HTMLElement | null>(null);\nconst popupRef = ref<HTMLElement | null>(null);\n\nlet openTimer: ReturnType<typeof setTimeout> | null = null;\nlet closeTimer: ReturnType<typeof setTimeout> | null = null;\n\nfunction clearTimers() {\n if (openTimer) {\n clearTimeout(openTimer);\n openTimer = null;\n }\n if (closeTimer) {\n clearTimeout(closeTimer);\n closeTimer = null;\n }\n}\n\n// ─────────────────────────────────────────────\n// Handlers\n// ─────────────────────────────────────────────\nfunction toggleOpen() {\n if (props.disabled) return;\n menu.onOpenChange(props.itemKey, !isOpen.value);\n}\n\nfunction handleTitleClick() {\n if (props.disabled) return;\n if (!isPopupMode.value) {\n toggleOpen();\n } else if (menu.triggerSubMenuAction.value === 'click') {\n toggleOpen();\n }\n}\n\nfunction handleTitleKeydown(e: KeyboardEvent) {\n if (props.disabled) return;\n\n switch (e.key) {\n case 'Enter':\n case ' ':\n e.preventDefault();\n toggleOpen();\n break;\n case 'ArrowRight':\n if (menu.mode.value !== 'inline' && !isOpen.value) {\n e.preventDefault();\n menu.onOpenChange(props.itemKey, true);\n }\n break;\n case 'ArrowLeft':\n if (menu.mode.value !== 'inline' && isOpen.value) {\n e.preventDefault();\n menu.onOpenChange(props.itemKey, false);\n }\n break;\n case 'Escape':\n if (isOpen.value) {\n e.preventDefault();\n menu.onOpenChange(props.itemKey, false);\n titleRef.value?.focus();\n }\n break;\n }\n}\n\nfunction handleMouseEnter() {\n if (props.disabled || !isPopupMode.value) return;\n if (menu.triggerSubMenuAction.value !== 'hover') return;\n\n clearTimers();\n const delay = menu.subMenuOpenDelay.value;\n if (delay > 0) {\n openTimer = setTimeout(() => menu.onOpenChange(props.itemKey, true), delay);\n } else {\n menu.onOpenChange(props.itemKey, true);\n }\n}\n\nfunction handleMouseLeave() {\n if (props.disabled || !isPopupMode.value) return;\n if (menu.triggerSubMenuAction.value !== 'hover') return;\n\n clearTimers();\n const delay = menu.subMenuCloseDelay.value;\n if (delay > 0) {\n closeTimer = setTimeout(() => menu.onOpenChange(props.itemKey, false), delay);\n } else {\n menu.onOpenChange(props.itemKey, false);\n }\n}\n\nonBeforeUnmount(() => {\n clearTimers();\n});\n\n// ─────────────────────────────────────────────\n// Classes\n// ─────────────────────────────────────────────\nconst titleClasses = computed(() => [\n 'b-menu-submenu__title',\n {\n 'b-menu-submenu__title--open': isOpen.value,\n 'b-menu-submenu__title--disabled': props.disabled,\n 'b-menu-submenu__title--selected': hasSelectedChild.value,\n 'b-menu-submenu__title--horizontal': menu.mode.value === 'horizontal',\n },\n]);\n\nconst submenuClasses = computed(() => [\n 'b-menu-submenu',\n {\n 'b-menu-submenu--open': isOpen.value,\n 'b-menu-submenu--disabled': props.disabled,\n 'b-menu-submenu--horizontal': menu.mode.value === 'horizontal',\n 'b-menu-submenu--collapsed': menu.inlineCollapsed.value,\n 'b-menu-submenu--popup': isPopupMode.value,\n },\n]);\n\nconst popupClasses = computed(() => [\n 'b-menu-submenu__popup',\n props.popupClassName,\n {\n 'b-menu-submenu__popup--visible': isOpen.value,\n 'b-menu-submenu__popup--horizontal': menu.mode.value === 'horizontal',\n 'b-menu-submenu__popup--vertical': menu.mode.value === 'vertical' || menu.inlineCollapsed.value,\n },\n]);\n\nconst inlineContentClasses = computed(() => [\n 'b-menu-submenu__inline',\n {\n 'b-menu-submenu__inline--open': isOpen.value,\n },\n]);\n</script>\n\n<template>\n <li\n :class=\"submenuClasses\"\n :data-menu-key=\"props.itemKey\"\n role=\"none\"\n @mouseenter=\"handleMouseEnter\"\n @mouseleave=\"handleMouseLeave\"\n >\n <!-- Title -->\n <div\n ref=\"titleRef\"\n :class=\"titleClasses\"\n :style=\"{ paddingInlineStart: paddingLeft }\"\n role=\"menuitem\"\n :tabindex=\"props.disabled ? -1 : 0\"\n :aria-haspopup=\"true\"\n :aria-expanded=\"isOpen\"\n :aria-disabled=\"props.disabled || undefined\"\n @click=\"handleTitleClick\"\n @keydown=\"handleTitleKeydown\"\n >\n <span v-if=\"props.icon || $slots.icon\" class=\"b-menu-submenu__icon\" aria-hidden=\"true\">\n <slot name=\"icon\">{{ props.icon }}</slot>\n </span>\n <span v-if=\"!menu.inlineCollapsed.value\" class=\"b-menu-submenu__label\">\n <slot name=\"title\">{{ props.label }}</slot>\n </span>\n <span v-if=\"!menu.inlineCollapsed.value\" class=\"b-menu-submenu__arrow\" aria-hidden=\"true\" />\n </div>\n\n <!-- Inline content (inline mode) -->\n <div v-if=\"!isPopupMode\" :class=\"inlineContentClasses\" role=\"none\">\n <ul class=\"b-menu-submenu__inline-list\" role=\"menu\">\n <slot>\n <template v-for=\"item in props.children\" :key=\"item.key ?? (item as any).type\">\n <BMenuDivider v-if=\"isDivider(item)\" :dashed=\"item.dashed\" />\n <BMenuItemGroup\n v-else-if=\"isItemGroup(item)\"\n :label=\"item.label\"\n :children=\"item.children\"\n />\n <BMenuSubMenu\n v-else-if=\"isSubMenu(item)\"\n :item-key=\"item.key\"\n :label=\"item.label\"\n :icon=\"item.icon\"\n :disabled=\"item.disabled\"\n :children=\"item.children\"\n :popup-class-name=\"item.popupClassName\"\n />\n <BMenuItem\n v-else\n :item-key=\"item.key\"\n :label=\"item.label\"\n :icon=\"item.icon\"\n :disabled=\"item.disabled\"\n :danger=\"(item as any).danger\"\n :extra=\"(item as any).extra\"\n />\n </template>\n </slot>\n </ul>\n </div>\n\n <!-- Popup content (vertical / horizontal / collapsed) -->\n <div v-if=\"isPopupMode\" ref=\"popupRef\" :class=\"popupClasses\" role=\"none\">\n <ul class=\"b-menu-submenu__popup-inner\" role=\"menu\">\n <slot>\n <template v-for=\"item in props.children\" :key=\"item.key ?? (item as any).type\">\n <BMenuDivider v-if=\"isDivider(item)\" :dashed=\"item.dashed\" />\n <BMenuItemGroup\n v-else-if=\"isItemGroup(item)\"\n :label=\"item.label\"\n :children=\"item.children\"\n />\n <BMenuSubMenu\n v-else-if=\"isSubMenu(item)\"\n :item-key=\"item.key\"\n :label=\"item.label\"\n :icon=\"item.icon\"\n :disabled=\"item.disabled\"\n :children=\"item.children\"\n :popup-class-name=\"item.popupClassName\"\n />\n <BMenuItem\n v-else\n :item-key=\"item.key\"\n :label=\"item.label\"\n :icon=\"item.icon\"\n :disabled=\"item.disabled\"\n :danger=\"(item as any).danger\"\n :extra=\"(item as any).extra\"\n />\n </template>\n </slot>\n </ul>\n </div>\n </li>\n</template>\n\n<style>\n/* ─────────────────────────────────────────────\n BMenuSubMenu\n ───────────────────────────────────────────── */\n.b-menu-submenu {\n list-style: none;\n position: relative;\n}\n\n.b-menu-submenu--horizontal {\n display: inline-flex;\n flex-direction: column;\n position: relative;\n}\n\n/* ── Title ── */\n.b-menu-submenu__title {\n display: flex;\n align-items: center;\n height: var(--b-menu-item-height);\n margin-block: var(--b-menu-item-margin-block);\n margin-inline: var(--b-menu-item-margin-inline);\n padding-inline: var(--b-menu-item-padding-inline);\n border-radius: var(--b-menu-item-border-radius);\n color: var(--b-menu-item-color);\n cursor: pointer;\n user-select: none;\n outline: none;\n position: relative;\n transition:\n background var(--b-menu-transition-duration),\n color var(--b-menu-transition-duration),\n padding var(--b-menu-transition-duration);\n box-sizing: border-box;\n}\n\n.b-menu-submenu__title:hover:not(.b-menu-submenu__title--disabled) {\n background: var(--b-menu-item-hover-bg);\n color: var(--b-menu-item-hover-color);\n}\n\n.b-menu-submenu__title:focus-visible {\n outline: 2px solid #1677ff;\n outline-offset: -2px;\n}\n\n.b-menu-submenu__title--selected {\n color: var(--b-menu-sub-menu-item-selected-color);\n}\n\n.b-menu-submenu__title--disabled {\n color: var(--b-menu-item-disabled-color);\n cursor: not-allowed;\n}\n\n/* ── Horizontal title ── */\n.b-menu-submenu__title--horizontal {\n margin-block: 0;\n border-radius: var(--b-menu-horizontal-item-border-radius);\n height: auto;\n line-height: var(--b-menu-horizontal-line-height);\n}\n\n.b-menu-submenu__title--horizontal::after {\n content: '';\n position: absolute;\n bottom: 0;\n left: var(--b-menu-item-padding-inline);\n right: var(--b-menu-item-padding-inline);\n height: var(--b-menu-active-bar-height);\n background: transparent;\n transition: background var(--b-menu-transition-duration);\n}\n\n.b-menu-submenu__title--horizontal:hover:not(.b-menu-submenu__title--disabled) {\n background: var(--b-menu-horizontal-item-hover-bg);\n color: var(--b-menu-horizontal-item-hover-color);\n}\n\n.b-menu-submenu__title--horizontal.b-menu-submenu__title--selected {\n color: var(--b-menu-horizontal-item-selected-color);\n}\n\n.b-menu-submenu__title--horizontal.b-menu-submenu__title--selected::after {\n background: var(--b-menu-horizontal-item-selected-color);\n}\n\n/* ── Icon & Label ── */\n.b-menu-submenu__icon {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n flex-shrink: 0;\n font-size: var(--b-menu-icon-size);\n margin-inline-end: var(--b-menu-icon-margin-inline-end);\n}\n\n.b-menu-submenu__label {\n flex: 1;\n min-width: 0;\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n}\n\n/* ── Expand arrow (CSS-only) ── */\n.b-menu-submenu__arrow {\n display: inline-block;\n width: 0;\n height: 0;\n margin-inline-start: auto;\n padding-inline-start: 8px;\n position: relative;\n}\n\n.b-menu-submenu__arrow::before,\n.b-menu-submenu__arrow::after {\n content: '';\n position: absolute;\n width: 6px;\n height: 1.5px;\n background: currentColor;\n border-radius: 1px;\n transition: transform var(--b-menu-transition-duration);\n top: 50%;\n}\n\n.b-menu-submenu__arrow::before {\n transform: rotate(-45deg) translateX(2px);\n}\n\n.b-menu-submenu__arrow::after {\n transform: rotate(45deg) translateX(-2px);\n}\n\n.b-menu-submenu__title--open .b-menu-submenu__arrow::before {\n transform: rotate(45deg) translateX(2px);\n}\n\n.b-menu-submenu__title--open .b-menu-submenu__arrow::after {\n transform: rotate(-45deg) translateX(-2px);\n}\n\n/* Collapsed submenu hides arrow */\n.b-menu-submenu--collapsed .b-menu-submenu__title {\n justify-content: center;\n padding-inline: 0;\n}\n\n.b-menu-submenu--collapsed .b-menu-submenu__icon {\n font-size: var(--b-menu-collapsed-icon-size);\n margin-inline-end: 0;\n}\n\n/* ─────────────────────────────────────────────\n Inline content (expand/collapse via grid)\n ───────────────────────────────────────────── */\n.b-menu-submenu__inline {\n display: grid;\n grid-template-rows: 0fr;\n transition: grid-template-rows var(--b-menu-transition-duration) ease;\n overflow: hidden;\n}\n\n.b-menu-submenu__inline--open {\n grid-template-rows: 1fr;\n}\n\n.b-menu-submenu__inline-list {\n min-height: 0;\n overflow: hidden;\n list-style: none;\n padding: 0;\n margin: 0;\n background: var(--b-menu-sub-menu-item-bg);\n}\n\n/* ─────────────────────────────────────────────\n Popup content (fly-out)\n ───────────────────────────────────────────── */\n.b-menu-submenu__popup {\n position: absolute;\n z-index: var(--b-menu-popup-z-index);\n min-width: var(--b-menu-dropdown-width);\n visibility: hidden;\n opacity: 0;\n pointer-events: none;\n transition:\n opacity var(--b-menu-transition-duration),\n visibility var(--b-menu-transition-duration);\n}\n\n.b-menu-submenu__popup--visible {\n visibility: visible;\n opacity: 1;\n pointer-events: auto;\n}\n\n.b-menu-submenu__popup--horizontal {\n top: 100%;\n left: 0;\n padding-top: 4px;\n}\n\n.b-menu-submenu__popup--vertical {\n top: 0;\n left: 100%;\n padding-inline-start: 4px;\n}\n\n.b-menu-submenu__popup-inner {\n background: var(--b-menu-popup-bg);\n border-radius: var(--b-menu-popup-border-radius);\n box-shadow: var(--b-menu-popup-shadow);\n padding: 4px;\n list-style: none;\n margin: 0;\n}\n\n.b-menu-submenu__popup-inner .b-menu-item {\n border-radius: var(--b-menu-sub-menu-item-border-radius);\n margin-inline: 0;\n}\n\n/* ── Reduced motion ── */\n@media (prefers-reduced-motion: reduce) {\n .b-menu-submenu__title {\n transition: none;\n }\n\n .b-menu-submenu__arrow::before,\n .b-menu-submenu__arrow::after {\n transition: none;\n }\n\n .b-menu-submenu__inline {\n transition: none;\n }\n\n .b-menu-submenu__popup {\n transition: none;\n }\n\n .b-menu-submenu__title--horizontal::after {\n transition: none;\n }\n}\n</style>\n"],"mappings":""}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import e from "./design-
|
|
2
|
-
import { BMenuContextKey as t, isDivider as n, isItemGroup as r, isSubMenu as i } from "./design-
|
|
3
|
-
import a from "./design-
|
|
4
|
-
import o from "./design-
|
|
5
|
-
import s from "./design-
|
|
1
|
+
import e from "./design-system141.js";
|
|
2
|
+
import { BMenuContextKey as t, isDivider as n, isItemGroup as r, isSubMenu as i } from "./design-system142.js";
|
|
3
|
+
import a from "./design-system145.js";
|
|
4
|
+
import o from "./design-system148.js";
|
|
5
|
+
import s from "./design-system151.js";
|
|
6
6
|
import { Fragment as c, computed as l, createBlock as u, createElementBlock as d, defineComponent as f, normalizeClass as p, openBlock as m, provide as h, ref as g, renderList as _, renderSlot as v, unref as y, watch as b } from "vue";
|
|
7
7
|
//#region src/components/BMenu/BMenu.vue?vue&type=script&setup=true&lang.ts
|
|
8
8
|
var x = [
|
|
@@ -151,4 +151,4 @@ var x = [
|
|
|
151
151
|
//#endregion
|
|
152
152
|
export { S as default };
|
|
153
153
|
|
|
154
|
-
//# sourceMappingURL=design-
|
|
154
|
+
//# sourceMappingURL=design-system152.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"design-system140.js","names":[],"sources":["../src/components/BMenu/BMenu.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { computed, provide, ref, watch } from 'vue';\nimport BMenuDivider from './BMenuDivider.vue';\nimport BMenuItem from './BMenuItem.vue';\nimport BMenuItemGroup from './BMenuItemGroup.vue';\nimport BMenuSubMenu from './BMenuSubMenu.vue';\nimport {\n BMenuContextKey,\n isDivider,\n isItemGroup,\n isSubMenu,\n type BMenuClickInfo,\n type BMenuContext,\n type BMenuItemUnion,\n type BMenuMode,\n type BMenuSelectInfo,\n type BMenuTheme,\n type BMenuTriggerAction,\n} from './types';\n\n// ─────────────────────────────────────────────\n// Props\n// ─────────────────────────────────────────────\nconst props = withDefaults(\n defineProps<{\n /** Menu display mode. @default 'inline' */\n mode?: BMenuMode;\n /** Color theme. @default 'light' */\n theme?: BMenuTheme;\n /** Menu items data array. */\n items?: BMenuItemUnion[];\n /** Whether items can be selected. @default true */\n selectable?: boolean;\n /** Allow multiple items to be selected. @default false */\n multiple?: boolean;\n /** Collapsed state in inline mode. @default false */\n inlineCollapsed?: boolean;\n /** Indent (px) per level for inline mode. @default 24 */\n inlineIndent?: number;\n /** Initially selected keys (uncontrolled). */\n defaultSelectedKeys?: string[];\n /** Currently selected keys (controlled). */\n selectedKeys?: string[];\n /** Initially opened submenu keys (uncontrolled). */\n defaultOpenKeys?: string[];\n /** Currently opened submenu keys (controlled). */\n openKeys?: string[];\n /** Action to trigger submenu open. @default 'hover' */\n triggerSubMenuAction?: BMenuTriggerAction;\n /** Delay (ms) before showing submenu. @default 0 */\n subMenuOpenDelay?: number;\n /** Delay (ms) before hiding submenu. @default 100 */\n subMenuCloseDelay?: number;\n }>(),\n {\n mode: 'inline',\n theme: 'light',\n items: () => [],\n selectable: true,\n multiple: false,\n inlineCollapsed: false,\n inlineIndent: 24,\n defaultSelectedKeys: () => [],\n selectedKeys: undefined,\n defaultOpenKeys: () => [],\n openKeys: undefined,\n triggerSubMenuAction: 'hover',\n subMenuOpenDelay: 0,\n subMenuCloseDelay: 100,\n },\n);\n\nconst emit = defineEmits<{\n 'update:selectedKeys': [keys: string[]];\n 'update:openKeys': [keys: string[]];\n click: [info: BMenuClickInfo];\n select: [info: BMenuSelectInfo];\n deselect: [info: BMenuSelectInfo];\n openChange: [keys: string[]];\n}>();\n\ndefineSlots<{\n default?(): unknown;\n}>();\n\n// ─────────────────────────────────────────────\n// Selection state (controlled + uncontrolled)\n// ─────────────────────────────────────────────\nconst isSelectionControlled = computed(() => props.selectedKeys !== undefined);\nconst internalSelectedKeys = ref<string[]>([...props.defaultSelectedKeys]);\n\nconst resolvedSelectedKeys = computed(() =>\n isSelectionControlled.value ? (props.selectedKeys ?? []) : internalSelectedKeys.value,\n);\n\n// ─────────────────────────────────────────────\n// Open state (controlled + uncontrolled)\n// ─────────────────────────────────────────────\nconst isOpenControlled = computed(() => props.openKeys !== undefined);\nconst internalOpenKeys = ref<string[]>([...props.defaultOpenKeys]);\n\nconst resolvedOpenKeys = computed(() =>\n isOpenControlled.value ? (props.openKeys ?? []) : internalOpenKeys.value,\n);\n\n// ─────────────────────────────────────────────\n// Key path registry (item key → full path from root)\n// ─────────────────────────────────────────────\nconst keyPathMap = new Map<string, string[]>();\n\nfunction registerKeyPath(key: string, path: string[]) {\n keyPathMap.set(key, path);\n}\n\n// ─────────────────────────────────────────────\n// Handlers\n// ─────────────────────────────────────────────\nfunction onItemClick(info: BMenuClickInfo) {\n emit('click', info);\n\n if (!props.selectable) return;\n\n const key = info.key;\n const current = [...resolvedSelectedKeys.value];\n\n if (props.multiple) {\n const idx = current.indexOf(key);\n if (idx >= 0) {\n current.splice(idx, 1);\n if (!isSelectionControlled.value) {\n internalSelectedKeys.value = current;\n }\n emit('update:selectedKeys', current);\n emit('deselect', { ...info, selectedKeys: current });\n } else {\n current.push(key);\n if (!isSelectionControlled.value) {\n internalSelectedKeys.value = current;\n }\n emit('update:selectedKeys', current);\n emit('select', { ...info, selectedKeys: current });\n }\n } else {\n const newKeys = [key];\n if (!isSelectionControlled.value) {\n internalSelectedKeys.value = newKeys;\n }\n emit('update:selectedKeys', newKeys);\n emit('select', { ...info, selectedKeys: newKeys });\n }\n}\n\nfunction onOpenChange(key: string, open: boolean) {\n const current = [...resolvedOpenKeys.value];\n const idx = current.indexOf(key);\n\n if (open && idx < 0) {\n if (props.mode === 'inline') {\n current.push(key);\n } else {\n // In vertical/horizontal mode, only one submenu open at a level\n current.push(key);\n }\n } else if (!open && idx >= 0) {\n current.splice(idx, 1);\n }\n\n if (!isOpenControlled.value) {\n internalOpenKeys.value = current;\n }\n emit('update:openKeys', current);\n emit('openChange', current);\n}\n\n// ─────────────────────────────────────────────\n// Sync controlled props\n// ─────────────────────────────────────────────\nwatch(\n () => props.selectedKeys,\n (val) => {\n if (val !== undefined) {\n internalSelectedKeys.value = [...val];\n }\n },\n);\n\nwatch(\n () => props.openKeys,\n (val) => {\n if (val !== undefined) {\n internalOpenKeys.value = [...val];\n }\n },\n);\n\n// When inline collapsed changes, close all submenus in uncontrolled mode\nwatch(\n () => props.inlineCollapsed,\n (collapsed) => {\n if (collapsed && !isOpenControlled.value) {\n internalOpenKeys.value = [];\n emit('update:openKeys', []);\n emit('openChange', []);\n }\n },\n);\n\n// ─────────────────────────────────────────────\n// Context for children\n// ─────────────────────────────────────────────\nconst context: BMenuContext = {\n mode: computed(() => props.mode),\n theme: computed(() => props.theme),\n inlineCollapsed: computed(() => props.inlineCollapsed),\n inlineIndent: computed(() => props.inlineIndent),\n selectedKeys: resolvedSelectedKeys,\n openKeys: resolvedOpenKeys,\n multiple: computed(() => props.multiple),\n selectable: computed(() => props.selectable),\n triggerSubMenuAction: computed(() => props.triggerSubMenuAction),\n subMenuOpenDelay: computed(() => props.subMenuOpenDelay),\n subMenuCloseDelay: computed(() => props.subMenuCloseDelay),\n onItemClick,\n onOpenChange,\n registerKeyPath,\n};\n\nprovide(BMenuContextKey, context);\n\n// ─────────────────────────────────────────────\n// Computed classes\n// ─────────────────────────────────────────────\nconst rootClasses = computed(() => [\n 'b-menu',\n `b-menu--${props.mode}`,\n `b-menu--${props.theme}`,\n {\n 'b-menu--collapsed': props.mode === 'inline' && props.inlineCollapsed,\n },\n]);\n\nconst ariaRole = computed(() => 'menu');\nconst ariaOrientation = computed(() => (props.mode === 'horizontal' ? 'horizontal' : 'vertical'));\n</script>\n\n<template>\n <ul\n :class=\"rootClasses\"\n :role=\"ariaRole\"\n :aria-orientation=\"ariaOrientation\"\n :data-theme=\"props.theme\"\n >\n <slot>\n <template v-for=\"item in props.items\" :key=\"item.key ?? (item as any).type\">\n <BMenuDivider v-if=\"isDivider(item)\" :dashed=\"item.dashed\" />\n <BMenuItemGroup\n v-else-if=\"isItemGroup(item)\"\n :label=\"item.label\"\n :children=\"item.children\"\n />\n <BMenuSubMenu\n v-else-if=\"isSubMenu(item)\"\n :item-key=\"item.key\"\n :label=\"item.label\"\n :icon=\"item.icon\"\n :disabled=\"item.disabled\"\n :children=\"item.children\"\n :popup-class-name=\"item.popupClassName\"\n />\n <BMenuItem\n v-else\n :item-key=\"item.key\"\n :label=\"item.label\"\n :icon=\"item.icon\"\n :disabled=\"item.disabled\"\n :danger=\"(item as any).danger\"\n :extra=\"(item as any).extra\"\n :title=\"(item as any).title\"\n />\n </template>\n </slot>\n </ul>\n</template>\n\n<style>\n/* ─────────────────────────────────────────────\n BMenu – Root CSS Custom Properties\n ───────────────────────────────────────────── */\n.b-menu {\n --b-menu-item-bg: #ffffff;\n --b-menu-item-color: rgba(0, 0, 0, 0.88);\n --b-menu-item-hover-bg: rgba(0, 0, 0, 0.06);\n --b-menu-item-hover-color: rgba(0, 0, 0, 0.88);\n --b-menu-item-active-bg: #e6f4ff;\n --b-menu-item-selected-bg: #e6f4ff;\n --b-menu-item-selected-color: #0958d9;\n --b-menu-item-disabled-color: rgba(0, 0, 0, 0.25);\n --b-menu-item-height: 40px;\n --b-menu-item-border-radius: 8px;\n --b-menu-item-margin-block: 4px;\n --b-menu-item-margin-inline: 4px;\n --b-menu-item-padding-inline: 16px;\n --b-menu-icon-size: 14px;\n --b-menu-icon-margin-inline-end: 10px;\n --b-menu-group-title-color: rgba(0, 0, 0, 0.65);\n --b-menu-group-title-font-size: 14px;\n --b-menu-group-title-line-height: 1.5714;\n --b-menu-danger-item-color: #cf1322;\n --b-menu-danger-item-hover-color: #cf1322;\n --b-menu-danger-item-active-bg: #fff2f0;\n --b-menu-danger-item-selected-bg: #fff2f0;\n --b-menu-danger-item-selected-color: #cf1322;\n --b-menu-sub-menu-item-bg: rgba(0, 0, 0, 0.02);\n --b-menu-sub-menu-item-border-radius: 4px;\n --b-menu-sub-menu-item-selected-color: #0958d9;\n --b-menu-popup-bg: #ffffff;\n --b-menu-popup-shadow:\n 0 6px 16px 0 rgba(0, 0, 0, 0.08), 0 3px 6px -4px rgba(0, 0, 0, 0.12),\n 0 9px 28px 8px rgba(0, 0, 0, 0.05);\n --b-menu-popup-border-radius: 8px;\n --b-menu-popup-z-index: 1050;\n --b-menu-dropdown-width: 160px;\n --b-menu-collapsed-width: 80px;\n --b-menu-collapsed-icon-size: 16px;\n --b-menu-active-bar-height: 2px;\n --b-menu-active-bar-width: 3px;\n --b-menu-active-bar-border-width: 1px;\n --b-menu-horizontal-line-height: 46px;\n --b-menu-horizontal-item-hover-bg: transparent;\n --b-menu-horizontal-item-hover-color: #0958d9;\n --b-menu-horizontal-item-selected-bg: transparent;\n --b-menu-horizontal-item-selected-color: #0958d9;\n --b-menu-horizontal-item-border-radius: 0;\n --b-menu-transition-duration: 200ms;\n}\n\n/* ── Dark theme (via data-theme or dark mode) ── */\n.b-menu--dark,\n[data-prefers-color='dark'] .b-menu {\n --b-menu-item-bg: #001529;\n --b-menu-item-color: rgba(255, 255, 255, 0.65);\n --b-menu-item-hover-bg: transparent;\n --b-menu-item-hover-color: #fff;\n --b-menu-item-active-bg: #1677ff;\n --b-menu-item-selected-bg: #1677ff;\n --b-menu-item-selected-color: #fff;\n --b-menu-item-disabled-color: rgba(255, 255, 255, 0.25);\n --b-menu-group-title-color: rgba(255, 255, 255, 0.65);\n --b-menu-danger-item-color: #ff4d4f;\n --b-menu-danger-item-hover-color: #ff7875;\n --b-menu-danger-item-active-bg: #ff4d4f;\n --b-menu-danger-item-selected-bg: #ff4d4f;\n --b-menu-danger-item-selected-color: #fff;\n --b-menu-sub-menu-item-bg: #000c17;\n --b-menu-popup-bg: #001529;\n}\n\n@media (prefers-color-scheme: dark) {\n [data-prefers-color='system'] .b-menu {\n --b-menu-item-bg: #001529;\n --b-menu-item-color: rgba(255, 255, 255, 0.65);\n --b-menu-item-hover-bg: transparent;\n --b-menu-item-hover-color: #fff;\n --b-menu-item-active-bg: #1677ff;\n --b-menu-item-selected-bg: #1677ff;\n --b-menu-item-selected-color: #fff;\n --b-menu-item-disabled-color: rgba(255, 255, 255, 0.25);\n --b-menu-group-title-color: rgba(255, 255, 255, 0.65);\n --b-menu-danger-item-color: #ff4d4f;\n --b-menu-danger-item-hover-color: #ff7875;\n --b-menu-danger-item-active-bg: #ff4d4f;\n --b-menu-danger-item-selected-bg: #ff4d4f;\n --b-menu-danger-item-selected-color: #fff;\n --b-menu-sub-menu-item-bg: #000c17;\n --b-menu-popup-bg: #001529;\n }\n}\n\n@media (prefers-color-scheme: dark) {\n [data-theme='dark'] .b-menu {\n --b-menu-item-bg: #001529;\n --b-menu-item-color: rgba(255, 255, 255, 0.65);\n --b-menu-item-hover-bg: transparent;\n --b-menu-item-hover-color: #fff;\n --b-menu-item-active-bg: #1677ff;\n --b-menu-item-selected-bg: #1677ff;\n --b-menu-item-selected-color: #fff;\n --b-menu-item-disabled-color: rgba(255, 255, 255, 0.25);\n --b-menu-group-title-color: rgba(255, 255, 255, 0.65);\n --b-menu-danger-item-color: #ff4d4f;\n --b-menu-danger-item-hover-color: #ff7875;\n --b-menu-danger-item-active-bg: #ff4d4f;\n --b-menu-danger-item-selected-bg: #ff4d4f;\n --b-menu-danger-item-selected-color: #fff;\n --b-menu-sub-menu-item-bg: #000c17;\n --b-menu-popup-bg: #001529;\n }\n}\n\n/* ─────────────────────────────────────────────\n Base layout\n ───────────────────────────────────────────── */\n.b-menu {\n margin: 0;\n padding: 4px;\n list-style: none;\n background: var(--b-menu-item-bg);\n color: var(--b-menu-item-color);\n font-size: 14px;\n line-height: 1.5714;\n box-sizing: border-box;\n outline: none;\n transition:\n background var(--b-menu-transition-duration),\n width var(--b-menu-transition-duration);\n}\n\n/* ── Inline mode ── */\n.b-menu--inline {\n width: 100%;\n border-inline-end: 1px solid rgba(5, 5, 5, 0.06);\n}\n\n.b-menu--inline.b-menu--collapsed {\n width: var(--b-menu-collapsed-width);\n}\n\n/* ── Vertical mode ── */\n.b-menu--vertical {\n width: 100%;\n border-inline-end: 1px solid rgba(5, 5, 5, 0.06);\n}\n\n/* ── Horizontal mode ── */\n.b-menu--horizontal {\n display: flex;\n flex-wrap: nowrap;\n align-items: center;\n border-bottom: 1px solid rgba(5, 5, 5, 0.06);\n padding: 0 4px;\n line-height: var(--b-menu-horizontal-line-height);\n}\n\n/* ── Dark theme border override ── */\n.b-menu--dark.b-menu--inline,\n.b-menu--dark.b-menu--vertical {\n border-inline-end-color: transparent;\n}\n\n.b-menu--dark.b-menu--horizontal {\n border-bottom-color: transparent;\n}\n\n/* ── Reduced motion ── */\n@media (prefers-reduced-motion: reduce) {\n .b-menu {\n transition: none;\n }\n}\n</style>\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"design-system152.js","names":[],"sources":["../src/components/BMenu/BMenu.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { computed, provide, ref, watch } from 'vue';\nimport BMenuDivider from './BMenuDivider.vue';\nimport BMenuItem from './BMenuItem.vue';\nimport BMenuItemGroup from './BMenuItemGroup.vue';\nimport BMenuSubMenu from './BMenuSubMenu.vue';\nimport {\n BMenuContextKey,\n isDivider,\n isItemGroup,\n isSubMenu,\n type BMenuClickInfo,\n type BMenuContext,\n type BMenuItemUnion,\n type BMenuMode,\n type BMenuSelectInfo,\n type BMenuTheme,\n type BMenuTriggerAction,\n} from './types';\n\n// ─────────────────────────────────────────────\n// Props\n// ─────────────────────────────────────────────\nconst props = withDefaults(\n defineProps<{\n /** Menu display mode. @default 'inline' */\n mode?: BMenuMode;\n /** Color theme. @default 'light' */\n theme?: BMenuTheme;\n /** Menu items data array. */\n items?: BMenuItemUnion[];\n /** Whether items can be selected. @default true */\n selectable?: boolean;\n /** Allow multiple items to be selected. @default false */\n multiple?: boolean;\n /** Collapsed state in inline mode. @default false */\n inlineCollapsed?: boolean;\n /** Indent (px) per level for inline mode. @default 24 */\n inlineIndent?: number;\n /** Initially selected keys (uncontrolled). */\n defaultSelectedKeys?: string[];\n /** Currently selected keys (controlled). */\n selectedKeys?: string[];\n /** Initially opened submenu keys (uncontrolled). */\n defaultOpenKeys?: string[];\n /** Currently opened submenu keys (controlled). */\n openKeys?: string[];\n /** Action to trigger submenu open. @default 'hover' */\n triggerSubMenuAction?: BMenuTriggerAction;\n /** Delay (ms) before showing submenu. @default 0 */\n subMenuOpenDelay?: number;\n /** Delay (ms) before hiding submenu. @default 100 */\n subMenuCloseDelay?: number;\n }>(),\n {\n mode: 'inline',\n theme: 'light',\n items: () => [],\n selectable: true,\n multiple: false,\n inlineCollapsed: false,\n inlineIndent: 24,\n defaultSelectedKeys: () => [],\n selectedKeys: undefined,\n defaultOpenKeys: () => [],\n openKeys: undefined,\n triggerSubMenuAction: 'hover',\n subMenuOpenDelay: 0,\n subMenuCloseDelay: 100,\n },\n);\n\nconst emit = defineEmits<{\n 'update:selectedKeys': [keys: string[]];\n 'update:openKeys': [keys: string[]];\n click: [info: BMenuClickInfo];\n select: [info: BMenuSelectInfo];\n deselect: [info: BMenuSelectInfo];\n openChange: [keys: string[]];\n}>();\n\ndefineSlots<{\n default?(): unknown;\n}>();\n\n// ─────────────────────────────────────────────\n// Selection state (controlled + uncontrolled)\n// ─────────────────────────────────────────────\nconst isSelectionControlled = computed(() => props.selectedKeys !== undefined);\nconst internalSelectedKeys = ref<string[]>([...props.defaultSelectedKeys]);\n\nconst resolvedSelectedKeys = computed(() =>\n isSelectionControlled.value ? (props.selectedKeys ?? []) : internalSelectedKeys.value,\n);\n\n// ─────────────────────────────────────────────\n// Open state (controlled + uncontrolled)\n// ─────────────────────────────────────────────\nconst isOpenControlled = computed(() => props.openKeys !== undefined);\nconst internalOpenKeys = ref<string[]>([...props.defaultOpenKeys]);\n\nconst resolvedOpenKeys = computed(() =>\n isOpenControlled.value ? (props.openKeys ?? []) : internalOpenKeys.value,\n);\n\n// ─────────────────────────────────────────────\n// Key path registry (item key → full path from root)\n// ─────────────────────────────────────────────\nconst keyPathMap = new Map<string, string[]>();\n\nfunction registerKeyPath(key: string, path: string[]) {\n keyPathMap.set(key, path);\n}\n\n// ─────────────────────────────────────────────\n// Handlers\n// ─────────────────────────────────────────────\nfunction onItemClick(info: BMenuClickInfo) {\n emit('click', info);\n\n if (!props.selectable) return;\n\n const key = info.key;\n const current = [...resolvedSelectedKeys.value];\n\n if (props.multiple) {\n const idx = current.indexOf(key);\n if (idx >= 0) {\n current.splice(idx, 1);\n if (!isSelectionControlled.value) {\n internalSelectedKeys.value = current;\n }\n emit('update:selectedKeys', current);\n emit('deselect', { ...info, selectedKeys: current });\n } else {\n current.push(key);\n if (!isSelectionControlled.value) {\n internalSelectedKeys.value = current;\n }\n emit('update:selectedKeys', current);\n emit('select', { ...info, selectedKeys: current });\n }\n } else {\n const newKeys = [key];\n if (!isSelectionControlled.value) {\n internalSelectedKeys.value = newKeys;\n }\n emit('update:selectedKeys', newKeys);\n emit('select', { ...info, selectedKeys: newKeys });\n }\n}\n\nfunction onOpenChange(key: string, open: boolean) {\n const current = [...resolvedOpenKeys.value];\n const idx = current.indexOf(key);\n\n if (open && idx < 0) {\n if (props.mode === 'inline') {\n current.push(key);\n } else {\n // In vertical/horizontal mode, only one submenu open at a level\n current.push(key);\n }\n } else if (!open && idx >= 0) {\n current.splice(idx, 1);\n }\n\n if (!isOpenControlled.value) {\n internalOpenKeys.value = current;\n }\n emit('update:openKeys', current);\n emit('openChange', current);\n}\n\n// ─────────────────────────────────────────────\n// Sync controlled props\n// ─────────────────────────────────────────────\nwatch(\n () => props.selectedKeys,\n (val) => {\n if (val !== undefined) {\n internalSelectedKeys.value = [...val];\n }\n },\n);\n\nwatch(\n () => props.openKeys,\n (val) => {\n if (val !== undefined) {\n internalOpenKeys.value = [...val];\n }\n },\n);\n\n// When inline collapsed changes, close all submenus in uncontrolled mode\nwatch(\n () => props.inlineCollapsed,\n (collapsed) => {\n if (collapsed && !isOpenControlled.value) {\n internalOpenKeys.value = [];\n emit('update:openKeys', []);\n emit('openChange', []);\n }\n },\n);\n\n// ─────────────────────────────────────────────\n// Context for children\n// ─────────────────────────────────────────────\nconst context: BMenuContext = {\n mode: computed(() => props.mode),\n theme: computed(() => props.theme),\n inlineCollapsed: computed(() => props.inlineCollapsed),\n inlineIndent: computed(() => props.inlineIndent),\n selectedKeys: resolvedSelectedKeys,\n openKeys: resolvedOpenKeys,\n multiple: computed(() => props.multiple),\n selectable: computed(() => props.selectable),\n triggerSubMenuAction: computed(() => props.triggerSubMenuAction),\n subMenuOpenDelay: computed(() => props.subMenuOpenDelay),\n subMenuCloseDelay: computed(() => props.subMenuCloseDelay),\n onItemClick,\n onOpenChange,\n registerKeyPath,\n};\n\nprovide(BMenuContextKey, context);\n\n// ─────────────────────────────────────────────\n// Computed classes\n// ─────────────────────────────────────────────\nconst rootClasses = computed(() => [\n 'b-menu',\n `b-menu--${props.mode}`,\n `b-menu--${props.theme}`,\n {\n 'b-menu--collapsed': props.mode === 'inline' && props.inlineCollapsed,\n },\n]);\n\nconst ariaRole = computed(() => 'menu');\nconst ariaOrientation = computed(() => (props.mode === 'horizontal' ? 'horizontal' : 'vertical'));\n</script>\n\n<template>\n <ul\n :class=\"rootClasses\"\n :role=\"ariaRole\"\n :aria-orientation=\"ariaOrientation\"\n :data-theme=\"props.theme\"\n >\n <slot>\n <template v-for=\"item in props.items\" :key=\"item.key ?? (item as any).type\">\n <BMenuDivider v-if=\"isDivider(item)\" :dashed=\"item.dashed\" />\n <BMenuItemGroup\n v-else-if=\"isItemGroup(item)\"\n :label=\"item.label\"\n :children=\"item.children\"\n />\n <BMenuSubMenu\n v-else-if=\"isSubMenu(item)\"\n :item-key=\"item.key\"\n :label=\"item.label\"\n :icon=\"item.icon\"\n :disabled=\"item.disabled\"\n :children=\"item.children\"\n :popup-class-name=\"item.popupClassName\"\n />\n <BMenuItem\n v-else\n :item-key=\"item.key\"\n :label=\"item.label\"\n :icon=\"item.icon\"\n :disabled=\"item.disabled\"\n :danger=\"(item as any).danger\"\n :extra=\"(item as any).extra\"\n :title=\"(item as any).title\"\n />\n </template>\n </slot>\n </ul>\n</template>\n\n<style>\n/* ─────────────────────────────────────────────\n BMenu – Root CSS Custom Properties\n ───────────────────────────────────────────── */\n.b-menu {\n --b-menu-item-bg: #ffffff;\n --b-menu-item-color: rgba(0, 0, 0, 0.88);\n --b-menu-item-hover-bg: rgba(0, 0, 0, 0.06);\n --b-menu-item-hover-color: rgba(0, 0, 0, 0.88);\n --b-menu-item-active-bg: #e6f4ff;\n --b-menu-item-selected-bg: #e6f4ff;\n --b-menu-item-selected-color: #0958d9;\n --b-menu-item-disabled-color: rgba(0, 0, 0, 0.25);\n --b-menu-item-height: 40px;\n --b-menu-item-border-radius: 8px;\n --b-menu-item-margin-block: 4px;\n --b-menu-item-margin-inline: 4px;\n --b-menu-item-padding-inline: 16px;\n --b-menu-icon-size: 14px;\n --b-menu-icon-margin-inline-end: 10px;\n --b-menu-group-title-color: rgba(0, 0, 0, 0.65);\n --b-menu-group-title-font-size: 14px;\n --b-menu-group-title-line-height: 1.5714;\n --b-menu-danger-item-color: #cf1322;\n --b-menu-danger-item-hover-color: #cf1322;\n --b-menu-danger-item-active-bg: #fff2f0;\n --b-menu-danger-item-selected-bg: #fff2f0;\n --b-menu-danger-item-selected-color: #cf1322;\n --b-menu-sub-menu-item-bg: rgba(0, 0, 0, 0.02);\n --b-menu-sub-menu-item-border-radius: 4px;\n --b-menu-sub-menu-item-selected-color: #0958d9;\n --b-menu-popup-bg: #ffffff;\n --b-menu-popup-shadow:\n 0 6px 16px 0 rgba(0, 0, 0, 0.08), 0 3px 6px -4px rgba(0, 0, 0, 0.12),\n 0 9px 28px 8px rgba(0, 0, 0, 0.05);\n --b-menu-popup-border-radius: 8px;\n --b-menu-popup-z-index: 1050;\n --b-menu-dropdown-width: 160px;\n --b-menu-collapsed-width: 80px;\n --b-menu-collapsed-icon-size: 16px;\n --b-menu-active-bar-height: 2px;\n --b-menu-active-bar-width: 3px;\n --b-menu-active-bar-border-width: 1px;\n --b-menu-horizontal-line-height: 46px;\n --b-menu-horizontal-item-hover-bg: transparent;\n --b-menu-horizontal-item-hover-color: #0958d9;\n --b-menu-horizontal-item-selected-bg: transparent;\n --b-menu-horizontal-item-selected-color: #0958d9;\n --b-menu-horizontal-item-border-radius: 0;\n --b-menu-transition-duration: 200ms;\n}\n\n/* ── Dark theme (via data-theme or dark mode) ── */\n.b-menu--dark,\n[data-prefers-color='dark'] .b-menu {\n --b-menu-item-bg: #001529;\n --b-menu-item-color: rgba(255, 255, 255, 0.65);\n --b-menu-item-hover-bg: transparent;\n --b-menu-item-hover-color: #fff;\n --b-menu-item-active-bg: #1677ff;\n --b-menu-item-selected-bg: #1677ff;\n --b-menu-item-selected-color: #fff;\n --b-menu-item-disabled-color: rgba(255, 255, 255, 0.25);\n --b-menu-group-title-color: rgba(255, 255, 255, 0.65);\n --b-menu-danger-item-color: #ff4d4f;\n --b-menu-danger-item-hover-color: #ff7875;\n --b-menu-danger-item-active-bg: #ff4d4f;\n --b-menu-danger-item-selected-bg: #ff4d4f;\n --b-menu-danger-item-selected-color: #fff;\n --b-menu-sub-menu-item-bg: #000c17;\n --b-menu-popup-bg: #001529;\n}\n\n@media (prefers-color-scheme: dark) {\n [data-prefers-color='system'] .b-menu {\n --b-menu-item-bg: #001529;\n --b-menu-item-color: rgba(255, 255, 255, 0.65);\n --b-menu-item-hover-bg: transparent;\n --b-menu-item-hover-color: #fff;\n --b-menu-item-active-bg: #1677ff;\n --b-menu-item-selected-bg: #1677ff;\n --b-menu-item-selected-color: #fff;\n --b-menu-item-disabled-color: rgba(255, 255, 255, 0.25);\n --b-menu-group-title-color: rgba(255, 255, 255, 0.65);\n --b-menu-danger-item-color: #ff4d4f;\n --b-menu-danger-item-hover-color: #ff7875;\n --b-menu-danger-item-active-bg: #ff4d4f;\n --b-menu-danger-item-selected-bg: #ff4d4f;\n --b-menu-danger-item-selected-color: #fff;\n --b-menu-sub-menu-item-bg: #000c17;\n --b-menu-popup-bg: #001529;\n }\n}\n\n@media (prefers-color-scheme: dark) {\n [data-theme='dark'] .b-menu {\n --b-menu-item-bg: #001529;\n --b-menu-item-color: rgba(255, 255, 255, 0.65);\n --b-menu-item-hover-bg: transparent;\n --b-menu-item-hover-color: #fff;\n --b-menu-item-active-bg: #1677ff;\n --b-menu-item-selected-bg: #1677ff;\n --b-menu-item-selected-color: #fff;\n --b-menu-item-disabled-color: rgba(255, 255, 255, 0.25);\n --b-menu-group-title-color: rgba(255, 255, 255, 0.65);\n --b-menu-danger-item-color: #ff4d4f;\n --b-menu-danger-item-hover-color: #ff7875;\n --b-menu-danger-item-active-bg: #ff4d4f;\n --b-menu-danger-item-selected-bg: #ff4d4f;\n --b-menu-danger-item-selected-color: #fff;\n --b-menu-sub-menu-item-bg: #000c17;\n --b-menu-popup-bg: #001529;\n }\n}\n\n/* ─────────────────────────────────────────────\n Base layout\n ───────────────────────────────────────────── */\n.b-menu {\n margin: 0;\n padding: 4px;\n list-style: none;\n background: var(--b-menu-item-bg);\n color: var(--b-menu-item-color);\n font-size: 14px;\n line-height: 1.5714;\n box-sizing: border-box;\n outline: none;\n transition:\n background var(--b-menu-transition-duration),\n width var(--b-menu-transition-duration);\n}\n\n/* ── Inline mode ── */\n.b-menu--inline {\n width: 100%;\n border-inline-end: 1px solid rgba(5, 5, 5, 0.06);\n}\n\n.b-menu--inline.b-menu--collapsed {\n width: var(--b-menu-collapsed-width);\n}\n\n/* ── Vertical mode ── */\n.b-menu--vertical {\n width: 100%;\n border-inline-end: 1px solid rgba(5, 5, 5, 0.06);\n}\n\n/* ── Horizontal mode ── */\n.b-menu--horizontal {\n display: flex;\n flex-wrap: nowrap;\n align-items: center;\n border-bottom: 1px solid rgba(5, 5, 5, 0.06);\n padding: 0 4px;\n line-height: var(--b-menu-horizontal-line-height);\n}\n\n/* ── Dark theme border override ── */\n.b-menu--dark.b-menu--inline,\n.b-menu--dark.b-menu--vertical {\n border-inline-end-color: transparent;\n}\n\n.b-menu--dark.b-menu--horizontal {\n border-bottom-color: transparent;\n}\n\n/* ── Reduced motion ── */\n@media (prefers-reduced-motion: reduce) {\n .b-menu {\n transition: none;\n }\n}\n</style>\n"],"mappings":"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"}
|
package/dist/design-system154.js
CHANGED
|
@@ -1,310 +1,8 @@
|
|
|
1
|
-
import e from "./design-
|
|
2
|
-
|
|
3
|
-
//#region src/components/
|
|
4
|
-
var
|
|
5
|
-
key: 0,
|
|
6
|
-
class: "b-pagination__total"
|
|
7
|
-
}, _ = [
|
|
8
|
-
"disabled",
|
|
9
|
-
"aria-disabled",
|
|
10
|
-
"title"
|
|
11
|
-
], v = { class: "b-pagination__simple-pager" }, y = [
|
|
12
|
-
"value",
|
|
13
|
-
"disabled",
|
|
14
|
-
"aria-label"
|
|
15
|
-
], b = {
|
|
16
|
-
key: 1,
|
|
17
|
-
class: "b-pagination__simple-current",
|
|
18
|
-
"aria-current": "page"
|
|
19
|
-
}, x = { class: "b-pagination__simple-total" }, S = [
|
|
20
|
-
"disabled",
|
|
21
|
-
"aria-disabled",
|
|
22
|
-
"title"
|
|
23
|
-
], C = [
|
|
24
|
-
"disabled",
|
|
25
|
-
"aria-disabled",
|
|
26
|
-
"title"
|
|
27
|
-
], w = [
|
|
28
|
-
"disabled",
|
|
29
|
-
"title",
|
|
30
|
-
"aria-label",
|
|
31
|
-
"onClick"
|
|
32
|
-
], ee = [
|
|
33
|
-
"disabled",
|
|
34
|
-
"aria-current",
|
|
35
|
-
"aria-label",
|
|
36
|
-
"title",
|
|
37
|
-
"onClick"
|
|
38
|
-
], T = [
|
|
39
|
-
"disabled",
|
|
40
|
-
"aria-disabled",
|
|
41
|
-
"title"
|
|
42
|
-
], E = ["value", "disabled"], D = ["value"], O = {
|
|
43
|
-
key: 4,
|
|
44
|
-
class: "b-pagination__quick-jumper"
|
|
45
|
-
}, k = ["value", "disabled"], A = /* @__PURE__ */ s({
|
|
46
|
-
__name: "BPagination",
|
|
47
|
-
props: {
|
|
48
|
-
current: {},
|
|
49
|
-
defaultCurrent: { default: 1 },
|
|
50
|
-
defaultPageSize: { default: 10 },
|
|
51
|
-
pageSize: {},
|
|
52
|
-
pageSizeOptions: { default: () => [
|
|
53
|
-
10,
|
|
54
|
-
20,
|
|
55
|
-
50,
|
|
56
|
-
100
|
|
57
|
-
] },
|
|
58
|
-
total: { default: 0 },
|
|
59
|
-
disabled: {
|
|
60
|
-
type: Boolean,
|
|
61
|
-
default: !1
|
|
62
|
-
},
|
|
63
|
-
hideOnSinglePage: {
|
|
64
|
-
type: Boolean,
|
|
65
|
-
default: !1
|
|
66
|
-
},
|
|
67
|
-
showLessItems: {
|
|
68
|
-
type: Boolean,
|
|
69
|
-
default: !1
|
|
70
|
-
},
|
|
71
|
-
showQuickJumper: {
|
|
72
|
-
type: [Boolean, Object],
|
|
73
|
-
default: !1
|
|
74
|
-
},
|
|
75
|
-
showSizeChanger: {
|
|
76
|
-
type: Boolean,
|
|
77
|
-
default: void 0
|
|
78
|
-
},
|
|
79
|
-
showTitle: {
|
|
80
|
-
type: Boolean,
|
|
81
|
-
default: !0
|
|
82
|
-
},
|
|
83
|
-
showTotal: {},
|
|
84
|
-
simple: {
|
|
85
|
-
type: [Boolean, Object],
|
|
86
|
-
default: !1
|
|
87
|
-
},
|
|
88
|
-
size: { default: "default" },
|
|
89
|
-
align: { default: "start" },
|
|
90
|
-
totalBoundaryShowSizeChanger: { default: 50 },
|
|
91
|
-
ariaLabel: { default: "Pagination" }
|
|
92
|
-
},
|
|
93
|
-
emits: [
|
|
94
|
-
"change",
|
|
95
|
-
"showSizeChange",
|
|
96
|
-
"update:current",
|
|
97
|
-
"update:pageSize"
|
|
98
|
-
],
|
|
99
|
-
setup(s, { emit: A }) {
|
|
100
|
-
let j = s, M = A, N = u(j.current ?? j.defaultCurrent), P = u(j.pageSize ?? j.defaultPageSize), F = n(() => j.current !== void 0), I = n(() => j.pageSize !== void 0);
|
|
101
|
-
m(() => j.current, (e) => {
|
|
102
|
-
e !== void 0 && (N.value = e);
|
|
103
|
-
}), m(() => j.pageSize, (e) => {
|
|
104
|
-
e !== void 0 && (P.value = e);
|
|
105
|
-
});
|
|
106
|
-
let L = n(() => F.value ? j.current : N.value), R = n(() => I.value ? j.pageSize : P.value), z = n(() => j.total <= 0 || R.value <= 0 ? 0 : Math.ceil(j.total / R.value)), B = n(() => j.hideOnSinglePage && z.value <= 1), V = n(() => j.showSizeChanger === void 0 ? j.total > j.totalBoundaryShowSizeChanger : j.showSizeChanger), H = n(() => !!j.simple), U = n(() => typeof j.simple == "object" && j.simple.readOnly === !0), W = n(() => {
|
|
107
|
-
if (!j.showTotal) return "";
|
|
108
|
-
let e = (L.value - 1) * R.value + 1, t = Math.min(L.value * R.value, j.total);
|
|
109
|
-
return j.showTotal(j.total, [e, t]);
|
|
110
|
-
}), G = n(() => {
|
|
111
|
-
let e = z.value;
|
|
112
|
-
if (e <= 0) return [];
|
|
113
|
-
let t = j.showLessItems ? 1 : 2, n = L.value, r = [];
|
|
114
|
-
if (r.push({
|
|
115
|
-
type: "page",
|
|
116
|
-
page: 1
|
|
117
|
-
}), e <= (j.showLessItems ? 4 : 6) + 2) {
|
|
118
|
-
for (let t = 2; t <= e; t++) r.push({
|
|
119
|
-
type: "page",
|
|
120
|
-
page: t
|
|
121
|
-
});
|
|
122
|
-
return r;
|
|
123
|
-
}
|
|
124
|
-
let i = Math.max(2, n - t), a = Math.min(e - 1, n + t);
|
|
125
|
-
i > 2 && r.push({
|
|
126
|
-
type: "prev-ellipsis",
|
|
127
|
-
page: Math.max(1, n - (j.showLessItems ? 3 : 5))
|
|
128
|
-
});
|
|
129
|
-
for (let e = i; e <= a; e++) r.push({
|
|
130
|
-
type: "page",
|
|
131
|
-
page: e
|
|
132
|
-
});
|
|
133
|
-
return a < e - 1 && r.push({
|
|
134
|
-
type: "next-ellipsis",
|
|
135
|
-
page: Math.min(e, n + (j.showLessItems ? 3 : 5))
|
|
136
|
-
}), e > 1 && r.push({
|
|
137
|
-
type: "page",
|
|
138
|
-
page: e
|
|
139
|
-
}), r;
|
|
140
|
-
});
|
|
141
|
-
function K(e) {
|
|
142
|
-
if (j.disabled) return;
|
|
143
|
-
let t = Math.max(1, Math.min(e, z.value));
|
|
144
|
-
t !== L.value && (F.value || (N.value = t), M("update:current", t), M("change", t, R.value));
|
|
145
|
-
}
|
|
146
|
-
function q(e) {
|
|
147
|
-
if (j.disabled || e === R.value) return;
|
|
148
|
-
let t = Math.ceil(j.total / e), n = Math.min(L.value, t) || 1;
|
|
149
|
-
I.value || (P.value = e), F.value || (N.value = n), M("update:pageSize", e), M("update:current", n), M("showSizeChange", n, e), M("change", n, e);
|
|
150
|
-
}
|
|
151
|
-
function J() {
|
|
152
|
-
K(L.value - 1);
|
|
153
|
-
}
|
|
154
|
-
function Y() {
|
|
155
|
-
K(L.value + 1);
|
|
156
|
-
}
|
|
157
|
-
let X = u("");
|
|
158
|
-
function Z(e) {
|
|
159
|
-
e.key === "Enter" && Q();
|
|
160
|
-
}
|
|
161
|
-
function Q() {
|
|
162
|
-
let e = parseInt(X.value, 10);
|
|
163
|
-
!isNaN(e) && e >= 1 && e <= z.value && K(e), X.value = "";
|
|
164
|
-
}
|
|
165
|
-
let $ = u(String(L.value));
|
|
166
|
-
m(L, (e) => {
|
|
167
|
-
$.value = String(e);
|
|
168
|
-
});
|
|
169
|
-
function te(e) {
|
|
170
|
-
if (e.key === "Enter") {
|
|
171
|
-
let e = parseInt($.value, 10);
|
|
172
|
-
isNaN(e) ? $.value = String(L.value) : K(e);
|
|
173
|
-
}
|
|
174
|
-
}
|
|
175
|
-
function ne() {
|
|
176
|
-
let e = parseInt($.value, 10);
|
|
177
|
-
!isNaN(e) && e >= 1 && e <= z.value ? K(e) : $.value = String(L.value);
|
|
178
|
-
}
|
|
179
|
-
let re = n(() => ["b-pagination", {
|
|
180
|
-
"b-pagination--disabled": j.disabled,
|
|
181
|
-
"b-pagination--simple": H.value,
|
|
182
|
-
"b-pagination--small": j.size === "small",
|
|
183
|
-
"b-pagination--large": j.size === "large",
|
|
184
|
-
"b-pagination--align-start": j.align === "start",
|
|
185
|
-
"b-pagination--align-center": j.align === "center",
|
|
186
|
-
"b-pagination--align-end": j.align === "end"
|
|
187
|
-
}]);
|
|
188
|
-
return (n, u) => B.value ? r("", !0) : (l(), i("nav", {
|
|
189
|
-
key: 0,
|
|
190
|
-
class: c(re.value),
|
|
191
|
-
role: "navigation",
|
|
192
|
-
"aria-label": j.ariaLabel
|
|
193
|
-
}, [
|
|
194
|
-
j.showTotal ? (l(), i("span", g, f(W.value), 1)) : r("", !0),
|
|
195
|
-
H.value ? (l(), i(t, { key: 1 }, [
|
|
196
|
-
a("button", {
|
|
197
|
-
class: "b-pagination__item b-pagination__prev",
|
|
198
|
-
type: "button",
|
|
199
|
-
disabled: j.disabled || L.value <= 1,
|
|
200
|
-
"aria-disabled": j.disabled || L.value <= 1 ? "true" : void 0,
|
|
201
|
-
title: j.showTitle ? "Previous Page" : void 0,
|
|
202
|
-
"aria-label": "Previous Page",
|
|
203
|
-
onClick: J
|
|
204
|
-
}, [o(p(e), {
|
|
205
|
-
icon: "chevron-left",
|
|
206
|
-
"aria-hidden": "true"
|
|
207
|
-
})], 8, _),
|
|
208
|
-
a("span", v, [
|
|
209
|
-
U.value ? (l(), i("span", b, f(L.value), 1)) : (l(), i("input", {
|
|
210
|
-
key: 0,
|
|
211
|
-
class: "b-pagination__simple-input",
|
|
212
|
-
type: "text",
|
|
213
|
-
inputmode: "numeric",
|
|
214
|
-
value: $.value,
|
|
215
|
-
disabled: j.disabled,
|
|
216
|
-
"aria-label": `Page ${L.value} of ${z.value}`,
|
|
217
|
-
onInput: u[0] ||= (e) => $.value = e.target.value,
|
|
218
|
-
onKeydown: te,
|
|
219
|
-
onBlur: ne
|
|
220
|
-
}, null, 40, y)),
|
|
221
|
-
u[3] ||= a("span", {
|
|
222
|
-
class: "b-pagination__simple-separator",
|
|
223
|
-
"aria-hidden": "true"
|
|
224
|
-
}, "/", -1),
|
|
225
|
-
a("span", x, f(z.value), 1)
|
|
226
|
-
]),
|
|
227
|
-
a("button", {
|
|
228
|
-
class: "b-pagination__item b-pagination__next",
|
|
229
|
-
type: "button",
|
|
230
|
-
disabled: j.disabled || L.value >= z.value,
|
|
231
|
-
"aria-disabled": j.disabled || L.value >= z.value ? "true" : void 0,
|
|
232
|
-
title: j.showTitle ? "Next Page" : void 0,
|
|
233
|
-
"aria-label": "Next Page",
|
|
234
|
-
onClick: Y
|
|
235
|
-
}, [o(p(e), {
|
|
236
|
-
icon: "chevron-right",
|
|
237
|
-
"aria-hidden": "true"
|
|
238
|
-
})], 8, S)
|
|
239
|
-
], 64)) : (l(), i(t, { key: 2 }, [
|
|
240
|
-
a("button", {
|
|
241
|
-
class: "b-pagination__item b-pagination__prev",
|
|
242
|
-
type: "button",
|
|
243
|
-
disabled: j.disabled || L.value <= 1,
|
|
244
|
-
"aria-disabled": j.disabled || L.value <= 1 ? "true" : void 0,
|
|
245
|
-
title: j.showTitle ? "Previous Page" : void 0,
|
|
246
|
-
"aria-label": "Previous Page",
|
|
247
|
-
onClick: J
|
|
248
|
-
}, [o(p(e), {
|
|
249
|
-
icon: "chevron-left",
|
|
250
|
-
"aria-hidden": "true"
|
|
251
|
-
})], 8, C),
|
|
252
|
-
(l(!0), i(t, null, d(G.value, (e) => (l(), i(t, { key: `${e.type}-${e.page}` }, [e.type === "prev-ellipsis" || e.type === "next-ellipsis" ? (l(), i("button", {
|
|
253
|
-
key: 0,
|
|
254
|
-
class: "b-pagination__item b-pagination__ellipsis",
|
|
255
|
-
type: "button",
|
|
256
|
-
disabled: j.disabled,
|
|
257
|
-
title: j.showTitle ? e.type === "prev-ellipsis" ? "Previous 5 Pages" : "Next 5 Pages" : void 0,
|
|
258
|
-
"aria-label": e.type === "prev-ellipsis" ? "Previous 5 Pages" : "Next 5 Pages",
|
|
259
|
-
onClick: (t) => K(e.page)
|
|
260
|
-
}, [...u[4] ||= [a("span", { "aria-hidden": "true" }, "•••", -1)]], 8, w)) : (l(), i("button", {
|
|
261
|
-
key: 1,
|
|
262
|
-
class: c(["b-pagination__item b-pagination__page", { "b-pagination__page--active": e.page === L.value }]),
|
|
263
|
-
type: "button",
|
|
264
|
-
disabled: j.disabled,
|
|
265
|
-
"aria-current": e.page === L.value ? "page" : void 0,
|
|
266
|
-
"aria-label": `Page ${e.page}`,
|
|
267
|
-
title: j.showTitle ? `${e.page}` : void 0,
|
|
268
|
-
onClick: (t) => K(e.page)
|
|
269
|
-
}, f(e.page), 11, ee))], 64))), 128)),
|
|
270
|
-
a("button", {
|
|
271
|
-
class: "b-pagination__item b-pagination__next",
|
|
272
|
-
type: "button",
|
|
273
|
-
disabled: j.disabled || L.value >= z.value,
|
|
274
|
-
"aria-disabled": j.disabled || L.value >= z.value ? "true" : void 0,
|
|
275
|
-
title: j.showTitle ? "Next Page" : void 0,
|
|
276
|
-
"aria-label": "Next Page",
|
|
277
|
-
onClick: Y
|
|
278
|
-
}, [o(p(e), {
|
|
279
|
-
icon: "chevron-right",
|
|
280
|
-
"aria-hidden": "true"
|
|
281
|
-
})], 8, T)
|
|
282
|
-
], 64)),
|
|
283
|
-
V.value && !H.value ? (l(), i("select", {
|
|
284
|
-
key: 3,
|
|
285
|
-
class: "b-pagination__size-changer",
|
|
286
|
-
value: R.value,
|
|
287
|
-
disabled: j.disabled,
|
|
288
|
-
"aria-label": "Items per page",
|
|
289
|
-
onChange: u[1] ||= (e) => q(Number(e.target.value))
|
|
290
|
-
}, [(l(!0), i(t, null, d(s.pageSizeOptions, (e) => (l(), i("option", {
|
|
291
|
-
key: e,
|
|
292
|
-
value: e
|
|
293
|
-
}, f(e) + " / page", 9, D))), 128))], 40, E)) : r("", !0),
|
|
294
|
-
j.showQuickJumper && !H.value ? (l(), i("span", O, [u[5] ||= a("span", null, "Go to", -1), a("input", {
|
|
295
|
-
class: "b-pagination__jumper-input",
|
|
296
|
-
type: "text",
|
|
297
|
-
inputmode: "numeric",
|
|
298
|
-
value: X.value,
|
|
299
|
-
disabled: j.disabled,
|
|
300
|
-
"aria-label": "Go to page",
|
|
301
|
-
onInput: u[2] ||= (e) => X.value = e.target.value,
|
|
302
|
-
onKeydown: Z
|
|
303
|
-
}, null, 40, k)])) : r("", !0)
|
|
304
|
-
], 10, h));
|
|
305
|
-
}
|
|
306
|
-
});
|
|
1
|
+
import e from "./design-system152.js";
|
|
2
|
+
/* empty css */
|
|
3
|
+
//#region src/components/BMenu/BMenu.vue
|
|
4
|
+
var t = e;
|
|
307
5
|
//#endregion
|
|
308
|
-
export {
|
|
6
|
+
export { t as default };
|
|
309
7
|
|
|
310
8
|
//# sourceMappingURL=design-system154.js.map
|