bromcom-ui-next 0.1.4 → 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 (170) 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-1d86c1cf.entry.js → p-2bbd3c52.entry.js} +2 -2
  5. package/dist/bromcom-ui/{p-1d86c1cf.entry.js.map → p-2bbd3c52.entry.js.map} +1 -1
  6. package/dist/bromcom-ui/p-2f1d87a7.entry.js +2 -0
  7. package/dist/bromcom-ui/p-2f1d87a7.entry.js.map +1 -0
  8. package/dist/bromcom-ui/{p-1b11150b.entry.js → p-4f402148.entry.js} +2 -2
  9. package/dist/bromcom-ui/{p-1b11150b.entry.js.map → p-4f402148.entry.js.map} +1 -1
  10. package/dist/bromcom-ui/p-53f21d16.entry.js +2 -0
  11. package/dist/bromcom-ui/{p-dcea8d62.entry.js.map → p-53f21d16.entry.js.map} +1 -1
  12. package/dist/bromcom-ui/{p-04f6d730.entry.js → p-5737e7de.entry.js} +2 -2
  13. package/dist/bromcom-ui/{p-04f6d730.entry.js.map → p-5737e7de.entry.js.map} +1 -1
  14. package/dist/bromcom-ui/{p-5d0838e9.entry.js → p-5bee2e76.entry.js} +2 -2
  15. package/dist/bromcom-ui/{p-5d0838e9.entry.js.map → p-5bee2e76.entry.js.map} +1 -1
  16. package/dist/bromcom-ui/p-63cb0933.entry.js +2 -0
  17. package/dist/bromcom-ui/p-63cb0933.entry.js.map +1 -0
  18. package/dist/bromcom-ui/{p-a590f793.entry.js → p-6abaf96f.entry.js} +2 -2
  19. package/dist/bromcom-ui/{p-a590f793.entry.js.map → p-6abaf96f.entry.js.map} +1 -1
  20. package/dist/bromcom-ui/{p-cd437280.entry.js → p-7a1bf6a6.entry.js} +2 -2
  21. package/dist/bromcom-ui/{p-cd437280.entry.js.map → p-7a1bf6a6.entry.js.map} +1 -1
  22. package/dist/bromcom-ui/{p-3b607038.entry.js → p-e08b23ff.entry.js} +2 -2
  23. package/dist/bromcom-ui/{p-3b607038.entry.js.map → p-e08b23ff.entry.js.map} +1 -1
  24. package/dist/bromcom-ui/p-f0ece968.entry.js +2 -0
  25. package/dist/bromcom-ui/p-f0ece968.entry.js.map +1 -0
  26. package/dist/bromcom-ui/{p-ebed10d5.entry.js → p-f9eeafa7.entry.js} +2 -2
  27. package/dist/bromcom-ui/{p-ebed10d5.entry.js.map → p-f9eeafa7.entry.js.map} +1 -1
  28. package/dist/bromcom-ui/styles/theme-variables.ts +369 -0
  29. package/dist/bromcom-ui/styles/themes/index.css +1 -0
  30. package/dist/bromcom-ui/styles/themes/library/default.css +73 -0
  31. package/dist/bromcom-ui/styles/variables/box-shadow.css +15 -0
  32. package/dist/bromcom-ui/styles/variables/colors-dark.css +314 -0
  33. package/dist/bromcom-ui/styles/variables/colors-light.css +325 -0
  34. package/dist/bromcom-ui/styles/variables/font-size-rem.css +33 -0
  35. package/dist/bromcom-ui/styles/variables/font-size.css +33 -0
  36. package/dist/bromcom-ui/styles/variables/index.css +6 -0
  37. package/dist/cjs/bcm-accordion-group.cjs.entry.js +1 -1
  38. package/dist/cjs/bcm-accordion-group.cjs.entry.js.map +1 -1
  39. package/dist/cjs/bcm-accordion.cjs.entry.js +1 -1
  40. package/dist/cjs/bcm-accordion.cjs.entry.js.map +1 -1
  41. package/dist/cjs/bcm-alert.cjs.entry.js +1 -1
  42. package/dist/cjs/bcm-alert.cjs.entry.js.map +1 -1
  43. package/dist/cjs/bcm-avatar_4.cjs.entry.js +4 -4
  44. package/dist/cjs/bcm-avatar_4.cjs.entry.js.map +1 -1
  45. package/dist/cjs/bcm-chip.cjs.entry.js +1 -1
  46. package/dist/cjs/bcm-chip.cjs.entry.js.map +1 -1
  47. package/dist/cjs/bcm-divider.cjs.entry.js +1 -1
  48. package/dist/cjs/bcm-divider.cjs.entry.js.map +1 -1
  49. package/dist/cjs/bcm-dropdown-item.cjs.entry.js +63 -0
  50. package/dist/cjs/bcm-dropdown-item.cjs.entry.js.map +1 -0
  51. package/dist/cjs/bcm-dropdown.cjs.entry.js +56 -0
  52. package/dist/cjs/bcm-dropdown.cjs.entry.js.map +1 -0
  53. package/dist/cjs/bcm-input.cjs.entry.js +3 -3
  54. package/dist/cjs/bcm-input.cjs.entry.js.map +1 -1
  55. package/dist/cjs/bcm-linked.cjs.entry.js +1981 -0
  56. package/dist/cjs/bcm-linked.cjs.entry.js.map +1 -0
  57. package/dist/cjs/bcm-text.cjs.entry.js +2 -2
  58. package/dist/cjs/bcm-text.cjs.entry.js.map +1 -1
  59. package/dist/cjs/bcm-textarea.cjs.entry.js +4 -4
  60. package/dist/cjs/bcm-textarea.cjs.entry.js.map +1 -1
  61. package/dist/cjs/bromcom-ui.cjs.js +1 -1
  62. package/dist/cjs/loader.cjs.js +1 -1
  63. package/dist/collection/collection-manifest.json +3 -0
  64. package/dist/collection/components/accordion/accordion.css +1 -1
  65. package/dist/collection/components/accordion-group/accordion-group.css +1 -1
  66. package/dist/collection/components/alert/alert.css +1 -1
  67. package/dist/collection/components/avatar/avatar.css +1 -1
  68. package/dist/collection/components/badge/badge.css +1 -1
  69. package/dist/collection/components/basic-badge/basic-badge.css +1 -1
  70. package/dist/collection/components/button/button.css +1 -1
  71. package/dist/collection/components/chip/chip.css +1 -1
  72. package/dist/collection/components/divider/divider.css +1 -1
  73. package/dist/collection/components/dropdown/dropdown.component.js +110 -0
  74. package/dist/collection/components/dropdown/dropdown.component.js.map +1 -0
  75. package/dist/collection/components/dropdown/dropdown.css +1 -0
  76. package/dist/collection/components/dropdown-item/dropdown-item.component.js +198 -0
  77. package/dist/collection/components/dropdown-item/dropdown-item.component.js.map +1 -0
  78. package/dist/collection/components/dropdown-item/dropdown-item.css +1 -0
  79. package/dist/collection/components/input/input.component.js +2 -2
  80. package/dist/collection/components/input/input.css +1 -1
  81. package/dist/collection/components/linked/linked.component.js +140 -0
  82. package/dist/collection/components/linked/linked.component.js.map +1 -0
  83. package/dist/collection/components/linked/linked.css +1 -0
  84. package/dist/collection/components/text/text.component.js +1 -1
  85. package/dist/collection/components/text/text.css +1 -1
  86. package/dist/collection/components/textarea/textarea.component.js +3 -3
  87. package/dist/collection/components/textarea/textarea.css +1 -1
  88. package/dist/collection/styles/theme-variables.js +15 -0
  89. package/dist/collection/styles/theme-variables.js.map +1 -1
  90. package/dist/collection/styles/theme-variables.ts +369 -0
  91. package/dist/collection/styles/themes/index.css +1 -0
  92. package/dist/collection/styles/themes/library/default.css +73 -0
  93. package/dist/collection/styles/variables/box-shadow.css +15 -0
  94. package/dist/collection/styles/variables/colors-dark.css +314 -0
  95. package/dist/collection/styles/variables/colors-light.css +325 -0
  96. package/dist/collection/styles/variables/font-size-rem.css +33 -0
  97. package/dist/collection/styles/variables/font-size.css +33 -0
  98. package/dist/collection/styles/variables/index.css +6 -0
  99. package/dist/components/bcm-accordion-group.js +1 -1
  100. package/dist/components/bcm-accordion-group.js.map +1 -1
  101. package/dist/components/bcm-accordion.js +1 -1
  102. package/dist/components/bcm-accordion.js.map +1 -1
  103. package/dist/components/bcm-alert.js +1 -1
  104. package/dist/components/bcm-alert.js.map +1 -1
  105. package/dist/components/bcm-avatar.js +2 -2
  106. package/dist/components/bcm-avatar.js.map +1 -1
  107. package/dist/components/bcm-badge.js +1 -1
  108. package/dist/components/bcm-basic-badge.js +1 -1
  109. package/dist/components/bcm-basic-badge.js.map +1 -1
  110. package/dist/components/bcm-button.js +1 -327
  111. package/dist/components/bcm-button.js.map +1 -1
  112. package/dist/components/bcm-chip.js +1 -1
  113. package/dist/components/bcm-chip.js.map +1 -1
  114. package/dist/components/bcm-divider.js +1 -1
  115. package/dist/components/bcm-divider.js.map +1 -1
  116. package/dist/components/bcm-dropdown-item.d.ts +11 -0
  117. package/dist/components/bcm-dropdown-item.js +85 -0
  118. package/dist/components/bcm-dropdown-item.js.map +1 -0
  119. package/dist/components/bcm-dropdown.d.ts +11 -0
  120. package/dist/components/bcm-dropdown.js +87 -0
  121. package/dist/components/bcm-dropdown.js.map +1 -0
  122. package/dist/components/bcm-input.js +3 -3
  123. package/dist/components/bcm-input.js.map +1 -1
  124. package/dist/components/bcm-linked.d.ts +11 -0
  125. package/dist/components/bcm-linked.js +8 -0
  126. package/dist/components/bcm-linked.js.map +1 -0
  127. package/dist/components/bcm-text.js +2 -2
  128. package/dist/components/bcm-text.js.map +1 -1
  129. package/dist/components/bcm-textarea.js +4 -4
  130. package/dist/components/bcm-textarea.js.map +1 -1
  131. package/dist/components/p-0063a3d9.js +331 -0
  132. package/dist/components/p-0063a3d9.js.map +1 -0
  133. package/dist/components/p-613ee92d.js +1997 -0
  134. package/dist/components/p-613ee92d.js.map +1 -0
  135. package/dist/components/{p-39637e05.js → p-e918f815.js} +2 -2
  136. package/dist/components/{p-39637e05.js.map → p-e918f815.js.map} +1 -1
  137. package/dist/esm/bcm-accordion-group.entry.js +1 -1
  138. package/dist/esm/bcm-accordion-group.entry.js.map +1 -1
  139. package/dist/esm/bcm-accordion.entry.js +1 -1
  140. package/dist/esm/bcm-accordion.entry.js.map +1 -1
  141. package/dist/esm/bcm-alert.entry.js +1 -1
  142. package/dist/esm/bcm-alert.entry.js.map +1 -1
  143. package/dist/esm/bcm-avatar_4.entry.js +4 -4
  144. package/dist/esm/bcm-avatar_4.entry.js.map +1 -1
  145. package/dist/esm/bcm-chip.entry.js +1 -1
  146. package/dist/esm/bcm-chip.entry.js.map +1 -1
  147. package/dist/esm/bcm-divider.entry.js +1 -1
  148. package/dist/esm/bcm-divider.entry.js.map +1 -1
  149. package/dist/esm/bcm-dropdown-item.entry.js +59 -0
  150. package/dist/esm/bcm-dropdown-item.entry.js.map +1 -0
  151. package/dist/esm/bcm-dropdown.entry.js +52 -0
  152. package/dist/esm/bcm-dropdown.entry.js.map +1 -0
  153. package/dist/esm/bcm-input.entry.js +3 -3
  154. package/dist/esm/bcm-input.entry.js.map +1 -1
  155. package/dist/esm/bcm-linked.entry.js +1977 -0
  156. package/dist/esm/bcm-linked.entry.js.map +1 -0
  157. package/dist/esm/bcm-text.entry.js +2 -2
  158. package/dist/esm/bcm-text.entry.js.map +1 -1
  159. package/dist/esm/bcm-textarea.entry.js +4 -4
  160. package/dist/esm/bcm-textarea.entry.js.map +1 -1
  161. package/dist/esm/bromcom-ui.js +1 -1
  162. package/dist/esm/loader.js +1 -1
  163. package/dist/tailwind.config.js +32 -0
  164. package/dist/types/components/dropdown/dropdown.component.d.ts +14 -0
  165. package/dist/types/components/dropdown-item/dropdown-item.component.d.ts +14 -0
  166. package/dist/types/components/linked/linked.component.d.ts +16 -0
  167. package/dist/types/components.d.ts +89 -0
  168. package/dist/types/styles/theme-variables.d.ts +15 -0
  169. package/package.json +2 -1
  170. package/dist/bromcom-ui/p-dcea8d62.entry.js +0 -2
