Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Feature/improve design of front page #287

Merged
merged 7 commits into from
Jun 3, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
14 changes: 7 additions & 7 deletions lang/en/ratingallocate.php
Original file line number Diff line number Diff line change
Expand Up @@ -87,8 +87,8 @@
$string['allocation_manual_explain_all'] = 'Select a choice to be assigned to a user.';
$string['distribution_algorithm'] = 'Distribution Algorithm';
$string['distribution_saved'] = 'Distribution saved (in {$a}s).';
$string['distributeequally'] = 'Distribute unallocated users equally';
$string['distributefill'] = 'Distribute unallocated users by filling up';
$string['distributeequally'] = 'Distribute equally';
$string['distributefill'] = 'Distribute by filling up';
$string['distribution_description'] = 'Distribution of unallocated users';
$string['distribution_description_help'] = 'You can choose between two different algorithms to distribute currently unallocated users.<br/>
<i>Distribute equally:</i> Users are being distributed equally across the choices regarding the maximum of each choice.<br/>
Expand All @@ -99,6 +99,7 @@
Each choice will be filled up to its maximum before assigning users to the next choice.';
$string['distribute_unallocated_equally_confirm'] = 'All currently unallocated users will be distributed to the choices.
The choices will be filled up equally, so all of them have about the same amount of places left.';
$string['unallocated_user_count'] = 'There are {$a->count} users unallocated. Distribute <b>unallocated</b> users to open places left in choices.';
$string['no_user_to_allocate'] = 'There is no user you could allocate';
$string['ratings_table'] = 'Ratings and Allocations';
$string['ratings_table_sum_allocations'] = 'Number of allocations / Maximum';
Expand Down Expand Up @@ -174,12 +175,11 @@
$string['publish_allocation_group_desc_rating_in_progress'] =
'The rating phase is in progress. Please wait till the rating phase has ended and then start to create allocations, first.';
$string['publish_allocation_group_desc_ready'] = 'There are no allocations yet. Please see the modify allocation section.';
$string['publish_allocation_group_desc_ready_alloc_started'] = 'The allocations can now be published.
After publishing the allocations they can no longer be altered.
Please have a look at the current allocations by following the link in the reports section.
You can choose to create groups within your course for all allocations.
$string['publish_allocation_group_desc_ready_alloc_started'] = 'The allocations can now be published and you can choose to create groups within your course for all allocations.';
$string['publish_allocation_group_desc_ready_alloc_started_help'] = 'After publishing the allocations they can no longer be altered.
Please have a look at the current allocations by following the link in the reports section. <br/><br/>
If the same groups have already been created by this plugin, they will be purged before refilling them.
This can be done before and after publishing the allocations.';
Creating groups can be done before and after publishing the allocations.';
$string['publish_allocation_group_desc_published'] = 'The allocations are already published.
You can choose to create groups within your course for all allocations.
If the same groups have already been created by this plugin, they will be purged before refilling them.';
Expand Down
10 changes: 5 additions & 5 deletions locallib.php
Original file line number Diff line number Diff line change
Expand Up @@ -190,7 +190,7 @@ public function get_raters_in_course(): array {
$raters = get_enrolled_users($this->context, 'mod/ratingallocate:give_rating');
$info = new info_module($cm);

// Only show raters who had the ability to access this activity. This funktion ignores the visibility setting,
// Only show raters who had the ability to access this activity. This function ignores the visibility setting,
// so the ratings and allocations are still shown, even when the activity is hidden.
$filteredraters = $info->filter_user_list($raters);

Expand Down Expand Up @@ -1085,11 +1085,11 @@ private function process_default() {
// Print data and controls for teachers.
if (has_capability('mod/ratingallocate:start_distribution', $this->context)) {
$undistributeduserscount = count($this->get_undistributed_users());
$output .= $renderer->modify_allocation_group($this->ratingallocateid, $this->coursemodule->id, $status,
$undistributeduserscount, (int) $this->ratingallocate->algorithmstatus,
(boolean) $this->ratingallocate->runalgorithmbycron);
$output .= $renderer->publish_allocation_group($this->ratingallocateid, $this->coursemodule->id, $status);

$output .= $renderer->render_ratingallocate_allocation_status($this->coursemodule->id, $status, $undistributeduserscount);
Laur0r marked this conversation as resolved.
Show resolved Hide resolved
$output .= $renderer->render_ratingallocate_publish_allocation($this->ratingallocateid, $this->coursemodule->id, $status);
// $output .= $renderer->reports_group($this->ratingallocateid, $this->coursemodule->id, $status, $this->context);

}

// Logging.
Expand Down
194 changes: 192 additions & 2 deletions renderer.php
Original file line number Diff line number Diff line change
Expand Up @@ -71,6 +71,174 @@ public function render_ratingallocate_strategyform($mform) {
return $o;
}

/**
* Displays the status of the allocation with buttons to start the algorithm, delete existing distributions,
* and distribute unallocated users.
*
* @param $coursemoduleid
* @param $status
* @param $undistributeduserscount
* @return string
* @throws coding_exception
* @throws moodle_exception
*/
public function render_ratingallocate_allocation_status($coursemoduleid, $status, $undistributeduserscount) {

$output = '';
$output .= $this->output->container_start('allocationstatustable');
$output .= $this->heading(get_string('modify_allocation_group', RATINGALLOCATE_MOD_NAME), 2);
$output .= $this->box_start();

$isdistributionrunning = $this->is_distribution_of_unallocated_users_running($coursemoduleid);

// The instance is called ready if it is in one of the two following status.
$ratingover = $status !== ratingallocate::DISTRIBUTION_STATUS_TOO_EARLY &&
$status !== ratingallocate::DISTRIBUTION_STATUS_RATING_IN_PROGRESS;

$starturl = new moodle_url($this->page->url, array('action' => ACTION_START_DISTRIBUTION));
$deleteurl = new moodle_url($this->page->url, array('id' => $coursemoduleid, 'action' => ACTION_DELETE_ALL_RATINGS));

// Get description dependent on status.
$descriptionbaseid = 'modify_allocation_group_desc_';
$description = get_string($descriptionbaseid . $status, RATINGALLOCATE_MOD_NAME);

// Create start algorithm button.
$button = new single_button($starturl, get_string('start_distribution', RATINGALLOCATE_MOD_NAME), 'get');
// Enable only if the instance is ready and the algorithm may run manually.
$button->disabled = !($ratingover) || $isdistributionrunning;
$button->tooltip = get_string('start_distribution_explanation', RATINGALLOCATE_MOD_NAME);
$button->add_action(new confirm_action(get_string('confirm_start_distribution', RATINGALLOCATE_MOD_NAME)));

// Create delete all ratings button.
$deletebutton = new single_button($deleteurl, get_string('delete_all_ratings', RATINGALLOCATE_MOD_NAME, 'get'));
// Only allow deletion if new submission is possible and distribution currently not running.
$deletebutton->disabled = $ratingover || $isdistributionrunning;
$deletebutton->tooltip = get_string('delete_all_ratings_explanation', RATINGALLOCATE_MOD_NAME);
$deletebutton->add_action(new confirm_action(get_string('confirm_delete_all_ratings', RATINGALLOCATE_MOD_NAME)));

$table = new html_table();

// Add status, buttons for manual and algorithmic allocation and delete all ratings button to the table.
$this->add_table_row_triple($table,
$description,
$this->render($button) . '<br/>' . '<br/>' . $this->single_button(
new moodle_url(
'/mod/ratingallocate/view.php',
array('id' => $coursemoduleid,
'action' => ACTION_MANUAL_ALLOCATION)),
get_string('manual_allocation_form',
RATINGALLOCATE_MOD_NAME),
'get',
array('disabled' => !$ratingover || $isdistributionrunning)
),
$this->render($deletebutton)
);

if (has_capability('mod/ratingallocate:distribute_unallocated', context_module::instance($coursemoduleid))) {

if ($ratingover && $undistributeduserscount != 0 && !$isdistributionrunning) {

// Add empty row.
$this->add_table_row_triple($table, '', '', '');

$distributeunallocatedurleq = new moodle_url(
$this->page->url,
array('action' => ACTION_DISTRIBUTE_UNALLOCATED_EQUALLY)
);
$buttondisteq = new single_button($distributeunallocatedurleq,
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The buttons are very large for the German version. The string is longer but it seems the button size is larger than it has to be. Can you have a look at that?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think it is not possible to make the buttons smaller manually, since this is just how they look like in this theme with a word wrap. I could give them a fixed size, but that wouldn't look good on different sized windows of the page.

get_string('distributeequally', RATINGALLOCATE_MOD_NAME), 'get');
$buttondisteq->class = 'ratingallocate_front_page_buttons';

$buttondisteq->add_action(new confirm_action(
get_string('distribute_unallocated_equally_confirm', RATINGALLOCATE_MOD_NAME)));

$distributeunallocatedurlfill = new moodle_url(
$this->page->url,
array('action' => ACTION_DISTRIBUTE_UNALLOCATED_FILL)
);
$buttondistfill = new single_button($distributeunallocatedurlfill,
get_string('distributefill', RATINGALLOCATE_MOD_NAME), 'get');
$buttondistfill->class = 'ratingallocate_front_page_buttons';
$buttondistfill->add_action(new confirm_action(
get_string('distribute_unallocated_fill_confirm', RATINGALLOCATE_MOD_NAME)));

// Add Amount of users that are unallocated and buttons to allocate them manually.
$this->add_table_row_triple($table,
get_string('unallocated_user_count',
RATINGALLOCATE_MOD_NAME,
['count' => $undistributeduserscount]) . $this->help_icon('distribution_description', RATINGALLOCATE_MOD_NAME),
$this->render($buttondisteq),
$this->render($buttondistfill)
);

} else if ($isdistributionrunning) {

// Add empty row.
$this->add_table_row_triple($table, '', '', '');

$this->add_table_row_triple($table,
get_string('unallocated_user_count', RATINGALLOCATE_MOD_NAME, ['count' => $undistributeduserscount]),
get_string('distribution_unallocated_already_running', RATINGALLOCATE_MOD_NAME),
''
);
}
}

$output .= html_writer::table($table);
$output .= $this->output->box_end();
$output .= $this->output->container_end();
return $output;
}

/**
* Displays the status concerning publishing the allocation together with the buttons to publish the allocation
* and to create groups.
*
* @param $ratingallocateid
* @param $coursemoduleid
* @param $status
* @return string
* @throws coding_exception
* @throws moodle_exception
*/
public function render_ratingallocate_publish_allocation($ratingallocateid, $coursemoduleid, $status) {

$output = '';
$output .= $this->output->container_start('allocationstatustable');
$output .= $this->heading(get_string('publish_allocation_group', RATINGALLOCATE_MOD_NAME), 2);
Laur0r marked this conversation as resolved.
Show resolved Hide resolved
$output .= $this->box_start();

$isready = $status === ratingallocate::DISTRIBUTION_STATUS_READY_ALLOC_STARTED;

$table = new html_table();

// Get description dependent on status.
$descriptionbaseid = 'publish_allocation_group_desc_';
$description = get_string($descriptionbaseid . $status, RATINGALLOCATE_MOD_NAME);

if ($isready) {
$description = $description . $this->help_icon('publish_allocation_group_desc_' . $status, RATINGALLOCATE_MOD_NAME);
} else {
$description = $this->format_text($description);
}

$this->add_table_row_triple($table,
Laur0r marked this conversation as resolved.
Show resolved Hide resolved
$description,
$this->single_button(new moodle_url('/mod/ratingallocate/view.php', array('id' => $coursemoduleid,
'ratingallocateid' => $ratingallocateid,
'action' => ACTION_PUBLISH_ALLOCATIONS)), get_string('publish_allocation', RATINGALLOCATE_MOD_NAME), 'get',
array('disabled' => !$isready)),
$this->single_button(new moodle_url('/mod/ratingallocate/view.php', array('id' => $coursemoduleid,
'ratingallocateid' => $ratingallocateid,
'action' => ACTION_ALLOCATION_TO_GROUPING)), get_string('create_moodle_groups', RATINGALLOCATE_MOD_NAME), 'get')
);

$output .= html_writer::table($table);
$output .= $this->output->box_end();
$output .= $this->output->container_end();
return $output;
}

/**
* render current choice status
* @param ratingallocate_choice_status $status
Expand Down Expand Up @@ -654,7 +822,7 @@ public function statistics_table_for_ratingallocate(ratingallocate $ratingalloca

$cell = new html_table_cell();
$usersinchoice = $ratingallocate->get_raters_in_course();
$cell->text = count($usersinchoice) - count($memberships);
$cell->text = count($ratingallocate->get_undistributed_users());
Laur0r marked this conversation as resolved.
Show resolved Hide resolved
$allocationrow[] = $cell;

$cell = new html_table_cell();
Expand Down Expand Up @@ -682,7 +850,7 @@ public function statistics_table_for_ratingallocate(ratingallocate $ratingalloca
'notrated' => $notrated,
'rated' => $activeraters,
'rating' => $titles[max(array_keys($distributiondata))],
'unassigned' => count($usersinchoice) - count($memberships))));
'unassigned' => count($ratingallocate->get_undistributed_users()))));
$output .= html_writer::table($allocationtable);
}
$output .= $this->box_end();
Expand Down Expand Up @@ -792,6 +960,28 @@ private function add_table_row_tuple(html_table $table, $first, $second) {
$table->data[] = $row;
}

/**
* Utility function to add a row of data to a table with 3 columns. Modified
* the table param and does not return a value
*
* @param html_table $table The table to append the row of data to
* @param string $first The first column text
* @param string $second The second column text
* @param string $third The third column text
* @return void
*/
private function add_table_row_triple(html_table $table, $first, $second, $third) {
$row = new html_table_row();
$cell1 = new html_table_cell($first);
$cell1->attributes['class'] = 'ratingallocate_front_page_table_1';
$cell2 = new html_table_cell($second);
$cell2->attributes['class'] = 'ratingallocate_front_page_table_23';
$cell3 = new html_table_cell($third);
$cell3->attributes['class'] = 'ratingallocate_front_page_table_23';
$row->cells = array($cell1, $cell2, $cell3);
$table->data[] = $row;
}

/**
* Method to check if an adhoc task for distributing unallocated users has already been queued.
*
Expand Down
16 changes: 16 additions & 0 deletions styles.css
Original file line number Diff line number Diff line change
Expand Up @@ -124,3 +124,19 @@
.ratingallocate_ratings_table_container .no-overflow {
overflow: unset;
}

.ratingallocate_front_page_table_1 {
margin: auto;
width: 40%;
}

.ratingallocate_front_page_table_23 {
margin: auto;
width: 30%;
padding-left: 50px;
padding-right: 50px;
}

.ratingallocate_front_page_buttons {
margin: auto;
}
Loading