@nlabs/arkhamjs-middleware-logger
Version:
Add console logging for ArkhamJS
145 lines (144 loc) • 17 kB
JavaScript
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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"}