Define Async Methods (Endpoints)
Endpoints are the methods of your data. Entities are a type of Schema, which define the data model. Resources are
a collection of endpoints
around one schema
.
- Rest
- GraphQL
- Promise
npm install --save @data-client/rest
▶api/Todo
import { Entity } from '@data-client/rest';import { createResource } from '@data-client/rest/next';export class Todo extends Entity {id = 0;userId = 0;title = '';completed = false;pk() {return `${this.id}`;}static key = 'Todo';}export const TodoResource = createResource({urlPrefix: 'https://jsonplaceholder.typicode.com',path: '/todos/:id',schema: Todo,searchParams: {} as { userId?: string | number } | undefined,});
▶Methods
import { TodoResource } from './api/Todo';// GET https://jsonplaceholder.typicode.com/todos/5TodoResource.get({ id: 5 });// GET https://jsonplaceholder.typicode.com/todosTodoResource.getList();// GET https://jsonplaceholder.typicode.com/todos?userId=1TodoResource.getList({ userId: 1 });// POST https://jsonplaceholder.typicode.com/todosTodoResource.create({ title: 'my todo' });// PUT https://jsonplaceholder.typicode.com/todos/5TodoResource.update({ id: 5 }, { title: 'my todo' });// PATCH https://jsonplaceholder.typicode.com/todos/5TodoResource.partialUpdate({ id: 5 }, { title: 'my todo' });// DELETE https://jsonplaceholder.typicode.com/todos/5TodoResource.delete({ id: 5 });
npm install --save @data-client/graphql
api/Todo
import { GQLEndpoint, GQLEntity } from '@data-client/graphql';const gql = new GQLEndpoint('/');export class Todo extends GQLEntity {title = '';completed = false;static key = 'Todo';}export const TodoResource = {getList: gql.query(`query GetTodos {todo {idtitlecompleted}}`,{ todos: new schema.Collection([Todo]) },),update: gql.mutation(`mutation UpdateTodo($todo: Todo!) {updateTodo(todo: $todo) {idtitlecompleted}}`,{ updateTodo: Todo },),};
npm install --save @data-client/endpoint
In case you have existing class and/or api definitions, you can use Endpoint and schema.Entity to make them useable in RDC.
▶existing/Todo
export class Todo {id = 0;userId = 0;title = '';completed = false;}/* These are just examples but it could be any promise API */export const getTodo = (id: string) =>fetch(`https://jsonplaceholder.typicode.com/todos/${id}`).then(res =>res.json(),);export const getTodoList = () =>fetch('https://jsonplaceholder.typicode.com/todos').then(res => res.json());export const updateTodo = (id: string, body: Partial<Todo>) =>fetch(`https://jsonplaceholder.typicode.com/todos/${id}`, {method: 'PUT',body: JSON.stringify(body),}).then(res => res.json());export const createTodo = (body: Partial<Todo>) =>fetch(`https://jsonplaceholder.typicode.com/todos`, {method: 'POST',body: JSON.stringify(body),}).then(res => res.json());
▶api/Todo
import { schema, Endpoint } from '@data-client/endpoint';import {Todo,getTodo,getTodoList,updateTodo,createTodo,} from '../existing/Todo';export const TodoEntity = schema.Entity(Todo, { key: 'Todo' });export const TodoResource = {get: new Endpoint(getTodo, { schema: TodoEntity }),getList: new Endpoint(getTodoList, {schema: new schema.Collection([TodoEntity]),}),update: new Endpoint(updateTodo, { schema: TodoEntity, sideEffect: true }),create: new Endpoint(createTodo, { schema: TodoEntity, sideEffect: true }),};
It's highly encouraged to design APIs with consistent patterns. Because of this, you can extend our protocol specific helpers. After choosing your protocol, you can read up on the full docs for reach protocol REST, GraphQL, Image/binary, Websockets+SSE
To use your own protocol or existing helpers, use the lower-level primitives from
@data-client/endpoint like Endpoint and schema.Entity.
[See Promise
tab above]