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