@aurodesignsystem-dev/auro-cli 0.0.0-pr212.1 → 0.0.0-pr217.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.
- package/dist/auro-cli.js +118 -25
- package/dist/auro-cli.js.map +4 -4
- package/dist/migrations/package-json-update-oidc/migration.d.ts +1 -0
- package/dist/migrations/package-json-update-oidc/migration.js +1 -0
- package/dist/migrations/package-json-update-oidc/multi-gitter.yml +176 -0
- package/dist/migrations/package-json-update-oidc/script.sh +5 -0
- package/dist/static/getAuroDeps.js +1 -1
- package/package.json +12 -5
package/dist/auro-cli.js
CHANGED
|
@@ -1,24 +1,24 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import{program as
|
|
2
|
+
import{program as he}from"commander";import it from"figlet";import{mind as st}from"gradient-string";var ye=()=>st(it.textSync("Auro CLI"));import we from"node:fs";import be from"node:path";import{fileURLToPath as at}from"node:url";function S(t){process.env.DEBUG&&console.log(`[DEBUG] ${t}`)}function J(){try{let t=at(import.meta.url),e=be.dirname(t);S(`Current module path: ${e}`);let r=be.resolve(e,"..","package.json");return S(`Checking package.json at: ${r}`),we.existsSync(r)?(S(`Found package.json at: ${r}`),JSON.parse(we.readFileSync(r,"utf8")).version):(S("Could not find package.json in the standard installed module location, using default version"),"0.0.0")}catch(t){return console.error("Error retrieving package version:",t),"0.0.0"}}import{program as Ht}from"commander";import Me from"ora";function I(t){return t.option("-m, --module-paths [paths...]","Path(s) to node_modules folder").option("-w, --watch","Watches for changes").option("--skip-docs","Skip documentation generation",!1).option("--wca-input [files...]","Source file(s) to analyze for API documentation").option("--wca-output [files...]","Output file(s) for API documentation")}function ke(t){return t.option("-s, --serve","Starts a server").option("-p, --port <number>","Port for the server").option("-o, --open","Open the browser after starting the server")}import Ft from"@rollup/plugin-terser";import{watch as Mt}from"rollup";import{rmSync as bt}from"node:fs";import{join as kt}from"node:path";import Z from"ora";import{rollup as Q}from"rollup";import Ee from"ora";import{spawn as ct}from"node:child_process";import lt from"ora";var y=(t,e)=>{let r=`${t} ${e?e.join(" "):""}`,n=lt(),o=t,s=e||[];if(!e&&typeof t=="string"){let c=t.split(" ");o=c[0],s=c.slice(1)}let i=r.includes("--watch")||r.includes(" -w"),l=ct(o,s,{stdio:i?"inherit":["inherit","pipe","pipe"],shell:!0});if(!i){let c=[];l.stdout?.on("data",m=>{let u=m.toString();c.push(u),process.stdout.write(u)}),l.stderr?.on("data",m=>{let u=m.toString();c.push(u),process.stderr.write(u)})}return new Promise((c,m)=>{l.on("close",u=>{u!==0?i?(n.info(`Watch mode terminated with code ${u}`),c()):(n.fail(`${r} failed (code ${u})`),m(new Error(`Command failed with exit code ${u}`))):(n.succeed(`${r} completed successfully`),c())})})};import j from"node:fs";import ut from"node:path";import{markdownTable as Ae}from"markdown-table";var T=class{static{this.manifest={schemaVersion:"1.0.0",readme:"",modules:[]}}static generate(e={}){let{outDir:r="./docs",outFile:n="api.md",manifestPath:o="./custom-elements.json"}=e;if(o)try{let c=j.readFileSync(o,"utf8");this.manifest=JSON.parse(c)}catch(c){throw console.error(`Error reading manifest file at ${o}:`,c),c}let s=this.getElements(),i=r;j.existsSync(i)||j.mkdirSync(i,{recursive:!0});let a=this.renderAllElements(s),l=ut.join(i,n);j.writeFileSync(l,a),console.log(`Generated combined API documentation at ${l}`)}static getElements(){return this.manifest.modules.reduce((e,r)=>e.concat(r.declarations?.filter(n=>"customElement"in n&&n.customElement===!0&&"tagName"in n&&this.isWcaModule(r))??[]),[])}static isWcaModule(e){let r=e.path;return r?r.startsWith("scripts/wca/auro-")&&r.endsWith(".js"):!1}static renderAllElements(e){return`${e.map(r=>this.renderElement(r,!0)).join(`
|
|
3
3
|
|
|
4
4
|
---
|
|
5
5
|
|
|
6
|
-
`)}`}static renderElement(e,r=!0){let n=[];n.push(r?`# ${e.tagName}`:""),e.description&&n.push(e.description);let o=this.renderPropertiesAttributesTable(e);o&&n.push(o.trim());let
|
|
6
|
+
`)}`}static renderElement(e,r=!0){let n=[];n.push(r?`# ${e.tagName}`:""),e.description&&n.push(e.description);let o=this.renderPropertiesAttributesTable(e);o&&n.push(o.trim());let s=this.renderTable("Methods",["name","parameters","return","description"],(e.members||[]).filter(m=>m.kind==="method"&&("privacy"in m?m.privacy!=="private":!0)&&m.name[0]!=="_").map(m=>({...m,parameters:this.renderParameters("parameters"in m?m.parameters:void 0),returnType:"return"in m&&m.return?this.getType(m.return):""})));s&&n.push(s.trim());let i=this.renderTable("Events",["name","description"],e.events);i&&n.push(i.trim());let a=this.renderTable("Slots",[["name","(default)"],"description"],e.slots);a&&n.push(a.trim());let l=this.renderTable("CSS Shadow Parts",["name","description"],e.cssParts);l&&n.push(l.trim());let c=this.renderTable("CSS Custom Properties",["name","description"],e.cssProperties);return c&&n.push(c.trim()),n.join(`
|
|
7
7
|
|
|
8
|
-
`)}static renderPropertiesAttributesTable(e){let r=e.members?.filter(
|
|
8
|
+
`)}static renderPropertiesAttributesTable(e){let r=e.members?.filter(c=>c.kind==="field"&&("privacy"in c?c.privacy!=="private":!0)&&c.name[0]!=="_")||[],n=e.attributes||[],o=[],s=new Set;if(r.forEach(c=>{c.description?.trim()&&o.push({name:c.name,properties:c.name,attributes:("attribute"in c?c.attribute:"")||"",type:this.getType(c)||"",default:("default"in c?c.default:"")||"",description:c.description||""}),s.add(c.name),"attribute"in c&&c.attribute&&s.add(c.attribute)}),n.forEach(c=>{!s.has(c.name)&&c.description?.trim()&&o.push({name:c.name,properties:"",attributes:c.name,type:this.getType(c)||"",default:c.default||"",description:c.description||""})}),o.length===0)return"";let i=["Properties","Attributes","Type","Default","Description"],a=o.map(c=>[this.escapeMarkdown(c.properties),this.escapeMarkdown(c.attributes),this.escapeMarkdown(c.type),this.escapeMarkdown(c.default),this.escapeMarkdown(c.description)]);return`### Properties & Attributes
|
|
9
9
|
|
|
10
|
-
${
|
|
11
|
-
`}static renderParameters(e){return!e||e.length===0?"None":e.map(r=>{let n=this.getType(r)||"any",o=r.description?` - ${r.description}`:"";return`\`${r.name}\` (${this.escapeMarkdown(n)})${this.escapeMarkdown(o)}`}).join("<br>")}static renderTable(e,r,n){if(n===void 0||n.length===0)return"";let o=n.filter(
|
|
10
|
+
${Ae([i,...a])}
|
|
11
|
+
`}static renderParameters(e){return!e||e.length===0?"None":e.map(r=>{let n=this.getType(r)||"any",o=r.description?` - ${r.description}`:"";return`\`${r.name}\` (${this.escapeMarkdown(n)})${this.escapeMarkdown(o)}`}).join("<br>")}static renderTable(e,r,n){if(n===void 0||n.length===0)return"";let o=n.filter(l=>{let c=l.description;return typeof c=="string"&&c.trim()});if(o.length===0)return"";let s=r.map(l=>this.capitalize((Array.isArray(l)?l[0]:l).split(".")[0])),i=o.map(l=>r.map(c=>{let m=this.get(l,c);return this.escapeMarkdown(String(m||""))})),a=Ae([s,...i]);return`### ${e}
|
|
12
12
|
|
|
13
|
-
${
|
|
14
|
-
`}static escapeMarkdown(e){return e.replace(/\\/g,"\\\\").replace(/\n/g,"<br>").replace(/\|/g,"\\|")}static getType(e){if(!e||!e.type)return"";let r=e.type;return typeof r=="string"?r:r.text?r.text:Array.isArray(r)?r.map(n=>typeof n=="string"?n:n.text?n.text:n.name?n.name:String(n)).join(" \\| "):r.name?r.name:r.references&&Array.isArray(r.references)?r.references.map(n=>n.name||String(n)).join(" \\| "):String(r)}static get(e,r){let n="",o=r;Array.isArray(r)&&([o,n]=r);let
|
|
15
|
-
`).start();try{let r={port:Number(t.port)||void 0,open:t.open?"/":void 0,watch:t.watch??
|
|
13
|
+
${a}
|
|
14
|
+
`}static escapeMarkdown(e){return e.replace(/\\/g,"\\\\").replace(/\n/g,"<br>").replace(/\|/g,"\\|")}static getType(e){if(!e||!e.type)return"";let r=e.type;return typeof r=="string"?r:r.text?r.text:Array.isArray(r)?r.map(n=>typeof n=="string"?n:n.text?n.text:n.name?n.name:String(n)).join(" \\| "):r.name?r.name:r.references&&Array.isArray(r.references)?r.references.map(n=>n.name||String(n)).join(" \\| "):String(r)}static get(e,r){let n="",o=r;Array.isArray(r)&&([o,n]=r);let s=o.split("."),i=e;for(;i&&s.length;)i=i[s.shift()];return i==null||i===""?n:String(i)}static capitalize(e){return e.replace(/([A-Z])/g," $1").replace(/^./,r=>r.toUpperCase()).trim()}};import mt from"node:fs";import dt from"node:os";import O from"node:path";import K from"node:process";function pt(){let t=dt.homedir()||K.env.HOME||K.env.USERPROFILE;if(!t)throw new Error("Unable to determine user home directory");return O.join(t,".auro")}function Y(...t){return O.join(pt(),...t)}function X(...t){let e=mt.realpathSync(K.argv[1]),r=O.dirname(e);return O.resolve(r,...t)}var $e=t=>X("configs",t);async function R(){let t=Ee("Generating Custom Elements Manifest...").start();try{await y(`npx --package=@custom-elements-manifest/analyzer -y -- cem analyze --config '${$e("custom-elements-manifest.config.mjs")}'`),t.succeed("Custom Elements Manifest generated successfully!")}catch(e){let r=e instanceof Error?e.message:String(e);t.warn("CEM analyzer completed with warnings: "+r)}}async function _(){let t=Ee("Generating API documentation...").start();try{await T.generate(),t.succeed("API documentation generated successfully!")}catch(e){let r=e instanceof Error?e.message:String(e);throw t.fail("Failed to generate API documentation: "+r),e}}async function N(){await R(),await _()}import{Logger as ft}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import{generateReadmeUrl as gt,processContentForFile as ht,templateFiller as Te}from"@aurodesignsystem/auro-library/scripts/utils/sharedFileProcessorUtils.mjs";var ve={overwriteLocalCopies:!0,remoteReadmeVersion:"master",remoteReadmeVariant:"_updated_paths"};function $(t){return`${process.cwd()}/${t}`}var yt=t=>[{identifier:"README.md",input:{remoteUrl:t.remoteReadmeUrl||gt(t.remoteReadmeVersion,t.remoteReadmeVariant),fileName:$("/docTemplates/README.md"),overwrite:t.overwriteLocalCopies},output:$("/README.md")},{identifier:"index.md",input:$("/docs/partials/index.md"),output:$("/demo/index.md"),mdMagicConfig:{output:{directory:$("/demo")}}},{identifier:"api.md",input:$("/docs/partials/api.md"),output:$("/demo/api.md"),preProcessors:[Te.formatApiTable]}];async function wt(t=ve){await Te.extractNames();for(let e of yt(t))try{await ht(e)}catch(r){ft.error(`Error processing ${e.identifier}: ${r.message}`)}}async function xe(){await wt({...ve,remoteReadmeUrl:"https://raw.githubusercontent.com/AlaskaAirlines/auro-templates/main/templates/default/README.md"})}function De(){let t=kt("./dist"),e=Z("Cleaning dist folder...").start();try{return bt(t,{recursive:!0,force:!0}),e.succeed("All clean! Dist folder wiped."),!0}catch(r){return e.fail(`Oops! Couldn't clean dist/ folder: ${r.message}`),console.error(r),!1}}async function ee(t,e,r,n){let o=Z(t).start();try{let s=await e();return o.succeed(r),s}catch(s){throw o.fail(n),console.error(`Error: ${s.message}`),s}}async function Ce(t,e){return ee("Creating type definitions...",async()=>{let r=await Q(t);await r.write(e),await r.close()},"Types files built.","Darn! Type definitions failed.")}async function Pe(t,e){return ee(`Bundling ${t.name||"main"} and ${e.name||"demo"}...`,async()=>{let r=await Q(t);await r.write(t.output),await r.close();let n=await Q(e);await n.write(e.output),await n.close()},`Bundles ready! ${t.name||"Main"} and ${e.name||"demo"} built.`,"Bundle hiccup! Build failed.")}async function F(t){let{wcaInput:e,wcaOutput:r,skipDocs:n}=t;if(n){let o=Z("Skipping docs generation...").start();setTimeout(()=>{o.succeed("Docs generation skipped.")},0);return}return ee("Analyzing components and making docs...",async()=>{await N(e,r),await xe()},"Docs ready! Looking good.","Doc troubles!")}import{basename as Et,join as Ie}from"node:path";import{nodeResolve as Tt}from"@rollup/plugin-node-resolve";import{glob as vt}from"glob";import{dts as xt}from"rollup-plugin-dts";import{litScss as Dt}from"rollup-plugin-scss-lit";import At from"node:path";import{glob as $t}from"glob";function Se(t){return{name:"watch-globs",buildStart(){let e=Array.isArray(t)?t:[t];for(let r of e)try{for(let n of $t.sync(At.resolve(r)))this.addWatchFile(n)}catch(n){this.error(`Error watching glob pattern "${r}": ${n.message}`)}}}}var te={moduleDirectories:["node_modules"],modulePaths:["../../node_modules","../node_modules","node_modules"],watchPatterns:["./apiExamples/**/*","./docs/**/*"]};function je(t=[],e={}){let{watchPatterns:r=te.watchPatterns,dedupe:n=["lit","lit-element","lit-html"]}=e,o=[...te.modulePaths,...t];return[Tt({dedupe:n,preferBuiltins:!1,moduleDirectories:te.moduleDirectories}),Dt({minify:{fast:!0},options:{loadPaths:[...o,Ie(process.cwd(),"src","styles"),Ie(process.cwd(),"src")]}}),Se(r)]}function re(t={}){let{modulePaths:e=[],watch:r=!1,input:n=["./src/index.js","./src/registered.js"],outputDir:o="./dist",format:s="esm"}=t;return{name:"Main",config:{input:n,output:{format:s,dir:o,entryFileNames:"[name].js"},external:Ct(),plugins:je(e),watch:Oe(r)}}}function ne(t={}){let{modulePaths:e=[],watch:r=!1,globPattern:n="./demo/*.js",ignorePattern:o=["./demo/*.min.js"],outputDir:s="./demo"}=t;return{name:"Demo",config:{input:Object.fromEntries(vt.sync(n,{ignore:o}).map(i=>[Et(i,".js"),i])),output:{format:"esm",dir:s,entryFileNames:"[name].min.js",chunkFileNames:"[name].min.js"},plugins:je(e),watch:Oe(r)}}}function v(t={}){let{input:e=["./dist/index.js"],outputDir:r="./dist"}=t;return{name:"DTS",config:{input:e,output:{format:"esm",dir:r,entryFileNames:"[name].d.ts"},plugins:[xt()]}}}function Oe(t){if(!t)return!1;let e=typeof t=="object"?t:{};return{clearScreen:e.clearScreen??!0,buildDelay:e.buildDelay??500,chokidar:{ignoreInitial:!0,ignored:e.ignored??["**/dist/**/*.d.ts","**/custom-elements.json","**/demo/*.md","**/demo/**/*.min.js","**/docs/api.md","**/node_modules/**","**/.git/**"],awaitWriteFinish:e.awaitWriteFinish??{stabilityThreshold:1e3,pollInterval:100}},include:e.include??["./src/**/*.scss","./src/**/*.js","./src/**/*.ts","./demo/**/*.js","./apiExamples/**/*","./docs/**/*.md"],exclude:e.exclude??["./dist/**/*","./node_modules/**/*"]}}function Ct(t=[]){return[...[/node_modules\/lit/,/node_modules\/lit-element/,/node_modules\/lit-html/,/node_modules\/@lit/],...t]}import{startDevServer as Pt}from"@web/dev-server";import{hmrPlugin as St}from"@web/dev-server-hmr";import It from"ora";var x={watch:!0,nodeResolve:!0,basePath:"/",rootDir:"./demo",hmrInclude:["src/**/*","demo/**/*","apiExamples/**/*","docs/**/*"]};async function Re(t={}){if(!t.serve)return;let e=It(`Firing up dev server...
|
|
15
|
+
`).start();try{let r={port:Number(t.port)||void 0,open:t.open?"/":void 0,watch:t.watch??x.watch,nodeResolve:t.nodeResolve??x.nodeResolve,basePath:t.basePath??x.basePath,rootDir:t.rootDir??x.rootDir,middleware:[function(s,i){return!s.url.endsWith("/")&&!s.url.includes(".")&&(s.url+=".html"),i()}],plugins:[St({include:t.hmrInclude??x.hmrInclude})]},n=await Pt({config:r,readCliArgs:!1,readFileConfig:!1});return e.stop(),n}catch(r){throw e.fail("Server snag! Couldn't start dev server."),console.error("Error starting development server:",r),new Error(`Development server failed to start: ${r.message}`)}}import _e from"node:path";import b from"ora";import{rollup as jt}from"rollup";var M=!1,Ot={dts:{active:!1,lastTime:0},analyze:{active:!1,lastTime:0},docs:{active:!1,lastTime:0}},Rt=5e3,G=new Set,_t=["/dist/index.d.ts","/custom-elements.json","/demo/api.md","/docs/api.md","/demo/index.min.js"];function Nt(t){if(!t||typeof t!="string")return!1;try{let e=_e.normalize(t);return _t.some(r=>e.endsWith(r))||e.includes("/dist/")||e.endsWith(".min.js")||e.endsWith(".d.ts")}catch(e){return console.error(`Error checking path (${typeof t}):`,e.message),!1}}async function oe(t,e){let r=Ot[t];if(r.active||Date.now()-r.lastTime<Rt)return!1;try{return r.active=!0,r.lastTime=Date.now(),await e()}catch(n){return console.error(`Error in ${t} task:`,n),!1}finally{r.active=!1}}async function Ne(t,e,r){let n=!0,o={dts:!1,analyze:!1,docs:!1},s=null,i,a=b("Activating watch mode...").start(),l={dts:async()=>{let u=b("Crafting type definitions...").start();try{let d=await jt(v().config);return await d.write(v().config.output),await d.close(),u.succeed("Type files built."),!0}catch(d){return u.fail("Types trouble! Build failed."),console.error("TypeScript definition build error:",d),!1}},analyze:async()=>{let{wcaInput:u,wcaOutput:d,skipDocs:h}=e;if(h){let w=b("Skipping component analysis...").start();return setTimeout(()=>{w.succeed("Component analysis skipped.")},0),!0}let A=b("Detective work: analyzing components...").start();try{return await N(u,d),A.succeed("Component analysis complete! API generated."),!0}catch(w){return A.fail("Analysis hiccup! Something went wrong."),console.error("Component analysis error:",w),!1}},docs:async()=>{if(M)return!1;if(e.skipDocs){let d=b("Skipping docs generation...").start();return setTimeout(()=>{d.succeed("Docs generation skipped.")},0),!0}let u=b("Refreshing docs...").start();try{return await F(e),u.succeed("Documentation refreshed!"),!0}catch(d){u.fail("Docs stumble! Couldn't refresh."),console.error("Documentation rebuild error:",d)}}},c=()=>{n&&o.dts&&o.analyze&&o.docs&&typeof r=="function"&&(n=!1,r())};function m(u=1e3){s&&clearTimeout(s),s=setTimeout(async()=>{o.dts=await oe("dts",l.dts),setTimeout(async()=>{o.analyze=await oe("analyze",l.analyze),setTimeout(async()=>{o.docs=await oe("docs",l.docs),c()},1e3)},1e3)},u)}t.on("event",async u=>{switch(u.code){case"START":a.succeed("Watch mode active! Eyes peeled.");break;case"BUNDLE_START":if(G.clear(),u.input)try{let d=Array.isArray(u.input)?u.input:typeof u.input=="string"?[u.input]:typeof u.input=="object"&&u.input!==null?Object.values(u.input):[];for(let h of d)typeof h=="string"&&!Nt(h)&&G.add(_e.normalize(h))}catch(d){console.error("Error processing input paths:",d)}i=b("Weaving bundles...").start(),M=!0;break;case"BUNDLE_END":i&&i.succeed(`Bundle ${Array.isArray(u.input)?`of ${u.input.join("& ")} `:""}done in ${u.duration}ms! \u{1F680}`),M=!1,G.size>0&&m();break;case"END":break;case"ERROR":M=!1,i?i.fail(`Oops! Bundle hit a snag: ${u.error.message}`):b().fail(`Watch mode hiccup: ${u.error.message}`),G.clear();break}})}function Fe(t){return process.on("SIGINT",()=>{let e=b("Wrapping up...").start();t.close(),e.succeed("All done! See you next time. \u2728"),process.exit(0)}),t}async function Gt(t){let e=re(t),r=ne(t),n=v();e.config.plugins.push(Ft()),await F(t),await Pe(e.config,r.config),await Ce(n.config,n.config.output)}async function Bt(t){let{dev:e}=t,r=re({...t,watch:!0}),n=ne({...t,watch:!0}),o=Mt([r.config,n.config]);return Ne(o,t,e?async()=>Re(t):void 0),Fe(o),o}async function B(t={}){try{let{watch:e}=t;return De(),e?await Bt(t):await Gt(t)}catch(e){throw new Error(`Build failed: ${e.message}`)}}var D=Ht.command("dev").description("Runs development server for auro components");D=I(D);D=ke(D);var ao=D.action(async t=>{try{let e=Me("Initializing...");t.watch?(e.text="Waiting for changes...",e.spinner="bouncingBar",e.color="green"):e.text=t.docs===!1?"Building component (docs disabled)":"Building component",e.start(),t.watch||e.succeed("Build completed!"),await B({...t,dev:!0,watch:t.watch})}catch(e){Me().fail(`Build failed: ${e.message}`),console.error(e),process.exit(1)}});import{program as Lt}from"commander";import Ge from"ora";var ie=Lt.command("build").description("Builds auro components");ie=I(ie);var fo=ie.action(async t=>{try{let e=Ge("Initializing...");t.watch?(e.text="Waiting for changes...",e.spinner="bouncingBar",e.color="green"):e.text=t.docs===!1?"Building component (docs disabled)":"Building component",e.start(),await B(t),t.watch||e.succeed("Build completed!")}catch(e){Ge().fail(`Build failed: ${e.message}`),console.error(e),process.exit(1)}});import{exec as Wt}from"node:child_process";import Be from"node:path";import Ut from"node:process";import{fileURLToPath as zt}from"node:url";import qt from"node:util";import{program as Vt}from"commander";import Jt from"inquirer";var To=Vt.command("migrate").description("Script runner to perform repetitive code change tasks").requiredOption("-i, --id <string>","Select the migration you would like to run by id").option("-m, --multi-gitter","Run the migration on all repositories in the multi-gitter config").action(async t=>{let e=zt(import.meta.url),r=Be.dirname(e),n=Be.resolve(r,"migrations",t.id);if(t.multiGitter){let o=qt.promisify(Wt);try{await o("command -v multi-gitter")}catch{console.error("multi-gitter is not installed."),Ut.exit(1)}(await Jt.prompt([{type:"confirm",name:"dryRun",message:"Run migration in dry-run mode? (no changes will be committed)",default:!0}])).dryRun?y(`multi-gitter run ${n}/script.sh --config "${n}/multi-gitter.yml" --dry-run`):y(`multi-gitter run ${n}/script.sh --config "${n}/multi-gitter.yml"`)}else y(`${n}/script.sh`)});import nr from"node:process";import{program as or}from"commander";import{readFile as ir,writeFile as sr}from"node:fs/promises";import{Logger as ae}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import Kt from"node:fs/promises";import{Logger as k}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import{processContentForFile as Yt,templateFiller as Xt}from"@aurodesignsystem/auro-library/scripts/utils/sharedFileProcessorUtils.mjs";var se="https://raw.githubusercontent.com/AlaskaAirlines/auro-templates",He="main",Qt="main",Zt="default",Le={ISSUE_TEMPLATE:["bug_report.yaml","config.yml","feature_request.yaml","general-support.yaml","group.yaml","story.yaml","task.yaml"],workflows:["codeql.yml","publishDemo.yml","testPublish.yml"],_root:["CODEOWNERS","CODE_OF_CONDUCT.md","CONTRIBUTING.md","PULL_REQUEST_TEMPLATE.md","SECURITY.md","settings.yml","stale.yml"]};function er(t,e){return t.startsWith("v")&&/^\d+\.\d+\.\d+(?<_>-.*)?$/u.test(t.slice(1))?`${se}/refs/tags/${t}/${e}`:t!==He?`${se}/refs/heads/${t}/${e}`:`${se}/${He}/${e}`}function tr(t,e,r){let n=er(e,t);return{identifier:t.split("/").pop(),input:{remoteUrl:n,fileName:r,overwrite:!0},output:r,overwrite:!0}}async function rr(t){try{await Kt.rm(t,{recursive:!0,force:!0}),k.log(`Successfully removed directory: ${t}`)}catch(e){throw k.error(`Error removing directory ${t}: ${e.message}`),e}}async function We(t){t||(k.error("Root directory must be specified"),process.exit(1));let e=".github";try{await rr(e),k.log(".github directory removed successfully")}catch(o){k.error(`Error removing .github directory: ${o.message}`),process.exit(1)}await Xt.extractNames();let r=[],n=[];for(let o of Object.keys(Le))for(let s of Le[o]){let i=`${o==="_root"?"":`${o}/`}${s}`,a=`${t}/.github/${i}`,l=tr(`templates/${Zt}/.github/${i}`,Qt,a);r.push(l)}if(await Promise.all(r.map(async o=>{try{(await fetch(o.input.remoteUrl,{method:"HEAD"})).ok||n.push(o.input.remoteUrl)}catch{n.push(o.input.remoteUrl)}})),n.length>0){let o=n.map(s=>`File not found: ${s}`).join(`
|
|
16
16
|
`);k.error(`Failed to sync .github directory. Confirm githubDirShape object is up to date:
|
|
17
|
-
${o}`),process.exit(1)}try{await Promise.all(r.map(o=>
|
|
17
|
+
${o}`),process.exit(1)}try{await Promise.all(r.map(o=>Yt(o))),k.log("All files processed.")}catch(o){k.error(`Error processing files: ${o.message}`),process.exit(1)}}var _o=or.command("sync").description("Script runner to synchronize local repository configuration files").action(async()=>{ae.info("Synchronizing repository configuration files..."),ae.warn("Note: sync does not create a new git branch. Changes are added to the current branch.");let t=nr.cwd();await We(t);let e=`${t}/.github/CODEOWNERS`,n=(await ir(e,{encoding:"utf-8"})).replace(/\r\n/gu,`
|
|
18
18
|
`).replace(/\n\n/gu,`
|
|
19
|
-
`);await
|
|
19
|
+
`);await sr(e,n,{encoding:"utf-8"}),(n.includes("\r")||n.includes(`
|
|
20
20
|
|
|
21
|
-
`))&&
|
|
21
|
+
`))&&ae.error("CODEOWNERS file still has Windows line endings.")});import H from"node:fs";import C from"node:path";import{Logger as ze}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import{program as ar}from"commander";import{glob as cr}from"glob";var Ue=(t,e)=>{let r=(t.match(/static register\(name \= (.+)\)/)||t.match(/customElements.get\((.+?)\)/))[1],n=t.match(/export class (.+) extends/)?.[1],o=t.match(/\/\*\*((.|\n)*?)(\*\n|\*\/|[@])/)?.[1]||"";return!r||!n?t:`
|
|
22
22
|
import { ${n} } from '${e}';
|
|
23
23
|
|
|
24
24
|
/**${o}*/
|
|
@@ -27,24 +27,117 @@ class ${n}WCA extends ${n} {}
|
|
|
27
27
|
if (!customElements.get(${r})) {
|
|
28
28
|
customElements.define(${r}, ${n}WCA);
|
|
29
29
|
}
|
|
30
|
-
`};var L=
|
|
31
|
-
`).filter(
|
|
32
|
-
`);if(
|
|
33
|
-
|
|
34
|
-
${d}`:""}`,author_name:
|
|
35
|
-
${e}`),r&&p.success(`${e} added to .gitignore`)}catch(o){p.error(o)}})}static async removeFromGitCache(e){try{await g.rmKeepLocal(e),p.success(`${e.join(", ")} are removed from git cache`)}catch(r){p.error(r)}}static async createBranch(e){try{await g.checkoutLocalBranch(e),p.success(`Created and switched to ${e} branch`)}catch(r){p.error(r)}}static async commitStagedFiles(e){try{await g.add("."),await g.commit(e),p.success(`Committed with message: ${e}`)}catch(r){p.error(r)}}};import f from"chalk";var
|
|
36
|
-
`,o=""),o=`${o}${
|
|
37
|
-
`)}import
|
|
38
|
-
`).start();try{let n=await W.getCommitMessages();if(t&&
|
|
30
|
+
`};var L=C.resolve(process.cwd(),"./scripts/wca");async function lr(t){try{return(await Promise.all(t.map(r=>cr(r)))).flat()}catch(e){throw console.error("Error processing glob patterns:",e),e}}async function ur(t){H.existsSync(L)||await H.promises.mkdir(L,{recursive:!0});for(let e of t){let r=C.resolve(process.cwd(),e),n=await H.promises.readFile(r,"utf-8"),o=C.resolve(L,`${C.basename(e)}`),s=Ue(n,C.relative(L,e));await H.promises.writeFile(o,s)}}async function mr(){let t=await lr(["./src/auro-*.js"]);await ur(t)}var Uo=ar.command("wca-setup").description("Set up WCA (Web Component Analyzer) for the project").action(()=>{mr().then(()=>{ze.success("WCA setup completed successfully.")}).catch(t=>{ze.error(`WCA setup failed: ${t.message}`)})});import{program as br}from"commander";import yr from"chalk";import Ke from"ora";import{appendFile as dr,readFile as pr}from"node:fs/promises";import{Logger as p}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import{simpleGit as fr}from"simple-git";var g;try{g=fr({baseDir:process.cwd(),binary:"git",maxConcurrentProcesses:1})}catch(t){p.error(`Failed to initialize git: ${t}`),g={}}var W=class t{static async checkGitignore(e){if(e==="")return!1;try{return(await pr(".gitignore","utf-8")).includes(e)}catch(r){return p.error(`Error reading file: ${r}`),!1}}static async getCommitMessages(){try{let e=await g.branchLocal();p.info(`Current branch: ${e.current}`);let r="main",n="";if(!!process.env.GITHUB_ACTIONS){p.info("Running in GitHub Actions environment"),r=process.env.GITHUB_BASE_REF||"main";try{await g.fetch("origin",r),p.info(`Fetched target branch: origin/${r}`),n=`${(await g.raw(["merge-base",`origin/${r}`,"HEAD"])).trim()}..HEAD`,p.info(`Using commit range: ${n}`)}catch(s){p.warn(`Error setting up commit range in CI: ${s}`),n=`origin/${r}..HEAD`,p.info(`Falling back to commit range: ${n}`)}}else{p.info("Running in local environment");try{try{await g.raw(["rev-parse","--verify",`origin/${r}`])}catch{p.info(`Fetching ${r} from origin`),await g.fetch("origin",r)}n=`${(await g.raw(["merge-base",`origin/${r}`,e.current])).trim()}..HEAD`,p.info(`Using commit range for PR commits: ${n}`)}catch(s){p.warn(`Error determining PR commits locally: ${s}`),p.info("Falling back to analyzing recent commits"),n="HEAD~10..HEAD",p.info(`Using fallback commit range: ${n}`)}}return await t.getFormattedCommits(n)}catch(e){return p.error(`Error getting commit messages: ${e}`),[]}}static async getFormattedCommits(e){let n=(await g.raw(["log","--pretty=format:COMMIT_START%n%H%n%ad%n%an%n%s%n%b%nCOMMIT_END","--date=short",e])).split(`COMMIT_START
|
|
31
|
+
`).filter(s=>s.trim()!==""),o=[];for(let s of n){let i=s.split(`
|
|
32
|
+
`);if(i.length>=4){let a=i[0],l=i[1],c=i[2],m=i[3],u=i.slice(4).filter(V=>V!=="COMMIT_END"),d=u.length>0?u.join(""):"",h=a.substring(0,7),A=m.match(/^(feat|fix|docs|style|refactor|perf|test|build|ci|chore)(\(.+\))?:/),w=A?A[1]:"unknown";d.includes("BREAKING CHANGE")&&(w="breaking"),o.push({type:w,hash:h,date:l,subject:m,body:d,message:`${m}${d?`
|
|
33
|
+
|
|
34
|
+
${d}`:""}`,author_name:c})}}return o}static async addToGitignore(e,r=!0){await t.checkGitignore(e).then(async n=>{if(n)p.warn(`${e} already exists`);else try{await dr(".gitignore",`
|
|
35
|
+
${e}`),r&&p.success(`${e} added to .gitignore`)}catch(o){p.error(o)}})}static async removeFromGitCache(e){try{await g.rmKeepLocal(e),p.success(`${e.join(", ")} are removed from git cache`)}catch(r){p.error(r)}}static async createBranch(e){try{await g.checkoutLocalBranch(e),p.success(`Created and switched to ${e} branch`)}catch(r){p.error(r)}}static async commitStagedFiles(e){try{await g.add("."),await g.commit(e),p.success(`Committed with message: ${e}`)}catch(r){p.error(r)}}};import f from"chalk";var gr=60,hr=100;function P(t){switch(t){case"breaking":return f.bold.red(t);case"feat":return f.bold.green(t);case"fix":return f.bold.green(t);case"perf":return f.bold.green(t);case"docs":return f.bold.cyan(t);case"style":return f.bold.cyan(t);case"refactor":return f.bold.cyan(t);case"test":return f.bold.cyan(t);case"build":return f.bold.cyan(t);case"ci":return f.bold.cyan(t);case"chore":return f.bold.cyan(t);default:return f.bold.white(t)}}function qe(t,e){if(!t)return"";if(t.length<=e)return t;let r=t.split(" "),n="",o="";for(let s of r)(o+s).length>e&&o.length>0&&(n+=`${o.trim()}
|
|
36
|
+
`,o=""),o=`${o}${s} `;return o.length>0&&(n+=o.trim()),n}function Ve(t){for(let e of t){console.log("\u2500".repeat(60));let r=qe(e.subject,gr),n=qe(e.body,hr);console.log(f.bold(`${P(e.type)}`)),console.log(f.dim(`${e.hash} | ${e.date} | ${e.author_name}`)),console.log(f.bold(`${f.white(r)}`)),e.body&&console.log(f.dim(n))}console.log("\u2500".repeat(60)),console.log(`
|
|
37
|
+
`)}import U from"@actions/github";async function ce(){try{let t=process.env.GITHUB_TOKEN;if(!t)throw new Error("GITHUB_TOKEN environment variable is not set");if(!process.env.GITHUB_REPOSITORY||!process.env.GITHUB_EVENT_PATH)throw new Error("This function can only be used in a GitHub Actions environment");let e=U.getOctokit(t),{context:r}=U;if(!r.payload.pull_request)throw new Error("No pull request found in the GitHub context");let[n,o]=process.env.GITHUB_REPOSITORY.split("/"),s=r.payload.pull_request.number,{data:i}=await e.rest.issues.listLabelsOnIssue({owner:n,repo:o,issue_number:s});return i.map(a=>a.name)}catch(t){throw t instanceof Error?new Error(`Failed to get existing labels: ${t.message}`):t}}async function Je(t){try{let e=process.env.GITHUB_TOKEN;if(!e)throw new Error("GITHUB_TOKEN environment variable is not set");if(!process.env.GITHUB_REPOSITORY||!process.env.GITHUB_EVENT_PATH)throw new Error("This function can only be used in a GitHub Actions environment");let r=U.getOctokit(e),{context:n}=U;if(!n.payload.pull_request)throw new Error("No pull request found in the GitHub context");let[o,s]=process.env.GITHUB_REPOSITORY.split("/"),i=n.payload.pull_request.number,a=`semantic-status: ${t}`,l=await ce();if(l.includes(a))return;let c=l.filter(m=>m.startsWith("semantic-status:")&&m!==a);for(let m of c)await r.rest.issues.removeLabel({owner:o,repo:s,issue_number:i,name:m});await r.rest.issues.addLabels({owner:o,repo:s,issue_number:i,labels:[a]});return}catch(e){throw e instanceof Error?new Error(`Failed to apply label: ${e.message}`):e}}async function Ye(t=!1,e=!1){let r=Ke(`Checking commits...
|
|
38
|
+
`).start();try{let n=await W.getCommitMessages();if(t&&Ve(n),r.succeed(`Total commits analyzed: ${n.length}`),n.length!==0){let o=n.map(a=>a.type),i=Array.from(new Set(o)).map(a=>P(a)).join(", ");r.succeed(`Found commit types: ${i}`)}else r.info(`The list of commits is created by comparing the current branch
|
|
39
39
|
with the main branch. If you are on a new branch, please
|
|
40
|
-
make sure to commit some changes before running this command.`);e&&await
|
|
41
|
-
`,"utf8"),n.succeed(`Package.json updated to use ${E.green(m)} and ${E.green(
|
|
40
|
+
make sure to commit some changes before running this command.`);e&&await wr(n,r)}catch(n){r.fail("Error getting commit messages"),console.error(n)}}async function wr(t,e){let r=["breaking","feat","fix","perf","docs","style","refactor","test","build","ci","chore"],n=t.map(i=>i.type).filter(i=>r.includes(i)),o=null,s=Number.POSITIVE_INFINITY;for(let i of n){let a=r.indexOf(i);a<s&&(s=a,o=i)}if(o){let i=Ke("Checking existing labels on pull request...").start();try{if((await ce()).includes(`semantic-status: ${o}`)){i.info(`Label "semantic-status: ${P(o)}" already exists on the pull request.`);return}i.text="Applying label to pull request...",await Je(o),i.succeed(`Label "semantic-status: ${P(o)}" applied to the pull request.`)}catch(a){let l=a instanceof Error?a.message:String(a);i.fail(l)}}else e.warn(yr.yellow("No semantic commit type found to apply as label."))}var ci=br.command("check-commits").alias("cc").option("-l, --set-label","Set label on the pull request based on the commit message type").option("-d, --debug","Display detailed commit information for debugging").description("Check commits in the local repository for the types of semantic commit messages made and return the results.").action(async t=>{await Ye(t.debug,t.setLabel)});import Xe from"node:fs";import{get as Qe}from"node:https";import E from"chalk";import{program as kr}from"commander";import Ar from"ora";var gi=kr.command("pr-release").option("-n, --namespace <package-namespace>","Set namespace of the package release","@aurodesignsystem-dev").option("-p, --pr-number <number>","Set pull request number for the release","0").description("Generate the package version based off of PR number then update the package.json file. Note: this does not publish the package.").action(async t=>{await $r(t)}),$r=async t=>{let{namespace:e,prNumber:r}=t,n=Ar("Updating package.json").start();try{let o="package.json",s=JSON.parse(Xe.readFileSync(o,"utf8"));n.text="Checking npm registry for version information...";let i=`0.0.0-pr${r}`,a=s.name.split("/")[1],l=`${e}/${a}`,c=await Er(i,l,n),m=`${i}.${c}`;s.name=l,s.version=m,n.text="Writing updated package.json...",Xe.writeFileSync(o,`${JSON.stringify(s,null,2)}
|
|
41
|
+
`,"utf8"),n.succeed(`Package.json updated to use ${E.green(m)} and ${E.green(l)}`),process.exit(0)}catch(o){n.fail(`Failed to update package.json: ${o}`),process.exit(1)}},Er=(t,e,r)=>new Promise(n=>{try{let a=function(l){if(l.statusCode!==200){r.info(`Package not found. Status code: ${E.red(l.statusCode)}, defaulting to version 0`),n(0);return}r.text="Processing version information...";let c="";l.on("data",m=>{c+=m}),l.on("end",()=>{try{let m=JSON.parse(c),u=m.versions?Object.keys(m.versions):[];r.text="Calculating next version number...";let d=-1,h=new RegExp(`^${t}\\.(\\d+)$`);for(let A of u){let w=A.match(h);if(w){let V=Number.parseInt(w[1],10);d=Math.max(d,V)}}d>=0?r.info(`Found existing version ${E.green(`${t}.${d}`)}. Incrementing to ${E.green(`${t}.${d+1}`)}`):r.info(`No existing version found for ${E.green(t)}. Starting with ${E.green(`${t}.0`)}`),n(d+1)}catch(m){r.warn(`Failed to parse NPM registry response: ${m instanceof Error?m.message:"Unknown error"}, defaulting to version 0`),n(0)}})};var o=a;let s=`https://registry.npmjs.org/${e}`,i=Qe(s,{headers:{Accept:"application/json"}},l=>{if((l.statusCode===301||l.statusCode===302)&&l.headers.location){r.info(`Following redirect to ${l.headers.location}...`);try{Qe(l.headers.location,{headers:{Accept:"application/json"}},a).on("error",c=>{r.warn(`Error following redirect: ${c.message}, defaulting to version 0`),n(0)}).end()}catch(c){r.warn(`Redirect request failed: ${c instanceof Error?c.message:"Unknown error"}, defaulting to version 0`),n(0)}return}a(l)});i.on("error",l=>{r.warn(`Request error: ${l.message}, defaulting to version 0`),n(0)}),i.end()}catch{r.warn("Error checking version in npm registry, defaulting to version 0"),n(0)}});import le from"node:path";import{fileURLToPath as Tr}from"node:url";import{program as vr}from"commander";import xr from"open";var Dr=Tr(import.meta.url),Cr=le.resolve(le.dirname(Dr),".."),$i=vr.command("test").option("-w, --watch","Set watch number for the test").option("-c, --coverage-report","Generate coverage report").option("-o, --open","Open the coverage report in the browser").option("-f, --files <String|String[]>","Test files glob pattern").description("Run the web test runner to test the component library").action(async t=>{let r=`npx wtr --config "${le.join(Cr,"dist","configs","web-test-runner.config.mjs")}"`,n=`${process.cwd()}/coverage/index.html`;if(t.coverageReport&&(r+=" --coverage"),t.watch&&(r+=" --watch"),t.files){let o=Array.isArray(t.files)?t.files.join(" "):t.files;r+=` --files "${o}"`}y(r),t.open&&await xr(n)});import pe from"node:fs/promises";import rt from"node:path";import{program as _r}from"commander";import Nr from"inquirer";import fe from"ora";import Pr from"node:fs/promises";import Sr from"node:path";import Ir from"ora";var jr={"auth-type":"workspace-token","author-email":null,"author-name":null,"base-branch":"main","base-url":null,"clone-dir":".gitter-temp","code-search":null,concurrent:4,"conflict-strategy":"replace",draft:!1,"dry-run":!0,"fetch-depth":1,fork:!1,"fork-owner":null,"git-type":"go",group:null,"include-subgroups":!1,insecure:!1,interactive:!1,labels:null,"log-file":"'-'","log-format":"'text'","log-level":"'error'","max-reviewers":0,"max-team-reviewers":0,org:null,output:"'-'","plain-output":!1,platform:"github",project:null,"push-only":!1,repo:["AlaskaAirlines/auro-accordion","AlaskaAirlines/auro-alert","AlaskaAirlines/auro-avatar","AlaskaAirlines/auro-background","AlaskaAirlines/auro-backtotop","AlaskaAirlines/auro-button","AlaskaAirlines/auro-badge","AlaskaAirlines/auro-banner","AlaskaAirlines/auro-card","AlaskaAirlines/auro-carousel","AlaskaAirlines/auro-datetime","AlaskaAirlines/auro-dialog","AlaskaAirlines/auro-drawer","AlaskaAirlines/auro-flight","AlaskaAirlines/auro-flightline","AlaskaAirlines/auro-header","AlaskaAirlines/auro-hyperlink","AlaskaAirlines/auro-icon","AlaskaAirlines/auro-loader","AlaskaAirlines/auro-lockup","AlaskaAirlines/auro-nav","AlaskaAirlines/auro-pane","AlaskaAirlines/auro-popover","AlaskaAirlines/auro-sidenav","AlaskaAirlines/auro-skeleton","AlaskaAirlines/auro-slideshow","AlaskaAirlines/auro-table","AlaskaAirlines/auro-tabs","AlaskaAirlines/auro-toast"],"repo-exclude":null,"repo-include":null,"repo-search":null,reviewers:null,"skip-forks":!1,"skip-pr":!1,"skip-repo":null,"ssh-auth":!1,"team-reviewers":null};function Or(t){return Object.entries(t).map(([e,r])=>Array.isArray(r)?`${e}:
|
|
42
42
|
- ${r.join(`
|
|
43
43
|
- `)}`:typeof r=="object"&&r!==null?`${e}:
|
|
44
44
|
${Object.entries(r).map(([n,o])=>` ${n}: ${o}`).join(`
|
|
45
45
|
`)}`:`${e}: ${r}`).join(`
|
|
46
|
-
`)}async function
|
|
47
|
-
${
|
|
46
|
+
`)}async function Ze(t){let e=Ir("Writing multi-gitter configuration...").start(),r=Or(jr),n=Sr.join(t,"multi-gitter_DEPENDENCY_TREE.yml");try{await Pr.writeFile(n,r,"utf8"),e.succeed(`Multi-gitter configuration written to ${n}`)}catch(o){e.fail("Error writing multi-gitter configuration:"),console.error(o)}}import ue from"node:fs";function et(t){let e={},r=[],n=[],o=[];for(let s in t)e[s]=t[s].dependsOn.length;for(let s in e)e[s]===0&&o.push(s);for(;o.length>0;){n=[];let s=o.length;for(let i=0;i<s;i++){let a=o.shift();n.push(a);for(let l of t[a].dependentPackages)e[l]--,e[l]===0&&o.push(l)}r.push(n)}if(r.flat().length!==Object.keys(t).length)throw new Error("Circular dependency detected!");return r}function Rr(t){return ue.readdirSync(t).filter(e=>e.endsWith(".json"))}async function tt(t,e=[]){console.log(e);let r={},n=Rr(t);for(let o of n){if(o==="dependencyTree.json")continue;let s=ue.readFileSync(`${t}/${o}`,"utf-8"),i=JSON.parse(s),a=i.name,l=Object.keys(i.peerDependencies),c=Object.keys(i.devDependencies),m=Object.keys(i.dependencies);r[a]||(r[a]={dependsOn:[],dependentPackages:[]});let u=[...l,...c,...m];r[a].dependsOn=[...new Set(u)];for(let d of u)r[d]||(r[d]={dependsOn:[],dependentPackages:[]}),r[d].dependentPackages.includes(a)||r[d].dependentPackages.push(a)}if(e.length){let o=new Set;for(let[i,a]of Object.entries(r))a.dependsOn.some(l=>e.includes(l))&&o.add(i);for(let i of e)r[i]&&o.add(i);let s={};for(let i of o)s[i]={dependsOn:r[i].dependsOn.filter(a=>o.has(a)),dependentPackages:r[i].dependentPackages.filter(a=>o.has(a))};r=s}else console.log("No target dependencies provided - using all packages.");return ue.writeFileSync(`${t}/dependencyTree.json`,JSON.stringify(r,null,2)),r}var me=Y("run-migrations","config"),de=Y("run-migrations","outputs");var nt=["@aurodesignsystem/auro-accordion","@aurodesignsystem/auro-alert","@aurodesignsystem/auro-avatar","@aurodesignsystem/auro-background","@aurodesignsystem/auro-backtotop","@aurodesignsystem/auro-button","@aurodesignsystem/auro-badge","@aurodesignsystem/auro-banner","@aurodesignsystem/auro-card","@aurodesignsystem/auro-carousel","@aurodesignsystem/auro-datetime","@aurodesignsystem/auro-dialog","@aurodesignsystem/auro-drawer","@aurodesignsystem/auro-formkit","@aurodesignsystem/auro-flight","@aurodesignsystem/auro-flightline","@aurodesignsystem/auro-header","@aurodesignsystem/auro-hyperlink","@aurodesignsystem/auro-icon","@aurodesignsystem/auro-loader","@aurodesignsystem/auro-lockup","@aurodesignsystem/auro-nav","@aurodesignsystem/auro-pane","@aurodesignsystem/auro-popover","@aurodesignsystem/auro-sidenav","@aurodesignsystem/auro-skeleton","@aurodesignsystem/auro-slideshow","@aurodesignsystem/auro-table","@aurodesignsystem/auro-tabs","@aurodesignsystem/auro-toast"],Gi=[...nt,"@aurodesignsystem/auro-library","@aurodesignsystem/WebCoreStyleSheets","@aurodesignsystem/AuroDesignTokens","@aurodesignsystem/auro-cli","@alaskaairux/icons"];async function Fr(t){try{await pe.mkdir(de,{recursive:!0}),await pe.mkdir(me,{recursive:!0})}catch(o){console.error("Failed to create output or config directories:",o),process.exit(1)}let e=fe("Creating dependency tree...").start();e.text="Creating multi-gitter dependency tree configuration...",await Ze(me),e.text="Scraping dependencies from Auro packages...";let n=`multi-gitter run "node ${X("static","getAuroDeps.js")}" --config ${rt.join(me,"multi-gitter_DEPENDENCY_TREE.yml")}`;try{await y(n)}catch(o){e.fail("Failed to generate dependency tree:"),console.error(o),process.exit(1)}return e.text="Generating dependency tree JSON file using packages...",await tt(de,t),e.succeed("Dependency tree generated successfully."),rt.join(de,"dependencyTree.json")}var Mr=async t=>{let e=fe("Loading dependency tree...").start(),r=JSON.parse(await pe.readFile(t,"utf-8"));e.text="Processing dependency tree...";let n=et(r);return e.succeed("Dependency batches created successfully."),n},Bi=_r.command("agent").action(async t=>{let e=await Nr.prompt([{type:"select",name:"agentAction",message:"What agent action do you want to perform?",choices:[{name:"Run a migration on auro components",value:"run-migration"}],default:["run-migration"]},{type:"input",name:"migrationId",message:"What migration id do you want to run?",when:r=>r.agentAction==="run-migration",validate:r=>r.trim()!==""||"Migration id cannot be empty."},{type:"confirm",name:"useExisting",message:"Would you like to specify starting packages?",default:!0,transformer:r=>r?"Yes = Packages related to selections":"No = All packages",when:r=>r.agentAction==="run-migration"},{type:"checkbox",name:"startWithComponents",message:"Enter the components to start with (comma-separated, blank for all):",choices:nt.map(r=>({name:r.replace("@aurodesignsystem/",""),value:r})),when:r=>r.agentAction==="run-migration"&&r.useExisting}]);switch(e.agentAction){case"run-migration":{let r=fe("Running migration...").start(),n=await Fr(e.startWithComponents);r.text="Getting dependency batches from tree...";let s=(await Mr(n)).map((i,a)=>`Batch ${a+1}
|
|
47
|
+
${i.map(l=>` - ${l.replace("@aurodesignsystem","AlaskaAirlines").replace("@alaskaairux/icons","AlaskaAirlines/Icons")}`).join(`
|
|
48
48
|
`)}`).join(`
|
|
49
49
|
|
|
50
|
-
`);console.log(
|
|
50
|
+
`);console.log(s),r.text="Running migrations on dependency batches...",new Promise(i=>setTimeout(i,2e3)),r.succeed("Migration process completed successfully.");break}default:console.error("Unknown action selected.")}});import{program as Gr}from"commander";var Ui=Gr.command("docs").description("Generate API documentation").option("-c, --cem","Generate Custom Elements Manifest (CEM) file",!1).action(async t=>{t.cem&&await R(),await _()});import{program as Ur}from"commander";import{Octokit as ge}from"@octokit/rest";import*as q from"azure-devops-node-api";import z from"ora";var Br=async t=>{let e=process.env.GH_TOKEN;if(!e)throw new Error("GH_TOKEN environment variable is required");let r=new ge({auth:e}),n,o,s;if(t.includes("github.com")){let a=t.match(/github\.com\/([^\/]+)\/([^\/]+)\/issues\/(\d+)/);if(!a)throw new Error("Invalid GitHub issue URL format");[,n,o,s]=a}else if(t.includes("#")){let a=t.match(/([^\/]+)\/([^#]+)#(\d+)/);if(!a)throw new Error("Invalid GitHub issue reference format");[,n,o,s]=a}else throw new Error("Issue must be provided as full URL or in format 'owner/repo#number'");let i=Number.parseInt(s,10);try{let{data:a}=await r.rest.issues.get({owner:n,repo:o,issue_number:i});return{title:a.title,body:a.body??null,html_url:a.html_url,number:a.number,repository:{owner:{login:n},name:o}}}catch(a){throw new Error(`Failed to fetch GitHub issue: ${a}`)}},Hr=async t=>{let e=process.env.GH_TOKEN;if(!e)return null;let r=new ge({auth:e});try{let n=`
|
|
51
|
+
query($owner: String!, $repo: String!, $issueNumber: Int!) {
|
|
52
|
+
repository(owner: $owner, name: $repo) {
|
|
53
|
+
issue(number: $issueNumber) {
|
|
54
|
+
projectItems(first: 10) {
|
|
55
|
+
nodes {
|
|
56
|
+
project {
|
|
57
|
+
number
|
|
58
|
+
}
|
|
59
|
+
fieldValues(first: 20) {
|
|
60
|
+
nodes {
|
|
61
|
+
... on ProjectV2ItemFieldTextValue {
|
|
62
|
+
text
|
|
63
|
+
field {
|
|
64
|
+
... on ProjectV2Field {
|
|
65
|
+
name
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
`,o={owner:t.repository.owner.login,repo:t.repository.name,issueNumber:t.number},i=(await r.graphql(n,o)).repository.issue.projectItems.nodes.find(a=>a.project.number===19);if(i){let a=i.fieldValues.nodes.find(l=>l.field?.name?.toLowerCase()==="ado"&&l.text?.trim());if(a?.text?.trim())return a.text.trim()}return null}catch(n){return console.error(`Failed to check existing ADO link: ${n}`),null}},Lr=async(t,e)=>{let r=process.env.GH_TOKEN;if(!r)throw new Error("GH_TOKEN environment variable is required");let n=new ge({auth:r}),o=19;try{let s=`
|
|
77
|
+
query($org: String!, $projectNumber: Int!, $owner: String!, $repo: String!, $issueNumber: Int!) {
|
|
78
|
+
organization(login: $org) {
|
|
79
|
+
projectV2(number: $projectNumber) {
|
|
80
|
+
id
|
|
81
|
+
fields(first: 20) {
|
|
82
|
+
nodes {
|
|
83
|
+
... on ProjectV2Field {
|
|
84
|
+
id
|
|
85
|
+
name
|
|
86
|
+
}
|
|
87
|
+
... on ProjectV2SingleSelectField {
|
|
88
|
+
id
|
|
89
|
+
name
|
|
90
|
+
}
|
|
91
|
+
... on ProjectV2IterationField {
|
|
92
|
+
id
|
|
93
|
+
name
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
repository(owner: $owner, name: $repo) {
|
|
100
|
+
issue(number: $issueNumber) {
|
|
101
|
+
id
|
|
102
|
+
projectItems(first: 10) {
|
|
103
|
+
nodes {
|
|
104
|
+
id
|
|
105
|
+
project {
|
|
106
|
+
number
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
`,i={org:"AlaskaAirlines",projectNumber:o,owner:t.repository.owner.login,repo:t.repository.name,issueNumber:t.number},a=await n.graphql(s,i),l=a.organization.projectV2.id,c=a.repository.issue.id,m=a.organization.projectV2.fields.nodes.find(d=>d.name?.toLowerCase()==="ado"),u=a.repository.issue.projectItems.nodes.find(d=>d.project.number===o)?.id;if(u||(u=(await n.graphql(`
|
|
114
|
+
mutation($projectId: ID!, $contentId: ID!) {
|
|
115
|
+
addProjectV2ItemById(
|
|
116
|
+
input: {
|
|
117
|
+
projectId: $projectId
|
|
118
|
+
contentId: $contentId
|
|
119
|
+
}
|
|
120
|
+
) {
|
|
121
|
+
item {
|
|
122
|
+
id
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
`,{projectId:l,contentId:c})).addProjectV2ItemById.item.id),m&&u)await n.graphql(`
|
|
127
|
+
mutation($projectId: ID!, $itemId: ID!, $fieldId: ID!, $value: String!) {
|
|
128
|
+
updateProjectV2ItemFieldValue(
|
|
129
|
+
input: {
|
|
130
|
+
projectId: $projectId
|
|
131
|
+
itemId: $itemId
|
|
132
|
+
fieldId: $fieldId
|
|
133
|
+
value: {
|
|
134
|
+
text: $value
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
) {
|
|
138
|
+
projectV2Item {
|
|
139
|
+
id
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
`,{projectId:l,itemId:u,fieldId:m.id,value:e});else if(!m)throw new Error("No 'ado' field found in GitHub project")}catch(s){console.error(`Failed to update GitHub project: ${s}`)}},Wr=async t=>{let e=process.env.ADO_TOKEN;if(!e)throw new Error("ADO_TOKEN environment variable is required");let r="https://dev.azure.com/itsals",n="E_Retain_Content",o="E_Retain_Content\\Auro Design System",s=q.getPersonalAccessTokenHandler(e),a=await new q.WebApi(r,s).getWorkItemTrackingApi();try{let l=[{op:"add",path:"/fields/System.Title",value:t.title},{op:"add",path:"/fields/System.Description",value:`GitHub Issue: <a href="${t.html_url}">${t.html_url}</a>`},{op:"add",path:"/fields/System.AreaPath",value:o}];return await a.createWorkItem(null,l,n,"User Story")}catch(l){throw new Error(`Failed to create ADO work item: ${l}`)}},ot=async t=>{let e=z(`Processing GitHub issue: ${t}`).start();try{if(!process.env.GH_TOKEN)throw new Error("GH_TOKEN environment variable is required");if(!process.env.ADO_TOKEN)throw new Error("ADO_TOKEN environment variable is required");e.text="Fetching GitHub issue details...";let r=await Br(t);e.succeed(`Found issue: "${r.title}"`);let n=z("Checking for existing ADO work item...").start(),o=await Hr(r);if(o){n.succeed("ADO work item already exists for this issue!"),console.log(`${o}`);return}n.succeed("No existing ADO work item found");let s=z("Creating new ADO work item...").start(),i=await Wr(r);if(s.succeed(`Successfully created ADO work item #${i.id}`),console.log(`Work item: ${i._links?.html?.href||"N/A"}`),i._links?.html?.href){let a=z("Adding to GitHub project and updating ADO field...").start();await Lr(r,i._links.html.href),a.succeed("Updated GitHub project with ADO link")}}catch(r){e.fail(`Error: ${r instanceof Error?r.message:r}`),process.exit(1)}};var Xi=Ur.command("ado").description("Generate ADO item from GitHub issue").option("-g, --gh-issue <issue>","What GitHub issue to use").action(async t=>{t.ghIssue&&await ot(t.ghIssue)});he.name("auro").version(J()).description("A cli tool to support the Auro Design System");he.addHelpText("beforeAll",ye());he.parse();
|