InvokeAI/invokeai/frontend/web/src/app/logging/useLogger.ts

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

69 lines
1.8 KiB
TypeScript
Raw Normal View History

2023-04-29 06:50:54 +00:00
import { createSelector } from '@reduxjs/toolkit';
import { createLogWriter } from '@roarr/browser-log-writer';
2023-04-29 06:50:54 +00:00
import { useAppSelector } from 'app/store/storeHooks';
import { systemSelector } from 'features/system/store/systemSelectors';
import { isEqual } from 'lodash-es';
import { useEffect, useMemo } from 'react';
import { ROARR, Roarr } from 'roarr';
import {
$logger,
BASE_CONTEXT,
LOG_LEVEL_MAP,
LoggerNamespace,
logger,
} from './logger';
2023-04-29 06:50:54 +00:00
const selector = createSelector(
systemSelector,
(system) => {
const { consoleLogLevel, shouldLogToConsole } = system;
2023-04-29 06:50:54 +00:00
return {
consoleLogLevel,
2023-04-29 07:55:39 +00:00
shouldLogToConsole,
2023-04-29 06:50:54 +00:00
};
},
{
memoizeOptions: {
resultEqualityCheck: isEqual,
},
}
);
export const useLogger = (namespace: LoggerNamespace) => {
const { consoleLogLevel, shouldLogToConsole } = useAppSelector(selector);
2023-04-29 06:50:54 +00:00
// The provided Roarr browser log writer uses localStorage to config logging to console
useEffect(() => {
2023-04-29 07:55:39 +00:00
if (shouldLogToConsole) {
2023-04-29 06:50:54 +00:00
// Enable console log output
localStorage.setItem('ROARR_LOG', 'true');
// Use a filter to show only logs of the given level
localStorage.setItem(
'ROARR_FILTER',
`context.logLevel:>=${LOG_LEVEL_MAP[consoleLogLevel]}`
);
2023-04-29 07:55:39 +00:00
} else {
// Disable console log output
localStorage.setItem('ROARR_LOG', 'false');
2023-04-29 06:50:54 +00:00
}
ROARR.write = createLogWriter();
2023-04-29 07:55:39 +00:00
}, [consoleLogLevel, shouldLogToConsole]);
2023-04-29 06:50:54 +00:00
// Update the module-scoped logger context as needed
useEffect(() => {
// TODO: type this properly
//eslint-disable-next-line @typescript-eslint/no-explicit-any
2023-04-29 06:50:54 +00:00
const newContext: Record<string, any> = {
...BASE_CONTEXT,
2023-04-29 06:50:54 +00:00
};
$logger.set(Roarr.child(newContext));
}, []);
2023-04-29 06:50:54 +00:00
const log = useMemo(() => logger(namespace), [namespace]);
2023-04-29 06:50:54 +00:00
return log;
2023-04-29 06:50:54 +00:00
};