ferns-ui 0.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (521) hide show
  1. package/LICENSE +203 -0
  2. package/README.md +22 -0
  3. package/dist/ActionSheet.d.ts +490 -0
  4. package/dist/ActionSheet.js +647 -0
  5. package/dist/ActionSheet.js.map +1 -0
  6. package/dist/Banner.d.ts +27 -0
  7. package/dist/Banner.js +56 -0
  8. package/dist/Banner.js.map +1 -0
  9. package/dist/Banner.stories.d.ts +1 -0
  10. package/dist/Banner.stories.js +13 -0
  11. package/dist/Banner.stories.js.map +1 -0
  12. package/dist/BlurBox.d.ts +5 -0
  13. package/dist/BlurBox.js +28 -0
  14. package/dist/BlurBox.js.map +1 -0
  15. package/dist/BlurBox.native.d.ts +6 -0
  16. package/dist/BlurBox.native.js +30 -0
  17. package/dist/BlurBox.native.js.map +1 -0
  18. package/dist/Body.d.ts +6 -0
  19. package/dist/Body.js +21 -0
  20. package/dist/Body.js.map +1 -0
  21. package/dist/Box.d.ts +18 -0
  22. package/dist/Box.js +228 -0
  23. package/dist/Box.js.map +1 -0
  24. package/dist/Box.stories.d.ts +1 -0
  25. package/dist/Box.stories.js +45 -0
  26. package/dist/Box.stories.js.map +1 -0
  27. package/dist/Button.d.ts +20 -0
  28. package/dist/Button.js +103 -0
  29. package/dist/Button.js.map +1 -0
  30. package/dist/Button.stories.d.ts +1 -0
  31. package/dist/Button.stories.js +41 -0
  32. package/dist/Button.stories.js.map +1 -0
  33. package/dist/Card.d.ts +5 -0
  34. package/dist/Card.js +8 -0
  35. package/dist/Card.js.map +1 -0
  36. package/dist/Card.stories.d.ts +6 -0
  37. package/dist/Card.stories.js +18 -0
  38. package/dist/Card.stories.js.map +1 -0
  39. package/dist/CheckBox.d.ts +6 -0
  40. package/dist/CheckBox.js +27 -0
  41. package/dist/CheckBox.js.map +1 -0
  42. package/dist/CheckBox.stories.d.ts +1 -0
  43. package/dist/CheckBox.stories.js +28 -0
  44. package/dist/CheckBox.stories.js.map +1 -0
  45. package/dist/Common.d.ts +868 -0
  46. package/dist/Common.js +46 -0
  47. package/dist/Common.js.map +1 -0
  48. package/dist/DateTimeActionSheet.d.ts +15 -0
  49. package/dist/DateTimeActionSheet.js +28 -0
  50. package/dist/DateTimeActionSheet.js.map +1 -0
  51. package/dist/DecimalRangeActionSheet.d.ts +18 -0
  52. package/dist/DecimalRangeActionSheet.js +65 -0
  53. package/dist/DecimalRangeActionSheet.js.map +1 -0
  54. package/dist/ErrorBoundary.d.ts +19 -0
  55. package/dist/ErrorBoundary.js +31 -0
  56. package/dist/ErrorBoundary.js.map +1 -0
  57. package/dist/ErrorPage.d.ts +10 -0
  58. package/dist/ErrorPage.js +20 -0
  59. package/dist/ErrorPage.js.map +1 -0
  60. package/dist/Field.d.ts +15 -0
  61. package/dist/Field.js +136 -0
  62. package/dist/Field.js.map +1 -0
  63. package/dist/Field.stories.d.ts +6 -0
  64. package/dist/Field.stories.js +38 -0
  65. package/dist/Field.stories.js.map +1 -0
  66. package/dist/FieldWithLabels.d.ts +3 -0
  67. package/dist/FieldWithLabels.js +8 -0
  68. package/dist/FieldWithLabels.js.map +1 -0
  69. package/dist/FlatList.d.ts +2 -0
  70. package/dist/FlatList.js +3 -0
  71. package/dist/FlatList.js.map +1 -0
  72. package/dist/Form.d.ts +22 -0
  73. package/dist/Form.js +89 -0
  74. package/dist/Form.js.map +1 -0
  75. package/dist/Form.stories.d.ts +6 -0
  76. package/dist/Form.stories.js +36 -0
  77. package/dist/Form.stories.js.map +1 -0
  78. package/dist/HeaderButtons.d.ts +31 -0
  79. package/dist/HeaderButtons.js +53 -0
  80. package/dist/HeaderButtons.js.map +1 -0
  81. package/dist/HeaderButtons.stories.d.ts +6 -0
  82. package/dist/HeaderButtons.stories.js +6 -0
  83. package/dist/HeaderButtons.stories.js.map +1 -0
  84. package/dist/Heading.d.ts +11 -0
  85. package/dist/Heading.js +46 -0
  86. package/dist/Heading.js.map +1 -0
  87. package/dist/Heading.stories.d.ts +1 -0
  88. package/dist/Heading.stories.js +22 -0
  89. package/dist/Heading.stories.js.map +1 -0
  90. package/dist/HeightActionSheet.d.ts +16 -0
  91. package/dist/HeightActionSheet.js +58 -0
  92. package/dist/HeightActionSheet.js.map +1 -0
  93. package/dist/Icon.d.ts +9 -0
  94. package/dist/Icon.js +125 -0
  95. package/dist/Icon.js.map +1 -0
  96. package/dist/Icon.stories.d.ts +1 -0
  97. package/dist/Icon.stories.js +30 -0
  98. package/dist/Icon.stories.js.map +1 -0
  99. package/dist/IconButton.d.ts +5 -0
  100. package/dist/IconButton.js +41 -0
  101. package/dist/IconButton.js.map +1 -0
  102. package/dist/IconButton.stories.d.ts +1 -0
  103. package/dist/IconButton.stories.js +16 -0
  104. package/dist/IconButton.stories.js.map +1 -0
  105. package/dist/Image.d.ts +8 -0
  106. package/dist/Image.js +37 -0
  107. package/dist/Image.js.map +1 -0
  108. package/dist/ImageBackground.d.ts +9 -0
  109. package/dist/ImageBackground.js +8 -0
  110. package/dist/ImageBackground.js.map +1 -0
  111. package/dist/Layer.d.ts +9 -0
  112. package/dist/Layer.js +12 -0
  113. package/dist/Layer.js.map +1 -0
  114. package/dist/Link.d.ts +9 -0
  115. package/dist/Link.js +12 -0
  116. package/dist/Link.js.map +1 -0
  117. package/dist/Link.stories.d.ts +1 -0
  118. package/dist/Link.stories.js +18 -0
  119. package/dist/Link.stories.js.map +1 -0
  120. package/dist/Mask.d.ts +5 -0
  121. package/dist/Mask.js +22 -0
  122. package/dist/Mask.js.map +1 -0
  123. package/dist/Mask.stories.d.ts +1 -0
  124. package/dist/Mask.stories.js +28 -0
  125. package/dist/Mask.stories.js.map +1 -0
  126. package/dist/MediaQuery.d.ts +2 -0
  127. package/dist/MediaQuery.js +33 -0
  128. package/dist/MediaQuery.js.map +1 -0
  129. package/dist/Meta.d.ts +5 -0
  130. package/dist/Meta.js +7 -0
  131. package/dist/Meta.js.map +1 -0
  132. package/dist/ModalSheet.d.ts +7 -0
  133. package/dist/ModalSheet.js +42 -0
  134. package/dist/ModalSheet.js.map +1 -0
  135. package/dist/NumberPickerActionSheet.d.ts +16 -0
  136. package/dist/NumberPickerActionSheet.js +29 -0
  137. package/dist/NumberPickerActionSheet.js.map +1 -0
  138. package/dist/Page.d.ts +26 -0
  139. package/dist/Page.js +38 -0
  140. package/dist/Page.js.map +1 -0
  141. package/dist/Permissions.d.ts +2 -0
  142. package/dist/Permissions.js +35 -0
  143. package/dist/Permissions.js.map +1 -0
  144. package/dist/PickerSelect.d.ts +174 -0
  145. package/dist/PickerSelect.js +426 -0
  146. package/dist/PickerSelect.js.map +1 -0
  147. package/dist/Pill.d.ts +5 -0
  148. package/dist/Pill.js +10 -0
  149. package/dist/Pill.js.map +1 -0
  150. package/dist/Pill.stories.d.ts +1 -0
  151. package/dist/Pill.stories.js +38 -0
  152. package/dist/Pill.stories.js.map +1 -0
  153. package/dist/Pog.d.ts +15 -0
  154. package/dist/Pog.js +144 -0
  155. package/dist/Pog.js.map +1 -0
  156. package/dist/ProgressBar.d.ts +9 -0
  157. package/dist/ProgressBar.js +41 -0
  158. package/dist/ProgressBar.js.map +1 -0
  159. package/dist/ScrollView.d.ts +2 -0
  160. package/dist/ScrollView.js +3 -0
  161. package/dist/ScrollView.js.map +1 -0
  162. package/dist/SegmentedControl.d.ts +6 -0
  163. package/dist/SegmentedControl.js +18 -0
  164. package/dist/SegmentedControl.js.map +1 -0
  165. package/dist/SegmentedControl.stories.d.ts +1 -0
  166. package/dist/SegmentedControl.stories.js +31 -0
  167. package/dist/SegmentedControl.stories.js.map +1 -0
  168. package/dist/SelectList.d.ts +22 -0
  169. package/dist/SelectList.js +28 -0
  170. package/dist/SelectList.js.map +1 -0
  171. package/dist/SelectList.stories.d.ts +1 -0
  172. package/dist/SelectList.stories.js +26 -0
  173. package/dist/SelectList.stories.js.map +1 -0
  174. package/dist/Spinner.d.ts +21 -0
  175. package/dist/Spinner.js +58 -0
  176. package/dist/Spinner.js.map +1 -0
  177. package/dist/Spinner.stories.d.ts +1 -0
  178. package/dist/Spinner.stories.js +12 -0
  179. package/dist/Spinner.stories.js.map +1 -0
  180. package/dist/SplitPage.d.ts +31 -0
  181. package/dist/SplitPage.js +51 -0
  182. package/dist/SplitPage.js.map +1 -0
  183. package/dist/SplitPage.stories.d.ts +1 -0
  184. package/dist/SplitPage.stories.js +15 -0
  185. package/dist/SplitPage.stories.js.map +1 -0
  186. package/dist/StorybookContainer.d.ts +4 -0
  187. package/dist/StorybookContainer.js +8 -0
  188. package/dist/StorybookContainer.js.map +1 -0
  189. package/dist/Switch.d.ts +5 -0
  190. package/dist/Switch.js +10 -0
  191. package/dist/Switch.js.map +1 -0
  192. package/dist/Switch.stories.d.ts +1 -0
  193. package/dist/Switch.stories.js +34 -0
  194. package/dist/Switch.stories.js.map +1 -0
  195. package/dist/TapToEdit.d.ts +12 -0
  196. package/dist/TapToEdit.js +32 -0
  197. package/dist/TapToEdit.js.map +1 -0
  198. package/dist/Text.d.ts +11 -0
  199. package/dist/Text.js +85 -0
  200. package/dist/Text.js.map +1 -0
  201. package/dist/Text.stories.d.ts +1 -0
  202. package/dist/Text.stories.js +37 -0
  203. package/dist/Text.stories.js.map +1 -0
  204. package/dist/TextArea.d.ts +6 -0
  205. package/dist/TextArea.js +12 -0
  206. package/dist/TextArea.js.map +1 -0
  207. package/dist/TextArea.stories.d.ts +10 -0
  208. package/dist/TextArea.stories.js +24 -0
  209. package/dist/TextArea.stories.js.map +1 -0
  210. package/dist/TextField.d.ts +48 -0
  211. package/dist/TextField.js +207 -0
  212. package/dist/TextField.js.map +1 -0
  213. package/dist/TextField.stories.d.ts +6 -0
  214. package/dist/TextField.stories.js +18 -0
  215. package/dist/TextField.stories.js.map +1 -0
  216. package/dist/TextFieldNumberActionSheet.d.ts +15 -0
  217. package/dist/TextFieldNumberActionSheet.js +28 -0
  218. package/dist/TextFieldNumberActionSheet.js.map +1 -0
  219. package/dist/UnifiedScreens.d.ts +9 -0
  220. package/dist/UnifiedScreens.js +25 -0
  221. package/dist/UnifiedScreens.js.map +1 -0
  222. package/dist/Unifier.d.ts +40 -0
  223. package/dist/Unifier.js +203 -0
  224. package/dist/Unifier.js.map +1 -0
  225. package/dist/Utilities.d.ts +31 -0
  226. package/dist/Utilities.js +74 -0
  227. package/dist/Utilities.js.map +1 -0
  228. package/dist/WithLabel.d.ts +5 -0
  229. package/dist/WithLabel.js +27 -0
  230. package/dist/WithLabel.js.map +1 -0
  231. package/dist/dist/ActionSheet.d.ts +139 -0
  232. package/dist/dist/ActionSheet.js +637 -0
  233. package/dist/dist/ActionSheet.js.map +1 -0
  234. package/dist/dist/Banner.d.ts +12 -0
  235. package/dist/dist/Banner.js +49 -0
  236. package/dist/dist/Banner.js.map +1 -0
  237. package/dist/dist/Banner.stories.d.ts +1 -0
  238. package/dist/dist/Banner.stories.js +9 -0
  239. package/dist/dist/Banner.stories.js.map +1 -0
  240. package/dist/dist/BlurBox.d.ts +7 -0
  241. package/dist/dist/BlurBox.js +29 -0
  242. package/dist/dist/BlurBox.js.map +1 -0
  243. package/dist/dist/BlurBox.native.d.ts +9 -0
  244. package/dist/dist/BlurBox.native.js +32 -0
  245. package/dist/dist/BlurBox.native.js.map +1 -0
  246. package/dist/dist/Body.d.ts +12 -0
  247. package/dist/dist/Body.js +19 -0
  248. package/dist/dist/Body.js.map +1 -0
  249. package/dist/dist/Box.d.ts +205 -0
  250. package/dist/dist/Box.js +229 -0
  251. package/dist/dist/Box.js.map +1 -0
  252. package/dist/dist/Box.stories.d.ts +1 -0
  253. package/dist/dist/Box.stories.js +37 -0
  254. package/dist/dist/Box.stories.js.map +1 -0
  255. package/dist/dist/Button.d.ts +16 -0
  256. package/dist/dist/Button.js +98 -0
  257. package/dist/dist/Button.js.map +1 -0
  258. package/dist/dist/Button.stories.d.ts +13 -0
  259. package/dist/dist/Button.stories.js +26 -0
  260. package/dist/dist/Button.stories.js.map +1 -0
  261. package/dist/dist/Card.d.ts +6 -0
  262. package/dist/dist/Card.js +9 -0
  263. package/dist/dist/Card.js.map +1 -0
  264. package/dist/dist/Card.stories.d.ts +6 -0
  265. package/dist/dist/Card.stories.js +11 -0
  266. package/dist/dist/Card.stories.js.map +1 -0
  267. package/dist/dist/CheckBox.d.ts +8 -0
  268. package/dist/dist/CheckBox.js +23 -0
  269. package/dist/dist/CheckBox.js.map +1 -0
  270. package/dist/dist/CheckBox.stories.d.ts +1 -0
  271. package/dist/dist/CheckBox.stories.js +22 -0
  272. package/dist/dist/CheckBox.stories.js.map +1 -0
  273. package/dist/dist/Common.d.ts +5 -0
  274. package/dist/dist/Common.js +47 -0
  275. package/dist/dist/Common.js.map +1 -0
  276. package/dist/dist/DateTimeActionSheet.d.ts +5 -0
  277. package/dist/dist/DateTimeActionSheet.js +24 -0
  278. package/dist/dist/DateTimeActionSheet.js.map +1 -0
  279. package/dist/dist/DecimalRangeActionSheet.d.ts +9 -0
  280. package/dist/dist/DecimalRangeActionSheet.js +57 -0
  281. package/dist/dist/DecimalRangeActionSheet.js.map +1 -0
  282. package/dist/dist/ErrorBoundary.d.ts +12 -0
  283. package/dist/dist/ErrorBoundary.js +32 -0
  284. package/dist/dist/ErrorBoundary.js.map +1 -0
  285. package/dist/dist/ErrorPage.d.ts +7 -0
  286. package/dist/dist/ErrorPage.js +15 -0
  287. package/dist/dist/ErrorPage.js.map +1 -0
  288. package/dist/dist/Field.d.ts +17 -0
  289. package/dist/dist/Field.js +136 -0
  290. package/dist/dist/Field.js.map +1 -0
  291. package/dist/dist/Field.stories.d.ts +6 -0
  292. package/dist/dist/Field.stories.js +25 -0
  293. package/dist/dist/Field.stories.js.map +1 -0
  294. package/dist/dist/FieldWithLabels.d.ts +10 -0
  295. package/dist/dist/FieldWithLabels.js +7 -0
  296. package/dist/dist/FieldWithLabels.js.map +1 -0
  297. package/dist/dist/FlatList.d.ts +1 -0
  298. package/dist/dist/FlatList.js +4 -0
  299. package/dist/dist/FlatList.js.map +1 -0
  300. package/dist/dist/Form.d.ts +15 -0
  301. package/dist/dist/Form.js +56 -0
  302. package/dist/dist/Form.js.map +1 -0
  303. package/dist/dist/Form.stories.d.ts +6 -0
  304. package/dist/dist/Form.stories.js +27 -0
  305. package/dist/dist/Form.stories.js.map +1 -0
  306. package/dist/dist/HeaderButtons.d.ts +39 -0
  307. package/dist/dist/HeaderButtons.js +50 -0
  308. package/dist/dist/HeaderButtons.js.map +1 -0
  309. package/dist/dist/HeaderButtons.stories.d.ts +6 -0
  310. package/dist/dist/HeaderButtons.stories.js +7 -0
  311. package/dist/dist/HeaderButtons.stories.js.map +1 -0
  312. package/dist/dist/Heading.d.ts +32 -0
  313. package/dist/dist/Heading.js +47 -0
  314. package/dist/dist/Heading.js.map +1 -0
  315. package/dist/dist/Heading.stories.d.ts +1 -0
  316. package/dist/dist/Heading.stories.js +11 -0
  317. package/dist/dist/Heading.stories.js.map +1 -0
  318. package/dist/dist/HeightActionSheet.d.ts +9 -0
  319. package/dist/dist/HeightActionSheet.js +50 -0
  320. package/dist/dist/HeightActionSheet.js.map +1 -0
  321. package/dist/dist/Icon.d.ts +12 -0
  322. package/dist/dist/Icon.js +126 -0
  323. package/dist/dist/Icon.js.map +1 -0
  324. package/dist/dist/Icon.stories.d.ts +1 -0
  325. package/dist/dist/Icon.stories.js +11 -0
  326. package/dist/dist/Icon.stories.js.map +1 -0
  327. package/dist/dist/IconButton.d.ts +42 -0
  328. package/dist/dist/IconButton.js +41 -0
  329. package/dist/dist/IconButton.js.map +1 -0
  330. package/dist/dist/IconButton.stories.d.ts +1 -0
  331. package/dist/dist/IconButton.stories.js +8 -0
  332. package/dist/dist/IconButton.stories.js.map +1 -0
  333. package/dist/dist/Image.d.ts +9 -0
  334. package/dist/dist/Image.js +37 -0
  335. package/dist/dist/Image.js.map +1 -0
  336. package/dist/dist/ImageBackground.d.ts +6 -0
  337. package/dist/dist/ImageBackground.js +9 -0
  338. package/dist/dist/ImageBackground.js.map +1 -0
  339. package/dist/dist/Layer.d.ts +5 -0
  340. package/dist/dist/Layer.js +13 -0
  341. package/dist/dist/Layer.js.map +1 -0
  342. package/dist/dist/Link.d.ts +7 -0
  343. package/dist/dist/Link.js +13 -0
  344. package/dist/dist/Link.js.map +1 -0
  345. package/dist/dist/Link.stories.d.ts +1 -0
  346. package/dist/dist/Link.stories.js +8 -0
  347. package/dist/dist/Link.stories.js.map +1 -0
  348. package/dist/dist/Mask.d.ts +5 -0
  349. package/dist/dist/Mask.js +23 -0
  350. package/dist/dist/Mask.js.map +1 -0
  351. package/dist/dist/Mask.stories.d.ts +1 -0
  352. package/dist/dist/Mask.stories.js +13 -0
  353. package/dist/dist/Mask.stories.js.map +1 -0
  354. package/dist/dist/MediaQuery.d.ts +2 -0
  355. package/dist/dist/MediaQuery.js +34 -0
  356. package/dist/dist/MediaQuery.js.map +1 -0
  357. package/dist/dist/Meta.d.ts +6 -0
  358. package/dist/dist/Meta.js +8 -0
  359. package/dist/dist/Meta.js.map +1 -0
  360. package/dist/dist/ModalSheet.d.ts +3 -0
  361. package/dist/dist/ModalSheet.js +43 -0
  362. package/dist/dist/ModalSheet.js.map +1 -0
  363. package/dist/dist/NumberPickerActionSheet.d.ts +5 -0
  364. package/dist/dist/NumberPickerActionSheet.js +25 -0
  365. package/dist/dist/NumberPickerActionSheet.js.map +1 -0
  366. package/dist/dist/Page.d.ts +9 -0
  367. package/dist/dist/Page.js +26 -0
  368. package/dist/dist/Page.js.map +1 -0
  369. package/dist/dist/Permissions.d.ts +1 -0
  370. package/dist/dist/Permissions.js +36 -0
  371. package/dist/dist/Permissions.js.map +1 -0
  372. package/dist/dist/PickerSelect.d.ts +172 -0
  373. package/dist/dist/PickerSelect.js +403 -0
  374. package/dist/dist/PickerSelect.js.map +1 -0
  375. package/dist/dist/Pill.d.ts +7 -0
  376. package/dist/dist/Pill.js +10 -0
  377. package/dist/dist/Pill.js.map +1 -0
  378. package/dist/dist/Pill.stories.d.ts +1 -0
  379. package/dist/dist/Pill.stories.js +36 -0
  380. package/dist/dist/Pill.stories.js.map +1 -0
  381. package/dist/dist/Pog.d.ts +7 -0
  382. package/dist/dist/Pog.js +144 -0
  383. package/dist/dist/Pog.js.map +1 -0
  384. package/dist/dist/ProgressBar.d.ts +16 -0
  385. package/dist/dist/ProgressBar.js +40 -0
  386. package/dist/dist/ProgressBar.js.map +1 -0
  387. package/dist/dist/ScrollView.d.ts +1 -0
  388. package/dist/dist/ScrollView.js +4 -0
  389. package/dist/dist/ScrollView.js.map +1 -0
  390. package/dist/dist/SegmentedControl.d.ts +9 -0
  391. package/dist/dist/SegmentedControl.js +18 -0
  392. package/dist/dist/SegmentedControl.js.map +1 -0
  393. package/dist/dist/SegmentedControl.stories.d.ts +1 -0
  394. package/dist/dist/SegmentedControl.stories.js +32 -0
  395. package/dist/dist/SegmentedControl.stories.js.map +1 -0
  396. package/dist/dist/SelectList.d.ts +9 -0
  397. package/dist/dist/SelectList.js +29 -0
  398. package/dist/dist/SelectList.js.map +1 -0
  399. package/dist/dist/SelectList.stories.d.ts +1 -0
  400. package/dist/dist/SelectList.stories.js +24 -0
  401. package/dist/dist/SelectList.stories.js.map +1 -0
  402. package/dist/dist/Spinner.d.ts +44 -0
  403. package/dist/dist/Spinner.js +58 -0
  404. package/dist/dist/Spinner.js.map +1 -0
  405. package/dist/dist/Spinner.stories.d.ts +1 -0
  406. package/dist/dist/Spinner.stories.js +10 -0
  407. package/dist/dist/Spinner.stories.js.map +1 -0
  408. package/dist/dist/SplitPage.d.ts +7 -0
  409. package/dist/dist/SplitPage.js +20 -0
  410. package/dist/dist/SplitPage.js.map +1 -0
  411. package/dist/dist/SplitPage.stories.d.ts +1 -0
  412. package/dist/dist/SplitPage.stories.js +7 -0
  413. package/dist/dist/SplitPage.stories.js.map +1 -0
  414. package/dist/dist/StorybookContainer.d.ts +7 -0
  415. package/dist/dist/StorybookContainer.js +9 -0
  416. package/dist/dist/StorybookContainer.js.map +1 -0
  417. package/dist/dist/Switch.d.ts +6 -0
  418. package/dist/dist/Switch.js +10 -0
  419. package/dist/dist/Switch.js.map +1 -0
  420. package/dist/dist/Switch.stories.d.ts +1 -0
  421. package/dist/dist/Switch.stories.js +27 -0
  422. package/dist/dist/Switch.stories.js.map +1 -0
  423. package/dist/dist/TapToEdit.d.ts +9 -0
  424. package/dist/dist/TapToEdit.js +27 -0
  425. package/dist/dist/TapToEdit.js.map +1 -0
  426. package/dist/dist/Text.d.ts +36 -0
  427. package/dist/dist/Text.js +86 -0
  428. package/dist/dist/Text.js.map +1 -0
  429. package/dist/dist/Text.stories.d.ts +1 -0
  430. package/dist/dist/Text.stories.js +13 -0
  431. package/dist/dist/Text.stories.js.map +1 -0
  432. package/dist/dist/TextArea.d.ts +6 -0
  433. package/dist/dist/TextArea.js +13 -0
  434. package/dist/dist/TextArea.js.map +1 -0
  435. package/dist/dist/TextArea.stories.d.ts +12 -0
  436. package/dist/dist/TextArea.stories.js +21 -0
  437. package/dist/dist/TextArea.stories.js.map +1 -0
  438. package/dist/dist/TextField.d.ts +47 -0
  439. package/dist/dist/TextField.js +199 -0
  440. package/dist/dist/TextField.js.map +1 -0
  441. package/dist/dist/TextField.stories.d.ts +6 -0
  442. package/dist/dist/TextField.stories.js +15 -0
  443. package/dist/dist/TextField.stories.js.map +1 -0
  444. package/dist/dist/TextFieldNumberActionSheet.d.ts +5 -0
  445. package/dist/dist/TextFieldNumberActionSheet.js +24 -0
  446. package/dist/dist/TextFieldNumberActionSheet.js.map +1 -0
  447. package/dist/dist/UnifiedScreens.d.ts +2 -0
  448. package/dist/dist/UnifiedScreens.js +26 -0
  449. package/dist/dist/UnifiedScreens.js.map +1 -0
  450. package/dist/dist/Unifier.d.ts +131 -0
  451. package/dist/dist/Unifier.js +198 -0
  452. package/dist/dist/Unifier.js.map +1 -0
  453. package/dist/dist/Utilities.d.ts +51 -0
  454. package/dist/dist/Utilities.js +77 -0
  455. package/dist/dist/Utilities.js.map +1 -0
  456. package/dist/dist/WithLabel.d.ts +6 -0
  457. package/dist/dist/WithLabel.js +23 -0
  458. package/dist/dist/WithLabel.js.map +1 -0
  459. package/dist/dist/index.d.ts +43 -0
  460. package/dist/dist/index.js +49 -0
  461. package/dist/dist/index.js.map +1 -0
  462. package/dist/index.d.ts +1284 -0
  463. package/dist/index.js +49 -0
  464. package/dist/index.js.map +1 -0
  465. package/package.json +197 -0
  466. package/src/ActionSheet.tsx +1234 -0
  467. package/src/Banner.tsx +124 -0
  468. package/src/BlurBox.native.tsx +40 -0
  469. package/src/BlurBox.tsx +31 -0
  470. package/src/Body.tsx +32 -0
  471. package/src/Box.tsx +277 -0
  472. package/src/Button.tsx +139 -0
  473. package/src/Card.tsx +23 -0
  474. package/src/CheckBox.tsx +93 -0
  475. package/src/Common.ts +1376 -0
  476. package/src/DateTimeActionSheet.tsx +61 -0
  477. package/src/DecimalRangeActionSheet.tsx +113 -0
  478. package/src/ErrorBoundary.tsx +39 -0
  479. package/src/ErrorPage.tsx +44 -0
  480. package/src/Field.tsx +194 -0
  481. package/src/FieldWithLabels.tsx +36 -0
  482. package/src/FlatList.tsx +2 -0
  483. package/src/Form.tsx +182 -0
  484. package/src/HeaderButtons.tsx +107 -0
  485. package/src/Heading.tsx +53 -0
  486. package/src/HeightActionSheet.tsx +104 -0
  487. package/src/Icon.tsx +139 -0
  488. package/src/IconButton.tsx +52 -0
  489. package/src/Image.tsx +50 -0
  490. package/src/ImageBackground.tsx +13 -0
  491. package/src/Layer.tsx +17 -0
  492. package/src/Link.tsx +17 -0
  493. package/src/Mask.tsx +24 -0
  494. package/src/MediaQuery.ts +28 -0
  495. package/src/Meta.tsx +9 -0
  496. package/src/ModalSheet.tsx +58 -0
  497. package/src/NumberPickerActionSheet.tsx +66 -0
  498. package/src/Page.tsx +134 -0
  499. package/src/Permissions.ts +44 -0
  500. package/src/PickerSelect.tsx +673 -0
  501. package/src/Pill.tsx +24 -0
  502. package/src/Pog.tsx +211 -0
  503. package/src/ProgressBar.tsx +55 -0
  504. package/src/ScrollView.tsx +2 -0
  505. package/src/SegmentedControl.tsx +51 -0
  506. package/src/SelectList.tsx +48 -0
  507. package/src/Spinner.tsx +69 -0
  508. package/src/SplitPage.tsx +115 -0
  509. package/src/Switch.tsx +19 -0
  510. package/src/TapToEdit.tsx +48 -0
  511. package/src/Text.tsx +92 -0
  512. package/src/TextArea.tsx +15 -0
  513. package/src/TextField.tsx +291 -0
  514. package/src/TextFieldNumberActionSheet.tsx +61 -0
  515. package/src/UnifiedScreens.ts +24 -0
  516. package/src/Unifier.ts +268 -0
  517. package/src/Utilities.tsx +161 -0
  518. package/src/WithLabel.tsx +46 -0
  519. package/src/index.tsx +1332 -0
  520. package/src/polyfill.d.ts +11 -0
  521. package/tsconfig.json +29 -0
