ConceptPortal-public/rsconcept/frontend/src/context/RSFormContext.tsx

158 lines
4.2 KiB
TypeScript
Raw Normal View History

2023-07-20 17:11:03 +03:00
import { createContext, useState, useContext, useMemo, useCallback } from 'react';
import { IConstituenta, IRSForm } from '../utils/models';
2023-07-15 17:46:19 +03:00
import { useRSFormDetails } from '../hooks/useRSFormDetails';
import { ErrorInfo } from '../components/BackendError';
import { useAuth } from './AuthContext';
2023-07-20 17:11:03 +03:00
import { BackendCallback, deleteRSForm, getTRSFile, patchConstituenta, patchRSForm, postClaimRSForm } from '../utils/backendAPI';
import { toast } from 'react-toastify';
2023-07-15 17:46:19 +03:00
interface IRSFormContext {
schema?: IRSForm
active?: IConstituenta
error: ErrorInfo
loading: boolean
processing: boolean
isEditable: boolean
isClaimable: boolean
2023-07-20 17:11:03 +03:00
forceAdmin: boolean
readonly: boolean
isTracking: boolean
2023-07-15 17:46:19 +03:00
setActive: (cst: IConstituenta | undefined) => void
2023-07-20 17:11:03 +03:00
setForceAdmin: (value: boolean) => void
setReadonly: (value: boolean) => void
toggleTracking: () => void
2023-07-15 17:46:19 +03:00
reload: () => void
2023-07-16 22:25:23 +03:00
update: (data: any, callback?: BackendCallback) => void
destroy: (callback: BackendCallback) => void
claim: (callback: BackendCallback) => void
2023-07-16 22:25:23 +03:00
download: (callback: BackendCallback) => void
2023-07-18 14:55:40 +03:00
cstUpdate: (data: any, callback: BackendCallback) => void
2023-07-15 17:46:19 +03:00
}
export const RSFormContext = createContext<IRSFormContext>({
schema: undefined,
active: undefined,
error: undefined,
loading: false,
processing: false,
isEditable: false,
isClaimable: false,
2023-07-20 17:11:03 +03:00
forceAdmin: false,
readonly: false,
isTracking: true,
2023-07-15 17:46:19 +03:00
setActive: () => {},
2023-07-20 17:11:03 +03:00
setForceAdmin: () => {},
setReadonly: () => {},
toggleTracking: () => {},
2023-07-15 17:46:19 +03:00
reload: () => {},
2023-07-16 22:25:23 +03:00
update: () => {},
2023-07-15 17:46:19 +03:00
destroy: () => {},
claim: () => {},
2023-07-16 22:25:23 +03:00
download: () => {},
2023-07-18 14:55:40 +03:00
cstUpdate: () => {},
2023-07-15 17:46:19 +03:00
})
interface RSFormStateProps {
id: string
children: React.ReactNode
}
export const RSFormState = ({ id, children }: RSFormStateProps) => {
const { user } = useAuth();
const { schema, reload, error, setError, loading } = useRSFormDetails({target: id});
const [processing, setProcessing] = useState(false)
const [active, setActive] = useState<IConstituenta | undefined>(undefined);
2023-07-20 17:11:03 +03:00
const [forceAdmin, setForceAdmin] = useState(false);
const [readonly, setReadonly] = useState(false);
const isEditable = useMemo(() => {
return (
!readonly &&
(user?.id === schema?.owner || (forceAdmin && user?.is_staff) || false)
)
}, [user, schema, readonly, forceAdmin]);
const isTracking = useMemo(() => {
return true;
}, []);
const toggleTracking = useCallback(() => {
toast('not implemented yet');
}, []);
2023-07-15 17:46:19 +03:00
const isClaimable = useMemo(() => (user?.id !== schema?.owner || false), [user, schema]);
2023-07-16 22:25:23 +03:00
async function update(data: any, callback?: BackendCallback) {
2023-07-15 17:46:19 +03:00
setError(undefined);
patchRSForm(id, {
data: data,
showError: true,
setLoading: setProcessing,
onError: error => setError(error),
onSucccess: callback
2023-07-15 17:46:19 +03:00
});
}
async function destroy(callback: BackendCallback) {
2023-07-15 17:46:19 +03:00
setError(undefined);
deleteRSForm(id, {
showError: true,
setLoading: setProcessing,
onError: error => setError(error),
onSucccess: callback
2023-07-15 17:46:19 +03:00
});
}
async function claim(callback: BackendCallback) {
2023-07-15 17:46:19 +03:00
setError(undefined);
postClaimRSForm(id, {
showError: true,
setLoading: setProcessing,
onError: error => setError(error),
onSucccess: callback
2023-07-15 17:46:19 +03:00
});
}
2023-07-16 22:25:23 +03:00
async function download(callback: BackendCallback) {
setError(undefined);
getTRSFile(id, {
showError: true,
setLoading: setProcessing,
onError: error => setError(error),
onSucccess: callback
});
}
2023-07-18 14:55:40 +03:00
async function cstUpdate(data: any, callback?: BackendCallback) {
setError(undefined);
patchConstituenta(String(active!.entityUID), {
data: data,
showError: true,
setLoading: setProcessing,
onError: error => setError(error),
onSucccess: callback
});
}
2023-07-15 17:46:19 +03:00
return (
<RSFormContext.Provider value={{
schema, error, loading, processing,
active, setActive,
2023-07-20 17:11:03 +03:00
forceAdmin, setForceAdmin,
readonly, setReadonly,
2023-07-15 17:46:19 +03:00
isEditable, isClaimable,
2023-07-20 17:11:03 +03:00
isTracking, toggleTracking,
2023-07-18 14:55:40 +03:00
cstUpdate,
2023-07-16 22:25:23 +03:00
reload, update, download, destroy, claim
2023-07-15 17:46:19 +03:00
}}>
{ children }
</RSFormContext.Provider>
);
}
export const useRSForm = () => useContext(RSFormContext);