bromcom-ui-next 0.1.25 → 0.1.27

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 (253) hide show
  1. package/dist/bromcom-ui/bcm-button.bcm-drawer.bcm-modal.entry.esm.js.map +1 -0
  2. package/dist/bromcom-ui/bcm-tabs-trigger.entry.esm.js.map +1 -1
  3. package/dist/bromcom-ui/bcm-tabs.entry.esm.js.map +1 -1
  4. package/dist/bromcom-ui/bromcom-ui.css +1 -1
  5. package/dist/bromcom-ui/bromcom-ui.esm.js +1 -1
  6. package/dist/bromcom-ui/p-0b30f818.entry.js +2 -0
  7. package/dist/bromcom-ui/{p-188bc34d.entry.js → p-120e6f35.entry.js} +2 -2
  8. package/dist/bromcom-ui/{p-5da9360c.entry.js → p-1450a153.entry.js} +2 -2
  9. package/dist/bromcom-ui/{p-6c2441a1.entry.js → p-15f4e5e7.entry.js} +2 -2
  10. package/dist/bromcom-ui/{p-c9683df3.entry.js → p-16f39dbe.entry.js} +2 -2
  11. package/dist/bromcom-ui/{p-c709842a.entry.js → p-1acc4cab.entry.js} +2 -2
  12. package/dist/bromcom-ui/p-1acc4cab.entry.js.map +1 -0
  13. package/dist/bromcom-ui/p-21ed863b.entry.js +2 -0
  14. package/dist/bromcom-ui/p-21ed863b.entry.js.map +1 -0
  15. package/dist/bromcom-ui/{p-a18d34c7.entry.js → p-2fc0b6dc.entry.js} +2 -2
  16. package/dist/bromcom-ui/{p-7560f0e9.entry.js → p-337a2256.entry.js} +2 -2
  17. package/dist/bromcom-ui/{p-00dc393e.entry.js → p-4c22167e.entry.js} +2 -2
  18. package/dist/bromcom-ui/{p-2cce1424.entry.js → p-4eef9825.entry.js} +2 -2
  19. package/dist/bromcom-ui/{p-ead5a030.entry.js → p-5a9ea12e.entry.js} +2 -2
  20. package/dist/bromcom-ui/p-6043ee4b.entry.js +2 -0
  21. package/dist/bromcom-ui/{p-b37f2434.entry.js.map → p-6043ee4b.entry.js.map} +1 -1
  22. package/dist/bromcom-ui/{p-0213e9e8.entry.js → p-6569b84d.entry.js} +2 -2
  23. package/dist/bromcom-ui/{p-ed796a79.entry.js → p-747fb75c.entry.js} +2 -2
  24. package/dist/bromcom-ui/{p-cf9dd0fc.entry.js → p-7b5df0be.entry.js} +2 -2
  25. package/dist/bromcom-ui/{p-96aba34c.entry.js → p-81227f26.entry.js} +2 -2
  26. package/dist/bromcom-ui/{p-8fd1a05d.entry.js → p-989f1878.entry.js} +2 -2
  27. package/dist/bromcom-ui/{p-a26619e4.entry.js → p-99d3ac36.entry.js} +2 -2
  28. package/dist/bromcom-ui/{p-a07a257f.entry.js → p-9c9bbecd.entry.js} +2 -2
  29. package/dist/bromcom-ui/{p-06656239.entry.js → p-9f53ce2d.entry.js} +2 -2
  30. package/dist/bromcom-ui/p-DCguxqPb.js +3 -0
  31. package/dist/bromcom-ui/p-DCguxqPb.js.map +1 -0
  32. package/dist/bromcom-ui/{p-7f117b72.entry.js → p-b9c939be.entry.js} +2 -2
  33. package/dist/bromcom-ui/p-c127c124.entry.js +2 -0
  34. package/dist/bromcom-ui/p-c127c124.entry.js.map +1 -0
  35. package/dist/bromcom-ui/{p-f34bfa88.entry.js → p-c35aea0f.entry.js} +2 -2
  36. package/dist/bromcom-ui/{p-10de6d9c.entry.js → p-cb4f0849.entry.js} +2 -2
  37. package/dist/bromcom-ui/{p-5e47b56d.entry.js → p-cb91b032.entry.js} +2 -2
  38. package/dist/bromcom-ui/{p-2f517bd8.entry.js → p-dfe7caa3.entry.js} +2 -2
  39. package/dist/bromcom-ui/{p-e989b918.entry.js → p-e454a232.entry.js} +2 -2
  40. package/dist/bromcom-ui/{p-84b1e52c.entry.js → p-e5040679.entry.js} +2 -2
  41. package/dist/bromcom-ui/{p-e500e6d1.entry.js → p-ef3ef111.entry.js} +2 -2
  42. package/dist/cjs/bcm-accordion-group.cjs.entry.js +2 -2
  43. package/dist/cjs/bcm-accordion.cjs.entry.js +3 -3
  44. package/dist/cjs/bcm-alert.cjs.entry.js +2 -2
  45. package/dist/cjs/bcm-avatar.cjs.entry.js +1 -1
  46. package/dist/cjs/bcm-badge.cjs.entry.js +3 -3
  47. package/dist/cjs/bcm-basic-badge.cjs.entry.js +3 -3
  48. package/dist/cjs/bcm-button-group.cjs.entry.js +3 -3
  49. package/dist/cjs/bcm-button.bcm-drawer.bcm-modal.entry.cjs.js.map +1 -0
  50. package/dist/cjs/bcm-button_3.cjs.entry.js +794 -0
  51. package/dist/cjs/bcm-button_3.cjs.entry.js.map +1 -0
  52. package/dist/cjs/bcm-checkbox.cjs.entry.js +2 -2
  53. package/dist/cjs/bcm-chip.cjs.entry.js +2 -2
  54. package/dist/cjs/bcm-divider.cjs.entry.js +2 -2
  55. package/dist/cjs/bcm-dropdown-item.cjs.entry.js +3 -3
  56. package/dist/cjs/bcm-dropdown.cjs.entry.js +2 -2
  57. package/dist/cjs/bcm-input.cjs.entry.js +3 -3
  58. package/dist/cjs/bcm-linked.cjs.entry.js +1 -1
  59. package/dist/cjs/bcm-pop-confirm.cjs.entry.js +2 -2
  60. package/dist/cjs/bcm-popover.cjs.entry.js +2 -2
  61. package/dist/cjs/bcm-radio-group.cjs.entry.js +3 -3
  62. package/dist/cjs/bcm-radio.cjs.entry.js +2 -2
  63. package/dist/cjs/bcm-segmented-picker-option.cjs.entry.js +3 -3
  64. package/dist/cjs/bcm-segmented-picker.cjs.entry.js +3 -3
  65. package/dist/cjs/bcm-shortcut.cjs.entry.js +2 -2
  66. package/dist/cjs/bcm-switch.cjs.entry.js +3 -3
  67. package/dist/cjs/bcm-tabs-content.cjs.entry.js +2 -2
  68. package/dist/cjs/bcm-tabs-list.cjs.entry.js +2 -2
  69. package/dist/cjs/bcm-tabs-trigger.cjs.entry.js +4 -4
  70. package/dist/cjs/bcm-tabs-trigger.cjs.entry.js.map +1 -1
  71. package/dist/cjs/bcm-tabs-trigger.entry.cjs.js.map +1 -1
  72. package/dist/cjs/bcm-tabs.cjs.entry.js +3 -3
  73. package/dist/cjs/bcm-tabs.cjs.entry.js.map +1 -1
  74. package/dist/cjs/bcm-tabs.entry.cjs.js.map +1 -1
  75. package/dist/cjs/bcm-text.cjs.entry.js +2 -2
  76. package/dist/cjs/bcm-textarea.cjs.entry.js +4 -4
  77. package/dist/cjs/bcm-tooltip.cjs.entry.js +2 -2
  78. package/dist/cjs/bromcom-ui.cjs.js +2 -2
  79. package/dist/cjs/{index-DHDrXFLM.js → index-BR4jGTh_.js} +3 -3
  80. package/dist/cjs/index-BR4jGTh_.js.map +1 -0
  81. package/dist/cjs/loader.cjs.js +2 -2
  82. package/dist/collection/collection-manifest.json +1 -0
  83. package/dist/collection/components/accordion/accordion.component.js +2 -2
  84. package/dist/collection/components/accordion-group/accordion-group.component.js +1 -1
  85. package/dist/collection/components/alert/alert.component.js +1 -1
  86. package/dist/collection/components/badge/badge.component.js +2 -2
  87. package/dist/collection/components/basic-badge/basic-badge.component.js +2 -2
  88. package/dist/collection/components/button/button.component.js +6 -5
  89. package/dist/collection/components/button/button.component.js.map +1 -1
  90. package/dist/collection/components/button/button.css +1 -1
  91. package/dist/collection/components/button-group/button-group.component.js +2 -2
  92. package/dist/collection/components/checkbox/checkbox.component.js +1 -1
  93. package/dist/collection/components/chip/chip.component.js +1 -1
  94. package/dist/collection/components/divider/divider.component.js +1 -1
  95. package/dist/collection/components/drawer/drawer.component.js +1 -1
  96. package/dist/collection/components/dropdown/dropdown.component.js +1 -1
  97. package/dist/collection/components/dropdown-item/dropdown-item.component.js +2 -2
  98. package/dist/collection/components/input/input.component.js +2 -2
  99. package/dist/collection/components/modal/modal.component.js +680 -0
  100. package/dist/collection/components/modal/modal.component.js.map +1 -0
  101. package/dist/collection/components/modal/modal.css +1 -0
  102. package/dist/collection/components/pop-confirm/pop-confirm.component.js +1 -1
  103. package/dist/collection/components/popover/popover.component.js +1 -1
  104. package/dist/collection/components/radio/radio.component.js +1 -1
  105. package/dist/collection/components/radio-group/radio-group.component.js +2 -2
  106. package/dist/collection/components/segmented-picker/segmented-picker-option.component.js +2 -2
  107. package/dist/collection/components/segmented-picker/segmented-picker.component.js +2 -2
  108. package/dist/collection/components/shortcut/shortcut.js +1 -1
  109. package/dist/collection/components/switch/switch.component.js +2 -2
  110. package/dist/collection/components/tabs/tabs-content.component.js +1 -1
  111. package/dist/collection/components/tabs/tabs-list.component.js +1 -1
  112. package/dist/collection/components/tabs/tabs-trigger.component.js +2 -2
  113. package/dist/collection/components/tabs/tabs-trigger.component.js.map +1 -1
  114. package/dist/collection/components/tabs/tabs-trigger.css +1 -1
  115. package/dist/collection/components/tabs/tabs.component.js +2 -2
  116. package/dist/collection/components/tabs/tabs.component.js.map +1 -1
  117. package/dist/collection/components/text/text.component.js +1 -1
  118. package/dist/collection/components/textarea/textarea.component.js +3 -3
  119. package/dist/collection/components/tooltip/tooltip.component.js +1 -1
  120. package/dist/components/bcm-accordion-group.js +1 -1
  121. package/dist/components/bcm-accordion.js +2 -2
  122. package/dist/components/bcm-alert.js +1 -1
  123. package/dist/components/bcm-avatar.js +1 -1
  124. package/dist/components/bcm-badge.js +1 -1
  125. package/dist/components/bcm-basic-badge.js +2 -2
  126. package/dist/components/bcm-button-group.js +2 -2
  127. package/dist/components/bcm-button.js +1 -1
  128. package/dist/components/bcm-checkbox.js +1 -1
  129. package/dist/components/bcm-chip.js +1 -1
  130. package/dist/components/bcm-divider.js +1 -1
  131. package/dist/components/bcm-drawer.js +1 -1
  132. package/dist/components/bcm-dropdown-item.js +2 -2
  133. package/dist/components/bcm-dropdown.js +2 -2
  134. package/dist/components/bcm-input.js +2 -2
  135. package/dist/components/bcm-modal.d.ts +11 -0
  136. package/dist/components/bcm-modal.js +324 -0
  137. package/dist/components/bcm-modal.js.map +1 -0
  138. package/dist/components/bcm-pop-confirm.js +2 -2
  139. package/dist/components/bcm-popover.js +1 -1
  140. package/dist/components/bcm-radio-group.js +2 -2
  141. package/dist/components/bcm-radio.js +1 -1
  142. package/dist/components/bcm-segmented-picker-option.js +2 -2
  143. package/dist/components/bcm-segmented-picker.js +2 -2
  144. package/dist/components/bcm-shortcut.js +1 -1
  145. package/dist/components/bcm-switch.js +2 -2
  146. package/dist/components/bcm-tabs-content.js +1 -1
  147. package/dist/components/bcm-tabs-list.js +1 -1
  148. package/dist/components/bcm-tabs-trigger.js +3 -3
  149. package/dist/components/bcm-tabs-trigger.js.map +1 -1
  150. package/dist/components/bcm-tabs.js +2 -2
  151. package/dist/components/bcm-tabs.js.map +1 -1
  152. package/dist/components/bcm-text.js +1 -1
  153. package/dist/components/bcm-textarea.js +3 -3
  154. package/dist/components/bcm-tooltip.js +1 -1
  155. package/dist/components/index.js +1 -1
  156. package/dist/components/index.js.map +1 -1
  157. package/dist/components/{p-A70Ppz6C.js → p-CQF7wlXf.js} +4 -4
  158. package/dist/components/{p-A70Ppz6C.js.map → p-CQF7wlXf.js.map} +1 -1
  159. package/dist/components/{p-e6quW4es.js → p-DGlecSBr.js} +9 -8
  160. package/dist/components/p-DGlecSBr.js.map +1 -0
  161. package/dist/esm/bcm-accordion-group.entry.js +2 -2
  162. package/dist/esm/bcm-accordion.entry.js +3 -3
  163. package/dist/esm/bcm-alert.entry.js +2 -2
  164. package/dist/esm/bcm-avatar.entry.js +1 -1
  165. package/dist/esm/bcm-badge.entry.js +3 -3
  166. package/dist/esm/bcm-basic-badge.entry.js +3 -3
  167. package/dist/esm/bcm-button-group.entry.js +3 -3
  168. package/dist/esm/bcm-button.bcm-drawer.bcm-modal.entry.js.map +1 -0
  169. package/dist/esm/bcm-button_3.entry.js +790 -0
  170. package/dist/esm/bcm-button_3.entry.js.map +1 -0
  171. package/dist/esm/bcm-checkbox.entry.js +2 -2
  172. package/dist/esm/bcm-chip.entry.js +2 -2
  173. package/dist/esm/bcm-divider.entry.js +2 -2
  174. package/dist/esm/bcm-dropdown-item.entry.js +3 -3
  175. package/dist/esm/bcm-dropdown.entry.js +2 -2
  176. package/dist/esm/bcm-input.entry.js +3 -3
  177. package/dist/esm/bcm-linked.entry.js +1 -1
  178. package/dist/esm/bcm-pop-confirm.entry.js +2 -2
  179. package/dist/esm/bcm-popover.entry.js +2 -2
  180. package/dist/esm/bcm-radio-group.entry.js +3 -3
  181. package/dist/esm/bcm-radio.entry.js +2 -2
  182. package/dist/esm/bcm-segmented-picker-option.entry.js +3 -3
  183. package/dist/esm/bcm-segmented-picker.entry.js +3 -3
  184. package/dist/esm/bcm-shortcut.entry.js +2 -2
  185. package/dist/esm/bcm-switch.entry.js +3 -3
  186. package/dist/esm/bcm-tabs-content.entry.js +2 -2
  187. package/dist/esm/bcm-tabs-list.entry.js +2 -2
  188. package/dist/esm/bcm-tabs-trigger.entry.js +4 -4
  189. package/dist/esm/bcm-tabs-trigger.entry.js.map +1 -1
  190. package/dist/esm/bcm-tabs.entry.js +3 -3
  191. package/dist/esm/bcm-tabs.entry.js.map +1 -1
  192. package/dist/esm/bcm-text.entry.js +2 -2
  193. package/dist/esm/bcm-textarea.entry.js +4 -4
  194. package/dist/esm/bcm-tooltip.entry.js +2 -2
  195. package/dist/esm/bromcom-ui.js +3 -3
  196. package/dist/esm/{index-B84DzIAh.js → index-DCguxqPb.js} +3 -3
  197. package/dist/esm/index-DCguxqPb.js.map +1 -0
  198. package/dist/esm/loader.js +3 -3
  199. package/dist/types/components/modal/modal.component.d.ts +39 -0
  200. package/dist/types/components.d.ts +124 -0
  201. package/package.json +1 -1
  202. package/dist/bromcom-ui/bcm-button.entry.esm.js.map +0 -1
  203. package/dist/bromcom-ui/bcm-drawer.entry.esm.js.map +0 -1
  204. package/dist/bromcom-ui/p-0421d64a.entry.js +0 -2
  205. package/dist/bromcom-ui/p-0421d64a.entry.js.map +0 -1
  206. package/dist/bromcom-ui/p-48c554fc.entry.js +0 -2
  207. package/dist/bromcom-ui/p-48c554fc.entry.js.map +0 -1
  208. package/dist/bromcom-ui/p-B84DzIAh.js +0 -3
  209. package/dist/bromcom-ui/p-B84DzIAh.js.map +0 -1
  210. package/dist/bromcom-ui/p-b37f2434.entry.js +0 -2
  211. package/dist/bromcom-ui/p-c709842a.entry.js.map +0 -1
  212. package/dist/bromcom-ui/p-dd9ec481.entry.js +0 -2
  213. package/dist/bromcom-ui/p-edd01d0d.entry.js +0 -2
  214. package/dist/bromcom-ui/p-edd01d0d.entry.js.map +0 -1
  215. package/dist/cjs/bcm-button.cjs.entry.js +0 -316
  216. package/dist/cjs/bcm-button.cjs.entry.js.map +0 -1
  217. package/dist/cjs/bcm-button.entry.cjs.js.map +0 -1
  218. package/dist/cjs/bcm-drawer.cjs.entry.js +0 -206
  219. package/dist/cjs/bcm-drawer.cjs.entry.js.map +0 -1
  220. package/dist/cjs/bcm-drawer.entry.cjs.js.map +0 -1
  221. package/dist/cjs/index-DHDrXFLM.js.map +0 -1
  222. package/dist/components/p-e6quW4es.js.map +0 -1
  223. package/dist/esm/bcm-button.entry.js +0 -314
  224. package/dist/esm/bcm-button.entry.js.map +0 -1
  225. package/dist/esm/bcm-drawer.entry.js +0 -204
  226. package/dist/esm/bcm-drawer.entry.js.map +0 -1
  227. package/dist/esm/index-B84DzIAh.js.map +0 -1
  228. /package/dist/bromcom-ui/{p-dd9ec481.entry.js.map → p-0b30f818.entry.js.map} +0 -0
  229. /package/dist/bromcom-ui/{p-188bc34d.entry.js.map → p-120e6f35.entry.js.map} +0 -0
  230. /package/dist/bromcom-ui/{p-5da9360c.entry.js.map → p-1450a153.entry.js.map} +0 -0
  231. /package/dist/bromcom-ui/{p-6c2441a1.entry.js.map → p-15f4e5e7.entry.js.map} +0 -0
  232. /package/dist/bromcom-ui/{p-c9683df3.entry.js.map → p-16f39dbe.entry.js.map} +0 -0
  233. /package/dist/bromcom-ui/{p-a18d34c7.entry.js.map → p-2fc0b6dc.entry.js.map} +0 -0
  234. /package/dist/bromcom-ui/{p-7560f0e9.entry.js.map → p-337a2256.entry.js.map} +0 -0
  235. /package/dist/bromcom-ui/{p-00dc393e.entry.js.map → p-4c22167e.entry.js.map} +0 -0
  236. /package/dist/bromcom-ui/{p-2cce1424.entry.js.map → p-4eef9825.entry.js.map} +0 -0
  237. /package/dist/bromcom-ui/{p-ead5a030.entry.js.map → p-5a9ea12e.entry.js.map} +0 -0
  238. /package/dist/bromcom-ui/{p-0213e9e8.entry.js.map → p-6569b84d.entry.js.map} +0 -0
  239. /package/dist/bromcom-ui/{p-ed796a79.entry.js.map → p-747fb75c.entry.js.map} +0 -0
  240. /package/dist/bromcom-ui/{p-cf9dd0fc.entry.js.map → p-7b5df0be.entry.js.map} +0 -0
  241. /package/dist/bromcom-ui/{p-96aba34c.entry.js.map → p-81227f26.entry.js.map} +0 -0
  242. /package/dist/bromcom-ui/{p-8fd1a05d.entry.js.map → p-989f1878.entry.js.map} +0 -0
  243. /package/dist/bromcom-ui/{p-a26619e4.entry.js.map → p-99d3ac36.entry.js.map} +0 -0
  244. /package/dist/bromcom-ui/{p-a07a257f.entry.js.map → p-9c9bbecd.entry.js.map} +0 -0
  245. /package/dist/bromcom-ui/{p-06656239.entry.js.map → p-9f53ce2d.entry.js.map} +0 -0
  246. /package/dist/bromcom-ui/{p-7f117b72.entry.js.map → p-b9c939be.entry.js.map} +0 -0
  247. /package/dist/bromcom-ui/{p-f34bfa88.entry.js.map → p-c35aea0f.entry.js.map} +0 -0
  248. /package/dist/bromcom-ui/{p-10de6d9c.entry.js.map → p-cb4f0849.entry.js.map} +0 -0
  249. /package/dist/bromcom-ui/{p-5e47b56d.entry.js.map → p-cb91b032.entry.js.map} +0 -0
  250. /package/dist/bromcom-ui/{p-2f517bd8.entry.js.map → p-dfe7caa3.entry.js.map} +0 -0
  251. /package/dist/bromcom-ui/{p-e989b918.entry.js.map → p-e454a232.entry.js.map} +0 -0
  252. /package/dist/bromcom-ui/{p-84b1e52c.entry.js.map → p-e5040679.entry.js.map} +0 -0
  253. /package/dist/bromcom-ui/{p-e500e6d1.entry.js.map → p-ef3ef111.entry.js.map} +0 -0
