<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Pomofocus</title>
    <script src="https://cdn.jsdelivr.net/npm/react@18.0.0/umd/react.development.js"></script>
    <script src="https://cdn.jsdelivr.net/npm/react-dom@18.0.0/umd/react-dom.development.js"></script>
    <script src="https://cdn.jsdelivr.net/npm/@babel/standalone/babel.js"></script>
    <script src="https://cdn.tailwindcss.com"></script>
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.15.3/css/all.min.css"></link>
    <style>
        @import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');
        body {
            font-family: 'Inter', sans-serif;
            margin: 0;
            padding: 0;
            height: 100vh;
            overflow: hidden;
        }
    </style>
</head>
<body>
    <div id="root"></div>

    <script type="text/babel">
        const { useState, useEffect } = React;

        function App() {
            const [activeTab, setActiveTab] = useState('pomodoro');
            const [time, setTime] = useState({ minutes: 25, seconds: 0 });
            const [isRunning, setIsRunning] = useState(false);
            const [taskInput, setTaskInput] = useState('');
            const [estPomodoros, setEstPomodoros] = useState(1);
            const [showTaskModal, setShowTaskModal] = useState(false);
            const [tasks, setTasks] = useState([]);
            const [currentTask, setCurrentTask] = useState(null);
            const [finishTime, setFinishTime] = useState('14:57');
            const [showCompletionMessage, setShowCompletionMessage] = useState(false);

            // Tab configurations
            const tabs = [
                { id: 'pomodoro', label: 'Pomodoro', duration: { minutes: 25, seconds: 0 }, bgColor: 'bg-red-500' },
                { id: 'shortBreak', label: 'Short Break', duration: { minutes: 5, seconds: 0 }, bgColor: 'bg-teal-500' },
                { id: 'longBreak', label: 'Long Break', duration: { minutes: 15, seconds: 0 }, bgColor: 'bg-blue-500' }
            ];

            const currentTab = tabs.find(tab => tab.id === activeTab);

            // Timer functions
            useEffect(() => {
                let interval = null;
                if (isRunning) {
                    interval = setInterval(() => {
                        setTime(prevTime => {
                            if (prevTime.seconds === 0) {
                                if (prevTime.minutes === 0) {
                                    clearInterval(interval);
                                    setIsRunning(false);
                                    return prevTime;
                                }
                                return { minutes: prevTime.minutes - 1, seconds: 59 };
                            }
                            return { ...prevTime, seconds: prevTime.seconds - 1 };
                        });
                    }, 1000);
                } else if (!isRunning && interval) {
                    clearInterval(interval);
                }
                return () => clearInterval(interval);
            }, [isRunning]);

            const toggleTimer = () => {
                setIsRunning(!isRunning);
            };

            const resetTimer = () => {
                setTime(currentTab.duration);
                setIsRunning(false);
            };

            const handleTabChange = (tabId) => {
                setActiveTab(tabId);
                setTime(tabs.find(tab => tab.id === tabId).duration);
                setIsRunning(false);
            };

            const openTaskModal = () => {
                setShowTaskModal(true);
                setCurrentTask(null);
                setTaskInput('');
            };

            const saveTask = () => {
                if (taskInput.trim()) {
                    const newTask = {
                        id: Date.now(),
                        text: taskInput,
                        completed: false,
                        estPomodoros: estPomodoros
                    };
                    setTasks([...tasks, newTask]);
                    setShowTaskModal(false);
                    setTaskInput('');
                }
            };

            const deleteTask = (taskId) => {
                setTasks(tasks.filter(task => task.id !== taskId));
            };

            const toggleTaskComplete = (taskId) => {
                setTasks(tasks.map(task => 
                    task.id === taskId ? { ...task, completed: !task.completed } : task
                ));
            };

            const clearAllTasks = () => {
                setTasks([]);
                setShowCompletionMessage(false);
            };

            // Calculate finish time
            useEffect(() => {
                const now = new Date();
                now.setMinutes(now.getMinutes() + time.minutes);
                now.setSeconds(now.getSeconds() + time.seconds);
                const hours = now.getHours().toString().padStart(2, '0');
                const minutes = now.getMinutes().toString().padStart(2, '0');
                setFinishTime(`${hours}:${minutes}`);
            }, [time]);

            // Check if all tasks are completed
            useEffect(() => {
                if (tasks.length > 0 && tasks.every(task => task.completed)) {
                    setShowCompletionMessage(true);
                } else {
                    setShowCompletionMessage(false);
                }
            }, [tasks]);

            return (
                <div className={`h-screen ${currentTab.bgColor} flex flex-col`} style={{ backgroundColor: currentTab.bgColor }}>
                    {/* Header */}
                    <header className="flex justify-between items-center p-4 bg-opacity-20 bg-black">
                        <div className="flex items-center">
                            <i className="fas fa-tomato text-white mr-2"></i>
                            <span className="text-white font-bold text-xl">Pomofocus</span>
                        </div>
                        <div className="flex space-x-3">
                            <button className="p-2 rounded-md bg-gray-200 bg-opacity-30">
                                <i className="fas fa-chart-bar text-white"></i>
                            </button>
                            <button className="p-2 rounded-md bg-gray-200 bg-opacity-30">
                                <i className="fas fa-cog text-white"></i>
                            </button>
                            <button className="p-2 rounded-md bg-gray-200 bg-opacity-30">
                                <i className="fas fa-user text-white"></i>
                            </button>
                            <button className="p-2 rounded-md bg-gray-200 bg-opacity-30">
                                <i className="fas fa-ellipsis-v text-white"></i>
                            </button>
                        </div>
                    </header>

                    {/* Main Content */}
                    <main className="flex-grow px-4 pb-4">
                        {/* Timer Section */}
                        <div className="bg-white bg-opacity-10 rounded-lg p-6 mb-6 mx-auto max-w-md">
                            {/* Tabs */}
                            <div className="flex mb-6">
                                {tabs.map(tab => (
                                    <button
                                        key={tab.id}
                                        onClick={() => handleTabChange(tab.id)}
                                        className={`px-4 py-2 rounded-md mr-2 ${
                                            activeTab === tab.id 
                                                ? 'bg-red-600 text-white' 
                                                : 'bg-transparent text-white opacity-70'
                                        }`}
                                    >
                                        {tab.label}
                                    </button>
                                ))}
                            </div>

                            {/* Time Display */}
                            <div className="text-center mb-6">
                                <div className="text-white text-8xl font-bold tracking-wider">
                                    {String(time.minutes).padStart(2, '0')}:{String(time.seconds).padStart(2, '0')}
                                </div>
                            </div>

                            {/* Control Button */}
                            <div className="flex justify-center mb-6">
                                <button
                                    onClick={toggleTimer}
                                    className="bg-white text-red-600 w-full py-3 rounded-md font-semibold text-xl"
                                >
                                    {isRunning ? 'PAUSE' : 'START'}
                                </button>
                            </div>

                            {/* Skip Button */}
                            {isRunning && (
                                <div className="flex justify-end mb-4">
                                    <button className="text-white">
                                        <i className="fas fa-forward"></i>
                                    </button>
                                </div>
                            )}
                        </div>

                        {/* Focus Message */}
                        <div className="text-center mb-6">
                            <div className="text-white text-2xl font-medium">#1</div>
                            <div className="text-white text-lg">
                                {activeTab === 'pomodoro' ? 'Time to focus!' : 'Time for a break!'}
                            </div>
                        </div>

                        {/* Tasks Section */}
                        <div className="mb-6">
                            <div className="flex justify-between items-center mb-4">
                                <h2 className="text-white text-xl font-bold">Tasks</h2>
                                <button className="text-white">
                                    <i className="fas fa-ellipsis-v"></i>
                                </button>
                            </div>

                            {/* Task List */}
                            <div className="space-y-2 mb-4">
                                {tasks.map(task => (
                                    <div key={task.id} className="bg-white rounded-md p-3 flex items-center justify-between">
                                        <div className="flex items-center">
                                            <input
                                                type="checkbox"
                                                checked={task.completed}
                                                onChange={() => toggleTaskComplete(task.id)}
                                                className="mr-3 h-5 w-5"
                                            />
                                            <span className={`${task.completed ? 'line-through text-gray-400' : 'text-gray-800'}`}>
                                                {task.text}
                                            </span>
                                        </div>
                                        <div className="flex items-center">
                                            <span className="text-sm text-gray-500 mr-2">{task.estPomodoros}/{task.estPomodoros}</span>
                                            <button onClick={() => deleteTask(task.id)}>
                                                <i className="fas fa-ellipsis-v text-gray-400"></i>
                                            </button>
                                        </div>
                                    </div>
                                ))}
                            </div>

                            {/* Add Task Button */}
                            <button
                                onClick={openTaskModal}
                                className="w-full border-2 border-dashed border-white rounded-md py-3 flex items-center justify-center text-white"
                            >
                                <i className="fas fa-plus mr-2"></i>
                                Add Task
                            </button>

                            {/* Progress Bar */}
                            <div className="mt-4 relative">
                                <div className="h-1 bg-white bg-opacity-30 rounded-full">
                                    <div className="absolute left-1/2 top-1/2 transform -translate-x-1/2 -translate-y-1/2 w-4 h-4 bg-white rounded-full"></div>
                                </div>
                            </div>

                            {/* Finish Time Info */}
                            <div className="bg-red-600 bg-opacity-50 rounded-md p-3 mt-4 text-white">
                                <div className="flex justify-between">
                                    <span>Pomos:</span>
                                    <span>{tasks.filter(t => t.completed).length}/{tasks.length}</span>
                                </div>
                                <div className="flex justify-between">
                                    <span>Finish At:</span>
                                    <span>{finishTime} ({time.minutes / 60}h)</span>
                                </div>
                            </div>
                        </div>
                    </main>

                    {/* Completion Message */}
                    {showCompletionMessage && (
                        <div className="fixed bottom-0 left-0 right-0 bg-white p-4 shadow-lg">
                            <div className="flex justify-between items-center">
                                <div className="flex items-center">
                                    <span className="text-gray-800">You've finished all your tasks for today 🎉</span>
                                </div>
                                <button
                                    onClick={clearAllTasks}
                                    className="bg-green-500 text-white px-4 py-2 rounded-md"
                                >
                                    Clear Tasks
                                </button>
                            </div>
                        </div>
                    )}

                    {/* Task Modal */}
                    {showTaskModal && (
                        <div className="fixed inset-0 bg-black bg-opacity-50 flex items-center justify-center z-50">
                            <div className="bg-white rounded-lg p-6 w-full max-w-md">
                                <input
                                    type="text"
                                    value={taskInput}
                                    onChange={(e) => setTaskInput(e.target.value)}
                                    placeholder="What are you working on?"
                                    className="w-full border-b border-gray-300 py-2 mb-4 focus:outline-none"
                                />
                                
                                <div className="mb-4">
                                    <label className="block text-gray-700 mb-2">Est Pomodoros</label>
                                    <div className="flex items-center">
                                        <input
                                            type="number"
                                            value={estPomodoros}
                                            onChange={(e) => setEstPomodoros(parseInt(e.target.value) || 1)}
                                            className="border border-gray-300 rounded-l-md px-3 py-2 w-16"
                                        />
                                        <button
                                            onClick={() => setEstPomodoros(Math.max(1, estPomodoros - 1))}
                                            className="border border-gray-300 border-l-0 px-3 py-2"
                                        >
                                            ▲
                                        </button>
                                        <button
                                            onClick={() => setEstPomodoros(estPomodoros + 1)}
                                            className="border border-gray-300 border-l-0 rounded-r-md px-3 py-2"
                                        >
                                            ▼
                                        </button>
                                    </div>
                                </div>

                                <div className="flex space-x-2 mb-6">
                                    <button className="text-gray-600 hover:text-gray-800">
                                        + Add Note
                                    </button>
                                    <button className="text-gray-600 hover:text-gray-800">
                                        + Add Project
                                    </button>
                                    <button className="text-gray-600 hover:text-gray-800">
                                        <i className="fas fa-lock"></i>
                                    </button>
                                </div>

                                <div className="flex justify-end space-x-2">
                                    <button
                                        onClick={() => setShowTaskModal(false)}
                                        className="px-4 py-2 text-gray-600 hover:text-gray-800"
                                    >
                                        Cancel
                                    </button>
                                    <button
                                        onClick={saveTask}
                                        className="px-4 py-2 bg-gray-800 text-white rounded-md"
                                    >
                                        Save
                                    </button>
                                </div>
                            </div>
                        </div>
                    )}

                    {/* Information Section */}
                    <footer className="bg-white p-6 mt-auto">
                        <h2 className="text-2xl font-bold text-gray-800 mb-4">An online Pomodoro Timer to boost your productivity</h2>
                        <h3 className="text-xl font-bold text-gray-800 mb-2">What is Pomofocus?</h3>
                        <p className="text-gray-600 leading-relaxed">
                            Pomofocus is a customizable pomodoro timer that works on desktop & mobile browser. The aim of this app is to help you focus on any task you are working on, such as study, writing, or coding. This app is inspired by <a href="#" className="text-red-500">Pomodoro Technique</a> which is a time management method developed by Francesco Cirillo.
                        </p>
                    </footer>
                </div>
            );
        }

        ReactDOM.render(<App />, document.getElementById('root'));
    </script>
</body>
</html>