@draftbit/core 47.0.0-0362d7.2 → 47.0.0-alpha.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 (135) hide show
  1. package/lib/commonjs/components/FormRow.js +3 -17
  2. package/lib/commonjs/components/FormRow.js.map +1 -1
  3. package/lib/commonjs/components/Picker/PickerComponent.ios.js +11 -30
  4. package/lib/commonjs/components/Picker/PickerComponent.ios.js.map +1 -1
  5. package/lib/commonjs/components/Portal/PortalHost.js +15 -45
  6. package/lib/commonjs/components/Portal/PortalHost.js.map +1 -1
  7. package/lib/commonjs/components/RadioButton/RadioButton.js +3 -14
  8. package/lib/commonjs/components/RadioButton/RadioButton.js.map +1 -1
  9. package/lib/commonjs/components/Stepper.js +0 -1
  10. package/lib/commonjs/components/Surface.js +2 -13
  11. package/lib/commonjs/components/Surface.js.map +1 -1
  12. package/lib/commonjs/mappings/View.js.map +1 -1
  13. package/lib/commonjs/mappings/WebView.js.map +1 -1
  14. package/lib/module/components/Accordion/AccordionItem.js +4 -23
  15. package/lib/module/components/Accordion/AccordionItem.js.map +1 -1
  16. package/lib/module/components/Stepper.js +0 -1
  17. package/package.json +3 -3
  18. package/src/Provider.js +0 -9
  19. package/src/components/Accordion/AccordionGroup.js +0 -44
  20. package/src/components/Accordion/AccordionItem.js +0 -32
  21. package/src/components/Accordion/index.js +0 -2
  22. package/src/components/ActionSheet/ActionSheet.js +0 -45
  23. package/src/components/ActionSheet/ActionSheetCancel.js +0 -6
  24. package/src/components/ActionSheet/ActionSheetItem.js +0 -30
  25. package/src/components/ActionSheet/index.js +0 -3
  26. package/src/components/Button.js +0 -114
  27. package/src/components/Checkbox/Checkbox.js +0 -63
  28. package/src/components/Checkbox/CheckboxGroup.js +0 -21
  29. package/src/components/Checkbox/CheckboxGroupRow.js +0 -77
  30. package/src/components/Checkbox/CheckboxRow.js +0 -78
  31. package/src/components/Checkbox/context.js +0 -14
  32. package/src/components/Checkbox/index.js +0 -3
  33. package/src/components/Config.js +0 -64
  34. package/src/components/DatePicker/DatePicker.js +0 -368
  35. package/src/components/DatePicker/DatePickerComponent.js +0 -13
  36. package/src/components/DatePicker/DatePickerComponent.web.js +0 -30
  37. package/src/components/DatePicker/DatePickerComponentType.js +0 -1
  38. package/src/components/DeprecatedButton.js +0 -95
  39. package/src/components/Elevation.js +0 -20
  40. package/src/components/FormRow.js +0 -19
  41. package/src/components/IconButton.js +0 -35
  42. package/src/components/Layout.js +0 -50
  43. package/src/components/NumberInput.js +0 -49
  44. package/src/components/Picker/Picker.js +0 -267
  45. package/src/components/Picker/PickerComponent.android.js +0 -69
  46. package/src/components/Picker/PickerComponent.ios.js +0 -79
  47. package/src/components/Picker/PickerComponent.web.js +0 -70
  48. package/src/components/Picker/PickerTypes.js +0 -1
  49. package/src/components/Portal/Portal.js +0 -35
  50. package/src/components/Portal/PortalConsumer.js +0 -27
  51. package/src/components/Portal/PortalHost.js +0 -107
  52. package/src/components/Portal/PortalManager.js +0 -32
  53. package/src/components/RadioButton/RadioButton.js +0 -17
  54. package/src/components/RadioButton/RadioButtonFieldGroup.js +0 -17
  55. package/src/components/RadioButton/RadioButtonGroup.js +0 -43
  56. package/src/components/RadioButton/RadioButtonRow.js +0 -76
  57. package/src/components/RadioButton/context.js +0 -14
  58. package/src/components/RadioButton/index.js +0 -4
  59. package/src/components/SVG.js +0 -13
  60. package/src/components/ScreenContainer.js +0 -34
  61. package/src/components/Slider.js +0 -63
  62. package/src/components/StarRating.js +0 -50
  63. package/src/components/Stepper.js +0 -39
  64. package/src/components/Surface.js +0 -32
  65. package/src/components/Swiper/Swiper.js +0 -29
  66. package/src/components/Swiper/SwiperItem.js +0 -9
  67. package/src/components/Swiper/index.js +0 -2
  68. package/src/components/Switch.js +0 -56
  69. package/src/components/Text.js +0 -33
  70. package/src/components/TextField.js +0 -428
  71. package/src/components/Touchable.js +0 -12
  72. package/src/components/Touchable.web.js +0 -2
  73. package/src/constants.js +0 -10
  74. package/src/hooks.js +0 -12
  75. package/src/index.js +0 -33
  76. package/src/interfaces/Icon.js +0 -8
  77. package/src/mappings/Accordion.js +0 -41
  78. package/src/mappings/AccordionItem.js +0 -16
  79. package/src/mappings/ActionSheet.js +0 -13
  80. package/src/mappings/ActionSheetCancel.js +0 -19
  81. package/src/mappings/ActionSheetItem.js +0 -23
  82. package/src/mappings/ActivityIndicator.js +0 -58
  83. package/src/mappings/AudioPlayer.js +0 -20
  84. package/src/mappings/BlurView.js +0 -42
  85. package/src/mappings/Button.js +0 -87
  86. package/src/mappings/Checkbox.js +0 -46
  87. package/src/mappings/CheckboxGroup.js +0 -26
  88. package/src/mappings/CheckboxRow.js +0 -61
  89. package/src/mappings/CustomCode.js +0 -8
  90. package/src/mappings/DatePicker.js +0 -157
  91. package/src/mappings/Fetch.js +0 -13
  92. package/src/mappings/FlashList.js +0 -33
  93. package/src/mappings/FlatList.js +0 -24
  94. package/src/mappings/Icon.js +0 -32
  95. package/src/mappings/IconButton.js +0 -35
  96. package/src/mappings/Image.js +0 -35
  97. package/src/mappings/ImageBackground.js +0 -29
  98. package/src/mappings/KeyboardAvoidingView.js +0 -41
  99. package/src/mappings/KeyboardAwareScrollView.js +0 -50
  100. package/src/mappings/Layout.js +0 -200
  101. package/src/mappings/LinearGradient.js +0 -77
  102. package/src/mappings/MapCallout.js +0 -21
  103. package/src/mappings/MapMarker.js +0 -47
  104. package/src/mappings/MapView.js +0 -139
  105. package/src/mappings/Modal.js +0 -42
  106. package/src/mappings/NumberInput.js +0 -254
  107. package/src/mappings/Picker.js +0 -148
  108. package/src/mappings/RadioButton.js +0 -51
  109. package/src/mappings/RadioButtonGroup.js +0 -17
  110. package/src/mappings/RadioButtonRow.js +0 -42
  111. package/src/mappings/SVG.js +0 -20
  112. package/src/mappings/SafeAreaView.js +0 -33
  113. package/src/mappings/ScrollView.js +0 -31
  114. package/src/mappings/Slider.js +0 -60
  115. package/src/mappings/StarRating.js +0 -43
  116. package/src/mappings/Stepper.js +0 -29
  117. package/src/mappings/Surface.js +0 -14
  118. package/src/mappings/Swiper.js +0 -60
  119. package/src/mappings/SwiperItem.js +0 -8
  120. package/src/mappings/Switch.js +0 -81
  121. package/src/mappings/Text.js +0 -251
  122. package/src/mappings/TextArea.js +0 -263
  123. package/src/mappings/TextField.js +0 -381
  124. package/src/mappings/TextInput.js +0 -391
  125. package/src/mappings/Touchable.js +0 -17
  126. package/src/mappings/Video.js +0 -81
  127. package/src/mappings/View.js +0 -207
  128. package/src/mappings/WebView.js +0 -88
  129. package/src/styles/DarkTheme.js +0 -26
  130. package/src/styles/DefaultTheme.js +0 -111
  131. package/src/styles/fonts.js +0 -62
  132. package/src/styles/overlay.js +0 -60
  133. package/src/styles/shadow.js +0 -51
  134. package/src/theming.js +0 -3
  135. package/src/utilities.js +0 -102
