@7pmlabs/design-system 2.0.9 → 2.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (377) hide show
  1. package/README.md +4 -4
  2. package/dist/design-system.css +1 -1
  3. package/dist/design-system.js +65 -59
  4. package/dist/design-system100.js +1 -1
  5. package/dist/design-system100.js.map +1 -1
  6. package/dist/design-system101.js +87 -53
  7. package/dist/design-system101.js.map +1 -1
  8. package/dist/design-system103.js +5 -13
  9. package/dist/design-system103.js.map +1 -1
  10. package/dist/design-system104.js +53 -108
  11. package/dist/design-system104.js.map +1 -1
  12. package/dist/{design-system102.js → design-system105.js} +1 -1
  13. package/dist/{design-system102.js.map → design-system105.js.map} +1 -1
  14. package/dist/design-system106.js +13 -6
  15. package/dist/design-system106.js.map +1 -1
  16. package/dist/design-system107.js +93 -190
  17. package/dist/design-system107.js.map +1 -1
  18. package/dist/design-system109.js +2 -2
  19. package/dist/design-system109.js.map +1 -1
  20. package/dist/design-system110.js +183 -484
  21. package/dist/design-system110.js.map +1 -1
  22. package/dist/design-system112.js +5 -4
  23. package/dist/design-system112.js.map +1 -1
  24. package/dist/design-system113.js +507 -7
  25. package/dist/design-system113.js.map +1 -1
  26. package/dist/design-system115.js +8 -0
  27. package/dist/design-system115.js.map +1 -0
  28. package/dist/design-system116.js +7 -6
  29. package/dist/design-system116.js.map +1 -1
  30. package/dist/design-system117.js +154 -169
  31. package/dist/design-system117.js.map +1 -1
  32. package/dist/design-system119.js +2 -2
  33. package/dist/design-system119.js.map +1 -1
  34. package/dist/design-system120.js +210 -149
  35. package/dist/design-system120.js.map +1 -1
  36. package/dist/design-system122.js +5 -4
  37. package/dist/design-system122.js.map +1 -1
  38. package/dist/design-system123.js +160 -9
  39. package/dist/design-system123.js.map +1 -1
  40. package/dist/design-system125.js +8 -0
  41. package/dist/design-system125.js.map +1 -0
  42. package/dist/design-system126.js +176 -6
  43. package/dist/design-system126.js.map +1 -1
  44. package/dist/design-system128.js +8 -0
  45. package/dist/design-system128.js.map +1 -0
  46. package/dist/design-system129.js +213 -5
  47. package/dist/design-system129.js.map +1 -1
  48. package/dist/design-system131.js +5 -90
  49. package/dist/design-system131.js.map +1 -1
  50. package/dist/design-system132.js +166 -0
  51. package/dist/design-system132.js.map +1 -0
  52. package/dist/design-system134.js +5 -42
  53. package/dist/design-system134.js.map +1 -1
  54. package/dist/design-system135.js +12 -0
  55. package/dist/design-system135.js.map +1 -0
  56. package/dist/design-system136.js +274 -5
  57. package/dist/design-system136.js.map +1 -1
  58. package/dist/design-system138.js +9 -0
  59. package/dist/{design-system124.js.map → design-system138.js.map} +1 -1
  60. package/dist/design-system139.js +16 -5
  61. package/dist/design-system139.js.map +1 -1
  62. package/dist/design-system141.js +8 -0
  63. package/dist/{design-system127.js.map → design-system141.js.map} +1 -1
  64. package/dist/design-system142.js +12 -5
  65. package/dist/design-system142.js.map +1 -1
  66. package/dist/design-system143.js +78 -83
  67. package/dist/design-system143.js.map +1 -1
  68. package/dist/design-system145.js +1 -1
  69. package/dist/design-system145.js.map +1 -1
  70. package/dist/design-system146.js +42 -9
  71. package/dist/design-system146.js.map +1 -1
  72. package/dist/design-system148.js +3 -2
  73. package/dist/design-system148.js.map +1 -1
  74. package/dist/design-system149.js +230 -18
  75. package/dist/design-system149.js.map +1 -1
  76. package/dist/design-system151.js +5 -158
  77. package/dist/design-system151.js.map +1 -1
  78. package/dist/{design-system140.js → design-system152.js} +6 -6
  79. package/dist/{design-system140.js.map → design-system152.js.map} +1 -1
  80. package/dist/design-system154.js +5 -307
  81. package/dist/design-system154.js.map +1 -1
  82. package/dist/design-system155.js +98 -0
  83. package/dist/design-system155.js.map +1 -0
  84. package/dist/design-system157.js +5 -240
  85. package/dist/design-system157.js.map +1 -1
  86. package/dist/design-system158.js +12 -0
  87. package/dist/design-system158.js.map +1 -0
  88. package/dist/design-system159.js +37 -5
  89. package/dist/design-system159.js.map +1 -1
  90. package/dist/design-system160.js +4 -189
  91. package/dist/design-system160.js.map +1 -1
  92. package/dist/design-system161.js +24 -0
  93. package/dist/{design-system150.js.map → design-system161.js.map} +1 -1
  94. package/dist/design-system162.js +2 -3
  95. package/dist/design-system162.js.map +1 -1
  96. package/dist/design-system163.js +158 -3
  97. package/dist/design-system163.js.map +1 -1
  98. package/dist/{design-system153.js → design-system165.js} +2 -2
  99. package/dist/{design-system153.js.map → design-system165.js.map} +1 -1
  100. package/dist/design-system166.js +307 -6
  101. package/dist/design-system166.js.map +1 -1
  102. package/dist/{design-system156.js → design-system168.js} +2 -2
  103. package/dist/{design-system156.js.map → design-system168.js.map} +1 -1
  104. package/dist/design-system169.js +167 -6
  105. package/dist/design-system169.js.map +1 -1
  106. package/dist/design-system171.js +8 -0
  107. package/dist/design-system171.js.map +1 -0
  108. package/dist/design-system172.js +240 -6
  109. package/dist/design-system172.js.map +1 -1
  110. package/dist/design-system174.js +8 -0
  111. package/dist/design-system174.js.map +1 -0
  112. package/dist/design-system175.js +189 -6
  113. package/dist/design-system175.js.map +1 -1
  114. package/dist/design-system177.js +8 -0
  115. package/dist/design-system177.js.map +1 -0
  116. package/dist/design-system178.js +3 -5
  117. package/dist/design-system178.js.map +1 -1
  118. package/dist/design-system179.js +58 -11
  119. package/dist/design-system179.js.map +1 -1
  120. package/dist/design-system181.js +9 -0
  121. package/dist/design-system181.js.map +1 -0
  122. package/dist/design-system182.js +56 -6
  123. package/dist/design-system182.js.map +1 -1
  124. package/dist/design-system184.js +9 -0
  125. package/dist/{design-system167.js.map → design-system184.js.map} +1 -1
  126. package/dist/design-system185.js +69 -5
  127. package/dist/design-system185.js.map +1 -1
  128. package/dist/design-system187.js +9 -0
  129. package/dist/{design-system170.js.map → design-system187.js.map} +1 -1
  130. package/dist/design-system188.js +182 -5
  131. package/dist/design-system188.js.map +1 -1
  132. package/dist/design-system190.js +9 -0
  133. package/dist/design-system190.js.map +1 -0
  134. package/dist/design-system191.js +115 -5
  135. package/dist/design-system191.js.map +1 -1
  136. package/dist/design-system193.js +8 -0
  137. package/dist/{design-system176.js.map → design-system193.js.map} +1 -1
  138. package/dist/design-system194.js +11 -5
  139. package/dist/design-system194.js.map +1 -1
  140. package/dist/design-system195.js +453 -24
  141. package/dist/design-system195.js.map +1 -1
  142. package/dist/design-system197.js +5 -4
  143. package/dist/design-system197.js.map +1 -1
  144. package/dist/design-system198.js +20 -16
  145. package/dist/design-system198.js.map +1 -1
  146. package/dist/design-system200.js +1 -1
  147. package/dist/design-system200.js.map +1 -1
  148. package/dist/design-system201.js +70 -314
  149. package/dist/design-system201.js.map +1 -1
  150. package/dist/design-system203.js +1 -1
  151. package/dist/design-system203.js.map +1 -1
  152. package/dist/design-system204.js +24 -89
  153. package/dist/design-system204.js.map +1 -1
  154. package/dist/design-system206.js +1 -1
  155. package/dist/design-system206.js.map +1 -1
  156. package/dist/design-system207.js +26 -17
  157. package/dist/design-system207.js.map +1 -1
  158. package/dist/design-system209.js +5 -3
  159. package/dist/design-system209.js.map +1 -1
  160. package/dist/design-system210.js +22 -408
  161. package/dist/design-system210.js.map +1 -1
  162. package/dist/design-system212.js +1 -1
  163. package/dist/design-system212.js.map +1 -1
  164. package/dist/design-system213.js +24 -52
  165. package/dist/design-system213.js.map +1 -1
  166. package/dist/design-system215.js +1 -1
  167. package/dist/design-system215.js.map +1 -1
  168. package/dist/design-system216.js +329 -85
  169. package/dist/design-system216.js.map +1 -1
  170. package/dist/design-system218.js +5 -108
  171. package/dist/design-system218.js.map +1 -1
  172. package/dist/design-system219.js +103 -0
  173. package/dist/design-system219.js.map +1 -0
  174. package/dist/design-system221.js +5 -106
  175. package/dist/design-system221.js.map +1 -1
  176. package/dist/design-system222.js +22 -0
  177. package/dist/{design-system208.js.map → design-system222.js.map} +1 -1
  178. package/dist/design-system223.js +4 -6
  179. package/dist/design-system223.js.map +1 -1
  180. package/dist/design-system224.js +3 -737
  181. package/dist/design-system224.js.map +1 -1
  182. package/dist/design-system225.js +422 -0
  183. package/dist/design-system225.js.map +1 -0
  184. package/dist/design-system227.js +5 -11
  185. package/dist/design-system227.js.map +1 -1
  186. package/dist/design-system228.js +51 -517
  187. package/dist/design-system228.js.map +1 -1
  188. package/dist/design-system230.js +1 -1
  189. package/dist/design-system230.js.map +1 -1
  190. package/dist/design-system231.js +88 -3
  191. package/dist/design-system231.js.map +1 -1
  192. package/dist/design-system232.js +4 -46
  193. package/dist/design-system232.js.map +1 -1
  194. package/dist/design-system233.js +108 -4
  195. package/dist/design-system233.js.map +1 -1
  196. package/dist/{design-system220.js → design-system235.js} +2 -2
  197. package/dist/{design-system220.js.map → design-system235.js.map} +1 -1
  198. package/dist/design-system236.js +106 -5
  199. package/dist/design-system236.js.map +1 -1
  200. package/dist/design-system238.js +9 -0
  201. package/dist/design-system238.js.map +1 -0
  202. package/dist/design-system239.js +737 -5
  203. package/dist/design-system239.js.map +1 -1
  204. package/dist/{design-system226.js → design-system241.js} +2 -2
  205. package/dist/{design-system226.js.map → design-system241.js.map} +1 -1
  206. package/dist/design-system242.js +3 -5
  207. package/dist/design-system242.js.map +1 -1
  208. package/dist/design-system243.js +42 -50
  209. package/dist/design-system243.js.map +1 -1
  210. package/dist/design-system244.js +1 -1
  211. package/dist/design-system244.js.map +1 -1
  212. package/dist/design-system245.js +254 -141
  213. package/dist/design-system245.js.map +1 -1
  214. package/dist/design-system247.js +1 -1
  215. package/dist/design-system247.js.map +1 -1
  216. package/dist/design-system248.js +119 -7
  217. package/dist/design-system248.js.map +1 -1
  218. package/dist/design-system250.js +8 -0
  219. package/dist/design-system250.js.map +1 -0
  220. package/dist/design-system251.js +172 -5
  221. package/dist/design-system251.js.map +1 -1
  222. package/dist/design-system253.js +8 -0
  223. package/dist/design-system253.js.map +1 -0
  224. package/dist/design-system254.js +11 -6
  225. package/dist/design-system254.js.map +1 -1
  226. package/dist/design-system255.js +525 -9
  227. package/dist/design-system255.js.map +1 -1
  228. package/dist/design-system257.js +8 -0
  229. package/dist/design-system257.js.map +1 -0
  230. package/dist/design-system258.js +112 -6
  231. package/dist/design-system258.js.map +1 -1
  232. package/dist/design-system260.js +5 -374
  233. package/dist/design-system260.js.map +1 -1
  234. package/dist/design-system261.js +57 -0
  235. package/dist/design-system261.js.map +1 -0
  236. package/dist/design-system262.js +4 -6
  237. package/dist/design-system262.js.map +1 -1
  238. package/dist/design-system263.js +173 -0
  239. package/dist/design-system263.js.map +1 -0
  240. package/dist/design-system265.js +8 -0
  241. package/dist/design-system265.js.map +1 -0
  242. package/dist/design-system266.js +10 -0
  243. package/dist/design-system266.js.map +1 -0
  244. package/dist/{design-system249.js → design-system267.js} +2 -2
  245. package/dist/{design-system249.js.map → design-system267.js.map} +1 -1
  246. package/dist/design-system269.js +8 -0
  247. package/dist/design-system269.js.map +1 -0
  248. package/dist/{design-system252.js → design-system270.js} +1 -1
  249. package/dist/{design-system252.js.map → design-system270.js.map} +1 -1
  250. package/dist/design-system272.js +9 -0
  251. package/dist/design-system272.js.map +1 -0
  252. package/dist/design-system273.js +12 -0
  253. package/dist/design-system273.js.map +1 -0
  254. package/dist/{design-system256.js → design-system274.js} +2 -2
  255. package/dist/{design-system256.js.map → design-system274.js.map} +1 -1
  256. package/dist/design-system276.js +9 -0
  257. package/dist/design-system276.js.map +1 -0
  258. package/dist/{design-system259.js → design-system277.js} +1 -1
  259. package/dist/{design-system259.js.map → design-system277.js.map} +1 -1
  260. package/dist/design-system278.js +377 -0
  261. package/dist/design-system278.js.map +1 -0
  262. package/dist/design-system280.js +9 -0
  263. package/dist/design-system280.js.map +1 -0
  264. package/dist/design-system69.js +182 -13
  265. package/dist/design-system69.js.map +1 -1
  266. package/dist/design-system71.js +8 -0
  267. package/dist/design-system71.js.map +1 -0
  268. package/dist/design-system72.js +13 -5
  269. package/dist/design-system72.js.map +1 -1
  270. package/dist/design-system73.js +677 -139
  271. package/dist/design-system73.js.map +1 -1
  272. package/dist/design-system75.js +1 -1
  273. package/dist/design-system75.js.map +1 -1
  274. package/dist/design-system76.js +152 -23
  275. package/dist/design-system76.js.map +1 -1
  276. package/dist/design-system78.js +5 -49
  277. package/dist/design-system78.js.map +1 -1
  278. package/dist/design-system79.js +32 -0
  279. package/dist/design-system79.js.map +1 -0
  280. package/dist/design-system80.js +2 -3
  281. package/dist/design-system80.js.map +1 -1
  282. package/dist/design-system81.js +38 -188
  283. package/dist/design-system81.js.map +1 -1
  284. package/dist/design-system83.js +1 -1
  285. package/dist/design-system83.js.map +1 -1
  286. package/dist/design-system84.js +199 -7
  287. package/dist/design-system84.js.map +1 -1
  288. package/dist/design-system86.js +8 -0
  289. package/dist/design-system86.js.map +1 -0
  290. package/dist/design-system87.js +7 -5
  291. package/dist/design-system87.js.map +1 -1
  292. package/dist/design-system88.js +264 -48
  293. package/dist/design-system88.js.map +1 -1
  294. package/dist/design-system90.js +1 -1
  295. package/dist/design-system90.js.map +1 -1
  296. package/dist/design-system91.js +57 -11
  297. package/dist/design-system91.js.map +1 -1
  298. package/dist/design-system93.js +8 -0
  299. package/dist/design-system93.js.map +1 -0
  300. package/dist/design-system94.js +11 -5
  301. package/dist/design-system94.js.map +1 -1
  302. package/dist/design-system95.js +92 -59
  303. package/dist/design-system95.js.map +1 -1
  304. package/dist/design-system97.js +1 -1
  305. package/dist/design-system97.js.map +1 -1
  306. package/dist/design-system98.js +56 -78
  307. package/dist/design-system98.js.map +1 -1
  308. package/dist/types/components/BContextMenu/BContextMenu.spec.d.ts +1 -0
  309. package/dist/types/components/BContextMenu/BContextMenu.vue.d.ts +42 -0
  310. package/dist/types/components/BContextMenu/index.d.ts +2 -0
  311. package/dist/types/components/BContextMenu/types.d.ts +23 -0
  312. package/dist/types/components/BInputTags/BInputTags.spec.d.ts +1 -0
  313. package/dist/types/components/BInputTags/BInputTags.vue.d.ts +54 -0
  314. package/dist/types/components/BInputTags/index.d.ts +1 -0
  315. package/dist/types/components/BLink/BLink.spec.d.ts +1 -0
  316. package/dist/types/components/BLink/BLink.vue.d.ts +100 -0
  317. package/dist/types/components/BLink/index.d.ts +1 -0
  318. package/dist/types/components/BListbox/BListbox.spec.d.ts +1 -0
  319. package/dist/types/components/BListbox/BListbox.vue.d.ts +52 -0
  320. package/dist/types/components/BListbox/index.d.ts +1 -0
  321. package/dist/types/components/BModal/BModal.spec.d.ts +1 -0
  322. package/dist/types/components/BPinInput/BPinInput.spec.d.ts +1 -0
  323. package/dist/types/components/BPinInput/BPinInput.vue.d.ts +43 -0
  324. package/dist/types/components/BPinInput/index.d.ts +1 -0
  325. package/dist/types/components/BProgress/BProgress.vue.d.ts +47 -2
  326. package/dist/types/components/BTextarea/BTextarea.spec.d.ts +1 -0
  327. package/dist/types/components/BTextarea/BTextarea.vue.d.ts +77 -0
  328. package/dist/types/components/BTextarea/index.d.ts +1 -0
  329. package/dist/types/components/index.d.ts +7 -1
  330. package/package.json +1 -1
  331. package/dist/design-system114.js +0 -212
  332. package/dist/design-system114.js.map +0 -1
  333. package/dist/design-system124.js +0 -277
  334. package/dist/design-system127.js +0 -19
  335. package/dist/design-system130.js +0 -15
  336. package/dist/design-system130.js.map +0 -1
  337. package/dist/design-system133.js +0 -8
  338. package/dist/design-system133.js.map +0 -1
  339. package/dist/design-system137.js +0 -236
  340. package/dist/design-system137.js.map +0 -1
  341. package/dist/design-system147.js +0 -40
  342. package/dist/design-system147.js.map +0 -1
  343. package/dist/design-system150.js +0 -7
  344. package/dist/design-system164.js +0 -61
  345. package/dist/design-system164.js.map +0 -1
  346. package/dist/design-system167.js +0 -59
  347. package/dist/design-system170.js +0 -72
  348. package/dist/design-system173.js +0 -185
  349. package/dist/design-system173.js.map +0 -1
  350. package/dist/design-system176.js +0 -118
  351. package/dist/design-system180.js +0 -465
  352. package/dist/design-system180.js.map +0 -1
  353. package/dist/design-system183.js +0 -38
  354. package/dist/design-system183.js.map +0 -1
  355. package/dist/design-system186.js +0 -91
  356. package/dist/design-system186.js.map +0 -1
  357. package/dist/design-system189.js +0 -38
  358. package/dist/design-system189.js.map +0 -1
  359. package/dist/design-system192.js +0 -31
  360. package/dist/design-system192.js.map +0 -1
  361. package/dist/design-system208.js +0 -7
  362. package/dist/design-system217.js +0 -7
  363. package/dist/design-system217.js.map +0 -1
  364. package/dist/design-system234.js +0 -286
  365. package/dist/design-system234.js.map +0 -1
  366. package/dist/design-system237.js +0 -122
  367. package/dist/design-system237.js.map +0 -1
  368. package/dist/design-system240.js +0 -115
  369. package/dist/design-system240.js.map +0 -1
  370. package/dist/design-system70.js +0 -699
  371. package/dist/design-system70.js.map +0 -1
  372. package/dist/design-system77.js +0 -7
  373. package/dist/design-system77.js.map +0 -1
  374. package/dist/design-system85.js +0 -276
  375. package/dist/design-system85.js.map +0 -1
  376. package/dist/design-system92.js +0 -102
  377. package/dist/design-system92.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"design-system145.js","names":[],"sources":["../src/components/BMessage/BMessage.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { BMessageType } from '@/types.ts';\nimport { computed, onUnmounted, ref, useId, watch } from 'vue';\n\n// ─────────────────────────────────────────────\n// Props & emits\n// ─────────────────────────────────────────────\nconst {\n type = BMessageType.Info,\n content = '',\n duration = 3,\n showIcon = true,\n modelValue = undefined,\n} = defineProps<{\n /**\n * Message type - controls icon and colour scheme.\n * @default 'info'\n */\n type?: `${BMessageType}`;\n /** The message content text (also accepts the default slot). */\n content?: string;\n /**\n * Time (in seconds) before auto-close. Set to `0` to disable auto-close.\n * @default 3\n */\n duration?: number;\n /** Show the built-in status icon. @default true */\n showIcon?: boolean;\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 message 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\n// ─────────────────────────────────────────────\n// Internal state\n// ─────────────────────────────────────────────\nconst messageId = useId();\n\n/** Uncontrolled visibility flag - default closed. */\nconst internalVisible = ref(false);\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 === BMessageType.Error || type === BMessageType.Warning ? 'alert' : 'status',\n);\n\n/** Map type → inline SVG path for the status icon. */\nconst iconPath = computed(() => {\n switch (type) {\n case BMessageType.Success:\n // circle-check\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 BMessageType.Warning:\n // triangle-exclamation\n return 'M1 21h22L12 2 1 21zm12-3h-2v-2h2v2zm0-4h-2v-4h2v4z';\n case BMessageType.Error:\n // circle-xmark\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 case BMessageType.Loading:\n // spinner (circle arc)\n return 'M12 2a10 10 0 0 1 10 10h-2a8 8 0 0 0-8-8V2z';\n default:\n // circle-info\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\ndefineSlots<{\n /** Overrides the `content` prop. */\n default?(): unknown;\n /** Overrides the built-in status icon. */\n icon?(): unknown;\n}>();\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 emit('afterClose');\n}\n\nfunction onMouseEnter() {\n clearTimer();\n}\n\nfunction onMouseLeave() {\n startTimer();\n}\n\n// ─────────────────────────────────────────────\n// Lifecycle\n// ─────────────────────────────────────────────\nonUnmounted(() => {\n clearTimer();\n});\n\n// Start / clear auto-close timer whenever visibility changes\nwatch(\n isVisible,\n (visible) => {\n if (visible) {\n startTimer();\n } else {\n clearTimer();\n }\n },\n { immediate: true },\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-message-fade\" @after-leave=\"onAfterLeave\">\n <div\n v-if=\"isVisible\"\n :id=\"messageId\"\n class=\"b-message\"\n :class=\"[\n `b-message--${type}`,\n {\n 'b-message--with-icon': showIcon,\n },\n ]\"\n :role=\"ariaRole\"\n :aria-live=\"ariaRole === 'alert' ? 'assertive' : 'polite'\"\n :aria-atomic=\"true\"\n @mouseenter=\"onMouseEnter\"\n @mouseleave=\"onMouseLeave\"\n >\n <!-- Status icon -->\n <span v-if=\"showIcon\" class=\"b-message__icon\" aria-hidden=\"true\">\n <slot name=\"icon\">\n <svg\n class=\"b-message__icon-svg\"\n :class=\"{ 'b-message__icon-svg--spin': type === 'loading' }\"\n viewBox=\"0 0 24 24\"\n xmlns=\"http://www.w3.org/2000/svg\"\n focusable=\"false\"\n >\n <path :d=\"iconPath\" />\n </svg>\n </slot>\n </span>\n\n <!-- Content -->\n <span class=\"b-message__content\">\n <slot>{{ content }}</slot>\n </span>\n </div>\n </Transition>\n </Teleport>\n</template>\n\n<style>\n/* ────────────────────────────────────────────\n CSS Custom Properties (tokens)\n ──────────────────────────────────────────── */\n.b-message {\n /* Layout */\n --b-message-padding-v: 0.625rem;\n --b-message-padding-h: 1rem;\n --b-message-border-radius: 0.5rem;\n --b-message-icon-size: 1rem;\n --b-message-gap: 0.5rem;\n --b-message-font-size: 0.875rem;\n --b-message-max-width: 32rem;\n\n /* Colours - info (default) */\n --b-message-bg: #ffffff;\n --b-message-border-color: oklch(90% 0.02 240);\n --b-message-color: oklch(30% 0.02 240);\n --b-message-icon-color: oklch(62.3% 0.214 259.815);\n --b-message-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-message-transition-duration: 300ms;\n --b-message-top: 8px;\n}\n\n/* ── Variant colour tokens ── */\n.b-message--success {\n --b-message-icon-color: oklch(72.3% 0.219 149.579);\n}\n\n.b-message--warning {\n --b-message-icon-color: oklch(75% 0.183 55.934);\n}\n\n.b-message--error {\n --b-message-icon-color: oklch(63.7% 0.237 25.331);\n}\n\n.b-message--loading {\n --b-message-icon-color: oklch(62.3% 0.214 259.815);\n}\n\n/* ── Dark mode ── */\n[data-prefers-color='dark'] .b-message {\n --b-message-bg: oklch(22% 0.02 240);\n --b-message-border-color: oklch(35% 0.03 240);\n --b-message-color: oklch(88% 0.02 240);\n --b-message-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-message {\n --b-message-bg: oklch(22% 0.02 240);\n --b-message-border-color: oklch(35% 0.03 240);\n --b-message-color: oklch(88% 0.02 240);\n --b-message-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-message {\n position: fixed;\n top: var(--b-message-top);\n left: 50%;\n transform: translateX(-50%);\n z-index: 1010;\n display: inline-flex;\n align-items: center;\n gap: var(--b-message-gap);\n padding: var(--b-message-padding-v) var(--b-message-padding-h);\n border-radius: var(--b-message-border-radius);\n background-color: var(--b-message-bg);\n color: var(--b-message-color);\n font-size: var(--b-message-font-size);\n line-height: 1.5;\n box-shadow: var(--b-message-shadow);\n box-sizing: border-box;\n max-width: var(--b-message-max-width);\n word-break: break-word;\n pointer-events: auto;\n}\n\n/* ── Icon ── */\n.b-message__icon {\n display: inline-flex;\n flex-shrink: 0;\n align-items: center;\n color: var(--b-message-icon-color);\n line-height: 1;\n}\n\n.b-message__icon-svg {\n width: var(--b-message-icon-size);\n height: var(--b-message-icon-size);\n fill: currentColor;\n display: block;\n}\n\n/* Loading spinner animation */\n.b-message__icon-svg--spin {\n animation: b-message-spin 1s linear infinite;\n}\n\n@keyframes b-message-spin {\n from {\n transform: rotate(0deg);\n }\n to {\n transform: rotate(360deg);\n }\n}\n\n/* ── Content ── */\n.b-message__content {\n flex: 1;\n min-width: 0;\n}\n\n/* ─────────────────────────────────────────────\n Transition (slide-down + fade)\n ───────────────────────────────────────────── */\n.b-message-fade-enter-active,\n.b-message-fade-leave-active {\n transition:\n opacity var(--b-message-transition-duration, 300ms) ease,\n transform var(--b-message-transition-duration, 300ms) ease;\n}\n\n.b-message-fade-enter-from {\n opacity: 0;\n transform: translateX(-50%) translateY(-100%);\n}\n\n.b-message-fade-enter-to {\n opacity: 1;\n transform: translateX(-50%) translateY(0);\n}\n\n.b-message-fade-leave-from {\n opacity: 1;\n transform: translateX(-50%) translateY(0);\n}\n\n.b-message-fade-leave-to {\n opacity: 0;\n transform: translateX(-50%) translateY(-100%);\n}\n\n/* Respect prefers-reduced-motion */\n@media (prefers-reduced-motion: reduce) {\n .b-message-fade-enter-active,\n .b-message-fade-leave-active {\n transition: opacity var(--b-message-transition-duration, 300ms) ease;\n }\n\n .b-message-fade-enter-from,\n .b-message-fade-leave-to {\n transform: translateX(-50%);\n }\n\n .b-message__icon-svg--spin {\n animation: none;\n }\n}\n</style>\n"],"mappings":""}
