Merge branch 'master' of https://git.coding.net/virusdefender/qduoj into dev-s
This commit is contained in:
@@ -278,6 +278,8 @@ class MakeContestProblemPublicAPIView(APIView):
|
|||||||
problem_id = request.data.get("problem_id", -1)
|
problem_id = request.data.get("problem_id", -1)
|
||||||
try:
|
try:
|
||||||
problem = ContestProblem.objects.get(id=problem_id)
|
problem = ContestProblem.objects.get(id=problem_id)
|
||||||
|
problem.is_public = True
|
||||||
|
problem.save()
|
||||||
except ContestProblem.DoesNotExist:
|
except ContestProblem.DoesNotExist:
|
||||||
return error_response(u"比赛不存在")
|
return error_response(u"比赛不存在")
|
||||||
Problem.objects.create(title=problem.title, description=problem.description,
|
Problem.objects.create(title=problem.title, description=problem.description,
|
||||||
|
|||||||
@@ -191,6 +191,8 @@ class TestCaseUploadAPIView(APIView):
|
|||||||
name_list = test_case_file.namelist()
|
name_list = test_case_file.namelist()
|
||||||
|
|
||||||
# 如果文件是直接打包的,那么name_list 就是["1.in", "1.out"]这样的
|
# 如果文件是直接打包的,那么name_list 就是["1.in", "1.out"]这样的
|
||||||
|
if len(name_list) == 0:
|
||||||
|
return error_response(u"压缩包内没有文件")
|
||||||
|
|
||||||
if len(name_list) % 2 == 1:
|
if len(name_list) % 2 == 1:
|
||||||
return error_response(u"测试用例文件格式错误,文件数目为奇数")
|
return error_response(u"测试用例文件格式错误,文件数目为奇数")
|
||||||
|
|||||||
@@ -1,4 +1,5 @@
|
|||||||
require(["jquery", "avalon", "editor", "uploader", "bsAlert", "csrfToken", "tagEditor", "validator", "editorComponent"],
|
require(["jquery", "avalon", "editor", "uploader", "bsAlert",
|
||||||
|
"csrfToken", "tagEditor", "validator", "editorComponent", "testCaseUploader"],
|
||||||
function ($, avalon, editor, uploader, bsAlert, csrfTokenHeader) {
|
function ($, avalon, editor, uploader, bsAlert, csrfTokenHeader) {
|
||||||
|
|
||||||
avalon.ready(function () {
|
avalon.ready(function () {
|
||||||
@@ -7,7 +8,7 @@ require(["jquery", "avalon", "editor", "uploader", "bsAlert", "csrfToken", "tagE
|
|||||||
.on('submit', function (e) {
|
.on('submit', function (e) {
|
||||||
if (!e.isDefaultPrevented()) {
|
if (!e.isDefaultPrevented()) {
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
if (vm.testCaseId == "") {
|
if (!avalon.vmodels.testCaseUploader.uploaded) {
|
||||||
bsAlert("你还没有上传测试数据!");
|
bsAlert("你还没有上传测试数据!");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@@ -35,7 +36,7 @@ require(["jquery", "avalon", "editor", "uploader", "bsAlert", "csrfToken", "tagE
|
|||||||
time_limit: vm.timeLimit,
|
time_limit: vm.timeLimit,
|
||||||
memory_limit: vm.memoryLimit,
|
memory_limit: vm.memoryLimit,
|
||||||
samples: [],
|
samples: [],
|
||||||
test_case_id: vm.testCaseId,
|
test_case_id: avalon.vmodels.testCaseUploader.testCaseId,
|
||||||
hint: avalon.vmodels.contestProblemHintEditor.content,
|
hint: avalon.vmodels.contestProblemHintEditor.content,
|
||||||
visible: vm.visible,
|
visible: vm.visible,
|
||||||
contest_id: avalon.vmodels.admin.contestId,
|
contest_id: avalon.vmodels.admin.contestId,
|
||||||
@@ -71,6 +72,7 @@ require(["jquery", "avalon", "editor", "uploader", "bsAlert", "csrfToken", "tagE
|
|||||||
success: function (data) {
|
success: function (data) {
|
||||||
if (!data.code) {
|
if (!data.code) {
|
||||||
bsAlert(alertContent);
|
bsAlert(alertContent);
|
||||||
|
avalon.vmodels.admin.template_url = "template/contest/problem_list.html";
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
bsAlert(data.data);
|
bsAlert(data.data);
|
||||||
@@ -97,7 +99,6 @@ require(["jquery", "avalon", "editor", "uploader", "bsAlert", "csrfToken", "tagE
|
|||||||
outputDescription: "",
|
outputDescription: "",
|
||||||
testCaseId: "",
|
testCaseId: "",
|
||||||
testCaseList: [],
|
testCaseList: [],
|
||||||
uploadSuccess: false,
|
|
||||||
|
|
||||||
contestProblemDescriptionEditor: {
|
contestProblemDescriptionEditor: {
|
||||||
editorId: "contest-problem-description-editor",
|
editorId: "contest-problem-description-editor",
|
||||||
@@ -134,38 +135,20 @@ require(["jquery", "avalon", "editor", "uploader", "bsAlert", "csrfToken", "tagE
|
|||||||
});
|
});
|
||||||
else {
|
else {
|
||||||
var vm = avalon.vmodels.editProblem;
|
var vm = avalon.vmodels.editProblem;
|
||||||
title = "";
|
vm.title = "";
|
||||||
description = "";
|
vm.description = "";
|
||||||
timeLimit = 1000;
|
vm.timeLimit = 1000;
|
||||||
memoryLimit = 128;
|
vm.memoryLimit = 128;
|
||||||
samples = [];
|
vm.samples = [];
|
||||||
hint = "";
|
vm.hint = "";
|
||||||
sortIndex = "";
|
vm.sortIndex = "";
|
||||||
visible = true;
|
vm.visible = true;
|
||||||
inputDescription = "";
|
vm.inputDescription = "";
|
||||||
outputDescription = "";
|
vm.outputDescription = "";
|
||||||
testCaseId = "";
|
vm.testCaseId = "";
|
||||||
testCaseList = [];
|
vm.testCaseList = [];
|
||||||
uploadSuccess = false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
var testCaseUploader = uploader("#testCaseFile", "/api/admin/test_case_upload/", function (file, response) {
|
|
||||||
if (response.code)
|
|
||||||
bsAlert(response.data);
|
|
||||||
else {
|
|
||||||
vm.testCaseId = response.data.test_case_id;
|
|
||||||
vm.testCaseList = [];
|
|
||||||
for (var key in response.data.file_list) {
|
|
||||||
vm.testCaseList.push({
|
|
||||||
input: response.data.file_list[key].input_name,
|
|
||||||
output: response.data.file_list[key].output_name
|
|
||||||
})
|
|
||||||
}
|
|
||||||
vm.uploadSuccess = true;
|
|
||||||
bsAlert("测试数据添加成功!共添加" + vm.testCaseList.length + "组测试数据");
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
if (avalon.vmodels.admin.contestProblemStatus == "edit") {
|
if (avalon.vmodels.admin.contestProblemStatus == "edit") {
|
||||||
$.ajax({
|
$.ajax({
|
||||||
url: "/api/admin/contest_problem/?contest_problem_id=" + avalon.vmodels.admin.problemId,
|
url: "/api/admin/contest_problem/?contest_problem_id=" + avalon.vmodels.admin.problemId,
|
||||||
@@ -188,7 +171,7 @@ require(["jquery", "avalon", "editor", "uploader", "bsAlert", "csrfToken", "tagE
|
|||||||
vm.inputDescription = problem.input_description;
|
vm.inputDescription = problem.input_description;
|
||||||
vm.outputDescription = problem.output_description;
|
vm.outputDescription = problem.output_description;
|
||||||
vm.score = problem.score;
|
vm.score = problem.score;
|
||||||
vm.testCaseId = problem.test_case_id;
|
avalon.vmodels.testCaseUploader.setTestCase(problem.test_case_id);
|
||||||
vm.samples = [];
|
vm.samples = [];
|
||||||
for (var i = 0; i < problem.samples.length; i++) {
|
for (var i = 0; i < problem.samples.length; i++) {
|
||||||
vm.samples.push({
|
vm.samples.push({
|
||||||
@@ -198,26 +181,6 @@ require(["jquery", "avalon", "editor", "uploader", "bsAlert", "csrfToken", "tagE
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
avalon.vmodels.contestProblemHintEditor.content = problem.hint;
|
avalon.vmodels.contestProblemHintEditor.content = problem.hint;
|
||||||
$.ajax({
|
|
||||||
url: "/api/admin/test_case_upload/?test_case_id=" + vm.testCaseId,
|
|
||||||
method: "get",
|
|
||||||
dataType: "json",
|
|
||||||
success: function (response) {
|
|
||||||
if (response.code) {
|
|
||||||
bsAlert(response.data);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
vm.testCaseList = [];
|
|
||||||
for (var key in response.data.file_list) {
|
|
||||||
vm.testCaseList.push({
|
|
||||||
input: response.data.file_list[key].input_name,
|
|
||||||
output: response.data.file_list[key].output_name
|
|
||||||
})
|
|
||||||
}
|
|
||||||
vm.uploadSuccess = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -1,11 +1,12 @@
|
|||||||
require(["jquery", "avalon", "editor", "uploader", "bsAlert", "csrfToken", "tagEditor", "validator", "jqueryUI", "editorComponent"],
|
require(["jquery", "avalon", "editor", "uploader", "bsAlert",
|
||||||
|
"csrfToken", "tagEditor", "validator", "jqueryUI", "editorComponent", "testCaseUploader"],
|
||||||
function ($, avalon, editor, uploader, bsAlert, csrfTokenHeader) {
|
function ($, avalon, editor, uploader, bsAlert, csrfTokenHeader) {
|
||||||
avalon.ready(function () {
|
avalon.ready(function () {
|
||||||
|
|
||||||
$("#add-problem-form").validator()
|
$("#add-problem-form").validator()
|
||||||
.on('submit', function (e) {
|
.on('submit', function (e) {
|
||||||
if (!e.isDefaultPrevented()) {
|
if (!e.isDefaultPrevented()) {
|
||||||
if (vm.testCaseId == "") {
|
if (!avalon.vmodels.testCaseUploader.uploaded) {
|
||||||
bsAlert("你还没有上传测试数据!");
|
bsAlert("你还没有上传测试数据!");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@@ -39,7 +40,7 @@ require(["jquery", "avalon", "editor", "uploader", "bsAlert", "csrfToken", "tagE
|
|||||||
time_limit: vm.timeLimit,
|
time_limit: vm.timeLimit,
|
||||||
memory_limit: vm.memoryLimit,
|
memory_limit: vm.memoryLimit,
|
||||||
samples: [],
|
samples: [],
|
||||||
test_case_id: vm.testCaseId,
|
test_case_id: avalon.vmodels.testCaseUploader.testCaseId,
|
||||||
hint: avalon.vmodels.problemHintEditor.content,
|
hint: avalon.vmodels.problemHintEditor.content,
|
||||||
source: vm.source,
|
source: vm.source,
|
||||||
visible: vm.visible,
|
visible: vm.visible,
|
||||||
@@ -139,29 +140,6 @@ require(["jquery", "avalon", "editor", "uploader", "bsAlert", "csrfToken", "tagE
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
var testCaseUploader = uploader("#testCaseFile", "/api/admin/test_case_upload/",
|
|
||||||
function (file, response) {
|
|
||||||
if (response.code) {
|
|
||||||
vm.uploadProgress = 0;
|
|
||||||
bsAlert(response.data);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
vm.testCaseId = response.data.test_case_id;
|
|
||||||
vm.uploadSuccess = true;
|
|
||||||
vm.testCaseList = [];
|
|
||||||
for (var key in response.data.file_list) {
|
|
||||||
vm.testCaseList.push({
|
|
||||||
input: response.data.file_list[key].input_name,
|
|
||||||
output: response.data.file_list[key].output_name
|
|
||||||
})
|
|
||||||
}
|
|
||||||
bsAlert("测试数据添加成功!共添加" + vm.testCaseList.length + "组测试数据");
|
|
||||||
}
|
|
||||||
},
|
|
||||||
function (file, percentage) {
|
|
||||||
vm.uploadProgress = parseInt(percentage * 100);
|
|
||||||
});
|
|
||||||
|
|
||||||
var tagAutoCompleteList = [];
|
var tagAutoCompleteList = [];
|
||||||
|
|
||||||
$.ajax({
|
$.ajax({
|
||||||
|
|||||||
@@ -1,4 +1,5 @@
|
|||||||
require(["jquery", "avalon", "editor", "uploader", "bsAlert", "csrfToken", "tagEditor", "validator", "jqueryUI", "editorComponent"],
|
require(["jquery", "avalon", "editor", "uploader", "bsAlert",
|
||||||
|
"csrfToken", "tagEditor", "validator", "jqueryUI", "editorComponent", "testCaseUploader"],
|
||||||
function ($, avalon, editor, uploader, bsAlert, csrfTokenHeader) {
|
function ($, avalon, editor, uploader, bsAlert, csrfTokenHeader) {
|
||||||
|
|
||||||
avalon.ready(function () {
|
avalon.ready(function () {
|
||||||
@@ -6,7 +7,7 @@ require(["jquery", "avalon", "editor", "uploader", "bsAlert", "csrfToken", "tagE
|
|||||||
$("#edit-problem-form").validator()
|
$("#edit-problem-form").validator()
|
||||||
.on('submit', function (e) {
|
.on('submit', function (e) {
|
||||||
if (!e.isDefaultPrevented()) {
|
if (!e.isDefaultPrevented()) {
|
||||||
if (vm.testCaseId == "") {
|
if (!avalon.vmodels.testCaseUploader.uploaded) {
|
||||||
bsAlert("你还没有上传测试数据!");
|
bsAlert("你还没有上传测试数据!");
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@@ -40,7 +41,7 @@ require(["jquery", "avalon", "editor", "uploader", "bsAlert", "csrfToken", "tagE
|
|||||||
time_limit: vm.timeLimit,
|
time_limit: vm.timeLimit,
|
||||||
memory_limit: vm.memoryLimit,
|
memory_limit: vm.memoryLimit,
|
||||||
samples: [],
|
samples: [],
|
||||||
test_case_id: vm.testCaseId,
|
test_case_id: avalon.vmodels.testCaseUploader.testCaseId,
|
||||||
hint: avalon.vmodels.problemHintEditor.content,
|
hint: avalon.vmodels.problemHintEditor.content,
|
||||||
source: vm.source,
|
source: vm.source,
|
||||||
visible: vm.visible,
|
visible: vm.visible,
|
||||||
@@ -127,29 +128,6 @@ require(["jquery", "avalon", "editor", "uploader", "bsAlert", "csrfToken", "tagE
|
|||||||
avalon.vmodels.admin.template_url = "template/problem/problem_list.html";
|
avalon.vmodels.admin.template_url = "template/problem/problem_list.html";
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
var testCaseUploader = uploader("#testCaseFile", "/api/admin/test_case_upload/",
|
|
||||||
function (file, response) {
|
|
||||||
if (response.code) {
|
|
||||||
vm.uploadProgress = 0;
|
|
||||||
bsAlert(response.data);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
vm.testCaseId = response.data.test_case_id;
|
|
||||||
vm.uploadSuccess = true;
|
|
||||||
vm.testCaseList = [];
|
|
||||||
for(var key in response.data.file_list){
|
|
||||||
vm.testCaseList.push({
|
|
||||||
input: response.data.file_list[key].input_name,
|
|
||||||
output: response.data.file_list[key].output_name
|
|
||||||
})
|
|
||||||
}
|
|
||||||
bsAlert("测试数据添加成功!共添加" + vm.testCaseList.length + "组测试数据");
|
|
||||||
}
|
|
||||||
},
|
|
||||||
function (file, percentage) {
|
|
||||||
vm.uploadProgress = parseInt(percentage * 100);
|
|
||||||
}
|
|
||||||
);
|
|
||||||
|
|
||||||
$.ajax({
|
$.ajax({
|
||||||
url: "/api/admin/problem/?problem_id=" + avalon.vmodels.admin.problemId,
|
url: "/api/admin/problem/?problem_id=" + avalon.vmodels.admin.problemId,
|
||||||
@@ -178,7 +156,7 @@ require(["jquery", "avalon", "editor", "uploader", "bsAlert", "csrfToken", "tagE
|
|||||||
vm.difficulty = problem.difficulty;
|
vm.difficulty = problem.difficulty;
|
||||||
vm.inputDescription = problem.input_description;
|
vm.inputDescription = problem.input_description;
|
||||||
vm.outputDescription = problem.output_description;
|
vm.outputDescription = problem.output_description;
|
||||||
vm.testCaseId = problem.test_case_id;
|
avalon.vmodels.testCaseUploader.setTestCase(problem.test_case_id);
|
||||||
vm.source = problem.source;
|
vm.source = problem.source;
|
||||||
var problemTags = problem.tags;
|
var problemTags = problem.tags;
|
||||||
$.ajax({
|
$.ajax({
|
||||||
|
|||||||
83
static/src/js/components/testCaseUploader.js
Normal file
83
static/src/js/components/testCaseUploader.js
Normal file
@@ -0,0 +1,83 @@
|
|||||||
|
define("testCaseUploader", ["avalon", "uploader", "bsAlert", "jquery"], function(avalon, uploader, bsAlert, $){
|
||||||
|
avalon.component("ms:testcaseuploader", {
|
||||||
|
$template: '<div class="col-md-12">' +
|
||||||
|
'<br> ' +
|
||||||
|
'<label>测试数据</label><br> ' +
|
||||||
|
'<small class="text-info">' +
|
||||||
|
'请将所有测试用例打包在一个文件中上传,' +
|
||||||
|
'所有文件要在压缩包的根目录,' +
|
||||||
|
'且输入输出文件名要以从1开始连续数字标识要对应例如:' +
|
||||||
|
'<br>1.in 1.out 2.in 2.out </small> ' +
|
||||||
|
'<p>上传进度<span ms-text="uploadProgress"></span>%</p> ' +
|
||||||
|
'<table class="table table-striped" ms-visible="uploaded"> ' +
|
||||||
|
'<tr> <td>编号</td> <td>输入文件名</td> <td>输出文件名</td> </tr> ' +
|
||||||
|
'<tr ms-repeat="testCaseList"> ' +
|
||||||
|
'<td>{{ $index + 1 }}</td> ' +
|
||||||
|
'<td>{{ el.input }}</td> ' +
|
||||||
|
'<td>{{ el.output }}</td> </tr> ' +
|
||||||
|
'</table> ' +
|
||||||
|
'</div> ' +
|
||||||
|
'<div class="col-md-12"> ' +
|
||||||
|
'<div class="form-group">' +
|
||||||
|
' <div id="testCaseFileSelector">选择文件</div> ' +
|
||||||
|
'</div> ' +
|
||||||
|
'</div>',
|
||||||
|
testCaseId: "",
|
||||||
|
testCaseList: [],
|
||||||
|
uploaded: false,
|
||||||
|
uploadProgress: 0,
|
||||||
|
|
||||||
|
setTestCaseId: function(){},
|
||||||
|
|
||||||
|
$init: function(vm, el){
|
||||||
|
vm.setTestCase = function(testCaseId){
|
||||||
|
vm.testCaseId = testCaseId;
|
||||||
|
$.ajax({
|
||||||
|
url: "/api/admin/test_case_upload/?test_case_id=" + testCaseId,
|
||||||
|
method: "get",
|
||||||
|
success: function(data){
|
||||||
|
if(data.code){
|
||||||
|
bsAlert("获取测试用例列表失败");
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
for(var key in data.data.file_list){
|
||||||
|
vm.testCaseList.push({
|
||||||
|
input: data.data.file_list[key].input_name,
|
||||||
|
output: data.data.file_list[key].output_name
|
||||||
|
})
|
||||||
|
}
|
||||||
|
vm.uploaded = true;
|
||||||
|
vm.uploadProgress = 100;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
$ready: function(vm, el){
|
||||||
|
el.msRetain = true;
|
||||||
|
var testCaseUploader = uploader("#testCaseFileSelector", "/api/admin/test_case_upload/",
|
||||||
|
function (file, response) {
|
||||||
|
if (response.code) {
|
||||||
|
bsAlert(response.data);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
vm.testCaseId = response.data.test_case_id;
|
||||||
|
vm.uploaded = true;
|
||||||
|
vm.testCaseList = [];
|
||||||
|
for(var key in response.data.file_list){
|
||||||
|
vm.testCaseList.push({
|
||||||
|
input: response.data.file_list[key].input_name,
|
||||||
|
output: response.data.file_list[key].output_name
|
||||||
|
})
|
||||||
|
}
|
||||||
|
bsAlert("测试数据添加成功!共添加" + vm.testCaseList.length + "组测试数据");
|
||||||
|
}
|
||||||
|
},
|
||||||
|
function (file, percentage) {
|
||||||
|
vm.uploadProgress = parseInt(percentage * 100);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
})
|
||||||
|
});
|
||||||
@@ -27,6 +27,7 @@ var require = {
|
|||||||
// ------ admin web 组件 ----------
|
// ------ admin web 组件 ----------
|
||||||
pager: "components/pager",
|
pager: "components/pager",
|
||||||
editorComponent: "components/editorComponent",
|
editorComponent: "components/editorComponent",
|
||||||
|
testCaseUploader: "components/testCaseUploader",
|
||||||
|
|
||||||
|
|
||||||
// ------ 下面写的都不要直接用,而是使用上面的封装版本 ------
|
// ------ 下面写的都不要直接用,而是使用上面的封装版本 ------
|
||||||
|
|||||||
@@ -96,29 +96,7 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="col-md-12"><br>
|
<ms:testcaseuploader $id="testCaseUploader"></ms:testcaseuploader>
|
||||||
<label>测试数据<span ms-if="uploadSuccess">(当前已上传,继续上传将覆盖原有测试用例)</span></label><br>
|
|
||||||
<small class="text-info">请将所有测试用例打包在一个文件中上传,所有文件要在压缩包的根目录,且输入输出文件名要以从1开始连续数字标识要对应例如:<br>
|
|
||||||
1.in 1.out 2.in 2.out
|
|
||||||
</small>
|
|
||||||
<table class="table table-striped" ms-visible="uploadSuccess">
|
|
||||||
<tr>
|
|
||||||
<td>编号</td>
|
|
||||||
<td>输入文件名</td>
|
|
||||||
<td>输出文件名</td>
|
|
||||||
</tr>
|
|
||||||
<tr ms-repeat="testCaseList">
|
|
||||||
<td>{{ $index + 1 }}</td>
|
|
||||||
<td>{{ el.input }}</td>
|
|
||||||
<td>{{ el.output }}</td>
|
|
||||||
</tr>
|
|
||||||
</table>
|
|
||||||
</div>
|
|
||||||
<div class="col-md-12">
|
|
||||||
<div class="form-group">
|
|
||||||
<div id="testCaseFile">选择文件</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="form-group col-md-12">
|
<div class="form-group col-md-12">
|
||||||
<label>提示</label>
|
<label>提示</label>
|
||||||
<ms:editor $id="contestProblemHintEditor" config="contestProblemHintEditor"></ms:editor>
|
<ms:editor $id="contestProblemHintEditor" config="contestProblemHintEditor"></ms:editor>
|
||||||
|
|||||||
@@ -99,30 +99,7 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="col-md-12"><br>
|
<ms:testcaseuploader $id="testCaseUploader"></ms:testcaseuploader>
|
||||||
<label>测试数据</label><br>
|
|
||||||
<small class="text-info">请将所有测试用例打包在一个文件中上传,所有文件要在压缩包的根目录,且输入输出文件名要以从1开始连续数字标识要对应例如:<br>
|
|
||||||
1.in 1.out 2.in 2.out
|
|
||||||
</small>
|
|
||||||
<p>上传进度<span ms-text="uploadProgress"></span>%</p>
|
|
||||||
<table class="table table-striped" ms-visible="uploadSuccess">
|
|
||||||
<tr>
|
|
||||||
<td>编号</td>
|
|
||||||
<td>输入文件名</td>
|
|
||||||
<td>输出文件名</td>
|
|
||||||
</tr>
|
|
||||||
<tr ms-repeat="testCaseList">
|
|
||||||
<td>{{$index + 1}}</td>
|
|
||||||
<td>{{ el.input }}</td>
|
|
||||||
<td>{{ el.output }}</td>
|
|
||||||
</tr>
|
|
||||||
</table>
|
|
||||||
</div>
|
|
||||||
<div class="col-md-12">
|
|
||||||
<div class="form-group">
|
|
||||||
<div id="testCaseFile">选择文件</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="form-group col-md-12">
|
<div class="form-group col-md-12">
|
||||||
<label>提示</label>
|
<label>提示</label>
|
||||||
<ms:editor $id="problemHintEditor" config="problemHintEditor"></ms:editor>
|
<ms:editor $id="problemHintEditor" config="problemHintEditor"></ms:editor>
|
||||||
|
|||||||
@@ -105,30 +105,7 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="col-md-12"><br>
|
<ms:testcaseuploader $id="testCaseUploader"></ms:testcaseuploader>
|
||||||
<label>测试数据(当前已上传,继续上传将覆盖原有测试用例)</label><br>
|
|
||||||
<small class="text-info">请将所有测试用例打包在一个文件中上传,所有文件要在压缩包的根目录,且输入输出文件名要以从1开始连续数字标识要对应例如:<br>
|
|
||||||
1.in 1.out 2.in 2.out
|
|
||||||
</small>
|
|
||||||
<p>上传进度<span ms-text="uploadProgress"></span>%</p>
|
|
||||||
<table class="table table-striped" ms-visible="uploadSuccess">
|
|
||||||
<tr>
|
|
||||||
<td>编号</td>
|
|
||||||
<td>输入文件名</td>
|
|
||||||
<td>输出文件名</td>
|
|
||||||
</tr>
|
|
||||||
<tr ms-repeat="testCaseList">
|
|
||||||
<td>{{ $index + 1 }}</td>
|
|
||||||
<td>{{ el.input }}</td>
|
|
||||||
<td>{{ el.output }}</td>
|
|
||||||
</tr>
|
|
||||||
</table>
|
|
||||||
</div>
|
|
||||||
<div class="col-md-12">
|
|
||||||
<div class="form-group">
|
|
||||||
<div id="testCaseFile">选择文件</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="form-group col-md-12">
|
<div class="form-group col-md-12">
|
||||||
<label>提示</label>
|
<label>提示</label>
|
||||||
<ms:editor $id="problemHintEditor" config="problemHintEditor"></ms:editor>
|
<ms:editor $id="problemHintEditor" config="problemHintEditor"></ms:editor>
|
||||||
|
|||||||
Reference in New Issue
Block a user