ngxs-requests-plugin
TypeScript icon, indicating that this package has built-in type declarations

1.0.0 • Public • Published

NgxsRequestsPlugin

NgxsRequestsPlugin is used to store the state of the request and response from the server into the request state

Installation

npm install ngxs-requests-plugin --save

or if you are using yarn
yarn add ngxs-requests-plugin

Connection

Provide withNgxsRequestsPlugin in the same place where you provide provideStore

import { withNgxsRequestsPlugin } from 'ngxs-requests-plugin';

export const appConfig: ApplicationConfig = {
  providers: [
    provideStore([]),
    withNgxsRequestsPlugin([]),
  ],
};

Using

  • Create an empty class with the RequestState decorator

      import { Injectable } from '@angular/core';
      import { RequestState } from 'ngxs-requests-plugin';
    
      @Injectable()
      @RequestState('signInRequest')
      export class SignInRequestState {
      }

    The argument of RequestState decorator will be use as a name of the requests state slice.
    Note: The argument is a required and must be unique for the entire application.
    The @Selector() decorator can be added for selecting the data from the store

    import { Injectable } from '@angular/core';
    import { RequestState } from 'ngxs-requests-plugin';
    
    @Injectable()
    @RequestState('signInRequest')
    export class SignInRequestState {
      @Selector()
      static getRequestState(state: IRequest) {
        return state;
      }
    }

    or it can be added to the separate getter class

    export class SignInRequestGetterState {
      @Selector([
        SignInRequestState,
      ])
      static getRequestState(state: IRequest) {
        return state;
      }
    }

    or reusable getter class can be created

    export class RequestGetterState {
      static getState(stateClass) {
          return createSelector([stateClass], (state: IRequest) => state);
      }
    }

    Ane approach of creating selectors from the NGXS package can be used

  • Use CreateRequestAction for request creation

    @State<AuthStateModel>({
      name: 'auth',
      defaults: {
        token: null,
      },
    })
    export class AuthState implements NgxsAfterBootstrap {  
      constructor(
        private httpClient: HttpClient
      ) {
      }
    
      @Action(SignIn)
      signIn(ctx: StateContext<AuthStateModel>, action: SignIn) {
        const request = this.httpClient.post('serverUrl/signIn', {});
    
        return ctx.dispatch(new CreateRequestAction({
          state: SignInRequestState,
          request,
          successAction: SignInSuccess,
          failAction: SignInFail,
          metadata: 'some additional data'
        }));
      }
    
      @Action(SignInSuccess)
      signInSuccess(ctx: StateContext<AuthStateModel>, action: SignInSuccess) {
        console.log('SignInSuccess');
      }
    
      @Action(SignInFail)
      signInFail(ctx: StateContext<AuthStateModel>, action: SignInSuccess) {
        console.log('SignInFail');
      }
    }

    CreateRequestAction parameters:

    • request - required field. Usually, it's observable returned from the HttpClient
    • state - required field. Class with RequestState decorator
    • successAction - action, which will be called on the successful request
    • failAction - action, which will be called if the request responded with an error
    • metadata - additional data that can be received in successAction and failAction
  • To get the request data and its state, use any NGXS Store method for selecting state. Here are a few examples:

    export class SignInComponent {
      signInRequestState$: Observable<IRequest> = inject(Store).select((state) => state.signInRequest);
    }
    export class SignInComponent {
      signInRequestState$: Observable<IRequest> = inject(Store).select(SignInRequestState.getRequestState);
    }
    export class SignInComponent {
    signInRequestState$: Observable<IRequest> = inject(Store).select(RequestGetterState.getState(SignInRequestState));
    }

    Also, you need to include your classes with RequestState decorator in withNgxsRequestsPlugin provider

    import { withNgxsRequestsPlugin } from 'ngxs-requests-plugin';
    
    export const appConfig: ApplicationConfig = {
      providers: [
        provideStore([],),
        withNgxsRequestsPlugin([
          SignInRequestState,
        ]),
      ],
    };

Readme

Keywords

Package Sidebar

Install

npm i ngxs-requests-plugin

Weekly Downloads

14

Version

1.0.0

License

MIT

Unpacked Size

45.4 kB

Total Files

20

Last publish

Collaborators

  • logvinoleg89
  • 2muchcoffee
  • rshchpkn