<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>失控宝可梦</title>
    <link rel="stylesheet" href="index.css">
    <link href="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/themes/prism-tomorrow.min.css" rel="stylesheet">
    <script src="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/prism.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/prism/1.29.0/components/prism-python.min.js"></script>
    <style>
        body {
            margin: 0;
            padding: 0;
            font-family: "Futura", Arial, sans-serif;
            background: url("asset/bg.png") no-repeat center center;
            background-size: cover;
            height: 100vh;
            display: flex;
            justify-content: center;
            align-items: center;
            position: relative;
            flex-direction: column;
        }
        body::before {
            content: "";
            position: absolute;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            background-color: rgba(255, 255, 255, 0.9);
            z-index: 1;
        }
        .start-section {
            width: 100%;
            z-index: 3;
        }
        .battle-section {
            position: absolute;
            width: 80%;
            height: 80%;
            z-index: 2;
        }

        .hidden {
            display: none;
        }

        .attack-animation-1 {
            animation: attackAnimation1 1s forwards;
        }
        .attack-animation-2 {
            animation: attackAnimation2 1s forwards;
        }
        .shake-animation {
            animation: shakeAnimation 0.75s ease-in-out;
        }
        .faint-animation {
            animation: faintAnimation 1.5s forwards;
        }
        @keyframes attackAnimation1 {
            0% {
                transform: translateX(0);
            }
            50% {
                transform: translate(100%, -50%);
            }
            100% {
                transform: translateX(0);
            }
        }
        @keyframes attackAnimation2 {
            0% {
                transform: translateX(0);
            }
            50% {
                transform: translate(-100%, 50%);
            }
            100% {
                transform: translateX(0);
            }
        }
        @keyframes shakeAnimation {
            0% { transform: translateX(0) rotate(0deg); }
            25% { transform: translateX(-15px) rotate(-5deg); }
            50% { transform: translateX(15px) rotate(5deg); }
            75% { transform: translateX(-15px) rotate(-5deg); }
            100% { transform: translateX(0) rotate(0deg); } 
        }
        @keyframes faintAnimation {
            0% {
                transform: translateY(0);
                opacity: 1;
            }
            100% {
                transform: translateY(200%);
                opacity: 0;
            }
        }

    </style>
