bromcom-ui 2.7.38-rc.13 → 2.7.38-rc.14

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 (296) hide show
  1. package/dist/bromcom-ui/bromcom-ui.css +1 -1
  2. package/dist/bromcom-ui/bromcom-ui.esm.js +1 -1
  3. package/dist/bromcom-ui/{p-14d4b66f.entry.js → p-047c35b1.entry.js} +1 -1
  4. package/dist/bromcom-ui/p-0fb362d7.entry.js +5 -0
  5. package/dist/bromcom-ui/p-16b50160.js +1 -1
  6. package/dist/bromcom-ui/p-1ff8838d.entry.js +5 -0
  7. package/dist/bromcom-ui/p-27429bb5.entry.js +5 -0
  8. package/dist/bromcom-ui/{p-134c6c32.entry.js → p-29866cdb.entry.js} +1 -1
  9. package/dist/bromcom-ui/p-2a1f44d8.entry.js +5 -0
  10. package/dist/bromcom-ui/p-2a5b5ecc.entry.js +5 -0
  11. package/dist/bromcom-ui/p-335dd2b5.entry.js +5 -0
  12. package/dist/bromcom-ui/p-3cbeb4dc.entry.js +5 -0
  13. package/dist/bromcom-ui/{p-a39daf28.entry.js → p-3ed25f2b.entry.js} +2 -2
  14. package/dist/bromcom-ui/p-4487e8c2.js +1 -1
  15. package/dist/bromcom-ui/{p-18b8a460.js → p-44f3ca76.js} +1 -1
  16. package/dist/bromcom-ui/p-468af02f.entry.js +5 -0
  17. package/dist/bromcom-ui/p-480024c3.js +5 -0
  18. package/dist/bromcom-ui/p-4b2852a8.entry.js +5 -0
  19. package/dist/bromcom-ui/p-4c91002a.js +5 -0
  20. package/dist/bromcom-ui/p-4debe197.entry.js +5 -0
  21. package/dist/bromcom-ui/p-4f5acd80.entry.js +5 -0
  22. package/dist/bromcom-ui/p-503a376b.entry.js +5 -0
  23. package/dist/bromcom-ui/p-56898932.js +1 -1
  24. package/dist/bromcom-ui/p-58c108a5.entry.js +5 -0
  25. package/dist/bromcom-ui/p-5b664dec.js +5 -0
  26. package/dist/bromcom-ui/p-5bf68f57.entry.js +5 -0
  27. package/dist/bromcom-ui/p-5d70f446.entry.js +5 -0
  28. package/dist/bromcom-ui/{p-a183a09f.entry.js → p-5de651cc.entry.js} +1 -1
  29. package/dist/bromcom-ui/p-5ebfa466.entry.js +5 -0
  30. package/dist/bromcom-ui/p-60947a22.entry.js +5 -0
  31. package/dist/bromcom-ui/p-67e6f5fe.entry.js +5 -0
  32. package/dist/bromcom-ui/p-687f8d9c.entry.js +5 -0
  33. package/dist/bromcom-ui/p-6d7be2d1.entry.js +5 -0
  34. package/dist/bromcom-ui/p-6e9e2e3b.entry.js +5 -0
  35. package/dist/bromcom-ui/{p-9a9151f4.js → p-74bac994.js} +1 -1
  36. package/dist/bromcom-ui/p-882f8cb1.entry.js +5 -0
  37. package/dist/bromcom-ui/p-8b9d2bb3.entry.js +5 -0
  38. package/dist/bromcom-ui/p-9799c72f.entry.js +5 -0
  39. package/dist/bromcom-ui/p-98af14a9.entry.js +5 -0
  40. package/dist/bromcom-ui/p-a1c843ae.entry.js +5 -0
  41. package/dist/bromcom-ui/p-a373d8b6.entry.js +5 -0
  42. package/dist/bromcom-ui/{p-39175c90.js → p-a3b9fc0c.js} +1 -1
  43. package/dist/bromcom-ui/p-a429e85b.js +1 -1
  44. package/dist/bromcom-ui/p-ab6d3082.entry.js +5 -0
  45. package/dist/bromcom-ui/p-ac1f9851.entry.js +5 -0
  46. package/dist/bromcom-ui/p-aff12492.entry.js +5 -0
  47. package/dist/bromcom-ui/p-b963626d.js +5 -0
  48. package/dist/bromcom-ui/p-ba73ad6b.entry.js +5 -0
  49. package/dist/bromcom-ui/{p-731eb879.js → p-bd031390.js} +1 -1
  50. package/dist/bromcom-ui/p-bdb0dfda.entry.js +5 -0
  51. package/dist/bromcom-ui/p-bef9e2fe.entry.js +5 -0
  52. package/dist/bromcom-ui/p-c0f70afa.entry.js +5 -0
  53. package/dist/bromcom-ui/p-ce1f522e.entry.js +5 -0
  54. package/dist/bromcom-ui/p-cebefc96.entry.js +5 -0
  55. package/dist/bromcom-ui/p-d01e8312.entry.js +5 -0
  56. package/dist/bromcom-ui/{p-9a5e145b.js → p-d651e723.js} +1 -1
  57. package/dist/bromcom-ui/p-d73e3d1d.entry.js +5 -0
  58. package/dist/bromcom-ui/p-d8fd3bbb.entry.js +5 -0
  59. package/dist/bromcom-ui/p-d9baf5e7.entry.js +5 -0
  60. package/dist/bromcom-ui/p-dda54e92.entry.js +5 -0
  61. package/dist/bromcom-ui/p-e34ad7a7.entry.js +5 -0
  62. package/dist/bromcom-ui/p-e38087d9.entry.js +5 -0
  63. package/dist/bromcom-ui/p-e3bfaffd.entry.js +5 -0
  64. package/dist/bromcom-ui/p-e74b4689.entry.js +5 -0
  65. package/dist/bromcom-ui/p-ea21c68d.entry.js +5 -0
  66. package/dist/bromcom-ui/p-ef787294.entry.js +5 -0
  67. package/dist/cjs/{bcm-ab921827.js → bcm-634604e3.js} +4 -4
  68. package/dist/cjs/bcm-accordion.cjs.entry.js +3 -1
  69. package/dist/cjs/bcm-alert.cjs.entry.js +4 -3
  70. package/dist/cjs/bcm-attendance.cjs.entry.js +3 -1
  71. package/dist/cjs/bcm-avatar_2.cjs.entry.js +12 -11
  72. package/dist/cjs/bcm-breadcrumb.cjs.entry.js +2 -1
  73. package/dist/cjs/bcm-button-group.cjs.entry.js +7 -6
  74. package/dist/cjs/bcm-button.cjs.entry.js +13 -12
  75. package/dist/cjs/bcm-card.cjs.entry.js +6 -5
  76. package/dist/cjs/bcm-checkbox-group.cjs.entry.js +25 -24
  77. package/dist/cjs/bcm-checkbox-lite_9.cjs.entry.js +6 -5
  78. package/dist/cjs/bcm-checkbox_2.cjs.entry.js +11 -10
  79. package/dist/cjs/bcm-chip.cjs.entry.js +3 -2
  80. package/dist/cjs/bcm-collapse.cjs.entry.js +2 -1
  81. package/dist/cjs/bcm-color-input.cjs.entry.js +7 -6
  82. package/dist/cjs/bcm-colorful_2.cjs.entry.js +10 -9
  83. package/dist/cjs/bcm-date-picker.cjs.entry.js +4 -3
  84. package/dist/cjs/bcm-datetime-picker.cjs.entry.js +9 -8
  85. package/dist/cjs/bcm-default.cjs.entry.js +3 -1
  86. package/dist/cjs/bcm-drawer.cjs.entry.js +9 -8
  87. package/dist/cjs/bcm-dropdown.cjs.entry.js +7 -6
  88. package/dist/cjs/bcm-expansion-panel.cjs.entry.js +5 -4
  89. package/dist/cjs/bcm-form-2.cjs.entry.js +5 -4
  90. package/dist/cjs/bcm-form.cjs.entry.js +2 -2
  91. package/dist/cjs/{bcm-list.cjs.entry.js → bcm-icon_3.cjs.entry.js} +383 -113
  92. package/dist/cjs/bcm-input-custom.cjs.entry.js +73 -0
  93. package/dist/cjs/bcm-input.cjs.entry.js +12 -11
  94. package/dist/cjs/bcm-item.cjs.entry.js +5 -4
  95. package/dist/cjs/bcm-items.cjs.entry.js +4 -3
  96. package/dist/cjs/bcm-label_2.cjs.entry.js +39 -15
  97. package/dist/cjs/bcm-link.cjs.entry.js +3 -3
  98. package/dist/cjs/bcm-menu.cjs.entry.js +9 -8
  99. package/dist/cjs/bcm-modal.cjs.entry.js +7 -6
  100. package/dist/cjs/bcm-popconfirm-box.cjs.entry.js +6 -5
  101. package/dist/cjs/bcm-popconfirm.cjs.entry.js +5 -4
  102. package/dist/cjs/bcm-popover.cjs.entry.js +88 -38
  103. package/dist/cjs/bcm-progress.cjs.entry.js +5 -4
  104. package/dist/cjs/bcm-radio-group.cjs.entry.js +77 -211
  105. package/dist/cjs/bcm-radio.cjs.entry.js +35 -76
  106. package/dist/cjs/bcm-range.cjs.entry.js +6 -5
  107. package/dist/cjs/bcm-select.cjs.entry.js +2 -2
  108. package/dist/cjs/bcm-skeleton.cjs.entry.js +3 -1
  109. package/dist/cjs/bcm-step.cjs.entry.js +3 -2
  110. package/dist/cjs/bcm-stepper.cjs.entry.js +10 -9
  111. package/dist/cjs/bcm-switch.cjs.entry.js +9 -8
  112. package/dist/cjs/bcm-tab-group.cjs.entry.js +160 -0
  113. package/dist/cjs/bcm-tab-item-header.cjs.entry.js +87 -0
  114. package/dist/cjs/bcm-tab-item.cjs.entry.js +104 -0
  115. package/dist/cjs/bcm-tag.cjs.entry.js +15 -14
  116. package/dist/cjs/bcm-text.cjs.entry.js +63 -0
  117. package/dist/cjs/bcm-textarea.cjs.entry.js +7 -6
  118. package/dist/cjs/bcm-time-picker.cjs.entry.js +4 -3
  119. package/dist/cjs/bromcom-ui.cjs.js +1 -1
  120. package/dist/cjs/color-helper-0e3e8ce5.js +86 -0
  121. package/dist/cjs/{color-helper-c9882bd8.js → colors-25c96ed6.js} +4 -81
  122. package/dist/cjs/{floating-ui-0ca84e74.js → floating-ui-c23acc6c.js} +2 -2
  123. package/dist/cjs/{generate-1c6288f3.js → generate-9739666b.js} +38 -1
  124. package/dist/cjs/{input-template-a6387296.js → input-template-8307182a.js} +6 -6
  125. package/dist/cjs/{json-parse-decarator-fb0443a2.js → json-parse-decarator-7a7415e0.js} +1 -1
  126. package/dist/cjs/{label-template-e83fc65c.js → label-template-098a30a4.js} +3 -3
  127. package/dist/cjs/loader.cjs.js +1 -1
  128. package/dist/cjs/{number-helper-9cb681ed.js → number-helper-063f8c7b.js} +1 -1
  129. package/dist/cjs/old-bcm-popover-box.cjs.entry.js +7 -6
  130. package/dist/cjs/old-bcm-popover.cjs.entry.js +5 -4
  131. package/dist/cjs/{popover-placement-5db8811b.js → popover-placement-69d37a5f.js} +1 -1
  132. package/dist/cjs/{slot-template-175c51fb.js → slot-template-7a07f865.js} +1 -1
  133. package/dist/cjs/{stepper-states-5ba5cabd.js → stepper-states-7dd1eab4.js} +1 -1
  134. package/dist/cjs/{string-helper-087a8134.js → string-helper-71b10c53.js} +2 -2
  135. package/dist/cjs/{tooltip-helper-348e4222.js → tooltip-helper-01c69059.js} +43 -13
  136. package/dist/cjs/{validators-d8faa4be.js → validators-861b4246.js} +1 -1
  137. package/dist/collection/collection-manifest.json +2 -1
  138. package/dist/collection/components/external-source/bcm-toast-helper.js +20 -0
  139. package/dist/collection/components/external-source/test.js/bcm-toast-helper.js +20 -0
  140. package/dist/collection/components/molecules/popover/popover.js +106 -1
  141. package/dist/collection/components/molecules/radio/{group.js → radio-group.js} +163 -246
  142. package/dist/collection/components/molecules/radio/radio.js +42 -132
  143. package/dist/collection/components/molecules/tooltip/tooltip.js +108 -1
  144. package/dist/collection/components/organism/states/bcm-list2.states.js +1 -1
  145. package/dist/collection/components/other/input-custom/input-custom.js +249 -0
  146. package/dist/collection/helper/generate.js +36 -0
  147. package/dist/collection/helper/popover-helper.js +57 -29
  148. package/dist/collection/helper/tooltip-helper.js +33 -4
  149. package/dist/components/bcm-input-custom.d.ts +11 -0
  150. package/dist/components/bcm-input-custom.js +114 -0
  151. package/dist/components/bcm-list.js +1 -1
  152. package/dist/components/bcm-popover.js +82 -29
  153. package/dist/components/bcm-radio-group.js +88 -230
  154. package/dist/components/color-helper.js +1 -405
  155. package/dist/{esm/color-helper-b5e9aa56.js → components/colors2.js} +2 -79
  156. package/dist/components/generate.js +37 -1
  157. package/dist/components/index.d.ts +2 -1
  158. package/dist/components/index.js +1 -0
  159. package/dist/components/radio.js +38 -82
  160. package/dist/components/tooltip-helper.js +33 -3
  161. package/dist/components/tooltip.js +28 -2
  162. package/dist/esm/bcm-9f50af9c.js +1 -1
  163. package/dist/esm/bcm-accordion.entry.js +3 -1
  164. package/dist/esm/bcm-alert.entry.js +2 -1
  165. package/dist/esm/bcm-attendance.entry.js +3 -1
  166. package/dist/esm/bcm-avatar_2.entry.js +6 -5
  167. package/dist/esm/bcm-breadcrumb.entry.js +2 -1
  168. package/dist/esm/bcm-button-group.entry.js +3 -2
  169. package/dist/esm/bcm-button.entry.js +4 -3
  170. package/dist/esm/bcm-card.entry.js +3 -2
  171. package/dist/esm/bcm-checkbox-group.entry.js +9 -8
  172. package/dist/esm/bcm-checkbox-lite_9.entry.js +3 -2
  173. package/dist/esm/bcm-checkbox_2.entry.js +4 -3
  174. package/dist/esm/bcm-chip.entry.js +3 -2
  175. package/dist/esm/bcm-collapse.entry.js +2 -1
  176. package/dist/esm/bcm-color-input.entry.js +5 -4
  177. package/dist/esm/bcm-colorful_2.entry.js +6 -5
  178. package/dist/esm/bcm-date-picker.entry.js +3 -2
  179. package/dist/esm/bcm-datetime-picker.entry.js +3 -2
  180. package/dist/esm/bcm-default.entry.js +3 -1
  181. package/dist/esm/bcm-drawer.entry.js +6 -5
  182. package/dist/esm/bcm-dropdown.entry.js +4 -3
  183. package/dist/esm/bcm-expansion-panel.entry.js +3 -2
  184. package/dist/esm/bcm-form-2.entry.js +3 -2
  185. package/dist/esm/{bcm-list.entry.js → bcm-icon_3.entry.js} +314 -46
  186. package/dist/esm/bcm-input-custom.entry.js +69 -0
  187. package/dist/esm/bcm-input.entry.js +6 -5
  188. package/dist/esm/bcm-item.entry.js +4 -3
  189. package/dist/esm/bcm-items.entry.js +3 -2
  190. package/dist/esm/bcm-label_2.entry.js +32 -8
  191. package/dist/esm/bcm-link.entry.js +1 -1
  192. package/dist/esm/bcm-menu.entry.js +6 -5
  193. package/dist/esm/bcm-modal.entry.js +3 -2
  194. package/dist/esm/bcm-popconfirm-box.entry.js +3 -2
  195. package/dist/esm/bcm-popconfirm.entry.js +3 -2
  196. package/dist/esm/bcm-popover.entry.js +85 -35
  197. package/dist/esm/bcm-progress.entry.js +4 -3
  198. package/dist/esm/bcm-radio-group.entry.js +72 -206
  199. package/dist/esm/bcm-radio.entry.js +35 -76
  200. package/dist/esm/bcm-range.entry.js +3 -2
  201. package/dist/esm/bcm-skeleton.entry.js +3 -1
  202. package/dist/esm/bcm-step.entry.js +3 -2
  203. package/dist/esm/bcm-stepper.entry.js +7 -6
  204. package/dist/esm/bcm-switch.entry.js +3 -2
  205. package/dist/esm/bcm-tab-group.entry.js +156 -0
  206. package/dist/esm/bcm-tab-item-header.entry.js +83 -0
  207. package/dist/esm/bcm-tab-item.entry.js +100 -0
  208. package/dist/esm/bcm-tag.entry.js +4 -3
  209. package/dist/esm/bcm-text.entry.js +59 -0
  210. package/dist/esm/bcm-textarea.entry.js +4 -3
  211. package/dist/esm/bcm-time-picker.entry.js +3 -2
  212. package/dist/esm/bromcom-ui.js +1 -1
  213. package/dist/esm/color-helper-0277e11a.js +84 -0
  214. package/dist/esm/colors-fabca483.js +411 -0
  215. package/dist/esm/floating-ui-4a49ea46.js +1 -1
  216. package/dist/esm/{generate-6d61a8d4.js → generate-0dc9b243.js} +38 -1
  217. package/dist/esm/{input-template-5377ad24.js → input-template-de00be57.js} +2 -2
  218. package/dist/esm/{json-parse-decarator-24e9b234.js → json-parse-decarator-5b16dfec.js} +1 -1
  219. package/dist/esm/label-template-eed2dd69.js +1 -1
  220. package/dist/esm/loader.js +1 -1
  221. package/dist/esm/{number-helper-056c158e.js → number-helper-282f0beb.js} +1 -1
  222. package/dist/esm/old-bcm-popover-box.entry.js +3 -2
  223. package/dist/esm/old-bcm-popover.entry.js +3 -2
  224. package/dist/esm/{stepper-states-450629eb.js → stepper-states-fdf47afe.js} +1 -1
  225. package/dist/esm/string-helper-0fb7ff20.js +1 -1
  226. package/dist/esm/{tooltip-helper-05959548.js → tooltip-helper-4e2db0c0.js} +38 -8
  227. package/dist/esm/{validators-649cde78.js → validators-089d15b9.js} +1 -1
  228. package/dist/types/components/external-source/bcm-toast-helper.d.ts +12 -0
  229. package/dist/types/components/external-source/test.js/bcm-toast-helper.d.ts +12 -0
  230. package/dist/types/components/molecules/popover/popover.d.ts +10 -1
  231. package/dist/types/components/molecules/radio/{group.d.ts → radio-group.d.ts} +19 -27
  232. package/dist/types/components/molecules/radio/radio.d.ts +5 -11
  233. package/dist/types/components/molecules/tooltip/tooltip.d.ts +10 -1
  234. package/dist/types/components/other/input-custom/input-custom.d.ts +20 -0
  235. package/dist/types/components.d.ts +76 -33
  236. package/dist/types/helper/generate.d.ts +2 -0
  237. package/dist/types/helper/popover-helper.d.ts +13 -3
  238. package/dist/types/helper/tooltip-helper.d.ts +13 -3
  239. package/package.json +1 -1
  240. package/dist/bromcom-ui/p-0b10d948.entry.js +0 -5
  241. package/dist/bromcom-ui/p-125b65f6.entry.js +0 -5
  242. package/dist/bromcom-ui/p-1945b686.entry.js +0 -5
  243. package/dist/bromcom-ui/p-29dc2191.js +0 -5
  244. package/dist/bromcom-ui/p-2a391ece.entry.js +0 -5
  245. package/dist/bromcom-ui/p-2ec946a1.entry.js +0 -5
  246. package/dist/bromcom-ui/p-33f4e17f.entry.js +0 -5
  247. package/dist/bromcom-ui/p-36224b1d.entry.js +0 -5
  248. package/dist/bromcom-ui/p-366e47ab.entry.js +0 -5
  249. package/dist/bromcom-ui/p-41c296b0.entry.js +0 -5
  250. package/dist/bromcom-ui/p-41dc9559.entry.js +0 -5
  251. package/dist/bromcom-ui/p-45367974.entry.js +0 -5
  252. package/dist/bromcom-ui/p-50db7a26.entry.js +0 -5
  253. package/dist/bromcom-ui/p-579e8412.entry.js +0 -5
  254. package/dist/bromcom-ui/p-5a899703.entry.js +0 -5
  255. package/dist/bromcom-ui/p-5e55f59b.entry.js +0 -5
  256. package/dist/bromcom-ui/p-5efd7090.entry.js +0 -5
  257. package/dist/bromcom-ui/p-688f1e5e.entry.js +0 -5
  258. package/dist/bromcom-ui/p-6a768487.entry.js +0 -5
  259. package/dist/bromcom-ui/p-6b321329.entry.js +0 -5
  260. package/dist/bromcom-ui/p-6c9920df.entry.js +0 -5
  261. package/dist/bromcom-ui/p-73d6483e.entry.js +0 -5
  262. package/dist/bromcom-ui/p-7aad993b.entry.js +0 -5
  263. package/dist/bromcom-ui/p-7e0b3687.entry.js +0 -5
  264. package/dist/bromcom-ui/p-82318c6a.entry.js +0 -5
  265. package/dist/bromcom-ui/p-880b9e3d.entry.js +0 -5
  266. package/dist/bromcom-ui/p-92382af0.entry.js +0 -5
  267. package/dist/bromcom-ui/p-96f555da.entry.js +0 -5
  268. package/dist/bromcom-ui/p-9c910424.entry.js +0 -5
  269. package/dist/bromcom-ui/p-a25d69f2.js +0 -5
  270. package/dist/bromcom-ui/p-a87c6718.entry.js +0 -5
  271. package/dist/bromcom-ui/p-a8d1397d.js +0 -5
  272. package/dist/bromcom-ui/p-a990ad01.entry.js +0 -5
  273. package/dist/bromcom-ui/p-aaac6552.entry.js +0 -5
  274. package/dist/bromcom-ui/p-abff65bf.entry.js +0 -5
  275. package/dist/bromcom-ui/p-bf7d791d.entry.js +0 -5
  276. package/dist/bromcom-ui/p-c2dfd997.entry.js +0 -5
  277. package/dist/bromcom-ui/p-c7d37238.entry.js +0 -5
  278. package/dist/bromcom-ui/p-cbb00d90.entry.js +0 -5
  279. package/dist/bromcom-ui/p-cf82f22a.entry.js +0 -5
  280. package/dist/bromcom-ui/p-d75546da.entry.js +0 -5
  281. package/dist/bromcom-ui/p-d8f62742.entry.js +0 -5
  282. package/dist/bromcom-ui/p-ddc53b28.entry.js +0 -5
  283. package/dist/bromcom-ui/p-e5dc36af.entry.js +0 -5
  284. package/dist/bromcom-ui/p-e85f520f.entry.js +0 -5
  285. package/dist/bromcom-ui/p-e94dcd9a.entry.js +0 -5
  286. package/dist/bromcom-ui/p-ec23e7f7.entry.js +0 -5
  287. package/dist/cjs/bcm-icon_5.cjs.entry.js +0 -378
  288. package/dist/cjs/bcm-search.cjs.entry.js +0 -258
  289. package/dist/collection/components/molecules/radio/group.css +0 -802
  290. package/dist/collection/components/molecules/radio/radio.css +0 -1287
  291. package/dist/collection/components/molecules/radio/types.js +0 -30
  292. package/dist/collection/components/molecules/states/radio-group.states.js +0 -107
  293. package/dist/esm/bcm-icon_5.entry.js +0 -370
  294. package/dist/esm/bcm-search.entry.js +0 -254
  295. package/dist/types/components/molecules/radio/types.d.ts +0 -29
  296. package/dist/types/components/molecules/states/radio-group.states.d.ts +0 -48
