mirror of
https://github.com/renbaoshuo/S2OJ.git
synced 2025-01-04 08:31:54 +00:00
86 lines
3.1 KiB
PHP
86 lines
3.1 KiB
PHP
<?php
|
|
if (!Auth::check() && UOJConfig::$data['switch']['force-login']) {
|
|
redirectToLogin();
|
|
}
|
|
|
|
if (!isNormalUser($myUser) && UOJConfig::$data['switch']['force-login']) {
|
|
become403Page();
|
|
}
|
|
|
|
requirePHPLib('form');
|
|
|
|
$username = UOJContext::userid();
|
|
|
|
$REQUIRE_LIB['bootstrap5'] = '';
|
|
$REQUIRE_LIB['mathjax'] = '';
|
|
?>
|
|
|
|
<?php echoUOJPageHeader(UOJLocale::get('contests::contest self reviews')) ?>
|
|
|
|
<h1 class="h2">
|
|
<?= $username ?> 的所有赛后总结
|
|
</h1>
|
|
|
|
<?php
|
|
$col_names = array('contest_id');
|
|
$from = 'contests_registrants a left join contests b on a.contest_id = b.id';
|
|
$cond = "username = '$username' and has_participated = 1";
|
|
$tail = 'order by start_time desc, id desc';
|
|
$config = array(
|
|
'pagination_table' => 'contests_registrants',
|
|
'page_len' => 10,
|
|
'div_classes' => ['card', 'card-default', 'table-responsive'],
|
|
'table_classes' => ['table', 'table-bordered', 'text-center', 'align-middle', 'uoj-table', 'mb-0'],
|
|
);
|
|
|
|
$header_row = '';
|
|
$header_row .= '<tr>';
|
|
$header_row .= '<th style="width: 28em;">'.UOJLocale::get('contests::contest name').'</th>';
|
|
$header_row .= '<th style="width: 14em;">'.UOJLocale::get('problems::problem').'</th>';
|
|
$header_row .= '<th style="width: 35em;">'.UOJLocale::get('contests::problem self review').'</th>';
|
|
$header_row .= '<th style="width: 35em;">'.UOJLocale::get('contests::contest self review').'</th>';
|
|
$header_row .= '</tr>';
|
|
|
|
$parsedown = HTML::parsedown();
|
|
$purifier = HTML::purifier_inline();
|
|
|
|
$print_row = function($row) use ($parsedown, $purifier) {
|
|
global $username;
|
|
|
|
$contest_id = $row['contest_id'];
|
|
$contest = queryContest($contest_id);
|
|
$contest_problems = queryContestProblems($contest_id);
|
|
$n_contest_problems = count($contest_problems);
|
|
|
|
for ($i = 0; $i < $n_contest_problems; $i++) {
|
|
$problem_id = $contest_problems[$i]['problem_id'];
|
|
$problem = queryProblemBrief($problem_id);
|
|
$problem_self_review = DB::selectFirst("select content from contests_reviews where contest_id = $contest_id and problem_id = $problem_id and poster = '$username'");
|
|
|
|
$result .= '<tr>';
|
|
|
|
if ($i == 0) {
|
|
$result .= '<td rowspan="' . $n_contest_problems . '"><a href="' . HTML::url("/contest/$contest_id") . '">' . $contest['name'] . '</a></td>';
|
|
}
|
|
|
|
$problem_review_id = "review-$contest_id-$i";
|
|
$result .= '<td>' . chr(ord('A') + $i) . '. <a href="/problem/' . $problem_id . '">' . $problem['title'] . '</a></td>';
|
|
$result .= '<td>' . $purifier->purify($problem_self_review != null ? $parsedown->line($problem_self_review['content']) : '') . '</td>';
|
|
|
|
if ($i == 0) {
|
|
$contest_review_id = "review-$contest_id-overall";
|
|
$contest_self_review = DB::selectFirst("select content from contests_reviews where contest_id = $contest_id and problem_id = -1 and poster = '$username'");
|
|
$result .= '<td rowspan="' . $n_contest_problems . '">' . $purifier->purify($contest_self_review != null ? $parsedown->line($contest_self_review['content']) : '') . '</td>';
|
|
}
|
|
|
|
$result .= '</tr>';
|
|
}
|
|
|
|
echo $result;
|
|
};
|
|
|
|
echoLongTable($col_names, $from, $cond, $tail, $header_row, $print_row, $config);
|
|
?>
|
|
|
|
<?php echoUOJPageFooter() ?>
|