You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Hydro/packages/ui-default/pages/contest_scoreboard.page.ts

40 lines
1.2 KiB
TypeScript

import $ from 'jquery';
import { NamedPage } from 'vj/misc/Page';
const page = new NamedPage('contest_scoreboard', () => {
const { tdoc } = UiContext;
const key = `scoreboard-star/${tdoc.domainId}/${tdoc.docId}`;
const read = () => JSON.parse(localStorage.getItem(key) || '[]');
const write = (data) => localStorage.setItem(key, JSON.stringify(data));
read().forEach((uid) => $(`.star.user--${uid}`).addClass('activated'));
$('.star').on('click', (e) => {
const star = read();
const $target = $(e.currentTarget);
const uid = $target.data('uid');
if (star.includes(uid)) {
$target.removeClass('activated');
star.splice(star.indexOf(uid), 1);
} else {
$target.addClass('activated');
star.push(uid);
}
write(star);
});
$('.select.filter').on('change', (e) => {
const val = $(e.target).val();
if (val === 'all') {
$('.data-table tbody tr').show();
} else if (val === 'star') {
$('.data-table tbody tr').hide();
read().forEach((uid) => $(`.star.user--${uid}`).closest('tr').show());
} else {
$('.data-table tbody tr').show();
$('.rank--unrank').closest('tr').hide();
}
});
});
export default page;