wbfy 1.9.0 → 1.10.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.
@@ -1,6 +1,6 @@
1
- var mt=Object.create;var I=Object.defineProperty;var ft=Object.getOwnPropertyDescriptor;var ut=Object.getOwnPropertyNames,ge=Object.getOwnPropertySymbols,dt=Object.getPrototypeOf,he=Object.prototype.hasOwnProperty,gt=Object.prototype.propertyIsEnumerable;var ye=(e,i,t)=>i in e?I(e,i,{enumerable:!0,configurable:!0,writable:!0,value:t}):e[i]=t,O=(e,i)=>{for(var t in i||(i={}))he.call(i,t)&&ye(e,t,i[t]);if(ge)for(var t of ge(i))gt.call(i,t)&&ye(e,t,i[t]);return e};var yt=e=>I(e,"__esModule",{value:!0});var ht=(e,i,t,o)=>{if(i&&typeof i=="object"||typeof i=="function")for(let r of ut(i))!he.call(e,r)&&(t||r!=="default")&&I(e,r,{get:()=>i[r],enumerable:!(o=ft(i,r))||o.enumerable});return e},l=(e,i)=>ht(yt(I(e!=null?mt(dt(e)):{},"default",!i&&e&&e.__esModule?{get:()=>e.default,enumerable:!0}:{value:e,enumerable:!0})),e);var lt=l(require("path")),pt=l(require("glob")),ct=l(require("yargs"));var N=l(require("fs")),q=l(require("path"));var ve=require("minimal-promise-pool"),p=new ve.PromisePool;async function Pe(e){if(!e.versionsText)return;let i=[];for(let o of e.versionsText.split(`
2
- `)){let r=o.trim();if(!r.startsWith("nodejs")){i.push(r);continue}let[,n]=r.split(/\s+/);await p.run(()=>N.default.promises.writeFile(q.default.resolve(e.dirPath,".node-version"),n))}let t=q.default.resolve(e.dirPath,".tool-versions");i.length?await p.run(()=>N.default.promises.writeFile(t,i.join(`
3
- `))):await p.run(()=>N.default.promises.rm(t,{force:!0}))}var we=l(require("path"));var g={codeWith2IndentSize:["cjs","mjs","js","jsx","ts","tsx","json","json5","cpp","dart","htm","html","pu","puml","rb","vue","yaml","yml"].sort(),codeWith4IndentSize:["go","gradle","py"].sort(),codeWith8IndentSize:["sh"].sort(),markdownLike:["md"].sort(),eslint:["cjs","mjs","js","ts","tsx","jsx"].sort(),prettier:["cjs","mjs","js","jsx","ts","tsx","json","json5","css","htm","html","md","scss","vue","yaml","yml"].sort()};var ke=l(require("fs/promises")),f={async generateFile(e,i){await ke.default.writeFile(e,i),console.log(`Generated ${e}`)}};var vt=`root = true
1
+ var mt=Object.create;var I=Object.defineProperty;var ut=Object.getOwnPropertyDescriptor;var ft=Object.getOwnPropertyNames,ge=Object.getOwnPropertySymbols,dt=Object.getPrototypeOf,he=Object.prototype.hasOwnProperty,gt=Object.prototype.propertyIsEnumerable;var ye=(e,n,t)=>n in e?I(e,n,{enumerable:!0,configurable:!0,writable:!0,value:t}):e[n]=t,C=(e,n)=>{for(var t in n||(n={}))he.call(n,t)&&ye(e,t,n[t]);if(ge)for(var t of ge(n))gt.call(n,t)&&ye(e,t,n[t]);return e};var yt=e=>I(e,"__esModule",{value:!0});var ht=(e,n,t,o)=>{if(n&&typeof n=="object"||typeof n=="function")for(let r of ft(n))!he.call(e,r)&&(t||r!=="default")&&I(e,r,{get:()=>n[r],enumerable:!(o=ut(n,r))||o.enumerable});return e},l=(e,n)=>ht(yt(I(e!=null?mt(dt(e)):{},"default",!n&&e&&e.__esModule?{get:()=>e.default,enumerable:!0}:{value:e,enumerable:!0})),e);var lt=l(require("path")),pt=l(require("glob")),ct=l(require("yargs"));var N=l(require("fs")),q=l(require("path"));var ve=require("minimal-promise-pool"),p=new ve.PromisePool;async function Pe(e){if(!e.versionsText)return;let n=[];for(let o of e.versionsText.split(`
2
+ `)){let r=o.trim();if(!r.startsWith("nodejs")){n.push(r);continue}let[,i]=r.split(/\s+/);await p.run(()=>N.default.promises.writeFile(q.default.resolve(e.dirPath,".node-version"),i))}let t=q.default.resolve(e.dirPath,".tool-versions");n.length?await p.run(()=>N.default.promises.writeFile(t,n.join(`
3
+ `))):await p.run(()=>N.default.promises.rm(t,{force:!0}))}var we=l(require("path"));var g={codeWith2IndentSize:["cjs","mjs","js","jsx","ts","tsx","json","json5","cpp","dart","htm","html","pu","puml","rb","vue","yaml","yml"].sort(),codeWith4IndentSize:["go","gradle","py"].sort(),codeWith8IndentSize:["sh"].sort(),markdownLike:["md"].sort(),eslint:["cjs","mjs","js","ts","tsx","jsx"].sort(),prettier:["cjs","mjs","js","jsx","ts","tsx","json","json5","css","htm","html","md","scss","vue","yaml","yml"].sort()};var ke=l(require("fs/promises")),u={async generateFile(e,n){await ke.default.writeFile(e,n),console.log(`Generated ${e}`)}};var vt=`root = true
4
4
 
5
5
  [*]
6
6
  charset = utf-8
@@ -26,10 +26,10 @@ trim_trailing_whitespace = false
26
26
 
27
27
  [{Makefile,*.mk}]
28
28
  indent_style = tab
29
- `;async function be(e){let i=we.default.resolve(e.dirPath,".editorconfig");await p.run(()=>f.generateFile(i,vt))}function W(e){return e.length>1?`[*.{${e.join(",")}}]`:`[*.${e[0]}]`}var V=l(require("path"));var C=l(require("fs")),y={header:"# Project-specific settings",separator:"# Generated by @willbooster/willboosterify",separatorPrefix:"# Generated by @willbooster",getExistingContent(e){return C.default.existsSync(e)?C.default.readFileSync(e).toString().replace(/# Project-specific settings[^\n]*\n/m,"").replace(/# Generated by[^\n]*\n/m,"").replace(/\r?\n\r?\n(\r?\n)+/gm,`
29
+ `;async function be(e){let n=we.default.resolve(e.dirPath,".editorconfig");await p.run(()=>u.generateFile(n,vt))}function W(e){return e.length>1?`[*.{${e.join(",")}}]`:`[*.${e[0]}]`}var V=l(require("path"));var F=l(require("fs")),y={header:"# Project-specific settings",separator:"# Generated by @willbooster/willboosterify",separatorPrefix:"# Generated by @willbooster",getExistingContent(e){return F.default.existsSync(e)?F.default.readFileSync(e).toString().replace(/# Project-specific settings[^\n]*\n/m,"").replace(/# Generated by[^\n]*\n/m,"").replace(/\r?\n\r?\n(\r?\n)+/gm,`
30
30
 
31
- `):null},getUserContent(e){if(C.default.existsSync(e)){let i=C.default.readFileSync(e,"utf-8"),t=i.indexOf(this.separatorPrefix);if(t>=0)return i.substr(0,i.indexOf(`
32
- `,t)+1)}return null},isBerryZeroInstallEnabled(e){return C.default.existsSync(e)?C.default.readFileSync(e,"utf-8").includes(`
31
+ `):null},getUserContent(e){if(F.default.existsSync(e)){let n=F.default.readFileSync(e,"utf-8"),t=n.indexOf(this.separatorPrefix);if(t>=0)return n.substr(0,n.indexOf(`
32
+ `,t)+1)}return null},isBerryZeroInstallEnabled(e){return F.default.existsSync(e)?F.default.readFileSync(e,"utf-8").includes(`
33
33
  !.yarn/cache`):!1}};var Pt=`${y.header}
34
34
 
35
35
 
@@ -47,13 +47,13 @@ test-fixtures/
47
47
  *.min.js
48
48
  .yarn/
49
49
  .pnp.js
50
- `;async function xe(e){let i=V.default.resolve(e.dirPath,".eslintignore"),t=y.getUserContent(i)||Pt,o=V.default.resolve(e.dirPath,".gitignore"),r=y.getExistingContent(o)||"",n=t+kt+r;await p.run(()=>f.generateFile(i,n))}var je=l(require("fs")),Ce=l(require("path")),Fe=l(require("deepmerge"));var Se=l(require("deepmerge"));function M(e,i){return i}function U(e,i,t){let o=e.slice();return i.forEach((r,n)=>{typeof o[n]>"u"?o[n]=t.cloneUnlessOtherwiseSpecified(r,t):t.isMergeableObject(r)?o[n]=(0,Se.default)(e[n],r,t):e.indexOf(r)===-1&&o.push(r)}),o}async function $e(e,i){let t=[];e.eslintBase&&t.push(e.eslintBase),e!==i&&t.push("../../.eslintrc.json");let o={root:!0,extends:t},r=Ce.default.resolve(e.dirPath,".eslintrc.json");try{let c=await je.default.promises.readFile(r,"utf-8"),a=JSON.parse(c);a.extends&&(a.extends=a.extends.filter(s=>!s.startsWith("@willbooster/")&&s!=="../../.eslintrc.json")),t.length||(a.extends=[]);let m=o.extends;o.extends=a.extends,a.extends=m,o=Fe.default.all([o,a,o],{arrayMerge:U}),e.depending.blitz&&(o.extends=[...o.extends.filter(s=>s!=="blitz"),"blitz"])}catch{}let n=JSON.stringify(o);await p.run(()=>f.generateFile(r,n))}var _e=l(require("path"));var wt=`* text=auto
50
+ `;async function xe(e){let n=V.default.resolve(e.dirPath,".eslintignore"),t=y.getUserContent(n)||Pt,o=V.default.resolve(e.dirPath,".gitignore"),r=y.getExistingContent(o)||"",i=t+kt+r;await p.run(()=>u.generateFile(n,i))}var je=l(require("fs")),Ce=l(require("path")),Fe=l(require("deepmerge"));var Se=l(require("deepmerge"));function B(e,n){return n}function M(e,n,t){let o=e.slice();return n.forEach((r,i)=>{typeof o[i]>"u"?o[i]=t.cloneUnlessOtherwiseSpecified(r,t):t.isMergeableObject(r)?o[i]=(0,Se.default)(e[i],r,t):e.indexOf(r)===-1&&o.push(r)}),o}async function $e(e,n){let t=[];e.eslintBase&&t.push(e.eslintBase),e!==n&&t.push("../../.eslintrc.json");let o={root:!0,extends:t},r=Ce.default.resolve(e.dirPath,".eslintrc.json");try{let c=await je.default.promises.readFile(r,"utf-8"),a=JSON.parse(c);a.extends&&(a.extends=a.extends.filter(s=>!s.startsWith("@willbooster/")&&s!=="../../.eslintrc.json")),t.length||(a.extends=[]);let m=o.extends;o.extends=a.extends,a.extends=m,o=Fe.default.all([o,a,o],{arrayMerge:M}),e.depending.blitz&&(o.extends=[...o.extends.filter(s=>s!=="blitz"),"blitz"])}catch{}let i=JSON.stringify(o);await p.run(()=>u.generateFile(r,i))}var _e=l(require("path"));var wt=`* text=auto
51
51
 
52
52
  *.vcproj text eol=crlf
53
53
 
54
54
  ${g.codeWith2IndentSize.concat(g.codeWith4IndentSize).concat(g.markdownLike).map(e=>`*.${e} text eol=lf`).join(`
55
55
  `)}
56
- `;async function Te(e){let i=_e.default.resolve(e.dirPath,".gitattributes");await p.run(()=>f.generateFile(i,wt))}var X=l(require("path"));async function z(e,i){let{default:t}=await import("node-fetch");return t(e,i)}var bt=["windows","macos","linux","jetbrains","visualstudiocode","emacs","vim","yarn"],xt=`${y.header}
56
+ `;async function Te(e){let n=_e.default.resolve(e.dirPath,".gitattributes");await p.run(()=>u.generateFile(n,wt))}var X=l(require("path"));async function z(e,n){let{default:t}=await import("node-fetch");return t(e,n)}var bt=["windows","macos","linux","jetbrains","visualstudiocode","emacs","vim","yarn"],xt=`${y.header}
57
57
 
58
58
 
59
59
  ${y.separator}
@@ -62,7 +62,7 @@ ${y.separator}
62
62
  dist/
63
63
  temp/
64
64
  Icon[\r]
65
- `;async function Re(e,i){let t=X.default.resolve(e.dirPath,".gitignore"),o=(y.getUserContent(t)||xt)+St,r=[...bt];e.containingGemfile&&r.push("ruby"),e.containingGoMod&&(r.push("go"),o+=`${X.default.basename(e.dirPath)}
65
+ `;async function Re(e,n){let t=X.default.resolve(e.dirPath,".gitignore"),o=(y.getUserContent(t)||xt)+St,r=[...bt];e.containingGemfile&&r.push("ruby"),e.containingGoMod&&(r.push("go"),o+=`${X.default.basename(e.dirPath)}
66
66
  `),e.containingPackageJson&&r.push("node"),e.containingPomXml&&(r.push("maven"),o+=`.idea/google-java-format.xml
67
67
  `),e.containingPubspecYaml&&(r.push("flutter","AndroidStudio","ruby"),o+=`.flutter-plugins-dependencies
68
68
  android/key.properties
@@ -70,10 +70,10 @@ ios/.bundle
70
70
  .idea/runConfigurations.xml
71
71
  `),e.containingTemplateYaml&&(o+=`.aws-sam/
72
72
  packaged.yaml
73
- `),e.containingPoetryLock&&r.push("python"),(i.depending.firebase||e.depending.firebase)&&r.push("firebase"),(i.depending.reactNative||e.depending.reactNative)&&(r.push("reactnative"),o+=`google-services.json
73
+ `),e.containingPoetryLock&&r.push("python"),(n.depending.firebase||e.depending.firebase)&&r.push("firebase"),(n.depending.reactNative||e.depending.reactNative)&&(r.push("reactnative"),o+=`google-services.json
74
74
  android/app/src/main/assets/
75
- `),i.depending.storybook&&r.push("storybookjs");let n=(await Promise.all(r.map(async a=>await(await z(`https://www.toptal.com/developers/gitignore/api/${a}`)).text()))).join("");y.isBerryZeroInstallEnabled(t)||(n=n.replace("!.yarn/cache","# !.yarn/cache").replace("# .pnp.*",".pnp.*")),(e.containingPomXml||e.containingPubspecYaml)&&(n=n.replace(/^# .idea\/artifacts$/gm,".idea/artifacts").replace(/^# .idea\/compiler.xml$/gm,".idea/compiler.xml").replace(/^# .idea\/jarRepositories.xml$/gm,".idea/jarRepositories.xml").replace(/^# .idea\/modules.xml$/gm,".idea/modules.xml").replace(/^# .idea\/*.iml$/gm,".idea/*.iml").replace(/^# .idea\/modules$/gm,".idea/modules").replace(/^# *.iml$/gm,"*.iml").replace(/^# *.ipr$/gm,"*.ipr"),e.containingPubspecYaml&&(n=n.replace(/^.idea\/modules.xml$/gm,"# .idea/modules.xml"))),n=n.replace(/^.idea\/?$/gm,"# .idea"),(i.depending.reactNative||e.depending.reactNative||e.containingPubspecYaml)&&(n=n.replace(/^(.idea\/.+)$/gm,`$1
76
- android/$1`));let c=o+n;await p.run(()=>f.generateFile(t,c))}var b=l(require("fs")),F=l(require("path"));var Z=l(require("child_process"));function h(e,i,t,o=0){do{let[r,n]=Oe(e,i,t);if(console.log(`$ ${r} at ${n.cwd}`),Z.default.spawnSync(r,n).status===0)break}while(--o>=0)}function Q(e,i,t){let[o,r]=Oe(e,i,t);return r.stdio="pipe",Z.default.spawnSync(o,r).stdout.toString().trim()}function Oe(e,i,t){let o=`${e} ${i.join(" ")}`;return process.env.ASDF_DIR&&(o=`bash -l -c '. ${process.env.ASDF_DIR}/asdf.sh && ${o}'`),[o,{cwd:t,env:{PATH:process.env.PATH},shell:!0,stdio:"inherit"}]}var ee="npm test",te={preCommit:"yarn lint-staged",prePush:"yarn typecheck",postMerge:"yarn"};async function Je(e){var s,u;let i=F.default.resolve(e.dirPath,"package.json"),t=await b.default.promises.readFile(i,"utf-8"),o=JSON.parse(t);o.scripts||(o.scripts={}),delete o.scripts.postinstall,delete o.scripts.postpublish,delete o.scripts.prepare,delete o.scripts.prepublishOnly,delete o.scripts.prepack,delete o.scripts.postpack;let r=F.default.resolve(e.dirPath,".husky");await Promise.all([b.default.promises.writeFile(i,JSON.stringify(o,void 0,2)),b.default.promises.rm(r,{force:!0,recursive:!0})]),h("yarn",["dlx","husky-init","--yarn2"],e.dirPath);let n=F.default.resolve(r,"pre-commit"),c=await b.default.promises.readFile(n,"utf-8");await p.run(()=>b.default.promises.rm(F.default.resolve(e.dirPath,".huskyrc.json"),{force:!0})),await p.run(()=>b.default.promises.writeFile(n,c.replace(ee,te.preCommit))),(e.containingTypeScript||e.containingTypeScriptInPackages)&&await p.run(()=>b.default.promises.writeFile(F.default.resolve(r,"pre-push"),c.replace(ee,te.prePush),{mode:493}));let a=[];((s=e.versionsText)==null?void 0:s.includes("python "))&&a.push("asdf install python"),e.versionsText&&a.push("asdf install"),a.push(te.postMerge),((u=e.versionsText)==null?void 0:u.includes("poetry "))&&a.push("poetry install"),e.depending.blitz?a.push("yarn blitz codegen"):e.depending.prisma&&a.push("yarn prisma generate");let m=c.replace(ee,a.join(" && "));await p.run(()=>b.default.promises.writeFile(F.default.resolve(r,"post-merge"),m,{mode:493}))}var ne=l(require("fs")),ie=l(require("path"));var jt=`<?xml version="1.0" encoding="UTF-8"?>
75
+ `),n.depending.storybook&&r.push("storybookjs"),n.depending.blitz&&r.push("nextjs");let i=(await Promise.all(r.map(async a=>await(await z(`https://www.toptal.com/developers/gitignore/api/${a}`)).text()))).join("");y.isBerryZeroInstallEnabled(t)||(i=i.replace("!.yarn/cache","# !.yarn/cache").replace("# .pnp.*",".pnp.*")),(e.containingPomXml||e.containingPubspecYaml)&&(i=i.replace(/^# .idea\/artifacts$/gm,".idea/artifacts").replace(/^# .idea\/compiler.xml$/gm,".idea/compiler.xml").replace(/^# .idea\/jarRepositories.xml$/gm,".idea/jarRepositories.xml").replace(/^# .idea\/modules.xml$/gm,".idea/modules.xml").replace(/^# .idea\/*.iml$/gm,".idea/*.iml").replace(/^# .idea\/modules$/gm,".idea/modules").replace(/^# *.iml$/gm,"*.iml").replace(/^# *.ipr$/gm,"*.ipr"),e.containingPubspecYaml&&(i=i.replace(/^.idea\/modules.xml$/gm,"# .idea/modules.xml"))),i=i.replace(/^.idea\/?$/gm,"# .idea"),(n.depending.reactNative||e.depending.reactNative||e.containingPubspecYaml)&&(i=i.replace(/^(.idea\/.+)$/gm,`$1
76
+ android/$1`));let c=o+i;await p.run(()=>u.generateFile(t,c))}var b=l(require("fs")),$=l(require("path"));var Z=l(require("child_process"));function h(e,n,t,o=0){do{let[r,i]=Oe(e,n,t);if(console.log(`$ ${r} at ${i.cwd}`),Z.default.spawnSync(r,i).status===0)break}while(--o>=0)}function Q(e,n,t){let[o,r]=Oe(e,n,t);return r.stdio="pipe",Z.default.spawnSync(o,r).stdout.toString().trim()}function Oe(e,n,t){let o=C({},process.env);o.PATH&&o.BERRY_BIN_FOLDER&&(o.PATH=o.PATH.replace(`${o.BERRY_BIN_FOLDER}:`,""));let r=`${e} ${n.join(" ")}`;return o.ASDF_DIR&&(r=`bash -l -c '. ${o.ASDF_DIR}/asdf.sh && ${r}'`),[r,{cwd:t,env:o,shell:!0,stdio:"inherit"}]}var ee="npm test",te={preCommit:"yarn lint-staged",prePush:"yarn typecheck",postMerge:"yarn"};async function Ee(e){var s,f;let n=$.default.resolve(e.dirPath,"package.json"),t=await b.default.promises.readFile(n,"utf-8"),o=JSON.parse(t);o.scripts||(o.scripts={}),delete o.scripts.postinstall,delete o.scripts.postpublish,delete o.scripts.prepare,delete o.scripts.prepublishOnly,delete o.scripts.prepack,delete o.scripts.postpack;let r=$.default.resolve(e.dirPath,".husky");await Promise.all([b.default.promises.writeFile(n,JSON.stringify(o,void 0,2)),b.default.promises.rm(r,{force:!0,recursive:!0})]),h("yarn",["dlx","husky-init","--yarn2"],e.dirPath);let i=$.default.resolve(r,"pre-commit"),c=await b.default.promises.readFile(i,"utf-8");await p.run(()=>b.default.promises.rm($.default.resolve(e.dirPath,".huskyrc.json"),{force:!0})),await p.run(()=>b.default.promises.writeFile(i,c.replace(ee,te.preCommit))),(e.containingTypeScript||e.containingTypeScriptInPackages)&&await p.run(()=>b.default.promises.writeFile($.default.resolve(r,"pre-push"),c.replace(ee,te.prePush),{mode:493}));let a=[];((s=e.versionsText)==null?void 0:s.includes("python "))&&a.push("asdf install python"),e.versionsText&&a.push("asdf install"),a.push(te.postMerge),((f=e.versionsText)==null?void 0:f.includes("poetry "))&&a.push("poetry install"),e.depending.blitz?a.push("yarn blitz codegen"):e.depending.prisma&&a.push("yarn prisma generate");let m=c.replace(ee,a.join(" && "));await p.run(()=>b.default.promises.writeFile($.default.resolve(r,"post-merge"),m,{mode:493}))}var ne=l(require("fs")),ie=l(require("path"));var jt=`<?xml version="1.0" encoding="UTF-8"?>
77
77
  <project version="4">
78
78
  <component name="ProjectTasksOptions">
79
79
  <TaskOptions isEnabled="true">
