0.4.1 • Published 2 years ago

ehttp v0.4.1

Weekly downloads
131
License
-
Repository
-
Last release
2 years ago

EHTTP

EHTTP is a Angular library. Toastr and jQuery is required for user side exception UI. The goal is to create a simple core library that makes HTTP requests in Abstractional classes.

Current Version

0.4.1

Install

npm

npm install --save ehttp

Usage

In your app.module.ts (bootstrap module)

import {EHTTPModule} from 'ehttp';
@NgModule({
  imports: [
    BrowserModule,
    BrowserAnimationsModule,
    EHTTPModule.forRoot()
  ]
})

In your any.service.ts

GET Request

import {GET} from 'ehttp';

@Injectable()
export class AnyService {
  constructor(private _get: GET) {}

  /**
   * Get Test Data for demonstration
   * @returns {Observable<any>}
   */
  public get(id?): Observable<any> {
    const optionalRequestSpecificHeaders = {
      "Content-Type": "application/json"
    }
    const configs: RequestConfigInterface = {
        observe: 'body'
    }
    return this._get
      .setHeaders(optionalRequestSpecificHeaders)
      .setApi('https://jsonplaceholder.typicode.com/posts')
      .setConfigs(configs)
      .request(id);
  }
}

POST Request

import {POST} from 'ehttp';

@Injectable()
export class AnyService {
  constructor(private _post: POST) {}

  /**
   * Get Test Data for demonstration
   * @returns {Observable<any>}
   */
  public post(payload: any): Observable<any> {
    const optionalRequestSpecificHeaders = {
      "Content-Type": "application/json"
    }
    const configs: RequestConfigInterface = {
            observe: 'body'
    }
    return this._post
      .setHeaders(optionalRequestSpecificHeaders)
      .setApi('https://jsonplaceholder.typicode.com/posts')
      .setPayload(payload)
      .setConfigs(configs)
      .request();
  }
}

PUT Request

import {PUT} from 'ehttp';

@Injectable()
export class AnyService {
  constructor(private _put: PUT) {}

  /**
   * Get Test Data for demonstration
   * @returns {Observable<any>}
   */
  public put(payload: any, id?: any): Observable<any> {
    const optionalRequestSpecificHeaders = {
      "Content-Type": "application/json"
    }
    const configs: RequestConfigInterface = {
        observe: 'body'
    }
    return this._put
      .setPayload(payload)
      .setHeaders(optionalRequestSpecificHeaders)
      .setApi('https://jsonplaceholder.typicode.com/posts')
      .setConfigs(configs)
      .request(id);
  }
}

PATCH Request

import {PATCH} from 'ehttp';

@Injectable()
export class AnyService {
  constructor(private _patch: PATCH) {}

  /**
   * Get Test Data for demonstration
   * @returns {Observable<any>}
   */
  public patch(payload: any, id?: any): Observable<any> {
    const optionalRequestSpecificHeaders = {
      "Content-Type": "application/json"
    }
    return this._patch
      .setHeaders(optionalRequestSpecificHeaders)
      .setPayload(payload)
      .setApi('https://jsonplaceholder.typicode.com/posts')
      .request(id);
  }
}

DELETE Request

import {DELETE} from 'ehttp';

@Injectable()
export class AnyService {
  constructor(private _delete: DELETE) {}

  /**
   * Get Test Data for demonstration
   * @returns {Observable<any>}
   */
  public delete(id?: any): Observable<any> {
    const optionalRequestSpecificHeaders = {
      "Content-Type": "application/json"
    }
    return this._delete
      .setHeaders(optionalRequestSpecificHeaders)
      .setApi('https://jsonplaceholder.typicode.com/posts')
      .request(id);
  }
}

Configurations

You can path custom default configuration to Module

EHTTPModule.forRoot(
  {
    headers: any;
  }
)

Headers

Default headers for all XMLHTTP requests

Support

Tested in Chrome , Firefox , IE 9-11 , Edge , Safari

Copyright

Copyright © 2020

0.4.1

2 years ago

0.4.0

2 years ago

0.3.2

4 years ago

0.3.3

4 years ago

0.3.0

4 years ago

0.3.1

4 years ago

0.2.7

4 years ago

0.2.6

5 years ago

0.2.5

5 years ago

0.2.4

6 years ago

0.2.3

6 years ago

0.2.2

6 years ago

0.2.1

6 years ago

0.2.0

6 years ago

0.1.7

6 years ago

0.1.6

6 years ago

0.1.5

6 years ago

0.1.4

6 years ago

0.1.3

6 years ago

0.1.2

6 years ago

0.1.1

6 years ago

0.1.0

6 years ago

0.0.9

6 years ago

0.0.8

6 years ago

0.0.7

6 years ago

0.0.6

6 years ago

0.0.5

6 years ago

0.0.4

6 years ago

0.0.3

6 years ago

0.0.2

6 years ago

0.0.1

6 years ago