bromcom-ui-next 0.1.3 → 0.1.5

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 (272) hide show
  1. package/dist/bromcom-ui/bromcom-ui.css +1 -1
  2. package/dist/bromcom-ui/bromcom-ui.esm.js +1 -1
  3. package/dist/bromcom-ui/bromcom-ui.esm.js.map +1 -1
  4. package/dist/bromcom-ui/global/global.js +14 -15
  5. package/dist/bromcom-ui/{p-b36f4f44.js → p-12360e4c.js} +1 -1
  6. package/dist/bromcom-ui/p-15fe392b.js +3 -0
  7. package/dist/bromcom-ui/p-15fe392b.js.map +1 -0
  8. package/dist/bromcom-ui/p-2bbd3c52.entry.js +2 -0
  9. package/dist/bromcom-ui/p-2bbd3c52.entry.js.map +1 -0
  10. package/dist/bromcom-ui/p-2f1d87a7.entry.js +2 -0
  11. package/dist/bromcom-ui/p-2f1d87a7.entry.js.map +1 -0
  12. package/dist/bromcom-ui/p-31354aaa.js +2 -0
  13. package/dist/bromcom-ui/p-31354aaa.js.map +1 -0
  14. package/dist/bromcom-ui/p-4f402148.entry.js +2 -0
  15. package/dist/bromcom-ui/{p-6430a887.entry.js.map → p-4f402148.entry.js.map} +1 -1
  16. package/dist/bromcom-ui/p-53f21d16.entry.js +2 -0
  17. package/dist/bromcom-ui/{p-dcc13a55.entry.js.map → p-53f21d16.entry.js.map} +1 -1
  18. package/dist/bromcom-ui/p-5737e7de.entry.js +2 -0
  19. package/dist/bromcom-ui/p-5737e7de.entry.js.map +1 -0
  20. package/dist/bromcom-ui/p-5bee2e76.entry.js +2 -0
  21. package/dist/bromcom-ui/{p-bde58312.entry.js.map → p-5bee2e76.entry.js.map} +1 -1
  22. package/dist/bromcom-ui/p-63cb0933.entry.js +2 -0
  23. package/dist/bromcom-ui/p-63cb0933.entry.js.map +1 -0
  24. package/dist/bromcom-ui/p-6abaf96f.entry.js +2 -0
  25. package/dist/bromcom-ui/p-6abaf96f.entry.js.map +1 -0
  26. package/dist/bromcom-ui/p-729a870f.js +2 -0
  27. package/dist/bromcom-ui/p-729a870f.js.map +1 -0
  28. package/dist/bromcom-ui/p-7a1bf6a6.entry.js +2 -0
  29. package/dist/bromcom-ui/p-7a1bf6a6.entry.js.map +1 -0
  30. package/dist/bromcom-ui/p-e08b23ff.entry.js +2 -0
  31. package/dist/bromcom-ui/p-e08b23ff.entry.js.map +1 -0
  32. package/dist/bromcom-ui/p-f0ece968.entry.js +2 -0
  33. package/dist/bromcom-ui/p-f0ece968.entry.js.map +1 -0
  34. package/dist/bromcom-ui/{p-3805363a.entry.js → p-f9eeafa7.entry.js} +2 -2
  35. package/dist/bromcom-ui/{p-3805363a.entry.js.map → p-f9eeafa7.entry.js.map} +1 -1
  36. package/dist/bromcom-ui/styles/theme-variables.ts +369 -0
  37. package/dist/bromcom-ui/styles/themes/index.css +1 -0
  38. package/dist/bromcom-ui/styles/themes/library/default.css +73 -0
  39. package/dist/bromcom-ui/styles/variables/box-shadow.css +15 -0
  40. package/dist/bromcom-ui/styles/variables/colors-dark.css +314 -0
  41. package/dist/bromcom-ui/styles/variables/colors-light.css +325 -0
  42. package/dist/bromcom-ui/styles/variables/font-size-rem.css +33 -0
  43. package/dist/bromcom-ui/styles/variables/font-size.css +33 -0
  44. package/dist/bromcom-ui/styles/variables/index.css +6 -0
  45. package/dist/cjs/app-globals-29edfda4.js +39 -0
  46. package/dist/cjs/app-globals-29edfda4.js.map +1 -0
  47. package/dist/cjs/bcm-accordion-group.cjs.entry.js +3 -3
  48. package/dist/cjs/bcm-accordion-group.cjs.entry.js.map +1 -1
  49. package/dist/cjs/bcm-accordion.cjs.entry.js +7 -7
  50. package/dist/cjs/bcm-accordion.cjs.entry.js.map +1 -1
  51. package/dist/cjs/bcm-alert.cjs.entry.js +2 -2
  52. package/dist/cjs/bcm-alert.cjs.entry.js.map +1 -1
  53. package/dist/cjs/bcm-avatar_4.cjs.entry.js +577 -0
  54. package/dist/cjs/bcm-avatar_4.cjs.entry.js.map +1 -0
  55. package/dist/cjs/bcm-chip.cjs.entry.js +4 -4
  56. package/dist/cjs/bcm-chip.cjs.entry.js.map +1 -1
  57. package/dist/cjs/bcm-divider.cjs.entry.js +81 -0
  58. package/dist/cjs/bcm-divider.cjs.entry.js.map +1 -0
  59. package/dist/cjs/bcm-dropdown-item.cjs.entry.js +63 -0
  60. package/dist/cjs/bcm-dropdown-item.cjs.entry.js.map +1 -0
  61. package/dist/cjs/bcm-dropdown.cjs.entry.js +56 -0
  62. package/dist/cjs/bcm-dropdown.cjs.entry.js.map +1 -0
  63. package/dist/cjs/bcm-input.cjs.entry.js +313 -0
  64. package/dist/cjs/bcm-input.cjs.entry.js.map +1 -0
  65. package/dist/cjs/bcm-linked.cjs.entry.js +1981 -0
  66. package/dist/cjs/bcm-linked.cjs.entry.js.map +1 -0
  67. package/dist/cjs/bcm-text.cjs.entry.js +4 -4
  68. package/dist/cjs/bcm-text.cjs.entry.js.map +1 -1
  69. package/dist/cjs/bcm-textarea.cjs.entry.js +316 -0
  70. package/dist/cjs/bcm-textarea.cjs.entry.js.map +1 -0
  71. package/dist/cjs/bromcom-ui.cjs.js +3 -3
  72. package/dist/cjs/{index-c36002ae.js → index-4795c073.js} +13 -4
  73. package/dist/cjs/index-4795c073.js.map +1 -0
  74. package/dist/{components/p-b36f4f44.js → cjs/index-5a88e57b.js} +5 -3
  75. package/dist/cjs/{index-a4eea4bb.js.map → index-5a88e57b.js.map} +1 -1
  76. package/dist/cjs/loader.cjs.js +3 -3
  77. package/dist/cjs/validation-messages-c36e5c31.js +134 -0
  78. package/dist/cjs/validation-messages-c36e5c31.js.map +1 -0
  79. package/dist/collection/collection-manifest.json +8 -1
  80. package/dist/collection/components/accordion/accordion.component.js +5 -5
  81. package/dist/collection/components/accordion/accordion.component.js.map +1 -1
  82. package/dist/collection/components/accordion/accordion.css +1 -1
  83. package/dist/collection/components/accordion-group/accordion-group.component.js +1 -1
  84. package/dist/collection/components/accordion-group/accordion-group.component.js.map +1 -1
  85. package/dist/collection/components/accordion-group/accordion-group.css +1 -1
  86. package/dist/collection/components/alert/alert.css +1 -1
  87. package/dist/collection/components/avatar/avatar.component.js.map +1 -1
  88. package/dist/collection/components/avatar/avatar.css +1 -1
  89. package/dist/collection/components/badge/badge.component.js +373 -0
  90. package/dist/collection/components/badge/badge.component.js.map +1 -0
  91. package/dist/collection/components/badge/badge.css +1 -0
  92. package/dist/collection/components/basic-badge/basic-badge.component.js +236 -0
  93. package/dist/collection/components/basic-badge/basic-badge.component.js.map +1 -0
  94. package/dist/collection/components/basic-badge/basic-badge.css +1 -0
  95. package/dist/collection/components/button/button.component.js +2 -2
  96. package/dist/collection/components/button/button.css +1 -1
  97. package/dist/collection/components/chip/chip.component.js +2 -2
  98. package/dist/collection/components/chip/chip.component.js.map +1 -1
  99. package/dist/collection/components/chip/chip.css +1 -1
  100. package/dist/collection/components/divider/divider.component.js +190 -0
  101. package/dist/collection/components/divider/divider.component.js.map +1 -0
  102. package/dist/collection/components/divider/divider.css +1 -0
  103. package/dist/collection/components/dropdown/dropdown.component.js +110 -0
  104. package/dist/collection/components/dropdown/dropdown.component.js.map +1 -0
  105. package/dist/collection/components/dropdown/dropdown.css +1 -0
  106. package/dist/collection/components/dropdown-item/dropdown-item.component.js +198 -0
  107. package/dist/collection/components/dropdown-item/dropdown-item.component.js.map +1 -0
  108. package/dist/collection/components/dropdown-item/dropdown-item.css +1 -0
  109. package/dist/collection/components/input/input.component.js +209 -24
  110. package/dist/collection/components/input/input.component.js.map +1 -1
  111. package/dist/collection/components/input/input.css +1 -1
  112. package/dist/collection/components/input/types.js +10 -1
  113. package/dist/collection/components/input/types.js.map +1 -1
  114. package/dist/collection/components/linked/linked.component.js +140 -0
  115. package/dist/collection/components/linked/linked.component.js.map +1 -0
  116. package/dist/collection/components/linked/linked.css +1 -0
  117. package/dist/collection/components/text/text.component.js +1 -1
  118. package/dist/collection/components/text/text.css +1 -1
  119. package/dist/collection/components/textarea/textarea.component.js +1013 -0
  120. package/dist/collection/components/textarea/textarea.component.js.map +1 -0
  121. package/dist/collection/components/textarea/textarea.css +2 -0
  122. package/dist/collection/components/textarea/types.js +2 -0
  123. package/dist/collection/components/textarea/types.js.map +1 -0
  124. package/dist/collection/global/global.js +14 -15
  125. package/dist/collection/styles/theme-variables.js +15 -0
  126. package/dist/collection/styles/theme-variables.js.map +1 -1
  127. package/dist/collection/styles/theme-variables.ts +369 -0
  128. package/dist/collection/styles/themes/index.css +1 -0
  129. package/dist/collection/styles/themes/library/default.css +73 -0
  130. package/dist/collection/styles/variables/box-shadow.css +15 -0
  131. package/dist/collection/styles/variables/colors-dark.css +314 -0
  132. package/dist/collection/styles/variables/colors-light.css +325 -0
  133. package/dist/collection/styles/variables/font-size-rem.css +33 -0
  134. package/dist/collection/styles/variables/font-size.css +33 -0
  135. package/dist/collection/styles/variables/index.css +6 -0
  136. package/dist/collection/utils/i18n.js +29 -0
  137. package/dist/collection/utils/i18n.js.map +1 -0
  138. package/dist/collection/utils/slot/check-slot-content.js +15 -0
  139. package/dist/collection/utils/slot/check-slot-content.js.map +1 -0
  140. package/dist/collection/utils/validation-messages.js +17 -0
  141. package/dist/collection/utils/validation-messages.js.map +1 -0
  142. package/dist/components/bcm-accordion-group.js +3 -3
  143. package/dist/components/bcm-accordion-group.js.map +1 -1
  144. package/dist/components/bcm-accordion.js +7 -7
  145. package/dist/components/bcm-accordion.js.map +1 -1
  146. package/dist/components/bcm-alert.js +2 -2
  147. package/dist/components/bcm-alert.js.map +1 -1
  148. package/dist/components/bcm-avatar.js +13 -7
  149. package/dist/components/bcm-avatar.js.map +1 -1
  150. package/dist/components/bcm-badge.d.ts +11 -0
  151. package/dist/components/bcm-badge.js +8 -0
  152. package/dist/components/bcm-badge.js.map +1 -0
  153. package/dist/components/bcm-basic-badge.d.ts +11 -0
  154. package/dist/components/bcm-basic-badge.js +113 -0
  155. package/dist/components/bcm-basic-badge.js.map +1 -0
  156. package/dist/components/bcm-button.js +1 -327
  157. package/dist/components/bcm-button.js.map +1 -1
  158. package/dist/components/bcm-chip.js +4 -4
  159. package/dist/components/bcm-chip.js.map +1 -1
  160. package/dist/components/bcm-divider.d.ts +11 -0
  161. package/dist/components/bcm-divider.js +100 -0
  162. package/dist/components/bcm-divider.js.map +1 -0
  163. package/dist/components/bcm-dropdown-item.d.ts +11 -0
  164. package/dist/components/bcm-dropdown-item.js +85 -0
  165. package/dist/components/bcm-dropdown-item.js.map +1 -0
  166. package/dist/components/bcm-dropdown.d.ts +11 -0
  167. package/dist/components/bcm-dropdown.js +87 -0
  168. package/dist/components/bcm-dropdown.js.map +1 -0
  169. package/dist/components/bcm-input.js +168 -105
  170. package/dist/components/bcm-input.js.map +1 -1
  171. package/dist/components/bcm-linked.d.ts +11 -0
  172. package/dist/components/bcm-linked.js +8 -0
  173. package/dist/components/bcm-linked.js.map +1 -0
  174. package/dist/components/bcm-text.js +4 -4
  175. package/dist/components/bcm-text.js.map +1 -1
  176. package/dist/components/bcm-textarea.d.ts +11 -0
  177. package/dist/components/bcm-textarea.js +369 -0
  178. package/dist/components/bcm-textarea.js.map +1 -0
  179. package/dist/components/index.js +12 -16
  180. package/dist/components/index.js.map +1 -1
  181. package/dist/components/p-0063a3d9.js +331 -0
  182. package/dist/components/p-0063a3d9.js.map +1 -0
  183. package/dist/{esm/index-f0e9d579.js → components/p-12360e4c.js} +3 -3
  184. package/dist/components/{p-b36f4f44.js.map → p-12360e4c.js.map} +1 -1
  185. package/dist/components/{p-8ded2c73.js → p-13582168.js} +10 -2
  186. package/dist/components/p-13582168.js.map +1 -0
  187. package/dist/components/p-31354aaa.js +129 -0
  188. package/dist/components/p-31354aaa.js.map +1 -0
  189. package/dist/components/p-613ee92d.js +1997 -0
  190. package/dist/components/p-613ee92d.js.map +1 -0
  191. package/dist/components/p-e918f815.js +145 -0
  192. package/dist/components/p-e918f815.js.map +1 -0
  193. package/dist/esm/app-globals-bfa07b76.js +37 -0
  194. package/dist/esm/app-globals-bfa07b76.js.map +1 -0
  195. package/dist/esm/bcm-accordion-group.entry.js +3 -3
  196. package/dist/esm/bcm-accordion-group.entry.js.map +1 -1
  197. package/dist/esm/bcm-accordion.entry.js +7 -7
  198. package/dist/esm/bcm-accordion.entry.js.map +1 -1
  199. package/dist/esm/bcm-alert.entry.js +2 -2
  200. package/dist/esm/bcm-alert.entry.js.map +1 -1
  201. package/dist/esm/bcm-avatar_4.entry.js +570 -0
  202. package/dist/esm/bcm-avatar_4.entry.js.map +1 -0
  203. package/dist/esm/bcm-chip.entry.js +4 -4
  204. package/dist/esm/bcm-chip.entry.js.map +1 -1
  205. package/dist/esm/bcm-divider.entry.js +77 -0
  206. package/dist/esm/bcm-divider.entry.js.map +1 -0
  207. package/dist/esm/bcm-dropdown-item.entry.js +59 -0
  208. package/dist/esm/bcm-dropdown-item.entry.js.map +1 -0
  209. package/dist/esm/bcm-dropdown.entry.js +52 -0
  210. package/dist/esm/bcm-dropdown.entry.js.map +1 -0
  211. package/dist/esm/bcm-input.entry.js +309 -0
  212. package/dist/esm/bcm-input.entry.js.map +1 -0
  213. package/dist/esm/bcm-linked.entry.js +1977 -0
  214. package/dist/esm/bcm-linked.entry.js.map +1 -0
  215. package/dist/esm/bcm-text.entry.js +4 -4
  216. package/dist/esm/bcm-text.entry.js.map +1 -1
  217. package/dist/esm/bcm-textarea.entry.js +312 -0
  218. package/dist/esm/bcm-textarea.entry.js.map +1 -0
  219. package/dist/esm/bromcom-ui.js +4 -4
  220. package/dist/{cjs/index-a4eea4bb.js → esm/index-097075ad.js} +3 -5
  221. package/dist/esm/{index-f0e9d579.js.map → index-097075ad.js.map} +1 -1
  222. package/dist/esm/{index-e23ee9b0.js → index-27cc1bac.js} +13 -4
  223. package/dist/esm/index-27cc1bac.js.map +1 -0
  224. package/dist/esm/loader.js +4 -4
  225. package/dist/esm/validation-messages-a29d53be.js +129 -0
  226. package/dist/esm/validation-messages-a29d53be.js.map +1 -0
  227. package/dist/tailwind.config.js +32 -0
  228. package/dist/types/components/badge/badge.component.d.ts +87 -0
  229. package/dist/types/components/basic-badge/basic-badge.component.d.ts +54 -0
  230. package/dist/types/components/divider/divider.component.d.ts +40 -0
  231. package/dist/types/components/dropdown/dropdown.component.d.ts +14 -0
  232. package/dist/types/components/dropdown-item/dropdown-item.component.d.ts +14 -0
  233. package/dist/types/components/input/input.component.d.ts +19 -0
  234. package/dist/types/components/input/types.d.ts +10 -0
  235. package/dist/types/components/linked/linked.component.d.ts +16 -0
  236. package/dist/types/components/textarea/textarea.component.d.ts +85 -0
  237. package/dist/types/components/textarea/types.d.ts +7 -0
  238. package/dist/types/components.d.ts +732 -0
  239. package/dist/types/styles/theme-variables.d.ts +15 -0
  240. package/dist/types/utils/i18n.d.ts +8 -0
  241. package/dist/types/utils/slot/check-slot-content.d.ts +7 -0
  242. package/dist/types/utils/validation-messages.d.ts +11 -0
  243. package/package.json +2 -1
  244. package/dist/bromcom-ui/p-047e562f.entry.js +0 -2
  245. package/dist/bromcom-ui/p-047e562f.entry.js.map +0 -1
  246. package/dist/bromcom-ui/p-40643b53.js +0 -2
  247. package/dist/bromcom-ui/p-40643b53.js.map +0 -1
  248. package/dist/bromcom-ui/p-61c030c5.js +0 -3
  249. package/dist/bromcom-ui/p-61c030c5.js.map +0 -1
  250. package/dist/bromcom-ui/p-6430a887.entry.js +0 -2
  251. package/dist/bromcom-ui/p-9e94d920.entry.js +0 -2
  252. package/dist/bromcom-ui/p-9e94d920.entry.js.map +0 -1
  253. package/dist/bromcom-ui/p-bde58312.entry.js +0 -2
  254. package/dist/bromcom-ui/p-dcc13a55.entry.js +0 -2
  255. package/dist/bromcom-ui/p-e7732b0c.entry.js +0 -2
  256. package/dist/bromcom-ui/p-e7732b0c.entry.js.map +0 -1
  257. package/dist/cjs/app-globals-e8faea0d.js +0 -43
  258. package/dist/cjs/app-globals-e8faea0d.js.map +0 -1
  259. package/dist/cjs/bcm-avatar.cjs.entry.js +0 -89
  260. package/dist/cjs/bcm-avatar.cjs.entry.js.map +0 -1
  261. package/dist/cjs/bcm-button_2.cjs.entry.js +0 -549
  262. package/dist/cjs/bcm-button_2.cjs.entry.js.map +0 -1
  263. package/dist/cjs/index-c36002ae.js.map +0 -1
  264. package/dist/components/p-8ded2c73.js.map +0 -1
  265. package/dist/esm/app-globals-f781c325.js +0 -41
  266. package/dist/esm/app-globals-f781c325.js.map +0 -1
  267. package/dist/esm/bcm-avatar.entry.js +0 -85
  268. package/dist/esm/bcm-avatar.entry.js.map +0 -1
  269. package/dist/esm/bcm-button_2.entry.js +0 -544
  270. package/dist/esm/bcm-button_2.entry.js.map +0 -1
  271. package/dist/esm/index-e23ee9b0.js.map +0 -1
  272. /package/dist/bromcom-ui/{p-b36f4f44.js.map → p-12360e4c.js.map} +0 -0
