@coze-arch/cli 0.0.1-alpha.ef8b63 → 0.0.1-alpha.f0fbc7

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 (438) hide show
  1. package/lib/__templates__/expo/README.md +12 -16
  2. package/lib/__templates__/expo/client/app/+not-found.tsx +4 -19
  3. package/lib/__templates__/expo/client/app/_layout.tsx +19 -17
  4. package/lib/__templates__/expo/client/components/Screen.tsx +4 -1
  5. package/lib/__templates__/expo/client/global.css +6 -0
  6. package/lib/__templates__/expo/client/heroui/components/accordion/accordion.animation.ts +178 -0
  7. package/lib/__templates__/expo/client/heroui/components/accordion/accordion.constants.ts +62 -0
  8. package/lib/__templates__/expo/client/heroui/components/accordion/accordion.md +437 -0
  9. package/lib/__templates__/expo/client/heroui/components/accordion/accordion.styles.ts +95 -0
  10. package/lib/__templates__/expo/client/heroui/components/accordion/accordion.tsx +340 -0
  11. package/lib/__templates__/expo/client/heroui/components/accordion/accordion.types.ts +267 -0
  12. package/lib/__templates__/expo/client/heroui/components/accordion/index.ts +17 -0
  13. package/lib/__templates__/expo/client/heroui/components/alert/alert.constants.ts +13 -0
  14. package/lib/__templates__/expo/client/heroui/components/alert/alert.hooks.ts +28 -0
  15. package/lib/__templates__/expo/client/heroui/components/alert/alert.md +263 -0
  16. package/lib/__templates__/expo/client/heroui/components/alert/alert.styles.ts +65 -0
  17. package/lib/__templates__/expo/client/heroui/components/alert/alert.tsx +181 -0
  18. package/lib/__templates__/expo/client/heroui/components/alert/alert.types.ts +99 -0
  19. package/lib/__templates__/expo/client/heroui/components/alert/alert.utils.tsx +25 -0
  20. package/lib/__templates__/expo/client/heroui/components/alert/default-icon.tsx +28 -0
  21. package/lib/__templates__/expo/client/heroui/components/alert/index.ts +15 -0
  22. package/lib/__templates__/expo/client/heroui/components/alert/success-icon.tsx +28 -0
  23. package/lib/__templates__/expo/client/heroui/components/alert/warning-icon.tsx +28 -0
  24. package/lib/__templates__/expo/client/heroui/components/avatar/avatar.animation.ts +123 -0
  25. package/lib/__templates__/expo/client/heroui/components/avatar/avatar.constants.ts +19 -0
  26. package/lib/__templates__/expo/client/heroui/components/avatar/avatar.context.ts +11 -0
  27. package/lib/__templates__/expo/client/heroui/components/avatar/avatar.md +386 -0
  28. package/lib/__templates__/expo/client/heroui/components/avatar/avatar.styles.ts +145 -0
  29. package/lib/__templates__/expo/client/heroui/components/avatar/avatar.tsx +307 -0
  30. package/lib/__templates__/expo/client/heroui/components/avatar/avatar.types.ts +239 -0
  31. package/lib/__templates__/expo/client/heroui/components/avatar/index.ts +13 -0
  32. package/lib/__templates__/expo/client/heroui/components/avatar/person-icon.tsx +23 -0
  33. package/lib/__templates__/expo/client/heroui/components/bottom-sheet/bottom-sheet.animation.ts +42 -0
  34. package/lib/__templates__/expo/client/heroui/components/bottom-sheet/bottom-sheet.constants.ts +13 -0
  35. package/lib/__templates__/expo/client/heroui/components/bottom-sheet/bottom-sheet.md +349 -0
  36. package/lib/__templates__/expo/client/heroui/components/bottom-sheet/bottom-sheet.styles.ts +66 -0
  37. package/lib/__templates__/expo/client/heroui/components/bottom-sheet/bottom-sheet.tsx +351 -0
  38. package/lib/__templates__/expo/client/heroui/components/bottom-sheet/bottom-sheet.types.ts +150 -0
  39. package/lib/__templates__/expo/client/heroui/components/bottom-sheet/index.ts +16 -0
  40. package/lib/__templates__/expo/client/heroui/components/button/button.constants.ts +7 -0
  41. package/lib/__templates__/expo/client/heroui/components/button/button.md +381 -0
  42. package/lib/__templates__/expo/client/heroui/components/button/button.styles.ts +89 -0
  43. package/lib/__templates__/expo/client/heroui/components/button/button.tsx +284 -0
  44. package/lib/__templates__/expo/client/heroui/components/button/button.types.ts +175 -0
  45. package/lib/__templates__/expo/client/heroui/components/button/button.utils.ts +34 -0
  46. package/lib/__templates__/expo/client/heroui/components/button/index.ts +9 -0
  47. package/lib/__templates__/expo/client/heroui/components/card/card.constants.ts +11 -0
  48. package/lib/__templates__/expo/client/heroui/components/card/card.md +186 -0
  49. package/lib/__templates__/expo/client/heroui/components/card/card.styles.ts +35 -0
  50. package/lib/__templates__/expo/client/heroui/components/card/card.tsx +153 -0
  51. package/lib/__templates__/expo/client/heroui/components/card/card.types.ts +77 -0
  52. package/lib/__templates__/expo/client/heroui/components/card/index.ts +10 -0
  53. package/lib/__templates__/expo/client/heroui/components/checkbox/checkbox.animation.ts +202 -0
  54. package/lib/__templates__/expo/client/heroui/components/checkbox/checkbox.constants.ts +6 -0
  55. package/lib/__templates__/expo/client/heroui/components/checkbox/checkbox.md +311 -0
  56. package/lib/__templates__/expo/client/heroui/components/checkbox/checkbox.styles.ts +105 -0
  57. package/lib/__templates__/expo/client/heroui/components/checkbox/checkbox.tsx +251 -0
  58. package/lib/__templates__/expo/client/heroui/components/checkbox/checkbox.types.ts +216 -0
  59. package/lib/__templates__/expo/client/heroui/components/checkbox/index.ts +3 -0
  60. package/lib/__templates__/expo/client/heroui/components/chip/chip.animation.ts +18 -0
  61. package/lib/__templates__/expo/client/heroui/components/chip/chip.constants.ts +7 -0
  62. package/lib/__templates__/expo/client/heroui/components/chip/chip.md +190 -0
  63. package/lib/__templates__/expo/client/heroui/components/chip/chip.styles.ts +234 -0
  64. package/lib/__templates__/expo/client/heroui/components/chip/chip.tsx +125 -0
  65. package/lib/__templates__/expo/client/heroui/components/chip/chip.types.ts +69 -0
  66. package/lib/__templates__/expo/client/heroui/components/chip/index.ts +3 -0
  67. package/lib/__templates__/expo/client/heroui/components/close-button/close-button.constants.ts +6 -0
  68. package/lib/__templates__/expo/client/heroui/components/close-button/close-button.md +109 -0
  69. package/lib/__templates__/expo/client/heroui/components/close-button/close-button.styles.ts +13 -0
  70. package/lib/__templates__/expo/client/heroui/components/close-button/close-button.tsx +57 -0
  71. package/lib/__templates__/expo/client/heroui/components/close-button/close-button.types.ts +30 -0
  72. package/lib/__templates__/expo/client/heroui/components/close-button/index.ts +6 -0
  73. package/lib/__templates__/expo/client/heroui/components/control-field/control-field.animation.ts +18 -0
  74. package/lib/__templates__/expo/client/heroui/components/control-field/control-field.constants.ts +7 -0
  75. package/lib/__templates__/expo/client/heroui/components/control-field/control-field.context.ts +14 -0
  76. package/lib/__templates__/expo/client/heroui/components/control-field/control-field.md +241 -0
  77. package/lib/__templates__/expo/client/heroui/components/control-field/control-field.styles.ts +15 -0
  78. package/lib/__templates__/expo/client/heroui/components/control-field/control-field.tsx +245 -0
  79. package/lib/__templates__/expo/client/heroui/components/control-field/control-field.types.ts +67 -0
  80. package/lib/__templates__/expo/client/heroui/components/control-field/index.ts +6 -0
  81. package/lib/__templates__/expo/client/heroui/components/description/description.animation.ts +53 -0
  82. package/lib/__templates__/expo/client/heroui/components/description/description.constants.ts +30 -0
  83. package/lib/__templates__/expo/client/heroui/components/description/description.md +129 -0
  84. package/lib/__templates__/expo/client/heroui/components/description/description.styles.ts +25 -0
  85. package/lib/__templates__/expo/client/heroui/components/description/description.tsx +81 -0
  86. package/lib/__templates__/expo/client/heroui/components/description/description.types.ts +77 -0
  87. package/lib/__templates__/expo/client/heroui/components/description/index.ts +3 -0
  88. package/lib/__templates__/expo/client/heroui/components/dialog/dialog.animation.ts +9 -0
  89. package/lib/__templates__/expo/client/heroui/components/dialog/dialog.constants.ts +13 -0
  90. package/lib/__templates__/expo/client/heroui/components/dialog/dialog.md +288 -0
  91. package/lib/__templates__/expo/client/heroui/components/dialog/dialog.styles.ts +77 -0
  92. package/lib/__templates__/expo/client/heroui/components/dialog/dialog.tsx +379 -0
  93. package/lib/__templates__/expo/client/heroui/components/dialog/dialog.types.ts +199 -0
  94. package/lib/__templates__/expo/client/heroui/components/dialog/index.ts +12 -0
  95. package/lib/__templates__/expo/client/heroui/components/field-error/field-error.animation.ts +50 -0
  96. package/lib/__templates__/expo/client/heroui/components/field-error/field-error.constants.ts +31 -0
  97. package/lib/__templates__/expo/client/heroui/components/field-error/field-error.md +204 -0
  98. package/lib/__templates__/expo/client/heroui/components/field-error/field-error.styles.ts +23 -0
  99. package/lib/__templates__/expo/client/heroui/components/field-error/field-error.tsx +91 -0
  100. package/lib/__templates__/expo/client/heroui/components/field-error/field-error.types.ts +79 -0
  101. package/lib/__templates__/expo/client/heroui/components/field-error/index.ts +3 -0
  102. package/lib/__templates__/expo/client/heroui/components/input/index.ts +3 -0
  103. package/lib/__templates__/expo/client/heroui/components/input/input.constants.ts +6 -0
  104. package/lib/__templates__/expo/client/heroui/components/input/input.md +193 -0
  105. package/lib/__templates__/expo/client/heroui/components/input/input.styles.ts +51 -0
  106. package/lib/__templates__/expo/client/heroui/components/input/input.tsx +96 -0
  107. package/lib/__templates__/expo/client/heroui/components/input/input.types.ts +44 -0
  108. package/lib/__templates__/expo/client/heroui/components/input-group/index.ts +9 -0
  109. package/lib/__templates__/expo/client/heroui/components/input-group/input-group.animation.ts +14 -0
  110. package/lib/__templates__/expo/client/heroui/components/input-group/input-group.constants.ts +6 -0
  111. package/lib/__templates__/expo/client/heroui/components/input-group/input-group.md +197 -0
  112. package/lib/__templates__/expo/client/heroui/components/input-group/input-group.styles.ts +31 -0
  113. package/lib/__templates__/expo/client/heroui/components/input-group/input-group.tsx +239 -0
  114. package/lib/__templates__/expo/client/heroui/components/input-group/input-group.types.ts +98 -0
  115. package/lib/__templates__/expo/client/heroui/components/input-otp/index.ts +9 -0
  116. package/lib/__templates__/expo/client/heroui/components/input-otp/input-otp.animation.ts +199 -0
  117. package/lib/__templates__/expo/client/heroui/components/input-otp/input-otp.constants.ts +12 -0
  118. package/lib/__templates__/expo/client/heroui/components/input-otp/input-otp.md +376 -0
  119. package/lib/__templates__/expo/client/heroui/components/input-otp/input-otp.styles.ts +68 -0
  120. package/lib/__templates__/expo/client/heroui/components/input-otp/input-otp.tsx +414 -0
  121. package/lib/__templates__/expo/client/heroui/components/input-otp/input-otp.types.ts +275 -0
  122. package/lib/__templates__/expo/client/heroui/components/label/index.ts +3 -0
  123. package/lib/__templates__/expo/client/heroui/components/label/label.animation.ts +18 -0
  124. package/lib/__templates__/expo/client/heroui/components/label/label.constants.ts +7 -0
  125. package/lib/__templates__/expo/client/heroui/components/label/label.md +187 -0
  126. package/lib/__templates__/expo/client/heroui/components/label/label.styles.ts +44 -0
  127. package/lib/__templates__/expo/client/heroui/components/label/label.tsx +172 -0
  128. package/lib/__templates__/expo/client/heroui/components/label/label.types.ts +86 -0
  129. package/lib/__templates__/expo/client/heroui/components/list-group/index.ts +17 -0
  130. package/lib/__templates__/expo/client/heroui/components/list-group/list-group.constants.ts +17 -0
  131. package/lib/__templates__/expo/client/heroui/components/list-group/list-group.md +387 -0
  132. package/lib/__templates__/expo/client/heroui/components/list-group/list-group.styles.ts +40 -0
  133. package/lib/__templates__/expo/client/heroui/components/list-group/list-group.tsx +206 -0
  134. package/lib/__templates__/expo/client/heroui/components/list-group/list-group.types.ts +132 -0
  135. package/lib/__templates__/expo/client/heroui/components/menu/index.ts +38 -0
  136. package/lib/__templates__/expo/client/heroui/components/menu/menu.animation.ts +121 -0
  137. package/lib/__templates__/expo/client/heroui/components/menu/menu.constants.ts +37 -0
  138. package/lib/__templates__/expo/client/heroui/components/menu/menu.md +620 -0
  139. package/lib/__templates__/expo/client/heroui/components/menu/menu.styles.ts +107 -0
  140. package/lib/__templates__/expo/client/heroui/components/menu/menu.tsx +664 -0
  141. package/lib/__templates__/expo/client/heroui/components/menu/menu.types.ts +394 -0
  142. package/lib/__templates__/expo/client/heroui/components/popover/arrow-svg.tsx +180 -0
  143. package/lib/__templates__/expo/client/heroui/components/popover/index.ts +18 -0
  144. package/lib/__templates__/expo/client/heroui/components/popover/popover.animation.ts +9 -0
  145. package/lib/__templates__/expo/client/heroui/components/popover/popover.constants.ts +34 -0
  146. package/lib/__templates__/expo/client/heroui/components/popover/popover.md +508 -0
  147. package/lib/__templates__/expo/client/heroui/components/popover/popover.styles.ts +98 -0
  148. package/lib/__templates__/expo/client/heroui/components/popover/popover.tsx +624 -0
  149. package/lib/__templates__/expo/client/heroui/components/popover/popover.types.ts +290 -0
  150. package/lib/__templates__/expo/client/heroui/components/pressable-feedback/index.ts +4 -0
  151. package/lib/__templates__/expo/client/heroui/components/pressable-feedback/pressable-feedback.animation.ts +449 -0
  152. package/lib/__templates__/expo/client/heroui/components/pressable-feedback/pressable-feedback.constants.ts +12 -0
  153. package/lib/__templates__/expo/client/heroui/components/pressable-feedback/pressable-feedback.md +328 -0
  154. package/lib/__templates__/expo/client/heroui/components/pressable-feedback/pressable-feedback.styles.ts +85 -0
  155. package/lib/__templates__/expo/client/heroui/components/pressable-feedback/pressable-feedback.tsx +330 -0
  156. package/lib/__templates__/expo/client/heroui/components/pressable-feedback/pressable-feedback.types.ts +386 -0
  157. package/lib/__templates__/expo/client/heroui/components/radio/index.ts +9 -0
  158. package/lib/__templates__/expo/client/heroui/components/radio/radio.animation.ts +92 -0
  159. package/lib/__templates__/expo/client/heroui/components/radio/radio.constants.ts +11 -0
  160. package/lib/__templates__/expo/client/heroui/components/radio/radio.md +339 -0
  161. package/lib/__templates__/expo/client/heroui/components/radio/radio.styles.ts +80 -0
  162. package/lib/__templates__/expo/client/heroui/components/radio/radio.tsx +217 -0
  163. package/lib/__templates__/expo/client/heroui/components/radio/radio.types.ts +106 -0
  164. package/lib/__templates__/expo/client/heroui/components/radio-group/index.ts +9 -0
  165. package/lib/__templates__/expo/client/heroui/components/radio-group/radio-group.animation.ts +20 -0
  166. package/lib/__templates__/expo/client/heroui/components/radio-group/radio-group.constants.ts +7 -0
  167. package/lib/__templates__/expo/client/heroui/components/radio-group/radio-group.context.ts +14 -0
  168. package/lib/__templates__/expo/client/heroui/components/radio-group/radio-group.md +273 -0
  169. package/lib/__templates__/expo/client/heroui/components/radio-group/radio-group.styles.ts +15 -0
  170. package/lib/__templates__/expo/client/heroui/components/radio-group/radio-group.tsx +220 -0
  171. package/lib/__templates__/expo/client/heroui/components/radio-group/radio-group.types.ts +64 -0
  172. package/lib/__templates__/expo/client/heroui/components/scroll-shadow/index.ts +7 -0
  173. package/lib/__templates__/expo/client/heroui/components/scroll-shadow/scroll-shadow.animation.ts +132 -0
  174. package/lib/__templates__/expo/client/heroui/components/scroll-shadow/scroll-shadow.constants.ts +21 -0
  175. package/lib/__templates__/expo/client/heroui/components/scroll-shadow/scroll-shadow.md +206 -0
  176. package/lib/__templates__/expo/client/heroui/components/scroll-shadow/scroll-shadow.styles.ts +52 -0
  177. package/lib/__templates__/expo/client/heroui/components/scroll-shadow/scroll-shadow.tsx +262 -0
  178. package/lib/__templates__/expo/client/heroui/components/scroll-shadow/scroll-shadow.types.ts +121 -0
  179. package/lib/__templates__/expo/client/heroui/components/search-field/index.ts +17 -0
  180. package/lib/__templates__/expo/client/heroui/components/search-field/search-field.animation.ts +18 -0
  181. package/lib/__templates__/expo/client/heroui/components/search-field/search-field.constants.ts +10 -0
  182. package/lib/__templates__/expo/client/heroui/components/search-field/search-field.md +231 -0
  183. package/lib/__templates__/expo/client/heroui/components/search-field/search-field.styles.ts +35 -0
  184. package/lib/__templates__/expo/client/heroui/components/search-field/search-field.tsx +253 -0
  185. package/lib/__templates__/expo/client/heroui/components/search-field/search-field.types.ts +160 -0
  186. package/lib/__templates__/expo/client/heroui/components/search-field/search-icon.tsx +37 -0
  187. package/lib/__templates__/expo/client/heroui/components/select/index.ts +28 -0
  188. package/lib/__templates__/expo/client/heroui/components/select/select.animation.ts +92 -0
  189. package/lib/__templates__/expo/client/heroui/components/select/select.constants.ts +53 -0
  190. package/lib/__templates__/expo/client/heroui/components/select/select.md +796 -0
  191. package/lib/__templates__/expo/client/heroui/components/select/select.styles.ts +149 -0
  192. package/lib/__templates__/expo/client/heroui/components/select/select.tsx +828 -0
  193. package/lib/__templates__/expo/client/heroui/components/select/select.types.ts +438 -0
  194. package/lib/__templates__/expo/client/heroui/components/separator/index.ts +7 -0
  195. package/lib/__templates__/expo/client/heroui/components/separator/separator.constants.ts +6 -0
  196. package/lib/__templates__/expo/client/heroui/components/separator/separator.md +106 -0
  197. package/lib/__templates__/expo/client/heroui/components/separator/separator.styles.ts +50 -0
  198. package/lib/__templates__/expo/client/heroui/components/separator/separator.tsx +62 -0
  199. package/lib/__templates__/expo/client/heroui/components/separator/separator.types.ts +40 -0
  200. package/lib/__templates__/expo/client/heroui/components/skeleton/index.ts +7 -0
  201. package/lib/__templates__/expo/client/heroui/components/skeleton/linear-gradient.tsx +45 -0
  202. package/lib/__templates__/expo/client/heroui/components/skeleton/skeleton.animation.ts +350 -0
  203. package/lib/__templates__/expo/client/heroui/components/skeleton/skeleton.constants.ts +39 -0
  204. package/lib/__templates__/expo/client/heroui/components/skeleton/skeleton.md +208 -0
  205. package/lib/__templates__/expo/client/heroui/components/skeleton/skeleton.styles.ts +49 -0
  206. package/lib/__templates__/expo/client/heroui/components/skeleton/skeleton.tsx +183 -0
  207. package/lib/__templates__/expo/client/heroui/components/skeleton/skeleton.types.ts +191 -0
  208. package/lib/__templates__/expo/client/heroui/components/skeleton-group/index.ts +7 -0
  209. package/lib/__templates__/expo/client/heroui/components/skeleton-group/skeleton-group.constants.ts +7 -0
  210. package/lib/__templates__/expo/client/heroui/components/skeleton-group/skeleton-group.md +247 -0
  211. package/lib/__templates__/expo/client/heroui/components/skeleton-group/skeleton-group.styles.ts +10 -0
  212. package/lib/__templates__/expo/client/heroui/components/skeleton-group/skeleton-group.tsx +94 -0
  213. package/lib/__templates__/expo/client/heroui/components/skeleton-group/skeleton-group.types.ts +28 -0
  214. package/lib/__templates__/expo/client/heroui/components/slider/index.ts +23 -0
  215. package/lib/__templates__/expo/client/heroui/components/slider/slider.animation.ts +87 -0
  216. package/lib/__templates__/expo/client/heroui/components/slider/slider.constants.ts +24 -0
  217. package/lib/__templates__/expo/client/heroui/components/slider/slider.md +348 -0
  218. package/lib/__templates__/expo/client/heroui/components/slider/slider.styles.ts +85 -0
  219. package/lib/__templates__/expo/client/heroui/components/slider/slider.tsx +413 -0
  220. package/lib/__templates__/expo/client/heroui/components/slider/slider.types.ts +120 -0
  221. package/lib/__templates__/expo/client/heroui/components/spinner/index.ts +10 -0
  222. package/lib/__templates__/expo/client/heroui/components/spinner/spinner-icon.tsx +49 -0
  223. package/lib/__templates__/expo/client/heroui/components/spinner/spinner.animation.ts +150 -0
  224. package/lib/__templates__/expo/client/heroui/components/spinner/spinner.constants.ts +36 -0
  225. package/lib/__templates__/expo/client/heroui/components/spinner/spinner.md +199 -0
  226. package/lib/__templates__/expo/client/heroui/components/spinner/spinner.styles.ts +44 -0
  227. package/lib/__templates__/expo/client/heroui/components/spinner/spinner.tsx +198 -0
  228. package/lib/__templates__/expo/client/heroui/components/spinner/spinner.types.ts +158 -0
  229. package/lib/__templates__/expo/client/heroui/components/surface/index.ts +3 -0
  230. package/lib/__templates__/expo/client/heroui/components/surface/surface.animation.ts +18 -0
  231. package/lib/__templates__/expo/client/heroui/components/surface/surface.constants.ts +6 -0
  232. package/lib/__templates__/expo/client/heroui/components/surface/surface.md +136 -0
  233. package/lib/__templates__/expo/client/heroui/components/surface/surface.styles.ts +28 -0
  234. package/lib/__templates__/expo/client/heroui/components/surface/surface.tsx +66 -0
  235. package/lib/__templates__/expo/client/heroui/components/surface/surface.types.ts +46 -0
  236. package/lib/__templates__/expo/client/heroui/components/switch/index.ts +3 -0
  237. package/lib/__templates__/expo/client/heroui/components/switch/switch.animation.ts +243 -0
  238. package/lib/__templates__/expo/client/heroui/components/switch/switch.constants.ts +26 -0
  239. package/lib/__templates__/expo/client/heroui/components/switch/switch.md +334 -0
  240. package/lib/__templates__/expo/client/heroui/components/switch/switch.styles.ts +83 -0
  241. package/lib/__templates__/expo/client/heroui/components/switch/switch.tsx +280 -0
  242. package/lib/__templates__/expo/client/heroui/components/switch/switch.types.ts +208 -0
  243. package/lib/__templates__/expo/client/heroui/components/tabs/index.ts +8 -0
  244. package/lib/__templates__/expo/client/heroui/components/tabs/tabs.animation.ts +246 -0
  245. package/lib/__templates__/expo/client/heroui/components/tabs/tabs.constants.ts +17 -0
  246. package/lib/__templates__/expo/client/heroui/components/tabs/tabs.context.ts +28 -0
  247. package/lib/__templates__/expo/client/heroui/components/tabs/tabs.md +565 -0
  248. package/lib/__templates__/expo/client/heroui/components/tabs/tabs.styles.ts +168 -0
  249. package/lib/__templates__/expo/client/heroui/components/tabs/tabs.tsx +445 -0
  250. package/lib/__templates__/expo/client/heroui/components/tabs/tabs.types.ts +341 -0
  251. package/lib/__templates__/expo/client/heroui/components/tag-group/index.ts +15 -0
  252. package/lib/__templates__/expo/client/heroui/components/tag-group/tag-group.animation.ts +17 -0
  253. package/lib/__templates__/expo/client/heroui/components/tag-group/tag-group.constants.ts +10 -0
  254. package/lib/__templates__/expo/client/heroui/components/tag-group/tag-group.md +404 -0
  255. package/lib/__templates__/expo/client/heroui/components/tag-group/tag-group.styles.ts +74 -0
  256. package/lib/__templates__/expo/client/heroui/components/tag-group/tag-group.tsx +325 -0
  257. package/lib/__templates__/expo/client/heroui/components/tag-group/tag-group.types.ts +125 -0
  258. package/lib/__templates__/expo/client/heroui/components/text-area/index.ts +3 -0
  259. package/lib/__templates__/expo/client/heroui/components/text-area/text-area.constants.ts +6 -0
  260. package/lib/__templates__/expo/client/heroui/components/text-area/text-area.md +133 -0
  261. package/lib/__templates__/expo/client/heroui/components/text-area/text-area.styles.ts +10 -0
  262. package/lib/__templates__/expo/client/heroui/components/text-area/text-area.tsx +44 -0
  263. package/lib/__templates__/expo/client/heroui/components/text-area/text-area.types.ts +6 -0
  264. package/lib/__templates__/expo/client/heroui/components/text-field/index.ts +3 -0
  265. package/lib/__templates__/expo/client/heroui/components/text-field/text-field.animation.ts +20 -0
  266. package/lib/__templates__/expo/client/heroui/components/text-field/text-field.constants.ts +6 -0
  267. package/lib/__templates__/expo/client/heroui/components/text-field/text-field.md +256 -0
  268. package/lib/__templates__/expo/client/heroui/components/text-field/text-field.styles.ts +10 -0
  269. package/lib/__templates__/expo/client/heroui/components/text-field/text-field.tsx +82 -0
  270. package/lib/__templates__/expo/client/heroui/components/text-field/text-field.types.ts +56 -0
  271. package/lib/__templates__/expo/client/heroui/components/toast/index.ts +4 -0
  272. package/lib/__templates__/expo/client/heroui/components/toast/toast.animation.ts +381 -0
  273. package/lib/__templates__/expo/client/heroui/components/toast/toast.constants.ts +10 -0
  274. package/lib/__templates__/expo/client/heroui/components/toast/toast.hooks.ts +73 -0
  275. package/lib/__templates__/expo/client/heroui/components/toast/toast.md +420 -0
  276. package/lib/__templates__/expo/client/heroui/components/toast/toast.styles.ts +89 -0
  277. package/lib/__templates__/expo/client/heroui/components/toast/toast.tsx +472 -0
  278. package/lib/__templates__/expo/client/heroui/components/toast/toast.types.ts +320 -0
  279. package/lib/__templates__/expo/client/heroui/docs.md +54 -0
  280. package/lib/__templates__/expo/client/heroui/helpers/external/hooks/index.ts +3 -0
  281. package/lib/__templates__/expo/client/heroui/helpers/external/hooks/use-is-on-surface.ts +8 -0
  282. package/lib/__templates__/expo/client/heroui/helpers/external/hooks/use-theme-color.ts +137 -0
  283. package/lib/__templates__/expo/client/heroui/helpers/external/utils/cn.ts +12 -0
  284. package/lib/__templates__/expo/client/heroui/helpers/external/utils/color-kit/index.ts +2392 -0
  285. package/lib/__templates__/expo/client/heroui/helpers/external/utils/color-kit/types.ts +212 -0
  286. package/lib/__templates__/expo/client/heroui/helpers/external/utils/index.ts +2 -0
  287. package/lib/__templates__/expo/client/heroui/helpers/internal/components/animated-check-icon.tsx +78 -0
  288. package/lib/__templates__/expo/client/heroui/helpers/internal/components/bottom-sheet-content-container.tsx +97 -0
  289. package/lib/__templates__/expo/client/heroui/helpers/internal/components/bottom-sheet-content.tsx +158 -0
  290. package/lib/__templates__/expo/client/heroui/helpers/internal/components/check-icon.tsx +28 -0
  291. package/lib/__templates__/expo/client/heroui/helpers/internal/components/chevron-down-icon.tsx +28 -0
  292. package/lib/__templates__/expo/client/heroui/helpers/internal/components/chevron-right-icon.tsx +29 -0
  293. package/lib/__templates__/expo/client/heroui/helpers/internal/components/close-icon.tsx +29 -0
  294. package/lib/__templates__/expo/client/heroui/helpers/internal/components/full-window-overlay.tsx +48 -0
  295. package/lib/__templates__/expo/client/heroui/helpers/internal/components/hero-text.tsx +71 -0
  296. package/lib/__templates__/expo/client/heroui/helpers/internal/components/index.ts +9 -0
  297. package/lib/__templates__/expo/client/heroui/helpers/internal/contexts/animation-settings-context.ts +19 -0
  298. package/lib/__templates__/expo/client/heroui/helpers/internal/contexts/bottom-sheet-is-dragging-context.ts +11 -0
  299. package/lib/__templates__/expo/client/heroui/helpers/internal/contexts/form-field-context.ts +36 -0
  300. package/lib/__templates__/expo/client/heroui/helpers/internal/contexts/index.ts +3 -0
  301. package/lib/__templates__/expo/client/heroui/helpers/internal/hooks/index.ts +14 -0
  302. package/lib/__templates__/expo/client/heroui/helpers/internal/hooks/use-augmented-ref.ts +32 -0
  303. package/lib/__templates__/expo/client/heroui/helpers/internal/hooks/use-bottom-sheet-aware-handlers.ts +94 -0
  304. package/lib/__templates__/expo/client/heroui/helpers/internal/hooks/use-bottom-sheet-gesture-handlers.ts +52 -0
  305. package/lib/__templates__/expo/client/heroui/helpers/internal/hooks/use-combined-animation-disabled-state.ts +49 -0
  306. package/lib/__templates__/expo/client/heroui/helpers/internal/hooks/use-controllable-state.ts +124 -0
  307. package/lib/__templates__/expo/client/heroui/helpers/internal/hooks/use-dev-info.ts +38 -0
  308. package/lib/__templates__/expo/client/heroui/helpers/internal/hooks/use-keyboard-status.ts +22 -0
  309. package/lib/__templates__/expo/client/heroui/helpers/internal/hooks/use-popup-bottom-sheet-content-animation.ts +67 -0
  310. package/lib/__templates__/expo/client/heroui/helpers/internal/hooks/use-popup-dialog-content-animation.ts +296 -0
  311. package/lib/__templates__/expo/client/heroui/helpers/internal/hooks/use-popup-overlay-animation.ts +91 -0
  312. package/lib/__templates__/expo/client/heroui/helpers/internal/hooks/use-popup-popover-content-animation.ts +199 -0
  313. package/lib/__templates__/expo/client/heroui/helpers/internal/hooks/use-popup-root-animation.ts +26 -0
  314. package/lib/__templates__/expo/client/heroui/helpers/internal/hooks/use-relative-position.ts +353 -0
  315. package/lib/__templates__/expo/client/heroui/helpers/internal/hooks/use-resolved-style-property.ts +118 -0
  316. package/lib/__templates__/expo/client/heroui/helpers/internal/types/animation.ts +131 -0
  317. package/lib/__templates__/expo/client/heroui/helpers/internal/types/bottom-sheet.ts +99 -0
  318. package/lib/__templates__/expo/client/heroui/helpers/internal/types/index.ts +5 -0
  319. package/lib/__templates__/expo/client/heroui/helpers/internal/types/misc.ts +10 -0
  320. package/lib/__templates__/expo/client/heroui/helpers/internal/types/primitives.ts +146 -0
  321. package/lib/__templates__/expo/client/heroui/helpers/internal/types/theme.ts +18 -0
  322. package/lib/__templates__/expo/client/heroui/helpers/internal/utils/animation.ts +266 -0
  323. package/lib/__templates__/expo/client/heroui/helpers/internal/utils/children-to-string.ts +117 -0
  324. package/lib/__templates__/expo/client/heroui/helpers/internal/utils/combine-styles.ts +17 -0
  325. package/lib/__templates__/expo/client/heroui/helpers/internal/utils/create-context.ts +60 -0
  326. package/lib/__templates__/expo/client/heroui/helpers/internal/utils/ease-gradient/create-interpolation.ts +35 -0
  327. package/lib/__templates__/expo/client/heroui/helpers/internal/utils/ease-gradient/index.ts +97 -0
  328. package/lib/__templates__/expo/client/heroui/helpers/internal/utils/get-element-by-display-name.ts +15 -0
  329. package/lib/__templates__/expo/client/heroui/helpers/internal/utils/get-element-with-default.ts +17 -0
  330. package/lib/__templates__/expo/client/heroui/helpers/internal/utils/has-prop.ts +18 -0
  331. package/lib/__templates__/expo/client/heroui/helpers/internal/utils/index.ts +8 -0
  332. package/lib/__templates__/expo/client/heroui/index.tsx +51 -0
  333. package/lib/__templates__/expo/client/heroui/primitives/README.md +27 -0
  334. package/lib/__templates__/expo/client/heroui/primitives/accordion/accordion.tsx +270 -0
  335. package/lib/__templates__/expo/client/heroui/primitives/accordion/accordion.types.ts +117 -0
  336. package/lib/__templates__/expo/client/heroui/primitives/accordion/accordion.utils.ts +12 -0
  337. package/lib/__templates__/expo/client/heroui/primitives/accordion/index.ts +2 -0
  338. package/lib/__templates__/expo/client/heroui/primitives/activity-indicator/activity-indicator.tsx +50 -0
  339. package/lib/__templates__/expo/client/heroui/primitives/activity-indicator/activity-indicator.types.ts +24 -0
  340. package/lib/__templates__/expo/client/heroui/primitives/activity-indicator/index.ts +2 -0
  341. package/lib/__templates__/expo/client/heroui/primitives/alert/alert.tsx +124 -0
  342. package/lib/__templates__/expo/client/heroui/primitives/alert/alert.types.ts +87 -0
  343. package/lib/__templates__/expo/client/heroui/primitives/alert/index.ts +2 -0
  344. package/lib/__templates__/expo/client/heroui/primitives/avatar/avatar.tsx +171 -0
  345. package/lib/__templates__/expo/client/heroui/primitives/avatar/avatar.types.ts +62 -0
  346. package/lib/__templates__/expo/client/heroui/primitives/avatar/avatar.utils.ts +102 -0
  347. package/lib/__templates__/expo/client/heroui/primitives/avatar/index.ts +2 -0
  348. package/lib/__templates__/expo/client/heroui/primitives/bottom-sheet/bottom-sheet.tsx +235 -0
  349. package/lib/__templates__/expo/client/heroui/primitives/bottom-sheet/bottom-sheet.types.ts +127 -0
  350. package/lib/__templates__/expo/client/heroui/primitives/bottom-sheet/index.ts +2 -0
  351. package/lib/__templates__/expo/client/heroui/primitives/checkbox/checkbox.tsx +119 -0
  352. package/lib/__templates__/expo/client/heroui/primitives/checkbox/checkbox.types.ts +37 -0
  353. package/lib/__templates__/expo/client/heroui/primitives/checkbox/index.ts +2 -0
  354. package/lib/__templates__/expo/client/heroui/primitives/dialog/dialog.tsx +274 -0
  355. package/lib/__templates__/expo/client/heroui/primitives/dialog/dialog.types.ts +129 -0
  356. package/lib/__templates__/expo/client/heroui/primitives/dialog/index.ts +2 -0
  357. package/lib/__templates__/expo/client/heroui/primitives/input-otp/index.ts +3 -0
  358. package/lib/__templates__/expo/client/heroui/primitives/input-otp/input-otp.tsx +431 -0
  359. package/lib/__templates__/expo/client/heroui/primitives/input-otp/input-otp.types.ts +169 -0
  360. package/lib/__templates__/expo/client/heroui/primitives/input-otp/input-otp.utils.ts +31 -0
  361. package/lib/__templates__/expo/client/heroui/primitives/label/index.ts +2 -0
  362. package/lib/__templates__/expo/client/heroui/primitives/label/label.tsx +24 -0
  363. package/lib/__templates__/expo/client/heroui/primitives/label/label.types.ts +39 -0
  364. package/lib/__templates__/expo/client/heroui/primitives/menu/index.ts +2 -0
  365. package/lib/__templates__/expo/client/heroui/primitives/menu/menu.tsx +765 -0
  366. package/lib/__templates__/expo/client/heroui/primitives/menu/menu.types.ts +401 -0
  367. package/lib/__templates__/expo/client/heroui/primitives/popover/index.ts +2 -0
  368. package/lib/__templates__/expo/client/heroui/primitives/popover/popover.tsx +382 -0
  369. package/lib/__templates__/expo/client/heroui/primitives/popover/popover.types.ts +201 -0
  370. package/lib/__templates__/expo/client/heroui/primitives/portal/index.ts +1 -0
  371. package/lib/__templates__/expo/client/heroui/primitives/portal/portal.tsx +126 -0
  372. package/lib/__templates__/expo/client/heroui/primitives/radio/index.ts +2 -0
  373. package/lib/__templates__/expo/client/heroui/primitives/radio/radio.tsx +133 -0
  374. package/lib/__templates__/expo/client/heroui/primitives/radio/radio.types.ts +47 -0
  375. package/lib/__templates__/expo/client/heroui/primitives/radio-group/index.ts +2 -0
  376. package/lib/__templates__/expo/client/heroui/primitives/radio-group/radio-group.tsx +114 -0
  377. package/lib/__templates__/expo/client/heroui/primitives/radio-group/radio-group.types.ts +65 -0
  378. package/lib/__templates__/expo/client/heroui/primitives/select/index.ts +2 -0
  379. package/lib/__templates__/expo/client/heroui/primitives/select/select.tsx +705 -0
  380. package/lib/__templates__/expo/client/heroui/primitives/select/select.types.ts +409 -0
  381. package/lib/__templates__/expo/client/heroui/primitives/select/select.utils.ts +35 -0
  382. package/lib/__templates__/expo/client/heroui/primitives/slider/index.ts +3 -0
  383. package/lib/__templates__/expo/client/heroui/primitives/slider/slider.tsx +463 -0
  384. package/lib/__templates__/expo/client/heroui/primitives/slider/slider.types.ts +208 -0
  385. package/lib/__templates__/expo/client/heroui/primitives/slider/slider.utils.ts +93 -0
  386. package/lib/__templates__/expo/client/heroui/primitives/slot/index.ts +1 -0
  387. package/lib/__templates__/expo/client/heroui/primitives/slot/slot.tsx +121 -0
  388. package/lib/__templates__/expo/client/heroui/primitives/slot/types.ts +19 -0
  389. package/lib/__templates__/expo/client/heroui/primitives/slot/utils.ts +96 -0
  390. package/lib/__templates__/expo/client/heroui/primitives/switch/index.ts +2 -0
  391. package/lib/__templates__/expo/client/heroui/primitives/switch/switch.tsx +61 -0
  392. package/lib/__templates__/expo/client/heroui/primitives/switch/switch.types.ts +55 -0
  393. package/lib/__templates__/expo/client/heroui/primitives/tabs/index.ts +2 -0
  394. package/lib/__templates__/expo/client/heroui/primitives/tabs/tabs.tsx +202 -0
  395. package/lib/__templates__/expo/client/heroui/primitives/tabs/tabs.types.ts +77 -0
  396. package/lib/__templates__/expo/client/heroui/primitives/tag-group/index.ts +2 -0
  397. package/lib/__templates__/expo/client/heroui/primitives/tag-group/tag-group.tsx +324 -0
  398. package/lib/__templates__/expo/client/heroui/primitives/tag-group/tag-group.types.ts +119 -0
  399. package/lib/__templates__/expo/client/heroui/primitives/toast/index.ts +2 -0
  400. package/lib/__templates__/expo/client/heroui/primitives/toast/toast.tsx +138 -0
  401. package/lib/__templates__/expo/client/heroui/primitives/toast/toast.types.ts +86 -0
  402. package/lib/__templates__/expo/client/heroui/providers/animation-settings/index.ts +8 -0
  403. package/lib/__templates__/expo/client/heroui/providers/animation-settings/provider.tsx +47 -0
  404. package/lib/__templates__/expo/client/heroui/providers/animation-settings/types.ts +27 -0
  405. package/lib/__templates__/expo/client/heroui/providers/hero-ui-native/index.ts +2 -0
  406. package/lib/__templates__/expo/client/heroui/providers/hero-ui-native/provider.tsx +67 -0
  407. package/lib/__templates__/expo/client/heroui/providers/hero-ui-native/types.ts +114 -0
  408. package/lib/__templates__/expo/client/heroui/providers/hero-ui-native-raw/index.ts +2 -0
  409. package/lib/__templates__/expo/client/heroui/providers/hero-ui-native-raw/provider.tsx +50 -0
  410. package/lib/__templates__/expo/client/heroui/providers/hero-ui-native-raw/types.ts +39 -0
  411. package/lib/__templates__/expo/client/heroui/providers/text-component/index.ts +2 -0
  412. package/lib/__templates__/expo/client/heroui/providers/text-component/provider.tsx +9 -0
  413. package/lib/__templates__/expo/client/heroui/providers/text-component/types.ts +52 -0
  414. package/lib/__templates__/expo/client/heroui/providers/toast/index.ts +3 -0
  415. package/lib/__templates__/expo/client/heroui/providers/toast/insets-container.tsx +87 -0
  416. package/lib/__templates__/expo/client/heroui/providers/toast/provider.tsx +431 -0
  417. package/lib/__templates__/expo/client/heroui/providers/toast/reducer.ts +34 -0
  418. package/lib/__templates__/expo/client/heroui/providers/toast/toast-config.context.ts +27 -0
  419. package/lib/__templates__/expo/client/heroui/providers/toast/toast-item-renderer.tsx +45 -0
  420. package/lib/__templates__/expo/client/heroui/providers/toast/types.ts +373 -0
  421. package/lib/__templates__/expo/client/heroui/styles/index.css +3 -0
  422. package/lib/__templates__/expo/client/heroui/styles/theme.css +112 -0
  423. package/lib/__templates__/expo/client/heroui/styles/utilities.css +8 -0
  424. package/lib/__templates__/expo/client/heroui/styles/variables.css +146 -0
  425. package/lib/__templates__/expo/client/metro.config.js +8 -1
  426. package/lib/__templates__/expo/client/package.json +7 -2
  427. package/lib/__templates__/expo/client/screens/demo/index.tsx +7 -13
  428. package/lib/__templates__/expo/client/theme.css +263 -0
  429. package/lib/__templates__/expo/client/uniwind-types.d.ts +10 -0
  430. package/lib/__templates__/expo/scripts/add-new-page-to-screens.js +107 -0
  431. package/lib/cli.js +1 -1
  432. package/package.json +1 -1
  433. package/lib/__templates__/expo/client/components/ThemedText.tsx +0 -33
  434. package/lib/__templates__/expo/client/components/ThemedView.tsx +0 -37
  435. package/lib/__templates__/expo/client/constants/theme.ts +0 -177
  436. package/lib/__templates__/expo/client/hooks/useColorScheme.tsx +0 -48
  437. package/lib/__templates__/expo/client/hooks/useTheme.ts +0 -33
  438. package/lib/__templates__/expo/client/screens/demo/styles.ts +0 -28
