@aurodesignsystem-dev/auro-cli 0.0.0-pr289.2 → 0.0.0-pr294.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,68 +1,68 @@
1
1
  #!/usr/bin/env node
2
- import{program as ze}from"commander";import Wt from"figlet";import{mind as zt}from"gradient-string";var qe=()=>zt(Wt.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 Gr from"@rollup/plugin-terser";import{watch as Lr}from"rollup";import{existsSync as mt,readFileSync as Sr,rmSync as Dr,writeFileSync as Pr}from"node:fs";import{basename as xr,dirname as Or,join as L,resolve as ae}from"node:path";import{pathToFileURL as dt}from"node:url";import{glob as Nr}from"glob";import Se from"ora";import{rollup as Re}from"rollup";import*as pt from"sass";import B 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(`
2
+ import"dotenv/config";import{program as Tt}from"commander";import hn from"figlet";import{mind as yn}from"gradient-string";var Ot=()=>yn(hn.textSync("Auro CLI"));import Nt from"node:fs";import jt from"node:path";import{fileURLToPath as wn}from"node:url";function fe(e){process.env.DEBUG&&console.log(`[DEBUG] ${e}`)}function Ve(){try{let e=wn(import.meta.url),t=jt.dirname(e);fe(`Current module path: ${t}`);let r=jt.resolve(t,"..","package.json");return fe(`Checking package.json at: ${r}`),Nt.existsSync(r)?(fe(`Found package.json at: ${r}`),JSON.parse(Nt.readFileSync(r,"utf8")).version):(fe("Could not find package.json in the standard installed module location, using default version"),"0.0.0")}catch(e){return console.error("Error retrieving package version:",e),"0.0.0"}}import{program as yo}from"commander";import ir from"ora";function he(e){return e.option("-m, --module-paths [paths...]","Path(s) to node_modules folder").option("-w, --watch","Watches for changes").option("--skip-docs","Skip documentation generation",!1).option("-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 ye(e){return e.option("-s, --serve","Starts a server").option("-p, --port <number>","Port for the server").option("-o, --open","Open the browser after starting the server")}import mo from"@rollup/plugin-terser";import{watch as go}from"rollup";import{existsSync as Zt,readFileSync as to,rmSync as ro,writeFileSync as no}from"node:fs";import{basename as oo,dirname as so,join as te,resolve as Ie}from"node:path";import{pathToFileURL as Qt}from"node:url";import{glob as io}from"glob";import nt from"ora";import{rollup as rt}from"rollup";import*as er from"sass";import Q from"ora";import bn from"node:fs";import kn from"node:os";import we from"node:path";import ze from"node:process";function $n(){let e=kn.homedir()||ze.env.HOME||ze.env.USERPROFILE;if(!e)throw new Error("Unable to determine user home directory");return we.join(e,".auro")}function qe(...e){return we.join($n(),...e)}function Je(...e){let t=bn.realpathSync(ze.argv[1]),r=we.dirname(t);return we.resolve(r,...e)}var _t=e=>Je("configs",e);import{copyFileSync as vn,existsSync as Bt,mkdirSync as Sn}from"node:fs";import{join as Cn,resolve as Ke}from"node:path";function J(){let e=process.cwd(),t=Ke(e,"README.md"),r=Cn(Ke(e,"demo"),"readme.md");if(!Bt(t))return;let n=Ke(e,"demo");Bt(n)||Sn(n,{recursive:!0}),vn(t,r)}import An from"ora";var Ut=[];function K(e){Ut.push(e)}var Ft=!1;function be(){Ft||(Ft=!0,process.on("SIGINT",()=>{let e=An("Wrapping up...").start();for(let t of Ut)t.close();e.succeed("All done! See you next time. \u2728"),process.exit(0)}))}import{spawn as In}from"node:child_process";import En from"ora";var R=(e,t)=>{let r=`${e} ${t?t.join(" "):""}`,n=En(),o=e,s=t||[];if(!t&&typeof e=="string"){let u=e.split(" ");o=u[0],s=u.slice(1)}let i=r.includes("--watch")||r.includes(" -w"),l=In(o,s,{stdio:i?"inherit":["inherit","pipe","pipe"],shell:!0});if(!i){let u=[];l.stdout?.on("data",d=>{let c=d.toString();u.push(c),process.stdout.write(c)}),l.stderr?.on("data",d=>{let c=d.toString();u.push(c),process.stderr.write(c)})}return new Promise((u,d)=>{l.on("close",c=>{c!==0?i?(n.info(`Watch mode terminated with code ${c}`),u()):(n.fail(`${r} failed (code ${c})`),d(new Error(`Command failed with exit code ${c}`))):(n.succeed(`${r} completed successfully`),u())})})};import T from"node:fs";import D from"node:path";import{Logger as Pn}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import{generateReadmeUrl as Rn,processContentForFile as xn,templateFiller as Xe}from"@aurodesignsystem/auro-library/scripts/utils/sharedFileProcessorUtils.mjs";import{readFileSync as Ze,existsSync as Ye}from"node:fs";var Tn="/docs/pages",Lt={overwriteLocalCopies:!0,remoteReadmeVersion:"master",remoteReadmeVariant:"_updated_paths",monorepoName:void 0,extraVars:{}};function E(e){return`${process.cwd()}/${e}`}function Dn(e=process.cwd()){let t=e;for(;;){let r=D.join(t,"package.json");if(Ye(r))try{if(JSON.parse(Ze(r,"utf8")).workspaces)return t}catch{}let n=D.dirname(t);if(n===t)break;t=n}return e}async function On(e,t=!1){let r=[];if(!t){let o=e.localReadmePath?e.localReadmePath:{remoteUrl:e.remoteReadmeUrl||Rn(e.remoteReadmeVersion,e.remoteReadmeVariant),fileName:E("/docTemplates/README.md"),overwrite:e.overwriteLocalCopies};r.push({identifier:"README.md",input:o,output:E("/README.md")})}Mt("/docs/partials/index.md")&&r.push({identifier:"index.md",input:E("/docs/partials/index.md"),output:E("/demo/index.md"),mdMagicConfig:{output:{directory:E("/demo")}}}),Mt("/docs/partials/api.md")&&r.push({identifier:"api.md",input:E("/docs/partials/api.md"),output:E("/demo/api.md"),preProcessors:[Xe.formatApiTable]});let n=E(Tn);if(T.existsSync(n)){let s=(await T.promises.readdir(n)).map(i=>({identifier:i,input:D.join(n,i),output:E(`/demo/${i}`)}));r.push(...s)}return r}async function Nn(e=Lt,t=!1){await Xe.extractNames();let r=await On(e,t),n=e.monorepoName;if(!n)try{let s=D.join(Dn(),"package.json");n=JSON.parse(Ze(s,"utf8")).name?.replace(/^@[^/]+\//,"")}catch{}let o={...n?{monorepoName:n}:{},...e.extraVars||{}};for(let s of r)try{await xn({...s,extraVars:o}),s.output.endsWith(".md")&&await jn(s.output,o)}catch(i){Pn.error(`Error processing ${s.identifier}: ${i.message}`)}}async function jn(e,t={}){let r=D.dirname(e),n=await T.promises.readFile(e,"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[p,m,g]=s,h=D.resolve(r,g),w=D.resolve(a,g),C=Ye(h)?h:Ye(w)?w:null;if(C){let v=Ze(C,"utf8"),y;if(m==="FILE")y=`<!-- AURO-GENERATED-CONTENT:START (FILE:src=${g}) -->
3
+ <!-- The below content is automatically added from ${g} -->
4
+ ${v.trimEnd()}
5
+ <!-- AURO-GENERATED-CONTENT:END -->`;else{let b=D.extname(g).slice(1)||"html",P=v.trimEnd().replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;");y=`<!-- AURO-GENERATED-CONTENT:START (CODE:src=${g}) -->
6
+ <!-- The below code snippet is automatically added from ${g} -->
7
+ <pre class="language-${b}"><code class="language-${b}">${P}
8
+ </code></pre>
9
+ <!-- AURO-GENERATED-CONTENT:END -->`}n=n.replace(p,y),o.lastIndex=0,i=!0}}i&&(n=Xe.replaceTemplateValues(n,t),await T.promises.writeFile(e,n)),n=await T.promises.readFile(e,"utf8");let l=/^[ \t]*```(\w*)\n([\s\S]*?)^[ \t]*```[ \t]*$/gm,u=n.replace(l,(p,m,g)=>{let h=m||"html",w=g.trimEnd().replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;");return`<pre class="language-${h}"><code class="language-${h}">${w}
10
+ </code></pre>`});u!==n&&await T.promises.writeFile(e,u),n=await T.promises.readFile(e,"utf8"),n=n.replace(/(<pre[^>]*><code[^>]*>)([\s\S]*?)(<\/code><\/pre>)/g,(p,m,g,h)=>{let w=g.split(`
11
+ `),C=w.filter(b=>b.trim().length>0);if(C.length===0)return p;let v=Math.min(...C.map(b=>{let P=b.match(/^[ \t]*/);return P?P[0].length:0})),y=w.map(b=>b===""||b.trim().length===0?"\u200B":v>0?b.substring(v):b);for(;y.length>0&&(y[y.length-1]==="\u200B"||y[y.length-1]==="");)y.pop();return m+y.join(`
12
+ `)+h});let d=n.split(`
13
+ `),c=!1;for(let p=0;p<d.length;p++)/<pre[\s>]/i.test(d[p])&&(c=!0),c||(d[p]=d[p].replace(/^[ \t]+(?=<)/,"")),/<\/pre>/i.test(d[p])&&(c=!1);await T.promises.writeFile(e,d.join(`
14
+ `))}async function Y(e={}){let t=e.readmeTemplate,r=t&&!t.startsWith("http");await Nn({...Lt,...r?{localReadmePath:D.resolve(process.cwd(),t)}:{remoteReadmeUrl:t||"https://raw.githubusercontent.com/AlaskaAirlines/auro-templates/main/templates/default/README.md"}},e.skipReadme)}function Mt(e){return T.existsSync(E(e))}import{existsSync as Gt,readFileSync as _n}from"node:fs";import{builtinModules as Bn}from"node:module";import{resolve as ke}from"node:path";import{startDevServer as Fn}from"@web/dev-server";import{hmrPlugin as Un}from"@web/dev-server-hmr";import*as Ht from"esbuild";import Mn from"ora";var N=["node_modules","../node_modules","../../node_modules","../../../node_modules"];var Ln=/^\/__wds-outside-root__\/(\d+)\/(.+)$/;function Gn(){return{name:"node-modules-css",serve(e){if(!e.path.endsWith(".css")||!e.path.startsWith("/@")&&!/^\/[a-z]/i.test(e.path))return;let t=e.path.slice(1),r=process.cwd();for(let n of N){let o=ke(r,n,t);if(Gt(o))return{body:_n(o,"utf-8"),type:"css"}}}}}function Hn(e,t){let r=e.match(Ln);return r?ke(t,"../".repeat(Number.parseInt(r[1],10)),r[2]):ke(t,`.${e}`)}function Wn(){let e=/\b(require\s*\(|module\.exports\b|exports\.\w)/,t=new Map,r;return{name:"cjs-to-esm",async serverStart({config:n}){r=ke(n.rootDir)},async transform(n){if(!n.path.includes("node_modules")||!n.path.endsWith(".js")&&!n.path.endsWith(".cjs")||typeof n.body!="string"||!e.test(n.body))return;let o=Hn(n.path,r);if(t.has(o))return t.get(o);if(Gt(o))try{let i={body:(await Ht.build({entryPoints:[o],bundle:!0,format:"esm",platform:"browser",write:!1,logLevel:"silent",external:Bn})).outputFiles[0].text};return t.set(o,i),i}catch(s){console.error(`CJS-to-ESM bundling failed for ${n.path}:`,s.message)}}}}var X={watch:!0,nodeResolve:!0,basePath:"/",rootDir:"./demo",hmrInclude:["src/**/*","demo/**/*","apiExamples/**/*","docs/**/*"]};async function $e(e={}){if(!e.serve)return;let t=Mn(`Firing up dev server...
15
+ `).start();try{let r={port:Number(e.port)||void 0,open:e.open?"/":void 0,watch:e.watch??X.watch,nodeResolve:e.nodeResolve??X.nodeResolve,basePath:e.basePath??X.basePath,rootDir:e.rootDir??X.rootDir,middleware:[function(s,i){return!s.url.endsWith("/")&&!s.url.includes(".")&&(s.url+=".html"),i()}],plugins:[Gn(),Wn(),Un({include:e.hmrInclude??X.hmrInclude})]},n=await Fn({config:r,readCliArgs:!1,readFileConfig:!1});return t.stop(),n}catch(r){throw t.fail("Server snag! Couldn't start dev server."),console.error("Error starting development server:",r),new Error(`Development server failed to start: ${r.message}`)}}import ve from"node:fs";import Vn from"node:path";import{markdownTable as Wt}from"markdown-table";var Z=class e{static{this.manifest={schemaVersion:"1.0.0",readme:"",modules:[]}}static generate(t={}){let{outDir:r="./docs",outFile:n="api.md",manifestPath:o="./custom-elements.json"}=t,{getElements:s,renderAllElements:i}=e;if(o)try{let c=ve.readFileSync(o,"utf8");e.manifest=JSON.parse(c)}catch(c){throw console.error(`Error reading manifest file at ${o}:`,c),c}let a=s(),l=r;ve.existsSync(l)||ve.mkdirSync(l,{recursive:!0});let u=i(a),d=Vn.join(l,n);ve.writeFileSync(d,u),console.log(`Generated combined API documentation at ${d}`)}static getElements(){let t=e.manifest.modules.filter(e.isWcaModule);return e.manifest.modules.reduce((r,n)=>r.concat(n.declarations?.filter(o=>"customElement"in o&&o.customElement===!0&&"tagName"in o&&(t.length>0?e.isWcaModule(n):!0))??[]),[])}static isWcaModule(t){let{path:r}=t;return r?r.startsWith("scripts/wca/auro-")&&r.endsWith(".js"):!1}static renderAllElements(t){return`${t.sort((r,n)=>(r.tagName||"").localeCompare(n.tagName||"")).map(r=>e.renderElement(r,!0)).join(`
3
16
 
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(`
17
+ `)}`}static renderElement(t,r=!0){let n=[],{renderTable:o,renderPropertiesAttributesTable:s,renderParameters:i,getType:a}=e;n.push(r?`# ${t.tagName}`:""),t.description&&n.push(t.description);let l=s(t);l&&n.push(l.trim());let u=o("Methods",["name","parameters","return","description"],(t.members||[]).filter(g=>g.kind==="method"&&("privacy"in g?g.privacy!=="private":!0)&&g.name[0]!=="_").map(g=>({...g,parameters:i("parameters"in g?g.parameters:void 0),return:"return"in g&&g.return?a(g.return):""})));u&&n.push(u.trim());let d=o("Events",["name","description"],t.events);d&&n.push(d.trim());let c=o("Slots",[["name","(default)"],"description"],t.slots);c&&n.push(c.trim());let p=o("CSS Shadow Parts",["name","description"],t.cssParts);p&&n.push(p.trim());let m=o("CSS Custom Properties",["name","description"],t.cssProperties);return m&&n.push(m.trim()),n.join(`
5
18
 
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
19
+ `)}static renderPropertiesAttributesTable(t){let{getType:r,escapeMarkdown:n}=e,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 p=r(c)||"",g=("return"in c&&c.return?r(c.return):"")||p;i.push({name:c.name,properties:c.name,attributes:("attribute"in c?c.attribute:"")||"",modifiers:"readonly"in c&&c.readonly?"readonly":"",type:g,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:r(c)||"",default:c.default||"",description:c.description||""})}),i.length===0)return"";let l=["Properties","Attributes","Modifiers","Type","Default","Description"],u=i.map(c=>{let h=(c.default||"").trim().replace(/^'([^']+)'$/,"$1").replace(/^"([^"]+)"$/,"$1"),w=h?h.startsWith("`")&&h.endsWith("`")?h:`\`${h}\``:"";return[n(c.properties),n(c.attributes),n(c.modifiers),n(c.type),n(w),n(c.description)]});return`### Properties & Attributes
7
20
 
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}
21
+ ${Wt([l,...u])}
22
+ `}static renderParameters(t){let{escapeMarkdown:r,getType:n}=e;return!t||t.length===0?"None":t.map(o=>{let s=n(o)||"any",i=o.description?` - ${o.description}`:"";return`\`${o.name}\` (${r(s)})${r(i)}`}).join("<br>")}static renderTable(t,r,n){let{escapeMarkdown:o,get:s,capitalize:i}=e;if(n===void 0||n.length===0)return"";let a=n.filter(c=>{let{description:p}=c;return typeof p=="string"&&p.trim()});if(a.length===0)return"";let l=r.map(c=>i((Array.isArray(c)?c[0]:c).split(".")[0])),u=a.map(c=>r.map(p=>{let m=s(c,p);return o(String(m||""))})),d=Wt([l,...u]);return`### ${t}
10
23
 
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
- <!-- The below content is automatically added from ${p} -->
14
- ${O.trimEnd()}
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
- <!-- The below code snippet is automatically added from ${p} -->
17
- <pre class="language-${$}"><code class="language-${$}">${K}
18
- </code></pre>
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 I=["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 I){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 M={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??M.watch,nodeResolve:r.nodeResolve??M.nodeResolve,basePath:r.basePath??M.basePath,rootDir:r.rootDir??M.rootDir,middleware:[function(s,i){return!s.url.endsWith("/")&&!s.url.includes(".")&&(s.url+=".html"),i()}],plugins:[yr(),br(),fr({include:r.hmrInclude??M.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=B("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=B("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=B("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 R(),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=B("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=B(`Change detected: ${u}`).start();try{await F(r),j(),await R(),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,resolve as Ar}from"node:path";import vr from"@rollup/plugin-commonjs";import{nodeResolve as Tr}from"@rollup/plugin-node-resolve";import{glob as Cr}from"glob";import{litScss as Ir}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],i=process.cwd(),a=I.map(l=>Ar(i,l));return[Tr({dedupe:n,preferBuiltins:!1,moduleDirectories:Ce.moduleDirectories,modulePaths:a}),vr(),Ir({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:Rr(),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=Cr.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,onwarn(f,p){if(f.code==="UNRESOLVED_IMPORT")throw new Error(`Unresolved import "${f.exporter??f.source}" in ${f.id??c}. Make sure workspace dependencies are built before bundling demos.`);p(f)},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 Rr(r=[]){return[...[/node_modules\/lit/,/node_modules\/lit-element/,/node_modules\/lit-html/,/node_modules\/@lit/],...r]}function ft(){let r=L("./dist"),t=Se("Cleaning dist folder...").start();try{return Dr(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 jr(){let r=process.cwd();function t(o){return[o,`${o}.scss`,`${o}.css`,L(Or(o),`_${xr(o)}.scss`),L(o,"_index.scss"),L(o,"index.scss")].find(i=>mt(i))}function e(o){for(let i of I){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 I){let l=ae(r,a,s,"package.json");if(mt(l))try{let u=JSON.parse(Sr(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 R(r="./demo"){return ce("Compiling demo SCSS...",async()=>{let t=Nr.sync(L(r,"**/*.scss")),e=jr(),n=process.cwd(),o=I.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");Pr(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 D from"ora";import"rollup";var U=!1,_r={analyze:{active:!1,lastTime:0},docs:{active:!1,lastTime:0},scss:{active:!1,lastTime:0}},Fr=5e3,ue=new Set,Mr=["/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 Mr.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=_r[r];if(e.active||Date.now()-e.lastTime<Fr)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=D("Activating watch mode...").start(),l={analyze:async()=>{let{wcaInput:c,wcaOutput:d,skipDocs:f}=t;if(f){let g=D("Skipping component analysis...").start();return setTimeout(()=>{g.succeed("Component analysis skipped.")},0),!0}let p=D("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(U)return!1;if(t.skipDocs){let d=D("Skipping docs generation...").start();return setTimeout(()=>{d.succeed("Docs generation skipped.")},0),!0}let c=D("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(U)return!1;try{return await R(),!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=D("Weaving bundles...").start(),U=!0;break;case"BUNDLE_END":i&&i.succeed(`Bundle ${Array.isArray(c.input)?`of ${c.input.join("& ")} `:""}done in ${c.duration}ms! \u{1F680}`),U=!1,ue.size>0&&u();break;case"END":break;case"ERROR":U=!1,i?i.fail(`Oops! Bundle hit a snag: ${c.error.message}`):D().fail(`Watch mode hiccup: ${c.error.message}`),ue.clear();break}})}function wt(r,t){return _(r),t&&_(t),te(),r}async function Ur(r){let t=Ie(r),e=G(r);r.dev||t.config.plugins.push(Gr()),await le(r),await R(),await gt(t.config,e.configs)}async function Hr(r){let{dev:t}=r,e=Ie({...r,watch:!0}),n=G({...r,watch:!0}),o=Lr([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 R()}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 Hr(r):await Ur(r)}catch(t){throw new Error(`Build failed: ${t.message}`)}}var H=Wr.command("dev").description("Runs development server for auro components");H=X(H);H=Z(H);var js=H.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 zr}from"commander";import kt from"ora";var Pe=zr.command("build").description("Builds auro components");Pe=X(Pe);var Ls=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 qr}from"node:child_process";import $t from"node:path";import Vr from"node:process";import{fileURLToPath as Jr}from"node:url";import Kr from"node:util";import{program as Yr}from"commander";import Xr from"inquirer";var Xs=Yr.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=Jr(import.meta.url),e=$t.dirname(t),n=$t.resolve(e,"migrations",r.id);if(r.multiGitter){let o=Kr.promisify(qr);try{await o("command -v multi-gitter")}catch{console.error("multi-gitter is not installed."),Vr.exit(1)}(await Xr.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 rn}from"commander";import{readFile as nn,writeFile as on}from"node:fs/promises";import{Logger as W}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import xe from"node:fs/promises";import Oe from"node:path";import{Octokit as Zr}from"@octokit/rest";import v from"ora";import{processContentForFile as Qr,templateFiller as en}from"@aurodesignsystem/auro-library/scripts/utils/sharedFileProcessorUtils.mjs";async function Et(r,t){let e=new Zr({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 tn(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
- `;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 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
- `}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 en.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 tn(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=>Qr(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 ui=rn.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=>{W.info("Synchronizing repository configuration files..."),W.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 nn(e,{encoding:"utf-8"})).replace(/\r\n/gu,`
24
+ ${d}
25
+ `}static escapeMarkdown(t){return t.replace(/\\/g,"\\\\").replace(/\n/g,"<br>").replace(/\|/g,"\\|")}static getType(t){if(!t||!t.type)return"";let{type:r}=t,n=s=>s.replace(/\s*\|\s*/g," | ").replace(/'([^']+)'/g,"`$1`");if(typeof r=="string")return n(r);if(r.text)return n(r.text);if(Array.isArray(r))return r.map(s=>typeof s=="string"?s:s.text?s.text:s.name?s.name:String(s)).join(" \\| ");if(r.name)return n(r.name);if(r.references&&Array.isArray(r.references))return r.references.map(s=>s.name||String(s)).join(" \\| ");let o=String(r);return n(o)}static get(t,r){let n="",o=r;Array.isArray(r)&&([o,n]=r);let s=o.split("."),i=t;for(;i&&s.length;)i=i[s.shift()];return i==null||i===""?n:String(i)}static capitalize(t){return t.replace(/([A-Z])/g," $1").replace(/^./,r=>r.toUpperCase()).trim()}};async function Se(){let e=Q("Generating Custom Elements Manifest...").start();try{await R(`npx --package=@custom-elements-manifest/analyzer -y -- cem analyze --config '${_t("custom-elements-manifest.config.mjs")}'`),e.succeed("Custom Elements Manifest generated successfully!")}catch(t){let r=t instanceof Error?t.message:String(t);e.warn("CEM analyzer completed with warnings: "+r)}}async function Ce(){let e=Q("Generating API md file...").start();try{await Z.generate(),e.succeed("API md file generated successfully!")}catch(t){let r=t instanceof Error?t.message:String(t);throw e.fail("Failed to generate API md file: "+r),t}}async function Vt(e={}){let t=Q("Compiling documentation...").start();try{await Y(e),t.succeed("Documentation compiled successfully!")}catch(r){let n=r instanceof Error?r.message:String(r);throw t.fail("Failed to compile MD documentation: "+n),r}J(),await j(),await Qe(e)}async function zt(e={}){await $e(e)}async function qt(e={}){let t=await import("chokidar"),r=["./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(r,{ignoreInitial:!0,ignored:n,awaitWriteFinish:{stabilityThreshold:1e3,pollInterval:100}}),s=Q("Waiting for changes...");s.spinner="bouncingBar",s.color="green",s.start();let i=null,a=!1,l=!1;async function u(d){if(a){l=!0;return}a=!0,o.unwatch(r);let c=Q(`Change detected: ${d}`).start();try{await Y(e),J(),await j(),await Qe(e),c.succeed("Docs rebuilt!")}catch(p){let m=p instanceof Error?p.message:String(p);c.fail("Rebuild failed: "+m)}finally{setTimeout(()=>{o.add(r),a=!1,l&&(l=!1,u("queued changes"))},1e3)}}o.on("all",(d,c)=>{a||(i&&clearTimeout(i),i=setTimeout(()=>{u(c)},1e3))}),K(o),be()}async function Ae(){await Se(),await Ce()}import{basename as Jn,join as Kt,resolve as Kn}from"node:path";import Yn from"@rollup/plugin-commonjs";import{nodeResolve as Xn}from"@rollup/plugin-node-resolve";import{glob as Zn}from"glob";import{litScss as Qn}from"rollup-plugin-scss-lit";import zn from"node:path";import{glob as qn}from"glob";function Jt(e){return{name:"watch-globs",buildStart(){let t=Array.isArray(e)?e:[e];for(let r of t)try{for(let n of qn.sync(zn.resolve(r)))this.addWatchFile(n)}catch(n){this.error(`Error watching glob pattern "${r}": ${n.message}`)}}}}var et={moduleDirectories:["node_modules"],modulePaths:["../../node_modules","../node_modules","node_modules"],watchPatterns:["./apiExamples/**/*","./docs/**/*"]};function Yt(e=[],t={}){let{watchPatterns:r=et.watchPatterns,dedupe:n=["lit","lit-element","lit-html"],dev:o=!1}=t,s=[...et.modulePaths,...e],i=process.cwd(),a=N.map(l=>Kn(i,l));return[Xn({dedupe:n,preferBuiltins:!1,moduleDirectories:et.moduleDirectories,modulePaths:a}),Yn(),Qn({minify:o?!1:{fast:!0},options:{loadPaths:[...s,Kt(process.cwd(),"src","styles"),Kt(process.cwd(),"src")]}}),Jt(r)]}function tt(e={}){let{modulePaths:t=[],watch:r=!1,input:n=["./src/index.js","./src/registered.js"],outputDir:o="./dist",format:s="esm",dev:i=!1}=e;return{name:"Main",config:{input:n,output:{format:s,dir:o,entryFileNames: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:eo(),plugins:Yt(t,{dev:i}),watch:Xt(r)}}}function ee(e={}){let{modulePaths:t=[],watch:r=!1,globPattern:n="./demo/*.js",ignorePattern:o=["./demo/*.min.js"],outputDir:s="./demo",dev:i=!1}=e,a=Zn.sync(n,{ignore:o}),l=Yt(t,{dev:i}),u=Xt(r);return{name:"Demo",configs:a.map(c=>({input:{[Jn(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,onwarn(m,g){if(m.code==="UNRESOLVED_IMPORT")throw new Error(`Unresolved import "${m.exporter??m.source}" in ${m.id??c}. Make sure workspace dependencies are built before bundling demos.`);g(m)},watch:u}))}}function Xt(e){if(!e)return!1;let t=typeof e=="object"?e:{};return{clearScreen:t.clearScreen??!0,buildDelay:t.buildDelay??500,chokidar:{ignoreInitial:!0,ignored:t.ignored??["**/dist/**/*.d.ts","**/custom-elements.json","**/demo/*.md","**/demo/**/*.min.js","**/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 eo(e=[]){return[...[/node_modules\/lit/,/node_modules\/lit-element/,/node_modules\/lit-html/,/node_modules\/@lit/],...e]}function tr(){let e=te("./dist"),t=nt("Cleaning dist folder...").start();try{return ro(e,{recursive:!0,force:!0}),t.succeed("All clean! Dist folder wiped."),!0}catch(r){return t.fail(`Oops! Couldn't clean dist/ folder: ${r.message}`),console.error(r),!1}}async function Ee(e,t,r,n){let o=nt(e).start();try{let s=await t();return o.succeed(r),s}catch(s){throw o.fail(n),console.error(`Error: ${s.message}`),s}}async function rr(e,t){return Ee(`Bundling ${e.name||"main"} and demo...`,async()=>{let r=await rt(e);await r.write(e.output),await r.close();for(let n of t){let o=await rt(n);await o.write(n.output),await o.close()}},`Bundles ready! ${e.name||"Main"} and demo built.`,"Bundle hiccup! Build failed.")}async function Pe(e){let{wcaInput:t,wcaOutput:r,skipDocs:n}=e;if(n){let o=nt("Skipping docs generation...").start();setTimeout(()=>{o.succeed("Docs generation skipped.")},0);return}return Ee("Analyzing components and making docs...",async()=>{await Ae(t,r),await Y(e),J()},"Docs ready! Looking good.","Doc troubles!")}function ao(){let e=process.cwd();function t(o){return[o,`${o}.scss`,`${o}.css`,te(so(o),`_${oo(o)}.scss`),te(o,"_index.scss"),te(o,"index.scss")].find(i=>Zt(i))}function r(o){for(let i of N){let a=t(Ie(e,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 N){let l=Ie(e,a,s,"package.json");if(Zt(l))try{let d=JSON.parse(to(l,"utf-8")).exports;if(!d||typeof d!="object")continue;let c=d[i];if(!c)continue;let p=typeof c=="string"?c:c.default||c.import;if(!p)continue;let m=t(Ie(e,a,s,p));if(m)return m}catch{continue}}return null}return{findFileUrl(o){if(o.includes("/node_modules/")){let s=o.lastIndexOf("/node_modules/"),i=o.slice(s+14),a=r(i);if(a)return Qt(a)}if(!o.startsWith(".")&&!o.startsWith("/")&&!o.startsWith("file:")){let s=r(o);if(s)return Qt(s)}return null}}}async function j(e="./demo"){return Ee("Compiling demo SCSS...",async()=>{let t=io.sync(te(e,"**/*.scss")),r=ao(),n=process.cwd(),o=N.map(s=>Ie(n,s));for(let s of t){let i=er.compile(s,{importers:[r],loadPaths:o,silenceDeprecations:["import"],style:"compressed"}),a=s.replace(/\.scss$/,".min.css");no(a,i.css)}return t.length},"Demo SCSS compiled.","SCSS compilation failed.")}async function Qe(e={}){let{configs:t}=ee(e);return Ee("Bundling demo JS...",async()=>{for(let r of t){let n=await rt(r);await n.write(r.output),await n.close()}},"Demo JS bundled.","Demo JS bundling failed.")}import nr from"node:path";import U from"ora";import"rollup";var re=!1,co={analyze:{active:!1,lastTime:0},docs:{active:!1,lastTime:0},scss:{active:!1,lastTime:0}},lo=5e3,Re=new Set,uo=["/dist/index.d.ts","/custom-elements.json","/demo/api.md","/docs/api.md","/demo/index.min.js"];function po(e){if(!e||typeof e!="string")return!1;try{let t=nr.normalize(e);return uo.some(r=>t.endsWith(r))||t.includes("/dist/")||t.endsWith(".min.js")||t.endsWith(".min.css")||t.endsWith(".d.ts")}catch(t){return console.error(`Error checking path (${typeof e}):`,t.message),!1}}async function ot(e,t){let r=co[e];if(r.active||Date.now()-r.lastTime<lo)return!1;try{return r.active=!0,r.lastTime=Date.now(),await t()}catch(n){return console.error(`Error in ${e} task:`,n),!1}finally{r.active=!1}}async function or(e,t,r){let n=!0,o={analyze:!1,docs:!1,scss:!1},s=null,i,a=U("Activating watch mode...").start(),l={analyze:async()=>{let{wcaInput:c,wcaOutput:p,skipDocs:m}=t;if(m){let h=U("Skipping component analysis...").start();return setTimeout(()=>{h.succeed("Component analysis skipped.")},0),!0}let g=U("Detective work: analyzing components...").start();try{return await Ae(c,p),g.succeed("Component analysis complete! API generated."),!0}catch(h){return g.fail("Analysis hiccup! Something went wrong."),console.error("Component analysis error:",h),!1}},docs:async()=>{if(re)return!1;if(t.skipDocs){let p=U("Skipping docs generation...").start();return setTimeout(()=>{p.succeed("Docs generation skipped.")},0),!0}let c=U("Refreshing docs...").start();try{return await Pe(t),c.succeed("Documentation refreshed!"),!0}catch(p){c.fail("Docs stumble! Couldn't refresh."),console.error("Documentation rebuild error:",p)}},scss:async()=>{if(re)return!1;try{return await j(),!0}catch(c){return console.error("Demo SCSS compilation error:",c),!1}}},u=()=>{n&&o.analyze&&o.docs&&o.scss&&typeof r=="function"&&(n=!1,r())};function d(c=1e3){s&&clearTimeout(s),s=setTimeout(async()=>{setTimeout(async()=>{o.analyze=await ot("analyze",l.analyze),setTimeout(async()=>{o.docs=await ot("docs",l.docs),setTimeout(async()=>{o.scss=await ot("scss",l.scss),u()},500)},1e3)},1e3)},c)}e.on("event",async c=>{switch(c.code){case"START":a.succeed("Watch mode active! Eyes peeled.");break;case"BUNDLE_START":if(Re.clear(),c.input)try{let p=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 m of p)typeof m=="string"&&!po(m)&&Re.add(nr.normalize(m))}catch(p){console.error("Error processing input paths:",p)}i=U("Weaving bundles...").start(),re=!0;break;case"BUNDLE_END":i&&i.succeed(`Bundle ${Array.isArray(c.input)?`of ${c.input.join("& ")} `:""}done in ${c.duration}ms! \u{1F680}`),re=!1,Re.size>0&&d();break;case"END":break;case"ERROR":re=!1,i?i.fail(`Oops! Bundle hit a snag: ${c.error.message}`):U().fail(`Watch mode hiccup: ${c.error.message}`),Re.clear();break}})}function sr(e,t){return K(e),t&&K(t),be(),e}async function fo(e){let t=tt(e),r=ee(e);e.dev||t.config.plugins.push(mo()),await Pe(e),await j(),await rr(t.config,r.configs)}async function ho(e){let{dev:t}=e,r=tt({...e,watch:!0}),n=ee({...e,watch:!0}),o=go([r.config,...n.configs]);or(o,e,t?async()=>$e(e):void 0);let s=await import("chokidar"),i=!1,a=!1,l=null,u=s.watch("./demo/**/*.scss",{ignoreInitial:!0,ignored:["**/demo/**/*.min.css"],awaitWriteFinish:{stabilityThreshold:500,pollInterval:100}});return u.on("all",()=>{l&&clearTimeout(l),l=setTimeout(async()=>{if(i){a=!0;return}i=!0;try{await j()}catch(d){console.error("Demo SCSS watch compilation error:",d)}finally{i=!1,a&&(a=!1,u.emit("all"))}},500)}),sr(o,u),o}async function xe(e={}){try{let{watch:t}=e;return tr(),t?await ho(e):await fo(e)}catch(t){throw new Error(`Build failed: ${t.message}`)}}var ne=yo.command("dev").description("Runs development server for auro components");ne=he(ne);ne=ye(ne);var yc=ne.action(async e=>{try{let t=ir("Initializing...");e.watch?(t.text="Waiting for changes...",t.spinner="bouncingBar",t.color="green"):t.text=e.docs===!1?"Building component (docs disabled)":"Building component",t.start(),e.watch||t.succeed("Build completed!"),await xe({...e,dev:!0,watch:e.watch})}catch(t){ir().fail(`Build failed: ${t.message}`),console.error(t),process.exit(1)}});import{program as wo}from"commander";import ar from"ora";var st=wo.command("build").description("Builds auro components");st=he(st);var Sc=st.action(async e=>{try{let t=ar("Initializing...");e.watch?(t.text="Waiting for changes...",t.spinner="bouncingBar",t.color="green"):t.text=e.docs===!1?"Building component (docs disabled)":"Building component",t.start(),await xe(e),e.watch||t.succeed("Build completed!")}catch(t){ar().fail(`Build failed: ${t.message}`),console.error(t),process.exit(1)}});import{exec as bo}from"node:child_process";import cr from"node:path";import ko from"node:process";import{fileURLToPath as $o}from"node:url";import vo from"node:util";import{program as So}from"commander";import Co from"inquirer";var Oc=So.command("migrate").description("Script runner to perform repetitive code change tasks").requiredOption("-i, --id <string>","Select the migration you would like to run by id").option("-m, --multi-gitter","Run the migration on all repositories in the multi-gitter config").action(async e=>{let t=$o(import.meta.url),r=cr.dirname(t),n=cr.resolve(r,"migrations",e.id);if(e.multiGitter){let o=vo.promisify(bo);try{await o("command -v multi-gitter")}catch{console.error("multi-gitter is not installed."),ko.exit(1)}(await Co.prompt([{type:"confirm",name:"dryRun",message:"Run migration in dry-run mode? (no changes will be committed)",default:!0}])).dryRun?R(`multi-gitter run ${n}/script.sh --config "${n}/multi-gitter.yml" --dry-run`):R(`multi-gitter run ${n}/script.sh --config "${n}/multi-gitter.yml"`)}else R(`${n}/script.sh`)});import{readFile as Ro,writeFile as xo}from"node:fs/promises";import mr from"node:process";import{Logger as oe}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import{program as To}from"commander";import it from"node:fs/promises";import at from"node:path";import{processContentForFile as Ao,templateFiller as Io}from"@aurodesignsystem/auro-library/scripts/utils/sharedFileProcessorUtils.mjs";import{Octokit as Eo}from"@octokit/rest";import x from"ora";async function lr(e,t){let r=new Eo({auth:process.env.GITHUB_TOKEN||""});try{let o=(await r.request("GET /repos/{owner}/{repo}/contents/{path}",{ref:t,owner:"AlaskaAirlines",repo:"auro-templates",path:e,headers:{"X-GitHub-Api-Version":"2022-11-28"}})).data;if(typeof o!="object"||!Array.isArray(o)){let s=`Unexpected response format: ${JSON.stringify(o)}`;throw x().start().fail(s),new Error("Failed to retrieve folder items")}return o}catch(n){let o=x().start();throw n.status===404?o.fail(`Template '${e.split("/")[1]}' not found`):o.fail(`Error accessing template: ${n.message}`),n}}async function ur({folderItems:e,templatePathToReplace:t,rootDir:r,ref:n}){let o=[];for(let s of e){if(s.type=="dir"){let u=x(`Processing directory: ${s.path}`).start(),d=await lr(s.path,n);u.succeed(`Found ${d.length} additional items in ${s.path}`);let c=await ur({folderItems:d,templatePathToReplace:t,rootDir:r,ref:n});o.push(...c);continue}let i=s.path.replace(`${t}/`,""),a=`${r}/.github/${i}`,l={identifier:s.name,input:{remoteUrl:s.download_url||"",fileName:a,overwrite:!0},output:a};o.push(l)}return o}async function Po(e){try{await it.rm(e,{recursive:!0,force:!0}),x().start().succeed(`Successfully removed directory: ${e}`)}catch(t){throw x().start().fail(`Error removing directory ${e}: ${t.message}`),t}}async function dr(e,t="",r=!0){try{let n=await it.stat(e),o=at.basename(e);if(!n.isDirectory())return`${t}${r?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 "}${o}
26
+ `;let s=`${t}${r?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 "}${o}/
27
+ `;try{let a=(await it.readdir(e)).sort();for(let l=0;l<a.length;l++){let u=a[l],d=at.join(e,u),c=l===a.length-1,p=t+(r?" ":"\u2502 ");s+=await dr(d,p,c)}}catch{s+=`${t}${r?" ":"\u2502 "}\u2514\u2500\u2500 [Permission denied or error reading directory]
28
+ `}return s}catch(n){return`${t}${r?"\u2514\u2500\u2500 ":"\u251C\u2500\u2500 "}[Error: ${n}]
29
+ `}}async function pr(e,t="main",r="default"){if(!e)throw x().start().fail("Root directory must be specified"),new Error("Root directory must be specified");if(await Io.extractNames(),!process.env.GITHUB_TOKEN)throw x().start().fail("GITHUB_TOKEN environment variable is not set."),new Error("GITHUB_TOKEN environment variable is not set");let n=`templates/${r}/.github`,o=await lr(n,t),s=".github",i=x("Removing existing .github directory...").start();try{await Po(s),i.succeed(".github directory removed successfully")}catch(u){throw i.fail(`Error removing .github directory: ${u.message}`),new Error(`Failed to remove .github directory: ${u.message}`)}let a=await ur({folderItems:o,templatePathToReplace:n,rootDir:e,ref:t}),l=x("Processing all files...").start();try{await Promise.all(a.map(d=>Ao(d))),l.succeed("All files processed.");let u=x("Generating directory tree...").start();try{let d=at.join(e,".github"),c=await dr(d);u.succeed("Synced .github directory structure:"),console.log(c)}catch(d){u.fail(`Error generating directory tree: ${d.message}`)}}catch(u){throw l.fail(`Error processing files: ${u.message}`),new Error(`Failed to process files: ${u.message}`)}}var zc=To.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 e=>{oe.info("Synchronizing repository configuration files..."),oe.warn("Note: sync does not create a new git branch. Changes are added to the current branch.");let t=mr.cwd();try{await pr(t,e.ref,e.template);try{let r=`${t}/.github/CODEOWNERS`,o=(await Ro(r,{encoding:"utf-8"})).replace(/\r\n/gu,`
30
30
  `).replace(/\n\n/gu,`
31
- `);await on(e,o,{encoding:"utf-8"}),(o.includes("\r")||o.includes(`
31
+ `);await xo(r,o,{encoding:"utf-8"}),(o.includes("\r")||o.includes(`
32
32
 
33
- `))&&W.error("CODEOWNERS file still has Windows line endings.")}catch(e){throw W.error(`Error processing CODEOWNERS file: ${e.message}`),e}}catch(e){W.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 sn}from"commander";import{glob as an}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
+ `))&&oe.error("CODEOWNERS file still has Windows line endings.")}catch(r){throw oe.error(`Error processing CODEOWNERS file: ${r.message}`),r}}catch(r){oe.error(`Sync operation failed: ${r.message}`),mr.exit(1)}});import Te from"node:fs";import se from"node:path";import{Logger as fr}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import{program as Do}from"commander";import{glob as Oo}from"glob";var gr=(e,t)=>{let r=(e.match(/static register\(name = (.+)\)/)||e.match(/customElements.get\((.+?)\)/))[1],n=e.match(/export class (.+) extends/)?.[1],o=e.match(/\/\*\*((.|\n)*?)(\*\n|\*\/|[@])/)?.[1]||"";return!r||!n?e:`
34
34
  import { ${n} } from '${t}';
35
35
 
36
36
  /**${o}*/
37
37
  class ${n}WCA extends ${n} {}
38
38
 
39
- if (!customElements.get(${e})) {
40
- customElements.define(${e}, ${n}WCA);
39
+ if (!customElements.get(${r})) {
40
+ customElements.define(${r}, ${n}WCA);
41
41
  }
42
- `};var pe=z.resolve(process.cwd(),"./scripts/wca");async function cn(r){try{return(await Promise.all(r.map(e=>an(e)))).flat()}catch(t){throw console.error("Error processing glob patterns:",t),t}}async function ln(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 un(){let r=await cn(["./src/auro-*.js"]);await ln(r)}var bi=sn.command("wca-setup").description("Set up WCA (Web Component Analyzer) for the project").action(()=>{un().then(()=>{Rt.success("WCA setup completed successfully.")}).catch(r=>{Rt.error(`WCA setup failed: ${r.message}`)})});import{program as wn}from"commander";import xt from"chalk";import Ot from"ora";import{appendFile as mn,readFile as dn}from"node:fs/promises";import{Logger as h}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import{simpleGit as pn}from"simple-git";var y;try{y=pn({baseDir:process.cwd(),binary:"git",maxConcurrentProcesses:1})}catch(r){h.error(`Failed to initialize git: ${r}`),y={}}var S=class r{static async checkGitignore(t){if(t==="")return!1;try{return(await dn(".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 De=se.resolve(process.cwd(),"./scripts/wca");async function No(e){try{return(await Promise.all(e.map(r=>Oo(r)))).flat()}catch(t){throw console.error("Error processing glob patterns:",t),t}}async function jo(e){Te.existsSync(De)||await Te.promises.mkdir(De,{recursive:!0});for(let t of e){let r=se.resolve(process.cwd(),t),n=await Te.promises.readFile(r,"utf-8"),o=se.resolve(De,`${se.basename(t)}`),s=gr(n,se.relative(De,t));await Te.promises.writeFile(o,s)}}async function _o(){let e=await No(["./src/auro-*.js"]);await jo(e)}var tl=Do.command("wca-setup").description("Set up WCA (Web Component Analyzer) for the project").action(()=>{_o().then(()=>{fr.success("WCA setup completed successfully.")}).catch(e=>{fr.error(`WCA setup failed: ${e.message}`)})});import{program as Wo}from"commander";import br from"chalk";import kr from"ora";import{appendFile as Bo,readFile as Fo}from"node:fs/promises";import{Logger as k}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import{simpleGit as Uo}from"simple-git";var $;try{$=Uo({baseDir:process.cwd(),binary:"git",maxConcurrentProcesses:1})}catch(e){k.error(`Failed to initialize git: ${e}`),$={}}var _=class e{static async checkGitignore(t){if(t==="")return!1;try{return(await Fo(".gitignore","utf-8")).includes(t)}catch(r){return k.error(`Error reading file: ${r}`),!1}}static async getCommitMessages(t=""){try{let r=t;r||(r=(await $.branchLocal()).current);let n="main",o="";if(!!process.env.GITHUB_ACTIONS){n=process.env.GITHUB_BASE_REF||"main";try{if(await $.fetch("origin",n),r!=="HEAD")try{await $.raw(["rev-parse","--verify",`origin/${r}`])}catch{await $.fetch("origin",r)}let i=r==="HEAD"?"HEAD":`origin/${r}`;o=`${(await $.raw(["merge-base",`origin/${n}`,i])).trim()}..${i}`}catch(i){k.warn(`Error setting up commit range in CI: ${i}`);let a=r==="HEAD"?"HEAD":`origin/${r}`;o=`origin/${n}..${a}`}}else try{try{await $.raw(["rev-parse","--verify",`origin/${n}`])}catch{k.info(`Fetching ${n} from origin`),await $.fetch("origin",n)}if(r!=="HEAD")try{await $.raw(["rev-parse","--verify",r])}catch{await $.fetch("origin",r)}o=`${(await $.raw(["merge-base",`origin/${n}`,r])).trim()}..${r}`}catch(i){k.warn(`Error determining commits locally: ${i}`),o=`${r}~10..${r}`}return await e.getFormattedCommits(o)}catch(r){return k.error(`Error getting commit messages: ${r}`),[]}}static async getRepoOwnerAndName(){try{let t=await $.getRemotes(!0);if(t.length===0)return k.warn("No remotes found"),null;let r=t.find(o=>o.name==="origin")||t[0],n=r.refs.fetch||r.refs.push;return e.parseGitUrl(n)}catch(t){return k.error(`Error getting repo owner and name: ${t}`),null}}static async getCurrentBranchName(){try{return(await $.branchLocal()).current||null}catch(t){return k.error(`Error getting current branch name: ${t}`),null}}static parseGitUrl(t){let r;return t.includes("@")&&t.includes(":")&&(r=t.match(/@([^:]+):([^/]+)\/(.+?)(?:\.git)?$/),r)?{owner:r[2],repo:r[3]}:(r=t.match(/https?:\/\/(?:[^@]+@)?[^/]+\/([^/]+)\/(.+?)(?:\.git)?$/),r?{owner:r[1],repo:r[2]}:(k.warn(`Could not parse git URL: ${t}`),null))}static async getFormattedCommits(t){let n=(await $.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],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?`
44
+ `);if(i.length>=4){let a=i[0],l=i[1],u=i[2],d=i[3],c=i.slice(4).filter(w=>w!=="COMMIT_END"),p=c.length>0?c.join(""):"",m=a.substring(0,7),g=d.match(/^(feat|fix|docs|style|refactor|perf|test|build|ci|chore)(\(.+\))?:/),h=g?g[1]:"unknown";p.includes("BREAKING CHANGE")&&(h="breaking"),o.push({type:h,hash:m,date:l,subject:d,body:p,message:`${d}${p?`
45
45
 
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 mn(".gitignore",`
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 fn=60,gn=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
- `,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,fn),n=St(t.body,gn);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*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 hn=["feat","fix","breaking","perf"];function je(r,t=!0){let e=`### In this release
50
- `;for(let n of r)if(e+=`- ${n.hash} ${n.subject}
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=>hn.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
- `),n}async function Nt(r=!1,t=!1,e=!1){let n=Ot(`Checking commits...
53
- `).start();try{let o=await S.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
46
+ ${p}`:""}`,author_name:u})}}return o}static async addToGitignore(t,r=!0){await e.checkGitignore(t).then(async n=>{if(n)k.warn(`${t} already exists`);else try{await Bo(".gitignore",`
47
+ ${t}`),r&&k.success(`${t} added to .gitignore`)}catch(o){k.error(o)}})}static async removeFromGitCache(t){try{await $.rmKeepLocal(t),k.success(`${t.join(", ")} are removed from git cache`)}catch(r){k.error(r)}}static async createBranch(t){try{await $.checkoutLocalBranch(t),k.success(`Created and switched to ${t} branch`)}catch(r){k.error(r)}}static async commitStagedFiles(t){try{await $.add("."),await $.commit(t),k.success(`Committed with message: ${t}`)}catch(r){k.error(r)}}};import A from"chalk";var Mo=60,Lo=100;function ie(e){switch(e){case"breaking":return A.bold.red(e);case"feat":return A.bold.green(e);case"fix":return A.bold.green(e);case"perf":return A.bold.green(e);case"docs":return A.bold.cyan(e);case"style":return A.bold.cyan(e);case"refactor":return A.bold.cyan(e);case"test":return A.bold.cyan(e);case"build":return A.bold.cyan(e);case"ci":return A.bold.cyan(e);case"chore":return A.bold.cyan(e);default:return A.bold.white(e)}}function hr(e,t){if(!e)return"";if(e.length<=t)return e;let r=e.split(" "),n="",o="";for(let s of r)(o+s).length>t&&o.length>0&&(n+=`${o.trim()}
48
+ `,o=""),o=`${o}${s} `;return o.length>0&&(n+=o.trim()),n}function yr(e){for(let t of e){console.log("\u2500".repeat(60));let r=hr(t.subject,Mo),n=hr(t.body,Lo);console.log(A.bold(`${ie(t.type)}`)),console.log(A.dim(`${t.hash} | ${t.date} | ${t.author_name}`)),console.log(A.bold(`${A.white(r)}`)),t.body&&console.log(A.dim(n))}console.log("\u2500".repeat(60)),console.log(`
49
+ `)}import*as ae from"@actions/github";async function ct(){try{let e=process.env.GITHUB_TOKEN;if(!e)throw new Error("GITHUB_TOKEN environment variable is not set");if(!process.env.GITHUB_REPOSITORY||!process.env.GITHUB_EVENT_PATH)throw new Error("This function can only be used in a GitHub Actions environment");let t=ae.getOctokit(e),{context:r}=ae;if(!r.payload.pull_request)throw new Error("No pull request found in the GitHub context");let[n,o]=process.env.GITHUB_REPOSITORY.split("/"),s=r.payload.pull_request.number,{data:i}=await t.rest.issues.listLabelsOnIssue({owner:n,repo:o,issue_number:s});return i.map(a=>a.name)}catch(e){throw e instanceof Error?new Error(`Failed to get existing labels: ${e.message}`):e}}async function wr(e){try{let t=process.env.GITHUB_TOKEN;if(!t)throw new Error("GITHUB_TOKEN environment variable is not set");if(!process.env.GITHUB_REPOSITORY||!process.env.GITHUB_EVENT_PATH)throw new Error("This function can only be used in a GitHub Actions environment");let r=ae.getOctokit(t),{context:n}=ae;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: ${e}`,l=await ct();if(l.includes(a))return;let u=l.filter(d=>d.startsWith("semantic-status:")&&d!==a);for(let d of u)await r.rest.issues.removeLabel({owner:o,repo:s,issue_number:i,name:d});await r.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 Go=["feat","fix","breaking","perf"];function lt(e,t=!0){let r=`### In this release
50
+ `;for(let n of e)if(r+=`- ${n.hash} ${n.subject}
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"),r+=` - ${a}`}}return e.length===0?"":(t&&console.log(br.green(`\u2713 Generating release notes for ${e.length} commits`)),r)}function ut(e,t=!0){let r=e.filter(o=>Go.includes(o.type)),n;return t?n=r.length>0?r:e:n=r,n.length===0&&console.log(`No commits found to include in release notes.
52
+ `),n}async function $r(e=!1,t=!1,r=!1){let n=kr(`Checking commits...
53
+ `).start();try{let o=await _.getCommitMessages();if(r){n.succeed(`Total commits analyzed: ${o.length}`);let s=ut(o);console.log(lt(s));return}if(e&&yr(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=>ie(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 yn(o,n)}catch(o){n.fail("Error getting commit messages"),console.error(o)}}async function yn(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 _i=wn.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 P from"chalk";import{program as bn}from"commander";import kn from"ora";var Hi=bn.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 $n(r)}),$n=async r=>{let{namespace:t,prNumber:e}=r,n=kn("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 En(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 ${P.green(u)} and ${P.green(l)}`),process.exit(0)}catch(o){n.fail(`Failed to update package.json: ${o}`),process.exit(1)}},En=(r,t,e)=>new Promise(n=>{try{let a=function(l){if(l.statusCode!==200){e.info(`Package not found. Status code: ${P.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 ${P.green(`${r}.${d}`)}. Incrementing to ${P.green(`${r}.${d+1}`)}`):e.info(`No existing version found for ${P.green(r)}. Starting with ${P.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 An}from"node:url";import{program as vn}from"commander";import Tn from"open";var Cn=An(import.meta.url),In=Fe.resolve(Fe.dirname(Cn),".."),Yi=vn.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(In,"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 Tn(n)});import Le from"node:fs/promises";import Gt from"node:path";import{program as Nn}from"commander";import jn from"inquirer";import Ue from"ora";import Rn from"node:fs/promises";import Sn from"node:path";import Dn from"ora";var Pn={"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 xn(r){return Object.entries(r).map(([t,e])=>Array.isArray(e)?`${t}:
57
- - ${e.join(`
58
- - `)}`:typeof e=="object"&&e!==null?`${t}:
59
- ${Object.entries(e).map(([n,o])=>` ${n}: ${o}`).join(`
60
- `)}`:`${t}: ${e}`).join(`
61
- `)}async function Ft(r){let t=Dn("Writing multi-gitter configuration...").start(),e=xn(Pn),n=Sn.join(r,"multi-gitter_DEPENDENCY_TREE.yml");try{await Rn.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 Me from"node:fs";function Mt(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 On(r){return Me.readdirSync(r).filter(t=>t.endsWith(".json"))}async function Bt(r,t=[]){console.log(t);let e={},n=On(r);for(let o of n){if(o==="dependencyTree.json")continue;let s=Me.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 Me.writeFileSync(`${r}/dependencyTree.json`,JSON.stringify(e,null,2)),e}var Be=be("run-migrations","config"),Ge=be("run-migrations","outputs");var Lt=["@aurodesignsystem/auro-accordion","@aurodesignsystem/auro-alert","@aurodesignsystem/auro-avatar","@aurodesignsystem/auro-background","@aurodesignsystem/auro-backtotop","@aurodesignsystem/auro-button","@aurodesignsystem/auro-badge","@aurodesignsystem/auro-banner","@aurodesignsystem/auro-card","@aurodesignsystem/auro-carousel","@aurodesignsystem/auro-datetime","@aurodesignsystem/auro-dialog","@aurodesignsystem/auro-drawer","@aurodesignsystem/auro-formkit","@aurodesignsystem/auro-flight","@aurodesignsystem/auro-flightline","@aurodesignsystem/auro-header","@aurodesignsystem/auro-hyperlink","@aurodesignsystem/auro-icon","@aurodesignsystem/auro-loader","@aurodesignsystem/auro-lockup","@aurodesignsystem/auro-nav","@aurodesignsystem/auro-pane","@aurodesignsystem/auro-popover","@aurodesignsystem/auro-sidenav","@aurodesignsystem/auro-skeleton","@aurodesignsystem/auro-slideshow","@aurodesignsystem/auro-table","@aurodesignsystem/auro-tabs","@aurodesignsystem/auro-toast"],pa=[...Lt,"@aurodesignsystem/auro-library","@aurodesignsystem/WebCoreStyleSheets","@aurodesignsystem/AuroDesignTokens","@aurodesignsystem/auro-cli","@alaskaairux/icons"];async function _n(r){try{await Le.mkdir(Ge,{recursive:!0}),await Le.mkdir(Be,{recursive:!0})}catch(o){console.error("Failed to create output or config directories:",o),process.exit(1)}let t=Ue("Creating dependency tree...").start();t.text="Creating multi-gitter dependency tree configuration...",await Ft(Be),t.text="Scraping dependencies from Auro packages...";let n=`multi-gitter run "node ${ke("static","getAuroDeps.js")}" --config ${Gt.join(Be,"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 Bt(Ge,r),t.succeed("Dependency tree generated successfully."),Gt.join(Ge,"dependencyTree.json")}var Fn=async r=>{let t=Ue("Loading dependency tree...").start(),e=JSON.parse(await Le.readFile(r,"utf-8"));t.text="Processing dependency tree...";let n=Mt(e);return t.succeed("Dependency batches created successfully."),n},fa=Nn.command("agent").action(async r=>{let t=await jn.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:Lt.map(e=>({name:e.replace("@aurodesignsystem/",""),value:e})),when:e=>e.agentAction==="run-migration"&&e.useExisting}]);switch(t.agentAction){case"run-migration":{let e=Ue("Running migration...").start(),n=await _n(t.startWithComponents);e.text="Getting dependency batches from tree...";let s=(await Fn(n)).map((i,a)=>`Batch ${a+1}
55
+ make sure to commit some changes before running this command.`);t&&await Ho(o,n)}catch(o){n.fail("Error getting commit messages"),console.error(o)}}async function Ho(e,t){let r=["breaking","feat","fix","perf","docs","style","refactor","test","build","ci","chore"],n=e.map(i=>i.type).filter(i=>r.includes(i)),o=null,s=Number.POSITIVE_INFINITY;for(let i of n){let a=r.indexOf(i);a<s&&(s=a,o=i)}if(o){let i=kr("Checking existing labels on pull request...").start();try{if((await ct()).includes(`semantic-status: ${o}`)){i.info(`Label "semantic-status: ${ie(o)}" already exists on the pull request.`);return}i.text="Applying label to pull request...",await wr(o),i.succeed(`Label "semantic-status: ${ie(o)}" applied to the pull request.`)}catch(a){let l=a instanceof Error?a.message:String(a);i.fail(l)}}else t.warn(br.yellow("No semantic commit type found to apply as label."))}var wl=Wo.command("check-commits").alias("cc").option("-l, --set-label","Set label on the pull request based on the commit message type").option("-d, --debug","Display detailed commit information for debugging").option("-r, --release-notes","Generate release notes based on commit messages").description("Check commits in the local repository for the types of semantic commit messages made and return the results.").action(async e=>{await $r(e.debug,e.setLabel,e.releaseNotes)});import vr from"node:fs";import{get as Sr}from"node:https";import M from"chalk";import{program as Vo}from"commander";import zo from"ora";var Al=Vo.command("pr-release").option("-n, --namespace <package-namespace>","Set namespace of the package release","@aurodesignsystem-dev").option("-p, --pr-number <number>","Set pull request number for the release","0").description("Generate the package version based off of PR number then update the package.json file. Note: this does not publish the package.").action(async e=>{await qo(e)}),qo=async e=>{let{namespace:t,prNumber:r}=e,n=zo("Updating package.json").start();try{let o="package.json",s=JSON.parse(vr.readFileSync(o,"utf8"));n.text="Checking npm registry for version information...";let i=`0.0.0-pr${r}`,a=s.name.split("/")[1],l=`${t}/${a}`,u=await Jo(i,l,n),d=`${i}.${u}`;s.name=l,s.version=d,n.text="Writing updated package.json...",vr.writeFileSync(o,`${JSON.stringify(s,null,2)}
56
+ `,"utf8"),n.succeed(`Package.json updated to use ${M.green(d)} and ${M.green(l)}`),process.exit(0)}catch(o){n.fail(`Failed to update package.json: ${o}`),process.exit(1)}},Jo=(e,t,r)=>new Promise(n=>{try{let a=function(l){if(l.statusCode!==200){r.info(`Package not found. Status code: ${M.red(l.statusCode)}, defaulting to version 0`),n(0);return}r.text="Processing version information...";let u="";l.on("data",d=>{u+=d}),l.on("end",()=>{try{let d=JSON.parse(u),c=d.versions?Object.keys(d.versions):[];r.text="Calculating next version number...";let p=-1,m=new RegExp(`^${e}\\.(\\d+)$`);for(let g of c){let h=g.match(m);if(h){let w=Number.parseInt(h[1],10);p=Math.max(p,w)}}p>=0?r.info(`Found existing version ${M.green(`${e}.${p}`)}. Incrementing to ${M.green(`${e}.${p+1}`)}`):r.info(`No existing version found for ${M.green(e)}. Starting with ${M.green(`${e}.0`)}`),n(p+1)}catch(d){r.warn(`Failed to parse NPM registry response: ${d instanceof Error?d.message:"Unknown error"}, defaulting to version 0`),n(0)}})};var o=a;let s=`https://registry.npmjs.org/${t}`,i=Sr(s,{headers:{Accept:"application/json"}},l=>{if((l.statusCode===301||l.statusCode===302)&&l.headers.location){r.info(`Following redirect to ${l.headers.location}...`);try{Sr(l.headers.location,{headers:{Accept:"application/json"}},a).on("error",u=>{r.warn(`Error following redirect: ${u.message}, defaulting to version 0`),n(0)}).end()}catch(u){r.warn(`Redirect request failed: ${u instanceof Error?u.message:"Unknown error"}, defaulting to version 0`),n(0)}return}a(l)});i.on("error",l=>{r.warn(`Request error: ${l.message}, defaulting to version 0`),n(0)}),i.end()}catch{r.warn("Error checking version in npm registry, defaulting to version 0"),n(0)}});import dt from"node:path";import{fileURLToPath as Ko}from"node:url";import{program as Yo}from"commander";import Xo from"open";var Zo=Ko(import.meta.url),Qo=dt.resolve(dt.dirname(Zo),".."),Dl=Yo.command("test").option("-w, --watch","Set watch number for the test").option("-c, --coverage-report","Generate coverage report").option("-o, --open","Open the coverage report in the browser").option("-f, --files <String|String[]>","Test files glob pattern").description("Run the web test runner to test the component library").action(async e=>{let r=`npx wtr --config "${dt.join(Qo,"dist","configs","web-test-runner.config.mjs")}"`,n=`${process.cwd()}/coverage/index.html`;if(e.coverageReport&&(r+=" --coverage"),e.watch&&(r+=" --watch"),e.files){let o=Array.isArray(e.files)?e.files.join(" "):e.files;r+=` --files "${o}"`}R(r),e.open&&await Xo(n)});import ft from"node:fs/promises";import Er from"node:path";import{program as is}from"commander";import as from"inquirer";import ht from"ora";import es from"node:fs/promises";import ts from"node:path";import rs from"ora";var ns={"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 os(e){return Object.entries(e).map(([t,r])=>Array.isArray(r)?`${t}:
57
+ - ${r.join(`
58
+ - `)}`:typeof r=="object"&&r!==null?`${t}:
59
+ ${Object.entries(r).map(([n,o])=>` ${n}: ${o}`).join(`
60
+ `)}`:`${t}: ${r}`).join(`
61
+ `)}async function Cr(e){let t=rs("Writing multi-gitter configuration...").start(),r=os(ns),n=ts.join(e,"multi-gitter_DEPENDENCY_TREE.yml");try{await es.writeFile(n,r,"utf8"),t.succeed(`Multi-gitter configuration written to ${n}`)}catch(o){t.fail("Error writing multi-gitter configuration:"),console.error(o)}}import pt from"node:fs";function Ar(e){let t={},r=[],n=[],o=[];for(let s in e)t[s]=e[s].dependsOn.length;for(let s in t)t[s]===0&&o.push(s);for(;o.length>0;){n=[];let s=o.length;for(let i=0;i<s;i++){let a=o.shift();n.push(a);for(let l of e[a].dependentPackages)t[l]--,t[l]===0&&o.push(l)}r.push(n)}if(r.flat().length!==Object.keys(e).length)throw new Error("Circular dependency detected!");return r}function ss(e){return pt.readdirSync(e).filter(t=>t.endsWith(".json"))}async function Ir(e,t=[]){console.log(t);let r={},n=ss(e);for(let o of n){if(o==="dependencyTree.json")continue;let s=pt.readFileSync(`${e}/${o}`,"utf-8"),i=JSON.parse(s),a=i.name,l=Object.keys(i.peerDependencies),u=Object.keys(i.devDependencies),d=Object.keys(i.dependencies);r[a]||(r[a]={dependsOn:[],dependentPackages:[]});let c=[...l,...u,...d];r[a].dependsOn=[...new Set(c)];for(let p of c)r[p]||(r[p]={dependsOn:[],dependentPackages:[]}),r[p].dependentPackages.includes(a)||r[p].dependentPackages.push(a)}if(t.length){let o=new Set;for(let[i,a]of Object.entries(r))a.dependsOn.some(l=>t.includes(l))&&o.add(i);for(let i of t)r[i]&&o.add(i);let s={};for(let i of o)s[i]={dependsOn:r[i].dependsOn.filter(a=>o.has(a)),dependentPackages:r[i].dependentPackages.filter(a=>o.has(a))};r=s}else console.log("No target dependencies provided - using all packages.");return pt.writeFileSync(`${e}/dependencyTree.json`,JSON.stringify(r,null,2)),r}var mt=qe("run-migrations","config"),gt=qe("run-migrations","outputs");var Pr=["@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"],Kl=[...Pr,"@aurodesignsystem/auro-library","@aurodesignsystem/WebCoreStyleSheets","@aurodesignsystem/AuroDesignTokens","@aurodesignsystem/auro-cli","@alaskaairux/icons"];async function cs(e){try{await ft.mkdir(gt,{recursive:!0}),await ft.mkdir(mt,{recursive:!0})}catch(o){console.error("Failed to create output or config directories:",o),process.exit(1)}let t=ht("Creating dependency tree...").start();t.text="Creating multi-gitter dependency tree configuration...",await Cr(mt),t.text="Scraping dependencies from Auro packages...";let n=`multi-gitter run "node ${Je("static","getAuroDeps.js")}" --config ${Er.join(mt,"multi-gitter_DEPENDENCY_TREE.yml")}`;try{await R(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 Ir(gt,e),t.succeed("Dependency tree generated successfully."),Er.join(gt,"dependencyTree.json")}var ls=async e=>{let t=ht("Loading dependency tree...").start(),r=JSON.parse(await ft.readFile(e,"utf-8"));t.text="Processing dependency tree...";let n=Ar(r);return t.succeed("Dependency batches created successfully."),n},Yl=is.command("agent").action(async e=>{let t=await as.prompt([{type:"select",name:"agentAction",message:"What agent action do you want to perform?",choices:[{name:"Run a migration on auro components",value:"run-migration"}],default:["run-migration"]},{type:"input",name:"migrationId",message:"What migration id do you want to run?",when:r=>r.agentAction==="run-migration",validate:r=>r.trim()!==""||"Migration id cannot be empty."},{type:"confirm",name:"useExisting",message:"Would you like to specify starting packages?",default:!0,transformer:r=>r?"Yes = Packages related to selections":"No = All packages",when:r=>r.agentAction==="run-migration"},{type:"checkbox",name:"startWithComponents",message:"Enter the components to start with (comma-separated, blank for all):",choices:Pr.map(r=>({name:r.replace("@aurodesignsystem/",""),value:r})),when:r=>r.agentAction==="run-migration"&&r.useExisting}]);switch(t.agentAction){case"run-migration":{let r=ht("Running migration...").start(),n=await cs(t.startWithComponents);r.text="Getting dependency batches from tree...";let s=(await ls(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 Mn}from"commander";var He=Mn.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);He=Z(He);var ba=He.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 Hn}from"commander";import{Octokit as We}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 We({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}`)}},Gn=async r=>{let t=process.env.GH_TOKEN;if(!t)return null;let e=new We({auth:t});try{let n=`
65
+ `);console.log(s),r.text="Running migrations on dependency batches...",new Promise(i=>setTimeout(i,2e3)),r.succeed("Migration process completed successfully.");break}default:console.error("Unknown action selected.")}});import{program as us}from"commander";var yt=us.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);yt=ye(yt);var tu=yt.action(async e=>{e.cem&&await Se(),e.api&&await Ce(),await Vt(e),e.serve&&await zt(e),e.watch&&await qt(e)});import{program as hs}from"commander";import{Octokit as wt}from"@octokit/rest";import*as Ne from"azure-devops-node-api";import Oe from"ora";var ds=async e=>{let t=process.env.GH_TOKEN;if(!t)throw new Error("GH_TOKEN environment variable is required");let r=new wt({auth:t}),n,o,s;if(e.includes("github.com")){let a=e.match(/github\.com\/([^/]+)\/([^/]+)\/issues\/(\d+)/);if(!a)throw new Error("Invalid GitHub issue URL format");[,n,o,s]=a}else if(e.includes("#")){let a=e.match(/([^/]+)\/([^#]+)#(\d+)/);if(!a)throw new Error("Invalid GitHub issue reference format");[,n,o,s]=a}else throw new Error("Issue must be provided as full URL or in format 'owner/repo#number'");let i=Number.parseInt(s,10);try{let{data:a}=await r.rest.issues.get({owner:n,repo:o,issue_number:i});return{title:a.title,body:a.body??null,html_url:a.html_url,number:a.number,repository:{owner:{login:n},name:o}}}catch(a){throw new Error(`Failed to fetch GitHub issue: ${a}`)}},ps=async e=>{let t=process.env.GH_TOKEN;if(!t)return null;let r=new wt({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) {
@@ -88,7 +88,7 @@ ${i.map(l=>` - ${l.replace("@aurodesignsystem","AlaskaAirlines").replace("@alas
88
88
  }
89
89
  }
90
90
  }
91
- `,o={owner:r.repository.owner.login,repo:r.repository.name,issueNumber:r.number},i=(await e.graphql(n,o)).repository.issue.projectItems.nodes.find(a=>a.project.number===19);if(i){let a=i.fieldValues.nodes.find(l=>l.field?.name?.toLowerCase()==="ado"&&l.text?.trim());if(a?.text?.trim())return a.text.trim()}return null}catch(n){return console.error(`Failed to check existing ADO link: ${n}`),null}},Ln=async(r,t)=>{let e=process.env.GH_TOKEN;if(!e)throw new Error("GH_TOKEN environment variable is required");let n=new We({auth:e}),o=19;try{let s=`
91
+ `,o={owner:e.repository.owner.login,repo:e.repository.name,issueNumber:e.number},i=(await r.graphql(n,o)).repository.issue.projectItems.nodes.find(a=>a.project.number===19);if(i){let a=i.fieldValues.nodes.find(l=>l.field?.name?.toLowerCase()==="ado"&&l.text?.trim());if(a?.text?.trim())return a.text.trim()}return null}catch(n){return console.error(`Failed to check existing ADO link: ${n}`),null}},ms=async(e,t)=>{let r=process.env.GH_TOKEN;if(!r)throw new Error("GH_TOKEN environment variable is required");let n=new wt({auth:r}),o=19;try{let s=`
92
92
  query($org: String!, $projectNumber: Int!, $owner: String!, $repo: String!, $issueNumber: Int!) {
93
93
  organization(login: $org) {
94
94
  projectV2(number: $projectNumber) {
@@ -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,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(`
128
+ `,i={org:"AlaskaAirlines",projectNumber:o,owner:e.repository.owner.login,repo:e.repository.name,issueNumber:e.number},a=await n.graphql(s,i),l=a.organization.projectV2.id,u=a.repository.issue.id,d=a.organization.projectV2.fields.nodes.find(p=>p.name?.toLowerCase()==="ado"),c=a.repository.issue.projectItems.nodes.find(p=>p.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:m})).addProjectV2ItemById.item.id),u&&c)await n.graphql(`
141
+ `,{projectId:l,contentId:u})).addProjectV2ItemById.item.id),d&&c)await n.graphql(`
142
142
  mutation($projectId: ID!, $itemId: ID!, $fieldId: ID!, $value: String!) {
143
143
  updateProjectV2ItemFieldValue(
144
144
  input: {
@@ -155,4 +155,79 @@ ${i.map(l=>` - ${l.replace("@aurodesignsystem","AlaskaAirlines").replace("@alas
155
155
  }
156
156
  }
157
157
  }
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}`)}},Un=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}`)}},Ut=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 Gn(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 Un(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 Ln(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 Ca=Hn.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 Ut(r.ghIssue)});import{program as Vn}from"commander";import{Octokit as Wn}from"@octokit/rest";import{simpleGit as zn}from"simple-git";var Ht="Release Candidate",J="dev",qn="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 S.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 zn().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 S.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:Ht,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:[Ht],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:qn,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/",""):S.getCurrentBranchName()}getCurrentDate(){return new Date().toISOString().split("T")[0]}};var ja=Vn.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:d.id,value:t});else if(!d)throw new Error("No 'ado' field found in GitHub project")}catch(s){console.error(`Failed to update GitHub project: ${s}`)}},gs="https://dev.azure.com/itsals",Rr="E_Retain_Content",fs="E_Retain_Content\\Auro Design System";function xr(){let e=process.env.ADO_TOKEN;if(!e)throw new Error("ADO_TOKEN environment variable is required");let t=Ne.getPersonalAccessTokenHandler(e);return new Ne.WebApi(gs,t).getWorkItemTrackingApi()}var bt=async e=>{let t=await xr();try{let r=[{op:"add",path:"/fields/System.Title",value:e.title},{op:"add",path:"/fields/System.Description",value:e.descriptionHtml},{op:"add",path:"/fields/System.AreaPath",value:fs}];return e.acceptanceCriteriaHtml&&r.push({op:"add",path:"/fields/Microsoft.VSTS.Common.AcceptanceCriteria",value:e.acceptanceCriteriaHtml}),e.tags&&e.tags.length>0&&r.push({op:"add",path:"/fields/System.Tags",value:e.tags.join("; ")}),await t.createWorkItem(null,r,Rr,"User Story")}catch(r){throw new Error(`Failed to create ADO work item: ${r}`)}},je=async e=>{let t=await xr(),n=[{op:"add",path:"/fields/System.State",value:e.state??"Removed"}];e.comment&&n.push({op:"add",path:"/fields/System.History",value:e.comment});try{return await t.updateWorkItem(null,n,e.id,Rr)}catch(o){throw new Error(`Failed to close ADO work item #${e.id}: ${o}`)}},Tr=async e=>{let t=Oe(`Processing GitHub issue: ${e}`).start();try{if(!process.env.GH_TOKEN)throw new Error("GH_TOKEN environment variable is required");if(!process.env.ADO_TOKEN)throw new Error("ADO_TOKEN environment variable is required");t.text="Fetching GitHub issue details...";let r=await ds(e);t.succeed(`Found issue: "${r.title}"`);let n=Oe("Checking for existing ADO work item...").start(),o=await ps(r);if(o){n.succeed("ADO work item already exists for this issue!"),console.log(`${o}`);return}n.succeed("No existing ADO work item found");let s=Oe("Creating new ADO work item...").start(),i=await bt({title:r.title,descriptionHtml:`GitHub Issue: <a href="${r.html_url}">${r.html_url}</a>`});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=Oe("Adding to GitHub project and updating ADO field...").start();await ms(r,i._links.html.href),a.succeed("Updated GitHub project with ADO link")}}catch(r){t.fail(`Error: ${r instanceof Error?r.message:r}`),process.exit(1)}};var cu=hs.command("ado").description("Generate ADO item from GitHub issue").option("-g, --gh-issue <issue>","What GitHub issue to use").action(async e=>{e.ghIssue&&await Tr(e.ghIssue)});import{program as ks}from"commander";import{Octokit as ys}from"@octokit/rest";import{simpleGit as ws}from"simple-git";var Dr="Release Candidate",ce="dev",bs="main",_e=class e{constructor(t,r,n){this.filteredCommits=null;this.repoInfo={owner:t,repo:r},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 r=await _.getRepoOwnerAndName(),n=new ys({auth:t});if(!r)throw new Error("Failed to retrieve repository information. Ensure you're in a valid git repository.");let o=await e.getTriggerBranchName();return o&&o!==ce&&(console.log(`Switching from ${o} to ${ce} branch...`),await ws().checkout(ce)),new e(r.owner,r.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 r=await this.getLatestOpenRcIssue(),n=r?await this.getLinkedPrByHead(r.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."),r=await this.createRcIssue(),n=null),r?await this.updateRcIssue(r.number):r=await this.createRcIssue(),!r)throw new Error("Failed to resolve RC issue.");await this.createOrUpdateRcBranch(r.number),n?await this.updateRcPr(r.number,n.number):n=await this.createRcPr(r.number)}async getFilteredCommits(){if(this.filteredCommits===null){let t=await _.getCommitMessages(ce);this.filteredCommits=ut(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:Dr,state:"open",sort:"updated",direction:"desc",per_page:30}),r=t.filter(o=>!o.pull_request);if(r.length===0)return console.log(`No open Release Candidate issues found in ${this.repoInfo.repo}`),null;let n=r[0];return console.log(`Using latest open Release Candidate issue: #${n.number}`),{number:n.number,title:n.title||""}}async updateRcIssue(t){let r=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:r})}async createRcIssue(){let t=await this.getReleaseNotes(),{data:r}=await this.octokit.rest.issues.create({owner:this.repoInfo.owner,repo:this.repoInfo.repo,title:`RC ${this.getCurrentDate()}`,labels:[Dr],body:t});return console.log(`Created Release Candidate issue: #${r.number} (${r.html_url})`),{number:r.number,html_url:r.html_url}}async createOrUpdateRcBranch(t){let r=`heads/rc/${t}`,n=`rc/${t}`,{data:o}=await this.octokit.rest.repos.getBranch({owner:this.repoInfo.owner,repo:this.repoInfo.repo,branch:ce}),{data:s}=await this.octokit.rest.git.listMatchingRefs({owner:this.repoInfo.owner,repo:this.repoInfo.repo,ref:r}),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:r,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/${r}`,sha:o.commit.sha}))}catch(a){throw new Error(`Failed to create or update ${n} branch: ${a}`)}}async getLinkedPrByHead(t){let r=`${this.repoInfo.owner}:rc/${t}`,{data:n}=await this.octokit.rest.pulls.list({owner:this.repoInfo.owner,repo:this.repoInfo.repo,state:"all",head:r,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:r}=await this.octokit.rest.repos.getContent({owner:this.repoInfo.owner,repo:this.repoInfo.repo,path:".github/PULL_REQUEST_TEMPLATE.md"});if("content"in r&&r.type==="file"){let n=Buffer.from(r.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(r){r&&typeof r=="object"&&"status"in r&&r.status===404?console.log("No PR template found in repo, using default message."):console.warn("Failed to fetch PR template:",r)}return`Release candidate pull request. See issue #${t} for details.`}async createRcPr(t){try{let r=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:r,head:`rc/${t}`,base:bs,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(r){throw console.error("Failed to create RC PR:",r),r}}async updateRcPr(t,r){try{let n=await this.fetchPrTemplate(t);await this.octokit.rest.pulls.update({owner:this.repoInfo.owner,repo:this.repoInfo.repo,pull_number:r,body:n}),console.log(`Updated Release Candidate pull request: #${r}`)}catch(n){throw console.error("Failed to update RC PR:",n),n}}async getReleaseNotes(){let t=await this.getFilteredCommits();return lt(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/",""):_.getCurrentBranchName()}getCurrentDate(){return new Date().toISOString().split("T")[0]}};var yu=ks.command("rc-workflow").description("Generate RC issue and pull request").action(async()=>{await(await _e.create()).createReleaseCandidate()});import H from"chalk";import{program as Hs}from"commander";import{Octokit as Ns}from"@octokit/rest";import de from"ora";import Is from"node:crypto";import Me from"node:fs";import Ur from"node:path";import O from"node:fs";import B from"node:path";var $s="auro-deps-by-ecommerce-repo.json",vs="auro-upgrade-candidates.json",Ss="auro-compliance-findings.json",Cs=B.join(".cache","version-bot");function As(){return B.resolve(process.cwd(),Cs)}function L(e){return e?B.resolve(e):As()}function Or(e){return L(e)}function Be(e){return B.join(L(e),$s)}function Fe(e){return B.join(L(e),vs)}function kt(e){return B.join(L(e),Ss)}function $t(e){O.existsSync(e)||O.mkdirSync(e,{recursive:!0})}function Nr(e){let t=Be(e);if(!O.existsSync(t))return{version:2,lastFullScan:null,repos:{}};try{let r=JSON.parse(O.readFileSync(t,"utf8"));if(r?.version===2&&r.repos)return r}catch{}return{version:2,lastFullScan:null,repos:{}}}function jr(e,t){$t(L(t)),e.lastFullScan=new Date().toISOString(),O.writeFileSync(Be(t),JSON.stringify(e,null,2))}function _r(e,t){$t(L(t)),O.writeFileSync(Fe(t),JSON.stringify(e,null,2))}function Br(e){let t=Fe(e);if(!O.existsSync(t))throw new Error(`Upgrade candidates file not found at ${t}. Run \`auro version-scan\` first.`);return JSON.parse(O.readFileSync(t,"utf8"))}function Fr(e,t){$t(L(t)),O.writeFileSync(kt(t),JSON.stringify(e,null,2))}function Ue(e){let t=B.relative(process.cwd(),e);return!t||t.startsWith("..")||B.isAbsolute(t)?e:`./${t}`}var Es="run-log.jsonl";function Mr(e){return Ur.join(Or(e),Es)}function z(){let e=new Date,t=(o,s=2)=>o.toString().padStart(s,"0"),r=[e.getUTCFullYear(),t(e.getUTCMonth()+1),t(e.getUTCDate()),"T",t(e.getUTCHours()),t(e.getUTCMinutes()),t(e.getUTCSeconds())].join(""),n=Is.randomBytes(3).toString("hex");return`${r}-${n}`}function le(e,t){let r=Mr(t);Me.mkdirSync(Ur.dirname(r),{recursive:!0}),Me.appendFileSync(r,`${JSON.stringify(e)}
159
+ `)}function Le(e){let t=Mr(e);if(!Me.existsSync(t))return[];let r=Me.readFileSync(t,"utf8"),n=[];for(let o of r.split(`
160
+ `)){let s=o.trim();if(s)try{n.push(JSON.parse(s))}catch{}}return n}function vt(e,t){return Le(t).filter(r=>r.runId===e)}function Ge(e){let t=new Set;for(let r of Le(e))t.add(r.runId);return[...t].sort()}function Lr(e){let t=Ge(e);return t.length>0?t[t.length-1]:null}var Ps=/^[\^~>=<\s]+/,St=e=>{let r=e.replace(Ps,"").trim().match(/^(\d+)\.(\d+)(?:\.(\d+))?/);return r?[Number.parseInt(r[1],10),Number.parseInt(r[2],10),r[3]!==void 0?Number.parseInt(r[3],10):0]:null},Gr=(e,t)=>{for(let r=0;r<Math.max(e.length,t.length);r++){let n=e[r]??0,o=t[r]??0;if(n!==o)return n>o?1:-1}return 0},Hr=(e,t)=>{let{declaredVersion:r,detected:n,hasDeprecatedApiUsage:o,packageName:s}=e;if(!n)return{packageName:s,reason:"No evidence of this package was found in the repository.",status:"Not used"};if(!t)return{packageName:s,reason:"No policy record exists for this package.",status:"Unknown"};if(t.replacedBy)return{packageName:s,reason:`This package is deprecated. Migrate to ${t.replacedBy}.`,status:"Unsupported"};if(o)return{packageName:s,reason:"Deprecated API usage was detected. Review usage and migrate to supported APIs.",status:"Review needed"};if(!r)return{packageName:s,reason:"Package was detected but no version could be determined.",status:"Unknown"};let i=St(r);if(!i)return{packageName:s,reason:`Could not parse declared version "${r}".`,status:"Unknown"};let{minimumVersion:a,targetVersion:l}=t;if(a){let u=St(a);if(u&&Gr(i,u)<0)return{packageName:s,reason:`Version ${r} is below the minimum supported version ${a}.`,status:"Unsupported"}}if(l){let u=St(l);if(u&&Gr(i,u)<0)return{packageName:s,reason:`Version ${r} is behind the target version ${l}.`,status:"Behind"}}return{packageName:s,reason:`Version ${r} meets or exceeds the target version${l?` ${l}`:""}.`,status:"Current"}};var Rs={"@alaskaairux/auro-button":"@aurodesignsystem/auro-button","@alaskaairux/auro-icon":"@aurodesignsystem/auro-icon","@alaskaairux/auro-popover":"@aurodesignsystem/auro-popover"};function Wr(e){return Rs[e]??null}var xs="https://registry.npmjs.org",Ts=1e4;async function Ct(e){let t=`${xs}/${encodeURIComponent(e)}/latest`,r=new AbortController,n=setTimeout(()=>r.abort(),Ts);try{let o=await fetch(t,{signal:r.signal});return o.ok?(await o.json()).version??null:null}catch{return null}finally{clearTimeout(n)}}function F(e){if(!e)return null;let r=String(e).replace(/^[\^~>=<\s]+/,"").match(/^(\d+)\.(\d+)\.(\d+)/);return r?{major:Number.parseInt(r[1],10),minor:Number.parseInt(r[2],10),patch:Number.parseInt(r[3],10)}:null}function Vr(e,t){let r=F(e),n=F(t);return!r||!n?0:Math.max(0,n.major-r.major)}async function zr(e){let t=Wr(e);if(!t)return{resolvedPackage:e,version:await Ct(e)};let[r,n]=await Promise.all([Ct(e),Ct(t)]);if(r===null&&n===null)return{resolvedPackage:e,version:null};if(r===null)return{resolvedPackage:t,version:n};if(n===null)return{resolvedPackage:e,version:r};let o=G(r,n);return o===null?{resolvedPackage:t,version:n}:o<0?{resolvedPackage:t,version:n}:{resolvedPackage:e,version:r}}function G(e,t){let r=F(e),n=F(t);return!r||!n?null:r.major!==n.major?r.major<n.major?-1:1:r.minor!==n.minor?r.minor<n.minor?-1:1:r.patch!==n.patch?r.patch<n.patch?-1:1:0}var Ds=[{packageName:"@aurodesignsystem/auro-checkbox",replacedBy:"@aurodesignsystem/auro-formkit"},{packageName:"@aurodesignsystem/auro-combobox",replacedBy:"@aurodesignsystem/auro-formkit"},{packageName:"@aurodesignsystem/auro-datepicker",replacedBy:"@aurodesignsystem/auro-formkit"},{packageName:"@aurodesignsystem/auro-dropdown",replacedBy:"@aurodesignsystem/auro-formkit"},{packageName:"@aurodesignsystem/auro-form",replacedBy:"@aurodesignsystem/auro-formkit"},{packageName:"@aurodesignsystem/auro-input",replacedBy:"@aurodesignsystem/auro-formkit"},{packageName:"@aurodesignsystem/auro-menu",replacedBy:"@aurodesignsystem/auro-formkit"},{packageName:"@aurodesignsystem/auro-radio",replacedBy:"@aurodesignsystem/auro-formkit"},{packageName:"@aurodesignsystem/auro-select",replacedBy:"@aurodesignsystem/auro-formkit"},{packageName:"@alaskaairux/auro-button",replacedBy:"@aurodesignsystem/auro-button"},{packageName:"@alaskaairux/auro-icon",replacedBy:"@aurodesignsystem/auro-icon"},{packageName:"@alaskaairux/auro-popover",replacedBy:"@aurodesignsystem/auro-popover"}],He=e=>Ds.find(t=>t.packageName===e);function ue(e,t,r,n){let o=He(e);if(r.has(e)&&!o?.replacedBy)return null;let s,i;if(o?.replacedBy){let c=n.get(o.replacedBy);if(!c?.version)return null;s=o.replacedBy,i=c.version}else{let c=n.get(e);if(!c?.version)return null;i=o?.targetVersion??c.version,c.resolvedPackage!==e&&(s=c.resolvedPackage)}let a=Vr(t,i),l=Hr({packageName:e,detected:!0,declaredVersion:t},o),u=l.status,d=l.reason;return o||(a>=1?(u="Behind",d=`Version ${t} is behind npm latest (${i}).`):(u="Current",d=`Version ${t} matches the latest published major.`)),{policy:o,targetPackage:s,effectiveLatest:i,majorsBehind:a,status:u,statusReason:d}}function qr(e,t,r,n,o){let s=new Map;for(let a of Object.values(e.repos))if(!(a.error||a.archived))for(let l of Object.values(a.packages))for(let[u,d]of Object.entries(l.auroDeps)){let c=ue(u,d,t,r);if(!c)continue;let p=`${a.name}|${u}`,m=s.get(p);if(m){if(m.paths.push(l.path),(G(d,m.pinned)??0)<0){let g=ue(u,d,t,r);g&&(m.pinned=d,m.evaluated=g)}}else s.set(p,{pinned:d,paths:[l.path],evaluated:c})}let i=[];for(let[a,l]of s){let u=a.indexOf("|"),d=a.slice(0,u),c=a.slice(u+1);i.push({scanRunId:n,scannedAt:o,repository:d,packageName:c,declaredVersion:l.pinned,resolvedVersion:null,targetVersion:l.evaluated.policy?.targetVersion??null,minimumVersion:l.evaluated.policy?.minimumVersion??null,status:l.evaluated.status,statusReason:l.evaluated.statusReason,majorsBehind:l.evaluated.majorsBehind,successorPackage:l.evaluated.targetPackage??null,notes:l.evaluated.policy?.notes??null,manifestPaths:l.paths})}return i}var Os=["@aurodesignsystem","@alaskaairux"];async function Jr(e,t){let r=new Map,n=0;for(let o of Os){let s=`${o} org:${t} in:file filename:package.json`,i=e.paginate.iterator(e.rest.search.code,{q:s,per_page:100});for await(let{data:a}of i)for(let l of a){n++;let u=l.repository?.name,d=l.path;if(!u||!d)continue;let c=r.get(u)??new Set;c.add(d),r.set(u,c)}}return{byRepo:r,totalMatches:n}}var Kr="AlaskaAirlines";async function Yr(e){let t=process.env.GH_TOKEN;if(!t)throw new Error("GH_TOKEN environment variable is required");let r=new Ns({auth:t}),n=Nr(e.outputDir),o=de(`Listing archived Auro packages in ${Kr}...`).start(),s=await _s(r);o.succeed(`Found ${s.size/2} archived Auro repos (excluded from upgrade candidates).`);let i=de(`Listing repos in ${e.org}...`).start(),a=await js(r,e.org);i.succeed(`Found ${a.length} non-archived, non-fork repos in ${e.org}.`);let l=de(`Discovering Auro package.json manifests in ${e.org}...`).start(),u=await Jr(r,e.org);l.succeed(`Discovered ${u.totalMatches} Auro references across ${u.byRepo.size} repos.`);let d=new Map(a.map(y=>[y.name,y])),c=0,p=0,m=0;for(let[y,b]of u.byRepo){let P=d.get(y);if(!P)continue;let ge=n.repos[y];if(!e.force&&ge?.scannedAt&&ge.pushedAt===P.pushed_at){p++;continue}let Dt=de(`Scanning ${y} (${b.size} manifest${b.size===1?"":"s"})...`).start(),V=await Bs(r,e.org,P,b);if(n.repos[y]=V,V.error)Dt.warn(`${y}: ${V.error}`),m++;else{let fn=Ms(V);Dt.succeed(`${y}: ${fn} Auro deps across ${Object.keys(V.packages).length} manifest${Object.keys(V.packages).length===1?"":"s"}`)}c++}for(let y of Object.keys(n.repos))u.byRepo.has(y)||delete n.repos[y];jr(n,e.outputDir);let g=await Ls(n,s),h=z(),w=new Date().toISOString(),C=qr(n,s,g,h,w);Fr(C,e.outputDir);let v=Gs(n,s,g,e.org);return _r(v,e.outputDir),{reposScanned:c,reposSkipped:p,reposErrored:m,candidatesFound:v.length,findingsCount:C.length,cachePath:Ue(Be(e.outputDir)),candidatesPath:Ue(Fe(e.outputDir)),findingsPath:Ue(kt(e.outputDir))}}async function js(e,t){let r=[],n=e.paginate.iterator(e.rest.repos.listForOrg,{org:t,per_page:100,type:"all"});for await(let{data:o}of n)for(let s of o)s.archived||s.fork||r.push({name:s.name,default_branch:s.default_branch??"main",pushed_at:s.pushed_at??"",language:s.language??null});return r}async function _s(e){let t=new Set,r=e.paginate.iterator(e.rest.repos.listForOrg,{org:Kr,per_page:100,type:"all"});for await(let{data:n}of r)for(let o of n)o.archived&&(t.add(`@aurodesignsystem/${o.name}`),t.add(`@alaskaairux/${o.name}`));return t}async function Bs(e,t,r,n){let o={name:r.name,defaultBranch:r.default_branch,pushedAt:r.pushed_at,archived:!1,language:r.language,scannedAt:new Date().toISOString(),isMonorepo:n.size>1,packages:{},error:null};for(let s of n){let i=await Fs(e,t,r.name,s,r.default_branch);i&&(o.packages[s]=Us(i,s))}return Object.keys(o.packages).length===0&&(o.error="no-manifests-fetched"),o}async function Fs(e,t,r,n,o){try{let s=await e.rest.repos.getContent({owner:t,repo:r,path:n,ref:o});if(Array.isArray(s.data)||s.data.type!=="file"||!("content"in s.data)||!s.data.content)return null;let i=Buffer.from(s.data.content,"base64").toString("utf8");return JSON.parse(i)}catch{return null}}function Us(e,t){let r={...e.dependencies??{},...e.devDependencies??{}},n={};for(let[o,s]of Object.entries(r))(o.startsWith("@aurodesignsystem/")||o.startsWith("@alaskaairux/"))&&(n[o]=s);return{path:t,auroDeps:n,totalDeps:Object.keys(r).length}}function Ms(e){let t=0;for(let r of Object.values(e.packages))t+=Object.keys(r.auroDeps).length;return t}async function Ls(e,t){let r=new Set;for(let a of Object.values(e.repos))if(!(a.error||a.archived))for(let l of Object.values(a.packages))for(let u of Object.keys(l.auroDeps)){let d=He(u);t.has(u)&&!d?.replacedBy||(r.add(u),d?.replacedBy&&r.add(d.replacedBy))}let n=de(`Resolving latest npm versions for ${r.size} Auro packages...`).start(),o=[...r],s=await Promise.all(o.map(a=>zr(a))),i=new Map(o.map((a,l)=>[a,s[l]]));return n.succeed(`Resolved ${i.size} package versions on npm.`),i}function Gs(e,t,r,n){let o=new Map;for(let s of Object.values(e.repos))if(!(s.error||s.archived))for(let i of Object.values(s.packages))for(let[a,l]of Object.entries(i.auroDeps)){let u=ue(a,l,t,r);if(!u||u.status==="Current")continue;let d=`${s.name}|${a}`,c=o.get(d);if(c){if(c.manifestPaths||(c.manifestPaths=[]),c.manifestPaths.push(i.path),(G(l,c.pinned)??0)<0){let p=ue(a,l,t,r);p&&p.status!=="Current"&&(c.pinned=l,c.majorsBehind=p.majorsBehind,c.status=p.status,c.statusReason=p.statusReason)}}else{let p={repo:s.name,package:a,pinned:l,latest:u.effectiveLatest,majorsBehind:u.majorsBehind,repoUrl:`https://github.com/${n}/${s.name}`,manifestPaths:[i.path],status:u.status,statusReason:u.statusReason};u.targetPackage&&(p.targetPackage=u.targetPackage),u.policy?.notes&&(p.notes=u.policy.notes),o.set(d,p)}}return[...o.values()]}var Ku=Hs.command("version-scan").description("Scan a GitHub org for repos using outdated Auro packages and write upgrade candidates JSON.").option("--org <name>","GitHub org to scan (overrides ECOM_ORG env var)",process.env.ECOM_ORG??"Alaska-ECommerce").option("--force","Re-scan all repos, ignoring the pushed_at incremental short-circuit",!1).option("--output-dir <dir>","Directory to write the cache + candidates JSON files (default: ./.cache/version-bot/)").action(async e=>{try{let t=await Yr({org:e.org,force:e.force,outputDir:e.outputDir});console.log(""),console.log(H.bold("Version scan complete.")),console.log(` Repos scanned: ${H.cyan(t.reposScanned)} skipped: ${H.gray(t.reposSkipped)} errored: ${H.yellow(t.reposErrored)}`),console.log(` Upgrade candidates (>= 1 major behind): ${H.cyan(t.candidatesFound)}`),console.log(` Compliance findings (all rows, incl. Current): ${H.cyan(t.findingsCount)}`),console.log(` Cache: ${t.cachePath}`),console.log(` Candidates: ${t.candidatesPath}`),console.log(` Findings: ${t.findingsPath}`)}catch(t){console.error(H.red(`version-scan failed: ${t instanceof Error?t.message:t}`)),process.exit(1)}});import S from"chalk";import{program as Ri}from"commander";import pe from"chalk";import Ws from"ora";function Vs(e){if(e.runId&&e.last)throw new Error("Pass either --run-id <id> or --last, not both.");if(e.last){let r=Lr();if(!r)throw new Error("No prior runs found in the audit log (no `version-tickets --apply` has run yet).");return r}if(!e.runId)throw new Error("Pass --run-id <id> to target a specific run, or --last for the most recent.");let t=new Set(Ge());if(!t.has(e.runId)){let r=[...t].slice(-3).join(", ");throw new Error(`Unknown run id "${e.runId}". Recent run ids: ${r||"(none)"}.`)}return e.runId}function zs(e){let t=Le(),r=new Set;for(let n of t)n.action==="closed"&&r.add(n.workItemId);return vt(e).filter(n=>n.action==="created"&&!r.has(n.workItemId))}async function Xr(e){if(e.list){let s=Ge();console.log(pe.bold(`Run ids in audit log (${s.length}):`));for(let i of s){let l=vt(i).filter(u=>u.action==="created").length;console.log(` ${i} (${l} ticket${l===1?"":"s"})`)}return{cleanupRunId:"(none \u2014 list mode)",targetRunId:null,candidates:0,closed:0,skipped:0,failed:0}}let t=Vs(e),r=zs(t),n=z(),o={cleanupRunId:n,targetRunId:t,candidates:r.length,closed:0,skipped:0,failed:0};if(console.log(pe.bold(`Cleanup target: ${t}`)),console.log(` ${r.length} ticket${r.length===1?"":"s"} eligible for removal`),r.length===0)return console.log(pe.dim(" Nothing to do \u2014 every ticket in this run is already closed.")),o;e.apply&&console.log(pe.dim(`run-id: ${n}`));for(let s of r){let i=`#${s.workItemId} (${s.candidate.package} in ${s.candidate.repo})`;if(!e.apply){console.log(` ${pe.cyan("[DRY RUN]")} would close ${i}`),o.skipped++;continue}let a=Ws(`Closing ${i}...`).start();try{await je({id:s.workItemId,comment:`Removed by \`auro version-tickets cleanup\` on ${new Date().toISOString().slice(0,10)} (cleanup run-id ${n}; original run ${t}).`}),a.succeed(`Closed ${i}`),le({runId:n,timestamp:new Date().toISOString(),action:"closed",workItemId:s.workItemId,workItemUrl:s.workItemUrl,candidate:s.candidate,note:`cleanup of run ${t}`}),o.closed++}catch(l){a.fail(`${i} \u2014 ${l instanceof Error?l.message:l}`),o.failed++}}return o}import un from"node:fs";import I from"chalk";import xt from"ora";import*as We from"azure-devops-node-api";var qs="https://dev.azure.com/itsals",At="E_Retain_Content",Js="E_Retain_Content\\Auro Design System";async function Zr({repo:e,pkg:t}){let r=process.env.ADO_TOKEN;if(!r)throw new Error("ADO_TOKEN environment variable is required");let n=We.getPersonalAccessTokenHandler(r),s=await new We.WebApi(qs,n).getWorkItemTrackingApi(),i=c=>c.replace(/'/g,"''"),a={query:`
161
+ SELECT [System.Id] FROM WorkItems
162
+ WHERE [System.TeamProject] = '${At}'
163
+ AND [System.AreaPath] UNDER '${Js}'
164
+ AND [System.WorkItemType] = 'User Story'
165
+ AND [System.State] <> 'Removed'
166
+ AND [System.State] <> 'Closed'
167
+ AND [System.State] <> 'Done'
168
+ AND [System.Title] CONTAINS '${i(t)}'
169
+ AND [System.Title] CONTAINS '${i(e)}'
170
+ `},u=(await s.queryByWiql(a,{project:At})).workItems?.map(c=>c.id).filter(c=>typeof c=="number")??[];return u.length===0?[]:(await s.getWorkItems(u,["System.Id","System.Title","System.State"],void 0,void 0,void 0,At)).map(c=>({id:c.id??0,title:c.fields?.["System.Title"]??"",state:c.fields?.["System.State"]??"",url:c._links?.html?.href??""}))}function Qr(e){let t=e.match(/\(\s*([\d.]+)\s*->\s*([\d.]+)\s*,/);return t?t[2]:null}import{Octokit as Ks}from"@octokit/rest";var Ys="AlaskaAirlines",It=new Map;async function tn(e,t,r){let n=`${e}|${t}|${r}`;if(It.has(n))return It.get(n)??null;let o=await Xs(e,t,r);return It.set(n,o),o}async function Xs(e,t,r){let n=process.env.GH_TOKEN;if(!n)return null;let o=e.replace(/^@[^/]+\//,""),s=new Ks({auth:n}),i;try{let c=await s.rest.repos.getContent({owner:Ys,repo:o,path:"CHANGELOG.md"});if(Array.isArray(c.data)||c.data.type!=="file"||!("content"in c.data)||!c.data.content)return null;i=Buffer.from(c.data.content,"base64").toString("utf8")}catch{return null}let a=Zs(i);if(a.length===0)return null;let l=Qs(a,t,r);if(l.length===0)return null;let u=l.map(ti),d=u.map(ni).join(`
171
+ `);return{versions:u,html:d}}function Zs(e){let t=/^#{1,2}\s+\[([^\]]+)\][^\n]*$/gm,r=[...e.matchAll(t)],n=[];for(let o=0;o<r.length;o++){let s=r[o],i=s[1],a=s[0],l=(s.index??0)+a.length,u=o+1<r.length?r[o+1].index??e.length:e.length,d=e.slice(l,u).trim(),c=a.match(/\((\d{4}-\d{2}-\d{2})\)/),p=c?c[1]:null;n.push({version:i,dateStr:p,body:d})}return n}function Qs(e,t,r){let n=F(t),o=F(r);return!n||!o?[]:e.filter(s=>{let i=F(s.version);return i?en(i,n)>0&&en(i,o)<=0:!1})}function en(e,t){return e.major!==t.major?e.major-t.major:e.minor!==t.minor?e.minor-t.minor:e.patch-t.patch}function ei(e){let t=e.trim().toLowerCase();return t.includes("breaking")?"breakingChanges":t.startsWith("feature")?"features":t.includes("bug fix")||t.startsWith("fix")?"bugFixes":"other"}function ti(e){let t=[],r=null,n=()=>{r&&(t.push(r),r=null)};for(let o of e.body.split(`
172
+ `)){let s=o.trim();if(!s)continue;let i=s.match(/^###\s+(.+)$/);if(i){n();let l=i[1].trim();r={type:ei(l),title:l,bullets:[]};continue}let a=s.match(/^[*-]\s+(.+)$/);a&&r&&r.bullets.push(ri(a[1]))}return n(),{version:e.version,dateStr:e.dateStr,sections:t}}function ri(e){return e.replace(/\s*\(\[[^\]]+\]\([^)]+\)\)/g,"").trim()}function ni(e){let r=[e.dateStr?`<h4>[${me(e.version)}] \u2014 ${me(e.dateStr)}</h4>`:`<h4>[${me(e.version)}]</h4>`];for(let n of e.sections)if(r.push(`<h5>${me(n.title)}</h5>`),n.bullets.length>0){let o=n.bullets.map(s=>`<li>${oi(s)}</li>`).join("");r.push(`<ul>${o}</ul>`)}return r.join(`
173
+ `)}function oi(e){let t=me(e);return t=t.replace(/`([^`]+)`/g,"<code>$1</code>"),t=t.replace(/\[([^\]]+)\]\(([^)]+)\)/g,(r,n,o)=>`<a href="${o}">${n}</a>`),t}function me(e){return e.replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/"/g,"&quot;").replace(/'/g,"&#39;")}function rn(e){let t=[];for(let r of e.versions)for(let n of r.sections)if(n.type==="breakingChanges")for(let o of n.bullets)t.push({version:r.version,text:o});return t}import Et from"node:fs";import si from"node:path";function on(e,t){ii(e);let r=ai(t.candidate),n=si.join(e,r);return Et.writeFileSync(n,ci(t)),n}function ii(e){Et.existsSync(e)||Et.mkdirSync(e,{recursive:!0})}function ai(e){let t=e.package.replace(/^@/,"").replace(/\//g,"-");return`${nn(e.repo)}__${nn(t)}.html`}function nn(e){return e.replace(/[^a-zA-Z0-9._-]/g,"-")}function ci(e){let{candidate:t,title:r,bodyHtml:n,acceptanceCriteriaHtml:o,tags:s,changelogInlined:i}=e,a=s.map(u=>`<span class="tag">${W(u)}</span>`).join(" "),l=i?'<span class="badge badge-good">CHANGELOG inlined</span>':'<span class="badge badge-warn">link-only fallback</span>';return`<!doctype html>
174
+ <html lang="en">
175
+ <head>
176
+ <meta charset="utf-8">
177
+ <title>${W(r)}</title>
178
+ <style>
179
+ body { font: 14px/1.55 -apple-system, system-ui, "Segoe UI", sans-serif; max-width: 760px; margin: 2em auto; padding: 0 1.2em; color: #1f2328; }
180
+ h1 { font-size: 1.35em; padding-bottom: 0.4em; border-bottom: 1px solid #d1d9e0; margin-bottom: 0.6em; }
181
+ h3 { margin-top: 1.6em; font-size: 1.05em; color: #1f2328; }
182
+ h4 { margin-top: 1.2em; font-size: 0.95em; color: #1f2328; }
183
+ h5 { margin: 0.9em 0 0.2em; color: #57606a; font-size: 0.9em; font-weight: 600; }
184
+ p { margin: 0.5em 0; }
185
+ code { background: #eff1f3; padding: 0.1em 0.35em; border-radius: 3px; font-size: 90%; font-family: ui-monospace, SFMono-Regular, monospace; }
186
+ a { color: #0969da; text-decoration: none; }
187
+ a:hover { text-decoration: underline; }
188
+ ul { padding-left: 1.5em; }
189
+ li { margin: 0.2em 0; }
190
+ .meta { color: #57606a; font-size: 0.88em; margin-bottom: 1em; }
191
+ .meta strong { color: #1f2328; }
192
+ .tag { display: inline-block; background: #ddf4ff; color: #0550ae; padding: 0.05em 0.55em; margin-right: 0.25em; border-radius: 2em; font-size: 0.82em; }
193
+ .badge { display: inline-block; padding: 0.1em 0.5em; border-radius: 3px; font-size: 0.78em; margin-left: 0.4em; }
194
+ .badge-good { background: #dafbe1; color: #1a7f37; }
195
+ .badge-warn { background: #fff1c2; color: #7d4e00; }
196
+ .preview-banner { background: #fff8c5; border: 1px solid #d4a72c; padding: 0.6em 1em; border-radius: 6px; margin-bottom: 1.5em; font-size: 0.9em; color: #633c01; }
197
+ </style>
198
+ </head>
199
+ <body>
200
+ <div class="preview-banner">
201
+ <strong>Dry-run preview.</strong> No ADO ticket was created. This file shows the HTML body
202
+ that <code>createADOWorkItem</code> would set as <code>System.Description</code>.
203
+ </div>
204
+ <h1>${W(r)}</h1>
205
+ <div class="meta">
206
+ <strong>Repo:</strong> <a href="${li(t.repoUrl)}">${W(t.repo)}</a> &nbsp;\xB7&nbsp;
207
+ <strong>Package:</strong> <code>${W(t.package)}</code> &nbsp;\xB7&nbsp;
208
+ <strong>Versions:</strong> <code>${W(t.pinned)}</code> \u2192 <code>${W(t.latest)}</code> &nbsp;\xB7&nbsp;
209
+ <strong>Majors behind:</strong> ${t.majorsBehind} ${l}<br>
210
+ <strong>Tags:</strong> ${a}
211
+ </div>
212
+ <hr>
213
+ ${n}
214
+ <h3>Acceptance criteria</h3>
215
+ ${o}
216
+ </body>
217
+ </html>
218
+ `}function W(e){return e.replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/"/g,"&quot;").replace(/'/g,"&#39;")}function li(e){return e.replace(/"/g,"&quot;")}function ui(e){let t=f(e.package),r=f(e.latest),n=e.targetPackage?f(e.targetPackage):null,o=di(e.manifestPaths),s=`lockfile${e.manifestPaths&&e.manifestPaths.length>1?"s":""}`,i=e.status==="Unsupported"&&n&&!sn(e.package,e.targetPackage),a;return i&&n?a=`Migrate from <code>${t}</code> to <code>${n}@${r}</code> in ${o} (and the matching ${s}). <b>This is a code migration, not a drop-in replacement</b> \u2014 the successor exposes different exports and APIs. Review its documentation, update imports and usage, and retest every surface that used <code>${t}</code>.`:n?a=`Replace <code>${t}</code> with <code>${n}@${r}</code> in ${o} (and the matching ${s}). Update all import paths from <code>${t}</code> to <code>${n}</code>.`:a=`Update <code>${t}</code> to <code>${r}</code> in ${o} (and the matching ${s}).`,[a,"<code>npm ci</code> succeeds with no peer-dep warnings or lockfile drift caused by the upgrade.","Build / TypeScript compile passes with no new errors introduced by the upgrade.","Lint passes (no new violations).","Existing test suite passes.",`Manual smoke check: every UI surface using <code>${n??t}</code> renders without new console errors and matches the prior visual baseline.`]}function sn(e,t){if(!t)return!1;let r=n=>n.replace(/^@[^/]+\//,"");return r(e)===r(t)}var an=5;function di(e){if(!e||e.length===0||e.length===1&&e[0]==="package.json")return"the consumer's <code>package.json</code>";if(e.length===1)return`<code>${f(e[0])}</code>`;if(e.length>an)return`each of the ${e.length} manifests listed in the "Multiple manifests" callout in this ticket's description`;let t=e.map(r=>`<code>${f(r)}</code>`).join(", ");return`each of the ${e.length} manifests where it appears (${t})`}function Pt(e,t=[]){let r=ui(e).map(n=>` <li>${n}</li>`);if(t.length>0){let n=t.length,o=n===1?"":"s";r.push(` <li>Verify each of the ${n} breaking change${o} listed in the "Breaking changes in this upgrade" section is handled in your codebase.</li>`)}return["<ul>",...r,"</ul>"].join(`
219
+ `)}function cn(e){if(e.status==="Unsupported"&&e.targetPackage)return`Replace ${e.package}@${e.pinned} (deprecated) with ${e.targetPackage}@${e.latest} in ${e.repo}`;let t=e.majorsBehind>1?"s":"";return`Upgrade ${e.package} in ${e.repo} (${e.pinned} -> ${e.latest}, ${e.majorsBehind} major${t} behind)`}function Rt({candidate:e,changelogSlice:t,changelogUrl:r,breakingChanges:n,usage:o,supersedes:s}){let{repo:i,package:a,pinned:l,latest:u,majorsBehind:d,repoUrl:c}=e,p=d>1?"s":"",m=e.targetPackage,g=e.status==="Unsupported"&&!!m&&!sn(a,m),h=g?`<p>The repo <a href="${c}"><b>${f(i)}</b></a> is using <code>${f(a)}@${f(l)}</code>, which has been <b>deprecated and replaced</b> by <code>${f(m)}@${f(u)}</code>. Migrating off the deprecated package keeps the repo on a supported track for a11y, security patches, and design-system parity.</p>`:`<p>The repo <a href="${c}"><b>${f(i)}</b></a> is using <code>${f(a)}@${f(l)}</code> but the latest published version is <code>${f(u)}</code> \u2014 that's <b>${d} major version${p} behind</b>. Staying current keeps a11y, security patches, and design-system parity in step with the rest of the Auro fleet.</p>`,w=m?g?`<p><b>\u26A0 Package deprecated \u2014 code migration required:</b> <code>${f(a)}</code> is no longer maintained. The successor <code>${f(m)}</code> is a different package with a different API surface, not a renamed version of the same component. Migration involves removing <code>${f(a)}</code>, adding <code>${f(m)}</code>, and rewriting source code that referenced the old package. Plan for review time proportional to a real refactor, not a version bump.</p>`:`<p><b>\u26A0 Namespace rename:</b> active development of this library moved to <code>${f(m)}</code>. Upgrading requires renaming the dependency in <code>package.json</code> from <code>${f(a)}</code> to <code>${f(m)}</code> AND updating any matching import paths in source files. The version number bridges both scopes \u2014 <code>${f(u)}</code> is the latest on the new scope.</p>`:"",C=["<h3>Context</h3>",h,w,pi(e.manifestPaths,l),s!==void 0?`<p><i>This ticket supersedes work item #${s}, which was closed because a newer version of <code>${f(a)}</code> has shipped since that ticket was created.</i></p>`:""].filter(Boolean).join(`
220
+ `),v=mi(e.notes),y=fi(o??null,a,m),b=hi(e,t,n),P=gi(t,r,a,l,u);return[C,"",v,"",y,"",b,"",P,"","<p><i>This ticket was auto-generated by the Auro Version Support bot.</i></p>"].filter(ge=>ge!=="").join(`
221
+ `)}function pi(e,t){if(!e||e.length===0||e.length===1&&e[0]==="package.json")return"";if(e.length===1)return`<p><b>\u{1F4CD} Manifest location:</b> this dependency is declared in <code>${f(e[0])}</code>, not the repo's root <code>package.json</code>. Make sure your upgrade edits the right file.</p>`;if(e.length>an){let n=e.map(o=>` <li><code>${f(o)}</code></li>`).join(`
222
+ `);return[`<p><b>\u26A0 Multiple manifests:</b> this dependency is declared in <b>${e.length}</b> <code>package.json</code> files \u2014 all must be updated to upgrade the repo consistently:</p>`,"<ul>",n,"</ul>"].join(`
223
+ `)}let r=e.map(n=>`<code>${f(n)}</code>`).join(", ");return`<p><b>\u26A0 Multiple manifests:</b> this dependency is declared in <b>${e.length}</b> <code>package.json</code> files \u2014 all must be updated to upgrade the repo consistently: ${r}.</p>`}function mi(e){return e?`<p><b>\u26A0 Incident notice:</b> ${f(e)}</p>`:""}function gi(e,t,r,n,o){if(!e)return["<h3>What's new</h3>",`<p>See the <a href="${t}">CHANGELOG for ${f(r)}</a> for changes between <code>${f(n)}</code> and <code>${f(o)}</code>.</p>`].join(`
224
+ `);let s=0,i=0;for(let u of e.versions)for(let d of u.sections)d.type==="features"?s+=d.bullets.length:d.type==="bugFixes"&&(i+=d.bullets.length);let a=`Features: <b>${s}</b>`,l=`Bug fixes: <b>${i}</b>`;return["<h3>What's new</h3>",`<p>Between <code>${f(n)}</code> and <code>${f(o)}</code>:</p>`,"<ul>",` <li>${a}</li>`,` <li>${l}</li>`,"</ul>",`<p>See the <a href="${t}">full CHANGELOG for ${f(r)}</a> for the details.</p>`].join(`
225
+ `)}function fi(e,t,r){if(!e||e.totalCount===0)return"";let n=e.totalCount===1?"file":"files",o=Math.min(e.sampleFiles.length,10),s=e.sampleFiles.slice(0,o).map(l=>` <li><a href="${l.htmlUrl}"><code>${f(l.path)}</code></a></li>`).join(`
226
+ `),i=e.totalCount>o?`<p>\u2026 and ${e.totalCount-o} more. <a href="${e.searchUrl}">View all results on GitHub</a>.</p>`:"";return["<h3>Where this package is used in your codebase</h3>",`<p>GitHub Code Search found ${r?`<code>${f(t)}</code> or <code>${f(r)}</code>`:`<code>${f(t)}</code>`} referenced in <b>${e.totalCount}</b> ${n} in this repo:</p>`,"<ul>",s,"</ul>",i].filter(Boolean).join(`
227
+ `)}function hi(e,t,r){let{package:n,pinned:o,latest:s}=e;return t?r.length===0?["<h3>Breaking changes in this upgrade</h3>",`<p>No breaking changes detected in <code>${f(n)}</code> between <code>${f(o)}</code> and <code>${f(s)}</code>.</p>`].join(`
228
+ `):["<h3>Breaking changes in this upgrade</h3>","<ul>",r.map(a=>yi(a,e)).join(`
229
+ `),"</ul>"].join(`
230
+ `):""}function yi(e,t){let r=`<b>${f(e.version)}:</b> ${ki(e.text)}`,n=wi(e.text,t);return n?` <li>${r} <span class="bot-find-link">${n}</span></li>`:` <li>${r}</li>`}function wi(e,t){let r=bi(e);if(r.length===0)return null;let n,o;try{let p=new URL(t.repoUrl).pathname.split("/").filter(Boolean);if(p.length<2)return null;[n,o]=p}catch{return null}let s=(t.targetPackage??t.package).replace(/^@[^/]+\//,""),i=r.map(c=>`"${c}"`).join(" OR "),a=r.length>1?`(${i})`:i,l=`repo:${n}/${o} "${s}" ${a}`,u=`https://github.com/search?q=${encodeURIComponent(l)}&type=code`,d=r.map(c=>`<code>${f(c)}</code>`).join(", ");return`<a href="${u}">\u2192 find ${d} in this repo</a>`}function bi(e){let t=new Set;for(let r of e.matchAll(/`([^`]+)`/g)){let n=r[1].trim();/^[A-Za-z][\w-]{1,}$/.test(n)&&t.add(n)}return[...t]}function ki(e){let t=f(e);return t=t.replace(/`([^`]+)`/g,"<code>$1</code>"),t=t.replace(/\[([^\]]+)\]\(([^)]+)\)/g,(r,n,o)=>`<a href="${o}">${n}</a>`),t}function f(e){return e.replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/"/g,"&quot;").replace(/'/g,"&#39;")}import{Octokit as $i}from"@octokit/rest";var q=new Map;async function ln(e){let{org:t,repo:r,packages:n}=e,o=n.slice().sort().join("|"),s=`${t}/${r}::${o}`;if(q.has(s))return q.get(s)??null;let i=process.env.GH_TOKEN;if(!i||n.length===0)return q.set(s,null),null;try{let a=new $i({auth:i}),l=new Map,u=0,d="";for(let p of n){let m=`"${p}" repo:${t}/${r} -path:package-lock.json -path:yarn.lock -path:pnpm-lock.yaml -path:dist -path:build -filename:package.json`;d||(d=m);let g=await a.rest.search.code({q:m,per_page:10});u+=g.data.total_count;for(let h of g.data.items)l.has(h.html_url)||l.set(h.html_url,{path:h.path,htmlUrl:h.html_url})}let c={totalCount:u,sampleFiles:[...l.values()].slice(0,10),searchUrl:`https://github.com/search?q=${encodeURIComponent(d)}&type=code`};return q.set(s,c),c}catch{return q.set(s,null),null}}async function mn(e){let t=e.candidatesPath?vi(e.candidatesPath):Br(),r=t.filter(l=>!(l.majorsBehind<e.minMajors||e.repo&&l.repo!==e.repo)),{kept:n,notUsedSkipped:o}=await Pi(r),s=e.limit!==void 0?n.slice(0,e.limit):n,i=z(),a={runId:i,totalCandidates:t.length,afterFilter:n.length,applied:0,dryRun:0,failed:0,dedupeSkipped:0,dedupeReplaced:0,notUsedSkipped:o};e.apply&&console.log(I.dim(`run-id: ${i}`));for(let l of s)await Si(l,e,a);return a}function vi(e){if(!un.existsSync(e))throw new Error(`Candidates file not found: ${e}`);return JSON.parse(un.readFileSync(e,"utf8"))}async function Si(e,t,r){let n=cn(e),o=Ai(e.package),s=t.noTags?[]:Ii(e),i=xt(`Fetching changelog for ${e.package}...`).start(),a=await tn(e.package,e.pinned,e.latest);i.stop();let l=a?rn(a):[],u=await gn(e);if(!t.apply){let{descriptionHtml:h,usedChangelogSlice:w}=pn({candidate:e,changelogSlice:a,changelogUrl:o,breakingChanges:l,usage:u},n),C=Pt(e,l);if(console.log(""),console.log(I.bold.cyan(`[DRY RUN] ${n}`)),console.log(` ${I.dim("tags:")} ${s.join(", ")}`),console.log(` ${I.dim("changelog:")} ${w?I.green("inlined"):I.yellow("link only")}`),console.log(` ${I.dim("breaking:")} ${l.length} change${l.length===1?"":"s"} detected`),console.log(` ${I.dim("usage:")} ${u?`${u.totalCount} file${u.totalCount===1?"":"s"} reference${u.totalCount===1?"s":""} this package`:"(not searched)"}`),console.log(` ${I.dim("body:")} ${h.length} chars`),console.log(` ${I.dim("AC:")} ${C.length} chars`),t.previewDir){let v=on(t.previewDir,{candidate:e,title:n,bodyHtml:h,acceptanceCriteriaHtml:C,tags:s,changelogInlined:w});console.log(` ${I.dim("preview:")} ${v}`)}r.dryRun++;return}let d=await Ci(e);if(d.action==="skip"){console.log(I.yellow(` \u21A9 Skipped (dupe of #${d.existing.id}): ${e.repo} / ${e.package}`)),r.dedupeSkipped++;return}let c=d.action==="replace"?d.existing.id:void 0,{descriptionHtml:p}=pn({candidate:e,changelogSlice:a,changelogUrl:o,breakingChanges:l,usage:u,supersedes:c},n),m=Pt(e,l),g=xt(`Creating: ${n}`).start();try{let h=await bt({title:n,descriptionHtml:p,acceptanceCriteriaHtml:m,tags:s}),w=h.id,C=h._links?.html?.href??"(no URL returned)";if(typeof w!="number"){g.fail(`${n} - work item create returned no id`),r.failed++;return}if(g.succeed(`Created #${w} -> ${C}`),r.applied++,le({runId:r.runId,timestamp:new Date().toISOString(),action:"created",workItemId:w,workItemUrl:C,candidate:{repo:e.repo,package:e.package,pinned:e.pinned,latest:e.latest,majorsBehind:e.majorsBehind},supersedes:c}),d.action==="replace"){let v=d.existing.id,y=xt(`Closing superseded #${v}...`).start();try{await je({id:v,comment:`Closed because a newer version of ${e.package} has shipped (now at ${e.latest}). Replaced by #${w}: ${C}`}),y.succeed(`Closed superseded #${v}`),r.dedupeReplaced++,le({runId:r.runId,timestamp:new Date().toISOString(),action:"closed",workItemId:v,workItemUrl:d.existing.url,candidate:{repo:e.repo,package:e.package,pinned:e.pinned,latest:e.latest,majorsBehind:e.majorsBehind},replacedBy:w,note:"close-and-recreate"})}catch(b){y.fail(`Failed to close superseded #${v} \u2014 ${b instanceof Error?b.message:b}`)}}}catch(h){g.fail(`${n} - ${h instanceof Error?h.message:h}`),console.log(I.dim(` retry candidate: ${JSON.stringify([e])}`)),console.log(I.dim(" (save that JSON line to a file, then re-run with --candidates <file>)")),r.failed++}}async function Ci(e){let t;try{t=await Zr({repo:e.repo,pkg:e.package})}catch(s){return console.log(I.yellow(` \u26A0 Dedupe check failed (${s instanceof Error?s.message:s}). Proceeding with create.`)),{action:"create"}}if(t.length===0)return{action:"create"};let r=t.reduce((s,i)=>s.id>=i.id?s:i);if(r.state!=="New")return{action:"skip",existing:r};let n=Qr(r.title);if(!n)return{action:"skip",existing:r};let o=G(n,e.latest);return o===null?{action:"skip",existing:r}:o>=0?{action:"skip",existing:r}:{action:"replace",existing:r}}function Ai(e){return`https://github.com/AlaskaAirlines/${e.replace(/^@[^/]+\//,"")}/blob/main/CHANGELOG.md`}function Ii(e){let t=["auro","version-upgrade"];return e.status!=="Unsupported"&&t.push(`majors-behind-${e.majorsBehind}`),e.status&&e.status!=="Behind"&&t.push(`compliance-${Ei(e.status)}`),t}function Ei(e){return e.toLowerCase().replace(/ /g,"-")}async function Pi(e){let t=[],r=0;for(let n of e){let o=await gn(n);if(o&&o.totalCount===0){r++;continue}t.push(n)}return{kept:t,notUsedSkipped:r}}async function gn(e){let t,r;try{let s=new URL(e.repoUrl).pathname.split("/").filter(Boolean);if(s.length<2)return null;[t,r]=s}catch{return null}let n=e.targetPackage?[e.package,e.targetPackage]:[e.package];return ln({org:t,repo:r,packages:n})}var dn=5e4;function pn(e,t){let r=Rt(e),n=e.changelogSlice!==null;if(r.length<=dn||!n)return{descriptionHtml:r,usedChangelogSlice:n};let o=Rt({...e,changelogSlice:null});return console.log(I.yellow(` \u26A0 ${t}: body was ${r.length} chars with the inlined CHANGELOG (> ${dn}). Dropped the slice; body is now ${o.length} chars with link-only migration section. Breaking-change AC bullets are preserved.`)),{descriptionHtml:o,usedChangelogSlice:!1}}var xi=Ri.command("version-tickets").description("Create ADO User Stories for Auro upgrade candidates. Defaults to dry-run; pass --apply to actually write to ADO.").option("--min-majors <n>","Only ticket candidates at or above this majors-behind threshold","2").option("--apply","Actually create tickets in ADO (otherwise dry-run)",!1).option("--limit <n>","Maximum number of tickets to process this run").option("--repo <name>","Only process candidates from this consumer repo").option("--candidates <file>","Read candidates from a custom JSON file instead of the default ./.cache/version-bot/auro-upgrade-candidates.json").option("--preview-dir <dir>","During dry-run, write one styled HTML preview file per candidate to this directory").option("--no-tags","Skip setting System.Tags on created work items").action(async e=>{try{let t=Number.parseInt(e.minMajors,10);if(Number.isNaN(t)||t<1)throw new Error("--min-majors must be an integer >= 1");let r=e.limit!==void 0?Number.parseInt(e.limit,10):void 0;if(r!==void 0&&(Number.isNaN(r)||r<1))throw new Error("--limit must be an integer >= 1");let n=await mn({minMajors:t,apply:e.apply,limit:r,repo:e.repo,candidatesPath:e.candidates,previewDir:e.previewDir,noTags:!e.tags});console.log(""),console.log(S.bold(e.apply?"Tickets applied.":"Dry run complete.")),console.log(` Total candidates in JSON: ${n.totalCandidates}`),console.log(` After filters: ${n.afterFilter}`),console.log(` Skipped (no usage): ${S.dim(n.notUsedSkipped)}`),e.apply?(console.log(` Applied: ${S.green(n.applied)} failed: ${S.red(n.failed)}`),console.log(` Dedupe: ${S.yellow(n.dedupeSkipped)} skipped, ${S.magenta(n.dedupeReplaced)} replaced`),console.log(` run-id: ${S.dim(n.runId)}`),console.log(S.dim(`
231
+ To roll back this run: auro version-tickets cleanup --run-id `+n.runId))):(console.log(` Dry-run printed: ${S.cyan(n.dryRun)}`),console.log(S.dim(`
232
+ Re-run with --apply to actually create tickets in ADO.`)))}catch(t){console.error(S.red(`version-tickets failed: ${t instanceof Error?t.message:t}`)),process.exit(1)}});xi.command("cleanup").description("Close (state=Removed) work items created by a prior `version-tickets --apply` run. Dry-run by default.").option("--run-id <id>","Target a specific run id from the audit log").option("--last","Target the most recent run id",!1).option("--list","List available run ids and exit (no writes)",!1).option("--apply","Actually close tickets in ADO (otherwise dry-run)",!1).action(async e=>{try{let t=await Xr({apply:e.apply,runId:e.runId,last:e.last,list:e.list});if(e.list)return;console.log(""),console.log(S.bold(e.apply?"Cleanup complete.":"Dry run complete.")),console.log(` Eligible: ${t.candidates}`),e.apply?(console.log(` Closed: ${S.green(t.closed)} failed: ${S.red(t.failed)}`),console.log(` run-id: ${S.dim(t.cleanupRunId)}`)):(console.log(` Dry-run printed: ${S.cyan(t.skipped)}`),console.log(S.dim(`
233
+ Re-run with --apply to actually close tickets in ADO.`)))}catch(t){console.error(S.red(`cleanup failed: ${t instanceof Error?t.message:t}`)),process.exit(1)}});Tt.name("auro").version(Ve()).description("A cli tool to support the Auro Design System");Tt.addHelpText("beforeAll",Ot());Tt.parse();