@codeleap/web 6.2.3 → 6.8.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 (896) hide show
  1. package/dist/components/ActivityIndicator/index.d.ts +6 -2
  2. package/dist/components/ActivityIndicator/index.d.ts.map +1 -0
  3. package/dist/components/ActivityIndicator/styles.d.ts +1 -0
  4. package/dist/components/ActivityIndicator/styles.d.ts.map +1 -0
  5. package/dist/components/ActivityIndicator/types.d.ts +13 -2
  6. package/dist/components/ActivityIndicator/types.d.ts.map +1 -0
  7. package/dist/components/Badge/index.d.ts +8 -1
  8. package/dist/components/Badge/index.d.ts.map +1 -0
  9. package/dist/components/Badge/styles.d.ts +1 -0
  10. package/dist/components/Badge/styles.d.ts.map +1 -0
  11. package/dist/components/Badge/types.d.ts +17 -2
  12. package/dist/components/Badge/types.d.ts.map +1 -0
  13. package/dist/components/Button/index.d.ts +12 -9
  14. package/dist/components/Button/index.d.ts.map +1 -0
  15. package/dist/components/Button/styles.d.ts +7 -4
  16. package/dist/components/Button/styles.d.ts.map +1 -0
  17. package/dist/components/Button/types.d.ts +9 -5
  18. package/dist/components/Button/types.d.ts.map +1 -0
  19. package/dist/components/Calendar/index.d.ts +18 -0
  20. package/dist/components/Calendar/index.d.ts.map +1 -0
  21. package/dist/components/Calendar/styles.d.ts +3 -0
  22. package/dist/components/Calendar/styles.d.ts.map +1 -0
  23. package/dist/components/Calendar/types.d.ts +20 -0
  24. package/dist/components/Calendar/types.d.ts.map +1 -0
  25. package/dist/components/Carousel/index.d.ts +6 -0
  26. package/dist/components/Carousel/index.d.ts.map +1 -0
  27. package/dist/components/Carousel/styles.d.ts +1 -0
  28. package/dist/components/Carousel/styles.d.ts.map +1 -0
  29. package/dist/components/Carousel/types.d.ts +14 -2
  30. package/dist/components/Carousel/types.d.ts.map +1 -0
  31. package/dist/components/Checkbox/index.d.ts +6 -2
  32. package/dist/components/Checkbox/index.d.ts.map +1 -0
  33. package/dist/components/Checkbox/styles.d.ts +4 -6
  34. package/dist/components/Checkbox/styles.d.ts.map +1 -0
  35. package/dist/components/Checkbox/types.d.ts +20 -5
  36. package/dist/components/Checkbox/types.d.ts.map +1 -0
  37. package/dist/components/Collapse/index.d.ts +5 -0
  38. package/dist/components/Collapse/index.d.ts.map +1 -0
  39. package/dist/components/Collapse/styles.d.ts +1 -0
  40. package/dist/components/Collapse/styles.d.ts.map +1 -0
  41. package/dist/components/Collapse/types.d.ts +6 -2
  42. package/dist/components/Collapse/types.d.ts.map +1 -0
  43. package/dist/components/ColorPicker/index.d.ts +6 -0
  44. package/dist/components/ColorPicker/index.d.ts.map +1 -0
  45. package/dist/components/ColorPicker/styles.d.ts +1 -0
  46. package/dist/components/ColorPicker/styles.d.ts.map +1 -0
  47. package/dist/components/ColorPicker/types.d.ts +17 -4
  48. package/dist/components/ColorPicker/types.d.ts.map +1 -0
  49. package/dist/components/CropPicker/hooks.d.ts +49 -0
  50. package/dist/components/CropPicker/hooks.d.ts.map +1 -0
  51. package/dist/components/CropPicker/index.d.ts +8 -2
  52. package/dist/components/CropPicker/index.d.ts.map +1 -0
  53. package/dist/components/CropPicker/styles.d.ts +3 -3
  54. package/dist/components/CropPicker/styles.d.ts.map +1 -0
  55. package/dist/components/CropPicker/types.d.ts +18 -16
  56. package/dist/components/CropPicker/types.d.ts.map +1 -0
  57. package/dist/components/CropPicker/utils.d.ts +20 -0
  58. package/dist/components/CropPicker/utils.d.ts.map +1 -0
  59. package/dist/components/DatePicker/index.d.ts +7 -2
  60. package/dist/components/DatePicker/index.d.ts.map +1 -0
  61. package/dist/components/DatePicker/styles.d.ts +3 -6
  62. package/dist/components/DatePicker/styles.d.ts.map +1 -0
  63. package/dist/components/DatePicker/types.d.ts +46 -50
  64. package/dist/components/DatePicker/types.d.ts.map +1 -0
  65. package/dist/components/Drawer/index.d.ts +7 -1
  66. package/dist/components/Drawer/index.d.ts.map +1 -0
  67. package/dist/components/Drawer/styles.d.ts +2 -2
  68. package/dist/components/Drawer/styles.d.ts.map +1 -0
  69. package/dist/components/Drawer/types.d.ts +8 -17
  70. package/dist/components/Drawer/types.d.ts.map +1 -0
  71. package/dist/components/Dropzone/context.d.ts +17 -0
  72. package/dist/components/Dropzone/context.d.ts.map +1 -0
  73. package/dist/components/Dropzone/elements.d.ts +32 -0
  74. package/dist/components/Dropzone/elements.d.ts.map +1 -0
  75. package/dist/components/Dropzone/index.d.ts +21 -0
  76. package/dist/components/Dropzone/index.d.ts.map +1 -0
  77. package/dist/components/Dropzone/styles.d.ts +3 -2
  78. package/dist/components/Dropzone/styles.d.ts.map +1 -0
  79. package/dist/components/Dropzone/types.d.ts +69 -33
  80. package/dist/components/Dropzone/types.d.ts.map +1 -0
  81. package/dist/components/Dropzone/useDropzone.d.ts +14 -0
  82. package/dist/components/Dropzone/useDropzone.d.ts.map +1 -0
  83. package/dist/components/EmptyPlaceholder/index.d.ts +6 -0
  84. package/dist/components/EmptyPlaceholder/index.d.ts.map +1 -0
  85. package/dist/components/EmptyPlaceholder/styles.d.ts +1 -0
  86. package/dist/components/EmptyPlaceholder/styles.d.ts.map +1 -0
  87. package/dist/components/EmptyPlaceholder/types.d.ts +12 -2
  88. package/dist/components/EmptyPlaceholder/types.d.ts.map +1 -0
  89. package/dist/components/Field/context.d.ts +26 -0
  90. package/dist/components/Field/context.d.ts.map +1 -0
  91. package/dist/components/Field/elements.d.ts +63 -0
  92. package/dist/components/Field/elements.d.ts.map +1 -0
  93. package/dist/components/Field/index.d.ts +66 -0
  94. package/dist/components/Field/index.d.ts.map +1 -0
  95. package/dist/components/Field/styles.d.ts +15 -0
  96. package/dist/components/Field/styles.d.ts.map +1 -0
  97. package/dist/components/Field/types.d.ts +46 -0
  98. package/dist/components/Field/types.d.ts.map +1 -0
  99. package/dist/components/{InputBase/useInputBase.d.ts → Field/useFieldInput.d.ts} +17 -6
  100. package/dist/components/Field/useFieldInput.d.ts.map +1 -0
  101. package/dist/components/FileInput/index.d.ts +6 -0
  102. package/dist/components/FileInput/index.d.ts.map +1 -0
  103. package/dist/components/FileInput/types.d.ts +8 -0
  104. package/dist/components/FileInput/types.d.ts.map +1 -0
  105. package/dist/components/Icon/index.d.ts +8 -1
  106. package/dist/components/Icon/index.d.ts.map +1 -0
  107. package/dist/components/Icon/styles.d.ts +1 -0
  108. package/dist/components/Icon/styles.d.ts.map +1 -0
  109. package/dist/components/Icon/types.d.ts +13 -3
  110. package/dist/components/Icon/types.d.ts.map +1 -0
  111. package/dist/components/List/context.d.ts +44 -0
  112. package/dist/components/List/context.d.ts.map +1 -0
  113. package/dist/components/List/elements.d.ts +29 -0
  114. package/dist/components/List/elements.d.ts.map +1 -0
  115. package/dist/components/List/index.d.ts +18 -2
  116. package/dist/components/List/index.d.ts.map +1 -0
  117. package/dist/components/List/scroll.d.ts +14 -0
  118. package/dist/components/List/scroll.d.ts.map +1 -0
  119. package/dist/components/List/styles.d.ts +2 -1
  120. package/dist/components/List/styles.d.ts.map +1 -0
  121. package/dist/components/List/types.d.ts +73 -13
  122. package/dist/components/List/types.d.ts.map +1 -0
  123. package/dist/components/LoadingOverlay/index.d.ts +7 -0
  124. package/dist/components/LoadingOverlay/index.d.ts.map +1 -0
  125. package/dist/components/LoadingOverlay/styles.d.ts +1 -0
  126. package/dist/components/LoadingOverlay/styles.d.ts.map +1 -0
  127. package/dist/components/LoadingOverlay/types.d.ts +8 -2
  128. package/dist/components/LoadingOverlay/types.d.ts.map +1 -0
  129. package/dist/components/MaskedTextInput/index.d.ts +7 -5
  130. package/dist/components/MaskedTextInput/index.d.ts.map +1 -0
  131. package/dist/components/MaskedTextInput/mask.d.ts +1 -0
  132. package/dist/components/MaskedTextInput/mask.d.ts.map +1 -0
  133. package/dist/components/MaskedTextInput/types.d.ts +12 -0
  134. package/dist/components/MaskedTextInput/types.d.ts.map +1 -0
  135. package/dist/components/Modal/context.d.ts +59 -0
  136. package/dist/components/Modal/context.d.ts.map +1 -0
  137. package/dist/components/Modal/elements.d.ts +38 -0
  138. package/dist/components/Modal/elements.d.ts.map +1 -0
  139. package/dist/components/Modal/index.d.ts +19 -2
  140. package/dist/components/Modal/index.d.ts.map +1 -0
  141. package/dist/components/Modal/styles.d.ts +3 -4
  142. package/dist/components/Modal/styles.d.ts.map +1 -0
  143. package/dist/components/Modal/types.d.ts +21 -36
  144. package/dist/components/Modal/types.d.ts.map +1 -0
  145. package/dist/components/NumberIncrement/index.d.ts +6 -2
  146. package/dist/components/NumberIncrement/index.d.ts.map +1 -0
  147. package/dist/components/NumberIncrement/styles.d.ts +4 -4
  148. package/dist/components/NumberIncrement/styles.d.ts.map +1 -0
  149. package/dist/components/NumberIncrement/types.d.ts +16 -4
  150. package/dist/components/NumberIncrement/types.d.ts.map +1 -0
  151. package/dist/components/NumberIncrement/useNumberIncrement.d.ts +10 -4
  152. package/dist/components/NumberIncrement/useNumberIncrement.d.ts.map +1 -0
  153. package/dist/components/Overlay/index.d.ts +7 -0
  154. package/dist/components/Overlay/index.d.ts.map +1 -0
  155. package/dist/components/Overlay/styles.d.ts +1 -0
  156. package/dist/components/Overlay/styles.d.ts.map +1 -0
  157. package/dist/components/Overlay/types.d.ts +8 -2
  158. package/dist/components/Overlay/types.d.ts.map +1 -0
  159. package/dist/components/PaginationButtons/index.d.ts +6 -0
  160. package/dist/components/PaginationButtons/index.d.ts.map +1 -0
  161. package/dist/components/PaginationButtons/styles.d.ts +1 -0
  162. package/dist/components/PaginationButtons/styles.d.ts.map +1 -0
  163. package/dist/components/PaginationButtons/types.d.ts +12 -2
  164. package/dist/components/PaginationButtons/types.d.ts.map +1 -0
  165. package/dist/components/PaginationIndicator/index.d.ts +6 -1
  166. package/dist/components/PaginationIndicator/index.d.ts.map +1 -0
  167. package/dist/components/PaginationIndicator/styles.d.ts +1 -0
  168. package/dist/components/PaginationIndicator/styles.d.ts.map +1 -0
  169. package/dist/components/PaginationIndicator/types.d.ts +11 -2
  170. package/dist/components/PaginationIndicator/types.d.ts.map +1 -0
  171. package/dist/components/Progress/Bar/Segmented.d.ts +16 -0
  172. package/dist/components/Progress/Bar/Segmented.d.ts.map +1 -0
  173. package/dist/components/Progress/Bar/index.d.ts +14 -0
  174. package/dist/components/Progress/Bar/index.d.ts.map +1 -0
  175. package/dist/components/Progress/Bar/styles.d.ts +3 -1
  176. package/dist/components/Progress/Bar/styles.d.ts.map +1 -0
  177. package/dist/components/Progress/Bar/types.d.ts +36 -6
  178. package/dist/components/Progress/Bar/types.d.ts.map +1 -0
  179. package/dist/components/Progress/Circle/Segmented.d.ts +16 -0
  180. package/dist/components/Progress/Circle/Segmented.d.ts.map +1 -0
  181. package/dist/components/Progress/Circle/index.d.ts +15 -0
  182. package/dist/components/Progress/Circle/index.d.ts.map +1 -0
  183. package/dist/components/Progress/Circle/styles.d.ts +3 -1
  184. package/dist/components/Progress/Circle/styles.d.ts.map +1 -0
  185. package/dist/components/Progress/Circle/types.d.ts +47 -7
  186. package/dist/components/Progress/Circle/types.d.ts.map +1 -0
  187. package/dist/components/Progress/index.d.ts +2 -0
  188. package/dist/components/Progress/index.d.ts.map +1 -0
  189. package/dist/components/Progress/utils.d.ts +1 -0
  190. package/dist/components/Progress/utils.d.ts.map +1 -0
  191. package/dist/components/RadioInput/index.d.ts +6 -2
  192. package/dist/components/RadioInput/index.d.ts.map +1 -0
  193. package/dist/components/RadioInput/styles.d.ts +4 -5
  194. package/dist/components/RadioInput/styles.d.ts.map +1 -0
  195. package/dist/components/RadioInput/types.d.ts +16 -7
  196. package/dist/components/RadioInput/types.d.ts.map +1 -0
  197. package/dist/components/SearchInput/index.d.ts +17 -0
  198. package/dist/components/SearchInput/index.d.ts.map +1 -0
  199. package/dist/components/SectionFilters/index.d.ts +8 -1
  200. package/dist/components/SectionFilters/index.d.ts.map +1 -0
  201. package/dist/components/SectionFilters/styles.d.ts +1 -0
  202. package/dist/components/SectionFilters/styles.d.ts.map +1 -0
  203. package/dist/components/SectionFilters/types.d.ts +28 -5
  204. package/dist/components/SectionFilters/types.d.ts.map +1 -0
  205. package/dist/components/Select/context.d.ts +61 -0
  206. package/dist/components/Select/context.d.ts.map +1 -0
  207. package/dist/components/Select/elements.d.ts +26 -0
  208. package/dist/components/Select/elements.d.ts.map +1 -0
  209. package/dist/components/Select/index.d.ts +71 -3
  210. package/dist/components/Select/index.d.ts.map +1 -0
  211. package/dist/components/Select/styles.d.ts +4 -51
  212. package/dist/components/Select/styles.d.ts.map +1 -0
  213. package/dist/components/Select/types.d.ts +79 -101
  214. package/dist/components/Select/types.d.ts.map +1 -0
  215. package/dist/components/Select/useTriggerWidth.d.ts +8 -0
  216. package/dist/components/Select/useTriggerWidth.d.ts.map +1 -0
  217. package/dist/components/Slider/index.d.ts +6 -2
  218. package/dist/components/Slider/index.d.ts.map +1 -0
  219. package/dist/components/Slider/styles.d.ts +4 -4
  220. package/dist/components/Slider/styles.d.ts.map +1 -0
  221. package/dist/components/Slider/types.d.ts +18 -4
  222. package/dist/components/Slider/types.d.ts.map +1 -0
  223. package/dist/components/Switch/index.d.ts +6 -2
  224. package/dist/components/Switch/index.d.ts.map +1 -0
  225. package/dist/components/Switch/styles.d.ts +4 -6
  226. package/dist/components/Switch/styles.d.ts.map +1 -0
  227. package/dist/components/Switch/types.d.ts +20 -5
  228. package/dist/components/Switch/types.d.ts.map +1 -0
  229. package/dist/components/Tag/index.d.ts +6 -0
  230. package/dist/components/Tag/index.d.ts.map +1 -0
  231. package/dist/components/Tag/styles.d.ts +1 -0
  232. package/dist/components/Tag/styles.d.ts.map +1 -0
  233. package/dist/components/Tag/types.d.ts +15 -2
  234. package/dist/components/Tag/types.d.ts.map +1 -0
  235. package/dist/components/Text/index.d.ts +8 -0
  236. package/dist/components/Text/index.d.ts.map +1 -0
  237. package/dist/components/Text/styles.d.ts +2 -1
  238. package/dist/components/Text/styles.d.ts.map +1 -0
  239. package/dist/components/Text/types.d.ts +18 -2
  240. package/dist/components/Text/types.d.ts.map +1 -0
  241. package/dist/components/TextEditor/index.d.ts +7 -1
  242. package/dist/components/TextEditor/index.d.ts.map +1 -0
  243. package/dist/components/TextEditor/styles.d.ts +1 -0
  244. package/dist/components/TextEditor/styles.d.ts.map +1 -0
  245. package/dist/components/TextEditor/types.d.ts +10 -2
  246. package/dist/components/TextEditor/types.d.ts.map +1 -0
  247. package/dist/components/TextInput/index.d.ts +6 -0
  248. package/dist/components/TextInput/index.d.ts.map +1 -0
  249. package/dist/components/TextInput/styles.d.ts +4 -6
  250. package/dist/components/TextInput/styles.d.ts.map +1 -0
  251. package/dist/components/TextInput/types.d.ts +20 -11
  252. package/dist/components/TextInput/types.d.ts.map +1 -0
  253. package/dist/components/TextInput/useTextInput.d.ts +22 -14
  254. package/dist/components/TextInput/useTextInput.d.ts.map +1 -0
  255. package/dist/components/Tooltip/index.d.ts +6 -0
  256. package/dist/components/Tooltip/index.d.ts.map +1 -0
  257. package/dist/components/Tooltip/styles.d.ts +1 -0
  258. package/dist/components/Tooltip/styles.d.ts.map +1 -0
  259. package/dist/components/Tooltip/types.d.ts +12 -2
  260. package/dist/components/Tooltip/types.d.ts.map +1 -0
  261. package/dist/components/Touchable/index.d.ts +13 -9
  262. package/dist/components/Touchable/index.d.ts.map +1 -0
  263. package/dist/components/Touchable/styles.d.ts +1 -0
  264. package/dist/components/Touchable/styles.d.ts.map +1 -0
  265. package/dist/components/Touchable/types.d.ts +14 -3
  266. package/dist/components/Touchable/types.d.ts.map +1 -0
  267. package/dist/components/View/index.d.ts +13 -9
  268. package/dist/components/View/index.d.ts.map +1 -0
  269. package/dist/components/View/styles.d.ts +1 -0
  270. package/dist/components/View/styles.d.ts.map +1 -0
  271. package/dist/components/View/types.d.ts +15 -2
  272. package/dist/components/View/types.d.ts.map +1 -0
  273. package/dist/components/components.d.ts +3 -4
  274. package/dist/components/components.d.ts.map +1 -0
  275. package/dist/index.d.ts +1 -0
  276. package/dist/index.d.ts.map +1 -0
  277. package/dist/lib/ListMasonry.d.ts +1 -0
  278. package/dist/lib/ListMasonry.d.ts.map +1 -0
  279. package/dist/lib/ThemeVariables.d.ts +10 -0
  280. package/dist/lib/ThemeVariables.d.ts.map +1 -0
  281. package/dist/lib/WebStyleRegistry.d.ts +21 -0
  282. package/dist/lib/WebStyleRegistry.d.ts.map +1 -0
  283. package/dist/lib/hooks/index.d.ts +4 -1
  284. package/dist/lib/hooks/index.d.ts.map +1 -0
  285. package/dist/lib/hooks/useAnimatedStyle.d.ts +8 -0
  286. package/dist/lib/hooks/useAnimatedStyle.d.ts.map +1 -0
  287. package/dist/lib/hooks/useAnimatedVariantStyles.d.ts +7 -0
  288. package/dist/lib/hooks/useAnimatedVariantStyles.d.ts.map +1 -0
  289. package/dist/lib/hooks/useAsyncSelect.d.ts +71 -0
  290. package/dist/lib/hooks/useAsyncSelect.d.ts.map +1 -0
  291. package/dist/lib/hooks/useBreakpointMatch.d.ts +12 -0
  292. package/dist/lib/hooks/useBreakpointMatch.d.ts.map +1 -0
  293. package/dist/lib/hooks/useClick.d.ts +7 -0
  294. package/dist/lib/hooks/useClick.d.ts.map +1 -0
  295. package/dist/lib/hooks/useClickOutside.d.ts +10 -1
  296. package/dist/lib/hooks/useClickOutside.d.ts.map +1 -0
  297. package/dist/lib/hooks/useFileInput.d.ts +8 -2
  298. package/dist/lib/hooks/useFileInput.d.ts.map +1 -0
  299. package/dist/lib/hooks/useIsomorphicEffect.d.ts +5 -0
  300. package/dist/lib/hooks/useIsomorphicEffect.d.ts.map +1 -0
  301. package/dist/lib/hooks/useKeydown.d.ts +9 -0
  302. package/dist/lib/hooks/useKeydown.d.ts.map +1 -0
  303. package/dist/lib/hooks/useListFocus.d.ts +19 -0
  304. package/dist/lib/hooks/useListFocus.d.ts.map +1 -0
  305. package/dist/lib/hooks/useMediaQuery.d.ts +8 -0
  306. package/dist/lib/hooks/useMediaQuery.d.ts.map +1 -0
  307. package/dist/lib/hooks/usePageExitBlocker.d.ts +11 -0
  308. package/dist/lib/hooks/usePageExitBlocker.d.ts.map +1 -0
  309. package/dist/lib/hooks/usePagination.d.ts +20 -5
  310. package/dist/lib/hooks/usePagination.d.ts.map +1 -0
  311. package/dist/lib/hooks/usePopState.d.ts +12 -0
  312. package/dist/lib/hooks/usePopState.d.ts.map +1 -0
  313. package/dist/lib/hooks/usePopoverDismiss.d.ts +20 -0
  314. package/dist/lib/hooks/usePopoverDismiss.d.ts.map +1 -0
  315. package/dist/lib/hooks/useRefresh.d.ts +12 -2
  316. package/dist/lib/hooks/useRefresh.d.ts.map +1 -0
  317. package/dist/lib/hooks/useScrollEffect.d.ts +7 -1
  318. package/dist/lib/hooks/useScrollEffect.d.ts.map +1 -0
  319. package/dist/lib/hooks/useSearchParams.d.ts +14 -0
  320. package/dist/lib/hooks/useSearchParams.d.ts.map +1 -0
  321. package/dist/lib/hooks/useStaticAnimationStyles.d.ts +7 -0
  322. package/dist/lib/hooks/useStaticAnimationStyles.d.ts.map +1 -0
  323. package/dist/lib/hooks/useStylesFor.d.ts +12 -2
  324. package/dist/lib/hooks/useStylesFor.d.ts.map +1 -0
  325. package/dist/lib/hooks/useTouchableEvents.d.ts +19 -0
  326. package/dist/lib/hooks/useTouchableEvents.d.ts.map +1 -0
  327. package/dist/lib/hooks/useWindowFocus.d.ts +6 -0
  328. package/dist/lib/hooks/useWindowFocus.d.ts.map +1 -0
  329. package/dist/lib/hooks/useWindowSize.d.ts +8 -1
  330. package/dist/lib/hooks/useWindowSize.d.ts.map +1 -0
  331. package/dist/lib/index.d.ts +2 -0
  332. package/dist/lib/index.d.ts.map +1 -0
  333. package/dist/lib/tools/index.d.ts +1 -0
  334. package/dist/lib/tools/index.d.ts.map +1 -0
  335. package/dist/lib/tools/localStorage.d.ts +13 -0
  336. package/dist/lib/tools/localStorage.d.ts.map +1 -0
  337. package/dist/lib/tools/mediaQuery.d.ts +10 -3
  338. package/dist/lib/tools/mediaQuery.d.ts.map +1 -0
  339. package/dist/lib/tools/modal.d.ts +12 -0
  340. package/dist/lib/tools/modal.d.ts.map +1 -0
  341. package/dist/lib/utils/attributes.d.ts +15 -0
  342. package/dist/lib/utils/attributes.d.ts.map +1 -0
  343. package/dist/lib/utils/cache.d.ts +5 -2
  344. package/dist/lib/utils/cache.d.ts.map +1 -0
  345. package/dist/lib/utils/index.d.ts +2 -0
  346. package/dist/lib/utils/index.d.ts.map +1 -0
  347. package/dist/lib/utils/pollyfils/scroll.d.ts +7 -0
  348. package/dist/lib/utils/pollyfils/scroll.d.ts.map +1 -0
  349. package/dist/lib/utils/stopPropagation.d.ts +6 -0
  350. package/dist/lib/utils/stopPropagation.d.ts.map +1 -0
  351. package/dist/lib/utils/test.d.ts +6 -0
  352. package/dist/lib/utils/test.d.ts.map +1 -0
  353. package/dist/types/index.d.ts +1 -0
  354. package/dist/types/index.d.ts.map +1 -0
  355. package/dist/types/utility.d.ts +19 -0
  356. package/dist/types/utility.d.ts.map +1 -0
  357. package/package.json +37 -23
  358. package/src/components/ActivityIndicator/index.tsx +8 -12
  359. package/src/components/ActivityIndicator/types.ts +12 -2
  360. package/src/components/Badge/index.tsx +8 -2
  361. package/src/components/Badge/types.ts +16 -2
  362. package/src/components/Button/index.tsx +28 -14
  363. package/src/components/Button/styles.ts +8 -4
  364. package/src/components/Button/types.ts +11 -5
  365. package/src/components/Calendar/index.tsx +121 -0
  366. package/src/components/Calendar/styles.ts +14 -0
  367. package/src/components/Calendar/types.ts +23 -0
  368. package/src/components/Carousel/index.tsx +5 -0
  369. package/src/components/Carousel/types.ts +13 -2
  370. package/src/components/Checkbox/index.tsx +62 -134
  371. package/src/components/Checkbox/styles.ts +3 -15
  372. package/src/components/Checkbox/types.ts +21 -7
  373. package/src/components/Collapse/index.tsx +4 -1
  374. package/src/components/Collapse/types.ts +5 -2
  375. package/src/components/ColorPicker/index.tsx +11 -4
  376. package/src/components/ColorPicker/types.ts +16 -4
  377. package/src/components/CropPicker/hooks.ts +182 -0
  378. package/src/components/CropPicker/index.tsx +44 -81
  379. package/src/components/CropPicker/styles.ts +5 -6
  380. package/src/components/CropPicker/types.ts +15 -17
  381. package/src/components/CropPicker/utils.ts +104 -0
  382. package/src/components/DatePicker/index.tsx +77 -130
  383. package/src/components/DatePicker/styles.ts +2 -22
  384. package/src/components/DatePicker/types.ts +45 -57
  385. package/src/components/Drawer/index.tsx +55 -167
  386. package/src/components/Drawer/styles.ts +4 -7
  387. package/src/components/Drawer/types.ts +9 -21
  388. package/src/components/Dropzone/context.tsx +52 -0
  389. package/src/components/Dropzone/elements.tsx +79 -0
  390. package/src/components/Dropzone/index.tsx +67 -213
  391. package/src/components/Dropzone/styles.ts +7 -12
  392. package/src/components/Dropzone/types.ts +92 -39
  393. package/src/components/Dropzone/useDropzone.ts +18 -0
  394. package/src/components/EmptyPlaceholder/index.tsx +6 -1
  395. package/src/components/EmptyPlaceholder/types.ts +11 -2
  396. package/src/components/Field/context.tsx +66 -0
  397. package/src/components/Field/elements.tsx +159 -0
  398. package/src/components/Field/index.tsx +55 -0
  399. package/src/components/Field/styles.ts +18 -0
  400. package/src/components/Field/types.ts +51 -0
  401. package/src/components/{InputBase/useInputBase.ts → Field/useFieldInput.ts} +13 -10
  402. package/src/components/FileInput/index.tsx +7 -2
  403. package/src/components/FileInput/types.ts +9 -2
  404. package/src/components/Icon/index.tsx +33 -5
  405. package/src/components/Icon/types.ts +14 -5
  406. package/src/components/List/context.tsx +97 -0
  407. package/src/components/List/elements.tsx +173 -0
  408. package/src/components/List/index.tsx +37 -74
  409. package/src/components/List/scroll.ts +83 -0
  410. package/src/components/List/styles.ts +1 -1
  411. package/src/components/List/types.ts +83 -19
  412. package/src/components/LoadingOverlay/index.tsx +6 -0
  413. package/src/components/LoadingOverlay/types.ts +7 -2
  414. package/src/components/MaskedTextInput/index.tsx +6 -4
  415. package/src/components/MaskedTextInput/types.ts +11 -0
  416. package/src/components/Modal/context.tsx +48 -0
  417. package/src/components/Modal/elements.tsx +119 -0
  418. package/src/components/Modal/index.tsx +38 -325
  419. package/src/components/Modal/styles.ts +4 -14
  420. package/src/components/Modal/types.ts +23 -45
  421. package/src/components/NumberIncrement/index.tsx +87 -88
  422. package/src/components/NumberIncrement/styles.ts +3 -8
  423. package/src/components/NumberIncrement/types.ts +16 -4
  424. package/src/components/NumberIncrement/useNumberIncrement.ts +7 -2
  425. package/src/components/Overlay/index.tsx +20 -3
  426. package/src/components/Overlay/types.ts +7 -2
  427. package/src/components/PaginationButtons/index.tsx +5 -0
  428. package/src/components/PaginationButtons/types.ts +11 -2
  429. package/src/components/PaginationIndicator/index.tsx +4 -0
  430. package/src/components/PaginationIndicator/types.ts +11 -3
  431. package/src/components/Progress/Bar/Segmented.tsx +66 -0
  432. package/src/components/Progress/Bar/index.tsx +31 -15
  433. package/src/components/Progress/Bar/styles.ts +6 -1
  434. package/src/components/Progress/Bar/types.ts +39 -7
  435. package/src/components/Progress/Circle/Segmented.tsx +114 -0
  436. package/src/components/Progress/Circle/index.tsx +89 -39
  437. package/src/components/Progress/Circle/styles.ts +7 -1
  438. package/src/components/Progress/Circle/types.ts +49 -7
  439. package/src/components/Progress/index.tsx +1 -0
  440. package/src/components/RadioInput/index.tsx +63 -56
  441. package/src/components/RadioInput/styles.ts +3 -7
  442. package/src/components/RadioInput/types.ts +16 -8
  443. package/src/components/SearchInput/index.tsx +31 -10
  444. package/src/components/SectionFilters/index.tsx +6 -0
  445. package/src/components/SectionFilters/types.ts +27 -5
  446. package/src/components/Select/context.tsx +262 -0
  447. package/src/components/Select/elements.tsx +126 -0
  448. package/src/components/Select/index.tsx +64 -494
  449. package/src/components/Select/styles.ts +7 -169
  450. package/src/components/Select/types.ts +68 -101
  451. package/src/components/Select/useTriggerWidth.ts +29 -0
  452. package/src/components/Slider/index.tsx +118 -116
  453. package/src/components/Slider/styles.ts +4 -9
  454. package/src/components/Slider/types.ts +19 -6
  455. package/src/components/Switch/index.tsx +60 -96
  456. package/src/components/Switch/styles.ts +3 -14
  457. package/src/components/Switch/types.ts +22 -7
  458. package/src/components/Tag/index.tsx +18 -5
  459. package/src/components/Tag/types.ts +15 -2
  460. package/src/components/Text/index.tsx +35 -3
  461. package/src/components/Text/styles.ts +1 -1
  462. package/src/components/Text/types.ts +19 -2
  463. package/src/components/TextEditor/index.tsx +7 -1
  464. package/src/components/TextEditor/types.ts +9 -2
  465. package/src/components/TextInput/index.tsx +94 -109
  466. package/src/components/TextInput/styles.ts +4 -8
  467. package/src/components/TextInput/types.ts +24 -11
  468. package/src/components/TextInput/useTextInput.ts +33 -17
  469. package/src/components/Tooltip/index.tsx +5 -3
  470. package/src/components/Tooltip/types.ts +11 -2
  471. package/src/components/Touchable/index.tsx +23 -25
  472. package/src/components/Touchable/types.ts +31 -19
  473. package/src/components/View/index.tsx +8 -6
  474. package/src/components/View/types.ts +14 -2
  475. package/src/components/components.ts +3 -4
  476. package/src/css.d.ts +10 -0
  477. package/src/lib/ThemeVariables.tsx +38 -0
  478. package/src/lib/WebStyleRegistry.ts +27 -0
  479. package/src/lib/hooks/index.ts +4 -1
  480. package/src/lib/hooks/useAnimatedStyle.ts +7 -0
  481. package/src/lib/hooks/useAnimatedVariantStyles.ts +6 -0
  482. package/src/lib/hooks/useAsyncSelect.ts +126 -0
  483. package/src/lib/hooks/useBreakpointMatch.ts +11 -0
  484. package/src/lib/hooks/useClick.ts +7 -1
  485. package/src/lib/hooks/useClickOutside.ts +8 -0
  486. package/src/lib/hooks/useFileInput.ts +5 -0
  487. package/src/lib/hooks/useIsomorphicEffect.ts +4 -0
  488. package/src/lib/hooks/useKeydown.ts +8 -0
  489. package/src/lib/hooks/useListFocus.ts +59 -0
  490. package/src/lib/hooks/useMediaQuery.ts +7 -0
  491. package/src/lib/hooks/usePageExitBlocker.ts +10 -0
  492. package/src/lib/hooks/usePagination.ts +14 -0
  493. package/src/lib/hooks/usePopState.ts +11 -0
  494. package/src/lib/hooks/usePopoverDismiss.ts +42 -0
  495. package/src/lib/hooks/useRefresh.ts +9 -0
  496. package/src/lib/hooks/useScrollEffect.ts +5 -0
  497. package/src/lib/hooks/useSearchParams.ts +13 -0
  498. package/src/lib/hooks/useStaticAnimationStyles.ts +6 -0
  499. package/src/lib/hooks/useStylesFor.ts +32 -21
  500. package/src/lib/hooks/useTouchableEvents.ts +41 -0
  501. package/src/lib/hooks/useWindowFocus.ts +5 -0
  502. package/src/lib/hooks/useWindowSize.ts +21 -6
  503. package/src/lib/index.ts +1 -0
  504. package/src/lib/tools/localStorage.ts +12 -0
  505. package/src/lib/tools/mediaQuery.ts +9 -3
  506. package/src/lib/tools/modal.ts +11 -0
  507. package/src/lib/utils/attributes.ts +53 -0
  508. package/src/lib/utils/cache.ts +2 -0
  509. package/src/lib/utils/index.ts +1 -0
  510. package/src/lib/utils/pollyfils/scroll.ts +6 -0
  511. package/src/lib/utils/stopPropagation.ts +5 -0
  512. package/src/lib/utils/test.ts +5 -0
  513. package/src/types/utility.ts +18 -2
  514. package/dist/components/ActionIcon/index.d.ts +0 -12
  515. package/dist/components/ActionIcon/index.js +0 -88
  516. package/dist/components/ActionIcon/index.js.map +0 -1
  517. package/dist/components/ActionIcon/styles.d.ts +0 -5
  518. package/dist/components/ActionIcon/styles.js +0 -3
  519. package/dist/components/ActionIcon/styles.js.map +0 -1
  520. package/dist/components/ActionIcon/types.d.ts +0 -11
  521. package/dist/components/ActionIcon/types.js +0 -3
  522. package/dist/components/ActionIcon/types.js.map +0 -1
  523. package/dist/components/ActivityIndicator/index.js +0 -74
  524. package/dist/components/ActivityIndicator/index.js.map +0 -1
  525. package/dist/components/ActivityIndicator/styles.js +0 -3
  526. package/dist/components/ActivityIndicator/styles.js.map +0 -1
  527. package/dist/components/ActivityIndicator/types.js +0 -3
  528. package/dist/components/ActivityIndicator/types.js.map +0 -1
  529. package/dist/components/Badge/index.js +0 -100
  530. package/dist/components/Badge/index.js.map +0 -1
  531. package/dist/components/Badge/styles.js +0 -3
  532. package/dist/components/Badge/styles.js.map +0 -1
  533. package/dist/components/Badge/types.js +0 -3
  534. package/dist/components/Badge/types.js.map +0 -1
  535. package/dist/components/Button/index.js +0 -91
  536. package/dist/components/Button/index.js.map +0 -1
  537. package/dist/components/Button/styles.js +0 -3
  538. package/dist/components/Button/styles.js.map +0 -1
  539. package/dist/components/Button/types.js +0 -3
  540. package/dist/components/Button/types.js.map +0 -1
  541. package/dist/components/Carousel/index.js +0 -168
  542. package/dist/components/Carousel/index.js.map +0 -1
  543. package/dist/components/Carousel/styles.js +0 -3
  544. package/dist/components/Carousel/styles.js.map +0 -1
  545. package/dist/components/Carousel/types.js +0 -3
  546. package/dist/components/Carousel/types.js.map +0 -1
  547. package/dist/components/Checkbox/index.js +0 -129
  548. package/dist/components/Checkbox/index.js.map +0 -1
  549. package/dist/components/Checkbox/styles.js +0 -3
  550. package/dist/components/Checkbox/styles.js.map +0 -1
  551. package/dist/components/Checkbox/types.js +0 -3
  552. package/dist/components/Checkbox/types.js.map +0 -1
  553. package/dist/components/Collapse/index.js +0 -62
  554. package/dist/components/Collapse/index.js.map +0 -1
  555. package/dist/components/Collapse/styles.js +0 -3
  556. package/dist/components/Collapse/styles.js.map +0 -1
  557. package/dist/components/Collapse/types.js +0 -3
  558. package/dist/components/Collapse/types.js.map +0 -1
  559. package/dist/components/ColorPicker/index.js +0 -84
  560. package/dist/components/ColorPicker/index.js.map +0 -1
  561. package/dist/components/ColorPicker/styles.js +0 -3
  562. package/dist/components/ColorPicker/styles.js.map +0 -1
  563. package/dist/components/ColorPicker/types.js +0 -3
  564. package/dist/components/ColorPicker/types.js.map +0 -1
  565. package/dist/components/CropPicker/index.js +0 -79
  566. package/dist/components/CropPicker/index.js.map +0 -1
  567. package/dist/components/CropPicker/styles.js +0 -3
  568. package/dist/components/CropPicker/styles.js.map +0 -1
  569. package/dist/components/CropPicker/types.js +0 -3
  570. package/dist/components/CropPicker/types.js.map +0 -1
  571. package/dist/components/DatePicker/components/DayContent.d.ts +0 -11
  572. package/dist/components/DatePicker/components/DayContent.js +0 -43
  573. package/dist/components/DatePicker/components/DayContent.js.map +0 -1
  574. package/dist/components/DatePicker/components/Header.d.ts +0 -3
  575. package/dist/components/DatePicker/components/Header.js +0 -50
  576. package/dist/components/DatePicker/components/Header.js.map +0 -1
  577. package/dist/components/DatePicker/components/OuterInput.d.ts +0 -2
  578. package/dist/components/DatePicker/components/OuterInput.js +0 -36
  579. package/dist/components/DatePicker/components/OuterInput.js.map +0 -1
  580. package/dist/components/DatePicker/components/YearContent.d.ts +0 -9
  581. package/dist/components/DatePicker/components/YearContent.js +0 -33
  582. package/dist/components/DatePicker/components/YearContent.js.map +0 -1
  583. package/dist/components/DatePicker/components/index.d.ts +0 -4
  584. package/dist/components/DatePicker/components/index.js +0 -21
  585. package/dist/components/DatePicker/components/index.js.map +0 -1
  586. package/dist/components/DatePicker/index.js +0 -102
  587. package/dist/components/DatePicker/index.js.map +0 -1
  588. package/dist/components/DatePicker/styles.js +0 -3
  589. package/dist/components/DatePicker/styles.js.map +0 -1
  590. package/dist/components/DatePicker/types.js +0 -3
  591. package/dist/components/DatePicker/types.js.map +0 -1
  592. package/dist/components/Drawer/index.js +0 -139
  593. package/dist/components/Drawer/index.js.map +0 -1
  594. package/dist/components/Drawer/styles.js +0 -3
  595. package/dist/components/Drawer/styles.js.map +0 -1
  596. package/dist/components/Drawer/types.js +0 -3
  597. package/dist/components/Drawer/types.js.map +0 -1
  598. package/dist/components/Dropzone/index.js +0 -167
  599. package/dist/components/Dropzone/index.js.map +0 -1
  600. package/dist/components/Dropzone/styles.js +0 -3
  601. package/dist/components/Dropzone/styles.js.map +0 -1
  602. package/dist/components/Dropzone/types.js +0 -3
  603. package/dist/components/Dropzone/types.js.map +0 -1
  604. package/dist/components/EmptyPlaceholder/index.js +0 -86
  605. package/dist/components/EmptyPlaceholder/index.js.map +0 -1
  606. package/dist/components/EmptyPlaceholder/styles.js +0 -3
  607. package/dist/components/EmptyPlaceholder/styles.js.map +0 -1
  608. package/dist/components/EmptyPlaceholder/types.js +0 -3
  609. package/dist/components/EmptyPlaceholder/types.js.map +0 -1
  610. package/dist/components/FileInput/index.js +0 -136
  611. package/dist/components/FileInput/index.js.map +0 -1
  612. package/dist/components/FileInput/types.js +0 -3
  613. package/dist/components/FileInput/types.js.map +0 -1
  614. package/dist/components/Icon/index.js +0 -73
  615. package/dist/components/Icon/index.js.map +0 -1
  616. package/dist/components/Icon/styles.js +0 -3
  617. package/dist/components/Icon/styles.js.map +0 -1
  618. package/dist/components/Icon/types.js +0 -3
  619. package/dist/components/Icon/types.js.map +0 -1
  620. package/dist/components/InputBase/index.d.ts +0 -7
  621. package/dist/components/InputBase/index.js +0 -120
  622. package/dist/components/InputBase/index.js.map +0 -1
  623. package/dist/components/InputBase/styles.d.ts +0 -30
  624. package/dist/components/InputBase/styles.js +0 -73
  625. package/dist/components/InputBase/styles.js.map +0 -1
  626. package/dist/components/InputBase/types.d.ts +0 -37
  627. package/dist/components/InputBase/types.js +0 -3
  628. package/dist/components/InputBase/types.js.map +0 -1
  629. package/dist/components/InputBase/useInputBase.js +0 -54
  630. package/dist/components/InputBase/useInputBase.js.map +0 -1
  631. package/dist/components/InputBase/useInputBasePartialStyles.d.ts +0 -2
  632. package/dist/components/InputBase/useInputBasePartialStyles.js +0 -39
  633. package/dist/components/InputBase/useInputBasePartialStyles.js.map +0 -1
  634. package/dist/components/InputBase/utils.d.ts +0 -18
  635. package/dist/components/InputBase/utils.js +0 -63
  636. package/dist/components/InputBase/utils.js.map +0 -1
  637. package/dist/components/List/index.js +0 -138
  638. package/dist/components/List/index.js.map +0 -1
  639. package/dist/components/List/styles.js +0 -3
  640. package/dist/components/List/styles.js.map +0 -1
  641. package/dist/components/List/types.js +0 -3
  642. package/dist/components/List/types.js.map +0 -1
  643. package/dist/components/LoadingOverlay/index.js +0 -63
  644. package/dist/components/LoadingOverlay/index.js.map +0 -1
  645. package/dist/components/LoadingOverlay/styles.js +0 -3
  646. package/dist/components/LoadingOverlay/styles.js.map +0 -1
  647. package/dist/components/LoadingOverlay/types.js +0 -3
  648. package/dist/components/LoadingOverlay/types.js.map +0 -1
  649. package/dist/components/MaskedTextInput/index.js +0 -69
  650. package/dist/components/MaskedTextInput/index.js.map +0 -1
  651. package/dist/components/MaskedTextInput/mask.js +0 -37
  652. package/dist/components/MaskedTextInput/mask.js.map +0 -1
  653. package/dist/components/MaskedTextInput/types.js +0 -3
  654. package/dist/components/MaskedTextInput/types.js.map +0 -1
  655. package/dist/components/Modal/index.js +0 -217
  656. package/dist/components/Modal/index.js.map +0 -1
  657. package/dist/components/Modal/styles.js +0 -3
  658. package/dist/components/Modal/styles.js.map +0 -1
  659. package/dist/components/Modal/types.js +0 -3
  660. package/dist/components/Modal/types.js.map +0 -1
  661. package/dist/components/NumberIncrement/index.js +0 -102
  662. package/dist/components/NumberIncrement/index.js.map +0 -1
  663. package/dist/components/NumberIncrement/styles.js +0 -3
  664. package/dist/components/NumberIncrement/styles.js.map +0 -1
  665. package/dist/components/NumberIncrement/types.js +0 -3
  666. package/dist/components/NumberIncrement/types.js.map +0 -1
  667. package/dist/components/NumberIncrement/useNumberIncrement.js +0 -114
  668. package/dist/components/NumberIncrement/useNumberIncrement.js.map +0 -1
  669. package/dist/components/Overlay/index.js +0 -71
  670. package/dist/components/Overlay/index.js.map +0 -1
  671. package/dist/components/Overlay/styles.js +0 -3
  672. package/dist/components/Overlay/styles.js.map +0 -1
  673. package/dist/components/Overlay/types.js +0 -3
  674. package/dist/components/Overlay/types.js.map +0 -1
  675. package/dist/components/PaginationButtons/index.js +0 -131
  676. package/dist/components/PaginationButtons/index.js.map +0 -1
  677. package/dist/components/PaginationButtons/styles.js +0 -3
  678. package/dist/components/PaginationButtons/styles.js.map +0 -1
  679. package/dist/components/PaginationButtons/types.js +0 -3
  680. package/dist/components/PaginationButtons/types.js.map +0 -1
  681. package/dist/components/PaginationIndicator/index.js +0 -63
  682. package/dist/components/PaginationIndicator/index.js.map +0 -1
  683. package/dist/components/PaginationIndicator/styles.js +0 -3
  684. package/dist/components/PaginationIndicator/styles.js.map +0 -1
  685. package/dist/components/PaginationIndicator/types.js +0 -3
  686. package/dist/components/PaginationIndicator/types.js.map +0 -1
  687. package/dist/components/Progress/Bar/index.js +0 -76
  688. package/dist/components/Progress/Bar/index.js.map +0 -1
  689. package/dist/components/Progress/Bar/styles.js +0 -3
  690. package/dist/components/Progress/Bar/styles.js.map +0 -1
  691. package/dist/components/Progress/Bar/types.js +0 -3
  692. package/dist/components/Progress/Bar/types.js.map +0 -1
  693. package/dist/components/Progress/Circle/index.js +0 -82
  694. package/dist/components/Progress/Circle/index.js.map +0 -1
  695. package/dist/components/Progress/Circle/styles.js +0 -3
  696. package/dist/components/Progress/Circle/styles.js.map +0 -1
  697. package/dist/components/Progress/Circle/types.js +0 -3
  698. package/dist/components/Progress/Circle/types.js.map +0 -1
  699. package/dist/components/Progress/index.js +0 -19
  700. package/dist/components/Progress/index.js.map +0 -1
  701. package/dist/components/Progress/utils.js +0 -7
  702. package/dist/components/Progress/utils.js.map +0 -1
  703. package/dist/components/RadioInput/index.js +0 -83
  704. package/dist/components/RadioInput/index.js.map +0 -1
  705. package/dist/components/RadioInput/styles.js +0 -3
  706. package/dist/components/RadioInput/styles.js.map +0 -1
  707. package/dist/components/RadioInput/types.js +0 -3
  708. package/dist/components/RadioInput/types.js.map +0 -1
  709. package/dist/components/SearchInput/index.js +0 -101
  710. package/dist/components/SearchInput/index.js.map +0 -1
  711. package/dist/components/SectionFilters/index.js +0 -179
  712. package/dist/components/SectionFilters/index.js.map +0 -1
  713. package/dist/components/SectionFilters/styles.js +0 -3
  714. package/dist/components/SectionFilters/styles.js.map +0 -1
  715. package/dist/components/SectionFilters/types.js +0 -3
  716. package/dist/components/SectionFilters/types.js.map +0 -1
  717. package/dist/components/SegmentedControl/index.d.ts +0 -12
  718. package/dist/components/SegmentedControl/index.js +0 -149
  719. package/dist/components/SegmentedControl/index.js.map +0 -1
  720. package/dist/components/SegmentedControl/styles.d.ts +0 -4
  721. package/dist/components/SegmentedControl/styles.js +0 -3
  722. package/dist/components/SegmentedControl/styles.js.map +0 -1
  723. package/dist/components/SegmentedControl/types.d.ts +0 -39
  724. package/dist/components/SegmentedControl/types.js +0 -3
  725. package/dist/components/SegmentedControl/types.js.map +0 -1
  726. package/dist/components/Select/index.js +0 -383
  727. package/dist/components/Select/index.js.map +0 -1
  728. package/dist/components/Select/styles.js +0 -96
  729. package/dist/components/Select/styles.js.map +0 -1
  730. package/dist/components/Select/types.js +0 -3
  731. package/dist/components/Select/types.js.map +0 -1
  732. package/dist/components/Slider/index.js +0 -193
  733. package/dist/components/Slider/index.js.map +0 -1
  734. package/dist/components/Slider/styles.js +0 -3
  735. package/dist/components/Slider/styles.js.map +0 -1
  736. package/dist/components/Slider/types.js +0 -3
  737. package/dist/components/Slider/types.js.map +0 -1
  738. package/dist/components/Switch/index.js +0 -108
  739. package/dist/components/Switch/index.js.map +0 -1
  740. package/dist/components/Switch/styles.js +0 -3
  741. package/dist/components/Switch/styles.js.map +0 -1
  742. package/dist/components/Switch/types.js +0 -3
  743. package/dist/components/Switch/types.js.map +0 -1
  744. package/dist/components/Tag/index.js +0 -86
  745. package/dist/components/Tag/index.js.map +0 -1
  746. package/dist/components/Tag/styles.js +0 -3
  747. package/dist/components/Tag/styles.js.map +0 -1
  748. package/dist/components/Tag/types.js +0 -3
  749. package/dist/components/Tag/types.js.map +0 -1
  750. package/dist/components/Text/index.js +0 -102
  751. package/dist/components/Text/index.js.map +0 -1
  752. package/dist/components/Text/styles.js +0 -3
  753. package/dist/components/Text/styles.js.map +0 -1
  754. package/dist/components/Text/types.js +0 -3
  755. package/dist/components/Text/types.js.map +0 -1
  756. package/dist/components/TextEditor/index.js +0 -114
  757. package/dist/components/TextEditor/index.js.map +0 -1
  758. package/dist/components/TextEditor/styles.js +0 -3
  759. package/dist/components/TextEditor/styles.js.map +0 -1
  760. package/dist/components/TextEditor/types.js +0 -3
  761. package/dist/components/TextEditor/types.js.map +0 -1
  762. package/dist/components/TextInput/index.js +0 -141
  763. package/dist/components/TextInput/index.js.map +0 -1
  764. package/dist/components/TextInput/styles.js +0 -3
  765. package/dist/components/TextInput/styles.js.map +0 -1
  766. package/dist/components/TextInput/types.js +0 -3
  767. package/dist/components/TextInput/types.js.map +0 -1
  768. package/dist/components/TextInput/useTextInput.js +0 -65
  769. package/dist/components/TextInput/useTextInput.js.map +0 -1
  770. package/dist/components/Tooltip/index.js +0 -134
  771. package/dist/components/Tooltip/index.js.map +0 -1
  772. package/dist/components/Tooltip/styles.js +0 -3
  773. package/dist/components/Tooltip/styles.js.map +0 -1
  774. package/dist/components/Tooltip/types.js +0 -3
  775. package/dist/components/Tooltip/types.js.map +0 -1
  776. package/dist/components/Touchable/index.js +0 -125
  777. package/dist/components/Touchable/index.js.map +0 -1
  778. package/dist/components/Touchable/styles.js +0 -3
  779. package/dist/components/Touchable/styles.js.map +0 -1
  780. package/dist/components/Touchable/types.js +0 -3
  781. package/dist/components/Touchable/types.js.map +0 -1
  782. package/dist/components/View/index.js +0 -74
  783. package/dist/components/View/index.js.map +0 -1
  784. package/dist/components/View/styles.js +0 -3
  785. package/dist/components/View/styles.js.map +0 -1
  786. package/dist/components/View/types.js +0 -3
  787. package/dist/components/View/types.js.map +0 -1
  788. package/dist/components/VirtualList/context.d.ts +0 -3
  789. package/dist/components/VirtualList/context.js +0 -93
  790. package/dist/components/VirtualList/context.js.map +0 -1
  791. package/dist/components/VirtualList/index.d.ts +0 -5
  792. package/dist/components/VirtualList/index.js +0 -14
  793. package/dist/components/VirtualList/index.js.map +0 -1
  794. package/dist/components/VirtualList/list.d.ts +0 -3
  795. package/dist/components/VirtualList/list.js +0 -102
  796. package/dist/components/VirtualList/list.js.map +0 -1
  797. package/dist/components/VirtualList/types.d.ts +0 -33
  798. package/dist/components/VirtualList/types.js +0 -3
  799. package/dist/components/VirtualList/types.js.map +0 -1
  800. package/dist/components/components.js +0 -60
  801. package/dist/components/components.js.map +0 -1
  802. package/dist/index.js +0 -21
  803. package/dist/index.js.map +0 -1
  804. package/dist/lib/ListMasonry.js +0 -103
  805. package/dist/lib/ListMasonry.js.map +0 -1
  806. package/dist/lib/WebStyleRegistry.js +0 -70
  807. package/dist/lib/WebStyleRegistry.js.map +0 -1
  808. package/dist/lib/hooks/index.js +0 -37
  809. package/dist/lib/hooks/index.js.map +0 -1
  810. package/dist/lib/hooks/useAnimatedStyle.js +0 -20
  811. package/dist/lib/hooks/useAnimatedStyle.js.map +0 -1
  812. package/dist/lib/hooks/useAnimatedVariantStyles.js +0 -17
  813. package/dist/lib/hooks/useAnimatedVariantStyles.js.map +0 -1
  814. package/dist/lib/hooks/useBreakpointMatch.js +0 -124
  815. package/dist/lib/hooks/useBreakpointMatch.js.map +0 -1
  816. package/dist/lib/hooks/useClick.js +0 -36
  817. package/dist/lib/hooks/useClick.js.map +0 -1
  818. package/dist/lib/hooks/useClickOutside.js +0 -27
  819. package/dist/lib/hooks/useClickOutside.js.map +0 -1
  820. package/dist/lib/hooks/useCropPicker.d.ts +0 -36
  821. package/dist/lib/hooks/useCropPicker.js +0 -216
  822. package/dist/lib/hooks/useCropPicker.js.map +0 -1
  823. package/dist/lib/hooks/useFileInput.js +0 -17
  824. package/dist/lib/hooks/useFileInput.js.map +0 -1
  825. package/dist/lib/hooks/useIsomorphicEffect.js +0 -6
  826. package/dist/lib/hooks/useIsomorphicEffect.js.map +0 -1
  827. package/dist/lib/hooks/useKeydown.js +0 -37
  828. package/dist/lib/hooks/useKeydown.js.map +0 -1
  829. package/dist/lib/hooks/useMediaQuery.js +0 -21
  830. package/dist/lib/hooks/useMediaQuery.js.map +0 -1
  831. package/dist/lib/hooks/usePageExitBlocker.js +0 -41
  832. package/dist/lib/hooks/usePageExitBlocker.js.map +0 -1
  833. package/dist/lib/hooks/usePagination.js +0 -82
  834. package/dist/lib/hooks/usePagination.js.map +0 -1
  835. package/dist/lib/hooks/usePopState.js +0 -24
  836. package/dist/lib/hooks/usePopState.js.map +0 -1
  837. package/dist/lib/hooks/useRefresh.js +0 -115
  838. package/dist/lib/hooks/useRefresh.js.map +0 -1
  839. package/dist/lib/hooks/useScrollEffect.js +0 -27
  840. package/dist/lib/hooks/useScrollEffect.js.map +0 -1
  841. package/dist/lib/hooks/useSearchParams.js +0 -55
  842. package/dist/lib/hooks/useSearchParams.js.map +0 -1
  843. package/dist/lib/hooks/useStaticAnimationStyles.js +0 -24
  844. package/dist/lib/hooks/useStaticAnimationStyles.js.map +0 -1
  845. package/dist/lib/hooks/useStylesFor.js +0 -41
  846. package/dist/lib/hooks/useStylesFor.js.map +0 -1
  847. package/dist/lib/hooks/useWindowFocus.js +0 -31
  848. package/dist/lib/hooks/useWindowFocus.js.map +0 -1
  849. package/dist/lib/hooks/useWindowSize.js +0 -19
  850. package/dist/lib/hooks/useWindowSize.js.map +0 -1
  851. package/dist/lib/index.js +0 -22
  852. package/dist/lib/index.js.map +0 -1
  853. package/dist/lib/tools/index.js +0 -20
  854. package/dist/lib/tools/index.js.map +0 -1
  855. package/dist/lib/tools/localStorage.js +0 -158
  856. package/dist/lib/tools/localStorage.js.map +0 -1
  857. package/dist/lib/tools/mediaQuery.js +0 -34
  858. package/dist/lib/tools/mediaQuery.js.map +0 -1
  859. package/dist/lib/tools/modal.js +0 -62
  860. package/dist/lib/tools/modal.js.map +0 -1
  861. package/dist/lib/utils/cache.js +0 -15
  862. package/dist/lib/utils/cache.js.map +0 -1
  863. package/dist/lib/utils/index.js +0 -21
  864. package/dist/lib/utils/index.js.map +0 -1
  865. package/dist/lib/utils/pollyfils/scroll.js +0 -66
  866. package/dist/lib/utils/pollyfils/scroll.js.map +0 -1
  867. package/dist/lib/utils/stopPropagation.js +0 -19
  868. package/dist/lib/utils/stopPropagation.js.map +0 -1
  869. package/dist/lib/utils/test.js +0 -13
  870. package/dist/lib/utils/test.js.map +0 -1
  871. package/dist/types/index.js +0 -18
  872. package/dist/types/index.js.map +0 -1
  873. package/dist/types/utility.js +0 -3
  874. package/dist/types/utility.js.map +0 -1
  875. package/package.json.bak +0 -65
  876. package/src/components/ActionIcon/index.tsx +0 -93
  877. package/src/components/ActionIcon/styles.ts +0 -8
  878. package/src/components/ActionIcon/types.ts +0 -15
  879. package/src/components/DatePicker/components/DayContent.tsx +0 -52
  880. package/src/components/DatePicker/components/Header.tsx +0 -79
  881. package/src/components/DatePicker/components/OuterInput.tsx +0 -17
  882. package/src/components/DatePicker/components/YearContent.tsx +0 -39
  883. package/src/components/DatePicker/components/index.tsx +0 -4
  884. package/src/components/InputBase/index.tsx +0 -138
  885. package/src/components/InputBase/styles.ts +0 -109
  886. package/src/components/InputBase/types.ts +0 -42
  887. package/src/components/InputBase/useInputBasePartialStyles.ts +0 -37
  888. package/src/components/InputBase/utils.ts +0 -84
  889. package/src/components/SegmentedControl/index.tsx +0 -223
  890. package/src/components/SegmentedControl/styles.ts +0 -12
  891. package/src/components/SegmentedControl/types.ts +0 -44
  892. package/src/components/VirtualList/context.tsx +0 -93
  893. package/src/components/VirtualList/index.tsx +0 -11
  894. package/src/components/VirtualList/list.tsx +0 -85
  895. package/src/components/VirtualList/types.ts +0 -38
  896. package/src/lib/hooks/useCropPicker.ts +0 -192