@@ -0,0 +1,647 @@
1
+ /* eslint-disable react/prop-types */
2
+ import React, { Component, createRef } from "react";
3
+ import { Animated, Dimensions, findNodeHandle, FlatList, Keyboard, Modal, Platform, SafeAreaView, StatusBar, StyleSheet, TextInput, TouchableOpacity, UIManager, View, } from "react-native";
4
+ export const styles = StyleSheet.create({
5
+ scrollView: {
6
+ height: "100%",
7
+ width: "100%",
8
+ backgroundColor: "transparent",
9
+ },
10
+ container: {
11
+ width: "100%",
12
+ backgroundColor: "white",
13
+ alignSelf: "center",
14
+ },
15
+ safearea: {
16
+ position: "absolute",
17
+ top: 999999,
18
+ left: 999999,
19
+ },
20
+ indicator: {
21
+ height: 6,
22
+ width: 45,
23
+ borderRadius: 100,
24
+ backgroundColor: "#f0f0f0",
25
+ marginVertical: 5,
26
+ alignSelf: "center",
27
+ },
28
+ parentContainer: {
29
+ width: "100%",
30
+ height: "100%",
31
+ justifyContent: "center",
32
+ alignItems: "center",
33
+ },
34
+ });
35
+ export function getDeviceHeight(statusBarTranslucent) {
36
+ const height = Dimensions.get("window").height;
37
+ if (Platform.OS === "android" && !statusBarTranslucent) {
38
+ return StatusBar.currentHeight ? height - StatusBar.currentHeight : height;
39
+ }
40
+ return height;
41
+ }
42
+ export const getElevation = (elevation) => {
43
+ if (!elevation) {
44
+ return {};
45
+ }
46
+ return {
47
+ elevation,
48
+ shadowColor: "black",
49
+ shadowOffset: { width: 0.3 * elevation, height: 0.5 * elevation },
50
+ shadowOpacity: 0.2,
51
+ shadowRadius: 0.7 * elevation,
52
+ };
53
+ };
54
+ export const SUPPORTED_ORIENTATIONS = ["portrait", "portrait-upside-down", "landscape", "landscape-left", "landscape-right"];
55
+ export const waitAsync = (ms) => new Promise((resolve) => {
56
+ setTimeout(() => {
57
+ resolve(null);
58
+ }, ms);
59
+ });
60
+ const safeAreaInnerHeight = 0;
61
+ const dummyData = ["dummy"];
62
+ let safeAreaPaddingTop = Platform.OS === "android" ? StatusBar.currentHeight || 0 : 0;
63
+ let calculatedDeviceHeight = Dimensions.get("window").height;
64
+ const defaultProps = {
65
+ animated: true,
66
+ closeOnPressBack: true,
67
+ bounciness: 8,
68
+ extraScroll: 0,
69
+ closeAnimationDuration: 300,
70
+ delayActionSheetDrawTime: 0,
71
+ openAnimationSpeed: 12,
72
+ springOffset: 100,
73
+ elevation: 5,
74
+ initialOffsetFromBottom: 1,
75
+ indicatorColor: "#f0f0f0",
76
+ defaultOverlayOpacity: 0.3,
77
+ overlayColor: "black",
78
+ closable: true,
79
+ bottomOffset: 0,
80
+ closeOnTouchBackdrop: true,
81
+ drawUnderStatusBar: true,
82
+ statusBarTranslucent: true,
83
+ keyboardMode: "padding",
84
+ gestureEnabled: false,
85
+ };
86
+ export class ActionSheet extends Component {
87
+ constructor(props) {
88
+ super(props);
89
+ this.actionSheetHeight = 0;
90
+ this.prevScroll = 0;
91
+ this.timeout = null;
92
+ this.offsetY = 0;
93
+ this.currentOffsetFromBottom = 0;
94
+ this.scrollAnimationEndValue = 0;
95
+ this.hasBounced = false;
96
+ this.layoutHasCalled = false;
97
+ this.isClosing = false;
98
+ this.isRecoiling = false;
99
+ this.isReachedTop = false;
100
+ this.deviceLayoutCalled = false;
101
+ /**
102
+ * Snap ActionSheet to Offset
103
+ */
104
+ this.snapToOffset = (offset) => {
105
+ const correction = this.state.deviceHeight * 0.15;
106
+ const extraScroll = this.props.extraScroll || 0;
107
+ const scrollOffset = this.props.gestureEnabled
108
+ ? offset + correction + extraScroll
109
+ : offset + correction + extraScroll;
110
+ this.currentOffsetFromBottom = offset / this.actionSheetHeight;
111
+ this._scrollTo(scrollOffset);
112
+ this.updateActionSheetPosition(scrollOffset);
113
+ };
114
+ // Open the ActionSheet
115
+ this.show = () => {
116
+ this.setModalVisible(true);
117
+ };
118
+ // Close the ActionSheet
119
+ this.hide = () => {
120
+ this.setModalVisible(false);
121
+ };
122
+ /**
123
+ * Open/Close the ActionSheet
124
+ */
125
+ this.setModalVisible = (visible) => {
126
+ let modalVisible = this.state.modalVisible;
127
+ if (visible !== undefined) {
128
+ if (modalVisible === visible) {
129
+ return;
130
+ }
131
+ modalVisible = !visible;
132
+ }
133
+ if (!modalVisible) {
134
+ this.setState({
135
+ modalVisible: true,
136
+ scrollable: this.props.gestureEnabled || false,
137
+ });
138
+ }
139
+ else {
140
+ this._hideModal();
141
+ }
142
+ };
143
+ this._hideModal = () => {
144
+ if (this.isClosing)
145
+ return;
146
+ this.isClosing = true;
147
+ this._hideAnimation();
148
+ };
149
+ this.measure = async () => {
150
+ return new Promise((resolve) => {
151
+ setTimeout(() => {
152
+ UIManager.measureInWindow(this.safeAreaViewRef.current._nativeTag, (x, y, width, height) => {
153
+ safeAreaPaddingTop = height;
154
+ resolve(height === 0 ? 20 : height);
155
+ });
156
+ }, 100);
157
+ });
158
+ };
159
+ this._showModal = async (event) => {
160
+ const { gestureEnabled, delayActionSheetDraw, delayActionSheetDrawTime } = this.props;
161
+ if (!(event === null || event === void 0 ? void 0 : event.nativeEvent))
162
+ return;
163
+ const height = event.nativeEvent.layout.height;
164
+ if (this.layoutHasCalled) {
165
+ this.actionSheetHeight = height;
166
+ this._returnToPrevScrollPosition(height);
167
+ return;
168
+ }
169
+ else {
170
+ this.layoutHasCalled = true;
171
+ this.actionSheetHeight = height;
172
+ const scrollOffset = this.getInitialScrollPosition();
173
+ this.isRecoiling = false;
174
+ if (Platform.OS === "ios") {
175
+ await waitAsync(delayActionSheetDrawTime);
176
+ }
177
+ else {
178
+ if (delayActionSheetDraw) {
179
+ await waitAsync(delayActionSheetDrawTime);
180
+ }
181
+ }
182
+ this._scrollTo(scrollOffset, false);
183
+ this.prevScroll = scrollOffset;
184
+ if (Platform.OS === "ios") {
185
+ await waitAsync(delayActionSheetDrawTime !== null && delayActionSheetDrawTime !== void 0 ? delayActionSheetDrawTime : 0 / 2);
186
+ }
187
+ else {
188
+ if (delayActionSheetDraw) {
189
+ await waitAsync(delayActionSheetDrawTime !== null && delayActionSheetDrawTime !== void 0 ? delayActionSheetDrawTime : 0 / 2);
190
+ }
191
+ }
192
+ this._openAnimation(scrollOffset);
193
+ this.underlayScale.setValue(1);
194
+ this.underlayTranslateY.setValue(100);
195
+ if (!gestureEnabled) {
196
+ this.props.onPositionChanged && this.props.onPositionChanged(true);
197
+ }
198
+ this.updateActionSheetPosition(scrollOffset);
199
+ }
200
+ };
201
+ this._openAnimation = (scrollOffset) => {
202
+ const { bounciness, bounceOnOpen, animated, openAnimationSpeed } = this.props;
203
+ if (animated) {
204
+ this.transformValue.setValue(scrollOffset);
205
+ Animated.parallel([
206
+ Animated.spring(this.transformValue, {
207
+ toValue: 0,
208
+ bounciness: bounceOnOpen ? bounciness : 1,
209
+ speed: openAnimationSpeed,
210
+ useNativeDriver: true,
211
+ }),
212
+ Animated.timing(this.opacityValue, {
213
+ toValue: 1,
214
+ duration: 150,
215
+ useNativeDriver: true,
216
+ }),
217
+ ]).start();
218
+ }
219
+ else {
220
+ this.opacityValue.setValue(1);
221
+ }
222
+ };
223
+ this._onScrollBegin = async () => { };
224
+ this._onScrollBeginDrag = async (event) => {
225
+ this.prevScroll = event.nativeEvent.contentOffset.y;
226
+ };
227
+ this._onScrollEnd = async (event) => {
228
+ var _a;
229
+ const { springOffset, extraScroll } = this.props;
230
+ const verticalOffset = event.nativeEvent.contentOffset.y;
231
+ const correction = this.state.deviceHeight * 0.15;
232
+ if (this.isRecoiling)
233
+ return;
234
+ if (this.prevScroll < verticalOffset) {
235
+ if (verticalOffset - this.prevScroll > (springOffset !== null && springOffset !== void 0 ? springOffset : 0) * 0.75) {
236
+ this.isRecoiling = true;
237
+ this._applyHeightLimiter();
238
+ this.currentOffsetFromBottom =
239
+ this.currentOffsetFromBottom < ((_a = this.props.initialOffsetFromBottom) !== null && _a !== void 0 ? _a : 0)
240
+ ? this.props.initialOffsetFromBottom
241
+ : 1;
242
+ const scrollOffset = this.actionSheetHeight * this.currentOffsetFromBottom + correction + (extraScroll !== null && extraScroll !== void 0 ? extraScroll : 0);
243
+ this._scrollTo(scrollOffset);
244
+ await waitAsync(300);
245
+ this.isRecoiling = false;
246
+ this.props.onPositionChanged && this.props.onPositionChanged(true);
247
+ }
248
+ else {
249
+ this._returnToPrevScrollPosition(this.actionSheetHeight);
250
+ }
251
+ }
252
+ else {
253
+ if (this.prevScroll - verticalOffset > (springOffset !== null && springOffset !== void 0 ? springOffset : 0)) {
254
+ this._hideModal();
255
+ }
256
+ else {
257
+ if (this.isRecoiling) {
258
+ return;
259
+ }
260
+ this.isRecoiling = true;
261
+ this._returnToPrevScrollPosition(this.actionSheetHeight);
262
+ await waitAsync(300);
263
+ this.isRecoiling = false;
264
+ }
265
+ }
266
+ };
267
+ this._scrollTo = (y, animated = true) => {
268
+ var _a;
269
+ this.scrollAnimationEndValue = y;
270
+ this.prevScroll = y;
271
+ (_a = this.scrollViewRef.current) === null || _a === void 0 ? void 0 : _a._listRef._scrollRef.scrollTo({
272
+ x: 0,
273
+ y: this.scrollAnimationEndValue,
274
+ animated,
275
+ });
276
+ };
277
+ this._onTouchMove = () => {
278
+ if (this.props.closeOnTouchBackdrop) {
279
+ this._hideModal();
280
+ }
281
+ this.setState({
282
+ scrollable: false,
283
+ });
284
+ };
285
+ this._onTouchStart = () => {
286
+ if (this.props.closeOnTouchBackdrop) {
287
+ this._hideModal();
288
+ }
289
+ this.setState({
290
+ scrollable: false,
291
+ });
292
+ };
293
+ this._onTouchEnd = () => {
294
+ this._returnToPrevScrollPosition(this.actionSheetHeight);
295
+ if (this.props.gestureEnabled) {
296
+ this.setState({
297
+ scrollable: true,
298
+ });
299
+ }
300
+ };
301
+ this._onScroll = (event) => {
302
+ this.offsetY = event.nativeEvent.contentOffset.y;
303
+ const correction = this.state.deviceHeight * 0.15;
304
+ const distanceFromTop = this.actionSheetHeight + correction - this.offsetY;
305
+ if (this.actionSheetHeight < this.offsetY) {
306
+ if (!this.isReachedTop) {
307
+ this.isReachedTop = true;
308
+ this.props.onPositionChanged && this.props.onPositionChanged(true);
309
+ }
310
+ }
311
+ else {
312
+ if (this.isReachedTop) {
313
+ this.isReachedTop = false;
314
+ this.props.onPositionChanged && this.props.onPositionChanged(false);
315
+ }
316
+ }
317
+ if (this.actionSheetHeight >= this.state.deviceHeight - 1) {
318
+ if (distanceFromTop < safeAreaPaddingTop) {
319
+ if (!this.props.drawUnderStatusBar)
320
+ return;
321
+ this.indicatorTranslateY.setValue(-this.state.paddingTop + (safeAreaPaddingTop - distanceFromTop));
322
+ }
323
+ else {
324
+ this.indicatorTranslateY.setValue(-safeAreaPaddingTop);
325
+ }
326
+ }
327
+ };
328
+ this._onRequestClose = () => {
329
+ if (this.props.closeOnPressBack)
330
+ this._hideModal();
331
+ };
332
+ this._onTouchBackdrop = () => {
333
+ if (this.props.closeOnTouchBackdrop) {
334
+ this._hideModal();
335
+ }
336
+ };
337
+ this._onKeyboardShow = (event) => {
338
+ this.setState({
339
+ keyboard: true,
340
+ });
341
+ // eslint-disable-next-line @typescript-eslint/no-var-requires
342
+ const ReactNativeVersion = require("react-native/Libraries/Core/ReactNativeVersion");
343
+ let v = ReactNativeVersion.version.major + ReactNativeVersion.version.minor;
344
+ v = parseInt(v);
345
+ if (v >= 63 || Platform.OS === "ios") {
346
+ const keyboardHeight = event.endCoordinates.height;
347
+ const { height: windowHeight } = Dimensions.get("window");
348
+ const currentlyFocusedField = TextInput.State.currentlyFocusedField
349
+ ? findNodeHandle(TextInput.State.currentlyFocusedField())
350
+ : TextInput.State.currentlyFocusedField();
351
+ if (!currentlyFocusedField) {
352
+ return;
353
+ }
354
+ UIManager.measure(currentlyFocusedField, (originX, originY, width, height, pageX, pageY) => {
355
+ const fieldHeight = height;
356
+ const fieldTop = pageY;
357
+ const gap = windowHeight - keyboardHeight - (fieldTop + fieldHeight);
358
+ if (gap >= 0) {
359
+ return;
360
+ }
361
+ const toValue = this.props.keyboardMode === "position" ? -(keyboardHeight + 15) : gap - 10;
362
+ Animated.timing(this.transformValue, {
363
+ toValue,
364
+ duration: 250,
365
+ useNativeDriver: true,
366
+ }).start();
367
+ });
368
+ }
369
+ else {
370
+ Animated.timing(this.transformValue, {
371
+ toValue: -10,
372
+ duration: 250,
373
+ useNativeDriver: true,
374
+ }).start();
375
+ }
376
+ };
377
+ /**
378
+ * Attach this to any child ScrollView Component's onScrollEndDrag,
379
+ * onMomentumScrollEnd,onScrollAnimationEnd callbacks to handle the ActionSheet
380
+ * closing and bouncing back properly.
381
+ */
382
+ this.handleChildScrollEnd = async () => {
383
+ var _a, _b;
384
+ if (this.offsetY > this.prevScroll)
385
+ return;
386
+ if (this.prevScroll - ((_a = this.props.springOffset) !== null && _a !== void 0 ? _a : 0) > this.offsetY) {
387
+ const scrollOffset = this.getInitialScrollPosition();
388
+ if (this.offsetY > scrollOffset - 100) {
389
+ this.isRecoiling = true;
390
+ this._scrollTo(scrollOffset);
391
+ this.currentOffsetFromBottom = (_b = this.props.initialOffsetFromBottom) !== null && _b !== void 0 ? _b : 0;
392
+ this.prevScroll = scrollOffset;
393
+ setTimeout(() => {
394
+ this.isRecoiling = false;
395
+ }, 500);
396
+ }
397
+ else {
398
+ this._hideModal();
399
+ }
400
+ }
401
+ else {
402
+ this.isRecoiling = true;
403
+ this._scrollTo(this.prevScroll, true);
404
+ setTimeout(() => {
405
+ this.isRecoiling = false;
406
+ }, 500);
407
+ }
408
+ };
409
+ this._onKeyboardHide = () => {
410
+ this.setState({
411
+ keyboard: false,
412
+ });
413
+ this.opacityValue.setValue(1);
414
+ Animated.timing(this.transformValue, {
415
+ toValue: 0,
416
+ duration: 100,
417
+ useNativeDriver: true,
418
+ }).start();
419
+ };
420
+ this._onDeviceLayout = async (_event) => {
421
+ const event = Object.assign({}, _event);
422
+ if (this.timeout) {
423
+ clearTimeout(this.timeout);
424
+ }
425
+ this.timeout = setTimeout(async () => {
426
+ var _a;
427
+ let safeMarginFromTop = 0;
428
+ const measuredPadding = Platform.OS === "ios" ? await this.measure() : StatusBar.currentHeight;
429
+ if (!this.props.drawUnderStatusBar) {
430
+ if (Platform.OS === "android" && !this.props.statusBarTranslucent)
431
+ return;
432
+ safeMarginFromTop = measuredPadding !== null && measuredPadding !== void 0 ? measuredPadding : 0;
433
+ this.indicatorTranslateY.setValue(-measuredPadding);
434
+ }
435
+ else {
436
+ this.updateActionSheetPosition(this.offsetY);
437
+ }
438
+ const height = event.nativeEvent.layout.height - safeMarginFromTop;
439
+ const width = Dimensions.get("window").width;
440
+ if ((height === null || height === void 0 ? void 0 : height.toFixed(0)) === (calculatedDeviceHeight === null || calculatedDeviceHeight === void 0 ? void 0 : calculatedDeviceHeight.toFixed(0)) &&
441
+ (width === null || width === void 0 ? void 0 : width.toFixed(0)) === ((_a = this.state.deviceWidth) === null || _a === void 0 ? void 0 : _a.toFixed(0)) &&
442
+ this.deviceLayoutCalled)
443
+ return;
444
+ this.deviceLayoutCalled = true;
445
+ calculatedDeviceHeight = height;
446
+ this.setState({
447
+ deviceHeight: height,
448
+ deviceWidth: width,
449
+ portrait: height > width,
450
+ paddingTop: measuredPadding,
451
+ });
452
+ }, 1);
453
+ };
454
+ this._keyExtractor = (item) => item;
455
+ this.state = {
456
+ modalVisible: false,
457
+ scrollable: false,
458
+ layoutHasCalled: false,
459
+ keyboard: false,
460
+ deviceHeight: calculatedDeviceHeight || getDeviceHeight(this.props.statusBarTranslucent),
461
+ deviceWidth: Dimensions.get("window").width,
462
+ portrait: true,
463
+ safeAreaInnerHeight,
464
+ paddingTop: safeAreaPaddingTop,
465
+ };
466
+ this.actionSheetHeight = 0;
467
+ this.prevScroll = 0;
468
+ this.scrollAnimationEndValue = 0;
469
+ this.hasBounced = false;
470
+ this.scrollViewRef = createRef();
471
+ this.layoutHasCalled = false;
472
+ this.isClosing = false;
473
+ this.isRecoiling = false;
474
+ this.offsetY = 0;
475
+ this.safeAreaViewRef = createRef();
476
+ this.transformValue = new Animated.Value(0);
477
+ this.opacityValue = new Animated.Value(0);
478
+ this.borderRadius = new Animated.Value(10);
479
+ this.currentOffsetFromBottom = this.props.initialOffsetFromBottom;
480
+ this.underlayTranslateY = new Animated.Value(100);
481
+ this.underlayScale = new Animated.Value(1);
482
+ this.indicatorTranslateY = new Animated.Value(-this.state.paddingTop | 0);
483
+ this.isReachedTop = false;
484
+ this.deviceLayoutCalled = false;
485
+ this.timeout = null;
486
+ }
487
+ _hideAnimation() {
488
+ const { animated, closeAnimationDuration, bottomOffset, initialOffsetFromBottom, extraScroll, closable, } = this.props;
489
+ Animated.parallel([
490
+ Animated.timing(this.opacityValue, {
491
+ toValue: closable ? 0 : 1,
492
+ duration: animated ? closeAnimationDuration : 1,
493
+ useNativeDriver: true,
494
+ }),
495
+ Animated.timing(this.transformValue, {
496
+ toValue: closable ? this.actionSheetHeight * 2 : 0,
497
+ duration: animated ? closeAnimationDuration : 1,
498
+ useNativeDriver: true,
499
+ }),
500
+ ]).start();
501
+ waitAsync(closeAnimationDuration / 1.5).then(() => {
502
+ if (!closable) {
503
+ if (bottomOffset && bottomOffset > 0) {
504
+ this.snapToOffset(bottomOffset);
505
+ }
506
+ else {
507
+ this._scrollTo((this.actionSheetHeight * (initialOffsetFromBottom || 0)) +
508
+ this.state.deviceHeight * 0.1 +
509
+ (extraScroll !== null && extraScroll !== void 0 ? extraScroll : 0), true);
510
+ this.currentOffsetFromBottom = initialOffsetFromBottom;
511
+ }
512
+ this.isClosing = false;
513
+ }
514
+ else {
515
+ this._scrollTo(0, false);
516
+ this.currentOffsetFromBottom = initialOffsetFromBottom;
517
+ this.setState({
518
+ modalVisible: !closable,
519
+ }, () => {
520
+ this.isClosing = false;
521
+ this.isReachedTop = false;
522
+ this.props.onPositionChanged && this.props.onPositionChanged(false);
523
+ this.indicatorTranslateY.setValue(-this.state.paddingTop);
524
+ this.layoutHasCalled = false;
525
+ this.deviceLayoutCalled = false;
526
+ this.props.onClose && this.props.onClose();
527
+ });
528
+ }
529
+ });
530
+ }
531
+ _applyHeightLimiter() {
532
+ if (this.actionSheetHeight > this.state.deviceHeight) {
533
+ this.actionSheetHeight =
534
+ this.actionSheetHeight - (this.actionSheetHeight - this.state.deviceHeight);
535
+ }
536
+ }
537
+ updateActionSheetPosition(scrollPosition) {
538
+ if (this.actionSheetHeight >= this.state.deviceHeight - 1) {
539
+ const correction = this.state.deviceHeight * 0.15;
540
+ const distanceFromTop = this.actionSheetHeight + correction - scrollPosition;
541
+ if (distanceFromTop < safeAreaPaddingTop) {
542
+ if (!this.props.drawUnderStatusBar)
543
+ return;
544
+ this.indicatorTranslateY.setValue(0);
545
+ }
546
+ else {
547
+ this.indicatorTranslateY.setValue(-safeAreaPaddingTop);
548
+ }
549
+ }
550
+ }
551
+ _returnToPrevScrollPosition(height) {
552
+ var _a;
553
+ const correction = this.state.deviceHeight * 0.15;
554
+ const scrollOffset = height * this.currentOffsetFromBottom + correction + ((_a = this.props.extraScroll) !== null && _a !== void 0 ? _a : 0);
555
+ this.updateActionSheetPosition(scrollOffset);
556
+ this._scrollTo(scrollOffset);
557
+ }
558
+ componentDidMount() {
559
+ Keyboard.addListener(Platform.OS === "android" ? "keyboardDidShow" : "keyboardWillShow", this._onKeyboardShow);
560
+ Keyboard.addListener(Platform.OS === "android" ? "keyboardDidHide" : "keyboardWillHide", this._onKeyboardHide);
561
+ }
562
+ componentWillUnmount() {
563
+ Keyboard.removeListener(Platform.OS === "android" ? "keyboardDidShow" : "keyboardWillShow", this._onKeyboardShow);
564
+ Keyboard.removeListener(Platform.OS === "android" ? "keyboardDidHide" : "keyboardWillHide", this._onKeyboardHide);
565
+ }
566
+ getInitialScrollPosition() {
567
+ var _a, _b, _c, _d;
568
+ this._applyHeightLimiter();
569
+ const correction = this.state.deviceHeight * 0.15;
570
+ const scrollPosition = this.props.gestureEnabled
571
+ ? this.actionSheetHeight * ((_a = this.props.initialOffsetFromBottom) !== null && _a !== void 0 ? _a : 0) +
572
+ correction +
573
+ ((_b = this.props.extraScroll) !== null && _b !== void 0 ? _b : 0)
574
+ : this.actionSheetHeight + correction + ((_c = this.props.extraScroll) !== null && _c !== void 0 ? _c : 0);
575
+ this.currentOffsetFromBottom = (_d = this.props.initialOffsetFromBottom) !== null && _d !== void 0 ? _d : 0;
576
+ this.updateActionSheetPosition(scrollPosition);
577
+ return scrollPosition;
578
+ }
579
+ render() {
580
+ const { scrollable, modalVisible, keyboard } = this.state;
581
+ const { onOpen, overlayColor, gestureEnabled, elevation, indicatorColor, defaultOverlayOpacity, children, containerStyle, CustomHeaderComponent, headerAlwaysVisible, keyboardShouldPersistTaps, statusBarTranslucent, } = this.props;
582
+ return (React.createElement(Modal, { animationType: "none", statusBarTranslucent: statusBarTranslucent,
583
+ // testID={testID}
584
+ supportedOrientations: SUPPORTED_ORIENTATIONS, transparent: true, visible: modalVisible, onRequestClose: this._onRequestClose, onShow: onOpen },
585
+ React.createElement(Animated.View, { style: [
586
+ styles.parentContainer,
587
+ {
588
+ opacity: this.opacityValue,
589
+ width: this.state.deviceWidth,
590
+ },
591
+ ], onLayout: this._onDeviceLayout },
592
+ React.createElement(SafeAreaView, { ref: this.safeAreaViewRef, style: styles.safearea },
593
+ React.createElement(View, null)),
594
+ React.createElement(FlatList, { ref: this.scrollViewRef, bounces: false, contentContainerStyle: {
595
+ width: this.state.deviceWidth,
596
+ }, data: dummyData, keyExtractor: this._keyExtractor, keyboardShouldPersistTaps: keyboardShouldPersistTaps, renderItem: () => (React.createElement(View, { style: {
597
+ width: "100%",
598
+ } },
599
+ React.createElement(Animated.View, { style: {
600
+ height: "100%",
601
+ width: "100%",
602
+ position: "absolute",
603
+ zIndex: 1,
604
+ backgroundColor: overlayColor,
605
+ opacity: defaultOverlayOpacity,
606
+ }, onTouchEnd: this._onTouchBackdrop, onTouchMove: this._onTouchBackdrop, onTouchStart: this._onTouchBackdrop }),
607
+ React.createElement(View, { style: {
608
+ height: this.state.deviceHeight * 1.15,
609
+ width: "100%",
610
+ zIndex: 10,
611
+ }, onTouchEnd: this._onTouchEnd, onTouchMove: this._onTouchMove, onTouchStart: this._onTouchStart },
612
+ React.createElement(TouchableOpacity, { style: {
613
+ height: this.state.deviceHeight * 1.15,
614
+ width: "100%",
615
+ }, onLongPress: this._onTouchBackdrop, onPress: this._onTouchBackdrop })),
616
+ React.createElement(Animated.View, { style: [
617
+ styles.container,
618
+ {
619
+ borderRadius: 10,
620
+ },
621
+ containerStyle,
622
+ Object.assign(Object.assign({}, getElevation(elevation)), { zIndex: 11, opacity: this.opacityValue, transform: [
623
+ {
624
+ translateY: this.transformValue,
625
+ },
626
+ ], maxHeight: this.state.deviceHeight }),
627
+ ], onLayout: this._showModal },
628
+ React.createElement(Animated.View, { style: {
629
+ maxHeight: this.state.deviceHeight,
630
+ transform: [
631
+ {
632
+ translateY: this.indicatorTranslateY,
633
+ },
634
+ ],
635
+ marginTop: this.state.paddingTop,
636
+ } },
637
+ gestureEnabled || headerAlwaysVisible ? (CustomHeaderComponent ? (CustomHeaderComponent) : (React.createElement(Animated.View, { style: [styles.indicator, { backgroundColor: indicatorColor }] }))) : null,
638
+ children)))), scrollEnabled: scrollable && !keyboard, scrollEventThrottle: 5, scrollsToTop: false, showsVerticalScrollIndicator: false, style: [
639
+ styles.scrollView,
640
+ {
641
+ width: this.state.deviceWidth,
642
+ },
643
+ ], onMomentumScrollBegin: this._onScrollBegin, onMomentumScrollEnd: this._onScrollEnd, onScroll: this._onScroll, onScrollBeginDrag: this._onScrollBeginDrag, onTouchEnd: this._onTouchEnd }))));
644
+ }
645
+ }
646
+ ActionSheet.defaultProps = defaultProps;
647
+ //# sourceMappingURL=ActionSheet.js.map