Skip to main content
Version: 5.0

Computed Properties

Resource classes are just normal classes, so any common derived data can just be added as getters to the class itself.

import { Resource } from '@rest-hooks/rest';

class User extends Resource {
readonly id: number | undefined = undefined;
readonly firstName: string = '';
readonly lastName: string = '';
readonly username: string = '';
readonly email: string = '';

pk() {
return this.id?.toString();
}

static urlRoot = '/users/';

get fullName() {
return `${this.firstName} ${this.lastName}`;
}
}

If the computations are expensive feel free to add some memoization.

import { Resource } from '@rest-hooks/rest';
import { memoize } from 'lodash';

class User extends Resource {
truelyExpensiveValue = memoize(() => {
// compute that expensive thing!
});
}