From d22930f72652b0b306dd491767e8368280bb8266 Mon Sep 17 00:00:00 2001 From: adityacp Date: Thu, 3 Sep 2020 18:21:40 +0530 Subject: Show table of contents on adding new content --- yaksh/static/yaksh/js/add_question.js | 11 ++++++ yaksh/static/yaksh/js/lesson.js | 69 ++++++++++++++++++++++++++--------- 2 files changed, 62 insertions(+), 18 deletions(-) (limited to 'yaksh/static') diff --git a/yaksh/static/yaksh/js/add_question.js b/yaksh/static/yaksh/js/add_question.js index 480ce51..479e8da 100644 --- a/yaksh/static/yaksh/js/add_question.js +++ b/yaksh/static/yaksh/js/add_question.js @@ -195,16 +195,20 @@ $(document).ready(() => { let option = $('#id_language').val(); if(option === 'other') { $('#id_topic').closest('tr').show(); + $('#id_topic').prop("required", true); } else { + $('#id_topic').prop("required", false); $('#id_topic').closest('tr').hide(); } $('#id_language').change(function() { let value = $(this).val(); if (value === "other") { $('#id_topic').closest('tr').show(); + $('#id_topic').prop("required", true); $('#id_type').children("option[value='code']").hide(); } else { $('#id_topic').closest('tr').hide(); + $('#id_topic').prop("required", false); $('#id_type').children("option[value='code']").show(); } }); @@ -216,4 +220,11 @@ $(document).ready(() => { $('#id_language').children("option[value='other']").show(); } }) + $('#add_more').click(function() { + var form_idx = $(tc_type).val(); + $('#form_set').append($('#empty_form').html().replace(/__prefix__/g, form_idx)); + $(tc_type).val(parseInt(form_idx) + 1); + var form_type = "#id_"+'{{tc_class}}'+"_set-"+form_idx+"-type"; + $(form_type).val($("#id_"+'{{tc_class}}'+"_set-0-type").val()); + }); }); \ No newline at end of file diff --git a/yaksh/static/yaksh/js/lesson.js b/yaksh/static/yaksh/js/lesson.js index c0f64ed..38db7d2 100644 --- a/yaksh/static/yaksh/js/lesson.js +++ b/yaksh/static/yaksh/js/lesson.js @@ -45,40 +45,54 @@ $(document).ready(function() { // Marker Form $("#marker-form").submit(function(e) { e.preventDefault(); - $("#loader").show(); - ajax_call($(this).attr("action"), 'POST', $(this).serializeArray()); + lock_screen(); + var csrf = document.getElementById("marker-form").elements[0].value; + ajax_call($(this).attr("action"), $(this).attr("method"), $(this).serialize(), csrf); }); - function ajax_call(url, method, data) { + function ajax_call(url, method, data, csrf) { $.ajax({ url: url, timeout: 15000, - type: method, - data: JSON.stringify(data), - dataType: 'json', - contentType: 'application/json; charset=utf-8', + method: method, + data: data, beforeSend: function(xhr, settings) { if (!csrfSafeMethod(settings.type) && !this.crossDomain) { - var csrftoken = data[0].value - xhr.setRequestHeader("X-CSRFToken", csrftoken); + xhr.setRequestHeader("X-CSRFToken", csrf); } }, success: function(msg) { - $("#loader").hide(); + unlock_screen(); if (msg.success) { if (msg.status) $("#lesson-content").html(msg.data); if (msg.content_type === '1') { add_topic(); } - else if(msg.content_type === '2') { + else { add_question(); } } + if (msg.toc) show_toc(msg.toc); if (msg.message) alert(msg.message) }, - error: function(jqXHR, textStatus) { - $("#loader").hide(); - alert("Cannot add the marker. Please try again"); + error: function(xhr, data) { + switch(xhr.status) { + case 400: { + unlock_screen(); + console.log(data.responseJSON); + break; + } + case 500: { + unlock_screen(); + alert('500 status code! server error'); + break; + } + case 404: { + unlock_screen(); + alert('404 status code! server error'); + break; + } + } } }); } @@ -89,8 +103,9 @@ $(document).ready(function() { } $("#topic-form").submit(function(e) { e.preventDefault(); - $("#loader").show(); - ajax_call($(this).attr("action"), 'POST', $(this).serializeArray()); + lock_screen(); + var csrf = document.getElementById("topic-form").elements[0].value; + ajax_call($(this).attr("action"), $(this).attr("method"), $(this).serialize(), csrf); }); } @@ -100,11 +115,29 @@ $(document).ready(function() { } $("#question-form").submit(function(e) { e.preventDefault(); - $("#loader").show(); - ajax_call($(this).attr("action"), 'POST', $(this).serializeArray()); + lock_screen(); + var csrf = document.getElementById("question-form").elements[0].value; + ajax_call($(this).attr("action"), $(this).attr("method"), $(this).serialize(), csrf); }); } + function lock_screen() { + document.getElementById("ontop").style.display = "block"; + } + + function unlock_screen() { + document.getElementById("ontop").style.display = "none"; + } + + function show_error() { + + } + + function show_toc(toc) { + $("#lesson-content").empty(); + $("#toc").html(toc); + } + $('#id_video_file').on('change',function(){ //get the file name var files = []; -- cgit