@moneko/core 3.8.7-beta.6 → 3.8.7-beta.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (51) hide show
  1. package/lib/common.js +1 -1
  2. package/lib/config.js +1 -1
  3. package/lib/dev.js +3 -3
  4. package/lib/has-pkg.js +1 -1
  5. package/lib/html-plugin-option.js +1 -1
  6. package/lib/info.d.ts +15 -0
  7. package/lib/info.js +1 -0
  8. package/lib/loader/app-comment.cjs +1 -1
  9. package/lib/loader/app-comment.d.cts +1 -1
  10. package/lib/loader/mdx.cjs +1 -1
  11. package/lib/loader/ts-doc.cjs +1 -1
  12. package/lib/loader/ts-doc.d.cts +2 -3
  13. package/lib/module.config.js +1 -1
  14. package/lib/paths.js +1 -1
  15. package/lib/plugin/override-resolve.js +1 -1
  16. package/lib/plugin/virtual-module.js +1 -1
  17. package/lib/process-env.d.ts +0 -2
  18. package/lib/process-env.js +1 -1
  19. package/lib/prod.js +1 -1
  20. package/lib/seo.js +1 -1
  21. package/lib/tsloader.config.js +1 -1
  22. package/lib/utils.d.ts +0 -6
  23. package/lib/utils.js +2 -2
  24. package/lib/vm/coverage.d.ts +2 -31
  25. package/lib/vm/coverage.js +1 -1
  26. package/lib/vm/entry.d.ts +2 -0
  27. package/lib/vm/entry.js +1 -0
  28. package/lib/vm/locales.js +2 -2
  29. package/lib/vm/mdx-scope.d.ts +2 -0
  30. package/lib/vm/mdx-scope.js +1 -0
  31. package/lib/vm/routes.js +1 -1
  32. package/lib/vm/utils.js +1 -1
  33. package/package.json +2 -2
  34. package/lib/virtual-modules.d.ts +0 -2
  35. package/lib/virtual-modules.js +0 -1
  36. package/lib/vm/app-entry.d.ts +0 -2
  37. package/lib/vm/app-entry.js +0 -1
  38. package/lib/vm/app.d.ts +0 -22
  39. package/lib/vm/app.js +0 -1
  40. package/lib/vm/fallback.d.ts +0 -2
  41. package/lib/vm/fallback.js +0 -1
  42. package/lib/vm/init-files.d.ts +0 -1
  43. package/lib/vm/init-files.js +0 -1
  44. package/lib/vm/merge-router.d.ts +0 -2
  45. package/lib/vm/merge-router.js +0 -1
  46. package/lib/vm/normalize-css.d.ts +0 -2
  47. package/lib/vm/normalize-css.js +0 -1
  48. package/lib/vm/prefix-router.d.ts +0 -2
  49. package/lib/vm/prefix-router.js +0 -1
  50. package/lib/vm/rem.d.ts +0 -2
  51. package/lib/vm/rem.js +0 -1
