mirror of
https://github.com/Stirling-Tools/Stirling-PDF.git
synced 2025-08-23 20:59:23 +00:00

* automate feature * Moved all providers to app level to simplify homepage * Circular dependency fixes * You will see that now toolRegistry gets a tool config and a tool settings object. These enable automate to run the tools using as much static code as possible. --------- Co-authored-by: Connor Yoh <connor@stirlingpdf.com>
31 lines
1.2 KiB
TypeScript
31 lines
1.2 KiB
TypeScript
import { useTranslation } from 'react-i18next';
|
|
import { useToolOperation } from '../shared/useToolOperation';
|
|
import { createStandardErrorHandler } from '../../../utils/toolErrorHandler';
|
|
import { RepairParameters, defaultParameters } from './useRepairParameters';
|
|
|
|
// Static function that can be used by both the hook and automation executor
|
|
export const buildRepairFormData = (parameters: RepairParameters, file: File): FormData => {
|
|
const formData = new FormData();
|
|
formData.append("fileInput", file);
|
|
return formData;
|
|
};
|
|
|
|
// Static configuration object
|
|
export const repairOperationConfig = {
|
|
operationType: 'repair',
|
|
endpoint: '/api/v1/misc/repair',
|
|
buildFormData: buildRepairFormData,
|
|
filePrefix: 'repaired_', // Will be overridden in hook with translation
|
|
multiFileEndpoint: false,
|
|
defaultParameters,
|
|
} as const;
|
|
|
|
export const useRepairOperation = () => {
|
|
const { t } = useTranslation();
|
|
|
|
return useToolOperation<RepairParameters>({
|
|
...repairOperationConfig,
|
|
filePrefix: t('repair.filenamePrefix', 'repaired') + '_',
|
|
getErrorMessage: createStandardErrorHandler(t('repair.error.failed', 'An error occurred while repairing the PDF.'))
|
|
});
|
|
}; |