@mpxjs/webpack-plugin 2.9.62 → 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.
- package/lib/index.js +1 -3
- package/lib/platform/style/wx/index.js +67 -53
- package/lib/react/processStyles.js +1 -0
- package/lib/react/processTemplate.js +2 -3
- package/lib/react/style-helper.js +12 -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 +52 -74
- package/lib/runtime/components/react/dist/mpx-checkbox-group.jsx +19 -18
- package/lib/runtime/components/react/dist/mpx-checkbox.jsx +28 -41
- package/lib/runtime/components/react/dist/mpx-form.jsx +16 -14
- package/lib/runtime/components/react/dist/mpx-icon.jsx +14 -17
- package/lib/runtime/components/react/dist/mpx-image/index.jsx +34 -33
- package/lib/runtime/components/react/dist/mpx-image/svg.jsx +3 -1
- package/lib/runtime/components/react/dist/mpx-input.jsx +35 -31
- package/lib/runtime/components/react/dist/mpx-label.jsx +29 -37
- package/lib/runtime/components/react/dist/mpx-movable-area.jsx +13 -18
- package/lib/runtime/components/react/dist/mpx-movable-view.jsx +8 -8
- package/lib/runtime/components/react/dist/mpx-picker/index.jsx +9 -9
- package/lib/runtime/components/react/dist/mpx-picker/multiSelector.jsx +7 -4
- package/lib/runtime/components/react/dist/mpx-picker/region.jsx +11 -7
- package/lib/runtime/components/react/dist/mpx-picker/selector.jsx +1 -1
- package/lib/runtime/components/react/dist/mpx-picker/time.jsx +18 -18
- package/lib/runtime/components/react/dist/mpx-picker-view-column.jsx +102 -10
- package/lib/runtime/components/react/dist/mpx-picker-view.jsx +147 -53
- package/lib/runtime/components/react/dist/mpx-radio-group.jsx +19 -18
- package/lib/runtime/components/react/dist/mpx-radio.jsx +28 -43
- package/lib/runtime/components/react/dist/mpx-root-portal.jsx +8 -4
- package/lib/runtime/components/react/dist/mpx-scroll-view.jsx +33 -26
- package/lib/runtime/components/react/dist/mpx-swiper/carouse.jsx +139 -74
- package/lib/runtime/components/react/dist/mpx-swiper/index.jsx +14 -6
- package/lib/runtime/components/react/dist/mpx-swiper-item.jsx +19 -11
- package/lib/runtime/components/react/dist/mpx-switch.jsx +17 -14
- package/lib/runtime/components/react/dist/mpx-text.jsx +19 -35
- package/lib/runtime/components/react/dist/mpx-textarea.jsx +1 -1
- package/lib/runtime/components/react/dist/mpx-view.jsx +284 -209
- package/lib/runtime/components/react/dist/mpx-web-view.jsx +8 -5
- package/lib/runtime/components/react/dist/parser.js +218 -0
- package/lib/runtime/components/react/dist/utils.jsx +433 -0
- package/lib/runtime/components/react/getInnerListeners.ts +18 -8
- package/lib/runtime/components/react/mpx-button.tsx +81 -91
- package/lib/runtime/components/react/mpx-checkbox-group.tsx +48 -43
- package/lib/runtime/components/react/mpx-checkbox.tsx +52 -63
- package/lib/runtime/components/react/mpx-form.tsx +49 -21
- package/lib/runtime/components/react/mpx-icon.tsx +30 -27
- package/lib/runtime/components/react/mpx-image/index.tsx +52 -46
- package/lib/runtime/components/react/mpx-image/svg.tsx +5 -3
- package/lib/runtime/components/react/mpx-input.tsx +58 -38
- package/lib/runtime/components/react/mpx-label.tsx +54 -59
- package/lib/runtime/components/react/mpx-movable-area.tsx +38 -24
- package/lib/runtime/components/react/mpx-movable-view.tsx +27 -28
- package/lib/runtime/components/react/mpx-navigator.tsx +2 -2
- package/lib/runtime/components/react/mpx-picker/date.tsx +2 -3
- package/lib/runtime/components/react/mpx-picker/index.tsx +10 -10
- package/lib/runtime/components/react/mpx-picker/multiSelector.tsx +15 -12
- package/lib/runtime/components/react/mpx-picker/region.tsx +21 -18
- package/lib/runtime/components/react/mpx-picker/selector.tsx +5 -6
- package/lib/runtime/components/react/mpx-picker/time.tsx +25 -29
- package/lib/runtime/components/react/mpx-picker/type.ts +1 -1
- package/lib/runtime/components/react/mpx-picker-view-column.tsx +148 -20
- package/lib/runtime/components/react/mpx-picker-view.tsx +179 -63
- package/lib/runtime/components/react/mpx-radio-group.tsx +50 -47
- package/lib/runtime/components/react/mpx-radio.tsx +56 -72
- package/lib/runtime/components/react/mpx-root-portal.tsx +10 -8
- package/lib/runtime/components/react/mpx-scroll-view.tsx +133 -103
- package/lib/runtime/components/react/mpx-swiper/carouse.tsx +174 -96
- package/lib/runtime/components/react/mpx-swiper/index.tsx +18 -9
- package/lib/runtime/components/react/mpx-swiper/type.ts +16 -5
- package/lib/runtime/components/react/mpx-swiper-item.tsx +46 -13
- package/lib/runtime/components/react/mpx-switch.tsx +44 -23
- package/lib/runtime/components/react/mpx-text.tsx +37 -45
- package/lib/runtime/components/react/mpx-textarea.tsx +1 -1
- package/lib/runtime/components/react/mpx-view.tsx +388 -240
- package/lib/runtime/components/react/mpx-web-view.tsx +19 -20
- 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 +14 -2
- package/lib/runtime/components/react/useNodesRef.ts +1 -2
- package/lib/runtime/components/react/utils.tsx +505 -0
- package/lib/template-compiler/compiler.js +28 -20
- package/lib/template-compiler/gen-node-react.js +1 -3
- package/lib/web/processStyles.js +2 -5
- package/package.json +6 -4
- package/lib/runtime/components/react/dist/utils.js +0 -148
- package/lib/runtime/components/react/utils.ts +0 -170
|
@@ -35,21 +35,21 @@
|
|
|
35
35
|
* ✔ bindtap
|
|
36
36
|
*/
|
|
37
37
|
import { useEffect, useRef, useState, forwardRef, useContext } from 'react';
|
|
38
|
-
import { View,
|
|
39
|
-
import {
|
|
38
|
+
import { View, StyleSheet, Animated, Easing } from 'react-native';
|
|
39
|
+
import { warn } from '@mpxjs/utils';
|
|
40
|
+
import { splitProps, splitStyle, useLayout, useTransformStyle, wrapChildren } from './utils';
|
|
40
41
|
import useInnerProps, { getCustomEvent } from './getInnerListeners';
|
|
41
42
|
import useNodesRef from './useNodesRef';
|
|
42
43
|
import { FormContext } from './context';
|
|
43
|
-
import { isEmptyObject } from '@mpxjs/utils';
|
|
44
44
|
const LOADING_IMAGE_URI = '';
|
|
45
45
|
const TypeColorMap = {
|
|
46
46
|
default: ['#F8F8F8', '#DEDEDE', '35,35,35', '#F7F7F7'],
|
|
47
47
|
primary: ['#1AAD19', '#179B16', '26,173,25', '#9ED99D'],
|
|
48
|
-
warn: ['#E64340', '#CE3C39', '230,67,64', '#EC8B89']
|
|
48
|
+
warn: ['#E64340', '#CE3C39', '230,67,64', '#EC8B89']
|
|
49
49
|
};
|
|
50
50
|
const OpenTypeEventsMap = new Map([
|
|
51
51
|
['share', 'onShareAppMessage'],
|
|
52
|
-
['getUserInfo', 'onUserInfo']
|
|
52
|
+
['getUserInfo', 'onUserInfo']
|
|
53
53
|
]);
|
|
54
54
|
const styles = StyleSheet.create({
|
|
55
55
|
button: {
|
|
@@ -63,35 +63,33 @@ const styles = StyleSheet.create({
|
|
|
63
63
|
marginHorizontal: 'auto' // 按钮默认居中
|
|
64
64
|
},
|
|
65
65
|
buttonMini: {
|
|
66
|
-
height: 30
|
|
66
|
+
height: 30
|
|
67
67
|
},
|
|
68
68
|
text: {
|
|
69
69
|
fontSize: 18,
|
|
70
|
-
color: '#000000'
|
|
70
|
+
color: '#000000'
|
|
71
71
|
},
|
|
72
72
|
textMini: {
|
|
73
|
-
fontSize: 13
|
|
73
|
+
fontSize: 13
|
|
74
74
|
},
|
|
75
75
|
loading: {
|
|
76
76
|
width: 20,
|
|
77
|
-
height: 20
|
|
78
|
-
}
|
|
77
|
+
height: 20
|
|
78
|
+
}
|
|
79
79
|
});
|
|
80
80
|
const getOpenTypeEvent = (openType) => {
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
throwReactWarning('[Mpx runtime warn]: Environment not supported');
|
|
81
|
+
if (!global.__mpx?.config?.rnConfig) {
|
|
82
|
+
warn('Environment not supported');
|
|
84
83
|
return;
|
|
85
84
|
}
|
|
86
85
|
const eventName = OpenTypeEventsMap.get(openType);
|
|
87
86
|
if (!eventName) {
|
|
88
|
-
|
|
87
|
+
warn(`open-type not support ${openType}`);
|
|
89
88
|
return;
|
|
90
89
|
}
|
|
91
|
-
|
|
92
|
-
const event = global.__mpx.config.rnConfig?.openTypeHandler?.[eventName];
|
|
90
|
+
const event = global.__mpx.config.rnConfig.openTypeHandler?.[eventName];
|
|
93
91
|
if (!event) {
|
|
94
|
-
|
|
92
|
+
warn(`Unregistered ${eventName} event`);
|
|
95
93
|
return;
|
|
96
94
|
}
|
|
97
95
|
return event;
|
|
@@ -100,7 +98,7 @@ const Loading = ({ alone = false }) => {
|
|
|
100
98
|
const image = useRef(new Animated.Value(0)).current;
|
|
101
99
|
const rotate = image.interpolate({
|
|
102
100
|
inputRange: [0, 1],
|
|
103
|
-
outputRange: ['0deg', '360deg']
|
|
101
|
+
outputRange: ['0deg', '360deg']
|
|
104
102
|
});
|
|
105
103
|
useEffect(() => {
|
|
106
104
|
const animation = Animated.loop(Animated.timing(image, {
|
|
@@ -108,23 +106,23 @@ const Loading = ({ alone = false }) => {
|
|
|
108
106
|
duration: 1000,
|
|
109
107
|
easing: Easing.linear,
|
|
110
108
|
useNativeDriver: true,
|
|
111
|
-
isInteraction: false
|
|
109
|
+
isInteraction: false
|
|
112
110
|
}));
|
|
113
111
|
animation.start();
|
|
114
112
|
return () => {
|
|
115
113
|
animation.stop();
|
|
116
114
|
};
|
|
117
|
-
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
118
115
|
}, []);
|
|
119
116
|
const loadingStyle = {
|
|
120
117
|
...styles.loading,
|
|
121
118
|
transform: [{ rotate }],
|
|
122
|
-
marginRight: alone ? 0 : 5
|
|
119
|
+
marginRight: alone ? 0 : 5
|
|
123
120
|
};
|
|
124
121
|
return <Animated.Image testID="loading" style={loadingStyle} source={{ uri: LOADING_IMAGE_URI }}/>;
|
|
125
122
|
};
|
|
126
|
-
const Button = forwardRef((
|
|
127
|
-
const {
|
|
123
|
+
const Button = forwardRef((buttonProps, ref) => {
|
|
124
|
+
const { textProps, innerProps: props = {} } = splitProps(buttonProps);
|
|
125
|
+
const { size = 'default', type = 'default', plain = false, disabled = false, loading = false, 'hover-class': hoverClass, 'hover-style': hoverStyle = {}, 'hover-start-time': hoverStartTime = 20, 'hover-stay-time': hoverStayTime = 70, 'open-type': openType, 'form-type': formType, 'enable-var': enableVar, 'external-var-context': externalVarContext, 'parent-font-size': parentFontSize, 'parent-width': parentWidth, 'parent-height': parentHeight, style = {}, children, bindgetuserinfo, bindtap, bindtouchstart, bindtouchend } = props;
|
|
128
126
|
const formContext = useContext(FormContext);
|
|
129
127
|
let submitFn;
|
|
130
128
|
let resetFn;
|
|
@@ -134,17 +132,11 @@ const Button = forwardRef((props, ref) => {
|
|
|
134
132
|
}
|
|
135
133
|
const refs = useRef({
|
|
136
134
|
hoverStartTimer: undefined,
|
|
137
|
-
hoverStayTimer: undefined
|
|
135
|
+
hoverStayTimer: undefined
|
|
138
136
|
});
|
|
139
|
-
const layoutRef = useRef({});
|
|
140
137
|
const [isHover, setIsHover] = useState(false);
|
|
141
138
|
const isMiniSize = size === 'mini';
|
|
142
139
|
const applyHoverEffect = isHover && hoverClass !== 'none';
|
|
143
|
-
const { textStyle, imageStyle, innerStyle } = splitStyle(style);
|
|
144
|
-
const { textStyle: hoverTextStyle, imageStyle: hoverImageStyle, innerStyle: hoverInnerStyle } = splitStyle(hoverStyle);
|
|
145
|
-
if (imageStyle || hoverImageStyle) {
|
|
146
|
-
throwReactWarning('[Mpx runtime warn]: Button does not support background image-related styles!');
|
|
147
|
-
}
|
|
148
140
|
const [color, hoverColor, plainColor, disabledColor] = TypeColorMap[type];
|
|
149
141
|
const normalBackgroundColor = disabled ? disabledColor : applyHoverEffect || loading ? hoverColor : color;
|
|
150
142
|
const plainBorderColor = disabled
|
|
@@ -165,18 +157,34 @@ const Button = forwardRef((props, ref) => {
|
|
|
165
157
|
borderWidth: 1,
|
|
166
158
|
borderStyle: 'solid',
|
|
167
159
|
borderColor: plain ? plainBorderColor : normalBorderColor,
|
|
168
|
-
backgroundColor: plain ? 'transparent' : normalBackgroundColor
|
|
160
|
+
backgroundColor: plain ? 'transparent' : normalBackgroundColor
|
|
169
161
|
};
|
|
170
162
|
const defaultViewStyle = {
|
|
171
163
|
...styles.button,
|
|
172
164
|
...(isMiniSize && styles.buttonMini),
|
|
173
|
-
...viewStyle
|
|
165
|
+
...viewStyle
|
|
174
166
|
};
|
|
175
167
|
const defaultTextStyle = {
|
|
176
168
|
...styles.text,
|
|
177
169
|
...(isMiniSize && styles.textMini),
|
|
178
|
-
color: plain ? plainTextColor : normalTextColor
|
|
170
|
+
color: plain ? plainTextColor : normalTextColor
|
|
179
171
|
};
|
|
172
|
+
const defaultStyle = {
|
|
173
|
+
...defaultViewStyle,
|
|
174
|
+
...defaultTextStyle
|
|
175
|
+
};
|
|
176
|
+
const styleObj = {
|
|
177
|
+
...defaultStyle,
|
|
178
|
+
...style,
|
|
179
|
+
...(applyHoverEffect && hoverStyle)
|
|
180
|
+
};
|
|
181
|
+
const { hasSelfPercent, normalStyle, hasVarDec, varContextRef, setWidth, setHeight } = useTransformStyle(styleObj, { enableVar, externalVarContext, parentFontSize, parentWidth, parentHeight });
|
|
182
|
+
const { nodeRef } = useNodesRef(props, ref, { defaultStyle });
|
|
183
|
+
const { layoutRef, layoutStyle, layoutProps } = useLayout({ props, hasSelfPercent, setWidth, setHeight, nodeRef });
|
|
184
|
+
const { textStyle, backgroundStyle, innerStyle } = splitStyle(normalStyle);
|
|
185
|
+
if (backgroundStyle) {
|
|
186
|
+
warn('Button does not support background image-related styles!');
|
|
187
|
+
}
|
|
180
188
|
const handleOpenTypeEvent = (evt) => {
|
|
181
189
|
if (!openType)
|
|
182
190
|
return;
|
|
@@ -184,7 +192,7 @@ const Button = forwardRef((props, ref) => {
|
|
|
184
192
|
if (openType === 'share') {
|
|
185
193
|
handleEvent && handleEvent({
|
|
186
194
|
from: 'button',
|
|
187
|
-
target: getCustomEvent('tap', evt, { layoutRef }, props).target
|
|
195
|
+
target: getCustomEvent('tap', evt, { layoutRef }, props).target
|
|
188
196
|
});
|
|
189
197
|
}
|
|
190
198
|
if (openType === 'getUserInfo' && handleEvent && bindgetuserinfo) {
|
|
@@ -237,54 +245,24 @@ const Button = forwardRef((props, ref) => {
|
|
|
237
245
|
handleOpenTypeEvent(evt);
|
|
238
246
|
handleFormTypeFn();
|
|
239
247
|
};
|
|
240
|
-
function wrapChildren(children, defaultTextStyle, textStyle) {
|
|
241
|
-
if (!children)
|
|
242
|
-
return children;
|
|
243
|
-
const hasTextStyle = !isEmptyObject(textStyle);
|
|
244
|
-
const { textProps } = splitProps(props);
|
|
245
|
-
if (every(children, (child) => isText(child))) {
|
|
246
|
-
transformTextStyle(textStyle);
|
|
247
|
-
children = <Text key='buttonTextWrap' style={{ ...defaultTextStyle, ...textStyle }} {...(textProps || {})}>{children}</Text>;
|
|
248
|
-
}
|
|
249
|
-
else {
|
|
250
|
-
if (hasTextStyle)
|
|
251
|
-
throwReactWarning('[Mpx runtime warn]: Text style will be ignored unless every child of the Button is Text node!');
|
|
252
|
-
}
|
|
253
|
-
return children;
|
|
254
|
-
}
|
|
255
|
-
const { nodeRef } = useNodesRef(props, ref, {
|
|
256
|
-
defaultStyle: {
|
|
257
|
-
...defaultViewStyle,
|
|
258
|
-
...defaultTextStyle,
|
|
259
|
-
...textStyle
|
|
260
|
-
}
|
|
261
|
-
});
|
|
262
|
-
const onLayout = () => {
|
|
263
|
-
nodeRef.current?.measure((x, y, width, height, offsetLeft, offsetTop) => {
|
|
264
|
-
layoutRef.current = { x, y, width, height, offsetLeft, offsetTop };
|
|
265
|
-
});
|
|
266
|
-
};
|
|
267
248
|
const innerProps = useInnerProps(props, {
|
|
268
249
|
ref: nodeRef,
|
|
250
|
+
style: { ...innerStyle, ...layoutStyle },
|
|
251
|
+
...layoutProps,
|
|
269
252
|
bindtouchstart: onTouchStart,
|
|
270
253
|
bindtouchend: onTouchEnd,
|
|
271
|
-
bindtap: onTap
|
|
272
|
-
|
|
273
|
-
}, [
|
|
274
|
-
'enable-offset'
|
|
275
|
-
], {
|
|
254
|
+
bindtap: onTap
|
|
255
|
+
}, [], {
|
|
276
256
|
layoutRef,
|
|
277
257
|
disableTap: disabled
|
|
278
258
|
});
|
|
279
|
-
return (<View {...innerProps}
|
|
280
|
-
...defaultViewStyle,
|
|
281
|
-
...innerStyle,
|
|
282
|
-
...(applyHoverEffect && hoverInnerStyle),
|
|
283
|
-
}}>
|
|
259
|
+
return (<View {...innerProps}>
|
|
284
260
|
{loading && <Loading alone={!children}/>}
|
|
285
|
-
{wrapChildren(
|
|
286
|
-
|
|
287
|
-
|
|
261
|
+
{wrapChildren(props, {
|
|
262
|
+
hasVarDec,
|
|
263
|
+
varContext: varContextRef.current,
|
|
264
|
+
textStyle,
|
|
265
|
+
textProps
|
|
288
266
|
})}
|
|
289
267
|
</View>);
|
|
290
268
|
});
|
|
@@ -3,13 +3,13 @@
|
|
|
3
3
|
*/
|
|
4
4
|
import { useRef, forwardRef, useContext } from 'react';
|
|
5
5
|
import { View } from 'react-native';
|
|
6
|
+
import { warn } from '@mpxjs/utils';
|
|
6
7
|
import { FormContext, CheckboxGroupContext } from './context';
|
|
7
8
|
import useInnerProps, { getCustomEvent } from './getInnerListeners';
|
|
8
9
|
import useNodesRef from './useNodesRef';
|
|
9
|
-
import {
|
|
10
|
+
import { useLayout, useTransformStyle, wrapChildren } from './utils';
|
|
10
11
|
const CheckboxGroup = forwardRef((props, ref) => {
|
|
11
|
-
const { style = {}, 'enable-
|
|
12
|
-
const layoutRef = useRef({});
|
|
12
|
+
const { style = {}, 'enable-var': enableVar, 'external-var-context': externalVarContext, 'parent-font-size': parentFontSize, 'parent-width': parentWidth, 'parent-height': parentHeight, bindchange } = props;
|
|
13
13
|
const formContext = useContext(FormContext);
|
|
14
14
|
let formValuesMap;
|
|
15
15
|
if (formContext) {
|
|
@@ -18,20 +18,18 @@ const CheckboxGroup = forwardRef((props, ref) => {
|
|
|
18
18
|
const groupValue = useRef({}).current;
|
|
19
19
|
const defaultStyle = {
|
|
20
20
|
flexDirection: 'row',
|
|
21
|
-
flexWrap: 'wrap'
|
|
22
|
-
...style
|
|
21
|
+
flexWrap: 'wrap'
|
|
23
22
|
};
|
|
24
|
-
const
|
|
25
|
-
defaultStyle
|
|
26
|
-
|
|
27
|
-
const onLayout = () => {
|
|
28
|
-
nodeRef.current?.measure((x, y, width, height, offsetLeft, offsetTop) => {
|
|
29
|
-
layoutRef.current = { x, y, width, height, offsetLeft, offsetTop };
|
|
30
|
-
});
|
|
23
|
+
const styleObj = {
|
|
24
|
+
...defaultStyle,
|
|
25
|
+
...style
|
|
31
26
|
};
|
|
27
|
+
const { hasSelfPercent, normalStyle, hasVarDec, varContextRef, setWidth, setHeight } = useTransformStyle(styleObj, { enableVar, externalVarContext, parentFontSize, parentWidth, parentHeight });
|
|
28
|
+
const { nodeRef } = useNodesRef(props, ref, { defaultStyle });
|
|
29
|
+
const { layoutRef, layoutStyle, layoutProps } = useLayout({ props, hasSelfPercent, setWidth, setHeight, nodeRef });
|
|
32
30
|
const getSelectionValue = () => {
|
|
33
31
|
const arr = [];
|
|
34
|
-
for (
|
|
32
|
+
for (const key in groupValue) {
|
|
35
33
|
if (groupValue[key].checked) {
|
|
36
34
|
arr.push(key);
|
|
37
35
|
}
|
|
@@ -49,7 +47,7 @@ const CheckboxGroup = forwardRef((props, ref) => {
|
|
|
49
47
|
};
|
|
50
48
|
if (formValuesMap) {
|
|
51
49
|
if (!props.name) {
|
|
52
|
-
|
|
50
|
+
warn('If a form component is used, the name attribute is required.');
|
|
53
51
|
}
|
|
54
52
|
else {
|
|
55
53
|
formValuesMap.set(props.name, { getValue, resetValue });
|
|
@@ -66,14 +64,17 @@ const CheckboxGroup = forwardRef((props, ref) => {
|
|
|
66
64
|
};
|
|
67
65
|
const innerProps = useInnerProps(props, {
|
|
68
66
|
ref: nodeRef,
|
|
69
|
-
style:
|
|
70
|
-
...
|
|
71
|
-
}, [
|
|
67
|
+
style: { ...normalStyle, ...layoutStyle },
|
|
68
|
+
...layoutProps
|
|
69
|
+
}, [], {
|
|
72
70
|
layoutRef
|
|
73
71
|
});
|
|
74
72
|
return (<View {...innerProps}>
|
|
75
73
|
<CheckboxGroupContext.Provider value={{ groupValue, notifyChange }}>
|
|
76
|
-
{
|
|
74
|
+
{wrapChildren(props, {
|
|
75
|
+
hasVarDec,
|
|
76
|
+
varContext: varContextRef.current
|
|
77
|
+
})}
|
|
77
78
|
</CheckboxGroupContext.Provider>
|
|
78
79
|
</View>);
|
|
79
80
|
});
|
|
@@ -4,12 +4,13 @@
|
|
|
4
4
|
* ✔ checked
|
|
5
5
|
* ✔ color
|
|
6
6
|
*/
|
|
7
|
-
import {
|
|
8
|
-
import { View,
|
|
7
|
+
import { useState, forwardRef, useEffect, useContext } from 'react';
|
|
8
|
+
import { View, StyleSheet } from 'react-native';
|
|
9
|
+
import { warn } from '@mpxjs/utils';
|
|
9
10
|
import useInnerProps, { getCustomEvent } from './getInnerListeners';
|
|
10
11
|
import useNodesRef from './useNodesRef';
|
|
11
12
|
import Icon from './mpx-icon';
|
|
12
|
-
import {
|
|
13
|
+
import { splitProps, splitStyle, useLayout, useTransformStyle, wrapChildren } from './utils';
|
|
13
14
|
import { CheckboxGroupContext, LabelContext } from './context';
|
|
14
15
|
const styles = StyleSheet.create({
|
|
15
16
|
container: {
|
|
@@ -37,24 +38,20 @@ const styles = StyleSheet.create({
|
|
|
37
38
|
opacity: 1
|
|
38
39
|
}
|
|
39
40
|
});
|
|
40
|
-
const Checkbox = forwardRef((
|
|
41
|
-
const {
|
|
42
|
-
const
|
|
41
|
+
const Checkbox = forwardRef((checkboxProps, ref) => {
|
|
42
|
+
const { textProps, innerProps: props = {} } = splitProps(checkboxProps);
|
|
43
|
+
const { value = '', disabled = false, checked = false, color = '#09BB07', style = {}, 'enable-var': enableVar, 'external-var-context': externalVarContext, 'parent-font-size': parentFontSize, 'parent-width': parentWidth, 'parent-height': parentHeight, bindtap, catchtap } = props;
|
|
43
44
|
const [isChecked, setIsChecked] = useState(!!checked);
|
|
44
|
-
const { textStyle, imageStyle, innerStyle } = splitStyle(style);
|
|
45
|
-
if (imageStyle) {
|
|
46
|
-
throwReactWarning('[Mpx runtime warn]: Checkbox does not support background image-related styles!');
|
|
47
|
-
}
|
|
48
45
|
const groupContext = useContext(CheckboxGroupContext);
|
|
49
46
|
let groupValue;
|
|
50
47
|
let notifyChange;
|
|
51
48
|
const defaultStyle = {
|
|
52
49
|
...styles.wrapper,
|
|
53
|
-
...(disabled && styles.wrapperDisabled)
|
|
50
|
+
...(disabled && styles.wrapperDisabled)
|
|
54
51
|
};
|
|
55
|
-
const
|
|
56
|
-
...
|
|
57
|
-
...
|
|
52
|
+
const styleObj = {
|
|
53
|
+
...styles.container,
|
|
54
|
+
...style
|
|
58
55
|
};
|
|
59
56
|
const onChange = (evt) => {
|
|
60
57
|
if (disabled)
|
|
@@ -78,31 +75,16 @@ const Checkbox = forwardRef((props, ref) => {
|
|
|
78
75
|
catchtap && catchtap(getCustomEvent('tap', evt, { layoutRef }, props));
|
|
79
76
|
onChange(evt);
|
|
80
77
|
};
|
|
78
|
+
const { hasSelfPercent, normalStyle, hasVarDec, varContextRef, setWidth, setHeight } = useTransformStyle(styleObj, { enableVar, externalVarContext, parentFontSize, parentWidth, parentHeight });
|
|
81
79
|
const { nodeRef } = useNodesRef(props, ref, {
|
|
82
80
|
defaultStyle,
|
|
83
81
|
change: onChange
|
|
84
82
|
});
|
|
85
|
-
const
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
}
|
|
90
|
-
const wrapChildren = (children, textStyle) => {
|
|
91
|
-
if (!children)
|
|
92
|
-
return children;
|
|
93
|
-
const { textProps } = splitProps(props);
|
|
94
|
-
if (every(children, (child) => isText(child))) {
|
|
95
|
-
if (textStyle || textProps) {
|
|
96
|
-
children = <Text key='checkboxTextWrap' style={textStyle || {}} {...(textProps || {})}>{children}</Text>;
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
else {
|
|
100
|
-
if (textStyle) {
|
|
101
|
-
throwReactWarning('[Mpx runtime warn]: Text style will be ignored unless every child of the Checkbox is Text node!');
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
return children;
|
|
105
|
-
};
|
|
83
|
+
const { layoutRef, layoutStyle, layoutProps } = useLayout({ props, hasSelfPercent, setWidth, setHeight, nodeRef });
|
|
84
|
+
const { textStyle, backgroundStyle, innerStyle } = splitStyle(normalStyle);
|
|
85
|
+
if (backgroundStyle) {
|
|
86
|
+
warn('Checkbox does not support background image-related styles!');
|
|
87
|
+
}
|
|
106
88
|
const labelContext = useContext(LabelContext);
|
|
107
89
|
if (groupContext) {
|
|
108
90
|
groupValue = groupContext.groupValue;
|
|
@@ -113,11 +95,11 @@ const Checkbox = forwardRef((props, ref) => {
|
|
|
113
95
|
}
|
|
114
96
|
const innerProps = useInnerProps(props, {
|
|
115
97
|
ref: nodeRef,
|
|
116
|
-
style:
|
|
98
|
+
style: { ...innerStyle, ...layoutStyle },
|
|
99
|
+
...layoutProps,
|
|
117
100
|
bindtap: onTap,
|
|
118
|
-
catchtap: catchTap
|
|
119
|
-
|
|
120
|
-
}, ['enable-offset'], {
|
|
101
|
+
catchtap: catchTap
|
|
102
|
+
}, [], {
|
|
121
103
|
layoutRef
|
|
122
104
|
});
|
|
123
105
|
useEffect(() => {
|
|
@@ -142,10 +124,15 @@ const Checkbox = forwardRef((props, ref) => {
|
|
|
142
124
|
}
|
|
143
125
|
}, [checked]);
|
|
144
126
|
return (<View {...innerProps}>
|
|
145
|
-
<View style={
|
|
127
|
+
<View style={defaultStyle}>
|
|
146
128
|
<Icon type='success_no_circle' size={18} color={disabled ? '#ADADAD' : color} style={isChecked ? styles.iconChecked : styles.icon}/>
|
|
147
129
|
</View>
|
|
148
|
-
{wrapChildren(
|
|
130
|
+
{wrapChildren(props, {
|
|
131
|
+
hasVarDec,
|
|
132
|
+
varContext: varContextRef.current,
|
|
133
|
+
textStyle,
|
|
134
|
+
textProps
|
|
135
|
+
})}
|
|
149
136
|
</View>);
|
|
150
137
|
});
|
|
151
138
|
Checkbox.displayName = 'mpx-checkbox';
|
|
@@ -9,20 +9,19 @@ import { useRef, forwardRef } from 'react';
|
|
|
9
9
|
import useNodesRef from './useNodesRef';
|
|
10
10
|
import useInnerProps, { getCustomEvent } from './getInnerListeners';
|
|
11
11
|
import { FormContext } from './context';
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
const
|
|
12
|
+
import { useTransformStyle, splitProps, splitStyle, useLayout, wrapChildren } from './utils';
|
|
13
|
+
const _Form = forwardRef((fromProps, ref) => {
|
|
14
|
+
const { textProps, innerProps: props = {} } = splitProps(fromProps);
|
|
15
15
|
const formValuesMap = useRef(new Map()).current;
|
|
16
|
+
const { style, 'enable-var': enableVar, 'external-var-context': externalVarContext, 'parent-font-size': parentFontSize, 'parent-width': parentWidth, 'parent-height': parentHeight } = props;
|
|
17
|
+
const { hasSelfPercent, normalStyle, hasVarDec, varContextRef, setWidth, setHeight } = useTransformStyle(style, { enableVar, externalVarContext, parentFontSize, parentWidth, parentHeight });
|
|
18
|
+
const { textStyle, innerStyle } = splitStyle(normalStyle);
|
|
16
19
|
const { nodeRef: formRef } = useNodesRef(props, ref);
|
|
17
|
-
const
|
|
18
|
-
formRef.current?.measure((x, y, width, height, offsetLeft, offsetTop) => {
|
|
19
|
-
layoutRef.current = { x, y, width, height, offsetLeft, offsetTop };
|
|
20
|
-
});
|
|
21
|
-
};
|
|
20
|
+
const { layoutRef, layoutStyle, layoutProps } = useLayout({ props, hasSelfPercent, setWidth, setHeight, nodeRef: formRef });
|
|
22
21
|
const submit = () => {
|
|
23
22
|
const { bindsubmit } = props;
|
|
24
23
|
const formValue = {};
|
|
25
|
-
for (
|
|
24
|
+
for (const name of formValuesMap.keys()) {
|
|
26
25
|
if (formValuesMap.get(name).getValue) {
|
|
27
26
|
formValue[name] = formValuesMap.get(name).getValue();
|
|
28
27
|
}
|
|
@@ -40,18 +39,21 @@ const _Form = forwardRef((props, ref) => {
|
|
|
40
39
|
formValuesMap.forEach(item => item.resetValue());
|
|
41
40
|
};
|
|
42
41
|
const innerProps = useInnerProps(props, {
|
|
42
|
+
style: { ...innerStyle, ...layoutStyle },
|
|
43
43
|
ref: formRef,
|
|
44
|
-
|
|
45
|
-
onLayout
|
|
44
|
+
...layoutProps
|
|
46
45
|
}, [
|
|
47
|
-
'children',
|
|
48
|
-
'style',
|
|
49
46
|
'bindsubmit',
|
|
50
47
|
'bindreset'
|
|
51
48
|
], { layoutRef });
|
|
52
49
|
return (<View {...innerProps}>
|
|
53
50
|
<FormContext.Provider value={{ formValuesMap, submit, reset }}>
|
|
54
|
-
{
|
|
51
|
+
{wrapChildren(props, {
|
|
52
|
+
hasVarDec,
|
|
53
|
+
varContext: varContextRef.current,
|
|
54
|
+
textStyle,
|
|
55
|
+
textProps
|
|
56
|
+
})}
|
|
55
57
|
</FormContext.Provider>
|
|
56
58
|
</View>);
|
|
57
59
|
});
|
|
@@ -3,10 +3,11 @@
|
|
|
3
3
|
* ✔ size
|
|
4
4
|
* ✔ color
|
|
5
5
|
*/
|
|
6
|
-
import {
|
|
6
|
+
import { forwardRef } 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,26 @@ 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 } = useNodesRef(props, ref, { defaultStyle });
|
|
32
|
+
const { layoutRef, layoutStyle, layoutProps } = useLayout({ props, hasSelfPercent, setWidth, setHeight, nodeRef });
|
|
34
33
|
const innerProps = useInnerProps(props, {
|
|
35
34
|
ref: nodeRef,
|
|
36
35
|
style: {
|
|
37
|
-
...
|
|
38
|
-
|
|
39
|
-
|
|
36
|
+
...normalStyle,
|
|
37
|
+
...layoutStyle,
|
|
38
|
+
tintColor: color
|
|
40
39
|
},
|
|
41
40
|
source: { uri },
|
|
42
|
-
...
|
|
43
|
-
}, [
|
|
44
|
-
'enable-offset'
|
|
45
|
-
], {
|
|
41
|
+
...layoutProps
|
|
42
|
+
}, [], {
|
|
46
43
|
layoutRef
|
|
47
44
|
});
|
|
48
45
|
return <Image {...innerProps}/>;
|