@jujulego/jill 2.3.3 → 2.4.0-alpha.2

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.
Files changed (38) hide show
  1. package/dist/489.mjs +1 -1
  2. package/dist/489.mjs.map +1 -1
  3. package/dist/71.mjs +2 -0
  4. package/dist/71.mjs.map +1 -0
  5. package/dist/828.mjs +1 -1
  6. package/dist/828.mjs.map +1 -1
  7. package/dist/commands/each.d.ts +3 -3
  8. package/dist/commands/run.d.ts +1 -1
  9. package/dist/commons/context.service.d.ts +1 -1
  10. package/dist/commons/git.service.d.ts +1 -1
  11. package/dist/commons/logger/log.gateway.d.ts +18 -0
  12. package/dist/commons/logger/parameters.d.ts +2 -0
  13. package/dist/commons/logger/thread.gateway.d.ts +13 -0
  14. package/dist/commons/logger/types.d.ts +2 -0
  15. package/dist/commons/logger.service.d.ts +1 -20
  16. package/dist/index.d.ts +1 -3
  17. package/dist/index.mjs +1 -1
  18. package/dist/index.mjs.map +1 -1
  19. package/dist/jill.application.d.ts +1 -1
  20. package/dist/main.d.ts +1 -1
  21. package/dist/main.mjs +1 -1
  22. package/dist/main.mjs.map +1 -1
  23. package/dist/middlewares/load-project.d.ts +1 -3
  24. package/dist/middlewares/load-workspace.d.ts +3 -3
  25. package/dist/modules/plugin-loader.service.d.ts +1 -1
  26. package/dist/modules/service.d.ts +4 -0
  27. package/dist/project/project.d.ts +1 -1
  28. package/dist/project/project.repository.d.ts +1 -1
  29. package/dist/tasks/task-expr.service.d.ts +2 -1
  30. package/dist/tsconfig.build.tsbuildinfo +1 -1
  31. package/package.json +21 -18
  32. package/dist/839.mjs +0 -2
  33. package/dist/839.mjs.map +0 -1
  34. package/dist/commons/logger/console.formatter.d.ts +0 -2
  35. package/dist/commons/logger/log.tag.d.ts +0 -1
  36. package/dist/commons/logger/thread.transport.d.ts +0 -10
  37. package/dist/commons/spinner.service.d.ts +0 -21
  38. package/dist/ui/global-spinner.d.ts +0 -1
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@jujulego/jill",
3
- "version": "2.3.3",
3
+ "version": "2.4.0-alpha.2",
4
4
  "license": "MIT",
5
5
  "repository": {
6
6
  "type": "git",
@@ -26,14 +26,18 @@
26
26
  "e2e:yarn": "yarn run e2e -t yarn"
27
27
  },
28
28
  "engines": {
29
- "node": "^16.x || ^18.x"
29
+ "node": "16.x || 18.x || 20.x"
30
30
  },
31
31
  "dependencies": {
32
- "@jujulego/event-tree": "^4.1.0",
33
- "@jujulego/tasks": "^2.0.1",
34
- "@jujulego/utils": "^2.0.1",
32
+ "@jujulego/aegis": "^2.0.0-beta.5",
33
+ "@jujulego/event-tree": "^4.2.0",
34
+ "@jujulego/logger": "^0.2.4",
35
+ "@jujulego/quick-tag": "^0.3.3",
36
+ "@jujulego/tasks": "^2.1.0",
37
+ "@jujulego/utils": "^2.0.2",
35
38
  "ajv": "^8.12.0",
36
39
  "chalk": "^5.3.0",
40
+ "chalk-template": "^1.1.0",
37
41
  "cosmiconfig": "^8.2.0",
38
42
  "ink": "^4.3.0",
39
43
  "ink-spinner": "^5.0.0",
@@ -48,47 +52,46 @@
48
52
  "semver": "^7.5.4",
49
53
  "slugify": "^1.6.6",
50
54
  "tiny-glob": "^0.2.9",
51
- "winston": "^3.10.0",
52
- "winston-transport": "^4.5.0",
53
55
  "yargs": "^17.7.2"
54
56
  },
55
57
  "devDependencies": {
56
58
  "@jujulego/2d-maths": "1.6.0",
59
+ "@jujulego/vite-plugin-swc": "1.1.0",
57
60
  "@microsoft/eslint-formatter-sarif": "3.0.0",
58
61
  "@rollup/plugin-swc": "0.2.1",
59
- "@swc/core": "1.3.92",
62
+ "@swc/core": "1.3.93",
60
63
  "@types/moo": "0.5.7",
61
- "@types/node": "16.18.57",
64
+ "@types/node": "16.18.58",
62
65
  "@types/normalize-package-data": "2.4.2",
63
- "@types/react": "18.2.25",
66
+ "@types/react": "18.2.28",
64
67
  "@types/semver": "7.5.3",
65
68
  "@types/webpack-bundle-analyzer": "4.6.1",
66
- "@types/yargs": "17.0.26",
67
- "@typescript-eslint/eslint-plugin": "6.7.4",
68
- "@typescript-eslint/parser": "6.7.4",
69
+ "@types/yargs": "17.0.28",
70
+ "@typescript-eslint/eslint-plugin": "6.8.0",
71
+ "@typescript-eslint/parser": "6.8.0",
69
72
  "@vitest/coverage-v8": "0.34.6",
70
73
  "@vitest/expect": "0.34.6",
71
74
  "@vitest/spy": "0.34.6",
72
75
  "browserslist": "4.22.1",
73
- "eslint": "8.50.0",
76
+ "eslint": "8.51.0",
74
77
  "eslint-plugin-react": "7.33.2",
75
78
  "eslint-plugin-react-hooks": "4.6.0",
76
79
  "eslint-plugin-vitest": "0.3.2",
77
80
  "eslint-plugin-workspaces": "0.9.0",
78
81
  "fork-ts-checker-webpack-plugin": "9.0.0",
79
82
  "ink-testing-library": "3.0.0",
80
- "memfs": "4.5.0",
83
+ "memfs": "4.6.0",
81
84
  "shx": "0.3.4",
82
85
  "swc-loader": "0.2.3",
83
86
  "ts-node": "10.9.1",
84
87
  "typescript": "5.2.2",
85
- "vite": "4.4.11",
88
+ "vite": "5.0.0-beta.10",
86
89
  "vite-tsconfig-paths": "4.2.1",
87
90
  "vitest": "0.34.6",
88
- "webpack": "5.88.2",
91
+ "webpack": "5.89.0",
89
92
  "webpack-bundle-analyzer": "4.9.1",
90
93
  "webpack-cli": "5.1.4",
91
- "webpack-merge": "5.9.0",
94
+ "webpack-merge": "5.10.0",
92
95
  "webpack-node-externals": "3.0.0"
93
96
  },
94
97
  "packageManager": "yarn@3.6.4"