@@ -1,16 +1,4 @@
1
- import { InputBaseParts, InputBaseStates } from '../InputBase'
1
+ import { FieldParts } from '../Field'
2
2
 
3
- type AnimatableParts = 'checkmarkWrapper' | 'box'
4
-
5
- export type CheckboxParts = InputBaseParts | AnimatableParts | 'checkmark'
6
-
7
- export type CheckboxAnimationStates = 'checked' | 'unchecked' | 'disabled-checked' | 'disabled-unchecked'
8
-
9
- export type CheckboxStates = InputBaseStates
10
-
11
- export type CheckboxComposition =
12
- | CheckboxParts
13
- | `${CheckboxParts}:${CheckboxStates}`
14
- | `${AnimatableParts}:transition`
15
- | `${AnimatableParts}:${CheckboxAnimationStates}`
16
- | '__props'
3
+ type CheckboxParts = FieldParts | 'box' | 'checkmarkWrapper' | 'checkmark'
4
+ export type CheckboxComposition = CheckboxParts
@@ -1,17 +1,31 @@
1
1
  import { CheckboxComposition } from './styles'
2
- import { InputBaseProps } from '../InputBase'
3
- import { ComponentCommonProps } from '../../types'
4
- import { AppIcon, StyledProp } from '@codeleap/styles'
2
+ import { FieldProps } from '../Field'
3
+ import { FieldStateContext } from '../Field/styles'
4
+ import { AppIcon, ICSS, StyleProp } from '@codeleap/styles'
5
5
  import { BooleanField } from '@codeleap/form'
