wbfy 1.70.0 → 1.71.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,8 +1,8 @@
1
- "use strict";var Lt=Object.create;var Ce=Object.defineProperty;var Ut=Object.getOwnPropertyDescriptor;var Gt=Object.getOwnPropertyNames;var zt=Object.getPrototypeOf,Ht=Object.prototype.hasOwnProperty;var Mt=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Gt(t))!Ht.call(e,s)&&s!==r&&Ce(e,s,{get:()=>t[s],enumerable:!(n=Ut(t,s))||n.enumerable});return e};var c=(e,t,r)=>(r=e!=null?Lt(zt(e)):{},Mt(t||!e||!e.__esModule?Ce(r,"default",{value:e,enumerable:!0}):r,e));var Nt=c(require("node:path")),Wt=c(require("glob")),It=c(require("yargs"));var G=c(require("node:fs")),q=c(require("node:path"));var ae=class{isVerbose;constructor(){this.isVerbose=!1}},j=new ae;var le=class{async function(t,r){j.isVerbose&&console.info(`--------- ${t} start ---------`),await r(),j.isVerbose&&console.info(`---------- ${t} end ----------`)}},m=new le;var $e=require("minimal-promise-pool"),p=new $e.PromisePool;var ce=c(require("node:child_process"));function v(e,t,r,n=0){do{let[s,i,a]=Re(e,t,r);if(console.log(`$ ${s} ${i.join(" ")} at ${a.cwd}`),ce.default.spawnSync(s,i,a).status===0)break}while(--n>=0)}function U(e,t,r){let[n,s,i]=Re(e,t,r);i.stdio="pipe";let a=ce.default.spawnSync(n,s,i),o=a.stderr.toString().trim();return o&&console.error(`${n} [${s.map(l=>`"${l}"`)}] caused the following error:
2
- ${o}`),a.stdout.toString().trim()}function Re(e,t,r){let n={...process.env};return n.PATH&&n.BERRY_BIN_FOLDER&&(n.PATH=n.PATH.replace(`${n.BERRY_BIN_FOLDER}:`,"")),n.ASDF_DIR&&(t=["-l","-c",`. ${n.ASDF_DIR}/asdf.sh && ${e} ${t.join(" ")}`],e="bash"),[e,t,{cwd:r,env:n,shell:!1,stdio:"inherit"}]}async function Te(e){return m.function("generateVersionConfigs",async()=>{await Yt(e)})}async function Yt(e){if(!e.versionsText)return;let t=[];for(let n of e.versionsText.trim().split(`
3
- `)){let s=n.trim();if(s&&s.split(/\s+/)[0]!=="nodejs"){t.push(s);continue}let[,i]=s.split(/\s+/);await p.run(()=>G.default.promises.writeFile(q.default.resolve(e.dirPath,".node-version"),i))}if(e.containingPoetryLock&&(K("poetry 1.2.2",0,t),G.default.existsSync(q.default.resolve(e.dirPath,".python-version"))||K("python 3.9.15",0,t)),e.depending.firebase&&K("java adoptopenjdk-17.0.5+8",0,t),e.containingPackageJson){let n=U("npm",["show","yarn","version"],e.dirPath);K(`yarn ${n}`,t.length,t)}let r=q.default.resolve(e.dirPath,".tool-versions");await(t.length>0?p.run(()=>G.default.promises.writeFile(r,t.join(`
1
+ "use strict";var Lt=Object.create;var Ce=Object.defineProperty;var Ut=Object.getOwnPropertyDescriptor;var Gt=Object.getOwnPropertyNames;var zt=Object.getPrototypeOf,Ht=Object.prototype.hasOwnProperty;var Mt=(e,t,i,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Gt(t))!Ht.call(e,s)&&s!==i&&Ce(e,s,{get:()=>t[s],enumerable:!(n=Ut(t,s))||n.enumerable});return e};var c=(e,t,i)=>(i=e!=null?Lt(zt(e)):{},Mt(t||!e||!e.__esModule?Ce(i,"default",{value:e,enumerable:!0}):i,e));var Nt=c(require("node:path")),Wt=c(require("glob")),It=c(require("yargs"));var G=c(require("node:fs")),q=c(require("node:path"));var ae=class{isVerbose;constructor(){this.isVerbose=!1}},E=new ae;var le=class{async function(t,i){E.isVerbose&&console.info(`--------- ${t} start ---------`),await i(),E.isVerbose&&console.info(`---------- ${t} end ----------`)}},m=new le;var $e=require("minimal-promise-pool"),p=new $e.PromisePool;var ce=c(require("node:child_process"));function v(e,t,i,n=0){do{let[s,r,a]=Re(e,t,i);if(console.log(`$ ${s} ${r.join(" ")} at ${a.cwd}`),ce.default.spawnSync(s,r,a).status===0)break}while(--n>=0)}function U(e,t,i){let[n,s,r]=Re(e,t,i);r.stdio="pipe";let a=ce.default.spawnSync(n,s,r),o=a.stderr.toString().trim();return o&&console.error(`${n} [${s.map(l=>`"${l}"`)}] caused the following error:
2
+ ${o}`),a.stdout.toString().trim()}function Re(e,t,i){let n={...process.env};return n.PATH&&n.BERRY_BIN_FOLDER&&(n.PATH=n.PATH.replace(`${n.BERRY_BIN_FOLDER}:`,"")),n.ASDF_DIR&&(t=["-l","-c",`. ${n.ASDF_DIR}/asdf.sh && ${e} ${t.join(" ")}`],e="bash"),[e,t,{cwd:i,env:n,shell:!1,stdio:"inherit"}]}async function Te(e){return m.function("generateVersionConfigs",async()=>{await Yt(e)})}async function Yt(e){if(!e.versionsText)return;let t=[];for(let n of e.versionsText.trim().split(`
3
+ `)){let s=n.trim();if(s&&s.split(/\s+/)[0]!=="nodejs"){t.push(s);continue}let[,r]=s.split(/\s+/);await p.run(()=>G.default.promises.writeFile(q.default.resolve(e.dirPath,".node-version"),r))}if(e.containingPoetryLock&&(K("poetry 1.2.2",0,t),G.default.existsSync(q.default.resolve(e.dirPath,".python-version"))||K("python 3.9.15",0,t)),e.depending.firebase&&K("java adoptopenjdk-17.0.5+8",0,t),e.containingPackageJson){let n=U("npm",["show","yarn","version"],e.dirPath);K(`yarn ${n}`,t.length,t)}let i=q.default.resolve(e.dirPath,".tool-versions");await(t.length>0?p.run(()=>G.default.promises.writeFile(i,t.join(`
4
4
  `)+`
5
- `)):p.run(()=>G.default.promises.rm(r,{force:!0}))),await p.promiseAll(),v("asdf",["plugin","update","--all"],e.dirPath),v("asdf",["install"],e.dirPath)}function K(e,t,r){let[n]=e.split(" "),s=r.findIndex(i=>i.split(/\s+/)[0]===n);s>=0?r[s]=e:r.splice(t,0,e)}var je=c(require("node:path"));var k={codeWith2IndentSize:["cjs","mjs","js","jsx","cts","mts","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","cts","mts","ts","tsx","jsx"].sort(),prettier:["cjs","mjs","js","jsx","cts","mts","ts","tsx","json","json5","css","htm","html","md","scss","vue","yaml","yml"].sort()};var pe=c(require("node:fs/promises")),y={async readFileIgnoringError(e){try{return await pe.default.readFile(e,"utf8")}catch{}},async generateFile(e,t){await pe.default.writeFile(e,t),console.log(`Generated ${e}`)}};var Kt=`root = true
5
+ `)):p.run(()=>G.default.promises.rm(i,{force:!0}))),await p.promiseAll(),v("asdf",["plugin","update","--all"],e.dirPath),v("asdf",["install"],e.dirPath)}function K(e,t,i){let[n]=e.split(" "),s=i.findIndex(r=>r.split(/\s+/)[0]===n);s>=0?i[s]=e:i.splice(t,0,e)}var Ee=c(require("node:path"));var k={codeWith2IndentSize:["cjs","mjs","js","jsx","cts","mts","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","cts","mts","ts","tsx","jsx"].sort(),prettier:["cjs","mjs","js","jsx","cts","mts","ts","tsx","json","json5","css","htm","html","md","scss","vue","yaml","yml"].sort()};var pe=c(require("node:fs/promises")),y={async readFileIgnoringError(e){try{return await pe.default.readFile(e,"utf8")}catch{}},async generateFile(e,t){await pe.default.writeFile(e,t),console.log(`Generated ${e}`)}};var Kt=`root = true
6
6
 
7
7
  [*]
8
8
  charset = utf-8
@@ -28,19 +28,19 @@ trim_trailing_whitespace = false
28
28
 
29
29
  [{Makefile,*.mk}]
30
30
  indent_style = tab
31
- `;async function Ee(e){return m.function("generateEditorconfig",async()=>{let t=je.default.resolve(e.dirPath,".editorconfig");await p.run(()=>y.generateFile(t,Kt))})}function V(e){return e.length>1?`[*.{${e.join(",")}}]`:`[*.${e[0]}]`}var fe=c(require("node:path"));var me=c(require("node:fs")),z="# Project-specific settings",Oe=/# Project-specific settings[^\n]*\n/gm,We="# Generated by wbfy",qt="# Generated by ",De=`${z} (head)
31
+ `;async function je(e){return m.function("generateEditorconfig",async()=>{let t=Ee.default.resolve(e.dirPath,".editorconfig");await p.run(()=>y.generateFile(t,Kt))})}function V(e){return e.length>1?`[*.{${e.join(",")}}]`:`[*.${e[0]}]`}var de=c(require("node:path"));var me=c(require("node:fs")),z="# Project-specific settings",Oe=/# Project-specific settings[^\n]*\n/gm,We="# Generated by wbfy",qt="# Generated by ",De=`${z} (head)
32
32
 
33
33
 
34
34
  ${We}
35
35
  `,Be=`
36
36
  ${z} (tail)
37
- `,b={separator:We,separatorPrefix:qt,defaultHeadUserContent:De,defaultTailUserContent:Be,async readGitignoreWithoutSeparators(e){try{let t=await me.default.promises.readFile(e,"utf8"),r=Ne(t);return r>0&&(t=t.slice(0,r-1)),t.replace(Oe,"").replace(/# Generated by [^\n]*\n/gm,"").replace(/\r?\n\r?\n(\r?\n)+/gm,`
37
+ `,b={separator:We,separatorPrefix:qt,defaultHeadUserContent:De,defaultTailUserContent:Be,async readGitignoreWithoutSeparators(e){try{let t=await me.default.promises.readFile(e,"utf8"),i=Ne(t);return i>0&&(t=t.slice(0,i-1)),t.replace(Oe,"").replace(/# Generated by [^\n]*\n/gm,"").replace(/\r?\n\r?\n(\r?\n)+/gm,`
38
38
 
39
39
  `).trim()+`
40
40
  `}catch{}},getHeadUserContent(e){let t=e.indexOf(this.separatorPrefix);return t>=0?e.slice(0,e.indexOf(`
41
41
  `,t)+1).replace(Oe,`${z} (head)
42
42
  `):De},getTailUserContent(e){let t=Ne(e);return t>0?e.slice(t-1):Be},async isBerryZeroInstallEnabled(e){try{return(await me.default.promises.readFile(e,"utf8")).includes(`
43
- !.yarn/cache`)}catch{return!1}}};function Ne(e){let t=e.indexOf(z),r=e.lastIndexOf(z);return r>t?r:-1}var Ie=`
43
+ !.yarn/cache`)}catch{return!1}}};function Ne(e){let t=e.indexOf(z),i=e.lastIndexOf(z);return i>t?i:-1}var Ie=`
44
44
  3rd-party/
45
45
  @types/
46
46
  __generated__/
@@ -53,7 +53,7 @@ test-fixtures/
53
53
  *.min.*js
54
54
  .yarn/
55
55
  .pnp.js
56
- `;async function Je(e){return m.function("generateEslintignore",async()=>{let t=fe.default.resolve(e.dirPath,".eslintignore"),r=await y.readFileIgnoringError(t)??"",n=b.getHeadUserContent(r)+Ie,s=b.getTailUserContent(r),i=fe.default.resolve(e.dirPath,".gitignore"),a=await b.readGitignoreWithoutSeparators(i)||"",o=n+Ie+a+s;await p.run(()=>y.generateFile(t,o))})}var Ue=c(require("node:fs")),Ge=c(require("node:path")),ze=c(require("deepmerge"));var Ae=c(require("deepmerge"));function N(e,t){return t}function X(e,t,r){let n=[...e];for(let[s,i]of t.entries())n[s]===void 0?n[s]=r.cloneUnlessOtherwiseSpecified(i,r):r.isMergeableObject(i)?n[s]=(0,Ae.default)(e[s],i,r):e.includes(i)||n.push(i);return n}async function He(e,t){return m.function("generateEslintrc",async()=>{if(t.depending.blitz==="2")return;let r=[];e.eslintBase&&r.push(e.eslintBase),e!==t&&r.push("../../.eslintrc.json");let n={root:!0,extends:r},s=Ge.default.resolve(e.dirPath,".eslintrc.json");try{let a=await Ue.default.promises.readFile(s,"utf8"),o=JSON.parse(a);o.extends&&(o.extends=o.extends.filter(f=>!f.startsWith("@willbooster/")&&f!=="../../.eslintrc.json")),r.length===0&&(o.extends=[]);let l=n.extends;n.extends=o.extends,o.extends=l,n=ze.default.all([n,o,n],{arrayMerge:X}),e.depending.blitz==="0"?Le(n,"blitz"):e.depending.blitz==="2"&&Le(n,"@blitzjs/next/eslint")}catch{}let i=JSON.stringify(n);await p.run(()=>y.generateFile(s,i))})}function Le(e,t){e.extends=[t,...e.extends.filter(r=>r!==t)]}var Me=c(require("node:path"));var Vt=`* text=auto
56
+ `;async function Je(e){return m.function("generateEslintignore",async()=>{let t=de.default.resolve(e.dirPath,".eslintignore"),i=await y.readFileIgnoringError(t)??"",n=b.getHeadUserContent(i)+Ie,s=b.getTailUserContent(i),r=de.default.resolve(e.dirPath,".gitignore"),a=await b.readGitignoreWithoutSeparators(r)||"",o=n+Ie+a+s;await p.run(()=>y.generateFile(t,o))})}var Ue=c(require("node:fs")),Ge=c(require("node:path")),ze=c(require("deepmerge"));var Ae=c(require("deepmerge"));function N(e,t){return t}function X(e,t,i){let n=[...e];for(let[s,r]of t.entries())n[s]===void 0?n[s]=i.cloneUnlessOtherwiseSpecified(r,i):i.isMergeableObject(r)?n[s]=(0,Ae.default)(e[s],r,i):e.includes(r)||n.push(r);return n}async function He(e,t){return m.function("generateEslintrc",async()=>{if(t.depending.blitz==="2")return;let i=[];e.eslintBase&&i.push(e.eslintBase),e!==t&&i.push("../../.eslintrc.json");let n={root:!0,extends:i},s=Ge.default.resolve(e.dirPath,".eslintrc.json");try{let a=await Ue.default.promises.readFile(s,"utf8"),o=JSON.parse(a);o.extends&&(o.extends=o.extends.filter(d=>!d.startsWith("@willbooster/")&&d!=="../../.eslintrc.json")),i.length===0&&(o.extends=[]);let l=n.extends;n.extends=o.extends,o.extends=l,n=ze.default.all([n,o,n],{arrayMerge:X}),e.depending.blitz==="0"?Le(n,"blitz"):e.depending.blitz==="2"&&Le(n,"@blitzjs/next/eslint")}catch{}let r=JSON.stringify(n);await p.run(()=>y.generateFile(s,r))})}function Le(e,t){e.extends=[t,...e.extends.filter(i=>i!==t)]}var Me=c(require("node:path"));var Vt=`* text=auto
57
57
 
58
58
  *.vcproj text eol=crlf
59
59
 
@@ -66,7 +66,7 @@ temp/
66
66
  Icon[\r]
67
67
  *.sqlite3
68
68
  *.sqlite3-journal
69
- `;async function qe(e,t){return m.function("generateGitignore",async()=>{let r=W.default.resolve(e.dirPath,".gitignore"),n=await y.readFileIgnoringError(r)??"",s=b.getHeadUserContent(n)+Zt,i=b.getTailUserContent(n),a=[...Xt];e.containingGemfile&&a.push("ruby"),e.containingGoMod&&(a.push("go"),s+=`${W.default.basename(e.dirPath)}
69
+ `;async function qe(e,t){return m.function("generateGitignore",async()=>{let i=W.default.resolve(e.dirPath,".gitignore"),n=await y.readFileIgnoringError(i)??"",s=b.getHeadUserContent(n)+Zt,r=b.getTailUserContent(n),a=[...Xt];e.containingGemfile&&a.push("ruby"),e.containingGoMod&&(a.push("go"),s+=`${W.default.basename(e.dirPath)}
70
70
  `),e.containingPackageJson&&a.push("node"),e.containingPomXml&&(a.push("maven"),s+=`.idea/google-java-format.xml
71
71
  `),e.containingPubspecYaml&&(a.push("flutter","AndroidStudio","ruby"),s+=`.flutter-plugins-dependencies
72
72
  android/key.properties
@@ -78,10 +78,10 @@ packaged.yaml
78
78
  android/app/src/main/assets/
79
79
  `),t.depending.storybook&&a.push("storybookjs"),t.depending.blitz&&(a.push("nextjs"),s+=`.blitz/
80
80
  .blitz**
81
- `);let o="";for(let f of a){let d=await er(f)??"";if(!d){let h=`https://www.toptal.com/developers/gitignore/api/${f}`,w=await(await fetch(h)).text();if(w.includes("Attention Required!")){console.error(`Failed to fetch ${h}`);return}d=w.trim(),await p.run(()=>Qt(f,d)),j.isVerbose&&console.info(`Fetched ${h}`)}o&&(o+=`
82
- `),o+=d+`
83
- `}await b.isBerryZeroInstallEnabled(r)||(o=o.replace("!.yarn/cache","# !.yarn/cache").replace("# .pnp.*",".pnp.*")),(e.containingPomXml||e.containingPubspecYaml)&&(o=o.replace(/^# .idea\/artifacts$/gm,".idea/artifacts").replace(/^# .idea\/compiler.xml$/gm,".idea/compiler.xml").replace(/^# .idea\/jarRepositories.xml$/gm,".idea/jarRepositories.xml").replace(/^# .idea\/modules.xml$/gm,".idea/modules.xml").replace(/^# .idea\/*.iml$/gm,".idea/*.iml").replace(/^# .idea\/modules$/gm,".idea/modules").replace(/^# *.iml$/gm,"*.iml").replace(/^# *.ipr$/gm,"*.ipr"),e.containingPubspecYaml&&(o=o.replace(/^.idea\/modules.xml$/gm,"# .idea/modules.xml"))),o=o.replace(/^.idea\/?$/gm,"# .idea"),(t.depending.reactNative||e.depending.reactNative||e.containingPubspecYaml)&&(o=o.replace(/^(.idea\/.+)$/gm,`$1
84
- android/$1`));let l=s+o+i;await p.run(()=>y.generateFile(r,l))})}var Z=W.default.join(Ke.default.homedir(),".cache","wbfy","gitignore");async function Qt(e,t){await H.default.promises.mkdir(Z,{recursive:!0}),await H.default.promises.writeFile(W.default.join(Z,e),t)}async function er(e){try{let t=await H.default.promises.stat(W.default.join(Z,e));return Date.now()-t.mtimeMs>6*60*60*1e3?void 0:await H.default.promises.readFile(W.default.join(Z,e),"utf8")}catch{}}var $=c(require("node:fs")),I=c(require("node:path"));var ue="npm test",Q={preCommit:"yarn lint-staged",prePush:"yarn typecheck",prePushForLab:`
81
+ `);let o="";for(let d of a){let f=await ei(d)??"";if(!f){let h=`https://www.toptal.com/developers/gitignore/api/${d}`,w=await(await fetch(h)).text();if(w.includes("Attention Required!")){console.error(`Failed to fetch ${h}`);return}f=w.trim(),await p.run(()=>Qt(d,f)),E.isVerbose&&console.info(`Fetched ${h}`)}o&&(o+=`
82
+ `),o+=f+`
83
+ `}await b.isBerryZeroInstallEnabled(i)||(o=o.replace("!.yarn/cache","# !.yarn/cache").replace("# .pnp.*",".pnp.*")),(e.containingPomXml||e.containingPubspecYaml)&&(o=o.replace(/^# .idea\/artifacts$/gm,".idea/artifacts").replace(/^# .idea\/compiler.xml$/gm,".idea/compiler.xml").replace(/^# .idea\/jarRepositories.xml$/gm,".idea/jarRepositories.xml").replace(/^# .idea\/modules.xml$/gm,".idea/modules.xml").replace(/^# .idea\/*.iml$/gm,".idea/*.iml").replace(/^# .idea\/modules$/gm,".idea/modules").replace(/^# *.iml$/gm,"*.iml").replace(/^# *.ipr$/gm,"*.ipr"),e.containingPubspecYaml&&(o=o.replace(/^.idea\/modules.xml$/gm,"# .idea/modules.xml"))),o=o.replace(/^.idea\/?$/gm,"# .idea"),(t.depending.reactNative||e.depending.reactNative||e.containingPubspecYaml)&&(o=o.replace(/^(.idea\/.+)$/gm,`$1
84
+ android/$1`));let l=s+o+r;await p.run(()=>y.generateFile(i,l))})}var Z=W.default.join(Ke.default.homedir(),".cache","wbfy","gitignore");async function Qt(e,t){await H.default.promises.mkdir(Z,{recursive:!0}),await H.default.promises.writeFile(W.default.join(Z,e),t)}async function ei(e){try{let t=await H.default.promises.stat(W.default.join(Z,e));return Date.now()-t.mtimeMs>6*60*60*1e3?void 0:await H.default.promises.readFile(W.default.join(Z,e),"utf8")}catch{}}var $=c(require("node:fs")),I=c(require("node:path"));var ue="npm test",Q={preCommit:"node node_modules/.bin/lint-staged",prePush:"yarn typecheck",prePushForLab:`
85
85
  if [ $(git branch --show-current) = "main" ] && [ $(git config user.email) != "exkazuu@gmail.com" ]; then
86
86
  echo "************************************************"
87
87
  echo "*** Don't push main branch directly. Use PR! ***"
@@ -96,14 +96,14 @@ run_if_changed() {
96
96
  if echo "$changed_files" | grep --quiet -E "$1"; then
97
97
  eval "$2"
98
98
  fi
99
- }`.trim()};async function Ve(e){return m.function("generateHuskyrc",async()=>{await tr(e)})}async function tr(e){var f,d;let t=I.default.resolve(e.dirPath,"package.json"),r=await $.default.promises.readFile(t,"utf8"),n=JSON.parse(r);n.scripts||={},delete n.scripts.postinstall,delete n.scripts.postpublish,delete n.scripts.prepare,delete n.scripts.prepublishOnly,delete n.scripts.prepack,delete n.scripts.postpack;let s=I.default.resolve(e.dirPath,".husky");await Promise.all([$.default.promises.writeFile(t,JSON.stringify(n,void 0,2)),$.default.promises.rm(s,{force:!0,recursive:!0})]),v("yarn",["dlx","husky-init","--yarn2"],e.dirPath);let i=I.default.resolve(s,"pre-commit"),a=await $.default.promises.readFile(i,"utf8");if(await p.run(()=>$.default.promises.rm(I.default.resolve(e.dirPath,".huskyrc.json"),{force:!0})),await p.run(()=>$.default.promises.writeFile(i,a.replace(ue,Q.preCommit))),e.containingTypeScript||e.containingTypeScriptInPackages){let h=(f=e.repository)!=null&&f.startsWith("github:WillBoosterLab/")?Q.prePushForLab:Q.prePush;await p.run(()=>$.default.promises.writeFile(I.default.resolve(s,"pre-push"),a.replace(ue,h),{mode:493}))}let o=[];e.versionsText&&o.push('run_if_changed "\\..+-version" "asdf plugin update --all"'),(d=e.versionsText)!=null&&d.includes("python ")&&o.push('run_if_changed "\\..+-version" "asdf install python"'),e.versionsText&&o.push('run_if_changed "\\..+-version" "asdf install"'),o.push('run_if_changed "package\\.json" "yarn"'),e.containingPoetryLock&&o.push('run_if_changed "poetry\\.lock" "poetry install"'),(e.depending.blitz||e.depending.prisma)&&o.push("yarn gen-code");let l=a.replace(ue,`${Q.postMerge}
99
+ }`.trim()};async function Ve(e){return m.function("generateHuskyrc",async()=>{await ti(e)})}async function ti(e){var d,f;let t=I.default.resolve(e.dirPath,"package.json"),i=await $.default.promises.readFile(t,"utf8"),n=JSON.parse(i);n.scripts||={},delete n.scripts.postinstall,delete n.scripts.postpublish,delete n.scripts.prepare,delete n.scripts.prepublishOnly,delete n.scripts.prepack,delete n.scripts.postpack;let s=I.default.resolve(e.dirPath,".husky");await Promise.all([$.default.promises.writeFile(t,JSON.stringify(n,void 0,2)),$.default.promises.rm(s,{force:!0,recursive:!0})]),v("yarn",["dlx","husky-init","--yarn2"],e.dirPath);let r=I.default.resolve(s,"pre-commit"),a=await $.default.promises.readFile(r,"utf8");if(await p.run(()=>$.default.promises.rm(I.default.resolve(e.dirPath,".huskyrc.json"),{force:!0})),await p.run(()=>$.default.promises.writeFile(r,a.replace(ue,Q.preCommit))),e.containingTypeScript||e.containingTypeScriptInPackages){let h=(d=e.repository)!=null&&d.startsWith("github:WillBoosterLab/")?Q.prePushForLab:Q.prePush;e.containingSubPackageJsons||(h=h.replace("yarn typecheck","node node_modules/.bin/tsc --noEmit --Pretty")),await p.run(()=>$.default.promises.writeFile(I.default.resolve(s,"pre-push"),a.replace(ue,h),{mode:493}))}let o=[];e.versionsText&&o.push('run_if_changed "\\..+-version" "asdf plugin update --all"'),(f=e.versionsText)!=null&&f.includes("python ")&&o.push('run_if_changed "\\..+-version" "asdf install python"'),e.versionsText&&o.push('run_if_changed "\\..+-version" "asdf install"'),o.push('run_if_changed "package\\.json" "yarn"'),e.containingPoetryLock&&o.push('run_if_changed "poetry\\.lock" "poetry install"'),(e.depending.blitz||e.depending.prisma)&&o.push("yarn gen-code");let l=a.replace(ue,`${Q.postMerge}
100
100
 
101
101
  ${o.join(`
102
- `)}`);await p.run(()=>$.default.promises.writeFile(I.default.resolve(s,"post-merge"),l,{mode:493}))}var de=c(require("node:fs")),ge=c(require("node:path"));var rr=`<?xml version="1.0" encoding="UTF-8"?>
102
+ `)}`);await p.run(()=>$.default.promises.writeFile(I.default.resolve(s,"post-merge"),l,{mode:493}))}var fe=c(require("node:fs")),ge=c(require("node:path"));var ii=`<?xml version="1.0" encoding="UTF-8"?>
103
103
  <project version="4">
104
104
  <component name="ProjectTasksOptions">
105
105
  <TaskOptions isEnabled="true">
106
- <option name="arguments" value="prettier --cache --write $FilePathRelativeToProjectRoot$" />
106
+ <option name="arguments" value="node node_modules/.bin/prettier --cache --write $FilePathRelativeToProjectRoot$" />
107
107
  <option name="checkSyntaxErrors" value="false" />
108
108
  <option name="description" />
109
109
  <option name="exitCodeBehavior" value="ERROR" />
@@ -123,7 +123,7 @@ ${o.join(`
123
123
  <envs />
124
124
  </TaskOptions>
125
125
  <TaskOptions isEnabled="true">
126
- <option name="arguments" value="prettier --cache --write $FilePathRelativeToProjectRoot$" />
126
+ <option name="arguments" value="node node_modules/.bin/prettier --cache --write $FilePathRelativeToProjectRoot$" />
127
127
  <option name="checkSyntaxErrors" value="false" />
128
128
  <option name="description" />
129
129
  <option name="exitCodeBehavior" value="ERROR" />
@@ -143,7 +143,7 @@ ${o.join(`
143
143
  <envs />
144
144
  </TaskOptions>
145
145
  <TaskOptions isEnabled="true">
146
- <option name="arguments" value="prettier --cache --write $FilePathRelativeToProjectRoot$" />
146
+ <option name="arguments" value="node node_modules/.bin/prettier --cache --write $FilePathRelativeToProjectRoot$" />
147
147
  <option name="checkSyntaxErrors" value="false" />
148
148
  <option name="description" />
149
149
  <option name="exitCodeBehavior" value="ERROR" />
@@ -163,7 +163,7 @@ ${o.join(`
163
163
  <envs />
164
164
  </TaskOptions>
165
165
  <TaskOptions isEnabled="true">
166
- <option name="arguments" value="prettier --cache --write $FilePathRelativeToProjectRoot$" />
166
+ <option name="arguments" value="node node_modules/.bin/prettier --cache --write $FilePathRelativeToProjectRoot$" />
167
167
  <option name="checkSyntaxErrors" value="false" />
168
168
  <option name="description" />
169
169
  <option name="exitCodeBehavior" value="ERROR" />
@@ -183,7 +183,7 @@ ${o.join(`
183
183
  <envs />
184
184
  </TaskOptions>
185
185
  <TaskOptions isEnabled="true">
186
- <option name="arguments" value="prettier --cache --write $FilePathRelativeToProjectRoot$" />
186
+ <option name="arguments" value="node node_modules/.bin/prettier --cache --write $FilePathRelativeToProjectRoot$" />
187
187
  <option name="checkSyntaxErrors" value="false" />
188
188
  <option name="description" />
189
189
  <option name="exitCodeBehavior" value="ERROR" />
@@ -203,7 +203,7 @@ ${o.join(`
203
203
  <envs />
204
204
  </TaskOptions>
205
205
  <TaskOptions isEnabled="true">
206
- <option name="arguments" value="prettier --cache --write $FilePathRelativeToProjectRoot$" />
206
+ <option name="arguments" value="node node_modules/.bin/prettier --cache --write $FilePathRelativeToProjectRoot$" />
207
207
  <option name="checkSyntaxErrors" value="false" />
208
208
  <option name="description" />
209
209
  <option name="exitCodeBehavior" value="ERROR" />
@@ -224,15 +224,15 @@ ${o.join(`
224
224
  </TaskOptions>
225
225
  </component>
226
226
  </project>
227
- `;async function Xe(e){return m.function("generateIdeaSettings",async()=>{let t=ge.default.resolve(e.dirPath,".idea");if(de.default.existsSync(t)){let r=ge.default.resolve(t,"watcherTasks.xml");await(e.containingJavaScript||e.containingJavaScriptInPackages||e.containingTypeScript||e.containingTypeScriptInPackages||e.containingPackageJson&&!e.containingPubspecYaml&&!e.containingGemfile&&!e.containingGoMod&&!e.containingPomXml?p.run(()=>y.generateFile(r,rr)):p.run(()=>de.default.promises.rm(r,{force:!0})))}})}var ye=c(require("node:fs")),re=c(require("node:path"));var ee={getLintFixSuffix(e){return e.containingJsxOrTsx?' --rule "{ react-hooks/exhaustive-deps: 0 }"':""}};var Ze={node:["src","__tests__","scripts"].sort(),blitz:["__tests__","scripts","app","db","integrations","mailers","pages","test"].sort()};function te(e){return e.depending.blitz?Ze.blitz:Ze.node}async function he(e){return m.function("generateLintstagedrc",async()=>{await ir(e)})}async function ir(e){let t=[];if(e.containingJavaScript||e.containingTypeScript){let i=`
228
- '${Qe(e)}': [${JSON.stringify(`eslint --fix${ee.getLintFixSuffix(e)}`)}, 'prettier --cache --write'],`;t.push(i)}let r=e.root?" && !file.includes('/packages/')":"";t.push(`
227
+ `;async function Xe(e){return m.function("generateIdeaSettings",async()=>{let t=ge.default.resolve(e.dirPath,".idea");if(fe.default.existsSync(t)){let i=ge.default.resolve(t,"watcherTasks.xml");await(e.containingJavaScript||e.containingJavaScriptInPackages||e.containingTypeScript||e.containingTypeScriptInPackages||e.containingPackageJson&&!e.containingPubspecYaml&&!e.containingGemfile&&!e.containingGoMod&&!e.containingPomXml?p.run(()=>y.generateFile(i,ii)):p.run(()=>fe.default.promises.rm(i,{force:!0})))}})}var ye=c(require("node:fs")),ie=c(require("node:path"));var ee={getLintFixSuffix(e){return e.containingJsxOrTsx?' --rule "{ react-hooks/exhaustive-deps: 0 }"':""}};var Ze={node:["src","__tests__","scripts"].sort(),blitz:["__tests__","scripts","app","db","integrations","mailers","pages","test"].sort()};function te(e){return e.depending.blitz?Ze.blitz:Ze.node}async function he(e){return m.function("generateLintstagedrc",async()=>{await ri(e)})}async function ri(e){let t=[];if(e.containingJavaScript||e.containingTypeScript){let r=`
228
+ '${Qe(e)}': [${JSON.stringify(`node node_modules/.bin/eslint --fix${ee.getLintFixSuffix(e)}`)}, 'node node_modules/.bin/prettier --cache --write'],`;t.push(r)}let i=e.root?" && !file.includes('/packages/')":"";t.push(`
229
229
  './**/*.{${k.prettier.join(",")}}': files => {
230
- ${e.containingJavaScript||e.containingTypeScript?nr(e):""}
231
- const filteredFiles = files.filter(file => !file.includes('/test-fixtures/')${r});
230
+ ${e.containingJavaScript||e.containingTypeScript?ni(e):""}
231
+ const filteredFiles = files.filter(file => !file.includes('/test-fixtures/')${i});
232
232
  if (filteredFiles.length === 0) return [];
233
- const commands = [\`prettier --cache --write \${filteredFiles.join(' ')}\`];
233
+ const commands = [\`node node_modules/.bin/prettier --cache --write \${filteredFiles.join(' ')}\`];
234
234
  if (filteredFiles.some(file => file.endsWith('package.json'))) {
235
- commands.push('yarn sort-package-json');
235
+ commands.push('node node_modules/.bin/sort-package-json');
236
236
  }
237
237
  return commands;
238
238
  },`),e.containingPubspecYaml&&t.push(`
@@ -250,7 +250,7 @@ ${o.join(`
250
250
 
251
251
  module.exports = {${t.join("")}
252
252
  };
253
- `,s=re.default.resolve(e.dirPath,".lintstagedrc.cjs");await p.run(()=>ye.default.promises.rm(re.default.resolve(e.dirPath,".lintstagedrc.js"),{force:!0})),await p.run(()=>ye.default.promises.rm(re.default.resolve(e.dirPath,".lintstagedrc.json"),{force:!0})),await p.run(()=>y.generateFile(s,n))}function Qe(e){return`./{${te(e).join(",")}}/**/*.{${k.eslint.join(",")}}`}function nr(e){return`files = micromatch.not(files, '${Qe(e)}');`}var O=c(require("node:fs")),A=c(require("node:path")),ve=c(require("deepmerge"));var et=require("@octokit/core"),tt=process.env.GH_BOT_PAT||process.env.PUBLIC_GH_BOT_PAT||process.env.GH_TOKEN||process.env.GITHUB_TOKEN,ie=!!tt,C=new et.Octokit({auth:tt}),we=class{getOrgAndName(t){var a;let r=t.split(":").at(-1),n=r==null?void 0:r.split("/"),s=(n==null?void 0:n.at(-2))??"",i=((a=n==null?void 0:n.at(-1))==null?void 0:a.replace(/.git$/,""))??"";return[s,i]}},E=new we;var Pe=["eslint","eslint-config-prettier","eslint-plugin-import","eslint-plugin-sort-class-members","eslint-plugin-sort-destructure-keys","eslint-plugin-unicorn"],rt=[...Pe,"@typescript-eslint/eslint-plugin","@typescript-eslint/parser","eslint-import-resolver-typescript"],it=["eslint-plugin-react","eslint-plugin-react-hooks"],nt={"@willbooster/eslint-config-js":["@willbooster/eslint-config-js",...Pe],"@willbooster/eslint-config-js-react":["@willbooster/eslint-config-js-react",...Pe,...it],"@willbooster/eslint-config-ts":["@willbooster/eslint-config-ts",...rt],"@willbooster/eslint-config-ts-react":["@willbooster/eslint-config-ts-react",...rt,...it],"../../.eslintrc.json":[]};async function ot(e,t,r){return m.function("generatePackageJson",async()=>{await or(e,t,r)})}async function or(e,t,r){var d,h;let n=A.default.resolve(e.dirPath,"package.json"),s=await O.default.promises.readFile(n,"utf8"),i=JSON.parse(s);i.scripts=i.scripts||{},i.dependencies=i.dependencies||{},i.devDependencies=i.devDependencies||{},i.peerDependencies=i.peerDependencies||{},await sr(i),i.name!=="@willbooster/prettier-config"&&(i.prettier="@willbooster/prettier-config");for(let g of Object.keys(i.scripts))i.scripts[g].includes("git clone")||(i.scripts[g]=i.scripts[g].replace(/yarn\s*&&\s*/,"").replace(/yarn\s*install\s*&&\s*/,""));i.scripts=(0,ve.default)(i.scripts,ar(e)),i.scripts.prettify+=await lr(e.dirPath);let a=[],o=["lint-staged","prettier","sort-package-json","@willbooster/prettier-config"],l=[];e.root&&(o.push("husky","@willbooster/renovate-config"),(e.publicRepo||e.referred)&&(o.push("pinst"),i.scripts.prepack="pinst --disable",i.scripts.postpack="pinst --enable"),e.depending.semanticRelease&&(o.push("conventional-changelog-conventionalcommits"),!i.devDependencies["semantic-release"]&&!i.devDependencies["multi-semantic-release"]&&!i.devDependencies["@qiwi/multi-semantic-release"]&&o.push("semantic-release"),i.version="0.0.0-semantically-released"),e.containingSubPackageJsons?i.workspaces=["packages/*"]:delete i.workspaces),(e.containingJavaScript||e.containingJavaScriptInPackages||e.containingTypeScript||e.containingTypeScriptInPackages)&&(o.push("eslint","micromatch"),e.containingTypeScriptInPackages&&o.push("@typescript-eslint/parser")),(e.containingTypeScript||e.containingTypeScriptInPackages)&&o.push("typescript"),e.eslintBase&&o.push(...nt[e.eslintBase]),e.willBoosterConfigs&&(a=a.filter(g=>!g.includes("@willbooster/")),o=o.filter(g=>!g.includes("@willbooster/"))),i.name||(i.name=A.default.basename(e.dirPath)),e.containingSubPackageJsons&&(i.private=!0),i.license||(i.license="UNLICENSED"),!i.private&&i.license!=="UNLICENSED"&&t.publicRepo&&(i.publishConfig??={},i.publishConfig.access??="public");let[f]=E.getOrgAndName(e.repository??"");if((f==="WillBooster"||f==="WillBoosterLab")&&(i.author="WillBooster Inc."),!e.containingTypeScript&&!e.containingTypeScriptInPackages&&delete i.scripts.typecheck,e.depending.semanticRelease&&e.release.npm&&(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"]+=ee.getLintFixSuffix(e),e.containingPubspecYaml){i.scripts.lint="flutter analyze",i.scripts["lint-fix"]="yarn lint";let g=["lib","test","test_driver"].filter(w=>O.default.existsSync(A.default.resolve(e.dirPath,w)));g.length>0&&(i.scripts["format-code"]=`flutter format $(find ${g.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 g=await O.default.promises.readdir(e.dirPath,{withFileTypes:!0}),F=(await Promise.all(g.map(async x=>{if(!x.isDirectory())return"";let Jt=A.default.resolve(e.dirPath,x.name);return(await O.default.promises.readdir(Jt)).some(At=>At.endsWith(".py"))?x.name:""}))).filter(Boolean);F.length>0&&(i.scripts["format-code"]=`poetry run isort --profile black ${F.join(" ")} && poetry run black ${F.join(" ")}`,i.scripts.lint=`poetry run flake8 ${F.join(" ")}`,i.scripts["lint-fix"]="yarn lint",i.scripts.format+=" && yarn format-code",l.push("black","isort","flake8"))}e.repository&&(i.repository=e.repository)}e.depending.blitz?(e.depending.blitz==="0"&&(o=o.filter(g=>!g.includes("@typescript-eslint/")),o=o.filter(g=>g!=="eslint-plugin-react"&&g!=="eslint-import-resolver-typescript"&&g!=="eslint-plugin-import"&&g!=="eslint-plugin-react-hooks")),(d=i.scripts["gen-code"])!=null&&d.startsWith("blitz codegen")||(i.scripts["gen-code"]="blitz codegen")):e.depending.prisma&&!((h=i.scripts["gen-code"])!=null&&h.startsWith("prisma generate"))&&(i.scripts["gen-code"]="prisma generate"),Object.keys(i.dependencies).length===0&&delete i.dependencies,Object.keys(i.devDependencies).length===0&&delete i.devDependencies,Object.keys(i.peerDependencies).length===0&&delete i.peerDependencies,await O.default.promises.writeFile(n,JSON.stringify(i)),r||(a=a.filter(g=>{var w;return!((w=i.devDependencies)!=null&&w[g])}),a.length>0&&v("yarn",["add",...new Set(a)],e.dirPath),o=o.filter(g=>{var w;return!((w=i.dependencies)!=null&&w[g])}),o.length>0&&v("yarn",["add","-D",...new Set(o)],e.dirPath),l.length>0&&v("poetry",["add",...new Set(l)],e.dirPath))}async function sr(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(nt))for(let r of t)delete e.devDependencies[r];await p.run(()=>O.default.promises.rm("lerna.json",{force:!0}))}function ar(e){let t={cleanup:"yarn format && yarn lint-fix",format:"sort-package-json && yarn prettify",lint:`eslint --color "./{${te(e)}}/**/*.{${k.eslint.join(",")}}"`,"lint-fix":"yarn lint --fix",prettify:`prettier --cache --color --write "**/{.*/,}*.{${k.prettier.join(",")}}" "!**/test-fixtures/**"`,typecheck:"tsc --noEmit --Pretty"};return e.containingSubPackageJsons&&(t=(0,ve.default)({...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 --cache --color --write "**/{.*/,}*.{${k.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 lr(e){let t=A.default.resolve(e,".prettierignore"),r=await O.default.promises.readFile(t,"utf8"),n=r.indexOf(b.separatorPrefix);return n<0?"":r.slice(0,n).split(`
253
+ `,s=ie.default.resolve(e.dirPath,".lintstagedrc.cjs");await p.run(()=>ye.default.promises.rm(ie.default.resolve(e.dirPath,".lintstagedrc.js"),{force:!0})),await p.run(()=>ye.default.promises.rm(ie.default.resolve(e.dirPath,".lintstagedrc.json"),{force:!0})),await p.run(()=>y.generateFile(s,n))}function Qe(e){return`./{${te(e).join(",")}}/**/*.{${k.eslint.join(",")}}`}function ni(e){return`files = micromatch.not(files, '${Qe(e)}');`}var O=c(require("node:fs")),A=c(require("node:path")),ve=c(require("deepmerge"));var et=require("@octokit/core"),tt=process.env.GH_BOT_PAT||process.env.PUBLIC_GH_BOT_PAT||process.env.GH_TOKEN||process.env.GITHUB_TOKEN,re=!!tt,C=new et.Octokit({auth:tt}),we=class{getOrgAndName(t){var a;let i=t.split(":").at(-1),n=i==null?void 0:i.split("/"),s=(n==null?void 0:n.at(-2))??"",r=((a=n==null?void 0:n.at(-1))==null?void 0:a.replace(/.git$/,""))??"";return[s,r]}},j=new we;var Pe=["eslint","eslint-config-prettier","eslint-plugin-import","eslint-plugin-sort-class-members","eslint-plugin-sort-destructure-keys","eslint-plugin-unicorn"],it=[...Pe,"@typescript-eslint/eslint-plugin","@typescript-eslint/parser","eslint-import-resolver-typescript"],rt=["eslint-plugin-react","eslint-plugin-react-hooks"],nt={"@willbooster/eslint-config-js":["@willbooster/eslint-config-js",...Pe],"@willbooster/eslint-config-js-react":["@willbooster/eslint-config-js-react",...Pe,...rt],"@willbooster/eslint-config-ts":["@willbooster/eslint-config-ts",...it],"@willbooster/eslint-config-ts-react":["@willbooster/eslint-config-ts-react",...it,...rt],"../../.eslintrc.json":[]};async function ot(e,t,i){return m.function("generatePackageJson",async()=>{await oi(e,t,i)})}async function oi(e,t,i){var f,h;let n=A.default.resolve(e.dirPath,"package.json"),s=await O.default.promises.readFile(n,"utf8"),r=JSON.parse(s);r.scripts=r.scripts||{},r.dependencies=r.dependencies||{},r.devDependencies=r.devDependencies||{},r.peerDependencies=r.peerDependencies||{},await si(r),r.name!=="@willbooster/prettier-config"&&(r.prettier="@willbooster/prettier-config");for(let g of Object.keys(r.scripts))r.scripts[g].includes("git clone")||(r.scripts[g]=r.scripts[g].replace(/yarn\s*&&\s*/,"").replace(/yarn\s*install\s*&&\s*/,""));r.scripts=(0,ve.default)(r.scripts,ai(e)),r.scripts.prettify+=await li(e.dirPath);let a=[],o=["lint-staged","prettier","sort-package-json","@willbooster/prettier-config"],l=[];e.root&&(o.push("husky","@willbooster/renovate-config"),(e.publicRepo||e.referred)&&(o.push("pinst"),r.scripts.prepack="pinst --disable",r.scripts.postpack="pinst --enable"),e.depending.semanticRelease&&(o.push("conventional-changelog-conventionalcommits"),!r.devDependencies["semantic-release"]&&!r.devDependencies["multi-semantic-release"]&&!r.devDependencies["@qiwi/multi-semantic-release"]&&o.push("semantic-release"),r.version="0.0.0-semantically-released"),e.containingSubPackageJsons?r.workspaces=["packages/*"]:delete r.workspaces),(e.containingJavaScript||e.containingJavaScriptInPackages||e.containingTypeScript||e.containingTypeScriptInPackages)&&(o.push("eslint","micromatch"),e.containingTypeScriptInPackages&&o.push("@typescript-eslint/parser")),(e.containingTypeScript||e.containingTypeScriptInPackages)&&o.push("typescript"),e.eslintBase&&o.push(...nt[e.eslintBase]),e.willBoosterConfigs&&(a=a.filter(g=>!g.includes("@willbooster/")),o=o.filter(g=>!g.includes("@willbooster/"))),r.name||(r.name=A.default.basename(e.dirPath)),e.containingSubPackageJsons&&(r.private=!0),r.license||(r.license="UNLICENSED"),!r.private&&r.license!=="UNLICENSED"&&t.publicRepo&&(r.publishConfig??={},r.publishConfig.access??="public");let[d]=j.getOrgAndName(e.repository??"");if((d==="WillBooster"||d==="WillBoosterLab")&&(r.author="WillBooster Inc."),!e.containingTypeScript&&!e.containingTypeScriptInPackages&&delete r.scripts.typecheck,e.depending.semanticRelease&&e.release.npm&&(r.resolutions||={},r.resolutions["npm/chalk"]="^4.1.2"),!e.containingSubPackageJsons){if(!e.containingJavaScript&&!e.containingTypeScript?(delete r.scripts.lint,delete r.scripts["lint-fix"],r.scripts.cleanup=r.scripts.cleanup.replace(" && yarn lint-fix","")):r.scripts["lint-fix"]+=ee.getLintFixSuffix(e),e.containingPubspecYaml){r.scripts.lint="flutter analyze",r.scripts["lint-fix"]="yarn lint";let g=["lib","test","test_driver"].filter(w=>O.default.existsSync(A.default.resolve(e.dirPath,w)));g.length>0&&(r.scripts["format-code"]=`flutter format $(find ${g.join(" ")} -name generated -prune -o -name '*.freezed.dart' -prune -o -name '*.g.dart' -prune -o -name '*.dart' -print)`,r.scripts.format+=" && yarn format-code")}if(e.containingPoetryLock){r.scripts.postinstall==="poetry install"&&delete r.scripts.postinstall;let g=await O.default.promises.readdir(e.dirPath,{withFileTypes:!0}),F=(await Promise.all(g.map(async x=>{if(!x.isDirectory())return"";let Jt=A.default.resolve(e.dirPath,x.name);return(await O.default.promises.readdir(Jt)).some(At=>At.endsWith(".py"))?x.name:""}))).filter(Boolean);F.length>0&&(r.scripts["format-code"]=`poetry run isort --profile black ${F.join(" ")} && poetry run black ${F.join(" ")}`,r.scripts.lint=`poetry run flake8 ${F.join(" ")}`,r.scripts["lint-fix"]="yarn lint",r.scripts.format+=" && yarn format-code",l.push("black","isort","flake8"))}e.repository&&(r.repository=e.repository)}e.depending.blitz?(e.depending.blitz==="0"&&(o=o.filter(g=>!g.includes("@typescript-eslint/")),o=o.filter(g=>g!=="eslint-plugin-react"&&g!=="eslint-import-resolver-typescript"&&g!=="eslint-plugin-import"&&g!=="eslint-plugin-react-hooks")),(f=r.scripts["gen-code"])!=null&&f.startsWith("blitz codegen")||(r.scripts["gen-code"]="blitz codegen")):e.depending.prisma&&!((h=r.scripts["gen-code"])!=null&&h.startsWith("prisma generate"))&&(r.scripts["gen-code"]="prisma generate"),Object.keys(r.dependencies).length===0&&delete r.dependencies,Object.keys(r.devDependencies).length===0&&delete r.devDependencies,Object.keys(r.peerDependencies).length===0&&delete r.peerDependencies,await O.default.promises.writeFile(n,JSON.stringify(r)),i||(a=a.filter(g=>{var w;return!((w=r.devDependencies)!=null&&w[g])}),a.length>0&&v("yarn",["add",...new Set(a)],e.dirPath),o=o.filter(g=>{var w;return!((w=r.dependencies)!=null&&w[g])}),o.length>0&&v("yarn",["add","-D",...new Set(o)],e.dirPath),l.length>0&&v("poetry",["add",...new Set(l)],e.dirPath))}async function si(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(nt))for(let i of t)delete e.devDependencies[i];await p.run(()=>O.default.promises.rm("lerna.json",{force:!0}))}function ai(e){let t={cleanup:"yarn format && yarn lint-fix",format:"sort-package-json && yarn prettify",lint:`eslint --color "./{${te(e)}}/**/*.{${k.eslint.join(",")}}"`,"lint-fix":"yarn lint --fix",prettify:`prettier --cache --color --write "**/{.*/,}*.{${k.prettier.join(",")}}" "!**/test-fixtures/**"`,typecheck:"tsc --noEmit --Pretty"};return e.containingSubPackageJsons&&(t=(0,ve.default)({...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 --cache --color --write "**/{.*/,}*.{${k.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 li(e){let t=A.default.resolve(e,".prettierignore"),i=await O.default.promises.readFile(t,"utf8"),n=i.indexOf(b.separatorPrefix);return n<0?"":i.slice(0,n).split(`
254
254
  `).map(a=>{let o=a.trim();return o.endsWith("/")?o.slice(0,-1):o}).filter(a=>a&&!a.startsWith("#")&&!a.includes("/")).map(a=>` "!**/${a}/**"`).join("")}var ke=c(require("node:path"));var st=`
255
255
  3rd-party/
256
256
  android/
@@ -261,13 +261,13 @@ test-fixtures/
261
261
  *.min.js
262
262
  .yarn/
263
263
  .pnp.js
264
- `;async function at(e){return m.function("generatePrettierignore",async()=>{let t=ke.default.resolve(e.dirPath,".prettierignore"),r=await y.readFileIgnoringError(t)??"",n=b.getHeadUserContent(r)+st,s=b.getTailUserContent(r),i=ke.default.resolve(e.dirPath,".gitignore"),a=await b.readGitignoreWithoutSeparators(i)||"",o="";e.containingPubspecYaml&&(o=`
264
+ `;async function at(e){return m.function("generatePrettierignore",async()=>{let t=ke.default.resolve(e.dirPath,".prettierignore"),i=await y.readFileIgnoringError(t)??"",n=b.getHeadUserContent(i)+st,s=b.getTailUserContent(i),r=ke.default.resolve(e.dirPath,".gitignore"),a=await b.readGitignoreWithoutSeparators(r)||"",o="";e.containingPubspecYaml&&(o=`
265
265
  android/app/
266
266
  ios/Runner/Assets.xcassets/
267
267
  pubspec.yaml
268
- `);let l=n+st+o+a+s;await p.run(()=>y.generateFile(t,l))})}var ne=c(require("node:fs")),be=c(require("node:path"));async function ct(e){return m.function("generateReadme",async()=>{var i,a;let t=be.default.resolve(e.dirPath,"README.md"),r=await ne.default.promises.readFile(t,"utf8");r=lt(e,r,cr,".releaserc.json");let n=(a=e.repository)==null?void 0:a.slice(((i=e.repository)==null?void 0:i.indexOf(":"))+1),s=ne.default.readdirSync(`${e.dirPath}/.github/workflows`);for(let o of s){if(!o.startsWith("test")&&!o.startsWith("deploy"))continue;let l=o;l=l.charAt(0).toUpperCase()+l.slice(1,l.indexOf(".")),l=l.replace("-"," ");let f=`[![${l}](https://github.com/${n}/actions/workflows/${o}/badge.svg)](https://github.com/${n}/actions/workflows/${o})`;r=lt(e,r,f,`.github/workflows/${o}`)}await p.run(()=>y.generateFile(t,r))})}var cr="[![semantic-release](https://img.shields.io/badge/%20%20%F0%9F%93%A6%F0%9F%9A%80-semantic--release-e10079.svg)](https://github.com/semantic-release/semantic-release)";function lt(e,t,r,n){if(!ne.default.existsSync(be.default.resolve(e.dirPath,n)))return t;let s=t.indexOf(r);s>=0&&(t=t.slice(0,s)+t.slice(s+r.length));let i=!1;for(let a=0;a<t.length;a++)if(t[a]===`
269
- `){i=!0,t=`${t.slice(0,a+1)}${r}
270
- ${t.slice(a+1)}`;break}return i||(t=`${t}
271
- ${r}
272
- `),t}var pt=c(require("node:fs")),mt=c(require("node:path")),xe=c(require("deepmerge"));async function ft(e){return m.function("generateReleaserc",async()=>{let t=mt.default.resolve(e.dirPath,".releaserc.json");try{let r=JSON.parse(await pt.default.promises.readFile(t,"utf8")),n=(r==null?void 0:r.plugins)||[];for(let i=0;i<n.length;i++){let a=Array.isArray(n[i])?n[i][0]:n[i],o=Array.isArray(n[i])&&n[i][1]||{};a==="@semantic-release/commit-analyzer"?n[i]=["@semantic-release/commit-analyzer",xe.default.all([o,{preset:"conventionalcommits"}],{arrayMerge:N})]:a==="@semantic-release/github"&&(n[i]=["@semantic-release/github",xe.default.all([o,{successComment:!1,labels:["r: semantic-release"],releasedLabels:["released :bookmark:"]}],{arrayMerge:N})])}let s=JSON.stringify(r);await p.run(()=>y.generateFile(t,s))}catch{}})}var oe=c(require("node:fs")),se=c(require("node:path")),ut=c(require("deepmerge")),dt=c(require("lodash.clonedeep"));var pr={extends:["@willbooster"]};async function gt(e){return m.function("generateRenovateJson",async()=>{let t=(0,dt.default)(pr),r=se.default.resolve(e.dirPath,".renovaterc.json");try{let s=await oe.default.promises.readFile(r,"utf8"),i=JSON.parse(s);t=ut.default.all([t,i,t],{arrayMerge:N})}catch{}await p.run(()=>oe.default.promises.rm(se.default.resolve(e.dirPath,".dependabot"),{force:!0})),await p.run(()=>oe.default.promises.rm(se.default.resolve(e.dirPath,"renovate.json"),{force:!0}));let n=JSON.stringify(t);await p.run(()=>y.generateFile(r,n))})}var yt=c(require("node:fs")),ht=c(require("node:path")),wt=c(require("deepmerge")),Pt=c(require("lodash.clonedeep"));function M(e){let t=Object.entries(e).sort(([r],[n])=>r.localeCompare(n));for(let[r,n]of t)delete e[r],e[r]=n;return e}var mr={compilerOptions:{target:"esnext",module:"esnext",moduleResolution:"node",jsx:"react-jsx",alwaysStrict:!0,strict:!0,skipLibCheck:!0,allowSyntheticDefaultImports:!0,esModuleInterop:!0,resolveJsonModule:!0,declaration:!0,sourceMap:!0,importHelpers:!1,outDir:"dist",typeRoots:["./node_modules/@types","./@types"]},include:["src/**/*","__tests__/**/*","scripts/**/*","packages/*/src/**/*","packages/*/__tests__/**/*","packages/*/scripts/**/*"]},fr={compilerOptions:{target:"esnext",module:"esnext",moduleResolution:"node",jsx:"react-jsx",alwaysStrict:!0,strict:!0,skipLibCheck:!0,allowSyntheticDefaultImports:!0,esModuleInterop:!0,resolveJsonModule:!0,declaration:!0,sourceMap:!0,importHelpers:!1,outDir:"dist",typeRoots:["../../node_modules/@types","../../@types","./@types"]},include:["src/**/*","__tests__/**/*","scripts/**/*"]};async function vt(e,t){return m.function("generateTsconfig",async()=>{var i,a;if(t.depending.blitz)return;let r=(0,Pt.default)(e.root?mr:fr);!e.containingJsxOrTsx&&!e.containingJsxOrTsxInPackages&&delete r.compilerOptions.jsx,e.root&&!e.containingSubPackageJsons&&(r.include=r.include.filter(o=>!o.startsWith("packages/*/")));let n=ht.default.resolve(e.dirPath,"tsconfig.json");try{let o=await yt.default.promises.readFile(n,"utf8"),l=JSON.parse(o);l.extends==="./node_modules/@willbooster/tsconfig/tsconfig.json"&&delete l.extends,(i=r==null?void 0:r.compilerOptions)==null||delete i.target,(a=r==null?void 0:r.compilerOptions)==null||delete a.module,l.jsx&&delete r.jsx,r=wt.default.all([r,l,r],{arrayMerge:N}),r.include=r.include.filter(f=>!f.includes("@types"))}catch{}M(r.compilerOptions);let s=JSON.stringify(r);await p.run(()=>y.generateFile(n,s))})}var T=c(require("node:fs")),R=c(require("node:path")),xt=c(require("deepmerge")),_e=c(require("js-yaml")),_t=c(require("lodash.clonedeep"));var ur={test:{name:"Test",on:{pull_request:null,push:{branches:["main","wbfy","renovate/**"]}},jobs:{test:{uses:"WillBooster/reusable-workflows/.github/workflows/test.yml@main"}}},release:{name:"Release",on:{push:{branches:[]}},jobs:{release:{uses:"WillBooster/reusable-workflows/.github/workflows/release.yml@main"}}},wbfy:{name:"Willboosterify",on:{workflow_dispatch:null},jobs:{wbfy:{uses:"WillBooster/reusable-workflows/.github/workflows/wbfy.yml@main"}}},"wbfy-merge":{name:"Merge wbfy",on:{workflow_dispatch:null},jobs:{"wbfy-merge":{uses:"WillBooster/reusable-workflows/.github/workflows/wbfy-merge.yml@main"}}},"semantic-pr":{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"}}},"notify-ready":{name:"Notify ready",on:{issues:{types:["labeled"]}},jobs:{"notify-ready":{uses:"WillBooster/reusable-workflows/.github/workflows/notify-ready.yml@main",secrets:{DISCORD_WEBHOOK_URL:"${{ secrets.DISCORD_WEBHOOK_URL_FOR_READY }}"}}}},"close-comment":{name:"Add close comment",on:{pull_request:{types:["opened"]}},jobs:{"close-comment":{uses:"WillBooster/reusable-workflows/.github/workflows/close-comment.yml@main"}}},"add-issue-to-project":{name:"Add issue to github project",on:{issues:{types:["labeled"]}},jobs:{"add-to-project":{uses:"WillBooster/reusable-workflows/.github/workflows/add-issue-to-project.yml@main",secrets:{GH_PROJECT_URL:"${{ secrets.GH_PROJECT_URL }}",GH_BOT_PAT:"${{ secrets.GH_BOT_PAT }}"}}}}};async function St(e){return m.function("generateWorkflow",async()=>{var i;let t=R.default.resolve(e.dirPath,".github","workflows");await T.default.promises.mkdir(t,{recursive:!0});let r=R.default.resolve(e.dirPath,".github","semantic.yml");await p.run(()=>T.default.promises.rm(r,{force:!0,recursive:!0}));let s=(await T.default.promises.readdir(t,{withFileTypes:!0})).filter(a=>a.isFile()&&a.name.endsWith(".yml")).map(a=>a.name);e.depending.semanticRelease&&s.push("release.yml"),(e.publicRepo||(i=e.repository)!=null&&i.startsWith("github:WillBoosterLab/"))&&s.push("notify-ready.yml"),s.push("test.yml","wbfy.yml","wbfy-merge.yml","semantic-pr.yml","close-comment.yml","add-issue-to-project.yml");for(let a of s){let o=R.default.basename(a,".yml");await p.run(()=>dr(e,t,o))}})}async function dr(e,t,r){var i,a;let n=(0,_t.default)(ur[r]||{}),s=R.default.join(t,`${r}.yml`);try{let o=await T.default.promises.readFile(s,"utf8"),l=_e.default.load(o);n=xt.default.all([n,l,n],{arrayMerge:X})}catch{}for(let o of Object.values(n.jobs)){if(!((a=(i=o.uses)==null?void 0:i.includes)!=null&&a.call(i,"/reusable-workflows/")))return;gr(e,o,r)}switch(r){case"release":{if(n.on.schedule)delete n.on.push;else if(e.release.branches.length>0)n.on.push.branches=e.release.branches;else{await T.default.promises.rm(R.default.join(t,"release.yml"),{force:!0});return}break}case"wbfy":{kt(n,20,24);break}case"wbfy-merge":{kt(n,0,4);break}}if(await bt(n,s),r==="release")await T.default.promises.rm(R.default.join(t,"semantic-release.yml"),{force:!0});else if(r==="sync"){if(await T.default.promises.rm(R.default.join(t,"sync-init.yml"),{force:!0}),!n.jobs.sync)return;n.jobs["sync-force"]=n.jobs.sync;let o=n.jobs.sync.with.sync_params_without_dest;if(!o)return;n.jobs.sync.with.sync_params_without_dest=`--force ${o}`,n.name="Force to Sync",n.on={workflow_dispatch:null},delete n.jobs.sync,await bt(n,R.default.join(t,"sync-force.yml"))}}function gr(e,t,r){var n,s,i;if(t.with||={},t.secrets||={},(e.release.github&&r==="test"||r==="release"||r==="wbfy"||r==="wbfy-merge")&&(t.secrets.GH_TOKEN=e.publicRepo?"${{ secrets.PUBLIC_GH_BOT_PAT }}":"${{ secrets.GH_BOT_PAT }}"),e.release.npm&&(r==="release"||r==="test")&&(t.secrets.NPM_TOKEN="${{ secrets.NPM_TOKEN }}"),t.secrets.FIREBASE_TOKEN&&(t.secrets.GCP_SA_KEY_JSON_FOR_FIREBASE="${{ secrets.GCP_SA_KEY_JSON_FOR_FIREBASE }}",delete t.secrets.FIREBASE_TOKEN),(t.secrets.DISCORD_WEBHOOK_URL&&(r==="release"||r.startsWith("deploy"))||t.with.server_url&&r.startsWith("deploy"))&&(t.secrets.DISCORD_WEBHOOK_URL="${{ secrets.DISCORD_WEBHOOK_URL_FOR_RELEASE }}"),r==="sync"){let a=(n=t.with)==null?void 0:n.sync_params_without_dest;a&&(t.with.sync_params_without_dest=a.replace("sync ",""))}if((s=e.repository)!=null&&s.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,delete t.with.notify_discord,delete t.with.require_fly,delete t.with.require_gcloud,t.with.dot_env_path===".env"&&delete t.with.dot_env_path,e.containingDockerfile&&r.startsWith("deploy")&&(t.with.cpu_arch="X64"),r==="release"||r==="test"||r==="wbfy"||r==="wbfy-merge"||r.startsWith("deploy")?e.publicRepo&&(t.with.github_hosted_runner=!0):delete t.with.github_hosted_runner,Object.keys(t.with).length>0?M(t.with):delete t.with,Object.keys(t.secrets).length>0){let a=M(t.secrets);delete t.secrets,t.secrets=a}else delete t.secrets}function kt(e,t,r){var l,f;let[n,s]=(((f=(l=e.on.schedule)==null?void 0:l[0])==null?void 0:f.cron)??"").split(" ").map(Number);if(n!==0&&Number.isInteger(s)){let d=(s+9)%24,h=t<r?t<=d&&d<r:t<=d||d<r;if(h)return;console.log("setSchedule:",e,n,s,h,d,t,r)}else console.log("setSchedule:",e,n,s);let i=1+Math.floor(Math.random()*59),a=t+Math.floor(Math.random()*(r-t)),o=`${i} ${(a-9+24)%24} * * *`;e.on.schedule=[{cron:o}]}async function bt(e,t){let r=_e.default.dump(e,{lineWidth:-1,noCompatMode:!0,styles:{"!!null":"empty"}});await T.default.promises.writeFile(t,r)}var J=c(require("node:fs")),L=c(require("node:path")),Se=c(require("js-yaml"));async function $t(e){return m.function("generateYarnrcYml",async()=>{let t=U("yarn",["--version"],e.dirPath),r=yr("@yarnpkg/cli",e.dirPath);Ct(t)<=Ct(r)&&t!==r&&v("yarn",["set","version",r],e.dirPath,1);let n=L.default.join(e.dirPath,".yarn","releases");await J.default.promises.mkdir(n,{recursive:!0});for(let f of await J.default.promises.readdir(n))f.startsWith("yarn-")&&!f.startsWith(`yarn-${r}.`)&&(await p.run(()=>J.default.promises.rm(L.default.join(n,f))),console.log("Removed",L.default.join(n,f)));let s=L.default.resolve(e.dirPath,".yarnrc");await p.run(()=>J.default.promises.rm(s,{force:!0}));let i=L.default.resolve(e.dirPath,".yarnrc.yml"),a=Se.default.load(await J.default.promises.readFile(i,"utf8"));a.defaultSemverRangePrefix="",e.requiringNodeModules&&(a.nodeLinker="node-modules",a.nmMode="hardlinks-global",a.enableGlobalCache=!0),await J.default.promises.writeFile(i,Se.default.dump(a,{lineWidth:-1}));let o=(a.plugins||[]).map(f=>f.spec),l=e.containingTypeScript||e.containingTypeScriptInPackages;Ft(e,o,l,"@yarnpkg/plugin-typescript"),l&&!e.requiringNodeModules&&v("yarn",["dlx","@yarnpkg/sdks","vscode"],e.dirPath),Ft(e,o,e.containingSubPackageJsons,"@yarnpkg/plugin-workspace-tools"),v("yarn",["dlx","yarn-plugin-auto-install"],e.dirPath)})}function yr(e,t){let r=U("npm",["show",e,"versions","--json"],t),n=JSON.parse(r);return n[n.length-1]}function Ft(e,t,r,n){r!==t.includes(n)&&v("yarn",["plugin",r?"import":"remove",n],e.dirPath)}function Ct(e){let[t]=e.split(".");return Number(t)}async function Rt(e){return m.function("setupLabels",async()=>{if(!ie)return;let[t,r]=E.getOrgAndName(e.repository??"");if(!(!t||!r)&&!(t!=="WillBooster"&&t!=="WillBoosterLab"))try{await u(t,r,"d1: x-easy :hedgehog:","EDE9FE"),await u(t,r,"d2: easy :rabbit2:","DDD6FE"),await u(t,r,"d3: medium :ox:","C4B5FD"),await u(t,r,"d4: hard :squid:","A78BFA"),await u(t,r,"d5: x-hard :whale2:","8B5CF6"),await u(t,r,"p1: critical :fire::fire::fire:","EF4444"),await u(t,r,"p2: urgent :fire::fire:","F87171"),await u(t,r,"p3: important :fire:","FCA5A5"),await u(t,r,"p4: nice to have :droplet:","FECACA"),await u(t,r,"r: blitz","5300bc"),await u(t,r,"r: firebase","ffca28"),await u(t,r,"r: prisma","0c344b"),await u(t,r,"r: react","61dafb"),await u(t,r,"r: svelte","ff3e00"),await u(t,r,"r: semantic-release","494949"),await u(t,r,"ready :rocket:","22C55E"),await u(t,r,"review requested :mag:","FBCA04"),await u(t,r,"released :bookmark:","6366F1"),await u(t,r,"s: 0.5h :clock1230:","F3F4F6"),await u(t,r,"s: 1h :clock1:","E5E7EB"),await u(t,r,"s: 2h :clock2:","D1D5DB"),await u(t,r,"s: 3h :clock3:","9CA3AF"),await u(t,r,"s: 5h :clock5:","6B7280"),await u(t,r,"s: 8h :clock8:","4B5563"),await u(t,r,"s: 13h :clock1:","374151"),await u(t,r,"t: build :hammer:","BFDBFE"),await u(t,r,"t: chore :broom:","BFDBFE"),await u(t,r,"t: ci :construction_worker:","BFDBFE"),await u(t,r,"t: docs :memo:","BFDBFE"),await u(t,r,"t: feat :sparkles:","BFDBFE"),await u(t,r,"t: fix :bug:","BFDBFE"),await u(t,r,"t: perf :zap:","BFDBFE"),await u(t,r,"t: refactor :recycle:","BFDBFE"),await u(t,r,"t: style :lipstick:","BFDBFE"),await u(t,r,"t: test :test_tube:","BFDBFE"),await u(t,r,"project","24292F"),await _(t,r,"bug"),await _(t,r,"documentation"),await _(t,r,"duplicate"),await _(t,r,"enhancement"),await _(t,r,"good first issue"),await _(t,r,"help wanted"),await _(t,r,"invalid"),await _(t,r,"question"),await _(t,r,"wontfix"),await _(t,r,"ready"),await _(t,r,"review requested"),await _(t,r,"released"),await _(t,r,"semantic-release")}catch(n){console.warn("Skip setupLabels due to:",(n==null?void 0:n.stack)??n)}})}async function u(e,t,r,n){try{await C.request("POST /repos/{owner}/{repo}/labels",{owner:e,repo:t,name:r,color:n})}catch{await C.request("PATCH /repos/{owner}/{repo}/labels/{name}",{owner:e,repo:t,name:r,color:n})}}async function _(e,t,r){try{await C.request("DELETE /repos/{owner}/{repo}/labels/{name}",{owner:e,repo:t,name:r})}catch{}}var Tt=c(require("dotenv")),D=c(require("libsodium-wrappers"));var hr=["READY_DISCORD_WEBHOOK_URL"];async function jt(e){return m.function("setupSecrets",async()=>{if(!ie)return;let[t,r]=E.getOrgAndName(e.repository??"");if(!t||!r||t!=="WillBoosterLab")return;let n=Tt.default.config().parsed||{};if(Object.keys(n).length!==0)try{for(let o of hr)try{await C.request("DELETE /repos/{owner}/{repo}/actions/secrets/{secret_name}",{owner:t,repo:r,secret_name:o})}catch{}let s=await C.request("GET /repos/{owner}/{repo}/actions/secrets/public-key",{owner:t,repo:r}),{key:i,key_id:a}=s.data;await D.default.ready;for(let[o,l]of Object.entries(n)){if(e.publicRepo&&o==="GH_BOT_PAT"||!e.publicRepo&&o==="PUBLIC_GH_BOT_PAT")continue;let f=D.default.from_base64(i,D.default.base64_variants.ORIGINAL),d=D.default.from_string(l),h=D.default.crypto_box_seal(d,f),g=D.default.to_base64(h,D.default.base64_variants.ORIGINAL);await C.request("PUT /repos/{owner}/{repo}/actions/secrets/{secret_name}",{owner:t,repo:r,secret_name:o,encrypted_value:g,key_id:a})}}catch(s){console.warn("Skip setupSecrets due to:",(s==null?void 0:s.stack)??s)}})}async function Et(e){}var S=c(require("node:fs")),Y=c(require("node:fs/promises")),P=c(require("node:path")),B=c(require("glob")),Dt=c(require("js-yaml")),Bt=require("simple-git");async function Fe(e){var r;let t=P.default.resolve(e,"package.json");try{let n=S.default.existsSync(t),s={},i={},a={};if(n){let F=S.default.readFileSync(t,"utf8");a=JSON.parse(F),s=a.dependencies??{},i=a.devDependencies??{}}let o=!0;try{let F=P.default.resolve(e,".yarnrc.yml"),x=Dt.default.load(await Y.default.readFile(F,"utf8"));o=!x.nodeLinker||x.nodeLinker==="node-modules"}catch{}let l=[],f=[];try{let F=P.default.resolve(e,".releaserc.json"),x=JSON.parse(await Y.default.readFile(F,"utf8"));l=(x==null?void 0:x.branches)||[],f=((r=x==null?void 0:x.plugins)==null?void 0:r.flat())||[]}catch{}let d=P.default.basename(P.default.resolve(e,".."))!=="packages"||!S.default.existsSync(P.default.resolve(e,"..","..","package.json")),h;d&&(h=await Pr(e,a));let g;try{g=await Y.default.readFile(P.default.resolve(e,".tool-versions"),"utf8")}catch{try{g="nodejs "+(await Y.default.readFile(P.default.resolve(e,".node-version"),"utf8")).trim()}catch{}}let w={dirPath:e,root:d,publicRepo:(h==null?void 0:h.private)===!1,referred:!!a.files,repository:h!=null&&h.full_name?`github:${h==null?void 0:h.full_name}`:void 0,willBoosterConfigs:t.includes(`${P.default.sep}willbooster-configs`),containingSubPackageJsons:B.default.sync("packages/**/package.json",{cwd:e}).length>0,containingDockerfile:S.default.existsSync(P.default.resolve(e,"Dockerfile"))||S.default.existsSync(P.default.resolve(e,"docker-compose.yml")),containingGemfile:S.default.existsSync(P.default.resolve(e,"Gemfile")),containingGoMod:S.default.existsSync(P.default.resolve(e,"go.mod")),containingPackageJson:S.default.existsSync(P.default.resolve(e,"package.json")),containingPoetryLock:S.default.existsSync(P.default.resolve(e,"poetry.lock")),containingPomXml:S.default.existsSync(P.default.resolve(e,"pom.xml")),containingPubspecYaml:S.default.existsSync(P.default.resolve(e,"pubspec.yaml")),containingTemplateYaml:S.default.existsSync(P.default.resolve(e,"template.yaml")),containingJavaScript:B.default.sync("@(app|src|__tests__|scripts)/**/*.{cjs,mjs,js,jsx}",{cwd:e}).length>0,containingTypeScript:B.default.sync("@(app|src|__tests__|scripts)/**/*.{cts,mts,ts,tsx}",{cwd:e}).length>0,containingJsxOrTsx:B.default.sync("@(app|src|__tests__)/**/*.{t,j}sx",{cwd:e}).length>0,containingJavaScriptInPackages:B.default.sync("packages/**/@(app|src|__tests__|scripts)/**/*.{cjs,mjs,js,jsx}",{cwd:e}).length>0,containingTypeScriptInPackages:B.default.sync("packages/**/@(app|src|__tests__|scripts)/**/*.{cts,mts,ts,tsx}",{cwd:e}).length>0,containingJsxOrTsxInPackages:B.default.sync("packages/**/@(app|src|__tests__)/**/*.{t,j}sx",{cwd:e}).length>0,depending:{blitz:(s.blitz||i.blitz||"").replace("^","")[0],firebase:!!i["firebase-tools"],prisma:!!i.prisma,reactNative:!!s["react-native"],semanticRelease:!!(i["semantic-release"]||l.length>0||f.length>0),storybook:!!i["@storybook/react"]},release:{branches:l,github:f.includes("@semantic-release/github"),npm:f.includes("@semantic-release/npm")},requiringNodeModules:o,versionsText:g};if(w.eslintBase=wr(w),w.containingGemfile||w.containingGoMod||w.containingPackageJson||w.containingPoetryLock||w.containingPomXml||w.containingPubspecYaml||w.containingTemplateYaml)return w}catch{}}function wr(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 Pr(e,t){var o,l,f;let s=(await(0,Bt.simpleGit)(e).getRemotes(!0)).find(d=>d.name==="origin"),i=((o=s==null?void 0:s.refs)==null?void 0:o.fetch)??((l=s==null?void 0:s.refs)==null?void 0:l.push);if(typeof i=="string"){let d=await Ot(i);if(d)return d}let a=((f=t.repository)==null?void 0:f.url)??t.repository;if(typeof a=="string"){let d=await Ot(a);if(d&&d.message!=="Not Found")return d}}async function Ot(e){let[t,r]=E.getOrgAndName(e);if(!t||!r)return;let n={full_name:`${t}/${r}`};try{let s=await C.request("GET /repos/{owner}/{repo}",{owner:t,repo:r});Object.assign(n,s.data)}catch{}return n}async function vr(){let e=await(0,It.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;j.isVerbose=e.verbose;for(let t of e._){if(typeof t=="number")continue;let r=await Fe(t);if(!r){console.error(`there is no valid package.json in ${t}`);continue}let n=r.containingSubPackageJsons?Wt.default.sync("packages/*",{cwd:t}).map(l=>Nt.default.resolve(t,l)):[],i=(await Promise.all(n.map(l=>Fe(l)))).filter(l=>!!l),a=[r,...i];if(j.isVerbose)for(let l of a)console.info(l);await Te(r),await $t(r),await Promise.all([Ee(r),Ye(r),Ve(r),Xe(r),he(r),ct(r),gt(r),ft(r),St(r),Rt(r),jt(r),Et(r)]),await p.promiseAll();let o=[];for(let l of a)await qe(l,r),await p.promiseAll(),!(!l.root&&!l.containingPackageJson)&&(await at(l),await ot(l,r,e.skipDeps),o.push(he(l)),(l.containingTypeScript||l.containingTypeScriptInPackages)&&o.push(vt(l,r)),(l.containingJavaScript||l.containingJavaScriptInPackages||l.containingTypeScript||l.containingTypeScriptInPackages)&&(r.willBoosterConfigs||o.push(He(l,r)),o.push(Je(l))));await Promise.all(o),await p.promiseAll(),v("yarn",["cleanup"],t),v("yarn",["install"],t)}}vr().then();
268
+ `);let l=n+st+o+a+s;await p.run(()=>y.generateFile(t,l))})}var ne=c(require("node:fs")),be=c(require("node:path"));async function ct(e){return m.function("generateReadme",async()=>{var r,a;let t=be.default.resolve(e.dirPath,"README.md"),i=await ne.default.promises.readFile(t,"utf8");i=lt(e,i,ci,".releaserc.json");let n=(a=e.repository)==null?void 0:a.slice(((r=e.repository)==null?void 0:r.indexOf(":"))+1),s=ne.default.readdirSync(`${e.dirPath}/.github/workflows`);for(let o of s){if(!o.startsWith("test")&&!o.startsWith("deploy"))continue;let l=o;l=l.charAt(0).toUpperCase()+l.slice(1,l.indexOf(".")),l=l.replace("-"," ");let d=`[![${l}](https://github.com/${n}/actions/workflows/${o}/badge.svg)](https://github.com/${n}/actions/workflows/${o})`;i=lt(e,i,d,`.github/workflows/${o}`)}await p.run(()=>y.generateFile(t,i))})}var ci="[![semantic-release](https://img.shields.io/badge/%20%20%F0%9F%93%A6%F0%9F%9A%80-semantic--release-e10079.svg)](https://github.com/semantic-release/semantic-release)";function lt(e,t,i,n){if(!ne.default.existsSync(be.default.resolve(e.dirPath,n)))return t;let s=t.indexOf(i);s>=0&&(t=t.slice(0,s)+t.slice(s+i.length));let r=!1;for(let a=0;a<t.length;a++)if(t[a]===`
269
+ `){r=!0,t=`${t.slice(0,a+1)}${i}
270
+ ${t.slice(a+1)}`;break}return r||(t=`${t}
271
+ ${i}
272
+ `),t}var pt=c(require("node:fs")),mt=c(require("node:path")),xe=c(require("deepmerge"));async function dt(e){return m.function("generateReleaserc",async()=>{let t=mt.default.resolve(e.dirPath,".releaserc.json");try{let i=JSON.parse(await pt.default.promises.readFile(t,"utf8")),n=(i==null?void 0:i.plugins)||[];for(let r=0;r<n.length;r++){let a=Array.isArray(n[r])?n[r][0]:n[r],o=Array.isArray(n[r])&&n[r][1]||{};a==="@semantic-release/commit-analyzer"?n[r]=["@semantic-release/commit-analyzer",xe.default.all([o,{preset:"conventionalcommits"}],{arrayMerge:N})]:a==="@semantic-release/github"&&(n[r]=["@semantic-release/github",xe.default.all([o,{successComment:!1,labels:["r: semantic-release"],releasedLabels:["released :bookmark:"]}],{arrayMerge:N})])}let s=JSON.stringify(i);await p.run(()=>y.generateFile(t,s))}catch{}})}var oe=c(require("node:fs")),se=c(require("node:path")),ut=c(require("deepmerge")),ft=c(require("lodash.clonedeep"));var pi={extends:["@willbooster"]};async function gt(e){return m.function("generateRenovateJson",async()=>{let t=(0,ft.default)(pi),i=se.default.resolve(e.dirPath,".renovaterc.json");try{let s=await oe.default.promises.readFile(i,"utf8"),r=JSON.parse(s);t=ut.default.all([t,r,t],{arrayMerge:N})}catch{}await p.run(()=>oe.default.promises.rm(se.default.resolve(e.dirPath,".dependabot"),{force:!0})),await p.run(()=>oe.default.promises.rm(se.default.resolve(e.dirPath,"renovate.json"),{force:!0}));let n=JSON.stringify(t);await p.run(()=>y.generateFile(i,n))})}var yt=c(require("node:fs")),ht=c(require("node:path")),wt=c(require("deepmerge")),Pt=c(require("lodash.clonedeep"));function M(e){let t=Object.entries(e).sort(([i],[n])=>i.localeCompare(n));for(let[i,n]of t)delete e[i],e[i]=n;return e}var mi={compilerOptions:{target:"esnext",module:"esnext",moduleResolution:"node",jsx:"react-jsx",alwaysStrict:!0,strict:!0,skipLibCheck:!0,allowSyntheticDefaultImports:!0,esModuleInterop:!0,resolveJsonModule:!0,declaration:!0,sourceMap:!0,importHelpers:!1,outDir:"dist",typeRoots:["./node_modules/@types","./@types"]},include:["src/**/*","__tests__/**/*","scripts/**/*","packages/*/src/**/*","packages/*/__tests__/**/*","packages/*/scripts/**/*"]},di={compilerOptions:{target:"esnext",module:"esnext",moduleResolution:"node",jsx:"react-jsx",alwaysStrict:!0,strict:!0,skipLibCheck:!0,allowSyntheticDefaultImports:!0,esModuleInterop:!0,resolveJsonModule:!0,declaration:!0,sourceMap:!0,importHelpers:!1,outDir:"dist",typeRoots:["../../node_modules/@types","../../@types","./@types"]},include:["src/**/*","__tests__/**/*","scripts/**/*"]};async function vt(e,t){return m.function("generateTsconfig",async()=>{var r,a;if(t.depending.blitz)return;let i=(0,Pt.default)(e.root?mi:di);!e.containingJsxOrTsx&&!e.containingJsxOrTsxInPackages&&delete i.compilerOptions.jsx,e.root&&!e.containingSubPackageJsons&&(i.include=i.include.filter(o=>!o.startsWith("packages/*/")));let n=ht.default.resolve(e.dirPath,"tsconfig.json");try{let o=await yt.default.promises.readFile(n,"utf8"),l=JSON.parse(o);l.extends==="./node_modules/@willbooster/tsconfig/tsconfig.json"&&delete l.extends,(r=i==null?void 0:i.compilerOptions)==null||delete r.target,(a=i==null?void 0:i.compilerOptions)==null||delete a.module,l.jsx&&delete i.jsx,i=wt.default.all([i,l,i],{arrayMerge:N}),i.include=i.include.filter(d=>!d.includes("@types"))}catch{}M(i.compilerOptions);let s=JSON.stringify(i);await p.run(()=>y.generateFile(n,s))})}var T=c(require("node:fs")),R=c(require("node:path")),xt=c(require("deepmerge")),_e=c(require("js-yaml")),_t=c(require("lodash.clonedeep"));var ui={test:{name:"Test",on:{pull_request:null,push:{branches:["main","wbfy","renovate/**"]}},jobs:{test:{uses:"WillBooster/reusable-workflows/.github/workflows/test.yml@main"}}},release:{name:"Release",on:{push:{branches:[]}},jobs:{release:{uses:"WillBooster/reusable-workflows/.github/workflows/release.yml@main"}}},wbfy:{name:"Willboosterify",on:{workflow_dispatch:null},jobs:{wbfy:{uses:"WillBooster/reusable-workflows/.github/workflows/wbfy.yml@main"}}},"wbfy-merge":{name:"Merge wbfy",on:{workflow_dispatch:null},jobs:{"wbfy-merge":{uses:"WillBooster/reusable-workflows/.github/workflows/wbfy-merge.yml@main"}}},"semantic-pr":{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"}}},"notify-ready":{name:"Notify ready",on:{issues:{types:["labeled"]}},jobs:{"notify-ready":{uses:"WillBooster/reusable-workflows/.github/workflows/notify-ready.yml@main",secrets:{DISCORD_WEBHOOK_URL:"${{ secrets.DISCORD_WEBHOOK_URL_FOR_READY }}"}}}},"close-comment":{name:"Add close comment",on:{pull_request:{types:["opened"]}},jobs:{"close-comment":{uses:"WillBooster/reusable-workflows/.github/workflows/close-comment.yml@main"}}},"add-issue-to-project":{name:"Add issue to github project",on:{issues:{types:["labeled"]}},jobs:{"add-to-project":{uses:"WillBooster/reusable-workflows/.github/workflows/add-issue-to-project.yml@main",secrets:{GH_PROJECT_URL:"${{ secrets.GH_PROJECT_URL }}",GH_BOT_PAT:"${{ secrets.GH_BOT_PAT }}"}}}}};async function St(e){return m.function("generateWorkflow",async()=>{var r;let t=R.default.resolve(e.dirPath,".github","workflows");await T.default.promises.mkdir(t,{recursive:!0});let i=R.default.resolve(e.dirPath,".github","semantic.yml");await p.run(()=>T.default.promises.rm(i,{force:!0,recursive:!0}));let s=(await T.default.promises.readdir(t,{withFileTypes:!0})).filter(a=>a.isFile()&&a.name.endsWith(".yml")).map(a=>a.name);e.depending.semanticRelease&&s.push("release.yml"),(e.publicRepo||(r=e.repository)!=null&&r.startsWith("github:WillBoosterLab/"))&&s.push("notify-ready.yml"),s.push("test.yml","wbfy.yml","wbfy-merge.yml","semantic-pr.yml","close-comment.yml","add-issue-to-project.yml");for(let a of s){let o=R.default.basename(a,".yml");await p.run(()=>fi(e,t,o))}})}async function fi(e,t,i){var r,a;let n=(0,_t.default)(ui[i]||{}),s=R.default.join(t,`${i}.yml`);try{let o=await T.default.promises.readFile(s,"utf8"),l=_e.default.load(o);n=xt.default.all([n,l,n],{arrayMerge:X})}catch{}for(let o of Object.values(n.jobs)){if(!((a=(r=o.uses)==null?void 0:r.includes)!=null&&a.call(r,"/reusable-workflows/")))return;gi(e,o,i)}switch(i){case"release":{if(n.on.schedule)delete n.on.push;else if(e.release.branches.length>0)n.on.push.branches=e.release.branches;else{await T.default.promises.rm(R.default.join(t,"release.yml"),{force:!0});return}break}case"wbfy":{kt(n,20,24);break}case"wbfy-merge":{kt(n,0,4);break}}if(await bt(n,s),i==="release")await T.default.promises.rm(R.default.join(t,"semantic-release.yml"),{force:!0});else if(i==="sync"){if(await T.default.promises.rm(R.default.join(t,"sync-init.yml"),{force:!0}),!n.jobs.sync)return;n.jobs["sync-force"]=n.jobs.sync;let o=n.jobs.sync.with.sync_params_without_dest;if(!o)return;n.jobs.sync.with.sync_params_without_dest=`--force ${o}`,n.name="Force to Sync",n.on={workflow_dispatch:null},delete n.jobs.sync,await bt(n,R.default.join(t,"sync-force.yml"))}}function gi(e,t,i){var n,s,r;if(t.with||={},t.secrets||={},(e.release.github&&i==="test"||i==="release"||i==="wbfy"||i==="wbfy-merge")&&(t.secrets.GH_TOKEN=e.publicRepo?"${{ secrets.PUBLIC_GH_BOT_PAT }}":"${{ secrets.GH_BOT_PAT }}"),e.release.npm&&(i==="release"||i==="test")&&(t.secrets.NPM_TOKEN="${{ secrets.NPM_TOKEN }}"),t.secrets.FIREBASE_TOKEN&&(t.secrets.GCP_SA_KEY_JSON_FOR_FIREBASE="${{ secrets.GCP_SA_KEY_JSON_FOR_FIREBASE }}",delete t.secrets.FIREBASE_TOKEN),(t.secrets.DISCORD_WEBHOOK_URL&&(i==="release"||i.startsWith("deploy"))||t.with.server_url&&i.startsWith("deploy"))&&(t.secrets.DISCORD_WEBHOOK_URL="${{ secrets.DISCORD_WEBHOOK_URL_FOR_RELEASE }}"),i==="sync"){let a=(n=t.with)==null?void 0:n.sync_params_without_dest;a&&(t.with.sync_params_without_dest=a.replace("sync ",""))}if((s=e.repository)!=null&&s.startsWith("github:WillBooster/")?t.uses=t.uses.replace("WillBoosterLab/","WillBooster/"):(r=e.repository)!=null&&r.startsWith("github:WillBoosterLab/")&&(t.uses=t.uses.replace("WillBooster/","WillBoosterLab/")),delete t.with.non_self_hosted,delete t.with.notify_discord,delete t.with.require_fly,delete t.with.require_gcloud,t.with.dot_env_path===".env"&&delete t.with.dot_env_path,e.containingDockerfile&&i.startsWith("deploy")&&(t.with.cpu_arch="X64"),i==="release"||i==="test"||i==="wbfy"||i==="wbfy-merge"||i.startsWith("deploy")?e.publicRepo&&(t.with.github_hosted_runner=!0):delete t.with.github_hosted_runner,Object.keys(t.with).length>0?M(t.with):delete t.with,Object.keys(t.secrets).length>0){let a=M(t.secrets);delete t.secrets,t.secrets=a}else delete t.secrets}function kt(e,t,i){var l,d;let[n,s]=(((d=(l=e.on.schedule)==null?void 0:l[0])==null?void 0:d.cron)??"").split(" ").map(Number);if(n!==0&&Number.isInteger(s)){let f=(s+9)%24,h=t<i?t<=f&&f<i:t<=f||f<i;if(h)return;console.log("setSchedule:",e,n,s,h,f,t,i)}else console.log("setSchedule:",e,n,s);let r=1+Math.floor(Math.random()*59),a=t+Math.floor(Math.random()*(i-t)),o=`${r} ${(a-9+24)%24} * * *`;e.on.schedule=[{cron:o}]}async function bt(e,t){let i=_e.default.dump(e,{lineWidth:-1,noCompatMode:!0,styles:{"!!null":"empty"}});await T.default.promises.writeFile(t,i)}var J=c(require("node:fs")),L=c(require("node:path")),Se=c(require("js-yaml"));async function $t(e){return m.function("generateYarnrcYml",async()=>{let t=U("yarn",["--version"],e.dirPath),i=yi("@yarnpkg/cli",e.dirPath);Ct(t)<=Ct(i)&&t!==i&&v("yarn",["set","version",i],e.dirPath,1);let n=L.default.join(e.dirPath,".yarn","releases");await J.default.promises.mkdir(n,{recursive:!0});for(let d of await J.default.promises.readdir(n))d.startsWith("yarn-")&&!d.startsWith(`yarn-${i}.`)&&(await p.run(()=>J.default.promises.rm(L.default.join(n,d))),console.log("Removed",L.default.join(n,d)));let s=L.default.resolve(e.dirPath,".yarnrc");await p.run(()=>J.default.promises.rm(s,{force:!0}));let r=L.default.resolve(e.dirPath,".yarnrc.yml"),a=Se.default.load(await J.default.promises.readFile(r,"utf8"));a.defaultSemverRangePrefix="",e.requiringNodeModules&&(a.nodeLinker="node-modules",a.nmMode="hardlinks-global",a.enableGlobalCache=!0),await J.default.promises.writeFile(r,Se.default.dump(a,{lineWidth:-1}));let o=(a.plugins||[]).map(d=>d.spec),l=e.containingTypeScript||e.containingTypeScriptInPackages;Ft(e,o,l,"@yarnpkg/plugin-typescript"),l&&!e.requiringNodeModules&&v("yarn",["dlx","@yarnpkg/sdks","vscode"],e.dirPath),Ft(e,o,e.containingSubPackageJsons,"@yarnpkg/plugin-workspace-tools"),v("yarn",["dlx","yarn-plugin-auto-install"],e.dirPath)})}function yi(e,t){let i=U("npm",["show",e,"versions","--json"],t),n=JSON.parse(i);return n[n.length-1]}function Ft(e,t,i,n){i!==t.includes(n)&&v("yarn",["plugin",i?"import":"remove",n],e.dirPath)}function Ct(e){let[t]=e.split(".");return Number(t)}async function Rt(e){return m.function("setupLabels",async()=>{if(!re)return;let[t,i]=j.getOrgAndName(e.repository??"");if(!(!t||!i)&&!(t!=="WillBooster"&&t!=="WillBoosterLab"))try{await u(t,i,"d1: x-easy :hedgehog:","EDE9FE"),await u(t,i,"d2: easy :rabbit2:","DDD6FE"),await u(t,i,"d3: medium :ox:","C4B5FD"),await u(t,i,"d4: hard :squid:","A78BFA"),await u(t,i,"d5: x-hard :whale2:","8B5CF6"),await u(t,i,"p1: critical :fire::fire::fire:","EF4444"),await u(t,i,"p2: urgent :fire::fire:","F87171"),await u(t,i,"p3: important :fire:","FCA5A5"),await u(t,i,"p4: nice to have :droplet:","FECACA"),await u(t,i,"r: blitz","5300bc"),await u(t,i,"r: firebase","ffca28"),await u(t,i,"r: prisma","0c344b"),await u(t,i,"r: react","61dafb"),await u(t,i,"r: svelte","ff3e00"),await u(t,i,"r: semantic-release","494949"),await u(t,i,"ready :rocket:","22C55E"),await u(t,i,"review requested :mag:","FBCA04"),await u(t,i,"released :bookmark:","6366F1"),await u(t,i,"s: 0.5h :clock1230:","F3F4F6"),await u(t,i,"s: 1h :clock1:","E5E7EB"),await u(t,i,"s: 2h :clock2:","D1D5DB"),await u(t,i,"s: 3h :clock3:","9CA3AF"),await u(t,i,"s: 5h :clock5:","6B7280"),await u(t,i,"s: 8h :clock8:","4B5563"),await u(t,i,"s: 13h :clock1:","374151"),await u(t,i,"t: build :hammer:","BFDBFE"),await u(t,i,"t: chore :broom:","BFDBFE"),await u(t,i,"t: ci :construction_worker:","BFDBFE"),await u(t,i,"t: docs :memo:","BFDBFE"),await u(t,i,"t: feat :sparkles:","BFDBFE"),await u(t,i,"t: fix :bug:","BFDBFE"),await u(t,i,"t: perf :zap:","BFDBFE"),await u(t,i,"t: refactor :recycle:","BFDBFE"),await u(t,i,"t: style :lipstick:","BFDBFE"),await u(t,i,"t: test :test_tube:","BFDBFE"),await u(t,i,"project","24292F"),await _(t,i,"bug"),await _(t,i,"documentation"),await _(t,i,"duplicate"),await _(t,i,"enhancement"),await _(t,i,"good first issue"),await _(t,i,"help wanted"),await _(t,i,"invalid"),await _(t,i,"question"),await _(t,i,"wontfix"),await _(t,i,"ready"),await _(t,i,"review requested"),await _(t,i,"released"),await _(t,i,"semantic-release")}catch(n){console.warn("Skip setupLabels due to:",(n==null?void 0:n.stack)??n)}})}async function u(e,t,i,n){try{await C.request("POST /repos/{owner}/{repo}/labels",{owner:e,repo:t,name:i,color:n})}catch{await C.request("PATCH /repos/{owner}/{repo}/labels/{name}",{owner:e,repo:t,name:i,color:n})}}async function _(e,t,i){try{await C.request("DELETE /repos/{owner}/{repo}/labels/{name}",{owner:e,repo:t,name:i})}catch{}}var Tt=c(require("dotenv")),D=c(require("libsodium-wrappers"));var hi=["READY_DISCORD_WEBHOOK_URL"];async function Et(e){return m.function("setupSecrets",async()=>{if(!re)return;let[t,i]=j.getOrgAndName(e.repository??"");if(!t||!i||t!=="WillBoosterLab")return;let n=Tt.default.config().parsed||{};if(Object.keys(n).length!==0)try{for(let o of hi)try{await C.request("DELETE /repos/{owner}/{repo}/actions/secrets/{secret_name}",{owner:t,repo:i,secret_name:o})}catch{}let s=await C.request("GET /repos/{owner}/{repo}/actions/secrets/public-key",{owner:t,repo:i}),{key:r,key_id:a}=s.data;await D.default.ready;for(let[o,l]of Object.entries(n)){if(e.publicRepo&&o==="GH_BOT_PAT"||!e.publicRepo&&o==="PUBLIC_GH_BOT_PAT")continue;let d=D.default.from_base64(r,D.default.base64_variants.ORIGINAL),f=D.default.from_string(l),h=D.default.crypto_box_seal(f,d),g=D.default.to_base64(h,D.default.base64_variants.ORIGINAL);await C.request("PUT /repos/{owner}/{repo}/actions/secrets/{secret_name}",{owner:t,repo:i,secret_name:o,encrypted_value:g,key_id:a})}}catch(s){console.warn("Skip setupSecrets due to:",(s==null?void 0:s.stack)??s)}})}async function jt(e){}var S=c(require("node:fs")),Y=c(require("node:fs/promises")),P=c(require("node:path")),B=c(require("glob")),Dt=c(require("js-yaml")),Bt=require("simple-git");async function Fe(e){var i;let t=P.default.resolve(e,"package.json");try{let n=S.default.existsSync(t),s={},r={},a={};if(n){let F=S.default.readFileSync(t,"utf8");a=JSON.parse(F),s=a.dependencies??{},r=a.devDependencies??{}}let o=!0;try{let F=P.default.resolve(e,".yarnrc.yml"),x=Dt.default.load(await Y.default.readFile(F,"utf8"));o=!x.nodeLinker||x.nodeLinker==="node-modules"}catch{}let l=[],d=[];try{let F=P.default.resolve(e,".releaserc.json"),x=JSON.parse(await Y.default.readFile(F,"utf8"));l=(x==null?void 0:x.branches)||[],d=((i=x==null?void 0:x.plugins)==null?void 0:i.flat())||[]}catch{}let f=P.default.basename(P.default.resolve(e,".."))!=="packages"||!S.default.existsSync(P.default.resolve(e,"..","..","package.json")),h;f&&(h=await Pi(e,a));let g;try{g=await Y.default.readFile(P.default.resolve(e,".tool-versions"),"utf8")}catch{try{g="nodejs "+(await Y.default.readFile(P.default.resolve(e,".node-version"),"utf8")).trim()}catch{}}let w={dirPath:e,root:f,publicRepo:(h==null?void 0:h.private)===!1,referred:!!a.files,repository:h!=null&&h.full_name?`github:${h==null?void 0:h.full_name}`:void 0,willBoosterConfigs:t.includes(`${P.default.sep}willbooster-configs`),containingSubPackageJsons:B.default.sync("packages/**/package.json",{cwd:e}).length>0,containingDockerfile:S.default.existsSync(P.default.resolve(e,"Dockerfile"))||S.default.existsSync(P.default.resolve(e,"docker-compose.yml")),containingGemfile:S.default.existsSync(P.default.resolve(e,"Gemfile")),containingGoMod:S.default.existsSync(P.default.resolve(e,"go.mod")),containingPackageJson:S.default.existsSync(P.default.resolve(e,"package.json")),containingPoetryLock:S.default.existsSync(P.default.resolve(e,"poetry.lock")),containingPomXml:S.default.existsSync(P.default.resolve(e,"pom.xml")),containingPubspecYaml:S.default.existsSync(P.default.resolve(e,"pubspec.yaml")),containingTemplateYaml:S.default.existsSync(P.default.resolve(e,"template.yaml")),containingJavaScript:B.default.sync("@(app|src|__tests__|scripts)/**/*.{cjs,mjs,js,jsx}",{cwd:e}).length>0,containingTypeScript:B.default.sync("@(app|src|__tests__|scripts)/**/*.{cts,mts,ts,tsx}",{cwd:e}).length>0,containingJsxOrTsx:B.default.sync("@(app|src|__tests__)/**/*.{t,j}sx",{cwd:e}).length>0,containingJavaScriptInPackages:B.default.sync("packages/**/@(app|src|__tests__|scripts)/**/*.{cjs,mjs,js,jsx}",{cwd:e}).length>0,containingTypeScriptInPackages:B.default.sync("packages/**/@(app|src|__tests__|scripts)/**/*.{cts,mts,ts,tsx}",{cwd:e}).length>0,containingJsxOrTsxInPackages:B.default.sync("packages/**/@(app|src|__tests__)/**/*.{t,j}sx",{cwd:e}).length>0,depending:{blitz:(s.blitz||r.blitz||"").replace("^","")[0],firebase:!!r["firebase-tools"],prisma:!!r.prisma,reactNative:!!s["react-native"],semanticRelease:!!(r["semantic-release"]||l.length>0||d.length>0),storybook:!!r["@storybook/react"]},release:{branches:l,github:d.includes("@semantic-release/github"),npm:d.includes("@semantic-release/npm")},requiringNodeModules:o,versionsText:g};if(w.eslintBase=wi(w),w.containingGemfile||w.containingGoMod||w.containingPackageJson||w.containingPoetryLock||w.containingPomXml||w.containingPubspecYaml||w.containingTemplateYaml)return w}catch{}}function wi(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 Pi(e,t){var o,l,d;let s=(await(0,Bt.simpleGit)(e).getRemotes(!0)).find(f=>f.name==="origin"),r=((o=s==null?void 0:s.refs)==null?void 0:o.fetch)??((l=s==null?void 0:s.refs)==null?void 0:l.push);if(typeof r=="string"){let f=await Ot(r);if(f)return f}let a=((d=t.repository)==null?void 0:d.url)??t.repository;if(typeof a=="string"){let f=await Ot(a);if(f&&f.message!=="Not Found")return f}}async function Ot(e){let[t,i]=j.getOrgAndName(e);if(!t||!i)return;let n={full_name:`${t}/${i}`};try{let s=await C.request("GET /repos/{owner}/{repo}",{owner:t,repo:i});Object.assign(n,s.data)}catch{}return n}async function vi(){let e=await(0,It.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;E.isVerbose=e.verbose;for(let t of e._){if(typeof t=="number")continue;let i=await Fe(t);if(!i){console.error(`there is no valid package.json in ${t}`);continue}let n=i.containingSubPackageJsons?Wt.default.sync("packages/*",{cwd:t}).map(l=>Nt.default.resolve(t,l)):[],r=(await Promise.all(n.map(l=>Fe(l)))).filter(l=>!!l),a=[i,...r];if(E.isVerbose)for(let l of a)console.info(l);await Te(i),await $t(i),await Promise.all([je(i),Ye(i),Ve(i),Xe(i),he(i),ct(i),gt(i),dt(i),St(i),Rt(i),Et(i),jt(i)]),await p.promiseAll();let o=[];for(let l of a)await qe(l,i),await p.promiseAll(),!(!l.root&&!l.containingPackageJson)&&(await at(l),await ot(l,i,e.skipDeps),o.push(he(l)),(l.containingTypeScript||l.containingTypeScriptInPackages)&&o.push(vt(l,i)),(l.containingJavaScript||l.containingJavaScriptInPackages||l.containingTypeScript||l.containingTypeScriptInPackages)&&(i.willBoosterConfigs||o.push(He(l,i)),o.push(Je(l))));await Promise.all(o),await p.promiseAll(),v("yarn",["cleanup"],t),v("yarn",["install"],t)}}vi().then();
273
273
  //# sourceMappingURL=index.min.cjs.map