@moneko/core 3.26.1 → 3.26.3-beta.1

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 (142) hide show
  1. package/lib/bin/build-app.d.mts +16 -1
  2. package/lib/bin/build-app.mjs +1 -1
  3. package/lib/bin/build.d.mts +2 -1
  4. package/lib/bin/build.mjs +1 -1
  5. package/lib/bin/changelog.d.mts +1 -1
  6. package/lib/bin/changelog.mjs +3 -3
  7. package/lib/bin/eslint.d.mts +1 -1
  8. package/lib/bin/eslint.mjs +1 -1
  9. package/lib/bin/file.d.mts +0 -15
  10. package/lib/bin/file.mjs +1 -1
  11. package/lib/bin/git-hooks.d.mts +1 -1
  12. package/lib/bin/git-hooks.mjs +1 -1
  13. package/lib/bin/help.d.mts +2 -0
  14. package/lib/bin/help.mjs +36 -0
  15. package/lib/bin/index.d.mts +1 -8
  16. package/lib/bin/index.mjs +1 -1
  17. package/lib/bin/lessc.mjs +1 -1
  18. package/lib/bin/runlint.d.mts +1 -1
  19. package/lib/bin/runlint.mjs +2 -2
  20. package/lib/bin/start.d.mts +2 -1
  21. package/lib/bin/start.mjs +1 -1
  22. package/lib/bin/stylelint.d.mts +1 -1
  23. package/lib/bin/stylelint.mjs +1 -1
  24. package/lib/bin/utils/bundle-app.mjs +1 -1
  25. package/lib/bin/utils/config.d.mts +0 -1
  26. package/lib/bin/utils/config.mjs +1 -1
  27. package/lib/bin/utils/setup-swcrc.d.mts +1 -1
  28. package/lib/bin/utils/setup-swcrc.mjs +1 -1
  29. package/lib/build/server.mjs +1 -1
  30. package/lib/build.mjs +1 -1
  31. package/lib/{utils → commom}/has-pkg.mjs +1 -1
  32. package/lib/commom/net.mjs +1 -0
  33. package/lib/commom/os-tmp-dir.mjs +1 -0
  34. package/lib/commom/parse-module-meta.mjs +1 -0
  35. package/lib/{paths.d.mts → commom/paths.d.mts} +2 -4
  36. package/lib/commom/paths.mjs +1 -0
  37. package/lib/{utils → commom}/reactive-object.d.mts +1 -1
  38. package/lib/commom/reactive-object.mjs +1 -0
  39. package/lib/commom/require.mjs +1 -0
  40. package/lib/common.mjs +1 -1
  41. package/lib/config.mjs +1 -1
  42. package/lib/dev/config.mjs +3 -3
  43. package/lib/dev/json-schema.d.mts +3 -0
  44. package/lib/dev/json-schema.mjs +1 -0
  45. package/lib/dev/mock.mjs +1 -1
  46. package/lib/dev/proxy.d.mts +1 -1
  47. package/lib/dev.mjs +1 -1
  48. package/lib/index.d.mts +14 -14
  49. package/lib/index.mjs +1 -1
  50. package/lib/loader/css-in-js-minify.cjs +1 -1
  51. package/lib/loader/css-in-js-minify.d.cts +1 -0
  52. package/lib/loader/lightning-css/codegen.cjs +20 -0
  53. package/lib/loader/lightning-css/codegen.d.cts +35 -0
  54. package/lib/loader/lightning-css/loader.cjs +1 -0
  55. package/lib/loader/lightning-css/loader.d.cts +29 -0
  56. package/lib/loader/lightning-css/runtime/api.cjs +1 -0
  57. package/lib/loader/lightning-css/runtime/get-url.cjs +1 -0
  58. package/lib/loader/lightning-css/runtime/get-url.d.cts +1 -0
  59. package/lib/loader/lightning-css/utils.cjs +1 -0
  60. package/lib/loader/lightning-css/utils.d.cts +16 -0
  61. package/lib/loader/mdx.cjs +1 -1
  62. package/lib/loader/react-compiler.cjs +1 -1
  63. package/lib/loader/solid.d.cts +1 -1
  64. package/lib/loader/ts-doc.cjs +1 -1
  65. package/lib/loader/ts-doc.d.cts +1 -1
  66. package/lib/module.config.mjs +2 -1
  67. package/lib/options/css-extract.mjs +1 -1
  68. package/lib/options/html-plugin-option.mjs +1 -1
  69. package/lib/options/modify-vars.d.mts +1 -1
  70. package/lib/options/modify-vars.mjs +1 -1
  71. package/lib/options/reslove.d.mts +0 -1
  72. package/lib/options/reslove.mjs +1 -1
  73. package/lib/options/swcrc.mjs +1 -1
  74. package/lib/plugin/copy.mjs +1 -1
  75. package/lib/plugin/exposes-declararion.mjs +1 -1
  76. package/lib/plugin/lightningcss-plugin.mjs +1 -1
  77. package/lib/plugin/module-federation.mjs +1 -1
  78. package/lib/plugin/override-resolve.mjs +1 -1
  79. package/lib/plugin/virtual-module.mjs +1 -1
  80. package/lib/plugins.config.mjs +1 -1
  81. package/lib/polyfills/polyfills.mjs +1 -1
  82. package/lib/polyfills/targets.mjs +1 -1
  83. package/lib/process-env.d.mts +1 -1
  84. package/lib/process-env.mjs +1 -1
  85. package/lib/utils/create-types.mjs +1 -1
  86. package/lib/utils/dts.mjs +1 -1
  87. package/lib/utils/fetch-module-federation-dts.mjs +1 -1
  88. package/lib/utils/index.d.mts +1 -1
  89. package/lib/utils/index.mjs +1 -1
  90. package/lib/utils/run.mjs +1 -1
  91. package/lib/utils/seo.mjs +2 -2
  92. package/lib/utils/vts.mjs +1 -1
  93. package/lib/vm/coverage.mjs +1 -1
  94. package/lib/vm/docs.d.mts +1 -1
  95. package/lib/vm/docs.mjs +1 -1
  96. package/lib/vm/example.d.mts +1 -1
  97. package/lib/vm/example.mjs +1 -1
  98. package/lib/vm/generate-doc.mjs +1 -1
  99. package/lib/vm/info.mjs +1 -1
  100. package/lib/vm/locales.d.mts +1 -1
  101. package/lib/vm/locales.mjs +2 -2
  102. package/lib/vm/modules.mjs +1 -1
  103. package/lib/vm/routes.d.mts +1 -1
  104. package/lib/vm/routes.mjs +1 -1
  105. package/lib/vm/utils.mjs +1 -1
  106. package/package.json +3 -4
  107. package/typings/global.d.ts +21 -21
  108. package/lib/bin/version.mjs +0 -1
  109. package/lib/dev/net.mjs +0 -1
  110. package/lib/loader/lightningcss.cjs +0 -1
  111. package/lib/loader/lightningcss.d.cts +0 -7
  112. package/lib/paths.mjs +0 -1
  113. package/lib/utils/os-tmp-dir.mjs +0 -1
  114. package/lib/utils/parse-module-meta.mjs +0 -1
  115. package/lib/utils/print.d.mts +0 -2
  116. package/lib/utils/print.mjs +0 -2
  117. package/lib/utils/reactive-object.mjs +0 -1
  118. package/lib/utils/require.mjs +0 -1
  119. package/lib/utils/setup-env.d.mts +0 -6
  120. package/lib/utils/setup-env.mjs +0 -1
  121. /package/lib/{utils → commom}/diff-object.d.mts +0 -0
  122. /package/lib/{utils → commom}/diff-object.mjs +0 -0
  123. /package/lib/{utils → commom}/esm.d.mts +0 -0
  124. /package/lib/{utils → commom}/esm.mjs +0 -0
  125. /package/lib/{utils → commom}/get-current-time.d.mts +0 -0
  126. /package/lib/{utils → commom}/get-current-time.mjs +0 -0
  127. /package/lib/{utils → commom}/has-pkg.d.mts +0 -0
  128. /package/lib/{utils → commom}/log.d.mts +0 -0
  129. /package/lib/{utils → commom}/log.mjs +0 -0
  130. /package/lib/{utils → commom}/match-path.d.mts +0 -0
  131. /package/lib/{utils → commom}/match-path.mjs +0 -0
  132. /package/lib/{dev → commom}/net.d.mts +0 -0
  133. /package/lib/{utils → commom}/os-tmp-dir.d.mts +0 -0
  134. /package/lib/{utils → commom}/parse-module-meta.d.mts +0 -0
  135. /package/lib/{utils → commom}/require.d.mts +0 -0
  136. /package/lib/{rule.d.mts → commom/rule.d.mts} +0 -0
  137. /package/lib/{rule.mjs → commom/rule.mjs} +0 -0
  138. /package/lib/{bin/utils → commom}/setup-env.d.mts +0 -0
  139. /package/lib/{bin/utils → commom}/setup-env.mjs +0 -0
  140. /package/lib/{utils → commom}/sigint-exit.d.mts +0 -0
  141. /package/lib/{utils → commom}/sigint-exit.mjs +0 -0
  142. /package/lib/{bin/version.d.mts → loader/lightning-css/runtime/api.d.cts} +0 -0
