mirror of
https://github.com/Frooodle/Stirling-PDF.git
synced 2026-03-13 02:18:16 +01:00
# Description of Changes <!-- Please provide a summary of the changes, including: - What was changed - Why the change was made - Any challenges encountered Closes #(issue_number) --> --- ## Checklist ### General - [ ] I have read the [Contribution Guidelines](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/CONTRIBUTING.md) - [ ] I have read the [Stirling-PDF Developer Guide](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/devGuide/DeveloperGuide.md) (if applicable) - [ ] I have read the [How to add new languages to Stirling-PDF](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/devGuide/HowToAddNewLanguage.md) (if applicable) - [ ] I have performed a self-review of my own code - [ ] My changes generate no new warnings ### Documentation - [ ] I have updated relevant docs on [Stirling-PDF's doc repo](https://github.com/Stirling-Tools/Stirling-Tools.github.io/blob/main/docs/) (if functionality has heavily changed) - [ ] I have read the section [Add New Translation Tags](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/devGuide/HowToAddNewLanguage.md#add-new-translation-tags) (for new translation tags only) ### UI Changes (if applicable) - [ ] Screenshots or videos demonstrating the UI changes are attached (e.g., as comments or direct attachments in the PR) ### Testing (if applicable) - [ ] I have tested my changes locally. Refer to the [Testing Guide](https://github.com/Stirling-Tools/Stirling-PDF/blob/main/devGuide/DeveloperGuide.md#6-testing) for more details. --------- Co-authored-by: James Brunton <jbrunton96@gmail.com> Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
96 lines
3.5 KiB
TypeScript
96 lines
3.5 KiB
TypeScript
import { useTranslation } from "react-i18next";
|
|
import { createToolFlow } from "@app/components/tools/shared/createToolFlow";
|
|
import CardSelector from "@app/components/shared/CardSelector";
|
|
import SplitSettings from "@app/components/tools/split/SplitSettings";
|
|
import { useSplitParameters } from "@app/hooks/tools/split/useSplitParameters";
|
|
import { useSplitOperation } from "@app/hooks/tools/split/useSplitOperation";
|
|
import { useBaseTool } from "@app/hooks/tools/shared/useBaseTool";
|
|
import { useSplitMethodTips } from "@app/components/tooltips/useSplitMethodTips";
|
|
import { useSplitSettingsTips } from "@app/components/tooltips/useSplitSettingsTips";
|
|
import { BaseToolProps, ToolComponent } from "@app/types/tool";
|
|
import { type SplitMethod, METHOD_OPTIONS, type MethodOption } from "@app/constants/splitConstants";
|
|
|
|
const Split = (props: BaseToolProps) => {
|
|
const { t } = useTranslation();
|
|
|
|
const base = useBaseTool(
|
|
'split',
|
|
useSplitParameters,
|
|
useSplitOperation,
|
|
props
|
|
);
|
|
|
|
const methodTips = useSplitMethodTips();
|
|
const settingsTips = useSplitSettingsTips(base.params.parameters.method);
|
|
|
|
// Get tooltip content for a specific method
|
|
const getMethodTooltip = (option: MethodOption) => {
|
|
const tooltipContent = useSplitSettingsTips(option.value);
|
|
return tooltipContent?.tips || [];
|
|
};
|
|
|
|
// Get the method name for the settings step title
|
|
const getSettingsTitle = () => {
|
|
if (!base.params.parameters.method) return t("split.steps.settings", "Settings");
|
|
|
|
const methodOption = METHOD_OPTIONS.find(option => option.value === base.params.parameters.method);
|
|
if (!methodOption) return t("split.steps.settings", "Settings");
|
|
|
|
const prefix = t(methodOption.prefixKey, "Split by");
|
|
const name = t(methodOption.nameKey, "Method Name");
|
|
return `${prefix} ${name}`;
|
|
};
|
|
|
|
return createToolFlow({
|
|
files: {
|
|
selectedFiles: base.selectedFiles,
|
|
isCollapsed: base.hasResults,
|
|
},
|
|
steps: [
|
|
{
|
|
title: t("split.steps.chooseMethod", "Choose Method"),
|
|
isCollapsed: !!base.params.parameters.method, // Collapse when method is selected
|
|
onCollapsedClick: () => base.params.updateParameter('method', ''),
|
|
tooltip: methodTips,
|
|
content: (
|
|
<CardSelector<SplitMethod, MethodOption>
|
|
options={METHOD_OPTIONS}
|
|
onSelect={(method) => base.params.updateParameter('method', method)}
|
|
disabled={base.endpointLoading}
|
|
getTooltipContent={getMethodTooltip}
|
|
/>
|
|
),
|
|
},
|
|
{
|
|
title: getSettingsTitle(),
|
|
isCollapsed: !base.params.parameters.method, // Collapsed until method selected
|
|
onCollapsedClick: base.hasResults ? base.handleSettingsReset : undefined,
|
|
tooltip: settingsTips || undefined,
|
|
content: (
|
|
<SplitSettings
|
|
parameters={base.params.parameters}
|
|
onParameterChange={base.params.updateParameter}
|
|
disabled={base.endpointLoading}
|
|
/>
|
|
),
|
|
},
|
|
],
|
|
executeButton: {
|
|
text: t("split.submit", "Split PDF"),
|
|
loadingText: t("loading"),
|
|
onClick: base.handleExecute,
|
|
isVisible: !base.hasResults,
|
|
disabled: !base.params.validateParameters() || !base.hasFiles || !base.endpointEnabled,
|
|
},
|
|
review: {
|
|
isVisible: base.hasResults,
|
|
operation: base.operation,
|
|
title: t("split.resultsTitle", "Split Results"),
|
|
onFileClick: base.handleThumbnailClick,
|
|
onUndo: base.handleUndo,
|
|
},
|
|
});
|
|
};
|
|
|
|
export default Split as ToolComponent;
|