@colimuca123/nativewind 4.2.2-rc.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 (146) hide show
  1. package/LICENSE +21 -0
  2. package/README.OpenSource +11 -0
  3. package/babel.js +1 -0
  4. package/dist/doctor.d.ts +1 -0
  5. package/dist/doctor.js +21 -0
  6. package/dist/doctor.js.map +1 -0
  7. package/dist/index.d.ts +4 -0
  8. package/dist/index.js +20 -0
  9. package/dist/index.js.map +1 -0
  10. package/dist/metro/common.d.ts +4 -0
  11. package/dist/metro/common.js +8 -0
  12. package/dist/metro/common.js.map +1 -0
  13. package/dist/metro/index.d.ts +15 -0
  14. package/dist/metro/index.js +47 -0
  15. package/dist/metro/index.js.map +1 -0
  16. package/dist/metro/picocolors.d.ts +26 -0
  17. package/dist/metro/picocolors.js +53 -0
  18. package/dist/metro/picocolors.js.map +1 -0
  19. package/dist/metro/tailwind/index.d.ts +5 -0
  20. package/dist/metro/tailwind/index.js +25 -0
  21. package/dist/metro/tailwind/index.js.map +1 -0
  22. package/dist/metro/tailwind/types.d.ts +8 -0
  23. package/dist/metro/tailwind/types.js +3 -0
  24. package/dist/metro/tailwind/types.js.map +1 -0
  25. package/dist/metro/tailwind/v3/child.d.ts +0 -0
  26. package/dist/metro/tailwind/v3/child.js +45 -0
  27. package/dist/metro/tailwind/v3/child.js.map +1 -0
  28. package/dist/metro/tailwind/v3/index.d.ts +6 -0
  29. package/dist/metro/tailwind/v3/index.js +81 -0
  30. package/dist/metro/tailwind/v3/index.js.map +1 -0
  31. package/dist/metro/typescript.d.ts +1 -0
  32. package/dist/metro/typescript.js +46 -0
  33. package/dist/metro/typescript.js.map +1 -0
  34. package/dist/stylesheet.d.ts +5 -0
  35. package/dist/stylesheet.js +25 -0
  36. package/dist/stylesheet.js.map +1 -0
  37. package/dist/tailwind/color.d.ts +4 -0
  38. package/dist/tailwind/color.js +25 -0
  39. package/dist/tailwind/color.js.map +1 -0
  40. package/dist/tailwind/common.d.ts +2 -0
  41. package/dist/tailwind/common.js +24 -0
  42. package/dist/tailwind/common.js.map +1 -0
  43. package/dist/tailwind/dark-mode.d.ts +4 -0
  44. package/dist/tailwind/dark-mode.js +48 -0
  45. package/dist/tailwind/dark-mode.js.map +1 -0
  46. package/dist/tailwind/index.d.ts +0 -0
  47. package/dist/tailwind/index.js +13 -0
  48. package/dist/tailwind/index.js.map +1 -0
  49. package/dist/tailwind/native.d.ts +3 -0
  50. package/dist/tailwind/native.js +265 -0
  51. package/dist/tailwind/native.js.map +1 -0
  52. package/dist/tailwind/prop-modifier.d.ts +4 -0
  53. package/dist/tailwind/prop-modifier.js +13 -0
  54. package/dist/tailwind/prop-modifier.js.map +1 -0
  55. package/dist/tailwind/safe-area.d.ts +4 -0
  56. package/dist/tailwind/safe-area.js +216 -0
  57. package/dist/tailwind/safe-area.js.map +1 -0
  58. package/dist/tailwind/shadows.d.ts +4 -0
  59. package/dist/tailwind/shadows.js +79 -0
  60. package/dist/tailwind/shadows.js.map +1 -0
  61. package/dist/tailwind/switch.d.ts +8 -0
  62. package/dist/tailwind/switch.js +51 -0
  63. package/dist/tailwind/switch.js.map +1 -0
  64. package/dist/tailwind/translate.d.ts +2 -0
  65. package/dist/tailwind/translate.js +40 -0
  66. package/dist/tailwind/translate.js.map +1 -0
  67. package/dist/tailwind/verify.d.ts +4 -0
  68. package/dist/tailwind/verify.js +22 -0
  69. package/dist/tailwind/verify.js.map +1 -0
  70. package/dist/tailwind/web.d.ts +3 -0
  71. package/dist/tailwind/web.js +40 -0
  72. package/dist/tailwind/web.js.map +1 -0
  73. package/dist/test.d.ts +373 -0
  74. package/dist/test.js +161 -0
  75. package/dist/test.js.map +1 -0
  76. package/dist/theme.d.ts +1 -0
  77. package/dist/theme.js +9 -0
  78. package/dist/theme.js.map +1 -0
  79. package/expo-snack.js +71 -0
  80. package/jsx-dev-runtime/index.d.ts +1 -0
  81. package/jsx-dev-runtime/index.js +1 -0
  82. package/jsx-runtime/index.d.ts +1 -0
  83. package/jsx-runtime/index.js +1 -0
  84. package/metro/package.json +1 -0
  85. package/package.json +75 -0
  86. package/preset/package.json +3 -0
  87. package/src/__tests__/README.md +3 -0
  88. package/src/__tests__/accessibility.tsx +41 -0
  89. package/src/__tests__/backgrounds.tsx +239 -0
  90. package/src/__tests__/borders.tsx +355 -0
  91. package/src/__tests__/container-queries.tsx +59 -0
  92. package/src/__tests__/custom-theme.tsx +45 -0
  93. package/src/__tests__/custom.tsx +17 -0
  94. package/src/__tests__/dark-mode.ios.tsx +251 -0
  95. package/src/__tests__/doctor.tsx +13 -0
  96. package/src/__tests__/effects.ios.tsx +230 -0
  97. package/src/__tests__/elevation.tsx +22 -0
  98. package/src/__tests__/filters.tsx +201 -0
  99. package/src/__tests__/flexbox-grid.tsx +670 -0
  100. package/src/__tests__/groups.tsx +134 -0
  101. package/src/__tests__/interactivity.tsx +547 -0
  102. package/src/__tests__/layout.tsx +854 -0
  103. package/src/__tests__/modifier-{}.tsx +71 -0
  104. package/src/__tests__/platform-modifiers-test.ios.tsx +34 -0
  105. package/src/__tests__/preset.tsx +9 -0
  106. package/src/__tests__/reusing-styles.tsx +44 -0
  107. package/src/__tests__/safe-area.test.ios.tsx +427 -0
  108. package/src/__tests__/sizing.tsx +241 -0
  109. package/src/__tests__/spacing.tsx +106 -0
  110. package/src/__tests__/states.tsx +145 -0
  111. package/src/__tests__/svg.tsx +25 -0
  112. package/src/__tests__/tables.tsx +103 -0
  113. package/src/__tests__/theme.tsx +245 -0
  114. package/src/__tests__/transforms.tsx +509 -0
  115. package/src/__tests__/transition-animations.tsx +254 -0
  116. package/src/__tests__/typography.tsx +657 -0
  117. package/src/__tests__/unofficial-plugins.test.ios.tsx +171 -0
  118. package/src/doctor.ts +28 -0
  119. package/src/index.tsx +16 -0
  120. package/src/metro/common.ts +11 -0
  121. package/src/metro/index.ts +77 -0
  122. package/src/metro/picocolors.ts +76 -0
  123. package/src/metro/tailwind/index.ts +22 -0
  124. package/src/metro/tailwind/types.ts +9 -0
  125. package/src/metro/tailwind/v3/child.ts +61 -0
  126. package/src/metro/tailwind/v3/index.ts +103 -0
  127. package/src/metro/typescript.ts +69 -0
  128. package/src/stylesheet.ts +31 -0
  129. package/src/tailwind/color.ts +23 -0
  130. package/src/tailwind/common.ts +26 -0
  131. package/src/tailwind/dark-mode.ts +46 -0
  132. package/src/tailwind/index.ts +15 -0
  133. package/src/tailwind/native.ts +374 -0
  134. package/src/tailwind/prop-modifier.ts +7 -0
  135. package/src/tailwind/safe-area.ts +262 -0
  136. package/src/tailwind/shadows.ts +100 -0
  137. package/src/tailwind/switch.ts +59 -0
  138. package/src/tailwind/translate.ts +51 -0
  139. package/src/tailwind/verify.ts +16 -0
  140. package/src/tailwind/web.ts +38 -0
  141. package/src/tailwindcss-internals.d.ts +7 -0
  142. package/src/test.tsx +224 -0
  143. package/src/theme.ts +15 -0
  144. package/test/package.json +4 -0
  145. package/theme/package.json +3 -0
  146. package/types.d.ts +1 -0
