@neo-one/server-plugin
Version:
NEO•ONE Server plugin API.
102 lines (100 loc) • 14.5 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
const tslib_1 = require("tslib");
const utils_1 = require("@neo-one/utils");
const chalk_1 = tslib_1.__importDefault(require("chalk"));
const cli_truncate_1 = tslib_1.__importDefault(require("cli-truncate"));
const figures_1 = tslib_1.__importDefault(require("figures"));
const logSymbols = tslib_1.__importStar(require("log-symbols"));
const log_update_1 = tslib_1.__importDefault(require("log-update"));
const ora_1 = tslib_1.__importDefault(require("ora"));
const rxjs_1 = require("rxjs");
const operators_1 = require("rxjs/operators");
const displayUtils_1 = require("./displayUtils");
const tasks_1 = require("./tasks");
const pointer = chalk_1.default.yellow(figures_1.default.pointer);
const skipped = chalk_1.default.yellow(figures_1.default.arrowDown);
const getSymbol = (task, mutableSpinners) => {
if (mutableSpinners[task.id] == undefined) {
const spinner = ora_1.default({ color: 'yellow' });
mutableSpinners[task.id] = spinner;
}
const hasSubtasks = task.subtasks !== undefined && task.subtasks.length > 0;
if (task.pending) {
return hasSubtasks ? pointer : chalk_1.default.yellow(mutableSpinners[task.id].frame().trim());
}
if (task.complete) {
return logSymbols.success;
}
if (task.error !== undefined) {
return hasSubtasks ? pointer : logSymbols.error;
}
if (task.skipped !== undefined) {
return skipped;
}
return ' ';
};
const renderTasks = (tasks, spinners, level = 0) => {
let mutableOutput = [];
tasks.forEach((task) => {
const skippedStr = task.skipped !== undefined ? ` ${chalk_1.default.dim('[skipped]')}` : '';
mutableOutput.push(displayUtils_1.indentString(` ${getSymbol(task, spinners)} ${task.title}${skippedStr}`, level, { indent: ' ' }));
if ((task.pending && task.message !== undefined) ||
task.skipped !== false ||
task.error !== undefined ||
task.message !== undefined) {
let data = task.error;
if (data === undefined && task.skipped !== false) {
if (typeof task.skipped === 'string') {
data = task.skipped;
}
}
else if (data === undefined) {
data = task.message;
}
if (data !== undefined) {
data = displayUtils_1.stripAnsi(data
.trim()
.split('\n')
.filter(utils_1.utils.notNull)[0]);
const out = displayUtils_1.indentString(`${figures_1.default.arrowRight} ${data}`, level, { indent: ' ' });
mutableOutput.push(` ${chalk_1.default.gray(cli_truncate_1.default(out, process.stdout.columns - 3))}`);
}
}
if ((task.pending || task.error !== undefined || !task.collapse) &&
task.subtasks !== undefined &&
task.subtasks.length > 0) {
mutableOutput = mutableOutput.concat(renderTasks(task.subtasks, spinners, level + 1));
}
});
return mutableOutput.join('\n');
};
exports.handleCLITaskList = async ({ cli, response$, progress, cancel$, }) => {
const spinners = {};
await response$
.pipe(operators_1.switchMap(({ tasks }) => {
if (tasks_1.areTasksDone(tasks)) {
if (progress) {
log_update_1.default(renderTasks(tasks, spinners));
log_update_1.default.done();
}
else {
cli.print(renderTasks(tasks, spinners));
}
cancel$.complete();
const error = tasks_1.getTasksError(tasks);
if (error !== undefined) {
throw new Error(error);
}
return rxjs_1.EMPTY;
}
if (progress) {
return rxjs_1.timer(0, 50).pipe(operators_1.map(() => {
log_update_1.default(renderTasks(tasks, spinners));
}));
}
return rxjs_1.EMPTY;
}))
.toPromise();
};
//# 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 figures from 'figures';\nimport * as logSymbols from 'log-symbols';\nimport logUpdate from 'log-update';\nimport ora from 'ora';\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    const spinner = ora({ color: 'yellow' });\n    mutableSpinners[task.id] = spinner;\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].frame().trim());\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: readonly 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"]}