rinjani-ui 0.0.1

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.
package/dist/index.cjs ADDED
@@ -0,0 +1 @@
1
+ "use strict";var P=Object.create;var b=Object.defineProperty,D=Object.defineProperties,W=Object.getOwnPropertyDescriptor,j=Object.getOwnPropertyDescriptors,q=Object.getOwnPropertyNames,l=Object.getOwnPropertySymbols,A=Object.getPrototypeOf,x=Object.prototype.hasOwnProperty,c=Object.prototype.propertyIsEnumerable;var v=(e,t,r)=>t in e?b(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,m=(e,t)=>{for(var r in t||(t={}))x.call(t,r)&&v(e,r,t[r]);if(l)for(var r of l(t))c.call(t,r)&&v(e,r,t[r]);return e},w=(e,t)=>D(e,j(t));var f=(e,t)=>{var r={};for(var o in e)x.call(e,o)&&t.indexOf(o)<0&&(r[o]=e[o]);if(e!=null&&l)for(var o of l(e))t.indexOf(o)<0&&c.call(e,o)&&(r[o]=e[o]);return r};var E=(e,t)=>{for(var r in t)b(e,r,{get:t[r],enumerable:!0})},B=(e,t,r,o)=>{if(t&&typeof t=="object"||typeof t=="function")for(let n of q(t))!x.call(e,n)&&n!==r&&b(e,n,{get:()=>t[n],enumerable:!(o=W(t,n))||o.enumerable});return e};var F=(e,t,r)=>(r=e!=null?P(A(e)):{},B(t||!e||!e.__esModule?b(r,"default",{value:e,enumerable:!0}):r,e)),G=e=>B(b({},"__esModule",{value:!0}),e);var H={};E(H,{Button:()=>z});module.exports=G(H);var U=require("react"),s=F(require("clsx"),1);var k="inline-flex items-center justify-center gap-2 rounded font-medium transition-colors focus:outline-none focus:ring-2 focus:ring-offset-1 disabled:opacity-50 disabled:cursor-not-allowed disabled:pointer-events-none",S={"2xs":"text-xs px-2 py-1",xs:"text-xs px-2.5 py-1.5",sm:"text-sm px-3 py-1.5",md:"text-sm px-4 py-2",lg:"text-base px-5 py-2.5",xl:"text-base px-6 py-3","2xl":"text-lg px-7 py-3.5"},a={"2xs":"text-xs",xs:"text-xs",sm:"text-sm",md:"text-base",lg:"text-lg",xl:"text-lg","2xl":"text-xl"},C={solid:{gray:"bg-gray-500 text-white hover:bg-gray-600",red:"bg-red-500 text-white hover:bg-red-600",green:"bg-green-500 text-white hover:bg-green-600",blue:"bg-blue-500 text-white hover:bg-blue-600",teal:"bg-teal-500 text-white hover:bg-teal-600",pink:"bg-pink-500 text-white hover:bg-pink-600",purple:"bg-purple-500 text-white hover:bg-purple-600",cyan:"bg-cyan-500 text-white hover:bg-cyan-600",orange:"bg-orange-500 text-white hover:bg-orange-600",yellow:"bg-yellow-500 text-white hover:bg-yellow-600",indigo:"bg-indigo-500 text-white hover:bg-indigo-600"},outline:{gray:"border border-gray-500 text-gray-500 hover:bg-gray-100",red:"border border-red-500 text-red-500 hover:bg-red-100",green:"border border-green-500 text-green-500 hover:bg-green-100",blue:"border border-blue-500 text-blue-500 hover:bg-blue-100",teal:"border border-teal-500 text-teal-500 hover:bg-teal-100",pink:"border border-pink-500 text-pink-500 hover:bg-pink-100",purple:"border border-purple-500 text-purple-500 hover:bg-purple-100",cyan:"border border-cyan-500 text-cyan-500 hover:bg-cyan-100",orange:"border border-orange-500 text-orange-500 hover:bg-orange-100",yellow:"border border-yellow-500 text-yellow-500 hover:bg-yellow-100",indigo:"border border-indigo-500 text-indigo-500 hover:bg-indigo-100"},surface:{gray:"bg-gray-100 text-gray-800 hover:bg-gray-200",red:"bg-red-100 text-red-800 hover:bg-red-200",green:"bg-green-100 text-green-800 hover:bg-green-200",blue:"bg-blue-100 text-blue-800 hover:bg-blue-200",teal:"bg-teal-100 text-teal-800 hover:bg-teal-200",pink:"bg-pink-100 text-pink-800 hover:bg-pink-200",purple:"bg-purple-100 text-purple-800 hover:bg-purple-200",cyan:"bg-cyan-100 text-cyan-800 hover:bg-cyan-200",orange:"bg-orange-100 text-orange-800 hover:bg-orange-200",yellow:"bg-yellow-100 text-yellow-800 hover:bg-yellow-200",indigo:"bg-indigo-100 text-indigo-800 hover:bg-indigo-200"},subtle:{gray:"bg-gray-50 text-gray-800 hover:bg-gray-100",red:"bg-red-50 text-red-800 hover:bg-red-100",green:"bg-green-50 text-green-800 hover:bg-green-100",blue:"bg-blue-50 text-blue-800 hover:bg-blue-100",teal:"bg-teal-50 text-teal-800 hover:bg-teal-100",pink:"bg-pink-50 text-pink-800 hover:bg-pink-100",purple:"bg-purple-50 text-purple-800 hover:bg-purple-100",cyan:"bg-cyan-50 text-cyan-800 hover:bg-cyan-100",orange:"bg-orange-50 text-orange-800 hover:bg-orange-100",yellow:"bg-yellow-50 text-yellow-800 hover:bg-yellow-100",indigo:"bg-indigo-50 text-indigo-800 hover:bg-indigo-100"}};function N(e,t,r){return r?"bg-gray-200 text-gray-400 cursor-not-allowed":C[t][e]}var g=require("react/jsx-runtime");function z(J){var h=J,{children:e,color:t="blue",variant:r="solid",size:o="md",className:n,startIcon:u,endIcon:y,isLoading:d=!1,loadingIndicator:i,disabled:R=!1,onClick:V}=h,M=f(h,["children","color","variant","size","className","startIcon","endIcon","isLoading","loadingIndicator","disabled","onClick"]);let p=R||d;return(0,g.jsx)("button",w(m({},M),{disabled:p,onClick:p?void 0:V,className:(0,s.default)(k,S[o],N(t,r,p),n),children:d?i!=null?i:(0,g.jsxs)(g.Fragment,{children:[(0,g.jsxs)("svg",{className:(0,s.default)(a[o],"animate-spin"),viewBox:"0 0 24 24",fill:"none",children:[(0,g.jsx)("circle",{className:"opacity-25",cx:"12",cy:"12",r:"10",stroke:"currentColor",strokeWidth:"4"}),(0,g.jsx)("path",{className:"opacity-75",fill:"currentColor",d:"M4 12a8 8 0 018-8v8z"})]}),(0,g.jsx)("span",{children:e})]}):(0,g.jsxs)(g.Fragment,{children:[u&&(0,g.jsx)("span",{className:a[o],children:u}),(0,g.jsx)("span",{children:e}),y&&(0,g.jsx)("span",{className:a[o],children:y})]})}))}0&&(module.exports={Button});
package/dist/index.css ADDED
@@ -0,0 +1,974 @@
1
+ /* src/index.css */
2
+ @layer properties;
3
+ @layer theme, base, components, utilities;
4
+ @layer theme {
5
+ :root,
6
+ :host {
7
+ --font-sans:
8
+ ui-sans-serif,
9
+ system-ui,
10
+ sans-serif,
11
+ "Apple Color Emoji",
12
+ "Segoe UI Emoji",
13
+ "Segoe UI Symbol",
14
+ "Noto Color Emoji";
15
+ --font-mono:
16
+ ui-monospace,
17
+ SFMono-Regular,
18
+ Menlo,
19
+ Monaco,
20
+ Consolas,
21
+ "Liberation Mono",
22
+ "Courier New",
23
+ monospace;
24
+ --color-red-50: oklch(97.1% 0.013 17.38);
25
+ --color-red-100: oklch(93.6% 0.032 17.717);
26
+ --color-red-200: oklch(88.5% 0.062 18.334);
27
+ --color-red-500: oklch(63.7% 0.237 25.331);
28
+ --color-red-600: oklch(57.7% 0.245 27.325);
29
+ --color-red-800: oklch(44.4% 0.177 26.899);
30
+ --color-orange-50: oklch(98% 0.016 73.684);
31
+ --color-orange-100: oklch(95.4% 0.038 75.164);
32
+ --color-orange-200: oklch(90.1% 0.076 70.697);
33
+ --color-orange-500: oklch(70.5% 0.213 47.604);
34
+ --color-orange-600: oklch(64.6% 0.222 41.116);
35
+ --color-orange-800: oklch(47% 0.157 37.304);
36
+ --color-yellow-50: oklch(98.7% 0.026 102.212);
37
+ --color-yellow-100: oklch(97.3% 0.071 103.193);
38
+ --color-yellow-200: oklch(94.5% 0.129 101.54);
39
+ --color-yellow-500: oklch(79.5% 0.184 86.047);
40
+ --color-yellow-600: oklch(68.1% 0.162 75.834);
41
+ --color-yellow-800: oklch(47.6% 0.114 61.907);
42
+ --color-green-50: oklch(98.2% 0.018 155.826);
43
+ --color-green-100: oklch(96.2% 0.044 156.743);
44
+ --color-green-200: oklch(92.5% 0.084 155.995);
45
+ --color-green-500: oklch(72.3% 0.219 149.579);
46
+ --color-green-600: oklch(62.7% 0.194 149.214);
47
+ --color-green-800: oklch(44.8% 0.119 151.328);
48
+ --color-teal-50: oklch(98.4% 0.014 180.72);
49
+ --color-teal-100: oklch(95.3% 0.051 180.801);
50
+ --color-teal-200: oklch(91% 0.096 180.426);
51
+ --color-teal-500: oklch(70.4% 0.14 182.503);
52
+ --color-teal-600: oklch(60% 0.118 184.704);
53
+ --color-teal-800: oklch(43.7% 0.078 188.216);
54
+ --color-cyan-50: oklch(98.4% 0.019 200.873);
55
+ --color-cyan-100: oklch(95.6% 0.045 203.388);
56
+ --color-cyan-200: oklch(91.7% 0.08 205.041);
57
+ --color-cyan-500: oklch(71.5% 0.143 215.221);
58
+ --color-cyan-600: oklch(60.9% 0.126 221.723);
59
+ --color-cyan-800: oklch(45% 0.085 224.283);
60
+ --color-blue-50: oklch(97% 0.014 254.604);
61
+ --color-blue-100: oklch(93.2% 0.032 255.585);
62
+ --color-blue-200: oklch(88.2% 0.059 254.128);
63
+ --color-blue-500: oklch(62.3% 0.214 259.815);
64
+ --color-blue-600: oklch(54.6% 0.245 262.881);
65
+ --color-blue-800: oklch(42.4% 0.199 265.638);
66
+ --color-indigo-50: oklch(96.2% 0.018 272.314);
67
+ --color-indigo-100: oklch(93% 0.034 272.788);
68
+ --color-indigo-200: oklch(87% 0.065 274.039);
69
+ --color-indigo-500: oklch(58.5% 0.233 277.117);
70
+ --color-indigo-600: oklch(51.1% 0.262 276.966);
71
+ --color-indigo-800: oklch(39.8% 0.195 277.366);
72
+ --color-purple-50: oklch(97.7% 0.014 308.299);
73
+ --color-purple-100: oklch(94.6% 0.033 307.174);
74
+ --color-purple-200: oklch(90.2% 0.063 306.703);
75
+ --color-purple-500: oklch(62.7% 0.265 303.9);
76
+ --color-purple-600: oklch(55.8% 0.288 302.321);
77
+ --color-purple-800: oklch(43.8% 0.218 303.724);
78
+ --color-pink-50: oklch(97.1% 0.014 343.198);
79
+ --color-pink-100: oklch(94.8% 0.028 342.258);
80
+ --color-pink-200: oklch(89.9% 0.061 343.231);
81
+ --color-pink-500: oklch(65.6% 0.241 354.308);
82
+ --color-pink-600: oklch(59.2% 0.249 0.584);
83
+ --color-pink-800: oklch(45.9% 0.187 3.815);
84
+ --color-gray-50: oklch(98.5% 0.002 247.839);
85
+ --color-gray-100: oklch(96.7% 0.003 264.542);
86
+ --color-gray-200: oklch(92.8% 0.006 264.531);
87
+ --color-gray-400: oklch(70.7% 0.022 261.325);
88
+ --color-gray-500: oklch(55.1% 0.027 264.364);
89
+ --color-gray-600: oklch(44.6% 0.03 256.802);
90
+ --color-gray-800: oklch(27.8% 0.033 256.848);
91
+ --color-white: #fff;
92
+ --spacing: 0.25rem;
93
+ --text-xs: 0.75rem;
94
+ --text-xs--line-height: calc(1 / 0.75);
95
+ --text-sm: 0.875rem;
96
+ --text-sm--line-height: calc(1.25 / 0.875);
97
+ --text-base: 1rem;
98
+ --text-base--line-height: calc(1.5 / 1);
99
+ --text-lg: 1.125rem;
100
+ --text-lg--line-height: calc(1.75 / 1.125);
101
+ --text-xl: 1.25rem;
102
+ --text-xl--line-height: calc(1.75 / 1.25);
103
+ --font-weight-medium: 500;
104
+ --animate-spin: spin 1s linear infinite;
105
+ --default-transition-duration: 150ms;
106
+ --default-transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
107
+ --default-font-family: var(--font-sans);
108
+ --default-mono-font-family: var(--font-mono);
109
+ }
110
+ }
111
+ @layer base {
112
+ *,
113
+ ::after,
114
+ ::before,
115
+ ::backdrop,
116
+ ::file-selector-button {
117
+ box-sizing: border-box;
118
+ margin: 0;
119
+ padding: 0;
120
+ border: 0 solid;
121
+ }
122
+ html,
123
+ :host {
124
+ line-height: 1.5;
125
+ -webkit-text-size-adjust: 100%;
126
+ -moz-tab-size: 4;
127
+ -o-tab-size: 4;
128
+ tab-size: 4;
129
+ font-family: var(--default-font-family, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");
130
+ font-feature-settings: var(--default-font-feature-settings, normal);
131
+ font-variation-settings: var(--default-font-variation-settings, normal);
132
+ -webkit-tap-highlight-color: transparent;
133
+ }
134
+ hr {
135
+ height: 0;
136
+ color: inherit;
137
+ border-top-width: 1px;
138
+ }
139
+ abbr:where([title]) {
140
+ -webkit-text-decoration: underline dotted;
141
+ text-decoration: underline dotted;
142
+ }
143
+ h1,
144
+ h2,
145
+ h3,
146
+ h4,
147
+ h5,
148
+ h6 {
149
+ font-size: inherit;
150
+ font-weight: inherit;
151
+ }
152
+ a {
153
+ color: inherit;
154
+ -webkit-text-decoration: inherit;
155
+ text-decoration: inherit;
156
+ }
157
+ b,
158
+ strong {
159
+ font-weight: bolder;
160
+ }
161
+ code,
162
+ kbd,
163
+ samp,
164
+ pre {
165
+ font-family: var(--default-mono-font-family, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);
166
+ font-feature-settings: var(--default-mono-font-feature-settings, normal);
167
+ font-variation-settings: var(--default-mono-font-variation-settings, normal);
168
+ font-size: 1em;
169
+ }
170
+ small {
171
+ font-size: 80%;
172
+ }
173
+ sub,
174
+ sup {
175
+ font-size: 75%;
176
+ line-height: 0;
177
+ position: relative;
178
+ vertical-align: baseline;
179
+ }
180
+ sub {
181
+ bottom: -0.25em;
182
+ }
183
+ sup {
184
+ top: -0.5em;
185
+ }
186
+ table {
187
+ text-indent: 0;
188
+ border-color: inherit;
189
+ border-collapse: collapse;
190
+ }
191
+ :-moz-focusring {
192
+ outline: auto;
193
+ }
194
+ progress {
195
+ vertical-align: baseline;
196
+ }
197
+ summary {
198
+ display: list-item;
199
+ }
200
+ ol,
201
+ ul,
202
+ menu {
203
+ list-style: none;
204
+ }
205
+ img,
206
+ svg,
207
+ video,
208
+ canvas,
209
+ audio,
210
+ iframe,
211
+ embed,
212
+ object {
213
+ display: block;
214
+ vertical-align: middle;
215
+ }
216
+ img,
217
+ video {
218
+ max-width: 100%;
219
+ height: auto;
220
+ }
221
+ button,
222
+ input,
223
+ select,
224
+ optgroup,
225
+ textarea,
226
+ ::file-selector-button {
227
+ font: inherit;
228
+ font-feature-settings: inherit;
229
+ font-variation-settings: inherit;
230
+ letter-spacing: inherit;
231
+ color: inherit;
232
+ border-radius: 0;
233
+ background-color: transparent;
234
+ opacity: 1;
235
+ }
236
+ :where(select:is([multiple], [size])) optgroup {
237
+ font-weight: bolder;
238
+ }
239
+ :where(select:is([multiple], [size])) optgroup option {
240
+ padding-inline-start: 20px;
241
+ }
242
+ ::file-selector-button {
243
+ margin-inline-end: 4px;
244
+ }
245
+ ::-moz-placeholder {
246
+ opacity: 1;
247
+ }
248
+ ::placeholder {
249
+ opacity: 1;
250
+ }
251
+ @supports (not (-webkit-appearance: -apple-pay-button)) or (contain-intrinsic-size: 1px) {
252
+ ::-moz-placeholder {
253
+ color: currentcolor;
254
+ @supports (color: color-mix(in lab, red, red)) {
255
+ color: color-mix(in oklab, currentcolor 50%, transparent);
256
+ }
257
+ }
258
+ ::placeholder {
259
+ color: currentcolor;
260
+ @supports (color: color-mix(in lab, red, red)) {
261
+ color: color-mix(in oklab, currentcolor 50%, transparent);
262
+ }
263
+ }
264
+ }
265
+ textarea {
266
+ resize: vertical;
267
+ }
268
+ ::-webkit-search-decoration {
269
+ -webkit-appearance: none;
270
+ }
271
+ ::-webkit-date-and-time-value {
272
+ min-height: 1lh;
273
+ text-align: inherit;
274
+ }
275
+ ::-webkit-datetime-edit {
276
+ display: inline-flex;
277
+ }
278
+ ::-webkit-datetime-edit-fields-wrapper {
279
+ padding: 0;
280
+ }
281
+ ::-webkit-datetime-edit,
282
+ ::-webkit-datetime-edit-year-field,
283
+ ::-webkit-datetime-edit-month-field,
284
+ ::-webkit-datetime-edit-day-field,
285
+ ::-webkit-datetime-edit-hour-field,
286
+ ::-webkit-datetime-edit-minute-field,
287
+ ::-webkit-datetime-edit-second-field,
288
+ ::-webkit-datetime-edit-millisecond-field,
289
+ ::-webkit-datetime-edit-meridiem-field {
290
+ padding-block: 0;
291
+ }
292
+ ::-webkit-calendar-picker-indicator {
293
+ line-height: 1;
294
+ }
295
+ :-moz-ui-invalid {
296
+ box-shadow: none;
297
+ }
298
+ button,
299
+ input:where([type=button], [type=reset], [type=submit]),
300
+ ::file-selector-button {
301
+ -webkit-appearance: button;
302
+ -moz-appearance: button;
303
+ appearance: button;
304
+ }
305
+ ::-webkit-inner-spin-button,
306
+ ::-webkit-outer-spin-button {
307
+ height: auto;
308
+ }
309
+ [hidden]:where(:not([hidden=until-found])) {
310
+ display: none !important;
311
+ }
312
+ }
313
+ @layer utilities {
314
+ .static {
315
+ position: static;
316
+ }
317
+ .flex {
318
+ display: flex;
319
+ }
320
+ .inline-block {
321
+ display: inline-block;
322
+ }
323
+ .inline-flex {
324
+ display: inline-flex;
325
+ }
326
+ .transform {
327
+ transform: var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,);
328
+ }
329
+ .animate-spin {
330
+ animation: var(--animate-spin);
331
+ }
332
+ .cursor-not-allowed {
333
+ cursor: not-allowed;
334
+ }
335
+ .items-center {
336
+ align-items: center;
337
+ }
338
+ .justify-center {
339
+ justify-content: center;
340
+ }
341
+ .gap-2 {
342
+ gap: calc(var(--spacing) * 2);
343
+ }
344
+ .rounded {
345
+ border-radius: 0.25rem;
346
+ }
347
+ .border {
348
+ border-style: var(--tw-border-style);
349
+ border-width: 1px;
350
+ }
351
+ .border-blue-500 {
352
+ border-color: var(--color-blue-500);
353
+ }
354
+ .border-cyan-500 {
355
+ border-color: var(--color-cyan-500);
356
+ }
357
+ .border-gray-500 {
358
+ border-color: var(--color-gray-500);
359
+ }
360
+ .border-green-500 {
361
+ border-color: var(--color-green-500);
362
+ }
363
+ .border-indigo-500 {
364
+ border-color: var(--color-indigo-500);
365
+ }
366
+ .border-orange-500 {
367
+ border-color: var(--color-orange-500);
368
+ }
369
+ .border-pink-500 {
370
+ border-color: var(--color-pink-500);
371
+ }
372
+ .border-purple-500 {
373
+ border-color: var(--color-purple-500);
374
+ }
375
+ .border-red-500 {
376
+ border-color: var(--color-red-500);
377
+ }
378
+ .border-teal-500 {
379
+ border-color: var(--color-teal-500);
380
+ }
381
+ .border-yellow-500 {
382
+ border-color: var(--color-yellow-500);
383
+ }
384
+ .bg-blue-50 {
385
+ background-color: var(--color-blue-50);
386
+ }
387
+ .bg-blue-100 {
388
+ background-color: var(--color-blue-100);
389
+ }
390
+ .bg-blue-500 {
391
+ background-color: var(--color-blue-500);
392
+ }
393
+ .bg-cyan-50 {
394
+ background-color: var(--color-cyan-50);
395
+ }
396
+ .bg-cyan-100 {
397
+ background-color: var(--color-cyan-100);
398
+ }
399
+ .bg-cyan-500 {
400
+ background-color: var(--color-cyan-500);
401
+ }
402
+ .bg-gray-50 {
403
+ background-color: var(--color-gray-50);
404
+ }
405
+ .bg-gray-100 {
406
+ background-color: var(--color-gray-100);
407
+ }
408
+ .bg-gray-200 {
409
+ background-color: var(--color-gray-200);
410
+ }
411
+ .bg-gray-500 {
412
+ background-color: var(--color-gray-500);
413
+ }
414
+ .bg-green-50 {
415
+ background-color: var(--color-green-50);
416
+ }
417
+ .bg-green-100 {
418
+ background-color: var(--color-green-100);
419
+ }
420
+ .bg-green-500 {
421
+ background-color: var(--color-green-500);
422
+ }
423
+ .bg-indigo-50 {
424
+ background-color: var(--color-indigo-50);
425
+ }
426
+ .bg-indigo-100 {
427
+ background-color: var(--color-indigo-100);
428
+ }
429
+ .bg-indigo-500 {
430
+ background-color: var(--color-indigo-500);
431
+ }
432
+ .bg-orange-50 {
433
+ background-color: var(--color-orange-50);
434
+ }
435
+ .bg-orange-100 {
436
+ background-color: var(--color-orange-100);
437
+ }
438
+ .bg-orange-500 {
439
+ background-color: var(--color-orange-500);
440
+ }
441
+ .bg-pink-50 {
442
+ background-color: var(--color-pink-50);
443
+ }
444
+ .bg-pink-100 {
445
+ background-color: var(--color-pink-100);
446
+ }
447
+ .bg-pink-500 {
448
+ background-color: var(--color-pink-500);
449
+ }
450
+ .bg-purple-50 {
451
+ background-color: var(--color-purple-50);
452
+ }
453
+ .bg-purple-100 {
454
+ background-color: var(--color-purple-100);
455
+ }
456
+ .bg-purple-500 {
457
+ background-color: var(--color-purple-500);
458
+ }
459
+ .bg-red-50 {
460
+ background-color: var(--color-red-50);
461
+ }
462
+ .bg-red-100 {
463
+ background-color: var(--color-red-100);
464
+ }
465
+ .bg-red-500 {
466
+ background-color: var(--color-red-500);
467
+ }
468
+ .bg-teal-50 {
469
+ background-color: var(--color-teal-50);
470
+ }
471
+ .bg-teal-100 {
472
+ background-color: var(--color-teal-100);
473
+ }
474
+ .bg-teal-500 {
475
+ background-color: var(--color-teal-500);
476
+ }
477
+ .bg-yellow-50 {
478
+ background-color: var(--color-yellow-50);
479
+ }
480
+ .bg-yellow-100 {
481
+ background-color: var(--color-yellow-100);
482
+ }
483
+ .bg-yellow-500 {
484
+ background-color: var(--color-yellow-500);
485
+ }
486
+ .px-2 {
487
+ padding-inline: calc(var(--spacing) * 2);
488
+ }
489
+ .px-2\.5 {
490
+ padding-inline: calc(var(--spacing) * 2.5);
491
+ }
492
+ .px-3 {
493
+ padding-inline: calc(var(--spacing) * 3);
494
+ }
495
+ .px-4 {
496
+ padding-inline: calc(var(--spacing) * 4);
497
+ }
498
+ .px-5 {
499
+ padding-inline: calc(var(--spacing) * 5);
500
+ }
501
+ .px-6 {
502
+ padding-inline: calc(var(--spacing) * 6);
503
+ }
504
+ .px-7 {
505
+ padding-inline: calc(var(--spacing) * 7);
506
+ }
507
+ .py-1 {
508
+ padding-block: calc(var(--spacing) * 1);
509
+ }
510
+ .py-1\.5 {
511
+ padding-block: calc(var(--spacing) * 1.5);
512
+ }
513
+ .py-2 {
514
+ padding-block: calc(var(--spacing) * 2);
515
+ }
516
+ .py-2\.5 {
517
+ padding-block: calc(var(--spacing) * 2.5);
518
+ }
519
+ .py-3 {
520
+ padding-block: calc(var(--spacing) * 3);
521
+ }
522
+ .py-3\.5 {
523
+ padding-block: calc(var(--spacing) * 3.5);
524
+ }
525
+ .text-base {
526
+ font-size: var(--text-base);
527
+ line-height: var(--tw-leading, var(--text-base--line-height));
528
+ }
529
+ .text-lg {
530
+ font-size: var(--text-lg);
531
+ line-height: var(--tw-leading, var(--text-lg--line-height));
532
+ }
533
+ .text-sm {
534
+ font-size: var(--text-sm);
535
+ line-height: var(--tw-leading, var(--text-sm--line-height));
536
+ }
537
+ .text-xl {
538
+ font-size: var(--text-xl);
539
+ line-height: var(--tw-leading, var(--text-xl--line-height));
540
+ }
541
+ .text-xs {
542
+ font-size: var(--text-xs);
543
+ line-height: var(--tw-leading, var(--text-xs--line-height));
544
+ }
545
+ .font-medium {
546
+ --tw-font-weight: var(--font-weight-medium);
547
+ font-weight: var(--font-weight-medium);
548
+ }
549
+ .text-blue-500 {
550
+ color: var(--color-blue-500);
551
+ }
552
+ .text-blue-800 {
553
+ color: var(--color-blue-800);
554
+ }
555
+ .text-cyan-500 {
556
+ color: var(--color-cyan-500);
557
+ }
558
+ .text-cyan-800 {
559
+ color: var(--color-cyan-800);
560
+ }
561
+ .text-gray-400 {
562
+ color: var(--color-gray-400);
563
+ }
564
+ .text-gray-500 {
565
+ color: var(--color-gray-500);
566
+ }
567
+ .text-gray-800 {
568
+ color: var(--color-gray-800);
569
+ }
570
+ .text-green-500 {
571
+ color: var(--color-green-500);
572
+ }
573
+ .text-green-800 {
574
+ color: var(--color-green-800);
575
+ }
576
+ .text-indigo-500 {
577
+ color: var(--color-indigo-500);
578
+ }
579
+ .text-indigo-800 {
580
+ color: var(--color-indigo-800);
581
+ }
582
+ .text-orange-500 {
583
+ color: var(--color-orange-500);
584
+ }
585
+ .text-orange-800 {
586
+ color: var(--color-orange-800);
587
+ }
588
+ .text-pink-500 {
589
+ color: var(--color-pink-500);
590
+ }
591
+ .text-pink-800 {
592
+ color: var(--color-pink-800);
593
+ }
594
+ .text-purple-500 {
595
+ color: var(--color-purple-500);
596
+ }
597
+ .text-purple-800 {
598
+ color: var(--color-purple-800);
599
+ }
600
+ .text-red-500 {
601
+ color: var(--color-red-500);
602
+ }
603
+ .text-red-800 {
604
+ color: var(--color-red-800);
605
+ }
606
+ .text-teal-500 {
607
+ color: var(--color-teal-500);
608
+ }
609
+ .text-teal-800 {
610
+ color: var(--color-teal-800);
611
+ }
612
+ .text-white {
613
+ color: var(--color-white);
614
+ }
615
+ .text-yellow-500 {
616
+ color: var(--color-yellow-500);
617
+ }
618
+ .text-yellow-800 {
619
+ color: var(--color-yellow-800);
620
+ }
621
+ .opacity-25 {
622
+ opacity: 25%;
623
+ }
624
+ .opacity-75 {
625
+ opacity: 75%;
626
+ }
627
+ .outline {
628
+ outline-style: var(--tw-outline-style);
629
+ outline-width: 1px;
630
+ }
631
+ .transition-colors {
632
+ transition-property:
633
+ color,
634
+ background-color,
635
+ border-color,
636
+ outline-color,
637
+ text-decoration-color,
638
+ fill,
639
+ stroke,
640
+ --tw-gradient-from,
641
+ --tw-gradient-via,
642
+ --tw-gradient-to;
643
+ transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
644
+ transition-duration: var(--tw-duration, var(--default-transition-duration));
645
+ }
646
+ .hover\:bg-blue-100 {
647
+ &:hover {
648
+ @media (hover: hover) {
649
+ background-color: var(--color-blue-100);
650
+ }
651
+ }
652
+ }
653
+ .hover\:bg-blue-200 {
654
+ &:hover {
655
+ @media (hover: hover) {
656
+ background-color: var(--color-blue-200);
657
+ }
658
+ }
659
+ }
660
+ .hover\:bg-blue-600 {
661
+ &:hover {
662
+ @media (hover: hover) {
663
+ background-color: var(--color-blue-600);
664
+ }
665
+ }
666
+ }
667
+ .hover\:bg-cyan-100 {
668
+ &:hover {
669
+ @media (hover: hover) {
670
+ background-color: var(--color-cyan-100);
671
+ }
672
+ }
673
+ }
674
+ .hover\:bg-cyan-200 {
675
+ &:hover {
676
+ @media (hover: hover) {
677
+ background-color: var(--color-cyan-200);
678
+ }
679
+ }
680
+ }
681
+ .hover\:bg-cyan-600 {
682
+ &:hover {
683
+ @media (hover: hover) {
684
+ background-color: var(--color-cyan-600);
685
+ }
686
+ }
687
+ }
688
+ .hover\:bg-gray-100 {
689
+ &:hover {
690
+ @media (hover: hover) {
691
+ background-color: var(--color-gray-100);
692
+ }
693
+ }
694
+ }
695
+ .hover\:bg-gray-200 {
696
+ &:hover {
697
+ @media (hover: hover) {
698
+ background-color: var(--color-gray-200);
699
+ }
700
+ }
701
+ }
702
+ .hover\:bg-gray-600 {
703
+ &:hover {
704
+ @media (hover: hover) {
705
+ background-color: var(--color-gray-600);
706
+ }
707
+ }
708
+ }
709
+ .hover\:bg-green-100 {
710
+ &:hover {
711
+ @media (hover: hover) {
712
+ background-color: var(--color-green-100);
713
+ }
714
+ }
715
+ }
716
+ .hover\:bg-green-200 {
717
+ &:hover {
718
+ @media (hover: hover) {
719
+ background-color: var(--color-green-200);
720
+ }
721
+ }
722
+ }
723
+ .hover\:bg-green-600 {
724
+ &:hover {
725
+ @media (hover: hover) {
726
+ background-color: var(--color-green-600);
727
+ }
728
+ }
729
+ }
730
+ .hover\:bg-indigo-100 {
731
+ &:hover {
732
+ @media (hover: hover) {
733
+ background-color: var(--color-indigo-100);
734
+ }
735
+ }
736
+ }
737
+ .hover\:bg-indigo-200 {
738
+ &:hover {
739
+ @media (hover: hover) {
740
+ background-color: var(--color-indigo-200);
741
+ }
742
+ }
743
+ }
744
+ .hover\:bg-indigo-600 {
745
+ &:hover {
746
+ @media (hover: hover) {
747
+ background-color: var(--color-indigo-600);
748
+ }
749
+ }
750
+ }
751
+ .hover\:bg-orange-100 {
752
+ &:hover {
753
+ @media (hover: hover) {
754
+ background-color: var(--color-orange-100);
755
+ }
756
+ }
757
+ }
758
+ .hover\:bg-orange-200 {
759
+ &:hover {
760
+ @media (hover: hover) {
761
+ background-color: var(--color-orange-200);
762
+ }
763
+ }
764
+ }
765
+ .hover\:bg-orange-600 {
766
+ &:hover {
767
+ @media (hover: hover) {
768
+ background-color: var(--color-orange-600);
769
+ }
770
+ }
771
+ }
772
+ .hover\:bg-pink-100 {
773
+ &:hover {
774
+ @media (hover: hover) {
775
+ background-color: var(--color-pink-100);
776
+ }
777
+ }
778
+ }
779
+ .hover\:bg-pink-200 {
780
+ &:hover {
781
+ @media (hover: hover) {
782
+ background-color: var(--color-pink-200);
783
+ }
784
+ }
785
+ }
786
+ .hover\:bg-pink-600 {
787
+ &:hover {
788
+ @media (hover: hover) {
789
+ background-color: var(--color-pink-600);
790
+ }
791
+ }
792
+ }
793
+ .hover\:bg-purple-100 {
794
+ &:hover {
795
+ @media (hover: hover) {
796
+ background-color: var(--color-purple-100);
797
+ }
798
+ }
799
+ }
800
+ .hover\:bg-purple-200 {
801
+ &:hover {
802
+ @media (hover: hover) {
803
+ background-color: var(--color-purple-200);
804
+ }
805
+ }
806
+ }
807
+ .hover\:bg-purple-600 {
808
+ &:hover {
809
+ @media (hover: hover) {
810
+ background-color: var(--color-purple-600);
811
+ }
812
+ }
813
+ }
814
+ .hover\:bg-red-100 {
815
+ &:hover {
816
+ @media (hover: hover) {
817
+ background-color: var(--color-red-100);
818
+ }
819
+ }
820
+ }
821
+ .hover\:bg-red-200 {
822
+ &:hover {
823
+ @media (hover: hover) {
824
+ background-color: var(--color-red-200);
825
+ }
826
+ }
827
+ }
828
+ .hover\:bg-red-600 {
829
+ &:hover {
830
+ @media (hover: hover) {
831
+ background-color: var(--color-red-600);
832
+ }
833
+ }
834
+ }
835
+ .hover\:bg-teal-100 {
836
+ &:hover {
837
+ @media (hover: hover) {
838
+ background-color: var(--color-teal-100);
839
+ }
840
+ }
841
+ }
842
+ .hover\:bg-teal-200 {
843
+ &:hover {
844
+ @media (hover: hover) {
845
+ background-color: var(--color-teal-200);
846
+ }
847
+ }
848
+ }
849
+ .hover\:bg-teal-600 {
850
+ &:hover {
851
+ @media (hover: hover) {
852
+ background-color: var(--color-teal-600);
853
+ }
854
+ }
855
+ }
856
+ .hover\:bg-yellow-100 {
857
+ &:hover {
858
+ @media (hover: hover) {
859
+ background-color: var(--color-yellow-100);
860
+ }
861
+ }
862
+ }
863
+ .hover\:bg-yellow-200 {
864
+ &:hover {
865
+ @media (hover: hover) {
866
+ background-color: var(--color-yellow-200);
867
+ }
868
+ }
869
+ }
870
+ .hover\:bg-yellow-600 {
871
+ &:hover {
872
+ @media (hover: hover) {
873
+ background-color: var(--color-yellow-600);
874
+ }
875
+ }
876
+ }
877
+ .focus\:ring-2 {
878
+ &:focus {
879
+ --tw-ring-shadow: var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
880
+ box-shadow:
881
+ var(--tw-inset-shadow),
882
+ var(--tw-inset-ring-shadow),
883
+ var(--tw-ring-offset-shadow),
884
+ var(--tw-ring-shadow),
885
+ var(--tw-shadow);
886
+ }
887
+ }
888
+ .focus\:ring-offset-1 {
889
+ &:focus {
890
+ --tw-ring-offset-width: 1px;
891
+ --tw-ring-offset-shadow: var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);
892
+ }
893
+ }
894
+ .focus\:outline-none {
895
+ &:focus {
896
+ --tw-outline-style: none;
897
+ outline-style: none;
898
+ }
899
+ }
900
+ .disabled\:pointer-events-none {
901
+ &:disabled {
902
+ pointer-events: none;
903
+ }
904
+ }
905
+ .disabled\:cursor-not-allowed {
906
+ &:disabled {
907
+ cursor: not-allowed;
908
+ }
909
+ }
910
+ .disabled\:opacity-50 {
911
+ &:disabled {
912
+ opacity: 50%;
913
+ }
914
+ }
915
+ }
916
+ @property --tw-rotate-x { syntax: "*"; inherits: false; }
917
+ @property --tw-rotate-y { syntax: "*"; inherits: false; }
918
+ @property --tw-rotate-z { syntax: "*"; inherits: false; }
919
+ @property --tw-skew-x { syntax: "*"; inherits: false; }
920
+ @property --tw-skew-y { syntax: "*"; inherits: false; }
921
+ @property --tw-border-style { syntax: "*"; inherits: false; initial-value: solid; }
922
+ @property --tw-font-weight { syntax: "*"; inherits: false; }
923
+ @property --tw-outline-style { syntax: "*"; inherits: false; initial-value: solid; }
924
+ @property --tw-shadow { syntax: "*"; inherits: false; initial-value: 0 0 #0000; }
925
+ @property --tw-shadow-color { syntax: "*"; inherits: false; }
926
+ @property --tw-shadow-alpha { syntax: "<percentage>"; inherits: false; initial-value: 100%; }
927
+ @property --tw-inset-shadow { syntax: "*"; inherits: false; initial-value: 0 0 #0000; }
928
+ @property --tw-inset-shadow-color { syntax: "*"; inherits: false; }
929
+ @property --tw-inset-shadow-alpha { syntax: "<percentage>"; inherits: false; initial-value: 100%; }
930
+ @property --tw-ring-color { syntax: "*"; inherits: false; }
931
+ @property --tw-ring-shadow { syntax: "*"; inherits: false; initial-value: 0 0 #0000; }
932
+ @property --tw-inset-ring-color { syntax: "*"; inherits: false; }
933
+ @property --tw-inset-ring-shadow { syntax: "*"; inherits: false; initial-value: 0 0 #0000; }
934
+ @property --tw-ring-inset { syntax: "*"; inherits: false; }
935
+ @property --tw-ring-offset-width { syntax: "<length>"; inherits: false; initial-value: 0px; }
936
+ @property --tw-ring-offset-color { syntax: "*"; inherits: false; initial-value: #fff; }
937
+ @property --tw-ring-offset-shadow { syntax: "*"; inherits: false; initial-value: 0 0 #0000; }
938
+ @keyframes spin {
939
+ to {
940
+ transform: rotate(360deg);
941
+ }
942
+ }
943
+ @layer properties {
944
+ @supports ((-webkit-hyphens: none) and (not (margin-trim: inline))) or ((-moz-orient: inline) and (not (color:rgb(from red r g b)))) {
945
+ *,
946
+ ::before,
947
+ ::after,
948
+ ::backdrop {
949
+ --tw-rotate-x: initial;
950
+ --tw-rotate-y: initial;
951
+ --tw-rotate-z: initial;
952
+ --tw-skew-x: initial;
953
+ --tw-skew-y: initial;
954
+ --tw-border-style: solid;
955
+ --tw-font-weight: initial;
956
+ --tw-outline-style: solid;
957
+ --tw-shadow: 0 0 #0000;
958
+ --tw-shadow-color: initial;
959
+ --tw-shadow-alpha: 100%;
960
+ --tw-inset-shadow: 0 0 #0000;
961
+ --tw-inset-shadow-color: initial;
962
+ --tw-inset-shadow-alpha: 100%;
963
+ --tw-ring-color: initial;
964
+ --tw-ring-shadow: 0 0 #0000;
965
+ --tw-inset-ring-color: initial;
966
+ --tw-inset-ring-shadow: 0 0 #0000;
967
+ --tw-ring-inset: initial;
968
+ --tw-ring-offset-width: 0px;
969
+ --tw-ring-offset-color: #fff;
970
+ --tw-ring-offset-shadow: 0 0 #0000;
971
+ }
972
+ }
973
+ }
974
+ /*! tailwindcss v4.1.18 | MIT License | https://tailwindcss.com */
@@ -0,0 +1,21 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+ import React from 'react';
3
+
4
+ type ButtonVariant = 'solid' | 'outline' | 'surface' | 'subtle';
5
+ type ButtonColor = 'gray' | 'red' | 'green' | 'blue' | 'teal' | 'pink' | 'purple' | 'cyan' | 'orange' | 'yellow' | 'indigo';
6
+ type ButtonSize = '2xs' | 'xs' | 'sm' | 'md' | 'lg' | 'xl' | '2xl';
7
+ type ButtonProps = React.ButtonHTMLAttributes<HTMLButtonElement> & {
8
+ children: React.ReactNode;
9
+ color?: ButtonColor;
10
+ variant?: ButtonVariant;
11
+ size?: ButtonSize;
12
+ className?: string;
13
+ startIcon?: React.ReactNode;
14
+ endIcon?: React.ReactNode;
15
+ isLoading?: boolean;
16
+ loadingIndicator?: React.ReactNode;
17
+ };
18
+
19
+ declare function Button({ children, color, variant, size, className, startIcon, endIcon, isLoading, loadingIndicator, disabled, onClick, ...rest }: ButtonProps): react_jsx_runtime.JSX.Element;
20
+
21
+ export { Button };
@@ -0,0 +1,21 @@
1
+ import * as react_jsx_runtime from 'react/jsx-runtime';
2
+ import React from 'react';
3
+
4
+ type ButtonVariant = 'solid' | 'outline' | 'surface' | 'subtle';
5
+ type ButtonColor = 'gray' | 'red' | 'green' | 'blue' | 'teal' | 'pink' | 'purple' | 'cyan' | 'orange' | 'yellow' | 'indigo';
6
+ type ButtonSize = '2xs' | 'xs' | 'sm' | 'md' | 'lg' | 'xl' | '2xl';
7
+ type ButtonProps = React.ButtonHTMLAttributes<HTMLButtonElement> & {
8
+ children: React.ReactNode;
9
+ color?: ButtonColor;
10
+ variant?: ButtonVariant;
11
+ size?: ButtonSize;
12
+ className?: string;
13
+ startIcon?: React.ReactNode;
14
+ endIcon?: React.ReactNode;
15
+ isLoading?: boolean;
16
+ loadingIndicator?: React.ReactNode;
17
+ };
18
+
19
+ declare function Button({ children, color, variant, size, className, startIcon, endIcon, isLoading, loadingIndicator, disabled, onClick, ...rest }: ButtonProps): react_jsx_runtime.JSX.Element;
20
+
21
+ export { Button };
package/dist/index.js ADDED
@@ -0,0 +1 @@
1
+ var M=Object.defineProperty,P=Object.defineProperties;var D=Object.getOwnPropertyDescriptors;var n=Object.getOwnPropertySymbols;var d=Object.prototype.hasOwnProperty,h=Object.prototype.propertyIsEnumerable;var y=(e,t,r)=>t in e?M(e,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):e[t]=r,v=(e,t)=>{for(var r in t||(t={}))d.call(t,r)&&y(e,r,t[r]);if(n)for(var r of n(t))h.call(t,r)&&y(e,r,t[r]);return e},c=(e,t)=>P(e,D(t));var m=(e,t)=>{var r={};for(var o in e)d.call(e,o)&&t.indexOf(o)<0&&(r[o]=e[o]);if(e!=null&&n)for(var o of n(e))t.indexOf(o)<0&&h.call(e,o)&&(r[o]=e[o]);return r};import"react";import S from"clsx";var w="inline-flex items-center justify-center gap-2 rounded font-medium transition-colors focus:outline-none focus:ring-2 focus:ring-offset-1 disabled:opacity-50 disabled:cursor-not-allowed disabled:pointer-events-none",f={"2xs":"text-xs px-2 py-1",xs:"text-xs px-2.5 py-1.5",sm:"text-sm px-3 py-1.5",md:"text-sm px-4 py-2",lg:"text-base px-5 py-2.5",xl:"text-base px-6 py-3","2xl":"text-lg px-7 py-3.5"},b={"2xs":"text-xs",xs:"text-xs",sm:"text-sm",md:"text-base",lg:"text-lg",xl:"text-lg","2xl":"text-xl"},B={solid:{gray:"bg-gray-500 text-white hover:bg-gray-600",red:"bg-red-500 text-white hover:bg-red-600",green:"bg-green-500 text-white hover:bg-green-600",blue:"bg-blue-500 text-white hover:bg-blue-600",teal:"bg-teal-500 text-white hover:bg-teal-600",pink:"bg-pink-500 text-white hover:bg-pink-600",purple:"bg-purple-500 text-white hover:bg-purple-600",cyan:"bg-cyan-500 text-white hover:bg-cyan-600",orange:"bg-orange-500 text-white hover:bg-orange-600",yellow:"bg-yellow-500 text-white hover:bg-yellow-600",indigo:"bg-indigo-500 text-white hover:bg-indigo-600"},outline:{gray:"border border-gray-500 text-gray-500 hover:bg-gray-100",red:"border border-red-500 text-red-500 hover:bg-red-100",green:"border border-green-500 text-green-500 hover:bg-green-100",blue:"border border-blue-500 text-blue-500 hover:bg-blue-100",teal:"border border-teal-500 text-teal-500 hover:bg-teal-100",pink:"border border-pink-500 text-pink-500 hover:bg-pink-100",purple:"border border-purple-500 text-purple-500 hover:bg-purple-100",cyan:"border border-cyan-500 text-cyan-500 hover:bg-cyan-100",orange:"border border-orange-500 text-orange-500 hover:bg-orange-100",yellow:"border border-yellow-500 text-yellow-500 hover:bg-yellow-100",indigo:"border border-indigo-500 text-indigo-500 hover:bg-indigo-100"},surface:{gray:"bg-gray-100 text-gray-800 hover:bg-gray-200",red:"bg-red-100 text-red-800 hover:bg-red-200",green:"bg-green-100 text-green-800 hover:bg-green-200",blue:"bg-blue-100 text-blue-800 hover:bg-blue-200",teal:"bg-teal-100 text-teal-800 hover:bg-teal-200",pink:"bg-pink-100 text-pink-800 hover:bg-pink-200",purple:"bg-purple-100 text-purple-800 hover:bg-purple-200",cyan:"bg-cyan-100 text-cyan-800 hover:bg-cyan-200",orange:"bg-orange-100 text-orange-800 hover:bg-orange-200",yellow:"bg-yellow-100 text-yellow-800 hover:bg-yellow-200",indigo:"bg-indigo-100 text-indigo-800 hover:bg-indigo-200"},subtle:{gray:"bg-gray-50 text-gray-800 hover:bg-gray-100",red:"bg-red-50 text-red-800 hover:bg-red-100",green:"bg-green-50 text-green-800 hover:bg-green-100",blue:"bg-blue-50 text-blue-800 hover:bg-blue-100",teal:"bg-teal-50 text-teal-800 hover:bg-teal-100",pink:"bg-pink-50 text-pink-800 hover:bg-pink-100",purple:"bg-purple-50 text-purple-800 hover:bg-purple-100",cyan:"bg-cyan-50 text-cyan-800 hover:bg-cyan-100",orange:"bg-orange-50 text-orange-800 hover:bg-orange-100",yellow:"bg-yellow-50 text-yellow-800 hover:bg-yellow-100",indigo:"bg-indigo-50 text-indigo-800 hover:bg-indigo-100"}};function k(e,t,r){return r?"bg-gray-200 text-gray-400 cursor-not-allowed":B[t][e]}import{Fragment as C,jsx as g,jsxs as i}from"react/jsx-runtime";function W(j){var u=j,{children:e,color:t="blue",variant:r="solid",size:o="md",className:N,startIcon:p,endIcon:x,isLoading:s=!1,loadingIndicator:l,disabled:z=!1,onClick:R}=u,V=m(u,["children","color","variant","size","className","startIcon","endIcon","isLoading","loadingIndicator","disabled","onClick"]);let a=z||s;return g("button",c(v({},V),{disabled:a,onClick:a?void 0:R,className:S(w,f[o],k(t,r,a),N),children:s?l!=null?l:i(C,{children:[i("svg",{className:S(b[o],"animate-spin"),viewBox:"0 0 24 24",fill:"none",children:[g("circle",{className:"opacity-25",cx:"12",cy:"12",r:"10",stroke:"currentColor",strokeWidth:"4"}),g("path",{className:"opacity-75",fill:"currentColor",d:"M4 12a8 8 0 018-8v8z"})]}),g("span",{children:e})]}):i(C,{children:[p&&g("span",{className:b[o],children:p}),g("span",{children:e}),x&&g("span",{className:b[o],children:x})]})}))}export{W as Button};
package/package.json ADDED
@@ -0,0 +1,61 @@
1
+ {
2
+ "name": "rinjani-ui",
3
+ "version": "0.0.1",
4
+ "description": "Custom UI Library built with React and TailwindCSS",
5
+ "main": "./dist/index.js",
6
+ "module": "./dist/index.mjs",
7
+ "types": "./dist/index.d.ts",
8
+ "type": "module",
9
+ "exports": {
10
+ ".": {
11
+ "types": "./dist/index.d.ts",
12
+ "import": "./dist/index.mjs",
13
+ "require": "./dist/index.js"
14
+ },
15
+ "./style.css": "./dist/index.css"
16
+ },
17
+ "sideEffects": [
18
+ "*.css"
19
+ ],
20
+ "files": [
21
+ "dist"
22
+ ],
23
+ "scripts": {
24
+ "build": "tsup src/index.ts --format cjs,esm --dts --minify --clean && tsup src/index.css --format esm",
25
+ "dev": "tsup src/index.ts src/index.css --format cjs,esm --watch --dts",
26
+ "lint": "tsc",
27
+ "storybook": "storybook dev -p 6006",
28
+ "build-storybook": "storybook build"
29
+ },
30
+ "peerDependencies": {
31
+ "react": "^18.0.0 || ^19.0.0",
32
+ "react-dom": "^18.0.0 || ^19.0.0",
33
+ "tailwindcss": ">=4.0.0"
34
+ },
35
+ "devDependencies": {
36
+ "@tailwindcss/postcss": "^4.1.18",
37
+ "@types/react": "^19.2.8",
38
+ "@types/react-dom": "^19.2.3",
39
+ "autoprefixer": "^10.4.23",
40
+ "postcss": "^8.5.6",
41
+ "react": "^19.2.3",
42
+ "react-dom": "^19.2.3",
43
+ "tailwindcss": "^4.1.18",
44
+ "tsup": "^8.5.1",
45
+ "typescript": "^5.9.3",
46
+ "storybook": "^10.1.11",
47
+ "@storybook/react-vite": "^10.1.11",
48
+ "@chromatic-com/storybook": "^5.0.0",
49
+ "@storybook/addon-vitest": "^10.1.11",
50
+ "@storybook/addon-a11y": "^10.1.11",
51
+ "@storybook/addon-docs": "^10.1.11",
52
+ "@storybook/addon-onboarding": "^10.1.11",
53
+ "vitest": "^4.0.17",
54
+ "playwright": "^1.57.0",
55
+ "@vitest/browser-playwright": "^4.0.17",
56
+ "@vitest/coverage-v8": "^4.0.17"
57
+ },
58
+ "dependencies": {
59
+ "clsx": "^2.1.1"
60
+ }
61
+ }