Skip to content

bmgandre/angular-object-logger

Repository files navigation

Build Status codecov

NPM

angular-object-logger

Send objects logs to console or web. angular-object-logger provides a multi target logger service with filtering capabilities.

Installing

Using npm install angular-object-logger alongside with its peer dependencies :

npm install angular-object-logger --save
npm install @angular/common --save
npm install stacktrace-js --save

Configure your project

import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { HttpClientModule } from '@angular/common/http';
import { AppComponent } from './app.component';

import {
  LoggerServiceModule,
  LoggerService,
  LoggerFactoryConfig,
  LoggerFactoryService
} from 'angular-object-logger';

@NgModule({
  declarations: [
    AppComponent
  ],
  imports: [
    BrowserModule,
    HttpClientModule,
    LoggerServiceModule
  ],
  providers: [
    { provide: LoggerEnvironmentConfig, useValue: environment }
  ],
  bootstrap: [ AppComponent ]
})
export class AppModule { }

Edit environment.ts and configure global and target filters:

export const environment = {
  production: false,
  logger: {
    filters: [
      { source: '.*', minlevel: 'warn', maxlevel: 'fatal' }
    ],
    consoleTarget: {
      filters: [
        { source: 'AppComponent', minlevel: 'info', maxlevel: 'fatal' },
        { source: 'HomeComponent', level: 'info' },
        { source: 'SearchComponent', levels: [ 'trace', 'debug' ] },
      ]
    },
    webTarget: {
      endpoint: 'http://localhost:4000/'
    }
  }
};
@Component({
  selector: 'app-playground',
  template: `<div></div>`
})
class AppComponent {
  constructor(
    private loggerFactory: LoggerFactoryService
  ) {
    const logger = loggerFactory.createLogger(this);

    logger.trace('string log');
    logger.debug('String format log {0}: {1}', { name: 'Andre' }, { x: 10, y: 20 });
    logger.info({ list: ['object', 'log'] });
    logger.warn('string message with exception', new Error());
    logger.error({ message: 'object with exception' }, new Error());
    logger.fatal('string log message with exception', new Error());
  }
}

Development

To generate all *.js, *.d.ts and *.metadata.json files:

npm run build

To lint all *.ts files:

npm run lint

License

MIT © André Gomes

Packages

No packages published

Languages