UNPKG

8.04 kBTypeScriptView Raw
1// Originally from Definitely Typed, see:
2// https://github.com/DefinitelyTyped/DefinitelyTyped/blob/b4683d7/types/loglevel/index.d.ts
3// Original definitions by: Stefan Profanter <https://github.com/Pro>
4// Gabor Szmetanko <https://github.com/szmeti>
5// Christian Rackerseder <https://github.com/screendriver>
6
7declare const log: log.RootLogger;
8export = log;
9
10declare namespace log {
11 /**
12 * Log levels
13 */
14 interface LogLevel {
15 TRACE: 0;
16 DEBUG: 1;
17 INFO: 2;
18 WARN: 3;
19 ERROR: 4;
20 SILENT: 5;
21 }
22
23 /**
24 * Possible log level numbers.
25 */
26 type LogLevelNumbers = LogLevel[keyof LogLevel];
27
28 /**
29 * Possible log level descriptors, may be string, lower or upper case, or number.
30 */
31 type LogLevelDesc = LogLevelNumbers
32 | 'trace'
33 | 'debug'
34 | 'info'
35 | 'warn'
36 | 'error'
37 | 'silent'
38 | keyof LogLevel;
39
40 type LoggingMethod = (...message: any[]) => void;
41
42 type MethodFactory = (methodName: string, level: LogLevelNumbers, loggerName: string) => LoggingMethod;
43
44 interface RootLogger extends Logger {
45 /**
46 * If you're using another JavaScript library that exposes a 'log' global, you can run into conflicts with loglevel.
47 * Similarly to jQuery, you can solve this by putting loglevel into no-conflict mode immediately after it is loaded
48 * onto the page. This resets to 'log' global to its value before loglevel was loaded (typically undefined), and
49 * returns the loglevel object, which you can then bind to another name yourself.
50 */
51 noConflict(): any;
52
53 /**
54 * This gets you a new logger object that works exactly like the root log object, but can have its level and
55 * logging methods set independently. All loggers must have a name (which is a non-empty string). Calling
56 * getLogger() multiple times with the same name will return an identical logger object.
57 * In large applications, it can be incredibly useful to turn logging on and off for particular modules as you are
58 * working with them. Using the getLogger() method lets you create a separate logger for each part of your
59 * application with its own logging level. Likewise, for small, independent modules, using a named logger instead
60 * of the default root logger allows developers using your module to selectively turn on deep, trace-level logging
61 * when trying to debug problems, while logging only errors or silencing logging altogether under normal
62 * circumstances.
63 * @param name The name of the produced logger
64 */
65 getLogger(name: string): Logger;
66
67 /**
68 * This will return you the dictionary of all loggers created with getLogger, keyed off of their names.
69 */
70 getLoggers(): { [name: string]: Logger };
71 }
72
73 interface Logger {
74 /**
75 * Available log levels.
76 */
77 readonly levels: LogLevel;
78
79 /**
80 * Plugin API entry point. This will be called for each enabled method each time the level is set
81 * (including initially), and should return a MethodFactory to be used for the given log method, at the given level,
82 * for a logger with the given name. If you'd like to retain all the reliability and features of loglevel, it's
83 * recommended that this wraps the initially provided value of log.methodFactory
84 */
85 methodFactory: MethodFactory;
86
87 /**
88 * Output trace message to console.
89 * This will also include a full stack trace
90 *
91 * @param msg any data to log to the console
92 */
93 trace(...msg: any[]): void;
94
95 /**
96 * Output debug message to console including appropriate icons
97 *
98 * @param msg any data to log to the console
99 */
100 debug(...msg: any[]): void;
101
102 /**
103 * Output info message to console including appropriate icons
104 *
105 * @param msg any data to log to the console
106 */
107 info(...msg: any[]): void;
108
109 /**
110 * Output warn message to console including appropriate icons
111 *
112 * @param msg any data to log to the console
113 */
114 warn(...msg: any[]): void;
115
116 /**
117 * Output error message to console including appropriate icons
118 *
119 * @param msg any data to log to the console
120 */
121 error(...msg: any[]): void;
122
123 /**
124 * This disables all logging below the given level, so that after a log.setLevel("warn") call log.warn("something")
125 * or log.error("something") will output messages, but log.info("something") will not.
126 *
127 * @param level as a string, like 'error' (case-insensitive) or as a number from 0 to 5 (or as log.levels. values)
128 * @param persist Where possible the log level will be persisted. LocalStorage will be used if available, falling
129 * back to cookies if not. If neither is available in the current environment (i.e. in Node), or if you pass
130 * false as the optional 'persist' second argument, persistence will be skipped.
131 */
132 setLevel(level: LogLevelDesc, persist?: boolean): void;
133
134 /**
135 * Returns the current logging level, as a value from LogLevel.
136 * It's very unlikely you'll need to use this for normal application logging; it's provided partly to help plugin
137 * development, and partly to let you optimize logging code as below, where debug data is only generated if the
138 * level is set such that it'll actually be logged. This probably doesn't affect you, unless you've run profiling
139 * on your code and you have hard numbers telling you that your log data generation is a real performance problem.
140 */
141 getLevel(): LogLevel[keyof LogLevel];
142
143 /**
144 * This sets the current log level only if one has not been persisted and can’t be loaded. This is useful when
145 * initializing scripts; if a developer or user has previously called setLevel(), this won’t alter their settings.
146 * For example, your application might set the log level to error in a production environment, but when debugging
147 * an issue, you might call setLevel("trace") on the console to see all the logs. If that error setting was set
148 * using setDefaultLevel(), it will still say as trace on subsequent page loads and refreshes instead of resetting
149 * to error.
150 *
151 * The level argument takes is the same values that you might pass to setLevel(). Levels set using
152 * setDefaultLevel() never persist to subsequent page loads.
153 *
154 * @param level as a string, like 'error' (case-insensitive) or as a number from 0 to 5 (or as log.levels. values)
155 */
156 setDefaultLevel(level: LogLevelDesc): void;
157
158 /**
159 * This enables all log messages, and is equivalent to log.setLevel("trace").
160 *
161 * @param persist Where possible the log level will be persisted. LocalStorage will be used if available, falling
162 * back to cookies if not. If neither is available in the current environment (i.e. in Node), or if you pass
163 * false as the optional 'persist' second argument, persistence will be skipped.
164 */
165 enableAll(persist?: boolean): void;
166
167 /**
168 * This disables all log messages, and is equivalent to log.setLevel("silent").
169 *
170 * @param persist Where possible the log level will be persisted. LocalStorage will be used if available, falling
171 * back to cookies if not. If neither is available in the current environment (i.e. in Node), or if you pass
172 * false as the optional 'persist' second argument, persistence will be skipped.
173 */
174 disableAll(persist?: boolean): void;
175 }
176}