@@ -1 +1,16 @@
1
- export {};
1
+ /**
2
+ * 拷贝文件
3
+ * @param {String} source 源文件
4
+ * @param {String} target 目标文件
5
+ * @constructor
6
+ * */
7
+ export declare function copyFileSync(source: string, target: string): void;
8
+ /**
9
+ * 拷贝文件夹
10
+ * @param {String} source 源文件夹
11
+ * @param {String} target 目标文件夹
12
+ * @param {String} sun 是否子文件夹
13
+ * @constructor
14
+ * */
15
+ export declare function copyFolderRecursiveSync(source: string, target: string, sun?: boolean): void;
16
+ export default function createApp(): Promise<void>;
@@ -1 +1 @@
1
- import{execSync as e}from"child_process";import i from"fs";import n from"path";import{program as r}from"commander";import{bundleApk as s,bundleIOS as o}from"./utils/bundle-app.mjs";import{__dirname as t,copyFolderRecursiveSync as a}from"./file.mjs";import{corePkg as l}from"./utils/config.mjs";import{cwd as d}from"./utils/config.mjs";import{createDir as p,loadFileSync as m,removeDir as c,saveFile as f,parseYaml as u,jsonToYaml as S,parsePlist as b,buildPlist as w,parseXml as y,buildXml as g,ink as j,print as _}from"@moneko/utils";let k=async(r,k)=>{k.args.forEach(e=>{let[i,n]=e.replace(/^--/,"").split("=");process.env[`__args__${i}__`]=n});let{CONFIG:h}=await import(`${l}/lib/config.mjs`),A=h.bundleId;if(!A)throw Error("请配置 bundleId");if(!/(^com\.)([a-zA-Z_][a-zA-Z0-9_]*[.])*([a-zA-Z_][a-zA-Z0-9_]*)$/.test(A)||3!==A.split(".").length)throw Error("软件包名不合法");let O=h.bundles;if(!O||0===O.length)throw Error("请配置 bundles (打包类型)");let E=A.split(".").splice(-1,1).join(""),N=n.join(d,"/dist"),$=`flutter create -t app --org ${A} -i swift -a kotlin ${E}`,T=n.join(d,"/"+E),V=n.join(T,"assets/web/");e($,{encoding:"utf-8"}),p(V),_(j("正在注册资产...","yellow"),!0),a(N,V);let I=n.join(T,"pubspec.yaml"),J=JSON.parse(await u(I)||"{}"),x=[],R=(e,n="assets/web")=>{let r=i.readdirSync(e);!function s(o){o!=r.length&&(i.statSync(e+"/"+r[o]).isDirectory()&&(x.push(n+"/"+r[o]+"/"),R(e+"/"+r[o],n+"/"+r[o])),s(o+1))}(0)};if(R(N),J.dependencies.webview_flutter_plus="^0.2.3",J.flutter.assets=["assets/web/",...x],f(I,await S(JSON.stringify(J))),_(j("注册资产","cyan")+": "+j("完成","cyan"),!0),O.includes("apk -release")||O.includes("apk -debug")){_(j("正在配置安卓权限...","yellow"),!0);let e=n.join(T,"android/app/src/main/AndroidManifest.xml"),i=JSON.parse(y(e));i.manifest.application.$["android:usesCleartextTraffic"]="true",i.manifest["uses-permission"]=[{$:{"android:name":"android.permission.INTERNET"}},{$:{"android:name":"android.permission.ACCESS_NETWORK_STATE"}},{$:{"android:name":"android.permission.WAKE_LOCK"}}],f(e,g(JSON.stringify(i)));let r=n.join(T,"android/app/build.gradle"),s=m(r)||"",o="minSdkVersion flutter.minSdkVersion";if(s?.includes(o))s=s.replace(o,"minSdkVersion 20");else{let e=s.indexOf("minSdkVersion "),i=s.substring(e,e+16);s=s.replace(i,"minSdkVersion 20")}let t="compileSdkVersion flutter.compileSdkVersion";s.includes(t)&&(s=s.replace(t,"compileSdkVersion 32")),f(r,s),_(j("安卓权限配置","cyan")+": "+j("完成","cyan"),!0)}if(O.includes("ios -release")||O.includes("ios -debug")){_(j("开始配置IOS权限","yellow"),!0);let e=n.join(T,"ios/Runner/Info.plist"),i=Object.assign(JSON.parse(await b(e)),{NSAppTransportSecurity:{NSAllowsArbitraryLoads:!0},"io.flutter.embedded_views_preview":!0});f(e,await w(JSON.stringify(i))),_(j("IOS权限配置","cyan")+": "+j("完成","cyan"),!0)}f(n.join(T,"lib/main.dart"),m(n.join(t,"./conf/bootstrap"))||"");let v=n.join(d,"./bundle/");p(v),setTimeout(()=>{O.forEach(e=>{let i=e.split(" ");"apk"===i[0]&&s(T,v,i[1]),"ios"===i[0]&&o(T,v,i[1])}),c(T),i.existsSync(n.join(v,"Runner"))&&c(n.join(v,"Runner")),_("✨ "+j("Done","green"),!0),process.exit(0)},1e3)};r.command("buildApp").description("编译将 h5 应用打包成移动客户端,使用 Flutter").action(k);
1
+ import{execSync as e}from"node:child_process";import{existsSync as i,readdirSync as n,statSync as o}from"node:fs";import s from"node:path";import{argv as r}from"node:process";import{buildPlist as t,buildXml as l,createDir as a,ink as c,jsonToYaml as d,loadFileSync as p,parsePlist as m,parseXml as u,parseYaml as f,print as y,println as S,removeDir as $,saveFile as b,saveFileSync as j}from"@moneko/utils";import{bundleApk as _,bundleIOS as g}from"./utils/bundle-app.mjs";import{corePkg as w,cwd as k}from"./utils/config.mjs";import{__dirname as O}from"./file.mjs";export function copyFileSync(e,i){let n=p(e);if(null!==n){let r=i;o(i).isDirectory()&&(r=s.join(i,s.basename(e))),j(r,n)}}export function copyFolderRecursiveSync(e,i,r){let t=i;r&&(t=s.join(i,s.basename(e))),o(e).isDirectory()&&n(e).forEach(function(i){let n=s.join(e,i);o(n).isDirectory()?copyFolderRecursiveSync(n,t,!0):copyFileSync(n,t)})}export default async function A(){r.slice(3).forEach(e=>{let[i,n]=e.replace(/^--/,"").split("=");process.env[`__args__${i}__`]=n});let{CONFIG:j}=await import(`${w}/lib/config.mjs`),A=j.bundleId;A||(S(c("请配置 bundleId","red")),process.exit(1)),/(^com\.)([a-zA-Z_][a-zA-Z0-9_]*[.])*([a-zA-Z_][a-zA-Z0-9_]*)$/.test(A)&&3===A.split(".").length||(S(c("软件包名不合法","red")),process.exit(1));let N=j.bundles;N&&0!==N.length||(S(c("请配置 bundles (打包类型)","red")),process.exit(1));let x=A.split(".").splice(-1,1).join(""),h=s.join(k,"/dist"),E=`flutter create -t app --org ${A} -i swift -a kotlin ${x}`,R=s.join(k,`/${x}`),T=s.join(R,"assets/web/");e(E,{encoding:"utf-8"}),a(T),y(c("正在注册资产...","yellow"),!0),copyFolderRecursiveSync(h,T);let V=s.join(R,"pubspec.yaml"),v=JSON.parse(await f(V)||"{}"),I=[],J=(e,i="assets/web")=>{let s=n(e);!function n(r){r!=s.length&&(o(`${e}/${s[r]}`).isDirectory()&&(I.push(`${i}/${s[r]}/`),J(`${e}/${s[r]}`,`${i}/${s[r]}`)),n(r+1))}(0)};if(J(h),v.dependencies.webview_flutter_plus="^0.2.3",v.flutter.assets=["assets/web/",...I],b(V,await d(JSON.stringify(v))),y(`${c("注册资产","cyan")}: ${c("完成","cyan")}`,!0),N.includes("apk -release")||N.includes("apk -debug")){y(c("正在配置安卓权限...","yellow"),!0);let e=s.join(R,"android/app/src/main/AndroidManifest.xml"),i=JSON.parse(u(e));i.manifest.application.$["android:usesCleartextTraffic"]="true",i.manifest["uses-permission"]=[{$:{"android:name":"android.permission.INTERNET"}},{$:{"android:name":"android.permission.ACCESS_NETWORK_STATE"}},{$:{"android:name":"android.permission.WAKE_LOCK"}}],b(e,l(JSON.stringify(i)));let n=s.join(R,"android/app/build.gradle"),o=p(n)||"",r="minSdkVersion flutter.minSdkVersion";if(o?.includes(r))o=o.replace(r,"minSdkVersion 20");else{let e=o.indexOf("minSdkVersion "),i=o.substring(e,e+16);o=o.replace(i,"minSdkVersion 20")}let t="compileSdkVersion flutter.compileSdkVersion";o.includes(t)&&(o=o.replace(t,"compileSdkVersion 32")),b(n,o),y(`${c("安卓权限配置","cyan")}: ${c("完成","cyan")}`,!0)}if(N.includes("ios -release")||N.includes("ios -debug")){y(c("开始配置IOS权限","yellow"),!0);let e=s.join(R,"ios/Runner/Info.plist"),i=Object.assign(JSON.parse(await m(e)),{NSAppTransportSecurity:{NSAllowsArbitraryLoads:!0},"io.flutter.embedded_views_preview":!0});b(e,await t(JSON.stringify(i))),y(`${c("IOS权限配置","cyan")}: ${c("完成","cyan")}`,!0)}b(s.join(R,"lib/main.dart"),p(s.join(O,"./conf/bootstrap"))||"");let D=s.join(k,"./bundle/");a(D),setTimeout(()=>{N.forEach(e=>{let i=e.split(" ");"apk"===i[0]&&_(R,D,i[1]),"ios"===i[0]&&g(R,D,i[1])}),$(R),i(s.join(D,"Runner"))&&$(s.join(D,"Runner")),y(`✨ ${c("Done","green")}`,!0),process.exit(0)},1e3)}
@@ -1 +1,2 @@
1
- export {};
1
+ declare function build(): Promise<void>;
2
+ export default build;
package/lib/bin/build.mjs CHANGED
@@ -1 +1 @@
1
- import{spawn as e}from"child_process";import{join as o,relative as s}from"path";import{program as t}from"commander";import i from"./utils/setup-env.mjs";import{lesscCommonjs as r}from"./lessc.mjs";import{corePkg as n,cwd as m,swcCachePath as l,runtimePath as c}from"./utils/config.mjs";import p from"./utils/setup-swcrc.mjs";import d from"../utils/require.mjs";import{__dirname as f}from"./file.mjs";import{deleteEmptyDirs as a,updateFileSync as u,removeDir as j,ink as $,println as y,scanFolderSync as g,removeFile as _}from"@moneko/utils";let b={stdio:"inherit",shell:!0};t.command("build <type> <framework>").description("编译项目").action(async(t,h,...x)=>{t||(y($(`type: 无效值 ${$(t,"245")}`,"red")),process.exit(1));let v=x[1].args.slice(2),C=!v.includes("no-docs"),w=!v.includes("no-lib"),E=!v.includes("no-es"),k=v.filter(e=>!["no-docs","no-es","no-lib"].includes(e));await i("production",t,h,k);let D=`${c} ${d.resolve(`${n}/lib/build.mjs`)}`;if("library"===t){let t=p(h),i=d.resolve("typescript/bin/tsc"),n=d.resolve("@swc/cli/bin/swc.js"),$=[w&&{type:"commonjs",dir:"lib",msg:"Convert to CommonJS"},E&&{type:"es6 -C jsc.target=es2015",dir:"es",msg:"Convert to ES Module"}].filter(Boolean),y=o(f,".types.json");$.length&&u(y,JSON.stringify({extends:s(f,o(m,"tsconfig.json")),include:[s(f,o(m,"components")),s(f,o(m,"typings"))],exclude:[s(f,o(m,"components/**/examples/*")),s(f,o(m,"components/**/__tests__/*")),s(f,o(m,"components/**/__mocks__/*"))]}));for(let s=0,p=$.length;s<p;s++){let p=o(m,`./${$[s].dir}`);j(p),e(`${c} ${n} components -d ${$[s].dir} -q --strip-leading-paths --config-file ${t} -C jsc.experimental.cacheRoot=${l} -C module.type=${$[s].type} -D --ignore "**/*.test.(js|ts)x?$"`,b).on("close",function(e){0===e&&(g(p,["README.mdx","examples","__*__"]).forEach(_),a(p),"commonjs"===$[s].type&&r())}),e(`${c} ${i} --project ${y} --outDir ${$[s].dir}`,b)}}("library"!==t||C&&"library"===t)&&e(D,b)});
1
+ import{spawn as o}from"node:child_process";import{join as e,relative as s}from"node:path";import{argv as t}from"node:process";import{deleteEmptyDirs as i,ink as r,println as n,removeDir as m,removeFile as l,scanFolderSync as c,updateFileSync as p}from"@moneko/utils";import d from"../commom/require.mjs";import f from"../commom/setup-env.mjs";import{corePkg as u,cwd as a,runtimePath as j,swcCachePath as $}from"./utils/config.mjs";import y from"./utils/setup-swcrc.mjs";import{__dirname as _}from"./file.mjs";import{lesscCommonjs as g}from"./lessc.mjs";let b={stdio:"inherit",shell:!0};async function h(){let h=t[3],x=t[4],v=t.slice(5);h||(n(r(`type: 无效值 ${r(h,"245")}`,"red")),process.exit(1));let C=!v.includes("no-docs"),w=!v.includes("no-lib"),E=!v.includes("no-es"),D=v.filter(o=>!["no-docs","no-es","no-lib"].includes(o));await f("production",h,x,D);let S=`${j} ${d.resolve(`${u}/lib/build.mjs`)}`;if("library"===h){let t=y(x),r=d.resolve("typescript/bin/tsc"),n=d.resolve("@swc/cli/bin/swc.js"),f=[w&&{type:"commonjs",dir:"lib",msg:"Convert to CommonJS"},E&&{type:"es6 -C jsc.target=es2015",dir:"es",msg:"Convert to ES Module"}].filter(Boolean),u=e(_,".types.json");f.length&&p(u,JSON.stringify({extends:s(_,e(a,"tsconfig.json")),include:[s(_,e(a,"components")),s(_,e(a,"typings"))],exclude:[s(_,e(a,"components/**/examples/*")),s(_,e(a,"components/**/__tests__/*")),s(_,e(a,"components/**/__mocks__/*"))]}));for(let s=0,p=f.length;s<p;s++){let p=e(a,`./${f[s].dir}`);m(p),o(`${j} ${n} components -d ${f[s].dir} -q --strip-leading-paths --config-file ${t} -C jsc.experimental.cacheRoot=${$} -C module.type=${f[s].type} -D --ignore "**/*.test.(js|ts)x?$"`,b).on("close",function(o){0===o&&(c(p,["README.mdx","examples","__*__"]).forEach(l),i(p),"commonjs"===f[s].type&&g())}),o(`${j} ${r} --project ${u} --outDir ${f[s].dir}`,b)}}("library"!==h||C&&"library"===h)&&o(S,b)}export default h;
@@ -1 +1 @@
1
- export {};
1
+ export default function changelog(): void;
@@ -1,4 +1,4 @@
1
- import{execSync as t}from"child_process";import{join as e}from"path";import{program as o}from"commander";import{cwd as r}from"./utils/config.mjs";import{updateFileSync as s}from"@moneko/utils";let i={feat:"✨ Features",fix:"🐛 Bug Fixes",docs:"📚 Documentation",style:"💎 Styles",refactor:"📦 Code Refactoring",perf:"🚀 Performance Improvements",test:"🚨 Tests",build:"🛠 Builds",ci:"⚙️ Continuous Integrations",chore:"♻️ Chores",revert:"🗑 Reverts"};function n(e,o){return function(t){let e=[];for(let o of t.trim().split("\n")){let[t,r,s,n,a]=o.split("|");if(a){let o=a.split(": "),l=i[o[0]];e.push({commitId:t,author:r,email:s,date:new Date(n).toLocaleString().replace(/\//g,"-"),message:l?o.slice(1).join(":"):a,type:l})}}return e}(t(`git log ${e?`${e}..`:""}${o||""} --format='%H|%an|%ae|%ad|%s'`,{encoding:"utf-8"}))}o.command("changelog <filename>").description("生成 CHANGELOG.md").action(o=>{let i=["# Change log"];try{t('git show-ref --quiet --verify "refs/heads/$(git rev-parse --abbrev-ref HEAD)";');let e=t('git config --get remote.origin.url | sed "s/\\.git$//"').toString().trim(),o=function(e){let o=t("git for-each-ref --sort='v:refname' --format '%(objectname) %(refname:short) %(creatordate:iso8601)' refs/tags",{encoding:"utf-8"}),r=[],s=o.trim().split("\n");return s.forEach((t,o)=>{let[i,n,a]=t.split(" "),l=s[o-1]?.split(" ")[1],c=`## ${n}`;l&&(c=`## [${n}](${e}/compare/${l}...${n}) (${new Date(a).toLocaleDateString().replace(/\//g,"-")})`),r.push({commitId:i,tag:n,date:a,title:c,logs:{}})}),r}(e);o.forEach((t,r)=>{if(r&&n(o[r-1].tag,t.tag).forEach(t=>{if(t.type){let s=o[r].logs[t.type]||[];s.push(`- ${t.message} ([${t.commitId.substring(0,7)}](${e}/commit/${t.commitId}))`),Object.assign(o[r].logs,{[t.type]:s})}}),r===o.length-1){let s=n(t.tag);s.length&&o.push({title:"## Last",logs:{}}),s.forEach(t=>{if(t.type){let s=o[r+1].logs[t.type]||[];s.push(`- ${t.message} ([${t.commitId.substring(0,7)}](${e}/commit/${t.commitId}))`),Object.assign(o[r+1].logs,{[t.type]:s})}})}}),o.reverse().forEach(t=>{for(let e in i.push(`
2
- ${t.title}`),t.logs)Object.prototype.hasOwnProperty.call(t.logs,e)&&(i.push(`
1
+ import{execSync as t}from"node:child_process";import{join as e}from"node:path";import{argv as o}from"node:process";import{updateFileSync as r}from"@moneko/utils";import s from"../commom/log.mjs";import{cwd as i}from"./utils/config.mjs";let n={feat:"✨ Features",fix:"🐛 Bug Fixes",docs:"📚 Documentation",style:"💎 Styles",refactor:"📦 Code Refactoring",perf:"🚀 Performance Improvements",test:"🚨 Tests",build:"🛠 Builds",ci:"⚙️ Continuous Integrations",chore:"♻️ Chores",revert:"🗑 Reverts"};function a(e,o){return function(t){let e=[];for(let o of t.trim().split("\n")){let[t,r,s,i,a]=o.split("|");if(a){let o=a.split(": "),l=n[o[0]];e.push({commitId:t,author:r,email:s,date:new Date(i).toLocaleString().replace(/\//g,"-"),message:l?o.slice(1).join(":"):a,type:l})}}return e}(t(`git log ${e?`${e}..`:""}${o||""} --format='%H|%an|%ae|%ad|%s'`,{encoding:"utf-8"}))}export default function l(){let n=o[3],l=["# Change log"];try{t('git show-ref --quiet --verify "refs/heads/$(git rev-parse --abbrev-ref HEAD)";');let e=t('git config --get remote.origin.url | sed "s/\\.git$//"').toString().trim(),o=function(e){let o=t("git for-each-ref --sort='v:refname' --format '%(objectname) %(refname:short) %(creatordate:iso8601)' refs/tags",{encoding:"utf-8"}),r=[],s=o.trim().split("\n");return s.forEach((t,o)=>{let[i,n,a]=t.split(" "),l=s[o-1]?.split(" ")[1],m=`## ${n}`;l&&(m=`## [${n}](${e}/compare/${l}...${n}) (${new Date(a).toLocaleDateString().replace(/\//g,"-")})`),r.push({commitId:i,tag:n,date:a,title:m,logs:{}})}),r}(e);o.forEach((t,r)=>{if(r&&a(o[r-1].tag,t.tag).forEach(t=>{if(t.type){let s=o[r].logs[t.type]||[];s.push(`- ${t.message} ([${t.commitId.substring(0,7)}](${e}/commit/${t.commitId}))`),Object.assign(o[r].logs,{[t.type]:s})}}),r===o.length-1){let s=a(t.tag);s.length&&o.push({title:"## Last",logs:{}}),s.forEach(t=>{if(t.type){let s=o[r+1].logs[t.type]||[];s.push(`- ${t.message} ([${t.commitId.substring(0,7)}](${e}/commit/${t.commitId}))`),Object.assign(o[r+1].logs,{[t.type]:s})}})}}),o.reverse().forEach(t=>{for(let e in l.push(`
2
+ ${t.title}`),t.logs)Object.prototype.hasOwnProperty.call(t.logs,e)&&(l.push(`
3
3
  ### ${e}
4
- `),t.logs[e].forEach(t=>i.push(t)))})}catch{i.push("\n当前分支尚无任何提交\n")}s(e(r,o),i.join("\n"))});
4
+ `),t.logs[e].forEach(t=>l.push(t)))})}catch(t){l.push("\n当前分支尚无任何提交\n"),s(t)}r(e(i,n),l.join("\n"))}
@@ -1 +1 @@
1
- export {};
1
+ export default function eslint(): void;
@@ -1 +1 @@
1
- import{join as o,relative as i}from"path";import{program as t}from"commander";import{runLint as n}from"./runlint.mjs";import{cachePath as r,cwd as e,runtimePath as m}from"./utils/config.mjs";import s from"../utils/require.mjs";t.command("eslint <soucre>").option("-o, --output-file").option("-f, --format").option("--color, --no-color").option("--fix").option("--fix-dry-run").option("--ext").description("js代码规范检查").action((t,c,l)=>{let p=o(s.resolve("eslint"),"../../bin/eslint.js");n(`${m} ${p} ${i(e,t)} --config ${i(e,"eslint.config.mjs")} ${l.parent.args.slice(2).join(" ")} --cache --cache-location "${r}/.eslintcache"`,"eslint")});
1
+ import{join as o,relative as i}from"node:path";import{argv as e}from"node:process";import t from"../commom/require.mjs";import{cachePath as m,cwd as n,runtimePath as r}from"./utils/config.mjs";import{runLint as s}from"./runlint.mjs";export default function c(){let c=e[3],l=e.slice(4),f=o(t.resolve("eslint"),"../../bin/eslint.js");s(`${r} ${f} ${i(n,c)} --config ${i(n,"eslint.config.mjs")} ${l.join(" ")} --cache --cache-location "${m}/.eslintcache"`,"eslint")}
@@ -1,17 +1,2 @@
1
1
  export declare const __filename: string;
2
2
  export declare const __dirname: string;
3
- /**
4
- * 拷贝文件
5
- * @param {String} source 源文件
6
- * @param {String} target 目标文件
7
- * @constructor
8
- * */
9
- export declare function copyFileSync(source: string, target: string): void;
10
- /**
11
- * 拷贝文件夹
12
- * @param {String} source 源文件夹
13
- * @param {String} target 目标文件夹
14
- * @param {String} sun 是否子文件夹
15
- * @constructor
16
- * */
17
- export declare function copyFolderRecursiveSync(source: string, target: string, sun?: boolean): void;
package/lib/bin/file.mjs CHANGED
@@ -1 +1 @@
1
- import{loadFileSync as o,saveFileSync as e}from"@moneko/utils";import{statSync as i,readdirSync as r}from"fs";import t from"path";import n from"url";export const __filename=n.fileURLToPath(import.meta.url);export const __dirname=t.dirname(__filename);export function copyFileSync(r,n){let c=o(r);if(null!==c){let o=n;i(n).isDirectory()&&(o=t.join(n,t.basename(r))),e(o,c)}}export function copyFolderRecursiveSync(o,e,n){let c=e;n&&(c=t.join(e,t.basename(o))),i(o).isDirectory()&&r(o).forEach(function(e){let r=t.join(o,e);i(r).isDirectory()?copyFolderRecursiveSync(r,c,!0):copyFileSync(r,c)})}
1
+ import e from"node:path";import o from"node:url";export const __filename=o.fileURLToPath(import.meta.url);export const __dirname=e.dirname(__filename);
@@ -1 +1 @@
1
- export {};
1
+ export default function githooks(): void;
@@ -1 +1 @@
1
- import{program as o}from"commander";import{runLint as i}from"./runlint.mjs";o.command("githooks").description("git hooks工具").action((o,t)=>{let m="node_modules/.husky",n=t.args.map(o=>{let i=o.split("=");return`echo "${i[1]}" > ${m}/${i[0]}`}).join(" && ");i(`git init && husky ${m} && ${n}`,"githooks",[null])});
1
+ import{argv as o}from"node:process";import{runLint as t}from"./runlint.mjs";export default function e(){let e="node_modules/.husky",i=o.slice(3).map(o=>{let t=o.split("=");return`echo "${t[1]}" > ${e}/${t[0]}`}).join(" && ");t(`git init && husky ${e} && ${i}`,"githooks",[null])}
@@ -0,0 +1,2 @@
1
+ declare function printHelp(): void;
2
+ export default printHelp;
@@ -0,0 +1,36 @@
1
+ import{ink as e,println as $}from"@moneko/utils";export default function(){let l="react | solid | vue",r="backstage | library | site | micro | mobile";$(`
2
+ ${e("使用方法:","white")} ${e("mo","blue")} ${e("<命令>","green")} ${e("<必选参数>","208")} ${e("[可选参数]","yellow")}
3
+
4
+ ${e("命令列表:","white")}
5
+ ${e("start","green")} ${e("<type> <framework>","208")} 启动开发服务器
6
+ ${e("type: ","245",{bold:!0})}${e(r,"245",{italic:!0})}
7
+ ${e("framework: ","245",{bold:!0})}${e(l,"245",{italic:!0})}
8
+
9
+ ${e("build","green")} ${e("<type> <framework>","208")} 构建生产环境应用
10
+ ${e("type: ","245",{bold:!0})}${e(r,"245")}
11
+ ${e("framework: ","245",{bold:!0})}${e(l,"245",{italic:!0})}
12
+
13
+ ${e("eslint","green")} ${e("<source_path>","208")} 执行代码规范检查
14
+ ${e("source_path: ","245",{bold:!0})}${e("要检查的文件或目录路径","245",{italic:!0})}
15
+
16
+ ${e("stylelint","green")} ${e("<source_path>","208")} 执行样式规范检查
17
+ ${e("source_path: ","245",{bold:!0})}${e("要检查的文件或目录路径","245",{italic:!0})}
18
+
19
+ ${e("githooks","green")} 配置 Git 钩子以自动化工作流
20
+
21
+ ${e("buildApp","green")} 创建新的应用程序脚手架
22
+
23
+ ${e("changelog","green")} ${e("<filename>","208")} 生成项目变更日志
24
+ ${e("filename: ","245",{bold:!0})}${e("输出的文件名","245",{italic:!0})}
25
+
26
+ ${e("选项:","white")}
27
+ ${e("-v, --version","yellow")} 显示版本信息
28
+ ${e("-h, --help","yellow")} 显示帮助信息
29
+
30
+ ${e("示例:","white")}
31
+ ${e("mo","blue")} ${e("start","green")} ${e("library react","208")} ${e("# 启动开发服务器","245")}
32
+ ${e("mo","blue")} ${e("build","green")} ${e("library react","208")} ${e("# 构建生产版本","245")}
33
+ ${e("mo","blue")} ${e("eslint","green")} ${e("components","208")} ${e("# 检查并修复代码","245")}
34
+ ${e("mo","blue")} ${e("stylelint","green")} ${e("src","208")} ${e("# 检查样式文件","245")}
35
+ ${e("mo","blue")} ${e("changelog","green")} ${e("CHANGELOG.md","208")} ${e("# 生成变更日志","245")}
36
+ `)}
@@ -1,9 +1,2 @@
1
1
  #!/usr/bin/env node
2
- import './version.mjs';
3
- import './eslint.mjs';
4
- import './stylelint.mjs';
5
- import './build.mjs';
6
- import './start.mjs';
7
- import './build-app.mjs';
8
- import './git-hooks.mjs';
9
- import './changelog.mjs';
2
+ export {};
package/lib/bin/index.mjs CHANGED
@@ -1,2 +1,2 @@
1
1
  #!/usr/bin/env node
2
- import{program as i}from"commander";import"./version.mjs";import"./eslint.mjs";import"./stylelint.mjs";import"./build.mjs";import"./start.mjs";import"./build-app.mjs";import"./git-hooks.mjs";import"./changelog.mjs";i.option("-ig,--initgit","init git"),i.parse(process.argv),["SIGINT","SIGTERM","SIGQUIT"].forEach(i=>process.on(i,()=>{process.exit(0)}));
2
+ import{argv as a}from"node:process";import{ink as t,println as e}from"@moneko/utils";import i from"../commom/require.mjs";import s from"../commom/sigint-exit.mjs";import{corePkg as o}from"./utils/config.mjs";switch(a[2]){case"-v":case"--version":e(`${t(o,"blue")}: ${i(`${o}/package.json`).version}`,!0);break;case"start":(await import("./start.mjs")).default();break;case"build":(await import("./build.mjs")).default();break;case"eslint":(await import("./eslint.mjs")).default();break;case"stylelint":(await import("./stylelint.mjs")).default();break;case"githooks":(await import("./git-hooks.mjs")).default();break;case"buildApp":(await import("./build-app.mjs")).default();break;case"changelog":(await import("./changelog.mjs")).default();break;default:(await import("./help.mjs")).default()}s(()=>{process.exit(0)});
package/lib/bin/lessc.mjs CHANGED
@@ -1 +1 @@
1
- import{join as s}from"path";import{exec as e}from"child_process";import{runtimePath as o,corePkg as t}from"./utils/config.mjs";import i from"../utils/require.mjs";import{loadFile as l,saveFile as r,scanFolderSync as m}from"@moneko/utils";let n="";function a(t){let l=s(i.resolve("less"),"../bin/lessc");return new Promise((s,i)=>{e(`${o} ${l} --js ${n} ${t} > ${t.replace(/\.less$/g,".css")}`,function(e){if(e)return i(e);s(!0)})})}let c=/\*?\.less/g;async function f(s){let e=await l(s);e&&c.test(e)&&await r(s,e.replace(c,".css"))}export async function lesscCommonjs(){let s=m("lib",["\\.less$"]),e=(await import(i.resolve(`${t}/lib/options/modify-vars.mjs`))).default;for(let s in e)Object.hasOwnProperty.call(e,s)&&(n+=`--modify-var="${s}=${e[s]}" `);Promise.all(s.map(a)),s.length&&Promise.all(m("lib",["\\.js$"]).map(f))}
1
+ import{exec as e}from"node:child_process";import{join as o}from"node:path";import{loadFile as s,saveFile as t,scanFolderSync as i}from"@moneko/utils";import r from"../commom/require.mjs";import{corePkg as l,runtimePath as m}from"./utils/config.mjs";let n="";function a(s){let t=o(r.resolve("less"),"../bin/lessc");return new Promise((o,i)=>{e(`${m} ${t} --js ${n} ${s} > ${s.replace(/\.less$/g,".css")}`,function(e){if(e)return i(e);o(!0)})})}let c=/\*?\.less/g;async function f(e){let o=await s(e);o&&c.test(o)&&await t(e,o.replace(c,".css"))}export async function lesscCommonjs(){let e=i("lib",["\\.less$"]),o=(await import(`${l}/lib/options/modify-vars.mjs`)).default;for(let e in o)Object.hasOwnProperty.call(o,e)&&(n+=`--modify-var="${e}=${o[e]}" `);Promise.all(e.map(a)),e.length&&Promise.all(i("lib",["\\.js$"]).map(f))}
@@ -1,2 +1,2 @@
1
- import { StdioOptions } from 'child_process';
1
+ import { StdioOptions } from 'node:child_process';
2
2
  export declare const runLint: (shellSrc: string, pluginName: string, stdio?: StdioOptions) => never;
@@ -1,2 +1,2 @@
1
- import{ink as t,print as s}from"@moneko/utils";import{spawnSync as e}from"child_process";export const runLint=(r,o,i="inherit")=>{let l=t(o,"cyan");s(l+": "+t("Runing...","yellow"),!0);let n=e(r,{stdio:i,shell:!0});s(l+": "+t(`✨ ${0!==n.status?"Error":"Successfully"}!
2
- `,0!==n.status?"red":"green"),!0),process.exit(n.status||0)};
1
+ import{spawnSync as t}from"node:child_process";import{ink as s,print as e}from"@moneko/utils";export const runLint=(o,r,i="inherit")=>{let l=s(r,"cyan");e(`${l}: ${s("Runing...","yellow")}`,!0);let n=t(o,{stdio:i,shell:!0}),u=s(`✨ ${0!==n.status?"Error":"Successfully"}!
2
+ `,0!==n.status?"red":"green");e(`${l}: ${u}`,!0),process.exit(n.status||0)};
@@ -1 +1,2 @@
1
- export {};
1
+ declare function start(): Promise<void>;
2
+ export default start;
package/lib/bin/start.mjs CHANGED
@@ -1 +1 @@
1
- import{spawn as e}from"child_process";import{program as i}from"commander";import{ink as o,println as r}from"@moneko/utils";import{corePkg as m,runtimePath as t}from"./utils/config.mjs";import s from"./utils/setup-env.mjs";import p from"../utils/require.mjs";i.command("start <type> <framework>").description("运行项目").action(async(i,l,...n)=>{i||(r(o("type: 无效值 "+o(i,"245"),"red")),process.exit(1));let c=n[1].args.slice(2),f=c.indexOf("no-verify");-1!==f&&c.splice(f,1),await s("development",i,l,c),e(`${t} ${p.resolve(`${m}/lib/dev.mjs`)}`,{stdio:"inherit",shell:!0})});
1
+ import{spawn as o}from"node:child_process";import{argv as e}from"node:process";import{ink as m,println as i}from"@moneko/utils";import r from"../commom/require.mjs";import t from"../commom/setup-env.mjs";import{corePkg as s,runtimePath as p}from"./utils/config.mjs";async function l(){let l=e[3],n=e[4],c=e.slice(5);l||(i(m(`type: 无效值 ${m(l,"245")}`,"red")),process.exit(1));let f=c.indexOf("no-verify");-1!==f&&c.splice(f,1),await t("development",l,n,c),o(`${p} ${r.resolve(`${s}/lib/dev.mjs`)}`,{stdio:"inherit",shell:!0})}export default l;
@@ -1 +1 @@
1
- export {};
1
+ export default function stylelint(): void;
@@ -1 +1 @@
1
- import{relative as o,join as t}from"path";import{program as i}from"commander";import{cachePath as s,cwd as e,runtimePath as n}from"./utils/config.mjs";import{runLint as r}from"./runlint.mjs";import l from"../utils/require.mjs";i.command("stylelint <soucre>").option("-o, --output-file").option("-f, --format").option("--color, --no-color").option("--fix").option("--fix-dry-run").option("--ext").description("css代码规范检查").action((i,c,m)=>{let p=t(l.resolve("stylelint"),"../../bin/stylelint.mjs");r(`${n} ${p} ${o(e,i)}/**/**/**/**/*.{less,css,scss,sass,style.ts,style.js} ${m.parent.args.slice(2).join(" ")} --cache --cache-location "${s}/.stylelintcache" --aei`,"stylelint")});
1
+ import{join as s,relative as t}from"node:path";import{argv as e}from"node:process";import o from"../commom/require.mjs";import{cachePath as i,cwd as l,runtimePath as m}from"./utils/config.mjs";import{runLint as r}from"./runlint.mjs";export default function c(){let c=e[3],n=e.slice(4),a=s(o.resolve("stylelint"),"../../bin/stylelint.mjs");r(`${m} ${a} ${t(l,c)}/**/**/**/**/*.{less,css,scss,sass,style.ts,style.js} ${n.join(" ")} --cache --cache-location "${i}/.stylelintcache" --aei`,"stylelint")}
@@ -1 +1 @@
1
- import o from"path";import{renameSync as e}from"fs";import{execSync as n}from"child_process";import{bundleIpa as i,createDir as p,ink as l,print as t}from"@moneko/utils";export function bundleApk(i,a,u="-release"){t(l("正在编译 apk...","yellow"),!0),console.time("bundle apk "+u),n(`flutter build apk -${u}`),console.timeEnd("bundle apk "+u),p(a),e(o.join(i,`build/app/outputs/flutter-apk/app${u}.apk`),a),t("✨ "+l("Apk 编译","cyan")+": "+l("完成","cyan"),!0)}export function bundleIOS(a,u,r="-release"){t(l("正在编译 ipa...","yellow"),!0),console.time("bundle ipa "+r);let d=o.join(u,"Runner/Payload");n(`flutter build ios -${r} --no-codesign`),p(d),e(o.join(a,"build/ios/iphoneos/Runner.app"),d),i(o.join(u,"Runner"),u,r),console.timeEnd("bundle ipa "+r),t("✨ "+l("ipa 编译","cyan")+": "+l("完成","cyan"),!0)}
1
+ import{execSync as e}from"node:child_process";import{renameSync as o}from"node:fs";import{join as n}from"node:path";import{bundleIpa as p,createDir as l,ink as i,print as t}from"@moneko/utils";export function bundleApk(p,a,u="-release"){t(i("正在编译 apk...","yellow"),!0),console.time(`bundle apk ${u}`),e(`flutter build apk -${u}`),console.timeEnd(`bundle apk ${u}`),l(a),o(n(p,`build/app/outputs/flutter-apk/app${u}.apk`),a),t(`✨ ${i("Apk 编译","cyan")}: ${i("完成","cyan")}`,!0)}export function bundleIOS(a,u,r="-release"){t(i("正在编译 ipa...","yellow"),!0),console.time(`bundle ipa ${r}`);let d=n(u,"Runner/Payload");e(`flutter build ios -${r} --no-codesign`),l(d),o(n(a,"build/ios/iphoneos/Runner.app"),d),p(n(u,"Runner"),u,r),console.timeEnd(`bundle ipa ${r}`),t(`✨ ${i("ipa 编译","cyan")}: ${i("完成","cyan")}`,!0)}
@@ -1,6 +1,5 @@
1
1
  export declare const runtimePath: string;
2
2
  export declare const corePkg = "@moneko/core";
3
- export declare const coreVersion: any;
4
3
  export declare const cwd: string;
5
4
  export declare const cachePath: string;
6
5
  export declare const swcCachePath: string;
@@ -1 +1 @@
1
- import{join as e,dirname as o}from"path";import c from"../../utils/require.mjs";let t=o(process.execPath);"win32"===process.platform&&t.includes(" ")&&(t=`"${t}"`);export const runtimePath=e(t,"undefined"!=typeof Deno?"deno":"undefined"!=typeof Bun?"bun":"node");export const corePkg="@moneko/core";export const coreVersion=c("@moneko/core/package.json").version;export const cwd=process.cwd();export const cachePath=e(cwd,"node_modules/.cache");export const swcCachePath=e(cachePath,".swc");
1
+ import{dirname as e,join as o}from"node:path";let c="undefined"!=typeof Deno?"deno":"undefined"!=typeof Bun?"bun":"node",t=e(process.execPath);"win32"===process.platform&&t.includes(" ")&&(t=`"${t}"`);export const runtimePath=o(t,c);export const corePkg="@moneko/core";export const cwd=process.cwd();export const cachePath=o(cwd,"node_modules/.cache");export const swcCachePath=o(cachePath,".swc");
@@ -1,2 +1,2 @@
1
- declare function setupSwcRc(framework: 'react' | 'solid'): string;
1
+ declare function setupSwcRc(framework: string): string;
2
2
  export default setupSwcRc;
@@ -1 +1 @@
1
- import{join as e}from"path";import{__dirname as o}from"../file.mjs";import r from"../../utils/require.mjs";import{updateFileSync as s}from"@moneko/utils";let m=e(o,".swcrc");export default function(e){let o="solid"===e;return s(m,JSON.stringify({$schema:"https://json.schemastore.org/swcrc",module:{type:"es6"},minify:!0,jsc:{minify:{mangle:!0,compress:!0,format:{comments:"some"}},parser:{syntax:"typescript",decorators:!0,dynamicImport:!0,tsx:!0},loose:!0,target:"es2022",externalHelpers:!1,transform:{legacyDecorator:!0,decoratorMetadata:!0,react:{runtime:"automatic",throwIfNamespace:!0,useBuiltins:!0,refresh:"react"===e,development:!1,importSource:o?"solid-js/h":void 0}},experimental:{plugins:[[r.resolve("@moneko/transform-imports"),{"@moneko/common":{transform:"@moneko/common/lib/${member}"},lodash:{transform:"lodash/${member}"},"@ant-design/icons":{transform:"es/icons/${member}"},antd:{transform:"es/${member}",memberTransformers:["dashed_case"]},"neko-ui":{transform:"es/${member}",memberTransformers:["dashed_case"]}}],o&&[r.resolve("@moneko/jsx-dom-expressions"),{moduleName:"solid-js/web",builtIns:["For","Show","Switch","Match","Suspense","SuspenseList","Portal","Index","Dynamic","ErrorBoundary"],contextToCustomElements:!0,wrapConditionals:!0,generate:"dom",hydratable:!1}]].filter(Boolean)}},sourceMaps:!0,exclude:["__tests__/","examples/"]})),m}
1
+ import{join as e}from"node:path";import{updateFileSync as o}from"@moneko/utils";import r from"../../commom/require.mjs";import{__dirname as s}from"../file.mjs";let m=e(s,".swcrc");export default function(e){let s="solid"===e;return o(m,JSON.stringify({$schema:"https://json.schemastore.org/swcrc",module:{type:"es6"},minify:!0,jsc:{minify:{mangle:!0,compress:!0,format:{comments:"some"}},parser:{syntax:"typescript",decorators:!0,dynamicImport:!0,tsx:!0},loose:!0,target:"es2022",externalHelpers:!1,transform:{legacyDecorator:!0,decoratorMetadata:!0,react:{runtime:"automatic",throwIfNamespace:!0,useBuiltins:!0,refresh:"react"===e,development:!1,importSource:s?"solid-js/h":void 0}},experimental:{plugins:[[r.resolve("@moneko/transform-imports"),{"@moneko/common":{transform:"@moneko/common/lib/${member}"},lodash:{transform:"lodash/${member}"},"@ant-design/icons":{transform:"es/icons/${member}"},antd:{transform:"es/${member}",memberTransformers:["dashed_case"]},"neko-ui":{transform:"es/${member}",memberTransformers:["dashed_case"]}}],s&&[r.resolve("@moneko/jsx-dom-expressions"),{moduleName:"solid-js/web",builtIns:["For","Show","Switch","Match","Suspense","SuspenseList","Portal","Index","Dynamic","ErrorBoundary"],contextToCustomElements:!0,wrapConditionals:!0,generate:"dom",hydratable:!1}]].filter(Boolean)}},sourceMaps:!0,exclude:["__tests__/","examples/","\\.d\\.ts$"]})),m}
@@ -1 +1 @@
1
- import e from"../module.config.mjs";import{CUSTOMCONFIG as s}from"../paths.mjs";import{isLibrary as t}from"../process-env.mjs";import{resolveProgram as r}from"../utils/index.mjs";let m={name:"server",target:"node",dependencies:["client"],entry:{main:r("site/ssr.tsx")},output:{path:r(`${t?"docs":"dist"}/server`),library:{type:"commonjs2",umdNamedDefine:!1},filename:"[name].cjs",chunkFilename:"[chunkhash].cjs",globalObject:"global"},cache:{type:"filesystem",name:[s,process.env.NODE_ENV,"server"].filter(Boolean).join("-")},externalsPresets:{node:!0},externals:[],module:e(!0)};export default m;
1
+ import{CUSTOMCONFIG as e}from"../commom/paths.mjs";import s from"../module.config.mjs";import{isLibrary as m}from"../process-env.mjs";import{resolveProgram as o}from"../utils/index.mjs";let t={name:"server",target:"node",dependencies:["client"],entry:{main:o("site/ssr.tsx")},output:{path:o(`${m?"docs":"dist"}/server`),library:{type:"commonjs2",umdNamedDefine:!1},filename:"[name].cjs",chunkFilename:"[chunkhash].cjs",globalObject:"global"},cache:{type:"filesystem",name:[e,process.env.NODE_ENV,"server"].filter(Boolean).join("-")},externalsPresets:{node:!0},externals:[],module:s(!0)};export default t;
package/lib/build.mjs CHANGED
@@ -1 +1 @@
1
- import{analyzeBundleSize as o,completedInfo as r,ink as m,println as t,progressBar as i}from"@moneko/utils";import{relative as e}from"path";import n from"webpack";import{merge as s}from"webpack-merge";import a from"./build/common.mjs";import p from"./plugin/done.mjs";import{empty as l}from"./utils/index.mjs";import c from"./utils/seo.mjs";import{CONFIG as f}from"./config.mjs";import u from"./module.config.mjs";import d from"./paths.mjs";let h=f.bar.name||"Build",{ProgressPlugin:g}=n,w=n(s(a,{module:u(!1),plugins:[f.done&&new p({done:f.done}),!!f.bar&&new g({handler(o,r,...m){i(o||0,1,h,m.length?`[${r}] ${m.join(" ")}`:""),1===o&&process.stdout.write("\r\x1b[2K")}})].filter(Boolean)}));async function j(){let i=await new Promise((o,r)=>{w.run((m,t)=>{m&&r(m),t?o(t):r(Error("编译过程中没有生成统计信息"))})});(i.hasErrors()||i.hasWarnings())&&function(o){let{warnings:r,errors:i}=o.compilation;r.forEach(o=>{t(m(o.message,"178"))}),i.forEach(o=>{t(m(o.message,"red"))})}(i),await new Promise(n=>{i.compilation.compiler.cache.shutdown(s=>{s&&t(m(s.toString(),"red")),o(i.compilation.outputOptions.path,["\\.js$"]),r(~~((i.endTime-i.startTime)/10)/100,e(d.programPath,i.compilation.outputOptions.path)),n()})}),f.seo&&c()}process.on("exit",l),await j();
1
+ import{relative as o}from"node:path";import{analyzeBundleSize as m,completedInfo as r,ink as t,println as i,progressBar as e}from"@moneko/utils";import n from"webpack";import{merge as s}from"webpack-merge";import a from"./build/common.mjs";import p from"./commom/paths.mjs";import l from"./plugin/done.mjs";import{empty as c}from"./utils/index.mjs";import f from"./utils/seo.mjs";import{CONFIG as u}from"./config.mjs";import d from"./module.config.mjs";let h=u.bar.name||"Build",{ProgressPlugin:g}=n,w=n(s(a,{module:d(!1),plugins:[u.done&&new l({done:u.done}),!!u.bar&&new g({handler(o,m,...r){e(o||0,1,h,r.length?`[${m}] ${r.join(" ")}`:""),1===o&&process.stdout.write("\r\x1b[2K")}})].filter(Boolean)}));async function j(){let e=await new Promise((o,m)=>{w.run((r,t)=>{r&&m(r),t?o(t):m(Error("编译过程中没有生成统计信息"))})});(e.hasErrors()||e.hasWarnings())&&function(o){let{warnings:m,errors:r}=o.compilation;m.forEach(o=>{i(t(o.message,"178"))}),r.forEach(o=>{i(t(o.message,"red"))})}(e),await new Promise(n=>{e.compilation.compiler.cache.shutdown(s=>{s&&i(t(s.toString(),"red")),m(e.compilation.outputOptions.path,["\\.js$"]),r(~~((e.endTime-e.startTime)/10)/100,o(p.programPath,e.compilation.outputOptions.path)),n()})}),u.seo&&f()}process.on("exit",c),await j();
@@ -1 +1 @@
1
- import r from"./require.mjs";export default function(e){try{return r.resolve(e)}catch(r){return!1}}
1
+ import r from"./require.mjs";export default function(e){try{return r.resolve(e)}catch{return!1}}
@@ -0,0 +1 @@
1
+ import{createConnection as e}from"node:net";import{networkInterfaces as t}from"node:os";export function getIPv4(){let e=t(),o=null,r=Object.keys(e);for(let t=0,n=r.length;t<n;t++){let n=e[r[t]]||[];for(let e=0,t=n.length;e<t;e++){let t=n[e];"IPv4"!==t.family||t.internal||(o=t.address)}}return o}export function getPort(t,o="0.0.0.0"){return new Promise((r,n)=>{if("number"!=typeof t)r(t);else{let l=e(t,o);l.on("connect",()=>{l.destroy(),r(getPort(t+1,o))}),l.on("error",e=>{l.destroy(e),"ECONNREFUSED"===e.code?r(t):n(e)})}})}
@@ -0,0 +1 @@
1
+ export default function(){let e;let s="win32"===process.platform;return e=s?process.env.TEMP||process.env.TMP||`${process.env.SystemRoot||process.env.windir}\\temp`:process.env.TMPDIR||process.env.TMP||process.env.TEMP||"/tmp",(s?/[^:]\\$/:/.\/$/).test(e)&&(e=e.slice(0,-1)),e}
@@ -0,0 +1 @@
1
+ import{resolve as e}from"node:path";import n from"./paths.mjs";export default function(a,o=1){let t=a.replace(/^\/|\/$/g,"").replace(/\\/g,"/"),i=t,m="index.ts",d=t.match(/(.+)\/index\.([^/]+)$/),r=t.match(/(.+)\.([^/]+)$/);return d?(i=d[1],m=`index.${d[2]}`):r&&(i=r[1],m=`index.${r[2]}`),{name:i,main:m,pkg:e(n.nodeModules,i,"package.json"),file:e(n.nodeModules,i,m),meta:`{"name":"${i}","main":"${m}","version":"0.0.${o}","description": ""}`}}
@@ -1,5 +1,3 @@
1
- /** 当前文件的绝对路径 */
2
- export declare const __filename: string;
3
1
  /** 当前文件所在目录的绝对路径 */
4
2
  export declare const __dirname: string;
5
3
  /** yarn 命令行参数对象,包含配置选项 */
@@ -15,12 +13,12 @@ export declare const yarnArgv: Record<string, string> & {
15
13
  */
16
14
  export declare const CUSTOMCONFIG: string | undefined;
17
15
  declare const paths: {
18
- __dirname: string;
19
- __filename: string;
20
16
  /** node_modules 目录路径 */
21
17
  nodeModules: string;
22
18
  /** pnpm node_modules 目录路径 */
23
19
  pnpmNodeModules: string;
20
+ /** deno node_modules 目录路径 */
21
+ denoNodeModules: string;
24
22
  /** 核心代码路径 */
25
23
  corePath: string;
26
24
  /** 项目根目录路径 */
@@ -0,0 +1 @@
1
+ import{resolve as o}from"node:path";import e from"node:url";import{fileExists as t}from"@moneko/utils";let n=JSON.parse(process.env.npm_config_argv||'{"original":[]}').original;export const __dirname=e.fileURLToPath(new URL("..",import.meta.url));export const yarnArgv={};for(let o=0,e=n.length;o<e;o++){let e=n[o].split("=");Object.assign(yarnArgv,{[e[0]]:e[1]||!0})}export const CUSTOMCONFIG=process.env.npm_config_config||yarnArgv.config||process.env.__args__config__;let c=process.cwd(),a=o(c,"./node_modules"),r={nodeModules:a,pnpmNodeModules:o(a,"./.pnpm/node_modules"),denoNodeModules:o(a,"./.deno"),corePath:__dirname,programPath:c,webpackCachePath:o(a,"./.cache"),lintCachePath:o(a,"./.cache"),httpCachePath:o(a,"./.cache/http"),swcCachePath:o(a,"./.cache/.swc"),configPath:o(c,"./config/index.ts"),customConfigPath:o(c,`./config/${CUSTOMCONFIG}.ts`),coveragePath:o(c,"./coverage/clover.xml"),pagesPath:o(c,"./src/pages"),componentsPath:o(c,"./components"),mockPath:o(c,"./mock")};export const config_files=[t(r.configPath)&&r.configPath,t(r.customConfigPath)&&r.customConfigPath].filter(Boolean);export const routeDir="library"===process.env.APPTYPE?r.componentsPath:r.pagesPath;export default r;
@@ -1,4 +1,4 @@
1
- import EventEmitter from 'events';
1
+ import EventEmitter from 'node:events';
2
2
  declare class ReactiveObject<T extends object = Record<string, string | undefined>> extends EventEmitter {
3
3
  readonly data: T;
4
4
  constructor(props?: T);
@@ -0,0 +1 @@
1
+ import t from"node:events";class e extends t{constructor(t={}){super(),this.data=t}setData(t,e){this.data[t]!==e&&(this.data[t]=e,this.emit("change",t,e))}getData(t){return this.data[t]}removeData(t){Object.prototype.hasOwnProperty.call(this.data,t)&&(delete this.data[t],this.emit("change",t,null))}[Symbol.iterator](){let t=Object.keys(this.data),e=0;return{next:()=>{if(e<t.length){let a=t[e++];return{value:[a,this.data[a]],done:!1}}return{value:void 0,done:!0}}}}}export default e;
@@ -0,0 +1 @@
1
+ import{createRequire as e}from"node:module";import{transformFileSync as o}from"@swc/core";let t=e(import.meta.url),s={sourceMaps:!1,module:{type:"commonjs"},jsc:{parser:{syntax:"typescript"}}};function r(e,t){return e._compile(o(t,s).code,t)}t.extensions[".ts"]=r,t.extensions[".mts"]=r,t.extensions[".mjs"]=r;export default t;
package/lib/common.mjs CHANGED
@@ -1 +1 @@
1
- import{CONFIG as e,PUBLICPATH as t}from"./config.mjs";import o,{CUSTOMCONFIG as a,config_files as s}from"./paths.mjs";import n from"./plugin/override-resolve.mjs";import i from"./plugins.config.mjs";import{NODE_ENV as l,PACKAGENAME as r,PACKAGEVERSION as m,isDev as p,isLibrary as c}from"./process-env.mjs";import{isObject as u,node_modules as h,resolveProgram as d}from"./utils/index.mjs";import{join as f,resolve as g,extname as b}from"path";import{exampleModuleName as y}from"./vm/example.mjs";import j from"./vm/info.mjs";export const outputConfig={path:d(c?"docs":"dist"),filename:"js/[name].bundle.js",chunkFilename:`js/[${p?"name":"contenthash"}].js`,assetModuleFilename:e=>{let t=b(e.filename||"").substring(1);return`assets/${t}/[name][hash][ext]`},library:{name:`${j.projectName}`,type:"umd",umdNamedDefine:!0},globalObject:"window",chunkLoadingGlobal:`webpackJsonp_${r}`,pathinfo:p,clean:!0,publicPath:t,asyncChunks:!0,charset:!0,iife:!0,crossOriginLoading:"anonymous",enabledWasmLoadingTypes:["fetch"],hotUpdateChunkFilename:"[id].[fullhash].hot.js",hotUpdateMainFilename:"[runtime].[fullhash].hot.json"};let v={main:[e.polyfill&&f(o.corePath,"./polyfills/replace-children.mjs"),h("@app/entry")].filter(Boolean)};e.entry&&("string"==typeof e.entry?v={main:[e.entry]}:Object.keys(e.entry)&&(v=Object.assign(v,e.entry))),"string"==typeof v.main&&(v.main=[v.main]),e.output&&("string"==typeof e.output?outputConfig.path=e.output:Object.keys(e.output)&&Object.assign(outputConfig,e.output));let C={type:"filesystem",allowCollectingMemory:!0,cacheDirectory:o.webpackCachePath,memoryCacheUnaffected:!0,name:`.${[a,l].filter(Boolean).join("-")}`,version:`${m}`,buildDependencies:{config:s}};!1===e.cache?C=!1:u(e.cache)&&(C=Object.assign(C,e.cache));let k=Object.assign({original:e.alias["@"],override:a&&d(a)},e.overrideResolve);export const commonConfig={name:"client",target:"web",devtool:e.devtool,entry:v,mode:p?"development":"production",stats:"errors-only",cache:C,snapshot:{immutablePaths:[/node_modules\/(?!(@app|@moneko)\/)/],managedPaths:[/^@app\/.+/,/^@moneko\/.+/],buildDependencies:{timestamp:!0,hash:!0}},infrastructureLogging:{level:"error"},externalsPresets:e.externalsPresets,plugins:i,node:{global:!1,__filename:!1,__dirname:!1},experiments:{topLevelAwait:!0,asyncWebAssembly:!0,cacheUnaffected:!0,layers:!0,lazyCompilation:e.lazyCompilation&&p&&{imports:!0,entries:!0,test:e=>{let t=e.nameForCondition();return!!(t&&(t.startsWith(h(y))||t.startsWith(h("@app/comment"))||t.startsWith(o.pagesPath)||t.startsWith(o.componentsPath)))}},buildHttp:u(e.buildHttp)?{allowedUris:[],lockfileLocation:g(o.httpCachePath,"http.lock"),cacheLocation:g(o.httpCachePath,"data"),upgrade:!0,...e.buildHttp}:e.buildHttp,backCompat:!0,futureDefaults:!0,css:!1,outputModule:!1},resolve:{extensions:[".mts",".mjs",".ts",".tsx",".js",".jsx",".json",".wasm"],alias:e.alias,modules:[o.nodeModules,o.pnpmNodeModules],mainFields:["browser","module","main"],mainFiles:["index"],plugins:[e.overrideResolve&&new n(k),...e.resolvePlugins].filter(Boolean),preferAbsolute:!0,cache:!0,fallback:{}},externals:e.externals,output:outputConfig};
1
+ import{extname as e,join as t,resolve as o}from"node:path";import a,{config_files as n,CUSTOMCONFIG as s}from"./commom/paths.mjs";import i from"./plugin/override-resolve.mjs";import{isObject as l,node_modules as r,resolveProgram as m}from"./utils/index.mjs";import{exampleModuleName as p}from"./vm/example.mjs";import c from"./vm/info.mjs";import{CONFIG as u,PUBLICPATH as d}from"./config.mjs";import h from"./plugins.config.mjs";import{isDev as f,isLibrary as g,NODE_ENV as b,PACKAGENAME as y,PACKAGEVERSION as j}from"./process-env.mjs";export const outputConfig={path:m(g?"docs":"dist"),filename:"js/[name].bundle.js",chunkFilename:`js/[${f?"name":"contenthash"}].js`,assetModuleFilename:t=>{let o=e(t.filename||"").substring(1);return`assets/${o}/[name][hash][ext]`},library:{name:`${c.projectName}`,type:"umd",umdNamedDefine:!0},globalObject:"window",chunkLoadingGlobal:`webpackJsonp_${y}`,pathinfo:f,clean:!0,publicPath:d,asyncChunks:!0,charset:!0,iife:!0,crossOriginLoading:"anonymous",enabledWasmLoadingTypes:["fetch"],hotUpdateChunkFilename:"[id].[fullhash].hot.js",hotUpdateMainFilename:"[runtime].[fullhash].hot.json"};let v={main:[u.polyfill&&t(a.corePath,"./polyfills/replace-children.mjs"),r("@app/entry")].filter(Boolean)};u.entry&&("string"==typeof u.entry?v={main:[u.entry]}:Object.keys(u.entry)&&(v=Object.assign(v,u.entry))),"string"==typeof v.main&&(v.main=[v.main]),u.output&&("string"==typeof u.output?outputConfig.path=u.output:Object.keys(u.output)&&Object.assign(outputConfig,u.output));let C={type:"filesystem",allowCollectingMemory:!0,cacheDirectory:a.webpackCachePath,memoryCacheUnaffected:!0,name:`.${[s,b].filter(Boolean).join("-")}`,version:`${j}`,buildDependencies:{config:n}};!1===u.cache?C=!1:l(u.cache)&&(C=Object.assign(C,u.cache));let k=Object.assign({original:u.alias["@"],override:s&&m(s)},u.overrideResolve);export const commonConfig={name:"client",target:"web",devtool:u.devtool,entry:v,mode:f?"development":"production",stats:"errors-only",cache:C,snapshot:{immutablePaths:[/node_modules\/(?!(@app|@moneko)\/)/],managedPaths:[/^@app\/.+/,/^@moneko\/.+/],buildDependencies:{timestamp:!0,hash:!0}},infrastructureLogging:{level:"error"},externalsPresets:u.externalsPresets,plugins:h,node:{global:!1,__filename:!1,__dirname:!1},experiments:{topLevelAwait:!0,asyncWebAssembly:!0,cacheUnaffected:!0,layers:!0,lazyCompilation:u.lazyCompilation&&f&&{imports:!0,entries:!0,test:e=>{let t=e.nameForCondition();return!!(t&&(t.startsWith(r(p))||t.startsWith(r("@app/comment"))||t.startsWith(a.pagesPath)||t.startsWith(a.componentsPath)))}},buildHttp:l(u.buildHttp)?{allowedUris:[],lockfileLocation:o(a.httpCachePath,"http.lock"),cacheLocation:o(a.httpCachePath,"data"),upgrade:!0,...u.buildHttp}:u.buildHttp,backCompat:!0,futureDefaults:!0,css:!1,outputModule:!1},resolve:{extensions:[".mts",".mjs",".ts",".tsx",".js",".jsx",".json",".wasm"],alias:u.alias,modules:[a.nodeModules,a.pnpmNodeModules,a.denoNodeModules],mainFields:["browser","module","main"],mainFiles:["index"],plugins:[u.overrideResolve&&new i(k),...u.resolvePlugins].filter(Boolean),preferAbsolute:!0,cache:!0,fallback:{}},externals:u.externals,output:outputConfig};
package/lib/config.mjs CHANGED
@@ -1 +1 @@
1
- import{merge as e}from"webpack-merge";import o from"./options/jsx-dom-expressions.mjs";import t from"./options/split-chunk.mjs";import n from"./paths.mjs";import{APPTYPE as s,FRAMEWORK as i,NODE_ENV as r,PACKAGENAME as l,isDev as a,isLibrary as m,isMobile as p,jsxImportSource as u,mainDirectory as c}from"./process-env.mjs";import{isFunction as d,resolveProgram as f}from"./utils/index.mjs";import h from"./utils/setup-env.mjs";import{fileExists as g}from"@moneko/utils";import x from"./utils/require.mjs";let v=["@app","@moneko","neko-ui",".cache/http/data","@ant-design","@antv","@antv/x6","@antv/x6-react-components","@element-plus","ant-design-vue","antd","antd-mini","antd-mobile","antd-mobile-icons","element-plus","element-ui","ng-zorro-antd","@antv","@mui","@du","ahooks","rc-queue-anim","umi","@fontsource","@fortawesome","font-pingfang-sc","font-pingfang-tc","katex","react-markdown-editor-lite","react-photo-view","schema-design"];export function getConfig(e){return delete x.cache[e],new Promise(o=>{if(g(e)){let t=x(e).default;return o(d(t)?t(process):t)}return o({})})}let[P,b,w]=await Promise.all([h(r,s,i),getConfig(n.configPath),getConfig(n.customConfigPath)]),C={devtool:a?"eval-cheap-module-source-map":"cheap-module-source-map",seo:!1,mode:"csr",bundleAnalyzer:!1,polyfill:!1,entry:{},minifier:{},sourceMap:{filename:"[file].map",publicPath:""},env:P,basename:"/",publicPath:"/",rem:{designSize:p?375:1920},fallbackCompPath:null,modifyVars:{},prefixCls:"n",alias:{"@":f(c)},moduleRules:[],prefixJsLoader:[],cssModules:[],cssModuleDefinition:!0,importOnDemand:{},proxy:{},devServer:{host:"localhost",port:3e3},htmlPluginOption:{},copy:{},routerMode:"browser",fixBrowserRouter:!1,plugins:[],resolvePlugins:[],overrideResolve:!1,splitChunk:t,runtimeChunk:"single",moduleFederation:[],rulesInclude:{css:v,js:v,media:v,font:v,wasm:[]},mdx:{jsx:!1,development:a,jsxImportSource:u,providerImportSource:`@moneko/${i}/mdx`},jsxDomExpressions:o,bar:{name:"Client",color:"#6f42c1"},normalizeCss:!0,externalsPresets:{},buildHttp:void 0,virtualModule:{},cssExtract:{},externals:["@swc/core"],lazyCompilation:!1,performance:!1,refresh:"solid"!==i,bundleId:"com.moneko.bid",bundles:[]};m&&(C.alias=Object.assign(C.alias,{"@pkg":n.componentsPath,[l]:n.componentsPath}));let j=C;(!1===(j=e(j,b,w)).devtool||!1===j.sourceMap)&&(j.sourceMap=!1,j.devtool=!1),j.fixBrowserRouter&&j.htmlPluginOption&&(j.htmlPluginOption.tags||(j.htmlPluginOption.tags=[]),j.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=j;export const PUBLICPATH=CONFIG.publicPath;
1
+ import{fileExists as e}from"@moneko/utils";import{merge as o}from"webpack-merge";import t from"./commom/paths.mjs";import n from"./commom/require.mjs";import s from"./commom/setup-env.mjs";import i from"./options/jsx-dom-expressions.mjs";import r from"./options/split-chunk.mjs";import{isFunction as l,resolveProgram as a}from"./utils/index.mjs";import{APPTYPE as m,FRAMEWORK as p,isDev as c,isLibrary as u,isMobile as d,jsxImportSource as f,mainDirectory as h,NODE_ENV as g,PACKAGENAME as x}from"./process-env.mjs";let v=["@app","@moneko","neko-ui",".cache/http/data","@ant-design","@antv","@antv/x6","@antv/x6-react-components","@element-plus","ant-design-vue","antd","antd-mini","antd-mobile","antd-mobile-icons","element-plus","element-ui","ng-zorro-antd","@antv","@mui","@du","ahooks","rc-queue-anim","umi","@fontsource","@fortawesome","font-pingfang-sc","font-pingfang-tc","katex","react-markdown-editor-lite","react-photo-view","schema-design"];export function getConfig(o){return delete n.cache[o],new Promise(t=>{if(e(o)){let e=n(o).default;return t(l(e)?e(process):e)}return t({})})}let[P,b,w]=await Promise.all([s(g,m,p,[]),getConfig(t.configPath),getConfig(t.customConfigPath)]),C={devtool:c?"eval-cheap-module-source-map":"cheap-module-source-map",seo:!1,mode:"csr",bundleAnalyzer:!1,polyfill:!1,entry:{},minifier:{},sourceMap:{filename:"[file].map",publicPath:""},env:P,basename:"/",publicPath:"/",rem:{designSize:d?375:1920},fallbackCompPath:null,modifyVars:{},prefixCls:"n",alias:{"@":a(h)},moduleRules:[],prefixJsLoader:[],cssModules:[],cssModuleDefinition:!0,importOnDemand:{},proxy:{},devServer:{host:"localhost",port:3e3},htmlPluginOption:{},copy:{},routerMode:"browser",fixBrowserRouter:!1,plugins:[],resolvePlugins:[],overrideResolve:!1,splitChunk:r,runtimeChunk:"single",moduleFederation:[],rulesInclude:{css:v,js:v,media:v,font:v,wasm:[]},mdx:{jsx:!1,development:c,jsxImportSource:f,providerImportSource:`@moneko/${p}/mdx`},jsxDomExpressions:i,bar:{name:"Client",color:"#6f42c1"},normalizeCss:!0,externalsPresets:{},buildHttp:void 0,virtualModule:{},cssExtract:{},externals:["@swc/core"],lazyCompilation:!1,performance:!1,refresh:"solid"!==p,bundleId:"com.moneko.bid",bundles:[]};u&&(C.alias=Object.assign(C.alias,{"@pkg":t.componentsPath,[x]:t.componentsPath}));let j=C;(!1===(j=o(j,b,w)).devtool||!1===j.sourceMap)&&(j.sourceMap=!1,j.devtool=!1),j.fixBrowserRouter&&j.htmlPluginOption&&(j.htmlPluginOption.tags||(j.htmlPluginOption.tags=[]),j.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=j;export const PUBLICPATH=CONFIG.publicPath;
@@ -1,3 +1,3 @@
1
- import{getIPv4 as e,getPort as t}from"./net.mjs";import{CONFIG as r}from"../config.mjs";import{ink as o,print as n,println as i,termClear as s}from"@moneko/utils";let l=r.devServer.port||3e3;export const PORT=await t(l);r.devServer.port=PORT;let m="/"===r.basename?"":r.basename,a=l!==PORT&&o(`Port ${o(l+"","yellow")} is in use, trying ${o(PORT+"","green")} instead.
2
- `,"245");function p(t){return`${r.devServer.https?"https":"http"}://${"local"===t?r.devServer.host:e()}:${PORT}${m}`}let $=o("You application is running here:","245"),c=`${o(" Local ","231",{bg:"blue"})} ${o(p("local"),"75")}
3
- ${o(" Network ","231",{bg:"29"})} ${o(p("net"),"green")}`;export function devLog(e,t){!e&&t&&(s(3),n([$,"",c,"",o(`Compiled successfully in ${o(`${t.endTime-t.startTime}ms`,"green")}`,"245")].join("\n"),!0),a&&i(a))}
1
+ import{ink as e,print as t,println as o,termClear as r}from"@moneko/utils";import{getIPv4 as n,getPort as i}from"../commom/net.mjs";import{CONFIG as m}from"../config.mjs";let s=m.devServer.port||3e3;export const PORT=await i(s);m.devServer.port=PORT;let l="/"===m.basename?"":m.basename,$=s!==PORT&&e(`Port ${e(`${s}`,"yellow")} is in use, trying ${e(`${PORT}`,"green")} instead.
2
+ `,"245");function a(e){return`${m.devServer.https?"https":"http"}://${"local"===e?m.devServer.host:n()}:${PORT}${l}`}let p=e("You application is running here:","245"),c=`${e(" Local ","231",{bg:"blue"})} ${e(a("local"),"75")}
3
+ ${e(" Network ","231",{bg:"29"})} ${e(a("net"),"green")}`;export function devLog(n,i){!n&&i&&(r(3),t([p,"",c,"",e(`Compiled successfully in ${e(`${i.endTime-i.startTime}ms`,"green")}`,"245")].join("\n"),!0),$&&o($))}
@@ -0,0 +1,3 @@
1
+ import { OpenAPIV3 } from 'openapi-types';
2
+ export type SchemaLike = OpenAPIV3.SchemaObject;
3
+ export declare function jsonSchema<T>(schema: SchemaLike): any;
@@ -0,0 +1 @@
1
+ function e(e,t,m){return Math.min(Math.max(e,t),m)}export function jsonSchema(t){if(void 0!==(t=function e(t){return t.allOf&&t.allOf[0]&&(t=t.allOf.reduce((t,m)=>Object.assign({},t,e(m)),t)),t}(t)).example)return t.example;if(void 0!==t.default)return t.default;if(t.oneOf&&t.oneOf[0])return jsonSchema(t.oneOf[0]);if(t.anyOf&&t.anyOf[0])return jsonSchema(t.anyOf[0]);let m=Array.isArray(t)?t[0].type:t.type;if("object"===m){let{properties:e}=t;return e?Object.fromEntries(Object.entries(e).map(([e,t])=>[e,jsonSchema(t)])):{}}if("array"===m){let e=t,m=e.items;if(!m)return[];let n=[],i=m.oneOf&&m.oneOf[0]||m;if(m.anyOf)for(let e of m.anyOf)i=e,n.push(jsonSchema(i));let r=e.minItems||1;for(;n.length<r;)n.push(jsonSchema(i));return e.maxItems?function(e,t=1){return e.slice(0,t)}(n,e.maxItems):n}if(Array.isArray(t.enum))return t.enum[0];if("string"===m){let{format:m}=t,n={email:"user@example.com",hostname:"example.com",ipv4:"8.8.8.8",ipv6:"2001:4860:4860::8888",uri:"https://example.com/path","uri-reference":"/path#anchor","uri-template":"/path/{param}","json-pointer":"/foo/bar","date-time":new Date("1970-01-01").toJSON(),uuid:"3fa85f64-5717-4562-b3fc-2c963f66afa6",_default:"string"},i=n[m]||n._default,r=t.minLength?t.minLength:0,u=t.maxLength?t.maxLength:i.length;return i===n._default&&i.length<r?i.padEnd(r,i):i.substring(0,e(i.length,r,u))}if("number"===m){let m=t.minimum?t.minimum:-Number.MAX_VALUE,n=t.maximum?t.maximum:Number.MAX_VALUE;return t.multipleOf&&(m=Math.ceil(m/t.multipleOf)*t.multipleOf,n=Math.floor(n/t.multipleOf)*t.multipleOf),e(0,m,n)}if("integer"===m){let m=t.minimum&&t.exclusiveMinimum?t.minimum+1:t.minimum,n=t.maximum&&t.exclusiveMaximum?t.maximum-1:t.maximum,i=m||Number.MIN_SAFE_INTEGER,r=n||Number.MAX_SAFE_INTEGER;return t.multipleOf&&(i=Math.ceil(i/t.multipleOf)*t.multipleOf,r=Math.floor(r/t.multipleOf)*t.multipleOf),e(0,i,r)}return"null"===m?null:"boolean"===m||{}}
package/lib/dev/mock.mjs CHANGED
@@ -1 +1 @@
1
- import e from"http";import{watch as t}from"chokidar";import o from"express";import{print as r}from"@moneko/utils";import{mock as a}from"mock-json-schema";import{merge as n}from"webpack-merge";import s from"../utils/match-path.mjs";import i from"../utils/require.mjs";import c from"../utils/log.mjs";function p(e,t,o){if(delete i.cache[t],o[t]){for(let r in o[t])Object.prototype.hasOwnProperty.call(o[t],r)&&(e[r]=null,delete e[r]);o[t]=null,delete o[t]}}export const yApiSchemaMock=(t,o)=>new Promise(r=>{e.get(`${t.host}/api/interface/get?id=${t.id}&token=${t.token}`,e=>{e.setEncoding("utf8");let t="";e.on("data",e=>{t+=e}),e.on("end",()=>{try{let e=JSON.parse(t);if(e?.data?.res_body_is_json_schema){let t=JSON.parse(e.data.res_body),s=a(t);void 0!==o?r(n(s,o)):r(s)}}catch(e){c(e)}})})});export const yApiMock=(t,o)=>new Promise((r,a)=>{let n=new URL(o.host),s={hostname:n.hostname,port:n.port,path:t.path.replace(new RegExp(o.pathRewrite),`/mock/${o.projectId}/`),method:t.method,headers:t.headers,query:t.query},i=e.request(s,e=>{e.setEncoding("utf8");let t="";e.on("data",e=>{t+=e}),e.on("end",()=>{try{r(JSON.parse(t))}catch(e){c(e)}})});i.on("error",e=>{a(e.message)}),i.write(JSON.stringify(t.body)),i.end()});export default(e=>{let a={},n={};return t(e).on("all",async function(e,t){switch(r("Updating mock...",!0),e){case"add":case"change":try{p(n,t,a);let e=i(t).default;a[t]=e,n=Object.assign(n,e)}catch{}break;case"unlink":p(n,t,a)}r("Mock update successful",!0)}),function(e,t,r){let a=`${e.method} ${e.path}`,i=Object.keys(n).filter(function(e){return RegExp(`^${e.replace(/(:\w*)[^/]/g,"((?!/).)")}*$`).test(a)});if(!n[a]&&(!i||!(i.length>0)))return r();{let c;let p=e.get("Content-Type");switch(p){case"text/plain":c=o.raw({type:"text/plain"});break;case"text/html":c=o.text({type:"text/html"});break;case"application/x-www-form-urlencoded":c=o.urlencoded({extended:!1});break;default:c=o.json()}p?.startsWith("multipart/form-data;")&&(c=o.static("./public")),c(e,t,function(){let o=n[a]||n[i[0]];if("function"==typeof o){let a=s(i[0].split(" ")[1],e.url);a&&Object.assign(e.params,a.params),o(e,t,r)}else t.json(o)})}}});
1
+ import e from"node:http";import{print as t}from"@moneko/utils";import{watch as o}from"chokidar";import r from"express";import{merge as a}from"webpack-merge";import n from"../commom/log.mjs";import s from"../commom/match-path.mjs";import c from"../commom/require.mjs";import{jsonSchema as i}from"./json-schema.mjs";function m(e,t,o){if(delete c.cache[t],o[t]){for(let r in o[t])Object.prototype.hasOwnProperty.call(o[t],r)&&(e[r]=null,delete e[r]);o[t]=null,delete o[t]}}export const yApiSchemaMock=(t,o)=>new Promise(r=>{e.get(`${t.host}/api/interface/get?id=${t.id}&token=${t.token}`,e=>{e.setEncoding("utf8");let t="";e.on("data",e=>{t+=e}),e.on("end",()=>{try{let e=JSON.parse(t);if(e?.data?.res_body_is_json_schema){let t=JSON.parse(e.data.res_body),n=i(t);void 0!==o?r(a(n,o)):r(n)}}catch(e){n(e)}})})});export const yApiMock=(t,o)=>new Promise((r,a)=>{let s=new URL(o.host),c={hostname:s.hostname,port:s.port,path:t.path.replace(new RegExp(o.pathRewrite),`/mock/${o.projectId}/`),method:t.method,headers:t.headers,query:t.query},i=e.request(c,e=>{e.setEncoding("utf8");let t="";e.on("data",e=>{t+=e}),e.on("end",()=>{try{r(JSON.parse(t))}catch(e){n(e)}})});i.on("error",e=>{a(e.message)}),i.write(JSON.stringify(t.body)),i.end()});export default(e=>{let a={},i={};return o(e).on("all",async function(e,o){switch(t("Updating mock...",!0),e){case"add":case"change":try{m(i,o,a);let e=c(o).default;a[o]=e,i=Object.assign(i,e)}catch(e){n(e)}break;case"unlink":m(i,o,a)}t("Mock update successful",!0)}),function(e,t,o){let a=`${e.method} ${e.path}`,n=Object.keys(i).filter(function(e){return RegExp(`^${e.replace(/(:\w*)[^/]/g,"((?!/).)")}*$`).test(a)});if(!i[a]&&(!n||!(n.length>0)))return o();{let c;let m=e.get("Content-Type");switch(m){case"text/plain":c=r.raw({type:"text/plain"});break;case"text/html":c=r.text({type:"text/html"});break;case"application/x-www-form-urlencoded":c=r.urlencoded({extended:!1});break;default:c=r.json()}m?.startsWith("multipart/form-data;")&&(c=r.static("./public")),c(e,t,function(){let r=i[a]||i[n[0]];if("function"==typeof r){let a=s(n[0].split(" ")[1],e.url);a&&Object.assign(e.params,a.params),r(e,t,o)}else t.json(r)})}}});
@@ -1,5 +1,5 @@
1
- import { type Options } from 'http-proxy-middleware';
2
1
  import type { Express } from 'express';
2
+ import { type Options } from 'http-proxy-middleware';
3
3
  export interface ProxyConfig {
4
4
  [key: string]: Options;
5
5
  }
package/lib/dev.mjs CHANGED
@@ -1 +1 @@
1
- let e;import t from"express";import o from"https";import s from"multer";import i from"webpack";import r from"webpack-dev-middleware";import l from"webpack-hot-middleware";import{merge as n}from"webpack-merge";import{commonConfig as a}from"./common.mjs";import{CONFIG as m,getConfig as c,PUBLICPATH as p}from"./config.mjs";import{PORT as d,devLog as u}from"./dev/config.mjs";import h from"./dev/mock.mjs";import f,{updateProxy as x}from"./dev/proxy.mjs";import y from"./module.config.mjs";import w,{config_files as g}from"./paths.mjs";import{isLibrary as v,isReact as k,refresh as $}from"./process-env.mjs";import C from"./utils/has-pkg.mjs";import{empty as b,resolveProgram as j}from"./utils/index.mjs";import P from"./utils/sigint-exit.mjs";import S from"./options/reslove.mjs";import{watchFile as A}from"fs";import{join as T}from"path";import{spawn as E,exec as O}from"child_process";import{directoryExists as I,ink as M,loadFile as _,println as R,progressBar as q,print as z}from"@moneko/utils";import{diffObject as B}from"./utils/diff-object.mjs";let{HotModuleReplacementPlugin:D,ProgressPlugin:G,WatchIgnorePlugin:H}=i,U=!1!==m.stylelint&&C("stylelint-webpack-plugin")&&(await import("stylelint-webpack-plugin")).default,L=!1!==m.eslint&&C("eslint-webpack-plugin")&&(await import("eslint-webpack-plugin")).default,N=k&&(await import("@pmmmwh/react-refresh-webpack-plugin")).default,F=["js","jsx","ts","tsx","json","html","vue"],W=F.join(","),K=["css","scss","sass","less","ts","tsx","js","jsx"],X=K.join(","),J=["node_modules/","es/","lib/","umd/","docs/","coverage/","dist/"],Q=`${p.endsWith("/")?"":"/"}__hmr__`,V=new URLSearchParams({name:"client",path:Q,dynamicPublicPath:!0,timeout:2e3,reload:!$,quiet:!0,noInfo:!0,overlay:!0,autoConnect:!0}).toString(),Y=a.output.path,Z=m.bar.name||"Build",ee=n(a,{entry:{main:[`${S.hotMiddlewareClient}?${V}`]},output:{path:Y},module:y(!1),optimization:{minimize:!1,concatenateModules:!1,removeAvailableModules:!1,removeEmptyChunks:!0,providedExports:!0,usedExports:!1,sideEffects:!1,splitChunks:{chunks:"all",minChunks:1,minSize:30720,maxSize:0,maxAsyncRequests:60,maxInitialRequests:50,hidePathInfo:!1,cacheGroups:{vendors:{test:/[\\/]node_modules[\\/]/,priority:-10,reuseExistingChunk:!0},default:{minChunks:1,priority:-20,reuseExistingChunk:!0}}}},plugins:[new D,new H({paths:[/node_modules\/(?!(@app|@moneko)).+/,/\.d\.ts$/]}),N&&new N,L&&new L({fix:!0,threads:!0,files:[`${m.alias["@"]}/**/*.{${W}}`,v&&`${m.alias["@pkg"]}/**/*.{${W}}`].filter(Boolean),extensions:F,exclude:J,cache:!0,cacheLocation:`${w.lintCachePath}/.eslintcache`,lintDirtyModulesOnly:!0,overrideConfigFile:j("eslint.config.mjs"),configType:"flat"}),U&&new U({fix:!0,threads:!0,files:[`${m.alias["@"]}/**/*.{${X}}`,v&&`${m.alias["@pkg"]}/**/*.{${X}}`].filter(Boolean),extensions:K,exclude:J,cache:!0,cacheLocation:`${w.lintCachePath}/.stylelintcache`,lintDirtyModulesOnly:!0}),!!m.bar&&new G({handler(e,t,...o){q(e||0,1,Z,o.length?`[${t}] ${o.join(" ")}`:""),1===e&&process.stdout.write("\r\x1b[2K")}})].filter(Boolean)}),et=i(ee);et.hooks.done.tap("client-log",e=>{u(null,e)});let eo=t(),es=s(),ei={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Credentials":"true","Access-Control-Allow-Headers":"DNT,X-Mx-ReqToken,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Authorization","Access-Control-Allow-Methods":"GET, POST, OPTIONS, DELETE, PATCH, PUT",...m.devServer.headers},er=r(et,{writeToDisk:!1,index:"index.html",headers:e=>({...ei,"Access-Control-Allow-Origin":e.headers.origin||"*","Cache-Control":"no-store, no-cache, must-revalidate, proxy-revalidate",Pragma:"no-cache",Expires:"0"}),serverSideRender:!1,lastModified:!0,publicPath:ee.output?.publicPath,cacheControl:!1,cacheImmutable:!1}),el=l(et,{log:!1,path:Q,heartbeat:2e3});eo.use(t.static(T(w.programPath,"./public"))).use(er).use(Q,el),I(w.mockPath)&&eo.use(es.any(),h(w.mockPath)),m.proxy&&f(eo,m.proxy);let en=`${ee.output.path}/index.html`;if(eo.use((e,t,o)=>{if("GET"===e.method){let s=e.get("Accept");if(s?.includes("text/html")){let e=er.context.outputFileSystem,o=e?.readFileSync?.(en);t.headersSent||(t.setHeader("Content-Type","text/html"),t.send(o))}else if("text/event-stream"===s&&e.url.endsWith(Q))return e.url=Q,el(e,t,o);else return o()}else{if("OPTIONS"!==e.method)return o();t.sendStatus(200)}}),m.devServer.https){let[t,s]=await Promise.all([_(m.devServer.https.key),_(m.devServer.https.cert)]);t||(R(M(`无法加载私钥。请检查路径和文件是否存在,并确保路径正确:${m.devServer.https.key}`,"red")),process.exit(1)),s||(R(M(`无法加载证书。请检查路径和文件是否存在,并确保路径正确:${m.devServer.https.cert}`,"red")),process.exit(1)),e=o.createServer({key:t,cert:s},eo)}let ea=(e||eo).listen(d,"0.0.0.0",()=>{});function em(){process.exit(0)}let ec=await Promise.all(g.map(c)),ep=n(ec[0]||{},ec[1]||{});g.forEach(function(e){A(e,async function(){let[t,o]=await Promise.all(g.map(c)),s=n(t||{},o||{}),i=B(ep,s);1===Object.keys(i).length&&"proxy"in i?(z(M(`代理更新中...`,"yellow"),!0),x(eo,s.proxy),z(M(`代理更新完成...`,"green"),!0),m.proxy=s.proxy,ep.proxy=s.proxy,ep=s):(ep=s,R(M(`检测到工程配置${M(`[${e}]`,"blue")}变更, 程序即将重启...`,"yellow"),!0),O("win32"===process.platform?`netstat -ano | findstr :${d}`:`lsof -i :${d} -t`,(e,t)=>{if(e){R(M(`查找端口 ${d} 时发生错误: ${e.message}`,"red")),R(M("请尝试手动重启程序","yellow"));return}let o=t.trim().split("\n").filter(Boolean),s=ed?o[0]?.split(/\s+/).pop()?.trim():o[0]?.trim();if(!s){R(M(`未找到占用端口 ${d} 的进程, 请尝试手动重启程序`,"yellow"));return}try{process.kill(Number(s),"SIGHUP")}catch(e){R(M(`终止进程 ${s} 时发生错误: ${e.message}`,"red"))}}))})});let ed="win32"===process.platform;process.on("SIGHUP",function(){er.close(b),ea.close(b),ea.closeAllConnections(),function(){let e=E(process.argv[0],process.argv.slice(1),{detached:!1,stdio:"inherit"});e.unref(),e.on("close",em)}()}),process.on("exit",function(){er.close(b),ea.close(b),ea.closeAllConnections()}),P(em);
1
+ let e;import{exec as t,spawn as o}from"node:child_process";import{watchFile as r}from"node:fs";import s from"node:https";import{join as i}from"node:path";import{directoryExists as n,ink as l,loadFile as a,print as m,println as c,progressBar as p}from"@moneko/utils";import d from"express";import u from"multer";import h from"webpack";import f from"webpack-dev-middleware";import x from"webpack-hot-middleware";import{merge as y}from"webpack-merge";import{diffObject as w}from"./commom/diff-object.mjs";import g from"./commom/has-pkg.mjs";import v,{config_files as k}from"./commom/paths.mjs";import $ from"./commom/sigint-exit.mjs";import{devLog as C,PORT as b}from"./dev/config.mjs";import j from"./dev/mock.mjs";import P,{updateProxy as S}from"./dev/proxy.mjs";import A from"./options/reslove.mjs";import{empty as T,resolveProgram as E}from"./utils/index.mjs";import{commonConfig as O}from"./common.mjs";import{CONFIG as I,getConfig as M,PUBLICPATH as _}from"./config.mjs";import R from"./module.config.mjs";import{isLibrary as q,isReact as z,refresh as B}from"./process-env.mjs";let{HotModuleReplacementPlugin:D,ProgressPlugin:G,WatchIgnorePlugin:H}=h,U=!1!==I.stylelint&&g("stylelint-webpack-plugin")&&(await import("stylelint-webpack-plugin")).default,L=!1!==I.eslint&&g("eslint-webpack-plugin")&&(await import("eslint-webpack-plugin")).default,N=z&&(await import("@pmmmwh/react-refresh-webpack-plugin")).default,F=["js","jsx","ts","tsx","json","html","vue"],W=F.join(","),K=["css","scss","sass","less","ts","tsx","js","jsx"],X=K.join(","),J=["node_modules/","es/","lib/","umd/","docs/","coverage/","dist/"],Q=`${_.endsWith("/")?"":"/"}__hmr__`,V=new URLSearchParams({name:"client",path:Q,dynamicPublicPath:!0,timeout:2e3,reload:!B,quiet:!0,noInfo:!0,overlay:!0,autoConnect:!0}).toString(),Y=O.output.path,Z=I.bar.name||"Build",ee=y(O,{entry:{main:[`${A.hotMiddlewareClient}?${V}`]},output:{path:Y},module:R(!1),optimization:{minimize:!1,concatenateModules:!1,removeAvailableModules:!1,removeEmptyChunks:!0,providedExports:!0,usedExports:!1,sideEffects:!1,splitChunks:{chunks:"all",minChunks:1,minSize:30720,maxSize:0,maxAsyncRequests:60,maxInitialRequests:50,hidePathInfo:!1,cacheGroups:{vendors:{test:/[\\/]node_modules[\\/]/,priority:-10,reuseExistingChunk:!0},default:{minChunks:1,priority:-20,reuseExistingChunk:!0}}}},plugins:[new D,new H({paths:[/node_modules\/(?!(@app|@moneko)).+/,/\.d\.ts$/]}),N&&new N,L&&new L({fix:!0,threads:!0,files:[`${I.alias["@"]}/**/*.{${W}}`,q&&`${I.alias["@pkg"]}/**/*.{${W}}`].filter(Boolean),extensions:F,exclude:J,cache:!0,cacheLocation:`${v.lintCachePath}/.eslintcache`,lintDirtyModulesOnly:!0,overrideConfigFile:E("eslint.config.mjs"),configType:"flat"}),U&&new U({fix:!0,threads:!0,files:[`${I.alias["@"]}/**/*.{${X}}`,q&&`${I.alias["@pkg"]}/**/*.{${X}}`].filter(Boolean),extensions:K,exclude:J,cache:!0,cacheLocation:`${v.lintCachePath}/.stylelintcache`,lintDirtyModulesOnly:!0}),!!I.bar&&new G({handler(e,t,...o){p(e||0,1,Z,o.length?`[${t}] ${o.join(" ")}`:""),1===e&&process.stdout.write("\r\x1b[2K")}})].filter(Boolean)}),et=h(ee);et.hooks.done.tap("client-log",e=>{C(null,e)});let eo=d(),er=u(),es={"Access-Control-Allow-Origin":"*","Access-Control-Allow-Credentials":"true","Access-Control-Allow-Headers":"DNT,X-Mx-ReqToken,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Authorization","Access-Control-Allow-Methods":"GET, POST, OPTIONS, DELETE, PATCH, PUT",...I.devServer.headers},ei=f(et,{writeToDisk:!1,index:"index.html",headers:e=>({...es,"Access-Control-Allow-Origin":e.headers.origin||"*","Cache-Control":"no-store, no-cache, must-revalidate, proxy-revalidate",Pragma:"no-cache",Expires:"0"}),serverSideRender:!1,lastModified:!0,publicPath:ee.output?.publicPath,cacheControl:!1,cacheImmutable:!1}),en=x(et,{log:!1,path:Q,heartbeat:2e3});eo.use(d.static(i(v.programPath,"./public"))).use(ei).use(Q,en),n(v.mockPath)&&eo.use(er.any(),j(v.mockPath)),I.proxy&&P(eo,I.proxy);let el=`${ee.output.path}/index.html`;if(eo.use((e,t,o)=>{if("GET"===e.method){let r=e.get("Accept");if(r?.includes("text/html")){let e=ei.context.outputFileSystem,o=e?.readFileSync?.(el);t.headersSent||(t.setHeader("Content-Type","text/html"),t.send(o))}else if("text/event-stream"===r&&e.url.endsWith(Q))return e.url=Q,en(e,t,o);else return o()}else{if("OPTIONS"!==e.method)return o();t.sendStatus(200)}}),I.devServer.https){let[t,o]=await Promise.all([a(I.devServer.https.key),a(I.devServer.https.cert)]);t||(c(l(`无法加载私钥。请检查路径和文件是否存在,并确保路径正确:${I.devServer.https.key}`,"red")),process.exit(1)),o||(c(l(`无法加载证书。请检查路径和文件是否存在,并确保路径正确:${I.devServer.https.cert}`,"red")),process.exit(1)),e=s.createServer({key:t,cert:o},eo)}let ea=(e||eo).listen(b,"0.0.0.0",()=>{});function em(){process.exit(0)}let ec=await Promise.all(k.map(M)),ep=y(ec[0]||{},ec[1]||{});k.forEach(function(e){r(e,async function(){let[o,r]=await Promise.all(k.map(M)),s=y(o||{},r||{}),i=w(ep,s);1===Object.keys(i).length&&"proxy"in i?(m(l(`代理更新中...`,"yellow"),!0),S(eo,s.proxy),m(l(`代理更新完成...`,"green"),!0),I.proxy=s.proxy,ep.proxy=s.proxy,ep=s):(ep=s,c(l(`检测到工程配置${l(`[${e}]`,"blue")}变更, 程序即将重启...`,"yellow"),!0),t("win32"===process.platform?`netstat -ano | findstr :${b}`:`lsof -i :${b} -t`,(e,t)=>{if(e){c(l(`查找端口 ${b} 时发生错误: ${e.message}`,"red")),c(l("请尝试手动重启程序","yellow"));return}let o=t.trim().split("\n").filter(Boolean),r=ed?o[0]?.split(/\s+/).pop()?.trim():o[0]?.trim();if(!r){c(l(`未找到占用端口 ${b} 的进程, 请尝试手动重启程序`,"yellow"));return}try{process.kill(Number(r),"SIGHUP")}catch(e){c(l(`终止进程 ${r} 时发生错误: ${e.message}`,"red"))}}))})});let ed="win32"===process.platform;process.on("SIGHUP",function(){ei.close(T),ea.close(T),ea.closeAllConnections(),function(){let e=o(process.argv[0],process.argv.slice(1),{detached:!1,stdio:"inherit"});e.unref(),e.on("close",em)}()}),process.on("exit",function(){ei.close(T),ea.close(T),ea.closeAllConnections()}),$(em);
package/lib/index.d.mts CHANGED
@@ -1,16 +1,16 @@
1
- export { default as paths, CUSTOMCONFIG, yarnArgv, routeDir } from './paths.mjs';
2
- export { APPTYPE, FRAMEWORK, PACKAGENAME, PACKAGEVERSION, coreName, isDev, isLibrary, isMicro, mainDirectory, } from './process-env.mjs';
3
- export { resolveProgram, toCamelCase } from './utils/index.mjs';
4
- export { default as hasPkg } from './utils/has-pkg.mjs';
5
- export { default as osTmpDir } from './utils/os-tmp-dir.mjs';
6
- export { default as require } from './utils/require.mjs';
7
- export type { MdxOptions } from '@moneko/mdx';
8
- export type { OverrideResolverOption } from './plugin/override-resolve.mjs';
9
- export { type YApiOption, type YApiOptionBySchema, yApiMock, yApiSchemaMock, type RequestFormData, type ProxyFuncType, type MockConfiguration, } from './dev/mock.mjs';
1
+ export type * from '../typings/global.js';
2
+ export { default as hasPkg } from './commom/has-pkg.mjs';
3
+ export { getIPv4, getPort } from './commom/net.mjs';
4
+ export { default as osTmpDir } from './commom/os-tmp-dir.mjs';
5
+ export { CUSTOMCONFIG, default as paths, routeDir, yarnArgv } from './commom/paths.mjs';
6
+ export { default as require } from './commom/require.mjs';
7
+ export { default as Rule } from './commom/rule.mjs';
8
+ export { type MockConfiguration, type ProxyFuncType, type RequestFormData, yApiMock, type YApiOption, type YApiOptionBySchema, yApiSchemaMock, } from './dev/mock.mjs';
10
9
  export type { ProxyConfig } from './dev/proxy.mjs';
11
- export { getIPv4, getPort } from './dev/net.mjs';
12
- export { default as jsxDomExpressions, type JsxDomExpressions, } from './options/jsx-dom-expressions.mjs';
13
- export { default as splitChunk, type OptimizationSplitChunksOptions, } from './options/split-chunk.mjs';
14
- export { default as Rule } from './rule.mjs';
10
+ export { type JsxDomExpressions, default as jsxDomExpressions, } from './options/jsx-dom-expressions.mjs';
11
+ export { type OptimizationSplitChunksOptions, default as splitChunk, } from './options/split-chunk.mjs';
12
+ export type { OverrideResolverOption } from './plugin/override-resolve.mjs';
15
13
  export type { VirtualModulePluginOption } from './plugin/virtual-module.mjs';
16
- export type * from '../typings/global.js';
14
+ export { APPTYPE, coreName, FRAMEWORK, isDev, isLibrary, isMicro, mainDirectory, PACKAGENAME, PACKAGEVERSION, } from './process-env.mjs';
15
+ export { resolveProgram, toCamelCase } from './utils/index.mjs';
16
+ export type { MdxOptions } from '@moneko/mdx';