1
+ {"version":3,"file":"design-system145.js","names":[],"sources":["../src/components/BMenu/BMenuItem.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { computed, inject, onMounted } from 'vue';\nimport {\n BMenuContextKey,\n BMenuSubMenuContextKey,\n type BMenuClickInfo,\n type BMenuContext,\n type BMenuSubMenuContext,\n} from './types';\n\n// ─────────────────────────────────────────────\n// Props\n// ─────────────────────────────────────────────\nconst {\n itemKey,\n label = '',\n icon = undefined,\n disabled = false,\n danger = false,\n extra = undefined,\n title = undefined,\n} = defineProps<{\n /** Unique key identifying this menu item. */\n itemKey: string;\n /** Display label text. */\n label?: string;\n /** Icon name rendered before the label. */\n icon?: string;\n /** Whether the item is disabled. @default false */\n disabled?: boolean;\n /** Display with danger (red) styling. @default false */\n danger?: boolean;\n /** Extra content at the right side. */\n extra?: string;\n /** Tooltip title when collapsed. */\n title?: string;\n}>();\n\ndefineSlots<{\n default?(): unknown;\n icon?(): unknown;\n extra?(): unknown;\n}>();\n\n// ─────────────────────────────────────────────\n// Inject context\n// ─────────────────────────────────────────────\nconst menu = inject<BMenuContext>(BMenuContextKey)!;\nconst subMenuCtx = inject<BMenuSubMenuContext | null>(BMenuSubMenuContextKey, null);\n\nconst level = computed(() => (subMenuCtx?.level ?? 0) + 1);\nconst keyPath = computed(() => [...(subMenuCtx?.keyPath ?? []), itemKey]);\n\n// Register key path with root menu\nonMounted(() => {\n menu.registerKeyPath(itemKey, keyPath.value);\n});\n\n// ─────────────────────────────────────────────\n// Computed\n// ─────────────────────────────────────────────\nconst isSelected = computed(() => menu.selectedKeys.value.includes(itemKey));\n\nconst itemRole = computed(() => {\n if (!menu.selectable.value) return 'menuitem';\n return menu.multiple.value ? 'menuitemcheckbox' : 'menuitemradio';\n});\n\nconst paddingLeft = computed(() => {\n if (menu.mode.value !== 'inline') return undefined;\n if (menu.inlineCollapsed.value) return undefined;\n return `${level.value * menu.inlineIndent.value}px`;\n});\n\nconst itemClasses = computed(() => [\n 'b-menu-item',\n {\n 'b-menu-item--selected': isSelected.value,\n 'b-menu-item--disabled': disabled,\n 'b-menu-item--danger': danger,\n 'b-menu-item--collapsed': menu.inlineCollapsed.value,\n 'b-menu-item--horizontal': menu.mode.value === 'horizontal',\n },\n]);\n\n// ─────────────────────────────────────────────\n// Handlers\n// ─────────────────────────────────────────────\nfunction handleClick(e: MouseEvent) {\n if (disabled) return;\n\n const info: BMenuClickInfo = {\n key: itemKey,\n keyPath: keyPath.value,\n domEvent: e,\n };\n menu.onItemClick(info);\n}\n\nfunction handleKeydown(e: KeyboardEvent) {\n if (disabled) return;\n\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault();\n const info: BMenuClickInfo = {\n key: itemKey,\n keyPath: keyPath.value,\n domEvent: e,\n };\n menu.onItemClick(info);\n }\n}\n</script>\n\n<template>\n <li\n :class=\"itemClasses\"\n :style=\"{ paddingInlineStart: paddingLeft }\"\n :role=\"itemRole\"\n :tabindex=\"disabled ? -1 : 0\"\n :aria-disabled=\"disabled || undefined\"\n :aria-checked=\"menu.selectable.value ? isSelected : undefined\"\n :title=\"title ?? (menu.inlineCollapsed.value ? label : undefined)\"\n :data-menu-key=\"itemKey\"\n @click=\"handleClick\"\n @keydown=\"handleKeydown\"\n >\n <span v-if=\"icon || $slots.icon\" class=\"b-menu-item__icon\" aria-hidden=\"true\">\n <slot name=\"icon\">{{ icon }}</slot>\n </span>\n <span v-if=\"!menu.inlineCollapsed.value\" class=\"b-menu-item__label\">\n <slot>{{ label }}</slot>\n </span>\n <span v-if=\"extra && !menu.inlineCollapsed.value\" class=\"b-menu-item__extra\">\n <slot name=\"extra\">{{ extra }}</slot>\n </span>\n </li>\n</template>\n\n<style>\n/* ─────────────────────────────────────────────\n BMenuItem\n ───────────────────────────────────────────── */\n.b-menu-item {\n display: flex;\n align-items: center;\n height: var(--b-menu-item-height);\n margin-block: var(--b-menu-item-margin-block);\n margin-inline: var(--b-menu-item-margin-inline);\n padding-inline: var(--b-menu-item-padding-inline);\n border-radius: var(--b-menu-item-border-radius);\n color: var(--b-menu-item-color);\n cursor: pointer;\n user-select: none;\n list-style: none;\n outline: none;\n position: relative;\n transition:\n background var(--b-menu-transition-duration),\n color var(--b-menu-transition-duration),\n padding var(--b-menu-transition-duration);\n box-sizing: border-box;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n\n.b-menu-item:hover:not(.b-menu-item--disabled) {\n background: var(--b-menu-item-hover-bg);\n color: var(--b-menu-item-hover-color);\n}\n\n.b-menu-item:focus-visible {\n outline: 2px solid #1677ff;\n outline-offset: -2px;\n}\n\n/* ── Selected ── */\n.b-menu-item--selected {\n background: var(--b-menu-item-selected-bg);\n color: var(--b-menu-item-selected-color);\n font-weight: 500;\n}\n\n/* ── Disabled ── */\n.b-menu-item--disabled {\n color: var(--b-menu-item-disabled-color);\n cursor: not-allowed;\n}\n\n/* ── Danger ── */\n.b-menu-item--danger {\n color: var(--b-menu-danger-item-color);\n}\n\n.b-menu-item--danger:hover:not(.b-menu-item--disabled) {\n color: var(--b-menu-danger-item-hover-color);\n background: var(--b-menu-danger-item-active-bg);\n}\n\n.b-menu-item--danger.b-menu-item--selected {\n background: var(--b-menu-danger-item-selected-bg);\n color: var(--b-menu-danger-item-selected-color);\n}\n\n/* ── Collapsed ── */\n.b-menu-item--collapsed {\n justify-content: center;\n padding-inline: 0;\n}\n\n.b-menu-item--collapsed .b-menu-item__icon {\n font-size: var(--b-menu-collapsed-icon-size);\n margin-inline-end: 0;\n}\n\n/* ── Horizontal mode ── */\n.b-menu-item--horizontal {\n margin-block: 0;\n border-radius: var(--b-menu-horizontal-item-border-radius);\n height: auto;\n line-height: var(--b-menu-horizontal-line-height);\n position: relative;\n}\n\n.b-menu-item--horizontal::after {\n content: '';\n position: absolute;\n bottom: 0;\n left: var(--b-menu-item-padding-inline);\n right: var(--b-menu-item-padding-inline);\n height: var(--b-menu-active-bar-height);\n background: transparent;\n transition: background var(--b-menu-transition-duration);\n}\n\n.b-menu-item--horizontal:hover:not(.b-menu-item--disabled) {\n background: var(--b-menu-horizontal-item-hover-bg);\n color: var(--b-menu-horizontal-item-hover-color);\n}\n\n.b-menu-item--horizontal.b-menu-item--selected {\n background: var(--b-menu-horizontal-item-selected-bg);\n color: var(--b-menu-horizontal-item-selected-color);\n}\n\n.b-menu-item--horizontal.b-menu-item--selected::after {\n background: var(--b-menu-horizontal-item-selected-color);\n}\n\n/* ─────────────────────────────────────────────\n Icon & Label\n ───────────────────────────────────────────── */\n.b-menu-item__icon {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n flex-shrink: 0;\n font-size: var(--b-menu-icon-size);\n margin-inline-end: var(--b-menu-icon-margin-inline-end);\n}\n\n.b-menu-item__label {\n flex: 1;\n min-width: 0;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n\n.b-menu-item__extra {\n margin-inline-start: auto;\n padding-inline-start: 8px;\n color: var(--b-menu-group-title-color);\n font-size: 12px;\n}\n\n/* ── Reduced motion ── */\n@media (prefers-reduced-motion: reduce) {\n .b-menu-item {\n transition: none;\n }\n\n .b-menu-item--horizontal::after {\n transition: none;\n }\n}\n</style>\n"],"mappings":""}
@@ -1,12 +1,45 @@
1
- import e from "./design-system14.js";
2
- import { createElementBlock as t, openBlock as n, renderSlot as r } from "vue";
3
- //#region src/components/BModal/BModalBody.vue
4
- var i = {}, a = { class: "b:text-sm b:text-black/80" };
5
- function o(e, i) {
6
- return n(), t("div", a, [r(e.$slots, "default")]);
7
- }
8
- var s = /* @__PURE__ */ e(i, [["render", o]]);
1
+ import { BMenuContextKey as e } from "./design-system142.js";
2
+ import t from "./design-system145.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
+ });
9
42
  //#endregion
