@draftbit/core 47.0.0 → 47.0.1-50db3c.2

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 (247) hide show
  1. package/lib/commonjs/components/Accordion/AccordionItem.js +23 -4
  2. package/lib/commonjs/components/Button.js +31 -22
  3. package/lib/commonjs/components/Checkbox/Checkbox.js +1 -3
  4. package/lib/commonjs/components/DeprecatedCardWrapper.js +2 -2
  5. package/lib/commonjs/components/DeprecatedFAB.js +1 -2
  6. package/lib/commonjs/components/Justification.js +5 -1
  7. package/lib/commonjs/components/Picker/Picker.js +3 -4
  8. package/lib/commonjs/components/Picker/PickerComponent.android.js +20 -3
  9. package/lib/commonjs/components/Picker/PickerComponent.ios.js +2 -2
  10. package/lib/commonjs/components/Pressable.js +59 -0
  11. package/lib/commonjs/components/ResizeMode.js +5 -1
  12. package/lib/commonjs/components/Touchable.js +27 -11
  13. package/lib/commonjs/constants.js +1 -1
  14. package/lib/commonjs/mappings/Button.js +21 -10
  15. package/lib/commonjs/mappings/Pressable.js +52 -0
  16. package/lib/module/components/Button.js +25 -16
  17. package/lib/module/components/Checkbox/Checkbox.js +2 -3
  18. package/lib/module/components/DeprecatedCardWrapper.js +2 -2
  19. package/lib/module/components/DeprecatedFAB.js +2 -3
  20. package/lib/module/components/Justification.js +1 -0
  21. package/lib/module/components/Picker/Picker.js +3 -4
  22. package/lib/module/components/Picker/PickerComponent.ios.js +1 -1
  23. package/lib/module/components/Pressable.js +40 -0
  24. package/lib/module/components/ResizeMode.js +1 -0
  25. package/lib/module/components/Touchable.js +25 -10
  26. package/lib/module/mappings/Button.js +22 -11
  27. package/lib/module/mappings/Pressable.js +45 -0
  28. package/lib/typescript/src/components/Button.d.ts +2 -0
  29. package/lib/typescript/src/components/Button.d.ts.map +1 -1
  30. package/lib/typescript/src/components/Checkbox/Checkbox.d.ts +2 -2
  31. package/lib/typescript/src/components/Checkbox/Checkbox.d.ts.map +1 -1
  32. package/lib/typescript/src/components/DeprecatedCardWrapper.d.ts.map +1 -1
  33. package/lib/typescript/src/components/DeprecatedFAB.d.ts +2 -2
  34. package/lib/typescript/src/components/DeprecatedFAB.d.ts.map +1 -1
  35. package/lib/typescript/src/components/Picker/Picker.d.ts.map +1 -1
  36. package/lib/typescript/src/components/Pressable.d.ts +18 -0
  37. package/lib/typescript/src/components/Pressable.d.ts.map +1 -0
  38. package/lib/typescript/src/components/Touchable.d.ts +9 -2
  39. package/lib/typescript/src/components/Touchable.d.ts.map +1 -1
  40. package/lib/typescript/src/mappings/Button.d.ts +113 -4
  41. package/lib/typescript/src/mappings/Button.d.ts.map +1 -1
  42. package/lib/typescript/src/mappings/Pressable.d.ts +76 -0
  43. package/lib/typescript/src/mappings/Pressable.d.ts.map +1 -0
  44. package/package.json +3 -3
  45. package/src/Provider.js +9 -0
  46. package/src/components/Accordion/AccordionGroup.js +44 -0
  47. package/src/components/Accordion/AccordionItem.js +32 -0
  48. package/src/components/Accordion/index.js +2 -0
  49. package/src/components/ActionSheet/ActionSheet.js +45 -0
  50. package/src/components/ActionSheet/ActionSheetCancel.js +6 -0
  51. package/src/components/ActionSheet/ActionSheetItem.js +30 -0
  52. package/src/components/ActionSheet/index.js +3 -0
  53. package/src/components/AnimatedCircularProgress.js +43 -0
  54. package/src/components/AspectRatio.js +18 -0
  55. package/src/components/AvatarEdit.js +30 -0
  56. package/src/components/Banner.js +109 -0
  57. package/src/components/Button.js +118 -0
  58. package/src/components/Button.tsx +49 -18
  59. package/src/components/Card.js +57 -0
  60. package/src/components/CardBlock.js +54 -0
  61. package/src/components/CardContainer.js +69 -0
  62. package/src/components/CardContainerRating.js +79 -0
  63. package/src/components/CardContainerShortImage.js +33 -0
  64. package/src/components/CardInline.js +36 -0
  65. package/src/components/Carousel.js +68 -0
  66. package/src/components/Checkbox/Checkbox.js +62 -0
  67. package/src/components/Checkbox/Checkbox.tsx +5 -7
  68. package/src/components/Checkbox/CheckboxGroup.js +21 -0
  69. package/src/components/Checkbox/CheckboxGroupRow.js +77 -0
  70. package/src/components/Checkbox/CheckboxRow.js +78 -0
  71. package/src/components/Checkbox/context.js +14 -0
  72. package/src/components/Checkbox/index.js +3 -0
  73. package/src/components/CircleImage.js +8 -0
  74. package/src/components/CircularProgress.js +81 -0
  75. package/src/components/Config.js +64 -0
  76. package/src/components/Container.js +43 -0
  77. package/src/components/DatePicker/DatePicker.js +377 -0
  78. package/src/components/DatePicker/DatePickerComponent.js +13 -0
  79. package/src/components/DatePicker/DatePickerComponent.web.js +30 -0
  80. package/src/components/DatePicker/DatePickerComponentType.js +1 -0
  81. package/src/components/DeprecatedCardWrapper.js +18 -0
  82. package/src/components/DeprecatedCardWrapper.tsx +3 -4
  83. package/src/components/DeprecatedFAB.js +114 -0
  84. package/src/components/DeprecatedFAB.tsx +5 -5
  85. package/src/components/Divider.js +13 -0
  86. package/src/components/Elevation.js +20 -0
  87. package/src/components/FAB.js +46 -0
  88. package/src/components/FieldSearchBarFull.js +53 -0
  89. package/src/components/FormRow.js +19 -0
  90. package/src/components/Header.js +44 -0
  91. package/src/components/HeaderLarge.js +7 -0
  92. package/src/components/HeaderMedium.js +7 -0
  93. package/src/components/HeaderOverline.js +7 -0
  94. package/src/components/IconButton.js +35 -0
  95. package/src/components/Image.js +47 -0
  96. package/src/components/Justification.js +1 -0
  97. package/src/components/Layout.js +50 -0
  98. package/src/components/NumberInput.js +49 -0
  99. package/src/components/Picker/Picker.js +266 -0
  100. package/src/components/Picker/Picker.tsx +4 -4
  101. package/src/components/Picker/PickerComponent.android.js +69 -0
  102. package/src/components/Picker/PickerComponent.ios.js +79 -0
  103. package/src/components/Picker/PickerComponent.ios.tsx +1 -1
  104. package/src/components/Picker/PickerComponent.web.js +70 -0
  105. package/src/components/Picker/PickerTypes.js +1 -0
  106. package/src/components/Portal/Portal.js +35 -0
  107. package/src/components/Portal/PortalConsumer.js +27 -0
  108. package/src/components/Portal/PortalHost.js +107 -0
  109. package/src/components/Portal/PortalManager.js +32 -0
  110. package/src/components/Pressable.js +17 -0
  111. package/src/components/Pressable.tsx +67 -0
  112. package/src/components/ProgressBar.js +118 -0
  113. package/src/components/ProgressCircle.js +13 -0
  114. package/src/components/ProgressIndicator.js +27 -0
  115. package/src/components/RadioButton/RadioButton.js +17 -0
  116. package/src/components/RadioButton/RadioButtonFieldGroup.js +17 -0
  117. package/src/components/RadioButton/RadioButtonGroup.js +43 -0
  118. package/src/components/RadioButton/RadioButtonRow.js +76 -0
  119. package/src/components/RadioButton/context.js +14 -0
  120. package/src/components/RadioButton/index.js +4 -0
  121. package/src/components/ResizeMode.js +1 -0
  122. package/src/components/Row.js +48 -0
  123. package/src/components/RowBodyIcon.js +8 -0
  124. package/src/components/RowHeadlineImageCaption.js +12 -0
  125. package/src/components/RowHeadlineImageIcon.js +14 -0
  126. package/src/components/SVG.js +13 -0
  127. package/src/components/ScreenContainer.js +34 -0
  128. package/src/components/Slider.js +63 -0
  129. package/src/components/StarRating.js +50 -0
  130. package/src/components/StepIndicator.js +346 -0
  131. package/src/components/Stepper.js +41 -0
  132. package/src/components/Surface.js +32 -0
  133. package/src/components/Swiper/Swiper.js +29 -0
  134. package/src/components/Swiper/SwiperItem.js +9 -0
  135. package/src/components/Swiper/index.js +2 -0
  136. package/src/components/Switch.js +56 -0
  137. package/src/components/Text.js +33 -0
  138. package/src/components/TextField.js +428 -0
  139. package/src/components/ToggleButton.js +39 -0
  140. package/src/components/Touchable.js +17 -0
  141. package/src/components/Touchable.tsx +42 -11
  142. package/src/components/Typography.js +36 -0
  143. package/src/components/useAuthState.js +31 -0
  144. package/src/constants.js +10 -0
  145. package/src/hooks.js +12 -0
  146. package/src/index.js +52 -0
  147. package/src/interfaces/Icon.js +8 -0
  148. package/src/mappings/Accordion.js +41 -0
  149. package/src/mappings/AccordionItem.js +16 -0
  150. package/src/mappings/ActionSheet.js +13 -0
  151. package/src/mappings/ActionSheetCancel.js +19 -0
  152. package/src/mappings/ActionSheetItem.js +23 -0
  153. package/src/mappings/ActivityIndicator.js +58 -0
  154. package/src/mappings/AudioPlayer.js +57 -0
  155. package/src/mappings/AvatarEdit.js +38 -0
  156. package/src/mappings/Banner.js +32 -0
  157. package/src/mappings/BlurView.js +42 -0
  158. package/src/mappings/Button.js +98 -0
  159. package/src/mappings/Button.ts +21 -10
  160. package/src/mappings/Card.js +52 -0
  161. package/src/mappings/CardBlock.js +123 -0
  162. package/src/mappings/CardContainer.js +104 -0
  163. package/src/mappings/CardContainerRating.js +126 -0
  164. package/src/mappings/CardContainerShortImage.js +120 -0
  165. package/src/mappings/CardInline.js +52 -0
  166. package/src/mappings/Carousel.js +19 -0
  167. package/src/mappings/Checkbox.js +46 -0
  168. package/src/mappings/CheckboxGroup.js +26 -0
  169. package/src/mappings/CheckboxRow.js +61 -0
  170. package/src/mappings/CircleImage.js +25 -0
  171. package/src/mappings/Container.js +30 -0
  172. package/src/mappings/CustomCode.js +8 -0
  173. package/src/mappings/DatePicker.js +176 -0
  174. package/src/mappings/Divider.js +27 -0
  175. package/src/mappings/FAB.js +37 -0
  176. package/src/mappings/Fetch.js +13 -0
  177. package/src/mappings/FieldSearchBarFull.js +50 -0
  178. package/src/mappings/FlashList.js +33 -0
  179. package/src/mappings/FlatList.js +24 -0
  180. package/src/mappings/HeaderLarge.js +29 -0
  181. package/src/mappings/HeaderMedium.js +55 -0
  182. package/src/mappings/HeaderOverline.js +55 -0
  183. package/src/mappings/Icon.js +32 -0
  184. package/src/mappings/IconButton.js +35 -0
  185. package/src/mappings/Image.js +35 -0
  186. package/src/mappings/ImageBackground.js +29 -0
  187. package/src/mappings/KeyboardAvoidingView.js +41 -0
  188. package/src/mappings/KeyboardAwareScrollView.js +50 -0
  189. package/src/mappings/Layout.js +200 -0
  190. package/src/mappings/LinearGradient.js +77 -0
  191. package/src/mappings/MapCallout.js +21 -0
  192. package/src/mappings/MapMarker.js +47 -0
  193. package/src/mappings/MapView.js +139 -0
  194. package/src/mappings/Modal.js +42 -0
  195. package/src/mappings/NumberInput.js +254 -0
  196. package/src/mappings/Picker.js +148 -0
  197. package/src/mappings/Pressable.js +52 -0
  198. package/src/mappings/Pressable.ts +63 -0
  199. package/src/mappings/ProgressBar.js +101 -0
  200. package/src/mappings/ProgressCircle.js +109 -0
  201. package/src/mappings/ProgressIndicator.js +181 -0
  202. package/src/mappings/RadioButton.js +51 -0
  203. package/src/mappings/RadioButtonGroup.js +17 -0
  204. package/src/mappings/RadioButtonRow.js +42 -0
  205. package/src/mappings/RowBodyIcon.js +75 -0
  206. package/src/mappings/RowHeadlineImageCaption.js +167 -0
  207. package/src/mappings/RowHeadlineImageIcon.js +99 -0
  208. package/src/mappings/SVG.js +20 -0
  209. package/src/mappings/SafeAreaView.js +33 -0
  210. package/src/mappings/ScrollView.js +31 -0
  211. package/src/mappings/Slider.js +60 -0
  212. package/src/mappings/StarRating.js +43 -0
  213. package/src/mappings/Stepper.js +32 -0
  214. package/src/mappings/Surface.js +14 -0
  215. package/src/mappings/Swiper.js +60 -0
  216. package/src/mappings/SwiperItem.js +8 -0
  217. package/src/mappings/Switch.js +81 -0
  218. package/src/mappings/Text.js +251 -0
  219. package/src/mappings/TextArea.js +274 -0
  220. package/src/mappings/TextField.js +391 -0
  221. package/src/mappings/TextInput.js +402 -0
  222. package/src/mappings/ToggleButton.js +50 -0
  223. package/src/mappings/Video.js +81 -0
  224. package/src/mappings/View.js +207 -0
  225. package/src/mappings/WebView.js +88 -0
  226. package/src/styles/DarkTheme.js +26 -0
  227. package/src/styles/DefaultTheme.js +111 -0
  228. package/src/styles/fonts.js +62 -0
  229. package/src/styles/overlay.js +60 -0
  230. package/src/styles/shadow.js +51 -0
  231. package/src/theming.js +3 -0
  232. package/src/utilities.js +102 -0
  233. package/lib/commonjs/components/DeprecatedButton.js +0 -151
  234. package/lib/commonjs/components/Touchable.web.js +0 -9
  235. package/lib/commonjs/mappings/Touchable.js +0 -20
  236. package/lib/module/components/DeprecatedButton.js +0 -141
  237. package/lib/module/components/Touchable.web.js +0 -2
  238. package/lib/module/mappings/Touchable.js +0 -13
  239. package/lib/typescript/src/components/DeprecatedButton.d.ts +0 -54
  240. package/lib/typescript/src/components/DeprecatedButton.d.ts.map +0 -1
  241. package/lib/typescript/src/components/Touchable.web.d.ts +0 -3
  242. package/lib/typescript/src/components/Touchable.web.d.ts.map +0 -1
  243. package/lib/typescript/src/mappings/Touchable.d.ts +0 -22
  244. package/lib/typescript/src/mappings/Touchable.d.ts.map +0 -1
  245. package/src/components/DeprecatedButton.tsx +0 -214
  246. package/src/components/Touchable.web.tsx +0 -3
  247. package/src/mappings/Touchable.ts +0 -23
