@mparticle/web-sdk
Version:
mParticle core SDK for web applications
67 lines (53 loc) • 1.79 kB
text/typescript
import { LogLevelType, SDKInitConfig, SDKLoggerApi } from './sdkRuntimeModels';
export type ILoggerConfig = Pick<SDKInitConfig, 'logLevel' | 'logger'>;
export type IConsoleLogger = Partial<Pick<SDKLoggerApi, 'error' | 'warning' | 'verbose'>>;
export class Logger {
private logLevel: LogLevelType;
private logger: IConsoleLogger;
constructor(config: ILoggerConfig) {
this.logLevel = config.logLevel ?? LogLevelType.Warning;
this.logger = config.logger ?? new ConsoleLogger();
}
public verbose(msg: string): void {
if(this.logLevel === LogLevelType.None)
return;
if (this.logger.verbose && this.logLevel === LogLevelType.Verbose) {
this.logger.verbose(msg);
}
}
public warning(msg: string): void {
if(this.logLevel === LogLevelType.None)
return;
if (this.logger.warning &&
(this.logLevel === LogLevelType.Verbose || this.logLevel === LogLevelType.Warning)) {
this.logger.warning(msg);
}
}
public error(msg: string): void {
if(this.logLevel === LogLevelType.None)
return;
if (this.logger.error) {
this.logger.error(msg);
}
}
public setLogLevel(newLogLevel: LogLevelType): void {
this.logLevel = newLogLevel;
}
}
export class ConsoleLogger implements IConsoleLogger {
public verbose(msg: string): void {
if (console && console.info) {
console.info(msg);
}
}
public error(msg: string): void {
if (console && console.error) {
console.error(msg);
}
}
public warning(msg: string): void {
if (console && console.warn) {
console.warn(msg);
}
}
}