function tutorial_explanation_page(page_index, adrs, txt, treatment){
    let str = '';
    // carousel-item
    page_index == 0 ?
    str = `<div class="carousel-item active">` :
    str = `<div class="carousel-item ">`;

    str += `
    <div class="container-md px-3 pt-4">`;
    if(page_index > 0){
        str+=`
        <button class="next-btn new-next-btn back-btn"  onClick="backward_slide()">Back</button>
        `;
    }

    if(page_index == 4){
        str+=`
        <button class="next-btn new-next-btn " onClick="next_page(0)">Next</button>
        `;
    }
    else{
        str+=`
        <button class="next-btn new-next-btn " onClick="next_page(2)">Next</button>
        `;
    }
    
    str +=`<p>${txt}</p>`;

    if (page_index == 0){
    str+=`
    <img src="${adrs}" alt="tutorial explanation" width="180" height="auto" style="display: block;
    margin-left: auto;
    margin-right: auto;">`;
    }
    else if (page_index == 2 ){
        str+=`
        <img src="${adrs}" alt="tutorial explanation" width="auto" height="200px" style="display: block;
        margin-left: auto;
        margin-right: auto;
        ">`;    
    }
    else if (page_index == 3){
        str+=`
        <img src="${adrs}" alt="tutorial explanation" width="auto" height="220px" style="display: block;
        margin-left: auto;
        margin-right: auto;
        ">`;    
    }else if (page_index == 4){
        str+=``;
    }
    else{
        str+=`
        <img src="${adrs}" alt="tutorial explanation" width="auto" height="290px" style="display: block;
        margin-left: auto;
        margin-right: auto;
    ">`;
    }

    
    //  end container, end item
    str += `</div>
    </div>`;

    return str;
}


function tutorial_question_page(page_index, pages_length, max_W, max_V, values, weights, ml_recom){

    //show values from json data
    
    let str = '';
    // carousel-item
    str = `<div class="carousel-item ">`;
   
    str += `
    <div class="container-md px-3 pt-4">`;

    str +=  `       
    <div id="controller" style="display:block !important;" >
            <button class="next-btn new-next-btn " onClick="show_feedback(${max_V});">Submit</button>
	        <h5 id="problem-title"> Practice Problem ${page_index + 1} / ${tutorials_length} </h5>
            <p id="info">
                <span id="constraint">Maximum Possible Weight = ${max_W} lb</span>  
                &emsp; 
                <span class="w"> Current Weight = 0 lb</span>  
                &emsp; <span class = "v"> 
                Current Value = £0 </span>&emsp; 
                </p>
            <p class ="count-down" ></p>
            <a class="ml-btn ${treatment_style}" onClick="show_feedback(${max_V}, 1, ${ml_recom} )"> Take AI's Solution with £${ml_recom}</a>
            <p class="buzz"> <b>Error:</b> The weight of this item exceeds the maximum possible weight!</p>
            <hr>
    </div>`;

    str += `<ul class='items'>`;
    for(let i = 0; i < 18; i++){
        str +=`<li >
        <label>
          <input type="checkbox" name="" data-w=${weights[i]} data-v=${values[i]} onclick="getPaging(this, this.dataset,${max_W}, ${i} )">
          <div class="icon-box">
            <i class="fa " aria-hidden="true" >£${values[i]}<br><br>${weights[i]} lb </i>
          </div>
        </label>
      </li>`;
    }
    str +=`</ul>`;

    // closing items
    str += '</div>';


    // end options, end container
    str += `  </div>
    </div>`;
    
    str+='</div>'
    return str;
}

