@draftbit/core 47.0.0-3bcd8b.2 → 47.0.0-alpha.1

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 (137) hide show
  1. package/lib/commonjs/components/Picker/Picker.js +2 -2
  2. package/lib/commonjs/components/Picker/Picker.js.map +1 -1
  3. package/lib/commonjs/components/Stepper.js +0 -1
  4. package/lib/commonjs/index.js +7 -0
  5. package/lib/commonjs/index.js.map +1 -1
  6. package/lib/commonjs/mappings/View.js.map +1 -1
  7. package/lib/commonjs/mappings/WebView.js.map +1 -1
  8. package/lib/module/components/Picker/Picker.js +1 -1
  9. package/lib/module/components/Picker/Picker.js.map +1 -1
  10. package/lib/module/components/Stepper.js +0 -1
  11. package/lib/module/index.js +1 -0
  12. package/lib/module/index.js.map +1 -1
  13. package/lib/typescript/src/components/Picker/Picker.d.ts.map +1 -1
  14. package/lib/typescript/src/index.d.ts +1 -0
  15. package/lib/typescript/src/index.d.ts.map +1 -1
  16. package/package.json +3 -3
  17. package/src/components/Picker/Picker.tsx +2 -2
  18. package/src/index.tsx +1 -0
  19. package/src/Provider.js +0 -9
  20. package/src/components/Accordion/AccordionGroup.js +0 -44
  21. package/src/components/Accordion/AccordionItem.js +0 -32
  22. package/src/components/Accordion/index.js +0 -2
  23. package/src/components/ActionSheet/ActionSheet.js +0 -45
  24. package/src/components/ActionSheet/ActionSheetCancel.js +0 -6
  25. package/src/components/ActionSheet/ActionSheetItem.js +0 -30
  26. package/src/components/ActionSheet/index.js +0 -3
  27. package/src/components/Banner.js +0 -109
  28. package/src/components/Button.js +0 -114
  29. package/src/components/Checkbox/Checkbox.js +0 -63
  30. package/src/components/Checkbox/CheckboxGroup.js +0 -21
  31. package/src/components/Checkbox/CheckboxGroupRow.js +0 -77
  32. package/src/components/Checkbox/CheckboxRow.js +0 -78
  33. package/src/components/Checkbox/context.js +0 -14
  34. package/src/components/Checkbox/index.js +0 -3
  35. package/src/components/Config.js +0 -64
  36. package/src/components/DatePicker/DatePicker.js +0 -368
  37. package/src/components/DatePicker/DatePickerComponent.js +0 -13
  38. package/src/components/DatePicker/DatePickerComponent.web.js +0 -30
  39. package/src/components/DatePicker/DatePickerComponentType.js +0 -1
  40. package/src/components/DeprecatedButton.js +0 -95
  41. package/src/components/Elevation.js +0 -20
  42. package/src/components/FormRow.js +0 -19
  43. package/src/components/IconButton.js +0 -35
  44. package/src/components/Layout.js +0 -50
  45. package/src/components/NumberInput.js +0 -49
  46. package/src/components/Picker/Picker.js +0 -267
  47. package/src/components/Picker/PickerComponent.android.js +0 -69
  48. package/src/components/Picker/PickerComponent.ios.js +0 -79
  49. package/src/components/Picker/PickerComponent.web.js +0 -70
  50. package/src/components/Picker/PickerTypes.js +0 -1
  51. package/src/components/Portal/Portal.js +0 -35
  52. package/src/components/Portal/PortalConsumer.js +0 -27
  53. package/src/components/Portal/PortalHost.js +0 -107
  54. package/src/components/Portal/PortalManager.js +0 -32
  55. package/src/components/RadioButton/RadioButton.js +0 -17
  56. package/src/components/RadioButton/RadioButtonFieldGroup.js +0 -17
  57. package/src/components/RadioButton/RadioButtonGroup.js +0 -43
  58. package/src/components/RadioButton/RadioButtonRow.js +0 -76
  59. package/src/components/RadioButton/context.js +0 -14
  60. package/src/components/RadioButton/index.js +0 -4
  61. package/src/components/SVG.js +0 -13
  62. package/src/components/ScreenContainer.js +0 -34
  63. package/src/components/Slider.js +0 -63
  64. package/src/components/StarRating.js +0 -50
  65. package/src/components/Stepper.js +0 -39
  66. package/src/components/Surface.js +0 -32
  67. package/src/components/Swiper/Swiper.js +0 -29
  68. package/src/components/Swiper/SwiperItem.js +0 -9
  69. package/src/components/Swiper/index.js +0 -2
  70. package/src/components/Switch.js +0 -56
  71. package/src/components/Text.js +0 -33
  72. package/src/components/TextField.js +0 -428
  73. package/src/components/Touchable.js +0 -12
  74. package/src/components/Touchable.web.js +0 -2
  75. package/src/constants.js +0 -10
  76. package/src/hooks.js +0 -12
  77. package/src/index.js +0 -34
  78. package/src/interfaces/Icon.js +0 -8
  79. package/src/mappings/Accordion.js +0 -41
  80. package/src/mappings/AccordionItem.js +0 -16
  81. package/src/mappings/ActionSheet.js +0 -13
  82. package/src/mappings/ActionSheetCancel.js +0 -19
  83. package/src/mappings/ActionSheetItem.js +0 -23
  84. package/src/mappings/ActivityIndicator.js +0 -58
  85. package/src/mappings/AudioPlayer.js +0 -20
  86. package/src/mappings/BlurView.js +0 -42
  87. package/src/mappings/Button.js +0 -87
  88. package/src/mappings/Checkbox.js +0 -46
  89. package/src/mappings/CheckboxGroup.js +0 -26
  90. package/src/mappings/CheckboxRow.js +0 -61
  91. package/src/mappings/CustomCode.js +0 -8
  92. package/src/mappings/DatePicker.js +0 -157
  93. package/src/mappings/Fetch.js +0 -13
  94. package/src/mappings/FlashList.js +0 -33
  95. package/src/mappings/FlatList.js +0 -24
  96. package/src/mappings/Icon.js +0 -32
  97. package/src/mappings/IconButton.js +0 -35
  98. package/src/mappings/Image.js +0 -35
  99. package/src/mappings/ImageBackground.js +0 -29
  100. package/src/mappings/KeyboardAvoidingView.js +0 -41
  101. package/src/mappings/KeyboardAwareScrollView.js +0 -50
  102. package/src/mappings/Layout.js +0 -200
  103. package/src/mappings/LinearGradient.js +0 -77
  104. package/src/mappings/MapCallout.js +0 -21
  105. package/src/mappings/MapMarker.js +0 -47
  106. package/src/mappings/MapView.js +0 -139
  107. package/src/mappings/Modal.js +0 -42
  108. package/src/mappings/NumberInput.js +0 -254
  109. package/src/mappings/Picker.js +0 -148
  110. package/src/mappings/RadioButton.js +0 -51
  111. package/src/mappings/RadioButtonGroup.js +0 -17
  112. package/src/mappings/RadioButtonRow.js +0 -42
  113. package/src/mappings/SVG.js +0 -20
  114. package/src/mappings/SafeAreaView.js +0 -33
  115. package/src/mappings/ScrollView.js +0 -31
  116. package/src/mappings/Slider.js +0 -60
  117. package/src/mappings/StarRating.js +0 -43
  118. package/src/mappings/Stepper.js +0 -29
  119. package/src/mappings/Surface.js +0 -14
  120. package/src/mappings/Swiper.js +0 -60
  121. package/src/mappings/SwiperItem.js +0 -8
  122. package/src/mappings/Switch.js +0 -81
  123. package/src/mappings/Text.js +0 -251
  124. package/src/mappings/TextArea.js +0 -263
  125. package/src/mappings/TextField.js +0 -381
  126. package/src/mappings/TextInput.js +0 -391
  127. package/src/mappings/Touchable.js +0 -17
  128. package/src/mappings/Video.js +0 -81
  129. package/src/mappings/View.js +0 -207
  130. package/src/mappings/WebView.js +0 -88
  131. package/src/styles/DarkTheme.js +0 -26
  132. package/src/styles/DefaultTheme.js +0 -111
  133. package/src/styles/fonts.js +0 -62
  134. package/src/styles/overlay.js +0 -60
  135. package/src/styles/shadow.js +0 -51
  136. package/src/theming.js +0 -3
  137. package/src/utilities.js +0 -102
