@salty-css/core 0.0.1-alpha.17 → 0.0.1-alpha.18
Sign up to get free protection for your applications and to get access to all the features.
- package/bin/bin-util.d.ts +1 -1
- package/bin/index.cjs +5 -5
- package/bin/index.js +97 -87
- package/package.json +1 -1
package/bin/bin-util.d.ts
CHANGED
@@ -1,2 +1,2 @@
|
|
1
1
|
export declare const execAsync: (command: string) => Promise<void>;
|
2
|
-
export declare const npmInstall: (
|
2
|
+
export declare const npmInstall: (...packages: string[]) => Promise<void>;
|
package/bin/index.cjs
CHANGED
@@ -1,9 +1,9 @@
|
|
1
1
|
#!/usr/bin/env node
|
2
|
-
"use strict";const D=require("commander"),n=require("fs/promises"),t=require("path"),_=require("ejs"),N=require("../compiler/index.cjs"),O=require("../pascal-case-iWoaJWwT.cjs"),h=require("winston"),k=require("fs"),z=require("child_process"),o=h.createLogger({level:"debug",format:h.format.combine(h.format.colorize(),h.format.cli()),transports:[new h.transports.Console({})]}),E=a=>new Promise((g,y)=>{z.exec(a,j=>{if(j)return y(j);g()})}),q=async a=>{await E(`npm install ${a}`)},J=()=>k.existsSync(t.join(process.cwd(),"node_modules",".bin","prettier"));async function v(a){try{if(!J())return;await E(`./node_modules/.bin/prettier --write "${a}"`),o.info(`Formatted ${a} with Prettier`)}catch(g){o.error(`Error formatting ${a} with Prettier:`,g)}}async function A(){const a=new D.Command;a.name("salty-css").description("Salty-CSS CLI tool to help with annoying configuration tasks.");const g={"salty.config.ts":Promise.resolve().then(()=>require("../salty.config-BupieCfE.cjs")),"saltygen/index.css":Promise.resolve().then(()=>require("../index-84Wroia-.cjs")),"react/react-styled-file.ts":Promise.resolve().then(()=>require("../react-styled-file-Dkubsz-U.cjs"))},y=async(r,l)=>{const{default:f}=await g[r],c=_.render(f,l);return{fileName:r,content:c}},j=async()=>{const r=t.join(process.cwd(),".saltyrc");return await n.readFile(r,"utf-8").then(JSON.parse).catch(()=>({}))},b=await(async()=>(await j()).defaultProject)();a.command("init").description("Initialize a new Salty-CSS project.").requiredOption("-d, --dir <dir>","Project directory to initialize the project in.").option("--css-file <css-file>","Existing CSS file where to import the generated CSS. Path must be relative to the given project directory.").action(async function(){o.info("Installing salty-css packages core, eslint-plugin and react"),await q("@salty-css/core @salty-css/react"),await q("-D @salty-css/eslint-plugin-core"),o.info("Initializing a new Salty-CSS project...");const{dir:r,cssFile:l}=this.opts(),f=process.cwd(),c=t.join(f,r),C=await Promise.all([y("salty.config.ts"),y("saltygen/index.css")]);await n.mkdir(c,{recursive:!0});const F=C.map(async({fileName:e,content:s})=>{const d=t.join(c,e);if(await n.readFile(d,"utf-8").catch(()=>{})!==void 0){o.debug("File already exists: "+d);return}const I=e.split("/").slice(0,-1).join("/");I&&await n.mkdir(t.join(c,I),{recursive:!0}),o.info("Writing file: "+d),await n.writeFile(d,s),await v(d)});await Promise.all(F);const m=t.relative(f,c),i=t.join(f,".saltyrc"),p=await n.readFile(i,"utf-8").catch(()=>{});if(p===void 0){o.info("Creating file: "+i);const s=JSON.stringify({defaultProject:m,projects:[m]},null,2);await n.writeFile(i,s)}else{o.info("Edit file: "+i);const e=JSON.parse(p),s=new Set((e==null?void 0:e.projects)||[]);s.add(m),e.projects=[...s];const d=JSON.stringify(e,null,2);await n.writeFile(i,d)}const S=t.join(f,".gitignore"),w=await n.readFile(S,"utf-8").catch(()=>{});if(w!==void 0&&(w.includes("saltygen")||(o.info("Edit file: "+S),await n.writeFile(S,w+`
|
2
|
+
"use strict";const J=require("commander"),C=require("fs/promises"),g=require("path"),Q=require("ejs"),S=require("../compiler/index.cjs"),z=require("../pascal-case-iWoaJWwT.cjs"),p=require("winston"),j=require("fs"),U=require("child_process");var H=typeof document<"u"?document.currentScript:null;const l=p.createLogger({level:"debug",format:p.format.combine(p.format.colorize(),p.format.cli()),transports:[new p.transports.Console({})]}),F=n=>new Promise((e,G)=>{U.exec(n,W=>{if(W)return G(W);e()})}),X=async(...n)=>{const e=n.join(" ");await F(`npm install ${e}`)},k=()=>j.existsSync(g.join(process.cwd(),"node_modules",".bin","prettier"));async function u(n){try{if(!k())return;await F(`./node_modules/.bin/prettier --write "${n}"`),l.info(`Formatted ${n} with Prettier`)}catch(e){l.error(`Error formatting ${n} with Prettier:`,e)}}const x=new URL("data:video/mp2t;base64,IyEvdXNyL2Jpbi9lbnYgbm9kZQppbXBvcnQgeyBDb21tYW5kIH0gZnJvbSAnY29tbWFuZGVyJzsKaW1wb3J0IHsgcmVhZEZpbGUsIHdyaXRlRmlsZSwgbWtkaXIgfSBmcm9tICdmcy9wcm9taXNlcyc7CmltcG9ydCB7IGpvaW4sIHJlbGF0aXZlLCBwYXJzZSBhcyBwYXJzZVBhdGgsIGZvcm1hdCBhcyBmb3JtYXRQYXRoIH0gZnJvbSAncGF0aCc7CmltcG9ydCB7IHJlbmRlciB9IGZyb20gJ2Vqcyc7CmltcG9ydCB7IGdlbmVyYXRlQ3NzIH0gZnJvbSAnLi4vY29tcGlsZXInOwppbXBvcnQgeyBwYXNjYWxDYXNlIH0gZnJvbSAnLi4vdXRpbCc7CmltcG9ydCB7IGxvZ2dlciB9IGZyb20gJy4vbG9nZ2VyJzsKaW1wb3J0IHsgZm9ybWF0V2l0aFByZXR0aWVyIH0gZnJvbSAnLi9wcmV0dGllcic7CmltcG9ydCB7IG5wbUluc3RhbGwgfSBmcm9tICcuL2Jpbi11dGlsJzsKCmNvbnN0IF9fZGlybmFtZSA9IG5ldyBVUkwoJy4nLCBpbXBvcnQubWV0YS51cmwpLnBhdGhuYW1lOwoKYXN5bmMgZnVuY3Rpb24gbWFpbigpIHsKICBjb25zdCBwcm9ncmFtID0gbmV3IENvbW1hbmQoKTsKCiAgcHJvZ3JhbS5uYW1lKCdzYWx0eS1jc3MnKS5kZXNjcmlwdGlvbignU2FsdHktQ1NTIENMSSB0b29sIHRvIGhlbHAgd2l0aCBhbm5veWluZyBjb25maWd1cmF0aW9uIHRhc2tzLicpOwoKICBjb25zdCBmaWxlcyA9IHsKICAgIC8vIENvcmUgZmlsZXMKICAgICdzYWx0eS5jb25maWcudHMnOiBpbXBvcnQoJy4vdGVtcGxhdGVzL3NhbHR5LmNvbmZpZy50c19fdGVtcGxhdGUnKSwKICAgICdzYWx0eWdlbi9pbmRleC5jc3MnOiBpbXBvcnQoJy4vdGVtcGxhdGVzL2luZGV4LmNzc19fdGVtcGxhdGUnKSwKICAgIC8vIFJlYWN0CiAgICAncmVhY3QvcmVhY3Qtc3R5bGVkLWZpbGUudHMnOiBpbXBvcnQoJy4vdGVtcGxhdGVzL3JlYWN0LXN0eWxlZC1maWxlLnRzX190ZW1wbGF0ZScpLAogIH0gYXMgY29uc3Q7CgogIHR5cGUgVGVtcGxhdGUgPSBrZXlvZiB0eXBlb2YgZmlsZXM7CgogIGNvbnN0IHJlYWRUZW1wbGF0ZSA9IGFzeW5jIDxUIGV4dGVuZHMgb2JqZWN0PihmaWxlTmFtZTogVGVtcGxhdGUsIG9wdGlvbnM/OiBUKSA9PiB7CiAgICBjb25zdCB7IGRlZmF1bHQ6IGZpbGUgfSA9IGF3YWl0IGZpbGVzW2ZpbGVOYW1lXTsKICAgIGNvbnN0IGNvbnRlbnQgPSByZW5kZXIoZmlsZSwgb3B0aW9ucyk7CiAgICByZXR1cm4geyBmaWxlTmFtZSwgY29udGVudCB9OwogIH07CgogIGludGVyZmFjZSBSQ0ZpbGUgewogICAgZGVmYXVsdFByb2plY3Q6IHN0cmluZzsKICAgIHByb2plY3RzOiBzdHJpbmdbXTsKICB9CgogIGNvbnN0IHJlYWRSQ0ZpbGUgPSBhc3luYyAoKSA9PiB7CiAgICBjb25zdCByY1BhdGggPSBqb2luKHByb2Nlc3MuY3dkKCksICcuc2FsdHlyYycpOwogICAgY29uc3QgcmNDb250ZW50ID0gYXdhaXQgcmVhZEZpbGUocmNQYXRoLCAndXRmLTgnKQogICAgICAudGhlbihKU09OLnBhcnNlKQogICAgICAuY2F0Y2goKCkgPT4gKHt9KSk7CgogICAgcmV0dXJuIHJjQ29udGVudCBhcyBSQ0ZpbGU7CiAgfTsKCiAgY29uc3QgcmVhZFRoaXNQYWNrYWdlSnNvbiA9IGFzeW5jICgpID0+IHsKICAgIGNvbnN0IHBhY2thZ2VKc29uUGF0aCA9IGpvaW4oX19kaXJuYW1lLCAnLi4vcGFja2FnZS5qc29uJyk7CiAgICBjb25zdCBwYWNrYWdlSnNvbkNvbnRlbnQgPSBhd2FpdCByZWFkRmlsZShwYWNrYWdlSnNvblBhdGgsICd1dGYtOCcpCiAgICAgIC50aGVuKEpTT04ucGFyc2UpCiAgICAgIC5jYXRjaCgoKSA9PiAoe30pKTsKCiAgICByZXR1cm4gcGFja2FnZUpzb25Db250ZW50OwogIH07CgogIGNvbnN0IHJlYWRQYWNrYWdlSnNvbiA9IGFzeW5jIChwcm9qZWN0RGlyOiBzdHJpbmcpID0+IHsKICAgIGNvbnN0IHBhY2thZ2VKc29uUGF0aCA9IGpvaW4ocHJvamVjdERpciwgJ3BhY2thZ2UuanNvbicpOwogICAgY29uc3QgcGFja2FnZUpzb25Db250ZW50ID0gYXdhaXQgcmVhZEZpbGUocGFja2FnZUpzb25QYXRoLCAndXRmLTgnKQogICAgICAudGhlbihKU09OLnBhcnNlKQogICAgICAuY2F0Y2goKCkgPT4gKHt9KSk7CgogICAgcmV0dXJuIHBhY2thZ2VKc29uQ29udGVudDsKICB9OwoKICBjb25zdCBnZXREZWZhdWx0UHJvamVjdCA9IGFzeW5jICgpID0+IHsKICAgIGNvbnN0IHJjQ29udGVudCA9IGF3YWl0IHJlYWRSQ0ZpbGUoKTsKICAgIHJldHVybiByY0NvbnRlbnQuZGVmYXVsdFByb2plY3Q7CiAgfTsKCiAgY29uc3QgZGVmYXVsdFByb2plY3QgPSBhd2FpdCBnZXREZWZhdWx0UHJvamVjdCgpOwoKICBpbnRlcmZhY2UgSW5pdE9wdGlvbnMgewogICAgZGlyOiBzdHJpbmc7CiAgICBjc3NGaWxlPzogc3RyaW5nOwogIH0KCiAgY29uc3QgY3VycmVudFBhY2thZ2VKc29uID0gYXdhaXQgcmVhZFRoaXNQYWNrYWdlSnNvbigpOwoKICBjb25zdCBwYWNrYWdlcyA9IHsKICAgIGNvcmU6IGBAc2FsdHktY3NzL2NvcmVAJHtjdXJyZW50UGFja2FnZUpzb24udmVyc2lvbn1gLAogICAgcmVhY3Q6IGBAc2FsdHktY3NzL3JlYWN0QCR7Y3VycmVudFBhY2thZ2VKc29uLnZlcnNpb259YCwKICAgIGVzbGludFBsdWdpbkNvcmU6IGBAc2FsdHktY3NzL2VzbGludC1wbHVnaW4tY29yZUAke2N1cnJlbnRQYWNrYWdlSnNvbi52ZXJzaW9ufWAsCiAgICB2aXRlOiBgQHNhbHR5LWNzcy92aXRlQCR7Y3VycmVudFBhY2thZ2VKc29uLnZlcnNpb259YCwKICB9OwoKICBwcm9ncmFtCiAgICAuY29tbWFuZCgnaW5pdCcpCiAgICAuZGVzY3JpcHRpb24oJ0luaXRpYWxpemUgYSBuZXcgU2FsdHktQ1NTIHByb2plY3QuJykKICAgIC5yZXF1aXJlZE9wdGlvbignLWQsIC0tZGlyIDxkaXI+JywgJ1Byb2plY3QgZGlyZWN0b3J5IHRvIGluaXRpYWxpemUgdGhlIHByb2plY3QgaW4uJykKICAgIC5vcHRpb24oJy0tY3NzLWZpbGUgPGNzcy1maWxlPicsICdFeGlzdGluZyBDU1MgZmlsZSB3aGVyZSB0byBpbXBvcnQgdGhlIGdlbmVyYXRlZCBDU1MuIFBhdGggbXVzdCBiZSByZWxhdGl2ZSB0byB0aGUgZ2l2ZW4gcHJvamVjdCBkaXJlY3RvcnkuJykKICAgIC8vIFZhbGlkYXRlIHRoYXQgYWxsIG9wdGlvbnMgYXJlIHByb3ZpZGVkCiAgICAuYWN0aW9uKGFzeW5jIGZ1bmN0aW9uICh0aGlzOiBDb21tYW5kKSB7CiAgICAgIGxvZ2dlci5pbmZvKCdJbnN0YWxsaW5nIHNhbHR5LWNzcyBwYWNrYWdlcyBjb3JlLCBlc2xpbnQtcGx1Z2luIGFuZCByZWFjdCcpOwogICAgICBhd2FpdCBucG1JbnN0YWxsKHBhY2thZ2VzLmNvcmUsIHBhY2thZ2VzLnJlYWN0KTsKICAgICAgYXdhaXQgbnBtSW5zdGFsbChgLUQgJHtwYWNrYWdlcy5lc2xpbnRQbHVnaW5Db3JlfWApOwoKICAgICAgbG9nZ2VyLmluZm8oJ0luaXRpYWxpemluZyBhIG5ldyBTYWx0eS1DU1MgcHJvamVjdC4uLicpOwoKICAgICAgY29uc3QgeyBkaXIsIGNzc0ZpbGUgfSA9IHRoaXMub3B0czxJbml0T3B0aW9ucz4oKTsKICAgICAgY29uc3Qgcm9vdERpciA9IHByb2Nlc3MuY3dkKCk7CiAgICAgIGNvbnN0IHByb2plY3REaXIgPSBqb2luKHJvb3REaXIsIGRpcik7CiAgICAgIGNvbnN0IHByb2plY3RGaWxlcyA9IGF3YWl0IFByb21pc2UuYWxsKFtyZWFkVGVtcGxhdGUoJ3NhbHR5LmNvbmZpZy50cycpLCByZWFkVGVtcGxhdGUoJ3NhbHR5Z2VuL2luZGV4LmNzcycpXSk7CgogICAgICAvLyBDcmVhdGUgdGhlIHByb2plY3Qgc3RydWN0dXJlIGlmIGl0IGRvZXNuJ3QgZXhpc3QKICAgICAgYXdhaXQgbWtkaXIocHJvamVjdERpciwgeyByZWN1cnNpdmU6IHRydWUgfSk7CiAgICAgIGNvbnN0IHdyaXRlRmlsZXMgPSBwcm9qZWN0RmlsZXMubWFwKGFzeW5jICh7IGZpbGVOYW1lLCBjb250ZW50IH0pID0+IHsKICAgICAgICBjb25zdCBmaWxlUGF0aCA9IGpvaW4ocHJvamVjdERpciwgZmlsZU5hbWUpOwogICAgICAgIGNvbnN0IGV4aXN0aW5nQ29udGVudCA9IGF3YWl0IHJlYWRGaWxlKGZpbGVQYXRoLCAndXRmLTgnKS5jYXRjaCgoKSA9PiB1bmRlZmluZWQpOwogICAgICAgIGlmIChleGlzdGluZ0NvbnRlbnQgIT09IHVuZGVmaW5lZCkgewogICAgICAgICAgbG9nZ2VyLmRlYnVnKCdGaWxlIGFscmVhZHkgZXhpc3RzOiAnICsgZmlsZVBhdGgpOwogICAgICAgICAgcmV0dXJuOwogICAgICAgIH0KICAgICAgICBjb25zdCBhZGRpdGlvbmFsRm9sZGVycyA9IGZpbGVOYW1lLnNwbGl0KCcvJykuc2xpY2UoMCwgLTEpLmpvaW4oJy8nKTsKICAgICAgICAvLyBDcmVhdGUgYWRkaXRpb25hbCBmb2xkZXJzIGlmIHRoZXkgZG9uJ3QgZXhpc3QKICAgICAgICBpZiAoYWRkaXRpb25hbEZvbGRlcnMpIGF3YWl0IG1rZGlyKGpvaW4ocHJvamVjdERpciwgYWRkaXRpb25hbEZvbGRlcnMpLCB7IHJlY3Vyc2l2ZTogdHJ1ZSB9KTsKICAgICAgICBsb2dnZXIuaW5mbygnV3JpdGluZyBmaWxlOiAnICsgZmlsZVBhdGgpOwogICAgICAgIGF3YWl0IHdyaXRlRmlsZShmaWxlUGF0aCwgY29udGVudCk7CiAgICAgICAgYXdhaXQgZm9ybWF0V2l0aFByZXR0aWVyKGZpbGVQYXRoKTsKICAgICAgfSk7CgogICAgICBhd2FpdCBQcm9taXNlLmFsbCh3cml0ZUZpbGVzKTsKCiAgICAgIC8vIENyZWF0ZSBzYWx0eXJjIGZpbGUKICAgICAgY29uc3QgcmVsYXRpdmVQcm9qZWN0UGF0aCA9IHJlbGF0aXZlKHJvb3REaXIsIHByb2plY3REaXIpOwogICAgICBjb25zdCBzYWx0eXJjUGF0aCA9IGpvaW4ocm9vdERpciwgJy5zYWx0eXJjJyk7CiAgICAgIGNvbnN0IGV4aXN0aW5nU2FsdHlyYyA9IGF3YWl0IHJlYWRGaWxlKHNhbHR5cmNQYXRoLCAndXRmLTgnKS5jYXRjaCgoKSA9PiB1bmRlZmluZWQpOwogICAgICBpZiAoZXhpc3RpbmdTYWx0eXJjID09PSB1bmRlZmluZWQpIHsKICAgICAgICBsb2dnZXIuaW5mbygnQ3JlYXRpbmcgZmlsZTogJyArIHNhbHR5cmNQYXRoKTsKICAgICAgICBjb25zdCByY0NvbnRlbnQgPSB7CiAgICAgICAgICBkZWZhdWx0UHJvamVjdDogcmVsYXRpdmVQcm9qZWN0UGF0aCwKICAgICAgICAgIHByb2plY3RzOiBbcmVsYXRpdmVQcm9qZWN0UGF0aF0sCiAgICAgICAgfTsKICAgICAgICBjb25zdCBjb250ZW50ID0gSlNPTi5zdHJpbmdpZnkocmNDb250ZW50LCBudWxsLCAyKTsKICAgICAgICBhd2FpdCB3cml0ZUZpbGUoc2FsdHlyY1BhdGgsIGNvbnRlbnQpOwogICAgICB9IGVsc2UgewogICAgICAgIGxvZ2dlci5pbmZvKCdFZGl0IGZpbGU6ICcgKyBzYWx0eXJjUGF0aCk7CiAgICAgICAgY29uc3QgcmNDb250ZW50ID0gSlNPTi5wYXJzZShleGlzdGluZ1NhbHR5cmMpOwogICAgICAgIGNvbnN0IHByb2plY3RzID0gbmV3IFNldChyY0NvbnRlbnQ/LnByb2plY3RzIHx8IFtdKTsKICAgICAgICBwcm9qZWN0cy5hZGQocmVsYXRpdmVQcm9qZWN0UGF0aCk7CiAgICAgICAgcmNDb250ZW50LnByb2plY3RzID0gWy4uLnByb2plY3RzXTsKICAgICAgICBjb25zdCBjb250ZW50ID0gSlNPTi5zdHJpbmdpZnkocmNDb250ZW50LCBudWxsLCAyKTsKICAgICAgICBhd2FpdCB3cml0ZUZpbGUoc2FsdHlyY1BhdGgsIGNvbnRlbnQpOwogICAgICB9CgogICAgICAvLyBFZGl0IGZpbGVzIGluIHRoZSBwcm9qZWN0CgogICAgICAvLyBFZGl0IEdpdGlnbm9yZQogICAgICBjb25zdCBnaXRJZ25vcmVQYXRoID0gam9pbihyb290RGlyLCAnLmdpdGlnbm9yZScpOwogICAgICBjb25zdCBnaXRJZ25vcmVDb250ZW50ID0gYXdhaXQgcmVhZEZpbGUoZ2l0SWdub3JlUGF0aCwgJ3V0Zi04JykuY2F0Y2goKCkgPT4gdW5kZWZpbmVkKTsKICAgICAgaWYgKGdpdElnbm9yZUNvbnRlbnQgIT09IHVuZGVmaW5lZCkgewogICAgICAgIGNvbnN0IGFscmVhZHlJZ25vcmVzU2FsdHlnZW4gPSBnaXRJZ25vcmVDb250ZW50LmluY2x1ZGVzKCdzYWx0eWdlbicpOwogICAgICAgIGlmICghYWxyZWFkeUlnbm9yZXNTYWx0eWdlbikgewogICAgICAgICAgbG9nZ2VyLmluZm8oJ0VkaXQgZmlsZTogJyArIGdpdElnbm9yZVBhdGgpOwogICAgICAgICAgYXdhaXQgd3JpdGVGaWxlKGdpdElnbm9yZVBhdGgsIGdpdElnbm9yZUNvbnRlbnQgKyAnXG5cbiMgU2FsdHktQ1NTXG5zYWx0eWdlblxuJyk7CiAgICAgICAgfQogICAgICB9CgogICAgICAvLyBFZGl0IHRoZSBDU1MgZmlsZSBpZiBwcm92aWRlZAogICAgICBpZiAoY3NzRmlsZSkgewogICAgICAgIGNvbnN0IGNzc0ZpbGVQYXRoID0gam9pbihwcm9qZWN0RGlyLCBjc3NGaWxlKTsKICAgICAgICBjb25zdCBjc3NGaWxlQ29udGVudCA9IGF3YWl0IHJlYWRGaWxlKGNzc0ZpbGVQYXRoLCAndXRmLTgnKS5jYXRjaCgoKSA9PiB1bmRlZmluZWQpOwogICAgICAgIGlmIChjc3NGaWxlQ29udGVudCAhPT0gdW5kZWZpbmVkKSB7CiAgICAgICAgICBjb25zdCBhbHJlYWR5SW1wb3J0c1NhbHR5Z2VuID0gY3NzRmlsZUNvbnRlbnQuaW5jbHVkZXMoJ3NhbHR5Z2VuJyk7CiAgICAgICAgICBpZiAoIWFscmVhZHlJbXBvcnRzU2FsdHlnZW4pIHsKICAgICAgICAgICAgY29uc3QgY3NzRmlsZUZvbGRlciA9IGpvaW4oY3NzRmlsZVBhdGgsICcuLicpOwogICAgICAgICAgICBjb25zdCByZWxhdGl2ZVBhdGggPSByZWxhdGl2ZShjc3NGaWxlRm9sZGVyLCBqb2luKHByb2plY3REaXIsICdzYWx0eWdlbi9pbmRleC5jc3MnKSk7CiAgICAgICAgICAgIGNvbnN0IGltcG9ydFN0YXRlbWVudCA9IGBAaW1wb3J0ICcke3JlbGF0aXZlUGF0aH0nO2A7CiAgICAgICAgICAgIGxvZ2dlci5pbmZvKCdFZGl0IGZpbGU6ICcgKyBjc3NGaWxlUGF0aCk7CiAgICAgICAgICAgIGF3YWl0IHdyaXRlRmlsZShjc3NGaWxlUGF0aCwgaW1wb3J0U3RhdGVtZW50ICsgJ1xuJyArIGNzc0ZpbGVDb250ZW50KTsKICAgICAgICAgICAgYXdhaXQgZm9ybWF0V2l0aFByZXR0aWVyKGNzc0ZpbGVQYXRoKTsKICAgICAgICAgIH0KICAgICAgICB9CiAgICAgIH0KCiAgICAgIC8vIEZyYW1ld29yayAvIGJ1aWxkIHRvb2wgc3BlY2lmaWMgZmlsZXMKCiAgICAgIC8vIERldGVjdCB2aXRlIGFuZCBhZGQgdGhlIHBsdWdpbgogICAgICBjb25zdCB2aXRlQ29uZmlnUGF0aCA9IGpvaW4ocHJvamVjdERpciwgJ3ZpdGUuY29uZmlnLnRzJyk7CiAgICAgIGNvbnN0IHZpdGVDb25maWdDb250ZW50ID0gYXdhaXQgcmVhZEZpbGUodml0ZUNvbmZpZ1BhdGgsICd1dGYtOCcpLmNhdGNoKCgpID0+IHVuZGVmaW5lZCk7CgogICAgICBpZiAodml0ZUNvbmZpZ0NvbnRlbnQgIT09IHVuZGVmaW5lZCkgewogICAgICAgIGNvbnN0IGFscmVhZHlIYXNQbHVnaW4gPSB2aXRlQ29uZmlnQ29udGVudC5pbmNsdWRlcygnc2FsdHlQbHVnaW4nKTsKICAgICAgICBpZiAoIWFscmVhZHlIYXNQbHVnaW4pIHsKICAgICAgICAgIGxvZ2dlci5pbmZvKCdFZGl0IGZpbGU6ICcgKyB2aXRlQ29uZmlnUGF0aCk7CiAgICAgICAgICBjb25zdCBwbHVnaW5JbXBvcnQgPSAiaW1wb3J0IHsgc2FsdHlQbHVnaW4gfSBmcm9tICdAc2FsdHktY3NzL3ZpdGUnO1xuIjsKICAgICAgICAgIGNvbnN0IHBsdWdpbkNvbmZpZyA9ICdzYWx0eVBsdWdpbihfX2Rpcm5hbWUpLCc7CiAgICAgICAgICBjb25zdCBuZXdDb250ZW50ID0gdml0ZUNvbmZpZ0NvbnRlbnQucmVwbGFjZSgvKHBsdWdpbnM6IFxbKS8sIGAkMVxuICAke3BsdWdpbkNvbmZpZ31gKTsKCiAgICAgICAgICBsb2dnZXIuaW5mbygnSW5zdGFsbGluZyBAc2FsdHktY3NzL3ZpdGUnKTsKICAgICAgICAgIGF3YWl0IG5wbUluc3RhbGwocGFja2FnZXMudml0ZSk7CgogICAgICAgICAgbG9nZ2VyLmluZm8oJ0FkZGluZyBTYWx0eS1DU1MgcGx1Z2luIHRvIFZpdGUgY29uZmlnLi4uJyk7CiAgICAgICAgICBhd2FpdCB3cml0ZUZpbGUodml0ZUNvbmZpZ1BhdGgsIHBsdWdpbkltcG9ydCArIG5ld0NvbnRlbnQpOwogICAgICAgICAgYXdhaXQgZm9ybWF0V2l0aFByZXR0aWVyKHZpdGVDb25maWdQYXRoKTsKICAgICAgICB9CiAgICAgIH0KICAgIH0pOwoKICBpbnRlcmZhY2UgQnVpbGRPcHRpb25zIHsKICAgIGRpcjogc3RyaW5nOwogIH0KCiAgcHJvZ3JhbQogICAgLmNvbW1hbmQoJ2J1aWxkJykKICAgIC5hbGlhcygnYicpCiAgICAuZGVzY3JpcHRpb24oJ0J1aWxkIHRoZSBTYWx0eS1DU1MgcHJvamVjdC4nKQogICAgLm9wdGlvbignLWQsIC0tZGlyIDxkaXI+JywgJ1Byb2plY3QgZGlyZWN0b3J5IHRvIGJ1aWxkIHRoZSBwcm9qZWN0IGluLicsIGRlZmF1bHRQcm9qZWN0KQogICAgLmFjdGlvbihhc3luYyBmdW5jdGlvbiAodGhpczogQ29tbWFuZCkgewogICAgICBsb2dnZXIuaW5mbygnQnVpbGRpbmcgdGhlIFNhbHR5LUNTUyBwcm9qZWN0Li4uJyk7CiAgICAgIGNvbnN0IHsgZGlyIH0gPSB0aGlzLm9wdHM8QnVpbGRPcHRpb25zPigpOwogICAgICBjb25zdCBwcm9qZWN0RGlyID0gam9pbihwcm9jZXNzLmN3ZCgpLCBkaXIpOwogICAgICBhd2FpdCBnZW5lcmF0ZUNzcyhwcm9qZWN0RGlyKTsKICAgIH0pOwoKICBpbnRlcmZhY2UgR2VuZXJhdGVPcHRpb25zIHsKICAgIGRpcjogc3RyaW5nOwogICAgdGFnOiBzdHJpbmc7CiAgICBuYW1lPzogc3RyaW5nOwogICAgY2xhc3NOYW1lPzogc3RyaW5nOwogIH0KCiAgcHJvZ3JhbQogICAgLmNvbW1hbmQoJ2dlbmVyYXRlIDxmaWxlPicpCiAgICAuYWxpYXMoJ2cnKQogICAgLmRlc2NyaXB0aW9uKCdHZW5lcmF0ZSBhIG5ldyBjb21wb25lbnQgZmlsZS4nKQogICAgLm9wdGlvbignLWQsIC0tZGlyIDxkaXI+JywgJ1Byb2plY3QgZGlyZWN0b3J5IHRvIGdlbmVyYXRlIHRoZSBmaWxlIGluLicsIGRlZmF1bHRQcm9qZWN0KQogICAgLm9wdGlvbignLXQsIC0tdGFnIDx0YWc+JywgJ0hUTUwgdGFnIG9mIHRoZSBjb21wb25lbnQuJywgJ2RpdicpCiAgICAub3B0aW9uKCctbiwgLS1uYW1lIDxuYW1lPicsICdOYW1lIG9mIHRoZSBjb21wb25lbnQuJykKICAgIC5vcHRpb24oJy1jLCAtLWNsYXNzTmFtZSA8Y2xhc3NOYW1lPicsICdDU1MgY2xhc3Mgb2YgdGhlIGNvbXBvbmVudC4nKQogICAgLmFjdGlvbihhc3luYyBmdW5jdGlvbiAodGhpczogQ29tbWFuZCwgZmlsZTogc3RyaW5nKSB7CiAgICAgIGNvbnN0IHsgZGlyLCB0YWcsIG5hbWUsIGNsYXNzTmFtZSB9ID0gdGhpcy5vcHRzPEdlbmVyYXRlT3B0aW9ucz4oKTsKICAgICAgY29uc3QgcHJvamVjdERpciA9IGpvaW4ocHJvY2Vzcy5jd2QoKSwgZGlyKTsKICAgICAgY29uc3QgZmlsZVBhdGggPSBqb2luKHByb2plY3REaXIsIGZpbGUpOwoKICAgICAgY29uc3QgcGFyc2VkRmlsZVBhdGggPSBwYXJzZVBhdGgoZmlsZVBhdGgpOwogICAgICBpZiAoIXBhcnNlZEZpbGVQYXRoLmV4dCkgewogICAgICAgIHBhcnNlZEZpbGVQYXRoLmV4dCA9ICcudHMnOwogICAgICB9CiAgICAgIGlmICghcGFyc2VkRmlsZVBhdGgubmFtZS5lbmRzV2l0aCgnLmNzcycpKSB7CiAgICAgICAgcGFyc2VkRmlsZVBhdGgubmFtZSA9IHBhcnNlZEZpbGVQYXRoLm5hbWUgKyAnLmNzcyc7CiAgICAgIH0KICAgICAgcGFyc2VkRmlsZVBhdGguYmFzZSA9IHBhcnNlZEZpbGVQYXRoLm5hbWUgKyBwYXJzZWRGaWxlUGF0aC5leHQ7CiAgICAgIGNvbnN0IGZvcm1hdHRlZEZpbGVQYXRoID0gZm9ybWF0UGF0aChwYXJzZWRGaWxlUGF0aCk7CgogICAgICBjb25zdCBhbHJlYWR5RXhpc3RzID0gYXdhaXQgcmVhZEZpbGUoZm9ybWF0dGVkRmlsZVBhdGgsICd1dGYtOCcpLmNhdGNoKCgpID0+IHVuZGVmaW5lZCk7CiAgICAgIGlmIChhbHJlYWR5RXhpc3RzICE9PSB1bmRlZmluZWQpIHsKICAgICAgICBsb2dnZXIuZXJyb3IoJ0ZpbGUgYWxyZWFkeSBleGlzdHM6JywgZm9ybWF0dGVkRmlsZVBhdGgpOwogICAgICAgIHJldHVybjsKICAgICAgfQogICAgICBsb2dnZXIuaW5mbygnR2VuZXJhdGluZyBhIG5ldyBmaWxlOiAnICsgZm9ybWF0dGVkRmlsZVBhdGgpOwoKICAgICAgY29uc3QgX25hbWUgPSBwYXNjYWxDYXNlKG5hbWUgfHwgcGFyc2VkRmlsZVBhdGguYmFzZS5yZXBsYWNlKC9cLmNzc1wuXHcrJC8sICcnKSk7CiAgICAgIGNvbnN0IHsgY29udGVudCB9ID0gYXdhaXQgcmVhZFRlbXBsYXRlKCdyZWFjdC9yZWFjdC1zdHlsZWQtZmlsZS50cycsIHsgdGFnLCBuYW1lOiBfbmFtZSwgY2xhc3NOYW1lIH0pOwogICAgICBhd2FpdCB3cml0ZUZpbGUoZm9ybWF0dGVkRmlsZVBhdGgsIGNvbnRlbnQpOwoKICAgICAgYXdhaXQgZm9ybWF0V2l0aFByZXR0aWVyKGZvcm1hdHRlZEZpbGVQYXRoKTsKICAgIH0pOwoKICBwcm9ncmFtLnBhcnNlQXN5bmMocHJvY2Vzcy5hcmd2KTsKfQoKbWFpbigpLmNhdGNoKChlKSA9PiBjb25zb2xlLmVycm9yKGUpKTsK",typeof document>"u"?require("url").pathToFileURL(__filename).href:H&&H.tagName.toUpperCase()==="SCRIPT"&&H.src||new URL("bin/index.cjs",document.baseURI).href).pathname;async function L(){const n=new J.Command;n.name("salty-css").description("Salty-CSS CLI tool to help with annoying configuration tasks.");const e={"salty.config.ts":Promise.resolve().then(()=>require("../salty.config-BupieCfE.cjs")),"saltygen/index.css":Promise.resolve().then(()=>require("../index-84Wroia-.cjs")),"react/react-styled-file.ts":Promise.resolve().then(()=>require("../react-styled-file-Dkubsz-U.cjs"))},G=async(t,o)=>{const{default:s}=await e[t],i=Q.render(s,o);return{fileName:t,content:i}},W=async()=>{const t=g.join(process.cwd(),".saltyrc");return await C.readFile(t,"utf-8").then(JSON.parse).catch(()=>({}))},w=async()=>{const t=g.join(x,"../package.json");return await C.readFile(t,"utf-8").then(JSON.parse).catch(()=>({}))},v=await(async()=>(await W()).defaultProject)(),B=await w(),y={core:`@salty-css/core@${B.version}`,react:`@salty-css/react@${B.version}`,eslintPluginCore:`@salty-css/eslint-plugin-core@${B.version}`,vite:`@salty-css/vite@${B.version}`};n.command("init").description("Initialize a new Salty-CSS project.").requiredOption("-d, --dir <dir>","Project directory to initialize the project in.").option("--css-file <css-file>","Existing CSS file where to import the generated CSS. Path must be relative to the given project directory.").action(async function(){l.info("Installing salty-css packages core, eslint-plugin and react"),await X(y.core,y.react),await X(`-D ${y.eslintPluginCore}`),l.info("Initializing a new Salty-CSS project...");const{dir:t,cssFile:o}=this.opts(),s=process.cwd(),i=g.join(s,t),h=await Promise.all([G("salty.config.ts"),G("saltygen/index.css")]);await C.mkdir(i,{recursive:!0});const R=h.map(async({fileName:I,content:a})=>{const d=g.join(i,I);if(await C.readFile(d,"utf-8").catch(()=>{})!==void 0){l.debug("File already exists: "+d);return}const V=I.split("/").slice(0,-1).join("/");V&&await C.mkdir(g.join(i,V),{recursive:!0}),l.info("Writing file: "+d),await C.writeFile(d,a),await u(d)});await Promise.all(R);const m=g.relative(s,i),c=g.join(s,".saltyrc"),b=await C.readFile(c,"utf-8").catch(()=>{});if(b===void 0){l.info("Creating file: "+c);const a=JSON.stringify({defaultProject:m,projects:[m]},null,2);await C.writeFile(c,a)}else{l.info("Edit file: "+c);const I=JSON.parse(b),a=new Set((I==null?void 0:I.projects)||[]);a.add(m),I.projects=[...a];const d=JSON.stringify(I,null,2);await C.writeFile(c,d)}const r=g.join(s,".gitignore"),A=await C.readFile(r,"utf-8").catch(()=>{});if(A!==void 0&&(A.includes("saltygen")||(l.info("Edit file: "+r),await C.writeFile(r,A+`
|
3
3
|
|
4
4
|
# Salty-CSS
|
5
5
|
saltygen
|
6
|
-
`))),
|
7
|
-
`+
|
8
|
-
`,
|
9
|
-
saltyPlugin(__dirname),`);
|
6
|
+
`))),o){const I=g.join(i,o),a=await C.readFile(I,"utf-8").catch(()=>{});if(a!==void 0&&!a.includes("saltygen")){const Y=g.join(I,".."),K=`@import '${g.relative(Y,g.join(i,"saltygen/index.css"))}';`;l.info("Edit file: "+I),await C.writeFile(I,K+`
|
7
|
+
`+a),await u(I)}}const Z=g.join(i,"vite.config.ts"),N=await C.readFile(Z,"utf-8").catch(()=>{});if(N!==void 0&&!N.includes("saltyPlugin")){l.info("Edit file: "+Z);const a=`import { saltyPlugin } from '@salty-css/vite';
|
8
|
+
`,Y=N.replace(/(plugins: \[)/,`$1
|
9
|
+
saltyPlugin(__dirname),`);l.info("Installing @salty-css/vite"),await X(y.vite),l.info("Adding Salty-CSS plugin to Vite config..."),await C.writeFile(Z,a+Y),await u(Z)}}),n.command("build").alias("b").description("Build the Salty-CSS project.").option("-d, --dir <dir>","Project directory to build the project in.",v).action(async function(){l.info("Building the Salty-CSS project...");const{dir:t}=this.opts(),o=g.join(process.cwd(),t);await S.generateCss(o)}),n.command("generate <file>").alias("g").description("Generate a new component file.").option("-d, --dir <dir>","Project directory to generate the file in.",v).option("-t, --tag <tag>","HTML tag of the component.","div").option("-n, --name <name>","Name of the component.").option("-c, --className <className>","CSS class of the component.").action(async function(t){const{dir:o,tag:s,name:i,className:h}=this.opts(),R=g.join(process.cwd(),o),m=g.join(R,t),c=g.parse(m);c.ext||(c.ext=".ts"),c.name.endsWith(".css")||(c.name=c.name+".css"),c.base=c.name+c.ext;const b=g.format(c);if(await C.readFile(b,"utf-8").catch(()=>{})!==void 0){l.error("File already exists:",b);return}l.info("Generating a new file: "+b);const A=z.pascalCase(i||c.base.replace(/\.css\.\w+$/,"")),{content:Z}=await G("react/react-styled-file.ts",{tag:s,name:A,className:h});await C.writeFile(b,Z),await u(b)}),n.parseAsync(process.argv)}L().catch(n=>console.error(n));
|
package/bin/index.js
CHANGED
@@ -1,120 +1,130 @@
|
|
1
1
|
#!/usr/bin/env node
|
2
|
-
import { Command as
|
3
|
-
import { mkdir as
|
4
|
-
import { join as
|
5
|
-
import { render as
|
6
|
-
import { generateCss as
|
7
|
-
import { p as
|
8
|
-
import { createLogger as
|
9
|
-
import { existsSync as
|
10
|
-
import { exec as
|
11
|
-
const
|
2
|
+
import { Command as S } from "commander";
|
3
|
+
import { mkdir as K, readFile as s, writeFile as G } from "fs/promises";
|
4
|
+
import { join as l, relative as w, parse as z, format as U } from "path";
|
5
|
+
import { render as j } from "ejs";
|
6
|
+
import { generateCss as k } from "../compiler/index.js";
|
7
|
+
import { p as x } from "../pascal-case-BQpR5PdN.js";
|
8
|
+
import { createLogger as L, format as H, transports as f } from "winston";
|
9
|
+
import { existsSync as P } from "fs";
|
10
|
+
import { exec as O } from "child_process";
|
11
|
+
const C = L({
|
12
12
|
level: "debug",
|
13
|
-
format:
|
14
|
-
transports: [new
|
15
|
-
}),
|
16
|
-
|
17
|
-
if (
|
18
|
-
|
13
|
+
format: H.combine(H.colorize(), H.cli()),
|
14
|
+
transports: [new f.Console({})]
|
15
|
+
}), F = (c) => new Promise((b, A) => {
|
16
|
+
O(c, (W) => {
|
17
|
+
if (W) return A(W);
|
18
|
+
b();
|
19
19
|
});
|
20
|
-
}),
|
21
|
-
|
22
|
-
|
23
|
-
|
20
|
+
}), X = async (...c) => {
|
21
|
+
const b = c.join(" ");
|
22
|
+
await F(`npm install ${b}`);
|
23
|
+
}, T = () => P(l(process.cwd(), "node_modules", ".bin", "prettier"));
|
24
|
+
async function r(c) {
|
24
25
|
try {
|
25
|
-
if (!
|
26
|
-
await
|
27
|
-
} catch (
|
28
|
-
|
26
|
+
if (!T()) return;
|
27
|
+
await F(`./node_modules/.bin/prettier --write "${c}"`), C.info(`Formatted ${c} with Prettier`);
|
28
|
+
} catch (b) {
|
29
|
+
C.error(`Error formatting ${c} with Prettier:`, b);
|
29
30
|
}
|
30
31
|
}
|
31
|
-
async function M() {
|
32
|
-
|
33
|
-
|
34
|
-
|
32
|
+
const D = new URL("data:video/mp2t;base64,IyEvdXNyL2Jpbi9lbnYgbm9kZQppbXBvcnQgeyBDb21tYW5kIH0gZnJvbSAnY29tbWFuZGVyJzsKaW1wb3J0IHsgcmVhZEZpbGUsIHdyaXRlRmlsZSwgbWtkaXIgfSBmcm9tICdmcy9wcm9taXNlcyc7CmltcG9ydCB7IGpvaW4sIHJlbGF0aXZlLCBwYXJzZSBhcyBwYXJzZVBhdGgsIGZvcm1hdCBhcyBmb3JtYXRQYXRoIH0gZnJvbSAncGF0aCc7CmltcG9ydCB7IHJlbmRlciB9IGZyb20gJ2Vqcyc7CmltcG9ydCB7IGdlbmVyYXRlQ3NzIH0gZnJvbSAnLi4vY29tcGlsZXInOwppbXBvcnQgeyBwYXNjYWxDYXNlIH0gZnJvbSAnLi4vdXRpbCc7CmltcG9ydCB7IGxvZ2dlciB9IGZyb20gJy4vbG9nZ2VyJzsKaW1wb3J0IHsgZm9ybWF0V2l0aFByZXR0aWVyIH0gZnJvbSAnLi9wcmV0dGllcic7CmltcG9ydCB7IG5wbUluc3RhbGwgfSBmcm9tICcuL2Jpbi11dGlsJzsKCmNvbnN0IF9fZGlybmFtZSA9IG5ldyBVUkwoJy4nLCBpbXBvcnQubWV0YS51cmwpLnBhdGhuYW1lOwoKYXN5bmMgZnVuY3Rpb24gbWFpbigpIHsKICBjb25zdCBwcm9ncmFtID0gbmV3IENvbW1hbmQoKTsKCiAgcHJvZ3JhbS5uYW1lKCdzYWx0eS1jc3MnKS5kZXNjcmlwdGlvbignU2FsdHktQ1NTIENMSSB0b29sIHRvIGhlbHAgd2l0aCBhbm5veWluZyBjb25maWd1cmF0aW9uIHRhc2tzLicpOwoKICBjb25zdCBmaWxlcyA9IHsKICAgIC8vIENvcmUgZmlsZXMKICAgICdzYWx0eS5jb25maWcudHMnOiBpbXBvcnQoJy4vdGVtcGxhdGVzL3NhbHR5LmNvbmZpZy50c19fdGVtcGxhdGUnKSwKICAgICdzYWx0eWdlbi9pbmRleC5jc3MnOiBpbXBvcnQoJy4vdGVtcGxhdGVzL2luZGV4LmNzc19fdGVtcGxhdGUnKSwKICAgIC8vIFJlYWN0CiAgICAncmVhY3QvcmVhY3Qtc3R5bGVkLWZpbGUudHMnOiBpbXBvcnQoJy4vdGVtcGxhdGVzL3JlYWN0LXN0eWxlZC1maWxlLnRzX190ZW1wbGF0ZScpLAogIH0gYXMgY29uc3Q7CgogIHR5cGUgVGVtcGxhdGUgPSBrZXlvZiB0eXBlb2YgZmlsZXM7CgogIGNvbnN0IHJlYWRUZW1wbGF0ZSA9IGFzeW5jIDxUIGV4dGVuZHMgb2JqZWN0PihmaWxlTmFtZTogVGVtcGxhdGUsIG9wdGlvbnM/OiBUKSA9PiB7CiAgICBjb25zdCB7IGRlZmF1bHQ6IGZpbGUgfSA9IGF3YWl0IGZpbGVzW2ZpbGVOYW1lXTsKICAgIGNvbnN0IGNvbnRlbnQgPSByZW5kZXIoZmlsZSwgb3B0aW9ucyk7CiAgICByZXR1cm4geyBmaWxlTmFtZSwgY29udGVudCB9OwogIH07CgogIGludGVyZmFjZSBSQ0ZpbGUgewogICAgZGVmYXVsdFByb2plY3Q6IHN0cmluZzsKICAgIHByb2plY3RzOiBzdHJpbmdbXTsKICB9CgogIGNvbnN0IHJlYWRSQ0ZpbGUgPSBhc3luYyAoKSA9PiB7CiAgICBjb25zdCByY1BhdGggPSBqb2luKHByb2Nlc3MuY3dkKCksICcuc2FsdHlyYycpOwogICAgY29uc3QgcmNDb250ZW50ID0gYXdhaXQgcmVhZEZpbGUocmNQYXRoLCAndXRmLTgnKQogICAgICAudGhlbihKU09OLnBhcnNlKQogICAgICAuY2F0Y2goKCkgPT4gKHt9KSk7CgogICAgcmV0dXJuIHJjQ29udGVudCBhcyBSQ0ZpbGU7CiAgfTsKCiAgY29uc3QgcmVhZFRoaXNQYWNrYWdlSnNvbiA9IGFzeW5jICgpID0+IHsKICAgIGNvbnN0IHBhY2thZ2VKc29uUGF0aCA9IGpvaW4oX19kaXJuYW1lLCAnLi4vcGFja2FnZS5qc29uJyk7CiAgICBjb25zdCBwYWNrYWdlSnNvbkNvbnRlbnQgPSBhd2FpdCByZWFkRmlsZShwYWNrYWdlSnNvblBhdGgsICd1dGYtOCcpCiAgICAgIC50aGVuKEpTT04ucGFyc2UpCiAgICAgIC5jYXRjaCgoKSA9PiAoe30pKTsKCiAgICByZXR1cm4gcGFja2FnZUpzb25Db250ZW50OwogIH07CgogIGNvbnN0IHJlYWRQYWNrYWdlSnNvbiA9IGFzeW5jIChwcm9qZWN0RGlyOiBzdHJpbmcpID0+IHsKICAgIGNvbnN0IHBhY2thZ2VKc29uUGF0aCA9IGpvaW4ocHJvamVjdERpciwgJ3BhY2thZ2UuanNvbicpOwogICAgY29uc3QgcGFja2FnZUpzb25Db250ZW50ID0gYXdhaXQgcmVhZEZpbGUocGFja2FnZUpzb25QYXRoLCAndXRmLTgnKQogICAgICAudGhlbihKU09OLnBhcnNlKQogICAgICAuY2F0Y2goKCkgPT4gKHt9KSk7CgogICAgcmV0dXJuIHBhY2thZ2VKc29uQ29udGVudDsKICB9OwoKICBjb25zdCBnZXREZWZhdWx0UHJvamVjdCA9IGFzeW5jICgpID0+IHsKICAgIGNvbnN0IHJjQ29udGVudCA9IGF3YWl0IHJlYWRSQ0ZpbGUoKTsKICAgIHJldHVybiByY0NvbnRlbnQuZGVmYXVsdFByb2plY3Q7CiAgfTsKCiAgY29uc3QgZGVmYXVsdFByb2plY3QgPSBhd2FpdCBnZXREZWZhdWx0UHJvamVjdCgpOwoKICBpbnRlcmZhY2UgSW5pdE9wdGlvbnMgewogICAgZGlyOiBzdHJpbmc7CiAgICBjc3NGaWxlPzogc3RyaW5nOwogIH0KCiAgY29uc3QgY3VycmVudFBhY2thZ2VKc29uID0gYXdhaXQgcmVhZFRoaXNQYWNrYWdlSnNvbigpOwoKICBjb25zdCBwYWNrYWdlcyA9IHsKICAgIGNvcmU6IGBAc2FsdHktY3NzL2NvcmVAJHtjdXJyZW50UGFja2FnZUpzb24udmVyc2lvbn1gLAogICAgcmVhY3Q6IGBAc2FsdHktY3NzL3JlYWN0QCR7Y3VycmVudFBhY2thZ2VKc29uLnZlcnNpb259YCwKICAgIGVzbGludFBsdWdpbkNvcmU6IGBAc2FsdHktY3NzL2VzbGludC1wbHVnaW4tY29yZUAke2N1cnJlbnRQYWNrYWdlSnNvbi52ZXJzaW9ufWAsCiAgICB2aXRlOiBgQHNhbHR5LWNzcy92aXRlQCR7Y3VycmVudFBhY2thZ2VKc29uLnZlcnNpb259YCwKICB9OwoKICBwcm9ncmFtCiAgICAuY29tbWFuZCgnaW5pdCcpCiAgICAuZGVzY3JpcHRpb24oJ0luaXRpYWxpemUgYSBuZXcgU2FsdHktQ1NTIHByb2plY3QuJykKICAgIC5yZXF1aXJlZE9wdGlvbignLWQsIC0tZGlyIDxkaXI+JywgJ1Byb2plY3QgZGlyZWN0b3J5IHRvIGluaXRpYWxpemUgdGhlIHByb2plY3QgaW4uJykKICAgIC5vcHRpb24oJy0tY3NzLWZpbGUgPGNzcy1maWxlPicsICdFeGlzdGluZyBDU1MgZmlsZSB3aGVyZSB0byBpbXBvcnQgdGhlIGdlbmVyYXRlZCBDU1MuIFBhdGggbXVzdCBiZSByZWxhdGl2ZSB0byB0aGUgZ2l2ZW4gcHJvamVjdCBkaXJlY3RvcnkuJykKICAgIC8vIFZhbGlkYXRlIHRoYXQgYWxsIG9wdGlvbnMgYXJlIHByb3ZpZGVkCiAgICAuYWN0aW9uKGFzeW5jIGZ1bmN0aW9uICh0aGlzOiBDb21tYW5kKSB7CiAgICAgIGxvZ2dlci5pbmZvKCdJbnN0YWxsaW5nIHNhbHR5LWNzcyBwYWNrYWdlcyBjb3JlLCBlc2xpbnQtcGx1Z2luIGFuZCByZWFjdCcpOwogICAgICBhd2FpdCBucG1JbnN0YWxsKHBhY2thZ2VzLmNvcmUsIHBhY2thZ2VzLnJlYWN0KTsKICAgICAgYXdhaXQgbnBtSW5zdGFsbChgLUQgJHtwYWNrYWdlcy5lc2xpbnRQbHVnaW5Db3JlfWApOwoKICAgICAgbG9nZ2VyLmluZm8oJ0luaXRpYWxpemluZyBhIG5ldyBTYWx0eS1DU1MgcHJvamVjdC4uLicpOwoKICAgICAgY29uc3QgeyBkaXIsIGNzc0ZpbGUgfSA9IHRoaXMub3B0czxJbml0T3B0aW9ucz4oKTsKICAgICAgY29uc3Qgcm9vdERpciA9IHByb2Nlc3MuY3dkKCk7CiAgICAgIGNvbnN0IHByb2plY3REaXIgPSBqb2luKHJvb3REaXIsIGRpcik7CiAgICAgIGNvbnN0IHByb2plY3RGaWxlcyA9IGF3YWl0IFByb21pc2UuYWxsKFtyZWFkVGVtcGxhdGUoJ3NhbHR5LmNvbmZpZy50cycpLCByZWFkVGVtcGxhdGUoJ3NhbHR5Z2VuL2luZGV4LmNzcycpXSk7CgogICAgICAvLyBDcmVhdGUgdGhlIHByb2plY3Qgc3RydWN0dXJlIGlmIGl0IGRvZXNuJ3QgZXhpc3QKICAgICAgYXdhaXQgbWtkaXIocHJvamVjdERpciwgeyByZWN1cnNpdmU6IHRydWUgfSk7CiAgICAgIGNvbnN0IHdyaXRlRmlsZXMgPSBwcm9qZWN0RmlsZXMubWFwKGFzeW5jICh7IGZpbGVOYW1lLCBjb250ZW50IH0pID0+IHsKICAgICAgICBjb25zdCBmaWxlUGF0aCA9IGpvaW4ocHJvamVjdERpciwgZmlsZU5hbWUpOwogICAgICAgIGNvbnN0IGV4aXN0aW5nQ29udGVudCA9IGF3YWl0IHJlYWRGaWxlKGZpbGVQYXRoLCAndXRmLTgnKS5jYXRjaCgoKSA9PiB1bmRlZmluZWQpOwogICAgICAgIGlmIChleGlzdGluZ0NvbnRlbnQgIT09IHVuZGVmaW5lZCkgewogICAgICAgICAgbG9nZ2VyLmRlYnVnKCdGaWxlIGFscmVhZHkgZXhpc3RzOiAnICsgZmlsZVBhdGgpOwogICAgICAgICAgcmV0dXJuOwogICAgICAgIH0KICAgICAgICBjb25zdCBhZGRpdGlvbmFsRm9sZGVycyA9IGZpbGVOYW1lLnNwbGl0KCcvJykuc2xpY2UoMCwgLTEpLmpvaW4oJy8nKTsKICAgICAgICAvLyBDcmVhdGUgYWRkaXRpb25hbCBmb2xkZXJzIGlmIHRoZXkgZG9uJ3QgZXhpc3QKICAgICAgICBpZiAoYWRkaXRpb25hbEZvbGRlcnMpIGF3YWl0IG1rZGlyKGpvaW4ocHJvamVjdERpciwgYWRkaXRpb25hbEZvbGRlcnMpLCB7IHJlY3Vyc2l2ZTogdHJ1ZSB9KTsKICAgICAgICBsb2dnZXIuaW5mbygnV3JpdGluZyBmaWxlOiAnICsgZmlsZVBhdGgpOwogICAgICAgIGF3YWl0IHdyaXRlRmlsZShmaWxlUGF0aCwgY29udGVudCk7CiAgICAgICAgYXdhaXQgZm9ybWF0V2l0aFByZXR0aWVyKGZpbGVQYXRoKTsKICAgICAgfSk7CgogICAgICBhd2FpdCBQcm9taXNlLmFsbCh3cml0ZUZpbGVzKTsKCiAgICAgIC8vIENyZWF0ZSBzYWx0eXJjIGZpbGUKICAgICAgY29uc3QgcmVsYXRpdmVQcm9qZWN0UGF0aCA9IHJlbGF0aXZlKHJvb3REaXIsIHByb2plY3REaXIpOwogICAgICBjb25zdCBzYWx0eXJjUGF0aCA9IGpvaW4ocm9vdERpciwgJy5zYWx0eXJjJyk7CiAgICAgIGNvbnN0IGV4aXN0aW5nU2FsdHlyYyA9IGF3YWl0IHJlYWRGaWxlKHNhbHR5cmNQYXRoLCAndXRmLTgnKS5jYXRjaCgoKSA9PiB1bmRlZmluZWQpOwogICAgICBpZiAoZXhpc3RpbmdTYWx0eXJjID09PSB1bmRlZmluZWQpIHsKICAgICAgICBsb2dnZXIuaW5mbygnQ3JlYXRpbmcgZmlsZTogJyArIHNhbHR5cmNQYXRoKTsKICAgICAgICBjb25zdCByY0NvbnRlbnQgPSB7CiAgICAgICAgICBkZWZhdWx0UHJvamVjdDogcmVsYXRpdmVQcm9qZWN0UGF0aCwKICAgICAgICAgIHByb2plY3RzOiBbcmVsYXRpdmVQcm9qZWN0UGF0aF0sCiAgICAgICAgfTsKICAgICAgICBjb25zdCBjb250ZW50ID0gSlNPTi5zdHJpbmdpZnkocmNDb250ZW50LCBudWxsLCAyKTsKICAgICAgICBhd2FpdCB3cml0ZUZpbGUoc2FsdHlyY1BhdGgsIGNvbnRlbnQpOwogICAgICB9IGVsc2UgewogICAgICAgIGxvZ2dlci5pbmZvKCdFZGl0IGZpbGU6ICcgKyBzYWx0eXJjUGF0aCk7CiAgICAgICAgY29uc3QgcmNDb250ZW50ID0gSlNPTi5wYXJzZShleGlzdGluZ1NhbHR5cmMpOwogICAgICAgIGNvbnN0IHByb2plY3RzID0gbmV3IFNldChyY0NvbnRlbnQ/LnByb2plY3RzIHx8IFtdKTsKICAgICAgICBwcm9qZWN0cy5hZGQocmVsYXRpdmVQcm9qZWN0UGF0aCk7CiAgICAgICAgcmNDb250ZW50LnByb2plY3RzID0gWy4uLnByb2plY3RzXTsKICAgICAgICBjb25zdCBjb250ZW50ID0gSlNPTi5zdHJpbmdpZnkocmNDb250ZW50LCBudWxsLCAyKTsKICAgICAgICBhd2FpdCB3cml0ZUZpbGUoc2FsdHlyY1BhdGgsIGNvbnRlbnQpOwogICAgICB9CgogICAgICAvLyBFZGl0IGZpbGVzIGluIHRoZSBwcm9qZWN0CgogICAgICAvLyBFZGl0IEdpdGlnbm9yZQogICAgICBjb25zdCBnaXRJZ25vcmVQYXRoID0gam9pbihyb290RGlyLCAnLmdpdGlnbm9yZScpOwogICAgICBjb25zdCBnaXRJZ25vcmVDb250ZW50ID0gYXdhaXQgcmVhZEZpbGUoZ2l0SWdub3JlUGF0aCwgJ3V0Zi04JykuY2F0Y2goKCkgPT4gdW5kZWZpbmVkKTsKICAgICAgaWYgKGdpdElnbm9yZUNvbnRlbnQgIT09IHVuZGVmaW5lZCkgewogICAgICAgIGNvbnN0IGFscmVhZHlJZ25vcmVzU2FsdHlnZW4gPSBnaXRJZ25vcmVDb250ZW50LmluY2x1ZGVzKCdzYWx0eWdlbicpOwogICAgICAgIGlmICghYWxyZWFkeUlnbm9yZXNTYWx0eWdlbikgewogICAgICAgICAgbG9nZ2VyLmluZm8oJ0VkaXQgZmlsZTogJyArIGdpdElnbm9yZVBhdGgpOwogICAgICAgICAgYXdhaXQgd3JpdGVGaWxlKGdpdElnbm9yZVBhdGgsIGdpdElnbm9yZUNvbnRlbnQgKyAnXG5cbiMgU2FsdHktQ1NTXG5zYWx0eWdlblxuJyk7CiAgICAgICAgfQogICAgICB9CgogICAgICAvLyBFZGl0IHRoZSBDU1MgZmlsZSBpZiBwcm92aWRlZAogICAgICBpZiAoY3NzRmlsZSkgewogICAgICAgIGNvbnN0IGNzc0ZpbGVQYXRoID0gam9pbihwcm9qZWN0RGlyLCBjc3NGaWxlKTsKICAgICAgICBjb25zdCBjc3NGaWxlQ29udGVudCA9IGF3YWl0IHJlYWRGaWxlKGNzc0ZpbGVQYXRoLCAndXRmLTgnKS5jYXRjaCgoKSA9PiB1bmRlZmluZWQpOwogICAgICAgIGlmIChjc3NGaWxlQ29udGVudCAhPT0gdW5kZWZpbmVkKSB7CiAgICAgICAgICBjb25zdCBhbHJlYWR5SW1wb3J0c1NhbHR5Z2VuID0gY3NzRmlsZUNvbnRlbnQuaW5jbHVkZXMoJ3NhbHR5Z2VuJyk7CiAgICAgICAgICBpZiAoIWFscmVhZHlJbXBvcnRzU2FsdHlnZW4pIHsKICAgICAgICAgICAgY29uc3QgY3NzRmlsZUZvbGRlciA9IGpvaW4oY3NzRmlsZVBhdGgsICcuLicpOwogICAgICAgICAgICBjb25zdCByZWxhdGl2ZVBhdGggPSByZWxhdGl2ZShjc3NGaWxlRm9sZGVyLCBqb2luKHByb2plY3REaXIsICdzYWx0eWdlbi9pbmRleC5jc3MnKSk7CiAgICAgICAgICAgIGNvbnN0IGltcG9ydFN0YXRlbWVudCA9IGBAaW1wb3J0ICcke3JlbGF0aXZlUGF0aH0nO2A7CiAgICAgICAgICAgIGxvZ2dlci5pbmZvKCdFZGl0IGZpbGU6ICcgKyBjc3NGaWxlUGF0aCk7CiAgICAgICAgICAgIGF3YWl0IHdyaXRlRmlsZShjc3NGaWxlUGF0aCwgaW1wb3J0U3RhdGVtZW50ICsgJ1xuJyArIGNzc0ZpbGVDb250ZW50KTsKICAgICAgICAgICAgYXdhaXQgZm9ybWF0V2l0aFByZXR0aWVyKGNzc0ZpbGVQYXRoKTsKICAgICAgICAgIH0KICAgICAgICB9CiAgICAgIH0KCiAgICAgIC8vIEZyYW1ld29yayAvIGJ1aWxkIHRvb2wgc3BlY2lmaWMgZmlsZXMKCiAgICAgIC8vIERldGVjdCB2aXRlIGFuZCBhZGQgdGhlIHBsdWdpbgogICAgICBjb25zdCB2aXRlQ29uZmlnUGF0aCA9IGpvaW4ocHJvamVjdERpciwgJ3ZpdGUuY29uZmlnLnRzJyk7CiAgICAgIGNvbnN0IHZpdGVDb25maWdDb250ZW50ID0gYXdhaXQgcmVhZEZpbGUodml0ZUNvbmZpZ1BhdGgsICd1dGYtOCcpLmNhdGNoKCgpID0+IHVuZGVmaW5lZCk7CgogICAgICBpZiAodml0ZUNvbmZpZ0NvbnRlbnQgIT09IHVuZGVmaW5lZCkgewogICAgICAgIGNvbnN0IGFscmVhZHlIYXNQbHVnaW4gPSB2aXRlQ29uZmlnQ29udGVudC5pbmNsdWRlcygnc2FsdHlQbHVnaW4nKTsKICAgICAgICBpZiAoIWFscmVhZHlIYXNQbHVnaW4pIHsKICAgICAgICAgIGxvZ2dlci5pbmZvKCdFZGl0IGZpbGU6ICcgKyB2aXRlQ29uZmlnUGF0aCk7CiAgICAgICAgICBjb25zdCBwbHVnaW5JbXBvcnQgPSAiaW1wb3J0IHsgc2FsdHlQbHVnaW4gfSBmcm9tICdAc2FsdHktY3NzL3ZpdGUnO1xuIjsKICAgICAgICAgIGNvbnN0IHBsdWdpbkNvbmZpZyA9ICdzYWx0eVBsdWdpbihfX2Rpcm5hbWUpLCc7CiAgICAgICAgICBjb25zdCBuZXdDb250ZW50ID0gdml0ZUNvbmZpZ0NvbnRlbnQucmVwbGFjZSgvKHBsdWdpbnM6IFxbKS8sIGAkMVxuICAke3BsdWdpbkNvbmZpZ31gKTsKCiAgICAgICAgICBsb2dnZXIuaW5mbygnSW5zdGFsbGluZyBAc2FsdHktY3NzL3ZpdGUnKTsKICAgICAgICAgIGF3YWl0IG5wbUluc3RhbGwocGFja2FnZXMudml0ZSk7CgogICAgICAgICAgbG9nZ2VyLmluZm8oJ0FkZGluZyBTYWx0eS1DU1MgcGx1Z2luIHRvIFZpdGUgY29uZmlnLi4uJyk7CiAgICAgICAgICBhd2FpdCB3cml0ZUZpbGUodml0ZUNvbmZpZ1BhdGgsIHBsdWdpbkltcG9ydCArIG5ld0NvbnRlbnQpOwogICAgICAgICAgYXdhaXQgZm9ybWF0V2l0aFByZXR0aWVyKHZpdGVDb25maWdQYXRoKTsKICAgICAgICB9CiAgICAgIH0KICAgIH0pOwoKICBpbnRlcmZhY2UgQnVpbGRPcHRpb25zIHsKICAgIGRpcjogc3RyaW5nOwogIH0KCiAgcHJvZ3JhbQogICAgLmNvbW1hbmQoJ2J1aWxkJykKICAgIC5hbGlhcygnYicpCiAgICAuZGVzY3JpcHRpb24oJ0J1aWxkIHRoZSBTYWx0eS1DU1MgcHJvamVjdC4nKQogICAgLm9wdGlvbignLWQsIC0tZGlyIDxkaXI+JywgJ1Byb2plY3QgZGlyZWN0b3J5IHRvIGJ1aWxkIHRoZSBwcm9qZWN0IGluLicsIGRlZmF1bHRQcm9qZWN0KQogICAgLmFjdGlvbihhc3luYyBmdW5jdGlvbiAodGhpczogQ29tbWFuZCkgewogICAgICBsb2dnZXIuaW5mbygnQnVpbGRpbmcgdGhlIFNhbHR5LUNTUyBwcm9qZWN0Li4uJyk7CiAgICAgIGNvbnN0IHsgZGlyIH0gPSB0aGlzLm9wdHM8QnVpbGRPcHRpb25zPigpOwogICAgICBjb25zdCBwcm9qZWN0RGlyID0gam9pbihwcm9jZXNzLmN3ZCgpLCBkaXIpOwogICAgICBhd2FpdCBnZW5lcmF0ZUNzcyhwcm9qZWN0RGlyKTsKICAgIH0pOwoKICBpbnRlcmZhY2UgR2VuZXJhdGVPcHRpb25zIHsKICAgIGRpcjogc3RyaW5nOwogICAgdGFnOiBzdHJpbmc7CiAgICBuYW1lPzogc3RyaW5nOwogICAgY2xhc3NOYW1lPzogc3RyaW5nOwogIH0KCiAgcHJvZ3JhbQogICAgLmNvbW1hbmQoJ2dlbmVyYXRlIDxmaWxlPicpCiAgICAuYWxpYXMoJ2cnKQogICAgLmRlc2NyaXB0aW9uKCdHZW5lcmF0ZSBhIG5ldyBjb21wb25lbnQgZmlsZS4nKQogICAgLm9wdGlvbignLWQsIC0tZGlyIDxkaXI+JywgJ1Byb2plY3QgZGlyZWN0b3J5IHRvIGdlbmVyYXRlIHRoZSBmaWxlIGluLicsIGRlZmF1bHRQcm9qZWN0KQogICAgLm9wdGlvbignLXQsIC0tdGFnIDx0YWc+JywgJ0hUTUwgdGFnIG9mIHRoZSBjb21wb25lbnQuJywgJ2RpdicpCiAgICAub3B0aW9uKCctbiwgLS1uYW1lIDxuYW1lPicsICdOYW1lIG9mIHRoZSBjb21wb25lbnQuJykKICAgIC5vcHRpb24oJy1jLCAtLWNsYXNzTmFtZSA8Y2xhc3NOYW1lPicsICdDU1MgY2xhc3Mgb2YgdGhlIGNvbXBvbmVudC4nKQogICAgLmFjdGlvbihhc3luYyBmdW5jdGlvbiAodGhpczogQ29tbWFuZCwgZmlsZTogc3RyaW5nKSB7CiAgICAgIGNvbnN0IHsgZGlyLCB0YWcsIG5hbWUsIGNsYXNzTmFtZSB9ID0gdGhpcy5vcHRzPEdlbmVyYXRlT3B0aW9ucz4oKTsKICAgICAgY29uc3QgcHJvamVjdERpciA9IGpvaW4ocHJvY2Vzcy5jd2QoKSwgZGlyKTsKICAgICAgY29uc3QgZmlsZVBhdGggPSBqb2luKHByb2plY3REaXIsIGZpbGUpOwoKICAgICAgY29uc3QgcGFyc2VkRmlsZVBhdGggPSBwYXJzZVBhdGgoZmlsZVBhdGgpOwogICAgICBpZiAoIXBhcnNlZEZpbGVQYXRoLmV4dCkgewogICAgICAgIHBhcnNlZEZpbGVQYXRoLmV4dCA9ICcudHMnOwogICAgICB9CiAgICAgIGlmICghcGFyc2VkRmlsZVBhdGgubmFtZS5lbmRzV2l0aCgnLmNzcycpKSB7CiAgICAgICAgcGFyc2VkRmlsZVBhdGgubmFtZSA9IHBhcnNlZEZpbGVQYXRoLm5hbWUgKyAnLmNzcyc7CiAgICAgIH0KICAgICAgcGFyc2VkRmlsZVBhdGguYmFzZSA9IHBhcnNlZEZpbGVQYXRoLm5hbWUgKyBwYXJzZWRGaWxlUGF0aC5leHQ7CiAgICAgIGNvbnN0IGZvcm1hdHRlZEZpbGVQYXRoID0gZm9ybWF0UGF0aChwYXJzZWRGaWxlUGF0aCk7CgogICAgICBjb25zdCBhbHJlYWR5RXhpc3RzID0gYXdhaXQgcmVhZEZpbGUoZm9ybWF0dGVkRmlsZVBhdGgsICd1dGYtOCcpLmNhdGNoKCgpID0+IHVuZGVmaW5lZCk7CiAgICAgIGlmIChhbHJlYWR5RXhpc3RzICE9PSB1bmRlZmluZWQpIHsKICAgICAgICBsb2dnZXIuZXJyb3IoJ0ZpbGUgYWxyZWFkeSBleGlzdHM6JywgZm9ybWF0dGVkRmlsZVBhdGgpOwogICAgICAgIHJldHVybjsKICAgICAgfQogICAgICBsb2dnZXIuaW5mbygnR2VuZXJhdGluZyBhIG5ldyBmaWxlOiAnICsgZm9ybWF0dGVkRmlsZVBhdGgpOwoKICAgICAgY29uc3QgX25hbWUgPSBwYXNjYWxDYXNlKG5hbWUgfHwgcGFyc2VkRmlsZVBhdGguYmFzZS5yZXBsYWNlKC9cLmNzc1wuXHcrJC8sICcnKSk7CiAgICAgIGNvbnN0IHsgY29udGVudCB9ID0gYXdhaXQgcmVhZFRlbXBsYXRlKCdyZWFjdC9yZWFjdC1zdHlsZWQtZmlsZS50cycsIHsgdGFnLCBuYW1lOiBfbmFtZSwgY2xhc3NOYW1lIH0pOwogICAgICBhd2FpdCB3cml0ZUZpbGUoZm9ybWF0dGVkRmlsZVBhdGgsIGNvbnRlbnQpOwoKICAgICAgYXdhaXQgZm9ybWF0V2l0aFByZXR0aWVyKGZvcm1hdHRlZEZpbGVQYXRoKTsKICAgIH0pOwoKICBwcm9ncmFtLnBhcnNlQXN5bmMocHJvY2Vzcy5hcmd2KTsKfQoKbWFpbigpLmNhdGNoKChlKSA9PiBjb25zb2xlLmVycm9yKGUpKTsK", import.meta.url).pathname;
|
33
|
+
async function E() {
|
34
|
+
const c = new S();
|
35
|
+
c.name("salty-css").description("Salty-CSS CLI tool to help with annoying configuration tasks.");
|
36
|
+
const b = {
|
35
37
|
// Core files
|
36
38
|
"salty.config.ts": import("../salty.config-D9ANEDiH.js"),
|
37
39
|
"saltygen/index.css": import("../index-D_732b92.js"),
|
38
40
|
// React
|
39
41
|
"react/react-styled-file.ts": import("../react-styled-file-CGVf5n1B.js")
|
40
|
-
},
|
41
|
-
const { default:
|
42
|
-
return { fileName:
|
43
|
-
},
|
44
|
-
const
|
45
|
-
return await
|
46
|
-
},
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
42
|
+
}, A = async (n, o) => {
|
43
|
+
const { default: i } = await b[n], a = j(i, o);
|
44
|
+
return { fileName: n, content: a };
|
45
|
+
}, W = async () => {
|
46
|
+
const n = l(process.cwd(), ".saltyrc");
|
47
|
+
return await s(n, "utf-8").then(JSON.parse).catch(() => ({}));
|
48
|
+
}, J = async () => {
|
49
|
+
const n = l(D, "../package.json");
|
50
|
+
return await s(n, "utf-8").then(JSON.parse).catch(() => ({}));
|
51
|
+
}, v = await (async () => (await W()).defaultProject)(), B = await J(), y = {
|
52
|
+
core: `@salty-css/core@${B.version}`,
|
53
|
+
react: `@salty-css/react@${B.version}`,
|
54
|
+
eslintPluginCore: `@salty-css/eslint-plugin-core@${B.version}`,
|
55
|
+
vite: `@salty-css/vite@${B.version}`
|
56
|
+
};
|
57
|
+
c.command("init").description("Initialize a new Salty-CSS project.").requiredOption("-d, --dir <dir>", "Project directory to initialize the project in.").option("--css-file <css-file>", "Existing CSS file where to import the generated CSS. Path must be relative to the given project directory.").action(async function() {
|
58
|
+
C.info("Installing salty-css packages core, eslint-plugin and react"), await X(y.core, y.react), await X(`-D ${y.eslintPluginCore}`), C.info("Initializing a new Salty-CSS project...");
|
59
|
+
const { dir: n, cssFile: o } = this.opts(), i = process.cwd(), a = l(i, n), u = await Promise.all([A("salty.config.ts"), A("saltygen/index.css")]);
|
60
|
+
await K(a, { recursive: !0 });
|
61
|
+
const R = u.map(async ({ fileName: g, content: t }) => {
|
62
|
+
const d = l(a, g);
|
63
|
+
if (await s(d, "utf-8").catch(() => {
|
54
64
|
}) !== void 0) {
|
55
|
-
|
65
|
+
C.debug("File already exists: " + d);
|
56
66
|
return;
|
57
67
|
}
|
58
|
-
const
|
59
|
-
|
68
|
+
const V = g.split("/").slice(0, -1).join("/");
|
69
|
+
V && await K(l(a, V), { recursive: !0 }), C.info("Writing file: " + d), await G(d, t), await r(d);
|
60
70
|
});
|
61
|
-
await Promise.all(
|
62
|
-
const
|
71
|
+
await Promise.all(R);
|
72
|
+
const e = w(i, a), I = l(i, ".saltyrc"), Z = await s(I, "utf-8").catch(() => {
|
63
73
|
});
|
64
|
-
if (
|
65
|
-
|
66
|
-
const
|
67
|
-
defaultProject:
|
68
|
-
projects: [
|
74
|
+
if (Z === void 0) {
|
75
|
+
C.info("Creating file: " + I);
|
76
|
+
const t = JSON.stringify({
|
77
|
+
defaultProject: e,
|
78
|
+
projects: [e]
|
69
79
|
}, null, 2);
|
70
|
-
await
|
80
|
+
await G(I, t);
|
71
81
|
} else {
|
72
|
-
|
73
|
-
const
|
74
|
-
|
75
|
-
const
|
76
|
-
await
|
82
|
+
C.info("Edit file: " + I);
|
83
|
+
const g = JSON.parse(Z), t = new Set((g == null ? void 0 : g.projects) || []);
|
84
|
+
t.add(e), g.projects = [...t];
|
85
|
+
const d = JSON.stringify(g, null, 2);
|
86
|
+
await G(I, d);
|
77
87
|
}
|
78
|
-
const
|
88
|
+
const Y = l(i, ".gitignore"), p = await s(Y, "utf-8").catch(() => {
|
79
89
|
});
|
80
|
-
if (
|
90
|
+
if (p !== void 0 && (p.includes("saltygen") || (C.info("Edit file: " + Y), await G(Y, p + `
|
81
91
|
|
82
92
|
# Salty-CSS
|
83
93
|
saltygen
|
84
|
-
`))),
|
85
|
-
const
|
94
|
+
`))), o) {
|
95
|
+
const g = l(a, o), t = await s(g, "utf-8").catch(() => {
|
86
96
|
});
|
87
|
-
if (
|
88
|
-
const
|
89
|
-
|
90
|
-
` +
|
97
|
+
if (t !== void 0 && !t.includes("saltygen")) {
|
98
|
+
const h = l(g, ".."), Q = `@import '${w(h, l(a, "saltygen/index.css"))}';`;
|
99
|
+
C.info("Edit file: " + g), await G(g, Q + `
|
100
|
+
` + t), await r(g);
|
91
101
|
}
|
92
102
|
}
|
93
|
-
const
|
103
|
+
const m = l(a, "vite.config.ts"), N = await s(m, "utf-8").catch(() => {
|
94
104
|
});
|
95
|
-
if (
|
96
|
-
|
97
|
-
const
|
98
|
-
`,
|
105
|
+
if (N !== void 0 && !N.includes("saltyPlugin")) {
|
106
|
+
C.info("Edit file: " + m);
|
107
|
+
const t = `import { saltyPlugin } from '@salty-css/vite';
|
108
|
+
`, h = N.replace(/(plugins: \[)/, `$1
|
99
109
|
saltyPlugin(__dirname),`);
|
100
|
-
|
110
|
+
C.info("Installing @salty-css/vite"), await X(y.vite), C.info("Adding Salty-CSS plugin to Vite config..."), await G(m, t + h), await r(m);
|
101
111
|
}
|
102
|
-
}),
|
103
|
-
|
104
|
-
const { dir:
|
105
|
-
await
|
106
|
-
}),
|
107
|
-
const { dir:
|
108
|
-
|
109
|
-
const
|
110
|
-
if (await
|
112
|
+
}), c.command("build").alias("b").description("Build the Salty-CSS project.").option("-d, --dir <dir>", "Project directory to build the project in.", v).action(async function() {
|
113
|
+
C.info("Building the Salty-CSS project...");
|
114
|
+
const { dir: n } = this.opts(), o = l(process.cwd(), n);
|
115
|
+
await k(o);
|
116
|
+
}), c.command("generate <file>").alias("g").description("Generate a new component file.").option("-d, --dir <dir>", "Project directory to generate the file in.", v).option("-t, --tag <tag>", "HTML tag of the component.", "div").option("-n, --name <name>", "Name of the component.").option("-c, --className <className>", "CSS class of the component.").action(async function(n) {
|
117
|
+
const { dir: o, tag: i, name: a, className: u } = this.opts(), R = l(process.cwd(), o), e = l(R, n), I = z(e);
|
118
|
+
I.ext || (I.ext = ".ts"), I.name.endsWith(".css") || (I.name = I.name + ".css"), I.base = I.name + I.ext;
|
119
|
+
const Z = U(I);
|
120
|
+
if (await s(Z, "utf-8").catch(() => {
|
111
121
|
}) !== void 0) {
|
112
|
-
|
122
|
+
C.error("File already exists:", Z);
|
113
123
|
return;
|
114
124
|
}
|
115
|
-
|
116
|
-
const
|
117
|
-
await
|
118
|
-
}),
|
125
|
+
C.info("Generating a new file: " + Z);
|
126
|
+
const p = x(a || I.base.replace(/\.css\.\w+$/, "")), { content: m } = await A("react/react-styled-file.ts", { tag: i, name: p, className: u });
|
127
|
+
await G(Z, m), await r(Z);
|
128
|
+
}), c.parseAsync(process.argv);
|
119
129
|
}
|
120
|
-
|
130
|
+
E().catch((c) => console.error(c));
|