Merge remote-tracking branch 'origin/V2' into auto-rename

This commit is contained in:
Connor Yoh 2025-08-29 17:24:43 +01:00
commit c14cb009c2
2 changed files with 19 additions and 10 deletions

View File

@ -1,16 +1,16 @@
import { useCallback } from 'react';
import { useTranslation } from 'react-i18next';
import { ToolType, useToolOperation } from '../shared/useToolOperation';
import { ToolType, useToolOperation, ToolOperationConfig } from '../shared/useToolOperation';
import { createStandardErrorHandler } from '../../../utils/toolErrorHandler';
import { SplitParameters, defaultParameters } from './useSplitParameters';
import { SPLIT_MODES } from '../../../constants/splitConstants';
import { useToolResources } from '../shared/useToolResources';
// Static functions that can be used by both the hook and automation executor
export const buildSplitFormData = (parameters: SplitParameters, selectedFiles: File[]): FormData => {
export const buildSplitFormData = (parameters: SplitParameters, file: File): FormData => {
const formData = new FormData();
selectedFiles.forEach(file => {
formData.append("fileInput", file);
});
formData.append("fileInput", file);
switch (parameters.mode) {
case SPLIT_MODES.BY_PAGES:
@ -57,7 +57,7 @@ export const getSplitEndpoint = (parameters: SplitParameters): string => {
// Static configuration object
export const splitOperationConfig = {
toolType: ToolType.multiFile,
toolType: ToolType.singleFile,
buildFormData: buildSplitFormData,
operationType: 'splitPdf',
endpoint: getSplitEndpoint,
@ -67,9 +67,20 @@ export const splitOperationConfig = {
export const useSplitOperation = () => {
const { t } = useTranslation();
const { extractZipFiles } = useToolResources();
return useToolOperation<SplitParameters>({
// Custom response handler that extracts ZIP files
// Can't add to exported config because it requires access to the zip code so must be part of the hook
const responseHandler = useCallback(async (blob: Blob, originalFiles: File[]): Promise<File[]> => {
// Split operations return ZIP files with multiple PDF pages
return await extractZipFiles(blob);
}, [extractZipFiles]);
const splitConfig: ToolOperationConfig<SplitParameters> = {
...splitOperationConfig,
responseHandler,
getErrorMessage: createStandardErrorHandler(t('split.error.failed', 'An error occurred while splitting the PDF.'))
});
};
return useToolOperation(splitConfig);
};

View File

@ -22,7 +22,5 @@ export function firePixel(pathname: string): void {
const img = new Image();
img.referrerPolicy = "no-referrer-when-downgrade";
img.src = url;
console.log("ScarfPixel: Fire to... " + pathname);
}