UNPKG

ng2-logger

Version:

isomorphic logger for browser/server in typescript

162 lines 16.8 kB
import { Logger } from './logger'; import { Level, LevelOrder, LevelKey } from './level'; import { Helpers } from 'tnp-core/websql'; /* */ /* */ /* */ /* */ /* */ class Log { constructor() { this._logOnly = false; this._logModules = false; this.isDevelopmentMode = true; this.modeIsSet = false; this.fixedWidth = 0; this.instances = {}; this.levels = []; this.modules = []; } // @ts-ignore static get instance() { // @ts-ignore if (!Log['_instance']) { // @ts-ignore Log['_instance'] = new Log(); } // @ts-ignore return Log['_instance']; } static { this.Logger = Logger; } static create(name, ...level) { return Log.instance.create(name, ...level); } static { this.consolelogfn = {}; } static disableLogs(level = Level.__NOTHING) { /* */ /* */ /* */ /* */ /* */ /* */ /* */ LevelOrder.reverse().find(a => { // @ts-ignore if (!this.consolelogfn[a]) { // @ts-ignore this.consolelogfn[a] = console[a]; } // @ts-ignore console[a] = () => { }; if (a === LevelKey[level]) { return true; } return false; }); } static enableLogs() { /* */ /* */ /* */ /* */ LevelOrder.forEach(a => { // @ts-ignore console[a] = this.consolelogfn[a]; }); } setProductionMode() { if (this.modeIsSet) { this.modeIsSet = false; throw '[ng2-logger] Production mode is already set'; } else { this.modeIsSet = true; setTimeout(() => { if (this.modeIsSet && console !== void 0 && console.clear !== void 0) { console.clear(); console.log = () => { }; console.error = () => { }; console.warn = () => { }; console.info = () => { }; } }); this.isDevelopmentMode = false; } } onlyModules(...modules) { if (this._logModules) { throw '[ng2-logger] You should use funcion onlyModules only once'; } if (!this._logModules) { this._logModules = true; } if (modules.length === 0) return; this.modules = modules; this.muteAllOtherModules(); } onlyLevel(...level) { if (this._logOnly) { throw '[ng2-logger] You should use funcion onlyLevel only once'; } if (!this._logOnly) { this._logOnly = true; } this.levels = Array.isArray(level) ? level : [level]; for (const logName in this.instances) { if (this.instances.hasOwnProperty(logName)) { const element = this.instances[logName]; element['allowed'] = this.levels; } } } create(name, ...level) { let i; if (Array.isArray(this.levels) && this.levels.length > 0) { level = this.levels; } if (this.instances[name] === void 0) { i = new (Log.Logger)(name, getRandomColor(), this.isDevelopmentMode, level, this.isMutedModule(name), this.levels.length > 0 ? this.fixedWidth : void 0); this.instances[name] = i; } else { i = this.instances[name]; } return i; } isMutedModule(moduleName) { if (this.modules.length == 0) return false; if (!Helpers.contain(this.modules, moduleName)) return true; return false; } muteAllOtherModules() { for (var moduleName in this.instances) { if (!Helpers.contain(this.modules, moduleName)) this.instances[moduleName].mute(); } } } export { Log }; function getRandomColor() { /* */ /* */ /* */ /* */ let letters = '012345'.split(''); let color = '#'; color += letters[Math.round(Math.random() * 5)]; letters = '0123456789ABCDEF'.split(''); for (let i = 0; i < 5; i++) { color += letters[Math.round(Math.random() * 15)]; } if (color === void 0) { return getRandomColor(); } ; return color; } ; ({}); // @--end-of-file-for-module=ng2-logger lib/log.ts //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"log.js","sourceRoot":"","sources":["../../../../tmp-libs-for-dist-websql/ng2-logger/projects/ng2-logger/src/lib/log.ts"],"names":[],"mappings":"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","sourcesContent":["\n\nimport { Logger } from './logger';\nimport { Level, LevelOrder, LevelKey } from './level';\nimport { Helpers } from 'tnp-core/websql';\n/* */\n/* */\n/* */\n  \n\n\n/* */\n/* */\n  \n\n\nexport class Log {\n\n  private constructor() { }\n  // @ts-ignore\n  private static get instance(): any {\n    // @ts-ignore\n    if (!Log['_instance']) {\n      // @ts-ignore\n      Log['_instance'] = new Log();\n    }\n    // @ts-ignore\n    return Log['_instance'];\n  }\n\n\n  static Logger: (typeof Logger) = Logger;\n  static create(name: string, ...level: Level[]): Logger {\n    return Log.instance.create(name, ...level);\n  }\n\n  private static readonly consolelogfn = {};\n  static disableLogs(level = Level.__NOTHING) {\n/* */\n/* */\n/* */\n/* */\n/* */\n/* */\n/* */\n  \n    LevelOrder.reverse().find(a => {\n      // @ts-ignore\n      if (!this.consolelogfn[a]) {\n        // @ts-ignore\n        this.consolelogfn[a] = console[a];\n      }\n      // @ts-ignore\n      console[a] = () => { };\n      if (a === LevelKey[level]) {\n        return true;\n      }\n      return false;\n    });\n  }\n\n  static enableLogs() {\n/* */\n/* */\n/* */\n/* */\n  \n    LevelOrder.forEach(a => {\n      // @ts-ignore\n      console[a] = this.consolelogfn[a]\n    });\n  }\n\n  private _logOnly = false;\n  private _logModules = false;\n  private isDevelopmentMode = true;\n  private modeIsSet: boolean = false;\n  private fixedWidth = 0;\n  private instances: { [moduleName: string]: Logger } = {};\n  private levels: Level[] = [];\n  private modules: (string | RegExp)[] = [];\n\n\n  public setProductionMode() {\n    if (this.modeIsSet) {\n      this.modeIsSet = false\n      throw '[ng2-logger] Production mode is already set';\n    } else {\n      this.modeIsSet = true;\n      setTimeout(() => {\n\n        if (this.modeIsSet && console !== void 0 && console.clear !== void 0) {\n\n          console.clear();\n          console.log = () => { };\n          console.error = () => { };\n          console.warn = () => { };\n          console.info = () => { };\n        }\n      });\n\n      this.isDevelopmentMode = false;\n    }\n  }\n\n  public onlyModules(...modules: (string | RegExp)[]) {\n    if (this._logModules) {\n      throw '[ng2-logger] You should use funcion onlyModules only once';\n    }\n    if (!this._logModules) {\n      this._logModules = true;\n    }\n    if (modules.length === 0) return;\n    this.modules = modules;\n\n    this.muteAllOtherModules();\n  }\n\n\n  public onlyLevel(...level: Level[]) {\n    if (this._logOnly) {\n      throw '[ng2-logger] You should use funcion onlyLevel only once';\n    }\n    if (!this._logOnly) {\n      this._logOnly = true;\n    }\n\n    this.levels = Array.isArray(level) ? level : [level];\n\n\n    for (const logName in this.instances) {\n      if (this.instances.hasOwnProperty(logName)) {\n        const element = this.instances[logName];\n        element['allowed'] = this.levels;\n      }\n    }\n  }\n\n\n\n  private create(name: string, ...level: Level[]): Logger {\n    let i: Logger;\n    if (Array.isArray(this.levels) && this.levels.length > 0) {\n      level = this.levels;\n    }\n    if (this.instances[name] === void 0) {\n      i = new (Log.Logger)(\n        name,\n        getRandomColor(),\n        this.isDevelopmentMode,\n        level,\n        this.isMutedModule(name),\n        this.levels.length > 0 ? this.fixedWidth : void 0,\n\n      );\n      this.instances[name] = i;\n    } else {\n      i = this.instances[name];\n    }\n    return i;\n  }\n\n  private isMutedModule(moduleName: string): boolean {\n    if (this.modules.length == 0) return false;\n    if (!Helpers.contain(this.modules, moduleName)) return true;\n    return false;\n  }\n  private muteAllOtherModules() {\n    for (var moduleName in this.instances) {\n      if (!Helpers.contain(this.modules, moduleName))\n        this.instances[moduleName].mute()\n    }\n  }\n\n}\n\n\nfunction getRandomColor(): string {\n/* */\n/* */\n/* */\n/* */\n  \n\n  let letters = '012345'.split('');\n  let color = '#';\n  color += letters[Math.round(Math.random() * 5)];\n  letters = '0123456789ABCDEF'.split('');\n  for (let i = 0; i < 5; i++) {\n    color += letters[Math.round(Math.random() * 15)];\n  }\n  if (color === void 0) {\n    return getRandomColor()\n  };\n  return color;\n}\n\n ;({}); // @--end-of-file-for-module=ng2-logger lib/log.ts"]}