@@ -7,6 +7,7 @@ import {
7
7
  ViewStyle,
8
8
  StyleProp,
9
9
  Dimensions,
10
+ Pressable,
10
11
  } from "react-native";
11
12
  import { omit, pickBy, identity, isObject } from "lodash";
12
13
  import { SafeAreaView } from "react-native-safe-area-context";
@@ -14,8 +15,7 @@ import { Picker as NativePicker } from "@react-native-picker/picker";
14
15
 
15
16
  import { withTheme } from "../../theming";
16
17
  import Portal from "../Portal/Portal";
17
- import Button from "../DeprecatedButton";
18
- import Touchable from "../Touchable";
18
+ import { Button } from "../Button";
19
19
  import type { Theme } from "../../styles/DefaultTheme";
20
20
  import type { IconSlot } from "../../interfaces/Icon";
21
21
  import {
@@ -306,7 +306,7 @@ const Picker: React.FC<PickerProps> = ({
306
306
  /* marginsContainer */
307
307
  <View style={[styles.marginsContainer, marginStyles]}>
308
308
  {/* touchableContainer */}
309
- <Touchable
309
+ <Pressable
310
310
  disabled={disabled}
311
311
  onPress={togglePickerVisible}
312
312
  style={styles.touchableContainer}
@@ -342,7 +342,7 @@ const Picker: React.FC<PickerProps> = ({
342
342
  </View>
343
343
  </View>
344
344
  {assistiveTextLabel}
345
- </Touchable>
345
+ </Pressable>
346
346
 
347
347
  {/* iosPicker */}
348
348
  {isIos && pickerVisible ? (
@@ -0,0 +1,69 @@
1
+ import * as React from "react";
2
+ import { View, StyleSheet } from "react-native";
3
+ import omit from "lodash.omit";
4
+ import { withTheme } from "../../theming";
5
+ import { Picker as NativePicker } from "@react-native-picker/picker";
6
+ import { extractStyles } from "../../utilities";
7
+ import TextField from "../TextField";
8
+ import Touchable from "../Touchable";
9
+ const Picker = ({ style, options, placeholder, selectedValue, disabled = false, onValueChange: onValueChangeOverride = () => { }, ...props }) => {
10
+ var _a, _b;
11
+ const { viewStyles: { borderRadius, // eslint-disable-line @typescript-eslint/no-unused-vars
12
+ borderWidth, // eslint-disable-line @typescript-eslint/no-unused-vars
13
+ borderTopWidth, // eslint-disable-line @typescript-eslint/no-unused-vars
14
+ borderRightWidth, // eslint-disable-line @typescript-eslint/no-unused-vars
15
+ borderBottomWidth, // eslint-disable-line @typescript-eslint/no-unused-vars
16
+ borderLeftWidth, // eslint-disable-line @typescript-eslint/no-unused-vars
17
+ borderColor, // eslint-disable-line @typescript-eslint/no-unused-vars
18
+ backgroundColor, // eslint-disable-line @typescript-eslint/no-unused-vars
19
+ padding, // eslint-disable-line @typescript-eslint/no-unused-vars
20
+ paddingTop, // eslint-disable-line @typescript-eslint/no-unused-vars
21
+ paddingRight, // eslint-disable-line @typescript-eslint/no-unused-vars
22
+ paddingBottom, // eslint-disable-line @typescript-eslint/no-unused-vars
23
+ paddingLeft, // eslint-disable-line @typescript-eslint/no-unused-vars
24
+ ...viewStyles }, } = extractStyles(style);
25
+ const textField = React.useRef(undefined);
26
+ const onValueChange = (itemValue, itemIndex) => {
27
+ toggleFocus();
28
+ onValueChangeOverride(itemValue, itemIndex);
29
+ };
30
+ const toggleFocus = () => {
31
+ if (!disabled) {
32
+ // @ts-ignore
33
+ textField.current.toggleFocus(); // cannot determine if method exists due to component being wrapped in a withTheme()
34
+ }
35
+ };
36
+ const stylesWithoutMargin = style &&
37
+ omit(StyleSheet.flatten(style), [
38
+ "margin",
39
+ "marginTop",
40
+ "marginRight",
41
+ "marginBottom",
42
+ "marginLeft",
43
+ ]);
44
+ const selectedLabel = selectedValue &&
45
+ ((_b = (_a = options.find((o) => o.value === selectedValue)) === null || _a === void 0 ? void 0 : _a.label) !== null && _b !== void 0 ? _b : selectedValue);
46
+ return (React.createElement(Touchable, { disabled: disabled, onPress: toggleFocus, style: [styles.container, viewStyles] },
47
+ React.createElement(View, null,
48
+ React.createElement(NativePicker, { enabled: !disabled, selectedValue: selectedValue, onValueChange: onValueChange, style: {
49
+ opacity: 0,
50
+ position: "absolute",
51
+ top: 0,
52
+ left: 0,
53
+ right: 0,
54
+ bottom: 0,
55
+ width: "100%",
56
+ } }, options.map((o) => (React.createElement(NativePicker.Item, { label: o.label, value: o.value, key: o.value })))),
57
+ React.createElement(View, { pointerEvents: "none" },
58
+ React.createElement(TextField, { ...props, value: selectedLabel, placeholder: placeholder,
59
+ // @ts-ignore
60
+ ref: textField, disabled: disabled,
61
+ // @ts-expect-error
62
+ style: stylesWithoutMargin })))));
63
+ };
64
+ const styles = StyleSheet.create({
65
+ container: {
66
+ alignSelf: "stretch",
67
+ },
68
+ });
69
+ export default withTheme(Picker);
@@ -0,0 +1,79 @@
1
+ import * as React from "react";
2
+ import { View, StyleSheet } from "react-native";
3
+ import { SafeAreaView } from "react-native-safe-area-context";
4
+ import omit from "lodash.omit";
5
+ import { Picker as NativePicker } from "@react-native-picker/picker";
6
+ import { withTheme } from "../../theming";
7
+ import Portal from "../Portal/Portal";
8
+ import { Button } from "../Button";
9
+ import TextField from "../TextField";
10
+ import Touchable from "../Touchable";
11
+ import { extractStyles } from "../../utilities";
12
+ const Picker = ({ Icon, style, options, placeholder, selectedValue, disabled = false, onValueChange = () => { }, theme: { colors }, ...props }) => {
13
+ var _a, _b;
14
+ const { viewStyles: { borderRadius, // eslint-disable-line @typescript-eslint/no-unused-vars
15
+ borderWidth, // eslint-disable-line @typescript-eslint/no-unused-vars
16
+ borderTopWidth, // eslint-disable-line @typescript-eslint/no-unused-vars
17
+ borderRightWidth, // eslint-disable-line @typescript-eslint/no-unused-vars
18
+ borderBottomWidth, // eslint-disable-line @typescript-eslint/no-unused-vars
19
+ borderLeftWidth, // eslint-disable-line @typescript-eslint/no-unused-vars
20
+ borderColor, // eslint-disable-line @typescript-eslint/no-unused-vars
21
+ backgroundColor, // eslint-disable-line @typescript-eslint/no-unused-vars
22
+ padding, // eslint-disable-line @typescript-eslint/no-unused-vars
23
+ paddingTop, // eslint-disable-line @typescript-eslint/no-unused-vars
24
+ paddingRight, // eslint-disable-line @typescript-eslint/no-unused-vars
25
+ paddingBottom, // eslint-disable-line @typescript-eslint/no-unused-vars
26
+ paddingLeft, // eslint-disable-line @typescript-eslint/no-unused-vars
27
+ ...viewStyles }, } = extractStyles(style);
28
+ const textField = React.useRef(undefined);
29
+ const [pickerVisible, setIsPickerVisible] = React.useState(false);
30
+ const toggleVisibility = () => {
31
+ setIsPickerVisible(!pickerVisible);
32
+ // @ts-ignore
33
+ textField.current.toggleFocus(); // cannot determine if method exists due to component being wrapped in a withTheme()
34
+ };
35
+ const stylesWithoutMargin = style &&
36
+ omit(StyleSheet.flatten(style), [
37
+ "margin",
38
+ "marginTop",
39
+ "marginRight",
40
+ "marginBottom",
41
+ "marginLeft",
42
+ ]);
43
+ const selectedLabel = selectedValue &&
44
+ ((_b = (_a = options.find((o) => o.value === selectedValue)) === null || _a === void 0 ? void 0 : _a.label) !== null && _b !== void 0 ? _b : selectedValue);
45
+ return (React.createElement(View, { style: [styles.container, viewStyles] },
46
+ React.createElement(Touchable, { disabled: disabled, onPress: toggleVisibility },
47
+ React.createElement(TextField, { ...props, value: String(selectedLabel), placeholder: placeholder,
48
+ // @ts-ignore
49
+ ref: textField, disabled: disabled, pointerEvents: "none",
50
+ // @ts-expect-error
51
+ style: stylesWithoutMargin, Icon: Icon })),
52
+ pickerVisible && (React.createElement(Portal, null,
53
+ React.createElement(View, { style: [styles.picker, { backgroundColor: colors.divider }] },
54
+ React.createElement(SafeAreaView, { style: styles.pickerContainer },
55
+ React.createElement(Button, { Icon: Icon, type: "text", onPress: toggleVisibility, style: styles.closeButton }, "Close"),
56
+ React.createElement(NativePicker, { style: { backgroundColor: "white" }, selectedValue: selectedValue, onValueChange: onValueChange }, options.map((o) => (React.createElement(NativePicker.Item, { label: o.label, value: o.value, key: o.value }))))))))));
57
+ };
58
+ const styles = StyleSheet.create({
59
+ container: {
60
+ alignSelf: "stretch",
61
+ },
62
+ picker: {
63
+ position: "absolute",
64
+ bottom: 0,
65
+ left: 0,
66
+ right: 0,
67
+ flexDirection: "row",
68
+ justifyContent: "center",
69
+ },
70
+ pickerContainer: {
71
+ backgroundColor: "white",
72
+ flexDirection: "column",
73
+ width: "100%",
74
+ },
75
+ closeButton: {
76
+ alignSelf: "flex-end",
77
+ },
78
+ });
79
+ export default withTheme(Picker);
@@ -8,7 +8,7 @@ import { Picker as NativePicker } from "@react-native-picker/picker";
8
8
  import { withTheme } from "../../theming";
9
9
 
10
10
  import Portal from "../Portal/Portal";
11
- import Button from "../DeprecatedButton";
11
+ import { Button } from "../Button";
12
12
  import TextField from "../TextField";
13
13
  import Touchable from "../Touchable";
14
14
  import { PickerComponentProps } from "./PickerTypes";
@@ -0,0 +1,70 @@
1
+ import * as React from "react";
2
+ import { View, StyleSheet } from "react-native";
3
+ import { Picker as NativePicker } from "@react-native-picker/picker";
4
+ import omit from "lodash.omit";
5
+ import { withTheme } from "../../theming";
6
+ import { extractStyles } from "../../utilities";
7
+ import TextField from "../TextField";
8
+ import Touchable from "../Touchable";
9
+ const Picker = ({ style, options, placeholder, selectedValue, disabled = false, onValueChange: onValueChangeOverride = () => { }, ...props }) => {
10
+ var _a, _b;
11
+ const { viewStyles: { borderRadius, // eslint-disable-line @typescript-eslint/no-unused-vars
12
+ borderWidth, // eslint-disable-line @typescript-eslint/no-unused-vars
13
+ borderTopWidth, // eslint-disable-line @typescript-eslint/no-unused-vars
14
+ borderRightWidth, // eslint-disable-line @typescript-eslint/no-unused-vars
15
+ borderBottomWidth, // eslint-disable-line @typescript-eslint/no-unused-vars
16
+ borderLeftWidth, // eslint-disable-line @typescript-eslint/no-unused-vars
17
+ borderColor, // eslint-disable-line @typescript-eslint/no-unused-vars
18
+ backgroundColor, // eslint-disable-line @typescript-eslint/no-unused-vars
19
+ padding, // eslint-disable-line @typescript-eslint/no-unused-vars
20
+ paddingTop, // eslint-disable-line @typescript-eslint/no-unused-vars
21
+ paddingRight, // eslint-disable-line @typescript-eslint/no-unused-vars
22
+ paddingBottom, // eslint-disable-line @typescript-eslint/no-unused-vars
23
+ paddingLeft, // eslint-disable-line @typescript-eslint/no-unused-vars
24
+ ...viewStyles }, } = extractStyles(style);
25
+ const textField = React.useRef(undefined);
26
+ const onValueChange = (itemValue, itemIndex) => {
27
+ toggleFocus();
28
+ onValueChangeOverride(itemValue, itemIndex);
29
+ };
30
+ const toggleFocus = () => {
31
+ if (!disabled) {
32
+ // @ts-ignore
33
+ textField.current.toggleFocus(); // cannot determine if method exists due to component being wrapped in a withTheme()
34
+ }
35
+ };
36
+ const stylesWithoutMargin = style &&
37
+ omit(StyleSheet.flatten(style), [
38
+ "margin",
39
+ "marginTop",
40
+ "marginRight",
41
+ "marginBottom",
42
+ "marginLeft",
43
+ ]);
44
+ const selectedLabel = selectedValue &&
45
+ ((_b = (_a = options.find((o) => o.value === selectedValue)) === null || _a === void 0 ? void 0 : _a.label) !== null && _b !== void 0 ? _b : selectedValue);
46
+ return (React.createElement(Touchable, { disabled: disabled, onPress: toggleFocus, style: [styles.container, viewStyles] },
47
+ React.createElement(View, null,
48
+ React.createElement(NativePicker, { enabled: !disabled, selectedValue: selectedValue, onValueChange: onValueChange, style: {
49
+ flex: 1,
50
+ opacity: 0,
51
+ position: "absolute",
52
+ top: 0,
53
+ left: 0,
54
+ right: 0,
55
+ bottom: 0,
56
+ width: "100%",
57
+ } }, options.map((o) => (React.createElement(NativePicker.Item, { label: o.label, value: o.value, key: o.value })))),
58
+ React.createElement(View, { pointerEvents: "none" },
59
+ React.createElement(TextField, { ...props, value: selectedLabel, placeholder: placeholder,
60
+ // @ts-ignore
61
+ ref: textField, disabled: disabled,
62
+ // @ts-expect-error
63
+ style: stylesWithoutMargin })))));
64
+ };
65
+ const styles = StyleSheet.create({
66
+ container: {
67
+ alignSelf: "stretch",
68
+ },
69
+ });
70
+ export default withTheme(Picker);
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,35 @@
1
+ import * as React from "react";
2
+ import PortalConsumer from "./PortalConsumer";
3
+ import PortalHost, { PortalContext } from "./PortalHost";
4
+ import { ThemeProvider, withTheme } from "../../theming";
5
+ /**
6
+ * Portal allows to render a component at a different place in the parent tree.
7
+ * You can use it to render content which should appear above other elements, similar to `Modal`.
8
+ * It requires a [`Portal.Host`](portal-host.html) component to be rendered somewhere in the parent tree.
9
+ *
10
+ * ## Usage
11
+ * ```js
12
+ * import * as React from 'react';
13
+ * import { Portal, Text } from 'react-native-paper';
14
+ *
15
+ * export default class MyComponent extends React.Component {
16
+ * render() {
17
+ * return (
18
+ * <Portal>
19
+ * <Text>This is rendered at a different place</Text>
20
+ * </Portal>
21
+ * );
22
+ * }
23
+ * }
24
+ * ```
25
+ */
26
+ class Portal extends React.Component {
27
+ render() {
28
+ const { children, theme } = this.props;
29
+ return (React.createElement(PortalContext.Consumer, null, (manager) => (React.createElement(PortalConsumer, { manager: manager },
30
+ React.createElement(ThemeProvider, { theme: theme }, children)))));
31
+ }
32
+ }
33
+ // @component ./PortalHost.tsx
34
+ Portal.Host = PortalHost;
35
+ export default withTheme(Portal);
@@ -0,0 +1,27 @@
1
+ import * as React from "react";
2
+ export default class PortalConsumer extends React.Component {
3
+ async componentDidMount() {
4
+ this.checkManager();
5
+ // Delay updating to prevent React from going to infinite loop
6
+ await Promise.resolve();
7
+ this.key = this.props.manager.mount(this.props.children);
8
+ }
9
+ componentDidUpdate() {
10
+ this.checkManager();
11
+ this.props.manager.update(this.key, this.props.children);
12
+ }
13
+ componentWillUnmount() {
14
+ this.checkManager();
15
+ this.props.manager.unmount(this.key);
16
+ }
17
+ checkManager() {
18
+ if (!this.props.manager) {
19
+ throw new Error("Looks like you forgot to wrap your root component with `Provider` component from `react-native-paper`.\n\n" +
20
+ "Please read our getting-started guide and make sure you've followed all the required steps.\n\n" +
21
+ "https://callstack.github.io/react-native-paper/getting-started.html");
22
+ }
23
+ }
24
+ render() {
25
+ return null;
26
+ }
27
+ }
@@ -0,0 +1,107 @@
1
+ import * as React from "react";
2
+ import { View, StyleSheet } from "react-native";
3
+ import PortalManager from "./PortalManager";
4
+ export const PortalContext = React.createContext(null);
5
+ /**
6
+ * Portal host renders all of its children `Portal` elements.
7
+ * For example, you can wrap a screen in `Portal.Host` to render items above the screen.
8
+ * If you're using the `Provider` component, it already includes `Portal.Host`.
9
+ *
10
+ * ## Usage
11
+ * ```js
12
+ * import * as React from 'react';
13
+ * import { Text } from 'react-native';
14
+ * import { Portal } from 'react-native-paper';
15
+ *
16
+ * export default class MyComponent extends React.Component {
17
+ * render() {
18
+ * return (
19
+ * <Portal.Host>
20
+ * <Text>Content of the app</Text>
21
+ * </Portal.Host>
22
+ * );
23
+ * }
24
+ * }
25
+ * ```
26
+ *
27
+ * Here any `Portal` elements under `<App />` are rendered alongside `<App />` and will appear above `<App />` like a `Modal`.
28
+ */
29
+ export default class PortalHost extends React.Component {
30
+ constructor() {
31
+ super(...arguments);
32
+ this.setManager = (manager) => {
33
+ this.manager = manager;
34
+ };
35
+ this.mount = (children) => {
36
+ const key = this.nextKey++;
37
+ if (this.manager) {
38
+ this.manager.mount(key, children);
39
+ }
40
+ else {
41
+ this.queue.push({ type: "mount", key, children });
42
+ }
43
+ return key;
44
+ };
45
+ this.update = (key, children) => {
46
+ if (this.manager) {
47
+ this.manager.update(key, children);
48
+ }
49
+ else {
50
+ const op = { type: "mount", key, children };
51
+ const index = this.queue.findIndex((o) => o.type === "mount" || (o.type === "update" && o.key === key));
52
+ if (index > -1) {
53
+ // @ts-ignore
54
+ this.queue[index] = op;
55
+ }
56
+ else {
57
+ this.queue.push(op);
58
+ }
59
+ }
60
+ };
61
+ this.unmount = (key) => {
62
+ if (this.manager) {
63
+ this.manager.unmount(key);
64
+ }
65
+ else {
66
+ this.queue.push({ type: "unmount", key });
67
+ }
68
+ };
69
+ this.nextKey = 0;
70
+ this.queue = [];
71
+ }
72
+ componentDidMount() {
73
+ const manager = this.manager;
74
+ const queue = this.queue;
75
+ while (queue.length && manager) {
76
+ const action = queue.pop();
77
+ if (action) {
78
+ switch (action.type) {
79
+ case "mount":
80
+ manager.mount(action.key, action.children);
81
+ break;
82
+ case "update":
83
+ manager.update(action.key, action.children);
84
+ break;
85
+ case "unmount":
86
+ manager.unmount(action.key);
87
+ break;
88
+ }
89
+ }
90
+ }
91
+ }
92
+ render() {
93
+ return (React.createElement(PortalContext.Provider, { value: {
94
+ mount: this.mount,
95
+ update: this.update,
96
+ unmount: this.unmount,
97
+ } },
98
+ React.createElement(View, { style: styles.container, collapsable: false, pointerEvents: "box-none" }, this.props.children),
99
+ React.createElement(PortalManager, { ref: this.setManager })));
100
+ }
101
+ }
102
+ PortalHost.displayName = "Portal.Host";
103
+ const styles = StyleSheet.create({
104
+ container: {
105
+ flex: 1,
106
+ },
107
+ });
@@ -0,0 +1,32 @@
1
+ import * as React from "react";
2
+ import { View, StyleSheet } from "react-native";
3
+ /**
4
+ * Portal host is the component which actually renders all Portals.
5
+ */
6
+ export default class PortalManager extends React.PureComponent {
7
+ constructor() {
8
+ super(...arguments);
9
+ this.state = {
10
+ portals: [],
11
+ };
12
+ this.mount = (key, children) => {
13
+ this.setState((state) => ({
14
+ portals: [...state.portals, { key, children }],
15
+ }));
16
+ };
17
+ this.update = (key, children) => this.setState((state) => ({
18
+ portals: state.portals.map((item) => {
19
+ if (item.key === key) {
20
+ return { ...item, children };
21
+ }
22
+ return item;
23
+ }),
24
+ }));
25
+ this.unmount = (key) => this.setState((state) => ({
26
+ portals: state.portals.filter((item) => item.key !== key),
27
+ }));
28
+ }
29
+ render() {
30
+ return this.state.portals.map(({ key, children }) => (React.createElement(View, { key: key, collapsable: false /* Need collapsable=false here to clip the elevations, otherwise they appear above sibling components */, pointerEvents: "box-none", style: StyleSheet.absoluteFill }, children)));
31
+ }
32
+ }
@@ -0,0 +1,17 @@
1
+ import React, { useCallback } from "react";
2
+ import { Pressable as NativePressable, } from "react-native";
3
+ export default function Pressable({ children, disabled, onPress, onLongPress, hitSlop, delayLongPress, activeOpacity, disabledOpacity, style, ...props }) {
4
+ const getOpacity = useCallback((pressed) => {
5
+ if (disabled) {
6
+ return disabledOpacity;
7
+ }
8
+ else {
9
+ if (pressed)
10
+ return activeOpacity;
11
+ else
12
+ return 1;
13
+ }
14
+ }, [activeOpacity, disabled, disabledOpacity]);
15
+ const _style = useCallback(({ pressed }) => [style, { opacity: getOpacity(pressed) }], [getOpacity, style]);
16
+ return (React.createElement(NativePressable, { onPress: onPress, onLongPress: onLongPress, disabled: disabled, delayLongPress: delayLongPress ? delayLongPress : 500, hitSlop: hitSlop ? hitSlop : 8, style: _style, ...props }, children));
17
+ }
@@ -0,0 +1,67 @@
1
+ import React, { useCallback } from "react";
2
+ import {
3
+ Pressable as NativePressable,
4
+ PressableProps,
5
+ PressableStateCallbackType,
6
+ StyleProp,
7
+ ViewStyle,
8
+ } from "react-native";
9
+
10
+ type Props = {
11
+ disabled?: boolean;
12
+ children: React.ReactNode;
13
+ style?: ViewStyle;
14
+ onPress?: () => void;
15
+ onLongPress?: () => void;
16
+ delayLongPress?: number;
17
+ hitSlop?: number;
18
+ pressRetentionOffset?: number;
19
+ activeOpacity?: number;
20
+ disabledOpacity?: number;
21
+ } & PressableProps;
22
+
23
+ export type StyleType = (
24
+ state: PressableStateCallbackType
25
+ ) => StyleProp<ViewStyle>;
26
+
27
+ export default function Pressable({
28
+ children,
29
+ disabled,
30
+ onPress,
31
+ onLongPress,
32
+ hitSlop,
33
+ delayLongPress,
34
+ activeOpacity,
35
+ disabledOpacity,
36
+ style,
37
+ ...props
38
+ }: Props) {
39
+ const getOpacity = useCallback(
40
+ (pressed: boolean) => {
41
+ if (disabled) {
42
+ return disabledOpacity;
43
+ } else {
44
+ if (pressed) return activeOpacity;
45
+ else return 1;
46
+ }
47
+ },
48
+ [activeOpacity, disabled, disabledOpacity]
49
+ );
50
+ const _style = useCallback<StyleType>(
51
+ ({ pressed }) => [style as ViewStyle, { opacity: getOpacity(pressed) }],
52
+ [getOpacity, style]
53
+ );
54
+ return (
55
+ <NativePressable
56
+ onPress={onPress}
57
+ onLongPress={onLongPress}
58
+ disabled={disabled}
59
+ delayLongPress={delayLongPress ? delayLongPress : 500}
60
+ hitSlop={hitSlop ? hitSlop : 8}
61
+ style={_style}
62
+ {...props}
63
+ >
64
+ {children}
65
+ </NativePressable>
66
+ );
67
+ }
@@ -0,0 +1,118 @@
1
+ import React, { Component } from "react";
2
+ import { Animated, Easing, View, I18nManager, } from "react-native";
3
+ const INDETERMINATE_WIDTH_FACTOR = 0.3;
4
+ const BAR_WIDTH_ZERO_POSITION = INDETERMINATE_WIDTH_FACTOR / (1 + INDETERMINATE_WIDTH_FACTOR);
5
+ export default class ProgressBar extends Component {
6
+ constructor(props) {
7
+ super(props);
8
+ this.handleLayout = (event) => {
9
+ const { width = 150, onLayout } = this.props;
10
+ if (!width) {
11
+ this.setState({ width: event.nativeEvent.layout.width });
12
+ }
13
+ if (onLayout) {
14
+ onLayout(event);
15
+ }
16
+ };
17
+ const { progress: progressP = 0, indeterminate = false } = props;
18
+ const progress = Math.min(Math.max(progressP, 0), 1);
19
+ this.state = {
20
+ width: 0,
21
+ progress: new Animated.Value(indeterminate ? INDETERMINATE_WIDTH_FACTOR : progress),
22
+ animationValue: new Animated.Value(BAR_WIDTH_ZERO_POSITION),
23
+ };
24
+ }
25
+ componentDidMount() {
26
+ const { indeterminate = false } = this.props;
27
+ if (indeterminate) {
28
+ this.animate();
29
+ }
30
+ }
31
+ componentDidUpdate(prevProps) {
32
+ const { indeterminate = false, useNativeDriver = false, progress: progressP = 0, animationType = "spring", animationConfig = { bounciness: 0 }, animated = true, } = this.props;
33
+ if (prevProps.indeterminate !== indeterminate) {
34
+ if (indeterminate) {
35
+ this.animate();
36
+ }
37
+ else {
38
+ Animated.spring(this.state.animationValue, {
39
+ toValue: BAR_WIDTH_ZERO_POSITION,
40
+ useNativeDriver,
41
+ }).start();
42
+ }
43
+ }
44
+ if (prevProps.indeterminate !== indeterminate ||
45
+ prevProps.progress !== progressP) {
46
+ const progress = this.props.indeterminate
47
+ ? INDETERMINATE_WIDTH_FACTOR
48
+ : Math.min(Math.max(progressP, 0), 1);
49
+ if (animated) {
50
+ Animated[animationType](this.state.progress, {
51
+ ...animationConfig,
52
+ toValue: progress,
53
+ velocity: 0,
54
+ useNativeDriver,
55
+ }).start();
56
+ }
57
+ else {
58
+ this.state.progress.setValue(progress);
59
+ }
60
+ }
61
+ }
62
+ animate() {
63
+ const { useNativeDriver = false, indeterminateAnimationDuration = 1000 } = this.props;
64
+ this.state.animationValue.setValue(0);
65
+ Animated.timing(this.state.animationValue, {
66
+ toValue: 1,
67
+ duration: indeterminateAnimationDuration,
68
+ easing: Easing.linear,
69
+ isInteraction: false,
70
+ useNativeDriver,
71
+ }).start((endState) => {
72
+ if (endState.finished) {
73
+ this.animate();
74
+ }
75
+ });
76
+ }
77
+ render() {
78
+ const { borderColor, borderRadius = 4, borderWidth = 1, children, color = "rgba(0, 122, 255, 1)", style, unfilledColor, width = 150, ...restProps } = this.props;
79
+ const innerWidth = Math.max(0, width || this.state.width) - borderWidth * 2;
80
+ const containerStyle = {
81
+ width,
82
+ borderWidth,
83
+ borderColor: borderColor || color,
84
+ borderRadius,
85
+ overflow: "hidden",
86
+ backgroundColor: unfilledColor,
87
+ };
88
+ const progressStyle = {
89
+ backgroundColor: color,
90
+ // Always take up full height of container.
91
+ height: "100%",
92
+ transform: [
93
+ {
94
+ translateX: this.state.animationValue.interpolate({
95
+ inputRange: [0, 1],
96
+ outputRange: [innerWidth * -INDETERMINATE_WIDTH_FACTOR, innerWidth],
97
+ }),
98
+ },
99
+ {
100
+ translateX: this.state.progress.interpolate({
101
+ inputRange: [0, 1],
102
+ outputRange: [innerWidth / (I18nManager.isRTL ? 2 : -2), 0],
103
+ }),
104
+ },
105
+ {
106
+ // Interpolation a temp workaround for https://github.com/facebook/react-native/issues/6278
107
+ scaleX: this.state.progress.interpolate({
108
+ inputRange: [0, 1],
109
+ outputRange: [0.0001, 1],
110
+ }),
111
+ },
112
+ ],
113
+ };
114
+ return (React.createElement(View, { style: [containerStyle, style], onLayout: this.handleLayout, ...restProps },
115
+ React.createElement(Animated.View, { style: progressStyle }),
116
+ children));
117
+ }
118
+ }