@@ -2,44 +2,52 @@
2
2
  * Built with Stencil
3
3
  * Copyright (c) Bromcom.
4
4
  */
5
- import { r as registerInstance, h, H as Host, g as getElement } from './index-6e2d80d7.js';
5
+ import { r as registerInstance, c as createEvent, h, H as Host, g as getElement } from './index-6e2d80d7.js';
6
6
  import { I as IsLoad } from './is-load-decorator-66e19e04.js';
7
- import { C as ColorHelper } from './color-helper-b5e9aa56.js';
7
+ import { C as ColorHelper } from './color-helper-0277e11a.js';
8
8
  import './datetime-helper-df25808a.js';
9
- import { G as Generate } from './generate-6d61a8d4.js';
10
- import './number-helper-056c158e.js';
9
+ import { G as Generate } from './generate-0dc9b243.js';
10
+ import './number-helper-282f0beb.js';
11
11
  import { S as StringHelper } from './string-helper-0fb7ff20.js';
12
- import './validators-649cde78.js';
12
+ import './validators-089d15b9.js';
13
13
  import './element-dragger-7ea06c76.js';
14
- import { B as Bcm } from './bcm-9f50af9c.js';
14
+ import { a as Bcm } from './bcm-9f50af9c.js';
15
+ import { d as delay } from './utils-b3338faf.js';
15
16
  import { F as FloatingUI } from './floating-ui-4a49ea46.js';
