@tanyueran/cli 0.3.0 → 0.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -21,6 +21,7 @@ Commands:
21
21
  create [options] <project-name> 创建项目
22
22
  server [options] 启动一个本地HTTP服务器
23
23
  help [command] display help for command
24
+ git-rename [options] <old-name> <new-name> git重命名模块名称
24
25
 
25
26
  ```
26
27
 
package/dist/index.js CHANGED
@@ -1 +1 @@
1
- "use strict";var e=require("prompts"),t=require("node:path"),o=require("fs-extra"),s=require("handlebars"),a=require("commander"),n=require("node:http"),r=require("connect"),c=require("serve-static"),l=require("open");var i,p;!function(e){e.ViteVueTs="vite-vue-ts",e.WebpackVueTs="webpack-vue-ts"}(i||(i={})),function(e){e.VueTsPageTemplate="vue-ts-page-template",e.VueTsDetailTemplate="vue-ts-detail-template",e.VueTsEmpty="vue-ts-empty"}(p||(p={}));const m=[{label:"vite + vue + ts项目",value:i.ViteVueTs,path:"../template/project/vue/vite-vue-ts"}],u=[{label:"vue-ts的空模板",value:p.VueTsEmpty,path:"../template/module/vue/vue-ts-empty"}];const d=require("node:path");function h(e){const{targetPath:t,sourcePath:a,templateData:n}=e;if(o.statSync(a).isDirectory()){o.mkdirSync(t,{recursive:!0}),o.readdirSync(a).forEach(e=>{h({targetPath:d.join(t,e),sourcePath:d.join(a,e),templateData:n})})}else if(a.endsWith(".hbs")){const e=o.readFileSync(a),r=s.compile(e.toString())(n);o.writeFileSync(t.replace(".hbs",""),r)}else o.copyFileSync(a,t)}function v(e){const{targetPath:t,sourcePath:s}=e;if(!o.statSync(s).isDirectory())throw new Error("源文件路劲必须是一个目录");o.existsSync(t)&&o.removeSync(t),o.mkdirSync(t,{recursive:!0}),h(e)}s.registerHelper("toPascalCase",function(e){return function(e){return e&&"string"==typeof e?e.split(/[\s-_]/).map(e=>e.charAt(0).toUpperCase()+e.slice(1).toLowerCase()).join(""):e}(e)});const g=new a.Command;g.name("tx cli").description("一个简单CLI 工具").version("0.3.0");const y=require("picocolors");g.command("add <module-name>").description("添加模块").option("-m, --module-name <moduleName>","模块名称").action(async o=>{console.log("模块名称:",o);let s=o||g.opts().moduleName;if(!s){const t=await e([{type:"text",name:"name",message:"请输入模块名"}]);s=t.name?t.name:"test-module-name"}const a=await e([{type:"select",name:"template",message:"请选择模板",choices:u.map(e=>({title:e.label,value:e.value}))}]);console.log(y.green("模板名称:"+s)),console.log(y.green("选择模板:"+a.template));const n=u.find(e=>e.value===a.template);v({targetPath:t.resolve(process.cwd(),s),sourcePath:t.resolve(__dirname,n.path),templateData:{name:s}})});const f=require("picocolors");g.command("create <project-name>").description("创建项目").option("-p, --project-name <projectName>","项目名称").action(async o=>{let s=o||g.opts().projectName;if(console.log("项目名称:",s),!s){const t=await e([{type:"text",name:"name",message:"请输入项目名称"}]);s=t.name?t.name:"test-project-name"}const a=await e([{type:"select",name:"template",message:"请选择模板",choices:m.map(e=>({title:e.label,value:e.value}))}]);console.log(f.green("项目名称:"+a.template)),console.log(f.green("选择模板:"+s));const n=m.find(e=>e.value===a.template);v({targetPath:t.resolve(process.cwd(),s),sourcePath:t.resolve(__dirname,n.path),templateData:{name:s}}),console.log(f.green("创建成功")),console.log(f.green(`cd ./${s} && pnpm install`))}),g.command("server").description("启动一个本地HTTP服务器").option("-p, --port <number>","端口号","8080").option("-h, --host <host>","主机地址","localhost").option("-d, --directory <path>","服务的目录",".").option("-o, --open","启动后自动打开浏览器").option("-s, --silent","静默模式,不输出信息").option("--header <json>","启动服务设置的HTTP相应头","{}").action(e=>{!function(e={}){const{port:o=8080,host:s="localhost",directory:a=process.cwd(),openBrowser:i=!1,silent:p=!1,header:m={}}=e,u=r();u.use(c(t.resolve(a),m)),u.use((e,t)=>{t.statusCode=404,t.end("Not Found")});const d=n.createServer(u);d.listen(o,s,()=>{const e=`http://${s}:${o}`;p||(console.log("> 本地开发服务器已启动"),console.log(`> 访问地址: ${e}`),console.log(`> 服务目录: ${a}`),console.log("> 按 Ctrl+C 停止服务器")),i&&l(e).catch(e=>{console.warn(`无法自动打开浏览器: ${e.message}`)})}),process.on("SIGINT",()=>{console.log("\n> 正在关闭服务器..."),d.close(()=>{console.log("> 服务器已停止。"),process.exit(0)})})}({...e,port:parseInt(e.port,10),openBrowser:!!e.open,silent:!!e.silent,header:JSON.parse(e.header)})}),exports.start=function(){g.parse(process.argv)};
1
+ "use strict";var e=require("prompts"),t=require("node:path"),o=require("fs-extra"),s=require("handlebars"),a=require("commander"),n=require("node:http"),r=require("connect"),c=require("serve-static"),i=require("open");var l,p;!function(e){e.ViteVueTs="vite-vue-ts",e.WebpackVueTs="webpack-vue-ts"}(l||(l={})),function(e){e.VueTsPageTemplate="vue-ts-page-template",e.VueTsDetailTemplate="vue-ts-detail-template",e.VueTsEmpty="vue-ts-empty"}(p||(p={}));const m=[{label:"vite + vue + ts项目",value:l.ViteVueTs,path:"../template/project/vue/vite-vue-ts"}],u=[{label:"vue-ts的空模板",value:p.VueTsEmpty,path:"../template/module/vue/vue-ts-empty"}];const d=require("node:path");function g(e){const{targetPath:t,sourcePath:a,templateData:n}=e;if(o.statSync(a).isDirectory()){o.mkdirSync(t,{recursive:!0}),o.readdirSync(a).forEach(e=>{g({targetPath:d.join(t,e),sourcePath:d.join(a,e),templateData:n})})}else if(a.endsWith(".hbs")){const e=o.readFileSync(a),r=s.compile(e.toString())(n);o.writeFileSync(t.replace(".hbs",""),r)}else o.copyFileSync(a,t)}function h(e){const{targetPath:t,sourcePath:s}=e;if(!o.statSync(s).isDirectory())throw new Error("源文件路劲必须是一个目录");o.existsSync(t)&&o.removeSync(t),o.mkdirSync(t,{recursive:!0}),g(e)}s.registerHelper("toPascalCase",function(e){return function(e){return e&&"string"==typeof e?e.split(/[\s-_]/).map(e=>e.charAt(0).toUpperCase()+e.slice(1).toLowerCase()).join(""):e}(e)});const v=new a.Command;v.name("tx cli").description("一个简单CLI 工具").version("0.4.0");const y=require("picocolors");v.command("add <module-name>").description("添加模块").option("-m, --module-name <moduleName>","模块名称").action(async o=>{console.log("模块名称:",o);let s=o||v.opts().moduleName;if(!s){const t=await e([{type:"text",name:"name",message:"请输入模块名"}]);s=t.name?t.name:"test-module-name"}const a=await e([{type:"select",name:"template",message:"请选择模板",choices:u.map(e=>({title:e.label,value:e.value}))}]);console.log(y.green("模板名称:"+s)),console.log(y.green("选择模板:"+a.template));const n=u.find(e=>e.value===a.template);h({targetPath:t.resolve(process.cwd(),s),sourcePath:t.resolve(__dirname,n.path),templateData:{name:s}})});const f=require("picocolors");function w(e={}){const{port:o=8080,host:s="localhost",directory:a=process.cwd(),openBrowser:l=!1,silent:p=!1,header:m={}}=e,u=r();u.use(c(t.resolve(a),{setHeaders:(...e)=>function(e,t,o,s){for(const[t,o]of Object.entries(s))e.setHeader(t,o)}(...e,m)})),u.use((e,t)=>{t.statusCode=404,t.end("Not Found")});const d=n.createServer(u);return d.listen(o,s,()=>{const e=`http://${s}:${o}`;p||(console.log("> 本地开发服务器已启动"),console.log(`> 访问地址: ${e}`),console.log(`> 服务目录: ${a}`),console.log("> 按 Ctrl+C 停止服务器")),l&&i(e).catch(e=>{console.warn(`无法自动打开浏览器: ${e.message}`)})}),process.on("SIGINT",()=>{console.log("\n> 正在关闭服务器..."),d.close(()=>{console.log("> 服务器已停止。"),process.exit(0)})}),d}v.command("create <project-name>").description("创建项目").option("-p, --project-name <projectName>","项目名称").action(async o=>{let s=o||v.opts().projectName;if(console.log("项目名称:",s),!s){const t=await e([{type:"text",name:"name",message:"请输入项目名称"}]);s=t.name?t.name:"test-project-name"}const a=await e([{type:"select",name:"template",message:"请选择模板",choices:m.map(e=>({title:e.label,value:e.value}))}]);console.log(f.green("项目名称:"+a.template)),console.log(f.green("选择模板:"+s));const n=m.find(e=>e.value===a.template);h({targetPath:t.resolve(process.cwd(),s),sourcePath:t.resolve(__dirname,n.path),templateData:{name:s}}),console.log(f.green("创建成功")),console.log(f.green(`cd ./${s} && pnpm install`))}),v.command("server").description("启动一个本地HTTP服务器").option("-p, --port <number>","端口号","8080").option("-h, --host <host>","主机地址","localhost").option("-d, --directory <path>","服务的目录",".").option("-o, --open","启动后自动打开浏览器").option("-s, --silent","静默模式,不输出信息").option("--header <json>","启动服务设置的HTTP相应头","{}").action(e=>{w({...e,port:parseInt(e.port,10),openBrowser:!!e.open,silent:!!e.silent,header:JSON.parse(e.header)})});const{simpleGit:P}=require("simple-git"),S=P();v.command("git-rename <old-model-url> <new-model-url>").description("git重命名模块").action(async(e,t)=>{await S.mv(e,`__${t}`),await S.mv(`__${t}`,t)}),exports.start=function(){v.parse(process.argv)};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@tanyueran/cli",
3
- "version": "0.3.0",
3
+ "version": "0.4.0",
4
4
  "description": "一个cli工具,支持创建项目,添加模版",
5
5
  "main": "./src/index.ts",
6
6
  "bin": {