package/lib/common.js CHANGED
@@ -1 +1 @@
1
- import e from"add-asset-html-webpack-plugin";import t from"html-webpack-plugin";import o from"webpack";import{CONFIG as l,PUBLICPATH as r}from"./config.js";import s from"./html-plugin-option.js";import n from"./module-federation.js";import a from"./module.config.js";import i,{CUSTOMCONFIG as p}from"./paths.js";import c from"./plugin/add-entry-attribute.js";import m from"./plugin/override-resolve.js";import u from"./plugin/virtual-module.js";import{PACKAGENAME as f,PACKAGEVERSION as h,isDev as d,isLibrary as g,isMicro as y}from"./process-env.js";import{resolveNodeModulesPath as b,resolveProgramPath as j}from"./utils.js";import w from"./virtual-modules.js";let{AutomaticPrefetchPlugin:v,DefinePlugin:k,SourceMapDevToolPlugin:x,WatchIgnorePlugin:C}=o,O=l.assetHtml.map(e=>({publicPath:"",...e}));export const outputConfig={path:j(g?"docs":"dist"),filename:"js/[name].bundle.js",chunkFilename:`js/[${d?"name":"chunkhash"}].js`,assetModuleFilename:e=>{let t=e.filename;return t&&t.endsWith("?url")&&/(?:webworker|worker)(\.|\b).*\.(js|ts)\b/.test(t.replace("?url",""))?"worker/[name][ext]":"assets/[name][hash][ext]"},library:{name:f,type:"window"},globalObject:"window",chunkLoadingGlobal:`webpackJsonp_${f}`,pathinfo:d,clean:!0,publicPath:r,asyncChunks:!0,charset:!0};let $={main:b("@app/entry")};l.polyfill&&Object.assign($,{"dom-polyfills":[`${i.corePath}/polyfills/replace-children.js`]}),l.entry&&("string"==typeof l.entry?$={main:l.entry}:Object.keys(l.entry)&&Object.assign($,l.entry)),l.output&&("string"==typeof l.output?outputConfig.path=l.output:Object.keys(l.output)&&Object.assign(outputConfig,l.output));let P=l.basename.split("/").filter(Boolean).length,B=`${Array(P).fill("..").join("/")+(P?"/":"")}404.html`,{pathSegmentsToKeep:D=P,path:M=B}=l.fixBrowserRouter||{},R=!1;l.cacheDirectory&&(R={type:"filesystem",store:"pack",allowCollectingMemory:!0,cacheDirectory:l.cacheDirectory,memoryCacheUnaffected:!0,name:[p,process.env.NODE_ENV].filter(Boolean).join("-"),version:h});let A=Object.assign({original:l.alias["@"],override:p&&j(p)},l.overrideResolve);export const clientConfig={entry:$,stats:"errors-only",cache:R,infrastructureLogging:{level:"error"},target:"web",externalsPresets:l.externalsPresets,plugins:[...n,new u(w),new v,l.htmlPluginOption&&new t(s),l.fixBrowserRouter&&new t({filename:M,inject:!1,templateContent:()=>`<html lang="en"><head><title>${s.title}</title><script>const pathKeep = ${D||P};const l = window.location;l.replace(l.protocol + '//' + l.hostname + (l.port ? ':' + l.port : '') + l.pathname.split('/').slice(0, 1 + pathKeep).join('/') + '/?/' + l.pathname.slice(1).split('/').slice(pathKeep).join('/').replace(/&/g, '~and~') + (l.search ? '&' + l.search.slice(1).replace(/&/g, '~and~') : '') + l.hash);</script></head><body></body></html>`}),new e(O),y&&new c(e=>!!(e.match(/main\.(.*)\.bundle.js$/)||e.match("main.bundle.js"))),new k({"process.env":JSON.stringify(l.env)}),new C({paths:[/\.d\.ts$/]}),l.sourceMap&&new x(l.sourceMap),...l.plugins].filter(e=>!!e),node:{global:!1},experiments:{topLevelAwait:!0,asyncWebAssembly:!0,cacheUnaffected:!0,layers:!0,lazyCompilation:d&&{imports:!0,entries:!0},buildHttp:l.buildHttp,backCompat:!0,futureDefaults:!1,css:!1,outputModule:!1},resolve:{extensions:[".tsx",".ts",".js",".jsx"],alias:l.alias,plugins:[l.overrideResolve&&new m(A),...l.resolvePlugins].filter(Boolean),fallback:{path:!1,fs:!1,crypto:!1,assert:!1}},module:a,externals:l.externals,output:outputConfig};
1
+ import e from"add-asset-html-webpack-plugin";import t from"html-webpack-plugin";import o from"webpack";import{CONFIG as l,PUBLICPATH as r}from"./config.js";import s from"./html-plugin-option.js";import n from"./module-federation.js";import a from"./module.config.js";import i,{CUSTOMCONFIG as p}from"./paths.js";import c from"./plugin/add-entry-attribute.js";import m from"./plugin/override-resolve.js";import u from"./plugin/virtual-module.js";import{PACKAGENAME as f,PACKAGEVERSION as h,isDev as d,isLibrary as g,isMicro as y}from"./process-env.js";import{resolveNodeModulesPath as b,resolveProgramPath as j}from"./utils.js";let{AutomaticPrefetchPlugin:w,DefinePlugin:v,SourceMapDevToolPlugin:k,WatchIgnorePlugin:x}=o,C=l.assetHtml.map(e=>({publicPath:"",...e}));export const outputConfig={path:j(g?"docs":"dist"),filename:"js/[name].bundle.js",chunkFilename:`js/[${d?"name":"chunkhash"}].js`,assetModuleFilename:e=>{let t=e.filename;return t&&t.endsWith("?url")&&/(?:webworker|worker)(\.|\b).*\.(js|ts)\b/.test(t.replace("?url",""))?"worker/[name][ext]":"assets/[name][hash][ext]"},library:{name:f,type:"window"},globalObject:"window",chunkLoadingGlobal:`webpackJsonp_${f}`,pathinfo:d,clean:!0,publicPath:r,asyncChunks:!0,charset:!0};let O={main:b("@app/entry")};l.polyfill&&Object.assign(O,{"dom-polyfills":[`${i.corePath}/polyfills/replace-children.js`]}),l.entry&&("string"==typeof l.entry?O={main:l.entry}:Object.keys(l.entry)&&Object.assign(O,l.entry)),l.output&&("string"==typeof l.output?outputConfig.path=l.output:Object.keys(l.output)&&Object.assign(outputConfig,l.output));let $=l.basename.split("/").filter(Boolean).length,P=`${Array($).fill("..").join("/")+($?"/":"")}404.html`,{pathSegmentsToKeep:M=$,path:B=P}=l.fixBrowserRouter||{},D=!1;l.cacheDirectory&&(D={type:"filesystem",store:"pack",allowCollectingMemory:!0,cacheDirectory:l.cacheDirectory,memoryCacheUnaffected:!0,name:[p,process.env.NODE_ENV].filter(Boolean).join("-"),version:h});let R=Object.assign({original:l.alias["@"],override:p&&j(p)},l.overrideResolve);export const clientConfig={entry:O,stats:"errors-only",cache:D,infrastructureLogging:{level:"error"},target:"web",externalsPresets:l.externalsPresets,plugins:[...n,new u(l.virtualModule||{}),new w,l.htmlPluginOption&&new t(s),l.fixBrowserRouter&&new t({filename:B,inject:!1,templateContent:()=>`<html lang="en"><head><title>${s.title}</title><script>const pathKeep = ${M||$};const l = window.location;l.replace(l.protocol + '//' + l.hostname + (l.port ? ':' + l.port : '') + l.pathname.split('/').slice(0, 1 + pathKeep).join('/') + '/?/' + l.pathname.slice(1).split('/').slice(pathKeep).join('/').replace(/&/g, '~and~') + (l.search ? '&' + l.search.slice(1).replace(/&/g, '~and~') : '') + l.hash);</script></head><body></body></html>`}),new e(C),y&&new c(e=>!!(e.match(/main\.(.*)\.bundle.js$/)||e.match("main.bundle.js"))),new v({"process.env":JSON.stringify(l.env)}),new x({paths:[/\.d\.ts$/]}),l.sourceMap&&new k(l.sourceMap),...l.plugins].filter(e=>!!e),node:{global:!1},experiments:{topLevelAwait:!0,asyncWebAssembly:!0,cacheUnaffected:!0,layers:!0,lazyCompilation:d&&{imports:!0,entries:!1},buildHttp:l.buildHttp,backCompat:!0,futureDefaults:!1,css:!1,outputModule:!1},resolve:{extensions:[".tsx",".ts",".js",".jsx"],alias:l.alias,plugins:[l.overrideResolve&&new m(R),...l.resolvePlugins].filter(Boolean),fallback:{path:!1,fs:!1,crypto:!1,assert:!1}},module:a,externals:l.externals,output:outputConfig};
package/lib/config.js CHANGED
@@ -1 +1 @@
1
- import{accessSync as e,constants as t}from"fs";import o from"chalk";import{merge as s}from"webpack-merge";import i,{CUSTOMCONFIG as a}from"./paths.js";import{FRAMEWORK as r,PACKAGENAME as n,coreName as l,isDev as c,isLibrary as m,isMobile as p,jsxImportSource as u,mainDirectory as d}from"./process-env.js";import{isFunction as h,log as f,readConf as g,resolveProgramPath as x}from"./utils.js";import{comment as C}from"./vm/docs.js";let P=["@moneko","neko-ui","antd","@antv","katex","font-pingfang-sc","font-pingfang-tc","react-photo-view","react-markdown-editor-lite","schema-design","@app",".cache/http/data"],w={seo:!1,mode:"csr",compiler:"swc",bundleAnalyzer:!1,polyfill:!1,entry:{},minifier:{js:{},css:{}},sourceMap:{filename:"[file].map",publicPath:""},env:{NODE_ENV:process.env.NODE_ENV},basename:"/",publicPath:"/",rem:{designSize:p?375:1680},fallbackCompPath:null,modifyVars:{},prefixCls:"n",alias:{"@":x(d)},moduleRules:[],prefixJsLoader:[],cssModules:[],importOnDemand:{},proxy:[],cacheDirectory:i.webpackCachePath,devServer:{allowedHosts:[".baidu.com"],host:"localhost",port:3e3,https:!1,compress:!1},htmlPluginOption:{template:`node_modules/${l}/template/index.html`,favicon:`node_modules/${l}/template/favicon.ico`,tags:[]},assetHtml:[],routerMode:"browser",fixBrowserRouter:!1,plugins:[],resolvePlugins:[],overrideResolve:!1,splitChunk:{chunks:"all",minSize:1024,minChunks:1,cacheGroups:{route:{test:/[\\/].git[\\/]router/,priority:-10,reuseExistingChunk:!0,name:"route"},example:{test:/[\\/].git[\\/]example/,priority:-10,reuseExistingChunk:!0,name:"example"}}},runtimeChunk:"single",moduleFederation:[],rulesInclude:{css:P,js:P,media:P,font:P,wasm:[]},mdx:{jsx:!1,development:c,jsxImportSource:u,providerImportSource:`@moneko/${r}/mdx`},jsxDomExpressions:{moduleName:"solid-js/web",builtIns:["For","Show","Switch","Match","Suspense","SuspenseList","Portal","Index","Dynamic","ErrorBoundary"],contextToCustomElements:!0,wrapConditionals:!0,generate:"dom",hydratable:!1},bar:{name:"Client",color:"#6f42c1"},virtualModule:{},normalizeCss:!0,externalsPresets:{},buildHttp:{allowedUris:[],lockfileLocation:`${i.httpCachePath}/http.lock`,cacheLocation:`${i.httpCachePath}/data`,upgrade:!0}};m&&(w.alias=Object.assign(w.alias,{"@pkg":i.componentsPath,[n]:i.componentsPath}));let b=w,v={},k={};try{e(i.configPath,t.R_OK);let o=(await g(i.configPath,"index")).default;v=h(o)?o(process):o}catch(e){f(o.red(e))}if(a)try{e(i.customConfigPath,t.R_OK);let o=(await g(i.customConfigPath,a)).default;k=h(o)?o(process):o}catch(e){f(o.red(e))}"tsc"===(b=s(b,v,k)).compiler&&b.minifier&&(b.minifier.js||Object.assign(b.minifier,{js:{type:"terser"}}),b.minifier.css||Object.assign(b.minifier,{css:{type:"cssnano"}})),!1===b.devtool&&(b.sourceMap=!1),!1===b.sourceMap&&(b.devtool=!1),b.fixBrowserRouter&&b.htmlPluginOption&&(b.htmlPluginOption.tags||(b.htmlPluginOption.tags=[]),b.htmlPluginOption.tags.push({textContent:"(function(l) {if (l.search[1] === '/' ) {var decoded = l.search.slice(1).split('&').map(function(s) {return s.replace(/~and~/g, '&')}).join('?');window.history.replaceState(null, null,l.pathname.slice(0, -1) + decoded + l.hash);}}(window.location))"}));export const CONFIG=b;export const PUBLICPATH=CONFIG.publicPath||"/";global.NEKOCLICONFIG={CONFIG,CUSTOMCONFIG:a,log:f,comment:C};
1
+ import{fileExists as e}from"@moneko/mdx";import t from"chalk";import{merge as o}from"webpack-merge";import s,{CUSTOMCONFIG as i}from"./paths.js";import{FRAMEWORK as a,PACKAGENAME as n,coreName as r,isDev as l,isLibrary as c,isMobile as m,jsxImportSource as p,mainDirectory as u}from"./process-env.js";import{isFunction as d,log as h,readConf as f,resolveProgramPath as g}from"./utils.js";let x=["@moneko","neko-ui","antd","@antv","katex","font-pingfang-sc","font-pingfang-tc","react-photo-view","react-markdown-editor-lite","schema-design","@app",".cache/http/data"],C={seo:!1,mode:"csr",compiler:"swc",bundleAnalyzer:!1,polyfill:!1,entry:{},minifier:{js:{},css:{}},sourceMap:{filename:"[file].map",publicPath:""},env:{NODE_ENV:process.env.NODE_ENV},basename:"/",publicPath:"/",rem:{designSize:m?375:1680},fallbackCompPath:null,modifyVars:{},prefixCls:"n",alias:{"@":g(u)},moduleRules:[],prefixJsLoader:[],cssModules:[],importOnDemand:{},proxy:[],cacheDirectory:s.webpackCachePath,devServer:{allowedHosts:[".baidu.com"],host:"localhost",port:3e3,https:!1,compress:!1},htmlPluginOption:{template:`node_modules/${r}/template/index.html`,favicon:`node_modules/${r}/template/favicon.ico`,tags:[]},assetHtml:[],routerMode:"browser",fixBrowserRouter:!1,plugins:[],resolvePlugins:[],overrideResolve:!1,splitChunk:{chunks:"all",minSize:1024,minChunks:1,cacheGroups:{route:{test:/[\\/].git[\\/]router/,priority:-10,reuseExistingChunk:!0,name:"route"},example:{test:/[\\/].git[\\/]example/,priority:-10,reuseExistingChunk:!0,name:"example"}}},runtimeChunk:"single",moduleFederation:[],rulesInclude:{css:x,js:x,media:x,font:x,wasm:[]},mdx:{jsx:!1,development:l,jsxImportSource:p,providerImportSource:`@moneko/${a}/mdx`},jsxDomExpressions:{moduleName:"solid-js/web",builtIns:["For","Show","Switch","Match","Suspense","SuspenseList","Portal","Index","Dynamic","ErrorBoundary"],contextToCustomElements:!0,wrapConditionals:!0,generate:"dom",hydratable:!1},bar:{name:"Client",color:"#6f42c1"},virtualModule:{},normalizeCss:!0,externalsPresets:{},buildHttp:{allowedUris:[],lockfileLocation:`${s.httpCachePath}/http.lock`,cacheLocation:`${s.httpCachePath}/data`,upgrade:!0}};c&&(C.alias=Object.assign(C.alias,{"@pkg":s.componentsPath,[n]:s.componentsPath}));let P=C,w={},b={};if(e(s.configPath))try{let e=(await f(s.configPath,"index")).default;w=d(e)?e(process):e}catch(e){h(t.red(e))}if(i&&e(s.customConfigPath))try{let e=(await f(s.customConfigPath,i)).default;b=d(e)?e(process):e}catch(e){h(t.red(e))}"tsc"===(P=o(P,w,b)).compiler&&P.minifier&&(P.minifier.js||Object.assign(P.minifier,{js:{type:"terser"}}),P.minifier.css||Object.assign(P.minifier,{css:{type:"cssnano"}})),!1===P.devtool&&(P.sourceMap=!1),!1===P.sourceMap&&(P.devtool=!1),P.fixBrowserRouter&&P.htmlPluginOption&&(P.htmlPluginOption.tags||(P.htmlPluginOption.tags=[]),P.htmlPluginOption.tags.push({textContent:"(function(l) {if (l.search[1] === '/' ) {var decoded = l.search.slice(1).split('&').map(function(s) {return s.replace(/~and~/g, '&')}).join('?');window.history.replaceState(null, null,l.pathname.slice(0, -1) + decoded + l.hash);}}(window.location))"}));export const CONFIG=P;export const PUBLICPATH=CONFIG.publicPath||"/";global.NEKOCLICONFIG={CONFIG,CUSTOMCONFIG:i,log:h};
package/lib/dev.js CHANGED
@@ -1,3 +1,3 @@
1
- import{readdirSync as e}from"fs";import t from"chalk";import o from"webpack";import s from"webpack-dev-server";import{merge as r}from"webpack-merge";import l from"webpackbar";import{clientConfig as i}from"./common.js";import{CONFIG as n}from"./config.js";import{hasPkg as a}from"./has-pkg.js";import{getIPv4 as c,getPort as p}from"./net.js";import m from"./paths.js";import{hasEslintConfig as d,hasStylelintConfig as f,isLibrary as u,isReact as h}from"./process-env.js";import{cleanDir as v,isFunction as w,log as g,resolveProgramPath as k}from"./utils.js";let{HotModuleReplacementPlugin:j}=o,{yellow:y,green:$,grey:b,gray:x,bgBlue:S,bgGreenBright:T,blueBright:C,greenBright:A}=t,B=[".eslintrc.js",".eslintrc.json",".eslintrc.yaml",".eslintrc.json"],D=[".stylelintrc",".stylelintrc.json",".stylelintrc.yaml",".stylelintrc.yml",".stylelintrc.js","stylelint.config.js","stylelint.config.cjs"],E=e(m.programPath),M=!1,O=!1;for(let e=0,t=E.length;e<t;e++)D.includes(E[e])&&(O=!0),B.includes(E[e])&&(M=!0);M||(M=d),O||(O=f);let P=O?(await import("stylelint-webpack-plugin")).default:null,_=M?(await import("eslint-webpack-plugin")).default:null,H=n.devServer.port||3e3,I=await p(H,65535,n.devServer.host),N=a("@moneko/mock")&&(await import("@moneko/mock")).default,W=h&&(await import("@pmmmwh/react-refresh-webpack-plugin")).default,F=!1===n.devtool||n.devtool?n.devtool:"eval-cheap-module-source-map";n.devServer.port=I;let G="/"===n.basename,L=n.devServer.https?"https:":"http:",R=G?"":n.basename,Y=n.devServer.port!==I&&x(`Port ${y(H)} is in use, trying ${$(I)} instead.
2
- `);function q(e){return`${L}//${"local"===e?n.devServer.host:c()}:${I}${R}`}let z=x("You application is running here:"),J=`${S(" Local ")} ${C(q("local"))}
3
- ${T(" Network ")} ${A(q("net"))}`,K=["js","md","mdx","jsx","ts","tsx","json","html","vue"],Q=K.join(","),U=["css","scss","sass","less","ts","tsx","js","jsx"],V=U.join(","),X=["node_modules/","es/","lib/","umd/","docs/","coverage/","dist/"],Z=[new j,W&&new W,_&&new _({fix:!0,threads:!0,files:[`${n.alias["@"]}/**/*.{${Q}}`,u&&`${n.alias["@pkg"]}/**/*.{${Q}}`].filter(Boolean),extensions:K,exclude:X,cache:!0,lintDirtyModulesOnly:!0}),P&&new P({fix:!0,threads:!0,files:[`${n.alias["@"]}/**/*.{${V}}`,u&&`${n.alias["@pkg"]}/**/*.{${V}}`].filter(Boolean),extensions:U,exclude:X,cache:!0,lintDirtyModulesOnly:!0}),n.bar&&new l(n.bar)].filter(Boolean),ee={headers:{"Access-Control-Allow-Origin":"*"},compress:n.devServer.compress,host:"0.0.0.0",port:I,historyApiFallback:G||{index:R.endsWith("/")?R:`${R}/`,disableDotRule:!0},https:n.devServer.https,proxy:n.proxy,allowedHosts:n.devServer.allowedHosts,client:{reconnect:!0,progress:!1,logging:"info",overlay:!1,webSocketTransport:"ws"},webSocketServer:"ws",static:{watch:{ignored:e=>e.endsWith(".d.ts")||e.includes("/node_modules/")}},setupMiddlewares:(e,t)=>{if(!t)throw Error("devServer is not defined");return t.app&&w(N)&&N(t.app,k("mock/")),e},open:!1,hot:!0},et=o(r(i,{devtool:F,mode:"development",plugins:Z}));et.watch({aggregateTimeout:20,ignored:/node_modules(?![\\/]@app)/,stdin:!0},(e,t)=>{!e&&t&&(g([z,"",J,"",b(`Compiled successfully in ${$(`${t.endTime-t.startTime}ms`)}`)]),t.compilation.warnings.forEach(e=>g(e.message)),t.compilation.errors.forEach(e=>g(e.message)),Y&&g(Y))});let eo=new s(ee,et);eo.startCallback(e=>{e||g([z,"",J])}),eo.stopCallback(e=>{e||v(m.cachePath)}),process.on("exit",function(){et.close(()=>{}),eo.invalidate(),eo.stop()}),process.on("SIGINT",()=>{process.exit()});
1
+ import{removeDirAll as e}from"@moneko/mdx";import o from"chalk";import t from"webpack";import s from"webpack-dev-server";import{merge as r}from"webpack-merge";import i from"webpackbar";import{clientConfig as a}from"./common.js";import{CONFIG as l}from"./config.js";import{hasPkg as n}from"./has-pkg.js";import{getIPv4 as p,getPort as m}from"./net.js";import c from"./paths.js";import{isLibrary as d,isReact as u}from"./process-env.js";import{isFunction as w,log as f,resolveProgramPath as v}from"./utils.js";let{HotModuleReplacementPlugin:h}=t,{yellow:g,green:k,grey:b,gray:$,bgBlue:x,bgGreenBright:j,blueBright:S,greenBright:y}=o,T=n("eslint-webpack-plugin"),C=n("stylelint-webpack-plugin"),A=n("@moneko/mock"),B=C?(await import("stylelint-webpack-plugin")).default:null,D=T?(await import("eslint-webpack-plugin")).default:null,E=l.devServer.port||3e3,H=await m(E,65535,l.devServer.host),M=A&&(await import("@moneko/mock")).default,O=u&&(await import("@pmmmwh/react-refresh-webpack-plugin")).default,_=!1===l.devtool||l.devtool?l.devtool:"eval-cheap-module-source-map";l.devServer.port=H;let I="/"===l.basename,J=l.devServer.https?"https:":"http:",N=I?"":l.basename,P=l.devServer.port!==H&&$(`Port ${g(E)} is in use, trying ${k(H)} instead.
2
+ `);function W(e){return`${J}//${"local"===e?l.devServer.host:p()}:${H}${N}`}let F=$("You application is running here:"),G=`${x(" Local ")} ${S(W("local"))}
3
+ ${j(" Network ")} ${y(W("net"))}`,L=["js","md","mdx","jsx","ts","tsx","json","html","vue"],R=L.join(","),Y=["css","scss","sass","less","ts","tsx","js","jsx"],q=Y.join(","),z=["node_modules/","es/","lib/","umd/","docs/","coverage/","dist/"],K=[new h,O&&new O,D&&new D({fix:!0,threads:!0,files:[`${l.alias["@"]}/**/*.{${R}}`,d&&`${l.alias["@pkg"]}/**/*.{${R}}`].filter(Boolean),extensions:L,exclude:z,cache:!0,lintDirtyModulesOnly:!0}),B&&new B({fix:!0,threads:!0,files:[`${l.alias["@"]}/**/*.{${q}}`,d&&`${l.alias["@pkg"]}/**/*.{${q}}`].filter(Boolean),extensions:Y,exclude:z,cache:!0,lintDirtyModulesOnly:!0}),l.bar&&new i(l.bar)].filter(Boolean),Q={headers:{"Access-Control-Allow-Origin":"*"},compress:l.devServer.compress,host:"0.0.0.0",port:H,historyApiFallback:I||{index:N.endsWith("/")?N:`${N}/`,disableDotRule:!0},https:l.devServer.https,proxy:l.proxy,allowedHosts:l.devServer.allowedHosts,client:{reconnect:!0,progress:!1,logging:"info",overlay:!1,webSocketTransport:"ws"},webSocketServer:"ws",static:{watch:{ignored:e=>e.endsWith(".d.ts")||e.includes("/node_modules/")}},setupMiddlewares:(e,o)=>{if(!o)throw Error("devServer is not defined");return o.app&&w(M)&&M(o.app,v("mock/")),e},open:!1,hot:!0},U=t(r(a,{devtool:_,mode:"development",plugins:K}));U.watch({aggregateTimeout:20,ignored:/node_modules(?![\\/]@app)/,stdin:!0},(e,o)=>{!e&&o&&(process.stdout.write("\x1b[2J\x1b[3J\x1b[H"),f([F,"",G,"",b(`Compiled successfully in ${k(`${o.endTime-o.startTime}ms`)}`)]),o.compilation.warnings.forEach(e=>f(e.message)),o.compilation.errors.forEach(e=>f(e.message)),P&&f(P))});let V=new s(Q,U);V.startCallback(e=>{e||f([F,"",G])}),V.stopCallback(o=>{o||e(c.cachePath)}),process.on("exit",function(){U.close(()=>{}),V.invalidate(),V.stop()}),process.on("SIGINT",()=>{process.exit()});
package/lib/has-pkg.js CHANGED
@@ -1 +1 @@
1
- import{accessSync as t,constants as r}from"fs";import{resolveNodeModulesPath as o}from"./utils.js";export function hasPkg(s){let a;try{t(o(`${s}/package.json`),r.R_OK),a=!0}catch(t){a=!1}return a}
1
+ import{fileExists as o}from"@moneko/mdx";import{resolveNodeModulesPath as r}from"./utils.js";export function hasPkg(m){return o(r(`${m}/package.json`))}
@@ -1 +1 @@
1
- import{merge as e}from"webpack-merge";import{CONFIG as t}from"./config.js";import{PACKAGENAME as i,coreName as o}from"./process-env.js";import{resolveProgramPath as a}from"./utils.js";import m from"./vm/app.js";let{template:p,favicon:r,...l}=Object.assign({template:`node_modules/${o}/template/index.html`,favicon:`node_modules/${o}/template/favicon.ico`},t.htmlPluginOption||{}),n=e({title:t.env?.PROJECTNAME||i.toLocaleUpperCase()||"Title",filename:"index.html",hash:!1,minify:{collapseWhitespace:!0,removeComments:!0,removeRedundantAttributes:!1,removeScriptTypeAttributes:!1,removeStyleLinkTypeAttributes:!1,removeAttributeQuotes:!0,useShortDoctype:!0},meta:{charset:"UTF-8","X-UA-Compatible":{"http-equiv":"X-UA-Compatible",content:"IE=edge,Chrome=1"},HandheldFriendly:"true",MobileOptimized:"320","screen-orientation":"portrait","x5-orientation":"portrait",browsermode:"application","x5-page-mode":"app","msapplication-tap-highlight":"no",viewport:"width=device-width,initial-scale=1,maximum-scale=1,minimum-scale=1,user-scalable=no","apple-mobile-web-app-capable":"yes",renderer:"webkit",description:m.description||""},tags:[],template:a(p),favicon:a(r)},l);export default n;
1
+ import{merge as e}from"webpack-merge";import{CONFIG as t}from"./config.js";import i from"./info.js";import{PACKAGENAME as o,coreName as a}from"./process-env.js";import{resolveProgramPath as r}from"./utils.js";let{template:m,favicon:p,...n}=Object.assign({template:`node_modules/${a}/template/index.html`,favicon:`node_modules/${a}/template/favicon.ico`},t.htmlPluginOption||{}),l=e({title:t.env?.PROJECTNAME||o.toLocaleUpperCase()||"Title",filename:"index.html",hash:!1,minify:{collapseWhitespace:!0,removeComments:!0,removeRedundantAttributes:!1,removeScriptTypeAttributes:!1,removeStyleLinkTypeAttributes:!1,removeAttributeQuotes:!0,useShortDoctype:!0},meta:{charset:"UTF-8","X-UA-Compatible":{"http-equiv":"X-UA-Compatible",content:"IE=edge,Chrome=1"},HandheldFriendly:"true",MobileOptimized:"320","screen-orientation":"portrait","x5-orientation":"portrait",browsermode:"application","x5-page-mode":"app","msapplication-tap-highlight":"no",viewport:"width=device-width,initial-scale=1,maximum-scale=1,minimum-scale=1,user-scalable=no","apple-mobile-web-app-capable":"yes",renderer:"webkit",description:i.description||""},tags:[],template:r(m),favicon:r(p)},n);export default l;
package/lib/info.d.ts ADDED
@@ -0,0 +1,15 @@
1
+ declare const app: {
2
+ name: string;
3
+ projectName: string;
4
+ version: string;
5
+ base: string;
6
+ type: import("./index.js").AppType;
7
+ routerMode: "browser" | "hash" | "memory";
8
+ prefixCls: string | undefined;
9
+ theme: import("./index.js").Theme | undefined;
10
+ description: any;
11
+ author: any;
12
+ repository: any;
13
+ keywords: any;
14
+ };
15
+ export default app;
package/lib/info.js ADDED
@@ -0,0 +1 @@
1
+ import{loadFileSync as e}from"@moneko/mdx";import{CONFIG as r}from"./config.js";import{APPTYPE as o,PACKAGENAME as t,PACKAGEVERSION as s}from"./process-env.js";import{resolveProgramPath as p,toUpperCaseString as i}from"./utils.js";let{description:m,author:a,repository:n,keywords:f}=JSON.parse(e(p("package.json"))||"{}"),l={name:t,projectName:JSON.stringify(i(t).replace(/-/g," ")),version:s,base:r.basename,type:o,routerMode:r.routerMode,prefixCls:r.prefixCls,theme:r.theme,description:m,author:"string"==typeof a?{name:a}:a,repository:"string"==typeof a?{url:n}:n,keywords:f};export default l;
@@ -1 +1 @@
1
- "use strict";function e(e=""){let t=this.resourcePath,r=this.getOptions().comment.getData(`@app/comment/${t.split("/").slice(-2).join("/")}`);return this.cacheable(!0),r||e}Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"default",{enumerable:!0,get:function(){return e}});
1
+ "use strict";function e(){let e=this.resourcePath,t=this.getOptions();return this.cacheable(!0),t.comment.getData(`@app/comment/${e.split("/").slice(-2).join("/")}`)}Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"default",{enumerable:!0,get:function(){return e}});
@@ -3,4 +3,4 @@ import type { LoaderContext } from 'webpack';
3
3
  export default function (this: LoaderContext<{
4
4
  test: RegExp;
5
5
  comment: ReactiveObject<Record<string, string>>;
6
- }>, _?: string): string;
6
+ }>): string;
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"default",{enumerable:!0,get:function(){return t}});const e=require("@moneko/mdx");function t(t){let n=this.async();(0,e.mdx)({value:t,filepath:this.resourcePath,...this.getOptions()}).then(e=>{this.cacheable(!0),n(null,e.code)}).catch(n)}
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"default",{enumerable:!0,get:function(){return t}});const e=require("@moneko/mdx");function t(t){let n=this.async();this.cacheable(!0),(0,e.mdx)({value:t,filepath:this.resourcePath,...this.getOptions()}).then(e=>{n(null,e.code)}).catch(n)}
@@ -1 +1 @@
1
- "use strict";var e;Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"default",{enumerable:!0,get:function(){return i}});const t=require("fs"),s=(e=require("./generate-doc.cjs"))&&e.__esModule?e:{default:e},r={},a={};function i(e){let i=this.async(),c=this.resourcePath;void 0===a[c]&&(a[c]=0),(0,t.stat)(c,(t,l)=>{if(!t){let t=l.mtime.getTime();r[c]!==t&&(a[c]=a[c]+1,Object.assign(r,{[c]:t}),global.NEKOCLICONFIG.comment.setData(`@app/comment/${c.split("/").slice(-2).join("/").replace(/\.tsx?/,".md")}`,(0,s.default)(e,c)))}this.cacheable(a[c]>1),i(null,e)})}
1
+ "use strict";var e;Object.defineProperty(exports,"__esModule",{value:!0}),Object.defineProperty(exports,"default",{enumerable:!0,get:function(){return a}});const t=require("fs"),r=(e=require("./generate-doc.cjs"))&&e.__esModule?e:{default:e},s={},i={};function a(e){let a=this.resourcePath,c=this.getOptions();return void 0===i[a]&&(i[a]=0),(0,t.stat)(a,(t,n)=>{if(!t){let t=n.mtime.getTime(),o=s[a]!==t;o&&(i[a]=i[a]+1,Object.assign(s,{[a]:t}),c.setData(`@app/comment/${a.split("/").slice(-2).join("/").replace(/\.tsx?/,".md")}`,(0,r.default)(e,a))),this.cacheable(i[a]>1&&o)}}),e}
@@ -1,4 +1,3 @@
1
+ import type ReactiveObject from '../reactive-object.js';
1
2
  import type { LoaderContext } from 'webpack';