16
17
  import './colors-1d7854ea.js';
17
- import './utils-b3338faf.js';
18
+ import './colors-fabca483.js';
18
19
  import './_commonjsHelpers-3016b722.js';
19
20
 
20
21
  class Popover {
21
- constructor({ content, message, targetId, placement = 'top', color = 'slate-700', trigger = 'none' }) {
22
+ constructor({ content, message, targetId, placement = "top", color = "slate-700", trigger = "none", openDelay = 0, closeDelay = 0, emitShow = () => { }, emitHide = () => { } }) {
23
+ this.destroy = () => {
24
+ this.el = document.getElementById(this.id);
25
+ if (this.el) {
26
+ this.el.remove();
27
+ this.emitHide();
28
+ }
29
+ this.removeListener();
30
+ };
22
31
  this.bgColor = () => ColorHelper.twColor(this.color, 700);
23
32
  this.exepcitonColors = {
24
- white: 'slate-300',
25
- black: 'slate-700',
33
+ white: "slate-300",
34
+ black: "slate-700",
26
35
  };
27
36
  this.target = () => document.getElementById(this.targetId);
28
37
  this.init = () => {
29
- console.log(this.content, this.message);
30
38
  const inner = `<div class="tw-z-[1] tw-rounded tw-py-2 tw-bg-${this.bgColor()}">
31
- ${this.message ? `<div class="tw-font-medium tw-w-full tw-pb-1 tw-px-4">${StringHelper.trim(this.message)}</div>` : ''}
32
- ${this.content ? `<div class="tw-font-normal tw-px-4">${StringHelper.trim(this.content)}</div>` : ''}
39
+ ${this.message ? `<div class="tw-font-medium tw-w-full tw-pb-1 tw-px-4">${StringHelper.trim(this.message)}</div>` : ""}
40
+ ${this.content ? `<div class="tw-font-normal tw-px-4">${StringHelper.trim(this.content)}</div>` : ""}
33
41
  </div>`;
34
- this.el = Generate.createElement('div', {
35
- 'id': `${this.targetId}-popover-box`,
36
- 'class': `
42
+ this.el = Generate.createElement("div", {
43
+ "id": `${this.targetId}-popover-box`,
44
+ "class": `
37
45
  tw-whitespace-normal tw-break-words tw-block tw-font-sans tw-pointer-events-none tw-max-w-[256px] tw-rounded tw-bg-${this.bgColor()} tw-text-white tw-text-3 tw-absolute tw-top-0 tw-left-0 tw-z-tooltip tw-opacity-0 tw-transition-opacity tw-duration-300
38
46
  tw-shadow`,
39
- 'role': 'popover',
40
- 'aria-hidden': 'true',
41
- 'style': `color: ${ColorHelper.twColorReverse(this.bgColor())}`,
42
- 'innerHTML': inner,
47
+ "role": "popover",
48
+ "aria-hidden": "true",
49
+ "style": `color: ${ColorHelper.twColorReverse(this.bgColor())}`,
50
+ "innerHTML": inner,
43
51
  });
44
52
  };
45
53
  this.update = () => {
@@ -50,26 +58,38 @@ class Popover {
50
58
  }
51
59
  };
52
60
  this.listener = () => {
53
- window.addEventListener('resize', this.calculatePosition.bind(this));
54
- window.addEventListener('scroll', this.calculatePosition.bind(this), true);
55
- window.addEventListener('wheel', this.calculatePosition.bind(this));
61
+ window.addEventListener("resize", this.calculatePosition.bind(this));
62
+ window.addEventListener("scroll", this.calculatePosition.bind(this), true);
63
+ window.addEventListener("wheel", this.calculatePosition.bind(this));
56
64
  if (this.trigger && this.target()) {
57
65
  switch (this.trigger) {
58
- case 'click':
59
- this.target().addEventListener('click', this.toggle.bind(this));
66
+ case "click":
67
+ this.target().addEventListener("click", this.toggle.bind(this));
60
68
  break;
61
- case 'hover':
62
- this.target().addEventListener('mouseenter', this.show.bind(this));
63
- this.target().addEventListener('mouseleave', this.hide.bind(this));
69
+ case "hover":
70
+ this.target().addEventListener("mouseenter", this.show.bind(this));
71
+ this.target().addEventListener("mouseleave", this.hide.bind(this));
64
72
  break;
65
- case 'focus':
66
- this.target().addEventListener('focus', this.show.bind(this), true);
67
- this.target().addEventListener('blur', this.hide.bind(this), true);
73
+ case "focus":
74
+ this.target().addEventListener("focus", this.show.bind(this), true);
75
+ this.target().addEventListener("blur", this.hide.bind(this), true);
68
76
  break;
69
77
  }
70
78
  }
71
79
  this.calculatePosition();
72
80
  };
81
+ this.removeListener = () => {
82
+ window.removeEventListener("resize", this.calculatePosition.bind(this));
83
+ window.removeEventListener("scroll", this.calculatePosition.bind(this), true);
84
+ window.removeEventListener("wheel", this.calculatePosition.bind(this));
85
+ if (this.target()) {
86
+ this.target().removeEventListener("click", this.toggle.bind(this));
87
+ this.target().removeEventListener("mouseenter", this.show.bind(this));
88
+ this.target().removeEventListener("mouseleave", this.hide.bind(this));
89
+ this.target().removeEventListener("focus", this.show.bind(this), true);
90
+ this.target().removeEventListener("blur", this.hide.bind(this), true);
91
+ }
92
+ };
73
93
  this.calculatePosition = () => {
74
94
  this.el = document.getElementById(this.id);
75
95
  if (this.el) {
@@ -83,19 +103,23 @@ class Popover {
83
103
  });
84
104
  }
85
105
  };
86
- this.show = () => {
106
+ this.show = async () => {
87
107
  if (this.message) {
88
108
  this.init();
109
+ await delay(this.openDelay);
89
110
  this.calculatePosition();
111
+ this.emitShow();
90
112
  }
91
113
  else {
92
114
  this.hide();
93
115
  }
94
116
  };
95
- this.hide = () => {
117
+ this.hide = async () => {
96
118
  this.el = document.getElementById(this.id);
97
119
  if (this.el) {
120
+ await delay(this.closeDelay);
98
121
  this.el.remove();
122
+ this.emitHide();
99
123
  }
100
124
  };
101
125
  this.toggle = () => {
@@ -113,7 +137,12 @@ class Popover {
113
137
  this.placement = placement;
114
138
  this.color = color;
115
139
  this.trigger = trigger;
116
- this.id = targetId + '-popover-box';
140
+ this.id = targetId + "-popover-box";
141
+ this.openDelay = openDelay;
142
+ this.closeDelay = closeDelay;
143
+ this.emitShow = emitShow;
144
+ this.emitHide = emitHide;
145
+ Generate.observeElementRemoval(document.getElementById(this.targetId), this.destroy.bind(this));
117
146
  }
118
147
  }
119
148
 
@@ -130,6 +159,8 @@ var __decorate = (undefined && undefined.__decorate) || function (decorators, ta
130
159
  const BcmPopover = class {
131
160
  constructor(hostRef) {
132
161
  registerInstance(this, hostRef);
162
+ this.bcmPopoverShow = createEvent(this, "bcmPopoverShow", 7);
163
+ this.bcmPopoverHide = createEvent(this, "bcmPopoverHide", 7);
133
164
  this._id = Generate.UID();
134
165
  this.message = "";
135
166
  this.content = "";
@@ -137,13 +168,29 @@ const BcmPopover = class {
137
168
  this.trigger = Bcm.TriggerType.click;
138
169
  this.open = false;
139
170
  this.color = "white";
171
+ this.targetId = undefined;
172
+ this.openDelay = 0;
173
+ this.closeDelay = 0;
174
+ this.popover = undefined;
175
+ }
176
+ emitShow() {
177
+ this.bcmPopoverShow.emit();
178
+ }
179
+ emitHide() {
180
+ this.bcmPopoverHide.emit();
181
+ }
182
+ componentWillLoad() {
140
183
  this.popover = new Popover({
141
- targetId: this._id,
184
+ targetId: this.targetId || this._id,
142
185
  content: this.content,
143
186
  message: this.message,
144
187
  placement: this.placement,
145
188
  color: this.color,
146
189
  trigger: this.trigger,
190
+ openDelay: this.openDelay,
191
+ closeDelay: this.closeDelay,
192
+ emitShow: () => this.emitShow(),
193
+ emitHide: () => this.emitHide(),
147
194
  });
148
195
  }
149
196
  componentDidLoad() {
@@ -158,6 +205,9 @@ const BcmPopover = class {
158
205
  this.popover.trigger = trigger;
159
206
  this.popover.update();
160
207
  }
208
+ disconnectedCallback() {
209
+ this.popover.destroy();
210
+ }
161
211
  async show() {
162
212
  this.popover.show();
163
213
  }
@@ -5,12 +5,13 @@
5
5
  import { r as registerInstance, h, H as Host, g as getElement } from './index-6e2d80d7.js';
6
6
  import { c as classnames } from './index-ba2edd32.js';
7
7
  import { I as IsLoad } from './is-load-decorator-66e19e04.js';
8
- import { C as ColorHelper } from './color-helper-b5e9aa56.js';
9
- import { G as Generate } from './generate-6d61a8d4.js';
10
- import { a as Bcm } from './bcm-9f50af9c.js';
8
+ import { C as ColorHelper } from './color-helper-0277e11a.js';
9
+ import { G as Generate } from './generate-0dc9b243.js';
10
+ import { B as Bcm } from './bcm-9f50af9c.js';
11
11
  import './_commonjsHelpers-3016b722.js';
12
12
  import './colors-1d7854ea.js';
13
13
  import './utils-b3338faf.js';
14
+ import './colors-fabca483.js';
14
15
 
15
16
  // export const lineSizes = {
16
17
  // small: {
@@ -3,118 +3,24 @@
3
3
  * Copyright (c) Bromcom.
4
4
  */
5
5
  import { r as registerInstance, c as createEvent, h, H as Host, g as getElement } from './index-6e2d80d7.js';
6
- import { c as classnames } from './index-ba2edd32.js';
7
- import { s as snq, G as Generate } from './generate-6d61a8d4.js';
8
- import { I as IsLoad } from './is-load-decorator-66e19e04.js';
6
+ import './color-helper-0277e11a.js';
7
+ import './datetime-helper-df25808a.js';
8
+ import { G as Generate } from './generate-0dc9b243.js';
9
+ import './number-helper-282f0beb.js';
10
+ import './string-helper-0fb7ff20.js';
11
+ import './validators-089d15b9.js';
12
+ import './element-dragger-7ea06c76.js';
13
+ import { d as delay } from './utils-b3338faf.js';
9
14
  import { a as Bcm } from './bcm-9f50af9c.js';
10
15
  import { C as CaptionTemplate } from './caption-template-389f5bd6.js';
11
- import { d as delay, a as getChildElements } from './utils-b3338faf.js';
12
- import { c as createStore } from './index-8b349654.js';
13
- import { S as StringHelper } from './string-helper-0fb7ff20.js';
16
+ import { c as classnames } from './index-ba2edd32.js';
17
+ import './types-6f06fa1a.js';
18
+ import './types-bfc3bba1.js';
19
+ import { I as IsLoad } from './is-load-decorator-66e19e04.js';
20
+ import './colors-1d7854ea.js';
21
+ import './colors-fabca483.js';
14
22
  import './_commonjsHelpers-3016b722.js';
15
23
 
16
- const { state, onChange } = createStore({
17
- group: new Map(),
18
- onChange: {},
19
- });
20
- const setValue = async ({ fullWidth, optionType, buttonStyle, size, disabled, defaultCheckedItems, el, id, label, required, captionType, hidden, direction, childs, gap, name, noCaption, }) => {
21
- if (el) {
22
- state.group.set(id, {
23
- fullWidth,
24
- optionType,
25
- buttonStyle,
26
- size,
27
- disabled,
28
- defaultCheckedItems,
29
- label,
30
- required,
31
- captionType,
32
- hidden,
33
- direction,
34
- gap,
35
- noCaption,
36
- name,
37
- childs: await childs.map(child => {
38
- fullWidth && (child.style.flex = fullWidth == 'flex' ? 'auto' : '100%');
39
- optionType && (child.optionType = optionType);
40
- buttonStyle && (child.buttonStyle = buttonStyle);
41
- size && (child.size = size);
42
- defaultCheckedItems && defaultCheckedItems.find(e => e === child.name) && (child.checked = true);
43
- child.noCaption = noCaption;
44
- return {
45
- id: child.id || Generate.UID(),
46
- checked: child.checked,
47
- name: name,
48
- value: child.value,
49
- size: child.size,
50
- buttonStyle: child.buttonStyle,
51
- optionType: child.optionType,
52
- style: child.style,
53
- noCaption: child.noCaption,
54
- color: child.color,
55
- disabled: child.disabled,
56
- label: child.label || child.name,
57
- slot: child.slot || child.textContent,
58
- required,
59
- captionType,
60
- hidden: child.hidden
61
- };
62
- }),
63
- });
64
- }
65
- };
66
- const getProperty = id => {
67
- return snq(() => state.group.get(id), {});
68
- };
69
- const getValue = id => {
70
- const group = getProperty(id);
71
- let value = null;
72
- group.childs.map(child => {
73
- child.checked == true && (value = child.value || child.slot);
74
- });
75
- return value && StringHelper.trim(value);
76
- };
77
- const setClear = id => {
78
- getProperty(id).childs.forEach(child => {
79
- child.checked = false;
80
- });
81
- };
82
- const setCheckedItem = (id, itemId, checked) => {
83
- const childs = getProperty(id).childs;
84
- if (childs && childs.length > 0) {
85
- childs.forEach(child => {
86
- child.checked = child.id == itemId || child.value == itemId ? checked : false;
87
- });
88
- }
89
- };
90
- const resetCaption = id => {
91
- const noCaption = getProperty(id).noCaption;
92
- getProperty(id).childs.forEach(child => {
93
- child.resetCaption();
94
- child.noCaption = noCaption;
95
- });
96
- };
97
- const removeState = id => {
98
- return Promise.resolve(state.group.delete(id));
99
- };
100
- onChange('onChange', (obj) => {
101
- getProperty(obj.id).childs.map(child => {
102
- child.checked = child.id === obj.childId;
103
- });
104
- });
105
- const radioGroupState = {
106
- setValue,
107
- getValue,
108
- setCheckedItem,
109
- getProperty,
110
- setClear,
111
- removeState,
112
- resetCaption,
113
- state,
114
- };
115
-
116
- const groupCss = "@import url(\"https://fonts.googleapis.com/css?family=Roboto:400,500\");@import url(\"https://fonts.googleapis.com/css2?family=Inter:wght@200;400;500;600&display=swap\"); @import url(\"https://fonts.googleapis.com/css2?family=Inter:wght@200;400;500;600&display=swap\"); .size-1{font-size:12px;line-height:20px}.size-2{font-size:14px;line-height:22px}.size-3{font-size:16px;line-height:24px}.size-4{font-size:20px;line-height:28px}.size-5{font-size:24px;line-height:32px}.size-6{font-size:30px;line-height:38px}.size-7{font-size:38px;line-height:46px}.size-8{font-size:46px;line-height:54px}.size-9{font-size:56px;line-height:64px}.weight-regular{font-weight:400}.weight-semibold{font-weight:500}.input-size-large{height:40px}.input-size-medium{height:32px}.input-size-small{height:24px}.resize-none textarea{resize:none}.resize-vertical textarea{resize:vertical}.resize-auto textarea{height:auto;resize:none}.textarea-size-large{padding:4px 0 0 4px;min-height:40px}.textarea-size-large .bcm-input-element{min-height:calc((40px - 8px) + 2px)}.textarea-size-large .input-clear-button{height:calc( 40px - 16px );top:8px;padding:0;margin-right:8px}.textarea-size-medium{padding:4px 0 0 4px;min-height:32px}.textarea-size-medium .bcm-input-element{min-height:calc((32px - 8px) + 2px)}.textarea-size-medium .input-clear-button{height:calc( 32px - 16px );top:8px;padding:0;margin-right:8px}.textarea-size-small{padding:0px 0 0 4px;min-height:24px}.textarea-size-small .bcm-input-element{min-height:calc((24px - 8px) + 2px)}.textarea-size-small .input-clear-button{height:calc( 24px - 16px );top:8px;padding:0;margin-right:8px}:root,::after,::before{--bcm-new-ds-color-inherit:inherit;--bcm-new-ds-color-current:currentColor;--bcm-new-ds-color-transparent:transparent;--bcm-new-ds-color-black:#000;--bcm-new-ds-color-white:#fff;--bcm-new-ds-color-slate:#64748b;--bcm-new-ds-color-slate-50:#f8fafc;--bcm-new-ds-color-slate-100:#f1f5f9;--bcm-new-ds-color-slate-200:#e2e8f0;--bcm-new-ds-color-slate-300:#cbd5e1;--bcm-new-ds-color-slate-400:#94a3b8;--bcm-new-ds-color-slate-500:#64748b;--bcm-new-ds-color-slate-600:#475569;--bcm-new-ds-color-slate-700:#334155;--bcm-new-ds-color-slate-800:#1e293b;--bcm-new-ds-color-slate-900:#0f172a;--bcm-new-ds-color-gray:#6b7280;--bcm-new-ds-color-gray-50:#f9fafb;--bcm-new-ds-color-gray-100:#f3f4f6;--bcm-new-ds-color-gray-200:#e5e7eb;--bcm-new-ds-color-gray-300:#d1d5db;--bcm-new-ds-color-gray-400:#9ca3af;--bcm-new-ds-color-gray-500:#6b7280;--bcm-new-ds-color-gray-600:#4b5563;--bcm-new-ds-color-gray-700:#374151;--bcm-new-ds-color-gray-800:#1f2937;--bcm-new-ds-color-gray-900:#111827;--bcm-new-ds-color-zinc:#71717a;--bcm-new-ds-color-zinc-50:#fafafa;--bcm-new-ds-color-zinc-100:#f4f4f5;--bcm-new-ds-color-zinc-200:#e4e4e7;--bcm-new-ds-color-zinc-300:#d4d4d8;--bcm-new-ds-color-zinc-400:#a1a1aa;--bcm-new-ds-color-zinc-500:#71717a;--bcm-new-ds-color-zinc-600:#52525b;--bcm-new-ds-color-zinc-700:#3f3f46;--bcm-new-ds-color-zinc-800:#27272a;--bcm-new-ds-color-zinc-900:#18181b;--bcm-new-ds-color-neutral:#737373;--bcm-new-ds-color-neutral-50:#fafafa;--bcm-new-ds-color-neutral-100:#f5f5f5;--bcm-new-ds-color-neutral-200:#e5e5e5;--bcm-new-ds-color-neutral-300:#d4d4d4;--bcm-new-ds-color-neutral-400:#a3a3a3;--bcm-new-ds-color-neutral-500:#737373;--bcm-new-ds-color-neutral-600:#525252;--bcm-new-ds-color-neutral-700:#404040;--bcm-new-ds-color-neutral-800:#262626;--bcm-new-ds-color-neutral-900:#171717;--bcm-new-ds-color-stone:#78716c;--bcm-new-ds-color-stone-50:#fafaf9;--bcm-new-ds-color-stone-100:#f5f5f4;--bcm-new-ds-color-stone-200:#e7e5e4;--bcm-new-ds-color-stone-300:#d6d3d1;--bcm-new-ds-color-stone-400:#a8a29e;--bcm-new-ds-color-stone-500:#78716c;--bcm-new-ds-color-stone-600:#57534e;--bcm-new-ds-color-stone-700:#44403c;--bcm-new-ds-color-stone-800:#292524;--bcm-new-ds-color-stone-900:#1c1917;--bcm-new-ds-color-red:#ef4444;--bcm-new-ds-color-red-50:#fef2f2;--bcm-new-ds-color-red-100:#fee2e2;--bcm-new-ds-color-red-200:#fecaca;--bcm-new-ds-color-red-300:#fca5a5;--bcm-new-ds-color-red-400:#f87171;--bcm-new-ds-color-red-500:#ef4444;--bcm-new-ds-color-red-600:#dc2626;--bcm-new-ds-color-red-700:#b91c1c;--bcm-new-ds-color-red-800:#991b1b;--bcm-new-ds-color-red-900:#7f1d1d;--bcm-new-ds-color-orange:#f97316;--bcm-new-ds-color-orange-50:#fff7ed;--bcm-new-ds-color-orange-100:#ffedd5;--bcm-new-ds-color-orange-200:#fed7aa;--bcm-new-ds-color-orange-300:#fdba74;--bcm-new-ds-color-orange-400:#fb923c;--bcm-new-ds-color-orange-500:#f97316;--bcm-new-ds-color-orange-600:#ea580c;--bcm-new-ds-color-orange-700:#c2410c;--bcm-new-ds-color-orange-800:#9a3412;--bcm-new-ds-color-orange-900:#7c2d12;--bcm-new-ds-color-amber:#f59e0b;--bcm-new-ds-color-amber-50:#fffbeb;--bcm-new-ds-color-amber-100:#fef3c7;--bcm-new-ds-color-amber-200:#fde68a;--bcm-new-ds-color-amber-300:#fcd34d;--bcm-new-ds-color-amber-400:#fbbf24;--bcm-new-ds-color-amber-500:#f59e0b;--bcm-new-ds-color-amber-600:#d97706;--bcm-new-ds-color-amber-700:#b45309;--bcm-new-ds-color-amber-800:#92400e;--bcm-new-ds-color-amber-900:#78350f;--bcm-new-ds-color-yellow:#eab308;--bcm-new-ds-color-yellow-50:#fefce8;--bcm-new-ds-color-yellow-100:#fef9c3;--bcm-new-ds-color-yellow-200:#fef08a;--bcm-new-ds-color-yellow-300:#fde047;--bcm-new-ds-color-yellow-400:#facc15;--bcm-new-ds-color-yellow-500:#eab308;--bcm-new-ds-color-yellow-600:#ca8a04;--bcm-new-ds-color-yellow-700:#a16207;--bcm-new-ds-color-yellow-800:#854d0e;--bcm-new-ds-color-yellow-900:#713f12;--bcm-new-ds-color-lime:#84cc16;--bcm-new-ds-color-lime-50:#f7fee7;--bcm-new-ds-color-lime-100:#ecfccb;--bcm-new-ds-color-lime-200:#d9f99d;--bcm-new-ds-color-lime-300:#bef264;--bcm-new-ds-color-lime-400:#a3e635;--bcm-new-ds-color-lime-500:#84cc16;--bcm-new-ds-color-lime-600:#65a30d;--bcm-new-ds-color-lime-700:#4d7c0f;--bcm-new-ds-color-lime-800:#3f6212;--bcm-new-ds-color-lime-900:#365314;--bcm-new-ds-color-green:#22c55e;--bcm-new-ds-color-green-50:#f0fdf4;--bcm-new-ds-color-green-100:#dcfce7;--bcm-new-ds-color-green-200:#bbf7d0;--bcm-new-ds-color-green-300:#86efac;--bcm-new-ds-color-green-400:#4ade80;--bcm-new-ds-color-green-500:#22c55e;--bcm-new-ds-color-green-600:#16a34a;--bcm-new-ds-color-green-700:#15803d;--bcm-new-ds-color-green-800:#166534;--bcm-new-ds-color-green-900:#14532d;--bcm-new-ds-color-emerald:#10b981;--bcm-new-ds-color-emerald-50:#ecfdf5;--bcm-new-ds-color-emerald-100:#d1fae5;--bcm-new-ds-color-emerald-200:#a7f3d0;--bcm-new-ds-color-emerald-300:#6ee7b7;--bcm-new-ds-color-emerald-400:#34d399;--bcm-new-ds-color-emerald-500:#10b981;--bcm-new-ds-color-emerald-600:#059669;--bcm-new-ds-color-emerald-700:#047857;--bcm-new-ds-color-emerald-800:#065f46;--bcm-new-ds-color-emerald-900:#064e3b;--bcm-new-ds-color-teal:#14b8a6;--bcm-new-ds-color-teal-50:#f0fdfa;--bcm-new-ds-color-teal-100:#ccfbf1;--bcm-new-ds-color-teal-200:#99f6e4;--bcm-new-ds-color-teal-300:#5eead4;--bcm-new-ds-color-teal-400:#2dd4bf;--bcm-new-ds-color-teal-500:#14b8a6;--bcm-new-ds-color-teal-600:#0d9488;--bcm-new-ds-color-teal-700:#0f766e;--bcm-new-ds-color-teal-800:#115e59;--bcm-new-ds-color-teal-900:#134e4a;--bcm-new-ds-color-cyan:#06b6d4;--bcm-new-ds-color-cyan-50:#ecfeff;--bcm-new-ds-color-cyan-100:#cffafe;--bcm-new-ds-color-cyan-200:#a5f3fc;--bcm-new-ds-color-cyan-300:#67e8f9;--bcm-new-ds-color-cyan-400:#22d3ee;--bcm-new-ds-color-cyan-500:#06b6d4;--bcm-new-ds-color-cyan-600:#0891b2;--bcm-new-ds-color-cyan-700:#0e7490;--bcm-new-ds-color-cyan-800:#155e75;--bcm-new-ds-color-cyan-900:#164e63;--bcm-new-ds-color-sky:#0ea5e9;--bcm-new-ds-color-sky-50:#f0f9ff;--bcm-new-ds-color-sky-100:#e0f2fe;--bcm-new-ds-color-sky-200:#bae6fd;--bcm-new-ds-color-sky-300:#7dd3fc;--bcm-new-ds-color-sky-400:#38bdf8;--bcm-new-ds-color-sky-500:#0ea5e9;--bcm-new-ds-color-sky-600:#0284c7;--bcm-new-ds-color-sky-700:#0369a1;--bcm-new-ds-color-sky-800:#075985;--bcm-new-ds-color-sky-900:#0c4a6e;--bcm-new-ds-color-blue:#3b82f6;--bcm-new-ds-color-blue-50:#eff6ff;--bcm-new-ds-color-blue-100:#dbeafe;--bcm-new-ds-color-blue-200:#bfdbfe;--bcm-new-ds-color-blue-300:#93c5fd;--bcm-new-ds-color-blue-400:#60a5fa;--bcm-new-ds-color-blue-500:#3b82f6;--bcm-new-ds-color-blue-600:#2563eb;--bcm-new-ds-color-blue-700:#1d4ed8;--bcm-new-ds-color-blue-800:#1e40af;--bcm-new-ds-color-blue-900:#1e3a8a;--bcm-new-ds-color-indigo:#6366f1;--bcm-new-ds-color-indigo-50:#eef2ff;--bcm-new-ds-color-indigo-100:#e0e7ff;--bcm-new-ds-color-indigo-200:#c7d2fe;--bcm-new-ds-color-indigo-300:#a5b4fc;--bcm-new-ds-color-indigo-400:#818cf8;--bcm-new-ds-color-indigo-500:#6366f1;--bcm-new-ds-color-indigo-600:#4f46e5;--bcm-new-ds-color-indigo-700:#4338ca;--bcm-new-ds-color-indigo-800:#3730a3;--bcm-new-ds-color-indigo-900:#312e81;--bcm-new-ds-color-violet:#8b5cf6;--bcm-new-ds-color-violet-50:#f5f3ff;--bcm-new-ds-color-violet-100:#ede9fe;--bcm-new-ds-color-violet-200:#ddd6fe;--bcm-new-ds-color-violet-300:#c4b5fd;--bcm-new-ds-color-violet-400:#a78bfa;--bcm-new-ds-color-violet-500:#8b5cf6;--bcm-new-ds-color-violet-600:#7c3aed;--bcm-new-ds-color-violet-700:#6d28d9;--bcm-new-ds-color-violet-800:#5b21b6;--bcm-new-ds-color-violet-900:#4c1d95;--bcm-new-ds-color-purple:#a855f7;--bcm-new-ds-color-purple-50:#faf5ff;--bcm-new-ds-color-purple-100:#f3e8ff;--bcm-new-ds-color-purple-200:#e9d5ff;--bcm-new-ds-color-purple-300:#d8b4fe;--bcm-new-ds-color-purple-400:#c084fc;--bcm-new-ds-color-purple-500:#a855f7;--bcm-new-ds-color-purple-600:#9333ea;--bcm-new-ds-color-purple-700:#7e22ce;--bcm-new-ds-color-purple-800:#6b21a8;--bcm-new-ds-color-purple-900:#581c87;--bcm-new-ds-color-fuchsia:#d946ef;--bcm-new-ds-color-fuchsia-50:#fdf4ff;--bcm-new-ds-color-fuchsia-100:#fae8ff;--bcm-new-ds-color-fuchsia-200:#f5d0fe;--bcm-new-ds-color-fuchsia-300:#f0abfc;--bcm-new-ds-color-fuchsia-400:#e879f9;--bcm-new-ds-color-fuchsia-500:#d946ef;--bcm-new-ds-color-fuchsia-600:#c026d3;--bcm-new-ds-color-fuchsia-700:#a21caf;--bcm-new-ds-color-fuchsia-800:#86198f;--bcm-new-ds-color-fuchsia-900:#701a75;--bcm-new-ds-color-pink:#ec4899;--bcm-new-ds-color-pink-50:#fdf2f8;--bcm-new-ds-color-pink-100:#fce7f3;--bcm-new-ds-color-pink-200:#fbcfe8;--bcm-new-ds-color-pink-300:#f9a8d4;--bcm-new-ds-color-pink-400:#f472b6;--bcm-new-ds-color-pink-500:#ec4899;--bcm-new-ds-color-pink-600:#db2777;--bcm-new-ds-color-pink-700:#be185d;--bcm-new-ds-color-pink-800:#9d174d;--bcm-new-ds-color-pink-900:#831843;--bcm-new-ds-color-rose:#f43f5e;--bcm-new-ds-color-rose-50:#fff1f2;--bcm-new-ds-color-rose-100:#ffe4e6;--bcm-new-ds-color-rose-200:#fecdd3;--bcm-new-ds-color-rose-300:#fda4af;--bcm-new-ds-color-rose-400:#fb7185;--bcm-new-ds-color-rose-500:#f43f5e;--bcm-new-ds-color-rose-600:#e11d48;--bcm-new-ds-color-rose-700:#be123c;--bcm-new-ds-color-rose-800:#9f1239;--bcm-new-ds-color-rose-900:#881337}*{box-sizing:border-box}.bcm-caption-area{font-family:\"Inter\", sans-serif;font-size:14px;line-height:calc(14px + 8px);font-weight:400;font-size:12px;line-height:calc(12px + 8px);color:var(--bcm-new-ds-color-slate-400);display:flex;flex-direction:row;align-items:flex-start;justify-content:space-between;flex-wrap:nowrap;margin-top:2px}.bcm-caption-area__text{color:var(--bcm-new-ds-color-slate-400)}.bcm-caption-area__text.default{color:var(--bcm-new-ds-color-slate-400)}.bcm-caption-area__text.info{color:var(--bcm-new-ds-color-blue-500)}.bcm-caption-area__text.success{color:var(--bcm-new-ds-color-emerald-500)}.bcm-caption-area__text.warning{color:var(--bcm-new-ds-color-amber-500)}.bcm-caption-area__text.error{color:var(--bcm-new-ds-color-red-500)}.bcm-caption-area__size-small{font-size:10px;line-height:calc(10px + 8px);min-height:calc(10px + 8px)}.bcm-caption-area__size-medium{font-size:12px;line-height:calc(12px + 8px);min-height:calc(12px + 8px)}.bcm-caption-area__size-large{font-size:14px;line-height:calc(14px + 8px);min-height:calc(14px + 8px)}:root,::after,::before{--bcm-new-ds-color-inherit:inherit;--bcm-new-ds-color-current:currentColor;--bcm-new-ds-color-transparent:transparent;--bcm-new-ds-color-black:#000;--bcm-new-ds-color-white:#fff;--bcm-new-ds-color-slate:#64748b;--bcm-new-ds-color-slate-50:#f8fafc;--bcm-new-ds-color-slate-100:#f1f5f9;--bcm-new-ds-color-slate-200:#e2e8f0;--bcm-new-ds-color-slate-300:#cbd5e1;--bcm-new-ds-color-slate-400:#94a3b8;--bcm-new-ds-color-slate-500:#64748b;--bcm-new-ds-color-slate-600:#475569;--bcm-new-ds-color-slate-700:#334155;--bcm-new-ds-color-slate-800:#1e293b;--bcm-new-ds-color-slate-900:#0f172a;--bcm-new-ds-color-gray:#6b7280;--bcm-new-ds-color-gray-50:#f9fafb;--bcm-new-ds-color-gray-100:#f3f4f6;--bcm-new-ds-color-gray-200:#e5e7eb;--bcm-new-ds-color-gray-300:#d1d5db;--bcm-new-ds-color-gray-400:#9ca3af;--bcm-new-ds-color-gray-500:#6b7280;--bcm-new-ds-color-gray-600:#4b5563;--bcm-new-ds-color-gray-700:#374151;--bcm-new-ds-color-gray-800:#1f2937;--bcm-new-ds-color-gray-900:#111827;--bcm-new-ds-color-zinc:#71717a;--bcm-new-ds-color-zinc-50:#fafafa;--bcm-new-ds-color-zinc-100:#f4f4f5;--bcm-new-ds-color-zinc-200:#e4e4e7;--bcm-new-ds-color-zinc-300:#d4d4d8;--bcm-new-ds-color-zinc-400:#a1a1aa;--bcm-new-ds-color-zinc-500:#71717a;--bcm-new-ds-color-zinc-600:#52525b;--bcm-new-ds-color-zinc-700:#3f3f46;--bcm-new-ds-color-zinc-800:#27272a;--bcm-new-ds-color-zinc-900:#18181b;--bcm-new-ds-color-neutral:#737373;--bcm-new-ds-color-neutral-50:#fafafa;--bcm-new-ds-color-neutral-100:#f5f5f5;--bcm-new-ds-color-neutral-200:#e5e5e5;--bcm-new-ds-color-neutral-300:#d4d4d4;--bcm-new-ds-color-neutral-400:#a3a3a3;--bcm-new-ds-color-neutral-500:#737373;--bcm-new-ds-color-neutral-600:#525252;--bcm-new-ds-color-neutral-700:#404040;--bcm-new-ds-color-neutral-800:#262626;--bcm-new-ds-color-neutral-900:#171717;--bcm-new-ds-color-stone:#78716c;--bcm-new-ds-color-stone-50:#fafaf9;--bcm-new-ds-color-stone-100:#f5f5f4;--bcm-new-ds-color-stone-200:#e7e5e4;--bcm-new-ds-color-stone-300:#d6d3d1;--bcm-new-ds-color-stone-400:#a8a29e;--bcm-new-ds-color-stone-500:#78716c;--bcm-new-ds-color-stone-600:#57534e;--bcm-new-ds-color-stone-700:#44403c;--bcm-new-ds-color-stone-800:#292524;--bcm-new-ds-color-stone-900:#1c1917;--bcm-new-ds-color-red:#ef4444;--bcm-new-ds-color-red-50:#fef2f2;--bcm-new-ds-color-red-100:#fee2e2;--bcm-new-ds-color-red-200:#fecaca;--bcm-new-ds-color-red-300:#fca5a5;--bcm-new-ds-color-red-400:#f87171;--bcm-new-ds-color-red-500:#ef4444;--bcm-new-ds-color-red-600:#dc2626;--bcm-new-ds-color-red-700:#b91c1c;--bcm-new-ds-color-red-800:#991b1b;--bcm-new-ds-color-red-900:#7f1d1d;--bcm-new-ds-color-orange:#f97316;--bcm-new-ds-color-orange-50:#fff7ed;--bcm-new-ds-color-orange-100:#ffedd5;--bcm-new-ds-color-orange-200:#fed7aa;--bcm-new-ds-color-orange-300:#fdba74;--bcm-new-ds-color-orange-400:#fb923c;--bcm-new-ds-color-orange-500:#f97316;--bcm-new-ds-color-orange-600:#ea580c;--bcm-new-ds-color-orange-700:#c2410c;--bcm-new-ds-color-orange-800:#9a3412;--bcm-new-ds-color-orange-900:#7c2d12;--bcm-new-ds-color-amber:#f59e0b;--bcm-new-ds-color-amber-50:#fffbeb;--bcm-new-ds-color-amber-100:#fef3c7;--bcm-new-ds-color-amber-200:#fde68a;--bcm-new-ds-color-amber-300:#fcd34d;--bcm-new-ds-color-amber-400:#fbbf24;--bcm-new-ds-color-amber-500:#f59e0b;--bcm-new-ds-color-amber-600:#d97706;--bcm-new-ds-color-amber-700:#b45309;--bcm-new-ds-color-amber-800:#92400e;--bcm-new-ds-color-amber-900:#78350f;--bcm-new-ds-color-yellow:#eab308;--bcm-new-ds-color-yellow-50:#fefce8;--bcm-new-ds-color-yellow-100:#fef9c3;--bcm-new-ds-color-yellow-200:#fef08a;--bcm-new-ds-color-yellow-300:#fde047;--bcm-new-ds-color-yellow-400:#facc15;--bcm-new-ds-color-yellow-500:#eab308;--bcm-new-ds-color-yellow-600:#ca8a04;--bcm-new-ds-color-yellow-700:#a16207;--bcm-new-ds-color-yellow-800:#854d0e;--bcm-new-ds-color-yellow-900:#713f12;--bcm-new-ds-color-lime:#84cc16;--bcm-new-ds-color-lime-50:#f7fee7;--bcm-new-ds-color-lime-100:#ecfccb;--bcm-new-ds-color-lime-200:#d9f99d;--bcm-new-ds-color-lime-300:#bef264;--bcm-new-ds-color-lime-400:#a3e635;--bcm-new-ds-color-lime-500:#84cc16;--bcm-new-ds-color-lime-600:#65a30d;--bcm-new-ds-color-lime-700:#4d7c0f;--bcm-new-ds-color-lime-800:#3f6212;--bcm-new-ds-color-lime-900:#365314;--bcm-new-ds-color-green:#22c55e;--bcm-new-ds-color-green-50:#f0fdf4;--bcm-new-ds-color-green-100:#dcfce7;--bcm-new-ds-color-green-200:#bbf7d0;--bcm-new-ds-color-green-300:#86efac;--bcm-new-ds-color-green-400:#4ade80;--bcm-new-ds-color-green-500:#22c55e;--bcm-new-ds-color-green-600:#16a34a;--bcm-new-ds-color-green-700:#15803d;--bcm-new-ds-color-green-800:#166534;--bcm-new-ds-color-green-900:#14532d;--bcm-new-ds-color-emerald:#10b981;--bcm-new-ds-color-emerald-50:#ecfdf5;--bcm-new-ds-color-emerald-100:#d1fae5;--bcm-new-ds-color-emerald-200:#a7f3d0;--bcm-new-ds-color-emerald-300:#6ee7b7;--bcm-new-ds-color-emerald-400:#34d399;--bcm-new-ds-color-emerald-500:#10b981;--bcm-new-ds-color-emerald-600:#059669;--bcm-new-ds-color-emerald-700:#047857;--bcm-new-ds-color-emerald-800:#065f46;--bcm-new-ds-color-emerald-900:#064e3b;--bcm-new-ds-color-teal:#14b8a6;--bcm-new-ds-color-teal-50:#f0fdfa;--bcm-new-ds-color-teal-100:#ccfbf1;--bcm-new-ds-color-teal-200:#99f6e4;--bcm-new-ds-color-teal-300:#5eead4;--bcm-new-ds-color-teal-400:#2dd4bf;--bcm-new-ds-color-teal-500:#14b8a6;--bcm-new-ds-color-teal-600:#0d9488;--bcm-new-ds-color-teal-700:#0f766e;--bcm-new-ds-color-teal-800:#115e59;--bcm-new-ds-color-teal-900:#134e4a;--bcm-new-ds-color-cyan:#06b6d4;--bcm-new-ds-color-cyan-50:#ecfeff;--bcm-new-ds-color-cyan-100:#cffafe;--bcm-new-ds-color-cyan-200:#a5f3fc;--bcm-new-ds-color-cyan-300:#67e8f9;--bcm-new-ds-color-cyan-400:#22d3ee;--bcm-new-ds-color-cyan-500:#06b6d4;--bcm-new-ds-color-cyan-600:#0891b2;--bcm-new-ds-color-cyan-700:#0e7490;--bcm-new-ds-color-cyan-800:#155e75;--bcm-new-ds-color-cyan-900:#164e63;--bcm-new-ds-color-sky:#0ea5e9;--bcm-new-ds-color-sky-50:#f0f9ff;--bcm-new-ds-color-sky-100:#e0f2fe;--bcm-new-ds-color-sky-200:#bae6fd;--bcm-new-ds-color-sky-300:#7dd3fc;--bcm-new-ds-color-sky-400:#38bdf8;--bcm-new-ds-color-sky-500:#0ea5e9;--bcm-new-ds-color-sky-600:#0284c7;--bcm-new-ds-color-sky-700:#0369a1;--bcm-new-ds-color-sky-800:#075985;--bcm-new-ds-color-sky-900:#0c4a6e;--bcm-new-ds-color-blue:#3b82f6;--bcm-new-ds-color-blue-50:#eff6ff;--bcm-new-ds-color-blue-100:#dbeafe;--bcm-new-ds-color-blue-200:#bfdbfe;--bcm-new-ds-color-blue-300:#93c5fd;--bcm-new-ds-color-blue-400:#60a5fa;--bcm-new-ds-color-blue-500:#3b82f6;--bcm-new-ds-color-blue-600:#2563eb;--bcm-new-ds-color-blue-700:#1d4ed8;--bcm-new-ds-color-blue-800:#1e40af;--bcm-new-ds-color-blue-900:#1e3a8a;--bcm-new-ds-color-indigo:#6366f1;--bcm-new-ds-color-indigo-50:#eef2ff;--bcm-new-ds-color-indigo-100:#e0e7ff;--bcm-new-ds-color-indigo-200:#c7d2fe;--bcm-new-ds-color-indigo-300:#a5b4fc;--bcm-new-ds-color-indigo-400:#818cf8;--bcm-new-ds-color-indigo-500:#6366f1;--bcm-new-ds-color-indigo-600:#4f46e5;--bcm-new-ds-color-indigo-700:#4338ca;--bcm-new-ds-color-indigo-800:#3730a3;--bcm-new-ds-color-indigo-900:#312e81;--bcm-new-ds-color-violet:#8b5cf6;--bcm-new-ds-color-violet-50:#f5f3ff;--bcm-new-ds-color-violet-100:#ede9fe;--bcm-new-ds-color-violet-200:#ddd6fe;--bcm-new-ds-color-violet-300:#c4b5fd;--bcm-new-ds-color-violet-400:#a78bfa;--bcm-new-ds-color-violet-500:#8b5cf6;--bcm-new-ds-color-violet-600:#7c3aed;--bcm-new-ds-color-violet-700:#6d28d9;--bcm-new-ds-color-violet-800:#5b21b6;--bcm-new-ds-color-violet-900:#4c1d95;--bcm-new-ds-color-purple:#a855f7;--bcm-new-ds-color-purple-50:#faf5ff;--bcm-new-ds-color-purple-100:#f3e8ff;--bcm-new-ds-color-purple-200:#e9d5ff;--bcm-new-ds-color-purple-300:#d8b4fe;--bcm-new-ds-color-purple-400:#c084fc;--bcm-new-ds-color-purple-500:#a855f7;--bcm-new-ds-color-purple-600:#9333ea;--bcm-new-ds-color-purple-700:#7e22ce;--bcm-new-ds-color-purple-800:#6b21a8;--bcm-new-ds-color-purple-900:#581c87;--bcm-new-ds-color-fuchsia:#d946ef;--bcm-new-ds-color-fuchsia-50:#fdf4ff;--bcm-new-ds-color-fuchsia-100:#fae8ff;--bcm-new-ds-color-fuchsia-200:#f5d0fe;--bcm-new-ds-color-fuchsia-300:#f0abfc;--bcm-new-ds-color-fuchsia-400:#e879f9;--bcm-new-ds-color-fuchsia-500:#d946ef;--bcm-new-ds-color-fuchsia-600:#c026d3;--bcm-new-ds-color-fuchsia-700:#a21caf;--bcm-new-ds-color-fuchsia-800:#86198f;--bcm-new-ds-color-fuchsia-900:#701a75;--bcm-new-ds-color-pink:#ec4899;--bcm-new-ds-color-pink-50:#fdf2f8;--bcm-new-ds-color-pink-100:#fce7f3;--bcm-new-ds-color-pink-200:#fbcfe8;--bcm-new-ds-color-pink-300:#f9a8d4;--bcm-new-ds-color-pink-400:#f472b6;--bcm-new-ds-color-pink-500:#ec4899;--bcm-new-ds-color-pink-600:#db2777;--bcm-new-ds-color-pink-700:#be185d;--bcm-new-ds-color-pink-800:#9d174d;--bcm-new-ds-color-pink-900:#831843;--bcm-new-ds-color-rose:#f43f5e;--bcm-new-ds-color-rose-50:#fff1f2;--bcm-new-ds-color-rose-100:#ffe4e6;--bcm-new-ds-color-rose-200:#fecdd3;--bcm-new-ds-color-rose-300:#fda4af;--bcm-new-ds-color-rose-400:#fb7185;--bcm-new-ds-color-rose-500:#f43f5e;--bcm-new-ds-color-rose-600:#e11d48;--bcm-new-ds-color-rose-700:#be123c;--bcm-new-ds-color-rose-800:#9f1239;--bcm-new-ds-color-rose-900:#881337}*{box-sizing:border-box}.bcm-label{display:inline-flex;align-items:flex-start;grid-gap:2px}.bcm-label__text{margin-bottom:2px;font-family:\"Inter\", sans-serif;font-size:14px;line-height:calc(14px + 8px);font-weight:400;display:inline-block;color:var(--bcm-new-ds-color-slate-600)}.bcm-label__size-small{font-size:10px;line-height:calc(10px + 8px);min-height:calc(10px + 8px)}.bcm-label__size-medium{font-size:12px;line-height:calc(12px + 8px);min-height:calc(12px + 8px)}.bcm-label__size-large{font-size:14px;line-height:calc(14px + 8px);min-height:calc(14px + 8px)}.bcm-input[no-margin]{margin:0}.bcm-textarea[no-margin]{margin:0}.bcm-switch[no-margin]{margin:0}.bcm-checkbox[no-margin]{margin:0}.bcm-radio-group[no-margin]{margin:0}.bcm-checkbox-group[no-margin]{margin:0}.bcm-range[no-margin]{margin:0}.bcm-form[no-margin]{margin:0}.bcm-form-group[no-margin]{margin:0}.bcm-list[no-margin]{margin:0}.bcm-colorpicker[no-margin]{margin:0}.bcm-date-picker[no-margin]{margin:0}.bcm-time-picker[no-margin]{margin:0}.bcm-datetime-picker[no-margin]{margin:0}.bcm-select[no-margin]{margin:0}.bcm-listbox[no-margin]{margin:0}.bcm-radio-group{margin-bottom:8px;display:block}.bcm-radio-group.hidden{display:none}.bcm-radio-group__container{display:flex;flex-wrap:wrap;justify-content:flex-start;align-items:flex-start;width:100%}.bcm-radio-group__container.vertical{gap:8px;flex-direction:column}.bcm-radio-group__container.full-width{max-width:100%}";
117
-
118
24
  var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
119
25
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
120
26
  if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
@@ -130,78 +36,68 @@ const BcmRadioGroup = class {
130
36
  registerInstance(this, hostRef);
131
37
  this.change = createEvent(this, "bcm-change", 7);
132
38
  this._id = Generate.UID();
133
- this.value = undefined;
134
- this.direction = Bcm.Direction.horizontal;
135
- this.items = [];
136
- this.size = Bcm.Size.medium;
137
- this.name = undefined;
138
39
  this.label = undefined;
40
+ this.name = undefined;
41
+ this.value = null;
42
+ this.defaultValue = undefined;
43
+ this.size = Bcm.Size.medium;
139
44
  this.disabled = false;
140
45
  this.hidden = false;
141
46
  this.required = false;
142
47
  this.gap = undefined;
143
- this.defaultValue = undefined;
144
- this.optionType = 'default';
145
- this.buttonStyle = 'solid';
48
+ this.direction = Bcm.Direction.horizontal;
146
49
  this.fullWidth = false;
50
+ this.items = [];
147
51
  this.caption = undefined;
148
52
  this.noCaption = false;
149
53
  this.captionError = undefined;
150
54
  this.captionType = Bcm.Status.default;
151
55
  this.captionCache = undefined;
152
56
  this.captionTypeCache = undefined;
153
- this.radioOptions = [];
154
- this.usingSlots = true;
155
- this.tick = {};
156
57
  }
157
- disconnectedCallback() {
158
- radioGroupState.removeState(this._id);
58
+ get radios() {
59
+ return Array.from(this.el.querySelectorAll("bcm-radio"));
159
60
  }
160
- componentDidLoad() {
161
- this.initState();
61
+ get Items() {
62
+ return this.items;
162
63
  }
163
- componentShouldUpdate(newVal, oldVal, propName) {
164
- if ((propName == 'defaultValue' || propName == 'tick') && newVal !== oldVal) {
165
- const isHaveChild = snq(() => radioGroupState.getProperty(this._id).childs.length > 0, false);
166
- if (isHaveChild) {
167
- this.getValue().then(values => (this.value = values));
168
- }
169
- }
64
+ connectedCallback() {
65
+ this.captionCache = this.caption;
66
+ this.captionTypeCache = this.captionType;
170
67
  }
171
- async initState() {
172
- const { fullWidth, optionType, buttonStyle, size, disabled, noCaption, defaultValue, label, required, captionType, hidden, direction, gap, items, name } = this;
173
- const defaultCheckedItems = defaultValue && defaultValue;
174
- const childElements = items.length > 0 ? snq(() => (typeof this.items == 'string' ? JSON.parse(this.items) : this.items)) : await this.getRadioItems();
175
- await radioGroupState.setValue({
176
- id: this._id,
177
- el: this.el,
178
- name,
179
- fullWidth,
180
- optionType,
181
- buttonStyle,
182
- size,
183
- disabled,
184
- defaultCheckedItems,
185
- label,
186
- noCaption,
187
- required,
188
- captionType,
189
- hidden,
190
- gap,
191
- direction,
192
- childs: childElements,
68
+ updateValue() {
69
+ var _a, _b, _c;
70
+ this.value = (_c = (_b = (_a = this.radios) === null || _a === void 0 ? void 0 : _a.find(radio => radio.checked)) === null || _b === void 0 ? void 0 : _b.value) !== null && _c !== void 0 ? _c : null;
71
+ }
72
+ componentWillLoad() {
73
+ var _a;
74
+ (_a = this.radios) === null || _a === void 0 ? void 0 : _a.forEach(radio => {
75
+ radio.disabled = radio.disabled || this.disabled;
76
+ radio.size = this.size;
77
+ if (this.defaultValue) {
78
+ radio.checked = radio.value == this.defaultValue;
79
+ }
193
80
  });
194
- this.getValue().then(values => (this.value = values));
195
- }
196
- async markForCheck() {
197
- await delay(10);
198
- this.tick = Generate.UID();
81
+ this.updateValue();
82
+ }
83
+ handleChange(e) {
84
+ var _a, _b;
85
+ e.stopPropagation();
86
+ e.preventDefault();
87
+ const checked = (_a = e.target.checked) !== null && _a !== void 0 ? _a : false;
88
+ (_b = this.radios) === null || _b === void 0 ? void 0 : _b.forEach(radio => {
89
+ radio.checked = radio.id == e.target.id ? !checked : false;
90
+ });
91
+ this.updateValue();
92
+ this.change.emit(this.value);
199
93
  }
94
+ ;
200
95
  async setClear() {
201
- radioGroupState.setClear(this._id);
202
- this.markForCheck();
203
- await delay(10);
204
- return Promise.resolve();
96
+ var _a;
97
+ this.value = null;
98
+ (_a = this.radios) === null || _a === void 0 ? void 0 : _a.forEach(radio => {
99
+ radio.checked = false;
100
+ });
205
101
  }
206
102
  async resetCaption() {
207
103
  await delay(10);
@@ -211,63 +107,33 @@ const BcmRadioGroup = class {
211
107
  await delay(10);
212
108
  return Promise.resolve();
213
109
  }
214
- async set(data) {
215
- await this.check(data);
110
+ async check(itemId, checked = true) {
111
+ var _a;
112
+ (_a = this.radios) === null || _a === void 0 ? void 0 : _a.forEach(radio => {
113
+ radio.checked = radio.id == itemId || radio.value == itemId ? checked : false;
114
+ });
115
+ this.updateValue();
116
+ this.change.emit(this.value);
216
117
  }
217
118
  async get() {
218
- return await this.getValue();
119
+ return this.value;
219
120
  }
220
- async check(item, checked = true) {
221
- radioGroupState.setCheckedItem(this._id, item, checked);
222
- this.defaultValue = item;
223
- await this.markForCheck();
224
- this.change.emit(this.value);
121
+ async set(data) {
122
+ await this.check(data);
225
123
  }
226
124
  async getValue() {
227
- return radioGroupState.getValue(this._id);
228
- }
229
- handleItemsChange() {
230
- this.initState();
231
- }
232
- getRadioItems() {
233
- return getChildElements(this.el, 'bcm-radio');
234
- }
235
- async changeRadio(event) {
236
- radioGroupState.state.onChange = { id: this._id, childId: event };
237
- await this.markForCheck();
238
- this.change.emit(this.value);
239
- }
240
- getItems() {
241
- return radioGroupState.getProperty(this._id);
242
- }
243
- connectedCallback() {
244
- this.captionCache = this.caption;
245
- this.captionTypeCache = this.captionType;
125
+ return this.value;
246
126
  }
247
127
  render() {
248
- const { label, required, hidden, childs, gap, direction, fullWidth, optionType } = this.getItems();
249
- const bcmRadioGroupHostClasses = classnames('bcm-radio-group', {
250
- hidden,
251
- 'error': this.captionType == 'error',
252
- 'full-width': fullWidth,
253
- });
254
- const bcmRadioGroupContainerClasses = classnames('bcm-radio-group__container', optionType, {
255
- [direction]: optionType === 'default',
256
- 'full-width': fullWidth,
257
- });
258
- return (h(Host, { class: bcmRadioGroupHostClasses }, label && h("bcm-label", { type: this.captionType, value: label, required: required }), h("div", { class: bcmRadioGroupContainerClasses, style: gap && { gap: gap } }, childs &&
259
- childs.map(radio => (h("bcm-radio", { id: radio.id, onClick: e => {
260
- !radio.disabled && this.changeRadio(radio.id), e.preventDefault();
261
- }, value: radio.value, disabled: radio.disabled, checked: radio.checked, size: radio.size, color: radio.color, required: radio.required, hidden: radio.hidden, "no-margin": true }, radio.slot || radio.label)))), h(CaptionTemplate, { noCaption: this.noCaption, captionType: this.captionType, captionError: this.captionError, caption: this.caption }), h("span", { hidden: true }, h("slot", null))));
128
+ var _a, _b;
129
+ const { direction, fullWidth, gap, label, size, required, disabled, caption, captionError, captionType, noCaption } = this;
130
+ return (h(Host, { role: "radio-group", class: "tw-mb-2 tw-flex tw-flex-col" }, label && h("bcm-label", { type: captionType, value: label, required: required }), h("div", { class: classnames("tw-flex tw-flex-wrap", direction == Bcm.Direction.horizontal ? "tw-flex-row" : "tw-flex-col", fullWidth && "tw-w-full"), style: { "gap": gap } }, h("slot", null), ((_a = this.Items) === null || _a === void 0 ? void 0 : _a.length) > 0 &&
131
+ ((_b = this.Items) === null || _b === void 0 ? void 0 : _b.map(item => (h("bcm-radio", { id: item.id, value: item.value, disabled: disabled || item.disabled, checked: item.checked, color: item.color, size: size }, item.label))))), h(CaptionTemplate, { noCaption: noCaption, captionType: captionType, captionError: captionError, caption: caption })));
262
132
  }
263
133
  get el() { return getElement(this); }
264
- static get watchers() { return {
265
- "items": ["handleItemsChange"]
266
- }; }
267
134
  };
268
135
  __decorate([
269
136
  IsLoad()
270
137
  ], BcmRadioGroup.prototype, "el", void 0);
271
- BcmRadioGroup.style = groupCss;
272
138
 
273
139
  export { BcmRadioGroup as bcm_radio_group };