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

174 lines
4.8 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';
import { BackendCallback, deleteRSForm, getTRSFile, patchConstituenta, patchRSForm, postClaimRSForm, postNewConstituenta } from '../utils/backendAPI';
2023-07-20 17:11:03 +03:00
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
2023-07-21 00:09:05 +03:00
isOwned: boolean
2023-07-15 17:46:19 +03:00
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
2023-07-21 00:09:05 +03:00
setActive: React.Dispatch<React.SetStateAction<IConstituenta | undefined>>
toggleForceAdmin: () => void
toggleReadonly: () => void
2023-07-20 17:11:03 +03:00
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
cstCreate: (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,
2023-07-21 00:09:05 +03:00
isOwned: false,
2023-07-15 17:46:19 +03:00
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-21 00:09:05 +03:00
toggleForceAdmin: () => {},
toggleReadonly: () => {},
2023-07-20 17:11:03 +03:00
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: () => {},
cstCreate: () => {},
2023-07-15 17:46:19 +03:00
})
interface RSFormStateProps {
schemaID: string
2023-07-15 17:46:19 +03:00
children: React.ReactNode
}
export const RSFormState = ({ schemaID, children }: RSFormStateProps) => {
2023-07-15 17:46:19 +03:00
const { user } = useAuth();
const { schema, reload, error, setError, loading } = useRSFormDetails({target: schemaID});
2023-07-15 17:46:19 +03:00
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);
2023-07-21 00:09:05 +03:00
const isOwned = useMemo(() => user?.id === schema?.owner || false, [user, schema]);
const isClaimable = useMemo(() => (user?.id !== schema?.owner || false), [user, schema]);
2023-07-20 17:11:03 +03:00
const isEditable = useMemo(() => {
return (
!readonly &&
2023-07-21 00:09:05 +03:00
(isOwned || (forceAdmin && user?.is_staff) || false)
2023-07-20 17:11:03 +03:00
)
2023-07-21 00:09:05 +03:00
}, [user, readonly, forceAdmin, isOwned]);
2023-07-20 17:11:03 +03:00
const isTracking = useMemo(() => {
return true;
}, []);
2023-07-21 00:09:05 +03:00
2023-07-20 17:11:03 +03:00
const toggleTracking = useCallback(() => {
toast('not implemented yet');
}, []);
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(schemaID, {
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(schemaID, {
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(schemaID, {
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(schemaID, {
2023-07-16 22:25:23 +03:00
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
});
}
async function cstCreate(data: any, callback?: BackendCallback) {
setError(undefined);
postNewConstituenta(schemaID, {
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-21 00:09:05 +03:00
forceAdmin, readonly,
toggleForceAdmin: () => setForceAdmin(prev => !prev),
toggleReadonly: () => setReadonly(prev => !prev),
isOwned, isEditable, isClaimable,
2023-07-20 17:11:03 +03:00
isTracking, toggleTracking,
reload, update, download, destroy, claim,
cstUpdate, cstCreate
2023-07-15 17:46:19 +03:00
}}>
{ children }
</RSFormContext.Provider>
);
}
export const useRSForm = () => useContext(RSFormContext);