S2OJ/web/app/controllers/groups.php

87 lines
2.3 KiB
PHP
Raw Normal View History

2022-03-20 00:07:46 +00:00
<?php
requirePHPLib('form');
requirePHPLib('judger');
requirePHPLib('data');
2022-04-03 10:18:17 +00:00
if (!Auth::check()) {
become403Page(UOJLocale::get('need login'));
}
if (!isNormalUser($myUser)) {
become403Page();
}
2022-03-20 00:07:46 +00:00
if (isSuperUser($myUser)) {
2022-03-20 09:19:07 +00:00
$new_group_form = new UOJForm('new_group');
$new_group_form->handle = function() {
DB::query("insert into `groups` (title, is_hidden) values ('新小组', 1)");
};
$new_group_form->submit_button_config['align'] = 'right';
$new_group_form->submit_button_config['class_str'] = 'btn btn-primary';
$new_group_form->submit_button_config['text'] = UOJLocale::get('add new group');
$new_group_form->submit_button_config['smart_confirm'] = '';
$new_group_form->runAtServer();
2022-03-20 00:07:46 +00:00
}
function echoGroup($group) {
2022-03-20 09:19:07 +00:00
global $myUser;
2022-03-20 00:07:46 +00:00
2022-03-20 09:19:07 +00:00
echo '<tr class="text-center">';
echo '<td>';
echo '#', $group['group_id'], '</td>';
2022-03-20 00:07:46 +00:00
2022-03-20 09:19:07 +00:00
echo '<td class="text-left">';
if ($group['is_hidden']) {
echo ' <span class="text-danger">[隐藏]</span> ';
}
echo '<a href="/group/', $group['group_id'], '">', $group['title'], '</a>';
echo '</td>';
2022-03-20 00:07:46 +00:00
2022-03-20 09:19:07 +00:00
echo "<td>{$group['user_count']}</td>";
2022-03-20 00:07:46 +00:00
2022-03-20 09:19:07 +00:00
echo '</tr>';
2022-03-20 00:07:46 +00:00
}
?>
<?php echoUOJPageHeader(UOJLocale::get('groups')) ?>
<?php
$groups_caption = UOJLocale::get('groups');
$users_caption = UOJLocale::get('users count');
$header = <<<EOD
<tr>
<th class="text-center" style="width:5em;">ID</th>
<th>{$groups_caption}</th>
<th class="text-center" style="width:8em;">{$users_caption}</th>
</tr>
EOD;
if (isSuperUser($myUser)) {
2022-03-20 09:19:07 +00:00
$cond = "1";
2022-03-20 00:07:46 +00:00
} else {
2022-03-20 09:19:07 +00:00
$cond = 'is_hidden = 0';
2022-03-20 00:07:46 +00:00
}
$from = "`groups` a left join groups_users b on a.id = b.group_id";
echoLongTable(
array('a.id as group_id', 'a.title as title', 'a.is_hidden as is_hidden', 'count(b.username) as user_count'),
$from, $cond, 'group by a.id order by a.id asc',
$header,
'echoGroup',
array('page_len' => 100,
'table_classes' => array('table', 'table-bordered', 'table-hover', 'table-striped'),
'print_after_table' => function() {
global $myUser;
if (isSuperUser($myUser)) {
global $new_group_form;
$new_group_form->printHTML();
}
},
'head_pagination' => true
)
);
?>
<?php echoUOJPageFooter() ?>