bromcom-ui-next 0.1.26 → 0.1.28

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 (266) hide show
  1. package/dist/bromcom-ui/bcm-button.bcm-chip.bcm-drawer.bcm-modal.entry.esm.js.map +1 -0
  2. package/dist/bromcom-ui/bcm-dropdown-item.entry.esm.js.map +1 -0
  3. package/dist/bromcom-ui/bcm-dropdown.entry.esm.js.map +1 -0
  4. package/dist/bromcom-ui/bcm-input.entry.esm.js.map +1 -0
  5. package/dist/bromcom-ui/bcm-linked.entry.esm.js.map +1 -0
  6. package/dist/bromcom-ui/bcm-shortcut.entry.esm.js.map +1 -0
  7. package/dist/bromcom-ui/bcm-text.entry.esm.js.map +1 -0
  8. package/dist/bromcom-ui/bromcom-ui.css +1 -1
  9. package/dist/bromcom-ui/bromcom-ui.esm.js +1 -1
  10. package/dist/bromcom-ui/{p-188bc34d.entry.js → p-0101b4f2.entry.js} +2 -2
  11. package/dist/bromcom-ui/{p-a18d34c7.entry.js → p-089edfdc.entry.js} +2 -2
  12. package/dist/bromcom-ui/{p-a07a257f.entry.js → p-08bc93c5.entry.js} +2 -2
  13. package/dist/bromcom-ui/{p-ead5a030.entry.js → p-09be61c3.entry.js} +2 -2
  14. package/dist/bromcom-ui/p-211ca6e0.entry.js +2 -0
  15. package/dist/bromcom-ui/p-2480e468.entry.js +2 -0
  16. package/dist/bromcom-ui/p-2480e468.entry.js.map +1 -0
  17. package/dist/bromcom-ui/{p-8fd1a05d.entry.js → p-26d2db9e.entry.js} +2 -2
  18. package/dist/bromcom-ui/p-2d0a6472.entry.js +2 -0
  19. package/dist/bromcom-ui/p-2d0a6472.entry.js.map +1 -0
  20. package/dist/bromcom-ui/{p-d3206345.entry.js → p-360bff8a.entry.js} +2 -2
  21. package/dist/bromcom-ui/{p-6c2441a1.entry.js → p-488d6ef4.entry.js} +2 -2
  22. package/dist/bromcom-ui/{p-84b1e52c.entry.js → p-5e0702d1.entry.js} +2 -2
  23. package/dist/bromcom-ui/{p-2f517bd8.entry.js → p-6169490c.entry.js} +2 -2
  24. package/dist/bromcom-ui/{p-c9683df3.entry.js → p-6b585adc.entry.js} +2 -2
  25. package/dist/bromcom-ui/{p-7f117b72.entry.js → p-6d7d73d5.entry.js} +2 -2
  26. package/dist/bromcom-ui/{p-e500e6d1.entry.js → p-7234af90.entry.js} +2 -2
  27. package/dist/bromcom-ui/{p-5e47b56d.entry.js → p-83f64814.entry.js} +2 -2
  28. package/dist/bromcom-ui/p-84677827.entry.js +2 -0
  29. package/dist/bromcom-ui/p-84677827.entry.js.map +1 -0
  30. package/dist/bromcom-ui/p-8ace5a6a.entry.js +2 -0
  31. package/dist/bromcom-ui/p-8ace5a6a.entry.js.map +1 -0
  32. package/dist/bromcom-ui/p-8d74249a.entry.js +2 -0
  33. package/dist/bromcom-ui/{p-6bc82dd4.entry.js.map → p-8d74249a.entry.js.map} +1 -1
  34. package/dist/bromcom-ui/p-BuuGCw0z.js +3 -0
  35. package/dist/bromcom-ui/p-BuuGCw0z.js.map +1 -0
  36. package/dist/bromcom-ui/{p-2cce1424.entry.js → p-a88f20e0.entry.js} +2 -2
  37. package/dist/bromcom-ui/{p-5da9360c.entry.js → p-bad299f2.entry.js} +2 -2
  38. package/dist/bromcom-ui/{p-7560f0e9.entry.js → p-bdaf5653.entry.js} +2 -2
  39. package/dist/bromcom-ui/{p-a26619e4.entry.js → p-c0e7f9d6.entry.js} +2 -2
  40. package/dist/bromcom-ui/{p-0213e9e8.entry.js → p-c34f0a66.entry.js} +2 -2
  41. package/dist/bromcom-ui/p-c9cf3f14.entry.js +2 -0
  42. package/dist/bromcom-ui/p-c9cf3f14.entry.js.map +1 -0
  43. package/dist/bromcom-ui/{p-cf9dd0fc.entry.js → p-d7cea19f.entry.js} +2 -2
  44. package/dist/bromcom-ui/p-e5e0ac07.entry.js +2 -0
  45. package/dist/bromcom-ui/p-e5e0ac07.entry.js.map +1 -0
  46. package/dist/bromcom-ui/{p-10de6d9c.entry.js → p-ee5f877f.entry.js} +2 -2
  47. package/dist/bromcom-ui/p-fbccbffc.entry.js +2 -0
  48. package/dist/bromcom-ui/p-fbccbffc.entry.js.map +1 -0
  49. package/dist/cjs/bcm-accordion-group.cjs.entry.js +2 -2
  50. package/dist/cjs/bcm-accordion.cjs.entry.js +3 -3
  51. package/dist/cjs/bcm-alert.cjs.entry.js +2 -2
  52. package/dist/cjs/bcm-avatar.cjs.entry.js +1 -1
  53. package/dist/cjs/bcm-badge.cjs.entry.js +3 -3
  54. package/dist/cjs/bcm-basic-badge.cjs.entry.js +3 -3
  55. package/dist/cjs/bcm-button-group.cjs.entry.js +3 -3
  56. package/dist/cjs/bcm-button.bcm-chip.bcm-drawer.bcm-modal.entry.cjs.js.map +1 -0
  57. package/dist/cjs/bcm-button_4.cjs.entry.js +915 -0
  58. package/dist/cjs/bcm-button_4.cjs.entry.js.map +1 -0
  59. package/dist/cjs/bcm-checkbox.cjs.entry.js +2 -2
  60. package/dist/cjs/bcm-divider.cjs.entry.js +2 -2
  61. package/dist/cjs/bcm-dropdown-item.cjs.entry.js +61 -0
  62. package/dist/cjs/bcm-dropdown-item.cjs.entry.js.map +1 -0
  63. package/dist/cjs/bcm-dropdown-item.entry.cjs.js.map +1 -0
  64. package/dist/cjs/bcm-dropdown.cjs.entry.js +54 -0
  65. package/dist/cjs/bcm-dropdown.cjs.entry.js.map +1 -0
  66. package/dist/cjs/bcm-dropdown.entry.cjs.js.map +1 -0
  67. package/dist/cjs/bcm-input.cjs.entry.js +315 -0
  68. package/dist/cjs/bcm-input.cjs.entry.js.map +1 -0
  69. package/dist/cjs/bcm-input.entry.cjs.js.map +1 -0
  70. package/dist/cjs/bcm-linked.cjs.entry.js +343 -0
  71. package/dist/cjs/bcm-linked.cjs.entry.js.map +1 -0
  72. package/dist/cjs/bcm-linked.entry.cjs.js.map +1 -0
  73. package/dist/cjs/bcm-pop-confirm.cjs.entry.js +2 -2
  74. package/dist/cjs/bcm-popover.cjs.entry.js +2 -2
  75. package/dist/cjs/bcm-radio-group.cjs.entry.js +3 -3
  76. package/dist/cjs/bcm-radio.cjs.entry.js +2 -2
  77. package/dist/cjs/bcm-segmented-picker-option.cjs.entry.js +3 -3
  78. package/dist/cjs/bcm-segmented-picker.cjs.entry.js +3 -3
  79. package/dist/cjs/bcm-shortcut.cjs.entry.js +50 -0
  80. package/dist/cjs/bcm-shortcut.cjs.entry.js.map +1 -0
  81. package/dist/cjs/bcm-shortcut.entry.cjs.js.map +1 -0
  82. package/dist/cjs/bcm-switch.cjs.entry.js +3 -3
  83. package/dist/cjs/bcm-tabs-content.cjs.entry.js +2 -2
  84. package/dist/cjs/bcm-tabs-list.cjs.entry.js +2 -2
  85. package/dist/cjs/bcm-tabs-trigger.cjs.entry.js +2 -2
  86. package/dist/cjs/bcm-tabs.cjs.entry.js +2 -2
  87. package/dist/cjs/bcm-text.cjs.entry.js +124 -0
  88. package/dist/cjs/bcm-text.cjs.entry.js.map +1 -0
  89. package/dist/cjs/bcm-text.entry.cjs.js.map +1 -0
  90. package/dist/cjs/bcm-textarea.cjs.entry.js +4 -4
  91. package/dist/cjs/bcm-tooltip.cjs.entry.js +2 -2
  92. package/dist/cjs/bromcom-ui.cjs.js +2 -2
  93. package/dist/cjs/{index-DHDrXFLM.js → index-BtiU-G2W.js} +3 -3
  94. package/dist/cjs/index-BtiU-G2W.js.map +1 -0
  95. package/dist/cjs/loader.cjs.js +2 -2
  96. package/dist/collection/collection-manifest.json +1 -0
  97. package/dist/collection/components/accordion/accordion.component.js +2 -2
  98. package/dist/collection/components/accordion-group/accordion-group.component.js +1 -1
  99. package/dist/collection/components/alert/alert.component.js +1 -1
  100. package/dist/collection/components/badge/badge.component.js +2 -2
  101. package/dist/collection/components/basic-badge/basic-badge.component.js +2 -2
  102. package/dist/collection/components/button/button.component.js +6 -5
  103. package/dist/collection/components/button/button.component.js.map +1 -1
  104. package/dist/collection/components/button-group/button-group.component.js +2 -2
  105. package/dist/collection/components/checkbox/checkbox.component.js +1 -1
  106. package/dist/collection/components/chip/chip.component.js +3 -3
  107. package/dist/collection/components/chip/chip.component.js.map +1 -1
  108. package/dist/collection/components/chip/types.js +1 -0
  109. package/dist/collection/components/chip/types.js.map +1 -1
  110. package/dist/collection/components/divider/divider.component.js +1 -1
  111. package/dist/collection/components/drawer/drawer.component.js +1 -1
  112. package/dist/collection/components/dropdown/dropdown.component.js +1 -1
  113. package/dist/collection/components/dropdown-item/dropdown-item.component.js +2 -2
  114. package/dist/collection/components/input/input.component.js +2 -2
  115. package/dist/collection/components/modal/modal.component.js +680 -0
  116. package/dist/collection/components/modal/modal.component.js.map +1 -0
  117. package/dist/collection/components/modal/modal.css +1 -0
  118. package/dist/collection/components/pop-confirm/pop-confirm.component.js +1 -1
  119. package/dist/collection/components/popover/popover.component.js +1 -1
  120. package/dist/collection/components/radio/radio.component.js +1 -1
  121. package/dist/collection/components/radio-group/radio-group.component.js +2 -2
  122. package/dist/collection/components/segmented-picker/segmented-picker-option.component.js +2 -2
  123. package/dist/collection/components/segmented-picker/segmented-picker.component.js +2 -2
  124. package/dist/collection/components/shortcut/shortcut.js +1 -1
  125. package/dist/collection/components/switch/switch.component.js +2 -2
  126. package/dist/collection/components/tabs/tabs-content.component.js +1 -1
  127. package/dist/collection/components/tabs/tabs-list.component.js +1 -1
  128. package/dist/collection/components/tabs/tabs-trigger.component.js +1 -1
  129. package/dist/collection/components/tabs/tabs.component.js +1 -1
  130. package/dist/collection/components/text/text.component.js +1 -1
  131. package/dist/collection/components/textarea/textarea.component.js +3 -3
  132. package/dist/collection/components/tooltip/tooltip.component.js +1 -1
  133. package/dist/collection/styles/theme-variables.js +72 -0
  134. package/dist/collection/styles/theme-variables.js.map +1 -1
  135. package/dist/components/bcm-accordion-group.js +1 -1
  136. package/dist/components/bcm-accordion.js +2 -2
  137. package/dist/components/bcm-alert.js +1 -1
  138. package/dist/components/bcm-avatar.js +1 -1
  139. package/dist/components/bcm-badge.js +1 -1
  140. package/dist/components/bcm-basic-badge.js +2 -2
  141. package/dist/components/bcm-button-group.js +2 -2
  142. package/dist/components/bcm-button.js +1 -1
  143. package/dist/components/bcm-checkbox.js +1 -1
  144. package/dist/components/bcm-chip.js +2 -1
  145. package/dist/components/bcm-chip.js.map +1 -1
  146. package/dist/components/bcm-divider.js +1 -1
  147. package/dist/components/bcm-drawer.js +1 -1
  148. package/dist/components/bcm-dropdown-item.js +2 -2
  149. package/dist/components/bcm-dropdown.js +2 -2
  150. package/dist/components/bcm-input.js +2 -2
  151. package/dist/components/bcm-modal.d.ts +11 -0
  152. package/dist/components/bcm-modal.js +324 -0
  153. package/dist/components/bcm-modal.js.map +1 -0
  154. package/dist/components/bcm-pop-confirm.js +2 -2
  155. package/dist/components/bcm-popover.js +1 -1
  156. package/dist/components/bcm-radio-group.js +2 -2
  157. package/dist/components/bcm-radio.js +1 -1
  158. package/dist/components/bcm-segmented-picker-option.js +2 -2
  159. package/dist/components/bcm-segmented-picker.js +2 -2
  160. package/dist/components/bcm-shortcut.js +1 -1
  161. package/dist/components/bcm-switch.js +2 -2
  162. package/dist/components/bcm-tabs-content.js +1 -1
  163. package/dist/components/bcm-tabs-list.js +1 -1
  164. package/dist/components/bcm-tabs-trigger.js +1 -1
  165. package/dist/components/bcm-tabs.js +1 -1
  166. package/dist/components/bcm-text.js +1 -1
  167. package/dist/components/bcm-textarea.js +3 -3
  168. package/dist/components/bcm-tooltip.js +1 -1
  169. package/dist/components/index.js +1 -1
  170. package/dist/components/index.js.map +1 -1
  171. package/dist/components/{p-A70Ppz6C.js → p-CQF7wlXf.js} +4 -4
  172. package/dist/components/{p-A70Ppz6C.js.map → p-CQF7wlXf.js.map} +1 -1
  173. package/dist/components/{p-BdGAZ8M0.js → p-DGlecSBr.js} +8 -7
  174. package/dist/components/p-DGlecSBr.js.map +1 -0
  175. package/dist/esm/bcm-accordion-group.entry.js +2 -2
  176. package/dist/esm/bcm-accordion.entry.js +3 -3
  177. package/dist/esm/bcm-alert.entry.js +2 -2
  178. package/dist/esm/bcm-avatar.entry.js +1 -1
  179. package/dist/esm/bcm-badge.entry.js +3 -3
  180. package/dist/esm/bcm-basic-badge.entry.js +3 -3
  181. package/dist/esm/bcm-button-group.entry.js +3 -3
  182. package/dist/esm/bcm-button.bcm-chip.bcm-drawer.bcm-modal.entry.js.map +1 -0
  183. package/dist/esm/bcm-button_4.entry.js +910 -0
  184. package/dist/esm/bcm-button_4.entry.js.map +1 -0
  185. package/dist/esm/bcm-checkbox.entry.js +2 -2
  186. package/dist/esm/bcm-divider.entry.js +2 -2
  187. package/dist/esm/bcm-dropdown-item.entry.js +59 -0
  188. package/dist/esm/bcm-dropdown-item.entry.js.map +1 -0
  189. package/dist/esm/bcm-dropdown.entry.js +52 -0
  190. package/dist/esm/bcm-dropdown.entry.js.map +1 -0
  191. package/dist/esm/bcm-input.entry.js +313 -0
  192. package/dist/esm/bcm-input.entry.js.map +1 -0
  193. package/dist/esm/bcm-linked.entry.js +341 -0
  194. package/dist/esm/bcm-linked.entry.js.map +1 -0
  195. package/dist/esm/bcm-pop-confirm.entry.js +2 -2
  196. package/dist/esm/bcm-popover.entry.js +2 -2
  197. package/dist/esm/bcm-radio-group.entry.js +3 -3
  198. package/dist/esm/bcm-radio.entry.js +2 -2
  199. package/dist/esm/bcm-segmented-picker-option.entry.js +3 -3
  200. package/dist/esm/bcm-segmented-picker.entry.js +3 -3
  201. package/dist/esm/bcm-shortcut.entry.js +48 -0
  202. package/dist/esm/bcm-shortcut.entry.js.map +1 -0
  203. package/dist/esm/bcm-switch.entry.js +3 -3
  204. package/dist/esm/bcm-tabs-content.entry.js +2 -2
  205. package/dist/esm/bcm-tabs-list.entry.js +2 -2
  206. package/dist/esm/bcm-tabs-trigger.entry.js +2 -2
  207. package/dist/esm/bcm-tabs.entry.js +2 -2
  208. package/dist/esm/bcm-text.entry.js +122 -0
  209. package/dist/esm/bcm-text.entry.js.map +1 -0
  210. package/dist/esm/bcm-textarea.entry.js +4 -4
  211. package/dist/esm/bcm-tooltip.entry.js +2 -2
  212. package/dist/esm/bromcom-ui.js +3 -3
  213. package/dist/esm/{index-B84DzIAh.js → index-BuuGCw0z.js} +3 -3
  214. package/dist/esm/index-BuuGCw0z.js.map +1 -0
  215. package/dist/esm/loader.js +3 -3
  216. package/dist/types/components/chip/chip.component.d.ts +1 -1
  217. package/dist/types/components/chip/types.d.ts +2 -1
  218. package/dist/types/components/modal/modal.component.d.ts +39 -0
  219. package/dist/types/components.d.ts +128 -4
  220. package/dist/types/styles/theme-variables.d.ts +72 -0
  221. package/package.json +1 -1
  222. package/dist/bromcom-ui/bcm-button.bcm-drawer.bcm-dropdown.bcm-dropdown-item.bcm-input.bcm-linked.bcm-shortcut.bcm-text.entry.esm.js.map +0 -1
  223. package/dist/bromcom-ui/bcm-chip.entry.esm.js.map +0 -1
  224. package/dist/bromcom-ui/p-6bc82dd4.entry.js +0 -2
  225. package/dist/bromcom-ui/p-96aba34c.entry.js +0 -2
  226. package/dist/bromcom-ui/p-96aba34c.entry.js.map +0 -1
  227. package/dist/bromcom-ui/p-B84DzIAh.js +0 -3
  228. package/dist/bromcom-ui/p-B84DzIAh.js.map +0 -1
  229. package/dist/bromcom-ui/p-bd293ffd.entry.js +0 -2
  230. package/dist/bromcom-ui/p-bd293ffd.entry.js.map +0 -1
  231. package/dist/bromcom-ui/p-dd9ec481.entry.js +0 -2
  232. package/dist/cjs/bcm-button.bcm-drawer.bcm-dropdown.bcm-dropdown-item.bcm-input.bcm-linked.bcm-shortcut.bcm-text.entry.cjs.js.map +0 -1
  233. package/dist/cjs/bcm-button_8.cjs.entry.js +0 -1414
  234. package/dist/cjs/bcm-button_8.cjs.entry.js.map +0 -1
  235. package/dist/cjs/bcm-chip.cjs.entry.js +0 -128
  236. package/dist/cjs/bcm-chip.cjs.entry.js.map +0 -1
  237. package/dist/cjs/bcm-chip.entry.cjs.js.map +0 -1
  238. package/dist/cjs/index-DHDrXFLM.js.map +0 -1
  239. package/dist/components/p-BdGAZ8M0.js.map +0 -1
  240. package/dist/esm/bcm-button.bcm-drawer.bcm-dropdown.bcm-dropdown-item.bcm-input.bcm-linked.bcm-shortcut.bcm-text.entry.js.map +0 -1
  241. package/dist/esm/bcm-button_8.entry.js +0 -1405
  242. package/dist/esm/bcm-button_8.entry.js.map +0 -1
  243. package/dist/esm/bcm-chip.entry.js +0 -126
  244. package/dist/esm/bcm-chip.entry.js.map +0 -1
  245. package/dist/esm/index-B84DzIAh.js.map +0 -1
  246. /package/dist/bromcom-ui/{p-188bc34d.entry.js.map → p-0101b4f2.entry.js.map} +0 -0
  247. /package/dist/bromcom-ui/{p-a18d34c7.entry.js.map → p-089edfdc.entry.js.map} +0 -0
  248. /package/dist/bromcom-ui/{p-a07a257f.entry.js.map → p-08bc93c5.entry.js.map} +0 -0
  249. /package/dist/bromcom-ui/{p-ead5a030.entry.js.map → p-09be61c3.entry.js.map} +0 -0
  250. /package/dist/bromcom-ui/{p-dd9ec481.entry.js.map → p-211ca6e0.entry.js.map} +0 -0
  251. /package/dist/bromcom-ui/{p-8fd1a05d.entry.js.map → p-26d2db9e.entry.js.map} +0 -0
  252. /package/dist/bromcom-ui/{p-d3206345.entry.js.map → p-360bff8a.entry.js.map} +0 -0
  253. /package/dist/bromcom-ui/{p-6c2441a1.entry.js.map → p-488d6ef4.entry.js.map} +0 -0
  254. /package/dist/bromcom-ui/{p-84b1e52c.entry.js.map → p-5e0702d1.entry.js.map} +0 -0
  255. /package/dist/bromcom-ui/{p-2f517bd8.entry.js.map → p-6169490c.entry.js.map} +0 -0
  256. /package/dist/bromcom-ui/{p-c9683df3.entry.js.map → p-6b585adc.entry.js.map} +0 -0
  257. /package/dist/bromcom-ui/{p-7f117b72.entry.js.map → p-6d7d73d5.entry.js.map} +0 -0
  258. /package/dist/bromcom-ui/{p-e500e6d1.entry.js.map → p-7234af90.entry.js.map} +0 -0
  259. /package/dist/bromcom-ui/{p-5e47b56d.entry.js.map → p-83f64814.entry.js.map} +0 -0
  260. /package/dist/bromcom-ui/{p-2cce1424.entry.js.map → p-a88f20e0.entry.js.map} +0 -0
  261. /package/dist/bromcom-ui/{p-5da9360c.entry.js.map → p-bad299f2.entry.js.map} +0 -0
  262. /package/dist/bromcom-ui/{p-7560f0e9.entry.js.map → p-bdaf5653.entry.js.map} +0 -0
  263. /package/dist/bromcom-ui/{p-a26619e4.entry.js.map → p-c0e7f9d6.entry.js.map} +0 -0
  264. /package/dist/bromcom-ui/{p-0213e9e8.entry.js.map → p-c34f0a66.entry.js.map} +0 -0
  265. /package/dist/bromcom-ui/{p-cf9dd0fc.entry.js.map → p-d7cea19f.entry.js.map} +0 -0
  266. /package/dist/bromcom-ui/{p-10de6d9c.entry.js.map → p-ee5f877f.entry.js.map} +0 -0
