bromcom-ui-next 0.1.0 → 0.1.3

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 (116) 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/p-047e562f.entry.js +2 -0
  5. package/dist/bromcom-ui/p-047e562f.entry.js.map +1 -0
  6. package/dist/bromcom-ui/p-3805363a.entry.js +2 -0
  7. package/dist/bromcom-ui/{p-341d46a8.entry.js.map → p-3805363a.entry.js.map} +1 -1
  8. package/dist/bromcom-ui/p-61c030c5.js +3 -0
  9. package/dist/bromcom-ui/p-61c030c5.js.map +1 -0
  10. package/dist/bromcom-ui/p-6430a887.entry.js +2 -0
  11. package/dist/bromcom-ui/p-6430a887.entry.js.map +1 -0
  12. package/dist/bromcom-ui/p-9e94d920.entry.js +2 -0
  13. package/dist/bromcom-ui/p-9e94d920.entry.js.map +1 -0
  14. package/dist/bromcom-ui/p-bde58312.entry.js +2 -0
  15. package/dist/bromcom-ui/p-bde58312.entry.js.map +1 -0
  16. package/dist/bromcom-ui/p-dcc13a55.entry.js +2 -0
  17. package/dist/bromcom-ui/{p-997f314c.entry.js.map → p-dcc13a55.entry.js.map} +1 -1
  18. package/dist/bromcom-ui/p-e7732b0c.entry.js +2 -0
  19. package/dist/bromcom-ui/{p-f0c61f8c.entry.js.map → p-e7732b0c.entry.js.map} +1 -1
  20. package/dist/cjs/bcm-accordion-group.cjs.entry.js +92 -0
  21. package/dist/cjs/bcm-accordion-group.cjs.entry.js.map +1 -0
  22. package/dist/cjs/bcm-accordion.cjs.entry.js +128 -0
  23. package/dist/cjs/bcm-accordion.cjs.entry.js.map +1 -0
  24. package/dist/cjs/bcm-alert.cjs.entry.js +3 -3
  25. package/dist/cjs/bcm-alert.cjs.entry.js.map +1 -1
  26. package/dist/cjs/bcm-avatar.cjs.entry.js +2 -2
  27. package/dist/cjs/bcm-avatar.cjs.entry.js.map +1 -1
  28. package/dist/cjs/bcm-button_2.cjs.entry.js +549 -0
  29. package/dist/cjs/bcm-button_2.cjs.entry.js.map +1 -0
  30. package/dist/cjs/bcm-chip.cjs.entry.js +130 -0
  31. package/dist/cjs/bcm-chip.cjs.entry.js.map +1 -0
  32. package/dist/cjs/bcm-text.cjs.entry.js +3 -3
  33. package/dist/cjs/bcm-text.cjs.entry.js.map +1 -1
  34. package/dist/cjs/bromcom-ui.cjs.js +2 -2
  35. package/dist/cjs/{index-638f2d15.js → index-c36002ae.js} +32 -3
  36. package/dist/cjs/index-c36002ae.js.map +1 -0
  37. package/dist/cjs/loader.cjs.js +2 -2
  38. package/dist/collection/collection-manifest.json +1 -0
  39. package/dist/collection/components/accordion/accordion.component.js +4 -4
  40. package/dist/collection/components/accordion/accordion.component.js.map +1 -1
  41. package/dist/collection/components/accordion/accordion.css +1 -1
  42. package/dist/collection/components/accordion-group/accordion-group.component.js +1 -1
  43. package/dist/collection/components/accordion-group/accordion-group.css +1 -1
  44. package/dist/collection/components/alert/alert.component.js +1 -1
  45. package/dist/collection/components/alert/alert.css +1 -1
  46. package/dist/collection/components/avatar/avatar.css +1 -1
  47. package/dist/collection/components/button/button.component.js +3 -3
  48. package/dist/collection/components/button/button.component.js.map +1 -1
  49. package/dist/collection/components/button/button.css +1 -1
  50. package/dist/collection/components/chip/chip.component.js +1 -1
  51. package/dist/collection/components/chip/chip.css +1 -1
  52. package/dist/collection/components/input/input.component.js +865 -0
  53. package/dist/collection/components/input/input.component.js.map +1 -0
  54. package/dist/collection/components/input/input.css +2 -0
  55. package/dist/collection/components/input/types.js +2 -0
  56. package/dist/collection/components/input/types.js.map +1 -0
  57. package/dist/collection/components/text/text.component.js +1 -1
  58. package/dist/collection/components/text/text.css +1 -1
  59. package/dist/collection/utils/id/generate-id.js +16 -0
  60. package/dist/collection/utils/id/generate-id.js.map +1 -0
  61. package/dist/components/bcm-accordion-group.js +3 -3
  62. package/dist/components/bcm-accordion-group.js.map +1 -1
  63. package/dist/components/bcm-accordion.js +6 -6
  64. package/dist/components/bcm-accordion.js.map +1 -1
  65. package/dist/components/bcm-alert.js +3 -3
  66. package/dist/components/bcm-alert.js.map +1 -1
  67. package/dist/components/bcm-avatar.js +2 -2
  68. package/dist/components/bcm-avatar.js.map +1 -1
  69. package/dist/components/bcm-button.js +5 -5
  70. package/dist/components/bcm-button.js.map +1 -1
  71. package/dist/components/bcm-chip.js +3 -3
  72. package/dist/components/bcm-chip.js.map +1 -1
  73. package/dist/components/bcm-input.d.ts +11 -0
  74. package/dist/components/bcm-input.js +306 -0
  75. package/dist/components/bcm-input.js.map +1 -0
  76. package/dist/components/bcm-text.js +3 -3
  77. package/dist/components/bcm-text.js.map +1 -1
  78. package/dist/components/index.js +1 -1
  79. package/dist/components/{p-0adcc84f.js → p-8ded2c73.js} +26 -3
  80. package/dist/{cjs/index-638f2d15.js.map → components/p-8ded2c73.js.map} +1 -1
  81. package/dist/esm/bcm-accordion-group.entry.js +88 -0
  82. package/dist/esm/bcm-accordion-group.entry.js.map +1 -0
  83. package/dist/esm/bcm-accordion.entry.js +124 -0
  84. package/dist/esm/bcm-accordion.entry.js.map +1 -0
  85. package/dist/esm/bcm-alert.entry.js +3 -3
  86. package/dist/esm/bcm-alert.entry.js.map +1 -1
  87. package/dist/esm/bcm-avatar.entry.js +2 -2
  88. package/dist/esm/bcm-avatar.entry.js.map +1 -1
  89. package/dist/esm/bcm-button_2.entry.js +544 -0
  90. package/dist/esm/bcm-button_2.entry.js.map +1 -0
  91. package/dist/esm/bcm-chip.entry.js +126 -0
  92. package/dist/esm/bcm-chip.entry.js.map +1 -0
  93. package/dist/esm/bcm-text.entry.js +3 -3
  94. package/dist/esm/bcm-text.entry.js.map +1 -1
  95. package/dist/esm/bromcom-ui.js +3 -3
  96. package/dist/esm/{index-ce2fac11.js → index-e23ee9b0.js} +32 -3
  97. package/dist/esm/index-e23ee9b0.js.map +1 -0
  98. package/dist/esm/loader.js +3 -3
  99. package/dist/types/components/input/input.component.d.ts +74 -0
  100. package/dist/types/components/input/types.d.ts +3 -0
  101. package/dist/types/components.d.ts +246 -0
  102. package/dist/types/utils/id/generate-id.d.ts +9 -0
  103. package/package.json +3 -2
  104. package/dist/bromcom-ui/p-27c997d8.js +0 -3
  105. package/dist/bromcom-ui/p-27c997d8.js.map +0 -1
  106. package/dist/bromcom-ui/p-341d46a8.entry.js +0 -2
  107. package/dist/bromcom-ui/p-997f314c.entry.js +0 -2
  108. package/dist/bromcom-ui/p-dcb9df00.entry.js +0 -2
  109. package/dist/bromcom-ui/p-dcb9df00.entry.js.map +0 -1
  110. package/dist/bromcom-ui/p-f0c61f8c.entry.js +0 -2
  111. package/dist/cjs/bcm-accordion_4.cjs.entry.js +0 -623
  112. package/dist/cjs/bcm-accordion_4.cjs.entry.js.map +0 -1
  113. package/dist/components/p-0adcc84f.js.map +0 -1
  114. package/dist/esm/bcm-accordion_4.entry.js +0 -616
  115. package/dist/esm/bcm-accordion_4.entry.js.map +0 -1
  116. package/dist/esm/index-ce2fac11.js.map +0 -1