6
6
 
7
+ export interface CheckboxStyleDef {
8
+ __internal: Record<CheckboxComposition, ICSS>
9
+ }
10
+
11
+ /** Extends `FieldStateContext` with the checkbox-position flag used for style variants. */
12
+ export interface CheckboxFieldContext extends FieldStateContext {
13
+ checkboxOnLeft?: boolean
14
+ }
15
+
16
+ /**
17
+ * Props for `Checkbox`.
18
+ * `checkboxOnLeft` repositions the tick box before the label; exposed as a context flag so variant styles can react.
19
+ * `checkIcon` overrides the icon rendered inside the tick box (defaults to `'check'`).
20
+ */
7
21
  export type CheckboxProps =
8
- Pick<InputBaseProps, 'disabled' | 'label'> &
9
- ComponentCommonProps &
10
- {
11
- style?: StyledProp<CheckboxComposition>
22
+ Pick<FieldProps, 'label' | 'helper' | 'leftSection' | 'rightSection'> & {
23
+ style?: StyleProp<CheckboxComposition, keyof CheckboxStyleDef>
12
24
  checkboxOnLeft?: boolean
13
25
  checkIcon?: AppIcon
14
26
  field?: BooleanField<any>
15
27
  value?: boolean
16
28
  onValueChange?: (value: boolean) => void
29
+ disabled?: boolean
30
+ debugName?: string
17
31
  }
@@ -7,6 +7,10 @@ import { motion } from 'motion/react'
7
7
  export * from './styles'
8
8
  export * from './types'
9
9
 
10
+ /**
11
+ * Animates a content region between zero height (collapsed) and its natural height (expanded) using Framer Motion.
12
+ * Fully controlled — pass `open` from the caller; the component owns no toggle state of its own.
13
+ */
10
14
  export const Collapse = (props: CollapseProps) => {
11
15
  const {
12
16
  open,
@@ -27,7 +31,6 @@ export const Collapse = (props: CollapseProps) => {
27
31
  transition={{ duration: 0.2 }}
28
32
  {...rest}
29
33
  style={open ? styles?.['wrapper:open'] : styles?.['wrapper:closed']}
30
- // @ts-expect-error css type
31
34
  css={[styles.wrapper, open ? styles?.['wrapper:open'] : styles?.['wrapper:closed']]}
32
35
  >
33
36
  {children}
@@ -1,11 +1,14 @@
1
- import { StyledProp } from '@codeleap/styles'
1
+ import { StyleProp, StyledProp } from '@codeleap/styles'
2
2
  import { MotionProps } from 'motion/react'
3
3
  import { CollapseComposition } from './styles'
4
4
 
5
+ export interface CollapseStyleDef {}
6
+
5
7
  export type CollapseProps =
6
8
  Omit<MotionProps, 'style'> &
7
9
  {
10
+ /** Controls expanded (`true`) or collapsed (`false`) state; the component is fully controlled. */
8
11
  open: boolean
9
- style?: StyledProp<CollapseComposition>
12
+ style?: StyleProp<CollapseComposition, keyof CollapseStyleDef>
10
13
  children?: React.ReactNode
11
14
  }
@@ -1,5 +1,7 @@
1
1
  import React, { useCallback } from 'react'
2
- import { ActionIcon, Collapse, View } from '../components'
2
+ import { Button } from '../Button'
3
+ import { Collapse } from '../Collapse'
4
+ import { View } from '../View'
3
5
  import { HexColorPicker } from 'react-colorful'
4
6
  import { TypeGuards } from '@codeleap/types'
5
7
  import { useConditionalState, useState } from '@codeleap/hooks'
@@ -16,13 +18,13 @@ const DefaultFooter = (props: ColorPickerFooterProps) => {
16
18
 
17
19
  return (
18
20
  <View style={styles.footerWrapper}>
19
- <ActionIcon
21
+ <Button
20
22
  debugName='ColorPicker footer trash'
21
23
  name={clearIcon}
22
24
  onPress={handleClear}
23
25
  style={styles.clearIcon}
24
26
  />
25
- <ActionIcon
27
+ <Button
26
28
  debugName='ColorPicker footer check'
27
29
  name={confirmIcon}
28
30
  onPress={handleConfirmation}
@@ -32,6 +34,11 @@ const DefaultFooter = (props: ColorPickerFooterProps) => {
32
34
  )
33
35
  }
34
36
 
37
+ /**
38
+ * Color selection control that wraps any `react-colorful` picker in either an inline (`isPlain`) or collapsible-dropdown layout with optional confirm/clear footer actions.
39
+ * Internal color state is initialised from `initialColor`; `onConfirm` fires only when the user explicitly confirms (not on every picker drag).
40
+ * Uses: `Button`, `Collapse`, `View`
41
+ */
35
42
  export const ColorPicker = (props: ColorPickerProps) => {
36
43
  const {
37
44
  isPlain,
@@ -79,7 +86,7 @@ export const ColorPicker = (props: ColorPickerProps) => {
79
86
  toggle={() => toggle(!visible)}
80
87
  />
81
88
  ) : (
82
- <ActionIcon
89
+ <Button
83
90
  onPress={() => toggle(!visible)}
84
91
  icon={icon}
85
92
  {...openPickerProps}
@@ -1,10 +1,14 @@
1
1
  import React from 'react'
2
- import { ActionIconProps, ColorPickerComposition } from '../components'
3
- import { AppIcon, ICSS, StyledProp } from '@codeleap/styles'
2
+ import { ButtonProps, ColorPickerComposition } from '../components'
3
+ import { AppIcon, ICSS, StyleProp, StyledProp } from '@codeleap/styles'
4
4
  import { RgbColor, RgbaColor, HslColor, HsvColor, HslaColor, HsvaColor } from 'react-colorful'
5
5
 
6
+ export interface ColorPickerStyleDef {}
7
+
8
+ /** Union of all `react-colorful` color-object types plus a plain CSS hex/string. */
6
9
  export type ColorTypes = RgbColor | HslColor | HsvColor | RgbaColor | HslaColor | HsvaColor | string
7
10
 
11
+ /** Props injected into the footer renderer by `ColorPicker`. */
8
12
  export type ColorPickerFooterProps = Pick<ColorPickerProps, 'confirmIcon' | 'clearIcon'> & {
9
13
  color?: ColorTypes
10
14
  handleConfirmation: (value: ColorTypes) => void
@@ -12,14 +16,22 @@ export type ColorPickerFooterProps = Pick<ColorPickerProps, 'confirmIcon' | 'cle
12
16
  styles: Record<ColorPickerComposition, ICSS>
13
17
  }
14
18
 
19
+ /** Props injected into the custom open-picker trigger renderer by `ColorPicker`. */
15
20
  export type ColorPickerPickerProps = {
16
21
  color: ColorTypes
17
22
  visible: boolean
18
23
  toggle: (v?: boolean) => void
19
24
  }
20
25
 
26
+ /**
27
+ * Props for `ColorPicker`.
28
+ * In the default (dropdown) mode a `Button` trigger opens a `Collapse` panel containing the picker; set `isPlain` to render the picker inline with no toggle.
29
+ * `visible`/`toggle` allow external control of the dropdown state; omit them for fully internal state.
30
+ * `pickerComponent` defaults to `HexColorPicker`; replace it with any `react-colorful` picker or a custom component.
31
+ * Confirmation and clear are handled by `footerComponent` (defaults to `DefaultFooter`); set `showFooter={false}` to hide it.
32
+ */
21
33
  export type ColorPickerProps = {
22
- style?: StyledProp<ColorPickerComposition>
34
+ style?: StyleProp<ColorPickerComposition, keyof ColorPickerStyleDef>
23
35
  isPlain?: boolean
24
36
  closeOnConfirm?: boolean
25
37
  initialColor?: ColorTypes
@@ -27,7 +39,7 @@ export type ColorPickerProps = {
27
39
  icon?: AppIcon
28
40
  clearIcon?: AppIcon
29
41
  confirmIcon?: AppIcon
30
- openPickerProps?: ActionIconProps
42
+ openPickerProps?: ButtonProps
31
43
  onConfirm?: (color: ColorTypes) => void
32
44
  onClear?: () => void
33
45
  openPickerComponent?: (props: ColorPickerPickerProps) => React.ReactElement
@@ -0,0 +1,182 @@
1
+ import { useMemo } from 'react'
2
+ import { WebInputFile } from '@codeleap/types'
3
+ import { useCallback, useEffect, useState } from 'react'
4
+ import { Crop } from 'react-image-crop'
5
+ import { calculateProportionalDimensions, cropImage, readImage } from './utils'
6
+
7
+ export type UseCropPicker = {
8
+ /** Source image file to load into the crop editor. */
9
+ file: File
10
+ /** Enforced aspect ratio for the crop selection; omit to allow free-form cropping. */
11
+ aspect?: number
12
+ /** Minimum crop width in pixels; defaults to 100. */
13
+ minWidth?: number
14
+ /** Minimum crop height in pixels; defaults to 100. */
15
+ minHeight?: number
16
+ /** Called with the cropped `WebInputFile` on confirm, or `null` when the user cancels. */
17
+ onCrop?: (croppedFile: WebInputFile | null) => void
18
+ }
19
+
20
+ /**
21
+ * Manages crop state for a `CropPicker`, including image loading, crop selection with minimum-size enforcement, confirm/cancel handlers, and display-size calculation.
22
+ * Pass the return value to `CropPicker` via the `handle` prop.
23
+ */
24
+ export function useCropPicker({
25
+ aspect,
26
+ minWidth: minW,
27
+ minHeight: minH,
28
+ file,
29
+ onCrop,
30
+ }: UseCropPicker) {
31
+ const [image, setImage] = useState<HTMLImageElement>(null)
32
+ const [crop, setCrop] = useState<Crop>()
33
+ const [relativeCrop, setRelativeCrop] = useState<Crop>()
34
+
35
+ const [imageDimensions, setImageDimensions] = useState<{
36
+ naturalWidth: number
37
+ naturalHeight: number
38
+ displayWidth: number
39
+ displayHeight: number
40
+ aspectRatio: number
41
+ } | null>(null)
42
+
43
+ const cleanup = () => {
44
+ setRelativeCrop(null)
45
+ setCrop(undefined)
46
+ setImageDimensions(null)
47
+ setTimeout(() => setImage(null), 500)
48
+ }
49
+
50
+ const handleConfirmCrop = async () => {
51
+ const [preview, croppedBlob] = await cropImage(image, relativeCrop)
52
+
53
+ const newImage: WebInputFile = {
54
+ file: new File([croppedBlob], 'cropped.jpg', {
55
+ type: 'image/jpeg',
56
+ lastModified: Date.now(),
57
+ }),
58
+ preview,
59
+ }
60
+
61
+ onCrop(newImage)
62
+
63
+ setTimeout(() => cleanup())
64
+ }
65
+
66
+ const handleCancelCrop = () => {
67
+ onCrop(null)
68
+
69
+ setTimeout(() => cleanup())
70
+ }
71
+
72
+ const loadFile = useCallback(async (toReadFile: File) => {
73
+ const imageData = await readImage(toReadFile)
74
+ const { naturalWidth, naturalHeight } = imageData
75
+
76
+ const dimensions = calculateProportionalDimensions(naturalWidth, naturalHeight)
77
+
78
+ setImageDimensions(dimensions)
79
+
80
+ const targetAspect = aspect || dimensions.aspectRatio
81
+ const imageAspect = dimensions.aspectRatio
82
+
83
+ let initialCrop: Crop
84
+
85
+ if (aspect) {
86
+ const v =
87
+ imageAspect >= targetAspect
88
+ ? {
89
+ width: ((naturalHeight * targetAspect) / naturalWidth) * 100,
90
+ height: 100,
91
+ }
92
+ : {
93
+ width: 100,
94
+ height: (naturalWidth / targetAspect / naturalHeight) * 100,
95
+ }
96
+
97
+ initialCrop = {
98
+ ...v,
99
+ x: (100 - v.width) / 2,
100
+ y: (100 - v.height) / 2,
101
+ unit: '%' as const,
102
+ }
103
+ } else {
104
+ initialCrop = {
105
+ width: 100,
106
+ height: 100,
107
+ x: 0,
108
+ y: 0,
109
+ unit: '%' as const,
110
+ }
111
+ }
112
+
113
+ setCrop(initialCrop)
114
+ setRelativeCrop(initialCrop)
115
+ setImage(imageData)
116
+ }, [])
117
+
118
+ const getMinDimensions = useCallback(() => {
119
+ if (!imageDimensions) return { minWidth: minW ?? 100, minHeight: minH ?? 100 }
120
+
121
+ const targetAspect = aspect || imageDimensions.aspectRatio
122
+ const calculatedMinWidth = (minW ?? 100) * targetAspect
123
+ const calculatedMinHeight = minH ?? 100
124
+
125
+ return {
126
+ minWidth: Math.max(calculatedMinWidth, 50),
127
+ minHeight: Math.max(calculatedMinHeight, 50),
128
+ }
129
+ }, [aspect, imageDimensions, minW, minH])
130
+
131
+ const handleCropChange = useCallback((newCrop: Crop) => {
132
+ if (!imageDimensions) {
133
+ setCrop(newCrop)
134
+ return
135
+ }
136
+
137
+ const { minWidth, minHeight } = getMinDimensions()
138
+
139
+ setCrop({
140
+ ...newCrop,
141
+ width: newCrop.width < minWidth ? minWidth : newCrop.width,
142
+ height: newCrop.height < minHeight ? minHeight : newCrop.height,
143
+ })
144
+ }, [imageDimensions, getMinDimensions])
145
+
146
+ const containerStyles = useMemo(() => {
147
+ if (!imageDimensions) return {}
148
+
149
+ return {
150
+ width: imageDimensions.displayWidth,
151
+ height: imageDimensions.displayHeight,
152
+ maxWidth: '90vw',
153
+ maxHeight: '70vh',
154
+ margin: '0 auto',
155
+ }
156
+ }, [imageDimensions])
157
+
158
+ const imageStyles = useMemo(() => {
159
+ if (!imageDimensions) return {}
160
+
161
+ return {
162
+ width: imageDimensions.displayWidth,
163
+ height: imageDimensions.displayHeight,
164
+ objectFit: 'contain' as const,
165
+ }
166
+ }, [imageDimensions])
167
+
168
+ useEffect(() => {
169
+ loadFile(file)
170
+ }, [])
171
+
172
+ return {
173
+ containerStyles,
174
+ imageStyles,
175
+ handleCropChange,
176
+ handleConfirmCrop,
177
+ handleCancelCrop,
178
+ setRelativeCrop,
179
+ crop,
180
+ image,
181
+ }
182
+ }
@@ -1,116 +1,79 @@
1
- import React, { forwardRef, Ref } from 'react'
2
- import { StyledComponentWithProps, useCompositionStyles } from '@codeleap/styles'
3
- import { CropPickerProps } from './types'
4
- import { useCropPicker } from '../../lib'
1
+ import React from 'react'
2
+ import { StyledComponentProps, AnyRecord, IJSX, useCompositionStyles } from '@codeleap/styles'
5
3
  import { WebStyleRegistry } from '../../lib/WebStyleRegistry'
6
4
  import { useStylesFor } from '../../lib/hooks/useStylesFor'
7
- import { AnyRecord, IJSX, StyledComponentProps } from '@codeleap/styles'
8
- import { FileInput, FileInputRef } from '../FileInput'
9
- import { Modal } from '../Modal'
10
- import { Button } from '../Button'
11
- import { LoadingOverlay } from '../LoadingOverlay'
5
+ import { View } from '../View'
6
+ import { ActivityIndicator } from '../ActivityIndicator'
7
+ import { CropPickerProps } from './types'
12
8
 
13
- const ReactCrop: React.ElementType = require('react-image-crop').Component
14
9
 
15
10
  import 'react-image-crop/dist/ReactCrop.css'
11
+ const ReactCrop: React.ElementType = require('react-image-crop').Component
16
12
 
17
13
  export * from './styles'
18
14
  export * from './types'
15
+ export * from './hooks'
19
16
 
17
+ /**
18
+ * Image crop editor that wraps react-image-crop and delegates all crop state to a `useCropPicker` handle.
19
+ * Renders a loading spinner while the image is being decoded; renders nothing when `handle` is not provided.
20
+ */
20
21
  export const CropPicker = (props: CropPickerProps) => {
21
22
  const {
22
- onFileSelect,
23
- targetCrop,
24
- modalProps,
25
- title,
26
- confirmButton,
27
- debugName,
28
- handle,
29
- withLoading,
30
23
  style,
31
- confirmButtonProps,
32
- ref,
33
- ...fileInputProps
24
+ handle,
25
+ reactCrop,
26
+ aspect,
27
+ children,
34
28
  } = {
35
29
  ...CropPicker.defaultProps,
36
30
  ...props,
37
31
  }
38
32
 
33
+ const styles = useStylesFor(CropPicker.styleRegistryName, style)
34
+ const compositionStyles = useCompositionStyles(['indicator'], styles)
35
+
36
+ if (!handle) return null
37
+
39
38
  const {
40
- onConfirmCrop,
41
- onFilesReturned,
42
- onClose,
43
- fileInputRef,
44
- visible,
45
39
  image,
46
40
  crop,
47
41
  setRelativeCrop,
48
- isLoading,
49
42
  handleCropChange,
50
- } = handle || useCropPicker({ onFileSelect, ref: ref as unknown as Ref<FileInputRef>, ...targetCrop })
51
-
52
- const styles = useStylesFor(CropPicker.styleRegistryName, style)
53
-
54
- const composition = useCompositionStyles(['confirmButton', 'modal'], styles)
43
+ } = handle
55
44
 
56
45
  return (
57
- <>
58
- <FileInput
59
- // @ts-ignore
60
- ref={fileInputRef}
61
- onChange={(files) => onFilesReturned(files)}
62
- {...fileInputProps}
63
- />
64
-
65
- <Modal
66
- visible={visible}
67
- toggle={onClose}
68
- title={title}
69
- footer={
70
- <Button
71
- text={confirmButton}
72
- style={composition?.confirmButton}
73
- onPress={onConfirmCrop}
74
- debugName={debugName}
75
- {...confirmButtonProps}
46
+ <View style={styles.wrapper}>
47
+ {!image?.src ? (
48
+ <ActivityIndicator style={compositionStyles.indicator} debugName='CropPickerLoading' />
49
+ ) : (
50
+ <ReactCrop
51
+ {...reactCrop}
52
+ crop={crop}
53
+ onChange={handleCropChange}
54
+ onComplete={(_, relCrop) => setRelativeCrop(relCrop)}
55
+ style={styles.crop}
56
+ aspect={aspect ?? reactCrop?.aspect}
57
+ >
58
+ <img
59
+ src={image.src}
60
+ // @ts-ignore
61
+ css={[styles?.image]}
76
62
  />
77
- }
78
- {...modalProps}
79
- style={composition?.modal}
80
- >
81
- {!!image?.src ? (
82
- <ReactCrop
83
- crop={crop}
84
- onChange={handleCropChange}
85
- onComplete={(_, relCrop) => setRelativeCrop(relCrop)}
86
- {...targetCrop}
87
- style={styles.previewSize}
88
- >
89
- <img
90
- src={image?.src}
91
- // @ts-ignore
92
- css={[styles.cropPreview, styles.previewSize]}
93
- />
94
- </ReactCrop>
95
- ) : null}
96
- {withLoading ? <LoadingOverlay debugName='CropPicker' visible={isLoading} /> : null}
97
- </Modal>
98
- </>
63
+ </ReactCrop>
64
+ )}
65
+ {children}
66
+ </View>
99
67
  )
100
68
  }
101
69
 
102
70
  CropPicker.styleRegistryName = 'CropPicker'
103
- CropPicker.elements = ['previewSize', 'cropPreview', 'confirmButton', 'modal']
104
- CropPicker.rootElement = 'previewSize'
105
-
71
+ CropPicker.elements = ['crop', 'image', 'wrapper', 'indicator']
72
+ CropPicker.rootElement = 'crop'
106
73
  CropPicker.withVariantTypes = <S extends AnyRecord>(styles: S) => {
107
74
  return CropPicker as (props: StyledComponentProps<CropPickerProps, typeof styles>) => IJSX
108
75
  }
109
76
 
110
- CropPicker.defaultProps = {
111
- title: 'Crop Image',
112
- confirmButton: 'Confirm Crop',
113
- withLoading: false,
114
- } as Partial<CropPickerProps>
77
+ CropPicker.defaultProps = {} as Partial<CropPickerProps>
115
78
 
116
79
  WebStyleRegistry.registerComponent(CropPicker)
@@ -1,8 +1,7 @@
1
- import { ButtonComposition } from '../Button'
2
- import { ModalComposition } from '../Modal'
1
+ import { ActivityIndicatorComposition } from '../ActivityIndicator'
3
2
 
4
3
  export type CropPickerComposition =
5
- | 'cropPreview'
6
- | 'previewSize'
7
- | `confirmButton${Capitalize<ButtonComposition>}`
8
- | `modal${Capitalize<ModalComposition>}`
4
+ | 'crop'
5
+ | 'image'
6
+ | 'wrapper'
7
+ | `indicator${Capitalize<ActivityIndicatorComposition>}`
@@ -1,27 +1,25 @@
1
- import { StyledProp } from '@codeleap/styles'
2
- import { FileInputProps, FileInputRef } from '../FileInput'
1
+ import { StyleProp, StyledProp } from '@codeleap/styles'
2
+ import { FileInputRef } from '../FileInput'
3
+ import type { ReactCropProps } from 'react-image-crop'
3
4
  import { CropPickerComposition } from './styles'
4
- import { ReactCropProps } from 'react-image-crop'
5
- import { ModalProps } from '../Modal'
6
- import { useCropPicker } from '../../lib'
7
- import { ButtonProps } from '../Button'
5
+ import React from 'react'
6
+ import { useCropPicker } from './hooks'
8
7
  import { RefObject } from 'react'
9
8
 
10
- export type BaseCropProps = Partial<ReactCropProps>
9
+ type NativeCropProps = Omit<ReactCropProps, 'crop' | 'onChange' | 'onComplete' | 'style'>
10
+
11
+ export interface CropPickerStyleDef {}
11
12
 
12
13
  export type CropPickerProps =
13
- Partial<FileInputProps> &
14
14
  {
15
- style?: StyledProp<CropPickerComposition>
16
- targetCrop?: BaseCropProps
17
- modalProps?: Partial<ModalProps>
18
- title?: string
19
- confirmButton?: string
20
15
  debugName: string
16
+ style?: StyleProp<CropPickerComposition, keyof CropPickerStyleDef>
17
+ /** Return value of `useCropPicker`; the component renders nothing when omitted. */
21
18
  handle?: ReturnType<typeof useCropPicker>
22
- withLoading?: boolean
23
- confirmButtonProps?: Partial<ButtonProps>
19
+ /** Enforced aspect ratio forwarded to react-image-crop; takes precedence over `reactCrop.aspect`. */
20
+ aspect?: number
21
+ /** Additional props forwarded directly to the underlying `ReactCrop` element (excluding `crop`, `onChange`, `onComplete`, and `style`). */
22
+ reactCrop?: NativeCropProps
23
+ children?: React.ReactNode
24
24
  ref?: RefObject<FileInputRef | null>
25
25
  }
26
-
27
- export type ImageReading = HTMLImageElement