Skip to content

Latest commit

 

History

History
60 lines (49 loc) · 1.24 KB

prepare-process.md

File metadata and controls

60 lines (49 loc) · 1.24 KB

Prepare request and process response

Response processing in some cases are important to get more usable format according to current application.

For example - auto add users avatars using http://placehold.it service.

class UsersDataSource extends DataSource {
  static steps = ['api', 'process'];

  static api = {
    list: api ('GET /users')
  };

  static process = {
    list: users => users.map(user => {
      return {
        ...user,
        avatar: user.avatar ? user.avatar : 'http://placehold.it/30x30'
      }
    });
  };

  loadAll(params) {
    return this.invoke('list', params);
  }
}

Prepare requests is very useful for requests params transformation (serialization): covert form camelCase to snake_case, rename some props, auto adding props etc.

class UsersDataSource extends DataSource {
  static steps = ['prepare', 'api', 'process'];

  static prepare = {
    list: params => ({
      l: [params.limit, params.offset],
      o: params.order,
    }),
  };

  static api = {
    list: api('GET /users'),
  };

  loadAll(params) {
    return this.invoke('list', params);
  }
}
const usersDataSource = new UsersDataSource();
usersDataSource.loadAll({
  limit: 100,
  offset: 2,
  order: 'id',
}); // GET /users?l=100,2&o=id