</head>
<body>

    <div class="start-section" id="start">
        <h1>Create Initial Pokémon</h1>
    
        <div class="panel">
            <div class="left-panel">
                <div class="input-container">
                    <label for="species">SPECIES</label>
                    <input type="text" id="species" name="species" placeholder="Pokémon species (e.g. Salamence, Mewtwo)", value="Reshiram">
                </div>
                <div class="input-container">
                    <label for="hp">STATS (&lt 600)</label>
                    <div class="stats-input">
                        <input type="number" id="hp" name="hp" placeholder="Base HP", value=100>
                        <input type="number" id="atk" name="atk" placeholder="Base Atk", value=100>
                        <input type="number" id="def" name="def" placeholder="Base Def", value=100>
                        <input type="number" id="spa" name="spa" placeholder="Base SpA", value=100>
                        <input type="number" id="spd" name="spd" placeholder="Base SpD", value=100>
                        <input type="number" id="spe" name="spe" placeholder="Base SpE", value=100>
                    </div>
                </div>
                <div class="input-container">
                    <label for="types">TYPES</label>
                    <div class="types-input">
                        <select type="text" id="type1" name="type1" style="width: 39%">
                            <option value="" disabled selected>Type 1</option>
                            <option value="131Lapras.png">Bug</option>
                            <option value="Dark">Dark</option>
                            <option value="Dragon">Dragon</option>
                            <option value="Electric">Electric</option>
                            <option value="Fairy">Fairy</option>
                            <option value="Fighting">Fighting</option>
                            <option value="Fire">Fire</option>
                            <option value="Flying">Flying</option>
                            <option value="Ghost">Ghost</option>
                            <option value="Grass">Grass</option>
                            <option value="Ground">Ground</option>
                            <option value="Ice">Ice</option>
                            <option value="Normal">Normal</option>
                            <option value="Poison">Poison</option>
                            <option value="Psychic">Psychic</option>
                            <option value="Rock">Rock</option>
                            <option value="Steel">Steel</option>
                            <option value="Water">Water</option>
                        </select>
                        <select type="text" id="type2" name="type2" style="width: 39%">
                            <option value="" disabled selected>Type 2</option>
                            <option value="131Lapras.png">Bug</option>
                            <option value="Dark">Dark</option>
                            <option value="Dragon">Dragon</option>
                            <option value="Electric">Electric</option>
                            <option value="Fairy">Fairy</option>
                            <option value="Fighting">Fighting</option>
                            <option value="Fire">Fire</option>
                            <option value="Flying">Flying</option>
                            <option value="Ghost">Ghost</option>
                            <option value="Grass">Grass</option>
                            <option value="Ground">Ground</option>
                            <option value="Ice">Ice</option>
                            <option value="Normal">Normal</option>
                            <option value="Poison">Poison</option>
                            <option value="Psychic">Psychic</option>
                            <option value="Rock">Rock</option>
                            <option value="Steel">Steel</option>
                            <option value="Water">Water</option>
                        </select>
                    </div>
                </div>
                <div class="input-container">
                    <label for="ability">ABILITY</label>
                    <div class="ability-input">
                        <input type="text" id="ability-name" name="ability-name" placeholder="Initial ability", value="Elemental Heart">
                        <input type="text" id="ability-effect" name="ability-effect" placeholder="Effect", value="Each time this Pokemon uses a non-Normal type moves (X-type), it becomes Normal+X type before moving.">
                    </div>
                </div>
                <div class="input-container">
                    <label for="move1">MOVE 1</label>
                    <div class="move-input-1">
                        <input type="text" id="move1-name" name="move1-name" placeholder="Name">
                        <input type="text" id="move1-power" name="move1-power" placeholder="Power">
                        <input type="text" id="move1-accuracy" name="move1-accuracy" placeholder="Accuracy">
                        <input type="text" id="move1-category" name="move1-category" placeholder="Category">
                        <input type="text" id="move1-type" name="move1-type" placeholder="Type">
                        <input type="number" id="move1-priority" name="move1-priority" placeholder="Priority">
                        <input type="text" id="move1-property" name="move1-property" placeholder="Property">
                    </div>
                    <input type="text" id="move1-effect" name="move1-effect" placeholder="Effect">
                </div>
                <div class="input-container">
                    <label for="move2">MOVE 2</label>
                    <div class="move-input-1">
                        <input type="text" id="move2-name" name="move2-name" placeholder="Name">
                        <input type="text" id="move2-power" name="move2-power" placeholder="Power">
                        <input type="text" id="move2-accuracy" name="move2-accuracy" placeholder="Accuracy">
                        <input type="text" id="move2-category" name="move2-category" placeholder="Category">
                        <input type="text" id="move2-type" name="move2-type" placeholder="Type">
                        <input type="number" id="move2-priority" name="move2-priority" placeholder="Priority">
                        <input type="text" id="move2-property" name="move2-property" placeholder="Property">
                    </div>
                    <input type="text" id="move2-effect" name="move2-effect" placeholder="Effect">
                </div>
            </div>
            <div class="right-panel">
                <div class="input-container">
                    <label for="avatar">AVATAR</label>
                    <select id="avatar" name="avatar" onchange="avatarDisplay()">
                        <option value="" disabled selected>Choose a loverly avatar</option>
                        <option value="131Lapras.png">131Lapras</option>
                        <option value="142Aerodactyl-Mega.png">142Aerodactyl-Mega</option>
                        <option value="145Zapdos.png">145Zapdos</option>
                        <option value="212Scizor.png">212Scizor</option>
                        <option value="248Tyranitar.png">248Tyranitar</option>
                        <option value="257Blaziken-Mega.png">257Blaziken-Mega</option>
                        <option value="373Salamence-Mega.png">373Salamence-Mega</option>
                        <option value="448Lucario.png">448Lucario</option>
                        <option value="643Reshiram-Activated.png" selected>643Reshiram</option>
                        <option value="741Oricorio-Pom-Pom.png">741Oricorio-Pom-Pom</option>
                        <option value="792Lunala.png">792Lunala</option>
                        <option value="937Ceruledge.png">937Ceruledge</option>
                        <option value="1003Ting-Lu.png">1003Ting-Lu</option>
                        <option value="Neos.webp">Neos</option>
                        <option value="Graphal.webp">Graphal</option>
                        <option value="Tigrex.png">Tigrex</option>
                    </select>
                </div>
                <div class="avatar-display">
                    <img id="avatar-image" src="asset/pm/643Reshiram-Activated.png">
                </div>
            </div>
        </div>

        <div class="input-container">
            <button class="start-battle">Start Your Journey</button>
        </div>
    </div>

    <div class="battle-section hidden">

        <!-- Code -->
        <button class="toggle-code-display" onclick="toggleCodeDisplay()">Code for </button>
        <div class="code-display">
            <pre><code class="language-python"></code></pre>
        </div>

        <!-- Log -->
        <div class="log-container">
            <!-- <div class="log-entry"></div> -->
        </div>

        <!-- Pokemon 1 -->
        <div class="pokemon-container pokemon-1">
            <div class="pokemon">
                <img src="" alt="Pokemon-1">
            </div>
            <div class="info-container">
                <div class="name">--</div>
                <div class="hp-bar">
                    <div class="hp"></div>
                    <div class="hp-value"></div>
                </div>
                <div class="status">
                    <img src="">
                </div>
            </div>
        </div>

        <!-- Pokemon 2 -->
        <div class="pokemon-container pokemon-2">
            <div class="pokemon">
                <img src="" alt="Pokemon-2">
            </div>
            <div class="info-container">
                <div class="name">--</div>
                <div class="hp-bar">
                    <div class="hp"></div>
                </div>
                <div class="status">
                    <img src="">
                </div>
            </div>
        </div>

        <!-- Move Select -->
        <div class="move-select">
            <button class="move" description="--">
                <img src="asset/type/Normal.png">
                <div class="move-name">Move 1
                    <div class="move-info">pow: -- acc: --</div>
                </div>
            </button>
            <button class="move" description="--">
                <img src="asset/type/Normal.png">
                <div class="move-name">Move 2
                    <div class="move-info">pow: -- acc: --</div>
                </div>
            </button>
            <button class="move" description="--">
                <img src="asset/type/Normal.png">
                <div class="move-name">Move 3
                    <div class="move-info">pow: -- acc: --</div>
                </div>
            </button>
            <button class="move" description="--">
                <img src="asset/type/Normal.png">
                <div class="move-name">Move 4
                    <div class="move-info">pow: -- acc: --</div>
                </div>
            </button>
            <button class="move" description="--">
                <img src="asset/type/Normal.png">
                <div class="move-name">Move 5
                    <div class="move-info">pow: -- acc: --</div>
                </div>
            </button>
            <button class="move" description="--">
                <img src="asset/type/Normal.png">
                <div class="move-name">Move 6
                    <div class="move-info">pow: -- acc: --</div>
                </div>
            </button>
        </div>
        <button class="restart">Restart</button>
    </div>
    <div class="tooltip hidden"></div>

    <div class="result-section hidden">
        <div class="result-container">
            <button class="next-battle">Next Battle</button>
        </div>
    </div>
    
    <script>

        const tooltip = document.querySelector(".tooltip");

        document.querySelectorAll(".move").forEach(move => {
            move.addEventListener("mouseenter", (e) => {
                const description = move.getAttribute("description");
                tooltip.textContent = description;
                tooltip.style.display = "block";
                const rect = move.getBoundingClientRect();
                tooltip.style.left = rect.right - 50 + "px";
                tooltip.style.top = rect.top + "px";
            });

            move.addEventListener("mouseleave", () => {
                tooltip.style.display = "none";
            });
        });

        document.addEventListener("keydown", function(event) {
            if (event.code === "Space") {
                let init = {};
                let inputs = document.querySelectorAll(".start-section input, .start-section select");
                inputs.forEach(i => {
                    init[i.name] = i.value;
                });
                initState(init);
            }
        });

        function toggleCodeDisplay() {
            const codeDisplay = document.querySelector(".code-display");
            codeDisplay.classList.toggle("open");
        }

        document.querySelector(".start-battle").addEventListener("click", () => {
            let init = {};
            let inputs = document.querySelectorAll(".start-section input, .start-section select");
            inputs.forEach(i => {
                init[i.name] = i.value;
            });
            initState(init);
            document.querySelector(".battle-section").classList.remove("hidden");
            document.getElementById("start").style.display = "none";
        });

        document.querySelectorAll(".move").forEach((move, i) => {
            move.addEventListener("click", () => {
                const moveId = move.querySelector(".move-name").firstChild.textContent.trim();
                updateState(moveId);
            });
        });

        document.querySelector(".restart").addEventListener("click", () => {
            document.querySelector(".battle-section").classList.add("hidden");
            document.getElementById("start").style.display = "block";
        });

        document.querySelector(".next-battle").addEventListener("click", () => {
            let init = {};
            let inputs = document.querySelectorAll(".start-section input, .start-section select");
            inputs.forEach(i => {
                init[i.name] = i.value;
            });
            initState(init);
            document.querySelector(".result-section").classList.add("hidden");
            document.querySelector(".battle-section").classList.remove("hidden");
        });

        function avatarDisplay() {
            const avatarSelect = document.getElementById("avatar");
            const avatarValue = avatarSelect.value;
            const avatarImage = document.getElementById("avatar-image");
            
            if (avatarValue) {
                avatarImage.src = `asset/pm/${avatarValue}`;
            }
        }

    </script>
    <script src="battle.js"></script>
    <script src="animation.js"></script>

</body>
</html>
