fix: list index error on quiz submission
This commit is contained in:
@@ -148,7 +148,7 @@ function submitEvaluation(close) {
|
|||||||
unavailabilityMessage = false
|
unavailabilityMessage = false
|
||||||
}
|
}
|
||||||
|
|
||||||
toast.warn(__('Evaluator is unavailable'))
|
toast.warning(__('Evaluator is unavailable'))
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -494,7 +494,7 @@ const getAnswers = () => {
|
|||||||
const checkAnswer = () => {
|
const checkAnswer = () => {
|
||||||
let answers = getAnswers()
|
let answers = getAnswers()
|
||||||
if (!answers.length) {
|
if (!answers.length) {
|
||||||
toast.warn(__('Please select an option'))
|
toast.warning(__('Please select an option'))
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -155,7 +155,7 @@ const saveSubmission = () => {
|
|||||||
|
|
||||||
usePageMeta(() => {
|
usePageMeta(() => {
|
||||||
return {
|
return {
|
||||||
title: `${submisisonDetails.doc.quiz_title}`,
|
title: `${submisisonDetails.doc?.quiz_title}`,
|
||||||
icon: brand.favicon,
|
icon: brand.favicon,
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -96,9 +96,7 @@ def set_total_marks(questions):
|
|||||||
|
|
||||||
@frappe.whitelist()
|
@frappe.whitelist()
|
||||||
def quiz_summary(quiz, results):
|
def quiz_summary(quiz, results):
|
||||||
score = 0
|
|
||||||
results = results and json.loads(results)
|
results = results and json.loads(results)
|
||||||
is_open_ended = False
|
|
||||||
percentage = 0
|
percentage = 0
|
||||||
|
|
||||||
quiz_details = frappe.db.get_value(
|
quiz_details = frappe.db.get_value(
|
||||||
@@ -108,7 +106,32 @@ def quiz_summary(quiz, results):
|
|||||||
as_dict=1,
|
as_dict=1,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
data = process_results(results, quiz)
|
||||||
|
results = data["results"]
|
||||||
|
score = data["score"]
|
||||||
|
is_open_ended = data["is_open_ended"]
|
||||||
|
|
||||||
score_out_of = quiz_details.total_marks
|
score_out_of = quiz_details.total_marks
|
||||||
|
percentage = (score / score_out_of) * 100
|
||||||
|
submission = create_submission(
|
||||||
|
quiz, results, score_out_of, quiz_details.passing_percentage
|
||||||
|
)
|
||||||
|
|
||||||
|
save_progress_after_quiz(quiz_details, percentage)
|
||||||
|
|
||||||
|
return {
|
||||||
|
"score": score,
|
||||||
|
"score_out_of": score_out_of,
|
||||||
|
"submission": submission.name,
|
||||||
|
"pass": percentage == quiz_details.passing_percentage,
|
||||||
|
"percentage": percentage,
|
||||||
|
"is_open_ended": is_open_ended,
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
def process_results(results, quiz):
|
||||||
|
score = 0
|
||||||
|
is_open_ended = False
|
||||||
|
|
||||||
for result in results:
|
for result in results:
|
||||||
question_details = frappe.db.get_value(
|
question_details = frappe.db.get_value(
|
||||||
@@ -123,55 +146,28 @@ def quiz_summary(quiz, results):
|
|||||||
result["marks_out_of"] = question_details.marks
|
result["marks_out_of"] = question_details.marks
|
||||||
|
|
||||||
if question_details.type != "Open Ended":
|
if question_details.type != "Open Ended":
|
||||||
correct = result["is_correct"][0]
|
if len(result["is_correct"]):
|
||||||
for point in result["is_correct"]:
|
correct = result["is_correct"][0]
|
||||||
correct = correct and point
|
for point in result["is_correct"]:
|
||||||
result["is_correct"] = correct
|
correct = correct and point
|
||||||
|
result["is_correct"] = correct
|
||||||
|
else:
|
||||||
|
result["is_correct"] = 0
|
||||||
|
|
||||||
marks = question_details.marks if correct else 0
|
marks = question_details.marks if correct else 0
|
||||||
result["marks"] = marks
|
result["marks"] = marks
|
||||||
score += marks
|
score += marks
|
||||||
|
|
||||||
else:
|
else:
|
||||||
result["is_correct"] = 0
|
|
||||||
is_open_ended = True
|
is_open_ended = True
|
||||||
|
result["is_correct"] = 0
|
||||||
percentage = (score / score_out_of) * 100
|
result["answer"] = re.sub(
|
||||||
result["answer"] = re.sub(
|
r'<img[^>]*src\s*=\s*["\'](?=data:)(.*?)["\']', _save_file, result["answer"]
|
||||||
r'<img[^>]*src\s*=\s*["\'](?=data:)(.*?)["\']', _save_file, result["answer"]
|
)
|
||||||
)
|
|
||||||
|
|
||||||
submission = frappe.new_doc("LMS Quiz Submission")
|
|
||||||
# Score and percentage are calculated by the controller function
|
|
||||||
submission.update(
|
|
||||||
{
|
|
||||||
"doctype": "LMS Quiz Submission",
|
|
||||||
"quiz": quiz,
|
|
||||||
"result": results,
|
|
||||||
"score": 0,
|
|
||||||
"score_out_of": score_out_of,
|
|
||||||
"member": frappe.session.user,
|
|
||||||
"percentage": 0,
|
|
||||||
"passing_percentage": quiz_details.passing_percentage,
|
|
||||||
}
|
|
||||||
)
|
|
||||||
submission.save(ignore_permissions=True)
|
|
||||||
|
|
||||||
if (
|
|
||||||
percentage >= quiz_details.passing_percentage
|
|
||||||
and quiz_details.lesson
|
|
||||||
and quiz_details.course
|
|
||||||
):
|
|
||||||
save_progress(quiz_details.lesson, quiz_details.course)
|
|
||||||
elif not quiz_details.passing_percentage:
|
|
||||||
save_progress(quiz_details.lesson, quiz_details.course)
|
|
||||||
|
|
||||||
return {
|
return {
|
||||||
|
"results": results,
|
||||||
"score": score,
|
"score": score,
|
||||||
"score_out_of": score_out_of,
|
|
||||||
"submission": submission.name,
|
|
||||||
"pass": percentage == quiz_details.passing_percentage,
|
|
||||||
"percentage": percentage,
|
|
||||||
"is_open_ended": is_open_ended,
|
"is_open_ended": is_open_ended,
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -219,6 +215,36 @@ def get_corrupted_image_msg():
|
|||||||
return _("Image: Corrupted Data Stream")
|
return _("Image: Corrupted Data Stream")
|
||||||
|
|
||||||
|
|
||||||
|
def create_submission(quiz, results, score_out_of, passing_percentage):
|
||||||
|
submission = frappe.new_doc("LMS Quiz Submission")
|
||||||
|
# Score and percentage are calculated by the controller function
|
||||||
|
submission.update(
|
||||||
|
{
|
||||||
|
"doctype": "LMS Quiz Submission",
|
||||||
|
"quiz": quiz,
|
||||||
|
"result": results,
|
||||||
|
"score": 0,
|
||||||
|
"score_out_of": score_out_of,
|
||||||
|
"member": frappe.session.user,
|
||||||
|
"percentage": 0,
|
||||||
|
"passing_percentage": passing_percentage,
|
||||||
|
}
|
||||||
|
)
|
||||||
|
submission.save(ignore_permissions=True)
|
||||||
|
return submission
|
||||||
|
|
||||||
|
|
||||||
|
def save_progress_after_quiz(quiz_details, percentage):
|
||||||
|
if (
|
||||||
|
percentage >= quiz_details.passing_percentage
|
||||||
|
and quiz_details.lesson
|
||||||
|
and quiz_details.course
|
||||||
|
):
|
||||||
|
save_progress(quiz_details.lesson, quiz_details.course)
|
||||||
|
elif not quiz_details.passing_percentage:
|
||||||
|
save_progress(quiz_details.lesson, quiz_details.course)
|
||||||
|
|
||||||
|
|
||||||
@frappe.whitelist()
|
@frappe.whitelist()
|
||||||
def get_question_details(question):
|
def get_question_details(question):
|
||||||
if frappe.db.exists("LMS Quiz Question", question):
|
if frappe.db.exists("LMS Quiz Question", question):
|
||||||
|
|||||||
Reference in New Issue
Block a user