@@ -198,8 +198,8 @@ android/$1`));let c=o+n;await p.run(()=>f.generateFile(t,c))}var b=l(require("fs
198
198
  </TaskOptions>
199
199
  </component>
200
200
  </project>
201
- `;async function De(e){let i=ie.default.resolve(e.dirPath,".idea");if(ne.default.existsSync(i)){let t=ie.default.resolve(i,"watcherTasks.xml");e.containingJavaScript||e.containingJavaScriptInPackages||e.containingTypeScript||e.containingTypeScriptInPackages||e.containingPackageJson&&!e.containingPubspecYaml&&!e.containingGemfile&&!e.containingGoMod&&!e.containingPomXml?await p.run(()=>f.generateFile(t,jt)):await p.run(()=>ne.default.promises.rm(t,{force:!0}))}}var oe=l(require("fs")),G=l(require("path"));var B={getLintFixSuffix(e){return e.containingJsxOrTsx?' --rule "{ react-hooks/exhaustive-deps: 0 }"':""}};var Ee=`./{src,__tests__}/**/*.{${g.eslint.join(",")}}`,Ct=`files = micromatch.not(files, '${Ee}');`;async function re(e){let i=[];if(e.containingJavaScript||e.containingTypeScript){let n=`
202
- '${Ee}': [${JSON.stringify(`eslint --fix${B.getLintFixSuffix(e)}`)}, 'prettier --write'],`;i.push(n)}let t=e.root?" && !file.includes('/packages/')":"";i.push(`
201
+ `;async function De(e){let n=ie.default.resolve(e.dirPath,".idea");if(ne.default.existsSync(n)){let t=ie.default.resolve(n,"watcherTasks.xml");e.containingJavaScript||e.containingJavaScriptInPackages||e.containingTypeScript||e.containingTypeScriptInPackages||e.containingPackageJson&&!e.containingPubspecYaml&&!e.containingGemfile&&!e.containingGoMod&&!e.containingPomXml?await p.run(()=>u.generateFile(t,jt)):await p.run(()=>ne.default.promises.rm(t,{force:!0}))}}var oe=l(require("fs")),L=l(require("path"));var U={getLintFixSuffix(e){return e.containingJsxOrTsx?' --rule "{ react-hooks/exhaustive-deps: 0 }"':""}};var Je=`./{src,__tests__}/**/*.{${g.eslint.join(",")}}`,Ct=`files = micromatch.not(files, '${Je}');`;async function re(e){let n=[];if(e.containingJavaScript||e.containingTypeScript){let i=`
202
+ '${Je}': [${JSON.stringify(`eslint --fix${U.getLintFixSuffix(e)}`)}, 'prettier --write'],`;n.push(i)}let t=e.root?" && !file.includes('/packages/')":"";n.push(`
203
203
  './**/*.{${g.prettier.join(",")}}': files => {
204
204
  ${e.containingJavaScript||e.containingTypeScript?Ct:""}
205
205
  const filteredFiles = files.filter(file => !file.includes('/test-fixtures/')${t});
@@ -209,22 +209,22 @@ android/$1`));let c=o+n;await p.run(()=>f.generateFile(t,c))}var b=l(require("fs
209
209
  commands.push('yarn sort-package-json');
210
210
  }
211
211
  return commands;
212
- },`),e.containingPubspecYaml&&i.push(`
212
+ },`),e.containingPubspecYaml&&n.push(`
213
213
  './{lib,test,test_driver}/**/*.dart': files => {
214
214
  const filteredFiles = files.filter(file => !file.includes('generated'))
215
215
  .filter(file => !file.endsWith('.freezed.dart') && !file.endsWith('.g.dart'));
216
216
  if (filteredFiles.length === 0) return [];
217
217
  return [\`flutter format \${filteredFiles.join(' ')}\`];
218
- },`),e.containingPoetryLock&&i.push(`
218
+ },`),e.containingPoetryLock&&n.push(`
219
219
  './**/*.py': [
220
220
  'poetry run isort --profile black --filter-files',
221
221
  'poetry run black',
222
222
  'poetry run flake8'
223
223
  ],`);let o=`${e.containingJavaScript||e.containingTypeScript?"const micromatch = require('micromatch');":""}
224
224
 
225
- module.exports = {${i.join("")}
225
+ module.exports = {${n.join("")}
226
226
  };
227
- `,r=G.default.resolve(e.dirPath,".lintstagedrc.cjs");await p.run(()=>oe.default.promises.rm(G.default.resolve(e.dirPath,".lintstagedrc.js"),{force:!0})),await p.run(()=>oe.default.promises.rm(G.default.resolve(e.dirPath,".lintstagedrc.json"),{force:!0})),await p.run(()=>f.generateFile(r,o))}var x=l(require("fs")),T=l(require("path")),L=l(require("deepmerge"));var ae={cleanup:"yarn format && yarn lint-fix",format:"sort-package-json && yarn prettify",lint:`eslint --color "./{src,__tests__}/**/*.{${g.eslint.join(",")}}"`,"lint-fix":"yarn lint --fix",prettify:`prettier --color --write "**/{.*/,}*.{${g.prettier.join(",")}}" "!**/test-fixtures/**"`,typecheck:"tsc --noEmit --Pretty"},Ft=(0,L.default)(O({},ae),{format:"sort-package-json && yarn prettify && yarn workspaces foreach --parallel --verbose run format",lint:"yarn workspaces foreach --parallel --verbose run lint","lint-fix":"yarn workspaces foreach --parallel --verbose run lint-fix",prettify:`prettier --color --write "**/{.*/,}*.{${g.prettier.join(",")}}" "!**/packages/**" "!**/test-fixtures/**"`,test:"yarn workspaces foreach --verbose run test",typecheck:"yarn workspaces foreach --parallel --verbose run typecheck"}),$t=(0,L.default)(O({},ae),{lint:`eslint --color "./**/*.{${g.eslint.join(",")}}"`,typecheck:`tsc --noEmit --Pretty || echo 'Please try "yarn blitz codegen" if you face unknown type errors.'`}),se=["eslint","eslint-config-prettier","eslint-plugin-import","eslint-plugin-sort-class-members","eslint-plugin-sort-destructure-keys"],Ie=[...se,"@typescript-eslint/eslint-plugin","@typescript-eslint/parser","eslint-import-resolver-typescript"],Ne=["eslint-plugin-react","eslint-plugin-react-hooks"],We={"@willbooster/eslint-config-js":["@willbooster/eslint-config-js",...se],"@willbooster/eslint-config-js-react":["@willbooster/eslint-config-js-react",...se,...Ne],"@willbooster/eslint-config-ts":["@willbooster/eslint-config-ts",...Ie],"@willbooster/eslint-config-ts-react":["@willbooster/eslint-config-ts-react",...Ie,...Ne],"../../.eslintrc.json":[]};async function Me(e,i,t){let o=T.default.resolve(e.dirPath,"package.json"),r=await x.default.promises.readFile(o,"utf-8"),n=JSON.parse(r);n.scripts=n.scripts||{},n.dependencies=n.dependencies||{},n.devDependencies=n.devDependencies||{},n.peerDependencies=n.peerDependencies||{},await _t(n),n.name!=="@willbooster/prettier-config"&&(n.prettier="@willbooster/prettier-config");for(let s of Object.keys(n.scripts))n.scripts[s].includes("git clone")||(n.scripts[s]=n.scripts[s].replace(/yarn\s*&&\s*/,"").replace(/yarn\s*install\s*&&\s*/,""));n.scripts=(0,L.default)(n.scripts,e.containingSubPackageJsons?Ft:e.depending.blitz?$t:ae),n.scripts.prettify+=await Tt(e.dirPath);let c=[],a=["lint-staged","prettier","sort-package-json","@willbooster/prettier-config"],m=[];if(e.root&&(a.push("husky","pinst","@willbooster/renovate-config"),e.depending.semanticRelease&&a.push("conventional-changelog-conventionalcommits"),e.containingSubPackageJsons?n.workspaces=["packages/*"]:delete n.workspaces),(e.containingJavaScript||e.containingJavaScriptInPackages||e.containingTypeScript||e.containingTypeScriptInPackages)&&(a.push("eslint","micromatch"),e.containingTypeScriptInPackages&&a.push("@typescript-eslint/parser")),(e.containingTypeScript||e.containingTypeScriptInPackages)&&!e.depending.blitz&&a.push("typescript"),e.eslintBase&&a.push(...We[e.eslintBase]),e.willBoosterConfigs&&(c=c.filter(s=>!s.includes("@willbooster/")),a=a.filter(s=>!s.includes("@willbooster/"))),n.name||(n.name=T.default.basename(e.dirPath)),e.containingSubPackageJsons&&(n.private=!0),n.license||(n.license="UNLICENSED"),!e.containingTypeScript&&!e.containingTypeScriptInPackages&&delete n.scripts.typecheck,e.depending.semanticRelease&&e.release.npm&&(n.resolutions||(n.resolutions={}),n.resolutions["npm/chalk"]="^4.1.2"),!e.containingSubPackageJsons){if(!e.containingJavaScript&&!e.containingTypeScript?(delete n.scripts.lint,delete n.scripts["lint-fix"],n.scripts.cleanup=n.scripts.cleanup.replace(" && yarn lint-fix","")):n.scripts["lint-fix"]+=B.getLintFixSuffix(e),e.containingPubspecYaml){n.scripts.lint="flutter analyze",n.scripts["lint-fix"]="yarn lint";let s=["lib","test","test_driver"].filter(u=>x.default.existsSync(T.default.resolve(e.dirPath,u)));s.length>0&&(n.scripts["format-code"]=`flutter format $(find ${s.join(" ")} -name generated -prune -o -name '*.freezed.dart' -prune -o -name '*.g.dart' -prune -o -name '*.dart' -print)`,n.scripts.format+=" && yarn format-code")}if(e.containingPoetryLock){n.scripts.postinstall==="poetry install"&&delete n.scripts.postinstall;let s=(await x.default.promises.readdir(e.dirPath)).filter(u=>{let v=T.default.resolve(e.dirPath,u);return x.default.lstatSync(v).isDirectory()?x.default.readdirSync(v).some(K=>K.endsWith(".py")):!1});s.length>0&&(n.scripts["format-code"]=`poetry run isort --profile black ${s.join(" ")} && poetry run black ${s.join(" ")}`,n.scripts.lint=`poetry run flake8 ${s.join(" ")}`,n.scripts["lint-fix"]="yarn lint",n.scripts.format+=" && yarn format-code",m.push("black","isort","flake8"))}e.repository&&(n.repository=e.repository)}e.depending.blitz&&(a=a.filter(s=>!s.includes("@typescript-eslint/")),a=a.filter(s=>s!=="eslint-plugin-react")),Object.keys(n.dependencies).length||delete n.dependencies,Object.keys(n.devDependencies).length||delete n.devDependencies,Object.keys(n.peerDependencies).length||delete n.peerDependencies,await x.default.promises.writeFile(o,JSON.stringify(n)),t||(c.length&&c.some(s=>{var u;return!((u=n.dependencies)==null?void 0:u[s])})&&h("yarn",["add",...new Set(c)],e.dirPath),a.length&&h("yarn",["add","-D",...new Set(a)],e.dirPath),m.length&&h("poetry",["add",...new Set(m)],e.dirPath))}async function _t(e){e.author==="WillBooster LLC"&&(e.author="WillBooster Inc."),delete e.scripts["sort-package-json"],delete e.scripts["sort-all-package-json"],delete e.dependencies.tslib,delete e.devDependencies["@willbooster/eslint-config"],delete e.devDependencies["@willbooster/eslint-config-react"],delete e.devDependencies["@willbooster/tsconfig"],delete e.devDependencies["eslint-import-resolver-node"],delete e.devDependencies["eslint-plugin-prettier"],delete e.devDependencies.lerna,delete e.devDependencies.pinst,delete e.scripts["flutter-format"],delete e.scripts["format-flutter"],delete e.scripts["python-format"],delete e.scripts["format-python"],delete e.scripts.prettier;for(let i of Object.values(We))for(let t of i)delete e.devDependencies[t];await p.run(()=>x.default.promises.rm("lerna.json",{force:!0}))}async function Tt(e){let i=T.default.resolve(e,".prettierignore"),t=await x.default.promises.readFile(i,"utf-8"),o=t.indexOf(y.separatorPrefix);return o<0?"":t.substring(0,o).split(`
227
+ `,r=L.default.resolve(e.dirPath,".lintstagedrc.cjs");await p.run(()=>oe.default.promises.rm(L.default.resolve(e.dirPath,".lintstagedrc.js"),{force:!0})),await p.run(()=>oe.default.promises.rm(L.default.resolve(e.dirPath,".lintstagedrc.json"),{force:!0})),await p.run(()=>u.generateFile(r,o))}var x=l(require("fs")),R=l(require("path")),G=l(require("deepmerge"));var ae={cleanup:"yarn format && yarn lint-fix",format:"sort-package-json && yarn prettify",lint:`eslint --color "./{src,__tests__}/**/*.{${g.eslint.join(",")}}"`,"lint-fix":"yarn lint --fix",prettify:`prettier --color --write "**/{.*/,}*.{${g.prettier.join(",")}}" "!**/test-fixtures/**"`,typecheck:"tsc --noEmit --Pretty"},Ft=(0,G.default)(C({},ae),{format:"sort-package-json && yarn prettify && yarn workspaces foreach --parallel --verbose run format",lint:"yarn workspaces foreach --parallel --verbose run lint","lint-fix":"yarn workspaces foreach --parallel --verbose run lint-fix",prettify:`prettier --color --write "**/{.*/,}*.{${g.prettier.join(",")}}" "!**/packages/**" "!**/test-fixtures/**"`,test:"yarn workspaces foreach --verbose run test",typecheck:"yarn workspaces foreach --parallel --verbose run typecheck"}),$t=(0,G.default)(C({},ae),{lint:`eslint --color "./**/*.{${g.eslint.join(",")}}"`,typecheck:`tsc --noEmit --Pretty || echo 'Please try "yarn blitz codegen" if you face unknown type errors.'`}),se=["eslint","eslint-config-prettier","eslint-plugin-import","eslint-plugin-sort-class-members","eslint-plugin-sort-destructure-keys"],Ie=[...se,"@typescript-eslint/eslint-plugin","@typescript-eslint/parser","eslint-import-resolver-typescript"],Ne=["eslint-plugin-react","eslint-plugin-react-hooks"],We={"@willbooster/eslint-config-js":["@willbooster/eslint-config-js",...se],"@willbooster/eslint-config-js-react":["@willbooster/eslint-config-js-react",...se,...Ne],"@willbooster/eslint-config-ts":["@willbooster/eslint-config-ts",...Ie],"@willbooster/eslint-config-ts-react":["@willbooster/eslint-config-ts-react",...Ie,...Ne],"../../.eslintrc.json":[]};async function Be(e,n,t){let o=R.default.resolve(e.dirPath,"package.json"),r=await x.default.promises.readFile(o,"utf-8"),i=JSON.parse(r);i.scripts=i.scripts||{},i.dependencies=i.dependencies||{},i.devDependencies=i.devDependencies||{},i.peerDependencies=i.peerDependencies||{},await _t(i),i.name!=="@willbooster/prettier-config"&&(i.prettier="@willbooster/prettier-config");for(let s of Object.keys(i.scripts))i.scripts[s].includes("git clone")||(i.scripts[s]=i.scripts[s].replace(/yarn\s*&&\s*/,"").replace(/yarn\s*install\s*&&\s*/,""));i.scripts=(0,G.default)(i.scripts,e.containingSubPackageJsons?Ft:e.depending.blitz?$t:ae),i.scripts.prettify+=await Tt(e.dirPath);let c=[],a=["lint-staged","prettier","sort-package-json","@willbooster/prettier-config"],m=[];if(e.root&&(a.push("husky","pinst","@willbooster/renovate-config"),e.depending.semanticRelease&&a.push("conventional-changelog-conventionalcommits"),e.containingSubPackageJsons?i.workspaces=["packages/*"]:delete i.workspaces),(e.containingJavaScript||e.containingJavaScriptInPackages||e.containingTypeScript||e.containingTypeScriptInPackages)&&(a.push("eslint","micromatch"),e.containingTypeScriptInPackages&&a.push("@typescript-eslint/parser")),(e.containingTypeScript||e.containingTypeScriptInPackages)&&!e.depending.blitz&&a.push("typescript"),e.eslintBase&&a.push(...We[e.eslintBase]),e.willBoosterConfigs&&(c=c.filter(s=>!s.includes("@willbooster/")),a=a.filter(s=>!s.includes("@willbooster/"))),i.name||(i.name=R.default.basename(e.dirPath)),e.containingSubPackageJsons&&(i.private=!0),i.license||(i.license="UNLICENSED"),!e.containingTypeScript&&!e.containingTypeScriptInPackages&&delete i.scripts.typecheck,e.depending.semanticRelease&&e.release.npm&&(i.resolutions||(i.resolutions={}),i.resolutions["npm/chalk"]="^4.1.2"),!e.containingSubPackageJsons){if(!e.containingJavaScript&&!e.containingTypeScript?(delete i.scripts.lint,delete i.scripts["lint-fix"],i.scripts.cleanup=i.scripts.cleanup.replace(" && yarn lint-fix","")):i.scripts["lint-fix"]+=U.getLintFixSuffix(e),e.containingPubspecYaml){i.scripts.lint="flutter analyze",i.scripts["lint-fix"]="yarn lint";let s=["lib","test","test_driver"].filter(f=>x.default.existsSync(R.default.resolve(e.dirPath,f)));s.length>0&&(i.scripts["format-code"]=`flutter format $(find ${s.join(" ")} -name generated -prune -o -name '*.freezed.dart' -prune -o -name '*.g.dart' -prune -o -name '*.dart' -print)`,i.scripts.format+=" && yarn format-code")}if(e.containingPoetryLock){i.scripts.postinstall==="poetry install"&&delete i.scripts.postinstall;let s=(await x.default.promises.readdir(e.dirPath)).filter(f=>{let v=R.default.resolve(e.dirPath,f);return x.default.lstatSync(v).isDirectory()?x.default.readdirSync(v).some(K=>K.endsWith(".py")):!1});s.length>0&&(i.scripts["format-code"]=`poetry run isort --profile black ${s.join(" ")} && poetry run black ${s.join(" ")}`,i.scripts.lint=`poetry run flake8 ${s.join(" ")}`,i.scripts["lint-fix"]="yarn lint",i.scripts.format+=" && yarn format-code",m.push("black","isort","flake8"))}e.repository&&(i.repository=e.repository)}e.depending.blitz&&(a=a.filter(s=>!s.includes("@typescript-eslint/")),a=a.filter(s=>s!=="eslint-plugin-react"&&s!=="eslint-import-resolver-typescript"&&s!=="eslint-plugin-import"&&s!=="eslint-plugin-react-hooks")),Object.keys(i.dependencies).length||delete i.dependencies,Object.keys(i.devDependencies).length||delete i.devDependencies,Object.keys(i.peerDependencies).length||delete i.peerDependencies,await x.default.promises.writeFile(o,JSON.stringify(i)),t||(c.length&&c.some(s=>{var f;return!((f=i.dependencies)==null?void 0:f[s])})&&h("yarn",["add",...new Set(c)],e.dirPath),a.length&&h("yarn",["add","-D",...new Set(a)],e.dirPath),m.length&&h("poetry",["add",...new Set(m)],e.dirPath))}async function _t(e){e.author==="WillBooster LLC"&&(e.author="WillBooster Inc."),delete e.scripts["sort-package-json"],delete e.scripts["sort-all-package-json"],delete e.dependencies.tslib,delete e.devDependencies["@willbooster/eslint-config"],delete e.devDependencies["@willbooster/eslint-config-react"],delete e.devDependencies["@willbooster/tsconfig"],delete e.devDependencies["eslint-import-resolver-node"],delete e.devDependencies["eslint-plugin-prettier"],delete e.devDependencies.lerna,delete e.devDependencies.pinst,delete e.scripts["flutter-format"],delete e.scripts["format-flutter"],delete e.scripts["python-format"],delete e.scripts["format-python"],delete e.scripts.prettier;for(let n of Object.values(We))for(let t of n)delete e.devDependencies[t];await p.run(()=>x.default.promises.rm("lerna.json",{force:!0}))}async function Tt(e){let n=R.default.resolve(e,".prettierignore"),t=await x.default.promises.readFile(n,"utf-8"),o=t.indexOf(y.separatorPrefix);return o<0?"":t.substring(0,o).split(`
228
228
  `).map(c=>{let a=c.trim();return a.endsWith("/")?a.slice(0,-1):a}).filter(c=>c&&!c.startsWith("#")&&!c.includes("/")).map(c=>` "!**/${c}/**"`).join("")}var le=l(require("path"));var Rt=`${y.header}
229
229
 
230
230
 
@@ -239,9 +239,9 @@ test-fixtures/
239
239
  *.min.js
240
240
  .yarn/
241
241
  .pnp.js
242
- `;async function Ue(e){let i=le.default.resolve(e.dirPath,".prettierignore"),t=y.getUserContent(i)||Rt,o=le.default.resolve(e.dirPath,".gitignore"),r=y.getExistingContent(o)||"",n="";e.containingPubspecYaml&&(n=`
242
+ `;async function Me(e){let n=le.default.resolve(e.dirPath,".prettierignore"),t=y.getUserContent(n)||Rt,o=le.default.resolve(e.dirPath,".gitignore"),r=y.getExistingContent(o)||"",i="";e.containingPubspecYaml&&(i=`
243
243
  android/app/
244
244
  ios/Runner/Assets.xcassets/
245
245
  pubspec.yaml
246
- `);let c=t+Ot+n+r;await p.run(()=>f.generateFile(i,c))}var ze=l(require("fs")),Be=l(require("path"));async function Ge(e){let i=Be.default.resolve(e.dirPath,".releaserc.json");try{let t=JSON.parse(await ze.default.promises.readFile(i,"utf8")),o=(t==null?void 0:t.plugins)||[];for(let n=0;n<o.length;n++)(o[n]==="@semantic-release/commit-analyzer"||o[n][0]==="@semantic-release/commit-analyzer")&&(o[n]=["@semantic-release/commit-analyzer",{preset:"conventionalcommits"}]);let r=JSON.stringify(t);await p.run(()=>f.generateFile(i,r))}catch{}}var Y=l(require("fs")),A=l(require("path")),Le=l(require("deepmerge")),Ye=l(require("lodash.clonedeep"));var Jt={extends:["@willbooster"]};async function Ae(e){let i=(0,Ye.default)(Jt),t=A.default.resolve(e.dirPath,".renovaterc.json"),o=await Y.default.promises.readFile(t,"utf-8");try{let n=JSON.parse(o);i=Le.default.all([i,n,i],{arrayMerge:M})}catch{}await p.run(()=>Y.default.promises.rm(A.default.resolve(e.dirPath,".dependabot"),{force:!0})),await p.run(()=>Y.default.promises.rm(A.default.resolve(e.dirPath,"renovate.json"),{force:!0}));let r=JSON.stringify(i);await p.run(()=>f.generateFile(t,r))}var He=l(require("fs")),pe=l(require("path")),Ke=l(require("js-yaml"));var Dt={titleOnly:!0};async function qe(e){let i=pe.default.resolve(e.dirPath,".github");await He.default.promises.mkdir(i,{recursive:!0});let t=pe.default.join(i,"semantic.yml"),o=Ke.default.dump(Dt);await p.run(()=>f.generateFile(t,o))}var Ve=l(require("fs")),D=l(require("path")),Xe=l(require("deepmerge")),Ze=l(require("lodash.clonedeep"));function J(e){let i=Object.entries(e).sort(([t],[o])=>t.localeCompare(o));for(let[t,o]of i)delete e[t],e[t]=o}var Et={compilerOptions:{target:"esnext",module:"esnext",moduleResolution:"node",jsx:"react",alwaysStrict:!0,strict:!0,skipLibCheck:!0,allowSyntheticDefaultImports:!0,esModuleInterop:!0,resolveJsonModule:!0,sourceMap:!0,importHelpers:!1,outDir:"dist"},include:["src/**/*","__tests__/**/*","packages/*/src/**/*","packages/*/__tests__/**/*","./node_modules/@types","./@types"]},It={compilerOptions:{target:"esnext",module:"esnext",moduleResolution:"node",jsx:"react",alwaysStrict:!0,strict:!0,skipLibCheck:!0,allowSyntheticDefaultImports:!0,esModuleInterop:!0,resolveJsonModule:!0,sourceMap:!0,importHelpers:!1,outDir:"dist"},include:["src/**/*","__tests__/**/*","../../node_modules/@types","../../@types","./@types"]};async function Qe(e,i){var n,c,a;if(i.depending.blitz)return;let t=(0,Ze.default)(e.root?Et:It);if(!e.containingJsxOrTsx&&!e.containingJsxOrTsxInPackages&&delete t.compilerOptions.jsx,e.root&&!e.containingSubPackageJsons&&(t.include=t.include.filter(m=>!m.startsWith("packages/*/"))),!e.root&&(e.depending.jestPlaywrightPreset||i.depending.jestPlaywrightPreset)){let m=D.default.relative(e.dirPath,i.dirPath);t.include.push(D.default.join(m,"node_modules/jest-playwright-preset/types"),D.default.join(m,"node_modules/expect-playwright"))}let o=D.default.resolve(e.dirPath,"tsconfig.json");try{let m=await Ve.default.promises.readFile(o,"utf-8"),s=JSON.parse(m);s.extends==="./node_modules/@willbooster/tsconfig/tsconfig.json"&&delete s.extends,(n=s.compilerOptions)==null||delete n.typeRoots,(c=t==null?void 0:t.compilerOptions)==null||delete c.target,(a=t==null?void 0:t.compilerOptions)==null||delete a.module,s.jsx&&delete t.jsx,e.depending.blitz||delete t.include,t=Xe.default.all([t,s,t],{arrayMerge:M})}catch{}J(t.compilerOptions);let r=JSON.stringify(t);await p.run(()=>f.generateFile(o,r))}var $=l(require("fs")),R=l(require("path")),et=l(require("deepmerge")),me=l(require("js-yaml")),tt=l(require("lodash.clonedeep"));var Nt={name:"Test",on:{pull_request:{branches:["main","!renovate/**"]},push:{branches:["main","renovate/**"]}},jobs:{test:{uses:"WillBooster/reusable-workflows/.github/workflows/test.yml@main"}}},Wt={name:"Release",on:{push:{branches:[]}},jobs:{release:{uses:"WillBooster/reusable-workflows/.github/workflows/release.yml@main"}}},Mt={name:"Willboosterify",on:{schedule:[{cron:"0 5 * * 0"}],workflow_dispatch:null},jobs:{wbfy:{uses:"WillBooster/reusable-workflows/.github/workflows/wbfy.yml@main"}}};async function nt(e){let i=R.default.resolve(e.dirPath,".github","workflows");await $.default.promises.mkdir(i,{recursive:!0}),e.depending.semanticRelease&&await p.run(async()=>{let t=await ce(e,i,"release");await $.default.promises.writeFile(R.default.join(i,"release.yml"),t)}),await p.run(async()=>{let t=await ce(e,i,"test");await $.default.promises.writeFile(R.default.join(i,"test.yml"),t)}),await p.run(async()=>{let t=await ce(e,i,"wbfy");await $.default.promises.writeFile(R.default.join(i,"wbfy.yml"),t)})}async function ce(e,i,t){var c;let o=(0,tt.default)(t==="test"?Nt:t==="release"?Wt:Mt);t==="release"&&(o.on.push.branches=e.release.branches);let r=o.jobs.test||o.jobs.release||o.jobs.wbfy;r.with||(r.with={}),r.secrets||(r.secrets={}),((c=e.repository)==null?void 0:c.startsWith("github:WillBoosterLab/"))&&(r.uses=r.uses.replace("WillBooster/","WillBoosterLab/")),e.containingDockerfile&&(r.with.cpu_arch="X64"),(e.release.github||t==="wbfy")&&(e.publicRepo?r.secrets.GH_TOKEN="${{ secrets.PUBLIC_GH_BOT_PAT }}":r.secrets.GH_TOKEN="${{ secrets.GH_BOT_PAT }}"),e.release.npm&&t!=="wbfy"&&(r.secrets.NPM_TOKEN="${{ secrets.NPM_TOKEN }}");let n=R.default.join(i,`${t}.yml`);try{let a=await $.default.promises.readFile(n,"utf-8"),m=me.default.load(a);o=et.default.all([o,m,o],{arrayMerge:U})}catch{}return r=o.jobs.test||o.jobs.release||o.jobs.wbfy,delete r.with.non_self_hosted,Object.keys(r.with).length?J(r.with):delete r.with,Object.keys(r.secrets).length?J(r.secrets):delete r.secrets,t==="release"&&o.on.schedule&&delete o.on.push,t==="release"&&await p.run(()=>$.default.promises.rm("semantic-release.yml",{force:!0})),me.default.dump(o,{styles:{"!!null":"empty"},noCompatMode:!0})}var _=l(require("fs")),E=l(require("path")),fe=l(require("js-yaml"));async function ot(e){let i=Q("yarn",["--version"],e.dirPath),t=Q("npm",["show","@yarnpkg/cli","version"],e.dirPath);i!==t&&h("yarn",["set","version",t],e.dirPath,1);let o=E.default.join(e.dirPath,".yarn","releases");await _.default.promises.mkdir(o,{recursive:!0});for(let s of await _.default.promises.readdir(o))s.startsWith("yarn-")&&!s.startsWith(`yarn-${t}`)&&await p.run(()=>_.default.promises.rm(E.default.join(o,s)));let r=E.default.resolve(e.dirPath,".yarnrc");await p.run(()=>_.default.promises.rm(r,{force:!0}));let n=E.default.resolve(e.dirPath,".yarnrc.yml"),c=fe.default.load(await _.default.promises.readFile(n,"utf8"));c.defaultSemverRangePrefix="",e.requiringNodeModules&&(c.nodeLinker="node-modules",c.nmMode="hardlinks-global"),await _.default.promises.writeFile(n,fe.default.dump(c));let a=(c.plugins||[]).map(s=>s.spec),m=e.containingTypeScript||e.containingTypeScriptInPackages;it(e,a,m,"@yarnpkg/plugin-typescript"),m&&!e.requiringNodeModules&&h("yarn",["dlx","@yarnpkg/sdks","vscode"],e.dirPath),it(e,a,e.containingSubPackageJsons,"@yarnpkg/plugin-workspace-tools"),h("yarn",["dlx","yarn-plugin-auto-install"],e.dirPath)}function it(e,i,t,o){t!==i.includes(o)&&h("yarn",["plugin",t?"import":"remove",o],e.dirPath)}var P=l(require("fs")),H=l(require("fs/promises")),d=l(require("path")),j=l(require("glob")),st=l(require("js-yaml")),at=l(require("simple-git"));async function ue(e){var t;let i=d.default.resolve(e,"package.json");try{let o=P.default.existsSync(i),r={},n={},c={};if(o){let S=P.default.readFileSync(i,"utf-8");c=JSON.parse(S),r=c.dependencies??{},n=c.devDependencies??{}}let a=!0;try{let S=d.default.resolve(e,".yarnrc.yml"),w=st.default.load(await H.default.readFile(S,"utf8"));a=!w.nodeLinker||w.nodeLinker==="node-modules"}catch{}let m=[],s=[];try{let S=d.default.resolve(e,".releaserc.json"),w=JSON.parse(await H.default.readFile(S,"utf8"));m=(w==null?void 0:w.branches)||[],s=((t=w==null?void 0:w.plugins)==null?void 0:t.flat())||[]}catch{}let u=d.default.basename(d.default.resolve(e,".."))!=="packages"||!P.default.existsSync(d.default.resolve(e,"..","..","package.json")),v;u&&(v=await zt(e,c));let K=d.default.resolve(e,".tool-versions"),de;try{de=await H.default.readFile(K,"utf-8")}catch{}let k={dirPath:e,root:u,publicRepo:(v==null?void 0:v.private)===!1,repository:(v==null?void 0:v.full_name)?`github:${v==null?void 0:v.full_name}`:void 0,willBoosterConfigs:i.includes(`${d.default.sep}willbooster-configs`),containingSubPackageJsons:j.default.sync("packages/**/package.json",{cwd:e}).length>0,containingDockerfile:P.default.existsSync(d.default.resolve(e,"Dockerfile"))||P.default.existsSync(d.default.resolve(e,"docker-compose.yml")),containingGemfile:P.default.existsSync(d.default.resolve(e,"Gemfile")),containingGoMod:P.default.existsSync(d.default.resolve(e,"go.mod")),containingPackageJson:P.default.existsSync(d.default.resolve(e,"package.json")),containingPoetryLock:P.default.existsSync(d.default.resolve(e,"poetry.lock")),containingPomXml:P.default.existsSync(d.default.resolve(e,"pom.xml")),containingPubspecYaml:P.default.existsSync(d.default.resolve(e,"pubspec.yaml")),containingTemplateYaml:P.default.existsSync(d.default.resolve(e,"template.yaml")),containingJavaScript:j.default.sync("@(app|src|__tests__)/**/*.js?(x)",{cwd:e}).length>0,containingTypeScript:j.default.sync("@(app|src|__tests__)/**/*.ts?(x)",{cwd:e}).length>0,containingJsxOrTsx:j.default.sync("@(app|src|__tests__)/**/*.{t,j}sx",{cwd:e}).length>0,containingJavaScriptInPackages:j.default.sync("packages/**/@(app|src|__tests__)/**/*.js?(x)",{cwd:e}).length>0,containingTypeScriptInPackages:j.default.sync("packages/**/@(app|src|__tests__)/**/*.ts?(x)",{cwd:e}).length>0,containingJsxOrTsxInPackages:j.default.sync("packages/**/@(app|src|__tests__)/**/*.{t,j}sx",{cwd:e}).length>0,depending:{blitz:!!(r.blitz||n.blitz),firebase:!!n["firebase-tools"],jestPlaywrightPreset:!!n["jest-playwright-preset"],prisma:!!n.prisma,reactNative:!!r["react-native"],semanticRelease:!!n["semantic-release"],storybook:!!n["@storybook/react"]},release:{branches:m,github:s.includes("@semantic-release/github"),npm:s.includes("@semantic-release/npm")},requiringNodeModules:a,versionsText:de};if(k.eslintBase=Ut(k),k.containingGemfile||k.containingGoMod||k.containingPackageJson||k.containingPoetryLock||k.containingPomXml||k.containingPubspecYaml||k.containingTemplateYaml)return k}catch{}return null}function Ut(e){if(e.containingTypeScript)return e.containingJsxOrTsx?"@willbooster/eslint-config-ts-react":"@willbooster/eslint-config-ts";if(e.containingJsxOrTsx)return"@willbooster/eslint-config-js-react";if(e.containingJavaScript)return"@willbooster/eslint-config-js"}async function zt(e,i){var a,m,s;let t=((a=i.repository)==null?void 0:a.url)??i.repository;if(typeof t=="string"){let u=await rt(t);if(u)return u}let n=(await(0,at.default)(e).getRemotes(!0)).find(u=>u.name==="origin"),c=((m=n==null?void 0:n.refs)==null?void 0:m.fetch)??((s=n==null?void 0:n.refs)==null?void 0:s.push);if(typeof c=="string"){let u=await rt(c);if(u)return u}}async function rt(e){var s;let i=e.split(":").at(-1),t=i==null?void 0:i.split("/"),o=t==null?void 0:t.at(-2),r=(s=t==null?void 0:t.at(-1))==null?void 0:s.replace(/.git$/,"");if(!o||!r)return;let n=process.env.GH_TOKEN||process.env.GITHUB_TOKEN,c=n?{headers:{Authorization:`token ${n}`}}:void 0,m=await(await z(`https://api.github.com/repos/${o}/${r}`,c)).json();return O({full_name:`${o}/${r}`},m??{})}async function Bt(){let e=await(0,ct.default)(process.argv.slice(2)).command("wbfy <paths...>","Generate/update project files for WillBooster").demandCommand(1).alias("d","skipDeps").boolean("skipDeps").default("skipDeps",!1).describe("skipDeps","Skip dependency installation").alias("v","verbose").boolean("verbose").default("verbose",!1).argv;for(let i of e._){if(typeof i=="number")continue;let t=await ue(i);if(t===null){console.error(`there is no valid package.json in ${i}`);continue}let o=t.containingSubPackageJsons?pt.default.sync("packages/*",{cwd:i}).map(s=>lt.default.resolve(i,s)):[],r=(await Promise.all(o.map(s=>ue(s)))).filter(s=>!!s),n=[t,...r],c=[t,...r.filter(s=>s.containingPackageJson)];if(e.verbose)for(let s of n)console.log(s);let a=n.map(s=>Re(s,t));await ot(t),a.push(be(t),Te(t),Je(t),De(t),re(t),Ae(t),Ge(t),qe(t),Pe(t),nt(t)),await Promise.all(a),await p.promiseAll();let m=[];for(let s of c)m.push(Ue(s),re(s)),(s.containingTypeScript||s.containingTypeScriptInPackages)&&m.push(Qe(s,t)),(s.containingJavaScript||s.containingJavaScriptInPackages||s.containingTypeScript||s.containingTypeScriptInPackages)&&(t.willBoosterConfigs||m.push($e(s,t)),m.push(xe(s)));await Promise.all(m),await p.promiseAll();for(let s of c)await Me(s,t,e.skipDeps);h("yarn",["cleanup"],i),h("yarn",["install"],i)}}Bt().then();
246
+ `);let c=t+Ot+i+r;await p.run(()=>u.generateFile(n,c))}var ze=l(require("fs")),Ue=l(require("path"));async function Le(e){let n=Ue.default.resolve(e.dirPath,".releaserc.json");try{let t=JSON.parse(await ze.default.promises.readFile(n,"utf8")),o=(t==null?void 0:t.plugins)||[];for(let i=0;i<o.length;i++)(o[i]==="@semantic-release/commit-analyzer"||o[i][0]==="@semantic-release/commit-analyzer")&&(o[i]=["@semantic-release/commit-analyzer",{preset:"conventionalcommits"}]);let r=JSON.stringify(t);await p.run(()=>u.generateFile(n,r))}catch{}}var Y=l(require("fs")),A=l(require("path")),Ge=l(require("deepmerge")),Ye=l(require("lodash.clonedeep"));var Et={extends:["@willbooster"]};async function Ae(e){let n=(0,Ye.default)(Et),t=A.default.resolve(e.dirPath,".renovaterc.json");try{let r=await Y.default.promises.readFile(t,"utf-8"),i=JSON.parse(r);n=Ge.default.all([n,i,n],{arrayMerge:B})}catch{}await p.run(()=>Y.default.promises.rm(A.default.resolve(e.dirPath,".dependabot"),{force:!0})),await p.run(()=>Y.default.promises.rm(A.default.resolve(e.dirPath,"renovate.json"),{force:!0}));let o=JSON.stringify(n);await p.run(()=>u.generateFile(t,o))}var He=l(require("fs")),pe=l(require("path")),Ke=l(require("js-yaml"));var Dt={titleOnly:!0};async function qe(e){let n=pe.default.resolve(e.dirPath,".github");await He.default.promises.mkdir(n,{recursive:!0});let t=pe.default.join(n,"semantic.yml"),o=Ke.default.dump(Dt);await p.run(()=>u.generateFile(t,o))}var Ve=l(require("fs")),D=l(require("path")),Xe=l(require("deepmerge")),Ze=l(require("lodash.clonedeep"));function E(e){let n=Object.entries(e).sort(([t],[o])=>t.localeCompare(o));for(let[t,o]of n)delete e[t],e[t]=o}var Jt={compilerOptions:{target:"esnext",module:"esnext",moduleResolution:"node",jsx:"react",alwaysStrict:!0,strict:!0,skipLibCheck:!0,allowSyntheticDefaultImports:!0,esModuleInterop:!0,resolveJsonModule:!0,sourceMap:!0,importHelpers:!1,outDir:"dist"},include:["src/**/*","__tests__/**/*","packages/*/src/**/*","packages/*/__tests__/**/*","./node_modules/@types","./@types"]},It={compilerOptions:{target:"esnext",module:"esnext",moduleResolution:"node",jsx:"react",alwaysStrict:!0,strict:!0,skipLibCheck:!0,allowSyntheticDefaultImports:!0,esModuleInterop:!0,resolveJsonModule:!0,sourceMap:!0,importHelpers:!1,outDir:"dist"},include:["src/**/*","__tests__/**/*","../../node_modules/@types","../../@types","./@types"]};async function Qe(e,n){var i,c,a;if(n.depending.blitz)return;let t=(0,Ze.default)(e.root?Jt:It);if(!e.containingJsxOrTsx&&!e.containingJsxOrTsxInPackages&&delete t.compilerOptions.jsx,e.root&&!e.containingSubPackageJsons&&(t.include=t.include.filter(m=>!m.startsWith("packages/*/"))),!e.root&&(e.depending.jestPlaywrightPreset||n.depending.jestPlaywrightPreset)){let m=D.default.relative(e.dirPath,n.dirPath);t.include.push(D.default.join(m,"node_modules/jest-playwright-preset/types"),D.default.join(m,"node_modules/expect-playwright"))}let o=D.default.resolve(e.dirPath,"tsconfig.json");try{let m=await Ve.default.promises.readFile(o,"utf-8"),s=JSON.parse(m);s.extends==="./node_modules/@willbooster/tsconfig/tsconfig.json"&&delete s.extends,(i=s.compilerOptions)==null||delete i.typeRoots,(c=t==null?void 0:t.compilerOptions)==null||delete c.target,(a=t==null?void 0:t.compilerOptions)==null||delete a.module,s.jsx&&delete t.jsx,e.depending.blitz||delete t.include,t=Xe.default.all([t,s,t],{arrayMerge:B})}catch{}E(t.compilerOptions);let r=JSON.stringify(t);await p.run(()=>u.generateFile(o,r))}var _=l(require("fs")),O=l(require("path")),et=l(require("deepmerge")),me=l(require("js-yaml")),tt=l(require("lodash.clonedeep"));var Nt={name:"Test",on:{pull_request:{branches:["main","!renovate/**"]},push:{branches:["main","renovate/**"]}},jobs:{test:{uses:"WillBooster/reusable-workflows/.github/workflows/test.yml@main"}}},Wt={name:"Release",on:{push:{branches:[]}},jobs:{release:{uses:"WillBooster/reusable-workflows/.github/workflows/release.yml@main"}}},Bt={name:"Willboosterify",on:{schedule:[{cron:"0 5 * * 0"}],workflow_dispatch:null},jobs:{wbfy:{uses:"WillBooster/reusable-workflows/.github/workflows/wbfy.yml@main"}}};async function nt(e){let n=O.default.resolve(e.dirPath,".github","workflows");await _.default.promises.mkdir(n,{recursive:!0}),e.depending.semanticRelease&&await p.run(async()=>{let t=await ce(e,n,"release");await _.default.promises.writeFile(O.default.join(n,"release.yml"),t)}),await p.run(async()=>{let t=await ce(e,n,"test");await _.default.promises.writeFile(O.default.join(n,"test.yml"),t)}),await p.run(async()=>{let t=await ce(e,n,"wbfy");await _.default.promises.writeFile(O.default.join(n,"wbfy.yml"),t)})}async function ce(e,n,t){var c;let o=(0,tt.default)(t==="test"?Nt:t==="release"?Wt:Bt);t==="release"&&(o.on.push.branches=e.release.branches);let r=o.jobs.test||o.jobs.release||o.jobs.wbfy;r.with||(r.with={}),r.secrets||(r.secrets={}),((c=e.repository)==null?void 0:c.startsWith("github:WillBoosterLab/"))&&(r.uses=r.uses.replace("WillBooster/","WillBoosterLab/")),e.containingDockerfile&&(r.with.cpu_arch="X64"),(e.release.github||t==="wbfy")&&(e.publicRepo?r.secrets.GH_TOKEN="${{ secrets.PUBLIC_GH_BOT_PAT }}":r.secrets.GH_TOKEN="${{ secrets.GH_BOT_PAT }}"),e.release.npm&&t!=="wbfy"&&(r.secrets.NPM_TOKEN="${{ secrets.NPM_TOKEN }}");let i=O.default.join(n,`${t}.yml`);try{let a=await _.default.promises.readFile(i,"utf-8"),m=me.default.load(a);o=et.default.all([o,m,o],{arrayMerge:M})}catch{}return r=o.jobs.test||o.jobs.release||o.jobs.wbfy,delete r.with.non_self_hosted,Object.keys(r.with).length?E(r.with):delete r.with,Object.keys(r.secrets).length?E(r.secrets):delete r.secrets,t==="release"&&o.on.schedule&&delete o.on.push,t==="release"&&await p.run(()=>_.default.promises.rm("semantic-release.yml",{force:!0})),me.default.dump(o,{styles:{"!!null":"empty"},noCompatMode:!0})}var T=l(require("fs")),J=l(require("path")),ue=l(require("js-yaml"));async function ot(e){let n=Q("yarn",["--version"],e.dirPath),t=Q("npm",["show","@yarnpkg/cli","version"],e.dirPath);n!==t&&h("yarn",["set","version",t],e.dirPath,1);let o=J.default.join(e.dirPath,".yarn","releases");await T.default.promises.mkdir(o,{recursive:!0});for(let s of await T.default.promises.readdir(o))s.startsWith("yarn-")&&!s.startsWith(`yarn-${t}`)&&await p.run(()=>T.default.promises.rm(J.default.join(o,s)));let r=J.default.resolve(e.dirPath,".yarnrc");await p.run(()=>T.default.promises.rm(r,{force:!0}));let i=J.default.resolve(e.dirPath,".yarnrc.yml"),c=ue.default.load(await T.default.promises.readFile(i,"utf8"));c.defaultSemverRangePrefix="",e.requiringNodeModules&&(c.nodeLinker="node-modules",c.nmMode="hardlinks-global"),await T.default.promises.writeFile(i,ue.default.dump(c));let a=(c.plugins||[]).map(s=>s.spec),m=e.containingTypeScript||e.containingTypeScriptInPackages;it(e,a,m,"@yarnpkg/plugin-typescript"),m&&!e.requiringNodeModules&&h("yarn",["dlx","@yarnpkg/sdks","vscode"],e.dirPath),it(e,a,e.containingSubPackageJsons,"@yarnpkg/plugin-workspace-tools"),h("yarn",["dlx","yarn-plugin-auto-install"],e.dirPath)}function it(e,n,t,o){t!==n.includes(o)&&h("yarn",["plugin",t?"import":"remove",o],e.dirPath)}var P=l(require("fs")),H=l(require("fs/promises")),d=l(require("path")),j=l(require("glob")),st=l(require("js-yaml")),at=l(require("simple-git"));async function fe(e){var t;let n=d.default.resolve(e,"package.json");try{let o=P.default.existsSync(n),r={},i={},c={};if(o){let S=P.default.readFileSync(n,"utf-8");c=JSON.parse(S),r=c.dependencies??{},i=c.devDependencies??{}}let a=!0;try{let S=d.default.resolve(e,".yarnrc.yml"),w=st.default.load(await H.default.readFile(S,"utf8"));a=!w.nodeLinker||w.nodeLinker==="node-modules"}catch{}let m=[],s=[];try{let S=d.default.resolve(e,".releaserc.json"),w=JSON.parse(await H.default.readFile(S,"utf8"));m=(w==null?void 0:w.branches)||[],s=((t=w==null?void 0:w.plugins)==null?void 0:t.flat())||[]}catch{}let f=d.default.basename(d.default.resolve(e,".."))!=="packages"||!P.default.existsSync(d.default.resolve(e,"..","..","package.json")),v;f&&(v=await zt(e,c));let K=d.default.resolve(e,".tool-versions"),de;try{de=await H.default.readFile(K,"utf-8")}catch{}let k={dirPath:e,root:f,publicRepo:(v==null?void 0:v.private)===!1,repository:(v==null?void 0:v.full_name)?`github:${v==null?void 0:v.full_name}`:void 0,willBoosterConfigs:n.includes(`${d.default.sep}willbooster-configs`),containingSubPackageJsons:j.default.sync("packages/**/package.json",{cwd:e}).length>0,containingDockerfile:P.default.existsSync(d.default.resolve(e,"Dockerfile"))||P.default.existsSync(d.default.resolve(e,"docker-compose.yml")),containingGemfile:P.default.existsSync(d.default.resolve(e,"Gemfile")),containingGoMod:P.default.existsSync(d.default.resolve(e,"go.mod")),containingPackageJson:P.default.existsSync(d.default.resolve(e,"package.json")),containingPoetryLock:P.default.existsSync(d.default.resolve(e,"poetry.lock")),containingPomXml:P.default.existsSync(d.default.resolve(e,"pom.xml")),containingPubspecYaml:P.default.existsSync(d.default.resolve(e,"pubspec.yaml")),containingTemplateYaml:P.default.existsSync(d.default.resolve(e,"template.yaml")),containingJavaScript:j.default.sync("@(app|src|__tests__)/**/*.js?(x)",{cwd:e}).length>0,containingTypeScript:j.default.sync("@(app|src|__tests__)/**/*.ts?(x)",{cwd:e}).length>0,containingJsxOrTsx:j.default.sync("@(app|src|__tests__)/**/*.{t,j}sx",{cwd:e}).length>0,containingJavaScriptInPackages:j.default.sync("packages/**/@(app|src|__tests__)/**/*.js?(x)",{cwd:e}).length>0,containingTypeScriptInPackages:j.default.sync("packages/**/@(app|src|__tests__)/**/*.ts?(x)",{cwd:e}).length>0,containingJsxOrTsxInPackages:j.default.sync("packages/**/@(app|src|__tests__)/**/*.{t,j}sx",{cwd:e}).length>0,depending:{blitz:!!(r.blitz||i.blitz),firebase:!!i["firebase-tools"],jestPlaywrightPreset:!!i["jest-playwright-preset"],prisma:!!i.prisma,reactNative:!!r["react-native"],semanticRelease:!!i["semantic-release"],storybook:!!i["@storybook/react"]},release:{branches:m,github:s.includes("@semantic-release/github"),npm:s.includes("@semantic-release/npm")},requiringNodeModules:a,versionsText:de};if(k.eslintBase=Mt(k),k.containingGemfile||k.containingGoMod||k.containingPackageJson||k.containingPoetryLock||k.containingPomXml||k.containingPubspecYaml||k.containingTemplateYaml)return k}catch{}return null}function Mt(e){if(e.containingTypeScript)return e.containingJsxOrTsx?"@willbooster/eslint-config-ts-react":"@willbooster/eslint-config-ts";if(e.containingJsxOrTsx)return"@willbooster/eslint-config-js-react";if(e.containingJavaScript)return"@willbooster/eslint-config-js"}async function zt(e,n){var a,m,s;let t=((a=n.repository)==null?void 0:a.url)??n.repository;if(typeof t=="string"){let f=await rt(t);if(f)return f}let i=(await(0,at.default)(e).getRemotes(!0)).find(f=>f.name==="origin"),c=((m=i==null?void 0:i.refs)==null?void 0:m.fetch)??((s=i==null?void 0:i.refs)==null?void 0:s.push);if(typeof c=="string"){let f=await rt(c);if(f)return f}}async function rt(e){var s;let n=e.split(":").at(-1),t=n==null?void 0:n.split("/"),o=t==null?void 0:t.at(-2),r=(s=t==null?void 0:t.at(-1))==null?void 0:s.replace(/.git$/,"");if(!o||!r)return;let i=process.env.GH_TOKEN||process.env.GITHUB_TOKEN,c=i?{headers:{Authorization:`token ${i}`}}:void 0,m=await(await z(`https://api.github.com/repos/${o}/${r}`,c)).json();return C({full_name:`${o}/${r}`},m??{})}async function Ut(){let e=await(0,ct.default)(process.argv.slice(2)).command("wbfy <paths...>","Generate/update project files for WillBooster").demandCommand(1).alias("d","skipDeps").boolean("skipDeps").default("skipDeps",!1).describe("skipDeps","Skip dependency installation").alias("v","verbose").boolean("verbose").default("verbose",!1).argv;for(let n of e._){if(typeof n=="number")continue;let t=await fe(n);if(t===null){console.error(`there is no valid package.json in ${n}`);continue}let o=t.containingSubPackageJsons?pt.default.sync("packages/*",{cwd:n}).map(s=>lt.default.resolve(n,s)):[],r=(await Promise.all(o.map(s=>fe(s)))).filter(s=>!!s),i=[t,...r],c=[t,...r.filter(s=>s.containingPackageJson)];if(e.verbose)for(let s of i)console.log(s);let a=i.map(s=>Re(s,t));await ot(t),a.push(be(t),Te(t),Ee(t),De(t),re(t),Ae(t),Le(t),qe(t),Pe(t),nt(t)),await Promise.all(a),await p.promiseAll();let m=[];for(let s of c)m.push(Me(s),re(s)),(s.containingTypeScript||s.containingTypeScriptInPackages)&&m.push(Qe(s,t)),(s.containingJavaScript||s.containingJavaScriptInPackages||s.containingTypeScript||s.containingTypeScriptInPackages)&&(t.willBoosterConfigs||m.push($e(s,t)),m.push(xe(s)));await Promise.all(m),await p.promiseAll();for(let s of c)await Be(s,t,e.skipDeps);h("yarn",["cleanup"],n),h("yarn",["install"],n)}}Ut().then();
247
247
  //# sourceMappingURL=index.min.cjs.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../src/index.ts", "../src/generators/asdf.ts", "../src/utils/promisePool.ts", "../src/generators/editorconfig.ts", "../src/utils/extensions.ts", "../src/utils/fsUtil.ts", "../src/generators/eslintignore.ts", "../src/utils/ignoreFileUtil.ts", "../src/generators/eslintrc.ts", "../src/utils/mergeUtil.ts", "../src/generators/gitattributes.ts", "../src/generators/gitignore.ts", "../src/utils/fetchOnNode.ts", "../src/generators/huskyrc.ts", "../src/utils/spawnUtil.ts", "../src/generators/idea.ts", "../src/generators/lintstagedrc.ts", "../src/utils/eslintUtil.ts", "../src/generators/packageJson.ts", "../src/generators/prettierignore.ts", "../src/generators/releaserc.ts", "../src/generators/renovaterc.ts", "../src/generators/semanticRelease.ts", "../src/generators/tsconfig.ts", "../src/utils/objectUtil.ts", "../src/generators/workflow.ts", "../src/generators/yarnrc.ts", "../src/utils/packageConfig.ts"],
4
- "sourcesContent": ["import path from 'path';\n\nimport glob from 'glob';\nimport yargs from 'yargs';\n\nimport { generateVersionConfigs } from './generators/asdf';\nimport { generateEditorconfig } from './generators/editorconfig';\nimport { generateEslintignore } from './generators/eslintignore';\nimport { generateEslintrc } from './generators/eslintrc';\nimport { generateGitattributes } from './generators/gitattributes';\nimport { generateGitignore } from './generators/gitignore';\nimport { generateHuskyrc } from './generators/huskyrc';\nimport { generateIdeaSettings } from './generators/idea';\nimport { generateLintstagedrc } from './generators/lintstagedrc';\nimport { generatePackageJson } from './generators/packageJson';\nimport { generatePrettierignore } from './generators/prettierignore';\nimport { generateReleaserc } from './generators/releaserc';\nimport { generateRenovateJson } from './generators/renovaterc';\nimport { generateSemanticYml } from './generators/semanticRelease';\nimport { generateTsconfig } from './generators/tsconfig';\nimport { generateWorkflow } from './generators/workflow';\nimport { generateYarnrcYml } from './generators/yarnrc';\nimport { getPackageConfig, PackageConfig } from './utils/packageConfig';\nimport { promisePool } from './utils/promisePool';\nimport { spawnSync } from './utils/spawnUtil';\n\nasync function main(): Promise<void> {\n const argv = await yargs(process.argv.slice(2))\n .command('wbfy <paths...>', 'Generate/update project files for WillBooster')\n .demandCommand(1)\n .alias('d', 'skipDeps')\n .boolean('skipDeps')\n .default('skipDeps', false)\n .describe('skipDeps', 'Skip dependency installation')\n .alias('v', 'verbose')\n .boolean('verbose')\n .default('verbose', false).argv;\n\n for (const rootDirPath of argv._) {\n if (typeof rootDirPath === 'number') continue;\n\n const rootConfig = await getPackageConfig(rootDirPath);\n if (rootConfig === null) {\n console.error(`there is no valid package.json in ${rootDirPath}`);\n continue;\n }\n\n const subDirPaths = rootConfig.containingSubPackageJsons\n ? glob.sync('packages/*', { cwd: rootDirPath }).map((subDirPath) => path.resolve(rootDirPath, subDirPath))\n : [];\n const subPackageConfigs = (await Promise.all(subDirPaths.map((subDirPath) => getPackageConfig(subDirPath)))).filter(\n (config) => !!config\n ) as PackageConfig[];\n const allPackageConfigs = [rootConfig, ...subPackageConfigs];\n const allNodePackageConfigs = [rootConfig, ...subPackageConfigs.filter((config) => config.containingPackageJson)];\n\n if (argv.verbose) {\n for (const config of allPackageConfigs) {\n console.log(config);\n }\n }\n\n const rootPromises = allPackageConfigs.map((config) => generateGitignore(config, rootConfig));\n // Install yarn berry at first\n await generateYarnrcYml(rootConfig);\n rootPromises.push(\n generateEditorconfig(rootConfig),\n generateGitattributes(rootConfig),\n generateHuskyrc(rootConfig),\n generateIdeaSettings(rootConfig),\n generateLintstagedrc(rootConfig),\n generateRenovateJson(rootConfig),\n generateReleaserc(rootConfig),\n generateSemanticYml(rootConfig),\n generateVersionConfigs(rootConfig),\n generateWorkflow(rootConfig)\n );\n await Promise.all(rootPromises);\n await promisePool.promiseAll();\n\n const promises: Promise<void>[] = [];\n for (const config of allNodePackageConfigs) {\n promises.push(generatePrettierignore(config), generateLintstagedrc(config));\n if (config.containingTypeScript || config.containingTypeScriptInPackages) {\n promises.push(generateTsconfig(config, rootConfig));\n }\n if (\n config.containingJavaScript ||\n config.containingJavaScriptInPackages ||\n config.containingTypeScript ||\n config.containingTypeScriptInPackages\n ) {\n if (!rootConfig.willBoosterConfigs) {\n promises.push(generateEslintrc(config, rootConfig));\n }\n promises.push(generateEslintignore(config));\n }\n }\n await Promise.all(promises);\n await promisePool.promiseAll();\n\n for (const config of allNodePackageConfigs) {\n await generatePackageJson(config, rootConfig, argv.skipDeps);\n }\n spawnSync('yarn', ['cleanup'], rootDirPath);\n // 'yarn install' should be after `yarn cleanup` because yarn berry generates yarn.lock\n // corresponding to the contents of dependant sub-package in monorepo\n spawnSync('yarn', ['install'], rootDirPath);\n }\n}\n\nmain().then();\n", "import fs from 'fs';\nimport path from 'path';\n\nimport { PackageConfig } from '../utils/packageConfig';\nimport { promisePool } from '../utils/promisePool';\n\nexport async function generateVersionConfigs(config: PackageConfig): Promise<void> {\n if (!config.versionsText) return;\n\n const lines: string[] = [];\n for (const versionText of config.versionsText.split('\\n')) {\n const line = versionText.trim();\n if (!line.startsWith('nodejs')) {\n lines.push(line);\n continue;\n }\n\n const [, version] = line.split(/\\s+/);\n await promisePool.run(() => fs.promises.writeFile(path.resolve(config.dirPath, '.node-version'), version));\n }\n\n const toolVersionsPath = path.resolve(config.dirPath, '.tool-versions');\n if (lines.length) {\n await promisePool.run(() => fs.promises.writeFile(toolVersionsPath, lines.join('\\n')));\n } else {\n await promisePool.run(() => fs.promises.rm(toolVersionsPath, { force: true }));\n }\n}\n", "import { PromisePool } from 'minimal-promise-pool';\n\nexport const promisePool = new PromisePool();\n", "import path from 'path';\n\nimport { Extensions } from '../utils/extensions';\nimport { FsUtil } from '../utils/fsUtil';\nimport { PackageConfig } from '../utils/packageConfig';\nimport { promisePool } from '../utils/promisePool';\n\nconst newContent = `root = true\n\n[*]\ncharset = utf-8\nend_of_line = lf\ninsert_final_newline = true\ntrim_trailing_whitespace = true\n\n${generateExtensions(Extensions.codeWith2IndentSize)}\nindent_size = 2\nindent_style = space\n\n${generateExtensions(Extensions.codeWith4IndentSize)}\nindent_size = 4\nindent_style = space\n\n${generateExtensions(Extensions.codeWith8IndentSize)}\nindent_size = 8\nindent_style = space\n\n${generateExtensions(Extensions.markdownLike)}\nmax_line_length = off\ntrim_trailing_whitespace = false\n\n[{Makefile,*.mk}]\nindent_style = tab\n`;\n\nexport async function generateEditorconfig(config: PackageConfig): Promise<void> {\n const filePath = path.resolve(config.dirPath, '.editorconfig');\n await promisePool.run(() => FsUtil.generateFile(filePath, newContent));\n}\n\nfunction generateExtensions(extensions: string[]): string {\n return extensions.length > 1 ? `[*.{${extensions.join(',')}}]` : `[*.${extensions[0]}]`;\n}\n", "export const Extensions = {\n codeWith2IndentSize: [\n 'cjs',\n 'mjs',\n 'js',\n 'jsx',\n 'ts',\n 'tsx',\n 'json',\n 'json5',\n 'cpp',\n 'dart',\n 'htm',\n 'html',\n 'pu',\n 'puml',\n 'rb',\n 'vue',\n 'yaml',\n 'yml',\n ].sort(),\n codeWith4IndentSize: ['go', 'gradle', 'py'].sort(),\n codeWith8IndentSize: ['sh'].sort(),\n markdownLike: ['md'].sort(),\n eslint: ['cjs', 'mjs', 'js', 'ts', 'tsx', 'jsx'].sort(),\n prettier: [\n 'cjs',\n 'mjs',\n 'js',\n 'jsx',\n 'ts',\n 'tsx',\n 'json',\n 'json5',\n 'css',\n 'htm',\n 'html',\n 'md',\n 'scss',\n 'vue',\n 'yaml',\n 'yml',\n ].sort(),\n};\n", "import fsp from 'fs/promises';\n\nexport const FsUtil = {\n async generateFile(filePath: string, content: string): Promise<void> {\n await fsp.writeFile(filePath, content);\n console.log(`Generated ${filePath}`);\n },\n};\n", "import path from 'path';\n\nimport { FsUtil } from '../utils/fsUtil';\nimport { IgnoreFileUtil } from '../utils/ignoreFileUtil';\nimport { PackageConfig } from '../utils/packageConfig';\nimport { promisePool } from '../utils/promisePool';\n\nconst defaultUserContent = `${IgnoreFileUtil.header}\n\n\n${IgnoreFileUtil.separator}\n`;\n\nconst commonContent = `\n3rd-party/\n@types/\n__generated__/\nandroid/\nios/\nno-format/\ntest-fixtures/\n*.config.js\n*.d.ts\n*.min.js\n.yarn/\n.pnp.js\n`;\n\nexport async function generateEslintignore(config: PackageConfig): Promise<void> {\n const filePath = path.resolve(config.dirPath, '.eslintignore');\n const userContent = IgnoreFileUtil.getUserContent(filePath) || defaultUserContent;\n\n const gitignoreFilePath = path.resolve(config.dirPath, '.gitignore');\n const gitignoreContent = IgnoreFileUtil.getExistingContent(gitignoreFilePath) || '';\n\n const newContent = userContent + commonContent + gitignoreContent;\n await promisePool.run(() => FsUtil.generateFile(filePath, newContent));\n}\n", "import fs from 'fs';\n\nexport const IgnoreFileUtil = {\n header: '# Project-specific settings',\n separator: '# Generated by @willbooster/willboosterify',\n separatorPrefix: '# Generated by @willbooster',\n getExistingContent(filePath: string): string | null {\n if (fs.existsSync(filePath)) {\n return fs\n .readFileSync(filePath)\n .toString()\n .replace(/# Project-specific settings[^\\n]*\\n/m, '')\n .replace(/# Generated by[^\\n]*\\n/m, '')\n .replace(/\\r?\\n\\r?\\n(\\r?\\n)+/gm, '\\n\\n');\n }\n return null;\n },\n getUserContent(filePath: string): string | null {\n if (fs.existsSync(filePath)) {\n const existingContent = fs.readFileSync(filePath, 'utf-8');\n const index = existingContent.indexOf(this.separatorPrefix);\n if (index >= 0) {\n return existingContent.substr(0, existingContent.indexOf('\\n', index) + 1);\n }\n }\n return null;\n },\n isBerryZeroInstallEnabled(filePath: string): boolean {\n if (fs.existsSync(filePath)) {\n const existingContent = fs.readFileSync(filePath, 'utf-8');\n return existingContent.includes('\\n!.yarn/cache');\n }\n return false;\n },\n};\n", "import fs from 'fs';\nimport path from 'path';\n\nimport merge from 'deepmerge';\n\nimport { FsUtil } from '../utils/fsUtil';\nimport { combineMerge } from '../utils/mergeUtil';\nimport { PackageConfig } from '../utils/packageConfig';\nimport { promisePool } from '../utils/promisePool';\n\nexport async function generateEslintrc(config: PackageConfig, rootConfig: PackageConfig): Promise<void> {\n const bases = [];\n if (config.eslintBase) {\n bases.push(config.eslintBase);\n }\n if (config !== rootConfig) {\n bases.push('../../.eslintrc.json');\n }\n let newSettings: any = { root: true, extends: bases };\n\n const filePath = path.resolve(config.dirPath, '.eslintrc.json');\n try {\n const oldContent = await fs.promises.readFile(filePath, 'utf-8');\n const oldSettings = JSON.parse(oldContent);\n if (oldSettings.extends) {\n oldSettings.extends = oldSettings.extends.filter(\n (ext: string) => !ext.startsWith('@willbooster/') && ext !== '../../.eslintrc.json'\n );\n }\n if (!bases.length) {\n oldSettings.extends = [];\n }\n const newExtends = newSettings.extends;\n newSettings.extends = oldSettings.extends;\n oldSettings.extends = newExtends;\n newSettings = merge.all([newSettings, oldSettings, newSettings], { arrayMerge: combineMerge });\n if (config.depending.blitz) {\n newSettings.extends = [...newSettings.extends.filter((e: string) => e !== 'blitz'), 'blitz'];\n }\n } catch (e) {\n // do nothing\n }\n const newContent = JSON.stringify(newSettings);\n await promisePool.run(() => FsUtil.generateFile(filePath, newContent));\n}\n", "import merge from 'deepmerge';\n\nexport function overwriteMerge(destinationArray: any[], sourceArray: any[]): any[] {\n return sourceArray;\n}\n\n// eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\nexport function combineMerge(target: any[], source: any[], options: any): any[] {\n const destination = target.slice();\n\n source.forEach((item, index) => {\n if (typeof destination[index] === 'undefined') {\n destination[index] = options.cloneUnlessOtherwiseSpecified(item, options);\n } else if (options.isMergeableObject(item)) {\n destination[index] = merge(target[index], item, options);\n } else if (target.indexOf(item) === -1) {\n destination.push(item);\n }\n });\n return destination;\n}\n", "import path from 'path';\n\nimport { Extensions } from '../utils/extensions';\nimport { FsUtil } from '../utils/fsUtil';\nimport { PackageConfig } from '../utils/packageConfig';\nimport { promisePool } from '../utils/promisePool';\n\nconst newContent = `* text=auto\n\n*.vcproj text eol=crlf\n\n${Extensions.codeWith2IndentSize\n .concat(Extensions.codeWith4IndentSize)\n .concat(Extensions.markdownLike)\n .map((ext) => `*.${ext} text eol=lf`)\n .join('\\n')}\n`;\n\nexport async function generateGitattributes(config: PackageConfig): Promise<void> {\n const filePath = path.resolve(config.dirPath, '.gitattributes');\n await promisePool.run(() => FsUtil.generateFile(filePath, newContent));\n}\n", "import path from 'path';\n\nimport { fetchOnNode } from '../utils/fetchOnNode';\nimport { FsUtil } from '../utils/fsUtil';\nimport { IgnoreFileUtil } from '../utils/ignoreFileUtil';\nimport { PackageConfig } from '../utils/packageConfig';\nimport { promisePool } from '../utils/promisePool';\n\nconst defaultNames = ['windows', 'macos', 'linux', 'jetbrains', 'visualstudiocode', 'emacs', 'vim', 'yarn'];\n\nconst defaultUserContent = `${IgnoreFileUtil.header}\n\n\n${IgnoreFileUtil.separator}\n`;\n\nconst commonContent = `\n.devcontainer/\ndist/\ntemp/\nIcon[\\r]\n`;\n\nexport async function generateGitignore(config: PackageConfig, rootConfig: PackageConfig): Promise<void> {\n const filePath = path.resolve(config.dirPath, '.gitignore');\n let userContent = (IgnoreFileUtil.getUserContent(filePath) || defaultUserContent) + commonContent;\n\n const names = [...defaultNames];\n if (config.containingGemfile) {\n names.push('ruby');\n }\n if (config.containingGoMod) {\n names.push('go');\n userContent += `${path.basename(config.dirPath)}\n`;\n }\n if (config.containingPackageJson) {\n names.push('node');\n }\n if (config.containingPomXml) {\n names.push('maven');\n userContent += `.idea/google-java-format.xml\n`;\n }\n if (config.containingPubspecYaml) {\n names.push('flutter', 'AndroidStudio', 'ruby');\n userContent += `.flutter-plugins-dependencies\nandroid/key.properties\nios/.bundle\n.idea/runConfigurations.xml\n`;\n }\n if (config.containingTemplateYaml) {\n userContent += `.aws-sam/\npackaged.yaml\n`;\n }\n // Because .venv should be ignored on root directory\n if (config.containingPoetryLock) {\n names.push('python');\n }\n if (rootConfig.depending.firebase || config.depending.firebase) {\n names.push('firebase');\n }\n if (rootConfig.depending.reactNative || config.depending.reactNative) {\n names.push('reactnative');\n userContent += `google-services.json\nandroid/app/src/main/assets/\n`;\n }\n if (rootConfig.depending.storybook) {\n names.push('storybookjs');\n }\n\n let generated = (\n await Promise.all(\n names.map(async (name) => {\n const response = await fetchOnNode(`https://www.toptal.com/developers/gitignore/api/${name}`);\n return await response.text();\n })\n )\n ).join('');\n if (!IgnoreFileUtil.isBerryZeroInstallEnabled(filePath)) {\n generated = generated.replace('!.yarn/cache', '# !.yarn/cache').replace('# .pnp.*', '.pnp.*');\n }\n if (config.containingPomXml || config.containingPubspecYaml) {\n generated = generated\n .replace(/^# .idea\\/artifacts$/gm, '.idea/artifacts')\n .replace(/^# .idea\\/compiler.xml$/gm, '.idea/compiler.xml')\n .replace(/^# .idea\\/jarRepositories.xml$/gm, '.idea/jarRepositories.xml')\n .replace(/^# .idea\\/modules.xml$/gm, '.idea/modules.xml')\n .replace(/^# .idea\\/*.iml$/gm, '.idea/*.iml')\n .replace(/^# .idea\\/modules$/gm, '.idea/modules')\n .replace(/^# *.iml$/gm, '*.iml')\n .replace(/^# *.ipr$/gm, '*.ipr');\n if (config.containingPubspecYaml) {\n generated = generated.replace(/^.idea\\/modules.xml$/gm, '# .idea/modules.xml');\n }\n }\n generated = generated.replace(/^.idea\\/?$/gm, '# .idea');\n if (rootConfig.depending.reactNative || config.depending.reactNative || config.containingPubspecYaml) {\n generated = generated.replace(/^(.idea\\/.+)$/gm, '$1\\nandroid/$1');\n }\n const newContent = userContent + generated;\n await promisePool.run(() => FsUtil.generateFile(filePath, newContent));\n}\n", "import type { RequestInfo, RequestInit, Response } from 'node-fetch';\n\nexport async function fetchOnNode(url: RequestInfo, init?: RequestInit | undefined): Promise<Response> {\n const { default: nodeFetch } = await import('node-fetch');\n return nodeFetch(url, init);\n}\n", "import fs from 'fs';\nimport path from 'path';\n\nimport { PackageConfig } from '../utils/packageConfig';\nimport { promisePool } from '../utils/promisePool';\nimport { spawnSync } from '../utils/spawnUtil';\n\nconst DEFAULT_COMMAND = 'npm test';\n\nconst settings = {\n preCommit: 'yarn lint-staged',\n prePush: 'yarn typecheck',\n postMerge: 'yarn',\n};\n\nexport async function generateHuskyrc(config: PackageConfig): Promise<void> {\n const packageJsonPath = path.resolve(config.dirPath, 'package.json');\n const jsonText = await fs.promises.readFile(packageJsonPath, 'utf-8');\n const packageJson = JSON.parse(jsonText);\n packageJson.scripts ||= {};\n delete packageJson.scripts['postinstall'];\n delete packageJson.scripts['postpublish'];\n delete packageJson.scripts['prepare'];\n delete packageJson.scripts['prepublishOnly'];\n delete packageJson.scripts['prepack'];\n delete packageJson.scripts['postpack'];\n\n const dirPath = path.resolve(config.dirPath, '.husky');\n await Promise.all([\n fs.promises.writeFile(packageJsonPath, JSON.stringify(packageJson, undefined, 2)),\n fs.promises.rm(dirPath, { force: true, recursive: true }),\n ]);\n spawnSync('yarn', ['dlx', 'husky-init', '--yarn2'], config.dirPath);\n\n const preCommitFilePath = path.resolve(dirPath, 'pre-commit');\n const content = await fs.promises.readFile(preCommitFilePath, 'utf-8');\n\n await promisePool.run(() => fs.promises.rm(path.resolve(config.dirPath, '.huskyrc.json'), { force: true }));\n await promisePool.run(() =>\n fs.promises.writeFile(preCommitFilePath, content.replace(DEFAULT_COMMAND, settings.preCommit))\n );\n\n if (config.containingTypeScript || config.containingTypeScriptInPackages) {\n await promisePool.run(() =>\n fs.promises.writeFile(path.resolve(dirPath, 'pre-push'), content.replace(DEFAULT_COMMAND, settings.prePush), {\n mode: 0o755,\n })\n );\n }\n\n const postMergeCommands: string[] = [];\n if (config.versionsText?.includes('python ')) {\n postMergeCommands.push('asdf install python');\n }\n if (config.versionsText) {\n postMergeCommands.push('asdf install');\n }\n postMergeCommands.push(settings.postMerge);\n if (config.versionsText?.includes('poetry ')) {\n postMergeCommands.push('poetry install');\n }\n if (config.depending.blitz) {\n postMergeCommands.push('yarn blitz codegen');\n } else if (config.depending.prisma) {\n postMergeCommands.push('yarn prisma generate');\n }\n const postMergeCommand = content.replace(DEFAULT_COMMAND, postMergeCommands.join(' && '));\n await promisePool.run(() =>\n fs.promises.writeFile(path.resolve(dirPath, 'post-merge'), postMergeCommand, {\n mode: 0o755,\n })\n );\n}\n", "import child_process from 'child_process';\n\nexport function spawnSync(command: string, args: string[], cwd: string, retry = 0): void {\n do {\n const [commandAndArgs, options] = getSpawnSyncArgs(command, args, cwd);\n console.log(`$ ${commandAndArgs} at ${options.cwd}`);\n const ret = child_process.spawnSync(commandAndArgs, options);\n if (ret.status === 0) break;\n } while (--retry >= 0);\n}\n\nexport function spawnSyncWithStringResult(command: string, args: string[], cwd: string): string {\n const [commandAndArgs, options] = getSpawnSyncArgs(command, args, cwd);\n options.stdio = 'pipe';\n const proc = child_process.spawnSync(commandAndArgs, options);\n return proc.stdout.toString().trim();\n}\n\nexport function getSpawnSyncArgs(command: string, args: string[], cwd: string): [string, any] {\n let commandAndArgs = `${command} ${args.join(' ')}`;\n if (process.env.ASDF_DIR) {\n commandAndArgs = `bash -l -c '. ${process.env.ASDF_DIR}/asdf.sh && ${commandAndArgs}'`;\n }\n return [\n commandAndArgs,\n {\n cwd,\n env: {\n PATH: process.env.PATH,\n },\n shell: true,\n stdio: 'inherit',\n },\n ];\n}\n", "import fs from 'fs';\nimport path from 'path';\n\nimport { FsUtil } from '../utils/fsUtil';\nimport { PackageConfig } from '../utils/packageConfig';\nimport { promisePool } from '../utils/promisePool';\n\nconst newContent = `<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<project version=\"4\">\n <component name=\"ProjectTasksOptions\">\n <TaskOptions isEnabled=\"true\">\n <option name=\"arguments\" value=\"prettier --write $FilePathRelativeToProjectRoot$\" />\n <option name=\"checkSyntaxErrors\" value=\"false\" />\n <option name=\"description\" />\n <option name=\"exitCodeBehavior\" value=\"ERROR\" />\n <option name=\"fileExtension\" value=\"ts\" />\n <option name=\"immediateSync\" value=\"false\" />\n <option name=\"name\" value=\"Prettier (.ts)\" />\n <option name=\"output\" value=\"$FilePathRelativeToProjectRoot$\" />\n <option name=\"outputFilters\">\n <array />\n </option>\n <option name=\"outputFromStdout\" value=\"false\" />\n <option name=\"program\" value=\"yarn\" />\n <option name=\"runOnExternalChanges\" value=\"false\" />\n <option name=\"scopeName\" value=\"Project Files\" />\n <option name=\"trackOnlyRoot\" value=\"false\" />\n <option name=\"workingDir\" value=\"$ProjectFileDir$\" />\n <envs />\n </TaskOptions>\n <TaskOptions isEnabled=\"true\">\n <option name=\"arguments\" value=\"prettier --write $FilePathRelativeToProjectRoot$\" />\n <option name=\"checkSyntaxErrors\" value=\"false\" />\n <option name=\"description\" />\n <option name=\"exitCodeBehavior\" value=\"ERROR\" />\n <option name=\"fileExtension\" value=\"tsx\" />\n <option name=\"immediateSync\" value=\"false\" />\n <option name=\"name\" value=\"Prettier (.tsx)\" />\n <option name=\"output\" value=\"$FilePathRelativeToProjectRoot$\" />\n <option name=\"outputFilters\">\n <array />\n </option>\n <option name=\"outputFromStdout\" value=\"false\" />\n <option name=\"program\" value=\"yarn\" />\n <option name=\"runOnExternalChanges\" value=\"false\" />\n <option name=\"scopeName\" value=\"Project Files\" />\n <option name=\"trackOnlyRoot\" value=\"false\" />\n <option name=\"workingDir\" value=\"$ProjectFileDir$\" />\n <envs />\n </TaskOptions>\n <TaskOptions isEnabled=\"true\">\n <option name=\"arguments\" value=\"prettier --write $FilePathRelativeToProjectRoot$\" />\n <option name=\"checkSyntaxErrors\" value=\"false\" />\n <option name=\"description\" />\n <option name=\"exitCodeBehavior\" value=\"ERROR\" />\n <option name=\"fileExtension\" value=\"js\" />\n <option name=\"immediateSync\" value=\"false\" />\n <option name=\"name\" value=\"Prettier (.js)\" />\n <option name=\"output\" value=\"$FilePathRelativeToProjectRoot$\" />\n <option name=\"outputFilters\">\n <array />\n </option>\n <option name=\"outputFromStdout\" value=\"false\" />\n <option name=\"program\" value=\"yarn\" />\n <option name=\"runOnExternalChanges\" value=\"false\" />\n <option name=\"scopeName\" value=\"Project Files\" />\n <option name=\"trackOnlyRoot\" value=\"false\" />\n <option name=\"workingDir\" value=\"$ProjectFileDir$\" />\n <envs />\n </TaskOptions>\n <TaskOptions isEnabled=\"true\">\n <option name=\"arguments\" value=\"prettier --write $FilePathRelativeToProjectRoot$\" />\n <option name=\"checkSyntaxErrors\" value=\"false\" />\n <option name=\"description\" />\n <option name=\"exitCodeBehavior\" value=\"ERROR\" />\n <option name=\"fileExtension\" value=\"json\" />\n <option name=\"immediateSync\" value=\"false\" />\n <option name=\"name\" value=\"Prettier (.json)\" />\n <option name=\"output\" value=\"$FilePathRelativeToProjectRoot$\" />\n <option name=\"outputFilters\">\n <array />\n </option>\n <option name=\"outputFromStdout\" value=\"false\" />\n <option name=\"program\" value=\"yarn\" />\n <option name=\"runOnExternalChanges\" value=\"false\" />\n <option name=\"scopeName\" value=\"Project Files\" />\n <option name=\"trackOnlyRoot\" value=\"false\" />\n <option name=\"workingDir\" value=\"$ProjectFileDir$\" />\n <envs />\n </TaskOptions>\n <TaskOptions isEnabled=\"true\">\n <option name=\"arguments\" value=\"prettier --write $FilePathRelativeToProjectRoot$\" />\n <option name=\"checkSyntaxErrors\" value=\"false\" />\n <option name=\"description\" />\n <option name=\"exitCodeBehavior\" value=\"ERROR\" />\n <option name=\"fileExtension\" value=\"md\" />\n <option name=\"immediateSync\" value=\"false\" />\n <option name=\"name\" value=\"Prettier (.md)\" />\n <option name=\"output\" value=\"$FilePathRelativeToProjectRoot$\" />\n <option name=\"outputFilters\">\n <array />\n </option>\n <option name=\"outputFromStdout\" value=\"false\" />\n <option name=\"program\" value=\"yarn\" />\n <option name=\"runOnExternalChanges\" value=\"false\" />\n <option name=\"scopeName\" value=\"Project Files\" />\n <option name=\"trackOnlyRoot\" value=\"false\" />\n <option name=\"workingDir\" value=\"$ProjectFileDir$\" />\n <envs />\n </TaskOptions>\n <TaskOptions isEnabled=\"true\">\n <option name=\"arguments\" value=\"prettier --write $FilePathRelativeToProjectRoot$\" />\n <option name=\"checkSyntaxErrors\" value=\"false\" />\n <option name=\"description\" />\n <option name=\"exitCodeBehavior\" value=\"ERROR\" />\n <option name=\"fileExtension\" value=\"html\" />\n <option name=\"immediateSync\" value=\"false\" />\n <option name=\"name\" value=\"Prettier (.html)\" />\n <option name=\"output\" value=\"$FilePathRelativeToProjectRoot$\" />\n <option name=\"outputFilters\">\n <array />\n </option>\n <option name=\"outputFromStdout\" value=\"false\" />\n <option name=\"program\" value=\"yarn\" />\n <option name=\"runOnExternalChanges\" value=\"false\" />\n <option name=\"scopeName\" value=\"Project Files\" />\n <option name=\"trackOnlyRoot\" value=\"false\" />\n <option name=\"workingDir\" value=\"$ProjectFileDir$\" />\n <envs />\n </TaskOptions>\n </component>\n</project>\n`;\n\nexport async function generateIdeaSettings(config: PackageConfig): Promise<void> {\n const dirPath = path.resolve(config.dirPath, '.idea');\n if (fs.existsSync(dirPath)) {\n const filePath = path.resolve(dirPath, 'watcherTasks.xml');\n if (\n config.containingJavaScript ||\n config.containingJavaScriptInPackages ||\n config.containingTypeScript ||\n config.containingTypeScriptInPackages ||\n (config.containingPackageJson &&\n !config.containingPubspecYaml &&\n !config.containingGemfile &&\n !config.containingGoMod &&\n !config.containingPomXml)\n ) {\n await promisePool.run(() => FsUtil.generateFile(filePath, newContent));\n } else {\n await promisePool.run(() => fs.promises.rm(filePath, { force: true }));\n }\n }\n}\n", "import fs from 'fs';\nimport path from 'path';\n\nimport { EslintUtil } from '../utils/eslintUtil';\nimport { Extensions } from '../utils/extensions';\nimport { FsUtil } from '../utils/fsUtil';\nimport { PackageConfig } from '../utils/packageConfig';\nimport { promisePool } from '../utils/promisePool';\n\nconst eslintKey = `./{src,__tests__}/**/*.{${Extensions.eslint.join(',')}}`;\nconst eslintFilterForPrettier = `files = micromatch.not(files, '${eslintKey}');`;\n\nexport async function generateLintstagedrc(config: PackageConfig): Promise<void> {\n const lines: string[] = [];\n if (config.containingJavaScript || config.containingTypeScript) {\n const eslint = `\n '${eslintKey}': [${JSON.stringify(`eslint --fix${EslintUtil.getLintFixSuffix(config)}`)}, 'prettier --write'],`;\n lines.push(eslint);\n }\n const packagesFilter = config.root ? \" && !file.includes('/packages/')\" : '';\n lines.push(`\n './**/*.{${Extensions.prettier.join(',')}}': files => {\n ${config.containingJavaScript || config.containingTypeScript ? eslintFilterForPrettier : ''}\n const filteredFiles = files.filter(file => !file.includes('/test-fixtures/')${packagesFilter});\n if (filteredFiles.length === 0) return [];\n const commands = [\\`prettier --write \\${filteredFiles.join(' ')}\\`];\n if (filteredFiles.some(file => file.endsWith('package.json'))) {\n commands.push('yarn sort-package-json');\n }\n return commands;\n },`);\n if (config.containingPubspecYaml) {\n lines.push(`\n './{lib,test,test_driver}/**/*.dart': files => {\n const filteredFiles = files.filter(file => !file.includes('generated'))\n .filter(file => !file.endsWith('.freezed.dart') && !file.endsWith('.g.dart'));\n if (filteredFiles.length === 0) return [];\n return [\\`flutter format \\${filteredFiles.join(' ')}\\`];\n },`);\n }\n if (config.containingPoetryLock) {\n lines.push(`\n './**/*.py': [\n 'poetry run isort --profile black --filter-files',\n 'poetry run black',\n 'poetry run flake8'\n ],`);\n }\n\n const newContent = `${\n config.containingJavaScript || config.containingTypeScript ? \"const micromatch = require('micromatch');\" : ''\n }\n\nmodule.exports = {${lines.join('')}\n};\n`;\n\n const filePath = path.resolve(config.dirPath, '.lintstagedrc.cjs');\n await promisePool.run(() => fs.promises.rm(path.resolve(config.dirPath, '.lintstagedrc.js'), { force: true }));\n await promisePool.run(() => fs.promises.rm(path.resolve(config.dirPath, '.lintstagedrc.json'), { force: true }));\n await promisePool.run(() => FsUtil.generateFile(filePath, newContent));\n}\n", "import { PackageConfig } from './packageConfig';\n\nexport const EslintUtil = {\n getLintFixSuffix(config: PackageConfig): string {\n return config.containingJsxOrTsx ? ' --rule \"{ react-hooks/exhaustive-deps: 0 }\"' : '';\n },\n};\n", "import fs from 'fs';\nimport path from 'path';\n\nimport merge from 'deepmerge';\n\nimport { EslintUtil } from '../utils/eslintUtil';\nimport { Extensions } from '../utils/extensions';\nimport { IgnoreFileUtil } from '../utils/ignoreFileUtil';\nimport { PackageConfig } from '../utils/packageConfig';\nimport { promisePool } from '../utils/promisePool';\nimport { spawnSync } from '../utils/spawnUtil';\n\nconst scriptsWithoutWorkspace = {\n cleanup: 'yarn format && yarn lint-fix',\n format: `sort-package-json && yarn prettify`,\n lint: `eslint --color \"./{src,__tests__}/**/*.{${Extensions.eslint.join(',')}}\"`,\n 'lint-fix': 'yarn lint --fix',\n prettify: `prettier --color --write \"**/{.*/,}*.{${Extensions.prettier.join(',')}}\" \"!**/test-fixtures/**\"`,\n typecheck: 'tsc --noEmit --Pretty',\n};\n\nconst scriptsWithWorkspace = merge(\n { ...scriptsWithoutWorkspace },\n {\n format: `sort-package-json && yarn prettify && yarn workspaces foreach --parallel --verbose run format`,\n lint: `yarn workspaces foreach --parallel --verbose run lint`,\n 'lint-fix': 'yarn workspaces foreach --parallel --verbose run lint-fix',\n prettify: `prettier --color --write \"**/{.*/,}*.{${Extensions.prettier.join(\n ','\n )}}\" \"!**/packages/**\" \"!**/test-fixtures/**\"`,\n test: 'yarn workspaces foreach --verbose run test',\n typecheck: 'yarn workspaces foreach --parallel --verbose run typecheck',\n }\n);\n\nconst scriptsForBlitz = merge(\n { ...scriptsWithoutWorkspace },\n {\n lint: `eslint --color \"./**/*.{${Extensions.eslint.join(',')}}\"`,\n typecheck: `tsc --noEmit --Pretty || echo 'Please try \"yarn blitz codegen\" if you face unknown type errors.'`,\n }\n);\n\nconst jsCommonDeps = [\n 'eslint',\n 'eslint-config-prettier',\n 'eslint-plugin-import',\n 'eslint-plugin-sort-class-members',\n 'eslint-plugin-sort-destructure-keys',\n];\n\nconst tsCommonDeps = [\n ...jsCommonDeps,\n '@typescript-eslint/eslint-plugin',\n '@typescript-eslint/parser',\n 'eslint-import-resolver-typescript',\n];\n\nconst reactCommonDeps = ['eslint-plugin-react', 'eslint-plugin-react-hooks'];\n\nconst devDeps: { [prop: string]: string[] } = {\n '@willbooster/eslint-config-js': ['@willbooster/eslint-config-js', ...jsCommonDeps],\n '@willbooster/eslint-config-js-react': ['@willbooster/eslint-config-js-react', ...jsCommonDeps, ...reactCommonDeps],\n '@willbooster/eslint-config-ts': ['@willbooster/eslint-config-ts', ...tsCommonDeps],\n '@willbooster/eslint-config-ts-react': ['@willbooster/eslint-config-ts-react', ...tsCommonDeps, ...reactCommonDeps],\n '../../.eslintrc.json': [],\n};\n\nexport async function generatePackageJson(\n config: PackageConfig,\n rootConfig: PackageConfig,\n skipAddingDeps: boolean\n): Promise<void> {\n const filePath = path.resolve(config.dirPath, 'package.json');\n const jsonText = await fs.promises.readFile(filePath, 'utf-8');\n const jsonObj = JSON.parse(jsonText);\n jsonObj.scripts = jsonObj.scripts || {};\n jsonObj.dependencies = jsonObj.dependencies || {};\n jsonObj.devDependencies = jsonObj.devDependencies || {};\n jsonObj.peerDependencies = jsonObj.peerDependencies || {};\n\n await removeDeprecatedStuff(jsonObj);\n\n if (jsonObj.name !== '@willbooster/prettier-config') {\n jsonObj.prettier = '@willbooster/prettier-config';\n }\n\n for (const scriptKey of Object.keys(jsonObj.scripts)) {\n // Fresh repo still requires 'yarn install'\n if (!jsonObj.scripts[scriptKey].includes('git clone')) {\n jsonObj.scripts[scriptKey] = jsonObj.scripts[scriptKey]\n .replace(/yarn\\s*&&\\s*/, '')\n .replace(/yarn\\s*install\\s*&&\\s*/, '');\n }\n }\n\n jsonObj.scripts = merge(\n jsonObj.scripts,\n config.containingSubPackageJsons\n ? scriptsWithWorkspace\n : config.depending.blitz\n ? scriptsForBlitz\n : scriptsWithoutWorkspace\n );\n jsonObj.scripts.prettify += await generatePrettierSuffix(config.dirPath);\n\n let dependencies: string[] = [];\n let devDependencies = ['lint-staged', 'prettier', 'sort-package-json', '@willbooster/prettier-config'];\n const poetryDependencies: string[] = [];\n\n if (config.root) {\n // To install the latest pinst\n devDependencies.push('husky', 'pinst', '@willbooster/renovate-config');\n if (config.depending.semanticRelease) {\n devDependencies.push('conventional-changelog-conventionalcommits');\n }\n if (config.containingSubPackageJsons) {\n jsonObj.workspaces = ['packages/*'];\n } else {\n delete jsonObj.workspaces;\n }\n }\n\n if (\n config.containingJavaScript ||\n config.containingJavaScriptInPackages ||\n config.containingTypeScript ||\n config.containingTypeScriptInPackages\n ) {\n devDependencies.push('eslint', 'micromatch');\n if (config.containingTypeScriptInPackages) {\n devDependencies.push('@typescript-eslint/parser');\n }\n }\n\n if ((config.containingTypeScript || config.containingTypeScriptInPackages) && !config.depending.blitz) {\n devDependencies.push('typescript');\n }\n\n if (config.eslintBase) {\n devDependencies.push(...devDeps[config.eslintBase]);\n }\n\n if (config.willBoosterConfigs) {\n dependencies = dependencies.filter((dep) => !dep.includes('@willbooster/'));\n devDependencies = devDependencies.filter((dep) => !dep.includes('@willbooster/'));\n }\n\n if (!jsonObj.name) {\n jsonObj.name = path.basename(config.dirPath);\n }\n\n if (config.containingSubPackageJsons) {\n jsonObj.private = true;\n }\n\n if (!jsonObj.license) {\n jsonObj.license = 'UNLICENSED';\n }\n\n if (!config.containingTypeScript && !config.containingTypeScriptInPackages) {\n delete jsonObj.scripts.typecheck;\n }\n\n // https://github.com/semantic-release/semantic-release/issues/2323#issuecomment-1032341621\n if (config.depending.semanticRelease && config.release.npm) {\n jsonObj.resolutions ||= {};\n jsonObj.resolutions['npm/chalk'] = '^4.1.2';\n }\n\n if (!config.containingSubPackageJsons) {\n if (!config.containingJavaScript && !config.containingTypeScript) {\n delete jsonObj.scripts.lint;\n delete jsonObj.scripts['lint-fix'];\n jsonObj.scripts.cleanup = jsonObj.scripts.cleanup.replace(' && yarn lint-fix', '');\n } else {\n jsonObj.scripts['lint-fix'] += EslintUtil.getLintFixSuffix(config);\n }\n\n if (config.containingPubspecYaml) {\n jsonObj.scripts.lint = 'flutter analyze';\n jsonObj.scripts['lint-fix'] = 'yarn lint';\n const dirs = ['lib', 'test', 'test_driver'].filter((dir) => fs.existsSync(path.resolve(config.dirPath, dir)));\n if (dirs.length > 0) {\n jsonObj.scripts['format-code'] = `flutter format $(find ${dirs.join(\n ' '\n )} -name generated -prune -o -name '*.freezed.dart' -prune -o -name '*.g.dart' -prune -o -name '*.dart' -print)`;\n jsonObj.scripts.format += ` && yarn format-code`;\n }\n }\n\n if (config.containingPoetryLock) {\n if (jsonObj.scripts.postinstall === 'poetry install') {\n delete jsonObj.scripts.postinstall;\n }\n const dirNames = (await fs.promises.readdir(config.dirPath)).filter((dirName) => {\n const dirPath = path.resolve(config.dirPath, dirName);\n if (!fs.lstatSync(dirPath).isDirectory()) return false;\n return fs.readdirSync(dirPath).some((fileName) => fileName.endsWith('.py'));\n });\n if (dirNames.length > 0) {\n jsonObj.scripts['format-code'] = `poetry run isort --profile black ${dirNames.join(\n ' '\n )} && poetry run black ${dirNames.join(' ')}`;\n jsonObj.scripts.lint = `poetry run flake8 ${dirNames.join(' ')}`;\n jsonObj.scripts['lint-fix'] = 'yarn lint';\n jsonObj.scripts.format += ` && yarn format-code`;\n poetryDependencies.push('black', 'isort', 'flake8');\n }\n }\n\n if (config.repository) {\n jsonObj.repository = config.repository;\n }\n }\n\n if (config.depending.blitz) {\n // These cause an error of eslint-plugin-import loading\n devDependencies = devDependencies.filter((dep) => !dep.includes('@typescript-eslint/'));\n // This causes eslint errors\n devDependencies = devDependencies.filter((d) => d !== 'eslint-plugin-react');\n }\n if (!Object.keys(jsonObj.dependencies).length) {\n delete jsonObj.dependencies;\n }\n if (!Object.keys(jsonObj.devDependencies).length) {\n delete jsonObj.devDependencies;\n }\n if (!Object.keys(jsonObj.peerDependencies).length) {\n delete jsonObj.peerDependencies;\n }\n\n await fs.promises.writeFile(filePath, JSON.stringify(jsonObj));\n\n if (!skipAddingDeps) {\n if (dependencies.length && dependencies.some((dep) => !jsonObj.dependencies?.[dep])) {\n spawnSync('yarn', ['add', ...new Set(dependencies)], config.dirPath);\n }\n if (devDependencies.length) {\n spawnSync('yarn', ['add', '-D', ...new Set(devDependencies)], config.dirPath);\n }\n if (poetryDependencies.length) {\n spawnSync('poetry', ['add', ...new Set(poetryDependencies)], config.dirPath);\n }\n }\n}\n\nasync function removeDeprecatedStuff(jsonObj: any): Promise<void> {\n // TODO: remove the following migration code in future\n if (jsonObj.author === 'WillBooster LLC') {\n jsonObj.author = 'WillBooster Inc.';\n }\n delete jsonObj.scripts['sort-package-json'];\n delete jsonObj.scripts['sort-all-package-json'];\n delete jsonObj.dependencies['tslib'];\n delete jsonObj.devDependencies['@willbooster/eslint-config'];\n delete jsonObj.devDependencies['@willbooster/eslint-config-react'];\n delete jsonObj.devDependencies['@willbooster/tsconfig'];\n delete jsonObj.devDependencies['eslint-import-resolver-node'];\n delete jsonObj.devDependencies['eslint-plugin-prettier'];\n delete jsonObj.devDependencies['lerna'];\n // To install the latest pinst\n delete jsonObj.devDependencies['pinst'];\n delete jsonObj.scripts['flutter-format'];\n delete jsonObj.scripts['format-flutter'];\n delete jsonObj.scripts['python-format'];\n delete jsonObj.scripts['format-python'];\n delete jsonObj.scripts['prettier'];\n for (const deps of Object.values(devDeps)) {\n for (const dep of deps) {\n delete jsonObj.devDependencies[dep];\n }\n }\n await promisePool.run(() => fs.promises.rm('lerna.json', { force: true }));\n}\n\nasync function generatePrettierSuffix(dirPath: string): Promise<string> {\n const filePath = path.resolve(dirPath, '.prettierignore');\n const existingContent = await fs.promises.readFile(filePath, 'utf-8');\n const index = existingContent.indexOf(IgnoreFileUtil.separatorPrefix);\n if (index < 0) return '';\n\n const originalContent = existingContent.substring(0, index);\n const lines = originalContent\n .split('\\n')\n .map((line) => {\n const newLine = line.trim();\n return newLine.endsWith('/') ? newLine.slice(0, -1) : newLine;\n })\n .filter((l) => l && !l.startsWith('#') && !l.includes('/'));\n\n return lines.map((line) => ` \"!**/${line}/**\"`).join('');\n}\n", "import path from 'path';\n\nimport { FsUtil } from '../utils/fsUtil';\nimport { IgnoreFileUtil } from '../utils/ignoreFileUtil';\nimport { PackageConfig } from '../utils/packageConfig';\nimport { promisePool } from '../utils/promisePool';\n\nconst defaultUserContent = `${IgnoreFileUtil.header}\n\n\n${IgnoreFileUtil.separator}\n`;\n\nconst commonContent = `\n3rd-party/\nandroid/\nios/\nno-format/\ntest-fixtures/\n*.d.ts\n*.min.js\n.yarn/\n.pnp.js\n`;\n\nexport async function generatePrettierignore(config: PackageConfig): Promise<void> {\n const filePath = path.resolve(config.dirPath, '.prettierignore');\n const userContent = IgnoreFileUtil.getUserContent(filePath) || defaultUserContent;\n\n const gitignoreFilePath = path.resolve(config.dirPath, '.gitignore');\n const gitignoreContent = IgnoreFileUtil.getExistingContent(gitignoreFilePath) || '';\n\n let additionalContent = '';\n if (config.containingPubspecYaml) {\n additionalContent = `\nandroid/app/\nios/Runner/Assets.xcassets/\npubspec.yaml\n`;\n }\n\n const newContent = userContent + commonContent + additionalContent + gitignoreContent;\n await promisePool.run(() => FsUtil.generateFile(filePath, newContent));\n}\n", "import fs from 'fs';\nimport path from 'path';\n\nimport { FsUtil } from '../utils/fsUtil';\nimport { PackageConfig } from '../utils/packageConfig';\nimport { promisePool } from '../utils/promisePool';\n\nexport async function generateReleaserc(rootConfig: PackageConfig): Promise<void> {\n const filePath = path.resolve(rootConfig.dirPath, '.releaserc.json');\n try {\n const settings = JSON.parse(await fs.promises.readFile(filePath, 'utf8'));\n const plugins = settings?.plugins || [];\n for (let i = 0; i < plugins.length; i++) {\n if (plugins[i] === '@semantic-release/commit-analyzer' || plugins[i][0] === '@semantic-release/commit-analyzer') {\n plugins[i] = [\n '@semantic-release/commit-analyzer',\n {\n preset: 'conventionalcommits',\n },\n ];\n }\n }\n const newContent = JSON.stringify(settings);\n await promisePool.run(() => FsUtil.generateFile(filePath, newContent));\n } catch (_) {\n // do nothing\n }\n}\n", "import fs from 'fs';\nimport path from 'path';\n\nimport merge from 'deepmerge';\nimport cloneDeep from 'lodash.clonedeep';\n\nimport { FsUtil } from '../utils/fsUtil';\nimport { overwriteMerge } from '../utils/mergeUtil';\nimport { PackageConfig } from '../utils/packageConfig';\nimport { promisePool } from '../utils/promisePool';\n\nconst jsonObj = {\n extends: ['@willbooster'],\n};\n\nexport async function generateRenovateJson(config: PackageConfig): Promise<void> {\n let newSettings: any = cloneDeep(jsonObj);\n\n const filePath = path.resolve(config.dirPath, '.renovaterc.json');\n const oldContent = await fs.promises.readFile(filePath, 'utf-8');\n try {\n const oldSettings = JSON.parse(oldContent) as any;\n newSettings = merge.all([newSettings, oldSettings, newSettings], { arrayMerge: overwriteMerge });\n } catch (e) {\n // do nothing\n }\n await promisePool.run(() => fs.promises.rm(path.resolve(config.dirPath, '.dependabot'), { force: true }));\n await promisePool.run(() => fs.promises.rm(path.resolve(config.dirPath, 'renovate.json'), { force: true }));\n const newContent = JSON.stringify(newSettings);\n await promisePool.run(() => FsUtil.generateFile(filePath, newContent));\n}\n", "import fs from 'fs';\nimport path from 'path';\n\nimport yaml from 'js-yaml';\n\nimport { FsUtil } from '../utils/fsUtil';\nimport { PackageConfig } from '../utils/packageConfig';\nimport { promisePool } from '../utils/promisePool';\n\nconst newSettings = {\n titleOnly: true,\n};\n\nexport async function generateSemanticYml(rootConfig: PackageConfig): Promise<void> {\n const githubPath = path.resolve(rootConfig.dirPath, '.github');\n await fs.promises.mkdir(githubPath, { recursive: true });\n const filePath = path.join(githubPath, 'semantic.yml');\n const newContent = yaml.dump(newSettings);\n await promisePool.run(() => FsUtil.generateFile(filePath, newContent));\n}\n", "import fs from 'fs';\nimport path from 'path';\n\nimport merge from 'deepmerge';\nimport cloneDeep from 'lodash.clonedeep';\n\nimport { FsUtil } from '../utils/fsUtil';\nimport { overwriteMerge } from '../utils/mergeUtil';\nimport { sortKeys } from '../utils/objectUtil';\nimport { PackageConfig } from '../utils/packageConfig';\nimport { promisePool } from '../utils/promisePool';\n\nconst rootJsonObj = {\n compilerOptions: {\n target: 'esnext',\n module: 'esnext',\n moduleResolution: 'node',\n jsx: 'react',\n alwaysStrict: true,\n strict: true,\n skipLibCheck: true,\n allowSyntheticDefaultImports: true,\n esModuleInterop: true,\n resolveJsonModule: true,\n sourceMap: true,\n importHelpers: false,\n outDir: 'dist',\n },\n include: [\n 'src/**/*',\n '__tests__/**/*',\n 'packages/*/src/**/*',\n 'packages/*/__tests__/**/*',\n './node_modules/@types',\n './@types',\n ],\n};\n\nconst subJsonObj = {\n compilerOptions: {\n target: 'esnext',\n module: 'esnext',\n moduleResolution: 'node',\n jsx: 'react',\n alwaysStrict: true,\n strict: true,\n skipLibCheck: true,\n allowSyntheticDefaultImports: true,\n esModuleInterop: true,\n resolveJsonModule: true,\n sourceMap: true,\n importHelpers: false,\n outDir: 'dist',\n },\n include: ['src/**/*', '__tests__/**/*', '../../node_modules/@types', '../../@types', './@types'],\n};\n\nexport async function generateTsconfig(config: PackageConfig, rootConfig: PackageConfig): Promise<void> {\n if (rootConfig.depending.blitz) return;\n\n let newSettings: any = cloneDeep(config.root ? rootJsonObj : subJsonObj);\n if (!config.containingJsxOrTsx && !config.containingJsxOrTsxInPackages) {\n delete newSettings.compilerOptions.jsx;\n }\n if (config.root && !config.containingSubPackageJsons) {\n newSettings.include = newSettings.include.filter((dirPath: string) => !dirPath.startsWith('packages/*/'));\n }\n if (!config.root && (config.depending.jestPlaywrightPreset || rootConfig.depending.jestPlaywrightPreset)) {\n const relativeDirPath = path.relative(config.dirPath, rootConfig.dirPath);\n newSettings.include.push(\n ...[\n path.join(relativeDirPath, 'node_modules/jest-playwright-preset/types'),\n path.join(relativeDirPath, 'node_modules/expect-playwright'),\n ]\n );\n }\n\n const filePath = path.resolve(config.dirPath, 'tsconfig.json');\n try {\n const existingContent = await fs.promises.readFile(filePath, 'utf-8');\n const oldSettings = JSON.parse(existingContent);\n if (oldSettings.extends === './node_modules/@willbooster/tsconfig/tsconfig.json') {\n delete oldSettings.extends;\n }\n delete oldSettings.compilerOptions?.typeRoots;\n delete newSettings?.compilerOptions?.target;\n delete newSettings?.compilerOptions?.module;\n if (oldSettings.jsx) {\n delete newSettings.jsx;\n }\n if (!config.depending.blitz) {\n delete newSettings.include;\n }\n newSettings = merge.all([newSettings, oldSettings, newSettings], { arrayMerge: overwriteMerge });\n } catch (e) {\n // do nothing\n }\n sortKeys(newSettings.compilerOptions);\n const newContent = JSON.stringify(newSettings);\n await promisePool.run(() => FsUtil.generateFile(filePath, newContent));\n}\n", "export function sortKeys(obj: any): void {\n const keyAndValues = Object.entries(obj).sort(([key1], [key2]) => key1.localeCompare(key2));\n for (const [key, value] of keyAndValues) {\n delete obj[key];\n obj[key] = value;\n }\n}\n", "import fs from 'fs';\nimport path from 'path';\n\nimport merge from 'deepmerge';\nimport yaml from 'js-yaml';\nimport cloneDeep from 'lodash.clonedeep';\n\nimport { combineMerge } from '../utils/mergeUtil';\nimport { sortKeys } from '../utils/objectUtil';\nimport { PackageConfig } from '../utils/packageConfig';\nimport { promisePool } from '../utils/promisePool';\n\nconst testWorkflow = {\n name: 'Test',\n on: {\n pull_request: {\n branches: ['main', '!renovate/**'],\n },\n push: {\n branches: ['main', 'renovate/**'],\n },\n },\n jobs: {\n test: {\n uses: 'WillBooster/reusable-workflows/.github/workflows/test.yml@main',\n },\n },\n};\n\nconst releaseWorkflow = {\n name: 'Release',\n on: {\n push: {\n branches: [],\n },\n },\n jobs: {\n release: {\n uses: 'WillBooster/reusable-workflows/.github/workflows/release.yml@main',\n },\n },\n};\n\nconst wbfyWorkflow = {\n name: 'Willboosterify',\n on: {\n schedule: [\n {\n cron: '0 5 * * 0',\n },\n ],\n workflow_dispatch: null,\n },\n jobs: {\n wbfy: {\n uses: 'WillBooster/reusable-workflows/.github/workflows/wbfy.yml@main',\n },\n },\n};\n\nexport async function generateWorkflow(rootConfig: PackageConfig): Promise<void> {\n const workflowsPath = path.resolve(rootConfig.dirPath, '.github', 'workflows');\n await fs.promises.mkdir(workflowsPath, { recursive: true });\n if (rootConfig.depending.semanticRelease) {\n await promisePool.run(async () => {\n const yml = await getWorkflowYaml(rootConfig, workflowsPath, 'release');\n await fs.promises.writeFile(path.join(workflowsPath, 'release.yml'), yml);\n });\n }\n await promisePool.run(async () => {\n const yml = await getWorkflowYaml(rootConfig, workflowsPath, 'test');\n await fs.promises.writeFile(path.join(workflowsPath, 'test.yml'), yml);\n });\n await promisePool.run(async () => {\n const yml = await getWorkflowYaml(rootConfig, workflowsPath, 'wbfy');\n await fs.promises.writeFile(path.join(workflowsPath, 'wbfy.yml'), yml);\n });\n}\n\nasync function getWorkflowYaml(\n config: PackageConfig,\n workflowsPath: string,\n kind: 'test' | 'release' | 'wbfy'\n): Promise<string> {\n let newSettings = cloneDeep(\n kind === 'test' ? testWorkflow : kind === 'release' ? releaseWorkflow : wbfyWorkflow\n ) as any;\n if (kind === 'release') {\n newSettings.on.push.branches = config.release.branches;\n }\n let job = newSettings.jobs.test || newSettings.jobs.release || newSettings.jobs.wbfy;\n job.with ||= {};\n job.secrets ||= {};\n if (config.repository?.startsWith('github:WillBoosterLab/')) {\n job.uses = job.uses.replace('WillBooster/', 'WillBoosterLab/');\n }\n\n if (config.containingDockerfile) {\n job.with['cpu_arch'] = 'X64';\n }\n if (config.release.github || kind === 'wbfy') {\n if (config.publicRepo) {\n job.secrets['GH_TOKEN'] = '${{ secrets.PUBLIC_GH_BOT_PAT }}';\n } else {\n job.secrets['GH_TOKEN'] = '${{ secrets.GH_BOT_PAT }}';\n }\n }\n if (config.release.npm && kind !== 'wbfy') {\n job.secrets['NPM_TOKEN'] = '${{ secrets.NPM_TOKEN }}';\n }\n\n const filePath = path.join(workflowsPath, `${kind}.yml`);\n try {\n const oldContent = await fs.promises.readFile(filePath, 'utf-8');\n const oldSettings = yaml.load(oldContent);\n newSettings = merge.all([newSettings, oldSettings, newSettings], { arrayMerge: combineMerge });\n } catch (e) {\n // do nothing\n }\n\n job = newSettings.jobs.test || newSettings.jobs.release || newSettings.jobs.wbfy;\n delete job.with['non_self_hosted'];\n if (Object.keys(job.with).length) {\n sortKeys(job.with);\n } else {\n delete job.with;\n }\n if (Object.keys(job.secrets).length) {\n sortKeys(job.secrets);\n } else {\n delete job.secrets;\n }\n if (kind === 'release' && newSettings.on.schedule) delete newSettings.on.push;\n if (kind === 'release') {\n await promisePool.run(() => fs.promises.rm('semantic-release.yml', { force: true }));\n }\n\n return yaml.dump(newSettings, {\n styles: {\n '!!null': 'empty',\n },\n noCompatMode: true,\n });\n}\n", "import fs from 'fs';\nimport path from 'path';\n\nimport yaml from 'js-yaml';\n\nimport { PackageConfig } from '../utils/packageConfig';\nimport { promisePool } from '../utils/promisePool';\nimport { spawnSync, spawnSyncWithStringResult } from '../utils/spawnUtil';\n\nexport async function generateYarnrcYml(config: PackageConfig): Promise<void> {\n const currentVersion = spawnSyncWithStringResult('yarn', ['--version'], config.dirPath);\n const latestVersion = spawnSyncWithStringResult('npm', ['show', '@yarnpkg/cli', 'version'], config.dirPath);\n if (currentVersion !== latestVersion) {\n spawnSync('yarn', ['set', 'version', latestVersion], config.dirPath, 1);\n }\n\n const releasesPath = path.join(config.dirPath, '.yarn', 'releases');\n await fs.promises.mkdir(releasesPath, { recursive: true });\n for (const file of await fs.promises.readdir(releasesPath)) {\n if (file.startsWith('yarn-') && !file.startsWith(`yarn-${latestVersion}`)) {\n await promisePool.run(() => fs.promises.rm(path.join(releasesPath, file)));\n }\n }\n\n const yarnrcPath = path.resolve(config.dirPath, '.yarnrc');\n await promisePool.run(() => fs.promises.rm(yarnrcPath, { force: true }));\n\n const yarnrcYmlPath = path.resolve(config.dirPath, '.yarnrc.yml');\n const settings = yaml.load(await fs.promises.readFile(yarnrcYmlPath, 'utf8')) as any;\n settings.defaultSemverRangePrefix = '';\n if (config.requiringNodeModules) {\n settings.nodeLinker = 'node-modules';\n settings.nmMode = 'hardlinks-global';\n }\n await fs.promises.writeFile(yarnrcYmlPath, yaml.dump(settings));\n\n const plugins = (settings.plugins || []).map((p: any) => p.spec as string);\n const requireTypeScript = config.containingTypeScript || config.containingTypeScriptInPackages;\n importOrRemovePlugin(config, plugins, requireTypeScript, '@yarnpkg/plugin-typescript');\n if (requireTypeScript && !config.requiringNodeModules) {\n spawnSync('yarn', ['dlx', '@yarnpkg/sdks', 'vscode'], config.dirPath);\n }\n importOrRemovePlugin(config, plugins, config.containingSubPackageJsons, '@yarnpkg/plugin-workspace-tools');\n spawnSync('yarn', ['dlx', 'yarn-plugin-auto-install'], config.dirPath);\n}\n\nfunction importOrRemovePlugin(config: PackageConfig, plugins: string[], requirePlugin: boolean, plugin: string): void {\n if (requirePlugin !== plugins.includes(plugin)) {\n spawnSync('yarn', ['plugin', requirePlugin ? 'import' : 'remove', plugin], config.dirPath);\n }\n}\n", "import fs from 'fs';\nimport fsp from 'fs/promises';\nimport path from 'path';\n\nimport glob from 'glob';\nimport yaml from 'js-yaml';\nimport simpleGit from 'simple-git';\n\nimport { fetchOnNode } from './fetchOnNode';\n\nexport interface PackageConfig {\n dirPath: string;\n root: boolean;\n publicRepo: boolean;\n repository?: string;\n willBoosterConfigs: boolean;\n containingSubPackageJsons: boolean;\n containingDockerfile: boolean;\n containingGemfile: boolean;\n containingGoMod: boolean;\n containingPackageJson: boolean;\n containingPoetryLock: boolean;\n containingPomXml: boolean;\n containingPubspecYaml: boolean;\n containingTemplateYaml: boolean;\n\n containingJavaScript: boolean;\n containingTypeScript: boolean;\n containingJsxOrTsx: boolean;\n containingJavaScriptInPackages: boolean;\n containingTypeScriptInPackages: boolean;\n containingJsxOrTsxInPackages: boolean;\n depending: {\n blitz: boolean;\n firebase: boolean;\n jestPlaywrightPreset: boolean;\n prisma: boolean;\n reactNative: boolean;\n semanticRelease: boolean;\n storybook: boolean;\n };\n release: {\n branches: string[];\n github: boolean;\n npm: boolean;\n };\n eslintBase?: string;\n requiringNodeModules: boolean;\n versionsText?: string;\n}\n\nexport async function getPackageConfig(dirPath: string): Promise<PackageConfig | null> {\n const packageJsonPath = path.resolve(dirPath, 'package.json');\n try {\n const containingPackageJson = fs.existsSync(packageJsonPath);\n let dependencies: { [key: string]: string } = {};\n let devDependencies: { [key: string]: string } = {};\n let packageJson: any = {};\n if (containingPackageJson) {\n const packageJsonText = fs.readFileSync(packageJsonPath, 'utf-8');\n packageJson = JSON.parse(packageJsonText);\n dependencies = packageJson.dependencies ?? {};\n devDependencies = packageJson.devDependencies ?? {};\n }\n\n let requiringNodeModules = true;\n try {\n const yarnrcYmlPath = path.resolve(dirPath, '.yarnrc.yml');\n const doc = yaml.load(await fsp.readFile(yarnrcYmlPath, 'utf8')) as any;\n requiringNodeModules = !doc.nodeLinker || doc.nodeLinker === 'node-modules';\n } catch (_) {\n // do nothing\n }\n\n let releaseBranches: string[] = [];\n let releasePlugins: string[] = [];\n try {\n const releasercJsonPath = path.resolve(dirPath, '.releaserc.json');\n const json = JSON.parse(await fsp.readFile(releasercJsonPath, 'utf8'));\n releaseBranches = json?.branches || [];\n releasePlugins = json?.plugins?.flat() || [];\n } catch (_) {\n // do nothing\n }\n\n const isRoot =\n path.basename(path.resolve(dirPath, '..')) !== 'packages' ||\n !fs.existsSync(path.resolve(dirPath, '..', '..', 'package.json'));\n\n let repoInfo: Record<string, any> | undefined;\n if (isRoot) {\n repoInfo = await getRepoInfo(dirPath, packageJson);\n }\n\n const toolVersionsPath = path.resolve(dirPath, '.tool-versions');\n let versionsText: string | undefined;\n try {\n versionsText = await fsp.readFile(toolVersionsPath, 'utf-8');\n } catch (_) {\n // do nothing\n }\n\n const config: PackageConfig = {\n dirPath,\n root: isRoot,\n publicRepo: repoInfo?.private === false,\n repository: repoInfo?.full_name ? `github:${repoInfo?.full_name}` : undefined,\n willBoosterConfigs: packageJsonPath.includes(`${path.sep}willbooster-configs`),\n containingSubPackageJsons: glob.sync('packages/**/package.json', { cwd: dirPath }).length > 0,\n containingDockerfile:\n fs.existsSync(path.resolve(dirPath, 'Dockerfile')) ||\n fs.existsSync(path.resolve(dirPath, 'docker-compose.yml')),\n containingGemfile: fs.existsSync(path.resolve(dirPath, 'Gemfile')),\n containingGoMod: fs.existsSync(path.resolve(dirPath, 'go.mod')),\n containingPackageJson: fs.existsSync(path.resolve(dirPath, 'package.json')),\n containingPoetryLock: fs.existsSync(path.resolve(dirPath, 'poetry.lock')),\n containingPomXml: fs.existsSync(path.resolve(dirPath, 'pom.xml')),\n containingPubspecYaml: fs.existsSync(path.resolve(dirPath, 'pubspec.yaml')),\n containingTemplateYaml: fs.existsSync(path.resolve(dirPath, 'template.yaml')),\n containingJavaScript: glob.sync('@(app|src|__tests__)/**/*.js?(x)', { cwd: dirPath }).length > 0,\n containingTypeScript: glob.sync('@(app|src|__tests__)/**/*.ts?(x)', { cwd: dirPath }).length > 0,\n containingJsxOrTsx: glob.sync('@(app|src|__tests__)/**/*.{t,j}sx', { cwd: dirPath }).length > 0,\n containingJavaScriptInPackages:\n glob.sync('packages/**/@(app|src|__tests__)/**/*.js?(x)', { cwd: dirPath }).length > 0,\n containingTypeScriptInPackages:\n glob.sync('packages/**/@(app|src|__tests__)/**/*.ts?(x)', { cwd: dirPath }).length > 0,\n containingJsxOrTsxInPackages:\n glob.sync('packages/**/@(app|src|__tests__)/**/*.{t,j}sx', { cwd: dirPath }).length > 0,\n depending: {\n blitz: !!(dependencies['blitz'] || devDependencies['blitz']),\n firebase: !!devDependencies['firebase-tools'],\n jestPlaywrightPreset: !!devDependencies['jest-playwright-preset'],\n prisma: !!devDependencies['prisma'],\n reactNative: !!dependencies['react-native'],\n semanticRelease: !!devDependencies['semantic-release'],\n storybook: !!devDependencies['@storybook/react'],\n },\n release: {\n branches: releaseBranches,\n github: releasePlugins.includes('@semantic-release/github'),\n npm: releasePlugins.includes('@semantic-release/npm'),\n },\n requiringNodeModules,\n versionsText,\n };\n config.eslintBase = getEslintExtensionBase(config);\n if (\n config.containingGemfile ||\n config.containingGoMod ||\n config.containingPackageJson ||\n config.containingPoetryLock ||\n config.containingPomXml ||\n config.containingPubspecYaml ||\n config.containingTemplateYaml\n ) {\n return config;\n }\n } catch (e) {\n // do nothing\n }\n return null;\n}\n\nfunction getEslintExtensionBase(config: PackageConfig): string | undefined {\n if (config.containingTypeScript) {\n if (config.containingJsxOrTsx) {\n return '@willbooster/eslint-config-ts-react';\n } else {\n return '@willbooster/eslint-config-ts';\n }\n } else {\n if (config.containingJsxOrTsx) {\n return '@willbooster/eslint-config-js-react';\n } else if (config.containingJavaScript) {\n return '@willbooster/eslint-config-js';\n }\n }\n return undefined;\n}\n\nasync function getRepoInfo(dirPath: string, packageJson: any): Promise<Record<string, any> | undefined> {\n const url = packageJson.repository?.url ?? packageJson.repository;\n if (typeof url === 'string') {\n const json = await fetchRepoInfo(url);\n if (json) return json;\n }\n\n const git = simpleGit(dirPath);\n const remotes = await git.getRemotes(true);\n const origin = remotes.find((r) => r.name === 'origin');\n const remoteUrl = origin?.refs?.fetch ?? origin?.refs?.push;\n if (typeof remoteUrl === 'string') {\n const json = await fetchRepoInfo(remoteUrl);\n if (json) return json;\n }\n}\n\nasync function fetchRepoInfo(urlOrFullName: string): Promise<Record<string, any> | undefined> {\n const urlWithoutProtocol = urlOrFullName.split(':').at(-1);\n const names = urlWithoutProtocol?.split('/');\n const org = names?.at(-2);\n const name = names?.at(-1)?.replace(/.git$/, '');\n if (!org || !name) return;\n\n const token = process.env.GH_TOKEN || process.env.GITHUB_TOKEN;\n const opts = token\n ? {\n headers: {\n Authorization: `token ${token}`,\n },\n }\n : undefined;\n const res = await fetchOnNode(`https://api.github.com/repos/${org}/${name}`, opts);\n const json = (await res.json()) as any;\n return { full_name: `${org}/${name}`, ...(json ?? {}) };\n}\n"],
5
- "mappings": "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",
4
+ "sourcesContent": ["import path from 'path';\n\nimport glob from 'glob';\nimport yargs from 'yargs';\n\nimport { generateVersionConfigs } from './generators/asdf';\nimport { generateEditorconfig } from './generators/editorconfig';\nimport { generateEslintignore } from './generators/eslintignore';\nimport { generateEslintrc } from './generators/eslintrc';\nimport { generateGitattributes } from './generators/gitattributes';\nimport { generateGitignore } from './generators/gitignore';\nimport { generateHuskyrc } from './generators/huskyrc';\nimport { generateIdeaSettings } from './generators/idea';\nimport { generateLintstagedrc } from './generators/lintstagedrc';\nimport { generatePackageJson } from './generators/packageJson';\nimport { generatePrettierignore } from './generators/prettierignore';\nimport { generateReleaserc } from './generators/releaserc';\nimport { generateRenovateJson } from './generators/renovaterc';\nimport { generateSemanticYml } from './generators/semanticRelease';\nimport { generateTsconfig } from './generators/tsconfig';\nimport { generateWorkflow } from './generators/workflow';\nimport { generateYarnrcYml } from './generators/yarnrc';\nimport { getPackageConfig, PackageConfig } from './utils/packageConfig';\nimport { promisePool } from './utils/promisePool';\nimport { spawnSync } from './utils/spawnUtil';\n\nasync function main(): Promise<void> {\n const argv = await yargs(process.argv.slice(2))\n .command('wbfy <paths...>', 'Generate/update project files for WillBooster')\n .demandCommand(1)\n .alias('d', 'skipDeps')\n .boolean('skipDeps')\n .default('skipDeps', false)\n .describe('skipDeps', 'Skip dependency installation')\n .alias('v', 'verbose')\n .boolean('verbose')\n .default('verbose', false).argv;\n\n for (const rootDirPath of argv._) {\n if (typeof rootDirPath === 'number') continue;\n\n const rootConfig = await getPackageConfig(rootDirPath);\n if (rootConfig === null) {\n console.error(`there is no valid package.json in ${rootDirPath}`);\n continue;\n }\n\n const subDirPaths = rootConfig.containingSubPackageJsons\n ? glob.sync('packages/*', { cwd: rootDirPath }).map((subDirPath) => path.resolve(rootDirPath, subDirPath))\n : [];\n const subPackageConfigs = (await Promise.all(subDirPaths.map((subDirPath) => getPackageConfig(subDirPath)))).filter(\n (config) => !!config\n ) as PackageConfig[];\n const allPackageConfigs = [rootConfig, ...subPackageConfigs];\n const allNodePackageConfigs = [rootConfig, ...subPackageConfigs.filter((config) => config.containingPackageJson)];\n\n if (argv.verbose) {\n for (const config of allPackageConfigs) {\n console.log(config);\n }\n }\n\n const rootPromises = allPackageConfigs.map((config) => generateGitignore(config, rootConfig));\n // Install yarn berry at first\n await generateYarnrcYml(rootConfig);\n rootPromises.push(\n generateEditorconfig(rootConfig),\n generateGitattributes(rootConfig),\n generateHuskyrc(rootConfig),\n generateIdeaSettings(rootConfig),\n generateLintstagedrc(rootConfig),\n generateRenovateJson(rootConfig),\n generateReleaserc(rootConfig),\n generateSemanticYml(rootConfig),\n generateVersionConfigs(rootConfig),\n generateWorkflow(rootConfig)\n );\n await Promise.all(rootPromises);\n await promisePool.promiseAll();\n\n const promises: Promise<void>[] = [];\n for (const config of allNodePackageConfigs) {\n promises.push(generatePrettierignore(config), generateLintstagedrc(config));\n if (config.containingTypeScript || config.containingTypeScriptInPackages) {\n promises.push(generateTsconfig(config, rootConfig));\n }\n if (\n config.containingJavaScript ||\n config.containingJavaScriptInPackages ||\n config.containingTypeScript ||\n config.containingTypeScriptInPackages\n ) {\n if (!rootConfig.willBoosterConfigs) {\n promises.push(generateEslintrc(config, rootConfig));\n }\n promises.push(generateEslintignore(config));\n }\n }\n await Promise.all(promises);\n await promisePool.promiseAll();\n\n for (const config of allNodePackageConfigs) {\n await generatePackageJson(config, rootConfig, argv.skipDeps);\n }\n spawnSync('yarn', ['cleanup'], rootDirPath);\n // 'yarn install' should be after `yarn cleanup` because yarn berry generates yarn.lock\n // corresponding to the contents of dependant sub-package in monorepo\n spawnSync('yarn', ['install'], rootDirPath);\n }\n}\n\nmain().then();\n", "import fs from 'fs';\nimport path from 'path';\n\nimport { PackageConfig } from '../utils/packageConfig';\nimport { promisePool } from '../utils/promisePool';\n\nexport async function generateVersionConfigs(config: PackageConfig): Promise<void> {\n if (!config.versionsText) return;\n\n const lines: string[] = [];\n for (const versionText of config.versionsText.split('\\n')) {\n const line = versionText.trim();\n if (!line.startsWith('nodejs')) {\n lines.push(line);\n continue;\n }\n\n const [, version] = line.split(/\\s+/);\n await promisePool.run(() => fs.promises.writeFile(path.resolve(config.dirPath, '.node-version'), version));\n }\n\n const toolVersionsPath = path.resolve(config.dirPath, '.tool-versions');\n if (lines.length) {\n await promisePool.run(() => fs.promises.writeFile(toolVersionsPath, lines.join('\\n')));\n } else {\n await promisePool.run(() => fs.promises.rm(toolVersionsPath, { force: true }));\n }\n}\n", "import { PromisePool } from 'minimal-promise-pool';\n\nexport const promisePool = new PromisePool();\n", "import path from 'path';\n\nimport { Extensions } from '../utils/extensions';\nimport { FsUtil } from '../utils/fsUtil';\nimport { PackageConfig } from '../utils/packageConfig';\nimport { promisePool } from '../utils/promisePool';\n\nconst newContent = `root = true\n\n[*]\ncharset = utf-8\nend_of_line = lf\ninsert_final_newline = true\ntrim_trailing_whitespace = true\n\n${generateExtensions(Extensions.codeWith2IndentSize)}\nindent_size = 2\nindent_style = space\n\n${generateExtensions(Extensions.codeWith4IndentSize)}\nindent_size = 4\nindent_style = space\n\n${generateExtensions(Extensions.codeWith8IndentSize)}\nindent_size = 8\nindent_style = space\n\n${generateExtensions(Extensions.markdownLike)}\nmax_line_length = off\ntrim_trailing_whitespace = false\n\n[{Makefile,*.mk}]\nindent_style = tab\n`;\n\nexport async function generateEditorconfig(config: PackageConfig): Promise<void> {\n const filePath = path.resolve(config.dirPath, '.editorconfig');\n await promisePool.run(() => FsUtil.generateFile(filePath, newContent));\n}\n\nfunction generateExtensions(extensions: string[]): string {\n return extensions.length > 1 ? `[*.{${extensions.join(',')}}]` : `[*.${extensions[0]}]`;\n}\n", "export const Extensions = {\n codeWith2IndentSize: [\n 'cjs',\n 'mjs',\n 'js',\n 'jsx',\n 'ts',\n 'tsx',\n 'json',\n 'json5',\n 'cpp',\n 'dart',\n 'htm',\n 'html',\n 'pu',\n 'puml',\n 'rb',\n 'vue',\n 'yaml',\n 'yml',\n ].sort(),\n codeWith4IndentSize: ['go', 'gradle', 'py'].sort(),\n codeWith8IndentSize: ['sh'].sort(),\n markdownLike: ['md'].sort(),\n eslint: ['cjs', 'mjs', 'js', 'ts', 'tsx', 'jsx'].sort(),\n prettier: [\n 'cjs',\n 'mjs',\n 'js',\n 'jsx',\n 'ts',\n 'tsx',\n 'json',\n 'json5',\n 'css',\n 'htm',\n 'html',\n 'md',\n 'scss',\n 'vue',\n 'yaml',\n 'yml',\n ].sort(),\n};\n", "import fsp from 'fs/promises';\n\nexport const FsUtil = {\n async generateFile(filePath: string, content: string): Promise<void> {\n await fsp.writeFile(filePath, content);\n console.log(`Generated ${filePath}`);\n },\n};\n", "import path from 'path';\n\nimport { FsUtil } from '../utils/fsUtil';\nimport { IgnoreFileUtil } from '../utils/ignoreFileUtil';\nimport { PackageConfig } from '../utils/packageConfig';\nimport { promisePool } from '../utils/promisePool';\n\nconst defaultUserContent = `${IgnoreFileUtil.header}\n\n\n${IgnoreFileUtil.separator}\n`;\n\nconst commonContent = `\n3rd-party/\n@types/\n__generated__/\nandroid/\nios/\nno-format/\ntest-fixtures/\n*.config.js\n*.d.ts\n*.min.js\n.yarn/\n.pnp.js\n`;\n\nexport async function generateEslintignore(config: PackageConfig): Promise<void> {\n const filePath = path.resolve(config.dirPath, '.eslintignore');\n const userContent = IgnoreFileUtil.getUserContent(filePath) || defaultUserContent;\n\n const gitignoreFilePath = path.resolve(config.dirPath, '.gitignore');\n const gitignoreContent = IgnoreFileUtil.getExistingContent(gitignoreFilePath) || '';\n\n const newContent = userContent + commonContent + gitignoreContent;\n await promisePool.run(() => FsUtil.generateFile(filePath, newContent));\n}\n", "import fs from 'fs';\n\nexport const IgnoreFileUtil = {\n header: '# Project-specific settings',\n separator: '# Generated by @willbooster/willboosterify',\n separatorPrefix: '# Generated by @willbooster',\n getExistingContent(filePath: string): string | null {\n if (fs.existsSync(filePath)) {\n return fs\n .readFileSync(filePath)\n .toString()\n .replace(/# Project-specific settings[^\\n]*\\n/m, '')\n .replace(/# Generated by[^\\n]*\\n/m, '')\n .replace(/\\r?\\n\\r?\\n(\\r?\\n)+/gm, '\\n\\n');\n }\n return null;\n },\n getUserContent(filePath: string): string | null {\n if (fs.existsSync(filePath)) {\n const existingContent = fs.readFileSync(filePath, 'utf-8');\n const index = existingContent.indexOf(this.separatorPrefix);\n if (index >= 0) {\n return existingContent.substr(0, existingContent.indexOf('\\n', index) + 1);\n }\n }\n return null;\n },\n isBerryZeroInstallEnabled(filePath: string): boolean {\n if (fs.existsSync(filePath)) {\n const existingContent = fs.readFileSync(filePath, 'utf-8');\n return existingContent.includes('\\n!.yarn/cache');\n }\n return false;\n },\n};\n", "import fs from 'fs';\nimport path from 'path';\n\nimport merge from 'deepmerge';\n\nimport { FsUtil } from '../utils/fsUtil';\nimport { combineMerge } from '../utils/mergeUtil';\nimport { PackageConfig } from '../utils/packageConfig';\nimport { promisePool } from '../utils/promisePool';\n\nexport async function generateEslintrc(config: PackageConfig, rootConfig: PackageConfig): Promise<void> {\n const bases = [];\n if (config.eslintBase) {\n bases.push(config.eslintBase);\n }\n if (config !== rootConfig) {\n bases.push('../../.eslintrc.json');\n }\n let newSettings: any = { root: true, extends: bases };\n\n const filePath = path.resolve(config.dirPath, '.eslintrc.json');\n try {\n const oldContent = await fs.promises.readFile(filePath, 'utf-8');\n const oldSettings = JSON.parse(oldContent);\n if (oldSettings.extends) {\n oldSettings.extends = oldSettings.extends.filter(\n (ext: string) => !ext.startsWith('@willbooster/') && ext !== '../../.eslintrc.json'\n );\n }\n if (!bases.length) {\n oldSettings.extends = [];\n }\n const newExtends = newSettings.extends;\n newSettings.extends = oldSettings.extends;\n oldSettings.extends = newExtends;\n newSettings = merge.all([newSettings, oldSettings, newSettings], { arrayMerge: combineMerge });\n if (config.depending.blitz) {\n newSettings.extends = [...newSettings.extends.filter((e: string) => e !== 'blitz'), 'blitz'];\n }\n } catch (e) {\n // do nothing\n }\n const newContent = JSON.stringify(newSettings);\n await promisePool.run(() => FsUtil.generateFile(filePath, newContent));\n}\n", "import merge from 'deepmerge';\n\nexport function overwriteMerge(destinationArray: any[], sourceArray: any[]): any[] {\n return sourceArray;\n}\n\n// eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\nexport function combineMerge(target: any[], source: any[], options: any): any[] {\n const destination = target.slice();\n\n source.forEach((item, index) => {\n if (typeof destination[index] === 'undefined') {\n destination[index] = options.cloneUnlessOtherwiseSpecified(item, options);\n } else if (options.isMergeableObject(item)) {\n destination[index] = merge(target[index], item, options);\n } else if (target.indexOf(item) === -1) {\n destination.push(item);\n }\n });\n return destination;\n}\n", "import path from 'path';\n\nimport { Extensions } from '../utils/extensions';\nimport { FsUtil } from '../utils/fsUtil';\nimport { PackageConfig } from '../utils/packageConfig';\nimport { promisePool } from '../utils/promisePool';\n\nconst newContent = `* text=auto\n\n*.vcproj text eol=crlf\n\n${Extensions.codeWith2IndentSize\n .concat(Extensions.codeWith4IndentSize)\n .concat(Extensions.markdownLike)\n .map((ext) => `*.${ext} text eol=lf`)\n .join('\\n')}\n`;\n\nexport async function generateGitattributes(config: PackageConfig): Promise<void> {\n const filePath = path.resolve(config.dirPath, '.gitattributes');\n await promisePool.run(() => FsUtil.generateFile(filePath, newContent));\n}\n", "import path from 'path';\n\nimport { fetchOnNode } from '../utils/fetchOnNode';\nimport { FsUtil } from '../utils/fsUtil';\nimport { IgnoreFileUtil } from '../utils/ignoreFileUtil';\nimport { PackageConfig } from '../utils/packageConfig';\nimport { promisePool } from '../utils/promisePool';\n\nconst defaultNames = ['windows', 'macos', 'linux', 'jetbrains', 'visualstudiocode', 'emacs', 'vim', 'yarn'];\n\nconst defaultUserContent = `${IgnoreFileUtil.header}\n\n\n${IgnoreFileUtil.separator}\n`;\n\nconst commonContent = `\n.devcontainer/\ndist/\ntemp/\nIcon[\\r]\n`;\n\nexport async function generateGitignore(config: PackageConfig, rootConfig: PackageConfig): Promise<void> {\n const filePath = path.resolve(config.dirPath, '.gitignore');\n let userContent = (IgnoreFileUtil.getUserContent(filePath) || defaultUserContent) + commonContent;\n\n const names = [...defaultNames];\n if (config.containingGemfile) {\n names.push('ruby');\n }\n if (config.containingGoMod) {\n names.push('go');\n userContent += `${path.basename(config.dirPath)}\n`;\n }\n if (config.containingPackageJson) {\n names.push('node');\n }\n if (config.containingPomXml) {\n names.push('maven');\n userContent += `.idea/google-java-format.xml\n`;\n }\n if (config.containingPubspecYaml) {\n names.push('flutter', 'AndroidStudio', 'ruby');\n userContent += `.flutter-plugins-dependencies\nandroid/key.properties\nios/.bundle\n.idea/runConfigurations.xml\n`;\n }\n if (config.containingTemplateYaml) {\n userContent += `.aws-sam/\npackaged.yaml\n`;\n }\n // Because .venv should be ignored on root directory\n if (config.containingPoetryLock) {\n names.push('python');\n }\n if (rootConfig.depending.firebase || config.depending.firebase) {\n names.push('firebase');\n }\n if (rootConfig.depending.reactNative || config.depending.reactNative) {\n names.push('reactnative');\n userContent += `google-services.json\nandroid/app/src/main/assets/\n`;\n }\n if (rootConfig.depending.storybook) {\n names.push('storybookjs');\n }\n if (rootConfig.depending.blitz) {\n names.push('nextjs');\n }\n\n let generated = (\n await Promise.all(\n names.map(async (name) => {\n const response = await fetchOnNode(`https://www.toptal.com/developers/gitignore/api/${name}`);\n return await response.text();\n })\n )\n ).join('');\n if (!IgnoreFileUtil.isBerryZeroInstallEnabled(filePath)) {\n generated = generated.replace('!.yarn/cache', '# !.yarn/cache').replace('# .pnp.*', '.pnp.*');\n }\n if (config.containingPomXml || config.containingPubspecYaml) {\n generated = generated\n .replace(/^# .idea\\/artifacts$/gm, '.idea/artifacts')\n .replace(/^# .idea\\/compiler.xml$/gm, '.idea/compiler.xml')\n .replace(/^# .idea\\/jarRepositories.xml$/gm, '.idea/jarRepositories.xml')\n .replace(/^# .idea\\/modules.xml$/gm, '.idea/modules.xml')\n .replace(/^# .idea\\/*.iml$/gm, '.idea/*.iml')\n .replace(/^# .idea\\/modules$/gm, '.idea/modules')\n .replace(/^# *.iml$/gm, '*.iml')\n .replace(/^# *.ipr$/gm, '*.ipr');\n if (config.containingPubspecYaml) {\n generated = generated.replace(/^.idea\\/modules.xml$/gm, '# .idea/modules.xml');\n }\n }\n generated = generated.replace(/^.idea\\/?$/gm, '# .idea');\n if (rootConfig.depending.reactNative || config.depending.reactNative || config.containingPubspecYaml) {\n generated = generated.replace(/^(.idea\\/.+)$/gm, '$1\\nandroid/$1');\n }\n const newContent = userContent + generated;\n await promisePool.run(() => FsUtil.generateFile(filePath, newContent));\n}\n", "import type { RequestInfo, RequestInit, Response } from 'node-fetch';\n\nexport async function fetchOnNode(url: RequestInfo, init?: RequestInit | undefined): Promise<Response> {\n const { default: nodeFetch } = await import('node-fetch');\n return nodeFetch(url, init);\n}\n", "import fs from 'fs';\nimport path from 'path';\n\nimport { PackageConfig } from '../utils/packageConfig';\nimport { promisePool } from '../utils/promisePool';\nimport { spawnSync } from '../utils/spawnUtil';\n\nconst DEFAULT_COMMAND = 'npm test';\n\nconst settings = {\n preCommit: 'yarn lint-staged',\n prePush: 'yarn typecheck',\n postMerge: 'yarn',\n};\n\nexport async function generateHuskyrc(config: PackageConfig): Promise<void> {\n const packageJsonPath = path.resolve(config.dirPath, 'package.json');\n const jsonText = await fs.promises.readFile(packageJsonPath, 'utf-8');\n const packageJson = JSON.parse(jsonText);\n packageJson.scripts ||= {};\n delete packageJson.scripts['postinstall'];\n delete packageJson.scripts['postpublish'];\n delete packageJson.scripts['prepare'];\n delete packageJson.scripts['prepublishOnly'];\n delete packageJson.scripts['prepack'];\n delete packageJson.scripts['postpack'];\n\n const dirPath = path.resolve(config.dirPath, '.husky');\n await Promise.all([\n fs.promises.writeFile(packageJsonPath, JSON.stringify(packageJson, undefined, 2)),\n fs.promises.rm(dirPath, { force: true, recursive: true }),\n ]);\n spawnSync('yarn', ['dlx', 'husky-init', '--yarn2'], config.dirPath);\n\n const preCommitFilePath = path.resolve(dirPath, 'pre-commit');\n const content = await fs.promises.readFile(preCommitFilePath, 'utf-8');\n\n await promisePool.run(() => fs.promises.rm(path.resolve(config.dirPath, '.huskyrc.json'), { force: true }));\n await promisePool.run(() =>\n fs.promises.writeFile(preCommitFilePath, content.replace(DEFAULT_COMMAND, settings.preCommit))\n );\n\n if (config.containingTypeScript || config.containingTypeScriptInPackages) {\n await promisePool.run(() =>\n fs.promises.writeFile(path.resolve(dirPath, 'pre-push'), content.replace(DEFAULT_COMMAND, settings.prePush), {\n mode: 0o755,\n })\n );\n }\n\n const postMergeCommands: string[] = [];\n if (config.versionsText?.includes('python ')) {\n postMergeCommands.push('asdf install python');\n }\n if (config.versionsText) {\n postMergeCommands.push('asdf install');\n }\n postMergeCommands.push(settings.postMerge);\n if (config.versionsText?.includes('poetry ')) {\n postMergeCommands.push('poetry install');\n }\n if (config.depending.blitz) {\n postMergeCommands.push('yarn blitz codegen');\n } else if (config.depending.prisma) {\n postMergeCommands.push('yarn prisma generate');\n }\n const postMergeCommand = content.replace(DEFAULT_COMMAND, postMergeCommands.join(' && '));\n await promisePool.run(() =>\n fs.promises.writeFile(path.resolve(dirPath, 'post-merge'), postMergeCommand, {\n mode: 0o755,\n })\n );\n}\n", "import child_process from 'child_process';\n\nexport function spawnSync(command: string, args: string[], cwd: string, retry = 0): void {\n do {\n const [commandAndArgs, options] = getSpawnSyncArgs(command, args, cwd);\n console.log(`$ ${commandAndArgs} at ${options.cwd}`);\n const ret = child_process.spawnSync(commandAndArgs, options);\n if (ret.status === 0) break;\n } while (--retry >= 0);\n}\n\nexport function spawnSyncWithStringResult(command: string, args: string[], cwd: string): string {\n const [commandAndArgs, options] = getSpawnSyncArgs(command, args, cwd);\n options.stdio = 'pipe';\n const proc = child_process.spawnSync(commandAndArgs, options);\n return proc.stdout.toString().trim();\n}\n\nexport function getSpawnSyncArgs(command: string, args: string[], cwd: string): [string, any] {\n const env = { ...process.env };\n // Remove berry from PATH\n if (env.PATH && env.BERRY_BIN_FOLDER) {\n env.PATH = env.PATH.replace(`${env.BERRY_BIN_FOLDER}:`, '');\n }\n\n let commandAndArgs = `${command} ${args.join(' ')}`;\n if (env.ASDF_DIR) {\n commandAndArgs = `bash -l -c '. ${env.ASDF_DIR}/asdf.sh && ${commandAndArgs}'`;\n }\n return [\n commandAndArgs,\n {\n cwd,\n env,\n shell: true,\n stdio: 'inherit',\n },\n ];\n}\n", "import fs from 'fs';\nimport path from 'path';\n\nimport { FsUtil } from '../utils/fsUtil';\nimport { PackageConfig } from '../utils/packageConfig';\nimport { promisePool } from '../utils/promisePool';\n\nconst newContent = `<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<project version=\"4\">\n <component name=\"ProjectTasksOptions\">\n <TaskOptions isEnabled=\"true\">\n <option name=\"arguments\" value=\"prettier --write $FilePathRelativeToProjectRoot$\" />\n <option name=\"checkSyntaxErrors\" value=\"false\" />\n <option name=\"description\" />\n <option name=\"exitCodeBehavior\" value=\"ERROR\" />\n <option name=\"fileExtension\" value=\"ts\" />\n <option name=\"immediateSync\" value=\"false\" />\n <option name=\"name\" value=\"Prettier (.ts)\" />\n <option name=\"output\" value=\"$FilePathRelativeToProjectRoot$\" />\n <option name=\"outputFilters\">\n <array />\n </option>\n <option name=\"outputFromStdout\" value=\"false\" />\n <option name=\"program\" value=\"yarn\" />\n <option name=\"runOnExternalChanges\" value=\"false\" />\n <option name=\"scopeName\" value=\"Project Files\" />\n <option name=\"trackOnlyRoot\" value=\"false\" />\n <option name=\"workingDir\" value=\"$ProjectFileDir$\" />\n <envs />\n </TaskOptions>\n <TaskOptions isEnabled=\"true\">\n <option name=\"arguments\" value=\"prettier --write $FilePathRelativeToProjectRoot$\" />\n <option name=\"checkSyntaxErrors\" value=\"false\" />\n <option name=\"description\" />\n <option name=\"exitCodeBehavior\" value=\"ERROR\" />\n <option name=\"fileExtension\" value=\"tsx\" />\n <option name=\"immediateSync\" value=\"false\" />\n <option name=\"name\" value=\"Prettier (.tsx)\" />\n <option name=\"output\" value=\"$FilePathRelativeToProjectRoot$\" />\n <option name=\"outputFilters\">\n <array />\n </option>\n <option name=\"outputFromStdout\" value=\"false\" />\n <option name=\"program\" value=\"yarn\" />\n <option name=\"runOnExternalChanges\" value=\"false\" />\n <option name=\"scopeName\" value=\"Project Files\" />\n <option name=\"trackOnlyRoot\" value=\"false\" />\n <option name=\"workingDir\" value=\"$ProjectFileDir$\" />\n <envs />\n </TaskOptions>\n <TaskOptions isEnabled=\"true\">\n <option name=\"arguments\" value=\"prettier --write $FilePathRelativeToProjectRoot$\" />\n <option name=\"checkSyntaxErrors\" value=\"false\" />\n <option name=\"description\" />\n <option name=\"exitCodeBehavior\" value=\"ERROR\" />\n <option name=\"fileExtension\" value=\"js\" />\n <option name=\"immediateSync\" value=\"false\" />\n <option name=\"name\" value=\"Prettier (.js)\" />\n <option name=\"output\" value=\"$FilePathRelativeToProjectRoot$\" />\n <option name=\"outputFilters\">\n <array />\n </option>\n <option name=\"outputFromStdout\" value=\"false\" />\n <option name=\"program\" value=\"yarn\" />\n <option name=\"runOnExternalChanges\" value=\"false\" />\n <option name=\"scopeName\" value=\"Project Files\" />\n <option name=\"trackOnlyRoot\" value=\"false\" />\n <option name=\"workingDir\" value=\"$ProjectFileDir$\" />\n <envs />\n </TaskOptions>\n <TaskOptions isEnabled=\"true\">\n <option name=\"arguments\" value=\"prettier --write $FilePathRelativeToProjectRoot$\" />\n <option name=\"checkSyntaxErrors\" value=\"false\" />\n <option name=\"description\" />\n <option name=\"exitCodeBehavior\" value=\"ERROR\" />\n <option name=\"fileExtension\" value=\"json\" />\n <option name=\"immediateSync\" value=\"false\" />\n <option name=\"name\" value=\"Prettier (.json)\" />\n <option name=\"output\" value=\"$FilePathRelativeToProjectRoot$\" />\n <option name=\"outputFilters\">\n <array />\n </option>\n <option name=\"outputFromStdout\" value=\"false\" />\n <option name=\"program\" value=\"yarn\" />\n <option name=\"runOnExternalChanges\" value=\"false\" />\n <option name=\"scopeName\" value=\"Project Files\" />\n <option name=\"trackOnlyRoot\" value=\"false\" />\n <option name=\"workingDir\" value=\"$ProjectFileDir$\" />\n <envs />\n </TaskOptions>\n <TaskOptions isEnabled=\"true\">\n <option name=\"arguments\" value=\"prettier --write $FilePathRelativeToProjectRoot$\" />\n <option name=\"checkSyntaxErrors\" value=\"false\" />\n <option name=\"description\" />\n <option name=\"exitCodeBehavior\" value=\"ERROR\" />\n <option name=\"fileExtension\" value=\"md\" />\n <option name=\"immediateSync\" value=\"false\" />\n <option name=\"name\" value=\"Prettier (.md)\" />\n <option name=\"output\" value=\"$FilePathRelativeToProjectRoot$\" />\n <option name=\"outputFilters\">\n <array />\n </option>\n <option name=\"outputFromStdout\" value=\"false\" />\n <option name=\"program\" value=\"yarn\" />\n <option name=\"runOnExternalChanges\" value=\"false\" />\n <option name=\"scopeName\" value=\"Project Files\" />\n <option name=\"trackOnlyRoot\" value=\"false\" />\n <option name=\"workingDir\" value=\"$ProjectFileDir$\" />\n <envs />\n </TaskOptions>\n <TaskOptions isEnabled=\"true\">\n <option name=\"arguments\" value=\"prettier --write $FilePathRelativeToProjectRoot$\" />\n <option name=\"checkSyntaxErrors\" value=\"false\" />\n <option name=\"description\" />\n <option name=\"exitCodeBehavior\" value=\"ERROR\" />\n <option name=\"fileExtension\" value=\"html\" />\n <option name=\"immediateSync\" value=\"false\" />\n <option name=\"name\" value=\"Prettier (.html)\" />\n <option name=\"output\" value=\"$FilePathRelativeToProjectRoot$\" />\n <option name=\"outputFilters\">\n <array />\n </option>\n <option name=\"outputFromStdout\" value=\"false\" />\n <option name=\"program\" value=\"yarn\" />\n <option name=\"runOnExternalChanges\" value=\"false\" />\n <option name=\"scopeName\" value=\"Project Files\" />\n <option name=\"trackOnlyRoot\" value=\"false\" />\n <option name=\"workingDir\" value=\"$ProjectFileDir$\" />\n <envs />\n </TaskOptions>\n </component>\n</project>\n`;\n\nexport async function generateIdeaSettings(config: PackageConfig): Promise<void> {\n const dirPath = path.resolve(config.dirPath, '.idea');\n if (fs.existsSync(dirPath)) {\n const filePath = path.resolve(dirPath, 'watcherTasks.xml');\n if (\n config.containingJavaScript ||\n config.containingJavaScriptInPackages ||\n config.containingTypeScript ||\n config.containingTypeScriptInPackages ||\n (config.containingPackageJson &&\n !config.containingPubspecYaml &&\n !config.containingGemfile &&\n !config.containingGoMod &&\n !config.containingPomXml)\n ) {\n await promisePool.run(() => FsUtil.generateFile(filePath, newContent));\n } else {\n await promisePool.run(() => fs.promises.rm(filePath, { force: true }));\n }\n }\n}\n", "import fs from 'fs';\nimport path from 'path';\n\nimport { EslintUtil } from '../utils/eslintUtil';\nimport { Extensions } from '../utils/extensions';\nimport { FsUtil } from '../utils/fsUtil';\nimport { PackageConfig } from '../utils/packageConfig';\nimport { promisePool } from '../utils/promisePool';\n\nconst eslintKey = `./{src,__tests__}/**/*.{${Extensions.eslint.join(',')}}`;\nconst eslintFilterForPrettier = `files = micromatch.not(files, '${eslintKey}');`;\n\nexport async function generateLintstagedrc(config: PackageConfig): Promise<void> {\n const lines: string[] = [];\n if (config.containingJavaScript || config.containingTypeScript) {\n const eslint = `\n '${eslintKey}': [${JSON.stringify(`eslint --fix${EslintUtil.getLintFixSuffix(config)}`)}, 'prettier --write'],`;\n lines.push(eslint);\n }\n const packagesFilter = config.root ? \" && !file.includes('/packages/')\" : '';\n lines.push(`\n './**/*.{${Extensions.prettier.join(',')}}': files => {\n ${config.containingJavaScript || config.containingTypeScript ? eslintFilterForPrettier : ''}\n const filteredFiles = files.filter(file => !file.includes('/test-fixtures/')${packagesFilter});\n if (filteredFiles.length === 0) return [];\n const commands = [\\`prettier --write \\${filteredFiles.join(' ')}\\`];\n if (filteredFiles.some(file => file.endsWith('package.json'))) {\n commands.push('yarn sort-package-json');\n }\n return commands;\n },`);\n if (config.containingPubspecYaml) {\n lines.push(`\n './{lib,test,test_driver}/**/*.dart': files => {\n const filteredFiles = files.filter(file => !file.includes('generated'))\n .filter(file => !file.endsWith('.freezed.dart') && !file.endsWith('.g.dart'));\n if (filteredFiles.length === 0) return [];\n return [\\`flutter format \\${filteredFiles.join(' ')}\\`];\n },`);\n }\n if (config.containingPoetryLock) {\n lines.push(`\n './**/*.py': [\n 'poetry run isort --profile black --filter-files',\n 'poetry run black',\n 'poetry run flake8'\n ],`);\n }\n\n const newContent = `${\n config.containingJavaScript || config.containingTypeScript ? \"const micromatch = require('micromatch');\" : ''\n }\n\nmodule.exports = {${lines.join('')}\n};\n`;\n\n const filePath = path.resolve(config.dirPath, '.lintstagedrc.cjs');\n await promisePool.run(() => fs.promises.rm(path.resolve(config.dirPath, '.lintstagedrc.js'), { force: true }));\n await promisePool.run(() => fs.promises.rm(path.resolve(config.dirPath, '.lintstagedrc.json'), { force: true }));\n await promisePool.run(() => FsUtil.generateFile(filePath, newContent));\n}\n", "import { PackageConfig } from './packageConfig';\n\nexport const EslintUtil = {\n getLintFixSuffix(config: PackageConfig): string {\n return config.containingJsxOrTsx ? ' --rule \"{ react-hooks/exhaustive-deps: 0 }\"' : '';\n },\n};\n", "import fs from 'fs';\nimport path from 'path';\n\nimport merge from 'deepmerge';\n\nimport { EslintUtil } from '../utils/eslintUtil';\nimport { Extensions } from '../utils/extensions';\nimport { IgnoreFileUtil } from '../utils/ignoreFileUtil';\nimport { PackageConfig } from '../utils/packageConfig';\nimport { promisePool } from '../utils/promisePool';\nimport { spawnSync } from '../utils/spawnUtil';\n\nconst scriptsWithoutWorkspace = {\n cleanup: 'yarn format && yarn lint-fix',\n format: `sort-package-json && yarn prettify`,\n lint: `eslint --color \"./{src,__tests__}/**/*.{${Extensions.eslint.join(',')}}\"`,\n 'lint-fix': 'yarn lint --fix',\n prettify: `prettier --color --write \"**/{.*/,}*.{${Extensions.prettier.join(',')}}\" \"!**/test-fixtures/**\"`,\n typecheck: 'tsc --noEmit --Pretty',\n};\n\nconst scriptsWithWorkspace = merge(\n { ...scriptsWithoutWorkspace },\n {\n format: `sort-package-json && yarn prettify && yarn workspaces foreach --parallel --verbose run format`,\n lint: `yarn workspaces foreach --parallel --verbose run lint`,\n 'lint-fix': 'yarn workspaces foreach --parallel --verbose run lint-fix',\n prettify: `prettier --color --write \"**/{.*/,}*.{${Extensions.prettier.join(\n ','\n )}}\" \"!**/packages/**\" \"!**/test-fixtures/**\"`,\n test: 'yarn workspaces foreach --verbose run test',\n typecheck: 'yarn workspaces foreach --parallel --verbose run typecheck',\n }\n);\n\nconst scriptsForBlitz = merge(\n { ...scriptsWithoutWorkspace },\n {\n lint: `eslint --color \"./**/*.{${Extensions.eslint.join(',')}}\"`,\n typecheck: `tsc --noEmit --Pretty || echo 'Please try \"yarn blitz codegen\" if you face unknown type errors.'`,\n }\n);\n\nconst jsCommonDeps = [\n 'eslint',\n 'eslint-config-prettier',\n 'eslint-plugin-import',\n 'eslint-plugin-sort-class-members',\n 'eslint-plugin-sort-destructure-keys',\n];\n\nconst tsCommonDeps = [\n ...jsCommonDeps,\n '@typescript-eslint/eslint-plugin',\n '@typescript-eslint/parser',\n 'eslint-import-resolver-typescript',\n];\n\nconst reactCommonDeps = ['eslint-plugin-react', 'eslint-plugin-react-hooks'];\n\nconst devDeps: { [prop: string]: string[] } = {\n '@willbooster/eslint-config-js': ['@willbooster/eslint-config-js', ...jsCommonDeps],\n '@willbooster/eslint-config-js-react': ['@willbooster/eslint-config-js-react', ...jsCommonDeps, ...reactCommonDeps],\n '@willbooster/eslint-config-ts': ['@willbooster/eslint-config-ts', ...tsCommonDeps],\n '@willbooster/eslint-config-ts-react': ['@willbooster/eslint-config-ts-react', ...tsCommonDeps, ...reactCommonDeps],\n '../../.eslintrc.json': [],\n};\n\nexport async function generatePackageJson(\n config: PackageConfig,\n rootConfig: PackageConfig,\n skipAddingDeps: boolean\n): Promise<void> {\n const filePath = path.resolve(config.dirPath, 'package.json');\n const jsonText = await fs.promises.readFile(filePath, 'utf-8');\n const jsonObj = JSON.parse(jsonText);\n jsonObj.scripts = jsonObj.scripts || {};\n jsonObj.dependencies = jsonObj.dependencies || {};\n jsonObj.devDependencies = jsonObj.devDependencies || {};\n jsonObj.peerDependencies = jsonObj.peerDependencies || {};\n\n await removeDeprecatedStuff(jsonObj);\n\n if (jsonObj.name !== '@willbooster/prettier-config') {\n jsonObj.prettier = '@willbooster/prettier-config';\n }\n\n for (const scriptKey of Object.keys(jsonObj.scripts)) {\n // Fresh repo still requires 'yarn install'\n if (!jsonObj.scripts[scriptKey].includes('git clone')) {\n jsonObj.scripts[scriptKey] = jsonObj.scripts[scriptKey]\n .replace(/yarn\\s*&&\\s*/, '')\n .replace(/yarn\\s*install\\s*&&\\s*/, '');\n }\n }\n\n jsonObj.scripts = merge(\n jsonObj.scripts,\n config.containingSubPackageJsons\n ? scriptsWithWorkspace\n : config.depending.blitz\n ? scriptsForBlitz\n : scriptsWithoutWorkspace\n );\n jsonObj.scripts.prettify += await generatePrettierSuffix(config.dirPath);\n\n let dependencies: string[] = [];\n let devDependencies = ['lint-staged', 'prettier', 'sort-package-json', '@willbooster/prettier-config'];\n const poetryDependencies: string[] = [];\n\n if (config.root) {\n // To install the latest pinst\n devDependencies.push('husky', 'pinst', '@willbooster/renovate-config');\n if (config.depending.semanticRelease) {\n devDependencies.push('conventional-changelog-conventionalcommits');\n }\n if (config.containingSubPackageJsons) {\n jsonObj.workspaces = ['packages/*'];\n } else {\n delete jsonObj.workspaces;\n }\n }\n\n if (\n config.containingJavaScript ||\n config.containingJavaScriptInPackages ||\n config.containingTypeScript ||\n config.containingTypeScriptInPackages\n ) {\n devDependencies.push('eslint', 'micromatch');\n if (config.containingTypeScriptInPackages) {\n devDependencies.push('@typescript-eslint/parser');\n }\n }\n\n if ((config.containingTypeScript || config.containingTypeScriptInPackages) && !config.depending.blitz) {\n devDependencies.push('typescript');\n }\n\n if (config.eslintBase) {\n devDependencies.push(...devDeps[config.eslintBase]);\n }\n\n if (config.willBoosterConfigs) {\n dependencies = dependencies.filter((dep) => !dep.includes('@willbooster/'));\n devDependencies = devDependencies.filter((dep) => !dep.includes('@willbooster/'));\n }\n\n if (!jsonObj.name) {\n jsonObj.name = path.basename(config.dirPath);\n }\n\n if (config.containingSubPackageJsons) {\n jsonObj.private = true;\n }\n\n if (!jsonObj.license) {\n jsonObj.license = 'UNLICENSED';\n }\n\n if (!config.containingTypeScript && !config.containingTypeScriptInPackages) {\n delete jsonObj.scripts.typecheck;\n }\n\n // https://github.com/semantic-release/semantic-release/issues/2323#issuecomment-1032341621\n if (config.depending.semanticRelease && config.release.npm) {\n jsonObj.resolutions ||= {};\n jsonObj.resolutions['npm/chalk'] = '^4.1.2';\n }\n\n if (!config.containingSubPackageJsons) {\n if (!config.containingJavaScript && !config.containingTypeScript) {\n delete jsonObj.scripts.lint;\n delete jsonObj.scripts['lint-fix'];\n jsonObj.scripts.cleanup = jsonObj.scripts.cleanup.replace(' && yarn lint-fix', '');\n } else {\n jsonObj.scripts['lint-fix'] += EslintUtil.getLintFixSuffix(config);\n }\n\n if (config.containingPubspecYaml) {\n jsonObj.scripts.lint = 'flutter analyze';\n jsonObj.scripts['lint-fix'] = 'yarn lint';\n const dirs = ['lib', 'test', 'test_driver'].filter((dir) => fs.existsSync(path.resolve(config.dirPath, dir)));\n if (dirs.length > 0) {\n jsonObj.scripts['format-code'] = `flutter format $(find ${dirs.join(\n ' '\n )} -name generated -prune -o -name '*.freezed.dart' -prune -o -name '*.g.dart' -prune -o -name '*.dart' -print)`;\n jsonObj.scripts.format += ` && yarn format-code`;\n }\n }\n\n if (config.containingPoetryLock) {\n if (jsonObj.scripts.postinstall === 'poetry install') {\n delete jsonObj.scripts.postinstall;\n }\n const dirNames = (await fs.promises.readdir(config.dirPath)).filter((dirName) => {\n const dirPath = path.resolve(config.dirPath, dirName);\n if (!fs.lstatSync(dirPath).isDirectory()) return false;\n return fs.readdirSync(dirPath).some((fileName) => fileName.endsWith('.py'));\n });\n if (dirNames.length > 0) {\n jsonObj.scripts['format-code'] = `poetry run isort --profile black ${dirNames.join(\n ' '\n )} && poetry run black ${dirNames.join(' ')}`;\n jsonObj.scripts.lint = `poetry run flake8 ${dirNames.join(' ')}`;\n jsonObj.scripts['lint-fix'] = 'yarn lint';\n jsonObj.scripts.format += ` && yarn format-code`;\n poetryDependencies.push('black', 'isort', 'flake8');\n }\n }\n\n if (config.repository) {\n jsonObj.repository = config.repository;\n }\n }\n\n if (config.depending.blitz) {\n // These cause an error of eslint-plugin-import loading\n devDependencies = devDependencies.filter((dep) => !dep.includes('@typescript-eslint/'));\n // This causes eslint errors\n devDependencies = devDependencies.filter(\n (d) =>\n d !== 'eslint-plugin-react' &&\n d !== 'eslint-import-resolver-typescript' &&\n d !== 'eslint-plugin-import' &&\n d !== 'eslint-plugin-react-hooks'\n );\n }\n if (!Object.keys(jsonObj.dependencies).length) {\n delete jsonObj.dependencies;\n }\n if (!Object.keys(jsonObj.devDependencies).length) {\n delete jsonObj.devDependencies;\n }\n if (!Object.keys(jsonObj.peerDependencies).length) {\n delete jsonObj.peerDependencies;\n }\n\n await fs.promises.writeFile(filePath, JSON.stringify(jsonObj));\n\n if (!skipAddingDeps) {\n if (dependencies.length && dependencies.some((dep) => !jsonObj.dependencies?.[dep])) {\n spawnSync('yarn', ['add', ...new Set(dependencies)], config.dirPath);\n }\n if (devDependencies.length) {\n spawnSync('yarn', ['add', '-D', ...new Set(devDependencies)], config.dirPath);\n }\n if (poetryDependencies.length) {\n spawnSync('poetry', ['add', ...new Set(poetryDependencies)], config.dirPath);\n }\n }\n}\n\nasync function removeDeprecatedStuff(jsonObj: any): Promise<void> {\n // TODO: remove the following migration code in future\n if (jsonObj.author === 'WillBooster LLC') {\n jsonObj.author = 'WillBooster Inc.';\n }\n delete jsonObj.scripts['sort-package-json'];\n delete jsonObj.scripts['sort-all-package-json'];\n delete jsonObj.dependencies['tslib'];\n delete jsonObj.devDependencies['@willbooster/eslint-config'];\n delete jsonObj.devDependencies['@willbooster/eslint-config-react'];\n delete jsonObj.devDependencies['@willbooster/tsconfig'];\n delete jsonObj.devDependencies['eslint-import-resolver-node'];\n delete jsonObj.devDependencies['eslint-plugin-prettier'];\n delete jsonObj.devDependencies['lerna'];\n // To install the latest pinst\n delete jsonObj.devDependencies['pinst'];\n delete jsonObj.scripts['flutter-format'];\n delete jsonObj.scripts['format-flutter'];\n delete jsonObj.scripts['python-format'];\n delete jsonObj.scripts['format-python'];\n delete jsonObj.scripts['prettier'];\n for (const deps of Object.values(devDeps)) {\n for (const dep of deps) {\n delete jsonObj.devDependencies[dep];\n }\n }\n await promisePool.run(() => fs.promises.rm('lerna.json', { force: true }));\n}\n\nasync function generatePrettierSuffix(dirPath: string): Promise<string> {\n const filePath = path.resolve(dirPath, '.prettierignore');\n const existingContent = await fs.promises.readFile(filePath, 'utf-8');\n const index = existingContent.indexOf(IgnoreFileUtil.separatorPrefix);\n if (index < 0) return '';\n\n const originalContent = existingContent.substring(0, index);\n const lines = originalContent\n .split('\\n')\n .map((line) => {\n const newLine = line.trim();\n return newLine.endsWith('/') ? newLine.slice(0, -1) : newLine;\n })\n .filter((l) => l && !l.startsWith('#') && !l.includes('/'));\n\n return lines.map((line) => ` \"!**/${line}/**\"`).join('');\n}\n", "import path from 'path';\n\nimport { FsUtil } from '../utils/fsUtil';\nimport { IgnoreFileUtil } from '../utils/ignoreFileUtil';\nimport { PackageConfig } from '../utils/packageConfig';\nimport { promisePool } from '../utils/promisePool';\n\nconst defaultUserContent = `${IgnoreFileUtil.header}\n\n\n${IgnoreFileUtil.separator}\n`;\n\nconst commonContent = `\n3rd-party/\nandroid/\nios/\nno-format/\ntest-fixtures/\n*.d.ts\n*.min.js\n.yarn/\n.pnp.js\n`;\n\nexport async function generatePrettierignore(config: PackageConfig): Promise<void> {\n const filePath = path.resolve(config.dirPath, '.prettierignore');\n const userContent = IgnoreFileUtil.getUserContent(filePath) || defaultUserContent;\n\n const gitignoreFilePath = path.resolve(config.dirPath, '.gitignore');\n const gitignoreContent = IgnoreFileUtil.getExistingContent(gitignoreFilePath) || '';\n\n let additionalContent = '';\n if (config.containingPubspecYaml) {\n additionalContent = `\nandroid/app/\nios/Runner/Assets.xcassets/\npubspec.yaml\n`;\n }\n\n const newContent = userContent + commonContent + additionalContent + gitignoreContent;\n await promisePool.run(() => FsUtil.generateFile(filePath, newContent));\n}\n", "import fs from 'fs';\nimport path from 'path';\n\nimport { FsUtil } from '../utils/fsUtil';\nimport { PackageConfig } from '../utils/packageConfig';\nimport { promisePool } from '../utils/promisePool';\n\nexport async function generateReleaserc(rootConfig: PackageConfig): Promise<void> {\n const filePath = path.resolve(rootConfig.dirPath, '.releaserc.json');\n try {\n const settings = JSON.parse(await fs.promises.readFile(filePath, 'utf8'));\n const plugins = settings?.plugins || [];\n for (let i = 0; i < plugins.length; i++) {\n if (plugins[i] === '@semantic-release/commit-analyzer' || plugins[i][0] === '@semantic-release/commit-analyzer') {\n plugins[i] = [\n '@semantic-release/commit-analyzer',\n {\n preset: 'conventionalcommits',\n },\n ];\n }\n }\n const newContent = JSON.stringify(settings);\n await promisePool.run(() => FsUtil.generateFile(filePath, newContent));\n } catch (_) {\n // do nothing\n }\n}\n", "import fs from 'fs';\nimport path from 'path';\n\nimport merge from 'deepmerge';\nimport cloneDeep from 'lodash.clonedeep';\n\nimport { FsUtil } from '../utils/fsUtil';\nimport { overwriteMerge } from '../utils/mergeUtil';\nimport { PackageConfig } from '../utils/packageConfig';\nimport { promisePool } from '../utils/promisePool';\n\nconst jsonObj = {\n extends: ['@willbooster'],\n};\n\nexport async function generateRenovateJson(config: PackageConfig): Promise<void> {\n let newSettings: any = cloneDeep(jsonObj);\n\n const filePath = path.resolve(config.dirPath, '.renovaterc.json');\n try {\n const oldContent = await fs.promises.readFile(filePath, 'utf-8');\n const oldSettings = JSON.parse(oldContent) as any;\n newSettings = merge.all([newSettings, oldSettings, newSettings], { arrayMerge: overwriteMerge });\n } catch (e) {\n // do nothing\n }\n await promisePool.run(() => fs.promises.rm(path.resolve(config.dirPath, '.dependabot'), { force: true }));\n await promisePool.run(() => fs.promises.rm(path.resolve(config.dirPath, 'renovate.json'), { force: true }));\n const newContent = JSON.stringify(newSettings);\n await promisePool.run(() => FsUtil.generateFile(filePath, newContent));\n}\n", "import fs from 'fs';\nimport path from 'path';\n\nimport yaml from 'js-yaml';\n\nimport { FsUtil } from '../utils/fsUtil';\nimport { PackageConfig } from '../utils/packageConfig';\nimport { promisePool } from '../utils/promisePool';\n\nconst newSettings = {\n titleOnly: true,\n};\n\nexport async function generateSemanticYml(rootConfig: PackageConfig): Promise<void> {\n const githubPath = path.resolve(rootConfig.dirPath, '.github');\n await fs.promises.mkdir(githubPath, { recursive: true });\n const filePath = path.join(githubPath, 'semantic.yml');\n const newContent = yaml.dump(newSettings);\n await promisePool.run(() => FsUtil.generateFile(filePath, newContent));\n}\n", "import fs from 'fs';\nimport path from 'path';\n\nimport merge from 'deepmerge';\nimport cloneDeep from 'lodash.clonedeep';\n\nimport { FsUtil } from '../utils/fsUtil';\nimport { overwriteMerge } from '../utils/mergeUtil';\nimport { sortKeys } from '../utils/objectUtil';\nimport { PackageConfig } from '../utils/packageConfig';\nimport { promisePool } from '../utils/promisePool';\n\nconst rootJsonObj = {\n compilerOptions: {\n target: 'esnext',\n module: 'esnext',\n moduleResolution: 'node',\n jsx: 'react',\n alwaysStrict: true,\n strict: true,\n skipLibCheck: true,\n allowSyntheticDefaultImports: true,\n esModuleInterop: true,\n resolveJsonModule: true,\n sourceMap: true,\n importHelpers: false,\n outDir: 'dist',\n },\n include: [\n 'src/**/*',\n '__tests__/**/*',\n 'packages/*/src/**/*',\n 'packages/*/__tests__/**/*',\n './node_modules/@types',\n './@types',\n ],\n};\n\nconst subJsonObj = {\n compilerOptions: {\n target: 'esnext',\n module: 'esnext',\n moduleResolution: 'node',\n jsx: 'react',\n alwaysStrict: true,\n strict: true,\n skipLibCheck: true,\n allowSyntheticDefaultImports: true,\n esModuleInterop: true,\n resolveJsonModule: true,\n sourceMap: true,\n importHelpers: false,\n outDir: 'dist',\n },\n include: ['src/**/*', '__tests__/**/*', '../../node_modules/@types', '../../@types', './@types'],\n};\n\nexport async function generateTsconfig(config: PackageConfig, rootConfig: PackageConfig): Promise<void> {\n if (rootConfig.depending.blitz) return;\n\n let newSettings: any = cloneDeep(config.root ? rootJsonObj : subJsonObj);\n if (!config.containingJsxOrTsx && !config.containingJsxOrTsxInPackages) {\n delete newSettings.compilerOptions.jsx;\n }\n if (config.root && !config.containingSubPackageJsons) {\n newSettings.include = newSettings.include.filter((dirPath: string) => !dirPath.startsWith('packages/*/'));\n }\n if (!config.root && (config.depending.jestPlaywrightPreset || rootConfig.depending.jestPlaywrightPreset)) {\n const relativeDirPath = path.relative(config.dirPath, rootConfig.dirPath);\n newSettings.include.push(\n ...[\n path.join(relativeDirPath, 'node_modules/jest-playwright-preset/types'),\n path.join(relativeDirPath, 'node_modules/expect-playwright'),\n ]\n );\n }\n\n const filePath = path.resolve(config.dirPath, 'tsconfig.json');\n try {\n const existingContent = await fs.promises.readFile(filePath, 'utf-8');\n const oldSettings = JSON.parse(existingContent);\n if (oldSettings.extends === './node_modules/@willbooster/tsconfig/tsconfig.json') {\n delete oldSettings.extends;\n }\n delete oldSettings.compilerOptions?.typeRoots;\n delete newSettings?.compilerOptions?.target;\n delete newSettings?.compilerOptions?.module;\n if (oldSettings.jsx) {\n delete newSettings.jsx;\n }\n if (!config.depending.blitz) {\n delete newSettings.include;\n }\n newSettings = merge.all([newSettings, oldSettings, newSettings], { arrayMerge: overwriteMerge });\n } catch (e) {\n // do nothing\n }\n sortKeys(newSettings.compilerOptions);\n const newContent = JSON.stringify(newSettings);\n await promisePool.run(() => FsUtil.generateFile(filePath, newContent));\n}\n", "export function sortKeys(obj: any): void {\n const keyAndValues = Object.entries(obj).sort(([key1], [key2]) => key1.localeCompare(key2));\n for (const [key, value] of keyAndValues) {\n delete obj[key];\n obj[key] = value;\n }\n}\n", "import fs from 'fs';\nimport path from 'path';\n\nimport merge from 'deepmerge';\nimport yaml from 'js-yaml';\nimport cloneDeep from 'lodash.clonedeep';\n\nimport { combineMerge } from '../utils/mergeUtil';\nimport { sortKeys } from '../utils/objectUtil';\nimport { PackageConfig } from '../utils/packageConfig';\nimport { promisePool } from '../utils/promisePool';\n\nconst testWorkflow = {\n name: 'Test',\n on: {\n pull_request: {\n branches: ['main', '!renovate/**'],\n },\n push: {\n branches: ['main', 'renovate/**'],\n },\n },\n jobs: {\n test: {\n uses: 'WillBooster/reusable-workflows/.github/workflows/test.yml@main',\n },\n },\n};\n\nconst releaseWorkflow = {\n name: 'Release',\n on: {\n push: {\n branches: [],\n },\n },\n jobs: {\n release: {\n uses: 'WillBooster/reusable-workflows/.github/workflows/release.yml@main',\n },\n },\n};\n\nconst wbfyWorkflow = {\n name: 'Willboosterify',\n on: {\n schedule: [\n {\n cron: '0 5 * * 0',\n },\n ],\n workflow_dispatch: null,\n },\n jobs: {\n wbfy: {\n uses: 'WillBooster/reusable-workflows/.github/workflows/wbfy.yml@main',\n },\n },\n};\n\nexport async function generateWorkflow(rootConfig: PackageConfig): Promise<void> {\n const workflowsPath = path.resolve(rootConfig.dirPath, '.github', 'workflows');\n await fs.promises.mkdir(workflowsPath, { recursive: true });\n if (rootConfig.depending.semanticRelease) {\n await promisePool.run(async () => {\n const yml = await getWorkflowYaml(rootConfig, workflowsPath, 'release');\n await fs.promises.writeFile(path.join(workflowsPath, 'release.yml'), yml);\n });\n }\n await promisePool.run(async () => {\n const yml = await getWorkflowYaml(rootConfig, workflowsPath, 'test');\n await fs.promises.writeFile(path.join(workflowsPath, 'test.yml'), yml);\n });\n await promisePool.run(async () => {\n const yml = await getWorkflowYaml(rootConfig, workflowsPath, 'wbfy');\n await fs.promises.writeFile(path.join(workflowsPath, 'wbfy.yml'), yml);\n });\n}\n\nasync function getWorkflowYaml(\n config: PackageConfig,\n workflowsPath: string,\n kind: 'test' | 'release' | 'wbfy'\n): Promise<string> {\n let newSettings = cloneDeep(\n kind === 'test' ? testWorkflow : kind === 'release' ? releaseWorkflow : wbfyWorkflow\n ) as any;\n if (kind === 'release') {\n newSettings.on.push.branches = config.release.branches;\n }\n let job = newSettings.jobs.test || newSettings.jobs.release || newSettings.jobs.wbfy;\n job.with ||= {};\n job.secrets ||= {};\n if (config.repository?.startsWith('github:WillBoosterLab/')) {\n job.uses = job.uses.replace('WillBooster/', 'WillBoosterLab/');\n }\n\n if (config.containingDockerfile) {\n job.with['cpu_arch'] = 'X64';\n }\n if (config.release.github || kind === 'wbfy') {\n if (config.publicRepo) {\n job.secrets['GH_TOKEN'] = '${{ secrets.PUBLIC_GH_BOT_PAT }}';\n } else {\n job.secrets['GH_TOKEN'] = '${{ secrets.GH_BOT_PAT }}';\n }\n }\n if (config.release.npm && kind !== 'wbfy') {\n job.secrets['NPM_TOKEN'] = '${{ secrets.NPM_TOKEN }}';\n }\n\n const filePath = path.join(workflowsPath, `${kind}.yml`);\n try {\n const oldContent = await fs.promises.readFile(filePath, 'utf-8');\n const oldSettings = yaml.load(oldContent);\n newSettings = merge.all([newSettings, oldSettings, newSettings], { arrayMerge: combineMerge });\n } catch (e) {\n // do nothing\n }\n\n job = newSettings.jobs.test || newSettings.jobs.release || newSettings.jobs.wbfy;\n delete job.with['non_self_hosted'];\n if (Object.keys(job.with).length) {\n sortKeys(job.with);\n } else {\n delete job.with;\n }\n if (Object.keys(job.secrets).length) {\n sortKeys(job.secrets);\n } else {\n delete job.secrets;\n }\n if (kind === 'release' && newSettings.on.schedule) delete newSettings.on.push;\n if (kind === 'release') {\n await promisePool.run(() => fs.promises.rm('semantic-release.yml', { force: true }));\n }\n\n return yaml.dump(newSettings, {\n styles: {\n '!!null': 'empty',\n },\n noCompatMode: true,\n });\n}\n", "import fs from 'fs';\nimport path from 'path';\n\nimport yaml from 'js-yaml';\n\nimport { PackageConfig } from '../utils/packageConfig';\nimport { promisePool } from '../utils/promisePool';\nimport { spawnSync, spawnSyncWithStringResult } from '../utils/spawnUtil';\n\nexport async function generateYarnrcYml(config: PackageConfig): Promise<void> {\n const currentVersion = spawnSyncWithStringResult('yarn', ['--version'], config.dirPath);\n const latestVersion = spawnSyncWithStringResult('npm', ['show', '@yarnpkg/cli', 'version'], config.dirPath);\n if (currentVersion !== latestVersion) {\n spawnSync('yarn', ['set', 'version', latestVersion], config.dirPath, 1);\n }\n\n const releasesPath = path.join(config.dirPath, '.yarn', 'releases');\n await fs.promises.mkdir(releasesPath, { recursive: true });\n for (const file of await fs.promises.readdir(releasesPath)) {\n if (file.startsWith('yarn-') && !file.startsWith(`yarn-${latestVersion}`)) {\n await promisePool.run(() => fs.promises.rm(path.join(releasesPath, file)));\n }\n }\n\n const yarnrcPath = path.resolve(config.dirPath, '.yarnrc');\n await promisePool.run(() => fs.promises.rm(yarnrcPath, { force: true }));\n\n const yarnrcYmlPath = path.resolve(config.dirPath, '.yarnrc.yml');\n const settings = yaml.load(await fs.promises.readFile(yarnrcYmlPath, 'utf8')) as any;\n settings.defaultSemverRangePrefix = '';\n if (config.requiringNodeModules) {\n settings.nodeLinker = 'node-modules';\n settings.nmMode = 'hardlinks-global';\n }\n await fs.promises.writeFile(yarnrcYmlPath, yaml.dump(settings));\n\n const plugins = (settings.plugins || []).map((p: any) => p.spec as string);\n const requireTypeScript = config.containingTypeScript || config.containingTypeScriptInPackages;\n importOrRemovePlugin(config, plugins, requireTypeScript, '@yarnpkg/plugin-typescript');\n if (requireTypeScript && !config.requiringNodeModules) {\n spawnSync('yarn', ['dlx', '@yarnpkg/sdks', 'vscode'], config.dirPath);\n }\n importOrRemovePlugin(config, plugins, config.containingSubPackageJsons, '@yarnpkg/plugin-workspace-tools');\n spawnSync('yarn', ['dlx', 'yarn-plugin-auto-install'], config.dirPath);\n}\n\nfunction importOrRemovePlugin(config: PackageConfig, plugins: string[], requirePlugin: boolean, plugin: string): void {\n if (requirePlugin !== plugins.includes(plugin)) {\n spawnSync('yarn', ['plugin', requirePlugin ? 'import' : 'remove', plugin], config.dirPath);\n }\n}\n", "import fs from 'fs';\nimport fsp from 'fs/promises';\nimport path from 'path';\n\nimport glob from 'glob';\nimport yaml from 'js-yaml';\nimport simpleGit from 'simple-git';\n\nimport { fetchOnNode } from './fetchOnNode';\n\nexport interface PackageConfig {\n dirPath: string;\n root: boolean;\n publicRepo: boolean;\n repository?: string;\n willBoosterConfigs: boolean;\n containingSubPackageJsons: boolean;\n containingDockerfile: boolean;\n containingGemfile: boolean;\n containingGoMod: boolean;\n containingPackageJson: boolean;\n containingPoetryLock: boolean;\n containingPomXml: boolean;\n containingPubspecYaml: boolean;\n containingTemplateYaml: boolean;\n\n containingJavaScript: boolean;\n containingTypeScript: boolean;\n containingJsxOrTsx: boolean;\n containingJavaScriptInPackages: boolean;\n containingTypeScriptInPackages: boolean;\n containingJsxOrTsxInPackages: boolean;\n depending: {\n blitz: boolean;\n firebase: boolean;\n jestPlaywrightPreset: boolean;\n prisma: boolean;\n reactNative: boolean;\n semanticRelease: boolean;\n storybook: boolean;\n };\n release: {\n branches: string[];\n github: boolean;\n npm: boolean;\n };\n eslintBase?: string;\n requiringNodeModules: boolean;\n versionsText?: string;\n}\n\nexport async function getPackageConfig(dirPath: string): Promise<PackageConfig | null> {\n const packageJsonPath = path.resolve(dirPath, 'package.json');\n try {\n const containingPackageJson = fs.existsSync(packageJsonPath);\n let dependencies: { [key: string]: string } = {};\n let devDependencies: { [key: string]: string } = {};\n let packageJson: any = {};\n if (containingPackageJson) {\n const packageJsonText = fs.readFileSync(packageJsonPath, 'utf-8');\n packageJson = JSON.parse(packageJsonText);\n dependencies = packageJson.dependencies ?? {};\n devDependencies = packageJson.devDependencies ?? {};\n }\n\n let requiringNodeModules = true;\n try {\n const yarnrcYmlPath = path.resolve(dirPath, '.yarnrc.yml');\n const doc = yaml.load(await fsp.readFile(yarnrcYmlPath, 'utf8')) as any;\n requiringNodeModules = !doc.nodeLinker || doc.nodeLinker === 'node-modules';\n } catch (_) {\n // do nothing\n }\n\n let releaseBranches: string[] = [];\n let releasePlugins: string[] = [];\n try {\n const releasercJsonPath = path.resolve(dirPath, '.releaserc.json');\n const json = JSON.parse(await fsp.readFile(releasercJsonPath, 'utf8'));\n releaseBranches = json?.branches || [];\n releasePlugins = json?.plugins?.flat() || [];\n } catch (_) {\n // do nothing\n }\n\n const isRoot =\n path.basename(path.resolve(dirPath, '..')) !== 'packages' ||\n !fs.existsSync(path.resolve(dirPath, '..', '..', 'package.json'));\n\n let repoInfo: Record<string, any> | undefined;\n if (isRoot) {\n repoInfo = await getRepoInfo(dirPath, packageJson);\n }\n\n const toolVersionsPath = path.resolve(dirPath, '.tool-versions');\n let versionsText: string | undefined;\n try {\n versionsText = await fsp.readFile(toolVersionsPath, 'utf-8');\n } catch (_) {\n // do nothing\n }\n\n const config: PackageConfig = {\n dirPath,\n root: isRoot,\n publicRepo: repoInfo?.private === false,\n repository: repoInfo?.full_name ? `github:${repoInfo?.full_name}` : undefined,\n willBoosterConfigs: packageJsonPath.includes(`${path.sep}willbooster-configs`),\n containingSubPackageJsons: glob.sync('packages/**/package.json', { cwd: dirPath }).length > 0,\n containingDockerfile:\n fs.existsSync(path.resolve(dirPath, 'Dockerfile')) ||\n fs.existsSync(path.resolve(dirPath, 'docker-compose.yml')),\n containingGemfile: fs.existsSync(path.resolve(dirPath, 'Gemfile')),\n containingGoMod: fs.existsSync(path.resolve(dirPath, 'go.mod')),\n containingPackageJson: fs.existsSync(path.resolve(dirPath, 'package.json')),\n containingPoetryLock: fs.existsSync(path.resolve(dirPath, 'poetry.lock')),\n containingPomXml: fs.existsSync(path.resolve(dirPath, 'pom.xml')),\n containingPubspecYaml: fs.existsSync(path.resolve(dirPath, 'pubspec.yaml')),\n containingTemplateYaml: fs.existsSync(path.resolve(dirPath, 'template.yaml')),\n containingJavaScript: glob.sync('@(app|src|__tests__)/**/*.js?(x)', { cwd: dirPath }).length > 0,\n containingTypeScript: glob.sync('@(app|src|__tests__)/**/*.ts?(x)', { cwd: dirPath }).length > 0,\n containingJsxOrTsx: glob.sync('@(app|src|__tests__)/**/*.{t,j}sx', { cwd: dirPath }).length > 0,\n containingJavaScriptInPackages:\n glob.sync('packages/**/@(app|src|__tests__)/**/*.js?(x)', { cwd: dirPath }).length > 0,\n containingTypeScriptInPackages:\n glob.sync('packages/**/@(app|src|__tests__)/**/*.ts?(x)', { cwd: dirPath }).length > 0,\n containingJsxOrTsxInPackages:\n glob.sync('packages/**/@(app|src|__tests__)/**/*.{t,j}sx', { cwd: dirPath }).length > 0,\n depending: {\n blitz: !!(dependencies['blitz'] || devDependencies['blitz']),\n firebase: !!devDependencies['firebase-tools'],\n jestPlaywrightPreset: !!devDependencies['jest-playwright-preset'],\n prisma: !!devDependencies['prisma'],\n reactNative: !!dependencies['react-native'],\n semanticRelease: !!devDependencies['semantic-release'],\n storybook: !!devDependencies['@storybook/react'],\n },\n release: {\n branches: releaseBranches,\n github: releasePlugins.includes('@semantic-release/github'),\n npm: releasePlugins.includes('@semantic-release/npm'),\n },\n requiringNodeModules,\n versionsText,\n };\n config.eslintBase = getEslintExtensionBase(config);\n if (\n config.containingGemfile ||\n config.containingGoMod ||\n config.containingPackageJson ||\n config.containingPoetryLock ||\n config.containingPomXml ||\n config.containingPubspecYaml ||\n config.containingTemplateYaml\n ) {\n return config;\n }\n } catch (e) {\n // do nothing\n }\n return null;\n}\n\nfunction getEslintExtensionBase(config: PackageConfig): string | undefined {\n if (config.containingTypeScript) {\n if (config.containingJsxOrTsx) {\n return '@willbooster/eslint-config-ts-react';\n } else {\n return '@willbooster/eslint-config-ts';\n }\n } else {\n if (config.containingJsxOrTsx) {\n return '@willbooster/eslint-config-js-react';\n } else if (config.containingJavaScript) {\n return '@willbooster/eslint-config-js';\n }\n }\n return undefined;\n}\n\nasync function getRepoInfo(dirPath: string, packageJson: any): Promise<Record<string, any> | undefined> {\n const url = packageJson.repository?.url ?? packageJson.repository;\n if (typeof url === 'string') {\n const json = await fetchRepoInfo(url);\n if (json) return json;\n }\n\n const git = simpleGit(dirPath);\n const remotes = await git.getRemotes(true);\n const origin = remotes.find((r) => r.name === 'origin');\n const remoteUrl = origin?.refs?.fetch ?? origin?.refs?.push;\n if (typeof remoteUrl === 'string') {\n const json = await fetchRepoInfo(remoteUrl);\n if (json) return json;\n }\n}\n\nasync function fetchRepoInfo(urlOrFullName: string): Promise<Record<string, any> | undefined> {\n const urlWithoutProtocol = urlOrFullName.split(':').at(-1);\n const names = urlWithoutProtocol?.split('/');\n const org = names?.at(-2);\n const name = names?.at(-1)?.replace(/.git$/, '');\n if (!org || !name) return;\n\n const token = process.env.GH_TOKEN || process.env.GITHUB_TOKEN;\n const opts = token\n ? {\n headers: {\n Authorization: `token ${token}`,\n },\n }\n : undefined;\n const res = await fetchOnNode(`https://api.github.com/repos/${org}/${name}`, opts);\n const json = (await res.json()) as any;\n return { full_name: `${org}/${name}`, ...(json ?? {}) };\n}\n"],
5
+ "mappings": "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",
6
6
  "names": []
7
7
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "wbfy",
3
- "version": "1.9.0",
3
+ "version": "1.10.1",
4
4
  "description": "A tool for applying WillBooster's conventional configures to npm packages",
5
5
  "repository": "github:WillBooster/wbfy",
6
6
  "license": "Apache-2.0",