10
- export { s as default };
43
+ export { v as default };
11
44
 
12
45
  //# sourceMappingURL=design-system146.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"design-system146.js","names":[],"sources":["../src/components/BModal/BModalBody.vue"],"sourcesContent":["<template>\n <div class=\"b:text-sm b:text-black/80\">\n <slot></slot>\n </div>\n</template>\n"],"mappings":";;;kBACO,OAAM,6BAA2B;;aAAtC,EAEM,OAFN,GAEM,CADJ,EAAa,EAAA,QAAA,UAAA,CAAA,CAAA"}
1
+ {"version":3,"file":"design-system146.js","names":[],"sources":["../src/components/BMenu/BMenuItemGroup.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { inject } from 'vue';\nimport BMenuItem from './BMenuItem.vue';\nimport { BMenuContextKey, type BMenuContext, type BMenuItemType } from './types';\n\n// ─────────────────────────────────────────────\n// Props\n// ─────────────────────────────────────────────\nconst props = withDefaults(\n defineProps<{\n /** Group title label. */\n label?: string;\n /** Items within this group. */\n children?: BMenuItemType[];\n }>(),\n {\n label: '',\n children: () => [],\n },\n);\n\ndefineSlots<{\n default?(): unknown;\n title?(): unknown;\n}>();\n\nconst menu = inject<BMenuContext>(BMenuContextKey)!;\n</script>\n\n<template>\n <li class=\"b-menu-item-group\" role=\"presentation\">\n <div v-if=\"!menu.inlineCollapsed.value\" class=\"b-menu-item-group__title\" role=\"presentation\">\n <slot name=\"title\">{{ props.label }}</slot>\n </div>\n <ul class=\"b-menu-item-group__list\" role=\"group\" :aria-label=\"props.label\">\n <slot>\n <BMenuItem\n v-for=\"item in props.children\"\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 />\n </slot>\n </ul>\n </li>\n</template>\n\n<style>\n/* ─────────────────────────────────────────────\n BMenuItemGroup\n ───────────────────────────────────────────── */\n.b-menu-item-group {\n list-style: none;\n}\n\n.b-menu-item-group__title {\n padding: 8px 16px 4px;\n color: var(--b-menu-group-title-color);\n font-size: var(--b-menu-group-title-font-size);\n line-height: var(--b-menu-group-title-line-height);\n font-weight: 500;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n\n.b-menu-item-group__list {\n list-style: none;\n padding: 0;\n margin: 0;\n}\n</style>\n"],"mappings":";;;;;;;;;;;;;;;;;;EAQA,IAAM,IAAQ,GAkBR,IAAO,EAAqB,EAAgB;yBAIhD,EAkBK,MAlBL,GAkBK,CAjBS,EAAA,EAAI,CAAC,gBAAgB,QACE,EAAA,IAAA,GAAA,IADF,GAAA,EAAjC,EAEM,OAFN,GAEM,CADJ,EAA2C,EAAA,QAAA,SAAA,EAAA,QAAA,CAAA,EAAA,EAArB,EAAM,MAAK,EAAA,EAAA,CAAA,CAAA,CAAA,CAAA,GAEnC,EAaK,MAAA;GAbD,OAAM;GAA0B,MAAK;GAAS,cAAY,EAAM;MAClE,EAWO,EAAA,QAAA,WAAA,EAAA,QAAA,EAAA,EAAA,GAAA,EAVL,EASE,GAAA,MAAA,EARe,EAAM,WAAd,YADT,EASE,GAAA;GAPC,KAAK,EAAK;GACV,YAAU,EAAK;GACf,OAAO,EAAK;GACZ,MAAM,EAAK;GACX,UAAU,EAAK;GACf,QAAQ,EAAK;GACb,OAAO,EAAK"}
@@ -1,5 +1,6 @@
1
- import e from "./design-system147.js";
2
- //#region src/components/BModal/BModalFooter.vue
1
+ import e from "./design-system146.js";
2
+ /* empty css */
3
+ //#region src/components/BMenu/BMenuItemGroup.vue
3
4
  var t = e;
