@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.
Files changed (95) hide show
  1. package/lib/config.js +38 -10
  2. package/lib/index.js +1 -3
  3. package/lib/platform/style/wx/index.js +115 -66
  4. package/lib/platform/template/wx/index.js +12 -8
  5. package/lib/react/processStyles.js +1 -0
  6. package/lib/react/processTemplate.js +2 -3
  7. package/lib/react/style-helper.js +9 -7
  8. package/lib/runtime/components/react/context.ts +9 -7
  9. package/lib/runtime/components/react/dist/context.js +1 -0
  10. package/lib/runtime/components/react/dist/getInnerListeners.js +12 -1
  11. package/lib/runtime/components/react/dist/mpx-button.jsx +53 -74
  12. package/lib/runtime/components/react/dist/mpx-checkbox-group.jsx +20 -18
  13. package/lib/runtime/components/react/dist/mpx-checkbox.jsx +30 -42
  14. package/lib/runtime/components/react/dist/mpx-form.jsx +18 -15
  15. package/lib/runtime/components/react/dist/mpx-icon.jsx +15 -17
  16. package/lib/runtime/components/react/dist/mpx-image/index.jsx +36 -34
  17. package/lib/runtime/components/react/dist/mpx-image/svg.jsx +3 -1
  18. package/lib/runtime/components/react/dist/mpx-input.jsx +36 -31
  19. package/lib/runtime/components/react/dist/mpx-label.jsx +30 -37
  20. package/lib/runtime/components/react/dist/mpx-movable-area.jsx +15 -19
  21. package/lib/runtime/components/react/dist/mpx-movable-view.jsx +10 -9
  22. package/lib/runtime/components/react/dist/mpx-picker/date.jsx +2 -1
  23. package/lib/runtime/components/react/dist/mpx-picker/index.jsx +11 -10
  24. package/lib/runtime/components/react/dist/mpx-picker/multiSelector.jsx +9 -5
  25. package/lib/runtime/components/react/dist/mpx-picker/region.jsx +13 -8
  26. package/lib/runtime/components/react/dist/mpx-picker/selector.jsx +3 -2
  27. package/lib/runtime/components/react/dist/mpx-picker/time.jsx +22 -20
  28. package/lib/runtime/components/react/dist/mpx-picker-view-column.jsx +103 -10
  29. package/lib/runtime/components/react/dist/mpx-picker-view.jsx +149 -54
  30. package/lib/runtime/components/react/dist/mpx-radio-group.jsx +20 -18
  31. package/lib/runtime/components/react/dist/mpx-radio.jsx +29 -43
  32. package/lib/runtime/components/react/dist/mpx-root-portal.jsx +8 -4
  33. package/lib/runtime/components/react/dist/mpx-scroll-view.jsx +36 -27
  34. package/lib/runtime/components/react/dist/mpx-swiper/carouse.jsx +141 -75
  35. package/lib/runtime/components/react/dist/mpx-swiper/index.jsx +16 -7
  36. package/lib/runtime/components/react/dist/mpx-swiper-item.jsx +20 -11
  37. package/lib/runtime/components/react/dist/mpx-switch.jsx +18 -14
  38. package/lib/runtime/components/react/dist/mpx-text.jsx +20 -35
  39. package/lib/runtime/components/react/dist/mpx-textarea.jsx +1 -1
  40. package/lib/runtime/components/react/dist/mpx-view.jsx +296 -210
  41. package/lib/runtime/components/react/dist/mpx-web-view.jsx +11 -7
  42. package/lib/runtime/components/react/dist/parser.js +218 -0
  43. package/lib/runtime/components/react/dist/useNodesRef.js +1 -5
  44. package/lib/runtime/components/react/dist/utils.jsx +445 -0
  45. package/lib/runtime/components/react/getInnerListeners.ts +18 -8
  46. package/lib/runtime/components/react/mpx-button.tsx +83 -91
  47. package/lib/runtime/components/react/mpx-checkbox-group.tsx +50 -43
  48. package/lib/runtime/components/react/mpx-checkbox.tsx +56 -64
  49. package/lib/runtime/components/react/mpx-form.tsx +51 -22
  50. package/lib/runtime/components/react/mpx-icon.tsx +31 -27
  51. package/lib/runtime/components/react/mpx-image/index.tsx +54 -47
  52. package/lib/runtime/components/react/mpx-image/svg.tsx +5 -3
  53. package/lib/runtime/components/react/mpx-input.tsx +59 -38
  54. package/lib/runtime/components/react/mpx-label.tsx +55 -59
  55. package/lib/runtime/components/react/mpx-movable-area.tsx +40 -25
  56. package/lib/runtime/components/react/mpx-movable-view.tsx +29 -29
  57. package/lib/runtime/components/react/mpx-navigator.tsx +2 -2
  58. package/lib/runtime/components/react/mpx-picker/date.tsx +4 -4
  59. package/lib/runtime/components/react/mpx-picker/index.tsx +12 -11
  60. package/lib/runtime/components/react/mpx-picker/multiSelector.tsx +17 -13
  61. package/lib/runtime/components/react/mpx-picker/region.tsx +23 -19
  62. package/lib/runtime/components/react/mpx-picker/selector.tsx +7 -7
  63. package/lib/runtime/components/react/mpx-picker/time.tsx +29 -31
  64. package/lib/runtime/components/react/mpx-picker/type.ts +1 -1
  65. package/lib/runtime/components/react/mpx-picker-view-column.tsx +149 -20
  66. package/lib/runtime/components/react/mpx-picker-view.tsx +180 -63
  67. package/lib/runtime/components/react/mpx-radio-group.tsx +51 -47
  68. package/lib/runtime/components/react/mpx-radio.tsx +57 -72
  69. package/lib/runtime/components/react/mpx-root-portal.tsx +10 -8
  70. package/lib/runtime/components/react/mpx-scroll-view.tsx +136 -104
  71. package/lib/runtime/components/react/mpx-swiper/carouse.tsx +175 -96
  72. package/lib/runtime/components/react/mpx-swiper/index.tsx +21 -9
  73. package/lib/runtime/components/react/mpx-swiper/type.ts +16 -5
  74. package/lib/runtime/components/react/mpx-swiper-item.tsx +48 -14
  75. package/lib/runtime/components/react/mpx-switch.tsx +46 -24
  76. package/lib/runtime/components/react/mpx-text.tsx +38 -45
  77. package/lib/runtime/components/react/mpx-textarea.tsx +1 -1
  78. package/lib/runtime/components/react/mpx-view.tsx +401 -241
  79. package/lib/runtime/components/react/mpx-web-view.tsx +22 -22
  80. package/lib/runtime/components/react/parser.ts +245 -0
  81. package/lib/runtime/components/react/types/common.ts +4 -4
  82. package/lib/runtime/components/react/types/global.d.ts +24 -2
  83. package/lib/runtime/components/react/useNodesRef.ts +1 -7
  84. package/lib/runtime/components/react/utils.tsx +524 -0
  85. package/lib/runtime/components/web/mpx-scroll-view.vue +25 -5
  86. package/lib/style-compiler/index.js +5 -4
  87. package/lib/template-compiler/compiler.js +133 -161
  88. package/lib/template-compiler/gen-node-react.js +1 -3
  89. package/lib/utils/const.js +2 -1
  90. package/lib/web/processStyles.js +2 -1
  91. package/lib/web/processTemplate.js +2 -3
  92. package/lib/wxml/loader.js +1 -1
  93. package/package.json +7 -4
  94. package/lib/runtime/components/react/dist/utils.js +0 -148
  95. package/lib/runtime/components/react/utils.ts +0 -170
