@mpxjs/webpack-plugin 2.9.62 → 2.9.65
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.
- package/lib/config.js +38 -10
- package/lib/index.js +1 -3
- package/lib/platform/style/wx/index.js +115 -66
- package/lib/platform/template/wx/index.js +12 -8
- package/lib/react/processStyles.js +1 -0
- package/lib/react/processTemplate.js +2 -3
- package/lib/react/style-helper.js +9 -7
- package/lib/runtime/components/react/context.ts +9 -7
- package/lib/runtime/components/react/dist/context.js +1 -0
- package/lib/runtime/components/react/dist/getInnerListeners.js +12 -1
- package/lib/runtime/components/react/dist/mpx-button.jsx +53 -74
- package/lib/runtime/components/react/dist/mpx-checkbox-group.jsx +20 -18
- package/lib/runtime/components/react/dist/mpx-checkbox.jsx +30 -42
- package/lib/runtime/components/react/dist/mpx-form.jsx +18 -15
- package/lib/runtime/components/react/dist/mpx-icon.jsx +15 -17
- package/lib/runtime/components/react/dist/mpx-image/index.jsx +36 -34
- package/lib/runtime/components/react/dist/mpx-image/svg.jsx +3 -1
- package/lib/runtime/components/react/dist/mpx-input.jsx +36 -31
- package/lib/runtime/components/react/dist/mpx-label.jsx +30 -37
- package/lib/runtime/components/react/dist/mpx-movable-area.jsx +15 -19
- package/lib/runtime/components/react/dist/mpx-movable-view.jsx +10 -9
- package/lib/runtime/components/react/dist/mpx-picker/date.jsx +2 -1
- package/lib/runtime/components/react/dist/mpx-picker/index.jsx +11 -10
- package/lib/runtime/components/react/dist/mpx-picker/multiSelector.jsx +9 -5
- package/lib/runtime/components/react/dist/mpx-picker/region.jsx +13 -8
- package/lib/runtime/components/react/dist/mpx-picker/selector.jsx +3 -2
- package/lib/runtime/components/react/dist/mpx-picker/time.jsx +22 -20
- package/lib/runtime/components/react/dist/mpx-picker-view-column.jsx +103 -10
- package/lib/runtime/components/react/dist/mpx-picker-view.jsx +149 -54
- package/lib/runtime/components/react/dist/mpx-radio-group.jsx +20 -18
- package/lib/runtime/components/react/dist/mpx-radio.jsx +29 -43
- package/lib/runtime/components/react/dist/mpx-root-portal.jsx +8 -4
- package/lib/runtime/components/react/dist/mpx-scroll-view.jsx +36 -27
- package/lib/runtime/components/react/dist/mpx-swiper/carouse.jsx +141 -75
- package/lib/runtime/components/react/dist/mpx-swiper/index.jsx +16 -7
- package/lib/runtime/components/react/dist/mpx-swiper-item.jsx +20 -11
- package/lib/runtime/components/react/dist/mpx-switch.jsx +18 -14
- package/lib/runtime/components/react/dist/mpx-text.jsx +20 -35
- package/lib/runtime/components/react/dist/mpx-textarea.jsx +1 -1
- package/lib/runtime/components/react/dist/mpx-view.jsx +296 -210
- package/lib/runtime/components/react/dist/mpx-web-view.jsx +11 -7
- package/lib/runtime/components/react/dist/parser.js +218 -0
- package/lib/runtime/components/react/dist/useNodesRef.js +1 -5
- package/lib/runtime/components/react/dist/utils.jsx +445 -0
- package/lib/runtime/components/react/getInnerListeners.ts +18 -8
- package/lib/runtime/components/react/mpx-button.tsx +83 -91
- package/lib/runtime/components/react/mpx-checkbox-group.tsx +50 -43
- package/lib/runtime/components/react/mpx-checkbox.tsx +56 -64
- package/lib/runtime/components/react/mpx-form.tsx +51 -22
- package/lib/runtime/components/react/mpx-icon.tsx +31 -27
- package/lib/runtime/components/react/mpx-image/index.tsx +54 -47
- package/lib/runtime/components/react/mpx-image/svg.tsx +5 -3
- package/lib/runtime/components/react/mpx-input.tsx +59 -38
- package/lib/runtime/components/react/mpx-label.tsx +55 -59
- package/lib/runtime/components/react/mpx-movable-area.tsx +40 -25
- package/lib/runtime/components/react/mpx-movable-view.tsx +29 -29
- package/lib/runtime/components/react/mpx-navigator.tsx +2 -2
- package/lib/runtime/components/react/mpx-picker/date.tsx +4 -4
- package/lib/runtime/components/react/mpx-picker/index.tsx +12 -11
- package/lib/runtime/components/react/mpx-picker/multiSelector.tsx +17 -13
- package/lib/runtime/components/react/mpx-picker/region.tsx +23 -19
- package/lib/runtime/components/react/mpx-picker/selector.tsx +7 -7
- package/lib/runtime/components/react/mpx-picker/time.tsx +29 -31
- package/lib/runtime/components/react/mpx-picker/type.ts +1 -1
- package/lib/runtime/components/react/mpx-picker-view-column.tsx +149 -20
- package/lib/runtime/components/react/mpx-picker-view.tsx +180 -63
- package/lib/runtime/components/react/mpx-radio-group.tsx +51 -47
- package/lib/runtime/components/react/mpx-radio.tsx +57 -72
- package/lib/runtime/components/react/mpx-root-portal.tsx +10 -8
- package/lib/runtime/components/react/mpx-scroll-view.tsx +136 -104
- package/lib/runtime/components/react/mpx-swiper/carouse.tsx +175 -96
- package/lib/runtime/components/react/mpx-swiper/index.tsx +21 -9
- package/lib/runtime/components/react/mpx-swiper/type.ts +16 -5
- package/lib/runtime/components/react/mpx-swiper-item.tsx +48 -14
- package/lib/runtime/components/react/mpx-switch.tsx +46 -24
- package/lib/runtime/components/react/mpx-text.tsx +38 -45
- package/lib/runtime/components/react/mpx-textarea.tsx +1 -1
- package/lib/runtime/components/react/mpx-view.tsx +401 -241
- package/lib/runtime/components/react/mpx-web-view.tsx +22 -22
- package/lib/runtime/components/react/parser.ts +245 -0
- package/lib/runtime/components/react/types/common.ts +4 -4
- package/lib/runtime/components/react/types/global.d.ts +24 -2
- package/lib/runtime/components/react/useNodesRef.ts +1 -7
- package/lib/runtime/components/react/utils.tsx +524 -0
- package/lib/runtime/components/web/mpx-scroll-view.vue +25 -5
- package/lib/style-compiler/index.js +5 -4
- package/lib/template-compiler/compiler.js +133 -161
- package/lib/template-compiler/gen-node-react.js +1 -3
- package/lib/utils/const.js +2 -1
- package/lib/web/processStyles.js +2 -1
- package/lib/web/processTemplate.js +2 -3
- package/lib/wxml/loader.js +1 -1
- package/package.json +7 -4
- package/lib/runtime/components/react/dist/utils.js +0 -148
- package/lib/runtime/components/react/utils.ts +0 -170
|
@@ -3,10 +3,11 @@
|
|
|
3
3
|
* ✔ size
|
|
4
4
|
* ✔ color
|
|
5
5
|
*/
|
|
6
|
-
import {
|
|
6
|
+
import { forwardRef, useRef } from 'react';
|
|
7
7
|
import { Image } from 'react-native';
|
|
8
8
|
import useInnerProps from './getInnerListeners';
|
|
9
9
|
import useNodesRef from './useNodesRef';
|
|
10
|
+
import { useLayout, useTransformStyle } from './utils';
|
|
10
11
|
const IconTypeMap = new Map([
|
|
11
12
|
['success', ''],
|
|
12
13
|
['success_no_circle', ''],
|
|
@@ -19,30 +20,27 @@ const IconTypeMap = new Map([
|
|
|
19
20
|
['clear', '']
|
|
20
21
|
]);
|
|
21
22
|
const Icon = forwardRef((props, ref) => {
|
|
22
|
-
const { type, size = 23, color, style = {}, 'enable-
|
|
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;
|
|
23
24
|
const uri = IconTypeMap.get(type);
|
|
24
25
|
const defaultStyle = { width: ~~size, height: ~~size };
|
|
25
|
-
const
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
});
|
|
29
|
-
const onLayout = () => {
|
|
30
|
-
nodeRef.current?.measure((x, y, width, height, offsetLeft, offsetTop) => {
|
|
31
|
-
layoutRef.current = { x, y, width, height, offsetLeft, offsetTop };
|
|
32
|
-
});
|
|
26
|
+
const styleObj = {
|
|
27
|
+
...defaultStyle,
|
|
28
|
+
...style
|
|
33
29
|
};
|
|
30
|
+
const { hasSelfPercent, normalStyle, setWidth, setHeight } = useTransformStyle(styleObj, { enableVar, externalVarContext, parentFontSize, parentWidth, parentHeight });
|
|
31
|
+
const nodeRef = useRef(null);
|
|
32
|
+
useNodesRef(props, ref, nodeRef, { defaultStyle });
|
|
33
|
+
const { layoutRef, layoutStyle, layoutProps } = useLayout({ props, hasSelfPercent, setWidth, setHeight, nodeRef });
|
|
34
34
|
const innerProps = useInnerProps(props, {
|
|
35
35
|
ref: nodeRef,
|
|
36
36
|
style: {
|
|
37
|
-
...
|
|
38
|
-
|
|
39
|
-
|
|
37
|
+
...normalStyle,
|
|
38
|
+
...layoutStyle,
|
|
39
|
+
tintColor: color
|
|
40
40
|
},
|
|
41
41
|
source: { uri },
|
|
42
|
-
...
|
|
43
|
-
}, [
|
|
44
|
-
'enable-offset'
|
|
45
|
-
], {
|
|
42
|
+
...layoutProps
|
|
43
|
+
}, [], {
|
|
46
44
|
layoutRef
|
|
47
45
|
});
|
|
48
46
|
return <Image {...innerProps}/>;
|
|
@@ -11,9 +11,10 @@
|
|
|
11
11
|
* ✔ DEFAULT_SIZE
|
|
12
12
|
*/
|
|
13
13
|
import { useEffect, useMemo, useState, useRef, forwardRef } from 'react';
|
|
14
|
-
import { Image as RNImage, View, StyleSheet
|
|
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,27 @@ 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-
|
|
60
|
-
const
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
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
|
+
};
|
|
70
|
+
const nodeRef = useRef(null);
|
|
71
|
+
useNodesRef(props, ref, nodeRef, {
|
|
72
|
+
defaultStyle
|
|
66
73
|
});
|
|
67
|
-
const
|
|
74
|
+
const onLayout = ({ nativeEvent: { layout: { width, height } } }) => {
|
|
75
|
+
setViewWidth(width);
|
|
76
|
+
setViewHeight(height);
|
|
77
|
+
};
|
|
78
|
+
const { normalStyle, hasSelfPercent, setWidth, setHeight } = useTransformStyle(styleObj, { enableVar, externalVarContext, parentFontSize, parentWidth, parentHeight });
|
|
79
|
+
const { layoutRef, layoutStyle, layoutProps } = useLayout({ props, hasSelfPercent, setWidth, setHeight, nodeRef, onLayout });
|
|
80
|
+
const { width, height } = normalStyle;
|
|
68
81
|
const preSrc = useRef();
|
|
69
82
|
const resizeMode = ModeMap.get(mode) || 'stretch';
|
|
70
83
|
const isWidthFixMode = mode === 'widthFix';
|
|
@@ -138,15 +151,6 @@ const Image = forwardRef((props, ref) => {
|
|
|
138
151
|
layoutRef
|
|
139
152
|
}, props));
|
|
140
153
|
};
|
|
141
|
-
const onViewLayout = ({ nativeEvent: { layout: { width, height }, }, }) => {
|
|
142
|
-
setViewWidth(width);
|
|
143
|
-
setViewHeight(height);
|
|
144
|
-
};
|
|
145
|
-
const onImageLayout = () => {
|
|
146
|
-
nodeRef.current?.measure((x, y, width, height, offsetLeft, offsetTop) => {
|
|
147
|
-
layoutRef.current = { x, y, width, height, offsetLeft, offsetTop };
|
|
148
|
-
});
|
|
149
|
-
};
|
|
150
154
|
useEffect(() => {
|
|
151
155
|
if (!isWidthFixMode && !isHeightFixMode && !isCropMode) {
|
|
152
156
|
setLoaded(true);
|
|
@@ -181,10 +185,14 @@ const Image = forwardRef((props, ref) => {
|
|
|
181
185
|
}, [isWidthFixMode, isHeightFixMode, isCropMode, src]);
|
|
182
186
|
const innerProps = useInnerProps(props, {
|
|
183
187
|
ref: nodeRef,
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
+
style: {
|
|
189
|
+
...normalStyle,
|
|
190
|
+
...layoutStyle,
|
|
191
|
+
...(isHeightFixMode && { width: fixedWidth }),
|
|
192
|
+
...(isWidthFixMode && { height: fixedHeight })
|
|
193
|
+
},
|
|
194
|
+
...layoutProps
|
|
195
|
+
}, [], {
|
|
188
196
|
layoutRef
|
|
189
197
|
});
|
|
190
198
|
// if (typeof src === 'string' && REMOTE_SVG_REGEXP.test(src)) {
|
|
@@ -205,17 +213,11 @@ const Image = forwardRef((props, ref) => {
|
|
|
205
213
|
// </Suspense>
|
|
206
214
|
// )
|
|
207
215
|
// }
|
|
208
|
-
return (<View
|
|
209
|
-
|
|
210
|
-
...style,
|
|
211
|
-
...(isHeightFixMode && { width: fixedWidth }),
|
|
212
|
-
...(isWidthFixMode && { height: fixedHeight }),
|
|
213
|
-
overflow: 'hidden',
|
|
214
|
-
}} onLayout={onViewLayout}>
|
|
215
|
-
{loaded && <RNImage {...innerProps} source={source} resizeMode={resizeMode} onLoad={onImageLoad} onError={onImageError} style={{
|
|
216
|
+
return (<View {...innerProps}>
|
|
217
|
+
{loaded && <RNImage source={source} resizeMode={resizeMode} onLoad={onImageLoad} onError={onImageError} style={{
|
|
216
218
|
...StyleSheet.absoluteFillObject,
|
|
217
|
-
width:
|
|
218
|
-
height:
|
|
219
|
+
width: isCropMode ? imageWidth : '100%',
|
|
220
|
+
height: isCropMode ? imageHeight : '100%',
|
|
219
221
|
...(isCropMode && cropModeStyle)
|
|
220
222
|
}}/>}
|
|
221
223
|
</View>);
|
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
import { SvgCssUri, WithLocalSvg } from 'react-native-svg/css';
|
|
2
2
|
const Svg = ({ local = false, src, style, width, height }) => {
|
|
3
|
-
return local
|
|
3
|
+
return local
|
|
4
|
+
? (<WithLocalSvg style={style} asset={src} width={width} height={height}/>)
|
|
5
|
+
: (<SvgCssUri style={style} uri={src} width={width} height={height}/>);
|
|
4
6
|
};
|
|
5
7
|
export default Svg;
|
|
@@ -39,7 +39,8 @@
|
|
|
39
39
|
*/
|
|
40
40
|
import { forwardRef, useMemo, useRef, useState, useContext, useEffect } from 'react';
|
|
41
41
|
import { Platform, TextInput } from 'react-native';
|
|
42
|
-
import {
|
|
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';
|
|
45
46
|
import { FormContext } from './context';
|
|
@@ -49,29 +50,38 @@ const keyboardTypeMap = {
|
|
|
49
50
|
idcard: 'default',
|
|
50
51
|
digit: Platform.select({
|
|
51
52
|
ios: 'decimal-pad',
|
|
52
|
-
android: 'numeric'
|
|
53
|
-
}) || ''
|
|
53
|
+
android: 'numeric'
|
|
54
|
+
}) || ''
|
|
54
55
|
};
|
|
55
56
|
const Input = forwardRef((props, ref) => {
|
|
56
|
-
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-
|
|
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,
|
|
57
58
|
// private
|
|
58
|
-
multiline, 'auto-height': autoHeight, bindlinechange
|
|
59
|
+
multiline, 'auto-height': autoHeight, bindlinechange } = props;
|
|
59
60
|
const formContext = useContext(FormContext);
|
|
60
61
|
let formValuesMap;
|
|
61
62
|
if (formContext) {
|
|
62
63
|
formValuesMap = formContext.formValuesMap;
|
|
63
64
|
}
|
|
64
|
-
const { nodeRef } = useNodesRef(props, ref);
|
|
65
65
|
const keyboardType = keyboardTypeMap[type];
|
|
66
66
|
const defaultValue = type === 'number' && value ? value + '' : value;
|
|
67
67
|
const placeholderTextColor = parseInlineStyle(placeholderStyle)?.color;
|
|
68
68
|
const textAlignVertical = multiline ? 'top' : 'auto';
|
|
69
|
-
const layoutRef = useRef({});
|
|
70
69
|
const tmpValue = useRef();
|
|
71
70
|
const cursorIndex = useRef(0);
|
|
72
71
|
const lineCount = useRef(0);
|
|
73
72
|
const [inputValue, setInputValue] = useState(defaultValue);
|
|
74
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 = useRef(null);
|
|
83
|
+
useNodesRef(props, ref, nodeRef);
|
|
84
|
+
const { layoutRef, layoutStyle, layoutProps } = useLayout({ props, hasSelfPercent, setWidth, setHeight, nodeRef });
|
|
75
85
|
useEffect(() => {
|
|
76
86
|
if (inputValue !== value) {
|
|
77
87
|
setInputValue(value);
|
|
@@ -88,7 +98,7 @@ const Input = forwardRef((props, ref) => {
|
|
|
88
98
|
const onTextInput = ({ nativeEvent }) => {
|
|
89
99
|
if (!bindinput && !bindblur)
|
|
90
100
|
return;
|
|
91
|
-
const { range: { start, end }, text
|
|
101
|
+
const { range: { start, end }, text } = nativeEvent;
|
|
92
102
|
cursorIndex.current = start < end ? start : start + text.length;
|
|
93
103
|
};
|
|
94
104
|
const onChange = (evt) => {
|
|
@@ -98,7 +108,7 @@ const Input = forwardRef((props, ref) => {
|
|
|
98
108
|
const result = bindinput(getCustomEvent('input', evt, {
|
|
99
109
|
detail: {
|
|
100
110
|
value: evt.nativeEvent.text,
|
|
101
|
-
cursor: cursorIndex.current
|
|
111
|
+
cursor: cursorIndex.current
|
|
102
112
|
},
|
|
103
113
|
layoutRef
|
|
104
114
|
}, props));
|
|
@@ -114,7 +124,7 @@ const Input = forwardRef((props, ref) => {
|
|
|
114
124
|
bindfocus &&
|
|
115
125
|
bindfocus(getCustomEvent('focus', evt, {
|
|
116
126
|
detail: {
|
|
117
|
-
value: tmpValue.current || ''
|
|
127
|
+
value: tmpValue.current || ''
|
|
118
128
|
},
|
|
119
129
|
layoutRef
|
|
120
130
|
}, props));
|
|
@@ -124,7 +134,7 @@ const Input = forwardRef((props, ref) => {
|
|
|
124
134
|
bindblur(getCustomEvent('blur', evt, {
|
|
125
135
|
detail: {
|
|
126
136
|
value: tmpValue.current || '',
|
|
127
|
-
cursor: cursorIndex.current
|
|
137
|
+
cursor: cursorIndex.current
|
|
128
138
|
},
|
|
129
139
|
layoutRef
|
|
130
140
|
}, props));
|
|
@@ -134,7 +144,7 @@ const Input = forwardRef((props, ref) => {
|
|
|
134
144
|
evt.nativeEvent.key === 'Enter' &&
|
|
135
145
|
bindconfirm(getCustomEvent('confirm', evt, {
|
|
136
146
|
detail: {
|
|
137
|
-
value: tmpValue.current || ''
|
|
147
|
+
value: tmpValue.current || ''
|
|
138
148
|
},
|
|
139
149
|
layoutRef
|
|
140
150
|
}, props));
|
|
@@ -144,7 +154,7 @@ const Input = forwardRef((props, ref) => {
|
|
|
144
154
|
multiline &&
|
|
145
155
|
bindconfirm(getCustomEvent('confirm', evt, {
|
|
146
156
|
detail: {
|
|
147
|
-
value: tmpValue.current || ''
|
|
157
|
+
value: tmpValue.current || ''
|
|
148
158
|
},
|
|
149
159
|
layoutRef
|
|
150
160
|
}, props));
|
|
@@ -161,7 +171,7 @@ const Input = forwardRef((props, ref) => {
|
|
|
161
171
|
detail: {
|
|
162
172
|
height,
|
|
163
173
|
lineHeight,
|
|
164
|
-
lineCount: lineCount.current
|
|
174
|
+
lineCount: lineCount.current
|
|
165
175
|
},
|
|
166
176
|
layoutRef
|
|
167
177
|
}, props));
|
|
@@ -173,16 +183,11 @@ const Input = forwardRef((props, ref) => {
|
|
|
173
183
|
bindselectionchange(getCustomEvent('selectionchange', evt, {
|
|
174
184
|
detail: {
|
|
175
185
|
selectionStart: evt.nativeEvent.selection.start,
|
|
176
|
-
selectionEnd: evt.nativeEvent.selection.end
|
|
186
|
+
selectionEnd: evt.nativeEvent.selection.end
|
|
177
187
|
},
|
|
178
188
|
layoutRef
|
|
179
189
|
}, props));
|
|
180
190
|
};
|
|
181
|
-
const onLayout = () => {
|
|
182
|
-
nodeRef.current?.measure((x, y, width, height, offsetLeft, offsetTop) => {
|
|
183
|
-
layoutRef.current = { x, y, width, height, offsetLeft, offsetTop };
|
|
184
|
-
});
|
|
185
|
-
};
|
|
186
191
|
const resetValue = () => {
|
|
187
192
|
setInputValue('');
|
|
188
193
|
};
|
|
@@ -191,7 +196,7 @@ const Input = forwardRef((props, ref) => {
|
|
|
191
196
|
};
|
|
192
197
|
if (formValuesMap) {
|
|
193
198
|
if (!props.name) {
|
|
194
|
-
|
|
199
|
+
warn('If a form component is used, the name attribute is required.');
|
|
195
200
|
}
|
|
196
201
|
else {
|
|
197
202
|
formValuesMap.set(props.name, { getValue, resetValue });
|
|
@@ -205,21 +210,21 @@ const Input = forwardRef((props, ref) => {
|
|
|
205
210
|
? nodeRef.current?.focus()
|
|
206
211
|
: nodeRef.current?.blur();
|
|
207
212
|
}, [focus]);
|
|
213
|
+
const composeStyle = { ...normalStyle, ...layoutStyle };
|
|
208
214
|
const innerProps = useInnerProps(props, {
|
|
209
215
|
ref: nodeRef,
|
|
210
|
-
|
|
211
|
-
}, [
|
|
212
|
-
'enable-offset'
|
|
213
|
-
], {
|
|
214
|
-
layoutRef
|
|
215
|
-
});
|
|
216
|
-
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={{
|
|
216
|
+
style: {
|
|
217
217
|
padding: 0,
|
|
218
|
-
...
|
|
218
|
+
...composeStyle,
|
|
219
219
|
...multiline && autoHeight && {
|
|
220
|
-
height: Math.max(
|
|
220
|
+
height: Math.max(composeStyle?.minHeight || 35, contentHeight)
|
|
221
221
|
}
|
|
222
|
-
}
|
|
222
|
+
},
|
|
223
|
+
...layoutProps
|
|
224
|
+
}, [], {
|
|
225
|
+
layoutRef
|
|
226
|
+
});
|
|
227
|
+
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}/>);
|
|
223
228
|
});
|
|
224
229
|
Input.displayName = 'mpx-input';
|
|
225
230
|
export default Input;
|
|
@@ -2,60 +2,53 @@
|
|
|
2
2
|
* ✘ for
|
|
3
3
|
*/
|
|
4
4
|
import { useRef, forwardRef } from 'react';
|
|
5
|
-
import { View
|
|
5
|
+
import { View } from 'react-native';
|
|
6
|
+
import { noop, warn } from '@mpxjs/utils';
|
|
6
7
|
import useInnerProps, { getCustomEvent } from './getInnerListeners';
|
|
7
8
|
import useNodesRef from './useNodesRef';
|
|
8
|
-
import {
|
|
9
|
+
import { splitProps, splitStyle, useLayout, useTransformStyle, wrapChildren } from './utils';
|
|
9
10
|
import { LabelContext } from './context';
|
|
10
|
-
const Label = forwardRef((
|
|
11
|
-
const {
|
|
12
|
-
const {
|
|
13
|
-
if (imageStyle) {
|
|
14
|
-
throwReactWarning('[Mpx runtime warn]: Label does not support background image-related styles!');
|
|
15
|
-
}
|
|
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;
|
|
16
14
|
const defaultStyle = {
|
|
17
|
-
flexDirection: 'row'
|
|
15
|
+
flexDirection: 'row'
|
|
16
|
+
};
|
|
17
|
+
const styleObj = {
|
|
18
|
+
...defaultStyle,
|
|
19
|
+
...style
|
|
18
20
|
};
|
|
21
|
+
const { hasSelfPercent, normalStyle, hasVarDec, varContextRef, setWidth, setHeight } = useTransformStyle(styleObj, { enableVar, externalVarContext, parentFontSize, parentWidth, parentHeight });
|
|
22
|
+
const nodeRef = useRef(null);
|
|
23
|
+
useNodesRef(props, ref, nodeRef, { defaultStyle });
|
|
24
|
+
const { layoutRef, layoutStyle, layoutProps } = useLayout({ props, hasSelfPercent, setWidth, setHeight, nodeRef });
|
|
25
|
+
const { textStyle, backgroundStyle, innerStyle } = splitStyle(normalStyle);
|
|
26
|
+
if (backgroundStyle) {
|
|
27
|
+
warn('Label does not support background image-related styles!');
|
|
28
|
+
}
|
|
19
29
|
const contextRef = useRef({
|
|
20
|
-
triggerChange:
|
|
30
|
+
triggerChange: noop
|
|
21
31
|
});
|
|
22
|
-
const layoutRef = useRef({});
|
|
23
|
-
const { nodeRef } = useNodesRef(props, ref, {
|
|
24
|
-
defaultStyle
|
|
25
|
-
});
|
|
26
|
-
const onLayout = () => {
|
|
27
|
-
nodeRef.current?.measure((x, y, width, height, offsetLeft, offsetTop) => {
|
|
28
|
-
layoutRef.current = { x, y, width, height, offsetLeft, offsetTop };
|
|
29
|
-
});
|
|
30
|
-
};
|
|
31
32
|
const onTap = (evt) => {
|
|
32
33
|
bindtap && bindtap(getCustomEvent('tap', evt, { layoutRef }, props));
|
|
33
34
|
contextRef.current.triggerChange?.(evt);
|
|
34
35
|
};
|
|
35
|
-
const wrapChildren = (children, textStyle) => {
|
|
36
|
-
const { textProps } = splitProps(props);
|
|
37
|
-
if (every(children, (child) => isText(child))) {
|
|
38
|
-
if (textStyle || textProps) {
|
|
39
|
-
children = <Text key='labelTextWrap' style={textStyle || {}} {...(textProps || {})}>{children}</Text>;
|
|
40
|
-
}
|
|
41
|
-
}
|
|
42
|
-
else {
|
|
43
|
-
if (textStyle)
|
|
44
|
-
throwReactWarning('[Mpx runtime warn]: Text style will be ignored unless every child of the Label is Text node!');
|
|
45
|
-
}
|
|
46
|
-
return children;
|
|
47
|
-
};
|
|
48
36
|
const innerProps = useInnerProps(props, {
|
|
49
37
|
ref: nodeRef,
|
|
50
|
-
style: { ...
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
}, [
|
|
38
|
+
style: { ...innerStyle, ...layoutStyle },
|
|
39
|
+
...layoutProps,
|
|
40
|
+
bindtap: onTap
|
|
41
|
+
}, [], {
|
|
54
42
|
layoutRef
|
|
55
43
|
});
|
|
56
44
|
return <View {...innerProps}>
|
|
57
45
|
<LabelContext.Provider value={contextRef}>
|
|
58
|
-
{wrapChildren(
|
|
46
|
+
{wrapChildren(props, {
|
|
47
|
+
hasVarDec,
|
|
48
|
+
varContext: varContextRef.current,
|
|
49
|
+
textStyle,
|
|
50
|
+
textProps
|
|
51
|
+
})}
|
|
59
52
|
</LabelContext.Provider>
|
|
60
53
|
</View>;
|
|
61
54
|
});
|
|
@@ -2,43 +2,39 @@
|
|
|
2
2
|
* ✘ scale-area
|
|
3
3
|
*/
|
|
4
4
|
import { View } from 'react-native';
|
|
5
|
-
import { useState, useEffect,
|
|
5
|
+
import { useState, useEffect, forwardRef, useRef } from 'react';
|
|
6
6
|
import useNodesRef from './useNodesRef';
|
|
7
7
|
import useInnerProps from './getInnerListeners';
|
|
8
8
|
import { MovableAreaContext } from './context';
|
|
9
|
+
import { useTransformStyle, wrapChildren, useLayout } from './utils';
|
|
9
10
|
const _MovableArea = forwardRef((props, ref) => {
|
|
10
|
-
const {
|
|
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;
|
|
11
12
|
const [areaWidth, setAreaWidth] = useState(0);
|
|
12
13
|
const [areaHeight, setAreaHeight] = useState(0);
|
|
13
|
-
const layoutRef = useRef({});
|
|
14
14
|
useEffect(() => {
|
|
15
15
|
setAreaWidth(width);
|
|
16
16
|
setAreaHeight(height);
|
|
17
17
|
}, [width, height]);
|
|
18
|
-
const {
|
|
18
|
+
const { hasSelfPercent, normalStyle, hasVarDec, varContextRef, setWidth, setHeight } = useTransformStyle(style, { enableVar, externalVarContext, parentFontSize, parentWidth, parentHeight });
|
|
19
|
+
const movableViewRef = useRef(null);
|
|
20
|
+
useNodesRef(props, ref, movableViewRef);
|
|
19
21
|
const onLayout = (e) => {
|
|
20
22
|
const { width = 10, height = 10 } = e.nativeEvent.layout;
|
|
21
23
|
setAreaWidth(width);
|
|
22
24
|
setAreaHeight(height);
|
|
23
|
-
movableViewRef.current?.measure((x, y, width, height, offsetLeft, offsetTop) => {
|
|
24
|
-
layoutRef.current = { x, y, width, height, offsetLeft, offsetTop };
|
|
25
|
-
});
|
|
26
25
|
};
|
|
26
|
+
const { layoutRef, layoutStyle, layoutProps } = useLayout({ props, hasSelfPercent, setWidth, setHeight, nodeRef: movableViewRef, onLayout });
|
|
27
27
|
const innerProps = useInnerProps(props, {
|
|
28
|
+
style: { height: areaHeight, width: areaWidth, overflow: 'hidden', ...normalStyle, ...layoutStyle },
|
|
28
29
|
ref: movableViewRef,
|
|
29
|
-
|
|
30
|
-
}, [
|
|
31
|
-
'children',
|
|
32
|
-
'style',
|
|
33
|
-
], { layoutRef });
|
|
30
|
+
...layoutProps
|
|
31
|
+
}, [], { layoutRef });
|
|
34
32
|
return (<MovableAreaContext.Provider value={{ height: areaHeight, width: areaWidth }}>
|
|
35
|
-
<View {...innerProps}
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
}}>
|
|
41
|
-
{children}
|
|
33
|
+
<View {...innerProps}>
|
|
34
|
+
{wrapChildren(props, {
|
|
35
|
+
hasVarDec,
|
|
36
|
+
varContext: varContextRef.current
|
|
37
|
+
})}
|
|
42
38
|
</View>
|
|
43
39
|
</MovableAreaContext.Provider>);
|
|
44
40
|
});
|
|
@@ -27,7 +27,7 @@ const styles = StyleSheet.create({
|
|
|
27
27
|
position: 'absolute',
|
|
28
28
|
left: 0,
|
|
29
29
|
top: 0
|
|
30
|
-
}
|
|
30
|
+
}
|
|
31
31
|
});
|
|
32
32
|
const _MovableView = forwardRef((props, ref) => {
|
|
33
33
|
const { children, friction = 7, scale = false, direction = 'none', x = 0, y = 0, style = {}, 'scale-min': scaleMin = 0.1, 'scale-max': scaleMax = 10, 'scale-value': originScaleValue = 1, bindscale, bindchange } = props;
|
|
@@ -41,13 +41,14 @@ const _MovableView = forwardRef((props, ref) => {
|
|
|
41
41
|
x: Number(x),
|
|
42
42
|
y: Number(y)
|
|
43
43
|
});
|
|
44
|
-
const
|
|
44
|
+
const nodeRef = useRef(null);
|
|
45
|
+
useNodesRef(props, ref, nodeRef, {
|
|
45
46
|
defaultStyle: styles.container
|
|
46
47
|
});
|
|
47
48
|
let panResponder = {};
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
49
|
+
const isFirstTouch = useRef(true);
|
|
50
|
+
const touchEvent = useRef('');
|
|
51
|
+
const initialDistance = useRef(0);
|
|
51
52
|
propsRef.current = props;
|
|
52
53
|
useEffect(() => {
|
|
53
54
|
if (scale && (scaleValue.current._value !== originScaleValue)) {
|
|
@@ -55,7 +56,7 @@ const _MovableView = forwardRef((props, ref) => {
|
|
|
55
56
|
Animated.spring(scaleValue.current, {
|
|
56
57
|
toValue: clampedScale,
|
|
57
58
|
friction,
|
|
58
|
-
useNativeDriver: false
|
|
59
|
+
useNativeDriver: false
|
|
59
60
|
}).start(() => {
|
|
60
61
|
bindscale && bindscale(getCustomEvent('scale', {}, {
|
|
61
62
|
detail: {
|
|
@@ -186,7 +187,7 @@ const _MovableView = forwardRef((props, ref) => {
|
|
|
186
187
|
null,
|
|
187
188
|
{
|
|
188
189
|
dx: direction === 'all' || direction === 'horizontal' ? pan.current.x : new Animated.Value(0),
|
|
189
|
-
dy: direction === 'all' || direction === 'vertical' ? pan.current.y : new Animated.Value(0)
|
|
190
|
+
dy: direction === 'all' || direction === 'vertical' ? pan.current.y : new Animated.Value(0)
|
|
190
191
|
}
|
|
191
192
|
], {
|
|
192
193
|
useNativeDriver: false
|
|
@@ -316,8 +317,8 @@ const _MovableView = forwardRef((props, ref) => {
|
|
|
316
317
|
ref: nodeRef,
|
|
317
318
|
...panResponder.panHandlers,
|
|
318
319
|
onLayout,
|
|
319
|
-
...(hasTouchmove() ? {
|
|
320
|
-
...(hasCatchTouchmove() ? {
|
|
320
|
+
...(hasTouchmove() ? { bindtouchmove: onTouchMove } : {}),
|
|
321
|
+
...(hasCatchTouchmove() ? { catchtouchmove: onCatchTouchMove } : {})
|
|
321
322
|
}, [
|
|
322
323
|
'children',
|
|
323
324
|
'style',
|
|
@@ -27,7 +27,8 @@ const _DatePicker = forwardRef((props, ref) => {
|
|
|
27
27
|
const [datevalue, setDateValue] = useState(value);
|
|
28
28
|
// 存储layout布局信息
|
|
29
29
|
const layoutRef = useRef({});
|
|
30
|
-
const
|
|
30
|
+
const viewRef = useRef(null);
|
|
31
|
+
useNodesRef(props, ref, viewRef, {});
|
|
31
32
|
useEffect(() => {
|
|
32
33
|
value && setDateValue(value);
|
|
33
34
|
}, [value]);
|