@@ -0,0 +1,331 @@
1
+ import { p as proxyCustomElement, H, c as createEvent, h, d as Host } from './p-13582168.js';
2
+ import { c as ce } from './p-5fcf77f9.js';
3
+
4
+ const variantOptions = {
5
+ save: {
6
+ text: 'Save',
7
+ status: 'success',
8
+ icon: 'far fa-save',
9
+ iconPosition: 'prefix',
10
+ kind: 'primary',
11
+ },
12
+ ok: {
13
+ text: 'Ok',
14
+ status: 'success',
15
+ icon: 'far fa-check',
16
+ iconPosition: 'prefix',
17
+ },
18
+ new: {
19
+ text: 'New',
20
+ status: 'success',
21
+ icon: 'far fa-plus',
22
+ iconPosition: 'prefix',
23
+ },
24
+ add: {
25
+ text: 'Add',
26
+ status: 'success',
27
+ icon: 'far fa-plus',
28
+ iconPosition: 'prefix',
29
+ },
30
+ create: {
31
+ text: 'Create',
32
+ status: 'success',
33
+ icon: 'far fa-plus',
34
+ iconPosition: 'prefix',
35
+ },
36
+ prev: {
37
+ text: 'Prev',
38
+ status: 'default',
39
+ icon: 'far fa-arrow-left',
40
+ iconPosition: 'prefix',
41
+ },
42
+ next: {
43
+ text: 'Next',
44
+ status: 'default',
45
+ icon: 'far fa-arrow-right',
46
+ iconPosition: 'suffix',
47
+ },
48
+ apply: {
49
+ text: 'Apply',
50
+ status: 'default',
51
+ icon: 'far fa-check-circle',
52
+ iconPosition: 'prefix',
53
+ },
54
+ submit: {
55
+ text: 'Submit',
56
+ status: 'default',
57
+ icon: 'far fa-save',
58
+ iconPosition: 'prefix',
59
+ },
60
+ send: {
61
+ text: 'Send',
62
+ status: 'success',
63
+ icon: 'far fa-paper-plane',
64
+ iconPosition: 'prefix',
65
+ },
66
+ delete: {
67
+ text: 'Delete',
68
+ status: 'error',
69
+ icon: 'far fa-trash',
70
+ iconPosition: 'prefix',
71
+ },
72
+ cancel: {
73
+ text: 'Cancel',
74
+ status: 'error',
75
+ icon: 'far fa-times',
76
+ iconPosition: 'prefix',
77
+ },
78
+ decline: {
79
+ text: 'Decline',
80
+ status: 'error',
81
+ icon: 'far fa-ban',
82
+ iconPosition: 'prefix',
83
+ },
84
+ close: {
85
+ text: 'Close',
86
+ status: 'error',
87
+ icon: 'far fa-times-circle',
88
+ iconPosition: 'prefix',
89
+ },
90
+ archive: {
91
+ text: 'Archive',
92
+ status: 'error',
93
+ icon: 'far fa-folder-open',
94
+ iconPosition: 'prefix',
95
+ },
96
+ remove: {
97
+ text: 'Remove',
98
+ status: 'error',
99
+ icon: 'far fa-minus-circle',
100
+ iconPosition: 'prefix',
101
+ },
102
+ edit: {
103
+ text: 'Edit',
104
+ status: 'default',
105
+ icon: 'far fa-edit',
106
+ iconPosition: 'prefix',
107
+ },
108
+ export: {
109
+ text: 'Export',
110
+ status: 'default',
111
+ icon: 'far fa-sign-out',
112
+ iconPosition: 'prefix',
113
+ },
114
+ import: {
115
+ text: 'Import',
116
+ status: 'default',
117
+ icon: 'far fa-sign-in',
118
+ iconPosition: 'prefix',
119
+ },
120
+ filter: {
121
+ text: 'Filter',
122
+ status: 'default',
123
+ icon: 'far fa-filter',
124
+ iconPosition: 'prefix',
125
+ },
126
+ update: {
127
+ text: 'Update',
128
+ status: 'default',
129
+ icon: 'far fa-sync',
130
+ iconPosition: 'prefix',
131
+ },
132
+ reset: {
133
+ text: 'Reset',
134
+ status: 'default',
135
+ icon: 'far fa-sync',
136
+ iconPosition: 'prefix',
137
+ },
138
+ download: {
139
+ text: 'Download',
140
+ status: 'default',
141
+ icon: 'far fa-download',
142
+ iconPosition: 'prefix',
143
+ },
144
+ };
145
+
146
+ const buttonCss = ".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)}";
147
+ const BcmButtonStyle0 = buttonCss;
148
+
149
+ const BcmButton = /*@__PURE__*/ proxyCustomElement(class BcmButton extends H {
150
+ constructor() {
151
+ super();
152
+ this.__registerHost();
153
+ this.__attachShadow();
154
+ this.bcmClick = createEvent(this, "bcmClick", 1);
155
+ this.bcmFocus = createEvent(this, "bcmFocus", 1);
156
+ this.bcmBlur = createEvent(this, "bcmBlur", 1);
157
+ /** Defines the main visual style of the button */
158
+ this.kind = 'primary';
159
+ /** Controls the button size */
160
+ this.size = 'medium';
161
+ /** Defines the button's status/state color */
162
+ this.status = 'default';
163
+ /** Icon placement (prefix/suffix) */
164
+ this.iconPosition = 'prefix';
165
+ /** Icon-only button mode */
166
+ this.iconOnly = false;
167
+ /** Full width button */
168
+ this.fullWidth = false;
169
+ /** HTML button type */
170
+ this.type = 'button';
171
+ /** Loading state */
172
+ this.loading = false;
173
+ /** Disabled state */
174
+ this.disabled = false;
175
+ /** Active state */
176
+ this.active = false;
177
+ this.handleClick = (event) => {
178
+ if (!this.disabled && !this.loading) {
179
+ this.bcmClick.emit(event);
180
+ }
181
+ };
182
+ this.handleFocus = (event) => {
183
+ this.bcmFocus.emit(event);
184
+ };
185
+ this.handleBlur = (event) => {
186
+ this.bcmBlur.emit(event);
187
+ };
188
+ this.buttonClass = ce({
189
+ base: 'bcm-button appearance-none inline-flex items-center justify-center border border-solid rounded outline-0',
190
+ variants: {
191
+ size: {
192
+ small: 'text-size-4 py-px px-2 min-h-6',
193
+ medium: 'text-size-5 py-0.5 px-3 min-h-8',
194
+ large: 'text-size-6 py-1 px-3 min-h-10',
195
+ },
196
+ kind: {
197
+ primary: 'kind-primary',
198
+ ghost: 'kind-ghost',
199
+ text: 'kind-text',
200
+ outline: 'kind-outline',
201
+ },
202
+ fullWidth: {
203
+ true: 'full-width w-full',
204
+ },
205
+ disabled: {
206
+ true: 'disabled cursor-not-allowed bg-[--bcm-ui-color-background-disabled-default] text-color-disabled border-color-disabled',
207
+ false: [
208
+ 'cursor-pointer',
209
+ 'bg-[--bcm-button-bg] text-[--bcm-button-text] border-[--bcm-button-border]',
210
+ 'hover:bg-[--bcm-button-bg-hover]',
211
+ 'active:bg-[--bcm-button-bg-active]',
212
+ 'focus-visible:ring',
213
+ ],
214
+ },
215
+ loading: {
216
+ true: '',
217
+ },
218
+ },
219
+ defaultVariants: {
220
+ size: 'medium',
221
+ kind: 'primary',
222
+ fullWidth: false,
223
+ disabled: false,
224
+ loading: false,
225
+ },
226
+ }, {
227
+ twMerge: false,
228
+ });
229
+ }
230
+ get buttonText() {
231
+ return this.text || (this.variant ? variantOptions[this.variant].text : '');
232
+ }
233
+ get buttonIcon() {
234
+ if (this.variant && variantOptions[this.variant].icon) {
235
+ return {
236
+ icon: variantOptions[this.variant].icon,
237
+ position: variantOptions[this.variant].iconPosition || 'prefix',
238
+ };
239
+ }
240
+ return {
241
+ icon: this.icon,
242
+ position: this.iconPosition,
243
+ };
244
+ }
245
+ get buttonStatus() {
246
+ return this.variant ? variantOptions[this.variant].status : this.status;
247
+ }
248
+ get buttonStyles() {
249
+ const status = this.buttonStatus === 'default' ? 'primary' : this.buttonStatus;
250
+ const kindStyleMap = {
251
+ primary: {
252
+ '--bcm-button-bg': `var(--bcm-ui-color-background-${status}-default)`,
253
+ '--bcm-button-bg-hover': `var(--bcm-ui-color-background-${status}-hover)`,
254
+ '--bcm-button-bg-active': `var(--bcm-ui-color-background-${status}-active)`,
255
+ '--bcm-button-border': 'transparent',
256
+ '--bcm-button-text': 'var(--bcm-ui-color-text-base)',
257
+ },
258
+ outline: {
259
+ '--bcm-button-bg': 'var(--bcm-ui-color-background-default-default)',
260
+ '--bcm-button-bg-hover': 'var(--bcm-ui-color-background-default-hover)',
261
+ '--bcm-button-bg-active': 'var(--bcm-ui-color-background-default-active)',
262
+ '--bcm-button-border': `var(--bcm-ui-color-border-${this.buttonStatus})`,
263
+ '--bcm-button-text': `var(--bcm-ui-color-text-${this.buttonStatus})`,
264
+ },
265
+ ghost: {
266
+ '--bcm-button-bg': 'transparent',
267
+ '--bcm-button-bg-hover': 'var(--bcm-ui-color-background-default-hover)',
268
+ '--bcm-button-bg-active': 'var(--bcm-ui-color-background-default-active)',
269
+ '--bcm-button-border': 'transparent',
270
+ '--bcm-button-text': `var(--bcm-ui-color-text-${this.buttonStatus})`,
271
+ },
272
+ text: {
273
+ '--bcm-button-bg': 'transparent',
274
+ '--bcm-button-bg-hover': 'var(--bcm-ui-color-background-default-hover)',
275
+ '--bcm-button-bg-active': 'var(--bcm-ui-color-background-default-active)',
276
+ '--bcm-button-border': 'transparent',
277
+ '--bcm-button-text': `var(--bcm-ui-color-text-${status})`,
278
+ },
279
+ };
280
+ return kindStyleMap[this.kind];
281
+ }
282
+ render() {
283
+ const { icon, position } = this.buttonIcon;
284
+ 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({
285
+ size: this.size,
286
+ kind: this.kind,
287
+ fullWidth: this.fullWidth,
288
+ disabled: this.disabled,
289
+ loading: this.loading,
290
+ }) }, 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 }))))));
291
+ }
292
+ static get style() { return BcmButtonStyle0; }
293
+ }, [1, "bcm-button", {
294
+ "kind": [1],
295
+ "size": [1],
296
+ "status": [1],
297
+ "variant": [1],
298
+ "icon": [1],
299
+ "iconPosition": [1, "icon-position"],
300
+ "iconOnly": [4, "icon-only"],
301
+ "fullWidth": [516, "full-width"],
302
+ "type": [1],
303
+ "loading": [4],
304
+ "disabled": [4],
305
+ "text": [1],
306
+ "active": [4],
307
+ "form": [1],
308
+ "value": [1],
309
+ "name": [1],
310
+ "label": [1],
311
+ "expanded": [1],
312
+ "controls": [1]
313
+ }]);
314
+ function defineCustomElement() {
315
+ if (typeof customElements === "undefined") {
316
+ return;
317
+ }
318
+ const components = ["bcm-button"];
319
+ components.forEach(tagName => { switch (tagName) {
320
+ case "bcm-button":
321
+ if (!customElements.get(tagName)) {
322
+ customElements.define(tagName, BcmButton);
323
+ }
324
+ break;
325
+ } });
326
+ }
327
+ defineCustomElement();
328
+
329
+ export { BcmButton as B, defineCustomElement as d };
330
+
331
+ //# sourceMappingURL=p-0063a3d9.js.map
@@ -0,0 +1 @@
1
+ {"file":"p-0063a3d9.js","mappings":"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","names":["tv"],"sources":["src/components/button/types.ts","src/components/button/button.css?tag=bcm-button&encapsulation=shadow","src/components/button/button.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 position: relative;\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"],"version":3}