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