@aurodesignsystem-dev/auro-cli 0.0.0-pr175.3 → 0.0.0-pr177.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/auro-cli.js CHANGED
@@ -1,5 +1,5 @@
1
1
  #!/usr/bin/env node
2
- import{program as ne}from"commander";import Me from"figlet";import{mind as Ge}from"gradient-string";var ie=()=>Ge(Me.textSync("Auro CLI"));import se from"node:fs";import ae from"node:path";import{fileURLToPath as Le}from"node:url";function A(t){process.env.DEBUG&&console.log(`[DEBUG] ${t}`)}function z(){try{let t=Le(import.meta.url),e=ae.dirname(t);A(`Current module path: ${e}`);let r=ae.resolve(e,"..","package.json");return A(`Checking package.json at: ${r}`),se.existsSync(r)?(A(`Found package.json at: ${r}`),JSON.parse(se.readFileSync(r,"utf8")).version):(A("Could not find package.json in the standard installed module location, using default version"),"0.0.0")}catch(t){return console.error("Error retrieving package version:",t),"0.0.0"}}import{program as wt}from"commander";import Te from"ora";function R(t){return t.option("-m, --module-paths [paths...]","Path(s) to node_modules folder").option("-w, --watch","Watches for changes").option("--skip-docs","Skip documentation generation",!1).option("--wca-input [files...]","Source file(s) to analyze for API documentation").option("--wca-output [files...]","Output file(s) for API documentation")}function ce(t){return t.option("-s, --serve","Starts a server").option("-p, --port <number>","Port for the server").option("-o, --open","Open the browser after starting the server")}import ft from"@rollup/plugin-terser";import{watch as gt}from"rollup";import{rmSync as Ke}from"node:fs";import{join as Xe}from"node:path";import V from"ora";import{rollup as q}from"rollup";import me from"ora";import{spawn as Ue}from"node:child_process";import We from"ora";var b=(t,e)=>{let r=`${t} ${e?e.join(" "):""}`,o=We(),n=t,i=e||[];if(!e&&typeof t=="string"){let a=t.split(" ");n=a[0],i=a.slice(1)}let s=r.includes("--watch")||r.includes(" -w"),c=Ue(n,i,{stdio:s?"inherit":["inherit","pipe","pipe"],shell:!0});if(!s){let a=[];c.stdout?.on("data",u=>{let m=u.toString();a.push(m),process.stdout.write(m)}),c.stderr?.on("data",u=>{let m=u.toString();a.push(m),process.stderr.write(m)})}return new Promise((a,u)=>{c.on("close",m=>{m!==0?s?(o.info(`Watch mode terminated with code ${m}`),a()):(o.fail(`${r} failed (code ${m})`),u(new Error(`Command failed with exit code ${m}`))):(o.succeed(`${r} completed successfully`),a())})})};import _ from"node:fs";import He from"node:path";var T=class{static{this.manifest={schemaVersion:"1.0.0",readme:"",modules:[]}}static generate(e={}){let{outDir:r="./docs",outFile:o="api.md",manifestPath:n="./custom-elements.json"}=e;if(n)try{let a=_.readFileSync(n,"utf8");this.manifest=JSON.parse(a)}catch(a){throw console.error(`Error reading manifest file at ${n}:`,a),a}let i=this.getElements(),s=r;_.existsSync(s)||_.mkdirSync(s,{recursive:!0});let l=this.renderAllElements(i),c=He.join(s,o);_.writeFileSync(c,l),console.log(`Generated combined API documentation at ${c}`)}static getElements(){return this.manifest.modules.reduce((e,r)=>e.concat(r.declarations?.filter(o=>"customElement"in o&&o.customElement===!0&&"tagName"in o&&this.isWcaModule(r))??[]),[])}static isWcaModule(e){let r=e.path;return r?r.startsWith("scripts/wca/auro-")&&r.endsWith(".js"):!1}static renderAllElements(e){return`${e.map(r=>this.renderElement(r,!1)).join(`
2
+ import{program as ue}from"commander";import Ze from"figlet";import{mind as et}from"gradient-string";var de=()=>et(Ze.textSync("Auro CLI"));import pe from"node:fs";import fe from"node:path";import{fileURLToPath as tt}from"node:url";function S(t){process.env.DEBUG&&console.log(`[DEBUG] ${t}`)}function q(){try{let t=tt(import.meta.url),e=fe.dirname(t);S(`Current module path: ${e}`);let r=fe.resolve(e,"..","package.json");return S(`Checking package.json at: ${r}`),pe.existsSync(r)?(S(`Found package.json at: ${r}`),JSON.parse(pe.readFileSync(r,"utf8")).version):(S("Could not find package.json in the standard installed module location, using default version"),"0.0.0")}catch(t){return console.error("Error retrieving package version:",t),"0.0.0"}}import{program as jt}from"commander";import Re from"ora";function R(t){return t.option("-m, --module-paths [paths...]","Path(s) to node_modules folder").option("-w, --watch","Watches for changes").option("--skip-docs","Skip documentation generation",!1).option("--wca-input [files...]","Source file(s) to analyze for API documentation").option("--wca-output [files...]","Output file(s) for API documentation")}function ge(t){return t.option("-s, --serve","Starts a server").option("-p, --port <number>","Port for the server").option("-o, --open","Open the browser after starting the server")}import Dt from"@rollup/plugin-terser";import{watch as Pt}from"rollup";import{rmSync as mt}from"node:fs";import{join as ut}from"node:path";import V from"ora";import{rollup as J}from"rollup";import he from"ora";import{spawn as rt}from"node:child_process";import nt from"ora";var h=(t,e)=>{let r=`${t} ${e?e.join(" "):""}`,n=nt(),o=t,s=e||[];if(!e&&typeof t=="string"){let a=t.split(" ");o=a[0],s=a.slice(1)}let i=r.includes("--watch")||r.includes(" -w"),c=rt(o,s,{stdio:i?"inherit":["inherit","pipe","pipe"],shell:!0});if(!i){let a=[];c.stdout?.on("data",u=>{let m=u.toString();a.push(m),process.stdout.write(m)}),c.stderr?.on("data",u=>{let m=u.toString();a.push(m),process.stderr.write(m)})}return new Promise((a,u)=>{c.on("close",m=>{m!==0?i?(n.info(`Watch mode terminated with code ${m}`),a()):(n.fail(`${r} failed (code ${m})`),u(new Error(`Command failed with exit code ${m}`))):(n.succeed(`${r} completed successfully`),a())})})};import j from"node:fs";import ot from"node:path";var x=class{static{this.manifest={schemaVersion:"1.0.0",readme:"",modules:[]}}static generate(e={}){let{outDir:r="./docs",outFile:n="api.md",manifestPath:o="./custom-elements.json"}=e;if(o)try{let a=j.readFileSync(o,"utf8");this.manifest=JSON.parse(a)}catch(a){throw console.error(`Error reading manifest file at ${o}:`,a),a}let s=this.getElements(),i=r;j.existsSync(i)||j.mkdirSync(i,{recursive:!0});let l=this.renderAllElements(s),c=ot.join(i,n);j.writeFileSync(c,l),console.log(`Generated combined API documentation at ${c}`)}static getElements(){return this.manifest.modules.reduce((e,r)=>e.concat(r.declarations?.filter(n=>"customElement"in n&&n.customElement===!0&&"tagName"in n&&this.isWcaModule(r))??[]),[])}static isWcaModule(e){let r=e.path;return r?r.startsWith("scripts/wca/auro-")&&r.endsWith(".js"):!1}static renderAllElements(e){return`${e.map(r=>this.renderElement(r,!1)).join(`
3
3
 
4
4
  ---
5
5
 
@@ -10,47 +10,56 @@ import{program as ne}from"commander";import Me from"figlet";import{mind as Ge}fr
10
10
 
11
11
  `}${e.description?`${e.description}
12
12
 
13
- `:""}${this.renderPropertiesAttributesTable(e)}${this.renderTable("Methods",["name","parameters","return.type.text","description"],(e.members||[]).filter(o=>o.kind==="method"&&("privacy"in o?o.privacy!=="private":!0)&&o.name[0]!=="_").map(o=>({...o,parameters:this.renderParameters("parameters"in o?o.parameters:void 0)})))}${this.renderTable("Events",["name","description"],e.events)}${this.renderTable("Slots",[["name","(default)"],"description"],e.slots)}${this.renderTable("CSS Shadow Parts",["name","description"],e.cssParts)}${this.renderTable("CSS Custom Properties",["name","description"],e.cssProperties)}`}static renderPropertiesAttributesTable(e){let r=e.members?.filter(a=>a.kind==="field")||[],o=e.attributes||[],n=[],i=new Set;if(r.forEach(a=>{a.description?.trim()&&n.push({name:a.name,properties:a.name,attributes:("attribute"in a?a.attribute:"")||"",type:this.get(a,"type.text")||"",default:("default"in a?a.default:"")||"",description:a.description||""}),i.add(a.name),"attribute"in a&&a.attribute&&i.add(a.attribute)}),o.forEach(a=>{!i.has(a.name)&&a.description?.trim()&&n.push({name:a.name,properties:"",attributes:a.name,type:this.get(a,"type.text")||"",default:a.default||"",description:a.description||""})}),n.length===0)return"";let s="Properties | Attributes | Type | Default | Description ",l="--- | --- | --- | --- | ---",c=n.map(a=>[a.properties,a.attributes,a.type,a.default,a.description].map(u=>String(u||"").replace(/\|/g,"\\|").replace(/\n/g,"<br>")).join(" | ")).join(`
13
+ `:""}${this.renderPropertiesAttributesTable(e)}${this.renderTable("Methods",["name","parameters","return.type.text","description"],(e.members||[]).filter(n=>n.kind==="method"&&("privacy"in n?n.privacy!=="private":!0)&&n.name[0]!=="_").map(n=>({...n,parameters:this.renderParameters("parameters"in n?n.parameters:void 0)})))}${this.renderTable("Events",["name","description"],e.events)}${this.renderTable("Slots",[["name","(default)"],"description"],e.slots)}${this.renderTable("CSS Shadow Parts",["name","description"],e.cssParts)}${this.renderTable("CSS Custom Properties",["name","description"],e.cssProperties)}`}static renderPropertiesAttributesTable(e){let r=e.members?.filter(a=>a.kind==="field")||[],n=e.attributes||[],o=[],s=new Set;if(r.forEach(a=>{a.description?.trim()&&o.push({name:a.name,properties:a.name,attributes:("attribute"in a?a.attribute:"")||"",type:this.get(a,"type.text")||"",default:("default"in a?a.default:"")||"",description:a.description||""}),s.add(a.name),"attribute"in a&&a.attribute&&s.add(a.attribute)}),n.forEach(a=>{!s.has(a.name)&&a.description?.trim()&&o.push({name:a.name,properties:"",attributes:a.name,type:this.get(a,"type.text")||"",default:a.default||"",description:a.description||""})}),o.length===0)return"";let i="Properties | Attributes | Type | Default | Description ",l="--- | --- | --- | --- | ---",c=o.map(a=>[a.properties,a.attributes,a.type,a.default,a.description].map(u=>String(u||"").replace(/\|/g,"\\|").replace(/\n/g,"<br>")).join(" | ")).join(`
14
14
  `);return`
15
15
  ### Properties & Attributes
16
16
 
17
- | ${s} |
17
+ | ${i} |
18
18
  | ${l} |
19
19
  ${c}
20
20
 
21
- `}static renderParameters(e){return!e||e.length===0?"None":e.map(r=>`\`${r.name}\` (${this.get(r,"type.text")||"any"})${r.description?` - ${r.description}`:""}`).join("<br>")}static renderTable(e,r,o){if(o===void 0||o.length===0)return"";let n=o.filter(c=>{let a=c.description;return typeof a=="string"&&a.trim()});if(n.length===0)return"";let i=r.map(c=>this.capitalize((Array.isArray(c)?c[0]:c).split(".")[0])).join(" | "),s=r.map(()=>"---").join(" | "),l=n.map(c=>r.map(a=>{let u=this.get(c,a);return String(u||"").replace(/\|/g,"\\|").replace(/\n/g,"<br>")}).join(" | ")).join(`
21
+ `}static renderParameters(e){return!e||e.length===0?"None":e.map(r=>`\`${r.name}\` (${this.get(r,"type.text")||"any"})${r.description?` - ${r.description}`:""}`).join("<br>")}static renderTable(e,r,n){if(n===void 0||n.length===0)return"";let o=n.filter(c=>{let a=c.description;return typeof a=="string"&&a.trim()});if(o.length===0)return"";let s=r.map(c=>this.capitalize((Array.isArray(c)?c[0]:c).split(".")[0])).join(" | "),i=r.map(()=>"---").join(" | "),l=o.map(c=>r.map(a=>{let u=this.get(c,a);return String(u||"").replace(/\|/g,"\\|").replace(/\n/g,"<br>")}).join(" | ")).join(`
22
22
  `);return`
23
23
  ### ${e}
24
24
 
25
- | ${i} |
26
25
  | ${s} |
26
+ | ${i} |
27
27
  ${l}
28
28
 
29
- `}static get(e,r){let o="",n=r;Array.isArray(r)&&([n,o]=r);let i=n.split("."),s=e;for(;s&&i.length;)s=s[i.shift()];return s==null||s===""?o:String(s)}static capitalize(e){return e[0].toUpperCase()+e.substring(1)}};async function B(){let t=me("Generating Custom Elements Manifest...").start();try{await b("npx --package=@custom-elements-manifest/analyzer -y -- cem analyze --litelement --globs src/*.*js scripts/wca/**/*.*js --packagejson --dependencies"),t.succeed("Custom Elements Manifest generated successfully!")}catch(e){let r=e instanceof Error?e.message:String(e);t.warn("CEM analyzer completed with warnings: "+r)}}async function I(){let t=me("Generating API documentation...").start();try{await T.generate(),t.succeed("API documentation generated successfully!")}catch(e){let r=e instanceof Error?e.message:String(e);throw t.fail("Failed to generate API documentation: "+r),e}}async function j(){await B(),await I()}import{Logger as ze}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import{generateReadmeUrl as qe,processContentForFile as Ve,templateFiller as le}from"@aurodesignsystem/auro-library/scripts/utils/sharedFileProcessorUtils.mjs";var ue={overwriteLocalCopies:!0,remoteReadmeVersion:"master",remoteReadmeVariant:"_updated_paths"};function C(t){return`${process.cwd()}/${t}`}var Je=t=>[{identifier:"README.md",input:{remoteUrl:t.remoteReadmeUrl||qe(t.remoteReadmeVersion,t.remoteReadmeVariant),fileName:C("/docTemplates/README.md"),overwrite:t.overwriteLocalCopies},output:C("/README.md")},{identifier:"index.md",input:C("/docs/partials/index.md"),output:C("/demo/index.md"),mdMagicConfig:{output:{directory:C("/demo")}}},{identifier:"api.md",input:C("/docs/partials/api.md"),output:C("/demo/api.md"),preProcessors:[le.formatApiTable]}];async function Ye(t=ue){await le.extractNames();for(let e of Je(t))try{await Ve(e)}catch(r){ze.error(`Error processing ${e.identifier}: ${r.message}`)}}async function de(){await Ye({...ue,remoteReadmeUrl:"https://raw.githubusercontent.com/AlaskaAirlines/auro-templates/main/templates/default/README.md"})}function pe(){let t=Xe("./dist"),e=V("Cleaning dist folder...").start();try{return Ke(t,{recursive:!0,force:!0}),e.succeed("All clean! Dist folder wiped."),!0}catch(r){return e.fail(`Oops! Couldn't clean dist/ folder: ${r.message}`),console.error(r),!1}}async function J(t,e,r,o){let n=V(t).start();try{let i=await e();return n.succeed(r),i}catch(i){throw n.fail(o),console.error(`Error: ${i.message}`),i}}async function fe(t,e){return J("Creating type definitions...",async()=>{let r=await q(t);await r.write(e),await r.close()},"Types files built.","Darn! Type definitions failed.")}async function ge(t,e){return J(`Bundling ${t.name||"main"} and ${e.name||"demo"}...`,async()=>{let r=await q(t);await r.write(t.output),await r.close();let o=await q(e);await o.write(e.output),await o.close()},`Bundles ready! ${t.name||"Main"} and ${e.name||"demo"} built.`,"Bundle hiccup! Build failed.")}async function F(t){let{wcaInput:e,wcaOutput:r,skipDocs:o}=t;if(o){let n=V("Skipping docs generation...").start();setTimeout(()=>{n.succeed("Docs generation skipped.")},0);return}return J("Analyzing components and making docs...",async()=>{await j(e,r),await de()},"Docs ready! Looking good.","Doc troubles!")}import{basename as et,join as ye}from"node:path";import{nodeResolve as tt}from"@rollup/plugin-node-resolve";import{glob as rt}from"glob";import{dts as ot}from"rollup-plugin-dts";import{litScss as nt}from"rollup-plugin-scss-lit";import Qe from"node:path";import{glob as Ze}from"glob";function he(t){return{name:"watch-globs",buildStart(){let e=Array.isArray(t)?t:[t];for(let r of e)try{for(let o of Ze.sync(Qe.resolve(r)))this.addWatchFile(o)}catch(o){this.error(`Error watching glob pattern "${r}": ${o.message}`)}}}}var Y={moduleDirectories:["node_modules"],modulePaths:["../../node_modules","../node_modules","node_modules"],watchPatterns:["./apiExamples/**/*","./docs/**/*"]};function we(t=[],e={}){let{watchPatterns:r=Y.watchPatterns,dedupe:o=["lit","lit-element","lit-html"]}=e,n=[...Y.modulePaths,...t];return[tt({dedupe:o,preferBuiltins:!1,moduleDirectories:Y.moduleDirectories}),nt({minify:{fast:!0},options:{loadPaths:[...n,ye(process.cwd(),"src","styles"),ye(process.cwd(),"src")]}}),he(r)]}function K(t={}){let{modulePaths:e=[],watch:r=!1,input:o=["./src/index.js","./src/registered.js"],outputDir:n="./dist",format:i="esm"}=t;return{name:"Main",config:{input:o,output:{format:i,dir:n,entryFileNames:"[name].js"},external:it(),plugins:we(e),watch:be(r)}}}function X(t={}){let{modulePaths:e=[],watch:r=!1,globPattern:o="./demo/*.js",ignorePattern:n=["./demo/*.min.js"],outputDir:i="./demo"}=t;return{name:"Demo",config:{input:Object.fromEntries(rt.sync(o,{ignore:n}).map(s=>[et(s,".js"),s])),output:{format:"esm",dir:i,entryFileNames:"[name].min.js",chunkFileNames:"[name].min.js"},plugins:we(e),watch:be(r)}}}function v(t={}){let{input:e=["./dist/index.js"],outputDir:r="./dist"}=t;return{name:"DTS",config:{input:e,output:{format:"esm",dir:r,entryFileNames:"[name].d.ts"},plugins:[ot()]}}}function be(t){if(!t)return!1;let e=typeof t=="object"?t:{};return{clearScreen:e.clearScreen??!0,buildDelay:e.buildDelay??500,chokidar:{ignoreInitial:!0,ignored:e.ignored??["**/dist/**/*.d.ts","**/custom-elements.json","**/demo/*.md","**/demo/**/*.min.js","**/docs/api.md","**/node_modules/**","**/.git/**"],awaitWriteFinish:e.awaitWriteFinish??{stabilityThreshold:1e3,pollInterval:100}},include:e.include??["./src/**/*.scss","./src/**/*.js","./src/**/*.ts","./demo/**/*.js","./apiExamples/**/*","./docs/**/*.md"],exclude:e.exclude??["./dist/**/*","./node_modules/**/*"]}}function it(t=[]){return[...[/node_modules\/lit/,/node_modules\/lit-element/,/node_modules\/lit-html/,/node_modules\/@lit/],...t]}import{startDevServer as st}from"@web/dev-server";import{hmrPlugin as at}from"@web/dev-server-hmr";import ct from"ora";var k={watch:!0,nodeResolve:!0,basePath:"/",rootDir:"./demo",hmrInclude:["src/**/*","demo/**/*","apiExamples/**/*","docs/**/*"]};async function $e(t={}){if(!t.serve)return;let e=ct(`Firing up dev server...
30
- `).start();try{let r={port:Number(t.port)||void 0,open:t.open?"/":void 0,watch:t.watch??k.watch,nodeResolve:t.nodeResolve??k.nodeResolve,basePath:t.basePath??k.basePath,rootDir:t.rootDir??k.rootDir,middleware:[function(i,s){return!i.url.endsWith("/")&&!i.url.includes(".")&&(i.url+=".html"),s()}],plugins:[at({include:t.hmrInclude??k.hmrInclude})]},o=await st({config:r,readCliArgs:!1,readFileConfig:!1});return e.stop(),o}catch(r){throw e.fail("Server snag! Couldn't start dev server."),console.error("Error starting development server:",r),new Error(`Development server failed to start: ${r.message}`)}}import Ee from"node:path";import w from"ora";import{rollup as mt}from"rollup";var O=!1,lt={dts:{active:!1,lastTime:0},analyze:{active:!1,lastTime:0},docs:{active:!1,lastTime:0}},ut=5e3,N=new Set,dt=["/dist/index.d.ts","/custom-elements.json","/demo/api.md","/docs/api.md","/demo/index.min.js"];function pt(t){if(!t||typeof t!="string")return!1;try{let e=Ee.normalize(t);return dt.some(r=>e.endsWith(r))||e.includes("/dist/")||e.endsWith(".min.js")||e.endsWith(".d.ts")}catch(e){return console.error(`Error checking path (${typeof t}):`,e.message),!1}}async function Q(t,e){let r=lt[t];if(r.active||Date.now()-r.lastTime<ut)return!1;try{return r.active=!0,r.lastTime=Date.now(),await e()}catch(o){return console.error(`Error in ${t} task:`,o),!1}finally{r.active=!1}}async function Ce(t,e,r){let o=!0,n={dts:!1,analyze:!1,docs:!1},i=null,s,l=w("Activating watch mode...").start(),c={dts:async()=>{let m=w("Crafting type definitions...").start();try{let d=await mt(v().config);return await d.write(v().config.output),await d.close(),m.succeed("Type files built."),!0}catch(d){return m.fail("Types trouble! Build failed."),console.error("TypeScript definition build error:",d),!1}},analyze:async()=>{let{wcaInput:m,wcaOutput:d,skipDocs:h}=e;if(h){let y=w("Skipping component analysis...").start();return setTimeout(()=>{y.succeed("Component analysis skipped.")},0),!0}let E=w("Detective work: analyzing components...").start();try{return await j(m,d),E.succeed("Component analysis complete! API generated."),!0}catch(y){return E.fail("Analysis hiccup! Something went wrong."),console.error("Component analysis error:",y),!1}},docs:async()=>{if(O)return!1;if(e.skipDocs){let d=w("Skipping docs generation...").start();return setTimeout(()=>{d.succeed("Docs generation skipped.")},0),!0}let m=w("Refreshing docs...").start();try{return await F(e),m.succeed("Documentation refreshed!"),!0}catch(d){m.fail("Docs stumble! Couldn't refresh."),console.error("Documentation rebuild error:",d)}}},a=()=>{o&&n.dts&&n.analyze&&n.docs&&typeof r=="function"&&(o=!1,r())};function u(m=1e3){i&&clearTimeout(i),i=setTimeout(async()=>{n.dts=await Q("dts",c.dts),setTimeout(async()=>{n.analyze=await Q("analyze",c.analyze),setTimeout(async()=>{n.docs=await Q("docs",c.docs),a()},1e3)},1e3)},m)}t.on("event",async m=>{switch(m.code){case"START":l.succeed("Watch mode active! Eyes peeled.");break;case"BUNDLE_START":if(N.clear(),m.input)try{let d=Array.isArray(m.input)?m.input:typeof m.input=="string"?[m.input]:typeof m.input=="object"&&m.input!==null?Object.values(m.input):[];for(let h of d)typeof h=="string"&&!pt(h)&&N.add(Ee.normalize(h))}catch(d){console.error("Error processing input paths:",d)}s=w("Weaving bundles...").start(),O=!0;break;case"BUNDLE_END":s&&s.succeed(`Bundle ${Array.isArray(m.input)?`of ${m.input.join("& ")} `:""}done in ${m.duration}ms! \u{1F680}`),O=!1,N.size>0&&u();break;case"END":break;case"ERROR":O=!1,s?s.fail(`Oops! Bundle hit a snag: ${m.error.message}`):w().fail(`Watch mode hiccup: ${m.error.message}`),N.clear();break}})}function xe(t){return process.on("SIGINT",()=>{let e=w("Wrapping up...").start();t.close(),e.succeed("All done! See you next time. \u2728"),process.exit(0)}),t}async function ht(t){let e=K(t),r=X(t),o=v();e.config.plugins.push(ft()),await F(t),await ge(e.config,r.config),await fe(o.config,o.config.output)}async function yt(t){let{dev:e}=t,r=K({...t,watch:!0}),o=X({...t,watch:!0}),n=gt([r.config,o.config]);return Ce(n,t,e?async()=>$e(t):void 0),xe(n),n}async function M(t={}){try{let{watch:e}=t;return pe(),e?await yt(t):await ht(t)}catch(e){throw new Error(`Build failed: ${e.message}`)}}var S=wt.command("dev").description("Runs development server for auro components");S=R(S);S=ce(S);var ho=S.action(async t=>{try{let e=Te("Initializing...");t.watch?(e.text="Waiting for changes...",e.spinner="bouncingBar",e.color="green"):e.text=t.docs===!1?"Building component (docs disabled)":"Building component",e.start(),t.watch||e.succeed("Build completed!"),await M({...t,dev:!0,watch:t.watch})}catch(e){Te().fail(`Build failed: ${e.message}`),console.error(e),process.exit(1)}});import{program as bt}from"commander";import ve from"ora";var Z=bt.command("build").description("Builds auro components");Z=R(Z);var Co=Z.action(async t=>{try{let e=ve("Initializing...");t.watch?(e.text="Waiting for changes...",e.spinner="bouncingBar",e.color="green"):e.text=t.docs===!1?"Building component (docs disabled)":"Building component",e.start(),await M(t),t.watch||e.succeed("Build completed!")}catch(e){ve().fail(`Build failed: ${e.message}`),console.error(e),process.exit(1)}});import{exec as $t}from"node:child_process";import ke from"node:path";import Et from"node:process";import{fileURLToPath as Ct}from"node:url";import xt from"node:util";import{program as Tt}from"commander";import vt from"inquirer";var _o=Tt.command("migrate").description("Script runner to perform repetitive code change tasks").requiredOption("-i, --id <string>","Select the migration you would like to run by id").option("-m, --multi-gitter","Run the migration on all repositories in the multi-gitter config").action(async t=>{let e=Ct(import.meta.url),r=ke.dirname(e),o=ke.resolve(r,"migrations",t.id);if(t.multiGitter){let n=xt.promisify($t);try{await n("command -v multi-gitter")}catch{console.error("multi-gitter is not installed."),Et.exit(1)}(await vt.prompt([{type:"confirm",name:"dryRun",message:"Run migration in dry-run mode? (no changes will be committed)",default:!0}])).dryRun?b(`multi-gitter run ${o}/script.sh --config "${o}/multi-gitter.yml" --dry-run`):b(`multi-gitter run ${o}/script.sh --config "${o}/multi-gitter.yml"`)}else b(`${o}/script.sh`)});import It from"node:process";import{program as jt}from"commander";import{readFile as Ft,writeFile as Ot}from"node:fs/promises";import{Logger as te}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import kt from"node:fs/promises";import{Logger as $}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import{processContentForFile as St,templateFiller as Dt}from"@aurodesignsystem/auro-library/scripts/utils/sharedFileProcessorUtils.mjs";var ee="https://raw.githubusercontent.com/AlaskaAirlines/auro-templates",Se="main",Pt="main",At="default",De={ISSUE_TEMPLATE:["bug_report.yaml","config.yml","feature_request.yaml","general-support.yaml","group.yaml","story.yaml","task.yaml"],workflows:["codeql.yml","publishDemo.yml","testPublish.yml"],_root:["CODEOWNERS","CODE_OF_CONDUCT.md","CONTRIBUTING.md","PULL_REQUEST_TEMPLATE.md","SECURITY.md","settings.yml","stale.yml"]};function Rt(t,e){return t.startsWith("v")&&/^\d+\.\d+\.\d+(?<_>-.*)?$/u.test(t.slice(1))?`${ee}/refs/tags/${t}/${e}`:t!==Se?`${ee}/refs/heads/${t}/${e}`:`${ee}/${Se}/${e}`}function _t(t,e,r){let o=Rt(e,t);return{identifier:t.split("/").pop(),input:{remoteUrl:o,fileName:r,overwrite:!0},output:r,overwrite:!0}}async function Bt(t){try{await kt.rm(t,{recursive:!0,force:!0}),$.log(`Successfully removed directory: ${t}`)}catch(e){throw $.error(`Error removing directory ${t}: ${e.message}`),e}}async function Pe(t){t||($.error("Root directory must be specified"),process.exit(1));let e=".github";try{await Bt(e),$.log(".github directory removed successfully")}catch(n){$.error(`Error removing .github directory: ${n.message}`),process.exit(1)}await Dt.extractNames();let r=[],o=[];for(let n of Object.keys(De))for(let i of De[n]){let s=`${n==="_root"?"":`${n}/`}${i}`,l=`${t}/.github/${s}`,c=_t(`templates/${At}/.github/${s}`,Pt,l);r.push(c)}if(await Promise.all(r.map(async n=>{try{(await fetch(n.input.remoteUrl,{method:"HEAD"})).ok||o.push(n.input.remoteUrl)}catch{o.push(n.input.remoteUrl)}})),o.length>0){let n=o.map(i=>`File not found: ${i}`).join(`
31
- `);$.error(`Failed to sync .github directory. Confirm githubDirShape object is up to date:
32
- ${n}`),process.exit(1)}try{await Promise.all(r.map(n=>St(n))),$.log("All files processed.")}catch(n){$.error(`Error processing files: ${n.message}`),process.exit(1)}}var Wo=jt.command("sync").description("Script runner to synchronize local repository configuration files").action(async()=>{te.info("Synchronizing repository configuration files..."),te.warn("Note: sync does not create a new git branch. Changes are added to the current branch.");let t=It.cwd();await Pe(t);let e=`${t}/.github/CODEOWNERS`,o=(await Ft(e,{encoding:"utf-8"})).replace(/\r\n/gu,`
29
+ `}static get(e,r){let n="",o=r;Array.isArray(r)&&([o,n]=r);let s=o.split("."),i=e;for(;i&&s.length;)i=i[s.shift()];return i==null||i===""?n:String(i)}static capitalize(e){return e[0].toUpperCase()+e.substring(1)}};async function O(){let t=he("Generating Custom Elements Manifest...").start();try{await h("npx --package=@custom-elements-manifest/analyzer -y -- cem analyze --litelement --globs src/*.*js scripts/wca/**/*.*js --packagejson --dependencies"),t.succeed("Custom Elements Manifest generated successfully!")}catch(e){let r=e instanceof Error?e.message:String(e);t.warn("CEM analyzer completed with warnings: "+r)}}async function _(){let t=he("Generating API documentation...").start();try{await x.generate(),t.succeed("API documentation generated successfully!")}catch(e){let r=e instanceof Error?e.message:String(e);throw t.fail("Failed to generate API documentation: "+r),e}}async function B(){await O(),await _()}import{Logger as it}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import{generateReadmeUrl as st,processContentForFile as at,templateFiller as ye}from"@aurodesignsystem/auro-library/scripts/utils/sharedFileProcessorUtils.mjs";var we={overwriteLocalCopies:!0,remoteReadmeVersion:"master",remoteReadmeVariant:"_updated_paths"};function $(t){return`${process.cwd()}/${t}`}var ct=t=>[{identifier:"README.md",input:{remoteUrl:t.remoteReadmeUrl||st(t.remoteReadmeVersion,t.remoteReadmeVariant),fileName:$("/docTemplates/README.md"),overwrite:t.overwriteLocalCopies},output:$("/README.md")},{identifier:"index.md",input:$("/docs/partials/index.md"),output:$("/demo/index.md"),mdMagicConfig:{output:{directory:$("/demo")}}},{identifier:"api.md",input:$("/docs/partials/api.md"),output:$("/demo/api.md"),preProcessors:[ye.formatApiTable]}];async function lt(t=we){await ye.extractNames();for(let e of ct(t))try{await at(e)}catch(r){it.error(`Error processing ${e.identifier}: ${r.message}`)}}async function be(){await lt({...we,remoteReadmeUrl:"https://raw.githubusercontent.com/AlaskaAirlines/auro-templates/main/templates/default/README.md"})}function ke(){let t=ut("./dist"),e=V("Cleaning dist folder...").start();try{return mt(t,{recursive:!0,force:!0}),e.succeed("All clean! Dist folder wiped."),!0}catch(r){return e.fail(`Oops! Couldn't clean dist/ folder: ${r.message}`),console.error(r),!1}}async function Y(t,e,r,n){let o=V(t).start();try{let s=await e();return o.succeed(r),s}catch(s){throw o.fail(n),console.error(`Error: ${s.message}`),s}}async function Ae(t,e){return Y("Creating type definitions...",async()=>{let r=await J(t);await r.write(e),await r.close()},"Types files built.","Darn! Type definitions failed.")}async function $e(t,e){return Y(`Bundling ${t.name||"main"} and ${e.name||"demo"}...`,async()=>{let r=await J(t);await r.write(t.output),await r.close();let n=await J(e);await n.write(e.output),await n.close()},`Bundles ready! ${t.name||"Main"} and ${e.name||"demo"} built.`,"Bundle hiccup! Build failed.")}async function I(t){let{wcaInput:e,wcaOutput:r,skipDocs:n}=t;if(n){let o=V("Skipping docs generation...").start();setTimeout(()=>{o.succeed("Docs generation skipped.")},0);return}return Y("Analyzing components and making docs...",async()=>{await B(e,r),await be()},"Docs ready! Looking good.","Doc troubles!")}import{basename as ft,join as xe}from"node:path";import{nodeResolve as gt}from"@rollup/plugin-node-resolve";import{glob as ht}from"glob";import{dts as yt}from"rollup-plugin-dts";import{litScss as wt}from"rollup-plugin-scss-lit";import dt from"node:path";import{glob as pt}from"glob";function Ee(t){return{name:"watch-globs",buildStart(){let e=Array.isArray(t)?t:[t];for(let r of e)try{for(let n of pt.sync(dt.resolve(r)))this.addWatchFile(n)}catch(n){this.error(`Error watching glob pattern "${r}": ${n.message}`)}}}}var K={moduleDirectories:["node_modules"],modulePaths:["../../node_modules","../node_modules","node_modules"],watchPatterns:["./apiExamples/**/*","./docs/**/*"]};function Ce(t=[],e={}){let{watchPatterns:r=K.watchPatterns,dedupe:n=["lit","lit-element","lit-html"]}=e,o=[...K.modulePaths,...t];return[gt({dedupe:n,preferBuiltins:!1,moduleDirectories:K.moduleDirectories}),wt({minify:{fast:!0},options:{loadPaths:[...o,xe(process.cwd(),"src","styles"),xe(process.cwd(),"src")]}}),Ee(r)]}function X(t={}){let{modulePaths:e=[],watch:r=!1,input:n=["./src/index.js","./src/registered.js"],outputDir:o="./dist",format:s="esm"}=t;return{name:"Main",config:{input:n,output:{format:s,dir:o,entryFileNames:"[name].js"},external:bt(),plugins:Ce(e),watch:Te(r)}}}function Q(t={}){let{modulePaths:e=[],watch:r=!1,globPattern:n="./demo/*.js",ignorePattern:o=["./demo/*.min.js"],outputDir:s="./demo"}=t;return{name:"Demo",config:{input:Object.fromEntries(ht.sync(n,{ignore:o}).map(i=>[ft(i,".js"),i])),output:{format:"esm",dir:s,entryFileNames:"[name].min.js",chunkFileNames:"[name].min.js"},plugins:Ce(e),watch:Te(r)}}}function C(t={}){let{input:e=["./dist/index.js"],outputDir:r="./dist"}=t;return{name:"DTS",config:{input:e,output:{format:"esm",dir:r,entryFileNames:"[name].d.ts"},plugins:[yt()]}}}function Te(t){if(!t)return!1;let e=typeof t=="object"?t:{};return{clearScreen:e.clearScreen??!0,buildDelay:e.buildDelay??500,chokidar:{ignoreInitial:!0,ignored:e.ignored??["**/dist/**/*.d.ts","**/custom-elements.json","**/demo/*.md","**/demo/**/*.min.js","**/docs/api.md","**/node_modules/**","**/.git/**"],awaitWriteFinish:e.awaitWriteFinish??{stabilityThreshold:1e3,pollInterval:100}},include:e.include??["./src/**/*.scss","./src/**/*.js","./src/**/*.ts","./demo/**/*.js","./apiExamples/**/*","./docs/**/*.md"],exclude:e.exclude??["./dist/**/*","./node_modules/**/*"]}}function bt(t=[]){return[...[/node_modules\/lit/,/node_modules\/lit-element/,/node_modules\/lit-html/,/node_modules\/@lit/],...t]}import{startDevServer as kt}from"@web/dev-server";import{hmrPlugin as At}from"@web/dev-server-hmr";import $t from"ora";var T={watch:!0,nodeResolve:!0,basePath:"/",rootDir:"./demo",hmrInclude:["src/**/*","demo/**/*","apiExamples/**/*","docs/**/*"]};async function ve(t={}){if(!t.serve)return;let e=$t(`Firing up dev server...
30
+ `).start();try{let r={port:Number(t.port)||void 0,open:t.open?"/":void 0,watch:t.watch??T.watch,nodeResolve:t.nodeResolve??T.nodeResolve,basePath:t.basePath??T.basePath,rootDir:t.rootDir??T.rootDir,middleware:[function(s,i){return!s.url.endsWith("/")&&!s.url.includes(".")&&(s.url+=".html"),i()}],plugins:[At({include:t.hmrInclude??T.hmrInclude})]},n=await kt({config:r,readCliArgs:!1,readFileConfig:!1});return e.stop(),n}catch(r){throw e.fail("Server snag! Couldn't start dev server."),console.error("Error starting development server:",r),new Error(`Development server failed to start: ${r.message}`)}}import De from"node:path";import b from"ora";import{rollup as Et}from"rollup";var N=!1,xt={dts:{active:!1,lastTime:0},analyze:{active:!1,lastTime:0},docs:{active:!1,lastTime:0}},Ct=5e3,F=new Set,Tt=["/dist/index.d.ts","/custom-elements.json","/demo/api.md","/docs/api.md","/demo/index.min.js"];function vt(t){if(!t||typeof t!="string")return!1;try{let e=De.normalize(t);return Tt.some(r=>e.endsWith(r))||e.includes("/dist/")||e.endsWith(".min.js")||e.endsWith(".d.ts")}catch(e){return console.error(`Error checking path (${typeof t}):`,e.message),!1}}async function Z(t,e){let r=xt[t];if(r.active||Date.now()-r.lastTime<Ct)return!1;try{return r.active=!0,r.lastTime=Date.now(),await e()}catch(n){return console.error(`Error in ${t} task:`,n),!1}finally{r.active=!1}}async function Pe(t,e,r){let n=!0,o={dts:!1,analyze:!1,docs:!1},s=null,i,l=b("Activating watch mode...").start(),c={dts:async()=>{let m=b("Crafting type definitions...").start();try{let d=await Et(C().config);return await d.write(C().config.output),await d.close(),m.succeed("Type files built."),!0}catch(d){return m.fail("Types trouble! Build failed."),console.error("TypeScript definition build error:",d),!1}},analyze:async()=>{let{wcaInput:m,wcaOutput:d,skipDocs:y}=e;if(y){let w=b("Skipping component analysis...").start();return setTimeout(()=>{w.succeed("Component analysis skipped.")},0),!0}let A=b("Detective work: analyzing components...").start();try{return await B(m,d),A.succeed("Component analysis complete! API generated."),!0}catch(w){return A.fail("Analysis hiccup! Something went wrong."),console.error("Component analysis error:",w),!1}},docs:async()=>{if(N)return!1;if(e.skipDocs){let d=b("Skipping docs generation...").start();return setTimeout(()=>{d.succeed("Docs generation skipped.")},0),!0}let m=b("Refreshing docs...").start();try{return await I(e),m.succeed("Documentation refreshed!"),!0}catch(d){m.fail("Docs stumble! Couldn't refresh."),console.error("Documentation rebuild error:",d)}}},a=()=>{n&&o.dts&&o.analyze&&o.docs&&typeof r=="function"&&(n=!1,r())};function u(m=1e3){s&&clearTimeout(s),s=setTimeout(async()=>{o.dts=await Z("dts",c.dts),setTimeout(async()=>{o.analyze=await Z("analyze",c.analyze),setTimeout(async()=>{o.docs=await Z("docs",c.docs),a()},1e3)},1e3)},m)}t.on("event",async m=>{switch(m.code){case"START":l.succeed("Watch mode active! Eyes peeled.");break;case"BUNDLE_START":if(F.clear(),m.input)try{let d=Array.isArray(m.input)?m.input:typeof m.input=="string"?[m.input]:typeof m.input=="object"&&m.input!==null?Object.values(m.input):[];for(let y of d)typeof y=="string"&&!vt(y)&&F.add(De.normalize(y))}catch(d){console.error("Error processing input paths:",d)}i=b("Weaving bundles...").start(),N=!0;break;case"BUNDLE_END":i&&i.succeed(`Bundle ${Array.isArray(m.input)?`of ${m.input.join("& ")} `:""}done in ${m.duration}ms! \u{1F680}`),N=!1,F.size>0&&u();break;case"END":break;case"ERROR":N=!1,i?i.fail(`Oops! Bundle hit a snag: ${m.error.message}`):b().fail(`Watch mode hiccup: ${m.error.message}`),F.clear();break}})}function Se(t){return process.on("SIGINT",()=>{let e=b("Wrapping up...").start();t.close(),e.succeed("All done! See you next time. \u2728"),process.exit(0)}),t}async function St(t){let e=X(t),r=Q(t),n=C();e.config.plugins.push(Dt()),await I(t),await $e(e.config,r.config),await Ae(n.config,n.config.output)}async function Rt(t){let{dev:e}=t,r=X({...t,watch:!0}),n=Q({...t,watch:!0}),o=Pt([r.config,n.config]);return Pe(o,t,e?async()=>ve(t):void 0),Se(o),o}async function M(t={}){try{let{watch:e}=t;return ke(),e?await Rt(t):await St(t)}catch(e){throw new Error(`Build failed: ${e.message}`)}}var v=jt.command("dev").description("Runs development server for auro components");v=R(v);v=ge(v);var Wn=v.action(async t=>{try{let e=Re("Initializing...");t.watch?(e.text="Waiting for changes...",e.spinner="bouncingBar",e.color="green"):e.text=t.docs===!1?"Building component (docs disabled)":"Building component",e.start(),t.watch||e.succeed("Build completed!"),await M({...t,dev:!0,watch:t.watch})}catch(e){Re().fail(`Build failed: ${e.message}`),console.error(e),process.exit(1)}});import{program as Ot}from"commander";import je from"ora";var ee=Ot.command("build").description("Builds auro components");ee=R(ee);var Yn=ee.action(async t=>{try{let e=je("Initializing...");t.watch?(e.text="Waiting for changes...",e.spinner="bouncingBar",e.color="green"):e.text=t.docs===!1?"Building component (docs disabled)":"Building component",e.start(),await M(t),t.watch||e.succeed("Build completed!")}catch(e){je().fail(`Build failed: ${e.message}`),console.error(e),process.exit(1)}});import{exec as _t}from"node:child_process";import Oe from"node:path";import Bt from"node:process";import{fileURLToPath as It}from"node:url";import Nt from"node:util";import{program as Ft}from"commander";import Mt from"inquirer";var io=Ft.command("migrate").description("Script runner to perform repetitive code change tasks").requiredOption("-i, --id <string>","Select the migration you would like to run by id").option("-m, --multi-gitter","Run the migration on all repositories in the multi-gitter config").action(async t=>{let e=It(import.meta.url),r=Oe.dirname(e),n=Oe.resolve(r,"migrations",t.id);if(t.multiGitter){let o=Nt.promisify(_t);try{await o("command -v multi-gitter")}catch{console.error("multi-gitter is not installed."),Bt.exit(1)}(await Mt.prompt([{type:"confirm",name:"dryRun",message:"Run migration in dry-run mode? (no changes will be committed)",default:!0}])).dryRun?h(`multi-gitter run ${n}/script.sh --config "${n}/multi-gitter.yml" --dry-run`):h(`multi-gitter run ${n}/script.sh --config "${n}/multi-gitter.yml"`)}else h(`${n}/script.sh`)});import Vt from"node:process";import{program as Yt}from"commander";import{readFile as Kt,writeFile as Xt}from"node:fs/promises";import{Logger as re}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import Gt from"node:fs/promises";import{Logger as k}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import{processContentForFile as Ut,templateFiller as Lt}from"@aurodesignsystem/auro-library/scripts/utils/sharedFileProcessorUtils.mjs";var te="https://raw.githubusercontent.com/AlaskaAirlines/auro-templates",_e="main",Wt="main",Ht="default",Be={ISSUE_TEMPLATE:["bug_report.yaml","config.yml","feature_request.yaml","general-support.yaml","group.yaml","story.yaml","task.yaml"],workflows:["codeql.yml","publishDemo.yml","testPublish.yml"],_root:["CODEOWNERS","CODE_OF_CONDUCT.md","CONTRIBUTING.md","PULL_REQUEST_TEMPLATE.md","SECURITY.md","settings.yml","stale.yml"]};function zt(t,e){return t.startsWith("v")&&/^\d+\.\d+\.\d+(?<_>-.*)?$/u.test(t.slice(1))?`${te}/refs/tags/${t}/${e}`:t!==_e?`${te}/refs/heads/${t}/${e}`:`${te}/${_e}/${e}`}function qt(t,e,r){let n=zt(e,t);return{identifier:t.split("/").pop(),input:{remoteUrl:n,fileName:r,overwrite:!0},output:r,overwrite:!0}}async function Jt(t){try{await Gt.rm(t,{recursive:!0,force:!0}),k.log(`Successfully removed directory: ${t}`)}catch(e){throw k.error(`Error removing directory ${t}: ${e.message}`),e}}async function Ie(t){t||(k.error("Root directory must be specified"),process.exit(1));let e=".github";try{await Jt(e),k.log(".github directory removed successfully")}catch(o){k.error(`Error removing .github directory: ${o.message}`),process.exit(1)}await Lt.extractNames();let r=[],n=[];for(let o of Object.keys(Be))for(let s of Be[o]){let i=`${o==="_root"?"":`${o}/`}${s}`,l=`${t}/.github/${i}`,c=qt(`templates/${Ht}/.github/${i}`,Wt,l);r.push(c)}if(await Promise.all(r.map(async o=>{try{(await fetch(o.input.remoteUrl,{method:"HEAD"})).ok||n.push(o.input.remoteUrl)}catch{n.push(o.input.remoteUrl)}})),n.length>0){let o=n.map(s=>`File not found: ${s}`).join(`
31
+ `);k.error(`Failed to sync .github directory. Confirm githubDirShape object is up to date:
32
+ ${o}`),process.exit(1)}try{await Promise.all(r.map(o=>Ut(o))),k.log("All files processed.")}catch(o){k.error(`Error processing files: ${o.message}`),process.exit(1)}}var yo=Yt.command("sync").description("Script runner to synchronize local repository configuration files").action(async()=>{re.info("Synchronizing repository configuration files..."),re.warn("Note: sync does not create a new git branch. Changes are added to the current branch.");let t=Vt.cwd();await Ie(t);let e=`${t}/.github/CODEOWNERS`,n=(await Kt(e,{encoding:"utf-8"})).replace(/\r\n/gu,`
33
33
  `).replace(/\n\n/gu,`
34
- `);await Ot(e,o,{encoding:"utf-8"}),(o.includes("\r")||o.includes(`
34
+ `);await Xt(e,n,{encoding:"utf-8"}),(n.includes("\r")||n.includes(`
35
35
 
36
- `))&&te.error("CODEOWNERS file still has Windows line endings.")});import G from"node:fs";import D from"node:path";import{Logger as Re}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import{program as Nt}from"commander";import{glob as Mt}from"glob";var Ae=(t,e)=>{let r=(t.match(/static register\(name \= (.+)\)/)||t.match(/customElements.get\((.+?)\)/))[1],o=t.match(/export class (.+) extends/)?.[1],n=t.match(/\/\*\*((.|\n)*?)(\*\n|\*\/|[@])/)?.[1]||"";return!r||!o?t:`
37
- import { ${o} } from '${e}';
36
+ `))&&re.error("CODEOWNERS file still has Windows line endings.")});import G from"node:fs";import D from"node:path";import{Logger as Fe}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import{program as Qt}from"commander";import{glob as Zt}from"glob";var Ne=(t,e)=>{let r=(t.match(/static register\(name \= (.+)\)/)||t.match(/customElements.get\((.+?)\)/))[1],n=t.match(/export class (.+) extends/)?.[1],o=t.match(/\/\*\*((.|\n)*?)(\*\n|\*\/|[@])/)?.[1]||"";return!r||!n?t:`
37
+ import { ${n} } from '${e}';
38
38
 
39
- /**${n}*/
40
- class ${o}WCA extends ${o} {}
39
+ /**${o}*/
40
+ class ${n}WCA extends ${n} {}
41
41
 
42
42
  if (!customElements.get(${r})) {
43
- customElements.define(${r}, ${o}WCA);
43
+ customElements.define(${r}, ${n}WCA);
44
44
  }
45
- `};var L=D.resolve(process.cwd(),"./scripts/wca");async function Gt(t){try{return(await Promise.all(t.map(r=>Mt(r)))).flat()}catch(e){throw console.error("Error processing glob patterns:",e),e}}async function Lt(t){G.existsSync(L)||await G.promises.mkdir(L,{recursive:!0});for(let e of t){let r=D.resolve(process.cwd(),e),o=await G.promises.readFile(r,"utf-8"),n=D.resolve(L,`${D.basename(e)}`),i=Ae(o,D.relative(L,e));await G.promises.writeFile(n,i)}}async function Ut(){let t=await Gt(["./src/auro-*.js"]);await Lt(t)}var Qo=Nt.command("wca-setup").description("Set up WCA (Web Component Analyzer) for the project").action(()=>{Ut().then(()=>{Re.success("WCA setup completed successfully.")}).catch(t=>{Re.error(`WCA setup failed: ${t.message}`)})});import{program as Kt}from"commander";import Jt from"chalk";import je from"ora";import{appendFile as Wt,readFile as Ht}from"node:fs/promises";import{Logger as p}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import{simpleGit as zt}from"simple-git";var g;try{g=zt({baseDir:process.cwd(),binary:"git",maxConcurrentProcesses:1})}catch(t){p.error(`Failed to initialize git: ${t}`),g={}}var U=class t{static async checkGitignore(e){if(e==="")return!1;try{return(await Ht(".gitignore","utf-8")).includes(e)}catch(r){return p.error(`Error reading file: ${r}`),!1}}static async getCommitMessages(){try{let e=await g.branchLocal();p.info(`Current branch: ${e.current}`);let r="main",o="";if(!!process.env.GITHUB_ACTIONS){p.info("Running in GitHub Actions environment"),r=process.env.GITHUB_BASE_REF||"main";try{await g.fetch("origin",r),p.info(`Fetched target branch: origin/${r}`),o=`${(await g.raw(["merge-base",`origin/${r}`,"HEAD"])).trim()}..HEAD`,p.info(`Using commit range: ${o}`)}catch(i){p.warn(`Error setting up commit range in CI: ${i}`),o=`origin/${r}..HEAD`,p.info(`Falling back to commit range: ${o}`)}}else{p.info("Running in local environment");try{try{await g.raw(["rev-parse","--verify",`origin/${r}`])}catch{p.info(`Fetching ${r} from origin`),await g.fetch("origin",r)}o=`${(await g.raw(["merge-base",`origin/${r}`,e.current])).trim()}..HEAD`,p.info(`Using commit range for PR commits: ${o}`)}catch(i){p.warn(`Error determining PR commits locally: ${i}`),p.info("Falling back to analyzing recent commits"),o="HEAD~10..HEAD",p.info(`Using fallback commit range: ${o}`)}}return await t.getFormattedCommits(o)}catch(e){return p.error(`Error getting commit messages: ${e}`),[]}}static async getFormattedCommits(e){let o=(await g.raw(["log","--pretty=format:COMMIT_START%n%H%n%ad%n%an%n%s%n%b%nCOMMIT_END","--date=short",e])).split(`COMMIT_START
46
- `).filter(i=>i.trim()!==""),n=[];for(let i of o){let s=i.split(`
47
- `);if(s.length>=4){let l=s[0],c=s[1],a=s[2],u=s[3],m=s.slice(4).filter(H=>H!=="COMMIT_END"),d=m.length>0?m.join(""):"",h=l.substring(0,7),E=u.match(/^(feat|fix|docs|style|refactor|perf|test|build|ci|chore)(\(.+\))?:/),y=E?E[1]:"unknown";d.includes("BREAKING CHANGE")&&(y="breaking"),n.push({type:y,hash:h,date:c,subject:u,body:d,message:`${u}${d?`
48
-
49
- ${d}`:""}`,author_name:a})}}return n}static async addToGitignore(e,r=!0){await t.checkGitignore(e).then(async o=>{if(o)p.warn(`${e} already exists`);else try{await Wt(".gitignore",`
50
- ${e}`),r&&p.success(`${e} added to .gitignore`)}catch(n){p.error(n)}})}static async removeFromGitCache(e){try{await g.rmKeepLocal(e),p.success(`${e.join(", ")} are removed from git cache`)}catch(r){p.error(r)}}static async createBranch(e){try{await g.checkoutLocalBranch(e),p.success(`Created and switched to ${e} branch`)}catch(r){p.error(r)}}static async commitStagedFiles(e){try{await g.add("."),await g.commit(e),p.success(`Committed with message: ${e}`)}catch(r){p.error(r)}}};import f from"chalk";var qt=60,Vt=100;function P(t){switch(t){case"breaking":return f.bold.red(t);case"feat":return f.bold.green(t);case"fix":return f.bold.green(t);case"perf":return f.bold.green(t);case"docs":return f.bold.cyan(t);case"style":return f.bold.cyan(t);case"refactor":return f.bold.cyan(t);case"test":return f.bold.cyan(t);case"build":return f.bold.cyan(t);case"ci":return f.bold.cyan(t);case"chore":return f.bold.cyan(t);default:return f.bold.white(t)}}function _e(t,e){if(!t)return"";if(t.length<=e)return t;let r=t.split(" "),o="",n="";for(let i of r)(n+i).length>e&&n.length>0&&(o+=`${n.trim()}
51
- `,n=""),n=`${n}${i} `;return n.length>0&&(o+=n.trim()),o}function Be(t){for(let e of t){console.log("\u2500".repeat(60));let r=_e(e.subject,qt),o=_e(e.body,Vt);console.log(f.bold(`${P(e.type)}`)),console.log(f.dim(`${e.hash} | ${e.date} | ${e.author_name}`)),console.log(f.bold(`${f.white(r)}`)),e.body&&console.log(f.dim(o))}console.log("\u2500".repeat(60)),console.log(`
52
- `)}import W from"@actions/github";async function re(){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=W.getOctokit(t),{context:r}=W;if(!r.payload.pull_request)throw new Error("No pull request found in the GitHub context");let[o,n]=process.env.GITHUB_REPOSITORY.split("/"),i=r.payload.pull_request.number,{data:s}=await e.rest.issues.listLabelsOnIssue({owner:o,repo:n,issue_number:i});return s.map(l=>l.name)}catch(t){throw t instanceof Error?new Error(`Failed to get existing labels: ${t.message}`):t}}async function Ie(t){try{let e=process.env.GITHUB_TOKEN;if(!e)throw new Error("GITHUB_TOKEN environment variable is not set");if(!process.env.GITHUB_REPOSITORY||!process.env.GITHUB_EVENT_PATH)throw new Error("This function can only be used in a GitHub Actions environment");let r=W.getOctokit(e),{context:o}=W;if(!o.payload.pull_request)throw new Error("No pull request found in the GitHub context");let[n,i]=process.env.GITHUB_REPOSITORY.split("/"),s=o.payload.pull_request.number,l=`semantic-status: ${t}`,c=await re();if(c.includes(l))return;let a=c.filter(u=>u.startsWith("semantic-status:")&&u!==l);for(let u of a)await r.rest.issues.removeLabel({owner:n,repo:i,issue_number:s,name:u});await r.rest.issues.addLabels({owner:n,repo:i,issue_number:s,labels:[l]});return}catch(e){throw e instanceof Error?new Error(`Failed to apply label: ${e.message}`):e}}async function Fe(t=!1,e=!1){let r=je(`Checking commits...
53
- `).start();try{let o=await U.getCommitMessages();if(t&&Be(o),r.succeed(`Total commits analyzed: ${o.length}`),o.length!==0){let n=o.map(l=>l.type),s=Array.from(new Set(n)).map(l=>P(l)).join(", ");r.succeed(`Found commit types: ${s}`)}else r.info(`The list of commits is created by comparing the current branch
45
+ `};var U=D.resolve(process.cwd(),"./scripts/wca");async function er(t){try{return(await Promise.all(t.map(r=>Zt(r)))).flat()}catch(e){throw console.error("Error processing glob patterns:",e),e}}async function tr(t){G.existsSync(U)||await G.promises.mkdir(U,{recursive:!0});for(let e of t){let r=D.resolve(process.cwd(),e),n=await G.promises.readFile(r,"utf-8"),o=D.resolve(U,`${D.basename(e)}`),s=Ne(n,D.relative(U,e));await G.promises.writeFile(o,s)}}async function rr(){let t=await er(["./src/auro-*.js"]);await tr(t)}var To=Qt.command("wca-setup").description("Set up WCA (Web Component Analyzer) for the project").action(()=>{rr().then(()=>{Fe.success("WCA setup completed successfully.")}).catch(t=>{Fe.error(`WCA setup failed: ${t.message}`)})});import{program as mr}from"commander";import cr from"chalk";import Le from"ora";import{appendFile as nr,readFile as or}from"node:fs/promises";import{Logger as p}from"@aurodesignsystem/auro-library/scripts/utils/logger.mjs";import{simpleGit as ir}from"simple-git";var g;try{g=ir({baseDir:process.cwd(),binary:"git",maxConcurrentProcesses:1})}catch(t){p.error(`Failed to initialize git: ${t}`),g={}}var L=class t{static async checkGitignore(e){if(e==="")return!1;try{return(await or(".gitignore","utf-8")).includes(e)}catch(r){return p.error(`Error reading file: ${r}`),!1}}static async getCommitMessages(){try{let e=await g.branchLocal();p.info(`Current branch: ${e.current}`);let r="main",n="";if(!!process.env.GITHUB_ACTIONS){p.info("Running in GitHub Actions environment"),r=process.env.GITHUB_BASE_REF||"main";try{await g.fetch("origin",r),p.info(`Fetched target branch: origin/${r}`),n=`${(await g.raw(["merge-base",`origin/${r}`,"HEAD"])).trim()}..HEAD`,p.info(`Using commit range: ${n}`)}catch(s){p.warn(`Error setting up commit range in CI: ${s}`),n=`origin/${r}..HEAD`,p.info(`Falling back to commit range: ${n}`)}}else{p.info("Running in local environment");try{try{await g.raw(["rev-parse","--verify",`origin/${r}`])}catch{p.info(`Fetching ${r} from origin`),await g.fetch("origin",r)}n=`${(await g.raw(["merge-base",`origin/${r}`,e.current])).trim()}..HEAD`,p.info(`Using commit range for PR commits: ${n}`)}catch(s){p.warn(`Error determining PR commits locally: ${s}`),p.info("Falling back to analyzing recent commits"),n="HEAD~10..HEAD",p.info(`Using fallback commit range: ${n}`)}}return await t.getFormattedCommits(n)}catch(e){return p.error(`Error getting commit messages: ${e}`),[]}}static async getFormattedCommits(e){let n=(await g.raw(["log","--pretty=format:COMMIT_START%n%H%n%ad%n%an%n%s%n%b%nCOMMIT_END","--date=short",e])).split(`COMMIT_START
46
+ `).filter(s=>s.trim()!==""),o=[];for(let s of n){let i=s.split(`
47
+ `);if(i.length>=4){let l=i[0],c=i[1],a=i[2],u=i[3],m=i.slice(4).filter(z=>z!=="COMMIT_END"),d=m.length>0?m.join(""):"",y=l.substring(0,7),A=u.match(/^(feat|fix|docs|style|refactor|perf|test|build|ci|chore)(\(.+\))?:/),w=A?A[1]:"unknown";d.includes("BREAKING CHANGE")&&(w="breaking"),o.push({type:w,hash:y,date:c,subject:u,body:d,message:`${u}${d?`
48
+
49
+ ${d}`:""}`,author_name:a})}}return o}static async addToGitignore(e,r=!0){await t.checkGitignore(e).then(async n=>{if(n)p.warn(`${e} already exists`);else try{await nr(".gitignore",`
50
+ ${e}`),r&&p.success(`${e} added to .gitignore`)}catch(o){p.error(o)}})}static async removeFromGitCache(e){try{await g.rmKeepLocal(e),p.success(`${e.join(", ")} are removed from git cache`)}catch(r){p.error(r)}}static async createBranch(e){try{await g.checkoutLocalBranch(e),p.success(`Created and switched to ${e} branch`)}catch(r){p.error(r)}}static async commitStagedFiles(e){try{await g.add("."),await g.commit(e),p.success(`Committed with message: ${e}`)}catch(r){p.error(r)}}};import f from"chalk";var sr=60,ar=100;function P(t){switch(t){case"breaking":return f.bold.red(t);case"feat":return f.bold.green(t);case"fix":return f.bold.green(t);case"perf":return f.bold.green(t);case"docs":return f.bold.cyan(t);case"style":return f.bold.cyan(t);case"refactor":return f.bold.cyan(t);case"test":return f.bold.cyan(t);case"build":return f.bold.cyan(t);case"ci":return f.bold.cyan(t);case"chore":return f.bold.cyan(t);default:return f.bold.white(t)}}function Me(t,e){if(!t)return"";if(t.length<=e)return t;let r=t.split(" "),n="",o="";for(let s of r)(o+s).length>e&&o.length>0&&(n+=`${o.trim()}
51
+ `,o=""),o=`${o}${s} `;return o.length>0&&(n+=o.trim()),n}function Ge(t){for(let e of t){console.log("\u2500".repeat(60));let r=Me(e.subject,sr),n=Me(e.body,ar);console.log(f.bold(`${P(e.type)}`)),console.log(f.dim(`${e.hash} | ${e.date} | ${e.author_name}`)),console.log(f.bold(`${f.white(r)}`)),e.body&&console.log(f.dim(n))}console.log("\u2500".repeat(60)),console.log(`
52
+ `)}import W from"@actions/github";async function ne(){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=W.getOctokit(t),{context:r}=W;if(!r.payload.pull_request)throw new Error("No pull request found in the GitHub context");let[n,o]=process.env.GITHUB_REPOSITORY.split("/"),s=r.payload.pull_request.number,{data:i}=await e.rest.issues.listLabelsOnIssue({owner:n,repo:o,issue_number:s});return i.map(l=>l.name)}catch(t){throw t instanceof Error?new Error(`Failed to get existing labels: ${t.message}`):t}}async function Ue(t){try{let e=process.env.GITHUB_TOKEN;if(!e)throw new Error("GITHUB_TOKEN environment variable is not set");if(!process.env.GITHUB_REPOSITORY||!process.env.GITHUB_EVENT_PATH)throw new Error("This function can only be used in a GitHub Actions environment");let r=W.getOctokit(e),{context:n}=W;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,l=`semantic-status: ${t}`,c=await ne();if(c.includes(l))return;let a=c.filter(u=>u.startsWith("semantic-status:")&&u!==l);for(let u of a)await r.rest.issues.removeLabel({owner:o,repo:s,issue_number:i,name:u});await r.rest.issues.addLabels({owner:o,repo:s,issue_number:i,labels:[l]});return}catch(e){throw e instanceof Error?new Error(`Failed to apply label: ${e.message}`):e}}async function We(t=!1,e=!1){let r=Le(`Checking commits...
53
+ `).start();try{let n=await L.getCommitMessages();if(t&&Ge(n),r.succeed(`Total commits analyzed: ${n.length}`),n.length!==0){let o=n.map(l=>l.type),i=Array.from(new Set(o)).map(l=>P(l)).join(", ");r.succeed(`Found commit types: ${i}`)}else r.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.`);e&&await Yt(o,r)}catch(o){r.fail("Error getting commit messages"),console.error(o)}}async function Yt(t,e){let r=["breaking","feat","fix","perf","docs","style","refactor","test","build","ci","chore"],o=t.map(s=>s.type).filter(s=>r.includes(s)),n=null,i=Number.POSITIVE_INFINITY;for(let s of o){let l=r.indexOf(s);l<i&&(i=l,n=s)}if(n){let s=je("Checking existing labels on pull request...").start();try{if((await re()).includes(`semantic-status: ${n}`)){s.info(`Label "semantic-status: ${P(n)}" already exists on the pull request.`);return}s.text="Applying label to pull request...",await Ie(n),s.succeed(`Label "semantic-status: ${P(n)}" applied to the pull request.`)}catch(l){let c=l instanceof Error?l.message:String(l);s.fail(c)}}else e.warn(Jt.yellow("No semantic commit type found to apply as label."))}var yn=Kt.command("check-commits").alias("cc").option("-l, --set-label","Set label on the pull request based on the commit message type").option("-d, --debug","Display detailed commit information for debugging").description("Check commits in the local repository for the types of semantic commit messages made and return the results.").action(async t=>{await Fe(t.debug,t.setLabel)});import Oe from"node:fs";import{get as Ne}from"node:https";import x from"chalk";import{program as Xt}from"commander";import Qt from"ora";var Tn=Xt.command("pr-release").option("-n, --namespace <package-namespace>","Set namespace of the package release","@aurodesignsystem-dev").option("-p, --pr-number <number>","Set pull request number for the release","0").description("Generate the package version based off of PR number then update the package.json file. Note: this does not publish the package.").action(async t=>{await Zt(t)}),Zt=async t=>{let{namespace:e,prNumber:r}=t,o=Qt("Updating package.json").start();try{let n="package.json",i=JSON.parse(Oe.readFileSync(n,"utf8"));o.text="Checking npm registry for version information...";let s=`0.0.0-pr${r}`,l=i.name.split("/")[1],c=`${e}/${l}`,a=await er(s,c,o),u=`${s}.${a}`;i.name=c,i.version=u,o.text="Writing updated package.json...",Oe.writeFileSync(n,`${JSON.stringify(i,null,2)}
56
- `,"utf8"),o.succeed(`Package.json updated to use ${x.green(u)} and ${x.green(c)}`),process.exit(0)}catch(n){o.fail(`Failed to update package.json: ${n}`),process.exit(1)}},er=(t,e,r)=>new Promise(o=>{try{let l=function(c){if(c.statusCode!==200){r.info(`Package not found. Status code: ${x.red(c.statusCode)}, defaulting to version 0`),o(0);return}r.text="Processing version information...";let a="";c.on("data",u=>{a+=u}),c.on("end",()=>{try{let u=JSON.parse(a),m=u.versions?Object.keys(u.versions):[];r.text="Calculating next version number...";let d=-1,h=new RegExp(`^${t}\\.(\\d+)$`);for(let E of m){let y=E.match(h);if(y){let H=Number.parseInt(y[1],10);d=Math.max(d,H)}}d>=0?r.info(`Found existing version ${x.green(`${t}.${d}`)}. Incrementing to ${x.green(`${t}.${d+1}`)}`):r.info(`No existing version found for ${x.green(t)}. Starting with ${x.green(`${t}.0`)}`),o(d+1)}catch(u){r.warn(`Failed to parse NPM registry response: ${u instanceof Error?u.message:"Unknown error"}, defaulting to version 0`),o(0)}})};var n=l;let i=`https://registry.npmjs.org/${e}`,s=Ne(i,{headers:{Accept:"application/json"}},c=>{if((c.statusCode===301||c.statusCode===302)&&c.headers.location){r.info(`Following redirect to ${c.headers.location}...`);try{Ne(c.headers.location,{headers:{Accept:"application/json"}},l).on("error",a=>{r.warn(`Error following redirect: ${a.message}, defaulting to version 0`),o(0)}).end()}catch(a){r.warn(`Redirect request failed: ${a instanceof Error?a.message:"Unknown error"}, defaulting to version 0`),o(0)}return}l(c)});s.on("error",c=>{r.warn(`Request error: ${c.message}, defaulting to version 0`),o(0)}),s.end()}catch{r.warn("Error checking version in npm registry, defaulting to version 0"),o(0)}});import oe from"node:path";import{fileURLToPath as tr}from"node:url";import{program as rr}from"commander";import or from"open";var nr=tr(import.meta.url),ir=oe.resolve(oe.dirname(nr),".."),Rn=rr.command("test").option("-w, --watch","Set watch number for the test").option("-c, --coverage-report","Generate coverage report").option("-o, --open","Open the coverage report in the browser").option("-f, --files <String|String[]>","Test files glob pattern").description("Run the web test runner to test the component library").action(async t=>{let r=`npx wtr --config "${oe.join(ir,"dist","configs","web-test-runner.config.mjs")}"`,o=`${process.cwd()}/coverage/index.html`;if(t.coverageReport&&(r+=" --coverage"),t.watch&&(r+=" --watch"),t.files){let n=Array.isArray(t.files)?t.files.join(" "):t.files;r+=` --files "${n}"`}b(r),t.open&&await or(o)});import{program as sr}from"commander";var jn=sr.command("docs").description("Generate API documentation").option("-c, --cem","Generate Custom Elements Manifest (CEM) file",!1).action(async t=>{t.cem&&await B(),await I()});ne.name("auro").version(z()).description("A cli tool to support the Auro Design System");ne.addHelpText("beforeAll",ie());ne.parse();
55
+ make sure to commit some changes before running this command.`);e&&await lr(n,r)}catch(n){r.fail("Error getting commit messages"),console.error(n)}}async function lr(t,e){let r=["breaking","feat","fix","perf","docs","style","refactor","test","build","ci","chore"],n=t.map(i=>i.type).filter(i=>r.includes(i)),o=null,s=Number.POSITIVE_INFINITY;for(let i of n){let l=r.indexOf(i);l<s&&(s=l,o=i)}if(o){let i=Le("Checking existing labels on pull request...").start();try{if((await ne()).includes(`semantic-status: ${o}`)){i.info(`Label "semantic-status: ${P(o)}" already exists on the pull request.`);return}i.text="Applying label to pull request...",await Ue(o),i.succeed(`Label "semantic-status: ${P(o)}" applied to the pull request.`)}catch(l){let c=l instanceof Error?l.message:String(l);i.fail(c)}}else e.warn(cr.yellow("No semantic commit type found to apply as label."))}var Ho=mr.command("check-commits").alias("cc").option("-l, --set-label","Set label on the pull request based on the commit message type").option("-d, --debug","Display detailed commit information for debugging").description("Check commits in the local repository for the types of semantic commit messages made and return the results.").action(async t=>{await We(t.debug,t.setLabel)});import He from"node:fs";import{get as ze}from"node:https";import E from"chalk";import{program as ur}from"commander";import dr from"ora";var Xo=ur.command("pr-release").option("-n, --namespace <package-namespace>","Set namespace of the package release","@aurodesignsystem-dev").option("-p, --pr-number <number>","Set pull request number for the release","0").description("Generate the package version based off of PR number then update the package.json file. Note: this does not publish the package.").action(async t=>{await pr(t)}),pr=async t=>{let{namespace:e,prNumber:r}=t,n=dr("Updating package.json").start();try{let o="package.json",s=JSON.parse(He.readFileSync(o,"utf8"));n.text="Checking npm registry for version information...";let i=`0.0.0-pr${r}`,l=s.name.split("/")[1],c=`${e}/${l}`,a=await fr(i,c,n),u=`${i}.${a}`;s.name=c,s.version=u,n.text="Writing updated package.json...",He.writeFileSync(o,`${JSON.stringify(s,null,2)}
56
+ `,"utf8"),n.succeed(`Package.json updated to use ${E.green(u)} and ${E.green(c)}`),process.exit(0)}catch(o){n.fail(`Failed to update package.json: ${o}`),process.exit(1)}},fr=(t,e,r)=>new Promise(n=>{try{let l=function(c){if(c.statusCode!==200){r.info(`Package not found. Status code: ${E.red(c.statusCode)}, defaulting to version 0`),n(0);return}r.text="Processing version information...";let a="";c.on("data",u=>{a+=u}),c.on("end",()=>{try{let u=JSON.parse(a),m=u.versions?Object.keys(u.versions):[];r.text="Calculating next version number...";let d=-1,y=new RegExp(`^${t}\\.(\\d+)$`);for(let A of m){let w=A.match(y);if(w){let z=Number.parseInt(w[1],10);d=Math.max(d,z)}}d>=0?r.info(`Found existing version ${E.green(`${t}.${d}`)}. Incrementing to ${E.green(`${t}.${d+1}`)}`):r.info(`No existing version found for ${E.green(t)}. Starting with ${E.green(`${t}.0`)}`),n(d+1)}catch(u){r.warn(`Failed to parse NPM registry response: ${u instanceof Error?u.message:"Unknown error"}, defaulting to version 0`),n(0)}})};var o=l;let s=`https://registry.npmjs.org/${e}`,i=ze(s,{headers:{Accept:"application/json"}},c=>{if((c.statusCode===301||c.statusCode===302)&&c.headers.location){r.info(`Following redirect to ${c.headers.location}...`);try{ze(c.headers.location,{headers:{Accept:"application/json"}},l).on("error",a=>{r.warn(`Error following redirect: ${a.message}, defaulting to version 0`),n(0)}).end()}catch(a){r.warn(`Redirect request failed: ${a instanceof Error?a.message:"Unknown error"}, defaulting to version 0`),n(0)}return}l(c)});i.on("error",c=>{r.warn(`Request error: ${c.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 oe from"node:path";import{fileURLToPath as gr}from"node:url";import{program as hr}from"commander";import yr from"open";var wr=gr(import.meta.url),br=oe.resolve(oe.dirname(wr),".."),oi=hr.command("test").option("-w, --watch","Set watch number for the test").option("-c, --coverage-report","Generate coverage report").option("-o, --open","Open the coverage report in the browser").option("-f, --files <String|String[]>","Test files glob pattern").description("Run the web test runner to test the component library").action(async t=>{let r=`npx wtr --config "${oe.join(br,"dist","configs","web-test-runner.config.mjs")}"`,n=`${process.cwd()}/coverage/index.html`;if(t.coverageReport&&(r+=" --coverage"),t.watch&&(r+=" --watch"),t.files){let o=Array.isArray(t.files)?t.files.join(" "):t.files;r+=` --files "${o}"`}h(r),t.open&&await yr(n)});import le from"node:fs/promises";import Xe from"node:path";import{program as Pr}from"commander";import Sr from"inquirer";import me from"ora";import kr from"node:fs/promises";import Ar from"node:path";import $r from"ora";var Er={"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 xr(t){return Object.entries(t).map(([e,r])=>Array.isArray(r)?`${e}:
57
+ - ${r.join(`
58
+ - `)}`:typeof r=="object"&&r!==null?`${e}:
59
+ ${Object.entries(r).map(([n,o])=>` ${n}: ${o}`).join(`
60
+ `)}`:`${e}: ${r}`).join(`
61
+ `)}async function qe(t){let e=$r("Writing multi-gitter configuration...").start(),r=xr(Er),n=Ar.join(t,"multi-gitter_DEPENDENCY_TREE.yml");try{await kr.writeFile(n,r,"utf8"),e.succeed(`Multi-gitter configuration written to ${n}`)}catch(o){e.fail("Error writing multi-gitter configuration:"),console.error(o)}}import ie from"node:fs";function Je(t){let e={},r=[],n=[],o=[];for(let s in t)e[s]=t[s].dependsOn.length;for(let s in e)e[s]===0&&o.push(s);for(;o.length>0;){n=[];let s=o.length;for(let i=0;i<s;i++){let l=o.shift();n.push(l);for(let c of t[l].dependentPackages)e[c]--,e[c]===0&&o.push(c)}r.push(n)}if(r.flat().length!==Object.keys(t).length)throw new Error("Circular dependency detected!");return r}function Cr(t){return ie.readdirSync(t).filter(e=>e.endsWith(".json"))}async function Ve(t,e=[]){console.log(e);let r={},n=Cr(t);for(let o of n){if(o==="dependencyTree.json")continue;let s=ie.readFileSync(`${t}/${o}`,"utf-8"),i=JSON.parse(s),l=i.name,c=Object.keys(i.peerDependencies),a=Object.keys(i.devDependencies),u=Object.keys(i.dependencies);r[l]||(r[l]={dependsOn:[],dependentPackages:[]});let m=[...c,...a,...u];r[l].dependsOn=[...new Set(m)];for(let d of m)r[d]||(r[d]={dependsOn:[],dependentPackages:[]}),r[d].dependentPackages.includes(l)||r[d].dependentPackages.push(l)}if(e.length){let o=new Set;for(let[i,l]of Object.entries(r))l.dependsOn.some(c=>e.includes(c))&&o.add(i);for(let i of e)r[i]&&o.add(i);let s={};for(let i of o)s[i]={dependsOn:r[i].dependsOn.filter(l=>o.has(l)),dependentPackages:r[i].dependentPackages.filter(l=>o.has(l))};r=s}else console.log("No target dependencies provided - using all packages.");return ie.writeFileSync(`${t}/dependencyTree.json`,JSON.stringify(r,null,2)),r}import Tr from"node:os";import H from"node:path";import Ye from"node:process";import{fileURLToPath as vr}from"node:url";function Dr(){let t=Tr.homedir()||Ye.env.HOME||Ye.env.USERPROFILE;if(!t)throw new Error("Unable to determine user home directory");return H.join(t,".auro")}function se(...t){return H.join(Dr(),...t)}function Ke(...t){let e=vr(import.meta.url),r=H.dirname(e);return H.resolve(r,...t)}var ae=se("run-migrations","config"),ce=se("run-migrations","outputs");var Qe=["@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"],Ti=[...Qe,"@aurodesignsystem/auro-library","@aurodesignsystem/WebCoreStyleSheets","@aurodesignsystem/AuroDesignTokens","@aurodesignsystem/auro-cli","@alaskaairux/icons"];async function Rr(t){try{await le.mkdir(ce,{recursive:!0}),await le.mkdir(ae,{recursive:!0})}catch(o){console.error("Failed to create output or config directories:",o),process.exit(1)}let e=me("Creating dependency tree...").start();e.text="Creating multi-gitter dependency tree configuration...",await qe(ae),e.text="Scraping dependencies from Auro packages...";let n=`multi-gitter run "node ${Ke("static","getAuroDeps.js")}" --config ${Xe.join(ae,"multi-gitter_DEPENDENCY_TREE.yml")}`;try{await h(n)}catch(o){e.fail("Failed to generate dependency tree:"),console.error(o),process.exit(1)}return e.text="Generating dependency tree JSON file using packages...",await Ve(ce,t),e.succeed("Dependency tree generated successfully."),Xe.join(ce,"dependencyTree.json")}var jr=async t=>{let e=me("Loading dependency tree...").start(),r=JSON.parse(await le.readFile(t,"utf-8"));e.text="Processing dependency tree...";let n=Je(r);return e.succeed("Dependency batches created successfully."),n},vi=Pr.command("agent").action(async t=>{let e=await Sr.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:Qe.map(r=>({name:r.replace("@aurodesignsystem/",""),value:r})),when:r=>r.agentAction==="run-migration"&&r.useExisting}]);switch(e.agentAction){case"run-migration":{let r=me("Running migration...").start(),n=await Rr(e.startWithComponents);r.text="Getting dependency batches from tree...";let s=(await jr(n)).map((i,l)=>`Batch ${l+1}
62
+ ${i.map(c=>` - ${c.replace("@aurodesignsystem","AlaskaAirlines").replace("@alaskaairux/icons","AlaskaAirlines/Icons")}`).join(`
63
+ `)}`).join(`
64
+
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 Or}from"commander";var Ri=Or.command("docs").description("Generate API documentation").option("-c, --cem","Generate Custom Elements Manifest (CEM) file",!1).action(async t=>{t.cem&&await O(),await _()});ue.name("auro").version(q()).description("A cli tool to support the Auro Design System");ue.addHelpText("beforeAll",de());ue.parse();