@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.
Files changed (86) hide show
  1. package/lib/index.js +1 -3
  2. package/lib/platform/style/wx/index.js +67 -53
  3. package/lib/react/processStyles.js +1 -0
  4. package/lib/react/processTemplate.js +2 -3
  5. package/lib/react/style-helper.js +12 -7
  6. package/lib/runtime/components/react/context.ts +9 -7
  7. package/lib/runtime/components/react/dist/context.js +1 -0
  8. package/lib/runtime/components/react/dist/getInnerListeners.js +12 -1
  9. package/lib/runtime/components/react/dist/mpx-button.jsx +52 -74
  10. package/lib/runtime/components/react/dist/mpx-checkbox-group.jsx +19 -18
  11. package/lib/runtime/components/react/dist/mpx-checkbox.jsx +28 -41
  12. package/lib/runtime/components/react/dist/mpx-form.jsx +16 -14
  13. package/lib/runtime/components/react/dist/mpx-icon.jsx +14 -17
  14. package/lib/runtime/components/react/dist/mpx-image/index.jsx +34 -33
  15. package/lib/runtime/components/react/dist/mpx-image/svg.jsx +3 -1
  16. package/lib/runtime/components/react/dist/mpx-input.jsx +35 -31
  17. package/lib/runtime/components/react/dist/mpx-label.jsx +29 -37
  18. package/lib/runtime/components/react/dist/mpx-movable-area.jsx +13 -18
  19. package/lib/runtime/components/react/dist/mpx-movable-view.jsx +8 -8
  20. package/lib/runtime/components/react/dist/mpx-picker/index.jsx +9 -9
  21. package/lib/runtime/components/react/dist/mpx-picker/multiSelector.jsx +7 -4
  22. package/lib/runtime/components/react/dist/mpx-picker/region.jsx +11 -7
  23. package/lib/runtime/components/react/dist/mpx-picker/selector.jsx +1 -1
  24. package/lib/runtime/components/react/dist/mpx-picker/time.jsx +18 -18
  25. package/lib/runtime/components/react/dist/mpx-picker-view-column.jsx +102 -10
  26. package/lib/runtime/components/react/dist/mpx-picker-view.jsx +147 -53
  27. package/lib/runtime/components/react/dist/mpx-radio-group.jsx +19 -18
  28. package/lib/runtime/components/react/dist/mpx-radio.jsx +28 -43
  29. package/lib/runtime/components/react/dist/mpx-root-portal.jsx +8 -4
  30. package/lib/runtime/components/react/dist/mpx-scroll-view.jsx +33 -26
  31. package/lib/runtime/components/react/dist/mpx-swiper/carouse.jsx +139 -74
  32. package/lib/runtime/components/react/dist/mpx-swiper/index.jsx +14 -6
  33. package/lib/runtime/components/react/dist/mpx-swiper-item.jsx +19 -11
  34. package/lib/runtime/components/react/dist/mpx-switch.jsx +17 -14
  35. package/lib/runtime/components/react/dist/mpx-text.jsx +19 -35
  36. package/lib/runtime/components/react/dist/mpx-textarea.jsx +1 -1
  37. package/lib/runtime/components/react/dist/mpx-view.jsx +284 -209
  38. package/lib/runtime/components/react/dist/mpx-web-view.jsx +8 -5
  39. package/lib/runtime/components/react/dist/parser.js +218 -0
  40. package/lib/runtime/components/react/dist/utils.jsx +433 -0
  41. package/lib/runtime/components/react/getInnerListeners.ts +18 -8
  42. package/lib/runtime/components/react/mpx-button.tsx +81 -91
  43. package/lib/runtime/components/react/mpx-checkbox-group.tsx +48 -43
  44. package/lib/runtime/components/react/mpx-checkbox.tsx +52 -63
  45. package/lib/runtime/components/react/mpx-form.tsx +49 -21
  46. package/lib/runtime/components/react/mpx-icon.tsx +30 -27
  47. package/lib/runtime/components/react/mpx-image/index.tsx +52 -46
  48. package/lib/runtime/components/react/mpx-image/svg.tsx +5 -3
  49. package/lib/runtime/components/react/mpx-input.tsx +58 -38
  50. package/lib/runtime/components/react/mpx-label.tsx +54 -59
  51. package/lib/runtime/components/react/mpx-movable-area.tsx +38 -24
  52. package/lib/runtime/components/react/mpx-movable-view.tsx +27 -28
  53. package/lib/runtime/components/react/mpx-navigator.tsx +2 -2
  54. package/lib/runtime/components/react/mpx-picker/date.tsx +2 -3
  55. package/lib/runtime/components/react/mpx-picker/index.tsx +10 -10
  56. package/lib/runtime/components/react/mpx-picker/multiSelector.tsx +15 -12
  57. package/lib/runtime/components/react/mpx-picker/region.tsx +21 -18
  58. package/lib/runtime/components/react/mpx-picker/selector.tsx +5 -6
  59. package/lib/runtime/components/react/mpx-picker/time.tsx +25 -29
  60. package/lib/runtime/components/react/mpx-picker/type.ts +1 -1
  61. package/lib/runtime/components/react/mpx-picker-view-column.tsx +148 -20
  62. package/lib/runtime/components/react/mpx-picker-view.tsx +179 -63
  63. package/lib/runtime/components/react/mpx-radio-group.tsx +50 -47
  64. package/lib/runtime/components/react/mpx-radio.tsx +56 -72
  65. package/lib/runtime/components/react/mpx-root-portal.tsx +10 -8
  66. package/lib/runtime/components/react/mpx-scroll-view.tsx +133 -103
  67. package/lib/runtime/components/react/mpx-swiper/carouse.tsx +174 -96
  68. package/lib/runtime/components/react/mpx-swiper/index.tsx +18 -9
  69. package/lib/runtime/components/react/mpx-swiper/type.ts +16 -5
  70. package/lib/runtime/components/react/mpx-swiper-item.tsx +46 -13
  71. package/lib/runtime/components/react/mpx-switch.tsx +44 -23
  72. package/lib/runtime/components/react/mpx-text.tsx +37 -45
  73. package/lib/runtime/components/react/mpx-textarea.tsx +1 -1
  74. package/lib/runtime/components/react/mpx-view.tsx +388 -240
  75. package/lib/runtime/components/react/mpx-web-view.tsx +19 -20
  76. package/lib/runtime/components/react/parser.ts +245 -0
  77. package/lib/runtime/components/react/types/common.ts +4 -4
  78. package/lib/runtime/components/react/types/global.d.ts +14 -2
  79. package/lib/runtime/components/react/useNodesRef.ts +1 -2
  80. package/lib/runtime/components/react/utils.tsx +505 -0
  81. package/lib/template-compiler/compiler.js +28 -20
  82. package/lib/template-compiler/gen-node-react.js +1 -3
  83. package/lib/web/processStyles.js +2 -5
  84. package/package.json +6 -4
  85. package/lib/runtime/components/react/dist/utils.js +0 -148
  86. 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, Text, StyleSheet, Animated, Easing, } from 'react-native';
