@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,106 @@
1
+ import { InputRef, padZeros } from '@chem-po/core'
2
+ import { TimeField, useIconColor } from '@chem-po/react'
3
+ import { Ionicons } from '@expo/vector-icons'
4
+ import { forwardRef, useImperativeHandle, useMemo, useState } from 'react'
5
+ import { StyleSheet, Text, TouchableOpacity, View } from 'react-native'
6
+ import { Portal } from 'react-native-paper'
7
+ import { TimePickerModal } from 'react-native-paper-dates'
8
+ import { FieldProps } from '../../types'
9
+ import { DateInputClearButton } from '../common/InputClearButton'
10
+ import { useInputColor } from '../hooks/useInputColor'
11
+
12
+ export const TimeInput = forwardRef<InputRef, FieldProps<TimeField>>(
13
+ ({ input: { onChange, value, onFocus, onBlur }, field: { placeholder, optional } }, ref) => {
14
+ const [visible, setVisible] = useState(false)
15
+
16
+ useImperativeHandle(ref, () => ({
17
+ focus: () => {
18
+ setVisible(true)
19
+ onFocus()
20
+ },
21
+ blur: () => {
22
+ setVisible(false)
23
+ onBlur()
24
+ },
25
+ }))
26
+
27
+ const handleTimeChange = ({ hours, minutes }: { hours: number; minutes: number }) => {
28
+ setVisible(false)
29
+ const timeString = `${padZeros(hours)}:${padZeros(minutes)}`
30
+ onChange(timeString)
31
+ onBlur()
32
+ }
33
+
34
+ const handleDismiss = () => {
35
+ setVisible(false)
36
+ onBlur()
37
+ }
38
+
39
+ const formattedValue = useMemo(() => {
40
+ if (!value) return null
41
+ const [hours, minutes] = value.split(':').map(Number)
42
+ const amPm = hours >= 12 ? 'PM' : 'AM'
43
+ const formattedHours = hours % 12 === 0 ? 12 : hours % 12
44
+ return `${formattedHours}:${padZeros(minutes)} ${amPm}`
45
+ }, [value])
46
+
47
+ const { hours, minutes } = useMemo(() => {
48
+ if (!value) return { hours: 0, minutes: 0 }
49
+ const [h, m] = value.split(':').map(Number)
50
+ return { hours: h, minutes: m }
51
+ }, [value])
52
+
53
+ const iconColor = useIconColor()
54
+ const inputColor = useInputColor(value)
55
+
56
+ return (
57
+ <View style={styles.container}>
58
+ <TouchableOpacity
59
+ style={styles.button}
60
+ onPress={() => {
61
+ setVisible(true)
62
+ onFocus()
63
+ }}>
64
+ <Text style={[styles.text, { color: inputColor }]}>{formattedValue ?? placeholder}</Text>
65
+ <Ionicons name="time" size={20} color={iconColor} style={styles.icon} />
66
+ {optional && value ? (
67
+ <DateInputClearButton onPress={() => onChange(null)} isActive={!!value} />
68
+ ) : null}
69
+ </TouchableOpacity>
70
+ <Portal>
71
+ <TimePickerModal
72
+ visible={visible}
73
+ onDismiss={handleDismiss}
74
+ onConfirm={handleTimeChange}
75
+ hours={hours}
76
+ minutes={minutes}
77
+ />
78
+ </Portal>
79
+ </View>
80
+ )
81
+ },
82
+ )
83
+
84
+ TimeInput.displayName = 'TimeInput'
85
+
86
+ const styles = StyleSheet.create({
87
+ container: {
88
+ width: '100%',
89
+ },
90
+ button: {
91
+ flexDirection: 'row',
92
+ alignItems: 'center',
93
+ justifyContent: 'space-between',
94
+ width: '100%',
95
+ height: 40,
96
+ paddingHorizontal: 12,
97
+ paddingVertical: 8,
98
+ },
99
+ text: {
100
+ fontSize: 16,
101
+ flex: 1,
102
+ },
103
+ icon: {
104
+ marginRight: 10,
105
+ },
106
+ })
@@ -0,0 +1,4 @@
1
+ import { BaseFieldProps, Field } from '@chem-po/react'
2
+ import { StyleProp } from 'react-native'
3
+
4
+ export type FieldProps<T extends Field> = BaseFieldProps<StyleProp<any>, T>
@@ -0,0 +1,59 @@
1
+ import { ImageViewOptions } from '@chem-po/core'
2
+ import { FileField } from '@chem-po/react'
3
+ import { useMemo } from 'react'
4
+ import { StyleSheet, Text, View, ViewStyle } from 'react-native'
5
+ import { FileView } from '../input/file'
6
+
7
+ const styles = StyleSheet.create({
8
+ container: {
9
+ flexDirection: 'column',
10
+ },
11
+ rowContainer: {
12
+ flexDirection: 'row',
13
+ },
14
+ label: {
15
+ paddingRight: 8,
16
+ opacity: 0.7,
17
+ fontWeight: '600',
18
+ },
19
+ emptyText: {
20
+ opacity: 0.7,
21
+ },
22
+ fileContainer: {
23
+ padding: 4,
24
+ },
25
+ })
26
+
27
+ export const FileFieldView = ({
28
+ field,
29
+ value,
30
+ noLabel,
31
+ style,
32
+ }: {
33
+ field: FileField
34
+ value: any
35
+ noLabel?: boolean
36
+ style?: ViewStyle
37
+ }) => {
38
+ const { imageOptions, placeholder } = field
39
+ const options = useMemo<ImageViewOptions>(
40
+ () => ({
41
+ height: 150,
42
+ ...imageOptions,
43
+ }),
44
+ [imageOptions],
45
+ )
46
+
47
+ return (
48
+ <View style={[value ? styles.container : styles.rowContainer, style]}>
49
+ {!noLabel && <Text style={styles.label}>{placeholder}</Text>}
50
+ {value ? (
51
+ <View style={styles.fileContainer}>
52
+ <FileView imageOptions={options} value={value} />
53
+ </View>
54
+ ) : (
55
+ <Text style={styles.emptyText}>None</Text>
56
+ )}
57
+ </View>
58
+ )
59
+ }
@@ -0,0 +1,77 @@
1
+ import { formatField } from '@chem-po/core'
2
+ import { Field } from '@chem-po/react'
3
+ import { useMemo } from 'react'
4
+ import { StyleSheet, Text, View, ViewStyle } from 'react-native'
5
+ import { FileFieldView } from './file'
6
+ import { MultipleSelectFieldView } from './multipleSelect'
7
+ import { SelectFieldView } from './select'
8
+
9
+ const styles = StyleSheet.create({
10
+ container: {
11
+ flexDirection: 'row',
12
+ alignItems: 'center',
13
+ },
14
+ label: {
15
+ paddingRight: 8,
16
+ opacity: 0.7,
17
+ fontWeight: '600',
18
+ },
19
+ value: {
20
+ opacity: 1,
21
+ },
22
+ valueEmpty: {
23
+ opacity: 0.6,
24
+ },
25
+ })
26
+
27
+ const DefaultFieldView = ({
28
+ field,
29
+ value,
30
+ noLabel,
31
+ style,
32
+ }: {
33
+ field: Field
34
+ value: any
35
+ noLabel?: boolean
36
+ style?: ViewStyle
37
+ }) => {
38
+ const { placeholder } = field
39
+
40
+ const formatted = useMemo(() => {
41
+ const format = formatField[field._type]
42
+ if (!format) return value
43
+ return format(field, value)
44
+ }, [value, field])
45
+
46
+ return (
47
+ <View style={[styles.container, style]}>
48
+ {!noLabel && <Text style={styles.label}>{placeholder}</Text>}
49
+ <Text style={value !== undefined && value !== null ? styles.value : styles.valueEmpty}>
50
+ {formatted ?? 'None'}
51
+ </Text>
52
+ </View>
53
+ )
54
+ }
55
+
56
+ export const FieldView = ({
57
+ field,
58
+ value,
59
+ noLabel,
60
+ style,
61
+ }: {
62
+ field: Field
63
+ value: any
64
+ noLabel?: boolean
65
+ style?: ViewStyle
66
+ }) => {
67
+ switch (field._type) {
68
+ case 'select':
69
+ return <SelectFieldView style={style} field={field} value={value} noLabel={noLabel} />
70
+ case 'multipleSelect':
71
+ return <MultipleSelectFieldView style={style} field={field} value={value} noLabel={noLabel} />
72
+ case 'file':
73
+ return <FileFieldView style={style} field={field} value={value} noLabel={noLabel} />
74
+ default:
75
+ return <DefaultFieldView style={style} field={field} value={value} noLabel={noLabel} />
76
+ }
77
+ }
@@ -0,0 +1,52 @@
1
+ import { MultipleSelectField } from '@chem-po/react'
2
+ import { StyleSheet, Text, useColorScheme, View, ViewStyle } from 'react-native'
3
+
4
+ const styles = StyleSheet.create({
5
+ container: {
6
+ flexDirection: 'row',
7
+ flexWrap: 'wrap',
8
+ alignItems: 'center',
9
+ maxWidth: '100%',
10
+ },
11
+ label: {
12
+ paddingRight: 8,
13
+ opacity: 0.7,
14
+ fontWeight: '600',
15
+ },
16
+ optionContainer: {
17
+ padding: 2,
18
+ },
19
+ emptyText: {
20
+ opacity: 0.6,
21
+ },
22
+ })
23
+
24
+ export const MultipleSelectFieldView = ({
25
+ field,
26
+ value,
27
+ noLabel,
28
+ style,
29
+ }: {
30
+ field: MultipleSelectField
31
+ value: any[]
32
+ noLabel?: boolean
33
+ style?: ViewStyle
34
+ }) => {
35
+ const { placeholder, renderOption, getOptionKey } = field
36
+ const colorScheme = useColorScheme() ?? 'light'
37
+
38
+ return (
39
+ <View style={[styles.container, style]}>
40
+ {!noLabel && <Text style={styles.label}>{placeholder}</Text>}
41
+ {value ? (
42
+ value.map((v: any) => (
43
+ <View key={getOptionKey ? getOptionKey(v) : v} style={styles.optionContainer}>
44
+ {renderOption(v, colorScheme, true)}
45
+ </View>
46
+ ))
47
+ ) : (
48
+ <Text style={styles.emptyText}>None</Text>
49
+ )}
50
+ </View>
51
+ )
52
+ }
@@ -0,0 +1,41 @@
1
+ import { SelectField, usePlaceholderColor } from '@chem-po/react'
2
+ import { StyleSheet, Text, useColorScheme, View, ViewStyle } from 'react-native'
3
+ import { Txt } from '../../text'
4
+
5
+ const styles = StyleSheet.create({
6
+ container: {
7
+ flexDirection: 'row',
8
+ alignItems: 'center',
9
+ },
10
+ label: {
11
+ paddingRight: 10,
12
+ fontWeight: '600',
13
+ },
14
+ })
15
+
16
+ const DefaultRenderOption = (value: any) => {
17
+ return <Txt>{typeof value === 'string' ? value : JSON.stringify(value)}</Txt>
18
+ }
19
+
20
+ export const SelectFieldView = ({
21
+ field,
22
+ value,
23
+ noLabel,
24
+ style,
25
+ }: {
26
+ field: SelectField
27
+ value: any
28
+ noLabel?: boolean
29
+ style?: ViewStyle
30
+ }) => {
31
+ const { placeholder, renderOption: customRender } = field
32
+ const colorScheme = useColorScheme() ?? 'light'
33
+ const placeholderColor = usePlaceholderColor()
34
+ const renderOption = customRender ?? DefaultRenderOption
35
+ return (
36
+ <View style={[styles.container, style]}>
37
+ {!noLabel && <Text style={[styles.label, { color: placeholderColor }]}>{placeholder}</Text>}
38
+ {value ? renderOption(value, colorScheme, true) : 'None'}
39
+ </View>
40
+ )
41
+ }
@@ -0,0 +1,28 @@
1
+ import { FC } from 'react'
2
+ import { Path, Svg } from 'react-native-svg'
3
+
4
+ interface IconProps {
5
+ size?: number
6
+ color?: string
7
+ }
8
+
9
+ export const ChevronDownIcon: FC<IconProps> = ({ size = 24, color = '#000' }) => (
10
+ <Svg width={size} height={size} viewBox="0 0 24 24" fill="none">
11
+ <Path d="M7.41 8.59L12 13.17l4.59-4.58L18 10l-6 6-6-6 1.41-1.41z" fill={color} />
12
+ </Svg>
13
+ )
14
+
15
+ export const ChevronUpIcon: FC<IconProps> = ({ size = 24, color = '#000' }) => (
16
+ <Svg width={size} height={size} viewBox="0 0 24 24" fill="none">
17
+ <Path d="M7.41 15.41L12 10.83l4.59 4.58L18 14l-6-6-6 6 1.41 1.41z" fill={color} />
18
+ </Svg>
19
+ )
20
+
21
+ export const TrashIcon: FC<IconProps> = ({ size = 24, color = '#000' }) => (
22
+ <Svg width={size} height={size} viewBox="0 0 24 24" fill="none">
23
+ <Path
24
+ d="M6 19c0 1.1.9 2 2 2h8c1.1 0 2-.9 2-2V7H6v12zM19 4h-3.5l-1-1h-5l-1 1H5v2h14V4z"
25
+ fill={color}
26
+ />
27
+ </Svg>
28
+ )
@@ -0,0 +1,8 @@
1
+ export * from './box'
2
+ export * from './button'
3
+ export * from './feed'
4
+ export * from './form'
5
+ export * from './loading'
6
+ export * from './overlay'
7
+ export * from './text'
8
+ export * from './theme'
@@ -0,0 +1,53 @@
1
+ import { useColorModeValue } from '@chem-po/react'
2
+ import { useEffect, useRef } from 'react'
3
+ import {
4
+ ActivityIndicator,
5
+ ActivityIndicatorProps,
6
+ Animated,
7
+ StyleProp,
8
+ StyleSheet,
9
+ ViewStyle,
10
+ } from 'react-native'
11
+
12
+ export const CircularProgress = ({
13
+ color,
14
+ trackColor,
15
+ animating,
16
+ visible = true,
17
+ viewStyle,
18
+ ...props
19
+ }: ActivityIndicatorProps & {
20
+ trackColor?: string
21
+ viewStyle?: StyleProp<ViewStyle>
22
+ visible?: boolean
23
+ }) => {
24
+ const defaultTrackColor = useColorModeValue('#959595', '#575757')
25
+ const opacity = useRef(new Animated.Value(visible ? 1 : 0)).current
26
+
27
+ useEffect(() => {
28
+ Animated.timing(opacity, {
29
+ toValue: visible ? 1 : 0,
30
+ duration: 300,
31
+ useNativeDriver: true,
32
+ }).start()
33
+ }, [visible, opacity])
34
+ return (
35
+ <Animated.View style={[styles.container, { opacity }, viewStyle]}>
36
+ <ActivityIndicator
37
+ color={trackColor ?? defaultTrackColor} // Lighter version of your color
38
+ style={StyleSheet.absoluteFill}
39
+ animating={false}
40
+ {...props}
41
+ />
42
+ {/* Spinning circle */}
43
+ <ActivityIndicator animating={animating} color={color ?? '#575757'} {...props} />
44
+ </Animated.View>
45
+ )
46
+ }
47
+
48
+ const styles = StyleSheet.create({
49
+ container: {
50
+ alignItems: 'center',
51
+ justifyContent: 'center',
52
+ },
53
+ })
@@ -0,0 +1,181 @@
1
+ import { ThemedAsset, useAppAssets, useTheme } from '@chem-po/react'
2
+ import LottieView from 'lottie-react-native'
3
+ import { useMemo } from 'react'
4
+ import { Image, StyleSheet, Text, View, ViewStyle } from 'react-native'
5
+
6
+ export const LottieLoadingLogo = ({
7
+ size = 30,
8
+ isLoading,
9
+ speed = 2,
10
+ inFeed,
11
+ asset,
12
+ }: {
13
+ size?: number
14
+ color?: string
15
+ isLoading: boolean
16
+ asset: ThemedAsset
17
+ inFeed?: boolean
18
+ speed?: number
19
+ }) => {
20
+ const { colorMode } = useTheme()
21
+ const animationData = useMemo(
22
+ () =>
23
+ inFeed
24
+ ? (asset.dark ?? asset.default)
25
+ : colorMode === 'dark'
26
+ ? (asset.dark ?? asset.default)
27
+ : asset.default,
28
+ [asset, inFeed, colorMode],
29
+ )
30
+
31
+ const style = useMemo(
32
+ () => ({
33
+ width: size,
34
+ height: size,
35
+ opacity: isLoading ? 0.85 : 0,
36
+ }),
37
+ [size, isLoading],
38
+ )
39
+
40
+ return <LottieView source={animationData} autoPlay={isLoading} loop speed={speed} style={style} />
41
+ }
42
+
43
+ const SVGLoadingLogo = ({
44
+ size = 30,
45
+ isLoading,
46
+ asset,
47
+ inFeed,
48
+ }: {
49
+ size?: number
50
+ isLoading: boolean
51
+ asset: ThemedAsset
52
+ inFeed?: boolean
53
+ }) => {
54
+ const { colorMode } = useTheme()
55
+ const svg = useMemo(
56
+ () =>
57
+ inFeed
58
+ ? (asset.dark ?? asset.default)
59
+ : colorMode === 'dark'
60
+ ? (asset.dark ?? asset.default)
61
+ : asset.default,
62
+ [asset, inFeed, colorMode],
63
+ )
64
+
65
+ const style = useMemo(
66
+ () => ({
67
+ width: size,
68
+ height: size,
69
+ opacity: isLoading ? 0.85 : 0,
70
+ }),
71
+ [size, isLoading],
72
+ )
73
+
74
+ return <Image source={{ uri: svg }} style={style} />
75
+ }
76
+
77
+ const LoadingBody = ({ isLoading, size }: { isLoading: boolean; size?: number }) => {
78
+ const { loading } = useAppAssets()
79
+ if (loading.lottieJson)
80
+ return <LottieLoadingLogo isLoading={isLoading} size={size} asset={loading.lottieJson} />
81
+ if (loading.svg) return <SVGLoadingLogo isLoading={isLoading} size={size} asset={loading.svg} />
82
+ return null
83
+ }
84
+
85
+ export const LoadingLogo = ({
86
+ isLoading,
87
+ size,
88
+ inFeed,
89
+ }: {
90
+ isLoading: boolean
91
+ size?: number
92
+ inFeed?: boolean
93
+ }) => {
94
+ const { loading } = useAppAssets()
95
+ if (loading.lottieJson)
96
+ return (
97
+ <LottieLoadingLogo
98
+ inFeed={inFeed}
99
+ isLoading={isLoading}
100
+ size={size}
101
+ asset={loading.lottieJson}
102
+ />
103
+ )
104
+ if (loading.svg)
105
+ return <SVGLoadingLogo inFeed={inFeed} isLoading={isLoading} size={size} asset={loading.svg} />
106
+ return <Text style={styles.errorText}>ERROR: No loading animation found</Text>
107
+ }
108
+
109
+ export const Loading = ({
110
+ text = 'Loading...',
111
+ inBox,
112
+ containerStyle,
113
+ }: {
114
+ text?: string
115
+ inBox?: boolean
116
+ containerStyle?: ViewStyle
117
+ }) => {
118
+ const body = (
119
+ <View style={[styles.loadingContainer, containerStyle]}>
120
+ <LoadingBody isLoading />
121
+ <Text style={styles.loadingText}>{text}</Text>
122
+ </View>
123
+ )
124
+ return inBox ? <View style={styles.boxContainer}>{body}</View> : body
125
+ }
126
+
127
+ export const LoadingOverlay = ({
128
+ isLoading,
129
+ text,
130
+ inFeed,
131
+ style,
132
+ }: {
133
+ isLoading: boolean
134
+ text?: string
135
+ inFeed?: boolean
136
+ style?: ViewStyle
137
+ }) => {
138
+ const { colorMode } = useTheme()
139
+ const bgColor = colorMode === 'dark' ? 'rgba(0, 0, 0, 0.53)' : 'rgba(255, 255, 255, 0.67)'
140
+
141
+ return (
142
+ <View
143
+ style={[styles.overlay, { backgroundColor: bgColor }, { opacity: isLoading ? 1 : 0 }, style]}>
144
+ {!text ? (
145
+ <LoadingLogo inFeed={inFeed} size={100} isLoading={isLoading} />
146
+ ) : (
147
+ <Loading text={text} />
148
+ )}
149
+ </View>
150
+ )
151
+ }
152
+
153
+ const styles = StyleSheet.create({
154
+ loadingContainer: {
155
+ flexDirection: 'row',
156
+ alignItems: 'center',
157
+ padding: 8,
158
+ },
159
+ loadingText: {
160
+ opacity: 0.8,
161
+ fontSize: 14,
162
+ marginLeft: 8,
163
+ },
164
+ boxContainer: {
165
+ padding: 16,
166
+ borderRadius: 8,
167
+ backgroundColor: 'rgba(0, 0, 0, 0.05)',
168
+ },
169
+ overlay: {
170
+ position: 'absolute',
171
+ top: 0,
172
+ left: 0,
173
+ right: 0,
174
+ bottom: 0,
175
+ justifyContent: 'center',
176
+ alignItems: 'center',
177
+ },
178
+ errorText: {
179
+ color: 'red',
180
+ },
181
+ })