feat(remote_judger): make details more beautiful

This commit is contained in:
Baoshuo Ren 2023-02-06 14:18:53 +08:00
parent 050b4995ee
commit e2fc360279
Signed by: baoshuo
GPG Key ID: 00CB9680AB29F51A
4 changed files with 58 additions and 22 deletions

View File

@ -420,13 +420,22 @@ export default class CodeforcesProvider implements IBasicProvider {
const details =
'<div>' +
'<div class="border-bottom p-3">' +
`<p><b>Contest:</b> ${stripHtml(body.contestName).result}</p>` +
`<p><b>Problem:</b> ${stripHtml(body.problemName).result}</p>` +
`<p><b>Remote submission:</b> <a href="https://codeforces.com${body.href}" target="_blank">${id}</a></p>` +
`<p><b>Remote account:</b> <a href="https://codeforces.com/profile/${remote_handle}" target="_blank">${remote_handle}</a></p>` +
`<p class="mb-0"><b>Verdict:</b> ${
stripHtml(body.verdict).result
}</p>` +
'<table class="table w-auto mb-0 caption-top">' +
'<caption class="fw-bold text-body mb-1 pt-0">远端信息</caption>' +
'<tbody class="border-top">' +
Object.entries({
比赛: stripHtml(body.contestName).result,
题目: stripHtml(body.problemName).result,
: `<a href="https://codeforces.com${body.href}" target="_blank">${id}</a>`,
: `<a href="https://codeforces.com/profile/${remote_handle}" target="_blank">${remote_handle}</a>`,
状态: stripHtml(body.verdict).result,
})
.map(
o => `<tr><td class="fw-bold">${o[0]}</td><td>${o[1]}</td></tr>`
)
.join('') +
'</tbody>' +
'</table>' +
'</div>' +
`<tests>${tests.join('\n')}</tests>` +
'</div>';

View File

@ -7,6 +7,7 @@ import { IBasicProvider, RemoteAccount, USER_AGENT } from '../interface';
import Logger from '../utils/logger';
import { normalize, VERDICT } from '../verdict';
import htmlspecialchars from '../utils/htmlspecialchars';
import { stripHtml } from 'string-strip-html';
proxy(superagent);
const logger = new Logger('remote/loj');
@ -461,13 +462,26 @@ export default class LibreojProvider implements IBasicProvider {
details +=
'<div class="border-bottom p-3">' +
`<p><b>Problem:</b> #${body.meta.problem.displayId}. ${body.meta.problemTitle}</p>` +
`<p><b>Remote submission:</b> <a href="https://loj.ac/s/${id}" target="_blank">${id}</a></p>` +
`<p><b>Remote submit time:</b> ${new Date(
body.meta.submitTime
).toLocaleString('zh-CN')}</p>` +
`<p><b>Remote account:</b> <a href="https://loj.ac/user/${body.meta.submitter.id}" target="_blank">${body.meta.submitter.username}</a></p>` +
`<p class="mb-0"><b>Verdict:</b> ${status}</p>` +
'<table class="table w-auto mb-0 caption-top">' +
'<caption class="fw-bold text-body mb-1 pt-0">远端信息</caption>' +
'<tbody class="border-top">' +
Object.entries({
: `<a href="https://loj.ac/p/${
body.meta.problem.displayId
}" target="_blank">#${
body.meta.problem.displayId
}. ${htmlspecialchars(body.meta.problemTitle)}</a>`,
: `<a href="https://loj.ac/s/${id}" target="_blank">${id}</a>`,
提交时间: new Date(body.meta.submitTime).toLocaleString('zh-CN'),
: `<a href="https://loj.ac/user/${body.meta.submitter.id}" target="_blank">${body.meta.submitter.username}</a>`,
状态: status,
})
.map(
o => `<tr><td class="fw-bold">${o[0]}</td><td>${o[1]}</td></tr>`
)
.join('') +
'</tbody>' +
'</table>' +
'</div>';
if (result_show_source) {

View File

@ -296,13 +296,26 @@ export default class LuoguProvider implements IBasicProvider {
details +=
'<div class="border-bottom p-3">' +
`<p><b>Problem:</b> ${data.problem.pid} ${data.problem.title}</p>` +
`<p><b>Remote submission:</b> <a href="https://www.luogu.com.cn/record/${id}" target="_blank">R${id}</a></p>` +
`<p><b>Remote submit time:</b> ${new Date(
data.submitTime * 1000
).toLocaleString('zh-CN')}</p>` +
`<p><b>Remote account:</b> <a href="https://www.luogu.com.cn/user/${data.user.uid}" target="_blank">${data.user.name}</a></p>` +
`<p class="mb-0"><b>Verdict:</b> ${status}</p>` +
'<table class="table w-auto mb-0 caption-top">' +
'<caption class="fw-bold text-body mb-1 pt-0">远端信息</caption>' +
'<tbody class="border-top">' +
Object.entries({
: `<a href="https://www.luogu.com.cn/problem/${
data.problem.pid
}" target="_blank">${data.problem.pid} ${htmlspecialchars(
data.problem.title
)}</a>`,
: `<a href="https://www.luogu.com.cn/record/${id}" target="_blank">R${id}</a>`,
提交时间: new Date(data.submitTime * 1000).toLocaleString('zh-CN'),
: `<a href="https://www.luogu.com.cn/user/${data.user.uid}" target="_blank">${data.user.name}</a>`,
状态: status,
})
.map(
o => `<tr><td class="fw-bold">${o[0]}</td><td>${o[1]}</td></tr>`
)
.join('') +
'</tbody>' +
'</table>' +
'</div>';
if (data.detail.judgeResult.subtasks.length === 1) {

View File

@ -543,7 +543,7 @@ class JudgmentDetailsPrinter {
if ($test_memory >= 0) {
echo '<div class="col-sm-2">';
echo '<i class="bi bi-memory"></i> ', $test_memory, 'kB';
echo '<i class="bi bi-memory"></i> ', $test_memory, ' kB';
echo '</div>';
}