@tomjs/create-app 0.2.2 → 0.2.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.mjs CHANGED
@@ -1,7 +1,7 @@
1
1
  #!/usr/bin/env node
2
- import a from"fs";import Z from"os";import l from"path";import{fileURLToPath as ee}from"url";import{blue as v,cyan as te,green as ne,red as U,reset as d,yellow as j}from"kolorist";import{camelCase as re}from"lodash-es";import oe from"minimist";import ie from"prompts";import w from"shelljs";import p from"fs";import E from"path";function M(e){return[["t","template"]].forEach(([t,r])=>{e[r]=e[r]??e[t]}),e}function V(e){let t=p.readdirSync(e);return t.length===0||t.length===1&&t[0]===".git"}function x(e){return e?.trim().replace(/\/+$/g,"")}function Y(e,t){p.mkdirSync(t,{recursive:!0});for(let r of p.readdirSync(e)){let f=E.resolve(e,r),h=E.resolve(t,r);F(f,h)}}function F(e,t){p.statSync(e).isDirectory()?Y(e,t):p.copyFileSync(e,t)}function z(e){if(p.existsSync(e))for(let t of p.readdirSync(e))t!==".git"&&p.rmSync(E.resolve(e,t),{recursive:!0,force:!0})}function N(e){return/^(?:@[a-z\d\-*~][a-z\d\-*._~]*\/)?[a-z\d\-~][a-z\d\-._~]*$/.test(e)}function W(e){return e.trim().toLowerCase().replace(/\s+/g,"-").replace(/^[._]/,"").replace(/[^a-z\d\-~]+/g,"-")}function I(e){if(!e)return;let r=e.split(" ")[0].split("/");return{name:r[0],version:r[1]}}var $=M(oe(process.argv.slice(2),{string:["_"]})),R=process.cwd(),B=[{name:"vue",display:"Vue",color:ne,variants:[{name:"vue",display:"Web",color:v},{name:"electron-vue",display:"Electron",color:j}]},{name:"react",display:"React",color:te,variants:[{name:"react",display:"Web",color:v},{name:"electron-react",display:"Electron",color:j}]},{name:"node",display:"Node",color:v,publish:!0,variants:[{name:"node",display:"Base",color:v},{name:"node-electron",display:"Electron",color:j}]}],L=B.map(e=>e.variants&&e.variants.map(t=>t.name)||[e.name]).reduce((e,t)=>e.concat(t),[]),ae={_gitignore:".gitignore","_lintstagedrc.cjs":".lintstagedrc.cjs"},P="my-app";function J(e){let t=w.exec(`git config --get ${e}`,{silent:!0});if(t.code===0)return t.stdout.trim()}async function se(){let e=x($._[0]),t=$.template||$.t,r=e||P,f=()=>r==="."?l.basename(l.resolve()):r,h={};h=await ie([{type:e?null:"text",name:"projectName",message:d("Project name:"),initial:P,onState:n=>{r=x(n.value)||P}},{type:()=>!a.existsSync(r)||V(r)?null:"toggle",name:"overwrite",message:()=>(r==="."?"Current directory":`Target directory "${r}"`)+" is not empty. Remove existing files and continue?",initial:!1,active:"yes",inactive:"no"},{type:(n,{overwrite:o})=>{if(o===!1)throw console.log(U("\u2716")+" Operation cancelled"),new Error;return null},name:"overwriteChecker"},{type:()=>N(f())?null:"text",name:"packageName",message:d("Package name:"),initial:()=>W(f()),validate:n=>N(n)||"Invalid package.json name"},{type:t&&L.includes(t)?null:"select",name:"framework",message:typeof t=="string"&&!L.includes(t)?d(`"${t}" isn't a valid template. Please choose from below: `):d("Select a framework:"),initial:0,choices:B.map(n=>{let o=n.color;return{title:o(n.display||n.name),value:n}})},{type:n=>n&&n.variants?"select":null,name:"variant",message:d("Select a variant:"),choices:n=>n?.variants?.map(o=>{let i=o.color;return{title:i(o.display||o.name),value:o.name}})},{type:(n,o)=>{let{variant:i,framework:u}=o,{publish:y,variants:X}=u||{};if(!(!y&&!X?.find(O=>O.name===i&&O.publish)))return"toggle"},name:"publish",message:d("Whether to publish to the npm repository?"),initial:!0,active:"yes",inactive:"no"}],{onCancel:()=>{throw console.log(U("\u2716")+" Operation cancelled"),new Error}});let{framework:G,overwrite:K,packageName:q,variant:H,publish:C}=h,s=l.join(R,r.substring(r.indexOf("/")+1));K?z(s):a.existsSync(s)||a.mkdirSync(s,{recursive:!0}),console.log(`
3
- Scaffolding project in ${s}...`);let k=H||G?.name||t||"",D=n=>l.join(ee(import.meta.url),"../..",`template-${n}`),A=D(k),_=k.includes("node");[A,D("config")].forEach(n=>{let o=a.readdirSync(n);for(let i of o){let u=ae[i]??i;if(_&&i.includes("stylelint"))continue;let y=l.join(s,u);F(l.join(n,i),y)}});let Q=`template-${k}`,c=JSON.parse(a.readFileSync(l.join(A,"package.json"),"utf-8")),m=q||f();c.name=m;let g={name:"UserName",email:"name@github.com"};if(C){w.which("git")&&(g.name=J("user.name")||Z.userInfo().username,g.email=J("user.email")||"",c.author=Object.assign(c.author,g));let n=m.startsWith("@")?m.split("/")[0].substring(1):re(g.name);c.repository.url=`git+https://github.com/${n}/${m.substring(m.indexOf("/")+1)}.git`}else delete c.author,delete c.publishConfig,delete c.repository,delete c.scripts.prepublishOnly,delete c.devDependencies.np;a.writeFileSync(l.join(s,"package.json"),JSON.stringify(c,null,2)+`
4
- `),_&&["LICENSE","README.md","README.zh_CN.md"].forEach(n=>{let o=l.join(s,n);if(!C&&a.existsSync(o)){a.rmSync(o),n==="README.md"&&a.writeFileSync(o,`# ${m}
5
- `,{encoding:"utf-8"});return}if(!a.existsSync(o))return;let i=a.readFileSync(o,"utf-8").replace(new RegExp(Q,"g"),m).replace(new RegExp("{{user.name}}","g"),g.name).replace(new RegExp("{{user.email}}","g"),g.email);if(n.startsWith("README")){let u=m.replace("@","%40"),y=m.replace("@","%40").replace(new RegExp("/","g"),"%2F");i=i.replace("{{badges}}",[`![npm](https://img.shields.io/npm/v/${u})`,`![node-current (scoped)](https://img.shields.io/node/v/${u})`,`![NPM](https://img.shields.io/npm/l/${y})`].join(" "))}a.writeFileSync(o,i)});let T=I(process.env.npm_config_user_agent),b=T?T.name:"npm";w.which("git")&&w.exec(`cd ${s} && git init`);let S=l.relative(R,s);switch(console.log(`
2
+ import s,{rmSync as re}from"fs";import oe from"os";import l from"path";import{fileURLToPath as ie}from"url";import se from"json5";import{blue as S,cyan as ae,green as ce,red as B,reset as d,yellow as $}from"kolorist";import{camelCase as le}from"lodash-es";import me from"minimist";import pe from"prompts";import w from"shelljs";import g from"fs";import F from"path";function I(e){return[["t","template"]].forEach(([t,o])=>{e[o]=e[o]??e[t]}),e}function J(e){let t=g.readdirSync(e);return t.length===0||t.length===1&&t[0]===".git"}function P(e){return e?.trim().replace(/\/+$/g,"")}function ne(e,t){g.mkdirSync(t,{recursive:!0});for(let o of g.readdirSync(e)){let u=F.resolve(e,o),f=F.resolve(t,o);b(u,f)}}function b(e,t){g.statSync(e).isDirectory()?ne(e,t):g.copyFileSync(e,t)}function U(e){if(g.existsSync(e))for(let t of g.readdirSync(e))t!==".git"&&g.rmSync(F.resolve(e,t),{recursive:!0,force:!0})}function N(e){return/^(?:@[a-z\d\-*~][a-z\d\-*._~]*\/)?[a-z\d\-~][a-z\d\-._~]*$/.test(e)}function V(e){return e.trim().toLowerCase().replace(/\s+/g,"-").replace(/^[._]/,"").replace(/[^a-z\d\-~]+/g,"-")}function L(e){if(!e)return;let o=e.split(" ")[0].split("/");return{name:o[0],version:o[1]}}function R(e,t){let{variant:o,framework:u}=e,f=u;return f[t]||!!f?.variants?.find(v=>v.name===o&&v[t])}var D=I(me(process.argv.slice(2),{string:["_"]})),A=process.cwd(),q=[{name:"vue",display:"Vue",color:ce,variants:[{name:"vue",display:"Web",color:S},{name:"electron-vue",display:"Electron",color:$}]},{name:"react",display:"React",color:ae,variants:[{name:"react",display:"Web",color:S},{name:"electron-react",display:"Electron",color:$}]},{name:"node",display:"Node",color:S,publish:!0,test:!0,variants:[{name:"node",display:"Base",color:S},{name:"node-electron",display:"Electron",color:$}]}],G=q.map(e=>e.variants&&e.variants.map(t=>t.name)||[e.name]).reduce((e,t)=>e.concat(t),[]),ge={_gitignore:".gitignore","_lintstagedrc.cjs":".lintstagedrc.cjs"},T="my-app";function K(e){let t=w.exec(`git config --get ${e}`,{silent:!0});if(t.code===0)return t.stdout.trim()}async function ue(){let e=P(D._[0]),t=D.template||D.t,o=e||T,u=()=>o==="."?l.basename(l.resolve()):o,f={};f=await pe([{type:e?null:"text",name:"projectName",message:d("Project name:"),initial:T,onState:n=>{o=P(n.value)||T}},{type:()=>!s.existsSync(o)||J(o)?null:"toggle",name:"overwrite",message:()=>(o==="."?"Current directory":`Target directory "${o}"`)+" is not empty. Remove existing files and continue?",initial:!1,active:"yes",inactive:"no"},{type:(n,{overwrite:r})=>{if(r===!1)throw console.log(B("\u2716")+" Operation cancelled"),new Error;return null},name:"overwriteChecker"},{type:()=>N(u())?null:"text",name:"packageName",message:d("Package name:"),initial:()=>V(u()),validate:n=>N(n)||"Invalid package.json name"},{type:t&&G.includes(t)?null:"select",name:"framework",message:typeof t=="string"&&!G.includes(t)?d(`"${t}" isn't a valid template. Please choose from below: `):d("Select a framework:"),initial:0,choices:q.map(n=>{let r=n.color;return{title:r(n.display||n.name),value:n}})},{type:n=>n&&n.variants?"select":null,name:"variant",message:d("Select a variant:"),choices:n=>n?.variants?.map(r=>{let i=r.color;return{title:i(r.display||r.name),value:r.name}})},{type:(n,r)=>R(r,"publish")?"toggle":null,name:"needPublish",message:d("Whether to publish to the npm repository?"),initial:!0,active:"yes",inactive:"no"},{type:(n,r)=>R(r,"test")?"toggle":null,name:"needTest",message:d("Whether to add Test?"),initial:!0,active:"yes",inactive:"no"}],{onCancel:()=>{throw console.log(B("\u2716")+" Operation cancelled"),new Error}});let{framework:v,overwrite:H,packageName:Q,variant:X,needPublish:_,needTest:O}=f,a=l.join(A,o.substring(o.indexOf("/")+1));H?U(a):s.existsSync(a)||s.mkdirSync(a,{recursive:!0}),console.log(`
3
+ Scaffolding project in ${a}...`);let k=X||v?.name||t||"",C=n=>l.join(ie(import.meta.url),"../..",`template-${n}`),M=C(k),W=k.includes("node");[M,C("config")].forEach(n=>{let r=s.readdirSync(n);for(let i of r){let h=ge[i]??i;if(W&&i.includes("stylelint"))continue;let p=l.join(a,h);b(l.join(n,i),p)}});let Y=`template-${k}`,c=JSON.parse(s.readFileSync(l.join(M,"package.json"),"utf-8")),m=Q||u();c.name=m;let y={name:"UserName",email:"name@github.com"};ee(),W&&Z();let z=L(process.env.npm_config_user_agent),E=z?z.name:"npm";w.which("git")&&w.exec(`cd ${a} && git init`);let x=l.relative(A,a);switch(console.log(`
6
4
  Done. Now run:
7
- `),s!==R&&console.log(` cd ${S.includes(" ")?`"${S}"`:S}`),b){case"yarn":console.log(" yarn"),console.log(" yarn dev");break;default:console.log(` ${b} install`),console.log(` ${b} run dev`);break}}se().catch(e=>{e.message&&console.error(e)});
5
+ `),a!==A&&console.log(` cd ${x.includes(" ")?`"${x}"`:x}`),E){case"yarn":console.log(" yarn"),console.log(" yarn dev");break;default:console.log(` ${E} install`),console.log(` ${E} run dev`);break}function Z(){["LICENSE","README.md","README.zh_CN.md"].forEach(n=>{let r=l.join(a,n);if(!_&&s.existsSync(r)){s.rmSync(r),n==="README.md"&&s.writeFileSync(r,`# ${m}
6
+ `,{encoding:"utf-8"});return}if(!s.existsSync(r))return;let i=s.readFileSync(r,"utf-8").replace(new RegExp(Y,"g"),m).replace(new RegExp("{{user.name}}","g"),y.name).replace(new RegExp("{{user.email}}","g"),y.email);if(n.startsWith("README")){let h=m.replace("@","%40"),p=m.replace("@","%40").replace(new RegExp("/","g"),"%2F");i=i.replace("{{badges}}",[`![npm](https://img.shields.io/npm/v/${h})`,`![node-current (scoped)](https://img.shields.io/node/v/${h})`,`![NPM](https://img.shields.io/npm/l/${p})`].join(" "))}s.writeFileSync(r,i)}),O||s.readdirSync(a).filter(r=>/tsconfig(\.\w+)?\.json/.test(r)).forEach(r=>{let i=l.join(a,r);if(s.existsSync(i)){let h=s.readFileSync(i,"utf-8"),p=se.parse(h);["include","exclude"].forEach(j=>{p[j]&&(p[j]=p[j].filter(te=>!te.includes("test")))}),s.writeFileSync(i,JSON.stringify(p,null,2))}})}function ee(){if(_){w.which("git")&&(y.name=K("user.name")||oe.userInfo().username,y.email=K("user.email")||"",c.author=Object.assign(c.author,y));let n=m.startsWith("@")?m.split("/")[0].substring(1):le(y.name);c.repository.url=`git+https://github.com/${n}/${m.substring(m.indexOf("/")+1)}.git`}else delete c.author,delete c.publishConfig,delete c.repository,delete c.scripts.prepublishOnly,delete c.devDependencies.np;if(!O){delete c.scripts.test,["jest.config.js","test"].forEach(r=>{let i=l.join(a,r);s.existsSync(i)&&re(i,{force:!0,recursive:!0})});let n=Object.keys(c.devDependencies||{});Array.isArray(n)&&n.forEach(r=>{r.includes("jest")&&delete c.devDependencies[r]})}s.writeFileSync(l.join(a,"package.json"),JSON.stringify(c,null,2)+`
7
+ `)}}ue().catch(e=>{e.message&&console.error(e)});
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@tomjs/create-app",
3
- "version": "0.2.2",
3
+ "version": "0.2.4",
4
4
  "description": "create tomjs web app",
