@moneko/core 3.1.0-beta.2 → 3.1.0-beta.3
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/app-entry.js +32 -1
- package/lib/app.js +40 -2
- package/lib/cleanup.js +19 -1
- package/lib/common.js +221 -2
- package/lib/config.js +230 -1
- package/lib/coverage.js +33 -3
- package/lib/dev.js +89 -5
- package/lib/docs.js +107 -2
- package/lib/done.js +11 -1
- package/lib/esm.js +7 -1
- package/lib/fallback.js +6 -1
- package/lib/generate-api.js +341 -3
- package/lib/has-pkg.js +12 -1
- package/lib/html-add-entry-attr.js +31 -10
- package/lib/html-plugin-option.js +45 -1
- package/lib/index.js +1 -1
- package/lib/locales.js +90 -3
- package/lib/merge-router.js +1 -1
- package/lib/minify.js +47 -2
- package/lib/modify-vars.js +11 -1
- package/lib/module-federation.js +46 -1
- package/lib/module.config.js +228 -3
- package/lib/net.js +33 -1
- package/lib/normalize-css.js +6 -1
- package/lib/object-listener.js +28 -1
- package/lib/paths.js +20 -1
- package/lib/prefix-router.js +6 -1
- package/lib/process-env.js +33 -1
- package/lib/prod.js +64 -5
- package/lib/rem.js +6 -1
- package/lib/resolver-sync.js +27 -1
- package/lib/routes.js +209 -4
- package/lib/seo.js +41 -2
- package/lib/swcrc.js +107 -2
- package/lib/tsloader.config.js +26 -2
- package/lib/utils.js +68 -6
- package/lib/virtual-module-plugin.js +63 -1
- package/lib/virtual-modules.js +37 -1
- package/lib/yarn-argv.js +9 -1
- package/package.json +2 -2
|
@@ -1 +1,63 @@
|
|
|
1
|
-
import
|
|
1
|
+
import VirtualModulesPlugin from 'webpack-virtual-modules';
|
|
2
|
+
import { docs } from './docs.js';
|
|
3
|
+
import { locales } from './locales.js';
|
|
4
|
+
import { isLibrary } from './process-env.js';
|
|
5
|
+
import { example, route } from './routes.js';
|
|
6
|
+
import { resolveNodeModulesPath } from './utils.js';
|
|
7
|
+
class VirtualModulePlugin {
|
|
8
|
+
constructor(options){
|
|
9
|
+
this.options = options;
|
|
10
|
+
}
|
|
11
|
+
apply(compiler) {
|
|
12
|
+
const vm = new VirtualModulesPlugin({
|
|
13
|
+
[resolveNodeModulesPath(route.data.name)]: route.data.data,
|
|
14
|
+
[resolveNodeModulesPath(example.data.name)]: 'export default []',
|
|
15
|
+
[resolveNodeModulesPath(locales.data.name)]: locales.data.data
|
|
16
|
+
});
|
|
17
|
+
route.listener((next)=>{
|
|
18
|
+
if (next.data) {
|
|
19
|
+
vm.writeModule(resolveNodeModulesPath(next.name), next.data);
|
|
20
|
+
}
|
|
21
|
+
});
|
|
22
|
+
locales.listener((next)=>{
|
|
23
|
+
if (next.data) {
|
|
24
|
+
vm.writeModule(resolveNodeModulesPath(next.name), next.data);
|
|
25
|
+
}
|
|
26
|
+
});
|
|
27
|
+
if (isLibrary) {
|
|
28
|
+
example.listener((next)=>{
|
|
29
|
+
const obj = next.data;
|
|
30
|
+
for(const key in obj){
|
|
31
|
+
if (Object.prototype.hasOwnProperty.call(obj, key)) {
|
|
32
|
+
if (obj[key]) {
|
|
33
|
+
vm.writeModule(resolveNodeModulesPath(key), obj[key]);
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
});
|
|
38
|
+
docs.listener((obj)=>{
|
|
39
|
+
for(const key in obj){
|
|
40
|
+
if (Object.prototype.hasOwnProperty.call(obj, key)) {
|
|
41
|
+
if (obj[key]) {
|
|
42
|
+
vm.writeModule(resolveNodeModulesPath(key), obj[key]);
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
vm.apply(compiler);
|
|
49
|
+
compiler.hooks.compilation.tap('VirtualModulePlugin', ()=>{
|
|
50
|
+
for(const key in this.options){
|
|
51
|
+
if (Object.prototype.hasOwnProperty.call(this.options, key)) {
|
|
52
|
+
const data = this.options[key];
|
|
53
|
+
if (typeof data === 'string') {
|
|
54
|
+
vm.writeModule(resolveNodeModulesPath(key), data);
|
|
55
|
+
} else {
|
|
56
|
+
vm.writeModule(resolveNodeModulesPath(key), `export default ${JSON.stringify(data)}`);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
export default VirtualModulePlugin;
|
package/lib/virtual-modules.js
CHANGED
|
@@ -1 +1,37 @@
|
|
|
1
|
-
import
|
|
1
|
+
import { accessSync, constants } from 'fs';
|
|
2
|
+
import { join } from 'path';
|
|
3
|
+
import appEntry from './app-entry.js';
|
|
4
|
+
import app from './app.js';
|
|
5
|
+
import { CONFIG } from './config.js';
|
|
6
|
+
import { coverage } from './coverage.js';
|
|
7
|
+
import fallback from './fallback.js';
|
|
8
|
+
import mergeRouter from './merge-router.js';
|
|
9
|
+
import normalizeCss from './normalize-css.js';
|
|
10
|
+
import prefixRouter from './prefix-router.js';
|
|
11
|
+
import { FRAMEWORKNAME, isLibrary, isReact } from './process-env.js';
|
|
12
|
+
import { resolveProgramPath } from './utils.js';
|
|
13
|
+
const virtualModules = {
|
|
14
|
+
...CONFIG.virtualModule,
|
|
15
|
+
'@app': app,
|
|
16
|
+
'@app/fallback': fallback,
|
|
17
|
+
'@app/coverage': coverage,
|
|
18
|
+
'@app/normalize/index.css': normalizeCss,
|
|
19
|
+
'@app/prefix-router': prefixRouter,
|
|
20
|
+
'@app/suspense/index.tsx': `import ${isReact ? 'React,' : ''}{Suspense,lazy} from "${FRAMEWORKNAME}";import Fallback from '@app/fallback';${isLibrary ? 'import scope from "@app/mdx-scope";' : ''}function SuspenseComp(props) {const Lazy = lazy(props.comp);return (<Suspense fallback={Fallback && <Fallback />}><Lazy ${isLibrary ? 'components={scope}' : ''}/></Suspense>);}export default SuspenseComp;`,
|
|
21
|
+
'@app/entry': appEntry,
|
|
22
|
+
'@app/merge-router': mergeRouter
|
|
23
|
+
};
|
|
24
|
+
let mdxScope = {};
|
|
25
|
+
if (isLibrary) {
|
|
26
|
+
try {
|
|
27
|
+
const appEntryPath = join(resolveProgramPath('site'), './mdx-scope.ts');
|
|
28
|
+
accessSync(appEntryPath, constants.R_OK);
|
|
29
|
+
mdxScope = 'import scope from "@/mdx-scope";export default scope;';
|
|
30
|
+
} catch (error) {
|
|
31
|
+
mdxScope = {};
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
Object.assign(virtualModules, {
|
|
35
|
+
'@app/mdx-scope': mdxScope
|
|
36
|
+
});
|
|
37
|
+
export default virtualModules;
|
package/lib/yarn-argv.js
CHANGED
|
@@ -1 +1,9 @@
|
|
|
1
|
-
|
|
1
|
+
const original = JSON.parse(process.env.npm_config_argv || '{}')?.original;
|
|
2
|
+
const yarnArgv = {};
|
|
3
|
+
original?.forEach((o)=>{
|
|
4
|
+
const m = o.split('=');
|
|
5
|
+
Object.assign(yarnArgv, {
|
|
6
|
+
[m[0]]: m[1] || true
|
|
7
|
+
});
|
|
8
|
+
});
|
|
9
|
+
export default yarnArgv;
|
package/package.json
CHANGED
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@moneko/core",
|
|
3
|
-
"version": "3.1.0-beta.
|
|
3
|
+
"version": "3.1.0-beta.3",
|
|
4
4
|
"description": "core",
|
|
5
5
|
"main": "lib/index.js",
|
|
6
6
|
"type": "module",
|
|
7
7
|
"scripts": {
|
|
8
|
-
"build": "swc src -d lib -C module.type=nodenext -C jsc.target=esnext -C jsc.loose=true -C jsc.minify.mangle=
|
|
8
|
+
"build": "swc src -d lib -C module.type=nodenext -C jsc.target=esnext -C jsc.loose=true -C jsc.minify.mangle=false -C jsc.minify.compress=false -C minify=false -D",
|
|
9
9
|
"prebuild": "rm -rf ./lib && tsc"
|
|
10
10
|
},
|
|
11
11
|
"keywords": [],
|