import { useState } from 'react'; import { useApi } from 'soapbox/hooks'; import { useCreateEntity } from './useCreateEntity'; import { useDeleteEntity } from './useDeleteEntity'; import { parseEntitiesPath } from './utils'; import type { Entity } from '../types'; import type { EntitySchema, ExpandedEntitiesPath } from './types'; interface UseEntityActionsOpts { schema?: EntitySchema } interface EntityActionEndpoints { post?: string delete?: string } function useEntityActions( expandedPath: ExpandedEntitiesPath, endpoints: EntityActionEndpoints, opts: UseEntityActionsOpts = {}, ) { const api = useApi(); const { entityType, path } = parseEntitiesPath(expandedPath); const [isLoading, setIsLoading] = useState(false); const deleteEntity = useDeleteEntity(entityType, (entityId) => { if (!endpoints.delete) return Promise.reject(endpoints); return api.delete(endpoints.delete.replace(':id', entityId)) .finally(() => setIsLoading(false)); }); const create = useCreateEntity(path, { method: 'post', url: endpoints.post }, opts); const createEntity: typeof create = async (...args) => { await create(...args); setIsLoading(false); }; return { createEntity, deleteEntity, isLoading, }; } export { useEntityActions };