Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/darekf77/ng2-rest
Isomorphic, simple, robust REST API library for Browser and NodeJS, ( ts / js ) apps
https://github.com/darekf77/ng2-rest
angular-httpclient-alternative angular-rest isomorphic jsonp nodejs-library react-rest request-cancellation rest rest-api rxjs-observables vue-rest
Last synced: 3 months ago
JSON representation
Isomorphic, simple, robust REST API library for Browser and NodeJS, ( ts / js ) apps
- Host: GitHub
- URL: https://github.com/darekf77/ng2-rest
- Owner: darekf77
- Created: 2016-05-13T08:59:37.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2024-05-22T04:37:49.000Z (8 months ago)
- Last Synced: 2024-05-22T12:39:43.813Z (8 months ago)
- Topics: angular-httpclient-alternative, angular-rest, isomorphic, jsonp, nodejs-library, react-rest, request-cancellation, rest, rest-api, rxjs-observables, vue-rest
- Language: TypeScript
- Homepage:
- Size: 9.3 MB
- Stars: 26
- Watchers: 5
- Forks: 6
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
## ng2-rest ##
Robust isomorphic REST framework for browser (Angular, React etc.) and backend (NodeJS) JavaScript/TypeScript apps.
Features:
- Compatible with Angular (2+) (newest 13,14 also...) , React, Vue , NodeJS (works everywhere)
- Compatible with RxJS operators (exhaustMap, switchMap, request cancelation etc.)
- Based on [axios](https://axios-http.com/) => excellent alternative to Angular's [HttpClient](https://angular.io/api/common/http/HttpClient)
- JSONP api request handling
- Transfer class instance from server to client and back
- Elegant way of dealing with REST api ( *similar to ExpressJS routes definitions* )(more documentation soon... )
To install this package run:
npm install ng2-rest --save
Import Resource class:
```ts
import { Resource } from 'ng2-rest/browser';
```Resource
========Fit you existing API (not only REST) into new fluent objects with **Resource**
class observables. Use power of **async** in new angular templates;**template.html**
```html
Users:
-
{{user.id}} {{user.fullName()}}
Update
loading users...
```
**component.ts**
```ts
class User {
name: string;
surname: string;
id: number;
fullName() {
return `Surname: ${this.surname}, Name: ${this.name}`;
}
}
// Express.js style url endpoint model
// you can ommit "" part is you don't wanna see response interface
// also you can ommit third argument ",User" is you don't wanna
// map response object to User class objects
const rest = Resource.create("http://yourbackend.com/api","users/:id",{'':User} )
class UserComponent {
// Prepare your beautiful interface
model = {
allUsers: () => rest.model()
.array
.get()
.observable // Observable resposne (useful for Angular 2+ html templates)
.pipe( map({ body } => body.json) ) // get all users, body.json => User[]
userBy: (id) => rest.model({id})
.get() // Promise response by default
.then({ body } => console.log(body.json)) // get user by id, body.json => User
update: async (user:User) =>{
try {
await rest.model({id:user.id}).put(user) // Promise response by default
alert('Update sucess')
} catch(e) {
alert(e)
}
}
}
constructor() { }
}
```
Specification
============
Example **UrlParams[]** :
`[ { sort: true },{ filter: 'id,5' }, { filter: 'name,test' } ]`
| Name | Parameters | Description |
| :---: | --- | ---: |
| **.array.** | get,post,put,head,delete,jsonp | for everything, but with arrays |
| **get** | `UrlParams[] ` | get model by parameters |
| **post** | `model, UrlParams[] ` | post object model |
| **put** | `model, UrlParams[]` | put object model |
| **head** | `model, UrlParams[]` | get head for model |
| **delete** | `UrlParams[]` | remove object by params |
| **jsonp** | `UrlParams[]` | get jsonp data |
# Production mode
===
Nice things to do in production mode:
**1. Disable warnings.**
If you don't wanna see warning, disable it like this:
```ts
if (environment.production) {
Resource.enableWarnings = false;
}
```
# Angular 2+ ngZone
If you are using Angular 2+ you need to do this in your root **app.component**:
```ts
constructor(zone:NgZone) {
Resource.initAngularNgZone(zone)
}
```