package/dist/839.mjs DELETED
@@ -1,2 +0,0 @@
1
- export const id=839;export const ids=[839];export const modules={6156:(e,t,n)=>{n.d(t,{O:()=>a});var s=n(6675),r=n(2761),o=n(2429),i=n(9921);let a=class{constructor(e){this._storage=new r.AsyncLocalStorage,this._logger=e.child({label:"context"}),this.reset()}reset(e={}){this._storage.enterWith(e)}_getContext(){return this._storage.getStore()||(this._logger.warn("Trying to access uninitialized context"),{})}_updateContext(e){Object.assign(this._getContext(),e)}get application(){return this._getContext().application}set application(e){this._updateContext({application:e})}get project(){return this._getContext().project}set project(e){this._updateContext({project:e})}get workspace(){return this._getContext().workspace}set workspace(e){this._updateContext({workspace:e})}};var c;a=function(e,t,n,s){var r,o=arguments.length,i=o<3?t:null===s?s=Object.getOwnPropertyDescriptor(t,n):s;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,n,s);else for(var a=e.length-1;a>=0;a--)(r=e[a])&&(i=(o<3?r(i):o>3?r(t,n,i):r(t,n))||i);return o>3&&i&&Object.defineProperty(t,n,i),i}([(0,i.t)(),(0,c=(0,s.inject)(o.Y),function(e,t){c(e,t,0)})],a)},2429:(e,t,n)=>{n.d(t,{Y:()=>f});var s=n(6675),r=n(4133),o=n(4086),i=n.n(o),a=n(466),c=n(1086),l=n(2033),u=n(5804);class d extends u.default{constructor(e){super({level:"debug"}),this.channel=new o.BroadcastChannel(e),this.channel.onmessageerror=e=>{this.emit("error",e)},this.channel.unref()}log(e,t){this.channel.postMessage(e),this.emit("logged",e),t()}close(e){this.channel.close(),e&&e(),this.emit("closed")}}let f=class{constructor(e){this.winston=e}log(e,t){this.winston.log(e,t)}debug(e,...t){"string"!=typeof e&&(e=(0,c.l)(e,...t)),this.winston.debug(e)}verbose(e,...t){"string"!=typeof e&&(e=(0,c.l)(e,...t)),this.winston.verbose(e)}info(e,...t){"string"!=typeof e&&(e=(0,c.l)(e,...t)),this.winston.info(e)}warn(e,...t){let n;"string"!=typeof e?e=(0,c.l)(e,...t):n=t[0],this.winston.warn(e,n)}error(e,...t){let n;"string"!=typeof e?e=(0,c.l)(e,...t):n=t[0],this.winston.error(e,n)}child(e){return new f(this.winston.child(e))}get level(){return this.winston.level}set level(e){this.winston.level=e}};f=function(e,t,n,s){var r,o=arguments.length,i=o<3?t:null===s?s=Object.getOwnPropertyDescriptor(t,n):s;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,n,s);else for(var a=e.length-1;a>=0;a--)(r=e[a])&&(i=(o<3?r(i):o>3?r(t,n,i):r(t,n))||i);return o>3&&i&&Object.defineProperty(t,n,i),i}([(0,s.injectable)()],f),a.nC.bind(f).toDynamicValue((()=>{const e=r.default.createLogger({format:r.default.format.combine(r.default.format.timestamp(),r.default.format.errors({stack:!1})),transports:[]});if(i().isMainThread){e.add(new r.default.transports.Console({format:l.D}));const t=new(i().BroadcastChannel)("jujulego:jill:logger");t.onmessage=t=>e.log(t.data),t.unref()}else e.add(new d("jujulego:jill:logger"));return new f(e)})).inSingletonScope()},2033:(e,t,n)=>{n.d(t,{D:()=>o});var s=n(7564),r=n(4133);const o=r.default.format.combine(r.default.format.colorize({message:!0,colors:{debug:"grey",verbose:"blue",info:"white",error:"red"}}),r.default.format.printf((({label:e,message:t,stack:n})=>{n&&(t=s.default.red(n));const r=t.split("\n");let o="",i=r[0];e&&(o=" ".repeat(e.length+3),i=`${s.default.grey(`[${e}]`)} ${r[0]}`);for(let e=1;e<r.length;++e)i+=`\n${o}${r[e]}`;return i})))},1086:(e,t,n)=>{n.d(t,{l:()=>i});var s=n(9411),r=n.n(s);const o={cwd:e=>r().relative(process.cwd(),e)||"."};function i(e,...t){let n=e[0];for(let s=0;s<t.length;++s){let r=""+t[s];const i=n.match(/#([a-z]+):$/),a=i&&o[i[1]];a&&(n=n.slice(0,n.length-i[0].length),r=a(r)),n+=r+e[s+1]}return n}},3565:(e,t,n)=>{n.d(t,{V:()=>l});var s=n(2786),r=n(6675),o=n(2429),i=n(466),a=n(2561),c=n(9921);let l=class{constructor(e){this._status="stop",this._label="",this._events=(0,s.multiplexer$)({state:(0,s.source$)()}),this._logger=e.child({label:"spinner"})}_awakeInk(){i.nC.get(a.I)}spin(e){this._logger.debug(`spin: ${e}`),this._status="spin",this._label=e,this._events.emit("state",this.state),this._awakeInk()}success(e){this._logger.debug(`success: ${e}`),this._status="success",this._label=e,this._events.emit("state",this.state),this._awakeInk()}failed(e){this._logger.debug(`failed: ${e}`),this._status="failed",this._label=e,this._events.emit("state",this.state),this._awakeInk()}stop(){"spin"===this._status&&(this._logger.debug(`stop: ${this._label}`),this._status="stop",this._events.emit("state",this.state))}get on(){return this._events.on}get off(){return this._events.off}get state(){return{status:this._status,label:this._label}}};var u;l=function(e,t,n,s){var r,o=arguments.length,i=o<3?t:null===s?s=Object.getOwnPropertyDescriptor(t,n):s;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,n,s);else for(var a=e.length-1;a>=0;a--)(r=e[a])&&(i=(o<3?r(i):o>3?r(t,n,i):r(t,n))||i);return o>3&&i&&Object.defineProperty(t,n,i),i}([(0,c.t)(),(0,u=(0,r.inject)(o.Y),function(e,t){u(e,t,0)})],l)},7839:(e,t,n)=>{n.d(t,{k:()=>y});var s=n(612),r=n.n(s),o=n(9411),i=n.n(o),a=n(5795),c=n(466),l=n(2429);const u=Symbol("jujulego:jill:Ajv");c.nC.bind(u).toDynamicValue((({container:e})=>{const t=e.get(l.Y);return new a.default({allErrors:!0,logger:t.child({label:"ajv"}),strict:!0})})).inSingletonScope();var d=n(6505),f=n(2180),p=n(3843),g=n(6623);const h=JSON.parse('{"$schema":"http://json-schema.org/draft-07/schema","type":"object","additionalProperties":false,"properties":{"jobs":{"type":"number"},"plugins":{"type":"array","items":{"type":"string"}},"verbose":{"type":"string","enum":["info","verbose","debug"]}}}');var m=n(8520);const j=Symbol("jujulego:jill:config-explorer"),b=Symbol("jujulego:jill:config-validator");c.nC.bind(b).toDynamicValue((({container:e})=>e.get(u).compile(h))).inSingletonScope(),c.nC.bind(j).toDynamicValue((()=>(0,g.cosmiconfig)("jill",{loaders:{".cjs":e=>(0,m.y)(e).then((e=>e.default)),".js":e=>(0,m.y)(e).then((e=>e.default)),".json":g.defaultLoaders[".json"],".yaml":g.defaultLoaders[".yaml"],".yml":g.defaultLoaders[".yml"],noExt:g.defaultLoaders.noExt}}))).inSingletonScope();const y=Symbol("jujulego:jill:config");async function w(){const e=c.nC.get(l.Y).child({label:"config"}),t=c.nC.get(p.c),n=c.nC.get(j),s=c.nC.get(b),o=await n.search(),a=o?.config??{};if(t.jobs&&(a.jobs=t.jobs),t.verbose&&(a.verbose=t.verbose),a.jobs??=r().cpus().length-1,!s(a)){const t=c.nC.get(u).errorsText(s.errors,{separator:"\n- ",dataVar:"config"});throw e.error`Errors in config file:\n- ${t}`,new d.T(1)}if(a.verbose&&(c.nC.get(l.Y).level=a.verbose),o){const t=i().dirname(o.filepath);a.plugins=a.plugins?.map((e=>i().resolve(t,e))),e.verbose`Loaded ${o.filepath} config file`}return e.debug`Loaded config:\n${JSON.stringify(a,null,2)}`,a}c.nC.bind(y).toDynamicValue((async()=>await(0,f.F)("jujulego:jill:config",w))).inSingletonScope()},3843:(e,t,n)=>{n.d(t,{N:()=>c,c:()=>i});var s=n(2699),r=n(1091),o=n(466);const i=Symbol("jujulego:jill:config-options"),a={1:"verbose",2:"debug"};function c(e){return e.option("verbose",{alias:"v",type:"count",description:"Set verbosity level",coerce:e=>a[Math.min(e,2)]}).option("jobs",{alias:"j",type:"number",description:"Set maximum parallel job number"})}o.nC.bind(i).toDynamicValue((()=>{const e=(0,s.default)((0,r.hideBin)(process.argv)).help(!1).version(!1);return c(e),e.parse()})).inSingletonScope()},9300:(e,t,n)=>{n.d(t,{W:()=>s});const s="current"},2561:(e,t,n)=>{n.d(t,{I:()=>l});var s=n(832),r=n(9149),o=n(4086),i=n.n(o),a=n(466),c=n(8348);const l=Symbol.for("jujulego:jill:ink-app");a.nC.bind(l).toDynamicValue((()=>{if(!i().isMainThread)throw new Error("Ink should only be used in main thread");return(0,r.render)((0,s.jsx)(c.Z,{}),{stdout:process.stdout.isTTY?process.stdout:process.stderr})})).inSingletonScope()},466:(e,t,n)=>{n.d(t,{nC:()=>a,oV:()=>l,yT:()=>c});var s=n(6675),r=n(4088),o=n.n(r),i=(n(2483),n(8520));const a=new s.Container,{lazyInject:c,lazyInjectNamed:l}=(0,i.v)(o())(a)},8727:(e,t,n)=>{n.d(t,{T:()=>h});var s=n(6675),r=n(2699),o=n(6156),i=n(2429),a=n(3843),c=n(9300),l=n(466),u=n(9717),d=n(3617),f=n(7051),p=n(366);function g(e,t){return function(n,s){t(n,s,e)}}let h=class{constructor(e,t,n){this.context=e,this.plugins=t,this.logger=n,this.container=l.nC.createChild(),this.parser=(0,r.default)().scriptName("jill").completion("completion","Generate bash completion script").help("help","Show help for a command").version("version","Show version","2.3.3").wrap(process.stdout.columns).exitProcess(!1)}_prepareParser(e){return(0,a.N)(this.parser),this.parser.command(e).recommendCommands().strict().fail(!1)}async _loadPlugins(){this.logger.child({label:"plugin"}).verbose("Loading plugin <core>");const{CorePlugin:e}=await Promise.all([n.e(828),n.e(489)]).then(n.bind(n,489));this.container.load((0,d.rT)(e,!0)),await this.plugins.loadPlugins(this.container)}async run(e){this.context.reset({application:this}),await this._loadPlugins();const t=await this.container.getAllAsync(u.mD);await this._prepareParser(t).parseAsync(e)}async tasksOf(e,t={}){this.context.reset({...t,application:this}),await this._loadPlugins();const n=await this.container.getAllAsync(u.NI);return new Promise(((t,s)=>{const r=[];for(const e of n){const n=(0,u._Y)(e.constructor),s=(0,u.$f)(e,n);s.handler=async n=>{if(e instanceof p.o){const s=[];for await(const t of e.prepare(n))s.push(t);t(s)}else t([])},r.push(s)}this._prepareParser(r).parseAsync(e).catch(s)}))}};h=function(e,t,n,s){var r,o=arguments.length,i=o<3?t:null===s?s=Object.getOwnPropertyDescriptor(t,n):s;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,n,s);else for(var a=e.length-1;a>=0;a--)(r=e[a])&&(i=(o<3?r(i):o>3?r(t,n,i):r(t,n))||i);return o>3&&i&&Object.defineProperty(t,n,i),i}([(0,s.injectable)(),g(0,(0,s.inject)(o.O)),g(1,(0,s.inject)(f.B)),g(2,(0,s.inject)(i.Y))],h),l.nC.bind(h).toSelf().inTransientScope().whenTargetIsDefault(),l.nC.bind(h).toDynamicValue((({container:e})=>{const t=e.get(o.O).application;if(!t)throw new Error("Cannot inject current application, it not yet defined");return t})).whenTargetNamed(c.W)},9717:(e,t,n)=>{n.d(t,{$f:()=>u,NI:()=>a,_Y:()=>l,mD:()=>c,mY:()=>d});var s=n(6675),r=n(3617),o=n(1632);const i=Symbol("jujulego:jill:command-opts"),a=Symbol("jujulego:jill:command"),c=Symbol("jujulego:jill:command-module");function l(e){const t=Reflect.getMetadata(i,e);if("object"!=typeof t)throw new Error(`No command options found in ${e.name}`);return t}function u(e,t){return{command:t.command,aliases:t.aliases,describe:t.describe,deprecated:t.deprecated,builder:n=>(t.middlewares&&(n=(0,o.S)(n,t.middlewares)),e.builder&&(n=e.builder(n)),n),handler:t=>e.handler(t)}}function d(e){return t=>{(0,s.decorate)((0,s.injectable)(),t),Reflect.defineMetadata(i,e,t);const n=e.command.split(" ")[0];(0,r.i8)(t,(s=>{s(t).toSelf(),s(a).toDynamicValue((({container:e})=>e.getAsync(t))).whenTargetNamed(n),s(c).toDynamicValue((async({container:n})=>u(await n.getAsync(t),e))).whenTargetNamed(n)}))}}},6729:(e,t,n)=>{n.d(t,{m:()=>l});var s=n(832),r=n(6675),o=n(2561),i=n(466),a=n(8348);function c(e,t,n,s){var r,o=arguments.length,i=o<3?t:null===s?s=Object.getOwnPropertyDescriptor(t,n):s;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,n,s);else for(var a=e.length-1;a>=0;a--)(r=e[a])&&(i=(o<3?r(i):o>3?r(t,n,i):r(t,n))||i);return o>3&&i&&Object.defineProperty(t,n,i),i}let l=class{builder(e){return e}async handler(e){for await(const t of this.render(e))this.app.rerender((0,s.jsx)(a.Z,{children:t}));await this.app.waitUntilExit()}};c([(0,i.yT)(o.I)],l.prototype,"app",void 0),l=c([(0,r.injectable)()],l)},1632:(e,t,n)=>{n.d(t,{S:()=>i,d:()=>o});var s=n(6675),r=n(466);function o(){return e=>{(0,s.decorate)((0,s.injectable)(),e),r.nC.bind(e).toSelf().inSingletonScope()}}function i(e,t){let n=e;for(const e of t){const t=r.nC.get(e);t.builder&&(n=t.builder(n)),n.middleware((e=>t.handler(e)))}return n}},3617:(e,t,n)=>{n.d(t,{IY:()=>l,JH:()=>i,i8:()=>a,rT:()=>c});var s=n(6675);const r=Symbol("jujulego:jill:module"),o=Symbol("jujulego:jill:registry");function i(e){const t=Reflect.getMetadata(o,e);if("function"!=typeof t)throw new Error(`No registry found in ${e.name}`);return t}function a(e,t){Reflect.defineMetadata(o,t,e)}function c(e,t=!1){let n=Reflect.getMetadata(r,e);if(!(n&&n instanceof s.ContainerModule)){const r=Reflect.getMetadata(o,e);if("function"!=typeof r){if(t)throw new Error(`No module found in ${e.name}`);return null}n=new s.ContainerModule(r),l(e,n)}return n}function l(e,t){Reflect.defineMetadata(r,t,e)}},7051:(e,t,n)=>{n.d(t,{B:()=>d});var s=n(6675),r=n(7839),o=n(2429),i=n(466),a=n(8520),c=n(3617),l=n(9921);function u(e,t){return function(n,s){t(n,s,e)}}let d=class{constructor(e,t){this._config=e,this._logger=t.child({label:"plugin"})}async _importPlugin(e){this._logger.verbose`Loading plugin ${e}`;let t=await(0,a.y)(e);for(;t&&"object"==typeof t&&"default"in t;)t=t.default;if(!t)throw new Error(`Invalid plugin ${e}: no plugin class found`);const n=(0,c.rT)(t);if(!n)throw new Error(`Invalid plugin ${e}: invalid plugin class`);return n}async loadPlugins(e=i.nC){if(this._config.plugins)for(const t of this._config.plugins){const n=await this._importPlugin(t);e.load(n)}}};d=function(e,t,n,s){var r,o=arguments.length,i=o<3?t:null===s?s=Object.getOwnPropertyDescriptor(t,n):s;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,n,s);else for(var a=e.length-1;a>=0;a--)(r=e[a])&&(i=(o<3?r(i):o>3?r(t,n,i):r(t,n))||i);return o>3&&i&&Object.defineProperty(t,n,i),i}([(0,l.t)(),u(0,(0,s.inject)(r.k)),u(1,(0,s.inject)(o.Y))],d)},9921:(e,t,n)=>{n.d(t,{t:()=>o});var s=n(6675),r=n(466);function o(){return e=>((0,s.decorate)((0,s.injectable)(),e),r.nC.bind(e).toSelf().inSingletonScope(),e)}},366:(e,t,n)=>{n.d(t,{o:()=>b});var s=n(832),r=n(2786),o=n(3410),i=n(6675),a=n(2429),c=n(466),l=n(4244),u=n(6839),d=n(5099),f=n(5740),p=n(4887),g=n(6505),h=n(5472),m=n(6729);function j(e,t,n,s){var r,o=arguments.length,i=o<3?t:null===s?s=Object.getOwnPropertyDescriptor(t,n):s;if("object"==typeof Reflect&&"function"==typeof Reflect.decorate)i=Reflect.decorate(e,t,n,s);else for(var a=e.length-1;a>=0;a--)(r=e[a])&&(i=(o<3?r(i):o>3?r(t,n,i):r(t,n))||i);return o>3&&i&&Object.defineProperty(t,n,i),i}let b=class extends m.m{addTaskOptions(e){return e.option("plan",{type:"boolean",desc:"Only prints tasks to be run",default:!1}).option("plan-mode",{type:"string",desc:"Plan output mode",choices:["json","list"],default:"list"})}async*render(e){const t=new o.TaskSet;for await(const n of this.prepare(e))t.add(n);if(e.plan){const n=Array.from((0,o.plan)(t));if("json"===e.planMode)(0,h.i)(n);else{const e=n.map((e=>({id:e.id.substring(0,6),name:e.name,workspace:(0,l.g)(e.context)||(0,u.G)(e.context)?e.context.workspace.name:"",group:e.groupId?.substring(0,6),"depends on":e.dependenciesIds.map((e=>e.substring(0,6))).join(", ")})));yield(0,s.jsx)(f.Z,{items:e,headers:!0})}}else if(t.tasks.length>0){if(yield(0,s.jsx)(p.Z,{manager:this.manager}),t.start(this.manager),(await(0,r.waitFor$)(t,"finished")).failed>0)throw new g.T(1)}else c.nC.get(a.Y).warn`No task found`}};j([(0,c.yT)(d.N)],b.prototype,"manager",void 0),b=j([(0,i.injectable)()],b)},4244:(e,t,n)=>{n.d(t,{F:()=>i,g:()=>o});var s=n(3410),r=n(3265);function o(e){return"workspace"in e&&"command"in e}class i extends s.SpawnTask{constructor(e,t,n,s={}){let r=t;s.superCommand&&("string"==typeof s.superCommand&&(s.superCommand=[s.superCommand]),s.superCommand.length>0&&(r=s.superCommand[0],n=[...s.superCommand.slice(1),t,...n])),super(r,n,{workspace:e,command:t},{...s,cwd:e.cwd,env:{FORCE_COLOR:"1",...s.env}}),this.workspace=e,this._logStreams()}_logStreams(){(0,r.m)(this,"stdout").subscribe((e=>this._logger.info(e))),(0,r.m)(this,"stderr").subscribe((e=>this._logger.info(e)))}}},6839:(e,t,n)=>{n.d(t,{G:()=>l,s:()=>u});var s=n(2786),r=n(3410),o=n(466),i=n(8727),a=n(4244),c=n(6379);function l(e){return"workspace"in e&&"script"in e}class u extends r.GroupTask{constructor(e,t,n,s){super(t,{workspace:e,script:t},s),this.workspace=e,this.script=t,this.args=n}async _runScript(e,t){const n=this.workspace.getScript(e);if(!n)return null;const[s,...r]=(0,c.z)(n);if("jill"===s){this._logger.debug(`Interpreting ${n}`);const e=r.map((e=>e.replace(/^["'](.+)["']$/,"$1"))),t=o.nC.get(i.T),s=await t.tasksOf(e,{project:this.project,workspace:this.workspace});if(s.length)return s}const l=await this.workspace.project.packageManager();return[new a.F(this.workspace,s,[...r,...t],{logger:this._logger,superCommand:"yarn"===l?["yarn","exec"]:void 0})]}async prepare(){const e=await this._runScript(this.script,this.args);if(!e)throw new Error(`No script ${this.script} in ${this.workspace.name}`);this._scriptTasks=new r.TaskSet;for(const t of e)this.add(t),this._scriptTasks.add(t)}async*_orchestrate(){if(!this._scriptTasks)throw new Error("ScriptTask needs to be prepared. Call prepare before starting it");yield*this._scriptTasks;const e=await(0,s.waitFor$)(this._scriptTasks,"finished");this.setStatus(0===e.failed?"done":"failed")}_stop(){if(this._scriptTasks)for(const e of this._scriptTasks)e.stop()}complexity(e=new Map){let t=super.complexity(e);return this._scriptTasks&&(t+=this._scriptTasks.tasks.reduce(((t,n)=>t+n.complexity(e)),0)),e.set(this.id,t),t}get project(){return this.workspace.project}}},5099:(e,t,n)=>{n.d(t,{N:()=>a});var s=n(3410),r=n(2429),o=n(7839),i=n(466);const a=Symbol("jujulego:jill:TaskManager");i.nC.bind(a).toDynamicValue((({container:e})=>{const t=e.get(o.k),n=e.get(r.Y);return new s.TaskManager({jobs:t.jobs,logger:n})})).inSingletonScope()},6872:(e,t,n)=>{n.d(t,{Z:()=>d});var s=n(832),r=n(3410),o=n(9149),i=n(810),a=n(7839),c=n(466),l=n(4244),u=n(6797);function d({group:e}){const[t,n]=(0,i.useState)(!1),[f,p]=(0,i.useState)(e.status),[g,h]=(0,i.useState)([...e.tasks]),[m,j]=(0,i.useState)(!0),b=(0,i.useMemo)((()=>t||g.some((e=>!(0,l.g)(e.context)))),[t,g]),y=(0,i.useMemo)((()=>!b&&m),[b,m]);return(0,i.useLayoutEffect)((()=>{const e=c.nC.get(a.k);e.verbose&&n(["verbose","debug"].includes(e.verbose))}),[]),(0,i.useLayoutEffect)((()=>e.on("status",(e=>{p(e.status)}))),[e]),(0,i.useLayoutEffect)((()=>{let t=!1;return e.on("task.added",(()=>{t||(t=!0,queueMicrotask((()=>{h([...e.tasks]),t=!1})))}))}),[e]),(0,i.useLayoutEffect)((()=>{"running"===f?j(!1):"done"===f&&j(!0)}),[f]),(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(u.Z,{task:e}),y||(0,s.jsx)(o.Box,{flexDirection:"column",marginLeft:2,children:g.map((e=>(0,s.jsx)(i.Fragment,{children:e instanceof r.GroupTask?(0,s.jsx)(d,{group:e}):(0,s.jsx)(u.Z,{task:e})},e.id)))})]})}},8348:(e,t,n)=>{n.d(t,{Z:()=>j});var s=n(832),r=n(9149),o=n(9165),i=n(6133),a=n(810),c=n(466),l=n(3565);function u(){const[e,t]=(0,a.useState)({status:"stop",label:""});switch((0,a.useLayoutEffect)((()=>{const e=c.nC.get(l.V);return t(e.state),e.on("state",t)}),[]),e.status){case"spin":return(0,s.jsxs)(r.Text,{children:[(0,s.jsx)(o.default,{})," "+e.label]});case"success":return(0,s.jsxs)(r.Text,{color:"green",children:[i.default.success," ",e.label]});case"failed":return(0,s.jsxs)(r.Text,{color:"red",children:[i.default.error," ",e.label]});default:return null}}var d=n(4133),f=n(5804),p=n(2429),g=n(2033);const h=Symbol.for("message");function m(){const{write:e}=(0,r.useStderr)();return(0,a.useLayoutEffect)((()=>{const t=c.nC.get(p.Y);for(const e of t.winston.transports)e instanceof d.default.transports.Console&&t.winston.remove(e);const n=new class extends f.default{constructor(){super({format:g.D})}log(t,n){setTimeout((()=>{this.emit("logged",t)}),0),e(t[h]+"\n"),n()}};return t.winston.add(n),()=>{t.winston.remove(n),t.winston.add(new d.default.transports.Console({format:g.D}))}}),[e]),null}function j({children:e}){return(0,s.jsxs)(s.Fragment,{children:[(0,s.jsx)(m,{}),(0,s.jsx)(u,{}),e]})}},5740:(e,t,n)=>{n.d(t,{Z:()=>i});var s=n(832),r=n(9149),o=n(6379);function i({items:e,headers:t}){return 0===e.length?null:(0,s.jsx)(r.Box,{children:Object.keys(e[0]).map((n=>(0,s.jsxs)(r.Box,{flexDirection:"column",marginRight:2,children:[t&&(0,s.jsx)(r.Text,{bold:!0,children:(0,o.k)(n)}),e.map(((e,t)=>(0,s.jsx)(r.Text,{children:e[n]||" "},t)))]},n)))})}},4887:(e,t,n)=>{n.d(t,{Z:()=>l});var s=n(832),r=n(3410),o=n(810),i=n(6872),a=n(6797);function c(e){return!(e.group||"hidden"in e.context&&e.context.hidden)}function l({manager:e}){const[t,n]=(0,o.useState)(e.tasks.filter(c));return(0,o.useLayoutEffect)((()=>{let t=!1;return e.on("added",(()=>{t||(t=!0,queueMicrotask((()=>{n(e.tasks.filter(c)),t=!1})))}))}),[e]),(0,s.jsx)(s.Fragment,{children:t.map((e=>e instanceof r.GroupTask?(0,s.jsx)(i.Z,{group:e},e.id):(0,s.jsx)(a.Z,{task:e},e.id)))})}},1562:(e,t,n)=>{n.d(t,{Z:()=>i});var s=n(832),r=n(9149),o=n(6839);function i({task:e}){return(0,o.G)(e.context)?(0,s.jsxs)(r.Text,{children:["Run ",(0,s.jsx)(r.Text,{bold:!0,children:e.context.script})," in ",e.context.workspace.name]}):(0,s.jsx)(r.Text,{children:e.name})}},6797:(e,t,n)=>{n.d(t,{Z:()=>f});var s=n(832),r=n(9149),o=n(9165),i=n(6133),a=n(9321),c=n(810),l=n(4244),u=n(6839),d=n(1562);function f({task:e}){const[t,n]=(0,c.useState)(e.status),[f,p]=(0,c.useState)(0);(0,c.useLayoutEffect)((()=>e.on("status",(e=>{n(e.status)}))),[e]),(0,c.useLayoutEffect)((()=>e.on("completed",(({duration:e})=>{p(e)}))),[e]);const g=(0,l.g)(e.context)&&e.group&&(0,u.G)(e.group.context);switch(t){case"blocked":case"ready":case"starting":return(0,s.jsxs)(r.Box,{children:[(0,s.jsx)(r.Text,{color:"grey",children:"·"}),(0,s.jsx)(r.Box,{paddingLeft:1,children:(0,s.jsx)(r.Text,{color:"grey",wrap:"truncate",children:(0,s.jsx)(d.Z,{task:e})})})]});case"running":return(0,s.jsxs)(r.Box,{children:[(0,s.jsx)(r.Text,{color:g?"dim":void 0,children:(0,s.jsx)(o.default,{})}),(0,s.jsx)(r.Box,{paddingLeft:1,children:(0,s.jsx)(r.Text,{color:g?"dim":void 0,wrap:"truncate",children:(0,s.jsx)(d.Z,{task:e})})})]});case"done":return(0,s.jsxs)(r.Box,{children:[(0,s.jsx)(r.Text,{color:"green",children:i.default.success}),(0,s.jsx)(r.Box,{paddingLeft:1,children:(0,s.jsx)(r.Text,{color:g?"dim":void 0,wrap:"truncate",children:(0,s.jsx)(d.Z,{task:e})})}),(0,s.jsx)(r.Box,{paddingLeft:1,flexShrink:0,children:(0,s.jsxs)(r.Text,{color:g?"grey":"dim",children:["(took ",(0,a.default)(f),")"]})})]});case"failed":return(0,s.jsxs)(r.Box,{children:[(0,s.jsx)(r.Text,{color:"red",children:i.default.error}),(0,s.jsx)(r.Box,{paddingLeft:1,children:(0,s.jsx)(r.Text,{color:g?"dim":void 0,wrap:"truncate",children:(0,s.jsx)(d.Z,{task:e})})}),(0,s.jsx)(r.Box,{paddingLeft:1,flexShrink:0,children:(0,s.jsxs)(r.Text,{color:g?"grey":"dim",children:["(took ",(0,a.default)(f),")"]})})]})}}},3265:(e,t,n)=>{n.d(t,{m:()=>r});var s=n(2786);function r(e,t){const n=(0,s.source$)();if(e.completed)return n;let r="";const o=e.on(`stream.${t}`,(e=>{const t=(r+e.data.toString("utf-8")).split(/\r?\n/);r=t.pop()??"";for(const e of t)n.next(e)}));return(0,s.once$)(e,"completed",(()=>{o(),r&&n.next(r)})),n}},6505:(e,t,n)=>{n.d(t,{T:()=>s});class s extends Error{constructor(e,t){super(t),this.code=e}}},8520:(e,t,n)=>{async function s(e){return import("win32"===process.platform?`file://${e}`:e)}function r(e){return e}n.d(t,{v:()=>r,y:()=>s})},5472:(e,t,n)=>{function s(e,t=process.stdout){t.isTTY?t.write(JSON.stringify(e,null,2)):t.write(JSON.stringify(e))}n.d(t,{i:()=>s})},6379:(e,t,n)=>{function s(e){return e.charAt(0).toUpperCase()+e.substring(1).toLowerCase()}function r(e){e=e.trim();const t=[];let n="",s=0;for(let r=1;r<e.length;++r){const o=e[r];n?o===n&&(n=""):['"',"'"].includes(o)?n=o:" "===o&&(t.push(e.slice(s,r)),s=r+1)}return t.push(e.slice(s)),t}n.d(t,{k:()=>s,z:()=>r})},2180:(e,t,n)=>{n.d(t,{F:()=>o});var s=n(4086);const r=new s.BroadcastChannel("jujulego:jill:worker-cache");async function o(e,t){const n=(0,s.getEnvironmentData)(e);if(void 0!==n)return n;const o=await t();return(0,s.setEnvironmentData)(e,o),r.postMessage({key:e,value:o}),o}r.unref(),r.onmessage=e=>{const t=e;(function(e){return"object"==typeof e&&null!==e&&"key"in e&&"value"in e})(t.data)&&(0,s.setEnvironmentData)(t.data.key,t.data.value)}}};
2
- //# sourceMappingURL=839.mjs.map
package/dist/839.mjs.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"file":"839.mjs","mappings":"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","sources":["webpack://@jujulego/jill/./src/commons/context.service.ts","webpack://@jujulego/jill/./src/commons/logger/thread.transport.ts","webpack://@jujulego/jill/./src/commons/logger.service.ts","webpack://@jujulego/jill/./src/commons/logger/console.formatter.ts","webpack://@jujulego/jill/./src/commons/logger/log.tag.ts","webpack://@jujulego/jill/./src/commons/spinner.service.ts","webpack://@jujulego/jill/./src/ajv.config.ts","webpack://@jujulego/jill/./src/config/utils.ts","webpack://@jujulego/jill/./src/config/config-loader.ts","webpack://@jujulego/jill/./src/config/config-options.ts","webpack://@jujulego/jill/./src/constants.ts","webpack://@jujulego/jill/./src/ink.config.tsx","webpack://@jujulego/jill/./src/inversify.config.ts","webpack://@jujulego/jill/./src/jill.application.ts","webpack://@jujulego/jill/./src/modules/command.ts","webpack://@jujulego/jill/./src/modules/ink-command.tsx","webpack://@jujulego/jill/./src/modules/middleware.ts","webpack://@jujulego/jill/./src/modules/module.ts","webpack://@jujulego/jill/./src/modules/plugin-loader.service.ts","webpack://@jujulego/jill/./src/modules/service.ts","webpack://@jujulego/jill/./src/modules/task-command.tsx","webpack://@jujulego/jill/./src/tasks/command-task.ts","webpack://@jujulego/jill/./src/tasks/script-task.ts","webpack://@jujulego/jill/./src/tasks/task-manager.config.ts","webpack://@jujulego/jill/./src/ui/group-task-spinner.tsx","webpack://@jujulego/jill/./src/ui/global-spinner.tsx","webpack://@jujulego/jill/./src/ui/static-logs.tsx","webpack://@jujulego/jill/./src/ui/layout.tsx","webpack://@jujulego/jill/./src/ui/list.tsx","webpack://@jujulego/jill/./src/ui/task-manager-spinner.tsx","webpack://@jujulego/jill/./src/ui/task-name.tsx","webpack://@jujulego/jill/./src/ui/task-spinner.tsx","webpack://@jujulego/jill/./src/utils/events.ts","webpack://@jujulego/jill/./src/utils/exit.ts","webpack://@jujulego/jill/./src/utils/import.ts","webpack://@jujulego/jill/./src/utils/json.ts","webpack://@jujulego/jill/./src/utils/string.ts","webpack://@jujulego/jill/./src/utils/worker-cache.ts"],"sourcesContent":["import { inject } from 'inversify';\nimport { AsyncLocalStorage } from 'node:async_hooks';\n\nimport { Logger } from '@/src/commons/logger.service.ts';\nimport { Service } from '@/src/modules/service.ts';\nimport { type Project } from '@/src/project/project.ts';\nimport { type Workspace } from '@/src/project/workspace.ts';\nimport { type JillApplication } from '@/src/jill.application.ts';\n\n// Types\nexport interface Context {\n application?: JillApplication;\n project?: Project;\n workspace?: Workspace;\n}\n\n// Service\n@Service()\nexport class ContextService implements Context {\n // Attributes\n private readonly _logger: Logger;\n private readonly _storage = new AsyncLocalStorage<Context>();\n\n // Constructor\n constructor(@inject(Logger) logger: Logger) {\n this._logger = logger.child({ label: 'context' });\n this.reset();\n }\n\n // Methods\n reset(context: Context = {}): void {\n this._storage.enterWith(context);\n }\n\n private _getContext(): Context {\n const ctx = this._storage.getStore();\n\n if (!ctx) {\n this._logger.warn('Trying to access uninitialized context');\n return {};\n }\n\n return ctx;\n }\n\n private _updateContext(update: Partial<Context>): void {\n Object.assign(this._getContext(), update);\n }\n\n // Properties\n get application(): JillApplication | undefined {\n return this._getContext().application;\n }\n\n set application(application: JillApplication | undefined) {\n this._updateContext({ application });\n }\n\n get project(): Project | undefined {\n return this._getContext().project;\n }\n\n set project(project: Project | undefined) {\n this._updateContext({ project });\n }\n\n get workspace(): Workspace | undefined {\n return this._getContext().workspace;\n }\n\n set workspace(workspace: Workspace | undefined) {\n this._updateContext({ workspace });\n }\n}\n","import { type LogEntry } from 'winston';\nimport Transport from 'winston-transport';\nimport { BroadcastChannel } from 'node:worker_threads';\n\n// Transport\nexport class ThreadTransport extends Transport {\n // Attributes\n readonly channel: BroadcastChannel;\n\n // Constructor\n constructor(channel: string) {\n super({\n level: 'debug',\n });\n\n this.channel = new BroadcastChannel(channel);\n this.channel.onmessageerror = (err) => {\n this.emit('error', err);\n };\n this.channel.unref();\n }\n\n // Methods\n log(info: LogEntry, next: () => void): void {\n this.channel.postMessage(info);\n this.emit('logged', info);\n\n next();\n }\n\n close(cb?: () => void) {\n this.channel.close();\n\n if (cb) cb();\n this.emit('closed');\n }\n}\n","import { type ILogger } from '@jujulego/tasks';\nimport { injectable } from 'inversify';\nimport winston, { type LogEntry } from 'winston';\nimport wt from 'node:worker_threads';\n\nimport { container } from '@/src/inversify.config.ts';\n\nimport { $log } from './logger/log.tag.ts';\nimport { consoleFormat } from './logger/console.formatter.ts';\nimport { ThreadTransport } from './logger/thread.transport.ts';\n\n// Service\n@injectable()\nexport class Logger implements ILogger {\n // Constructor\n constructor(\n readonly winston: winston.Logger\n ) {}\n\n // Methods\n log(level: string, msg: string): void {\n this.winston.log(level, msg);\n }\n\n debug(msg: string): void;\n debug(strings: TemplateStringsArray, ...args: unknown[]): void;\n debug(msg: TemplateStringsArray | string, ...args: unknown[]): void {\n if (typeof msg !== 'string') {\n msg = $log(msg, ...args);\n }\n\n this.winston.debug(msg);\n }\n\n verbose(msg: string): void;\n verbose(strings: TemplateStringsArray, ...args: unknown[]): void;\n verbose(msg: TemplateStringsArray | string, ...args: unknown[]): void {\n if (typeof msg !== 'string') {\n msg = $log(msg, ...args);\n }\n\n this.winston.verbose(msg);\n }\n\n info(msg: string): void;\n info(strings: TemplateStringsArray, ...args: unknown[]): void;\n info(msg: TemplateStringsArray | string, ...args: unknown[]): void {\n if (typeof msg !== 'string') {\n msg = $log(msg, ...args);\n }\n\n this.winston.info(msg);\n }\n\n warn(msg: string, cause?: unknown): void;\n warn(strings: TemplateStringsArray, ...args: unknown[]): void;\n warn(msg: TemplateStringsArray | string, ...args: unknown[]): void {\n let cause = undefined;\n\n if (typeof msg !== 'string') {\n msg = $log(msg, ...args);\n } else {\n cause = args[0];\n }\n\n this.winston.warn(msg, cause);\n }\n\n error(msg: string, cause?: unknown): void;\n error(strings: TemplateStringsArray, ...args: unknown[]): void;\n error(msg: TemplateStringsArray | string, ...args: unknown[]): void {\n let cause = undefined;\n\n if (typeof msg !== 'string') {\n msg = $log(msg, ...args);\n } else {\n cause = args[0];\n }\n\n this.winston.error(msg, cause);\n }\n\n child(options: Record<string, unknown>): Logger {\n return new Logger(this.winston.child(options));\n }\n\n // Properties\n get level() {\n return this.winston.level;\n }\n\n set level(level: string) {\n this.winston.level = level;\n }\n}\n\ncontainer.bind(Logger)\n .toDynamicValue(() => {\n const logger = winston.createLogger({\n format: winston.format.combine(\n winston.format.timestamp(),\n winston.format.errors({\n stack: process.env.NODE_ENV === 'development'\n }),\n ),\n transports: []\n });\n\n if (wt.isMainThread) {\n logger.add(\n new winston.transports.Console({\n format: consoleFormat\n })\n );\n\n const channel = new wt.BroadcastChannel('jujulego:jill:logger');\n channel.onmessage = (entry) => logger.log((entry as MessageEvent<LogEntry>).data);\n channel.unref();\n } else {\n logger.add(new ThreadTransport('jujulego:jill:logger'));\n }\n\n return new Logger(logger);\n })\n .inSingletonScope();\n","import chalk from 'chalk';\nimport winston from 'winston';\n\n// Formatter\nexport const consoleFormat = winston.format.combine(\n winston.format.colorize({\n message: true,\n colors: { debug: 'grey', verbose: 'blue', info: 'white', error: 'red' }\n }),\n winston.format.printf(({ label, message, stack }) => {\n if (stack) message = chalk.red(stack);\n const lines = message.split('\\n');\n\n // Format\n let spaces = '';\n let formatted = lines[0];\n\n if (label) {\n spaces = ' '.repeat(label.length + 3);\n formatted = `${chalk.grey(`[${label}]`)} ${lines[0]}`;\n }\n\n for (let i = 1; i < lines.length; ++i) {\n formatted += `\\n${spaces}${lines[i]}`;\n }\n\n return formatted;\n }),\n);\n","import path from 'node:path';\n\n// Types\ntype Formatter = (arg: string) => string;\n\n// Commands\nconst COMMANDS: Record<string, Formatter> = {\n 'cwd': (arg) => path.relative(process.cwd(), arg) || '.'\n};\n\n// Tag\nexport function $log(strings: TemplateStringsArray, ...args: unknown[]): string {\n let result = strings[0];\n\n for (let i = 0; i < args.length; ++i) {\n let arg = '' + args[i];\n\n // Check for commands\n const match = result.match(/#([a-z]+):$/);\n const command = match && COMMANDS[match[1]];\n\n if (command) {\n result = result.slice(0, result.length - match[0].length);\n arg = command(arg);\n }\n\n result += arg + strings[i + 1];\n }\n\n return result;\n}\n","import { multiplexer$, source$ } from '@jujulego/event-tree';\nimport { inject } from 'inversify';\n\nimport { Logger } from '@/src/commons/logger.service.ts';\nimport { container } from '@/src/inversify.config.ts';\nimport { INK_APP } from '@/src/ink.config.tsx';\nimport { Service } from '@/src/modules/service.ts';\n\n// Interface\nexport type SpinnerStatus = 'spin' | 'stop' | 'success' | 'failed';\nexport interface SpinnerState {\n status: SpinnerStatus;\n label: string;\n}\n\n// Service\n@Service()\nexport class SpinnerService {\n // Attributes\n private readonly _logger: Logger;\n private _status: SpinnerStatus = 'stop';\n private _label = '';\n private _events = multiplexer$({\n state: source$<SpinnerState>(),\n });\n\n // Constructor\n constructor(@inject(Logger) logger: Logger) {\n this._logger = logger.child({ label: 'spinner' });\n }\n\n // Methods\n private _awakeInk() {\n // Ensure ink is instanced => spinner is printed\n container.get(INK_APP);\n }\n\n spin(label: string) {\n this._logger.debug(`spin: ${label}`);\n this._status = 'spin';\n this._label = label;\n\n this._events.emit('state', this.state);\n this._awakeInk();\n }\n\n success(label: string) {\n this._logger.debug(`success: ${label}`);\n this._status = 'success';\n this._label = label;\n\n this._events.emit('state', this.state);\n this._awakeInk();\n }\n\n failed(label: string) {\n this._logger.debug(`failed: ${label}`);\n this._status = 'failed';\n this._label = label;\n\n this._events.emit('state', this.state);\n this._awakeInk();\n }\n\n stop() {\n if (this._status === 'spin') {\n this._logger.debug(`stop: ${this._label}`);\n this._status = 'stop';\n\n this._events.emit('state', this.state);\n }\n }\n\n // Properties\n get on() {\n return this._events.on;\n }\n\n get off() {\n return this._events.off;\n }\n\n get state(): SpinnerState {\n return {\n status: this._status,\n label: this._label,\n };\n }\n}\n","import Ajv from 'ajv';\nimport { type interfaces as int } from 'inversify';\n\nimport { container } from './inversify.config.ts';\nimport { Logger } from './commons/logger.service.ts';\n\n// Symbols\nexport const AJV: int.ServiceIdentifier<Ajv.default> = Symbol('jujulego:jill:Ajv');\n\n// Setup\ncontainer\n .bind(AJV)\n .toDynamicValue(({ container }) => {\n const logger = container.get(Logger);\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n return new (Ajv as any)({\n allErrors: true,\n logger: logger.child({ label: 'ajv' }),\n strict: process.env.NODE_ENV === 'development' ? 'log' : true,\n });\n })\n .inSingletonScope();\n\n","import { type interfaces as int } from 'inversify';\nimport { type ValidateFunction } from 'ajv';\nimport { cosmiconfig, defaultLoaders } from 'cosmiconfig';\n\nimport { AJV } from '@/src/ajv.config.ts';\nimport schema from '@/src/config/schema.json';\nimport { container } from '@/src/inversify.config.ts';\nimport { dynamicImport } from '@/src/utils/import.ts';\n\nimport { type IConfig, type IConfigExplorer } from './types.ts';\n\n// Symbols\nexport const CONFIG_EXPLORER: int.ServiceIdentifier<IConfigExplorer> = Symbol('jujulego:jill:config-explorer');\nexport const CONFIG_VALIDATOR: int.ServiceIdentifier<ValidateFunction<IConfig>> = Symbol('jujulego:jill:config-validator');\n\n// Setup\ncontainer\n .bind(CONFIG_VALIDATOR)\n .toDynamicValue(({ container }) => {\n const ajv = container.get(AJV);\n return ajv.compile<IConfig>(schema);\n })\n .inSingletonScope();\n\ncontainer\n .bind(CONFIG_EXPLORER)\n .toDynamicValue(() => {\n return cosmiconfig('jill', {\n loaders: {\n '.cjs': (filepath) => dynamicImport(filepath).then((mod) => mod.default),\n '.js': (filepath) => dynamicImport(filepath).then((mod) => mod.default),\n '.json': defaultLoaders['.json'],\n '.yaml': defaultLoaders['.yaml'],\n '.yml': defaultLoaders['.yml'],\n noExt: defaultLoaders.noExt,\n }\n });\n })\n .inSingletonScope();\n","import { type interfaces as int } from 'inversify';\nimport os from 'node:os';\nimport path from 'node:path';\n\nimport { AJV } from '@/src/ajv.config.ts';\nimport { Logger } from '@/src/commons/logger.service.ts';\nimport { container } from '@/src/inversify.config.ts';\nimport { ExitException } from '@/src/utils/exit.ts';\nimport { workerCache } from '@/src/utils/worker-cache.ts';\n\nimport { CONFIG_OPTIONS } from './config-options.ts';\nimport { type IConfig } from './types.ts';\nimport { CONFIG_EXPLORER, CONFIG_VALIDATOR } from './utils.ts';\n\n// Symbols\nexport const CONFIG: int.ServiceIdentifier<IConfig> = Symbol('jujulego:jill:config');\n\n// Loader\nexport async function configLoader() {\n const logger = container.get(Logger).child({ label: 'config' });\n\n const options = container.get(CONFIG_OPTIONS);\n const explorer = container.get(CONFIG_EXPLORER);\n const validator = container.get(CONFIG_VALIDATOR);\n\n // Load file\n const loaded = await explorer.search();\n const config = loaded?.config ?? {};\n\n // Apply options from cli\n if (options.jobs) config.jobs = options.jobs;\n if (options.verbose) config.verbose = options.verbose;\n\n // Apply default\n config.jobs ??= (os.cpus().length - 1);\n\n // Validate\n if (!validator(config)) {\n const ajv = container.get(AJV);\n const errors = ajv.errorsText(validator.errors, { separator: '\\n- ', dataVar: 'config' });\n\n logger.error`Errors in config file:\\n- ${errors}`;\n throw new ExitException(1);\n }\n\n // Apply on logger\n if (config.verbose) {\n container.get(Logger).level = config.verbose;\n }\n\n if (loaded) {\n // Resolve paths relative to config file\n const base = path.dirname(loaded.filepath);\n config.plugins = config.plugins?.map((plugin) => path.resolve(base, plugin));\n\n logger.verbose`Loaded ${loaded.filepath} config file`;\n }\n\n logger.debug`Loaded config:\\n${JSON.stringify(config, null, 2)}`;\n\n return config;\n}\n\ncontainer\n .bind(CONFIG)\n .toDynamicValue(async () => await workerCache('jujulego:jill:config', configLoader))\n .inSingletonScope();\n","import yargs, { type Argv } from 'yargs';\nimport { type interfaces as int } from 'inversify';\nimport { hideBin } from 'yargs/helpers';\n\nimport { container } from '@/src/inversify.config.ts';\n\nimport { type IConfig } from './types.ts';\n\n// Symbols\nexport const CONFIG_OPTIONS: int.ServiceIdentifier<IConfig> = Symbol('jujulego:jill:config-options');\n\n// Constants\nconst VERBOSITY_LEVEL: Record<number, IConfig['verbose']> = {\n 1: 'verbose',\n 2: 'debug',\n};\n\n// Options\nexport function applyConfigOptions(parser: Argv): Argv<Omit<IConfig, 'plugins'>> {\n return parser\n .option('verbose', {\n alias: 'v',\n type: 'count',\n description: 'Set verbosity level',\n coerce: (cnt) => VERBOSITY_LEVEL[Math.min(cnt, 2)]\n })\n .option('jobs', {\n alias: 'j',\n type: 'number',\n description: 'Set maximum parallel job number',\n });\n}\n\ncontainer\n .bind(CONFIG_OPTIONS)\n .toDynamicValue(() => {\n const parser = yargs(hideBin(process.argv))\n .help(false)\n .version(false);\n\n applyConfigOptions(parser);\n\n return parser.parse();\n })\n .inSingletonScope();\n","// Constants\nexport const CURRENT = 'current';\n","import { type Instance } from 'ink';\nimport { render } from 'ink';\nimport { type interfaces as int } from 'inversify';\nimport wt from 'node:worker_threads';\n\nimport { container } from '@/src/inversify.config.ts';\nimport Layout from '@/src/ui/layout.tsx';\n\n// Constants\nexport const INK_APP: int.ServiceIdentifier<Instance> = Symbol.for('jujulego:jill:ink-app');\n\n// Setup\ncontainer\n .bind(INK_APP)\n .toDynamicValue(() => {\n if (!wt.isMainThread) {\n throw new Error('Ink should only be used in main thread');\n }\n\n return render(\n <Layout />,\n {\n stdout: process.stdout.isTTY ? process.stdout : process.stderr,\n }\n );\n })\n .inSingletonScope();\n","import { Container } from 'inversify';\nimport getDecorators from 'inversify-inject-decorators';\n\nimport 'reflect-metadata';\n\nimport { fixDefaultExport } from './utils/import.ts';\n\n// Container\nexport const container = new Container();\n\n// Utilities\nexport const { lazyInject, lazyInjectNamed } = fixDefaultExport(getDecorators)(container);\n","import { type Task } from '@jujulego/tasks';\nimport { inject, injectable, type interfaces as int } from 'inversify';\nimport yargs, { type Argv, type CommandModule } from 'yargs';\n\nimport { ContextService, type Context } from '@/src/commons/context.service.ts';\nimport { Logger } from '@/src/commons/logger.service.ts';\nimport { applyConfigOptions } from '@/src/config/config-options.ts';\nimport { CURRENT } from '@/src/constants.ts';\nimport { container, lazyInjectNamed } from '@/src/inversify.config.ts';\nimport { buildCommandModule, COMMAND, COMMAND_MODULE, getCommandOpts, type ICommand } from '@/src/modules/command.ts';\nimport { getModule } from '@/src/modules/module.ts';\nimport { PluginLoaderService } from '@/src/modules/plugin-loader.service.ts';\nimport { TaskCommand } from '@/src/modules/task-command.tsx';\nimport { type Class } from '@/src/types.ts';\n\n// @ts-ignore: Outside of typescript's rootDir in build\nimport pkg from '../package.json';\n\n// Application\n@injectable()\nexport class JillApplication {\n // Attributes\n readonly container: int.Container;\n readonly parser: Argv;\n\n // Constructor\n constructor(\n @inject(ContextService)\n private readonly context: ContextService,\n @inject(PluginLoaderService)\n private readonly plugins: PluginLoaderService,\n @inject(Logger)\n private readonly logger: Logger,\n ) {\n // Create container\n this.container = container.createChild();\n\n // Create parser\n this.parser = yargs()\n .scriptName('jill')\n .completion('completion', 'Generate bash completion script')\n .help('help', 'Show help for a command')\n .version('version', 'Show version', pkg.version)\n .wrap(process.stdout.columns)\n .exitProcess(false);\n }\n\n // Methods\n private _prepareParser(commands: CommandModule[]): Argv {\n applyConfigOptions(this.parser);\n\n return this.parser\n .command(commands)\n .recommendCommands()\n .strict()\n .fail(false);\n }\n\n private async _loadPlugins(): Promise<void> {\n this.logger.child({ label: 'plugin' }).verbose('Loading plugin <core>');\n\n const { CorePlugin } = await import('@/src/core.plugin.ts');\n this.container.load(getModule(CorePlugin, true));\n\n await this.plugins.loadPlugins(this.container);\n }\n\n async run(argv: string | readonly string[]): Promise<void> {\n this.context.reset({ application: this });\n await this._loadPlugins();\n\n // Parse command\n const commands = await this.container.getAllAsync(COMMAND_MODULE);\n\n await this._prepareParser(commands).parseAsync(argv);\n }\n\n async tasksOf(argv: string[], ctx: Omit<Context, 'application'> = {}): Promise<Task[]> {\n this.context.reset({ ...ctx, application: this });\n await this._loadPlugins();\n\n // Prepare commands\n const commands = await this.container.getAllAsync(COMMAND);\n\n return new Promise<Task[]>((resolve, reject) => {\n const modules: CommandModule[] = [];\n\n for (const cmd of commands) {\n const opts = getCommandOpts(cmd.constructor as Class<ICommand>);\n const mod = buildCommandModule(cmd, opts);\n\n mod.handler = async (args) => {\n if (cmd instanceof TaskCommand) {\n const tasks: Task[] = [];\n\n for await (const tsk of cmd.prepare(args)) {\n tasks.push(tsk);\n }\n\n resolve(tasks);\n } else {\n resolve([]);\n }\n };\n\n modules.push(mod);\n }\n\n // Parse command\n this._prepareParser(modules)\n .parseAsync(argv)\n .catch(reject);\n });\n }\n}\n\ncontainer.bind(JillApplication)\n .toSelf()\n .inTransientScope()\n .whenTargetIsDefault();\n\n// Lazy injection\nexport function LazyCurrentApplication() {\n return lazyInjectNamed(JillApplication, CURRENT);\n}\n\ncontainer.bind(JillApplication)\n .toDynamicValue(({ container }) => {\n const ctx = container.get(ContextService);\n const app = ctx.application;\n\n if (!app) {\n throw new Error('Cannot inject current application, it not yet defined');\n }\n\n return app;\n })\n .whenTargetNamed(CURRENT);\n","import { decorate, injectable, type interfaces as int } from 'inversify';\nimport { type ArgumentsCamelCase, type Argv, type CommandModule } from 'yargs';\n\nimport { setRegistry } from '@/src/modules/module.ts';\nimport { type Awaitable, type Class, type Type } from '@/src/types.ts';\n\nimport { applyMiddlewares, type IMiddleware } from './middleware.ts';\n\n// Symbols\nconst COMMAND_OPTS = Symbol('jujulego:jill:command-opts');\n\nexport const COMMAND: int.ServiceIdentifier<ICommand> = Symbol('jujulego:jill:command');\nexport const COMMAND_MODULE: int.ServiceIdentifier<CommandModule> = Symbol('jujulego:jill:command-module');\n\n// Types\nexport interface ICommand<A = unknown> {\n builder?: (parser: Argv) => Argv<A>;\n handler(args: ArgumentsCamelCase<A>): Awaitable<void>;\n}\n\nexport interface ICommandOpts {\n readonly command: string;\n readonly aliases?: string | readonly string[];\n readonly describe?: string;\n readonly deprecated?: boolean;\n readonly middlewares?: Type<IMiddleware>[];\n}\n\n// Utils\nexport function getCommandOpts(target: Class<ICommand>): ICommandOpts {\n const opts = Reflect.getMetadata(COMMAND_OPTS, target);\n\n if (typeof opts !== 'object') {\n throw new Error(`No command options found in ${target.name}`);\n }\n\n return opts;\n}\n\nexport function buildCommandModule(cmd: ICommand, opts: ICommandOpts): CommandModule {\n return {\n command: opts.command,\n aliases: opts.aliases,\n describe: opts.describe,\n deprecated: opts.deprecated,\n\n builder(parser: Argv) {\n if (opts.middlewares) {\n parser = applyMiddlewares(parser, opts.middlewares);\n }\n\n if (cmd.builder) {\n parser = cmd.builder(parser);\n }\n\n return parser;\n },\n handler: (args) => cmd.handler(args),\n };\n}\n\n// Decorator\nexport function Command(opts: ICommandOpts) {\n return (target: Class<ICommand>) => {\n decorate(injectable(), target);\n\n Reflect.defineMetadata(COMMAND_OPTS, opts, target);\n\n const cmd = opts.command.split(' ')[0];\n setRegistry(target, (bind) => {\n bind(target).toSelf();\n\n bind(COMMAND)\n .toDynamicValue(({ container }) => container.getAsync(target))\n .whenTargetNamed(cmd);\n\n bind(COMMAND_MODULE)\n .toDynamicValue(async ({ container }) => {\n const cmd = await container.getAsync(target);\n return buildCommandModule(cmd, opts);\n })\n .whenTargetNamed(cmd);\n });\n };\n}\n","import { type Instance} from 'ink';\nimport { injectable } from 'inversify';\nimport { type ReactNode } from 'react';\nimport { type ArgumentsCamelCase, type Argv } from 'yargs';\n\nimport { INK_APP } from '@/src/ink.config.tsx';\nimport { lazyInject } from '@/src/inversify.config.ts';\nimport { type AwaitableGenerator } from '@/src/types.ts';\nimport Layout from '@/src/ui/layout.tsx';\n\nimport { type ICommand } from './command.ts';\n\n// Class\n@injectable()\nexport abstract class InkCommand<A = unknown> implements ICommand<A> {\n // Lazy injections\n @lazyInject(INK_APP)\n readonly app: Instance;\n\n // Methods\n abstract render(args: ArgumentsCamelCase<A>): AwaitableGenerator<ReactNode>;\n\n builder(parser: Argv): Argv<A> {\n return parser as Argv<A>;\n }\n\n async handler(args: ArgumentsCamelCase<A>): Promise<void> {\n for await (const children of this.render(args)) {\n this.app.rerender(\n <Layout>\n { children }\n </Layout>\n );\n }\n\n await this.app.waitUntilExit();\n }\n}\n","import { decorate, injectable } from 'inversify';\nimport { type ArgumentsCamelCase, type Argv } from 'yargs';\n\nimport { container } from '@/src/inversify.config.ts';\nimport { type Awaitable, type Type } from '@/src/types.ts';\n\n// Types\nexport interface IMiddleware<A = unknown> {\n builder?: (parser: Argv) => Argv<A>;\n handler(args: ArgumentsCamelCase<A>): Awaitable<void>;\n}\n\n// Decorator\nexport function Middleware() {\n return (target: Type<IMiddleware>) => {\n decorate(injectable(), target);\n container.bind(target).toSelf().inSingletonScope();\n };\n}\n\n// Utils\nexport function applyMiddlewares(parser: Argv, middlewares: Type<IMiddleware>[]): Argv {\n let tmp = parser;\n\n for (const cls of middlewares) {\n const middleware = container.get(cls);\n\n if (middleware.builder) {\n tmp = middleware.builder(tmp);\n }\n\n tmp.middleware((args) => middleware.handler(args));\n }\n\n return tmp;\n}\n","import { ContainerModule, type interfaces as int } from 'inversify';\n\nimport { type Class } from '@/src/types.ts';\n\n// Symbols\nconst MODULE = Symbol('jujulego:jill:module');\nconst REGISTRY = Symbol('jujulego:jill:registry');\n\n// Utils\nexport function getRegistry(target: Class): int.ContainerModuleCallBack {\n const registry = Reflect.getMetadata(REGISTRY, target);\n\n if (typeof registry !== 'function') {\n throw new Error(`No registry found in ${target.name}`);\n }\n\n return registry;\n}\n\nexport function setRegistry(target: Class, registry: int.ContainerModuleCallBack) {\n Reflect.defineMetadata(REGISTRY, registry, target);\n}\n\nexport function getModule(target: Class): ContainerModule | null;\nexport function getModule(target: Class, assert: true): ContainerModule;\nexport function getModule(target: Class, assert = false): ContainerModule | null {\n let module = Reflect.getMetadata(MODULE, target);\n\n if (!module || !(module instanceof ContainerModule)) {\n const registry = Reflect.getMetadata(REGISTRY, target);\n\n if (typeof registry !== 'function') {\n if (assert) {\n throw new Error(`No module found in ${target.name}`);\n }\n\n return null;\n }\n\n module = new ContainerModule(registry);\n setModule(target, module);\n }\n\n return module;\n}\n\nexport function setModule(target: Class, module: ContainerModule) {\n Reflect.defineMetadata(MODULE, module, target);\n}\n","import { type ContainerModule, inject, type interfaces as int } from 'inversify';\n\nimport { CONFIG } from '@/src/config/config-loader.ts';\nimport { type IConfig } from '@/src/config/types.ts';\nimport { Logger } from '@/src/commons/logger.service.ts';\nimport { container } from '@/src/inversify.config.ts';\nimport { dynamicImport } from '@/src/utils/import.ts';\n\nimport { getModule } from './module.ts';\nimport { Service } from './service.ts';\n\n// Class\n@Service()\nexport class PluginLoaderService {\n // Attributes\n private readonly _logger: Logger;\n\n // Constructor\n constructor(\n @inject(CONFIG)\n private readonly _config: IConfig,\n @inject(Logger)\n logger: Logger,\n ) {\n this._logger = logger.child({ label: 'plugin' });\n }\n\n // Methods\n private async _importPlugin(filepath: string): Promise<ContainerModule> {\n this._logger.verbose`Loading plugin ${filepath}`;\n\n // Load plugin\n let plugin = await dynamicImport(filepath);\n\n while (plugin && typeof plugin === 'object' && 'default' in plugin) {\n plugin = plugin.default;\n }\n\n if (!plugin) {\n throw new Error(`Invalid plugin ${filepath}: no plugin class found`);\n }\n\n // Load module from plugin\n const module = getModule(plugin);\n\n if (!module) {\n throw new Error(`Invalid plugin ${filepath}: invalid plugin class`);\n }\n\n return module;\n }\n\n async loadPlugins(ctn: int.Container = container): Promise<void> {\n if (!this._config.plugins) return;\n\n for (const path of this._config.plugins) {\n const plugin = await this._importPlugin(path);\n ctn.load(plugin);\n }\n }\n}\n","import { decorate, injectable } from 'inversify';\n\nimport { container } from '@/src/inversify.config.ts';\n\n// Decorators\n/**\n * Register class as a service\n */\nexport function Service(): ClassDecorator {\n return (cls) => {\n decorate(injectable(), cls);\n container.bind(cls).toSelf().inSingletonScope();\n\n return cls;\n };\n}\n","import { waitFor$ } from '@jujulego/event-tree';\nimport { plan as extractPlan, type Task, type TaskManager, TaskSet, type TaskSummary } from '@jujulego/tasks';\nimport { injectable } from 'inversify';\nimport { type ArgumentsCamelCase, type Argv } from 'yargs';\n\nimport { Logger } from '@/src/commons/logger.service.ts';\nimport { container, lazyInject } from '@/src/inversify.config.ts';\nimport { isCommandCtx } from '@/src/tasks/command-task.ts';\nimport { isScriptCtx } from '@/src/tasks/script-task.ts';\nimport { TASK_MANAGER } from '@/src/tasks/task-manager.config.ts';\nimport { type AwaitableGenerator } from '@/src/types.ts';\nimport List from '@/src/ui/list.tsx';\nimport TaskManagerSpinner from '@/src/ui/task-manager-spinner.tsx';\nimport { ExitException } from '@/src/utils/exit.ts';\nimport { printJson } from '@/src/utils/json.ts';\n\nimport { InkCommand } from './ink-command.tsx';\n\n// Types\nexport interface ITaskCommandArgs {\n plan: boolean;\n 'plan-mode': 'json' | 'list';\n}\n\n// Class\n@injectable()\nexport abstract class TaskCommand<A = unknown> extends InkCommand<A> {\n // Attributes\n @lazyInject(TASK_MANAGER)\n readonly manager: TaskManager;\n\n // Methods\n abstract prepare(args: ArgumentsCamelCase<A>): AwaitableGenerator<Task>;\n\n protected addTaskOptions(parser: Argv): Argv<ITaskCommandArgs> {\n return parser\n .option('plan', {\n type: 'boolean',\n desc: 'Only prints tasks to be run',\n default: false,\n })\n .option('plan-mode', {\n type: 'string',\n desc: 'Plan output mode',\n choices: ['json', 'list'] as const,\n default: 'list' as const\n });\n }\n\n async* render(args: ArgumentsCamelCase<A & ITaskCommandArgs>) {\n // Prepare tasks\n const tasks = new TaskSet();\n\n for await (const tsk of this.prepare(args)) {\n tasks.add(tsk);\n }\n\n if (args.plan) {\n const plan: TaskSummary[] = Array.from(extractPlan(tasks));\n\n if (args.planMode === 'json') {\n printJson(plan);\n } else {\n const data = plan.map((tsk) => ({\n id: tsk.id.substring(0, 6),\n name: tsk.name,\n workspace: isCommandCtx(tsk.context) || isScriptCtx(tsk.context) ? tsk.context.workspace.name : '',\n group: tsk.groupId?.substring(0, 6),\n 'depends on': tsk.dependenciesIds.map(id => id.substring(0, 6)).join(', ')\n }));\n\n yield <List items={data} headers/>;\n }\n } else if (tasks.tasks.length > 0) {\n // Render\n yield <TaskManagerSpinner manager={this.manager} />;\n\n // Start tasks\n tasks.start(this.manager);\n\n const result = await waitFor$(tasks, 'finished');\n\n if (result.failed > 0) {\n throw new ExitException(1);\n }\n } else {\n const logger = container.get(Logger);\n logger.warn`No task found`;\n }\n }\n}\n","import { SpawnTask, type SpawnTaskOptions, type TaskContext } from '@jujulego/tasks';\n\nimport { type Workspace } from '@/src/project/workspace.ts';\nimport { linesFrom } from '@/src/utils/events.ts';\n\n// Types\nexport interface CommandContext extends TaskContext {\n workspace: Workspace;\n command: string;\n}\n\nexport interface CommandOptions extends Omit<SpawnTaskOptions, 'cwd'> {\n superCommand?: string | string[];\n}\n\n// Utils\nexport function isCommandCtx(ctx: Readonly<TaskContext>): ctx is Readonly<CommandContext> {\n return 'workspace' in ctx && 'command' in ctx;\n}\n\n// Class\nexport class CommandTask extends SpawnTask<CommandContext> {\n // Constructor\n constructor(readonly workspace: Workspace, command: string, args: string[], opts: CommandOptions = {}) {\n let cmd = command;\n\n if (opts.superCommand) {\n if (typeof opts.superCommand === 'string') {\n opts.superCommand = [opts.superCommand];\n }\n\n if (opts.superCommand.length > 0) {\n cmd = opts.superCommand[0];\n args = [...opts.superCommand.slice(1), command, ...args];\n }\n }\n\n super(cmd, args, { workspace, command }, {\n ...opts,\n cwd: workspace.cwd,\n env: {\n FORCE_COLOR: '1',\n ...opts.env\n }\n });\n\n this._logStreams();\n }\n\n // Methods\n private _logStreams() {\n // TODO: clean up this subscriptions\n linesFrom(this, 'stdout').subscribe((line) => this._logger.info(line));\n linesFrom(this, 'stderr').subscribe((line) => this._logger.info(line));\n }\n}\n","import { waitFor$ } from '@jujulego/event-tree';\nimport { GroupTask, type Task, type TaskContext, type TaskOptions, TaskSet } from '@jujulego/tasks';\n\nimport { container } from '@/src/inversify.config.ts';\nimport { JillApplication } from '@/src/jill.application.ts';\nimport { type Workspace } from '@/src/project/workspace.ts';\nimport { CommandTask } from '@/src/tasks/command-task.ts';\nimport { splitCommandLine } from '@/src/utils/string.ts';\n\n// Types\nexport interface ScriptContext extends TaskContext {\n workspace: Workspace;\n script: string;\n}\n\n// Utils\nexport function isScriptCtx(ctx: Readonly<TaskContext>): ctx is Readonly<ScriptContext> {\n return 'workspace' in ctx && 'script' in ctx;\n}\n\n// Class\nexport class ScriptTask extends GroupTask<ScriptContext> {\n // Attributes\n private _scriptTasks?: TaskSet;\n\n // Constructor\n constructor(\n readonly workspace: Workspace,\n readonly script: string,\n readonly args: string[],\n opts?: TaskOptions\n ) {\n super(script, { workspace, script }, opts);\n }\n\n // Methods\n private async _runScript(script: string, args: string[]): Promise<Task[] | null> {\n const line = this.workspace.getScript(script);\n\n if (!line) {\n return null;\n }\n\n // Create command task for script\n const [command, ...commandArgs] = splitCommandLine(line);\n\n if (command === 'jill') {\n this._logger.debug(`Interpreting ${line}`);\n const argv = commandArgs.map(arg => arg.replace(/^[\"'](.+)[\"']$/, '$1'));\n\n const app = container.get(JillApplication);\n const tasks = await app.tasksOf(argv, {\n project: this.project,\n workspace: this.workspace,\n });\n\n if (tasks.length) {\n return tasks;\n }\n }\n\n const pm = await this.workspace.project.packageManager();\n\n return [\n new CommandTask(this.workspace, command, [...commandArgs, ...args], {\n logger: this._logger,\n superCommand: pm === 'yarn' ? ['yarn', 'exec'] : undefined,\n })\n ];\n }\n\n async prepare(): Promise<void> {\n const tasks = await this._runScript(this.script, this.args);\n\n if (!tasks) {\n throw new Error(`No script ${this.script} in ${this.workspace.name}`);\n }\n\n this._scriptTasks = new TaskSet();\n\n for (const tsk of tasks) {\n this.add(tsk);\n this._scriptTasks.add(tsk);\n }\n }\n\n protected async *_orchestrate(): AsyncGenerator<Task, void, undefined> {\n if (!this._scriptTasks) {\n throw new Error('ScriptTask needs to be prepared. Call prepare before starting it');\n }\n\n yield* this._scriptTasks;\n\n const results = await waitFor$(this._scriptTasks, 'finished');\n this.setStatus(results.failed === 0 ? 'done' : 'failed');\n }\n\n protected _stop(): void {\n if (!this._scriptTasks) return;\n\n for (const tsk of this._scriptTasks) {\n tsk.stop();\n }\n }\n\n complexity(cache = new Map<string, number>()): number {\n let complexity = super.complexity(cache);\n\n if (this._scriptTasks) {\n complexity += this._scriptTasks.tasks.reduce((cpl, tsk) => cpl + tsk.complexity(cache), 0);\n }\n\n cache.set(this.id, complexity);\n\n return complexity;\n }\n\n // Properties\n get project() {\n return this.workspace.project;\n }\n}\n","import { TaskManager } from '@jujulego/tasks';\nimport { type interfaces as int } from 'inversify';\n\nimport { Logger } from '@/src/commons/logger.service.ts';\nimport { CONFIG } from '@/src/config/config-loader.ts';\nimport { container } from '@/src/inversify.config.ts';\n\n// Symbols\nexport const TASK_MANAGER: int.ServiceIdentifier<TaskManager> = Symbol('jujulego:jill:TaskManager');\n\n// Service\ncontainer.bind(TASK_MANAGER)\n .toDynamicValue(({ container }) => {\n const config = container.get(CONFIG);\n const logger = container.get(Logger);\n\n return new TaskManager({ jobs: config.jobs, logger });\n })\n .inSingletonScope();\n","import { GroupTask } from '@jujulego/tasks';\nimport { Box } from 'ink';\nimport { Fragment, useLayoutEffect, useMemo, useState } from 'react';\n\nimport { CONFIG } from '@/src/config/config-loader.ts';\nimport { container } from '@/src/inversify.config.ts';\nimport { isCommandCtx } from '@/src/tasks/command-task.ts';\n\nimport TaskSpinner from './task-spinner.tsx';\n\n// Types\nexport interface GroupTaskSpinnerProps {\n group: GroupTask;\n}\n\n// Components\nexport default function GroupTaskSpinner({ group }: GroupTaskSpinnerProps) {\n // State\n const [verbose, setVerbose] = useState(false);\n const [status, setStatus] = useState(group.status);\n const [tasks, setTasks] = useState([...group.tasks]);\n const [canReduce, setCanReduce] = useState(true);\n\n // Memo\n const forceExtended = useMemo(() => verbose || tasks.some((tsk) => !isCommandCtx(tsk.context)), [verbose, tasks]);\n const isReduced = useMemo(() => !forceExtended && canReduce, [forceExtended, canReduce]);\n\n // Effects\n useLayoutEffect(() => {\n const config = container.get(CONFIG);\n\n if (config.verbose) {\n setVerbose(['verbose', 'debug'].includes(config.verbose));\n }\n }, []);\n\n useLayoutEffect(() => {\n return group.on('status', (event) => {\n setStatus(event.status);\n });\n }, [group]);\n\n useLayoutEffect(() => {\n let dirty = false;\n\n return group.on('task.added', () => {\n if (!dirty) {\n dirty = true;\n\n queueMicrotask(() => {\n setTasks([...group.tasks]);\n dirty = false;\n });\n }\n });\n }, [group]);\n\n useLayoutEffect(() => {\n if (status === 'running') {\n setCanReduce(false);\n } else if (status === 'done') {\n setCanReduce(true);\n }\n }, [status]);\n\n // Render\n return (\n <>\n <TaskSpinner task={group} />\n { isReduced || (\n <Box flexDirection=\"column\" marginLeft={2}>\n { tasks.map((task) => (\n <Fragment key={task.id}>\n { (task instanceof GroupTask) ? (\n <GroupTaskSpinner group={task} />\n ) : (\n <TaskSpinner task={task} />\n ) }\n </Fragment>\n )) }\n </Box>\n ) }\n </>\n );\n}\n","import { Text } from 'ink';\nimport Spinner from 'ink-spinner';\nimport symbols from 'log-symbols';\nimport { useLayoutEffect, useState } from 'react';\n\nimport { container } from '@/src/inversify.config.ts';\nimport { SpinnerService, type SpinnerState } from '@/src/commons/spinner.service.ts';\n\n// Components\nexport default function GlobalSpinner() {\n // State\n const [state, setState] = useState<SpinnerState>({ status: 'stop', label: '' });\n\n // Effect\n useLayoutEffect(() => {\n const spinner = container.get(SpinnerService);\n setState(spinner.state);\n\n return spinner.on('state', setState);\n }, []);\n\n // Render\n switch (state.status) {\n case 'spin':\n return (\n <Text>\n <Spinner />{' ' + state.label}\n </Text>\n );\n\n case 'success':\n return (\n <Text color=\"green\">\n {symbols.success} {state.label}\n </Text>\n );\n\n case 'failed':\n return (\n <Text color=\"red\">\n {symbols.error} {state.label}\n </Text>\n );\n\n case 'stop':\n default:\n return null;\n }\n}\n","import { useStderr } from 'ink';\nimport { useLayoutEffect, } from 'react';\nimport winston from 'winston';\nimport Transport from 'winston-transport';\n\nimport { container } from '@/src/inversify.config.ts';\nimport { Logger } from '@/src/commons/logger.service.ts';\nimport { consoleFormat } from '@/src/commons/logger/console.formatter.ts';\n\n// Constants\nconst MESSAGE = Symbol.for('message');\n\n// Types\ninterface Info extends Record<string, unknown> {\n [MESSAGE]: string;\n}\n\n// Component\nexport default function StaticLogs() {\n // State\n const { write } = useStderr();\n\n // Effect\n useLayoutEffect(() => {\n const logger = container.get(Logger);\n\n // Remove Console transport\n for (const transport of logger.winston.transports) {\n if (transport instanceof winston.transports.Console) {\n logger.winston.remove(transport);\n }\n }\n\n // Add custom transport\n const transport = new class extends Transport {\n // Constructor\n constructor() {\n super({\n format: consoleFormat\n });\n }\n\n // Methods\n log(info: Info, next: () => void): void {\n setTimeout(() => {\n this.emit('logged', info);\n }, 0);\n\n write(info[MESSAGE] + '\\n');\n\n next();\n }\n };\n\n logger.winston.add(transport);\n\n return () => {\n logger.winston.remove(transport);\n logger.winston.add(new winston.transports.Console({\n format: consoleFormat\n }));\n };\n }, [write]);\n\n return null;\n}\n","import { type ReactNode } from 'react';\n\nimport GlobalSpinner from './global-spinner.tsx';\nimport StaticLogs from './static-logs.tsx';\n\n// Types\nexport interface LayoutProps {\n children?: ReactNode;\n}\n\n// Component\nexport default function Layout({ children }: LayoutProps) {\n return (\n <>\n <StaticLogs />\n <GlobalSpinner />\n { children }\n </>\n );\n}\n","import { Box, Text } from 'ink';\n\nimport { capitalize } from '@/src/utils/string.ts';\n\n// Types\nexport interface ListProps<T extends Record<string, unknown>> {\n items: T[];\n headers?: boolean;\n}\n\n// Component\nexport default function List<T extends Record<string, unknown>>({ items, headers }: ListProps<T>) {\n if (items.length === 0) {\n return null;\n }\n\n return (\n <Box>\n { Object.keys(items[0]).map((key) => (\n <Box key={key} flexDirection=\"column\" marginRight={2}>\n { headers && (\n <Text bold>{ capitalize(key) }</Text>\n ) }\n { items.map((item, idx) => (\n <Text key={idx}>{ item[key] as string || ' ' }</Text>\n )) }\n </Box>\n )) }\n </Box>\n );\n}\n","import { GroupTask, Task, type TaskManager } from '@jujulego/tasks';\nimport { useLayoutEffect, useState } from 'react';\n\nimport GroupTaskSpinner from './group-task-spinner.tsx';\nimport TaskSpinner from './task-spinner.tsx';\n\n// Types\nexport interface TasksSpinnerProps {\n manager: TaskManager;\n}\n\n// Utils\nfunction taskPredicate(task: Task): boolean {\n if (task.group) {\n return false;\n }\n\n if ('hidden' in task.context && task.context.hidden) {\n return false;\n }\n\n return true;\n}\n\n// Components\nexport default function TaskManagerSpinner({ manager }: TasksSpinnerProps) {\n const [tasks, setTasks] = useState(manager.tasks.filter(taskPredicate));\n\n useLayoutEffect(() => {\n let dirty = false;\n\n return manager.on('added', () => {\n if (!dirty) {\n dirty = true;\n\n queueMicrotask(() => {\n setTasks(manager.tasks.filter(taskPredicate));\n dirty = false;\n });\n }\n });\n }, [manager]);\n\n return (\n <>\n { tasks.map((task) =>\n (task instanceof GroupTask) ? (\n <GroupTaskSpinner key={task.id} group={task} />\n ) : (\n <TaskSpinner key={task.id} task={task} />\n )\n ) }\n </>\n );\n}\n","import { type Task } from '@jujulego/tasks';\nimport { Text } from 'ink';\n\nimport { isScriptCtx } from '@/src/tasks/script-task.ts';\n\n// Types\nexport interface TaskNameProps {\n task: Task;\n}\n\n// Components\nexport default function TaskName({ task }: TaskNameProps) {\n if (isScriptCtx(task.context)) {\n return (\n <Text>\n Run <Text bold>{ task.context.script }</Text> in { task.context.workspace.name }\n </Text>\n );\n } else {\n return <Text>{ task.name }</Text>;\n }\n}\n","import { type Task } from '@jujulego/tasks';\nimport { Box, Text } from 'ink';\nimport Spinner from 'ink-spinner';\nimport symbols from 'log-symbols';\nimport ms from 'pretty-ms';\nimport { useLayoutEffect, useState } from 'react';\n\nimport { isCommandCtx } from '@/src/tasks/command-task.ts';\nimport { isScriptCtx } from '@/src/tasks/script-task.ts';\n\nimport TaskName from './task-name.tsx';\n\n// Types\nexport interface TaskSpinnerProps {\n task: Task;\n}\n\n// Components\nexport default function TaskSpinner({ task }: TaskSpinnerProps) {\n // State\n const [status, setStatus] = useState(task.status);\n const [time, setTime] = useState(0);\n\n // Effects\n useLayoutEffect(() => {\n return task.on('status', (event) => {\n setStatus(event.status);\n });\n }, [task]);\n\n useLayoutEffect(() => {\n return task.on('completed', ({ duration }) => {\n setTime(duration);\n });\n }, [task]);\n\n // Render\n const isScriptChild = isCommandCtx(task.context) && task.group && isScriptCtx(task.group.context);\n\n switch (status) {\n case 'blocked':\n case 'ready':\n case 'starting':\n return (\n <Box>\n <Text color=\"grey\">{'\\u00B7'}</Text>\n <Box paddingLeft={1}>\n <Text color=\"grey\" wrap=\"truncate\"><TaskName task={task} /></Text>\n </Box>\n </Box>\n );\n\n case 'running':\n return (\n <Box>\n <Text color={isScriptChild ? 'dim' : undefined}>\n <Spinner />\n </Text>\n <Box paddingLeft={1}>\n <Text color={isScriptChild ? 'dim' : undefined} wrap=\"truncate\">\n <TaskName task={task} />\n </Text>\n </Box>\n </Box>\n );\n\n case 'done':\n return (\n <Box>\n <Text color=\"green\">{ symbols.success }</Text>\n <Box paddingLeft={1}>\n <Text color={isScriptChild ? 'dim' : undefined} wrap=\"truncate\"><TaskName task={task} /></Text>\n </Box>\n <Box paddingLeft={1} flexShrink={0}>\n <Text color={isScriptChild ? 'grey' : 'dim'}>(took {ms(time)})</Text>\n </Box>\n </Box>\n );\n\n case 'failed':\n return (\n <Box>\n <Text color=\"red\">{ symbols.error }</Text>\n <Box paddingLeft={1}>\n <Text color={isScriptChild ? 'dim' : undefined} wrap=\"truncate\"><TaskName task={task} /></Text>\n </Box>\n <Box paddingLeft={1} flexShrink={0}>\n <Text color={isScriptChild ? 'grey' : 'dim'}>(took {ms(time)})</Text>\n </Box>\n </Box>\n );\n }\n}\n","import { once$, source$, type Source } from '@jujulego/event-tree';\nimport { type SpawnTask, type SpawnTaskStream } from '@jujulego/tasks';\n\n// Utils\nexport function linesFrom(task: SpawnTask, stream: SpawnTaskStream): Source<string> {\n const inner = source$<string>();\n\n if (task.completed) {\n return inner;\n }\n\n // Listen to stream\n let current = '';\n\n const stop = task.on(`stream.${stream}`, (chunk) => {\n const data = current + chunk.data.toString('utf-8');\n const lines = data.split(/\\r?\\n/);\n\n current = lines.pop() ?? '';\n\n for (const line of lines) {\n inner.next(line);\n }\n });\n\n // Listen to end of task\n once$(task, 'completed', () => {\n stop();\n\n if (current) {\n inner.next(current);\n }\n });\n\n return inner;\n}\n","// Class\nexport class ExitException extends Error {\n // Constructor\n constructor(readonly code: number, message?: string) {\n super(message);\n }\n}\n","// Utils\nexport async function dynamicImport(filepath: string) {\n return import(/* webpackIgnore: true */ process.platform === 'win32' ? `file://${filepath}` : filepath);\n}\n\nexport function fixDefaultExport<T extends { default: unknown }>(mod: T): T['default'] {\n return mod as T['default'];\n}","// Utils\nexport function printJson(data: unknown, stream: NodeJS.WriteStream = process.stdout): void {\n if (stream.isTTY) { // Pretty print for ttys\n stream.write(JSON.stringify(data, null, 2));\n } else {\n stream.write(JSON.stringify(data));\n }\n}\n","// Utils\nexport function capitalize(txt: string): string {\n return txt.charAt(0).toUpperCase() + txt.substring(1).toLowerCase();\n}\n\nexport function splitCommandLine(line: string): string[] {\n line = line.trim();\n\n const parts: string[] = [];\n let current_cote = '';\n let last = 0;\n\n for (let i = 1; i < line.length; ++i) {\n const c = line[i];\n\n if (current_cote) {\n if (c === current_cote) {\n current_cote = '';\n }\n } else {\n if (['\"', '\\''].includes(c)) {\n current_cote = c;\n } else if (c === ' ') {\n parts.push(line.slice(last, i));\n\n last = i + 1;\n }\n }\n }\n\n parts.push(line.slice(last));\n\n return parts;\n}\n","import { BroadcastChannel, getEnvironmentData, type Serializable, setEnvironmentData } from 'node:worker_threads';\n\nimport { type Awaitable } from '@/src/types.ts';\n\n// Types\ninterface CacheUpdate {\n key: Serializable;\n value: Serializable;\n}\n\nfunction isCacheUpdate(msg: unknown): msg is CacheUpdate {\n return typeof msg === 'object' && msg !== null && 'key' in msg && 'value' in msg;\n}\n\n// Chanel\nconst channel = new BroadcastChannel('jujulego:jill:worker-cache');\nchannel.unref();\n\nchannel.onmessage = (arg) => {\n const msg = arg as MessageEvent;\n\n if (isCacheUpdate(msg.data)) {\n setEnvironmentData(msg.data.key, msg.data.value);\n }\n};\n\n// Utils\nexport async function workerCache<R extends Serializable>(key: Serializable, compute: () => Awaitable<R>): Promise<R> {\n const cache = getEnvironmentData(key) as R | undefined;\n if (cache !== undefined) return cache;\n\n // Compute it\n const result = await compute();\n\n setEnvironmentData(key, result);\n channel.postMessage({ key, value: result });\n\n return result;\n}\n"],"names":["ContextService","constructor","_storage","AsyncLocalStorage","this","_logger","logger","child","label","reset","context","enterWith","_getContext","getStore","warn","_updateContext","update","Object","assign","application","project","workspace","Service","inject","Logger","ThreadTransport","Transport","channel","super","level","BroadcastChannel","onmessageerror","err","emit","unref","log","info","next","postMessage","close","cb","winston","msg","debug","args","$log","verbose","cause","error","options","injectable","container","bind","toDynamicValue","format","combine","timestamp","errors","stack","process","transports","wt","add","Console","consoleFormat","onmessage","entry","data","inSingletonScope","colorize","message","colors","printf","chalk","lines","split","spaces","formatted","repeat","length","i","COMMANDS","arg","path","cwd","strings","result","match","command","slice","SpinnerService","_status","_label","_events","multiplexer$","state","source$","_awakeInk","get","INK_APP","spin","success","failed","stop","on","off","status","AJV","Symbol","Ajv","allErrors","strict","CONFIG_EXPLORER","CONFIG_VALIDATOR","compile","schema","cosmiconfig","loaders","filepath","dynamicImport","then","mod","default","defaultLoaders","noExt","CONFIG","async","configLoader","CONFIG_OPTIONS","explorer","validator","loaded","search","config","jobs","os","errorsText","separator","dataVar","ExitException","base","plugins","map","plugin","JSON","stringify","workerCache","VERBOSITY_LEVEL","applyConfigOptions","parser","option","alias","type","description","coerce","cnt","Math","min","yargs","hideBin","argv","help","version","parse","CURRENT","for","Error","render","Layout","stdout","isTTY","stderr","Container","lazyInject","lazyInjectNamed","fixDefaultExport","getDecorators","JillApplication","createChild","scriptName","completion","wrap","columns","exitProcess","_prepareParser","commands","recommendCommands","fail","CorePlugin","load","getModule","loadPlugins","_loadPlugins","getAllAsync","COMMAND_MODULE","parseAsync","ctx","COMMAND","Promise","resolve","reject","modules","cmd","opts","getCommandOpts","buildCommandModule","handler","TaskCommand","tasks","tsk","prepare","push","catch","PluginLoaderService","toSelf","inTransientScope","whenTargetIsDefault","app","whenTargetNamed","COMMAND_OPTS","target","Reflect","getMetadata","name","aliases","describe","deprecated","builder","middlewares","applyMiddlewares","Command","decorate","defineMetadata","setRegistry","getAsync","InkCommand","children","rerender","waitUntilExit","Middleware","tmp","cls","middleware","MODULE","REGISTRY","getRegistry","registry","assert","module","ContainerModule","setModule","_config","ctn","_importPlugin","addTaskOptions","desc","choices","TaskSet","plan","Array","from","extractPlan","planMode","printJson","id","substring","isCommandCtx","isScriptCtx","group","groupId","dependenciesIds","join","List","items","headers","TaskManagerSpinner","manager","start","waitFor$","TASK_MANAGER","CommandTask","SpawnTask","superCommand","env","FORCE_COLOR","_logStreams","linesFrom","subscribe","line","ScriptTask","GroupTask","script","getScript","commandArgs","splitCommandLine","replace","tasksOf","pm","packageManager","undefined","_runScript","_scriptTasks","results","setStatus","_stop","complexity","cache","Map","reduce","cpl","set","TaskManager","GroupTaskSpinner","setVerbose","useState","setTasks","canReduce","setCanReduce","forceExtended","useMemo","some","isReduced","useLayoutEffect","includes","event","dirty","queueMicrotask","TaskSpinner","task","Box","flexDirection","marginLeft","Fragment","GlobalSpinner","setState","spinner","Text","Spinner","color","symbols","MESSAGE","StaticLogs","write","useStderr","transport","remove","setTimeout","keys","key","marginRight","bold","capitalize","item","idx","taskPredicate","hidden","filter","TaskName","time","setTime","duration","isScriptChild","paddingLeft","flexShrink","ms","stream","inner","completed","current","chunk","toString","pop","once$","code","import","platform","txt","charAt","toUpperCase","toLowerCase","trim","parts","current_cote","last","c","compute","getEnvironmentData","setEnvironmentData","value","isCacheUpdate"],"sourceRoot":""}
@@ -1,2 +0,0 @@
1
- import winston from 'winston';
2
- export declare const consoleFormat: winston.Logform.Format;
@@ -1 +0,0 @@
1
- export declare function $log(strings: TemplateStringsArray, ...args: unknown[]): string;
@@ -1,10 +0,0 @@
1
- /// <reference types="node" resolution-mode="require"/>
2
- import { type LogEntry } from 'winston';
3
- import Transport from 'winston-transport';
4
- import { BroadcastChannel } from 'node:worker_threads';
5
- export declare class ThreadTransport extends Transport {
6
- readonly channel: BroadcastChannel;
7
- constructor(channel: string);
8
- log(info: LogEntry, next: () => void): void;
9
- close(cb?: () => void): void;
10
- }
@@ -1,21 +0,0 @@
1
- import { Logger } from '@/src/commons/logger.service.ts';
2
- export type SpinnerStatus = 'spin' | 'stop' | 'success' | 'failed';
3
- export interface SpinnerState {
4
- status: SpinnerStatus;
5
- label: string;
6
- }
7
- export declare class SpinnerService {
8
- private readonly _logger;
9
- private _status;
10
- private _label;
11
- private _events;
12
- constructor(logger: Logger);
13
- private _awakeInk;
14
- spin(label: string): void;
15
- success(label: string): void;
16
- failed(label: string): void;
17
- stop(): void;
18
- get on(): <const K extends "state">(key: K, listener: import("@jujulego/event-tree").EventListener<Record<"state", SpinnerState>, K>) => import("@jujulego/event-tree").OffFn;
19
- get off(): <const K extends "state">(key: K, listener: import("@jujulego/event-tree").EventListener<Record<"state", SpinnerState>, K>) => void;
20
- get state(): SpinnerState;
21
- }
@@ -1 +0,0 @@
1
- export default function GlobalSpinner(): import("react/jsx-runtime").JSX.Element | null;