mirror of
https://github.com/Stirling-Tools/Stirling-PDF.git
synced 2025-08-26 06:09: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>
76 lines
2.7 KiB
TypeScript
76 lines
2.7 KiB
TypeScript
import { useTranslation } from 'react-i18next';
|
|
import { useToolOperation } from '../shared/useToolOperation';
|
|
import { createStandardErrorHandler } from '../../../utils/toolErrorHandler';
|
|
import { SplitParameters, defaultParameters } from './useSplitParameters';
|
|
import { SPLIT_MODES } from '../../../constants/splitConstants';
|
|
|
|
// Static functions that can be used by both the hook and automation executor
|
|
export const buildSplitFormData = (parameters: SplitParameters, selectedFiles: File[]): FormData => {
|
|
const formData = new FormData();
|
|
|
|
selectedFiles.forEach(file => {
|
|
formData.append("fileInput", file);
|
|
});
|
|
|
|
switch (parameters.mode) {
|
|
case SPLIT_MODES.BY_PAGES:
|
|
formData.append("pageNumbers", parameters.pages);
|
|
break;
|
|
case SPLIT_MODES.BY_SECTIONS:
|
|
formData.append("horizontalDivisions", parameters.hDiv);
|
|
formData.append("verticalDivisions", parameters.vDiv);
|
|
formData.append("merge", parameters.merge.toString());
|
|
break;
|
|
case SPLIT_MODES.BY_SIZE_OR_COUNT:
|
|
formData.append(
|
|
"splitType",
|
|
parameters.splitType === "size" ? "0" : parameters.splitType === "pages" ? "1" : "2"
|
|
);
|
|
formData.append("splitValue", parameters.splitValue);
|
|
break;
|
|
case SPLIT_MODES.BY_CHAPTERS:
|
|
formData.append("bookmarkLevel", parameters.bookmarkLevel);
|
|
formData.append("includeMetadata", parameters.includeMetadata.toString());
|
|
formData.append("allowDuplicates", parameters.allowDuplicates.toString());
|
|
break;
|
|
default:
|
|
throw new Error(`Unknown split mode: ${parameters.mode}`);
|
|
}
|
|
|
|
return formData;
|
|
};
|
|
|
|
export const getSplitEndpoint = (parameters: SplitParameters): string => {
|
|
switch (parameters.mode) {
|
|
case SPLIT_MODES.BY_PAGES:
|
|
return "/api/v1/general/split-pages";
|
|
case SPLIT_MODES.BY_SECTIONS:
|
|
return "/api/v1/general/split-pdf-by-sections";
|
|
case SPLIT_MODES.BY_SIZE_OR_COUNT:
|
|
return "/api/v1/general/split-by-size-or-count";
|
|
case SPLIT_MODES.BY_CHAPTERS:
|
|
return "/api/v1/general/split-pdf-by-chapters";
|
|
default:
|
|
throw new Error(`Unknown split mode: ${parameters.mode}`);
|
|
}
|
|
};
|
|
|
|
// Static configuration object
|
|
export const splitOperationConfig = {
|
|
operationType: 'splitPdf',
|
|
endpoint: getSplitEndpoint,
|
|
buildFormData: buildSplitFormData,
|
|
filePrefix: 'split_',
|
|
multiFileEndpoint: true, // Single API call with all files
|
|
defaultParameters,
|
|
} as const;
|
|
|
|
export const useSplitOperation = () => {
|
|
const { t } = useTranslation();
|
|
|
|
return useToolOperation<SplitParameters>({
|
|
...splitOperationConfig,
|
|
getErrorMessage: createStandardErrorHandler(t('split.error.failed', 'An error occurred while splitting the PDF.'))
|
|
});
|
|
};
|