hookifyResource
hookifyResource()
Turns any Resource (collection of RestEndpoints) into a collection
of hooks that return RestEndpoints.
info
TypeScript >=4.3 is required for generative types to work correctly.
▶api/ArticleResource.ts
import React from 'react';import { createResource, hookifyResource, Entity } from '@data-client/rest';class Article extends Entity {id = '';title = '';content = '';pk() {return this.id;}}const AuthContext = React.createContext('');const ArticleResourceBase = createResource({urlPrefix: 'http://test.com',path: '/article/:id',schema: Article,});export const ArticleResource = hookifyResource(ArticleResourceBase,function useInit() {const accessToken = React.useContext(AuthContext);return {headers: {'Access-Token': accessToken,},};},);
▶ArticleDetail.tsx
import { ArticleResource } from './api/ArticleResource';function ArticleDetail({ id }) {const article = useSuspense(ArticleResource.useGet(), { id });const updateArticle = ArticleResource.useUpdate();const ctrl = useController();const onSubmit = (body: any) => ctrl.fetch(updateArticle, { id }, body);return <ArticleForm onSubmit={onSubmit} initialValues={article} />;}render(<ArticleDetail id="1" />);
Members
Assuming you use the unchanged result of createResource(), these will be your methods
useGet()
- method: 'GET'
- path:
path
- schema: schema
// GET //test.com/api/abc/xyz
hookifyResource(
createResource({ urlPrefix: '//test.com', path: '/api/:group/:id' }),
).useGet()({
group: 'abc',
id: 'xyz',
});
Commonly used with useSuspense(), Controller.invalidate
useGetList()
- method: 'GET'
- path:
shortenPath(path)
- Removes the last argument:
hookifyResource(createResource({ path: '/:first/:second' })).useGetList()
.path === '/:first';
hookifyResource(createResource({ path: '/:first' })).useGetList().path ===
'/';
- Removes the last argument:
- schema: [schema]
// GET //test.com/api/abc?isExtra=xyz
hookifyResource(
createResource({ urlPrefix: '//test.com', path: '/api/:group/:id' }),
).useGetList()({
group: 'abc',
isExtra: 'xyz',
});
Commonly used with useSuspense(), Controller.invalidate
useCreate()
- method: 'POST'
- path:
shortenPath(path)
- Removes the last argument:
hookifyResource(createResource({ path: '/:first/:second' })).useCreate()
.path === '/:first';
hookifyResource(createResource({ path: '/:first' })).useCreate().path ===
'/';
- Removes the last argument:
- schema:
schema
// POST //test.com/api/abc
// BODY { "title": "winning" }
hookifyResource(
createResource({ urlPrefix: '//test.com', path: '/api/:group/:id' }),
).useCreate()({ group: 'abc' }, { title: 'winning' });
Commonly used with Controller.fetch
useUpdate()
- method: 'PUT'
- path:
path
- schema:
schema
// PUT //test.com/api/abc/xyz
// BODY { "title": "winning" }
hookifyResource(
createResource({ urlPrefix: '//test.com', path: '/api/:group/:id' }),
).useUpdate()({ group: 'abc', id: 'xyz' }, { title: 'winning' });
Commonly used with Controller.fetch
usePartialUpdate()
- method: 'PATCH'
- path:
path
- schema:
schema
// PATCH //test.com/api/abc/xyz
// BODY { "title": "winning" }
hookifyResource(
createResource({ urlPrefix: '//test.com', path: '/api/:group/:id' }),
).usePartialUpdate()({ group: 'abc', id: 'xyz' }, { title: 'winning' });
Commonly used with Controller.fetch
useDelete()
- method: 'DELETE'
- path:
path
- schema: new schema.Invalidate(schema)
- process:
(value, params) {
return value && Object.keys(value).length ? value : params;
},
// DELETE //test.com/api/abc/xyz
hookifyResource(
createResource({ urlPrefix: '//test.com', path: '/api/:group/:id' }),
).useDelete()({
group: 'abc',
id: 'xyz',
});
Commonly used with Controller.fetch