UNPKG

14.3 kBJavaScriptView Raw
1"use strict";
2Object.defineProperty(exports, "__esModule", { value: true });
3const tslib_1 = require("tslib");
4const utils_1 = require("@neo-one/utils");
5const chalk_1 = tslib_1.__importDefault(require("chalk"));
6const cli_truncate_1 = tslib_1.__importDefault(require("cli-truncate"));
7const elegant_spinner_1 = tslib_1.__importDefault(require("elegant-spinner"));
8const figures_1 = tslib_1.__importDefault(require("figures"));
9const logSymbols = tslib_1.__importStar(require("log-symbols"));
10const log_update_1 = tslib_1.__importDefault(require("log-update"));
11const rxjs_1 = require("rxjs");
12const operators_1 = require("rxjs/operators");
13const displayUtils_1 = require("./displayUtils");
14const tasks_1 = require("./tasks");
15const pointer = chalk_1.default.yellow(figures_1.default.pointer);
16const skipped = chalk_1.default.yellow(figures_1.default.arrowDown);
17const 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};
36const 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};
71exports.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"]}