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/problem_submit.page.js

65 lines
2.3 KiB
JavaScript

import { NamedPage } from 'vj/misc/Page';
function setOptions($el, options) {
$el.empty();
$.each(options, (key, value) => {
$el.append($('<option></option>').attr('value', key).text(value));
});
}
const page = new NamedPage(['problem_submit', 'contest_detail_problem_submit', 'homework_detail_problem_submit'], async () => {
const { config } = UiContext.pdoc;
const domainId = UiContext.pdoc.reference?.domainId || UiContext.pdoc.domainId;
function onChangeMain(update = true) {
const options = {};
for (const key in window.LANGS) {
if (config.langs && !config.langs.includes(key)) continue;
if (window.LANGS[key].domain && !window.LANGS[key].domain.includes(domainId)) continue;
if (key.startsWith(`${this.value}.`) && key !== this.value) options[key] = window.LANGS[key].display;
}
setOptions($('#codelang-sub-select'), options);
if (Object.keys(options).length) {
$('#codelang-sub-container').show();
if (update) $('[name="lang"]').val($('#codelang-sub-select').val());
} else {
$('#codelang-sub-container').hide();
if (update) $('[name="lang"]').val(this.value);
}
return Object.keys(options)[0];
}
const main = {};
for (const key in window.LANGS) {
if (config.langs && !config.langs.filter((i) => i === key || i.startsWith(`${key}.`)).length) continue;
if (window.LANGS[key].domain && !window.LANGS[key].domain.includes(domainId)) continue;
if (!key.includes('.')) main[key] = window.LANGS[key].display;
else {
const a = key.split('.')[0];
main[a] = window.LANGS[a].display;
}
}
setOptions($('#codelang-main-select'), main);
const current = $('[name="lang"]').val();
if (current.includes('.')) {
const [m] = current.split('.');
$('#codelang-main-select').val(m);
const fallback = onChangeMain.call({ value: m }, false);
$('#codelang-sub-select').val(current);
if (fallback && !$('#codelang-sub-select').val()) {
$('#codelang-sub-select').val(fallback);
$('[name="lang"]').val(fallback);
}
} else {
$('#codelang-main-select').val(current);
onChangeMain.call({ value: $('#codelang-main-select').val() }, false);
}
$('#codelang-main-select').on('change', onChangeMain);
$('#codelang-sub-select').on('change', function () {
$('[name="lang"]').val(this.value);
});
});
export default page;