@@ -1,32 +0,0 @@
1
- import * as React from "react";
2
- import { Pressable, StyleSheet, View, } from "react-native";
3
- import Text from "../Text";
4
- import { extractStyles } from "../../utilities";
5
- import { withTheme } from "../../theming";
6
- const AccordionItem = ({ Icon, icon, label, style, iconColor, theme, ...rest }) => {
7
- const { textStyles, viewStyles } = extractStyles(style);
8
- return (React.createElement(Pressable, { style: [styles.container, viewStyles], ...rest },
9
- React.createElement(View, { style: styles.row },
10
- icon ? (React.createElement(Icon, { name: icon, size: 24, color: iconColor || theme.colors.primary })) : null,
11
- React.createElement(View, { style: [styles.item, styles.content] },
12
- React.createElement(Text, { selectable: false, style: textStyles }, label)))));
13
- };
14
- const styles = StyleSheet.create({
15
- container: {
16
- padding: 8,
17
- },
18
- row: {
19
- flexDirection: "row",
20
- alignItems: "center",
21
- paddingLeft: 8,
22
- },
23
- item: {
24
- marginVertical: 6,
25
- paddingLeft: 8,
26
- },
27
- content: {
28
- flex: 1,
29
- justifyContent: "center",
30
- },
31
- });
32
- export default withTheme(AccordionItem);
@@ -1,2 +0,0 @@
1
- export { default as AccordionGroup } from "./AccordionGroup";
2
- export { default as AccordionItem } from "./AccordionItem";
@@ -1,45 +0,0 @@
1
- import React from "react";
2
- import { View, StyleSheet } from "react-native";
3
- import Portal from "../Portal/Portal";
4
- import Touchable from "../Touchable";
5
- import ActionSheetCancel from "./ActionSheetCancel";
6
- const ActionSheet = ({ visible = false, onClose, children }) => {
7
- return visible ? (React.createElement(Portal, null,
8
- React.createElement(Touchable, { style: styles.wrapper, onPress: onClose },
9
- React.createElement(View, { style: styles.overlay }),
10
- React.createElement(View, { style: styles.groupWrapper },
11
- React.createElement(View, { style: styles.group }, React.Children.toArray(children).filter((child) => (child === null || child === void 0 ? void 0 : child.type) !== ActionSheetCancel)),
12
- React.createElement(View, { style: styles.group }, React.Children.toArray(children).filter((child) => child.type === ActionSheetCancel)))))) : (React.createElement(React.Fragment, null));
13
- };
14
- const styles = StyleSheet.create({
15
- wrapper: {
16
- flex: 1,
17
- display: "flex",
18
- flexDirection: "column",
19
- },
20
- overlay: {
21
- position: "absolute",
22
- top: 0,
23
- left: 0,
24
- right: 0,
25
- bottom: 0,
26
- backgroundColor: "#000000",
27
- opacity: 0.3,
28
- },
29
- groupWrapper: {
30
- flex: 1,
31
- flexDirection: "column",
32
- justifyContent: "flex-end",
33
- display: "flex",
34
- marginBottom: 25,
35
- },
36
- group: {
37
- display: "flex",
38
- flexDirection: "column",
39
- borderRadius: 10,
40
- marginHorizontal: 7,
41
- marginVertical: 2.5,
42
- overflow: "hidden",
43
- },
44
- });
45
- export default ActionSheet;
@@ -1,6 +0,0 @@
1
- import React from "react";
2
- import ActionSheetItem from "./ActionSheetItem";
3
- const ActionSheetCancel = ({ label = "Cancel", color, style, onPress, }) => {
4
- return (React.createElement(ActionSheetItem, { label: label, color: color || "#FF453A", style: [style], onPress: onPress }));
5
- };
6
- export default ActionSheetCancel;
@@ -1,30 +0,0 @@
1
- import React from "react";
2
- import { Text, StyleSheet, TouchableOpacity, } from "react-native";
3
- import { extractStyles } from "../../utilities";
4
- const ActionSheetItem = ({ label, style, color, onPress, }) => {
5
- const { textStyles, viewStyles } = extractStyles(style);
6
- return (React.createElement(TouchableOpacity, { activeOpacity: 0.7, style: [styles.wrapper, viewStyles], onPress: onPress },
7
- React.createElement(Text, { style: [styles.label, textStyles, { color }] }, label)));
8
- };
9
- const styles = StyleSheet.create({
10
- wrapper: {
11
- borderBottomWidth: StyleSheet.hairlineWidth,
12
- borderBottomColor: "#CCCCCC",
13
- backgroundColor: "#F1F1F1",
14
- minHeight: 50,
15
- overflow: "hidden",
16
- display: "flex",
17
- justifyContent: "center",
18
- },
19
- label: {
20
- fontSize: 16,
21
- textAlign: "center",
22
- color: "#0A84FF",
23
- fontWeight: "500",
24
- overflow: "hidden",
25
- paddingHorizontal: 20,
26
- paddingVertical: 10,
27
- alignSelf: "center",
28
- },
29
- });
30
- export default ActionSheetItem;
@@ -1,3 +0,0 @@
1
- export { default as ActionSheet } from "./ActionSheet";
2
- export { default as ActionSheetItem } from "./ActionSheetItem";
3
- export { default as ActionSheetCancel } from "./ActionSheetCancel";
@@ -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
- };