@chem-po/react-native 0.0.5 → 0.0.7

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 (561) hide show
  1. package/lib/commonjs/components/box/Center.js +35 -0
  2. package/lib/commonjs/components/box/Center.js.map +1 -0
  3. package/lib/commonjs/components/box/CollapseHorizontal.js +44 -0
  4. package/lib/commonjs/components/box/CollapseHorizontal.js.map +1 -0
  5. package/lib/commonjs/components/box/ContentBox.js +32 -0
  6. package/lib/commonjs/components/box/ContentBox.js.map +1 -0
  7. package/lib/commonjs/components/box/DropShadow.js +31 -0
  8. package/lib/commonjs/components/box/DropShadow.js.map +1 -0
  9. package/lib/commonjs/components/box/ExpandOnMount.js +71 -0
  10. package/lib/commonjs/components/box/ExpandOnMount.js.map +1 -0
  11. package/lib/commonjs/components/box/Expandable.js +125 -0
  12. package/lib/commonjs/components/box/Expandable.js.map +1 -0
  13. package/lib/commonjs/components/box/FullSizeContainer.js +79 -0
  14. package/lib/commonjs/components/box/FullSizeContainer.js.map +1 -0
  15. package/lib/commonjs/components/box/index.js +83 -0
  16. package/lib/commonjs/components/box/index.js.map +1 -0
  17. package/lib/commonjs/components/button/DeleteButton.js +279 -0
  18. package/lib/commonjs/components/button/DeleteButton.js.map +1 -0
  19. package/lib/commonjs/components/button/LoadingButton.js +132 -0
  20. package/lib/commonjs/components/button/LoadingButton.js.map +1 -0
  21. package/lib/commonjs/components/button/Toggle.js +89 -0
  22. package/lib/commonjs/components/button/Toggle.js.map +1 -0
  23. package/lib/commonjs/components/button/index.js +39 -0
  24. package/lib/commonjs/components/button/index.js.map +1 -0
  25. package/lib/commonjs/components/feed/FeedContentPane.js +105 -0
  26. package/lib/commonjs/components/feed/FeedContentPane.js.map +1 -0
  27. package/lib/commonjs/components/feed/MediaFeed.js +178 -0
  28. package/lib/commonjs/components/feed/MediaFeed.js.map +1 -0
  29. package/lib/commonjs/components/feed/MediaFeedBackground.js +126 -0
  30. package/lib/commonjs/components/feed/MediaFeedBackground.js.map +1 -0
  31. package/lib/commonjs/components/feed/MediaFeedRefresh.js +113 -0
  32. package/lib/commonjs/components/feed/MediaFeedRefresh.js.map +1 -0
  33. package/lib/commonjs/components/feed/constants.js +9 -0
  34. package/lib/commonjs/components/feed/constants.js.map +1 -0
  35. package/lib/commonjs/components/feed/context.js +23 -0
  36. package/lib/commonjs/components/feed/context.js.map +1 -0
  37. package/lib/commonjs/components/feed/hooks.js +262 -0
  38. package/lib/commonjs/components/feed/hooks.js.map +1 -0
  39. package/lib/commonjs/components/feed/index.js +28 -0
  40. package/lib/commonjs/components/feed/index.js.map +1 -0
  41. package/lib/commonjs/components/form/Condition.js +29 -0
  42. package/lib/commonjs/components/form/Condition.js.map +1 -0
  43. package/lib/commonjs/components/form/Field.js +57 -0
  44. package/lib/commonjs/components/form/Field.js.map +1 -0
  45. package/lib/commonjs/components/form/Form.js +387 -0
  46. package/lib/commonjs/components/form/Form.js.map +1 -0
  47. package/lib/commonjs/components/form/FormFooter.js +173 -0
  48. package/lib/commonjs/components/form/FormFooter.js.map +1 -0
  49. package/lib/commonjs/components/form/UploadProgress/index.js +66 -0
  50. package/lib/commonjs/components/form/UploadProgress/index.js.map +1 -0
  51. package/lib/commonjs/components/form/index.js +40 -0
  52. package/lib/commonjs/components/form/index.js.map +1 -0
  53. package/lib/commonjs/components/form/input/Editable.js +153 -0
  54. package/lib/commonjs/components/form/input/Editable.js.map +1 -0
  55. package/lib/commonjs/components/form/input/InputSlider.js +59 -0
  56. package/lib/commonjs/components/form/input/InputSlider.js.map +1 -0
  57. package/lib/commonjs/components/form/input/OptionalTag.js +46 -0
  58. package/lib/commonjs/components/form/input/OptionalTag.js.map +1 -0
  59. package/lib/commonjs/components/form/input/StandaloneInput.js +33 -0
  60. package/lib/commonjs/components/form/input/StandaloneInput.js.map +1 -0
  61. package/lib/commonjs/components/form/input/boolean/index.js +83 -0
  62. package/lib/commonjs/components/form/input/boolean/index.js.map +1 -0
  63. package/lib/commonjs/components/form/input/color/index.js +147 -0
  64. package/lib/commonjs/components/form/input/color/index.js.map +1 -0
  65. package/lib/commonjs/components/form/input/common/InputClearButton.js +63 -0
  66. package/lib/commonjs/components/form/input/common/InputClearButton.js.map +1 -0
  67. package/lib/commonjs/components/form/input/date/index.js +111 -0
  68. package/lib/commonjs/components/form/input/date/index.js.map +1 -0
  69. package/lib/commonjs/components/form/input/datetime/index.js +155 -0
  70. package/lib/commonjs/components/form/input/datetime/index.js.map +1 -0
  71. package/lib/commonjs/components/form/input/file/index.js +229 -0
  72. package/lib/commonjs/components/form/input/file/index.js.map +1 -0
  73. package/lib/commonjs/components/form/input/hooks/index.js +28 -0
  74. package/lib/commonjs/components/form/input/hooks/index.js.map +1 -0
  75. package/lib/commonjs/components/form/input/hooks/useInputColor.js +14 -0
  76. package/lib/commonjs/components/form/input/hooks/useInputColor.js.map +1 -0
  77. package/lib/commonjs/components/form/input/hooks/useInputImperativeHandle.js +23 -0
  78. package/lib/commonjs/components/form/input/hooks/useInputImperativeHandle.js.map +1 -0
  79. package/lib/commonjs/components/form/input/hooks/useInputStyle.js +50 -0
  80. package/lib/commonjs/components/form/input/hooks/useInputStyle.js.map +1 -0
  81. package/lib/commonjs/components/form/input/index.js +28 -0
  82. package/lib/commonjs/components/form/input/index.js.map +1 -0
  83. package/lib/commonjs/components/form/input/input.js +159 -0
  84. package/lib/commonjs/components/form/input/input.js.map +1 -0
  85. package/lib/commonjs/components/form/input/multipleSelect/index.js +80 -0
  86. package/lib/commonjs/components/form/input/multipleSelect/index.js.map +1 -0
  87. package/lib/commonjs/components/form/input/number/index.js +117 -0
  88. package/lib/commonjs/components/form/input/number/index.js.map +1 -0
  89. package/lib/commonjs/components/form/input/select/index.js +225 -0
  90. package/lib/commonjs/components/form/input/select/index.js.map +1 -0
  91. package/lib/commonjs/components/form/input/socialMedia/index.js +219 -0
  92. package/lib/commonjs/components/form/input/socialMedia/index.js.map +1 -0
  93. package/lib/commonjs/components/form/input/text/index.js +97 -0
  94. package/lib/commonjs/components/form/input/text/index.js.map +1 -0
  95. package/lib/commonjs/components/form/input/text/textarea.js +63 -0
  96. package/lib/commonjs/components/form/input/text/textarea.js.map +1 -0
  97. package/lib/commonjs/components/form/input/time/index.js +125 -0
  98. package/lib/commonjs/components/form/input/time/index.js.map +1 -0
  99. package/lib/commonjs/components/form/types.js +6 -0
  100. package/lib/commonjs/components/form/types.js.map +1 -0
  101. package/lib/commonjs/components/form/view/file.js +57 -0
  102. package/lib/commonjs/components/form/view/file.js.map +1 -0
  103. package/lib/commonjs/components/form/view/index.js +90 -0
  104. package/lib/commonjs/components/form/view/index.js.map +1 -0
  105. package/lib/commonjs/components/form/view/multipleSelect.js +51 -0
  106. package/lib/commonjs/components/form/view/multipleSelect.js.map +1 -0
  107. package/lib/commonjs/components/form/view/select.js +45 -0
  108. package/lib/commonjs/components/form/view/select.js.map +1 -0
  109. package/lib/commonjs/components/icons/index.js +47 -0
  110. package/lib/commonjs/components/icons/index.js.map +1 -0
  111. package/lib/commonjs/components/index.js +94 -0
  112. package/lib/commonjs/components/index.js.map +1 -0
  113. package/lib/commonjs/components/loading/CircularProgress.js +49 -0
  114. package/lib/commonjs/components/loading/CircularProgress.js.map +1 -0
  115. package/lib/commonjs/components/loading/Loading.js +174 -0
  116. package/lib/commonjs/components/loading/Loading.js.map +1 -0
  117. package/lib/commonjs/components/loading/LoadingImage.js +115 -0
  118. package/lib/commonjs/components/loading/LoadingImage.js.map +1 -0
  119. package/lib/commonjs/components/loading/LoadingSwitch.js +100 -0
  120. package/lib/commonjs/components/loading/LoadingSwitch.js.map +1 -0
  121. package/lib/commonjs/components/loading/index.js +50 -0
  122. package/lib/commonjs/components/loading/index.js.map +1 -0
  123. package/lib/commonjs/components/overlay/ImageViewOverlay.js +126 -0
  124. package/lib/commonjs/components/overlay/ImageViewOverlay.js.map +1 -0
  125. package/lib/commonjs/components/overlay/index.js +17 -0
  126. package/lib/commonjs/components/overlay/index.js.map +1 -0
  127. package/lib/commonjs/components/text/AnimatedText.js +63 -0
  128. package/lib/commonjs/components/text/AnimatedText.js.map +1 -0
  129. package/lib/commonjs/components/text/Txt.js +22 -0
  130. package/lib/commonjs/components/text/Txt.js.map +1 -0
  131. package/lib/commonjs/components/text/index.js +17 -0
  132. package/lib/commonjs/components/text/index.js.map +1 -0
  133. package/lib/commonjs/components/theme/colorMode/DarkModeToggle.js +49 -0
  134. package/lib/commonjs/components/theme/colorMode/DarkModeToggle.js.map +1 -0
  135. package/lib/commonjs/components/theme/colorMode/index.js +17 -0
  136. package/lib/commonjs/components/theme/colorMode/index.js.map +1 -0
  137. package/lib/commonjs/components/theme/index.js +17 -0
  138. package/lib/commonjs/components/theme/index.js.map +1 -0
  139. package/lib/commonjs/constants/index.js +17 -0
  140. package/lib/commonjs/constants/index.js.map +1 -0
  141. package/lib/commonjs/constants/toast.js +31 -0
  142. package/lib/commonjs/constants/toast.js.map +1 -0
  143. package/lib/commonjs/contexts/index.js +17 -0
  144. package/lib/commonjs/contexts/index.js.map +1 -0
  145. package/lib/commonjs/contexts/root.js +33 -0
  146. package/lib/commonjs/contexts/root.js.map +1 -0
  147. package/lib/commonjs/hooks/index.js +17 -0
  148. package/lib/commonjs/hooks/index.js.map +1 -0
  149. package/lib/commonjs/hooks/useThemeState.js +21 -0
  150. package/lib/commonjs/hooks/useThemeState.js.map +1 -0
  151. package/lib/commonjs/index.js +61 -0
  152. package/lib/commonjs/index.js.map +1 -0
  153. package/lib/commonjs/store/index.js +17 -0
  154. package/lib/commonjs/store/index.js.map +1 -0
  155. package/lib/commonjs/store/useScreen.js +36 -0
  156. package/lib/commonjs/store/useScreen.js.map +1 -0
  157. package/lib/commonjs/styles/fill.js +25 -0
  158. package/lib/commonjs/styles/fill.js.map +1 -0
  159. package/lib/module/components/box/Center.js +29 -0
  160. package/lib/module/components/box/Center.js.map +1 -0
  161. package/lib/module/components/box/CollapseHorizontal.js +37 -0
  162. package/lib/module/components/box/CollapseHorizontal.js.map +1 -0
  163. package/lib/module/components/box/ContentBox.js +26 -0
  164. package/lib/module/components/box/ContentBox.js.map +1 -0
  165. package/lib/module/components/box/DropShadow.js +25 -0
  166. package/lib/module/components/box/DropShadow.js.map +1 -0
  167. package/lib/module/components/box/ExpandOnMount.js +64 -0
  168. package/lib/module/components/box/ExpandOnMount.js.map +1 -0
  169. package/lib/module/components/box/Expandable.js +117 -0
  170. package/lib/module/components/box/Expandable.js.map +1 -0
  171. package/lib/module/components/box/FullSizeContainer.js +70 -0
  172. package/lib/module/components/box/FullSizeContainer.js.map +1 -0
  173. package/lib/module/components/box/index.js +8 -0
  174. package/lib/module/components/box/index.js.map +1 -0
  175. package/lib/module/components/button/DeleteButton.js +270 -0
  176. package/lib/module/components/button/DeleteButton.js.map +1 -0
  177. package/lib/module/components/button/LoadingButton.js +124 -0
  178. package/lib/module/components/button/LoadingButton.js.map +1 -0
  179. package/lib/module/components/button/Toggle.js +82 -0
  180. package/lib/module/components/button/Toggle.js.map +1 -0
  181. package/lib/module/components/button/index.js +4 -0
  182. package/lib/module/components/button/index.js.map +1 -0
  183. package/lib/module/components/feed/FeedContentPane.js +97 -0
  184. package/lib/module/components/feed/FeedContentPane.js.map +1 -0
  185. package/lib/module/components/feed/MediaFeed.js +170 -0
  186. package/lib/module/components/feed/MediaFeed.js.map +1 -0
  187. package/lib/module/components/feed/MediaFeedBackground.js +118 -0
  188. package/lib/module/components/feed/MediaFeedBackground.js.map +1 -0
  189. package/lib/module/components/feed/MediaFeedRefresh.js +103 -0
  190. package/lib/module/components/feed/MediaFeedRefresh.js.map +1 -0
  191. package/lib/module/components/feed/constants.js +3 -0
  192. package/lib/module/components/feed/constants.js.map +1 -0
  193. package/lib/module/components/feed/context.js +15 -0
  194. package/lib/module/components/feed/context.js.map +1 -0
  195. package/lib/module/components/feed/hooks.js +255 -0
  196. package/lib/module/components/feed/hooks.js.map +1 -0
  197. package/lib/module/components/feed/index.js +3 -0
  198. package/lib/module/components/feed/index.js.map +1 -0
  199. package/lib/module/components/form/Condition.js +22 -0
  200. package/lib/module/components/form/Condition.js.map +1 -0
  201. package/lib/module/components/form/Field.js +51 -0
  202. package/lib/module/components/form/Field.js.map +1 -0
  203. package/lib/module/components/form/Form.js +375 -0
  204. package/lib/module/components/form/Form.js.map +1 -0
  205. package/lib/module/components/form/FormFooter.js +165 -0
  206. package/lib/module/components/form/FormFooter.js.map +1 -0
  207. package/lib/module/components/form/UploadProgress/index.js +59 -0
  208. package/lib/module/components/form/UploadProgress/index.js.map +1 -0
  209. package/lib/module/components/form/index.js +4 -0
  210. package/lib/module/components/form/index.js.map +1 -0
  211. package/lib/module/components/form/input/Editable.js +146 -0
  212. package/lib/module/components/form/input/Editable.js.map +1 -0
  213. package/lib/module/components/form/input/InputSlider.js +51 -0
  214. package/lib/module/components/form/input/InputSlider.js.map +1 -0
  215. package/lib/module/components/form/input/OptionalTag.js +39 -0
  216. package/lib/module/components/form/input/OptionalTag.js.map +1 -0
  217. package/lib/module/components/form/input/StandaloneInput.js +27 -0
  218. package/lib/module/components/form/input/StandaloneInput.js.map +1 -0
  219. package/lib/module/components/form/input/boolean/index.js +77 -0
  220. package/lib/module/components/form/input/boolean/index.js.map +1 -0
  221. package/lib/module/components/form/input/color/index.js +141 -0
  222. package/lib/module/components/form/input/color/index.js.map +1 -0
  223. package/lib/module/components/form/input/common/InputClearButton.js +55 -0
  224. package/lib/module/components/form/input/common/InputClearButton.js.map +1 -0
  225. package/lib/module/components/form/input/date/index.js +106 -0
  226. package/lib/module/components/form/input/date/index.js.map +1 -0
  227. package/lib/module/components/form/input/datetime/index.js +149 -0
  228. package/lib/module/components/form/input/datetime/index.js.map +1 -0
  229. package/lib/module/components/form/input/file/index.js +221 -0
  230. package/lib/module/components/form/input/file/index.js.map +1 -0
  231. package/lib/module/components/form/input/hooks/index.js +3 -0
  232. package/lib/module/components/form/input/hooks/index.js.map +1 -0
  233. package/lib/module/components/form/input/hooks/useInputColor.js +7 -0
  234. package/lib/module/components/form/input/hooks/useInputColor.js.map +1 -0
  235. package/lib/module/components/form/input/hooks/useInputImperativeHandle.js +16 -0
  236. package/lib/module/components/form/input/hooks/useInputImperativeHandle.js.map +1 -0
  237. package/lib/module/components/form/input/hooks/useInputStyle.js +43 -0
  238. package/lib/module/components/form/input/hooks/useInputStyle.js.map +1 -0
  239. package/lib/module/components/form/input/index.js +3 -0
  240. package/lib/module/components/form/input/index.js.map +1 -0
  241. package/lib/module/components/form/input/input.js +153 -0
  242. package/lib/module/components/form/input/input.js.map +1 -0
  243. package/lib/module/components/form/input/multipleSelect/index.js +74 -0
  244. package/lib/module/components/form/input/multipleSelect/index.js.map +1 -0
  245. package/lib/module/components/form/input/number/index.js +111 -0
  246. package/lib/module/components/form/input/number/index.js.map +1 -0
  247. package/lib/module/components/form/input/select/index.js +219 -0
  248. package/lib/module/components/form/input/select/index.js.map +1 -0
  249. package/lib/module/components/form/input/socialMedia/index.js +213 -0
  250. package/lib/module/components/form/input/socialMedia/index.js.map +1 -0
  251. package/lib/module/components/form/input/text/index.js +91 -0
  252. package/lib/module/components/form/input/text/index.js.map +1 -0
  253. package/lib/module/components/form/input/text/textarea.js +57 -0
  254. package/lib/module/components/form/input/text/textarea.js.map +1 -0
  255. package/lib/module/components/form/input/time/index.js +119 -0
  256. package/lib/module/components/form/input/time/index.js.map +1 -0
  257. package/lib/module/components/form/types.js +2 -0
  258. package/lib/module/components/form/types.js.map +1 -0
  259. package/lib/module/components/form/view/file.js +50 -0
  260. package/lib/module/components/form/view/file.js.map +1 -0
  261. package/lib/module/components/form/view/index.js +83 -0
  262. package/lib/module/components/form/view/index.js.map +1 -0
  263. package/lib/module/components/form/view/multipleSelect.js +44 -0
  264. package/lib/module/components/form/view/multipleSelect.js.map +1 -0
  265. package/lib/module/components/form/view/select.js +38 -0
  266. package/lib/module/components/form/view/select.js.map +1 -0
  267. package/lib/module/components/icons/index.js +38 -0
  268. package/lib/module/components/icons/index.js.map +1 -0
  269. package/lib/module/components/index.js +9 -0
  270. package/lib/module/components/index.js.map +1 -0
  271. package/lib/module/components/loading/CircularProgress.js +42 -0
  272. package/lib/module/components/loading/CircularProgress.js.map +1 -0
  273. package/lib/module/components/loading/Loading.js +163 -0
  274. package/lib/module/components/loading/Loading.js.map +1 -0
  275. package/lib/module/components/loading/LoadingImage.js +108 -0
  276. package/lib/module/components/loading/LoadingImage.js.map +1 -0
  277. package/lib/module/components/loading/LoadingSwitch.js +93 -0
  278. package/lib/module/components/loading/LoadingSwitch.js.map +1 -0
  279. package/lib/module/components/loading/index.js +5 -0
  280. package/lib/module/components/loading/index.js.map +1 -0
  281. package/lib/module/components/overlay/ImageViewOverlay.js +119 -0
  282. package/lib/module/components/overlay/ImageViewOverlay.js.map +1 -0
  283. package/lib/module/components/overlay/index.js +2 -0
  284. package/lib/module/components/overlay/index.js.map +1 -0
  285. package/lib/module/components/text/AnimatedText.js +56 -0
  286. package/lib/module/components/text/AnimatedText.js.map +1 -0
  287. package/lib/module/components/text/Txt.js +15 -0
  288. package/lib/module/components/text/Txt.js.map +1 -0
  289. package/lib/module/components/text/index.js +2 -0
  290. package/lib/module/components/text/index.js.map +1 -0
  291. package/lib/module/components/theme/colorMode/DarkModeToggle.js +41 -0
  292. package/lib/module/components/theme/colorMode/DarkModeToggle.js.map +1 -0
  293. package/lib/module/components/theme/colorMode/index.js +2 -0
  294. package/lib/module/components/theme/colorMode/index.js.map +1 -0
  295. package/lib/module/components/theme/index.js +2 -0
  296. package/lib/module/components/theme/index.js.map +1 -0
  297. package/lib/module/constants/index.js +2 -0
  298. package/lib/module/constants/index.js.map +1 -0
  299. package/lib/module/constants/toast.js +25 -0
  300. package/lib/module/constants/toast.js.map +1 -0
  301. package/lib/module/contexts/index.js +2 -0
  302. package/lib/module/contexts/index.js.map +1 -0
  303. package/lib/module/contexts/root.js +26 -0
  304. package/lib/module/contexts/root.js.map +1 -0
  305. package/lib/module/hooks/index.js +2 -0
  306. package/lib/module/hooks/index.js.map +1 -0
  307. package/lib/module/hooks/useThemeState.js +14 -0
  308. package/lib/module/hooks/useThemeState.js.map +1 -0
  309. package/lib/module/index.js +6 -0
  310. package/lib/module/index.js.map +1 -0
  311. package/lib/module/store/index.js +2 -0
  312. package/lib/module/store/index.js.map +1 -0
  313. package/lib/module/store/useScreen.js +29 -0
  314. package/lib/module/store/useScreen.js.map +1 -0
  315. package/lib/module/styles/fill.js +19 -0
  316. package/lib/module/styles/fill.js.map +1 -0
  317. package/lib/typescript/src/components/box/Center.d.ts +5 -0
  318. package/lib/typescript/src/components/box/Center.d.ts.map +1 -0
  319. package/lib/typescript/src/components/box/CollapseHorizontal.d.ts +7 -0
  320. package/lib/typescript/src/components/box/CollapseHorizontal.d.ts.map +1 -0
  321. package/lib/typescript/src/components/box/ContentBox.d.ts +3 -0
  322. package/lib/typescript/src/components/box/ContentBox.d.ts.map +1 -0
  323. package/lib/typescript/src/components/box/DropShadow.d.ts +6 -0
  324. package/lib/typescript/src/components/box/DropShadow.d.ts.map +1 -0
  325. package/lib/typescript/src/components/box/ExpandOnMount.d.ts +9 -0
  326. package/lib/typescript/src/components/box/ExpandOnMount.d.ts.map +1 -0
  327. package/lib/typescript/src/components/box/Expandable.d.ts +23 -0
  328. package/lib/typescript/src/components/box/Expandable.d.ts.map +1 -0
  329. package/lib/typescript/src/components/box/FullSizeContainer.d.ts +16 -0
  330. package/lib/typescript/src/components/box/FullSizeContainer.d.ts.map +1 -0
  331. package/lib/typescript/src/components/box/index.d.ts +8 -0
  332. package/lib/typescript/src/components/box/index.d.ts.map +1 -0
  333. package/lib/typescript/src/components/button/DeleteButton.d.ts +21 -0
  334. package/lib/typescript/src/components/button/DeleteButton.d.ts.map +1 -0
  335. package/lib/typescript/src/components/button/LoadingButton.d.ts +17 -0
  336. package/lib/typescript/src/components/button/LoadingButton.d.ts.map +1 -0
  337. package/lib/typescript/src/components/button/Toggle.d.ts +14 -0
  338. package/lib/typescript/src/components/button/Toggle.d.ts.map +1 -0
  339. package/lib/typescript/src/components/button/index.d.ts +4 -0
  340. package/lib/typescript/src/components/button/index.d.ts.map +1 -0
  341. package/lib/typescript/src/components/feed/FeedContentPane.d.ts +16 -0
  342. package/lib/typescript/src/components/feed/FeedContentPane.d.ts.map +1 -0
  343. package/lib/typescript/src/components/feed/MediaFeed.d.ts +5 -0
  344. package/lib/typescript/src/components/feed/MediaFeed.d.ts.map +1 -0
  345. package/lib/typescript/src/components/feed/MediaFeedBackground.d.ts +19 -0
  346. package/lib/typescript/src/components/feed/MediaFeedBackground.d.ts.map +1 -0
  347. package/lib/typescript/src/components/feed/MediaFeedRefresh.d.ts +7 -0
  348. package/lib/typescript/src/components/feed/MediaFeedRefresh.d.ts.map +1 -0
  349. package/lib/typescript/src/components/feed/constants.d.ts +3 -0
  350. package/lib/typescript/src/components/feed/constants.d.ts.map +1 -0
  351. package/lib/typescript/src/components/feed/context.d.ts +12 -0
  352. package/lib/typescript/src/components/feed/context.d.ts.map +1 -0
  353. package/lib/typescript/src/components/feed/hooks.d.ts +16 -0
  354. package/lib/typescript/src/components/feed/hooks.d.ts.map +1 -0
  355. package/lib/typescript/src/components/feed/index.d.ts +3 -0
  356. package/lib/typescript/src/components/feed/index.d.ts.map +1 -0
  357. package/lib/typescript/src/components/form/Condition.d.ts +6 -0
  358. package/lib/typescript/src/components/form/Condition.d.ts.map +1 -0
  359. package/lib/typescript/src/components/form/Field.d.ts +8 -0
  360. package/lib/typescript/src/components/form/Field.d.ts.map +1 -0
  361. package/lib/typescript/src/components/form/Form.d.ts +18 -0
  362. package/lib/typescript/src/components/form/Form.d.ts.map +1 -0
  363. package/lib/typescript/src/components/form/FormFooter.d.ts +9 -0
  364. package/lib/typescript/src/components/form/FormFooter.d.ts.map +1 -0
  365. package/lib/typescript/src/components/form/UploadProgress/index.d.ts +5 -0
  366. package/lib/typescript/src/components/form/UploadProgress/index.d.ts.map +1 -0
  367. package/lib/typescript/src/components/form/index.d.ts +4 -0
  368. package/lib/typescript/src/components/form/index.d.ts.map +1 -0
  369. package/lib/typescript/src/components/form/input/Editable.d.ts +4 -0
  370. package/lib/typescript/src/components/form/input/Editable.d.ts.map +1 -0
  371. package/lib/typescript/src/components/form/input/InputSlider.d.ts +9 -0
  372. package/lib/typescript/src/components/form/input/InputSlider.d.ts.map +1 -0
  373. package/lib/typescript/src/components/form/input/OptionalTag.d.ts +6 -0
  374. package/lib/typescript/src/components/form/input/OptionalTag.d.ts.map +1 -0
  375. package/lib/typescript/src/components/form/input/StandaloneInput.d.ts +16 -0
  376. package/lib/typescript/src/components/form/input/StandaloneInput.d.ts.map +1 -0
  377. package/lib/typescript/src/components/form/input/boolean/index.d.ts +5 -0
  378. package/lib/typescript/src/components/form/input/boolean/index.d.ts.map +1 -0
  379. package/lib/typescript/src/components/form/input/color/index.d.ts +5 -0
  380. package/lib/typescript/src/components/form/input/color/index.d.ts.map +1 -0
  381. package/lib/typescript/src/components/form/input/common/InputClearButton.d.ts +10 -0
  382. package/lib/typescript/src/components/form/input/common/InputClearButton.d.ts.map +1 -0
  383. package/lib/typescript/src/components/form/input/date/index.d.ts +5 -0
  384. package/lib/typescript/src/components/form/input/date/index.d.ts.map +1 -0
  385. package/lib/typescript/src/components/form/input/datetime/index.d.ts +5 -0
  386. package/lib/typescript/src/components/form/input/datetime/index.d.ts.map +1 -0
  387. package/lib/typescript/src/components/form/input/file/index.d.ts +10 -0
  388. package/lib/typescript/src/components/form/input/file/index.d.ts.map +1 -0
  389. package/lib/typescript/src/components/form/input/hooks/index.d.ts +3 -0
  390. package/lib/typescript/src/components/form/input/hooks/index.d.ts.map +1 -0
  391. package/lib/typescript/src/components/form/input/hooks/useInputColor.d.ts +2 -0
  392. package/lib/typescript/src/components/form/input/hooks/useInputColor.d.ts.map +1 -0
  393. package/lib/typescript/src/components/form/input/hooks/useInputImperativeHandle.d.ts +5 -0
  394. package/lib/typescript/src/components/form/input/hooks/useInputImperativeHandle.d.ts.map +1 -0
  395. package/lib/typescript/src/components/form/input/hooks/useInputStyle.d.ts +9 -0
  396. package/lib/typescript/src/components/form/input/hooks/useInputStyle.d.ts.map +1 -0
  397. package/lib/typescript/src/components/form/input/index.d.ts +3 -0
  398. package/lib/typescript/src/components/form/input/index.d.ts.map +1 -0
  399. package/lib/typescript/src/components/form/input/input.d.ts +6 -0
  400. package/lib/typescript/src/components/form/input/input.d.ts.map +1 -0
  401. package/lib/typescript/src/components/form/input/multipleSelect/index.d.ts +5 -0
  402. package/lib/typescript/src/components/form/input/multipleSelect/index.d.ts.map +1 -0
  403. package/lib/typescript/src/components/form/input/number/index.d.ts +8 -0
  404. package/lib/typescript/src/components/form/input/number/index.d.ts.map +1 -0
  405. package/lib/typescript/src/components/form/input/select/index.d.ts +5 -0
  406. package/lib/typescript/src/components/form/input/select/index.d.ts.map +1 -0
  407. package/lib/typescript/src/components/form/input/socialMedia/index.d.ts +5 -0
  408. package/lib/typescript/src/components/form/input/socialMedia/index.d.ts.map +1 -0
  409. package/lib/typescript/src/components/form/input/text/index.d.ts +5 -0
  410. package/lib/typescript/src/components/form/input/text/index.d.ts.map +1 -0
  411. package/lib/typescript/src/components/form/input/text/textarea.d.ts +5 -0
  412. package/lib/typescript/src/components/form/input/text/textarea.d.ts.map +1 -0
  413. package/lib/typescript/src/components/form/input/time/index.d.ts +5 -0
  414. package/lib/typescript/src/components/form/input/time/index.d.ts.map +1 -0
  415. package/lib/typescript/src/components/form/types.d.ts +4 -0
  416. package/lib/typescript/src/components/form/types.d.ts.map +1 -0
  417. package/lib/typescript/src/components/form/view/file.d.ts +9 -0
  418. package/lib/typescript/src/components/form/view/file.d.ts.map +1 -0
  419. package/lib/typescript/src/components/form/view/index.d.ts +9 -0
  420. package/lib/typescript/src/components/form/view/index.d.ts.map +1 -0
  421. package/lib/typescript/src/components/form/view/multipleSelect.d.ts +9 -0
  422. package/lib/typescript/src/components/form/view/multipleSelect.d.ts.map +1 -0
  423. package/lib/typescript/src/components/form/view/select.d.ts +9 -0
  424. package/lib/typescript/src/components/form/view/select.d.ts.map +1 -0
  425. package/lib/typescript/src/components/icons/index.d.ts +10 -0
  426. package/lib/typescript/src/components/icons/index.d.ts.map +1 -0
  427. package/lib/typescript/src/components/index.d.ts +9 -0
  428. package/lib/typescript/src/components/index.d.ts.map +1 -0
  429. package/lib/typescript/src/components/loading/CircularProgress.d.ts +7 -0
  430. package/lib/typescript/src/components/loading/CircularProgress.d.ts.map +1 -0
  431. package/lib/typescript/src/components/loading/Loading.d.ts +27 -0
  432. package/lib/typescript/src/components/loading/Loading.d.ts.map +1 -0
  433. package/lib/typescript/src/components/loading/LoadingImage.d.ts +13 -0
  434. package/lib/typescript/src/components/loading/LoadingImage.d.ts.map +1 -0
  435. package/lib/typescript/src/components/loading/LoadingSwitch.d.ts +6 -0
  436. package/lib/typescript/src/components/loading/LoadingSwitch.d.ts.map +1 -0
  437. package/lib/typescript/src/components/loading/index.d.ts +5 -0
  438. package/lib/typescript/src/components/loading/index.d.ts.map +1 -0
  439. package/lib/typescript/src/components/overlay/ImageViewOverlay.d.ts +5 -0
  440. package/lib/typescript/src/components/overlay/ImageViewOverlay.d.ts.map +1 -0
  441. package/lib/typescript/src/components/overlay/index.d.ts +2 -0
  442. package/lib/typescript/src/components/overlay/index.d.ts.map +1 -0
  443. package/lib/typescript/src/components/text/AnimatedText.d.ts +11 -0
  444. package/lib/typescript/src/components/text/AnimatedText.d.ts.map +1 -0
  445. package/lib/typescript/src/components/text/Txt.d.ts +3 -0
  446. package/lib/typescript/src/components/text/Txt.d.ts.map +1 -0
  447. package/lib/typescript/src/components/text/index.d.ts +2 -0
  448. package/lib/typescript/src/components/text/index.d.ts.map +1 -0
  449. package/lib/typescript/src/components/theme/colorMode/DarkModeToggle.d.ts +3 -0
  450. package/lib/typescript/src/components/theme/colorMode/DarkModeToggle.d.ts.map +1 -0
  451. package/lib/typescript/src/components/theme/colorMode/index.d.ts +2 -0
  452. package/lib/typescript/src/components/theme/colorMode/index.d.ts.map +1 -0
  453. package/lib/typescript/src/components/theme/index.d.ts +2 -0
  454. package/lib/typescript/src/components/theme/index.d.ts.map +1 -0
  455. package/lib/typescript/src/constants/index.d.ts +2 -0
  456. package/lib/typescript/src/constants/index.d.ts.map +1 -0
  457. package/lib/typescript/src/constants/toast.d.ts +3 -0
  458. package/lib/typescript/src/constants/toast.d.ts.map +1 -0
  459. package/lib/typescript/src/contexts/index.d.ts +2 -0
  460. package/lib/typescript/src/contexts/index.d.ts.map +1 -0
  461. package/lib/typescript/src/contexts/root.d.ts +9 -0
  462. package/lib/typescript/src/contexts/root.d.ts.map +1 -0
  463. package/lib/typescript/src/hooks/index.d.ts +2 -0
  464. package/lib/typescript/src/hooks/index.d.ts.map +1 -0
  465. package/lib/typescript/src/hooks/useThemeState.d.ts +8 -0
  466. package/lib/typescript/src/hooks/useThemeState.d.ts.map +1 -0
  467. package/lib/typescript/src/index.d.ts +6 -0
  468. package/lib/typescript/src/index.d.ts.map +1 -0
  469. package/lib/typescript/src/store/index.d.ts +2 -0
  470. package/lib/typescript/src/store/index.d.ts.map +1 -0
  471. package/lib/typescript/src/store/useScreen.d.ts +2 -0
  472. package/lib/typescript/src/store/useScreen.d.ts.map +1 -0
  473. package/lib/typescript/src/styles/fill.d.ts +269 -0
  474. package/lib/typescript/src/styles/fill.d.ts.map +1 -0
  475. package/lib/typescript/tsup.config.d.ts +3 -0
  476. package/lib/typescript/tsup.config.d.ts.map +1 -0
  477. package/package.json +47 -11
  478. package/src/components/box/Center.tsx +19 -0
  479. package/src/components/box/CollapseHorizontal.tsx +44 -0
  480. package/src/components/box/ContentBox.tsx +24 -0
  481. package/src/components/box/DropShadow.tsx +28 -0
  482. package/src/components/box/ExpandOnMount.tsx +74 -0
  483. package/src/components/box/Expandable.tsx +143 -0
  484. package/src/components/box/FullSizeContainer.tsx +64 -0
  485. package/src/components/box/index.ts +7 -0
  486. package/src/components/button/DeleteButton.tsx +294 -0
  487. package/src/components/button/LoadingButton.tsx +155 -0
  488. package/src/components/button/Toggle.tsx +104 -0
  489. package/src/components/button/index.ts +3 -0
  490. package/src/components/feed/FeedContentPane.tsx +97 -0
  491. package/src/components/feed/MediaFeed.tsx +199 -0
  492. package/src/components/feed/MediaFeedBackground.tsx +136 -0
  493. package/src/components/feed/MediaFeedRefresh.tsx +113 -0
  494. package/src/components/feed/constants.ts +2 -0
  495. package/src/components/feed/context.tsx +19 -0
  496. package/src/components/feed/hooks.ts +279 -0
  497. package/src/components/feed/index.ts +2 -0
  498. package/src/components/form/Condition.tsx +27 -0
  499. package/src/components/form/Field.tsx +43 -0
  500. package/src/components/form/Form.tsx +393 -0
  501. package/src/components/form/FormFooter.tsx +163 -0
  502. package/src/components/form/UploadProgress/index.tsx +62 -0
  503. package/src/components/form/index.ts +3 -0
  504. package/src/components/form/input/Editable.tsx +167 -0
  505. package/src/components/form/input/InputSlider.tsx +70 -0
  506. package/src/components/form/input/OptionalTag.tsx +43 -0
  507. package/src/components/form/input/StandaloneInput.tsx +36 -0
  508. package/src/components/form/input/boolean/index.tsx +56 -0
  509. package/src/components/form/input/color/index.tsx +145 -0
  510. package/src/components/form/input/common/InputClearButton.tsx +47 -0
  511. package/src/components/form/input/date/index.tsx +103 -0
  512. package/src/components/form/input/datetime/index.tsx +143 -0
  513. package/src/components/form/input/file/index.tsx +226 -0
  514. package/src/components/form/input/hooks/index.ts +2 -0
  515. package/src/components/form/input/hooks/useInputColor.ts +7 -0
  516. package/src/components/form/input/hooks/useInputImperativeHandle.ts +22 -0
  517. package/src/components/form/input/hooks/useInputStyle.ts +40 -0
  518. package/src/components/form/input/index.ts +2 -0
  519. package/src/components/form/input/input.tsx +174 -0
  520. package/src/components/form/input/multipleSelect/index.tsx +79 -0
  521. package/src/components/form/input/number/index.tsx +100 -0
  522. package/src/components/form/input/select/index.tsx +215 -0
  523. package/src/components/form/input/socialMedia/index.tsx +234 -0
  524. package/src/components/form/input/text/index.tsx +89 -0
  525. package/src/components/form/input/text/textarea.tsx +56 -0
  526. package/src/components/form/input/time/index.tsx +106 -0
  527. package/src/components/form/types.ts +4 -0
  528. package/src/components/form/view/file.tsx +59 -0
  529. package/src/components/form/view/index.tsx +77 -0
  530. package/src/components/form/view/multipleSelect.tsx +52 -0
  531. package/src/components/form/view/select.tsx +41 -0
  532. package/src/components/icons/index.tsx +28 -0
  533. package/src/components/index.ts +8 -0
  534. package/src/components/loading/CircularProgress.tsx +53 -0
  535. package/src/components/loading/Loading.tsx +181 -0
  536. package/src/components/loading/LoadingImage.tsx +144 -0
  537. package/src/components/loading/LoadingSwitch.tsx +110 -0
  538. package/src/components/loading/index.ts +4 -0
  539. package/src/components/overlay/ImageViewOverlay.tsx +104 -0
  540. package/src/components/overlay/index.ts +1 -0
  541. package/src/components/text/AnimatedText.tsx +66 -0
  542. package/src/components/text/Txt.tsx +11 -0
  543. package/src/components/text/index.ts +1 -0
  544. package/src/components/theme/colorMode/DarkModeToggle.tsx +45 -0
  545. package/src/components/theme/colorMode/index.ts +1 -0
  546. package/src/components/theme/index.ts +1 -0
  547. package/src/constants/index.ts +1 -0
  548. package/src/constants/toast.ts +23 -0
  549. package/src/contexts/index.ts +1 -0
  550. package/src/contexts/root.tsx +39 -0
  551. package/src/hooks/index.ts +1 -0
  552. package/src/hooks/useThemeState.ts +18 -0
  553. package/src/store/index.ts +1 -0
  554. package/src/store/useScreen.ts +25 -0
  555. package/src/styles/fill.ts +19 -0
  556. package/dist/index.d.mts +0 -228
  557. package/dist/index.d.ts +0 -228
  558. package/dist/index.js +0 -2
  559. package/dist/index.js.map +0 -1
  560. package/dist/index.mjs +0 -2
  561. package/dist/index.mjs.map +0 -1