@@ -3,10 +3,11 @@
3
3
  * ✔ size
4
4
  * ✔ color
5
5
  */
6
- import { useRef, forwardRef } from 'react';
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-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 = 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
- ...defaultStyle,
38
- tintColor: color,
39
- ...style
37
+ ...normalStyle,
38
+ ...layoutStyle,
39
+ tintColor: color
40
40
  },
41
41
  source: { uri },
42
- ...(enableOffset ? { onLayout } : {})
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, } from 'react-native';
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-offset': enableOffset, bindload, binderror } = props;
60
- const { width = DEFAULT_IMAGE_WIDTH, height = DEFAULT_IMAGE_HEIGHT } = style;
61
- const { nodeRef } = useNodesRef(props, ref, {
62
- defaultStyle: {
63
- width: DEFAULT_IMAGE_WIDTH,
64
- height: DEFAULT_IMAGE_HEIGHT
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 layoutRef = useRef({});
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
- ...(enableOffset ? { onLayout: onImageLayout } : {})
185
- }, [
186
- 'enable-offset'
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 style={{
209
- width, height,
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: !isCropMode ? '100%' : imageWidth,
218
- height: !isCropMode ? '100%' : imageHeight,
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 ? (<WithLocalSvg style={style} asset={src} width={width} height={height}/>) : (<SvgCssUri style={style} uri={src} width={width} height={height}/>);
3
+ return local
4
+ ? (<WithLocalSvg style={style} asset={src} width={width} height={height}/>)
5
+ : (<SvgCssUri style={style} uri={src} width={width} height={height}/>);
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 { parseInlineStyle, useUpdateEffect, throwReactWarning } from './utils';
42
+ import { warn } from '@mpxjs/utils';
43
+ import { parseInlineStyle, useUpdateEffect, useTransformStyle, useLayout } from './utils';
43
44
  import useInnerProps, { getCustomEvent } from './getInnerListeners';
44
45
  import useNodesRef from './useNodesRef';
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-offset': enableOffset, bindinput, bindfocus, bindblur, bindconfirm, bindselectionchange,
57
+ const { style = {}, type = 'text', value, password, 'placeholder-style': placeholderStyle, disabled, maxlength = 140, 'auto-focus': autoFocus, focus, 'confirm-type': confirmType = 'done', 'confirm-hold': confirmHold = false, cursor, 'cursor-color': cursorColor, 'selection-start': selectionStart = -1, 'selection-end': selectionEnd = -1, 'enable-var': enableVar, 'external-var-context': externalVarContext, 'parent-font-size': parentFontSize, 'parent-width': parentWidth, 'parent-height': parentHeight, bindinput, bindfocus, bindblur, bindconfirm, bindselectionchange,
57
58
  // private
58
- multiline, 'auto-height': autoHeight, bindlinechange, } = props;
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, } = nativeEvent;
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
- throwReactWarning('[Mpx runtime warn]: If a form component is used, the name attribute is required.');
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
- ...(enableOffset ? { onLayout } : {}),
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
- ...style,
218
+ ...composeStyle,
219
219
  ...multiline && autoHeight && {
220
- height: Math.max(style?.minHeight || 35, contentHeight)
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, Text, } from 'react-native';
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 { every, splitStyle, splitProps, isText, throwReactWarning } from './utils';
9
+ import { splitProps, splitStyle, useLayout, useTransformStyle, wrapChildren } from './utils';
9
10
  import { LabelContext } from './context';
10
- const Label = forwardRef((props, ref) => {
11
- const { style = {}, 'enable-offset': enableOffset, children, bindtap } = props;
12
- const { textStyle, imageStyle, innerStyle } = splitStyle(style);
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: { ...defaultStyle, ...innerStyle },
51
- bindtap: onTap,
52
- ...(enableOffset ? { onLayout } : {})
53
- }, ['enable-offset'], {
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(children, textStyle)}
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, useRef, forwardRef } from 'react';
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 { children, style = {}, width = 10, height = 10 } = props;
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 { nodeRef: movableViewRef } = useNodesRef(props, ref);
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
- onLayout
30
- }, [
31
- 'children',
32
- 'style',
33
- ], { layoutRef });
30
+ ...layoutProps
31
+ }, [], { layoutRef });
34
32
  return (<MovableAreaContext.Provider value={{ height: areaHeight, width: areaWidth }}>
35
- <View {...innerProps} style={{
36
- height: areaHeight,
37
- width: areaWidth,
38
- overflow: 'hidden',
39
- ...style
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 { nodeRef } = useNodesRef(props, ref, {
44
+ const nodeRef = useRef(null);
45
+ useNodesRef(props, ref, nodeRef, {
45
46
  defaultStyle: styles.container
46
47
  });
47
48
  let panResponder = {};
48
- let isFirstTouch = useRef(true);
49
- let touchEvent = useRef('');
50
- let initialDistance = useRef(0);
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() ? { 'bindtouchmove': onTouchMove } : {}),
320
- ...(hasCatchTouchmove() ? { 'catchtouchmove': onCatchTouchMove } : {}),
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 { nodeRef: viewRef } = useNodesRef(props, ref, {});
30
+ const viewRef = useRef(null);
31
+ useNodesRef(props, ref, viewRef, {});
31
32
  useEffect(() => {
32
33
  value && setDateValue(value);
33
34
  }, [value]);