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
@@ -130,13 +130,13 @@ export class BcmButton {
130
130
  }
131
131
  render() {
132
132
  const { icon, position } = this.buttonIcon;
133
- return (h(Host, { key: '72bb1d2567880894e0c4c7667670e267faa9a6dd' }, h("button", { key: 'a1101e3c0846c6bf1c7059a8992b0b46fce74f8b', 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({
133
+ return (h(Host, { key: 'b1188fbe4439c4878a3306020097d07913b2212d' }, h("button", { key: 'eae7a80a19ea54120102d93127f55b039833bc54', 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({
134
134
  size: this.size,
135
135
  kind: this.kind,
136
136
  fullWidth: this.fullWidth,
137
137
  disabled: this.disabled,
138
138
  loading: this.loading,
139
- }) }, this.loading && h("slot", { key: 'c8a58aac8903477638cec974e32cdcd728e1ee8d', name: "loading" }), h("span", { key: '9690dfa5a312885da070ff90036b898c06f69621' }, h("slot", { key: '66eed1efbf522aec86d32ddbf0e9e8e68cbbb592', name: "prefix" }, position === 'prefix' && icon && h("i", { key: 'b0f91818830bd7e74d3d5cb6f957fa05f15b29a5', class: ' leading-none ' + icon }))), h("slot", { key: '7dbb0221b6119d61bc94c67355659e99a5bc75f5' }, this.buttonText), h("span", { key: 'd7547cc65575eef30ee8816b40de4485b0286b83' }, h("slot", { key: '32bd079256e6ca4a74572a726d459a3cb691a3ed', name: "suffix" }, position === 'suffix' && icon && h("i", { key: '66c307ec0637537986cb454f5cf718afc5715529', class: ' leading-none ' + icon }))))));
139
+ }) }, this.loading && h("slot", { key: 'c231e6995ec417011a833b86668be0226855df26', name: "loading" }), h("span", { key: '0398204b65ab60a2061b78cedd61c1fc934f9946' }, h("slot", { key: '664f13b119445486a1185bb009581cc64d1c0b3e', name: "prefix" }, position === 'prefix' && icon && h("i", { key: 'c06367c640065ef5255a89c3d3c9db08a88659d1', class: ' leading-none ' + icon }))), h("slot", { key: 'f8fc4f7eaae1ad869af95a6990a53def07678cd7' }, this.buttonText), h("span", { key: 'b1b7dc15d8090bb057b6b237d65c17ac328ee380' }, h("slot", { key: '43539884f514d7bb365e10e06bf1119b5c60a2b3', name: "suffix" }, position === 'suffix' && icon && h("i", { key: 'bf9ad3dc22fc11ca218c28e1a00e9e5a8cef80f2', class: ' leading-none ' + icon }))))));
140
140
  }
141
141
  static get is() { return "bcm-button"; }
142
142
  static get encapsulation() { return "shadow"; }