5
5
  "keywords": [
6
6
  "tomjs",
@@ -42,16 +42,8 @@
42
42
  "engines": {
43
43
  "node": ">=18"
44
44
  },
45
- "scripts": {
46
- "dev": "tsup --watch",
47
- "build": "tsup --minify",
48
- "lint": "run-s lint:eslint lint:prettier",
49
- "lint:eslint": "eslint \"src/**/*.{js,cjs,ts}\" *.{js,cjs,ts} --fix --cache",
50
- "lint:prettier": "prettier --write \"src/**/*.{js,cjs,ts,json,md}\" *.{js,cjs,ts,json,md}",
51
- "prepare": "husky install",
52
- "prepublishOnly": "npm run build && np --any-branch --no-yarn --yolo --no-publish --message \"chore: release v%s\""
53
- },
54
45
  "dependencies": {
46
+ "json5": "^2.2.3",
55
47
  "kolorist": "^1.8.0",
56
48
  "lodash-es": "^4.17.21",
57
49
  "minimist": "^1.2.8",
@@ -77,5 +69,12 @@
77
69
  "prettier": "^3.1.0",
78
70
  "tsup": "^8.0.1",
79
71
  "typescript": "~5.2.2"
72
+ },
73
+ "scripts": {
74
+ "dev": "tsup --watch",
75
+ "build": "tsup --minify",
76
+ "lint": "run-s lint:eslint lint:prettier",
77
+ "lint:eslint": "eslint \"src/**/*.{js,cjs,ts}\" *.{js,cjs,ts} --fix --cache",
78
+ "lint:prettier": "prettier --write \"src/**/*.{js,cjs,ts,json,md}\" *.{js,cjs,ts,json,md}"
80
79
  }
81
- }
80
+ }
@@ -5,5 +5,5 @@
5
5
  "src/**/*.d.ts",
6
6
  "test/**/*.ts",
7
7
  "test/**/*.d.ts"
8
- ],
8
+ ]
9
9
  }
@@ -5,5 +5,5 @@
5
5
  "src/**/*.d.ts",
6
6
  "test/**/*.ts",
7
7
  "test/**/*.d.ts"
8
- ],
8
+ ]
9
9
  }