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