@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
|
@@ -2,8 +2,10 @@ const postcss = require('postcss')
|
|
|
2
2
|
const selectorParser = require('postcss-selector-parser')
|
|
3
3
|
const getRulesRunner = require('../platform/index')
|
|
4
4
|
const dash2hump = require('../utils/hump-dash').dash2hump
|
|
5
|
-
const
|
|
6
|
-
const
|
|
5
|
+
const unitRegExp = /^\s*(-?\d+(?:\.\d+)?)(rpx|vw|vh)\s*$/
|
|
6
|
+
const numberRegExp = /^\s*(-?\d+(\.\d+)?)(px)?\s*$/
|
|
7
|
+
const hairlineRegExp = /^\s*hairlineWidth\s*$/
|
|
8
|
+
const varRegExp = /^--/
|
|
7
9
|
const cssPrefixExp = /^-(webkit|moz|ms|o)-/
|
|
8
10
|
function getClassMap ({ content, filename, mode, srcMode, warn, error }) {
|
|
9
11
|
const classMap = {}
|
|
@@ -15,11 +17,11 @@ function getClassMap ({ content, filename, mode, srcMode, warn, error }) {
|
|
|
15
17
|
function formatValue (value) {
|
|
16
18
|
let matched
|
|
17
19
|
let needStringify = true
|
|
18
|
-
if ((matched =
|
|
20
|
+
if ((matched = numberRegExp.exec(value))) {
|
|
19
21
|
value = matched[1]
|
|
20
22
|
needStringify = false
|
|
21
|
-
} else if ((
|
|
22
|
-
value = `
|
|
23
|
+
} else if (unitRegExp.test(value) || hairlineRegExp.test(value)) {
|
|
24
|
+
value = `global.__formatValue(${JSON.stringify(value)})`
|
|
23
25
|
needStringify = false
|
|
24
26
|
}
|
|
25
27
|
return needStringify ? JSON.stringify(value) : value
|
|
@@ -38,13 +40,13 @@ function getClassMap ({ content, filename, mode, srcMode, warn, error }) {
|
|
|
38
40
|
const classMapValue = {}
|
|
39
41
|
rule.walkDecls(({ prop, value }) => {
|
|
40
42
|
if (cssPrefixExp.test(prop) || cssPrefixExp.test(value)) return
|
|
41
|
-
let newData = rulesRunner({ prop, value })
|
|
43
|
+
let newData = rulesRunner({ prop, value, selector: rule.selector })
|
|
42
44
|
if (!newData) return
|
|
43
45
|
if (!Array.isArray(newData)) {
|
|
44
46
|
newData = [newData]
|
|
45
47
|
}
|
|
46
48
|
newData.forEach(item => {
|
|
47
|
-
prop = dash2hump(item.prop)
|
|
49
|
+
prop = varRegExp.test(item.prop) ? item.prop : dash2hump(item.prop)
|
|
48
50
|
value = item.value
|
|
49
51
|
if (Array.isArray(value)) {
|
|
50
52
|
value = value.map(val => {
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { createContext, Dispatch, MutableRefObject, SetStateAction } from 'react'
|
|
1
|
+
import { createContext, Dispatch, MutableRefObject, SetStateAction } from 'react'
|
|
2
2
|
import { NativeSyntheticEvent } from 'react-native'
|
|
3
3
|
|
|
4
4
|
export type LabelContextValue = MutableRefObject<{
|
|
@@ -15,14 +15,14 @@ export interface GroupContextValue {
|
|
|
15
15
|
}
|
|
16
16
|
|
|
17
17
|
export interface FormFieldValue {
|
|
18
|
-
getValue: () => any
|
|
19
|
-
resetValue: ({ newVal, type }: { newVal?: any; type?: string }) => void
|
|
18
|
+
getValue: () => any
|
|
19
|
+
resetValue: ({ newVal, type }: { newVal?: any; type?: string }) => void
|
|
20
20
|
}
|
|
21
21
|
|
|
22
22
|
export interface FormContextValue {
|
|
23
|
-
formValuesMap: Map<string, FormFieldValue
|
|
24
|
-
submit: () => void
|
|
25
|
-
reset: () => void
|
|
23
|
+
formValuesMap: Map<string, FormFieldValue>
|
|
24
|
+
submit: () => void
|
|
25
|
+
reset: () => void
|
|
26
26
|
}
|
|
27
27
|
|
|
28
28
|
export const MovableAreaContext = createContext({ width: 0, height: 0 })
|
|
@@ -35,4 +35,6 @@ export const RadioGroupContext = createContext<GroupContextValue | null>(null)
|
|
|
35
35
|
|
|
36
36
|
export const LabelContext = createContext<LabelContextValue | null>(null)
|
|
37
37
|
|
|
38
|
-
export const PickerContext = createContext(null)
|
|
38
|
+
export const PickerContext = createContext(null)
|
|
39
|
+
|
|
40
|
+
export const VarContext = createContext({})
|
|
@@ -71,7 +71,7 @@ export const getCustomEvent = (type = '', oe = {}, { detail = {}, layoutRef }, p
|
|
|
71
71
|
preventDefault: oe.preventDefault
|
|
72
72
|
};
|
|
73
73
|
};
|
|
74
|
-
const useInnerProps = (props = {}, additionalProps = {},
|
|
74
|
+
const useInnerProps = (props = {}, additionalProps = {}, userRemoveProps = [], rawConfig) => {
|
|
75
75
|
const ref = useRef({
|
|
76
76
|
startTimer: {
|
|
77
77
|
bubble: null,
|
|
@@ -91,6 +91,17 @@ const useInnerProps = (props = {}, additionalProps = {}, removeProps = [], rawCo
|
|
|
91
91
|
const propsRef = useRef({});
|
|
92
92
|
const eventConfig = {};
|
|
93
93
|
const config = rawConfig || { layoutRef: { current: {} }, disableTouch: false, disableTap: false };
|
|
94
|
+
const removeProps = [
|
|
95
|
+
'children',
|
|
96
|
+
'enable-background',
|
|
97
|
+
'enable-offset',
|
|
98
|
+
'enable-var',
|
|
99
|
+
'external-var-context',
|
|
100
|
+
'parent-font-size',
|
|
101
|
+
'parent-width',
|
|
102
|
+
'parent-height',
|
|
103
|
+
...userRemoveProps
|
|
104
|
+
];
|
|
94
105
|
propsRef.current = { ...props, ...additionalProps };
|
|
95
106
|
for (const key in eventConfigMap) {
|
|
96
107
|
if (propsRef.current[key]) {
|
|
@@ -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,35 @@ 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 = useRef(null);
|
|
183
|
+
useNodesRef(props, ref, nodeRef, { defaultStyle });
|
|
184
|
+
const { layoutRef, layoutStyle, layoutProps } = useLayout({ props, hasSelfPercent, setWidth, setHeight, nodeRef });
|
|
185
|
+
const { textStyle, backgroundStyle, innerStyle } = splitStyle(normalStyle);
|
|
186
|
+
if (backgroundStyle) {
|
|
187
|
+
warn('Button does not support background image-related styles!');
|
|
188
|
+
}
|
|
180
189
|
const handleOpenTypeEvent = (evt) => {
|
|
181
190
|
if (!openType)
|
|
182
191
|
return;
|
|
@@ -184,7 +193,7 @@ const Button = forwardRef((props, ref) => {
|
|
|
184
193
|
if (openType === 'share') {
|
|
185
194
|
handleEvent && handleEvent({
|
|
186
195
|
from: 'button',
|
|
187
|
-
target: getCustomEvent('tap', evt, { layoutRef }, props).target
|
|
196
|
+
target: getCustomEvent('tap', evt, { layoutRef }, props).target
|
|
188
197
|
});
|
|
189
198
|
}
|
|
190
199
|
if (openType === 'getUserInfo' && handleEvent && bindgetuserinfo) {
|
|
@@ -237,54 +246,24 @@ const Button = forwardRef((props, ref) => {
|
|
|
237
246
|
handleOpenTypeEvent(evt);
|
|
238
247
|
handleFormTypeFn();
|
|
239
248
|
};
|
|
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
249
|
const innerProps = useInnerProps(props, {
|
|
268
250
|
ref: nodeRef,
|
|
251
|
+
style: { ...innerStyle, ...layoutStyle },
|
|
252
|
+
...layoutProps,
|
|
269
253
|
bindtouchstart: onTouchStart,
|
|
270
254
|
bindtouchend: onTouchEnd,
|
|
271
|
-
bindtap: onTap
|
|
272
|
-
|
|
273
|
-
}, [
|
|
274
|
-
'enable-offset'
|
|
275
|
-
], {
|
|
255
|
+
bindtap: onTap
|
|
256
|
+
}, [], {
|
|
276
257
|
layoutRef,
|
|
277
258
|
disableTap: disabled
|
|
278
259
|
});
|
|
279
|
-
return (<View {...innerProps}
|
|
280
|
-
...defaultViewStyle,
|
|
281
|
-
...innerStyle,
|
|
282
|
-
...(applyHoverEffect && hoverInnerStyle),
|
|
283
|
-
}}>
|
|
260
|
+
return (<View {...innerProps}>
|
|
284
261
|
{loading && <Loading alone={!children}/>}
|
|
285
|
-
{wrapChildren(
|
|
286
|
-
|
|
287
|
-
|
|
262
|
+
{wrapChildren(props, {
|
|
263
|
+
hasVarDec,
|
|
264
|
+
varContext: varContextRef.current,
|
|
265
|
+
textStyle,
|
|
266
|
+
textProps
|
|
288
267
|
})}
|
|
289
268
|
</View>);
|
|
290
269
|
});
|
|
@@ -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,19 @@ 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 = useRef(null);
|
|
29
|
+
useNodesRef(props, ref, nodeRef, { defaultStyle });
|
|
30
|
+
const { layoutRef, layoutStyle, layoutProps } = useLayout({ props, hasSelfPercent, setWidth, setHeight, nodeRef });
|
|
32
31
|
const getSelectionValue = () => {
|
|
33
32
|
const arr = [];
|
|
34
|
-
for (
|
|
33
|
+
for (const key in groupValue) {
|
|
35
34
|
if (groupValue[key].checked) {
|
|
36
35
|
arr.push(key);
|
|
37
36
|
}
|
|
@@ -49,7 +48,7 @@ const CheckboxGroup = forwardRef((props, ref) => {
|
|
|
49
48
|
};
|
|
50
49
|
if (formValuesMap) {
|
|
51
50
|
if (!props.name) {
|
|
52
|
-
|
|
51
|
+
warn('If a form component is used, the name attribute is required.');
|
|
53
52
|
}
|
|
54
53
|
else {
|
|
55
54
|
formValuesMap.set(props.name, { getValue, resetValue });
|
|
@@ -66,14 +65,17 @@ const CheckboxGroup = forwardRef((props, ref) => {
|
|
|
66
65
|
};
|
|
67
66
|
const innerProps = useInnerProps(props, {
|
|
68
67
|
ref: nodeRef,
|
|
69
|
-
style:
|
|
70
|
-
...
|
|
71
|
-
}, [
|
|
68
|
+
style: { ...normalStyle, ...layoutStyle },
|
|
69
|
+
...layoutProps
|
|
70
|
+
}, [], {
|
|
72
71
|
layoutRef
|
|
73
72
|
});
|
|
74
73
|
return (<View {...innerProps}>
|
|
75
74
|
<CheckboxGroupContext.Provider value={{ groupValue, notifyChange }}>
|
|
76
|
-
{
|
|
75
|
+
{wrapChildren(props, {
|
|
76
|
+
hasVarDec,
|
|
77
|
+
varContext: varContextRef.current
|
|
78
|
+
})}
|
|
77
79
|
</CheckboxGroupContext.Provider>
|
|
78
80
|
</View>);
|
|
79
81
|
});
|
|
@@ -4,12 +4,13 @@
|
|
|
4
4
|
* ✔ checked
|
|
5
5
|
* ✔ color
|
|
6
6
|
*/
|
|
7
|
-
import {
|
|
8
|
-
import { View,
|
|
7
|
+
import { useState, useRef, 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,17 @@ const Checkbox = forwardRef((props, ref) => {
|
|
|
78
75
|
catchtap && catchtap(getCustomEvent('tap', evt, { layoutRef }, props));
|
|
79
76
|
onChange(evt);
|
|
80
77
|
};
|
|
81
|
-
const {
|
|
78
|
+
const { hasSelfPercent, normalStyle, hasVarDec, varContextRef, setWidth, setHeight } = useTransformStyle(styleObj, { enableVar, externalVarContext, parentFontSize, parentWidth, parentHeight });
|
|
79
|
+
const nodeRef = useRef(null);
|
|
80
|
+
useNodesRef(props, ref, nodeRef, {
|
|
82
81
|
defaultStyle,
|
|
83
82
|
change: onChange
|
|
84
83
|
});
|
|
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
|
-
};
|
|
84
|
+
const { layoutRef, layoutStyle, layoutProps } = useLayout({ props, hasSelfPercent, setWidth, setHeight, nodeRef });
|
|
85
|
+
const { textStyle, backgroundStyle, innerStyle } = splitStyle(normalStyle);
|
|
86
|
+
if (backgroundStyle) {
|
|
87
|
+
warn('Checkbox does not support background image-related styles!');
|
|
88
|
+
}
|
|
106
89
|
const labelContext = useContext(LabelContext);
|
|
107
90
|
if (groupContext) {
|
|
108
91
|
groupValue = groupContext.groupValue;
|
|
@@ -113,11 +96,11 @@ const Checkbox = forwardRef((props, ref) => {
|
|
|
113
96
|
}
|
|
114
97
|
const innerProps = useInnerProps(props, {
|
|
115
98
|
ref: nodeRef,
|
|
116
|
-
style:
|
|
99
|
+
style: { ...innerStyle, ...layoutStyle },
|
|
100
|
+
...layoutProps,
|
|
117
101
|
bindtap: onTap,
|
|
118
|
-
catchtap: catchTap
|
|
119
|
-
|
|
120
|
-
}, ['enable-offset'], {
|
|
102
|
+
catchtap: catchTap
|
|
103
|
+
}, [], {
|
|
121
104
|
layoutRef
|
|
122
105
|
});
|
|
123
106
|
useEffect(() => {
|
|
@@ -142,10 +125,15 @@ const Checkbox = forwardRef((props, ref) => {
|
|
|
142
125
|
}
|
|
143
126
|
}, [checked]);
|
|
144
127
|
return (<View {...innerProps}>
|
|
145
|
-
<View style={
|
|
128
|
+
<View style={defaultStyle}>
|
|
146
129
|
<Icon type='success_no_circle' size={18} color={disabled ? '#ADADAD' : color} style={isChecked ? styles.iconChecked : styles.icon}/>
|
|
147
130
|
</View>
|
|
148
|
-
{wrapChildren(
|
|
131
|
+
{wrapChildren(props, {
|
|
132
|
+
hasVarDec,
|
|
133
|
+
varContext: varContextRef.current,
|
|
134
|
+
textStyle,
|
|
135
|
+
textProps
|
|
136
|
+
})}
|
|
149
137
|
</View>);
|
|
150
138
|
});
|
|
151
139
|
Checkbox.displayName = 'mpx-checkbox';
|
|
@@ -9,20 +9,20 @@ 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 {
|
|
17
|
-
const
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
};
|
|
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);
|
|
19
|
+
const formRef = useRef(null);
|
|
20
|
+
useNodesRef(props, ref, formRef);
|
|
21
|
+
const { layoutRef, layoutStyle, layoutProps } = useLayout({ props, hasSelfPercent, setWidth, setHeight, nodeRef: formRef });
|
|
22
22
|
const submit = () => {
|
|
23
23
|
const { bindsubmit } = props;
|
|
24
24
|
const formValue = {};
|
|
25
|
-
for (
|
|
25
|
+
for (const name of formValuesMap.keys()) {
|
|
26
26
|
if (formValuesMap.get(name).getValue) {
|
|
27
27
|
formValue[name] = formValuesMap.get(name).getValue();
|
|
28
28
|
}
|
|
@@ -40,18 +40,21 @@ const _Form = forwardRef((props, ref) => {
|
|
|
40
40
|
formValuesMap.forEach(item => item.resetValue());
|
|
41
41
|
};
|
|
42
42
|
const innerProps = useInnerProps(props, {
|
|
43
|
+
style: { ...innerStyle, ...layoutStyle },
|
|
43
44
|
ref: formRef,
|
|
44
|
-
|
|
45
|
-
onLayout
|
|
45
|
+
...layoutProps
|
|
46
46
|
}, [
|
|
47
|
-
'children',
|
|
48
|
-
'style',
|
|
49
47
|
'bindsubmit',
|
|
50
48
|
'bindreset'
|
|
51
49
|
], { layoutRef });
|
|
52
50
|
return (<View {...innerProps}>
|
|
53
51
|
<FormContext.Provider value={{ formValuesMap, submit, reset }}>
|
|
54
|
-
{
|
|
52
|
+
{wrapChildren(props, {
|
|
53
|
+
hasVarDec,
|
|
54
|
+
varContext: varContextRef.current,
|
|
55
|
+
textStyle,
|
|
56
|
+
textProps
|
|
57
|
+
})}
|
|
55
58
|
</FormContext.Provider>
|
|
56
59
|
</View>);
|
|
57
60
|
});
|