@mpxjs/webpack-plugin 2.9.59 → 2.9.64

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 (115) hide show
  1. package/lib/index.js +1 -3
  2. package/lib/platform/style/wx/index.js +344 -270
  3. package/lib/platform/template/wx/component-config/checkbox-group.js +8 -0
  4. package/lib/platform/template/wx/component-config/checkbox.js +8 -0
  5. package/lib/platform/template/wx/component-config/cover-image.js +15 -0
  6. package/lib/platform/template/wx/component-config/cover-view.js +9 -0
  7. package/lib/platform/template/wx/component-config/form.js +13 -1
  8. package/lib/platform/template/wx/component-config/icon.js +8 -0
  9. package/lib/platform/template/wx/component-config/index.js +5 -1
  10. package/lib/platform/template/wx/component-config/label.js +15 -0
  11. package/lib/platform/template/wx/component-config/movable-area.js +18 -1
  12. package/lib/platform/template/wx/component-config/movable-view.js +18 -1
  13. package/lib/platform/template/wx/component-config/navigator.js +8 -0
  14. package/lib/platform/template/wx/component-config/picker-view-column.js +8 -0
  15. package/lib/platform/template/wx/component-config/picker-view.js +18 -2
  16. package/lib/platform/template/wx/component-config/picker.js +14 -1
  17. package/lib/platform/template/wx/component-config/radio-group.js +8 -0
  18. package/lib/platform/template/wx/component-config/radio.js +8 -0
  19. package/lib/platform/template/wx/component-config/root-portal.js +15 -0
  20. package/lib/platform/template/wx/component-config/switch.js +8 -0
  21. package/lib/platform/template/wx/component-config/unsupported.js +1 -3
  22. package/lib/react/processScript.js +2 -0
  23. package/lib/react/processStyles.js +1 -0
  24. package/lib/react/processTemplate.js +2 -3
  25. package/lib/react/style-helper.js +12 -7
  26. package/lib/runtime/components/react/context.ts +40 -0
  27. package/lib/runtime/components/react/dist/context.js +8 -0
  28. package/lib/runtime/components/react/dist/getInnerListeners.js +34 -12
  29. package/lib/runtime/components/react/dist/mpx-button.jsx +88 -88
  30. package/lib/runtime/components/react/dist/mpx-checkbox-group.jsx +82 -0
  31. package/lib/runtime/components/react/dist/mpx-checkbox.jsx +139 -0
  32. package/lib/runtime/components/react/dist/mpx-form.jsx +61 -0
  33. package/lib/runtime/components/react/dist/mpx-icon.jsx +48 -0
  34. package/lib/runtime/components/react/dist/mpx-image/index.jsx +39 -43
  35. package/lib/runtime/components/react/dist/mpx-image/svg.jsx +3 -2
  36. package/lib/runtime/components/react/dist/mpx-input.jsx +63 -37
  37. package/lib/runtime/components/react/dist/mpx-label.jsx +55 -0
  38. package/lib/runtime/components/react/dist/mpx-movable-area.jsx +41 -0
  39. package/lib/runtime/components/react/dist/mpx-movable-view.jsx +346 -0
  40. package/lib/runtime/components/react/dist/mpx-navigator.jsx +35 -0
  41. package/lib/runtime/components/react/dist/mpx-picker/date.jsx +69 -0
  42. package/lib/runtime/components/react/dist/mpx-picker/index.jsx +138 -0
  43. package/lib/runtime/components/react/dist/mpx-picker/multiSelector.jsx +142 -0
  44. package/lib/runtime/components/react/dist/mpx-picker/region.jsx +94 -0
  45. package/lib/runtime/components/react/dist/mpx-picker/regionData.js +6099 -0
  46. package/lib/runtime/components/react/dist/mpx-picker/selector.jsx +76 -0
  47. package/lib/runtime/components/react/dist/mpx-picker/time.jsx +244 -0
  48. package/lib/runtime/components/react/dist/mpx-picker/type.js +1 -0
  49. package/lib/runtime/components/react/dist/mpx-picker-view-column.jsx +107 -0
  50. package/lib/runtime/components/react/dist/mpx-picker-view.jsx +162 -0
  51. package/lib/runtime/components/react/dist/mpx-radio-group.jsx +80 -0
  52. package/lib/runtime/components/react/dist/mpx-radio.jsx +154 -0
  53. package/lib/runtime/components/react/dist/mpx-root-portal.jsx +15 -0
  54. package/lib/runtime/components/react/dist/mpx-scroll-view.jsx +93 -70
  55. package/lib/runtime/components/react/dist/mpx-swiper/carouse.jsx +281 -157
  56. package/lib/runtime/components/react/dist/mpx-swiper/index.jsx +21 -11
  57. package/lib/runtime/components/react/dist/mpx-swiper-item.jsx +19 -11
  58. package/lib/runtime/components/react/dist/mpx-switch.jsx +79 -0
  59. package/lib/runtime/components/react/dist/mpx-text.jsx +21 -49
  60. package/lib/runtime/components/react/dist/mpx-textarea.jsx +2 -2
  61. package/lib/runtime/components/react/dist/mpx-view.jsx +451 -146
  62. package/lib/runtime/components/react/dist/mpx-web-view.jsx +17 -20
  63. package/lib/runtime/components/react/dist/parser.js +218 -0
  64. package/lib/runtime/components/react/dist/types/common.js +1 -0
  65. package/lib/runtime/components/react/dist/useNodesRef.js +3 -8
  66. package/lib/runtime/components/react/dist/utils.jsx +433 -0
  67. package/lib/runtime/components/react/getInnerListeners.ts +43 -21
  68. package/lib/runtime/components/react/mpx-button.tsx +129 -119
  69. package/lib/runtime/components/react/mpx-checkbox-group.tsx +152 -0
  70. package/lib/runtime/components/react/mpx-checkbox.tsx +234 -0
  71. package/lib/runtime/components/react/mpx-form.tsx +117 -0
  72. package/lib/runtime/components/react/mpx-icon.tsx +106 -0
  73. package/lib/runtime/components/react/mpx-image/index.tsx +62 -68
  74. package/lib/runtime/components/react/mpx-image/svg.tsx +7 -5
  75. package/lib/runtime/components/react/mpx-input.tsx +90 -42
  76. package/lib/runtime/components/react/mpx-label.tsx +110 -0
  77. package/lib/runtime/components/react/mpx-movable-area.tsx +81 -0
  78. package/lib/runtime/components/react/mpx-movable-view.tsx +424 -0
  79. package/lib/runtime/components/react/mpx-navigator.tsx +67 -0
  80. package/lib/runtime/components/react/mpx-picker/date.tsx +82 -0
  81. package/lib/runtime/components/react/mpx-picker/index.tsx +155 -0
  82. package/lib/runtime/components/react/mpx-picker/multiSelector.tsx +156 -0
  83. package/lib/runtime/components/react/mpx-picker/region.tsx +107 -0
  84. package/lib/runtime/components/react/mpx-picker/regionData.ts +6101 -0
  85. package/lib/runtime/components/react/mpx-picker/selector.tsx +91 -0
  86. package/lib/runtime/components/react/mpx-picker/time.tsx +270 -0
  87. package/lib/runtime/components/react/mpx-picker/type.ts +107 -0
  88. package/lib/runtime/components/react/mpx-picker-view-column.tsx +156 -0
  89. package/lib/runtime/components/react/mpx-picker-view.tsx +220 -0
  90. package/lib/runtime/components/react/mpx-radio-group.tsx +150 -0
  91. package/lib/runtime/components/react/mpx-radio.tsx +230 -0
  92. package/lib/runtime/components/react/mpx-root-portal.tsx +27 -0
  93. package/lib/runtime/components/react/mpx-scroll-view.tsx +184 -130
  94. package/lib/runtime/components/react/mpx-swiper/carouse.tsx +308 -183
  95. package/lib/runtime/components/react/mpx-swiper/index.tsx +27 -19
  96. package/lib/runtime/components/react/mpx-swiper/type.ts +23 -5
  97. package/lib/runtime/components/react/mpx-swiper-item.tsx +49 -14
  98. package/lib/runtime/components/react/mpx-switch.tsx +148 -0
  99. package/lib/runtime/components/react/mpx-text.tsx +53 -77
  100. package/lib/runtime/components/react/mpx-textarea.tsx +3 -3
  101. package/lib/runtime/components/react/mpx-view.tsx +576 -195
  102. package/lib/runtime/components/react/mpx-web-view.tsx +34 -39
  103. package/lib/runtime/components/react/parser.ts +245 -0
  104. package/lib/runtime/components/react/types/common.ts +12 -0
  105. package/lib/runtime/components/react/types/getInnerListeners.ts +2 -1
  106. package/lib/runtime/components/react/types/global.d.ts +17 -1
  107. package/lib/runtime/components/react/useNodesRef.ts +4 -10
  108. package/lib/runtime/components/react/utils.tsx +505 -0
  109. package/lib/runtime/optionProcessor.js +19 -17
  110. package/lib/template-compiler/compiler.js +84 -61
  111. package/lib/template-compiler/gen-node-react.js +7 -9
  112. package/lib/web/processStyles.js +2 -5
  113. package/package.json +8 -3
  114. package/lib/runtime/components/react/dist/utils.js +0 -80
  115. package/lib/runtime/components/react/utils.ts +0 -92
