@7pmlabs/design-system 1.0.10 → 2.0.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 (429) hide show
  1. package/README.md +57 -6
  2. package/dist/design-system.css +1 -1
  3. package/dist/design-system.js +66 -60
  4. package/dist/design-system100.js +4 -5
  5. package/dist/design-system100.js.map +1 -1
  6. package/dist/design-system101.js +53 -506
  7. package/dist/design-system101.js.map +1 -1
  8. package/dist/{design-system93.js → design-system102.js} +1 -1
  9. package/dist/design-system102.js.map +1 -0
  10. package/dist/design-system103.js +13 -5
  11. package/dist/design-system103.js.map +1 -1
  12. package/dist/design-system104.js +109 -7
  13. package/dist/design-system104.js.map +1 -1
  14. package/dist/design-system106.js +9 -0
  15. package/dist/design-system106.js.map +1 -0
  16. package/dist/design-system107.js +206 -6
  17. package/dist/design-system107.js.map +1 -1
  18. package/dist/design-system109.js +9 -0
  19. package/dist/design-system109.js.map +1 -0
  20. package/dist/design-system110.js +507 -6
  21. package/dist/design-system110.js.map +1 -1
  22. package/dist/design-system112.js +8 -0
  23. package/dist/design-system112.js.map +1 -0
  24. package/dist/design-system113.js +7 -5
  25. package/dist/design-system113.js.map +1 -1
  26. package/dist/design-system114.js +209 -9
  27. package/dist/design-system114.js.map +1 -1
  28. package/dist/design-system116.js +9 -0
  29. package/dist/design-system116.js.map +1 -0
  30. package/dist/design-system117.js +224 -6
  31. package/dist/design-system117.js.map +1 -1
  32. package/dist/design-system119.js +9 -0
  33. package/dist/design-system119.js.map +1 -0
  34. package/dist/design-system12.js.map +1 -1
  35. package/dist/design-system120.js +163 -5
  36. package/dist/design-system120.js.map +1 -1
  37. package/dist/design-system122.js +5 -90
  38. package/dist/design-system122.js.map +1 -1
  39. package/dist/design-system123.js +12 -0
  40. package/dist/design-system123.js.map +1 -0
  41. package/dist/design-system124.js +274 -5
  42. package/dist/design-system124.js.map +1 -1
  43. package/dist/design-system126.js +9 -0
  44. package/dist/design-system126.js.map +1 -0
  45. package/dist/design-system127.js +16 -5
  46. package/dist/design-system127.js.map +1 -1
  47. package/dist/design-system129.js +8 -0
  48. package/dist/design-system129.js.map +1 -0
  49. package/dist/design-system130.js +12 -5
  50. package/dist/design-system130.js.map +1 -1
  51. package/dist/design-system131.js +76 -137
  52. package/dist/design-system131.js.map +1 -1
  53. package/dist/design-system133.js +1 -1
  54. package/dist/design-system133.js.map +1 -1
  55. package/dist/design-system134.js +37 -90
  56. package/dist/design-system134.js.map +1 -1
  57. package/dist/design-system136.js +1 -1
  58. package/dist/design-system136.js.map +1 -1
  59. package/dist/design-system137.js +226 -20
  60. package/dist/design-system137.js.map +1 -1
  61. package/dist/design-system139.js +4 -5
  62. package/dist/design-system139.js.map +1 -1
  63. package/dist/design-system140.js +151 -9
  64. package/dist/design-system140.js.map +1 -1
  65. package/dist/design-system142.js +3 -2
  66. package/dist/design-system142.js.map +1 -1
  67. package/dist/design-system143.js +93 -19
  68. package/dist/design-system143.js.map +1 -1
  69. package/dist/design-system145.js +5 -158
  70. package/dist/design-system145.js.map +1 -1
  71. package/dist/design-system146.js +12 -0
  72. package/dist/design-system146.js.map +1 -0
  73. package/dist/design-system147.js +37 -5
  74. package/dist/design-system147.js.map +1 -1
  75. package/dist/design-system148.js +4 -307
  76. package/dist/design-system148.js.map +1 -1
  77. package/dist/design-system149.js +24 -0
  78. package/dist/{design-system144.js.map → design-system149.js.map} +1 -1
  79. package/dist/design-system150.js +2 -3
  80. package/dist/design-system150.js.map +1 -1
  81. package/dist/design-system151.js +131 -213
  82. package/dist/design-system151.js.map +1 -1
  83. package/dist/design-system153.js +1 -1
  84. package/dist/design-system153.js.map +1 -1
  85. package/dist/design-system154.js +278 -160
  86. package/dist/design-system154.js.map +1 -1
  87. package/dist/design-system156.js +1 -1
  88. package/dist/design-system156.js.map +1 -1
  89. package/dist/design-system157.js +240 -3
  90. package/dist/design-system157.js.map +1 -1
  91. package/dist/design-system159.js +8 -0
  92. package/dist/design-system159.js.map +1 -0
  93. package/dist/design-system16.js.map +1 -1
  94. package/dist/design-system160.js +189 -6
  95. package/dist/design-system160.js.map +1 -1
  96. package/dist/design-system162.js +8 -0
  97. package/dist/design-system162.js.map +1 -0
  98. package/dist/design-system163.js +3 -6
  99. package/dist/design-system163.js.map +1 -1
  100. package/dist/design-system164.js +46 -57
  101. package/dist/design-system164.js.map +1 -1
  102. package/dist/design-system166.js +2 -2
  103. package/dist/design-system166.js.map +1 -1
  104. package/dist/design-system167.js +44 -170
  105. package/dist/design-system167.js.map +1 -1
  106. package/dist/design-system169.js +2 -2
  107. package/dist/design-system169.js.map +1 -1
  108. package/dist/design-system170.js +55 -101
  109. package/dist/design-system170.js.map +1 -1
  110. package/dist/design-system172.js +5 -4
  111. package/dist/design-system172.js.map +1 -1
  112. package/dist/design-system173.js +182 -11
  113. package/dist/design-system173.js.map +1 -1
  114. package/dist/design-system175.js +9 -0
  115. package/dist/design-system175.js.map +1 -0
  116. package/dist/design-system176.js +115 -6
  117. package/dist/design-system176.js.map +1 -1
  118. package/dist/design-system178.js +8 -0
  119. package/dist/design-system178.js.map +1 -0
  120. package/dist/design-system179.js +11 -5
  121. package/dist/design-system179.js.map +1 -1
  122. package/dist/design-system180.js +444 -70
  123. package/dist/design-system180.js.map +1 -1
  124. package/dist/design-system182.js +5 -4
  125. package/dist/design-system182.js.map +1 -1
  126. package/dist/design-system183.js +21 -21
  127. package/dist/design-system183.js.map +1 -1
  128. package/dist/design-system185.js +1 -1
  129. package/dist/design-system185.js.map +1 -1
  130. package/dist/design-system186.js +85 -25
  131. package/dist/design-system186.js.map +1 -1
  132. package/dist/design-system188.js +1 -1
  133. package/dist/design-system188.js.map +1 -1
  134. package/dist/design-system189.js +7 -5
  135. package/dist/design-system189.js.map +1 -1
  136. package/dist/design-system19.js.map +1 -1
  137. package/dist/design-system191.js +1 -1
  138. package/dist/design-system191.js.map +1 -1
  139. package/dist/design-system192.js +20 -23
  140. package/dist/design-system192.js.map +1 -1
  141. package/dist/design-system194.js +1 -1
  142. package/dist/design-system194.js.map +1 -1
  143. package/dist/design-system195.js +24 -323
  144. package/dist/design-system195.js.map +1 -1
  145. package/dist/design-system197.js +1 -1
  146. package/dist/design-system197.js.map +1 -1
  147. package/dist/design-system198.js +19 -88
  148. package/dist/design-system198.js.map +1 -1
  149. package/dist/design-system200.js +1 -1
  150. package/dist/design-system200.js.map +1 -1
  151. package/dist/design-system201.js +330 -17
  152. package/dist/design-system201.js.map +1 -1
  153. package/dist/design-system203.js +5 -3
  154. package/dist/design-system203.js.map +1 -1
  155. package/dist/design-system204.js +88 -407
  156. package/dist/design-system204.js.map +1 -1
  157. package/dist/design-system206.js +1 -1
  158. package/dist/design-system206.js.map +1 -1
  159. package/dist/design-system207.js +17 -106
  160. package/dist/design-system207.js.map +1 -1
  161. package/dist/{design-system202.js → design-system208.js} +2 -2
  162. package/dist/{design-system202.js.map → design-system208.js.map} +1 -1
  163. package/dist/design-system209.js +3 -6
  164. package/dist/design-system209.js.map +1 -1
  165. package/dist/design-system210.js +403 -90
  166. package/dist/design-system210.js.map +1 -1
  167. package/dist/design-system212.js +4 -5
  168. package/dist/design-system212.js.map +1 -1
  169. package/dist/design-system213.js +45 -723
  170. package/dist/design-system213.js.map +1 -1
  171. package/dist/design-system215.js +1 -1
  172. package/dist/design-system215.js.map +1 -1
  173. package/dist/design-system216.js +88 -11
  174. package/dist/design-system216.js.map +1 -1
  175. package/dist/design-system217.js +4 -525
  176. package/dist/design-system217.js.map +1 -1
  177. package/dist/design-system218.js +111 -0
  178. package/dist/design-system218.js.map +1 -0
  179. package/dist/design-system22.js.map +1 -1
  180. package/dist/design-system220.js +6 -3
  181. package/dist/design-system220.js.map +1 -1
  182. package/dist/design-system221.js +103 -43
  183. package/dist/design-system221.js.map +1 -1
  184. package/dist/design-system223.js +6 -283
  185. package/dist/design-system223.js.map +1 -1
  186. package/dist/design-system224.js +740 -0
  187. package/dist/design-system224.js.map +1 -0
  188. package/dist/design-system226.js +5 -119
  189. package/dist/design-system226.js.map +1 -1
  190. package/dist/{design-system60.js → design-system227.js} +6 -8
  191. package/dist/design-system227.js.map +1 -0
  192. package/dist/design-system228.js +525 -5
  193. package/dist/design-system228.js.map +1 -1
  194. package/dist/{design-system219.js → design-system230.js} +2 -2
  195. package/dist/{design-system219.js.map → design-system230.js.map} +1 -1
  196. package/dist/design-system231.js +3 -5
  197. package/dist/design-system231.js.map +1 -1
  198. package/dist/design-system232.js +42 -50
  199. package/dist/design-system232.js.map +1 -1
  200. package/dist/design-system233.js +1 -1
  201. package/dist/design-system233.js.map +1 -1
  202. package/dist/design-system234.js +254 -141
  203. package/dist/design-system234.js.map +1 -1
  204. package/dist/design-system236.js +1 -1
  205. package/dist/design-system236.js.map +1 -1
  206. package/dist/design-system237.js +119 -7
  207. package/dist/design-system237.js.map +1 -1
  208. package/dist/design-system239.js +8 -0
  209. package/dist/design-system239.js.map +1 -0
  210. package/dist/design-system240.js +112 -5
  211. package/dist/design-system240.js.map +1 -1
  212. package/dist/design-system242.js +8 -0
  213. package/dist/design-system242.js.map +1 -0
  214. package/dist/design-system243.js +54 -6
  215. package/dist/design-system243.js.map +1 -1
  216. package/dist/design-system244.js +4 -7
  217. package/dist/design-system244.js.map +1 -1
  218. package/dist/design-system245.js +139 -343
  219. package/dist/design-system245.js.map +1 -1
  220. package/dist/design-system247.js +4 -5
  221. package/dist/design-system247.js.map +1 -1
  222. package/dist/design-system248.js +10 -0
  223. package/dist/design-system248.js.map +1 -0
  224. package/dist/{design-system238.js → design-system249.js} +2 -2
  225. package/dist/design-system249.js.map +1 -0
  226. package/dist/design-system25.js.map +1 -1
  227. package/dist/design-system251.js +8 -0
  228. package/dist/design-system251.js.map +1 -0
  229. package/dist/{design-system241.js → design-system252.js} +1 -1
  230. package/dist/design-system252.js.map +1 -0
  231. package/dist/design-system254.js +9 -0
  232. package/dist/design-system254.js.map +1 -0
  233. package/dist/design-system255.js +12 -0
  234. package/dist/design-system255.js.map +1 -0
  235. package/dist/design-system256.js +769 -0
  236. package/dist/design-system256.js.map +1 -0
  237. package/dist/design-system258.js +9 -0
  238. package/dist/design-system258.js.map +1 -0
  239. package/dist/design-system259.js +10 -0
  240. package/dist/design-system259.js.map +1 -0
  241. package/dist/design-system260.js +377 -0
  242. package/dist/design-system260.js.map +1 -0
  243. package/dist/design-system262.js +9 -0
  244. package/dist/design-system262.js.map +1 -0
  245. package/dist/design-system28.js.map +1 -1
  246. package/dist/design-system3.js.map +1 -1
  247. package/dist/design-system30.js +21 -138
  248. package/dist/design-system30.js.map +1 -1
  249. package/dist/design-system32.js +5 -4
  250. package/dist/design-system32.js.map +1 -1
  251. package/dist/design-system33.js +488 -14
  252. package/dist/design-system33.js.map +1 -1
  253. package/dist/design-system35.js +1 -1
  254. package/dist/design-system35.js.map +1 -1
  255. package/dist/design-system36.js +135 -17
  256. package/dist/design-system36.js.map +1 -1
  257. package/dist/design-system38.js +1 -1
  258. package/dist/design-system38.js.map +1 -1
  259. package/dist/design-system39.js +16 -11
  260. package/dist/design-system39.js.map +1 -1
  261. package/dist/design-system4.js.map +1 -1
  262. package/dist/design-system41.js +8 -0
  263. package/dist/design-system41.js.map +1 -0
  264. package/dist/design-system42.js +26 -5
  265. package/dist/design-system42.js.map +1 -1
  266. package/dist/design-system44.js +5 -71
  267. package/dist/design-system44.js.map +1 -1
  268. package/dist/design-system45.js +353 -0
  269. package/dist/design-system45.js.map +1 -0
  270. package/dist/design-system47.js +5 -50
  271. package/dist/design-system47.js.map +1 -1
  272. package/dist/design-system48.js +11 -4
  273. package/dist/design-system48.js.map +1 -1
  274. package/dist/design-system49.js +476 -3
  275. package/dist/design-system49.js.map +1 -1
  276. package/dist/design-system51.js +8 -0
  277. package/dist/design-system51.js.map +1 -0
  278. package/dist/design-system52.js +3 -5
  279. package/dist/design-system52.js.map +1 -1
  280. package/dist/design-system53.js +56 -83
  281. package/dist/design-system53.js.map +1 -1
  282. package/dist/design-system55.js +5 -4
  283. package/dist/design-system55.js.map +1 -1
  284. package/dist/design-system56.js +50 -11
  285. package/dist/design-system56.js.map +1 -1
  286. package/dist/design-system57.js +4 -591
  287. package/dist/design-system57.js.map +1 -1
  288. package/dist/design-system58.js +6 -0
  289. package/dist/design-system58.js.map +1 -0
  290. package/dist/design-system59.js +64 -5
  291. package/dist/design-system59.js.map +1 -1
  292. package/dist/design-system61.js +5 -696
  293. package/dist/design-system61.js.map +1 -1
  294. package/dist/design-system62.js +101 -0
  295. package/dist/design-system62.js.map +1 -0
  296. package/dist/design-system64.js +5 -158
  297. package/dist/design-system64.js.map +1 -1
  298. package/dist/design-system65.js +14 -0
  299. package/dist/design-system65.js.map +1 -0
  300. package/dist/design-system66.js +591 -5
  301. package/dist/design-system66.js.map +1 -1
  302. package/dist/design-system68.js +3 -2
  303. package/dist/design-system68.js.map +1 -1
  304. package/dist/design-system69.js +13 -49
  305. package/dist/design-system69.js.map +1 -1
  306. package/dist/design-system7.js.map +1 -1
  307. package/dist/design-system70.js +699 -0
  308. package/dist/{design-system63.js.map → design-system70.js.map} +1 -1
  309. package/dist/design-system72.js +5 -199
  310. package/dist/design-system72.js.map +1 -1
  311. package/dist/design-system73.js +161 -0
  312. package/dist/design-system73.js.map +1 -0
  313. package/dist/design-system75.js +5 -7
  314. package/dist/design-system75.js.map +1 -1
  315. package/dist/design-system76.js +25 -269
  316. package/dist/design-system76.js.map +1 -1
  317. package/dist/design-system77.js +7 -0
  318. package/dist/design-system77.js.map +1 -0
  319. package/dist/design-system78.js +49 -5
  320. package/dist/design-system78.js.map +1 -1
  321. package/dist/{design-system71.js → design-system80.js} +2 -2
  322. package/dist/{design-system71.js.map → design-system80.js.map} +1 -1
  323. package/dist/design-system81.js +199 -5
  324. package/dist/design-system81.js.map +1 -1
  325. package/dist/design-system83.js +5 -99
  326. package/dist/design-system83.js.map +1 -1
  327. package/dist/design-system84.js +10 -0
  328. package/dist/design-system84.js.map +1 -0
  329. package/dist/design-system85.js +273 -5
  330. package/dist/design-system85.js.map +1 -1
  331. package/dist/design-system87.js +8 -0
  332. package/dist/design-system87.js.map +1 -0
  333. package/dist/design-system88.js +57 -5
  334. package/dist/design-system88.js.map +1 -1
  335. package/dist/design-system90.js +8 -0
  336. package/dist/design-system90.js.map +1 -0
  337. package/dist/design-system91.js +11 -5
  338. package/dist/design-system91.js.map +1 -1
  339. package/dist/design-system92.js +98 -53
  340. package/dist/design-system92.js.map +1 -1
  341. package/dist/design-system94.js +5 -13
  342. package/dist/design-system94.js.map +1 -1
  343. package/dist/design-system95.js +61 -104
  344. package/dist/design-system95.js.map +1 -1
  345. package/dist/design-system97.js +4 -5
  346. package/dist/design-system97.js.map +1 -1
  347. package/dist/design-system98.js +80 -198
  348. package/dist/design-system98.js.map +1 -1
  349. package/dist/types/components/BCalendar/BCalendar.spec.d.ts +1 -0
  350. package/dist/types/components/BCalendar/BCalendar.vue.d.ts +114 -0
  351. package/dist/types/components/BCalendar/index.d.ts +2 -0
  352. package/dist/types/components/BCalendar/types.d.ts +54 -0
  353. package/dist/types/components/BCarousel/BCarousel.spec.d.ts +1 -0
  354. package/dist/types/components/BCarousel/BCarousel.vue.d.ts +133 -0
  355. package/dist/types/components/BCarousel/index.d.ts +2 -0
  356. package/dist/types/components/BCarousel/types.d.ts +15 -0
  357. package/dist/types/components/BDivider/types.d.ts +2 -2
  358. package/dist/types/components/BMasonry/types.d.ts +2 -2
  359. package/dist/types/components/BPagination/BPagination.vue.d.ts +1 -1
  360. package/dist/types/components/BStatistic/BStatistic.spec.d.ts +1 -0
  361. package/dist/types/components/BStatistic/BStatistic.vue.d.ts +44 -0
  362. package/dist/types/components/BStatistic/BStatisticTimer.vue.d.ts +50 -0
  363. package/dist/types/components/BStatistic/index.d.ts +3 -0
  364. package/dist/types/components/BStatistic/types.d.ts +6 -0
  365. package/dist/types/components/BTreeSelect/BTreeSelect.spec.d.ts +1 -0
  366. package/dist/types/components/BTreeSelect/BTreeSelect.vue.d.ts +143 -0
  367. package/dist/types/components/BTreeSelect/index.d.ts +2 -0
  368. package/dist/types/components/BTreeSelect/types.d.ts +77 -0
  369. package/dist/types/components/index.d.ts +4 -0
  370. package/dist/types/types.d.ts +3 -0
  371. package/package.json +18 -15
  372. package/dist/design-system105.js +0 -212
  373. package/dist/design-system105.js.map +0 -1
  374. package/dist/design-system108.js +0 -227
  375. package/dist/design-system108.js.map +0 -1
  376. package/dist/design-system111.js +0 -166
  377. package/dist/design-system111.js.map +0 -1
  378. package/dist/design-system115.js +0 -277
  379. package/dist/design-system115.js.map +0 -1
  380. package/dist/design-system118.js +0 -19
  381. package/dist/design-system118.js.map +0 -1
  382. package/dist/design-system121.js +0 -15
  383. package/dist/design-system121.js.map +0 -1
  384. package/dist/design-system125.js +0 -45
  385. package/dist/design-system125.js.map +0 -1
  386. package/dist/design-system128.js +0 -236
  387. package/dist/design-system128.js.map +0 -1
  388. package/dist/design-system141.js +0 -40
  389. package/dist/design-system141.js.map +0 -1
  390. package/dist/design-system144.js +0 -7
  391. package/dist/design-system158.js +0 -61
  392. package/dist/design-system158.js.map +0 -1
  393. package/dist/design-system161.js +0 -59
  394. package/dist/design-system161.js.map +0 -1
  395. package/dist/design-system174.js +0 -465
  396. package/dist/design-system174.js.map +0 -1
  397. package/dist/design-system177.js +0 -38
  398. package/dist/design-system177.js.map +0 -1
  399. package/dist/design-system222.js +0 -7
  400. package/dist/design-system222.js.map +0 -1
  401. package/dist/design-system225.js +0 -8
  402. package/dist/design-system225.js.map +0 -1
  403. package/dist/design-system229.js +0 -115
  404. package/dist/design-system229.js.map +0 -1
  405. package/dist/design-system238.js.map +0 -1
  406. package/dist/design-system241.js.map +0 -1
  407. package/dist/design-system40.js +0 -479
  408. package/dist/design-system40.js.map +0 -1
  409. package/dist/design-system43.js +0 -6
  410. package/dist/design-system43.js.map +0 -1
  411. package/dist/design-system46.js +0 -9
  412. package/dist/design-system46.js.map +0 -1
  413. package/dist/design-system50.js +0 -67
  414. package/dist/design-system50.js.map +0 -1
  415. package/dist/design-system60.js.map +0 -1
  416. package/dist/design-system63.js +0 -8
  417. package/dist/design-system67.js +0 -32
  418. package/dist/design-system67.js.map +0 -1
  419. package/dist/design-system74.js +0 -8
  420. package/dist/design-system74.js.map +0 -1
  421. package/dist/design-system79.js +0 -60
  422. package/dist/design-system79.js.map +0 -1
  423. package/dist/design-system82.js +0 -14
  424. package/dist/design-system82.js.map +0 -1
  425. package/dist/design-system86.js +0 -69
  426. package/dist/design-system86.js.map +0 -1
  427. package/dist/design-system89.js +0 -91
  428. package/dist/design-system89.js.map +0 -1
  429. package/dist/design-system93.js.map +0 -1
