<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Gridworld</title>

</head>
<body>


<div id="index">0</div>
<input id="prev" type="button" value="Prev"/>
<input id="next" type="button" value="Next">
<input id="download" type="button" value="Download">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<input id="downloadall" type="button" value="Download All">



<gridworld-player id="player" map-name="house" trajectory=""></gridworld-player>
<gridworld-display id="display" map-name="house" trajectory=""></gridworld-display>
<div id="qual"></div>

<script src="//cdn.jsdelivr.net/npm/phaser@3.24.1/dist/phaser.js"></script>

<script type="module" src="dist/vendors.bundle.js"></script>
<script type="module" src="dist/interactive.bundle.js"></script>
<script>

    let explanations = []
    let trajectories = []
    let workerIds = []
    let prompts = []
    let features = []
    let featureNames = ["goal_cov",
        "overlap",
        "length",
        "straight template match",
        "hook template match",
        "goal deviation",
        "collision time",
        "redundant coverage",
        "total coverage",
        "idle time",
        "start-stop template match"
        ]

    function getJSON(path) {
        return fetch(path).then(response => response.json());
    }
    // load JSON data; then proceed
    getJSON('active1_demos.json').then(data => {
        trajectories = JSON.parse(data["trajectories"]
            .replace(/\(/g, '[')
            .replace(/\)/g, ']')
        );
        explanations = data["explanations"]
        workerIds = data["workerIds"]
        prompts = data["prompts"]
        setTraj(0)
    })

    let player = document.getElementById("player")
    let display = document.getElementById("display")
    let index = document.getElementById("index")
    let i = 0;

    function setTraj(i){
        player.setAttribute("trajectory", JSON.stringify(trajectories[i]))
        display.setAttribute("trajectory", JSON.stringify(trajectories[i]))
        let featSummary = ""
        if (i < features.length) {
            feats = features[i].map((num) => {
                return num.toFixed(2)
            })
            featSummary = ""
            for (let j = 0; j < feats.length; j++) {
                featSummary += featureNames[j] + ": " + String(feats[j]) + " \n"
            }
        }
        index.innerText = String(i) + "\n " + featSummary
        const qual = document.getElementById("qual")
        qual.innerText = ""
        if (i < prompts.length) {
            qual.innerText += prompts[i] + "\n"
        }
        if (i < explanations.length) {
            qual.innerText += explanations[i] + "\n"
        }
        if (i < workerIds.length) {
            qual.innerText += workerIds[i] + "\n"
        }
    }
    function recordAndAdvance() {
        if (i === trajectories.length) {
            return
        }
        const readyHandler = () =>{
            player.configureRecorder()
            player.recorder.addEventListener("stop", ()=> {
                player.download(String(vidIndex));
                recordAndAdvance();
            })
            player.play()
            player.removeEventListener("ready",readyHandler)
        }
        player.addEventListener("ready", readyHandler)
        setTraj(i)
        const vidIndex = i
        i++
    }
    document.getElementById("next").addEventListener("click", ()=>{
        i++;
        i = Math.min(trajectories.length - 1, Math.max(0, i))
        setTraj(i)
    })
    document.getElementById("prev").addEventListener("click", ()=>{
        i--;
        i = Math.min(trajectories.length - 1, Math.max(0, i))
        setTraj(i)
    })
    document.getElementById("downloadall").addEventListener("click", ()=> {
        i = 0;
        recordAndAdvance()
    })
    document.getElementById("download").addEventListener("click", ()=> {
        const vidIndex = i
        player.game.game.events.once("postrender", () =>{
            player.configureRecorder()
            player.recorder.addEventListener("stop", ()=> {
                player.download(String(vidIndex));
            })
            player.play()
        })
    })
    setTraj(0)
</script>
</body>
</html>