@@ -0,0 +1,790 @@
1
+ import { r as registerInstance, c as createEvent, h, H as Host, a as getElement } from './index-DCguxqPb.js';
2
+ import { t as tv } from './tv-CEcVC0yX.js';
3
+
4
+ const variantOptions = {
5
+ save: {
6
+ text: 'Save',
7
+ status: 'success',
8
+ icon: 'far fa-save',
9
+ iconPosition: 'prefix',
10
+ kind: 'primary',
11
+ },
12
+ ok: {
13
+ text: 'Ok',
14
+ status: 'success',
15
+ icon: 'far fa-check',
16
+ iconPosition: 'prefix',
17
+ },
18
+ new: {
19
+ text: 'New',
20
+ status: 'success',
21
+ icon: 'far fa-plus',
22
+ iconPosition: 'prefix',
23
+ },
24
+ add: {
25
+ text: 'Add',
26
+ status: 'success',
27
+ icon: 'far fa-plus',
28
+ iconPosition: 'prefix',
29
+ },
30
+ create: {
31
+ text: 'Create',
32
+ status: 'success',
33
+ icon: 'far fa-plus',
34
+ iconPosition: 'prefix',
35
+ },
36
+ prev: {
37
+ text: 'Prev',
38
+ status: 'default',
39
+ icon: 'far fa-arrow-left',
40
+ iconPosition: 'prefix',
41
+ },
42
+ next: {
43
+ text: 'Next',
44
+ status: 'default',
45
+ icon: 'far fa-arrow-right',
46
+ iconPosition: 'suffix',
47
+ },
48
+ apply: {
49
+ text: 'Apply',
50
+ status: 'default',
51
+ icon: 'far fa-check-circle',
52
+ iconPosition: 'prefix',
53
+ },
54
+ submit: {
55
+ text: 'Submit',
56
+ status: 'default',
57
+ icon: 'far fa-save',
58
+ iconPosition: 'prefix',
59
+ },
60
+ send: {
61
+ text: 'Send',
62
+ status: 'success',
63
+ icon: 'far fa-paper-plane',
64
+ iconPosition: 'prefix',
65
+ },
66
+ delete: {
67
+ text: 'Delete',
68
+ status: 'error',
69
+ icon: 'far fa-trash',
70
+ iconPosition: 'prefix',
71
+ },
72
+ cancel: {
73
+ text: 'Cancel',
74
+ status: 'error',
75
+ icon: 'far fa-times',
76
+ iconPosition: 'prefix',
77
+ },
78
+ decline: {
79
+ text: 'Decline',
80
+ status: 'error',
81
+ icon: 'far fa-ban',
82
+ iconPosition: 'prefix',
83
+ },
84
+ close: {
85
+ text: 'Close',
86
+ status: 'error',
87
+ icon: 'far fa-times-circle',
88
+ iconPosition: 'prefix',
89
+ },
90
+ archive: {
91
+ text: 'Archive',
92
+ status: 'error',
93
+ icon: 'far fa-folder-open',
94
+ iconPosition: 'prefix',
95
+ },
96
+ remove: {
97
+ text: 'Remove',
98
+ status: 'error',
99
+ icon: 'far fa-minus-circle',
100
+ iconPosition: 'prefix',
101
+ },
102
+ edit: {
103
+ text: 'Edit',
104
+ status: 'default',
105
+ icon: 'far fa-edit',
106
+ iconPosition: 'prefix',
107
+ },
108
+ export: {
109
+ text: 'Export',
110
+ status: 'default',
111
+ icon: 'far fa-sign-out',
112
+ iconPosition: 'prefix',
113
+ },
114
+ import: {
115
+ text: 'Import',
116
+ status: 'default',
117
+ icon: 'far fa-sign-in',
118
+ iconPosition: 'prefix',
119
+ },
120
+ filter: {
121
+ text: 'Filter',
122
+ status: 'default',
123
+ icon: 'far fa-filter',
124
+ iconPosition: 'prefix',
125
+ },
126
+ update: {
127
+ text: 'Update',
128
+ status: 'default',
129
+ icon: 'far fa-sync',
130
+ iconPosition: 'prefix',
131
+ },
132
+ reset: {
133
+ text: 'Reset',
134
+ status: 'default',
135
+ icon: 'far fa-sync',
136
+ iconPosition: 'prefix',
137
+ },
138
+ download: {
139
+ text: 'Download',
140
+ status: 'default',
141
+ icon: 'far fa-download',
142
+ iconPosition: 'prefix',
143
+ },
144
+ };
145
+
146
+ const buttonCss = ".relative{position:relative}:host{display:inline-flex;height:-moz-fit-content;height:fit-content;position:relative;width:-moz-fit-content;width:fit-content}:host([full-width]){width:100%}:host([position=first]) .bcm-button{border-bottom-right-radius:0;border-top-right-radius:0}:host([position=middle]) .bcm-button{border-radius:0}:host([position=last]) .bcm-button{border-bottom-left-radius:0;border-top-left-radius:0}:host([position=first].orientation-vertical) .bcm-button{border-bottom-left-radius:0;border-bottom-right-radius:0;border-top-left-radius:var(--bcm-ui-border-radius,4px);border-top-right-radius:var(--bcm-ui-border-radius,4px)}:host([position=middle].orientation-vertical) .bcm-button{border-radius:0}:host([position=last].orientation-vertical) .bcm-button{border-bottom-left-radius:var(--bcm-ui-border-radius,4px);border-bottom-right-radius:var(--bcm-ui-border-radius,4px);border-top-left-radius:0;border-top-right-radius:0}.static{position:static}.inline-flex{display:inline-flex}.min-h-10{min-height:2.5rem}.min-h-6{min-height:1.5rem}.min-h-8{min-height:2rem}.w-full{width:100%}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.appearance-none{appearance:none}.items-center{align-items:center}.justify-center{justify-content:center}.rounded{border-radius:var(--bcm-ui-border-radius-default,6px)}.border{border-width:1px}.border-solid{border-style:solid}.border-\\[--bcm-final-border-color\\]{border-color:var(--bcm-final-border-color)}.border-color-disabled{border-color:var(--bcm-ui-color-border-disabled)}.bg-\\[--bcm-final-bg-color\\]{background-color:var(--bcm-final-bg-color)}.bg-\\[--bcm-ui-color-background-disabled-default\\]{background-color:var(--bcm-ui-color-background-disabled-default)}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.py-0\\.5{padding-bottom:.125rem;padding-top:.125rem}.py-1{padding-bottom:.25rem;padding-top:.25rem}.py-px{padding-bottom:1px;padding-top:1px}.text-size-4{font-size:var(--bcm-ui-font-size-4,14px);line-height:var(--bcm-ui-line-height-4,20px)}.text-size-5{font-size:var(--bcm-ui-font-size-5,16px);line-height:var(--bcm-ui-line-height-5,24px)}.text-size-6{font-size:var(--bcm-ui-font-size-6,18px);line-height:var(--bcm-ui-line-height-6,24px)}.leading-none{line-height:1}.text-\\[--bcm-final-text-color\\]{color:var(--bcm-final-text-color)}.text-color-disabled{color:var(--bcm-ui-color-text-disabled)}.shadow{--tw-shadow:var(--bcm-ui-box-shadow-default);--tw-shadow-colored:var(--bcm-ui-box-shadow-default);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.outline{outline-style:solid}.outline-0{outline-width:0}.hover\\:bg-\\[--bcm-final-hover-bg-color\\]:hover{background-color:var(--bcm-final-hover-bg-color)}.focus-visible\\:ring:focus-visible{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.active\\:bg-\\[--bcm-final-active-bg-color\\]:active{background-color:var(--bcm-final-active-bg-color)}.flex{display:flex}.max-h-64{max-height:16rem}.min-w-10{min-width:2.5rem}.max-w-64{max-width:16rem}.flex-col{flex-direction:column}.overflow-y-auto{overflow-y:auto}.rounded-lg{border-radius:var(--bcm-ui-border-radius-lg,8px)}.bg-color-basic-panel{background-color:var(--bcm-ui-color-background-basic-panel)}.py-1\\.5{padding-bottom:.375rem;padding-top:.375rem}.shadow,.shadow-3{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-3{--tw-shadow:var(--bcm-ui-box-shadow-3);--tw-shadow-colored:var(--bcm-ui-box-shadow-3)}.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.bcm-ui-element{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,sans-serif}.absolute{position:absolute}.z-\\[9999\\]{z-index:9999}.mx-auto{margin-left:auto;margin-right:auto}.hidden{display:none}.size-6{height:1.5rem;width:1.5rem}.h-2{height:.5rem}.w-4{width:1rem}.max-w-80{max-width:20rem}.max-w-96{max-width:24rem}.flex-1{flex:1 1 0%}.flex-row{flex-direction:row}.justify-end{justify-content:flex-end}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-2\\.5{gap:.625rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.text-pretty{text-wrap:pretty}.rounded-\\[--popover-radius\\]{border-radius:var(--popover-radius)}.rounded-full{border-radius:var(--bcm-ui-border-radius-full,9999px)}.bg-\\[--popover-bg\\]{background-color:var(--popover-bg)}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.font-sans{font-family:Inter,sans-serif}.text-size-7{font-size:var(--bcm-ui-font-size-7,20px);line-height:var(--bcm-ui-line-height-7,28px)}.text-size-inherit{font-size:inherit;line-height:inherit}.font-semibold{font-weight:600}.\\!text-color-header{color:var(--bcm-ui-color-text-header)!important}.text-\\[--text-color\\]{color:var(--text-color)}.shadow,.shadow-2{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-2{--tw-shadow:var(--bcm-ui-box-shadow-2);--tw-shadow-colored:var(--bcm-ui-box-shadow-2)}.hover\\:bg-gray-100:hover{background-color:oklch(.967 .003 264.542)}";
147
+
148
+ const BcmButton = class {
149
+ constructor(hostRef) {
150
+ registerInstance(this, hostRef);
151
+ this.bcmClick = createEvent(this, "bcmClick", 1);
152
+ this.bcmFocus = createEvent(this, "bcmFocus", 1);
153
+ this.bcmBlur = createEvent(this, "bcmBlur", 1);
154
+ /** Defines the main visual style of the button */
155
+ this.kind = 'primary';
156
+ /** Controls the button size */
157
+ this.size = 'medium';
158
+ /** Defines the button's status/state color */
159
+ this.status = 'default';
160
+ /** Icon placement (prefix/suffix) */
161
+ this.iconPosition = 'prefix';
162
+ /** Icon-only button mode */
163
+ this.iconOnly = false;
164
+ /** Full width button */
165
+ this.fullWidth = false;
166
+ /** HTML button type */
167
+ this.type = 'button';
168
+ /** Loading state */
169
+ this.loading = false;
170
+ /** Disabled state */
171
+ this.disabled = false;
172
+ /** Active state */
173
+ this.active = false;
174
+ this.handleClick = (event) => {
175
+ if (!this.disabled && !this.loading) {
176
+ this.bcmClick.emit(event);
177
+ }
178
+ };
179
+ this.handleFocus = (event) => {
180
+ this.bcmFocus.emit(event);
181
+ };
182
+ this.handleBlur = (event) => {
183
+ this.bcmBlur.emit(event);
184
+ };
185
+ this.buttonClass = tv({
186
+ base: 'bcm-button appearance-none inline-flex items-center justify-center border border-solid rounded outline-0',
187
+ variants: {
188
+ size: {
189
+ small: 'text-size-4 py-px px-2 min-h-6',
190
+ medium: 'text-size-5 py-0.5 px-3 min-h-8',
191
+ large: 'text-size-6 py-1 px-3 min-h-10',
192
+ },
193
+ kind: {
194
+ primary: 'kind-primary',
195
+ ghost: 'kind-ghost',
196
+ text: 'kind-text',
197
+ outline: 'kind-outline',
198
+ },
199
+ fullWidth: {
200
+ true: 'full-width w-full',
201
+ },
202
+ disabled: {
203
+ true: 'disabled cursor-not-allowed bg-[--bcm-ui-color-background-disabled-default] text-color-disabled border-color-disabled',
204
+ false: [
205
+ 'cursor-pointer',
206
+ 'bg-[--bcm-final-bg-color] text-[--bcm-final-text-color] border-[--bcm-final-border-color]',
207
+ 'hover:bg-[--bcm-final-hover-bg-color]',
208
+ 'active:bg-[--bcm-final-active-bg-color]',
209
+ 'focus-visible:ring',
210
+ ],
211
+ },
212
+ loading: {
213
+ true: '',
214
+ },
215
+ position: {
216
+ first: 'position-first',
217
+ middle: 'position-middle',
218
+ last: 'position-last',
219
+ },
220
+ },
221
+ defaultVariants: {
222
+ size: 'medium',
223
+ kind: 'primary',
224
+ fullWidth: false,
225
+ disabled: false,
226
+ loading: false,
227
+ },
228
+ }, {
229
+ twMerge: false,
230
+ });
231
+ }
232
+ get buttonText() {
233
+ return this.text || (this.variant && variantOptions[this.variant] ? variantOptions[this.variant].text : '');
234
+ }
235
+ get buttonIcon() {
236
+ var _a;
237
+ if (this.variant && ((_a = variantOptions[this.variant]) === null || _a === void 0 ? void 0 : _a.icon)) {
238
+ return {
239
+ icon: variantOptions[this.variant].icon,
240
+ position: variantOptions[this.variant].iconPosition || 'prefix',
241
+ };
242
+ }
243
+ return {
244
+ icon: this.icon,
245
+ position: this.iconPosition,
246
+ };
247
+ }
248
+ get buttonStatus() {
249
+ return this.variant && variantOptions[this.variant] ? variantOptions[this.variant].status : this.status;
250
+ }
251
+ get buttonStyles() {
252
+ const status = this.buttonStatus === 'default' ? 'primary' : this.buttonStatus;
253
+ // These are the internal default styles based on component props (kind, status)
254
+ const kindStyleMap = {
255
+ primary: {
256
+ '--bcm-button-bg': `var(--bcm-ui-color-background-${status}-default)`,
257
+ '--bcm-button-bg-hover': `var(--bcm-ui-color-background-${status}-hover)`,
258
+ '--bcm-button-bg-active': `var(--bcm-ui-color-background-${status}-active)`,
259
+ '--bcm-button-border': 'transparent',
260
+ '--bcm-button-text': 'var(--bcm-ui-color-text-base)',
261
+ },
262
+ outline: {
263
+ '--bcm-button-bg': 'var(--bcm-ui-color-background-default-default)',
264
+ '--bcm-button-bg-hover': 'var(--bcm-ui-color-background-default-hover)',
265
+ '--bcm-button-bg-active': 'var(--bcm-ui-color-background-default-active)',
266
+ '--bcm-button-border': `var(--bcm-ui-color-border-${this.buttonStatus})`,
267
+ '--bcm-button-text': `var(--bcm-ui-color-text-${this.buttonStatus})`,
268
+ },
269
+ ghost: {
270
+ '--bcm-button-bg': 'transparent',
271
+ '--bcm-button-bg-hover': 'var(--bcm-ui-color-background-default-hover)',
272
+ '--bcm-button-bg-active': 'var(--bcm-ui-color-background-default-active)',
273
+ '--bcm-button-border': 'transparent',
274
+ '--bcm-button-text': `var(--bcm-ui-color-text-${this.buttonStatus})`,
275
+ },
276
+ text: {
277
+ '--bcm-button-bg': 'transparent',
278
+ '--bcm-button-bg-hover': 'var(--bcm-ui-color-background-default-hover)',
279
+ '--bcm-button-bg-active': 'var(--bcm-ui-color-background-default-active)',
280
+ '--bcm-button-border': 'transparent',
281
+ '--bcm-button-text': `var(--bcm-ui-color-text-${status})`,
282
+ },
283
+ };
284
+ const internalDefaultStyles = kindStyleMap[this.kind];
285
+ // These are the "final" CSS custom properties used by the component's styling.
286
+ // They use the "--bcm-button-custom-..." token if provided by the user,
287
+ // otherwise, they fall back to the internal "--bcm-button-..." style defined above.
288
+ const finalEffectiveStyles = {
289
+ '--bcm-final-text-color': `var(--bcm-button-custom-text-color, ${internalDefaultStyles['--bcm-button-text']})`,
290
+ '--bcm-final-border-color': `var(--bcm-button-custom-border-color, ${internalDefaultStyles['--bcm-button-border']})`,
291
+ '--bcm-final-bg-color': `var(--bcm-button-custom-bg-color, ${internalDefaultStyles['--bcm-button-bg']})`,
292
+ '--bcm-final-hover-bg-color': `var(--bcm-button-custom-hover-bg-color, ${internalDefaultStyles['--bcm-button-bg-hover']})`,
293
+ '--bcm-final-active-bg-color': `var(--bcm-button-custom-active-bg-color, ${internalDefaultStyles['--bcm-button-bg-active']})`,
294
+ };
295
+ // return kindStyleMap[this.kind];
296
+ return Object.assign(Object.assign({}, internalDefaultStyles), finalEffectiveStyles);
297
+ }
298
+ render() {
299
+ const { icon, position } = this.buttonIcon;
300
+ return (h(Host, { key: 'a9d5f590bcc4175aa663c999f5a84bee10c3c7f2' }, h("button", { key: 'c18c414edad304b4f9cd0155e683f1f9783b6fde', type: this.type, disabled: this.disabled || this.loading, "aria-label": this.label, "aria-expanded": this.expanded, "aria-controls": this.controls, "aria-disabled": this.disabled, onClick: this.handleClick, onFocus: this.handleFocus, onBlur: this.handleBlur, style: this.buttonStyles, class: this.buttonClass({
301
+ size: this.size,
302
+ kind: this.kind,
303
+ fullWidth: this.fullWidth,
304
+ disabled: this.disabled,
305
+ loading: this.loading,
306
+ position: this.position,
307
+ }) }, this.loading && h("slot", { key: '682e48b9d4a5e4ab6fb66bf44781448fad55f720', name: "loading" }), h("span", { key: 'b201ef2563f68e42416efa2816b890b2d41867ad' }, h("slot", { key: '4b30c9c05551671c45757a7afbccaabe4dea1d9a', name: "prefix" }, position === 'prefix' && icon && h("i", { key: '618a7e811aa190f60621095dbece3d29ee133f9e', class: ' leading-none ' + icon }))), h("slot", { key: 'b3a3a7257767f3e49895c8e7963899a701cdab43' }, this.buttonText), h("span", { key: '81b97078b064ce82516cea7564c64c8a89332759' }, h("slot", { key: '4e4d3bfb4814f207f27f6efc2327575e65f69180', name: "suffix" }, position === 'suffix' && icon && h("i", { key: '75373a66baeae2a66b219626b2f3694ac7cb4179', class: ' leading-none ' + icon }))))));
308
+ }
309
+ };
310
+ BcmButton.style = buttonCss;
311
+
312
+ const drawerCss = ".contents{display:contents}:host{display:contents}.bcm-ui-element{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,sans-serif}.visible{visibility:visible}.invisible{visibility:hidden}.static{position:static}.fixed{position:fixed}.inset-0{inset:0}.bottom-0{bottom:0}.left-0{left:0}.right-0{right:0}.top-0{top:0}.z-40{z-index:40}.z-50{z-index:50}.m-0{margin:0}.flex{display:flex}.hidden{display:none}.h-6{height:1.5rem}.w-6{width:1.5rem}.flex-grow{flex-grow:1}.-translate-x-full{--tw-translate-x:-100%}.-translate-x-full,.-translate-y-full{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.-translate-y-full{--tw-translate-y:-100%}.translate-x-0{--tw-translate-x:0px}.translate-x-0,.translate-x-full{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-x-full{--tw-translate-x:100%}.translate-y-0{--tw-translate-y:0px}.translate-y-0,.translate-y-full{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-y-full{--tw-translate-y:100%}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.cursor-pointer{cursor:pointer}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.overflow-y-auto{overflow-y:auto}.border-none{border-style:none}.bg-color-base{background-color:var(--bcm-ui-color-background-base-default)}.bg-color-default{background-color:var(--bcm-ui-color-background-default-default)}.bg-color-transparent{background-color:var(--bcm-ui-color-background-transparent-default)}.bg-transparent{background-color:transparent}.p-0{padding:0}.p-4{padding:1rem}.px-4{padding-left:1rem;padding-right:1rem}.py-3{padding-bottom:.75rem;padding-top:.75rem}.text-size-5{font-size:var(--bcm-ui-font-size-5,16px);line-height:var(--bcm-ui-line-height-5,24px)}.text-size-6{font-size:var(--bcm-ui-font-size-6,18px);line-height:var(--bcm-ui-line-height-6,24px)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.text-color-default{color:var(--bcm-ui-color-text-default)}.opacity-0{opacity:0}.opacity-100{opacity:1}.shadow{--tw-shadow:var(--bcm-ui-box-shadow-default);--tw-shadow-colored:var(--bcm-ui-box-shadow-default);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.transition-opacity{transition-duration:.15s;transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-transform{transition-duration:.15s;transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration-300{transition-duration:.3s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.hover\\:bg-color-default-hover:hover{background-color:var(--bcm-ui-color-background-default-hover)}.active\\:bg-color-default-active:active{background-color:var(--bcm-ui-color-background-default-active)}";
313
+
314
+ const BcmDrawer = class {
315
+ constructor(hostRef) {
316
+ registerInstance(this, hostRef);
317
+ this.bcmOpen = createEvent(this, "bcmOpen", 7);
318
+ this.bcmClose = createEvent(this, "bcmClose", 7);
319
+ this.bcmBeforeOpen = createEvent(this, "bcmBeforeOpen", 7);
320
+ this.bcmBeforeClose = createEvent(this, "bcmBeforeClose", 7);
321
+ this.open = false;
322
+ this.size = 'medium';
323
+ this.position = 'right';
324
+ this.fullWidth = false;
325
+ this.noHeader = false;
326
+ this.drawerClass = tv({
327
+ slots: {
328
+ backdrop: 'fixed inset-0 bg-color-transparent z-40 transition-opacity duration-300',
329
+ wrapper: 'bcm-ui-element fixed bg-color-base text-color-default z-50 transform transition-transform duration-300 ease-in-out flex flex-col',
330
+ header: 'flex justify-between items-center bg-color-default text-color-default',
331
+ title: 'font-semibold m-0 text-size-6',
332
+ closeButton: 'text-size-5 font-medium text-color-default bg-transparent border-none p-0 h-6 w-6 hover:bg-color-default-hover cursor-pointer active:bg-color-default-active',
333
+ content: 'overflow-y-auto flex-grow',
334
+ },
335
+ variants: {
336
+ open: {
337
+ true: {
338
+ backdrop: 'opacity-100 visible',
339
+ },
340
+ false: {
341
+ backdrop: 'opacity-0 invisible',
342
+ },
343
+ },
344
+ position: {
345
+ left: {
346
+ wrapper: 'top-0 left-0 bottom-0',
347
+ },
348
+ right: {
349
+ wrapper: 'top-0 right-0 bottom-0',
350
+ },
351
+ top: {
352
+ wrapper: 'top-0 left-0 right-0',
353
+ },
354
+ bottom: {
355
+ wrapper: 'bottom-0 left-0 right-0',
356
+ },
357
+ },
358
+ size: {
359
+ small: {
360
+ header: 'py-3 px-4',
361
+ content: 'p-4',
362
+ },
363
+ medium: {
364
+ header: 'py-3 px-4',
365
+ content: 'p-4',
366
+ },
367
+ large: {
368
+ header: 'py-3 px-4',
369
+ content: 'p-4',
370
+ },
371
+ },
372
+ noHeader: {
373
+ true: {
374
+ header: 'hidden',
375
+ },
376
+ },
377
+ },
378
+ compoundVariants: [
379
+ {
380
+ open: true,
381
+ position: ['left', 'right'],
382
+ class: {
383
+ wrapper: 'translate-x-0',
384
+ },
385
+ },
386
+ {
387
+ open: true,
388
+ position: ['top', 'bottom'],
389
+ class: {
390
+ wrapper: 'translate-y-0',
391
+ },
392
+ },
393
+ {
394
+ open: false,
395
+ position: 'left',
396
+ class: {
397
+ wrapper: '-translate-x-full',
398
+ },
399
+ },
400
+ {
401
+ open: false,
402
+ position: 'right',
403
+ class: {
404
+ wrapper: 'translate-x-full',
405
+ },
406
+ },
407
+ {
408
+ open: false,
409
+ position: 'top',
410
+ class: {
411
+ wrapper: '-translate-y-full',
412
+ },
413
+ },
414
+ {
415
+ open: false,
416
+ position: 'bottom',
417
+ class: {
418
+ wrapper: 'translate-y-full',
419
+ },
420
+ },
421
+ ],
422
+ });
423
+ }
424
+ handleOpenChange(isOpen) {
425
+ if (isOpen) {
426
+ document.body.style.overflow = 'hidden';
427
+ this.bcmOpen.emit();
428
+ }
429
+ else {
430
+ document.body.style.overflow = '';
431
+ this.bcmClose.emit();
432
+ }
433
+ }
434
+ handleKeyDown(event) {
435
+ if (event.key === 'Escape' && this.open) {
436
+ this.hide();
437
+ }
438
+ }
439
+ async show() {
440
+ const event = this.bcmBeforeOpen.emit();
441
+ if (!event.defaultPrevented) {
442
+ this.open = true;
443
+ }
444
+ }
445
+ async hide() {
446
+ const event = this.bcmBeforeClose.emit();
447
+ if (!event.defaultPrevented) {
448
+ this.open = false;
449
+ }
450
+ }
451
+ disconnectedCallback() {
452
+ document.body.style.overflow = '';
453
+ }
454
+ getWrapperStyle() {
455
+ const style = {};
456
+ if (this.fullWidth) {
457
+ if (this.position === 'left' || this.position === 'right') {
458
+ style.width = '100vw';
459
+ }
460
+ else {
461
+ style.height = '100vh';
462
+ }
463
+ return style;
464
+ }
465
+ if (this.position === 'left' || this.position === 'right') {
466
+ switch (this.size) {
467
+ case 'small':
468
+ style.width = '320px';
469
+ break;
470
+ case 'medium':
471
+ style.width = '480px';
472
+ break;
473
+ case 'large':
474
+ style.width = '1064px';
475
+ break;
476
+ }
477
+ }
478
+ else {
479
+ switch (this.size) {
480
+ case 'small':
481
+ style.height = '40vh';
482
+ break;
483
+ case 'medium':
484
+ style.height = '60vh';
485
+ break;
486
+ case 'large':
487
+ style.height = '90vh';
488
+ break;
489
+ }
490
+ }
491
+ return style;
492
+ }
493
+ render() {
494
+ const { backdrop, wrapper, header, title, closeButton, content } = this.drawerClass({
495
+ open: this.open,
496
+ position: this.position,
497
+ size: this.size,
498
+ noHeader: this.noHeader,
499
+ });
500
+ return (h("div", { key: '120639c39b40ba77d7420813e82c18952ae67514', part: "base" }, h("div", { key: '3f59e0b0c482421b38d8eb39076da51453a91a70', part: "backdrop", class: backdrop(), onClick: () => this.hide() }), h("div", { key: '9b97aeb2ad7067a11c76a7b265adeb2e3c80eac5', part: "wrapper", class: wrapper(), style: this.getWrapperStyle(), role: "dialog", "aria-modal": "true", "aria-hidden": !this.open ? 'true' : 'false', "aria-label": this.headerText }, h("div", { key: 'd2613cabb535822fed605f52fd782af88c6bef8e', part: "header", class: header() }, h("h2", { key: '1771936e710fe478e3793a1846a0acf3f98d8864', part: "title", class: title() }, h("slot", { key: '0f6e8cb671e201d20b54b7669de9abec7a5627d0', name: "header" }, this.headerText)), h("button", { key: 'da006eaf46c4e6e3d7e7f773477e8eb61be69c00', part: "close-button", class: closeButton(), onClick: () => this.hide(), "aria-label": "Close" }, h("bcm-icon", { key: '913497c5cc4305f3b0ddaf751803fdca19143a9d', name: "fa-solid fa-xmark" }))), h("div", { key: 'd0a287ee5726197cd180724fc70984c5f54f5ba2', part: "content", class: content() }, h("slot", { key: '8401ec9c937f0888499ec8bd4c7bdead3141284e' })), h("div", { key: '14991163fc8d7d78b5a89b8ec18cbf82690a4f0d', part: "footer" }, h("slot", { key: '10e3bb6c6e9aefa5eea8d24dd02fa482feedfb18', name: "footer" })))));
501
+ }
502
+ get host() { return getElement(this); }
503
+ static get watchers() { return {
504
+ "open": ["handleOpenChange"]
505
+ }; }
506
+ };
507
+ BcmDrawer.style = drawerCss;
508
+
509
+ const modalCss = ".contents{display:contents}:host{display:contents}.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.bcm-ui-element{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,sans-serif}.static{position:static}.fixed{position:fixed}.relative{position:relative}.inset-0{inset:0}.m-0{margin:0}.flex{display:flex}.hidden{display:none}.h-6{height:1.5rem}.h-full{height:100%}.h-screen{height:100vh}.max-h-full{max-height:100%}.max-h-none{max-height:none}.w-6{width:1.5rem}.w-full{width:100%}.w-screen{width:100vw}.min-w-0{min-width:0}.max-w-full{max-width:100%}.max-w-none{max-width:none}.flex-1{flex:1 1 0%}.flex-shrink-0{flex-shrink:0}.flex-grow{flex-grow:1}.-translate-y-4{--tw-translate-y:-1rem}.-translate-y-4,.translate-y-0{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.translate-y-0{--tw-translate-y:0px}.scale-100{--tw-scale-x:1;--tw-scale-y:1}.scale-100,.scale-95{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.scale-95{--tw-scale-x:.95;--tw-scale-y:.95}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.animate-shake{animation:shake .82s cubic-bezier(.36,.07,.19,.97) infinite;animation:shake .3s cubic-bezier(.36,.07,.19,.97) both}.cursor-pointer{cursor:pointer}.flex-col{flex-direction:column}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.overflow-y-auto{overflow-y:auto}.overscroll-contain{overscroll-behavior:contain}.rounded{border-radius:var(--bcm-ui-border-radius-default,6px)}.rounded-lg{border-radius:var(--bcm-ui-border-radius-lg,8px)}.rounded-none{border-radius:var(--bcm-ui-border-radius-none,0)}.rounded-t-lg{border-top-left-radius:var(--bcm-ui-border-radius-lg,8px);border-top-right-radius:var(--bcm-ui-border-radius-lg,8px)}.border-0{border-width:0}.border-b{border-bottom-width:1px}.border-solid{border-style:solid}.border-none{border-style:none}.border-color-default{border-color:var(--bcm-ui-color-border-default)}.bg-color-base{background-color:var(--bcm-ui-color-background-base-default)}.bg-color-basic-base{background-color:var(--bcm-ui-color-background-basic-base)}.bg-transparent{background-color:transparent}.p-0{padding:0}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}.py-3{padding-bottom:.75rem;padding-top:.75rem}.py-4{padding-bottom:1rem;padding-top:1rem}.py-5{padding-bottom:1.25rem;padding-top:1.25rem}.pt-20{padding-top:5rem}.text-size-5{font-size:var(--bcm-ui-font-size-5,16px);line-height:var(--bcm-ui-line-height-5,24px)}.text-size-6{font-size:var(--bcm-ui-font-size-6,18px);line-height:var(--bcm-ui-line-height-6,24px)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.text-color-default{color:var(--bcm-ui-color-text-default)}.text-color-header{color:var(--bcm-ui-color-text-header)}.text-color-placeholder{color:var(--bcm-ui-color-text-placeholder)}.opacity-0{opacity:0}.opacity-100{opacity:1}.shadow{--tw-shadow:var(--bcm-ui-box-shadow-default);--tw-shadow-colored:var(--bcm-ui-box-shadow-default)}.shadow,.shadow-2xl{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.shadow-2xl{--tw-shadow:var(--bcm-ui-box-shadow-2xl);--tw-shadow-colored:var(--bcm-ui-box-shadow-2xl)}.outline-none{outline:2px solid transparent;outline-offset:2px}.transition-all{transition-duration:.15s;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-colors{transition-duration:.15s;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1)}.duration-300{transition-duration:.3s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.backdrop\\:bg-color-default-dark::backdrop{background-color:var(--bcm-ui-color-background-default-dark-default)}.backdrop\\:opacity-50::backdrop{opacity:.5}.backdrop\\:transition-opacity::backdrop{transition-duration:.15s;transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1)}.backdrop\\:duration-300::backdrop{transition-duration:.3s}.hover\\:bg-color-default-hover:hover{background-color:var(--bcm-ui-color-background-default-hover)}.focus-visible\\:ring:focus-visible{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}";
510
+
511
+ const BcmModal = class {
512
+ constructor(hostRef) {
513
+ registerInstance(this, hostRef);
514
+ this.bcmOpen = createEvent(this, "bcmOpen", 7);
515
+ this.bcmClose = createEvent(this, "bcmClose", 7);
516
+ this.bcmBeforeOpen = createEvent(this, "bcmBeforeOpen", 7);
517
+ this.bcmBeforeClose = createEvent(this, "bcmBeforeClose", 7);
518
+ this.open = false;
519
+ this.size = 'medium';
520
+ this.placement = 'center';
521
+ this.backdrop = true;
522
+ this.fullWidth = false;
523
+ this.fullScreen = false;
524
+ this.noHeader = false;
525
+ this.noFooter = false;
526
+ this.closeOnBackdrop = true;
527
+ this.closeOnEscape = true;
528
+ this.isAnimating = false;
529
+ this.shake = false;
530
+ this.modalClass = tv({
531
+ slots: {
532
+ dialog: 'bcm-ui-element fixed inset-0 m-0 p-0 w-full max-w-full h-full max-h-full border-none bg-transparent backdrop:bg-color-default-dark backdrop:opacity-50 backdrop:transition-opacity backdrop:duration-300',
533
+ container: 'fixed inset-0 flex items-start justify-center p-4 overflow-y-auto overscroll-contain',
534
+ modal: 'relative bg-color-basic-base text-color-default rounded-lg shadow-2xl transform transition-all duration-300 ease-in-out flex flex-col',
535
+ header: 'flex justify-between items-start bg-color-base text-color-default border-color-default border-solid border-0 border-b rounded-t-lg',
536
+ headerContent: 'flex-1 min-w-0 flex items-center gap-2',
537
+ title: 'font-semibold m-0 text-size-6 text-color-header',
538
+ helperText: 'text-size-5 text-color-placeholder m-0',
539
+ closeButton: 'text-size-5 font-medium text-color-default bg-transparent border-none p-0 h-6 w-6 rounded hover:bg-color-default-hover cursor-pointer active:bg-color-active transition-colors flex-shrink-0 outline-none focus-visible:ring ',
540
+ content: 'flex-grow overflow-y-auto',
541
+ footer: 'flex items-center justify-end gap-2',
542
+ },
543
+ variants: {
544
+ open: {
545
+ true: {
546
+ modal: 'opacity-100 translate-y-0 scale-100',
547
+ },
548
+ false: {
549
+ modal: 'opacity-0 -translate-y-4 scale-95',
550
+ },
551
+ },
552
+ placement: {
553
+ center: {
554
+ container: 'items-center',
555
+ },
556
+ top: {
557
+ container: 'items-start pt-20',
558
+ },
559
+ },
560
+ size: {
561
+ small: {
562
+ header: 'py-3 px-4',
563
+ content: 'p-4',
564
+ footer: 'py-3 px-4',
565
+ },
566
+ medium: {
567
+ header: 'py-4 px-5',
568
+ content: 'p-5',
569
+ footer: 'py-4 px-5',
570
+ },
571
+ large: {
572
+ header: 'py-4 px-6',
573
+ content: 'p-6',
574
+ footer: 'py-4 px-6',
575
+ },
576
+ xlarge: {
577
+ header: 'py-5 px-6',
578
+ content: 'p-6',
579
+ footer: 'py-5 px-6',
580
+ },
581
+ xxlarge: {
582
+ header: 'py-5 px-8',
583
+ content: 'p-8',
584
+ footer: 'py-5 px-8',
585
+ },
586
+ full: {
587
+ header: 'py-5 px-8',
588
+ content: 'p-8',
589
+ footer: 'py-5 px-8',
590
+ },
591
+ },
592
+ fullScreen: {
593
+ true: {
594
+ modal: 'rounded-none w-screen h-screen max-w-none max-h-none',
595
+ container: 'p-0',
596
+ },
597
+ },
598
+ shake: {
599
+ true: {
600
+ modal: 'animate-shake',
601
+ },
602
+ },
603
+ noHeader: {
604
+ true: {
605
+ header: 'hidden',
606
+ },
607
+ },
608
+ noFooter: {
609
+ true: {
610
+ footer: 'hidden',
611
+ },
612
+ },
613
+ },
614
+ });
615
+ this.handleBackdropClick = (event) => {
616
+ const target = event.target;
617
+ // Check if click is on the container (backdrop area), not on modal content
618
+ if (target.getAttribute('part') === 'container') {
619
+ if (this.backdrop === 'static') {
620
+ this.shakeModal();
621
+ }
622
+ else if (this.closeOnBackdrop) {
623
+ this.hide();
624
+ }
625
+ }
626
+ };
627
+ this.handleDialogCancel = (event) => {
628
+ event.preventDefault();
629
+ if (this.closeOnEscape) {
630
+ if (this.backdrop === 'static') {
631
+ this.shakeModal();
632
+ }
633
+ else {
634
+ this.hide();
635
+ }
636
+ }
637
+ };
638
+ }
639
+ async handleOpenChange(isOpen) {
640
+ if (isOpen) {
641
+ this.isAnimating = true;
642
+ const event = this.bcmBeforeOpen.emit();
643
+ if (event.defaultPrevented) {
644
+ this.open = false;
645
+ return;
646
+ }
647
+ // Use native dialog API with top-layer
648
+ if (this.dialogRef) {
649
+ this.dialogRef.showModal();
650
+ // Small delay for animation
651
+ await new Promise(resolve => setTimeout(resolve, 50));
652
+ this.isAnimating = false;
653
+ this.bcmOpen.emit();
654
+ }
655
+ }
656
+ else {
657
+ this.isAnimating = true;
658
+ const event = this.bcmBeforeClose.emit();
659
+ if (event.defaultPrevented) {
660
+ this.open = true;
661
+ return;
662
+ }
663
+ // Wait for animation before closing
664
+ await new Promise(resolve => setTimeout(resolve, 300));
665
+ if (this.dialogRef) {
666
+ this.dialogRef.close();
667
+ }
668
+ this.isAnimating = false;
669
+ this.bcmClose.emit();
670
+ }
671
+ }
672
+ handleClick(event) {
673
+ // Use composedPath to work with shadow DOM and slots
674
+ const path = event.composedPath();
675
+ const dismissElement = path.find(el => { var _a; return (_a = el.hasAttribute) === null || _a === void 0 ? void 0 : _a.call(el, 'data-dismiss'); });
676
+ const closeModalElement = path.find(el => { var _a; return (_a = el.hasAttribute) === null || _a === void 0 ? void 0 : _a.call(el, 'data-close-modal'); });
677
+ if (dismissElement) {
678
+ this.hide();
679
+ event.preventDefault();
680
+ event.stopPropagation();
681
+ }
682
+ else if (closeModalElement) {
683
+ const modalId = closeModalElement.getAttribute('data-close-modal');
684
+ // If modalId matches this modal's id, close it
685
+ if (!modalId || modalId === this.host.id) {
686
+ this.hide();
687
+ event.preventDefault();
688
+ event.stopPropagation();
689
+ }
690
+ }
691
+ }
692
+ handleKeyDown(event) {
693
+ if (event.key === 'Escape' && this.open) {
694
+ // Only handle ESC if this is the topmost modal
695
+ const openModals = Array.from(document.querySelectorAll('bcm-modal[open]'));
696
+ const topModal = openModals[openModals.length - 1];
697
+ if (topModal !== this.host) {
698
+ return;
699
+ }
700
+ event.preventDefault();
701
+ if (this.closeOnEscape) {
702
+ if (this.backdrop === 'static') {
703
+ this.shakeModal();
704
+ }
705
+ else {
706
+ this.hide();
707
+ }
708
+ }
709
+ else if (this.backdrop === 'static') {
710
+ this.shakeModal();
711
+ }
712
+ }
713
+ }
714
+ async show() {
715
+ this.open = true;
716
+ }
717
+ async hide() {
718
+ this.open = false;
719
+ }
720
+ async toggle() {
721
+ this.open = !this.open;
722
+ }
723
+ shakeModal() {
724
+ this.shake = true;
725
+ setTimeout(() => {
726
+ this.shake = false;
727
+ }, 300);
728
+ }
729
+ getModalStyle() {
730
+ if (this.fullScreen) {
731
+ return {
732
+ width: '100vw',
733
+ height: '100vh',
734
+ maxWidth: 'none',
735
+ maxHeight: 'none',
736
+ };
737
+ }
738
+ if (this.fullWidth) {
739
+ return {
740
+ width: '100%',
741
+ maxWidth: '100%',
742
+ };
743
+ }
744
+ const widths = {
745
+ small: '400px',
746
+ medium: '600px',
747
+ large: '800px',
748
+ xlarge: '1024px',
749
+ xxlarge: '1200px',
750
+ full: '100%',
751
+ };
752
+ return {
753
+ width: widths[this.size],
754
+ maxWidth: this.fullScreen ? 'none' : '90vw',
755
+ maxHeight: this.fullScreen ? 'none' : '90vh',
756
+ };
757
+ }
758
+ componentDidLoad() {
759
+ if (this.open && this.dialogRef) {
760
+ this.dialogRef.showModal();
761
+ }
762
+ }
763
+ disconnectedCallback() {
764
+ if (this.dialogRef && this.open) {
765
+ this.dialogRef.close();
766
+ }
767
+ }
768
+ render() {
769
+ const { dialog, container, modal, header, headerContent, title, helperText, closeButton, content, footer } = this.modalClass({
770
+ open: this.open,
771
+ placement: this.placement,
772
+ size: this.size,
773
+ fullScreen: this.fullScreen,
774
+ shake: this.shake,
775
+ noHeader: this.noHeader,
776
+ noFooter: this.noFooter,
777
+ });
778
+ return (h("dialog", { key: 'c56eace3816f22ce8c5c3d779940c32c1a2504fe', ref: el => (this.dialogRef = el), part: "dialog", class: dialog(), onClick: this.handleBackdropClick, onCancel: this.handleDialogCancel, "aria-labelledby": "modal-title", "aria-describedby": this.helperText ? 'modal-helper' : undefined, "aria-modal": "true" }, h("div", { key: '0c8185cd161cb0dafcbd8a6c5f67528cd32c23de', part: "container", class: container() }, h("div", { key: 'ff66ec6396147a71d7819ae5e2f00ca38070b306', part: "modal", class: modal(), style: this.getModalStyle(), role: "document", onClick: e => e.stopPropagation() }, !this.noHeader && (h("div", { key: '4cc6b28b668fe76dcaee1138887183ea98466cbe', part: "header", class: header() }, h("div", { key: '8b005c9d586d4d2527c0319c4d17512650479bb0', part: "header-content", class: headerContent() }, h("h2", { key: '756e7f7f7e0d7b2b8c1f476fcb2b00a204884b8e', id: "modal-title", part: "title", class: title() }, h("slot", { key: 'd814bb4b44e47455ded1b0f737c8ddf61fddf9b3', name: "header" }, this.headerText)), this.helperText && (h("p", { key: '7c385f9dce88bc22bf0b7700bb2b289b7803683e', id: "modal-helper", part: "helper-text", class: helperText() }, h("slot", { key: '57bdf3201dd678a1ebdda9893b67032ff773fd05', name: "helper" }, this.helperText)))), h("button", { key: '6bcdfc24e13b375f81c9664a20b552a3f0c5d591', part: "close-button", class: closeButton(), onClick: () => this.hide(), "aria-label": "Close modal", type: "button" }, h("bcm-icon", { key: '894f44177f0acbf3e581cbae5cdc76f71e321b57', name: "fa-solid fa-xmark" })))), h("div", { key: '74db820df232cb7728c8a58923a9459b9545e8a1', part: "content", class: content() }, h("slot", { key: '95fd04fbbb441d79d649fd68eeef3868ce65bccc' })), !this.noFooter && (h("div", { key: '7c841bfe1a35abc8d9fe031eb0c8fed5a131db4e', part: "footer", class: footer() }, h("slot", { key: '9bd84178717338a821204f81179571a48bfd1f66', name: "footer" })))))));
779
+ }
780
+ get host() { return getElement(this); }
781
+ static get watchers() { return {
782
+ "open": ["handleOpenChange"]
783
+ }; }
784
+ };
785
+ BcmModal.style = modalCss;
786
+
787
+ export { BcmButton as bcm_button, BcmDrawer as bcm_drawer, BcmModal as bcm_modal };
788
+ //# sourceMappingURL=bcm-button.bcm-drawer.bcm-modal.entry.js.map
789
+
790
+ //# sourceMappingURL=bcm-button_3.entry.js.map