@retray-dev/ui-kit 12.1.0 → 13.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/COMPONENTS.md +183 -147
- package/CONSUMER.md +2 -2
- package/DESIGN.md +2 -2
- package/README.md +13 -8
- package/dist/Accordion.d.mts +6 -0
- package/dist/Accordion.d.ts +6 -0
- package/dist/Accordion.js +62 -208
- package/dist/Accordion.mjs +6 -5
- package/dist/AlertBanner.js +29 -151
- package/dist/AlertBanner.mjs +3 -3
- package/dist/AppHeader.js +37 -233
- package/dist/AppHeader.mjs +6 -7
- package/dist/Avatar.d.mts +17 -1
- package/dist/Avatar.d.ts +17 -1
- package/dist/Avatar.js +80 -113
- package/dist/Avatar.mjs +2 -2
- package/dist/Badge.js +24 -147
- package/dist/Badge.mjs +3 -3
- package/dist/Button.js +86 -274
- package/dist/Button.mjs +6 -6
- package/dist/Card.js +15 -198
- package/dist/Card.mjs +4 -5
- package/dist/CategoryStrip.d.mts +0 -5
- package/dist/CategoryStrip.d.ts +0 -5
- package/dist/CategoryStrip.js +47 -263
- package/dist/CategoryStrip.mjs +6 -6
- package/dist/Checkbox.js +15 -198
- package/dist/Checkbox.mjs +5 -5
- package/dist/Chip.js +44 -234
- package/dist/Chip.mjs +7 -6
- package/dist/ConfirmDialog.js +100 -296
- package/dist/ConfirmDialog.mjs +7 -7
- package/dist/CurrencyDisplay.js +1 -112
- package/dist/CurrencyDisplay.mjs +2 -2
- package/dist/CurrencyInput.js +35 -160
- package/dist/CurrencyInput.mjs +5 -5
- package/dist/DetailRow.js +25 -148
- package/dist/DetailRow.mjs +3 -3
- package/dist/EmptyState.js +87 -275
- package/dist/EmptyState.mjs +7 -7
- package/dist/ErrorBoundary.js +32 -197
- package/dist/ErrorBoundary.mjs +4 -4
- package/dist/Form.js +1 -112
- package/dist/Form.mjs +2 -2
- package/dist/HolographicCard.d.mts +0 -28
- package/dist/HolographicCard.d.ts +0 -28
- package/dist/HolographicCard.js +20 -130
- package/dist/HolographicCard.mjs +9 -32
- package/dist/IconButton.js +36 -232
- package/dist/IconButton.mjs +5 -6
- package/dist/IconPicker.js +222 -927
- package/dist/IconPicker.mjs +5 -5
- package/dist/ImageUpload.d.mts +5 -1
- package/dist/ImageUpload.d.ts +5 -1
- package/dist/ImageUpload.js +32 -215
- package/dist/ImageUpload.mjs +5 -6
- package/dist/ImageViewer.js +75 -264
- package/dist/ImageViewer.mjs +8 -8
- package/dist/Input.d.mts +1 -1
- package/dist/Input.d.ts +1 -1
- package/dist/Input.js +35 -160
- package/dist/Input.mjs +4 -4
- package/dist/LabelValue.js +24 -147
- package/dist/LabelValue.mjs +3 -3
- package/dist/ListGroup.js +1 -112
- package/dist/ListGroup.mjs +2 -2
- package/dist/ListItem.js +38 -233
- package/dist/ListItem.mjs +5 -6
- package/dist/MediaCard.d.mts +0 -14
- package/dist/MediaCard.d.ts +0 -14
- package/dist/MediaCard.js +69 -313
- package/dist/MediaCard.mjs +5 -6
- package/dist/MenuGroup.js +1 -112
- package/dist/MenuGroup.mjs +2 -2
- package/dist/MenuItem.js +36 -232
- package/dist/MenuItem.mjs +5 -6
- package/dist/MonthPicker.js +8 -161
- package/dist/MonthPicker.mjs +3 -3
- package/dist/NumberStepper.js +40 -236
- package/dist/NumberStepper.mjs +5 -6
- package/dist/PagerDots.d.mts +1 -1
- package/dist/PagerDots.d.ts +1 -1
- package/dist/PagerDots.js +69 -222
- package/dist/PagerDots.mjs +6 -5
- package/dist/Pressable.js +14 -85
- package/dist/Pressable.mjs +4 -4
- package/dist/PricingCard.js +94 -279
- package/dist/PricingCard.mjs +8 -8
- package/dist/Progress.js +3 -121
- package/dist/Progress.mjs +3 -3
- package/dist/RadioGroup.js +52 -263
- package/dist/RadioGroup.mjs +5 -5
- package/dist/RetrayProvider.d.mts +1 -1
- package/dist/RetrayProvider.d.ts +1 -1
- package/dist/RetrayProvider.js +5 -6
- package/dist/RetrayProvider.mjs +3 -3
- package/dist/Select.d.mts +2 -1
- package/dist/Select.d.ts +2 -1
- package/dist/Select.js +24 -230
- package/dist/Select.mjs +4 -5
- package/dist/SelectableCard.d.mts +27 -0
- package/dist/SelectableCard.d.ts +27 -0
- package/dist/SelectableCard.js +335 -0
- package/dist/SelectableCard.mjs +8 -0
- package/dist/SelectableGrid.d.mts +0 -21
- package/dist/SelectableGrid.d.ts +0 -21
- package/dist/SelectableGrid.js +49 -269
- package/dist/SelectableGrid.mjs +5 -6
- package/dist/Separator.js +1 -112
- package/dist/Separator.mjs +2 -2
- package/dist/Sheet.js +16 -163
- package/dist/Sheet.mjs +3 -3
- package/dist/SheetSelect.js +39 -234
- package/dist/SheetSelect.mjs +6 -6
- package/dist/Skeleton.d.mts +3 -1
- package/dist/Skeleton.d.ts +3 -1
- package/dist/Skeleton.js +7 -124
- package/dist/Skeleton.mjs +3 -3
- package/dist/Slider.js +6 -159
- package/dist/Slider.mjs +3 -3
- package/dist/Spinner.js +3 -114
- package/dist/Spinner.mjs +2 -2
- package/dist/Stats.d.mts +4 -1
- package/dist/Stats.d.ts +4 -1
- package/dist/Stats.js +60 -234
- package/dist/Stats.mjs +5 -6
- package/dist/Switch.js +24 -173
- package/dist/Switch.mjs +5 -4
- package/dist/TabBar.js +43 -198
- package/dist/TabBar.mjs +5 -4
- package/dist/Tabs.js +15 -197
- package/dist/Tabs.mjs +5 -5
- package/dist/Text.js +9 -128
- package/dist/Text.mjs +2 -2
- package/dist/Textarea.d.mts +2 -1
- package/dist/Textarea.d.ts +2 -1
- package/dist/Textarea.js +71 -217
- package/dist/Textarea.mjs +4 -4
- package/dist/Toast.js +1 -112
- package/dist/Toast.mjs +2 -2
- package/dist/Toggle.js +39 -234
- package/dist/Toggle.mjs +6 -6
- package/dist/{chunk-FFTYLPSB.mjs → chunk-2QOHHBJC.mjs} +13 -7
- package/dist/{chunk-BCWEHE34.mjs → chunk-2VIDP72N.mjs} +3 -3
- package/dist/{chunk-PGERH3P7.mjs → chunk-4NQFTHN3.mjs} +13 -7
- package/dist/{chunk-3N2M3WZL.mjs → chunk-4ZO5PTKF.mjs} +4 -4
- package/dist/{chunk-MYZ2EDYU.mjs → chunk-5MYNAAFE.mjs} +13 -17
- package/dist/{chunk-E7NEHHXV.mjs → chunk-62BBSSUF.mjs} +3 -3
- package/dist/{chunk-ISY26JQJ.mjs → chunk-6CR4S6W2.mjs} +3 -3
- package/dist/{chunk-FUVYSVGR.mjs → chunk-6QLBHUEG.mjs} +8 -7
- package/dist/chunk-ARONDO7M.mjs +40 -0
- package/dist/{chunk-3UYAZ7I4.mjs → chunk-AZV7KNJI.mjs} +3 -3
- package/dist/{chunk-HLMPMUK2.mjs → chunk-BTUW5LSG.mjs} +11 -8
- package/dist/chunk-BULKGOIZ.mjs +235 -0
- package/dist/{chunk-265G6A46.mjs → chunk-CBIZLRYH.mjs} +29 -12
- package/dist/chunk-CM2DG4MR.mjs +142 -0
- package/dist/{chunk-2I2AYECM.mjs → chunk-DBHSUUKU.mjs} +2 -2
- package/dist/{chunk-P64WHW4A.mjs → chunk-DE25XTVQ.mjs} +3 -3
- package/dist/{chunk-DI7CBDL6.mjs → chunk-E4EQSCKR.mjs} +5 -5
- package/dist/{chunk-357YO24D.mjs → chunk-EHGBHFMH.mjs} +9 -17
- package/dist/{chunk-GK4VRMNE.mjs → chunk-EROPDCB5.mjs} +24 -27
- package/dist/{chunk-XBAGGKLW.mjs → chunk-ERWJPVX7.mjs} +2 -2
- package/dist/{chunk-LRM4AVYY.mjs → chunk-ESQDPO5E.mjs} +7 -7
- package/dist/{chunk-EFLFRAHD.mjs → chunk-EW2FIDSM.mjs} +1 -1
- package/dist/{chunk-7HSILTC4.mjs → chunk-FTTI6T5Q.mjs} +4 -4
- package/dist/{chunk-X26S5EVZ.mjs → chunk-HUSSF6TF.mjs} +1 -1
- package/dist/chunk-IFYMBOEN.mjs +14 -0
- package/dist/{chunk-S3KJCPEJ.mjs → chunk-IGU223UM.mjs} +80 -4
- package/dist/chunk-IJCMPVW5.mjs +121 -0
- package/dist/{chunk-I4V5XZPS.mjs → chunk-ITG4JQM3.mjs} +4 -4
- package/dist/{chunk-F4V6XLP4.mjs → chunk-K3QX2M26.mjs} +11 -8
- package/dist/{chunk-V6NFJXKO.mjs → chunk-K7TKID3V.mjs} +8 -7
- package/dist/{chunk-ZHMSAYLT.mjs → chunk-KAGADD2O.mjs} +4 -4
- package/dist/{chunk-3GEYJ7I5.mjs → chunk-KC5QDYGZ.mjs} +4 -4
- package/dist/{chunk-HJ46DTJE.mjs → chunk-KPTY7UYQ.mjs} +1 -1
- package/dist/{chunk-EMUWGDWC.mjs → chunk-KSSVIFYR.mjs} +11 -12
- package/dist/chunk-L3YKPTJQ.mjs +119 -0
- package/dist/chunk-M53LC4Q7.mjs +35 -0
- package/dist/{chunk-NXI4YDZ2.mjs → chunk-MP7GLMIR.mjs} +17 -25
- package/dist/chunk-MZ6WRTD2.mjs +40 -0
- package/dist/chunk-NGEN2EES.mjs +581 -0
- package/dist/{chunk-JULSIZDM.mjs → chunk-OBV72JD4.mjs} +1 -1
- package/dist/{chunk-2A2LEFZG.mjs → chunk-PGQ6FMXS.mjs} +6 -5
- package/dist/{chunk-BQZE3HAW.mjs → chunk-PI6RULJX.mjs} +1 -1
- package/dist/{chunk-FA2KMTH5.mjs → chunk-RA6SAAFE.mjs} +9 -8
- package/dist/{chunk-FVTVCJAH.mjs → chunk-RRKM4MKB.mjs} +7 -7
- package/dist/{chunk-AKM4EPOT.mjs → chunk-S2VGME7X.mjs} +1 -1
- package/dist/{chunk-OULVKTWL.mjs → chunk-S44XWTTC.mjs} +35 -25
- package/dist/{chunk-QSFV2P7O.mjs → chunk-SZEKQAOY.mjs} +1 -1
- package/dist/{chunk-N4ZPVCJH.mjs → chunk-TETMEKZE.mjs} +9 -9
- package/dist/{chunk-2CBQKU7H.mjs → chunk-TMH263OK.mjs} +5 -4
- package/dist/{chunk-D3Y2T42P.mjs → chunk-U6DEBYU5.mjs} +10 -9
- package/dist/{chunk-4WFMPFZB.mjs → chunk-UOKFSFNJ.mjs} +2 -2
- package/dist/{chunk-WOEWGSTU.mjs → chunk-URIH43IJ.mjs} +13 -21
- package/dist/{chunk-JCZQOY4O.mjs → chunk-V2ZB2XNS.mjs} +16 -10
- package/dist/{chunk-P73V2EKS.mjs → chunk-WIPEDNSD.mjs} +7 -7
- package/dist/{chunk-BOVUP27T.mjs → chunk-XCIG6HT2.mjs} +6 -5
- package/dist/chunk-Y6YS33GM.mjs +131 -0
- package/dist/{chunk-5OLNXP3S.mjs → chunk-ZKDKKQCE.mjs} +29 -7
- package/dist/{chunk-DF6DU42P.mjs → chunk-ZTPYUU5C.mjs} +5 -5
- package/dist/{index-wt-orHUi.d.ts → index-CY34hxPN.d.mts} +1 -0
- package/dist/{index-wt-orHUi.d.mts → index-CY34hxPN.d.ts} +1 -0
- package/dist/index.d.mts +15 -74
- package/dist/index.d.ts +15 -74
- package/dist/index.js +1055 -1562
- package/dist/index.mjs +81 -84
- package/package.json +8 -10
- package/src/components/Accordion/Accordion.tsx +32 -9
- package/src/components/AlertBanner/AlertBanner.tsx +7 -6
- package/src/components/AppHeader/AppHeader.tsx +1 -1
- package/src/components/Avatar/Avatar.tsx +92 -1
- package/src/components/Avatar/index.ts +2 -2
- package/src/components/Badge/Badge.tsx +2 -2
- package/src/components/Button/Button.tsx +64 -57
- package/src/components/Card/Card.tsx +1 -0
- package/src/components/CategoryStrip/CategoryStrip.tsx +36 -49
- package/src/components/Chip/Chip.tsx +5 -4
- package/src/components/ConfirmDialog/ConfirmDialog.tsx +13 -6
- package/src/components/DetailRow/DetailRow.tsx +3 -3
- package/src/components/EmptyState/EmptyState.tsx +2 -2
- package/src/components/ErrorBoundary/ErrorBoundary.tsx +6 -6
- package/src/components/HolographicCard/HolographicCard.tsx +14 -95
- package/src/components/IconButton/IconButton.tsx +2 -2
- package/src/components/IconPicker/IconPicker.tsx +13 -12
- package/src/components/ImageUpload/ImageUpload.tsx +24 -28
- package/src/components/ImageViewer/ImageViewer.tsx +3 -3
- package/src/components/Input/Input.tsx +11 -5
- package/src/components/LabelValue/LabelValue.tsx +2 -2
- package/src/components/ListItem/ListItem.tsx +4 -4
- package/src/components/MediaCard/MediaCard.tsx +21 -59
- package/src/components/MenuItem/MenuItem.tsx +2 -2
- package/src/components/MonthPicker/MonthPicker.tsx +2 -2
- package/src/components/NumberStepper/NumberStepper.tsx +6 -6
- package/src/components/PagerDots/PagerDots.tsx +38 -28
- package/src/components/PricingCard/PricingCard.tsx +6 -6
- package/src/components/RadioGroup/RadioGroup.tsx +18 -31
- package/src/components/Select/Select.tsx +32 -39
- package/src/components/SelectableCard/SelectableCard.tsx +302 -0
- package/src/components/SelectableCard/index.ts +1 -0
- package/src/components/SelectableGrid/SelectableGrid.tsx +38 -72
- package/src/components/Sheet/Sheet.tsx +11 -4
- package/src/components/SheetSelect/SheetSelect.tsx +3 -3
- package/src/components/Skeleton/Skeleton.tsx +6 -3
- package/src/components/Spinner/Spinner.tsx +2 -2
- package/src/components/Stats/Stats.tsx +36 -8
- package/src/components/Switch/Switch.tsx +9 -6
- package/src/components/TabBar/TabBar.tsx +9 -8
- package/src/components/Text/Text.tsx +12 -1
- package/src/components/Textarea/Textarea.tsx +18 -32
- package/src/components/Toggle/Toggle.tsx +3 -3
- package/src/hooks/useConfirmDialog.ts +31 -42
- package/src/index.ts +4 -4
- package/src/theme/ThemeProvider.tsx +1 -4
- package/src/theme/colorUtils.ts +1 -72
- package/src/theme/colors.ts +47 -1
- package/src/theme/types.ts +6 -3
- package/src/utils/animations.ts +0 -47
- package/src/utils/curatedIcons.ts +93 -801
- package/src/utils/haptics.ts +13 -208
- package/src/utils/icons.ts +27 -91
- package/src/utils/pressable.ts +10 -61
- package/dist/VirtualList.d.mts +0 -19
- package/dist/VirtualList.d.ts +0 -19
- package/dist/VirtualList.js +0 -38
- package/dist/VirtualList.mjs +0 -2
- package/dist/chunk-3DKJ2GIC.mjs +0 -30
- package/dist/chunk-AQEVCEXV.mjs +0 -164
- package/dist/chunk-DOGIPOF5.mjs +0 -131
- package/dist/chunk-DVK4G2GT.mjs +0 -59
- package/dist/chunk-EJ7ZPXOH.mjs +0 -163
- package/dist/chunk-J6Q2YJEV.mjs +0 -134
- package/dist/chunk-JNVAIDLK.mjs +0 -136
- package/dist/chunk-KA7LTET3.mjs +0 -71
- package/dist/chunk-KHYX4IOM.mjs +0 -1114
- package/dist/chunk-NC5ZTR2Y.mjs +0 -32
- package/dist/chunk-YNROWHQJ.mjs +0 -46
- package/src/components/VirtualList/VirtualList.tsx +0 -60
- package/src/components/VirtualList/index.ts +0 -1
- package/src/utils/fontGuard.ts +0 -35
- package/src/utils/hover.ts +0 -25
- package/src/utils/useColorTransition.ts +0 -40
- package/src/utils/usePressScale.ts +0 -75
package/src/theme/colors.ts
CHANGED
|
@@ -1,5 +1,44 @@
|
|
|
1
1
|
import { ThemeColors, ResolvedColors } from './types'
|
|
2
|
-
import {
|
|
2
|
+
import { hexToRgb } from './colorUtils'
|
|
3
|
+
|
|
4
|
+
function componentToHex(c: number): string {
|
|
5
|
+
return Math.round(Math.max(0, Math.min(255, c))).toString(16).padStart(2, '0')
|
|
6
|
+
}
|
|
7
|
+
|
|
8
|
+
function rgbToHex(r: number, g: number, b: number): string {
|
|
9
|
+
return `#${componentToHex(r)}${componentToHex(g)}${componentToHex(b)}`
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
function withAlphaOnWhite(hex: string, alpha: number): string {
|
|
13
|
+
const rgb = hexToRgb(hex)
|
|
14
|
+
if (!rgb) return hex
|
|
15
|
+
const r = rgb.r * alpha + 255 * (1 - alpha); const g = rgb.g * alpha + 255 * (1 - alpha); const b = rgb.b * alpha + 255 * (1 - alpha)
|
|
16
|
+
return rgbToHex(r, g, b)
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
function withAlphaOnDark(hex: string, alpha: number, bgHex = '#0f0f0f'): string {
|
|
20
|
+
const rgb = hexToRgb(hex); const bg = hexToRgb(bgHex)
|
|
21
|
+
if (!rgb || !bg) return hex
|
|
22
|
+
const r = rgb.r * alpha + bg.r * (1 - alpha); const g = rgb.g * alpha + bg.g * (1 - alpha); const b = rgb.b * alpha + bg.b * (1 - alpha)
|
|
23
|
+
return rgbToHex(r, g, b)
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
function mixWithBackground(fgHex: string, bgHex: string, opacity: number): string {
|
|
27
|
+
const fg = hexToRgb(fgHex); const bg = hexToRgb(bgHex)
|
|
28
|
+
if (!fg || !bg) return fgHex
|
|
29
|
+
const r = fg.r * opacity + bg.r * (1 - opacity); const g = fg.g * opacity + bg.g * (1 - opacity); const b = fg.b * opacity + bg.b * (1 - opacity)
|
|
30
|
+
return rgbToHex(r, g, b)
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
function lighten(hex: string, amount: number): string {
|
|
34
|
+
return withAlphaOnWhite(hex, 1 - amount)
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
function darken(hex: string, amount: number): string {
|
|
38
|
+
const rgb = hexToRgb(hex)
|
|
39
|
+
if (!rgb) return hex
|
|
40
|
+
return rgbToHex(rgb.r * (1 - amount), rgb.g * (1 - amount), rgb.b * (1 - amount))
|
|
41
|
+
}
|
|
3
42
|
|
|
4
43
|
// ─── Default palettes ─────────────────────────────────────────────────────────
|
|
5
44
|
// AUDIT FIXES applied:
|
|
@@ -69,6 +108,12 @@ export function deriveColors(t: ThemeColors, scheme: 'light' | 'dark'): Resolved
|
|
|
69
108
|
? lighten(bg, -0.12)
|
|
70
109
|
: darken(bg, 0.08)
|
|
71
110
|
|
|
111
|
+
// Skeleton needs higher contrast than surface to be visible.
|
|
112
|
+
// Light: 10% darken (was 4% via surface — invisible). Dark: 10% lighten.
|
|
113
|
+
const skeleton = dark
|
|
114
|
+
? lighten(bg, -0.10)
|
|
115
|
+
: darken(bg, 0.10)
|
|
116
|
+
|
|
72
117
|
const destructiveTint = dark
|
|
73
118
|
? withAlphaOnDark(t.destructive, 0.15, bg)
|
|
74
119
|
: withAlphaOnWhite(t.destructive, 0.08)
|
|
@@ -96,6 +141,7 @@ export function deriveColors(t: ThemeColors, scheme: 'light' | 'dark'): Resolved
|
|
|
96
141
|
foregroundMuted,
|
|
97
142
|
surface,
|
|
98
143
|
surfaceStrong,
|
|
144
|
+
skeleton,
|
|
99
145
|
destructiveTint,
|
|
100
146
|
destructiveBorder,
|
|
101
147
|
successTint,
|
package/src/theme/types.ts
CHANGED
|
@@ -26,13 +26,16 @@ export type ThemeColors = {
|
|
|
26
26
|
// Derived from ThemeColors. Never supplied by consumers directly.
|
|
27
27
|
export type ResolvedColors = ThemeColors & {
|
|
28
28
|
// Text hierarchy
|
|
29
|
-
foregroundSubtle: string // ~
|
|
30
|
-
foregroundMuted: string // ~
|
|
29
|
+
foregroundSubtle: string // ~70% — body text, subtitles
|
|
30
|
+
foregroundMuted: string // ~62% — captions, timestamps, placeholders
|
|
31
31
|
|
|
32
|
-
// Surface fills (chips unselected, input bg, tag bg
|
|
32
|
+
// Surface fills (chips unselected, input bg, tag bg)
|
|
33
33
|
surface: string // background slightly off-canvas
|
|
34
34
|
surfaceStrong: string // slightly stronger fill for pressed/hover states
|
|
35
35
|
|
|
36
|
+
// Skeleton placeholder — higher contrast than surface for visibility
|
|
37
|
+
skeleton: string
|
|
38
|
+
|
|
36
39
|
// Semantic tints (light bg for alert banners, toast backgrounds)
|
|
37
40
|
destructiveTint: string
|
|
38
41
|
destructiveBorder: string
|
package/src/utils/animations.ts
CHANGED
|
@@ -1,74 +1,29 @@
|
|
|
1
|
-
import { Easing } from 'react-native-reanimated'
|
|
2
1
|
import type { SingleTransition } from 'react-native-ease'
|
|
3
2
|
|
|
4
|
-
// ─── Spring presets ──────────────────────────────────────────────────────────
|
|
5
|
-
// Tuned for the "Apple HIG / Airbnb" press-feel: snap inward fast, settle out elastically.
|
|
6
|
-
// `stiffness`/`damping`/`mass` model — Reanimated v4 default physics units.
|
|
7
|
-
//
|
|
8
|
-
// pressIn: high stiffness, heavy damping → fast, controlled compression
|
|
9
|
-
// pressOut: lower stiffness, less damping → soft, elastic rebound
|
|
10
|
-
// settle: pillows / drawers / large surfaces → calm, never twitchy
|
|
11
3
|
export const SPRINGS = {
|
|
12
|
-
/** Tight, premium press feel — Buttons, Toggle, Tabs triggers. */
|
|
13
|
-
pressIn: { stiffness: 600, damping: 35, mass: 0.8 },
|
|
14
|
-
pressOut: { stiffness: 280, damping: 22, mass: 0.8 },
|
|
15
|
-
|
|
16
|
-
/** Slightly softer for larger surfaces — Card, ListItem, MenuItem. */
|
|
17
|
-
surfacePressIn: { stiffness: 380, damping: 30, mass: 0.95 },
|
|
18
|
-
surfacePressOut: { stiffness: 220, damping: 20, mass: 0.95 },
|
|
19
|
-
|
|
20
|
-
/** Settled transitions for moving indicators — Tabs pill, Switch thumb. */
|
|
21
4
|
glide: { stiffness: 380, damping: 38, mass: 1 },
|
|
22
|
-
|
|
23
|
-
/** Elastic indicator — Switch thumb, RadioGroup dot. */
|
|
24
5
|
elastic: { stiffness: 320, damping: 22, mass: 0.7 },
|
|
25
6
|
} as const
|
|
26
7
|
|
|
27
|
-
// ─── Timing presets ──────────────────────────────────────────────────────────
|
|
28
|
-
// All timings target the UI thread via Reanimated `withTiming`.
|
|
29
8
|
export const TIMINGS = {
|
|
30
|
-
/** Color/opacity transitions on toggles, checkboxes, switches. */
|
|
31
9
|
state: { duration: 160 },
|
|
32
|
-
/** Focus ring on inputs. */
|
|
33
|
-
focusIn: { duration: 140 },
|
|
34
|
-
focusOut: { duration: 100 },
|
|
35
|
-
/** Accordion / collapsible content. */
|
|
36
10
|
expand: { duration: 240 },
|
|
37
11
|
collapse: { duration: 200 },
|
|
38
|
-
/** Skeleton shimmer cycle (full pass). */
|
|
39
12
|
shimmer: { duration: 1400 },
|
|
40
13
|
} as const
|
|
41
14
|
|
|
42
|
-
// ─── Easing presets ──────────────────────────────────────────────────────────
|
|
43
|
-
export const EASINGS = {
|
|
44
|
-
/** Material-style ease-out — natural deceleration for state changes. */
|
|
45
|
-
standard: Easing.bezier(0.2, 0, 0, 1),
|
|
46
|
-
/** Strong ease-out for expanding surfaces (Accordion open). */
|
|
47
|
-
expand: Easing.bezier(0.23, 1, 0.32, 1),
|
|
48
|
-
/** Quick ease-in for collapsing. */
|
|
49
|
-
collapse: Easing.in(Easing.ease),
|
|
50
|
-
} as const
|
|
51
|
-
|
|
52
|
-
// ─── EaseView transition presets ─────────────────────────────────────────────
|
|
53
|
-
// Equivalents of the reanimated presets above, in `react-native-ease` units.
|
|
54
|
-
// EaseView spring takes raw damping/stiffness/mass (same physical model). EaseView
|
|
55
|
-
// timing takes duration + an easing curve as a cubic-bezier tuple.
|
|
56
|
-
|
|
57
|
-
/** Color/border state transition for Toggle, Checkbox, Chip, CategoryStrip, Switch track. Mirrors TIMINGS.state + EASINGS.standard. */
|
|
58
15
|
export const COLOR_TRANSITION: SingleTransition = {
|
|
59
16
|
type: 'timing',
|
|
60
17
|
duration: TIMINGS.state.duration,
|
|
61
18
|
easing: [0.2, 0, 0, 1],
|
|
62
19
|
}
|
|
63
20
|
|
|
64
|
-
/** Icon/opacity crossfade. Mirrors TIMINGS.state + EASINGS.standard. */
|
|
65
21
|
export const OPACITY_TRANSITION: SingleTransition = {
|
|
66
22
|
type: 'timing',
|
|
67
23
|
duration: TIMINGS.state.duration,
|
|
68
24
|
easing: [0.2, 0, 0, 1],
|
|
69
25
|
}
|
|
70
26
|
|
|
71
|
-
/** Elastic indicator spring — Switch thumb, RadioGroup dot. Mirrors SPRINGS.elastic. */
|
|
72
27
|
export const SPRING_ELASTIC: SingleTransition = {
|
|
73
28
|
type: 'spring',
|
|
74
29
|
stiffness: 320,
|
|
@@ -76,8 +31,6 @@ export const SPRING_ELASTIC: SingleTransition = {
|
|
|
76
31
|
mass: 0.7,
|
|
77
32
|
}
|
|
78
33
|
|
|
79
|
-
// ─── Press scale tokens ──────────────────────────────────────────────────────
|
|
80
|
-
// Per-component press intensities — taken from DESIGN.md.
|
|
81
34
|
export const PRESS_SCALE = {
|
|
82
35
|
button: 0.95,
|
|
83
36
|
card: 0.98,
|