<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8">

    <!-- read in js libraries -->
    <script src="../static/lib_clf/jquery-3.3.1/jquery.min.js"></script>
    <script src="../static/lib_clf/jquery-3.3.1/jquery.msgBox.js"></script>
    <link href="../static/lib_clf/jquery-3.3.1/msgBoxLight.css" rel="stylesheet" type="text/css"></script>
    <script src="../static/lib_clf/jspsych-6.3.1/jspsych.js"></script>
    
    <script src="../static/js_clf/nivturk-plugins.js" type="text/javascript"></script>

    <!-- read in jsPsych plugins -->
    <script src="../static/lib_clf/jspsych-6.3.1/plugins/jspsych-html-keyboard-response.js"></script>
    <script src="../static/lib_clf/jspsych-6.3.1/plugins/jspsych-fullscreen.js"></script>

    <script src="../static/lib_clf/jspsych-6.3.1/plugins/jspsych-image-slider-response.js"></script>
    <script src="../static/lib_clf/jspsych-6.3.1/plugins/jspsych-call-function.js"></script>
    <script src="../static/lib_clf/jspsych-6.3.1/plugins/jspsych-html-button-response.js"></script>
    <script src="../static/lib_clf/jspsych-6.3.1/plugins/jspsych-preload.js"></script>
    <!--<script src="../static/lib/jspsych-6.3.1/plugins/jspsych-image-button-response.js"></script>-->

    <!-- read in static variables for running experiment -->
    <script src="../static/js_clf/load_imgs.js"></script>
    <script src="../static/js_clf/instructions.js"></script>
    <script src="../static/js_clf/label_trial.js"></script>
    <script src="../static/js_clf/practice_trial.js"></script>

    <!-- read in stylesheets -->
    <link href="../static/lib_clf/jspsych-6.3.1/css/jspsych.css" rel="stylesheet" type="text/css"></link>
    <script>
      var task_imgs = get_task_imgs()      
      
      //var task_imgs = ["../static/img/cifar10_250pair_norm_linsp_128/set0/m_cifar10_0_0_0_0_norm.png",
      //                  "../static/img/cifar10_250pair_norm_linsp_128/set0/m_cifar10_0_0_10_10_norm.png",
      //                  "../static/img/cifar10_250pair_norm_linsp_128/set0/m_cifar10_0_2_2_2_norm.png",
      //                  "../static/img/cifar10_250pair_norm_linsp_128/set0/m_cifar10_0_2_12_12_norm.png", ]
          
    </script>
  </head>
  <body>
  </body>
  <script>

  //------------------------------------
  // Messages and landing pages
  //------------------------------------
  
  //console.log(task_imgs)
  var consentform = {
    type: "html-button-response",
    choices: ["I accept", "No thank you"],
    stimulus: "<h1>CONSENT FORM</h1>"
    +"<p>You are being asked to participate in a research study conducted by the Center for Neuroscience-Inspired Artificial Intelligence (CNAI) at the Korea Advanced Institute of Science and Technology (KAIST).</p>"
    +"<h2>Purpose of the research:</h2><p>This study aims to understand humans’ decision-making probability in visual perception.</p>"
    +"<h2>Study Procedures:</h2><p>Select the class to which the image belongs for each trial. For some images, the correct answer may be unclear, and there may be acceptable close answers. Therefore, we expect you to make your selection as accurately as possible. After selecting a class, click the “submit” button or press “Shift”+“Enter” to confirm your selection.</p>"
    +"<p>Your total expected time commitment for this study is 30 minutes.</p>"
    +"<h2>Benefits and risks:</h2><p>This task consists of 125 trials; you must complete them before submitting the HIT. Throughout the survey, we insert attention checks to encourage and monitor whether you completed the task in good faith. Please adhere to these checks to avoid the rejection of your HIT, and you may not receive the reward.</p>"
    +"<h2>Confidentiality:</h2><p>To protect your privacy, we will use your Mechanical Turk Worker ID to distribute the payment. While your Mturk Workers ID can potentially be linked to information about you on your Amazon Public Profile page, we will not access any personally identifying information from your Amazon Public Profile.</p>"
    +"<h2>Compensation:</h2><p>We will pay you 1.5 USD after completing the survey.</p>"
    +"<hr><p>I understand the information that was presented and that:<blockquote>My participation is voluntary, and I may withdraw my consent and discontinue participation in the project at any time. My refusal to participate will not result in any penalty.</blockquote>By clicking the box below, I hereby give my consent to be the subject of your research.</p>",

    on_finish: function(data){
      document.body.style.overflowY = "hidden";
      document.body.style.backgroundColor = '#d2d2d2'
      if(data.response == 1){
        console.log(data.trial_type);
        jsPsych.endExperiment();
      }
    }
  }

  // define welcome message
  var welcome = {
    type: "html-keyboard-response",
    stimulus: "Welcome to the experiment. Press any key to begin.",
    on_start: function(){
      document.body.style.overflowY = "hidden";
      document.body.style.backgroundColor = '#d2d2d2'
    }
  };

  //------------------------------------
  // Functions to turn fullscreen on/off
  //------------------------------------
  var page = document.documentElement;

  function openFullScreen () {
    if (page.requestFullscreen)
        page.requestFullscreen();
    else if (page.webkitRequestFullscreen) // Chrome, Safari (webkit)
        page.webkitRequestFullscreen();
    else if (page.mozRequestFullScreen) // Firefox
        page.mozRequestFullScreen();
    else if (page.msRequestFullscreen) // IE or Edge
        page.msRequestFullscreen();
  }

  var fullscreen_on = {
    type: "fullscreen",
    fullscreen_mode: true,
    message: '<p>The experiment will switch to full screen mode when you press the button below.</p><p>Where possible, please stay in full screen mode for the entire experiment.</p>'
    , on_start: function(){
      jsPsych.setProgressBar(0);
    },
    on_finish: function(){
      (document.body).addEventListener('click',openFullScreen);
    }
  };

  var fullscreen_off = {
    type: "fullscreen",
    fullscreen_mode: false
  };

  //------------------------------------
  // Define and randomise experimental variables
  //------------------------------------


  //------------------------------------
  // Define supportive blocks
  //------------------------------------

  var cursor_off = {
      type: 'call-function',
      func: function() {
          document.body.style.cursor= "none";
      }
  }
  var cursor_on = {
      type: 'call-function',
      func: function() {
          document.body.style.cursor= "auto";
      }
  }

  //------------------------------------
  // Define experimental blocks
  //------------------------------------


  image_size = [128, 128]; // cue image size
  disp_scale = 1.0; // for cue presentation
  num_trials = task_imgs.length
  let img_idx = [];
  img_idx[0] = 0 // increment one by one
     
  // define instructions and tutorial
  var instruction_tutorial = {
      type: "instructions",
      pages: inst_images.slice(0,3)
    }
  var instruction_tutorial2 = {
    type: "instructions",
    pages: inst_images.slice(3,4)
  }
  
  function docWrite(variable) {
    document.write(variable);
}

  var practice_trials = []
  for(idx=0; idx<practice_images.length; idx++)
  {
    var practice_trial = {
      type: "practice-trial",
      stimulus: practice_images[idx],
      true_label : practice_truth[idx],
      choices: label_infos,
      prompt: "<b>Practice " + (idx+1) + "/" + practice_images.length + "</b><br>Select the class to which the image best belongs: ",
      
    }
    practice_trials.push(practice_trial)

  }

  instructions = [instruction_tutorial]
  instructions.push.apply(instructions,practice_trials)
  instructions.push(instruction_tutorial2)

  var all_instructions = {
    timeline: instructions,
  };

  var label_trials = []
  for(idx=0; idx<task_imgs.length; idx++)
  {
    var label_trial = {
    type: "image-button-response",
    stimulus: task_imgs[idx],
    choices: label_infos,
    prompt: "Select the class to which the image best belongs: ",
    on_finish: function(){
      var cur_bar_value = jsPsych.getProgressBarCompleted();
      jsPsych.setProgressBar(cur_bar_value + (1/task_imgs.length))
    }
    }
    label_trials.push(label_trial)
  }


  

  //main_timeline = [label_trial,];

  var all_rounds = {
    timeline: label_trials,
  };

  //------------------------------------
  // Define bonus round timeline
  //------------------------------------



  //------------------------------------
  // Preload images
  //------------------------------------

  var preload_img = {
    type: 'preload',
    images: inst_images.concat(task_imgs,end_img),
    max_load_time: 300000,
    continue_after_error: true,

    message:"<p>Experiment loading...</p>",

  }

  // define experiment end message
  var expt_end = {
    type: "html-keyboard-response",
    stimulus: "<img src='"+end_img[0]+"' width='"+(window.screen.width)+"' height='"+(window.screen.height)+"'></img>",
    on_finish: function(){
      document.removeEventListener('keydown', openFullScreen);
    }
  };

  //----------------------------------
  // Put it all in a timeline
  //----------------------------------

  var experiment_timeline = [];
  //experiment_timeline.push(preload_img,welcome,cursor_on,fullscreen_on)
  experiment_timeline.push(preload_img,cursor_on,fullscreen_on)
  experiment_timeline.push(all_instructions)
  experiment_timeline.push(all_rounds)
  
  //experiment_timeline.push(expt_end)
  experiment_timeline.push(fullscreen_off)


  //------------------------------------
  // Set up and run the experiment
  //------------------------------------
  var low_quality = false;

  jsPsych.init({
    timeline: experiment_timeline,
    show_progress_bar: true,
    auto_update_progress_bar: false,
    override_save_mode: true,
    on_finish: function() {

      document.body.style.overflowY = "visible";

      // add interactions to the data variable
      var interaction_data = jsPsych.data.getInteractionData();
      jsPsych.data.get().addToLast({interactions: interaction_data.json()});

      // Display jsPsych data in viewport.
      //jsPsych.data.displayData();

      // save local file for test
      //jsPsych.data.get().localSave('json','test.json');

      if (low_quality) {
        // Save rejected dataset to disk.
        redirect_reject("1004");
      } else {
        // Save complete dataset to disk.
        redirect_success("{{workerId}}", "{{assignmentId}}", "{{hitId}}",  "{{a}}", "{{tp_a}}", "{{b}}", "{{tp_b}}", "{{c}}", "{{tp_c}}");

      }
    }
  });



  </script>
</html>