@@ -0,0 +1,48 @@
1
+ /**
2
+ * ✔ type
3
+ * ✔ size
4
+ * ✔ color
5
+ */
6
+ import { forwardRef } from 'react';
7
+ import { Image } from 'react-native';
8
+ import useInnerProps from './getInnerListeners';
9
+ import useNodesRef from './useNodesRef';
10
+ import { useLayout, useTransformStyle } from './utils';
11
+ const IconTypeMap = new Map([
12
+ ['success', ''],
13
+ ['success_no_circle', ''],
14
+ ['info', ''],
15
+ ['warn', ''],
16
+ ['waiting', ''],
17
+ ['cancel', ''],
18
+ ['download', ''],
19
+ ['search', ''],
20
+ ['clear', '']
21
+ ]);
22
+ const Icon = forwardRef((props, ref) => {
23
+ const { type, size = 23, color, style = {}, 'enable-var': enableVar, 'external-var-context': externalVarContext, 'parent-font-size': parentFontSize, 'parent-width': parentWidth, 'parent-height': parentHeight } = props;
24
+ const uri = IconTypeMap.get(type);
25
+ const defaultStyle = { width: ~~size, height: ~~size };
26
+ const styleObj = {
27
+ ...defaultStyle,
28
+ ...style
29
+ };
30
+ const { hasSelfPercent, normalStyle, setWidth, setHeight } = useTransformStyle(styleObj, { enableVar, externalVarContext, parentFontSize, parentWidth, parentHeight });
31
+ const { nodeRef } = useNodesRef(props, ref, { defaultStyle });
32
+ const { layoutRef, layoutStyle, layoutProps } = useLayout({ props, hasSelfPercent, setWidth, setHeight, nodeRef });
33
+ const innerProps = useInnerProps(props, {
34
+ ref: nodeRef,
35
+ style: {
36
+ ...normalStyle,
37
+ ...layoutStyle,
38
+ tintColor: color
39
+ },
40
+ source: { uri },
41
+ ...layoutProps
42
+ }, [], {
43
+ layoutRef
44
+ });
45
+ return <Image {...innerProps}/>;
46
+ });
47
+ Icon.displayName = 'mpx-icon';
48
+ export default Icon;
@@ -10,10 +10,11 @@
10
10
  * ✔ bindtap
