@aurodesignsystem-dev/auro-cli 0.0.0-pr286.6 → 0.0.0-pr289.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/auro-cli.js CHANGED
@@ -1,36 +1,36 @@
1
1
  #!/usr/bin/env node
2
- import{program as ze}from"commander";import Ut from"figlet";import{mind as zt}from"gradient-string";var qe=()=>zt(Ut.textSync("Auro CLI"));import Ve from"node:fs";import Je from"node:path";import{fileURLToPath as qt}from"node:url";function K(r){process.env.DEBUG&&console.log(`[DEBUG] ${r}`)}function ye(){try{let r=qt(import.meta.url),t=Je.dirname(r);K(`Current module path: ${t}`);let e=Je.resolve(t,"..","package.json");return K(`Checking package.json at: ${e}`),Ve.existsSync(e)?(K(`Found package.json at: ${e}`),JSON.parse(Ve.readFileSync(e,"utf8")).version):(K("Could not find package.json in the standard installed module location, using default version"),"0.0.0")}catch(r){return console.error("Error retrieving package version:",r),"0.0.0"}}import{program as Wr}from"commander";import bt from"ora";function Y(r){return r.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("-r, --readme-template <url>","URL to the README template file").option("--wca-input [files...]","Source file(s) to analyze for API documentation").option("--wca-output [files...]","Output file(s) for API documentation")}function X(r){return r.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 Mr from"@rollup/plugin-terser";import{watch as Gr}from"rollup";import{existsSync as ut,readFileSync as Rr,rmSync as Sr,writeFileSync as Dr}from"node:fs";import{basename as Pr,dirname as xr,join as H,resolve as ie}from"node:path";import{pathToFileURL as dt}from"node:url";import{glob as Or}from"glob";import Se from"ora";import{rollup as Re}from"rollup";import*as pt from"sass";import M from"ora";import{spawn as Vt}from"node:child_process";import Jt from"ora";var A=(r,t)=>{let e=`${r} ${t?t.join(" "):""}`,n=Jt(),o=r,s=t||[];if(!t&&typeof r=="string"){let d=r.split(" ");o=d[0],s=d.slice(1)}let i=e.includes("--watch")||e.includes(" -w"),l=Vt(o,s,{stdio:i?"inherit":["inherit","pipe","pipe"],shell:!0});if(!i){let d=[];l.stdout?.on("data",m=>{let c=m.toString();d.push(c),process.stdout.write(c)}),l.stderr?.on("data",m=>{let c=m.toString();d.push(c),process.stderr.write(c)})}return new Promise((d,m)=>{l.on("close",c=>{c!==0?i?(n.info(`Watch mode terminated with code ${c}`),d()):(n.fail(`${e} failed (code ${c})`),m(new Error(`Command failed with exit code ${c}`))):(n.succeed(`${e} completed successfully`),d())})})};import Z from"node:fs";import Kt from"node:path";import{markdownTable as Ke}from"markdown-table";var N=class r{static{this.manifest={schemaVersion:"1.0.0",readme:"",modules:[]}}static generate(t={}){let{outDir:e="./docs",outFile:n="api.md",manifestPath:o="./custom-elements.json"}=t,{getElements:s,renderAllElements:i}=r;if(o)try{let c=Z.readFileSync(o,"utf8");r.manifest=JSON.parse(c)}catch(c){throw console.error(`Error reading manifest file at ${o}:`,c),c}let a=s(),l=e;Z.existsSync(l)||Z.mkdirSync(l,{recursive:!0});let d=i(a),m=Kt.join(l,n);Z.writeFileSync(m,d),console.log(`Generated combined API documentation at ${m}`)}static getElements(){let t=r.manifest.modules.filter(r.isWcaModule);return r.manifest.modules.reduce((e,n)=>e.concat(n.declarations?.filter(o=>"customElement"in o&&o.customElement===!0&&"tagName"in o&&(t.length>0?r.isWcaModule(n):!0))??[]),[])}static isWcaModule(t){let{path:e}=t;return e?e.startsWith("scripts/wca/auro-")&&e.endsWith(".js"):!1}static renderAllElements(t){return`${t.sort((e,n)=>(e.tagName||"").localeCompare(n.tagName||"")).map(e=>r.renderElement(e,!0)).join(`
2
+ import{program as ze}from"commander";import Ut from"figlet";import{mind as zt}from"gradient-string";var qe=()=>zt(Ut.textSync("Auro CLI"));import Ve from"node:fs";import Je from"node:path";import{fileURLToPath as qt}from"node:url";function Y(r){process.env.DEBUG&&console.log(`[DEBUG] ${r}`)}function ye(){try{let r=qt(import.meta.url),t=Je.dirname(r);Y(`Current module path: ${t}`);let e=Je.resolve(t,"..","package.json");return Y(`Checking package.json at: ${e}`),Ve.existsSync(e)?(Y(`Found package.json at: ${e}`),JSON.parse(Ve.readFileSync(e,"utf8")).version):(Y("Could not find package.json in the standard installed module location, using default version"),"0.0.0")}catch(r){return console.error("Error retrieving package version:",r),"0.0.0"}}import{program as Wr}from"commander";import bt from"ora";function X(r){return r.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("-r, --readme-template <url>","URL to the README template file").option("--wca-input [files...]","Source file(s) to analyze for API documentation").option("--wca-output [files...]","Output file(s) for API documentation")}function Z(r){return r.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 Mr from"@rollup/plugin-terser";import{watch as Gr}from"rollup";import{existsSync as mt,readFileSync as Rr,rmSync as Sr,writeFileSync as Dr}from"node:fs";import{basename as Pr,dirname as xr,join as H,resolve as ae}from"node:path";import{pathToFileURL as dt}from"node:url";import{glob as Or}from"glob";import Se from"ora";import{rollup as Re}from"rollup";import*as pt from"sass";import M from"ora";import{spawn as Vt}from"node:child_process";import Jt from"ora";var A=(r,t)=>{let e=`${r} ${t?t.join(" "):""}`,n=Jt(),o=r,s=t||[];if(!t&&typeof r=="string"){let m=r.split(" ");o=m[0],s=m.slice(1)}let i=e.includes("--watch")||e.includes(" -w"),l=Vt(o,s,{stdio:i?"inherit":["inherit","pipe","pipe"],shell:!0});if(!i){let m=[];l.stdout?.on("data",u=>{let c=u.toString();m.push(c),process.stdout.write(c)}),l.stderr?.on("data",u=>{let c=u.toString();m.push(c),process.stderr.write(c)})}return new Promise((m,u)=>{l.on("close",c=>{c!==0?i?(n.info(`Watch mode terminated with code ${c}`),m()):(n.fail(`${e} failed (code ${c})`),u(new Error(`Command failed with exit code ${c}`))):(n.succeed(`${e} completed successfully`),m())})})};import Q from"node:fs";import Kt from"node:path";import{markdownTable as Ke}from"markdown-table";var N=class r{static{this.manifest={schemaVersion:"1.0.0",readme:"",modules:[]}}static generate(t={}){let{outDir:e="./docs",outFile:n="api.md",manifestPath:o="./custom-elements.json"}=t,{getElements:s,renderAllElements:i}=r;if(o)try{let c=Q.readFileSync(o,"utf8");r.manifest=JSON.parse(c)}catch(c){throw console.error(`Error reading manifest file at ${o}:`,c),c}let a=s(),l=e;Q.existsSync(l)||Q.mkdirSync(l,{recursive:!0});let m=i(a),u=Kt.join(l,n);Q.writeFileSync(u,m),console.log(`Generated combined API documentation at ${u}`)}static getElements(){let t=r.manifest.modules.filter(r.isWcaModule);return r.manifest.modules.reduce((e,n)=>e.concat(n.declarations?.filter(o=>"customElement"in o&&o.customElement===!0&&"tagName"in o&&(t.length>0?r.isWcaModule(n):!0))??[]),[])}static isWcaModule(t){let{path:e}=t;return e?e.startsWith("scripts/wca/auro-")&&e.endsWith(".js"):!1}static renderAllElements(t){return`${t.sort((e,n)=>(e.tagName||"").localeCompare(n.tagName||"")).map(e=>r.renderElement(e,!0)).join(`
3
3
 
4
- `)}`}static renderElement(t,e=!0){let n=[],{renderTable:o,renderPropertiesAttributesTable:s,renderParameters:i,getType:a}=r;n.push(e?`# ${t.tagName}`:""),t.description&&n.push(t.description);let l=s(t);l&&n.push(l.trim());let d=o("Methods",["name","parameters","return","description"],(t.members||[]).filter(p=>p.kind==="method"&&("privacy"in p?p.privacy!=="private":!0)&&p.name[0]!=="_").map(p=>({...p,parameters:i("parameters"in p?p.parameters:void 0),return:"return"in p&&p.return?a(p.return):""})));d&&n.push(d.trim());let m=o("Events",["name","description"],t.events);m&&n.push(m.trim());let c=o("Slots",[["name","(default)"],"description"],t.slots);c&&n.push(c.trim());let u=o("CSS Shadow Parts",["name","description"],t.cssParts);u&&n.push(u.trim());let f=o("CSS Custom Properties",["name","description"],t.cssProperties);return f&&n.push(f.trim()),n.join(`
4
+ `)}`}static renderElement(t,e=!0){let n=[],{renderTable:o,renderPropertiesAttributesTable:s,renderParameters:i,getType:a}=r;n.push(e?`# ${t.tagName}`:""),t.description&&n.push(t.description);let l=s(t);l&&n.push(l.trim());let m=o("Methods",["name","parameters","return","description"],(t.members||[]).filter(p=>p.kind==="method"&&("privacy"in p?p.privacy!=="private":!0)&&p.name[0]!=="_").map(p=>({...p,parameters:i("parameters"in p?p.parameters:void 0),return:"return"in p&&p.return?a(p.return):""})));m&&n.push(m.trim());let u=o("Events",["name","description"],t.events);u&&n.push(u.trim());let c=o("Slots",[["name","(default)"],"description"],t.slots);c&&n.push(c.trim());let d=o("CSS Shadow Parts",["name","description"],t.cssParts);d&&n.push(d.trim());let f=o("CSS Custom Properties",["name","description"],t.cssProperties);return f&&n.push(f.trim()),n.join(`
5
5
 
6
- `)}static renderPropertiesAttributesTable(t){let{getType:e,escapeMarkdown:n}=r,o=t.members?.filter(c=>c.kind==="field"&&("privacy"in c?c.privacy!=="private":!0)&&c.name[0]!=="_")||[],s=t.attributes||[],i=[],a=new Set;if(o.forEach(c=>{if(c.description?.trim()){let u=e(c)||"",p=("return"in c&&c.return?e(c.return):"")||u;i.push({name:c.name,properties:c.name,attributes:("attribute"in c?c.attribute:"")||"",modifiers:"readonly"in c&&c.readonly?"readonly":"",type:p,default:("default"in c?c.default:"")||"",description:c.description||""})}a.add(c.name),"attribute"in c&&c.attribute&&a.add(c.attribute)}),s.forEach(c=>{!a.has(c.name)&&c.description?.trim()&&i.push({name:c.name,properties:"",attributes:c.name,modifiers:"",type:e(c)||"",default:c.default||"",description:c.description||""})}),i.length===0)return"";let l=["Properties","Attributes","Modifiers","Type","Default","Description"],d=i.map(c=>{let g=(c.default||"").trim().replace(/^'([^']+)'$/,"$1").replace(/^"([^"]+)"$/,"$1"),b=g?g.startsWith("`")&&g.endsWith("`")?g:`\`${g}\``:"";return[n(c.properties),n(c.attributes),n(c.modifiers),n(c.type),n(b),n(c.description)]});return`### Properties & Attributes
6
+ `)}static renderPropertiesAttributesTable(t){let{getType:e,escapeMarkdown:n}=r,o=t.members?.filter(c=>c.kind==="field"&&("privacy"in c?c.privacy!=="private":!0)&&c.name[0]!=="_")||[],s=t.attributes||[],i=[],a=new Set;if(o.forEach(c=>{if(c.description?.trim()){let d=e(c)||"",p=("return"in c&&c.return?e(c.return):"")||d;i.push({name:c.name,properties:c.name,attributes:("attribute"in c?c.attribute:"")||"",modifiers:"readonly"in c&&c.readonly?"readonly":"",type:p,default:("default"in c?c.default:"")||"",description:c.description||""})}a.add(c.name),"attribute"in c&&c.attribute&&a.add(c.attribute)}),s.forEach(c=>{!a.has(c.name)&&c.description?.trim()&&i.push({name:c.name,properties:"",attributes:c.name,modifiers:"",type:e(c)||"",default:c.default||"",description:c.description||""})}),i.length===0)return"";let l=["Properties","Attributes","Modifiers","Type","Default","Description"],m=i.map(c=>{let g=(c.default||"").trim().replace(/^'([^']+)'$/,"$1").replace(/^"([^"]+)"$/,"$1"),b=g?g.startsWith("`")&&g.endsWith("`")?g:`\`${g}\``:"";return[n(c.properties),n(c.attributes),n(c.modifiers),n(c.type),n(b),n(c.description)]});return`### Properties & Attributes
7
7
 
8
- ${Ke([l,...d])}
9
- `}static renderParameters(t){let{escapeMarkdown:e,getType:n}=r;return!t||t.length===0?"None":t.map(o=>{let s=n(o)||"any",i=o.description?` - ${o.description}`:"";return`\`${o.name}\` (${e(s)})${e(i)}`}).join("<br>")}static renderTable(t,e,n){let{escapeMarkdown:o,get:s,capitalize:i}=r;if(n===void 0||n.length===0)return"";let a=n.filter(c=>{let{description:u}=c;return typeof u=="string"&&u.trim()});if(a.length===0)return"";let l=e.map(c=>i((Array.isArray(c)?c[0]:c).split(".")[0])),d=a.map(c=>e.map(u=>{let f=s(c,u);return o(String(f||""))})),m=Ke([l,...d]);return`### ${t}
8
+ ${Ke([l,...m])}
9
+ `}static renderParameters(t){let{escapeMarkdown:e,getType:n}=r;return!t||t.length===0?"None":t.map(o=>{let s=n(o)||"any",i=o.description?` - ${o.description}`:"";return`\`${o.name}\` (${e(s)})${e(i)}`}).join("<br>")}static renderTable(t,e,n){let{escapeMarkdown:o,get:s,capitalize:i}=r;if(n===void 0||n.length===0)return"";let a=n.filter(c=>{let{description:d}=c;return typeof d=="string"&&d.trim()});if(a.length===0)return"";let l=e.map(c=>i((Array.isArray(c)?c[0]:c).split(".")[0])),m=a.map(c=>e.map(d=>{let f=s(c,d);return o(String(f||""))})),u=Ke([l,...m]);return`### ${t}
10
10
 
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:e}=t,n=s=>s.replace(/\s*\|\s*/g," | ").replace(/'([^']+)'/g,"`$1`");if(typeof e=="string")return n(e);if(e.text)return n(e.text);if(Array.isArray(e))return e.map(s=>typeof s=="string"?s:s.text?s.text:s.name?s.name:String(s)).join(" \\| ");if(e.name)return n(e.name);if(e.references&&Array.isArray(e.references))return e.references.map(s=>s.name||String(s)).join(" \\| ");let o=String(e);return n(o)}static get(t,e){let n="",o=e;Array.isArray(e)&&([o,n]=e);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(/^./,e=>e.toUpperCase()).trim()}};import Yt from"node:fs";import Xt from"node:os";import Q from"node:path";import we from"node:process";function Zt(){let r=Xt.homedir()||we.env.HOME||we.env.USERPROFILE;if(!r)throw new Error("Unable to determine user home directory");return Q.join(r,".auro")}function be(...r){return Q.join(Zt(),...r)}function ke(...r){let t=Yt.realpathSync(we.argv[1]),e=Q.dirname(t);return Q.resolve(e,...r)}var Ye=r=>ke("configs",r);import{copyFileSync as Qt,existsSync as Xe,mkdirSync as er}from"node:fs";import{join as tr,resolve as $e}from"node:path";function j(){let r=process.cwd(),t=$e(r,"README.md"),e=tr($e(r,"demo"),"readme.md");if(!Xe(t))return;let n=$e(r,"demo");Xe(n)||er(n,{recursive:!0}),Qt(t,e)}import rr from"ora";var Qe=[];function _(r){Qe.push(r)}var Ze=!1;function ee(){Ze||(Ze=!0,process.on("SIGINT",()=>{let r=rr("Wrapping up...").start();for(let t of Qe)t.close();r.succeed("All done! See you next time. \u2728"),process.exit(0)}))}import{Logger as nr}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import{generateReadmeUrl as or,processContentForFile as sr,templateFiller as Ae}from"@aurodesignsystem/auro-library/scripts/utils/sharedFileProcessorUtils.mjs";import T from"node:fs";import{readFileSync as ve,existsSync as Ee}from"node:fs";import C from"node:path";var ir="/docs/pages",tt={overwriteLocalCopies:!0,remoteReadmeVersion:"master",remoteReadmeVariant:"_updated_paths",monorepoName:void 0,extraVars:{}};function E(r){return`${process.cwd()}/${r}`}function ar(r=process.cwd()){let t=r;for(;;){let e=C.join(t,"package.json");if(Ee(e))try{if(JSON.parse(ve(e,"utf8")).workspaces)return t}catch{}let n=C.dirname(t);if(n===t)break;t=n}return r}async function cr(r,t=!1){let e=[];if(!t){let o=r.localReadmePath?r.localReadmePath:{remoteUrl:r.remoteReadmeUrl||or(r.remoteReadmeVersion,r.remoteReadmeVariant),fileName:E("/docTemplates/README.md"),overwrite:r.overwriteLocalCopies};e.push({identifier:"README.md",input:o,output:E("/README.md")})}et("/docs/partials/index.md")&&e.push({identifier:"index.md",input:E("/docs/partials/index.md"),output:E("/demo/index.md"),mdMagicConfig:{output:{directory:E("/demo")}}}),et("/docs/partials/api.md")&&e.push({identifier:"api.md",input:E("/docs/partials/api.md"),output:E("/demo/api.md"),preProcessors:[Ae.formatApiTable]});let n=E(ir);if(T.existsSync(n)){let s=(await T.promises.readdir(n)).map(i=>({identifier:i,input:C.join(n,i),output:E(`/demo/${i}`)}));e.push(...s)}return e}async function lr(r=tt,t=!1){await Ae.extractNames();let e=await cr(r,t),n=r.monorepoName;if(!n)try{let s=C.join(ar(),"package.json");n=JSON.parse(ve(s,"utf8")).name?.replace(/^@[^/]+\//,"")}catch{}let o={...n?{monorepoName:n}:{},...r.extraVars||{}};for(let s of e)try{await sr({...s,extraVars:o}),s.output.endsWith(".md")&&await mr(s.output,o)}catch(i){nr.error(`Error processing ${s.identifier}: ${i.message}`)}}async function mr(r,t={}){let e=C.dirname(r),n=await T.promises.readFile(r,"utf8"),o=/^[ \t]*<!-- AURO-GENERATED-CONTENT:START \((FILE|CODE):src=([^)]+)\) -->\n[ \t]*<!-- AURO-GENERATED-CONTENT:END -->/gm,s,i=!1,a=E("demo");for(;(s=o.exec(n))!==null;){let[u,f,p]=s,g=C.resolve(e,p),b=C.resolve(a,p),x=Ee(g)?g:Ee(b)?b:null;if(x){let O=ve(x,"utf8"),k;if(f==="FILE")k=`<!-- AURO-GENERATED-CONTENT:START (FILE:src=${p}) -->
11
+ ${u}
12
+ `}static escapeMarkdown(t){return t.replace(/\\/g,"\\\\").replace(/\n/g,"<br>").replace(/\|/g,"\\|")}static getType(t){if(!t||!t.type)return"";let{type:e}=t,n=s=>s.replace(/\s*\|\s*/g," | ").replace(/'([^']+)'/g,"`$1`");if(typeof e=="string")return n(e);if(e.text)return n(e.text);if(Array.isArray(e))return e.map(s=>typeof s=="string"?s:s.text?s.text:s.name?s.name:String(s)).join(" \\| ");if(e.name)return n(e.name);if(e.references&&Array.isArray(e.references))return e.references.map(s=>s.name||String(s)).join(" \\| ");let o=String(e);return n(o)}static get(t,e){let n="",o=e;Array.isArray(e)&&([o,n]=e);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(/^./,e=>e.toUpperCase()).trim()}};import Yt from"node:fs";import Xt from"node:os";import ee from"node:path";import we from"node:process";function Zt(){let r=Xt.homedir()||we.env.HOME||we.env.USERPROFILE;if(!r)throw new Error("Unable to determine user home directory");return ee.join(r,".auro")}function be(...r){return ee.join(Zt(),...r)}function ke(...r){let t=Yt.realpathSync(we.argv[1]),e=ee.dirname(t);return ee.resolve(e,...r)}var Ye=r=>ke("configs",r);import{copyFileSync as Qt,existsSync as Xe,mkdirSync as er}from"node:fs";import{join as tr,resolve as $e}from"node:path";function j(){let r=process.cwd(),t=$e(r,"README.md"),e=tr($e(r,"demo"),"readme.md");if(!Xe(t))return;let n=$e(r,"demo");Xe(n)||er(n,{recursive:!0}),Qt(t,e)}import rr from"ora";var Qe=[];function _(r){Qe.push(r)}var Ze=!1;function te(){Ze||(Ze=!0,process.on("SIGINT",()=>{let r=rr("Wrapping up...").start();for(let t of Qe)t.close();r.succeed("All done! See you next time. \u2728"),process.exit(0)}))}import{Logger as nr}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import{generateReadmeUrl as or,processContentForFile as sr,templateFiller as Ae}from"@aurodesignsystem/auro-library/scripts/utils/sharedFileProcessorUtils.mjs";import T from"node:fs";import{readFileSync as ve,existsSync as Ee}from"node:fs";import C from"node:path";var ir="/docs/pages",tt={overwriteLocalCopies:!0,remoteReadmeVersion:"master",remoteReadmeVariant:"_updated_paths",monorepoName:void 0,extraVars:{}};function E(r){return`${process.cwd()}/${r}`}function ar(r=process.cwd()){let t=r;for(;;){let e=C.join(t,"package.json");if(Ee(e))try{if(JSON.parse(ve(e,"utf8")).workspaces)return t}catch{}let n=C.dirname(t);if(n===t)break;t=n}return r}async function cr(r,t=!1){let e=[];if(!t){let o=r.localReadmePath?r.localReadmePath:{remoteUrl:r.remoteReadmeUrl||or(r.remoteReadmeVersion,r.remoteReadmeVariant),fileName:E("/docTemplates/README.md"),overwrite:r.overwriteLocalCopies};e.push({identifier:"README.md",input:o,output:E("/README.md")})}et("/docs/partials/index.md")&&e.push({identifier:"index.md",input:E("/docs/partials/index.md"),output:E("/demo/index.md"),mdMagicConfig:{output:{directory:E("/demo")}}}),et("/docs/partials/api.md")&&e.push({identifier:"api.md",input:E("/docs/partials/api.md"),output:E("/demo/api.md"),preProcessors:[Ae.formatApiTable]});let n=E(ir);if(T.existsSync(n)){let s=(await T.promises.readdir(n)).map(i=>({identifier:i,input:C.join(n,i),output:E(`/demo/${i}`)}));e.push(...s)}return e}async function lr(r=tt,t=!1){await Ae.extractNames();let e=await cr(r,t),n=r.monorepoName;if(!n)try{let s=C.join(ar(),"package.json");n=JSON.parse(ve(s,"utf8")).name?.replace(/^@[^/]+\//,"")}catch{}let o={...n?{monorepoName:n}:{},...r.extraVars||{}};for(let s of e)try{await sr({...s,extraVars:o}),s.output.endsWith(".md")&&await ur(s.output,o)}catch(i){nr.error(`Error processing ${s.identifier}: ${i.message}`)}}async function ur(r,t={}){let e=C.dirname(r),n=await T.promises.readFile(r,"utf8"),o=/^[ \t]*<!-- AURO-GENERATED-CONTENT:START \((FILE|CODE):src=([^)]+)\) -->\n[ \t]*<!-- AURO-GENERATED-CONTENT:END -->/gm,s,i=!1,a=E("demo");for(;(s=o.exec(n))!==null;){let[d,f,p]=s,g=C.resolve(e,p),b=C.resolve(a,p),x=Ee(g)?g:Ee(b)?b:null;if(x){let O=ve(x,"utf8"),k;if(f==="FILE")k=`<!-- AURO-GENERATED-CONTENT:START (FILE:src=${p}) -->
13
13
  <!-- The below content is automatically added from ${p} -->
14
14
  ${O.trimEnd()}
15
- <!-- AURO-GENERATED-CONTENT:END -->`;else{let $=C.extname(p).slice(1)||"html",J=O.trimEnd().replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;");k=`<!-- AURO-GENERATED-CONTENT:START (CODE:src=${p}) -->
15
+ <!-- AURO-GENERATED-CONTENT:END -->`;else{let $=C.extname(p).slice(1)||"html",K=O.trimEnd().replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;");k=`<!-- AURO-GENERATED-CONTENT:START (CODE:src=${p}) -->
16
16
  <!-- The below code snippet is automatically added from ${p} -->
17
- <pre class="language-${$}"><code class="language-${$}">${J}
17
+ <pre class="language-${$}"><code class="language-${$}">${K}
18
18
  </code></pre>
19
- <!-- AURO-GENERATED-CONTENT:END -->`}n=n.replace(u,k),o.lastIndex=0,i=!0}}i&&(n=Ae.replaceTemplateValues(n,t),await T.promises.writeFile(r,n)),n=await T.promises.readFile(r,"utf8");let l=/^[ \t]*```(\w*)\n([\s\S]*?)^[ \t]*```[ \t]*$/gm,d=n.replace(l,(u,f,p)=>{let g=f||"html",b=p.trimEnd().replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;");return`<pre class="language-${g}"><code class="language-${g}">${b}
20
- </code></pre>`});d!==n&&await T.promises.writeFile(r,d),n=await T.promises.readFile(r,"utf8"),n=n.replace(/(<pre[^>]*><code[^>]*>)([\s\S]*?)(<\/code><\/pre>)/g,(u,f,p,g)=>{let b=p.split(`
21
- `),x=b.filter($=>$.trim().length>0);if(x.length===0)return u;let O=Math.min(...x.map($=>{let J=$.match(/^[ \t]*/);return J?J[0].length:0})),k=b.map($=>$===""||$.trim().length===0?"\u200B":O>0?$.substring(O):$);for(;k.length>0&&(k[k.length-1]==="\u200B"||k[k.length-1]==="");)k.pop();return f+k.join(`
22
- `)+g});let m=n.split(`
23
- `),c=!1;for(let u=0;u<m.length;u++)/<pre[\s>]/i.test(m[u])&&(c=!0),c||(m[u]=m[u].replace(/^[ \t]+(?=<)/,"")),/<\/pre>/i.test(m[u])&&(c=!1);await T.promises.writeFile(r,m.join(`
24
- `))}async function F(r={}){let t=r.readmeTemplate,e=t&&!t.startsWith("http");await lr({...tt,...e?{localReadmePath:C.resolve(process.cwd(),t)}:{remoteReadmeUrl:t||"https://raw.githubusercontent.com/AlaskaAirlines/auro-templates/main/templates/default/README.md"}},r.skipReadme)}function et(r){return T.existsSync(E(r))}import{existsSync as rt,readFileSync as ur}from"node:fs";import{builtinModules as dr}from"node:module";import{resolve as te}from"node:path";import{startDevServer as pr}from"@web/dev-server";import{hmrPlugin as fr}from"@web/dev-server-hmr";import*as nt from"esbuild";import gr from"ora";var P=["node_modules","../node_modules","../../node_modules","../../../node_modules"];var hr=/^\/__wds-outside-root__\/(\d+)\/(.+)$/;function yr(){return{name:"node-modules-css",serve(r){if(!r.path.endsWith(".css")||!r.path.startsWith("/@")&&!/^\/[a-z]/i.test(r.path))return;let t=r.path.slice(1),e=process.cwd();for(let n of P){let o=te(e,n,t);if(rt(o))return{body:ur(o,"utf-8"),type:"css"}}}}}function wr(r,t){let e=r.match(hr);return e?te(t,"../".repeat(Number.parseInt(e[1],10)),e[2]):te(t,`.${r}`)}function br(){let r=/\b(require\s*\(|module\.exports\b|exports\.\w)/,t=new Map,e;return{name:"cjs-to-esm",async serverStart({config:n}){e=te(n.rootDir)},async transform(n){if(!n.path.includes("node_modules")||!n.path.endsWith(".js")&&!n.path.endsWith(".cjs")||typeof n.body!="string"||!r.test(n.body))return;let o=wr(n.path,e);if(t.has(o))return t.get(o);if(rt(o))try{let i={body:(await nt.build({entryPoints:[o],bundle:!0,format:"esm",platform:"browser",write:!1,logLevel:"silent",external:dr})).outputFiles[0].text};return t.set(o,i),i}catch(s){console.error(`CJS-to-ESM bundling failed for ${n.path}:`,s.message)}}}}var B={watch:!0,nodeResolve:!0,basePath:"/",rootDir:"./demo",hmrInclude:["src/**/*","demo/**/*","apiExamples/**/*","docs/**/*"]};async function re(r={}){if(!r.serve)return;let t=gr(`Firing up dev server...
25
- `).start();try{let e={port:Number(r.port)||void 0,open:r.open?"/":void 0,watch:r.watch??B.watch,nodeResolve:r.nodeResolve??B.nodeResolve,basePath:r.basePath??B.basePath,rootDir:r.rootDir??B.rootDir,middleware:[function(s,i){return!s.url.endsWith("/")&&!s.url.includes(".")&&(s.url+=".html"),i()}],plugins:[yr(),br(),fr({include:r.hmrInclude??B.hmrInclude})]},n=await pr({config:e,readCliArgs:!1,readFileConfig:!1});return t.stop(),n}catch(e){throw t.fail("Server snag! Couldn't start dev server."),console.error("Error starting development server:",e),new Error(`Development server failed to start: ${e.message}`)}}async function ne(){let r=M("Generating Custom Elements Manifest...").start();try{await A(`npx --package=@custom-elements-manifest/analyzer -y -- cem analyze --config '${Ye("custom-elements-manifest.config.mjs")}'`),r.succeed("Custom Elements Manifest generated successfully!")}catch(t){let e=t instanceof Error?t.message:String(t);r.warn("CEM analyzer completed with warnings: "+e)}}async function oe(){let r=M("Generating API md file...").start();try{await N.generate(),r.succeed("API md file generated successfully!")}catch(t){let e=t instanceof Error?t.message:String(t);throw r.fail("Failed to generate API md file: "+e),t}}async function ot(r={}){let t=M("Compiling documentation...").start();try{await F(r),t.succeed("Documentation compiled successfully!")}catch(e){let n=e instanceof Error?e.message:String(e);throw t.fail("Failed to compile MD documentation: "+n),e}j(),await I(),await Te(r)}async function st(r={}){await re(r)}async function it(r={}){let t=await import("chokidar"),e=["./src/**/*","./docs/**/*","./docTemplates/**/*","./apiExamples/**/*","./demo/**/*.scss"],n=["**/demo/*.min.js","**/demo/*.min.css","**/demo/*.md","**/demo/readme.md","**/docs/api.md","**/custom-elements.json","**/node_modules/**","**/dist/**","**/.git/**"],o=t.watch(e,{ignoreInitial:!0,ignored:n,awaitWriteFinish:{stabilityThreshold:1e3,pollInterval:100}}),s=M("Waiting for changes...");s.spinner="bouncingBar",s.color="green",s.start();let i=null,a=!1,l=!1;async function d(m){if(a){l=!0;return}a=!0,o.unwatch(e);let c=M(`Change detected: ${m}`).start();try{await F(r),j(),await I(),await Te(r),c.succeed("Docs rebuilt!")}catch(u){let f=u instanceof Error?u.message:String(u);c.fail("Rebuild failed: "+f)}finally{setTimeout(()=>{o.add(e),a=!1,l&&(l=!1,d("queued changes"))},1e3)}}o.on("all",(m,c)=>{a||(i&&clearTimeout(i),i=setTimeout(()=>{d(c)},1e3))}),_(o),ee()}async function se(){await ne(),await oe()}import{basename as Er,join as ct}from"node:path";import Ar from"@rollup/plugin-commonjs";import{nodeResolve as vr}from"@rollup/plugin-node-resolve";import{glob as Tr}from"glob";import{litScss as Cr}from"rollup-plugin-scss-lit";import kr from"node:path";import{glob as $r}from"glob";function at(r){return{name:"watch-globs",buildStart(){let t=Array.isArray(r)?r:[r];for(let e of t)try{for(let n of $r.sync(kr.resolve(e)))this.addWatchFile(n)}catch(n){this.error(`Error watching glob pattern "${e}": ${n.message}`)}}}}var Ce={moduleDirectories:["node_modules"],modulePaths:["../../node_modules","../node_modules","node_modules"],watchPatterns:["./apiExamples/**/*","./docs/**/*"]};function lt(r=[],t={}){let{watchPatterns:e=Ce.watchPatterns,dedupe:n=["lit","lit-element","lit-html"],dev:o=!1}=t,s=[...Ce.modulePaths,...r];return[vr({dedupe:n,preferBuiltins:!1,moduleDirectories:Ce.moduleDirectories}),Ar(),Cr({minify:o?!1:{fast:!0},options:{loadPaths:[...s,ct(process.cwd(),"src","styles"),ct(process.cwd(),"src")]}}),at(e)]}function Ie(r={}){let{modulePaths:t=[],watch:e=!1,input:n=["./src/index.js","./src/registered.js"],outputDir:o="./dist",format:s="esm",dev:i=!1}=r;return{name:"Main",config:{input:n,output:{format:s,dir:o,entryFileNames:a=>i||["index","registered"].includes(a.name)?"[name].js":"[name]-[hash].js",chunkFileNames:i?"[name].js":"[name]-[hash].js",assetFileNames:i?"[name][extname]":"[name]-[hash][extname]"},external:Ir(),plugins:lt(t,{dev:i}),watch:mt(e)}}}function G(r={}){let{modulePaths:t=[],watch:e=!1,globPattern:n="./demo/*.js",ignorePattern:o=["./demo/*.min.js"],outputDir:s="./demo",dev:i=!1}=r;return{name:"Demo",config:{input:Object.fromEntries(Tr.sync(n,{ignore:o}).map(a=>[Er(a,".js"),a])),output:{format:"esm",dir:s,entryFileNames:"[name].min.js",chunkFileNames:"[name].min.js",assetFileNames:i?"[name][extname]":"[name]-[hash][extname]"},plugins:lt(t,{dev:i}),watch:mt(e)}}}function mt(r){if(!r)return!1;let t=typeof r=="object"?r:{};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","**/demo/**/*.min.css","**/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 Ir(r=[]){return[...[/node_modules\/lit/,/node_modules\/lit-element/,/node_modules\/lit-html/,/node_modules\/@lit/],...r]}function ft(){let r=H("./dist"),t=Se("Cleaning dist folder...").start();try{return Sr(r,{recursive:!0,force:!0}),t.succeed("All clean! Dist folder wiped."),!0}catch(e){return t.fail(`Oops! Couldn't clean dist/ folder: ${e.message}`),console.error(e),!1}}async function ae(r,t,e,n){let o=Se(r).start();try{let s=await t();return o.succeed(e),s}catch(s){throw o.fail(n),console.error(`Error: ${s.message}`),s}}async function gt(r,t){return ae(`Bundling ${r.name||"main"} and ${t.name||"demo"}...`,async()=>{let e=await Re(r);await e.write(r.output),await e.close();let n=await Re(t);await n.write(t.output),await n.close()},`Bundles ready! ${r.name||"Main"} and ${t.name||"demo"} built.`,"Bundle hiccup! Build failed.")}async function ce(r){let{wcaInput:t,wcaOutput:e,skipDocs:n}=r;if(n){let o=Se("Skipping docs generation...").start();setTimeout(()=>{o.succeed("Docs generation skipped.")},0);return}return ae("Analyzing components and making docs...",async()=>{await se(t,e),await F(r),j()},"Docs ready! Looking good.","Doc troubles!")}function Nr(){let r=process.cwd();function t(o){return[o,`${o}.scss`,`${o}.css`,H(xr(o),`_${Pr(o)}.scss`),H(o,"_index.scss"),H(o,"index.scss")].find(i=>ut(i))}function e(o){for(let i of P){let a=t(ie(r,i,o));if(a)return a}let s=n(o);return s||null}function n(o){let s,i;if(o.startsWith("@")){let a=o.split("/");if(a.length<3)return null;s=`${a[0]}/${a[1]}`,i=`./${a.slice(2).join("/")}`}else{let a=o.indexOf("/");if(a===-1)return null;s=o.slice(0,a),i=`./${o.slice(a+1)}`}for(let a of P){let l=ie(r,a,s,"package.json");if(ut(l))try{let m=JSON.parse(Rr(l,"utf-8")).exports;if(!m||typeof m!="object")continue;let c=m[i];if(!c)continue;let u=typeof c=="string"?c:c.default||c.import;if(!u)continue;let f=t(ie(r,a,s,u));if(f)return f}catch{continue}}return null}return{findFileUrl(o){if(o.includes("/node_modules/")){let s=o.lastIndexOf("/node_modules/"),i=o.slice(s+14),a=e(i);if(a)return dt(a)}if(!o.startsWith(".")&&!o.startsWith("/")&&!o.startsWith("file:")){let s=e(o);if(s)return dt(s)}return null}}}async function I(r="./demo"){return ae("Compiling demo SCSS...",async()=>{let t=Or.sync(H(r,"**/*.scss")),e=Nr(),n=process.cwd(),o=P.map(s=>ie(n,s));for(let s of t){let i=pt.compile(s,{importers:[e],loadPaths:o,silenceDeprecations:["import"],style:"compressed"}),a=s.replace(/\.scss$/,".min.css");Dr(a,i.css)}return t.length},"Demo SCSS compiled.","SCSS compilation failed.")}async function Te(r={}){let t=G(r);return ae("Bundling demo JS...",async()=>{let e=await Re(t.config);await e.write(t.config.output),await e.close()},"Demo JS bundled.","Demo JS bundling failed.")}import ht from"node:path";import S from"ora";import"rollup";var L=!1,jr={analyze:{active:!1,lastTime:0},docs:{active:!1,lastTime:0},scss:{active:!1,lastTime:0}},_r=5e3,le=new Set,Fr=["/dist/index.d.ts","/custom-elements.json","/demo/api.md","/docs/api.md","/demo/index.min.js"];function Br(r){if(!r||typeof r!="string")return!1;try{let t=ht.normalize(r);return Fr.some(e=>t.endsWith(e))||t.includes("/dist/")||t.endsWith(".min.js")||t.endsWith(".min.css")||t.endsWith(".d.ts")}catch(t){return console.error(`Error checking path (${typeof r}):`,t.message),!1}}async function De(r,t){let e=jr[r];if(e.active||Date.now()-e.lastTime<_r)return!1;try{return e.active=!0,e.lastTime=Date.now(),await t()}catch(n){return console.error(`Error in ${r} task:`,n),!1}finally{e.active=!1}}async function yt(r,t,e){let n=!0,o={analyze:!1,docs:!1,scss:!1},s=null,i,a=S("Activating watch mode...").start(),l={analyze:async()=>{let{wcaInput:c,wcaOutput:u,skipDocs:f}=t;if(f){let g=S("Skipping component analysis...").start();return setTimeout(()=>{g.succeed("Component analysis skipped.")},0),!0}let p=S("Detective work: analyzing components...").start();try{return await se(c,u),p.succeed("Component analysis complete! API generated."),!0}catch(g){return p.fail("Analysis hiccup! Something went wrong."),console.error("Component analysis error:",g),!1}},docs:async()=>{if(L)return!1;if(t.skipDocs){let u=S("Skipping docs generation...").start();return setTimeout(()=>{u.succeed("Docs generation skipped.")},0),!0}let c=S("Refreshing docs...").start();try{return await ce(t),c.succeed("Documentation refreshed!"),!0}catch(u){c.fail("Docs stumble! Couldn't refresh."),console.error("Documentation rebuild error:",u)}},scss:async()=>{if(L)return!1;try{return await I(),!0}catch(c){return console.error("Demo SCSS compilation error:",c),!1}}},d=()=>{n&&o.analyze&&o.docs&&o.scss&&typeof e=="function"&&(n=!1,e())};function m(c=1e3){s&&clearTimeout(s),s=setTimeout(async()=>{setTimeout(async()=>{o.analyze=await De("analyze",l.analyze),setTimeout(async()=>{o.docs=await De("docs",l.docs),setTimeout(async()=>{o.scss=await De("scss",l.scss),d()},500)},1e3)},1e3)},c)}r.on("event",async c=>{switch(c.code){case"START":a.succeed("Watch mode active! Eyes peeled.");break;case"BUNDLE_START":if(le.clear(),c.input)try{let u=Array.isArray(c.input)?c.input:typeof c.input=="string"?[c.input]:typeof c.input=="object"&&c.input!==null?Object.values(c.input):[];for(let f of u)typeof f=="string"&&!Br(f)&&le.add(ht.normalize(f))}catch(u){console.error("Error processing input paths:",u)}i=S("Weaving bundles...").start(),L=!0;break;case"BUNDLE_END":i&&i.succeed(`Bundle ${Array.isArray(c.input)?`of ${c.input.join("& ")} `:""}done in ${c.duration}ms! \u{1F680}`),L=!1,le.size>0&&m();break;case"END":break;case"ERROR":L=!1,i?i.fail(`Oops! Bundle hit a snag: ${c.error.message}`):S().fail(`Watch mode hiccup: ${c.error.message}`),le.clear();break}})}function wt(r,t){return _(r),t&&_(t),ee(),r}async function Hr(r){let t=Ie(r),e=G(r);r.dev||t.config.plugins.push(Mr()),await ce(r),await I(),await gt(t.config,e.config)}async function Lr(r){let{dev:t}=r,e=Ie({...r,watch:!0}),n=G({...r,watch:!0}),o=Gr([e.config,n.config]);yt(o,r,t?async()=>re(r):void 0);let s=await import("chokidar"),i=!1,a=!1,l=null,d=s.watch("./demo/**/*.scss",{ignoreInitial:!0,ignored:["**/demo/**/*.min.css"],awaitWriteFinish:{stabilityThreshold:500,pollInterval:100}});return d.on("all",()=>{l&&clearTimeout(l),l=setTimeout(async()=>{if(i){a=!0;return}i=!0;try{await I()}catch(m){console.error("Demo SCSS watch compilation error:",m)}finally{i=!1,a&&(a=!1,d.emit("all"))}},500)}),wt(o,d),o}async function me(r={}){try{let{watch:t}=r;return ft(),t?await Lr(r):await Hr(r)}catch(t){throw new Error(`Build failed: ${t.message}`)}}var W=Wr.command("dev").description("Runs development server for auro components");W=Y(W);W=X(W);var Os=W.action(async r=>{try{let t=bt("Initializing...");r.watch?(t.text="Waiting for changes...",t.spinner="bouncingBar",t.color="green"):t.text=r.docs===!1?"Building component (docs disabled)":"Building component",t.start(),r.watch||t.succeed("Build completed!"),await me({...r,dev:!0,watch:r.watch})}catch(t){bt().fail(`Build failed: ${t.message}`),console.error(t),process.exit(1)}});import{program as Ur}from"commander";import kt from"ora";var Pe=Ur.command("build").description("Builds auro components");Pe=Y(Pe);var Ms=Pe.action(async r=>{try{let t=kt("Initializing...");r.watch?(t.text="Waiting for changes...",t.spinner="bouncingBar",t.color="green"):t.text=r.docs===!1?"Building component (docs disabled)":"Building component",t.start(),await me(r),r.watch||t.succeed("Build completed!")}catch(t){kt().fail(`Build failed: ${t.message}`),console.error(t),process.exit(1)}});import{exec as zr}from"node:child_process";import $t from"node:path";import qr from"node:process";import{fileURLToPath as Vr}from"node:url";import Jr from"node:util";import{program as Kr}from"commander";import Yr from"inquirer";var Ks=Kr.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 r=>{let t=Vr(import.meta.url),e=$t.dirname(t),n=$t.resolve(e,"migrations",r.id);if(r.multiGitter){let o=Jr.promisify(zr);try{await o("command -v multi-gitter")}catch{console.error("multi-gitter is not installed."),qr.exit(1)}(await Yr.prompt([{type:"confirm",name:"dryRun",message:"Run migration in dry-run mode? (no changes will be committed)",default:!0}])).dryRun?A(`multi-gitter run ${n}/script.sh --config "${n}/multi-gitter.yml" --dry-run`):A(`multi-gitter run ${n}/script.sh --config "${n}/multi-gitter.yml"`)}else A(`${n}/script.sh`)});import Ct from"node:process";import{program as tn}from"commander";import{readFile as rn,writeFile as nn}from"node:fs/promises";import{Logger as U}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import xe from"node:fs/promises";import Oe from"node:path";import{Octokit as Xr}from"@octokit/rest";import v from"ora";import{processContentForFile as Zr,templateFiller as Qr}from"@aurodesignsystem/auro-library/scripts/utils/sharedFileProcessorUtils.mjs";async function Et(r,t){let e=new Xr({auth:process.env.GITHUB_TOKEN||""});try{let o=(await e.request("GET /repos/{owner}/{repo}/contents/{path}",{ref:t,owner:"AlaskaAirlines",repo:"auro-templates",path:r,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 v().start().fail(s),new Error("Failed to retrieve folder items")}return o}catch(n){let o=v().start();throw n.status===404?o.fail(`Template '${r.split("/")[1]}' not found`):o.fail(`Error accessing template: ${n.message}`),n}}async function At({folderItems:r,templatePathToReplace:t,rootDir:e,ref:n}){let o=[];for(let s of r){if(s.type=="dir"){let d=v(`Processing directory: ${s.path}`).start(),m=await Et(s.path,n);d.succeed(`Found ${m.length} additional items in ${s.path}`);let c=await At({folderItems:m,templatePathToReplace:t,rootDir:e,ref:n});o.push(...c);continue}let i=s.path.replace(`${t}/`,""),a=`${e}/.github/${i}`,l={identifier:s.name,input:{remoteUrl:s.download_url||"",fileName:a,overwrite:!0},output:a};o.push(l)}return o}async function en(r){try{await xe.rm(r,{recursive:!0,force:!0}),v().start().succeed(`Successfully removed directory: ${r}`)}catch(t){throw v().start().fail(`Error removing directory ${r}: ${t.message}`),t}}async function vt(r,t="",e=!0){try{let n=await xe.stat(r),o=Oe.basename(r);if(!n.isDirectory())return`${t}${e?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 "}${o}
19
+ <!-- AURO-GENERATED-CONTENT:END -->`}n=n.replace(d,k),o.lastIndex=0,i=!0}}i&&(n=Ae.replaceTemplateValues(n,t),await T.promises.writeFile(r,n)),n=await T.promises.readFile(r,"utf8");let l=/^[ \t]*```(\w*)\n([\s\S]*?)^[ \t]*```[ \t]*$/gm,m=n.replace(l,(d,f,p)=>{let g=f||"html",b=p.trimEnd().replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;");return`<pre class="language-${g}"><code class="language-${g}">${b}
20
+ </code></pre>`});m!==n&&await T.promises.writeFile(r,m),n=await T.promises.readFile(r,"utf8"),n=n.replace(/(<pre[^>]*><code[^>]*>)([\s\S]*?)(<\/code><\/pre>)/g,(d,f,p,g)=>{let b=p.split(`
21
+ `),x=b.filter($=>$.trim().length>0);if(x.length===0)return d;let O=Math.min(...x.map($=>{let K=$.match(/^[ \t]*/);return K?K[0].length:0})),k=b.map($=>$===""||$.trim().length===0?"\u200B":O>0?$.substring(O):$);for(;k.length>0&&(k[k.length-1]==="\u200B"||k[k.length-1]==="");)k.pop();return f+k.join(`
22
+ `)+g});let u=n.split(`
23
+ `),c=!1;for(let d=0;d<u.length;d++)/<pre[\s>]/i.test(u[d])&&(c=!0),c||(u[d]=u[d].replace(/^[ \t]+(?=<)/,"")),/<\/pre>/i.test(u[d])&&(c=!1);await T.promises.writeFile(r,u.join(`
24
+ `))}async function F(r={}){let t=r.readmeTemplate,e=t&&!t.startsWith("http");await lr({...tt,...e?{localReadmePath:C.resolve(process.cwd(),t)}:{remoteReadmeUrl:t||"https://raw.githubusercontent.com/AlaskaAirlines/auro-templates/main/templates/default/README.md"}},r.skipReadme)}function et(r){return T.existsSync(E(r))}import{existsSync as rt,readFileSync as mr}from"node:fs";import{builtinModules as dr}from"node:module";import{resolve as re}from"node:path";import{startDevServer as pr}from"@web/dev-server";import{hmrPlugin as fr}from"@web/dev-server-hmr";import*as nt from"esbuild";import gr from"ora";var P=["node_modules","../node_modules","../../node_modules","../../../node_modules"];var hr=/^\/__wds-outside-root__\/(\d+)\/(.+)$/;function yr(){return{name:"node-modules-css",serve(r){if(!r.path.endsWith(".css")||!r.path.startsWith("/@")&&!/^\/[a-z]/i.test(r.path))return;let t=r.path.slice(1),e=process.cwd();for(let n of P){let o=re(e,n,t);if(rt(o))return{body:mr(o,"utf-8"),type:"css"}}}}}function wr(r,t){let e=r.match(hr);return e?re(t,"../".repeat(Number.parseInt(e[1],10)),e[2]):re(t,`.${r}`)}function br(){let r=/\b(require\s*\(|module\.exports\b|exports\.\w)/,t=new Map,e;return{name:"cjs-to-esm",async serverStart({config:n}){e=re(n.rootDir)},async transform(n){if(!n.path.includes("node_modules")||!n.path.endsWith(".js")&&!n.path.endsWith(".cjs")||typeof n.body!="string"||!r.test(n.body))return;let o=wr(n.path,e);if(t.has(o))return t.get(o);if(rt(o))try{let i={body:(await nt.build({entryPoints:[o],bundle:!0,format:"esm",platform:"browser",write:!1,logLevel:"silent",external:dr})).outputFiles[0].text};return t.set(o,i),i}catch(s){console.error(`CJS-to-ESM bundling failed for ${n.path}:`,s.message)}}}}var B={watch:!0,nodeResolve:!0,basePath:"/",rootDir:"./demo",hmrInclude:["src/**/*","demo/**/*","apiExamples/**/*","docs/**/*"]};async function ne(r={}){if(!r.serve)return;let t=gr(`Firing up dev server...
25
+ `).start();try{let e={port:Number(r.port)||void 0,open:r.open?"/":void 0,watch:r.watch??B.watch,nodeResolve:r.nodeResolve??B.nodeResolve,basePath:r.basePath??B.basePath,rootDir:r.rootDir??B.rootDir,middleware:[function(s,i){return!s.url.endsWith("/")&&!s.url.includes(".")&&(s.url+=".html"),i()}],plugins:[yr(),br(),fr({include:r.hmrInclude??B.hmrInclude})]},n=await pr({config:e,readCliArgs:!1,readFileConfig:!1});return t.stop(),n}catch(e){throw t.fail("Server snag! Couldn't start dev server."),console.error("Error starting development server:",e),new Error(`Development server failed to start: ${e.message}`)}}async function oe(){let r=M("Generating Custom Elements Manifest...").start();try{await A(`npx --package=@custom-elements-manifest/analyzer -y -- cem analyze --config '${Ye("custom-elements-manifest.config.mjs")}'`),r.succeed("Custom Elements Manifest generated successfully!")}catch(t){let e=t instanceof Error?t.message:String(t);r.warn("CEM analyzer completed with warnings: "+e)}}async function se(){let r=M("Generating API md file...").start();try{await N.generate(),r.succeed("API md file generated successfully!")}catch(t){let e=t instanceof Error?t.message:String(t);throw r.fail("Failed to generate API md file: "+e),t}}async function ot(r={}){let t=M("Compiling documentation...").start();try{await F(r),t.succeed("Documentation compiled successfully!")}catch(e){let n=e instanceof Error?e.message:String(e);throw t.fail("Failed to compile MD documentation: "+n),e}j(),await I(),await Te(r)}async function st(r={}){await ne(r)}async function it(r={}){let t=await import("chokidar"),e=["./src/**/*","./docs/**/*","./docTemplates/**/*","./apiExamples/**/*","./demo/**/*.scss"],n=["**/demo/*.min.js","**/demo/*.min.css","**/demo/*.md","**/demo/readme.md","**/docs/api.md","**/custom-elements.json","**/node_modules/**","**/dist/**","**/.git/**"],o=t.watch(e,{ignoreInitial:!0,ignored:n,awaitWriteFinish:{stabilityThreshold:1e3,pollInterval:100}}),s=M("Waiting for changes...");s.spinner="bouncingBar",s.color="green",s.start();let i=null,a=!1,l=!1;async function m(u){if(a){l=!0;return}a=!0,o.unwatch(e);let c=M(`Change detected: ${u}`).start();try{await F(r),j(),await I(),await Te(r),c.succeed("Docs rebuilt!")}catch(d){let f=d instanceof Error?d.message:String(d);c.fail("Rebuild failed: "+f)}finally{setTimeout(()=>{o.add(e),a=!1,l&&(l=!1,m("queued changes"))},1e3)}}o.on("all",(u,c)=>{a||(i&&clearTimeout(i),i=setTimeout(()=>{m(c)},1e3))}),_(o),te()}async function ie(){await oe(),await se()}import{basename as Er,join as ct}from"node:path";import Ar from"@rollup/plugin-commonjs";import{nodeResolve as vr}from"@rollup/plugin-node-resolve";import{glob as Tr}from"glob";import{litScss as Cr}from"rollup-plugin-scss-lit";import kr from"node:path";import{glob as $r}from"glob";function at(r){return{name:"watch-globs",buildStart(){let t=Array.isArray(r)?r:[r];for(let e of t)try{for(let n of $r.sync(kr.resolve(e)))this.addWatchFile(n)}catch(n){this.error(`Error watching glob pattern "${e}": ${n.message}`)}}}}var Ce={moduleDirectories:["node_modules"],modulePaths:["../../node_modules","../node_modules","node_modules"],watchPatterns:["./apiExamples/**/*","./docs/**/*"]};function lt(r=[],t={}){let{watchPatterns:e=Ce.watchPatterns,dedupe:n=["lit","lit-element","lit-html"],dev:o=!1}=t,s=[...Ce.modulePaths,...r];return[vr({dedupe:n,preferBuiltins:!1,moduleDirectories:Ce.moduleDirectories}),Ar(),Cr({minify:o?!1:{fast:!0},options:{loadPaths:[...s,ct(process.cwd(),"src","styles"),ct(process.cwd(),"src")]}}),at(e)]}function Ie(r={}){let{modulePaths:t=[],watch:e=!1,input:n=["./src/index.js","./src/registered.js"],outputDir:o="./dist",format:s="esm",dev:i=!1}=r;return{name:"Main",config:{input:n,output:{format:s,dir:o,entryFileNames:a=>i||["index","registered"].includes(a.name)?"[name].js":"[name]-[hash].js",chunkFileNames:i?"[name].js":"[name]-[hash].js",assetFileNames:i?"[name][extname]":"[name]-[hash][extname]"},external:Ir(),plugins:lt(t,{dev:i}),watch:ut(e)}}}function G(r={}){let{modulePaths:t=[],watch:e=!1,globPattern:n="./demo/*.js",ignorePattern:o=["./demo/*.min.js"],outputDir:s="./demo",dev:i=!1}=r,a=Tr.sync(n,{ignore:o}),l=lt(t,{dev:i}),m=ut(e);return{name:"Demo",configs:a.map(c=>({input:{[Er(c,".js")]:c},output:{format:"esm",dir:s,entryFileNames:"[name].min.js",chunkFileNames:"[name].min.js",assetFileNames:i?"[name][extname]":"[name]-[hash][extname]",inlineDynamicImports:!0},plugins:l,watch:m}))}}function ut(r){if(!r)return!1;let t=typeof r=="object"?r:{};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","**/demo/**/*.min.css","**/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 Ir(r=[]){return[...[/node_modules\/lit/,/node_modules\/lit-element/,/node_modules\/lit-html/,/node_modules\/@lit/],...r]}function ft(){let r=H("./dist"),t=Se("Cleaning dist folder...").start();try{return Sr(r,{recursive:!0,force:!0}),t.succeed("All clean! Dist folder wiped."),!0}catch(e){return t.fail(`Oops! Couldn't clean dist/ folder: ${e.message}`),console.error(e),!1}}async function ce(r,t,e,n){let o=Se(r).start();try{let s=await t();return o.succeed(e),s}catch(s){throw o.fail(n),console.error(`Error: ${s.message}`),s}}async function gt(r,t){return ce(`Bundling ${r.name||"main"} and demo...`,async()=>{let e=await Re(r);await e.write(r.output),await e.close();for(let n of t){let o=await Re(n);await o.write(n.output),await o.close()}},`Bundles ready! ${r.name||"Main"} and demo built.`,"Bundle hiccup! Build failed.")}async function le(r){let{wcaInput:t,wcaOutput:e,skipDocs:n}=r;if(n){let o=Se("Skipping docs generation...").start();setTimeout(()=>{o.succeed("Docs generation skipped.")},0);return}return ce("Analyzing components and making docs...",async()=>{await ie(t,e),await F(r),j()},"Docs ready! Looking good.","Doc troubles!")}function Nr(){let r=process.cwd();function t(o){return[o,`${o}.scss`,`${o}.css`,H(xr(o),`_${Pr(o)}.scss`),H(o,"_index.scss"),H(o,"index.scss")].find(i=>mt(i))}function e(o){for(let i of P){let a=t(ae(r,i,o));if(a)return a}let s=n(o);return s||null}function n(o){let s,i;if(o.startsWith("@")){let a=o.split("/");if(a.length<3)return null;s=`${a[0]}/${a[1]}`,i=`./${a.slice(2).join("/")}`}else{let a=o.indexOf("/");if(a===-1)return null;s=o.slice(0,a),i=`./${o.slice(a+1)}`}for(let a of P){let l=ae(r,a,s,"package.json");if(mt(l))try{let u=JSON.parse(Rr(l,"utf-8")).exports;if(!u||typeof u!="object")continue;let c=u[i];if(!c)continue;let d=typeof c=="string"?c:c.default||c.import;if(!d)continue;let f=t(ae(r,a,s,d));if(f)return f}catch{continue}}return null}return{findFileUrl(o){if(o.includes("/node_modules/")){let s=o.lastIndexOf("/node_modules/"),i=o.slice(s+14),a=e(i);if(a)return dt(a)}if(!o.startsWith(".")&&!o.startsWith("/")&&!o.startsWith("file:")){let s=e(o);if(s)return dt(s)}return null}}}async function I(r="./demo"){return ce("Compiling demo SCSS...",async()=>{let t=Or.sync(H(r,"**/*.scss")),e=Nr(),n=process.cwd(),o=P.map(s=>ae(n,s));for(let s of t){let i=pt.compile(s,{importers:[e],loadPaths:o,silenceDeprecations:["import"],style:"compressed"}),a=s.replace(/\.scss$/,".min.css");Dr(a,i.css)}return t.length},"Demo SCSS compiled.","SCSS compilation failed.")}async function Te(r={}){let{configs:t}=G(r);return ce("Bundling demo JS...",async()=>{for(let e of t){let n=await Re(e);await n.write(e.output),await n.close()}},"Demo JS bundled.","Demo JS bundling failed.")}import ht from"node:path";import S from"ora";import"rollup";var L=!1,jr={analyze:{active:!1,lastTime:0},docs:{active:!1,lastTime:0},scss:{active:!1,lastTime:0}},_r=5e3,ue=new Set,Fr=["/dist/index.d.ts","/custom-elements.json","/demo/api.md","/docs/api.md","/demo/index.min.js"];function Br(r){if(!r||typeof r!="string")return!1;try{let t=ht.normalize(r);return Fr.some(e=>t.endsWith(e))||t.includes("/dist/")||t.endsWith(".min.js")||t.endsWith(".min.css")||t.endsWith(".d.ts")}catch(t){return console.error(`Error checking path (${typeof r}):`,t.message),!1}}async function De(r,t){let e=jr[r];if(e.active||Date.now()-e.lastTime<_r)return!1;try{return e.active=!0,e.lastTime=Date.now(),await t()}catch(n){return console.error(`Error in ${r} task:`,n),!1}finally{e.active=!1}}async function yt(r,t,e){let n=!0,o={analyze:!1,docs:!1,scss:!1},s=null,i,a=S("Activating watch mode...").start(),l={analyze:async()=>{let{wcaInput:c,wcaOutput:d,skipDocs:f}=t;if(f){let g=S("Skipping component analysis...").start();return setTimeout(()=>{g.succeed("Component analysis skipped.")},0),!0}let p=S("Detective work: analyzing components...").start();try{return await ie(c,d),p.succeed("Component analysis complete! API generated."),!0}catch(g){return p.fail("Analysis hiccup! Something went wrong."),console.error("Component analysis error:",g),!1}},docs:async()=>{if(L)return!1;if(t.skipDocs){let d=S("Skipping docs generation...").start();return setTimeout(()=>{d.succeed("Docs generation skipped.")},0),!0}let c=S("Refreshing docs...").start();try{return await le(t),c.succeed("Documentation refreshed!"),!0}catch(d){c.fail("Docs stumble! Couldn't refresh."),console.error("Documentation rebuild error:",d)}},scss:async()=>{if(L)return!1;try{return await I(),!0}catch(c){return console.error("Demo SCSS compilation error:",c),!1}}},m=()=>{n&&o.analyze&&o.docs&&o.scss&&typeof e=="function"&&(n=!1,e())};function u(c=1e3){s&&clearTimeout(s),s=setTimeout(async()=>{setTimeout(async()=>{o.analyze=await De("analyze",l.analyze),setTimeout(async()=>{o.docs=await De("docs",l.docs),setTimeout(async()=>{o.scss=await De("scss",l.scss),m()},500)},1e3)},1e3)},c)}r.on("event",async c=>{switch(c.code){case"START":a.succeed("Watch mode active! Eyes peeled.");break;case"BUNDLE_START":if(ue.clear(),c.input)try{let d=Array.isArray(c.input)?c.input:typeof c.input=="string"?[c.input]:typeof c.input=="object"&&c.input!==null?Object.values(c.input):[];for(let f of d)typeof f=="string"&&!Br(f)&&ue.add(ht.normalize(f))}catch(d){console.error("Error processing input paths:",d)}i=S("Weaving bundles...").start(),L=!0;break;case"BUNDLE_END":i&&i.succeed(`Bundle ${Array.isArray(c.input)?`of ${c.input.join("& ")} `:""}done in ${c.duration}ms! \u{1F680}`),L=!1,ue.size>0&&u();break;case"END":break;case"ERROR":L=!1,i?i.fail(`Oops! Bundle hit a snag: ${c.error.message}`):S().fail(`Watch mode hiccup: ${c.error.message}`),ue.clear();break}})}function wt(r,t){return _(r),t&&_(t),te(),r}async function Hr(r){let t=Ie(r),e=G(r);r.dev||t.config.plugins.push(Mr()),await le(r),await I(),await gt(t.config,e.configs)}async function Lr(r){let{dev:t}=r,e=Ie({...r,watch:!0}),n=G({...r,watch:!0}),o=Gr([e.config,...n.configs]);yt(o,r,t?async()=>ne(r):void 0);let s=await import("chokidar"),i=!1,a=!1,l=null,m=s.watch("./demo/**/*.scss",{ignoreInitial:!0,ignored:["**/demo/**/*.min.css"],awaitWriteFinish:{stabilityThreshold:500,pollInterval:100}});return m.on("all",()=>{l&&clearTimeout(l),l=setTimeout(async()=>{if(i){a=!0;return}i=!0;try{await I()}catch(u){console.error("Demo SCSS watch compilation error:",u)}finally{i=!1,a&&(a=!1,m.emit("all"))}},500)}),wt(o,m),o}async function me(r={}){try{let{watch:t}=r;return ft(),t?await Lr(r):await Hr(r)}catch(t){throw new Error(`Build failed: ${t.message}`)}}var W=Wr.command("dev").description("Runs development server for auro components");W=X(W);W=Z(W);var Os=W.action(async r=>{try{let t=bt("Initializing...");r.watch?(t.text="Waiting for changes...",t.spinner="bouncingBar",t.color="green"):t.text=r.docs===!1?"Building component (docs disabled)":"Building component",t.start(),r.watch||t.succeed("Build completed!"),await me({...r,dev:!0,watch:r.watch})}catch(t){bt().fail(`Build failed: ${t.message}`),console.error(t),process.exit(1)}});import{program as Ur}from"commander";import kt from"ora";var Pe=Ur.command("build").description("Builds auro components");Pe=X(Pe);var Ms=Pe.action(async r=>{try{let t=kt("Initializing...");r.watch?(t.text="Waiting for changes...",t.spinner="bouncingBar",t.color="green"):t.text=r.docs===!1?"Building component (docs disabled)":"Building component",t.start(),await me(r),r.watch||t.succeed("Build completed!")}catch(t){kt().fail(`Build failed: ${t.message}`),console.error(t),process.exit(1)}});import{exec as zr}from"node:child_process";import $t from"node:path";import qr from"node:process";import{fileURLToPath as Vr}from"node:url";import Jr from"node:util";import{program as Kr}from"commander";import Yr from"inquirer";var Ks=Kr.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 r=>{let t=Vr(import.meta.url),e=$t.dirname(t),n=$t.resolve(e,"migrations",r.id);if(r.multiGitter){let o=Jr.promisify(zr);try{await o("command -v multi-gitter")}catch{console.error("multi-gitter is not installed."),qr.exit(1)}(await Yr.prompt([{type:"confirm",name:"dryRun",message:"Run migration in dry-run mode? (no changes will be committed)",default:!0}])).dryRun?A(`multi-gitter run ${n}/script.sh --config "${n}/multi-gitter.yml" --dry-run`):A(`multi-gitter run ${n}/script.sh --config "${n}/multi-gitter.yml"`)}else A(`${n}/script.sh`)});import Ct from"node:process";import{program as tn}from"commander";import{readFile as rn,writeFile as nn}from"node:fs/promises";import{Logger as U}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import xe from"node:fs/promises";import Oe from"node:path";import{Octokit as Xr}from"@octokit/rest";import v from"ora";import{processContentForFile as Zr,templateFiller as Qr}from"@aurodesignsystem/auro-library/scripts/utils/sharedFileProcessorUtils.mjs";async function Et(r,t){let e=new Xr({auth:process.env.GITHUB_TOKEN||""});try{let o=(await e.request("GET /repos/{owner}/{repo}/contents/{path}",{ref:t,owner:"AlaskaAirlines",repo:"auro-templates",path:r,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 v().start().fail(s),new Error("Failed to retrieve folder items")}return o}catch(n){let o=v().start();throw n.status===404?o.fail(`Template '${r.split("/")[1]}' not found`):o.fail(`Error accessing template: ${n.message}`),n}}async function At({folderItems:r,templatePathToReplace:t,rootDir:e,ref:n}){let o=[];for(let s of r){if(s.type=="dir"){let m=v(`Processing directory: ${s.path}`).start(),u=await Et(s.path,n);m.succeed(`Found ${u.length} additional items in ${s.path}`);let c=await At({folderItems:u,templatePathToReplace:t,rootDir:e,ref:n});o.push(...c);continue}let i=s.path.replace(`${t}/`,""),a=`${e}/.github/${i}`,l={identifier:s.name,input:{remoteUrl:s.download_url||"",fileName:a,overwrite:!0},output:a};o.push(l)}return o}async function en(r){try{await xe.rm(r,{recursive:!0,force:!0}),v().start().succeed(`Successfully removed directory: ${r}`)}catch(t){throw v().start().fail(`Error removing directory ${r}: ${t.message}`),t}}async function vt(r,t="",e=!0){try{let n=await xe.stat(r),o=Oe.basename(r);if(!n.isDirectory())return`${t}${e?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 "}${o}
26
26
  `;let s=`${t}${e?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 "}${o}/
27
- `;try{let a=(await xe.readdir(r)).sort();for(let l=0;l<a.length;l++){let d=a[l],m=Oe.join(r,d),c=l===a.length-1,u=t+(e?" ":"\u2502 ");s+=await vt(m,u,c)}}catch{s+=`${t}${e?" ":"\u2502 "}\u2514\u2500\u2500 [Permission denied or error reading directory]
27
+ `;try{let a=(await xe.readdir(r)).sort();for(let l=0;l<a.length;l++){let m=a[l],u=Oe.join(r,m),c=l===a.length-1,d=t+(e?" ":"\u2502 ");s+=await vt(u,d,c)}}catch{s+=`${t}${e?" ":"\u2502 "}\u2514\u2500\u2500 [Permission denied or error reading directory]
28
28
  `}return s}catch(n){return`${t}${e?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 "}[Error: ${n}]
29
- `}}async function Tt(r,t="main",e="default"){if(!r)throw v().start().fail("Root directory must be specified"),new Error("Root directory must be specified");if(await Qr.extractNames(),!process.env.GITHUB_TOKEN)throw v().start().fail("GITHUB_TOKEN environment variable is not set."),new Error("GITHUB_TOKEN environment variable is not set");let n=`templates/${e}/.github`,o=await Et(n,t),s=".github",i=v("Removing existing .github directory...").start();try{await en(s),i.succeed(".github directory removed successfully")}catch(d){throw i.fail(`Error removing .github directory: ${d.message}`),new Error(`Failed to remove .github directory: ${d.message}`)}let a=await At({folderItems:o,templatePathToReplace:n,rootDir:r,ref:t}),l=v("Processing all files...").start();try{await Promise.all(a.map(m=>Zr(m))),l.succeed("All files processed.");let d=v("Generating directory tree...").start();try{let m=Oe.join(r,".github"),c=await vt(m);d.succeed("Synced .github directory structure:"),console.log(c)}catch(m){d.fail(`Error generating directory tree: ${m.message}`)}}catch(d){throw l.fail(`Error processing files: ${d.message}`),new Error(`Failed to process files: ${d.message}`)}}var ci=tn.command("sync").option("-r, --ref <branch/tag/commit>","Git reference (branch/tag/commit) to use","main").option("-t, --template <name>","Template based on which to sync","default").description("Script runner to synchronize local repository configuration files").action(async r=>{U.info("Synchronizing repository configuration files..."),U.warn("Note: sync does not create a new git branch. Changes are added to the current branch.");let t=Ct.cwd();try{await Tt(t,r.ref,r.template);try{let e=`${t}/.github/CODEOWNERS`,o=(await rn(e,{encoding:"utf-8"})).replace(/\r\n/gu,`
29
+ `}}async function Tt(r,t="main",e="default"){if(!r)throw v().start().fail("Root directory must be specified"),new Error("Root directory must be specified");if(await Qr.extractNames(),!process.env.GITHUB_TOKEN)throw v().start().fail("GITHUB_TOKEN environment variable is not set."),new Error("GITHUB_TOKEN environment variable is not set");let n=`templates/${e}/.github`,o=await Et(n,t),s=".github",i=v("Removing existing .github directory...").start();try{await en(s),i.succeed(".github directory removed successfully")}catch(m){throw i.fail(`Error removing .github directory: ${m.message}`),new Error(`Failed to remove .github directory: ${m.message}`)}let a=await At({folderItems:o,templatePathToReplace:n,rootDir:r,ref:t}),l=v("Processing all files...").start();try{await Promise.all(a.map(u=>Zr(u))),l.succeed("All files processed.");let m=v("Generating directory tree...").start();try{let u=Oe.join(r,".github"),c=await vt(u);m.succeed("Synced .github directory structure:"),console.log(c)}catch(u){m.fail(`Error generating directory tree: ${u.message}`)}}catch(m){throw l.fail(`Error processing files: ${m.message}`),new Error(`Failed to process files: ${m.message}`)}}var ci=tn.command("sync").option("-r, --ref <branch/tag/commit>","Git reference (branch/tag/commit) to use","main").option("-t, --template <name>","Template based on which to sync","default").description("Script runner to synchronize local repository configuration files").action(async r=>{U.info("Synchronizing repository configuration files..."),U.warn("Note: sync does not create a new git branch. Changes are added to the current branch.");let t=Ct.cwd();try{await Tt(t,r.ref,r.template);try{let e=`${t}/.github/CODEOWNERS`,o=(await rn(e,{encoding:"utf-8"})).replace(/\r\n/gu,`
30
30
  `).replace(/\n\n/gu,`
31
31
  `);await nn(e,o,{encoding:"utf-8"}),(o.includes("\r")||o.includes(`
32
32
 
33
- `))&&U.error("CODEOWNERS file still has Windows line endings.")}catch(e){throw U.error(`Error processing CODEOWNERS file: ${e.message}`),e}}catch(e){U.error(`Sync operation failed: ${e.message}`),Ct.exit(1)}});import ue from"node:fs";import z from"node:path";import{Logger as Rt}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import{program as on}from"commander";import{glob as sn}from"glob";var It=(r,t)=>{let e=(r.match(/static register\(name \= (.+)\)/)||r.match(/customElements.get\((.+?)\)/))[1],n=r.match(/export class (.+) extends/)?.[1],o=r.match(/\/\*\*((.|\n)*?)(\*\n|\*\/|[@])/)?.[1]||"";return!e||!n?r:`
33
+ `))&&U.error("CODEOWNERS file still has Windows line endings.")}catch(e){throw U.error(`Error processing CODEOWNERS file: ${e.message}`),e}}catch(e){U.error(`Sync operation failed: ${e.message}`),Ct.exit(1)}});import de from"node:fs";import z from"node:path";import{Logger as Rt}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import{program as on}from"commander";import{glob as sn}from"glob";var It=(r,t)=>{let e=(r.match(/static register\(name \= (.+)\)/)||r.match(/customElements.get\((.+?)\)/))[1],n=r.match(/export class (.+) extends/)?.[1],o=r.match(/\/\*\*((.|\n)*?)(\*\n|\*\/|[@])/)?.[1]||"";return!e||!n?r:`
34
34
  import { ${n} } from '${t}';
35
35
 
36
36
  /**${o}*/
@@ -39,30 +39,30 @@ class ${n}WCA extends ${n} {}
39
39
  if (!customElements.get(${e})) {
40
40
  customElements.define(${e}, ${n}WCA);
41
41
  }
42
- `};var de=z.resolve(process.cwd(),"./scripts/wca");async function an(r){try{return(await Promise.all(r.map(e=>sn(e)))).flat()}catch(t){throw console.error("Error processing glob patterns:",t),t}}async function cn(r){ue.existsSync(de)||await ue.promises.mkdir(de,{recursive:!0});for(let t of r){let e=z.resolve(process.cwd(),t),n=await ue.promises.readFile(e,"utf-8"),o=z.resolve(de,`${z.basename(t)}`),s=It(n,z.relative(de,t));await ue.promises.writeFile(o,s)}}async function ln(){let r=await an(["./src/auro-*.js"]);await cn(r)}var yi=on.command("wca-setup").description("Set up WCA (Web Component Analyzer) for the project").action(()=>{ln().then(()=>{Rt.success("WCA setup completed successfully.")}).catch(r=>{Rt.error(`WCA setup failed: ${r.message}`)})});import{program as yn}from"commander";import xt from"chalk";import Ot from"ora";import{appendFile as mn,readFile as un}from"node:fs/promises";import{Logger as h}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import{simpleGit as dn}from"simple-git";var y;try{y=dn({baseDir:process.cwd(),binary:"git",maxConcurrentProcesses:1})}catch(r){h.error(`Failed to initialize git: ${r}`),y={}}var R=class r{static async checkGitignore(t){if(t==="")return!1;try{return(await un(".gitignore","utf-8")).includes(t)}catch(e){return h.error(`Error reading file: ${e}`),!1}}static async getCommitMessages(t=""){try{let e=t;e||(e=(await y.branchLocal()).current);let n="main",o="";if(!!process.env.GITHUB_ACTIONS){n=process.env.GITHUB_BASE_REF||"main";try{if(await y.fetch("origin",n),e!=="HEAD")try{await y.raw(["rev-parse","--verify",`origin/${e}`])}catch{await y.fetch("origin",e)}let i=e==="HEAD"?"HEAD":`origin/${e}`;o=`${(await y.raw(["merge-base",`origin/${n}`,i])).trim()}..${i}`}catch(i){h.warn(`Error setting up commit range in CI: ${i}`);let a=e==="HEAD"?"HEAD":`origin/${e}`;o=`origin/${n}..${a}`}}else try{try{await y.raw(["rev-parse","--verify",`origin/${n}`])}catch{h.info(`Fetching ${n} from origin`),await y.fetch("origin",n)}if(e!=="HEAD")try{await y.raw(["rev-parse","--verify",e])}catch{await y.fetch("origin",e)}o=`${(await y.raw(["merge-base",`origin/${n}`,e])).trim()}..${e}`}catch(i){h.warn(`Error determining commits locally: ${i}`),o=`${e}~10..${e}`}return await r.getFormattedCommits(o)}catch(e){return h.error(`Error getting commit messages: ${e}`),[]}}static async getRepoOwnerAndName(){try{let t=await y.getRemotes(!0);if(t.length===0)return h.warn("No remotes found"),null;let e=t.find(o=>o.name==="origin")||t[0],n=e.refs.fetch||e.refs.push;return r.parseGitUrl(n)}catch(t){return h.error(`Error getting repo owner and name: ${t}`),null}}static async getCurrentBranchName(){try{return(await y.branchLocal()).current||null}catch(t){return h.error(`Error getting current branch name: ${t}`),null}}static parseGitUrl(t){let e;return t.includes("@")&&t.includes(":")&&(e=t.match(/@([^:]+):([^/]+)\/(.+?)(?:\.git)?$/),e)?{owner:e[2],repo:e[3]}:(e=t.match(/https?:\/\/(?:[^@]+@)?[^/]+\/([^/]+)\/(.+?)(?:\.git)?$/),e?{owner:e[1],repo:e[2]}:(h.warn(`Could not parse git URL: ${t}`),null))}static async getFormattedCommits(t){let n=(await y.raw(["log","--pretty=format:COMMIT_START%n%H%n%ad%n%an%n%s%n%b%nCOMMIT_END","--date=short",t])).split(`COMMIT_START
42
+ `};var pe=z.resolve(process.cwd(),"./scripts/wca");async function an(r){try{return(await Promise.all(r.map(e=>sn(e)))).flat()}catch(t){throw console.error("Error processing glob patterns:",t),t}}async function cn(r){de.existsSync(pe)||await de.promises.mkdir(pe,{recursive:!0});for(let t of r){let e=z.resolve(process.cwd(),t),n=await de.promises.readFile(e,"utf-8"),o=z.resolve(pe,`${z.basename(t)}`),s=It(n,z.relative(pe,t));await de.promises.writeFile(o,s)}}async function ln(){let r=await an(["./src/auro-*.js"]);await cn(r)}var yi=on.command("wca-setup").description("Set up WCA (Web Component Analyzer) for the project").action(()=>{ln().then(()=>{Rt.success("WCA setup completed successfully.")}).catch(r=>{Rt.error(`WCA setup failed: ${r.message}`)})});import{program as yn}from"commander";import xt from"chalk";import Ot from"ora";import{appendFile as un,readFile as mn}from"node:fs/promises";import{Logger as h}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import{simpleGit as dn}from"simple-git";var y;try{y=dn({baseDir:process.cwd(),binary:"git",maxConcurrentProcesses:1})}catch(r){h.error(`Failed to initialize git: ${r}`),y={}}var R=class r{static async checkGitignore(t){if(t==="")return!1;try{return(await mn(".gitignore","utf-8")).includes(t)}catch(e){return h.error(`Error reading file: ${e}`),!1}}static async getCommitMessages(t=""){try{let e=t;e||(e=(await y.branchLocal()).current);let n="main",o="";if(!!process.env.GITHUB_ACTIONS){n=process.env.GITHUB_BASE_REF||"main";try{if(await y.fetch("origin",n),e!=="HEAD")try{await y.raw(["rev-parse","--verify",`origin/${e}`])}catch{await y.fetch("origin",e)}let i=e==="HEAD"?"HEAD":`origin/${e}`;o=`${(await y.raw(["merge-base",`origin/${n}`,i])).trim()}..${i}`}catch(i){h.warn(`Error setting up commit range in CI: ${i}`);let a=e==="HEAD"?"HEAD":`origin/${e}`;o=`origin/${n}..${a}`}}else try{try{await y.raw(["rev-parse","--verify",`origin/${n}`])}catch{h.info(`Fetching ${n} from origin`),await y.fetch("origin",n)}if(e!=="HEAD")try{await y.raw(["rev-parse","--verify",e])}catch{await y.fetch("origin",e)}o=`${(await y.raw(["merge-base",`origin/${n}`,e])).trim()}..${e}`}catch(i){h.warn(`Error determining commits locally: ${i}`),o=`${e}~10..${e}`}return await r.getFormattedCommits(o)}catch(e){return h.error(`Error getting commit messages: ${e}`),[]}}static async getRepoOwnerAndName(){try{let t=await y.getRemotes(!0);if(t.length===0)return h.warn("No remotes found"),null;let e=t.find(o=>o.name==="origin")||t[0],n=e.refs.fetch||e.refs.push;return r.parseGitUrl(n)}catch(t){return h.error(`Error getting repo owner and name: ${t}`),null}}static async getCurrentBranchName(){try{return(await y.branchLocal()).current||null}catch(t){return h.error(`Error getting current branch name: ${t}`),null}}static parseGitUrl(t){let e;return t.includes("@")&&t.includes(":")&&(e=t.match(/@([^:]+):([^/]+)\/(.+?)(?:\.git)?$/),e)?{owner:e[2],repo:e[3]}:(e=t.match(/https?:\/\/(?:[^@]+@)?[^/]+\/([^/]+)\/(.+?)(?:\.git)?$/),e?{owner:e[1],repo:e[2]}:(h.warn(`Could not parse git URL: ${t}`),null))}static async getFormattedCommits(t){let n=(await y.raw(["log","--pretty=format:COMMIT_START%n%H%n%ad%n%an%n%s%n%b%nCOMMIT_END","--date=short",t])).split(`COMMIT_START
43
43
  `).filter(s=>s.trim()!==""),o=[];for(let s of n){let i=s.split(`
44
- `);if(i.length>=4){let a=i[0],l=i[1],d=i[2],m=i[3],c=i.slice(4).filter(b=>b!=="COMMIT_END"),u=c.length>0?c.join(""):"",f=a.substring(0,7),p=m.match(/^(feat|fix|docs|style|refactor|perf|test|build|ci|chore)(\(.+\))?:/),g=p?p[1]:"unknown";u.includes("BREAKING CHANGE")&&(g="breaking"),o.push({type:g,hash:f,date:l,subject:m,body:u,message:`${m}${u?`
44
+ `);if(i.length>=4){let a=i[0],l=i[1],m=i[2],u=i[3],c=i.slice(4).filter(b=>b!=="COMMIT_END"),d=c.length>0?c.join(""):"",f=a.substring(0,7),p=u.match(/^(feat|fix|docs|style|refactor|perf|test|build|ci|chore)(\(.+\))?:/),g=p?p[1]:"unknown";d.includes("BREAKING CHANGE")&&(g="breaking"),o.push({type:g,hash:f,date:l,subject:u,body:d,message:`${u}${d?`
45
45
 
46
- ${u}`:""}`,author_name:d})}}return o}static async addToGitignore(t,e=!0){await r.checkGitignore(t).then(async n=>{if(n)h.warn(`${t} already exists`);else try{await mn(".gitignore",`
46
+ ${d}`:""}`,author_name:m})}}return o}static async addToGitignore(t,e=!0){await r.checkGitignore(t).then(async n=>{if(n)h.warn(`${t} already exists`);else try{await un(".gitignore",`
47
47
  ${t}`),e&&h.success(`${t} added to .gitignore`)}catch(o){h.error(o)}})}static async removeFromGitCache(t){try{await y.rmKeepLocal(t),h.success(`${t.join(", ")} are removed from git cache`)}catch(e){h.error(e)}}static async createBranch(t){try{await y.checkoutLocalBranch(t),h.success(`Created and switched to ${t} branch`)}catch(e){h.error(e)}}static async commitStagedFiles(t){try{await y.add("."),await y.commit(t),h.success(`Committed with message: ${t}`)}catch(e){h.error(e)}}};import w from"chalk";var pn=60,fn=100;function q(r){switch(r){case"breaking":return w.bold.red(r);case"feat":return w.bold.green(r);case"fix":return w.bold.green(r);case"perf":return w.bold.green(r);case"docs":return w.bold.cyan(r);case"style":return w.bold.cyan(r);case"refactor":return w.bold.cyan(r);case"test":return w.bold.cyan(r);case"build":return w.bold.cyan(r);case"ci":return w.bold.cyan(r);case"chore":return w.bold.cyan(r);default:return w.bold.white(r)}}function St(r,t){if(!r)return"";if(r.length<=t)return r;let e=r.split(" "),n="",o="";for(let s of e)(o+s).length>t&&o.length>0&&(n+=`${o.trim()}
48
48
  `,o=""),o=`${o}${s} `;return o.length>0&&(n+=o.trim()),n}function Dt(r){for(let t of r){console.log("\u2500".repeat(60));let e=St(t.subject,pn),n=St(t.body,fn);console.log(w.bold(`${q(t.type)}`)),console.log(w.dim(`${t.hash} | ${t.date} | ${t.author_name}`)),console.log(w.bold(`${w.white(e)}`)),t.body&&console.log(w.dim(n))}console.log("\u2500".repeat(60)),console.log(`
49
- `)}import pe from"@actions/github";async function Ne(){try{let r=process.env.GITHUB_TOKEN;if(!r)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=pe.getOctokit(r),{context:e}=pe;if(!e.payload.pull_request)throw new Error("No pull request found in the GitHub context");let[n,o]=process.env.GITHUB_REPOSITORY.split("/"),s=e.payload.pull_request.number,{data:i}=await t.rest.issues.listLabelsOnIssue({owner:n,repo:o,issue_number:s});return i.map(a=>a.name)}catch(r){throw r instanceof Error?new Error(`Failed to get existing labels: ${r.message}`):r}}async function Pt(r){try{let t=process.env.GITHUB_TOKEN;if(!t)throw new Error("GITHUB_TOKEN environment variable is not set");if(!process.env.GITHUB_REPOSITORY||!process.env.GITHUB_EVENT_PATH)throw new Error("This function can only be used in a GitHub Actions environment");let e=pe.getOctokit(t),{context:n}=pe;if(!n.payload.pull_request)throw new Error("No pull request found in the GitHub context");let[o,s]=process.env.GITHUB_REPOSITORY.split("/"),i=n.payload.pull_request.number,a=`semantic-status: ${r}`,l=await Ne();if(l.includes(a))return;let d=l.filter(m=>m.startsWith("semantic-status:")&&m!==a);for(let m of d)await e.rest.issues.removeLabel({owner:o,repo:s,issue_number:i,name:m});await e.rest.issues.addLabels({owner:o,repo:s,issue_number:i,labels:[a]});return}catch(t){throw t instanceof Error?new Error(`Failed to apply label: ${t.message}`):t}}var gn=["feat","fix","breaking","perf"];function je(r,t=!0){let e=`### In this release
49
+ `)}import*as V from"@actions/github";async function Ne(){try{let r=process.env.GITHUB_TOKEN;if(!r)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(r),{context:e}=V;if(!e.payload.pull_request)throw new Error("No pull request found in the GitHub context");let[n,o]=process.env.GITHUB_REPOSITORY.split("/"),s=e.payload.pull_request.number,{data:i}=await t.rest.issues.listLabelsOnIssue({owner:n,repo:o,issue_number:s});return i.map(a=>a.name)}catch(r){throw r instanceof Error?new Error(`Failed to get existing labels: ${r.message}`):r}}async function Pt(r){try{let t=process.env.GITHUB_TOKEN;if(!t)throw new Error("GITHUB_TOKEN environment variable is not set");if(!process.env.GITHUB_REPOSITORY||!process.env.GITHUB_EVENT_PATH)throw new Error("This function can only be used in a GitHub Actions environment");let e=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,a=`semantic-status: ${r}`,l=await Ne();if(l.includes(a))return;let m=l.filter(u=>u.startsWith("semantic-status:")&&u!==a);for(let u of m)await e.rest.issues.removeLabel({owner:o,repo:s,issue_number:i,name:u});await e.rest.issues.addLabels({owner:o,repo:s,issue_number:i,labels:[a]});return}catch(t){throw t instanceof Error?new Error(`Failed to apply label: ${t.message}`):t}}var gn=["feat","fix","breaking","perf"];function je(r,t=!0){let e=`### In this release
50
50
  `;for(let n of r)if(e+=`- ${n.hash} ${n.subject}
51
51
  `,n.body?.trim()){let s=n.body.trim().split(/\n+/).map(i=>i.trim()).filter(i=>i.length>0);for(let i of s){let a=i;a=a.replace(/([^\s])(AlaskaAirlines\/[a-zA-Z0-9-]+#\d+)/g,"$1 $2"),a=a.replace(/(AlaskaAirlines\/[a-zA-Z0-9-]+#\d+)([^\s])/g,"$1 $2"),e+=` - ${a}`}}return r.length===0?"":(t&&console.log(xt.green(`\u2713 Generating release notes for ${r.length} commits`)),e)}function _e(r,t=!0){let e=r.filter(o=>gn.includes(o.type)),n;return t?n=e.length>0?e:r:n=e,n.length===0&&console.log(`No commits found to include in release notes.
52
52
  `),n}async function Nt(r=!1,t=!1,e=!1){let n=Ot(`Checking commits...
53
53
  `).start();try{let o=await R.getCommitMessages();if(e){n.succeed(`Total commits analyzed: ${o.length}`);let s=_e(o);console.log(je(s));return}if(r&&Dt(o),n.succeed(`Total commits analyzed: ${o.length}`),o.length!==0){let s=o.map(l=>l.type),a=Array.from(new Set(s)).map(l=>q(l)).join(", ");n.succeed(`Found commit types: ${a}`)}else n.info(`The list of commits is created by comparing the current branch
54
54
  with the main branch. If you are on a new branch, please
55
- make sure to commit some changes before running this command.`);t&&await hn(o,n)}catch(o){n.fail("Error getting commit messages"),console.error(o)}}async function hn(r,t){let e=["breaking","feat","fix","perf","docs","style","refactor","test","build","ci","chore"],n=r.map(i=>i.type).filter(i=>e.includes(i)),o=null,s=Number.POSITIVE_INFINITY;for(let i of n){let a=e.indexOf(i);a<s&&(s=a,o=i)}if(o){let i=Ot("Checking existing labels on pull request...").start();try{if((await Ne()).includes(`semantic-status: ${o}`)){i.info(`Label "semantic-status: ${q(o)}" already exists on the pull request.`);return}i.text="Applying label to pull request...",await Pt(o),i.succeed(`Label "semantic-status: ${q(o)}" applied to the pull request.`)}catch(a){let l=a instanceof Error?a.message:String(a);i.fail(l)}}else t.warn(xt.yellow("No semantic commit type found to apply as label."))}var ji=yn.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 r=>{await Nt(r.debug,r.setLabel,r.releaseNotes)});import jt from"node:fs";import{get as _t}from"node:https";import D from"chalk";import{program as wn}from"commander";import bn from"ora";var Li=wn.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 r=>{await kn(r)}),kn=async r=>{let{namespace:t,prNumber:e}=r,n=bn("Updating package.json").start();try{let o="package.json",s=JSON.parse(jt.readFileSync(o,"utf8"));n.text="Checking npm registry for version information...";let i=`0.0.0-pr${e}`,a=s.name.split("/")[1],l=`${t}/${a}`,d=await $n(i,l,n),m=`${i}.${d}`;s.name=l,s.version=m,n.text="Writing updated package.json...",jt.writeFileSync(o,`${JSON.stringify(s,null,2)}
56
- `,"utf8"),n.succeed(`Package.json updated to use ${D.green(m)} and ${D.green(l)}`),process.exit(0)}catch(o){n.fail(`Failed to update package.json: ${o}`),process.exit(1)}},$n=(r,t,e)=>new Promise(n=>{try{let a=function(l){if(l.statusCode!==200){e.info(`Package not found. Status code: ${D.red(l.statusCode)}, defaulting to version 0`),n(0);return}e.text="Processing version information...";let d="";l.on("data",m=>{d+=m}),l.on("end",()=>{try{let m=JSON.parse(d),c=m.versions?Object.keys(m.versions):[];e.text="Calculating next version number...";let u=-1,f=new RegExp(`^${r}\\.(\\d+)$`);for(let p of c){let g=p.match(f);if(g){let b=Number.parseInt(g[1],10);u=Math.max(u,b)}}u>=0?e.info(`Found existing version ${D.green(`${r}.${u}`)}. Incrementing to ${D.green(`${r}.${u+1}`)}`):e.info(`No existing version found for ${D.green(r)}. Starting with ${D.green(`${r}.0`)}`),n(u+1)}catch(m){e.warn(`Failed to parse NPM registry response: ${m instanceof Error?m.message:"Unknown error"}, defaulting to version 0`),n(0)}})};var o=a;let s=`https://registry.npmjs.org/${t}`,i=_t(s,{headers:{Accept:"application/json"}},l=>{if((l.statusCode===301||l.statusCode===302)&&l.headers.location){e.info(`Following redirect to ${l.headers.location}...`);try{_t(l.headers.location,{headers:{Accept:"application/json"}},a).on("error",d=>{e.warn(`Error following redirect: ${d.message}, defaulting to version 0`),n(0)}).end()}catch(d){e.warn(`Redirect request failed: ${d instanceof Error?d.message:"Unknown error"}, defaulting to version 0`),n(0)}return}a(l)});i.on("error",l=>{e.warn(`Request error: ${l.message}, defaulting to version 0`),n(0)}),i.end()}catch{e.warn("Error checking version in npm registry, defaulting to version 0"),n(0)}});import Fe from"node:path";import{fileURLToPath as En}from"node:url";import{program as An}from"commander";import vn from"open";var Tn=En(import.meta.url),Cn=Fe.resolve(Fe.dirname(Tn),".."),Ki=An.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 r=>{let e=`npx wtr --config "${Fe.join(Cn,"dist","configs","web-test-runner.config.mjs")}"`,n=`${process.cwd()}/coverage/index.html`;if(r.coverageReport&&(e+=" --coverage"),r.watch&&(e+=" --watch"),r.files){let o=Array.isArray(r.files)?r.files.join(" "):r.files;e+=` --files "${o}"`}A(e),r.open&&await vn(n)});import He from"node:fs/promises";import Gt from"node:path";import{program as On}from"commander";import Nn from"inquirer";import Le from"ora";import In from"node:fs/promises";import Rn from"node:path";import Sn from"ora";var Dn={"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 Pn(r){return Object.entries(r).map(([t,e])=>Array.isArray(e)?`${t}:
55
+ make sure to commit some changes before running this command.`);t&&await hn(o,n)}catch(o){n.fail("Error getting commit messages"),console.error(o)}}async function hn(r,t){let e=["breaking","feat","fix","perf","docs","style","refactor","test","build","ci","chore"],n=r.map(i=>i.type).filter(i=>e.includes(i)),o=null,s=Number.POSITIVE_INFINITY;for(let i of n){let a=e.indexOf(i);a<s&&(s=a,o=i)}if(o){let i=Ot("Checking existing labels on pull request...").start();try{if((await Ne()).includes(`semantic-status: ${o}`)){i.info(`Label "semantic-status: ${q(o)}" already exists on the pull request.`);return}i.text="Applying label to pull request...",await Pt(o),i.succeed(`Label "semantic-status: ${q(o)}" applied to the pull request.`)}catch(a){let l=a instanceof Error?a.message:String(a);i.fail(l)}}else t.warn(xt.yellow("No semantic commit type found to apply as label."))}var Ni=yn.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 r=>{await Nt(r.debug,r.setLabel,r.releaseNotes)});import jt from"node:fs";import{get as _t}from"node:https";import D from"chalk";import{program as wn}from"commander";import bn from"ora";var Hi=wn.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 r=>{await kn(r)}),kn=async r=>{let{namespace:t,prNumber:e}=r,n=bn("Updating package.json").start();try{let o="package.json",s=JSON.parse(jt.readFileSync(o,"utf8"));n.text="Checking npm registry for version information...";let i=`0.0.0-pr${e}`,a=s.name.split("/")[1],l=`${t}/${a}`,m=await $n(i,l,n),u=`${i}.${m}`;s.name=l,s.version=u,n.text="Writing updated package.json...",jt.writeFileSync(o,`${JSON.stringify(s,null,2)}
56
+ `,"utf8"),n.succeed(`Package.json updated to use ${D.green(u)} and ${D.green(l)}`),process.exit(0)}catch(o){n.fail(`Failed to update package.json: ${o}`),process.exit(1)}},$n=(r,t,e)=>new Promise(n=>{try{let a=function(l){if(l.statusCode!==200){e.info(`Package not found. Status code: ${D.red(l.statusCode)}, defaulting to version 0`),n(0);return}e.text="Processing version information...";let m="";l.on("data",u=>{m+=u}),l.on("end",()=>{try{let u=JSON.parse(m),c=u.versions?Object.keys(u.versions):[];e.text="Calculating next version number...";let d=-1,f=new RegExp(`^${r}\\.(\\d+)$`);for(let p of c){let g=p.match(f);if(g){let b=Number.parseInt(g[1],10);d=Math.max(d,b)}}d>=0?e.info(`Found existing version ${D.green(`${r}.${d}`)}. Incrementing to ${D.green(`${r}.${d+1}`)}`):e.info(`No existing version found for ${D.green(r)}. Starting with ${D.green(`${r}.0`)}`),n(d+1)}catch(u){e.warn(`Failed to parse NPM registry response: ${u instanceof Error?u.message:"Unknown error"}, defaulting to version 0`),n(0)}})};var o=a;let s=`https://registry.npmjs.org/${t}`,i=_t(s,{headers:{Accept:"application/json"}},l=>{if((l.statusCode===301||l.statusCode===302)&&l.headers.location){e.info(`Following redirect to ${l.headers.location}...`);try{_t(l.headers.location,{headers:{Accept:"application/json"}},a).on("error",m=>{e.warn(`Error following redirect: ${m.message}, defaulting to version 0`),n(0)}).end()}catch(m){e.warn(`Redirect request failed: ${m instanceof Error?m.message:"Unknown error"}, defaulting to version 0`),n(0)}return}a(l)});i.on("error",l=>{e.warn(`Request error: ${l.message}, defaulting to version 0`),n(0)}),i.end()}catch{e.warn("Error checking version in npm registry, defaulting to version 0"),n(0)}});import Fe from"node:path";import{fileURLToPath as En}from"node:url";import{program as An}from"commander";import vn from"open";var Tn=En(import.meta.url),Cn=Fe.resolve(Fe.dirname(Tn),".."),Ji=An.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 r=>{let e=`npx wtr --config "${Fe.join(Cn,"dist","configs","web-test-runner.config.mjs")}"`,n=`${process.cwd()}/coverage/index.html`;if(r.coverageReport&&(e+=" --coverage"),r.watch&&(e+=" --watch"),r.files){let o=Array.isArray(r.files)?r.files.join(" "):r.files;e+=` --files "${o}"`}A(e),r.open&&await vn(n)});import He from"node:fs/promises";import Gt from"node:path";import{program as On}from"commander";import Nn from"inquirer";import Le from"ora";import In from"node:fs/promises";import Rn from"node:path";import Sn from"ora";var Dn={"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 Pn(r){return Object.entries(r).map(([t,e])=>Array.isArray(e)?`${t}:
57
57
  - ${e.join(`
58
58
  - `)}`:typeof e=="object"&&e!==null?`${t}:
59
59
  ${Object.entries(e).map(([n,o])=>` ${n}: ${o}`).join(`
60
60
  `)}`:`${t}: ${e}`).join(`
61
- `)}async function Ft(r){let t=Sn("Writing multi-gitter configuration...").start(),e=Pn(Dn),n=Rn.join(r,"multi-gitter_DEPENDENCY_TREE.yml");try{await In.writeFile(n,e,"utf8"),t.succeed(`Multi-gitter configuration written to ${n}`)}catch(o){t.fail("Error writing multi-gitter configuration:"),console.error(o)}}import Be from"node:fs";function Bt(r){let t={},e=[],n=[],o=[];for(let s in r)t[s]=r[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 a=o.shift();n.push(a);for(let l of r[a].dependentPackages)t[l]--,t[l]===0&&o.push(l)}e.push(n)}if(e.flat().length!==Object.keys(r).length)throw new Error("Circular dependency detected!");return e}function xn(r){return Be.readdirSync(r).filter(t=>t.endsWith(".json"))}async function Mt(r,t=[]){console.log(t);let e={},n=xn(r);for(let o of n){if(o==="dependencyTree.json")continue;let s=Be.readFileSync(`${r}/${o}`,"utf-8"),i=JSON.parse(s),a=i.name,l=Object.keys(i.peerDependencies),d=Object.keys(i.devDependencies),m=Object.keys(i.dependencies);e[a]||(e[a]={dependsOn:[],dependentPackages:[]});let c=[...l,...d,...m];e[a].dependsOn=[...new Set(c)];for(let u of c)e[u]||(e[u]={dependsOn:[],dependentPackages:[]}),e[u].dependentPackages.includes(a)||e[u].dependentPackages.push(a)}if(t.length){let o=new Set;for(let[i,a]of Object.entries(e))a.dependsOn.some(l=>t.includes(l))&&o.add(i);for(let i of t)e[i]&&o.add(i);let s={};for(let i of o)s[i]={dependsOn:e[i].dependsOn.filter(a=>o.has(a)),dependentPackages:e[i].dependentPackages.filter(a=>o.has(a))};e=s}else console.log("No target dependencies provided - using all packages.");return Be.writeFileSync(`${r}/dependencyTree.json`,JSON.stringify(e,null,2)),e}var Me=be("run-migrations","config"),Ge=be("run-migrations","outputs");var Ht=["@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"],da=[...Ht,"@aurodesignsystem/auro-library","@aurodesignsystem/WebCoreStyleSheets","@aurodesignsystem/AuroDesignTokens","@aurodesignsystem/auro-cli","@alaskaairux/icons"];async function jn(r){try{await He.mkdir(Ge,{recursive:!0}),await He.mkdir(Me,{recursive:!0})}catch(o){console.error("Failed to create output or config directories:",o),process.exit(1)}let t=Le("Creating dependency tree...").start();t.text="Creating multi-gitter dependency tree configuration...",await Ft(Me),t.text="Scraping dependencies from Auro packages...";let n=`multi-gitter run "node ${ke("static","getAuroDeps.js")}" --config ${Gt.join(Me,"multi-gitter_DEPENDENCY_TREE.yml")}`;try{await A(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 Mt(Ge,r),t.succeed("Dependency tree generated successfully."),Gt.join(Ge,"dependencyTree.json")}var _n=async r=>{let t=Le("Loading dependency tree...").start(),e=JSON.parse(await He.readFile(r,"utf-8"));t.text="Processing dependency tree...";let n=Bt(e);return t.succeed("Dependency batches created successfully."),n},pa=On.command("agent").action(async r=>{let t=await Nn.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:e=>e.agentAction==="run-migration",validate:e=>e.trim()!==""||"Migration id cannot be empty."},{type:"confirm",name:"useExisting",message:"Would you like to specify starting packages?",default:!0,transformer:e=>e?"Yes = Packages related to selections":"No = All packages",when:e=>e.agentAction==="run-migration"},{type:"checkbox",name:"startWithComponents",message:"Enter the components to start with (comma-separated, blank for all):",choices:Ht.map(e=>({name:e.replace("@aurodesignsystem/",""),value:e})),when:e=>e.agentAction==="run-migration"&&e.useExisting}]);switch(t.agentAction){case"run-migration":{let e=Le("Running migration...").start(),n=await jn(t.startWithComponents);e.text="Getting dependency batches from tree...";let s=(await _n(n)).map((i,a)=>`Batch ${a+1}
61
+ `)}async function Ft(r){let t=Sn("Writing multi-gitter configuration...").start(),e=Pn(Dn),n=Rn.join(r,"multi-gitter_DEPENDENCY_TREE.yml");try{await In.writeFile(n,e,"utf8"),t.succeed(`Multi-gitter configuration written to ${n}`)}catch(o){t.fail("Error writing multi-gitter configuration:"),console.error(o)}}import Be from"node:fs";function Bt(r){let t={},e=[],n=[],o=[];for(let s in r)t[s]=r[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 a=o.shift();n.push(a);for(let l of r[a].dependentPackages)t[l]--,t[l]===0&&o.push(l)}e.push(n)}if(e.flat().length!==Object.keys(r).length)throw new Error("Circular dependency detected!");return e}function xn(r){return Be.readdirSync(r).filter(t=>t.endsWith(".json"))}async function Mt(r,t=[]){console.log(t);let e={},n=xn(r);for(let o of n){if(o==="dependencyTree.json")continue;let s=Be.readFileSync(`${r}/${o}`,"utf-8"),i=JSON.parse(s),a=i.name,l=Object.keys(i.peerDependencies),m=Object.keys(i.devDependencies),u=Object.keys(i.dependencies);e[a]||(e[a]={dependsOn:[],dependentPackages:[]});let c=[...l,...m,...u];e[a].dependsOn=[...new Set(c)];for(let d of c)e[d]||(e[d]={dependsOn:[],dependentPackages:[]}),e[d].dependentPackages.includes(a)||e[d].dependentPackages.push(a)}if(t.length){let o=new Set;for(let[i,a]of Object.entries(e))a.dependsOn.some(l=>t.includes(l))&&o.add(i);for(let i of t)e[i]&&o.add(i);let s={};for(let i of o)s[i]={dependsOn:e[i].dependsOn.filter(a=>o.has(a)),dependentPackages:e[i].dependentPackages.filter(a=>o.has(a))};e=s}else console.log("No target dependencies provided - using all packages.");return Be.writeFileSync(`${r}/dependencyTree.json`,JSON.stringify(e,null,2)),e}var Me=be("run-migrations","config"),Ge=be("run-migrations","outputs");var Ht=["@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"],ma=[...Ht,"@aurodesignsystem/auro-library","@aurodesignsystem/WebCoreStyleSheets","@aurodesignsystem/AuroDesignTokens","@aurodesignsystem/auro-cli","@alaskaairux/icons"];async function jn(r){try{await He.mkdir(Ge,{recursive:!0}),await He.mkdir(Me,{recursive:!0})}catch(o){console.error("Failed to create output or config directories:",o),process.exit(1)}let t=Le("Creating dependency tree...").start();t.text="Creating multi-gitter dependency tree configuration...",await Ft(Me),t.text="Scraping dependencies from Auro packages...";let n=`multi-gitter run "node ${ke("static","getAuroDeps.js")}" --config ${Gt.join(Me,"multi-gitter_DEPENDENCY_TREE.yml")}`;try{await A(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 Mt(Ge,r),t.succeed("Dependency tree generated successfully."),Gt.join(Ge,"dependencyTree.json")}var _n=async r=>{let t=Le("Loading dependency tree...").start(),e=JSON.parse(await He.readFile(r,"utf-8"));t.text="Processing dependency tree...";let n=Bt(e);return t.succeed("Dependency batches created successfully."),n},da=On.command("agent").action(async r=>{let t=await Nn.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:e=>e.agentAction==="run-migration",validate:e=>e.trim()!==""||"Migration id cannot be empty."},{type:"confirm",name:"useExisting",message:"Would you like to specify starting packages?",default:!0,transformer:e=>e?"Yes = Packages related to selections":"No = All packages",when:e=>e.agentAction==="run-migration"},{type:"checkbox",name:"startWithComponents",message:"Enter the components to start with (comma-separated, blank for all):",choices:Ht.map(e=>({name:e.replace("@aurodesignsystem/",""),value:e})),when:e=>e.agentAction==="run-migration"&&e.useExisting}]);switch(t.agentAction){case"run-migration":{let e=Le("Running migration...").start(),n=await jn(t.startWithComponents);e.text="Getting dependency batches from tree...";let s=(await _n(n)).map((i,a)=>`Batch ${a+1}
62
62
  ${i.map(l=>` - ${l.replace("@aurodesignsystem","AlaskaAirlines").replace("@alaskaairux/icons","AlaskaAirlines/Icons")}`).join(`
63
63
  `)}`).join(`
64
64
 
65
- `);console.log(s),e.text="Running migrations on dependency batches...",new Promise(i=>setTimeout(i,2e3)),e.succeed("Migration process completed successfully.");break}default:console.error("Unknown action selected.")}});import{program as Fn}from"commander";var We=Fn.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).option("-w, --watch","Watch for changes and rebuild docs",!1).option("-r, --readme-template <url>","URL to the README template file").option("--skip-readme","Skip README.md processing",!1);We=X(We);var wa=We.action(async r=>{r.cem&&await ne(),r.api&&await oe(),await ot(r),r.serve&&await st(r),r.watch&&await it(r)});import{program as Ln}from"commander";import{Octokit as Ue}from"@octokit/rest";import*as ge from"azure-devops-node-api";import fe from"ora";var Bn=async r=>{let t=process.env.GH_TOKEN;if(!t)throw new Error("GH_TOKEN environment variable is required");let e=new Ue({auth:t}),n,o,s;if(r.includes("github.com")){let a=r.match(/github\.com\/([^\/]+)\/([^\/]+)\/issues\/(\d+)/);if(!a)throw new Error("Invalid GitHub issue URL format");[,n,o,s]=a}else if(r.includes("#")){let a=r.match(/([^\/]+)\/([^#]+)#(\d+)/);if(!a)throw new Error("Invalid GitHub issue reference format");[,n,o,s]=a}else throw new Error("Issue must be provided as full URL or in format 'owner/repo#number'");let i=Number.parseInt(s,10);try{let{data:a}=await e.rest.issues.get({owner:n,repo:o,issue_number:i});return{title:a.title,body:a.body??null,html_url:a.html_url,number:a.number,repository:{owner:{login:n},name:o}}}catch(a){throw new Error(`Failed to fetch GitHub issue: ${a}`)}},Mn=async r=>{let t=process.env.GH_TOKEN;if(!t)return null;let e=new Ue({auth:t});try{let n=`
65
+ `);console.log(s),e.text="Running migrations on dependency batches...",new Promise(i=>setTimeout(i,2e3)),e.succeed("Migration process completed successfully.");break}default:console.error("Unknown action selected.")}});import{program as Fn}from"commander";var We=Fn.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).option("-w, --watch","Watch for changes and rebuild docs",!1).option("-r, --readme-template <url>","URL to the README template file").option("--skip-readme","Skip README.md processing",!1);We=Z(We);var ya=We.action(async r=>{r.cem&&await oe(),r.api&&await se(),await ot(r),r.serve&&await st(r),r.watch&&await it(r)});import{program as Ln}from"commander";import{Octokit as Ue}from"@octokit/rest";import*as ge from"azure-devops-node-api";import fe from"ora";var Bn=async r=>{let t=process.env.GH_TOKEN;if(!t)throw new Error("GH_TOKEN environment variable is required");let e=new Ue({auth:t}),n,o,s;if(r.includes("github.com")){let a=r.match(/github\.com\/([^\/]+)\/([^\/]+)\/issues\/(\d+)/);if(!a)throw new Error("Invalid GitHub issue URL format");[,n,o,s]=a}else if(r.includes("#")){let a=r.match(/([^\/]+)\/([^#]+)#(\d+)/);if(!a)throw new Error("Invalid GitHub issue reference format");[,n,o,s]=a}else throw new Error("Issue must be provided as full URL or in format 'owner/repo#number'");let i=Number.parseInt(s,10);try{let{data:a}=await e.rest.issues.get({owner:n,repo:o,issue_number:i});return{title:a.title,body:a.body??null,html_url:a.html_url,number:a.number,repository:{owner:{login:n},name:o}}}catch(a){throw new Error(`Failed to fetch GitHub issue: ${a}`)}},Mn=async r=>{let t=process.env.GH_TOKEN;if(!t)return null;let e=new Ue({auth:t});try{let n=`
66
66
  query($owner: String!, $repo: String!, $issueNumber: Int!) {
67
67
  repository(owner: $owner, name: $repo) {
68
68
  issue(number: $issueNumber) {
@@ -125,7 +125,7 @@ ${i.map(l=>` - ${l.replace("@aurodesignsystem","AlaskaAirlines").replace("@alas
125
125
  }
126
126
  }
127
127
  }
128
- `,i={org:"AlaskaAirlines",projectNumber:o,owner:r.repository.owner.login,repo:r.repository.name,issueNumber:r.number},a=await n.graphql(s,i),l=a.organization.projectV2.id,d=a.repository.issue.id,m=a.organization.projectV2.fields.nodes.find(u=>u.name?.toLowerCase()==="ado"),c=a.repository.issue.projectItems.nodes.find(u=>u.project.number===o)?.id;if(c||(c=(await n.graphql(`
128
+ `,i={org:"AlaskaAirlines",projectNumber:o,owner:r.repository.owner.login,repo:r.repository.name,issueNumber:r.number},a=await n.graphql(s,i),l=a.organization.projectV2.id,m=a.repository.issue.id,u=a.organization.projectV2.fields.nodes.find(d=>d.name?.toLowerCase()==="ado"),c=a.repository.issue.projectItems.nodes.find(d=>d.project.number===o)?.id;if(c||(c=(await n.graphql(`
129
129
  mutation($projectId: ID!, $contentId: ID!) {
130
130
  addProjectV2ItemById(
131
131
  input: {
@@ -138,7 +138,7 @@ ${i.map(l=>` - ${l.replace("@aurodesignsystem","AlaskaAirlines").replace("@alas
138
138
  }
139
139
  }
140
140
  }
141
- `,{projectId:l,contentId:d})).addProjectV2ItemById.item.id),m&&c)await n.graphql(`
141
+ `,{projectId:l,contentId:m})).addProjectV2ItemById.item.id),u&&c)await n.graphql(`
142
142
  mutation($projectId: ID!, $itemId: ID!, $fieldId: ID!, $value: String!) {
143
143
  updateProjectV2ItemFieldValue(
144
144
  input: {
@@ -155,4 +155,4 @@ ${i.map(l=>` - ${l.replace("@aurodesignsystem","AlaskaAirlines").replace("@alas
155
155
  }
156
156
  }
157
157
  }
158
- `,{projectId:l,itemId:c,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}`)}},Hn=async r=>{let t=process.env.ADO_TOKEN;if(!t)throw new Error("ADO_TOKEN environment variable is required");let e="https://dev.azure.com/itsals",n="E_Retain_Content",o="E_Retain_Content\\Auro Design System",s=ge.getPersonalAccessTokenHandler(t),a=await new ge.WebApi(e,s).getWorkItemTrackingApi();try{let l=[{op:"add",path:"/fields/System.Title",value:r.title},{op:"add",path:"/fields/System.Description",value:`GitHub Issue: <a href="${r.html_url}">${r.html_url}</a>`},{op:"add",path:"/fields/System.AreaPath",value:o}];return await a.createWorkItem(null,l,n,"User Story")}catch(l){throw new Error(`Failed to create ADO work item: ${l}`)}},Lt=async r=>{let t=fe(`Processing GitHub issue: ${r}`).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 e=await Bn(r);t.succeed(`Found issue: "${e.title}"`);let n=fe("Checking for existing ADO work item...").start(),o=await Mn(e);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=fe("Creating new ADO work item...").start(),i=await Hn(e);if(s.succeed(`Successfully created ADO work item #${i.id}`),console.log(`Work item: ${i._links?.html?.href||"N/A"}`),i._links?.html?.href){let a=fe("Adding to GitHub project and updating ADO field...").start();await Gn(e,i._links.html.href),a.succeed("Updated GitHub project with ADO link")}}catch(e){t.fail(`Error: ${e instanceof Error?e.message:e}`),process.exit(1)}};var Ta=Ln.command("ado").description("Generate ADO item from GitHub issue").option("-g, --gh-issue <issue>","What GitHub issue to use").action(async r=>{r.ghIssue&&await Lt(r.ghIssue)});import{program as qn}from"commander";import{Octokit as Wn}from"@octokit/rest";import{simpleGit as Un}from"simple-git";var Wt="Release Candidate",V="dev",zn="main",he=class r{constructor(t,e,n){this.filteredCommits=null;this.repoInfo={owner:t,repo:e},this.octokit=n}static async create(){let t=process.env.GITHUB_TOKEN;if(!t)throw new Error("GITHUB_TOKEN is required to run RC workflow.");let e=await R.getRepoOwnerAndName(),n=new Wn({auth:t});if(!e)throw new Error("Failed to retrieve repository information. Ensure you're in a valid git repository.");let o=await r.getTriggerBranchName();return o&&o!==V&&(console.log(`Switching from ${o} to ${V} branch...`),await Un().checkout(V)),new r(e.owner,e.repo,n)}get owner(){return this.repoInfo.owner}get repo(){return this.repoInfo.repo}get repoData(){return{...this.repoInfo}}async createReleaseCandidate(){await this.hasCommitsReadyInDev()||console.log("No filtered commits found. Continuing to update RC issue/branch/PR.");let e=await this.getLatestOpenRcIssue(),n=e?await this.getLinkedPrByHead(e.number):null;if(n?.multipleOpen)throw new Error("Multiple open RC PRs found for the same rc/<issueNumber> branch.");if(n?.state==="closed"&&(console.log("Linked RC PR is closed. Creating a new RC issue and PR."),e=await this.createRcIssue(),n=null),e?await this.updateRcIssue(e.number):e=await this.createRcIssue(),!e)throw new Error("Failed to resolve RC issue.");await this.createOrUpdateRcBranch(e.number),n?await this.updateRcPr(e.number,n.number):n=await this.createRcPr(e.number)}async getFilteredCommits(){if(this.filteredCommits===null){let t=await R.getCommitMessages(V);this.filteredCommits=_e(t)}return this.filteredCommits}async hasCommitsReadyInDev(){return(await this.getFilteredCommits()).length>0}async getLatestOpenRcIssue(){let{data:t}=await this.octokit.rest.issues.listForRepo({owner:this.repoInfo.owner,repo:this.repoInfo.repo,labels:Wt,state:"open",sort:"updated",direction:"desc",per_page:30}),e=t.filter(o=>!o.pull_request);if(e.length===0)return console.log(`No open Release Candidate issues found in ${this.repoInfo.repo}`),null;let n=e[0];return console.log(`Using latest open Release Candidate issue: #${n.number}`),{number:n.number,title:n.title||""}}async updateRcIssue(t){let e=await this.getReleaseNotes(),n=`RC ${this.getCurrentDate()}`;await this.octokit.rest.issues.update({owner:this.repoInfo.owner,repo:this.repoInfo.repo,issue_number:t,title:n,body:e})}async createRcIssue(){let t=await this.getReleaseNotes(),{data:e}=await this.octokit.rest.issues.create({owner:this.repoInfo.owner,repo:this.repoInfo.repo,title:`RC ${this.getCurrentDate()}`,labels:[Wt],body:t});return console.log(`Created Release Candidate issue: #${e.number} (${e.html_url})`),{number:e.number,html_url:e.html_url}}async createOrUpdateRcBranch(t){let e=`heads/rc/${t}`,n=`rc/${t}`,{data:o}=await this.octokit.rest.repos.getBranch({owner:this.repoInfo.owner,repo:this.repoInfo.repo,branch:V}),{data:s}=await this.octokit.rest.git.listMatchingRefs({owner:this.repoInfo.owner,repo:this.repoInfo.repo,ref:e}),i=s.length>0;try{i?(console.log(`Updating existing RC branch: ${n}`),await this.octokit.rest.git.updateRef({owner:this.repoInfo.owner,repo:this.repoInfo.repo,ref:e,sha:o.commit.sha,force:!0})):(console.log(`Creating new RC branch: ${n}`),await this.octokit.rest.git.createRef({owner:this.repoInfo.owner,repo:this.repoInfo.repo,ref:`refs/${e}`,sha:o.commit.sha}))}catch(a){throw new Error(`Failed to create or update ${n} branch: ${a}`)}}async getLinkedPrByHead(t){let e=`${this.repoInfo.owner}:rc/${t}`,{data:n}=await this.octokit.rest.pulls.list({owner:this.repoInfo.owner,repo:this.repoInfo.repo,state:"all",head:e,per_page:30}),o=n.filter(i=>i.state==="open");if(o.length>1)return{state:"open",multipleOpen:!0};if(o.length===1)return{state:"open",html_url:o[0].html_url,number:o[0].number};let s=n.filter(i=>i.state==="closed");return s.length>0?{state:"closed",html_url:s[0].html_url,number:s[0].number}:null}async fetchPrTemplate(t){try{let{data:e}=await this.octokit.rest.repos.getContent({owner:this.repoInfo.owner,repo:this.repoInfo.repo,path:".github/PULL_REQUEST_TEMPLATE.md"});if("content"in e&&e.type==="file"){let n=Buffer.from(e.content,"base64").toString("utf-8");return n=n.replace("Please include a summary of the change and which issue is fixed. Please also include relevant motivation and context. List any dependencies that are required for this change.",`Release candidate pull request. See issue #${t} for details.`),n=n.replace(/<details>/g,"<details open>"),n}}catch(e){e&&typeof e=="object"&&"status"in e&&e.status===404?console.log("No PR template found in repo, using default message."):console.warn("Failed to fetch PR template:",e)}return`Release candidate pull request. See issue #${t} for details.`}async createRcPr(t){try{let e=await this.fetchPrTemplate(t),{data:n}=await this.octokit.request(`POST /repos/${this.repoInfo.owner}/${this.repoInfo.repo}/pulls`,{owner:this.repoInfo.owner,repo:this.repoInfo.repo,title:`RC #${t}`,body:e,head:`rc/${t}`,base:zn,headers:{"X-GitHub-Api-Version":"2022-11-28"}});return console.log(`Created Release Candidate pull request: #${n.number} (${n.html_url})`),{state:"open",html_url:n.html_url,number:n.number}}catch(e){throw console.error("Failed to create RC PR:",e),e}}async updateRcPr(t,e){try{let n=await this.fetchPrTemplate(t);await this.octokit.rest.pulls.update({owner:this.repoInfo.owner,repo:this.repoInfo.repo,pull_number:e,body:n}),console.log(`Updated Release Candidate pull request: #${e}`)}catch(n){throw console.error("Failed to update RC PR:",n),n}}async getReleaseNotes(){let t=await this.getFilteredCommits();return je(t,!1)}static async getTriggerBranchName(){return process.env.GITHUB_REF_NAME?process.env.GITHUB_REF_NAME:process.env.GITHUB_REF?.startsWith("refs/heads/")?process.env.GITHUB_REF.replace("refs/heads/",""):R.getCurrentBranchName()}getCurrentDate(){return new Date().toISOString().split("T")[0]}};var Na=qn.command("rc-workflow").description("Generate RC issue and pull request").action(async()=>{await(await he.create()).createReleaseCandidate()});ze.name("auro").version(ye()).description("A cli tool to support the Auro Design System");ze.addHelpText("beforeAll",qe());ze.parse();
158
+ `,{projectId:l,itemId:c,fieldId:u.id,value:t});else if(!u)throw new Error("No 'ado' field found in GitHub project")}catch(s){console.error(`Failed to update GitHub project: ${s}`)}},Hn=async r=>{let t=process.env.ADO_TOKEN;if(!t)throw new Error("ADO_TOKEN environment variable is required");let e="https://dev.azure.com/itsals",n="E_Retain_Content",o="E_Retain_Content\\Auro Design System",s=ge.getPersonalAccessTokenHandler(t),a=await new ge.WebApi(e,s).getWorkItemTrackingApi();try{let l=[{op:"add",path:"/fields/System.Title",value:r.title},{op:"add",path:"/fields/System.Description",value:`GitHub Issue: <a href="${r.html_url}">${r.html_url}</a>`},{op:"add",path:"/fields/System.AreaPath",value:o}];return await a.createWorkItem(null,l,n,"User Story")}catch(l){throw new Error(`Failed to create ADO work item: ${l}`)}},Lt=async r=>{let t=fe(`Processing GitHub issue: ${r}`).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 e=await Bn(r);t.succeed(`Found issue: "${e.title}"`);let n=fe("Checking for existing ADO work item...").start(),o=await Mn(e);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=fe("Creating new ADO work item...").start(),i=await Hn(e);if(s.succeed(`Successfully created ADO work item #${i.id}`),console.log(`Work item: ${i._links?.html?.href||"N/A"}`),i._links?.html?.href){let a=fe("Adding to GitHub project and updating ADO field...").start();await Gn(e,i._links.html.href),a.succeed("Updated GitHub project with ADO link")}}catch(e){t.fail(`Error: ${e instanceof Error?e.message:e}`),process.exit(1)}};var va=Ln.command("ado").description("Generate ADO item from GitHub issue").option("-g, --gh-issue <issue>","What GitHub issue to use").action(async r=>{r.ghIssue&&await Lt(r.ghIssue)});import{program as qn}from"commander";import{Octokit as Wn}from"@octokit/rest";import{simpleGit as Un}from"simple-git";var Wt="Release Candidate",J="dev",zn="main",he=class r{constructor(t,e,n){this.filteredCommits=null;this.repoInfo={owner:t,repo:e},this.octokit=n}static async create(){let t=process.env.GITHUB_TOKEN;if(!t)throw new Error("GITHUB_TOKEN is required to run RC workflow.");let e=await R.getRepoOwnerAndName(),n=new Wn({auth:t});if(!e)throw new Error("Failed to retrieve repository information. Ensure you're in a valid git repository.");let o=await r.getTriggerBranchName();return o&&o!==J&&(console.log(`Switching from ${o} to ${J} branch...`),await Un().checkout(J)),new r(e.owner,e.repo,n)}get owner(){return this.repoInfo.owner}get repo(){return this.repoInfo.repo}get repoData(){return{...this.repoInfo}}async createReleaseCandidate(){await this.hasCommitsReadyInDev()||console.log("No filtered commits found. Continuing to update RC issue/branch/PR.");let e=await this.getLatestOpenRcIssue(),n=e?await this.getLinkedPrByHead(e.number):null;if(n?.multipleOpen)throw new Error("Multiple open RC PRs found for the same rc/<issueNumber> branch.");if(n?.state==="closed"&&(console.log("Linked RC PR is closed. Creating a new RC issue and PR."),e=await this.createRcIssue(),n=null),e?await this.updateRcIssue(e.number):e=await this.createRcIssue(),!e)throw new Error("Failed to resolve RC issue.");await this.createOrUpdateRcBranch(e.number),n?await this.updateRcPr(e.number,n.number):n=await this.createRcPr(e.number)}async getFilteredCommits(){if(this.filteredCommits===null){let t=await R.getCommitMessages(J);this.filteredCommits=_e(t)}return this.filteredCommits}async hasCommitsReadyInDev(){return(await this.getFilteredCommits()).length>0}async getLatestOpenRcIssue(){let{data:t}=await this.octokit.rest.issues.listForRepo({owner:this.repoInfo.owner,repo:this.repoInfo.repo,labels:Wt,state:"open",sort:"updated",direction:"desc",per_page:30}),e=t.filter(o=>!o.pull_request);if(e.length===0)return console.log(`No open Release Candidate issues found in ${this.repoInfo.repo}`),null;let n=e[0];return console.log(`Using latest open Release Candidate issue: #${n.number}`),{number:n.number,title:n.title||""}}async updateRcIssue(t){let e=await this.getReleaseNotes(),n=`RC ${this.getCurrentDate()}`;await this.octokit.rest.issues.update({owner:this.repoInfo.owner,repo:this.repoInfo.repo,issue_number:t,title:n,body:e})}async createRcIssue(){let t=await this.getReleaseNotes(),{data:e}=await this.octokit.rest.issues.create({owner:this.repoInfo.owner,repo:this.repoInfo.repo,title:`RC ${this.getCurrentDate()}`,labels:[Wt],body:t});return console.log(`Created Release Candidate issue: #${e.number} (${e.html_url})`),{number:e.number,html_url:e.html_url}}async createOrUpdateRcBranch(t){let e=`heads/rc/${t}`,n=`rc/${t}`,{data:o}=await this.octokit.rest.repos.getBranch({owner:this.repoInfo.owner,repo:this.repoInfo.repo,branch:J}),{data:s}=await this.octokit.rest.git.listMatchingRefs({owner:this.repoInfo.owner,repo:this.repoInfo.repo,ref:e}),i=s.length>0;try{i?(console.log(`Updating existing RC branch: ${n}`),await this.octokit.rest.git.updateRef({owner:this.repoInfo.owner,repo:this.repoInfo.repo,ref:e,sha:o.commit.sha,force:!0})):(console.log(`Creating new RC branch: ${n}`),await this.octokit.rest.git.createRef({owner:this.repoInfo.owner,repo:this.repoInfo.repo,ref:`refs/${e}`,sha:o.commit.sha}))}catch(a){throw new Error(`Failed to create or update ${n} branch: ${a}`)}}async getLinkedPrByHead(t){let e=`${this.repoInfo.owner}:rc/${t}`,{data:n}=await this.octokit.rest.pulls.list({owner:this.repoInfo.owner,repo:this.repoInfo.repo,state:"all",head:e,per_page:30}),o=n.filter(i=>i.state==="open");if(o.length>1)return{state:"open",multipleOpen:!0};if(o.length===1)return{state:"open",html_url:o[0].html_url,number:o[0].number};let s=n.filter(i=>i.state==="closed");return s.length>0?{state:"closed",html_url:s[0].html_url,number:s[0].number}:null}async fetchPrTemplate(t){try{let{data:e}=await this.octokit.rest.repos.getContent({owner:this.repoInfo.owner,repo:this.repoInfo.repo,path:".github/PULL_REQUEST_TEMPLATE.md"});if("content"in e&&e.type==="file"){let n=Buffer.from(e.content,"base64").toString("utf-8");return n=n.replace("Please include a summary of the change and which issue is fixed. Please also include relevant motivation and context. List any dependencies that are required for this change.",`Release candidate pull request. See issue #${t} for details.`),n=n.replace(/<details>/g,"<details open>"),n}}catch(e){e&&typeof e=="object"&&"status"in e&&e.status===404?console.log("No PR template found in repo, using default message."):console.warn("Failed to fetch PR template:",e)}return`Release candidate pull request. See issue #${t} for details.`}async createRcPr(t){try{let e=await this.fetchPrTemplate(t),{data:n}=await this.octokit.request(`POST /repos/${this.repoInfo.owner}/${this.repoInfo.repo}/pulls`,{owner:this.repoInfo.owner,repo:this.repoInfo.repo,title:`RC #${t}`,body:e,head:`rc/${t}`,base:zn,headers:{"X-GitHub-Api-Version":"2022-11-28"}});return console.log(`Created Release Candidate pull request: #${n.number} (${n.html_url})`),{state:"open",html_url:n.html_url,number:n.number}}catch(e){throw console.error("Failed to create RC PR:",e),e}}async updateRcPr(t,e){try{let n=await this.fetchPrTemplate(t);await this.octokit.rest.pulls.update({owner:this.repoInfo.owner,repo:this.repoInfo.repo,pull_number:e,body:n}),console.log(`Updated Release Candidate pull request: #${e}`)}catch(n){throw console.error("Failed to update RC PR:",n),n}}async getReleaseNotes(){let t=await this.getFilteredCommits();return je(t,!1)}static async getTriggerBranchName(){return process.env.GITHUB_REF_NAME?process.env.GITHUB_REF_NAME:process.env.GITHUB_REF?.startsWith("refs/heads/")?process.env.GITHUB_REF.replace("refs/heads/",""):R.getCurrentBranchName()}getCurrentDate(){return new Date().toISOString().split("T")[0]}};var Oa=qn.command("rc-workflow").description("Generate RC issue and pull request").action(async()=>{await(await he.create()).createReleaseCandidate()});ze.name("auro").version(ye()).description("A cli tool to support the Auro Design System");ze.addHelpText("beforeAll",qe());ze.parse();