39
- import { splitStyle, isText, every, splitProps, throwReactWarning, transformTextStyle } from './utils';
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
- // @ts-ignore
82
- if (!global?.__mpx?.config?.rnConfig) {
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
- throwReactWarning(`[Mpx runtime warn]: open-type not support ${openType}`);
87
+ warn(`open-type not support ${openType}`);
89
88
  return;
90
89
  }
91
- // @ts-ignore
92
- const event = global.__mpx.config.rnConfig?.openTypeHandler?.[eventName];
90
+ const event = global.__mpx.config.rnConfig.openTypeHandler?.[eventName];
93
91
  if (!event) {
94
- throwReactWarning(`[Mpx runtime warn]: Unregistered ${eventName} event`);
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((props, ref) => {
127
- 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, 'enable-offset': enableOffset, 'form-type': formType, style = {}, children, bindgetuserinfo, bindtap, bindtouchstart, bindtouchend, } = props;
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
- ...(enableOffset ? { onLayout } : {}),
273
- }, [
274
- 'enable-offset'
275
- ], {
254
+ bindtap: onTap
255
+ }, [], {
276
256
  layoutRef,
277
257
  disableTap: disabled
278
258
  });
279
- return (<View {...innerProps} style={{
280
- ...defaultViewStyle,
281
- ...innerStyle,
282
- ...(applyHoverEffect && hoverInnerStyle),
283
- }}>
259
+ return (<View {...innerProps}>
284
260
  {loading && <Loading alone={!children}/>}
285
- {wrapChildren(children, defaultTextStyle, {
286
- ...textStyle,
287
- ...(applyHoverEffect && hoverTextStyle),
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 { throwReactWarning } from './utils';
10
+ import { useLayout, useTransformStyle, wrapChildren } from './utils';
10
11
  const CheckboxGroup = forwardRef((props, ref) => {
11
- const { style = {}, 'enable-offset': enableOffset, children, bindchange } = props;
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 { nodeRef } = useNodesRef(props, ref, {
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 (let key in groupValue) {
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
- throwReactWarning('[Mpx runtime warn]: If a form component is used, the name attribute is required.');
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: defaultStyle,
70
- ...(enableOffset ? { onLayout } : {})
71
- }, ['enable-offset'], {
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
- {children}
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 { useRef, useState, forwardRef, useEffect, useContext } from 'react';
8
- import { View, Text, StyleSheet } from 'react-native';
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 { every, splitStyle, isText, splitProps, throwReactWarning } from './utils';
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((props, ref) => {
41
- const { value = '', disabled = false, checked = false, color = '#09BB07', style = {}, 'enable-offset': enableOffset, children, bindtap, catchtap, } = props;
42
- const layoutRef = useRef({});
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 viewStyle = {
56
- ...defaultStyle,
57
- ...innerStyle
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 onLayout = () => {
86
- nodeRef.current?.measure((x, y, width, height, offsetLeft, offsetTop) => {
87
- layoutRef.current = { x, y, width, height, offsetLeft, offsetTop };
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: styles.container,
98
+ style: { ...innerStyle, ...layoutStyle },
99
+ ...layoutProps,
117
100
  bindtap: onTap,
118
- catchtap: catchTap,
119
- ...(enableOffset ? { onLayout } : {})
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={viewStyle}>
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(children, textStyle)}
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
- const _Form = forwardRef((props, ref) => {
13
- const { children, style } = props;
14
- const layoutRef = useRef({});
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 onLayout = (e) => {
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 (let name of formValuesMap.keys()) {
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
- style,
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
- {children}
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 { useRef, forwardRef } from 'react';
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-offset': enableOffset } = props;
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 layoutRef = useRef({});
26
- const { nodeRef } = useNodesRef(props, ref, {
27
- defaultStyle
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
- ...defaultStyle,
38
- tintColor: color,
39
- ...style
36
+ ...normalStyle,
37
+ ...layoutStyle,
38
+ tintColor: color
40
39
  },
41
40
  source: { uri },
42
- ...(enableOffset ? { onLayout } : {})
43
- }, [
44
- 'enable-offset'
45
- ], {
41
+ ...layoutProps
42
+ }, [], {
46
43
  layoutRef
47
44
  });
48
45
  return <Image {...innerProps}/>;