11
11
  * ✔ DEFAULT_SIZE
12
12
  */
13
- import React, { useEffect, useMemo, useState, forwardRef, useRef, } from 'react';
14
- import { Image as RNImage, View, StyleSheet, } from 'react-native';
13
+ import { useEffect, useMemo, useState, useRef, forwardRef } from 'react';
14
+ import { Image as RNImage, View, StyleSheet } from 'react-native';
15
15
  import useInnerProps, { getCustomEvent } from '../getInnerListeners';
16
16
  import useNodesRef from '../useNodesRef';
17
+ import { useLayout, useTransformStyle } from '../utils';
17
18
  const DEFAULT_IMAGE_WIDTH = 320;
18
19
  const DEFAULT_IMAGE_HEIGHT = 240;
19
20
  // const REMOTE_SVG_REGEXP = /https?:\/\/.*\.(?:svg)/i
@@ -35,7 +36,7 @@ const cropMode = [
35
36
  'top left',
36
37
  'top right',
37
38
  'bottom left',
38
- 'bottom right',
39
+ 'bottom right'
39
40
  ];
40
41
  const ModeMap = new Map([
41
42
  ['scaleToFill', 'stretch'],
@@ -43,7 +44,7 @@ const ModeMap = new Map([
43
44
  ['aspectFill', 'cover'],
44
45
  ['widthFix', 'stretch'],
45
46
  ['heightFix', 'stretch'],
46
- ...cropMode.map(mode => [mode, 'stretch']),
47
+ ...cropMode.map(mode => [mode, 'stretch'])
47
48
  ]);
48
49
  const isNumber = (value) => typeof value === 'number';
49
50
  const relativeCenteredSize = (viewSize, imageSize) => (viewSize - imageSize) / 2;
@@ -56,15 +57,26 @@ const relativeCenteredSize = (viewSize, imageSize) => (viewSize - imageSize) / 2
56
57
  const Image = forwardRef((props, ref) => {
57
58
  const { src = '', mode = 'scaleToFill',
58
59
  // svg = false,
59
- style = [], 'enable-offset': enableOffset, bindload, binderror } = props;
60
- const { width = DEFAULT_IMAGE_WIDTH, height = DEFAULT_IMAGE_HEIGHT } = StyleSheet.flatten(style);
60
+ style = {}, 'enable-var': enableVar, 'external-var-context': externalVarContext, 'parent-font-size': parentFontSize, 'parent-width': parentWidth, 'parent-height': parentHeight, bindload, binderror } = props;
61
+ const defaultStyle = {
62
+ width: DEFAULT_IMAGE_WIDTH,
63
+ height: DEFAULT_IMAGE_HEIGHT
64
+ };
65
+ const styleObj = {
66
+ ...defaultStyle,
67
+ ...style,
68
+ overflow: 'hidden'
69
+ };
61
70
  const { nodeRef } = useNodesRef(props, ref, {
62
- defaultStyle: {
63
- width: DEFAULT_IMAGE_WIDTH,
64
- height: DEFAULT_IMAGE_HEIGHT
65
- }
71
+ defaultStyle
66
72
  });
67
- const layoutRef = useRef({});
73
+ const onLayout = ({ nativeEvent: { layout: { width, height } } }) => {
74
+ setViewWidth(width);
75
+ setViewHeight(height);
76
+ };
77
+ const { normalStyle, hasSelfPercent, setWidth, setHeight } = useTransformStyle(styleObj, { enableVar, externalVarContext, parentFontSize, parentWidth, parentHeight });
78
+ const { layoutRef, layoutStyle, layoutProps } = useLayout({ props, hasSelfPercent, setWidth, setHeight, nodeRef, onLayout });
79
+ const { width, height } = normalStyle;
68
80
  const preSrc = useRef();
69
81
  const resizeMode = ModeMap.get(mode) || 'stretch';
70
82
  const isWidthFixMode = mode === 'widthFix';
@@ -115,6 +127,7 @@ const Image = forwardRef((props, ref) => {
115
127
  if (!bindload)
116
128
  return;
117
129
  if (typeof src === 'string') {
130
+ evt.persist();
118
131
  RNImage.getSize(src, (width, height) => {
119
132
  bindload(getCustomEvent('load', evt, {
120
133
  detail: { width, height },
@@ -137,15 +150,6 @@ const Image = forwardRef((props, ref) => {
137
150
  layoutRef
138
151
  }, props));
139
152
  };
140
- const onViewLayout = ({ nativeEvent: { layout: { width, height }, }, }) => {
141
- setViewWidth(width);
142
- setViewHeight(height);
143
- };
144
- const onImageLayout = () => {
145
- nodeRef.current?.measure((x, y, width, height, offsetLeft, offsetTop) => {
146
- layoutRef.current = { x, y, width, height, offsetLeft, offsetTop };
147
- });
148
- };
149
153
  useEffect(() => {
150
154
  if (!isWidthFixMode && !isHeightFixMode && !isCropMode) {
151
155
  setLoaded(true);
@@ -180,10 +184,14 @@ const Image = forwardRef((props, ref) => {
180
184
  }, [isWidthFixMode, isHeightFixMode, isCropMode, src]);
181
185
  const innerProps = useInnerProps(props, {
182
186
  ref: nodeRef,
183
- ...(enableOffset ? { onLayout: onImageLayout } : {})
184
- }, [
185
- 'enable-offset'
186
- ], {
187
+ style: {
188
+ ...normalStyle,
189
+ ...layoutStyle,
190
+ ...(isHeightFixMode && { width: fixedWidth }),
191
+ ...(isWidthFixMode && { height: fixedHeight })
192
+ },
193
+ ...layoutProps
194
+ }, [], {
187
195
  layoutRef
188
196
  });
189
197
  // if (typeof src === 'string' && REMOTE_SVG_REGEXP.test(src)) {
@@ -204,25 +212,13 @@ const Image = forwardRef((props, ref) => {
204
212
  // </Suspense>
205
213
  // )
206
214
  // }
207
- return (<View style={[
208
- { width, height },
209
- style,
210
- {
211
- ...(isHeightFixMode && { width: fixedWidth }),
212
- ...(isWidthFixMode && { height: fixedHeight }),
213
- },
214
- { overflow: 'hidden' },
215
- ]} onLayout={onViewLayout}>
216
- {loaded && <RNImage {...innerProps} source={source} resizeMode={resizeMode} onLoad={onImageLoad} onError={onImageError} style={[
217
- StyleSheet.absoluteFill,
218
- {
219
- width: !isCropMode ? '100%' : imageWidth,
220
- height: !isCropMode ? '100%' : imageHeight,
221
- },
222
- {
223
- ...(isCropMode && cropModeStyle),
224
- },
225
- ]}/>}
215
+ return (<View {...innerProps}>
216
+ {loaded && <RNImage source={source} resizeMode={resizeMode} onLoad={onImageLoad} onError={onImageError} style={{
217
+ ...StyleSheet.absoluteFillObject,
218
+ width: isCropMode ? imageWidth : '100%',
219
+ height: isCropMode ? imageHeight : '100%',
220
+ ...(isCropMode && cropModeStyle)
221
+ }}/>}
226
222
  </View>);
227
223
  });
228
224
  Image.displayName = 'mpx-image';
@@ -1,6 +1,7 @@
1
- import React from 'react';
2
1
  import { SvgCssUri, WithLocalSvg } from 'react-native-svg/css';
3
2
  const Svg = ({ local = false, src, style, width, height }) => {
4
- return local ? (<WithLocalSvg style={style} asset={src} width={width} height={height}/>) : (<SvgCssUri style={style} uri={src} width={width} height={height}/>);
3
+ return local
4
+ ? (<WithLocalSvg style={style} asset={src} width={width} height={height}/>)
5
+ : (<SvgCssUri style={style} uri={src} width={width} height={height}/>);
5
6
  };
6
7
  export default Svg;
@@ -37,35 +37,55 @@
37
37
  * ✘ bind:keyboardcompositionend
38
38
  * ✘ bind:onkeyboardheightchange
39
39
  */
40
- import React, { forwardRef, useMemo, useRef, useState } from 'react';
40
+ import { forwardRef, useMemo, useRef, useState, useContext, useEffect } from 'react';
41
41
  import { Platform, TextInput } from 'react-native';
42
- import { parseInlineStyle, useUpdateEffect } from './utils';
42
+ import { warn } from '@mpxjs/utils';
43
+ import { parseInlineStyle, useUpdateEffect, useTransformStyle, useLayout } from './utils';
43
44
  import useInnerProps, { getCustomEvent } from './getInnerListeners';
44
45
  import useNodesRef from './useNodesRef';
46
+ import { FormContext } from './context';
45
47
  const keyboardTypeMap = {
46
48
  text: 'default',
47
49
  number: 'numeric',
48
50
  idcard: 'default',
49
51
  digit: Platform.select({
50
52
  ios: 'decimal-pad',
51
- android: 'numeric',
52
- }) || '',
53
+ android: 'numeric'
54
+ }) || ''
53
55
  };
54
56
  const Input = forwardRef((props, ref) => {
55
- const { style = [], type = 'text', value, password, 'placeholder-style': placeholderStyle, disabled, maxlength = 140, 'auto-focus': autoFocus, focus, 'confirm-type': confirmType = 'done', 'confirm-hold': confirmHold = false, cursor, 'cursor-color': cursorColor, 'selection-start': selectionStart = -1, 'selection-end': selectionEnd = -1, 'enable-offset': enableOffset, bindinput, bindfocus, bindblur, bindconfirm, bindselectionchange,
57
+ const { style = {}, type = 'text', value, password, 'placeholder-style': placeholderStyle, disabled, maxlength = 140, 'auto-focus': autoFocus, focus, 'confirm-type': confirmType = 'done', 'confirm-hold': confirmHold = false, cursor, 'cursor-color': cursorColor, 'selection-start': selectionStart = -1, 'selection-end': selectionEnd = -1, 'enable-var': enableVar, 'external-var-context': externalVarContext, 'parent-font-size': parentFontSize, 'parent-width': parentWidth, 'parent-height': parentHeight, bindinput, bindfocus, bindblur, bindconfirm, bindselectionchange,
56
58
  // private
57
- multiline, 'auto-height': autoHeight, bindlinechange, } = props;
58
- const { nodeRef } = useNodesRef(props, ref);
59
+ multiline, 'auto-height': autoHeight, bindlinechange } = props;
60
+ const formContext = useContext(FormContext);
61
+ let formValuesMap;
62
+ if (formContext) {
63
+ formValuesMap = formContext.formValuesMap;
64
+ }
59
65
  const keyboardType = keyboardTypeMap[type];
60
66
  const defaultValue = type === 'number' && value ? value + '' : value;
61
67
  const placeholderTextColor = parseInlineStyle(placeholderStyle)?.color;
62
68
  const textAlignVertical = multiline ? 'top' : 'auto';
63
- const layoutRef = useRef({});
64
69
  const tmpValue = useRef();
65
70
  const cursorIndex = useRef(0);
66
71
  const lineCount = useRef(0);
67
- const [inputValue, setInputValue] = useState();
72
+ const [inputValue, setInputValue] = useState(defaultValue);
68
73
  const [contentHeight, setContentHeight] = useState(0);
74
+ const styleObj = {
75
+ padding: 0,
76
+ ...style,
77
+ ...multiline && autoHeight && {
78
+ height: Math.max(style?.minHeight || 35, contentHeight)
79
+ }
80
+ };
81
+ const { hasSelfPercent, normalStyle, setWidth, setHeight } = useTransformStyle(styleObj, { enableVar, externalVarContext, parentFontSize, parentWidth, parentHeight });
82
+ const { nodeRef } = useNodesRef(props, ref);
83
+ const { layoutRef, layoutStyle, layoutProps } = useLayout({ props, hasSelfPercent, setWidth, setHeight, nodeRef });
84
+ useEffect(() => {
85
+ if (inputValue !== value) {
86
+ setInputValue(value);
87
+ }
88
+ }, [value]);
69
89
  const selection = useMemo(() => {
70
90
  if (selectionStart >= 0 && selectionEnd >= 0) {
71
91
  return { start: selectionStart, end: selectionEnd };
@@ -77,7 +97,7 @@ const Input = forwardRef((props, ref) => {
77
97
  const onTextInput = ({ nativeEvent }) => {
78
98
  if (!bindinput && !bindblur)
79
99
  return;
80
- const { range: { start, end }, text, } = nativeEvent;
100
+ const { range: { start, end }, text } = nativeEvent;
81
101
  cursorIndex.current = start < end ? start : start + text.length;
82
102
  };
83
103
  const onChange = (evt) => {
@@ -87,7 +107,7 @@ const Input = forwardRef((props, ref) => {
87
107
  const result = bindinput(getCustomEvent('input', evt, {
88
108
  detail: {
89
109
  value: evt.nativeEvent.text,
90
- cursor: cursorIndex.current,
110
+ cursor: cursorIndex.current
91
111
  },
92
112
  layoutRef
93
113
  }, props));
@@ -95,15 +115,15 @@ const Input = forwardRef((props, ref) => {
95
115
  tmpValue.current = result;
96
116
  setInputValue(result);
97
117
  }
98
- else if (inputValue) {
99
- setInputValue(undefined);
118
+ else {
119
+ setInputValue(tmpValue.current);
100
120
  }
101
121
  };
102
122
  const onInputFocus = (evt) => {
103
123
  bindfocus &&
104
124
  bindfocus(getCustomEvent('focus', evt, {
105
125
  detail: {
106
- value: tmpValue.current || '',
126
+ value: tmpValue.current || ''
107
127
  },
108
128
  layoutRef
109
129
  }, props));
@@ -113,7 +133,7 @@ const Input = forwardRef((props, ref) => {
113
133
  bindblur(getCustomEvent('blur', evt, {
114
134
  detail: {
115
135
  value: tmpValue.current || '',
116
- cursor: cursorIndex.current,
136
+ cursor: cursorIndex.current
117
137
  },
118
138
  layoutRef
119
139
  }, props));
@@ -123,7 +143,7 @@ const Input = forwardRef((props, ref) => {
123
143
  evt.nativeEvent.key === 'Enter' &&
124
144
  bindconfirm(getCustomEvent('confirm', evt, {
125
145
  detail: {
126
- value: tmpValue.current || '',
146
+ value: tmpValue.current || ''
127
147
  },
128
148
  layoutRef
129
149
  }, props));
@@ -133,7 +153,7 @@ const Input = forwardRef((props, ref) => {
133
153
  multiline &&
134
154
  bindconfirm(getCustomEvent('confirm', evt, {
135
155
  detail: {
136
- value: tmpValue.current || '',
156
+ value: tmpValue.current || ''
137
157
  },
138
158
  layoutRef
139
159
  }, props));
@@ -150,7 +170,7 @@ const Input = forwardRef((props, ref) => {
150
170
  detail: {
151
171
  height,
152
172
  lineHeight,
153
- lineCount: lineCount.current,
173
+ lineCount: lineCount.current
154
174
  },
155
175
  layoutRef
156
176
  }, props));
@@ -162,16 +182,25 @@ const Input = forwardRef((props, ref) => {
162
182
  bindselectionchange(getCustomEvent('selectionchange', evt, {
163
183
  detail: {
164
184
  selectionStart: evt.nativeEvent.selection.start,
165
- selectionEnd: evt.nativeEvent.selection.end,
185
+ selectionEnd: evt.nativeEvent.selection.end
166
186
  },
167
187
  layoutRef
168
188
  }, props));
169
189
  };
170
- const onLayout = () => {
171
- nodeRef.current?.measure((x, y, width, height, offsetLeft, offsetTop) => {
172
- layoutRef.current = { x, y, width, height, offsetLeft, offsetTop };
173
- });
190
+ const resetValue = () => {
191
+ setInputValue('');
192
+ };
193
+ const getValue = () => {
194
+ return inputValue;
174
195
  };
196
+ if (formValuesMap) {
197
+ if (!props.name) {
198
+ warn('If a form component is used, the name attribute is required.');
199
+ }
200
+ else {
201
+ formValuesMap.set(props.name, { getValue, resetValue });
202
+ }
203
+ }
175
204
  useUpdateEffect(() => {
176
205
  if (!nodeRef?.current) {
177
206
  return;
@@ -180,24 +209,21 @@ const Input = forwardRef((props, ref) => {
180
209
  ? nodeRef.current?.focus()
181
210
  : nodeRef.current?.blur();
182
211
  }, [focus]);
212
+ const composeStyle = { ...normalStyle, ...layoutStyle };
183
213
  const innerProps = useInnerProps(props, {
184
214
  ref: nodeRef,
185
- ...(enableOffset ? { onLayout } : {}),
186
- }, [
187
- 'enable-offset'
188
- ], {
215
+ style: {
216
+ padding: 0,
217
+ ...composeStyle,
218
+ ...multiline && autoHeight && {
219
+ height: Math.max(composeStyle?.minHeight || 35, contentHeight)
220
+ }
221
+ },
222
+ ...layoutProps
223
+ }, [], {
189
224
  layoutRef
190
225
  });
191
- return (<TextInput {...innerProps} keyboardType={keyboardType} secureTextEntry={!!password} defaultValue={defaultValue} value={inputValue} maxLength={maxlength === -1 ? undefined : maxlength} editable={!disabled} autoFocus={!!autoFocus || !!focus} returnKeyType={confirmType} selection={selection} selectionColor={cursorColor} blurOnSubmit={!multiline && !confirmHold} underlineColorAndroid="rgba(0,0,0,0)" textAlignVertical={textAlignVertical} placeholderTextColor={placeholderTextColor} multiline={!!multiline} onTextInput={onTextInput} onChange={onChange} onFocus={onInputFocus} onBlur={onInputBlur} onKeyPress={onKeyPress} onSubmitEditing={onSubmitEditing} onContentSizeChange={onContentSizeChange} onSelectionChange={onSelectionChange} style={[
192
- {
193
- padding: 0,
194
- },
195
- style,
196
- multiline &&
197
- autoHeight && {
198
- height: Math.max(style?.minHeight || 35, contentHeight),
199
- },
200
- ]}/>);
226
+ return (<TextInput {...innerProps} keyboardType={keyboardType} secureTextEntry={!!password} defaultValue={defaultValue} value={inputValue} maxLength={maxlength === -1 ? undefined : maxlength} editable={!disabled} autoFocus={!!autoFocus || !!focus} returnKeyType={confirmType} selection={selection} selectionColor={cursorColor} blurOnSubmit={!multiline && !confirmHold} underlineColorAndroid="rgba(0,0,0,0)" textAlignVertical={textAlignVertical} placeholderTextColor={placeholderTextColor} multiline={!!multiline} onTextInput={onTextInput} onChange={onChange} onFocus={onInputFocus} onBlur={onInputBlur} onKeyPress={onKeyPress} onSubmitEditing={onSubmitEditing} onContentSizeChange={onContentSizeChange} onSelectionChange={onSelectionChange}/>);
201
227
  });
202
228
  Input.displayName = 'mpx-input';
203
229
  export default Input;
@@ -0,0 +1,55 @@
1
+ /**
2
+ * ✘ for
3
+ */
4
+ import { useRef, forwardRef } from 'react';
5
+ import { View } from 'react-native';
6
+ import { noop, warn } from '@mpxjs/utils';
7
+ import useInnerProps, { getCustomEvent } from './getInnerListeners';
8
+ import useNodesRef from './useNodesRef';
9
+ import { splitProps, splitStyle, useLayout, useTransformStyle, wrapChildren } from './utils';
10
+ import { LabelContext } from './context';
11
+ const Label = forwardRef((labelProps, ref) => {
12
+ const { textProps, innerProps: props = {} } = splitProps(labelProps);
13
+ const { style = {}, 'enable-var': enableVar, 'external-var-context': externalVarContext, 'parent-font-size': parentFontSize, 'parent-width': parentWidth, 'parent-height': parentHeight, bindtap } = props;
14
+ const defaultStyle = {
15
+ flexDirection: 'row'
16
+ };
17
+ const styleObj = {
18
+ ...defaultStyle,
19
+ ...style
20
+ };
21
+ const { hasSelfPercent, normalStyle, hasVarDec, varContextRef, setWidth, setHeight } = useTransformStyle(styleObj, { enableVar, externalVarContext, parentFontSize, parentWidth, parentHeight });
22
+ const { nodeRef } = useNodesRef(props, ref, { defaultStyle });
23
+ const { layoutRef, layoutStyle, layoutProps } = useLayout({ props, hasSelfPercent, setWidth, setHeight, nodeRef });
24
+ const { textStyle, backgroundStyle, innerStyle } = splitStyle(normalStyle);
25
+ if (backgroundStyle) {
26
+ warn('Label does not support background image-related styles!');
27
+ }
28
+ const contextRef = useRef({
29
+ triggerChange: noop
30
+ });
31
+ const onTap = (evt) => {
32
+ bindtap && bindtap(getCustomEvent('tap', evt, { layoutRef }, props));
33
+ contextRef.current.triggerChange?.(evt);
34
+ };
35
+ const innerProps = useInnerProps(props, {
36
+ ref: nodeRef,
37
+ style: { ...innerStyle, ...layoutStyle },
38
+ ...layoutProps,
39
+ bindtap: onTap
40
+ }, [], {
41
+ layoutRef
42
+ });
43
+ return <View {...innerProps}>
44
+ <LabelContext.Provider value={contextRef}>
45
+ {wrapChildren(props, {
46
+ hasVarDec,
47
+ varContext: varContextRef.current,
48
+ textStyle,
49
+ textProps
50
+ })}
51
+ </LabelContext.Provider>
52
+ </View>;
53
+ });
54
+ Label.displayName = 'mpx-label';
55
+ export default Label;
@@ -0,0 +1,41 @@
1
+ /**
2
+ * ✘ scale-area
3
+ */
4
+ import { View } from 'react-native';
5
+ import { useState, useEffect, forwardRef } from 'react';
6
+ import useNodesRef from './useNodesRef';
7
+ import useInnerProps from './getInnerListeners';
8
+ import { MovableAreaContext } from './context';
9
+ import { useTransformStyle, wrapChildren, useLayout } from './utils';
10
+ const _MovableArea = forwardRef((props, ref) => {
11
+ const { style = {}, width = 10, height = 10, 'enable-var': enableVar, 'external-var-context': externalVarContext, 'parent-font-size': parentFontSize, 'parent-width': parentWidth, 'parent-height': parentHeight } = props;
12
+ const [areaWidth, setAreaWidth] = useState(0);
13
+ const [areaHeight, setAreaHeight] = useState(0);
14
+ useEffect(() => {
15
+ setAreaWidth(width);
16
+ setAreaHeight(height);
17
+ }, [width, height]);
18
+ const { hasSelfPercent, normalStyle, hasVarDec, varContextRef, setWidth, setHeight } = useTransformStyle(style, { enableVar, externalVarContext, parentFontSize, parentWidth, parentHeight });
19
+ const { nodeRef: movableViewRef } = useNodesRef(props, ref);
20
+ const onLayout = (e) => {
21
+ const { width = 10, height = 10 } = e.nativeEvent.layout;
22
+ setAreaWidth(width);
23
+ setAreaHeight(height);
24
+ };
25
+ const { layoutRef, layoutStyle, layoutProps } = useLayout({ props, hasSelfPercent, setWidth, setHeight, nodeRef: movableViewRef, onLayout });
26
+ const innerProps = useInnerProps(props, {
27
+ style: { height: areaHeight, width: areaWidth, overflow: 'hidden', ...normalStyle, ...layoutStyle },
28
+ ref: movableViewRef,
29
+ ...layoutProps
30
+ }, [], { layoutRef });
31
+ return (<MovableAreaContext.Provider value={{ height: areaHeight, width: areaWidth }}>
32
+ <View {...innerProps}>
33
+ {wrapChildren(props, {
34
+ hasVarDec,
35
+ varContext: varContextRef.current
36
+ })}
37
+ </View>
38
+ </MovableAreaContext.Provider>);
39
+ });
40
+ _MovableArea.displayName = 'mpx-movable-area';
41
+ export default _MovableArea;