mirror of
https://github.com/Stirling-Tools/Stirling-PDF.git
synced 2025-09-19 01:49:24 +00:00
99 lines
3.3 KiB
TypeScript
99 lines
3.3 KiB
TypeScript
![]() |
import { useCallback } from "react";
|
||
|
import { useTranslation } from "react-i18next";
|
||
|
import { createToolFlow } from "../components/tools/shared/createToolFlow";
|
||
|
import MergeSettings from "../components/tools/merge/MergeSettings";
|
||
|
import MergeFileSorter from "../components/tools/merge/MergeFileSorter";
|
||
|
import { useMergeParameters } from "../hooks/tools/merge/useMergeParameters";
|
||
|
import { useMergeOperation } from "../hooks/tools/merge/useMergeOperation";
|
||
|
import { useBaseTool } from "../hooks/tools/shared/useBaseTool";
|
||
|
import { BaseToolProps, ToolComponent } from "../types/tool";
|
||
|
import { useMergeTips } from "../components/tooltips/useMergeTips";
|
||
|
import { useFileManagement, useSelectedFiles, useAllFiles } from "../contexts/FileContext";
|
||
|
|
||
|
const Merge = (props: BaseToolProps) => {
|
||
|
const { t } = useTranslation();
|
||
|
const mergeTips = useMergeTips();
|
||
|
|
||
|
// File selection hooks for custom sorting
|
||
|
const { fileIds } = useAllFiles();
|
||
|
const { selectedRecords } = useSelectedFiles();
|
||
|
const { reorderFiles } = useFileManagement();
|
||
|
|
||
|
const base = useBaseTool(
|
||
|
'merge',
|
||
|
useMergeParameters,
|
||
|
useMergeOperation,
|
||
|
props,
|
||
|
{ minFiles: 2 }
|
||
|
);
|
||
|
|
||
|
// Custom file sorting logic for merge tool
|
||
|
const sortFiles = useCallback((sortType: 'filename' | 'dateModified', ascending: boolean = true) => {
|
||
|
const sortedRecords = [...selectedRecords].sort((recordA, recordB) => {
|
||
|
let comparison = 0;
|
||
|
switch (sortType) {
|
||
|
case 'filename':
|
||
|
comparison = recordA.name.localeCompare(recordB.name);
|
||
|
break;
|
||
|
case 'dateModified':
|
||
|
comparison = recordA.lastModified - recordB.lastModified;
|
||
|
break;
|
||
|
}
|
||
|
return ascending ? comparison : -comparison;
|
||
|
});
|
||
|
|
||
|
const selectedIds = sortedRecords.map(record => record.id);
|
||
|
const deselectedIds = fileIds.filter(id => !selectedIds.includes(id));
|
||
|
reorderFiles([...selectedIds, ...deselectedIds]);
|
||
|
}, [selectedRecords, fileIds, reorderFiles]);
|
||
|
|
||
|
return createToolFlow({
|
||
|
files: {
|
||
|
selectedFiles: base.selectedFiles,
|
||
|
isCollapsed: base.hasResults,
|
||
|
minFiles: 2,
|
||
|
},
|
||
|
steps: [
|
||
|
{
|
||
|
title: "Sort Files",
|
||
|
isCollapsed: base.settingsCollapsed,
|
||
|
content: (
|
||
|
<MergeFileSorter
|
||
|
onSortFiles={sortFiles}
|
||
|
disabled={!base.hasFiles || base.endpointLoading}
|
||
|
/>
|
||
|
),
|
||
|
},
|
||
|
{
|
||
|
title: "Settings",
|
||
|
isCollapsed: base.settingsCollapsed,
|
||
|
onCollapsedClick: base.settingsCollapsed ? base.handleSettingsReset : undefined,
|
||
|
tooltip: mergeTips,
|
||
|
content: (
|
||
|
<MergeSettings
|
||
|
parameters={base.params.parameters}
|
||
|
onParameterChange={base.params.updateParameter}
|
||
|
disabled={base.endpointLoading}
|
||
|
/>
|
||
|
),
|
||
|
},
|
||
|
],
|
||
|
executeButton: {
|
||
|
text: t("merge.submit", "Merge PDFs"),
|
||
|
isVisible: !base.hasResults,
|
||
|
loadingText: t("loading"),
|
||
|
onClick: base.handleExecute,
|
||
|
disabled: !base.params.validateParameters() || !base.hasFiles || !base.endpointEnabled,
|
||
|
},
|
||
|
review: {
|
||
|
isVisible: base.hasResults,
|
||
|
operation: base.operation,
|
||
|
title: t("merge.title", "Merge Results"),
|
||
|
onFileClick: base.handleThumbnailClick,
|
||
|
onUndo: base.handleUndo,
|
||
|
},
|
||
|
});
|
||
|
};
|
||
|
|
||
|
export default Merge as ToolComponent;
|