ngx-models
v1.3.0
Published
Models with relations for typescript
Downloads
16
Readme
ngx-models
Why did I do that ... because angular does not ship with a model object. Because dealing with API data has to be reliable and flexible. And because a model object is a key feature in oop ...
So ...
The aim is to transform json data into classes (models) reflecting the original structure of a given api. From there we will edit the data and send them back to the api.
Let’s say the api returns json data shapped like this:
{
"id": 1,
"name": "Leanne Graham",
"username": "Bret",
"email": "[email protected]",
"address": {
"street": "Kulas Light",
"suite": "Apt. 556",
"city": "Gwenborough",
"zipcode": "92998-3874",
"geo": {
"lat": "-37.3159",
"lng": "81.1496"
}
},
"phone": "1-770-736-8031 x56442",
"website": "hildegard.org",
"company": {
"name": "Romaguera-Crona",
"catchPhrase": "Multi-layered client-server neural-net",
"bs": "harness real-time e-markets"
}
}
Creating a model
We can create a model like this one to reflect the json structure of the A.P.I:
// user.ts model
import { Model } from 'ngx-models';
import { Formatters } from 'ngx-models';
import { Company } from './company';
import { Address } from './address';
export class User extends Model {
public id: number;
public name: string;
public username: string;
public email: string;
public phone: string;
public website: string;
public company: any;
public address: any;
attributesHook() {
this.addAttribute('id');
this.addAttribute('name');
// I want to make sure the username attribute value is a string
this.addAttribute('username', '', Formatters.toString);
this.addAttribute('email');
this.addAttribute('phone');
this.addAttribute('website');
// Relation with the Company model
this.addAttribute('company')
.setSingleModelRelation('company', Company);
// Relation with the Address model
this.addAttribute('address')
.setSingleModelRelation('address', Address);
}
get full_name(): string {
return `${this.name} (${this.username})`;
}
}
By doing this we have created a class User with a relation with two other classes Company and Address. The Address model himself has a relation to the Location model.
// model company.ts
import { Formatters } from 'ngx-models';
import { Model } from 'ngx-models';
export class Company extends Model {
public bs: string;
public catchPhrase: string;
public name: string;
attributesHook() {
this.addAttribute('bs');
this.addAttribute('catchPhrase');
this.addAttribute('name');
}
get full_name(): string {
return `${this.name} ${this.bs}`;
}
}
// model adress.ts
export class Address extends Model {
public city: string;
public street: string;
public suite: string;
public zipcode: string;
public geo: Location;
attributesHook() {
this.addAttribute('city', null, Formatters.toString);
this.addAttribute('street', null, Formatters.toString);
this.addAttribute('suite', null, Formatters.toString);
this.addAttribute('zipcode', null, Formatters.toString);
// Relation with the Location model
this.addAttribute('geo', null)
.setSingleModelRelation('geo', Location);
}
}
Model instanciation
To create a model we simply create an instance of our model and pass the json data to its constructor:
this.user = new User(json_data);
console.log(this.user.dump())
console.log('full name:', this.user.full_name)
console.log('city', this.user.address.city)
this.user.address.city = 'London';
console.log('city updated', this.user.address.city)
// returns
// console.log(user.dump())
Model (9) {
id: Number 1,
name: String (13) "Leanne Graham",
username: String (4) "Bret",
email: String (17) "[email protected]",
phone: String (21) "1-770-736-8031 x56442",
website: String (13) "hildegard.org",
company: Model (3) {
bs: String (27) "harness real-time e-markets",
catchPhrase: String (38) "Multi-layered client-server neural-net",
name: String (15) "Romaguera-Crona"
},
address: Model (5) {
city: String (11) "Gwenborough",
street: String (11) "Kulas Light",
suite: String (8) "Apt. 556",
zipcode: String (10) "92998-3874",
geo: Model (2) {
lat: Number -37.3159,
lng: Number 81.1496
}
}
}
full name: Leanne Graham Bret
city: Gwenborough
city updated: London
To send our model back to the api we can simply to something like:
public saveUser() {
this.http.put(url, this.user.toJson(), {options}).subscribe(
(response: HttpResponse) => this.user.patch(response)
(...)
);
}