@admin-layout/gluestack-ui-mobile 10.0.9-alpha.9 → 10.1.1-alpha.8
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/CHANGELOG.md +2 -6
- package/lib/components/ui/accordion/index.web.d.ts +209 -0
- package/lib/components/ui/accordion/index.web.js +156 -0
- package/lib/components/ui/accordion/index.web.js.map +1 -0
- package/lib/components/ui/actionsheet/index.web.d.ts +872 -0
- package/lib/components/ui/actionsheet/index.web.js +286 -0
- package/lib/components/ui/actionsheet/index.web.js.map +1 -0
- package/lib/components/ui/alert/index.web.d.ts +135 -0
- package/lib/components/ui/alert/index.web.js +38 -0
- package/lib/components/ui/alert/index.web.js.map +1 -0
- package/lib/components/ui/alert-dialog/index.web.d.ts +64 -0
- package/lib/components/ui/alert-dialog/index.web.js +139 -0
- package/lib/components/ui/alert-dialog/index.web.js.map +1 -0
- package/lib/components/ui/avatar/index.web.d.ts +21 -0
- package/lib/components/ui/avatar/index.web.js +92 -0
- package/lib/components/ui/avatar/index.web.js.map +1 -0
- package/lib/components/ui/badge/index.web.d.ts +382 -0
- package/lib/components/ui/badge/index.web.js +138 -0
- package/lib/components/ui/badge/index.web.js.map +1 -0
- package/lib/components/ui/button/index.web.d.ts +247 -0
- package/lib/components/ui/button/index.web.js +57 -0
- package/lib/components/ui/button/index.web.js.map +1 -0
- package/lib/components/ui/checkbox/index.web.d.ts +265 -0
- package/lib/components/ui/checkbox/index.web.js +77 -0
- package/lib/components/ui/checkbox/index.web.js.map +1 -0
- package/lib/components/ui/divider/index.web.d.ts +53 -0
- package/lib/components/ui/divider/index.web.js +21 -0
- package/lib/components/ui/divider/index.web.js.map +1 -0
- package/lib/components/ui/drawer/index.web.d.ts +174 -0
- package/lib/components/ui/drawer/index.web.js +65 -0
- package/lib/components/ui/drawer/index.web.js.map +1 -0
- package/lib/components/ui/fab/index.web.d.ts +520 -0
- package/lib/components/ui/fab/index.web.js +146 -0
- package/lib/components/ui/fab/index.web.js.map +1 -0
- package/lib/components/ui/flat-list/index.web.d.ts +21 -0
- package/lib/components/ui/flat-list/index.web.js +41 -0
- package/lib/components/ui/flat-list/index.web.js.map +1 -0
- package/lib/components/ui/form-control/index.web.d.ts +2071 -0
- package/lib/components/ui/form-control/index.web.js +290 -0
- package/lib/components/ui/form-control/index.web.js.map +1 -0
- package/lib/components/ui/image/index.web.d.ts +142 -0
- package/lib/components/ui/image/index.web.js +29 -0
- package/lib/components/ui/image/index.web.js.map +1 -0
- package/lib/components/ui/image-background/index.web.d.ts +8 -0
- package/lib/components/ui/image-background/index.web.js +23 -0
- package/lib/components/ui/image-background/index.web.js.map +1 -0
- package/lib/components/ui/input/index.web.d.ts +163 -0
- package/lib/components/ui/input/index.web.js +50 -0
- package/lib/components/ui/input/index.web.js.map +1 -0
- package/lib/components/ui/input-accessory-view/index.web.d.ts +9 -0
- package/lib/components/ui/input-accessory-view/index.web.js +16 -0
- package/lib/components/ui/input-accessory-view/index.web.js.map +1 -0
- package/lib/components/ui/keyboard-avoiding-view/index.web.d.ts +9 -0
- package/lib/components/ui/keyboard-avoiding-view/index.web.js +8 -0
- package/lib/components/ui/keyboard-avoiding-view/index.web.js.map +1 -0
- package/lib/components/ui/link/index.web.d.ts +365 -0
- package/lib/components/ui/link/index.web.js +70 -0
- package/lib/components/ui/link/index.web.js.map +1 -0
- package/lib/components/ui/menu/index.web.d.ts +142 -0
- package/lib/components/ui/menu/index.web.js +83 -0
- package/lib/components/ui/menu/index.web.js.map +1 -0
- package/lib/components/ui/modal/index.web.d.ts +111 -0
- package/lib/components/ui/modal/index.web.js +58 -0
- package/lib/components/ui/modal/index.web.js.map +1 -0
- package/lib/components/ui/popover/index.web.d.ts +309 -0
- package/lib/components/ui/popover/index.web.js +184 -0
- package/lib/components/ui/popover/index.web.js.map +1 -0
- package/lib/components/ui/portal/index.web.d.ts +9 -0
- package/lib/components/ui/portal/index.web.js +16 -0
- package/lib/components/ui/portal/index.web.js.map +1 -0
- package/lib/components/ui/pressable/index.web.d.ts +8 -0
- package/lib/components/ui/pressable/index.web.js +44 -0
- package/lib/components/ui/pressable/index.web.js.map +1 -0
- package/lib/components/ui/progress/index.web.d.ts +237 -0
- package/lib/components/ui/progress/index.web.js +73 -0
- package/lib/components/ui/progress/index.web.js.map +1 -0
- package/lib/components/ui/radio/index.web.d.ts +224 -0
- package/lib/components/ui/radio/index.web.js +69 -0
- package/lib/components/ui/radio/index.web.js.map +1 -0
- package/lib/components/ui/refresh-control/index.web.d.ts +14 -0
- package/lib/components/ui/refresh-control/index.web.js +69 -0
- package/lib/components/ui/refresh-control/index.web.js.map +1 -0
- package/lib/components/ui/safe-area-view/index.web.d.ts +6 -0
- package/lib/components/ui/safe-area-view/index.web.js +10 -0
- package/lib/components/ui/safe-area-view/index.web.js.map +1 -0
- package/lib/components/ui/scroll-view/index.web.d.ts +44 -0
- package/lib/components/ui/scroll-view/index.web.js +41 -0
- package/lib/components/ui/scroll-view/index.web.js.map +1 -0
- package/lib/components/ui/section-list/index.web.d.ts +26 -0
- package/lib/components/ui/section-list/index.web.js +35 -0
- package/lib/components/ui/section-list/index.web.js.map +1 -0
- package/lib/components/ui/select/index.web.d.ts +162 -0
- package/lib/components/ui/select/index.web.js +51 -0
- package/lib/components/ui/select/index.web.js.map +1 -0
- package/lib/components/ui/slider/index.web.d.ts +223 -0
- package/lib/components/ui/slider/index.web.js +189 -0
- package/lib/components/ui/slider/index.web.js.map +1 -0
- package/lib/components/ui/spinner/index.web.d.ts +176 -0
- package/lib/components/ui/spinner/index.web.js +55 -0
- package/lib/components/ui/spinner/index.web.js.map +1 -0
- package/lib/components/ui/status-bar/index.web.d.ts +14 -0
- package/lib/components/ui/status-bar/index.web.js +7 -0
- package/lib/components/ui/status-bar/index.web.js.map +1 -0
- package/lib/components/ui/switch/index.web.d.ts +71 -0
- package/lib/components/ui/switch/index.web.js +27 -0
- package/lib/components/ui/switch/index.web.js.map +1 -0
- package/lib/components/ui/tabs/index.web.d.ts +351 -0
- package/lib/components/ui/tabs/index.web.js +120 -0
- package/lib/components/ui/tabs/index.web.js.map +1 -0
- package/lib/components/ui/textarea/index.web.d.ts +162 -0
- package/lib/components/ui/textarea/index.web.js +50 -0
- package/lib/components/ui/textarea/index.web.js.map +1 -0
- package/lib/components/ui/toast/index.web.d.ts +225 -0
- package/lib/components/ui/toast/index.web.js +80 -0
- package/lib/components/ui/toast/index.web.js.map +1 -0
- package/lib/components/ui/tooltip/index.web.d.ts +86 -0
- package/lib/components/ui/tooltip/index.web.js +110 -0
- package/lib/components/ui/tooltip/index.web.js.map +1 -0
- package/lib/components/ui/view/index.web.d.ts +2 -0
- package/lib/components/ui/view/index.web.js +7 -0
- package/lib/components/ui/view/index.web.js.map +1 -0
- package/lib/components/ui/virtualized-list/index.web.d.ts +19 -0
- package/lib/components/ui/virtualized-list/index.web.js +30 -0
- package/lib/components/ui/virtualized-list/index.web.js.map +1 -0
- package/lib/components/usePermissionAutoFetch.d.ts +7 -19
- package/lib/containers/layout/DrawerBottomNavigationConfig.d.ts +47 -47
- package/lib/containers/layout/DrawerConfig.d.ts +31 -31
- package/lib/redux/settings.d.ts +3 -9
- package/package.json +9 -5
- package/src/components/ui/accordion/index.web.tsx +294 -0
- package/src/components/ui/actionsheet/index.web.tsx +555 -0
- package/src/components/ui/alert/index.web.tsx +71 -0
- package/src/components/ui/alert-dialog/index.web.tsx +241 -0
- package/src/components/ui/avatar/index.web.tsx +150 -0
- package/src/components/ui/badge/index.web.tsx +188 -0
- package/src/components/ui/button/index.web.tsx +86 -0
- package/src/components/ui/checkbox/index.web.tsx +151 -0
- package/src/components/ui/divider/index.web.tsx +37 -0
- package/src/components/ui/drawer/index.web.tsx +144 -0
- package/src/components/ui/fab/index.web.tsx +201 -0
- package/src/components/ui/flat-list/index.web.tsx +89 -0
- package/src/components/ui/form-control/index.web.tsx +451 -0
- package/src/components/ui/image/index.web.tsx +43 -0
- package/src/components/ui/image-background/index.web.tsx +43 -0
- package/src/components/ui/input/index.web.tsx +80 -0
- package/src/components/ui/input-accessory-view/index.web.tsx +31 -0
- package/src/components/ui/keyboard-avoiding-view/index.web.tsx +23 -0
- package/src/components/ui/link/index.web.tsx +103 -0
- package/src/components/ui/menu/index.web.tsx +159 -0
- package/src/components/ui/modal/index.web.tsx +135 -0
- package/src/components/ui/popover/index.web.tsx +326 -0
- package/src/components/ui/portal/index.web.tsx +34 -0
- package/src/components/ui/pressable/index.web.tsx +73 -0
- package/src/components/ui/progress/index.web.tsx +123 -0
- package/src/components/ui/radio/index.web.tsx +130 -0
- package/src/components/ui/refresh-control/index.web.tsx +104 -0
- package/src/components/ui/safe-area-view/index.web.tsx +24 -0
- package/src/components/ui/scroll-view/index.web.tsx +142 -0
- package/src/components/ui/section-list/index.web.tsx +93 -0
- package/src/components/ui/select/index.web.tsx +83 -0
- package/src/components/ui/slider/index.web.tsx +283 -0
- package/src/components/ui/spinner/index.web.tsx +81 -0
- package/src/components/ui/status-bar/index.web.tsx +20 -0
- package/src/components/ui/switch/index.web.tsx +44 -0
- package/src/components/ui/tabs/index.web.tsx +205 -0
- package/src/components/ui/textarea/index.web.tsx +86 -0
- package/src/components/ui/toast/index.web.tsx +132 -0
- package/src/components/ui/tooltip/index.web.tsx +155 -0
- package/src/components/ui/view/index.web.tsx +15 -0
- package/src/components/ui/virtualized-list/index.web.tsx +84 -0
|
@@ -0,0 +1,351 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import type { VariantProps } from '@gluestack-ui/nativewind-utils';
|
|
3
|
+
declare const tabListStyle: import("@gluestack-ui/nativewind-utils/types").TVReturnType<{
|
|
4
|
+
align: {
|
|
5
|
+
start: string;
|
|
6
|
+
center: string;
|
|
7
|
+
end: string;
|
|
8
|
+
};
|
|
9
|
+
size: {
|
|
10
|
+
sm: string;
|
|
11
|
+
md: string;
|
|
12
|
+
lg: string;
|
|
13
|
+
};
|
|
14
|
+
} | ({
|
|
15
|
+
align: {
|
|
16
|
+
start: string;
|
|
17
|
+
center: string;
|
|
18
|
+
end: string;
|
|
19
|
+
};
|
|
20
|
+
size: {
|
|
21
|
+
sm: string;
|
|
22
|
+
md: string;
|
|
23
|
+
lg: string;
|
|
24
|
+
};
|
|
25
|
+
} & {
|
|
26
|
+
align: {
|
|
27
|
+
start: import("tailwind-merge").ClassNameValue | {
|
|
28
|
+
base?: import("tailwind-merge").ClassNameValue;
|
|
29
|
+
};
|
|
30
|
+
center: import("tailwind-merge").ClassNameValue | {
|
|
31
|
+
base?: import("tailwind-merge").ClassNameValue;
|
|
32
|
+
};
|
|
33
|
+
end: import("tailwind-merge").ClassNameValue | {
|
|
34
|
+
base?: import("tailwind-merge").ClassNameValue;
|
|
35
|
+
};
|
|
36
|
+
};
|
|
37
|
+
size: {
|
|
38
|
+
sm: import("tailwind-merge").ClassNameValue | {
|
|
39
|
+
base?: import("tailwind-merge").ClassNameValue;
|
|
40
|
+
};
|
|
41
|
+
md: import("tailwind-merge").ClassNameValue | {
|
|
42
|
+
base?: import("tailwind-merge").ClassNameValue;
|
|
43
|
+
};
|
|
44
|
+
lg: import("tailwind-merge").ClassNameValue | {
|
|
45
|
+
base?: import("tailwind-merge").ClassNameValue;
|
|
46
|
+
};
|
|
47
|
+
};
|
|
48
|
+
}), undefined, "flex border-b border-gray-200", import("tailwind-variants/dist/config").TVConfig<{
|
|
49
|
+
align: {
|
|
50
|
+
start: string;
|
|
51
|
+
center: string;
|
|
52
|
+
end: string;
|
|
53
|
+
};
|
|
54
|
+
size: {
|
|
55
|
+
sm: string;
|
|
56
|
+
md: string;
|
|
57
|
+
lg: string;
|
|
58
|
+
};
|
|
59
|
+
}, {
|
|
60
|
+
align: {
|
|
61
|
+
start: string;
|
|
62
|
+
center: string;
|
|
63
|
+
end: string;
|
|
64
|
+
};
|
|
65
|
+
size: {
|
|
66
|
+
sm: string;
|
|
67
|
+
md: string;
|
|
68
|
+
lg: string;
|
|
69
|
+
};
|
|
70
|
+
}>, {
|
|
71
|
+
align: {
|
|
72
|
+
start: string;
|
|
73
|
+
center: string;
|
|
74
|
+
end: string;
|
|
75
|
+
};
|
|
76
|
+
size: {
|
|
77
|
+
sm: string;
|
|
78
|
+
md: string;
|
|
79
|
+
lg: string;
|
|
80
|
+
};
|
|
81
|
+
}, undefined, import("@gluestack-ui/nativewind-utils/types").TVReturnType<{
|
|
82
|
+
align: {
|
|
83
|
+
start: string;
|
|
84
|
+
center: string;
|
|
85
|
+
end: string;
|
|
86
|
+
};
|
|
87
|
+
size: {
|
|
88
|
+
sm: string;
|
|
89
|
+
md: string;
|
|
90
|
+
lg: string;
|
|
91
|
+
};
|
|
92
|
+
}, undefined, "flex border-b border-gray-200", import("tailwind-variants/dist/config").TVConfig<{
|
|
93
|
+
align: {
|
|
94
|
+
start: string;
|
|
95
|
+
center: string;
|
|
96
|
+
end: string;
|
|
97
|
+
};
|
|
98
|
+
size: {
|
|
99
|
+
sm: string;
|
|
100
|
+
md: string;
|
|
101
|
+
lg: string;
|
|
102
|
+
};
|
|
103
|
+
}, {
|
|
104
|
+
align: {
|
|
105
|
+
start: string;
|
|
106
|
+
center: string;
|
|
107
|
+
end: string;
|
|
108
|
+
};
|
|
109
|
+
size: {
|
|
110
|
+
sm: string;
|
|
111
|
+
md: string;
|
|
112
|
+
lg: string;
|
|
113
|
+
};
|
|
114
|
+
}>, unknown, unknown, undefined>>;
|
|
115
|
+
declare const tabStyle: import("@gluestack-ui/nativewind-utils/types").TVReturnType<{
|
|
116
|
+
variant: {
|
|
117
|
+
line: string;
|
|
118
|
+
enclosed: string;
|
|
119
|
+
soft: string;
|
|
120
|
+
};
|
|
121
|
+
size: {
|
|
122
|
+
sm: string;
|
|
123
|
+
md: string;
|
|
124
|
+
lg: string;
|
|
125
|
+
};
|
|
126
|
+
state: {
|
|
127
|
+
active: {
|
|
128
|
+
line: string;
|
|
129
|
+
enclosed: string;
|
|
130
|
+
soft: string;
|
|
131
|
+
};
|
|
132
|
+
inactive: {
|
|
133
|
+
line: string;
|
|
134
|
+
enclosed: string;
|
|
135
|
+
soft: string;
|
|
136
|
+
};
|
|
137
|
+
};
|
|
138
|
+
} | ({
|
|
139
|
+
variant: {
|
|
140
|
+
line: string;
|
|
141
|
+
enclosed: string;
|
|
142
|
+
soft: string;
|
|
143
|
+
};
|
|
144
|
+
size: {
|
|
145
|
+
sm: string;
|
|
146
|
+
md: string;
|
|
147
|
+
lg: string;
|
|
148
|
+
};
|
|
149
|
+
state: {
|
|
150
|
+
active: {
|
|
151
|
+
line: string;
|
|
152
|
+
enclosed: string;
|
|
153
|
+
soft: string;
|
|
154
|
+
};
|
|
155
|
+
inactive: {
|
|
156
|
+
line: string;
|
|
157
|
+
enclosed: string;
|
|
158
|
+
soft: string;
|
|
159
|
+
};
|
|
160
|
+
};
|
|
161
|
+
} & {
|
|
162
|
+
variant: {
|
|
163
|
+
line: import("tailwind-merge").ClassNameValue | {
|
|
164
|
+
base?: import("tailwind-merge").ClassNameValue;
|
|
165
|
+
};
|
|
166
|
+
enclosed: import("tailwind-merge").ClassNameValue | {
|
|
167
|
+
base?: import("tailwind-merge").ClassNameValue;
|
|
168
|
+
};
|
|
169
|
+
soft: import("tailwind-merge").ClassNameValue | {
|
|
170
|
+
base?: import("tailwind-merge").ClassNameValue;
|
|
171
|
+
};
|
|
172
|
+
};
|
|
173
|
+
size: {
|
|
174
|
+
sm: import("tailwind-merge").ClassNameValue | {
|
|
175
|
+
base?: import("tailwind-merge").ClassNameValue;
|
|
176
|
+
};
|
|
177
|
+
md: import("tailwind-merge").ClassNameValue | {
|
|
178
|
+
base?: import("tailwind-merge").ClassNameValue;
|
|
179
|
+
};
|
|
180
|
+
lg: import("tailwind-merge").ClassNameValue | {
|
|
181
|
+
base?: import("tailwind-merge").ClassNameValue;
|
|
182
|
+
};
|
|
183
|
+
};
|
|
184
|
+
state: {
|
|
185
|
+
active: import("tailwind-merge").ClassNameValue | {
|
|
186
|
+
base?: import("tailwind-merge").ClassNameValue;
|
|
187
|
+
};
|
|
188
|
+
inactive: import("tailwind-merge").ClassNameValue | {
|
|
189
|
+
base?: import("tailwind-merge").ClassNameValue;
|
|
190
|
+
};
|
|
191
|
+
};
|
|
192
|
+
}), undefined, "px-4 py-2 font-medium focus:outline-none focus:ring-2 focus:ring-blue-500 rounded-t-lg transition-colors", import("tailwind-variants/dist/config").TVConfig<{
|
|
193
|
+
variant: {
|
|
194
|
+
line: string;
|
|
195
|
+
enclosed: string;
|
|
196
|
+
soft: string;
|
|
197
|
+
};
|
|
198
|
+
size: {
|
|
199
|
+
sm: string;
|
|
200
|
+
md: string;
|
|
201
|
+
lg: string;
|
|
202
|
+
};
|
|
203
|
+
state: {
|
|
204
|
+
active: {
|
|
205
|
+
line: string;
|
|
206
|
+
enclosed: string;
|
|
207
|
+
soft: string;
|
|
208
|
+
};
|
|
209
|
+
inactive: {
|
|
210
|
+
line: string;
|
|
211
|
+
enclosed: string;
|
|
212
|
+
soft: string;
|
|
213
|
+
};
|
|
214
|
+
};
|
|
215
|
+
}, {
|
|
216
|
+
variant: {
|
|
217
|
+
line: string;
|
|
218
|
+
enclosed: string;
|
|
219
|
+
soft: string;
|
|
220
|
+
};
|
|
221
|
+
size: {
|
|
222
|
+
sm: string;
|
|
223
|
+
md: string;
|
|
224
|
+
lg: string;
|
|
225
|
+
};
|
|
226
|
+
state: {
|
|
227
|
+
active: {
|
|
228
|
+
line: string;
|
|
229
|
+
enclosed: string;
|
|
230
|
+
soft: string;
|
|
231
|
+
};
|
|
232
|
+
inactive: {
|
|
233
|
+
line: string;
|
|
234
|
+
enclosed: string;
|
|
235
|
+
soft: string;
|
|
236
|
+
};
|
|
237
|
+
};
|
|
238
|
+
}>, {
|
|
239
|
+
variant: {
|
|
240
|
+
line: string;
|
|
241
|
+
enclosed: string;
|
|
242
|
+
soft: string;
|
|
243
|
+
};
|
|
244
|
+
size: {
|
|
245
|
+
sm: string;
|
|
246
|
+
md: string;
|
|
247
|
+
lg: string;
|
|
248
|
+
};
|
|
249
|
+
state: {
|
|
250
|
+
active: {
|
|
251
|
+
line: string;
|
|
252
|
+
enclosed: string;
|
|
253
|
+
soft: string;
|
|
254
|
+
};
|
|
255
|
+
inactive: {
|
|
256
|
+
line: string;
|
|
257
|
+
enclosed: string;
|
|
258
|
+
soft: string;
|
|
259
|
+
};
|
|
260
|
+
};
|
|
261
|
+
}, undefined, import("@gluestack-ui/nativewind-utils/types").TVReturnType<{
|
|
262
|
+
variant: {
|
|
263
|
+
line: string;
|
|
264
|
+
enclosed: string;
|
|
265
|
+
soft: string;
|
|
266
|
+
};
|
|
267
|
+
size: {
|
|
268
|
+
sm: string;
|
|
269
|
+
md: string;
|
|
270
|
+
lg: string;
|
|
271
|
+
};
|
|
272
|
+
state: {
|
|
273
|
+
active: {
|
|
274
|
+
line: string;
|
|
275
|
+
enclosed: string;
|
|
276
|
+
soft: string;
|
|
277
|
+
};
|
|
278
|
+
inactive: {
|
|
279
|
+
line: string;
|
|
280
|
+
enclosed: string;
|
|
281
|
+
soft: string;
|
|
282
|
+
};
|
|
283
|
+
};
|
|
284
|
+
}, undefined, "px-4 py-2 font-medium focus:outline-none focus:ring-2 focus:ring-blue-500 rounded-t-lg transition-colors", import("tailwind-variants/dist/config").TVConfig<{
|
|
285
|
+
variant: {
|
|
286
|
+
line: string;
|
|
287
|
+
enclosed: string;
|
|
288
|
+
soft: string;
|
|
289
|
+
};
|
|
290
|
+
size: {
|
|
291
|
+
sm: string;
|
|
292
|
+
md: string;
|
|
293
|
+
lg: string;
|
|
294
|
+
};
|
|
295
|
+
state: {
|
|
296
|
+
active: {
|
|
297
|
+
line: string;
|
|
298
|
+
enclosed: string;
|
|
299
|
+
soft: string;
|
|
300
|
+
};
|
|
301
|
+
inactive: {
|
|
302
|
+
line: string;
|
|
303
|
+
enclosed: string;
|
|
304
|
+
soft: string;
|
|
305
|
+
};
|
|
306
|
+
};
|
|
307
|
+
}, {
|
|
308
|
+
variant: {
|
|
309
|
+
line: string;
|
|
310
|
+
enclosed: string;
|
|
311
|
+
soft: string;
|
|
312
|
+
};
|
|
313
|
+
size: {
|
|
314
|
+
sm: string;
|
|
315
|
+
md: string;
|
|
316
|
+
lg: string;
|
|
317
|
+
};
|
|
318
|
+
state: {
|
|
319
|
+
active: {
|
|
320
|
+
line: string;
|
|
321
|
+
enclosed: string;
|
|
322
|
+
soft: string;
|
|
323
|
+
};
|
|
324
|
+
inactive: {
|
|
325
|
+
line: string;
|
|
326
|
+
enclosed: string;
|
|
327
|
+
soft: string;
|
|
328
|
+
};
|
|
329
|
+
};
|
|
330
|
+
}>, unknown, unknown, undefined>>;
|
|
331
|
+
type ITabsProps = React.ComponentProps<'div'> & {
|
|
332
|
+
defaultIndex?: number;
|
|
333
|
+
onChange?: (index: number) => void;
|
|
334
|
+
variant?: VariantProps<typeof tabStyle>['variant'];
|
|
335
|
+
size?: VariantProps<typeof tabStyle>['size'];
|
|
336
|
+
};
|
|
337
|
+
export declare const Tabs: React.ForwardRefExoticComponent<Omit<ITabsProps, "ref"> & React.RefAttributes<HTMLDivElement>>;
|
|
338
|
+
type ITabListProps = React.ComponentProps<'div'> & {
|
|
339
|
+
align?: VariantProps<typeof tabListStyle>['align'];
|
|
340
|
+
size?: VariantProps<typeof tabListStyle>['size'];
|
|
341
|
+
};
|
|
342
|
+
export declare const TabList: React.ForwardRefExoticComponent<Omit<ITabListProps, "ref"> & React.RefAttributes<HTMLDivElement>>;
|
|
343
|
+
type ITabProps = Omit<React.ComponentProps<'button'>, 'value'> & {
|
|
344
|
+
index?: number;
|
|
345
|
+
};
|
|
346
|
+
export declare const Tab: React.ForwardRefExoticComponent<Omit<ITabProps, "ref"> & React.RefAttributes<HTMLButtonElement>>;
|
|
347
|
+
type ITabPanelProps = React.ComponentProps<'div'> & {
|
|
348
|
+
index?: number;
|
|
349
|
+
};
|
|
350
|
+
export declare const TabPanel: React.ForwardRefExoticComponent<Omit<ITabPanelProps, "ref"> & React.RefAttributes<HTMLDivElement>>;
|
|
351
|
+
export {};
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import React, { forwardRef, createContext, useContext, useState } from 'react';
|
|
3
|
+
import { tva } from '@gluestack-ui/nativewind-utils/tva';
|
|
4
|
+
const SCOPE = 'TABS';
|
|
5
|
+
const tabListStyle = tva({
|
|
6
|
+
base: 'flex border-b border-gray-200',
|
|
7
|
+
variants: {
|
|
8
|
+
align: {
|
|
9
|
+
start: 'justify-start',
|
|
10
|
+
center: 'justify-center',
|
|
11
|
+
end: 'justify-end',
|
|
12
|
+
},
|
|
13
|
+
size: {
|
|
14
|
+
sm: 'gap-2',
|
|
15
|
+
md: 'gap-4',
|
|
16
|
+
lg: 'gap-6',
|
|
17
|
+
},
|
|
18
|
+
},
|
|
19
|
+
defaultVariants: {
|
|
20
|
+
align: 'start',
|
|
21
|
+
size: 'md',
|
|
22
|
+
},
|
|
23
|
+
});
|
|
24
|
+
const tabStyle = tva({
|
|
25
|
+
base: 'px-4 py-2 font-medium focus:outline-none focus:ring-2 focus:ring-blue-500 rounded-t-lg transition-colors',
|
|
26
|
+
variants: {
|
|
27
|
+
variant: {
|
|
28
|
+
line: '-mb-px border-b-2 hover:border-gray-300',
|
|
29
|
+
enclosed: 'border border-b-0 hover:bg-gray-50',
|
|
30
|
+
soft: 'hover:bg-gray-100 rounded-lg',
|
|
31
|
+
},
|
|
32
|
+
size: {
|
|
33
|
+
sm: 'text-sm',
|
|
34
|
+
md: 'text-base',
|
|
35
|
+
lg: 'text-lg',
|
|
36
|
+
},
|
|
37
|
+
state: {
|
|
38
|
+
active: {
|
|
39
|
+
line: 'border-blue-500 text-blue-600',
|
|
40
|
+
enclosed: 'border-gray-200 bg-white',
|
|
41
|
+
soft: 'bg-gray-100 text-blue-600',
|
|
42
|
+
},
|
|
43
|
+
inactive: {
|
|
44
|
+
line: 'border-transparent text-gray-500',
|
|
45
|
+
enclosed: 'border-transparent text-gray-500',
|
|
46
|
+
soft: 'text-gray-500',
|
|
47
|
+
},
|
|
48
|
+
},
|
|
49
|
+
},
|
|
50
|
+
defaultVariants: {
|
|
51
|
+
variant: 'line',
|
|
52
|
+
size: 'md',
|
|
53
|
+
state: 'inactive',
|
|
54
|
+
},
|
|
55
|
+
});
|
|
56
|
+
const tabPanelStyle = tva({
|
|
57
|
+
base: 'mt-4 focus:outline-none focus:ring-2 focus:ring-blue-500 rounded-lg',
|
|
58
|
+
});
|
|
59
|
+
const TabsContext = createContext({
|
|
60
|
+
selectedIndex: 0,
|
|
61
|
+
onChange: () => { },
|
|
62
|
+
});
|
|
63
|
+
export const Tabs = forwardRef(({ defaultIndex = 0, onChange, variant = 'line', size = 'md', children, ...props }, ref) => {
|
|
64
|
+
const [selectedIndex, setSelectedIndex] = useState(defaultIndex);
|
|
65
|
+
const handleChange = (index) => {
|
|
66
|
+
setSelectedIndex(index);
|
|
67
|
+
if (onChange)
|
|
68
|
+
onChange(index);
|
|
69
|
+
};
|
|
70
|
+
return (React.createElement(TabsContext.Provider, { value: { selectedIndex, onChange: handleChange, variant, size } },
|
|
71
|
+
React.createElement("div", { ref: ref, ...props }, children)));
|
|
72
|
+
});
|
|
73
|
+
Tabs.displayName = 'Tabs';
|
|
74
|
+
export const TabList = forwardRef(({ className, align, size: sizeProp, children, ...props }, ref) => {
|
|
75
|
+
const { size } = useContext(TabsContext);
|
|
76
|
+
return (React.createElement("div", { ref: ref, role: "tablist", className: tabListStyle({ align, size: sizeProp || size, class: className }), ...props }, children));
|
|
77
|
+
});
|
|
78
|
+
TabList.displayName = 'TabList';
|
|
79
|
+
export const Tab = forwardRef(({ className, index = 0, onClick, onKeyDown, children, ...props }, ref) => {
|
|
80
|
+
const { selectedIndex, onChange, variant, size } = useContext(TabsContext);
|
|
81
|
+
const isSelected = selectedIndex === index;
|
|
82
|
+
const handleClick = (e) => {
|
|
83
|
+
if (onClick)
|
|
84
|
+
onClick(e);
|
|
85
|
+
onChange(index);
|
|
86
|
+
};
|
|
87
|
+
const handleKeyDown = (e) => {
|
|
88
|
+
if (onKeyDown)
|
|
89
|
+
onKeyDown(e);
|
|
90
|
+
if (e.key === 'ArrowLeft' || e.key === 'ArrowRight') {
|
|
91
|
+
e.preventDefault();
|
|
92
|
+
const tabList = e.currentTarget.parentElement;
|
|
93
|
+
if (tabList) {
|
|
94
|
+
const tabs = Array.from(tabList.querySelectorAll('[role="tab"]'));
|
|
95
|
+
const currentIndex = tabs.indexOf(e.currentTarget);
|
|
96
|
+
const nextIndex = e.key === 'ArrowLeft' ? currentIndex - 1 : currentIndex + 1;
|
|
97
|
+
if (nextIndex >= 0 && nextIndex < tabs.length) {
|
|
98
|
+
tabs[nextIndex].focus();
|
|
99
|
+
onChange(nextIndex);
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
};
|
|
104
|
+
return (React.createElement("button", { ref: ref, role: "tab", "aria-selected": isSelected, tabIndex: isSelected ? 0 : -1, onClick: handleClick, onKeyDown: handleKeyDown, className: tabStyle({
|
|
105
|
+
variant,
|
|
106
|
+
size,
|
|
107
|
+
state: isSelected ? 'active' : 'inactive',
|
|
108
|
+
class: className,
|
|
109
|
+
}), ...props }, children));
|
|
110
|
+
});
|
|
111
|
+
Tab.displayName = 'Tab';
|
|
112
|
+
export const TabPanel = forwardRef(({ className, index = 0, children, ...props }, ref) => {
|
|
113
|
+
const { selectedIndex } = useContext(TabsContext);
|
|
114
|
+
const isSelected = selectedIndex === index;
|
|
115
|
+
if (!isSelected)
|
|
116
|
+
return null;
|
|
117
|
+
return (React.createElement("div", { ref: ref, role: "tabpanel", tabIndex: 0, className: tabPanelStyle({ class: className }), ...props }, children));
|
|
118
|
+
});
|
|
119
|
+
TabPanel.displayName = 'TabPanel';
|
|
120
|
+
//# sourceMappingURL=index.web.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.web.js","sourceRoot":"","sources":["../../../../src/components/ui/tabs/index.web.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,162 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import type { VariantProps } from '@gluestack-ui/nativewind-utils';
|
|
3
|
+
declare const StyledTextarea: React.ForwardRefExoticComponent<Omit<any, "ref"> & React.RefAttributes<HTMLTextAreaElement>>;
|
|
4
|
+
declare const textareaStyle: import("@gluestack-ui/nativewind-utils/types").TVReturnType<{
|
|
5
|
+
size: {
|
|
6
|
+
sm: string;
|
|
7
|
+
md: string;
|
|
8
|
+
lg: string;
|
|
9
|
+
};
|
|
10
|
+
variant: {
|
|
11
|
+
outline: string;
|
|
12
|
+
filled: string;
|
|
13
|
+
unstyled: string;
|
|
14
|
+
};
|
|
15
|
+
state: {
|
|
16
|
+
error: string;
|
|
17
|
+
success: string;
|
|
18
|
+
};
|
|
19
|
+
} | ({
|
|
20
|
+
size: {
|
|
21
|
+
sm: string;
|
|
22
|
+
md: string;
|
|
23
|
+
lg: string;
|
|
24
|
+
};
|
|
25
|
+
variant: {
|
|
26
|
+
outline: string;
|
|
27
|
+
filled: string;
|
|
28
|
+
unstyled: string;
|
|
29
|
+
};
|
|
30
|
+
state: {
|
|
31
|
+
error: string;
|
|
32
|
+
success: string;
|
|
33
|
+
};
|
|
34
|
+
} & {
|
|
35
|
+
size: {
|
|
36
|
+
sm: import("tailwind-merge").ClassNameValue | {
|
|
37
|
+
base?: import("tailwind-merge").ClassNameValue;
|
|
38
|
+
};
|
|
39
|
+
md: import("tailwind-merge").ClassNameValue | {
|
|
40
|
+
base?: import("tailwind-merge").ClassNameValue;
|
|
41
|
+
};
|
|
42
|
+
lg: import("tailwind-merge").ClassNameValue | {
|
|
43
|
+
base?: import("tailwind-merge").ClassNameValue;
|
|
44
|
+
};
|
|
45
|
+
};
|
|
46
|
+
variant: {
|
|
47
|
+
outline: import("tailwind-merge").ClassNameValue | {
|
|
48
|
+
base?: import("tailwind-merge").ClassNameValue;
|
|
49
|
+
};
|
|
50
|
+
filled: import("tailwind-merge").ClassNameValue | {
|
|
51
|
+
base?: import("tailwind-merge").ClassNameValue;
|
|
52
|
+
};
|
|
53
|
+
unstyled: import("tailwind-merge").ClassNameValue | {
|
|
54
|
+
base?: import("tailwind-merge").ClassNameValue;
|
|
55
|
+
};
|
|
56
|
+
};
|
|
57
|
+
state: {
|
|
58
|
+
error: import("tailwind-merge").ClassNameValue | {
|
|
59
|
+
base?: import("tailwind-merge").ClassNameValue;
|
|
60
|
+
};
|
|
61
|
+
success: import("tailwind-merge").ClassNameValue | {
|
|
62
|
+
base?: import("tailwind-merge").ClassNameValue;
|
|
63
|
+
};
|
|
64
|
+
};
|
|
65
|
+
}), undefined, "px-4 py-2 border border-gray-300 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500 focus:border-transparent", import("tailwind-variants/dist/config").TVConfig<{
|
|
66
|
+
size: {
|
|
67
|
+
sm: string;
|
|
68
|
+
md: string;
|
|
69
|
+
lg: string;
|
|
70
|
+
};
|
|
71
|
+
variant: {
|
|
72
|
+
outline: string;
|
|
73
|
+
filled: string;
|
|
74
|
+
unstyled: string;
|
|
75
|
+
};
|
|
76
|
+
state: {
|
|
77
|
+
error: string;
|
|
78
|
+
success: string;
|
|
79
|
+
};
|
|
80
|
+
}, {
|
|
81
|
+
size: {
|
|
82
|
+
sm: string;
|
|
83
|
+
md: string;
|
|
84
|
+
lg: string;
|
|
85
|
+
};
|
|
86
|
+
variant: {
|
|
87
|
+
outline: string;
|
|
88
|
+
filled: string;
|
|
89
|
+
unstyled: string;
|
|
90
|
+
};
|
|
91
|
+
state: {
|
|
92
|
+
error: string;
|
|
93
|
+
success: string;
|
|
94
|
+
};
|
|
95
|
+
}>, {
|
|
96
|
+
size: {
|
|
97
|
+
sm: string;
|
|
98
|
+
md: string;
|
|
99
|
+
lg: string;
|
|
100
|
+
};
|
|
101
|
+
variant: {
|
|
102
|
+
outline: string;
|
|
103
|
+
filled: string;
|
|
104
|
+
unstyled: string;
|
|
105
|
+
};
|
|
106
|
+
state: {
|
|
107
|
+
error: string;
|
|
108
|
+
success: string;
|
|
109
|
+
};
|
|
110
|
+
}, undefined, import("@gluestack-ui/nativewind-utils/types").TVReturnType<{
|
|
111
|
+
size: {
|
|
112
|
+
sm: string;
|
|
113
|
+
md: string;
|
|
114
|
+
lg: string;
|
|
115
|
+
};
|
|
116
|
+
variant: {
|
|
117
|
+
outline: string;
|
|
118
|
+
filled: string;
|
|
119
|
+
unstyled: string;
|
|
120
|
+
};
|
|
121
|
+
state: {
|
|
122
|
+
error: string;
|
|
123
|
+
success: string;
|
|
124
|
+
};
|
|
125
|
+
}, undefined, "px-4 py-2 border border-gray-300 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500 focus:border-transparent", import("tailwind-variants/dist/config").TVConfig<{
|
|
126
|
+
size: {
|
|
127
|
+
sm: string;
|
|
128
|
+
md: string;
|
|
129
|
+
lg: string;
|
|
130
|
+
};
|
|
131
|
+
variant: {
|
|
132
|
+
outline: string;
|
|
133
|
+
filled: string;
|
|
134
|
+
unstyled: string;
|
|
135
|
+
};
|
|
136
|
+
state: {
|
|
137
|
+
error: string;
|
|
138
|
+
success: string;
|
|
139
|
+
};
|
|
140
|
+
}, {
|
|
141
|
+
size: {
|
|
142
|
+
sm: string;
|
|
143
|
+
md: string;
|
|
144
|
+
lg: string;
|
|
145
|
+
};
|
|
146
|
+
variant: {
|
|
147
|
+
outline: string;
|
|
148
|
+
filled: string;
|
|
149
|
+
unstyled: string;
|
|
150
|
+
};
|
|
151
|
+
state: {
|
|
152
|
+
error: string;
|
|
153
|
+
success: string;
|
|
154
|
+
};
|
|
155
|
+
}>, unknown, unknown, undefined>>;
|
|
156
|
+
type ITextareaProps = React.ComponentProps<typeof StyledTextarea> & VariantProps<typeof textareaStyle> & {
|
|
157
|
+
className?: string;
|
|
158
|
+
onChangeText?: (text: string) => void;
|
|
159
|
+
placeholderTextColor?: string;
|
|
160
|
+
};
|
|
161
|
+
declare const Textarea: React.ForwardRefExoticComponent<Omit<ITextareaProps, "ref"> & React.RefAttributes<HTMLTextAreaElement>>;
|
|
162
|
+
export { Textarea };
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import React, { forwardRef } from 'react';
|
|
3
|
+
import { tva } from '@gluestack-ui/nativewind-utils/tva';
|
|
4
|
+
const SCOPE = 'TEXTAREA';
|
|
5
|
+
const StyledTextarea = forwardRef(({ onChangeText, onChange, placeholder, placeholderTextColor, ...props }, ref) => {
|
|
6
|
+
const handleChange = (e) => {
|
|
7
|
+
if (onChange) {
|
|
8
|
+
onChange(e);
|
|
9
|
+
}
|
|
10
|
+
if (onChangeText) {
|
|
11
|
+
onChangeText(e.target.value);
|
|
12
|
+
}
|
|
13
|
+
};
|
|
14
|
+
return (React.createElement("textarea", { ref: ref, placeholder: placeholder, onChange: handleChange, style: {
|
|
15
|
+
...props.style,
|
|
16
|
+
'::placeholder': {
|
|
17
|
+
color: placeholderTextColor,
|
|
18
|
+
},
|
|
19
|
+
}, ...props }));
|
|
20
|
+
});
|
|
21
|
+
StyledTextarea.displayName = 'StyledTextarea';
|
|
22
|
+
const textareaStyle = tva({
|
|
23
|
+
base: 'px-4 py-2 border border-gray-300 rounded-md focus:outline-none focus:ring-2 focus:ring-blue-500 focus:border-transparent',
|
|
24
|
+
variants: {
|
|
25
|
+
size: {
|
|
26
|
+
sm: 'text-sm min-h-[80px]',
|
|
27
|
+
md: 'text-base min-h-[100px]',
|
|
28
|
+
lg: 'text-lg min-h-[120px]',
|
|
29
|
+
},
|
|
30
|
+
variant: {
|
|
31
|
+
outline: 'bg-transparent',
|
|
32
|
+
filled: 'bg-gray-100',
|
|
33
|
+
unstyled: '',
|
|
34
|
+
},
|
|
35
|
+
state: {
|
|
36
|
+
error: 'border-red-500 focus:ring-red-500',
|
|
37
|
+
success: 'border-green-500 focus:ring-green-500',
|
|
38
|
+
},
|
|
39
|
+
},
|
|
40
|
+
defaultVariants: {
|
|
41
|
+
size: 'md',
|
|
42
|
+
variant: 'outline',
|
|
43
|
+
},
|
|
44
|
+
});
|
|
45
|
+
const Textarea = React.forwardRef(({ className, size, variant, state, ...props }, ref) => {
|
|
46
|
+
return (React.createElement(StyledTextarea, { ref: ref, className: textareaStyle({ size, variant, state, class: className }), ...props }));
|
|
47
|
+
});
|
|
48
|
+
Textarea.displayName = 'Textarea';
|
|
49
|
+
export { Textarea };
|
|
50
|
+
//# sourceMappingURL=index.web.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.web.js","sourceRoot":"","sources":["../../../../src/components/ui/textarea/index.web.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;AACb,OAAO,KAAK,EAAE,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAE1C,OAAO,EAAE,GAAG,EAAE,MAAM,oCAAoC,CAAC;AAKzD,MAAM,KAAK,GAAG,UAAU,CAAC;AAEzB,MAAM,cAAc,GAAG,UAAU,CAC7B,CAAC,EAAE,YAAY,EAAE,QAAQ,EAAE,WAAW,EAAE,oBAAoB,EAAE,GAAG,KAAK,EAAE,EAAE,GAAG,EAAE,EAAE;IAC7E,MAAM,YAAY,GAAG,CAAC,CAAyC,EAAE,EAAE;QAC/D,IAAI,QAAQ,EAAE,CAAC;YACX,QAAQ,CAAC,CAAC,CAAC,CAAC;QAChB,CAAC;QACD,IAAI,YAAY,EAAE,CAAC;YACf,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QACjC,CAAC;IACL,CAAC,CAAC;IAEF,OAAO,CACH,kCACI,GAAG,EAAE,GAAG,EACR,WAAW,EAAE,WAAW,EACxB,QAAQ,EAAE,YAAY,EACtB,KAAK,EAAE;YACH,GAAG,KAAK,CAAC,KAAK;YACd,eAAe,EAAE;gBACb,KAAK,EAAE,oBAAoB;aAC9B;SACJ,KACG,KAAK,GACX,CACL,CAAC;AACN,CAAC,CACJ,CAAC;AAEF,cAAc,CAAC,WAAW,GAAG,gBAAgB,CAAC;AAE9C,MAAM,aAAa,GAAG,GAAG,CAAC;IACtB,IAAI,EAAE,0HAA0H;IAChI,QAAQ,EAAE;QACN,IAAI,EAAE;YACF,EAAE,EAAE,sBAAsB;YAC1B,EAAE,EAAE,yBAAyB;YAC7B,EAAE,EAAE,uBAAuB;SAC9B;QACD,OAAO,EAAE;YACL,OAAO,EAAE,gBAAgB;YACzB,MAAM,EAAE,aAAa;YACrB,QAAQ,EAAE,EAAE;SACf;QACD,KAAK,EAAE;YACH,KAAK,EAAE,mCAAmC;YAC1C,OAAO,EAAE,uCAAuC;SACnD;KACJ;IACD,eAAe,EAAE;QACb,IAAI,EAAE,IAAI;QACV,OAAO,EAAE,SAAS;KACrB;CACJ,CAAC,CAAC;AASH,MAAM,QAAQ,GAAG,KAAK,CAAC,UAAU,CAC7B,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,GAAG,KAAK,EAAE,EAAE,GAAG,EAAE,EAAE;IACnD,OAAO,CACH,oBAAC,cAAc,IACX,GAAG,EAAE,GAAG,EACR,SAAS,EAAE,aAAa,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC,KAChE,KAAK,GACX,CACL,CAAC;AACN,CAAC,CACJ,CAAC;AAEF,QAAQ,CAAC,WAAW,GAAG,UAAU,CAAC;AAElC,OAAO,EAAE,QAAQ,EAAE,CAAC"}
|