aboutsummaryrefslogtreecommitdiffstats
path: root/packages/renderer/src/utils/log.ts
diff options
context:
space:
mode:
Diffstat (limited to 'packages/renderer/src/utils/log.ts')
-rw-r--r--packages/renderer/src/utils/log.ts50
1 files changed, 50 insertions, 0 deletions
diff --git a/packages/renderer/src/utils/log.ts b/packages/renderer/src/utils/log.ts
new file mode 100644
index 0000000..c17fc2a
--- /dev/null
+++ b/packages/renderer/src/utils/log.ts
@@ -0,0 +1,50 @@
1/*
2 * Copyright (C) 2022 Kristóf Marussy <kristof@marussy.com>
3 *
4 * This file is part of Sophie.
5 *
6 * Sophie is free software: you can redistribute it and/or modify
7 * it under the terms of the GNU Affero General Public License as
8 * published by the Free Software Foundation, version 3.
9 *
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU Affero General Public License for more details.
14 *
15 * You should have received a copy of the GNU Affero General Public License
16 * along with this program. If not, see <https://www.gnu.org/licenses/>.
17 *
18 * SPDX-License-Identifier: AGPL-3.0-only
19 */
20
21import loglevel, { Logger } from 'loglevel';
22import prefix from 'loglevel-plugin-prefix';
23
24if (import.meta.env?.DEV) {
25 loglevel.setLevel('debug');
26} else {
27 // No devtools in production, so there's not point to log anything.
28 loglevel.disableAll();
29}
30
31prefix.reg(loglevel);
32prefix.apply(loglevel, {
33 format(level, name, timestamp) {
34 const timeStr = timestamp.toString();
35 const nameStr = typeof name === 'undefined' ? '' : ` ${name}`;
36 return `[${timeStr}] ${level}${nameStr}:`;
37 },
38});
39
40export function getLogger(loggerName: string): Logger {
41 return loglevel.getLogger(loggerName);
42}
43
44export function silenceLogger(): void {
45 loglevel.disableAll();
46 const loggers = loglevel.getLoggers();
47 Object.keys(loggers).forEach((loggerName) => {
48 loggers[loggerName].disableAll();
49 });
50}