import React, { useState, useCallback, useEffect, useRef } from "react"; import { useTranslation } from 'react-i18next'; import { useFileContext } from "../contexts/FileContext"; import { FileSelectionProvider, useFileSelection } from "../contexts/FileSelectionContext"; import { SidebarProvider, useSidebarContext } from "../contexts/SidebarContext"; import { useToolManagement } from "../hooks/useToolManagement"; import { useFileHandler } from "../hooks/useFileHandler"; import { Group, Box, Button } from "@mantine/core"; import { useRainbowThemeContext } from "../components/shared/RainbowThemeProvider"; import { PageEditorFunctions } from "../types/pageEditor"; import { SidebarRefs, SidebarState } from "../types/sidebar"; 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 ToolRenderer from "../components/tools/ToolRenderer"; import QuickAccessBar from "../components/shared/QuickAccessBar"; import LandingPage from "../components/shared/LandingPage"; import FileUploadModal from "../components/shared/FileUploadModal"; function HomePageContent() { const { t } = useTranslation(); const { isRainbowMode } = useRainbowThemeContext(); const { sidebarState, sidebarRefs, setSidebarsVisible, setLeftPanelView, setReaderMode } = useSidebarContext(); const { sidebarsVisible, leftPanelView, readerMode } = sidebarState; const { quickAccessRef, toolPanelRef } = sidebarRefs; const fileContext = useFileContext(); const { activeFiles, currentView, setCurrentView } = fileContext; const { setMaxFiles, setIsToolMode, setSelectedFiles } = useFileSelection(); const { addToActiveFiles } = useFileHandler(); const { selectedToolKey, selectedTool, toolRegistry, selectTool, clearToolSelection, } = useToolManagement(); 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]); 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] ? ( ) : 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 ) : ( )} {/* Global Modals */}
); } // Main HomePage component wrapped with FileSelectionProvider export default function HomePage() { return ( ); }