2023-06-22 21:17:40 -07:00
|
|
|
import { importEntities } from 'soapbox/entity-store/actions';
|
|
|
|
import { Entities } from 'soapbox/entity-store/entities';
|
|
|
|
import { type Entity } from 'soapbox/entity-store/types';
|
2023-09-16 04:08:46 -07:00
|
|
|
import { useAppDispatch } from 'soapbox/hooks/useAppDispatch';
|
|
|
|
import { useGetState } from 'soapbox/hooks/useGetState';
|
2023-06-22 21:17:40 -07:00
|
|
|
|
|
|
|
type ChangeEntityFn<TEntity extends Entity> = (entity: TEntity) => TEntity
|
|
|
|
|
|
|
|
function useChangeEntity<TEntity extends Entity = Entity>(entityType: Entities) {
|
|
|
|
const getState = useGetState();
|
|
|
|
const dispatch = useAppDispatch();
|
|
|
|
|
|
|
|
function changeEntity(entityId: string, change: ChangeEntityFn<TEntity>): void {
|
|
|
|
if (!entityId) return;
|
|
|
|
const entity = getState().entities[entityType]?.store[entityId] as TEntity | undefined;
|
|
|
|
if (entity) {
|
|
|
|
const newEntity = change(entity);
|
|
|
|
dispatch(importEntities([newEntity], entityType));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return { changeEntity };
|
|
|
|
}
|
|
|
|
|
|
|
|
export { useChangeEntity, type ChangeEntityFn };
|