UNPKG

ra-core

Version:

Core components of react-admin, a frontend Framework for building admin applications on top of REST services, using ES6, React

75 lines 3.05 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.removeDoubleSlashes = exports.useCreatePath = void 0; const react_1 = require("react"); const useBasename_1 = require("./useBasename.cjs"); /** * Get a callback to create a link to a given page in the admin app. * * The callback expects an object as parameter, containing the following properties: * - type: 'list', 'edit', 'show' or 'create' * - resource * - id (optional), for 'edit' or 'show' pages * * This is used internally by react-admin to allow default components to work * in applications that are mounted on a sub path, e.g. '/admin'. If your app * is mounted in the root path, you don't need it, and you can create links by * hand, e.g. '/articles/1/show'. * * @example * import { useCreatePath, useRecordContext, useNavigate } from 'react-admin'; * * const PostEditButton = () => { * const createPath = useCreatePath(); * const record = useRecordContext(); * const navigate = useNavigate(); * * const handleClick = () => { * const link = createPath({ * type: 'edit', * resource: 'posts', * id: record.id * }); * navigate(link); * }; * * return <button onClick={handleClick}>Edit Post</button>; * }; */ const useCreatePath = () => { const basename = (0, useBasename_1.useBasename)(); return (0, react_1.useCallback)(({ resource, id, type }) => { if (['list', 'create', 'edit', 'show'].includes(type) && !resource) { throw new Error('Cannot create a link without a resource. You must provide the resource name.'); } switch (type) { case 'list': return (0, exports.removeDoubleSlashes)(`${basename}/${resource}`); case 'create': return (0, exports.removeDoubleSlashes)(`${basename}/${resource}/create`); case 'edit': { if (id == null) { // maybe the id isn't defined yet // instead of throwing an error, fallback to list link return (0, exports.removeDoubleSlashes)(`${basename}/${resource}`); } return (0, exports.removeDoubleSlashes)(`${basename}/${resource}/${encodeURIComponent(id)}`); } case 'show': { if (id == null) { // maybe the id isn't defined yet // instead of throwing an error, fallback to list link return (0, exports.removeDoubleSlashes)(`${basename}/${resource}`); } return (0, exports.removeDoubleSlashes)(`${basename}/${resource}/${encodeURIComponent(id)}/show`); } default: return type; } }, [basename]); }; exports.useCreatePath = useCreatePath; const removeDoubleSlashes = (path) => path.replace('//', '/'); exports.removeDoubleSlashes = removeDoubleSlashes; //# sourceMappingURL=useCreatePath.js.map