|
1 |
| -// document hack |
2 |
| -import root from './window-or-global'; |
3 | 1 |
|
4 |
| -let bows; |
5 |
| -(function (base) { |
6 |
| - window = base || window |
7 |
| - if (!window.localStorage) window.localStorage = {}; |
8 |
| -})(root); |
9 | 2 |
|
10 |
| -const levels = [ |
11 |
| - 'warn', 'info', 'error', 'debug' |
12 |
| -]; |
| 3 | +import { windowOrGlobal } from './'; |
| 4 | + |
| 5 | +((base) => { |
| 6 | + window = base || window; |
| 7 | + if (!window.localStorage) window.localStorage = {}; |
| 8 | +})(windowOrGlobal); |
13 | 9 |
|
14 |
| -class Log { |
| 10 | +export default class Log { |
15 | 11 | constructor(namespace) {
|
16 | 12 | this._namespace = namespace || 'firestack';
|
| 13 | + require('bows').config({ padLength: 20 }); |
17 | 14 | this.loggers = {};
|
18 |
| - // Add the logging levels for each level |
19 |
| - levels |
20 |
| - .forEach(level => this[level] = (...args) => this._log(level)(...args)); |
21 | 15 | }
|
22 | 16 |
|
23 |
| - static enable(booleanOrStringDebug) { |
24 |
| - window.localStorage.debug = |
25 |
| - typeof booleanOrStringDebug === 'string' ? |
26 |
| - (booleanOrStringDebug === '*' ? true : booleanOrStringDebug) : |
27 |
| - (booleanOrStringDebug instanceof RegExp ? booleanOrStringDebug.toString() : booleanOrStringDebug); |
| 17 | + get warn() { |
| 18 | + return this._createOrGetLogger('warn'); |
| 19 | + } |
| 20 | + |
| 21 | + get info() { |
| 22 | + return this._createOrGetLogger('info'); |
| 23 | + } |
28 | 24 |
|
| 25 | + get error() { |
| 26 | + return this._createOrGetLogger('error'); |
| 27 | + } |
| 28 | + |
| 29 | + get debug() { |
| 30 | + return this._createOrGetLogger('debug'); |
| 31 | + } |
| 32 | + |
| 33 | + static enable(booleanOrStringDebug) { |
| 34 | + window.localStorage.debug = booleanOrStringDebug; |
29 | 35 | window.localStorage.debugColors = !!window.localStorage.debug;
|
30 | 36 | }
|
31 | 37 |
|
32 |
| - _log(level) { |
33 |
| - if (!this.loggers[level]) { |
34 |
| - (function () { |
35 |
| - const bows = require('bows'); |
36 |
| - bows.config({ padLength: 20 }); |
37 |
| - this.loggers[level] = bows(this._namespace, `[${level}]`); |
38 |
| - }.bind(this))(); |
39 |
| - } |
| 38 | + _createOrGetLogger(level) { |
| 39 | + if (!this.loggers[level]) this.loggers[level] = require('bows')(this._namespace, `[${level}]`); |
40 | 40 | return this.loggers[level];
|
41 | 41 | }
|
42 | 42 | }
|
43 |
| - |
44 |
| -export default Log; |
0 commit comments