@draftbit/core 47.0.1-e04fa3.2 → 47.1.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 (328) hide show
  1. package/lib/commonjs/components/Button.js +3 -3
  2. package/lib/commonjs/components/Checkbox/Checkbox.js +1 -3
  3. package/lib/commonjs/components/Checkbox/CheckboxGroupRow.js +1 -2
  4. package/lib/commonjs/components/Checkbox/CheckboxRow.js +1 -2
  5. package/lib/commonjs/components/DeprecatedButton.js +3 -27
  6. package/lib/commonjs/components/DeprecatedFAB.js +1 -2
  7. package/lib/commonjs/components/Justification.js +1 -5
  8. package/lib/commonjs/components/Pressable.js +37 -0
  9. package/lib/commonjs/components/ResizeMode.js +1 -5
  10. package/lib/commonjs/components/Swiper/Swiper.js +2 -0
  11. package/lib/commonjs/components/Touchable.js +8 -3
  12. package/lib/commonjs/index.js +89 -25
  13. package/lib/commonjs/mappings/Button.js +39 -10
  14. package/lib/commonjs/mappings/FlashList.js +45 -2
  15. package/lib/commonjs/mappings/FlatList.js +12 -0
  16. package/lib/commonjs/mappings/Swiper.js +2 -0
  17. package/lib/commonjs/mappings/Touchable.js +47 -7
  18. package/lib/module/components/Button.js +3 -3
  19. package/lib/module/components/Checkbox/Checkbox.js +2 -3
  20. package/lib/module/components/Checkbox/CheckboxGroupRow.js +2 -3
  21. package/lib/module/components/Checkbox/CheckboxRow.js +2 -3
  22. package/lib/module/components/DeprecatedButton.js +4 -28
  23. package/lib/module/components/DeprecatedFAB.js +2 -3
  24. package/lib/module/components/Justification.js +0 -1
  25. package/lib/module/components/Pressable.js +30 -0
  26. package/lib/module/components/ResizeMode.js +0 -1
  27. package/lib/module/components/Swiper/Swiper.js +2 -0
  28. package/lib/module/components/Touchable.js +8 -3
  29. package/lib/module/index.js +32 -121
  30. package/lib/module/mappings/Button.js +40 -11
  31. package/lib/module/mappings/FlashList.js +46 -3
  32. package/lib/module/mappings/FlatList.js +13 -1
  33. package/lib/module/mappings/Swiper.js +3 -1
  34. package/lib/module/mappings/Touchable.js +49 -9
  35. package/lib/typescript/src/components/Button.d.ts.map +1 -1
  36. package/lib/typescript/src/components/Checkbox/Checkbox.d.ts +2 -2
  37. package/lib/typescript/src/components/Checkbox/Checkbox.d.ts.map +1 -1
  38. package/lib/typescript/src/components/Checkbox/CheckboxGroupRow.d.ts.map +1 -1
  39. package/lib/typescript/src/components/Checkbox/CheckboxRow.d.ts.map +1 -1
  40. package/lib/typescript/src/components/DeprecatedButton.d.ts +2 -2
  41. package/lib/typescript/src/components/DeprecatedButton.d.ts.map +1 -1
  42. package/lib/typescript/src/components/DeprecatedFAB.d.ts +2 -2
  43. package/lib/typescript/src/components/DeprecatedFAB.d.ts.map +1 -1
  44. package/lib/typescript/src/components/Pressable.d.ts +10 -0
  45. package/lib/typescript/src/components/Pressable.d.ts.map +1 -0
  46. package/lib/typescript/src/components/Swiper/Swiper.d.ts +2 -1
  47. package/lib/typescript/src/components/Swiper/Swiper.d.ts.map +1 -1
  48. package/lib/typescript/src/components/Touchable.d.ts +5 -6
  49. package/lib/typescript/src/components/Touchable.d.ts.map +1 -1
  50. package/lib/typescript/src/index.d.ts +30 -102
  51. package/lib/typescript/src/index.d.ts.map +1 -1
  52. package/lib/typescript/src/mappings/Button.d.ts +113 -4
  53. package/lib/typescript/src/mappings/Button.d.ts.map +1 -1
  54. package/lib/typescript/src/mappings/FlashList.d.ts +112 -2
  55. package/lib/typescript/src/mappings/FlashList.d.ts.map +1 -1
  56. package/lib/typescript/src/mappings/FlatList.d.ts +42 -0
  57. package/lib/typescript/src/mappings/FlatList.d.ts.map +1 -1
  58. package/lib/typescript/src/mappings/Swiper.d.ts +11 -0
  59. package/lib/typescript/src/mappings/Swiper.d.ts.map +1 -1
  60. package/lib/typescript/src/mappings/Touchable.d.ts +59 -5
  61. package/lib/typescript/src/mappings/Touchable.d.ts.map +1 -1
  62. package/package.json +3 -3
  63. package/src/components/Button.tsx +14 -4
  64. package/src/components/Checkbox/Checkbox.tsx +5 -7
  65. package/src/components/Checkbox/CheckboxGroupRow.tsx +3 -3
  66. package/src/components/Checkbox/CheckboxRow.tsx +3 -3
  67. package/src/components/DeprecatedButton.tsx +7 -31
  68. package/src/components/DeprecatedFAB.tsx +5 -5
  69. package/src/components/Pressable.tsx +44 -0
  70. package/src/components/Swiper/Swiper.tsx +3 -0
  71. package/src/components/Touchable.tsx +11 -7
  72. package/src/index.tsx +44 -123
  73. package/src/mappings/Button.ts +41 -10
  74. package/src/mappings/FlashList.ts +82 -30
  75. package/src/mappings/FlatList.ts +16 -0
  76. package/src/mappings/Swiper.ts +4 -0
  77. package/src/mappings/Touchable.ts +53 -6
  78. package/lib/commonjs/mappings/NativeBase/AlertDialog.js +0 -102
  79. package/lib/commonjs/mappings/NativeBase/Button.js +0 -84
  80. package/lib/commonjs/mappings/NativeBase/DataDisplay.js +0 -61
  81. package/lib/commonjs/mappings/NativeBase/Feedback.js +0 -74
  82. package/lib/commonjs/mappings/NativeBase/Layout.js +0 -114
  83. package/lib/commonjs/mappings/NativeBase/Media.js +0 -49
  84. package/lib/commonjs/mappings/NativeBase/Menu.js +0 -111
  85. package/lib/commonjs/mappings/NativeBase/Modal.js +0 -93
  86. package/lib/commonjs/mappings/NativeBase/Other.js +0 -94
  87. package/lib/commonjs/mappings/NativeBase/Popover.js +0 -99
  88. package/lib/commonjs/mappings/NativeBase/Select.js +0 -65
  89. package/lib/commonjs/mappings/NativeBase/Slider.js +0 -81
  90. package/lib/module/mappings/NativeBase/AlertDialog.js +0 -95
  91. package/lib/module/mappings/NativeBase/Button.js +0 -86
  92. package/lib/module/mappings/NativeBase/DataDisplay.js +0 -54
  93. package/lib/module/mappings/NativeBase/Feedback.js +0 -67
  94. package/lib/module/mappings/NativeBase/Layout.js +0 -107
  95. package/lib/module/mappings/NativeBase/Media.js +0 -42
  96. package/lib/module/mappings/NativeBase/Menu.js +0 -104
  97. package/lib/module/mappings/NativeBase/Modal.js +0 -86
  98. package/lib/module/mappings/NativeBase/Other.js +0 -87
  99. package/lib/module/mappings/NativeBase/Popover.js +0 -92
  100. package/lib/module/mappings/NativeBase/Select.js +0 -58
  101. package/lib/module/mappings/NativeBase/Slider.js +0 -74
  102. package/lib/typescript/src/mappings/NativeBase/AlertDialog.d.ts +0 -146
  103. package/lib/typescript/src/mappings/NativeBase/AlertDialog.d.ts.map +0 -1
  104. package/lib/typescript/src/mappings/NativeBase/Button.d.ts +0 -1
  105. package/lib/typescript/src/mappings/NativeBase/Button.d.ts.map +0 -1
  106. package/lib/typescript/src/mappings/NativeBase/DataDisplay.d.ts +0 -96
  107. package/lib/typescript/src/mappings/NativeBase/DataDisplay.d.ts.map +0 -1
  108. package/lib/typescript/src/mappings/NativeBase/Feedback.d.ts +0 -2
  109. package/lib/typescript/src/mappings/NativeBase/Feedback.d.ts.map +0 -1
  110. package/lib/typescript/src/mappings/NativeBase/Layout.d.ts +0 -146
  111. package/lib/typescript/src/mappings/NativeBase/Layout.d.ts.map +0 -1
  112. package/lib/typescript/src/mappings/NativeBase/Media.d.ts +0 -48
  113. package/lib/typescript/src/mappings/NativeBase/Media.d.ts.map +0 -1
  114. package/lib/typescript/src/mappings/NativeBase/Menu.d.ts +0 -227
  115. package/lib/typescript/src/mappings/NativeBase/Menu.d.ts.map +0 -1
  116. package/lib/typescript/src/mappings/NativeBase/Modal.d.ts +0 -133
  117. package/lib/typescript/src/mappings/NativeBase/Modal.d.ts.map +0 -1
  118. package/lib/typescript/src/mappings/NativeBase/Other.d.ts +0 -179
  119. package/lib/typescript/src/mappings/NativeBase/Other.d.ts.map +0 -1
  120. package/lib/typescript/src/mappings/NativeBase/Popover.d.ts +0 -136
  121. package/lib/typescript/src/mappings/NativeBase/Popover.d.ts.map +0 -1
  122. package/lib/typescript/src/mappings/NativeBase/Select.d.ts +0 -156
  123. package/lib/typescript/src/mappings/NativeBase/Select.d.ts.map +0 -1
  124. package/lib/typescript/src/mappings/NativeBase/Slider.d.ts +0 -200
  125. package/lib/typescript/src/mappings/NativeBase/Slider.d.ts.map +0 -1
  126. package/src/Provider.js +0 -9
  127. package/src/components/Accordion/AccordionGroup.js +0 -44
  128. package/src/components/Accordion/AccordionItem.js +0 -32
  129. package/src/components/Accordion/index.js +0 -2
  130. package/src/components/ActionSheet/ActionSheet.js +0 -45
  131. package/src/components/ActionSheet/ActionSheetCancel.js +0 -6
  132. package/src/components/ActionSheet/ActionSheetItem.js +0 -30
  133. package/src/components/ActionSheet/index.js +0 -3
  134. package/src/components/AnimatedCircularProgress.js +0 -43
  135. package/src/components/AspectRatio.js +0 -18
  136. package/src/components/AvatarEdit.js +0 -30
  137. package/src/components/Banner.js +0 -109
  138. package/src/components/Button.js +0 -114
  139. package/src/components/Card.js +0 -57
  140. package/src/components/CardBlock.js +0 -54
  141. package/src/components/CardContainer.js +0 -69
  142. package/src/components/CardContainerRating.js +0 -79
  143. package/src/components/CardContainerShortImage.js +0 -33
  144. package/src/components/CardInline.js +0 -36
  145. package/src/components/Carousel.js +0 -68
  146. package/src/components/Checkbox/Checkbox.js +0 -63
  147. package/src/components/Checkbox/CheckboxGroup.js +0 -21
  148. package/src/components/Checkbox/CheckboxGroupRow.js +0 -77
  149. package/src/components/Checkbox/CheckboxRow.js +0 -78
  150. package/src/components/Checkbox/context.js +0 -14
  151. package/src/components/Checkbox/index.js +0 -3
  152. package/src/components/CircleImage.js +0 -8
  153. package/src/components/CircularProgress.js +0 -81
  154. package/src/components/Config.js +0 -64
  155. package/src/components/Container.js +0 -43
  156. package/src/components/DatePicker/DatePicker.js +0 -377
  157. package/src/components/DatePicker/DatePickerComponent.js +0 -13
  158. package/src/components/DatePicker/DatePickerComponent.web.js +0 -30
  159. package/src/components/DatePicker/DatePickerComponentType.js +0 -1
  160. package/src/components/DeprecatedButton.js +0 -95
  161. package/src/components/DeprecatedCardWrapper.js +0 -18
  162. package/src/components/DeprecatedFAB.js +0 -115
  163. package/src/components/Divider.js +0 -13
  164. package/src/components/Elevation.js +0 -20
  165. package/src/components/FAB.js +0 -46
  166. package/src/components/FieldSearchBarFull.js +0 -53
  167. package/src/components/FormRow.js +0 -19
  168. package/src/components/Header.js +0 -44
  169. package/src/components/HeaderLarge.js +0 -7
  170. package/src/components/HeaderMedium.js +0 -7
  171. package/src/components/HeaderOverline.js +0 -7
  172. package/src/components/IconButton.js +0 -35
  173. package/src/components/Image.js +0 -47
  174. package/src/components/Justification.js +0 -1
  175. package/src/components/Layout.js +0 -50
  176. package/src/components/NumberInput.js +0 -49
  177. package/src/components/Picker/Picker.js +0 -267
  178. package/src/components/Picker/PickerComponent.android.js +0 -69
  179. package/src/components/Picker/PickerComponent.ios.js +0 -79
  180. package/src/components/Picker/PickerComponent.web.js +0 -70
  181. package/src/components/Picker/PickerTypes.js +0 -1
  182. package/src/components/Portal/Portal.js +0 -35
  183. package/src/components/Portal/PortalConsumer.js +0 -27
  184. package/src/components/Portal/PortalHost.js +0 -107
  185. package/src/components/Portal/PortalManager.js +0 -32
  186. package/src/components/ProgressBar.js +0 -118
  187. package/src/components/ProgressCircle.js +0 -13
  188. package/src/components/ProgressIndicator.js +0 -27
  189. package/src/components/RadioButton/RadioButton.js +0 -17
  190. package/src/components/RadioButton/RadioButtonFieldGroup.js +0 -17
  191. package/src/components/RadioButton/RadioButtonGroup.js +0 -43
  192. package/src/components/RadioButton/RadioButtonRow.js +0 -76
  193. package/src/components/RadioButton/context.js +0 -14
  194. package/src/components/RadioButton/index.js +0 -4
  195. package/src/components/ResizeMode.js +0 -1
  196. package/src/components/Row.js +0 -48
  197. package/src/components/RowBodyIcon.js +0 -8
  198. package/src/components/RowHeadlineImageCaption.js +0 -12
  199. package/src/components/RowHeadlineImageIcon.js +0 -14
  200. package/src/components/SVG.js +0 -13
  201. package/src/components/ScreenContainer.js +0 -34
  202. package/src/components/Slider.js +0 -63
  203. package/src/components/StarRating.js +0 -50
  204. package/src/components/StepIndicator.js +0 -346
  205. package/src/components/Stepper.js +0 -41
  206. package/src/components/Surface.js +0 -32
  207. package/src/components/Swiper/Swiper.js +0 -29
  208. package/src/components/Swiper/SwiperItem.js +0 -9
  209. package/src/components/Swiper/index.js +0 -2
  210. package/src/components/Switch.js +0 -56
  211. package/src/components/Text.js +0 -33
  212. package/src/components/TextField.js +0 -428
  213. package/src/components/ToggleButton.js +0 -39
  214. package/src/components/Touchable.js +0 -12
  215. package/src/components/Touchable.web.js +0 -2
  216. package/src/components/Typography.js +0 -36
  217. package/src/components/useAuthState.js +0 -31
  218. package/src/constants.js +0 -10
  219. package/src/hooks.js +0 -12
  220. package/src/index.js +0 -133
  221. package/src/interfaces/Icon.js +0 -8
  222. package/src/mappings/Accordion.js +0 -41
  223. package/src/mappings/AccordionItem.js +0 -16
  224. package/src/mappings/ActionSheet.js +0 -13
  225. package/src/mappings/ActionSheetCancel.js +0 -19
  226. package/src/mappings/ActionSheetItem.js +0 -23
  227. package/src/mappings/ActivityIndicator.js +0 -58
  228. package/src/mappings/AudioPlayer.js +0 -57
  229. package/src/mappings/AvatarEdit.js +0 -38
  230. package/src/mappings/Banner.js +0 -32
  231. package/src/mappings/BlurView.js +0 -42
  232. package/src/mappings/Button.js +0 -87
  233. package/src/mappings/Card.js +0 -52
  234. package/src/mappings/CardBlock.js +0 -123
  235. package/src/mappings/CardContainer.js +0 -104
  236. package/src/mappings/CardContainerRating.js +0 -126
  237. package/src/mappings/CardContainerShortImage.js +0 -120
  238. package/src/mappings/CardInline.js +0 -52
  239. package/src/mappings/Carousel.js +0 -19
  240. package/src/mappings/Checkbox.js +0 -46
  241. package/src/mappings/CheckboxGroup.js +0 -26
  242. package/src/mappings/CheckboxRow.js +0 -61
  243. package/src/mappings/CircleImage.js +0 -25
  244. package/src/mappings/Container.js +0 -30
  245. package/src/mappings/CustomCode.js +0 -8
  246. package/src/mappings/DatePicker.js +0 -176
  247. package/src/mappings/Divider.js +0 -27
  248. package/src/mappings/FAB.js +0 -37
  249. package/src/mappings/Fetch.js +0 -13
  250. package/src/mappings/FieldSearchBarFull.js +0 -50
  251. package/src/mappings/FlashList.js +0 -33
  252. package/src/mappings/FlatList.js +0 -24
  253. package/src/mappings/HeaderLarge.js +0 -29
  254. package/src/mappings/HeaderMedium.js +0 -55
  255. package/src/mappings/HeaderOverline.js +0 -55
  256. package/src/mappings/Icon.js +0 -32
  257. package/src/mappings/IconButton.js +0 -35
  258. package/src/mappings/Image.js +0 -35
  259. package/src/mappings/ImageBackground.js +0 -29
  260. package/src/mappings/KeyboardAvoidingView.js +0 -41
  261. package/src/mappings/KeyboardAwareScrollView.js +0 -50
  262. package/src/mappings/Layout.js +0 -200
  263. package/src/mappings/LinearGradient.js +0 -77
  264. package/src/mappings/MapCallout.js +0 -21
  265. package/src/mappings/MapMarker.js +0 -47
  266. package/src/mappings/MapView.js +0 -139
  267. package/src/mappings/Modal.js +0 -42
  268. package/src/mappings/NativeBase/AlertDialog.js +0 -112
  269. package/src/mappings/NativeBase/AlertDialog.ts +0 -128
  270. package/src/mappings/NativeBase/Button.js +0 -84
  271. package/src/mappings/NativeBase/Button.ts +0 -83
  272. package/src/mappings/NativeBase/DataDisplay.js +0 -67
  273. package/src/mappings/NativeBase/DataDisplay.ts +0 -79
  274. package/src/mappings/NativeBase/Feedback.js +0 -89
  275. package/src/mappings/NativeBase/Feedback.ts +0 -100
  276. package/src/mappings/NativeBase/Layout.js +0 -140
  277. package/src/mappings/NativeBase/Layout.ts +0 -152
  278. package/src/mappings/NativeBase/Media.js +0 -56
  279. package/src/mappings/NativeBase/Media.ts +0 -65
  280. package/src/mappings/NativeBase/Menu.js +0 -134
  281. package/src/mappings/NativeBase/Menu.ts +0 -150
  282. package/src/mappings/NativeBase/Modal.js +0 -103
  283. package/src/mappings/NativeBase/Modal.ts +0 -118
  284. package/src/mappings/NativeBase/Other.js +0 -123
  285. package/src/mappings/NativeBase/Other.ts +0 -139
  286. package/src/mappings/NativeBase/Popover.js +0 -123
  287. package/src/mappings/NativeBase/Popover.ts +0 -136
  288. package/src/mappings/NativeBase/Select.js +0 -71
  289. package/src/mappings/NativeBase/Select.ts +0 -85
  290. package/src/mappings/NativeBase/Slider.js +0 -89
  291. package/src/mappings/NativeBase/Slider.ts +0 -105
  292. package/src/mappings/NumberInput.js +0 -254
  293. package/src/mappings/Picker.js +0 -148
  294. package/src/mappings/ProgressBar.js +0 -101
  295. package/src/mappings/ProgressCircle.js +0 -109
  296. package/src/mappings/ProgressIndicator.js +0 -181
  297. package/src/mappings/RadioButton.js +0 -51
  298. package/src/mappings/RadioButtonGroup.js +0 -17
  299. package/src/mappings/RadioButtonRow.js +0 -42
  300. package/src/mappings/RowBodyIcon.js +0 -75
  301. package/src/mappings/RowHeadlineImageCaption.js +0 -167
  302. package/src/mappings/RowHeadlineImageIcon.js +0 -99
  303. package/src/mappings/SVG.js +0 -20
  304. package/src/mappings/SafeAreaView.js +0 -33
  305. package/src/mappings/ScrollView.js +0 -31
  306. package/src/mappings/Slider.js +0 -60
  307. package/src/mappings/StarRating.js +0 -43
  308. package/src/mappings/Stepper.js +0 -32
  309. package/src/mappings/Surface.js +0 -14
  310. package/src/mappings/Swiper.js +0 -60
  311. package/src/mappings/SwiperItem.js +0 -8
  312. package/src/mappings/Switch.js +0 -81
  313. package/src/mappings/Text.js +0 -251
  314. package/src/mappings/TextArea.js +0 -274
  315. package/src/mappings/TextField.js +0 -391
  316. package/src/mappings/TextInput.js +0 -402
  317. package/src/mappings/ToggleButton.js +0 -50
  318. package/src/mappings/Touchable.js +0 -17
  319. package/src/mappings/Video.js +0 -81
  320. package/src/mappings/View.js +0 -207
  321. package/src/mappings/WebView.js +0 -88
  322. package/src/styles/DarkTheme.js +0 -26
  323. package/src/styles/DefaultTheme.js +0 -111
  324. package/src/styles/fonts.js +0 -62
  325. package/src/styles/overlay.js +0 -60
  326. package/src/styles/shadow.js +0 -51
  327. package/src/theming.js +0 -3
  328. package/src/utilities.js +0 -102