@@ -0,0 +1,509 @@
1
+ import { renderCurrentTest } from "../test";
2
+
3
+ describe("Transforms - Scale", () => {
4
+ test("scale-0", async () => {
5
+ expect(await renderCurrentTest()).toStrictEqual({
6
+ props: {
7
+ style: {
8
+ transform: [
9
+ { translateX: 0 },
10
+ { translateY: 0 },
11
+ { rotate: "0deg" },
12
+ { skewX: "0deg" },
13
+ { skewY: "0deg" },
14
+ { scaleX: 0 },
15
+ { scaleY: 0 },
16
+ ],
17
+ },
18
+ },
19
+ });
20
+ });
21
+ test("scale-x-0", async () => {
22
+ expect(await renderCurrentTest()).toStrictEqual({
23
+ props: {
24
+ style: {
25
+ transform: [
26
+ { translateX: 0 },
27
+ { translateY: 0 },
28
+ { rotate: "0deg" },
29
+ { skewX: "0deg" },
30
+ { skewY: "0deg" },
31
+ { scaleX: 0 },
32
+ { scaleY: 1 },
33
+ ],
34
+ },
35
+ },
36
+ });
37
+ });
38
+ test("scale-y-0", async () => {
39
+ expect(await renderCurrentTest()).toStrictEqual({
40
+ props: {
41
+ style: {
42
+ transform: [
43
+ { translateX: 0 },
44
+ { translateY: 0 },
45
+ { rotate: "0deg" },
46
+ { skewX: "0deg" },
47
+ { skewY: "0deg" },
48
+ { scaleX: 1 },
49
+ { scaleY: 0 },
50
+ ],
51
+ },
52
+ },
53
+ });
54
+ });
55
+ test("scale-50", async () => {
56
+ expect(await renderCurrentTest()).toStrictEqual({
57
+ props: {
58
+ style: {
59
+ transform: [
60
+ { translateX: 0 },
61
+ { translateY: 0 },
62
+ { rotate: "0deg" },
63
+ { skewX: "0deg" },
64
+ { skewY: "0deg" },
65
+ { scaleX: 0.5 },
66
+ { scaleY: 0.5 },
67
+ ],
68
+ },
69
+ },
70
+ });
71
+ });
72
+ test("scale-x-50", async () => {
73
+ expect(await renderCurrentTest()).toStrictEqual({
74
+ props: {
75
+ style: {
76
+ transform: [
77
+ { translateX: 0 },
78
+ { translateY: 0 },
79
+ { rotate: "0deg" },
80
+ { skewX: "0deg" },
81
+ { skewY: "0deg" },
82
+ { scaleX: 0.5 },
83
+ { scaleY: 1 },
84
+ ],
85
+ },
86
+ },
87
+ });
88
+ });
89
+
90
+ test("scale-y-50", async () => {
91
+ expect(await renderCurrentTest()).toStrictEqual({
92
+ props: {
93
+ style: {
94
+ transform: [
95
+ { translateX: 0 },
96
+ { translateY: 0 },
97
+ { rotate: "0deg" },
98
+ { skewX: "0deg" },
99
+ { skewY: "0deg" },
100
+ { scaleX: 1 },
101
+ { scaleY: 0.5 },
102
+ ],
103
+ },
104
+ },
105
+ });
106
+ });
107
+ });
108
+
109
+ describe("Transforms - Rotate", () => {
110
+ test("rotate-0", async () => {
111
+ expect(await renderCurrentTest()).toStrictEqual({
112
+ props: {
113
+ style: {
114
+ transform: [
115
+ { translateX: 0 },
116
+ { translateY: 0 },
117
+ { rotate: "0deg" },
118
+ { skewX: "0deg" },
119
+ { skewY: "0deg" },
120
+ { scaleX: 1 },
121
+ { scaleY: 1 },
122
+ ],
123
+ },
124
+ },
125
+ });
126
+ });
127
+ test("rotate-180", async () => {
128
+ expect(await renderCurrentTest()).toStrictEqual({
129
+ props: {
130
+ style: {
131
+ transform: [
132
+ { translateX: 0 },
133
+ { translateY: 0 },
134
+ { rotate: "180deg" },
135
+ { skewX: "0deg" },
136
+ { skewY: "0deg" },
137
+ { scaleX: 1 },
138
+ { scaleY: 1 },
139
+ ],
140
+ },
141
+ },
142
+ });
143
+ });
144
+ test("rotate-[30deg]", async () => {
145
+ expect(await renderCurrentTest()).toStrictEqual({
146
+ props: {
147
+ style: {
148
+ transform: [
149
+ { translateX: 0 },
150
+ { translateY: 0 },
151
+ { rotate: "30deg" },
152
+ { skewX: "0deg" },
153
+ { skewY: "0deg" },
154
+ { scaleX: 1 },
155
+ { scaleY: 1 },
156
+ ],
157
+ },
158
+ },
159
+ });
160
+ });
161
+ });
162
+
163
+ describe("Transforms - Translate", () => {
164
+ test("translate-x-0", async () => {
165
+ expect(await renderCurrentTest()).toStrictEqual({
166
+ props: {
167
+ style: {
168
+ transform: [
169
+ { translateX: 0 },
170
+ { translateY: 0 },
171
+ { rotate: "0deg" },
172
+ { skewX: "0deg" },
173
+ { skewY: "0deg" },
174
+ { scaleX: 1 },
175
+ { scaleY: 1 },
176
+ ],
177
+ },
178
+ },
179
+ });
180
+ });
181
+ test("translate-y-0", async () => {
182
+ expect(await renderCurrentTest()).toStrictEqual({
183
+ props: {
184
+ style: {
185
+ transform: [
186
+ { translateX: 0 },
187
+ { translateY: 0 },
188
+ { rotate: "0deg" },
189
+ { skewX: "0deg" },
190
+ { skewY: "0deg" },
191
+ { scaleX: 1 },
192
+ { scaleY: 1 },
193
+ ],
194
+ },
195
+ },
196
+ });
197
+ });
198
+ test("translate-x-px", async () => {
199
+ expect(await renderCurrentTest()).toStrictEqual({
200
+ props: {
201
+ style: {
202
+ transform: [
203
+ { translateX: 1 },
204
+ { translateY: 0 },
205
+ { rotate: "0deg" },
206
+ { skewX: "0deg" },
207
+ { skewY: "0deg" },
208
+ { scaleX: 1 },
209
+ { scaleY: 1 },
210
+ ],
211
+ },
212
+ },
213
+ });
214
+ });
215
+ test("translate-y-px", async () => {
216
+ expect(await renderCurrentTest()).toStrictEqual({
217
+ props: {
218
+ style: {
219
+ transform: [
220
+ { translateX: 0 },
221
+ { translateY: 1 },
222
+ { rotate: "0deg" },
223
+ { skewX: "0deg" },
224
+ { skewY: "0deg" },
225
+ { scaleX: 1 },
226
+ { scaleY: 1 },
227
+ ],
228
+ },
229
+ },
230
+ });
231
+ });
232
+ test("translate-x-1", async () => {
233
+ expect(await renderCurrentTest()).toStrictEqual({
234
+ props: {
235
+ style: {
236
+ transform: [
237
+ { translateX: 3.5 },
238
+ { translateY: 0 },
239
+ { rotate: "0deg" },
240
+ { skewX: "0deg" },
241
+ { skewY: "0deg" },
242
+ { scaleX: 1 },
243
+ { scaleY: 1 },
244
+ ],
245
+ },
246
+ },
247
+ });
248
+ });
249
+ test("translate-y-1", async () => {
250
+ expect(await renderCurrentTest()).toStrictEqual({
251
+ props: {
252
+ style: {
253
+ transform: [
254
+ { translateX: 0 },
255
+ { translateY: 3.5 },
256
+ { rotate: "0deg" },
257
+ { skewX: "0deg" },
258
+ { skewY: "0deg" },
259
+ { scaleX: 1 },
260
+ { scaleY: 1 },
261
+ ],
262
+ },
263
+ },
264
+ });
265
+ });
266
+ });
267
+
268
+ describe("Transforms - Translate (%)", () => {
269
+ test("translate-x-1/2", async () => {
270
+ expect(
271
+ await renderCurrentTest({
272
+ className: "w-2 translate-x-1/2",
273
+ }),
274
+ ).toStrictEqual({
275
+ props: {
276
+ style: {
277
+ width: 7,
278
+ transform: [
279
+ { translateX: 3.5 },
280
+ { translateY: 0 },
281
+ { rotate: "0deg" },
282
+ { skewX: "0deg" },
283
+ { skewY: "0deg" },
284
+ { scaleX: 1 },
285
+ { scaleY: 1 },
286
+ ],
287
+ },
288
+ },
289
+ });
290
+ });
291
+ test("translate-y-1/2", async () => {
292
+ expect(
293
+ await renderCurrentTest({
294
+ className: "h-2 translate-y-1/2",
295
+ }),
296
+ ).toStrictEqual({
297
+ props: {
298
+ style: {
299
+ height: 7,
300
+ transform: [
301
+ { translateX: 0 },
302
+ { translateY: 3.5 },
303
+ { rotate: "0deg" },
304
+ { skewX: "0deg" },
305
+ { skewY: "0deg" },
306
+ { scaleX: 1 },
307
+ { scaleY: 1 },
308
+ ],
309
+ },
310
+ },
311
+ });
312
+ });
313
+ test("translate-x-full", async () => {
314
+ expect(
315
+ await renderCurrentTest({
316
+ className: "w-2 translate-x-full",
317
+ }),
318
+ ).toStrictEqual({
319
+ props: {
320
+ style: {
321
+ width: 7,
322
+ transform: [
323
+ { translateX: 7 },
324
+ { translateY: 0 },
325
+ { rotate: "0deg" },
326
+ { skewX: "0deg" },
327
+ { skewY: "0deg" },
328
+ { scaleX: 1 },
329
+ { scaleY: 1 },
330
+ ],
331
+ },
332
+ },
333
+ });
334
+ });
335
+ test("translate-y-full", async () => {
336
+ expect(
337
+ await renderCurrentTest({
338
+ className: "h-2 translate-y-full",
339
+ }),
340
+ ).toStrictEqual({
341
+ props: {
342
+ style: {
343
+ height: 7,
344
+ transform: [
345
+ { translateX: 0 },
346
+ { translateY: 7 },
347
+ { rotate: "0deg" },
348
+ { skewX: "0deg" },
349
+ { skewY: "0deg" },
350
+ { scaleX: 1 },
351
+ { scaleY: 1 },
352
+ ],
353
+ },
354
+ },
355
+ });
356
+ });
357
+ });
358
+
359
+ describe("Transforms - Skew", () => {
360
+ test("skew-x-0", async () => {
361
+ expect(await renderCurrentTest()).toStrictEqual({
362
+ props: {
363
+ style: {
364
+ transform: [
365
+ { translateX: 0 },
366
+ { translateY: 0 },
367
+ { rotate: "0deg" },
368
+ { skewX: "0deg" },
369
+ { skewY: "0deg" },
370
+ { scaleX: 1 },
371
+ { scaleY: 1 },
372
+ ],
373
+ },
374
+ },
375
+ });
376
+ });
377
+ test("skew-y-0", async () => {
378
+ expect(await renderCurrentTest()).toStrictEqual({
379
+ props: {
380
+ style: {
381
+ transform: [
382
+ { translateX: 0 },
383
+ { translateY: 0 },
384
+ { rotate: "0deg" },
385
+ { skewX: "0deg" },
386
+ { skewY: "0deg" },
387
+ { scaleX: 1 },
388
+ { scaleY: 1 },
389
+ ],
390
+ },
391
+ },
392
+ });
393
+ });
394
+ test("skew-x-1", async () => {
395
+ expect(await renderCurrentTest()).toStrictEqual({
396
+ props: {
397
+ style: {
398
+ transform: [
399
+ { translateX: 0 },
400
+ { translateY: 0 },
401
+ { rotate: "0deg" },
402
+ { skewX: "1deg" },
403
+ { skewY: "0deg" },
404
+ { scaleX: 1 },
405
+ { scaleY: 1 },
406
+ ],
407
+ },
408
+ },
409
+ });
410
+ });
411
+ test("skew-y-1", async () => {
412
+ expect(await renderCurrentTest()).toStrictEqual({
413
+ props: {
414
+ style: {
415
+ transform: [
416
+ { translateX: 0 },
417
+ { translateY: 0 },
418
+ { rotate: "0deg" },
419
+ { skewX: "0deg" },
420
+ { skewY: "1deg" },
421
+ { scaleX: 1 },
422
+ { scaleY: 1 },
423
+ ],
424
+ },
425
+ },
426
+ });
427
+ });
428
+ });
429
+
430
+ describe("Transforms - Mixed", () => {
431
+ test("rotate-90 skew-y-1 translate-x-1", async () => {
432
+ expect(
433
+ await renderCurrentTest({
434
+ className: "rotate-90 skew-y-1 translate-x-1",
435
+ }),
436
+ ).toStrictEqual({
437
+ props: {
438
+ style: {
439
+ transform: [
440
+ { translateX: 3.5 },
441
+ { translateY: 0 },
442
+ { rotate: "90deg" },
443
+ { skewX: "0deg" },
444
+ { skewY: "1deg" },
445
+ { scaleX: 1 },
446
+ { scaleY: 1 },
447
+ ],
448
+ },
449
+ },
450
+ });
451
+ });
452
+
453
+ describe("Transforms - Transform Origin", () => {
454
+ test("origin-center", async () => {
455
+ expect(await renderCurrentTest()).toStrictEqual({
456
+ props: {},
457
+ invalid: { properties: ["transform-origin"] },
458
+ });
459
+ });
460
+ test("origin-top", async () => {
461
+ expect(await renderCurrentTest()).toStrictEqual({
462
+ props: {},
463
+ invalid: { properties: ["transform-origin"] },
464
+ });
465
+ });
466
+ test("origin-top-right", async () => {
467
+ expect(await renderCurrentTest()).toStrictEqual({
468
+ props: {},
469
+ invalid: { properties: ["transform-origin"] },
470
+ });
471
+ });
472
+ test("origin-right", async () => {
473
+ expect(await renderCurrentTest()).toStrictEqual({
474
+ props: {},
475
+ invalid: { properties: ["transform-origin"] },
476
+ });
477
+ });
478
+ test("origin-bottom-right", async () => {
479
+ expect(await renderCurrentTest()).toStrictEqual({
480
+ props: {},
481
+ invalid: { properties: ["transform-origin"] },
482
+ });
483
+ });
484
+ test("origin-bottom", async () => {
485
+ expect(await renderCurrentTest()).toStrictEqual({
486
+ props: {},
487
+ invalid: { properties: ["transform-origin"] },
488
+ });
489
+ });
490
+ test("origin-bottom-left", async () => {
491
+ expect(await renderCurrentTest()).toStrictEqual({
492
+ props: {},
493
+ invalid: { properties: ["transform-origin"] },
494
+ });
495
+ });
496
+ test("origin-left", async () => {
497
+ expect(await renderCurrentTest()).toStrictEqual({
498
+ props: {},
499
+ invalid: { properties: ["transform-origin"] },
500
+ });
501
+ });
502
+ test("origin-top-left", async () => {
503
+ expect(await renderCurrentTest()).toStrictEqual({
504
+ props: {},
505
+ invalid: { properties: ["transform-origin"] },
506
+ });
507
+ });
508
+ });
509
+ });