@@ -0,0 +1,915 @@
1
+ 'use strict';
2
+
3
+ var index = require('./index-BtiU-G2W.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 STATUS_COLORS = {
315
+ info: 'blue',
316
+ error: 'red',
317
+ warning: 'amber',
318
+ success: 'green',
319
+ primary: 'primary',
320
+ };
321
+
322
+ const chipCss = ":host{--bcm-chip-bg:var(--bcm-ui-color-background-default-default);--bcm-chip-text:var(--bcm-ui-color-text-default);--bcm-chip-border:var(--bcm-ui-color-border-default);--bcm-chip-hover-bg:var(--bcm-ui-color-background-default-hover);--bcm-chip-active-bg:var(--bcm-ui-color-background-default-active);--bcm-chip-radius:6px;display:inline-block}.bcm-ui-element{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,sans-serif}.static{position:static}.flex{display:flex}.min-w-max{min-width:max-content}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.items-center{align-items:center}.justify-center{justify-content:center}.gap-1{gap:.25rem}.rounded-\\[--bcm-chip-radius\\]{border-radius:var(--bcm-chip-radius)}.border{border-width:1px}.border-none{border-style:none}.border-\\[--bcm-chip-border\\]{border-color:var(--bcm-chip-border)}.border-transparent{border-color:transparent}.bg-\\[--bcm-chip-bg\\]{background-color:var(--bcm-chip-bg)}.px-2{padding-left:.5rem;padding-right:.5rem}.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-3{font-size:var(--bcm-ui-font-size-3,12px);line-height:var(--bcm-ui-line-height-3,16px)}.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)}.font-normal{font-weight:400}.text-\\[--bcm-chip-text\\]{color:var(--bcm-chip-text)}.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)}.hover\\:bg-\\[--bcm-chip-hover-bg\\]:hover{background-color:var(--bcm-chip-hover-bg)}.active\\:bg-\\[--bcm-chip-active-bg\\]:active{background-color:var(--bcm-chip-active-bg)}";
323
+
324
+ const BcmChip = class {
325
+ constructor(hostRef) {
326
+ index.registerInstance(this, hostRef);
327
+ this.bcmDismiss = index.createEvent(this, "bcmDismiss", 1);
328
+ /** Chip size variant */
329
+ this.size = 'medium';
330
+ /** Chip style variant */
331
+ this.kind = 'filled';
332
+ /** Chip status */
333
+ this.status = 'default';
334
+ /** Whether chip can be dismissed */
335
+ this.dismissible = false;
336
+ /** Whether chip is disabled */
337
+ this.disabled = false;
338
+ this.chipClass = tv.tv({
339
+ base: [
340
+ 'chip bcm-ui-element font-normal flex items-center justify-center px-2 gap-1 min-w-max border',
341
+ 'bg-[--bcm-chip-bg] text-[--bcm-chip-text] rounded-[--bcm-chip-radius] border-[--bcm-chip-border]',
342
+ 'hover:bg-[--bcm-chip-hover-bg] active:bg-[--bcm-chip-active-bg]',
343
+ ],
344
+ variants: {
345
+ size: {
346
+ small: 'small py-px text-size-3',
347
+ medium: 'medium py-0.5 text-size-4',
348
+ large: 'large py-1 text-size-5',
349
+ },
350
+ kind: {
351
+ filled: 'filled border-transparent',
352
+ outlined: 'outlined',
353
+ text: 'text border-none',
354
+ },
355
+ disabled: {
356
+ true: 'cursor-not-allowed',
357
+ },
358
+ },
359
+ }, { twMerge: false });
360
+ }
361
+ get chipStyle() {
362
+ let _color = this.color;
363
+ if (this.disabled) {
364
+ return {
365
+ '--bcm-chip-bg': 'var(--bcm-ui-color-background-disabled-default)',
366
+ '--bcm-chip-text': 'var(--bcm-ui-color-text-disabled)',
367
+ '--bcm-chip-border': 'var(--bcm-ui-color-border-disabled)',
368
+ '--bcm-chip-hover-bg': 'var(--bcm-ui-color-background-disabled-default)',
369
+ '--bcm-chip-active-bg': 'var(--bcm-ui-color-background-disabled-default)',
370
+ };
371
+ }
372
+ if (this.status !== 'default') {
373
+ _color = STATUS_COLORS[this.status];
374
+ }
375
+ const styles = {
376
+ filled: {
377
+ '--bcm-chip-bg': `var(--bcm-ui-color-background-palette-${_color}-default)`,
378
+ '--bcm-chip-text': `var(--bcm-ui-color-text-palette-${_color})`,
379
+ '--bcm-chip-border': `var(--bcm-ui-color-border-${_color})`,
380
+ '--bcm-chip-hover-bg': `var(--bcm-ui-color-background-palette-${_color}-hover)`,
381
+ '--bcm-chip-active-bg': `var(--bcm-ui-color-background-palette-${_color}-active)`,
382
+ },
383
+ outlined: {
384
+ '--bcm-chip-bg': 'transparent',
385
+ '--bcm-chip-text': `var(--bcm-ui-color-text-palette-${_color})`,
386
+ '--bcm-chip-border': `var(--bcm-ui-color-border-${_color})`,
387
+ '--bcm-chip-hover-bg': `var(--bcm-ui-color-background-palette-${_color}-hover)`,
388
+ '--bcm-chip-active-bg': `var(--bcm-ui-color-background-palette-${_color}-active)`,
389
+ },
390
+ text: {
391
+ '--bcm-chip-bg': 'transparent',
392
+ '--bcm-chip-text': `var(--bcm-ui-color-text-palette-${_color})`,
393
+ '--bcm-chip-border': 'transparent',
394
+ '--bcm-chip-hover-bg': `var(--bcm-ui-color-background-palette-${_color}-hover)`,
395
+ '--bcm-chip-active-bg': `var(--bcm-ui-color-background-palette-${_color}-active)`,
396
+ },
397
+ };
398
+ const defaultStyles = {
399
+ filled: {
400
+ '--bcm-chip-bg': 'var(--bcm-ui-color-background-default-default)',
401
+ '--bcm-chip-text': 'var(--bcm-ui-color-text-default)',
402
+ '--bcm-chip-border': 'var(--bcm-ui-color-border-default)',
403
+ '--bcm-chip-hover-bg': 'var(--bcm-ui-color-background-default-hover)',
404
+ '--bcm-chip-active-bg': 'var(--bcm-ui-color-background-default-active)',
405
+ },
406
+ outlined: {
407
+ '--bcm-chip-bg': 'transparent',
408
+ '--bcm-chip-text': 'var(--bcm-ui-color-text-default)',
409
+ '--bcm-chip-border': 'var(--bcm-ui-color-border-default)',
410
+ '--bcm-chip-hover-bg': 'var(--bcm-ui-color-background-default-hover)',
411
+ '--bcm-chip-active-bg': 'var(--bcm-ui-color-background-default-active)',
412
+ },
413
+ text: {
414
+ '--bcm-chip-bg': 'transparent',
415
+ '--bcm-chip-text': 'var(--bcm-ui-color-text-default)',
416
+ '--bcm-chip-border': 'transparent',
417
+ '--bcm-chip-hover-bg': 'var(--bcm-ui-color-background-default-hover)',
418
+ '--bcm-chip-active-bg': 'var(--bcm-ui-color-background-default-active)',
419
+ },
420
+ };
421
+ return _color ? styles[this.kind] : defaultStyles[this.kind];
422
+ }
423
+ handleDismiss() {
424
+ if (!this.disabled) {
425
+ this.bcmDismiss.emit();
426
+ }
427
+ }
428
+ render() {
429
+ return (index.h("div", { key: 'd2692652edd6275d143e7ddffbc789d0b5315027', style: this.chipStyle, class: this.chipClass({ size: this.size, kind: this.kind, disabled: this.disabled }), role: "button", "aria-disabled": this.disabled ? 'true' : 'false' }, index.h("slot", { key: '8d3abf8a40a30dc93003077e52edc81062f10424' }), this.dismissible && index.h("bcm-icon", { key: '9914f1803e5d6feece7221e73b041d46f8237e95', onClick: () => this.handleDismiss(), class: "cursor-pointer", "icon-name": "fa-regular fa-xmark", "aria-label": "Dismiss chip" })));
430
+ }
431
+ };
432
+ BcmChip.style = chipCss;
433
+
434
+ 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)}";
435
+
436
+ const BcmDrawer = class {
437
+ constructor(hostRef) {
438
+ index.registerInstance(this, hostRef);
439
+ this.bcmOpen = index.createEvent(this, "bcmOpen", 7);
440
+ this.bcmClose = index.createEvent(this, "bcmClose", 7);
441
+ this.bcmBeforeOpen = index.createEvent(this, "bcmBeforeOpen", 7);
442
+ this.bcmBeforeClose = index.createEvent(this, "bcmBeforeClose", 7);
443
+ this.open = false;
444
+ this.size = 'medium';
445
+ this.position = 'right';
446
+ this.fullWidth = false;
447
+ this.noHeader = false;
448
+ this.drawerClass = tv.tv({
449
+ slots: {
450
+ backdrop: 'fixed inset-0 bg-color-transparent z-40 transition-opacity duration-300',
451
+ wrapper: 'bcm-ui-element fixed bg-color-base text-color-default z-50 transform transition-transform duration-300 ease-in-out flex flex-col',
452
+ header: 'flex justify-between items-center bg-color-default text-color-default',
453
+ title: 'font-semibold m-0 text-size-6',
454
+ 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',
455
+ content: 'overflow-y-auto flex-grow',
456
+ },
457
+ variants: {
458
+ open: {
459
+ true: {
460
+ backdrop: 'opacity-100 visible',
461
+ },
462
+ false: {
463
+ backdrop: 'opacity-0 invisible',
464
+ },
465
+ },
466
+ position: {
467
+ left: {
468
+ wrapper: 'top-0 left-0 bottom-0',
469
+ },
470
+ right: {
471
+ wrapper: 'top-0 right-0 bottom-0',
472
+ },
473
+ top: {
474
+ wrapper: 'top-0 left-0 right-0',
475
+ },
476
+ bottom: {
477
+ wrapper: 'bottom-0 left-0 right-0',
478
+ },
479
+ },
480
+ size: {
481
+ small: {
482
+ header: 'py-3 px-4',
483
+ content: 'p-4',
484
+ },
485
+ medium: {
486
+ header: 'py-3 px-4',
487
+ content: 'p-4',
488
+ },
489
+ large: {
490
+ header: 'py-3 px-4',
491
+ content: 'p-4',
492
+ },
493
+ },
494
+ noHeader: {
495
+ true: {
496
+ header: 'hidden',
497
+ },
498
+ },
499
+ },
500
+ compoundVariants: [
501
+ {
502
+ open: true,
503
+ position: ['left', 'right'],
504
+ class: {
505
+ wrapper: 'translate-x-0',
506
+ },
507
+ },
508
+ {
509
+ open: true,
510
+ position: ['top', 'bottom'],
511
+ class: {
512
+ wrapper: 'translate-y-0',
513
+ },
514
+ },
515
+ {
516
+ open: false,
517
+ position: 'left',
518
+ class: {
519
+ wrapper: '-translate-x-full',
520
+ },
521
+ },
522
+ {
523
+ open: false,
524
+ position: 'right',
525
+ class: {
526
+ wrapper: 'translate-x-full',
527
+ },
528
+ },
529
+ {
530
+ open: false,
531
+ position: 'top',
532
+ class: {
533
+ wrapper: '-translate-y-full',
534
+ },
535
+ },
536
+ {
537
+ open: false,
538
+ position: 'bottom',
539
+ class: {
540
+ wrapper: 'translate-y-full',
541
+ },
542
+ },
543
+ ],
544
+ });
545
+ }
546
+ handleOpenChange(isOpen) {
547
+ if (isOpen) {
548
+ document.body.style.overflow = 'hidden';
549
+ this.bcmOpen.emit();
550
+ }
551
+ else {
552
+ document.body.style.overflow = '';
553
+ this.bcmClose.emit();
554
+ }
555
+ }
556
+ handleKeyDown(event) {
557
+ if (event.key === 'Escape' && this.open) {
558
+ this.hide();
559
+ }
560
+ }
561
+ async show() {
562
+ const event = this.bcmBeforeOpen.emit();
563
+ if (!event.defaultPrevented) {
564
+ this.open = true;
565
+ }
566
+ }
567
+ async hide() {
568
+ const event = this.bcmBeforeClose.emit();
569
+ if (!event.defaultPrevented) {
570
+ this.open = false;
571
+ }
572
+ }
573
+ disconnectedCallback() {
574
+ document.body.style.overflow = '';
575
+ }
576
+ getWrapperStyle() {
577
+ const style = {};
578
+ if (this.fullWidth) {
579
+ if (this.position === 'left' || this.position === 'right') {
580
+ style.width = '100vw';
581
+ }
582
+ else {
583
+ style.height = '100vh';
584
+ }
585
+ return style;
586
+ }
587
+ if (this.position === 'left' || this.position === 'right') {
588
+ switch (this.size) {
589
+ case 'small':
590
+ style.width = '320px';
591
+ break;
592
+ case 'medium':
593
+ style.width = '480px';
594
+ break;
595
+ case 'large':
596
+ style.width = '1064px';
597
+ break;
598
+ }
599
+ }
600
+ else {
601
+ switch (this.size) {
602
+ case 'small':
603
+ style.height = '40vh';
604
+ break;
605
+ case 'medium':
606
+ style.height = '60vh';
607
+ break;
608
+ case 'large':
609
+ style.height = '90vh';
610
+ break;
611
+ }
612
+ }
613
+ return style;
614
+ }
615
+ render() {
616
+ const { backdrop, wrapper, header, title, closeButton, content } = this.drawerClass({
617
+ open: this.open,
618
+ position: this.position,
619
+ size: this.size,
620
+ noHeader: this.noHeader,
621
+ });
622
+ 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" })))));
623
+ }
624
+ get host() { return index.getElement(this); }
625
+ static get watchers() { return {
626
+ "open": ["handleOpenChange"]
627
+ }; }
628
+ };
629
+ BcmDrawer.style = drawerCss;
630
+
631
+ 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)}";
632
+
633
+ const BcmModal = class {
634
+ constructor(hostRef) {
635
+ index.registerInstance(this, hostRef);
636
+ this.bcmOpen = index.createEvent(this, "bcmOpen", 7);
637
+ this.bcmClose = index.createEvent(this, "bcmClose", 7);
638
+ this.bcmBeforeOpen = index.createEvent(this, "bcmBeforeOpen", 7);
639
+ this.bcmBeforeClose = index.createEvent(this, "bcmBeforeClose", 7);
640
+ this.open = false;
641
+ this.size = 'medium';
642
+ this.placement = 'center';
643
+ this.backdrop = true;
644
+ this.fullWidth = false;
645
+ this.fullScreen = false;
646
+ this.noHeader = false;
647
+ this.noFooter = false;
648
+ this.closeOnBackdrop = true;
649
+ this.closeOnEscape = true;
650
+ this.isAnimating = false;
651
+ this.shake = false;
652
+ this.modalClass = tv.tv({
653
+ slots: {
654
+ 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',
655
+ container: 'fixed inset-0 flex items-start justify-center p-4 overflow-y-auto overscroll-contain',
656
+ modal: 'relative bg-color-basic-base text-color-default rounded-lg shadow-2xl transform transition-all duration-300 ease-in-out flex flex-col',
657
+ header: 'flex justify-between items-start bg-color-base text-color-default border-color-default border-solid border-0 border-b rounded-t-lg',
658
+ headerContent: 'flex-1 min-w-0 flex items-center gap-2',
659
+ title: 'font-semibold m-0 text-size-6 text-color-header',
660
+ helperText: 'text-size-5 text-color-placeholder m-0',
661
+ 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 ',
662
+ content: 'flex-grow overflow-y-auto',
663
+ footer: 'flex items-center justify-end gap-2',
664
+ },
665
+ variants: {
666
+ open: {
667
+ true: {
668
+ modal: 'opacity-100 translate-y-0 scale-100',
669
+ },
670
+ false: {
671
+ modal: 'opacity-0 -translate-y-4 scale-95',
672
+ },
673
+ },
674
+ placement: {
675
+ center: {
676
+ container: 'items-center',
677
+ },
678
+ top: {
679
+ container: 'items-start pt-20',
680
+ },
681
+ },
682
+ size: {
683
+ small: {
684
+ header: 'py-3 px-4',
685
+ content: 'p-4',
686
+ footer: 'py-3 px-4',
687
+ },
688
+ medium: {
689
+ header: 'py-4 px-5',
690
+ content: 'p-5',
691
+ footer: 'py-4 px-5',
692
+ },
693
+ large: {
694
+ header: 'py-4 px-6',
695
+ content: 'p-6',
696
+ footer: 'py-4 px-6',
697
+ },
698
+ xlarge: {
699
+ header: 'py-5 px-6',
700
+ content: 'p-6',
701
+ footer: 'py-5 px-6',
702
+ },
703
+ xxlarge: {
704
+ header: 'py-5 px-8',
705
+ content: 'p-8',
706
+ footer: 'py-5 px-8',
707
+ },
708
+ full: {
709
+ header: 'py-5 px-8',
710
+ content: 'p-8',
711
+ footer: 'py-5 px-8',
712
+ },
713
+ },
714
+ fullScreen: {
715
+ true: {
716
+ modal: 'rounded-none w-screen h-screen max-w-none max-h-none',
717
+ container: 'p-0',
718
+ },
719
+ },
720
+ shake: {
721
+ true: {
722
+ modal: 'animate-shake',
723
+ },
724
+ },
725
+ noHeader: {
726
+ true: {
727
+ header: 'hidden',
728
+ },
729
+ },
730
+ noFooter: {
731
+ true: {
732
+ footer: 'hidden',
733
+ },
734
+ },
735
+ },
736
+ });
737
+ this.handleBackdropClick = (event) => {
738
+ const target = event.target;
739
+ // Check if click is on the container (backdrop area), not on modal content
740
+ if (target.getAttribute('part') === 'container') {
741
+ if (this.backdrop === 'static') {
742
+ this.shakeModal();
743
+ }
744
+ else if (this.closeOnBackdrop) {
745
+ this.hide();
746
+ }
747
+ }
748
+ };
749
+ this.handleDialogCancel = (event) => {
750
+ event.preventDefault();
751
+ if (this.closeOnEscape) {
752
+ if (this.backdrop === 'static') {
753
+ this.shakeModal();
754
+ }
755
+ else {
756
+ this.hide();
757
+ }
758
+ }
759
+ };
760
+ }
761
+ async handleOpenChange(isOpen) {
762
+ if (isOpen) {
763
+ this.isAnimating = true;
764
+ const event = this.bcmBeforeOpen.emit();
765
+ if (event.defaultPrevented) {
766
+ this.open = false;
767
+ return;
768
+ }
769
+ // Use native dialog API with top-layer
770
+ if (this.dialogRef) {
771
+ this.dialogRef.showModal();
772
+ // Small delay for animation
773
+ await new Promise(resolve => setTimeout(resolve, 50));
774
+ this.isAnimating = false;
775
+ this.bcmOpen.emit();
776
+ }
777
+ }
778
+ else {
779
+ this.isAnimating = true;
780
+ const event = this.bcmBeforeClose.emit();
781
+ if (event.defaultPrevented) {
782
+ this.open = true;
783
+ return;
784
+ }
785
+ // Wait for animation before closing
786
+ await new Promise(resolve => setTimeout(resolve, 300));
787
+ if (this.dialogRef) {
788
+ this.dialogRef.close();
789
+ }
790
+ this.isAnimating = false;
791
+ this.bcmClose.emit();
792
+ }
793
+ }
794
+ handleClick(event) {
795
+ // Use composedPath to work with shadow DOM and slots
796
+ const path = event.composedPath();
797
+ const dismissElement = path.find(el => { var _a; return (_a = el.hasAttribute) === null || _a === void 0 ? void 0 : _a.call(el, 'data-dismiss'); });
798
+ const closeModalElement = path.find(el => { var _a; return (_a = el.hasAttribute) === null || _a === void 0 ? void 0 : _a.call(el, 'data-close-modal'); });
799
+ if (dismissElement) {
800
+ this.hide();
801
+ event.preventDefault();
802
+ event.stopPropagation();
803
+ }
804
+ else if (closeModalElement) {
805
+ const modalId = closeModalElement.getAttribute('data-close-modal');
806
+ // If modalId matches this modal's id, close it
807
+ if (!modalId || modalId === this.host.id) {
808
+ this.hide();
809
+ event.preventDefault();
810
+ event.stopPropagation();
811
+ }
812
+ }
813
+ }
814
+ handleKeyDown(event) {
815
+ if (event.key === 'Escape' && this.open) {
816
+ // Only handle ESC if this is the topmost modal
817
+ const openModals = Array.from(document.querySelectorAll('bcm-modal[open]'));
818
+ const topModal = openModals[openModals.length - 1];
819
+ if (topModal !== this.host) {
820
+ return;
821
+ }
822
+ event.preventDefault();
823
+ if (this.closeOnEscape) {
824
+ if (this.backdrop === 'static') {
825
+ this.shakeModal();
826
+ }
827
+ else {
828
+ this.hide();
829
+ }
830
+ }
831
+ else if (this.backdrop === 'static') {
832
+ this.shakeModal();
833
+ }
834
+ }
835
+ }
836
+ async show() {
837
+ this.open = true;
838
+ }
839
+ async hide() {
840
+ this.open = false;
841
+ }
842
+ async toggle() {
843
+ this.open = !this.open;
844
+ }
845
+ shakeModal() {
846
+ this.shake = true;
847
+ setTimeout(() => {
848
+ this.shake = false;
849
+ }, 300);
850
+ }
851
+ getModalStyle() {
852
+ if (this.fullScreen) {
853
+ return {
854
+ width: '100vw',
855
+ height: '100vh',
856
+ maxWidth: 'none',
857
+ maxHeight: 'none',
858
+ };
859
+ }
860
+ if (this.fullWidth) {
861
+ return {
862
+ width: '100%',
863
+ maxWidth: '100%',
864
+ };
865
+ }
866
+ const widths = {
867
+ small: '400px',
868
+ medium: '600px',
869
+ large: '800px',
870
+ xlarge: '1024px',
871
+ xxlarge: '1200px',
872
+ full: '100%',
873
+ };
874
+ return {
875
+ width: widths[this.size],
876
+ maxWidth: this.fullScreen ? 'none' : '90vw',
877
+ maxHeight: this.fullScreen ? 'none' : '90vh',
878
+ };
879
+ }
880
+ componentDidLoad() {
881
+ if (this.open && this.dialogRef) {
882
+ this.dialogRef.showModal();
883
+ }
884
+ }
885
+ disconnectedCallback() {
886
+ if (this.dialogRef && this.open) {
887
+ this.dialogRef.close();
888
+ }
889
+ }
890
+ render() {
891
+ const { dialog, container, modal, header, headerContent, title, helperText, closeButton, content, footer } = this.modalClass({
892
+ open: this.open,
893
+ placement: this.placement,
894
+ size: this.size,
895
+ fullScreen: this.fullScreen,
896
+ shake: this.shake,
897
+ noHeader: this.noHeader,
898
+ noFooter: this.noFooter,
899
+ });
900
+ 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" })))))));
901
+ }
902
+ get host() { return index.getElement(this); }
903
+ static get watchers() { return {
904
+ "open": ["handleOpenChange"]
905
+ }; }
906
+ };
907
+ BcmModal.style = modalCss;
908
+
909
+ exports.bcm_button = BcmButton;
910
+ exports.bcm_chip = BcmChip;
911
+ exports.bcm_drawer = BcmDrawer;
912
+ exports.bcm_modal = BcmModal;
913
+ //# sourceMappingURL=bcm-button.bcm-chip.bcm-drawer.bcm-modal.entry.cjs.js.map
914
+
915
+ //# sourceMappingURL=bcm-button_4.cjs.entry.js.map