function make_problem(problem_index, max_W, values, weights, max_V, ml_recom){
    let str = '';
    // carousel-item
    str = `<div class="carousel-item ">`;
   
    str += `
    <div class="container-md px-3 pt-4">`;
    let next_state = 1; //0: tutorail , 1: it is a problem, 2 : next page does not need any timer
    if ((problem_index + 1) == problems_length ){
        next_state = 2;//no timer for next page
        // console.log("there should be no timer");
    }
    str +=  `       
    <div id="controller" style="display:block !important;" >
            <button class="next-btn new-next-btn" onclick="show_break(${max_V}, 0,0, ${next_state} );" >Submit</button>
	    <h5 id="problem-title">Problem ${problem_index + 1} / ${problems_length} </h5>
            <p id="info">
                <span id="constraint">Maximum Possible Weight = ${max_W} lb</span>  
                &emsp; 
                <span class="w"> Current Weight = 0 lb</span>  
                &emsp; 
                <span class = "v"> Current Value = £0 </span> 
                &emsp; 
                </p>
            <p class ="count-down" ></p>
            <a class="ml-btn ${treatment_style}" onClick="show_break(${max_V}, 1, ${ml_recom}, ${next_state})"> Take AI's Solution with £${ml_recom}</a>
            <p class="buzz"> Error: The sum weight can not exceed the limit.</p>
            <hr>
    </div>`;

    // items
    str += `<ul class='items'>`;
    for(let i = 0; i < 18; i++){
        str +=`<li >
        <label>
          <input type="checkbox" name="" data-w=${weights[i]} data-v=${values[i]} onclick="getPaging(this, this.dataset, ${max_W}, ${i})">
          <div class="icon-box">
            <i class="fa " aria-hidden="true" >£${values[i]}<br><br>${weights[i]} lb </i>
          </div>
        </label>
      </li>`;
    }
    str +=`</ul>`;

    // closing items
    str += '</div>';


    // end options, end container
    str += `  </div>
    </div>`;
    
    str+='</div>'
    return str;
}



function success_end_page(){
    // start caruosel item
    str = `<div class="carousel-item end-page">` ;

    // container, header, text, socials
    str += `
    <div class="container-md px-3 pt-4">
        <h5>Finished succesfully</h5>
        <hr>
        <p>
        Thanks for your effort. You successfully finished the study.
        <br><br>
        Press on finish and you will be redirected to the Prolific website. 
        </p>
        <br>
        <br>
        <button onclick="finisher(1)" class="btn btn-success finish">Finish</button>
    `
    str+=`</div>
    </div>`
    return str;
}


function finisher(flag){
    //update success
    /***************call serverside fucntions ************/
    var xhttp = new XMLHttpRequest();

    xhttp.onreadystatechange = function() {
        if (xhttp.readyState === 4) {
        //   var response = JSON.parse(xhttp.responseText);
            if (xhttp.status === 200) {
            //    alert('successful');
                // window.location = './index.php'
                console.log("done.");
            } else {
            alert('There is a problem in the system please try again later.');
            }
        }
    }

    xhttp.open("GET", "./db/on-success.php");
    xhttp.send();


    //style for footer
   footer = document.getElementById("my-footer");
   footer.classList.remove("mobile-position");
   footer.style.position = "fixed !important";
   
    /****remove the cookies */
   deleteCookies();

   console.log("----------Bye------------");


   //redirect to prolific

}


function start_timer(state){
    // state= 0 --> tutorial 
    // state= 1 --> problem

    
    update_problem_info();


    // document.getElementById("count-down").innerHTML = "";
    update_counter("")
    var timeleft = 180;//180
    interval_id = setInterval(function(){
      if(timeleft <= 0){
        console.log("-------time's up------", "state = ", state );
        
        is_hidden = document.getElementsByName("break")[0].style.display != "block";

        if( is_hidden  ){// if the person did not click on submit)
            // clearInterval(downloadTimer);
            clearInterval();
            update_counter(timeleft + " Finished");

            if(state == 0 ){//it is a tutorial question
                temp_index = pages_data['index'] - tutorial_explanation_lenght; //0, 1               
                show_feedback(ks_tutorial[temp_index]["optimum"]);

            }else{//it is a task
                temp_index = pages_data['index'] - tutorial_explanation_lenght;
                temp_task_index = games_assigned["game-id"][temp_index] - 1;//because the ids in ks_tasks starts from 1
                console.log("current game index = ", games_assigned["game-id"][temp_index]);
                console.log("opt = ", ks_tasks[temp_task_index]["optimum"]);
                show_break(parseInt(ks_tasks[temp_task_index]["optimum"])); 
            }
        }

      } else {
        update_counter(timeleft + " seconds remaining");
      }
      timeleft -= 1;
    }, 1000);
}