4
5
  //#endregion
5
6
  export { t as default };
@@ -1 +1 @@
1
- {"version":3,"file":"design-system148.js","names":[],"sources":["../src/components/BModal/BModalFooter.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { BButton } from '@/components';\n\nconst { cancelText = 'Cancel', okText = 'OK' } = defineProps<{\n /**\n * Text to display on the cancel button.\n */\n cancelText?: string;\n /**\n * If true, the cancel button will not be displayed.\n */\n hideCancel?: boolean;\n /**\n * If true, the cancel button will be disabled.\n */\n cancelDisabled?: boolean;\n /**\n * Text to display on the OK button.\n */\n okText?: string;\n /**\n * If true, the OK button will not be displayed.\n */\n hideOk?: boolean;\n /**\n * If true, the OK button will be disabled.\n */\n okDisabled?: boolean;\n}>();\n\nconst emit = defineEmits<{\n /**\n * Emitted when the cancel button is clicked.\n */\n cancel: [];\n /**\n * Emitted when the OK button is clicked.\n */\n ok: [];\n}>();\n</script>\n\n<template>\n <div class=\"b:mt-2 b:flex b:items-center b:bg-white\">\n <slot name=\"left\">\n <div class=\"b:flex-auto\"></div>\n </slot>\n\n <slot name=\"right\">\n <div class=\"b:flex b:flex-initial b:gap-x-2\">\n <BButton\n v-if=\"!hideCancel\"\n variant=\"outlined\"\n color=\"secondary\"\n autofocus\n :disabled=\"cancelDisabled\"\n @click=\"emit('cancel')\"\n >\n {{ cancelText }}\n </BButton>\n <BButton v-if=\"!hideOk\" :disabled=\"okDisabled\" @click=\"emit('ok')\">\n {{ okText }}\n </BButton>\n </div>\n </slot>\n </div>\n</template>\n"],"mappings":""}
1
+ {"version":3,"file":"design-system148.js","names":[],"sources":["../src/components/BMenu/BMenuItemGroup.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { inject } from 'vue';\nimport BMenuItem from './BMenuItem.vue';\nimport { BMenuContextKey, type BMenuContext, type BMenuItemType } from './types';\n\n// ─────────────────────────────────────────────\n// Props\n// ─────────────────────────────────────────────\nconst props = withDefaults(\n defineProps<{\n /** Group title label. */\n label?: string;\n /** Items within this group. */\n children?: BMenuItemType[];\n }>(),\n {\n label: '',\n children: () => [],\n },\n);\n\ndefineSlots<{\n default?(): unknown;\n title?(): unknown;\n}>();\n\nconst menu = inject<BMenuContext>(BMenuContextKey)!;\n</script>\n\n<template>\n <li class=\"b-menu-item-group\" role=\"presentation\">\n <div v-if=\"!menu.inlineCollapsed.value\" class=\"b-menu-item-group__title\" role=\"presentation\">\n <slot name=\"title\">{{ props.label }}</slot>\n </div>\n <ul class=\"b-menu-item-group__list\" role=\"group\" :aria-label=\"props.label\">\n <slot>\n <BMenuItem\n v-for=\"item in props.children\"\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 />\n </slot>\n </ul>\n </li>\n</template>\n\n<style>\n/* ─────────────────────────────────────────────\n BMenuItemGroup\n ───────────────────────────────────────────── */\n.b-menu-item-group {\n list-style: none;\n}\n\n.b-menu-item-group__title {\n padding: 8px 16px 4px;\n color: var(--b-menu-group-title-color);\n font-size: var(--b-menu-group-title-font-size);\n line-height: var(--b-menu-group-title-line-height);\n font-weight: 500;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n\n.b-menu-item-group__list {\n list-style: none;\n padding: 0;\n margin: 0;\n}\n</style>\n"],"mappings":""}
@@ -1,24 +1,236 @@
1
- import e from "./design-system29.js";
2
- import { createElementBlock as t, createElementVNode as n, createVNode as r, defineComponent as i, getCurrentInstance as a, openBlock as o, renderSlot as s, toDisplayString as c, unref as l } from "vue";
3
- //#region src/components/BModal/BModalHeader.vue?vue&type=script&setup=true&lang.ts
4
- var u = { class: "b:mb-2 b:flex b:items-center b:bg-white" }, d = { class: "b:flex-auto b:font-semibold" }, f = /* @__PURE__ */ i({
5
- __name: "BModalHeader",
6
- props: { title: {} },
7
- setup(i) {
8
- let f = a(), p = () => {
9
- f?.parent?.emit("update:modelValue", !1);
1
+ import e from "./design-system141.js";
2
+ import { BMenuContextKey as t, BMenuSubMenuContextKey as n, isDivider as r, isItemGroup as i, isSubMenu as a } from "./design-system142.js";
3
+ import o from "./design-system145.js";
4
+ import s from "./design-system148.js";
5
+ import { Fragment as c, computed as l, createBlock as u, createCommentVNode as d, createElementBlock as f, createElementVNode as p, createTextVNode as m, defineComponent as h, inject as g, normalizeClass as _, normalizeStyle as v, onBeforeUnmount as y, openBlock as b, provide as x, ref as S, renderList as C, renderSlot as w, resolveComponent as T, toDisplayString as E, unref as D } from "vue";
6
+ //#region src/components/BMenu/BMenuSubMenu.vue?vue&type=script&setup=true&lang.ts
7
+ var O = ["data-menu-key"], k = [
8
+ "tabindex",
9
+ "aria-expanded",
10
+ "aria-disabled"
11
+ ], A = {
12
+ key: 0,
13
+ class: "b-menu-submenu__icon",
14
+ "aria-hidden": "true"
15
+ }, j = {
16
+ key: 1,
17
+ class: "b-menu-submenu__label"
18
+ }, M = {
19
+ key: 2,
20
+ class: "b-menu-submenu__arrow",
21
+ "aria-hidden": "true"
22
+ }, N = {
23
+ class: "b-menu-submenu__inline-list",
24
+ role: "menu"
25
+ }, P = {
26
+ class: "b-menu-submenu__popup-inner",
27
+ role: "menu"
28
+ }, F = /* @__PURE__ */ h({
29
+ __name: "BMenuSubMenu",
30
+ props: {
31
+ itemKey: {},
32
+ label: { default: "" },
33
+ icon: { default: void 0 },
34
+ disabled: {
35
+ type: Boolean,
36
+ default: !1
37
+ },
38
+ children: { default: () => [] },
39
+ popupClassName: { default: "" }
40
+ },
41
+ setup(h) {
42
+ let F = h, I = g(t), L = g(n, null), R = l(() => (L?.level ?? 0) + 1), z = l(() => [...L?.keyPath ?? [], F.itemKey]);
43
+ x(n, {
44
+ level: R.value,
45
+ keyPath: z.value
46
+ });
47
+ let B = l(() => I.openKeys.value.includes(F.itemKey)), V = l(() => {
48
+ function e(t) {
49
+ for (let n of t) if ("key" in n && I.selectedKeys.value.includes(n.key) || a(n) && n.children && e(n.children) || i(n) && n.children && e(n.children)) return !0;
50
+ return !1;
51
+ }
52
+ return e(F.children);
53
+ }), H = l(() => {
54
+ if (I.mode.value === "inline" && !I.inlineCollapsed.value) return `${R.value * I.inlineIndent.value}px`;
55
+ }), U = l(() => I.mode.value !== "inline" || I.inlineCollapsed.value), W = S(null), G = S(null), K = null, q = null;
56
+ function J() {
57
+ K &&= (clearTimeout(K), null), q &&= (clearTimeout(q), null);
58
+ }
59
+ function Y() {
60
+ F.disabled || I.onOpenChange(F.itemKey, !B.value);
61
+ }
62
+ function X() {
63
+ F.disabled || (U.value ? I.triggerSubMenuAction.value === "click" && Y() : Y());
64
+ }
65
+ function Z(e) {
66
+ if (!F.disabled) switch (e.key) {
67
+ case "Enter":
68
+ case " ":
69
+ e.preventDefault(), Y();
70
+ break;
71
+ case "ArrowRight":
72
+ I.mode.value !== "inline" && !B.value && (e.preventDefault(), I.onOpenChange(F.itemKey, !0));
73
+ break;
74
+ case "ArrowLeft":
75
+ I.mode.value !== "inline" && B.value && (e.preventDefault(), I.onOpenChange(F.itemKey, !1));
76
+ break;
77
+ case "Escape":
78
+ B.value && (e.preventDefault(), I.onOpenChange(F.itemKey, !1), W.value?.focus());
79
+ break;
80
+ }
81
+ }
82
+ function Q() {
83
+ if (F.disabled || !U.value || I.triggerSubMenuAction.value !== "hover") return;
84
+ J();
85
+ let e = I.subMenuOpenDelay.value;
86
+ e > 0 ? K = setTimeout(() => I.onOpenChange(F.itemKey, !0), e) : I.onOpenChange(F.itemKey, !0);
87
+ }
88
+ function $() {
89
+ if (F.disabled || !U.value || I.triggerSubMenuAction.value !== "hover") return;
90
+ J();
91
+ let e = I.subMenuCloseDelay.value;
92
+ e > 0 ? q = setTimeout(() => I.onOpenChange(F.itemKey, !1), e) : I.onOpenChange(F.itemKey, !1);
93
+ }
94
+ y(() => {
95
+ J();
96
+ });
97
+ let ee = l(() => ["b-menu-submenu__title", {
98
+ "b-menu-submenu__title--open": B.value,
99
+ "b-menu-submenu__title--disabled": F.disabled,
100
+ "b-menu-submenu__title--selected": V.value,
101
+ "b-menu-submenu__title--horizontal": I.mode.value === "horizontal"
102
+ }]), te = l(() => ["b-menu-submenu", {
103
+ "b-menu-submenu--open": B.value,
104
+ "b-menu-submenu--disabled": F.disabled,
105
+ "b-menu-submenu--horizontal": I.mode.value === "horizontal",
106
+ "b-menu-submenu--collapsed": I.inlineCollapsed.value,
107
+ "b-menu-submenu--popup": U.value
108
+ }]), ne = l(() => [
109
+ "b-menu-submenu__popup",
110
+ F.popupClassName,
111
+ {
112
+ "b-menu-submenu__popup--visible": B.value,
113
+ "b-menu-submenu__popup--horizontal": I.mode.value === "horizontal",
114
+ "b-menu-submenu__popup--vertical": I.mode.value === "vertical" || I.inlineCollapsed.value
115
+ }
116
+ ]), re = l(() => ["b-menu-submenu__inline", { "b-menu-submenu__inline--open": B.value }]);
117
+ return (t, n) => {
118
+ let l = T("BMenuSubMenu", !0);
119
+ return b(), f("li", {
120
+ class: _(te.value),
121
+ "data-menu-key": F.itemKey,
122
+ role: "none",
123
+ onMouseenter: Q,
124
+ onMouseleave: $
125
+ }, [
126
+ p("div", {
127
+ ref_key: "titleRef",
128
+ ref: W,
129
+ class: _(ee.value),
130
+ style: v({ paddingInlineStart: H.value }),
131
+ role: "menuitem",
132
+ tabindex: F.disabled ? -1 : 0,
133
+ "aria-haspopup": !0,
134
+ "aria-expanded": B.value,
135
+ "aria-disabled": F.disabled || void 0,
136
+ onClick: X,
137
+ onKeydown: Z
138
+ }, [
139
+ F.icon || t.$slots.icon ? (b(), f("span", A, [w(t.$slots, "icon", {}, () => [m(E(F.icon), 1)])])) : d("", !0),
140
+ D(I).inlineCollapsed.value ? d("", !0) : (b(), f("span", j, [w(t.$slots, "title", {}, () => [m(E(F.label), 1)])])),
141
+ D(I).inlineCollapsed.value ? d("", !0) : (b(), f("span", M))
142
+ ], 46, k),
143
+ U.value ? d("", !0) : (b(), f("div", {
144
+ key: 0,
145
+ class: _(re.value),
146
+ role: "none"
147
+ }, [p("ul", N, [w(t.$slots, "default", {}, () => [(b(!0), f(c, null, C(F.children, (t) => (b(), f(c, { key: t.key ?? t.type }, [D(r)(t) ? (b(), u(e, {
148
+ key: 0,
149
+ dashed: t.dashed
150
+ }, null, 8, ["dashed"])) : D(i)(t) ? (b(), u(s, {
151
+ key: 1,
152
+ label: t.label,
153
+ children: t.children
154
+ }, null, 8, ["label", "children"])) : D(a)(t) ? (b(), u(l, {
155
+ key: 2,
156
+ "item-key": t.key,
157
+ label: t.label,
158
+ icon: t.icon,
159
+ disabled: t.disabled,
160
+ children: t.children,
161
+ "popup-class-name": t.popupClassName
162
+ }, null, 8, [
163
+ "item-key",
164
+ "label",
165
+ "icon",
166
+ "disabled",
167
+ "children",
168
+ "popup-class-name"
169
+ ])) : (b(), u(o, {
170
+ key: 3,
171
+ "item-key": t.key,
172
+ label: t.label,
173
+ icon: t.icon,
174
+ disabled: t.disabled,
175
+ danger: t.danger,
176
+ extra: t.extra
177
+ }, null, 8, [
178
+ "item-key",
179
+ "label",
180
+ "icon",
181
+ "disabled",
182
+ "danger",
183
+ "extra"
184
+ ]))], 64))), 128))])])], 2)),
185
+ U.value ? (b(), f("div", {
186
+ key: 1,
187
+ ref_key: "popupRef",
188
+ ref: G,
189
+ class: _(ne.value),
190
+ role: "none"
191
+ }, [p("ul", P, [w(t.$slots, "default", {}, () => [(b(!0), f(c, null, C(F.children, (t) => (b(), f(c, { key: t.key ?? t.type }, [D(r)(t) ? (b(), u(e, {
192
+ key: 0,
193
+ dashed: t.dashed
194
+ }, null, 8, ["dashed"])) : D(i)(t) ? (b(), u(s, {
195
+ key: 1,
196
+ label: t.label,
197
+ children: t.children
198
+ }, null, 8, ["label", "children"])) : D(a)(t) ? (b(), u(l, {
199
+ key: 2,
200
+ "item-key": t.key,
201
+ label: t.label,
202
+ icon: t.icon,
203
+ disabled: t.disabled,
204
+ children: t.children,
205
+ "popup-class-name": t.popupClassName
206
+ }, null, 8, [
207
+ "item-key",
208
+ "label",
209
+ "icon",
210
+ "disabled",
211
+ "children",
212
+ "popup-class-name"
213
+ ])) : (b(), u(o, {
214
+ key: 3,
215
+ "item-key": t.key,
216
+ label: t.label,
217
+ icon: t.icon,
218
+ disabled: t.disabled,
219
+ danger: t.danger,
220
+ extra: t.extra
221
+ }, null, 8, [
222
+ "item-key",
223
+ "label",
224
+ "icon",
225
+ "disabled",
226
+ "danger",
227
+ "extra"
228
+ ]))], 64))), 128))])])], 2)) : d("", !0)
229
+ ], 42, O);
10
230
  };
11
- return (a, f) => (o(), t("div", u, [s(a.$slots, "title", {}, () => [n("h2", d, c(i.title), 1)]), s(a.$slots, "icon", {}, () => [r(l(e), {
12
- variant: "text",
13
- color: "secondary",
14
- "prepend-icon": "xmark",
15
- "prepend-icon-size": "md",
16
- autofocus: "",
17
- onClick: p
18
- })])]));
19
231
  }
20
232
  });
21
233
  //#endregion
22
- export { f as default };
234
+ export { F as default };
23
235
 
24
236
  //# sourceMappingURL=design-system149.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"design-system149.js","names":[],"sources":["../src/components/BModal/BModalHeader.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { BButton } from '@/components';\nimport { getCurrentInstance } from 'vue';\n\nconst { title } = defineProps<{\n title?: string;\n}>();\n\nconst instance = getCurrentInstance();\n\nconst close = () => {\n instance?.parent?.emit('update:modelValue', false);\n};\n</script>\n\n<template>\n <div class=\"b:mb-2 b:flex b:items-center b:bg-white\">\n <slot name=\"title\">\n <h2 class=\"b:flex-auto b:font-semibold\">\n {{ title }}\n </h2>\n </slot>\n <slot name=\"icon\">\n <BButton\n variant=\"text\"\n color=\"secondary\"\n prepend-icon=\"xmark\"\n prepend-icon-size=\"md\"\n autofocus\n @click=\"close\"\n />\n </slot>\n </div>\n</template>\n"],"mappings":";;;;;;;EAQA,IAAM,IAAW,GAAoB,EAE/B,UAAc;AAClB,MAAU,QAAQ,KAAK,qBAAqB,GAAM;;yBAKlD,EAgBM,OAhBN,GAgBM,CAfJ,EAIO,EAAA,QAAA,SAAA,EAAA,QAAA,CAHL,EAEK,MAFL,GAEK,EADA,EAAA,MAAK,EAAA,EAAA,CAAA,CAAA,EAGZ,EASO,EAAA,QAAA,QAAA,EAAA,QAAA,CARL,EAOE,EAAA,EAAA,EAAA;GANA,SAAQ;GACR,OAAM;GACN,gBAAa;GACb,qBAAkB;GAClB,WAAA;GACC,SAAO"}
1
+ {"version":3,"file":"design-system149.js","names":["$slots"],"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":"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"}
@@ -1,161 +1,8 @@
1
- import { BNotificationPlacement as e, BNotificationType as t } from "./design-system3.js";
2
- import { Teleport as n, Transition as r, computed as i, createBlock as a, createCommentVNode as o, createElementBlock as s, createElementVNode as c, createTextVNode as l, createVNode as u, defineComponent as d, nextTick as f, normalizeClass as p, onUnmounted as m, openBlock as h, ref as g, renderSlot as _, toDisplayString as v, unref as y, useId as b, watch as x, withCtx as S } from "vue";
3
- //#region src/components/BNotification/BNotification.vue?vue&type=script&setup=true&lang.ts
4
- var C = [
5
- "id",
6
- "role",
7
- "aria-live",
8
- "aria-describedby"
9
- ], w = {
10
- key: 0,
11
- class: "b-notification__icon",
12
- "aria-hidden": "true"
13
- }, T = ["innerHTML"], E = {
14
- key: 1,
15
- class: "b-notification__icon-svg",
16
- viewBox: "0 0 24 24",
17
- xmlns: "http://www.w3.org/2000/svg",
18
- focusable: "false",
19
- "aria-hidden": "true"
20
- }, D = ["d"], O = { class: "b-notification__body" }, k = {
21
- key: 1,
22
- class: "b-notification__btn"
23
- }, A = ["innerHTML"], j = {
24
- key: 1,
25
- class: "b-notification__close-svg",
26
- viewBox: "0 0 24 24",
27
- xmlns: "http://www.w3.org/2000/svg",
28
- focusable: "false",
29
- "aria-hidden": "true"
30
- }, M = "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 = /* @__PURE__ */ d({
31
- __name: "BNotification",
32
- props: {
33
- type: { default: () => void 0 },
34
- message: { default: "" },
35
- description: { default: "" },
36
- placement: { default: () => e.TopRight },
37
- duration: { default: 4.5 },
38
- closable: {
39
- type: Boolean,
40
- default: !0
41
- },
42
- showIcon: {
43
- type: Boolean,
44
- default: !0
45
- },
46
- icon: {},
47
- closeIcon: {},
48
- btn: {},
49
- modelValue: {
50
- type: Boolean,
51
- default: () => void 0
52
- }
53
- },
54
- emits: [
55
- "close",
56
- "afterClose",
57
- "update:modelValue"
58
- ],
59
- setup(e, { expose: d, emit: N }) {
60
- let P = N, F = b(), I = `${F}-title`, L = `${F}-desc`, R = g(!1), z = g(null), B = g(null), V = i(() => e.modelValue === void 0 ? R.value : e.modelValue), H = i(() => e.modelValue !== void 0), U = i(() => e.type === t.Error || e.type === t.Warning ? "alert" : "status"), W = i(() => U.value === "alert" ? "assertive" : "polite"), G = i(() => !!(e.type && e.showIcon) || !!e.icon || !1), K = i(() => !!e.description), q = i(() => {
61
- switch (e.type) {
62
- case t.Success: 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";
63
- case t.Warning: return "M1 21h22L12 2 1 21zm12-3h-2v-2h2v2zm0-4h-2v-4h2v4z";
64
- case t.Error: 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";
65
- default: 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";
66
- }
67
- }), J = null;
68
- function Y() {
69
- X(), e.duration > 0 && (J = setTimeout(() => {
70
- Q();
71
- }, e.duration * 1e3));
72
- }
73
- function X() {
74
- J !== null && (clearTimeout(J), J = null);
75
- }
76
- function Z() {
77
- H.value ? P("update:modelValue", !0) : R.value = !0;
78
- }
79
- function Q() {
80
- P("close"), H.value ? P("update:modelValue", !1) : R.value = !1;
81
- }
82
- function $() {
83
- B.value && document.contains(B.value) && (B.value.focus(), B.value = null), P("afterClose");
84
- }
85
- function ee() {
86
- X();
87
- }
88
- function te() {
89
- Y();
90
- }
91
- function ne(t) {
92
- t.key === "Escape" && e.closable && (t.stopPropagation(), Q());
93
- }
94
- return x(V, async (t) => {
95
- t ? (B.value = document.activeElement, Y(), e.closable && (await f(), (z.value?.querySelector(".b-notification__close"))?.focus())) : X();
96
- }, { immediate: !0 }), m(() => {
97
- X();
98
- }), d({
99
- open: Z,
100
- close: Q
101
- }), (t, i) => (h(), a(n, { to: "body" }, [u(r, {
102
- name: "b-notification-fade",
103
- onAfterLeave: $
104
- }, {
105
- default: S(() => [V.value ? (h(), s("div", {
106
- key: 0,
107
- id: y(F),
108
- ref_key: "notificationRef",
109
- ref: z,
110
- class: p(["b-notification", [
111
- e.placement && `b-notification--${e.placement}`,
112
- e.type && `b-notification--${e.type}`,
113
- {
114
- "b-notification--with-icon": G.value,
115
- "b-notification--with-description": K.value
116
- }
117
- ]]),
118
- role: U.value,
119
- "aria-live": W.value,
120
- "aria-atomic": !0,
121
- "aria-labelledby": I,
122
- "aria-describedby": K.value ? L : void 0,
123
- onMouseenter: ee,
124
- onMouseleave: te,
125
- onKeydown: ne
126
- }, [
127
- G.value ? (h(), s("span", w, [_(t.$slots, "icon", {}, () => [e.icon ? (h(), s("span", {
128
- key: 0,
129
- innerHTML: e.icon
130
- }, null, 8, T)) : e.type ? (h(), s("svg", E, [c("path", { d: q.value }, null, 8, D)])) : o("", !0)])])) : o("", !0),
131
- c("div", O, [
132
- c("div", {
133
- id: I,
134
- class: "b-notification__message"
135
- }, [_(t.$slots, "message", {}, () => [l(v(e.message), 1)])]),
136
- K.value || t.$slots.description ? (h(), s("div", {
137
- key: 0,
138
- id: L,
139
- class: "b-notification__description"
140
- }, [_(t.$slots, "description", {}, () => [l(v(e.description), 1)])])) : o("", !0),
141
- e.btn || t.$slots.btn ? (h(), s("div", k, [_(t.$slots, "btn", {}, () => [l(v(e.btn), 1)])])) : o("", !0)
142
- ]),
143
- e.closable ? (h(), s("button", {
144
- key: 1,
145
- type: "button",
146
- class: "b-notification__close",
147
- "aria-label": "Close notification",
148
- onClick: Q
149
- }, [_(t.$slots, "closeIcon", {}, () => [e.closeIcon ? (h(), s("span", {
150
- key: 0,
151
- innerHTML: e.closeIcon
152
- }, null, 8, A)) : (h(), s("svg", j, [c("path", { d: M })]))])])) : o("", !0)
153
- ], 42, C)) : o("", !0)]),
154
- _: 3
155
- })]));
156
- }
157
- });
1
+ import e from "./design-system149.js";
2
+ /* empty css */
3
+ //#region src/components/BMenu/BMenuSubMenu.vue
4
+ var t = e;
158
5
  //#endregion
159
- export { N as default };
6
+ export { t as default };
160
7
 
161
8
  //# sourceMappingURL=design-system151.js.map