@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.
Files changed (282) hide show
  1. package/COMPONENTS.md +183 -147
  2. package/CONSUMER.md +2 -2
  3. package/DESIGN.md +2 -2
  4. package/README.md +13 -8
  5. package/dist/Accordion.d.mts +6 -0
  6. package/dist/Accordion.d.ts +6 -0
  7. package/dist/Accordion.js +62 -208
  8. package/dist/Accordion.mjs +6 -5
  9. package/dist/AlertBanner.js +29 -151
  10. package/dist/AlertBanner.mjs +3 -3
  11. package/dist/AppHeader.js +37 -233
  12. package/dist/AppHeader.mjs +6 -7
  13. package/dist/Avatar.d.mts +17 -1
  14. package/dist/Avatar.d.ts +17 -1
  15. package/dist/Avatar.js +80 -113
  16. package/dist/Avatar.mjs +2 -2
  17. package/dist/Badge.js +24 -147
  18. package/dist/Badge.mjs +3 -3
  19. package/dist/Button.js +86 -274
  20. package/dist/Button.mjs +6 -6
  21. package/dist/Card.js +15 -198
  22. package/dist/Card.mjs +4 -5
  23. package/dist/CategoryStrip.d.mts +0 -5
  24. package/dist/CategoryStrip.d.ts +0 -5
  25. package/dist/CategoryStrip.js +47 -263
  26. package/dist/CategoryStrip.mjs +6 -6
  27. package/dist/Checkbox.js +15 -198
  28. package/dist/Checkbox.mjs +5 -5
  29. package/dist/Chip.js +44 -234
  30. package/dist/Chip.mjs +7 -6
  31. package/dist/ConfirmDialog.js +100 -296
  32. package/dist/ConfirmDialog.mjs +7 -7
  33. package/dist/CurrencyDisplay.js +1 -112
  34. package/dist/CurrencyDisplay.mjs +2 -2
  35. package/dist/CurrencyInput.js +35 -160
  36. package/dist/CurrencyInput.mjs +5 -5
  37. package/dist/DetailRow.js +25 -148
  38. package/dist/DetailRow.mjs +3 -3
  39. package/dist/EmptyState.js +87 -275
  40. package/dist/EmptyState.mjs +7 -7
  41. package/dist/ErrorBoundary.js +32 -197
  42. package/dist/ErrorBoundary.mjs +4 -4
  43. package/dist/Form.js +1 -112
  44. package/dist/Form.mjs +2 -2
  45. package/dist/HolographicCard.d.mts +0 -28
  46. package/dist/HolographicCard.d.ts +0 -28
  47. package/dist/HolographicCard.js +20 -130
  48. package/dist/HolographicCard.mjs +9 -32
  49. package/dist/IconButton.js +36 -232
  50. package/dist/IconButton.mjs +5 -6
  51. package/dist/IconPicker.js +222 -927
  52. package/dist/IconPicker.mjs +5 -5
  53. package/dist/ImageUpload.d.mts +5 -1
  54. package/dist/ImageUpload.d.ts +5 -1
  55. package/dist/ImageUpload.js +32 -215
  56. package/dist/ImageUpload.mjs +5 -6
  57. package/dist/ImageViewer.js +75 -264
  58. package/dist/ImageViewer.mjs +8 -8
  59. package/dist/Input.d.mts +1 -1
  60. package/dist/Input.d.ts +1 -1
  61. package/dist/Input.js +35 -160
  62. package/dist/Input.mjs +4 -4
  63. package/dist/LabelValue.js +24 -147
  64. package/dist/LabelValue.mjs +3 -3
  65. package/dist/ListGroup.js +1 -112
  66. package/dist/ListGroup.mjs +2 -2
  67. package/dist/ListItem.js +38 -233
  68. package/dist/ListItem.mjs +5 -6
  69. package/dist/MediaCard.d.mts +0 -14
  70. package/dist/MediaCard.d.ts +0 -14
  71. package/dist/MediaCard.js +69 -313
  72. package/dist/MediaCard.mjs +5 -6
  73. package/dist/MenuGroup.js +1 -112
  74. package/dist/MenuGroup.mjs +2 -2
  75. package/dist/MenuItem.js +36 -232
  76. package/dist/MenuItem.mjs +5 -6
  77. package/dist/MonthPicker.js +8 -161
  78. package/dist/MonthPicker.mjs +3 -3
  79. package/dist/NumberStepper.js +40 -236
  80. package/dist/NumberStepper.mjs +5 -6
  81. package/dist/PagerDots.d.mts +1 -1
  82. package/dist/PagerDots.d.ts +1 -1
  83. package/dist/PagerDots.js +69 -222
  84. package/dist/PagerDots.mjs +6 -5
  85. package/dist/Pressable.js +14 -85
  86. package/dist/Pressable.mjs +4 -4
  87. package/dist/PricingCard.js +94 -279
  88. package/dist/PricingCard.mjs +8 -8
  89. package/dist/Progress.js +3 -121
  90. package/dist/Progress.mjs +3 -3
  91. package/dist/RadioGroup.js +52 -263
  92. package/dist/RadioGroup.mjs +5 -5
  93. package/dist/RetrayProvider.d.mts +1 -1
  94. package/dist/RetrayProvider.d.ts +1 -1
  95. package/dist/RetrayProvider.js +5 -6
  96. package/dist/RetrayProvider.mjs +3 -3
  97. package/dist/Select.d.mts +2 -1
  98. package/dist/Select.d.ts +2 -1
  99. package/dist/Select.js +24 -230
  100. package/dist/Select.mjs +4 -5
  101. package/dist/SelectableCard.d.mts +27 -0
  102. package/dist/SelectableCard.d.ts +27 -0
  103. package/dist/SelectableCard.js +335 -0
  104. package/dist/SelectableCard.mjs +8 -0
  105. package/dist/SelectableGrid.d.mts +0 -21
  106. package/dist/SelectableGrid.d.ts +0 -21
  107. package/dist/SelectableGrid.js +49 -269
  108. package/dist/SelectableGrid.mjs +5 -6
  109. package/dist/Separator.js +1 -112
  110. package/dist/Separator.mjs +2 -2
  111. package/dist/Sheet.js +16 -163
  112. package/dist/Sheet.mjs +3 -3
  113. package/dist/SheetSelect.js +39 -234
  114. package/dist/SheetSelect.mjs +6 -6
  115. package/dist/Skeleton.d.mts +3 -1
  116. package/dist/Skeleton.d.ts +3 -1
  117. package/dist/Skeleton.js +7 -124
  118. package/dist/Skeleton.mjs +3 -3
  119. package/dist/Slider.js +6 -159
  120. package/dist/Slider.mjs +3 -3
  121. package/dist/Spinner.js +3 -114
  122. package/dist/Spinner.mjs +2 -2
  123. package/dist/Stats.d.mts +4 -1
  124. package/dist/Stats.d.ts +4 -1
  125. package/dist/Stats.js +60 -234
  126. package/dist/Stats.mjs +5 -6
  127. package/dist/Switch.js +24 -173
  128. package/dist/Switch.mjs +5 -4
  129. package/dist/TabBar.js +43 -198
  130. package/dist/TabBar.mjs +5 -4
  131. package/dist/Tabs.js +15 -197
  132. package/dist/Tabs.mjs +5 -5
  133. package/dist/Text.js +9 -128
  134. package/dist/Text.mjs +2 -2
  135. package/dist/Textarea.d.mts +2 -1
  136. package/dist/Textarea.d.ts +2 -1
  137. package/dist/Textarea.js +71 -217
  138. package/dist/Textarea.mjs +4 -4
  139. package/dist/Toast.js +1 -112
  140. package/dist/Toast.mjs +2 -2
  141. package/dist/Toggle.js +39 -234
  142. package/dist/Toggle.mjs +6 -6
  143. package/dist/{chunk-FFTYLPSB.mjs → chunk-2QOHHBJC.mjs} +13 -7
  144. package/dist/{chunk-BCWEHE34.mjs → chunk-2VIDP72N.mjs} +3 -3
  145. package/dist/{chunk-PGERH3P7.mjs → chunk-4NQFTHN3.mjs} +13 -7
  146. package/dist/{chunk-3N2M3WZL.mjs → chunk-4ZO5PTKF.mjs} +4 -4
  147. package/dist/{chunk-MYZ2EDYU.mjs → chunk-5MYNAAFE.mjs} +13 -17
  148. package/dist/{chunk-E7NEHHXV.mjs → chunk-62BBSSUF.mjs} +3 -3
  149. package/dist/{chunk-ISY26JQJ.mjs → chunk-6CR4S6W2.mjs} +3 -3
  150. package/dist/{chunk-FUVYSVGR.mjs → chunk-6QLBHUEG.mjs} +8 -7
  151. package/dist/chunk-ARONDO7M.mjs +40 -0
  152. package/dist/{chunk-3UYAZ7I4.mjs → chunk-AZV7KNJI.mjs} +3 -3
  153. package/dist/{chunk-HLMPMUK2.mjs → chunk-BTUW5LSG.mjs} +11 -8
  154. package/dist/chunk-BULKGOIZ.mjs +235 -0
  155. package/dist/{chunk-265G6A46.mjs → chunk-CBIZLRYH.mjs} +29 -12
  156. package/dist/chunk-CM2DG4MR.mjs +142 -0
  157. package/dist/{chunk-2I2AYECM.mjs → chunk-DBHSUUKU.mjs} +2 -2
  158. package/dist/{chunk-P64WHW4A.mjs → chunk-DE25XTVQ.mjs} +3 -3
  159. package/dist/{chunk-DI7CBDL6.mjs → chunk-E4EQSCKR.mjs} +5 -5
  160. package/dist/{chunk-357YO24D.mjs → chunk-EHGBHFMH.mjs} +9 -17
  161. package/dist/{chunk-GK4VRMNE.mjs → chunk-EROPDCB5.mjs} +24 -27
  162. package/dist/{chunk-XBAGGKLW.mjs → chunk-ERWJPVX7.mjs} +2 -2
  163. package/dist/{chunk-LRM4AVYY.mjs → chunk-ESQDPO5E.mjs} +7 -7
  164. package/dist/{chunk-EFLFRAHD.mjs → chunk-EW2FIDSM.mjs} +1 -1
  165. package/dist/{chunk-7HSILTC4.mjs → chunk-FTTI6T5Q.mjs} +4 -4
  166. package/dist/{chunk-X26S5EVZ.mjs → chunk-HUSSF6TF.mjs} +1 -1
  167. package/dist/chunk-IFYMBOEN.mjs +14 -0
  168. package/dist/{chunk-S3KJCPEJ.mjs → chunk-IGU223UM.mjs} +80 -4
  169. package/dist/chunk-IJCMPVW5.mjs +121 -0
  170. package/dist/{chunk-I4V5XZPS.mjs → chunk-ITG4JQM3.mjs} +4 -4
  171. package/dist/{chunk-F4V6XLP4.mjs → chunk-K3QX2M26.mjs} +11 -8
  172. package/dist/{chunk-V6NFJXKO.mjs → chunk-K7TKID3V.mjs} +8 -7
  173. package/dist/{chunk-ZHMSAYLT.mjs → chunk-KAGADD2O.mjs} +4 -4
  174. package/dist/{chunk-3GEYJ7I5.mjs → chunk-KC5QDYGZ.mjs} +4 -4
  175. package/dist/{chunk-HJ46DTJE.mjs → chunk-KPTY7UYQ.mjs} +1 -1
  176. package/dist/{chunk-EMUWGDWC.mjs → chunk-KSSVIFYR.mjs} +11 -12
  177. package/dist/chunk-L3YKPTJQ.mjs +119 -0
  178. package/dist/chunk-M53LC4Q7.mjs +35 -0
  179. package/dist/{chunk-NXI4YDZ2.mjs → chunk-MP7GLMIR.mjs} +17 -25
  180. package/dist/chunk-MZ6WRTD2.mjs +40 -0
  181. package/dist/chunk-NGEN2EES.mjs +581 -0
  182. package/dist/{chunk-JULSIZDM.mjs → chunk-OBV72JD4.mjs} +1 -1
  183. package/dist/{chunk-2A2LEFZG.mjs → chunk-PGQ6FMXS.mjs} +6 -5
  184. package/dist/{chunk-BQZE3HAW.mjs → chunk-PI6RULJX.mjs} +1 -1
  185. package/dist/{chunk-FA2KMTH5.mjs → chunk-RA6SAAFE.mjs} +9 -8
  186. package/dist/{chunk-FVTVCJAH.mjs → chunk-RRKM4MKB.mjs} +7 -7
  187. package/dist/{chunk-AKM4EPOT.mjs → chunk-S2VGME7X.mjs} +1 -1
  188. package/dist/{chunk-OULVKTWL.mjs → chunk-S44XWTTC.mjs} +35 -25
  189. package/dist/{chunk-QSFV2P7O.mjs → chunk-SZEKQAOY.mjs} +1 -1
  190. package/dist/{chunk-N4ZPVCJH.mjs → chunk-TETMEKZE.mjs} +9 -9
  191. package/dist/{chunk-2CBQKU7H.mjs → chunk-TMH263OK.mjs} +5 -4
  192. package/dist/{chunk-D3Y2T42P.mjs → chunk-U6DEBYU5.mjs} +10 -9
  193. package/dist/{chunk-4WFMPFZB.mjs → chunk-UOKFSFNJ.mjs} +2 -2
  194. package/dist/{chunk-WOEWGSTU.mjs → chunk-URIH43IJ.mjs} +13 -21
  195. package/dist/{chunk-JCZQOY4O.mjs → chunk-V2ZB2XNS.mjs} +16 -10
  196. package/dist/{chunk-P73V2EKS.mjs → chunk-WIPEDNSD.mjs} +7 -7
  197. package/dist/{chunk-BOVUP27T.mjs → chunk-XCIG6HT2.mjs} +6 -5
  198. package/dist/chunk-Y6YS33GM.mjs +131 -0
  199. package/dist/{chunk-5OLNXP3S.mjs → chunk-ZKDKKQCE.mjs} +29 -7
  200. package/dist/{chunk-DF6DU42P.mjs → chunk-ZTPYUU5C.mjs} +5 -5
  201. package/dist/{index-wt-orHUi.d.ts → index-CY34hxPN.d.mts} +1 -0
  202. package/dist/{index-wt-orHUi.d.mts → index-CY34hxPN.d.ts} +1 -0
  203. package/dist/index.d.mts +15 -74
  204. package/dist/index.d.ts +15 -74
  205. package/dist/index.js +1055 -1562
  206. package/dist/index.mjs +81 -84
  207. package/package.json +8 -10
  208. package/src/components/Accordion/Accordion.tsx +32 -9
  209. package/src/components/AlertBanner/AlertBanner.tsx +7 -6
  210. package/src/components/AppHeader/AppHeader.tsx +1 -1
  211. package/src/components/Avatar/Avatar.tsx +92 -1
  212. package/src/components/Avatar/index.ts +2 -2
  213. package/src/components/Badge/Badge.tsx +2 -2
  214. package/src/components/Button/Button.tsx +64 -57
  215. package/src/components/Card/Card.tsx +1 -0
  216. package/src/components/CategoryStrip/CategoryStrip.tsx +36 -49
  217. package/src/components/Chip/Chip.tsx +5 -4
  218. package/src/components/ConfirmDialog/ConfirmDialog.tsx +13 -6
  219. package/src/components/DetailRow/DetailRow.tsx +3 -3
  220. package/src/components/EmptyState/EmptyState.tsx +2 -2
  221. package/src/components/ErrorBoundary/ErrorBoundary.tsx +6 -6
  222. package/src/components/HolographicCard/HolographicCard.tsx +14 -95
  223. package/src/components/IconButton/IconButton.tsx +2 -2
  224. package/src/components/IconPicker/IconPicker.tsx +13 -12
  225. package/src/components/ImageUpload/ImageUpload.tsx +24 -28
  226. package/src/components/ImageViewer/ImageViewer.tsx +3 -3
  227. package/src/components/Input/Input.tsx +11 -5
  228. package/src/components/LabelValue/LabelValue.tsx +2 -2
  229. package/src/components/ListItem/ListItem.tsx +4 -4
  230. package/src/components/MediaCard/MediaCard.tsx +21 -59
  231. package/src/components/MenuItem/MenuItem.tsx +2 -2
  232. package/src/components/MonthPicker/MonthPicker.tsx +2 -2
  233. package/src/components/NumberStepper/NumberStepper.tsx +6 -6
  234. package/src/components/PagerDots/PagerDots.tsx +38 -28
  235. package/src/components/PricingCard/PricingCard.tsx +6 -6
  236. package/src/components/RadioGroup/RadioGroup.tsx +18 -31
  237. package/src/components/Select/Select.tsx +32 -39
  238. package/src/components/SelectableCard/SelectableCard.tsx +302 -0
  239. package/src/components/SelectableCard/index.ts +1 -0
  240. package/src/components/SelectableGrid/SelectableGrid.tsx +38 -72
  241. package/src/components/Sheet/Sheet.tsx +11 -4
  242. package/src/components/SheetSelect/SheetSelect.tsx +3 -3
  243. package/src/components/Skeleton/Skeleton.tsx +6 -3
  244. package/src/components/Spinner/Spinner.tsx +2 -2
  245. package/src/components/Stats/Stats.tsx +36 -8
  246. package/src/components/Switch/Switch.tsx +9 -6
  247. package/src/components/TabBar/TabBar.tsx +9 -8
  248. package/src/components/Text/Text.tsx +12 -1
  249. package/src/components/Textarea/Textarea.tsx +18 -32
  250. package/src/components/Toggle/Toggle.tsx +3 -3
  251. package/src/hooks/useConfirmDialog.ts +31 -42
  252. package/src/index.ts +4 -4
  253. package/src/theme/ThemeProvider.tsx +1 -4
  254. package/src/theme/colorUtils.ts +1 -72
  255. package/src/theme/colors.ts +47 -1
  256. package/src/theme/types.ts +6 -3
  257. package/src/utils/animations.ts +0 -47
  258. package/src/utils/curatedIcons.ts +93 -801
  259. package/src/utils/haptics.ts +13 -208
  260. package/src/utils/icons.ts +27 -91
  261. package/src/utils/pressable.ts +10 -61
  262. package/dist/VirtualList.d.mts +0 -19
  263. package/dist/VirtualList.d.ts +0 -19
  264. package/dist/VirtualList.js +0 -38
  265. package/dist/VirtualList.mjs +0 -2
  266. package/dist/chunk-3DKJ2GIC.mjs +0 -30
  267. package/dist/chunk-AQEVCEXV.mjs +0 -164
  268. package/dist/chunk-DOGIPOF5.mjs +0 -131
  269. package/dist/chunk-DVK4G2GT.mjs +0 -59
  270. package/dist/chunk-EJ7ZPXOH.mjs +0 -163
  271. package/dist/chunk-J6Q2YJEV.mjs +0 -134
  272. package/dist/chunk-JNVAIDLK.mjs +0 -136
  273. package/dist/chunk-KA7LTET3.mjs +0 -71
  274. package/dist/chunk-KHYX4IOM.mjs +0 -1114
  275. package/dist/chunk-NC5ZTR2Y.mjs +0 -32
  276. package/dist/chunk-YNROWHQJ.mjs +0 -46
  277. package/src/components/VirtualList/VirtualList.tsx +0 -60
  278. package/src/components/VirtualList/index.ts +0 -1
  279. package/src/utils/fontGuard.ts +0 -35
  280. package/src/utils/hover.ts +0 -25
  281. package/src/utils/useColorTransition.ts +0 -40
  282. package/src/utils/usePressScale.ts +0 -75
