ferns-ui 0.36.1 → 0.36.3

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 (303) hide show
  1. package/dist/ActionSheet.d.ts +492 -0
  2. package/dist/ActionSheet.js +649 -0
  3. package/dist/ActionSheet.js.map +1 -0
  4. package/dist/Avatar.d.ts +68 -0
  5. package/dist/Avatar.js +152 -0
  6. package/dist/Avatar.js.map +1 -0
  7. package/dist/Badge.d.ts +10 -0
  8. package/dist/Badge.js +36 -0
  9. package/dist/Badge.js.map +1 -0
  10. package/dist/Banner.d.ts +27 -0
  11. package/dist/Banner.js +56 -0
  12. package/dist/Banner.js.map +1 -0
  13. package/dist/BlurBox.d.ts +5 -0
  14. package/dist/BlurBox.js +28 -0
  15. package/dist/BlurBox.js.map +1 -0
  16. package/dist/BlurBox.native.d.ts +6 -0
  17. package/dist/BlurBox.native.js +30 -0
  18. package/dist/BlurBox.native.js.map +1 -0
  19. package/dist/Body.d.ts +6 -0
  20. package/dist/Body.js +21 -0
  21. package/dist/Body.js.map +1 -0
  22. package/dist/Box.d.ts +3 -0
  23. package/dist/Box.js +251 -0
  24. package/dist/Box.js.map +1 -0
  25. package/dist/Button.d.ts +26 -0
  26. package/dist/Button.js +120 -0
  27. package/dist/Button.js.map +1 -0
  28. package/dist/Card.d.ts +5 -0
  29. package/dist/Card.js +8 -0
  30. package/dist/Card.js.map +1 -0
  31. package/dist/CheckBox.d.ts +3 -0
  32. package/dist/CheckBox.js +40 -0
  33. package/dist/CheckBox.js.map +1 -0
  34. package/dist/Common.d.ts +868 -0
  35. package/dist/Common.js +46 -0
  36. package/dist/Common.js.map +1 -0
  37. package/dist/Constants.d.ts +4 -0
  38. package/dist/Constants.js +54 -0
  39. package/dist/Constants.js.map +1 -0
  40. package/dist/CustomSelect.d.ts +14 -0
  41. package/dist/CustomSelect.js +43 -0
  42. package/dist/CustomSelect.js.map +1 -0
  43. package/dist/DateTimeActionSheet.d.ts +12 -0
  44. package/dist/DateTimeActionSheet.js +248 -0
  45. package/dist/DateTimeActionSheet.js.map +1 -0
  46. package/dist/DateTimeField.android.d.ts +3 -0
  47. package/dist/DateTimeField.android.js +66 -0
  48. package/dist/DateTimeField.android.js.map +1 -0
  49. package/dist/DateTimeField.d.ts +3 -0
  50. package/dist/DateTimeField.ios.d.ts +3 -0
  51. package/dist/DateTimeField.ios.js +48 -0
  52. package/dist/DateTimeField.ios.js.map +1 -0
  53. package/dist/DateTimeField.js +35 -0
  54. package/dist/DateTimeField.js.map +1 -0
  55. package/dist/DecimalRangeActionSheet.d.ts +18 -0
  56. package/dist/DecimalRangeActionSheet.js +65 -0
  57. package/dist/DecimalRangeActionSheet.js.map +1 -0
  58. package/dist/ErrorBoundary.d.ts +19 -0
  59. package/dist/ErrorBoundary.js +29 -0
  60. package/dist/ErrorBoundary.js.map +1 -0
  61. package/dist/ErrorPage.d.ts +10 -0
  62. package/dist/ErrorPage.js +20 -0
  63. package/dist/ErrorPage.js.map +1 -0
  64. package/dist/FernsProvider.d.ts +4 -0
  65. package/dist/FernsProvider.js +9 -0
  66. package/dist/FernsProvider.js.map +1 -0
  67. package/dist/Field.d.ts +17 -0
  68. package/dist/Field.js +114 -0
  69. package/dist/Field.js.map +1 -0
  70. package/dist/FieldWithLabels.d.ts +3 -0
  71. package/dist/FieldWithLabels.js +8 -0
  72. package/dist/FieldWithLabels.js.map +1 -0
  73. package/dist/FlatList.d.ts +2 -0
  74. package/dist/FlatList.js +3 -0
  75. package/dist/FlatList.js.map +1 -0
  76. package/dist/Form.d.ts +22 -0
  77. package/dist/Form.js +89 -0
  78. package/dist/Form.js.map +1 -0
  79. package/dist/HeaderButtons.d.ts +31 -0
  80. package/dist/HeaderButtons.js +53 -0
  81. package/dist/HeaderButtons.js.map +1 -0
  82. package/dist/Heading.d.ts +11 -0
  83. package/dist/Heading.js +46 -0
  84. package/dist/Heading.js.map +1 -0
  85. package/dist/HeightActionSheet.d.ts +16 -0
  86. package/dist/HeightActionSheet.js +58 -0
  87. package/dist/HeightActionSheet.js.map +1 -0
  88. package/dist/Hyperlink.d.ts +43 -0
  89. package/dist/Hyperlink.js +135 -0
  90. package/dist/Hyperlink.js.map +1 -0
  91. package/dist/Icon.d.ts +4 -0
  92. package/dist/Icon.js +14 -0
  93. package/dist/Icon.js.map +1 -0
  94. package/dist/IconButton.d.ts +26 -0
  95. package/dist/IconButton.js +78 -0
  96. package/dist/IconButton.js.map +1 -0
  97. package/dist/Image.d.ts +8 -0
  98. package/dist/Image.js +37 -0
  99. package/dist/Image.js.map +1 -0
  100. package/dist/ImageBackground.d.ts +10 -0
  101. package/dist/ImageBackground.js +8 -0
  102. package/dist/ImageBackground.js.map +1 -0
  103. package/dist/InfoTooltipButton.d.ts +8 -0
  104. package/dist/InfoTooltipButton.js +6 -0
  105. package/dist/InfoTooltipButton.js.map +1 -0
  106. package/dist/Layer.d.ts +9 -0
  107. package/dist/Layer.js +12 -0
  108. package/dist/Layer.js.map +1 -0
  109. package/dist/Link.d.ts +9 -0
  110. package/dist/Link.js +12 -0
  111. package/dist/Link.js.map +1 -0
  112. package/dist/Mask.d.ts +2 -0
  113. package/dist/Mask.js +19 -0
  114. package/dist/Mask.js.map +1 -0
  115. package/dist/MediaQuery.d.ts +4 -0
  116. package/dist/MediaQuery.js +52 -0
  117. package/dist/MediaQuery.js.map +1 -0
  118. package/dist/Meta.d.ts +5 -0
  119. package/dist/Meta.js +7 -0
  120. package/dist/Meta.js.map +1 -0
  121. package/dist/Modal.d.ts +19 -0
  122. package/dist/Modal.js +101 -0
  123. package/dist/Modal.js.map +1 -0
  124. package/dist/ModalSheet.d.ts +7 -0
  125. package/dist/ModalSheet.js +42 -0
  126. package/dist/ModalSheet.js.map +1 -0
  127. package/dist/NumberPickerActionSheet.d.ts +16 -0
  128. package/dist/NumberPickerActionSheet.js +29 -0
  129. package/dist/NumberPickerActionSheet.js.map +1 -0
  130. package/dist/Page.d.ts +26 -0
  131. package/dist/Page.js +38 -0
  132. package/dist/Page.js.map +1 -0
  133. package/dist/Permissions.d.ts +2 -0
  134. package/dist/Permissions.js +35 -0
  135. package/dist/Permissions.js.map +1 -0
  136. package/dist/PickerSelect.d.ts +109 -0
  137. package/dist/PickerSelect.js +296 -0
  138. package/dist/PickerSelect.js.map +1 -0
  139. package/dist/Pill.d.ts +5 -0
  140. package/dist/Pill.js +10 -0
  141. package/dist/Pill.js.map +1 -0
  142. package/dist/Pog.d.ts +15 -0
  143. package/dist/Pog.js +48 -0
  144. package/dist/Pog.js.map +1 -0
  145. package/dist/ProgressBar.d.ts +9 -0
  146. package/dist/ProgressBar.js +41 -0
  147. package/dist/ProgressBar.js.map +1 -0
  148. package/dist/ScrollView.d.ts +2 -0
  149. package/dist/ScrollView.js +3 -0
  150. package/dist/ScrollView.js.map +1 -0
  151. package/dist/SegmentedControl.d.ts +3 -0
  152. package/dist/SegmentedControl.js +55 -0
  153. package/dist/SegmentedControl.js.map +1 -0
  154. package/dist/SelectList.d.ts +18 -0
  155. package/dist/SelectList.js +48 -0
  156. package/dist/SelectList.js.map +1 -0
  157. package/dist/SideDrawer.d.ts +13 -0
  158. package/dist/SideDrawer.js +22 -0
  159. package/dist/SideDrawer.js.map +1 -0
  160. package/dist/Spinner.d.ts +3 -0
  161. package/dist/Spinner.js +16 -0
  162. package/dist/Spinner.js.map +1 -0
  163. package/dist/SplitPage.d.ts +3 -0
  164. package/dist/SplitPage.js +149 -0
  165. package/dist/SplitPage.js.map +1 -0
  166. package/dist/SplitPage.native.d.ts +3 -0
  167. package/dist/SplitPage.native.js +79 -0
  168. package/dist/SplitPage.native.js.map +1 -0
  169. package/dist/Switch.d.ts +5 -0
  170. package/dist/Switch.js +10 -0
  171. package/dist/Switch.js.map +1 -0
  172. package/dist/Table.d.ts +30 -0
  173. package/dist/Table.js +31 -0
  174. package/dist/Table.js.map +1 -0
  175. package/dist/TableHeader.d.ts +22 -0
  176. package/dist/TableHeader.js +11 -0
  177. package/dist/TableHeader.js.map +1 -0
  178. package/dist/TableHeaderCell.d.ts +15 -0
  179. package/dist/TableHeaderCell.js +36 -0
  180. package/dist/TableHeaderCell.js.map +1 -0
  181. package/dist/TableRow.d.ts +29 -0
  182. package/dist/TableRow.js +30 -0
  183. package/dist/TableRow.js.map +1 -0
  184. package/dist/TapToEdit.d.ts +19 -0
  185. package/dist/TapToEdit.js +136 -0
  186. package/dist/TapToEdit.js.map +1 -0
  187. package/dist/Text.d.ts +19 -0
  188. package/dist/Text.js +91 -0
  189. package/dist/Text.js.map +1 -0
  190. package/dist/TextArea.d.ts +6 -0
  191. package/dist/TextArea.js +24 -0
  192. package/dist/TextArea.js.map +1 -0
  193. package/dist/TextField.d.ts +3 -0
  194. package/dist/TextField.js +260 -0
  195. package/dist/TextField.js.map +1 -0
  196. package/dist/TextFieldNumberActionSheet.d.ts +15 -0
  197. package/dist/TextFieldNumberActionSheet.js +28 -0
  198. package/dist/TextFieldNumberActionSheet.js.map +1 -0
  199. package/dist/Toast.d.ts +12 -0
  200. package/dist/Toast.js +46 -0
  201. package/dist/Toast.js.map +1 -0
  202. package/dist/Tooltip.d.ts +9 -0
  203. package/dist/Tooltip.js +174 -0
  204. package/dist/Tooltip.js.map +1 -0
  205. package/dist/UnifiedScreens.d.ts +9 -0
  206. package/dist/UnifiedScreens.js +25 -0
  207. package/dist/UnifiedScreens.js.map +1 -0
  208. package/dist/Unifier.d.ts +45 -0
  209. package/dist/Unifier.js +291 -0
  210. package/dist/Unifier.js.map +1 -0
  211. package/dist/Utilities.d.ts +31 -0
  212. package/dist/Utilities.js +73 -0
  213. package/dist/Utilities.js.map +1 -0
  214. package/dist/WithLabel.d.ts +14 -0
  215. package/dist/WithLabel.js +15 -0
  216. package/dist/WithLabel.js.map +1 -0
  217. package/dist/dayjsExtended.d.ts +2 -0
  218. package/{src/dayjsExtended.ts → dist/dayjsExtended.js} +1 -2
  219. package/dist/dayjsExtended.js.map +1 -0
  220. package/dist/index.d.ts +1299 -0
  221. package/dist/index.js.map +1 -0
  222. package/dist/tableContext.d.ts +21 -0
  223. package/dist/tableContext.js +35 -0
  224. package/dist/tableContext.js.map +1 -0
  225. package/package.json +4 -1
  226. package/checkDeps.js +0 -19
  227. package/src/ActionSheet.tsx +0 -1231
  228. package/src/Avatar.tsx +0 -317
  229. package/src/Badge.tsx +0 -65
  230. package/src/Banner.tsx +0 -124
  231. package/src/BlurBox.native.tsx +0 -40
  232. package/src/BlurBox.tsx +0 -31
  233. package/src/Body.tsx +0 -32
  234. package/src/Box.tsx +0 -308
  235. package/src/Button.tsx +0 -219
  236. package/src/Card.tsx +0 -23
  237. package/src/CheckBox.tsx +0 -118
  238. package/src/Common.ts +0 -2743
  239. package/src/Constants.ts +0 -53
  240. package/src/CustomSelect.tsx +0 -85
  241. package/src/DateTimeActionSheet.tsx +0 -409
  242. package/src/DateTimeField.android.tsx +0 -101
  243. package/src/DateTimeField.ios.tsx +0 -83
  244. package/src/DateTimeField.tsx +0 -69
  245. package/src/DecimalRangeActionSheet.tsx +0 -113
  246. package/src/ErrorBoundary.tsx +0 -37
  247. package/src/ErrorPage.tsx +0 -44
  248. package/src/FernsProvider.tsx +0 -21
  249. package/src/Field.tsx +0 -299
  250. package/src/FieldWithLabels.tsx +0 -36
  251. package/src/FlatList.tsx +0 -2
  252. package/src/Form.tsx +0 -182
  253. package/src/HeaderButtons.tsx +0 -107
  254. package/src/Heading.tsx +0 -53
  255. package/src/HeightActionSheet.tsx +0 -104
  256. package/src/Hyperlink.tsx +0 -181
  257. package/src/Icon.tsx +0 -24
  258. package/src/IconButton.tsx +0 -165
  259. package/src/Image.tsx +0 -50
  260. package/src/ImageBackground.tsx +0 -14
  261. package/src/InfoTooltipButton.tsx +0 -23
  262. package/src/Layer.tsx +0 -17
  263. package/src/Link.tsx +0 -17
  264. package/src/Mask.tsx +0 -21
  265. package/src/MediaQuery.ts +0 -46
  266. package/src/Meta.tsx +0 -9
  267. package/src/Modal.tsx +0 -248
  268. package/src/ModalSheet.tsx +0 -58
  269. package/src/NumberPickerActionSheet.tsx +0 -66
  270. package/src/Page.tsx +0 -133
  271. package/src/Permissions.ts +0 -44
  272. package/src/PickerSelect.tsx +0 -553
  273. package/src/Pill.tsx +0 -24
  274. package/src/Pog.tsx +0 -87
  275. package/src/ProgressBar.tsx +0 -55
  276. package/src/ScrollView.tsx +0 -2
  277. package/src/SegmentedControl.tsx +0 -102
  278. package/src/SelectList.tsx +0 -89
  279. package/src/SideDrawer.tsx +0 -62
  280. package/src/Spinner.tsx +0 -20
  281. package/src/SplitPage.native.tsx +0 -160
  282. package/src/SplitPage.tsx +0 -302
  283. package/src/Switch.tsx +0 -19
  284. package/src/Table.tsx +0 -87
  285. package/src/TableHeader.tsx +0 -36
  286. package/src/TableHeaderCell.tsx +0 -76
  287. package/src/TableRow.tsx +0 -87
  288. package/src/TapToEdit.tsx +0 -221
  289. package/src/Text.tsx +0 -131
  290. package/src/TextArea.tsx +0 -16
  291. package/src/TextField.tsx +0 -401
  292. package/src/TextFieldNumberActionSheet.tsx +0 -61
  293. package/src/Toast.tsx +0 -106
  294. package/src/Tooltip.tsx +0 -269
  295. package/src/UnifiedScreens.ts +0 -24
  296. package/src/Unifier.ts +0 -371
  297. package/src/Utilities.tsx +0 -159
  298. package/src/WithLabel.tsx +0 -57
  299. package/src/index.tsx +0 -1346
  300. package/src/polyfill.d.ts +0 -11
  301. package/src/tableContext.tsx +0 -80
  302. package/tsconfig.json +0 -30
  303. package/updateDeps.js +0 -14