2
- export default function (this: LoaderContext<{
3
- test: RegExp;
4
- }>, value: string): void;
3
+ export default function (this: LoaderContext<ReactiveObject<Record<string, string>>>, value: string): string;
@@ -1 +1 @@
1
- import e from"mini-css-extract-plugin";import s from"mini-svg-data-uri";import{CONFIG as t,PUBLICPATH as o}from"./config.js";import{hasPkg as r}from"./has-pkg.js";import l from"./modify-vars.js";import a,{CUSTOMCONFIG as i}from"./paths.js";import{FRAMEWORK as n,isDev as c,isLibrary as d,isMicro as m}from"./process-env.js";import p from"./swcrc.js";import u from"./tsloader.config.js";import{resolveNodeModulesPath as f,resolveProgramPath as y}from"./utils.js";let x={loader:`${a.corePath}/loader/css-unicode.cjs`},$=m?o:"../",g={loader:e.loader,options:{publicPath:"/"!==$?$:"../"}},v=r("@moneko/postcss")&&{loader:"postcss-loader",options:{postcssOptions:(await import("@moneko/postcss")).default}};c&&(g="style-loader");let j=[...t.cssModules,`@moneko/${n}`,"neko-ui"].map(f),w=[...["src/styles/variables.less","src/styles/mixins.less","site/styles/variables.less","site/styles/mixins.less"].map(y)],h=["components","example","mock","site","src","server"].map(y);i&&h.push(y(i)),t.overrideResolve&&t.overrideResolve.override&&h.push(t.overrideResolve.override);let b={loader:"css-loader",options:{modules:{auto:e=>{for(let s=0,t=j.length;s<t;s++)if(e&&e?.includes(j[s]))return/(.*(?<!\.?global\.(le|c|sc|sa)ss)$)/i.test(e);return/(^(?!.*node_modules))(.*(?<!\.?global\.(le|c|sc|sa)ss)$)/i.test(e)},localIdentName:"[path][name]__[local]",exportLocalsConvention:"dashesOnly"},importLoaders:2}},_=c&&{loader:"@teamsupercell/typings-for-css-modules-loader",options:{verifyOnly:!c}},k=[g,_,b,v,x,{loader:"less-loader",options:{sourceMap:!!t.sourceMap,lessOptions:{modifyVars:l,javascriptEnabled:!0}}},{loader:"style-resources-loader",options:{patterns:w}}].filter(Boolean),O="tsc"===t.compiler,B={loader:O?"ts-loader":"swc-loader",options:O?u:p(c)};function L(e){return h.concat(t.rulesInclude?.[e]?.map(f)||[])}let P=L("media"),R={rules:[d&&{test:/^(?![._]).*(?<!\.test)\.(tsx?)$/,include:t.alias["@pkg"],exclude:[/node_modules/,/(.+)\/__tests__\/(.+)/i],enforce:"pre",use:[{loader:`${a.corePath}/loader/ts-doc.cjs`}]},{oneOf:[{resourceQuery:/raw/i,type:"asset/source"},{resourceQuery:/url/i,type:"asset/resource",generator:{filename:e=>{let s=e.filename;return s&&s.endsWith("wasm?url")?"wasm/[name][ext]":"assets/[name][ext]"}}},{test:/\.wasm$/i,type:"webassembly/async",include:L("wasm")},{test:/\.txt$/i,type:"asset/source"},{test:/\.ico$/i,type:"asset/inline",include:P},{test:/\.svg$/i,type:"asset/inline",generator:{dataUrl:e=>s(e.toString())},include:P},{test:/\.(gif|png|jpe?g|webp)$/i,type:"asset",dependency:{not:["url"]},generator:{filename:"assets/images/[name][ext]"},include:P},{test:/\.(webm|mp4|ogv)$/i,type:"asset",dependency:{not:["url"]},generator:{filename:"assets/video/[name][ext]"},include:P},{test:/\.(woff2?|eot|ttf|otf)(\?.*)?$/i,type:"asset",dependency:{not:["url"]},generator:{filename:"assets/fonts/[name][ext]"},include:L("font")},{test:/\.(sa|sc)ss$/i,use:[g,_,b,v,x,{loader:"sass-loader",options:{implementation:await import("sass"),sassOptions:{}}}].filter(Boolean),include:L("css")},{test:/\.less$/i,use:k,include:L("css")},{test:/\.css$/i,use:[g,"css-loader",v,x].filter(Boolean),include:L("css")},{test:/\.(cj|mj|t|j)s(|x)$/i,use:[...t.prefixJsLoader,B].filter(Boolean),include:L("js")},{test:/\.mdx?$/i,use:[...t.prefixJsLoader,{loader:`${a.corePath}/loader/mdx.cjs`,options:t.mdx}].filter(Boolean),include:h,exclude:[/(.+)\/examples\/(.+).mdx?$/i]},{test:/\.mdx?$/i,type:"asset/source",include:[/(.+)\/examples\/(.+).mdx?$/i]},{type:"asset/source",include:[/(.+)\/examples\/(.+).*?$/i]}]},...t.moduleRules].filter(e=>"object"==typeof e)};export default R;
1
+ import e from"mini-css-extract-plugin";import s from"mini-svg-data-uri";import{CONFIG as t,PUBLICPATH as o}from"./config.js";import{hasPkg as r}from"./has-pkg.js";import l from"./modify-vars.js";import a,{CUSTOMCONFIG as i}from"./paths.js";import{FRAMEWORK as n,isDev as c,isLibrary as d,isMicro as m}from"./process-env.js";import p from"./swcrc.js";import u from"./tsloader.config.js";import{resolveNodeModulesPath as f,resolveProgramPath as y}from"./utils.js";import{comment as x}from"./vm/docs.js";let $={loader:`${a.corePath}/loader/css-unicode.cjs`},g=m?o:"../",v={loader:e.loader,options:{publicPath:"/"!==g?g:"../"}},j=r("@moneko/postcss")&&{loader:"postcss-loader",options:{postcssOptions:(await import("@moneko/postcss")).default}};c&&(v="style-loader");let w=[...t.cssModules,`@moneko/${n}`,"neko-ui"].map(f),h=[...["src/styles/variables.less","src/styles/mixins.less","site/styles/variables.less","site/styles/mixins.less"].map(y)],b=["components","example","mock","site","src","server"].map(y);i&&b.push(y(i)),t.overrideResolve&&t.overrideResolve.override&&b.push(t.overrideResolve.override);let _={loader:"css-loader",options:{modules:{auto:e=>{for(let s=0,t=w.length;s<t;s++)if(e&&e?.includes(w[s]))return/(.*(?<!\.?global\.(le|c|sc|sa)ss)$)/i.test(e);return/(^(?!.*node_modules))(.*(?<!\.?global\.(le|c|sc|sa)ss)$)/i.test(e)},localIdentName:"[path][name]__[local]",exportLocalsConvention:"dashesOnly"},importLoaders:2}},k=c&&{loader:"@teamsupercell/typings-for-css-modules-loader",options:{verifyOnly:!c}},O=[v,k,_,j,$,{loader:"less-loader",options:{sourceMap:!!t.sourceMap,lessOptions:{modifyVars:l,javascriptEnabled:!0}}},{loader:"style-resources-loader",options:{patterns:h}}].filter(Boolean),B="tsc"===t.compiler,L={loader:B?"ts-loader":"swc-loader",options:B?u:p(c)};function P(e){return b.concat(t.rulesInclude?.[e]?.map(f)||[])}let R=P("media"),M={rules:[d&&{test:/^(?![._]).*(?<!\.test)\.(tsx?)$/,include:t.alias["@pkg"],exclude:[/node_modules/,/(.+)\/__tests__\/(.+)/i],enforce:"pre",loader:`${a.corePath}/loader/ts-doc.cjs`,options:x},{oneOf:[{resourceQuery:/raw/i,type:"asset/source"},{resourceQuery:/url/i,type:"asset/resource",generator:{filename:e=>{let s=e.filename;return s&&s.endsWith("wasm?url")?"wasm/[name][ext]":"assets/[name][ext]"}}},{test:/\.wasm$/i,type:"webassembly/async",include:P("wasm")},{test:/\.txt$/i,type:"asset/source"},{test:/\.ico$/i,type:"asset/inline",include:R},{test:/\.svg$/i,type:"asset/inline",generator:{dataUrl:e=>s(e.toString())},include:R},{test:/\.(gif|png|jpe?g|webp)$/i,type:"asset",dependency:{not:["url"]},generator:{filename:"assets/images/[name][ext]"},include:R},{test:/\.(webm|mp4|ogv)$/i,type:"asset",dependency:{not:["url"]},generator:{filename:"assets/video/[name][ext]"},include:R},{test:/\.(woff2?|eot|ttf|otf)(\?.*)?$/i,type:"asset",dependency:{not:["url"]},generator:{filename:"assets/fonts/[name][ext]"},include:P("font")},{test:/\.(sa|sc)ss$/i,use:[v,k,_,j,$,{loader:"sass-loader",options:{implementation:await import("sass"),sassOptions:{}}}].filter(Boolean),include:P("css")},{test:/\.less$/i,use:O,include:P("css")},{test:/\.css$/i,use:[v,"css-loader",j,$].filter(Boolean),include:P("css")},{test:/\.(cj|mj|t|j)s(|x)$/i,use:[...t.prefixJsLoader,L].filter(Boolean),include:P("js")},{test:/\.mdx?$/i,use:[...t.prefixJsLoader,{loader:`${a.corePath}/loader/mdx.cjs`,options:t.mdx}].filter(Boolean),include:b,exclude:[/(.+)\/examples\/(.+).mdx?$/i]},{test:/\.mdx?$/i,type:"asset/source",include:[/(.+)\/examples\/(.+).mdx?$/i]},{type:"asset/source",include:[/(.+)\/examples\/(.+).*?$/i]}]},...t.moduleRules].filter(e=>"object"==typeof e)};export default M;
package/lib/paths.js CHANGED
@@ -1 +1 @@
1
- import{existsSync as e,mkdirSync as o}from"fs";import c from"url";let t=JSON.parse(process.env.npm_config_argv||"{}")?.original;export const yarnArgv={};t?.forEach(e=>{let o=e.split("=");Object.assign(yarnArgv,{[o[0]]:o[1]||!0})});export const CUSTOMCONFIG=process.env.npm_config_config||yarnArgv.config;let a=process.cwd(),r=`${a}/node_modules/.cache/.mo`;e(r)||o(r,{recursive:!0});export default{corePath:c.fileURLToPath(new URL(".",import.meta.url)),programPath:a,webpackCachePath:`${a}/node_modules/.temp_cache`,cachePath:r,httpCachePath:`${a}/node_modules/.cache/http`,swcCachePath:`${a}/node_modules/.swc`,configPath:`${a}/config/index.ts`,customConfigPath:`${a}/config/${CUSTOMCONFIG}.ts`,coveragePath:`${a}/coverage/clover.xml`,pagesPath:`${a}/src/pages`,componentsPath:`${a}/components`};
1
+ import e from"url";import{createDirAll as o,directoryExists as c}from"@moneko/mdx";let t=JSON.parse(process.env.npm_config_argv||"{}")?.original;export const yarnArgv={};t?.forEach(e=>{let o=e.split("=");Object.assign(yarnArgv,{[o[0]]:o[1]||!0})});export const CUSTOMCONFIG=process.env.npm_config_config||yarnArgv.config;let a=process.cwd(),n=`${a}/node_modules/.cache/.mo`;c(n)||o(n);export default{corePath:e.fileURLToPath(new URL(".",import.meta.url)),programPath:a,webpackCachePath:`${a}/node_modules/.temp_cache`,cachePath:n,httpCachePath:`${a}/node_modules/.cache/http`,swcCachePath:`${a}/node_modules/.swc`,configPath:`${a}/config/index.ts`,customConfigPath:`${a}/config/${CUSTOMCONFIG}.ts`,coveragePath:`${a}/coverage/clover.xml`,pagesPath:`${a}/src/pages`,componentsPath:`${a}/components`};
@@ -1 +1 @@
1
- import{existsSync as t}from"fs";import{relative as e}from"path";import r from"../paths.js";let a="OverrideResolverPlugin";export default class{constructor(t){this.options=t}apply(i){let{override:s,original:o}=this.options;if(s&&o){let l=`./${e(r.programPath,o)}`,p=`./${e(r.programPath,s)}`;i.getHook("existing-file").tapAsync(a,(e,r,h)=>{let n=e.request||e.path;if(n&&n.startsWith(o)&&e.relativePath){let f=n.replace(o,s);if(t(f)){let t=e.relativePath.replace(l,p);return Object.assign(e,{path:f,relativePath:t,__innerRequest_relativePath:t,__innerRequest:t}),i.doResolve("resolved",e,`${a} 使用目标模块${s}`,r,h)}}return h()})}}}
1
+ import{relative as e}from"path";import{fileExists as t}from"@moneko/mdx";import r from"../paths.js";let a="OverrideResolverPlugin";export default class{constructor(e){this.options=e}apply(i){let{override:o,original:s}=this.options;if(o&&s){let l=`./${e(r.programPath,s)}`,p=`./${e(r.programPath,o)}`;i.getHook("existing-file").tapAsync(a,(e,r,n)=>{let h=e.request||e.path;if(h&&h.startsWith(s)&&e.relativePath){let m=h.replace(s,o);if(t(m)){let t=e.relativePath.replace(l,p);return Object.assign(e,{path:m,relativePath:t,__innerRequest_relativePath:t,__innerRequest:t}),i.doResolve("resolved",e,`${a} 使用目标模块${o}`,r,n)}}return n()})}}}
@@ -1 +1 @@
1
- import o from"webpack-virtual-modules";import{isLibrary as t}from"../process-env.js";import{resolveNodeModulesPath as e}from"../utils.js";import{comment as p,docs as s,docsModuleName as a}from"../vm/docs.js";import{exampleModuleName as r,examples as i}from"../vm/example.js";import{locales as l,localesModuleName as n}from"../vm/locales.js";import{route as f,routesModuleName as m}from"../vm/routes.js";export default class{constructor(o){this.options=o,this.hasTapped=!1}apply(c){let h=new o({[e(m)]:f.getData(m),[e(r)]:"export default []",[e(n)]:l.getData(n),[e(a)]:s.getData(a)});function u(o,t){let p=e(o);h.writeModule(p,t||"")}h.apply(c),f.on("change",u),l.on("change",u),t&&(i.on("change",u),s.on("change",u),p.on("change",u)),c.hooks.compilation.tap("VirtualModuleWebpackPlugin",()=>{if(!this.hasTapped){for(let o in this.hasTapped=!0,this.options)if(Object.prototype.hasOwnProperty.call(this.options,o)){let t=this.options[o];u(o,"string"==typeof t?t:`export default ${JSON.stringify(t)}`)}for(let o of i)u(...o);for(let o of s)u(...o);for(let o of p)u(...o)}})}}
1
+ import e from"webpack-virtual-modules";import{CONFIG as t}from"../config.js";import o from"../info.js";import{FRAMEWORKNAME as n,isLibrary as r,isReact as i}from"../process-env.js";import{resolveNodeModulesPath as a}from"../utils.js";import l from"../vm/coverage.js";import{comment as p,docs as s,docsModuleName as c}from"../vm/docs.js";import m from"../vm/entry.js";import{exampleModuleName as u,examples as d}from"../vm/example.js";import{locales as f,localesModuleName as b}from"../vm/locales.js";import h from"../vm/mdx-scope.js";import{route as g,routesModuleName as y}from"../vm/routes.js";let x=t.fallbackCompPath&&`import F from "${t.fallbackCompPath}";export default F;`,k=t.rem?.designSize||1680;export default class{constructor(e){this.options=e,this.hasTapped=!1}apply(t){let v=new e({[a("@app/info")]:`export default ${JSON.stringify(o)}`,[a("@app/entry")]:m,[a("@app/rem")]:`!function(e,n){function t(){let n=e.documentElement,t=n.clientWidth||e.body.clientWidth,i=t<=375?375:${k},o=t;o=t<=375?t:t<=${k}?i:t;let d=16/i*o+"px";d!==n.style.fontSize&&(n.style.fontSize=d)}t(),"addEventListener"in e&&n.addEventListener("orientationchange"in n?"orientationchange":"resize",t,!1)}(document,window);`,[a("@app/fallback")]:x||"export default null",[a("@app/coverage")]:l,[a("@app/merge-router")]:"function merge(e,r){if(!e.length)return void 0;const n=[];e.forEach(e=>{const t=n.findIndex(n=>n[r]==e[r]);if(t>-1){const i=[...n[t].children||[],...e.children||[]];n[t]=Object.assign(e,n[t],n[t].meta&&{meta:{...n[t].meta,...e.meta}});if(i.length){n[t].children=merge(i,r)}}else{n.push(Object.assign(e,Array.isArray(e.children)&&{children:merge(e.children,r)}))}});return n}export default merge;",[a("@app/prefix-router")]:'import { createElement, isValidElement } from "react";import { Outlet } from "react-router-dom";function prefix(e){return e.map(function(e){var n=Object.assign({key:e.path},e);return n.element?isValidElement(n.element)||(n.element=createElement(n.element,n.meta)):n.element=createElement(Outlet,null),Array.isArray(n.children)&&(n.children=prefix(n.children)),n})}export default prefix;',[a("@app/normalize/index.css")]:'html,body{margin:0;padding:0;line-height:1.8}input,textarea{caret-color:inherit}h1{margin:0.67em 0;font-size:2em}hr{overflow:visible;block-size:0;box-sizing:content-box}pre{font-size:1em;font-family:monospace}a{text-decoration:none;background-color:transparent;cursor:pointer}abbr[title]{border-block-end:none;text-decoration:underline;text-decoration:underline dotted}b,strong{font-weight:bolder}code,kbd,samp{font-size:1em;font-family:monospace}small{font-size:80%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sub{inset-block-end:-0.25em}sup{inset-block-start:-0.5em}img{border-style:none}img,button{outline:1px solid transparent}button,input,optgroup,select,textarea{margin:0;font-size:100%;font-family:inherit;line-height:1.15}button,input{overflow:visible}button,select{text-transform:none}button,[type="button"],[type="reset"],[type="submit"]{appearance:button}button::-moz-focus-inner,[type="button"]::-moz-focus-inner,[type="reset"]::-moz-focus-inner,[type="submit"]::-moz-focus-inner{border-style:none;padding:0}button:-moz-focusring,[type="button"]:-moz-focusring,[type="reset"]:-moz-focusring,[type="submit"]:-moz-focusring{outline:1px dotted var(--primary-outline)}fieldset{padding:0.35em 0.75em 0.625em}legend{display:table;padding:0;max-inline-size:100%;white-space:normal;color:inherit;box-sizing:border-box}progress{vertical-align:baseline}textarea{overflow:auto}details{display:block}summary{display:list-item}template,[hidden]{display:none}[type="checkbox"],[type="radio"]{box-sizing:border-box;padding:0}[type="number"]::-webkit-inner-spin-button,[type="number"]::-webkit-outer-spin-button{block-size:auto}[type="search"]{appearance:textfield;outline-offset:-2px}[type="search"]::-webkit-search-decoration{appearance:none}::-webkit-file-upload-button{appearance:button;font:inherit}::-webkit-scrollbar{inline-size:5px;block-size:5px}::-webkit-scrollbar-track,::-webkit-scrollbar-thumb{background-color:transparent}:hover::-webkit-scrollbar-thumb{background-color:var(--primary-selection)}::-webkit-scrollbar-thumb:hover{background-color:var(--primary-hover)}::-webkit-scrollbar-thumb:active{background-color:var(--primary-active)}::-webkit-scrollbar-button{display:none}',[a("@app/suspense/index.tsx")]:`import ${i?"React,":""}{Suspense,lazy} from "${n}";import Fallback from '@app/fallback';${r?'import scope from "@app/mdx-scope";':""}function SuspenseComp(props) {const Lazy = lazy(props.comp);return (<Suspense fallback={Fallback && <Fallback />}><Lazy ${r?"components={scope}":""}/></Suspense>);}export default SuspenseComp;`,[a("@app/mdx-scope")]:h,[a(y)]:g.getData(y),[a(u)]:"export default []",[a(b)]:f.getData(b),[a(c)]:s.getData(c)});function z(e,t){let o=a(e);v.writeModule(o,t||"")}v.apply(t),g.on("change",z),f.on("change",z),r&&(d.on("change",z),s.on("change",z),p.on("change",z)),t.hooks.compilation.tap("VirtualModuleWebpackPlugin",()=>{if(!this.hasTapped){for(let e in this.hasTapped=!0,this.options)if(Object.prototype.hasOwnProperty.call(this.options,e)){let t=this.options[e];z(e,"string"==typeof t?t:`export default ${JSON.stringify(t)}`)}for(let e of d)z(...e);for(let e of s)z(...e);for(let e of p)z(...e)}})}}
@@ -20,5 +20,3 @@ export declare const PACKAGEVERSION: string;
20
20
  export declare const coreName: string;