package/dist/Select.js CHANGED
@@ -2,28 +2,22 @@
2
2
 
3
3
  var React2 = require('react');
4
4
  var reactNative = require('react-native');
5
- var Animated = require('react-native-reanimated');
6
5
  var picker = require('@react-native-picker/picker');
7
6
  var vectorIcons = require('@expo/vector-icons');
8
7
  var reactNativeSizeMatters = require('react-native-size-matters');
8
+ var pressto = require('pressto');
9
9
 
10
10
  function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
11
11
 
12
12
  var React2__default = /*#__PURE__*/_interopDefault(React2);
13
- var Animated__default = /*#__PURE__*/_interopDefault(Animated);
14
13
 
15
- var __require = /* @__PURE__ */ ((x) => typeof require !== "undefined" ? require : typeof Proxy !== "undefined" ? new Proxy(x, {
16
- get: (a, b) => (typeof require !== "undefined" ? require : a)[b]
17
- }) : x)(function(x) {
18
- if (typeof require !== "undefined") return require.apply(this, arguments);
19
- throw Error('Dynamic require of "' + x + '" is not supported');
20
- });
14
+ // src/components/Select/Select.tsx
21
15
  var _haptics = null;
22
- var _hapticsLoaded = false;
16
+ var _loaded = false;
23
17
  async function getHaptics() {
24
18
  if (reactNative.Platform.OS === "web") return null;
25
- if (!_hapticsLoaded) {
26
- _hapticsLoaded = true;
19
+ if (!_loaded) {
20
+ _loaded = true;
27
21
  try {
28
22
  _haptics = await import('expo-haptics');
29
23
  } catch {
@@ -32,158 +26,10 @@ async function getHaptics() {
32
26
  }
33
27
  return _haptics;
34
28
  }
35
- var _pulsar = null;
36
- var _pulsarChecked = false;
37
- var _pulsarAvailable = false;
38
- function isPulsarNativeRegistered() {
39
- try {
40
- const g = globalThis;
41
- if (typeof g.__turboModuleProxy === "function") {
42
- return g.__turboModuleProxy("RNPulsar") != null;
43
- }
44
- return reactNative.NativeModules?.RNPulsar != null;
45
- } catch {
46
- return false;
47
- }
48
- }
49
- function getPulsar() {
50
- if (reactNative.Platform.OS === "web") return null;
51
- if (!_pulsarChecked) {
52
- _pulsarChecked = true;
53
- try {
54
- if (isPulsarNativeRegistered()) {
55
- _pulsar = __require("react-native-pulsar");
56
- _pulsarAvailable = true;
57
- }
58
- } catch {
59
- _pulsar = null;
60
- _pulsarAvailable = false;
61
- }
62
- }
63
- return _pulsarAvailable ? _pulsar : null;
64
- }
65
29
  function selectionAsync() {
66
- if (reactNative.Platform.OS === "web") return;
67
- getHaptics().then((h) => {
68
- if (h) {
69
- h.selectionAsync();
70
- } else {
71
- getPulsar()?.Presets.System.selection();
72
- }
73
- });
74
- }
75
-
76
- // src/theme/colorUtils.ts
77
- function hexToRgb(hex) {
78
- const clean = hex.replace("#", "");
79
- const full = clean.length === 3 ? clean.split("").map((c) => c + c).join("") : clean;
80
- if (full.length !== 6) return null;
81
- return {
82
- r: parseInt(full.slice(0, 2), 16),
83
- g: parseInt(full.slice(2, 4), 16),
84
- b: parseInt(full.slice(4, 6), 16)
85
- };
86
- }
87
- function componentToHex(c) {
88
- return Math.round(Math.max(0, Math.min(255, c))).toString(16).padStart(2, "0");
89
- }
90
- function rgbToHex(r, g, b) {
91
- return `#${componentToHex(r)}${componentToHex(g)}${componentToHex(b)}`;
92
- }
93
- function withAlphaOnWhite(hex, alpha) {
94
- const rgb = hexToRgb(hex);
95
- if (!rgb) return hex;
96
- const r = rgb.r * alpha + 255 * (1 - alpha);
97
- const g = rgb.g * alpha + 255 * (1 - alpha);
98
- const b = rgb.b * alpha + 255 * (1 - alpha);
99
- return rgbToHex(r, g, b);
30
+ getHaptics().then((h) => h?.selectionAsync());
100
31
  }
101
- function withAlphaOnDark(hex, alpha, bgHex = "#0f0f0f") {
102
- const rgb = hexToRgb(hex);
103
- const bg = hexToRgb(bgHex);
104
- if (!rgb || !bg) return hex;
105
- const r = rgb.r * alpha + bg.r * (1 - alpha);
106
- const g = rgb.g * alpha + bg.g * (1 - alpha);
107
- const b = rgb.b * alpha + bg.b * (1 - alpha);
108
- return rgbToHex(r, g, b);
109
- }
110
- function mixWithBackground(fgHex, bgHex, opacity) {
111
- const fg = hexToRgb(fgHex);
112
- const bg = hexToRgb(bgHex);
113
- if (!fg || !bg) return fgHex;
114
- const r = fg.r * opacity + bg.r * (1 - opacity);
115
- const g = fg.g * opacity + bg.g * (1 - opacity);
116
- const b = fg.b * opacity + bg.b * (1 - opacity);
117
- return rgbToHex(r, g, b);
118
- }
119
- function lighten(hex, amount) {
120
- return withAlphaOnWhite(hex, 1 - amount);
121
- }
122
- function darken(hex, amount) {
123
- const rgb = hexToRgb(hex);
124
- if (!rgb) return hex;
125
- return rgbToHex(rgb.r * (1 - amount), rgb.g * (1 - amount), rgb.b * (1 - amount));
126
- }
127
-
128
- // src/theme/colors.ts
129
- var defaultLight = {
130
- background: "#ffffff",
131
- foreground: "#1a1a1a",
132
- card: "#ffffff",
133
- primary: "#1a1a1a",
134
- primaryForeground: "#ffffff",
135
- // AUDIT FIX: brand accent — was undefined; falls back to primary when omitted
136
- accent: "#d4561d",
137
- accentForeground: "#ffffff",
138
- border: "#dddddd",
139
- // AUDIT FIX: was #e53935 (4.22:1 on white — fails AA); #c72828 = 5.59:1 ✓
140
- destructive: "#c72828",
141
- destructiveForeground: "#ffffff",
142
- success: "#1a7a45",
143
- successForeground: "#ffffff",
144
- // AUDIT FIX: was #e67e00 (2.86:1 — severe fail); #9a5200 = 5.86:1 ✓ AAA-near
145
- warning: "#9a5200",
146
- warningForeground: "#ffffff"
147
- };
148
- function deriveColors(t, scheme) {
149
- const dark = scheme === "dark";
150
- const bg = t.background;
151
- const foregroundSubtle = mixWithBackground(t.foreground, bg, 0.7);
152
- const foregroundMuted = mixWithBackground(t.foreground, bg, 0.62);
153
- const surface = dark ? lighten(bg, -0.06) : darken(bg, 0.04);
154
- const surfaceStrong = dark ? lighten(bg, -0.12) : darken(bg, 0.08);
155
- const destructiveTint = dark ? withAlphaOnDark(t.destructive, 0.15, bg) : withAlphaOnWhite(t.destructive, 0.08);
156
- const destructiveBorder = dark ? withAlphaOnDark(t.destructive, 0.45, bg) : withAlphaOnWhite(t.destructive, 0.3);
157
- const successTint = dark ? withAlphaOnDark(t.success, 0.15, bg) : withAlphaOnWhite(t.success, 0.08);
158
- const successBorder = dark ? withAlphaOnDark(t.success, 0.45, bg) : withAlphaOnWhite(t.success, 0.3);
159
- const warningTint = dark ? withAlphaOnDark(t.warning, 0.15, bg) : withAlphaOnWhite(t.warning, 0.08);
160
- const warningBorder = dark ? withAlphaOnDark(t.warning, 0.45, bg) : withAlphaOnWhite(t.warning, 0.3);
161
- return {
162
- ...t,
163
- foregroundSubtle,
164
- foregroundMuted,
165
- surface,
166
- surfaceStrong,
167
- destructiveTint,
168
- destructiveBorder,
169
- successTint,
170
- successBorder,
171
- warningTint,
172
- warningBorder,
173
- overlay: t.overlay ?? "rgba(0,0,0,0.45)",
174
- accentResolved: t.accent ?? t.primary,
175
- accentForegroundResolved: t.accentForeground ?? t.primaryForeground,
176
- ring: t.accent ?? t.primary,
177
- input: t.border,
178
- separator: dark ? lighten(t.border, 0.22) : darken(t.border, 0.16)
179
- };
180
- }
181
-
182
- // src/theme/ThemeProvider.tsx
183
- var ThemeContext = React2.createContext({
184
- colors: deriveColors(defaultLight, "light"),
185
- colorScheme: "light"
186
- });
32
+ var ThemeContext = React2.createContext(void 0);
187
33
  function useTheme() {
188
34
  const context = React2.useContext(ThemeContext);
189
35
  if (!context) {
@@ -195,61 +41,15 @@ var isWeb = reactNative.Platform.OS === "web";
195
41
  var s = isWeb ? (n) => n : reactNativeSizeMatters.scale;
196
42
  var vs = isWeb ? (n) => n : reactNativeSizeMatters.verticalScale;
197
43
  var ms = isWeb ? (n, _factor) => n : reactNativeSizeMatters.moderateScale;
198
- var SPRINGS = {
199
- /** Tight, premium press feel — Buttons, Toggle, Tabs triggers. */
200
- pressIn: { stiffness: 600, damping: 35, mass: 0.8 },
201
- pressOut: { stiffness: 280, damping: 22, mass: 0.8 }};
202
- ({
203
- /** Material-style ease-out — natural deceleration for state changes. */
204
- standard: Animated.Easing.bezier(0.2, 0, 0, 1),
205
- /** Strong ease-out for expanding surfaces (Accordion open). */
206
- expand: Animated.Easing.bezier(0.23, 1, 0.32, 1),
207
- /** Quick ease-in for collapsing. */
208
- collapse: Animated.Easing.in(Animated.Easing.ease)
44
+ var makePressable = (scale2) => pressto.createAnimatedPressable((progress) => {
45
+ "worklet";
46
+ return { transform: [{ scale: 1 - (1 - scale2) * progress }] };
209
47
  });
210
- var PRESS_SCALE = {
211
- button: 0.95};
212
- function useHover() {
213
- const [hovered, setHovered] = React2.useState(false);
214
- const onMouseEnter = React2.useCallback(() => setHovered(true), []);
215
- const onMouseLeave = React2.useCallback(() => setHovered(false), []);
216
- if (reactNative.Platform.OS !== "web") {
217
- return { hovered: false, hoverHandlers: {} };
218
- }
219
- return { hovered, hoverHandlers: { onMouseEnter, onMouseLeave } };
220
- }
221
-
222
- // src/utils/usePressScale.ts
223
- function usePressScale({
224
- pressScale = PRESS_SCALE.button,
225
- hoverScale = 1.02,
226
- pressInSpring = SPRINGS.pressIn,
227
- pressOutSpring = SPRINGS.pressOut,
228
- disabled = false
229
- } = {}) {
230
- const scale2 = Animated.useSharedValue(1);
231
- const { hovered, hoverHandlers } = useHover();
232
- const onPressIn = React2.useCallback(() => {
233
- if (disabled) return;
234
- scale2.value = Animated.withSpring(pressScale, pressInSpring);
235
- }, [disabled, pressScale, pressInSpring, scale2]);
236
- const onPressOut = React2.useCallback(() => {
237
- if (disabled) return;
238
- scale2.value = Animated.withSpring(1, pressOutSpring);
239
- }, [disabled, pressOutSpring, scale2]);
240
- const hoverActive = reactNative.Platform.OS === "web" && hovered && hoverScale !== 1 && !disabled;
241
- const animatedStyle = Animated.useAnimatedStyle(() => ({
242
- transform: [
243
- { scale: scale2.value * (hoverActive ? hoverScale : 1) }
244
- ]
245
- }));
246
- return {
247
- animatedStyle,
248
- onPressIn,
249
- onPressOut,
250
- hoverHandlers
251
- };
252
- }
48
+ var PressableButton = makePressable(0.95);
49
+ makePressable(0.98);
50
+ makePressable(0.97);
51
+ makePressable(0.94);
52
+ makePressable(0.95);
253
53
 
254
54
  // src/components/Select/Select.tsx
255
55
  var isIOS = reactNative.Platform.OS === "ios";
@@ -261,16 +61,13 @@ function Select({
261
61
  onValueChange,
262
62
  placeholder = "Select an option",
263
63
  label,
64
+ hint,
264
65
  error,
265
66
  disabled,
266
67
  style,
267
68
  accessibilityLabel
268
69
  }) {
269
70
  const { colors } = useTheme();
270
- const { animatedStyle, onPressIn, onPressOut } = usePressScale({
271
- pressScale: PRESS_SCALE.button,
272
- disabled
273
- });
274
71
  const [pickerVisible, setPickerVisible] = React2.useState(false);
275
72
  const [pendingValue, setPendingValue] = React2.useState(value);
276
73
  const pickerRef = React2.useRef(null);
@@ -295,20 +92,20 @@ function Select({
295
92
  }
296
93
  setPickerVisible(false);
297
94
  };
298
- return /* @__PURE__ */ React2__default.default.createElement(reactNative.View, { style: [styles.container, style] }, label ? /* @__PURE__ */ React2__default.default.createElement(reactNative.Text, { style: [styles.label, { color: colors.foreground }], allowFontScaling: true }, label) : null, !isWeb2 ? /* @__PURE__ */ React2__default.default.createElement(Animated__default.default.View, { style: [animatedStyle, { opacity: disabled ? 0.45 : 1 }] }, /* @__PURE__ */ React2__default.default.createElement(
299
- reactNative.TouchableOpacity,
95
+ return /* @__PURE__ */ React2__default.default.createElement(reactNative.View, { style: [styles.container, style] }, label ? /* @__PURE__ */ React2__default.default.createElement(reactNative.Text, { style: [styles.label, { color: colors.foreground }], allowFontScaling: true }, label) : null, !isWeb2 ? /* @__PURE__ */ React2__default.default.createElement(
96
+ PressableButton,
300
97
  {
301
98
  style: [
302
99
  styles.trigger,
303
100
  {
304
101
  borderColor: error ? colors.destructive : colors.border,
305
102
  backgroundColor: colors.background
306
- }
103
+ },
104
+ disabled && { opacity: 0.45 }
307
105
  ],
308
106
  onPress: handleOpen,
309
- onPressIn,
310
- onPressOut,
311
- activeOpacity: 1,
107
+ enabled: !disabled,
108
+ rippleColor: "transparent",
312
109
  touchSoundDisabled: true,
313
110
  accessibilityRole: "combobox",
314
111
  accessibilityLabel: accessibilityLabel ?? label,
@@ -328,7 +125,7 @@ function Select({
328
125
  selected?.label ?? placeholder
329
126
  ),
330
127
  /* @__PURE__ */ React2__default.default.createElement(vectorIcons.Entypo, { name: "chevron-down", size: 20, color: colors.foregroundMuted })
331
- )) : null, isIOS ? /* @__PURE__ */ React2__default.default.createElement(
128
+ ) : null, isIOS ? /* @__PURE__ */ React2__default.default.createElement(
332
129
  reactNative.Modal,
333
130
  {
334
131
  visible: pickerVisible,
@@ -412,7 +209,7 @@ function Select({
412
209
  enabled: !o.disabled
413
210
  }
414
211
  ))
415
- ) : null, error ? /* @__PURE__ */ React2__default.default.createElement(reactNative.Text, { style: [styles.helperText, { color: colors.destructive }], allowFontScaling: true }, error) : null);
212
+ ) : null, error ? /* @__PURE__ */ React2__default.default.createElement(reactNative.Text, { style: [styles.helperText, { color: colors.destructive }], allowFontScaling: true }, error) : !error && hint ? /* @__PURE__ */ React2__default.default.createElement(reactNative.Text, { style: [styles.helperText, { color: colors.foregroundMuted }], allowFontScaling: true }, hint) : null);
416
213
  }
417
214
  var styles = reactNative.StyleSheet.create({
418
215
  container: {
@@ -436,9 +233,6 @@ var styles = reactNative.StyleSheet.create({
436
233
  fontSize: ms(15),
437
234
  flex: 1
438
235
  },
439
- chevron: {
440
- marginLeft: s(8)
441
- },
442
236
  helperText: {
443
237
  fontFamily: "Sohne-Regular",
444
238
  fontSize: ms(13)
package/dist/Select.mjs CHANGED
@@ -1,7 +1,6 @@
1
- export { Select } from './chunk-WOEWGSTU.mjs';
2
- import './chunk-YNROWHQJ.mjs';
3
- import './chunk-EJ7ZPXOH.mjs';
4
- import './chunk-DVK4G2GT.mjs';
5
- import './chunk-EMUWGDWC.mjs';
1
+ export { Select } from './chunk-URIH43IJ.mjs';
2
+ import './chunk-IFYMBOEN.mjs';
3
+ import './chunk-ARONDO7M.mjs';
4
+ import './chunk-KSSVIFYR.mjs';
6
5
  import './chunk-2CE3TQVY.mjs';
7
6
  import './chunk-Y6FXYEAI.mjs';
@@ -0,0 +1,27 @@
1
+ import React from 'react';
2
+ import { ViewStyle } from 'react-native';
3
+
4
+ type SelectType = 'radio' | 'checkbox';
5
+ type CardVariant = 'elevated' | 'outlined' | 'filled';
6
+ interface SelectableCardGroupProps {
7
+ type: SelectType;
8
+ value: string | string[];
9
+ onValueChange: (value: string | string[]) => void;
10
+ variant?: CardVariant;
11
+ gap?: number;
12
+ style?: ViewStyle;
13
+ children: React.ReactNode;
14
+ }
15
+ declare function SelectableCardGroup({ type, value, onValueChange, variant, gap, style, children, }: SelectableCardGroupProps): React.JSX.Element;
16
+ interface SelectableCardProps {
17
+ value: string;
18
+ title: string;
19
+ description?: string;
20
+ iconName?: string;
21
+ icon?: React.ReactNode;
22
+ disabled?: boolean;
23
+ style?: ViewStyle;
24
+ }
25
+ declare function SelectableCard({ value, title, description, iconName, icon, disabled, style, }: SelectableCardProps): React.JSX.Element;
26
+
27
+ export { SelectableCard, SelectableCardGroup, type SelectableCardGroupProps, type SelectableCardProps };
@@ -0,0 +1,27 @@
1
+ import React from 'react';
2
+ import { ViewStyle } from 'react-native';
3
+
4
+ type SelectType = 'radio' | 'checkbox';
5
+ type CardVariant = 'elevated' | 'outlined' | 'filled';
6
+ interface SelectableCardGroupProps {
7
+ type: SelectType;
8
+ value: string | string[];
9
+ onValueChange: (value: string | string[]) => void;
10
+ variant?: CardVariant;
11
+ gap?: number;
12
+ style?: ViewStyle;
13
+ children: React.ReactNode;
14
+ }
15
+ declare function SelectableCardGroup({ type, value, onValueChange, variant, gap, style, children, }: SelectableCardGroupProps): React.JSX.Element;
16
+ interface SelectableCardProps {
17
+ value: string;
18
+ title: string;
19
+ description?: string;
20
+ iconName?: string;
21
+ icon?: React.ReactNode;
22
+ disabled?: boolean;
23
+ style?: ViewStyle;
24
+ }
25
+ declare function SelectableCard({ value, title, description, iconName, icon, disabled, style, }: SelectableCardProps): React.JSX.Element;
26
+
27
+ export { SelectableCard, SelectableCardGroup, type SelectableCardGroupProps, type SelectableCardProps };