@aurodesignsystem-dev/auro-cli 0.0.0-pr258.0 → 0.0.0-pr258.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 CHANGED
@@ -1,24 +1,24 @@
1
1
  #!/usr/bin/env node
2
- import{program as be}from"commander";import ut from"figlet";import{mind as dt}from"gradient-string";var ke=()=>dt(ut.textSync("Auro CLI"));import Ae from"node:fs";import $e from"node:path";import{fileURLToPath as pt}from"node:url";function S(e){process.env.DEBUG&&console.log(`[DEBUG] ${e}`)}function Y(){try{let e=pt(import.meta.url),t=$e.dirname(e);S(`Current module path: ${t}`);let r=$e.resolve(t,"..","package.json");return S(`Checking package.json at: ${r}`),Ae.existsSync(r)?(S(`Found package.json at: ${r}`),JSON.parse(Ae.readFileSync(r,"utf8")).version):(S("Could not find package.json in the standard installed module location, using default version"),"0.0.0")}catch(e){return console.error("Error retrieving package version:",e),"0.0.0"}}import{program as qt}from"commander";import Le from"ora";function I(e){return e.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 j(e){return e.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 Wt from"@rollup/plugin-terser";import{watch as Lt}from"rollup";import{rmSync as Ct}from"node:fs";import{join as St}from"node:path";import te from"ora";import{rollup as Ie}from"rollup";import ee from"ora";import{spawn as ft}from"node:child_process";import gt from"ora";var b=(e,t)=>{let r=`${e} ${t?t.join(" "):""}`,n=gt(),o=e,i=t||[];if(!t&&typeof e=="string"){let u=e.split(" ");o=u[0],i=u.slice(1)}let s=r.includes("--watch")||r.includes(" -w"),l=ft(o,i,{stdio:s?"inherit":["inherit","pipe","pipe"],shell:!0});if(!s){let u=[];l.stdout?.on("data",m=>{let a=m.toString();u.push(a),process.stdout.write(a)}),l.stderr?.on("data",m=>{let a=m.toString();u.push(a),process.stderr.write(a)})}return new Promise((u,m)=>{l.on("close",a=>{a!==0?s?(n.info(`Watch mode terminated with code ${a}`),u()):(n.fail(`${r} failed (code ${a})`),m(new Error(`Command failed with exit code ${a}`))):(n.succeed(`${r} completed successfully`),u())})})};import O from"node:fs";import ht from"node:path";import{markdownTable as ve}from"markdown-table";var x=class e{static{this.manifest={schemaVersion:"1.0.0",readme:"",modules:[]}}static generate(t={}){let{outDir:r="./docs",outFile:n="api.md",manifestPath:o="./custom-elements.json"}=t,{getElements:i,renderAllElements:s}=e;if(o)try{let a=O.readFileSync(o,"utf8");e.manifest=JSON.parse(a)}catch(a){throw console.error(`Error reading manifest file at ${o}:`,a),a}let c=i(),l=r;O.existsSync(l)||O.mkdirSync(l,{recursive:!0});let u=s(c),m=ht.join(l,n);O.writeFileSync(m,u),console.log(`Generated combined API documentation at ${m}`)}static getElements(){let t=e.manifest.modules.filter(e.isWcaModule);return e.manifest.modules.reduce((r,n)=>r.concat(n.declarations?.filter(o=>"customElement"in o&&o.customElement===!0&&"tagName"in o&&(t.length>0?e.isWcaModule(n):!0))??[]),[])}static isWcaModule(t){let{path:r}=t;return r?r.startsWith("scripts/wca/auro-")&&r.endsWith(".js"):!1}static renderAllElements(t){return`${t.sort((r,n)=>(r.tagName||"").localeCompare(n.tagName||"")).map(r=>e.renderElement(r,!0)).join(`
2
+ import{program as ke}from"commander";import ut from"figlet";import{mind as dt}from"gradient-string";var Ae=()=>dt(ut.textSync("Auro CLI"));import $e from"node:fs";import ve from"node:path";import{fileURLToPath as pt}from"node:url";function C(e){process.env.DEBUG&&console.log(`[DEBUG] ${e}`)}function Y(){try{let e=pt(import.meta.url),t=ve.dirname(e);C(`Current module path: ${t}`);let r=ve.resolve(t,"..","package.json");return C(`Checking package.json at: ${r}`),$e.existsSync(r)?(C(`Found package.json at: ${r}`),JSON.parse($e.readFileSync(r,"utf8")).version):(C("Could not find package.json in the standard installed module location, using default version"),"0.0.0")}catch(e){return console.error("Error retrieving package version:",e),"0.0.0"}}import{program as Vt}from"commander";import Le from"ora";function I(e){return e.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 j(e){return e.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 Lt from"@rollup/plugin-terser";import{watch as Ut}from"rollup";import{rmSync as Ct}from"node:fs";import{join as It}from"node:path";import re from"ora";import{rollup as Ie}from"rollup";import te from"ora";import{spawn as ft}from"node:child_process";import gt from"ora";var b=(e,t)=>{let r=`${e} ${t?t.join(" "):""}`,n=gt(),o=e,s=t||[];if(!t&&typeof e=="string"){let u=e.split(" ");o=u[0],s=u.slice(1)}let i=r.includes("--watch")||r.includes(" -w"),l=ft(o,s,{stdio:i?"inherit":["inherit","pipe","pipe"],shell:!0});if(!i){let u=[];l.stdout?.on("data",m=>{let a=m.toString();u.push(a),process.stdout.write(a)}),l.stderr?.on("data",m=>{let a=m.toString();u.push(a),process.stderr.write(a)})}return new Promise((u,m)=>{l.on("close",a=>{a!==0?i?(n.info(`Watch mode terminated with code ${a}`),u()):(n.fail(`${r} failed (code ${a})`),m(new Error(`Command failed with exit code ${a}`))):(n.succeed(`${r} completed successfully`),u())})})};import O from"node:fs";import ht from"node:path";import{markdownTable as Ee}from"markdown-table";var x=class e{static{this.manifest={schemaVersion:"1.0.0",readme:"",modules:[]}}static generate(t={}){let{outDir:r="./docs",outFile:n="api.md",manifestPath:o="./custom-elements.json"}=t,{getElements:s,renderAllElements:i}=e;if(o)try{let a=O.readFileSync(o,"utf8");e.manifest=JSON.parse(a)}catch(a){throw console.error(`Error reading manifest file at ${o}:`,a),a}let c=s(),l=r;O.existsSync(l)||O.mkdirSync(l,{recursive:!0});let u=i(c),m=ht.join(l,n);O.writeFileSync(m,u),console.log(`Generated combined API documentation at ${m}`)}static getElements(){let t=e.manifest.modules.filter(e.isWcaModule);return e.manifest.modules.reduce((r,n)=>r.concat(n.declarations?.filter(o=>"customElement"in o&&o.customElement===!0&&"tagName"in o&&(t.length>0?e.isWcaModule(n):!0))??[]),[])}static isWcaModule(t){let{path:r}=t;return r?r.startsWith("scripts/wca/auro-")&&r.endsWith(".js"):!1}static renderAllElements(t){return`${t.sort((r,n)=>(r.tagName||"").localeCompare(n.tagName||"")).map(r=>e.renderElement(r,!0)).join(`
3
3
 
4
- `)}`}static renderElement(t,r=!0){let n=[],{renderTable:o,renderPropertiesAttributesTable:i,renderParameters:s,getType:c}=e;n.push(r?`# ${t.tagName}`:""),t.description&&n.push(t.description);let l=i(t);l&&n.push(l.trim());let u=o("Methods",["name","parameters","return","description"],(t.members||[]).filter(f=>f.kind==="method"&&("privacy"in f?f.privacy!=="private":!0)&&f.name[0]!=="_").map(f=>({...f,parameters:s("parameters"in f?f.parameters:void 0),return:"return"in f&&f.return?c(f.return):""})));u&&n.push(u.trim());let m=o("Events",["name","description"],t.events);m&&n.push(m.trim());let a=o("Slots",[["name","(default)"],"description"],t.slots);a&&n.push(a.trim());let d=o("CSS Shadow Parts",["name","description"],t.cssParts);d&&n.push(d.trim());let g=o("CSS Custom Properties",["name","description"],t.cssProperties);return g&&n.push(g.trim()),n.join(`
4
+ `)}`}static renderElement(t,r=!0){let n=[],{renderTable:o,renderPropertiesAttributesTable:s,renderParameters:i,getType:c}=e;n.push(r?`# ${t.tagName}`:""),t.description&&n.push(t.description);let l=s(t);l&&n.push(l.trim());let u=o("Methods",["name","parameters","return","description"],(t.members||[]).filter(f=>f.kind==="method"&&("privacy"in f?f.privacy!=="private":!0)&&f.name[0]!=="_").map(f=>({...f,parameters:i("parameters"in f?f.parameters:void 0),return:"return"in f&&f.return?c(f.return):""})));u&&n.push(u.trim());let m=o("Events",["name","description"],t.events);m&&n.push(m.trim());let a=o("Slots",[["name","(default)"],"description"],t.slots);a&&n.push(a.trim());let d=o("CSS Shadow Parts",["name","description"],t.cssParts);d&&n.push(d.trim());let g=o("CSS Custom Properties",["name","description"],t.cssProperties);return g&&n.push(g.trim()),n.join(`
5
5
 
6
- `)}static renderPropertiesAttributesTable(t){let{getType:r,escapeMarkdown:n}=e,o=t.members?.filter(a=>a.kind==="field"&&("privacy"in a?a.privacy!=="private":!0)&&a.name[0]!=="_")||[],i=t.attributes||[],s=[],c=new Set;if(o.forEach(a=>{if(a.description?.trim()){let d=r(a)||"",f=("return"in a&&a.return?r(a.return):"")||d;s.push({name:a.name,properties:a.name,attributes:("attribute"in a?a.attribute:"")||"",modifiers:"readonly"in a&&a.readonly?"readonly":"",type:f,default:("default"in a?a.default:"")||"",description:a.description||""})}c.add(a.name),"attribute"in a&&a.attribute&&c.add(a.attribute)}),i.forEach(a=>{!c.has(a.name)&&a.description?.trim()&&s.push({name:a.name,properties:"",attributes:a.name,modifiers:"",type:r(a)||"",default:a.default||"",description:a.description||""})}),s.length===0)return"";let l=["Properties","Attributes","Modifiers","Type","Default","Description"],u=s.map(a=>{let y=(a.default||"").trim().replace(/^'([^']+)'$/,"$1").replace(/^"([^"]+)"$/,"$1"),E=y?y.startsWith("`")&&y.endsWith("`")?y:`\`${y}\``:"";return[n(a.properties),n(a.attributes),n(a.modifiers),n(a.type),n(E),n(a.description)]});return`### Properties & Attributes
6
+ `)}static renderPropertiesAttributesTable(t){let{getType:r,escapeMarkdown:n}=e,o=t.members?.filter(a=>a.kind==="field"&&("privacy"in a?a.privacy!=="private":!0)&&a.name[0]!=="_")||[],s=t.attributes||[],i=[],c=new Set;if(o.forEach(a=>{if(a.description?.trim()){let d=r(a)||"",f=("return"in a&&a.return?r(a.return):"")||d;i.push({name:a.name,properties:a.name,attributes:("attribute"in a?a.attribute:"")||"",modifiers:"readonly"in a&&a.readonly?"readonly":"",type:f,default:("default"in a?a.default:"")||"",description:a.description||""})}c.add(a.name),"attribute"in a&&a.attribute&&c.add(a.attribute)}),s.forEach(a=>{!c.has(a.name)&&a.description?.trim()&&i.push({name:a.name,properties:"",attributes:a.name,modifiers:"",type:r(a)||"",default:a.default||"",description:a.description||""})}),i.length===0)return"";let l=["Properties","Attributes","Modifiers","Type","Default","Description"],u=i.map(a=>{let y=(a.default||"").trim().replace(/^'([^']+)'$/,"$1").replace(/^"([^"]+)"$/,"$1"),E=y?y.startsWith("`")&&y.endsWith("`")?y:`\`${y}\``:"";return[n(a.properties),n(a.attributes),n(a.modifiers),n(a.type),n(E),n(a.description)]});return`### Properties & Attributes
7
7
 
8
- ${ve([l,...u])}
9
- `}static renderParameters(t){let{escapeMarkdown:r,getType:n}=e;return!t||t.length===0?"None":t.map(o=>{let i=n(o)||"any",s=o.description?` - ${o.description}`:"";return`\`${o.name}\` (${r(i)})${r(s)}`}).join("<br>")}static renderTable(t,r,n){let{escapeMarkdown:o,get:i,capitalize:s}=e;if(n===void 0||n.length===0)return"";let c=n.filter(a=>{let{description:d}=a;return typeof d=="string"&&d.trim()});if(c.length===0)return"";let l=r.map(a=>s((Array.isArray(a)?a[0]:a).split(".")[0])),u=c.map(a=>r.map(d=>{let g=i(a,d);return o(String(g||""))})),m=ve([l,...u]);return`### ${t}
8
+ ${Ee([l,...u])}
9
+ `}static renderParameters(t){let{escapeMarkdown:r,getType:n}=e;return!t||t.length===0?"None":t.map(o=>{let s=n(o)||"any",i=o.description?` - ${o.description}`:"";return`\`${o.name}\` (${r(s)})${r(i)}`}).join("<br>")}static renderTable(t,r,n){let{escapeMarkdown:o,get:s,capitalize:i}=e;if(n===void 0||n.length===0)return"";let c=n.filter(a=>{let{description:d}=a;return typeof d=="string"&&d.trim()});if(c.length===0)return"";let l=r.map(a=>i((Array.isArray(a)?a[0]:a).split(".")[0])),u=c.map(a=>r.map(d=>{let g=s(a,d);return o(String(g||""))})),m=Ee([l,...u]);return`### ${t}
10
10
 
11
11
  ${m}
12
- `}static escapeMarkdown(t){return t.replace(/\\/g,"\\\\").replace(/\n/g,"<br>").replace(/\|/g,"\\|")}static getType(t){if(!t||!t.type)return"";let{type:r}=t,n=i=>i.replace(/\s*\|\s*/g," | ").replace(/'([^']+)'/g,"`$1`");if(typeof r=="string")return n(r);if(r.text)return n(r.text);if(Array.isArray(r))return r.map(i=>typeof i=="string"?i:i.text?i.text:i.name?i.name:String(i)).join(" \\| ");if(r.name)return n(r.name);if(r.references&&Array.isArray(r.references))return r.references.map(i=>i.name||String(i)).join(" \\| ");let o=String(r);return n(o)}static get(t,r){let n="",o=r;Array.isArray(r)&&([o,n]=r);let i=o.split("."),s=t;for(;s&&i.length;)s=s[i.shift()];return s==null||s===""?n:String(s)}static capitalize(t){return t.replace(/([A-Z])/g," $1").replace(/^./,r=>r.toUpperCase()).trim()}};import yt from"node:fs";import wt from"node:os";import R from"node:path";import X from"node:process";function bt(){let e=wt.homedir()||X.env.HOME||X.env.USERPROFILE;if(!e)throw new Error("Unable to determine user home directory");return R.join(e,".auro")}function Z(...e){return R.join(bt(),...e)}function Q(...e){let t=yt.realpathSync(X.argv[1]),r=R.dirname(t);return R.resolve(r,...e)}var Ee=e=>Q("configs",e);import{Logger as kt}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import{generateReadmeUrl as At,processContentForFile as $t,templateFiller as Pe}from"@aurodesignsystem/auro-library/scripts/utils/sharedFileProcessorUtils.mjs";import xe from"node:fs";import vt from"node:path";var Te="/docs/pages",De={overwriteLocalCopies:!0,remoteReadmeVersion:"master",remoteReadmeVariant:"_updated_paths"};function k(e){return`${process.cwd()}/${e}`}async function Et(e){let t=k(Te),r=[];xe.existsSync(t)&&(r=await xe.promises.readdir(t));let n=r.map(o=>({identifier:o,input:vt.join(k(Te),o),output:k(`/demo/${o}`)}));return[{identifier:"README.md",input:{remoteUrl:e.remoteReadmeUrl||At(e.remoteReadmeVersion,e.remoteReadmeVariant),fileName:k("/docTemplates/README.md"),overwrite:e.overwriteLocalCopies},output:k("/README.md")},{identifier:"index.md",input:k("/docs/partials/index.md"),output:k("/demo/index.md"),mdMagicConfig:{output:{directory:k("/demo")}}},{identifier:"api.md",input:k("/docs/partials/api.md"),output:k("/demo/api.md"),preProcessors:[Pe.formatApiTable]},...n]}async function xt(e=De){await Pe.extractNames();let t=await Et(e);for(let r of t)try{await $t(r)}catch(n){kt.error(`Error processing ${r.identifier}: ${n.message}`)}}async function N(){await xt({...De,remoteReadmeUrl:"https://raw.githubusercontent.com/AlaskaAirlines/auro-templates/main/templates/default/README.md"})}import{startDevServer as Tt}from"@web/dev-server";import{hmrPlugin as Pt}from"@web/dev-server-hmr";import Dt from"ora";var T={watch:!0,nodeResolve:!0,basePath:"/",rootDir:"./demo",hmrInclude:["src/**/*","demo/**/*","apiExamples/**/*","docs/**/*"]};async function F(e={}){if(!e.serve)return;let t=Dt(`Firing up dev server...
13
- `).start();try{let r={port:Number(e.port)||void 0,open:e.open?"/":void 0,watch:e.watch??T.watch,nodeResolve:e.nodeResolve??T.nodeResolve,basePath:e.basePath??T.basePath,rootDir:e.rootDir??T.rootDir,middleware:[function(i,s){return!i.url.endsWith("/")&&!i.url.includes(".")&&(i.url+=".html"),s()}],plugins:[Pt({include:e.hmrInclude??T.hmrInclude})]},n=await Tt({config:r,readCliArgs:!1,readFileConfig:!1});return t.stop(),n}catch(r){throw t.fail("Server snag! Couldn't start dev server."),console.error("Error starting development server:",r),new Error(`Development server failed to start: ${r.message}`)}}async function G(){let e=ee("Generating Custom Elements Manifest...").start();try{await b(`npx --package=@custom-elements-manifest/analyzer -y -- cem analyze --config '${Ee("custom-elements-manifest.config.mjs")}'`),e.succeed("Custom Elements Manifest generated successfully!")}catch(t){let r=t instanceof Error?t.message:String(t);e.warn("CEM analyzer completed with warnings: "+r)}}async function M(){let e=ee("Generating API md file...").start();try{await x.generate(),e.succeed("API md file generated successfully!")}catch(t){let r=t instanceof Error?t.message:String(t);throw e.fail("Failed to generate API md file: "+r),t}}async function Ce(){let e=ee("Compiling documentation...").start();try{await N(),e.succeed("Documentation compiled successfully!")}catch(t){let r=t instanceof Error?t.message:String(t);throw e.fail("Failed to compile MD documentation: "+r),t}}async function Se(e={}){await F(e)}async function _(){await G(),await M()}function je(){let e=St("./dist"),t=te("Cleaning dist folder...").start();try{return Ct(e,{recursive:!0,force:!0}),t.succeed("All clean! Dist folder wiped."),!0}catch(r){return t.fail(`Oops! Couldn't clean dist/ folder: ${r.message}`),console.error(r),!1}}async function Oe(e,t,r,n){let o=te(e).start();try{let i=await t();return o.succeed(r),i}catch(i){throw o.fail(n),console.error(`Error: ${i.message}`),i}}async function Re(e,t){return Oe(`Bundling ${e.name||"main"} and ${t.name||"demo"}...`,async()=>{let r=await Ie(e);await r.write(e.output),await r.close();let n=await Ie(t);await n.write(t.output),await n.close()},`Bundles ready! ${e.name||"Main"} and ${t.name||"demo"} built.`,"Bundle hiccup! Build failed.")}async function B(e){let{wcaInput:t,wcaOutput:r,skipDocs:n}=e;if(n){let o=te("Skipping docs generation...").start();setTimeout(()=>{o.succeed("Docs generation skipped.")},0);return}return Oe("Analyzing components and making docs...",async()=>{await _(t,r),await N()},"Docs ready! Looking good.","Doc troubles!")}import{basename as Ot,join as Fe}from"node:path";import{nodeResolve as Rt}from"@rollup/plugin-node-resolve";import{glob as Nt}from"glob";import{litScss as Ft}from"rollup-plugin-scss-lit";import It from"node:path";import{glob as jt}from"glob";function Ne(e){return{name:"watch-globs",buildStart(){let t=Array.isArray(e)?e:[e];for(let r of t)try{for(let n of jt.sync(It.resolve(r)))this.addWatchFile(n)}catch(n){this.error(`Error watching glob pattern "${r}": ${n.message}`)}}}}var re={moduleDirectories:["node_modules"],modulePaths:["../../node_modules","../node_modules","node_modules"],watchPatterns:["./apiExamples/**/*","./docs/**/*"]};function Ge(e=[],t={}){let{watchPatterns:r=re.watchPatterns,dedupe:n=["lit","lit-element","lit-html"],dev:o=!1}=t,i=[...re.modulePaths,...e];return[Rt({dedupe:n,preferBuiltins:!1,moduleDirectories:re.moduleDirectories}),Ft({minify:o?!1:{fast:!0},options:{loadPaths:[...i,Fe(process.cwd(),"src","styles"),Fe(process.cwd(),"src")]}}),Ne(r)]}function ne(e={}){let{modulePaths:t=[],watch:r=!1,input:n=["./src/index.js","./src/registered.js"],outputDir:o="./dist",format:i="esm",dev:s=!1}=e;return{name:"Main",config:{input:n,output:{format:i,dir:o,entryFileNames:c=>s||["index","registered"].includes(c.name)?"[name].js":"[name]-[hash].js",chunkFileNames:s?"[name].js":"[name]-[hash].js",assetFileNames:s?"[name][extname]":"[name]-[hash][extname]"},external:Gt(),plugins:Ge(t,{dev:s}),watch:Me(r)}}}function oe(e={}){let{modulePaths:t=[],watch:r=!1,globPattern:n="./demo/*.js",ignorePattern:o=["./demo/*.min.js"],outputDir:i="./demo",dev:s=!1}=e;return{name:"Demo",config:{input:Object.fromEntries(Nt.sync(n,{ignore:o}).map(c=>[Ot(c,".js"),c])),output:{format:"esm",dir:i,entryFileNames:"[name].min.js",chunkFileNames:"[name].min.js",assetFileNames:s?"[name][extname]":"[name]-[hash][extname]"},plugins:Ge(t,{dev:s}),watch:Me(r)}}}function Me(e){if(!e)return!1;let t=typeof e=="object"?e:{};return{clearScreen:t.clearScreen??!0,buildDelay:t.buildDelay??500,chokidar:{ignoreInitial:!0,ignored:t.ignored??["**/dist/**/*.d.ts","**/custom-elements.json","**/demo/*.md","**/demo/**/*.min.js","**/docs/api.md","**/node_modules/**","**/.git/**"],awaitWriteFinish:t.awaitWriteFinish??{stabilityThreshold:1e3,pollInterval:100}},include:t.include??["./src/**/*.scss","./src/**/*.js","./src/**/*.ts","./demo/**/*.js","./apiExamples/**/*","./docs/**/*.md"],exclude:t.exclude??["./dist/**/*","./node_modules/**/*"]}}function Gt(e=[]){return[...[/node_modules\/lit/,/node_modules\/lit-element/,/node_modules\/lit-html/,/node_modules\/@lit/],...e]}import Be from"node:path";import $ from"ora";import"rollup";var H=!1,Mt={analyze:{active:!1,lastTime:0},docs:{active:!1,lastTime:0}},_t=5e3,W=new Set,Bt=["/dist/index.d.ts","/custom-elements.json","/demo/api.md","/docs/api.md","/demo/index.min.js"];function Ht(e){if(!e||typeof e!="string")return!1;try{let t=Be.normalize(e);return Bt.some(r=>t.endsWith(r))||t.includes("/dist/")||t.endsWith(".min.js")||t.endsWith(".d.ts")}catch(t){return console.error(`Error checking path (${typeof e}):`,t.message),!1}}async function _e(e,t){let r=Mt[e];if(r.active||Date.now()-r.lastTime<_t)return!1;try{return r.active=!0,r.lastTime=Date.now(),await t()}catch(n){return console.error(`Error in ${e} task:`,n),!1}finally{r.active=!1}}async function He(e,t,r){let n=!0,o={analyze:!1,docs:!1},i=null,s,c=$("Activating watch mode...").start(),l={analyze:async()=>{let{wcaInput:a,wcaOutput:d,skipDocs:g}=t;if(g){let y=$("Skipping component analysis...").start();return setTimeout(()=>{y.succeed("Component analysis skipped.")},0),!0}let f=$("Detective work: analyzing components...").start();try{return await _(a,d),f.succeed("Component analysis complete! API generated."),!0}catch(y){return f.fail("Analysis hiccup! Something went wrong."),console.error("Component analysis error:",y),!1}},docs:async()=>{if(H)return!1;if(t.skipDocs){let d=$("Skipping docs generation...").start();return setTimeout(()=>{d.succeed("Docs generation skipped.")},0),!0}let a=$("Refreshing docs...").start();try{return await B(t),a.succeed("Documentation refreshed!"),!0}catch(d){a.fail("Docs stumble! Couldn't refresh."),console.error("Documentation rebuild error:",d)}}},u=()=>{n&&o.analyze&&o.docs&&typeof r=="function"&&(n=!1,r())};function m(a=1e3){i&&clearTimeout(i),i=setTimeout(async()=>{setTimeout(async()=>{o.analyze=await _e("analyze",l.analyze),setTimeout(async()=>{o.docs=await _e("docs",l.docs),u()},1e3)},1e3)},a)}e.on("event",async a=>{switch(a.code){case"START":c.succeed("Watch mode active! Eyes peeled.");break;case"BUNDLE_START":if(W.clear(),a.input)try{let d=Array.isArray(a.input)?a.input:typeof a.input=="string"?[a.input]:typeof a.input=="object"&&a.input!==null?Object.values(a.input):[];for(let g of d)typeof g=="string"&&!Ht(g)&&W.add(Be.normalize(g))}catch(d){console.error("Error processing input paths:",d)}s=$("Weaving bundles...").start(),H=!0;break;case"BUNDLE_END":s&&s.succeed(`Bundle ${Array.isArray(a.input)?`of ${a.input.join("& ")} `:""}done in ${a.duration}ms! \u{1F680}`),H=!1,W.size>0&&m();break;case"END":break;case"ERROR":H=!1,s?s.fail(`Oops! Bundle hit a snag: ${a.error.message}`):$().fail(`Watch mode hiccup: ${a.error.message}`),W.clear();break}})}function We(e){return process.on("SIGINT",()=>{let t=$("Wrapping up...").start();e.close(),t.succeed("All done! See you next time. \u2728"),process.exit(0)}),e}async function Ut(e){let t=ne(e),r=oe(e);e.dev||t.config.plugins.push(Wt()),await B(e),await Re(t.config,r.config)}async function zt(e){let{dev:t}=e,r=ne({...e,watch:!0}),n=oe({...e,watch:!0}),o=Lt([r.config,n.config]);return He(o,e,t?async()=>F(e):void 0),We(o),o}async function L(e={}){try{let{watch:t}=e;return je(),t?await zt(e):await Ut(e)}catch(t){throw new Error(`Build failed: ${t.message}`)}}var P=qt.command("dev").description("Runs development server for auro components");P=I(P);P=j(P);var uo=P.action(async e=>{try{let t=Le("Initializing...");e.watch?(t.text="Waiting for changes...",t.spinner="bouncingBar",t.color="green"):t.text=e.docs===!1?"Building component (docs disabled)":"Building component",t.start(),e.watch||t.succeed("Build completed!"),await L({...e,dev:!0,watch:e.watch})}catch(t){Le().fail(`Build failed: ${t.message}`),console.error(t),process.exit(1)}});import{program as Vt}from"commander";import Ue from"ora";var ie=Vt.command("build").description("Builds auro components");ie=I(ie);var wo=ie.action(async e=>{try{let t=Ue("Initializing...");e.watch?(t.text="Waiting for changes...",t.spinner="bouncingBar",t.color="green"):t.text=e.docs===!1?"Building component (docs disabled)":"Building component",t.start(),await L(e),e.watch||t.succeed("Build completed!")}catch(t){Ue().fail(`Build failed: ${t.message}`),console.error(t),process.exit(1)}});import{exec as Jt}from"node:child_process";import ze from"node:path";import Kt from"node:process";import{fileURLToPath as Yt}from"node:url";import Xt from"node:util";import{program as Zt}from"commander";import Qt from"inquirer";var Do=Zt.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 e=>{let t=Yt(import.meta.url),r=ze.dirname(t),n=ze.resolve(r,"migrations",e.id);if(e.multiGitter){let o=Xt.promisify(Jt);try{await o("command -v multi-gitter")}catch{console.error("multi-gitter is not installed."),Kt.exit(1)}(await Qt.prompt([{type:"confirm",name:"dryRun",message:"Run migration in dry-run mode? (no changes will be committed)",default:!0}])).dryRun?b(`multi-gitter run ${n}/script.sh --config "${n}/multi-gitter.yml" --dry-run`):b(`multi-gitter run ${n}/script.sh --config "${n}/multi-gitter.yml"`)}else b(`${n}/script.sh`)});import or from"node:process";import{program as ir}from"commander";import{readFile as sr,writeFile as ar}from"node:fs/promises";import{Logger as ce}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import se from"node:fs/promises";import ae from"node:path";import{Octokit as er}from"@octokit/rest";import A from"ora";import{processContentForFile as tr,templateFiller as rr}from"@aurodesignsystem/auro-library/scripts/utils/sharedFileProcessorUtils.mjs";async function qe(e,t){let o=(await new er({auth:process.env.GITHUB_TOKEN||""}).request("GET /repos/{owner}/{repo}/contents/{path}",{ref:t,owner:"AlaskaAirlines",repo:"auro-templates",path:e,headers:{"X-GitHub-Api-Version":"2022-11-28"}})).data;if(typeof o!="object"||!Array.isArray(o)){let i=`Unexpected response format: ${JSON.stringify(o)}`;throw A().start().fail(i),new Error("Failed to retrieve folder items")}return o}async function Ve({folderItems:e,templatePathToReplace:t,rootDir:r,ref:n}){let o=[];for(let i of e){if(i.type=="dir"){let u=A(`Processing directory: ${i.path}`).start(),m=await qe(i.path,n);u.succeed(`Found ${m.length} additional items in ${i.path}`);let a=await Ve({folderItems:m,templatePathToReplace:t,rootDir:r,ref:n});o.push(...a);continue}let s=i.path.replace(`${t}/`,""),c=`${r}/.github/${s}`,l={identifier:i.name,input:{remoteUrl:i.download_url||"",fileName:c,overwrite:!0},output:c};o.push(l)}return o}async function nr(e){try{await se.rm(e,{recursive:!0,force:!0}),A().start().succeed(`Successfully removed directory: ${e}`)}catch(t){throw A().start().fail(`Error removing directory ${e}: ${t.message}`),t}}async function Je(e,t="",r=!0){try{let n=await se.stat(e),o=ae.basename(e);if(!n.isDirectory())return`${t}${r?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 "}${o}
14
- `;let i=`${t}${r?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 "}${o}/
15
- `;try{let c=(await se.readdir(e)).sort();for(let l=0;l<c.length;l++){let u=c[l],m=ae.join(e,u),a=l===c.length-1,d=t+(r?" ":"\u2502 ");i+=await Je(m,d,a)}}catch{i+=`${t}${r?" ":"\u2502 "}\u2514\u2500\u2500 [Permission denied or error reading directory]
16
- `}return i}catch(n){return`${t}${r?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 "}[Error: ${n}]
17
- `}}async function Ke(e,t="main"){e||(A().start().fail("Root directory must be specified"),process.exit(1));let r=".github",n=A("Removing existing .github directory...").start();try{await nr(r),n.succeed(".github directory removed successfully")}catch(l){n.fail(`Error removing .github directory: ${l.message}`),process.exit(1)}await rr.extractNames(),process.env.GITHUB_TOKEN||(A().start().fail("GITHUB_TOKEN environment variable is not set."),process.exit(1));let o="templates/default/.github",i=await qe(o,t),s=await Ve({folderItems:i,templatePathToReplace:o,rootDir:e,ref:t}),c=A("Processing all files...").start();try{await Promise.all(s.map(u=>tr(u))),c.succeed("All files processed.");let l=A("Generating directory tree...").start();try{let u=ae.join(e,".github"),m=await Je(u);l.succeed("Synced .github directory structure:"),console.log(m)}catch(u){l.fail(`Error generating directory tree: ${u.message}`)}}catch(l){c.fail(`Error processing files: ${l.message}`),process.exit(1)}}var Ho=ir.command("sync").option("-r, --ref <branch/tag/commit>","Git reference (branch/tag/commit) to use","main").description("Script runner to synchronize local repository configuration files").action(async e=>{ce.info("Synchronizing repository configuration files..."),ce.warn("Note: sync does not create a new git branch. Changes are added to the current branch.");let t=or.cwd();await Ke(t,e.ref);let r=`${t}/.github/CODEOWNERS`,o=(await sr(r,{encoding:"utf-8"})).replace(/\r\n/gu,`
12
+ `}static escapeMarkdown(t){return t.replace(/\\/g,"\\\\").replace(/\n/g,"<br>").replace(/\|/g,"\\|")}static getType(t){if(!t||!t.type)return"";let{type:r}=t,n=s=>s.replace(/\s*\|\s*/g," | ").replace(/'([^']+)'/g,"`$1`");if(typeof r=="string")return n(r);if(r.text)return n(r.text);if(Array.isArray(r))return r.map(s=>typeof s=="string"?s:s.text?s.text:s.name?s.name:String(s)).join(" \\| ");if(r.name)return n(r.name);if(r.references&&Array.isArray(r.references))return r.references.map(s=>s.name||String(s)).join(" \\| ");let o=String(r);return n(o)}static get(t,r){let n="",o=r;Array.isArray(r)&&([o,n]=r);let s=o.split("."),i=t;for(;i&&s.length;)i=i[s.shift()];return i==null||i===""?n:String(i)}static capitalize(t){return t.replace(/([A-Z])/g," $1").replace(/^./,r=>r.toUpperCase()).trim()}};import yt from"node:fs";import wt from"node:os";import R from"node:path";import X from"node:process";function bt(){let e=wt.homedir()||X.env.HOME||X.env.USERPROFILE;if(!e)throw new Error("Unable to determine user home directory");return R.join(e,".auro")}function Z(...e){return R.join(bt(),...e)}function Q(...e){let t=yt.realpathSync(X.argv[1]),r=R.dirname(t);return R.resolve(r,...e)}var xe=e=>Q("configs",e);import{Logger as kt}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import{generateReadmeUrl as At,processContentForFile as $t,templateFiller as Pe}from"@aurodesignsystem/auro-library/scripts/utils/sharedFileProcessorUtils.mjs";import ee from"node:fs";import vt from"node:path";var Et="/docs/pages",De={overwriteLocalCopies:!0,remoteReadmeVersion:"master",remoteReadmeVariant:"_updated_paths"};function k(e){return`${process.cwd()}/${e}`}async function xt(e){let t=[];t.push({identifier:"README.md",input:{remoteUrl:e.remoteReadmeUrl||At(e.remoteReadmeVersion,e.remoteReadmeVariant),fileName:k("/docTemplates/README.md"),overwrite:e.overwriteLocalCopies},output:k("/README.md")}),Te("/docs/partials/index.md")&&t.push({identifier:"index.md",input:k("/docs/partials/index.md"),output:k("/demo/index.md"),mdMagicConfig:{output:{directory:k("/demo")}}}),Te("/docs/partials/api.md")&&t.push({identifier:"api.md",input:k("/docs/partials/api.md"),output:k("/demo/api.md"),preProcessors:[Pe.formatApiTable]});let r=k(Et);if(ee.existsSync(r)){let o=(await ee.promises.readdir(r)).map(s=>({identifier:s,input:vt.join(r,s),output:k(`/demo/${s}`)}));t.push(...o)}return t}async function Tt(e=De){await Pe.extractNames();let t=await xt(e);for(let r of t)try{await $t(r)}catch(n){kt.error(`Error processing ${r.identifier}: ${n.message}`)}}async function N(){await Tt({...De,remoteReadmeUrl:"https://raw.githubusercontent.com/AlaskaAirlines/auro-templates/main/templates/default/README.md"})}function Te(e){return ee.existsSync(k(e))}import{startDevServer as Pt}from"@web/dev-server";import{hmrPlugin as Dt}from"@web/dev-server-hmr";import St from"ora";var T={watch:!0,nodeResolve:!0,basePath:"/",rootDir:"./demo",hmrInclude:["src/**/*","demo/**/*","apiExamples/**/*","docs/**/*"]};async function F(e={}){if(!e.serve)return;let t=St(`Firing up dev server...
13
+ `).start();try{let r={port:Number(e.port)||void 0,open:e.open?"/":void 0,watch:e.watch??T.watch,nodeResolve:e.nodeResolve??T.nodeResolve,basePath:e.basePath??T.basePath,rootDir:e.rootDir??T.rootDir,middleware:[function(s,i){return!s.url.endsWith("/")&&!s.url.includes(".")&&(s.url+=".html"),i()}],plugins:[Dt({include:e.hmrInclude??T.hmrInclude})]},n=await Pt({config:r,readCliArgs:!1,readFileConfig:!1});return t.stop(),n}catch(r){throw t.fail("Server snag! Couldn't start dev server."),console.error("Error starting development server:",r),new Error(`Development server failed to start: ${r.message}`)}}async function G(){let e=te("Generating Custom Elements Manifest...").start();try{await b(`npx --package=@custom-elements-manifest/analyzer -y -- cem analyze --config '${xe("custom-elements-manifest.config.mjs")}'`),e.succeed("Custom Elements Manifest generated successfully!")}catch(t){let r=t instanceof Error?t.message:String(t);e.warn("CEM analyzer completed with warnings: "+r)}}async function M(){let e=te("Generating API md file...").start();try{await x.generate(),e.succeed("API md file generated successfully!")}catch(t){let r=t instanceof Error?t.message:String(t);throw e.fail("Failed to generate API md file: "+r),t}}async function Se(){let e=te("Compiling documentation...").start();try{await N(),e.succeed("Documentation compiled successfully!")}catch(t){let r=t instanceof Error?t.message:String(t);throw e.fail("Failed to compile MD documentation: "+r),t}}async function Ce(e={}){await F(e)}async function _(){await G(),await M()}function je(){let e=It("./dist"),t=re("Cleaning dist folder...").start();try{return Ct(e,{recursive:!0,force:!0}),t.succeed("All clean! Dist folder wiped."),!0}catch(r){return t.fail(`Oops! Couldn't clean dist/ folder: ${r.message}`),console.error(r),!1}}async function Oe(e,t,r,n){let o=re(e).start();try{let s=await t();return o.succeed(r),s}catch(s){throw o.fail(n),console.error(`Error: ${s.message}`),s}}async function Re(e,t){return Oe(`Bundling ${e.name||"main"} and ${t.name||"demo"}...`,async()=>{let r=await Ie(e);await r.write(e.output),await r.close();let n=await Ie(t);await n.write(t.output),await n.close()},`Bundles ready! ${e.name||"Main"} and ${t.name||"demo"} built.`,"Bundle hiccup! Build failed.")}async function B(e){let{wcaInput:t,wcaOutput:r,skipDocs:n}=e;if(n){let o=re("Skipping docs generation...").start();setTimeout(()=>{o.succeed("Docs generation skipped.")},0);return}return Oe("Analyzing components and making docs...",async()=>{await _(t,r),await N()},"Docs ready! Looking good.","Doc troubles!")}import{basename as Rt,join as Fe}from"node:path";import{nodeResolve as Nt}from"@rollup/plugin-node-resolve";import{glob as Ft}from"glob";import{litScss as Gt}from"rollup-plugin-scss-lit";import jt from"node:path";import{glob as Ot}from"glob";function Ne(e){return{name:"watch-globs",buildStart(){let t=Array.isArray(e)?e:[e];for(let r of t)try{for(let n of Ot.sync(jt.resolve(r)))this.addWatchFile(n)}catch(n){this.error(`Error watching glob pattern "${r}": ${n.message}`)}}}}var ne={moduleDirectories:["node_modules"],modulePaths:["../../node_modules","../node_modules","node_modules"],watchPatterns:["./apiExamples/**/*","./docs/**/*"]};function Ge(e=[],t={}){let{watchPatterns:r=ne.watchPatterns,dedupe:n=["lit","lit-element","lit-html"],dev:o=!1}=t,s=[...ne.modulePaths,...e];return[Nt({dedupe:n,preferBuiltins:!1,moduleDirectories:ne.moduleDirectories}),Gt({minify:o?!1:{fast:!0},options:{loadPaths:[...s,Fe(process.cwd(),"src","styles"),Fe(process.cwd(),"src")]}}),Ne(r)]}function oe(e={}){let{modulePaths:t=[],watch:r=!1,input:n=["./src/index.js","./src/registered.js"],outputDir:o="./dist",format:s="esm",dev:i=!1}=e;return{name:"Main",config:{input:n,output:{format:s,dir:o,entryFileNames:c=>i||["index","registered"].includes(c.name)?"[name].js":"[name]-[hash].js",chunkFileNames:i?"[name].js":"[name]-[hash].js",assetFileNames:i?"[name][extname]":"[name]-[hash][extname]"},external:Mt(),plugins:Ge(t,{dev:i}),watch:Me(r)}}}function se(e={}){let{modulePaths:t=[],watch:r=!1,globPattern:n="./demo/*.js",ignorePattern:o=["./demo/*.min.js"],outputDir:s="./demo",dev:i=!1}=e;return{name:"Demo",config:{input:Object.fromEntries(Ft.sync(n,{ignore:o}).map(c=>[Rt(c,".js"),c])),output:{format:"esm",dir:s,entryFileNames:"[name].min.js",chunkFileNames:"[name].min.js",assetFileNames:i?"[name][extname]":"[name]-[hash][extname]"},plugins:Ge(t,{dev:i}),watch:Me(r)}}}function Me(e){if(!e)return!1;let t=typeof e=="object"?e:{};return{clearScreen:t.clearScreen??!0,buildDelay:t.buildDelay??500,chokidar:{ignoreInitial:!0,ignored:t.ignored??["**/dist/**/*.d.ts","**/custom-elements.json","**/demo/*.md","**/demo/**/*.min.js","**/docs/api.md","**/node_modules/**","**/.git/**"],awaitWriteFinish:t.awaitWriteFinish??{stabilityThreshold:1e3,pollInterval:100}},include:t.include??["./src/**/*.scss","./src/**/*.js","./src/**/*.ts","./demo/**/*.js","./apiExamples/**/*","./docs/**/*.md"],exclude:t.exclude??["./dist/**/*","./node_modules/**/*"]}}function Mt(e=[]){return[...[/node_modules\/lit/,/node_modules\/lit-element/,/node_modules\/lit-html/,/node_modules\/@lit/],...e]}import Be from"node:path";import $ from"ora";import"rollup";var H=!1,_t={analyze:{active:!1,lastTime:0},docs:{active:!1,lastTime:0}},Bt=5e3,W=new Set,Ht=["/dist/index.d.ts","/custom-elements.json","/demo/api.md","/docs/api.md","/demo/index.min.js"];function Wt(e){if(!e||typeof e!="string")return!1;try{let t=Be.normalize(e);return Ht.some(r=>t.endsWith(r))||t.includes("/dist/")||t.endsWith(".min.js")||t.endsWith(".d.ts")}catch(t){return console.error(`Error checking path (${typeof e}):`,t.message),!1}}async function _e(e,t){let r=_t[e];if(r.active||Date.now()-r.lastTime<Bt)return!1;try{return r.active=!0,r.lastTime=Date.now(),await t()}catch(n){return console.error(`Error in ${e} task:`,n),!1}finally{r.active=!1}}async function He(e,t,r){let n=!0,o={analyze:!1,docs:!1},s=null,i,c=$("Activating watch mode...").start(),l={analyze:async()=>{let{wcaInput:a,wcaOutput:d,skipDocs:g}=t;if(g){let y=$("Skipping component analysis...").start();return setTimeout(()=>{y.succeed("Component analysis skipped.")},0),!0}let f=$("Detective work: analyzing components...").start();try{return await _(a,d),f.succeed("Component analysis complete! API generated."),!0}catch(y){return f.fail("Analysis hiccup! Something went wrong."),console.error("Component analysis error:",y),!1}},docs:async()=>{if(H)return!1;if(t.skipDocs){let d=$("Skipping docs generation...").start();return setTimeout(()=>{d.succeed("Docs generation skipped.")},0),!0}let a=$("Refreshing docs...").start();try{return await B(t),a.succeed("Documentation refreshed!"),!0}catch(d){a.fail("Docs stumble! Couldn't refresh."),console.error("Documentation rebuild error:",d)}}},u=()=>{n&&o.analyze&&o.docs&&typeof r=="function"&&(n=!1,r())};function m(a=1e3){s&&clearTimeout(s),s=setTimeout(async()=>{setTimeout(async()=>{o.analyze=await _e("analyze",l.analyze),setTimeout(async()=>{o.docs=await _e("docs",l.docs),u()},1e3)},1e3)},a)}e.on("event",async a=>{switch(a.code){case"START":c.succeed("Watch mode active! Eyes peeled.");break;case"BUNDLE_START":if(W.clear(),a.input)try{let d=Array.isArray(a.input)?a.input:typeof a.input=="string"?[a.input]:typeof a.input=="object"&&a.input!==null?Object.values(a.input):[];for(let g of d)typeof g=="string"&&!Wt(g)&&W.add(Be.normalize(g))}catch(d){console.error("Error processing input paths:",d)}i=$("Weaving bundles...").start(),H=!0;break;case"BUNDLE_END":i&&i.succeed(`Bundle ${Array.isArray(a.input)?`of ${a.input.join("& ")} `:""}done in ${a.duration}ms! \u{1F680}`),H=!1,W.size>0&&m();break;case"END":break;case"ERROR":H=!1,i?i.fail(`Oops! Bundle hit a snag: ${a.error.message}`):$().fail(`Watch mode hiccup: ${a.error.message}`),W.clear();break}})}function We(e){return process.on("SIGINT",()=>{let t=$("Wrapping up...").start();e.close(),t.succeed("All done! See you next time. \u2728"),process.exit(0)}),e}async function zt(e){let t=oe(e),r=se(e);e.dev||t.config.plugins.push(Lt()),await B(e),await Re(t.config,r.config)}async function qt(e){let{dev:t}=e,r=oe({...e,watch:!0}),n=se({...e,watch:!0}),o=Ut([r.config,n.config]);return He(o,e,t?async()=>F(e):void 0),We(o),o}async function L(e={}){try{let{watch:t}=e;return je(),t?await qt(e):await zt(e)}catch(t){throw new Error(`Build failed: ${t.message}`)}}var P=Vt.command("dev").description("Runs development server for auro components");P=I(P);P=j(P);var po=P.action(async e=>{try{let t=Le("Initializing...");e.watch?(t.text="Waiting for changes...",t.spinner="bouncingBar",t.color="green"):t.text=e.docs===!1?"Building component (docs disabled)":"Building component",t.start(),e.watch||t.succeed("Build completed!"),await L({...e,dev:!0,watch:e.watch})}catch(t){Le().fail(`Build failed: ${t.message}`),console.error(t),process.exit(1)}});import{program as Jt}from"commander";import Ue from"ora";var ie=Jt.command("build").description("Builds auro components");ie=I(ie);var bo=ie.action(async e=>{try{let t=Ue("Initializing...");e.watch?(t.text="Waiting for changes...",t.spinner="bouncingBar",t.color="green"):t.text=e.docs===!1?"Building component (docs disabled)":"Building component",t.start(),await L(e),e.watch||t.succeed("Build completed!")}catch(t){Ue().fail(`Build failed: ${t.message}`),console.error(t),process.exit(1)}});import{exec as Kt}from"node:child_process";import ze from"node:path";import Yt from"node:process";import{fileURLToPath as Xt}from"node:url";import Zt from"node:util";import{program as Qt}from"commander";import er from"inquirer";var So=Qt.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 e=>{let t=Xt(import.meta.url),r=ze.dirname(t),n=ze.resolve(r,"migrations",e.id);if(e.multiGitter){let o=Zt.promisify(Kt);try{await o("command -v multi-gitter")}catch{console.error("multi-gitter is not installed."),Yt.exit(1)}(await er.prompt([{type:"confirm",name:"dryRun",message:"Run migration in dry-run mode? (no changes will be committed)",default:!0}])).dryRun?b(`multi-gitter run ${n}/script.sh --config "${n}/multi-gitter.yml" --dry-run`):b(`multi-gitter run ${n}/script.sh --config "${n}/multi-gitter.yml"`)}else b(`${n}/script.sh`)});import sr from"node:process";import{program as ir}from"commander";import{readFile as ar,writeFile as cr}from"node:fs/promises";import{Logger as le}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import ae from"node:fs/promises";import ce from"node:path";import{Octokit as tr}from"@octokit/rest";import A from"ora";import{processContentForFile as rr,templateFiller as nr}from"@aurodesignsystem/auro-library/scripts/utils/sharedFileProcessorUtils.mjs";async function qe(e,t){let o=(await new tr({auth:process.env.GITHUB_TOKEN||""}).request("GET /repos/{owner}/{repo}/contents/{path}",{ref:t,owner:"AlaskaAirlines",repo:"auro-templates",path:e,headers:{"X-GitHub-Api-Version":"2022-11-28"}})).data;if(typeof o!="object"||!Array.isArray(o)){let s=`Unexpected response format: ${JSON.stringify(o)}`;throw A().start().fail(s),new Error("Failed to retrieve folder items")}return o}async function Ve({folderItems:e,templatePathToReplace:t,rootDir:r,ref:n}){let o=[];for(let s of e){if(s.type=="dir"){let u=A(`Processing directory: ${s.path}`).start(),m=await qe(s.path,n);u.succeed(`Found ${m.length} additional items in ${s.path}`);let a=await Ve({folderItems:m,templatePathToReplace:t,rootDir:r,ref:n});o.push(...a);continue}let i=s.path.replace(`${t}/`,""),c=`${r}/.github/${i}`,l={identifier:s.name,input:{remoteUrl:s.download_url||"",fileName:c,overwrite:!0},output:c};o.push(l)}return o}async function or(e){try{await ae.rm(e,{recursive:!0,force:!0}),A().start().succeed(`Successfully removed directory: ${e}`)}catch(t){throw A().start().fail(`Error removing directory ${e}: ${t.message}`),t}}async function Je(e,t="",r=!0){try{let n=await ae.stat(e),o=ce.basename(e);if(!n.isDirectory())return`${t}${r?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 "}${o}
14
+ `;let s=`${t}${r?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 "}${o}/
15
+ `;try{let c=(await ae.readdir(e)).sort();for(let l=0;l<c.length;l++){let u=c[l],m=ce.join(e,u),a=l===c.length-1,d=t+(r?" ":"\u2502 ");s+=await Je(m,d,a)}}catch{s+=`${t}${r?" ":"\u2502 "}\u2514\u2500\u2500 [Permission denied or error reading directory]
16
+ `}return s}catch(n){return`${t}${r?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 "}[Error: ${n}]
17
+ `}}async function Ke(e,t="main"){e||(A().start().fail("Root directory must be specified"),process.exit(1));let r=".github",n=A("Removing existing .github directory...").start();try{await or(r),n.succeed(".github directory removed successfully")}catch(l){n.fail(`Error removing .github directory: ${l.message}`),process.exit(1)}await nr.extractNames(),process.env.GITHUB_TOKEN||(A().start().fail("GITHUB_TOKEN environment variable is not set."),process.exit(1));let o="templates/default/.github",s=await qe(o,t),i=await Ve({folderItems:s,templatePathToReplace:o,rootDir:e,ref:t}),c=A("Processing all files...").start();try{await Promise.all(i.map(u=>rr(u))),c.succeed("All files processed.");let l=A("Generating directory tree...").start();try{let u=ce.join(e,".github"),m=await Je(u);l.succeed("Synced .github directory structure:"),console.log(m)}catch(u){l.fail(`Error generating directory tree: ${u.message}`)}}catch(l){c.fail(`Error processing files: ${l.message}`),process.exit(1)}}var Wo=ir.command("sync").option("-r, --ref <branch/tag/commit>","Git reference (branch/tag/commit) to use","main").description("Script runner to synchronize local repository configuration files").action(async e=>{le.info("Synchronizing repository configuration files..."),le.warn("Note: sync does not create a new git branch. Changes are added to the current branch.");let t=sr.cwd();await Ke(t,e.ref);let r=`${t}/.github/CODEOWNERS`,o=(await ar(r,{encoding:"utf-8"})).replace(/\r\n/gu,`
18
18
  `).replace(/\n\n/gu,`
19
- `);await ar(r,o,{encoding:"utf-8"}),(o.includes("\r")||o.includes(`
19
+ `);await cr(r,o,{encoding:"utf-8"}),(o.includes("\r")||o.includes(`
20
20
 
21
- `))&&ce.error("CODEOWNERS file still has Windows line endings.")});import U from"node:fs";import D from"node:path";import{Logger as Xe}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import{program as cr}from"commander";import{glob as lr}from"glob";var Ye=(e,t)=>{let r=(e.match(/static register\(name \= (.+)\)/)||e.match(/customElements.get\((.+?)\)/))[1],n=e.match(/export class (.+) extends/)?.[1],o=e.match(/\/\*\*((.|\n)*?)(\*\n|\*\/|[@])/)?.[1]||"";return!r||!n?e:`
21
+ `))&&le.error("CODEOWNERS file still has Windows line endings.")});import U from"node:fs";import D from"node:path";import{Logger as Xe}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import{program as lr}from"commander";import{glob as mr}from"glob";var Ye=(e,t)=>{let r=(e.match(/static register\(name \= (.+)\)/)||e.match(/customElements.get\((.+?)\)/))[1],n=e.match(/export class (.+) extends/)?.[1],o=e.match(/\/\*\*((.|\n)*?)(\*\n|\*\/|[@])/)?.[1]||"";return!r||!n?e:`
22
22
  import { ${n} } from '${t}';
23
23
 
24
24
  /**${o}*/
@@ -27,33 +27,33 @@ class ${n}WCA extends ${n} {}
27
27
  if (!customElements.get(${r})) {
28
28
  customElements.define(${r}, ${n}WCA);
29
29
  }
30
- `};var z=D.resolve(process.cwd(),"./scripts/wca");async function mr(e){try{return(await Promise.all(e.map(r=>lr(r)))).flat()}catch(t){throw console.error("Error processing glob patterns:",t),t}}async function ur(e){U.existsSync(z)||await U.promises.mkdir(z,{recursive:!0});for(let t of e){let r=D.resolve(process.cwd(),t),n=await U.promises.readFile(r,"utf-8"),o=D.resolve(z,`${D.basename(t)}`),i=Ye(n,D.relative(z,t));await U.promises.writeFile(o,i)}}async function dr(){let e=await mr(["./src/auro-*.js"]);await ur(e)}var Yo=cr.command("wca-setup").description("Set up WCA (Web Component Analyzer) for the project").action(()=>{dr().then(()=>{Xe.success("WCA setup completed successfully.")}).catch(e=>{Xe.error(`WCA setup failed: ${e.message}`)})});import{program as kr}from"commander";import me from"chalk";import tt from"ora";import{appendFile as pr,readFile as fr}from"node:fs/promises";import{Logger as p}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import{simpleGit as gr}from"simple-git";var w;try{w=gr({baseDir:process.cwd(),binary:"git",maxConcurrentProcesses:1})}catch(e){p.error(`Failed to initialize git: ${e}`),w={}}var q=class e{static async checkGitignore(t){if(t==="")return!1;try{return(await fr(".gitignore","utf-8")).includes(t)}catch(r){return p.error(`Error reading file: ${r}`),!1}}static async getCommitMessages(){try{let t=await w.branchLocal();p.info(`Current branch: ${t.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 w.fetch("origin",r),p.info(`Fetched target branch: origin/${r}`),n=`${(await w.raw(["merge-base",`origin/${r}`,"HEAD"])).trim()}..HEAD`,p.info(`Using commit range: ${n}`)}catch(i){p.warn(`Error setting up commit range in CI: ${i}`),n=`origin/${r}..HEAD`,p.info(`Falling back to commit range: ${n}`)}}else{p.info("Running in local environment");try{try{await w.raw(["rev-parse","--verify",`origin/${r}`])}catch{p.info(`Fetching ${r} from origin`),await w.fetch("origin",r)}n=`${(await w.raw(["merge-base",`origin/${r}`,t.current])).trim()}..HEAD`,p.info(`Using commit range for PR commits: ${n}`)}catch(i){p.warn(`Error determining PR commits locally: ${i}`),p.info("Falling back to analyzing recent commits"),n="HEAD~10..HEAD",p.info(`Using fallback commit range: ${n}`)}}return await e.getFormattedCommits(n)}catch(t){return p.error(`Error getting commit messages: ${t}`),[]}}static async getFormattedCommits(t){let n=(await w.raw(["log","--pretty=format:COMMIT_START%n%H%n%ad%n%an%n%s%n%b%nCOMMIT_END","--date=short",t])).split(`COMMIT_START
31
- `).filter(i=>i.trim()!==""),o=[];for(let i of n){let s=i.split(`
32
- `);if(s.length>=4){let c=s[0],l=s[1],u=s[2],m=s[3],a=s.slice(4).filter(E=>E!=="COMMIT_END"),d=a.length>0?a.join(""):"",g=c.substring(0,7),f=m.match(/^(feat|fix|docs|style|refactor|perf|test|build|ci|chore)(\(.+\))?:/),y=f?f[1]:"unknown";d.includes("BREAKING CHANGE")&&(y="breaking"),o.push({type:y,hash:g,date:l,subject:m,body:d,message:`${m}${d?`
30
+ `};var z=D.resolve(process.cwd(),"./scripts/wca");async function ur(e){try{return(await Promise.all(e.map(r=>mr(r)))).flat()}catch(t){throw console.error("Error processing glob patterns:",t),t}}async function dr(e){U.existsSync(z)||await U.promises.mkdir(z,{recursive:!0});for(let t of e){let r=D.resolve(process.cwd(),t),n=await U.promises.readFile(r,"utf-8"),o=D.resolve(z,`${D.basename(t)}`),s=Ye(n,D.relative(z,t));await U.promises.writeFile(o,s)}}async function pr(){let e=await ur(["./src/auro-*.js"]);await dr(e)}var Xo=lr.command("wca-setup").description("Set up WCA (Web Component Analyzer) for the project").action(()=>{pr().then(()=>{Xe.success("WCA setup completed successfully.")}).catch(e=>{Xe.error(`WCA setup failed: ${e.message}`)})});import{program as Ar}from"commander";import ue from"chalk";import tt from"ora";import{appendFile as fr,readFile as gr}from"node:fs/promises";import{Logger as p}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import{simpleGit as hr}from"simple-git";var w;try{w=hr({baseDir:process.cwd(),binary:"git",maxConcurrentProcesses:1})}catch(e){p.error(`Failed to initialize git: ${e}`),w={}}var q=class e{static async checkGitignore(t){if(t==="")return!1;try{return(await gr(".gitignore","utf-8")).includes(t)}catch(r){return p.error(`Error reading file: ${r}`),!1}}static async getCommitMessages(){try{let t=await w.branchLocal();p.info(`Current branch: ${t.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 w.fetch("origin",r),p.info(`Fetched target branch: origin/${r}`),n=`${(await w.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 w.raw(["rev-parse","--verify",`origin/${r}`])}catch{p.info(`Fetching ${r} from origin`),await w.fetch("origin",r)}n=`${(await w.raw(["merge-base",`origin/${r}`,t.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 e.getFormattedCommits(n)}catch(t){return p.error(`Error getting commit messages: ${t}`),[]}}static async getFormattedCommits(t){let n=(await w.raw(["log","--pretty=format:COMMIT_START%n%H%n%ad%n%an%n%s%n%b%nCOMMIT_END","--date=short",t])).split(`COMMIT_START
31
+ `).filter(s=>s.trim()!==""),o=[];for(let s of n){let i=s.split(`
32
+ `);if(i.length>=4){let c=i[0],l=i[1],u=i[2],m=i[3],a=i.slice(4).filter(E=>E!=="COMMIT_END"),d=a.length>0?a.join(""):"",g=c.substring(0,7),f=m.match(/^(feat|fix|docs|style|refactor|perf|test|build|ci|chore)(\(.+\))?:/),y=f?f[1]:"unknown";d.includes("BREAKING CHANGE")&&(y="breaking"),o.push({type:y,hash:g,date:l,subject:m,body:d,message:`${m}${d?`
33
33
 
34
- ${d}`:""}`,author_name:u})}}return o}static async addToGitignore(t,r=!0){await e.checkGitignore(t).then(async n=>{if(n)p.warn(`${t} already exists`);else try{await pr(".gitignore",`
35
- ${t}`),r&&p.success(`${t} added to .gitignore`)}catch(o){p.error(o)}})}static async removeFromGitCache(t){try{await w.rmKeepLocal(t),p.success(`${t.join(", ")} are removed from git cache`)}catch(r){p.error(r)}}static async createBranch(t){try{await w.checkoutLocalBranch(t),p.success(`Created and switched to ${t} branch`)}catch(r){p.error(r)}}static async commitStagedFiles(t){try{await w.add("."),await w.commit(t),p.success(`Committed with message: ${t}`)}catch(r){p.error(r)}}};import h from"chalk";var hr=60,yr=100;function C(e){switch(e){case"breaking":return h.bold.red(e);case"feat":return h.bold.green(e);case"fix":return h.bold.green(e);case"perf":return h.bold.green(e);case"docs":return h.bold.cyan(e);case"style":return h.bold.cyan(e);case"refactor":return h.bold.cyan(e);case"test":return h.bold.cyan(e);case"build":return h.bold.cyan(e);case"ci":return h.bold.cyan(e);case"chore":return h.bold.cyan(e);default:return h.bold.white(e)}}function Ze(e,t){if(!e)return"";if(e.length<=t)return e;let r=e.split(" "),n="",o="";for(let i of r)(o+i).length>t&&o.length>0&&(n+=`${o.trim()}
36
- `,o=""),o=`${o}${i} `;return o.length>0&&(n+=o.trim()),n}function Qe(e){for(let t of e){console.log("\u2500".repeat(60));let r=Ze(t.subject,hr),n=Ze(t.body,yr);console.log(h.bold(`${C(t.type)}`)),console.log(h.dim(`${t.hash} | ${t.date} | ${t.author_name}`)),console.log(h.bold(`${h.white(r)}`)),t.body&&console.log(h.dim(n))}console.log("\u2500".repeat(60)),console.log(`
37
- `)}import V from"@actions/github";async function le(){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 t=V.getOctokit(e),{context:r}=V;if(!r.payload.pull_request)throw new Error("No pull request found in the GitHub context");let[n,o]=process.env.GITHUB_REPOSITORY.split("/"),i=r.payload.pull_request.number,{data:s}=await t.rest.issues.listLabelsOnIssue({owner:n,repo:o,issue_number:i});return s.map(c=>c.name)}catch(e){throw e instanceof Error?new Error(`Failed to get existing labels: ${e.message}`):e}}async function et(e){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 r=V.getOctokit(t),{context:n}=V;if(!n.payload.pull_request)throw new Error("No pull request found in the GitHub context");let[o,i]=process.env.GITHUB_REPOSITORY.split("/"),s=n.payload.pull_request.number,c=`semantic-status: ${e}`,l=await le();if(l.includes(c))return;let u=l.filter(m=>m.startsWith("semantic-status:")&&m!==c);for(let m of u)await r.rest.issues.removeLabel({owner:o,repo:i,issue_number:s,name:m});await r.rest.issues.addLabels({owner:o,repo:i,issue_number:s,labels:[c]});return}catch(t){throw t instanceof Error?new Error(`Failed to apply label: ${t.message}`):t}}function wr(e){let t=["feat","fix","breaking"],r=e.filter(o=>t.includes(o.type)),n=r.length>0?r:e;if(n.length===0){console.log(`No commits found to include in release notes.
34
+ ${d}`:""}`,author_name:u})}}return o}static async addToGitignore(t,r=!0){await e.checkGitignore(t).then(async n=>{if(n)p.warn(`${t} already exists`);else try{await fr(".gitignore",`
35
+ ${t}`),r&&p.success(`${t} added to .gitignore`)}catch(o){p.error(o)}})}static async removeFromGitCache(t){try{await w.rmKeepLocal(t),p.success(`${t.join(", ")} are removed from git cache`)}catch(r){p.error(r)}}static async createBranch(t){try{await w.checkoutLocalBranch(t),p.success(`Created and switched to ${t} branch`)}catch(r){p.error(r)}}static async commitStagedFiles(t){try{await w.add("."),await w.commit(t),p.success(`Committed with message: ${t}`)}catch(r){p.error(r)}}};import h from"chalk";var yr=60,wr=100;function S(e){switch(e){case"breaking":return h.bold.red(e);case"feat":return h.bold.green(e);case"fix":return h.bold.green(e);case"perf":return h.bold.green(e);case"docs":return h.bold.cyan(e);case"style":return h.bold.cyan(e);case"refactor":return h.bold.cyan(e);case"test":return h.bold.cyan(e);case"build":return h.bold.cyan(e);case"ci":return h.bold.cyan(e);case"chore":return h.bold.cyan(e);default:return h.bold.white(e)}}function Ze(e,t){if(!e)return"";if(e.length<=t)return e;let r=e.split(" "),n="",o="";for(let s of r)(o+s).length>t&&o.length>0&&(n+=`${o.trim()}
36
+ `,o=""),o=`${o}${s} `;return o.length>0&&(n+=o.trim()),n}function Qe(e){for(let t of e){console.log("\u2500".repeat(60));let r=Ze(t.subject,yr),n=Ze(t.body,wr);console.log(h.bold(`${S(t.type)}`)),console.log(h.dim(`${t.hash} | ${t.date} | ${t.author_name}`)),console.log(h.bold(`${h.white(r)}`)),t.body&&console.log(h.dim(n))}console.log("\u2500".repeat(60)),console.log(`
37
+ `)}import V from"@actions/github";async function me(){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 t=V.getOctokit(e),{context:r}=V;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 t.rest.issues.listLabelsOnIssue({owner:n,repo:o,issue_number:s});return i.map(c=>c.name)}catch(e){throw e instanceof Error?new Error(`Failed to get existing labels: ${e.message}`):e}}async function et(e){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 r=V.getOctokit(t),{context:n}=V;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,c=`semantic-status: ${e}`,l=await me();if(l.includes(c))return;let u=l.filter(m=>m.startsWith("semantic-status:")&&m!==c);for(let m of u)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:[c]});return}catch(t){throw t instanceof Error?new Error(`Failed to apply label: ${t.message}`):t}}function br(e){let t=["feat","fix","breaking"],r=e.filter(o=>t.includes(o.type)),n=r.length>0?r:e;if(n.length===0){console.log(`No commits found to include in release notes.
38
38
  `);return}console.log(`
39
39
  ------
40
40
  `),console.log(`### In this release
41
- `);for(let o of n)if(console.log(`- ${o.hash} ${o.subject}`),o.body?.trim()){let s=o.body.trim().split(/\n+/).map(c=>c.trim()).filter(c=>c.length>0);for(let c of s){let l=c;l=l.replace(/([^\s])(AlaskaAirlines\/[a-zA-Z0-9-]+#\d+)/g,"$1 $2"),l=l.replace(/(AlaskaAirlines\/[a-zA-Z0-9-]+#\d+)([^\s])/g,"$1 $2"),console.log(` - ${l}`)}}console.log(`
41
+ `);for(let o of n)if(console.log(`- ${o.hash} ${o.subject}`),o.body?.trim()){let i=o.body.trim().split(/\n+/).map(c=>c.trim()).filter(c=>c.length>0);for(let c of i){let l=c;l=l.replace(/([^\s])(AlaskaAirlines\/[a-zA-Z0-9-]+#\d+)/g,"$1 $2"),l=l.replace(/(AlaskaAirlines\/[a-zA-Z0-9-]+#\d+)([^\s])/g,"$1 $2"),console.log(` - ${l}`)}}console.log(`
42
42
  ------
43
- `),r.length>0?console.log(me.green(`\u2713 Showing ${r.length} commits of types: ${t.join(", ")}`)):console.log(me.yellow(`\u26A0 No feat/fix/breaking commits found. Showing all ${e.length} commits for your selection.`))}async function rt(e=!1,t=!1,r=!1){let n=tt(`Checking commits...
44
- `).start();try{let o=await q.getCommitMessages();if(r){n.succeed(`Total commits analyzed: ${o.length}`),wr(o);return}if(e&&Qe(o),n.succeed(`Total commits analyzed: ${o.length}`),o.length!==0){let i=o.map(l=>l.type),c=Array.from(new Set(i)).map(l=>C(l)).join(", ");n.succeed(`Found commit types: ${c}`)}else n.info(`The list of commits is created by comparing the current branch
43
+ `),r.length>0?console.log(ue.green(`\u2713 Showing ${r.length} commits of types: ${t.join(", ")}`)):console.log(ue.yellow(`\u26A0 No feat/fix/breaking commits found. Showing all ${e.length} commits for your selection.`))}async function rt(e=!1,t=!1,r=!1){let n=tt(`Checking commits...
44
+ `).start();try{let o=await q.getCommitMessages();if(r){n.succeed(`Total commits analyzed: ${o.length}`),br(o);return}if(e&&Qe(o),n.succeed(`Total commits analyzed: ${o.length}`),o.length!==0){let s=o.map(l=>l.type),c=Array.from(new Set(s)).map(l=>S(l)).join(", ");n.succeed(`Found commit types: ${c}`)}else n.info(`The list of commits is created by comparing the current branch
45
45
  with the main branch. If you are on a new branch, please
46
- make sure to commit some changes before running this command.`);t&&await br(o,n)}catch(o){n.fail("Error getting commit messages"),console.error(o)}}async function br(e,t){let r=["breaking","feat","fix","perf","docs","style","refactor","test","build","ci","chore"],n=e.map(s=>s.type).filter(s=>r.includes(s)),o=null,i=Number.POSITIVE_INFINITY;for(let s of n){let c=r.indexOf(s);c<i&&(i=c,o=s)}if(o){let s=tt("Checking existing labels on pull request...").start();try{if((await le()).includes(`semantic-status: ${o}`)){s.info(`Label "semantic-status: ${C(o)}" already exists on the pull request.`);return}s.text="Applying label to pull request...",await et(o),s.succeed(`Label "semantic-status: ${C(o)}" applied to the pull request.`)}catch(c){let l=c instanceof Error?c.message:String(c);s.fail(l)}}else t.warn(me.yellow("No semantic commit type found to apply as label."))}var fi=kr.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").option("-r, --release-notes","Generate release notes based on commit messages").description("Check commits in the local repository for the types of semantic commit messages made and return the results.").action(async e=>{await rt(e.debug,e.setLabel,e.releaseNotes)});import nt from"node:fs";import{get as ot}from"node:https";import v from"chalk";import{program as Ar}from"commander";import $r from"ora";var Ai=Ar.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 e=>{await vr(e)}),vr=async e=>{let{namespace:t,prNumber:r}=e,n=$r("Updating package.json").start();try{let o="package.json",i=JSON.parse(nt.readFileSync(o,"utf8"));n.text="Checking npm registry for version information...";let s=`0.0.0-pr${r}`,c=i.name.split("/")[1],l=`${t}/${c}`,u=await Er(s,l,n),m=`${s}.${u}`;i.name=l,i.version=m,n.text="Writing updated package.json...",nt.writeFileSync(o,`${JSON.stringify(i,null,2)}
47
- `,"utf8"),n.succeed(`Package.json updated to use ${v.green(m)} and ${v.green(l)}`),process.exit(0)}catch(o){n.fail(`Failed to update package.json: ${o}`),process.exit(1)}},Er=(e,t,r)=>new Promise(n=>{try{let c=function(l){if(l.statusCode!==200){r.info(`Package not found. Status code: ${v.red(l.statusCode)}, defaulting to version 0`),n(0);return}r.text="Processing version information...";let u="";l.on("data",m=>{u+=m}),l.on("end",()=>{try{let m=JSON.parse(u),a=m.versions?Object.keys(m.versions):[];r.text="Calculating next version number...";let d=-1,g=new RegExp(`^${e}\\.(\\d+)$`);for(let f of a){let y=f.match(g);if(y){let E=Number.parseInt(y[1],10);d=Math.max(d,E)}}d>=0?r.info(`Found existing version ${v.green(`${e}.${d}`)}. Incrementing to ${v.green(`${e}.${d+1}`)}`):r.info(`No existing version found for ${v.green(e)}. Starting with ${v.green(`${e}.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=c;let i=`https://registry.npmjs.org/${t}`,s=ot(i,{headers:{Accept:"application/json"}},l=>{if((l.statusCode===301||l.statusCode===302)&&l.headers.location){r.info(`Following redirect to ${l.headers.location}...`);try{ot(l.headers.location,{headers:{Accept:"application/json"}},c).on("error",u=>{r.warn(`Error following redirect: ${u.message}, defaulting to version 0`),n(0)}).end()}catch(u){r.warn(`Redirect request failed: ${u instanceof Error?u.message:"Unknown error"}, defaulting to version 0`),n(0)}return}c(l)});s.on("error",l=>{r.warn(`Request error: ${l.message}, defaulting to version 0`),n(0)}),s.end()}catch{r.warn("Error checking version in npm registry, defaulting to version 0"),n(0)}});import ue from"node:path";import{fileURLToPath as xr}from"node:url";import{program as Tr}from"commander";import Pr from"open";var Dr=xr(import.meta.url),Cr=ue.resolve(ue.dirname(Dr),".."),Di=Tr.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 e=>{let r=`npx wtr --config "${ue.join(Cr,"dist","configs","web-test-runner.config.mjs")}"`,n=`${process.cwd()}/coverage/index.html`;if(e.coverageReport&&(r+=" --coverage"),e.watch&&(r+=" --watch"),e.files){let o=Array.isArray(e.files)?e.files.join(" "):e.files;r+=` --files "${o}"`}b(r),e.open&&await Pr(n)});import ge from"node:fs/promises";import ct from"node:path";import{program as Fr}from"commander";import Gr from"inquirer";import he from"ora";import Sr from"node:fs/promises";import Ir from"node:path";import jr from"ora";var Or={"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 Rr(e){return Object.entries(e).map(([t,r])=>Array.isArray(r)?`${t}:
46
+ make sure to commit some changes before running this command.`);t&&await kr(o,n)}catch(o){n.fail("Error getting commit messages"),console.error(o)}}async function kr(e,t){let r=["breaking","feat","fix","perf","docs","style","refactor","test","build","ci","chore"],n=e.map(i=>i.type).filter(i=>r.includes(i)),o=null,s=Number.POSITIVE_INFINITY;for(let i of n){let c=r.indexOf(i);c<s&&(s=c,o=i)}if(o){let i=tt("Checking existing labels on pull request...").start();try{if((await me()).includes(`semantic-status: ${o}`)){i.info(`Label "semantic-status: ${S(o)}" already exists on the pull request.`);return}i.text="Applying label to pull request...",await et(o),i.succeed(`Label "semantic-status: ${S(o)}" applied to the pull request.`)}catch(c){let l=c instanceof Error?c.message:String(c);i.fail(l)}}else t.warn(ue.yellow("No semantic commit type found to apply as label."))}var gs=Ar.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").option("-r, --release-notes","Generate release notes based on commit messages").description("Check commits in the local repository for the types of semantic commit messages made and return the results.").action(async e=>{await rt(e.debug,e.setLabel,e.releaseNotes)});import nt from"node:fs";import{get as ot}from"node:https";import v from"chalk";import{program as $r}from"commander";import vr from"ora";var $s=$r.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 e=>{await Er(e)}),Er=async e=>{let{namespace:t,prNumber:r}=e,n=vr("Updating package.json").start();try{let o="package.json",s=JSON.parse(nt.readFileSync(o,"utf8"));n.text="Checking npm registry for version information...";let i=`0.0.0-pr${r}`,c=s.name.split("/")[1],l=`${t}/${c}`,u=await xr(i,l,n),m=`${i}.${u}`;s.name=l,s.version=m,n.text="Writing updated package.json...",nt.writeFileSync(o,`${JSON.stringify(s,null,2)}
47
+ `,"utf8"),n.succeed(`Package.json updated to use ${v.green(m)} and ${v.green(l)}`),process.exit(0)}catch(o){n.fail(`Failed to update package.json: ${o}`),process.exit(1)}},xr=(e,t,r)=>new Promise(n=>{try{let c=function(l){if(l.statusCode!==200){r.info(`Package not found. Status code: ${v.red(l.statusCode)}, defaulting to version 0`),n(0);return}r.text="Processing version information...";let u="";l.on("data",m=>{u+=m}),l.on("end",()=>{try{let m=JSON.parse(u),a=m.versions?Object.keys(m.versions):[];r.text="Calculating next version number...";let d=-1,g=new RegExp(`^${e}\\.(\\d+)$`);for(let f of a){let y=f.match(g);if(y){let E=Number.parseInt(y[1],10);d=Math.max(d,E)}}d>=0?r.info(`Found existing version ${v.green(`${e}.${d}`)}. Incrementing to ${v.green(`${e}.${d+1}`)}`):r.info(`No existing version found for ${v.green(e)}. Starting with ${v.green(`${e}.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=c;let s=`https://registry.npmjs.org/${t}`,i=ot(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{ot(l.headers.location,{headers:{Accept:"application/json"}},c).on("error",u=>{r.warn(`Error following redirect: ${u.message}, defaulting to version 0`),n(0)}).end()}catch(u){r.warn(`Redirect request failed: ${u instanceof Error?u.message:"Unknown error"}, defaulting to version 0`),n(0)}return}c(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 de from"node:path";import{fileURLToPath as Tr}from"node:url";import{program as Pr}from"commander";import Dr from"open";var Sr=Tr(import.meta.url),Cr=de.resolve(de.dirname(Sr),".."),Ss=Pr.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 e=>{let r=`npx wtr --config "${de.join(Cr,"dist","configs","web-test-runner.config.mjs")}"`,n=`${process.cwd()}/coverage/index.html`;if(e.coverageReport&&(r+=" --coverage"),e.watch&&(r+=" --watch"),e.files){let o=Array.isArray(e.files)?e.files.join(" "):e.files;r+=` --files "${o}"`}b(r),e.open&&await Dr(n)});import he from"node:fs/promises";import ct from"node:path";import{program as Gr}from"commander";import Mr from"inquirer";import ye from"ora";import Ir from"node:fs/promises";import jr from"node:path";import Or from"ora";var Rr={"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 Nr(e){return Object.entries(e).map(([t,r])=>Array.isArray(r)?`${t}:
48
48
  - ${r.join(`
49
49
  - `)}`:typeof r=="object"&&r!==null?`${t}:
50
50
  ${Object.entries(r).map(([n,o])=>` ${n}: ${o}`).join(`
51
51
  `)}`:`${t}: ${r}`).join(`
52
- `)}async function it(e){let t=jr("Writing multi-gitter configuration...").start(),r=Rr(Or),n=Ir.join(e,"multi-gitter_DEPENDENCY_TREE.yml");try{await Sr.writeFile(n,r,"utf8"),t.succeed(`Multi-gitter configuration written to ${n}`)}catch(o){t.fail("Error writing multi-gitter configuration:"),console.error(o)}}import de from"node:fs";function st(e){let t={},r=[],n=[],o=[];for(let i in e)t[i]=e[i].dependsOn.length;for(let i in t)t[i]===0&&o.push(i);for(;o.length>0;){n=[];let i=o.length;for(let s=0;s<i;s++){let c=o.shift();n.push(c);for(let l of e[c].dependentPackages)t[l]--,t[l]===0&&o.push(l)}r.push(n)}if(r.flat().length!==Object.keys(e).length)throw new Error("Circular dependency detected!");return r}function Nr(e){return de.readdirSync(e).filter(t=>t.endsWith(".json"))}async function at(e,t=[]){console.log(t);let r={},n=Nr(e);for(let o of n){if(o==="dependencyTree.json")continue;let i=de.readFileSync(`${e}/${o}`,"utf-8"),s=JSON.parse(i),c=s.name,l=Object.keys(s.peerDependencies),u=Object.keys(s.devDependencies),m=Object.keys(s.dependencies);r[c]||(r[c]={dependsOn:[],dependentPackages:[]});let a=[...l,...u,...m];r[c].dependsOn=[...new Set(a)];for(let d of a)r[d]||(r[d]={dependsOn:[],dependentPackages:[]}),r[d].dependentPackages.includes(c)||r[d].dependentPackages.push(c)}if(t.length){let o=new Set;for(let[s,c]of Object.entries(r))c.dependsOn.some(l=>t.includes(l))&&o.add(s);for(let s of t)r[s]&&o.add(s);let i={};for(let s of o)i[s]={dependsOn:r[s].dependsOn.filter(c=>o.has(c)),dependentPackages:r[s].dependentPackages.filter(c=>o.has(c))};r=i}else console.log("No target dependencies provided - using all packages.");return de.writeFileSync(`${e}/dependencyTree.json`,JSON.stringify(r,null,2)),r}var pe=Z("run-migrations","config"),fe=Z("run-migrations","outputs");var lt=["@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"],zi=[...lt,"@aurodesignsystem/auro-library","@aurodesignsystem/WebCoreStyleSheets","@aurodesignsystem/AuroDesignTokens","@aurodesignsystem/auro-cli","@alaskaairux/icons"];async function Mr(e){try{await ge.mkdir(fe,{recursive:!0}),await ge.mkdir(pe,{recursive:!0})}catch(o){console.error("Failed to create output or config directories:",o),process.exit(1)}let t=he("Creating dependency tree...").start();t.text="Creating multi-gitter dependency tree configuration...",await it(pe),t.text="Scraping dependencies from Auro packages...";let n=`multi-gitter run "node ${Q("static","getAuroDeps.js")}" --config ${ct.join(pe,"multi-gitter_DEPENDENCY_TREE.yml")}`;try{await b(n)}catch(o){t.fail("Failed to generate dependency tree:"),console.error(o),process.exit(1)}return t.text="Generating dependency tree JSON file using packages...",await at(fe,e),t.succeed("Dependency tree generated successfully."),ct.join(fe,"dependencyTree.json")}var _r=async e=>{let t=he("Loading dependency tree...").start(),r=JSON.parse(await ge.readFile(e,"utf-8"));t.text="Processing dependency tree...";let n=st(r);return t.succeed("Dependency batches created successfully."),n},qi=Fr.command("agent").action(async e=>{let t=await Gr.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:lt.map(r=>({name:r.replace("@aurodesignsystem/",""),value:r})),when:r=>r.agentAction==="run-migration"&&r.useExisting}]);switch(t.agentAction){case"run-migration":{let r=he("Running migration...").start(),n=await Mr(t.startWithComponents);r.text="Getting dependency batches from tree...";let i=(await _r(n)).map((s,c)=>`Batch ${c+1}
53
- ${s.map(l=>` - ${l.replace("@aurodesignsystem","AlaskaAirlines").replace("@alaskaairux/icons","AlaskaAirlines/Icons")}`).join(`
52
+ `)}async function st(e){let t=Or("Writing multi-gitter configuration...").start(),r=Nr(Rr),n=jr.join(e,"multi-gitter_DEPENDENCY_TREE.yml");try{await Ir.writeFile(n,r,"utf8"),t.succeed(`Multi-gitter configuration written to ${n}`)}catch(o){t.fail("Error writing multi-gitter configuration:"),console.error(o)}}import pe from"node:fs";function it(e){let t={},r=[],n=[],o=[];for(let s in e)t[s]=e[s].dependsOn.length;for(let s in t)t[s]===0&&o.push(s);for(;o.length>0;){n=[];let s=o.length;for(let i=0;i<s;i++){let c=o.shift();n.push(c);for(let l of e[c].dependentPackages)t[l]--,t[l]===0&&o.push(l)}r.push(n)}if(r.flat().length!==Object.keys(e).length)throw new Error("Circular dependency detected!");return r}function Fr(e){return pe.readdirSync(e).filter(t=>t.endsWith(".json"))}async function at(e,t=[]){console.log(t);let r={},n=Fr(e);for(let o of n){if(o==="dependencyTree.json")continue;let s=pe.readFileSync(`${e}/${o}`,"utf-8"),i=JSON.parse(s),c=i.name,l=Object.keys(i.peerDependencies),u=Object.keys(i.devDependencies),m=Object.keys(i.dependencies);r[c]||(r[c]={dependsOn:[],dependentPackages:[]});let a=[...l,...u,...m];r[c].dependsOn=[...new Set(a)];for(let d of a)r[d]||(r[d]={dependsOn:[],dependentPackages:[]}),r[d].dependentPackages.includes(c)||r[d].dependentPackages.push(c)}if(t.length){let o=new Set;for(let[i,c]of Object.entries(r))c.dependsOn.some(l=>t.includes(l))&&o.add(i);for(let i of t)r[i]&&o.add(i);let s={};for(let i of o)s[i]={dependsOn:r[i].dependsOn.filter(c=>o.has(c)),dependentPackages:r[i].dependentPackages.filter(c=>o.has(c))};r=s}else console.log("No target dependencies provided - using all packages.");return pe.writeFileSync(`${e}/dependencyTree.json`,JSON.stringify(r,null,2)),r}var fe=Z("run-migrations","config"),ge=Z("run-migrations","outputs");var lt=["@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"],qs=[...lt,"@aurodesignsystem/auro-library","@aurodesignsystem/WebCoreStyleSheets","@aurodesignsystem/AuroDesignTokens","@aurodesignsystem/auro-cli","@alaskaairux/icons"];async function _r(e){try{await he.mkdir(ge,{recursive:!0}),await he.mkdir(fe,{recursive:!0})}catch(o){console.error("Failed to create output or config directories:",o),process.exit(1)}let t=ye("Creating dependency tree...").start();t.text="Creating multi-gitter dependency tree configuration...",await st(fe),t.text="Scraping dependencies from Auro packages...";let n=`multi-gitter run "node ${Q("static","getAuroDeps.js")}" --config ${ct.join(fe,"multi-gitter_DEPENDENCY_TREE.yml")}`;try{await b(n)}catch(o){t.fail("Failed to generate dependency tree:"),console.error(o),process.exit(1)}return t.text="Generating dependency tree JSON file using packages...",await at(ge,e),t.succeed("Dependency tree generated successfully."),ct.join(ge,"dependencyTree.json")}var Br=async e=>{let t=ye("Loading dependency tree...").start(),r=JSON.parse(await he.readFile(e,"utf-8"));t.text="Processing dependency tree...";let n=it(r);return t.succeed("Dependency batches created successfully."),n},Vs=Gr.command("agent").action(async e=>{let t=await Mr.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:lt.map(r=>({name:r.replace("@aurodesignsystem/",""),value:r})),when:r=>r.agentAction==="run-migration"&&r.useExisting}]);switch(t.agentAction){case"run-migration":{let r=ye("Running migration...").start(),n=await _r(t.startWithComponents);r.text="Getting dependency batches from tree...";let s=(await Br(n)).map((i,c)=>`Batch ${c+1}
53
+ ${i.map(l=>` - ${l.replace("@aurodesignsystem","AlaskaAirlines").replace("@alaskaairux/icons","AlaskaAirlines/Icons")}`).join(`
54
54
  `)}`).join(`
55
55
 
56
- `);console.log(i),r.text="Running migrations on dependency batches...",new Promise(s=>setTimeout(s,2e3)),r.succeed("Migration process completed successfully.");break}default:console.error("Unknown action selected.")}});import{program as Br}from"commander";var ye=Br.command("docs").description("Generate API documentation").option("-c, --cem","Generate Custom Elements Manifest (CEM) file",!1).option("-a, --api","Creates api md file from CEM",!1);ye=j(ye);var Xi=ye.action(async e=>{e.cem&&await G(),e.api&&await M(),await Ce(),e.serve&&await Se(e)});import{program as zr}from"commander";import{Octokit as we}from"@octokit/rest";import*as K from"azure-devops-node-api";import J from"ora";var Hr=async e=>{let t=process.env.GH_TOKEN;if(!t)throw new Error("GH_TOKEN environment variable is required");let r=new we({auth:t}),n,o,i;if(e.includes("github.com")){let c=e.match(/github\.com\/([^\/]+)\/([^\/]+)\/issues\/(\d+)/);if(!c)throw new Error("Invalid GitHub issue URL format");[,n,o,i]=c}else if(e.includes("#")){let c=e.match(/([^\/]+)\/([^#]+)#(\d+)/);if(!c)throw new Error("Invalid GitHub issue reference format");[,n,o,i]=c}else throw new Error("Issue must be provided as full URL or in format 'owner/repo#number'");let s=Number.parseInt(i,10);try{let{data:c}=await r.rest.issues.get({owner:n,repo:o,issue_number:s});return{title:c.title,body:c.body??null,html_url:c.html_url,number:c.number,repository:{owner:{login:n},name:o}}}catch(c){throw new Error(`Failed to fetch GitHub issue: ${c}`)}},Wr=async e=>{let t=process.env.GH_TOKEN;if(!t)return null;let r=new we({auth:t});try{let n=`
56
+ `);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 Hr}from"commander";var we=Hr.command("docs").description("Generate API documentation").option("-c, --cem","Generate Custom Elements Manifest (CEM) file",!1).option("-a, --api","Creates api md file from CEM",!1);we=j(we);var Zs=we.action(async e=>{e.cem&&await G(),e.api&&await M(),await Se(),e.serve&&await Ce(e)});import{program as qr}from"commander";import{Octokit as be}from"@octokit/rest";import*as K from"azure-devops-node-api";import J from"ora";var Wr=async e=>{let t=process.env.GH_TOKEN;if(!t)throw new Error("GH_TOKEN environment variable is required");let r=new be({auth:t}),n,o,s;if(e.includes("github.com")){let c=e.match(/github\.com\/([^\/]+)\/([^\/]+)\/issues\/(\d+)/);if(!c)throw new Error("Invalid GitHub issue URL format");[,n,o,s]=c}else if(e.includes("#")){let c=e.match(/([^\/]+)\/([^#]+)#(\d+)/);if(!c)throw new Error("Invalid GitHub issue reference format");[,n,o,s]=c}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:c}=await r.rest.issues.get({owner:n,repo:o,issue_number:i});return{title:c.title,body:c.body??null,html_url:c.html_url,number:c.number,repository:{owner:{login:n},name:o}}}catch(c){throw new Error(`Failed to fetch GitHub issue: ${c}`)}},Lr=async e=>{let t=process.env.GH_TOKEN;if(!t)return null;let r=new be({auth:t});try{let n=`
57
57
  query($owner: String!, $repo: String!, $issueNumber: Int!) {
58
58
  repository(owner: $owner, name: $repo) {
59
59
  issue(number: $issueNumber) {
@@ -79,7 +79,7 @@ ${s.map(l=>` - ${l.replace("@aurodesignsystem","AlaskaAirlines").replace("@alas
79
79
  }
80
80
  }
81
81
  }
82
- `,o={owner:e.repository.owner.login,repo:e.repository.name,issueNumber:e.number},s=(await r.graphql(n,o)).repository.issue.projectItems.nodes.find(c=>c.project.number===19);if(s){let c=s.fieldValues.nodes.find(l=>l.field?.name?.toLowerCase()==="ado"&&l.text?.trim());if(c?.text?.trim())return c.text.trim()}return null}catch(n){return console.error(`Failed to check existing ADO link: ${n}`),null}},Lr=async(e,t)=>{let r=process.env.GH_TOKEN;if(!r)throw new Error("GH_TOKEN environment variable is required");let n=new we({auth:r}),o=19;try{let i=`
82
+ `,o={owner:e.repository.owner.login,repo:e.repository.name,issueNumber:e.number},i=(await r.graphql(n,o)).repository.issue.projectItems.nodes.find(c=>c.project.number===19);if(i){let c=i.fieldValues.nodes.find(l=>l.field?.name?.toLowerCase()==="ado"&&l.text?.trim());if(c?.text?.trim())return c.text.trim()}return null}catch(n){return console.error(`Failed to check existing ADO link: ${n}`),null}},Ur=async(e,t)=>{let r=process.env.GH_TOKEN;if(!r)throw new Error("GH_TOKEN environment variable is required");let n=new be({auth:r}),o=19;try{let s=`
83
83
  query($org: String!, $projectNumber: Int!, $owner: String!, $repo: String!, $issueNumber: Int!) {
84
84
  organization(login: $org) {
85
85
  projectV2(number: $projectNumber) {
@@ -116,7 +116,7 @@ ${s.map(l=>` - ${l.replace("@aurodesignsystem","AlaskaAirlines").replace("@alas
116
116
  }
117
117
  }
118
118
  }
119
- `,s={org:"AlaskaAirlines",projectNumber:o,owner:e.repository.owner.login,repo:e.repository.name,issueNumber:e.number},c=await n.graphql(i,s),l=c.organization.projectV2.id,u=c.repository.issue.id,m=c.organization.projectV2.fields.nodes.find(d=>d.name?.toLowerCase()==="ado"),a=c.repository.issue.projectItems.nodes.find(d=>d.project.number===o)?.id;if(a||(a=(await n.graphql(`
119
+ `,i={org:"AlaskaAirlines",projectNumber:o,owner:e.repository.owner.login,repo:e.repository.name,issueNumber:e.number},c=await n.graphql(s,i),l=c.organization.projectV2.id,u=c.repository.issue.id,m=c.organization.projectV2.fields.nodes.find(d=>d.name?.toLowerCase()==="ado"),a=c.repository.issue.projectItems.nodes.find(d=>d.project.number===o)?.id;if(a||(a=(await n.graphql(`
120
120
  mutation($projectId: ID!, $contentId: ID!) {
121
121
  addProjectV2ItemById(
122
122
  input: {
@@ -146,4 +146,4 @@ ${s.map(l=>` - ${l.replace("@aurodesignsystem","AlaskaAirlines").replace("@alas
146
146
  }
147
147
  }
148
148
  }
149
- `,{projectId:l,itemId:a,fieldId:m.id,value:t});else if(!m)throw new Error("No 'ado' field found in GitHub project")}catch(i){console.error(`Failed to update GitHub project: ${i}`)}},Ur=async e=>{let t=process.env.ADO_TOKEN;if(!t)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",i=K.getPersonalAccessTokenHandler(t),c=await new K.WebApi(r,i).getWorkItemTrackingApi();try{let l=[{op:"add",path:"/fields/System.Title",value:e.title},{op:"add",path:"/fields/System.Description",value:`GitHub Issue: <a href="${e.html_url}">${e.html_url}</a>`},{op:"add",path:"/fields/System.AreaPath",value:o}];return await c.createWorkItem(null,l,n,"User Story")}catch(l){throw new Error(`Failed to create ADO work item: ${l}`)}},mt=async e=>{let t=J(`Processing GitHub issue: ${e}`).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");t.text="Fetching GitHub issue details...";let r=await Hr(e);t.succeed(`Found issue: "${r.title}"`);let n=J("Checking for existing ADO work item...").start(),o=await Wr(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 i=J("Creating new ADO work item...").start(),s=await Ur(r);if(i.succeed(`Successfully created ADO work item #${s.id}`),console.log(`Work item: ${s._links?.html?.href||"N/A"}`),s._links?.html?.href){let c=J("Adding to GitHub project and updating ADO field...").start();await Lr(r,s._links.html.href),c.succeed("Updated GitHub project with ADO link")}}catch(r){t.fail(`Error: ${r instanceof Error?r.message:r}`),process.exit(1)}};var os=zr.command("ado").description("Generate ADO item from GitHub issue").option("-g, --gh-issue <issue>","What GitHub issue to use").action(async e=>{e.ghIssue&&await mt(e.ghIssue)});be.name("auro").version(Y()).description("A cli tool to support the Auro Design System");be.addHelpText("beforeAll",ke());be.parse();
149
+ `,{projectId:l,itemId:a,fieldId:m.id,value:t});else if(!m)throw new Error("No 'ado' field found in GitHub project")}catch(s){console.error(`Failed to update GitHub project: ${s}`)}},zr=async e=>{let t=process.env.ADO_TOKEN;if(!t)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=K.getPersonalAccessTokenHandler(t),c=await new K.WebApi(r,s).getWorkItemTrackingApi();try{let l=[{op:"add",path:"/fields/System.Title",value:e.title},{op:"add",path:"/fields/System.Description",value:`GitHub Issue: <a href="${e.html_url}">${e.html_url}</a>`},{op:"add",path:"/fields/System.AreaPath",value:o}];return await c.createWorkItem(null,l,n,"User Story")}catch(l){throw new Error(`Failed to create ADO work item: ${l}`)}},mt=async e=>{let t=J(`Processing GitHub issue: ${e}`).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");t.text="Fetching GitHub issue details...";let r=await Wr(e);t.succeed(`Found issue: "${r.title}"`);let n=J("Checking for existing ADO work item...").start(),o=await Lr(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=J("Creating new ADO work item...").start(),i=await zr(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 c=J("Adding to GitHub project and updating ADO field...").start();await Ur(r,i._links.html.href),c.succeed("Updated GitHub project with ADO link")}}catch(r){t.fail(`Error: ${r instanceof Error?r.message:r}`),process.exit(1)}};var si=qr.command("ado").description("Generate ADO item from GitHub issue").option("-g, --gh-issue <issue>","What GitHub issue to use").action(async e=>{e.ghIssue&&await mt(e.ghIssue)});ke.name("auro").version(Y()).description("A cli tool to support the Auro Design System");ke.addHelpText("beforeAll",Ae());ke.parse();