This commit is contained in:
esp
2015-11-07 20:13:46 +08:00
10 changed files with 118 additions and 179 deletions

View File

@@ -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,

View File

@@ -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"测试用例文件格式错误,文件数目为奇数")

View File

@@ -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;
}
}
})
} }
} }
}); });

View File

@@ -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({

View File

@@ -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({

View 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);
});
}
})
});

View File

@@ -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",
// ------ 下面写的都不要直接用,而是使用上面的封装版本 ------ // ------ 下面写的都不要直接用,而是使用上面的封装版本 ------

View File

@@ -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>

View File

@@ -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>

View File

@@ -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>