@luxfi/ui 5.6.0 → 6.0.0
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/README.md +109 -0
- package/package.json +81 -278
- package/dist/accordion.cjs +0 -213
- package/dist/accordion.js +0 -186
- package/dist/alert.cjs +0 -553
- package/dist/alert.js +0 -531
- package/dist/avatar.cjs +0 -149
- package/dist/avatar.js +0 -125
- package/dist/badge.cjs +0 -611
- package/dist/badge.js +0 -589
- package/dist/button.cjs +0 -689
- package/dist/button.js +0 -664
- package/dist/checkbox.cjs +0 -265
- package/dist/checkbox.js +0 -241
- package/dist/close-button.cjs +0 -73
- package/dist/close-button.js +0 -51
- package/dist/collapsible.cjs +0 -702
- package/dist/collapsible.js +0 -679
- package/dist/color-mode.cjs +0 -96
- package/dist/color-mode.js +0 -72
- package/dist/dialog.cjs +0 -279
- package/dist/dialog.js +0 -246
- package/dist/drawer.cjs +0 -207
- package/dist/drawer.js +0 -175
- package/dist/empty-state.cjs +0 -93
- package/dist/empty-state.js +0 -71
- package/dist/field.cjs +0 -183
- package/dist/field.js +0 -160
- package/dist/heading.cjs +0 -46
- package/dist/heading.js +0 -40
- package/dist/icon-button.cjs +0 -491
- package/dist/icon-button.js +0 -470
- package/dist/image.cjs +0 -572
- package/dist/image.js +0 -551
- package/dist/index.cjs +0 -5779
- package/dist/index.js +0 -5619
- package/dist/input-group.cjs +0 -155
- package/dist/input-group.js +0 -133
- package/dist/input.cjs +0 -65
- package/dist/input.js +0 -59
- package/dist/link.cjs +0 -630
- package/dist/link.js +0 -606
- package/dist/menu.cjs +0 -305
- package/dist/menu.js +0 -269
- package/dist/pin-input.cjs +0 -182
- package/dist/pin-input.js +0 -160
- package/dist/popover.cjs +0 -327
- package/dist/popover.js +0 -294
- package/dist/progress-circle.cjs +0 -152
- package/dist/progress-circle.js +0 -128
- package/dist/progress.cjs +0 -117
- package/dist/progress.js +0 -94
- package/dist/provider.cjs +0 -62
- package/dist/provider.js +0 -40
- package/dist/radio.cjs +0 -177
- package/dist/radio.js +0 -153
- package/dist/rating.cjs +0 -80
- package/dist/rating.js +0 -58
- package/dist/select.cjs +0 -791
- package/dist/select.js +0 -757
- package/dist/separator.cjs +0 -57
- package/dist/separator.js +0 -51
- package/dist/skeleton.cjs +0 -370
- package/dist/skeleton.js +0 -346
- package/dist/slider.cjs +0 -138
- package/dist/slider.js +0 -115
- package/dist/switch.cjs +0 -163
- package/dist/switch.js +0 -140
- package/dist/table.cjs +0 -1044
- package/dist/table.js +0 -1013
- package/dist/tabs.cjs +0 -240
- package/dist/tabs.js +0 -213
- package/dist/tag.cjs +0 -651
- package/dist/tag.js +0 -628
- package/dist/textarea.cjs +0 -65
- package/dist/textarea.js +0 -59
- package/dist/toaster.cjs +0 -99
- package/dist/toaster.js +0 -96
- package/dist/tooltip.cjs +0 -171
- package/dist/tooltip.js +0 -148
- package/dist/utils.cjs +0 -11
- package/dist/utils.js +0 -9
- package/src/accordion.tsx +0 -285
- package/src/alert.tsx +0 -221
- package/src/avatar.tsx +0 -174
- package/src/badge.tsx +0 -158
- package/src/button.tsx +0 -411
- package/src/checkbox.tsx +0 -307
- package/src/close-button.tsx +0 -51
- package/src/collapsible.tsx +0 -126
- package/src/color-mode.tsx +0 -125
- package/src/dialog.tsx +0 -356
- package/src/drawer.tsx +0 -186
- package/src/empty-state.tsx +0 -97
- package/src/field.tsx +0 -202
- package/src/heading.tsx +0 -55
- package/src/icon-button.tsx +0 -192
- package/src/image.tsx +0 -280
- package/src/index.ts +0 -192
- package/src/input-group.tsx +0 -159
- package/src/input.tsx +0 -60
- package/src/link.tsx +0 -326
- package/src/menu.tsx +0 -471
- package/src/pin-input.tsx +0 -187
- package/src/popover.tsx +0 -400
- package/src/progress-circle.tsx +0 -180
- package/src/progress.tsx +0 -109
- package/src/provider.tsx +0 -12
- package/src/radio.tsx +0 -175
- package/src/rating.tsx +0 -79
- package/src/select.tsx +0 -696
- package/src/separator.tsx +0 -59
- package/src/skeleton.tsx +0 -302
- package/src/slider.tsx +0 -152
- package/src/switch.tsx +0 -158
- package/src/table.tsx +0 -621
- package/src/tabs.tsx +0 -354
- package/src/tag.tsx +0 -159
- package/src/textarea.tsx +0 -60
- package/src/toaster.tsx +0 -117
- package/src/tokens.css +0 -438
- package/src/tooltip.tsx +0 -184
- package/src/utils/cn.ts +0 -7
- package/src/utils.ts +0 -6
- package/tokens.css +0 -438
package/dist/tabs.cjs
DELETED
|
@@ -1,240 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
'use strict';
|
|
3
|
-
|
|
4
|
-
var RadixTabs = require('@radix-ui/react-tabs');
|
|
5
|
-
var React = require('react');
|
|
6
|
-
var clsx = require('clsx');
|
|
7
|
-
var tailwindMerge = require('tailwind-merge');
|
|
8
|
-
var jsxRuntime = require('react/jsx-runtime');
|
|
9
|
-
|
|
10
|
-
function _interopNamespace(e) {
|
|
11
|
-
if (e && e.__esModule) return e;
|
|
12
|
-
var n = Object.create(null);
|
|
13
|
-
if (e) {
|
|
14
|
-
Object.keys(e).forEach(function (k) {
|
|
15
|
-
if (k !== 'default') {
|
|
16
|
-
var d = Object.getOwnPropertyDescriptor(e, k);
|
|
17
|
-
Object.defineProperty(n, k, d.get ? d : {
|
|
18
|
-
enumerable: true,
|
|
19
|
-
get: function () { return e[k]; }
|
|
20
|
-
});
|
|
21
|
-
}
|
|
22
|
-
});
|
|
23
|
-
}
|
|
24
|
-
n.default = e;
|
|
25
|
-
return Object.freeze(n);
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
var RadixTabs__namespace = /*#__PURE__*/_interopNamespace(RadixTabs);
|
|
29
|
-
var React__namespace = /*#__PURE__*/_interopNamespace(React);
|
|
30
|
-
|
|
31
|
-
// src/tabs.tsx
|
|
32
|
-
function cn(...inputs) {
|
|
33
|
-
return tailwindMerge.twMerge(clsx.clsx(inputs));
|
|
34
|
-
}
|
|
35
|
-
var ROOT_SIZE_CLASSES = {
|
|
36
|
-
sm: "[--tabs-height:2rem] [--tabs-content-padding:1.5rem]",
|
|
37
|
-
md: "[--tabs-height:2.5rem] [--tabs-content-padding:1.5rem]",
|
|
38
|
-
free: ""
|
|
39
|
-
};
|
|
40
|
-
var TabsRoot = React__namespace.forwardRef(
|
|
41
|
-
function TabsRoot2(props, ref) {
|
|
42
|
-
const {
|
|
43
|
-
variant = "solid",
|
|
44
|
-
size = "md",
|
|
45
|
-
fitted,
|
|
46
|
-
lazyMount: _lazyMount,
|
|
47
|
-
unmountOnExit: _unmountOnExit,
|
|
48
|
-
onValueChange,
|
|
49
|
-
className,
|
|
50
|
-
...rest
|
|
51
|
-
} = props;
|
|
52
|
-
const handleValueChange = React__namespace.useCallback(
|
|
53
|
-
(value) => {
|
|
54
|
-
if (!onValueChange) return;
|
|
55
|
-
onValueChange({ value });
|
|
56
|
-
},
|
|
57
|
-
[onValueChange]
|
|
58
|
-
);
|
|
59
|
-
return /* @__PURE__ */ jsxRuntime.jsx(
|
|
60
|
-
RadixTabs__namespace.Root,
|
|
61
|
-
{
|
|
62
|
-
ref,
|
|
63
|
-
"data-variant": variant,
|
|
64
|
-
"data-size": size,
|
|
65
|
-
"data-fitted": fitted ? "" : void 0,
|
|
66
|
-
className: cn(
|
|
67
|
-
"relative",
|
|
68
|
-
ROOT_SIZE_CLASSES[size],
|
|
69
|
-
className
|
|
70
|
-
),
|
|
71
|
-
onValueChange: onValueChange ? handleValueChange : void 0,
|
|
72
|
-
...rest
|
|
73
|
-
}
|
|
74
|
-
);
|
|
75
|
-
}
|
|
76
|
-
);
|
|
77
|
-
var TabsList = React__namespace.forwardRef(
|
|
78
|
-
function TabsList2(props, ref) {
|
|
79
|
-
const {
|
|
80
|
-
className,
|
|
81
|
-
// Strip Chakra style props
|
|
82
|
-
flexWrap: _flexWrap,
|
|
83
|
-
alignItems: _alignItems,
|
|
84
|
-
whiteSpace: _whiteSpace,
|
|
85
|
-
bgColor: _bgColor,
|
|
86
|
-
marginBottom: _marginBottom,
|
|
87
|
-
mx: _mx,
|
|
88
|
-
px: _px,
|
|
89
|
-
w: _w,
|
|
90
|
-
overflowX: _overflowX,
|
|
91
|
-
overscrollBehaviorX: _overscrollBehaviorX,
|
|
92
|
-
css: _css,
|
|
93
|
-
position: _position,
|
|
94
|
-
boxShadow: _boxShadow,
|
|
95
|
-
top: _top,
|
|
96
|
-
zIndex: _zIndex,
|
|
97
|
-
style: styleProp,
|
|
98
|
-
asChild,
|
|
99
|
-
loop,
|
|
100
|
-
...rest
|
|
101
|
-
} = props;
|
|
102
|
-
return /* @__PURE__ */ jsxRuntime.jsx(
|
|
103
|
-
RadixTabs__namespace.List,
|
|
104
|
-
{
|
|
105
|
-
ref,
|
|
106
|
-
asChild,
|
|
107
|
-
loop,
|
|
108
|
-
className: cn(
|
|
109
|
-
"inline-flex w-full relative isolate flex-row",
|
|
110
|
-
"min-h-[var(--tabs-height,2.5rem)]",
|
|
111
|
-
className
|
|
112
|
-
),
|
|
113
|
-
style: styleProp,
|
|
114
|
-
...rest
|
|
115
|
-
}
|
|
116
|
-
);
|
|
117
|
-
}
|
|
118
|
-
);
|
|
119
|
-
var TRIGGER_BASE = "outline-none min-w-[var(--tabs-height,2.5rem)] h-[var(--tabs-height,2.5rem)] flex items-center relative cursor-pointer gap-2 focus-visible:z-[1] focus-visible:outline-2 focus-visible:outline-offset-0 disabled:cursor-not-allowed disabled:opacity-50";
|
|
120
|
-
var TRIGGER_SIZE_CLASSES = {
|
|
121
|
-
sm: "py-1 px-3 text-sm",
|
|
122
|
-
md: "py-2 px-4 text-base",
|
|
123
|
-
free: ""
|
|
124
|
-
};
|
|
125
|
-
var TRIGGER_VARIANT_CLASSES = {
|
|
126
|
-
solid: "font-semibold gap-1 rounded-md bg-transparent text-tabs-solid-fg data-[state=active]:bg-selected-control-bg data-[state=active]:text-selected-control-text data-[state=active]:hover:text-selected-control-text hover:text-hover",
|
|
127
|
-
secondary: "font-medium bg-transparent text-tabs-secondary-fg border-2 border-solid border-tabs-secondary-border rounded-md data-[state=active]:bg-selected-control-bg data-[state=active]:text-selected-control-text data-[state=active]:border-transparent data-[state=active]:hover:border-transparent hover:text-hover hover:border-hover",
|
|
128
|
-
segmented: "bg-transparent text-text-primary border-2 border-solid border-selected-control-bg hover:text-hover data-[state=active]:text-selected-control-text data-[state=active]:bg-selected-control-bg data-[state=active]:border-selected-control-bg data-[state=active]:hover:text-selected-control-text",
|
|
129
|
-
unstyled: ""
|
|
130
|
-
};
|
|
131
|
-
var TabsTrigger = React__namespace.forwardRef(
|
|
132
|
-
function TabsTrigger2(props, ref) {
|
|
133
|
-
const {
|
|
134
|
-
className,
|
|
135
|
-
// Strip Chakra style props
|
|
136
|
-
scrollSnapAlign: _scrollSnapAlign,
|
|
137
|
-
flexShrink: _flexShrink,
|
|
138
|
-
bgColor: _bgColor,
|
|
139
|
-
w: _w,
|
|
140
|
-
py: _py,
|
|
141
|
-
borderRadius: _borderRadius,
|
|
142
|
-
fontWeight: _fontWeight,
|
|
143
|
-
color: _color,
|
|
144
|
-
_hover,
|
|
145
|
-
position: _position,
|
|
146
|
-
top: _top,
|
|
147
|
-
left: _left,
|
|
148
|
-
visibility: _visibility,
|
|
149
|
-
...rest
|
|
150
|
-
} = props;
|
|
151
|
-
const internalRef = React__namespace.useRef(null);
|
|
152
|
-
const mergedRef = useMergedRef(ref, internalRef);
|
|
153
|
-
const { variant, size, fitted } = useTabsContext(internalRef);
|
|
154
|
-
return /* @__PURE__ */ jsxRuntime.jsx(
|
|
155
|
-
RadixTabs__namespace.Trigger,
|
|
156
|
-
{
|
|
157
|
-
ref: mergedRef,
|
|
158
|
-
className: cn(
|
|
159
|
-
"group",
|
|
160
|
-
TRIGGER_BASE,
|
|
161
|
-
TRIGGER_SIZE_CLASSES[size],
|
|
162
|
-
TRIGGER_VARIANT_CLASSES[variant],
|
|
163
|
-
fitted && "flex-1 text-center justify-center",
|
|
164
|
-
className
|
|
165
|
-
),
|
|
166
|
-
...rest
|
|
167
|
-
}
|
|
168
|
-
);
|
|
169
|
-
}
|
|
170
|
-
);
|
|
171
|
-
var TabsContent = React__namespace.forwardRef(
|
|
172
|
-
function TabsContent2(props, ref) {
|
|
173
|
-
const { className, padding: _padding, ...rest } = props;
|
|
174
|
-
return /* @__PURE__ */ jsxRuntime.jsx(
|
|
175
|
-
RadixTabs__namespace.Content,
|
|
176
|
-
{
|
|
177
|
-
ref,
|
|
178
|
-
className: cn(
|
|
179
|
-
"w-full pt-[var(--tabs-content-padding,1.5rem)]",
|
|
180
|
-
"focus-visible:outline-2 focus-visible:outline-offset-[-2px]",
|
|
181
|
-
className
|
|
182
|
-
),
|
|
183
|
-
...rest
|
|
184
|
-
}
|
|
185
|
-
);
|
|
186
|
-
}
|
|
187
|
-
);
|
|
188
|
-
var COUNTER_OVERLOAD = 50;
|
|
189
|
-
var TabsCounter = ({ count }) => {
|
|
190
|
-
if (count === void 0 || count === null) {
|
|
191
|
-
return null;
|
|
192
|
-
}
|
|
193
|
-
return /* @__PURE__ */ jsxRuntime.jsx(
|
|
194
|
-
"span",
|
|
195
|
-
{
|
|
196
|
-
className: cn(
|
|
197
|
-
"group-hover:text-inherit",
|
|
198
|
-
count > 0 ? "text-text-secondary" : "text-[rgba(16,17,18,0.24)] dark:text-[rgba(255,255,255,0.24)]"
|
|
199
|
-
),
|
|
200
|
-
children: count > COUNTER_OVERLOAD ? `${COUNTER_OVERLOAD}+` : count
|
|
201
|
-
}
|
|
202
|
-
);
|
|
203
|
-
};
|
|
204
|
-
function useTabsContext(triggerRef) {
|
|
205
|
-
const [ctx, setCtx] = React__namespace.useState({ variant: "solid", size: "md", fitted: false });
|
|
206
|
-
React__namespace.useEffect(() => {
|
|
207
|
-
const el = triggerRef.current;
|
|
208
|
-
if (!el) return;
|
|
209
|
-
const root = el.closest("[data-variant]");
|
|
210
|
-
if (!root) return;
|
|
211
|
-
setCtx({
|
|
212
|
-
variant: root.getAttribute("data-variant") ?? "solid",
|
|
213
|
-
size: root.getAttribute("data-size") ?? "md",
|
|
214
|
-
fitted: root.hasAttribute("data-fitted")
|
|
215
|
-
});
|
|
216
|
-
}, [triggerRef]);
|
|
217
|
-
return ctx;
|
|
218
|
-
}
|
|
219
|
-
function useMergedRef(...refs) {
|
|
220
|
-
return React__namespace.useCallback(
|
|
221
|
-
(instance) => {
|
|
222
|
-
for (const ref of refs) {
|
|
223
|
-
if (!ref) continue;
|
|
224
|
-
if (typeof ref === "function") {
|
|
225
|
-
ref(instance);
|
|
226
|
-
} else {
|
|
227
|
-
ref.current = instance;
|
|
228
|
-
}
|
|
229
|
-
}
|
|
230
|
-
},
|
|
231
|
-
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
232
|
-
refs
|
|
233
|
-
);
|
|
234
|
-
}
|
|
235
|
-
|
|
236
|
-
exports.TabsContent = TabsContent;
|
|
237
|
-
exports.TabsCounter = TabsCounter;
|
|
238
|
-
exports.TabsList = TabsList;
|
|
239
|
-
exports.TabsRoot = TabsRoot;
|
|
240
|
-
exports.TabsTrigger = TabsTrigger;
|
package/dist/tabs.js
DELETED
|
@@ -1,213 +0,0 @@
|
|
|
1
|
-
"use client";
|
|
2
|
-
import * as RadixTabs from '@radix-ui/react-tabs';
|
|
3
|
-
import * as React from 'react';
|
|
4
|
-
import { clsx } from 'clsx';
|
|
5
|
-
import { twMerge } from 'tailwind-merge';
|
|
6
|
-
import { jsx } from 'react/jsx-runtime';
|
|
7
|
-
|
|
8
|
-
// src/tabs.tsx
|
|
9
|
-
function cn(...inputs) {
|
|
10
|
-
return twMerge(clsx(inputs));
|
|
11
|
-
}
|
|
12
|
-
var ROOT_SIZE_CLASSES = {
|
|
13
|
-
sm: "[--tabs-height:2rem] [--tabs-content-padding:1.5rem]",
|
|
14
|
-
md: "[--tabs-height:2.5rem] [--tabs-content-padding:1.5rem]",
|
|
15
|
-
free: ""
|
|
16
|
-
};
|
|
17
|
-
var TabsRoot = React.forwardRef(
|
|
18
|
-
function TabsRoot2(props, ref) {
|
|
19
|
-
const {
|
|
20
|
-
variant = "solid",
|
|
21
|
-
size = "md",
|
|
22
|
-
fitted,
|
|
23
|
-
lazyMount: _lazyMount,
|
|
24
|
-
unmountOnExit: _unmountOnExit,
|
|
25
|
-
onValueChange,
|
|
26
|
-
className,
|
|
27
|
-
...rest
|
|
28
|
-
} = props;
|
|
29
|
-
const handleValueChange = React.useCallback(
|
|
30
|
-
(value) => {
|
|
31
|
-
if (!onValueChange) return;
|
|
32
|
-
onValueChange({ value });
|
|
33
|
-
},
|
|
34
|
-
[onValueChange]
|
|
35
|
-
);
|
|
36
|
-
return /* @__PURE__ */ jsx(
|
|
37
|
-
RadixTabs.Root,
|
|
38
|
-
{
|
|
39
|
-
ref,
|
|
40
|
-
"data-variant": variant,
|
|
41
|
-
"data-size": size,
|
|
42
|
-
"data-fitted": fitted ? "" : void 0,
|
|
43
|
-
className: cn(
|
|
44
|
-
"relative",
|
|
45
|
-
ROOT_SIZE_CLASSES[size],
|
|
46
|
-
className
|
|
47
|
-
),
|
|
48
|
-
onValueChange: onValueChange ? handleValueChange : void 0,
|
|
49
|
-
...rest
|
|
50
|
-
}
|
|
51
|
-
);
|
|
52
|
-
}
|
|
53
|
-
);
|
|
54
|
-
var TabsList = React.forwardRef(
|
|
55
|
-
function TabsList2(props, ref) {
|
|
56
|
-
const {
|
|
57
|
-
className,
|
|
58
|
-
// Strip Chakra style props
|
|
59
|
-
flexWrap: _flexWrap,
|
|
60
|
-
alignItems: _alignItems,
|
|
61
|
-
whiteSpace: _whiteSpace,
|
|
62
|
-
bgColor: _bgColor,
|
|
63
|
-
marginBottom: _marginBottom,
|
|
64
|
-
mx: _mx,
|
|
65
|
-
px: _px,
|
|
66
|
-
w: _w,
|
|
67
|
-
overflowX: _overflowX,
|
|
68
|
-
overscrollBehaviorX: _overscrollBehaviorX,
|
|
69
|
-
css: _css,
|
|
70
|
-
position: _position,
|
|
71
|
-
boxShadow: _boxShadow,
|
|
72
|
-
top: _top,
|
|
73
|
-
zIndex: _zIndex,
|
|
74
|
-
style: styleProp,
|
|
75
|
-
asChild,
|
|
76
|
-
loop,
|
|
77
|
-
...rest
|
|
78
|
-
} = props;
|
|
79
|
-
return /* @__PURE__ */ jsx(
|
|
80
|
-
RadixTabs.List,
|
|
81
|
-
{
|
|
82
|
-
ref,
|
|
83
|
-
asChild,
|
|
84
|
-
loop,
|
|
85
|
-
className: cn(
|
|
86
|
-
"inline-flex w-full relative isolate flex-row",
|
|
87
|
-
"min-h-[var(--tabs-height,2.5rem)]",
|
|
88
|
-
className
|
|
89
|
-
),
|
|
90
|
-
style: styleProp,
|
|
91
|
-
...rest
|
|
92
|
-
}
|
|
93
|
-
);
|
|
94
|
-
}
|
|
95
|
-
);
|
|
96
|
-
var TRIGGER_BASE = "outline-none min-w-[var(--tabs-height,2.5rem)] h-[var(--tabs-height,2.5rem)] flex items-center relative cursor-pointer gap-2 focus-visible:z-[1] focus-visible:outline-2 focus-visible:outline-offset-0 disabled:cursor-not-allowed disabled:opacity-50";
|
|
97
|
-
var TRIGGER_SIZE_CLASSES = {
|
|
98
|
-
sm: "py-1 px-3 text-sm",
|
|
99
|
-
md: "py-2 px-4 text-base",
|
|
100
|
-
free: ""
|
|
101
|
-
};
|
|
102
|
-
var TRIGGER_VARIANT_CLASSES = {
|
|
103
|
-
solid: "font-semibold gap-1 rounded-md bg-transparent text-tabs-solid-fg data-[state=active]:bg-selected-control-bg data-[state=active]:text-selected-control-text data-[state=active]:hover:text-selected-control-text hover:text-hover",
|
|
104
|
-
secondary: "font-medium bg-transparent text-tabs-secondary-fg border-2 border-solid border-tabs-secondary-border rounded-md data-[state=active]:bg-selected-control-bg data-[state=active]:text-selected-control-text data-[state=active]:border-transparent data-[state=active]:hover:border-transparent hover:text-hover hover:border-hover",
|
|
105
|
-
segmented: "bg-transparent text-text-primary border-2 border-solid border-selected-control-bg hover:text-hover data-[state=active]:text-selected-control-text data-[state=active]:bg-selected-control-bg data-[state=active]:border-selected-control-bg data-[state=active]:hover:text-selected-control-text",
|
|
106
|
-
unstyled: ""
|
|
107
|
-
};
|
|
108
|
-
var TabsTrigger = React.forwardRef(
|
|
109
|
-
function TabsTrigger2(props, ref) {
|
|
110
|
-
const {
|
|
111
|
-
className,
|
|
112
|
-
// Strip Chakra style props
|
|
113
|
-
scrollSnapAlign: _scrollSnapAlign,
|
|
114
|
-
flexShrink: _flexShrink,
|
|
115
|
-
bgColor: _bgColor,
|
|
116
|
-
w: _w,
|
|
117
|
-
py: _py,
|
|
118
|
-
borderRadius: _borderRadius,
|
|
119
|
-
fontWeight: _fontWeight,
|
|
120
|
-
color: _color,
|
|
121
|
-
_hover,
|
|
122
|
-
position: _position,
|
|
123
|
-
top: _top,
|
|
124
|
-
left: _left,
|
|
125
|
-
visibility: _visibility,
|
|
126
|
-
...rest
|
|
127
|
-
} = props;
|
|
128
|
-
const internalRef = React.useRef(null);
|
|
129
|
-
const mergedRef = useMergedRef(ref, internalRef);
|
|
130
|
-
const { variant, size, fitted } = useTabsContext(internalRef);
|
|
131
|
-
return /* @__PURE__ */ jsx(
|
|
132
|
-
RadixTabs.Trigger,
|
|
133
|
-
{
|
|
134
|
-
ref: mergedRef,
|
|
135
|
-
className: cn(
|
|
136
|
-
"group",
|
|
137
|
-
TRIGGER_BASE,
|
|
138
|
-
TRIGGER_SIZE_CLASSES[size],
|
|
139
|
-
TRIGGER_VARIANT_CLASSES[variant],
|
|
140
|
-
fitted && "flex-1 text-center justify-center",
|
|
141
|
-
className
|
|
142
|
-
),
|
|
143
|
-
...rest
|
|
144
|
-
}
|
|
145
|
-
);
|
|
146
|
-
}
|
|
147
|
-
);
|
|
148
|
-
var TabsContent = React.forwardRef(
|
|
149
|
-
function TabsContent2(props, ref) {
|
|
150
|
-
const { className, padding: _padding, ...rest } = props;
|
|
151
|
-
return /* @__PURE__ */ jsx(
|
|
152
|
-
RadixTabs.Content,
|
|
153
|
-
{
|
|
154
|
-
ref,
|
|
155
|
-
className: cn(
|
|
156
|
-
"w-full pt-[var(--tabs-content-padding,1.5rem)]",
|
|
157
|
-
"focus-visible:outline-2 focus-visible:outline-offset-[-2px]",
|
|
158
|
-
className
|
|
159
|
-
),
|
|
160
|
-
...rest
|
|
161
|
-
}
|
|
162
|
-
);
|
|
163
|
-
}
|
|
164
|
-
);
|
|
165
|
-
var COUNTER_OVERLOAD = 50;
|
|
166
|
-
var TabsCounter = ({ count }) => {
|
|
167
|
-
if (count === void 0 || count === null) {
|
|
168
|
-
return null;
|
|
169
|
-
}
|
|
170
|
-
return /* @__PURE__ */ jsx(
|
|
171
|
-
"span",
|
|
172
|
-
{
|
|
173
|
-
className: cn(
|
|
174
|
-
"group-hover:text-inherit",
|
|
175
|
-
count > 0 ? "text-text-secondary" : "text-[rgba(16,17,18,0.24)] dark:text-[rgba(255,255,255,0.24)]"
|
|
176
|
-
),
|
|
177
|
-
children: count > COUNTER_OVERLOAD ? `${COUNTER_OVERLOAD}+` : count
|
|
178
|
-
}
|
|
179
|
-
);
|
|
180
|
-
};
|
|
181
|
-
function useTabsContext(triggerRef) {
|
|
182
|
-
const [ctx, setCtx] = React.useState({ variant: "solid", size: "md", fitted: false });
|
|
183
|
-
React.useEffect(() => {
|
|
184
|
-
const el = triggerRef.current;
|
|
185
|
-
if (!el) return;
|
|
186
|
-
const root = el.closest("[data-variant]");
|
|
187
|
-
if (!root) return;
|
|
188
|
-
setCtx({
|
|
189
|
-
variant: root.getAttribute("data-variant") ?? "solid",
|
|
190
|
-
size: root.getAttribute("data-size") ?? "md",
|
|
191
|
-
fitted: root.hasAttribute("data-fitted")
|
|
192
|
-
});
|
|
193
|
-
}, [triggerRef]);
|
|
194
|
-
return ctx;
|
|
195
|
-
}
|
|
196
|
-
function useMergedRef(...refs) {
|
|
197
|
-
return React.useCallback(
|
|
198
|
-
(instance) => {
|
|
199
|
-
for (const ref of refs) {
|
|
200
|
-
if (!ref) continue;
|
|
201
|
-
if (typeof ref === "function") {
|
|
202
|
-
ref(instance);
|
|
203
|
-
} else {
|
|
204
|
-
ref.current = instance;
|
|
205
|
-
}
|
|
206
|
-
}
|
|
207
|
-
},
|
|
208
|
-
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
209
|
-
refs
|
|
210
|
-
);
|
|
211
|
-
}
|
|
212
|
-
|
|
213
|
-
export { TabsContent, TabsCounter, TabsList, TabsRoot, TabsTrigger };
|