function update_counter(text){
    const boxes = document.querySelectorAll('.count-down');

    boxes.forEach(box => {
   box.innerHTML = text;
    });
}

function update_problem_info(){
        // document.getElementById("problem-title").innerText= `Tutorial ${+1} / ${tutorials_length}`;
        //clean last variables
        clearInterval(interval_id);
        $('input:checkbox').removeAttr('checked');
        document.getElementsByClassName("w").innerText  = "Current Weight =" + 0;
        document.getElementsByClassName("w").innerText  = "Current Value =" + 0;
        start_time = new Date();
        // start_time = date.getSeconds();
}

function show_feedback(opt, is_ml = 0, ml_ans = 0){
    //save the answers in db
    submit_answer(opt, is_ml, ml_ans);

    document.getElementById("tutorial_feedback").style.display = "block";
    document.getElementById("opt_value").innerHTML=opt;
    let perc =0;
    if (is_ml == 1){
        document.getElementById("feedback_value").innerHTML=ml_ans;
        perc = (ml_ans/opt)*100;
    }
    else{
        document.getElementById("feedback_value").innerHTML=sum_v;
        perc = (sum_v/opt)*100;
    }

    document.getElementById("percentage_value").innerHTML=perc.toFixed(0);
    sum_v = 0;

    if(pages_data['index'] - tutorial_explanation_lenght == 1  ){//this is the second tutorial
        // console.log("Attention!!!! The tasks start after this.");
        

        document.getElementById("next_tutorial_btn").style.display ="none";
        const elements = document.querySelectorAll('.last_tutorial_info');
        elements.forEach(e => {
        e.style.display = 'block';
        });
    }
}

function from_feedback_to_next_page(state){//0 tutorial problem //1 problem
    document.getElementById("tutorial_feedback").style.display = "none";
    next_page(state);
}

function show_break(opt, is_ml = 0, ml_recom = 0, state = 1){
    document.getElementById("problem_break").style.display = "block";
    document.getElementById("next-problem-btn").onclick = function jsFunc() {
        from_break_to_next_problem(state);
        } ;
    submit_answer(opt, is_ml, ml_recom, state);
}

function from_break_to_next_problem(state=1){
    document.getElementById("problem_break").style.display = "none";
    next_page(state);
}

function backward_slide(){
    hide_buzz();
    $('#myCarousel').carousel('prev');
    pages_data.index--;
}

function check_quiz(){
    var radio_btn = document.getElementById('no');
    var answer1 = document.getElementById('earnings').value;
    var answer2 = document.getElementById('earnings2').value;
    var treatment = getCookie('treatment');
    if (treatment == "yes_monetary_no_ml"){
        if ((answer1 == '4.00' || answer1 == '4') && (answer2 == '0' || answer2 == '0.00')){
            return true;
        }else{
            return false;
        }
    }else{
    if (radio_btn.checked && (answer1 == '4.00' || answer1 == '4') && (answer2 == '0' || answer2 == '0.00')){
        return true;
    }else{
        return false;
    }
    }
}

function next_page(state){    //0 tutorial problem //1 problem //2 no time        
    // /***** handle carousel next ******/
    // if(document.querySelectorAll('.carousel-item .options')[pages_data.index].querySelectorAll('input:checked').length==0
    //     && pages_data.index >= tutorials_length
    // ){
    //     alert('Please try to solve the problem.');
    //     return;
    // }
    // else{
        //uncheck all
        // var checkedBoxes = document.querySelectorAll('input[type=checkbox]:checked');
        if (state !=2  && !check_quiz()){
            document.getElementById('incorrect').style.display = 'block';
        }else{
            hide_buzz();
            pages_data.index++;
            $('#myCarousel').carousel('next');
            if (state !=2){
                start_timer(state);
                start_new_problem();
                problem_id++;
            // if (problem_id == 0){
            //     problem_id = 1; //the knapsak tasks id start from 1
            // }
            }
        }
        //if it is last page:
        // alert( pages_data.index, tutorials_length);
    // }
 
}

