UNPKG

decova-gotcha

Version:

It's my personal trial for automating daunting tasks

80 lines 4.14 kB
"use strict"; var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) { var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); 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; return c > 3 && r && Object.defineProperty(target, key, r), r; }; var __metadata = (this && this.__metadata) || function (k, v) { if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v); }; var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } return new (P || (P = Promise))(function (resolve, reject) { function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } step((generator = generator.apply(thisArg, _arguments || [])).next()); }); }; var LocalToolsDispatcher_1; Object.defineProperty(exports, "__esModule", { value: true }); exports.LocalToolsDispatcher = void 0; const decova_dotnet_1 = require("decova-dotnet"); const tsyringe_1 = require("tsyringe"); const TerminalAgent_1 = require("../external-sheet/TerminalAgent"); const CommonMenu_1 = require("./Techies/CommonMenu"); let LocalToolsDispatcher = LocalToolsDispatcher_1 = class LocalToolsDispatcher { constructor() { this._local_tools_dictionary = new Map(); if (LocalToolsDispatcher_1._singleton) throw new decova_dotnet_1.Exception('Only one instance of LocalToolsDispatcher is expected to be initialzed on the app lifetime'); LocalToolsDispatcher_1._singleton = this; } RegisterLocalTools(...localTools) { localTools.forEach(tool => { const shortcut = tool.GetShortcut().trim().toLowerCase(); if (this._local_tools_dictionary == null) { this._local_tools_dictionary = new Map(); } if (this._local_tools_dictionary.xContains(shortcut)) throw new decova_dotnet_1.Exception(`Local tool shortcut ${shortcut} is already registered!`); this._local_tools_dictionary.xAdd(shortcut, tool); }); } TryAimToolAsync(shortcut, args) { return __awaiter(this, void 0, void 0, function* () { if (this._local_tools_dictionary.xContains(shortcut) == false) { return false; } else { const tool = this._local_tools_dictionary.xGet(shortcut); yield tool.TakeControlAsync(args); return true; } }); } static RunAsync(lTool, args) { return __awaiter(this, void 0, void 0, function* () { TerminalAgent_1.TerminalAgent.Hint(lTool.GetHint()); const ans = yield CommonMenu_1.CommonMenu.ShowContinueSkipAsync('>>>'); if (ans) { const cmd = `g ${lTool.GetShortcut()}`; console.log('command: ', cmd); TerminalAgent_1.TerminalAgent.Exec(cmd); } else { TerminalAgent_1.TerminalAgent.ShowError("Command skipped!"); } }); } get RegisteredTools() { return this._local_tools_dictionary.xValues(); } }; LocalToolsDispatcher = LocalToolsDispatcher_1 = __decorate([ (0, tsyringe_1.singleton)(), __metadata("design:paramtypes", []) ], LocalToolsDispatcher); exports.LocalToolsDispatcher = LocalToolsDispatcher; //# sourceMappingURL=LocalToolsDispatcher.js.map