@@ -1,428 +0,0 @@
1
- import * as React from "react";
2
- import { View, Animated, TextInput as NativeTextInput, StyleSheet, Text, I18nManager, } from "react-native";
3
- import { withTheme } from "../theming";
4
- import { applyStyles, extractStyles } from "../utilities";
5
- const AnimatedText = Animated.createAnimatedComponent(Text);
6
- const FOCUS_ANIMATION_DURATION = 150;
7
- const BLUR_ANIMATION_DURATION = 180;
8
- const ICON_SIZE = 24;
9
- class TextField extends React.Component {
10
- constructor() {
11
- super(...arguments);
12
- this.state = {
13
- nativeProps: {},
14
- labeled: new Animated.Value(this.props.value || this.props.error ? 0 : 1),
15
- focused: false,
16
- placeholder: this.props.error ? this.props.placeholder : "",
17
- labelLayout: {
18
- measured: false,
19
- width: 0,
20
- },
21
- };
22
- this._timer = setTimeout(() => { }, 0);
23
- this._showPlaceholder = () => {
24
- clearTimeout(this._timer);
25
- // Set the placeholder in a delay to offset the label animation
26
- // If we show it immediately, they'll overlap and look ugly
27
- this._timer = setTimeout(() => this.setState({
28
- placeholder: this.props.placeholder,
29
- }), 50);
30
- };
31
- this._hidePlaceholder = () => this.setState({
32
- placeholder: "",
33
- });
34
- this._restoreLabel = () => Animated.timing(this.state.labeled, {
35
- toValue: 1,
36
- duration: FOCUS_ANIMATION_DURATION,
37
- useNativeDriver: true,
38
- }).start();
39
- this._minmizeLabel = () => Animated.timing(this.state.labeled, {
40
- toValue: 0,
41
- duration: BLUR_ANIMATION_DURATION,
42
- useNativeDriver: true,
43
- }).start();
44
- this._handleFocus = () => {
45
- if (this.props.disabled) {
46
- return;
47
- }
48
- this.setState({ focused: true });
49
- };
50
- this._handleBlur = () => {
51
- if (this.props.disabled) {
52
- return;
53
- }
54
- this.setState({ focused: false });
55
- };
56
- this._handleChangeText = (value) => {
57
- if (this.props.disabled) {
58
- return;
59
- }
60
- if (typeof value === "string") {
61
- this.setState({ value });
62
- this.props.onChangeText && this.props.onChangeText(value);
63
- }
64
- else {
65
- this.setState({ value: value.nativeEvent.text });
66
- this.props.onChangeText &&
67
- this.props.onChangeText(value.nativeEvent.text);
68
- }
69
- };
70
- this._root = undefined;
71
- }
72
- static getDerivedStateFromProps(nextProps, prevState) {
73
- return {
74
- value: typeof nextProps.value !== "undefined"
75
- ? nextProps.value
76
- : prevState.value,
77
- };
78
- }
79
- componentDidMount() {
80
- if (this.props.defaultValue) {
81
- this._handleChangeText(this.props.defaultValue);
82
- }
83
- if (this.props.placeholder) {
84
- this._minmizeLabel();
85
- }
86
- }
87
- componentDidUpdate(prevProps, prevState) {
88
- if (prevState.focused !== this.state.focused ||
89
- prevState.value !== this.state.value) {
90
- // The label should be minimized if the text input is focused, or has text
91
- // In minimized mode, the label moves up and becomes small
92
- if (this.state.value ||
93
- this.state.focused ||
94
- this.props.error ||
95
- this.props.placeholder) {
96
- this._minmizeLabel();
97
- }
98
- else {
99
- this._restoreLabel();
100
- }
101
- }
102
- if (prevState.focused !== this.state.focused ||
103
- prevProps.label !== this.props.label) {
104
- // Show placeholder text only if the input is focused, or has error, or there's no label
105
- // We don't show placeholder if there's a label because the label acts as placeholder
106
- // When focused, the label moves up, so we can show a placeholder
107
- if (this.state.focused || this.props.error || !this.props.label) {
108
- this._showPlaceholder();
109
- }
110
- else {
111
- this._hidePlaceholder();
112
- }
113
- }
114
- }
115
- componentWillUnmount() {
116
- clearTimeout(this._timer);
117
- }
118
- toggleFocus() {
119
- this.setState((prevState) => ({ focused: !prevState.focused }));
120
- }
121
- /**
122
- * @internal
123
- */
124
- setNativeProps(args) {
125
- this.setState((state) => ({
126
- ...state,
127
- nativeState: args || {},
128
- }));
129
- }
130
- isFocused() {
131
- return this._root && this._root.isFocused();
132
- }
133
- clear() {
134
- return this._root && this._root.clear();
135
- }
136
- focus() {
137
- return this._root && this._root.focus();
138
- }
139
- blur() {
140
- return this._root && this._root.blur();
141
- }
142
- render() {
143
- const { Icon, type = "underline", disabled = false, label, error = false, leftIconName, leftIconMode, rightIconName, assistiveText, underlineColor: underlineColorProp, activeBorderColor: activeBorderColorProp, multiline = false, numberOfLines = 4, style, theme: { colors, typography, roundness, disabledOpacity }, render = (props) => React.createElement(NativeTextInput, { ...props }), ...rest } = this.props;
144
- const MINIMIZED_LABEL_Y_OFFSET = -(typography.caption.lineHeight + 4);
145
- const OUTLINE_MINIMIZED_LABEL_Y_OFFSET = -(16 * 0.5 + 4);
146
- const MAXIMIZED_LABEL_FONT_SIZE = typography.subtitle1.fontSize;
147
- const MINIMIZED_LABEL_FONT_SIZE = typography.caption.fontSize;
148
- const hasActiveOutline = this.state.focused || error;
149
- let inputTextColor, activeColor, underlineColor, borderColor, placeholderColor, containerStyle, backgroundColor, inputStyle;
150
- inputTextColor = colors.strong;
151
- if (disabled) {
152
- activeColor = colors.light;
153
- placeholderColor = colors.light;
154
- borderColor = "transparent";
155
- underlineColor = "transparent";
156
- backgroundColor = colors.divider;
157
- }
158
- else {
159
- activeColor = error ? colors.error : activeBorderColorProp;
160
- placeholderColor = borderColor = colors.light;
161
- underlineColor = underlineColorProp;
162
- backgroundColor = colors.background;
163
- }
164
- if (rest.placeholderTextColor) {
165
- placeholderColor = rest.placeholderTextColor;
166
- }
167
- const { lineHeight, ...subtitle1 } = typography.subtitle1;
168
- inputStyle = {
169
- paddingVertical: 0,
170
- color: inputTextColor,
171
- paddingLeft: leftIconName && leftIconMode === "inset"
172
- ? ICON_SIZE + 12 + (type === "solid" ? 16 : 0)
173
- : 0,
174
- paddingRight: rightIconName ? ICON_SIZE + 16 + 4 : 12,
175
- ...subtitle1,
176
- };
177
- if (!multiline) {
178
- inputStyle.height = lineHeight;
179
- }
180
- let assistiveTextLeftMargin;
181
- if (type === "underline") {
182
- containerStyle = {
183
- borderTopLeftRadius: roundness,
184
- borderTopRightRadius: roundness,
185
- paddingBottom: 12,
186
- marginTop: 16,
187
- };
188
- if (leftIconName && leftIconMode === "outset") {
189
- assistiveTextLeftMargin = ICON_SIZE + 8;
190
- }
191
- else {
192
- assistiveTextLeftMargin = 0;
193
- }
194
- }
195
- else {
196
- containerStyle = {
197
- borderRadius: roundness,
198
- borderColor: hasActiveOutline ? activeColor : borderColor,
199
- borderWidth: 1,
200
- paddingTop: label ? 16 * 1.5 : 16,
201
- paddingBottom: label ? 16 * 0.5 : 16,
202
- opacity: disabled ? disabledOpacity : 1,
203
- backgroundColor,
204
- };
205
- if (leftIconName && leftIconMode === "inset") {
206
- assistiveTextLeftMargin = 16 + 4;
207
- }
208
- else if (leftIconName && leftIconMode === "outset") {
209
- assistiveTextLeftMargin = ICON_SIZE + 8 + 12;
210
- }
211
- else {
212
- assistiveTextLeftMargin = 12;
213
- }
214
- inputStyle.paddingHorizontal = 12;
215
- }
216
- if (leftIconName && leftIconMode === "outset") {
217
- containerStyle.marginLeft = ICON_SIZE + 8;
218
- }
219
- let leftIconColor;
220
- if (error) {
221
- leftIconColor = colors.error;
222
- }
223
- else if (this.state.focused) {
224
- leftIconColor = colors.primary;
225
- }
226
- else {
227
- leftIconColor = colors.light;
228
- }
229
- const leftIconProps = {
230
- size: 24,
231
- color: leftIconColor,
232
- name: leftIconName || "",
233
- };
234
- const leftIconStyle = {
235
- position: "absolute",
236
- marginTop: type === "solid"
237
- ? MINIMIZED_LABEL_FONT_SIZE + 4
238
- : leftIconMode === "outset"
239
- ? 16
240
- : 0,
241
- marginLeft: leftIconMode === "inset" && type === "solid" ? 16 : 0,
242
- };
243
- const labelStyle = {
244
- ...typography.subtitle1,
245
- top: type === "solid" ? 16 : 0,
246
- left: leftIconName && leftIconMode === "inset"
247
- ? ICON_SIZE + (type === "solid" ? 16 : 12)
248
- : 0,
249
- transform: [
250
- {
251
- // Move label to top
252
- translateY: this.state.labeled.interpolate({
253
- inputRange: [0, 1],
254
- outputRange: [
255
- type === "solid"
256
- ? OUTLINE_MINIMIZED_LABEL_Y_OFFSET
257
- : MINIMIZED_LABEL_Y_OFFSET,
258
- 0,
259
- ],
260
- }),
261
- },
262
- {
263
- // Make label smaller
264
- scale: this.state.labeled.interpolate({
265
- inputRange: [0, 1],
266
- outputRange: [
267
- MINIMIZED_LABEL_FONT_SIZE / MAXIMIZED_LABEL_FONT_SIZE,
268
- 1,
269
- ],
270
- }),
271
- },
272
- {
273
- // Offset label scale since RN doesn't support transform origin
274
- translateX: this.state.labeled.interpolate({
275
- inputRange: [0, 1],
276
- outputRange: [
277
- -(1 - MINIMIZED_LABEL_FONT_SIZE / MAXIMIZED_LABEL_FONT_SIZE) *
278
- (this.state.labelLayout.width / 2),
279
- 0,
280
- ],
281
- }),
282
- },
283
- ],
284
- };
285
- const { textStyles } = extractStyles(style);
286
- const inputStyles = applyStyles([
287
- styles.input,
288
- inputStyle,
289
- type === "solid" ? { marginHorizontal: 12 } : {},
290
- ], textStyles);
291
- const { backgroundColor: bgColor, padding, paddingTop, paddingBottom, paddingLeft, paddingRight, borderRadius, borderWidth, borderTopWidth, borderRightWidth, borderBottomWidth, borderLeftWidth, borderColor: borderCol, ...styleProp } = StyleSheet.flatten(style || {});
292
- return (React.createElement(View, { style: [styles.container, styleProp] },
293
- leftIconName && leftIconMode === "outset" ? (React.createElement(Icon, { ...leftIconProps, style: leftIconStyle })) : null,
294
- React.createElement(View, { style: applyStyles([containerStyle], {
295
- height: style === null || style === void 0 ? void 0 : style.height,
296
- backgroundColor: bgColor,
297
- padding,
298
- paddingTop,
299
- paddingBottom,
300
- paddingLeft,
301
- paddingRight,
302
- borderRadius,
303
- borderWidth,
304
- borderTopWidth,
305
- borderRightWidth,
306
- borderBottomWidth,
307
- borderLeftWidth,
308
- borderColor: borderCol,
309
- }) },
310
- type === "underline" ? (
311
- // When type === 'flat', render an underline
312
- React.createElement(Animated.View, { style: [
313
- styles.underline,
314
- {
315
- backgroundColor: bgColor ||
316
- (error
317
- ? colors.error
318
- : this.state.focused
319
- ? activeColor
320
- : underlineColor),
321
- // Underlines is thinner when input is not focused
322
- transform: [{ scaleY: this.state.focused ? 1 : 0.5 }],
323
- },
324
- ] })) : null,
325
- label ? (
326
- // Position colored placeholder and gray placeholder on top of each other and crossfade them
327
- // This gives the effect of animating the color, but allows us to use native driver
328
- React.createElement(View, { pointerEvents: "none", style: [
329
- StyleSheet.absoluteFill,
330
- {
331
- opacity:
332
- // Hide the label in minimized state until we measure its width
333
- this.state.value || this.state.focused
334
- ? this.state.labelLayout.measured
335
- ? 1
336
- : 0
337
- : 1,
338
- },
339
- ] },
340
- React.createElement(AnimatedText, { onLayout: (e) => this.setState({
341
- labelLayout: {
342
- width: e.nativeEvent.layout.width,
343
- measured: true,
344
- },
345
- }), style: [
346
- styles.placeholder,
347
- type === "solid" ? { paddingHorizontal: 12 } : {},
348
- labelStyle,
349
- {
350
- color: placeholderColor,
351
- opacity: this.state.labeled.interpolate({
352
- inputRange: [0, 1],
353
- outputRange: [hasActiveOutline ? 1 : 0, 0],
354
- }),
355
- },
356
- ], numberOfLines: 1 }, label),
357
- React.createElement(AnimatedText, { style: [
358
- styles.placeholder,
359
- type === "solid" ? { paddingHorizontal: 12 } : {},
360
- labelStyle,
361
- {
362
- color: placeholderColor,
363
- opacity: hasActiveOutline ? this.state.labeled : 1,
364
- },
365
- ], numberOfLines: 1 }, label))) : null,
366
- leftIconName && leftIconMode === "inset" ? (React.createElement(View, { style: {
367
- justifyContent: type === "solid" ? "center" : undefined,
368
- } },
369
- React.createElement(Icon, { ...leftIconProps, style: leftIconStyle }))) : null,
370
- render({
371
- ref: (c) => {
372
- this._root = c;
373
- },
374
- onChange: this._handleChangeText,
375
- placeholder: label
376
- ? this.state.placeholder
377
- : this.props.placeholder,
378
- placeholderTextColor: placeholderColor,
379
- editable: !disabled,
380
- selectionColor: activeColor,
381
- multiline,
382
- numberOfLines,
383
- onFocus: this._handleFocus,
384
- onBlur: this._handleBlur,
385
- underlineColorAndroid: "transparent",
386
- style: inputStyles,
387
- ...rest,
388
- ...this.state.nativeProps,
389
- value: this.state.value,
390
- })),
391
- rightIconName ? (React.createElement(Icon, { name: rightIconName, size: ICON_SIZE, color: colors.light, style: {
392
- position: "absolute",
393
- right: 16,
394
- marginTop: type === "solid" ? MINIMIZED_LABEL_FONT_SIZE + 4 : 16,
395
- } })) : null,
396
- assistiveText ? (React.createElement(Text, { style: [
397
- {
398
- color: error ? colors.error : colors.light,
399
- marginTop: 8,
400
- marginLeft: assistiveTextLeftMargin,
401
- },
402
- ] }, assistiveText)) : null));
403
- }
404
- }
405
- export default withTheme(TextField);
406
- const styles = StyleSheet.create({
407
- container: {
408
- alignSelf: "stretch",
409
- },
410
- placeholder: {
411
- position: "absolute",
412
- left: 0,
413
- },
414
- underline: {
415
- position: "absolute",
416
- left: 0,
417
- right: 0,
418
- bottom: 0,
419
- height: 2,
420
- },
421
- input: {
422
- flexGrow: 1,
423
- justifyContent: "center",
424
- textAlignVertical: "center",
425
- margin: 0,
426
- textAlign: I18nManager.isRTL ? "right" : "left",
427
- },
428
- });
@@ -1,39 +0,0 @@
1
- import * as React from "react";
2
- import { withTheme } from "../theming";
3
- import { StyleSheet } from "react-native";
4
- import IconButton from "./IconButton";
5
- const ToggleButton = ({ Icon, icon, toggled = false, onPress = () => { }, defaultValue, disabled = false, color = "primary", colorSecondary = "surface", borderColor = "divider", iconSize = 25, width = 50, height = 50, theme: { colors }, style, ...rest }) => {
6
- const [internalValue, setInternalValue] = React.useState(toggled || defaultValue || false);
7
- React.useEffect(() => {
8
- if (toggled != null) {
9
- setInternalValue(toggled);
10
- }
11
- }, [toggled]);
12
- React.useEffect(() => {
13
- if (defaultValue != null) {
14
- setInternalValue(defaultValue);
15
- }
16
- }, [defaultValue]);
17
- const handlePress = () => {
18
- setInternalValue(!internalValue);
19
- onPress(!internalValue);
20
- };
21
- return (React.createElement(IconButton, { Icon: Icon, icon: icon, size: iconSize, color: internalValue ? colors[color] : colors[colorSecondary], onPress: handlePress, disabled: disabled, style: [
22
- styles.mainContainer,
23
- {
24
- width,
25
- height,
26
- backgroundColor: internalValue
27
- ? colors[colorSecondary]
28
- : colors[color],
29
- borderColor: colors[borderColor],
30
- },
31
- style,
32
- ], ...rest }));
33
- };
34
- const styles = StyleSheet.create({
35
- mainContainer: {
36
- borderWidth: 1,
37
- },
38
- });
39
- export default withTheme(ToggleButton);
@@ -1,12 +0,0 @@
1
- import React from "react";
2
- import { Pressable } from "react-native";
3
- export default function Touchable({ children, disabled, onPress, style, ...props }) {
4
- return (React.createElement(Pressable, { onPress: onPress, disabled: disabled, hitSlop: 8, style: ({ pressed }) => {
5
- return [
6
- {
7
- opacity: pressed || disabled ? 0.75 : 1,
8
- },
9
- style,
10
- ];
11
- }, ...props }, children));
12
- }
@@ -1,2 +0,0 @@
1
- import { TouchableOpacity } from "react-native";
2
- export default TouchableOpacity;
@@ -1,36 +0,0 @@
1
- import React from "react";
2
- import { Text } from "react-native";
3
- import { withTheme } from "../theming";
4
- export const Title = withTheme(({ text, theme, style }) => {
5
- return (React.createElement(Text, { style: [
6
- {
7
- fontSize: 20,
8
- letterSpacing: 0,
9
- lineHeight: 26,
10
- color: theme.colors.text,
11
- },
12
- style,
13
- ] }, text));
14
- });
15
- export const Subtitle = withTheme(({ text, theme, style }) => {
16
- return (React.createElement(Text, { style: [
17
- {
18
- fontSize: 14,
19
- letterSpacing: 0,
20
- lineHeight: 16,
21
- color: theme.colors.medium,
22
- },
23
- style,
24
- ] }, text));
25
- });
26
- export const Caption = withTheme(({ text, theme, style }) => {
27
- return (React.createElement(Text, { style: [
28
- {
29
- fontSize: 12,
30
- letterSpacing: 0,
31
- lineHeight: 14,
32
- color: theme.colors.light,
33
- },
34
- style,
35
- ] }, text));
36
- });
@@ -1,31 +0,0 @@
1
- import * as React from "react";
2
- export const useAuthState = (auth) => {
3
- const [error, setError] = React.useState();
4
- const [value, setValue] = React.useState(auth.currentUser);
5
- React.useEffect(() => {
6
- const list = auth.onAuthStateChanged(setValue, setError);
7
- return () => {
8
- list();
9
- };
10
- }, [auth]);
11
- const signInWithEmailAndPassword = (user, password) => {
12
- auth
13
- .signInWithEmailAndPassword(user, password)
14
- .then(setValue)
15
- .catch(setError);
16
- };
17
- const createUserWithEmailAndPassword = (user, password) => {
18
- auth
19
- .signInWithEmailAndPassword(user, password)
20
- .then(setValue)
21
- .catch(setError);
22
- };
23
- const signOut = () => auth.signOut();
24
- return [
25
- value,
26
- error,
27
- signInWithEmailAndPassword,
28
- signOut,
29
- createUserWithEmailAndPassword,
30
- ];
31
- };
package/src/constants.js DELETED
@@ -1,10 +0,0 @@
1
- import { Platform } from "react-native";
2
- // @ts-ignore
3
- const expo = global.__expo;
4
- const DEFAULT_STATUSBAR_HEIGHT_EXPO = (expo === null || expo === void 0 ? void 0 : expo.Constants)
5
- ? expo.Constants.statusBarHeight
6
- : 0;
7
- export const APPROX_STATUSBAR_HEIGHT = Platform.select({
8
- android: DEFAULT_STATUSBAR_HEIGHT_EXPO,
9
- ios: Platform.Version < 11 ? DEFAULT_STATUSBAR_HEIGHT_EXPO : 0,
10
- });
package/src/hooks.js DELETED
@@ -1,12 +0,0 @@
1
- import React from "react";
2
- export function usePrevious(value) {
3
- // The ref object is a generic container whose current property is mutable
4
- // and can hold any value, similar to an instance property on a class
5
- const ref = React.useRef();
6
- // Store current value in ref
7
- React.useEffect(() => {
8
- ref.current = value;
9
- }, [value]);
10
- // Return previous value (happens before update in useEffect above)
11
- return ref.current;
12
- }