function factory(){

    // make tutorial_explanation_pages
    // treatment = 'no_monetary_no_ml';
    
    //var treatment = getCookie('treatment');// this triggers race condition in firefox
    var rec_string = ""
    //console.log(treatment)
    if (treatment.includes('q1')){
        rec_string = "recommendation_value_q1"
    }else if(treatment.includes('q2')){
        rec_string = "recommendation_value_q2"
    }else if(treatment.includes('q3')){
        rec_string = "recommendation_value_q3"
    }else if(treatment.includes('q4')){
        rec_string = "recommendation_value_q4"
    }else if(treatment.includes('q5')){
        rec_string = "recommendation_value_q5"
    }else if (treatment.includes('q6')){
        rec_string = "recommendation_value_q6"
    }else if (treatment.includes('q7')){
        rec_string = "recommendation_value_q7"
    }else if (treatment.includes('q8')){
        rec_string = "recommendation_value_q8"
    }else if (treatment.includes('q9')){
        rec_string = "recommendation_value_q9"
    }else if(treatment.includes('q10')){
        rec_string = "recommendation_value_q10"
    }

    l = image_addresses.length;
    for(let i =0; i < l; i++){
        //console.log(image_addresses[i])
        pages_data.pages.push(tutorial_explanation_page(i, image_addresses[i], instructions[i], treatment));
    }

    
    // make tutorial_question_pages
    
    for(let i =0; i < tutorials_length; i++){
        max_W = ks_tutorial[i]['W'];
        max_V = ks_tutorial[i]['optimum'];
        values = ks_tutorial[i]["values"];
        weights = ks_tutorial[i]["weights"];
        ml_recom =  ks_tutorial[i][rec_string];
        pages_data.pages.push(tutorial_question_page(i, tutorials_length, max_W, max_V, values, weights, ml_recom));
    }
    // make problem pages
    for (let i = 0 ; i < problems_length; i++){
        id = games_assigned['game-id'][i+2]; //load the game after 2 tutorials
        // console.log("making problem for game id = " , id);
        // console.log(id);
        // console.log(ks_tasks)
        // console.log(ks_tasks[id-1]);
        max_W = ks_tasks[id-1]['W'];
        max_V = ks_tasks[id-1]['optimum'];
        values = ks_tasks[id-1]["values"];
        weights = ks_tasks[id-1]["weights"]; 
        ml_recom =  ks_tasks[id-1][rec_string];
        pages_data.pages.push(make_problem(i, max_W, values, weights, max_V, ml_recom))
    }
    
  //make demographic question pages
    //demographic_pagesload the text
    demographic_pages = '';
    $.ajax({
        url: './demographic-info.php',
        async: false,
        dataType: 'text',
        success: function (str) {
            if(treatment.includes("yes_ml")){
                str = str.replace("If you would have had recommendations from an algorithm to solve each problem, how much effort would you have put in solving the problems?", "If you would have had no recommendations from the algorithm to solve each problem, how much effort would you have put in solving the problems?")
            }
            demographic_pages = str;
        }
        });
    pages_data.pages.push(demographic_pages);
  

    //performance page
    performance_page = '';
    $.ajax({
        url: './performance-table.php',
        async: false,
        dataType: 'text',
        success: function (str) {
            performance_page = str;
        }
        });
    pages_data.pages.push(performance_page);

    // pages_data.pages.push(success_end_page());
}

function index_main(){
    document.querySelector('.carousel-inner').innerHTML = '';
    factory();
    document.querySelector('.carousel-inner').innerHTML = pages_data.pages.join('\n');

    //check for Navigation Timing API support
    // if (window.performance) {
        // console.info("window.performance works fine on this browser");
    // }
    // console.info(performance.navigation.type);
    if (performance.navigation.type == performance.navigation.TYPE_RELOAD) {
        console.info( "This page is reloaded" ); //maybe makes some bug for repeated users
        page_to_show = getCookie('last-page');
        console.log("----> page to show is ---> " + page_to_show ); 
        if(page_to_show == null){
            page_to_show = 0;
        }
        //show that page 
        document.querySelector('.active').classList.remove("active");
        to_show_index = parseInt(page_to_show , 10);//+ 5 number of tutorials
        pages_data.index = to_show_index;
        document.querySelectorAll('.carousel-item')[to_show_index].classList.add('active');
    } //else {
        // console.info( "This page is not reloaded");
    //}


}

if_id_exists('index');

