@jujulego/jill 2.0.0-beta.2 → 2.0.0-rc.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.
- package/LICENSE +21 -0
- package/README.md +28 -0
- package/dist/commands/each.d.ts +16 -0
- package/dist/commands/each.d.ts.map +1 -0
- package/dist/commands/each.js +117 -0
- package/dist/commands/each.js.map +1 -0
- package/dist/commands/{list.command.d.ts → list.d.ts} +3 -5
- package/dist/commands/list.d.ts.map +1 -0
- package/dist/commands/list.js +170 -0
- package/dist/commands/list.js.map +1 -0
- package/dist/commands/run.d.ts +8 -0
- package/dist/commands/run.d.ts.map +1 -0
- package/dist/commands/run.js +59 -0
- package/dist/commands/run.js.map +1 -0
- package/dist/commands/tree.d.ts +3 -0
- package/dist/commands/tree.d.ts.map +1 -0
- package/dist/commands/tree.js +35 -0
- package/dist/commands/tree.js.map +1 -0
- package/dist/filters/affected.filter.d.ts +11 -0
- package/dist/filters/affected.filter.d.ts.map +1 -0
- package/dist/filters/affected.filter.js +82 -0
- package/dist/filters/affected.filter.js.map +1 -0
- package/dist/filters/index.d.ts +4 -0
- package/dist/filters/index.d.ts.map +1 -0
- package/dist/filters/index.js +21 -0
- package/dist/filters/index.js.map +1 -0
- package/dist/filters/pipeline.d.ts +11 -0
- package/dist/filters/pipeline.d.ts.map +1 -0
- package/dist/filters/pipeline.js +34 -0
- package/dist/filters/pipeline.js.map +1 -0
- package/dist/filters/private.filter.d.ts +7 -0
- package/dist/filters/private.filter.d.ts.map +1 -0
- package/dist/filters/private.filter.js +20 -0
- package/dist/filters/private.filter.js.map +1 -0
- package/dist/filters/scripts.filter.d.ts +7 -0
- package/dist/filters/scripts.filter.d.ts.map +1 -0
- package/dist/filters/scripts.filter.js +21 -0
- package/dist/filters/scripts.filter.js.map +1 -0
- package/dist/git.d.ts +16 -0
- package/dist/git.d.ts.map +1 -0
- package/dist/git.js +94 -0
- package/dist/git.js.map +1 -0
- package/dist/index.d.ts +7 -4
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +19 -33
- package/dist/index.js.map +1 -1
- package/dist/main.d.ts.map +1 -1
- package/dist/main.js +26 -62
- package/dist/main.js.map +1 -1
- package/dist/middlewares/global-config.d.ts +5 -0
- package/dist/middlewares/global-config.d.ts.map +1 -0
- package/dist/middlewares/global-config.js +29 -0
- package/dist/middlewares/global-config.js.map +1 -0
- package/dist/middlewares/index.d.ts +4 -0
- package/dist/middlewares/index.d.ts.map +1 -0
- package/dist/middlewares/index.js +21 -0
- package/dist/middlewares/index.js.map +1 -0
- package/dist/middlewares/load-project.d.ts +6 -0
- package/dist/middlewares/load-project.d.ts.map +1 -0
- package/dist/middlewares/load-project.js +41 -0
- package/dist/middlewares/load-project.js.map +1 -0
- package/dist/middlewares/load-workspace.d.ts +3 -0
- package/dist/middlewares/load-workspace.d.ts.map +1 -0
- package/dist/middlewares/load-workspace.js +42 -0
- package/dist/middlewares/load-workspace.js.map +1 -0
- package/dist/middlewares/setup-ink.d.ts +1 -0
- package/dist/middlewares/setup-ink.d.ts.map +1 -0
- package/dist/middlewares/setup-ink.js +22 -0
- package/dist/middlewares/setup-ink.js.map +1 -0
- package/dist/project/index.d.ts +2 -0
- package/dist/project/index.d.ts.map +1 -0
- package/dist/project/index.js +19 -0
- package/dist/project/index.js.map +1 -0
- package/dist/project/project.d.ts +25 -0
- package/dist/project/project.d.ts.map +1 -0
- package/dist/project/project.js +190 -0
- package/dist/project/project.js.map +1 -0
- package/dist/project/workspace.d.ts +34 -0
- package/dist/project/workspace.d.ts.map +1 -0
- package/dist/project/workspace.js +173 -0
- package/dist/project/workspace.js.map +1 -0
- package/dist/services/index.d.ts +4 -0
- package/dist/services/index.d.ts.map +1 -0
- package/dist/services/index.js +21 -0
- package/dist/services/index.js.map +1 -0
- package/dist/services/inversify.config.d.ts +11 -0
- package/dist/services/inversify.config.d.ts.map +1 -0
- package/dist/services/inversify.config.js +34 -0
- package/dist/services/inversify.config.js.map +1 -0
- package/dist/services/logger.service.d.ts +6 -0
- package/dist/services/logger.service.d.ts.map +1 -0
- package/dist/services/logger.service.js +75 -0
- package/dist/services/logger.service.js.map +1 -0
- package/dist/services/spinner.service.d.ts +18 -0
- package/dist/services/spinner.service.d.ts.map +1 -0
- package/dist/services/spinner.service.js +68 -0
- package/dist/services/spinner.service.js.map +1 -0
- package/dist/services/task-manager.service.d.ts +1 -0
- package/dist/services/task-manager.service.d.ts.map +1 -0
- package/dist/services/task-manager.service.js +18 -0
- package/dist/services/task-manager.service.js.map +1 -0
- package/dist/types.d.ts +1 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +7 -0
- package/dist/types.js.map +1 -0
- package/dist/ui/global-spinner.d.ts +2 -0
- package/dist/ui/global-spinner.d.ts.map +1 -0
- package/dist/ui/global-spinner.js +65 -0
- package/dist/ui/global-spinner.js.map +1 -0
- package/dist/ui/index.d.ts +7 -0
- package/dist/ui/index.d.ts.map +1 -0
- package/dist/ui/index.js +24 -0
- package/dist/ui/index.js.map +1 -0
- package/dist/ui/layout.d.ts +2 -0
- package/dist/ui/layout.d.ts.map +1 -0
- package/dist/ui/layout.js +20 -0
- package/dist/ui/layout.js.map +1 -0
- package/dist/ui/list.d.ts +6 -0
- package/dist/ui/list.d.ts.map +1 -0
- package/dist/ui/list.js +30 -0
- package/dist/ui/list.js.map +1 -0
- package/dist/{components/StaticLogs.d.ts → ui/static-logs.d.ts} +0 -0
- package/dist/ui/static-logs.d.ts.map +1 -0
- package/dist/ui/static-logs.js +63 -0
- package/dist/ui/static-logs.js.map +1 -0
- package/dist/ui/task-name.d.ts +6 -0
- package/dist/ui/task-name.d.ts.map +1 -0
- package/dist/ui/task-name.js +35 -0
- package/dist/ui/task-name.js.map +1 -0
- package/dist/ui/task-spinner.d.ts +6 -0
- package/dist/ui/task-spinner.d.ts.map +1 -0
- package/dist/ui/task-spinner.js +143 -0
- package/dist/ui/task-spinner.js.map +1 -0
- package/dist/ui/tasks-spinner.d.ts +6 -0
- package/dist/ui/tasks-spinner.d.ts.map +1 -0
- package/dist/ui/tasks-spinner.js +17 -0
- package/dist/ui/tasks-spinner.js.map +1 -0
- package/dist/{components/WorkspaceTree.d.ts → ui/workspace-tree.d.ts} +1 -1
- package/dist/ui/workspace-tree.d.ts.map +1 -0
- package/dist/ui/workspace-tree.js +87 -0
- package/dist/ui/workspace-tree.js.map +1 -0
- package/dist/utils.d.ts +13 -0
- package/dist/utils.d.ts.map +1 -0
- package/dist/utils.js +72 -0
- package/dist/utils.js.map +1 -0
- package/package.json +55 -56
- package/dist/application.context.d.ts +0 -28
- package/dist/application.context.d.ts.map +0 -1
- package/dist/application.context.js +0 -30
- package/dist/application.context.js.map +0 -1
- package/dist/application.d.ts +0 -7
- package/dist/application.d.ts.map +0 -1
- package/dist/application.js +0 -125
- package/dist/application.js.map +0 -1
- package/dist/command.d.ts +0 -8
- package/dist/command.d.ts.map +0 -1
- package/dist/command.js +0 -24
- package/dist/command.js.map +0 -1
- package/dist/commands/each.command.d.ts +0 -18
- package/dist/commands/each.command.d.ts.map +0 -1
- package/dist/commands/each.command.js +0 -176
- package/dist/commands/each.command.js.map +0 -1
- package/dist/commands/list.command.d.ts.map +0 -1
- package/dist/commands/list.command.js +0 -252
- package/dist/commands/list.command.js.map +0 -1
- package/dist/commands/run.command.d.ts +0 -12
- package/dist/commands/run.command.d.ts.map +0 -1
- package/dist/commands/run.command.js +0 -94
- package/dist/commands/run.command.js.map +0 -1
- package/dist/commands/tree.command.d.ts +0 -7
- package/dist/commands/tree.command.d.ts.map +0 -1
- package/dist/commands/tree.command.js +0 -35
- package/dist/commands/tree.command.js.map +0 -1
- package/dist/components/StaticLogs.d.ts.map +0 -1
- package/dist/components/StaticLogs.js +0 -77
- package/dist/components/StaticLogs.js.map +0 -1
- package/dist/components/WorkspaceTree.d.ts.map +0 -1
- package/dist/components/WorkspaceTree.js +0 -151
- package/dist/components/WorkspaceTree.js.map +0 -1
- package/dist/wrapper.d.ts +0 -6
- package/dist/wrapper.d.ts.map +0 -1
- package/dist/wrapper.js +0 -30
- package/dist/wrapper.js.map +0 -1
- package/dist/wrappers/project.wrapper.d.ts +0 -7
- package/dist/wrappers/project.wrapper.d.ts.map +0 -1
- package/dist/wrappers/project.wrapper.js +0 -105
- package/dist/wrappers/project.wrapper.js.map +0 -1
- package/dist/wrappers/workspace.wrapper.d.ts +0 -5
- package/dist/wrappers/workspace.wrapper.d.ts.map +0 -1
- package/dist/wrappers/workspace.wrapper.js +0 -108
- package/dist/wrappers/workspace.wrapper.js.map +0 -1
|
@@ -0,0 +1,173 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
Object.defineProperty(exports, "Workspace", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: ()=>Workspace
|
|
8
|
+
});
|
|
9
|
+
const _tasks = require("@jujulego/tasks");
|
|
10
|
+
const _nodePath = /*#__PURE__*/ _interopRequireDefault(require("node:path"));
|
|
11
|
+
const _semver = require("semver");
|
|
12
|
+
const _git = require("../git");
|
|
13
|
+
const _services = require("../services");
|
|
14
|
+
const _utils = require("../utils");
|
|
15
|
+
function _interopRequireDefault(obj) {
|
|
16
|
+
return obj && obj.__esModule ? obj : {
|
|
17
|
+
default: obj
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
class Workspace {
|
|
21
|
+
// Constructor
|
|
22
|
+
constructor(_cwd, manifest, project){
|
|
23
|
+
this._cwd = _cwd;
|
|
24
|
+
this.manifest = manifest;
|
|
25
|
+
this.project = project;
|
|
26
|
+
this._affectedCache = new Map();
|
|
27
|
+
this._tasks = new Map();
|
|
28
|
+
const logger = _services.container.get(_services.Logger);
|
|
29
|
+
this._logger = logger.child({
|
|
30
|
+
label: this.manifest.name
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
// Methods
|
|
34
|
+
_satisfies(from, range) {
|
|
35
|
+
if (range.startsWith('file:')) {
|
|
36
|
+
return _nodePath.default.resolve(from.cwd, range.substring(5)) === this.cwd;
|
|
37
|
+
}
|
|
38
|
+
if (range.startsWith('workspace:')) {
|
|
39
|
+
range = range.substring(10);
|
|
40
|
+
}
|
|
41
|
+
return !this.version || (0, _semver.satisfies)(this.version, range);
|
|
42
|
+
}
|
|
43
|
+
async _buildDependencies(task, deps = 'all') {
|
|
44
|
+
// Generators
|
|
45
|
+
const generators = [];
|
|
46
|
+
switch(deps){
|
|
47
|
+
case 'all':
|
|
48
|
+
generators.unshift(this.devDependencies());
|
|
49
|
+
// eslint-disable-next no-fallthrough
|
|
50
|
+
case 'prod':
|
|
51
|
+
generators.unshift(this.dependencies());
|
|
52
|
+
}
|
|
53
|
+
// Build deps
|
|
54
|
+
for await (const dep of (0, _utils.combine)(...generators)){
|
|
55
|
+
const build = await dep.build();
|
|
56
|
+
if (build) {
|
|
57
|
+
task.dependsOn(build);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
async _isAffected(reference) {
|
|
62
|
+
const isAffected = await _git.Git.isAffected(reference, [
|
|
63
|
+
'--',
|
|
64
|
+
this.cwd
|
|
65
|
+
], {
|
|
66
|
+
cwd: this.project.root,
|
|
67
|
+
logger: this._logger
|
|
68
|
+
});
|
|
69
|
+
if (isAffected) {
|
|
70
|
+
return true;
|
|
71
|
+
}
|
|
72
|
+
// Test dependencies
|
|
73
|
+
const proms = [];
|
|
74
|
+
for await (const dep of (0, _utils.combine)(this.dependencies(), this.devDependencies())){
|
|
75
|
+
proms.push(dep.isAffected(reference));
|
|
76
|
+
}
|
|
77
|
+
const results = await Promise.all(proms);
|
|
78
|
+
return results.some((r)=>r);
|
|
79
|
+
}
|
|
80
|
+
async isAffected(reference) {
|
|
81
|
+
let isAffected = this._affectedCache.get(reference);
|
|
82
|
+
if (!isAffected) {
|
|
83
|
+
isAffected = this._isAffected(reference);
|
|
84
|
+
this._affectedCache.set(reference, isAffected);
|
|
85
|
+
}
|
|
86
|
+
return await isAffected;
|
|
87
|
+
}
|
|
88
|
+
async *_loadDependencies(dependencies, kind) {
|
|
89
|
+
for (const [dep, range] of Object.entries(dependencies)){
|
|
90
|
+
const ws = await this.project.workspace(dep);
|
|
91
|
+
if (ws) {
|
|
92
|
+
if (ws._satisfies(this, range)) {
|
|
93
|
+
yield ws;
|
|
94
|
+
} else {
|
|
95
|
+
this._logger.verbose(`Ignoring ${kind} ${ws.reference} as it does not match requirement ${range}`);
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
async *dependencies() {
|
|
101
|
+
if (!this.manifest.dependencies) return;
|
|
102
|
+
for await (const ws of this._loadDependencies(this.manifest.dependencies, 'dependency')){
|
|
103
|
+
yield ws;
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
async *devDependencies() {
|
|
107
|
+
if (!this.manifest.devDependencies) return;
|
|
108
|
+
for await (const ws of this._loadDependencies(this.manifest.devDependencies, 'devDependency')){
|
|
109
|
+
yield ws;
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
async _streamLogs(task, stream, level) {
|
|
113
|
+
try {
|
|
114
|
+
for await (const line of (0, _utils.streamLines)(task, stream)){
|
|
115
|
+
this._logger.log(level, line);
|
|
116
|
+
}
|
|
117
|
+
} catch (err) {
|
|
118
|
+
if (err) {
|
|
119
|
+
this._logger.warn(`Error while streaming task ${stream}`, err);
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
async run(script, args = [], opts = {}) {
|
|
124
|
+
let task = this._tasks.get(script);
|
|
125
|
+
if (!task) {
|
|
126
|
+
const pm = await this.project.packageManager();
|
|
127
|
+
task = new _tasks.SpawnTask(pm, [
|
|
128
|
+
'run',
|
|
129
|
+
script,
|
|
130
|
+
...args
|
|
131
|
+
], {
|
|
132
|
+
workspace: this,
|
|
133
|
+
script
|
|
134
|
+
}, {
|
|
135
|
+
...opts,
|
|
136
|
+
cwd: this.cwd,
|
|
137
|
+
logger: this._logger,
|
|
138
|
+
env: {
|
|
139
|
+
FORCE_COLOR: '1',
|
|
140
|
+
...opts.env
|
|
141
|
+
}
|
|
142
|
+
});
|
|
143
|
+
this._streamLogs(task, 'stdout', 'info');
|
|
144
|
+
this._streamLogs(task, 'stderr', 'info');
|
|
145
|
+
await this._buildDependencies(task, opts.buildDeps);
|
|
146
|
+
this._tasks.set(script, task);
|
|
147
|
+
}
|
|
148
|
+
return task;
|
|
149
|
+
}
|
|
150
|
+
async build(opts) {
|
|
151
|
+
const { scripts ={} } = this.manifest;
|
|
152
|
+
if (!scripts.build) {
|
|
153
|
+
this._logger.warn('Will not be built (no build script)');
|
|
154
|
+
return null;
|
|
155
|
+
}
|
|
156
|
+
return await this.run('build', [], opts);
|
|
157
|
+
}
|
|
158
|
+
// Properties
|
|
159
|
+
get name() {
|
|
160
|
+
return this.manifest.name;
|
|
161
|
+
}
|
|
162
|
+
get version() {
|
|
163
|
+
return this.manifest.version;
|
|
164
|
+
}
|
|
165
|
+
get reference() {
|
|
166
|
+
return this.version ? `${this.name}@${this.version}` : this.name;
|
|
167
|
+
}
|
|
168
|
+
get cwd() {
|
|
169
|
+
return _nodePath.default.resolve(this.project.root, this._cwd);
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
|
|
173
|
+
//# sourceMappingURL=workspace.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["project/workspace.js"],"sourcesContent":["import { SpawnTask, SpawnTaskOptions, SpawnTaskStream, TaskContext } from '@jujulego/tasks';\nimport path from 'node:path';\nimport { Package } from 'normalize-package-data';\nimport { satisfies } from 'semver';\nimport winston from 'winston';\n\nimport { Git } from '../git';\nimport { container, Logger } from '../services';\nimport { combine, streamLines } from '../utils';\nimport { Project } from './project';\n\n// Types\nexport type WorkspaceDepsMode = 'all' | 'prod' | 'none';\n\nexport interface WorkspaceContext extends TaskContext {\n workspace: Workspace;\n script: string;\n}\n\nexport interface WorkspaceRunOptions extends Omit<SpawnTaskOptions, 'cwd'> {\n buildDeps?: WorkspaceDepsMode;\n}\n\n// Class\nexport class Workspace {\n // Attributes\n private readonly _logger: winston.Logger;\n private readonly _affectedCache = new Map<string, Promise<boolean>>();\n private readonly _tasks = new Map<string, SpawnTask<WorkspaceContext>>();\n\n // Constructor\n constructor(\n private readonly _cwd: string,\n readonly manifest: Package,\n readonly project: Project\n ) {\n const logger = container.get(Logger);\n this._logger = logger.child({ label: this.manifest.name });\n }\n\n // Methods\n private _satisfies(from: Workspace, range: string): boolean {\n if (range.startsWith('file:')) {\n return path.resolve(from.cwd, range.substring(5)) === this.cwd;\n }\n\n if (range.startsWith('workspace:')) {\n range = range.substring(10);\n }\n\n return !this.version || satisfies(this.version, range);\n }\n\n private async _buildDependencies(task: SpawnTask, deps: WorkspaceDepsMode = 'all') {\n // Generators\n const generators: AsyncGenerator<Workspace, void>[] = [];\n\n switch (deps) {\n case 'all':\n generators.unshift(this.devDependencies());\n\n // eslint-disable-next no-fallthrough\n case 'prod':\n generators.unshift(this.dependencies());\n }\n\n // Build deps\n for await (const dep of combine(...generators)) {\n const build = await dep.build();\n\n if (build) {\n task.dependsOn(build);\n }\n }\n }\n\n private async _isAffected(reference: string): Promise<boolean> {\n const isAffected = await Git.isAffected(reference, ['--', this.cwd], {\n cwd: this.project.root,\n logger: this._logger,\n });\n\n if (isAffected) {\n return true;\n }\n\n // Test dependencies\n const proms: Promise<boolean>[] = [];\n\n for await (const dep of combine(this.dependencies(), this.devDependencies())) {\n proms.push(dep.isAffected(reference));\n }\n\n const results = await Promise.all(proms);\n return results.some(r => r);\n }\n\n async isAffected(reference: string): Promise<boolean> {\n let isAffected = this._affectedCache.get(reference);\n\n if (!isAffected) {\n isAffected = this._isAffected(reference);\n this._affectedCache.set(reference, isAffected);\n }\n\n return await isAffected;\n }\n\n private async* _loadDependencies(dependencies: Record<string, string>, kind: string): AsyncGenerator<Workspace, void> {\n for (const [dep, range] of Object.entries(dependencies)) {\n const ws = await this.project.workspace(dep);\n\n if (ws) {\n if (ws._satisfies(this, range)) {\n yield ws;\n } else {\n this._logger.verbose(`Ignoring ${kind} ${ws.reference} as it does not match requirement ${range}`);\n }\n }\n }\n }\n\n async* dependencies(): AsyncGenerator<Workspace, void> {\n if (!this.manifest.dependencies) return;\n\n for await (const ws of this._loadDependencies(this.manifest.dependencies, 'dependency')) {\n yield ws;\n }\n }\n\n async* devDependencies(): AsyncGenerator<Workspace, void> {\n if (!this.manifest.devDependencies) return;\n\n for await (const ws of this._loadDependencies(this.manifest.devDependencies, 'devDependency')) {\n yield ws;\n }\n }\n\n private async _streamLogs(task: SpawnTask<WorkspaceContext>, stream: SpawnTaskStream, level: string) {\n try {\n for await (const line of streamLines(task, stream)) {\n this._logger.log(level, line);\n }\n } catch (err) {\n if (err) {\n this._logger.warn(`Error while streaming task ${stream}`, err);\n }\n }\n }\n\n async run(script: string, args: string[] = [], opts: WorkspaceRunOptions = {}): Promise<SpawnTask<WorkspaceContext>> {\n let task = this._tasks.get(script);\n\n if (!task) {\n const pm = await this.project.packageManager();\n\n task = new SpawnTask(pm, ['run', script, ...args], { workspace: this, script }, {\n ...opts,\n cwd: this.cwd,\n logger: this._logger,\n env: {\n FORCE_COLOR: '1',\n ...opts.env\n }\n });\n\n this._streamLogs(task, 'stdout', 'info');\n this._streamLogs(task, 'stderr', 'info');\n\n await this._buildDependencies(task, opts.buildDeps);\n\n this._tasks.set(script, task);\n }\n\n return task;\n }\n\n async build(opts?: WorkspaceRunOptions): Promise<SpawnTask | null> {\n const { scripts = {} } = this.manifest;\n\n if (!scripts.build) {\n this._logger.warn('Will not be built (no build script)');\n return null;\n }\n\n return await this.run('build', [], opts);\n }\n\n // Properties\n get name(): string {\n return this.manifest.name;\n }\n\n get version(): string {\n return this.manifest.version;\n }\n\n get reference(): string {\n return this.version ? `${this.name}@${this.version}` : this.name;\n }\n\n get cwd(): string {\n return path.resolve(this.project.root, this._cwd);\n }\n}\n"],"names":["Workspace","constructor","_cwd","manifest","project","_affectedCache","Map","_tasks","logger","container","get","Logger","_logger","child","label","name","_satisfies","from","range","startsWith","path","resolve","cwd","substring","version","satisfies","_buildDependencies","task","deps","generators","unshift","devDependencies","dependencies","dep","combine","build","dependsOn","_isAffected","reference","isAffected","Git","root","proms","push","results","Promise","all","some","r","set","_loadDependencies","kind","Object","entries","ws","workspace","verbose","_streamLogs","stream","level","line","streamLines","log","err","warn","run","script","args","opts","pm","packageManager","SpawnTask","env","FORCE_COLOR","buildDeps","scripts"],"mappings":"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","file":"workspace.js"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["services/index.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAC;AACnC,cAAc,kBAAkB,CAAC;AACjC,cAAc,mBAAmB,CAAC;AAClC,cAAc,wBAAwB,CAAC","file":"index.d.ts","sourcesContent":["export * from './inversify.config';\nexport * from './logger.service';\nexport * from './spinner.service';\nexport * from './task-manager.service';\n"]}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
_exportStar(require("./inversify.config"), exports);
|
|
6
|
+
_exportStar(require("./logger.service"), exports);
|
|
7
|
+
_exportStar(require("./spinner.service"), exports);
|
|
8
|
+
_exportStar(require("./task-manager.service"), exports);
|
|
9
|
+
function _exportStar(from, to) {
|
|
10
|
+
Object.keys(from).forEach(function(k) {
|
|
11
|
+
if (k !== "default" && !Object.prototype.hasOwnProperty.call(to, k)) Object.defineProperty(to, k, {
|
|
12
|
+
enumerable: true,
|
|
13
|
+
get: function() {
|
|
14
|
+
return from[k];
|
|
15
|
+
}
|
|
16
|
+
});
|
|
17
|
+
});
|
|
18
|
+
return from;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["services/index.js"],"sourcesContent":["export * from './inversify.config';\nexport * from './logger.service';\nexport * from './spinner.service';\nexport * from './task-manager.service';\n"],"names":[],"mappings":"AAAA;;;;oBAAc;oBACA;oBACA;oBACA","file":"index.js"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { Container } from 'inversify';
|
|
2
|
+
import 'reflect-metadata';
|
|
3
|
+
export declare const INK_APP: unique symbol;
|
|
4
|
+
export declare const GLOBAL_CONFIG: unique symbol;
|
|
5
|
+
export declare const CURRENT: unique symbol;
|
|
6
|
+
export interface GlobalConfig {
|
|
7
|
+
jobs?: number;
|
|
8
|
+
verbose: number;
|
|
9
|
+
}
|
|
10
|
+
export declare const container: Container;
|
|
11
|
+
export declare const lazyInject: (serviceIdentifier: string | symbol | import("inversify/lib/interfaces/interfaces").interfaces.Newable<any> | import("inversify/lib/interfaces/interfaces").interfaces.Abstract<any>) => (proto: any, key: string) => void;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["services/inversify.config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AAGtC,OAAO,kBAAkB,CAAC;AAG1B,eAAO,MAAM,OAAO,eAAuB,CAAC;AAC5C,eAAO,MAAM,aAAa,eAA6B,CAAC;AACxD,eAAO,MAAM,OAAO,eAAwB,CAAC;AAG7C,MAAM,WAAW,YAAY;IAC3B,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,CAAC;CACjB;AAGD,eAAO,MAAM,SAAS,WAEpB,CAAC;AAGH,eAAO,MAAQ,UAAU,4NAA6B,CAAC","file":"inversify.config.d.ts","sourcesContent":["import { Container } from 'inversify';\nimport getDecorators from 'inversify-inject-decorators';\n\nimport 'reflect-metadata';\n\n// Constants\nexport const INK_APP = Symbol.for('InkApp');\nexport const GLOBAL_CONFIG = Symbol.for('GlobalConfig');\nexport const CURRENT = Symbol.for('Current');\n\n// Types\nexport interface GlobalConfig {\n jobs?: number;\n verbose: number;\n}\n\n// Container\nexport const container = new Container({\n skipBaseClassChecks: true,\n});\n\n// Utilities\nexport const { lazyInject } = getDecorators(container);\n"]}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
function _export(target, all) {
|
|
6
|
+
for(var name in all)Object.defineProperty(target, name, {
|
|
7
|
+
enumerable: true,
|
|
8
|
+
get: all[name]
|
|
9
|
+
});
|
|
10
|
+
}
|
|
11
|
+
_export(exports, {
|
|
12
|
+
INK_APP: ()=>INK_APP,
|
|
13
|
+
GLOBAL_CONFIG: ()=>GLOBAL_CONFIG,
|
|
14
|
+
CURRENT: ()=>CURRENT,
|
|
15
|
+
container: ()=>container,
|
|
16
|
+
lazyInject: ()=>lazyInject
|
|
17
|
+
});
|
|
18
|
+
const _inversify = require("inversify");
|
|
19
|
+
const _inversifyInjectDecorators = /*#__PURE__*/ _interopRequireDefault(require("inversify-inject-decorators"));
|
|
20
|
+
require("reflect-metadata");
|
|
21
|
+
function _interopRequireDefault(obj) {
|
|
22
|
+
return obj && obj.__esModule ? obj : {
|
|
23
|
+
default: obj
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
const INK_APP = Symbol.for('InkApp');
|
|
27
|
+
const GLOBAL_CONFIG = Symbol.for('GlobalConfig');
|
|
28
|
+
const CURRENT = Symbol.for('Current');
|
|
29
|
+
const container = new _inversify.Container({
|
|
30
|
+
skipBaseClassChecks: true
|
|
31
|
+
});
|
|
32
|
+
const { lazyInject } = (0, _inversifyInjectDecorators.default)(container);
|
|
33
|
+
|
|
34
|
+
//# sourceMappingURL=inversify.config.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["services/inversify.config.js"],"sourcesContent":["import { Container } from 'inversify';\nimport getDecorators from 'inversify-inject-decorators';\n\nimport 'reflect-metadata';\n\n// Constants\nexport const INK_APP = Symbol.for('InkApp');\nexport const GLOBAL_CONFIG = Symbol.for('GlobalConfig');\nexport const CURRENT = Symbol.for('Current');\n\n// Types\nexport interface GlobalConfig {\n jobs?: number;\n verbose: number;\n}\n\n// Container\nexport const container = new Container({\n skipBaseClassChecks: true,\n});\n\n// Utilities\nexport const { lazyInject } = getDecorators(container);\n"],"names":["INK_APP","GLOBAL_CONFIG","CURRENT","container","lazyInject","Symbol","for","Container","skipBaseClassChecks","getDecorators"],"mappings":"AAAA;;;;;;;;;;;IAMaA,OAAO,MAAPA;IACAC,aAAa,MAAbA;IACAC,OAAO,MAAPA;IASAC,SAAS,MAATA;IAKEC,UAAU,MAAVA;;2BAtBW;gFACA;QAEnB;;;;;;AAGA,MAAMJ,UAAUK,OAAOC,GAAG,CAAC;AAC3B,MAAML,gBAAgBI,OAAOC,GAAG,CAAC;AACjC,MAAMJ,UAAUG,OAAOC,GAAG,CAAC;AAS3B,MAAMH,YAAY,IAAII,oBAAS,CAAC;IACrCC,qBAAqB,IAAI;AAC3B;AAGO,MAAM,EAAEJ,WAAU,EAAE,GAAGK,IAAAA,kCAAa,EAACN","file":"inversify.config.js"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["services/logger.service.ts"],"names":[],"mappings":"AAEA,OAAO,OAAO,MAAM,SAAS,CAAC;AAW9B,eAAO,MAAM,aAAa,wBAwBzB,CAAC;AAGF,qBACa,MAAM;CAAG;AAGtB,MAAM,WAAW,MAAO,SAAQ,OAAO,CAAC,MAAM;CAAG","file":"logger.service.d.ts","sourcesContent":["import chalk from 'chalk';\nimport { injectable } from 'inversify';\nimport winston from 'winston';\n\nimport { type GlobalConfig, GLOBAL_CONFIG, container } from './inversify.config';\n\n// Constants\nconst VERBOSITY_LEVEL: Record<number, string> = {\n 1: 'verbose',\n 2: 'debug',\n};\n\n// Utils\nexport const consoleFormat = winston.format.combine(\n winston.format.errors(),\n winston.format.colorize({\n message: true,\n colors: { debug: 'grey', verbose: 'blue', info: 'white', error: 'red' }\n }),\n winston.format.printf(({ label, message }) => {\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\n// Service\n@injectable()\nexport class Logger {}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-interface\nexport interface Logger extends winston.Logger {}\n\ncontainer.bind(Logger)\n .toDynamicValue((context) => {\n const config = context.container.get<GlobalConfig>(GLOBAL_CONFIG);\n\n return winston.createLogger({\n level: VERBOSITY_LEVEL[Math.min(config.verbose, 2)],\n format: winston.format.combine(\n winston.format.timestamp(),\n ),\n transports: [\n new winston.transports.Console({\n format: consoleFormat\n })\n ]\n });\n })\n .inSingletonScope();\n"]}
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
function _export(target, all) {
|
|
6
|
+
for(var name in all)Object.defineProperty(target, name, {
|
|
7
|
+
enumerable: true,
|
|
8
|
+
get: all[name]
|
|
9
|
+
});
|
|
10
|
+
}
|
|
11
|
+
_export(exports, {
|
|
12
|
+
consoleFormat: ()=>consoleFormat,
|
|
13
|
+
Logger: ()=>Logger
|
|
14
|
+
});
|
|
15
|
+
const _chalk = /*#__PURE__*/ _interopRequireDefault(require("chalk"));
|
|
16
|
+
const _inversify = require("inversify");
|
|
17
|
+
const _winston = /*#__PURE__*/ _interopRequireDefault(require("winston"));
|
|
18
|
+
const _inversifyConfig = require("./inversify.config");
|
|
19
|
+
function _interopRequireDefault(obj) {
|
|
20
|
+
return obj && obj.__esModule ? obj : {
|
|
21
|
+
default: obj
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
var __decorate = (void 0) && (void 0).__decorate || function(decorators, target, key, desc) {
|
|
25
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
26
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
27
|
+
else for(var i = decorators.length - 1; i >= 0; i--)if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
28
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
29
|
+
};
|
|
30
|
+
// Constants
|
|
31
|
+
const VERBOSITY_LEVEL = {
|
|
32
|
+
1: 'verbose',
|
|
33
|
+
2: 'debug'
|
|
34
|
+
};
|
|
35
|
+
const consoleFormat = _winston.default.format.combine(_winston.default.format.errors(), _winston.default.format.colorize({
|
|
36
|
+
message: true,
|
|
37
|
+
colors: {
|
|
38
|
+
debug: 'grey',
|
|
39
|
+
verbose: 'blue',
|
|
40
|
+
info: 'white',
|
|
41
|
+
error: 'red'
|
|
42
|
+
}
|
|
43
|
+
}), _winston.default.format.printf(({ label , message })=>{
|
|
44
|
+
const lines = message.split('\n');
|
|
45
|
+
// Format
|
|
46
|
+
let spaces = '';
|
|
47
|
+
let formatted = lines[0];
|
|
48
|
+
if (label) {
|
|
49
|
+
spaces = ' '.repeat(label.length + 3);
|
|
50
|
+
formatted = `${_chalk.default.grey(`[${label}]`)} ${lines[0]}`;
|
|
51
|
+
}
|
|
52
|
+
for(let i = 1; i < lines.length; ++i){
|
|
53
|
+
formatted += `\n${spaces}${lines[i]}`;
|
|
54
|
+
}
|
|
55
|
+
return formatted;
|
|
56
|
+
}));
|
|
57
|
+
let Logger = class Logger {
|
|
58
|
+
};
|
|
59
|
+
Logger = __decorate([
|
|
60
|
+
(0, _inversify.injectable)()
|
|
61
|
+
], Logger);
|
|
62
|
+
_inversifyConfig.container.bind(Logger).toDynamicValue((context)=>{
|
|
63
|
+
const config = context.container.get(_inversifyConfig.GLOBAL_CONFIG);
|
|
64
|
+
return _winston.default.createLogger({
|
|
65
|
+
level: VERBOSITY_LEVEL[Math.min(config.verbose, 2)],
|
|
66
|
+
format: _winston.default.format.combine(_winston.default.format.timestamp()),
|
|
67
|
+
transports: [
|
|
68
|
+
new _winston.default.transports.Console({
|
|
69
|
+
format: consoleFormat
|
|
70
|
+
})
|
|
71
|
+
]
|
|
72
|
+
});
|
|
73
|
+
}).inSingletonScope();
|
|
74
|
+
|
|
75
|
+
//# sourceMappingURL=logger.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["services/logger.service.js"],"sourcesContent":["import chalk from 'chalk';\nimport { injectable } from 'inversify';\nimport winston from 'winston';\n\nimport { type GlobalConfig, GLOBAL_CONFIG, container } from './inversify.config';\n\n// Constants\nconst VERBOSITY_LEVEL: Record<number, string> = {\n 1: 'verbose',\n 2: 'debug',\n};\n\n// Utils\nexport const consoleFormat = winston.format.combine(\n winston.format.errors(),\n winston.format.colorize({\n message: true,\n colors: { debug: 'grey', verbose: 'blue', info: 'white', error: 'red' }\n }),\n winston.format.printf(({ label, message }) => {\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\n// Service\n@injectable()\nexport class Logger {}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-interface\nexport interface Logger extends winston.Logger {}\n\ncontainer.bind(Logger)\n .toDynamicValue((context) => {\n const config = context.container.get<GlobalConfig>(GLOBAL_CONFIG);\n\n return winston.createLogger({\n level: VERBOSITY_LEVEL[Math.min(config.verbose, 2)],\n format: winston.format.combine(\n winston.format.timestamp(),\n ),\n transports: [\n new winston.transports.Console({\n format: consoleFormat\n })\n ]\n });\n })\n .inSingletonScope();\n"],"names":["consoleFormat","Logger","VERBOSITY_LEVEL","winston","format","combine","errors","colorize","message","colors","debug","verbose","info","error","printf","label","lines","split","spaces","formatted","repeat","length","chalk","grey","i","injectable","container","bind","toDynamicValue","context","config","get","GLOBAL_CONFIG","createLogger","level","Math","min","timestamp","transports","Console","inSingletonScope"],"mappings":"AAAA;;;;;;;;;;;IAaaA,aAAa,MAAbA;IA4BAC,MAAM,MAANA;;4DAzCK;2BACS;8DACP;iCAEwC;;;;;;;;;;;;AAE5D,YAAY;AACZ,MAAMC,kBAA0C;IAC9C,GAAG;IACH,GAAG;AACL;AAGO,MAAMF,gBAAgBG,gBAAO,CAACC,MAAM,CAACC,OAAO,CACjDF,gBAAO,CAACC,MAAM,CAACE,MAAM,IACrBH,gBAAO,CAACC,MAAM,CAACG,QAAQ,CAAC;IACtBC,SAAS,IAAI;IACbC,QAAQ;QAAEC,OAAO;QAAQC,SAAS;QAAQC,MAAM;QAASC,OAAO;IAAM;AACxE,IACAV,gBAAO,CAACC,MAAM,CAACU,MAAM,CAAC,CAAC,EAAEC,MAAK,EAAEP,QAAO,EAAE,GAAK;IAC5C,MAAMQ,QAAQR,QAAQS,KAAK,CAAC;IAE5B,SAAS;IACT,IAAIC,SAAS;IACb,IAAIC,YAAYH,KAAK,CAAC,EAAE;IAExB,IAAID,OAAO;QACTG,SAAS,IAAIE,MAAM,CAACL,MAAMM,MAAM,GAAG;QACnCF,YAAY,CAAC,EAAEG,cAAK,CAACC,IAAI,CAAC,CAAC,CAAC,EAAER,MAAM,CAAC,CAAC,EAAE,CAAC,EAAEC,KAAK,CAAC,EAAE,CAAC,CAAC;IACvD,CAAC;IAED,IAAK,IAAIQ,IAAI,GAAGA,IAAIR,MAAMK,MAAM,EAAE,EAAEG,EAAG;QACrCL,aAAa,CAAC,EAAE,EAAED,OAAO,EAAEF,KAAK,CAACQ,EAAE,CAAC,CAAC;IACvC;IAEA,OAAOL;AACT;IAKWlB,SAAN;AAAc;AAARA;IADZwB,IAAAA,qBAAU;GACExB;AAKbyB,0BAAS,CAACC,IAAI,CAAC1B,QACZ2B,cAAc,CAAC,CAACC,UAAY;IAC3B,MAAMC,SAASD,QAAQH,SAAS,CAACK,GAAG,CAAeC,8BAAa;IAEhE,OAAO7B,gBAAO,CAAC8B,YAAY,CAAC;QAC1BC,OAAOhC,eAAe,CAACiC,KAAKC,GAAG,CAACN,OAAOnB,OAAO,EAAE,GAAG;QACnDP,QAAQD,gBAAO,CAACC,MAAM,CAACC,OAAO,CAC5BF,gBAAO,CAACC,MAAM,CAACiC,SAAS;QAE1BC,YAAY;YACV,IAAInC,gBAAO,CAACmC,UAAU,CAACC,OAAO,CAAC;gBAC7BnC,QAAQJ;YACV;SACD;IACH;AACF,GACCwC,gBAAgB","file":"logger.service.js"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export declare type SpinnerStatus = 'spin' | 'stop' | 'success' | 'failed';
|
|
2
|
+
export interface SpinnerState {
|
|
3
|
+
status: SpinnerStatus;
|
|
4
|
+
label: string;
|
|
5
|
+
}
|
|
6
|
+
export declare type SpinnerStateListener = (state: SpinnerState) => void;
|
|
7
|
+
export declare class SpinnerService {
|
|
8
|
+
private _status;
|
|
9
|
+
private _label;
|
|
10
|
+
private readonly _listeners;
|
|
11
|
+
private _propagate;
|
|
12
|
+
subscribe(listener: SpinnerStateListener): () => void;
|
|
13
|
+
spin(label: string): void;
|
|
14
|
+
success(label: string): void;
|
|
15
|
+
failed(label: string): void;
|
|
16
|
+
stop(): void;
|
|
17
|
+
get state(): SpinnerState;
|
|
18
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["services/spinner.service.ts"],"names":[],"mappings":"AAKA,oBAAY,aAAa,GAAG,MAAM,GAAG,MAAM,GAAG,SAAS,GAAG,QAAQ,CAAC;AACnE,MAAM,WAAW,YAAY;IAC3B,MAAM,EAAE,aAAa,CAAC;IACtB,KAAK,EAAE,MAAM,CAAC;CACf;AAED,oBAAY,oBAAoB,GAAG,CAAC,KAAK,EAAE,YAAY,KAAK,IAAI,CAAC;AAGjE,qBACa,cAAc;IAEzB,OAAO,CAAC,OAAO,CAAyB;IACxC,OAAO,CAAC,MAAM,CAAM;IAEpB,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAmC;IAG9D,OAAO,CAAC,UAAU;IAMlB,SAAS,CAAC,QAAQ,EAAE,oBAAoB;IAQxC,IAAI,CAAC,KAAK,EAAE,MAAM;IAOlB,OAAO,CAAC,KAAK,EAAE,MAAM;IAOrB,MAAM,CAAC,KAAK,EAAE,MAAM;IAOpB,IAAI;IASJ,IAAI,KAAK,IAAI,YAAY,CAKxB;CACF","file":"spinner.service.d.ts","sourcesContent":["import { injectable } from 'inversify';\n\nimport { container } from './inversify.config';\n\n// Interface\nexport type SpinnerStatus = 'spin' | 'stop' | 'success' | 'failed';\nexport interface SpinnerState {\n status: SpinnerStatus;\n label: string;\n}\n\nexport type SpinnerStateListener = (state: SpinnerState) => void;\n\n// Service\n@injectable()\nexport class SpinnerService {\n // Attributes\n private _status: SpinnerStatus = 'stop';\n private _label = '';\n\n private readonly _listeners = new Set<SpinnerStateListener>();\n\n // Methods\n private _propagate() {\n for (const listener of this._listeners) {\n listener(this.state);\n }\n }\n\n subscribe(listener: SpinnerStateListener) {\n this._listeners.add(listener);\n\n return () => {\n this._listeners.delete(listener);\n };\n }\n\n spin(label: string) {\n this._status = 'spin';\n this._label = label;\n\n this._propagate();\n }\n\n success(label: string) {\n this._status = 'success';\n this._label = label;\n\n this._propagate();\n }\n\n failed(label: string) {\n this._status = 'failed';\n this._label = label;\n\n this._propagate();\n }\n\n stop() {\n if (this._status === 'spin') {\n this._status = 'stop';\n\n this._propagate();\n }\n }\n\n // Properties\n get state(): SpinnerState {\n return {\n status: this._status,\n label: this._label,\n };\n }\n}\n\ncontainer.bind(SpinnerService)\n .toSelf()\n .inSingletonScope();\n"]}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
Object.defineProperty(exports, "SpinnerService", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: ()=>SpinnerService
|
|
8
|
+
});
|
|
9
|
+
const _inversify = require("inversify");
|
|
10
|
+
const _inversifyConfig = require("./inversify.config");
|
|
11
|
+
var __decorate = (void 0) && (void 0).__decorate || function(decorators, target, key, desc) {
|
|
12
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
13
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
14
|
+
else for(var i = decorators.length - 1; i >= 0; i--)if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
15
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
16
|
+
};
|
|
17
|
+
let SpinnerService = class SpinnerService {
|
|
18
|
+
// Attributes
|
|
19
|
+
_status = 'stop';
|
|
20
|
+
_label = '';
|
|
21
|
+
_listeners = new Set();
|
|
22
|
+
// Methods
|
|
23
|
+
_propagate() {
|
|
24
|
+
for (const listener of this._listeners){
|
|
25
|
+
listener(this.state);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
subscribe(listener) {
|
|
29
|
+
this._listeners.add(listener);
|
|
30
|
+
return ()=>{
|
|
31
|
+
this._listeners.delete(listener);
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
spin(label) {
|
|
35
|
+
this._status = 'spin';
|
|
36
|
+
this._label = label;
|
|
37
|
+
this._propagate();
|
|
38
|
+
}
|
|
39
|
+
success(label) {
|
|
40
|
+
this._status = 'success';
|
|
41
|
+
this._label = label;
|
|
42
|
+
this._propagate();
|
|
43
|
+
}
|
|
44
|
+
failed(label) {
|
|
45
|
+
this._status = 'failed';
|
|
46
|
+
this._label = label;
|
|
47
|
+
this._propagate();
|
|
48
|
+
}
|
|
49
|
+
stop() {
|
|
50
|
+
if (this._status === 'spin') {
|
|
51
|
+
this._status = 'stop';
|
|
52
|
+
this._propagate();
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
// Properties
|
|
56
|
+
get state() {
|
|
57
|
+
return {
|
|
58
|
+
status: this._status,
|
|
59
|
+
label: this._label
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
};
|
|
63
|
+
SpinnerService = __decorate([
|
|
64
|
+
(0, _inversify.injectable)()
|
|
65
|
+
], SpinnerService);
|
|
66
|
+
_inversifyConfig.container.bind(SpinnerService).toSelf().inSingletonScope();
|
|
67
|
+
|
|
68
|
+
//# sourceMappingURL=spinner.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["services/spinner.service.js"],"sourcesContent":["import { injectable } from 'inversify';\n\nimport { container } from './inversify.config';\n\n// Interface\nexport type SpinnerStatus = 'spin' | 'stop' | 'success' | 'failed';\nexport interface SpinnerState {\n status: SpinnerStatus;\n label: string;\n}\n\nexport type SpinnerStateListener = (state: SpinnerState) => void;\n\n// Service\n@injectable()\nexport class SpinnerService {\n // Attributes\n private _status: SpinnerStatus = 'stop';\n private _label = '';\n\n private readonly _listeners = new Set<SpinnerStateListener>();\n\n // Methods\n private _propagate() {\n for (const listener of this._listeners) {\n listener(this.state);\n }\n }\n\n subscribe(listener: SpinnerStateListener) {\n this._listeners.add(listener);\n\n return () => {\n this._listeners.delete(listener);\n };\n }\n\n spin(label: string) {\n this._status = 'spin';\n this._label = label;\n\n this._propagate();\n }\n\n success(label: string) {\n this._status = 'success';\n this._label = label;\n\n this._propagate();\n }\n\n failed(label: string) {\n this._status = 'failed';\n this._label = label;\n\n this._propagate();\n }\n\n stop() {\n if (this._status === 'spin') {\n this._status = 'stop';\n\n this._propagate();\n }\n }\n\n // Properties\n get state(): SpinnerState {\n return {\n status: this._status,\n label: this._label,\n };\n }\n}\n\ncontainer.bind(SpinnerService)\n .toSelf()\n .inSingletonScope();\n"],"names":["SpinnerService","_status","_label","_listeners","Set","_propagate","listener","state","subscribe","add","delete","spin","label","success","failed","stop","status","injectable","container","bind","toSelf","inSingletonScope"],"mappings":"AAAA;;;;+BAeaA;;aAAAA;;2BAfc;iCAED;;;;;;;IAabA,iBAAN;IACL,aAAa;IACLC,UAAyB,OAAO;IAChCC,SAAS,GAAG;IAEHC,aAAa,IAAIC,MAA4B;IAE9D,UAAU;IACFC,aAAa;QACnB,KAAK,MAAMC,YAAY,IAAI,CAACH,UAAU,CAAE;YACtCG,SAAS,IAAI,CAACC,KAAK;QACrB;IACF;IAEAC,UAAUF,QAA8B,EAAE;QACxC,IAAI,CAACH,UAAU,CAACM,GAAG,CAACH;QAEpB,OAAO,IAAM;YACX,IAAI,CAACH,UAAU,CAACO,MAAM,CAACJ;QACzB;IACF;IAEAK,KAAKC,KAAa,EAAE;QAClB,IAAI,CAACX,OAAO,GAAG;QACf,IAAI,CAACC,MAAM,GAAGU;QAEd,IAAI,CAACP,UAAU;IACjB;IAEAQ,QAAQD,KAAa,EAAE;QACrB,IAAI,CAACX,OAAO,GAAG;QACf,IAAI,CAACC,MAAM,GAAGU;QAEd,IAAI,CAACP,UAAU;IACjB;IAEAS,OAAOF,KAAa,EAAE;QACpB,IAAI,CAACX,OAAO,GAAG;QACf,IAAI,CAACC,MAAM,GAAGU;QAEd,IAAI,CAACP,UAAU;IACjB;IAEAU,OAAO;QACL,IAAI,IAAI,CAACd,OAAO,KAAK,QAAQ;YAC3B,IAAI,CAACA,OAAO,GAAG;YAEf,IAAI,CAACI,UAAU;QACjB,CAAC;IACH;IAEA,aAAa;IACb,IAAIE,QAAsB;QACxB,OAAO;YACLS,QAAQ,IAAI,CAACf,OAAO;YACpBW,OAAO,IAAI,CAACV,MAAM;QACpB;IACF;AACF;AA1DaF;IADZiB,IAAAA,qBAAU;GACEjB;AA4DbkB,0BAAS,CAACC,IAAI,CAACnB,gBACZoB,MAAM,GACNC,gBAAgB","file":"spinner.service.js"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["services/task-manager.service.ts"],"names":[],"mappings":"","file":"task-manager.service.d.ts","sourcesContent":["import { TaskManager } from '@jujulego/tasks';\n\nimport { type GlobalConfig, GLOBAL_CONFIG, container } from './inversify.config';\nimport { Logger } from './logger.service';\n\n// Service\ncontainer.bind(TaskManager)\n .toDynamicValue((context) => {\n const config = context.container.get<GlobalConfig>(GLOBAL_CONFIG);\n const logger = context.container.get(Logger);\n\n return new TaskManager({ jobs: config.jobs, logger });\n })\n .inSingletonScope();\n"]}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
const _tasks = require("@jujulego/tasks");
|
|
6
|
+
const _inversifyConfig = require("./inversify.config");
|
|
7
|
+
const _loggerService = require("./logger.service");
|
|
8
|
+
// Service
|
|
9
|
+
_inversifyConfig.container.bind(_tasks.TaskManager).toDynamicValue((context)=>{
|
|
10
|
+
const config = context.container.get(_inversifyConfig.GLOBAL_CONFIG);
|
|
11
|
+
const logger = context.container.get(_loggerService.Logger);
|
|
12
|
+
return new _tasks.TaskManager({
|
|
13
|
+
jobs: config.jobs,
|
|
14
|
+
logger
|
|
15
|
+
});
|
|
16
|
+
}).inSingletonScope();
|
|
17
|
+
|
|
18
|
+
//# sourceMappingURL=task-manager.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["services/task-manager.service.js"],"sourcesContent":["import { TaskManager } from '@jujulego/tasks';\n\nimport { type GlobalConfig, GLOBAL_CONFIG, container } from './inversify.config';\nimport { Logger } from './logger.service';\n\n// Service\ncontainer.bind(TaskManager)\n .toDynamicValue((context) => {\n const config = context.container.get<GlobalConfig>(GLOBAL_CONFIG);\n const logger = context.container.get(Logger);\n\n return new TaskManager({ jobs: config.jobs, logger });\n })\n .inSingletonScope();\n"],"names":["container","bind","TaskManager","toDynamicValue","context","config","get","GLOBAL_CONFIG","logger","Logger","jobs","inSingletonScope"],"mappings":"AAAA;;;;uBAA4B;iCAEgC;+BACrC;AAEvB,UAAU;AACVA,0BAAS,CAACC,IAAI,CAACC,kBAAW,EACvBC,cAAc,CAAC,CAACC,UAAY;IAC3B,MAAMC,SAASD,QAAQJ,SAAS,CAACM,GAAG,CAAeC,8BAAa;IAChE,MAAMC,SAASJ,QAAQJ,SAAS,CAACM,GAAG,CAACG,qBAAM;IAE3C,OAAO,IAAIP,kBAAW,CAAC;QAAEQ,MAAML,OAAOK,IAAI;QAAEF;IAAO;AACrD,GACCG,gBAAgB","file":"task-manager.service.js"}
|
package/dist/types.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare type Awaitable<T> = T | Promise<T>;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["types.ts"],"names":[],"mappings":"AACA,oBAAY,SAAS,CAAC,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC","file":"types.d.ts","sourcesContent":["// Types\nexport type Awaitable<T> = T | Promise<T>;\n"]}
|
package/dist/types.js
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["types.js"],"sourcesContent":["// Types\nexport type Awaitable<T> = T | Promise<T>;\n"],"names":[],"mappings":"AAAA,QAAQ;AACR","file":"types.js"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["ui/global-spinner.tsx"],"names":[],"mappings":"AAGA,OAAO,EAAE,EAAE,EAA6B,MAAM,OAAO,CAAC;AAKtD,eAAO,MAAM,aAAa,EAAE,EAuC3B,CAAC","file":"global-spinner.d.ts","sourcesContent":["import { Text } from 'ink';\nimport Spinner from 'ink-spinner';\nimport symbols from 'log-symbols';\nimport { FC, useLayoutEffect, useState } from 'react';\n\nimport { container, SpinnerService, SpinnerState } from '../services';\n\n// Components\nexport const GlobalSpinner: FC = () => {\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.subscribe(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"]}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
Object.defineProperty(exports, "GlobalSpinner", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: ()=>GlobalSpinner
|
|
8
|
+
});
|
|
9
|
+
const _jsxRuntime = require("react/jsx-runtime");
|
|
10
|
+
const _ink = require("ink");
|
|
11
|
+
const _inkSpinner = /*#__PURE__*/ _interopRequireDefault(require("ink-spinner"));
|
|
12
|
+
const _logSymbols = /*#__PURE__*/ _interopRequireDefault(require("log-symbols"));
|
|
13
|
+
const _react = require("react");
|
|
14
|
+
const _services = require("../services");
|
|
15
|
+
function _interopRequireDefault(obj) {
|
|
16
|
+
return obj && obj.__esModule ? obj : {
|
|
17
|
+
default: obj
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
const GlobalSpinner = ()=>{
|
|
21
|
+
// State
|
|
22
|
+
const [state, setState] = (0, _react.useState)({
|
|
23
|
+
status: 'stop',
|
|
24
|
+
label: ''
|
|
25
|
+
});
|
|
26
|
+
// Effect
|
|
27
|
+
(0, _react.useLayoutEffect)(()=>{
|
|
28
|
+
const spinner = _services.container.get(_services.SpinnerService);
|
|
29
|
+
setState(spinner.state);
|
|
30
|
+
return spinner.subscribe(setState);
|
|
31
|
+
}, []);
|
|
32
|
+
// Render
|
|
33
|
+
switch(state.status){
|
|
34
|
+
case 'spin':
|
|
35
|
+
return /*#__PURE__*/ (0, _jsxRuntime.jsxs)(_ink.Text, {
|
|
36
|
+
children: [
|
|
37
|
+
/*#__PURE__*/ (0, _jsxRuntime.jsx)(_inkSpinner.default, {}),
|
|
38
|
+
' ' + state.label
|
|
39
|
+
]
|
|
40
|
+
});
|
|
41
|
+
case 'success':
|
|
42
|
+
return /*#__PURE__*/ (0, _jsxRuntime.jsxs)(_ink.Text, {
|
|
43
|
+
color: "green",
|
|
44
|
+
children: [
|
|
45
|
+
_logSymbols.default.success,
|
|
46
|
+
" ",
|
|
47
|
+
state.label
|
|
48
|
+
]
|
|
49
|
+
});
|
|
50
|
+
case 'failed':
|
|
51
|
+
return /*#__PURE__*/ (0, _jsxRuntime.jsxs)(_ink.Text, {
|
|
52
|
+
color: "red",
|
|
53
|
+
children: [
|
|
54
|
+
_logSymbols.default.error,
|
|
55
|
+
" ",
|
|
56
|
+
state.label
|
|
57
|
+
]
|
|
58
|
+
});
|
|
59
|
+
case 'stop':
|
|
60
|
+
default:
|
|
61
|
+
return null;
|
|
62
|
+
}
|
|
63
|
+
};
|
|
64
|
+
|
|
65
|
+
//# sourceMappingURL=global-spinner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["ui/global-spinner.js"],"sourcesContent":["import { Text } from 'ink';\nimport Spinner from 'ink-spinner';\nimport symbols from 'log-symbols';\nimport { FC, useLayoutEffect, useState } from 'react';\n\nimport { container, SpinnerService, SpinnerState } from '../services';\n\n// Components\nexport const GlobalSpinner: FC = () => {\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.subscribe(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"],"names":["GlobalSpinner","state","setState","useState","status","label","useLayoutEffect","spinner","container","get","SpinnerService","subscribe","Text","Spinner","color","symbols","success","error"],"mappings":"AAAA;;;;+BAQaA;;aAAAA;;;qBARQ;iEACD;iEACA;uBAC0B;0BAEU;;;;;;AAGjD,MAAMA,gBAAoB,IAAM;IACrC,QAAQ;IACR,MAAM,CAACC,OAAOC,SAAS,GAAGC,IAAAA,eAAQ,EAAe;QAAEC,QAAQ;QAAQC,OAAO;IAAG;IAE7E,SAAS;IACTC,IAAAA,sBAAe,EAAC,IAAM;QACpB,MAAMC,UAAUC,mBAAS,CAACC,GAAG,CAACC,wBAAc;QAC5CR,SAASK,QAAQN,KAAK;QAEtB,OAAOM,QAAQI,SAAS,CAACT;IAC3B,GAAG,EAAE;IAEL,SAAS;IACT,OAAQD,MAAMG,MAAM;QAClB,KAAK;YACH,qBACE,sBAACQ,SAAI;;kCACH,qBAACC,mBAAO;oBAAI,MAAMZ,MAAMI,KAAK;;;QAInC,KAAK;YACH,qBACE,sBAACO,SAAI;gBAACE,OAAM;;oBACTC,mBAAO,CAACC,OAAO;oBAAC;oBAAEf,MAAMI,KAAK;;;QAIpC,KAAK;YACH,qBACE,sBAACO,SAAI;gBAACE,OAAM;;oBACTC,mBAAO,CAACE,KAAK;oBAAC;oBAAEhB,MAAMI,KAAK;;;QAIlC,KAAK;QACL;YACE,OAAO,IAAI;IACf;AACF","file":"global-spinner.js"}
|