S2OJ/web/app/controllers/problem_list.php
Baoshuo 4fabe53a51
All checks were successful
continuous-integration/drone/push Build is passing
feat: display problem uploader in problemset
2022-09-20 18:39:01 +08:00

280 lines
9.4 KiB
PHP

<?php
if (!Auth::check()) {
become403Page(UOJLocale::get('need login'));
}
requirePHPLib('form');
requirePHPLib('judger');
requirePHPLib('data');
$list_id = $_GET['id'];
if (!validateUInt($list_id) || !($list = queryProblemList($list_id))) {
become404Page();
}
if (isSuperUser($myUser)) {
$list_tags = queryProblemListTags($list_id);
$list_editor = new UOJBlogEditor();
$list_editor->name = 'list';
$list_editor->blog_url = null;
$list_editor->cur_data = array(
'title' => $list['title'],
'tags' => $list_tags,
'is_hidden' => $list['is_hidden']
);
$list_editor->label_text = array_merge($list_editor->label_text, array(
'view blog' => '保存题单信息',
'blog visibility' => '题单可见性'
));
$list_editor->show_editor = false;
$list_editor->save = function($data) {
global $list_id, $list;
DB::update("update lists set title = '" . DB::escape($data['title']) . "' where id = {$list_id}");
if ($data['tags'] !== $list_tags) {
DB::delete("delete from lists_tags where list_id = {$list_id}");
foreach ($data['tags'] as $tag) {
DB::insert("insert into lists_tags (list_id, tag) values ({$list_id}, '" . DB::escape($tag) . "')");
}
}
if ($data['is_hidden'] != $list['is_hidden'] ) {
DB::update("update lists set is_hidden = {$data['is_hidden']} where id = {$list_id}");
}
};
$list_editor->runAtServer();
}
function removeFromProblemListForm($problem_id) {
$res_form = new UOJForm("remove_problem_{$problem_id}");
$input_name = "problem_id_delete_{$problem_id}";
$res_form->addHidden($input_name, $problem_id, function($problem_id) {
global $myUser;
if (!isSuperUser($myUser)) {
return '只有超级用户可以编辑题单';
}
}, null);
$res_form->handle = function() use ($input_name) {
global $list_id;
$problem_id = $_POST[$input_name];
DB::query("delete from lists_problems where problem_id={$problem_id} and list_id={$list_id}");
};
$res_form->submit_button_config['class_str'] = 'btn btn-danger';
$res_form->submit_button_config['text'] = '删除';
$res_form->submit_button_config['align'] = 'inline';
return $res_form;
}
$removeProblemForms = array();
if (isSuperUser($myUser)) {
$problem_ids = DB::query("select problem_id from lists_problems where list_id = {$list_id}");
while ($row = DB::fetch($problem_ids)) {
$problem_id = $row['problem_id'];
$removeForm = removeFromProblemListForm($problem_id);
$removeForm->runAtServer();
$removeProblemForms[$problem_id] = $removeForm;
}
}
if (isSuperUser($myUser)) {
$add_new_problem_form = new UOJForm('add_new_problem');
$add_new_problem_form->addInput('problem_id', 'text', '题目 ID', '',
function ($x) {
global $myUser, $list_id;
if (!isSuperUser($myUser)) {
return '只有超级用户可以编辑题单';
}
if (!validateUInt($x)) {
return 'ID 不合法';
}
$problem = queryProblemBrief($x);
if (!$problem) {
return '题目不存在';
}
if (queryProblemInList($list_id, $x)) {
return '该题目已经在题单中';
}
return '';
},
null
);
$add_new_problem_form->submit_button_config['align'] = 'compressed';
$add_new_problem_form->submit_button_config['text'] = '添加到题单';
$add_new_problem_form->handle = function() {
global $list_id, $myUser;
$problem_id = $_POST['problem_id'];
DB::insert("insert into lists_problems (list_id, problem_id) values ({$list_id}, {$problem_id})");
};
$add_new_problem_form->runAtServer();
}
function echoProblem($problem) {
global $myUser, $removeProblemForms;
if (isProblemVisibleToUser($problem, $myUser)) {
echo '<tr class="text-center">';
if ($problem['submission_id']) {
echo '<td class="success">';
} else {
echo '<td>';
}
echo '#', $problem['id'], '</td>';
echo '<td class="text-left">';
if (isSuperUser($myUser)) {
$form = $removeProblemForms[$problem['id']];
$form->printHTML();
}
if ($problem['is_hidden']) {
echo ' <span class="text-danger">[隐藏]</span> ';
}
if ($problem['uploader'] == $myUser['username']) {
echo ' <span class="text-info">[我的题目]</span> ';
}
echo '<a href="/problem/', $problem['id'], '">', $problem['title'], '</a>';
if (isset($_COOKIE['show_tags_mode'])) {
echo ' <span class="text-info" style="font-size: 10px">' . $problem["uploader"] . '</span> ';
foreach (queryProblemTags($problem['id']) as $tag) {
echo '<a class="uoj-problem-tag">', '<span class="badge badge-pill badge-secondary">', HTML::escape($tag), '</span>', '</a>';
}
}
echo '</td>';
if (isset($_COOKIE['show_submit_mode'])) {
$perc = $problem['submit_num'] > 0 ? round(100 * $problem['ac_num'] / $problem['submit_num']) : 0;
echo <<<EOD
<td><a href="/submissions?problem_id={$problem['id']}&min_score=100&max_score=100">&times;{$problem['ac_num']}</a></td>
<td><a href="/submissions?problem_id={$problem['id']}">&times;{$problem['submit_num']}</a></td>
<td>
<div class="progress bot-buffer-no">
<div class="progress-bar progress-bar-success" role="progressbar" aria-valuenow="$perc" aria-valuemin="0" aria-valuemax="100" style="width: $perc%; min-width: 20px;">{$perc}%</div>
</div>
</td>
EOD;
}
if (isset($_COOKIE['show_difficulty'])) {
$extra_config = getProblemExtraConfig($problem);
if ($extra_config['difficulty'] == 0) {
echo "<td></td>";
} else {
echo "<td>{$extra_config['difficulty']}</td>";
}
}
echo '<td class="text-left">', getClickZanBlock('P', $problem['id'], $problem['zan']), '</td>';
echo '</tr>';
}
}
$header = '<tr>';
$header .= '<th class="text-center" style="width:5em;">ID</th>';
$header .= '<th>'.UOJLocale::get('problems::problem').'</th>';
if (isset($_COOKIE['show_submit_mode'])) {
$header .= '<th class="text-center" style="width:5em;">'.UOJLocale::get('problems::ac').'</th>';
$header .= '<th class="text-center" style="width:5em;">'.UOJLocale::get('problems::submit').'</th>';
$header .= '<th class="text-center" style="width:150px;">'.UOJLocale::get('problems::ac ratio').'</th>';
}
if (isset($_COOKIE['show_difficulty'])) {
$header .= '<th class="text-center" style="width:7em;">'.UOJLocale::get('problems::difficulty').'</th>';
}
$header .= '<th class="text-center" style="width:180px;">'.UOJLocale::get('appraisal').'</th>';
$header .= '</tr>';
$pag_config = array('page_len' => 40);
$pag_config['col_names'] = array('best_ac_submissions.submission_id as submission_id', 'problems.id as id', 'problems.is_hidden as is_hidden', 'problems.title as title', 'problems.submit_num as submit_num', 'problems.ac_num as ac_num', 'problems.zan as zan', 'problems.extra_config as extra_config', 'problems.uploader as uploader');
$pag_config['table_name'] = "problems left join best_ac_submissions on best_ac_submissions.submitter = '{$myUser['username']}' and problems.id = best_ac_submissions.problem_id inner join lists_problems lp on lp.list_id = {$list_id} and lp.problem_id = problems.id";
$pag_config['cond'] = '1';
$pag_config['tail'] = "order by id asc";
$pag = new Paginator($pag_config);
$div_classes = array('table-responsive');
$table_classes = array('table', 'table-bordered', 'table-hover', 'table-striped');
?>
<?php echoUOJPageHeader(UOJLocale::get('problems lists')); ?>
<?php
if (isSuperUser($myUser)) {
echo '<h5>编辑题单信息</h5>';
echo '<div class="mb-4">';
$list_editor->printHTML();
echo '</div>';
echo '<h5>添加题目到题单</h5>';
$add_new_problem_form->printHTML();
}
?>
<div class="row">
<div class="col-sm-4">
<h5>"<?= $list['title'] ?>" 中的题目: </h5>
<p>(题单 ID: #<?= $list['id'] ?>)</p>
</div>
<div class="col-sm-4 order-sm-9 checkbox text-right fine-tune-down">
<label class="checkbox-inline" for="input-show_tags_mode"><input type="checkbox" id="input-show_tags_mode" <?= isset($_COOKIE['show_tags_mode']) ? 'checked="checked" ': ''?>/> <?= UOJLocale::get('problems::show tags') ?></label>
<label class="checkbox-inline" for="input-show_submit_mode"><input type="checkbox" id="input-show_submit_mode" <?= isset($_COOKIE['show_submit_mode']) ? 'checked="checked" ': ''?>/> <?= UOJLocale::get('problems::show statistics') ?></label>
</div>
<div class="col-sm-4 order-sm-5">
<?php echo $pag->pagination(); ?>
</div>
</div>
<div class="top-buffer-sm"></div>
<script type="text/javascript">
$('#input-show_tags_mode').click(function() {
if (this.checked) {
$.cookie('show_tags_mode', '', {path: '/'});
} else {
$.removeCookie('show_tags_mode', {path: '/'});
}
location.reload();
});
$('#input-show_submit_mode').click(function() {
if (this.checked) {
$.cookie('show_submit_mode', '', {path: '/'});
} else {
$.removeCookie('show_submit_mode', {path: '/'});
}
location.reload();
});
$('#input-show_difficulty').click(function() {
if (this.checked) {
$.cookie('show_difficulty', '', {path: '/'});
} else {
$.removeCookie('show_difficulty', {path: '/'});
}
location.reload();
});
</script>
<?php
echo '<div class="', join($div_classes, ' '), '">';
echo '<table class="', join($table_classes, ' '), '">';
echo '<thead>';
echo $header;
echo '</thead>';
echo '<tbody>';
foreach ($pag->get() as $idx => $row) {
echoProblem($row);
echo "\n";
}
if ($pag->isEmpty()) {
echo '<tr><td class="text-center" colspan="233">'.UOJLocale::get('none').'</td></tr>';
}
echo '</tbody>';
echo '</table>';
echo '</div>';
echo $pag->pagination();
?>
<?php echoUOJPageFooter() ?>