@@ -0,0 +1,199 @@
1
+ import { AnyObject, WithId } from '@chem-po/core'
2
+ import {
3
+ MediaBackgroundRef,
4
+ MediaFeedProps,
5
+ PanelData,
6
+ UpdatePanelsArgs,
7
+ useScreen,
8
+ useTheme,
9
+ } from '@chem-po/react'
10
+ import React, { Dispatch, PropsWithChildren, useCallback, useMemo, useRef, useState } from 'react'
11
+ import { Animated, StyleSheet, View, ViewStyle } from 'react-native'
12
+ import {
13
+ Gesture,
14
+ GestureDetector,
15
+ GestureStateChangeEvent,
16
+ GestureUpdateEvent,
17
+ PanGestureHandlerEventPayload,
18
+ } from 'react-native-gesture-handler'
19
+ import { fill } from '../../styles/fill'
20
+ import { Center } from '../box/Center'
21
+ import { LoadingOverlay } from '../loading/Loading'
22
+ import { REFRESH_THRESHOLD, SWIPE_THRESHOLD } from './constants'
23
+ import { MediaFeedProvider } from './context'
24
+ import { FeedContentPane } from './FeedContentPane'
25
+ import { useMediaFeed } from './hooks'
26
+ import { MediaFeedBackground } from './MediaFeedBackground'
27
+ import { MediaFeedRefresh } from './MediaFeedRefresh'
28
+
29
+ const useUpdatePanels = (setItems: Dispatch<React.SetStateAction<Array<PanelData>>>) =>
30
+ useCallback(
31
+ (data: UpdatePanelsArgs) => {
32
+ const updated: PanelData[] = []
33
+ if (data.prev) updated.push({ status: 'prev', id: data.prev })
34
+ if (data.curr) {
35
+ updated.push({
36
+ status: 'current',
37
+ id: data.curr,
38
+ })
39
+ }
40
+ if (data.next) updated.push({ status: 'next', id: data.next })
41
+ setItems(updated)
42
+ },
43
+ [setItems],
44
+ )
45
+
46
+ export const MediaFeed = <T extends AnyObject = AnyObject>({
47
+ fetch,
48
+ collection: collectionPath,
49
+ RenderItem,
50
+ authRequired,
51
+ getBackgroundUrl,
52
+ getBackgroundValue,
53
+ limit,
54
+ defaultBackground,
55
+ swipeDisabled,
56
+ children,
57
+ }: PropsWithChildren<MediaFeedProps<T>>) => {
58
+ const { width, height } = useScreen()
59
+ const { theme } = useTheme()
60
+
61
+ const contentRef = useRef<View>(null)
62
+ const containerRef = useRef<View>(null)
63
+ // const panels = useRef<Array<FeedContentPaneRef>>([])
64
+ const [direction, setDirection] = useState<'next' | 'prev' | null>(null)
65
+ const [panels, setPanels] = useState<Array<PanelData>>([])
66
+
67
+ const offsetY = useRef(new Animated.Value(0)).current
68
+ const onNewData = useUpdatePanels(setPanels)
69
+
70
+ const backgroundRef = useRef<MediaBackgroundRef<T>>(null)
71
+
72
+ const { goNext, goPrev, loading, canGoNext, canGoPrev, refresh, refreshing } = useMediaFeed(
73
+ fetch,
74
+ onNewData,
75
+ limit,
76
+ authRequired,
77
+ )
78
+
79
+ const pointerDown = useRef(false)
80
+ const dragStart = useRef({ x: 0, y: 0 })
81
+
82
+ const onDragStart = useCallback(
83
+ (e: GestureStateChangeEvent<PanGestureHandlerEventPayload>) => {
84
+ if (swipeDisabled) return
85
+ pointerDown.current = true
86
+ dragStart.current = { x: e.x, y: e.y }
87
+ },
88
+ [swipeDisabled],
89
+ )
90
+
91
+ const onDragEnd = useCallback(
92
+ (e: GestureStateChangeEvent<PanGestureHandlerEventPayload>) => {
93
+ if (!pointerDown.current) return
94
+
95
+ const maxY = canGoPrev ? SWIPE_THRESHOLD : REFRESH_THRESHOLD
96
+ const minY = canGoNext ? -SWIPE_THRESHOLD : -REFRESH_THRESHOLD
97
+ const oY = Math.max(minY, Math.min(maxY, e.y - dragStart.current.y))
98
+
99
+ if (canGoNext && oY < -(SWIPE_THRESHOLD - 10)) {
100
+ setDirection('next')
101
+ goNext()
102
+ } else if (canGoPrev && oY > SWIPE_THRESHOLD - 10) {
103
+ setDirection('prev')
104
+ goPrev()
105
+ } else if (oY > REFRESH_THRESHOLD - 10 || oY < -(REFRESH_THRESHOLD - 10)) {
106
+ refresh()
107
+ if (backgroundRef.current) backgroundRef.current.onNewData(null)
108
+ }
109
+
110
+ offsetY.setValue(0)
111
+ pointerDown.current = false
112
+ },
113
+ [offsetY, goNext, goPrev, canGoNext, canGoPrev, refresh],
114
+ )
115
+
116
+ const onDragMove = useCallback(
117
+ (e: GestureUpdateEvent<PanGestureHandlerEventPayload>) => {
118
+ if (!pointerDown.current) return
119
+
120
+ const oX = Math.max(-10, Math.min(10, e.x - dragStart.current.x))
121
+ const maxY = canGoPrev ? SWIPE_THRESHOLD : REFRESH_THRESHOLD
122
+ const minY = canGoNext ? -SWIPE_THRESHOLD : -REFRESH_THRESHOLD
123
+ const oY = Math.max(minY, Math.min(maxY, e.y - dragStart.current.y))
124
+
125
+ const dist = Math.sqrt(oX ** 2 + oY ** 2)
126
+ if (dist > 10 && contentRef.current) {
127
+ // contentRef.current.style.setProperty('pointer-events', 'none')
128
+ }
129
+ offsetY.setValue(oY)
130
+ },
131
+ [offsetY, canGoNext, canGoPrev],
132
+ )
133
+
134
+ const panGesture = Gesture.Pan().onStart(onDragStart).onUpdate(onDragMove).onEnd(onDragEnd)
135
+
136
+ const containerStyle = useMemo<ViewStyle>(
137
+ () => ({
138
+ height,
139
+ width,
140
+ overflow: 'hidden',
141
+ pointerEvents: swipeDisabled ? 'none' : 'auto',
142
+ }),
143
+ [width, height, swipeDisabled],
144
+ )
145
+ const [curr, setCurr] = useState<WithId<T> | null>(null)
146
+
147
+ const handleItemLoad = useCallback(
148
+ (data: WithId<T> | null) => {
149
+ const isCurr = panels.find(p => p.status === 'current')?.id === data?._id
150
+ if (isCurr) setCurr(data)
151
+ },
152
+ [panels],
153
+ )
154
+
155
+ return (
156
+ <MediaFeedProvider curr={curr}>
157
+ <GestureDetector gesture={panGesture}>
158
+ <Center
159
+ style={[
160
+ styles.container,
161
+ { backgroundColor: defaultBackground ?? theme.colors.background[100] },
162
+ ]}>
163
+ <MediaFeedBackground
164
+ item={curr}
165
+ getBackgroundValue={getBackgroundValue}
166
+ getBackgroundUrl={getBackgroundUrl}
167
+ />
168
+ <View style={containerStyle} ref={containerRef}>
169
+ <Center style={fill.relative} ref={contentRef}>
170
+ {panels.map(panel => (
171
+ <FeedContentPane<T>
172
+ key={panel.id}
173
+ id={panel.id}
174
+ collectionPath={collectionPath}
175
+ RenderItem={RenderItem}
176
+ onItemLoad={handleItemLoad}
177
+ status={panel.status}
178
+ enterStatus={direction}
179
+ offsetY={offsetY}
180
+ />
181
+ ))}
182
+ </Center>
183
+ </View>
184
+ <MediaFeedRefresh canRefresh={!canGoPrev} refreshing={refreshing} offsetY={offsetY} />
185
+ {/* {onSwipeUp ? <MediaFeedSwipeUp offsetY={offsetY} /> : null} */}
186
+ <LoadingOverlay inFeed isLoading={loading} />
187
+ {children ? <Center style={[fill.absolute, { zIndex: 3 }]}>{children}</Center> : null}
188
+ </Center>
189
+ </GestureDetector>
190
+ </MediaFeedProvider>
191
+ )
192
+ }
193
+
194
+ const styles = StyleSheet.create({
195
+ container: {
196
+ ...fill.relative,
197
+ overflow: 'hidden',
198
+ },
199
+ })
@@ -0,0 +1,136 @@
1
+ import { AnyObject, WithId } from '@chem-po/core'
2
+ import { GetBackgroundUrl, GetBackgroundValue, useObjectUrl } from '@chem-po/react'
3
+ import React, { useEffect, useMemo, useRef, useState } from 'react'
4
+ import { ImageBackground, StyleSheet, View, ViewProps } from 'react-native'
5
+ import { fill } from '../../styles/fill'
6
+ import { Center } from '../box/Center'
7
+ import { LoadingLogo } from '../loading'
8
+
9
+ const emptyPng =
10
+ 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAQAAAC1HAwCAAAAC0lEQVR42mNkAAIAAAoAAv/lxKUAAAAASUVORK5CYII='
11
+ export const backgroundStyle = StyleSheet.create({
12
+ imageBackground: {
13
+ flex: 1,
14
+ transform: [{ scale: 1.075 }],
15
+ },
16
+ })
17
+
18
+ interface FillBackgroundProps extends ViewProps {
19
+ background: string | null
20
+ opacity?: number
21
+ }
22
+
23
+ const FillBackground: React.FC<FillBackgroundProps> = ({
24
+ background,
25
+ opacity = 0.7,
26
+ style,
27
+ ...props
28
+ }) => (
29
+ <View style={[fill.absolute, style]} {...props}>
30
+ <ImageBackground
31
+ source={{ uri: background ?? emptyPng }}
32
+ style={[backgroundStyle.imageBackground, { opacity }]}
33
+ resizeMode="cover"></ImageBackground>
34
+ </View>
35
+ )
36
+
37
+ interface FileValueBackgroundProps<T extends AnyObject = AnyObject> {
38
+ getBackgroundValue: GetBackgroundValue<T>
39
+ item: WithId<T> | null
40
+ filter?: string
41
+ }
42
+ const FileValueBackground = <T extends AnyObject = AnyObject>({
43
+ getBackgroundValue,
44
+ item,
45
+ }: FileValueBackgroundProps<T>) => {
46
+ const background = useMemo(
47
+ () => (item ? getBackgroundValue(item) : null),
48
+ [getBackgroundValue, item],
49
+ )
50
+ const { loading, url } = useObjectUrl(background)
51
+ const usedIndex = useRef(0)
52
+ const [index, setIndex] = useState(0)
53
+ const [url1, setUrl1] = useState<string | null>(null)
54
+ const [url2, setUrl2] = useState<string | null>(null)
55
+
56
+ useEffect(() => {
57
+ const usedIdx = usedIndex.current
58
+ if (usedIdx === 0) {
59
+ setUrl1(url)
60
+ usedIndex.current = 1
61
+ setIndex(0)
62
+ } else {
63
+ setUrl2(url)
64
+ usedIndex.current = 0
65
+ setIndex(1)
66
+ }
67
+ }, [url])
68
+
69
+ return (
70
+ <Center style={fill.absolute}>
71
+ <FillBackground opacity={index === 0 ? 1 : 0} background={url1} />
72
+ <FillBackground opacity={index === 1 ? 1 : 0} background={url2} />
73
+ <LoadingLogo isLoading={loading} />
74
+ </Center>
75
+ )
76
+ }
77
+
78
+ const UrlBackground = <T extends AnyObject = AnyObject>({
79
+ getBackgroundUrl,
80
+ item,
81
+ }: {
82
+ getBackgroundUrl: GetBackgroundUrl<T>
83
+ item: T | null
84
+ }) => {
85
+ const background = useMemo(() => (item ? getBackgroundUrl(item) : null), [getBackgroundUrl, item])
86
+ const usedIndex = useRef(0)
87
+ const [index, setIndex] = useState(0)
88
+ const [url1, setUrl1] = useState<string | null>(null)
89
+ const [url2, setUrl2] = useState<string | null>(null)
90
+
91
+ useEffect(() => {
92
+ if (!background) return
93
+ if (usedIndex.current === 0) {
94
+ setUrl1(background)
95
+ usedIndex.current = 1
96
+ setIndex(0)
97
+ } else {
98
+ setUrl2(background)
99
+ usedIndex.current = 0
100
+ setIndex(1)
101
+ }
102
+ }, [background])
103
+
104
+ return (
105
+ <Center style={fill.absolute}>
106
+ <FillBackground
107
+ //filter={filter}
108
+ opacity={index === 0 ? 1 : 0}
109
+ background={url1}
110
+ />
111
+ <FillBackground
112
+ //filter={filter}
113
+ opacity={index === 1 ? 1 : 0}
114
+ background={url2}
115
+ />
116
+ </Center>
117
+ )
118
+ }
119
+
120
+ interface MediaFeedBackgroundProps<T extends AnyObject = AnyObject> {
121
+ getBackgroundValue?: GetBackgroundValue<T>
122
+ getBackgroundUrl?: GetBackgroundUrl<T>
123
+ filter?: string
124
+ item: WithId<T> | null
125
+ }
126
+
127
+ export const MediaFeedBackground = <T extends AnyObject = AnyObject>({
128
+ getBackgroundValue,
129
+ getBackgroundUrl,
130
+ ...props
131
+ }: MediaFeedBackgroundProps<T>) => {
132
+ if (getBackgroundValue)
133
+ return <FileValueBackground getBackgroundValue={getBackgroundValue} {...props} />
134
+ if (getBackgroundUrl) return <UrlBackground getBackgroundUrl={getBackgroundUrl} {...props} />
135
+ return null
136
+ }
@@ -0,0 +1,113 @@
1
+ import Icon from '@expo/vector-icons/MaterialCommunityIcons' // or your preferred icon set
2
+ import { useEffect, useRef } from 'react'
3
+ import { Animated, StyleSheet, View } from 'react-native'
4
+ import { DropShadow } from '../box/DropShadow'
5
+ import { CircularProgress } from '../loading'
6
+ import { REFRESH_THRESHOLD, SWIPE_THRESHOLD } from './constants'
7
+
8
+ const WINDOW = REFRESH_THRESHOLD - SWIPE_THRESHOLD
9
+
10
+ export const MediaFeedRefresh = ({
11
+ offsetY,
12
+ refreshing,
13
+ canRefresh,
14
+ }: {
15
+ offsetY: Animated.Value
16
+ refreshing: boolean
17
+ canRefresh: boolean
18
+ }) => {
19
+ // Create animated values
20
+ const baseY = useRef(new Animated.Value(0)).current
21
+ const isIn = useRef(new Animated.Value(0)).current
22
+
23
+ const dist = Animated.subtract(offsetY, SWIPE_THRESHOLD)
24
+ const baseProgress = Animated.divide(dist, WINDOW)
25
+ const progress = Animated.diffClamp(baseProgress, 0, 1)
26
+
27
+ // Handle refreshing state
28
+ useEffect(() => {
29
+ Animated.spring(baseY, {
30
+ toValue: refreshing ? 50 : 0,
31
+ useNativeDriver: true,
32
+ }).start()
33
+ }, [refreshing, baseY])
34
+
35
+ // Handle canRefresh state
36
+ useEffect(() => {
37
+ Animated.spring(isIn, {
38
+ toValue: canRefresh ? 1 : 0,
39
+ useNativeDriver: true,
40
+ }).start()
41
+ }, [canRefresh, isIn])
42
+
43
+ // Create complex animations
44
+ const progressRoot = progress.interpolate({
45
+ inputRange: [0, 1],
46
+ outputRange: [0, Math.sqrt(1) * 20],
47
+ })
48
+
49
+ const yBase = Animated.add(baseY, progressRoot)
50
+ const yConstrained = yBase.interpolate({
51
+ inputRange: [0, 20],
52
+ outputRange: [0, 20],
53
+ extrapolate: 'clamp',
54
+ })
55
+
56
+ const y = Animated.multiply(isIn, yConstrained)
57
+
58
+ const scale = y.interpolate({
59
+ inputRange: [0, 30],
60
+ outputRange: [0, 1],
61
+ extrapolate: 'clamp',
62
+ })
63
+ const finalScale = Animated.multiply(isIn, scale)
64
+
65
+ const rotate = progress.interpolate({
66
+ inputRange: [0, 1],
67
+ outputRange: ['0deg', '180deg'],
68
+ })
69
+
70
+ return (
71
+ <Animated.View
72
+ style={[
73
+ styles.container,
74
+ {
75
+ opacity: finalScale,
76
+ transform: [{ translateY: y }, { scale: finalScale }, { rotate }],
77
+ },
78
+ ]}>
79
+ <View style={styles.centerContainer}>
80
+ <DropShadow
81
+ style={[
82
+ {
83
+ opacity: refreshing ? 0 : 1,
84
+ },
85
+ ]}>
86
+ <Icon name="refresh" size={32} color="white" />
87
+ </DropShadow>
88
+
89
+ <DropShadow
90
+ style={{
91
+ opacity: refreshing ? 1 : 0,
92
+ }}>
93
+ <CircularProgress animating size="large" color="white" />
94
+ </DropShadow>
95
+ </View>
96
+ </Animated.View>
97
+ )
98
+ }
99
+
100
+ const styles = StyleSheet.create({
101
+ container: {
102
+ position: 'absolute',
103
+ top: 0,
104
+ left: 0,
105
+ right: 0,
106
+ pointerEvents: 'none',
107
+ },
108
+ centerContainer: {
109
+ alignItems: 'center',
110
+ justifyContent: 'center',
111
+ width: '100%',
112
+ },
113
+ })
@@ -0,0 +1,2 @@
1
+ export const SWIPE_THRESHOLD = 75
2
+ export const REFRESH_THRESHOLD = 100
@@ -0,0 +1,19 @@
1
+ import { AnyObject, WithId } from '@chem-po/core'
2
+ import { createContext, PropsWithChildren, useContext, useMemo } from 'react'
3
+
4
+ interface MediaFeedContextValue<T extends AnyObject = AnyObject> {
5
+ curr: WithId<T> | null
6
+ }
7
+ export const MediaFeedContext = createContext<MediaFeedContextValue<any>>(
8
+ {} as MediaFeedContextValue<any>,
9
+ )
10
+
11
+ export const MediaFeedProvider = <T extends AnyObject = AnyObject>({
12
+ curr,
13
+ children,
14
+ }: PropsWithChildren<{ curr: WithId<T> | null }>) => {
15
+ const contextData = useMemo(() => ({ curr }), [curr])
16
+ return <MediaFeedContext.Provider value={contextData}>{children}</MediaFeedContext.Provider>
17
+ }
18
+ export const useMediaFeed = <T extends AnyObject = AnyObject>() =>
19
+ useContext(MediaFeedContext) as MediaFeedContextValue<T>