260220:1504 20260220 TASK-BEFE-001 Refactor by ADR-014
All checks were successful
Build and Deploy / deploy (push) Successful in 2m34s
All checks were successful
Build and Deploy / deploy (push) Successful in 2m34s
This commit is contained in:
83
frontend/hooks/use-numbering.ts
Normal file
83
frontend/hooks/use-numbering.ts
Normal file
@@ -0,0 +1,83 @@
|
||||
import { useQuery, useMutation, useQueryClient } from '@tanstack/react-query';
|
||||
import { documentNumberingService } from '@/lib/services/document-numbering.service';
|
||||
import { numberingApi, NumberingTemplate } from '@/lib/api/numbering';
|
||||
import { ManualOverrideDto, VoidReplaceDto, CancelNumberDto, AuditQueryParams } from '@/types/dto/numbering.dto';
|
||||
|
||||
export const numberingKeys = {
|
||||
all: ['numbering'] as const,
|
||||
templates: () => [...numberingKeys.all, 'templates'] as const,
|
||||
metrics: () => [...numberingKeys.all, 'metrics'] as const,
|
||||
auditLogs: (params?: AuditQueryParams) => [...numberingKeys.all, 'auditLogs', params] as const,
|
||||
};
|
||||
|
||||
export const useTemplates = () => {
|
||||
return useQuery({
|
||||
queryKey: numberingKeys.templates(),
|
||||
queryFn: () => numberingApi.getTemplates(),
|
||||
});
|
||||
};
|
||||
|
||||
export const useSaveTemplate = () => {
|
||||
const queryClient = useQueryClient();
|
||||
return useMutation({
|
||||
mutationFn: (data: Partial<NumberingTemplate>) => numberingApi.saveTemplate(data),
|
||||
onSuccess: () => {
|
||||
queryClient.invalidateQueries({ queryKey: numberingKeys.templates() });
|
||||
},
|
||||
});
|
||||
};
|
||||
|
||||
export const useNumberingMetrics = () => {
|
||||
return useQuery({
|
||||
queryKey: numberingKeys.metrics(),
|
||||
queryFn: () => documentNumberingService.getMetrics(),
|
||||
});
|
||||
};
|
||||
|
||||
export const useNumberingAuditLogs = (params?: AuditQueryParams) => {
|
||||
return useQuery({
|
||||
queryKey: numberingKeys.auditLogs(params),
|
||||
queryFn: () => documentNumberingService.getAuditLogs(params),
|
||||
});
|
||||
};
|
||||
|
||||
export const useManualOverrideNumbering = () => {
|
||||
const queryClient = useQueryClient();
|
||||
return useMutation({
|
||||
mutationFn: (data: ManualOverrideDto) => documentNumberingService.manualOverride(data),
|
||||
onSuccess: () => {
|
||||
queryClient.invalidateQueries({ queryKey: numberingKeys.metrics() });
|
||||
queryClient.invalidateQueries({ queryKey: numberingKeys.all }); // depending on keys
|
||||
},
|
||||
});
|
||||
};
|
||||
|
||||
export const useVoidAndReplaceNumbering = () => {
|
||||
const queryClient = useQueryClient();
|
||||
return useMutation({
|
||||
mutationFn: (data: VoidReplaceDto) => documentNumberingService.voidAndReplace(data),
|
||||
onSuccess: () => {
|
||||
queryClient.invalidateQueries({ queryKey: numberingKeys.all });
|
||||
},
|
||||
});
|
||||
};
|
||||
|
||||
export const useCancelNumbering = () => {
|
||||
const queryClient = useQueryClient();
|
||||
return useMutation({
|
||||
mutationFn: (data: CancelNumberDto) => documentNumberingService.cancelNumber(data),
|
||||
onSuccess: () => {
|
||||
queryClient.invalidateQueries({ queryKey: numberingKeys.all });
|
||||
},
|
||||
});
|
||||
};
|
||||
|
||||
export const useBulkImportNumbering = () => {
|
||||
const queryClient = useQueryClient();
|
||||
return useMutation({
|
||||
mutationFn: (data: FormData | any[]) => documentNumberingService.bulkImport(data),
|
||||
onSuccess: () => {
|
||||
queryClient.invalidateQueries({ queryKey: numberingKeys.all });
|
||||
},
|
||||
});
|
||||
};
|
||||
Reference in New Issue
Block a user