summaryrefslogtreecommitdiff
path: root/yaksh/static
diff options
context:
space:
mode:
authorPrabhu Ramachandran2017-12-29 07:10:36 -0500
committerGitHub2017-12-29 07:10:36 -0500
commite00c624d860552589d56d8fa3fdbe7a9245545e3 (patch)
tree2ba98e1af73ecf317ddf7575a4b2e0276bf84d5d /yaksh/static
parent63326f9519478f0d9bfb0b843e5dac8ab29428f4 (diff)
parent9c1c80277252fb6b151183bbf4995c96f25e31ff (diff)
downloadonline_test-e00c624d860552589d56d8fa3fdbe7a9245545e3.tar.gz
online_test-e00c624d860552589d56d8fa3fdbe7a9245545e3.tar.bz2
online_test-e00c624d860552589d56d8fa3fdbe7a9245545e3.zip
Merge pull request #406 from maheshgudi/fix_assignment
Fix assignment upload to work with new code server
Diffstat (limited to 'yaksh/static')
-rw-r--r--yaksh/static/yaksh/js/requesthandler.js51
1 files changed, 37 insertions, 14 deletions
diff --git a/yaksh/static/yaksh/js/requesthandler.js b/yaksh/static/yaksh/js/requesthandler.js
index 5159c31..3a7cdba 100644
--- a/yaksh/static/yaksh/js/requesthandler.js
+++ b/yaksh/static/yaksh/js/requesthandler.js
@@ -81,31 +81,47 @@ function focus_on_error(ele){
window.scrollBy(0, -15);
}
}
+function csrfSafeMethod(method) {
+ // these HTTP methods do not require CSRF protection
+ return (/^(GET|HEAD|OPTIONS|TRACE)$/.test(method));
+}
-function ajax_check_code(url, method_type, data_type, data, uid) {
- $.ajax({
- method: method_type,
- url: url,
- data: data,
- dataType: data_type,
- success: function(data, status, xhr) {
+function ajax_check_code(url, method_type, data_type, data, uid)
+ {
+ var ajax_post_data = {
+ "method": method_type,
+ "url": url,
+ "data": data,
+ "dataType": data_type,
+ "beforeSend": function(xhr, settings) {
+ if (!csrfSafeMethod(settings.type) && !this.crossDomain) {
+ xhr.setRequestHeader("X-CSRFToken", csrftoken);
+ }
+ },
+ "success": function(data, status, xhr) {
content_type = xhr.getResponseHeader("content-type");
response_handler(method_type, content_type, data, uid)
},
- error: function(xhr, text_status, error_thrown ) {
+ "error": function(xhr, text_status, error_thrown ) {
reset_values();
unlock_screen();
notify("There is some problem. Try later.")
}
- });
+ }
+ if (question_type == "upload"){
+ ajax_post_data["processData"] = false;
+ ajax_post_data["contentType"] = false;
+ }
+ $.ajax(ajax_post_data);
}
var global_editor = {};
-
+var csrftoken = jQuery("[name=csrfmiddlewaretoken]").val();
$(document).ready(function(){
// Codemirror object, language modes and initial content
// Get the textarea node
+
var textarea_node = document.querySelector('#answer');
var mode_dict = {
@@ -126,19 +142,26 @@ $(document).ready(function(){
render();
}
};
-
+ if (question_type == 'code'){
+
// Initialize the codemirror editor
global_editor.editor = CodeMirror.fromTextArea(textarea_node, options);
-
// Setting code editors initial content
global_editor.editor.setValue(init_val);
-
+}
+if (question_type == 'upload' || question_type == 'code') {
$('#code').submit(function(e) {
lock_screen();
+ if (question_type == "code"){
var data = $(this).serializeArray();
+ }
+ else if (question_type == "upload"){
+ var data = new FormData(getElementById("code"));
+ }
ajax_check_code($(this).attr("action"), "POST", "html", data, null)
- e.preventDefault(); // To stop the default form submission.
+ e.preventDefault(); // To stop the default form submission.
});
+ }
reset_editor = function() {
global_editor.editor.setValue(init_val);