aboutsummaryrefslogtreecommitdiff
path: root/app/controllers/course/courseware.php
diff options
context:
space:
mode:
authorRon Lucke <lucke@elan-ev.de>2021-10-04 06:21:26 +0000
committerElmar Ludwig <elmar.ludwig@uni-osnabrueck.de>2021-10-04 06:21:26 +0000
commit277bae6f9304c8f19d065820e2ee5f82346dfb49 (patch)
tree450758cde7352adf660e350ae53ba4c7f6625621 /app/controllers/course/courseware.php
parentbffdb4715ca4da6ef4e936ce7f44a8ffda0aa16b (diff)
fix #229
Diffstat (limited to 'app/controllers/course/courseware.php')
-rwxr-xr-xapp/controllers/course/courseware.php50
1 files changed, 36 insertions, 14 deletions
diff --git a/app/controllers/course/courseware.php b/app/controllers/course/courseware.php
index 7d2eb7c..834764f 100755
--- a/app/controllers/course/courseware.php
+++ b/app/controllers/course/courseware.php
@@ -2,6 +2,7 @@
use Courseware\StructuralElement;
use Courseware\Instance;
+use Courseware\UserProgress;
/**
* @property ?string $entry_element_id
@@ -42,7 +43,7 @@ class Course_CoursewareController extends AuthenticatedController
]);
}
- // load courseware for seminar
+ // load courseware for course
if (!$this->entry_element_id || !$struct || !$struct->canRead($GLOBALS['user'])) {
$course = Course::find(Context::getId());
@@ -110,9 +111,20 @@ class Course_CoursewareController extends AuthenticatedController
$data = [];
$cid = Context::getId();
+ $course = Course::find($cid);
+ $course_members = $course->getMembersWithStatus('autor');
+ $course_member_ids = array_column($course_members, 'user_id');
$elements = StructuralElement::findBySQL('range_id = ?', [$cid]);
+ if ($course_progress) {
+ $cw_user_progresses = UserProgress::findBySQL('user_id IN (?)', [$course_member_ids]);
+ } else {
+ $cw_user_progresses = UserProgress::findBySQL('user_id = ?', [
+ $GLOBALS['user']->id,
+ ]);
+ }
+
foreach ($elements as $element) {
$el = [
'id' => $element->id,
@@ -121,7 +133,7 @@ class Course_CoursewareController extends AuthenticatedController
'parent_name' => $element->parent->title,
'children' => $this->getChildren($element->children),
];
- $el['progress'] = $this->getProgress($element, $course_progress);
+ $el['progress'] = $this->getProgress($course, $element, $course_progress, $cw_user_progresses, $course_member_ids);
array_push($data, $el);
}
@@ -156,16 +168,15 @@ class Course_CoursewareController extends AuthenticatedController
return $data;
}
- private function getProgress(StructuralElement $element, bool $course_progress = false): array
+ private function getProgress(Course $course, StructuralElement $element, bool $course_progress = false, array $cw_user_progresses, array $course_member_ids): array
{
$descendants = $element->findDescendants();
$count = count($descendants);
$progress = 0;
$own_progress = 0;
- $course = Seminar::GetInstance(Context::getId());
foreach ($descendants as $el) {
- $block = $this->getBlocks($el->id, $course_progress, $course);
+ $block = $this->getBlocks($el->id, $course_progress, $cw_user_progresses, $course, $course_member_ids);
if ($block['counter'] > 0) {
$progress += $block['progress'] / $block['counter'];
} else {
@@ -173,7 +184,7 @@ class Course_CoursewareController extends AuthenticatedController
}
}
- $own_blocks = $this->getBlocks($element->id, $course_progress, $course);
+ $own_blocks = $this->getBlocks($element->id, $course_progress, $cw_user_progresses, $course, $course_member_ids);
if ($own_blocks['counter'] > 0) {
$own_progress = $own_blocks['progress'] / $own_blocks['counter'];
@@ -191,7 +202,7 @@ class Course_CoursewareController extends AuthenticatedController
return ['total' => round($progress, 2) * 100, 'current' => round($own_progress, 2) * 100];
}
- private function getBlocks(string $element_id, bool $course_progress = false, $course): array
+ private function getBlocks(string $element_id, bool $course_progress = false, array $cw_user_progresses, Course $course, array $course_member_ids): array
{
$containers = Courseware\Container::findBySQL('structural_element_id = ?', [intval($element_id)]);
$blocks = [];
@@ -201,16 +212,22 @@ class Course_CoursewareController extends AuthenticatedController
foreach ($containers as $container) {
$counter = $container->countBlocks();
+
$blocks['counter'] += $counter;
if ($counter > 0) {
$blks = Courseware\Block::findBySQL('container_id = ?', [$container->id]);
foreach ($blks as $item) {
if ($course_progress) {
if ($users_counter > 0) {
- $progresses = Courseware\UserProgress::findBySQL('block_id = ?', [$item->id]);
+ $progresses = array_filter($cw_user_progresses, function($progress) use ($item) {
+ if ($progress->block_id === $item->id) {
+ return true;
+ }
+ });
+
$users_progress = 0;
foreach ($progresses as $prog) {
- if (array_key_exists($prog->user_id, $course->getMembersWithStatus('autor'))) {
+ if (in_array($prog->user_id, $course_member_ids)) {
$users_progress += $prog->grade;
}
}
@@ -218,11 +235,16 @@ class Course_CoursewareController extends AuthenticatedController
$blocks['progress'] += $users_progress / $users_counter;
}
} else {
- $progress = Courseware\UserProgress::findOneBySQL('user_id = ? and block_id = ?', [
- $GLOBALS['user']->id,
- $item->id,
- ]);
- $blocks['progress'] += $progress->grade;
+ $uid = $GLOBALS['user']->id;
+ $progresses = array_filter($cw_user_progresses, function($progress) use ($item, $uid) {
+ if ($progress->block_id === $item->id && $progress->user_id === $uid) {
+ return true;
+ }
+ });
+ $progress = reset($progresses);
+ if ($progress !== null) {
+ $blocks['progress'] += intval($progress->grade);
+ }
}
}
}