sprotty
Version:
A next-gen framework for graphical views
106 lines • 4.52 kB
JavaScript
;
/********************************************************************************
* Copyright (c) 2017-2018 TypeFox and others.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v. 2.0 which is available at
* http://www.eclipse.org/legal/epl-2.0.
*
* This Source Code may also be made available under the following Secondary
* Licenses when the conditions for such availability set forth in the Eclipse
* Public License v. 2.0 are satisfied: GNU General Public License, version 2
* with the GNU Classpath Exception which is available at
* https://www.gnu.org/software/classpath/license.html.
*
* SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
********************************************************************************/
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);
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.ConsoleLogger = exports.NullLogger = exports.LogLevel = void 0;
const inversify_1 = require("inversify");
const types_1 = require("../base/types");
var LogLevel;
(function (LogLevel) {
LogLevel[LogLevel["none"] = 0] = "none";
LogLevel[LogLevel["error"] = 1] = "error";
LogLevel[LogLevel["warn"] = 2] = "warn";
LogLevel[LogLevel["info"] = 3] = "info";
LogLevel[LogLevel["log"] = 4] = "log";
})(LogLevel || (exports.LogLevel = LogLevel = {}));
let NullLogger = class NullLogger {
constructor() {
this.logLevel = LogLevel.none;
}
error(thisArg, message, ...params) { }
warn(thisArg, message, ...params) { }
info(thisArg, message, ...params) { }
log(thisArg, message, ...params) { }
};
exports.NullLogger = NullLogger;
exports.NullLogger = NullLogger = __decorate([
(0, inversify_1.injectable)()
], NullLogger);
let ConsoleLogger = class ConsoleLogger {
constructor() {
this.logLevel = LogLevel.log;
this.viewOptions = { baseDiv: '' };
}
error(thisArg, message, ...params) {
if (this.logLevel >= LogLevel.error)
try {
console.error.apply(thisArg, this.consoleArguments(thisArg, message, params));
}
catch (error) { }
}
warn(thisArg, message, ...params) {
if (this.logLevel >= LogLevel.warn)
try {
console.warn.apply(thisArg, this.consoleArguments(thisArg, message, params));
}
catch (error) { }
}
info(thisArg, message, ...params) {
if (this.logLevel >= LogLevel.info)
try {
console.info.apply(thisArg, this.consoleArguments(thisArg, message, params));
}
catch (error) { }
}
log(thisArg, message, ...params) {
if (this.logLevel >= LogLevel.log)
try {
console.log.apply(thisArg, this.consoleArguments(thisArg, message, params));
}
catch (error) { }
}
consoleArguments(thisArg, message, params) {
let caller;
if (typeof thisArg === 'object')
caller = thisArg.constructor.name;
else
caller = thisArg;
const date = new Date();
return [date.toLocaleTimeString() + ' ' + this.viewOptions.baseDiv + ' ' + caller + ': ' + message, ...params];
}
};
exports.ConsoleLogger = ConsoleLogger;
__decorate([
(0, inversify_1.inject)(types_1.TYPES.LogLevel),
__metadata("design:type", Number)
], ConsoleLogger.prototype, "logLevel", void 0);
__decorate([
(0, inversify_1.inject)(types_1.TYPES.ViewerOptions),
__metadata("design:type", Object)
], ConsoleLogger.prototype, "viewOptions", void 0);
exports.ConsoleLogger = ConsoleLogger = __decorate([
(0, inversify_1.injectable)()
], ConsoleLogger);
//# sourceMappingURL=logging.js.map