wbfy 1.28.1 → 1.29.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,7 +1,7 @@
1
- var dt=Object.create;var Q=Object.defineProperty;var gt=Object.getOwnPropertyDescriptor;var yt=Object.getOwnPropertyNames,he=Object.getOwnPropertySymbols,ht=Object.getPrototypeOf,ve=Object.prototype.hasOwnProperty,Pt=Object.prototype.propertyIsEnumerable;var Pe=(e,t,n)=>t in e?Q(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n,O=(e,t)=>{for(var n in t||(t={}))ve.call(t,n)&&Pe(e,n,t[n]);if(he)for(var n of he(t))Pt.call(t,n)&&Pe(e,n,t[n]);return e};var vt=(e,t,n,o)=>{if(t&&typeof t=="object"||typeof t=="function")for(let r of yt(t))!ve.call(e,r)&&r!==n&&Q(e,r,{get:()=>t[r],enumerable:!(o=gt(t,r))||o.enumerable});return e};var l=(e,t,n)=>(n=e!=null?dt(ht(e)):{},vt(t||!e||!e.__esModule?Q(n,"default",{value:e,enumerable:!0}):n,e));var mt=l(require("path")),ft=l(require("glob")),ut=l(require("yargs"));var z=l(require("fs")),te=l(require("path"));var we=require("minimal-promise-pool"),c=new we.PromisePool;var ee=l(require("child_process"));function h(e,t,n,o=0){do{let[r,i,a]=ke(e,t,n);if(console.log(`$ ${r} ${i.join(" ")} at ${a.cwd}`),ee.default.spawnSync(r,i,a).status===0)break}while(--o>=0)}function E(e,t,n){let[o,r,i]=ke(e,t,n);return i.stdio="pipe",ee.default.spawnSync(o,r,i).stdout.toString().trim()}function ke(e,t,n){let o=O({},process.env);return o.PATH&&o.BERRY_BIN_FOLDER&&(o.PATH=o.PATH.replace(`${o.BERRY_BIN_FOLDER}:`,"")),o.ASDF_DIR&&(t=["-l","-c",`. ${o.ASDF_DIR}/asdf.sh && ${e} ${t.join(" ")}`],e="bash"),[e,t,{cwd:n,env:o,shell:!1,stdio:"inherit"}]}async function be(e){if(!e.versionsText)return;let t=[];for(let o of e.versionsText.trim().split(`
2
- `)){let r=o.trim();if(r&&r.split(/\s+/)[0]!=="nodejs"){t.push(r);continue}let[,i]=r.split(/\s+/);await c.run(()=>z.default.promises.writeFile(te.default.resolve(e.dirPath,".node-version"),i))}if(e.containingPoetryLock&&(M("poetry 1.1.13",0,t),M("python 3.9.10",0,t)),e.depending.firebase&&M("java adoptopenjdk-17.0.2+8",0,t),e.containingPackageJson){let o=E("npm",["show","yarn","version"],e.dirPath);M(`yarn ${o}`,t.length,t)}let n=te.default.resolve(e.dirPath,".tool-versions");t.length?await c.run(()=>z.default.promises.writeFile(n,t.join(`
1
+ var gt=Object.create;var Q=Object.defineProperty;var yt=Object.getOwnPropertyDescriptor;var ht=Object.getOwnPropertyNames,he=Object.getOwnPropertySymbols,Pt=Object.getPrototypeOf,we=Object.prototype.hasOwnProperty,wt=Object.prototype.propertyIsEnumerable;var Pe=(e,t,n)=>t in e?Q(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n,T=(e,t)=>{for(var n in t||(t={}))we.call(t,n)&&Pe(e,n,t[n]);if(he)for(var n of he(t))wt.call(t,n)&&Pe(e,n,t[n]);return e};var vt=(e,t,n,o)=>{if(t&&typeof t=="object"||typeof t=="function")for(let r of ht(t))!we.call(e,r)&&r!==n&&Q(e,r,{get:()=>t[r],enumerable:!(o=yt(t,r))||o.enumerable});return e};var l=(e,t,n)=>(n=e!=null?gt(Pt(e)):{},vt(t||!e||!e.__esModule?Q(n,"default",{value:e,enumerable:!0}):n,e));var ft=l(require("path")),ut=l(require("glob")),dt=l(require("yargs"));var z=l(require("fs")),te=l(require("path"));var ve=require("minimal-promise-pool"),c=new ve.PromisePool;var ee=l(require("child_process"));function h(e,t,n,o=0){do{let[r,i,a]=ke(e,t,n);if(console.log(`$ ${r} ${i.join(" ")} at ${a.cwd}`),ee.default.spawnSync(r,i,a).status===0)break}while(--o>=0)}function J(e,t,n){let[o,r,i]=ke(e,t,n);return i.stdio="pipe",ee.default.spawnSync(o,r,i).stdout.toString().trim()}function ke(e,t,n){let o=T({},process.env);return o.PATH&&o.BERRY_BIN_FOLDER&&(o.PATH=o.PATH.replace(`${o.BERRY_BIN_FOLDER}:`,"")),o.ASDF_DIR&&(t=["-l","-c",`. ${o.ASDF_DIR}/asdf.sh && ${e} ${t.join(" ")}`],e="bash"),[e,t,{cwd:n,env:o,shell:!1,stdio:"inherit"}]}async function be(e){if(!e.versionsText)return;let t=[];for(let o of e.versionsText.trim().split(`
2
+ `)){let r=o.trim();if(r&&r.split(/\s+/)[0]!=="nodejs"){t.push(r);continue}let[,i]=r.split(/\s+/);await c.run(()=>z.default.promises.writeFile(te.default.resolve(e.dirPath,".node-version"),i))}if(e.containingPoetryLock&&(B("poetry 1.1.13",0,t),B("python 3.9.10",0,t)),e.depending.firebase&&B("java adoptopenjdk-17.0.2+8",0,t),e.containingPackageJson){let o=J("npm",["show","yarn","version"],e.dirPath);B(`yarn ${o}`,t.length,t)}let n=te.default.resolve(e.dirPath,".tool-versions");t.length?await c.run(()=>z.default.promises.writeFile(n,t.join(`
3
3
  `)+`
4
- `)):await c.run(()=>z.default.promises.rm(n,{force:!0})),await c.promiseAll(),h("asdf",["install"],e.dirPath)}function M(e,t,n){let[o]=e.split(" "),r=n.findIndex(i=>i.split(/\s+/)[0]===o);r>=0?n[r]=e:n.splice(t,0,e)}var Se=l(require("path"));var P={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 xe=l(require("fs/promises")),d={async generateFile(e,t){await xe.default.writeFile(e,t),console.log(`Generated ${e}`)}};var wt=`root = true
4
+ `)):await c.run(()=>z.default.promises.rm(n,{force:!0})),await c.promiseAll(),h("asdf",["install"],e.dirPath)}function B(e,t,n){let[o]=e.split(" "),r=n.findIndex(i=>i.split(/\s+/)[0]===o);r>=0?n[r]=e:n.splice(t,0,e)}var Se=l(require("path"));var P={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 xe=l(require("fs/promises")),d={async generateFile(e,t){await xe.default.writeFile(e,t),console.log(`Generated ${e}`)}};var kt=`root = true
5
5
 
6
6
  [*]
7
7
  charset = utf-8
@@ -9,33 +9,33 @@ end_of_line = lf
9
9
  insert_final_newline = true
10
10
  trim_trailing_whitespace = true
11
11
 
12
- ${B(P.codeWith2IndentSize)}
12
+ ${U(P.codeWith2IndentSize)}
13
13
  indent_size = 2
14
14
  indent_style = space
15
15
 
16
- ${B(P.codeWith4IndentSize)}
16
+ ${U(P.codeWith4IndentSize)}
17
17
  indent_size = 4
18
18
  indent_style = space
19
19
 
20
- ${B(P.codeWith8IndentSize)}
20
+ ${U(P.codeWith8IndentSize)}
21
21
  indent_size = 8
22
22
  indent_style = space
23
23
 
24
- ${B(P.markdownLike)}
24
+ ${U(P.markdownLike)}
25
25
  max_line_length = off
26
26
  trim_trailing_whitespace = false
27
27
 
28
28
  [{Makefile,*.mk}]
29
29
  indent_style = tab
30
- `;async function Ce(e){let t=Se.default.resolve(e.dirPath,".editorconfig");await c.run(()=>d.generateFile(t,wt))}function B(e){return e.length>1?`[*.{${e.join(",")}}]`:`[*.${e[0]}]`}var ne=l(require("path"));var L=l(require("fs")),y={header:"# Project-specific settings",separator:"# Generated by @willbooster/willboosterify",separatorPrefix:"# Generated by @willbooster",async getExistingContent(e){try{return(await L.default.promises.readFile(e,"utf-8")).replace(/# Project-specific settings[^\n]*\n/m,"").replace(/# Generated by[^\n]*\n/m,"").replace(/\r?\n\r?\n(\r?\n)+/gm,`
30
+ `;async function Ce(e){let t=Se.default.resolve(e.dirPath,".editorconfig");await c.run(()=>d.generateFile(t,kt))}function U(e){return e.length>1?`[*.{${e.join(",")}}]`:`[*.${e[0]}]`}var ne=l(require("path"));var L=l(require("fs")),y={header:"# Project-specific settings",separator:"# Generated by @willbooster/willboosterify",separatorPrefix:"# Generated by @willbooster",async getExistingContent(e){try{return(await L.default.promises.readFile(e,"utf-8")).replace(/# Project-specific settings[^\n]*\n/m,"").replace(/# Generated by[^\n]*\n/m,"").replace(/\r?\n\r?\n(\r?\n)+/gm,`
31
31
 
32
32
  `)}catch{return null}},async getUserContent(e){try{let t=await L.default.promises.readFile(e,"utf-8"),n=t.indexOf(this.separatorPrefix);if(n>=0)return t.substring(0,t.indexOf(`
33
33
  `,n)+1)}catch{}return null},async isBerryZeroInstallEnabled(e){try{return(await L.default.promises.readFile(e,"utf-8")).includes(`
34
- !.yarn/cache`)}catch{return!1}}};var kt=`${y.header}
34
+ !.yarn/cache`)}catch{return!1}}};var bt=`${y.header}
35
35
 
36
36
 
37
37
  ${y.separator}
38
- `,bt=`
38
+ `,xt=`
39
39
  3rd-party/
40
40
  @types/
41
41
  __generated__/
@@ -48,24 +48,24 @@ test-fixtures/
48
48
  *.min.js
49
49
  .yarn/
50
50
  .pnp.js
51
- `;async function Fe(e){let t=ne.default.resolve(e.dirPath,".eslintignore"),n=await y.getUserContent(t)||kt,o=ne.default.resolve(e.dirPath,".gitignore"),r=await y.getExistingContent(o)||"",i=n+bt+r;await c.run(()=>d.generateFile(t,i))}var _e=l(require("fs")),je=l(require("path")),Re=l(require("deepmerge"));var $e=l(require("deepmerge"));function U(e,t){return t}function G(e,t,n){let o=e.slice();return t.forEach((r,i)=>{typeof o[i]>"u"?o[i]=n.cloneUnlessOtherwiseSpecified(r,n):n.isMergeableObject(r)?o[i]=(0,$e.default)(e[i],r,n):e.indexOf(r)===-1&&o.push(r)}),o}async function Te(e,t){let n=[];e.eslintBase&&n.push(e.eslintBase),e!==t&&n.push("../../.eslintrc.json");let o={root:!0,extends:n},r=je.default.resolve(e.dirPath,".eslintrc.json");try{let a=await _e.default.promises.readFile(r,"utf-8"),s=JSON.parse(a);s.extends&&(s.extends=s.extends.filter(m=>!m.startsWith("@willbooster/")&&m!=="../../.eslintrc.json")),n.length||(s.extends=[]);let f=o.extends;o.extends=s.extends,s.extends=f,o=Re.default.all([o,s,o],{arrayMerge:G}),e.depending.blitz&&(o.extends=[...o.extends.filter(m=>m!=="blitz"),"blitz"])}catch{}let i=JSON.stringify(o);await c.run(()=>d.generateFile(r,i))}var Oe=l(require("path"));var xt=`* text=auto
51
+ `;async function Fe(e){let t=ne.default.resolve(e.dirPath,".eslintignore"),n=await y.getUserContent(t)||bt,o=ne.default.resolve(e.dirPath,".gitignore"),r=await y.getExistingContent(o)||"",i=n+xt+r;await c.run(()=>d.generateFile(t,i))}var $e=l(require("fs")),je=l(require("path")),Re=l(require("deepmerge"));var _e=l(require("deepmerge"));function M(e,t){return t}function G(e,t,n){let o=e.slice();return t.forEach((r,i)=>{typeof o[i]>"u"?o[i]=n.cloneUnlessOtherwiseSpecified(r,n):n.isMergeableObject(r)?o[i]=(0,_e.default)(e[i],r,n):e.indexOf(r)===-1&&o.push(r)}),o}async function Te(e,t){let n=[];e.eslintBase&&n.push(e.eslintBase),e!==t&&n.push("../../.eslintrc.json");let o={root:!0,extends:n},r=je.default.resolve(e.dirPath,".eslintrc.json");try{let a=await $e.default.promises.readFile(r,"utf-8"),s=JSON.parse(a);s.extends&&(s.extends=s.extends.filter(m=>!m.startsWith("@willbooster/")&&m!=="../../.eslintrc.json")),n.length||(s.extends=[]);let f=o.extends;o.extends=s.extends,s.extends=f,o=Re.default.all([o,s,o],{arrayMerge:G}),e.depending.blitz&&(o.extends=[...o.extends.filter(m=>m!=="blitz"),"blitz"])}catch{}let i=JSON.stringify(o);await c.run(()=>d.generateFile(r,i))}var Oe=l(require("path"));var St=`* text=auto
52
52
 
53
53
  *.vcproj text eol=crlf
54
54
 
55
55
  ${P.codeWith2IndentSize.concat(P.codeWith4IndentSize).concat(P.markdownLike).map(e=>`*.${e} text eol=lf`).join(`
56
56
  `)}
57
- `;async function De(e){let t=Oe.default.resolve(e.dirPath,".gitattributes");await c.run(()=>d.generateFile(t,xt))}var oe=l(require("path"));async function Y(e,t){let{default:n}=await import("node-fetch");return n(e,t)}var St=["windows","macos","linux","jetbrains","visualstudiocode","emacs","vim","yarn"],Ct=`${y.header}
57
+ `;async function De(e){let t=Oe.default.resolve(e.dirPath,".gitattributes");await c.run(()=>d.generateFile(t,St))}var oe=l(require("path"));async function Y(e,t){let{default:n}=await import("node-fetch");return n(e,t)}var Ct=["windows","macos","linux","jetbrains","visualstudiocode","emacs","vim","yarn"],Ft=`${y.header}
58
58
 
59
59
 
60
60
  ${y.separator}
61
- `,Ft=`
61
+ `,_t=`
62
62
  .devcontainer/
63
63
  dist/
64
64
  temp/
65
65
  Icon[\r]
66
66
  *.sqlite3
67
67
  *.sqlite3-journal
68
- `,ie=new Map;async function Je(e,t){let n=oe.default.resolve(e.dirPath,".gitignore"),o=(await y.getUserContent(n)||Ct)+Ft,r=[...St];e.containingGemfile&&r.push("ruby"),e.containingGoMod&&(r.push("go"),o+=`${oe.default.basename(e.dirPath)}
68
+ `,ie=new Map;async function Ee(e,t){let n=oe.default.resolve(e.dirPath,".gitignore"),o=(await y.getUserContent(n)||Ft)+_t,r=[...Ct];e.containingGemfile&&r.push("ruby"),e.containingGoMod&&(r.push("go"),o+=`${oe.default.basename(e.dirPath)}
69
69
  `),e.containingPackageJson&&r.push("node"),e.containingPomXml&&(r.push("maven"),o+=`.idea/google-java-format.xml
70
70
  `),e.containingPubspecYaml&&(r.push("flutter","AndroidStudio","ruby"),o+=`.flutter-plugins-dependencies
71
71
  android/key.properties
@@ -86,7 +86,7 @@ if [ $(git branch --show-current) = "main" ]; then
86
86
  exit 1
87
87
  fi
88
88
 
89
- yarn typecheck`.trim(),postMerge:"yarn"};async function Ee(e){var m,u;let t=_.default.resolve(e.dirPath,"package.json"),n=await x.default.promises.readFile(t,"utf-8"),o=JSON.parse(n);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([x.default.promises.writeFile(t,JSON.stringify(o,void 0,2)),x.default.promises.rm(r,{force:!0,recursive:!0})]),h("yarn",["dlx","husky-init","--yarn2"],e.dirPath);let i=_.default.resolve(r,"pre-commit"),a=await x.default.promises.readFile(i,"utf-8");if(await c.run(()=>x.default.promises.rm(_.default.resolve(e.dirPath,".huskyrc.json"),{force:!0})),await c.run(()=>x.default.promises.writeFile(i,a.replace(re,A.preCommit))),e.containingTypeScript||e.containingTypeScriptInPackages){let p=(m=e.repository)!=null&&m.startsWith("github:WillBoosterLab/")?A.prePushForLab:A.prePush;await c.run(()=>x.default.promises.writeFile(_.default.resolve(r,"pre-push"),a.replace(re,p),{mode:493}))}let s=[];(u=e.versionsText)!=null&&u.includes("python ")&&s.push("asdf install python"),e.versionsText&&s.push("asdf install"),s.push(A.postMerge),e.containingPoetryLock&&s.push("poetry install"),(e.depending.blitz||e.depending.prisma)&&s.push("yarn gen-code");let f=a.replace(re,s.join(" && "));await c.run(()=>x.default.promises.writeFile(_.default.resolve(r,"post-merge"),f,{mode:493}))}var se=l(require("fs")),ae=l(require("path"));var $t=`<?xml version="1.0" encoding="UTF-8"?>
89
+ yarn typecheck`.trim(),postMerge:"yarn"};async function Je(e){var m,u;let t=_.default.resolve(e.dirPath,"package.json"),n=await x.default.promises.readFile(t,"utf-8"),o=JSON.parse(n);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([x.default.promises.writeFile(t,JSON.stringify(o,void 0,2)),x.default.promises.rm(r,{force:!0,recursive:!0})]),h("yarn",["dlx","husky-init","--yarn2"],e.dirPath);let i=_.default.resolve(r,"pre-commit"),a=await x.default.promises.readFile(i,"utf-8");if(await c.run(()=>x.default.promises.rm(_.default.resolve(e.dirPath,".huskyrc.json"),{force:!0})),await c.run(()=>x.default.promises.writeFile(i,a.replace(re,A.preCommit))),e.containingTypeScript||e.containingTypeScriptInPackages){let p=(m=e.repository)!=null&&m.startsWith("github:WillBoosterLab/")?A.prePushForLab:A.prePush;await c.run(()=>x.default.promises.writeFile(_.default.resolve(r,"pre-push"),a.replace(re,p),{mode:493}))}let s=[];(u=e.versionsText)!=null&&u.includes("python ")&&s.push("asdf install python"),e.versionsText&&s.push("asdf install"),s.push(A.postMerge),e.containingPoetryLock&&s.push("poetry install"),(e.depending.blitz||e.depending.prisma)&&s.push("yarn gen-code");let f=a.replace(re,s.join(" && "));await c.run(()=>x.default.promises.writeFile(_.default.resolve(r,"post-merge"),f,{mode:493}))}var se=l(require("fs")),ae=l(require("path"));var $t=`<?xml version="1.0" encoding="UTF-8"?>
90
90
  <project version="4">
91
91
  <component name="ProjectTasksOptions">
92
92
  <TaskOptions isEnabled="true">
@@ -211,10 +211,10 @@ yarn typecheck`.trim(),postMerge:"yarn"};async function Ee(e){var m,u;let t=_.de
211
211
  </TaskOptions>
212
212
  </component>
213
213
  </project>
214
- `;async function Ne(e){let t=ae.default.resolve(e.dirPath,".idea");if(se.default.existsSync(t)){let n=ae.default.resolve(t,"watcherTasks.xml");e.containingJavaScript||e.containingJavaScriptInPackages||e.containingTypeScript||e.containingTypeScriptInPackages||e.containingPackageJson&&!e.containingPubspecYaml&&!e.containingGemfile&&!e.containingGoMod&&!e.containingPomXml?await c.run(()=>d.generateFile(n,$t)):await c.run(()=>se.default.promises.rm(n,{force:!0}))}}var le=l(require("fs")),K=l(require("path"));var q={getLintFixSuffix(e){return e.containingJsxOrTsx?' --rule "{ react-hooks/exhaustive-deps: 0 }"':""}};var N={node:["src","__tests__","scripts"],blitz:["app","db","integrations","mailers","test"]};N.blitz=[...N.node,...N.blitz];function H(e){return e.depending.blitz?N.blitz:N.node}async function ce(e){let t=[];if(e.containingJavaScript||e.containingTypeScript){let i=`
215
- '${Ie(e)}': [${JSON.stringify(`eslint --fix${q.getLintFixSuffix(e)}`)}, 'prettier --write'],`;t.push(i)}let n=e.root?" && !file.includes('/packages/')":"";t.push(`
214
+ `;async function Ne(e){let t=ae.default.resolve(e.dirPath,".idea");if(se.default.existsSync(t)){let n=ae.default.resolve(t,"watcherTasks.xml");e.containingJavaScript||e.containingJavaScriptInPackages||e.containingTypeScript||e.containingTypeScriptInPackages||e.containingPackageJson&&!e.containingPubspecYaml&&!e.containingGemfile&&!e.containingGoMod&&!e.containingPomXml?await c.run(()=>d.generateFile(n,$t)):await c.run(()=>se.default.promises.rm(n,{force:!0}))}}var le=l(require("fs")),V=l(require("path"));var K={getLintFixSuffix(e){return e.containingJsxOrTsx?' --rule "{ react-hooks/exhaustive-deps: 0 }"':""}};var N={node:["src","__tests__","scripts"],blitz:["app","db","integrations","mailers","test"]};N.blitz=[...N.node,...N.blitz];function q(e){return e.depending.blitz?N.blitz:N.node}async function ce(e){let t=[];if(e.containingJavaScript||e.containingTypeScript){let i=`
215
+ '${We(e)}': [${JSON.stringify(`eslint --fix${K.getLintFixSuffix(e)}`)}, 'prettier --write'],`;t.push(i)}let n=e.root?" && !file.includes('/packages/')":"";t.push(`
216
216
  './**/*.{${P.prettier.join(",")}}': files => {
217
- ${e.containingJavaScript||e.containingTypeScript?_t(e):""}
217
+ ${e.containingJavaScript||e.containingTypeScript?jt(e):""}
218
218
  const filteredFiles = files.filter(file => !file.includes('/test-fixtures/')${n});
219
219
  if (filteredFiles.length === 0) return [];
220
220
  const commands = [\`prettier --write \${filteredFiles.join(' ')}\`];
@@ -237,12 +237,12 @@ yarn typecheck`.trim(),postMerge:"yarn"};async function Ee(e){var m,u;let t=_.de
237
237
 
238
238
  module.exports = {${t.join("")}
239
239
  };
240
- `,r=K.default.resolve(e.dirPath,".lintstagedrc.cjs");await c.run(()=>le.default.promises.rm(K.default.resolve(e.dirPath,".lintstagedrc.js"),{force:!0})),await c.run(()=>le.default.promises.rm(K.default.resolve(e.dirPath,".lintstagedrc.json"),{force:!0})),await c.run(()=>d.generateFile(r,o))}function Ie(e){return`./{${H(e).join(",")}}/**/*.{${P.eslint.join(",")}}`}function _t(e){return`files = micromatch.not(files, '${Ie(e)}');`}var S=l(require("fs")),D=l(require("path")),me=l(require("deepmerge"));var pe=["eslint","eslint-config-prettier","eslint-plugin-import","eslint-plugin-sort-class-members","eslint-plugin-sort-destructure-keys"],We=[...pe,"@typescript-eslint/eslint-plugin","@typescript-eslint/parser","eslint-import-resolver-typescript"],Me=["eslint-plugin-react","eslint-plugin-react-hooks"],ze={"@willbooster/eslint-config-js":["@willbooster/eslint-config-js",...pe],"@willbooster/eslint-config-js-react":["@willbooster/eslint-config-js-react",...pe,...Me],"@willbooster/eslint-config-ts":["@willbooster/eslint-config-ts",...We],"@willbooster/eslint-config-ts-react":["@willbooster/eslint-config-ts-react",...We,...Me],"../../.eslintrc.json":[]};async function Be(e,t,n){var m,u;let o=D.default.resolve(e.dirPath,"package.json"),r=await S.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 jt(i),i.name!=="@willbooster/prettier-config"&&(i.prettier="@willbooster/prettier-config");for(let p of Object.keys(i.scripts))i.scripts[p].includes("git clone")||(i.scripts[p]=i.scripts[p].replace(/yarn\s*&&\s*/,"").replace(/yarn\s*install\s*&&\s*/,""));i.scripts=(0,me.default)(i.scripts,Rt(e)),i.scripts.prettify+=await Tt(e.dirPath);let a=[],s=["lint-staged","prettier","sort-package-json","@willbooster/prettier-config"],f=[];if(e.root&&(s.push("husky","pinst","@willbooster/renovate-config"),e.depending.semanticRelease&&s.push("conventional-changelog-conventionalcommits"),e.containingSubPackageJsons?i.workspaces=["packages/*"]:delete i.workspaces),(e.containingJavaScript||e.containingJavaScriptInPackages||e.containingTypeScript||e.containingTypeScriptInPackages)&&(s.push("eslint","micromatch"),e.containingTypeScriptInPackages&&s.push("@typescript-eslint/parser")),(e.containingTypeScript||e.containingTypeScriptInPackages)&&!e.depending.blitz&&s.push("typescript"),e.eslintBase&&s.push(...ze[e.eslintBase]),e.willBoosterConfigs&&(a=a.filter(p=>!p.includes("@willbooster/")),s=s.filter(p=>!p.includes("@willbooster/"))),i.name||(i.name=D.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"]+=q.getLintFixSuffix(e),e.containingPubspecYaml){i.scripts.lint="flutter analyze",i.scripts["lint-fix"]="yarn lint";let p=["lib","test","test_driver"].filter(v=>S.default.existsSync(D.default.resolve(e.dirPath,v)));p.length>0&&(i.scripts["format-code"]=`flutter format $(find ${p.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 p=(await S.default.promises.readdir(e.dirPath)).filter(v=>{let $=D.default.resolve(e.dirPath,v);return S.default.lstatSync($).isDirectory()?S.default.readdirSync($).some(k=>k.endsWith(".py")):!1});p.length>0&&(i.scripts["format-code"]=`poetry run isort --profile black ${p.join(" ")} && poetry run black ${p.join(" ")}`,i.scripts.lint=`poetry run flake8 ${p.join(" ")}`,i.scripts["lint-fix"]="yarn lint",i.scripts.format+=" && yarn format-code",f.push("black","isort","flake8"))}e.repository&&(i.repository=e.repository)}e.depending.blitz?(s=s.filter(p=>!p.includes("@typescript-eslint/")),s=s.filter(p=>p!=="eslint-plugin-react"&&p!=="eslint-import-resolver-typescript"&&p!=="eslint-plugin-import"&&p!=="eslint-plugin-react-hooks"),(m=i.scripts["gen-code"])!=null&&m.startsWith("blitz codegen")||(i.scripts["gen-code"]="blitz codegen")):e.depending.prisma&&((u=i.scripts["gen-code"])!=null&&u.startsWith("prisma generate")||(i.scripts["gen-code"]="prisma generate")),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 S.default.promises.writeFile(o,JSON.stringify(i)),n||(a=a.filter(p=>{var v;return!((v=i.devDependencies)!=null&&v[p])}),a.length&&h("yarn",["add",...new Set(a)],e.dirPath),s=s.filter(p=>{var v;return!((v=i.dependencies)!=null&&v[p])}),s.length&&h("yarn",["add","-D",...new Set(s)],e.dirPath),f.length&&h("poetry",["add",...new Set(f)],e.dirPath))}async function jt(e){e.author==="WillBooster LLC"&&(e.author="WillBooster Inc."),delete e.scripts["sort-package-json"],delete e.scripts["sort-all-package-json"],delete e.scripts["typecheck:codegen"],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 t of Object.values(ze))for(let n of t)delete e.devDependencies[n];await c.run(()=>S.default.promises.rm("lerna.json",{force:!0}))}function Rt(e){let t={cleanup:"yarn format && yarn lint-fix",format:"sort-package-json && yarn prettify",lint:`eslint --color "./{${H(e)}}/**/*.{${P.eslint.join(",")}}"`,"lint-fix":"yarn lint --fix",prettify:`prettier --color --write "**/{.*/,}*.{${P.prettier.join(",")}}" "!**/test-fixtures/**"`,typecheck:"tsc --noEmit --Pretty"};return e.containingSubPackageJsons&&(t=(0,me.default)(O({},t),{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 "**/{.*/,}*.{${P.prettier.join(",")}}" "!**/packages/**" "!**/test-fixtures/**"`,test:"yarn workspaces foreach --verbose run test",typecheck:"yarn workspaces foreach --parallel --verbose run typecheck"})),e.depending.blitz&&(t.typecheck=`${t.typecheck} || yarn run typecheck/warn`,t["typecheck/warn"]=`echo 'Please try "yarn gen-code" if you face unknown type errors.' && exit 1`,t["typecheck:gen-code"]="yarn gen-code && tsc --noEmit --Pretty"),t}async function Tt(e){let t=D.default.resolve(e,".prettierignore"),n=await S.default.promises.readFile(t,"utf-8"),o=n.indexOf(y.separatorPrefix);return o<0?"":n.substring(0,o).split(`
241
- `).map(a=>{let s=a.trim();return s.endsWith("/")?s.slice(0,-1):s}).filter(a=>a&&!a.startsWith("#")&&!a.includes("/")).map(a=>` "!**/${a}/**"`).join("")}var fe=l(require("path"));var Ot=`${y.header}
240
+ `,r=V.default.resolve(e.dirPath,".lintstagedrc.cjs");await c.run(()=>le.default.promises.rm(V.default.resolve(e.dirPath,".lintstagedrc.js"),{force:!0})),await c.run(()=>le.default.promises.rm(V.default.resolve(e.dirPath,".lintstagedrc.json"),{force:!0})),await c.run(()=>d.generateFile(r,o))}function We(e){return`./{${q(e).join(",")}}/**/*.{${P.eslint.join(",")}}`}function jt(e){return`files = micromatch.not(files, '${We(e)}');`}var S=l(require("fs")),O=l(require("path")),me=l(require("deepmerge"));var pe=["eslint","eslint-config-prettier","eslint-plugin-import","eslint-plugin-sort-class-members","eslint-plugin-sort-destructure-keys"],Ie=[...pe,"@typescript-eslint/eslint-plugin","@typescript-eslint/parser","eslint-import-resolver-typescript"],Be=["eslint-plugin-react","eslint-plugin-react-hooks"],ze={"@willbooster/eslint-config-js":["@willbooster/eslint-config-js",...pe],"@willbooster/eslint-config-js-react":["@willbooster/eslint-config-js-react",...pe,...Be],"@willbooster/eslint-config-ts":["@willbooster/eslint-config-ts",...Ie],"@willbooster/eslint-config-ts-react":["@willbooster/eslint-config-ts-react",...Ie,...Be],"../../.eslintrc.json":[]};async function Ue(e,t,n){var m,u;let o=O.default.resolve(e.dirPath,"package.json"),r=await S.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 Rt(i),i.name!=="@willbooster/prettier-config"&&(i.prettier="@willbooster/prettier-config");for(let p of Object.keys(i.scripts))i.scripts[p].includes("git clone")||(i.scripts[p]=i.scripts[p].replace(/yarn\s*&&\s*/,"").replace(/yarn\s*install\s*&&\s*/,""));i.scripts=(0,me.default)(i.scripts,Tt(e)),i.scripts.prettify+=await Ot(e.dirPath);let a=[],s=["lint-staged","prettier","sort-package-json","@willbooster/prettier-config"],f=[];if(e.root&&(s.push("husky","pinst","@willbooster/renovate-config"),e.depending.semanticRelease&&s.push("conventional-changelog-conventionalcommits"),e.containingSubPackageJsons?i.workspaces=["packages/*"]:delete i.workspaces),(e.containingJavaScript||e.containingJavaScriptInPackages||e.containingTypeScript||e.containingTypeScriptInPackages)&&(s.push("eslint","micromatch"),e.containingTypeScriptInPackages&&s.push("@typescript-eslint/parser")),(e.containingTypeScript||e.containingTypeScriptInPackages)&&!e.depending.blitz&&s.push("typescript"),e.eslintBase&&s.push(...ze[e.eslintBase]),e.willBoosterConfigs&&(a=a.filter(p=>!p.includes("@willbooster/")),s=s.filter(p=>!p.includes("@willbooster/"))),i.name||(i.name=O.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"]+=K.getLintFixSuffix(e),e.containingPubspecYaml){i.scripts.lint="flutter analyze",i.scripts["lint-fix"]="yarn lint";let p=["lib","test","test_driver"].filter(k=>S.default.existsSync(O.default.resolve(e.dirPath,k)));p.length>0&&(i.scripts["format-code"]=`flutter format $(find ${p.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 p=(await S.default.promises.readdir(e.dirPath)).filter(k=>{let E=O.default.resolve(e.dirPath,k);return S.default.lstatSync(E).isDirectory()?S.default.readdirSync(E).some(v=>v.endsWith(".py")):!1});p.length>0&&(i.scripts["format-code"]=`poetry run isort --profile black ${p.join(" ")} && poetry run black ${p.join(" ")}`,i.scripts.lint=`poetry run flake8 ${p.join(" ")}`,i.scripts["lint-fix"]="yarn lint",i.scripts.format+=" && yarn format-code",f.push("black","isort","flake8"))}e.repository&&(i.repository=e.repository)}e.depending.blitz?(s=s.filter(p=>!p.includes("@typescript-eslint/")),s=s.filter(p=>p!=="eslint-plugin-react"&&p!=="eslint-import-resolver-typescript"&&p!=="eslint-plugin-import"&&p!=="eslint-plugin-react-hooks"),(m=i.scripts["gen-code"])!=null&&m.startsWith("blitz codegen")||(i.scripts["gen-code"]="blitz codegen")):e.depending.prisma&&((u=i.scripts["gen-code"])!=null&&u.startsWith("prisma generate")||(i.scripts["gen-code"]="prisma generate")),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 S.default.promises.writeFile(o,JSON.stringify(i)),n||(a=a.filter(p=>{var k;return!((k=i.devDependencies)!=null&&k[p])}),a.length&&h("yarn",["add",...new Set(a)],e.dirPath),s=s.filter(p=>{var k;return!((k=i.dependencies)!=null&&k[p])}),s.length&&h("yarn",["add","-D",...new Set(s)],e.dirPath),f.length&&h("poetry",["add",...new Set(f)],e.dirPath))}async function Rt(e){e.author==="WillBooster LLC"&&(e.author="WillBooster Inc."),delete e.scripts["sort-package-json"],delete e.scripts["sort-all-package-json"],delete e.scripts["typecheck:codegen"],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 t of Object.values(ze))for(let n of t)delete e.devDependencies[n];await c.run(()=>S.default.promises.rm("lerna.json",{force:!0}))}function Tt(e){let t={cleanup:"yarn format && yarn lint-fix",format:"sort-package-json && yarn prettify",lint:`eslint --color "./{${q(e)}}/**/*.{${P.eslint.join(",")}}"`,"lint-fix":"yarn lint --fix",prettify:`prettier --color --write "**/{.*/,}*.{${P.prettier.join(",")}}" "!**/test-fixtures/**"`,typecheck:"tsc --noEmit --Pretty"};return e.containingSubPackageJsons&&(t=(0,me.default)(T({},t),{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 "**/{.*/,}*.{${P.prettier.join(",")}}" "!**/packages/**" "!**/test-fixtures/**"`,test:"yarn workspaces foreach --verbose run test",typecheck:"yarn workspaces foreach --parallel --verbose run typecheck"})),e.depending.blitz&&(t.typecheck=`${t.typecheck} || yarn run typecheck/warn`,t["typecheck/warn"]=`echo 'Please try "yarn gen-code" if you face unknown type errors.' && exit 1`,t["typecheck:gen-code"]="yarn gen-code && tsc --noEmit --Pretty"),t}async function Ot(e){let t=O.default.resolve(e,".prettierignore"),n=await S.default.promises.readFile(t,"utf-8"),o=n.indexOf(y.separatorPrefix);return o<0?"":n.substring(0,o).split(`
241
+ `).map(a=>{let s=a.trim();return s.endsWith("/")?s.slice(0,-1):s}).filter(a=>a&&!a.startsWith("#")&&!a.includes("/")).map(a=>` "!**/${a}/**"`).join("")}var fe=l(require("path"));var Dt=`${y.header}
242
242
 
243
243
 
244
244
  ${y.separator}
245
- `,Dt=`
245
+ `,Et=`
246
246
  3rd-party/
247
247
  android/
248
248
  ios/
@@ -252,9 +252,9 @@ test-fixtures/
252
252
  *.min.js
253
253
  .yarn/
254
254
  .pnp.js
255
- `;async function Le(e){let t=fe.default.resolve(e.dirPath,".prettierignore"),n=await y.getUserContent(t)||Ot,o=fe.default.resolve(e.dirPath,".gitignore"),r=await y.getExistingContent(o)||"",i="";e.containingPubspecYaml&&(i=`
255
+ `;async function Le(e){let t=fe.default.resolve(e.dirPath,".prettierignore"),n=await y.getUserContent(t)||Dt,o=fe.default.resolve(e.dirPath,".gitignore"),r=await y.getExistingContent(o)||"",i="";e.containingPubspecYaml&&(i=`
256
256
  android/app/
257
257
  ios/Runner/Assets.xcassets/
258
258
  pubspec.yaml
259
- `);let a=n+Dt+i+r;await c.run(()=>d.generateFile(t,a))}var Ue=l(require("fs")),Ge=l(require("path"));async function Ye(e){let t=Ge.default.resolve(e.dirPath,".releaserc.json");try{let n=JSON.parse(await Ue.default.promises.readFile(t,"utf8")),o=(n==null?void 0:n.plugins)||[];for(let i=0;i<o.length;i++){let a=Array.isArray(o[i])?o[i][0]:o[i];a==="@semantic-release/commit-analyzer"?o[i]=["@semantic-release/commit-analyzer",{preset:"conventionalcommits"}]:a==="@semantic-release/github"&&!e.publicRepo&&(o[i]=["@semantic-release/github",{successComment:!1}])}let r=JSON.stringify(n);await c.run(()=>d.generateFile(t,r))}catch{}}var V=l(require("fs")),X=l(require("path")),Ae=l(require("deepmerge")),qe=l(require("lodash.clonedeep"));var Jt={extends:["@willbooster"]};async function He(e){let t=(0,qe.default)(Jt),n=X.default.resolve(e.dirPath,".renovaterc.json");try{let r=await V.default.promises.readFile(n,"utf-8"),i=JSON.parse(r);t=Ae.default.all([t,i,t],{arrayMerge:U})}catch{}await c.run(()=>V.default.promises.rm(X.default.resolve(e.dirPath,".dependabot"),{force:!0})),await c.run(()=>V.default.promises.rm(X.default.resolve(e.dirPath,"renovate.json"),{force:!0}));let o=JSON.stringify(t);await c.run(()=>d.generateFile(n,o))}var Ke=l(require("fs")),ue=l(require("path")),Ve=l(require("js-yaml"));var Et={titleOnly:!0};async function Xe(e){let t=ue.default.resolve(e.dirPath,".github");await Ke.default.promises.mkdir(t,{recursive:!0});let n=ue.default.join(t,"semantic.yml"),o=Ve.default.dump(Et);await c.run(()=>d.generateFile(n,o))}var Ze=l(require("fs")),W=l(require("path")),Qe=l(require("deepmerge")),et=l(require("lodash.clonedeep"));function I(e){let t=Object.entries(e).sort(([n],[o])=>n.localeCompare(o));for(let[n,o]of t)delete e[n],e[n]=o}var Nt={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__/**/*","scripts/**/*","packages/*/src/**/*","packages/*/__tests__/**/*","packages/*/scripts/**/*","./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__/**/*","scripts/**/*","../../node_modules/@types","../../@types","./@types"]};async function tt(e,t){var i,a,s;if(t.depending.blitz)return;let n=(0,et.default)(e.root?Nt:It);if(!e.containingJsxOrTsx&&!e.containingJsxOrTsxInPackages&&delete n.compilerOptions.jsx,e.root&&!e.containingSubPackageJsons&&(n.include=n.include.filter(f=>!f.startsWith("packages/*/"))),!e.root&&(e.depending.jestPlaywrightPreset||t.depending.jestPlaywrightPreset)){let f=W.default.relative(e.dirPath,t.dirPath);n.include.push(W.default.join(f,"node_modules/jest-playwright-preset/types"),W.default.join(f,"node_modules/expect-playwright"))}let o=W.default.resolve(e.dirPath,"tsconfig.json");try{let f=await Ze.default.promises.readFile(o,"utf-8"),m=JSON.parse(f);m.extends==="./node_modules/@willbooster/tsconfig/tsconfig.json"&&delete m.extends,(i=m.compilerOptions)==null||delete i.typeRoots,(a=n==null?void 0:n.compilerOptions)==null||delete a.target,(s=n==null?void 0:n.compilerOptions)==null||delete s.module,m.jsx&&delete n.jsx,e.depending.blitz&&delete n.include,n=Qe.default.all([n,m,n],{arrayMerge:U})}catch{}I(n.compilerOptions);let r=JSON.stringify(n);await c.run(()=>d.generateFile(o,r))}var R=l(require("fs")),j=l(require("path")),it=l(require("deepmerge")),de=l(require("js-yaml")),ot=l(require("lodash.clonedeep"));var Wt={name:"Test",on:{pull_request:{branches:["main","!renovate/**"]},push:{branches:["main","renovate/**"]}},jobs:{test:{uses:"WillBooster/reusable-workflows/.github/workflows/test.yml@main"}}},Mt={name:"Release",on:{push:{branches:[]}},jobs:{release:{uses:"WillBooster/reusable-workflows/.github/workflows/release.yml@main"}}},zt={name:"Willboosterify",on:{workflow_dispatch:null},jobs:{wbfy:{uses:"WillBooster/reusable-workflows/.github/workflows/wbfy.yml@main"}}};async function rt(e){let t=j.default.resolve(e.dirPath,".github","workflows");await R.default.promises.mkdir(t,{recursive:!0});let n=(await R.default.promises.readdir(t,{withFileTypes:!0})).filter(o=>o.isFile()&&o.name.endsWith(".yml")).map(o=>o.name);e.depending.semanticRelease&&n.push("release.yml"),n.push("test.yml","wbfy.yml");for(let o of n){let r=j.default.basename(o,".yml");await c.run(()=>Bt(e,t,r))}}async function nt(e,t){let n=de.default.dump(e,{lineWidth:-1,noCompatMode:!0,styles:{"!!null":"empty"}});await c.run(()=>R.default.promises.writeFile(t,n))}async function Bt(e,t,n){var i,a,s,f,m;let o={};n==="test"?o=Wt:n==="release"?o=Mt:n==="wbfy"&&(o=zt),o=(0,ot.default)(o);let r=j.default.join(t,`${n}.yml`);try{let u=await R.default.promises.readFile(r,"utf-8"),p=de.default.load(u);o=it.default.all([o,p,o],{arrayMerge:G})}catch{}for(let u of Object.values(o.jobs)){if(!((a=(i=u.uses)==null?void 0:i.includes)!=null&&a.call(i,"/reusable-workflows/")))return;Lt(e,u,n)}if(n==="release")o.on.schedule?delete o.on.push:o.on.push.branches=e.release.branches;else if(n==="wbfy"){let u=(m=(f=(s=o.on.schedule)==null?void 0:s[0])==null?void 0:f.cron)==null?void 0:m[0];if(!u||u==="0"){let p=1+Math.floor(Math.random()*59),v=(3+Math.floor(Math.random()*6)+9)%24,$=`${p} ${v} * * *`;o.on.schedule=[{cron:$}]}}if(await nt(o,r),n==="release")await c.run(()=>R.default.promises.rm(j.default.join(t,"semantic-release.yml"),{force:!0}));else if(n==="sync"){if(await c.run(()=>R.default.promises.rm(j.default.join(t,"sync-init.yml"),{force:!0})),!o.jobs.sync)return;o.jobs["sync-force"]=o.jobs.sync;let u=o.jobs.sync.with.sync_params_without_dest;if(!u)return;o.jobs.sync.with.sync_params_without_dest=`--force ${u}`,o.name="Force to Sync",o.on={workflow_dispatch:null},delete o.jobs.sync,await nt(o,j.default.join(t,"sync-force.yml"))}}function Lt(e,t,n){var o,r,i;if(t.with||(t.with={}),t.secrets||(t.secrets={}),(e.release.github&&n==="test"||n==="release"||n==="wbfy")&&(e.publicRepo?t.secrets.GH_TOKEN="${{ secrets.PUBLIC_GH_BOT_PAT }}":t.secrets.GH_TOKEN="${{ secrets.GH_BOT_PAT }}"),e.release.npm&&(n==="release"||n==="test")&&(t.secrets.NPM_TOKEN="${{ secrets.NPM_TOKEN }}"),n==="sync"){let a=(o=t.with)==null?void 0:o.sync_params_without_dest;a&&(t.with.sync_params_without_dest=a.replace("sync ",""))}(r=e.repository)!=null&&r.startsWith("github:WillBooster/")?t.uses=t.uses.replace("WillBoosterLab/","WillBooster/"):(i=e.repository)!=null&&i.startsWith("github:WillBoosterLab/")&&(t.uses=t.uses.replace("WillBooster/","WillBoosterLab/")),delete t.with.non_self_hosted,e.containingDockerfile&&n.startsWith("deploy")&&(t.with.cpu_arch="X64"),Object.keys(t.with).length?I(t.with):delete t.with,Object.keys(t.secrets).length?I(t.secrets):delete t.secrets}var T=l(require("fs")),J=l(require("path")),ge=l(require("js-yaml"));async function at(e){let t=E("yarn",["--version"],e.dirPath),n=E("npm",["show","@yarnpkg/cli","version"],e.dirPath);t!==n&&h("yarn",["set","version",n],e.dirPath,1);let o=J.default.join(e.dirPath,".yarn","releases");await T.default.promises.mkdir(o,{recursive:!0});for(let m of await T.default.promises.readdir(o))m.startsWith("yarn-")&&!m.startsWith(`yarn-${n}.`)&&(await c.run(()=>T.default.promises.rm(J.default.join(o,m))),console.log("Removed",J.default.join(o,m)));let r=J.default.resolve(e.dirPath,".yarnrc");await c.run(()=>T.default.promises.rm(r,{force:!0}));let i=J.default.resolve(e.dirPath,".yarnrc.yml"),a=ge.default.load(await T.default.promises.readFile(i,"utf8"));a.defaultSemverRangePrefix="",e.requiringNodeModules&&(a.nodeLinker="node-modules",a.nmMode="hardlinks-global"),await T.default.promises.writeFile(i,ge.default.dump(a,{lineWidth:-1}));let s=(a.plugins||[]).map(m=>m.spec),f=e.containingTypeScript||e.containingTypeScriptInPackages;st(e,s,f,"@yarnpkg/plugin-typescript"),f&&!e.requiringNodeModules&&h("yarn",["dlx","@yarnpkg/sdks","vscode"],e.dirPath),st(e,s,e.containingSubPackageJsons,"@yarnpkg/plugin-workspace-tools"),h("yarn",["dlx","yarn-plugin-auto-install"],e.dirPath)}function st(e,t,n,o){n!==t.includes(o)&&h("yarn",["plugin",n?"import":"remove",o],e.dirPath)}var w=l(require("fs")),Z=l(require("fs/promises")),g=l(require("path")),F=l(require("glob")),ct=l(require("js-yaml")),pt=l(require("simple-git"));async function ye(e){var n;let t=g.default.resolve(e,"package.json");try{let o=w.default.existsSync(t),r={},i={},a={};if(o){let C=w.default.readFileSync(t,"utf-8");a=JSON.parse(C),r=a.dependencies??{},i=a.devDependencies??{}}let s=!0;try{let C=g.default.resolve(e,".yarnrc.yml"),b=ct.default.load(await Z.default.readFile(C,"utf8"));s=!b.nodeLinker||b.nodeLinker==="node-modules"}catch{}let f=[],m=[];try{let C=g.default.resolve(e,".releaserc.json"),b=JSON.parse(await Z.default.readFile(C,"utf8"));f=(b==null?void 0:b.branches)||[],m=((n=b==null?void 0:b.plugins)==null?void 0:n.flat())||[]}catch{}let u=g.default.basename(g.default.resolve(e,".."))!=="packages"||!w.default.existsSync(g.default.resolve(e,"..","..","package.json")),p;u&&(p=await Gt(e,a));let v=g.default.resolve(e,".tool-versions"),$;try{$=await Z.default.readFile(v,"utf-8")}catch{}let k={dirPath:e,root:u,publicRepo:(p==null?void 0:p.private)===!1,repository:p!=null&&p.full_name?`github:${p==null?void 0:p.full_name}`:void 0,willBoosterConfigs:t.includes(`${g.default.sep}willbooster-configs`),containingSubPackageJsons:F.default.sync("packages/**/package.json",{cwd:e}).length>0,containingDockerfile:w.default.existsSync(g.default.resolve(e,"Dockerfile"))||w.default.existsSync(g.default.resolve(e,"docker-compose.yml")),containingGemfile:w.default.existsSync(g.default.resolve(e,"Gemfile")),containingGoMod:w.default.existsSync(g.default.resolve(e,"go.mod")),containingPackageJson:w.default.existsSync(g.default.resolve(e,"package.json")),containingPoetryLock:w.default.existsSync(g.default.resolve(e,"poetry.lock")),containingPomXml:w.default.existsSync(g.default.resolve(e,"pom.xml")),containingPubspecYaml:w.default.existsSync(g.default.resolve(e,"pubspec.yaml")),containingTemplateYaml:w.default.existsSync(g.default.resolve(e,"template.yaml")),containingJavaScript:F.default.sync("@(app|src|__tests__|scripts)/**/*.js?(x)",{cwd:e}).length>0,containingTypeScript:F.default.sync("@(app|src|__tests__|scripts)/**/*.ts?(x)",{cwd:e}).length>0,containingJsxOrTsx:F.default.sync("@(app|src|__tests__)/**/*.{t,j}sx",{cwd:e}).length>0,containingJavaScriptInPackages:F.default.sync("packages/**/@(app|src|__tests__|scripts)/**/*.js?(x)",{cwd:e}).length>0,containingTypeScriptInPackages:F.default.sync("packages/**/@(app|src|__tests__|scripts)/**/*.ts?(x)",{cwd:e}).length>0,containingJsxOrTsxInPackages:F.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:f,github:m.includes("@semantic-release/github"),npm:m.includes("@semantic-release/npm")},requiringNodeModules:s,versionsText:$};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 Gt(e,t){var s,f,m;let r=(await(0,pt.default)(e).getRemotes(!0)).find(u=>u.name==="origin"),i=((s=r==null?void 0:r.refs)==null?void 0:s.fetch)??((f=r==null?void 0:r.refs)==null?void 0:f.push);if(typeof i=="string"){let u=await lt(i);if(u)return u}let a=((m=t.repository)==null?void 0:m.url)??t.repository;if(typeof a=="string"){let u=await lt(a);if(u&&u.message!=="Not Found")return u}}async function lt(e){var m;let t=e.split(":").at(-1),n=t==null?void 0:t.split("/"),o=n==null?void 0:n.at(-2),r=(m=n==null?void 0:n.at(-1))==null?void 0:m.replace(/.git$/,"");if(!o||!r)return;let i=process.env.GH_TOKEN||process.env.GITHUB_TOKEN,a=i?{headers:{Authorization:`token ${i}`}}:void 0,f=await(await Y(`https://api.github.com/repos/${o}/${r}`,a)).json();return O({full_name:`${o}/${r}`},f??{})}async function Yt(){let e=await(0,ut.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 t of e._){if(typeof t=="number")continue;let n=await ye(t);if(n===null){console.error(`there is no valid package.json in ${t}`);continue}let o=n.containingSubPackageJsons?ft.default.sync("packages/*",{cwd:t}).map(s=>mt.default.resolve(t,s)):[],r=(await Promise.all(o.map(s=>ye(s)))).filter(s=>!!s),i=[n,...r];if(e.verbose)for(let s of i)console.log(s);await be(n),await at(n),await Promise.all([Ce(n),De(n),Ee(n),Ne(n),ce(n),He(n),Ye(n),Xe(n),rt(n)]),await c.promiseAll();let a=[];for(let s of i)await Je(s,n),!(!s.root&&!s.containingPackageJson)&&(await Le(s),await Be(s,n,e.skipDeps),a.push(ce(s)),(s.containingTypeScript||s.containingTypeScriptInPackages)&&a.push(tt(s,n)),(s.containingJavaScript||s.containingJavaScriptInPackages||s.containingTypeScript||s.containingTypeScriptInPackages)&&(n.willBoosterConfigs||a.push(Te(s,n)),a.push(Fe(s))));await Promise.all(a),await c.promiseAll(),h("yarn",["cleanup"],t),h("yarn",["install"],t)}}Yt().then();
259
+ `);let a=n+Et+i+r;await c.run(()=>d.generateFile(t,a))}var Me=l(require("fs")),Ge=l(require("path"));async function Ye(e){let t=Ge.default.resolve(e.dirPath,".releaserc.json");try{let n=JSON.parse(await Me.default.promises.readFile(t,"utf8")),o=(n==null?void 0:n.plugins)||[];for(let i=0;i<o.length;i++){let a=Array.isArray(o[i])?o[i][0]:o[i];a==="@semantic-release/commit-analyzer"?o[i]=["@semantic-release/commit-analyzer",{preset:"conventionalcommits"}]:a==="@semantic-release/github"&&!e.publicRepo&&(o[i]=["@semantic-release/github",{successComment:!1}])}let r=JSON.stringify(n);await c.run(()=>d.generateFile(t,r))}catch{}}var X=l(require("fs")),H=l(require("path")),Ae=l(require("deepmerge")),Ke=l(require("lodash.clonedeep"));var Jt={extends:["@willbooster"]};async function qe(e){let t=(0,Ke.default)(Jt),n=H.default.resolve(e.dirPath,".renovaterc.json");try{let r=await X.default.promises.readFile(n,"utf-8"),i=JSON.parse(r);t=Ae.default.all([t,i,t],{arrayMerge:M})}catch{}await c.run(()=>X.default.promises.rm(H.default.resolve(e.dirPath,".dependabot"),{force:!0})),await c.run(()=>X.default.promises.rm(H.default.resolve(e.dirPath,"renovate.json"),{force:!0}));let o=JSON.stringify(t);await c.run(()=>d.generateFile(n,o))}var Ve=l(require("fs")),ue=l(require("path")),Xe=l(require("js-yaml"));var Nt={titleOnly:!0};async function He(e){let t=ue.default.resolve(e.dirPath,".github");await Ve.default.promises.mkdir(t,{recursive:!0});let n=ue.default.join(t,"semantic.yml"),o=Xe.default.dump(Nt);await c.run(()=>d.generateFile(n,o))}var Ze=l(require("fs")),I=l(require("path")),Qe=l(require("deepmerge")),et=l(require("lodash.clonedeep"));function W(e){let t=Object.entries(e).sort(([n],[o])=>n.localeCompare(o));for(let[n,o]of t)delete e[n],e[n]=o}var Wt={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__/**/*","scripts/**/*","packages/*/src/**/*","packages/*/__tests__/**/*","packages/*/scripts/**/*","./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__/**/*","scripts/**/*","../../node_modules/@types","../../@types","./@types"]};async function tt(e,t){var i,a,s;if(t.depending.blitz)return;let n=(0,et.default)(e.root?Wt:It);if(!e.containingJsxOrTsx&&!e.containingJsxOrTsxInPackages&&delete n.compilerOptions.jsx,e.root&&!e.containingSubPackageJsons&&(n.include=n.include.filter(f=>!f.startsWith("packages/*/"))),!e.root&&(e.depending.jestPlaywrightPreset||t.depending.jestPlaywrightPreset)){let f=I.default.relative(e.dirPath,t.dirPath);n.include.push(I.default.join(f,"node_modules/jest-playwright-preset/types"),I.default.join(f,"node_modules/expect-playwright"))}let o=I.default.resolve(e.dirPath,"tsconfig.json");try{let f=await Ze.default.promises.readFile(o,"utf-8"),m=JSON.parse(f);m.extends==="./node_modules/@willbooster/tsconfig/tsconfig.json"&&delete m.extends,(i=m.compilerOptions)==null||delete i.typeRoots,(a=n==null?void 0:n.compilerOptions)==null||delete a.target,(s=n==null?void 0:n.compilerOptions)==null||delete s.module,m.jsx&&delete n.jsx,e.depending.blitz&&delete n.include,n=Qe.default.all([n,m,n],{arrayMerge:M})}catch{}W(n.compilerOptions);let r=JSON.stringify(n);await c.run(()=>d.generateFile(o,r))}var j=l(require("fs")),$=l(require("path")),ot=l(require("deepmerge")),de=l(require("js-yaml")),rt=l(require("lodash.clonedeep"));var Bt={name:"Test",on:{pull_request:{branches:["main","!renovate/**"]},push:{branches:["main","renovate/**"]}},jobs:{test:{uses:"WillBooster/reusable-workflows/.github/workflows/test.yml@main"}}},zt={name:"Release",on:{push:{branches:[]}},jobs:{release:{uses:"WillBooster/reusable-workflows/.github/workflows/release.yml@main"}}},Ut={name:"Willboosterify",on:{workflow_dispatch:null},jobs:{wbfy:{uses:"WillBooster/reusable-workflows/.github/workflows/wbfy.yml@main"}}},Lt={name:"Merge wbfy",on:{workflow_dispatch:null},jobs:{"wbfy-merge":{uses:"WillBooster/reusable-workflows/.github/workflows/wbfy-merge.yml@main"}}},Mt={name:"Lint PR title",on:{pull_request_target:{types:["opened","edited","synchronize"]}},jobs:{"semantic-pr":{uses:"WillBooster/reusable-workflows/.github/workflows/semantic-pr.yml@main"}}};async function st(e){let t=$.default.resolve(e.dirPath,".github","workflows");await j.default.promises.mkdir(t,{recursive:!0});let n=(await j.default.promises.readdir(t,{withFileTypes:!0})).filter(o=>o.isFile()&&o.name.endsWith(".yml")).map(o=>o.name);e.depending.semanticRelease&&n.push("release.yml"),n.push("test.yml","wbfy.yml");for(let o of n){let r=$.default.basename(o,".yml");await c.run(()=>Gt(e,t,r))}}async function nt(e,t){let n=de.default.dump(e,{lineWidth:-1,noCompatMode:!0,styles:{"!!null":"empty"}});await c.run(()=>j.default.promises.writeFile(t,n))}async function Gt(e,t,n){var i,a;let o={};n==="test"?o=Bt:n==="release"?o=zt:n==="wbfy"?o=Ut:n==="wbfy-merge"?o=Lt:n==="semantic-pr"&&(o=Mt),o=(0,rt.default)(o);let r=$.default.join(t,`${n}.yml`);try{let s=await j.default.promises.readFile(r,"utf-8"),f=de.default.load(s);o=ot.default.all([o,f,o],{arrayMerge:G})}catch{}for(let s of Object.values(o.jobs)){if(!((a=(i=s.uses)==null?void 0:i.includes)!=null&&a.call(i,"/reusable-workflows/")))return;Yt(e,s,n)}if(n==="release"?o.on.schedule?delete o.on.push:o.on.push.branches=e.release.branches:n==="wbfy"?it(o,20,24):n==="wbfy-merge"&&it(o,0,4),await nt(o,r),n==="release")await c.run(()=>j.default.promises.rm($.default.join(t,"semantic-release.yml"),{force:!0}));else if(n==="sync"){if(await c.run(()=>j.default.promises.rm($.default.join(t,"sync-init.yml"),{force:!0})),!o.jobs.sync)return;o.jobs["sync-force"]=o.jobs.sync;let s=o.jobs.sync.with.sync_params_without_dest;if(!s)return;o.jobs.sync.with.sync_params_without_dest=`--force ${s}`,o.name="Force to Sync",o.on={workflow_dispatch:null},delete o.jobs.sync,await nt(o,$.default.join(t,"sync-force.yml"))}}function Yt(e,t,n){var o,r,i;if(t.with||(t.with={}),t.secrets||(t.secrets={}),(e.release.github&&n==="test"||n==="release"||n==="wbfy"||n==="wbfy-merge")&&(e.publicRepo?t.secrets.GH_TOKEN="${{ secrets.PUBLIC_GH_BOT_PAT }}":t.secrets.GH_TOKEN="${{ secrets.GH_BOT_PAT }}"),e.release.npm&&(n==="release"||n==="test")&&(t.secrets.NPM_TOKEN="${{ secrets.NPM_TOKEN }}"),n==="sync"){let a=(o=t.with)==null?void 0:o.sync_params_without_dest;a&&(t.with.sync_params_without_dest=a.replace("sync ",""))}(r=e.repository)!=null&&r.startsWith("github:WillBooster/")?t.uses=t.uses.replace("WillBoosterLab/","WillBooster/"):(i=e.repository)!=null&&i.startsWith("github:WillBoosterLab/")&&(t.uses=t.uses.replace("WillBooster/","WillBoosterLab/")),delete t.with.non_self_hosted,e.containingDockerfile&&n.startsWith("deploy")&&(t.with.cpu_arch="X64"),Object.keys(t.with).length?W(t.with):delete t.with,Object.keys(t.secrets).length?W(t.secrets):delete t.secrets}function it(e,t,n){var f,m;let[o,r]=(((m=(f=e.on.schedule)==null?void 0:f[0])==null?void 0:m.cron)??"").split(" ").map(Number);if(o!==0&&Number.isInteger(r)){let u=(r+9)%24;if(t<n?t<=u&&u<n:t<=u||u<n)return}let i=1+Math.floor(Math.random()*59),a=t+Math.floor(Math.random()*(n-t)),s=`${i} ${(a-9+24)%24} * * *`;e.on.schedule=[{cron:s}]}var R=l(require("fs")),D=l(require("path")),ge=l(require("js-yaml"));async function lt(e){let t=J("yarn",["--version"],e.dirPath),n=J("npm",["show","@yarnpkg/cli","version"],e.dirPath);t!==n&&h("yarn",["set","version",n],e.dirPath,1);let o=D.default.join(e.dirPath,".yarn","releases");await R.default.promises.mkdir(o,{recursive:!0});for(let m of await R.default.promises.readdir(o))m.startsWith("yarn-")&&!m.startsWith(`yarn-${n}.`)&&(await c.run(()=>R.default.promises.rm(D.default.join(o,m))),console.log("Removed",D.default.join(o,m)));let r=D.default.resolve(e.dirPath,".yarnrc");await c.run(()=>R.default.promises.rm(r,{force:!0}));let i=D.default.resolve(e.dirPath,".yarnrc.yml"),a=ge.default.load(await R.default.promises.readFile(i,"utf8"));a.defaultSemverRangePrefix="",e.requiringNodeModules&&(a.nodeLinker="node-modules",a.nmMode="hardlinks-global"),await R.default.promises.writeFile(i,ge.default.dump(a,{lineWidth:-1}));let s=(a.plugins||[]).map(m=>m.spec),f=e.containingTypeScript||e.containingTypeScriptInPackages;at(e,s,f,"@yarnpkg/plugin-typescript"),f&&!e.requiringNodeModules&&h("yarn",["dlx","@yarnpkg/sdks","vscode"],e.dirPath),at(e,s,e.containingSubPackageJsons,"@yarnpkg/plugin-workspace-tools"),h("yarn",["dlx","yarn-plugin-auto-install"],e.dirPath)}function at(e,t,n,o){n!==t.includes(o)&&h("yarn",["plugin",n?"import":"remove",o],e.dirPath)}var w=l(require("fs")),Z=l(require("fs/promises")),g=l(require("path")),F=l(require("glob")),pt=l(require("js-yaml")),mt=l(require("simple-git"));async function ye(e){var n;let t=g.default.resolve(e,"package.json");try{let o=w.default.existsSync(t),r={},i={},a={};if(o){let C=w.default.readFileSync(t,"utf-8");a=JSON.parse(C),r=a.dependencies??{},i=a.devDependencies??{}}let s=!0;try{let C=g.default.resolve(e,".yarnrc.yml"),b=pt.default.load(await Z.default.readFile(C,"utf8"));s=!b.nodeLinker||b.nodeLinker==="node-modules"}catch{}let f=[],m=[];try{let C=g.default.resolve(e,".releaserc.json"),b=JSON.parse(await Z.default.readFile(C,"utf8"));f=(b==null?void 0:b.branches)||[],m=((n=b==null?void 0:b.plugins)==null?void 0:n.flat())||[]}catch{}let u=g.default.basename(g.default.resolve(e,".."))!=="packages"||!w.default.existsSync(g.default.resolve(e,"..","..","package.json")),p;u&&(p=await Kt(e,a));let k=g.default.resolve(e,".tool-versions"),E;try{E=await Z.default.readFile(k,"utf-8")}catch{}let v={dirPath:e,root:u,publicRepo:(p==null?void 0:p.private)===!1,repository:p!=null&&p.full_name?`github:${p==null?void 0:p.full_name}`:void 0,willBoosterConfigs:t.includes(`${g.default.sep}willbooster-configs`),containingSubPackageJsons:F.default.sync("packages/**/package.json",{cwd:e}).length>0,containingDockerfile:w.default.existsSync(g.default.resolve(e,"Dockerfile"))||w.default.existsSync(g.default.resolve(e,"docker-compose.yml")),containingGemfile:w.default.existsSync(g.default.resolve(e,"Gemfile")),containingGoMod:w.default.existsSync(g.default.resolve(e,"go.mod")),containingPackageJson:w.default.existsSync(g.default.resolve(e,"package.json")),containingPoetryLock:w.default.existsSync(g.default.resolve(e,"poetry.lock")),containingPomXml:w.default.existsSync(g.default.resolve(e,"pom.xml")),containingPubspecYaml:w.default.existsSync(g.default.resolve(e,"pubspec.yaml")),containingTemplateYaml:w.default.existsSync(g.default.resolve(e,"template.yaml")),containingJavaScript:F.default.sync("@(app|src|__tests__|scripts)/**/*.js?(x)",{cwd:e}).length>0,containingTypeScript:F.default.sync("@(app|src|__tests__|scripts)/**/*.ts?(x)",{cwd:e}).length>0,containingJsxOrTsx:F.default.sync("@(app|src|__tests__)/**/*.{t,j}sx",{cwd:e}).length>0,containingJavaScriptInPackages:F.default.sync("packages/**/@(app|src|__tests__|scripts)/**/*.js?(x)",{cwd:e}).length>0,containingTypeScriptInPackages:F.default.sync("packages/**/@(app|src|__tests__|scripts)/**/*.ts?(x)",{cwd:e}).length>0,containingJsxOrTsxInPackages:F.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:f,github:m.includes("@semantic-release/github"),npm:m.includes("@semantic-release/npm")},requiringNodeModules:s,versionsText:E};if(v.eslintBase=At(v),v.containingGemfile||v.containingGoMod||v.containingPackageJson||v.containingPoetryLock||v.containingPomXml||v.containingPubspecYaml||v.containingTemplateYaml)return v}catch{}return null}function At(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 Kt(e,t){var s,f,m;let r=(await(0,mt.default)(e).getRemotes(!0)).find(u=>u.name==="origin"),i=((s=r==null?void 0:r.refs)==null?void 0:s.fetch)??((f=r==null?void 0:r.refs)==null?void 0:f.push);if(typeof i=="string"){let u=await ct(i);if(u)return u}let a=((m=t.repository)==null?void 0:m.url)??t.repository;if(typeof a=="string"){let u=await ct(a);if(u&&u.message!=="Not Found")return u}}async function ct(e){var m;let t=e.split(":").at(-1),n=t==null?void 0:t.split("/"),o=n==null?void 0:n.at(-2),r=(m=n==null?void 0:n.at(-1))==null?void 0:m.replace(/.git$/,"");if(!o||!r)return;let i=process.env.GH_TOKEN||process.env.GITHUB_TOKEN,a=i?{headers:{Authorization:`token ${i}`}}:void 0,f=await(await Y(`https://api.github.com/repos/${o}/${r}`,a)).json();return T({full_name:`${o}/${r}`},f??{})}async function qt(){let e=await(0,dt.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 t of e._){if(typeof t=="number")continue;let n=await ye(t);if(n===null){console.error(`there is no valid package.json in ${t}`);continue}let o=n.containingSubPackageJsons?ut.default.sync("packages/*",{cwd:t}).map(s=>ft.default.resolve(t,s)):[],r=(await Promise.all(o.map(s=>ye(s)))).filter(s=>!!s),i=[n,...r];if(e.verbose)for(let s of i)console.log(s);await be(n),await lt(n),await Promise.all([Ce(n),De(n),Je(n),Ne(n),ce(n),qe(n),Ye(n),He(n),st(n)]),await c.promiseAll();let a=[];for(let s of i)await Ee(s,n),!(!s.root&&!s.containingPackageJson)&&(await Le(s),await Ue(s,n,e.skipDeps),a.push(ce(s)),(s.containingTypeScript||s.containingTypeScriptInPackages)&&a.push(tt(s,n)),(s.containingJavaScript||s.containingJavaScriptInPackages||s.containingTypeScript||s.containingTypeScriptInPackages)&&(n.willBoosterConfigs||a.push(Te(s,n)),a.push(Fe(s))));await Promise.all(a),await c.promiseAll(),h("yarn",["cleanup"],t),h("yarn",["install"],t)}}qt().then();
260
260
  //# 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/utils/spawnUtil.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/generators/idea.ts", "../src/generators/lintstagedrc.ts", "../src/utils/eslintUtil.ts", "../src/utils/srcDirectories.ts", "../src/generators/packageJson.ts", "../src/generators/prettierignore.ts", "../src/generators/releaserc.ts", "../src/generators/renovaterc.ts", "../src/generators/semanticPullRequest.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/semanticPullRequest';\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\n if (argv.verbose) {\n for (const config of allPackageConfigs) {\n console.log(config);\n }\n }\n\n // Install tools via asdf at first\n await generateVersionConfigs(rootConfig);\n // Install yarn berry\n await generateYarnrcYml(rootConfig);\n await Promise.all([\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 generateWorkflow(rootConfig),\n ]);\n await promisePool.promiseAll();\n\n const promises: Promise<void>[] = [];\n for (const config of allPackageConfigs) {\n await generateGitignore(config, rootConfig);\n if (!config.root && !config.containingPackageJson) {\n continue;\n }\n await generatePrettierignore(config);\n await generatePackageJson(config, rootConfig, argv.skipDeps);\n\n promises.push(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 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';\nimport { spawnSync, spawnSyncWithStringResult } from '../utils/spawnUtil';\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.trim().split('\\n')) {\n const line = versionText.trim();\n if (line && line.split(/\\s+/)[0] !== '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 if (config.containingPoetryLock) {\n updateLine('poetry 1.1.13', 0, lines);\n updateLine('python 3.9.10', 0, lines);\n }\n if (config.depending.firebase) {\n updateLine('java adoptopenjdk-17.0.2+8', 0, lines);\n }\n if (config.containingPackageJson) {\n const version = spawnSyncWithStringResult('npm', ['show', 'yarn', 'version'], config.dirPath);\n updateLine(`yarn ${version}`, lines.length, lines);\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'));\n } else {\n await promisePool.run(() => fs.promises.rm(toolVersionsPath, { force: true }));\n }\n await promisePool.promiseAll();\n spawnSync('asdf', ['install'], config.dirPath);\n}\n\nfunction updateLine(line: string, insertionIndex: number, lines: string[]): void {\n const [prefix] = line.split(' ');\n const index = lines.findIndex((l) => l.split(/\\s+/)[0] === prefix);\n if (index >= 0) {\n lines[index] = line;\n } else {\n lines.splice(insertionIndex, 0, line);\n }\n}\n", "import { PromisePool } from 'minimal-promise-pool';\n\nexport const promisePool = new PromisePool();\n", "import child_process from 'child_process';\n\nexport function spawnSync(command: string, args: string[], cwd: string, retry = 0): void {\n do {\n const [newCmd, newArgs, options] = getSpawnSyncArgs(command, args, cwd);\n console.log(`$ ${newCmd} ${newArgs.join(' ')} at ${options.cwd}`);\n const ret = child_process.spawnSync(newCmd, newArgs, 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 [newCmd, newArgs, options] = getSpawnSyncArgs(command, args, cwd);\n options.stdio = 'pipe';\n const proc = child_process.spawnSync(newCmd, newArgs, options);\n return proc.stdout.toString().trim();\n}\n\nexport function getSpawnSyncArgs(command: string, args: string[], cwd: string): [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 if (env.ASDF_DIR) {\n args = ['-l', '-c', `. ${env.ASDF_DIR}/asdf.sh && ${command} ${args.join(' ')}`];\n command = 'bash';\n }\n return [\n command,\n args,\n {\n cwd,\n env,\n shell: false,\n stdio: 'inherit',\n },\n ];\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 = `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 = (await IgnoreFileUtil.getUserContent(filePath)) || defaultUserContent;\n\n const gitignoreFilePath = path.resolve(config.dirPath, '.gitignore');\n const gitignoreContent = (await 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 async getExistingContent(filePath: string): Promise<string | null> {\n try {\n const content = await fs.promises.readFile(filePath, 'utf-8');\n return content\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 } catch (_) {\n return null;\n }\n },\n async getUserContent(filePath: string): Promise<string | null> {\n try {\n const content = await fs.promises.readFile(filePath, 'utf-8');\n const index = content.indexOf(this.separatorPrefix);\n if (index >= 0) {\n return content.substring(0, content.indexOf('\\n', index) + 1);\n }\n } catch (_) {\n // do nothing\n }\n return null;\n },\n async isBerryZeroInstallEnabled(filePath: string): Promise<boolean> {\n try {\n const content = await fs.promises.readFile(filePath, 'utf-8');\n return content.includes('\\n!.yarn/cache');\n } catch (_) {\n return false;\n }\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';\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*.sqlite3\n*.sqlite3-journal\n`;\n\nconst gitignoreCache = new Map<string, string>();\n\nexport async function generateGitignore(config: PackageConfig, rootConfig: PackageConfig): Promise<void> {\n const filePath = path.resolve(config.dirPath, '.gitignore');\n let userContent = ((await 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 userContent += `.blitz/\n.blitz**\n`;\n }\n\n let generated = '';\n for (const name of names) {\n if (!gitignoreCache.has(name)) {\n const url = `https://www.toptal.com/developers/gitignore/api/${name}`;\n const response = await fetchOnNode(url);\n const responseText = await response.text();\n if (responseText.includes('Attention Required!')) {\n console.error(`Failed to fetch ${url}`);\n return;\n }\n gitignoreCache.set(name, responseText);\n }\n generated += gitignoreCache.get(name);\n }\n if (!(await 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 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 prePushForLab: `\nif [ $(git branch --show-current) = \"main\" ]; then\n echo \"************************************************\"\n echo \"*** Don't push main branch directly. Use PR! ***\"\n echo \"************************************************\"\n exit 1\nfi\n\nyarn typecheck`.trim(),\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 const prePush = config.repository?.startsWith('github:WillBoosterLab/') ? settings.prePushForLab : settings.prePush;\n await promisePool.run(() =>\n fs.promises.writeFile(path.resolve(dirPath, 'pre-push'), content.replace(DEFAULT_COMMAND, 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.containingPoetryLock) {\n postMergeCommands.push('poetry install');\n }\n if (config.depending.blitz || config.depending.prisma) {\n postMergeCommands.push('yarn gen-code');\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 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';\nimport { getSrcDirs } from '../utils/srcDirectories';\n\nexport async function generateLintstagedrc(config: PackageConfig): Promise<void> {\n const lines: string[] = [];\n if (config.containingJavaScript || config.containingTypeScript) {\n const eslint = `\n '${getEslintKey(config)}': [${JSON.stringify(\n `eslint --fix${EslintUtil.getLintFixSuffix(config)}`\n )}, '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 ? getEslintFilterForPrettier(config) : ''}\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\nfunction getEslintKey(config: PackageConfig): string {\n const dirs = getSrcDirs(config);\n return `./{${dirs.join(',')}}/**/*.{${extensions.eslint.join(',')}}`;\n}\n\nfunction getEslintFilterForPrettier(config: PackageConfig): string {\n return `files = micromatch.not(files, '${getEslintKey(config)}');`;\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 { PackageConfig } from './packageConfig';\n\nconst srcDirectories = {\n node: ['src', '__tests__', 'scripts'],\n blitz: ['app', 'db', 'integrations', 'mailers', 'test'],\n};\n\nsrcDirectories.blitz = [...srcDirectories.node, ...srcDirectories.blitz];\n\nexport function getSrcDirs(config: PackageConfig): string[] {\n return config.depending.blitz ? srcDirectories.blitz : srcDirectories.node;\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';\nimport { getSrcDirs } from '../utils/srcDirectories';\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(jsonObj.scripts, generateScripts(config));\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 // TODO: not needed anymore?\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 if (!jsonObj.scripts['gen-code']?.startsWith('blitz codegen')) {\n jsonObj.scripts['gen-code'] = 'blitz codegen';\n }\n } else if (config.depending.prisma) {\n if (!jsonObj.scripts['gen-code']?.startsWith('prisma generate')) {\n jsonObj.scripts['gen-code'] = 'prisma generate';\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 dependencies = dependencies.filter((dep) => !jsonObj.devDependencies?.[dep]);\n if (dependencies.length) {\n spawnSync('yarn', ['add', ...new Set(dependencies)], config.dirPath);\n }\n devDependencies = devDependencies.filter((dep) => !jsonObj.dependencies?.[dep]);\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.scripts['typecheck:codegen'];\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\nfunction generateScripts(config: PackageConfig): Record<string, string> {\n let scripts = {\n cleanup: 'yarn format && yarn lint-fix',\n format: `sort-package-json && yarn prettify`,\n lint: `eslint --color \"./{${getSrcDirs(config)}}/**/*.{${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 if (config.containingSubPackageJsons) {\n scripts = merge(\n { ...scripts },\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 }\n if (config.depending.blitz) {\n scripts.typecheck = `${scripts.typecheck} || yarn run typecheck/warn`;\n (scripts as any)['typecheck/warn'] = `echo 'Please try \"yarn gen-code\" if you face unknown type errors.' && exit 1`;\n (scripts as any)['typecheck:gen-code'] = 'yarn gen-code && tsc --noEmit --Pretty';\n }\n return scripts;\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 = (await IgnoreFileUtil.getUserContent(filePath)) || defaultUserContent;\n\n const gitignoreFilePath = path.resolve(config.dirPath, '.gitignore');\n const gitignoreContent = (await 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 const plugin = Array.isArray(plugins[i]) ? plugins[i][0] : plugins[i];\n if (plugin === '@semantic-release/commit-analyzer') {\n plugins[i] = [\n '@semantic-release/commit-analyzer',\n {\n preset: 'conventionalcommits',\n },\n ];\n } else if (plugin === '@semantic-release/github' && !rootConfig.publicRepo) {\n plugins[i] = ['@semantic-release/github', { successComment: false }];\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 'scripts/**/*',\n 'packages/*/src/**/*',\n 'packages/*/__tests__/**/*',\n 'packages/*/scripts/**/*',\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__/**/*', 'scripts/**/*', '../../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 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\n const fileNames = (await fs.promises.readdir(workflowsPath, { withFileTypes: true }))\n .filter((dirent) => dirent.isFile() && dirent.name.endsWith('.yml'))\n .map((dirent) => dirent.name);\n if (rootConfig.depending.semanticRelease) {\n fileNames.push('release.yml');\n }\n fileNames.push('test.yml', 'wbfy.yml');\n\n for (const fileName of fileNames) {\n const kind = path.basename(fileName, '.yml');\n await promisePool.run(() => writeWorkflowYaml(rootConfig, workflowsPath, kind));\n }\n}\n\nasync function writeYaml(newSettings: any, filePath: string): Promise<void> {\n const yamlText = yaml.dump(newSettings, {\n lineWidth: -1,\n noCompatMode: true,\n styles: {\n '!!null': 'empty',\n },\n });\n await promisePool.run(() => fs.promises.writeFile(filePath, yamlText));\n}\n\nasync function writeWorkflowYaml(\n config: PackageConfig,\n workflowsPath: string,\n kind: 'test' | 'release' | 'sync' | 'wbfy' | string\n): Promise<void> {\n let newSettings: any = {};\n if (kind === 'test') {\n newSettings = testWorkflow;\n } else if (kind === 'release') {\n newSettings = releaseWorkflow;\n } else if (kind === 'wbfy') {\n newSettings = wbfyWorkflow;\n }\n newSettings = cloneDeep(newSettings);\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 for (const job of Object.values(newSettings.jobs) as any[]) {\n // Ignore non-reusable workflows\n if (!job.uses?.includes?.('/reusable-workflows/')) return;\n\n normalizeJob(config, job, kind);\n }\n\n if (kind === 'release') {\n if (newSettings.on.schedule) {\n delete newSettings.on.push;\n } else {\n newSettings.on.push.branches = config.release.branches;\n }\n } else if (kind === 'wbfy') {\n const firstCharOfCron = newSettings.on.schedule?.[0]?.cron?.[0];\n if (!firstCharOfCron || firstCharOfCron === '0') {\n const min = 1 + Math.floor(Math.random() * 59);\n // 3:00 AM (UTC) (12:00 PM (JST)) - 9:00 AM (UTC) (18:00 PM (JST))\n const hour = (3 + Math.floor(Math.random() * 6) + 9) % 24;\n const cron = `${min} ${hour} * * *`;\n newSettings.on.schedule = [{ cron }];\n }\n }\n await writeYaml(newSettings, filePath);\n\n if (kind === 'release') {\n await promisePool.run(() => fs.promises.rm(path.join(workflowsPath, 'semantic-release.yml'), { force: true }));\n } else if (kind === 'sync') {\n await promisePool.run(() => fs.promises.rm(path.join(workflowsPath, 'sync-init.yml'), { force: true }));\n if (!newSettings.jobs.sync) return;\n\n newSettings.jobs['sync-force'] = newSettings.jobs.sync;\n const params = newSettings.jobs.sync.with.sync_params_without_dest;\n if (!params) return;\n\n newSettings.jobs.sync.with.sync_params_without_dest = `--force ${params}`;\n newSettings.name = 'Force to Sync';\n newSettings.on = { workflow_dispatch: null };\n delete newSettings.jobs.sync;\n await writeYaml(newSettings, path.join(workflowsPath, 'sync-force.yml'));\n }\n}\n\nfunction normalizeJob(config: PackageConfig, job: any, kind: string): void {\n job.with ||= {};\n job.secrets ||= {};\n\n if ((config.release.github && kind === 'test') || kind === 'release' || 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 === 'release' || kind === 'test')) {\n job.secrets['NPM_TOKEN'] = '${{ secrets.NPM_TOKEN }}';\n }\n\n if (kind === 'sync') {\n const params = job.with?.sync_params_without_dest;\n if (params) {\n job.with.sync_params_without_dest = params.replace('sync ', '');\n }\n }\n\n if (config.repository?.startsWith('github:WillBooster/')) {\n job.uses = job.uses.replace('WillBoosterLab/', 'WillBooster/');\n } else if (config.repository?.startsWith('github:WillBoosterLab/')) {\n job.uses = job.uses.replace('WillBooster/', 'WillBoosterLab/');\n }\n\n delete job.with['non_self_hosted'];\n if (config.containingDockerfile && kind.startsWith('deploy')) {\n job.with['cpu_arch'] = 'X64';\n }\n if (Object.keys(job.with).length) {\n sortKeys(job.with);\n } else {\n delete job.with;\n }\n\n if (Object.keys(job.secrets).length) {\n sortKeys(job.secrets);\n } else {\n delete job.secrets;\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 console.log('Removed', 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, { lineWidth: -1 }));\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__|scripts)/**/*.js?(x)', { cwd: dirPath }).length > 0,\n containingTypeScript: glob.sync('@(app|src|__tests__|scripts)/**/*.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__|scripts)/**/*.js?(x)', { cwd: dirPath }).length > 0,\n containingTypeScriptInPackages:\n glob.sync('packages/**/@(app|src|__tests__|scripts)/**/*.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 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 const url = packageJson.repository?.url ?? packageJson.repository;\n if (typeof url === 'string') {\n const json = await fetchRepoInfo(url);\n if (json && json.message !== 'Not Found') 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/semanticPullRequest';\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\n if (argv.verbose) {\n for (const config of allPackageConfigs) {\n console.log(config);\n }\n }\n\n // Install tools via asdf at first\n await generateVersionConfigs(rootConfig);\n // Install yarn berry\n await generateYarnrcYml(rootConfig);\n await Promise.all([\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 generateWorkflow(rootConfig),\n ]);\n await promisePool.promiseAll();\n\n const promises: Promise<void>[] = [];\n for (const config of allPackageConfigs) {\n await generateGitignore(config, rootConfig);\n if (!config.root && !config.containingPackageJson) {\n continue;\n }\n await generatePrettierignore(config);\n await generatePackageJson(config, rootConfig, argv.skipDeps);\n\n promises.push(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 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';\nimport { spawnSync, spawnSyncWithStringResult } from '../utils/spawnUtil';\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.trim().split('\\n')) {\n const line = versionText.trim();\n if (line && line.split(/\\s+/)[0] !== '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 if (config.containingPoetryLock) {\n updateLine('poetry 1.1.13', 0, lines);\n updateLine('python 3.9.10', 0, lines);\n }\n if (config.depending.firebase) {\n updateLine('java adoptopenjdk-17.0.2+8', 0, lines);\n }\n if (config.containingPackageJson) {\n const version = spawnSyncWithStringResult('npm', ['show', 'yarn', 'version'], config.dirPath);\n updateLine(`yarn ${version}`, lines.length, lines);\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'));\n } else {\n await promisePool.run(() => fs.promises.rm(toolVersionsPath, { force: true }));\n }\n await promisePool.promiseAll();\n spawnSync('asdf', ['install'], config.dirPath);\n}\n\nfunction updateLine(line: string, insertionIndex: number, lines: string[]): void {\n const [prefix] = line.split(' ');\n const index = lines.findIndex((l) => l.split(/\\s+/)[0] === prefix);\n if (index >= 0) {\n lines[index] = line;\n } else {\n lines.splice(insertionIndex, 0, line);\n }\n}\n", "import { PromisePool } from 'minimal-promise-pool';\n\nexport const promisePool = new PromisePool();\n", "import child_process from 'child_process';\n\nexport function spawnSync(command: string, args: string[], cwd: string, retry = 0): void {\n do {\n const [newCmd, newArgs, options] = getSpawnSyncArgs(command, args, cwd);\n console.log(`$ ${newCmd} ${newArgs.join(' ')} at ${options.cwd}`);\n const ret = child_process.spawnSync(newCmd, newArgs, 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 [newCmd, newArgs, options] = getSpawnSyncArgs(command, args, cwd);\n options.stdio = 'pipe';\n const proc = child_process.spawnSync(newCmd, newArgs, options);\n return proc.stdout.toString().trim();\n}\n\nexport function getSpawnSyncArgs(command: string, args: string[], cwd: string): [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 if (env.ASDF_DIR) {\n args = ['-l', '-c', `. ${env.ASDF_DIR}/asdf.sh && ${command} ${args.join(' ')}`];\n command = 'bash';\n }\n return [\n command,\n args,\n {\n cwd,\n env,\n shell: false,\n stdio: 'inherit',\n },\n ];\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 = `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 = (await IgnoreFileUtil.getUserContent(filePath)) || defaultUserContent;\n\n const gitignoreFilePath = path.resolve(config.dirPath, '.gitignore');\n const gitignoreContent = (await 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 async getExistingContent(filePath: string): Promise<string | null> {\n try {\n const content = await fs.promises.readFile(filePath, 'utf-8');\n return content\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 } catch (_) {\n return null;\n }\n },\n async getUserContent(filePath: string): Promise<string | null> {\n try {\n const content = await fs.promises.readFile(filePath, 'utf-8');\n const index = content.indexOf(this.separatorPrefix);\n if (index >= 0) {\n return content.substring(0, content.indexOf('\\n', index) + 1);\n }\n } catch (_) {\n // do nothing\n }\n return null;\n },\n async isBerryZeroInstallEnabled(filePath: string): Promise<boolean> {\n try {\n const content = await fs.promises.readFile(filePath, 'utf-8');\n return content.includes('\\n!.yarn/cache');\n } catch (_) {\n return false;\n }\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';\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*.sqlite3\n*.sqlite3-journal\n`;\n\nconst gitignoreCache = new Map<string, string>();\n\nexport async function generateGitignore(config: PackageConfig, rootConfig: PackageConfig): Promise<void> {\n const filePath = path.resolve(config.dirPath, '.gitignore');\n let userContent = ((await 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 userContent += `.blitz/\n.blitz**\n`;\n }\n\n let generated = '';\n for (const name of names) {\n if (!gitignoreCache.has(name)) {\n const url = `https://www.toptal.com/developers/gitignore/api/${name}`;\n const response = await fetchOnNode(url);\n const responseText = await response.text();\n if (responseText.includes('Attention Required!')) {\n console.error(`Failed to fetch ${url}`);\n return;\n }\n gitignoreCache.set(name, responseText);\n }\n generated += gitignoreCache.get(name);\n }\n if (!(await 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 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 prePushForLab: `\nif [ $(git branch --show-current) = \"main\" ]; then\n echo \"************************************************\"\n echo \"*** Don't push main branch directly. Use PR! ***\"\n echo \"************************************************\"\n exit 1\nfi\n\nyarn typecheck`.trim(),\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 const prePush = config.repository?.startsWith('github:WillBoosterLab/') ? settings.prePushForLab : settings.prePush;\n await promisePool.run(() =>\n fs.promises.writeFile(path.resolve(dirPath, 'pre-push'), content.replace(DEFAULT_COMMAND, 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.containingPoetryLock) {\n postMergeCommands.push('poetry install');\n }\n if (config.depending.blitz || config.depending.prisma) {\n postMergeCommands.push('yarn gen-code');\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 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';\nimport { getSrcDirs } from '../utils/srcDirectories';\n\nexport async function generateLintstagedrc(config: PackageConfig): Promise<void> {\n const lines: string[] = [];\n if (config.containingJavaScript || config.containingTypeScript) {\n const eslint = `\n '${getEslintKey(config)}': [${JSON.stringify(\n `eslint --fix${EslintUtil.getLintFixSuffix(config)}`\n )}, '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 ? getEslintFilterForPrettier(config) : ''}\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\nfunction getEslintKey(config: PackageConfig): string {\n const dirs = getSrcDirs(config);\n return `./{${dirs.join(',')}}/**/*.{${extensions.eslint.join(',')}}`;\n}\n\nfunction getEslintFilterForPrettier(config: PackageConfig): string {\n return `files = micromatch.not(files, '${getEslintKey(config)}');`;\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 { PackageConfig } from './packageConfig';\n\nconst srcDirectories = {\n node: ['src', '__tests__', 'scripts'],\n blitz: ['app', 'db', 'integrations', 'mailers', 'test'],\n};\n\nsrcDirectories.blitz = [...srcDirectories.node, ...srcDirectories.blitz];\n\nexport function getSrcDirs(config: PackageConfig): string[] {\n return config.depending.blitz ? srcDirectories.blitz : srcDirectories.node;\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';\nimport { getSrcDirs } from '../utils/srcDirectories';\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(jsonObj.scripts, generateScripts(config));\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 // TODO: not needed anymore?\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 if (!jsonObj.scripts['gen-code']?.startsWith('blitz codegen')) {\n jsonObj.scripts['gen-code'] = 'blitz codegen';\n }\n } else if (config.depending.prisma) {\n if (!jsonObj.scripts['gen-code']?.startsWith('prisma generate')) {\n jsonObj.scripts['gen-code'] = 'prisma generate';\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 dependencies = dependencies.filter((dep) => !jsonObj.devDependencies?.[dep]);\n if (dependencies.length) {\n spawnSync('yarn', ['add', ...new Set(dependencies)], config.dirPath);\n }\n devDependencies = devDependencies.filter((dep) => !jsonObj.dependencies?.[dep]);\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.scripts['typecheck:codegen'];\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\nfunction generateScripts(config: PackageConfig): Record<string, string> {\n let scripts = {\n cleanup: 'yarn format && yarn lint-fix',\n format: `sort-package-json && yarn prettify`,\n lint: `eslint --color \"./{${getSrcDirs(config)}}/**/*.{${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 if (config.containingSubPackageJsons) {\n scripts = merge(\n { ...scripts },\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 }\n if (config.depending.blitz) {\n scripts.typecheck = `${scripts.typecheck} || yarn run typecheck/warn`;\n (scripts as any)['typecheck/warn'] = `echo 'Please try \"yarn gen-code\" if you face unknown type errors.' && exit 1`;\n (scripts as any)['typecheck:gen-code'] = 'yarn gen-code && tsc --noEmit --Pretty';\n }\n return scripts;\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 = (await IgnoreFileUtil.getUserContent(filePath)) || defaultUserContent;\n\n const gitignoreFilePath = path.resolve(config.dirPath, '.gitignore');\n const gitignoreContent = (await 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 const plugin = Array.isArray(plugins[i]) ? plugins[i][0] : plugins[i];\n if (plugin === '@semantic-release/commit-analyzer') {\n plugins[i] = [\n '@semantic-release/commit-analyzer',\n {\n preset: 'conventionalcommits',\n },\n ];\n } else if (plugin === '@semantic-release/github' && !rootConfig.publicRepo) {\n plugins[i] = ['@semantic-release/github', { successComment: false }];\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 'scripts/**/*',\n 'packages/*/src/**/*',\n 'packages/*/__tests__/**/*',\n 'packages/*/scripts/**/*',\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__/**/*', 'scripts/**/*', '../../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 workflow_dispatch: null,\n },\n jobs: {\n wbfy: {\n uses: 'WillBooster/reusable-workflows/.github/workflows/wbfy.yml@main',\n },\n },\n};\n\nconst wbfyMergeWorkflow = {\n name: 'Merge wbfy',\n on: {\n workflow_dispatch: null,\n },\n jobs: {\n 'wbfy-merge': {\n uses: 'WillBooster/reusable-workflows/.github/workflows/wbfy-merge.yml@main',\n },\n },\n};\n\nconst semanticPullRequestWorkflow = {\n name: 'Lint PR title',\n on: {\n pull_request_target: {\n types: ['opened', 'edited', 'synchronize'],\n },\n },\n jobs: {\n 'semantic-pr': {\n uses: 'WillBooster/reusable-workflows/.github/workflows/semantic-pr.yml@main',\n },\n },\n};\n\ntype KnownKind = 'test' | 'release' | 'sync' | 'wbfy' | 'wbfy-merge' | 'semantic-pr';\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\n const fileNames = (await fs.promises.readdir(workflowsPath, { withFileTypes: true }))\n .filter((dirent) => dirent.isFile() && dirent.name.endsWith('.yml'))\n .map((dirent) => dirent.name);\n if (rootConfig.depending.semanticRelease) {\n fileNames.push('release.yml');\n }\n fileNames.push('test.yml', 'wbfy.yml');\n\n for (const fileName of fileNames) {\n const kind = path.basename(fileName, '.yml');\n await promisePool.run(() => writeWorkflowYaml(rootConfig, workflowsPath, kind));\n }\n}\n\nasync function writeYaml(newSettings: any, filePath: string): Promise<void> {\n const yamlText = yaml.dump(newSettings, {\n lineWidth: -1,\n noCompatMode: true,\n styles: {\n '!!null': 'empty',\n },\n });\n await promisePool.run(() => fs.promises.writeFile(filePath, yamlText));\n}\n\nasync function writeWorkflowYaml(\n config: PackageConfig,\n workflowsPath: string,\n kind: KnownKind | string\n): Promise<void> {\n let newSettings: any = {};\n if (kind === 'test') {\n newSettings = testWorkflow;\n } else if (kind === 'release') {\n newSettings = releaseWorkflow;\n } else if (kind === 'wbfy') {\n newSettings = wbfyWorkflow;\n } else if (kind === 'wbfy-merge') {\n newSettings = wbfyMergeWorkflow;\n } else if (kind === 'semantic-pr') {\n newSettings = semanticPullRequestWorkflow;\n }\n newSettings = cloneDeep(newSettings);\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 for (const job of Object.values(newSettings.jobs) as any[]) {\n // Ignore non-reusable workflows\n if (!job.uses?.includes?.('/reusable-workflows/')) return;\n\n normalizeJob(config, job, kind);\n }\n\n if (kind === 'release') {\n if (newSettings.on.schedule) {\n delete newSettings.on.push;\n } else {\n newSettings.on.push.branches = config.release.branches;\n }\n } else if (kind === 'wbfy') {\n setSchedule(newSettings, 20, 24);\n } else if (kind === 'wbfy-merge') {\n setSchedule(newSettings, 0, 4);\n }\n await writeYaml(newSettings, filePath);\n\n if (kind === 'release') {\n await promisePool.run(() => fs.promises.rm(path.join(workflowsPath, 'semantic-release.yml'), { force: true }));\n } else if (kind === 'sync') {\n await promisePool.run(() => fs.promises.rm(path.join(workflowsPath, 'sync-init.yml'), { force: true }));\n if (!newSettings.jobs.sync) return;\n\n newSettings.jobs['sync-force'] = newSettings.jobs.sync;\n const params = newSettings.jobs.sync.with.sync_params_without_dest;\n if (!params) return;\n\n newSettings.jobs.sync.with.sync_params_without_dest = `--force ${params}`;\n newSettings.name = 'Force to Sync';\n newSettings.on = { workflow_dispatch: null };\n delete newSettings.jobs.sync;\n await writeYaml(newSettings, path.join(workflowsPath, 'sync-force.yml'));\n }\n}\n\nfunction normalizeJob(config: PackageConfig, job: any, kind: KnownKind | string): void {\n job.with ||= {};\n job.secrets ||= {};\n\n if ((config.release.github && kind === 'test') || kind === 'release' || kind === 'wbfy' || kind === 'wbfy-merge') {\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 === 'release' || kind === 'test')) {\n job.secrets['NPM_TOKEN'] = '${{ secrets.NPM_TOKEN }}';\n }\n\n if (kind === 'sync') {\n const params = job.with?.sync_params_without_dest;\n if (params) {\n job.with.sync_params_without_dest = params.replace('sync ', '');\n }\n }\n\n if (config.repository?.startsWith('github:WillBooster/')) {\n job.uses = job.uses.replace('WillBoosterLab/', 'WillBooster/');\n } else if (config.repository?.startsWith('github:WillBoosterLab/')) {\n job.uses = job.uses.replace('WillBooster/', 'WillBoosterLab/');\n }\n\n delete job.with['non_self_hosted'];\n if (config.containingDockerfile && kind.startsWith('deploy')) {\n job.with['cpu_arch'] = 'X64';\n }\n if (Object.keys(job.with).length) {\n sortKeys(job.with);\n } else {\n delete job.with;\n }\n\n if (Object.keys(job.secrets).length) {\n sortKeys(job.secrets);\n } else {\n delete job.secrets;\n }\n}\n\nfunction setSchedule(newSettings: any, inclusiveMinHourJst: number, exclusiveMaxHourJst: number): void {\n const [minuteUtc, hourUtc] = ((newSettings.on.schedule?.[0]?.cron as string) ?? '').split(' ').map(Number);\n if (minuteUtc !== 0 && Number.isInteger(hourUtc)) {\n const hourJst = (hourUtc + 9) % 24;\n const inRange =\n inclusiveMinHourJst < exclusiveMaxHourJst\n ? inclusiveMinHourJst <= hourJst && hourJst < exclusiveMaxHourJst\n : inclusiveMinHourJst <= hourJst || hourJst < exclusiveMaxHourJst;\n if (inRange) return;\n }\n\n const minJst = 1 + Math.floor(Math.random() * 59);\n const hourJst = inclusiveMinHourJst + Math.floor(Math.random() * (exclusiveMaxHourJst - inclusiveMinHourJst));\n const cron = `${minJst} ${(hourJst - 9 + 24) % 24} * * *`;\n newSettings.on.schedule = [{ cron }];\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 console.log('Removed', 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, { lineWidth: -1 }));\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__|scripts)/**/*.js?(x)', { cwd: dirPath }).length > 0,\n containingTypeScript: glob.sync('@(app|src|__tests__|scripts)/**/*.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__|scripts)/**/*.js?(x)', { cwd: dirPath }).length > 0,\n containingTypeScriptInPackages:\n glob.sync('packages/**/@(app|src|__tests__|scripts)/**/*.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 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 const url = packageJson.repository?.url ?? packageJson.repository;\n if (typeof url === 'string') {\n const json = await fetchRepoInfo(url);\n if (json && json.message !== 'Not Found') 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.28.1",
3
+ "version": "1.29.0",
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",