@@ -1,154 +1,93 @@
1
- import e from "./design-system120.js";
2
- import { BMenuContextKey as t, isDivider as n, isItemGroup as r, isSubMenu as i } from "./design-system121.js";
3
- import a from "./design-system124.js";
4
- import o from "./design-system127.js";
5
- import s from "./design-system130.js";
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
- //#region src/components/BMenu/BMenu.vue?vue&type=script&setup=true&lang.ts
8
- var x = [
1
+ import { BMenuContextKey as e, BMenuSubMenuContextKey as t } from "./design-system130.js";
2
+ import { computed as n, createCommentVNode as r, createElementBlock as i, createTextVNode as a, defineComponent as o, inject as s, normalizeClass as c, normalizeStyle as l, onMounted as u, openBlock as d, renderSlot as f, toDisplayString as p, unref as m } from "vue";
3
+ //#region src/components/BMenu/BMenuItem.vue?vue&type=script&setup=true&lang.ts
4
+ var h = [
9
5
  "role",
10
- "aria-orientation",
11
- "data-theme"
12
- ], S = /* @__PURE__ */ f({
13
- __name: "BMenu",
6
+ "tabindex",
7
+ "aria-disabled",
8
+ "aria-checked",
9
+ "title",
10
+ "data-menu-key"
11
+ ], g = {
12
+ key: 0,
13
+ class: "b-menu-item__icon",
14
+ "aria-hidden": "true"
15
+ }, _ = {
16
+ key: 1,
17
+ class: "b-menu-item__label"
18
+ }, v = {
19
+ key: 2,
20
+ class: "b-menu-item__extra"
21
+ }, y = /* @__PURE__ */ o({
22
+ __name: "BMenuItem",
14
23
  props: {
15
- mode: { default: "inline" },
16
- theme: { default: "light" },
17
- items: { default: () => [] },
18
- selectable: {
19
- type: Boolean,
20
- default: !0
21
- },
22
- multiple: {
24
+ itemKey: {},
25
+ label: { default: "" },
26
+ icon: { default: () => void 0 },
27
+ disabled: {
23
28
  type: Boolean,
24
29
  default: !1
25
30
  },
26
- inlineCollapsed: {
31
+ danger: {
27
32
  type: Boolean,
28
33
  default: !1
29
34
  },
30
- inlineIndent: { default: 24 },
31
- defaultSelectedKeys: { default: () => [] },
32
- selectedKeys: { default: void 0 },
33
- defaultOpenKeys: { default: () => [] },
34
- openKeys: { default: void 0 },
35
- triggerSubMenuAction: { default: "hover" },
36
- subMenuOpenDelay: { default: 0 },
37
- subMenuCloseDelay: { default: 100 }
35
+ extra: { default: () => void 0 },
36
+ title: { default: () => void 0 }
38
37
  },
39
- emits: [
40
- "update:selectedKeys",
41
- "update:openKeys",
42
- "click",
43
- "select",
44
- "deselect",
45
- "openChange"
46
- ],
47
- setup(f, { emit: S }) {
48
- let C = f, w = S, T = l(() => C.selectedKeys !== void 0), E = g([...C.defaultSelectedKeys]), D = l(() => T.value ? C.selectedKeys ?? [] : E.value), O = l(() => C.openKeys !== void 0), k = g([...C.defaultOpenKeys]), A = l(() => O.value ? C.openKeys ?? [] : k.value), j = /* @__PURE__ */ new Map();
49
- function M(e, t) {
50
- j.set(e, t);
38
+ setup(o) {
39
+ let y = s(e), b = s(t, null), x = n(() => (b?.level ?? 0) + 1), S = n(() => [...b?.keyPath ?? [], o.itemKey]);
40
+ u(() => {
41
+ y.registerKeyPath(o.itemKey, S.value);
42
+ });
43
+ let C = n(() => y.selectedKeys.value.includes(o.itemKey)), w = n(() => y.selectable.value ? y.multiple.value ? "menuitemcheckbox" : "menuitemradio" : "menuitem"), T = n(() => {
44
+ if (y.mode.value === "inline" && !y.inlineCollapsed.value) return `${x.value * y.inlineIndent.value}px`;
45
+ }), E = n(() => ["b-menu-item", {
46
+ "b-menu-item--selected": C.value,
47
+ "b-menu-item--disabled": o.disabled,
48
+ "b-menu-item--danger": o.danger,
49
+ "b-menu-item--collapsed": y.inlineCollapsed.value,
50
+ "b-menu-item--horizontal": y.mode.value === "horizontal"
51
+ }]);
52
+ function D(e) {
53
+ if (o.disabled) return;
54
+ let t = {
55
+ key: o.itemKey,
56
+ keyPath: S.value,
57
+ domEvent: e
58
+ };
59
+ y.onItemClick(t);
51
60
  }
52
- function N(e) {
53
- if (w("click", e), !C.selectable) return;
54
- let t = e.key, n = [...D.value];
55
- if (C.multiple) {
56
- let r = n.indexOf(t);
57
- r >= 0 ? (n.splice(r, 1), T.value || (E.value = n), w("update:selectedKeys", n), w("deselect", {
58
- ...e,
59
- selectedKeys: n
60
- })) : (n.push(t), T.value || (E.value = n), w("update:selectedKeys", n), w("select", {
61
- ...e,
62
- selectedKeys: n
63
- }));
64
- } else {
65
- let n = [t];
66
- T.value || (E.value = n), w("update:selectedKeys", n), w("select", {
67
- ...e,
68
- selectedKeys: n
69
- });
61
+ function O(e) {
62
+ if (!o.disabled && (e.key === "Enter" || e.key === " ")) {
63
+ e.preventDefault();
64
+ let t = {
65
+ key: o.itemKey,
66
+ keyPath: S.value,
67
+ domEvent: e
68
+ };
69
+ y.onItemClick(t);
70
70
  }
71
71
  }
72
- function P(e, t) {
73
- let n = [...A.value], r = n.indexOf(e);
74
- t && r < 0 ? (C.mode, n.push(e)) : !t && r >= 0 && n.splice(r, 1), O.value || (k.value = n), w("update:openKeys", n), w("openChange", n);
75
- }
76
- b(() => C.selectedKeys, (e) => {
77
- e !== void 0 && (E.value = [...e]);
78
- }), b(() => C.openKeys, (e) => {
79
- e !== void 0 && (k.value = [...e]);
80
- }), b(() => C.inlineCollapsed, (e) => {
81
- e && !O.value && (k.value = [], w("update:openKeys", []), w("openChange", []));
82
- }), h(t, {
83
- mode: l(() => C.mode),
84
- theme: l(() => C.theme),
85
- inlineCollapsed: l(() => C.inlineCollapsed),
86
- inlineIndent: l(() => C.inlineIndent),
87
- selectedKeys: D,
88
- openKeys: A,
89
- multiple: l(() => C.multiple),
90
- selectable: l(() => C.selectable),
91
- triggerSubMenuAction: l(() => C.triggerSubMenuAction),
92
- subMenuOpenDelay: l(() => C.subMenuOpenDelay),
93
- subMenuCloseDelay: l(() => C.subMenuCloseDelay),
94
- onItemClick: N,
95
- onOpenChange: P,
96
- registerKeyPath: M
97
- });
98
- let F = l(() => [
99
- "b-menu",
100
- `b-menu--${C.mode}`,
101
- `b-menu--${C.theme}`,
102
- { "b-menu--collapsed": C.mode === "inline" && C.inlineCollapsed }
103
- ]), I = l(() => "menu"), L = l(() => C.mode === "horizontal" ? "horizontal" : "vertical");
104
- return (t, l) => (m(), d("ul", {
105
- class: p(F.value),
106
- role: I.value,
107
- "aria-orientation": L.value,
108
- "data-theme": C.theme
109
- }, [v(t.$slots, "default", {}, () => [(m(!0), d(c, null, _(C.items, (t) => (m(), d(c, { key: t.key ?? t.type }, [y(n)(t) ? (m(), u(e, {
110
- key: 0,
111
- dashed: t.dashed
112
- }, null, 8, ["dashed"])) : y(r)(t) ? (m(), u(o, {
113
- key: 1,
114
- label: t.label,
115
- children: t.children
116
- }, null, 8, ["label", "children"])) : y(i)(t) ? (m(), u(s, {
117
- key: 2,
118
- "item-key": t.key,
119
- label: t.label,
120
- icon: t.icon,
121
- disabled: t.disabled,
122
- children: t.children,
123
- "popup-class-name": t.popupClassName
124
- }, null, 8, [
125
- "item-key",
126
- "label",
127
- "icon",
128
- "disabled",
129
- "children",
130
- "popup-class-name"
131
- ])) : (m(), u(a, {
132
- key: 3,
133
- "item-key": t.key,
134
- label: t.label,
135
- icon: t.icon,
136
- disabled: t.disabled,
137
- danger: t.danger,
138
- extra: t.extra,
139
- title: t.title
140
- }, null, 8, [
141
- "item-key",
142
- "label",
143
- "icon",
144
- "disabled",
145
- "danger",
146
- "extra",
147
- "title"
148
- ]))], 64))), 128))])], 10, x));
72
+ return (e, t) => (d(), i("li", {
73
+ class: c(E.value),
74
+ style: l({ paddingInlineStart: T.value }),
75
+ role: w.value,
76
+ tabindex: o.disabled ? -1 : 0,
77
+ "aria-disabled": o.disabled || void 0,
78
+ "aria-checked": m(y).selectable.value ? C.value : void 0,
79
+ title: o.title ?? (m(y).inlineCollapsed.value ? o.label : void 0),
80
+ "data-menu-key": o.itemKey,
81
+ onClick: D,
82
+ onKeydown: O
83
+ }, [
84
+ o.icon || e.$slots.icon ? (d(), i("span", g, [f(e.$slots, "icon", {}, () => [a(p(o.icon), 1)])])) : r("", !0),
85
+ m(y).inlineCollapsed.value ? r("", !0) : (d(), i("span", _, [f(e.$slots, "default", {}, () => [a(p(o.label), 1)])])),
86
+ o.extra && !m(y).inlineCollapsed.value ? (d(), i("span", v, [f(e.$slots, "extra", {}, () => [a(p(o.extra), 1)])])) : r("", !0)
87
+ ], 46, h));
149
88
  }
150
89
  });
151
90
  //#endregion
152
- export { S as default };
91
+ export { y as default };
153
92
 
154
93
  //# sourceMappingURL=design-system131.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"design-system131.js","names":[],"sources":["../src/components/BMenu/BMenu.vue?vue&type=script&setup=true&lang.ts"],"sourcesContent":["import { defineComponent as _defineComponent } from 'vue'\nimport { renderSlot as _renderSlot, renderList as _renderList, Fragment as _Fragment, openBlock as _openBlock, createElementBlock as _createElementBlock, unref as _unref, createBlock as _createBlock, createCommentVNode as _createCommentVNode, normalizeClass as _normalizeClass } from \"vue\"\n\nconst _hoisted_1 = [\"role\", \"aria-orientation\", \"data-theme\"]\n\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// ─────────────────────────────────────────────\n\nexport default /*@__PURE__*/_defineComponent({\n __name: 'BMenu',\n props: {\n mode: { default: 'inline' },\n theme: { default: 'light' },\n items: { default: () => [] },\n selectable: { type: Boolean, default: true },\n multiple: { type: Boolean, default: false },\n inlineCollapsed: { type: Boolean, default: false },\n inlineIndent: { default: 24 },\n defaultSelectedKeys: { default: () => [] },\n selectedKeys: { default: undefined },\n defaultOpenKeys: { default: () => [] },\n openKeys: { default: undefined },\n triggerSubMenuAction: { default: 'hover' },\n subMenuOpenDelay: { default: 0 },\n subMenuCloseDelay: { default: 100 }\n },\n emits: [\"update:selectedKeys\", \"update:openKeys\", \"click\", \"select\", \"deselect\", \"openChange\"],\n setup(__props: any, { emit: __emit }) {\n\nconst props = __props;\n\nconst emit = __emit;\n\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\nreturn (_ctx: any,_cache: any) => {\n return (_openBlock(), _createElementBlock(\"ul\", {\n class: _normalizeClass(rootClasses.value),\n role: ariaRole.value,\n \"aria-orientation\": ariaOrientation.value,\n \"data-theme\": props.theme\n }, [\n _renderSlot(_ctx.$slots, \"default\", {}, () => [\n (_openBlock(true), _createElementBlock(_Fragment, null, _renderList(props.items, (item) => {\n return (_openBlock(), _createElementBlock(_Fragment, {\n key: item.key ?? (item as any).type\n }, [\n (_unref(isDivider)(item))\n ? (_openBlock(), _createBlock(BMenuDivider, {\n key: 0,\n dashed: item.dashed\n }, null, 8, [\"dashed\"]))\n : (_unref(isItemGroup)(item))\n ? (_openBlock(), _createBlock(BMenuItemGroup, {\n key: 1,\n label: item.label,\n children: item.children\n }, null, 8, [\"label\", \"children\"]))\n : (_unref(isSubMenu)(item))\n ? (_openBlock(), _createBlock(BMenuSubMenu, {\n key: 2,\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 }, null, 8, [\"item-key\", \"label\", \"icon\", \"disabled\", \"children\", \"popup-class-name\"]))\n : (_openBlock(), _createBlock(BMenuItem, {\n key: 3,\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 }, null, 8, [\"item-key\", \"label\", \"icon\", \"disabled\", \"danger\", \"extra\", \"title\"]))\n ], 64))\n }), 128))\n ])\n ], 10, _hoisted_1))\n}\n}\n\n})"],"mappings":"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"}
1
+ {"version":3,"file":"design-system131.js","names":["$slots"],"sources":["../src/components/BMenu/BMenuItem.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { computed, inject, onMounted } from 'vue';\nimport {\n BMenuContextKey,\n BMenuSubMenuContextKey,\n type BMenuClickInfo,\n type BMenuContext,\n type BMenuSubMenuContext,\n} from './types';\n\n// ─────────────────────────────────────────────\n// Props\n// ─────────────────────────────────────────────\nconst {\n itemKey,\n label = '',\n icon = undefined,\n disabled = false,\n danger = false,\n extra = undefined,\n title = undefined,\n} = defineProps<{\n /** Unique key identifying this menu item. */\n itemKey: string;\n /** Display label text. */\n label?: string;\n /** Icon name rendered before the label. */\n icon?: string;\n /** Whether the item is disabled. @default false */\n disabled?: boolean;\n /** Display with danger (red) styling. @default false */\n danger?: boolean;\n /** Extra content at the right side. */\n extra?: string;\n /** Tooltip title when collapsed. */\n title?: string;\n}>();\n\ndefineSlots<{\n default?(): unknown;\n icon?(): unknown;\n extra?(): unknown;\n}>();\n\n// ─────────────────────────────────────────────\n// Inject context\n// ─────────────────────────────────────────────\nconst menu = inject<BMenuContext>(BMenuContextKey)!;\nconst subMenuCtx = inject<BMenuSubMenuContext | null>(BMenuSubMenuContextKey, null);\n\nconst level = computed(() => (subMenuCtx?.level ?? 0) + 1);\nconst keyPath = computed(() => [...(subMenuCtx?.keyPath ?? []), itemKey]);\n\n// Register key path with root menu\nonMounted(() => {\n menu.registerKeyPath(itemKey, keyPath.value);\n});\n\n// ─────────────────────────────────────────────\n// Computed\n// ─────────────────────────────────────────────\nconst isSelected = computed(() => menu.selectedKeys.value.includes(itemKey));\n\nconst itemRole = computed(() => {\n if (!menu.selectable.value) return 'menuitem';\n return menu.multiple.value ? 'menuitemcheckbox' : 'menuitemradio';\n});\n\nconst paddingLeft = computed(() => {\n if (menu.mode.value !== 'inline') return undefined;\n if (menu.inlineCollapsed.value) return undefined;\n return `${level.value * menu.inlineIndent.value}px`;\n});\n\nconst itemClasses = computed(() => [\n 'b-menu-item',\n {\n 'b-menu-item--selected': isSelected.value,\n 'b-menu-item--disabled': disabled,\n 'b-menu-item--danger': danger,\n 'b-menu-item--collapsed': menu.inlineCollapsed.value,\n 'b-menu-item--horizontal': menu.mode.value === 'horizontal',\n },\n]);\n\n// ─────────────────────────────────────────────\n// Handlers\n// ─────────────────────────────────────────────\nfunction handleClick(e: MouseEvent) {\n if (disabled) return;\n\n const info: BMenuClickInfo = {\n key: itemKey,\n keyPath: keyPath.value,\n domEvent: e,\n };\n menu.onItemClick(info);\n}\n\nfunction handleKeydown(e: KeyboardEvent) {\n if (disabled) return;\n\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault();\n const info: BMenuClickInfo = {\n key: itemKey,\n keyPath: keyPath.value,\n domEvent: e,\n };\n menu.onItemClick(info);\n }\n}\n</script>\n\n<template>\n <li\n :class=\"itemClasses\"\n :style=\"{ paddingInlineStart: paddingLeft }\"\n :role=\"itemRole\"\n :tabindex=\"disabled ? -1 : 0\"\n :aria-disabled=\"disabled || undefined\"\n :aria-checked=\"menu.selectable.value ? isSelected : undefined\"\n :title=\"title ?? (menu.inlineCollapsed.value ? label : undefined)\"\n :data-menu-key=\"itemKey\"\n @click=\"handleClick\"\n @keydown=\"handleKeydown\"\n >\n <span v-if=\"icon || $slots.icon\" class=\"b-menu-item__icon\" aria-hidden=\"true\">\n <slot name=\"icon\">{{ icon }}</slot>\n </span>\n <span v-if=\"!menu.inlineCollapsed.value\" class=\"b-menu-item__label\">\n <slot>{{ label }}</slot>\n </span>\n <span v-if=\"extra && !menu.inlineCollapsed.value\" class=\"b-menu-item__extra\">\n <slot name=\"extra\">{{ extra }}</slot>\n </span>\n </li>\n</template>\n\n<style>\n/* ─────────────────────────────────────────────\n BMenuItem\n ───────────────────────────────────────────── */\n.b-menu-item {\n display: flex;\n align-items: center;\n height: var(--b-menu-item-height);\n margin-block: var(--b-menu-item-margin-block);\n margin-inline: var(--b-menu-item-margin-inline);\n padding-inline: var(--b-menu-item-padding-inline);\n border-radius: var(--b-menu-item-border-radius);\n color: var(--b-menu-item-color);\n cursor: pointer;\n user-select: none;\n list-style: none;\n outline: none;\n position: relative;\n transition:\n background var(--b-menu-transition-duration),\n color var(--b-menu-transition-duration),\n padding var(--b-menu-transition-duration);\n box-sizing: border-box;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n\n.b-menu-item:hover:not(.b-menu-item--disabled) {\n background: var(--b-menu-item-hover-bg);\n color: var(--b-menu-item-hover-color);\n}\n\n.b-menu-item:focus-visible {\n outline: 2px solid #1677ff;\n outline-offset: -2px;\n}\n\n/* ── Selected ── */\n.b-menu-item--selected {\n background: var(--b-menu-item-selected-bg);\n color: var(--b-menu-item-selected-color);\n font-weight: 500;\n}\n\n/* ── Disabled ── */\n.b-menu-item--disabled {\n color: var(--b-menu-item-disabled-color);\n cursor: not-allowed;\n}\n\n/* ── Danger ── */\n.b-menu-item--danger {\n color: var(--b-menu-danger-item-color);\n}\n\n.b-menu-item--danger:hover:not(.b-menu-item--disabled) {\n color: var(--b-menu-danger-item-hover-color);\n background: var(--b-menu-danger-item-active-bg);\n}\n\n.b-menu-item--danger.b-menu-item--selected {\n background: var(--b-menu-danger-item-selected-bg);\n color: var(--b-menu-danger-item-selected-color);\n}\n\n/* ── Collapsed ── */\n.b-menu-item--collapsed {\n justify-content: center;\n padding-inline: 0;\n}\n\n.b-menu-item--collapsed .b-menu-item__icon {\n font-size: var(--b-menu-collapsed-icon-size);\n margin-inline-end: 0;\n}\n\n/* ── Horizontal mode ── */\n.b-menu-item--horizontal {\n margin-block: 0;\n border-radius: var(--b-menu-horizontal-item-border-radius);\n height: auto;\n line-height: var(--b-menu-horizontal-line-height);\n position: relative;\n}\n\n.b-menu-item--horizontal::after {\n content: '';\n position: absolute;\n bottom: 0;\n left: var(--b-menu-item-padding-inline);\n right: var(--b-menu-item-padding-inline);\n height: var(--b-menu-active-bar-height);\n background: transparent;\n transition: background var(--b-menu-transition-duration);\n}\n\n.b-menu-item--horizontal:hover:not(.b-menu-item--disabled) {\n background: var(--b-menu-horizontal-item-hover-bg);\n color: var(--b-menu-horizontal-item-hover-color);\n}\n\n.b-menu-item--horizontal.b-menu-item--selected {\n background: var(--b-menu-horizontal-item-selected-bg);\n color: var(--b-menu-horizontal-item-selected-color);\n}\n\n.b-menu-item--horizontal.b-menu-item--selected::after {\n background: var(--b-menu-horizontal-item-selected-color);\n}\n\n/* ─────────────────────────────────────────────\n Icon & Label\n ───────────────────────────────────────────── */\n.b-menu-item__icon {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n flex-shrink: 0;\n font-size: var(--b-menu-icon-size);\n margin-inline-end: var(--b-menu-icon-margin-inline-end);\n}\n\n.b-menu-item__label {\n flex: 1;\n min-width: 0;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n\n.b-menu-item__extra {\n margin-inline-start: auto;\n padding-inline-start: 8px;\n color: var(--b-menu-group-title-color);\n font-size: 12px;\n}\n\n/* ── Reduced motion ── */\n@media (prefers-reduced-motion: reduce) {\n .b-menu-item {\n transition: none;\n }\n\n .b-menu-item--horizontal::after {\n transition: none;\n }\n}\n</style>\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA+CA,IAAM,IAAO,EAAqB,EAAgB,EAC5C,IAAa,EAAmC,GAAwB,KAAK,EAE7E,IAAQ,SAAgB,GAAY,SAAS,KAAK,EAAE,EACpD,IAAU,QAAe,CAAC,GAAI,GAAY,WAAW,EAAE,EAAG,EAAA,QAAQ,CAAC;AAGzE,UAAgB;AACd,KAAK,gBAAgB,EAAA,SAAS,EAAQ,MAAM;IAC5C;EAKF,IAAM,IAAa,QAAe,EAAK,aAAa,MAAM,SAAS,EAAA,QAAQ,CAAC,EAEtE,IAAW,QACV,EAAK,WAAW,QACd,EAAK,SAAS,QAAQ,qBAAqB,kBADf,WAEnC,EAEI,IAAc,QAAe;AAC7B,SAAK,KAAK,UAAU,YACpB,GAAK,gBAAgB,MACzB,QAAO,GAAG,EAAM,QAAQ,EAAK,aAAa,MAAM;IAChD,EAEI,IAAc,QAAe,CACjC,eACA;GACE,yBAAyB,EAAW;GACpC,yBAAyB,EAAA;GACzB,uBAAuB,EAAA;GACvB,0BAA0B,EAAK,gBAAgB;GAC/C,2BAA2B,EAAK,KAAK,UAAU;GAChD,CACF,CAAC;EAKF,SAAS,EAAY,GAAe;AAClC,OAAI,EAAA,SAAU;GAEd,IAAM,IAAuB;IAC3B,KAAK,EAAA;IACL,SAAS,EAAQ;IACjB,UAAU;IACX;AACD,KAAK,YAAY,EAAK;;EAGxB,SAAS,EAAc,GAAkB;AACnC,UAAA,aAEA,EAAE,QAAQ,WAAW,EAAE,QAAQ,MAAK;AACtC,MAAE,gBAAgB;IAClB,IAAM,IAAuB;KAC3B,KAAK,EAAA;KACL,SAAS,EAAQ;KACjB,UAAU;KACX;AACD,MAAK,YAAY,EAAK;;;yBAMxB,EAqBK,MAAA;GApBF,OAAK,EAAE,EAAA,MAAW;GAClB,OAAK,EAAA,EAAA,oBAAwB,EAAA,OAAW,CAAA;GACxC,MAAM,EAAA;GACN,UAAU,EAAA,WAAQ,KAAA;GAClB,iBAAe,EAAA,YAAY,KAAA;GAC3B,gBAAc,EAAA,EAAI,CAAC,WAAW,QAAQ,EAAA,QAAa,KAAA;GACnD,OAAO,EAAA,UAAU,EAAA,EAAI,CAAC,gBAAgB,QAAQ,EAAA,QAAQ,KAAA;GACtD,iBAAe,EAAA;GACf,SAAO;GACP,WAAS;;GAEE,EAAA,QAAQA,EAAAA,OAAO,QAAA,GAAA,EAA3B,EAEO,QAFP,GAEO,CADL,EAAmC,EAAA,QAAA,QAAA,EAAA,QAAA,CAAA,EAAA,EAAd,EAAA,KAAI,EAAA,EAAA,CAAA,CAAA,CAAA,CAAA,IAAA,EAAA,IAAA,GAAA;GAEd,EAAA,EAAI,CAAC,gBAAgB,QAClB,EAAA,IAAA,GAAA,IADkB,GAAA,EAAlC,EAEO,QAFP,GAEO,CADL,EAAwB,EAAA,QAAA,WAAA,EAAA,QAAA,CAAA,EAAA,EAAf,EAAA,MAAK,EAAA,EAAA,CAAA,CAAA,CAAA,CAAA;GAEJ,EAAA,SAAK,CAAK,EAAA,EAAI,CAAC,gBAAgB,SAAA,GAAA,EAA3C,EAEO,QAFP,GAEO,CADL,EAAqC,EAAA,QAAA,SAAA,EAAA,QAAA,CAAA,EAAA,EAAf,EAAA,MAAK,EAAA,EAAA,CAAA,CAAA,CAAA,CAAA,IAAA,EAAA,IAAA,GAAA"}
@@ -1,6 +1,6 @@
1
1
  import e from "./design-system131.js";
2
2
  /* empty css */
3
- //#region src/components/BMenu/BMenu.vue
3
+ //#region src/components/BMenu/BMenuItem.vue
4
4
  var t = e;
5
5
  //#endregion
6
6
  export { t as default };
@@ -1 +1 @@
1
- {"version":3,"file":"design-system133.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":""}
1
+ {"version":3,"file":"design-system133.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,98 +1,45 @@
1
- import { BMessageType as e } from "./design-system3.js";
2
- import { Teleport as t, Transition as n, computed as r, createBlock as i, createCommentVNode as a, createElementBlock as o, createElementVNode as s, createTextVNode as c, createVNode as l, defineComponent as u, normalizeClass as d, onUnmounted as f, openBlock as p, ref as m, renderSlot as h, toDisplayString as g, unref as _, useId as v, watch as y, withCtx as b } from "vue";
3
- //#region src/components/BMessage/BMessage.vue?vue&type=script&setup=true&lang.ts
4
- var x = [
5
- "id",
6
- "role",
7
- "aria-live"
8
- ], S = {
1
+ import { BMenuContextKey as e } from "./design-system130.js";
2
+ import t from "./design-system133.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
9
  key: 0,
10
- class: "b-message__icon",
11
- "aria-hidden": "true"
12
- }, C = ["d"], w = { class: "b-message__content" }, T = /* @__PURE__ */ u({
13
- __name: "BMessage",
10
+ class: "b-menu-item-group__title",
11
+ role: "presentation"
12
+ }, _ = ["aria-label"], v = /* @__PURE__ */ c({
13
+ __name: "BMenuItemGroup",
14
14
  props: {
15
- type: { default: () => e.Info },
16
- content: { default: "" },
17
- duration: { default: 3 },
18
- showIcon: {
19
- type: Boolean,
20
- default: !0
21
- },
22
- modelValue: {
23
- type: Boolean,
24
- default: () => void 0
25
- }
15
+ label: { default: "" },
16
+ children: { default: () => [] }
26
17
  },
27
- emits: [
28
- "close",
29
- "afterClose",
30
- "update:modelValue"
31
- ],
32
- setup(u, { expose: T, emit: E }) {
33
- let D = E, O = v(), k = m(!1), A = r(() => u.modelValue === void 0 ? k.value : u.modelValue), j = r(() => u.modelValue !== void 0), M = r(() => u.type === e.Error || u.type === e.Warning ? "alert" : "status"), N = r(() => {
34
- switch (u.type) {
35
- case e.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";
36
- case e.Warning: return "M1 21h22L12 2 1 21zm12-3h-2v-2h2v2zm0-4h-2v-4h2v4z";
37
- case e.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";
38
- case e.Loading: return "M12 2a10 10 0 0 1 10 10h-2a8 8 0 0 0-8-8V2z";
39
- 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";
40
- }
41
- }), P = null;
42
- function F() {
43
- I(), u.duration > 0 && (P = setTimeout(() => {
44
- R();
45
- }, u.duration * 1e3));
46
- }
47
- function I() {
48
- P !== null && (clearTimeout(P), P = null);
49
- }
50
- function L() {
51
- j.value ? D("update:modelValue", !0) : k.value = !0;
52
- }
53
- function R() {
54
- D("close"), j.value ? D("update:modelValue", !1) : k.value = !1;
55
- }
56
- function z() {
57
- D("afterClose");
58
- }
59
- function B() {
60
- I();
61
- }
62
- function V() {
63
- F();
64
- }
65
- return f(() => {
66
- I();
67
- }), y(A, (e) => {
68
- e ? F() : I();
69
- }, { immediate: !0 }), T({
70
- open: L,
71
- close: R
72
- }), (e, r) => (p(), i(t, { to: "body" }, [l(n, {
73
- name: "b-message-fade",
74
- onAfterLeave: z
75
- }, {
76
- default: b(() => [A.value ? (p(), o("div", {
77
- key: 0,
78
- id: _(O),
79
- class: d(["b-message", [`b-message--${u.type}`, { "b-message--with-icon": u.showIcon }]]),
80
- role: M.value,
81
- "aria-live": M.value === "alert" ? "assertive" : "polite",
82
- "aria-atomic": !0,
83
- onMouseenter: B,
84
- onMouseleave: V
85
- }, [u.showIcon ? (p(), o("span", S, [h(e.$slots, "icon", {}, () => [(p(), o("svg", {
86
- class: d(["b-message__icon-svg", { "b-message__icon-svg--spin": u.type === "loading" }]),
87
- viewBox: "0 0 24 24",
88
- xmlns: "http://www.w3.org/2000/svg",
89
- focusable: "false"
90
- }, [s("path", { d: N.value }, null, 8, C)], 2))])])) : a("", !0), s("span", w, [h(e.$slots, "default", {}, () => [c(g(u.content), 1)])])], 42, x)) : a("", !0)]),
91
- _: 3
92
- })]));
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, _)]));
93
40
  }
94
41
  });
95
42
  //#endregion
96
- export { T as default };
43
+ export { v as default };
97
44
 
98
45
  //# sourceMappingURL=design-system134.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"design-system134.js","names":[],"sources":["../src/components/BMessage/BMessage.vue?vue&type=script&setup=true&lang.ts"],"sourcesContent":["import { defineComponent as _defineComponent } from 'vue'\nimport { unref as _unref, renderSlot as _renderSlot, createElementVNode as _createElementVNode, normalizeClass as _normalizeClass, openBlock as _openBlock, createElementBlock as _createElementBlock, createCommentVNode as _createCommentVNode, toDisplayString as _toDisplayString, createTextVNode as _createTextVNode, Transition as _Transition, withCtx as _withCtx, createVNode as _createVNode, Teleport as _Teleport, createBlock as _createBlock } from \"vue\"\n\nconst _hoisted_1 = [\"id\", \"role\", \"aria-live\"]\nconst _hoisted_2 = {\n key: 0,\n class: \"b-message__icon\",\n \"aria-hidden\": \"true\"\n}\nconst _hoisted_3 = [\"d\"]\nconst _hoisted_4 = { class: \"b-message__content\" }\n\nimport { BMessageType } from '@/types.ts';\nimport { computed, onUnmounted, ref, useId, watch } from 'vue';\n\n// ─────────────────────────────────────────────\n// Props & emits\n// ─────────────────────────────────────────────\n\nexport default /*@__PURE__*/_defineComponent({\n __name: 'BMessage',\n props: {\n type: { default: () => (BMessageType.Info) },\n content: { default: '' },\n duration: { default: 3 },\n showIcon: { type: Boolean, default: true },\n modelValue: { type: Boolean, default: () => (undefined) }\n },\n emits: [\"close\", \"afterClose\", \"update:modelValue\"],\n setup(__props: any, { expose: __expose, emit: __emit }) {\n\n\n\nconst emit = __emit;\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(() => (__props.modelValue !== undefined ? __props.modelValue : internalVisible.value));\n\nconst isControlled = computed(() => __props.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 __props.type === BMessageType.Error || __props.type === BMessageType.Warning ? 'alert' : 'status',\n);\n\n/** Map type → inline SVG path for the status icon. */\nconst iconPath = computed(() => {\n switch (__props.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\n\n\n// ─────────────────────────────────────────────\n// Auto-close timer\n// ─────────────────────────────────────────────\nlet timer: ReturnType<typeof setTimeout> | null = null;\n\nfunction startTimer() {\n clearTimer();\n if (__props.duration > 0) {\n timer = setTimeout(() => {\n close();\n }, __props.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\n__expose({ open, close });\n\nreturn (_ctx: any,_cache: any) => {\n return (_openBlock(), _createBlock(_Teleport, { to: \"body\" }, [\n _createVNode(_Transition, {\n name: \"b-message-fade\",\n onAfterLeave: onAfterLeave\n }, {\n default: _withCtx(() => [\n (isVisible.value)\n ? (_openBlock(), _createElementBlock(\"div\", {\n key: 0,\n id: _unref(messageId),\n class: _normalizeClass([\"b-message\", [\n `b-message--${__props.type}`,\n {\n 'b-message--with-icon': __props.showIcon,\n },\n ]]),\n role: ariaRole.value,\n \"aria-live\": ariaRole.value === 'alert' ? 'assertive' : 'polite',\n \"aria-atomic\": true,\n onMouseenter: onMouseEnter,\n onMouseleave: onMouseLeave\n }, [\n (__props.showIcon)\n ? (_openBlock(), _createElementBlock(\"span\", _hoisted_2, [\n _renderSlot(_ctx.$slots, \"icon\", {}, () => [\n (_openBlock(), _createElementBlock(\"svg\", {\n class: _normalizeClass([\"b-message__icon-svg\", { 'b-message__icon-svg--spin': __props.type === 'loading' }]),\n viewBox: \"0 0 24 24\",\n xmlns: \"http://www.w3.org/2000/svg\",\n focusable: \"false\"\n }, [\n _createElementVNode(\"path\", { d: iconPath.value }, null, 8, _hoisted_3)\n ], 2))\n ])\n ]))\n : _createCommentVNode(\"\", true),\n _createElementVNode(\"span\", _hoisted_4, [\n _renderSlot(_ctx.$slots, \"default\", {}, () => [\n _createTextVNode(_toDisplayString(__props.content), 1)\n ])\n ])\n ], 42, _hoisted_1))\n : _createCommentVNode(\"\", true)\n ]),\n _: 3\n })\n ]))\n}\n}\n\n})"],"mappings":";;;AAGA,IAAM,IAAa;CAAC;CAAM;CAAQ;CAAY,EACxC,IAAa;CACjB,KAAK;CACL,OAAO;CACP,eAAe;CAChB,EACK,IAAa,CAAC,IAAI,EAClB,IAAa,EAAE,OAAO,sBAAsB,EASlD,IAA4B,kBAAiB;CAC3C,QAAQ;CACR,OAAO;EACL,MAAM,EAAE,eAAgB,EAAa,MAAO;EAC5C,SAAS,EAAE,SAAS,IAAI;EACxB,UAAU,EAAE,SAAS,GAAG;EACxB,UAAU;GAAE,MAAM;GAAS,SAAS;GAAM;EAC1C,YAAY;GAAE,MAAM;GAAS,eAAgB,KAAA;GAAY;EAC1D;CACD,OAAO;EAAC;EAAS;EAAc;EAAoB;CACnD,MAAM,GAAc,EAAE,QAAQ,GAAU,MAAM,KAAU;EAI1D,IAAM,IAAO,GAKP,IAAY,GAAO,EAGnB,IAAkB,EAAI,GAAM,EAO5B,IAAY,QAAgB,EAAQ,eAAe,KAAA,IAAiC,EAAgB,QAArC,EAAQ,WAAoC,EAE3G,IAAe,QAAe,EAAQ,eAAe,KAAA,EAAU,EAM/D,IAAW,QACf,EAAQ,SAAS,EAAa,SAAS,EAAQ,SAAS,EAAa,UAAU,UAAU,SAC1F,EAGK,IAAW,QAAe;AAC9B,WAAQ,EAAQ,MAAhB;IACE,KAAK,EAAa,QAEhB,QAAO;IACT,KAAK,EAAa,QAEhB,QAAO;IACT,KAAK,EAAa,MAEhB,QAAO;IACT,KAAK,EAAa,QAEhB,QAAO;IACT,QAEE,QAAO;;IAEX,EAOE,IAA8C;EAElD,SAAS,IAAa;AAEpB,GADA,GAAY,EACR,EAAQ,WAAW,MACrB,IAAQ,iBAAiB;AACvB,OAAO;MACN,EAAQ,WAAW,IAAK;;EAI/B,SAAS,IAAa;AACpB,GAAI,MAAU,SACZ,aAAa,EAAM,EACnB,IAAQ;;EAOZ,SAAS,IAAO;AACd,GAAI,EAAa,QACf,EAAK,qBAAqB,GAAK,GAE/B,EAAgB,QAAQ;;EAI5B,SAAS,IAAQ;AAEf,GADA,EAAK,QAAQ,EACT,EAAa,QACf,EAAK,qBAAqB,GAAM,GAEhC,EAAgB,QAAQ;;EAI5B,SAAS,IAAe;AACtB,KAAK,aAAa;;EAGpB,SAAS,IAAe;AACtB,MAAY;;EAGd,SAAS,IAAe;AACtB,MAAY;;AA0Bd,SApBA,QAAkB;AAChB,MAAY;IACZ,EAGF,EACE,IACC,MAAY;AACX,GAAI,IACF,GAAY,GAEZ,GAAY;KAGhB,EAAE,WAAW,IAAM,CACpB,EAGD,EAAS;GAAE;GAAM;GAAO,CAAC,GAEjB,GAAU,OACR,GAAY,EAAE,EAAa,GAAW,EAAE,IAAI,QAAQ,EAAE,CAC5D,EAAa,GAAa;GACxB,MAAM;GACQ;GACf,EAAE;GACD,SAAS,QAAe,CACrB,EAAU,SACN,GAAY,EAAE,EAAoB,OAAO;IACxC,KAAK;IACL,IAAI,EAAO,EAAU;IACrB,OAAO,EAAgB,CAAC,aAAa,CACzC,cAAc,EAAQ,QACtB,EACE,wBAAwB,EAAQ,UACjC,CACF,CAAC,CAAC;IACG,MAAM,EAAS;IACf,aAAa,EAAS,UAAU,UAAU,cAAc;IACxD,eAAe;IACf,cAAc;IACd,cAAc;IACf,EAAE,CACA,EAAQ,YACJ,GAAY,EAAE,EAAoB,QAAQ,GAAY,CACrD,EAAY,EAAK,QAAQ,QAAQ,EAAE,QAAQ,EACxC,GAAY,EAAE,EAAoB,OAAO;IACxC,OAAO,EAAgB,CAAC,uBAAuB,EAAE,6BAA6B,EAAQ,SAAS,WAAW,CAAC,CAAC;IAC5G,SAAS;IACT,OAAO;IACP,WAAW;IACZ,EAAE,CACD,EAAoB,QAAQ,EAAE,GAAG,EAAS,OAAO,EAAE,MAAM,GAAG,EAAW,CACxE,EAAE,EAAE,EACN,CAAC,CACH,CAAC,IACF,EAAoB,IAAI,GAAK,EACjC,EAAoB,QAAQ,GAAY,CACtC,EAAY,EAAK,QAAQ,WAAW,EAAE,QAAQ,CAC5C,EAAiB,EAAiB,EAAQ,QAAQ,EAAE,EAAE,CACvD,CAAC,CACH,CAAC,CACH,EAAE,IAAI,EAAW,IAClB,EAAoB,IAAI,GAAK,CAClC,CAAC;GACF,GAAG;GACJ,CAAC,CACH,CAAC;;CAIH,CAAA"}
1
+ {"version":3,"file":"design-system134.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,6 +1,6 @@
1
1
  import e from "./design-system134.js";
2
2
  /* empty css */
3
- //#region src/components/BMessage/BMessage.vue
3
+ //#region src/components/BMenu/BMenuItemGroup.vue
4
4
  var t = e;
5
5
  //#endregion
6
6
  export { t as default };
@@ -1 +1 @@
1
- {"version":3,"file":"design-system136.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-system136.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":""}