@admin-layout/gluestack-ui-mobile 11.0.4-alpha.0 → 12.0.16-alpha.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.
Files changed (204) hide show
  1. package/CHANGELOG.md +60 -4
  2. package/lib/__tests__/prolayout-layout-feature.test.js +1 -1
  3. package/lib/__tests__/prolayout-layout-feature.test.js.map +1 -1
  4. package/lib/components/AuthWrapper.js +5 -3
  5. package/lib/components/AuthWrapper.js.map +1 -1
  6. package/lib/components/ErrorBounday.js.map +1 -1
  7. package/lib/components/NavigationComponent.js.map +1 -1
  8. package/lib/components/UnAuthenticatedComponent.js.map +1 -1
  9. package/lib/components/WithConfiguration.js +4 -4
  10. package/lib/components/WithConfiguration.js.map +1 -1
  11. package/lib/components/WithPermission.js +1 -1
  12. package/lib/components/WithPermission.js.map +1 -1
  13. package/lib/components/WithPolicy.js +2 -2
  14. package/lib/components/WithPolicy.js.map +1 -1
  15. package/lib/components/ui/accordion/index.web.d.ts +209 -0
  16. package/lib/components/ui/accordion/index.web.js +156 -0
  17. package/lib/components/ui/accordion/index.web.js.map +1 -0
  18. package/lib/components/ui/actionsheet/index.web.d.ts +872 -0
  19. package/lib/components/ui/actionsheet/index.web.js +286 -0
  20. package/lib/components/ui/actionsheet/index.web.js.map +1 -0
  21. package/lib/components/ui/alert/index.web.d.ts +135 -0
  22. package/lib/components/ui/alert/index.web.js +38 -0
  23. package/lib/components/ui/alert/index.web.js.map +1 -0
  24. package/lib/components/ui/alert-dialog/index.web.d.ts +64 -0
  25. package/lib/components/ui/alert-dialog/index.web.js +139 -0
  26. package/lib/components/ui/alert-dialog/index.web.js.map +1 -0
  27. package/lib/components/ui/avatar/index.web.d.ts +21 -0
  28. package/lib/components/ui/avatar/index.web.js +92 -0
  29. package/lib/components/ui/avatar/index.web.js.map +1 -0
  30. package/lib/components/ui/badge/index.web.d.ts +382 -0
  31. package/lib/components/ui/badge/index.web.js +138 -0
  32. package/lib/components/ui/badge/index.web.js.map +1 -0
  33. package/lib/components/ui/button/index.web.d.ts +247 -0
  34. package/lib/components/ui/button/index.web.js +57 -0
  35. package/lib/components/ui/button/index.web.js.map +1 -0
  36. package/lib/components/ui/checkbox/index.web.d.ts +265 -0
  37. package/lib/components/ui/checkbox/index.web.js +77 -0
  38. package/lib/components/ui/checkbox/index.web.js.map +1 -0
  39. package/lib/components/ui/divider/index.web.d.ts +53 -0
  40. package/lib/components/ui/divider/index.web.js +21 -0
  41. package/lib/components/ui/divider/index.web.js.map +1 -0
  42. package/lib/components/ui/drawer/index.web.d.ts +174 -0
  43. package/lib/components/ui/drawer/index.web.js +65 -0
  44. package/lib/components/ui/drawer/index.web.js.map +1 -0
  45. package/lib/components/ui/fab/index.web.d.ts +520 -0
  46. package/lib/components/ui/fab/index.web.js +146 -0
  47. package/lib/components/ui/fab/index.web.js.map +1 -0
  48. package/lib/components/ui/flat-list/index.web.d.ts +21 -0
  49. package/lib/components/ui/flat-list/index.web.js +41 -0
  50. package/lib/components/ui/flat-list/index.web.js.map +1 -0
  51. package/lib/components/ui/form-control/index.web.d.ts +2071 -0
  52. package/lib/components/ui/form-control/index.web.js +290 -0
  53. package/lib/components/ui/form-control/index.web.js.map +1 -0
  54. package/lib/components/ui/image/index.web.d.ts +142 -0
  55. package/lib/components/ui/image/index.web.js +29 -0
  56. package/lib/components/ui/image/index.web.js.map +1 -0
  57. package/lib/components/ui/image-background/index.web.d.ts +8 -0
  58. package/lib/components/ui/image-background/index.web.js +23 -0
  59. package/lib/components/ui/image-background/index.web.js.map +1 -0
  60. package/lib/components/ui/input/index.web.d.ts +163 -0
  61. package/lib/components/ui/input/index.web.js +50 -0
  62. package/lib/components/ui/input/index.web.js.map +1 -0
  63. package/lib/components/ui/input-accessory-view/index.web.d.ts +9 -0
  64. package/lib/components/ui/input-accessory-view/index.web.js +16 -0
  65. package/lib/components/ui/input-accessory-view/index.web.js.map +1 -0
  66. package/lib/components/ui/keyboard-avoiding-view/index.web.d.ts +9 -0
  67. package/lib/components/ui/keyboard-avoiding-view/index.web.js +8 -0
  68. package/lib/components/ui/keyboard-avoiding-view/index.web.js.map +1 -0
  69. package/lib/components/ui/link/index.web.d.ts +365 -0
  70. package/lib/components/ui/link/index.web.js +70 -0
  71. package/lib/components/ui/link/index.web.js.map +1 -0
  72. package/lib/components/ui/menu/index.web.d.ts +142 -0
  73. package/lib/components/ui/menu/index.web.js +83 -0
  74. package/lib/components/ui/menu/index.web.js.map +1 -0
  75. package/lib/components/ui/modal/index.web.d.ts +111 -0
  76. package/lib/components/ui/modal/index.web.js +58 -0
  77. package/lib/components/ui/modal/index.web.js.map +1 -0
  78. package/lib/components/ui/popover/index.web.d.ts +309 -0
  79. package/lib/components/ui/popover/index.web.js +184 -0
  80. package/lib/components/ui/popover/index.web.js.map +1 -0
  81. package/lib/components/ui/portal/index.web.d.ts +9 -0
  82. package/lib/components/ui/portal/index.web.js +16 -0
  83. package/lib/components/ui/portal/index.web.js.map +1 -0
  84. package/lib/components/ui/pressable/index.web.d.ts +8 -0
  85. package/lib/components/ui/pressable/index.web.js +44 -0
  86. package/lib/components/ui/pressable/index.web.js.map +1 -0
  87. package/lib/components/ui/progress/index.web.d.ts +237 -0
  88. package/lib/components/ui/progress/index.web.js +73 -0
  89. package/lib/components/ui/progress/index.web.js.map +1 -0
  90. package/lib/components/ui/radio/index.web.d.ts +224 -0
  91. package/lib/components/ui/radio/index.web.js +69 -0
  92. package/lib/components/ui/radio/index.web.js.map +1 -0
  93. package/lib/components/ui/refresh-control/index.web.d.ts +14 -0
  94. package/lib/components/ui/refresh-control/index.web.js +69 -0
  95. package/lib/components/ui/refresh-control/index.web.js.map +1 -0
  96. package/lib/components/ui/safe-area-view/index.web.d.ts +6 -0
  97. package/lib/components/ui/safe-area-view/index.web.js +10 -0
  98. package/lib/components/ui/safe-area-view/index.web.js.map +1 -0
  99. package/lib/components/ui/scroll-view/index.web.d.ts +44 -0
  100. package/lib/components/ui/scroll-view/index.web.js +41 -0
  101. package/lib/components/ui/scroll-view/index.web.js.map +1 -0
  102. package/lib/components/ui/section-list/index.web.d.ts +26 -0
  103. package/lib/components/ui/section-list/index.web.js +35 -0
  104. package/lib/components/ui/section-list/index.web.js.map +1 -0
  105. package/lib/components/ui/select/index.web.d.ts +162 -0
  106. package/lib/components/ui/select/index.web.js +51 -0
  107. package/lib/components/ui/select/index.web.js.map +1 -0
  108. package/lib/components/ui/slider/index.web.d.ts +223 -0
  109. package/lib/components/ui/slider/index.web.js +189 -0
  110. package/lib/components/ui/slider/index.web.js.map +1 -0
  111. package/lib/components/ui/spinner/index.web.d.ts +176 -0
  112. package/lib/components/ui/spinner/index.web.js +55 -0
  113. package/lib/components/ui/spinner/index.web.js.map +1 -0
  114. package/lib/components/ui/status-bar/index.web.d.ts +14 -0
  115. package/lib/components/ui/status-bar/index.web.js +7 -0
  116. package/lib/components/ui/status-bar/index.web.js.map +1 -0
  117. package/lib/components/ui/switch/index.web.d.ts +71 -0
  118. package/lib/components/ui/switch/index.web.js +27 -0
  119. package/lib/components/ui/switch/index.web.js.map +1 -0
  120. package/lib/components/ui/tabs/index.web.d.ts +351 -0
  121. package/lib/components/ui/tabs/index.web.js +120 -0
  122. package/lib/components/ui/tabs/index.web.js.map +1 -0
  123. package/lib/components/ui/textarea/index.web.d.ts +162 -0
  124. package/lib/components/ui/textarea/index.web.js +50 -0
  125. package/lib/components/ui/textarea/index.web.js.map +1 -0
  126. package/lib/components/ui/toast/index.web.d.ts +225 -0
  127. package/lib/components/ui/toast/index.web.js +80 -0
  128. package/lib/components/ui/toast/index.web.js.map +1 -0
  129. package/lib/components/ui/tooltip/index.web.d.ts +86 -0
  130. package/lib/components/ui/tooltip/index.web.js +110 -0
  131. package/lib/components/ui/tooltip/index.web.js.map +1 -0
  132. package/lib/components/ui/view/index.web.d.ts +2 -0
  133. package/lib/components/ui/view/index.web.js +7 -0
  134. package/lib/components/ui/view/index.web.js.map +1 -0
  135. package/lib/components/ui/virtualized-list/index.web.d.ts +19 -0
  136. package/lib/components/ui/virtualized-list/index.web.js +30 -0
  137. package/lib/components/ui/virtualized-list/index.web.js.map +1 -0
  138. package/lib/components/usePermissionAutoFetch.d.ts +7 -19
  139. package/lib/components/with-interactions-lifecycle-managed.js.map +1 -1
  140. package/lib/components/with-interactions-managed.js +2 -3
  141. package/lib/components/with-interactions-managed.js.map +1 -1
  142. package/lib/containers/layout/DrawerBottomNavigationConfig.d.ts +47 -47
  143. package/lib/containers/layout/DrawerConfig.d.ts +31 -31
  144. package/lib/containers/layout/module.js +1 -1
  145. package/lib/containers/layout/module.js.map +1 -1
  146. package/lib/interfaces/settings.d.ts +1 -0
  147. package/lib/redux/settings.d.ts +4 -9
  148. package/lib/utils/routeConfigKeyReplace.test.js +1 -1
  149. package/lib/utils/routeConfigKeyReplace.test.js.map +1 -1
  150. package/package.json +7 -4
  151. package/src/__tests__/prolayout-layout-feature.test.tsx +2 -2
  152. package/src/components/AuthWrapper.tsx +6 -3
  153. package/src/components/ErrorBounday.tsx +18 -19
  154. package/src/components/NavigationComponent.tsx +1 -1
  155. package/src/components/UnAuthenticatedComponent.tsx +1 -3
  156. package/src/components/WithConfiguration.tsx +5 -8
  157. package/src/components/WithPermission.tsx +1 -1
  158. package/src/components/WithPolicy.tsx +4 -3
  159. package/src/components/ui/accordion/index.web.tsx +294 -0
  160. package/src/components/ui/actionsheet/index.web.tsx +555 -0
  161. package/src/components/ui/alert/index.web.tsx +71 -0
  162. package/src/components/ui/alert-dialog/index.web.tsx +241 -0
  163. package/src/components/ui/avatar/index.web.tsx +150 -0
  164. package/src/components/ui/badge/index.web.tsx +188 -0
  165. package/src/components/ui/button/index.web.tsx +86 -0
  166. package/src/components/ui/checkbox/index.web.tsx +151 -0
  167. package/src/components/ui/divider/index.web.tsx +37 -0
  168. package/src/components/ui/drawer/index.web.tsx +144 -0
  169. package/src/components/ui/fab/index.web.tsx +201 -0
  170. package/src/components/ui/flat-list/index.web.tsx +89 -0
  171. package/src/components/ui/form-control/index.web.tsx +451 -0
  172. package/src/components/ui/image/index.web.tsx +43 -0
  173. package/src/components/ui/image-background/index.web.tsx +43 -0
  174. package/src/components/ui/input/index.web.tsx +80 -0
  175. package/src/components/ui/input-accessory-view/index.web.tsx +31 -0
  176. package/src/components/ui/keyboard-avoiding-view/index.web.tsx +23 -0
  177. package/src/components/ui/link/index.web.tsx +103 -0
  178. package/src/components/ui/menu/index.web.tsx +159 -0
  179. package/src/components/ui/modal/index.web.tsx +135 -0
  180. package/src/components/ui/popover/index.web.tsx +326 -0
  181. package/src/components/ui/portal/index.web.tsx +34 -0
  182. package/src/components/ui/pressable/index.web.tsx +73 -0
  183. package/src/components/ui/progress/index.web.tsx +123 -0
  184. package/src/components/ui/radio/index.web.tsx +130 -0
  185. package/src/components/ui/refresh-control/index.web.tsx +104 -0
  186. package/src/components/ui/safe-area-view/index.web.tsx +24 -0
  187. package/src/components/ui/scroll-view/index.web.tsx +142 -0
  188. package/src/components/ui/section-list/index.web.tsx +93 -0
  189. package/src/components/ui/select/index.web.tsx +83 -0
  190. package/src/components/ui/slider/index.web.tsx +283 -0
  191. package/src/components/ui/spinner/index.web.tsx +81 -0
  192. package/src/components/ui/status-bar/index.web.tsx +20 -0
  193. package/src/components/ui/switch/index.web.tsx +44 -0
  194. package/src/components/ui/tabs/index.web.tsx +205 -0
  195. package/src/components/ui/textarea/index.web.tsx +86 -0
  196. package/src/components/ui/toast/index.web.tsx +132 -0
  197. package/src/components/ui/tooltip/index.web.tsx +155 -0
  198. package/src/components/ui/view/index.web.tsx +15 -0
  199. package/src/components/ui/virtualized-list/index.web.tsx +84 -0
  200. package/src/components/with-interactions-lifecycle-managed.tsx +0 -4
  201. package/src/components/with-interactions-managed.tsx +3 -4
  202. package/src/containers/layout/module.ts +1 -1
  203. package/src/interfaces/settings.ts +1 -0
  204. package/src/utils/routeConfigKeyReplace.test.ts +4 -4
@@ -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"}