@mpxjs/webpack-plugin 2.9.66 → 2.9.69
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/dependencies/RecordGlobalComponentsDependency.js +11 -12
- package/lib/dependencies/RecordRuntimeInfoDependency.js +1 -1
- package/lib/index.js +29 -8
- package/lib/json-compiler/index.js +2 -11
- package/lib/loader.js +24 -45
- package/lib/native-loader.js +49 -64
- package/lib/platform/json/wx/index.js +3 -10
- package/lib/platform/style/wx/index.js +15 -10
- package/lib/platform/template/wx/component-config/canvas.js +8 -0
- package/lib/platform/template/wx/component-config/unsupported.js +1 -1
- package/lib/react/index.js +4 -3
- package/lib/react/processJSON.js +5 -13
- package/lib/react/processMainScript.js +7 -3
- package/lib/react/processScript.js +3 -4
- package/lib/react/processStyles.js +14 -4
- package/lib/react/processTemplate.js +2 -2
- package/lib/resolver/AddModePlugin.js +20 -7
- package/lib/runtime/components/react/context.ts +2 -0
- package/lib/runtime/components/react/dist/context.js +1 -0
- package/lib/runtime/components/react/dist/getInnerListeners.js +3 -12
- package/lib/runtime/components/react/dist/mpx-button.jsx +44 -9
- package/lib/runtime/components/react/dist/mpx-canvas/Bus.js +60 -0
- package/lib/runtime/components/react/dist/mpx-canvas/CanvasGradient.js +15 -0
- package/lib/runtime/components/react/dist/mpx-canvas/CanvasRenderingContext2D.js +84 -0
- package/lib/runtime/components/react/dist/mpx-canvas/Image.js +87 -0
- package/lib/runtime/components/react/dist/mpx-canvas/ImageData.js +15 -0
- package/lib/runtime/components/react/dist/mpx-canvas/constructorsRegistry.js +28 -0
- package/lib/runtime/components/react/dist/mpx-canvas/html.js +343 -0
- package/lib/runtime/components/react/dist/mpx-canvas/index.jsx +214 -0
- package/lib/runtime/components/react/dist/mpx-canvas/utils.jsx +89 -0
- package/lib/runtime/components/react/dist/mpx-checkbox-group.jsx +30 -17
- package/lib/runtime/components/react/dist/mpx-checkbox.jsx +1 -1
- package/lib/runtime/components/react/dist/mpx-form.jsx +33 -24
- package/lib/runtime/components/react/dist/mpx-icon.jsx +1 -1
- package/lib/runtime/components/react/dist/mpx-image/index.jsx +1 -1
- package/lib/runtime/components/react/dist/mpx-input.jsx +44 -38
- package/lib/runtime/components/react/dist/mpx-label.jsx +10 -7
- package/lib/runtime/components/react/dist/mpx-movable-area.jsx +10 -17
- package/lib/runtime/components/react/dist/mpx-movable-view.jsx +378 -294
- package/lib/runtime/components/react/dist/mpx-navigator.jsx +1 -1
- package/lib/runtime/components/react/dist/mpx-picker-view-column.jsx +143 -84
- package/lib/runtime/components/react/dist/mpx-picker-view.jsx +69 -113
- package/lib/runtime/components/react/dist/mpx-radio-group.jsx +30 -17
- package/lib/runtime/components/react/dist/mpx-radio.jsx +1 -1
- package/lib/runtime/components/react/dist/mpx-root-portal.jsx +1 -1
- package/lib/runtime/components/react/dist/mpx-scroll-view.jsx +49 -29
- package/lib/runtime/components/react/dist/mpx-swiper/carouse.jsx +1 -1
- package/lib/runtime/components/react/dist/mpx-swiper/index.jsx +1 -1
- package/lib/runtime/components/react/dist/mpx-swiper-item.jsx +1 -1
- package/lib/runtime/components/react/dist/mpx-switch.jsx +8 -1
- package/lib/runtime/components/react/dist/mpx-text.jsx +1 -1
- package/lib/runtime/components/react/dist/mpx-textarea.jsx +1 -1
- package/lib/runtime/components/react/dist/mpx-view.jsx +46 -27
- package/lib/runtime/components/react/dist/mpx-web-view.jsx +20 -6
- package/lib/runtime/components/react/dist/pickerFaces.js +75 -0
- package/lib/runtime/components/react/dist/pickerOverlay.jsx +21 -0
- package/lib/runtime/components/react/dist/useAnimationHooks.js +96 -8
- package/lib/runtime/components/react/dist/utils.jsx +66 -6
- package/lib/runtime/components/react/getInnerListeners.ts +3 -16
- package/lib/runtime/components/react/mpx-button.tsx +42 -9
- package/lib/runtime/components/react/mpx-canvas/Bus.ts +70 -0
- package/lib/runtime/components/react/mpx-canvas/CanvasGradient.ts +18 -0
- package/lib/runtime/components/react/mpx-canvas/CanvasRenderingContext2D.ts +87 -0
- package/lib/runtime/components/react/mpx-canvas/Image.ts +102 -0
- package/lib/runtime/components/react/mpx-canvas/ImageData.ts +23 -0
- package/lib/runtime/components/react/mpx-canvas/constructorsRegistry.ts +38 -0
- package/lib/runtime/components/react/mpx-canvas/html.ts +343 -0
- package/lib/runtime/components/react/mpx-canvas/index.tsx +302 -0
- package/lib/runtime/components/react/mpx-canvas/utils.tsx +150 -0
- package/lib/runtime/components/react/mpx-checkbox-group.tsx +52 -29
- package/lib/runtime/components/react/mpx-checkbox.tsx +1 -1
- package/lib/runtime/components/react/mpx-form.tsx +42 -34
- package/lib/runtime/components/react/mpx-icon.tsx +1 -1
- package/lib/runtime/components/react/mpx-image/index.tsx +2 -3
- package/lib/runtime/components/react/mpx-input.tsx +68 -66
- package/lib/runtime/components/react/mpx-label.tsx +11 -8
- package/lib/runtime/components/react/mpx-movable-area.tsx +11 -19
- package/lib/runtime/components/react/mpx-movable-view.tsx +456 -334
- package/lib/runtime/components/react/mpx-navigator.tsx +1 -1
- package/lib/runtime/components/react/mpx-picker-view-column.tsx +232 -103
- package/lib/runtime/components/react/mpx-picker-view.tsx +126 -122
- package/lib/runtime/components/react/mpx-radio-group.tsx +55 -29
- package/lib/runtime/components/react/mpx-radio.tsx +1 -1
- package/lib/runtime/components/react/mpx-root-portal.tsx +1 -1
- package/lib/runtime/components/react/mpx-scroll-view.tsx +81 -36
- package/lib/runtime/components/react/mpx-swiper/carouse.tsx +2 -2
- package/lib/runtime/components/react/mpx-swiper/index.tsx +2 -1
- package/lib/runtime/components/react/mpx-swiper-item.tsx +1 -1
- package/lib/runtime/components/react/mpx-switch.tsx +10 -2
- package/lib/runtime/components/react/mpx-text.tsx +1 -1
- package/lib/runtime/components/react/mpx-textarea.tsx +1 -1
- package/lib/runtime/components/react/mpx-view.tsx +58 -28
- package/lib/runtime/components/react/mpx-web-view.tsx +23 -6
- package/lib/runtime/components/react/pickerFaces.ts +104 -0
- package/lib/runtime/components/react/pickerOverlay.tsx +32 -0
- package/lib/runtime/components/react/types/common.ts +2 -0
- package/lib/runtime/components/react/types/global.d.ts +2 -0
- package/lib/runtime/components/react/useAnimationHooks.ts +97 -13
- package/lib/runtime/components/react/useNodesRef.ts +1 -0
- package/lib/runtime/components/react/utils.tsx +94 -8
- package/lib/runtime/optionProcessorReact.js +0 -15
- package/lib/runtime/swanHelper.wxs +1 -1
- package/lib/style-compiler/index.js +1 -1
- package/lib/style-compiler/plugins/scope-id.js +1 -0
- package/lib/template-compiler/compiler.js +47 -16
- package/lib/template-compiler/gen-node-react.js +2 -2
- package/lib/template-compiler/index.js +4 -4
- package/lib/utils/pre-process-json.js +113 -0
- package/lib/web/index.js +5 -4
- package/lib/web/processJSON.js +5 -13
- package/lib/web/processTemplate.js +2 -2
- package/package.json +5 -4
package/lib/react/processJSON.js
CHANGED
|
@@ -12,9 +12,8 @@ const createJSONHelper = require('../json-compiler/helper')
|
|
|
12
12
|
const getRulesRunner = require('../platform/index')
|
|
13
13
|
const { RESOLVE_IGNORED_ERR } = require('../utils/const')
|
|
14
14
|
const RecordResourceMapDependency = require('../dependencies/RecordResourceMapDependency')
|
|
15
|
-
const RecordGlobalComponentsDependency = require('../dependencies/RecordGlobalComponentsDependency')
|
|
16
15
|
|
|
17
|
-
module.exports = function (
|
|
16
|
+
module.exports = function (jsonContent, {
|
|
18
17
|
loaderContext,
|
|
19
18
|
ctorType,
|
|
20
19
|
pagesMap,
|
|
@@ -81,12 +80,11 @@ module.exports = function (json, {
|
|
|
81
80
|
}
|
|
82
81
|
|
|
83
82
|
const isApp = ctorType === 'app'
|
|
84
|
-
if (!
|
|
83
|
+
if (!jsonContent) {
|
|
85
84
|
return callback()
|
|
86
85
|
}
|
|
87
|
-
// 由于json需要提前读取在template处理中使用,src的场景已经在loader中处理了,此处无需考虑json.src的场景
|
|
88
86
|
try {
|
|
89
|
-
jsonObj = JSON5.parse(
|
|
87
|
+
jsonObj = JSON5.parse(jsonContent)
|
|
90
88
|
// 处理runner
|
|
91
89
|
const rulesRunnerOptions = {
|
|
92
90
|
mode,
|
|
@@ -96,8 +94,8 @@ module.exports = function (json, {
|
|
|
96
94
|
warn: emitWarning,
|
|
97
95
|
error: emitError,
|
|
98
96
|
data: {
|
|
99
|
-
// polyfill global usingComponents
|
|
100
|
-
globalComponents: mpx.
|
|
97
|
+
// polyfill global usingComponents
|
|
98
|
+
globalComponents: mpx.globalComponents
|
|
101
99
|
}
|
|
102
100
|
}
|
|
103
101
|
|
|
@@ -110,12 +108,6 @@ module.exports = function (json, {
|
|
|
110
108
|
if (rulesRunner) {
|
|
111
109
|
rulesRunner(jsonObj)
|
|
112
110
|
}
|
|
113
|
-
if (isApp) {
|
|
114
|
-
// 收集全局组件
|
|
115
|
-
Object.assign(mpx.usingComponents, jsonObj.usingComponents)
|
|
116
|
-
// 在 rulesRunner 运行后保存全局注册组件
|
|
117
|
-
loaderContext._module.addPresentationalDependency(new RecordGlobalComponentsDependency(mpx.usingComponents, loaderContext.context))
|
|
118
|
-
}
|
|
119
111
|
} catch (e) {
|
|
120
112
|
return callback(e)
|
|
121
113
|
}
|
|
@@ -8,7 +8,7 @@ const {
|
|
|
8
8
|
module.exports = function ({
|
|
9
9
|
loaderContext
|
|
10
10
|
}, callback) {
|
|
11
|
-
const { i18n,
|
|
11
|
+
const { i18n, rnConfig } = loaderContext.getMpx()
|
|
12
12
|
|
|
13
13
|
let output = 'import { AppRegistry } from \'react-native\'\n'
|
|
14
14
|
|
|
@@ -16,8 +16,12 @@ module.exports = function ({
|
|
|
16
16
|
output += buildI18n({ loaderContext })
|
|
17
17
|
}
|
|
18
18
|
// 此处可添加前置于App执行的语句
|
|
19
|
-
output += `var
|
|
20
|
-
|
|
19
|
+
output += `var app = require(${stringifyRequest(loaderContext, addQuery(loaderContext.resource, { isApp: true }))}).default\n`
|
|
20
|
+
if (rnConfig.projectName) {
|
|
21
|
+
output += `AppRegistry.registerComponent(${JSON.stringify(rnConfig.projectName)}, () => app)\n`
|
|
22
|
+
} else {
|
|
23
|
+
output += 'export default app\n'
|
|
24
|
+
}
|
|
21
25
|
|
|
22
26
|
callback(null, {
|
|
23
27
|
output
|
|
@@ -24,16 +24,15 @@ module.exports = function (script, {
|
|
|
24
24
|
if (ctorType === 'app') {
|
|
25
25
|
output += `
|
|
26
26
|
import { getComponent } from ${stringifyRequest(loaderContext, optionProcessorPath)}
|
|
27
|
-
import { NavigationContainer,
|
|
28
|
-
import {
|
|
27
|
+
import { NavigationContainer, StackActions } from '@react-navigation/native'
|
|
28
|
+
import { createStackNavigator } from '@react-navigation/stack'
|
|
29
29
|
import { Provider } from '@ant-design/react-native'
|
|
30
30
|
import { SafeAreaProvider, useSafeAreaInsets } from 'react-native-safe-area-context'
|
|
31
31
|
import { GestureHandlerRootView } from 'react-native-gesture-handler'
|
|
32
32
|
|
|
33
33
|
global.__navigationHelper = {
|
|
34
34
|
NavigationContainer: NavigationContainer,
|
|
35
|
-
|
|
36
|
-
createNativeStackNavigator: createNativeStackNavigator,
|
|
35
|
+
createStackNavigator: createStackNavigator,
|
|
37
36
|
StackActions: StackActions,
|
|
38
37
|
GestureHandlerRootView: GestureHandlerRootView,
|
|
39
38
|
Provider: Provider,
|
|
@@ -56,13 +56,23 @@ module.exports = function (styles, {
|
|
|
56
56
|
error
|
|
57
57
|
})
|
|
58
58
|
if (ctorType === 'app') {
|
|
59
|
-
output += `
|
|
60
|
-
|
|
59
|
+
output += `
|
|
60
|
+
let __appClassMap
|
|
61
|
+
global.__getAppClassMap = function() {
|
|
62
|
+
if(!__appClassMap) {
|
|
63
|
+
__appClassMap = ${shallowStringify(classMap)};
|
|
64
|
+
}
|
|
65
|
+
return __appClassMap;
|
|
61
66
|
};\n`
|
|
62
67
|
} else {
|
|
63
|
-
output += `
|
|
68
|
+
output += `
|
|
69
|
+
let __classMap
|
|
70
|
+
global.currentInject.injectMethods = {
|
|
64
71
|
__getClassMap: function() {
|
|
65
|
-
|
|
72
|
+
if(!__classMap) {
|
|
73
|
+
__classMap = ${shallowStringify(classMap)};
|
|
74
|
+
}
|
|
75
|
+
return __classMap;
|
|
66
76
|
}
|
|
67
77
|
};\n`
|
|
68
78
|
}
|
|
@@ -14,7 +14,7 @@ module.exports = function (template, {
|
|
|
14
14
|
srcMode,
|
|
15
15
|
moduleId,
|
|
16
16
|
ctorType,
|
|
17
|
-
|
|
17
|
+
usingComponentsInfo,
|
|
18
18
|
componentGenerics
|
|
19
19
|
}, callback) {
|
|
20
20
|
const mpx = loaderContext.getMpx()
|
|
@@ -64,7 +64,7 @@ module.exports = function (template, {
|
|
|
64
64
|
const { root, meta } = templateCompiler.parse(template.content, {
|
|
65
65
|
warn,
|
|
66
66
|
error,
|
|
67
|
-
|
|
67
|
+
usingComponentsInfo, // processTemplate中无其他地方使用,直接透传 string 类型
|
|
68
68
|
hasComment,
|
|
69
69
|
isNative,
|
|
70
70
|
ctorType,
|
|
@@ -6,16 +6,17 @@ const addInfix = require('../utils/add-infix')
|
|
|
6
6
|
const { JSON_JS_EXT } = require('../utils/const')
|
|
7
7
|
|
|
8
8
|
module.exports = class AddModePlugin {
|
|
9
|
-
constructor (source, mode,
|
|
9
|
+
constructor (source, mode, options, target) {
|
|
10
10
|
this.source = source
|
|
11
11
|
this.target = target
|
|
12
12
|
this.mode = mode
|
|
13
|
-
this.
|
|
13
|
+
this.options = options
|
|
14
14
|
}
|
|
15
15
|
|
|
16
16
|
apply (resolver) {
|
|
17
17
|
const target = resolver.ensureHook(this.target)
|
|
18
|
-
const mode = this
|
|
18
|
+
const { options = {}, mode } = this
|
|
19
|
+
const { defaultMode, fileConditionRules, implicitMode } = options
|
|
19
20
|
resolver.getHook(this.source).tapAsync('AddModePlugin', (request, resolveContext, callback) => {
|
|
20
21
|
if (request.mode || request.env) {
|
|
21
22
|
return callback()
|
|
@@ -31,14 +32,26 @@ module.exports = class AddModePlugin {
|
|
|
31
32
|
extname = path.extname(resourcePath)
|
|
32
33
|
}
|
|
33
34
|
// 当前资源没有后缀名或者路径不符合fileConditionRules规则时,直接返回
|
|
34
|
-
if (!extname || !matchCondition(resourcePath,
|
|
35
|
+
if (!extname || !matchCondition(resourcePath, fileConditionRules)) return callback()
|
|
35
36
|
const queryObj = parseQuery(request.query || '?')
|
|
36
|
-
|
|
37
|
-
|
|
37
|
+
const queryInfix = queryObj.infix
|
|
38
|
+
if (!implicitMode) queryObj.mode = mode
|
|
39
|
+
queryObj.infix = `${queryInfix || ''}.${mode}`
|
|
38
40
|
obj.query = stringifyQuery(queryObj)
|
|
39
41
|
obj.path = addInfix(resourcePath, mode, extname)
|
|
40
42
|
obj.relativePath = request.relativePath && addInfix(request.relativePath, mode, extname)
|
|
41
|
-
resolver.doResolve(target, Object.assign({}, request, obj), 'add mode: ' + mode, resolveContext,
|
|
43
|
+
resolver.doResolve(target, Object.assign({}, request, obj), 'add mode: ' + mode, resolveContext, (err, result) => {
|
|
44
|
+
if (defaultMode && !result) {
|
|
45
|
+
queryObj.infix = `${queryInfix || ''}.${defaultMode}`
|
|
46
|
+
obj.query = stringifyQuery(queryObj)
|
|
47
|
+
obj.path = addInfix(resourcePath, defaultMode, extname)
|
|
48
|
+
resolver.doResolve(target, Object.assign({}, request, obj), 'add mode: ' + defaultMode, resolveContext, (err, result) => {
|
|
49
|
+
callback(err, result)
|
|
50
|
+
})
|
|
51
|
+
return
|
|
52
|
+
}
|
|
53
|
+
callback(err, result)
|
|
54
|
+
})
|
|
42
55
|
})
|
|
43
56
|
}
|
|
44
57
|
}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { useRef } from 'react';
|
|
2
|
+
import { collectDataset } from '@mpxjs/utils';
|
|
2
3
|
import { omit } from './utils';
|
|
3
4
|
import eventConfigMap from './event.config';
|
|
4
5
|
const getTouchEvent = (type, event, props, config) => {
|
|
@@ -13,7 +14,7 @@ const getTouchEvent = (type, event, props, config) => {
|
|
|
13
14
|
currentTarget: {
|
|
14
15
|
...(event.currentTarget || {}),
|
|
15
16
|
id: id || '',
|
|
16
|
-
dataset:
|
|
17
|
+
dataset: collectDataset(props),
|
|
17
18
|
offsetLeft: layoutRef?.current?.offsetLeft || 0,
|
|
18
19
|
offsetTop: layoutRef?.current?.offsetTop || 0
|
|
19
20
|
},
|
|
@@ -44,16 +45,6 @@ const getTouchEvent = (type, event, props, config) => {
|
|
|
44
45
|
preventDefault: event.preventDefault
|
|
45
46
|
};
|
|
46
47
|
};
|
|
47
|
-
export const getDataSet = (props) => {
|
|
48
|
-
const result = {};
|
|
49
|
-
for (const key in props) {
|
|
50
|
-
if (key.indexOf('data-') === 0) {
|
|
51
|
-
const newKey = key.substr(5);
|
|
52
|
-
result[newKey] = props[key];
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
return result;
|
|
56
|
-
};
|
|
57
48
|
export const getCustomEvent = (type = '', oe = {}, { detail = {}, layoutRef }, props = {}) => {
|
|
58
49
|
return {
|
|
59
50
|
...oe,
|
|
@@ -62,7 +53,7 @@ export const getCustomEvent = (type = '', oe = {}, { detail = {}, layoutRef }, p
|
|
|
62
53
|
target: {
|
|
63
54
|
...(oe.target || {}),
|
|
64
55
|
id: props.id || '',
|
|
65
|
-
dataset:
|
|
56
|
+
dataset: collectDataset(props),
|
|
66
57
|
offsetLeft: layoutRef?.current?.offsetLeft || 0,
|
|
67
58
|
offsetTop: layoutRef?.current?.offsetTop || 0
|
|
68
59
|
},
|
|
@@ -37,10 +37,10 @@
|
|
|
37
37
|
import { useEffect, useRef, useState, forwardRef, useContext } from 'react';
|
|
38
38
|
import { View, StyleSheet, Animated, Easing } from 'react-native';
|
|
39
39
|
import { warn } from '@mpxjs/utils';
|
|
40
|
-
import { splitProps, splitStyle, useLayout, useTransformStyle, wrapChildren } from './utils';
|
|
40
|
+
import { getCurrentPage, splitProps, splitStyle, useLayout, useTransformStyle, wrapChildren } from './utils';
|
|
41
41
|
import useInnerProps, { getCustomEvent } from './getInnerListeners';
|
|
42
42
|
import useNodesRef from './useNodesRef';
|
|
43
|
-
import { FormContext } from './context';
|
|
43
|
+
import { RouteContext, FormContext } from './context';
|
|
44
44
|
const LOADING_IMAGE_URI = '';
|
|
45
45
|
const TypeColorMap = {
|
|
46
46
|
default: ['#F8F8F8', '#DEDEDE', '35,35,35', '#F7F7F7'],
|
|
@@ -78,6 +78,8 @@ const styles = StyleSheet.create({
|
|
|
78
78
|
}
|
|
79
79
|
});
|
|
80
80
|
const getOpenTypeEvent = (openType) => {
|
|
81
|
+
if (!openType)
|
|
82
|
+
return;
|
|
81
83
|
if (!global.__mpx?.config?.rnConfig) {
|
|
82
84
|
warn('Environment not supported');
|
|
83
85
|
return;
|
|
@@ -94,6 +96,11 @@ const getOpenTypeEvent = (openType) => {
|
|
|
94
96
|
}
|
|
95
97
|
return event;
|
|
96
98
|
};
|
|
99
|
+
const timer = (data, time = 3000) => new Promise((resolve) => {
|
|
100
|
+
setTimeout(() => {
|
|
101
|
+
resolve(data);
|
|
102
|
+
}, time);
|
|
103
|
+
});
|
|
97
104
|
const Loading = ({ alone = false }) => {
|
|
98
105
|
const image = useRef(new Animated.Value(0)).current;
|
|
99
106
|
const rotate = image.interpolate({
|
|
@@ -123,6 +130,7 @@ const Loading = ({ alone = false }) => {
|
|
|
123
130
|
const Button = forwardRef((buttonProps, ref) => {
|
|
124
131
|
const { textProps, innerProps: props = {} } = splitProps(buttonProps);
|
|
125
132
|
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;
|
|
133
|
+
const pageId = useContext(RouteContext);
|
|
126
134
|
const formContext = useContext(FormContext);
|
|
127
135
|
let submitFn;
|
|
128
136
|
let resetFn;
|
|
@@ -187,16 +195,43 @@ const Button = forwardRef((buttonProps, ref) => {
|
|
|
187
195
|
warn('Button does not support background image-related styles!');
|
|
188
196
|
}
|
|
189
197
|
const handleOpenTypeEvent = (evt) => {
|
|
190
|
-
if (!openType)
|
|
191
|
-
return;
|
|
192
198
|
const handleEvent = getOpenTypeEvent(openType);
|
|
199
|
+
if (!handleEvent)
|
|
200
|
+
return;
|
|
193
201
|
if (openType === 'share') {
|
|
194
|
-
|
|
202
|
+
const currentPage = getCurrentPage(pageId);
|
|
203
|
+
const event = {
|
|
195
204
|
from: 'button',
|
|
196
|
-
target: getCustomEvent('tap', evt, { layoutRef }, props).target
|
|
197
|
-
|
|
205
|
+
target: getCustomEvent('tap', evt, { layoutRef }, props).target,
|
|
206
|
+
webViewUrl: currentPage?.__webViewUrl
|
|
207
|
+
};
|
|
208
|
+
if (currentPage) {
|
|
209
|
+
const defaultMessage = {
|
|
210
|
+
title: global.__mpx.config.rnConfig.projectName || 'AwesomeProject',
|
|
211
|
+
path: currentPage.route || ''
|
|
212
|
+
};
|
|
213
|
+
if (currentPage.onShareAppMessage) {
|
|
214
|
+
const { promise, ...message } = currentPage.onShareAppMessage(event) || {};
|
|
215
|
+
if (promise) {
|
|
216
|
+
Promise.race([Promise.resolve(promise), timer(message)])
|
|
217
|
+
.then((msg) => {
|
|
218
|
+
handleEvent(Object.assign({}, defaultMessage, msg));
|
|
219
|
+
});
|
|
220
|
+
}
|
|
221
|
+
else {
|
|
222
|
+
handleEvent(Object.assign({}, defaultMessage, message));
|
|
223
|
+
}
|
|
224
|
+
}
|
|
225
|
+
else {
|
|
226
|
+
handleEvent(defaultMessage);
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
else {
|
|
230
|
+
warn('Current page not found');
|
|
231
|
+
// Todo handleEvent(event)
|
|
232
|
+
}
|
|
198
233
|
}
|
|
199
|
-
if (openType === 'getUserInfo' &&
|
|
234
|
+
if (openType === 'getUserInfo' && bindgetuserinfo) {
|
|
200
235
|
Promise.resolve(handleEvent)
|
|
201
236
|
.then((userInfo) => {
|
|
202
237
|
if (typeof userInfo === 'object') {
|
|
@@ -267,5 +302,5 @@ const Button = forwardRef((buttonProps, ref) => {
|
|
|
267
302
|
})}
|
|
268
303
|
</View>);
|
|
269
304
|
});
|
|
270
|
-
Button.displayName = '
|
|
305
|
+
Button.displayName = 'MpxButton';
|
|
271
306
|
export default Button;
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import { warn } from '@mpxjs/utils';
|
|
2
|
+
export default class Bus {
|
|
3
|
+
_paused = false;
|
|
4
|
+
_messageListeners = {};
|
|
5
|
+
_queue = [];
|
|
6
|
+
_send;
|
|
7
|
+
_timeoutId = null;
|
|
8
|
+
constructor(send) {
|
|
9
|
+
this._send = send;
|
|
10
|
+
}
|
|
11
|
+
post(message) {
|
|
12
|
+
return new Promise((resolve) => {
|
|
13
|
+
if (message.type !== 'set' && message.id) {
|
|
14
|
+
this._messageListeners[message.id] = resolve;
|
|
15
|
+
}
|
|
16
|
+
if (!this._paused) {
|
|
17
|
+
this._queue.push(message);
|
|
18
|
+
this.startBatching();
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
this._queue.push(message);
|
|
22
|
+
}
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
handle(message) {
|
|
26
|
+
if (!message.id)
|
|
27
|
+
return;
|
|
28
|
+
const handler = this._messageListeners[message.id];
|
|
29
|
+
delete this._messageListeners[message.id];
|
|
30
|
+
if (handler) {
|
|
31
|
+
handler(message);
|
|
32
|
+
}
|
|
33
|
+
else {
|
|
34
|
+
warn(`Received unexpected message: ${message}`);
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
pause() {
|
|
38
|
+
this._paused = true;
|
|
39
|
+
}
|
|
40
|
+
resume() {
|
|
41
|
+
this._paused = false;
|
|
42
|
+
this._send(this._queue);
|
|
43
|
+
this._queue = [];
|
|
44
|
+
}
|
|
45
|
+
startBatching() {
|
|
46
|
+
if (this._timeoutId)
|
|
47
|
+
return;
|
|
48
|
+
this._timeoutId = setTimeout(() => {
|
|
49
|
+
this._send(this._queue);
|
|
50
|
+
this._queue = [];
|
|
51
|
+
this._timeoutId = null;
|
|
52
|
+
}, 16);
|
|
53
|
+
}
|
|
54
|
+
clearBatchingTimeout() {
|
|
55
|
+
if (this._timeoutId) {
|
|
56
|
+
clearTimeout(this._timeoutId);
|
|
57
|
+
this._timeoutId = null;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { registerWebviewMethods } from './utils';
|
|
2
|
+
const METHODS = ['addColorStop'];
|
|
3
|
+
export default class CanvasGradient {
|
|
4
|
+
canvas;
|
|
5
|
+
constructor(canvas, noOnConstruction = false) {
|
|
6
|
+
this.canvas = canvas;
|
|
7
|
+
registerWebviewMethods(this, METHODS);
|
|
8
|
+
if (this.onConstruction && !noOnConstruction) {
|
|
9
|
+
this.onConstruction();
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
postMessage(message) {
|
|
13
|
+
return this.canvas.postMessage(message);
|
|
14
|
+
}
|
|
15
|
+
}
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
import { registerWebviewProperties, registerWebviewMethods, registerWebviewTarget } from './utils';
|
|
2
|
+
const PROPERTIES = {
|
|
3
|
+
direction: 'inherit',
|
|
4
|
+
fillStyle: '#000',
|
|
5
|
+
filter: 'none',
|
|
6
|
+
font: '10px sans-serif',
|
|
7
|
+
fontKerning: 'auto',
|
|
8
|
+
fontStretch: 'auto',
|
|
9
|
+
fontVariantCaps: 'normal',
|
|
10
|
+
globalAlpha: 1.0,
|
|
11
|
+
globalCompositeOperation: 'source-over',
|
|
12
|
+
imageSmoothingEnabled: 'true',
|
|
13
|
+
imageSmoothingQuality: 'low',
|
|
14
|
+
letterSpacing: '0px',
|
|
15
|
+
lineCap: 'butt',
|
|
16
|
+
lineDashOffset: 0.0,
|
|
17
|
+
lineJoin: 'miter',
|
|
18
|
+
lineWidth: 1.0,
|
|
19
|
+
miterLimit: 10.0,
|
|
20
|
+
shadowBlur: 0,
|
|
21
|
+
shadowColor: 'rgba(0,0,0,0)',
|
|
22
|
+
shadowOffsetX: 0,
|
|
23
|
+
shadowOffsetY: 0,
|
|
24
|
+
strokeStyle: '#000',
|
|
25
|
+
textAlign: 'start',
|
|
26
|
+
textBaseline: 'alphabetic',
|
|
27
|
+
textRendering: 'auto',
|
|
28
|
+
wordSpacing: '0px'
|
|
29
|
+
};
|
|
30
|
+
const METHODS = [
|
|
31
|
+
'arc',
|
|
32
|
+
'arcTo',
|
|
33
|
+
'beginPath',
|
|
34
|
+
'bezierCurveTo',
|
|
35
|
+
'clearRect',
|
|
36
|
+
'clip',
|
|
37
|
+
'closePath',
|
|
38
|
+
'createConicGradient',
|
|
39
|
+
'createImageData',
|
|
40
|
+
'createLinearGradient',
|
|
41
|
+
'createPattern',
|
|
42
|
+
'createRadialGradient',
|
|
43
|
+
'drawFocusIfNeeded',
|
|
44
|
+
'drawImage',
|
|
45
|
+
'ellipse',
|
|
46
|
+
'fill',
|
|
47
|
+
'fillRect',
|
|
48
|
+
'fillText',
|
|
49
|
+
'getImageData',
|
|
50
|
+
'getLineDash',
|
|
51
|
+
'getTransform',
|
|
52
|
+
'lineTo',
|
|
53
|
+
'measureText',
|
|
54
|
+
'moveTo',
|
|
55
|
+
'putImageData',
|
|
56
|
+
'quadraticCurveTo',
|
|
57
|
+
'rect',
|
|
58
|
+
'reset',
|
|
59
|
+
'resetTransform',
|
|
60
|
+
'restore',
|
|
61
|
+
'rotate',
|
|
62
|
+
'roundRect',
|
|
63
|
+
'save',
|
|
64
|
+
'scale',
|
|
65
|
+
'setLineDash',
|
|
66
|
+
'setTransform',
|
|
67
|
+
'stroke',
|
|
68
|
+
'strokeRect',
|
|
69
|
+
'strokeText',
|
|
70
|
+
'transform',
|
|
71
|
+
'translate'
|
|
72
|
+
];
|
|
73
|
+
export default class CanvasRenderingContext2D {
|
|
74
|
+
canvas;
|
|
75
|
+
constructor(canvas) {
|
|
76
|
+
this.canvas = canvas;
|
|
77
|
+
registerWebviewTarget(this, 'context2D');
|
|
78
|
+
registerWebviewProperties(this, PROPERTIES);
|
|
79
|
+
registerWebviewMethods(this, METHODS);
|
|
80
|
+
}
|
|
81
|
+
postMessage(message) {
|
|
82
|
+
return this.canvas.postMessage(message);
|
|
83
|
+
}
|
|
84
|
+
}
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
import { WEBVIEW_TARGET, registerWebviewProperties } from './utils';
|
|
2
|
+
const PROPERTIES = {
|
|
3
|
+
crossOrigin: undefined,
|
|
4
|
+
height: undefined,
|
|
5
|
+
src: undefined,
|
|
6
|
+
width: undefined
|
|
7
|
+
};
|
|
8
|
+
export class Image {
|
|
9
|
+
[WEBVIEW_TARGET];
|
|
10
|
+
canvas;
|
|
11
|
+
width;
|
|
12
|
+
height;
|
|
13
|
+
_loadListener;
|
|
14
|
+
_errorListener;
|
|
15
|
+
_onload;
|
|
16
|
+
_onerror;
|
|
17
|
+
constructor(canvas, width, height, noOnConstruction = false) {
|
|
18
|
+
this.canvas = canvas;
|
|
19
|
+
registerWebviewProperties(this, PROPERTIES);
|
|
20
|
+
if (width) {
|
|
21
|
+
this.width = width;
|
|
22
|
+
}
|
|
23
|
+
if (height) {
|
|
24
|
+
this.height = height;
|
|
25
|
+
}
|
|
26
|
+
if (this.onConstruction && !noOnConstruction) {
|
|
27
|
+
this.onConstruction();
|
|
28
|
+
this.postMessage({
|
|
29
|
+
type: 'listen',
|
|
30
|
+
payload: {
|
|
31
|
+
types: ['error', 'load'],
|
|
32
|
+
target: this[WEBVIEW_TARGET]
|
|
33
|
+
}
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
postMessage(message) {
|
|
38
|
+
return this.canvas.postMessage(message);
|
|
39
|
+
}
|
|
40
|
+
addEventListener(type, callbackFn) {
|
|
41
|
+
return this.canvas.addMessageListener((message) => {
|
|
42
|
+
const target = message?.payload?.target || {};
|
|
43
|
+
if (message &&
|
|
44
|
+
message.type === 'event' &&
|
|
45
|
+
target[WEBVIEW_TARGET] === this[WEBVIEW_TARGET] &&
|
|
46
|
+
message.payload.type === type) {
|
|
47
|
+
for (const key in target) {
|
|
48
|
+
const value = target[key];
|
|
49
|
+
if (key in this && this[key] !== value) {
|
|
50
|
+
this[key] = value;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
callbackFn({
|
|
54
|
+
...message.payload,
|
|
55
|
+
target: this
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
set onload(callback) {
|
|
61
|
+
this._onload = callback;
|
|
62
|
+
if (this._loadListener) {
|
|
63
|
+
this.canvas.removeMessageListener(this._loadListener);
|
|
64
|
+
}
|
|
65
|
+
if (callback) {
|
|
66
|
+
this._loadListener = this.addEventListener('load', callback);
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
get onload() {
|
|
70
|
+
return this._onload;
|
|
71
|
+
}
|
|
72
|
+
set onerror(callback) {
|
|
73
|
+
this._onerror = callback;
|
|
74
|
+
if (this._errorListener) {
|
|
75
|
+
this.canvas.removeMessageListener(this._errorListener);
|
|
76
|
+
}
|
|
77
|
+
if (callback) {
|
|
78
|
+
this._errorListener = this.addEventListener('error', callback);
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
get onerror() {
|
|
82
|
+
return this._onerror;
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
export function createImage(canvas, width, height) {
|
|
86
|
+
return new Image(canvas, width, height);
|
|
87
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export default class ImageData {
|
|
2
|
+
canvas;
|
|
3
|
+
constructor(canvas, dataArray, width, height, noOnConstruction) {
|
|
4
|
+
this.canvas = canvas;
|
|
5
|
+
if (this.onConstruction && !noOnConstruction) {
|
|
6
|
+
this.onConstruction(dataArray, width, height);
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
postMessage = (message) => {
|
|
10
|
+
return this.canvas.postMessage(message);
|
|
11
|
+
};
|
|
12
|
+
}
|
|
13
|
+
export function createImageData(canvas, dataArray, width, height) {
|
|
14
|
+
return new ImageData(canvas, dataArray, width, height);
|
|
15
|
+
}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { Image } from './Image';
|
|
2
|
+
import CanvasGradient from './CanvasGradient';
|
|
3
|
+
import ImageData from './ImageData';
|
|
4
|
+
export var ConstructorType;
|
|
5
|
+
(function (ConstructorType) {
|
|
6
|
+
ConstructorType["Image"] = "Image";
|
|
7
|
+
ConstructorType["CanvasGradient"] = "CanvasGradient";
|
|
8
|
+
ConstructorType["ImageData"] = "ImageData";
|
|
9
|
+
})(ConstructorType || (ConstructorType = {}));
|
|
10
|
+
const constructors = [
|
|
11
|
+
{ type: ConstructorType.Image, instance: Image },
|
|
12
|
+
{ type: ConstructorType.CanvasGradient, instance: CanvasGradient },
|
|
13
|
+
{ type: ConstructorType.ImageData, instance: ImageData }
|
|
14
|
+
];
|
|
15
|
+
export function useConstructorsRegistry() {
|
|
16
|
+
const register = (registerWebviewConstructor) => {
|
|
17
|
+
constructors.forEach(({ type, instance }) => {
|
|
18
|
+
registerWebviewConstructor(instance, type);
|
|
19
|
+
});
|
|
20
|
+
};
|
|
21
|
+
const getConstructor = (type) => {
|
|
22
|
+
return constructors.find(c => c.type === type)?.instance;
|
|
23
|
+
};
|
|
24
|
+
return {
|
|
25
|
+
register,
|
|
26
|
+
getConstructor
|
|
27
|
+
};
|
|
28
|
+
}
|