@@ -0,0 +1,100 @@
1
+ import { p as proxyCustomElement, H, h } from './p-13582168.js';
2
+ import { c as ce } from './p-5fcf77f9.js';
3
+
4
+ const dividerCss = ".block{display:block}:host{--bcm-divider-border:var(--bcm-ui-color-border-default);display:block}.static{position:static}.h-full{height:100%}.w-full{width:100%}.border{border-width:1px}.border-2{border-width:2px}.border-4{border-width:4px}.border-\\[1px\\]{border-width:1px}.border-l{border-left-width:1px}.border-t{border-top-width:1px}.border-solid{border-style:solid}.border-dashed{border-style:dashed}.border-dotted{border-style:dotted}.border-\\[--bcm-divider-border\\]{border-color:var(--bcm-divider-border)}.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)}";
5
+ const BcmDividerStyle0 = dividerCss;
6
+
7
+ const Divider = /*@__PURE__*/ proxyCustomElement(class Divider extends H {
8
+ constructor() {
9
+ super();
10
+ this.__registerHost();
11
+ this.__attachShadow();
12
+ /**
13
+ * @prop {('horizontal'|'vertical')} direction
14
+ * @description Determines the orientation of the divider
15
+ * @default 'horizontal'
16
+ * @example
17
+ * <bcm-divider direction="vertical" />
18
+ */
19
+ this.direction = 'horizontal';
20
+ /**
21
+ * @prop {('solid'|'dashed'|'dotted')} variant
22
+ * @description Sets the border style of the divider
23
+ * @default 'solid'
24
+ * @example
25
+ * <bcm-divider variant="dashed" />
26
+ */
27
+ this.variant = 'solid';
28
+ /**
29
+ * @prop {('small'|'medium'|'large')} size
30
+ * @description Controls the thickness of the divider
31
+ * @default 'medium'
32
+ * @values
33
+ * - small: 1px border
34
+ * - medium: 2px border
35
+ * - large: 4px border
36
+ * @example
37
+ * <bcm-divider size="large" />
38
+ */
39
+ this.size = 'medium';
40
+ this.dividerClass = ce({
41
+ base: 'border-[--bcm-divider-border]',
42
+ variants: {
43
+ direction: {
44
+ horizontal: 'w-full border-t',
45
+ vertical: 'h-full border-l',
46
+ },
47
+ variant: {
48
+ solid: 'border-solid',
49
+ dashed: 'border-dashed',
50
+ dotted: 'border-dotted',
51
+ },
52
+ size: {
53
+ small: 'border-[1px]',
54
+ medium: 'border-2',
55
+ large: 'border-4',
56
+ },
57
+ },
58
+ defaultVariants: {
59
+ direction: 'horizontal',
60
+ variant: 'solid',
61
+ size: 'medium',
62
+ },
63
+ }, {
64
+ twMerge: false,
65
+ });
66
+ }
67
+ render() {
68
+ return (h("div", { key: '92fe4c3cf2ae2824759a643912fcbb9bc7e426f8', role: "separator", "aria-orientation": this.direction, class: this.dividerClass({
69
+ direction: this.direction,
70
+ variant: this.variant,
71
+ size: this.size,
72
+ }) }));
73
+ }
74
+ static get style() { return BcmDividerStyle0; }
75
+ }, [1, "bcm-divider", {
76
+ "direction": [1],
77
+ "variant": [1],
78
+ "size": [1]
79
+ }]);
80
+ function defineCustomElement$1() {
81
+ if (typeof customElements === "undefined") {
82
+ return;
83
+ }
84
+ const components = ["bcm-divider"];
85
+ components.forEach(tagName => { switch (tagName) {
86
+ case "bcm-divider":
87
+ if (!customElements.get(tagName)) {
88
+ customElements.define(tagName, Divider);
89
+ }
90
+ break;
91
+ } });
92
+ }
93
+ defineCustomElement$1();
94
+
95
+ const BcmDivider = Divider;
96
+ const defineCustomElement = defineCustomElement$1;
97
+
98
+ export { BcmDivider, defineCustomElement };
99
+
100
+ //# sourceMappingURL=bcm-divider.js.map
@@ -0,0 +1 @@
1
+ {"file":"bcm-divider.js","mappings":";;;AAAA,MAAM,UAAU,GAAG,itBAAitB,CAAC;AACruB,yBAAe,UAAU;;MCcZ,OAAO;IALpB;;;;;;;;;;;QAcI,cAAS,GAA8B,YAAY,CAAC;;;;;;;;QAUpD,YAAO,GAAkC,OAAO,CAAC;;;;;;;;;;;;QAcjD,SAAI,GAAiC,QAAQ,CAAC;QAEtC,iBAAY,GAAGA,EAAE,CACrB;YACI,IAAI,EAAE,+BAA+B;YACrC,QAAQ,EAAE;gBACN,SAAS,EAAE;oBACP,UAAU,EAAE,iBAAiB;oBAC7B,QAAQ,EAAE,iBAAiB;iBAC9B;gBACD,OAAO,EAAE;oBACL,KAAK,EAAE,cAAc;oBACrB,MAAM,EAAE,eAAe;oBACvB,MAAM,EAAE,eAAe;iBAC1B;gBACD,IAAI,EAAE;oBACF,KAAK,EAAE,cAAc;oBACrB,MAAM,EAAE,UAAU;oBAClB,KAAK,EAAE,UAAU;iBACpB;aACJ;YACD,eAAe,EAAE;gBACb,SAAS,EAAE,YAAY;gBACvB,OAAO,EAAE,OAAO;gBAChB,IAAI,EAAE,QAAQ;aACjB;SACJ,EACD;YACI,OAAO,EAAE,KAAK;SACjB,CACJ,CAAC;KAeL;IAbG,MAAM;QACF,QACI,4DACI,IAAI,EAAC,WAAW,sBACE,IAAI,CAAC,SAAS,EAChC,KAAK,EAAE,IAAI,CAAC,YAAY,CAAC;gBACrB,SAAS,EAAE,IAAI,CAAC,SAAS;gBACzB,OAAO,EAAE,IAAI,CAAC,OAAO;gBACrB,IAAI,EAAE,IAAI,CAAC,IAAI;aAClB,CAAC,GACC,EACT;KACL;;;;;;;;;;;;;;;;;;;;;;;;;;;","names":["tv"],"sources":["src/components/divider/divider.css?tag=bcm-divider&encapsulation=shadow","src/components/divider/divider.component.tsx"],"sourcesContent":[":host {\n display: block;\n --bcm-divider-border: var(--bcm-ui-color-border-default);\n}\n","import { Component, ComponentInterface, Prop, h } from '@stencil/core';\nimport { tv } from 'tailwind-variants';\n\n/**\n * @component BCM Divider\n * @description\n * A versatile divider component that creates a visual separation between content.\n * It supports horizontal or vertical orientation with customizable styles and sizes.\n * The component uses CSS variables for theming and Tailwind for styling.\n */\n@Component({\n tag: 'bcm-divider',\n styleUrl: 'divider.css',\n shadow: true,\n})\nexport class Divider implements ComponentInterface {\n /**\n * @prop {('horizontal'|'vertical')} direction\n * @description Determines the orientation of the divider\n * @default 'horizontal'\n * @example\n * <bcm-divider direction=\"vertical\" />\n */\n @Prop()\n direction: 'horizontal' | 'vertical' = 'horizontal';\n\n /**\n * @prop {('solid'|'dashed'|'dotted')} variant\n * @description Sets the border style of the divider\n * @default 'solid'\n * @example\n * <bcm-divider variant=\"dashed\" />\n */\n @Prop()\n variant: 'solid' | 'dashed' | 'dotted' = 'solid';\n\n /**\n * @prop {('small'|'medium'|'large')} size\n * @description Controls the thickness of the divider\n * @default 'medium'\n * @values\n * - small: 1px border\n * - medium: 2px border\n * - large: 4px border\n * @example\n * <bcm-divider size=\"large\" />\n */\n @Prop()\n size: 'small' | 'medium' | 'large' = 'medium';\n\n private dividerClass = tv(\n {\n base: 'border-[--bcm-divider-border]',\n variants: {\n direction: {\n horizontal: 'w-full border-t',\n vertical: 'h-full border-l',\n },\n variant: {\n solid: 'border-solid',\n dashed: 'border-dashed',\n dotted: 'border-dotted',\n },\n size: {\n small: 'border-[1px]',\n medium: 'border-2',\n large: 'border-4',\n },\n },\n defaultVariants: {\n direction: 'horizontal',\n variant: 'solid',\n size: 'medium',\n },\n },\n {\n twMerge: false,\n },\n );\n\n render() {\n return (\n <div\n role=\"separator\"\n aria-orientation={this.direction}\n class={this.dividerClass({\n direction: this.direction,\n variant: this.variant,\n size: this.size,\n })}\n ></div>\n );\n }\n}\n"],"version":3}
@@ -0,0 +1,11 @@
1
+ import type { Components, JSX } from "../types/components";
2
+
3
+ interface BcmDropdownItem extends Components.BcmDropdownItem, HTMLElement {}
4
+ export const BcmDropdownItem: {
5
+ prototype: BcmDropdownItem;
6
+ new (): BcmDropdownItem;
7
+ };
8
+ /**
9
+ * Used to define this component and all nested components recursively.
10
+ */
11
+ export const defineCustomElement: () => void;
@@ -0,0 +1,85 @@
1
+ import { p as proxyCustomElement, H, c as createEvent, h } from './p-13582168.js';
2
+ import { c as ce } from './p-5fcf77f9.js';
3
+
4
+ const dropdownItemCss = ".flex{display:flex}:host{display:inline-block;width:100%}::slotted([slot=left-content]){align-items:center;display:flex;flex-direction:row;gap:8px}::slotted([slot=right-content]){align-items:center;display:flex;flex-direction:row;gap:8px}.bcm-ui-element{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,sans-serif}.static{position:static}.w-full{width:100%}.cursor-pointer{cursor:pointer}.flex-row{flex-direction:row}.gap-2{gap:.5rem}.text-pretty{text-wrap:pretty}.bg-\\[var\\(--bcm-ui-color-background-base-active\\)\\]{background-color:var(--bcm-ui-color-background-base-active)}.bg-\\[var\\(--bcm-ui-color-background-palette-red-default\\)\\]{background-color:var(--bcm-ui-color-background-palette-red-default)}.px-4{padding-left:1rem;padding-right:1rem}.py-2{padding-bottom:.5rem;padding-top:.5rem}.text-color{color:var(--bcm-ui-color-text-default)}.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-\\[var\\(--bcm-ui-color-background-base-active\\)\\]:hover{background-color:var(--bcm-ui-color-background-base-active)}.hover\\:bg-\\[var\\(--bcm-ui-color-background-base-hover\\)\\]:hover{background-color:var(--bcm-ui-color-background-base-hover)}.hover\\:bg-\\[var\\(--bcm-ui-color-background-palette-red-default\\)\\]:hover{background-color:var(--bcm-ui-color-background-palette-red-default)}";
5
+ const BcmDropdownItemStyle0 = dropdownItemCss;
6
+
7
+ const DropdownItem = /*@__PURE__*/ proxyCustomElement(class DropdownItem extends H {
8
+ constructor() {
9
+ super();
10
+ this.__registerHost();
11
+ this.__attachShadow();
12
+ this.bcmDropDownItemChange = createEvent(this, "bcmDropDownItemChange", 1);
13
+ this.selected = false;
14
+ this.error = false;
15
+ this.disabled = false;
16
+ this.dropdownItemClass = ce({
17
+ base: 'dropdown-item bcm-ui-element bcm-ui-content-display flex flex-row gap-2 py-2 px-4 cursor-pointer text-color',
18
+ variants: {
19
+ selected: {
20
+ true: 'bg-[var(--bcm-ui-color-background-base-active)] hover:bg-[var(--bcm-ui-color-background-base-active)]',
21
+ false: 'hover:bg-[var(--bcm-ui-color-background-base-hover)]',
22
+ },
23
+ error: {
24
+ true: 'bg-[var(--bcm-ui-color-background-palette-red-default)] hover:bg-[var(--bcm-ui-color-background-palette-red-default)]',
25
+ false: '',
26
+ },
27
+ disabled: {
28
+ true: '', // should be discuss with ux team
29
+ false: '',
30
+ },
31
+ },
32
+ defaultVariants: {
33
+ selected: false,
34
+ error: false,
35
+ disabled: false,
36
+ },
37
+ }, {
38
+ twMerge: false,
39
+ });
40
+ }
41
+ handleClick() {
42
+ this.selected = true;
43
+ this.bcmDropDownItemChange.emit({
44
+ element: this.host,
45
+ selected: this.selected,
46
+ });
47
+ }
48
+ render() {
49
+ var _a;
50
+ return (h("div", { key: '5fc499042cd981b6edfe3f44550cf198c49af57a', "aria-checked": this.selected, class: this.dropdownItemClass({
51
+ selected: this.selected,
52
+ error: this.error,
53
+ }), onClick: () => this.handleClick() }, h("slot", { key: 'd071c2f932538bfac7db4ba8b2814737f8564d86', name: "left-content" }, this.icon && h("bcm-icon", { key: 'a56ca3229b08765f10b792b0aaa850e15ab6a233', "icon-name": this.icon })), h("div", { key: '69c25567202874fb152f0b01205c79a14f9bb534', class: "flex flex-row text-pretty w-full" }, h("slot", { key: 'be46aaf4103f9d9a1f7c1951cabb7523b97a3004' }, this.text)), h("slot", { key: '91067b0910f89d6a77b135c36990ecc14d5b97fe', name: "right-content" }, (_a = this.rightIcons) === null || _a === void 0 ? void 0 : _a.map(icon => (h("bcm-icon", { "icon-name": icon }))))));
54
+ }
55
+ get host() { return this; }
56
+ static get style() { return BcmDropdownItemStyle0; }
57
+ }, [1, "bcm-dropdown-item", {
58
+ "text": [1],
59
+ "icon": [1],
60
+ "rightIcons": [16],
61
+ "selected": [516],
62
+ "error": [516],
63
+ "disabled": [516]
64
+ }]);
65
+ function defineCustomElement$1() {
66
+ if (typeof customElements === "undefined") {
67
+ return;
68
+ }
69
+ const components = ["bcm-dropdown-item"];
70
+ components.forEach(tagName => { switch (tagName) {
71
+ case "bcm-dropdown-item":
72
+ if (!customElements.get(tagName)) {
73
+ customElements.define(tagName, DropdownItem);
74
+ }
75
+ break;
76
+ } });
77
+ }
78
+ defineCustomElement$1();
79
+
80
+ const BcmDropdownItem = DropdownItem;
81
+ const defineCustomElement = defineCustomElement$1;
82
+
83
+ export { BcmDropdownItem, defineCustomElement };
84
+
85
+ //# sourceMappingURL=bcm-dropdown-item.js.map
@@ -0,0 +1 @@
1
+ {"file":"bcm-dropdown-item.js","mappings":";;;AAAA,MAAM,eAAe,GAAG,i+CAAi+C,CAAC;AAC1/C,8BAAe,eAAe;;MCOjB,YAAY;IALzB;;;;;QAU6B,aAAQ,GAAY,KAAK,CAAC;QAC1B,UAAK,GAAY,KAAK,CAAC;QACvB,aAAQ,GAAY,KAAK,CAAC;QAmB3C,sBAAiB,GAAGA,EAAE,CAC1B;YACI,IAAI,EAAE,6GAA6G;YACnH,QAAQ,EAAE;gBACN,QAAQ,EAAE;oBACN,IAAI,EAAE,uGAAuG;oBAC7G,KAAK,EAAE,sDAAsD;iBAChE;gBACD,KAAK,EAAE;oBACH,IAAI,EAAE,uHAAuH;oBAC7H,KAAK,EAAE,EAAE;iBACZ;gBACD,QAAQ,EAAE;oBACN,IAAI,EAAE,EAAE;oBACR,KAAK,EAAE,EAAE;iBACZ;aACJ;YACD,eAAe,EAAE;gBACb,QAAQ,EAAE,KAAK;gBACf,KAAK,EAAE,KAAK;gBACZ,QAAQ,EAAE,KAAK;aAClB;SACJ,EACD;YACI,OAAO,EAAE,KAAK;SACjB,CACJ,CAAC;KAwBL;IA1DW,WAAW;QACf,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACrB,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC;YAC5B,OAAO,EAAE,IAAI,CAAC,IAAI;YAClB,QAAQ,EAAE,IAAI,CAAC,QAAQ;SAC1B,CAAC,CAAC;KACN;IA8BD,MAAM;;QACF,QACI,4EACkB,IAAI,CAAC,QAAQ,EAC3B,KAAK,EAAE,IAAI,CAAC,iBAAiB,CAAC;gBAC1B,QAAQ,EAAE,IAAI,CAAC,QAAQ;gBACvB,KAAK,EAAE,IAAI,CAAC,KAAK;aACpB,CAAC,EACF,OAAO,EAAE,MAAM,IAAI,CAAC,WAAW,EAAE,IAEjC,6DAAM,IAAI,EAAC,cAAc,IAAE,IAAI,CAAC,IAAI,IAAI,8EAAqB,IAAI,CAAC,IAAI,GAAa,CAAQ,EAC3F,4DAAK,KAAK,EAAC,kCAAkC,IACzC,+DAAO,IAAI,CAAC,IAAI,CAAQ,CACtB,EACN,6DAAM,IAAI,EAAC,eAAe,IACrB,MAAA,IAAI,CAAC,UAAU,0CAAE,GAAG,CAAC,IAAI,KACtB,6BAAqB,IAAI,GAAa,CACzC,CAAC,CACC,CACL,EACR;KACL;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","names":["tv"],"sources":["src/components/dropdown-item/dropdown-item.css?tag=bcm-dropdown-item&encapsulation=shadow","src/components/dropdown-item/dropdown-item.component.tsx"],"sourcesContent":[":host {\n display: inline-block;\n width: 100%;\n}\n\n::slotted([slot='left-content']) {\n display: flex;\n flex-direction: row;\n align-items: center;\n gap: 8px;\n}\n\n::slotted([slot='right-content']) {\n display: flex;\n flex-direction: row;\n align-items: center;\n gap: 8px;\n}\n","import { Component, ComponentInterface, h, Prop, Event, EventEmitter, Element } from '@stencil/core';\nimport { tv } from 'tailwind-variants';\n\n@Component({\n tag: 'bcm-dropdown-item',\n styleUrl: 'dropdown-item.css',\n shadow: true,\n})\nexport class DropdownItem implements ComponentInterface {\n @Element() host: HTMLElement;\n @Prop() text: string;\n @Prop() icon: string;\n @Prop() rightIcons: string[];\n @Prop({ reflect: true }) selected: boolean = false;\n @Prop({ reflect: true }) error: boolean = false;\n @Prop({ reflect: true }) disabled: boolean = false;\n\n @Event({\n composed: false,\n bubbles: false,\n cancelable: true,\n eventName: 'bcmDropDownItemChange',\n })\n bcmDropDownItemChange: EventEmitter<any>;\n\n\n private handleClick() {\n this.selected = true;\n this.bcmDropDownItemChange.emit({\n element: this.host,\n selected: this.selected,\n });\n }\n\n private dropdownItemClass = tv(\n {\n base: 'dropdown-item bcm-ui-element bcm-ui-content-display flex flex-row gap-2 py-2 px-4 cursor-pointer text-color',\n variants: {\n selected: {\n true: 'bg-[var(--bcm-ui-color-background-base-active)] hover:bg-[var(--bcm-ui-color-background-base-active)]',\n false: 'hover:bg-[var(--bcm-ui-color-background-base-hover)]',\n },\n error: {\n true: 'bg-[var(--bcm-ui-color-background-palette-red-default)] hover:bg-[var(--bcm-ui-color-background-palette-red-default)]',\n false: '',\n },\n disabled: {\n true: '', // should be discuss with ux team\n false: '',\n },\n },\n defaultVariants: {\n selected: false,\n error: false,\n disabled: false,\n },\n },\n {\n twMerge: false,\n },\n );\n\n render() {\n return (\n <div\n aria-checked={this.selected}\n class={this.dropdownItemClass({\n selected: this.selected,\n error: this.error,\n })}\n onClick={() => this.handleClick()}\n >\n <slot name=\"left-content\">{this.icon && <bcm-icon icon-name={this.icon}></bcm-icon>}</slot>\n <div class=\"flex flex-row text-pretty w-full\">\n <slot>{this.text}</slot>\n </div>\n <slot name=\"right-content\">\n {this.rightIcons?.map(icon => (\n <bcm-icon icon-name={icon}></bcm-icon>\n ))}\n </slot>\n </div>\n );\n }\n}\n"],"version":3}
@@ -0,0 +1,11 @@
1
+ import type { Components, JSX } from "../types/components";
2
+
3
+ interface BcmDropdown extends Components.BcmDropdown, HTMLElement {}
4
+ export const BcmDropdown: {
5
+ prototype: BcmDropdown;
6
+ new (): BcmDropdown;
7
+ };
8
+ /**
9
+ * Used to define this component and all nested components recursively.
10
+ */
11
+ export const defineCustomElement: () => void;
@@ -0,0 +1,87 @@
1
+ import { p as proxyCustomElement, H, c as createEvent, h, d as Host } from './p-13582168.js';
2
+ import { c as ce } from './p-5fcf77f9.js';
3
+ import { d as defineCustomElement$3 } from './p-0063a3d9.js';
4
+ import { d as defineCustomElement$2 } from './p-613ee92d.js';
5
+
6
+ const dropdownCss = ".visible{visibility:visible}.hidden{display:none}:host{--dropdown-box-min-weight:32px;--dropdown-box-max-width:384px;--dropdown-box-max-height:384px;--dropdown-box-background-color:var(\"--bcm-ui-color-background-base-default\")}.scroll{height:140px;overflow-y:auto;width:140px}.scroll:active::-webkit-scrollbar-thumb,.scroll:focus::-webkit-scrollbar-thumb,.scroll:hover::-webkit-scrollbar-thumb{visibility:visible}.scroll::-webkit-scrollbar-thumb{background-color:#a9a9a9;visibility:hidden}.scroll::-webkit-scrollbar{height:8px;width:8px}.static{position:static}.flex{display:flex}.max-h-\\[--dropdown-box-max-height\\]{max-height:var(--dropdown-box-max-height)}.w-full{width:100%}.min-w-\\[--dropdown-box-min-weight\\]{min-width:var(--dropdown-box-min-weight)}.max-w-\\[--dropdown-box-max-weight\\]{max-width:var(--dropdown-box-max-weight)}.flex-col{flex-direction:column}.items-center{align-items:center}.rounded-lg{border-radius:.5rem}.bg-\\[--dropdown-box-background-color\\]{background-color:var(--dropdown-box-background-color)}.py-1\\.5{padding-bottom:.375rem;padding-top:.375rem}.shadow{--tw-shadow:var(--bcm-ui-box-shadow-default);--tw-shadow-colored:var(--bcm-ui-box-shadow-default)}.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)}.outline{outline-style:solid}";
7
+ const BcmDropdownStyle0 = dropdownCss;
8
+
9
+ const Dropdown = /*@__PURE__*/ proxyCustomElement(class Dropdown extends H {
10
+ constructor() {
11
+ super();
12
+ this.__registerHost();
13
+ this.__attachShadow();
14
+ this.bcmDropdownChange = createEvent(this, "bcmDropdownChange", 1);
15
+ this.isReady = false;
16
+ this.dropdownItems = [];
17
+ this.dropdownClass = ce({
18
+ base: 'dropdown flex flex-col items-center min-w-[--dropdown-box-min-weight] shadow-3 max-w-[--dropdown-box-max-weight] max-h-[--dropdown-box-max-height] w-full bg-[--dropdown-box-background-color] rounded-lg py-1.5 scroll',
19
+ });
20
+ this.handleSlotChange = () => {
21
+ this.dropdownItems = Array.from(this.host.querySelectorAll('bcm-dropdown-item'));
22
+ if (this.dropdownItems.length === 0) {
23
+ console.warn('No dropdown items found in dropdown component');
24
+ }
25
+ };
26
+ }
27
+ componentDidLoad() {
28
+ const button = this.host.shadowRoot.querySelector('bcm-button');
29
+ if (button) {
30
+ this.buttonRef = button;
31
+ this.isReady = true;
32
+ }
33
+ }
34
+ handleDropdownItemChange(event) {
35
+ var _a;
36
+ const { element, selected } = event === null || event === void 0 ? void 0 : event.detail;
37
+ (_a = this.dropdownItems) === null || _a === void 0 ? void 0 : _a.forEach(item => {
38
+ if (item != element) {
39
+ item.selected = false;
40
+ }
41
+ });
42
+ this.bcmDropdownChange.emit({
43
+ element: element,
44
+ selected,
45
+ });
46
+ }
47
+ render() {
48
+ return (h(Host, { key: 'b11ebb72b3edcdfb390e0db6670f4529be9c68fb' }, h("bcm-button", { key: 'ed882535b16ddbc4125a1fc0dc99da8c09b6ee08', kind: "outline" }, h("span", { key: '6bbbaf7e987dda4cab9871bdf05f2b1563c88f76', part: "text" }, this.text)), this.isReady && (h("bcm-linked", { key: '0baaf5b767cb1be7fd88fac88d721b672f9a3fce', targetElement: this.buttonRef }, h("div", { key: 'c5548264d4ab84019eeac053317d210898320d01', part: "dropdown-container", class: this.dropdownClass() }, h("slot", { key: '7484957ffd0d7997e8acea90c56291eb0d036003', onSlotchange: this.handleSlotChange }))))));
49
+ }
50
+ get host() { return this; }
51
+ static get style() { return BcmDropdownStyle0; }
52
+ }, [1, "bcm-dropdown", {
53
+ "text": [1],
54
+ "isReady": [32],
55
+ "dropdownItems": [32]
56
+ }, [[2, "bcmDropDownItemChange", "handleDropdownItemChange"]]]);
57
+ function defineCustomElement$1() {
58
+ if (typeof customElements === "undefined") {
59
+ return;
60
+ }
61
+ const components = ["bcm-dropdown", "bcm-button", "bcm-linked"];
62
+ components.forEach(tagName => { switch (tagName) {
63
+ case "bcm-dropdown":
64
+ if (!customElements.get(tagName)) {
65
+ customElements.define(tagName, Dropdown);
66
+ }
67
+ break;
68
+ case "bcm-button":
69
+ if (!customElements.get(tagName)) {
70
+ defineCustomElement$3();
71
+ }
72
+ break;
73
+ case "bcm-linked":
74
+ if (!customElements.get(tagName)) {
75
+ defineCustomElement$2();
76
+ }
77
+ break;
78
+ } });
79
+ }
80
+ defineCustomElement$1();
81
+
82
+ const BcmDropdown = Dropdown;
83
+ const defineCustomElement = defineCustomElement$1;
84
+
85
+ export { BcmDropdown, defineCustomElement };
86
+
87
+ //# sourceMappingURL=bcm-dropdown.js.map
@@ -0,0 +1 @@
1
+ {"file":"bcm-dropdown.js","mappings":";;;;;AAAA,MAAM,WAAW,GAAG,85CAA85C,CAAC;AACn7C,0BAAe,WAAW;;MCOb,QAAQ;IALrB;;;;;QAUa,YAAO,GAAY,KAAK,CAAC;QAEzB,kBAAa,GAAiC,EAAE,CAAC;QAoClD,kBAAa,GAAGA,EAAE,CAAC;YACvB,IAAI,EAAE,yNAAyN;SAClO,CAAC,CAAC;QAEK,qBAAgB,GAAG;YACvB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,mBAAmB,CAAC,CAAC,CAAC;YAEjF,IAAI,IAAI,CAAC,aAAa,CAAC,MAAM,KAAK,CAAC,EAAE;gBACjC,OAAO,CAAC,IAAI,CAAC,+CAA+C,CAAC,CAAC;aACjE;SACJ,CAAC;KAkBL;IApDG,gBAAgB;QACZ,MAAM,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,YAAY,CAAyB,CAAC;QACxF,IAAI,MAAM,EAAE;YACR,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC;YACxB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;SACvB;KACJ;IAGD,wBAAwB,CAAC,KAAkB;;QACvC,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,GAAG,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,MAAM,CAAC;QAE5C,MAAA,IAAI,CAAC,aAAa,0CAAE,OAAO,CAAC,IAAI;YAC5B,IAAI,IAAI,IAAI,OAAO,EAAE;gBACjB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;aACzB;SACJ,CAAC,CAAC;QAEH,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC;YACxB,OAAO,EAAE,OAAO;YAChB,QAAQ;SACX,CAAC,CAAC;KACN;IAcD,MAAM;QACF,QACI,EAAC,IAAI,uDACD,mEAAY,IAAI,EAAC,SAAS,IACtB,6DAAM,IAAI,EAAC,MAAM,IAAE,IAAI,CAAC,IAAI,CAAQ,CAC3B,EACZ,IAAI,CAAC,OAAO,KACT,mEAAY,aAAa,EAAE,IAAI,CAAC,SAAS,IACrC,4DAAK,IAAI,EAAC,oBAAoB,EAAC,KAAK,EAAE,IAAI,CAAC,aAAa,EAAE,IACtD,6DAAM,YAAY,EAAE,IAAI,CAAC,gBAAgB,GAAS,CAChD,CACG,CAChB,CACE,EACT;KACL;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","names":["tv"],"sources":["src/components/dropdown/dropdown.css?tag=bcm-dropdown&encapsulation=shadow","src/components/dropdown/dropdown.component.tsx"],"sourcesContent":[":host {\n --dropdown-box-min-weight: 32px;\n --dropdown-box-max-width: 384px;\n --dropdown-box-max-height: 384px;\n --dropdown-box-background-color: var('--bcm-ui-color-background-base-default');\n}\n\n.scroll {\n height: 140px;\n width: 140px;\n overflow-y: auto;\n}\n\n.scroll:active::-webkit-scrollbar-thumb,\n.scroll:focus::-webkit-scrollbar-thumb,\n.scroll:hover::-webkit-scrollbar-thumb {\n visibility: visible;\n}\n.scroll::-webkit-scrollbar-thumb {\n background-color: darkgrey;\n visibility: hidden;\n}\n\n.scroll::-webkit-scrollbar {\n width: 8px;\n height: 8px;\n}\n","import { Component, ComponentInterface, h, Prop, State, Element, Host, Event, EventEmitter, Listen } from '@stencil/core';\nimport { tv } from 'tailwind-variants';\n\n@Component({\n tag: 'bcm-dropdown',\n styleUrl: 'dropdown.css',\n shadow: true,\n})\nexport class Dropdown implements ComponentInterface {\n @Element() host: HTMLElement;\n\n @Prop() text?: string;\n\n @State() isReady: boolean = false;\n\n @State() dropdownItems: HTMLBcmDropdownItemElement[] = [];\n\n protected buttonRef?: HTMLBcmButtonElement;\n\n @Event({\n composed: false,\n bubbles: false,\n cancelable: true,\n eventName: 'bcmDropdownChange',\n })\n bcmDropdownChange: EventEmitter<any>;\n\n componentDidLoad() {\n const button = this.host.shadowRoot.querySelector('bcm-button') as HTMLBcmButtonElement;\n if (button) {\n this.buttonRef = button;\n this.isReady = true;\n }\n }\n\n @Listen('bcmDropDownItemChange', { capture: true })\n handleDropdownItemChange(event: CustomEvent) {\n const { element, selected } = event?.detail;\n\n this.dropdownItems?.forEach(item => {\n if (item != element) {\n item.selected = false;\n }\n });\n\n this.bcmDropdownChange.emit({\n element: element,\n selected,\n });\n }\n\n private dropdownClass = tv({\n base: 'dropdown flex flex-col items-center min-w-[--dropdown-box-min-weight] shadow-3 max-w-[--dropdown-box-max-weight] max-h-[--dropdown-box-max-height] w-full bg-[--dropdown-box-background-color] rounded-lg py-1.5 scroll',\n });\n\n private handleSlotChange = () => {\n this.dropdownItems = Array.from(this.host.querySelectorAll('bcm-dropdown-item'));\n\n if (this.dropdownItems.length === 0) {\n console.warn('No dropdown items found in dropdown component');\n }\n };\n\n render() {\n return (\n <Host>\n <bcm-button kind=\"outline\">\n <span part=\"text\">{this.text}</span>\n </bcm-button>\n {this.isReady && (\n <bcm-linked targetElement={this.buttonRef}>\n <div part=\"dropdown-container\" class={this.dropdownClass()}>\n <slot onSlotchange={this.handleSlotChange}></slot>\n </div>\n </bcm-linked>\n )}\n </Host>\n );\n }\n}\n"],"version":3}