import React, { useState, useCallback, useEffect} from "react"; import { useTranslation } from 'react-i18next'; import { useFileContext } from "../contexts/FileContext"; import { FileSelectionProvider, useFileSelection } from "../contexts/FileSelectionContext"; import { useToolManagement } from "../hooks/useToolManagement"; import { Group, Box, Button, Container } from "@mantine/core"; import { useRainbowThemeContext } from "../components/shared/RainbowThemeProvider"; import { PageEditorFunctions } from "../types/pageEditor"; import rainbowStyles from '../styles/rainbow.module.css'; import ToolPicker from "../components/tools/ToolPicker"; import TopControls from "../components/shared/TopControls"; import FileEditor from "../components/fileEditor/FileEditor"; import PageEditor from "../components/pageEditor/PageEditor"; import PageEditorControls from "../components/pageEditor/PageEditorControls"; import Viewer from "../components/viewer/Viewer"; import FileUploadSelector from "../components/shared/FileUploadSelector"; import ToolRenderer from "../components/tools/ToolRenderer"; import QuickAccessBar from "../components/shared/QuickAccessBar"; function HomePageContent() { const { t } = useTranslation(); const { isRainbowMode } = useRainbowThemeContext(); const fileContext = useFileContext(); const { activeFiles, currentView, currentMode, setCurrentView, addFiles } = fileContext; const { setMaxFiles, setIsToolMode, setSelectedFiles } = useFileSelection(); const { selectedToolKey, selectedTool, toolRegistry, selectTool, clearToolSelection, } = useToolManagement(); const [sidebarsVisible, setSidebarsVisible] = useState(true); const [leftPanelView, setLeftPanelView] = useState<'toolPicker' | 'toolContent'>('toolPicker'); const [readerMode, setReaderMode] = useState(false); const [pageEditorFunctions, setPageEditorFunctions] = useState(null); const [previewFile, setPreviewFile] = useState(null); // Update file selection context when tool changes useEffect(() => { if (selectedTool) { setMaxFiles(selectedTool.maxFiles); setIsToolMode(true); } else { setMaxFiles(-1); setIsToolMode(false); setSelectedFiles([]); } }, [selectedTool, setMaxFiles, setIsToolMode, setSelectedFiles]); const handleToolSelect = useCallback( (id: string) => { selectTool(id); setCurrentView('fileEditor'); // Tools use fileEditor view for file selection setLeftPanelView('toolContent'); setReaderMode(false); }, [selectTool, setCurrentView] ); const handleQuickAccessTools = useCallback(() => { setLeftPanelView('toolPicker'); setReaderMode(false); clearToolSelection(); }, [clearToolSelection]); const handleReaderToggle = useCallback(() => { setReaderMode(true); }, [readerMode]); const handleViewChange = useCallback((view: string) => { setCurrentView(view as any); }, [setCurrentView]); const addToActiveFiles = useCallback(async (file: File) => { const exists = activeFiles.some(f => f.name === file.name && f.size === file.size); if (!exists) { await addFiles([file]); } }, [activeFiles, addFiles]); return ( {/* Quick Access Bar */} {/* Left: Tool Picker or Selected Tool Panel */}
{leftPanelView === 'toolPicker' ? ( // Tool Picker View
) : ( // Selected Tool Content View
{/* Back button */}
{/* Tool title */}

{selectedTool?.name}

{/* Tool content */}
)}
{/* Main View */} {/* Top Controls */} {/* Main content area */} {!activeFiles[0] ? ( { addToActiveFiles(file); }} onFilesSelect={(files) => { files.forEach(addToActiveFiles); }} accept={["*/*"]} supportedExtensions={selectedTool?.supportedFormats || ["pdf"]} loading={false} showRecentFiles={true} maxRecentFiles={8} /> ) : currentView === "fileEditor" ? ( { handleViewChange("pageEditor"); }, onMergeFiles: (filesToMerge) => { filesToMerge.forEach(addToActiveFiles); handleViewChange("viewer"); } })} /> ) : currentView === "viewer" ? ( { setPreviewFile(null); // Clear preview file const previousMode = sessionStorage.getItem('previousMode'); if (previousMode === 'split') { selectTool('split'); setCurrentView('split'); setLeftPanelView('toolContent'); sessionStorage.removeItem('previousMode'); } else if (previousMode === 'compress') { selectTool('compress'); setCurrentView('compress'); setLeftPanelView('toolContent'); sessionStorage.removeItem('previousMode'); } else if (previousMode === 'convert') { selectTool('convert'); setCurrentView('convert'); setLeftPanelView('toolContent'); sessionStorage.removeItem('previousMode'); } else { setCurrentView('fileEditor'); } } })} /> ) : currentView === "pageEditor" ? ( <> {pageEditorFunctions && ( )} ) : selectedToolKey && selectedTool ? ( // Fallback: if tool is selected but not in fileEditor view, show tool in main area ) : ( { addToActiveFiles(file); }} onFilesSelect={(files) => { files.forEach(addToActiveFiles); }} accept={["*/*"]} supportedExtensions={selectedTool?.supportedFormats || ["pdf"]} loading={false} showRecentFiles={true} maxRecentFiles={8} /> )}
); } // Main HomePage component wrapped with FileSelectionProvider export default function HomePage() { return ( ); }