function getPaging(elem, dataset, limit, item_index) {
    hide_buzz();
    calculate_V_W();
    
    if(elem.checked == true){
        insert_click_in_db(item_index, 'clicked');
        // console.log("selecting an item");
        //check the constraint
        if (sum_w > parseInt(limit)){
            //document.getElementById('weight-warning').innerHTML = "This item exceeds the maximum weight!";
            //document.getElementById('weight-warning').style.display = 'block';
            // alert("check the weight limit.");
            $(".buzz").css("display", "block");
            buzz_toggle = 1;
            //console.log("displayed")
            elem.checked = false;
        }
    }
    else{
        insert_click_in_db(item_index, 'unclicked');
    }

    calculate_V_W();
    update_profit_weight();    
}

function hide_buzz(){
    if(buzz_toggle == 1){
        buzz_toggle =0;
        $(".buzz").css("display", "none");
    }

}

function calculate_V_W(){
    checkedBoxes = document.querySelectorAll('input[type=checkbox]:checked');
    sum_v = 0;
    sum_w = 0;
    let n = checkedBoxes.length;
    for(let i = 0; i < n; i++){
        sum_v += parseInt(checkedBoxes[i].dataset.v);
        sum_w += parseInt(checkedBoxes[i].dataset.w);
    }
}

function update_profit_weight(){
 
    // console.log(sum_v, sum_w);
    document.getElementsByClassName("w")[pages_data.index - tutorial_explanation_lenght].innerText  = "Current Weight = " + sum_w + " lb";
    document.getElementsByClassName("v")[pages_data.index - tutorial_explanation_lenght].innerText  = "Current Value = £" + sum_v;
    // console.log("page index = ", pages_data.index);
    // console.log("sum_w = ", document.getElementsByClassName("w")[pages_data.index - tutorial_explanation_lenght] , 
    //             "  sum_v=", document.getElementsByClassName("v")[pages_data.index - tutorial_explanation_lenght] );
}


function insert_click_in_db(item_index, action){
    setCookie('item-index', item_index);
    setCookie('action', action);
    // console.log("cookies = ", 'participation id = ', getCookie('participation-id'));

   /***************call serverside fucntions ************/
        
   var xhttp = new XMLHttpRequest();

   xhttp.onreadystatechange = function() {
       if (xhttp.readyState === 4) {
       //   var response = JSON.parse(xhttp.responseText);
           if (xhttp.status === 200) {
            //   console.log('saved the click in db.');
           } else {
              alert('There is a problem in the system please try again later.');
           }
       }
     }
  
   xhttp.open("GET", "./db/insert-click.php");
   xhttp.send();
}

function make_answer_array(element){
    li = element.parentNode.parentNode;
    ul = li.parentNode;
    index = Array.prototype.indexOf.call(ul.children, li);
    answer_array.push(index);
}

function submit_answer(opt, is_ml = 0, ml_ans =0, state = 0){
    // console.log("submit answer called", "optimum = ", opt);
    calculate_V_W();
    if (is_ml ==1 ){
        setCookie('gained-value', ml_ans);
        setCookie('gained-capacity', 0);
        performance = parseFloat(ml_ans) / parseFloat(opt);  
    }
    else{
        setCookie('gained-value', sum_v);
        setCookie('gained-capacity', sum_w);  
        // console.log("sum_v=", sum_v);
        performance = parseFloat(sum_v) / parseFloat(opt);
        // console.log("performance=", performance);
    }
      
    
    
    
    // console.log("sum_v, max_V= ", sum_v, opt )
    setCookie('performance', performance.toString() ); 
    // console.log("performance in cookie = ", getCookie("performance")); 
    
    setCookie('is-ml', is_ml);
    games_assigned['performance'].push(performance);

    answer_array = []
    checkedBoxes.forEach(make_answer_array);
    setCookie('answers', JSON.stringify(answer_array));
    // console.log("item indexes = " , getCookie('answers'));
    // console.log("performance to store in db =  " , getCookie('performance'));


    
    //save the time 
    end_time = new Date();
    // end_time = date.getSeconds();
    time_spent = end_time - start_time;
    setCookie('time-spent', time_spent);
    // console.log("time spent = ", time_spent);
    
    //timer should stop
    clearInterval(interval_id);    
    
    /***************call serverside fucntions ************/
        
   var xhttp = new XMLHttpRequest();

   xhttp.onreadystatechange = function() {
       if (xhttp.readyState === 4) {
       //   var response = JSON.parse(xhttp.responseText);
           if (xhttp.status === 200) {
            //   console.log('saved the click in db.');
           } else {
              alert('There is a problem in the system please try again later.');
           }
       }
     }
  
   xhttp.open("GET", "./db/insert-answer.php");
   xhttp.send();
}


function make_performance_table(){
    let str = '';
    let sum = 0;
    for (let i = 0 ; i < 10; i++){
        temp = Math.round(games_assigned['performance'][i+2] * 100);//// to show 2 decimal digit
        // temp = temp.toFixed(0);
        str += `<tr> <td> ${i+2}</td><td> ${ temp } %</td> </tr>`;
        // sum += parseInt(temp);
        sum += temp;
    }
    document.getElementById("performanc-table-body").innerHTML = str;

    //total avg
    avg = (sum / 10.0)  || 0;
    // document.getElementById("perf-avg").innerHTML = Math.round(avg*100)/100;; // to show 2 decimal digit
    document.getElementById("perf-avg").innerHTML = avg.toFixed(2); // to show 2 decimal digit
    
    
}



var checkedBoxes = [];
var answer_array = [];
var sum_v = 0;
var sum_w = 0;
buzz_toggle = 0;