@7pmlabs/design-system 1.0.9 → 1.0.11

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (438) hide show
  1. package/README.md +57 -6
  2. package/dist/design-system.css +1 -1
  3. package/dist/design-system.js +74 -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 +452 -90
  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 +33 -106
  127. package/dist/design-system183.js.map +1 -1
  128. package/dist/design-system185.js +4 -5
  129. package/dist/design-system185.js.map +1 -1
  130. package/dist/design-system186.js +71 -89
  131. package/dist/design-system186.js.map +1 -1
  132. package/dist/design-system188.js +4 -5
  133. package/dist/design-system188.js.map +1 -1
  134. package/dist/design-system189.js +25 -727
  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 +28 -11
  140. package/dist/design-system192.js.map +1 -1
  141. package/dist/design-system194.js +8 -0
  142. package/dist/design-system194.js.map +1 -0
  143. package/dist/design-system195.js +33 -5
  144. package/dist/design-system195.js.map +1 -1
  145. package/dist/design-system197.js +5 -46
  146. package/dist/design-system197.js.map +1 -1
  147. package/dist/design-system198.js +31 -4
  148. package/dist/design-system198.js.map +1 -1
  149. package/dist/design-system200.js +8 -0
  150. package/dist/design-system200.js.map +1 -0
  151. package/dist/design-system201.js +332 -5
  152. package/dist/design-system201.js.map +1 -1
  153. package/dist/design-system203.js +8 -0
  154. package/dist/design-system203.js.map +1 -0
  155. package/dist/design-system204.js +100 -5
  156. package/dist/design-system204.js.map +1 -1
  157. package/dist/design-system206.js +8 -0
  158. package/dist/design-system206.js.map +1 -0
  159. package/dist/design-system207.js +19 -5
  160. package/dist/design-system207.js.map +1 -1
  161. package/dist/design-system208.js +4 -54
  162. package/dist/design-system208.js.map +1 -1
  163. package/dist/design-system209.js +3 -4
  164. package/dist/design-system209.js.map +1 -1
  165. package/dist/design-system210.js +386 -137
  166. package/dist/design-system210.js.map +1 -1
  167. package/dist/design-system212.js +1 -1
  168. package/dist/design-system212.js.map +1 -1
  169. package/dist/design-system213.js +59 -7
  170. package/dist/design-system213.js.map +1 -1
  171. package/dist/design-system215.js +8 -0
  172. package/dist/design-system215.js.map +1 -0
  173. package/dist/design-system216.js +88 -5
  174. package/dist/design-system216.js.map +1 -1
  175. package/dist/design-system217.js +4 -580
  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 -7
  181. package/dist/design-system220.js.map +1 -1
  182. package/dist/design-system221.js +85 -353
  183. package/dist/design-system221.js.map +1 -1
  184. package/dist/design-system223.js +2 -2
  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 +8 -0
  189. package/dist/design-system226.js.map +1 -0
  190. package/dist/{design-system60.js → design-system227.js} +6 -8
  191. package/dist/design-system227.js.map +1 -0
  192. package/dist/{design-system193.js → design-system228.js} +2 -2
  193. package/dist/design-system228.js.map +1 -0
  194. package/dist/design-system230.js +8 -0
  195. package/dist/design-system230.js.map +1 -0
  196. package/dist/{design-system196.js → design-system231.js} +1 -1
  197. package/dist/{design-system196.js.map → design-system231.js.map} +1 -1
  198. package/dist/design-system232.js +49 -0
  199. package/dist/design-system232.js.map +1 -0
  200. package/dist/design-system233.js +7 -0
  201. package/dist/design-system233.js.map +1 -0
  202. package/dist/{design-system199.js → design-system234.js} +2 -2
  203. package/dist/design-system234.js.map +1 -0
  204. package/dist/design-system236.js +8 -0
  205. package/dist/design-system236.js.map +1 -0
  206. package/dist/{design-system202.js → design-system237.js} +1 -1
  207. package/dist/design-system237.js.map +1 -0
  208. package/dist/design-system239.js +8 -0
  209. package/dist/design-system239.js.map +1 -0
  210. package/dist/{design-system205.js → design-system240.js} +1 -1
  211. package/dist/design-system240.js.map +1 -0
  212. package/dist/design-system242.js +8 -0
  213. package/dist/design-system242.js.map +1 -0
  214. package/dist/design-system243.js +57 -0
  215. package/dist/design-system243.js.map +1 -0
  216. package/dist/design-system244.js +7 -0
  217. package/dist/design-system244.js.map +1 -0
  218. package/dist/design-system245.js +173 -0
  219. package/dist/design-system245.js.map +1 -0
  220. package/dist/design-system247.js +8 -0
  221. package/dist/design-system247.js.map +1 -0
  222. package/dist/design-system248.js +10 -0
  223. package/dist/design-system248.js.map +1 -0
  224. package/dist/{design-system214.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-system252.js +583 -0
  230. package/dist/design-system252.js.map +1 -0
  231. package/dist/{design-system219.js → design-system254.js} +2 -2
  232. package/dist/{design-system219.js.map → design-system254.js.map} +1 -1
  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/BPagination/BPagination.vue.d.ts +1 -1
  358. package/dist/types/components/BSkeleton/BSkeleton.spec.d.ts +1 -0
  359. package/dist/types/components/BSkeleton/BSkeleton.vue.d.ts +46 -0
  360. package/dist/types/components/BSkeleton/BSkeletonAvatar.vue.d.ts +12 -0
  361. package/dist/types/components/BSkeleton/BSkeletonButton.vue.d.ts +14 -0
  362. package/dist/types/components/BSkeleton/BSkeletonImage.vue.d.ts +7 -0
  363. package/dist/types/components/BSkeleton/BSkeletonInput.vue.d.ts +12 -0
  364. package/dist/types/components/BSkeleton/BSkeletonNode.vue.d.ts +19 -0
  365. package/dist/types/components/BSkeleton/index.d.ts +7 -0
  366. package/dist/types/components/BSkeleton/types.d.ts +20 -0
  367. package/dist/types/components/BSplitter/BSplitter.spec.d.ts +1 -0
  368. package/dist/types/components/BSplitter/BSplitter.vue.d.ts +45 -0
  369. package/dist/types/components/BSplitter/BSplitterPanel.vue.d.ts +40 -0
  370. package/dist/types/components/BSplitter/index.d.ts +3 -0
  371. package/dist/types/components/BSplitter/types.d.ts +42 -0
  372. package/dist/types/components/BStatistic/BStatistic.spec.d.ts +1 -0
  373. package/dist/types/components/BStatistic/BStatistic.vue.d.ts +44 -0
  374. package/dist/types/components/BStatistic/BStatisticTimer.vue.d.ts +50 -0
  375. package/dist/types/components/BStatistic/index.d.ts +3 -0
  376. package/dist/types/components/BStatistic/types.d.ts +6 -0
  377. package/dist/types/components/BTreeSelect/BTreeSelect.spec.d.ts +1 -0
  378. package/dist/types/components/BTreeSelect/BTreeSelect.vue.d.ts +143 -0
  379. package/dist/types/components/BTreeSelect/index.d.ts +2 -0
  380. package/dist/types/components/BTreeSelect/types.d.ts +77 -0
  381. package/dist/types/components/index.d.ts +6 -0
  382. package/dist/types/types.d.ts +3 -0
  383. package/package.json +6 -3
  384. package/dist/design-system105.js +0 -212
  385. package/dist/design-system105.js.map +0 -1
  386. package/dist/design-system108.js +0 -227
  387. package/dist/design-system108.js.map +0 -1
  388. package/dist/design-system111.js +0 -166
  389. package/dist/design-system111.js.map +0 -1
  390. package/dist/design-system115.js +0 -277
  391. package/dist/design-system115.js.map +0 -1
  392. package/dist/design-system118.js +0 -19
  393. package/dist/design-system118.js.map +0 -1
  394. package/dist/design-system121.js +0 -15
  395. package/dist/design-system121.js.map +0 -1
  396. package/dist/design-system125.js +0 -45
  397. package/dist/design-system125.js.map +0 -1
  398. package/dist/design-system128.js +0 -236
  399. package/dist/design-system128.js.map +0 -1
  400. package/dist/design-system141.js +0 -40
  401. package/dist/design-system141.js.map +0 -1
  402. package/dist/design-system144.js +0 -7
  403. package/dist/design-system158.js +0 -61
  404. package/dist/design-system158.js.map +0 -1
  405. package/dist/design-system161.js +0 -59
  406. package/dist/design-system161.js.map +0 -1
  407. package/dist/design-system174.js +0 -465
  408. package/dist/design-system174.js.map +0 -1
  409. package/dist/design-system177.js +0 -335
  410. package/dist/design-system177.js.map +0 -1
  411. package/dist/design-system193.js.map +0 -1
  412. package/dist/design-system199.js.map +0 -1
  413. package/dist/design-system202.js.map +0 -1
  414. package/dist/design-system205.js.map +0 -1
  415. package/dist/design-system214.js.map +0 -1
  416. package/dist/design-system40.js +0 -479
  417. package/dist/design-system40.js.map +0 -1
  418. package/dist/design-system43.js +0 -6
  419. package/dist/design-system43.js.map +0 -1
  420. package/dist/design-system46.js +0 -9
  421. package/dist/design-system46.js.map +0 -1
  422. package/dist/design-system50.js +0 -67
  423. package/dist/design-system50.js.map +0 -1
  424. package/dist/design-system60.js.map +0 -1
  425. package/dist/design-system63.js +0 -8
  426. package/dist/design-system67.js +0 -32
  427. package/dist/design-system67.js.map +0 -1
  428. package/dist/design-system74.js +0 -8
  429. package/dist/design-system74.js.map +0 -1
  430. package/dist/design-system79.js +0 -60
  431. package/dist/design-system79.js.map +0 -1
  432. package/dist/design-system82.js +0 -14
  433. package/dist/design-system82.js.map +0 -1
  434. package/dist/design-system86.js +0 -69
  435. package/dist/design-system86.js.map +0 -1
  436. package/dist/design-system89.js +0 -91
  437. package/dist/design-system89.js.map +0 -1
  438. package/dist/design-system93.js.map +0 -1
@@ -1,118 +1,72 @@
1
- import { Fragment as e, computed as t, createCommentVNode as n, createElementBlock as r, createElementVNode as i, createTextVNode as a, defineComponent as o, nextTick as s, normalizeClass as c, normalizeStyle as l, onMounted as u, openBlock as d, ref as f, renderList as p, renderSlot as m, toDisplayString as h, watch as g } from "vue";
2
- //#region src/components/BSegmented/BSegmented.vue?vue&type=script&setup=true&lang.ts
3
- var _ = ["aria-disabled"], v = [
4
- "aria-label",
5
- "aria-checked",
6
- "aria-disabled",
7
- "tabindex",
8
- "onClick",
9
- "onKeydown"
10
- ], y = { class: "b-segmented__item-inner" }, b = {
11
- key: 0,
12
- class: "b-segmented__item-icon",
13
- "aria-hidden": "true"
14
- }, x = { class: "b-segmented__item-label" }, S = /* @__PURE__ */ o({
15
- __name: "BSegmented",
16
- props: {
17
- modelValue: {},
18
- defaultValue: {},
19
- options: { default: () => [] },
1
+ import { B_RADIO_GROUP_KEY as e } from "./design-system163.js";
2
+ import t from "./design-system166.js";
3
+ import n from "./design-system169.js";
4
+ import { Fragment as r, computed as i, createBlock as a, createElementBlock as o, createTextVNode as s, defineComponent as c, mergeModels as l, normalizeClass as u, openBlock as d, provide as f, reactive as p, renderList as m, renderSlot as h, resolveDynamicComponent as g, toDisplayString as _, toRefs as v, useModel as y, withCtx as b } from "vue";
5
+ //#region src/components/BRadio/BRadioGroup.vue?vue&type=script&setup=true&lang.ts
6
+ var x = /* @__PURE__ */ c({
7
+ __name: "BRadioGroup",
8
+ props: /* @__PURE__ */ l({
20
9
  disabled: {
21
10
  type: Boolean,
22
11
  default: !1
23
12
  },
24
- size: { default: "default" },
13
+ name: { default: "" },
14
+ options: { default: () => void 0 },
15
+ optionType: { default: "default" },
16
+ size: { default: "middle" },
17
+ buttonStyle: { default: "outline" },
25
18
  block: {
26
19
  type: Boolean,
27
20
  default: !1
28
21
  }
29
- },
30
- emits: ["update:modelValue", "change"],
31
- setup(o, { emit: S }) {
32
- let C = S, w = t(() => o.options.map((e) => typeof e == "string" || typeof e == "number" ? {
22
+ }, {
23
+ modelValue: {},
24
+ modelModifiers: {}
25
+ }),
26
+ emits: /* @__PURE__ */ l(["change"], ["update:modelValue"]),
27
+ setup(c, { emit: l }) {
28
+ let x = y(c, "modelValue"), S = l, C = i(() => c.options ? c.options.map((e) => typeof e == "string" || typeof e == "number" ? {
33
29
  label: String(e),
34
- value: e,
35
- disabled: !1
36
- } : {
37
- label: String(e.label ?? e.value),
38
- value: e.value,
39
- disabled: e.disabled ?? !1,
40
- icon: e.icon
41
- })), T = t(() => o.modelValue !== void 0), E = f(o.modelValue ?? o.defaultValue ?? w.value[0]?.value);
42
- g(() => o.modelValue, (e) => {
43
- e !== void 0 && (E.value = e);
44
- }), g(w, (e) => {
45
- E.value === void 0 && e.length > 0 && (E.value = e[0].value);
46
- });
47
- let D = t(() => T.value ? o.modelValue : E.value), O = f(null), k = f(null);
48
- function A(e) {
49
- if (!O.value) return;
50
- let t = O.value.querySelectorAll(".b-segmented__item")[e];
51
- if (!t) return;
52
- let n = O.value.getBoundingClientRect().left, { left: r, width: i } = t.getBoundingClientRect();
53
- k.value = {
54
- transform: `translateX(${r - n}px)`,
55
- width: `${i}px`
56
- };
30
+ value: e
31
+ } : e) : []);
32
+ function w(e) {
33
+ x.value = e, S("change", e);
57
34
  }
58
- let j = t(() => w.value.findIndex((e) => e.value === D.value));
59
- g(j, async (e) => {
60
- e < 0 || (await s(), A(e));
61
- }, { immediate: !1 }), u(() => {
62
- j.value >= 0 && A(j.value);
35
+ let { disabled: T, name: E, size: D, optionType: O, buttonStyle: k } = v(p({
36
+ disabled: c.disabled,
37
+ name: c.name,
38
+ size: c.size,
39
+ optionType: c.optionType,
40
+ buttonStyle: c.buttonStyle
41
+ }));
42
+ f(e, {
43
+ modelValue: i(() => x.value),
44
+ disabled: T,
45
+ name: E,
46
+ size: D,
47
+ optionType: O,
48
+ buttonStyle: k,
49
+ setValue: w
63
50
  });
64
- function M(e) {
65
- o.disabled || e.disabled || e.value !== D.value && (T.value || (E.value = e.value), C("update:modelValue", e.value), C("change", e.value));
66
- }
67
- function N(e, t) {
68
- (e.key === "Enter" || e.key === " ") && (e.preventDefault(), M(t)), (e.key === "ArrowRight" || e.key === "ArrowDown") && (e.preventDefault(), P(1)), (e.key === "ArrowLeft" || e.key === "ArrowUp") && (e.preventDefault(), P(-1));
69
- }
70
- function P(e) {
71
- if (!O.value) return;
72
- let t = Array.from(O.value.querySelectorAll(".b-segmented__item:not([aria-disabled=\"true\"])")), n = document.activeElement, r = t.indexOf(n);
73
- if (r < 0) {
74
- t[0]?.focus();
75
- return;
76
- }
77
- t[(r + e + t.length) % t.length]?.focus();
78
- }
79
- let F = t(() => ["b-segmented", {
80
- "b-segmented--disabled": o.disabled,
81
- "b-segmented--block": o.block,
82
- "b-segmented--small": o.size === "small",
83
- "b-segmented--large": o.size === "large"
84
- }]);
85
- return (t, s) => (d(), r("div", {
86
- ref_key: "rootRef",
87
- ref: O,
88
- class: c(F.value),
89
- role: "group",
90
- "aria-disabled": o.disabled ? "true" : void 0
91
- }, [k.value ? (d(), r("div", {
92
- key: 0,
93
- class: "b-segmented__thumb",
94
- "aria-hidden": "true",
95
- style: l({
96
- transform: k.value.transform,
97
- width: k.value.width
98
- })
99
- }, null, 4)) : n("", !0), (d(!0), r(e, null, p(w.value, (e) => (d(), r("div", {
100
- key: String(e.value),
101
- class: c(["b-segmented__item", {
102
- "b-segmented__item--selected": e.value === D.value,
103
- "b-segmented__item--disabled": e.disabled || o.disabled
51
+ let A = i(() => c.optionType === "button" ? n : t);
52
+ return (e, t) => (d(), o("div", {
53
+ class: u(["b-radio-group b:inline-flex b:flex-wrap b:items-center", {
54
+ "b-radio-group--block b:flex b:w-full": c.block,
55
+ "b:gap-2": c.optionType !== "button",
56
+ "b:gap-0": c.optionType === "button"
104
57
  }]),
105
- role: "radio",
106
- "aria-label": e.label,
107
- "aria-checked": e.value === D.value,
108
- "aria-disabled": e.disabled || o.disabled ? "true" : void 0,
109
- tabindex: o.disabled || e.disabled ? -1 : e.value === D.value ? 0 : -1,
110
- onClick: (t) => M(e),
111
- onKeydown: (t) => N(t, e)
112
- }, [i("div", y, [e.icon ? (d(), r("span", b, h(e.icon), 1)) : n("", !0), i("span", x, [m(t.$slots, "label", { option: e }, () => [a(h(e.label), 1)])])])], 42, v))), 128))], 10, _));
58
+ role: "radiogroup"
59
+ }, [C.value.length > 0 ? (d(!0), o(r, { key: 0 }, m(C.value, (e) => (d(), a(g(A.value), {
60
+ key: e.value,
61
+ value: e.value,
62
+ disabled: e.disabled
63
+ }, {
64
+ default: b(() => [s(_(e.label), 1)]),
65
+ _: 2
66
+ }, 1032, ["value", "disabled"]))), 128)) : h(e.$slots, "default", { key: 1 }, void 0, !0)], 2));
113
67
  }
114
68
  });
115
69
  //#endregion
116
- export { S as default };
70
+ export { x as default };
117
71
 
118
72
  //# sourceMappingURL=design-system170.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"design-system170.js","names":[],"sources":["../src/components/BSegmented/BSegmented.vue?vue&type=script&setup=true&lang.ts"],"sourcesContent":["import { defineComponent as _defineComponent } from 'vue'\nimport { normalizeStyle as _normalizeStyle, openBlock as _openBlock, createElementBlock as _createElementBlock, createCommentVNode as _createCommentVNode, renderList as _renderList, Fragment as _Fragment, toDisplayString as _toDisplayString, renderSlot as _renderSlot, createTextVNode as _createTextVNode, createElementVNode as _createElementVNode, normalizeClass as _normalizeClass } from \"vue\"\n\nconst _hoisted_1 = [\"aria-disabled\"]\nconst _hoisted_2 = [\"aria-label\", \"aria-checked\", \"aria-disabled\", \"tabindex\", \"onClick\", \"onKeydown\"]\nconst _hoisted_3 = { class: \"b-segmented__item-inner\" }\nconst _hoisted_4 = {\n key: 0,\n class: \"b-segmented__item-icon\",\n \"aria-hidden\": \"true\"\n}\nconst _hoisted_5 = { class: \"b-segmented__item-label\" }\n\nimport { computed, nextTick, onMounted, ref, watch } from 'vue';\n\nimport type { BSegmentedOption, BSegmentedRawOption } from './types';\n\n// ─────────────────────────────────────────────\n// Props\n// ─────────────────────────────────────────────\n\nexport default /*@__PURE__*/_defineComponent({\n __name: 'BSegmented',\n props: {\n modelValue: {},\n defaultValue: {},\n options: { default: () => ([]) },\n disabled: { type: Boolean, default: false },\n size: { default: 'default' },\n block: { type: Boolean, default: false }\n },\n emits: [\"update:modelValue\", \"change\"],\n setup(__props: any, { emit: __emit }) {\n\n\n\n// ─────────────────────────────────────────────\n// Emits\n// ─────────────────────────────────────────────\nconst emit = __emit;\n\n// ─────────────────────────────────────────────\n// Slots\n// ─────────────────────────────────────────────\n\n\n// ─────────────────────────────────────────────\n// Normalise options\n// ─────────────────────────────────────────────\nconst normalizedOptions = computed<BSegmentedOption[]>(() =>\n __props.options.map((opt) => {\n if (typeof opt === 'string' || typeof opt === 'number') {\n return { label: String(opt), value: opt, disabled: false };\n }\n return {\n label: String(opt.label ?? opt.value),\n value: opt.value,\n disabled: opt.disabled ?? false,\n icon: opt.icon,\n };\n }),\n);\n\n// ─────────────────────────────────────────────\n// Internal selection state\n// ─────────────────────────────────────────────\nconst isControlled = computed(() => __props.modelValue !== undefined);\n\nconst internalValue = ref<string | number | undefined>(\n __props.modelValue ?? __props.defaultValue ?? normalizedOptions.value[0]?.value,\n);\n\n// Sync controlled value → internal\nwatch(\n () => __props.modelValue,\n (val) => {\n if (val !== undefined) internalValue.value = val;\n },\n);\n\n// Sync first option as default when options change and nothing is selected\nwatch(normalizedOptions, (opts) => {\n if (internalValue.value === undefined && opts.length > 0) {\n internalValue.value = opts[0].value;\n }\n});\n\nconst selectedValue = computed(() => (isControlled.value ? __props.modelValue : internalValue.value));\n\n// ─────────────────────────────────────────────\n// Thumb (animated indicator) positioning\n// ─────────────────────────────────────────────\nconst rootRef = ref<HTMLElement | null>(null);\nconst thumbStyle = ref<{ transform: string; width: string } | null>(null);\n\nfunction updateThumb(index: number) {\n if (!rootRef.value) return;\n const items = rootRef.value.querySelectorAll<HTMLElement>('.b-segmented__item');\n const target = items[index];\n if (!target) return;\n\n const containerLeft = rootRef.value.getBoundingClientRect().left;\n const { left, width } = target.getBoundingClientRect();\n thumbStyle.value = {\n transform: `translateX(${left - containerLeft}px)`,\n width: `${width}px`,\n };\n}\n\nconst selectedIndex = computed(() =>\n normalizedOptions.value.findIndex((o) => o.value === selectedValue.value),\n);\n\nwatch(\n selectedIndex,\n async (idx) => {\n if (idx < 0) return;\n await nextTick();\n updateThumb(idx);\n },\n { immediate: false },\n);\n\nonMounted(() => {\n if (selectedIndex.value >= 0) updateThumb(selectedIndex.value);\n});\n\n// ─────────────────────────────────────────────\n// Selection logic\n// ─────────────────────────────────────────────\nfunction select(opt: BSegmentedOption) {\n if (__props.disabled || opt.disabled) return;\n if (opt.value === selectedValue.value) return;\n\n if (!isControlled.value) {\n internalValue.value = opt.value;\n }\n emit('update:modelValue', opt.value);\n emit('change', opt.value);\n}\n\n// ─────────────────────────────────────────────\n// Keyboard navigation\n// ─────────────────────────────────────────────\nfunction onKeydown(event: KeyboardEvent, opt: BSegmentedOption) {\n if (event.key === 'Enter' || event.key === ' ') {\n event.preventDefault();\n select(opt);\n }\n if (event.key === 'ArrowRight' || event.key === 'ArrowDown') {\n event.preventDefault();\n focusNext(1);\n }\n if (event.key === 'ArrowLeft' || event.key === 'ArrowUp') {\n event.preventDefault();\n focusNext(-1);\n }\n}\n\nfunction focusNext(direction: 1 | -1) {\n if (!rootRef.value) return;\n const items = Array.from(\n rootRef.value.querySelectorAll<HTMLElement>('.b-segmented__item:not([aria-disabled=\"true\"])'),\n );\n const activeEl = document.activeElement as HTMLElement;\n const currentIdx = items.indexOf(activeEl);\n if (currentIdx < 0) {\n items[0]?.focus();\n return;\n }\n const next = (currentIdx + direction + items.length) % items.length;\n items[next]?.focus();\n}\n\n// ─────────────────────────────────────────────\n// Root classes\n// ─────────────────────────────────────────────\nconst rootClasses = computed(() => [\n 'b-segmented',\n {\n 'b-segmented--disabled': __props.disabled,\n 'b-segmented--block': __props.block,\n 'b-segmented--small': __props.size === 'small',\n 'b-segmented--large': __props.size === 'large',\n },\n]);\n\nreturn (_ctx: any,_cache: any) => {\n return (_openBlock(), _createElementBlock(\"div\", {\n ref_key: \"rootRef\",\n ref: rootRef,\n class: _normalizeClass(rootClasses.value),\n role: \"group\",\n \"aria-disabled\": __props.disabled ? 'true' : undefined\n }, [\n (thumbStyle.value)\n ? (_openBlock(), _createElementBlock(\"div\", {\n key: 0,\n class: \"b-segmented__thumb\",\n \"aria-hidden\": \"true\",\n style: _normalizeStyle({ transform: thumbStyle.value.transform, width: thumbStyle.value.width })\n }, null, 4))\n : _createCommentVNode(\"\", true),\n (_openBlock(true), _createElementBlock(_Fragment, null, _renderList(normalizedOptions.value, (opt) => {\n return (_openBlock(), _createElementBlock(\"div\", {\n key: String(opt.value),\n class: _normalizeClass([\"b-segmented__item\", {\n 'b-segmented__item--selected': opt.value === selectedValue.value,\n 'b-segmented__item--disabled': opt.disabled || __props.disabled,\n }]),\n role: \"radio\",\n \"aria-label\": opt.label,\n \"aria-checked\": opt.value === selectedValue.value,\n \"aria-disabled\": opt.disabled || __props.disabled ? 'true' : undefined,\n tabindex: __props.disabled || opt.disabled ? -1 : opt.value === selectedValue.value ? 0 : -1,\n onClick: ($event: any) => (select(opt)),\n onKeydown: ($event: any) => (onKeydown($event, opt))\n }, [\n _createElementVNode(\"div\", _hoisted_3, [\n (opt.icon)\n ? (_openBlock(), _createElementBlock(\"span\", _hoisted_4, _toDisplayString(opt.icon), 1))\n : _createCommentVNode(\"\", true),\n _createElementVNode(\"span\", _hoisted_5, [\n _renderSlot(_ctx.$slots, \"label\", { option: opt }, () => [\n _createTextVNode(_toDisplayString(opt.label), 1)\n ])\n ])\n ])\n ], 42, _hoisted_2))\n }), 128))\n ], 10, _hoisted_1))\n}\n}\n\n})"],"mappings":"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"}
1
+ {"version":3,"file":"design-system170.js","names":[],"sources":["../src/components/BRadio/BRadioGroup.vue"],"sourcesContent":["<script lang=\"ts\" setup>\nimport { computed, provide, reactive, toRefs } from 'vue';\nimport BRadio from './BRadio.vue';\nimport BRadioButton from './BRadioButton.vue';\nimport { B_RADIO_GROUP_KEY, type BRadioOption } from './types';\n\n//#region Props\nconst {\n disabled = false,\n name = '',\n options = undefined,\n optionType = 'default',\n size = 'middle',\n buttonStyle = 'outline',\n block = false,\n} = defineProps<{\n /** Disable all radios in the group. */\n disabled?: boolean;\n /** The name property of all child input elements. */\n name?: string;\n /** Shorthand options to render radios from an array. */\n options?: BRadioOption[] | string[] | number[];\n /** Style type of radio: default or button. */\n optionType?: 'default' | 'button';\n /** Size of radio button (only works with button style). */\n size?: 'large' | 'middle' | 'small';\n /** Style of radio button appearance. */\n buttonStyle?: 'outline' | 'solid';\n /** Whether to fit the width of the parent container. */\n block?: boolean;\n}>();\n\n/**\n * Currently selected value.\n */\nconst model = defineModel<string | number>();\n\nconst emit = defineEmits<{\n change: [value: string | number | undefined, event?: Event];\n}>();\n//#endregion\n\n//#region Normalize options\nconst normalizedOptions = computed<BRadioOption[]>(() => {\n if (!options) return [];\n return options.map((opt) => {\n if (typeof opt === 'string' || typeof opt === 'number') {\n return { label: String(opt), value: opt };\n }\n return opt;\n });\n});\n//#endregion\n\n//#region Group context\nfunction setValue(val: string | number) {\n model.value = val;\n emit('change', val);\n}\n\nconst props = reactive({ disabled, name, size, optionType, buttonStyle });\nconst {\n disabled: disabledRef,\n name: nameRef,\n size: sizeRef,\n optionType: optionTypeRef,\n buttonStyle: buttonStyleRef,\n} = toRefs(props);\n\nprovide(B_RADIO_GROUP_KEY, {\n modelValue: computed(() => model.value),\n disabled: disabledRef,\n name: nameRef,\n size: sizeRef,\n optionType: optionTypeRef,\n buttonStyle: buttonStyleRef,\n setValue,\n});\n//#endregion\n\n//#region Computed component\nconst radioComponent = computed(() => (optionType === 'button' ? BRadioButton : BRadio));\n//#endregion\n</script>\n\n<template>\n <div\n class=\"b-radio-group b:inline-flex b:flex-wrap b:items-center\"\n :class=\"{\n 'b-radio-group--block b:flex b:w-full': block,\n 'b:gap-2': optionType !== 'button',\n 'b:gap-0': optionType === 'button',\n }\"\n role=\"radiogroup\"\n >\n <template v-if=\"normalizedOptions.length > 0\">\n <component\n :is=\"radioComponent\"\n v-for=\"opt in normalizedOptions\"\n :key=\"opt.value\"\n :value=\"opt.value\"\n :disabled=\"opt.disabled\"\n >\n {{ opt.label }}\n </component>\n </template>\n <slot v-else />\n </div>\n</template>\n\n<style scoped>\n.b-radio-group--block > * {\n flex: 1;\n}\n</style>\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;EAmCA,IAAM,IAAQ,EAA4B,GAAA,aAAE,EAEtC,IAAO,GAMP,IAAoB,QACnB,EAAA,UACE,EAAA,QAAQ,KAAK,MACd,OAAO,KAAQ,YAAY,OAAO,KAAQ,WACrC;GAAE,OAAO,OAAO,EAAI;GAAE,OAAO;GAAK,GAEpC,EACP,GANmB,EAAE,CAOvB;EAIF,SAAS,EAAS,GAAsB;AAEtC,GADA,EAAM,QAAQ,GACd,EAAK,UAAU,EAAI;;EAIrB,IAAM,EACJ,UAAU,GACV,MAAM,GACN,MAAM,GACN,YAAY,GACZ,aAAa,MACX,EAPU,EAAS;GAAE,UAAO,EAAA;GAAG,MAAG,EAAA;GAAG,MAAG,EAAA;GAAG,YAAS,EAAA;GAAG,aAAU,EAAA;GAAG,CAAC,CAOxD;AAEjB,IAAQ,GAAmB;GACzB,YAAY,QAAe,EAAM,MAAM;GACvC,UAAU;GACV,MAAM;GACN,MAAM;GACN,YAAY;GACZ,aAAa;GACb;GACD,CAAC;EAIF,IAAM,IAAiB,QAAgB,EAAA,eAAe,WAAW,IAAe,EAAQ;yBAKtF,EAqBM,OAAA;GApBJ,OAAK,EAAA,CAAC,0DAAwD;4CACN,EAAA;eAAwB,EAAA,eAAU;eAAgC,EAAA,eAAU;;GAKpI,MAAK;MAEW,EAAA,MAAkB,SAAM,KAAA,EAAA,GAAA,EACtC,EAQY,GAAA,EAAA,KAAA,GAAA,EAAA,EANI,EAAA,QAAP,YAFT,EAQY,EAPL,EAAA,MAAc,EAAA;GAElB,KAAK,EAAI;GACT,OAAO,EAAI;GACX,UAAU,EAAI;;oBAEA,CAAA,EAAA,EAAZ,EAAI,MAAK,EAAA,EAAA,CAAA,CAAA;;6CAGhB,EAAe,EAAA,QAAA,WAAA,EAAA,KAAA,GAAA,EAAA,KAAA,GAAA,GAAA,CAAA,EAAA,EAAA"}
@@ -1,8 +1,9 @@
1
- import e from "./design-system170.js";
1
+ import e from "./design-system14.js";
2
+ import t from "./design-system170.js";
2
3
  /* empty css */
3
- //#region src/components/BSegmented/BSegmented.vue
4
- var t = e;
4
+ //#region src/components/BRadio/BRadioGroup.vue
5
+ var n = /* @__PURE__ */ e(t, [["__scopeId", "data-v-a8ec6dad"]]);
5
6
  //#endregion
6
- export { t as default };
7
+ export { n as default };
7
8
 
8
9
  //# sourceMappingURL=design-system172.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"design-system172.js","names":[],"sources":["../src/components/BSegmented/BSegmented.vue"],"sourcesContent":["<script setup lang=\"ts\">\nimport { computed, nextTick, onMounted, ref, watch } from 'vue';\n\nimport type { BSegmentedOption, BSegmentedRawOption } from './types';\n\n// ─────────────────────────────────────────────\n// Props\n// ─────────────────────────────────────────────\nconst {\n modelValue,\n defaultValue,\n options = [],\n disabled = false,\n size = 'default',\n block = false,\n} = defineProps<{\n /**\n * Currently selected value (controlled / two-way binding via v-model).\n * When provided, the component is in controlled mode.\n */\n modelValue?: string | number;\n /**\n * Initial selected value for uncontrolled mode.\n * Ignored when `modelValue` is set.\n * @default first option value\n */\n defaultValue?: string | number;\n /** Segmented options. Accepts strings, numbers, or option objects. */\n options?: BSegmentedRawOption[];\n /** Whether the whole control is disabled. @default false */\n disabled?: boolean;\n /** Size of the component. @default 'default' */\n size?: 'small' | 'default' | 'large';\n /** Whether the segmented fills the full width of its container. @default false */\n block?: boolean;\n}>();\n\n// ─────────────────────────────────────────────\n// Emits\n// ─────────────────────────────────────────────\nconst emit = defineEmits<{\n /** Fires when the selected value changes. */\n (e: 'update:modelValue', value: string | number): void;\n /** Fires when the selected value changes (mirrors `update:modelValue`). */\n (e: 'change', value: string | number): void;\n}>();\n\n// ─────────────────────────────────────────────\n// Slots\n// ─────────────────────────────────────────────\ndefineSlots<{\n /** Custom label renderer for each option. Receives the resolved option object. */\n label?: (props: { option: BSegmentedOption }) => unknown;\n}>();\n\n// ─────────────────────────────────────────────\n// Normalise options\n// ─────────────────────────────────────────────\nconst normalizedOptions = computed<BSegmentedOption[]>(() =>\n options.map((opt) => {\n if (typeof opt === 'string' || typeof opt === 'number') {\n return { label: String(opt), value: opt, disabled: false };\n }\n return {\n label: String(opt.label ?? opt.value),\n value: opt.value,\n disabled: opt.disabled ?? false,\n icon: opt.icon,\n };\n }),\n);\n\n// ─────────────────────────────────────────────\n// Internal selection state\n// ─────────────────────────────────────────────\nconst isControlled = computed(() => modelValue !== undefined);\n\nconst internalValue = ref<string | number | undefined>(\n modelValue ?? defaultValue ?? normalizedOptions.value[0]?.value,\n);\n\n// Sync controlled value → internal\nwatch(\n () => modelValue,\n (val) => {\n if (val !== undefined) internalValue.value = val;\n },\n);\n\n// Sync first option as default when options change and nothing is selected\nwatch(normalizedOptions, (opts) => {\n if (internalValue.value === undefined && opts.length > 0) {\n internalValue.value = opts[0].value;\n }\n});\n\nconst selectedValue = computed(() => (isControlled.value ? modelValue : internalValue.value));\n\n// ─────────────────────────────────────────────\n// Thumb (animated indicator) positioning\n// ─────────────────────────────────────────────\nconst rootRef = ref<HTMLElement | null>(null);\nconst thumbStyle = ref<{ transform: string; width: string } | null>(null);\n\nfunction updateThumb(index: number) {\n if (!rootRef.value) return;\n const items = rootRef.value.querySelectorAll<HTMLElement>('.b-segmented__item');\n const target = items[index];\n if (!target) return;\n\n const containerLeft = rootRef.value.getBoundingClientRect().left;\n const { left, width } = target.getBoundingClientRect();\n thumbStyle.value = {\n transform: `translateX(${left - containerLeft}px)`,\n width: `${width}px`,\n };\n}\n\nconst selectedIndex = computed(() =>\n normalizedOptions.value.findIndex((o) => o.value === selectedValue.value),\n);\n\nwatch(\n selectedIndex,\n async (idx) => {\n if (idx < 0) return;\n await nextTick();\n updateThumb(idx);\n },\n { immediate: false },\n);\n\nonMounted(() => {\n if (selectedIndex.value >= 0) updateThumb(selectedIndex.value);\n});\n\n// ─────────────────────────────────────────────\n// Selection logic\n// ─────────────────────────────────────────────\nfunction select(opt: BSegmentedOption) {\n if (disabled || opt.disabled) return;\n if (opt.value === selectedValue.value) return;\n\n if (!isControlled.value) {\n internalValue.value = opt.value;\n }\n emit('update:modelValue', opt.value);\n emit('change', opt.value);\n}\n\n// ─────────────────────────────────────────────\n// Keyboard navigation\n// ─────────────────────────────────────────────\nfunction onKeydown(event: KeyboardEvent, opt: BSegmentedOption) {\n if (event.key === 'Enter' || event.key === ' ') {\n event.preventDefault();\n select(opt);\n }\n if (event.key === 'ArrowRight' || event.key === 'ArrowDown') {\n event.preventDefault();\n focusNext(1);\n }\n if (event.key === 'ArrowLeft' || event.key === 'ArrowUp') {\n event.preventDefault();\n focusNext(-1);\n }\n}\n\nfunction focusNext(direction: 1 | -1) {\n if (!rootRef.value) return;\n const items = Array.from(\n rootRef.value.querySelectorAll<HTMLElement>('.b-segmented__item:not([aria-disabled=\"true\"])'),\n );\n const activeEl = document.activeElement as HTMLElement;\n const currentIdx = items.indexOf(activeEl);\n if (currentIdx < 0) {\n items[0]?.focus();\n return;\n }\n const next = (currentIdx + direction + items.length) % items.length;\n items[next]?.focus();\n}\n\n// ─────────────────────────────────────────────\n// Root classes\n// ─────────────────────────────────────────────\nconst rootClasses = computed(() => [\n 'b-segmented',\n {\n 'b-segmented--disabled': disabled,\n 'b-segmented--block': block,\n 'b-segmented--small': size === 'small',\n 'b-segmented--large': size === 'large',\n },\n]);\n</script>\n\n<template>\n <div\n ref=\"rootRef\"\n :class=\"rootClasses\"\n role=\"group\"\n :aria-disabled=\"disabled ? 'true' : undefined\"\n >\n <!-- Animated thumb - positioned via JS -->\n <div\n v-if=\"thumbStyle\"\n class=\"b-segmented__thumb\"\n aria-hidden=\"true\"\n :style=\"{ transform: thumbStyle.transform, width: thumbStyle.width }\"\n />\n\n <!-- Items -->\n <div\n v-for=\"opt in normalizedOptions\"\n :key=\"String(opt.value)\"\n class=\"b-segmented__item\"\n :class=\"{\n 'b-segmented__item--selected': opt.value === selectedValue,\n 'b-segmented__item--disabled': opt.disabled || disabled,\n }\"\n role=\"radio\"\n :aria-label=\"opt.label\"\n :aria-checked=\"opt.value === selectedValue\"\n :aria-disabled=\"opt.disabled || disabled ? 'true' : undefined\"\n :tabindex=\"disabled || opt.disabled ? -1 : opt.value === selectedValue ? 0 : -1\"\n @click=\"select(opt)\"\n @keydown=\"onKeydown($event, opt)\"\n >\n <div class=\"b-segmented__item-inner\">\n <!-- Icon -->\n <span v-if=\"opt.icon\" class=\"b-segmented__item-icon\" aria-hidden=\"true\">{{\n opt.icon\n }}</span>\n\n <!-- Label - slot or prop -->\n <span class=\"b-segmented__item-label\">\n <slot name=\"label\" :option=\"opt\">{{ opt.label }}</slot>\n </span>\n </div>\n </div>\n </div>\n</template>\n\n<style>\n/* ─────────────────────────────────────────────\n BSegmented - CSS custom properties (scoped to root)\n ───────────────────────────────────────────── */\n.b-segmented {\n /* Surface */\n --b-segmented-bg: oklch(95% 0.003 260);\n --b-segmented-border-radius: 8px;\n --b-segmented-padding: 2px;\n\n /* Item */\n --b-segmented-item-color: oklch(40% 0.02 260);\n --b-segmented-item-hover-color: oklch(20% 0.02 260);\n --b-segmented-item-hover-bg: oklch(100% 0 0 / 50%);\n --b-segmented-item-padding: 0 11px;\n --b-segmented-item-border-radius: 6px;\n\n /* Selected thumb */\n --b-segmented-thumb-bg: oklch(100% 0 0);\n --b-segmented-thumb-shadow: 0 1px 2px oklch(0% 0 0 / 10%), 0 0 0 1px oklch(0% 0 0 / 6%);\n --b-segmented-thumb-transition:\n transform 200ms cubic-bezier(0.34, 0.69, 0.1, 1), width 200ms cubic-bezier(0.34, 0.69, 0.1, 1);\n\n /* Selected text */\n --b-segmented-selected-color: oklch(20% 0.02 260);\n --b-segmented-selected-font-weight: 500;\n\n /* Disabled */\n --b-segmented-disabled-opacity: 0.4;\n --b-segmented-disabled-cursor: not-allowed;\n\n /* Height variants */\n --b-segmented-height: 32px;\n\n /* Focus ring */\n --b-segmented-focus-ring: 0 0 0 2px oklch(54.6% 0.245 262.881 / 20%);\n\n /* Transition */\n --b-segmented-transition-duration: 200ms;\n\n /* ── Layout ── */\n position: relative;\n display: inline-flex;\n align-items: center;\n background: var(--b-segmented-bg);\n border-radius: var(--b-segmented-border-radius);\n padding: var(--b-segmented-padding);\n box-sizing: border-box;\n user-select: none;\n height: var(--b-segmented-height);\n font-size: 14px;\n line-height: 1;\n}\n\n/* ── Block (full width) ── */\n.b-segmented--block {\n display: flex;\n width: 100%;\n}\n\n.b-segmented--block .b-segmented__item {\n flex: 1;\n}\n\n/* ── Size variants ── */\n.b-segmented--small {\n --b-segmented-height: 24px;\n --b-segmented-item-padding: 0 7px;\n font-size: 12px;\n}\n\n.b-segmented--large {\n --b-segmented-height: 40px;\n --b-segmented-item-padding: 0 15px;\n font-size: 16px;\n}\n\n/* ── Thumb (sliding indicator) ── */\n.b-segmented__thumb {\n position: absolute;\n top: var(--b-segmented-padding);\n left: 0;\n height: calc(100% - var(--b-segmented-padding) * 2);\n background: var(--b-segmented-thumb-bg);\n border-radius: var(--b-segmented-item-border-radius);\n box-shadow: var(--b-segmented-thumb-shadow);\n transition: var(--b-segmented-thumb-transition);\n pointer-events: none;\n will-change: transform, width;\n}\n\n/* ── Item ── */\n.b-segmented__item {\n position: relative;\n display: flex;\n align-items: center;\n justify-content: center;\n height: calc(var(--b-segmented-height) - var(--b-segmented-padding) * 2);\n padding: var(--b-segmented-item-padding);\n border-radius: var(--b-segmented-item-border-radius);\n color: var(--b-segmented-item-color);\n cursor: pointer;\n transition:\n color var(--b-segmented-transition-duration),\n background var(--b-segmented-transition-duration);\n white-space: nowrap;\n outline: none;\n box-sizing: border-box;\n z-index: 1;\n}\n\n.b-segmented__item:hover:not(.b-segmented__item--selected):not(.b-segmented__item--disabled) {\n color: var(--b-segmented-item-hover-color);\n background: var(--b-segmented-item-hover-bg);\n}\n\n.b-segmented__item:focus-visible {\n box-shadow: var(--b-segmented-focus-ring);\n}\n\n/* ── Selected item ── */\n.b-segmented__item--selected {\n color: var(--b-segmented-selected-color);\n font-weight: var(--b-segmented-selected-font-weight);\n}\n\n/* ── Disabled ── */\n.b-segmented--disabled,\n.b-segmented__item--disabled {\n opacity: var(--b-segmented-disabled-opacity);\n cursor: var(--b-segmented-disabled-cursor);\n pointer-events: none;\n}\n\n/* Re-enable pointer events on items when only the item is disabled (not whole control) */\n.b-segmented:not(.b-segmented--disabled) .b-segmented__item--disabled {\n pointer-events: auto;\n cursor: var(--b-segmented-disabled-cursor);\n}\n\n/* ── Inner wrapper (icon + label) ── */\n.b-segmented__item-inner {\n display: flex;\n align-items: center;\n gap: 6px;\n line-height: 1;\n}\n\n.b-segmented__item-icon {\n display: flex;\n align-items: center;\n font-size: 1em;\n flex-shrink: 0;\n}\n\n.b-segmented__item-label {\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n}\n\n/* ── Dark mode ── */\n[data-prefers-color='dark'] .b-segmented {\n --b-segmented-bg: oklch(22% 0.02 260);\n --b-segmented-item-color: oklch(72% 0.01 260);\n --b-segmented-item-hover-color: oklch(92% 0.005 260);\n --b-segmented-item-hover-bg: oklch(100% 0 0 / 8%);\n --b-segmented-thumb-bg: oklch(30% 0.02 260);\n --b-segmented-thumb-shadow: 0 1px 2px oklch(0% 0 0 / 30%), 0 0 0 1px oklch(0% 0 0 / 20%);\n --b-segmented-selected-color: oklch(95% 0.005 260);\n}\n\n@media (prefers-color-scheme: dark) {\n [data-prefers-color='system'] .b-segmented {\n --b-segmented-bg: oklch(22% 0.02 260);\n --b-segmented-item-color: oklch(72% 0.01 260);\n --b-segmented-item-hover-color: oklch(92% 0.005 260);\n --b-segmented-item-hover-bg: oklch(100% 0 0 / 8%);\n --b-segmented-thumb-bg: oklch(30% 0.02 260);\n --b-segmented-thumb-shadow: 0 1px 2px oklch(0% 0 0 / 30%), 0 0 0 1px oklch(0% 0 0 / 20%);\n --b-segmented-selected-color: oklch(95% 0.005 260);\n }\n}\n\n/* ── Reduced motion ── */\n@media (prefers-reduced-motion: reduce) {\n .b-segmented {\n --b-segmented-thumb-transition: none;\n --b-segmented-transition-duration: 0ms;\n }\n}\n</style>\n"],"mappings":""}
1
+ {"version":3,"file":"design-system172.js","names":[],"sources":["../src/components/BRadio/BRadioGroup.vue"],"sourcesContent":["<script lang=\"ts\" setup>\nimport { computed, provide, reactive, toRefs } from 'vue';\nimport BRadio from './BRadio.vue';\nimport BRadioButton from './BRadioButton.vue';\nimport { B_RADIO_GROUP_KEY, type BRadioOption } from './types';\n\n//#region Props\nconst {\n disabled = false,\n name = '',\n options = undefined,\n optionType = 'default',\n size = 'middle',\n buttonStyle = 'outline',\n block = false,\n} = defineProps<{\n /** Disable all radios in the group. */\n disabled?: boolean;\n /** The name property of all child input elements. */\n name?: string;\n /** Shorthand options to render radios from an array. */\n options?: BRadioOption[] | string[] | number[];\n /** Style type of radio: default or button. */\n optionType?: 'default' | 'button';\n /** Size of radio button (only works with button style). */\n size?: 'large' | 'middle' | 'small';\n /** Style of radio button appearance. */\n buttonStyle?: 'outline' | 'solid';\n /** Whether to fit the width of the parent container. */\n block?: boolean;\n}>();\n\n/**\n * Currently selected value.\n */\nconst model = defineModel<string | number>();\n\nconst emit = defineEmits<{\n change: [value: string | number | undefined, event?: Event];\n}>();\n//#endregion\n\n//#region Normalize options\nconst normalizedOptions = computed<BRadioOption[]>(() => {\n if (!options) return [];\n return options.map((opt) => {\n if (typeof opt === 'string' || typeof opt === 'number') {\n return { label: String(opt), value: opt };\n }\n return opt;\n });\n});\n//#endregion\n\n//#region Group context\nfunction setValue(val: string | number) {\n model.value = val;\n emit('change', val);\n}\n\nconst props = reactive({ disabled, name, size, optionType, buttonStyle });\nconst {\n disabled: disabledRef,\n name: nameRef,\n size: sizeRef,\n optionType: optionTypeRef,\n buttonStyle: buttonStyleRef,\n} = toRefs(props);\n\nprovide(B_RADIO_GROUP_KEY, {\n modelValue: computed(() => model.value),\n disabled: disabledRef,\n name: nameRef,\n size: sizeRef,\n optionType: optionTypeRef,\n buttonStyle: buttonStyleRef,\n setValue,\n});\n//#endregion\n\n//#region Computed component\nconst radioComponent = computed(() => (optionType === 'button' ? BRadioButton : BRadio));\n//#endregion\n</script>\n\n<template>\n <div\n class=\"b-radio-group b:inline-flex b:flex-wrap b:items-center\"\n :class=\"{\n 'b-radio-group--block b:flex b:w-full': block,\n 'b:gap-2': optionType !== 'button',\n 'b:gap-0': optionType === 'button',\n }\"\n role=\"radiogroup\"\n >\n <template v-if=\"normalizedOptions.length > 0\">\n <component\n :is=\"radioComponent\"\n v-for=\"opt in normalizedOptions\"\n :key=\"opt.value\"\n :value=\"opt.value\"\n :disabled=\"opt.disabled\"\n >\n {{ opt.label }}\n </component>\n </template>\n <slot v-else />\n </div>\n</template>\n\n<style scoped>\n.b-radio-group--block > * {\n flex: 1;\n}\n</style>\n"],"mappings":""}
@@ -1,14 +1,185 @@
1
- //#region src/components/BSelect/types.ts
2
- var e = /* @__PURE__ */ function(e) {
3
- return e.Multiple = "multiple", e.Tags = "tags", e;
4
- }({}), t = /* @__PURE__ */ function(e) {
5
- return e.Outlined = "outlined", e.Filled = "filled", e.Borderless = "borderless", e;
6
- }({}), n = /* @__PURE__ */ function(e) {
7
- return e.Error = "error", e.Warning = "warning", e;
8
- }({}), r = /* @__PURE__ */ function(e) {
9
- return e.BottomLeft = "bottomLeft", e.BottomRight = "bottomRight", e.TopLeft = "topLeft", e.TopRight = "topRight", e;
10
- }({});
1
+ import { useComponentId as e } from "./design-system10.js";
2
+ import { Fragment as t, computed as n, createElementBlock as r, createElementVNode as i, defineComponent as a, mergeModels as o, normalizeClass as s, openBlock as c, ref as l, renderList as u, renderSlot as d, unref as f, useModel as p, watch as m } from "vue";
3
+ //#region src/components/BRate/BRate.vue?vue&type=script&setup=true&lang.ts
4
+ var h = [
5
+ "aria-label",
6
+ "aria-disabled",
7
+ "aria-valuenow",
8
+ "aria-valuemax",
9
+ "aria-valuetext",
10
+ "tabindex"
11
+ ], g = [
12
+ "title",
13
+ "onMousemove",
14
+ "onClick"
15
+ ], _ = {
16
+ class: "b-rate__star-first",
17
+ "aria-hidden": "true"
18
+ }, v = ["data-character"], y = {
19
+ key: 1,
20
+ class: "b-rate__icon",
21
+ viewBox: "0 0 24 24",
22
+ fill: "currentColor",
23
+ "aria-hidden": "true"
24
+ }, b = {
25
+ class: "b-rate__star-second",
26
+ "aria-hidden": "true"
27
+ }, x = ["data-character"], S = {
28
+ key: 1,
29
+ class: "b-rate__icon",
30
+ viewBox: "0 0 24 24",
31
+ fill: "currentColor",
32
+ "aria-hidden": "true"
33
+ }, C = ["name", "value"], w = /* @__PURE__ */ a({
34
+ __name: "BRate",
35
+ props: /* @__PURE__ */ o({
36
+ allowClear: {
37
+ type: Boolean,
38
+ default: !0
39
+ },
40
+ allowHalf: {
41
+ type: Boolean,
42
+ default: !1
43
+ },
44
+ count: { default: 5 },
45
+ disabled: {
46
+ type: Boolean,
47
+ default: !1
48
+ },
49
+ keyboard: {
50
+ type: Boolean,
51
+ default: !0
52
+ },
53
+ size: { default: "default" },
54
+ tooltips: { default: () => [] },
55
+ character: {}
56
+ }, {
57
+ modelValue: { default: 0 },
58
+ modelModifiers: {}
59
+ }),
60
+ emits: /* @__PURE__ */ o([
61
+ "hover-change",
62
+ "change",
63
+ "focus",
64
+ "blur",
65
+ "keydown"
66
+ ], ["update:modelValue"]),
67
+ setup(a, { expose: o, emit: w }) {
68
+ let T = p(a, "modelValue"), E = w, { componentUID: D } = e(), O = l(0), k = l(!1), A = l(0), j = n(() => O.value > 0 ? O.value : T.value), M = n(() => {
69
+ let e = [];
70
+ for (let t = 1; t <= a.count; t++) e.push({
71
+ index: t,
72
+ value: t
73
+ });
74
+ return e;
75
+ });
76
+ function N(e) {
77
+ let t = j.value;
78
+ return e <= Math.floor(t) ? "full" : a.allowHalf && e - .5 <= t && e > t ? "half" : "zero";
79
+ }
80
+ function P(e, t) {
81
+ if (a.disabled) return;
82
+ let n = t && a.allowHalf ? e - .5 : e;
83
+ a.allowClear && n === T.value ? (T.value = 0, E("change", 0)) : (T.value = n, E("change", n));
84
+ }
85
+ function F(e, t) {
86
+ if (a.disabled) return;
87
+ let n = t.currentTarget.getBoundingClientRect(), r = t.clientX - n.left < n.width / 2, i;
88
+ i = a.allowHalf && r ? e - .5 : e, i !== O.value && (O.value = i, E("hover-change", i));
89
+ }
90
+ function I() {
91
+ a.disabled || (O.value = 0, E("hover-change", 0));
92
+ }
93
+ function L() {
94
+ k.value = !0, A.value = Math.ceil(T.value) || 1, E("focus");
95
+ }
96
+ function R() {
97
+ k.value = !1, A.value = 0, E("blur");
98
+ }
99
+ function z(e) {
100
+ if (a.disabled || !a.keyboard) return;
101
+ E("keydown", e);
102
+ let t = a.allowHalf ? .5 : 1;
103
+ switch (e.key) {
104
+ case "ArrowRight":
105
+ case "ArrowUp": {
106
+ e.preventDefault();
107
+ let n = Math.min(T.value + t, a.count);
108
+ T.value = n, A.value = Math.ceil(n), E("change", n);
109
+ break;
110
+ }
111
+ case "ArrowLeft":
112
+ case "ArrowDown": {
113
+ e.preventDefault();
114
+ let n = Math.max(T.value - t, 0);
115
+ T.value = n, A.value = Math.ceil(n) || 1, E("change", n);
116
+ break;
117
+ }
118
+ case "Enter":
119
+ case " ":
120
+ e.preventDefault(), a.allowClear && A.value === Math.ceil(T.value) && (T.value = 0, E("change", 0));
121
+ break;
122
+ }
123
+ }
124
+ let B = l(null);
125
+ function V() {
126
+ B.value?.focus();
127
+ }
128
+ function H() {
129
+ B.value?.blur();
130
+ }
131
+ return o({
132
+ focus: V,
133
+ blur: H
134
+ }), m(O, (e) => {
135
+ e === 0 && (A.value = Math.ceil(T.value) || 0);
136
+ }), (e, n) => (c(), r("div", {
137
+ ref_key: "rootRef",
138
+ ref: B,
139
+ class: s(["b-rate", [`b-rate--${a.size}`, {
140
+ "b-rate--disabled": a.disabled,
141
+ "b-rate--focused": k.value
142
+ }]]),
143
+ role: "slider",
144
+ "aria-label": e.$attrs["aria-label"] || "Rating",
145
+ "aria-disabled": a.disabled || void 0,
146
+ "aria-valuenow": T.value,
147
+ "aria-valuemin": 0,
148
+ "aria-valuemax": a.count,
149
+ "aria-valuetext": `${T.value} out of ${a.count} stars`,
150
+ tabindex: a.disabled ? -1 : 0,
151
+ onMouseleave: I,
152
+ onFocus: L,
153
+ onBlur: R,
154
+ onKeydown: z
155
+ }, [(c(!0), r(t, null, u(M.value, (t) => (c(), r("div", {
156
+ key: t.index,
157
+ class: s(["b-rate__star", {
158
+ "b-rate__star--full": N(t.index) === "full",
159
+ "b-rate__star--half": N(t.index) === "half",
160
+ "b-rate__star--zero": N(t.index) === "zero",
161
+ "b-rate__star--active": O.value > 0,
162
+ "b-rate__star--focused": k.value && A.value === t.index
163
+ }]),
164
+ title: a.tooltips[t.index - 1] || void 0,
165
+ onMousemove: (e) => F(t.index, e),
166
+ onClick: (e) => P(t.index, a.allowHalf && e.offsetX < e.currentTarget.offsetWidth / 2)
167
+ }, [i("div", _, [d(e.$slots, "character", { index: t.index }, () => [a.character ? (c(), r("span", {
168
+ key: 0,
169
+ class: "b-rate__character",
170
+ "data-character": a.character
171
+ }, null, 8, v)) : (c(), r("svg", y, [...n[0] ||= [i("path", { d: "M12 2l3.09 6.26L22 9.27l-5 4.87 1.18 6.88L12 17.77l-6.18 3.25L7 14.14 2 9.27l6.91-1.01L12 2z" }, null, -1)]]))], !0)]), i("div", b, [d(e.$slots, "character", { index: t.index }, () => [a.character ? (c(), r("span", {
172
+ key: 0,
173
+ class: "b-rate__character",
174
+ "data-character": a.character
175
+ }, null, 8, x)) : (c(), r("svg", S, [...n[1] ||= [i("path", { d: "M12 2l3.09 6.26L22 9.27l-5 4.87 1.18 6.88L12 17.77l-6.18 3.25L7 14.14 2 9.27l6.91-1.01L12 2z" }, null, -1)]]))], !0)])], 42, g))), 128)), i("input", {
176
+ type: "hidden",
177
+ name: `b-rate-${f(D)}`,
178
+ value: T.value
179
+ }, null, 8, C)], 42, h));
180
+ }
181
+ });
11
182
  //#endregion
12
- export { e as BSelectMode, r as BSelectPlacement, n as BSelectStatus, t as BSelectVariant };
183
+ export { w as default };
13
184
 
14
185
  //# sourceMappingURL=design-system173.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"design-system173.js","names":[],"sources":["../src/components/BSelect/types.ts"],"sourcesContent":["export interface BSelectOption {\n /** Display label for the option. Falls back to `value` if omitted. */\n label?: string;\n /** The value submitted when this option is selected. */\n value: string | number;\n /** Whether this option is disabled. */\n disabled?: boolean;\n /** Grouping: nested options under this group label. */\n options?: BSelectOption[];\n}\n\nexport enum BSelectMode {\n Multiple = 'multiple',\n Tags = 'tags',\n}\n\nexport enum BSelectVariant {\n Outlined = 'outlined',\n Filled = 'filled',\n Borderless = 'borderless',\n}\n\nexport enum BSelectStatus {\n Error = 'error',\n Warning = 'warning',\n}\n\nexport enum BSelectPlacement {\n BottomLeft = 'bottomLeft',\n BottomRight = 'bottomRight',\n TopLeft = 'topLeft',\n TopRight = 'topRight',\n}\n\nexport interface BSelectFieldNames {\n label?: string;\n value?: string;\n options?: string;\n groupLabel?: string;\n}\n"],"mappings":";AAWA,IAAY,IAAL,yBAAA,GAAA;QACL,EAAA,WAAA,YACA,EAAA,OAAA;KACD,EAEW,IAAL,yBAAA,GAAA;QACL,EAAA,WAAA,YACA,EAAA,SAAA,UACA,EAAA,aAAA;KACD,EAEW,IAAL,yBAAA,GAAA;QACL,EAAA,QAAA,SACA,EAAA,UAAA;KACD,EAEW,IAAL,yBAAA,GAAA;QACL,EAAA,aAAA,cACA,EAAA,cAAA,eACA,EAAA,UAAA,WACA,EAAA,WAAA;KACD"}
1
+ {"version":3,"file":"design-system173.js","names":["$attrs"],"sources":["../src/components/BRate/BRate.vue"],"sourcesContent":["<script lang=\"ts\" setup>\nimport { useComponentId } from '@/composables/useComponentId.ts';\nimport { computed, ref, watch } from 'vue';\n\n//#region Props\nconst {\n allowClear = true,\n allowHalf = false,\n count = 5,\n disabled = false,\n keyboard = true,\n size = 'default',\n tooltips = [],\n character,\n} = defineProps<{\n /** Whether to allow clearing the value when clicking the same star again. */\n allowClear?: boolean;\n /** Whether to allow half-star selection. */\n allowHalf?: boolean;\n /** Total number of stars. */\n count?: number;\n /** If true, the component is read-only and cannot be interacted with. */\n disabled?: boolean;\n /** Whether keyboard navigation is enabled. */\n keyboard?: boolean;\n /** Size of the stars. */\n size?: 'small' | 'default' | 'large';\n /** Array of tooltip strings displayed on hover for each star. */\n tooltips?: string[];\n /** Custom character/icon rendered as each star. Receives `{ index }`. */\n character?: string;\n}>();\n\n/**\n * The current rating value.\n * Supports v-model for controlled usage.\n */\nconst model = defineModel<number>({ default: 0 });\n\nconst emit = defineEmits<{\n 'hover-change': [value: number];\n change: [value: number];\n focus: [];\n blur: [];\n keydown: [event: KeyboardEvent];\n}>();\n//#endregion\n\n//#region Internal state\nconst { componentUID } = useComponentId();\nconst hoverValue = ref(0);\nconst isFocused = ref(false);\nconst focusedIndex = ref(0);\n\nconst currentValue = computed(() =>\n hoverValue.value > 0 ? hoverValue.value : model.value,\n);\n\nconst stars = computed(() => {\n const items: { index: number; value: number }[] = [];\n for (let i = 1; i <= count; i++) {\n items.push({ index: i, value: i });\n }\n return items;\n});\n//#endregion\n\n//#region Star state\nfunction getStarState(index: number): 'full' | 'half' | 'zero' {\n const val = currentValue.value;\n if (index <= Math.floor(val)) return 'full';\n if (allowHalf && index - 0.5 <= val && index > val) return 'half';\n return 'zero';\n}\n//#endregion\n\n//#region Handlers\nfunction handleClick(index: number, isHalf: boolean) {\n if (disabled) return;\n\n const newValue = isHalf && allowHalf ? index - 0.5 : index;\n\n if (allowClear && newValue === model.value) {\n model.value = 0;\n emit('change', 0);\n } else {\n model.value = newValue;\n emit('change', newValue);\n }\n}\n\nfunction handleMouseMove(index: number, event: MouseEvent) {\n if (disabled) return;\n\n const target = event.currentTarget as HTMLElement;\n const rect = target.getBoundingClientRect();\n const isLeftHalf = event.clientX - rect.left < rect.width / 2;\n\n let newHoverValue: number;\n if (allowHalf && isLeftHalf) {\n newHoverValue = index - 0.5;\n } else {\n newHoverValue = index;\n }\n\n if (newHoverValue !== hoverValue.value) {\n hoverValue.value = newHoverValue;\n emit('hover-change', newHoverValue);\n }\n}\n\nfunction handleMouseLeave() {\n if (disabled) return;\n hoverValue.value = 0;\n emit('hover-change', 0);\n}\n\nfunction handleFocus() {\n isFocused.value = true;\n focusedIndex.value = Math.ceil(model.value) || 1;\n emit('focus');\n}\n\nfunction handleBlur() {\n isFocused.value = false;\n focusedIndex.value = 0;\n emit('blur');\n}\n\nfunction handleKeyDown(event: KeyboardEvent) {\n if (disabled || !keyboard) return;\n emit('keydown', event);\n\n const step = allowHalf ? 0.5 : 1;\n\n switch (event.key) {\n case 'ArrowRight':\n case 'ArrowUp': {\n event.preventDefault();\n const next = Math.min(model.value + step, count);\n model.value = next;\n focusedIndex.value = Math.ceil(next);\n emit('change', next);\n break;\n }\n case 'ArrowLeft':\n case 'ArrowDown': {\n event.preventDefault();\n const prev = Math.max(model.value - step, 0);\n model.value = prev;\n focusedIndex.value = Math.ceil(prev) || 1;\n emit('change', prev);\n break;\n }\n case 'Enter':\n case ' ': {\n event.preventDefault();\n if (allowClear && focusedIndex.value === Math.ceil(model.value)) {\n model.value = 0;\n emit('change', 0);\n }\n break;\n }\n }\n}\n//#endregion\n\n//#region Expose\nconst rootRef = ref<HTMLElement | null>(null);\n\nfunction focus() {\n rootRef.value?.focus();\n}\n\nfunction blur() {\n rootRef.value?.blur();\n}\n\ndefineExpose({ focus, blur });\n//#endregion\n\n//#region Watch hover for tooltip\nwatch(hoverValue, (val) => {\n if (val === 0) {\n focusedIndex.value = Math.ceil(model.value) || 0;\n }\n});\n//#endregion\n</script>\n\n<template>\n <div\n ref=\"rootRef\"\n class=\"b-rate\"\n :class=\"[\n `b-rate--${size}`,\n {\n 'b-rate--disabled': disabled,\n 'b-rate--focused': isFocused,\n },\n ]\"\n role=\"slider\"\n :aria-label=\"$attrs['aria-label'] as string || 'Rating'\"\n :aria-disabled=\"disabled || undefined\"\n :aria-valuenow=\"model\"\n :aria-valuemin=\"0\"\n :aria-valuemax=\"count\"\n :aria-valuetext=\"`${model} out of ${count} stars`\"\n :tabindex=\"disabled ? -1 : 0\"\n @mouseleave=\"handleMouseLeave\"\n @focus=\"handleFocus\"\n @blur=\"handleBlur\"\n @keydown=\"handleKeyDown\"\n >\n <div\n v-for=\"star in stars\"\n :key=\"star.index\"\n class=\"b-rate__star\"\n :class=\"{\n 'b-rate__star--full': getStarState(star.index) === 'full',\n 'b-rate__star--half': getStarState(star.index) === 'half',\n 'b-rate__star--zero': getStarState(star.index) === 'zero',\n 'b-rate__star--active': hoverValue > 0,\n 'b-rate__star--focused': isFocused && focusedIndex === star.index,\n }\"\n :title=\"tooltips[star.index - 1] || undefined\"\n @mousemove=\"(e) => handleMouseMove(star.index, e)\"\n @click=\"(e) => handleClick(star.index, allowHalf && (e.offsetX < (e.currentTarget as HTMLElement).offsetWidth / 2))\"\n >\n <div class=\"b-rate__star-first\" aria-hidden=\"true\">\n <slot name=\"character\" :index=\"star.index\">\n <span v-if=\"character\" class=\"b-rate__character\" :data-character=\"character\" />\n <svg\n v-else\n class=\"b-rate__icon\"\n viewBox=\"0 0 24 24\"\n fill=\"currentColor\"\n aria-hidden=\"true\"\n >\n <path\n d=\"M12 2l3.09 6.26L22 9.27l-5 4.87 1.18 6.88L12 17.77l-6.18 3.25L7 14.14 2 9.27l6.91-1.01L12 2z\"\n />\n </svg>\n </slot>\n </div>\n <div class=\"b-rate__star-second\" aria-hidden=\"true\">\n <slot name=\"character\" :index=\"star.index\">\n <span v-if=\"character\" class=\"b-rate__character\" :data-character=\"character\" />\n <svg\n v-else\n class=\"b-rate__icon\"\n viewBox=\"0 0 24 24\"\n fill=\"currentColor\"\n aria-hidden=\"true\"\n >\n <path\n d=\"M12 2l3.09 6.26L22 9.27l-5 4.87 1.18 6.88L12 17.77l-6.18 3.25L7 14.14 2 9.27l6.91-1.01L12 2z\"\n />\n </svg>\n </slot>\n </div>\n </div>\n\n <input\n type=\"hidden\"\n :name=\"`b-rate-${componentUID}`\"\n :value=\"model\"\n />\n </div>\n</template>\n\n<style scoped>\n.b-rate {\n --b-rate-star-bg: rgba(0, 0, 0, 0.06);\n --b-rate-star-color: #fadb14;\n --b-rate-star-hover-scale: scale(1.1);\n --b-rate-star-size: 20px;\n\n display: inline-flex;\n gap: 8px;\n align-items: center;\n outline: none;\n cursor: pointer;\n line-height: 1;\n}\n\n.b-rate--small {\n --b-rate-star-size: 15px;\n gap: 6px;\n}\n\n.b-rate--large {\n --b-rate-star-size: 25px;\n gap: 10px;\n}\n\n.b-rate--disabled {\n cursor: not-allowed;\n opacity: 0.65;\n}\n\n.b-rate:focus-visible {\n outline: 2px solid var(--b-rate-star-color);\n outline-offset: 4px;\n border-radius: 2px;\n}\n\n.b-rate__star {\n position: relative;\n display: inline-flex;\n width: var(--b-rate-star-size);\n height: var(--b-rate-star-size);\n cursor: pointer;\n transition: transform 0.15s ease;\n}\n\n.b-rate--disabled .b-rate__star {\n cursor: not-allowed;\n}\n\n.b-rate__star:not(.b-rate--disabled .b-rate__star):hover {\n transform: var(--b-rate-star-hover-scale);\n}\n\n.b-rate__star--focused {\n outline: 2px solid var(--b-rate-star-color);\n outline-offset: 2px;\n border-radius: 2px;\n}\n\n.b-rate__star-first,\n.b-rate__star-second {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n display: flex;\n align-items: center;\n justify-content: flex-start;\n user-select: none;\n}\n\n.b-rate__star-first {\n width: 50%;\n overflow: hidden;\n z-index: 1;\n}\n\n.b-rate__star-second {\n z-index: 0;\n}\n\n/* Zero state: both halves use background color */\n.b-rate__star--zero .b-rate__star-first,\n.b-rate__star--zero .b-rate__star-second {\n color: var(--b-rate-star-bg);\n}\n\n/* Full state: both halves use active color */\n.b-rate__star--full .b-rate__star-first,\n.b-rate__star--full .b-rate__star-second {\n color: var(--b-rate-star-color);\n}\n\n/* Half state: first half active, second half background */\n.b-rate__star--half .b-rate__star-first {\n color: var(--b-rate-star-color);\n}\n\n.b-rate__star--half .b-rate__star-second {\n color: var(--b-rate-star-bg);\n}\n\n.b-rate__icon {\n width: var(--b-rate-star-size);\n height: var(--b-rate-star-size);\n flex-shrink: 0;\n display: block;\n}\n\n.b-rate__character {\n font-size: var(--b-rate-star-size);\n line-height: 1;\n white-space: nowrap;\n}\n\n.b-rate__character::before {\n content: attr(data-character);\n}\n\n/* Dark mode */\n[data-prefers-color='dark'] .b-rate {\n --b-rate-star-bg: rgba(255, 255, 255, 0.12);\n --b-rate-star-color: #fadb14;\n}\n\n@media (prefers-color-scheme: dark) {\n [data-prefers-color='system'] .b-rate {\n --b-rate-star-bg: rgba(255, 255, 255, 0.12);\n --b-rate-star-color: #fadb14;\n }\n}\n\n/* Reduced motion */\n@media (prefers-reduced-motion: reduce) {\n .b-rate__star {\n transition: none;\n }\n}\n</style>\n"],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ import e from "./design-system14.js";
2
+ import t from "./design-system173.js";
3
+ /* empty css */
4
+ //#region src/components/BRate/BRate.vue
5
+ var n = /* @__PURE__ */ e(t, [["__scopeId", "data-v-60355169"]]);
6
+ //#endregion
7
+ export { n as default };
8
+
9
+ //# sourceMappingURL=design-system175.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"design-system175.js","names":[],"sources":["../src/components/BRate/BRate.vue"],"sourcesContent":["<script lang=\"ts\" setup>\nimport { useComponentId } from '@/composables/useComponentId.ts';\nimport { computed, ref, watch } from 'vue';\n\n//#region Props\nconst {\n allowClear = true,\n allowHalf = false,\n count = 5,\n disabled = false,\n keyboard = true,\n size = 'default',\n tooltips = [],\n character,\n} = defineProps<{\n /** Whether to allow clearing the value when clicking the same star again. */\n allowClear?: boolean;\n /** Whether to allow half-star selection. */\n allowHalf?: boolean;\n /** Total number of stars. */\n count?: number;\n /** If true, the component is read-only and cannot be interacted with. */\n disabled?: boolean;\n /** Whether keyboard navigation is enabled. */\n keyboard?: boolean;\n /** Size of the stars. */\n size?: 'small' | 'default' | 'large';\n /** Array of tooltip strings displayed on hover for each star. */\n tooltips?: string[];\n /** Custom character/icon rendered as each star. Receives `{ index }`. */\n character?: string;\n}>();\n\n/**\n * The current rating value.\n * Supports v-model for controlled usage.\n */\nconst model = defineModel<number>({ default: 0 });\n\nconst emit = defineEmits<{\n 'hover-change': [value: number];\n change: [value: number];\n focus: [];\n blur: [];\n keydown: [event: KeyboardEvent];\n}>();\n//#endregion\n\n//#region Internal state\nconst { componentUID } = useComponentId();\nconst hoverValue = ref(0);\nconst isFocused = ref(false);\nconst focusedIndex = ref(0);\n\nconst currentValue = computed(() =>\n hoverValue.value > 0 ? hoverValue.value : model.value,\n);\n\nconst stars = computed(() => {\n const items: { index: number; value: number }[] = [];\n for (let i = 1; i <= count; i++) {\n items.push({ index: i, value: i });\n }\n return items;\n});\n//#endregion\n\n//#region Star state\nfunction getStarState(index: number): 'full' | 'half' | 'zero' {\n const val = currentValue.value;\n if (index <= Math.floor(val)) return 'full';\n if (allowHalf && index - 0.5 <= val && index > val) return 'half';\n return 'zero';\n}\n//#endregion\n\n//#region Handlers\nfunction handleClick(index: number, isHalf: boolean) {\n if (disabled) return;\n\n const newValue = isHalf && allowHalf ? index - 0.5 : index;\n\n if (allowClear && newValue === model.value) {\n model.value = 0;\n emit('change', 0);\n } else {\n model.value = newValue;\n emit('change', newValue);\n }\n}\n\nfunction handleMouseMove(index: number, event: MouseEvent) {\n if (disabled) return;\n\n const target = event.currentTarget as HTMLElement;\n const rect = target.getBoundingClientRect();\n const isLeftHalf = event.clientX - rect.left < rect.width / 2;\n\n let newHoverValue: number;\n if (allowHalf && isLeftHalf) {\n newHoverValue = index - 0.5;\n } else {\n newHoverValue = index;\n }\n\n if (newHoverValue !== hoverValue.value) {\n hoverValue.value = newHoverValue;\n emit('hover-change', newHoverValue);\n }\n}\n\nfunction handleMouseLeave() {\n if (disabled) return;\n hoverValue.value = 0;\n emit('hover-change', 0);\n}\n\nfunction handleFocus() {\n isFocused.value = true;\n focusedIndex.value = Math.ceil(model.value) || 1;\n emit('focus');\n}\n\nfunction handleBlur() {\n isFocused.value = false;\n focusedIndex.value = 0;\n emit('blur');\n}\n\nfunction handleKeyDown(event: KeyboardEvent) {\n if (disabled || !keyboard) return;\n emit('keydown', event);\n\n const step = allowHalf ? 0.5 : 1;\n\n switch (event.key) {\n case 'ArrowRight':\n case 'ArrowUp': {\n event.preventDefault();\n const next = Math.min(model.value + step, count);\n model.value = next;\n focusedIndex.value = Math.ceil(next);\n emit('change', next);\n break;\n }\n case 'ArrowLeft':\n case 'ArrowDown': {\n event.preventDefault();\n const prev = Math.max(model.value - step, 0);\n model.value = prev;\n focusedIndex.value = Math.ceil(prev) || 1;\n emit('change', prev);\n break;\n }\n case 'Enter':\n case ' ': {\n event.preventDefault();\n if (allowClear && focusedIndex.value === Math.ceil(model.value)) {\n model.value = 0;\n emit('change', 0);\n }\n break;\n }\n }\n}\n//#endregion\n\n//#region Expose\nconst rootRef = ref<HTMLElement | null>(null);\n\nfunction focus() {\n rootRef.value?.focus();\n}\n\nfunction blur() {\n rootRef.value?.blur();\n}\n\ndefineExpose({ focus, blur });\n//#endregion\n\n//#region Watch hover for tooltip\nwatch(hoverValue, (val) => {\n if (val === 0) {\n focusedIndex.value = Math.ceil(model.value) || 0;\n }\n});\n//#endregion\n</script>\n\n<template>\n <div\n ref=\"rootRef\"\n class=\"b-rate\"\n :class=\"[\n `b-rate--${size}`,\n {\n 'b-rate--disabled': disabled,\n 'b-rate--focused': isFocused,\n },\n ]\"\n role=\"slider\"\n :aria-label=\"$attrs['aria-label'] as string || 'Rating'\"\n :aria-disabled=\"disabled || undefined\"\n :aria-valuenow=\"model\"\n :aria-valuemin=\"0\"\n :aria-valuemax=\"count\"\n :aria-valuetext=\"`${model} out of ${count} stars`\"\n :tabindex=\"disabled ? -1 : 0\"\n @mouseleave=\"handleMouseLeave\"\n @focus=\"handleFocus\"\n @blur=\"handleBlur\"\n @keydown=\"handleKeyDown\"\n >\n <div\n v-for=\"star in stars\"\n :key=\"star.index\"\n class=\"b-rate__star\"\n :class=\"{\n 'b-rate__star--full': getStarState(star.index) === 'full',\n 'b-rate__star--half': getStarState(star.index) === 'half',\n 'b-rate__star--zero': getStarState(star.index) === 'zero',\n 'b-rate__star--active': hoverValue > 0,\n 'b-rate__star--focused': isFocused && focusedIndex === star.index,\n }\"\n :title=\"tooltips[star.index - 1] || undefined\"\n @mousemove=\"(e) => handleMouseMove(star.index, e)\"\n @click=\"(e) => handleClick(star.index, allowHalf && (e.offsetX < (e.currentTarget as HTMLElement).offsetWidth / 2))\"\n >\n <div class=\"b-rate__star-first\" aria-hidden=\"true\">\n <slot name=\"character\" :index=\"star.index\">\n <span v-if=\"character\" class=\"b-rate__character\" :data-character=\"character\" />\n <svg\n v-else\n class=\"b-rate__icon\"\n viewBox=\"0 0 24 24\"\n fill=\"currentColor\"\n aria-hidden=\"true\"\n >\n <path\n d=\"M12 2l3.09 6.26L22 9.27l-5 4.87 1.18 6.88L12 17.77l-6.18 3.25L7 14.14 2 9.27l6.91-1.01L12 2z\"\n />\n </svg>\n </slot>\n </div>\n <div class=\"b-rate__star-second\" aria-hidden=\"true\">\n <slot name=\"character\" :index=\"star.index\">\n <span v-if=\"character\" class=\"b-rate__character\" :data-character=\"character\" />\n <svg\n v-else\n class=\"b-rate__icon\"\n viewBox=\"0 0 24 24\"\n fill=\"currentColor\"\n aria-hidden=\"true\"\n >\n <path\n d=\"M12 2l3.09 6.26L22 9.27l-5 4.87 1.18 6.88L12 17.77l-6.18 3.25L7 14.14 2 9.27l6.91-1.01L12 2z\"\n />\n </svg>\n </slot>\n </div>\n </div>\n\n <input\n type=\"hidden\"\n :name=\"`b-rate-${componentUID}`\"\n :value=\"model\"\n />\n </div>\n</template>\n\n<style scoped>\n.b-rate {\n --b-rate-star-bg: rgba(0, 0, 0, 0.06);\n --b-rate-star-color: #fadb14;\n --b-rate-star-hover-scale: scale(1.1);\n --b-rate-star-size: 20px;\n\n display: inline-flex;\n gap: 8px;\n align-items: center;\n outline: none;\n cursor: pointer;\n line-height: 1;\n}\n\n.b-rate--small {\n --b-rate-star-size: 15px;\n gap: 6px;\n}\n\n.b-rate--large {\n --b-rate-star-size: 25px;\n gap: 10px;\n}\n\n.b-rate--disabled {\n cursor: not-allowed;\n opacity: 0.65;\n}\n\n.b-rate:focus-visible {\n outline: 2px solid var(--b-rate-star-color);\n outline-offset: 4px;\n border-radius: 2px;\n}\n\n.b-rate__star {\n position: relative;\n display: inline-flex;\n width: var(--b-rate-star-size);\n height: var(--b-rate-star-size);\n cursor: pointer;\n transition: transform 0.15s ease;\n}\n\n.b-rate--disabled .b-rate__star {\n cursor: not-allowed;\n}\n\n.b-rate__star:not(.b-rate--disabled .b-rate__star):hover {\n transform: var(--b-rate-star-hover-scale);\n}\n\n.b-rate__star--focused {\n outline: 2px solid var(--b-rate-star-color);\n outline-offset: 2px;\n border-radius: 2px;\n}\n\n.b-rate__star-first,\n.b-rate__star-second {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n display: flex;\n align-items: center;\n justify-content: flex-start;\n user-select: none;\n}\n\n.b-rate__star-first {\n width: 50%;\n overflow: hidden;\n z-index: 1;\n}\n\n.b-rate__star-second {\n z-index: 0;\n}\n\n/* Zero state: both halves use background color */\n.b-rate__star--zero .b-rate__star-first,\n.b-rate__star--zero .b-rate__star-second {\n color: var(--b-rate-star-bg);\n}\n\n/* Full state: both halves use active color */\n.b-rate__star--full .b-rate__star-first,\n.b-rate__star--full .b-rate__star-second {\n color: var(--b-rate-star-color);\n}\n\n/* Half state: first half active, second half background */\n.b-rate__star--half .b-rate__star-first {\n color: var(--b-rate-star-color);\n}\n\n.b-rate__star--half .b-rate__star-second {\n color: var(--b-rate-star-bg);\n}\n\n.b-rate__icon {\n width: var(--b-rate-star-size);\n height: var(--b-rate-star-size);\n flex-shrink: 0;\n display: block;\n}\n\n.b-rate__character {\n font-size: var(--b-rate-star-size);\n line-height: 1;\n white-space: nowrap;\n}\n\n.b-rate__character::before {\n content: attr(data-character);\n}\n\n/* Dark mode */\n[data-prefers-color='dark'] .b-rate {\n --b-rate-star-bg: rgba(255, 255, 255, 0.12);\n --b-rate-star-color: #fadb14;\n}\n\n@media (prefers-color-scheme: dark) {\n [data-prefers-color='system'] .b-rate {\n --b-rate-star-bg: rgba(255, 255, 255, 0.12);\n --b-rate-star-color: #fadb14;\n }\n}\n\n/* Reduced motion */\n@media (prefers-reduced-motion: reduce) {\n .b-rate__star {\n transition: none;\n }\n}\n</style>\n"],"mappings":""}