@@ -1 +1 @@
1
- :host{display:inline-block}:host([full-width]){width:100%}.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:.25rem}.border{border-width:1px}.border-solid{border-style:solid}.border-\[--bcm-button-border\]{border-color:var(--bcm-button-border)}.bg-\[--bcm-button-bg\]{background-color:var(--bcm-button-bg)}.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-button-text\]{color:var(--bcm-button-text)}.text-color-disabled{color:var(--bcm-ui-color-text-disabled)}.shadow{--tw-shadow:0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1);--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color),0 1px 2px -1px var(--tw-shadow-color);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-button-bg-hover\]:hover{background-color:var(--bcm-button-bg-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)}.active\:bg-\[--bcm-button-bg-active\]:active{background-color:var(--bcm-button-bg-active)}
1
+ .relative{position:relative}:host{display:inline-block;position:relative}:host([full-width]){width:100%}.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:.25rem}.border{border-width:1px}.border-solid{border-style:solid}.border-\[--bcm-button-border\]{border-color:var(--bcm-button-border)}.bg-\[--bcm-button-bg\]{background-color:var(--bcm-button-bg)}.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-button-text\]{color:var(--bcm-button-text)}.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-button-bg-hover\]:hover{background-color:var(--bcm-button-bg-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)}.active\:bg-\[--bcm-button-bg-active\]:active{background-color:var(--bcm-button-bg-active)}.flex{display:flex}.max-h-\[--dropdown-box-max-height\]{max-height:var(--dropdown-box-max-height)}.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}.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,.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)}
@@ -42,7 +42,7 @@ export class BcmChip {
42
42
  this.disabled = false;
43
43
  this.chipClass = tv({
44
44
  base: [
45
- 'chip bcm-ui-element font-normal flex items-center px-2 gap-1 w-full border',
45
+ 'chip bcm-ui-element font-normal flex items-center justify-center px-2 gap-1 min-w-max border',
46
46
  'bg-[--bcm-chip-bg] text-[--bcm-chip-text] rounded-[--bcm-chip-radius] border-[--bcm-chip-border]',
47
47
  'hover:bg-[--bcm-chip-hover-bg] active:bg-[--bcm-chip-active-bg]',
48
48
  ],
@@ -131,7 +131,7 @@ export class BcmChip {
131
131
  }
132
132
  }
133
133
  render() {
134
- return (h("div", { key: '83c822b736059446f9f19c9112ab8b11a1aa17b9', style: this.chipStyle, class: this.chipClass({ size: this.size, kind: this.kind, disabled: this.disabled }), role: "button", "aria-disabled": this.disabled ? 'true' : 'false' }, h("slot", { key: 'ef139f27de5b6f3d1c0077a08882fd965b0745c8' }), this.dismissible && h("bcm-icon", { key: '7ac646b4641eb8bd8db9df3e25895bf5b45231c5', onClick: () => this.handleDismiss(), class: "cursor-pointer", "icon-name": "fa-regular fa-xmark", "aria-label": "Dismiss chip" })));
134
+ return (h("div", { key: '1bcc941d68f13e8d57ffb0621911b585b3909d5a', style: this.chipStyle, class: this.chipClass({ size: this.size, kind: this.kind, disabled: this.disabled }), role: "button", "aria-disabled": this.disabled ? 'true' : 'false' }, h("slot", { key: '3a2dc016ac80905bfa38f16f50417700c854a421' }), this.dismissible && h("bcm-icon", { key: '9176d4a57accdcc9b814293d441fa12ba2065c9b', onClick: () => this.handleDismiss(), class: "cursor-pointer", "icon-name": "fa-regular fa-xmark", "aria-label": "Dismiss chip" })));
135
135
  }
136
136
  static get is() { return "bcm-chip"; }
137
137
  static get encapsulation() { return "shadow"; }
@@ -1 +1 @@
1
- {"version":3,"file":"chip.component.js","sourceRoot":"","sources":["../../../src/components/chip/chip.component.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, ComponentInterface, h, Prop, Event, EventEmitter } from '@stencil/core';\nimport { ChipKind, ChipSize, ChipStatus, STATUS_COLORS } from './types';\nimport { tv } from 'tailwind-variants';\n\n/**\n * @component BcmChip\n * @description A versatile chip component that can be used to display compact pieces of information, filters, or actions.\n * Supports different sizes, styles (filled, outlined, text), statuses, and can be dismissible.\n *\n * @example\n * <bcm-chip size=\"medium\" kind=\"filled\" status=\"success\">\n * Success Chip\n * </bcm-chip>\n *\n * @example Dismissible chip\n * <bcm-chip dismissible={true} onDismiss={() => handleDismiss()}>\n * Dismissible Chip\n * </bcm-chip>\n *\n * @prop {ChipSize} size - Defines the size of the chip: 'small' | 'medium' | 'large'\n * @prop {ChipKind} kind - Defines the visual style: 'filled' | 'outlined' | 'text'\n * @prop {ChipStatus} status - Defines the status color: 'info' | 'error' | 'warning' | 'success' | 'default'\n * @prop {boolean} dismissible - Whether the chip can be dismissed\n * @prop {boolean} disabled - Whether the chip is disabled\n * @prop {string} color - Custom color override for the chip\n *\n * @event {EventEmitter<void>} dismiss - Emitted when the dismiss button is clicked\n *\n * @csspart chip - The root chip element\n * @csspart dismiss-icon - The dismiss button icon\n */\n\n@Component({\n tag: 'bcm-chip',\n styleUrl: 'chip.css',\n shadow: true,\n})\nexport class BcmChip implements ComponentInterface {\n /** Chip size variant */\n @Prop()\n size?: ChipSize = 'medium';\n\n /** Chip style variant */\n @Prop()\n kind?: ChipKind = 'filled';\n\n /** Chip status */\n @Prop()\n status?: ChipStatus = 'default';\n\n /** Whether chip can be dismissed */\n @Prop()\n dismissible?: boolean = false;\n\n /** Whether chip is disabled */\n @Prop()\n disabled?: boolean = false;\n\n /** Chip color variant */\n @Prop()\n color?: string;\n\n @Event({\n composed: false,\n bubbles: false,\n cancelable: true,\n })\n bcmDismiss: EventEmitter<void>;\n\n private chipClass = tv(\n {\n base: [\n 'chip bcm-ui-element font-normal flex items-center px-2 gap-1 w-full border',\n 'bg-[--bcm-chip-bg] text-[--bcm-chip-text] rounded-[--bcm-chip-radius] border-[--bcm-chip-border]',\n 'hover:bg-[--bcm-chip-hover-bg] active:bg-[--bcm-chip-active-bg]',\n ],\n variants: {\n size: {\n small: 'small py-px text-size-3',\n medium: 'medium py-0.5 text-size-4',\n large: 'large py-1 text-size-5',\n },\n kind: {\n filled: 'filled border-transparent',\n outlined: 'outlined',\n text: 'text border-none',\n },\n disabled: {\n true: 'cursor-not-allowed',\n },\n },\n },\n { twMerge: false },\n );\n\n private get chipStyle() {\n let _color = this.color;\n\n if (this.disabled) {\n return {\n '--bcm-chip-bg': 'var(--bcm-ui-color-background-disabled-default)',\n '--bcm-chip-text': 'var(--bcm-ui-color-text-disabled)',\n '--bcm-chip-border': 'var(--bcm-ui-color-border-disabled)',\n '--bcm-chip-hover-bg': 'var(--bcm-ui-color-background-disabled-default)',\n '--bcm-chip-active-bg': 'var(--bcm-ui-color-background-disabled-default)',\n };\n }\n\n if (this.status !== 'default') {\n _color = STATUS_COLORS[this.status];\n }\n\n const styles = {\n filled: {\n '--bcm-chip-bg': `var(--bcm-ui-color-background-palette-${_color}-default)`,\n '--bcm-chip-text': `var(--bcm-ui-color-text-palette-${_color})`,\n '--bcm-chip-border': `var(--bcm-ui-color-border-${_color})`,\n '--bcm-chip-hover-bg': `var(--bcm-ui-color-background-palette-${_color}-hover)`,\n '--bcm-chip-active-bg': `var(--bcm-ui-color-background-palette-${_color}-active)`,\n },\n outlined: {\n '--bcm-chip-bg': 'transparent',\n '--bcm-chip-text': `var(--bcm-ui-color-text-palette-${_color})`,\n '--bcm-chip-border': `var(--bcm-ui-color-border-${_color})`,\n '--bcm-chip-hover-bg': `var(--bcm-ui-color-background-palette-${_color}-hover)`,\n '--bcm-chip-active-bg': `var(--bcm-ui-color-background-palette-${_color}-active)`,\n },\n text: {\n '--bcm-chip-bg': 'transparent',\n '--bcm-chip-text': `var(--bcm-ui-color-text-palette-${_color})`,\n '--bcm-chip-border': 'transparent',\n '--bcm-chip-hover-bg': `var(--bcm-ui-color-background-palette-${_color}-hover)`,\n '--bcm-chip-active-bg': `var(--bcm-ui-color-background-palette-${_color}-active)`,\n },\n };\n\n const defaultStyles = {\n filled: {\n '--bcm-chip-bg': 'var(--bcm-ui-color-background-default-default)',\n '--bcm-chip-text': 'var(--bcm-ui-color-text-default)',\n '--bcm-chip-border': 'var(--bcm-ui-color-border-default)',\n '--bcm-chip-hover-bg': 'var(--bcm-ui-color-background-default-hover)',\n '--bcm-chip-active-bg': 'var(--bcm-ui-color-background-default-active)',\n },\n outlined: {\n '--bcm-chip-bg': 'transparent',\n '--bcm-chip-text': 'var(--bcm-ui-color-text-default)',\n '--bcm-chip-border': 'var(--bcm-ui-color-border-default)',\n '--bcm-chip-hover-bg': 'var(--bcm-ui-color-background-default-hover)',\n '--bcm-chip-active-bg': 'var(--bcm-ui-color-background-default-active)',\n },\n text: {\n '--bcm-chip-bg': 'transparent',\n '--bcm-chip-text': 'var(--bcm-ui-color-text-default)',\n '--bcm-chip-border': 'transparent',\n '--bcm-chip-hover-bg': 'var(--bcm-ui-color-background-default-hover)',\n '--bcm-chip-active-bg': 'var(--bcm-ui-color-background-default-active)',\n },\n };\n\n return _color ? styles[this.kind] : defaultStyles[this.kind];\n }\n\n private handleDismiss() {\n if (!this.disabled) {\n this.bcmDismiss.emit();\n }\n }\n\n render() {\n return (\n <div\n style={this.chipStyle}\n class={this.chipClass({ size: this.size, kind: this.kind, disabled: this.disabled })}\n role=\"button\"\n aria-disabled={this.disabled ? 'true' : 'false'}\n >\n <slot></slot>\n {this.dismissible && <bcm-icon onClick={() => this.handleDismiss()} class=\"cursor-pointer\" icon-name=\"fa-regular fa-xmark\" aria-label=\"Dismiss chip\"></bcm-icon>}\n </div>\n );\n }\n}\n"]}
1
+ {"version":3,"file":"chip.component.js","sourceRoot":"","sources":["../../../src/components/chip/chip.component.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, ComponentInterface, h, Prop, Event, EventEmitter } from '@stencil/core';\nimport { ChipKind, ChipSize, ChipStatus, STATUS_COLORS } from './types';\nimport { tv } from 'tailwind-variants';\n\n/**\n * @component BcmChip\n * @description A versatile chip component that can be used to display compact pieces of information, filters, or actions.\n * Supports different sizes, styles (filled, outlined, text), statuses, and can be dismissible.\n *\n * @example\n * <bcm-chip size=\"medium\" kind=\"filled\" status=\"success\">\n * Success Chip\n * </bcm-chip>\n *\n * @example Dismissible chip\n * <bcm-chip dismissible={true} onDismiss={() => handleDismiss()}>\n * Dismissible Chip\n * </bcm-chip>\n *\n * @prop {ChipSize} size - Defines the size of the chip: 'small' | 'medium' | 'large'\n * @prop {ChipKind} kind - Defines the visual style: 'filled' | 'outlined' | 'text'\n * @prop {ChipStatus} status - Defines the status color: 'info' | 'error' | 'warning' | 'success' | 'default'\n * @prop {boolean} dismissible - Whether the chip can be dismissed\n * @prop {boolean} disabled - Whether the chip is disabled\n * @prop {string} color - Custom color override for the chip\n *\n * @event {EventEmitter<void>} dismiss - Emitted when the dismiss button is clicked\n *\n * @csspart chip - The root chip element\n * @csspart dismiss-icon - The dismiss button icon\n */\n\n@Component({\n tag: 'bcm-chip',\n styleUrl: 'chip.css',\n shadow: true,\n})\nexport class BcmChip implements ComponentInterface {\n /** Chip size variant */\n @Prop()\n size?: ChipSize = 'medium';\n\n /** Chip style variant */\n @Prop()\n kind?: ChipKind = 'filled';\n\n /** Chip status */\n @Prop()\n status?: ChipStatus = 'default';\n\n /** Whether chip can be dismissed */\n @Prop()\n dismissible?: boolean = false;\n\n /** Whether chip is disabled */\n @Prop()\n disabled?: boolean = false;\n\n /** Chip color variant */\n @Prop()\n color?: string;\n\n @Event({\n composed: false,\n bubbles: false,\n cancelable: true,\n })\n bcmDismiss: EventEmitter<void>;\n\n private chipClass = tv(\n {\n base: [\n 'chip bcm-ui-element font-normal flex items-center justify-center px-2 gap-1 min-w-max border',\n 'bg-[--bcm-chip-bg] text-[--bcm-chip-text] rounded-[--bcm-chip-radius] border-[--bcm-chip-border]',\n 'hover:bg-[--bcm-chip-hover-bg] active:bg-[--bcm-chip-active-bg]',\n ],\n variants: {\n size: {\n small: 'small py-px text-size-3',\n medium: 'medium py-0.5 text-size-4',\n large: 'large py-1 text-size-5',\n },\n kind: {\n filled: 'filled border-transparent',\n outlined: 'outlined',\n text: 'text border-none',\n },\n disabled: {\n true: 'cursor-not-allowed',\n },\n },\n },\n { twMerge: false },\n );\n\n private get chipStyle() {\n let _color = this.color;\n\n if (this.disabled) {\n return {\n '--bcm-chip-bg': 'var(--bcm-ui-color-background-disabled-default)',\n '--bcm-chip-text': 'var(--bcm-ui-color-text-disabled)',\n '--bcm-chip-border': 'var(--bcm-ui-color-border-disabled)',\n '--bcm-chip-hover-bg': 'var(--bcm-ui-color-background-disabled-default)',\n '--bcm-chip-active-bg': 'var(--bcm-ui-color-background-disabled-default)',\n };\n }\n\n if (this.status !== 'default') {\n _color = STATUS_COLORS[this.status];\n }\n\n const styles = {\n filled: {\n '--bcm-chip-bg': `var(--bcm-ui-color-background-palette-${_color}-default)`,\n '--bcm-chip-text': `var(--bcm-ui-color-text-palette-${_color})`,\n '--bcm-chip-border': `var(--bcm-ui-color-border-${_color})`,\n '--bcm-chip-hover-bg': `var(--bcm-ui-color-background-palette-${_color}-hover)`,\n '--bcm-chip-active-bg': `var(--bcm-ui-color-background-palette-${_color}-active)`,\n },\n outlined: {\n '--bcm-chip-bg': 'transparent',\n '--bcm-chip-text': `var(--bcm-ui-color-text-palette-${_color})`,\n '--bcm-chip-border': `var(--bcm-ui-color-border-${_color})`,\n '--bcm-chip-hover-bg': `var(--bcm-ui-color-background-palette-${_color}-hover)`,\n '--bcm-chip-active-bg': `var(--bcm-ui-color-background-palette-${_color}-active)`,\n },\n text: {\n '--bcm-chip-bg': 'transparent',\n '--bcm-chip-text': `var(--bcm-ui-color-text-palette-${_color})`,\n '--bcm-chip-border': 'transparent',\n '--bcm-chip-hover-bg': `var(--bcm-ui-color-background-palette-${_color}-hover)`,\n '--bcm-chip-active-bg': `var(--bcm-ui-color-background-palette-${_color}-active)`,\n },\n };\n\n const defaultStyles = {\n filled: {\n '--bcm-chip-bg': 'var(--bcm-ui-color-background-default-default)',\n '--bcm-chip-text': 'var(--bcm-ui-color-text-default)',\n '--bcm-chip-border': 'var(--bcm-ui-color-border-default)',\n '--bcm-chip-hover-bg': 'var(--bcm-ui-color-background-default-hover)',\n '--bcm-chip-active-bg': 'var(--bcm-ui-color-background-default-active)',\n },\n outlined: {\n '--bcm-chip-bg': 'transparent',\n '--bcm-chip-text': 'var(--bcm-ui-color-text-default)',\n '--bcm-chip-border': 'var(--bcm-ui-color-border-default)',\n '--bcm-chip-hover-bg': 'var(--bcm-ui-color-background-default-hover)',\n '--bcm-chip-active-bg': 'var(--bcm-ui-color-background-default-active)',\n },\n text: {\n '--bcm-chip-bg': 'transparent',\n '--bcm-chip-text': 'var(--bcm-ui-color-text-default)',\n '--bcm-chip-border': 'transparent',\n '--bcm-chip-hover-bg': 'var(--bcm-ui-color-background-default-hover)',\n '--bcm-chip-active-bg': 'var(--bcm-ui-color-background-default-active)',\n },\n };\n\n return _color ? styles[this.kind] : defaultStyles[this.kind];\n }\n\n private handleDismiss() {\n if (!this.disabled) {\n this.bcmDismiss.emit();\n }\n }\n\n render() {\n return (\n <div\n style={this.chipStyle}\n class={this.chipClass({ size: this.size, kind: this.kind, disabled: this.disabled })}\n role=\"button\"\n aria-disabled={this.disabled ? 'true' : 'false'}\n ><slot></slot>\n {this.dismissible && <bcm-icon onClick={() => this.handleDismiss()} class=\"cursor-pointer\" icon-name=\"fa-regular fa-xmark\" aria-label=\"Dismiss chip\"></bcm-icon>}\n </div>\n );\n }\n}\n"]}
@@ -1 +1 @@
1
- :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}.w-full{width:100%}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.items-center{align-items: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:0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1);--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color),0 1px 2px -1px var(--tw-shadow-color);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)}
1
+ :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)}
@@ -0,0 +1,190 @@
1
+ import { h } from "@stencil/core";
2
+ import { tv } from "tailwind-variants";
3
+ /**
4
+ * @component BCM Divider
5
+ * @description
6
+ * A versatile divider component that creates a visual separation between content.
7
+ * It supports horizontal or vertical orientation with customizable styles and sizes.
8
+ * The component uses CSS variables for theming and Tailwind for styling.
9
+ */
10
+ export class Divider {
11
+ constructor() {
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 = tv({
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 is() { return "bcm-divider"; }
75
+ static get encapsulation() { return "shadow"; }
76
+ static get originalStyleUrls() {
77
+ return {
78
+ "$": ["divider.css"]
79
+ };
80
+ }
81
+ static get styleUrls() {
82
+ return {
83
+ "$": ["divider.css"]
84
+ };
85
+ }
86
+ static get properties() {
87
+ return {
88
+ "direction": {
89
+ "type": "string",
90
+ "mutable": false,
91
+ "complexType": {
92
+ "original": "'horizontal' | 'vertical'",
93
+ "resolved": "\"horizontal\" | \"vertical\"",
94
+ "references": {}
95
+ },
96
+ "required": false,
97
+ "optional": false,
98
+ "docs": {
99
+ "tags": [{
100
+ "name": "prop",
101
+ "text": "{('horizontal'|'vertical')} direction"
102
+ }, {
103
+ "name": "description",
104
+ "text": "Determines the orientation of the divider"
105
+ }, {
106
+ "name": "default",
107
+ "text": "'horizontal'"
108
+ }, {
109
+ "name": "example",
110
+ "text": "<bcm-divider direction=\"vertical\" />"
111
+ }],
112
+ "text": ""
113
+ },
114
+ "getter": false,
115
+ "setter": false,
116
+ "attribute": "direction",
117
+ "reflect": false,
118
+ "defaultValue": "'horizontal'"
119
+ },
120
+ "variant": {
121
+ "type": "string",
122
+ "mutable": false,
123
+ "complexType": {
124
+ "original": "'solid' | 'dashed' | 'dotted'",
125
+ "resolved": "\"dashed\" | \"dotted\" | \"solid\"",
126
+ "references": {}
127
+ },
128
+ "required": false,
129
+ "optional": false,
130
+ "docs": {
131
+ "tags": [{
132
+ "name": "prop",
133
+ "text": "{('solid'|'dashed'|'dotted')} variant"
134
+ }, {
135
+ "name": "description",
136
+ "text": "Sets the border style of the divider"
137
+ }, {
138
+ "name": "default",
139
+ "text": "'solid'"
140
+ }, {
141
+ "name": "example",
142
+ "text": "<bcm-divider variant=\"dashed\" />"
143
+ }],
144
+ "text": ""
145
+ },
146
+ "getter": false,
147
+ "setter": false,
148
+ "attribute": "variant",
149
+ "reflect": false,
150
+ "defaultValue": "'solid'"
151
+ },
152
+ "size": {
153
+ "type": "string",
154
+ "mutable": false,
155
+ "complexType": {
156
+ "original": "'small' | 'medium' | 'large'",
157
+ "resolved": "\"large\" | \"medium\" | \"small\"",
158
+ "references": {}
159
+ },
160
+ "required": false,
161
+ "optional": false,
162
+ "docs": {
163
+ "tags": [{
164
+ "name": "prop",
165
+ "text": "{('small'|'medium'|'large')} size"
166
+ }, {
167
+ "name": "description",
168
+ "text": "Controls the thickness of the divider"
169
+ }, {
170
+ "name": "default",
171
+ "text": "'medium'"
172
+ }, {
173
+ "name": "values",
174
+ "text": "- small: 1px border\n- medium: 2px border\n- large: 4px border"
175
+ }, {
176
+ "name": "example",
177
+ "text": "<bcm-divider size=\"large\" />"
178
+ }],
179
+ "text": ""
180
+ },
181
+ "getter": false,
182
+ "setter": false,
183
+ "attribute": "size",
184
+ "reflect": false,
185
+ "defaultValue": "'medium'"
186
+ }
187
+ };
188
+ }
189
+ }
190
+ //# sourceMappingURL=divider.component.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"divider.component.js","sourceRoot":"","sources":["../../../src/components/divider/divider.component.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAsB,IAAI,EAAE,CAAC,EAAE,MAAM,eAAe,CAAC;AACvE,OAAO,EAAE,EAAE,EAAE,MAAM,mBAAmB,CAAC;AAEvC;;;;;;GAMG;AAMH,MAAM,OAAO,OAAO;IALpB;QAMI;;;;;;WAMG;QAEH,cAAS,GAA8B,YAAY,CAAC;QAEpD;;;;;;WAMG;QAEH,YAAO,GAAkC,OAAO,CAAC;QAEjD;;;;;;;;;;WAUG;QAEH,SAAI,GAAiC,QAAQ,CAAC;QAEtC,iBAAY,GAAG,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,OAAO,CACH,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,CACV,CAAC;IACN,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACJ","sourcesContent":["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"]}
@@ -0,0 +1 @@
1
+ .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)}
@@ -0,0 +1,110 @@
1
+ import { h, Host } from "@stencil/core";
2
+ import { tv } from "tailwind-variants";
3
+ export class Dropdown {
4
+ constructor() {
5
+ this.isReady = false;
6
+ this.dropdownItems = [];
7
+ this.dropdownClass = tv({
8
+ 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',
9
+ });
10
+ this.handleSlotChange = () => {
11
+ this.dropdownItems = Array.from(this.host.querySelectorAll('bcm-dropdown-item'));
12
+ if (this.dropdownItems.length === 0) {
13
+ console.warn('No dropdown items found in dropdown component');
14
+ }
15
+ };
16
+ }
17
+ componentDidLoad() {
18
+ const button = this.host.shadowRoot.querySelector('bcm-button');
19
+ if (button) {
20
+ this.buttonRef = button;
21
+ this.isReady = true;
22
+ }
23
+ }
24
+ handleDropdownItemChange(event) {
25
+ var _a;
26
+ const { element, selected } = event === null || event === void 0 ? void 0 : event.detail;
27
+ (_a = this.dropdownItems) === null || _a === void 0 ? void 0 : _a.forEach(item => {
28
+ if (item != element) {
29
+ item.selected = false;
30
+ }
31
+ });
32
+ this.bcmDropdownChange.emit({
33
+ element: element,
34
+ selected,
35
+ });
36
+ }
37
+ render() {
38
+ 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 }))))));
39
+ }
40
+ static get is() { return "bcm-dropdown"; }
41
+ static get encapsulation() { return "shadow"; }
42
+ static get originalStyleUrls() {
43
+ return {
44
+ "$": ["dropdown.css"]
45
+ };
46
+ }
47
+ static get styleUrls() {
48
+ return {
49
+ "$": ["dropdown.css"]
50
+ };
51
+ }
52
+ static get properties() {
53
+ return {
54
+ "text": {
55
+ "type": "string",
56
+ "mutable": false,
57
+ "complexType": {
58
+ "original": "string",
59
+ "resolved": "string",
60
+ "references": {}
61
+ },
62
+ "required": false,
63
+ "optional": true,
64
+ "docs": {
65
+ "tags": [],
66
+ "text": ""
67
+ },
68
+ "getter": false,
69
+ "setter": false,
70
+ "attribute": "text",
71
+ "reflect": false
72
+ }
73
+ };
74
+ }
75
+ static get states() {
76
+ return {
77
+ "isReady": {},
78
+ "dropdownItems": {}
79
+ };
80
+ }
81
+ static get events() {
82
+ return [{
83
+ "method": "bcmDropdownChange",
84
+ "name": "bcmDropdownChange",
85
+ "bubbles": false,
86
+ "cancelable": true,
87
+ "composed": false,
88
+ "docs": {
89
+ "tags": [],
90
+ "text": ""
91
+ },
92
+ "complexType": {
93
+ "original": "any",
94
+ "resolved": "any",
95
+ "references": {}
96
+ }
97
+ }];
98
+ }
99
+ static get elementRef() { return "host"; }
100
+ static get listeners() {
101
+ return [{
102
+ "name": "bcmDropDownItemChange",
103
+ "method": "handleDropdownItemChange",
104
+ "target": undefined,
105
+ "capture": true,
106
+ "passive": false
107
+ }];
108
+ }
109
+ }
110
+ //# sourceMappingURL=dropdown.component.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../src/components/dropdown/dropdown.component.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAsB,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE,KAAK,EAAgB,MAAM,EAAE,MAAM,eAAe,CAAC;AAC1H,OAAO,EAAE,EAAE,EAAE,MAAM,mBAAmB,CAAC;AAOvC,MAAM,OAAO,QAAQ;IALrB;QAUa,YAAO,GAAY,KAAK,CAAC;QAEzB,kBAAa,GAAiC,EAAE,CAAC;QAoClD,kBAAa,GAAG,EAAE,CAAC;YACvB,IAAI,EAAE,yNAAyN;SAClO,CAAC,CAAC;QAEK,qBAAgB,GAAG,GAAG,EAAE;YAC5B,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,CAAC;gBAClC,OAAO,CAAC,IAAI,CAAC,+CAA+C,CAAC,CAAC;YAClE,CAAC;QACL,CAAC,CAAC;KAkBL;IApDG,gBAAgB;QACZ,MAAM,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,YAAY,CAAyB,CAAC;QACxF,IAAI,MAAM,EAAE,CAAC;YACT,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC;YACxB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACxB,CAAC;IACL,CAAC;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,CAAC,EAAE;YAC/B,IAAI,IAAI,IAAI,OAAO,EAAE,CAAC;gBAClB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;YAC1B,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC;YACxB,OAAO,EAAE,OAAO;YAChB,QAAQ;SACX,CAAC,CAAC;IACP,CAAC;IAcD,MAAM;QACF,OAAO,CACH,EAAC,IAAI;YACD,mEAAY,IAAI,EAAC,SAAS;gBACtB,6DAAM,IAAI,EAAC,MAAM,IAAE,IAAI,CAAC,IAAI,CAAQ,CAC3B;YACZ,IAAI,CAAC,OAAO,IAAI,CACb,mEAAY,aAAa,EAAE,IAAI,CAAC,SAAS;gBACrC,4DAAK,IAAI,EAAC,oBAAoB,EAAC,KAAK,EAAE,IAAI,CAAC,aAAa,EAAE;oBACtD,6DAAM,YAAY,EAAE,IAAI,CAAC,gBAAgB,GAAS,CAChD,CACG,CAChB,CACE,CACV,CAAC;IACN,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACJ","sourcesContent":["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"]}
@@ -0,0 +1 @@
1
+ .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}