@@ -1,109 +0,0 @@
1
- import * as React from "react";
2
- import { Button, Text, View, StyleSheet, Animated, } from "react-native";
3
- import Surface from "./Surface";
4
- import shadow from "../styles/shadow";
5
- import { withTheme } from "../theming";
6
- const ELEVATION = 1;
7
- const DEFAULT_MAX_WIDTH = 960;
8
- const Banner = ({ initiallyVisible = true, dismissable = true, icon, buttonColor, content, contentStyle, style, theme, Icon, ...rest }) => {
9
- const [visible, setVisible] = React.useState(initiallyVisible);
10
- React.useEffect(() => {
11
- if (initiallyVisible) {
12
- setVisible(true);
13
- }
14
- }, [initiallyVisible]);
15
- const { current: position } = React.useRef(new Animated.Value(visible ? 1 : 0));
16
- const [layout, setLayout] = React.useState({
17
- height: 0,
18
- measured: false,
19
- });
20
- React.useEffect(() => {
21
- if (visible) {
22
- // show
23
- Animated.timing(position, {
24
- duration: 250,
25
- toValue: 1,
26
- useNativeDriver: false,
27
- }).start();
28
- }
29
- else {
30
- // hide
31
- Animated.timing(position, {
32
- duration: 200,
33
- toValue: 0,
34
- useNativeDriver: false,
35
- }).start();
36
- }
37
- }, [visible, position]);
38
- const handleLayout = ({ nativeEvent }) => {
39
- const { height } = nativeEvent.layout;
40
- setLayout({ height, measured: true });
41
- };
42
- // The banner animation has 2 parts:
43
- // 1. Blank spacer element which animates its height to move the content
44
- // 2. Actual banner which animates its translateY
45
- // In initial render, we position everything normally and measure the height of the banner
46
- // Once we have the height, we apply the height to the spacer and switch the banner to position: absolute
47
- // We need this because we need to move the content below as if banner's height was being animated
48
- // However we can't animated banner's height directly as it'll also resize the content inside
49
- const height = Animated.multiply(position, layout.height);
50
- const translateY = Animated.multiply(Animated.add(position, -1), layout.height);
51
- return (React.createElement(Surface, { ...rest, style: [styles.container, shadow(ELEVATION), style] },
52
- React.createElement(View, { style: [styles.wrapper, contentStyle] },
53
- React.createElement(Animated.View, { style: { height } }),
54
- React.createElement(Animated.View, { onLayout: handleLayout, style: [
55
- layout.measured || !visible
56
- ? // If we have measured banner's height or it's invisible,
57
- // Position it absolutely, the layout will be taken care of the spacer
58
- [styles.absolute, { transform: [{ translateY }] }]
59
- : // Otherwise position it normally
60
- null,
61
- !layout.measured && !visible
62
- ? // If we haven't measured banner's height yet and it's invisible,
63
- // hide it with opacity: 0 so user doesn't see it
64
- { opacity: 0 }
65
- : null,
66
- ] },
67
- React.createElement(View, { style: [styles.content, { marginBottom: dismissable ? 0 : 16 }] },
68
- icon ? (React.createElement(View, { style: styles.icon },
69
- React.createElement(Icon, { name: icon, size: 40 }))) : null,
70
- React.createElement(Text, { style: [styles.message, { color: theme.colors.text }], accessibilityLiveRegion: visible ? "polite" : "none", accessibilityRole: "alert" }, content)),
71
- dismissable ? (React.createElement(View, { style: styles.actions },
72
- React.createElement(Button, { color: buttonColor || theme.colors.primary, title: "Close", onPress: () => setVisible(false) }))) : null))));
73
- };
74
- const styles = StyleSheet.create({
75
- container: {
76
- elevation: ELEVATION,
77
- },
78
- wrapper: {
79
- overflow: "hidden",
80
- alignSelf: "center",
81
- width: "100%",
82
- maxWidth: DEFAULT_MAX_WIDTH,
83
- },
84
- absolute: {
85
- position: "absolute",
86
- top: 0,
87
- width: "100%",
88
- },
89
- content: {
90
- flexDirection: "row",
91
- justifyContent: "flex-start",
92
- marginHorizontal: 8,
93
- marginTop: 16,
94
- marginBottom: 0,
95
- },
96
- icon: {
97
- margin: 8,
98
- },
99
- message: {
100
- flex: 1,
101
- margin: 8,
102
- },
103
- actions: {
104
- flexDirection: "row",
105
- justifyContent: "flex-end",
106
- margin: 8,
107
- },
108
- });
109
- export default withTheme(Banner);
@@ -1,114 +0,0 @@
1
- import * as React from "react";
2
- import { Text, Pressable, Platform, StyleSheet, ActivityIndicator, } from "react-native";
3
- import { withTheme } from "../theming";
4
- const CONSTANTS = {
5
- baseHeight: 42,
6
- borderRadius: 4,
7
- padding: 8,
8
- icon: 24,
9
- };
10
- function Base({ Icon, icon, title, onPress, loading, disabled, style, ...props }) {
11
- const { color, fontFamily, fontWeight, fontSize, lineHeight, letterSpacing, textTransform, textAlign, textDecorationLine, textDecorationColor, textDecorationStyle, ...buttonStyles } = StyleSheet.flatten(style || {});
12
- const titleStyles = {
13
- color,
14
- fontFamily,
15
- fontWeight,
16
- fontSize,
17
- lineHeight,
18
- letterSpacing,
19
- textTransform,
20
- textAlign,
21
- textDecorationLine,
22
- textDecorationColor,
23
- textDecorationStyle,
24
- };
25
- if (textAlign === "left") {
26
- buttonStyles.justifyContent = "flex-start";
27
- }
28
- if (textAlign === "right") {
29
- buttonStyles.justifyContent = "flex-end";
30
- }
31
- return (React.createElement(Pressable, { onPress: onPress, disabled: disabled || loading, style: ({ pressed }) => {
32
- return [
33
- styles.base,
34
- {
35
- opacity: pressed || disabled ? 0.75 : 1,
36
- },
37
- buttonStyles,
38
- ];
39
- }, ...props },
40
- loading ? (React.createElement(ActivityIndicator, { size: "small", color: color, style: styles.loading })) : null,
41
- icon && !loading ? (React.createElement(Icon, { name: icon, color: color, style: styles.icon, size: CONSTANTS.icon })) : null,
42
- React.createElement(Text, { style: titleStyles }, title)));
43
- }
44
- const Solid = ({ style, theme, ...props }) => {
45
- return (React.createElement(Base, { style: [
46
- {
47
- color: "#FFF",
48
- borderRadius: theme.roundness,
49
- backgroundColor: theme.colors.primary,
50
- },
51
- style,
52
- ], ...props }));
53
- };
54
- const ButtonSolid = withTheme(Solid);
55
- export { ButtonSolid };
56
- const Button = withTheme(Solid);
57
- export { Button };
58
- const Outline = ({ style, theme, ...props }) => {
59
- return (React.createElement(Base, { style: [
60
- styles.outline,
61
- {
62
- borderRadius: theme.roundness,
63
- borderColor: theme.colors.primary,
64
- color: theme.colors.primary,
65
- },
66
- style,
67
- ], ...props }));
68
- };
69
- const ButtonOutline = withTheme(Outline);
70
- export { ButtonOutline };
71
- const styles = StyleSheet.create({
72
- base: {
73
- position: "relative",
74
- flexDirection: "row",
75
- alignItems: "center",
76
- justifyContent: "center",
77
- minHeight: CONSTANTS.baseHeight,
78
- paddingHorizontal: 12,
79
- fontFamily: "System",
80
- fontWeight: "700",
81
- ...Platform.select({
82
- web: {
83
- cursor: "pointer",
84
- userSelect: "none",
85
- },
86
- }),
87
- },
88
- outline: {
89
- backgroundColor: "transparent",
90
- borderWidth: 1,
91
- },
92
- bare: {
93
- backgroundColor: "transparent",
94
- padding: 0,
95
- minHeight: undefined,
96
- },
97
- loading: {
98
- marginRight: 6,
99
- },
100
- icon: {
101
- ...Platform.select({
102
- web: {
103
- marginTop: 1,
104
- marginRight: 4,
105
- alignSelf: "center",
106
- },
107
- default: {
108
- marginBottom: 2,
109
- marginRight: 4,
110
- alignSelf: "center",
111
- },
112
- }),
113
- },
114
- });
@@ -1,63 +0,0 @@
1
- import * as React from "react";
2
- import { View, StyleSheet, } from "react-native";
3
- import { useTheme } from "../../theming";
4
- import Touchable from "../Touchable";
5
- import { usePrevious } from "../../hooks";
6
- const Checkbox = ({ Icon, status, disabled = false, onPress, onCheck, onUncheck, color, uncheckedColor, defaultValue, checkedIcon = "MaterialCommunityIcons/checkbox-marked", uncheckedIcon = "MaterialCommunityIcons/checkbox-blank-outline", size = 24, style, ...rest }) => {
7
- const [internalValue, setInternalValue] = React.useState(status || defaultValue || false);
8
- React.useEffect(() => {
9
- if (status != null) {
10
- setInternalValue(status);
11
- }
12
- }, [status]);
13
- // This special logic is to handle weird APIs like Airtable that return
14
- // true or undefined for a boolean
15
- const previousDefaultValue = usePrevious(defaultValue);
16
- React.useEffect(() => {
17
- if (defaultValue !== previousDefaultValue) {
18
- setInternalValue(Boolean(defaultValue));
19
- }
20
- }, [defaultValue, previousDefaultValue]);
21
- const { colors } = useTheme();
22
- const checkboxColor = internalValue
23
- ? color || colors.primary
24
- : uncheckedColor || colors.primary;
25
- const handlePress = () => {
26
- const newValue = !internalValue;
27
- setInternalValue(newValue);
28
- onPress === null || onPress === void 0 ? void 0 : onPress(newValue);
29
- if (newValue) {
30
- onCheck === null || onCheck === void 0 ? void 0 : onCheck();
31
- }
32
- if (!newValue) {
33
- onUncheck === null || onUncheck === void 0 ? void 0 : onUncheck();
34
- }
35
- };
36
- return (React.createElement(Touchable, { ...rest, onPress: handlePress, disabled: disabled, accessibilityState: { disabled }, accessibilityRole: "button", accessibilityLiveRegion: "polite", style: [styles.container, style, { width: size, height: size }] },
37
- React.createElement(Icon, { style: styles.icon, name: internalValue ? checkedIcon : uncheckedIcon, size: size, color: checkboxColor }),
38
- React.createElement(View, { style: [StyleSheet.absoluteFill, styles.fillContainer] },
39
- React.createElement(View, { style: [
40
- styles.fill,
41
- { opacity: disabled ? 0.5 : 1 },
42
- { borderColor: checkboxColor },
43
- ] }))));
44
- };
45
- const styles = StyleSheet.create({
46
- container: {
47
- borderRadius: 18,
48
- },
49
- fillContainer: {
50
- alignItems: "center",
51
- justifyContent: "center",
52
- },
53
- icon: {
54
- alignSelf: "center",
55
- },
56
- fill: {
57
- borderRadius: 5,
58
- width: 30,
59
- height: 30,
60
- alignSelf: "center",
61
- },
62
- });
63
- export default Checkbox;
@@ -1,21 +0,0 @@
1
- import * as React from "react";
2
- import { View } from "react-native";
3
- import { checkboxGroupContext, Direction } from "./context";
4
- const { Provider } = checkboxGroupContext;
5
- const CheckboxGroup = ({ direction = Direction.Vertical, values, onValueChange = () => { }, style, children, ...rest }) => {
6
- const _containerStyle = [
7
- {
8
- flexDirection: direction === Direction.Horizontal ? "row" : "column",
9
- overflow: "hidden",
10
- },
11
- ];
12
- if (direction !== Direction.Vertical) {
13
- _containerStyle.push({
14
- alignItems: "center",
15
- });
16
- }
17
- return (React.createElement(View, { style: [{ minHeight: 40 }, style], ...rest },
18
- React.createElement(Provider, { value: { values, onValueChange, direction } },
19
- React.createElement(View, { style: _containerStyle }, children))));
20
- };
21
- export default CheckboxGroup;
@@ -1,77 +0,0 @@
1
- import * as React from "react";
2
- import { StyleSheet, View, Platform, } from "react-native";
3
- import Checkbox from "./Checkbox";
4
- import Text from "../Text";
5
- import { useCheckboxGroupContext } from "./context";
6
- import { Direction as GroupDirection } from "./context";
7
- import Touchable from "../Touchable";
8
- import { extractStyles } from "../../utilities";
9
- export var Direction;
10
- (function (Direction) {
11
- Direction["Row"] = "row";
12
- Direction["RowReverse"] = "row-reverse";
13
- })(Direction || (Direction = {}));
14
- const getCheckboxAlignment = (parentDirection, direction) => {
15
- if (parentDirection === GroupDirection.Horizontal) {
16
- return direction === Direction.Row ? "flex-start" : "flex-end";
17
- }
18
- else if (direction === Direction.RowReverse) {
19
- return "flex-start";
20
- }
21
- else {
22
- return "flex-end";
23
- }
24
- };
25
- const renderLabel = (value, labelStyle, textStyle) => {
26
- if (typeof value === "string") {
27
- return React.createElement(Text, { style: [labelStyle, textStyle] }, value);
28
- }
29
- else {
30
- return React.createElement(React.Fragment, null, value);
31
- }
32
- };
33
- const CheckboxGroupRow = ({ Icon, label = "Label", status, value, onPress, labelContainerStyle, labelStyle, checkboxStyle, direction = Direction.Row, disabled, style, color, uncheckedColor, ...rest }) => {
34
- const { values: selectedValues, onValueChange, direction: parentDirection, } = useCheckboxGroupContext();
35
- const values = Array.isArray(selectedValues) ? selectedValues : [];
36
- const isChecked = status || values.includes(value);
37
- const handlePress = () => {
38
- if (!disabled) {
39
- onPress === null || onPress === void 0 ? void 0 : onPress(!isChecked);
40
- onValueChange === null || onValueChange === void 0 ? void 0 : onValueChange(value, !isChecked);
41
- }
42
- };
43
- const { textStyles, viewStyles } = extractStyles(style);
44
- return (React.createElement(Touchable, { onPress: handlePress, style: [styles.mainParent, { flexDirection: direction }, viewStyles], disabled: disabled, ...rest },
45
- React.createElement(View, { style: [
46
- styles.label,
47
- {
48
- alignItems: direction === Direction.Row ? "flex-start" : "flex-end",
49
- },
50
- labelContainerStyle,
51
- ] }, renderLabel(label, labelStyle, textStyles)),
52
- React.createElement(View, { style: {
53
- flex: 1,
54
- alignItems: getCheckboxAlignment(parentDirection, direction),
55
- } },
56
- React.createElement(Checkbox, { Icon: Icon, status: isChecked, onPress: handlePress, style: checkboxStyle, disabled: disabled, color: color, uncheckedColor: uncheckedColor }))));
57
- };
58
- const styles = StyleSheet.create({
59
- mainParent: {
60
- alignItems: "center",
61
- justifyContent: "space-around",
62
- paddingStart: 20,
63
- minHeight: 50,
64
- paddingEnd: 20,
65
- display: "flex",
66
- ...Platform.select({
67
- web: {
68
- cursor: "pointer",
69
- userSelect: "none",
70
- },
71
- }),
72
- },
73
- label: {
74
- flex: 3,
75
- },
76
- });
77
- export default CheckboxGroupRow;
@@ -1,78 +0,0 @@
1
- import * as React from "react";
2
- import { StyleSheet, View, Platform, } from "react-native";
3
- import { isString } from "lodash";
4
- import { extractStyles } from "../../utilities";
5
- import { usePrevious } from "../../hooks";
6
- import Text from "../Text";
7
- import Touchable from "../Touchable";
8
- import Checkbox from "./Checkbox";
9
- export var Direction;
10
- (function (Direction) {
11
- Direction["Row"] = "row";
12
- Direction["RowReverse"] = "row-reverse";
13
- })(Direction || (Direction = {}));
14
- const renderLabel = (value, labelStyle, textStyle) => {
15
- if (isString(value)) {
16
- return React.createElement(Text, { style: [textStyle, labelStyle] }, value);
17
- }
18
- else {
19
- return React.createElement(React.Fragment, null, value);
20
- }
21
- };
22
- const CheckboxRow = ({ label = "Label", labelStyle, labelContainerStyle, checkboxStyle, direction = Direction.Row, Icon, status, disabled = false, onPress, onCheck, onUncheck, color, uncheckedColor, defaultValue, checkedIcon, uncheckedIcon, size, style, ...rest }) => {
23
- const [internalValue, setInternalValue] = React.useState(status || defaultValue || false);
24
- React.useEffect(() => {
25
- if (status != null) {
26
- setInternalValue(status);
27
- }
28
- }, [status]);
29
- // This special logic is to handle weird APIs like Airtable that return
30
- // true or undefined for a boolean
31
- const previousDefaultValue = usePrevious(defaultValue);
32
- React.useEffect(() => {
33
- if (defaultValue !== previousDefaultValue) {
34
- setInternalValue(Boolean(defaultValue));
35
- }
36
- }, [defaultValue, previousDefaultValue]);
37
- const handlePress = () => {
38
- const newValue = !internalValue;
39
- setInternalValue(newValue);
40
- onPress === null || onPress === void 0 ? void 0 : onPress(newValue);
41
- if (newValue) {
42
- onCheck === null || onCheck === void 0 ? void 0 : onCheck();
43
- }
44
- if (!newValue) {
45
- onUncheck === null || onUncheck === void 0 ? void 0 : onUncheck();
46
- }
47
- };
48
- const { textStyles, viewStyles } = extractStyles(style);
49
- return (React.createElement(Touchable, { onPress: handlePress, style: [viewStyles, styles.mainParent, { flexDirection: direction }], disabled: disabled, ...rest },
50
- React.createElement(View, { style: [
51
- styles.label,
52
- {
53
- alignItems: direction === Direction.Row ? "flex-start" : "flex-end",
54
- },
55
- labelContainerStyle,
56
- ] }, renderLabel(label, textStyles, labelStyle)),
57
- React.createElement(Checkbox, { Icon: Icon, status: internalValue, style: checkboxStyle, disabled: disabled, onPress: handlePress, color: color, uncheckedColor: uncheckedColor, checkedIcon: checkedIcon, uncheckedIcon: uncheckedIcon, size: size })));
58
- };
59
- const styles = StyleSheet.create({
60
- mainParent: {
61
- alignItems: "center",
62
- justifyContent: "space-around",
63
- paddingStart: 20,
64
- minHeight: 50,
65
- paddingEnd: 20,
66
- display: "flex",
67
- ...Platform.select({
68
- web: {
69
- cursor: "pointer",
70
- userSelect: "none",
71
- },
72
- }),
73
- },
74
- label: {
75
- flex: 3,
76
- },
77
- });
78
- export default CheckboxRow;
@@ -1,14 +0,0 @@
1
- import { createContext, useContext } from "react";
2
- export var Direction;
3
- (function (Direction) {
4
- Direction["Horizontal"] = "horizontal";
5
- Direction["Vertical"] = "vertical";
6
- })(Direction || (Direction = {}));
7
- export const checkboxGroupContext = createContext({
8
- onValueChange: () => { },
9
- values: [],
10
- direction: undefined,
11
- });
12
- export function useCheckboxGroupContext() {
13
- return useContext(checkboxGroupContext);
14
- }
@@ -1,3 +0,0 @@
1
- export { default as Checkbox } from "./Checkbox";
2
- export { default as CheckboxGroup } from "./CheckboxGroup";
3
- export { default as CheckboxRow } from "./CheckboxRow";
@@ -1,64 +0,0 @@
1
- import { Dimensions, Platform } from "react-native";
2
- const getWindowDimensions = () => {
3
- const { width, height } = Dimensions.get("window");
4
- return {
5
- windowWidth: width,
6
- windowHeight: height,
7
- };
8
- };
9
- const { windowWidth, windowHeight } = getWindowDimensions();
10
- const getFilters = (options) => {
11
- const { width, height } = options;
12
- const filters = ["c_scale", "q_auto", "dpr_auto"];
13
- if (width)
14
- filters.push(`w_${width}`);
15
- if (height)
16
- filters.push(`h_${height}`);
17
- return filters.join(",");
18
- };
19
- const buildImageUrl = (options, name) => {
20
- const filters = getFilters(options);
21
- return [
22
- "https://res.cloudinary.com/altos/image/upload",
23
- filters,
24
- `${name}.png`,
25
- ].join("/");
26
- };
27
- const getExtension = () => {
28
- return Platform.OS === "web" ? ".svg" : ".png";
29
- };
30
- export default {
31
- windowWidth,
32
- windowHeight,
33
- avatarImageUrl: buildImageUrl({
34
- width: 60,
35
- height: 60,
36
- }, "Avatar"),
37
- avatarImageSize: 60,
38
- cardImageSize: 200,
39
- cardImageUrl: "https://static.draftbit.com/images/placeholder-image" + getExtension(),
40
- cardIconSize: 16,
41
- cardIconBackgroundOpacity: 0.24,
42
- cardIconElevation: 1,
43
- placeholderImageURL: "https://static.draftbit.com/images/placeholder-image" + getExtension(),
44
- getPlaceholderImageUrl: (size) => buildImageUrl({ width: size.width, height: size.height }, "image-placeholder_1"),
45
- placeholderSvgURL: "https://static.draftbit.com/images/placeholder-image.svg",
46
- squareImageUrl: buildImageUrl({ width: 100, height: 100 }, "Avatar"),
47
- FABSize: 40,
48
- FABBorderRadius: 20,
49
- FABFixedHeight: 64,
50
- cardContainerShortImageAspectRatio: 1,
51
- rowSingleLineImageSize: 24,
52
- rowMultiLineImageSize: 48,
53
- rowSingleLineIconSize: 24,
54
- rowMultiLineIconSize: 16,
55
- headerIconSize: 24,
56
- buttonIconSize: 24,
57
- swiperInactiveDotSize: 6,
58
- swiperActiveDotSize: 10,
59
- fieldSearchBarFullIconSize: 24,
60
- stepperButtonSize: 40,
61
- radioButtonSize: 24,
62
- topSafeAreaViewHeight: 0,
63
- // topSafeAreaViewHeight: Platform.OS === "android" ? Constants.statusBarHeight : 0
64
- };