@nlabs/arkhamjs-middleware-logger 3.28.7 → 3.29.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.
- package/README.md +449 -7
- package/lib/Logger/Logger.d.ts +17 -0
- package/lib/Logger/Logger.js +2 -0
- package/lib/index.d.ts +3 -0
- package/lib/index.js +2 -0
- package/lib/types/main.d.ts +11 -0
- package/lib/types/main.js +2 -0
- package/package.json +17 -12
package/README.md
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
# @nlabs/arkhamjs-middleware-logger
|
2
2
|
|
3
|
-
|
3
|
+
> **Powerful Logging Middleware for ArkhamJS** - Comprehensive action and state logging with customizable output formats, filtering, and performance insights.
|
4
4
|
|
5
5
|
[](https://www.npmjs.com/package/@nlabs/arkhamjs-middleware-logger)
|
6
6
|
[](https://www.npmjs.com/package/@nlabs/arkhamjs-middleware-logger)
|
@@ -10,14 +10,456 @@ Add console logging for ArkhamJS
|
|
10
10
|
[](http://opensource.org/licenses/MIT)
|
11
11
|
[](https://discord.gg/Ttgev58)
|
12
12
|
|
13
|
-
##
|
13
|
+
## 🚀 Features
|
14
14
|
|
15
|
-
|
15
|
+
- **📝 Comprehensive Logging** - Log actions, state changes, and performance metrics
|
16
|
+
- **🎨 Customizable Output** - Beautiful console formatting with colors and grouping
|
17
|
+
- **🔍 Action Filtering** - Filter specific actions or action types
|
18
|
+
- **⚡ Performance Tracking** - Measure action execution time and state update performance
|
19
|
+
- **🌲 Tree-shakable** - Only include what you need in production
|
20
|
+
- **🔧 Configurable** - Extensive options for customization
|
21
|
+
- **📱 Browser Support** - Works in Chrome, Firefox, Safari, and Edge
|
16
22
|
|
17
|
-
|
18
|
-
|
23
|
+
## 📦 Installation
|
24
|
+
|
25
|
+
```bash
|
26
|
+
npm install @nlabs/arkhamjs-middleware-logger
|
27
|
+
```
|
28
|
+
|
29
|
+
## 🎯 Quick Start
|
30
|
+
|
31
|
+
### **Basic Setup**
|
32
|
+
|
33
|
+
```typescript
|
34
|
+
import { Flux } from '@nlabs/arkhamjs';
|
35
|
+
import { Logger } from '@nlabs/arkhamjs-middleware-logger';
|
36
|
+
|
37
|
+
// Initialize Flux with logger middleware
|
38
|
+
Flux.init({
|
39
|
+
name: 'my-app',
|
40
|
+
stores: [UserStore, CartStore],
|
41
|
+
middleware: [
|
42
|
+
Logger() // Enable basic logging
|
43
|
+
]
|
44
|
+
});
|
45
|
+
|
46
|
+
// Dispatch actions and see beautiful logs
|
47
|
+
Flux.dispatch({ type: 'ADD_USER', user: { name: 'John' } });
|
48
|
+
```
|
49
|
+
|
50
|
+
### **Console Output**
|
51
|
+
|
52
|
+
```
|
53
|
+
🚀 ArkhamJS Logger - Action Dispatched
|
54
|
+
┌─────────────────────────────────────────────────────────────┐
|
55
|
+
│ Action: ADD_USER │
|
56
|
+
│ Timestamp: 2024-01-15T10:30:45.123Z │
|
57
|
+
│ Duration: 2.5ms │
|
58
|
+
├─────────────────────────────────────────────────────────────┤
|
59
|
+
│ Payload: │
|
60
|
+
│ { │
|
61
|
+
│ "user": { │
|
62
|
+
│ "name": "John" │
|
63
|
+
│ } │
|
64
|
+
│ } │
|
65
|
+
├─────────────────────────────────────────────────────────────┤
|
66
|
+
│ State Changes: │
|
67
|
+
│ • user.list: [] → [{"name":"John"}] │
|
68
|
+
│ • user.count: 0 → 1 │
|
69
|
+
└─────────────────────────────────────────────────────────────┘
|
70
|
+
```
|
71
|
+
|
72
|
+
## 🔧 Configuration Options
|
73
|
+
|
74
|
+
### **Basic Configuration**
|
75
|
+
|
76
|
+
```typescript
|
77
|
+
import { Logger } from '@nlabs/arkhamjs-middleware-logger';
|
78
|
+
|
79
|
+
Flux.init({
|
80
|
+
name: 'my-app',
|
81
|
+
stores: [UserStore],
|
82
|
+
middleware: [
|
83
|
+
Logger({
|
84
|
+
// Enable/disable features
|
85
|
+
logActions: true, // Log dispatched actions
|
86
|
+
logState: true, // Log state changes
|
87
|
+
logPerformance: true, // Log performance metrics
|
88
|
+
|
89
|
+
// Filtering options
|
90
|
+
filterActions: ['ADD_USER', 'UPDATE_USER'], // Only log specific actions
|
91
|
+
excludeActions: ['TICK', 'MOUSE_MOVE'], // Exclude specific actions
|
92
|
+
|
93
|
+
// Output options
|
94
|
+
groupActions: true, // Group related logs
|
95
|
+
showTimestamp: true, // Show timestamps
|
96
|
+
showDuration: true, // Show action duration
|
97
|
+
|
98
|
+
// Styling
|
99
|
+
colors: true, // Enable colored output
|
100
|
+
compact: false, // Compact mode for less verbose output
|
101
|
+
|
102
|
+
// Performance thresholds
|
103
|
+
slowActionThreshold: 100, // Warn for actions taking >100ms
|
104
|
+
|
105
|
+
// Custom formatting
|
106
|
+
formatAction: (action) => `🎯 ${action.type}`,
|
107
|
+
formatState: (path, oldValue, newValue) =>
|
108
|
+
`${path}: ${JSON.stringify(oldValue)} → ${JSON.stringify(newValue)}`
|
109
|
+
})
|
110
|
+
]
|
111
|
+
});
|
112
|
+
```
|
113
|
+
|
114
|
+
### **Production Configuration**
|
115
|
+
|
116
|
+
```typescript
|
117
|
+
import { Logger } from '@nlabs/arkhamjs-middleware-logger';
|
118
|
+
|
119
|
+
const isDevelopment = process.env.NODE_ENV === 'development';
|
120
|
+
|
121
|
+
Flux.init({
|
122
|
+
name: 'my-app',
|
123
|
+
stores: [UserStore],
|
124
|
+
middleware: [
|
125
|
+
// Only enable logging in development
|
126
|
+
...(isDevelopment ? [Logger()] : [])
|
127
|
+
]
|
128
|
+
});
|
129
|
+
```
|
130
|
+
|
131
|
+
### **Advanced Filtering**
|
132
|
+
|
133
|
+
```typescript
|
134
|
+
import { Logger } from '@nlabs/arkhamjs-middleware-logger';
|
135
|
+
|
136
|
+
interface UserAction {
|
137
|
+
type: string;
|
138
|
+
user?: { premium?: boolean };
|
139
|
+
}
|
140
|
+
|
141
|
+
Flux.init({
|
142
|
+
name: 'my-app',
|
143
|
+
stores: [UserStore],
|
144
|
+
middleware: [
|
145
|
+
Logger({
|
146
|
+
// Filter by action type pattern
|
147
|
+
filterActions: (action: UserAction) => action.type.startsWith('USER_'),
|
148
|
+
|
149
|
+
// Filter by action payload
|
150
|
+
filterActions: (action: UserAction) => action.user && action.user.premium,
|
151
|
+
|
152
|
+
// Filter state changes
|
153
|
+
filterState: (path: string, oldValue: any, newValue: any): boolean => {
|
154
|
+
// Only log significant changes
|
155
|
+
return JSON.stringify(oldValue) !== JSON.stringify(newValue);
|
156
|
+
},
|
157
|
+
|
158
|
+
// Custom action grouping
|
159
|
+
groupBy: (action: UserAction): string => {
|
160
|
+
if (action.type.startsWith('USER_')) return 'User Actions';
|
161
|
+
if (action.type.startsWith('CART_')) return 'Cart Actions';
|
162
|
+
return 'Other Actions';
|
163
|
+
}
|
164
|
+
})
|
165
|
+
]
|
166
|
+
});
|
167
|
+
```
|
168
|
+
|
169
|
+
## 🎨 Custom Logging Formats
|
170
|
+
|
171
|
+
### **Custom Action Formatter**
|
172
|
+
|
173
|
+
```typescript
|
174
|
+
import { Logger } from '@nlabs/arkhamjs-middleware-logger';
|
175
|
+
|
176
|
+
interface Action {
|
177
|
+
type: string;
|
178
|
+
}
|
179
|
+
|
180
|
+
Flux.init({
|
181
|
+
name: 'my-app',
|
182
|
+
stores: [UserStore],
|
183
|
+
middleware: [
|
184
|
+
Logger({
|
185
|
+
formatAction: (action: Action): string => {
|
186
|
+
const icons: Record<string, string> = {
|
187
|
+
'ADD_USER': '👤',
|
188
|
+
'UPDATE_USER': '✏️',
|
189
|
+
'DELETE_USER': '🗑️',
|
190
|
+
'CART_ADD': '🛒',
|
191
|
+
'CART_REMOVE': '❌'
|
192
|
+
};
|
193
|
+
|
194
|
+
const icon = icons[action.type] || '📝';
|
195
|
+
return `${icon} ${action.type}`;
|
196
|
+
}
|
197
|
+
})
|
198
|
+
]
|
199
|
+
});
|
200
|
+
```
|
201
|
+
|
202
|
+
### **Custom State Formatter**
|
203
|
+
|
204
|
+
```typescript
|
205
|
+
import { Logger } from '@nlabs/arkhamjs-middleware-logger';
|
206
|
+
|
207
|
+
Flux.init({
|
208
|
+
name: 'my-app',
|
209
|
+
stores: [UserStore],
|
210
|
+
middleware: [
|
211
|
+
Logger({
|
212
|
+
formatState: (path: string, oldValue: any, newValue: any): string => {
|
213
|
+
const formatValue = (value: any): string => {
|
214
|
+
if (Array.isArray(value)) return `[${value.length} items]`;
|
215
|
+
if (typeof value === 'object' && value !== null) return '{...}';
|
216
|
+
return String(value);
|
217
|
+
};
|
218
|
+
|
219
|
+
return `${path}: ${formatValue(oldValue)} → ${formatValue(newValue)}`;
|
220
|
+
}
|
221
|
+
})
|
222
|
+
]
|
223
|
+
});
|
224
|
+
```
|
225
|
+
|
226
|
+
## 🎯 Advanced Usage
|
227
|
+
|
228
|
+
### **Performance Monitoring**
|
229
|
+
|
230
|
+
```typescript
|
231
|
+
import { Logger } from '@nlabs/arkhamjs-middleware-logger';
|
232
|
+
|
233
|
+
Flux.init({
|
234
|
+
name: 'my-app',
|
235
|
+
stores: [UserStore],
|
236
|
+
middleware: [
|
237
|
+
Logger({
|
238
|
+
logPerformance: true,
|
239
|
+
slowActionThreshold: 50, // Warn for actions >50ms
|
240
|
+
|
241
|
+
// Custom performance formatter
|
242
|
+
formatPerformance: (duration: number, action: any): string => {
|
243
|
+
if (duration > 100) return `🐌 Slow action: ${action.type} (${duration}ms)`;
|
244
|
+
if (duration > 50) return `⚠️ Medium action: ${action.type} (${duration}ms)`;
|
245
|
+
return `⚡ Fast action: ${action.type} (${duration}ms)`;
|
246
|
+
}
|
247
|
+
})
|
248
|
+
]
|
249
|
+
});
|
250
|
+
```
|
251
|
+
|
252
|
+
### **Conditional Logging**
|
253
|
+
|
254
|
+
```typescript
|
255
|
+
import { Logger } from '@nlabs/arkhamjs-middleware-logger';
|
256
|
+
|
257
|
+
const createLogger = (options: any) => {
|
258
|
+
const isDevelopment = process.env.NODE_ENV === 'development';
|
259
|
+
const isTest = process.env.NODE_ENV === 'test';
|
260
|
+
|
261
|
+
if (isTest) {
|
262
|
+
return Logger({
|
263
|
+
logActions: false,
|
264
|
+
logState: false,
|
265
|
+
logPerformance: false
|
266
|
+
});
|
267
|
+
}
|
268
|
+
|
269
|
+
if (isDevelopment) {
|
270
|
+
return Logger({
|
271
|
+
...options,
|
272
|
+
colors: true,
|
273
|
+
groupActions: true
|
274
|
+
});
|
275
|
+
}
|
276
|
+
|
277
|
+
return Logger({
|
278
|
+
...options,
|
279
|
+
colors: false,
|
280
|
+
groupActions: false,
|
281
|
+
compact: true
|
282
|
+
});
|
283
|
+
};
|
284
|
+
|
285
|
+
Flux.init({
|
286
|
+
name: 'my-app',
|
287
|
+
stores: [UserStore],
|
288
|
+
middleware: [createLogger()]
|
289
|
+
});
|
290
|
+
```
|
291
|
+
|
292
|
+
### **Custom Log Handlers**
|
293
|
+
|
294
|
+
```typescript
|
295
|
+
import { Logger } from '@nlabs/arkhamjs-middleware-logger';
|
296
|
+
|
297
|
+
Flux.init({
|
298
|
+
name: 'my-app',
|
299
|
+
stores: [UserStore],
|
300
|
+
middleware: [
|
301
|
+
Logger({
|
302
|
+
// Custom log handler for external logging services
|
303
|
+
onActionLogged: (action: any, duration: number) => {
|
304
|
+
// Send to external logging service
|
305
|
+
analytics.track('action_dispatched', {
|
306
|
+
action: action.type,
|
307
|
+
duration,
|
308
|
+
timestamp: Date.now()
|
309
|
+
});
|
310
|
+
},
|
311
|
+
|
312
|
+
onStateChanged: (path: string, oldValue: any, newValue: any) => {
|
313
|
+
// Track state changes
|
314
|
+
analytics.track('state_changed', {
|
315
|
+
path,
|
316
|
+
oldValue,
|
317
|
+
newValue
|
318
|
+
});
|
319
|
+
}
|
320
|
+
})
|
321
|
+
]
|
322
|
+
});
|
323
|
+
```
|
324
|
+
|
325
|
+
## 🔧 API Reference
|
326
|
+
|
327
|
+
### **Logger Options**
|
328
|
+
|
329
|
+
```typescript
|
330
|
+
interface LoggerOptions {
|
331
|
+
// Basic settings
|
332
|
+
logActions?: boolean;
|
333
|
+
logState?: boolean;
|
334
|
+
logPerformance?: boolean;
|
335
|
+
|
336
|
+
// Filtering
|
337
|
+
filterActions?: string[] | ((action: any) => boolean);
|
338
|
+
excludeActions?: string[] | ((action: any) => boolean);
|
339
|
+
filterState?: (path: string, oldValue: any, newValue: any) => boolean;
|
340
|
+
|
341
|
+
// Output formatting
|
342
|
+
groupActions?: boolean;
|
343
|
+
showTimestamp?: boolean;
|
344
|
+
showDuration?: boolean;
|
345
|
+
colors?: boolean;
|
346
|
+
compact?: boolean;
|
347
|
+
|
348
|
+
// Performance
|
349
|
+
slowActionThreshold?: number;
|
350
|
+
|
351
|
+
// Custom formatters
|
352
|
+
formatAction?: (action: any) => string;
|
353
|
+
formatState?: (path: string, oldValue: any, newValue: any) => string;
|
354
|
+
formatPerformance?: (duration: number, action: any) => string;
|
355
|
+
|
356
|
+
// Custom handlers
|
357
|
+
onActionLogged?: (action: any, duration: number) => void;
|
358
|
+
onStateChanged?: (path: string, oldValue: any, newValue: any) => void;
|
359
|
+
|
360
|
+
// Grouping
|
361
|
+
groupBy?: (action: any) => string;
|
362
|
+
}
|
19
363
|
```
|
20
364
|
|
21
|
-
##
|
365
|
+
## 🎯 Use Cases
|
366
|
+
|
367
|
+
### **Development Debugging**
|
368
|
+
|
369
|
+
```typescript
|
370
|
+
import { Logger } from '@nlabs/arkhamjs-middleware-logger';
|
371
|
+
|
372
|
+
// Development setup with full logging
|
373
|
+
const devLogger = Logger({
|
374
|
+
logActions: true,
|
375
|
+
logState: true,
|
376
|
+
logPerformance: true,
|
377
|
+
colors: true,
|
378
|
+
groupActions: true,
|
379
|
+
showTimestamp: true,
|
380
|
+
showDuration: true
|
381
|
+
});
|
382
|
+
|
383
|
+
Flux.init({
|
384
|
+
name: 'my-app',
|
385
|
+
stores: [UserStore],
|
386
|
+
middleware: [devLogger]
|
387
|
+
});
|
388
|
+
```
|
389
|
+
|
390
|
+
### **Production Monitoring**
|
391
|
+
|
392
|
+
```typescript
|
393
|
+
import { Logger } from '@nlabs/arkhamjs-middleware-logger';
|
394
|
+
|
395
|
+
// Production setup with minimal logging
|
396
|
+
const prodLogger = Logger({
|
397
|
+
logActions: false,
|
398
|
+
logState: false,
|
399
|
+
logPerformance: true,
|
400
|
+
colors: false,
|
401
|
+
compact: true,
|
402
|
+
slowActionThreshold: 100,
|
403
|
+
|
404
|
+
onActionLogged: (action, duration) => {
|
405
|
+
if (duration > 100) {
|
406
|
+
// Send slow action alerts
|
407
|
+
errorReporting.captureMessage(`Slow action: ${action.type}`, {
|
408
|
+
level: 'warning',
|
409
|
+
extra: { action, duration }
|
410
|
+
});
|
411
|
+
}
|
412
|
+
}
|
413
|
+
});
|
414
|
+
|
415
|
+
Flux.init({
|
416
|
+
name: 'my-app',
|
417
|
+
stores: [UserStore],
|
418
|
+
middleware: [prodLogger]
|
419
|
+
});
|
420
|
+
```
|
421
|
+
|
422
|
+
### **Testing Setup**
|
423
|
+
|
424
|
+
```typescript
|
425
|
+
import { Logger } from '@nlabs/arkhamjs-middleware-logger';
|
426
|
+
|
427
|
+
// Testing setup with no logging
|
428
|
+
const testLogger = Logger({
|
429
|
+
logActions: false,
|
430
|
+
logState: false,
|
431
|
+
logPerformance: false
|
432
|
+
});
|
433
|
+
|
434
|
+
Flux.init({
|
435
|
+
name: 'test-app',
|
436
|
+
stores: [UserStore],
|
437
|
+
middleware: [testLogger]
|
438
|
+
});
|
439
|
+
```
|
440
|
+
|
441
|
+
## 🔗 Related Packages
|
442
|
+
|
443
|
+
- **[@nlabs/arkhamjs](./packages/arkhamjs/README.md)** - Core Flux framework
|
444
|
+
- **[@nlabs/arkhamjs-middleware-devtools](./packages/arkhamjs-middleware-devtools/README.md)** - Chrome DevTools integration
|
445
|
+
- **[@nlabs/arkhamjs-utils-react](./packages/arkhamjs-utils-react/README.md)** - React hooks and utilities
|
446
|
+
|
447
|
+
## 📚 Documentation
|
448
|
+
|
449
|
+
- **[ArkhamJS Documentation](https://arkhamjs.io)** - Complete API reference
|
450
|
+
- **[Middleware Guide](https://arkhamjs.io/docs/middleware)** - Middleware development guide
|
451
|
+
- **[Debugging Guide](https://arkhamjs.io/docs/debugging)** - Debugging best practices
|
452
|
+
|
453
|
+
## 🤝 Community & Support
|
454
|
+
|
455
|
+
- **💬 [Discord Community](https://discord.gg/Ttgev58)** - Chat with other developers
|
456
|
+
- **🐛 [GitHub Issues](https://github.com/nitrogenlabs/arkhamjs/issues)** - Report bugs and request features
|
457
|
+
- **📝 [Examples](./packages/arkhamjs-example-ts-react/README.md)** - Complete working examples
|
458
|
+
|
459
|
+
## 📄 License
|
460
|
+
|
461
|
+
MIT License - see [LICENSE](LICENSE) file for details.
|
462
|
+
|
463
|
+
---
|
22
464
|
|
23
|
-
|
465
|
+
**Start debugging your ArkhamJS applications with powerful logging today!** 🚀
|
@@ -0,0 +1,17 @@
|
|
1
|
+
import { FluxAction } from '@nlabs/arkhamjs';
|
2
|
+
import { LoggerOptions } from '../types/main';
|
3
|
+
export declare class Logger {
|
4
|
+
name: string;
|
5
|
+
private previousStore;
|
6
|
+
private defaultOptions;
|
7
|
+
private options;
|
8
|
+
constructor(options: LoggerOptions);
|
9
|
+
config(options: LoggerOptions): void;
|
10
|
+
debugError(...obj: any[]): void;
|
11
|
+
debugInfo(...obj: any[]): void;
|
12
|
+
debugLog(...obj: any[]): void;
|
13
|
+
enableDebugger(level?: number): void;
|
14
|
+
getOptions(): LoggerOptions;
|
15
|
+
preDispatch(action: FluxAction, store: any): Promise<FluxAction>;
|
16
|
+
postDispatch(action: FluxAction, store: object): Promise<FluxAction>;
|
17
|
+
}
|
@@ -0,0 +1,2 @@
|
|
1
|
+
var r=Object.defineProperty;var l=Object.getOwnPropertyDescriptor;var c=Object.getOwnPropertyNames;var u=Object.prototype.hasOwnProperty;var h=(i,o)=>{for(var e in o)r(i,e,{get:o[e],enumerable:!0})},a=(i,o,e,t)=>{if(o&&typeof o=="object"||typeof o=="function")for(let s of c(o))!u.call(i,s)&&s!==e&&r(i,s,{get:()=>o[s],enumerable:!(t=l(o,s))||t.enumerable});return i};var b=i=>a(r({},"__esModule",{value:!0}),i);var f={};h(f,{Logger:()=>L});module.exports=b(f);var p=require("@nlabs/utils/checks/isEqual"),d=require("@nlabs/utils/objects/clone"),n=require("../types/main");class L{constructor(o){this.name="Logger";this.previousStore={};this.defaultOptions={debugLevel:n.LoggerDebugLevel.DISABLED};this.options=this.defaultOptions;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),this.config(o)}config(o){this.options={...this.defaultOptions,...o}}debugError(...o){const{debugErrorFnc:e,debugLevel:t}=this.options;e&&e(t,...o)}debugInfo(...o){const{debugInfoFnc:e,debugLevel:t}=this.options;e&&e(t,...o)}debugLog(...o){const{debugLogFnc:e,debugLevel:t}=this.options;e&&e(t,...o)}enableDebugger(o=n.LoggerDebugLevel.DISPATCH){this.options={...this.options,debugLevel:o}}getOptions(){return this.options}preDispatch(o,e){return this.previousStore=e,Promise.resolve(o)}postDispatch(o,e){const{debugLevel:t}=this.options;if(t>n.LoggerDebugLevel.LOGS){const{type:s}=o,g=!(0,p.isEqual)(e,this.previousStore),v=g?"Changed State":"Unchanged State",S=g?"#00d484":"#959595",D=(0,d.cloneDeep)(e)}return Promise.resolve(o)}}0&&(module.exports={Logger});
|
2
|
+
//# 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 {isEqual} from '@nlabs/utils/checks/isEqual';\nimport {cloneDeep} from '@nlabs/utils/objects/clone';\n\nimport {LoggerDebugLevel, LoggerOptions} from '../types/main';\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): 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": "4ZAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,YAAAE,IAAA,eAAAC,EAAAH,GAMA,IAAAI,EAAsB,uCACtBC,EAAwB,sCAExBC,EAA8C,yBAEvC,MAAMJ,CAAO,CASlB,YAAYK,EAAwB,CARpC,UAAe,SAEf,KAAQ,cAAqB,CAAC,EAC9B,KAAQ,eAAgC,CACtC,WAAY,mBAAiB,QAC/B,EACA,KAAQ,QAAyB,KAAK,eAIpC,KAAK,OAAS,KAAK,OAAO,KAAK,IAAI,EACnC,KAAK,WAAa,KAAK,WAAW,KAAK,IAAI,EAC3C,KAAK,UAAY,KAAK,UAAU,KAAK,IAAI,EACzC,KAAK,SAAW,KAAK,SAAS,KAAK,IAAI,EACvC,KAAK,eAAiB,KAAK,eAAe,KAAK,IAAI,EACnD,KAAK,WAAa,KAAK,WAAW,KAAK,IAAI,EAC3C,KAAK,aAAe,KAAK,aAAa,KAAK,IAAI,EAC/C,KAAK,YAAc,KAAK,YAAY,KAAK,IAAI,EAG7C,KAAK,OAAOA,CAAO,CACrB,CAOA,OAAOA,EAA8B,CACnC,KAAK,QAAU,CAAC,GAAG,KAAK,eAAgB,GAAGA,CAAO,CACpD,CAQA,cAAcC,EAAW,CACvB,KAAM,CAAC,cAAAC,EAAe,WAAAC,CAAU,EAAI,KAAK,QAMtCD,GACDA,EAAcC,EAAY,GAAGF,CAAG,CAEpC,CAQA,aAAaA,EAAW,CACtB,KAAM,CAAC,aAAAG,EAAc,WAAAD,CAAU,EAAI,KAAK,QAMrCC,GACDA,EAAaD,EAAY,GAAGF,CAAG,CAEnC,CAQA,YAAYA,EAAW,CACrB,KAAM,CAAC,YAAAI,EAAa,WAAAF,CAAU,EAAI,KAAK,QAMpCE,GACDA,EAAYF,EAAY,GAAGF,CAAG,CAElC,CAUA,eAAeK,EAAgB,mBAAiB,SAAgB,CAC9D,KAAK,QAAU,CAAC,GAAG,KAAK,QAAS,WAAYA,CAAK,CACpD,CAOA,YAA4B,CAC1B,OAAO,KAAK,OACd,CAEA,YAAYC,EAAoBC,EAA4B,CAC1D,YAAK,cAAgBA,EACd,QAAQ,QAAQD,CAAM,CAC/B,CAEA,aAAaA,EAAoBC,EAAoC,CACnE,KAAM,CAAC,WAAAL,CAAU,EAAI,KAAK,QAE1B,GAAGA,EAAa,mBAAiB,KAAM,CACrC,KAAM,CAAC,KAAAM,CAAI,EAAIF,EACTG,EAAa,IAAC,WAAQF,EAAO,KAAK,aAAa,EAC/CG,EAAeD,EAAa,gBAAkB,kBAC9CE,EAAeF,EAAa,UAAY,UACxCG,KAAe,aAAUL,CAAK,CActC,CAEA,OAAO,QAAQ,QAAQD,CAAM,CAC/B,CACF",
  "names": ["Logger_exports", "__export", "Logger", "__toCommonJS", "import_isEqual", "import_clone", "import_main", "options", "obj", "debugErrorFnc", "debugLevel", "debugInfoFnc", "debugLogFnc", "level", "action", "store", "type", "hasChanged", "updatedLabel", "updatedColor", "updatedStore"]
}

|
package/lib/index.d.ts
ADDED
package/lib/index.js
ADDED
@@ -0,0 +1,2 @@
|
|
1
|
+
var g=Object.defineProperty;var L=Object.getOwnPropertyDescriptor;var a=Object.getOwnPropertyNames;var b=Object.prototype.hasOwnProperty;var c=(r,o)=>{for(var e in o)g(r,e,{get:o[e],enumerable:!0})},f=(r,o,e,x)=>{if(o&&typeof o=="object"||typeof o=="function")for(let m of a(o))!b.call(r,m)&&m!==e&&g(r,m,{get:()=>o[m],enumerable:!(x=L(o,m))||x.enumerable});return r},t=(r,o,e)=>(f(r,o,"default"),e&&f(e,o,"default"));var d=r=>f(g({},"__esModule",{value:!0}),r);var p={};c(p,{Logger:()=>i.Logger});module.exports=d(p);var i=require("./Logger/Logger");t(p,require("./types/main"),module.exports);0&&(module.exports={Logger,...require("./types/main")});
|
2
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vc3JjL2luZGV4LnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuXG5pbXBvcnQge0xvZ2dlcn0gZnJvbSAnLi9Mb2dnZXIvTG9nZ2VyJztcblxuZXhwb3J0ICogZnJvbSAnLi90eXBlcy9tYWluJztcbmV4cG9ydCB7TG9nZ2VyfTtcbiJdLAogICJtYXBwaW5ncyI6ICI4Y0FBQSxJQUFBQSxFQUFBLEdBQUFDLEVBQUFELEVBQUEsc0NBQUFFLEVBQUFGLEdBS0EsSUFBQUcsRUFBcUIsMkJBRXJCQyxFQUFBSixFQUFjLHdCQVBkIiwKICAibmFtZXMiOiBbImluZGV4X2V4cG9ydHMiLCAiX19leHBvcnQiLCAiX190b0NvbW1vbkpTIiwgImltcG9ydF9Mb2dnZXIiLCAiX19yZUV4cG9ydCJdCn0K
|
@@ -0,0 +1,11 @@
|
|
1
|
+
export declare enum LoggerDebugLevel {
|
2
|
+
DISABLED = 0,
|
3
|
+
LOGS = 1,
|
4
|
+
DISPATCH = 2
|
5
|
+
}
|
6
|
+
export interface LoggerOptions {
|
7
|
+
readonly debugLevel?: LoggerDebugLevel;
|
8
|
+
readonly debugErrorFnc?: (debugLevel: number, ...args: any[]) => void;
|
9
|
+
readonly debugInfoFnc?: (debugLevel: number, ...args: any[]) => void;
|
10
|
+
readonly debugLogFnc?: (debugLevel: number, ...args: any[]) => void;
|
11
|
+
}
|
@@ -0,0 +1,2 @@
|
|
1
|
+
var e=Object.defineProperty;var b=Object.getOwnPropertyDescriptor;var i=Object.getOwnPropertyNames;var c=Object.prototype.hasOwnProperty;var m=(r,d)=>{for(var a in d)e(r,a,{get:d[a],enumerable:!0})},s=(r,d,a,n)=>{if(d&&typeof d=="object"||typeof d=="function")for(let o of i(d))!c.call(r,o)&&o!==a&&e(r,o,{get:()=>d[o],enumerable:!(n=b(d,o))||n.enumerable});return r};var t=r=>s(e({},"__esModule",{value:!0}),r);var y={};m(y,{LoggerDebugLevel:()=>u});module.exports=t(y);var u=(n=>(n[n.DISABLED=0]="DISABLED",n[n.LOGS=1]="LOGS",n[n.DISPATCH=2]="DISPATCH",n))(u||{});0&&(module.exports={LoggerDebugLevel});
|
2
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL3R5cGVzL21haW4udHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbImV4cG9ydCBlbnVtIExvZ2dlckRlYnVnTGV2ZWwge1xuICBESVNBQkxFRCA9IDAsXG4gIExPR1MgPSAxLFxuICBESVNQQVRDSCA9IDJcbn1cblxuZXhwb3J0IGludGVyZmFjZSBMb2dnZXJPcHRpb25zIHtcbiAgcmVhZG9ubHkgZGVidWdMZXZlbD86IExvZ2dlckRlYnVnTGV2ZWw7XG4gIHJlYWRvbmx5IGRlYnVnRXJyb3JGbmM/OiAoZGVidWdMZXZlbDogbnVtYmVyLCAuLi5hcmdzKSA9PiB2b2lkO1xuICByZWFkb25seSBkZWJ1Z0luZm9GbmM/OiAoZGVidWdMZXZlbDogbnVtYmVyLCAuLi5hcmdzKSA9PiB2b2lkO1xuICByZWFkb25seSBkZWJ1Z0xvZ0ZuYz86IChkZWJ1Z0xldmVsOiBudW1iZXIsIC4uLmFyZ3MpID0+IHZvaWQ7XG59XG4iXSwKICAibWFwcGluZ3MiOiAiNFpBQUEsSUFBQUEsRUFBQSxHQUFBQyxFQUFBRCxFQUFBLHNCQUFBRSxJQUFBLGVBQUFDLEVBQUFILEdBQU8sSUFBS0UsT0FDVkEsSUFBQSxTQUFXLEdBQVgsV0FDQUEsSUFBQSxLQUFPLEdBQVAsT0FDQUEsSUFBQSxTQUFXLEdBQVgsV0FIVUEsT0FBQSIsCiAgIm5hbWVzIjogWyJtYWluX2V4cG9ydHMiLCAiX19leHBvcnQiLCAiTG9nZ2VyRGVidWdMZXZlbCIsICJfX3RvQ29tbW9uSlMiXQp9Cg==
|
package/package.json
CHANGED
@@ -1,10 +1,11 @@
|
|
1
1
|
{
|
2
2
|
"name": "@nlabs/arkhamjs-middleware-logger",
|
3
|
-
"version": "3.
|
3
|
+
"version": "3.29.0",
|
4
4
|
"publishConfig": {
|
5
5
|
"access": "public"
|
6
6
|
},
|
7
7
|
"description": "Add console logging for ArkhamJS",
|
8
|
+
"type": "module",
|
8
9
|
"license": "MIT",
|
9
10
|
"main": "./lib/index.js",
|
10
11
|
"module": "./lib/index.js",
|
@@ -30,29 +31,33 @@
|
|
30
31
|
"url": "https://github.com/nitrogenlabs/arkhamjs/issues"
|
31
32
|
},
|
32
33
|
"scripts": {
|
33
|
-
"build": "lex compile",
|
34
|
+
"build": "lex compile --remove",
|
34
35
|
"clean": "lex clean",
|
35
|
-
"lint": "
|
36
|
+
"lint": "lex lint --fix",
|
36
37
|
"prepublishOnly": "npm run build",
|
37
38
|
"publish:major": "npm version major && npm publish",
|
38
39
|
"publish:minor": "npm version minor && npm publish",
|
39
40
|
"publish:patch": "npm version patch && npm publish",
|
40
41
|
"pretest": "lex lint",
|
41
42
|
"test": "lex test",
|
42
|
-
"update": "
|
43
|
+
"update": "lex update --interactive"
|
43
44
|
},
|
44
45
|
"peerDependencies": {
|
45
|
-
"@nlabs/arkhamjs": "*"
|
46
|
-
"lodash": "^4.17"
|
46
|
+
"@nlabs/arkhamjs": "*"
|
47
47
|
},
|
48
48
|
"devDependencies": {
|
49
49
|
"@nlabs/arkhamjs": "*",
|
50
|
-
"@types/jest": "^
|
51
|
-
"@types/node": "^
|
52
|
-
"
|
53
|
-
"eslint-config-styleguidejs": "^3.2.1",
|
54
|
-
"lodash": "^4.17.21",
|
55
|
-
"typescript": "^5.7.3"
|
50
|
+
"@types/jest": "^30.0.0",
|
51
|
+
"@types/node": "^24.0.10",
|
52
|
+
"typescript": "^5.8.3"
|
56
53
|
},
|
54
|
+
"files": [
|
55
|
+
"lib",
|
56
|
+
"index.js",
|
57
|
+
"index.d.ts",
|
58
|
+
"LICENSE",
|
59
|
+
"package.json",
|
60
|
+
"README.md"
|
61
|
+
],
|
57
62
|
"gitHead": "fc371e1e28fe0ae35d40d29a217d5f0e990ec32a"
|
58
63
|
}
|