@@ -0,0 +1,449 @@
1
+ import { useCallback } from 'react';
2
+ import type { GestureResponderEvent } from 'react-native';
3
+ import type { SharedValue } from 'react-native-reanimated';
4
+ import {
5
+ Easing,
6
+ interpolate,
7
+ useAnimatedReaction,
8
+ useAnimatedStyle,
9
+ useDerivedValue,
10
+ useSharedValue,
11
+ withTiming,
12
+ } from 'react-native-reanimated';
13
+ import { useUniwind } from 'uniwind';
14
+ import { useAnimationSettings } from '../../helpers/internal/contexts';
15
+ import { useCombinedAnimationDisabledState } from '../../helpers/internal/hooks';
16
+ import {
17
+ createContext,
18
+ getAnimationState,
19
+ getAnimationValueMergedConfig,
20
+ getAnimationValueProperty,
21
+ getIsAnimationDisabledValue,
22
+ getRootAnimationState,
23
+ } from '../../helpers/internal/utils';
24
+ import {
25
+ BASE_RIPPLE_PROGRESS_DURATION,
26
+ BASE_RIPPLE_PROGRESS_DURATION_MIN,
27
+ } from './pressable-feedback.constants';
28
+ import type {
29
+ PressableFeedbackHighlightAnimation,
30
+ PressableFeedbackRippleAnimation,
31
+ PressableFeedbackRootAnimation,
32
+ PressableFeedbackRootAnimationContextValue,
33
+ PressableFeedbackScaleAnimation,
34
+ } from './pressable-feedback.types';
35
+
36
+ const [
37
+ PressableFeedbackRootAnimationProvider,
38
+ usePressableFeedbackRootAnimationContext,
39
+ ] = createContext<PressableFeedbackRootAnimationContextValue>({
40
+ name: 'PressableFeedbackRootAnimationContext',
41
+ });
42
+
43
+ export {
44
+ PressableFeedbackRootAnimationProvider,
45
+ usePressableFeedbackRootAnimationContext,
46
+ };
47
+
48
+ // --------------------------------------------------
49
+
50
+ /**
51
+ * Shared hook that produces an animated scale style from press state and container width.
52
+ * Reused by both the root's built-in scale and the PressableFeedback.Scale compound part.
53
+ *
54
+ * @param options.isPressed - Shared value tracking whether the component is pressed
55
+ * @param options.containerWidth - Shared value tracking the container width (for scale coefficient)
56
+ * @param options.animation - Scale animation configuration (value, timingConfig, ignoreScaleCoefficient)
57
+ * @param options.isAnimationDisabledValue - Final resolved boolean: true when scale should be disabled
58
+ */
59
+ function useScaleAnimatedStyle(options: {
60
+ isPressed: SharedValue<boolean>;
61
+ containerWidth: SharedValue<number>;
62
+ animation?: PressableFeedbackScaleAnimation;
63
+ isAnimationDisabledValue: boolean;
64
+ }) {
65
+ const { isPressed, containerWidth, animation, isAnimationDisabledValue } =
66
+ options;
67
+
68
+ const { animationConfig } = getAnimationState(animation);
69
+
70
+ const scaleValue = getAnimationValueProperty({
71
+ animationValue: animationConfig,
72
+ property: 'value',
73
+ defaultValue: 0.985,
74
+ });
75
+
76
+ const scaleTimingConfig = getAnimationValueMergedConfig({
77
+ animationValue: animationConfig,
78
+ property: 'timingConfig',
79
+ defaultValue: { duration: 300, easing: Easing.out(Easing.ease) },
80
+ });
81
+
82
+ const ignoreScaleCoefficient = getAnimationValueProperty({
83
+ animationValue: animationConfig,
84
+ property: 'ignoreScaleCoefficient',
85
+ defaultValue: false,
86
+ });
87
+
88
+ const adjustedScaleValue = useDerivedValue(() => {
89
+ const coefficient = ignoreScaleCoefficient
90
+ ? 1
91
+ : containerWidth.get() > 0
92
+ ? 300 / containerWidth.get()
93
+ : 1;
94
+ return 1 - (1 - scaleValue) * coefficient;
95
+ });
96
+
97
+ const rScaleStyle = useAnimatedStyle(() => {
98
+ if (isAnimationDisabledValue) {
99
+ return {
100
+ transform: [{ scale: 1 }],
101
+ };
102
+ }
103
+
104
+ return {
105
+ transform: [
106
+ {
107
+ scale: withTiming(
108
+ isPressed.get() ? adjustedScaleValue.get() : 1,
109
+ scaleTimingConfig
110
+ ),
111
+ },
112
+ ],
113
+ };
114
+ });
115
+
116
+ return { rScaleStyle };
117
+ }
118
+
119
+ // --------------------------------------------------
120
+
121
+ /**
122
+ * Animation hook for PressableFeedback root component.
123
+ * Manages press state and container dimensions for child compound parts.
124
+ * Produces the built-in scale animated style by default.
125
+ * Use `animation.scale` to customize, or `animation={false}` to disable.
126
+ */
127
+ export function usePressableFeedbackRootAnimation(options: {
128
+ animation?: PressableFeedbackRootAnimation;
129
+ }) {
130
+ const { animation } = options;
131
+
132
+ const isAllAnimationsDisabled = useCombinedAnimationDisabledState(animation);
133
+
134
+ const isPressed = useSharedValue(false);
135
+ const containerWidth = useSharedValue(0);
136
+ const containerHeight = useSharedValue(0);
137
+
138
+ const animationOnPressIn = useCallback(() => {
139
+ isPressed.set(true);
140
+ }, [isPressed]);
141
+
142
+ const animationOnPressOut = useCallback(() => {
143
+ isPressed.set(false);
144
+ }, [isPressed]);
145
+
146
+ // Extract root-level config to check for built-in scale
147
+ const { animationConfig: rootConfig, isAnimationDisabled: isRootDisabled } =
148
+ getRootAnimationState(animation);
149
+
150
+ const scaleAnimation = rootConfig?.scale;
151
+ const hasRootScale = scaleAnimation !== undefined;
152
+
153
+ // Resolve scale-specific disabled state (root disabled OR scale's own disabled OR cascade)
154
+ const { isAnimationDisabled: isScaleOwnDisabled } =
155
+ getAnimationState(scaleAnimation);
156
+
157
+ const isScaleDisabledValue = getIsAnimationDisabledValue({
158
+ isAnimationDisabled: isRootDisabled || isScaleOwnDisabled,
159
+ isAllAnimationsDisabled,
160
+ });
161
+
162
+ const { rScaleStyle } = useScaleAnimatedStyle({
163
+ isPressed,
164
+ containerWidth,
165
+ animation: scaleAnimation,
166
+ isAnimationDisabledValue: isScaleDisabledValue,
167
+ });
168
+
169
+ return {
170
+ isAllAnimationsDisabled,
171
+ animationOnPressIn,
172
+ animationOnPressOut,
173
+ isPressed,
174
+ containerWidth,
175
+ containerHeight,
176
+ hasRootScale,
177
+ rScaleStyle,
178
+ };
179
+ }
180
+
181
+ // --------------------------------------------------
182
+
183
+ /**
184
+ * Animation hook for PressableFeedback.Scale compound part.
185
+ * Used when applying scale to a specific child element instead of the root.
186
+ * Reads the root's press state via context and delegates to the shared `useScaleAnimatedStyle` hook.
187
+ */
188
+ export function usePressableFeedbackScaleAnimation(options: {
189
+ animation?: PressableFeedbackScaleAnimation;
190
+ }) {
191
+ const { animation } = options;
192
+
193
+ const { isAllAnimationsDisabled } = useAnimationSettings();
194
+
195
+ const { isPressed, containerWidth } =
196
+ usePressableFeedbackRootAnimationContext();
197
+
198
+ const { isAnimationDisabled } = getAnimationState(animation);
199
+
200
+ const isAnimationDisabledValue = getIsAnimationDisabledValue({
201
+ isAnimationDisabled,
202
+ isAllAnimationsDisabled,
203
+ });
204
+
205
+ const { rScaleStyle } = useScaleAnimatedStyle({
206
+ isPressed,
207
+ containerWidth,
208
+ animation,
209
+ isAnimationDisabledValue,
210
+ });
211
+
212
+ return {
213
+ rContainerStyle: rScaleStyle,
214
+ };
215
+ }
216
+
217
+ // --------------------------------------------------
218
+
219
+ /**
220
+ * Animation hook for PressableFeedback highlight overlay
221
+ * Handles opacity and background color animations for the highlight effect
222
+ */
223
+ export function usePressableFeedbackHighlightAnimation(options: {
224
+ animation?: PressableFeedbackHighlightAnimation;
225
+ }) {
226
+ const { animation } = options;
227
+
228
+ const { theme } = useUniwind();
229
+
230
+ const { isAllAnimationsDisabled } = useAnimationSettings();
231
+
232
+ const { isPressed } = usePressableFeedbackRootAnimationContext();
233
+
234
+ const { animationConfig, isAnimationDisabled } = getAnimationState(animation);
235
+
236
+ const isAnimationDisabledValue = getIsAnimationDisabledValue({
237
+ isAnimationDisabled,
238
+ isAllAnimationsDisabled,
239
+ });
240
+
241
+ // Background color
242
+ const defaultColor = theme === 'dark' ? '#d4d4d8' : '#3f3f46';
243
+
244
+ const backgroundColor = getAnimationValueProperty({
245
+ animationValue: animationConfig?.backgroundColor,
246
+ property: 'value',
247
+ defaultValue: defaultColor,
248
+ });
249
+
250
+ // Opacity animation
251
+ const opacityValue = getAnimationValueProperty({
252
+ animationValue: animationConfig?.opacity,
253
+ property: 'value',
254
+ defaultValue: [0, 0.1] as [number, number],
255
+ });
256
+
257
+ const opacityTimingConfig = getAnimationValueMergedConfig({
258
+ animationValue: animationConfig?.opacity,
259
+ property: 'timingConfig',
260
+ defaultValue: { duration: 200 },
261
+ });
262
+
263
+ const rContainerStyle = useAnimatedStyle(() => {
264
+ if (isAnimationDisabledValue) {
265
+ return {};
266
+ }
267
+
268
+ return {
269
+ backgroundColor,
270
+ opacity: withTiming(
271
+ isPressed.get() ? opacityValue[1] : opacityValue[0],
272
+ opacityTimingConfig
273
+ ),
274
+ };
275
+ });
276
+
277
+ return {
278
+ rContainerStyle,
279
+ };
280
+ }
281
+
282
+ // --------------------------------------------------
283
+
284
+ /**
285
+ * Animation hook for PressableFeedback ripple effect
286
+ * Handles ripple circle animation with radial gradient
287
+ */
288
+ export function usePressableFeedbackRippleAnimation(options: {
289
+ animation?: PressableFeedbackRippleAnimation;
290
+ }) {
291
+ const { animation } = options;
292
+
293
+ const { theme } = useUniwind();
294
+
295
+ const { isAllAnimationsDisabled } = useAnimationSettings();
296
+
297
+ const { containerWidth, containerHeight } =
298
+ usePressableFeedbackRootAnimationContext();
299
+
300
+ const pressedCenterX = useSharedValue(0);
301
+ const pressedCenterY = useSharedValue(0);
302
+ const rippleProgress = useSharedValue(0);
303
+ const isPressed = useSharedValue(false);
304
+
305
+ const { animationConfig, isAnimationDisabled } = getAnimationState(animation);
306
+
307
+ const isAnimationDisabledValue = getIsAnimationDisabledValue({
308
+ isAnimationDisabled,
309
+ isAllAnimationsDisabled,
310
+ });
311
+
312
+ const rippleProgressBaseDuration = getAnimationValueProperty({
313
+ animationValue: animationConfig?.progress,
314
+ property: 'baseDuration',
315
+ defaultValue: BASE_RIPPLE_PROGRESS_DURATION,
316
+ });
317
+
318
+ const ignoreDurationCoefficient = getAnimationValueProperty({
319
+ animationValue: animationConfig?.progress,
320
+ property: 'ignoreDurationCoefficient',
321
+ defaultValue: false,
322
+ });
323
+
324
+ const rippleProgressMinBaseDuration = getAnimationValueProperty({
325
+ animationValue: animationConfig?.progress,
326
+ property: 'minBaseDuration',
327
+ defaultValue: BASE_RIPPLE_PROGRESS_DURATION_MIN,
328
+ });
329
+
330
+ // Calculate duration coefficient based on diagonal to maintain consistent ripple speed
331
+ const durationCoefficient = useDerivedValue(() => {
332
+ if (ignoreDurationCoefficient) return 1;
333
+
334
+ const baseDiagonal = 450;
335
+ const currentDiagonal = Math.sqrt(
336
+ containerWidth.get() ** 2 + containerHeight.get() ** 2
337
+ );
338
+ return currentDiagonal > 0 ? currentDiagonal / baseDiagonal : 1;
339
+ });
340
+
341
+ // Touch handlers for ripple
342
+ const animationOnTouchStart = useCallback(
343
+ (event: GestureResponderEvent) => {
344
+ isPressed.set(true);
345
+ pressedCenterX.set(event.nativeEvent.locationX);
346
+ pressedCenterY.set(event.nativeEvent.locationY);
347
+ rippleProgress.set(0);
348
+ },
349
+ [isPressed, pressedCenterX, pressedCenterY, rippleProgress]
350
+ );
351
+
352
+ useAnimatedReaction(
353
+ () => isPressed.get(),
354
+ (isPressedValue) => {
355
+ if (isPressedValue && rippleProgress.get() === 0) {
356
+ const adjustedDuration = Math.min(
357
+ Math.max(
358
+ rippleProgressBaseDuration * durationCoefficient.get(),
359
+ rippleProgressMinBaseDuration
360
+ ),
361
+ rippleProgressBaseDuration * 2
362
+ );
363
+ rippleProgress.set(withTiming(1, { duration: adjustedDuration }));
364
+ }
365
+ }
366
+ );
367
+
368
+ const animationOnTouchEnd = useCallback(() => {
369
+ isPressed.set(false);
370
+ const adjustedDuration = Math.min(
371
+ Math.max(
372
+ rippleProgressBaseDuration * durationCoefficient.get(),
373
+ rippleProgressMinBaseDuration
374
+ ),
375
+ rippleProgressBaseDuration * 2
376
+ );
377
+ rippleProgress.set(withTiming(2, { duration: adjustedDuration }));
378
+ }, [
379
+ isPressed,
380
+ rippleProgress,
381
+ durationCoefficient,
382
+ rippleProgressBaseDuration,
383
+ rippleProgressMinBaseDuration,
384
+ ]);
385
+
386
+ // Background color
387
+ const defaultColor = theme === 'dark' ? '#d4d4d8' : '#3f3f46';
388
+
389
+ const backgroundColor = getAnimationValueProperty({
390
+ animationValue: animationConfig?.backgroundColor,
391
+ property: 'value',
392
+ defaultValue: defaultColor,
393
+ });
394
+
395
+ // Opacity animation
396
+ const opacityValue = getAnimationValueProperty({
397
+ animationValue: animationConfig?.opacity,
398
+ property: 'value',
399
+ defaultValue: [0, 0.1, 0] as [number, number, number],
400
+ });
401
+
402
+ // Scale animation
403
+ const scaleValue = getAnimationValueProperty({
404
+ animationValue: animationConfig?.scale,
405
+ property: 'value',
406
+ defaultValue: [0, 1, 1] as [number, number, number],
407
+ });
408
+
409
+ const rContainerStyle = useAnimatedStyle(() => {
410
+ if (isAnimationDisabledValue) {
411
+ return {};
412
+ }
413
+
414
+ const circleRadius =
415
+ Math.sqrt(containerWidth.get() ** 2 + containerHeight.get() ** 2) * 1.25;
416
+
417
+ const translateX = pressedCenterX.get() - circleRadius;
418
+ const translateY = pressedCenterY.get() - circleRadius;
419
+
420
+ return {
421
+ width: circleRadius * 2,
422
+ height: circleRadius * 2,
423
+ borderRadius: circleRadius,
424
+ opacity: interpolate(
425
+ rippleProgress.get(),
426
+ [0, 1, 2],
427
+ [opacityValue[0], opacityValue[1], opacityValue[2]]
428
+ ),
429
+ transform: [
430
+ { translateX },
431
+ { translateY },
432
+ {
433
+ scale: interpolate(
434
+ rippleProgress.get(),
435
+ [0, 1, 2],
436
+ [scaleValue[0], scaleValue[1], scaleValue[2]]
437
+ ),
438
+ },
439
+ ],
440
+ };
441
+ });
442
+
443
+ return {
444
+ rContainerStyle,
445
+ backgroundColor,
446
+ animationOnTouchStart,
447
+ animationOnTouchEnd,
448
+ };
449
+ }
@@ -0,0 +1,12 @@
1
+ /**
2
+ * Display names for PressableFeedback components
3
+ */
4
+ export const DISPLAY_NAME = {
5
+ ROOT: 'HeroUINative.PressableFeedback.Root',
6
+ SCALE: 'HeroUINative.PressableFeedback.Scale',
7
+ HIGHLIGHT: 'HeroUINative.PressableFeedback.Highlight',
8
+ RIPPLE: 'HeroUINative.PressableFeedback.Ripple',
9
+ } as const;
10
+
11
+ export const BASE_RIPPLE_PROGRESS_DURATION = 1000;
12
+ export const BASE_RIPPLE_PROGRESS_DURATION_MIN = 750;