21
21
  /** 是否为本地开发环境 */
22
22
  export declare const isDev: boolean;
23
- export declare const hasEslintConfig: boolean;
24
- export declare const hasStylelintConfig: boolean;
@@ -1 +1 @@
1
- export const APPTYPE=process.env.APPTYPE;export const FRAMEWORK=process.env.FRAMEWORK;export const isLibrary="library"===APPTYPE;export const isMicro="micro"===APPTYPE;export const isMobile="mobile"===APPTYPE;export const isReact="react"===FRAMEWORK;export const isSolid="solid"===FRAMEWORK;export const mainDirectory=isLibrary?"site":"src";export const jsxImportSource={react:"react",solid:"solid-js/h"}[FRAMEWORK];export const createElement={react:"createElement",solid:"createComponent"}[FRAMEWORK];export const FRAMEWORKNAME={react:"react",solid:"solid-js"}[FRAMEWORK];export const PACKAGENAME=process.env.npm_package_name;export const PACKAGEVERSION=process.env.npm_package_version;export const coreName="@moneko/core";export const isDev="development"===process.env.NODE_ENV;let e=Object.keys(process.env);export const hasEslintConfig=-1!==e.findIndex(e=>e.startsWith("npm_package_eslintConfig_"));export const hasStylelintConfig=-1!==e.findIndex(e=>e.startsWith("npm_package_stylelint_"));
1
+ export const APPTYPE=process.env.APPTYPE;export const FRAMEWORK=process.env.FRAMEWORK;export const isLibrary="library"===APPTYPE;export const isMicro="micro"===APPTYPE;export const isMobile="mobile"===APPTYPE;export const isReact="react"===FRAMEWORK;export const isSolid="solid"===FRAMEWORK;export const mainDirectory=isLibrary?"site":"src";export const jsxImportSource={react:"react",solid:"solid-js/h"}[FRAMEWORK];export const createElement={react:"createElement",solid:"createComponent"}[FRAMEWORK];export const FRAMEWORKNAME={react:"react",solid:"solid-js"}[FRAMEWORK];export const PACKAGENAME=process.env.npm_package_name;export const PACKAGEVERSION=process.env.npm_package_version;export const coreName="@moneko/core";export const isDev="development"===process.env.NODE_ENV;
package/lib/prod.js CHANGED
@@ -1 +1 @@
1
- import e from"css-minimizer-webpack-plugin";import i from"mini-css-extract-plugin";import o from"terser-webpack-plugin";import n from"webpack";import{BundleAnalyzerPlugin as m}from"webpack-bundle-analyzer";import{merge as r}from"webpack-merge";import s from"webpackbar";import{clientConfig as t}from"./common.js";import{CONFIG as p}from"./config.js";import{getMinifyOption as a}from"./minify.js";import l from"./paths.js";import c from"./plugin/done.js";import u from"./seo.js";import{cleanDir as f}from"./utils.js";let{optimize:{MinChunkSizePlugin:d}}=n,{cssnanoMinify:h,swcMinify:w}=e,k="swc"===p.compiler,b=[];p.minifier&&(p.minifier.js&&b.push(new o(a(p.minifier.js?.type||(k?"swc":"terser"),p.minifier.js?.options))),p.minifier.css&&b.push(new e({minify:{swc:w,cssnano:h}[p.minifier.css?.type||(k?"swc":"cssnano")],minimizerOptions:p.minifier.css?.options})));let g={splitChunks:p.splitChunk,runtimeChunk:p.runtimeChunk,chunkIds:"named",moduleIds:"named",removeAvailableModules:!0,removeEmptyChunks:!0,mergeDuplicateChunks:!0,mangleWasmImports:!0,minimize:!0,minimizer:b},j=n(r(t,{devtool:!1===p.devtool||p.devtool?p.devtool:"cheap-module-source-map",mode:"production",optimization:g,plugins:[new i({filename:"style/[name].bundle.css",chunkFilename:"style/[name].chunk.css",experimentalUseImportModule:!0}),p.splitChunk&&new d({minChunkSize:1e4}),p.bundleAnalyzer&&new m(p.bundleAnalyzer),p.bar&&new s(p.bar),new c({done:e=>{p.done?.(e),p.seo&&u()}})].filter(Boolean)}));j.watch({aggregateTimeout:20,ignored:/node_modules(?![\\/]@app)/,stdin:!0},e=>{if(e)throw j.close(()=>{}),e;j.hooks.done.tap("WatchRunPlugin",e=>{e.hasErrors(),j.close(()=>{})})}),process.on("exit",function(){f(l.cachePath)});
1
+ import{removeDirAll as e}from"@moneko/mdx";import i from"css-minimizer-webpack-plugin";import o from"mini-css-extract-plugin";import n from"terser-webpack-plugin";import m from"webpack";import{BundleAnalyzerPlugin as r}from"webpack-bundle-analyzer";import{merge as s}from"webpack-merge";import t from"webpackbar";import{clientConfig as p}from"./common.js";import{CONFIG as a}from"./config.js";import{getMinifyOption as l}from"./minify.js";import c from"./paths.js";import u from"./plugin/done.js";import f from"./seo.js";let{optimize:{MinChunkSizePlugin:d}}=m,{cssnanoMinify:h,swcMinify:k}=i,w="swc"===a.compiler,b=[];a.minifier&&(a.minifier.js&&b.push(new n(l(a.minifier.js?.type||(w?"swc":"terser"),a.minifier.js?.options))),a.minifier.css&&b.push(new i({minify:{swc:k,cssnano:h}[a.minifier.css?.type||(w?"swc":"cssnano")],minimizerOptions:a.minifier.css?.options})));let g={splitChunks:a.splitChunk,runtimeChunk:a.runtimeChunk,chunkIds:"named",moduleIds:"named",removeAvailableModules:!0,removeEmptyChunks:!0,mergeDuplicateChunks:!0,mangleWasmImports:!0,minimize:!0,minimizer:b},y=m(s(p,{devtool:!1===a.devtool||a.devtool?a.devtool:"cheap-module-source-map",mode:"production",optimization:g,plugins:[new o({filename:"style/[name].bundle.css",chunkFilename:"style/[name].chunk.css",experimentalUseImportModule:!0}),a.splitChunk&&new d({minChunkSize:1e4}),a.bundleAnalyzer&&new r(a.bundleAnalyzer),a.bar&&new t(a.bar),new u({done:e=>{a.done?.(e),a.seo&&f()}})].filter(Boolean)}));y.watch({aggregateTimeout:20,ignored:/node_modules(?![\\/]@app)/,stdin:!0},e=>{if(e)throw y.close(()=>{}),e;y.hooks.done.tap("WatchRunPlugin",e=>{e.hasErrors(),y.close(()=>{})})}),process.on("exit",function(){e(c.cachePath)});
package/lib/seo.js CHANGED
@@ -1 +1 @@
1
- import{existsSync as t,mkdirSync as o,writeFileSync as r}from"fs";import{join as i}from"path";import{outputConfig as m}from"./common.js";import{CONFIG as e}from"./config.js";import{resolveProgramPath as s}from"./utils.js";import{routes as p}from"./vm/routes.js";function f(t,o){try{r(t,o,"utf-8")}catch(t){}}export default(()=>{let{domain:r,nojekyll:n,path:a}=e.seo||{},h=a&&s(a)||m?.path;if(!r||!h)return;t(h)||o(h);let c=e.basename,l=c.endsWith("/")?c:`${c}/`;f(i(h,"CNAME"),r),f(i(h,"robots"),`Sitemap: https://${r}${l}sitemap.txt`);let u=[];!function t(o){o.forEach(o=>{u.push(`https://${r}${l}${o.key}`),Array.isArray(o.children)&&t(o.children)})}(p),f(i(h,"sitemap.txt"),u.join("\n")),n&&f(i(h,".nojekyll"),"")});
1
+ import{join as t}from"path";import{createDirAll as o,directoryExists as r,saveFileSync as m}from"@moneko/mdx";import{outputConfig as e}from"./common.js";import{CONFIG as i}from"./config.js";import{resolveProgramPath as s}from"./utils.js";import{routes as p}from"./vm/routes.js";export default(()=>{let{domain:n,nojekyll:a,path:f}=i.seo||{},h=f&&s(f)||e?.path;if(!n||!h)return;r(h)||o(h);let l=i.basename,c=l.endsWith("/")?l:`${l}/`;m(t(h,"CNAME"),n),m(t(h,"robots"),`Sitemap: https://${n}${c}sitemap.txt`);let j=[];!function t(o){o.forEach(o=>{j.push(`https://${n}${c}${o.key}`),Array.isArray(o.children)&&t(o.children)})}(p),m(t(h,"sitemap.txt"),j.join("\n")),a&&m(t(h,".nojekyll"),"")});
@@ -1 +1 @@
1
- import t from"fs";import r from"ts-import-plugin";import o from"webpack-merge";import{CONFIG as e}from"./config.js";import{isFunction as s,readConf as m,resolveProgramPath as a}from"./utils.js";let i=[];Array.isArray(e.importOnDemand)&&Object.assign(i,e.importOnDemand.map(t=>r(t)));let n=[...i],p={transpileOnly:!0,getCustomTransformers:()=>({before:n})};try{let r=a("tsloader.config.ts");t.accessSync(r,t.constants.R_OK);let e=(await m(r,"tsloader.config")).default;p=o(p,s(e)?e(process):e)}catch(t){}export default p;
1
+ import{fileExists as r}from"@moneko/mdx";import t from"ts-import-plugin";import o from"webpack-merge";import{CONFIG as e}from"./config.js";import{isFunction as m,readConf as i,resolveProgramPath as a}from"./utils.js";let s=[];Array.isArray(e.importOnDemand)&&Object.assign(s,e.importOnDemand.map(r=>t(r)));let p=[...s],f={transpileOnly:!0,getCustomTransformers:()=>({before:p})},n=a("tsloader.config.ts");if(r(n))try{let r=(await i(n,"tsloader.config")).default;f=o(f,m(r)?r(process):r)}catch(r){}export default f;
package/lib/utils.d.ts CHANGED
@@ -1,14 +1,8 @@
1
1
  export declare function esm(templateStrings: TemplateStringsArray, ...substitutions: unknown[]): string;
