add log level setting

This commit is contained in:
jeffvli
2025-12-07 00:50:09 -08:00
parent 1507aff8e6
commit 512a769742
4 changed files with 109 additions and 5 deletions
+7
View File
@@ -531,6 +531,7 @@
"lyrics": "lyrics",
"transcoding": "transcoding",
"discord": "discord",
"logger": "logger",
"playerFilters": "player filters"
},
"sidebar": {
@@ -780,6 +781,12 @@
"lyricFetchProvider": "providers to fetch lyrics from",
"lyricOffset_description": "offset the lyric by the specified amount of milliseconds",
"lyricOffset": "lyric offset (ms)",
"logLevel": "log level",
"logLevel_description": "sets the minimum log level to display. debug shows all logs, error only shows errors",
"logLevel_optionDebug": "debug",
"logLevel_optionError": "error",
"logLevel_optionInfo": "info",
"logLevel_optionWarn": "warn",
"minimizeToTray_description": "minimize the application to the system tray",
"minimizeToTray": "minimize to tray",
"minimumScrobblePercentage_description": "the minimum percentage of the song that must be played before it is scrobbled",
@@ -2,6 +2,7 @@ import { Fragment } from 'react/jsx-runtime';
import { AnalyticsSettings } from '/@/renderer/features/settings/components/advanced/analytics-settings';
import { ExportImportSettings } from '/@/renderer/features/settings/components/advanced/export-import-settings';
import { LoggerSettings } from '/@/renderer/features/settings/components/advanced/logger-settings';
import { CacheSettings } from '/@/renderer/features/settings/components/window/cache-settngs';
import { UpdateSettings } from '/@/renderer/features/settings/components/window/update-settings';
import { Divider } from '/@/shared/components/divider/divider';
@@ -11,6 +12,7 @@ const sections = [
{ component: UpdateSettings, key: 'update' },
{ component: AnalyticsSettings, key: 'analytics' },
{ component: ExportImportSettings, key: 'export-import' },
{ component: LoggerSettings, key: 'logger' },
{ component: CacheSettings, key: 'cache' },
];
@@ -0,0 +1,87 @@
import { useTranslation } from 'react-i18next';
import {
SettingOption,
SettingsSection,
} from '/@/renderer/features/settings/components/settings-section';
import { logFn, LogLevel } from '/@/renderer/utils/logger';
import { Select } from '/@/shared/components/select/select';
const DEFAULT_LOG_LEVEL: LogLevel = process.env.NODE_ENV === 'production' ? 'info' : 'debug';
export const LoggerSettings = () => {
const { t } = useTranslation();
const getCurrentLogLevel = (): LogLevel => {
const stored = localStorage.getItem('log_level');
if (stored && ['debug', 'error', 'info', 'warn'].includes(stored)) {
return stored as LogLevel;
}
return DEFAULT_LOG_LEVEL;
};
const handleLogLevelChange = (value: null | string) => {
if (!value) return;
const logLevel = value as LogLevel;
localStorage.setItem('log_level', logLevel);
// Update the logger dynamically
if (logFn.updateLogLevel) {
logFn.updateLogLevel(logLevel);
}
};
const loggerOptions: SettingOption[] = [
{
control: (
<Select
data={[
{
label: t('setting.logLevel', {
context: 'optionDebug',
postProcess: 'titleCase',
}),
value: 'debug',
},
{
label: t('setting.logLevel', {
context: 'optionInfo',
postProcess: 'titleCase',
}),
value: 'info',
},
{
label: t('setting.logLevel', {
context: 'optionWarn',
postProcess: 'titleCase',
}),
value: 'warn',
},
{
label: t('setting.logLevel', {
context: 'optionError',
postProcess: 'titleCase',
}),
value: 'error',
},
]}
defaultValue={getCurrentLogLevel()}
onChange={handleLogLevelChange}
/>
),
description: t('setting.logLevel', {
context: 'description',
postProcess: 'sentenceCase',
}),
title: t('setting.logLevel', { postProcess: 'sentenceCase' }),
},
];
return (
<SettingsSection
options={loggerOptions}
title={t('page.setting.logger', { postProcess: 'sentenceCase' })}
/>
);
};
+13 -5
View File
@@ -27,6 +27,7 @@ interface Logger {
debug: LogFn;
error: LogFn;
info: LogFn;
updateLogLevel: (level: LogLevel) => void;
warn: LogFn;
}
@@ -73,14 +74,21 @@ setInterval(() => {
}, DEBOUNCE_INTERVAL);
class ConsoleLogger implements Logger {
readonly debug: LogFn;
readonly error: LogFn;
readonly info: LogFn;
readonly warn: LogFn;
debug: LogFn = NO_OP;
error: LogFn = NO_OP;
info: LogFn = NO_OP;
updateLogLevel: (level: LogLevel) => void;
warn: LogFn = NO_OP;
constructor() {
const level = localStorage.getItem('log_level') || DEFAULT_LOG_LEVEL;
const level = (localStorage.getItem('log_level') || DEFAULT_LOG_LEVEL) as LogLevel;
this.initializeLoggers(level);
this.updateLogLevel = (newLevel: LogLevel) => {
this.initializeLoggers(newLevel);
};
}
private initializeLoggers(level: LogLevel) {
// Create timestamp wrapper function with colors and debouncing
const withTimestamp = (logLevel: string): LogFn => {
return (message?: any, options?: { category?: string; meta?: any }) => {