Skip to content

Advanced logging middleware for @ngrx/store applications

License

Notifications You must be signed in to change notification settings

klinem/ngrx-store-logger

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

17 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

ngrx-store-logger

Advanced logging for @ngrx/store applications, ported from redux-logger.

ngrx-store-logger

Dependencies

ngrx-store-logger depends on @ngrx/store and Angular 2.

Usage

npm install ngrx-store-logger --save
  1. Configure your ngrx store as normal using provideStore.
  2. Using the provided loggerMiddleware function, specify option overrides.
import {bootstrap} from 'angular2/platform/browser';
import {TodoApp} from './todo-app';
import {provideStore} from "@ngrx/store";
import {loggerMiddleware} from "ngrx-store-logger";

export function main() {
  return bootstrap(TodoApp, [
      provideStore({todos, visibilityFilter}),
      //taking all defaults
      ...loggerMiddleware()
  ])
  .catch(err => console.error(err));
}

document.addEventListener('DOMContentLoaded', main);

API

loggerMiddleware(options : LoggerOptions = {})

Initializes logger middleware with appropriate options (logical defaults if no options supplied)

Arguments

  • options (Object): Available logger options
Options
interface LoggerOptions {
    level? : 'log' | 'console' | 'warn' | 'error' | 'info'; //default log
    collapsed? : boolean; //Should log group be collapsed? default: false
    duration? : boolean; //Print duration with action? default: false
    timestamp? : boolean; //Print timestamp with action? default: true
    stateTransformer? : (state : Object) => Object; //Transform state before print default: state => state
    actionTransformer? : (actn : Object) => Object; //Transform action before print default: actn => actn
    colors? : {
        title: (action : Object) => string;
        prevState: (prevState : Object) => string;
        action: (action: Object) => string;
        nextState: (nextState : Object) => string;
        error: (error: any, prevState: Object) => string;
    }
}

About

Advanced logging middleware for @ngrx/store applications

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 100.0%