@@ -0,0 +1,549 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ const index = require('./index-c36002ae.js');
6
+ const index$1 = require('./index-310db2a6.js');
7
+ const index$2 = require('./index-a4eea4bb.js');
8
+
9
+ const variantOptions = {
10
+ save: {
11
+ text: 'Save',
12
+ status: 'success',
13
+ icon: 'far fa-save',
14
+ iconPosition: 'prefix',
15
+ kind: 'primary',
16
+ },
17
+ ok: {
18
+ text: 'Ok',
19
+ status: 'success',
20
+ icon: 'far fa-check',
21
+ iconPosition: 'prefix',
22
+ },
23
+ new: {
24
+ text: 'New',
25
+ status: 'success',
26
+ icon: 'far fa-plus',
27
+ iconPosition: 'prefix',
28
+ },
29
+ add: {
30
+ text: 'Add',
31
+ status: 'success',
32
+ icon: 'far fa-plus',
33
+ iconPosition: 'prefix',
34
+ },
35
+ create: {
36
+ text: 'Create',
37
+ status: 'success',
38
+ icon: 'far fa-plus',
39
+ iconPosition: 'prefix',
40
+ },
41
+ prev: {
42
+ text: 'Prev',
43
+ status: 'default',
44
+ icon: 'far fa-arrow-left',
45
+ iconPosition: 'prefix',
46
+ },
47
+ next: {
48
+ text: 'Next',
49
+ status: 'default',
50
+ icon: 'far fa-arrow-right',
51
+ iconPosition: 'suffix',
52
+ },
53
+ apply: {
54
+ text: 'Apply',
55
+ status: 'default',
56
+ icon: 'far fa-check-circle',
57
+ iconPosition: 'prefix',
58
+ },
59
+ submit: {
60
+ text: 'Submit',
61
+ status: 'default',
62
+ icon: 'far fa-save',
63
+ iconPosition: 'prefix',
64
+ },
65
+ send: {
66
+ text: 'Send',
67
+ status: 'success',
68
+ icon: 'far fa-paper-plane',
69
+ iconPosition: 'prefix',
70
+ },
71
+ delete: {
72
+ text: 'Delete',
73
+ status: 'error',
74
+ icon: 'far fa-trash',
75
+ iconPosition: 'prefix',
76
+ },
77
+ cancel: {
78
+ text: 'Cancel',
79
+ status: 'error',
80
+ icon: 'far fa-times',
81
+ iconPosition: 'prefix',
82
+ },
83
+ decline: {
84
+ text: 'Decline',
85
+ status: 'error',
86
+ icon: 'far fa-ban',
87
+ iconPosition: 'prefix',
88
+ },
89
+ close: {
90
+ text: 'Close',
91
+ status: 'error',
92
+ icon: 'far fa-times-circle',
93
+ iconPosition: 'prefix',
94
+ },
95
+ archive: {
96
+ text: 'Archive',
97
+ status: 'error',
98
+ icon: 'far fa-folder-open',
99
+ iconPosition: 'prefix',
100
+ },
101
+ remove: {
102
+ text: 'Remove',
103
+ status: 'error',
104
+ icon: 'far fa-minus-circle',
105
+ iconPosition: 'prefix',
106
+ },
107
+ edit: {
108
+ text: 'Edit',
109
+ status: 'default',
110
+ icon: 'far fa-edit',
111
+ iconPosition: 'prefix',
112
+ },
113
+ export: {
114
+ text: 'Export',
115
+ status: 'default',
116
+ icon: 'far fa-sign-out',
117
+ iconPosition: 'prefix',
118
+ },
119
+ import: {
120
+ text: 'Import',
121
+ status: 'default',
122
+ icon: 'far fa-sign-in',
123
+ iconPosition: 'prefix',
124
+ },
125
+ filter: {
126
+ text: 'Filter',
127
+ status: 'default',
128
+ icon: 'far fa-filter',
129
+ iconPosition: 'prefix',
130
+ },
131
+ update: {
132
+ text: 'Update',
133
+ status: 'default',
134
+ icon: 'far fa-sync',
135
+ iconPosition: 'prefix',
136
+ },
137
+ reset: {
138
+ text: 'Reset',
139
+ status: 'default',
140
+ icon: 'far fa-sync',
141
+ iconPosition: 'prefix',
142
+ },
143
+ download: {
144
+ text: 'Download',
145
+ status: 'default',
146
+ icon: 'far fa-download',
147
+ iconPosition: 'prefix',
148
+ },
149
+ };
150
+
151
+ const buttonCss = ":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)}";
152
+ const BcmButtonStyle0 = buttonCss;
153
+
154
+ const BcmButton = class {
155
+ constructor(hostRef) {
156
+ index.registerInstance(this, hostRef);
157
+ this.bcmClick = index.createEvent(this, "bcmClick", 1);
158
+ this.bcmFocus = index.createEvent(this, "bcmFocus", 1);
159
+ this.bcmBlur = index.createEvent(this, "bcmBlur", 1);
160
+ /** Defines the main visual style of the button */
161
+ this.kind = 'primary';
162
+ /** Controls the button size */
163
+ this.size = 'medium';
164
+ /** Defines the button's status/state color */
165
+ this.status = 'default';
166
+ /** Icon placement (prefix/suffix) */
167
+ this.iconPosition = 'prefix';
168
+ /** Icon-only button mode */
169
+ this.iconOnly = false;
170
+ /** Full width button */
171
+ this.fullWidth = false;
172
+ /** HTML button type */
173
+ this.type = 'button';
174
+ /** Loading state */
175
+ this.loading = false;
176
+ /** Disabled state */
177
+ this.disabled = false;
178
+ /** Active state */
179
+ this.active = false;
180
+ this.handleClick = (event) => {
181
+ if (!this.disabled && !this.loading) {
182
+ this.bcmClick.emit(event);
183
+ }
184
+ };
185
+ this.handleFocus = (event) => {
186
+ this.bcmFocus.emit(event);
187
+ };
188
+ this.handleBlur = (event) => {
189
+ this.bcmBlur.emit(event);
190
+ };
191
+ this.buttonClass = index$1.ce({
192
+ base: 'bcm-button appearance-none inline-flex items-center justify-center border border-solid rounded outline-0',
193
+ variants: {
194
+ size: {
195
+ small: 'text-size-4 py-px px-2 min-h-6',
196
+ medium: 'text-size-5 py-0.5 px-3 min-h-8',
197
+ large: 'text-size-6 py-1 px-3 min-h-10',
198
+ },
199
+ kind: {
200
+ primary: 'kind-primary',
201
+ ghost: 'kind-ghost',
202
+ text: 'kind-text',
203
+ outline: 'kind-outline',
204
+ },
205
+ fullWidth: {
206
+ true: 'full-width w-full',
207
+ },
208
+ disabled: {
209
+ true: 'disabled cursor-not-allowed bg-[--bcm-ui-color-background-disabled-default] text-color-disabled border-color-disabled',
210
+ false: [
211
+ 'cursor-pointer',
212
+ 'bg-[--bcm-button-bg] text-[--bcm-button-text] border-[--bcm-button-border]',
213
+ 'hover:bg-[--bcm-button-bg-hover]',
214
+ 'active:bg-[--bcm-button-bg-active]',
215
+ 'focus-visible:ring',
216
+ ],
217
+ },
218
+ loading: {
219
+ true: '',
220
+ },
221
+ },
222
+ defaultVariants: {
223
+ size: 'medium',
224
+ kind: 'primary',
225
+ fullWidth: false,
226
+ disabled: false,
227
+ loading: false,
228
+ },
229
+ }, {
230
+ twMerge: false,
231
+ });
232
+ }
233
+ get buttonText() {
234
+ return this.text || (this.variant ? variantOptions[this.variant].text : '');
235
+ }
236
+ get buttonIcon() {
237
+ if (this.variant && variantOptions[this.variant].icon) {
238
+ return {
239
+ icon: variantOptions[this.variant].icon,
240
+ position: variantOptions[this.variant].iconPosition || 'prefix',
241
+ };
242
+ }
243
+ return {
244
+ icon: this.icon,
245
+ position: this.iconPosition,
246
+ };
247
+ }
248
+ get buttonStatus() {
249
+ return this.variant ? variantOptions[this.variant].status : this.status;
250
+ }
251
+ get buttonStyles() {
252
+ const status = this.buttonStatus === 'default' ? 'primary' : this.buttonStatus;
253
+ const kindStyleMap = {
254
+ primary: {
255
+ '--bcm-button-bg': `var(--bcm-ui-color-background-${status}-default)`,
256
+ '--bcm-button-bg-hover': `var(--bcm-ui-color-background-${status}-hover)`,
257
+ '--bcm-button-bg-active': `var(--bcm-ui-color-background-${status}-active)`,
258
+ '--bcm-button-border': 'transparent',
259
+ '--bcm-button-text': 'var(--bcm-ui-color-text-base)',
260
+ },
261
+ outline: {
262
+ '--bcm-button-bg': 'var(--bcm-ui-color-background-default-default)',
263
+ '--bcm-button-bg-hover': 'var(--bcm-ui-color-background-default-hover)',
264
+ '--bcm-button-bg-active': 'var(--bcm-ui-color-background-default-active)',
265
+ '--bcm-button-border': `var(--bcm-ui-color-border-${this.buttonStatus})`,
266
+ '--bcm-button-text': `var(--bcm-ui-color-text-${this.buttonStatus})`,
267
+ },
268
+ ghost: {
269
+ '--bcm-button-bg': 'transparent',
270
+ '--bcm-button-bg-hover': 'var(--bcm-ui-color-background-default-hover)',
271
+ '--bcm-button-bg-active': 'var(--bcm-ui-color-background-default-active)',
272
+ '--bcm-button-border': 'transparent',
273
+ '--bcm-button-text': `var(--bcm-ui-color-text-${this.buttonStatus})`,
274
+ },
275
+ text: {
276
+ '--bcm-button-bg': 'transparent',
277
+ '--bcm-button-bg-hover': 'var(--bcm-ui-color-background-default-hover)',
278
+ '--bcm-button-bg-active': 'var(--bcm-ui-color-background-default-active)',
279
+ '--bcm-button-border': 'transparent',
280
+ '--bcm-button-text': `var(--bcm-ui-color-text-${status})`,
281
+ },
282
+ };
283
+ return kindStyleMap[this.kind];
284
+ }
285
+ render() {
286
+ const { icon, position } = this.buttonIcon;
287
+ return (index.h(index.Host, { key: '72bb1d2567880894e0c4c7667670e267faa9a6dd' }, index.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({
288
+ size: this.size,
289
+ kind: this.kind,
290
+ fullWidth: this.fullWidth,
291
+ disabled: this.disabled,
292
+ loading: this.loading,
293
+ }) }, this.loading && index.h("slot", { key: 'c8a58aac8903477638cec974e32cdcd728e1ee8d', name: "loading" }), index.h("span", { key: '9690dfa5a312885da070ff90036b898c06f69621' }, index.h("slot", { key: '66eed1efbf522aec86d32ddbf0e9e8e68cbbb592', name: "prefix" }, position === 'prefix' && icon && index.h("i", { key: 'b0f91818830bd7e74d3d5cb6f957fa05f15b29a5', class: ' leading-none ' + icon }))), index.h("slot", { key: '7dbb0221b6119d61bc94c67355659e99a5bc75f5' }, this.buttonText), index.h("span", { key: 'd7547cc65575eef30ee8816b40de4485b0286b83' }, index.h("slot", { key: '32bd079256e6ca4a74572a726d459a3cb691a3ed', name: "suffix" }, position === 'suffix' && icon && index.h("i", { key: '66c307ec0637537986cb454f5cf718afc5715529', class: ' leading-none ' + icon }))))));
294
+ }
295
+ };
296
+ BcmButton.style = BcmButtonStyle0;
297
+
298
+ const byteToHex = [];
299
+ for (let i = 0; i < 256; ++i) {
300
+ byteToHex.push((i + 0x100).toString(16).slice(1));
301
+ }
302
+ function unsafeStringify(arr, offset = 0) {
303
+ return (byteToHex[arr[offset + 0]] +
304
+ byteToHex[arr[offset + 1]] +
305
+ byteToHex[arr[offset + 2]] +
306
+ byteToHex[arr[offset + 3]] +
307
+ '-' +
308
+ byteToHex[arr[offset + 4]] +
309
+ byteToHex[arr[offset + 5]] +
310
+ '-' +
311
+ byteToHex[arr[offset + 6]] +
312
+ byteToHex[arr[offset + 7]] +
313
+ '-' +
314
+ byteToHex[arr[offset + 8]] +
315
+ byteToHex[arr[offset + 9]] +
316
+ '-' +
317
+ byteToHex[arr[offset + 10]] +
318
+ byteToHex[arr[offset + 11]] +
319
+ byteToHex[arr[offset + 12]] +
320
+ byteToHex[arr[offset + 13]] +
321
+ byteToHex[arr[offset + 14]] +
322
+ byteToHex[arr[offset + 15]]).toLowerCase();
323
+ }
324
+
325
+ let getRandomValues;
326
+ const rnds8 = new Uint8Array(16);
327
+ function rng() {
328
+ if (!getRandomValues) {
329
+ if (typeof crypto === 'undefined' || !crypto.getRandomValues) {
330
+ throw new Error('crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported');
331
+ }
332
+ getRandomValues = crypto.getRandomValues.bind(crypto);
333
+ }
334
+ return getRandomValues(rnds8);
335
+ }
336
+
337
+ const randomUUID = typeof crypto !== 'undefined' && crypto.randomUUID && crypto.randomUUID.bind(crypto);
338
+ const native = { randomUUID };
339
+
340
+ function v4(options, buf, offset) {
341
+ if (native.randomUUID && !buf && !options) {
342
+ return native.randomUUID();
343
+ }
344
+ options = options || {};
345
+ const rnds = options.random ?? options.rng?.() ?? rng();
346
+ if (rnds.length < 16) {
347
+ throw new Error('Random bytes length must be >= 16');
348
+ }
349
+ rnds[6] = (rnds[6] & 0x0f) | 0x40;
350
+ rnds[8] = (rnds[8] & 0x3f) | 0x80;
351
+ if (buf) {
352
+ offset = offset || 0;
353
+ if (offset < 0 || offset + 16 > buf.length) {
354
+ throw new RangeError(`UUID byte range ${offset}:${offset + 15} is out of buffer bounds`);
355
+ }
356
+ for (let i = 0; i < 16; ++i) {
357
+ buf[offset + i] = rnds[i];
358
+ }
359
+ return buf;
360
+ }
361
+ return unsafeStringify(rnds);
362
+ }
363
+
364
+ /**
365
+ * Generates a unique identifier with an optional prefix.
366
+ * @param prefix - Optional prefix for the generated ID (default: 'bcm')
367
+ * @returns A unique string ID in the format "prefix-uuid"
368
+ * @example
369
+ * const id = generateId('button'); // -> "button-123e4567-e89b..."
370
+ * const defaultId = generateId(); // -> "bcm-123e4567-e89b..."
371
+ */
372
+ const generateId = (prefix = 'bcm') => {
373
+ if (!prefix) {
374
+ throw new Error('Prefix cannot be empty');
375
+ }
376
+ return `${prefix}-${v4()}`;
377
+ };
378
+
379
+ const inputCss = ".visible{visibility:visible}.collapse{visibility:collapse}.relative{position:relative}.block{display:block}.table{display:table}.contents{display:contents}.hidden{display:none}.border-collapse{border-collapse:collapse}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.resize{resize:both}.border{border-width:1px}.underline{text-decoration-line:underline}.outline{outline-style:solid}/*! tailwindcss v3.4.17 | MIT License | https://tailwindcss.com*/*,:after,:before{border:0 solid oklch(.928 .006 264.531);box-sizing:border-box}:after,:before{--tw-content:\"\"}:host,html{-webkit-text-size-adjust:100%;font-feature-settings:normal;-webkit-tap-highlight-color:transparent;font-family:Inter,sans-serif;font-variation-settings:normal;line-height:1.5;-moz-tab-size:4;-o-tab-size:4;tab-size:4}body{line-height:inherit;margin:0}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-feature-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em;font-variation-settings:normal}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}button,input,optgroup,select,textarea{font-feature-settings:inherit;color:inherit;font-family:inherit;font-size:100%;font-variation-settings:inherit;font-weight:inherit;letter-spacing:inherit;line-height:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,fieldset,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{color:oklch(.707 .022 261.325);opacity:1}input::placeholder,textarea::placeholder{color:oklch(.707 .022 261.325);opacity:1}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}[hidden]:where(:not([hidden=until-found])){display:none}:host{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}.h-10{height:2.5rem}.h-6{height:1.5rem}.h-8{height:2rem}.w-full{width:100%}.flex-1{flex:1 1 0%}.cursor-not-allowed{cursor:not-allowed}.appearance-none{appearance:none}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.text-ellipsis{text-overflow:ellipsis}.rounded{border-radius:.25rem}.border-0{border-width:0}.border-solid{border-style:solid}.border-\\[--bcm-ui-color-border-default\\]{border-color:var(--bcm-ui-color-border-default)}.bg-\\[--bcm-ui-color-background-base-default\\]{background-color:var(--bcm-ui-color-background-base-default)}.bg-transparent{background-color:transparent}.px-3{padding-left:.75rem;padding-right:.75rem}.font-sans{font-family:Inter,sans-serif}.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)}.text-size-6{font-size:var(--bcm-ui-font-size-6,18px);line-height:var(--bcm-ui-line-height-6,24px)}.font-medium{font-weight:500}.text-\\[--bcm-ui-color-text-default\\]{color:var(--bcm-ui-color-text-default)}.text-color-caption{color:var(--bcm-ui-color-text-caption)}.text-color-disabled{color:var(--bcm-ui-color-text-disabled)}.text-color-error{color:var(--bcm-ui-color-text-error)}.text-color-info{color:var(--bcm-ui-color-text-info)}.text-color-label{color:var(--bcm-ui-color-text-label)}.text-color-success{color:var(--bcm-ui-color-text-success)}.text-color-warning{color:var(--bcm-ui-color-text-warning)}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.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-0{outline-width:0}.ring{--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)}.blur{--tw-blur:blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.placeholder\\:font-normal::placeholder{font-weight:400}.placeholder\\:text-\\[--bcm-ui-color-text-placeholder\\]::placeholder{color:var(--bcm-ui-color-text-placeholder)}";
380
+ const BcmInputStyle0 = inputCss;
381
+
382
+ const BcmInput = class {
383
+ constructor(hostRef) {
384
+ index.registerInstance(this, hostRef);
385
+ this.bcmInput = index.createEvent(this, "bcmInput", 1);
386
+ this.bcmChange = index.createEvent(this, "bcmChange", 1);
387
+ this.bcmFocus = index.createEvent(this, "bcmFocus", 1);
388
+ this.bcmBlur = index.createEvent(this, "bcmBlur", 1);
389
+ this.bcmKeyDown = index.createEvent(this, "bcmKeyDown", 1);
390
+ this.bcmKeyUp = index.createEvent(this, "bcmKeyUp", 1);
391
+ this.isFocused = false;
392
+ /** Input value */
393
+ this.value = '';
394
+ /** Input id */
395
+ this._id = generateId('input');
396
+ /** Controls the input size */
397
+ this.size = 'medium';
398
+ /** Defines the input's status/state */
399
+ this.status = 'default';
400
+ /** Full width input */
401
+ this.fullWidth = false;
402
+ /** HTML input type */
403
+ this.type = 'text';
404
+ /** Whether the input is disabled */
405
+ this.disabled = false;
406
+ /** Whether the input is readonly */
407
+ this.readonly = false;
408
+ /** Whether the input is required */
409
+ this.required = false;
410
+ this.onInput = (event) => {
411
+ const input = event.target;
412
+ this.value = input.value;
413
+ this.bcmInput.emit(event);
414
+ };
415
+ this.onChange = (event) => {
416
+ this.bcmChange.emit(event);
417
+ };
418
+ this.onFocus = (event) => {
419
+ this.isFocused = true;
420
+ this.bcmFocus.emit(event);
421
+ };
422
+ this.onBlur = (event) => {
423
+ this.isFocused = false;
424
+ this.bcmBlur.emit(event);
425
+ };
426
+ this.onKeyDown = (event) => {
427
+ this.bcmKeyDown.emit(event);
428
+ };
429
+ this.onKeyUp = (event) => {
430
+ this.bcmKeyUp.emit(event);
431
+ };
432
+ this.styleClass = index$1.ce({
433
+ slots: {
434
+ base: [
435
+ 'bcm-input bcm-input__container',
436
+ 'bg-[--bcm-ui-color-background-base-default] border-[--bcm-ui-color-border-default]',
437
+ 'border border-solid rounded',
438
+ 'flex items-center justify-between gap-2',
439
+ // 'px-3',
440
+ ],
441
+ inputClass: [
442
+ 'input',
443
+ 'w-full flex-1',
444
+ 'border-0 outline-0 bg-transparent',
445
+ 'appearance-none text-ellipsis',
446
+ 'text-[--bcm-ui-color-text-default] placeholder:text-[--bcm-ui-color-text-placeholder] placeholder:font-normal',
447
+ 'font-sans antialiased font-medium',
448
+ ],
449
+ },
450
+ variants: {
451
+ size: {
452
+ small: {
453
+ base: '',
454
+ inputClass: 'text-size-4 px-3 h-6',
455
+ },
456
+ medium: {
457
+ base: '',
458
+ inputClass: 'text-size-5 px-3 h-8',
459
+ },
460
+ large: {
461
+ base: '',
462
+ inputClass: 'text-size-6 px-3 h-10',
463
+ },
464
+ },
465
+ fullWidth: {
466
+ true: 'full-width w-full',
467
+ },
468
+ disabled: {
469
+ true: 'disabled cursor-not-allowed',
470
+ false: '',
471
+ },
472
+ focused: {
473
+ true: {
474
+ base: 'ring',
475
+ },
476
+ },
477
+ },
478
+ defaultVariants: {
479
+ size: 'medium',
480
+ fullWidth: false,
481
+ disabled: false,
482
+ focused: false,
483
+ },
484
+ }, {
485
+ twMerge: false,
486
+ });
487
+ }
488
+ handleValueChange(newValue) {
489
+ if (this.inputRef) {
490
+ this.inputRef.value = newValue;
491
+ }
492
+ }
493
+ async setFocus() {
494
+ var _a;
495
+ (_a = this.inputRef) === null || _a === void 0 ? void 0 : _a.focus();
496
+ }
497
+ async setBlur() {
498
+ var _a;
499
+ (_a = this.inputRef) === null || _a === void 0 ? void 0 : _a.blur();
500
+ }
501
+ async select() {
502
+ var _a;
503
+ (_a = this.inputRef) === null || _a === void 0 ? void 0 : _a.select();
504
+ }
505
+ // private inputStyles = {
506
+ // '--bcm-input-bg': `var(--bcm-ui-color-background-${this.status}-default)`,
507
+ // '--bcm-button-bg-hover': `var(--bcm-ui-color-background-${this.status}-hover)`,
508
+ // '--bcm-button-bg-active': `var(--bcm-ui-color-background-${this.status}-active)`,
509
+ // '--bcm-button-border': 'transparent',
510
+ // '--bcm-button-text': 'var(--bcm-ui-color-text-base)',
511
+ // };
512
+ render() {
513
+ const inputId = this._id + '-input' || this.name;
514
+ const { base, inputClass } = this.styleClass({
515
+ size: this.size,
516
+ fullWidth: this.fullWidth,
517
+ disabled: this.disabled,
518
+ focused: this.isFocused,
519
+ });
520
+ return (index.h("div", { key: '4e8b381764b3bf96ccd8e8506286d0e88e989a30', class: "bcm-ui-element" }, this.label && (index.h("label", { key: 'dc213a515a6596e388b4a60c23c498f8bdd22247', class: index$2.cs('input-label font-medium', {
521
+ 'text-color-label': !this.disabled,
522
+ 'text-color-disabled': this.disabled,
523
+ }, {
524
+ 'text-size-3': this.size === 'small',
525
+ 'text-size-4': this.size === 'medium',
526
+ 'text-size-5': this.size === 'large',
527
+ }), htmlFor: inputId }, index.h("slot", { key: '513585e5000edf7f7f9e3ff73241b7203e3433a3', name: "label" }, this.label), this.required && index.h("span", { key: '5ffc16ce50aa435033518ce1b7a2e616150f99ca' }, "*"))), index.h("div", { key: '3a9d0bdbc9d1d6949a05088c889d7feb2fa6d64b', class: base() }, index.h("slot", { key: '3d10c90faeb1ee767de8f5261551c8bd62652856', name: "prefix" }), this.prefixIcon && index.h("bcm-icon", { key: 'e4e01b842c49cac8da1f2ac2e37a80311caa32d3', class: "prefix-icon", "icon-name": this.prefixIcon }), index.h("input", { key: '17d404e0e63f2b89ad1be1a564c0a462e76bbd72', ref: el => (this.inputRef = el), id: inputId, class: inputClass(), type: this.type, name: this.name, disabled: this.disabled, readonly: this.readonly, required: this.required, placeholder: this.placeholder, autocomplete: this.autocomplete, minlength: this.minLength, maxlength: this.maxLength, min: this.min, max: this.max, step: this.step, pattern: this.pattern, "aria-invalid": this.status === 'error', "aria-required": this.required, "aria-labelledby": this.labelledby, "aria-describedby": this.describedby, value: this.value, onInput: this.onInput, onChange: this.onChange, onFocus: this.onFocus, onBlur: this.onBlur, onKeyDown: this.onKeyDown, onKeyUp: this.onKeyUp }), this.suffixIcon && index.h("bcm-icon", { key: '293c7b2d1853bb86c7733d70201817b5c809f645', class: "suffix-icon", "icon-name": this.suffixIcon }), index.h("slot", { key: '0ccd4968dbeeff480e452c23fb10913df8436dc6', name: "suffix" })), (this.captionText || this.errorMessage) && (index.h("div", { key: '30f7cd413c012c755dd0297d252afacf1405c1fb', class: index$2.cs('input-caption-text font-regular', {
528
+ 'text-color-caption': !this.disabled && this.status === 'default',
529
+ 'text-color-error': !this.disabled && this.status === 'error',
530
+ 'text-color-success': !this.disabled && this.status === 'success',
531
+ 'text-color-warning': !this.disabled && this.status === 'warning',
532
+ 'text-color-info': !this.disabled && this.status === 'info',
533
+ 'text-color-disabled': this.disabled,
534
+ }, {
535
+ 'text-size-3': this.size === 'small',
536
+ 'text-size-4': this.size === 'medium',
537
+ 'text-size-5': this.size === 'large',
538
+ }) }, this.status === 'error' ? this.errorMessage : this.captionText))));
539
+ }
540
+ static get watchers() { return {
541
+ "value": ["handleValueChange"]
542
+ }; }
543
+ };
544
+ BcmInput.style = BcmInputStyle0;
545
+
546
+ exports.bcm_button = BcmButton;
547
+ exports.bcm_input = BcmInput;
548
+
549
+ //# sourceMappingURL=bcm-button_2.cjs.entry.js.map
@@ -0,0 +1 @@
1
+ {"file":"bcm-button.bcm-input.entry.cjs.js","mappings":"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","names":["tv","h","Host","uuidv4","classNames"],"sources":["src/components/button/types.ts","src/components/button/button.css?tag=bcm-button&encapsulation=shadow","src/components/button/button.component.tsx","node_modules/uuid/dist/esm-browser/stringify.js","node_modules/uuid/dist/esm-browser/rng.js","node_modules/uuid/dist/esm-browser/native.js","node_modules/uuid/dist/esm-browser/v4.js","src/utils/id/generate-id.ts","src/components/input/input.scss?tag=bcm-input&encapsulation=shadow","src/components/input/input.component.tsx"],"sourcesContent":["export type ButtonKind = 'primary' | 'ghost' | 'text' | 'outline';\nexport type ButtonSize = 'small' | 'medium' | 'large';\nexport type ButtonType = 'button' | 'reset' | 'submit';\nexport type ButtonStatus = 'default' | 'success' | 'error' | 'warning' | 'info';\nexport type IconPosition = 'prefix' | 'suffix';\n\ninterface ButtonVariantConfig {\n text: string;\n status: ButtonStatus;\n icon?: string;\n iconPosition?: IconPosition;\n kind?: ButtonKind;\n}\n\nexport const variantOptions: Record<string, ButtonVariantConfig> = {\n save: {\n text: 'Save',\n status: 'success',\n icon: 'far fa-save',\n iconPosition: 'prefix',\n kind: 'primary',\n },\n ok: {\n text: 'Ok',\n status: 'success',\n icon: 'far fa-check',\n iconPosition: 'prefix',\n },\n new: {\n text: 'New',\n status: 'success',\n icon: 'far fa-plus',\n iconPosition: 'prefix',\n },\n add: {\n text: 'Add',\n status: 'success',\n icon: 'far fa-plus',\n iconPosition: 'prefix',\n },\n create: {\n text: 'Create',\n status: 'success',\n icon: 'far fa-plus',\n iconPosition: 'prefix',\n },\n prev: {\n text: 'Prev',\n status: 'default',\n icon: 'far fa-arrow-left',\n iconPosition: 'prefix',\n },\n next: {\n text: 'Next',\n status: 'default',\n icon: 'far fa-arrow-right',\n iconPosition: 'suffix',\n },\n apply: {\n text: 'Apply',\n status: 'default',\n icon: 'far fa-check-circle',\n iconPosition: 'prefix',\n },\n submit: {\n text: 'Submit',\n status: 'default',\n icon: 'far fa-save',\n iconPosition: 'prefix',\n },\n send: {\n text: 'Send',\n status: 'success',\n icon: 'far fa-paper-plane',\n iconPosition: 'prefix',\n },\n delete: {\n text: 'Delete',\n status: 'error',\n icon: 'far fa-trash',\n iconPosition: 'prefix',\n },\n cancel: {\n text: 'Cancel',\n status: 'error',\n icon: 'far fa-times',\n iconPosition: 'prefix',\n },\n decline: {\n text: 'Decline',\n status: 'error',\n icon: 'far fa-ban',\n iconPosition: 'prefix',\n },\n close: {\n text: 'Close',\n status: 'error',\n icon: 'far fa-times-circle',\n iconPosition: 'prefix',\n },\n archive: {\n text: 'Archive',\n status: 'error',\n icon: 'far fa-folder-open',\n iconPosition: 'prefix',\n },\n remove: {\n text: 'Remove',\n status: 'error',\n icon: 'far fa-minus-circle',\n iconPosition: 'prefix',\n },\n edit: {\n text: 'Edit',\n status: 'default',\n icon: 'far fa-edit',\n iconPosition: 'prefix',\n },\n export: {\n text: 'Export',\n status: 'default',\n icon: 'far fa-sign-out',\n iconPosition: 'prefix',\n },\n import: {\n text: 'Import',\n status: 'default',\n icon: 'far fa-sign-in',\n iconPosition: 'prefix',\n },\n filter: {\n text: 'Filter',\n status: 'default',\n icon: 'far fa-filter',\n iconPosition: 'prefix',\n },\n update: {\n text: 'Update',\n status: 'default',\n icon: 'far fa-sync',\n iconPosition: 'prefix',\n },\n reset: {\n text: 'Reset',\n status: 'default',\n icon: 'far fa-sync',\n iconPosition: 'prefix',\n },\n download: {\n text: 'Download',\n status: 'default',\n icon: 'far fa-download',\n iconPosition: 'prefix',\n },\n};\n\nexport type ButtonVariant = keyof typeof variantOptions;\n",":host {\n display: inline-block;\n}\n\n:host([full-width]) {\n width: 100%;\n}\n","import { Component, Prop, h, Event, EventEmitter, Host } from '@stencil/core';\nimport { ButtonKind, ButtonSize, ButtonType, ButtonStatus, ButtonVariant, IconPosition, variantOptions } from './types';\nimport { tv } from 'tailwind-variants';\n\n@Component({\n tag: 'bcm-button',\n styleUrl: 'button.css',\n shadow: true,\n})\nexport class BcmButton {\n /** Defines the main visual style of the button */\n @Prop()\n kind: ButtonKind = 'primary';\n\n /** Controls the button size */\n @Prop()\n size: ButtonSize = 'medium';\n\n /** Defines the button's status/state color */\n @Prop()\n status: ButtonStatus = 'default';\n\n /** Predefined button variants */\n @Prop()\n variant?: ButtonVariant;\n\n /** Icon class name */\n @Prop()\n icon?: string;\n\n /** Icon placement (prefix/suffix) */\n @Prop()\n iconPosition: IconPosition = 'prefix';\n\n /** Icon-only button mode */\n @Prop()\n iconOnly = false;\n\n /** Full width button */\n @Prop({ attribute: 'full-width', reflect: true })\n fullWidth = false;\n\n /** HTML button type */\n @Prop()\n type: ButtonType = 'button';\n\n /** Loading state */\n @Prop()\n loading = false;\n\n /** Disabled state */\n @Prop()\n disabled = false;\n\n /** Button text content */\n @Prop()\n text?: string;\n\n /** Active state */\n @Prop()\n active = false;\n\n /** Form association */\n @Prop()\n form: string;\n\n @Prop()\n value: string;\n\n @Prop()\n name: string;\n\n /** Screen reader label */\n @Prop()\n label: string;\n\n /** Expanded state for expandable content */\n @Prop()\n expanded?: string;\n\n /** ID of controlled element */\n @Prop()\n controls: string;\n\n @Event({\n composed: false,\n bubbles: false,\n cancelable: true,\n })\n bcmClick: EventEmitter<MouseEvent>;\n\n @Event({\n composed: false,\n bubbles: false,\n cancelable: true,\n })\n bcmFocus: EventEmitter<FocusEvent>;\n\n @Event({\n composed: false,\n bubbles: false,\n cancelable: true,\n })\n bcmBlur: EventEmitter<FocusEvent>;\n\n private handleClick = (event: MouseEvent) => {\n if (!this.disabled && !this.loading) {\n this.bcmClick.emit(event);\n }\n };\n\n private handleFocus = (event: FocusEvent) => {\n this.bcmFocus.emit(event);\n };\n\n private handleBlur = (event: FocusEvent) => {\n this.bcmBlur.emit(event);\n };\n\n private get buttonText(): string {\n return this.text || (this.variant ? variantOptions[this.variant].text : '');\n }\n\n private get buttonIcon(): { icon?: string; position: IconPosition } {\n if (this.variant && variantOptions[this.variant].icon) {\n return {\n icon: variantOptions[this.variant].icon,\n position: variantOptions[this.variant].iconPosition || 'prefix',\n };\n }\n\n return {\n icon: this.icon,\n position: this.iconPosition,\n };\n }\n\n private get buttonStatus(): ButtonStatus {\n return this.variant ? variantOptions[this.variant].status : this.status;\n }\n\n private get buttonStyles() {\n const status = this.buttonStatus === 'default' ? 'primary' : this.buttonStatus;\n\n const kindStyleMap = {\n primary: {\n '--bcm-button-bg': `var(--bcm-ui-color-background-${status}-default)`,\n '--bcm-button-bg-hover': `var(--bcm-ui-color-background-${status}-hover)`,\n '--bcm-button-bg-active': `var(--bcm-ui-color-background-${status}-active)`,\n '--bcm-button-border': 'transparent',\n '--bcm-button-text': 'var(--bcm-ui-color-text-base)',\n },\n outline: {\n '--bcm-button-bg': 'var(--bcm-ui-color-background-default-default)',\n '--bcm-button-bg-hover': 'var(--bcm-ui-color-background-default-hover)',\n '--bcm-button-bg-active': 'var(--bcm-ui-color-background-default-active)',\n '--bcm-button-border': `var(--bcm-ui-color-border-${this.buttonStatus})`,\n '--bcm-button-text': `var(--bcm-ui-color-text-${this.buttonStatus})`,\n },\n ghost: {\n '--bcm-button-bg': 'transparent',\n '--bcm-button-bg-hover': 'var(--bcm-ui-color-background-default-hover)',\n '--bcm-button-bg-active': 'var(--bcm-ui-color-background-default-active)',\n '--bcm-button-border': 'transparent',\n '--bcm-button-text': `var(--bcm-ui-color-text-${this.buttonStatus})`,\n },\n text: {\n '--bcm-button-bg': 'transparent',\n '--bcm-button-bg-hover': 'var(--bcm-ui-color-background-default-hover)',\n '--bcm-button-bg-active': 'var(--bcm-ui-color-background-default-active)',\n '--bcm-button-border': 'transparent',\n '--bcm-button-text': `var(--bcm-ui-color-text-${status})`,\n },\n };\n\n return kindStyleMap[this.kind];\n }\n\n private buttonClass = tv(\n {\n base: 'bcm-button appearance-none inline-flex items-center justify-center border border-solid rounded outline-0',\n variants: {\n size: {\n small: 'text-size-4 py-px px-2 min-h-6',\n medium: 'text-size-5 py-0.5 px-3 min-h-8',\n large: 'text-size-6 py-1 px-3 min-h-10',\n },\n kind: {\n primary: 'kind-primary',\n ghost: 'kind-ghost',\n text: 'kind-text',\n outline: 'kind-outline',\n },\n fullWidth: {\n true: 'full-width w-full',\n },\n disabled: {\n true: 'disabled cursor-not-allowed bg-[--bcm-ui-color-background-disabled-default] text-color-disabled border-color-disabled',\n false: [\n 'cursor-pointer',\n 'bg-[--bcm-button-bg] text-[--bcm-button-text] border-[--bcm-button-border]',\n 'hover:bg-[--bcm-button-bg-hover]',\n 'active:bg-[--bcm-button-bg-active]',\n 'focus-visible:ring',\n ],\n },\n loading: {\n true: '',\n },\n },\n defaultVariants: {\n size: 'medium',\n kind: 'primary',\n fullWidth: false,\n disabled: false,\n loading: false,\n },\n },\n {\n twMerge: false,\n },\n );\n\n render() {\n const { icon, position } = this.buttonIcon;\n\n return (\n <Host>\n <button\n type={this.type}\n disabled={this.disabled || this.loading}\n aria-label={this.label}\n aria-expanded={this.expanded}\n aria-controls={this.controls}\n aria-disabled={this.disabled}\n onClick={this.handleClick}\n onFocus={this.handleFocus}\n onBlur={this.handleBlur}\n style={this.buttonStyles}\n class={this.buttonClass({\n size: this.size,\n kind: this.kind,\n fullWidth: this.fullWidth,\n disabled: this.disabled,\n loading: this.loading,\n })}\n >\n {this.loading && <slot name=\"loading\"></slot>}\n <span>\n <slot name=\"prefix\">{position === 'prefix' && icon && <i class={' leading-none ' + icon}></i>}</slot>\n </span>\n <slot>{this.buttonText}</slot>\n <span>\n <slot name=\"suffix\">{position === 'suffix' && icon && <i class={' leading-none ' + icon}></i>}</slot>\n </span>\n </button>\n </Host>\n );\n }\n}\n","import validate from './validate.js';\nconst byteToHex = [];\nfor (let i = 0; i < 256; ++i) {\n byteToHex.push((i + 0x100).toString(16).slice(1));\n}\nexport function unsafeStringify(arr, offset = 0) {\n return (byteToHex[arr[offset + 0]] +\n byteToHex[arr[offset + 1]] +\n byteToHex[arr[offset + 2]] +\n byteToHex[arr[offset + 3]] +\n '-' +\n byteToHex[arr[offset + 4]] +\n byteToHex[arr[offset + 5]] +\n '-' +\n byteToHex[arr[offset + 6]] +\n byteToHex[arr[offset + 7]] +\n '-' +\n byteToHex[arr[offset + 8]] +\n byteToHex[arr[offset + 9]] +\n '-' +\n byteToHex[arr[offset + 10]] +\n byteToHex[arr[offset + 11]] +\n byteToHex[arr[offset + 12]] +\n byteToHex[arr[offset + 13]] +\n byteToHex[arr[offset + 14]] +\n byteToHex[arr[offset + 15]]).toLowerCase();\n}\nfunction stringify(arr, offset = 0) {\n const uuid = unsafeStringify(arr, offset);\n if (!validate(uuid)) {\n throw TypeError('Stringified UUID is invalid');\n }\n return uuid;\n}\nexport default stringify;\n","let getRandomValues;\nconst rnds8 = new Uint8Array(16);\nexport default function rng() {\n if (!getRandomValues) {\n if (typeof crypto === 'undefined' || !crypto.getRandomValues) {\n throw new Error('crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported');\n }\n getRandomValues = crypto.getRandomValues.bind(crypto);\n }\n return getRandomValues(rnds8);\n}\n","const randomUUID = typeof crypto !== 'undefined' && crypto.randomUUID && crypto.randomUUID.bind(crypto);\nexport default { randomUUID };\n","import native from './native.js';\nimport rng from './rng.js';\nimport { unsafeStringify } from './stringify.js';\nfunction v4(options, buf, offset) {\n if (native.randomUUID && !buf && !options) {\n return native.randomUUID();\n }\n options = options || {};\n const rnds = options.random ?? options.rng?.() ?? rng();\n if (rnds.length < 16) {\n throw new Error('Random bytes length must be >= 16');\n }\n rnds[6] = (rnds[6] & 0x0f) | 0x40;\n rnds[8] = (rnds[8] & 0x3f) | 0x80;\n if (buf) {\n offset = offset || 0;\n if (offset < 0 || offset + 16 > buf.length) {\n throw new RangeError(`UUID byte range ${offset}:${offset + 15} is out of buffer bounds`);\n }\n for (let i = 0; i < 16; ++i) {\n buf[offset + i] = rnds[i];\n }\n return buf;\n }\n return unsafeStringify(rnds);\n}\nexport default v4;\n","import { v4 as uuidv4 } from 'uuid';\n\n/**\n * Generates a unique identifier with an optional prefix.\n * @param prefix - Optional prefix for the generated ID (default: 'bcm')\n * @returns A unique string ID in the format \"prefix-uuid\"\n * @example\n * const id = generateId('button'); // -> \"button-123e4567-e89b...\"\n * const defaultId = generateId(); // -> \"bcm-123e4567-e89b...\"\n */\nexport const generateId = (prefix = 'bcm'): string => {\n if (!prefix) {\n throw new Error('Prefix cannot be empty');\n }\n return `${prefix}-${uuidv4()}`;\n};\n",":host {\n display: inline-block;\n}\n","import { Component, Prop, h, Event, EventEmitter, Method, State, Watch } from '@stencil/core';\nimport { InputSize, InputStatus, InputType } from './types';\nimport { tv } from 'tailwind-variants';\nimport classNames from 'classnames';\nimport { generateId } from '../../utils/id/generate-id';\n\n@Component({\n tag: 'bcm-input',\n styleUrl: 'input.scss',\n shadow: true,\n})\nexport class BcmInput {\n private inputRef: HTMLInputElement;\n\n @State() isFocused = false;\n\n /** Input value */\n @Prop({ mutable: true, reflect: true })\n value: string = '';\n\n /** Input placeholder text */\n @Prop()\n placeholder?: string;\n\n /** Input name */\n @Prop()\n name?: string;\n\n /** Input id */\n @Prop({ attribute: 'id', reflect: true })\n _id?: string = generateId('input');\n\n /** Controls the input size */\n @Prop()\n size: InputSize = 'medium';\n\n /** Defines the input's status/state */\n @Prop()\n status: InputStatus = 'default';\n\n /** Full width input */\n @Prop({ attribute: 'full-width', reflect: true })\n fullWidth = false;\n\n /** HTML input type */\n @Prop()\n type: InputType = 'text';\n\n /** Whether the input is disabled */\n @Prop()\n disabled = false;\n\n /** Whether the input is readonly */\n @Prop()\n readonly = false;\n\n /** Whether the input is required */\n @Prop()\n required = false;\n\n /** Input autocomplete attribute */\n @Prop()\n autocomplete?: string;\n\n /** Min length for text input */\n @Prop()\n minLength?: number;\n\n /** Max length for text input */\n @Prop()\n maxLength?: number;\n\n /** Min value for number input */\n @Prop()\n min?: number;\n\n /** Max value for number input */\n @Prop()\n max?: number;\n\n /** Step value for number input */\n @Prop()\n step?: number;\n\n /** Pattern for validation */\n @Prop()\n pattern?: string;\n\n /** Input label for accessibility */\n @Prop()\n label?: string;\n\n /** Error message to display */\n @Prop()\n errorMessage?: string;\n\n /** Caption text to display below input */\n @Prop()\n captionText?: string;\n\n /** ID of associated label element */\n @Prop()\n labelledby?: string;\n\n /** ID of associated caption/error text element */\n @Prop()\n describedby?: string;\n\n /** Prefix icon class name */\n @Prop()\n prefixIcon?: string;\n\n /** Suffix icon class name */\n @Prop()\n suffixIcon?: string;\n\n @Event({\n composed: false,\n bubbles: false,\n cancelable: true,\n })\n bcmInput: EventEmitter<InputEvent>;\n\n @Event({\n composed: false,\n bubbles: false,\n cancelable: true,\n })\n bcmChange: EventEmitter<Event>;\n\n @Event({\n composed: false,\n bubbles: false,\n cancelable: true,\n })\n bcmFocus: EventEmitter<FocusEvent>;\n\n @Event({\n composed: false,\n bubbles: false,\n cancelable: true,\n })\n bcmBlur: EventEmitter<FocusEvent>;\n\n @Event({\n composed: false,\n bubbles: false,\n cancelable: true,\n })\n bcmKeyDown: EventEmitter<KeyboardEvent>;\n\n @Event({\n composed: false,\n bubbles: false,\n cancelable: true,\n })\n bcmKeyUp: EventEmitter<KeyboardEvent>;\n\n @Watch('value')\n handleValueChange(newValue: string) {\n if (this.inputRef) {\n this.inputRef.value = newValue;\n }\n }\n\n @Method()\n async setFocus() {\n this.inputRef?.focus();\n }\n\n @Method()\n async setBlur() {\n this.inputRef?.blur();\n }\n\n @Method()\n async select() {\n this.inputRef?.select();\n }\n\n private onInput = (event: InputEvent) => {\n const input = event.target as HTMLInputElement;\n this.value = input.value;\n this.bcmInput.emit(event);\n };\n\n private onChange = (event: Event) => {\n this.bcmChange.emit(event);\n };\n\n private onFocus = (event: FocusEvent) => {\n this.isFocused = true;\n this.bcmFocus.emit(event);\n };\n\n private onBlur = (event: FocusEvent) => {\n this.isFocused = false;\n this.bcmBlur.emit(event);\n };\n\n private onKeyDown = (event: KeyboardEvent) => {\n this.bcmKeyDown.emit(event);\n };\n\n private onKeyUp = (event: KeyboardEvent) => {\n this.bcmKeyUp.emit(event);\n };\n\n private styleClass = tv(\n {\n slots: {\n base: [\n 'bcm-input bcm-input__container',\n 'bg-[--bcm-ui-color-background-base-default] border-[--bcm-ui-color-border-default]',\n 'border border-solid rounded',\n 'flex items-center justify-between gap-2',\n // 'px-3',\n ],\n inputClass: [\n 'input',\n 'w-full flex-1',\n 'border-0 outline-0 bg-transparent',\n 'appearance-none text-ellipsis',\n 'text-[--bcm-ui-color-text-default] placeholder:text-[--bcm-ui-color-text-placeholder] placeholder:font-normal',\n 'font-sans antialiased font-medium',\n ],\n },\n variants: {\n size: {\n small: {\n base: '',\n inputClass: 'text-size-4 px-3 h-6',\n },\n medium: {\n base: '',\n inputClass: 'text-size-5 px-3 h-8',\n },\n large: {\n base: '',\n inputClass: 'text-size-6 px-3 h-10',\n },\n },\n fullWidth: {\n true: 'full-width w-full',\n },\n disabled: {\n true: 'disabled cursor-not-allowed',\n false: '',\n },\n focused: {\n true: {\n base: 'ring',\n },\n },\n },\n defaultVariants: {\n size: 'medium',\n fullWidth: false,\n disabled: false,\n focused: false,\n },\n },\n {\n twMerge: false,\n },\n );\n\n // private inputStyles = {\n // '--bcm-input-bg': `var(--bcm-ui-color-background-${this.status}-default)`,\n // '--bcm-button-bg-hover': `var(--bcm-ui-color-background-${this.status}-hover)`,\n // '--bcm-button-bg-active': `var(--bcm-ui-color-background-${this.status}-active)`,\n // '--bcm-button-border': 'transparent',\n // '--bcm-button-text': 'var(--bcm-ui-color-text-base)',\n // };\n\n render() {\n const inputId = this._id + '-input' || this.name;\n\n const { base, inputClass } = this.styleClass({\n size: this.size,\n fullWidth: this.fullWidth,\n disabled: this.disabled,\n focused: this.isFocused,\n });\n\n return (\n <div class=\"bcm-ui-element\">\n {this.label && (\n <label\n class={classNames(\n 'input-label font-medium',\n {\n 'text-color-label': !this.disabled,\n 'text-color-disabled': this.disabled,\n },\n {\n 'text-size-3': this.size === 'small',\n 'text-size-4': this.size === 'medium',\n 'text-size-5': this.size === 'large',\n },\n )}\n htmlFor={inputId}\n >\n <slot name=\"label\">{this.label}</slot>\n {this.required && <span>*</span>}\n </label>\n )}\n\n <div class={base()}>\n <slot name=\"prefix\"></slot>\n {this.prefixIcon && <bcm-icon class=\"prefix-icon\" icon-name={this.prefixIcon}></bcm-icon>}\n <input\n ref={el => (this.inputRef = el)}\n id={inputId}\n class={inputClass()}\n type={this.type}\n name={this.name}\n disabled={this.disabled}\n readonly={this.readonly}\n required={this.required}\n placeholder={this.placeholder}\n autocomplete={this.autocomplete}\n minlength={this.minLength}\n maxlength={this.maxLength}\n min={this.min}\n max={this.max}\n step={this.step}\n pattern={this.pattern}\n aria-invalid={this.status === 'error'}\n aria-required={this.required}\n aria-labelledby={this.labelledby}\n aria-describedby={this.describedby}\n value={this.value}\n onInput={this.onInput}\n onChange={this.onChange}\n onFocus={this.onFocus}\n onBlur={this.onBlur}\n onKeyDown={this.onKeyDown}\n onKeyUp={this.onKeyUp}\n />\n {this.suffixIcon && <bcm-icon class=\"suffix-icon\" icon-name={this.suffixIcon}></bcm-icon>}\n <slot name=\"suffix\"></slot>\n </div>\n {(this.captionText || this.errorMessage) && (\n <div\n class={classNames(\n 'input-caption-text font-regular',\n {\n 'text-color-caption': !this.disabled && this.status === 'default',\n 'text-color-error': !this.disabled && this.status === 'error',\n 'text-color-success': !this.disabled && this.status === 'success',\n 'text-color-warning': !this.disabled && this.status === 'warning',\n 'text-color-info': !this.disabled && this.status === 'info',\n 'text-color-disabled': this.disabled,\n },\n {\n 'text-size-3': this.size === 'small',\n 'text-size-4': this.size === 'medium',\n 'text-size-5': this.size === 'large',\n },\n )}\n >\n {this.status === 'error' ? this.errorMessage : this.captionText}\n </div>\n )}\n </div>\n );\n }\n}\n"],"version":3}