SerializeJS
Examples:
- Create model and extend the
SerializeModel
abstract class:
export interface IDarkStore {
id: string;
netName: string;
name: string;
coordinates: string[];
}
export class DarkStore extends SerializeModel {
public id: string;
public netName: string;
public name: string;
public coordinates: string[];
public static replacingMap: TReplacingMap<DarkStore> = {
"net_name": "netName",
"darkstore_name": "name",
"darkstore_coordinates": "coordinates",
};
constructor(props: IDarkStore) {
super();
this.id = props.id;
this.netName = props.netName;
this.name = props.name;
this.coordinates = props.coordinates;
}
public get polygon(): number[][] {
return this.coordinates.map(coordinate => {
const [lat, lng] = coordinate.split(":");
return [
Number(lat),
Number(lng),
];
});
}
}
- Use the
Serialize
helper:
export class DarkStoreApi extends BaseApi {
constructor() {
super();
}
public getDarkStoreList = async (): Promise<DarkStore[]> => {
const response = await this.getRequest("darkstore");
return new Serialize<DarkStore, DarkStore[], IDarkStore>({
data: response,
instanceConstructor: DarkStore,
}).getModel();
};
}
define the generic types DarkStore
as base type, DarkStore[]
as generic type of base (as returned) & IDarkStore
as type definition of constructor arguments.
Use the getModel
-method to getting class instance.
If you need specify exactly the root of the response, for example:
You have response like:
{
"data": {
"list": {
"totalCount": 2,
"items": [
{
"modelName": 1
},
{
"modelName": 2
}
]
}
},
"errors": {
},
"message": {
}
}
So, you able to specify the root of response like that:
import {Serialize} from "./serialize";
new Serialize<Model, Model[], IModel>({
response: data,
root: 'data -> list -> items'
})
If you have complicated model, that containing another model, you can use decorators:
import {serialized} from "./serialize";
interface IUser {
name: string;
age: number;
email: string;
}
class User implements IUser {
public name: string;
public age: number;
public email: string;
constructor(props: IUser) {
this.name = props.name;
this.age = props.age;
this.email = props.email;
}
}
interface IEvent {
eventName: string;
userList: IUser[];
}
class Event implements IEvent {
public eventName: string;
@serialized<User, User[]>(User)
public userList: IUser[];
constructor(props: IEvent) {
this.eventName = props.eventName;
this.user = props.user;
}
}