mirror of
https://github.com/Stirling-Tools/Stirling-PDF.git
synced 2025-09-19 09:59:22 +00:00
88 lines
2.3 KiB
TypeScript
88 lines
2.3 KiB
TypeScript
![]() |
import React from "react";
|
||
|
import { Box, Group, Text, Button } from "@mantine/core";
|
||
|
import { useTranslation } from "react-i18next";
|
||
|
|
||
|
interface MultiSelectControlsProps {
|
||
|
selectedCount: number;
|
||
|
onClearSelection: () => void;
|
||
|
onOpenInFileEditor?: () => void;
|
||
|
onOpenInPageEditor?: () => void;
|
||
|
onAddToUpload?: () => void;
|
||
|
onDeleteAll?: () => void;
|
||
|
}
|
||
|
|
||
|
const MultiSelectControls = ({
|
||
|
selectedCount,
|
||
|
onClearSelection,
|
||
|
onOpenInFileEditor,
|
||
|
onOpenInPageEditor,
|
||
|
onAddToUpload,
|
||
|
onDeleteAll
|
||
|
}: MultiSelectControlsProps) => {
|
||
|
const { t } = useTranslation();
|
||
|
|
||
|
if (selectedCount === 0) return null;
|
||
|
|
||
|
return (
|
||
|
<Box mb="md" p="md" style={{ backgroundColor: 'var(--mantine-color-blue-0)', borderRadius: 8 }}>
|
||
|
<Group justify="space-between">
|
||
|
<Text size="sm">
|
||
|
{selectedCount} {t("fileManager.filesSelected", "files selected")}
|
||
|
</Text>
|
||
|
<Group>
|
||
|
<Button
|
||
|
size="xs"
|
||
|
variant="light"
|
||
|
onClick={onClearSelection}
|
||
|
>
|
||
|
{t("fileManager.clearSelection", "Clear Selection")}
|
||
|
</Button>
|
||
|
|
||
|
{onAddToUpload && (
|
||
|
<Button
|
||
|
size="xs"
|
||
|
color="green"
|
||
|
onClick={onAddToUpload}
|
||
|
>
|
||
|
{t("fileManager.addToUpload", "Add to Upload")}
|
||
|
</Button>
|
||
|
)}
|
||
|
|
||
|
{onOpenInFileEditor && (
|
||
|
<Button
|
||
|
size="xs"
|
||
|
color="orange"
|
||
|
onClick={onOpenInFileEditor}
|
||
|
disabled={selectedCount === 0}
|
||
|
>
|
||
|
{t("fileManager.openInFileEditor", "Open in File Editor")}
|
||
|
</Button>
|
||
|
)}
|
||
|
|
||
|
{onOpenInPageEditor && (
|
||
|
<Button
|
||
|
size="xs"
|
||
|
color="blue"
|
||
|
onClick={onOpenInPageEditor}
|
||
|
disabled={selectedCount === 0}
|
||
|
>
|
||
|
{t("fileManager.openInPageEditor", "Open in Page Editor")}
|
||
|
</Button>
|
||
|
)}
|
||
|
|
||
|
{onDeleteAll && (
|
||
|
<Button
|
||
|
size="xs"
|
||
|
color="red"
|
||
|
onClick={onDeleteAll}
|
||
|
>
|
||
|
{t("fileManager.deleteAll", "Delete All")}
|
||
|
</Button>
|
||
|
)}
|
||
|
</Group>
|
||
|
</Group>
|
||
|
</Box>
|
||
|
);
|
||
|
};
|
||
|
|
||
|
export default MultiSelectControls;
|