@luxfi/ui 1.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.
Files changed (124) hide show
  1. package/dist/accordion.cjs +213 -0
  2. package/dist/accordion.js +186 -0
  3. package/dist/alert.cjs +553 -0
  4. package/dist/alert.js +531 -0
  5. package/dist/avatar.cjs +149 -0
  6. package/dist/avatar.js +125 -0
  7. package/dist/badge.cjs +611 -0
  8. package/dist/badge.js +589 -0
  9. package/dist/button.cjs +689 -0
  10. package/dist/button.js +664 -0
  11. package/dist/checkbox.cjs +265 -0
  12. package/dist/checkbox.js +241 -0
  13. package/dist/close-button.cjs +73 -0
  14. package/dist/close-button.js +51 -0
  15. package/dist/collapsible.cjs +711 -0
  16. package/dist/collapsible.js +685 -0
  17. package/dist/color-mode.cjs +36 -0
  18. package/dist/color-mode.js +32 -0
  19. package/dist/dialog.cjs +279 -0
  20. package/dist/dialog.js +246 -0
  21. package/dist/drawer.cjs +207 -0
  22. package/dist/drawer.js +175 -0
  23. package/dist/empty-state.cjs +93 -0
  24. package/dist/empty-state.js +71 -0
  25. package/dist/field.cjs +183 -0
  26. package/dist/field.js +160 -0
  27. package/dist/heading.cjs +46 -0
  28. package/dist/heading.js +40 -0
  29. package/dist/icon-button.cjs +491 -0
  30. package/dist/icon-button.js +470 -0
  31. package/dist/image.cjs +572 -0
  32. package/dist/image.js +551 -0
  33. package/dist/index.cjs +5749 -0
  34. package/dist/index.js +5586 -0
  35. package/dist/input-group.cjs +155 -0
  36. package/dist/input-group.js +133 -0
  37. package/dist/input.cjs +65 -0
  38. package/dist/input.js +59 -0
  39. package/dist/link.cjs +639 -0
  40. package/dist/link.js +612 -0
  41. package/dist/menu.cjs +305 -0
  42. package/dist/menu.js +269 -0
  43. package/dist/pin-input.cjs +182 -0
  44. package/dist/pin-input.js +160 -0
  45. package/dist/popover.cjs +327 -0
  46. package/dist/popover.js +294 -0
  47. package/dist/progress-circle.cjs +152 -0
  48. package/dist/progress-circle.js +128 -0
  49. package/dist/progress.cjs +117 -0
  50. package/dist/progress.js +94 -0
  51. package/dist/provider.cjs +22 -0
  52. package/dist/provider.js +20 -0
  53. package/dist/radio.cjs +177 -0
  54. package/dist/radio.js +153 -0
  55. package/dist/rating.cjs +80 -0
  56. package/dist/rating.js +58 -0
  57. package/dist/select.cjs +791 -0
  58. package/dist/select.js +757 -0
  59. package/dist/separator.cjs +57 -0
  60. package/dist/separator.js +51 -0
  61. package/dist/skeleton.cjs +370 -0
  62. package/dist/skeleton.js +346 -0
  63. package/dist/slider.cjs +138 -0
  64. package/dist/slider.js +115 -0
  65. package/dist/switch.cjs +163 -0
  66. package/dist/switch.js +140 -0
  67. package/dist/table.cjs +1053 -0
  68. package/dist/table.js +1019 -0
  69. package/dist/tabs.cjs +240 -0
  70. package/dist/tabs.js +213 -0
  71. package/dist/tag.cjs +651 -0
  72. package/dist/tag.js +628 -0
  73. package/dist/textarea.cjs +65 -0
  74. package/dist/textarea.js +59 -0
  75. package/dist/toaster.cjs +99 -0
  76. package/dist/toaster.js +96 -0
  77. package/dist/tooltip.cjs +171 -0
  78. package/dist/tooltip.js +148 -0
  79. package/dist/utils.cjs +11 -0
  80. package/dist/utils.js +9 -0
  81. package/package.json +296 -0
  82. package/src/accordion.tsx +285 -0
  83. package/src/alert.tsx +221 -0
  84. package/src/avatar.tsx +174 -0
  85. package/src/badge.tsx +158 -0
  86. package/src/button.tsx +411 -0
  87. package/src/checkbox.tsx +307 -0
  88. package/src/close-button.tsx +51 -0
  89. package/src/collapsible.tsx +126 -0
  90. package/src/color-mode.tsx +37 -0
  91. package/src/dialog.tsx +356 -0
  92. package/src/drawer.tsx +186 -0
  93. package/src/empty-state.tsx +97 -0
  94. package/src/field.tsx +202 -0
  95. package/src/heading.tsx +55 -0
  96. package/src/icon-button.tsx +192 -0
  97. package/src/image.tsx +280 -0
  98. package/src/index.ts +192 -0
  99. package/src/input-group.tsx +159 -0
  100. package/src/input.tsx +60 -0
  101. package/src/link.tsx +333 -0
  102. package/src/menu.tsx +471 -0
  103. package/src/pin-input.tsx +187 -0
  104. package/src/popover.tsx +400 -0
  105. package/src/progress-circle.tsx +180 -0
  106. package/src/progress.tsx +109 -0
  107. package/src/provider.tsx +12 -0
  108. package/src/radio.tsx +175 -0
  109. package/src/rating.tsx +79 -0
  110. package/src/select.tsx +696 -0
  111. package/src/separator.tsx +59 -0
  112. package/src/skeleton.tsx +302 -0
  113. package/src/slider.tsx +152 -0
  114. package/src/switch.tsx +158 -0
  115. package/src/table.tsx +621 -0
  116. package/src/tabs.tsx +354 -0
  117. package/src/tag.tsx +159 -0
  118. package/src/textarea.tsx +60 -0
  119. package/src/toaster.tsx +117 -0
  120. package/src/tokens.css +438 -0
  121. package/src/tooltip.tsx +184 -0
  122. package/src/utils/cn.ts +7 -0
  123. package/src/utils.ts +6 -0
  124. package/tokens.css +438 -0
