@tarojs/plugin-platform-harmony-ets 4.0.0-beta.11 → 4.0.0-beta.111
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/dist/apis/base/system.ts +73 -20
- package/dist/apis/canvas/index.ts +10 -1
- package/dist/apis/device/clipboard.ts +16 -8
- package/dist/apis/framework/index.ts +1 -5
- package/dist/apis/index.ts +25 -17
- package/dist/apis/media/image/index.ts +1 -1
- package/dist/apis/storage/index.ts +135 -131
- package/dist/apis/ui/animation/animation.ts +71 -29
- package/dist/apis/ui/background.ts +2 -1
- package/dist/apis/ui/interaction/index.ts +42 -59
- package/dist/apis/ui/navigation-bar/index.ts +1 -1
- package/dist/apis/ui/pull-down-refresh.ts +9 -3
- package/dist/apis/ui/scroll/index.ts +5 -5
- package/dist/apis/ui/tab-bar.ts +3 -3
- package/dist/apis/utils/index.ts +2 -1
- package/dist/apis/wxml/IntersectionObserver.ts +18 -10
- package/dist/apis/wxml/selectorQuery.ts +26 -13
- package/dist/components-harmony-ets/button.ets +35 -8
- package/dist/components-harmony-ets/canvas.ets +51 -0
- package/dist/components-harmony-ets/checkbox.ets +70 -60
- package/dist/components-harmony-ets/form.ets +35 -16
- package/dist/components-harmony-ets/icon.ets +16 -8
- package/dist/components-harmony-ets/image.ets +22 -6
- package/dist/components-harmony-ets/index.ets +92 -0
- package/dist/components-harmony-ets/innerHtml.ets +6 -5
- package/dist/components-harmony-ets/input.ets +62 -40
- package/dist/components-harmony-ets/label.ets +44 -21
- package/dist/components-harmony-ets/listView.ets +31 -0
- package/dist/components-harmony-ets/movableArea.ets +112 -53
- package/dist/components-harmony-ets/movableView.ets +75 -48
- package/dist/components-harmony-ets/navigationBar.ets +65 -0
- package/dist/components-harmony-ets/pageMeta.ets +94 -0
- package/dist/components-harmony-ets/picker.ets +41 -38
- package/dist/components-harmony-ets/progress.ets +31 -24
- package/dist/components-harmony-ets/pseudo.ets +80 -0
- package/dist/components-harmony-ets/radio.ets +76 -66
- package/dist/components-harmony-ets/richText.ets +4 -25
- package/dist/components-harmony-ets/scrollList.ets +103 -0
- package/dist/components-harmony-ets/scrollView.ets +47 -47
- package/dist/components-harmony-ets/slider.ets +18 -14
- package/dist/components-harmony-ets/stickySection.ets +42 -0
- package/dist/components-harmony-ets/style.ets +386 -130
- package/dist/components-harmony-ets/swiper.ets +41 -4
- package/dist/components-harmony-ets/switch.ets +35 -31
- package/dist/components-harmony-ets/{index.ts → tag.ts} +6 -0
- package/dist/components-harmony-ets/text.ets +102 -46
- package/dist/components-harmony-ets/textArea.ets +49 -34
- package/dist/components-harmony-ets/utils/AttributeManager.ets +2 -2
- package/dist/components-harmony-ets/utils/DynamicCenter.ts +2 -2
- package/dist/components-harmony-ets/utils/flexManager.ets +49 -19
- package/dist/components-harmony-ets/utils/helper.ets +20 -8
- package/dist/components-harmony-ets/utils/htmlParser/HarmonyHTMLParser.ts +1 -2
- package/dist/components-harmony-ets/utils/htmlParser/index.ts +1 -1
- package/dist/components-harmony-ets/utils/index.ts +54 -50
- package/dist/components-harmony-ets/utils/styles.ets +170 -93
- package/dist/components-harmony-ets/video.ets +27 -19
- package/dist/components-harmony-ets/view.ets +47 -40
- package/dist/components-harmony-ets/webView.ets +6 -5
- package/dist/index.d.ts +152 -0
- package/dist/index.js +69 -43
- package/dist/index.js.map +1 -1
- package/dist/runtime-ets/bom/document.ts +6 -4
- package/dist/runtime-ets/bom/getComputedStyle.ts +2 -2
- package/dist/runtime-ets/bom/window.ts +7 -0
- package/dist/runtime-ets/current.ts +5 -1
- package/dist/runtime-ets/dom/bind.ts +28 -12
- package/dist/runtime-ets/dom/class-list.ts +2 -2
- package/dist/runtime-ets/dom/cssNesting.ts +419 -0
- package/dist/runtime-ets/dom/cssStyleDeclaration.ts +28 -42
- package/dist/runtime-ets/dom/document.ts +8 -11
- package/dist/runtime-ets/dom/element/canvas.ts +136 -0
- package/dist/runtime-ets/dom/element/element.ts +376 -56
- package/dist/runtime-ets/dom/element/form.ts +20 -22
- package/dist/runtime-ets/dom/element/index.ts +22 -2
- package/dist/runtime-ets/dom/element/movableArea.ts +0 -1
- package/dist/runtime-ets/dom/element/movableView.ts +234 -2
- package/dist/runtime-ets/dom/element/normal.ts +27 -6
- package/dist/runtime-ets/dom/element/progress.ts +0 -2
- package/dist/runtime-ets/dom/element/text.ts +0 -8
- package/dist/runtime-ets/dom/element/video.ts +4 -4
- package/dist/runtime-ets/dom/element/webView.ts +4 -5
- package/dist/runtime-ets/dom/event.ts +3 -5
- package/dist/runtime-ets/dom/eventTarget.ts +2 -3
- package/dist/runtime-ets/dom/node.ts +51 -19
- package/dist/runtime-ets/dom/stylesheet/covertWeb2Hm.ts +418 -237
- package/dist/runtime-ets/dom/stylesheet/index.ts +29 -311
- package/dist/runtime-ets/dom/stylesheet/type.ts +51 -9
- package/dist/runtime-ets/dom/stylesheet/util.ts +33 -27
- package/dist/runtime-ets/index.ts +2 -1
- package/dist/runtime-ets/interface/event.ts +1 -1
- package/dist/runtime-ets/utils/index.ts +74 -13
- package/dist/runtime-ets/utils/info.ts +2 -2
- package/dist/runtime-framework/react/app.ts +15 -10
- package/dist/runtime-framework/react/hooks.ts +0 -1
- package/dist/runtime-framework/react/index.ts +0 -2
- package/dist/runtime-framework/react/native-page.ts +185 -78
- package/dist/runtime-framework/react/page.ts +4 -9
- package/dist/runtime-framework/react/utils/index.ts +3 -3
- package/dist/runtime-framework/solid/app.ts +30 -46
- package/dist/runtime-framework/solid/connect.ts +21 -3
- package/dist/runtime-framework/solid/hooks.ts +16 -11
- package/dist/runtime-framework/solid/index.ts +6 -2
- package/dist/runtime-framework/solid/page.ts +85 -31
- package/dist/runtime-framework/solid/reconciler/props.ts +70 -25
- package/dist/runtime-framework/solid/reconciler/render.ts +16 -6
- package/dist/runtime-framework/solid/reconciler/use.ts +0 -1
- package/dist/runtime-framework/solid/utils/index.ts +3 -5
- package/dist/runtime-utils.d.ts +827 -0
- package/dist/runtime-utils.js +425 -253
- package/dist/runtime-utils.js.map +1 -1
- package/dist/runtime.d.ts +1 -0
- package/dist/runtime.js +425 -253
- package/dist/runtime.js.map +1 -1
- package/index.js +3 -1
- package/package.json +14 -15
- package/static/media/cancel.svg +1 -1
- package/static/media/circle.svg +1 -1
- package/static/media/clear.svg +1 -1
- package/static/media/download.svg +1 -1
- package/static/media/info.svg +1 -1
- package/static/media/info_circle.svg +1 -1
- package/static/media/search.svg +1 -1
- package/static/media/success.svg +1 -1
- package/static/media/success_no_circle.svg +1 -1
- package/static/media/warn.svg +1 -1
- package/types/harmony.d.ts +4 -0
- package/types/index.d.ts +4 -0
- package/types/runtime.d.ts +1 -1
- /package/dist/runtime-framework/solid/{contant.ts → constant.ts} +0 -0
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
/* eslint-disable no-console */
|
|
2
|
+
import { IFileType, TConfig, TaroPlatform, IPluginContext, TaroPlatformBase } from "@tarojs/service";
|
|
3
|
+
import { PLATFORM_TYPE } from "@tarojs/shared";
|
|
4
|
+
declare abstract class TaroPlatformHarmony<T extends TConfig = TConfig> extends TaroPlatform<T> {
|
|
5
|
+
platformType: PLATFORM_TYPE;
|
|
6
|
+
globalObject: string;
|
|
7
|
+
abstract fileType: IFileType;
|
|
8
|
+
abstract useETS: boolean;
|
|
9
|
+
abstract useJSON5: boolean;
|
|
10
|
+
taroComponentsPath: string;
|
|
11
|
+
/**
|
|
12
|
+
* 1. 清空 dist 文件夹
|
|
13
|
+
* 2. 输出编译提示
|
|
14
|
+
*/
|
|
15
|
+
private setup;
|
|
16
|
+
private setupHarmonyApp;
|
|
17
|
+
protected printDevelopmentTip(): void;
|
|
18
|
+
/**
|
|
19
|
+
* 返回当前项目内的 runner 包
|
|
20
|
+
*/
|
|
21
|
+
protected getRunner(): Promise<any>;
|
|
22
|
+
/**
|
|
23
|
+
* 准备 runner 参数
|
|
24
|
+
* @param extraOptions 需要额外合入 Options 的配置项
|
|
25
|
+
*/
|
|
26
|
+
protected getOptions(extraOptions?: {}): any;
|
|
27
|
+
/**
|
|
28
|
+
* 调用 runner 开始编译
|
|
29
|
+
* @param extraOptions 需要额外传入 runner 的配置项
|
|
30
|
+
*/
|
|
31
|
+
private build;
|
|
32
|
+
private buildHarmonyApp;
|
|
33
|
+
/**
|
|
34
|
+
* 调用 runner 开启编译
|
|
35
|
+
*/
|
|
36
|
+
start(): Promise<void>;
|
|
37
|
+
}
|
|
38
|
+
declare class Harmony extends TaroPlatformHarmony {
|
|
39
|
+
#private;
|
|
40
|
+
platform: string;
|
|
41
|
+
globalObject: string;
|
|
42
|
+
fileType: {
|
|
43
|
+
templ: string;
|
|
44
|
+
style: string;
|
|
45
|
+
config: string;
|
|
46
|
+
script: string;
|
|
47
|
+
};
|
|
48
|
+
useETS: boolean;
|
|
49
|
+
useJSON5: boolean;
|
|
50
|
+
runtimePath: string[] | string;
|
|
51
|
+
taroComponentsPath: string;
|
|
52
|
+
apiEntryList: RegExp[];
|
|
53
|
+
constructor(ctx: IPluginContext, config: TConfig);
|
|
54
|
+
get framework(): "solid" | "vue3" | "react" | "preact";
|
|
55
|
+
get aliasFramework(): string;
|
|
56
|
+
get apiLibrary(): string;
|
|
57
|
+
get apiEntry(): RegExp[];
|
|
58
|
+
get componentLibrary(): string;
|
|
59
|
+
get runtimeLibrary(): string;
|
|
60
|
+
get runtimeFrameworkLibrary(): string;
|
|
61
|
+
get defineConstants(): Record<string, string> | undefined;
|
|
62
|
+
extensions: string[];
|
|
63
|
+
excludeLibraries: (string | RegExp)[];
|
|
64
|
+
externalDeps: [
|
|
65
|
+
string,
|
|
66
|
+
RegExp,
|
|
67
|
+
string?
|
|
68
|
+
][];
|
|
69
|
+
harmonyScope: RegExp[];
|
|
70
|
+
indexOfLibraries(lib: string): number;
|
|
71
|
+
removeFromLibraries(lib: string): void;
|
|
72
|
+
moveLibraries(lib: string, target?: string, basedir?: string, sync?: boolean): void;
|
|
73
|
+
replaceDefineValue(code: string, define: Record<string, string>, ext?: string): string;
|
|
74
|
+
/**
|
|
75
|
+
* 修改 Vite 配置
|
|
76
|
+
*/
|
|
77
|
+
modifyViteConfig(): void;
|
|
78
|
+
handleResourceEmit(outDir: string, basedir?: string): void;
|
|
79
|
+
}
|
|
80
|
+
declare module HarmonyWrapper {
|
|
81
|
+
export { Harmony };
|
|
82
|
+
}
|
|
83
|
+
import HarmonyOS_ArkTS = HarmonyWrapper.Harmony;
|
|
84
|
+
declare class Harmony$0 extends TaroPlatformBase {
|
|
85
|
+
platform: string;
|
|
86
|
+
globalObject: string;
|
|
87
|
+
runtimePath: string;
|
|
88
|
+
taroComponentsPath: string;
|
|
89
|
+
fileType: {
|
|
90
|
+
templ: string;
|
|
91
|
+
style: string;
|
|
92
|
+
config: string;
|
|
93
|
+
script: string;
|
|
94
|
+
};
|
|
95
|
+
template: any;
|
|
96
|
+
/**
|
|
97
|
+
* 1. setupTransaction - init
|
|
98
|
+
* 2. setup
|
|
99
|
+
* 3. setupTransaction - close
|
|
100
|
+
* 4. buildTransaction - init
|
|
101
|
+
* 5. build
|
|
102
|
+
* 6. buildTransaction - close
|
|
103
|
+
*/
|
|
104
|
+
constructor(ctx: any, config: any);
|
|
105
|
+
/**
|
|
106
|
+
* 增加组件或修改组件属性
|
|
107
|
+
*/
|
|
108
|
+
modifyComponents(): void;
|
|
109
|
+
/**
|
|
110
|
+
* 不需要转 rpx
|
|
111
|
+
*/
|
|
112
|
+
modifyPostcssConfigs(config: Record<string, any>): void;
|
|
113
|
+
/**
|
|
114
|
+
* 模板自定义组件 js
|
|
115
|
+
* 等鸿蒙支持 template 后需要重构
|
|
116
|
+
*/
|
|
117
|
+
addEntry(): void;
|
|
118
|
+
/**
|
|
119
|
+
* 把 app、pages、自定义组件的 js 改造为鸿蒙的 export default 导出形式
|
|
120
|
+
*/
|
|
121
|
+
modifyTaroExport(): void;
|
|
122
|
+
/**
|
|
123
|
+
* 修改最终的编译产物
|
|
124
|
+
* 1. 生成模板自定义组件的 xml、css 文件
|
|
125
|
+
* 2. 删除多余的文件
|
|
126
|
+
* 3. 把 components-harmony 中被使用到的组件移动到输出目录
|
|
127
|
+
*/
|
|
128
|
+
modifyBuildAssets(ctx: any, config: any): void;
|
|
129
|
+
modifyWebpackConfig(): void;
|
|
130
|
+
modifyHarmonyConfig(pages: any, { projectPath, hapName, name }: {
|
|
131
|
+
projectPath: any;
|
|
132
|
+
hapName: any;
|
|
133
|
+
name: any;
|
|
134
|
+
}): void;
|
|
135
|
+
modifyHostPackage({ projectPath, hapName }: {
|
|
136
|
+
projectPath: any;
|
|
137
|
+
hapName?: string | undefined;
|
|
138
|
+
}): Promise<any>;
|
|
139
|
+
getChunkEntryModule(compilation: any, chunk: any, compiler?: string): any;
|
|
140
|
+
checkMetaType(entryModule: any): boolean;
|
|
141
|
+
isHarmonyRequest(request: string): boolean;
|
|
142
|
+
}
|
|
143
|
+
declare module HarmonyWrapper {
|
|
144
|
+
export { Harmony$0 as Harmony };
|
|
145
|
+
}
|
|
146
|
+
import HarmonyOS_JSUI = HarmonyWrapper.Harmony;
|
|
147
|
+
interface IOptions {
|
|
148
|
+
disableArkTS?: boolean;
|
|
149
|
+
useConfigName?: string;
|
|
150
|
+
}
|
|
151
|
+
declare const _default: (ctx: IPluginContext, options?: IOptions) => void;
|
|
152
|
+
export { _default as default, HarmonyOS_ArkTS, HarmonyOS_JSUI, IOptions };
|
package/dist/index.js
CHANGED
|
@@ -4,10 +4,9 @@ Object.defineProperty(exports, '__esModule', { value: true });
|
|
|
4
4
|
|
|
5
5
|
var helper = require('@tarojs/helper');
|
|
6
6
|
var path = require('node:path');
|
|
7
|
-
var runnerUtils = require('@tarojs/runner-utils');
|
|
8
|
-
var shared = require('@tarojs/shared');
|
|
9
7
|
var service = require('@tarojs/service');
|
|
10
8
|
var _package = require('@tarojs/service/dist/utils/package');
|
|
9
|
+
var shared = require('@tarojs/shared');
|
|
11
10
|
var webpackSources = require('webpack-sources');
|
|
12
11
|
var template = require('@tarojs/shared/dist/template');
|
|
13
12
|
|
|
@@ -180,8 +179,8 @@ class TaroPlatformHarmony extends service.TaroPlatform {
|
|
|
180
179
|
* 2. 输出编译提示
|
|
181
180
|
*/
|
|
182
181
|
setup() {
|
|
183
|
-
var _a, _b;
|
|
184
182
|
return __awaiter(this, void 0, void 0, function* () {
|
|
183
|
+
var _a, _b;
|
|
185
184
|
yield this.setupTransaction.perform(this.setupHarmonyApp, this);
|
|
186
185
|
(_b = (_a = this.ctx).onSetupClose) === null || _b === void 0 ? void 0 : _b.call(_a, this);
|
|
187
186
|
});
|
|
@@ -237,6 +236,7 @@ class TaroPlatformHarmony extends service.TaroPlatform {
|
|
|
237
236
|
* @param extraOptions 需要额外合入 Options 的配置项
|
|
238
237
|
*/
|
|
239
238
|
getOptions(extraOptions = {}) {
|
|
239
|
+
var _a, _b, _c;
|
|
240
240
|
const { ctx } = this;
|
|
241
241
|
const { recursiveMerge } = ctx.helper;
|
|
242
242
|
const config = recursiveMerge(Object.assign({}, this.config), {
|
|
@@ -248,21 +248,21 @@ class TaroPlatformHarmony extends service.TaroPlatform {
|
|
|
248
248
|
SUPPORT_TARO_POLYFILL: 'disabled',
|
|
249
249
|
},
|
|
250
250
|
});
|
|
251
|
-
return Object.assign(Object.assign(Object.assign({}, config), { buildAdapter: config.platform, fileType: this.fileType, platformType: this.platformType, useETS: this.useETS, useJSON5: this.useJSON5 }), extraOptions);
|
|
251
|
+
return Object.assign(Object.assign(Object.assign({}, config), { buildAdapter: config.platform, fileType: this.fileType, platformType: this.platformType, useETS: this.useETS, useJSON5: this.useJSON5, isPure: Boolean((_c = (_b = (_a = ctx === null || ctx === void 0 ? void 0 : ctx.runOpts) === null || _a === void 0 ? void 0 : _a.options) === null || _b === void 0 ? void 0 : _b.args) === null || _c === void 0 ? void 0 : _c.pure) }), extraOptions);
|
|
252
252
|
}
|
|
253
253
|
/**
|
|
254
254
|
* 调用 runner 开始编译
|
|
255
255
|
* @param extraOptions 需要额外传入 runner 的配置项
|
|
256
256
|
*/
|
|
257
|
-
build(
|
|
258
|
-
|
|
259
|
-
|
|
257
|
+
build() {
|
|
258
|
+
return __awaiter(this, arguments, void 0, function* (extraOptions = {}) {
|
|
259
|
+
var _a, _b;
|
|
260
260
|
(_b = (_a = this.ctx).onBuildInit) === null || _b === void 0 ? void 0 : _b.call(_a, this);
|
|
261
261
|
yield this.buildTransaction.perform(this.buildHarmonyApp, this, extraOptions);
|
|
262
262
|
});
|
|
263
263
|
}
|
|
264
|
-
buildHarmonyApp(
|
|
265
|
-
return __awaiter(this,
|
|
264
|
+
buildHarmonyApp() {
|
|
265
|
+
return __awaiter(this, arguments, void 0, function* (extraOptions = {}) {
|
|
266
266
|
const runner = yield this.getRunner();
|
|
267
267
|
const options = this.getOptions(Object.assign({
|
|
268
268
|
runtimePath: this.runtimePath,
|
|
@@ -285,7 +285,6 @@ class TaroPlatformHarmony extends service.TaroPlatform {
|
|
|
285
285
|
var _Harmony_defineConstants;
|
|
286
286
|
const frameworkAlias = {
|
|
287
287
|
solid: 'solid',
|
|
288
|
-
vue: 'vue2',
|
|
289
288
|
vue3: 'vue3',
|
|
290
289
|
};
|
|
291
290
|
let Harmony$1 = class Harmony extends TaroPlatformHarmony {
|
|
@@ -303,6 +302,9 @@ let Harmony$1 = class Harmony extends TaroPlatformHarmony {
|
|
|
303
302
|
this.useJSON5 = true;
|
|
304
303
|
this.runtimePath = [];
|
|
305
304
|
this.taroComponentsPath = `${PACKAGE_NAME}/dist/components-harmony-ets`;
|
|
305
|
+
this.apiEntryList = [
|
|
306
|
+
/(@tarojs[\\/]plugin-platform-harmony-ets|taro-platform-harmony)[\\/]dist[\\/]apis[\\/]index\.ts/,
|
|
307
|
+
];
|
|
306
308
|
_Harmony_defineConstants.set(this, {});
|
|
307
309
|
this.extensions = ['.js', '.jsx', '.ts', '.tsx', '.cjs', '.mjs', '.mts', '.vue', '.ets', '.d.ts'];
|
|
308
310
|
this.excludeLibraries = [];
|
|
@@ -317,14 +319,16 @@ let Harmony$1 = class Harmony extends TaroPlatformHarmony {
|
|
|
317
319
|
['react', /^react$|react[\\/]cjs/],
|
|
318
320
|
['react/jsx-runtime', /^react[\\/]jsx-runtime$/], // Note: React 环境下自动注入,避免重复
|
|
319
321
|
];
|
|
322
|
+
this.harmonyScope = [...HARMONY_SCOPES];
|
|
323
|
+
const that = this;
|
|
320
324
|
this.setupTransaction.addWrapper({
|
|
321
325
|
close() {
|
|
322
|
-
|
|
326
|
+
that.modifyViteConfig();
|
|
323
327
|
},
|
|
324
328
|
});
|
|
325
329
|
ctx.onBuildFinish(() => {
|
|
326
330
|
const outDir = path__namespace.resolve(process.cwd(), config.outputRoot);
|
|
327
|
-
|
|
331
|
+
that.handleResourceEmit(outDir);
|
|
328
332
|
});
|
|
329
333
|
}
|
|
330
334
|
get framework() {
|
|
@@ -336,6 +340,9 @@ let Harmony$1 = class Harmony extends TaroPlatformHarmony {
|
|
|
336
340
|
get apiLibrary() {
|
|
337
341
|
return path__namespace.resolve(__dirname, './apis');
|
|
338
342
|
}
|
|
343
|
+
get apiEntry() {
|
|
344
|
+
return this.apiEntryList;
|
|
345
|
+
}
|
|
339
346
|
get componentLibrary() {
|
|
340
347
|
return path__namespace.resolve(__dirname, './components-harmony-ets');
|
|
341
348
|
}
|
|
@@ -421,9 +428,10 @@ let Harmony$1 = class Harmony extends TaroPlatformHarmony {
|
|
|
421
428
|
}
|
|
422
429
|
if (ext) {
|
|
423
430
|
const code = helper.fs.readFileSync(lib, { encoding: 'utf8' });
|
|
424
|
-
if ((/(?:import\s|from\s|require\()['"]([\\/.][^'"\s]+)['"]\)?/g.test(code)
|
|
425
|
-
|
|
426
|
-
|
|
431
|
+
if ((/(?:import\s|from\s|require\()['"]([\\/.][^'"\s]+)['"]\)?/g.test(code) ||
|
|
432
|
+
/\/{3}\s<reference\spath=['"][^'"\s]+['"]\s\/>/g.test(code)) &&
|
|
433
|
+
`${libName}${path__namespace.extname(libDir)}` !== libDir) {
|
|
434
|
+
// Note: 文件包含包内引用的依赖
|
|
427
435
|
const pkgPath = path__namespace.relative(libName, libDir);
|
|
428
436
|
if (new RegExp(`^index(${this.extensions.map(e => e.replace('.', '\\.')).join('|')})$`).test(pkgPath)) {
|
|
429
437
|
// Note: 入口为 index 场景
|
|
@@ -474,17 +482,18 @@ let Harmony$1 = class Harmony extends TaroPlatformHarmony {
|
|
|
474
482
|
}
|
|
475
483
|
else if (stat.isFile()) {
|
|
476
484
|
let code = helper.fs.readFileSync(lib, { encoding: 'utf8' });
|
|
477
|
-
|
|
478
|
-
if ([/(@tarojs[\\/]plugin-platform-harmony-ets|taro-platform-harmony)[\\/]dist[\\/]apis[\\/]index\.ts/].some(e => e.test(lib))) {
|
|
485
|
+
if (this.apiEntry.some(e => e.test(lib))) {
|
|
479
486
|
code = apiLoader(code);
|
|
480
487
|
}
|
|
481
488
|
if (this.extensions.includes(path__namespace.extname(lib))) {
|
|
482
489
|
// Note: 查询 externals 内的依赖,并将它们添加到 externalDeps 中
|
|
483
|
-
code = code.replace(/(?:import\s|from\s|require\()['"]([
|
|
490
|
+
code = code.replace(/(?:import\s|from\s|require\()['"]([^\\/.][^'"\s]+)['"]\)?/g, (src, p1 = '') => {
|
|
491
|
+
if (p1.startsWith('node:') || p1.endsWith('.so'))
|
|
492
|
+
return src;
|
|
484
493
|
const { outputRoot } = this.ctx.runOpts.config;
|
|
485
494
|
const targetPath = path__namespace.join(outputRoot, helper.NODE_MODULES, p1);
|
|
486
495
|
const relativePath = parseRelativePath(path__namespace.dirname(target), targetPath);
|
|
487
|
-
if (
|
|
496
|
+
if (this.harmonyScope.every(e => !e.test(p1))) {
|
|
488
497
|
if (this.indexOfLibraries(p1) === -1 && !/\.(d\.ts|flow\.js)$/.test(lib)) {
|
|
489
498
|
this.externalDeps.push([p1, new RegExp(`^${p1.replace(/([-\\/$])/g, '\\$1')}$`)]);
|
|
490
499
|
this.moveLibraries(p1, targetPath, path__namespace.dirname(lib), true);
|
|
@@ -493,15 +502,24 @@ let Harmony$1 = class Harmony extends TaroPlatformHarmony {
|
|
|
493
502
|
}
|
|
494
503
|
return src;
|
|
495
504
|
});
|
|
496
|
-
const define = Object.assign({}, this.defineConstants)
|
|
505
|
+
const define = Object.assign(Object.assign({}, this.defineConstants), {
|
|
506
|
+
// Note: React 开发环境可能调用 stack 可能导致 appWrapper 实例变更
|
|
507
|
+
'ReactDebugCurrentFrame.getCurrentStack': 'ReactDebugCurrentFrame.getCurrentStack$' });
|
|
497
508
|
if ([/(@tarojs[\\/]runtime|taro-runtime)[\\/]dist/].some(e => e.test(lib))) {
|
|
498
509
|
define.global = 'globalThis';
|
|
499
510
|
}
|
|
500
|
-
code = this.replaceDefineValue(code, define);
|
|
501
511
|
const ext = path__namespace.extname(target);
|
|
512
|
+
if (![/d\.e?tsx?$/, /\.(json|map|md)$/].some(e => e.test(target))) {
|
|
513
|
+
code = this.replaceDefineValue(code, define, ext);
|
|
514
|
+
}
|
|
502
515
|
if (['.ts'].includes(ext)) {
|
|
503
516
|
code = '// @ts-nocheck\n' + code;
|
|
504
517
|
}
|
|
518
|
+
// 处理嵌套样式的编译,需要针对ReactElement进行props操作,dev模式下会Object.freeze,所以需要在开发模式下注入Object.freeze来覆盖解锁
|
|
519
|
+
// 处理的方法再taro-platform-harmony/src/runtime-ets/dom/cssNesting: ele.props.style = declaration
|
|
520
|
+
if (/react\/jsx-runtime/.test(lib) && process.env.NODE_ENV === 'development') {
|
|
521
|
+
code = 'Object.freeze = (obj) => obj \n' + code;
|
|
522
|
+
}
|
|
505
523
|
}
|
|
506
524
|
// Note: 传入 chorePackagePrefix 时,不生成核心依赖库
|
|
507
525
|
if (!chorePackagePrefix) {
|
|
@@ -542,9 +560,13 @@ declare global {
|
|
|
542
560
|
this.moveLibraries(realPath, target, basedir);
|
|
543
561
|
}
|
|
544
562
|
}
|
|
545
|
-
replaceDefineValue(code, define) {
|
|
563
|
+
replaceDefineValue(code, define, ext = '.js') {
|
|
546
564
|
Object.keys(define).forEach(key => {
|
|
547
|
-
|
|
565
|
+
let value = define[key];
|
|
566
|
+
if (/^['"`].*['"`]$/.test(value) && ['.ts', '.tsx', '.ets'].includes(ext)) {
|
|
567
|
+
value = `(${value} as string)`;
|
|
568
|
+
}
|
|
569
|
+
code = code.replace(new RegExp(`\\b${key}\\b`, 'g'), value);
|
|
548
570
|
});
|
|
549
571
|
return code;
|
|
550
572
|
}
|
|
@@ -563,8 +585,8 @@ declare global {
|
|
|
563
585
|
// @ts-ignore
|
|
564
586
|
if (that.framework === 'solid') {
|
|
565
587
|
that.externalDeps.push([
|
|
566
|
-
'@tarojs/plugin-framework-
|
|
567
|
-
/^@tarojs\/plugin-framework-
|
|
588
|
+
'@tarojs/plugin-framework-solid/dist/reconciler',
|
|
589
|
+
/^@tarojs\/plugin-framework-solid\/dist\/reconciler$/,
|
|
568
590
|
path__namespace.join(this.runtimeFrameworkLibrary, 'reconciler')
|
|
569
591
|
]);
|
|
570
592
|
that.externalDeps.push([
|
|
@@ -572,15 +594,24 @@ declare global {
|
|
|
572
594
|
/^solid-js\/universal$/,
|
|
573
595
|
]);
|
|
574
596
|
}
|
|
597
|
+
const chorePkgRgx = new RegExp(`^${(chorePackagePrefix || '').replace(/[\\/]+/g, '[\\\\/]+').replace(/[-^$*?.|]/g, '\\$&')}`);
|
|
575
598
|
const externals = Object.keys(ohPackage.dependencies || []).concat(Object.keys(ohPackage.devDependencies || []));
|
|
576
|
-
function modifyResolveId({ source = '',
|
|
577
|
-
if (externals.includes(source)) {
|
|
599
|
+
function modifyResolveId({ source = '', name = 'modifyResolveId' }) {
|
|
600
|
+
if (externals.includes(source) || (chorePackagePrefix && chorePkgRgx.test(source))) {
|
|
578
601
|
return {
|
|
579
602
|
external: true,
|
|
580
603
|
id: source,
|
|
581
604
|
resolvedBy: name,
|
|
582
605
|
};
|
|
583
606
|
}
|
|
607
|
+
else if (source.includes('css_variables')) {
|
|
608
|
+
return {
|
|
609
|
+
external: true,
|
|
610
|
+
id: path__namespace.join(outputRoot, 'css_variables'),
|
|
611
|
+
moduleSideEffects: 'no-treeshake',
|
|
612
|
+
resolvedBy: name,
|
|
613
|
+
};
|
|
614
|
+
}
|
|
584
615
|
if (chorePackagePrefix && that.indexOfLibraries(source) > -1) {
|
|
585
616
|
return {
|
|
586
617
|
external: true,
|
|
@@ -588,11 +619,6 @@ declare global {
|
|
|
588
619
|
resolvedBy: name,
|
|
589
620
|
};
|
|
590
621
|
}
|
|
591
|
-
if (shared.isFunction(resolve)) {
|
|
592
|
-
if (source === that.runtimePath || that.runtimePath.includes(source)) {
|
|
593
|
-
return resolve('@tarojs/runtime', importer, options);
|
|
594
|
-
}
|
|
595
|
-
}
|
|
596
622
|
// Note: 映射 Taro 相关依赖到注入 taro 目录
|
|
597
623
|
if (that.indexOfLibraries(source) > -1) {
|
|
598
624
|
return {
|
|
@@ -622,19 +648,18 @@ declare global {
|
|
|
622
648
|
}
|
|
623
649
|
function injectLoaderMeta() {
|
|
624
650
|
return {
|
|
625
|
-
name: 'taro:vite-
|
|
651
|
+
name: 'taro:vite-loader-meta',
|
|
626
652
|
buildStart() {
|
|
627
653
|
return __awaiter(this, void 0, void 0, function* () {
|
|
628
|
-
|
|
629
|
-
const
|
|
630
|
-
const compiler = info === null || info === void 0 ? void 0 : info.meta.viteCompilerContext;
|
|
654
|
+
const { getViteHarmonyCompilerContext } = that.ctx.runnerUtils;
|
|
655
|
+
const compiler = getViteHarmonyCompilerContext(this);
|
|
631
656
|
if (compiler) {
|
|
632
657
|
switch (that.framework) {
|
|
633
658
|
// @ts-ignore
|
|
634
659
|
case 'solid':
|
|
635
660
|
compiler.loaderMeta || (compiler.loaderMeta = {});
|
|
636
661
|
compiler.loaderMeta.importFrameworkStatement = ``;
|
|
637
|
-
compiler.mockAppStatement = `
|
|
662
|
+
compiler.loaderMeta.mockAppStatement = `
|
|
638
663
|
function App(props) {
|
|
639
664
|
return null
|
|
640
665
|
}
|
|
@@ -1030,7 +1055,7 @@ class Harmony extends service.TaroPlatformBase {
|
|
|
1030
1055
|
* 等鸿蒙支持 template 后需要重构
|
|
1031
1056
|
*/
|
|
1032
1057
|
addEntry() {
|
|
1033
|
-
this.ctx.onCompilerMake((
|
|
1058
|
+
this.ctx.onCompilerMake((_a) => __awaiter(this, [_a], void 0, function* ({ compilation, plugin }) {
|
|
1034
1059
|
// container/index.hml
|
|
1035
1060
|
const filePath = path.resolve(__dirname, 'template/container');
|
|
1036
1061
|
plugin.addEntry(filePath, 'container/index', helper.META_TYPE.STATIC);
|
|
@@ -1233,8 +1258,8 @@ class Harmony extends service.TaroPlatformBase {
|
|
|
1233
1258
|
console.warn(helper.chalk.red('设置鸿蒙 Hap 配置失败:', err));
|
|
1234
1259
|
});
|
|
1235
1260
|
}
|
|
1236
|
-
modifyHostPackage(
|
|
1237
|
-
return __awaiter(this,
|
|
1261
|
+
modifyHostPackage(_a) {
|
|
1262
|
+
return __awaiter(this, arguments, void 0, function* ({ projectPath, hapName = 'entry' }) {
|
|
1238
1263
|
const packageJsonFile = path.join(projectPath, hapName, 'package.json');
|
|
1239
1264
|
const hmsDeps = {
|
|
1240
1265
|
'@hmscore/hms-js-base': '^6.1.0-300',
|
|
@@ -1259,7 +1284,7 @@ class Harmony extends service.TaroPlatformBase {
|
|
|
1259
1284
|
return packageJson;
|
|
1260
1285
|
});
|
|
1261
1286
|
}
|
|
1262
|
-
getChunkEntryModule(compilation, chunk, compiler = '
|
|
1287
|
+
getChunkEntryModule(compilation, chunk, compiler = 'webpack5') {
|
|
1263
1288
|
if (compiler === 'webpack5') {
|
|
1264
1289
|
const chunkGraph = compilation.chunkGraph;
|
|
1265
1290
|
const entryModules = Array.from(chunkGraph.getChunkEntryModulesIterable(chunk));
|
|
@@ -1300,8 +1325,8 @@ var index = (ctx, options = {}) => {
|
|
|
1300
1325
|
ctx.registerPlatform({
|
|
1301
1326
|
name: PLATFORM_NAME,
|
|
1302
1327
|
useConfigName: options.useConfigName || PLATFORM_NAME,
|
|
1303
|
-
fn(
|
|
1304
|
-
return __awaiter(this,
|
|
1328
|
+
fn(_a) {
|
|
1329
|
+
return __awaiter(this, arguments, void 0, function* ({ config }) {
|
|
1305
1330
|
const program = new Harmony$2(ctx, config);
|
|
1306
1331
|
yield program.start();
|
|
1307
1332
|
});
|
|
@@ -1325,6 +1350,7 @@ function assertHarmonyConfig(ctx, config) {
|
|
|
1325
1350
|
}
|
|
1326
1351
|
}
|
|
1327
1352
|
|
|
1353
|
+
exports.HarmonyOS_ArkTS = Harmony$1;
|
|
1328
1354
|
exports.HarmonyOS_JSUI = Harmony;
|
|
1329
1355
|
exports.default = index;
|
|
1330
1356
|
//# sourceMappingURL=index.js.map
|