@@ -0,0 +1,492 @@
1
+ import React, { Component } from "react";
2
+ import { Animated, EmitterSubscription, KeyboardEvent, LayoutChangeEvent, NativeScrollEvent, NativeSyntheticEvent, ViewStyle } from "react-native";
3
+ export type ActionSheetProps = {
4
+ children?: React.ReactNode;
5
+ ref?: React.MutableRefObject<{
6
+ /**
7
+ * Open or close the ActionSheet.
8
+ */
9
+ setModalVisible(visible?: boolean): void;
10
+ /**
11
+ * Open the Action Sheet.
12
+ */
13
+ show(): void;
14
+ /**
15
+ * Close the ActionSheet.
16
+ */
17
+ hide(): void;
18
+ /**
19
+ * Attach this to any child ScrollView Component's onScrollEndDrag,
20
+ * onMomentumScrollEnd,onScrollAnimationEnd callbacks to handle the ActionSheet
21
+ * closing and bouncing back properly.
22
+ */
23
+ handleChildScrollEnd(): void;
24
+ /**
25
+ * Snap ActionSheet to given offset
26
+ */
27
+ snapToOffset(offset: number): void;
28
+ }>;
29
+ /**
30
+ * Animate the opening and closing of ActionSheet.
31
+
32
+ | Type | Required |
33
+ | ---- | -------- |
34
+ | boolean | no |
35
+
36
+ Default: `true`
37
+ */
38
+ animated?: boolean;
39
+ /**
40
+ * Use if you want to show the ActionSheet Partially on Opening. **Requires `gestureEnabled=true`**
41
+
42
+ | Type | Required |
43
+ | ---- | -------- |
44
+ | boolean | no |
45
+
46
+ Default:`1`
47
+ */
48
+ initialOffsetFromBottom?: number;
49
+ /**
50
+ * When touch ends and user has not moved farther from the set springOffset, the ActionSheet will return to previous position.
51
+
52
+ | Type | Required |
53
+ | ---- | -------- |
54
+ | number | no |
55
+
56
+ Default: `50`
57
+ */
58
+ springOffset?: number;
59
+ /**
60
+ * Add elevation to the ActionSheet container.
61
+
62
+ | Type | Required |
63
+ | ---- | -------- |
64
+ | number | no |
65
+
66
+ Default: `0`
67
+
68
+ #
69
+ */
70
+ elevation?: number;
71
+ /**
72
+ * Color of the gestureEnabled Indicator.
73
+
74
+ | Type | Required |
75
+ | ---- | -------- |
76
+ | string | no |
77
+
78
+ Default: `"#f0f0f0"`
79
+ */
80
+ indicatorColor?: string;
81
+ /**
82
+ * Normally when the ActionSheet is fully opened, a small portion from the bottom is hidden by default. Use this prop if you want the ActionSheet to hover over the bottom of screen and not hide a little behind it.
83
+
84
+ | Type | Required |
85
+ | ---- | -------- |
86
+ | number | no |
87
+
88
+ Default:`0`
89
+ */
90
+ extraScroll?: number;
91
+ /**
92
+ * Color of the overlay/backdrop.
93
+
94
+ | Type | Required |
95
+ | ---- | -------- |
96
+ | string | no |
97
+
98
+ Default: `"black"`
99
+ */
100
+ overlayColor?: string;
101
+ /**
102
+ * Keep the header always visible even when gestures are disabled.
103
+
104
+ | Type | Required |
105
+ | ---- | -------- |
106
+ | boolean | no |
107
+
108
+ Default: `false`
109
+ */
110
+ headerAlwaysVisible?: boolean;
111
+ /**
112
+ * Delay draw of ActionSheet on open for android.
113
+
114
+ | Type | Required |
115
+ | ---- | -------- |
116
+ | boolean | no |
117
+
118
+ Default: `false`
119
+ */
120
+ delayActionSheetDraw?: boolean;
121
+ /**
122
+ * Delay draw of ActionSheet on open for android time.
123
+
124
+ | Type | Required |
125
+ | ---- | -------- |
126
+ | number (ms) | no |
127
+
128
+ Default: `50`
129
+ */
130
+ delayActionSheetDrawTime?: number;
131
+ /**
132
+ * Your custom header component. Using this will hide the default indicator.
133
+
134
+ | Type | Required |
135
+ | ---- | -------- |
136
+ | React.Component | no |
137
+ */
138
+ CustomHeaderComponent?: React.ReactNode;
139
+ /**
140
+ * Any custom styles for the container.
141
+
142
+ | Type | Required |
143
+ | ---- | -------- |
144
+ | Object | no |
145
+ */
146
+ containerStyle?: ViewStyle;
147
+ /**
148
+ * Control closing ActionSheet by touching on backdrop.
149
+
150
+ | Type | Required |
151
+ | ---- | -------- |
152
+ | boolean | no |
153
+
154
+ Default: `true`
155
+ */
156
+ closeOnTouchBackdrop?: boolean;
157
+ /**
158
+ * Speed of opening animation. Higher means the ActionSheet will open more quickly.
159
+
160
+ | Type | Required |
161
+ | ---- | -------- |
162
+ | number | no |
163
+
164
+ Default: `12`
165
+ */
166
+ openAnimationSpeed?: number;
167
+ /**
168
+ * Duration of closing animation.
169
+
170
+ | Type | Required |
171
+ | ---- | -------- |
172
+ | number | no |
173
+
174
+ Default: `300`
175
+ */
176
+ closeAnimationDuration?: number;
177
+ /**
178
+ *
179
+ How much you want the ActionSheet to bounce when it is opened.
180
+
181
+ | Type | Required |
182
+ | ---- | -------- |
183
+ | number | no |
184
+
185
+ Default: `8`
186
+ */
187
+ bounciness?: number;
188
+ /**
189
+ * Will the ActionSheet close on `hardwareBackPress` event.
190
+
191
+ | Type | Required |
192
+ | ---- | -------- |
193
+ | boolean | no |
194
+
195
+ Default: `true`
196
+ */
197
+ closeOnPressBack?: boolean;
198
+ /**
199
+ * Default opacity of the overlay/backdrop.
200
+
201
+ | Type | Required |
202
+ | ---- | -------- |
203
+ | number 0 - 1 | no |
204
+
205
+ Default: `0.3`
206
+ */
207
+ defaultOverlayOpacity?: number;
208
+ /**
209
+ * Enables gesture control of ActionSheet
210
+
211
+ | Type | Required |
212
+ | ---- | -------- |
213
+ | boolean | no |
214
+
215
+ Default: `false`
216
+ */
217
+ gestureEnabled?: boolean;
218
+ /**
219
+ * Bounces the ActionSheet on open.
220
+
221
+ | Type | Required |
222
+ | ---- | -------- |
223
+ | boolean | no |
224
+
225
+ Default: `false`
226
+ */
227
+ bounceOnOpen?: boolean;
228
+ /**
229
+ * Setting the keyboard persistence of the ScrollView component, should be one of "never", "always", or "handled"
230
+
231
+ | Type | Required |
232
+ | ---- | -------- |
233
+ | string | no |
234
+
235
+ Default: `"never"`
236
+ */
237
+ keyboardShouldPersistTaps?: boolean | "always" | "never" | "handled";
238
+ /**
239
+ * Determine whether the modal should go under the system statusbar.
240
+
241
+ | Type | Required |
242
+ | ---- | -------- |
243
+ | boolean | no |
244
+
245
+ Default: `true`
246
+ */
247
+ statusBarTranslucent?: boolean;
248
+ /**
249
+ * Prevent ActionSheet from closing on
250
+ * gesture or tapping on backdrop.
251
+ * Instead snap it to `bottomOffset` location
252
+ *
253
+ *
254
+ * | Type | Required |
255
+ | ---- | -------- |
256
+ | boolean | no |
257
+ */
258
+ closable?: boolean;
259
+ /**
260
+ * Allow ActionSheet to draw under the StatusBar.
261
+ * This is enabled by default.
262
+ *
263
+ *
264
+ * | Type | Required |
265
+ | ---- | -------- |
266
+ | boolean | no |
267
+ Default: `true`
268
+ */
269
+ drawUnderStatusBar?: boolean;
270
+ /**
271
+ * Snap ActionSheet to this location if `closable` is set to false;
272
+ *
273
+ *
274
+ * | Type | Required |
275
+ | ---- | -------- |
276
+ | number | no |
277
+ */
278
+ bottomOffset?: number;
279
+ /**
280
+ * Change how ActionSheet behaves when keyboard is opened.
281
+ *
282
+ *
283
+ * | Type | Required |
284
+ | ---- | -------- |
285
+ | "padding" | "position" | no |
286
+ Default:`padding`
287
+ */
288
+ keyboardMode?: "padding" | "position";
289
+ /**
290
+ * Test ID for unit testing
291
+ */
292
+ testID?: string;
293
+ /**
294
+ *
295
+ Event called when the ActionSheet closes.
296
+
297
+
298
+ * | Type | Required |
299
+ | ---- | -------- |
300
+ | function | no |
301
+
302
+
303
+ #
304
+ */
305
+ onClose?: () => void;
306
+ /**
307
+ * An event called when the ActionSheet Opens.
308
+
309
+ | Type | Required |
310
+ | ---- | -------- |
311
+ | function | no |
312
+ */
313
+ onOpen?: () => void;
314
+ /**
315
+ * Event called when position of ActionSheet changes.
316
+ */
317
+ onPositionChanged?: (hasReachedTop: boolean) => void;
318
+ };
319
+ export declare const styles: {
320
+ scrollView: {
321
+ height: "100%";
322
+ width: "100%";
323
+ backgroundColor: string;
324
+ };
325
+ container: {
326
+ width: "100%";
327
+ backgroundColor: string;
328
+ alignSelf: "center";
329
+ };
330
+ safearea: {
331
+ position: "absolute";
332
+ top: number;
333
+ left: number;
334
+ };
335
+ indicator: {
336
+ height: number;
337
+ width: number;
338
+ borderRadius: number;
339
+ backgroundColor: string;
340
+ marginVertical: number;
341
+ alignSelf: "center";
342
+ };
343
+ parentContainer: {
344
+ width: "100%";
345
+ height: "100%";
346
+ justifyContent: "center";
347
+ alignItems: "center";
348
+ };
349
+ };
350
+ export declare function getDeviceHeight(statusBarTranslucent: boolean | undefined): number;
351
+ export declare const getElevation: (elevation?: number) => {
352
+ elevation?: undefined;
353
+ shadowColor?: undefined;
354
+ shadowOffset?: undefined;
355
+ shadowOpacity?: undefined;
356
+ shadowRadius?: undefined;
357
+ } | {
358
+ elevation: number;
359
+ shadowColor: string;
360
+ shadowOffset: {
361
+ width: number;
362
+ height: number;
363
+ };
364
+ shadowOpacity: number;
365
+ shadowRadius: number;
366
+ };
367
+ export declare const SUPPORTED_ORIENTATIONS: ("portrait" | "portrait-upside-down" | "landscape" | "landscape-left" | "landscape-right")[];
368
+ export declare const waitAsync: (ms: number) => Promise<null>;
369
+ type State = {
370
+ modalVisible: boolean;
371
+ scrollable: boolean;
372
+ layoutHasCalled: boolean;
373
+ keyboard: boolean;
374
+ deviceHeight: number;
375
+ deviceWidth: number;
376
+ portrait: boolean;
377
+ safeAreaInnerHeight: number;
378
+ paddingTop: number;
379
+ };
380
+ declare const defaultProps: {
381
+ animated: boolean;
382
+ closeOnPressBack: boolean;
383
+ bounciness: number;
384
+ extraScroll: number;
385
+ closeAnimationDuration: number;
386
+ delayActionSheetDrawTime: number;
387
+ openAnimationSpeed: number;
388
+ springOffset: number;
389
+ elevation: number;
390
+ initialOffsetFromBottom: number;
391
+ indicatorColor: string;
392
+ defaultOverlayOpacity: number;
393
+ overlayColor: string;
394
+ closable: boolean;
395
+ bottomOffset: number;
396
+ closeOnTouchBackdrop: boolean;
397
+ drawUnderStatusBar: boolean;
398
+ statusBarTranslucent: boolean;
399
+ keyboardMode: string;
400
+ gestureEnabled: boolean;
401
+ };
402
+ type Props = Partial<typeof defaultProps> & ActionSheetProps;
403
+ export declare class ActionSheet extends Component<Props, State, any> {
404
+ static defaultProps: {
405
+ animated: boolean;
406
+ closeOnPressBack: boolean;
407
+ bounciness: number;
408
+ extraScroll: number;
409
+ closeAnimationDuration: number;
410
+ delayActionSheetDrawTime: number;
411
+ openAnimationSpeed: number;
412
+ springOffset: number;
413
+ elevation: number;
414
+ initialOffsetFromBottom: number;
415
+ indicatorColor: string;
416
+ defaultOverlayOpacity: number;
417
+ overlayColor: string;
418
+ closable: boolean;
419
+ bottomOffset: number;
420
+ closeOnTouchBackdrop: boolean;
421
+ drawUnderStatusBar: boolean;
422
+ statusBarTranslucent: boolean;
423
+ keyboardMode: string;
424
+ gestureEnabled: boolean;
425
+ };
426
+ actionSheetHeight: number;
427
+ keyboardDidShowListener: EmitterSubscription | null;
428
+ keyboardDidHideListener: EmitterSubscription | null;
429
+ prevScroll: number;
430
+ timeout: any | null;
431
+ offsetY: number;
432
+ currentOffsetFromBottom: number;
433
+ scrollAnimationEndValue: number;
434
+ hasBounced: boolean;
435
+ layoutHasCalled: boolean;
436
+ isClosing: boolean;
437
+ isRecoiling: boolean;
438
+ isReachedTop: boolean;
439
+ deviceLayoutCalled: boolean;
440
+ scrollViewRef: React.RefObject<any>;
441
+ safeAreaViewRef: React.RefObject<any>;
442
+ transformValue: Animated.Value;
443
+ opacityValue: Animated.Value;
444
+ borderRadius: Animated.Value;
445
+ underlayTranslateY: Animated.Value;
446
+ underlayScale: Animated.Value;
447
+ indicatorTranslateY: Animated.Value;
448
+ constructor(props: ActionSheetProps);
449
+ /**
450
+ * Snap ActionSheet to Offset
451
+ */
452
+ snapToOffset: (offset: number) => void;
453
+ show: () => void;
454
+ hide: () => void;
455
+ /**
456
+ * Open/Close the ActionSheet
457
+ */
458
+ setModalVisible: (visible: boolean) => void;
459
+ _hideAnimation(): void;
460
+ _hideModal: () => void;
461
+ measure: () => Promise<number>;
462
+ _showModal: (event: LayoutChangeEvent) => Promise<void>;
463
+ _openAnimation: (scrollOffset: number) => void;
464
+ _onScrollBegin: () => Promise<void>;
465
+ _onScrollBeginDrag: (event: NativeSyntheticEvent<NativeScrollEvent>) => Promise<void>;
466
+ _applyHeightLimiter(): void;
467
+ _onScrollEnd: (event: NativeSyntheticEvent<NativeScrollEvent>) => Promise<void>;
468
+ updateActionSheetPosition(scrollPosition: number): void;
469
+ _returnToPrevScrollPosition(height: number): void;
470
+ _scrollTo: (y: number, animated?: boolean) => void;
471
+ _onTouchMove: () => void;
472
+ _onTouchStart: () => void;
473
+ _onTouchEnd: () => void;
474
+ _onScroll: (event: NativeSyntheticEvent<NativeScrollEvent>) => void;
475
+ _onRequestClose: () => void;
476
+ _onTouchBackdrop: () => void;
477
+ componentDidMount(): void;
478
+ _onKeyboardShow: (event: KeyboardEvent) => void;
479
+ /**
480
+ * Attach this to any child ScrollView Component's onScrollEndDrag,
481
+ * onMomentumScrollEnd,onScrollAnimationEnd callbacks to handle the ActionSheet
482
+ * closing and bouncing back properly.
483
+ */
484
+ handleChildScrollEnd: () => Promise<void>;
485
+ _onKeyboardHide: () => void;
486
+ componentWillUnmount(): void;
487
+ _onDeviceLayout: (_event: any) => Promise<void>;
488
+ getInitialScrollPosition(): number;
489
+ _keyExtractor: (item: any) => any;
490
+ render(): React.JSX.Element;
491
+ }
492
+ export {};