2
- /** 获取导出标识
3
- * @param {string} path 文件地址
4
- * @returns {string[]} 包含的标识
5
- */
6
- export declare function getExportTokens(path: string): string[];
7
2
  export declare function log(msg: string | string[]): void;
8
3
  export declare function tfc(filepath: string): string;
9
4
  export declare function readConf(src: string, name: string): Promise<any>;
10
5
  export declare function toUpperCaseString(string: string): string;
11
- export declare function cleanDir(folderPath: string): void;
12
6
  type ProgramPath<T extends string> = `${T extends string ? T : string}`;
13
7
  type NodeModulesPath<T> = ProgramPath<`node_modules/${T extends string ? T : string}`>;
14
8
  /** 位于项目根目录下的位置
package/lib/utils.js CHANGED
@@ -1,2 +1,2 @@
1
- import{existsSync as t,readFileSync as e,readdirSync as r,rmdirSync as o,statSync as n,unlinkSync as c,writeFileSync as s}from"fs";import{join as p,resolve as i}from"path";import a from"readline";import{transformFileSync as u}from"@swc/core";import f from"./paths.js";import l from"./resolver-sync.js";export function esm(t,...e){let r=t.raw[0];for(let o=0;o<e.length;o++)r+=e[o]+t.raw[o+1];return`data:text/javascript;base64,${Buffer.from(r).toString("base64")}`}let m=/export\s+(?:async\s+)?(?:function|const)\s+(\w+)/g;export function getExportTokens(t){let r;let o=e(t,{encoding:"utf-8"}),n=[];for(;r=m.exec(o);)n.includes(r[1])||n.push(r[1]);return n}let x={inputSourceMap:!1,sourceMaps:!1,module:{type:"es6"},jsc:{parser:{syntax:"typescript"},loose:!1}};export function log(t){Array.isArray(t)?t.forEach(t=>{log(`${t}
2
- `)}):(a.cursorTo(process.stdout,0),process.stdout.write(t))}export function tfc(t){return u(t,x).code||"{}"}export function readConf(t,e){let r=`${f.cachePath}/${e}.mjs`;return s(r,tfc(t),"utf-8"),import(r)}export function toUpperCaseString(t){return t?.replace(/\b\w/g,t=>t.toUpperCase()).replace(/\./g," ")}export function cleanDir(e){t(e)&&(r(e).forEach(t=>{let r=p(e,t);n(r).isDirectory()?cleanDir(r):c(r)}),o(e))}export function resolveProgramPath(t){return i(f.programPath,`./${t}`)}export const resolveNodeModulesPath=t=>resolveProgramPath(`node_modules/${t}`);export const realResolve=t=>l.resolveSync({},f.programPath,t)||t;export function isObject(t){let e=typeof t;return null!==t&&("object"==e||"function"==e)}export function isFunction(t){if(!isObject(t))return!1;let e=Object.prototype.toString.call(t);return"[object Function]"==e||"[object AsyncFunction]"==e||"[object GeneratorFunction]"==e||"[object Proxy]"==e}export function empty(){}
1
+ import{resolve as t}from"path";import r from"readline";import{saveFileSync as o}from"@moneko/mdx";import{transformFileSync as e}from"@swc/core";import n from"./paths.js";import c from"./resolver-sync.js";export function esm(t,...r){let o=t.raw[0];for(let e=0;e<r.length;e++)o+=r[e]+t.raw[e+1];return`data:text/javascript;base64,${Buffer.from(o).toString("base64")}`}let p={inputSourceMap:!1,sourceMaps:!1,module:{type:"es6"},jsc:{parser:{syntax:"typescript"},loose:!1}};export function log(t){Array.isArray(t)?t.forEach(t=>{log(`${t}
2
+ `)}):(r.cursorTo(process.stdout,0),process.stdout.write(t))}export function tfc(t){return e(t,p).code||"{}"}export function readConf(t,r){let e=`${n.cachePath}/${r}.mjs`;return o(e,tfc(t)),import(e)}export function toUpperCaseString(t){return t?.replace(/\b\w/g,t=>t.toUpperCase()).replace(/\./g," ")}export function resolveProgramPath(r){return t(n.programPath,`./${r}`)}export const resolveNodeModulesPath=t=>resolveProgramPath(`node_modules/${t}`);export const realResolve=t=>c.resolveSync({},n.programPath,t)||t;export function isObject(t){let r=typeof t;return null!==t&&("object"==r||"function"==r)}export function isFunction(t){if(!isObject(t))return!1;let r=Object.prototype.toString.call(t);return"[object Function]"==r||"[object AsyncFunction]"==r||"[object GeneratorFunction]"==r||"[object Proxy]"==r}export function empty(){}
@@ -1,31 +1,2 @@
1
- type CoverageType = {
2
- /** 语句(statement coverage) */
3
- statements: string;
4
- /** 语句覆盖: 是不是每个语句都执行了 */
5
- coveredstatements: string;
6
- /** 条件(branch coverage) */
7
- conditionals: string;
8
- /** 条件覆盖: 是不是每个条件代码块都执行了 */
9
- coveredconditionals: string;
10
- /** 函数(function coverage) */
11
- methods: string;
12
- /** 函数覆盖: 是不是每个函数都调用了 */
13
- coveredmethods: string;
14
- };
15
- type ProjectCoverageType = {
16
- /** 元素 */
17
- elements: string;
18
- /** 覆盖元素 */
19
- coveredelements: string;
20
- complexity: string;
21
- loc: string;
22
- ncloc: string;
23
- /** 经过测试的组件 */
24
- packages: string;
25
- /** 经过测试的文件 */
26
- files: string;
27
- /** 经过测试的类 */
28
- classes: string;
29
- };
30
- export declare const coverage: Record<string, CoverageType & ProjectCoverageType>;
31
- export {};
1
+ declare let coverage: string;
2
+ export default coverage;
@@ -1 +1 @@
1
- import{accessSync as e,constants as r,readFileSync as c}from"fs";import{Parser as o}from"xml2js";import t from"../paths.js";import{PACKAGENAME as a,isLibrary as s}from"../process-env.js";export const coverage={};if(s)try{e(t.coveragePath,r.R_OK);let s=new o({explicitArray:!1,async:!1}).parseString,i=c(t.coveragePath,{encoding:"utf-8"});s(i,(e,r)=>{if(!e){let e=r.coverage.project.metrics.$,c=r.coverage.project.package;Object.assign(coverage,{[a]:e}),c.forEach(e=>{Object.assign(coverage,{[e.$.name]:e.metrics.$})})}})}catch(e){}
1
+ import{fileExists as e,loadFileSync as r}from"@moneko/mdx";import{Parser as t}from"xml2js";import o from"../paths.js";import{PACKAGENAME as a,isLibrary as c}from"../process-env.js";let s={},i="export default {}";if(c&&e(o.coveragePath))try{let e=r(o.coveragePath);(0,new t({explicitArray:!1,async:!1}).parseString)(e,(e,r)=>{e||(Object.assign(s,{[a]:r.coverage.project.metrics.$}),r.coverage.project.package.forEach(e=>{Object.assign(s,{[e.$.name]:e.metrics.$})})),i=`export default ${JSON.stringify(s)}`})}catch(e){}export default i;
@@ -0,0 +1,2 @@
1
+ declare const _default: string;
2
+ export default _default;
@@ -0,0 +1 @@
1
+ import{join as o}from"path";import{fileExists as p,loadFileSync as n}from"@moneko/mdx";import{CONFIG as t}from"../config.js";import{FRAMEWORK as e,isMicro as r,isMobile as i}from"../process-env.js";let s=/export\s+(?:async\s+)?(?:function|const)\s+(\w+)/g,m=o(t.alias["@"],"./index.ts"),u="",a=`const renderApp = (await import('@moneko/${e}/lib/entry.js')).default;`,_=[];if(p(m)){let o="";r&&(_=(function(o){let p;let t=n(o)||"",e=[];for(;p=s.exec(t);)e.includes(p[1])||e.push(p[1]);return e})(m).filter(Boolean)).length&&(o=`{${_.map(o=>`${o} as app${o}`).join(",")}} from `),u=`import ${o}"@/index.ts";`}t.rem&&(u+='import "@app/rem";'),t.normalizeCss&&(u+='import "@app/normalize/index.css";'),r?(u+="if (window.__POWERED_BY_QIANKUN__) {__webpack_public_path__ = window.__INJECTED_PUBLIC_PATH_BY_QIANKUN__;}",a+=`if (!window.__POWERED_BY_QIANKUN__) {renderApp();}let unmountApp = void 0;export async function bootstrap() {console.log('app bootstraped');}export async function mount(props) {${_.includes("mount")?"appmount(props);":""}unmountApp = renderApp(props);}export async function unmount(props) {${_.includes("unmount")?"appunmount(props);":""}unmountApp();}`):a+="renderApp();",i&&(a+="window.H5RemoteRuntime = {bootstrap: renderApp};");export default`${u}${a}`;
package/lib/vm/locales.js CHANGED
@@ -1,2 +1,2 @@
1
- import{existsSync as e}from"fs";import{basename as t,join as o}from"path";import{watch as a}from"chokidar";import{CONFIG as l}from"../config.js";import{FRAMEWORK as r,isDev as n}from"../process-env.js";import c from"../reactive-object.js";import{empty as s,esm as i,tfc as g}from"../utils.js";let f={react:'import sso from "shared-store-object";',solid:'import { createEffect, createRoot, getOwner } from "solid-js";import { createStore } from "solid-js/store";'},u={react:'let storageKey="localizable.language",language=localStorage.getItem(storageKey)||"zh_CN",{translation:a,...defaultLocale}=Object.assign({title:"简体中文",language:"zh_CN",translation:{}},resources[language]||resources.zh_CN),localizable=sso({lang:defaultLocale,t:a});export function setLang(a){let{translation:e,...l}=resources[a]||{};e&&(localizable.lang=l,localizable.t=e,localStorage.setItem(storageKey,l.language))}export default localizable;',solid:'let locale=createRoot(()=>{let e="localizable.language",a=localStorage.getItem(e)||"zh_CN",{translation:l,...o}=Object.assign({title:"简体中文",language:"zh_CN",translation:{}},resources[a]||resources.zh_CN),[n,c]=createStore({lang:o,t:l});return createEffect(()=>{let a=resources[n.lang.language]?.translation;a&&(c("t",a),localStorage.setItem(e,n.lang.language))}),{localizable:n,setLocalizable:c,setLang:function(e){let{translation:a,...l}=resources[e]||{};a&&c("lang",l)}}},getOwner());export const setLocalizable=locale.setLocalizable;export const t=locale.localizable.t;export const lang=locale.localizable.lang;export const setLang=locale.setLang;'}[r];function p(e,t){return`${f[r]}
2
- export function interpolateString(r,n){return r.replace(/\\\${\\w+}/g,function(r){var t=r.slice(2,-1);var e=n[t];return e!==void 0?e.toString():""})}function deepFreeze(o) { const p = Reflect.ownKeys(o);for (const k of p) {const v = o[k];if ((v && typeof v === "object") || typeof v === "function") {deepFreeze(v);}}return Object.freeze(o);}export const locales = ${JSON.stringify(e)};const _res = ${JSON.stringify(t)};const resources = deepFreeze(_res);${u}`}export const localesModuleName="@app/locales";export const locales=new c({[localesModuleName]:p([],{})});let d={};async function m(e,o){let a=t(e).replace(/\.[^.]+$/,"");"deleted"===o?delete d[a]:Object.assign(d,{[a]:(await import(i`${g(e)}`)).default});let l=[],r={};for(let e in d)if(Object.prototype.hasOwnProperty.call(d,e)){let{language:t=a,title:o=t,icon:n,translation:c={}}=d[e];l.push({language:t,title:o,icon:n}),r[t]={language:t,title:o,icon:n,translation:c}}locales.setData(localesModuleName,p(l,r))}let z=o(l.alias["@"],"./locales");e(z)&&function(e,t){let o=[],l=a(e,{ignored:t,persistent:!0,ignoreInitial:!1});function r(){l.unwatch(e),l.close()}l.on("add",e=>{o.push(e),m(e,"added").finally(s)}),l.on("change",e=>{m(e,"change").finally(s)}),l.on("unlink",e=>{o.splice(o.indexOf(e),1),m(e,"deleted").finally(s)}),l.once("ready",()=>{o.forEach(e=>{m(e,"change").finally(s)}),n||r()}),process.on("SIGINT",r)}(z,[/^\..*/,/!\.ts$/,/\.d\.ts$/]);
1
+ import{basename as e,join as t}from"path";import{directoryExists as o}from"@moneko/mdx";import{watch as a}from"chokidar";import{CONFIG as l}from"../config.js";import{FRAMEWORK as r,isDev as n}from"../process-env.js";import c from"../reactive-object.js";import{empty as s,esm as i,tfc as g}from"../utils.js";let f={react:'import sso from "shared-store-object";',solid:'import { createEffect, createRoot, getOwner } from "solid-js";import { createStore } from "solid-js/store";'},u={react:'let storageKey="localizable.language",language=localStorage.getItem(storageKey)||"zh_CN",{translation:a,...defaultLocale}=Object.assign({title:"简体中文",language:"zh_CN",translation:{}},resources[language]||resources.zh_CN),localizable=sso({lang:defaultLocale,t:a});export function setLang(a){let{translation:e,...l}=resources[a]||{};e&&(localizable.lang=l,localizable.t=e,localStorage.setItem(storageKey,l.language))}export default localizable;',solid:'let locale=createRoot(()=>{let e="localizable.language",a=localStorage.getItem(e)||"zh_CN",{translation:l,...o}=Object.assign({title:"简体中文",language:"zh_CN",translation:{}},resources[a]||resources.zh_CN),[n,c]=createStore({lang:o,t:l});return createEffect(()=>{let a=resources[n.lang.language]?.translation;a&&(c("t",a),localStorage.setItem(e,n.lang.language))}),{localizable:n,setLocalizable:c,setLang:function(e){let{translation:a,...l}=resources[e]||{};a&&c("lang",l)}}},getOwner());export const setLocalizable=locale.setLocalizable;export const t=locale.localizable.t;export const lang=locale.localizable.lang;export const setLang=locale.setLang;'}[r];function p(e,t){return`${f[r]}
2
+ export function interpolateString(r,n){return r.replace(/\\\${\\w+}/g,function(r){var t=r.slice(2,-1);var e=n[t];return e!==void 0?e.toString():""})}function deepFreeze(o) { const p = Reflect.ownKeys(o);for (const k of p) {const v = o[k];if ((v && typeof v === "object") || typeof v === "function") {deepFreeze(v);}}return Object.freeze(o);}export const locales = ${JSON.stringify(e)};const _res = ${JSON.stringify(t)};const resources = deepFreeze(_res);${u}`}export const localesModuleName="@app/locales";export const locales=new c({[localesModuleName]:p([],{})});let d={};async function m(t,o){let a=e(t).replace(/\.[^.]+$/,"");"deleted"===o?delete d[a]:Object.assign(d,{[a]:(await import(i`${g(t)}`)).default});let l=[],r={};for(let e in d)if(Object.prototype.hasOwnProperty.call(d,e)){let{language:t=a,title:o=t,icon:n,translation:c={}}=d[e];l.push({language:t,title:o,icon:n}),r[t]={language:t,title:o,icon:n,translation:c}}locales.setData(localesModuleName,p(l,r))}let z=t(l.alias["@"],"./locales");o(z)&&function(e,t){let o=[],l=a(e,{ignored:t,persistent:!0,ignoreInitial:!1});function r(){l.unwatch(e),l.close()}l.on("add",e=>{o.push(e),m(e,"added").finally(s)}),l.on("change",e=>{m(e,"change").finally(s)}),l.on("unlink",e=>{o.splice(o.indexOf(e),1),m(e,"deleted").finally(s)}),l.once("ready",()=>{o.forEach(e=>{m(e,"change").finally(s)}),n||r()}),process.on("SIGINT",r)}(z,[/^\..*/,/!\.ts$/,/\.d\.ts$/]);
@@ -0,0 +1,2 @@
1
+ declare let mdxScope: string;
2
+ export default mdxScope;
@@ -0,0 +1 @@
1
+ import{fileExists as o}from"@moneko/mdx";import{resolveProgramPath as e}from"../utils.js";let t="export default {};";o(e("site/mdx-scope.ts"))&&(t='import scope from "@/mdx-scope";export default scope');export default t;
package/lib/vm/routes.js CHANGED
@@ -1 +1 @@
1
- let e,r;import{accessSync as t,constants as o}from"fs";import{getTree as s,mergeRouter as p,watchFiles as m}from"./utils.js";import{CONFIG as u}from"../config.js";import i from"../paths.js";import{FRAMEWORK as a,FRAMEWORKNAME as c,createElement as f,isLibrary as l,isReact as n,isSolid as $}from"../process-env.js";import x from"../reactive-object.js";try{t(`${u.alias["@"]}/router/index.ts`,o.R_OK),e=!0}catch(r){e=!1}let d=`${$?"() => ":""}${f}(SuspenseComp, { comp: $1 })`,g=`import { ${f} } from "${c}";import SuspenseComp from "@app/suspense";${n?'import prefix from "@app/prefix-router";':""}`;e&&(g+='import merge from "@app/merge-router";import customRouter from "@/router";'),["react","solid"].includes(a)||(d="$1",g="");export const routesModuleName="@app/routes";export const route=new x({[routesModuleName]:"export default []"});export let routes=[];let h=l?i.componentsPath:i.pagesPath,j=l?"@pkg":"@/pages";m(h,l?/(?<!README\.mdx?)$/:/(?<!index\.tsx?)$/,function(t){clearTimeout(r),r=setTimeout(()=>{var o;clearTimeout(r),routes=p(s({base:h,files:t,alia:j}).reverse(),"key"),route.setData(routesModuleName,(o=JSON.stringify(routes).replace(/"rr\((.+?)\)rr"/g,d).slice(1,-1),`${g}const routes = [{ path: "/", children: [${$?'{ path: "/" },':""} ${o}] }];const _routes = ${e?'merge([...routes, ...customRouter], "path")':"routes"};export default ${n?"prefix(_routes)":"_routes"};`))},10)});
1
+ let e;import{fileExists as r}from"@moneko/mdx";import{getTree as o,mergeRouter as t,watchFiles as s}from"./utils.js";import{CONFIG as p}from"../config.js";import m from"../paths.js";import{FRAMEWORK as u,FRAMEWORKNAME as i,createElement as a,isLibrary as c,isReact as f,isSolid as l}from"../process-env.js";import n from"../reactive-object.js";let $=r(`${p.alias["@"]}/router/index.ts`),x=`${l?"() => ":""}${a}(SuspenseComp, { comp: $1 })`,d=`import { ${a} } from "${i}";import SuspenseComp from "@app/suspense";${f?'import prefix from "@app/prefix-router";':""}`;$&&(d+='import merge from "@app/merge-router";import customRouter from "@/router";'),["react","solid"].includes(u)||(x="$1",d="");export const routesModuleName="@app/routes";export const route=new n({[routesModuleName]:"export default []"});export let routes=[];let g=c?m.componentsPath:m.pagesPath,h=c?"@pkg":"@/pages";s(g,c?/(?<!README\.mdx?)$/:/(?<!index\.tsx?)$/,function(r){clearTimeout(e),e=setTimeout(()=>{var s;clearTimeout(e),routes=t(o({base:g,files:r,alia:h}).reverse(),"key"),route.setData(routesModuleName,(s=JSON.stringify(routes).replace(/"rr\((.+?)\)rr"/g,x).slice(1,-1),`${d}const routes = [{ path: "/", children: [${l?'{ path: "/" },':""} ${s}] }];const _routes = ${$?'merge([...routes, ...customRouter], "path")':"routes"};export default ${f?"prefix(_routes)":"_routes"};`))},10)});
package/lib/vm/utils.js CHANGED
@@ -1 +1 @@
1
- import{readFileSync as e}from"fs";import{join as t,relative as n}from"path";import{frontmatterSync as r}from"@moneko/mdx";import{watch as i}from"chokidar";import{isDev as o,isSolid as a}from"../process-env.js";import l from"../reactive-object.js";let s=new l({}),c=a?"component":"element";export function mergeRouter(e,t){if(!e.length)return;let n=[];return e.forEach(e=>{let r=n.findIndex(n=>n[t]==e[t]);if(r>-1){let i=[...n[r].children||[],...e.children||[]];n[r]=Object.assign(e,n[r]),i.length&&(n[r].children=mergeRouter(i,t))}else n.push(Object.assign(e,Array.isArray(e.children)&&{children:mergeRouter(e.children,t)}))}),n.forEach((e,t)=>{if(e.children?.length){let{children:r=[],...i}=e;n[t]={path:i.path,key:i.key,children:[a&&{...i,path:e.path===i.path?"/":i.path},...r].filter(e=>e&&(e.component||e.children?.length))}}}),n}export function getTree(e){let r={};return e.files.forEach(i=>{let o=s.getData(i)||{code:""},a=n(e.base,i),l=e.base.split("/").filter(Boolean),h=i.split("/").filter(Boolean).slice(0,-1),p={},f=Object.assign({meta:JSON.parse(o.frontmatter||"{}")},e.alia&&{[c]:`rr(() => import(/* webpackChunkName: '${a}' */'${t(e.alia,a)}'))rr`},e.outputSource&&{codes:function(e){let t;let n={},r=/```(.+?)\n([\s\S]*?)\n```/g;for(;null!==(t=r.exec(e));){let[,e="jsx",r]=t;n[e.split(" ").pop()||"jsx"]=r.trim()}return Object.keys(n).length?n:{jsx:e}}(o.code.replace(/^\n+|\n+$/g,""))});for(let t=l.length;t<h.length;t++){let n={path:h[t],key:h[t]};t===l.length?(Object.assign(p,r[n.key],{path:n.path,key:n.key},t===h.length-1&&f),r[n.key]=p):(p.children=(p.children||[]).concat([n]),e.outputSource?(Object.assign(n,{path:i.split("/").pop(),key:i.split("/").pop()},f),n.children=getTree({...e,base:`${e.base}/${n.key}`,files:e.files.filter(t=>t.startsWith(`${e.base}/${n.key}`))})):Object.assign(n,{key:h.slice(l.length,t+1).join("/")},f),p=n)}}),Object.values(r)}function h(t,n,i){if(i)s.removeData(t),n.removeData(t);else{let i=e(t,{encoding:"utf-8"});if(t.endsWith(".md")||t.endsWith(".mdx")){let e=r(i);s.setData(t,e),n.setData(t,!0)}else s.setData(t,{code:i,frontmatter:"{}"}),n.setData(t,!0)}}export function watchFiles(e,t,n){let r=new l({}),a=i(e,{ignored:(e,n)=>{if(n)return!n.isDirectory()&&t.test(e)},persistent:!0,ignoreInitial:!1});function s(){a.unwatch(e),a.close()}a.on("add",e=>{h(e,r)}).on("change",e=>{h(e,r)}).on("unlink",e=>{h(e,r,!0)}),a.once("ready",()=>{o||s()}),r.on("change",()=>{n(Object.keys(r.data))}),process.on("SIGINT",s)}
1
+ import{join as e,relative as t}from"path";import{frontmatterSync as n,loadFileSync as r}from"@moneko/mdx";import{watch as i}from"chokidar";import{isDev as o,isSolid as a}from"../process-env.js";import l from"../reactive-object.js";let s=new l({}),c=a?"component":"element";export function mergeRouter(e,t){if(!e.length)return;let n=[];return e.forEach(e=>{let r=n.findIndex(n=>n[t]==e[t]);if(r>-1){let i=[...n[r].children||[],...e.children||[]];n[r]=Object.assign(e,n[r]),i.length&&(n[r].children=mergeRouter(i,t))}else n.push(Object.assign(e,Array.isArray(e.children)&&{children:mergeRouter(e.children,t)}))}),n.forEach((e,t)=>{if(e.children?.length){let{children:r=[],...i}=e;n[t]={path:i.path,key:i.key,children:[a&&{...i,path:e.path===i.path?"/":i.path},...r].filter(e=>e&&(e.component||e.children?.length))}}}),n}export function getTree(n){let r={};return n.files.forEach(i=>{let o=s.getData(i)||{code:""},a=t(n.base,i),l=n.base.split("/").filter(Boolean),h=i.split("/").filter(Boolean).slice(0,-1),p={},f=Object.assign({meta:JSON.parse(o.frontmatter||"{}")},n.alia&&{[c]:`rr(() => import(/* webpackChunkName: '${a}' */'${e(n.alia,a)}'))rr`},n.outputSource&&{codes:function(e){let t;let n={},r=/```(.+?)\n([\s\S]*?)\n```/g;for(;null!==(t=r.exec(e));){let[,e="jsx",r]=t;n[e.split(" ").pop()||"jsx"]=r.trim()}return Object.keys(n).length?n:{jsx:e}}(o.code.replace(/^\n+|\n+$/g,""))});for(let e=l.length;e<h.length;e++){let t={path:h[e],key:h[e]};e===l.length?(Object.assign(p,r[t.key],{path:t.path,key:t.key},e===h.length-1&&f),r[t.key]=p):(p.children=(p.children||[]).concat([t]),n.outputSource?(Object.assign(t,{path:i.split("/").pop(),key:i.split("/").pop()},f),t.children=getTree({...n,base:`${n.base}/${t.key}`,files:n.files.filter(e=>e.startsWith(`${n.base}/${t.key}`))})):Object.assign(t,{key:h.slice(l.length,e+1).join("/")},f),p=t)}}),Object.values(r)}function h(e,t,i){if(i)s.removeData(e),t.removeData(e);else{let i=r(e)||"";if(e.endsWith(".md")||e.endsWith(".mdx")){let r=n(i);s.setData(e,r),t.setData(e,!0)}else s.setData(e,{code:i,frontmatter:"{}"}),t.setData(e,!0)}}export function watchFiles(e,t,n){let r=new l({}),a=i(e,{ignored:(e,n)=>{if(n)return!n.isDirectory()&&t.test(e)},persistent:!0,ignoreInitial:!1});function s(){a.unwatch(e),a.close()}a.on("add",e=>{h(e,r)}).on("change",e=>{h(e,r)}).on("unlink",e=>{h(e,r,!0)}),a.once("ready",()=>{o||s()}),r.on("change",()=>{n(Object.keys(r.data))}),process.on("SIGINT",s)}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@moneko/core",
3
- "version": "3.8.7-beta.6",
3
+ "version": "3.8.7-beta.8",
4
4
  "description": "core",
