<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="utf-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <meta name="Description" content="The interpretation process of descriptions for an [anonymous institution] study on the efficacy of human communication of abstract patterns.">
    <title>ARC labeling interface</title>

    <!-- jQuery library -->
    <script src="https://code.jquery.com/jquery-3.1.1.min.js"></script>
    <script src="https://code.jquery.com/ui/1.12.1/jquery-ui.js"></script>

    <!-- CSS files -->
    <!-- CSS -->
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/css/bootstrap.min.css"
    integrity="sha384-Gn5384xqQ1aoWXA+058RXPxPg6fy4IWvTNh0E263XmFcJlSAwiGgFAW/dAiS6JXm" crossorigin="anonymous">
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-table/1.10.1/bootstrap-table.min.css">

    <link rel="stylesheet" type="text/css" href="css/listener.css">
    <link rel="stylesheet" type="text/css" href="css/common.css">
    <link rel="stylesheet" type="text/css" href="css/grids.css">
    <link rel="stylesheet" type="text/css" href="css/testing_interface.css">
</head>

<body>

    <!-- Progress Bar -->
    <div class="progress-bar-complete">
        <div class="progress md-progress">
            <div class="progress-bar success" role="progressbar" aria-valuenow="5" aria-valuemin="0" aria-valuemax="11">
            </div>
        </div>

        <div class="progress-meter">
            <div class="meter meter-right" style="width: 50%;" id="done_label"><span class="meter-text">All Done!</span>
            </div>
            <div class="meter meter-right" style="width: 25%;" id="tutorial_label"><span class="meter-text">Practice</span>
            </div>
        </div>
    </div>

    <div class="row">
        <div id="objective-col" class="col-md">
            <h3 class="objective"><b>Objective:</b></h3>
            <h5 class="objective" id="objective-text">Create the correct output based on the description and input grid.
            </h5>
        </div>
    </div>

    <div id="container-fluid">

        <div id="loader">
            <h5 id="loading_next_title">Loading your next task</h5>
            <div class="spinner-border text-primary"></div>
        </div>


        <div class="alert alert-success" id="info_display"></div>
        <div class="alert alert-danger" id="error_display"></div>

        <button id="feedback_btn" type="button" class="btn btn-success" onclick="$('#bug_report_modal').modal('show');">Report Issue</button>

        <div class="row">
            <div class="col-md-4" id="description-col">
                <div class="col-header">
                    <h1 class="col-title">Description</h1>
                </div>

                <div id="description-text">
                    <p id="see_p">In the input, you should see...</p>
                    <p id="grid_size_p">The output grid size...</p>
                    <p id="do_p">To make the output, you have to...</p>
                    <hr>
                </div>

                <div id="examples_area">
                    <h3>Example Transformation</h3>
                    <div id="task_preview">
                        Loading...
                    </div>
                </div>
            </div>

            <div class="col-md-4">
                <div class="col-header">
                    <h1>Input</h1>
                </div>

                <div id="evaluation_input" class="selectable_grid"></div>
            </div>

            <div class="col-md-4" id="validation-col">

                <div class="col-header">
                    <h1>Output</h1>
                </div>

                <div id="output_grid">
                    <div class="editable_grid selectable_grid">
                        <div class="grid_row">
                            <div class="cell" symbol="0" x="0" y="0"></div>
                            <div class="cell" symbol="0" x="0" y="1"></div>
                            <div class="cell" symbol="0" x="0" y="2"></div>
                        </div>
                        <div class="grid_row">
                            <div class="cell" symbol="0" x="1" y="0"></div>
                            <div class="cell" symbol="0" x="1" y="1"></div>
                            <div class="cell" symbol="0" x="1" y="2"></div>
                        </div>
                        <div class="grid_row">
                            <div class="cell" symbol="0" x="2" y="0"></div>
                            <div class="cell" symbol="0" x="2" y="1"></div>
                            <div class="cell" symbol="0" x="2" y="2"></div>
                        </div>
                    </div>
                </div>

                <div class="input-group mb-3" id="resize_control_btns">
                    <input type="text" id="output_grid_size" class="form-control" placeholder="3x3" value="3x3">
                    <div class="input-group-append">
                      <button class="btn btn-secondary" type="button" onclick="resizeOutputGrid();">resize output</button>
                    </div>
                </div>

                <div id="toolbar_and_symbol_picker">
                    <div id="edit_control_btns">
                        <button type="button" class="btn btn-secondary" onclick="copyFromInput();">Copy input grid</button>
                        <button type="button" class="btn btn-secondary" onclick="resetOutputGrid();">Make output grid black</button>
                    </div>
                    <div id="toolbar">
                        <div>
                            <div id="draw" style="float:left;">
                                <input type="radio" id="tool_edit" name="tool_switching" value="edit" checked>
                                <label for="tool_edit">Draw</label>
                            </div>

                            <div id="floodfill" style="float:left;">
                                <input type="radio" id="tool_floodfill" name="tool_switching" value="floodfill">
                                <label for="tool_floodfill">Flood fill</label>
                            </div>

                            <div id="copypaste" style="float:left;">
                                <input type="radio" id="tool_select" name="tool_switching" value="select">
                                <label for="tool_select">Copy-Paste</label>
                            </div>
                        </div>
                    </div>

                    <div id="symbol_picker">
                        <div class="symbol_preview symbol_0 selected-symbol-preview" symbol="0"></div>
                        <div class="symbol_preview symbol_1" symbol="1"></div>
                        <div class="symbol_preview symbol_2" symbol="2"></div>
                        <div class="symbol_preview symbol_3" symbol="3"></div>
                        <div class="symbol_preview symbol_4" symbol="4"></div>
                        <div class="symbol_preview symbol_5" symbol="5"></div>
                        <div class="symbol_preview symbol_6" symbol="6"></div>
                        <div class="symbol_preview symbol_7" symbol="7"></div>
                        <div class="symbol_preview symbol_8" symbol="8"></div>
                        <div class="symbol_preview symbol_9" symbol="9"></div>
                    </div>
                </div>

                <div id="submit_quit_buttons">
                    <button type="button" id="check-btn" class="btn btn-success" onclick="check();">Check!</button>
                </div>
            </div>
        </div>
    </div>

    <!-- Instructions Modal -->
    <div class="modal fade" id="instructionsModal" tabindex="-1" role="dialog" aria-labelledby="exampleModalCenterTitle"
        aria-hidden="true">
        <div class="modal-dialog modal-dialog-centered" role="document">
            <div class="modal-content">
                <div class="modal-header">
                    <h3 class="modal-title" id="gen-modal-title">Instructions</h3>
                </div>
                <div class="modal-body" id="gen-modal-body">
                    <p id="instruction_reminder">For this task, you will do exactly what you did in the practice tasks:
                        use a description to create a grid.</p>
                        <p><b>If you spam a random grid and do not give a good faith effort,
                            <mark>you will not be approved</mark>. If you try your best for every task, you will always be approved.
                            We will manually review every user.
                        </b></p>
                    <p>If you create the correct grid in 3 attempts, you will recieve a <b>$0.25 bonus</b>.</p>
                </div>
                <div class="modal-footer">
                    <button onclick="scroll_highlight_objective()" type="button" class="btn btn-primary"
                        data-dismiss="modal">Okay!</button>
                </div>
            </div>
        </div>
    </div>

    <!-- Verification Instructions Modal -->
    <div class="modal fade" id="verInstructionsModal" tabindex="-1" role="dialog"
        aria-labelledby="exampleModalCenterTitle" aria-hidden="true">
        <div class="modal-dialog modal-dialog-centered" role="document">
            <div class="modal-content">
                <div class="modal-header">
                    <h3 class="modal-title" id="gen-modal-title">Instructions</h3>
                </div>
                <div class="modal-body" id="gen-modal-body">
                    <p>Now, you will be shown the description you just wrote and a <b>new input grid</b>.</p>
                    <p>Use your own description to create the correct output grid.</p>
                </div>
                <div class="modal-footer">
                    <button onclick="scroll_highlight_objective()" type="button" class="btn btn-primary"
                        data-dismiss="modal">Okay!</button>
                </div>
            </div>
        </div>
    </div>

    <!-- Demographic Modal -->
    <div class="modal fade" id="demographic_modal" tabindex="-1" role="dialog" aria-labelledby="exampleModalCenterTitle"
    aria-hidden="true">
        <div class="modal-dialog modal-dialog-centered" role="document">
            <div class="modal-content">
                <div class="modal-header">
                    <h3 class="modal-title" id="gen-modal-title">Demographics</h3>
                </div>
                <div class="modal-body" id="final-modal-body">
                    <p>Please enter your age and gender.</p>

                    <div class="form-group">
                        <label for="gender_form">What is your gender?</label>
                        <select class="form-control" id="gender_form">
                            <option>Male</option>
                            <option>Female</option>
                            <option>Other</option>
                        </select>
                    </div>

                    <div class="form-group">
                        <label for="age_form">What is your age?</label>
                        <input class="form-control" type="text" placeholder="Enter your age..." id="age_form">
                    </div>

                    <div class="modal-footer">
                        <button onclick="exit_demographic()" type="button" class="btn btn-primary">Submit</button>
                    </div>
                </div>
            </div>
        </div>
    </div>

    <!-- Speaker Certainty Modal -->
    <div class="modal fade" id="speaker_certainty_modal" tabindex="-1" role="dialog" aria-labelledby="exampleModalCenterTitle" aria-hidden="true">
        <div class="modal-dialog modal-dialog-centered" role="document">
            <div class="modal-content">
                <div class="modal-header">
                    <h3 class="modal-title" id="gen-modal-title">Confidence Survey</h3>
                </div>
                <div class="modal-body" id="final-modal-body">

                    <label for="conf_form">
                        <p>How confident are you that someone else, given your description, could create the correct output grid for the input grid you were just shown?</p>
                        <p><b>0</b> means you are certain that they will not create the correct output grid, <b>5</b> means you are unsure, and <b>10</b> means you are certain that they will create the correct output grid.</p>
                    </label>
                    <input type="range" class="custom-range" min="0" max="10" step="1" id="conf_form">
                    <label id="conf_result"></label>

                    <div class="modal-footer">
                        <button onclick="submit_description()" type="button" class="btn btn-primary" data-dismiss="modal">Finish</button>
                    </div>
                    
                </div>
            </div>
        </div>
    </div>

    <!-- Finished Modal -->
    <div class="modal fade" id="finished_modal" tabindex="-1" role="dialog" aria-labelledby="exampleModalCenterTitle"
        aria-hidden="true">
        <div class="modal-dialog modal-dialog-centered" role="document">
            <div class="modal-content">
                <div class="modal-header">
                    <h3 class="modal-title" id="gen-modal-title">Thank You!</h3>
                </div>
                <div class="modal-body" id="final-modal-body">
                    <p id="final_message">Thank you for participating in this study! Your survey code is: </p>
                    <h5 id="finish_modal_uid" class="bold"></h5>
                </div>

                <div class="modal-body" id="gen-modal-body">
                    <label for="feedback_textarea">(Optional): If you have any feedback on the study interface, or you experienced any issues, please share them here:</label>
                    <textarea class="form-control" id="feedback_textarea" rows="3"></textarea>
                </div>
                <div class="modal-footer">
                    <button type="button" id="submit_feedback_btn" class="btn btn-primary" onclick="save_user_feedback();">Submit feedback</button>
                </div>
            </div>
        </div>
    </div>

    <!-- Bug Report Modal -->
    <div class="modal fade" id="bug_report_modal" tabindex="-1" role="dialog" aria-labelledby="exampleModalCenterTitle"
        aria-hidden="true">
        <div class="modal-dialog modal-dialog-centered" role="document">
            <div class="modal-content">
                <div class="modal-header">
                    <h3 class="modal-title" id="gen-modal-title">Report Issue</h3>
                </div>
                <div class="modal-body" id="gen-modal-body">
                    <label for="bug_desc_textarea">Please describe the issue. If the issue persists and stops you from completing the study, please email <b>[anonymous author]@[anonymous institution].edu</b>.</label>
                    <textarea class="form-control" id="bug_desc_textarea" rows="3" placeholder="describe the issue"></textarea>
                </br>
                    <label for="email-input">If you want, leave your email so that we can contact you about your issue.</label>
                    <input id="email-input" type="text" class="form-control" placeholder="email">
                </div>
                <div class="modal-footer">
                    <button type="button" class="btn btn-secondary" data-dismiss="modal">Cancel</button>
                    <button type="button" class="btn btn-primary" onclick="store_bug_report();" data-dismiss="modal">Submit</button>
                </div>
            </div>
        </div>
    </div>

    <!-- Failed Build Recap -->
    <div class="modal fade" id="fail_recap_modal" tabindex="-1" role="dialog" aria-labelledby="exampleModalCenterTitle"
        aria-hidden="true">
        <div class="modal-dialog modal-dialog-centered" role="document">
            <div class="modal-content">
                <div class="modal-header">
                    <h3 class="modal-title" id="gen-modal-title">Recap</h3>
                </div>
                <div class="modal-body" id="gen-modal-body">

                    <h5>Description:</h5>
                    <div id="description-text-recap">
                        <p id="see_p_recap">In the input, you should see...</p>
                        <p id="grid_size_p_recap">The output grid size...</p>
                        <p id="do_p_recap">To make the output, you have to...</p>
                    </div>

                </br>
                    <h5>Correct transformation:</h5>
                    <div id="test-io-preview"></div>

                    <h5>Your attempts:</h5>
                    <div id="user-attempts">
                        <div id="attempt1" class="attempt-divs"></div>
                        <div id="attempt2" class="attempt-divs"></div>
                        <div id="attempt3" class="attempt-divs"></div>
                    </div>

                    <hr>

                    <label>Even though this description wasn't sufficient for you to solve this problem on the first 3 tries, 
                        in retrospect, having seen the correct transformation, 
                        do you think the description was a reasonable good faith attempt?</label>
                    <form id="myForm">
                        <div class="radio">
                            <label><input type="radio" name="exampleRadios" value="true">
                                Yes, the description makes sense in hindsight, and some people might have been able to solve this task.
                            </label>
                          </div>
                          <div class="radio">
                            <label><input type="radio" name="exampleRadios" value="false">
                                No, the description makes no sense even in hindsight, and I doubt anyone could have solved this task.
                            </label>
                          </div>
                    </form>
                    <hr>

                </br>
                    <label for="build_recap_textarea">Tell us what went wrong (optional):</label>
                    <textarea class="form-control" id="build_recap_textarea" rows="3" placeholder="describe why you could not create the correct output in 3 attempts"></textarea>

                </div>
                <div class="modal-footer">
                    <button type="button" class="btn btn-secondary" data-dismiss="modal">Cancel</button>
                    <button type="button" class="btn btn-primary" onclick="exit_recap_modal();">Submit</button>
                </div>
            </div>
        </div>
    </div>

    <!-- JS files -->
    <!-- Firebase -->
    <script src="https://www.gstatic.com/firebasejs/7.17.1/firebase-app.js"></script>
    <script src="https://www.gstatic.com/firebasejs/7.15.5/firebase-database.js"></script>
    <script src="https://www.gstatic.com/firebasejs/7.17.1/firebase-firestore.js"></script>

    <!-- Bootstrap -->
    <script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.12.9/umd/popper.min.js"
        integrity="sha384-ApNbgh9B+Y1QKtv3Rn7W3mgPxhU9K/ScQsAP7hUibX39j7fakFPskvXusvfa0b4Q"
        crossorigin="anonymous"></script>
    <script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/js/bootstrap.min.js"
        integrity="sha384-JZR6Spejh4U02d8jOt6vLEHfe/JQGiRRSQQxSfFWpi1MquVdAyjUar5+76PVCmYl"
        crossorigin="anonymous"></script>

    <script src="js/listener.js"></script>
    <script src="js/common.js"></script>
    <script src="js/constants.js"></script>
    <script src="js/grids.js"></script>
    <script src="js/more_grids.js"></script>
    <script src="js/fire.js"></script>
    <script src="js/bandit.js"></script>

    <!-- Don't allow exit from modal -->
    <script>
        $.fn.modal.prototype.constructor.Constructor.Default.backdrop = 'static';
        $.fn.modal.prototype.constructor.Constructor.Default.keyboard = false;
    </script>

</body>

</html>