ui: add contest_timer

pull/442/head
undefined 2 years ago
parent 72c3e48f1b
commit dffca5f8c7

@ -41,6 +41,14 @@ for key, value in $contest-color
background: $primary-color
border-color: $primary-color
.contest-timer
position: fixed;
left: 0;
top: 48px;
z-index: 10000;
+mobile()
visibility: hidden !important;
.contest-problems
font-size: 0.9375rem;
font-weight: 400;

@ -1,5 +1,10 @@
import { formatSeconds } from '@hydrooj/utils/lib/common';
import NProgress from 'nprogress';
import { NamedPage } from 'vj/misc/Page';
import tpl from 'vj/utils/tpl';
const contestTimer = $(tpl`<pre class="contest-timer" style="display:none"></pre>`);
contestTimer.appendTo(document.body);
export default new NamedPage(['contest_detail', 'contest_detail_problem', 'contest_scoreboard'], () => {
const beginAt = new Date(UiContext.tdoc.beginAt).getTime();
@ -7,11 +12,17 @@ export default new NamedPage(['contest_detail', 'contest_detail_problem', 'conte
NProgress.configure({ trickle: false, showSpinner: false, minimum: 0 });
function updateProgress() {
const now = Date.now();
if (beginAt <= now && now <= endAt) NProgress.set((now - beginAt) / (endAt - beginAt));
else if (now > endAt) NProgress.set(1);
else NProgress.set(0);
if (beginAt <= now && now <= endAt) {
NProgress.set((now - beginAt) / (endAt - beginAt));
contestTimer.show();
contestTimer.text(formatSeconds(Math.floor((endAt - now) / 1000)));
} else {
if (now > endAt) NProgress.set(1);
else NProgress.set(0);
contestTimer.hide();
}
}
NProgress.start();
updateProgress();
setInterval(updateProgress, 5000);
setInterval(updateProgress, 1000);
});

@ -149,6 +149,20 @@ export function parseMemoryMB(str: string | number, throwOnError = true) {
return Math.ceil(parseFloat(match[1]) * MEMORY_UNITS[match[2].toLowerCase()]);
}
function _digit2(number: number) {
return number < 10 ? `0${number}` : number.toString();
}
export function formatSeconds(_seconds: string | number = '0', showSeconds = true) {
const seconds = +_seconds;
let res = '{0}:{1}'.format(
showSeconds ? _digit2(Math.floor(seconds / 3600)) : Math.floor(seconds / 3600),
_digit2(Math.floor((seconds % 3600) / 60)),
);
if (showSeconds) res += `:${_digit2(seconds % 60)}`;
return res;
}
export function size(s: number, base = 1) {
s *= base;
const unit = 1024;

@ -190,20 +190,6 @@ export function errorMessage(err: Error | string) {
return err;
}
function _digit2(number: number) {
return number < 10 ? `0${number}` : number.toString();
}
export function formatSeconds(_seconds: string | number = '0', showSeconds = true) {
const seconds = +_seconds;
let res = '{0}:{1}'.format(
showSeconds ? _digit2(Math.floor(seconds / 3600)) : Math.floor(seconds / 3600),
_digit2(Math.floor((seconds % 3600) / 60)),
);
if (showSeconds) res += `:${_digit2(seconds % 60)}`;
return res;
}
export function changeErrorType(err: any, Err: any) {
const e = new Err(err.message);
e.stack = err.stack;

Loading…
Cancel
Save