diff options
author | adityacp | 2018-01-18 14:21:05 +0530 |
---|---|---|
committer | adityacp | 2018-01-18 14:21:58 +0530 |
commit | 9f0724354ae2801be02c5c8b8762d76ef6ce589d (patch) | |
tree | 3afff6a6c4e608542cdcad070bbeb4840edb406a /yaksh/models.py | |
parent | 6e9fa57333261f2ef1e38f1de9f88e0daeed32da (diff) | |
parent | 1445358b4ee548edd16a8d42026b080b7d92a0c4 (diff) | |
download | online_test-9f0724354ae2801be02c5c8b8762d76ef6ce589d.tar.gz online_test-9f0724354ae2801be02c5c8b8762d76ef6ce589d.tar.bz2 online_test-9f0724354ae2801be02c5c8b8762d76ef6ce589d.zip |
Update to latest changes from master
Diffstat (limited to 'yaksh/models.py')
-rw-r--r-- | yaksh/models.py | 36 |
1 files changed, 31 insertions, 5 deletions
diff --git a/yaksh/models.py b/yaksh/models.py index 90215e3..1e45851 100644 --- a/yaksh/models.py +++ b/yaksh/models.py @@ -1,4 +1,4 @@ -from __future__ import unicode_literals +from __future__ import unicode_literals, division from datetime import datetime, timedelta import json import random @@ -453,12 +453,16 @@ class LearningModule(models.Model): ordered_units = learning_module.learning_unit.order_by("order") status_list = [unit.get_completion_status(user, course) for unit in ordered_units] - if all([status == "completed" for status in status_list]): - return "completed" + + if not status_list: + default_status = "no units" + elif all([status == "completed" for status in status_list]): + default_status = "completed" elif "inprogress" in status_list: - return "inprogress" + default_status = "inprogress" else: - return "not attempted" + default_status = "not attempted" + return default_status def is_prerequisite_passed(self, user, course): """ Check if prerequisite module is completed """ @@ -481,6 +485,17 @@ class LearningModule(models.Model): def has_prerequisite(self): return self.check_prerequisite + def get_module_complete_percent(self, course, user): + units = self.get_learning_units() + if not units: + percent = 0.0 + else: + status_list = [unit.get_completion_status(user, course) + for unit in units] + count = status_list.count("completed") + percent = round((count / len(units)) * 100) + return percent + def __str__(self): return self.name @@ -681,6 +696,17 @@ class Course(models.Model): next_index = 0 return modules.get(id=module_ids[next_index]) + def percent_completed(self, user): + modules = self.get_learning_modules() + if not modules: + percent = 0.0 + else: + status_list = [module.get_module_complete_percent(self, user) + for module in modules] + count = sum(status_list) + percent = round((count / len(modules))) + return percent + def __str__(self): return self.name |