decova-gotcha
Version:
It's my personal trial for automating daunting tasks
80 lines • 4.14 kB
JavaScript
;
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