@nlabs/arkhamjs-middleware-logger 3.20.5 → 3.23.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,84 +1,62 @@
1
- "use strict";
2
-
3
- require("core-js/modules/es.object.keys.js");
4
-
5
- require("core-js/modules/es.symbol.js");
6
-
7
- require("core-js/modules/es.array.filter.js");
8
-
9
- require("core-js/modules/es.object.get-own-property-descriptor.js");
10
-
11
- require("core-js/modules/es.array.for-each.js");
12
-
13
- require("core-js/modules/web.dom-collections.for-each.js");
14
-
15
- require("core-js/modules/es.object.get-own-property-descriptors.js");
16
-
17
- require("core-js/modules/es.object.define-properties.js");
18
-
19
- Object.defineProperty(exports, "__esModule", {
20
- value: true
1
+ var __create = Object.create;
2
+ var __defProp = Object.defineProperty;
3
+ var __defProps = Object.defineProperties;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
6
+ var __getOwnPropNames = Object.getOwnPropertyNames;
7
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
8
+ var __getProtoOf = Object.getPrototypeOf;
9
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
10
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
11
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
12
+ var __spreadValues = (a, b) => {
13
+ for (var prop in b || (b = {}))
14
+ if (__hasOwnProp.call(b, prop))
15
+ __defNormalProp(a, prop, b[prop]);
16
+ if (__getOwnPropSymbols)
17
+ for (var prop of __getOwnPropSymbols(b)) {
18
+ if (__propIsEnum.call(b, prop))
19
+ __defNormalProp(a, prop, b[prop]);
20
+ }
21
+ return a;
22
+ };
23
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
24
+ var __markAsModule = (target) => __defProp(target, "__esModule", { value: true });
25
+ var __export = (target, all) => {
26
+ for (var name in all)
27
+ __defProp(target, name, { get: all[name], enumerable: true });
28
+ };
29
+ var __reExport = (target, module2, copyDefault, desc) => {
30
+ if (module2 && typeof module2 === "object" || typeof module2 === "function") {
31
+ for (let key of __getOwnPropNames(module2))
32
+ if (!__hasOwnProp.call(target, key) && (copyDefault || key !== "default"))
33
+ __defProp(target, key, { get: () => module2[key], enumerable: !(desc = __getOwnPropDesc(module2, key)) || desc.enumerable });
34
+ }
35
+ return target;
36
+ };
37
+ var __toESM = (module2, isNodeMode) => {
38
+ return __reExport(__markAsModule(__defProp(module2 != null ? __create(__getProtoOf(module2)) : {}, "default", !isNodeMode && module2 && module2.__esModule ? { get: () => module2.default, enumerable: true } : { value: module2, enumerable: true })), module2);
39
+ };
40
+ var __toCommonJS = /* @__PURE__ */ ((cache) => {
41
+ return (module2, temp) => {
42
+ return cache && cache.get(module2) || (temp = __reExport(__markAsModule({}), module2, 1), cache && cache.set(module2, temp), temp);
43
+ };
44
+ })(typeof WeakMap !== "undefined" ? /* @__PURE__ */ new WeakMap() : 0);
45
+ var Logger_exports = {};
46
+ __export(Logger_exports, {
47
+ Logger: () => Logger
21
48
  });
22
- exports.Logger = void 0;
23
-
24
- require("core-js/modules/es.function.bind.js");
25
-
26
- require("core-js/modules/es.array.concat.js");
27
-
28
- require("core-js/modules/es.promise.js");
29
-
30
- require("core-js/modules/es.object.to-string.js");
31
-
32
- require("core-js/modules/es.object.define-property.js");
33
-
34
- var _cloneDeep = _interopRequireDefault(require("lodash/cloneDeep"));
35
-
36
- var _isEqual = _interopRequireDefault(require("lodash/isEqual"));
37
-
38
- var _main = require("../types/main");
39
-
40
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
41
-
42
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
43
-
44
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
45
-
46
- function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
47
-
48
- function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
49
-
50
- function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
51
-
52
- function _defineProperty(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; }
53
-
54
- /**
55
- * FluxLogger
56
- * @type {EventEmitter}
57
- */
58
- var Logger = /*#__PURE__*/function () {
59
- // Public properties
60
- // Private properties
61
-
62
- /**
63
- * Create a new instance of the FluxLogger.
64
- *
65
- * @constructor
66
- * @this {FluxLogger}
67
- */
68
- function Logger(options) {
69
- _classCallCheck(this, Logger);
70
-
71
- _defineProperty(this, "name", 'Logger');
72
-
73
- _defineProperty(this, "previousStore", {});
74
-
75
- _defineProperty(this, "defaultOptions", {
76
- debugLevel: _main.LoggerDebugLevel.DISABLED
77
- });
78
-
79
- _defineProperty(this, "options", this.defaultOptions);
80
-
81
- // Methods
49
+ var import_cloneDeep = __toESM(require("lodash/cloneDeep"));
50
+ var import_isEqual = __toESM(require("lodash/isEqual"));
51
+ var import_main = require("../types/main");
52
+ class Logger {
53
+ constructor(options) {
54
+ this.name = "Logger";
55
+ this.previousStore = {};
56
+ this.defaultOptions = {
57
+ debugLevel: import_main.LoggerDebugLevel.DISABLED
58
+ };
59
+ this.options = this.defaultOptions;
82
60
  this.config = this.config.bind(this);
83
61
  this.debugError = this.debugError.bind(this);
84
62
  this.debugInfo = this.debugInfo.bind(this);
@@ -86,172 +64,76 @@ var Logger = /*#__PURE__*/function () {
86
64
  this.enableDebugger = this.enableDebugger.bind(this);
87
65
  this.getOptions = this.getOptions.bind(this);
88
66
  this.postDispatch = this.postDispatch.bind(this);
89
- this.preDispatch = this.preDispatch.bind(this); // Configuration
90
-
67
+ this.preDispatch = this.preDispatch.bind(this);
91
68
  this.config(options);
92
69
  }
93
- /**
94
- * Set configuration options.
95
- *
96
- * @param {object} options Configuration options.
97
- */
98
-
99
-
100
- _createClass(Logger, [{
101
- key: "config",
102
- value: function config(options) {
103
- this.options = _objectSpread(_objectSpread({}, this.defaultOptions), options);
104
- }
105
- /**
106
- * Logs errors in the console. Will also call the debugErrorFnc method set in the config.
107
- *
108
- * @param {object} obj A list of JavaScript objects to output. The string representations of each of these objects
109
- * are appended together in the order listed and output.
110
- */
111
-
112
- }, {
113
- key: "debugError",
114
- value: function debugError() {
115
- var _this$options = this.options,
116
- debugErrorFnc = _this$options.debugErrorFnc,
117
- debugLevel = _this$options.debugLevel;
118
-
119
- for (var _len = arguments.length, obj = new Array(_len), _key = 0; _key < _len; _key++) {
120
- obj[_key] = arguments[_key];
121
- }
122
-
123
- if (debugLevel) {
124
- var _console;
125
-
126
- (_console = console).error.apply(_console, obj);
127
- }
128
-
129
- if (debugErrorFnc) {
130
- debugErrorFnc.apply(void 0, [debugLevel].concat(obj));
131
- }
70
+ config(options) {
71
+ this.options = __spreadValues(__spreadValues({}, this.defaultOptions), options);
72
+ }
73
+ debugError(...obj) {
74
+ const { debugErrorFnc, debugLevel } = this.options;
75
+ if (debugLevel) {
76
+ console.error(...obj);
132
77
  }
133
- /**
134
- * Logs informational messages to the console. Will also call the debugInfoFnc method set in the config.
135
- *
136
- * @param {object} obj A list of JavaScript objects to output. The string representations of each of these objects
137
- * are appended together in the order listed and output.
138
- */
139
-
140
- }, {
141
- key: "debugInfo",
142
- value: function debugInfo() {
143
- var _this$options2 = this.options,
144
- debugInfoFnc = _this$options2.debugInfoFnc,
145
- debugLevel = _this$options2.debugLevel;
146
-
147
- for (var _len2 = arguments.length, obj = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
148
- obj[_key2] = arguments[_key2];
149
- }
150
-
151
- if (debugLevel) {
152
- var _console2;
153
-
154
- (_console2 = console).info.apply(_console2, obj);
155
- }
156
-
157
- if (debugInfoFnc) {
158
- debugInfoFnc.apply(void 0, [debugLevel].concat(obj));
159
- }
78
+ if (debugErrorFnc) {
79
+ debugErrorFnc(debugLevel, ...obj);
160
80
  }
161
- /**
162
- * Logs data in the console. Only logs when in debug mode. Will also call the debugLogFnc method set in the config.
163
- *
164
- * @param {object} obj A list of JavaScript objects to output. The string representations of each of these objects
165
- * are appended together in the order listed and output.
166
- */
167
-
168
- }, {
169
- key: "debugLog",
170
- value: function debugLog() {
171
- var _this$options3 = this.options,
172
- debugLogFnc = _this$options3.debugLogFnc,
173
- debugLevel = _this$options3.debugLevel;
174
-
175
- for (var _len3 = arguments.length, obj = new Array(_len3), _key3 = 0; _key3 < _len3; _key3++) {
176
- obj[_key3] = arguments[_key3];
177
- }
178
-
179
- if (debugLevel) {
180
- var _console3;
181
-
182
- (_console3 = console).log.apply(_console3, obj);
183
- }
184
-
185
- if (debugLogFnc) {
186
- debugLogFnc.apply(void 0, [debugLevel].concat(obj));
187
- }
81
+ }
82
+ debugInfo(...obj) {
83
+ const { debugInfoFnc, debugLevel } = this.options;
84
+ if (debugLevel) {
85
+ console.info(...obj);
188
86
  }
189
- /**
190
- * Enables the console debugger.
191
- *
192
- * @param {number} level Enable or disable the debugger. Uses the constants:
193
- * LoggerDebugLevel.DISABLED (0) - Disable.
194
- * LoggerDebugLevel.LOGS (1) - Enable console logs.
195
- * LoggerDebugLevel.DISPATCH (2) - Enable console logs and dispatch action data (default).
196
- */
197
-
198
- }, {
199
- key: "enableDebugger",
200
- value: function enableDebugger() {
201
- var level = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : _main.LoggerDebugLevel.DISPATCH;
202
- this.options = _objectSpread(_objectSpread({}, this.options), {}, {
203
- debugLevel: level
204
- });
87
+ if (debugInfoFnc) {
88
+ debugInfoFnc(debugLevel, ...obj);
205
89
  }
206
- /**
207
- * Get the current FluxLogger options.
208
- *
209
- * @returns {LoggerOptions} the FluxLogger options object.
210
- */
211
-
212
- }, {
213
- key: "getOptions",
214
- value: function getOptions() {
215
- return this.options;
90
+ }
91
+ debugLog(...obj) {
92
+ const { debugLogFnc, debugLevel } = this.options;
93
+ if (debugLevel) {
94
+ console.log(...obj);
216
95
  }
217
- }, {
218
- key: "preDispatch",
219
- value: function preDispatch(action, store) {
220
- this.previousStore = store;
221
- return Promise.resolve(action);
96
+ if (debugLogFnc) {
97
+ debugLogFnc(debugLevel, ...obj);
222
98
  }
223
- }, {
224
- key: "postDispatch",
225
- value: function postDispatch(action, store) {
226
- var debugLevel = this.options.debugLevel;
227
-
228
- if (debugLevel > _main.LoggerDebugLevel.LOGS) {
229
- var type = action.type;
230
- var hasChanged = !(0, _isEqual["default"])(store, this.previousStore);
231
- var updatedLabel = hasChanged ? 'Changed State' : 'Unchanged State';
232
- var updatedColor = hasChanged ? '#00d484' : '#959595';
233
- var updatedStore = (0, _cloneDeep["default"])(store);
234
-
235
- if (console.groupCollapsed) {
236
- console.groupCollapsed("FLUX DISPATCH: ".concat(type));
237
- console.log('%c Action: ', 'color: #00C4FF', action);
238
- console.log('%c Last State: ', 'color: #959595', this.previousStore);
239
- console.log("%c ".concat(updatedLabel, ": "), "color: ".concat(updatedColor), updatedStore);
240
- console.groupEnd();
241
- } else {
242
- console.log("FLUX DISPATCH: ".concat(type));
243
- console.log('Action: ', action);
244
- console.log('Last State: ', this.previousStore);
245
- console.log("".concat(updatedLabel, ": "), updatedStore);
246
- }
99
+ }
100
+ enableDebugger(level = import_main.LoggerDebugLevel.DISPATCH) {
101
+ this.options = __spreadProps(__spreadValues({}, this.options), { debugLevel: level });
102
+ }
103
+ getOptions() {
104
+ return this.options;
105
+ }
106
+ preDispatch(action, store) {
107
+ this.previousStore = store;
108
+ return Promise.resolve(action);
109
+ }
110
+ postDispatch(action, store) {
111
+ const { debugLevel } = this.options;
112
+ if (debugLevel > import_main.LoggerDebugLevel.LOGS) {
113
+ const { type } = action;
114
+ const hasChanged = !(0, import_isEqual.default)(store, this.previousStore);
115
+ const updatedLabel = hasChanged ? "Changed State" : "Unchanged State";
116
+ const updatedColor = hasChanged ? "#00d484" : "#959595";
117
+ const updatedStore = (0, import_cloneDeep.default)(store);
118
+ if (console.groupCollapsed) {
119
+ console.groupCollapsed(`FLUX DISPATCH: ${type}`);
120
+ console.log("%c Action: ", "color: #00C4FF", action);
121
+ console.log("%c Last State: ", "color: #959595", this.previousStore);
122
+ console.log(`%c ${updatedLabel}: `, `color: ${updatedColor}`, updatedStore);
123
+ console.groupEnd();
124
+ } else {
125
+ console.log(`FLUX DISPATCH: ${type}`);
126
+ console.log("Action: ", action);
127
+ console.log("Last State: ", this.previousStore);
128
+ console.log(`${updatedLabel}: `, updatedStore);
247
129
  }
248
-
249
- return Promise.resolve(action);
250
130
  }
251
- }]);
252
-
253
- return Logger;
254
- }();
255
-
256
- exports.Logger = Logger;
257
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Logger/Logger.ts"],"names":["Logger","options","debugLevel","LoggerDebugLevel","DISABLED","defaultOptions","config","bind","debugError","debugInfo","debugLog","enableDebugger","getOptions","postDispatch","preDispatch","debugErrorFnc","obj","console","error","debugInfoFnc","info","debugLogFnc","log","level","DISPATCH","action","store","previousStore","Promise","resolve","LOGS","type","hasChanged","updatedLabel","updatedColor","updatedStore","groupCollapsed","groupEnd"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAMA;;AACA;;AAEA;;;;;;;;;;;;;;;;AAEA;AACA;AACA;AACA;IACaA,M;AACX;AAGA;;AAOA;AACF;AACA;AACA;AACA;AACA;AACE,kBAAYC,OAAZ,EAAoC;AAAA;;AAAA,kCAfrB,QAeqB;;AAAA,2CAZP,EAYO;;AAAA,4CAXI;AACtCC,MAAAA,UAAU,EAAEC,uBAAiBC;AADS,KAWJ;;AAAA,qCARH,KAAKC,cAQF;;AAClC;AACA,SAAKC,MAAL,GAAc,KAAKA,MAAL,CAAYC,IAAZ,CAAiB,IAAjB,CAAd;AACA,SAAKC,UAAL,GAAkB,KAAKA,UAAL,CAAgBD,IAAhB,CAAqB,IAArB,CAAlB;AACA,SAAKE,SAAL,GAAiB,KAAKA,SAAL,CAAeF,IAAf,CAAoB,IAApB,CAAjB;AACA,SAAKG,QAAL,GAAgB,KAAKA,QAAL,CAAcH,IAAd,CAAmB,IAAnB,CAAhB;AACA,SAAKI,cAAL,GAAsB,KAAKA,cAAL,CAAoBJ,IAApB,CAAyB,IAAzB,CAAtB;AACA,SAAKK,UAAL,GAAkB,KAAKA,UAAL,CAAgBL,IAAhB,CAAqB,IAArB,CAAlB;AACA,SAAKM,YAAL,GAAoB,KAAKA,YAAL,CAAkBN,IAAlB,CAAuB,IAAvB,CAApB;AACA,SAAKO,WAAL,GAAmB,KAAKA,WAAL,CAAiBP,IAAjB,CAAsB,IAAtB,CAAnB,CATkC,CAWlC;;AACA,SAAKD,MAAL,CAAYL,OAAZ;AACD;AAED;AACF;AACA;AACA;AACA;;;;;WACE,gBAAOA,OAAP,EAAqC;AACnC,WAAKA,OAAL,mCAAmB,KAAKI,cAAxB,GAA2CJ,OAA3C;AACD;AAED;AACF;AACA;AACA;AACA;AACA;;;;WACE,sBAAyB;AAAA,0BACa,KAAKA,OADlB;AAAA,UAChBc,aADgB,iBAChBA,aADgB;AAAA,UACDb,UADC,iBACDA,UADC;;AAAA,wCAAXc,GAAW;AAAXA,QAAAA,GAAW;AAAA;;AAGvB,UAAGd,UAAH,EAAe;AAAA;;AACb,oBAAAe,OAAO,EAACC,KAAR,iBAAiBF,GAAjB;AACD;;AAED,UAAGD,aAAH,EAAkB;AAChBA,QAAAA,aAAa,MAAb,UAAcb,UAAd,SAA6Bc,GAA7B;AACD;AACF;AAED;AACF;AACA;AACA;AACA;AACA;;;;WACE,qBAAwB;AAAA,2BACa,KAAKf,OADlB;AAAA,UACfkB,YADe,kBACfA,YADe;AAAA,UACDjB,UADC,kBACDA,UADC;;AAAA,yCAAXc,GAAW;AAAXA,QAAAA,GAAW;AAAA;;AAGtB,UAAGd,UAAH,EAAe;AAAA;;AACb,qBAAAe,OAAO,EAACG,IAAR,kBAAgBJ,GAAhB;AACD;;AAED,UAAGG,YAAH,EAAiB;AACfA,QAAAA,YAAY,MAAZ,UAAajB,UAAb,SAA4Bc,GAA5B;AACD;AACF;AAED;AACF;AACA;AACA;AACA;AACA;;;;WACE,oBAAuB;AAAA,2BACa,KAAKf,OADlB;AAAA,UACdoB,WADc,kBACdA,WADc;AAAA,UACDnB,UADC,kBACDA,UADC;;AAAA,yCAAXc,GAAW;AAAXA,QAAAA,GAAW;AAAA;;AAGrB,UAAGd,UAAH,EAAe;AAAA;;AACb,qBAAAe,OAAO,EAACK,GAAR,kBAAeN,GAAf;AACD;;AAED,UAAGK,WAAH,EAAgB;AACdA,QAAAA,WAAW,MAAX,UAAYnB,UAAZ,SAA2Bc,GAA3B;AACD;AACF;AAED;AACF;AACA;AACA;AACA;AACA;AACA;AACA;;;;WACE,0BAAgE;AAAA,UAAjDO,KAAiD,uEAAjCpB,uBAAiBqB,QAAgB;AAC9D,WAAKvB,OAAL,mCAAmB,KAAKA,OAAxB;AAAiCC,QAAAA,UAAU,EAAEqB;AAA7C;AACD;AAED;AACF;AACA;AACA;AACA;;;;WACE,sBAA4B;AAC1B,aAAO,KAAKtB,OAAZ;AACD;;;WAED,qBAAYwB,MAAZ,EAAgCC,KAAhC,EAA4D;AAC1D,WAAKC,aAAL,GAAqBD,KAArB;AACA,aAAOE,OAAO,CAACC,OAAR,CAAgBJ,MAAhB,CAAP;AACD;;;WAED,sBAAaA,MAAb,EAAiCC,KAAjC,EAAqE;AAAA,UAC5DxB,UAD4D,GAC9C,KAAKD,OADyC,CAC5DC,UAD4D;;AAGnE,UAAGA,UAAU,GAAGC,uBAAiB2B,IAAjC,EAAuC;AAAA,YAC9BC,IAD8B,GACtBN,MADsB,CAC9BM,IAD8B;AAErC,YAAMC,UAAU,GAAG,CAAC,yBAAQN,KAAR,EAAe,KAAKC,aAApB,CAApB;AACA,YAAMM,YAAY,GAAGD,UAAU,GAAG,eAAH,GAAqB,iBAApD;AACA,YAAME,YAAY,GAAGF,UAAU,GAAG,SAAH,GAAe,SAA9C;AACA,YAAMG,YAAY,GAAG,2BAAUT,KAAV,CAArB;;AAEA,YAAGT,OAAO,CAACmB,cAAX,EAA2B;AACzBnB,UAAAA,OAAO,CAACmB,cAAR,0BAAyCL,IAAzC;AACAd,UAAAA,OAAO,CAACK,GAAR,CAAY,aAAZ,EAA2B,gBAA3B,EAA6CG,MAA7C;AACAR,UAAAA,OAAO,CAACK,GAAR,CAAY,iBAAZ,EAA+B,gBAA/B,EAAiD,KAAKK,aAAtD;AACAV,UAAAA,OAAO,CAACK,GAAR,cAAkBW,YAAlB,0BAA8CC,YAA9C,GAA8DC,YAA9D;AACAlB,UAAAA,OAAO,CAACoB,QAAR;AACD,SAND,MAMO;AACLpB,UAAAA,OAAO,CAACK,GAAR,0BAA8BS,IAA9B;AACAd,UAAAA,OAAO,CAACK,GAAR,CAAY,UAAZ,EAAwBG,MAAxB;AACAR,UAAAA,OAAO,CAACK,GAAR,CAAY,cAAZ,EAA4B,KAAKK,aAAjC;AACAV,UAAAA,OAAO,CAACK,GAAR,WAAeW,YAAf,SAAiCE,YAAjC;AACD;AACF;;AAED,aAAOP,OAAO,CAACC,OAAR,CAAgBJ,MAAhB,CAAP;AACD","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\nimport {FluxAction} from '@nlabs/arkhamjs';\nimport cloneDeep from 'lodash/cloneDeep';\nimport isEqual from 'lodash/isEqual';\n\nimport {LoggerDebugLevel, LoggerOptions} from '../types/main';\n\n/**\n * FluxLogger\n * @type {EventEmitter}\n */\nexport class Logger {\n  // Public properties\n  name: string = 'Logger';\n\n  // Private properties\n  private previousStore: any = {};\n  private defaultOptions: LoggerOptions = {\n    debugLevel: LoggerDebugLevel.DISABLED\n  };\n  private options: LoggerOptions = this.defaultOptions;\n\n  /**\n   * Create a new instance of the FluxLogger.\n   *\n   * @constructor\n   * @this {FluxLogger}\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): void {\n    const {debugErrorFnc, debugLevel} = this.options;\n\n    if(debugLevel) {\n      console.error(...obj);\n    }\n\n    if(debugErrorFnc) {\n      debugErrorFnc(debugLevel, ...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): void {\n    const {debugInfoFnc, debugLevel} = this.options;\n\n    if(debugLevel) {\n      console.info(...obj);\n    }\n\n    if(debugInfoFnc) {\n      debugInfoFnc(debugLevel, ...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): void {\n    const {debugLogFnc, debugLevel} = this.options;\n\n    if(debugLevel) {\n      console.log(...obj);\n    }\n\n    if(debugLogFnc) {\n      debugLogFnc(debugLevel, ...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: number = 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 > 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"]}
131
+ return Promise.resolve(action);
132
+ }
133
+ }
134
+ module.exports = __toCommonJS(Logger_exports);
135
+ // Annotate the CommonJS export names for ESM import in node:
136
+ 0 && (module.exports = {
137
+ Logger
138
+ });
139
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../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\nimport {FluxAction} from '@nlabs/arkhamjs';\nimport cloneDeep from 'lodash/cloneDeep';\nimport isEqual from 'lodash/isEqual';\n\nimport {LoggerDebugLevel, LoggerOptions} from '../types/main';\n\n/**\n * FluxLogger\n * @type {EventEmitter}\n */\nexport class Logger {\n  // Public properties\n  name: string = 'Logger';\n\n  // Private properties\n  private previousStore: any = {};\n  private defaultOptions: LoggerOptions = {\n    debugLevel: LoggerDebugLevel.DISABLED\n  };\n  private options: LoggerOptions = this.defaultOptions;\n\n  /**\n   * Create a new instance of the FluxLogger.\n   *\n   * @constructor\n   * @this {FluxLogger}\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): void {\n    const {debugErrorFnc, debugLevel} = this.options;\n\n    if(debugLevel) {\n      console.error(...obj);\n    }\n\n    if(debugErrorFnc) {\n      debugErrorFnc(debugLevel, ...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): void {\n    const {debugInfoFnc, debugLevel} = this.options;\n\n    if(debugLevel) {\n      console.info(...obj);\n    }\n\n    if(debugInfoFnc) {\n      debugInfoFnc(debugLevel, ...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): void {\n    const {debugLogFnc, debugLevel} = this.options;\n\n    if(debugLevel) {\n      console.log(...obj);\n    }\n\n    if(debugLogFnc) {\n      debugLogFnc(debugLevel, ...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: number = 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 > 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"],
  "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAMA,uBAAsB;AACtB,qBAAoB;AAEpB,kBAA8C;AAMvC,aAAa;AAAA,EAiBlB,YAAY,SAAwB;AAfpC,gBAAe;AAGP,yBAAqB;AACrB,0BAAgC;AAAA,MACtC,YAAY,6BAAiB;AAAA;AAEvB,mBAAyB,KAAK;AAUpC,SAAK,SAAS,KAAK,OAAO,KAAK;AAC/B,SAAK,aAAa,KAAK,WAAW,KAAK;AACvC,SAAK,YAAY,KAAK,UAAU,KAAK;AACrC,SAAK,WAAW,KAAK,SAAS,KAAK;AACnC,SAAK,iBAAiB,KAAK,eAAe,KAAK;AAC/C,SAAK,aAAa,KAAK,WAAW,KAAK;AACvC,SAAK,eAAe,KAAK,aAAa,KAAK;AAC3C,SAAK,cAAc,KAAK,YAAY,KAAK;AAGzC,SAAK,OAAO;AAAA;AAAA,EAQd,OAAO,SAA8B;AACnC,SAAK,UAAU,kCAAI,KAAK,iBAAmB;AAAA;AAAA,EAS7C,cAAc,KAAW;AACvB,UAAM,EAAC,eAAe,eAAc,KAAK;AAEzC,QAAG,YAAY;AACb,cAAQ,MAAM,GAAG;AAAA;AAGnB,QAAG,eAAe;AAChB,oBAAc,YAAY,GAAG;AAAA;AAAA;AAAA,EAUjC,aAAa,KAAW;AACtB,UAAM,EAAC,cAAc,eAAc,KAAK;AAExC,QAAG,YAAY;AACb,cAAQ,KAAK,GAAG;AAAA;AAGlB,QAAG,cAAc;AACf,mBAAa,YAAY,GAAG;AAAA;AAAA;AAAA,EAUhC,YAAY,KAAW;AACrB,UAAM,EAAC,aAAa,eAAc,KAAK;AAEvC,QAAG,YAAY;AACb,cAAQ,IAAI,GAAG;AAAA;AAGjB,QAAG,aAAa;AACd,kBAAY,YAAY,GAAG;AAAA;AAAA;AAAA,EAY/B,eAAe,QAAgB,6BAAiB,UAAgB;AAC9D,SAAK,UAAU,iCAAI,KAAK,UAAT,EAAkB,YAAY;AAAA;AAAA,EAQ/C,aAA4B;AAC1B,WAAO,KAAK;AAAA;AAAA,EAGd,YAAY,QAAoB,OAA4B;AAC1D,SAAK,gBAAgB;AACrB,WAAO,QAAQ,QAAQ;AAAA;AAAA,EAGzB,aAAa,QAAoB,OAAoC;AACnE,UAAM,EAAC,eAAc,KAAK;AAE1B,QAAG,aAAa,6BAAiB,MAAM;AACrC,YAAM,EAAC,SAAQ;AACf,YAAM,aAAa,CAAC,4BAAQ,OAAO,KAAK;AACxC,YAAM,eAAe,aAAa,kBAAkB;AACpD,YAAM,eAAe,aAAa,YAAY;AAC9C,YAAM,eAAe,8BAAU;AAE/B,UAAG,QAAQ,gBAAgB;AACzB,gBAAQ,eAAe,kBAAkB;AACzC,gBAAQ,IAAI,eAAe,kBAAkB;AAC7C,gBAAQ,IAAI,mBAAmB,kBAAkB,KAAK;AACtD,gBAAQ,IAAI,MAAM,kBAAkB,UAAU,gBAAgB;AAC9D,gBAAQ;AAAA,aACH;AACL,gBAAQ,IAAI,kBAAkB;AAC9B,gBAAQ,IAAI,YAAY;AACxB,gBAAQ,IAAI,gBAAgB,KAAK;AACjC,gBAAQ,IAAI,GAAG,kBAAkB;AAAA;AAAA;AAIrC,WAAO,QAAQ,QAAQ;AAAA;AAAA;",
  "names": []
}

@@ -0,0 +1,140 @@
1
+ var __create = Object.create;
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __getProtoOf = Object.getPrototypeOf;
6
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
7
+ var __markAsModule = (target) => __defProp(target, "__esModule", { value: true });
8
+ var __reExport = (target, module2, copyDefault, desc) => {
9
+ if (module2 && typeof module2 === "object" || typeof module2 === "function") {
10
+ for (let key of __getOwnPropNames(module2))
11
+ if (!__hasOwnProp.call(target, key) && (copyDefault || key !== "default"))
12
+ __defProp(target, key, { get: () => module2[key], enumerable: !(desc = __getOwnPropDesc(module2, key)) || desc.enumerable });
13
+ }
14
+ return target;
15
+ };
16
+ var __toESM = (module2, isNodeMode) => {
17
+ return __reExport(__markAsModule(__defProp(module2 != null ? __create(__getProtoOf(module2)) : {}, "default", !isNodeMode && module2 && module2.__esModule ? { get: () => module2.default, enumerable: true } : { value: module2, enumerable: true })), module2);
18
+ };
19
+ var import_arkhamjs = require("@nlabs/arkhamjs");
20
+ var import_set = __toESM(require("lodash/set"));
21
+ var import_main = require("../types/main");
22
+ var import_Logger = require("./Logger");
23
+ const test = (type, data, state = { hello: "world" }) => {
24
+ switch (type) {
25
+ case "TEST_EVENT":
26
+ return (0, import_set.default)(state, "testAction", data.testVar);
27
+ default:
28
+ return state;
29
+ }
30
+ };
31
+ describe("Logger", () => {
32
+ const cfg = { debugLevel: import_main.LoggerDebugLevel.DISPATCH };
33
+ const logger = new import_Logger.Logger(cfg);
34
+ const testAction = { hello: "world", type: "TEST_EVENT" };
35
+ beforeAll(async () => {
36
+ await import_arkhamjs.Flux.init({
37
+ stores: [test]
38
+ });
39
+ });
40
+ describe("#config", () => {
41
+ const opts = {
42
+ debugLevel: 0
43
+ };
44
+ beforeAll(() => {
45
+ logger.config(opts);
46
+ });
47
+ afterAll(() => {
48
+ logger.config(cfg);
49
+ });
50
+ it("should set debugLevel", () => {
51
+ const privateProperty = "options";
52
+ expect(logger[privateProperty].debugLevel).toEqual(opts.debugLevel);
53
+ });
54
+ });
55
+ describe("#debugError", () => {
56
+ let consoleSpy;
57
+ const msg = "test";
58
+ beforeAll(() => {
59
+ consoleSpy = jest.spyOn(console, "error");
60
+ logger.debugError(msg);
61
+ });
62
+ afterAll(() => {
63
+ consoleSpy.mockRestore();
64
+ });
65
+ it("should send data to console.error", () => {
66
+ expect(consoleSpy.mock.calls[0][0]).toEqual(msg);
67
+ });
68
+ });
69
+ describe("#debugInfo", () => {
70
+ let consoleSpy;
71
+ const msg = "test";
72
+ beforeAll(() => {
73
+ consoleSpy = jest.spyOn(console, "info");
74
+ logger.debugInfo(msg);
75
+ });
76
+ afterAll(() => {
77
+ consoleSpy.mockRestore();
78
+ });
79
+ it("should send data to console.info", () => {
80
+ expect(consoleSpy.mock.calls[0][0]).toEqual(msg);
81
+ });
82
+ });
83
+ describe("#debugLog", () => {
84
+ let consoleSpy;
85
+ const msg = "test";
86
+ beforeAll(() => {
87
+ consoleSpy = jest.spyOn(console, "log");
88
+ logger.debugLog(msg);
89
+ });
90
+ afterAll(() => {
91
+ consoleSpy.mockRestore();
92
+ });
93
+ it("should send data to console.log", () => {
94
+ expect(consoleSpy.mock.calls[0][0]).toEqual(msg);
95
+ });
96
+ });
97
+ describe("#enableDebugger", () => {
98
+ it("should disable debugger", () => {
99
+ logger.enableDebugger(import_main.LoggerDebugLevel.DISABLED);
100
+ const options = logger.getOptions();
101
+ expect(options.debugLevel).toEqual(0);
102
+ });
103
+ it("should enable debugger for logs", () => {
104
+ logger.enableDebugger(import_main.LoggerDebugLevel.LOGS);
105
+ const options = logger.getOptions();
106
+ expect(options.debugLevel).toEqual(1);
107
+ });
108
+ it("should enable debugger for dispatch actions", () => {
109
+ logger.enableDebugger(import_main.LoggerDebugLevel.DISPATCH);
110
+ const options = logger.getOptions();
111
+ expect(options.debugLevel).toEqual(2);
112
+ });
113
+ });
114
+ describe("#preDispatch", () => {
115
+ it("should update the previous store", () => {
116
+ const testStore = { test: "test" };
117
+ const privateProperty = "previousStore";
118
+ logger.preDispatch(testAction, testStore);
119
+ expect(JSON.stringify(logger[privateProperty])).toEqual(JSON.stringify(testStore));
120
+ });
121
+ });
122
+ describe("#postDispatch", () => {
123
+ let consoleSpy;
124
+ const prevStore = { test: "previous" };
125
+ const nextStore = { test: "next" };
126
+ beforeEach(() => {
127
+ consoleSpy = jest.spyOn(console, "log");
128
+ });
129
+ afterEach(() => {
130
+ consoleSpy.mockRestore();
131
+ });
132
+ it("should dispatch logs for a changed state", () => {
133
+ logger.preDispatch(testAction, prevStore);
134
+ logger.postDispatch(testAction, nextStore);
135
+ expect(consoleSpy.mock.calls[2][0]).toEqual("%c Changed State: ");
136
+ expect(consoleSpy.mock.calls[2][2]).toEqual(nextStore);
137
+ });
138
+ });
139
+ });
140
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/Logger/Logger.test.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 */\nimport {Flux, FluxAction} from '@nlabs/arkhamjs';\nimport set from 'lodash/set';\n\nimport {LoggerDebugLevel, LoggerOptions} from '../types/main';\nimport {Logger} from './Logger';\n\nconst test = (type: string, data, state = {hello: 'world'}) => {\n  switch(type) {\n    case 'TEST_EVENT':\n      return set(state, 'testAction', data.testVar);\n    default:\n      return state;\n  }\n};\n\ndescribe('Logger', () => {\n  const cfg: LoggerOptions = {debugLevel: LoggerDebugLevel.DISPATCH};\n  const logger: Logger = new Logger(cfg);\n  const testAction: FluxAction = {hello: 'world', type: 'TEST_EVENT'};\n\n  beforeAll(async () => {\n    await Flux.init({\n      stores: [test]\n    });\n  });\n\n  describe('#config', () => {\n    // Vars\n    const opts: LoggerOptions = {\n      debugLevel: 0\n    };\n\n    beforeAll(() => {\n      // Method\n      logger.config(opts);\n    });\n\n    afterAll(() => {\n      logger.config(cfg);\n    });\n\n    it('should set debugLevel', () => {\n      const privateProperty: string = 'options';\n      expect(logger[privateProperty].debugLevel).toEqual(opts.debugLevel);\n    });\n  });\n\n  describe('#debugError', () => {\n    let consoleSpy;\n    const msg: string = 'test';\n\n    beforeAll(() => {\n      // Spy\n      consoleSpy = jest.spyOn(console, 'error');\n\n      // Method\n      logger.debugError(msg);\n    });\n\n    afterAll(() => {\n      consoleSpy.mockRestore();\n    });\n\n    it('should send data to console.error', () => {\n      expect(consoleSpy.mock.calls[0][0]).toEqual(msg);\n    });\n  });\n\n  describe('#debugInfo', () => {\n    let consoleSpy;\n    const msg: string = 'test';\n\n    beforeAll(() => {\n      // Spy\n      consoleSpy = jest.spyOn(console, 'info');\n\n      // Method\n      logger.debugInfo(msg);\n    });\n\n    afterAll(() => {\n      consoleSpy.mockRestore();\n    });\n\n    it('should send data to console.info', () => {\n      expect(consoleSpy.mock.calls[0][0]).toEqual(msg);\n    });\n  });\n\n  describe('#debugLog', () => {\n    let consoleSpy;\n    const msg: string = 'test';\n\n    beforeAll(() => {\n      // Spy\n      consoleSpy = jest.spyOn(console, 'log');\n\n      // Method\n      logger.debugLog(msg);\n    });\n\n    afterAll(() => {\n      consoleSpy.mockRestore();\n    });\n\n    it('should send data to console.log', () => {\n      expect(consoleSpy.mock.calls[0][0]).toEqual(msg);\n    });\n  });\n\n  describe('#enableDebugger', () => {\n    it('should disable debugger', () => {\n      logger.enableDebugger(LoggerDebugLevel.DISABLED);\n      const options: LoggerOptions = logger.getOptions();\n      expect(options.debugLevel).toEqual(0);\n    });\n\n    it('should enable debugger for logs', () => {\n      logger.enableDebugger(LoggerDebugLevel.LOGS);\n      const options: LoggerOptions = logger.getOptions();\n      expect(options.debugLevel).toEqual(1);\n    });\n\n    it('should enable debugger for dispatch actions', () => {\n      logger.enableDebugger(LoggerDebugLevel.DISPATCH);\n      const options: LoggerOptions = logger.getOptions();\n      expect(options.debugLevel).toEqual(2);\n    });\n  });\n\n  describe('#preDispatch', () => {\n    it('should update the previous store', () => {\n      const testStore = {test: 'test'};\n      const privateProperty: string = 'previousStore';\n      logger.preDispatch(testAction, testStore);\n      expect(JSON.stringify(logger[privateProperty])).toEqual(JSON.stringify(testStore));\n    });\n  });\n\n  describe('#postDispatch', () => {\n    let consoleSpy;\n    const prevStore = {test: 'previous'};\n    const nextStore = {test: 'next'};\n\n    beforeEach(() => {\n      // Spy\n      consoleSpy = jest.spyOn(console, 'log');\n    });\n\n    afterEach(() => {\n      consoleSpy.mockRestore();\n    });\n\n    it('should dispatch logs for a changed state', () => {\n      // Method\n      logger.preDispatch(testAction, prevStore);\n      logger.postDispatch(testAction, nextStore);\n\n      // expect(consoleSpy.mock.calls[0][0]).toEqual('%c Action: ');\n      // expect(consoleSpy.mock.calls[0][2]).toEqual(testAction);\n      // expect(consoleSpy.mock.calls[1][0]).toEqual('%c Last State: ');\n      // expect(consoleSpy.mock.calls[1][2]).toEqual(prevStore);\n      expect(consoleSpy.mock.calls[2][0]).toEqual('%c Changed State: ');\n      expect(consoleSpy.mock.calls[2][2]).toEqual(nextStore);\n    });\n\n    // it('should dispatch logs for an unchanged state', () => {\n    //   // Method\n    //   logger.preDispatch(testAction, prevStore);\n    //   logger.postDispatch(testAction, prevStore);\n\n    //   expect(consoleSpy.mock.calls[0][0]).toEqual('%c Action: ');\n    //   expect(consoleSpy.mock.calls[0][2]).toEqual(testAction);\n    //   expect(consoleSpy.mock.calls[1][0]).toEqual('%c Last State: ');\n    //   expect(consoleSpy.mock.calls[1][2]).toEqual(prevStore);\n    //   expect(consoleSpy.mock.calls[2][0]).toEqual('%c Unchanged State: ');\n    //   expect(consoleSpy.mock.calls[2][2]).toEqual(prevStore);\n    // });\n  });\n});\n"],
  "mappings": "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",
  "names": []
}

package/lib/index.js CHANGED
@@ -1,39 +1,34 @@
1
- "use strict";
2
-
3
- require("core-js/modules/es.object.define-property.js");
4
-
5
- require("core-js/modules/es.array.for-each.js");
6
-
7
- require("core-js/modules/web.dom-collections.for-each.js");
8
-
9
- require("core-js/modules/es.object.keys.js");
10
-
11
- Object.defineProperty(exports, "__esModule", {
12
- value: true
13
- });
14
- var _exportNames = {
15
- Logger: true
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __markAsModule = (target) => __defProp(target, "__esModule", { value: true });
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
16
9
  };
17
- Object.defineProperty(exports, "Logger", {
18
- enumerable: true,
19
- get: function get() {
20
- return _Logger.Logger;
10
+ var __reExport = (target, module2, copyDefault, desc) => {
11
+ if (module2 && typeof module2 === "object" || typeof module2 === "function") {
12
+ for (let key of __getOwnPropNames(module2))
13
+ if (!__hasOwnProp.call(target, key) && (copyDefault || key !== "default"))
14
+ __defProp(target, key, { get: () => module2[key], enumerable: !(desc = __getOwnPropDesc(module2, key)) || desc.enumerable });
21
15
  }
16
+ return target;
17
+ };
18
+ var __toCommonJS = /* @__PURE__ */ ((cache) => {
19
+ return (module2, temp) => {
20
+ return cache && cache.get(module2) || (temp = __reExport(__markAsModule({}), module2, 1), cache && cache.set(module2, temp), temp);
21
+ };
22
+ })(typeof WeakMap !== "undefined" ? /* @__PURE__ */ new WeakMap() : 0);
23
+ var src_exports = {};
24
+ __export(src_exports, {
25
+ Logger: () => import_Logger.Logger
22
26
  });
23
-
24
- var _Logger = require("./Logger/Logger");
25
-
26
- var _main = require("./types/main");
27
-
28
- Object.keys(_main).forEach(function (key) {
29
- if (key === "default" || key === "__esModule") return;
30
- if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
31
- if (key in exports && exports[key] === _main[key]) return;
32
- Object.defineProperty(exports, key, {
33
- enumerable: true,
34
- get: function get() {
35
- return _main[key];
36
- }
37
- });
27
+ var import_Logger = require("./Logger/Logger");
28
+ __reExport(src_exports, require("./types/main"));
29
+ module.exports = __toCommonJS(src_exports);
30
+ // Annotate the CommonJS export names for ESM import in node:
31
+ 0 && (module.exports = {
32
+ Logger
38
33
  });
39
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUtBOztBQUVBOztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuXG5pbXBvcnQge0xvZ2dlcn0gZnJvbSAnLi9Mb2dnZXIvTG9nZ2VyJztcblxuZXhwb3J0ICogZnJvbSAnLi90eXBlcy9tYWluJztcbmV4cG9ydCB7TG9nZ2VyfTtcbiJdfQ==
34
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vc3JjL2luZGV4LnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuXG5pbXBvcnQge0xvZ2dlcn0gZnJvbSAnLi9Mb2dnZXIvTG9nZ2VyJztcblxuZXhwb3J0ICogZnJvbSAnLi90eXBlcy9tYWluJztcbmV4cG9ydCB7TG9nZ2VyfTtcbiJdLAogICJtYXBwaW5ncyI6ICI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUtBLG9CQUFxQjtBQUVyQix3QkFBYzsiLAogICJuYW1lcyI6IFtdCn0K
package/lib/types/main.js CHANGED
@@ -1,17 +1,38 @@
1
- "use strict";
2
-
3
- require("core-js/modules/es.object.define-property.js");
4
-
5
- Object.defineProperty(exports, "__esModule", {
6
- value: true
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __markAsModule = (target) => __defProp(target, "__esModule", { value: true });
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __reExport = (target, module2, copyDefault, desc) => {
11
+ if (module2 && typeof module2 === "object" || typeof module2 === "function") {
12
+ for (let key of __getOwnPropNames(module2))
13
+ if (!__hasOwnProp.call(target, key) && (copyDefault || key !== "default"))
14
+ __defProp(target, key, { get: () => module2[key], enumerable: !(desc = __getOwnPropDesc(module2, key)) || desc.enumerable });
15
+ }
16
+ return target;
17
+ };
18
+ var __toCommonJS = /* @__PURE__ */ ((cache) => {
19
+ return (module2, temp) => {
20
+ return cache && cache.get(module2) || (temp = __reExport(__markAsModule({}), module2, 1), cache && cache.set(module2, temp), temp);
21
+ };
22
+ })(typeof WeakMap !== "undefined" ? /* @__PURE__ */ new WeakMap() : 0);
23
+ var main_exports = {};
24
+ __export(main_exports, {
25
+ LoggerDebugLevel: () => LoggerDebugLevel
7
26
  });
8
- exports.LoggerDebugLevel = void 0;
9
- var LoggerDebugLevel;
10
- exports.LoggerDebugLevel = LoggerDebugLevel;
11
-
12
- (function (LoggerDebugLevel) {
13
- LoggerDebugLevel[LoggerDebugLevel["DISABLED"] = 0] = "DISABLED";
14
- LoggerDebugLevel[LoggerDebugLevel["LOGS"] = 1] = "LOGS";
15
- LoggerDebugLevel[LoggerDebugLevel["DISPATCH"] = 2] = "DISPATCH";
16
- })(LoggerDebugLevel || (exports.LoggerDebugLevel = LoggerDebugLevel = {}));
17
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy90eXBlcy9tYWluLnRzIl0sIm5hbWVzIjpbIkxvZ2dlckRlYnVnTGV2ZWwiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0lBQVlBLGdCOzs7V0FBQUEsZ0I7QUFBQUEsRUFBQUEsZ0IsQ0FBQUEsZ0I7QUFBQUEsRUFBQUEsZ0IsQ0FBQUEsZ0I7QUFBQUEsRUFBQUEsZ0IsQ0FBQUEsZ0I7R0FBQUEsZ0IsZ0NBQUFBLGdCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGVudW0gTG9nZ2VyRGVidWdMZXZlbCB7XG4gIERJU0FCTEVEID0gMCxcbiAgTE9HUyA9IDEsXG4gIERJU1BBVENIID0gMlxufVxuXG5leHBvcnQgaW50ZXJmYWNlIExvZ2dlck9wdGlvbnMge1xuICByZWFkb25seSBkZWJ1Z0xldmVsPzogTG9nZ2VyRGVidWdMZXZlbDtcbiAgcmVhZG9ubHkgZGVidWdFcnJvckZuYz86IChkZWJ1Z0xldmVsOiBudW1iZXIsIC4uLmFyZ3MpID0+IHZvaWQ7XG4gIHJlYWRvbmx5IGRlYnVnSW5mb0ZuYz86IChkZWJ1Z0xldmVsOiBudW1iZXIsIC4uLmFyZ3MpID0+IHZvaWQ7XG4gIHJlYWRvbmx5IGRlYnVnTG9nRm5jPzogKGRlYnVnTGV2ZWw6IG51bWJlciwgLi4uYXJncykgPT4gdm9pZDtcbn1cbiJdfQ==
27
+ var LoggerDebugLevel = /* @__PURE__ */ ((LoggerDebugLevel2) => {
28
+ LoggerDebugLevel2[LoggerDebugLevel2["DISABLED"] = 0] = "DISABLED";
29
+ LoggerDebugLevel2[LoggerDebugLevel2["LOGS"] = 1] = "LOGS";
30
+ LoggerDebugLevel2[LoggerDebugLevel2["DISPATCH"] = 2] = "DISPATCH";
31
+ return LoggerDebugLevel2;
32
+ })(LoggerDebugLevel || {});
33
+ module.exports = __toCommonJS(main_exports);
34
+ // Annotate the CommonJS export names for ESM import in node:
35
+ 0 && (module.exports = {
36
+ LoggerDebugLevel
37
+ });
38
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL3R5cGVzL21haW4udHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbImV4cG9ydCBlbnVtIExvZ2dlckRlYnVnTGV2ZWwge1xuICBESVNBQkxFRCA9IDAsXG4gIExPR1MgPSAxLFxuICBESVNQQVRDSCA9IDJcbn1cblxuZXhwb3J0IGludGVyZmFjZSBMb2dnZXJPcHRpb25zIHtcbiAgcmVhZG9ubHkgZGVidWdMZXZlbD86IExvZ2dlckRlYnVnTGV2ZWw7XG4gIHJlYWRvbmx5IGRlYnVnRXJyb3JGbmM/OiAoZGVidWdMZXZlbDogbnVtYmVyLCAuLi5hcmdzKSA9PiB2b2lkO1xuICByZWFkb25seSBkZWJ1Z0luZm9GbmM/OiAoZGVidWdMZXZlbDogbnVtYmVyLCAuLi5hcmdzKSA9PiB2b2lkO1xuICByZWFkb25seSBkZWJ1Z0xvZ0ZuYz86IChkZWJ1Z0xldmVsOiBudW1iZXIsIC4uLmFyZ3MpID0+IHZvaWQ7XG59XG4iXSwKICAibWFwcGluZ3MiOiAiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBTyxJQUFLLG1CQUFMLGtCQUFLLHNCQUFMO0FBQ0wsb0RBQVcsS0FBWDtBQUNBLGdEQUFPLEtBQVA7QUFDQSxvREFBVyxLQUFYO0FBSFU7QUFBQTsiLAogICJuYW1lcyI6IFtdCn0K
package/package.json CHANGED
@@ -1,12 +1,14 @@
1
1
  {
2
2
  "name": "@nlabs/arkhamjs-middleware-logger",
3
- "version": "3.20.5",
3
+ "version": "3.23.0",
4
4
  "publishConfig": {
5
5
  "access": "public"
6
6
  },
7
7
  "description": "Add console logging for ArkhamJS",
8
8
  "license": "MIT",
9
- "main": "index.js",
9
+ "main": "./lib/index.js",
10
+ "module": "./lib/index.js",
11
+ "browser": "./lib/index.js",
10
12
  "types": "./lib/index.d.ts",
11
13
  "keywords": [
12
14
  "arkhamjs",
@@ -40,13 +42,13 @@
40
42
  "lodash": "^4.17"
41
43
  },
42
44
  "devDependencies": {
43
- "@nlabs/arkhamjs": "^3.20.5",
44
- "@types/jest": "^26.0.20",
45
- "@types/node": "^14.14.31",
46
- "eslint": "^7.20.0",
47
- "eslint-config-styleguidejs": "^1.5.3",
45
+ "@nlabs/arkhamjs": "^3.23.0",
46
+ "@types/jest": "^27.4.0",
47
+ "@types/node": "^17.0.18",
48
+ "eslint": "^7.32.0",
49
+ "eslint-config-styleguidejs": "^1.5.5",
48
50
  "lodash": "^4.17.21",
49
- "typescript": "^4.2.2"
51
+ "typescript": "^4.5.5"
50
52
  },
51
- "gitHead": "6af1ac24ff6fdd602832aefba4386b10f0163ec4"
53
+ "gitHead": "337ef3d14c6cf514db1ae5429d9471188f8ec9b9"
52
54
  }