@@ -0,0 +1,57 @@
1
+ "use client";
2
+ 'use strict';
3
+
4
+ var React = require('react');
5
+ var clsx = require('clsx');
6
+ var tailwindMerge = require('tailwind-merge');
7
+ var jsxRuntime = require('react/jsx-runtime');
8
+
9
+ function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
10
+
11
+ var React__default = /*#__PURE__*/_interopDefault(React);
12
+
13
+ // src/separator.tsx
14
+ function cn(...inputs) {
15
+ return tailwindMerge.twMerge(clsx.clsx(inputs));
16
+ }
17
+ var VARIANT_CLASSES = {
18
+ solid: "border-solid",
19
+ dashed: "border-dashed",
20
+ dotted: "border-dotted"
21
+ };
22
+ var HORIZONTAL_SIZE_CLASSES = {
23
+ xs: "border-t-[0.5px]",
24
+ sm: "border-t",
25
+ md: "border-t-2",
26
+ lg: "border-t-[3px]"
27
+ };
28
+ var VERTICAL_SIZE_CLASSES = {
29
+ xs: "border-l-[0.5px]",
30
+ sm: "border-l",
31
+ md: "border-l-2",
32
+ lg: "border-l-[3px]"
33
+ };
34
+ var Separator = React__default.default.forwardRef(
35
+ function Separator2({ orientation = "horizontal", variant = "solid", size = "sm", className, ...rest }, ref) {
36
+ const isVertical = orientation === "vertical";
37
+ return /* @__PURE__ */ jsxRuntime.jsx(
38
+ "hr",
39
+ {
40
+ ref,
41
+ role: "separator",
42
+ "aria-orientation": orientation,
43
+ className: cn(
44
+ "border-[var(--color-border-divider)]",
45
+ "border-0",
46
+ VARIANT_CLASSES[variant],
47
+ isVertical ? VERTICAL_SIZE_CLASSES[size] : HORIZONTAL_SIZE_CLASSES[size],
48
+ isVertical ? "self-stretch h-auto w-0" : "w-full",
49
+ className
50
+ ),
51
+ ...rest
52
+ }
53
+ );
54
+ }
55
+ );
56
+
57
+ exports.Separator = Separator;
@@ -0,0 +1,51 @@
1
+ "use client";
2
+ import React from 'react';
3
+ import { clsx } from 'clsx';
4
+ import { twMerge } from 'tailwind-merge';
5
+ import { jsx } from 'react/jsx-runtime';
6
+
7
+ // src/separator.tsx
8
+ function cn(...inputs) {
9
+ return twMerge(clsx(inputs));
10
+ }
11
+ var VARIANT_CLASSES = {
12
+ solid: "border-solid",
13
+ dashed: "border-dashed",
14
+ dotted: "border-dotted"
15
+ };
16
+ var HORIZONTAL_SIZE_CLASSES = {
17
+ xs: "border-t-[0.5px]",
18
+ sm: "border-t",
19
+ md: "border-t-2",
20
+ lg: "border-t-[3px]"
21
+ };
22
+ var VERTICAL_SIZE_CLASSES = {
23
+ xs: "border-l-[0.5px]",
24
+ sm: "border-l",
25
+ md: "border-l-2",
26
+ lg: "border-l-[3px]"
27
+ };
28
+ var Separator = React.forwardRef(
29
+ function Separator2({ orientation = "horizontal", variant = "solid", size = "sm", className, ...rest }, ref) {
30
+ const isVertical = orientation === "vertical";
31
+ return /* @__PURE__ */ jsx(
32
+ "hr",
33
+ {
34
+ ref,
35
+ role: "separator",
36
+ "aria-orientation": orientation,
37
+ className: cn(
38
+ "border-[var(--color-border-divider)]",
39
+ "border-0",
40
+ VARIANT_CLASSES[variant],
41
+ isVertical ? VERTICAL_SIZE_CLASSES[size] : HORIZONTAL_SIZE_CLASSES[size],
42
+ isVertical ? "self-stretch h-auto w-0" : "w-full",
43
+ className
44
+ ),
45
+ ...rest
46
+ }
47
+ );
48
+ }
49
+ );
50
+
51
+ export { Separator };
@@ -0,0 +1,370 @@
1
+ "use client";
2
+ 'use strict';
3
+
4
+ var React = require('react');
5
+ var clsx = require('clsx');
6
+ var tailwindMerge = require('tailwind-merge');
7
+ var jsxRuntime = require('react/jsx-runtime');
8
+
9
+ function _interopNamespace(e) {
10
+ if (e && e.__esModule) return e;
11
+ var n = Object.create(null);
12
+ if (e) {
13
+ Object.keys(e).forEach(function (k) {
14
+ if (k !== 'default') {
15
+ var d = Object.getOwnPropertyDescriptor(e, k);
16
+ Object.defineProperty(n, k, d.get ? d : {
17
+ enumerable: true,
18
+ get: function () { return e[k]; }
19
+ });
20
+ }
21
+ });
22
+ }
23
+ n.default = e;
24
+ return Object.freeze(n);
25
+ }
26
+
27
+ var React__namespace = /*#__PURE__*/_interopNamespace(React);
28
+
29
+ // src/skeleton.tsx
30
+ function cn(...inputs) {
31
+ return tailwindMerge.twMerge(clsx.clsx(inputs));
32
+ }
33
+ var SPACING_SCALE = 4;
34
+ function toStylePx(value) {
35
+ if (value === void 0) return void 0;
36
+ if (typeof value === "string") return value;
37
+ return `${value * SPACING_SCALE}px`;
38
+ }
39
+ function extractSkeletonStyleProps(props) {
40
+ const style = {};
41
+ const rest = {};
42
+ function resolveDimension(value) {
43
+ if (value === void 0 || value === null) return void 0;
44
+ if (typeof value === "number") return `${value * SPACING_SCALE}px`;
45
+ if (typeof value === "string") return value;
46
+ if (typeof value === "object") {
47
+ const obj = value;
48
+ return obj.base ?? obj.lg ?? obj.xl ?? Object.values(obj)[0];
49
+ }
50
+ return void 0;
51
+ }
52
+ for (const [key, value] of Object.entries(props)) {
53
+ if (value === void 0) continue;
54
+ switch (key) {
55
+ case "w": {
56
+ const v = resolveDimension(value);
57
+ if (v) style.width = v;
58
+ break;
59
+ }
60
+ case "h": {
61
+ const v = resolveDimension(value);
62
+ if (v) style.height = v;
63
+ break;
64
+ }
65
+ case "minW": {
66
+ const v = resolveDimension(value);
67
+ if (v) style.minWidth = v;
68
+ break;
69
+ }
70
+ case "maxW": {
71
+ const v = resolveDimension(value);
72
+ if (v) style.maxWidth = v;
73
+ break;
74
+ }
75
+ case "height":
76
+ style.height = value;
77
+ break;
78
+ case "display":
79
+ style.display = value;
80
+ break;
81
+ case "flexGrow":
82
+ style.flexGrow = value;
83
+ break;
84
+ case "flexShrink":
85
+ style.flexShrink = value;
86
+ break;
87
+ case "flexBasis":
88
+ style.flexBasis = value;
89
+ break;
90
+ case "fontWeight":
91
+ style.fontWeight = value;
92
+ break;
93
+ case "borderRadius":
94
+ style.borderRadius = value;
95
+ break;
96
+ case "alignSelf":
97
+ style.alignSelf = value;
98
+ break;
99
+ case "alignItems":
100
+ style.alignItems = value;
101
+ break;
102
+ case "justifyContent":
103
+ style.justifyContent = value;
104
+ break;
105
+ case "color":
106
+ style.color = value;
107
+ break;
108
+ case "mt":
109
+ style.marginTop = toStylePx(value);
110
+ break;
111
+ case "mb":
112
+ style.marginBottom = toStylePx(value);
113
+ break;
114
+ case "ml":
115
+ style.marginLeft = toStylePx(value);
116
+ break;
117
+ case "mr":
118
+ style.marginRight = toStylePx(value);
119
+ break;
120
+ case "overflow":
121
+ style.overflow = value;
122
+ break;
123
+ case "whiteSpace":
124
+ style.whiteSpace = value;
125
+ break;
126
+ case "textOverflow":
127
+ style.textOverflow = value;
128
+ break;
129
+ case "textTransform":
130
+ style.textTransform = value;
131
+ break;
132
+ case "gap":
133
+ style.gap = typeof value === "number" ? `${value * SPACING_SCALE}px` : value;
134
+ break;
135
+ case "gridTemplateColumns":
136
+ style.gridTemplateColumns = value;
137
+ break;
138
+ case "minWidth":
139
+ style.minWidth = value;
140
+ break;
141
+ case "boxSize": {
142
+ const s = typeof value === "number" ? `${value * SPACING_SCALE}px` : value;
143
+ style.width = s;
144
+ style.height = s;
145
+ break;
146
+ }
147
+ case "py": {
148
+ const v = toStylePx(value);
149
+ style.paddingTop = v;
150
+ style.paddingBottom = v;
151
+ break;
152
+ }
153
+ case "px": {
154
+ const v = toStylePx(value);
155
+ style.paddingLeft = v;
156
+ style.paddingRight = v;
157
+ break;
158
+ }
159
+ case "p": {
160
+ const v = toStylePx(value);
161
+ style.padding = v;
162
+ break;
163
+ }
164
+ case "hideBelow":
165
+ break;
166
+ // handled via className
167
+ case "textStyle":
168
+ break;
169
+ // drop textStyle, not directly applicable
170
+ case "fontSize":
171
+ style.fontSize = value;
172
+ break;
173
+ case "flexWrap":
174
+ style.flexWrap = value;
175
+ break;
176
+ case "wordBreak":
177
+ style.wordBreak = value;
178
+ break;
179
+ case "lineHeight":
180
+ style.lineHeight = value;
181
+ break;
182
+ case "marginRight":
183
+ style.marginRight = value;
184
+ break;
185
+ case "position":
186
+ style.position = value;
187
+ break;
188
+ case "background":
189
+ style.background = value;
190
+ break;
191
+ default:
192
+ rest[key] = value;
193
+ break;
194
+ }
195
+ }
196
+ return { style, rest };
197
+ }
198
+ var Skeleton = React__namespace.forwardRef(
199
+ function Skeleton2(props, ref) {
200
+ const {
201
+ loading = false,
202
+ asChild,
203
+ className,
204
+ children,
205
+ style: styleProp,
206
+ // Destructure style-prop shims so they don't leak into DOM
207
+ w: _w,
208
+ h: _h,
209
+ minW: _minW,
210
+ maxW: _maxW,
211
+ display: _display,
212
+ flexGrow: _flexGrow,
213
+ flexShrink: _flexShrink,
214
+ flexBasis: _flexBasis,
215
+ fontWeight: _fontWeight,
216
+ textStyle: _textStyle,
217
+ borderRadius: _borderRadius,
218
+ alignSelf: _alignSelf,
219
+ alignItems: _alignItems,
220
+ justifyContent: _justifyContent,
221
+ color: _color,
222
+ mt: _mt,
223
+ mb: _mb,
224
+ ml: _ml,
225
+ mr: _mr,
226
+ height: _height,
227
+ overflow: _overflow,
228
+ whiteSpace: _whiteSpace,
229
+ textOverflow: _textOverflow,
230
+ textTransform: _textTransform,
231
+ gap: _gap,
232
+ gridTemplateColumns: _gridTemplateColumns,
233
+ minWidth: _minWidth,
234
+ boxSize: _boxSize,
235
+ py: _py,
236
+ px: _px,
237
+ p: _p,
238
+ hideBelow: _hideBelow,
239
+ fontSize: _fontSize,
240
+ flexWrap: _flexWrap,
241
+ wordBreak: _wordBreak,
242
+ lineHeight: _lineHeight,
243
+ marginRight: _marginRight,
244
+ position: _position,
245
+ background: _background,
246
+ as: Component = "div",
247
+ ...htmlRest
248
+ } = props;
249
+ const { style: shimStyle } = extractSkeletonStyleProps({
250
+ w: _w,
251
+ h: _h,
252
+ minW: _minW,
253
+ maxW: _maxW,
254
+ display: _display,
255
+ flexGrow: _flexGrow,
256
+ flexShrink: _flexShrink,
257
+ flexBasis: _flexBasis,
258
+ fontWeight: _fontWeight,
259
+ textStyle: _textStyle,
260
+ borderRadius: _borderRadius,
261
+ alignSelf: _alignSelf,
262
+ alignItems: _alignItems,
263
+ justifyContent: _justifyContent,
264
+ color: _color,
265
+ mt: _mt,
266
+ mb: _mb,
267
+ ml: _ml,
268
+ mr: _mr,
269
+ height: _height,
270
+ overflow: _overflow,
271
+ whiteSpace: _whiteSpace,
272
+ textOverflow: _textOverflow,
273
+ textTransform: _textTransform,
274
+ gap: _gap,
275
+ gridTemplateColumns: _gridTemplateColumns,
276
+ minWidth: _minWidth,
277
+ boxSize: _boxSize,
278
+ py: _py,
279
+ px: _px,
280
+ p: _p,
281
+ hideBelow: _hideBelow,
282
+ fontSize: _fontSize,
283
+ flexWrap: _flexWrap,
284
+ wordBreak: _wordBreak,
285
+ lineHeight: _lineHeight,
286
+ marginRight: _marginRight,
287
+ position: _position,
288
+ background: _background
289
+ });
290
+ const mergedStyle = Object.keys(shimStyle).length > 0 || styleProp ? { ...shimStyle, ...styleProp } : void 0;
291
+ const HIDE_BELOW_MAP = { lg: "lg:hidden", md: "md:hidden", sm: "sm:hidden" };
292
+ const hideBelowClass = _hideBelow ? HIDE_BELOW_MAP[_hideBelow] : void 0;
293
+ const finalClassName = hideBelowClass ? cn(className, hideBelowClass) : className;
294
+ if (!loading) {
295
+ if (asChild && React__namespace.isValidElement(children)) {
296
+ return children;
297
+ }
298
+ return /* @__PURE__ */ jsxRuntime.jsx(Component, { ref, className: finalClassName, style: mergedStyle, ...htmlRest, children });
299
+ }
300
+ if (asChild && React__namespace.isValidElement(children)) {
301
+ return /* @__PURE__ */ jsxRuntime.jsx(
302
+ Component,
303
+ {
304
+ ref,
305
+ "data-loading": true,
306
+ className: cn(
307
+ "animate-skeleton-shimmer rounded-sm",
308
+ "bg-[linear-gradient(90deg,var(--color-skeleton-start)_0%,var(--color-skeleton-end)_50%,var(--color-skeleton-start)_100%)]",
309
+ "bg-[length:200%_100%]",
310
+ "text-transparent [&_*]:invisible",
311
+ finalClassName
312
+ ),
313
+ style: mergedStyle,
314
+ ...htmlRest,
315
+ children
316
+ }
317
+ );
318
+ }
319
+ return /* @__PURE__ */ jsxRuntime.jsx(
320
+ Component,
321
+ {
322
+ ref,
323
+ "data-loading": true,
324
+ className: cn(
325
+ "animate-skeleton-shimmer rounded-sm",
326
+ "bg-[linear-gradient(90deg,var(--color-skeleton-start)_0%,var(--color-skeleton-end)_50%,var(--color-skeleton-start)_100%)]",
327
+ "bg-[length:200%_100%]",
328
+ children ? "text-transparent [&_*]:invisible" : "min-h-5",
329
+ finalClassName
330
+ ),
331
+ style: mergedStyle,
332
+ ...htmlRest,
333
+ children
334
+ }
335
+ );
336
+ }
337
+ );
338
+ var SkeletonCircle = React__namespace.forwardRef(
339
+ function SkeletonCircle2(props, ref) {
340
+ const { size = 40, loading = true, className, ...rest } = props;
341
+ const dimension = typeof size === "number" ? `${size}px` : size;
342
+ return /* @__PURE__ */ jsxRuntime.jsx(
343
+ Skeleton,
344
+ {
345
+ ref,
346
+ loading,
347
+ className: cn("rounded-full shrink-0", className),
348
+ style: { width: dimension, height: dimension, ...rest.style },
349
+ ...rest
350
+ }
351
+ );
352
+ }
353
+ );
354
+ var SkeletonText = React__namespace.forwardRef(
355
+ function SkeletonText2(props, ref) {
356
+ const { noOfLines = 3, loading = true, className, ...rest } = props;
357
+ return /* @__PURE__ */ jsxRuntime.jsx("div", { ref, className: cn("flex w-full flex-col gap-2", className), ...rest, children: Array.from({ length: noOfLines }).map((_, index) => /* @__PURE__ */ jsxRuntime.jsx(
358
+ Skeleton,
359
+ {
360
+ loading,
361
+ className: cn("h-4", index === noOfLines - 1 && "max-w-[80%]")
362
+ },
363
+ index
364
+ )) });
365
+ }
366
+ );
367
+
368
+ exports.Skeleton = Skeleton;
369
+ exports.SkeletonCircle = SkeletonCircle;
370
+ exports.SkeletonText = SkeletonText;