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