feat(submission): finish refactor

This commit is contained in:
Baoshuo Ren 2023-02-17 16:50:32 +08:00
parent 496b87d0a4
commit 8b45b03225
Signed by: baoshuo
GPG Key ID: 00CB9680AB29F51A
3 changed files with 53 additions and 47 deletions

View File

@ -41,7 +41,7 @@ if ($can_see_minor) {
redirectTo(UOJSubmission::cur()->getUriForNewTID($tid)); redirectTo(UOJSubmission::cur()->getUriForNewTID($tid));
}; };
$minor_rejudge_form->config['submit_button']['class'] = 'list-group-item list-group-item-action border-start-0 border-end-0 list-group-item-secondary'; $minor_rejudge_form->config['submit_button']['class'] = 'list-group-item list-group-item-action border-start-0 border-end-0 list-group-item-secondary';
$minor_rejudge_form->config['submit_button']['text'] = '偷偷重新测试'; $minor_rejudge_form->config['submit_button']['text'] = '<i class="bi bi-arrow-clockwise"></i> 偷偷重新测试';
$minor_rejudge_form->config['submit_container']['class'] = ''; $minor_rejudge_form->config['submit_container']['class'] = '';
$minor_rejudge_form->runAtServer(); $minor_rejudge_form->runAtServer();
} }
@ -94,7 +94,7 @@ if (UOJSubmission::cur()->isLatest()) {
UOJSubmission::rejudgeById(UOJSubmission::info('id')); UOJSubmission::rejudgeById(UOJSubmission::info('id'));
}; };
$rejudge_form->config['submit_button']['class'] = 'list-group-item list-group-item-action border-start-0 border-end-0 list-group-item-secondary'; $rejudge_form->config['submit_button']['class'] = 'list-group-item list-group-item-action border-start-0 border-end-0 list-group-item-secondary';
$rejudge_form->config['submit_button']['text'] = '重新测试'; $rejudge_form->config['submit_button']['text'] = '<i class="bi bi-arrow-clockwise"></i> 重新测试';
$rejudge_form->config['submit_container']['class'] = ''; $rejudge_form->config['submit_container']['class'] = '';
$rejudge_form->runAtServer(); $rejudge_form->runAtServer();
} }
@ -105,7 +105,7 @@ if (UOJSubmission::cur()->isLatest()) {
UOJSubmission::cur()->delete(); UOJSubmission::cur()->delete();
}; };
$delete_form->config['submit_button']['class'] = 'list-group-item list-group-item-action border-start-0 border-end-0 list-group-item-danger'; $delete_form->config['submit_button']['class'] = 'list-group-item list-group-item-action border-start-0 border-end-0 list-group-item-danger';
$delete_form->config['submit_button']['text'] = '删除此提交记录'; $delete_form->config['submit_button']['text'] = '<i class="bi bi-trash-3"></i> 删除此提交记录';
$delete_form->config['submit_container']['class'] = ''; $delete_form->config['submit_container']['class'] = '';
$delete_form->config['confirm']['text'] = '你真的要删除这条提交记录吗?'; $delete_form->config['confirm']['text'] = '你真的要删除这条提交记录吗?';
$delete_form->succ_href = "/submissions"; $delete_form->succ_href = "/submissions";
@ -118,7 +118,7 @@ if (UOJSubmission::cur()->isLatest()) {
UOJSubmission::cur()->deleteThisMinorVersion(); UOJSubmission::cur()->deleteThisMinorVersion();
}; };
$delete_form->config['submit_button']['class'] = 'list-group-item list-group-item-action border-start-0 border-end-0 list-group-item-danger'; $delete_form->config['submit_button']['class'] = 'list-group-item list-group-item-action border-start-0 border-end-0 list-group-item-danger';
$delete_form->config['submit_button']['text'] = '删除当前历史记录(保留其他历史记录)'; $delete_form->config['submit_button']['text'] = '<i class="bi bi-trash-3"></i> 删除当前历史记录';
$delete_form->config['submit_container']['class'] = ''; $delete_form->config['submit_container']['class'] = '';
$delete_form->config['confirm']['text'] = '你真的要删除这条历史记录吗?删除这条历史记录不会影响其他的历史记录。'; $delete_form->config['confirm']['text'] = '你真的要删除这条历史记录吗?删除这条历史记录不会影响其他的历史记录。';
$delete_form->succ_href = UOJSubmission::cur()->getUriForLatest(); $delete_form->succ_href = UOJSubmission::cur()->getUriForLatest();
@ -167,7 +167,12 @@ if (UOJSubmission::cur()->hasJudged()) {
'card_body' => false, 'card_body' => false,
]; ];
} else { } else {
// TODO: 您当前无法查看详细信息 $tabs['details'] = [
'name' => '详细信息',
'displayer' => function () {
echo '<div>您无权查看当前提交的详细信息。</div>';
},
];
} }
if ($perm['manager_view'] && isset($submission_result['final_result'])) { if ($perm['manager_view'] && isset($submission_result['final_result'])) {
@ -182,14 +187,29 @@ if (UOJSubmission::cur()->hasJudged()) {
]; ];
} }
} else { } else {
// TODO: move judge_status from UOJSubmission::echoStatusCard() to here $show_status_details = UOJSubmission::cur()->viewerCanSeeStatusDetailsHTML(Auth::user());
$tabs['details'] = [
'name' => '详细信息',
'displayer' => function () {
echo '<div class="card-body rounded-bottom">';
echo '<table class="w-100">';
echo '<tr id="status_details_' . UOJSubmission::info('id') . '">';
echo UOJSubmission::cur()->getStatusDetailsHTML();
echo '</tr>';
echo '<script>update_judgement_status_details(' . UOJSubmission::info('id') . ')</script>';
echo '</table>';
echo '</div>';
},
'card_body' => false,
];
} }
if ($perm['content'] || $perm['manager_view']) { if ($perm['content'] || $perm['manager_view']) {
$tabs['source'] = [ $tabs['source'] = [
'name' => '源代码', 'name' => '源代码',
'displayer' => function () { 'displayer' => function () {
echo '<div class="list-group list-group-flush">'; echo '<div class="list-group list-group-flush rounded-bottom">';
UOJSubmission::cur()->echoContent(['list_group' => true]); UOJSubmission::cur()->echoContent(['list_group' => true]);
echo '</div>'; echo '</div>';
}, },
@ -243,29 +263,6 @@ if (isset($hack_form)) {
<?= UOJLocale::get('problems::submission') . ' #' . $submission['id'] ?> <?= UOJLocale::get('problems::submission') . ' #' . $submission['id'] ?>
</h1> </h1>
<style>
.submission-layout {
/* display: grid; */
grid-template-columns: minmax(0, calc(100% - 25% - var(--bs-gutter-x))) auto;
grid-template-rows: auto 1fr;
}
.submission-left-col {
grid-column: 1;
grid-row: 1 / span 2;
}
.submission-right-col {
grid-column: 2;
grid-row: 1;
}
.submission-right-control-panel {
grid-column: 2;
grid-row: 2;
}
</style>
<div class="row mt-3 submission-layout d-md-grid"> <div class="row mt-3 submission-layout d-md-grid">
<div class="submission-right-col"> <div class="submission-right-col">
<?php UOJSubmission::cur()->echoStatusCard(['show_actual_score' => $perm['score'], 'id_hidden' => true], Auth::user()) ?> <?php UOJSubmission::cur()->echoStatusCard(['show_actual_score' => $perm['score'], 'id_hidden' => true], Auth::user()) ?>
@ -314,7 +311,6 @@ if (isset($hack_form)) {
</div> </div>
<div class="submission-right-control-panel"> <div class="submission-right-control-panel">
<?php if ( <?php if (
isset($minor_rejudge_form) || isset($minor_rejudge_form) ||
isset($rejudge_form) || isset($rejudge_form) ||
@ -325,7 +321,7 @@ if (isset($hack_form)) {
操作 操作
</div> </div>
<div class="list-group list-group-flush"> <div class="list-group list-group-flush rounded-bottom">
<?php if (isset($minor_rejudge_form)) : ?> <?php if (isset($minor_rejudge_form)) : ?>
<?php $minor_rejudge_form->printHTML() ?> <?php $minor_rejudge_form->printHTML() ?>
<?php endif ?> <?php endif ?>

View File

@ -588,8 +588,6 @@ class UOJSubmission {
$cfg['show_actual_score'] = $this->viewerCanSeeScore($viewer); $cfg['show_actual_score'] = $this->viewerCanSeeScore($viewer);
} }
$show_status_details = $this->viewerCanSeeStatusDetailsHTML($viewer);
$rows = [ $rows = [
'id' => 'ID', 'id' => 'ID',
'submitter' => UOJLocale::get('problems::submitter'), 'submitter' => UOJLocale::get('problems::submitter'),
@ -624,8 +622,8 @@ class UOJSubmission {
break; break;
default: default:
echo '<div class="d-flex justify-content-between align-items-center">'; echo '<div class="d-flex justify-content-between align-items-center">';
echo '<span class="flex-shrink-0">', $name, '</span>'; echo '<span class="flex-shrink-0 me-2">', $name, '</span>';
echo '<span class="text-end">', $this->echoStatusBarTD($id, $cfg), '</span>'; echo '<span class="text-end text-truncate d-inline-block">', $this->echoStatusBarTD($id, $cfg), '</span>';
echo '</div>'; echo '</div>';
break; break;
@ -635,17 +633,6 @@ class UOJSubmission {
echo '</div>'; echo '</div>';
echo '</div>'; echo '</div>';
if ($show_status_details) {
echo '<div class="card">';
echo '<table>';
echo '<tr id="', "status_details_{$this->info['id']}", '" class="">';
echo $this->getStatusDetailsHTML();
echo '</tr>';
echo '<script type="text/javascript">update_judgement_status_details(' . $this->info['id'] . ')</script>';
echo '</table>';
echo '</div>';
}
} }
public function delete() { public function delete() {

View File

@ -502,3 +502,26 @@ form.form-horizontal {
padding-right: 0 !important; padding-right: 0 !important;
} }
} }
/* Submission Page */
.submission-layout {
/* display: grid; */
grid-template-columns: 75% 25%;
grid-template-rows: auto 1fr;
}
.submission-left-col {
grid-column: 1;
grid-row: 1 / span 2;
}
.submission-right-col {
grid-column: 2;
grid-row: 1;
}
.submission-right-control-panel {
grid-column: 2;
grid-row: 2;
}