5
5
  "main": "lib/index.js",
6
6
  "type": "module",
@@ -13,7 +13,7 @@
13
13
  "author": "moneko",
14
14
  "license": "MIT",
15
15
  "dependencies": {
16
- "@moneko/mdx": "0.1.9",
16
+ "@moneko/mdx": "0.1.13",
17
17
  "@swc/core": "1.3.100",
18
18
  "@swc/css": "0.0.28",
19
19
  "@swc/helpers": "0.5.3",
@@ -1,2 +0,0 @@
1
- declare const virtualModules: Record<string, string | object>;
2
- export default virtualModules;
@@ -1 +0,0 @@
1
- import{accessSync as p,constants as o}from"fs";import{join as r}from"path";import{CONFIG as e}from"./config.js";import{FRAMEWORKNAME as m,isLibrary as s,isReact as t}from"./process-env.js";import{resolveProgramPath as a}from"./utils.js";import c from"./vm/app-entry.js";import f from"./vm/app.js";import{coverage as i}from"./vm/coverage.js";import l from"./vm/fallback.js";import n from"./vm/merge-router.js";import u from"./vm/normalize-css.js";import x from"./vm/prefix-router.js";let j={...e.virtualModule,"@app":f,"@app/fallback":l,"@app/coverage":i,"@app/normalize/index.css":u,"@app/prefix-router":x,"@app/suspense/index.tsx":`import ${t?"React,":""}{Suspense,lazy} from "${m}";import Fallback from '@app/fallback';${s?'import scope from "@app/mdx-scope";':""}function SuspenseComp(props) {const Lazy = lazy(props.comp);return (<Suspense fallback={Fallback && <Fallback />}><Lazy ${s?"components={scope}":""}/></Suspense>);}export default SuspenseComp;`,"@app/entry":c,"@app/merge-router":n},v={};if(s)try{let e=r(a("site"),"./mdx-scope.ts");p(e,o.R_OK),v='import scope from "@/mdx-scope";export default scope;'}catch(p){v={}}Object.assign(j,{"@app/mdx-scope":v});export default j;
@@ -1,2 +0,0 @@
1
- declare const appEntry: string;
2
- export default appEntry;
@@ -1 +0,0 @@
1
- import{existsSync as o}from"fs";import{join as p}from"path";import n from"./rem.js";import{CONFIG as t}from"../config.js";import{FRAMEWORK as r,isMicro as e,isMobile as i}from"../process-env.js";import{getExportTokens as m}from"../utils.js";let s=p(t.alias["@"],"./index.ts"),_=o(s),u="",a=`const renderApp = (await import('@moneko/${r}/lib/entry.js')).default;`,d=[];if(_){let o="";e&&(d=m(s).filter(Boolean)).length&&(o=`{${d.map(o=>`${o} as app${o}`).join(",")}} from `),u=`import ${o}"@/index.ts";`}u+=`import "@app/normalize/index.css";${n}`,e?(u+="if (window.__POWERED_BY_QIANKUN__) {__webpack_public_path__ = window.__INJECTED_PUBLIC_PATH_BY_QIANKUN__;}",a+=`if (!window.__POWERED_BY_QIANKUN__) {renderApp();}let unmountApp = void 0;export async function bootstrap() {console.log('app bootstraped');}export async function mount(props) {${d.includes("mount")?"appmount(props);":""}unmountApp = renderApp(props);}export async function unmount(props) {${d.includes("unmount")?"appunmount(props);":""}unmountApp();}`):a+="renderApp();",i&&(a+="window.H5RemoteRuntime = {bootstrap: renderApp};");let f=`${u}${a}`;export default f;
package/lib/vm/app.d.ts DELETED
@@ -1,22 +0,0 @@
1
- declare const app: {
2
- name: string;
3
- projectName: string;
4
- version: string;
5
- base: string;
6
- type: import("../index.js").AppType;
7
- routerMode: "browser" | "hash" | "memory";
8
- prefixCls: string | undefined;
9
- theme: import("../index.js").Theme | undefined;
10
- description: string | undefined;
11
- author: {
12
- name: string | undefined;
13
- email: string | undefined;
14
- url: string | undefined;
15
- };
16
- repository: {
17
- type: string | undefined;
18
- url: string | undefined;
19
- directory: string | undefined;
20
- };
21
- };
22
- export default app;
package/lib/vm/app.js DELETED
@@ -1 +0,0 @@
1
- import{readFileSync as e}from"fs";import{CONFIG as r}from"../config.js";import{APPTYPE as o,PACKAGENAME as p,PACKAGEVERSION as s}from"../process-env.js";import{resolveProgramPath as t,toUpperCaseString as a}from"../utils.js";let n={name:p,projectName:JSON.stringify(a(p).replace(/-/g," ")),version:s,base:r.basename,type:o,routerMode:r.routerMode,prefixCls:r.prefixCls,theme:r.theme,description:process.env.npm_package_description,author:{name:process.env.npm_package_author_name,email:process.env.npm_package_author_email,url:process.env.npm_package_author_url},repository:{type:process.env.npm_package_repository_type,url:process.env.npm_package_repository_url,directory:process.env.npm_package_repository_directory}};if(parseInt(process.versions.node)>14){let{description:r,author:o,repository:p}=JSON.parse(e(t("package.json"),{encoding:"utf-8"}));n.author="string"==typeof o?{name:o}:o,n.repository="string"==typeof o?{url:p}:p,n.description=r}export default n;
@@ -1,2 +0,0 @@
1
- declare let fallback: string;
2
- export default fallback;
@@ -1 +0,0 @@
1
- import{CONFIG as l}from"../config.js";let a="export default null";l.fallbackCompPath&&(a=`import Fallback from "${l.fallbackCompPath}";export default Fallback;`);export default a;
@@ -1 +0,0 @@
1
- export declare function scanfolder(folderPath: string, condition: (file: string) => boolean, list?: string[]): string[];
@@ -1 +0,0 @@
1
- import{readdirSync as r,statSync as o}from"fs";import{join as t}from"path";export function scanfolder(f,e,c=[]){return r(f).forEach(r=>{let i=t(f,r);o(i).isDirectory()?scanfolder(i,e,c):e(i)&&c.push(i)}),c}
@@ -1,2 +0,0 @@
1
- declare const _default: "function merge(e,r){if(!e.length)return void 0;const n=[];e.forEach(e=>{const t=n.findIndex(n=>n[r]==e[r]);if(t>-1){const i=[...n[t].children||[],...e.children||[]];n[t]=Object.assign(e,n[t],n[t].meta&&{meta:{...n[t].meta,...e.meta}});if(i.length){n[t].children=merge(i,r)}}else{n.push(Object.assign(e,Array.isArray(e.children)&&{children:merge(e.children,r)}))}});return n}export default merge;";
2
- export default _default;
@@ -1 +0,0 @@
1
- export default"function merge(e,r){if(!e.length)return void 0;const n=[];e.forEach(e=>{const t=n.findIndex(n=>n[r]==e[r]);if(t>-1){const i=[...n[t].children||[],...e.children||[]];n[t]=Object.assign(e,n[t],n[t].meta&&{meta:{...n[t].meta,...e.meta}});if(i.length){n[t].children=merge(i,r)}}else{n.push(Object.assign(e,Array.isArray(e.children)&&{children:merge(e.children,r)}))}});return n}export default merge;";
@@ -1,2 +0,0 @@
1
- declare let normalizeCss: string;
2
- export default normalizeCss;
@@ -1 +0,0 @@
1
- import{CONFIG as e}from"../config.js";let t="";e.normalizeCss&&(t='html,body{margin:0;padding:0;line-height:1.8}input,textarea{caret-color:inherit}h1{margin:0.67em 0;font-size:2em}hr{overflow:visible;block-size:0;box-sizing:content-box}pre{font-size:1em;font-family:monospace}a{text-decoration:none;background-color:transparent;cursor:pointer}abbr[title]{border-block-end:none;text-decoration:underline;text-decoration:underline dotted}b,strong{font-weight:bolder}code,kbd,samp{font-size:1em;font-family:monospace}small{font-size:80%}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sub{inset-block-end:-0.25em}sup{inset-block-start:-0.5em}img{border-style:none}img,button{outline:1px solid transparent}button,input,optgroup,select,textarea{margin:0;font-size:100%;font-family:inherit;line-height:1.15}button,input{overflow:visible}button,select{text-transform:none}button,[type="button"],[type="reset"],[type="submit"]{appearance:button}button::-moz-focus-inner,[type="button"]::-moz-focus-inner,[type="reset"]::-moz-focus-inner,[type="submit"]::-moz-focus-inner{border-style:none;padding:0}button:-moz-focusring,[type="button"]:-moz-focusring,[type="reset"]:-moz-focusring,[type="submit"]:-moz-focusring{outline:1px dotted var(--primary-outline)}fieldset{padding:0.35em 0.75em 0.625em}legend{display:table;padding:0;max-inline-size:100%;white-space:normal;color:inherit;box-sizing:border-box}progress{vertical-align:baseline}textarea{overflow:auto}details{display:block}summary{display:list-item}template,[hidden]{display:none}[type="checkbox"],[type="radio"]{box-sizing:border-box;padding:0}[type="number"]::-webkit-inner-spin-button,[type="number"]::-webkit-outer-spin-button{block-size:auto}[type="search"]{appearance:textfield;outline-offset:-2px}[type="search"]::-webkit-search-decoration{appearance:none}::-webkit-file-upload-button{appearance:button;font:inherit}::-webkit-scrollbar{inline-size:5px;block-size:5px}::-webkit-scrollbar-track,::-webkit-scrollbar-thumb{background-color:transparent}:hover::-webkit-scrollbar-thumb{background-color:var(--primary-selection)}::-webkit-scrollbar-thumb:hover{background-color:var(--primary-hover)}::-webkit-scrollbar-thumb:active{background-color:var(--primary-active)}::-webkit-scrollbar-button{display:none}');export default t;
@@ -1,2 +0,0 @@
1
- declare let prefixRouter: string;
2
- export default prefixRouter;
@@ -1 +0,0 @@
1
- import{isReact as e}from"../process-env.js";let t="";e&&(t='import { createElement, isValidElement } from "react";import { Outlet } from "react-router-dom";function prefix(e){return e.map(function(e){var n=Object.assign({key:e.path},e);return n.element?isValidElement(n.element)||(n.element=createElement(n.element,n.meta)):n.element=createElement(Outlet,null),Array.isArray(n.children)&&(n.children=prefix(n.children)),n})}export default prefix;');export default t;
package/lib/vm/rem.d.ts DELETED
@@ -1,2 +0,0 @@
1
- declare let rem: string;
2
- export default rem;
package/lib/vm/rem.js DELETED
@@ -1 +0,0 @@
1
- import{CONFIG as e}from"../config.js";let t="";e.rem.designSize&&(t=`!function(e,n){function t(){let n=e.documentElement,t=n.clientWidth||e.body.clientWidth,i=t<=375?375:${e.rem.designSize},o=t;o=t<=375?t:t<=${e.rem.designSize}?i:t;let d=16/i*o+"px";d!==n.style.fontSize&&(n.style.fontSize=d)}t(),"addEventListener"in e&&n.addEventListener("orientationchange"in n?"orientationchange":"resize",t,!1)}(document,window);`);export default t;