1 | ;
|
2 | Object.defineProperty(exports, "__esModule", { value: true });
|
3 | const tslib_1 = require("tslib");
|
4 | const utils_1 = require("@neo-one/utils");
|
5 | const chalk_1 = tslib_1.__importDefault(require("chalk"));
|
6 | const cli_truncate_1 = tslib_1.__importDefault(require("cli-truncate"));
|
7 | const elegant_spinner_1 = tslib_1.__importDefault(require("elegant-spinner"));
|
8 | const figures_1 = tslib_1.__importDefault(require("figures"));
|
9 | const logSymbols = tslib_1.__importStar(require("log-symbols"));
|
10 | const log_update_1 = tslib_1.__importDefault(require("log-update"));
|
11 | const rxjs_1 = require("rxjs");
|
12 | const operators_1 = require("rxjs/operators");
|
13 | const displayUtils_1 = require("./displayUtils");
|
14 | const tasks_1 = require("./tasks");
|
15 | const pointer = chalk_1.default.yellow(figures_1.default.pointer);
|
16 | const skipped = chalk_1.default.yellow(figures_1.default.arrowDown);
|
17 | const getSymbol = (task, mutableSpinners) => {
|
18 | if (mutableSpinners[task.id] == undefined) {
|
19 | mutableSpinners[task.id] = elegant_spinner_1.default();
|
20 | }
|
21 | const hasSubtasks = task.subtasks !== undefined && task.subtasks.length > 0;
|
22 | if (task.pending) {
|
23 | return hasSubtasks ? pointer : chalk_1.default.yellow(mutableSpinners[task.id]());
|
24 | }
|
25 | if (task.complete) {
|
26 | return logSymbols.success;
|
27 | }
|
28 | if (task.error !== undefined) {
|
29 | return hasSubtasks ? pointer : logSymbols.error;
|
30 | }
|
31 | if (task.skipped !== undefined) {
|
32 | return skipped;
|
33 | }
|
34 | return ' ';
|
35 | };
|
36 | const renderTasks = (tasks, spinners, level = 0) => {
|
37 | let mutableOutput = [];
|
38 | tasks.forEach((task) => {
|
39 | const skippedStr = task.skipped !== undefined ? ` ${chalk_1.default.dim('[skipped]')}` : '';
|
40 | mutableOutput.push(displayUtils_1.indentString(` ${getSymbol(task, spinners)} ${task.title}${skippedStr}`, level, { indent: ' ' }));
|
41 | if ((task.pending && task.message !== undefined) ||
|
42 | task.skipped !== false ||
|
43 | task.error !== undefined ||
|
44 | task.message !== undefined) {
|
45 | let data = task.error;
|
46 | if (data === undefined && task.skipped !== false) {
|
47 | if (typeof task.skipped === 'string') {
|
48 | data = task.skipped;
|
49 | }
|
50 | }
|
51 | else if (data === undefined) {
|
52 | data = task.message;
|
53 | }
|
54 | if (data !== undefined) {
|
55 | data = displayUtils_1.stripAnsi(data
|
56 | .trim()
|
57 | .split('\n')
|
58 | .filter(utils_1.utils.notNull)[0]);
|
59 | const out = displayUtils_1.indentString(`${figures_1.default.arrowRight} ${data}`, level, { indent: ' ' });
|
60 | mutableOutput.push(` ${chalk_1.default.gray(cli_truncate_1.default(out, process.stdout.columns - 3))}`);
|
61 | }
|
62 | }
|
63 | if ((task.pending || task.error !== undefined || !task.collapse) &&
|
64 | task.subtasks !== undefined &&
|
65 | task.subtasks.length > 0) {
|
66 | mutableOutput = mutableOutput.concat(renderTasks(task.subtasks, spinners, level + 1));
|
67 | }
|
68 | });
|
69 | return mutableOutput.join('\n');
|
70 | };
|
71 | exports.handleCLITaskList = async ({ cli, response$, progress, cancel$, }) => {
|
72 | const spinners = {};
|
73 | await response$
|
74 | .pipe(operators_1.switchMap(({ tasks }) => {
|
75 | if (tasks_1.areTasksDone(tasks)) {
|
76 | if (progress) {
|
77 | log_update_1.default(renderTasks(tasks, spinners));
|
78 | log_update_1.default.done();
|
79 | }
|
80 | else {
|
81 | cli.print(renderTasks(tasks, spinners));
|
82 | }
|
83 | cancel$.complete();
|
84 | const error = tasks_1.getTasksError(tasks);
|
85 | if (error !== undefined) {
|
86 | throw new Error(error);
|
87 | }
|
88 | return rxjs_1.EMPTY;
|
89 | }
|
90 | if (progress) {
|
91 | return rxjs_1.timer(0, 50).pipe(operators_1.map(() => {
|
92 | log_update_1.default(renderTasks(tasks, spinners));
|
93 | }));
|
94 | }
|
95 | return rxjs_1.EMPTY;
|
96 | }))
|
97 | .toPromise();
|
98 | };
|
99 |
|
100 | //# sourceMappingURL=data:application/json;charset=utf8;base64,{"version":3,"sources":["handleCLITaskList.ts"],"names":[],"mappings":"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","file":"neo-one-server-plugin/src/handleCLITaskList.js","sourcesContent":["import { utils } from '@neo-one/utils';\nimport chalk from 'chalk';\nimport cliTruncate from 'cli-truncate';\nimport elegantSpinner from 'elegant-spinner';\nimport figures from 'figures';\nimport * as logSymbols from 'log-symbols';\nimport logUpdate from 'log-update';\nimport { EMPTY, Observable, Subject, timer } from 'rxjs';\nimport { map, switchMap } from 'rxjs/operators';\nimport { indentString, stripAnsi } from './displayUtils';\nimport { areTasksDone, getTasksError } from './tasks';\nimport { InteractiveCLI, TaskStatus } from './types';\n\n// tslint:disable-next-line no-any\ntype Spinners = any;\n\nconst pointer = chalk.yellow(figures.pointer);\nconst skipped = chalk.yellow(figures.arrowDown);\n\nconst getSymbol = (task: TaskStatus, mutableSpinners: Spinners) => {\n  if (mutableSpinners[task.id] == undefined) {\n    mutableSpinners[task.id] = elegantSpinner();\n  }\n\n  const hasSubtasks = task.subtasks !== undefined && task.subtasks.length > 0;\n  if (task.pending) {\n    return hasSubtasks ? pointer : chalk.yellow(mutableSpinners[task.id]());\n  }\n\n  if (task.complete) {\n    return logSymbols.success;\n  }\n\n  if (task.error !== undefined) {\n    return hasSubtasks ? pointer : logSymbols.error;\n  }\n\n  if (task.skipped !== undefined) {\n    return skipped;\n  }\n\n  return ' ';\n};\n\nconst renderTasks = (tasks: ReadonlyArray<TaskStatus>, spinners: Spinners, level = 0): string => {\n  let mutableOutput: string[] = [];\n\n  tasks.forEach((task) => {\n    const skippedStr = task.skipped !== undefined ? ` ${chalk.dim('[skipped]')}` : '';\n\n    mutableOutput.push(\n      indentString(` ${getSymbol(task, spinners)} ${task.title}${skippedStr}`, level, { indent: '  ' }),\n    );\n\n    if (\n      (task.pending && task.message !== undefined) ||\n      task.skipped !== false ||\n      task.error !== undefined ||\n      task.message !== undefined\n    ) {\n      let data = task.error;\n      if (data === undefined && task.skipped !== false) {\n        if (typeof task.skipped === 'string') {\n          data = task.skipped;\n        }\n      } else if (data === undefined) {\n        data = task.message;\n      }\n\n      if (data !== undefined) {\n        data = stripAnsi(\n          data\n            .trim()\n            .split('\\n')\n            .filter(utils.notNull)[0],\n        );\n\n        const out = indentString(`${figures.arrowRight} ${data}`, level, { indent: '  ' });\n        mutableOutput.push(`   ${chalk.gray(cliTruncate(out, (process.stdout.columns as number) - 3))}`);\n      }\n    }\n\n    if (\n      (task.pending || task.error !== undefined || !task.collapse) &&\n      task.subtasks !== undefined &&\n      task.subtasks.length > 0\n    ) {\n      mutableOutput = mutableOutput.concat(renderTasks(task.subtasks, spinners, level + 1));\n    }\n  });\n\n  return mutableOutput.join('\\n');\n};\n\nexport const handleCLITaskList = async ({\n  cli,\n  response$,\n  progress,\n  cancel$,\n}: {\n  readonly cli: InteractiveCLI;\n  // tslint:disable-next-line no-any\n  readonly response$: Observable<any>;\n  readonly progress: boolean;\n  readonly cancel$: Subject<void>;\n}): Promise<void> => {\n  const spinners = {};\n  await response$\n    .pipe(\n      switchMap(({ tasks }) => {\n        if (areTasksDone(tasks)) {\n          if (progress) {\n            logUpdate(renderTasks(tasks, spinners));\n            logUpdate.done();\n          } else {\n            cli.print(renderTasks(tasks, spinners));\n          }\n\n          cancel$.complete();\n          const error = getTasksError(tasks);\n          if (error !== undefined) {\n            throw new Error(error);\n          }\n\n          return EMPTY;\n        }\n\n        if (progress) {\n          return timer(0, 50).pipe(\n            map(() => {\n              logUpdate(renderTasks(tasks, spinners));\n            }),\n          );\n        }\n\n        return EMPTY;\n      }),\n    )\n    .toPromise();\n};\n"]}
|