2015-12-27 16:54:50 -05:00
|
|
|
<!--
|
|
|
|
Adding files:
|
|
|
|
1) put file in /files
|
|
|
|
2) create an "<a href="/files/example.txt" target="_blank"><h4>Example File</h4></a>"
|
|
|
|
3) remove these instructions (:P)
|
|
|
|
-->
|
2016-01-02 00:51:56 -05:00
|
|
|
<div class="fade_in">
|
2016-04-16 22:15:57 -04:00
|
|
|
<h1 class="text-center">Problems</h1>
|
|
|
|
<div ng-repeat="problem in problems">
|
|
|
|
<div class="panel-group">
|
|
|
|
<div class="panel panel-default">
|
|
|
|
<div class="panel-heading" data-toggle="collapse" data-target="#{{ problem['pid'] }}_body">
|
|
|
|
<h4 class="panel-title">
|
|
|
|
{{ problem["title"] }} {{ problem["value"] }} points
|
|
|
|
<div class="pull-right">{{ problem["category"] }} - {{ problem["solved"] }} ({{ problem["solves"] }} {{ problem["solves"] === 1 ? "solve" : "solves" }})</div>
|
|
|
|
</h4>
|
|
|
|
</div>
|
|
|
|
<div id="{{ problem['pid'] }}_body" class="panel-collapse collapse">
|
|
|
|
<div class="panel-body">
|
|
|
|
<div hidden id="{{ problem['pid'] }}_hint">{{ problem['hint'] }}</div>
|
|
|
|
<div hidden id="{{ problem['pid'] }}_status"/>
|
|
|
|
{{ problem["description"] }}
|
|
|
|
</div>
|
|
|
|
<form id="{{ problem['pid'] }}_form" class="horizontal-form" onsubmit="submit_problem(this.id); return false;">
|
|
|
|
<div class="input-group">
|
|
|
|
<input hidden name="pid" value="{{ problem['pid'] }}"/>
|
|
|
|
<input class="form-control" name="flag" placeholder="Flag"/>
|
|
|
|
<span class="input-group-btn">
|
|
|
|
<input onclick="toggle_hint(this.closest('form').id); return false;" type="button" class="btn btn-success" value="Hint"/>
|
|
|
|
</span>
|
|
|
|
<span class="input-group-btn">
|
|
|
|
<input type="submit" class="btn btn-success" value="Submit"/>
|
|
|
|
</span>
|
|
|
|
</div>
|
|
|
|
</form>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
2016-01-02 00:51:56 -05:00
|
|
|
</div>
|
2016-04-16 22:15:57 -04:00
|
|
|
|
|
|
|
<script>
|
|
|
|
var toggle_hint = function(form) {
|
|
|
|
pid = form.split("_")[0];
|
|
|
|
$("#" + pid + "_hint").slideToggle("fast", function() {});
|
|
|
|
}
|
|
|
|
|
|
|
|
var submit_problem = function(form) {
|
|
|
|
var input = "#" + form + " input";
|
|
|
|
var data = $("#" + form).serializeObject();
|
|
|
|
pid = data["pid"];
|
|
|
|
$(input).attr("disabled", "disabed");
|
|
|
|
api_call("POST", "/api/problem/submit", data, function(result) {
|
|
|
|
if (result["success"] == 1) {
|
|
|
|
display_message(pid + "_status", "success", result["message"], function() {
|
|
|
|
$(input).removeAttr("disabled");
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
display_message(pid + "_status", "danger", result["message"], function() {
|
|
|
|
$(input).removeAttr("disabled");
|
|
|
|
});
|
|
|
|
}
|
|
|
|
console.log(result["error"]);
|
|
|
|
}, function(jqXHR, status, error) {
|
|
|
|
var result = jqXHR["responseText"];
|
|
|
|
display_message(pid + "_status", "danger", "Error " + jqXHR["status"] + ": " + result["message"], function() {
|
|
|
|
$(input).removeAttr("disabled");
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
</script>
|