UNPKG

@nlabs/arkhamjs-middleware-logger

Version:

Add console logging for ArkhamJS

145 lines (144 loc) 17 kB
function _define_property(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } /** * Copyright (c) 2018-Present, Nitrogen Labs, Inc. * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms. */ /* eslint-disable no-console */ import { cloneDeep } from '@nlabs/utils/objects/clone'; import { isEqual } from '@nlabs/utils/checks/isEqual'; export const LoggerDebugLevel = { DISABLED: 0, LOGS: 1, DISPATCH: 2 }; export class Logger { /** * Set configuration options. * * @param {object} options Configuration options. */ config(options) { this.options = { ...this.defaultOptions, ...options }; } /** * Logs errors in the console. Will also call the debugErrorFnc method set in the config. * * @param {object} obj A list of JavaScript objects to output. The string representations of each of these objects * are appended together in the order listed and output. */ debugError(...obj) { const { debugErrorFnc, debugLevel } = this.options; if (debugLevel) { console.error(...obj); } if (debugErrorFnc) { debugErrorFnc(debugLevel, ...obj); } } /** * Logs informational messages to the console. Will also call the debugInfoFnc method set in the config. * * @param {object} obj A list of JavaScript objects to output. The string representations of each of these objects * are appended together in the order listed and output. */ debugInfo(...obj) { const { debugInfoFnc, debugLevel } = this.options; if (debugLevel) { console.info(...obj); } if (debugInfoFnc) { debugInfoFnc(debugLevel, ...obj); } } /** * Logs data in the console. Only logs when in debug mode. Will also call the debugLogFnc method set in the config. * * @param {object} obj A list of JavaScript objects to output. The string representations of each of these objects * are appended together in the order listed and output. */ debugLog(...obj) { const { debugLogFnc, debugLevel } = this.options; if (debugLevel) { console.log(...obj); } if (debugLogFnc) { debugLogFnc(debugLevel, ...obj); } } /** * Enables the console debugger. * * @param {number} level Enable or disable the debugger. Uses the constants: * LoggerDebugLevel.DISABLED (0) - Disable. * LoggerDebugLevel.LOGS (1) - Enable console logs. * LoggerDebugLevel.DISPATCH (2) - Enable console logs and dispatch action data (default). */ enableDebugger(level = LoggerDebugLevel.DISPATCH) { this.options = { ...this.options, debugLevel: level }; } /** * Get the current FluxLogger options. * * @returns {LoggerOptions} the FluxLogger options object. */ getOptions() { return this.options; } preDispatch(action, store) { this.previousStore = store; return Promise.resolve(action); } postDispatch(action, store) { const { debugLevel } = this.options; if (debugLevel && debugLevel > LoggerDebugLevel.LOGS) { const { type } = action; const hasChanged = !isEqual(store, this.previousStore); const updatedLabel = hasChanged ? 'Changed State' : 'Unchanged State'; const updatedColor = hasChanged ? '#00d484' : '#959595'; const updatedStore = cloneDeep(store); if (console.groupCollapsed) { console.groupCollapsed(`FLUX DISPATCH: ${type}`); console.log('%c Action: ', 'color: #00C4FF', action); console.log('%c Last State: ', 'color: #959595', this.previousStore); console.log(`%c ${updatedLabel}: `, `color: ${updatedColor}`, updatedStore); console.groupEnd(); } else { console.log(`FLUX DISPATCH: ${type}`); console.log('Action: ', action); console.log('Last State: ', this.previousStore); console.log(`${updatedLabel}: `, updatedStore); } } return Promise.resolve(action); } constructor(options){ _define_property(this, "name", 'Logger'); _define_property(this, "previousStore", {}); _define_property(this, "defaultOptions", { debugLevel: LoggerDebugLevel.DISABLED }); _define_property(this, "options", this.defaultOptions); // Methods this.config = this.config.bind(this); this.debugError = this.debugError.bind(this); this.debugInfo = this.debugInfo.bind(this); this.debugLog = this.debugLog.bind(this); this.enableDebugger = this.enableDebugger.bind(this); this.getOptions = this.getOptions.bind(this); this.postDispatch = this.postDispatch.bind(this); this.preDispatch = this.preDispatch.bind(this); // Configuration this.config(options); } } //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["/Users/nitrog7/Development/arkhamjs/packages/arkhamjs-middleware-logger/src/Logger/Logger.ts"],"sourcesContent":["/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\n/* eslint-disable no-console */\nimport {cloneDeep} from '@nlabs/utils/objects/clone';\nimport {isEqual} from '@nlabs/utils/checks/isEqual';\n\nimport type {FluxAction} from '@nlabs/arkhamjs';\n\nexport const LoggerDebugLevel = {\n  DISABLED: 0,\n  LOGS: 1,\n  DISPATCH: 2\n} as const;\n\nexport type LoggerDebugLevelType = typeof LoggerDebugLevel[keyof typeof LoggerDebugLevel];\n\nexport interface LoggerOptions {\n  readonly debugLevel?: LoggerDebugLevelType;\n  readonly debugErrorFnc?: (debugLevel: number, ...args: any[]) => void;\n  readonly debugInfoFnc?: (debugLevel: number, ...args: any[]) => void;\n  readonly debugLogFnc?: (debugLevel: number, ...args: any[]) => void;\n}\n\nexport class Logger {\n  name: string = 'Logger';\n\n  private previousStore: any = {};\n  private defaultOptions: LoggerOptions = {\n    debugLevel: LoggerDebugLevel.DISABLED\n  };\n  private options: LoggerOptions = this.defaultOptions;\n\n  constructor(options: LoggerOptions) {\n    // Methods\n    this.config = this.config.bind(this);\n    this.debugError = this.debugError.bind(this);\n    this.debugInfo = this.debugInfo.bind(this);\n    this.debugLog = this.debugLog.bind(this);\n    this.enableDebugger = this.enableDebugger.bind(this);\n    this.getOptions = this.getOptions.bind(this);\n    this.postDispatch = this.postDispatch.bind(this);\n    this.preDispatch = this.preDispatch.bind(this);\n\n    // Configuration\n    this.config(options);\n  }\n\n  /**\n   * Set configuration options.\n   *\n   * @param {object} options Configuration options.\n   */\n  config(options: LoggerOptions): void {\n    this.options = {...this.defaultOptions, ...options};\n  }\n\n  /**\n   * Logs errors in the console. Will also call the debugErrorFnc method set in the config.\n   *\n   * @param {object} obj A list of JavaScript objects to output. The string representations of each of these objects\n   * are appended together in the order listed and output.\n   */\n  debugError(...obj: any[]): void {\n    const {debugErrorFnc, debugLevel} = this.options;\n\n    if(debugLevel) {\n      console.error(...obj);\n    }\n\n    if(debugErrorFnc) {\n      debugErrorFnc(debugLevel as number, ...obj);\n    }\n  }\n\n  /**\n   * Logs informational messages to the console. Will also call the debugInfoFnc method set in the config.\n   *\n   * @param {object} obj A list of JavaScript objects to output. The string representations of each of these objects\n   * are appended together in the order listed and output.\n   */\n  debugInfo(...obj: any[]): void {\n    const {debugInfoFnc, debugLevel} = this.options;\n\n    if(debugLevel) {\n      console.info(...obj);\n    }\n\n    if(debugInfoFnc) {\n      debugInfoFnc(debugLevel as number, ...obj);\n    }\n  }\n\n  /**\n   * Logs data in the console. Only logs when in debug mode.  Will also call the debugLogFnc method set in the config.\n   *\n   * @param {object} obj A list of JavaScript objects to output. The string representations of each of these objects\n   * are appended together in the order listed and output.\n   */\n  debugLog(...obj: any[]): void {\n    const {debugLogFnc, debugLevel} = this.options;\n\n    if(debugLevel) {\n      console.log(...obj);\n    }\n\n    if(debugLogFnc) {\n      debugLogFnc(debugLevel as number, ...obj);\n    }\n  }\n\n  /**\n   * Enables the console debugger.\n   *\n   * @param {number} level Enable or disable the debugger. Uses the constants:\n   *   LoggerDebugLevel.DISABLED (0) - Disable.\n   *   LoggerDebugLevel.LOGS (1) - Enable console logs.\n   *   LoggerDebugLevel.DISPATCH (2) - Enable console logs and dispatch action data (default).\n   */\n  enableDebugger(level: LoggerDebugLevelType = LoggerDebugLevel.DISPATCH): void {\n    this.options = {...this.options, debugLevel: level};\n  }\n\n  /**\n   * Get the current FluxLogger options.\n   *\n   * @returns {LoggerOptions} the FluxLogger options object.\n   */\n  getOptions(): LoggerOptions {\n    return this.options;\n  }\n\n  preDispatch(action: FluxAction, store): Promise<FluxAction> {\n    this.previousStore = store;\n    return Promise.resolve(action);\n  }\n\n  postDispatch(action: FluxAction, store: object): Promise<FluxAction> {\n    const {debugLevel} = this.options;\n\n    if(debugLevel && debugLevel > LoggerDebugLevel.LOGS) {\n      const {type} = action;\n      const hasChanged = !isEqual(store, this.previousStore);\n      const updatedLabel = hasChanged ? 'Changed State' : 'Unchanged State';\n      const updatedColor = hasChanged ? '#00d484' : '#959595';\n      const updatedStore = cloneDeep(store);\n\n      if(console.groupCollapsed) {\n        console.groupCollapsed(`FLUX DISPATCH: ${type}`);\n        console.log('%c Action: ', 'color: #00C4FF', action);\n        console.log('%c Last State: ', 'color: #959595', this.previousStore);\n        console.log(`%c ${updatedLabel}: `, `color: ${updatedColor}`, updatedStore);\n        console.groupEnd();\n      } else {\n        console.log(`FLUX DISPATCH: ${type}`);\n        console.log('Action: ', action);\n        console.log('Last State: ', this.previousStore);\n        console.log(`${updatedLabel}: `, updatedStore);\n      }\n    }\n\n    return Promise.resolve(action);\n  }\n}\n"],"names":["cloneDeep","isEqual","LoggerDebugLevel","DISABLED","LOGS","DISPATCH","Logger","config","options","defaultOptions","debugError","obj","debugErrorFnc","debugLevel","console","error","debugInfo","debugInfoFnc","info","debugLog","debugLogFnc","log","enableDebugger","level","getOptions","preDispatch","action","store","previousStore","Promise","resolve","postDispatch","type","hasChanged","updatedLabel","updatedColor","updatedStore","groupCollapsed","groupEnd","name","bind"],"mappings":"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"}