2019-06-16 00:19:56 +00:00
|
|
|
{% extends "core/base.jinja" %}
|
2019-07-07 16:51:36 +00:00
|
|
|
{% from "core/macros.jinja" import user_profile_link %}
|
2019-07-05 10:31:49 +00:00
|
|
|
{% from "pedagogy/macros.jinja" import display_star %}
|
2019-06-16 00:19:56 +00:00
|
|
|
|
|
|
|
{% block title %}
|
|
|
|
{% trans %}UV Details{% endtrans %}
|
|
|
|
{% endblock %}
|
|
|
|
|
|
|
|
{% block content %}
|
2019-07-08 13:25:28 +00:00
|
|
|
<div class="pedagogy">
|
|
|
|
<div id="uv_detail">
|
2019-07-07 12:44:25 +00:00
|
|
|
<p id="return_noscript"><a href="{{ url('pedagogy:guide') }}">{% trans %}Back{% endtrans %}</a></p>
|
|
|
|
<button id="return_js" onclick='(function(){
|
|
|
|
// If comes from the guide page, go back with history
|
|
|
|
if (document.referrer.replace(/\?(.+)/gm,"").endsWith(`{{ url("pedagogy:guide") }}`)){
|
|
|
|
window.history.back();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
// Simply goes to the guide page
|
|
|
|
window.location.href = `{{ url("pedagogy:guide") }}`;
|
|
|
|
})()' hidden>{% trans %}Back{% endtrans %}</button>
|
2019-07-05 23:16:09 +00:00
|
|
|
|
2019-07-03 19:19:56 +00:00
|
|
|
<h1>{{ object.code }} - {{ object.title }}</h1>
|
2019-07-07 16:29:31 +00:00
|
|
|
<br>
|
2019-07-07 19:38:00 +00:00
|
|
|
<div class="uv-quick-info-container">
|
|
|
|
<div class="hours-cm">
|
|
|
|
<b>{% trans %}CM: {% endtrans %}</b>{{ object.hours_CM }}
|
|
|
|
</div>
|
|
|
|
<div class="hours-td">
|
|
|
|
<b>{% trans %}TD: {% endtrans %}</b>{{ object.hours_TD }}
|
|
|
|
</div>
|
|
|
|
<div class="hours-tp">
|
|
|
|
<b>{% trans %}TP: {% endtrans %}</b>{{ object.hours_TP }}
|
|
|
|
</div>
|
|
|
|
<div class="hours-te">
|
|
|
|
<b>{% trans %}TE: {% endtrans %}</b>{{ object.hours_TE }}
|
|
|
|
</div>
|
|
|
|
<div class="hours-the">
|
|
|
|
<b>{% trans %}THE: {% endtrans %}</b>{{ object.hours_THE }}
|
|
|
|
</div>
|
2019-07-07 19:56:59 +00:00
|
|
|
|
|
|
|
<div class="department">
|
|
|
|
{{ object.department }}
|
|
|
|
</div>
|
|
|
|
<div class="credit-type">
|
|
|
|
{{ object.credit_type }}
|
|
|
|
</div>
|
|
|
|
<div class="semester">
|
2019-07-08 13:17:12 +00:00
|
|
|
{{ object.get_semester_display() }}
|
2019-07-07 19:56:59 +00:00
|
|
|
</div>
|
2019-07-07 16:29:31 +00:00
|
|
|
</div>
|
2019-06-16 15:02:45 +00:00
|
|
|
|
2019-07-07 14:33:03 +00:00
|
|
|
<br>
|
|
|
|
|
2019-07-07 19:38:00 +00:00
|
|
|
<div class="uv-details-container">
|
2019-07-07 14:33:03 +00:00
|
|
|
<div class="grade">
|
2019-07-08 21:16:53 +00:00
|
|
|
<p>{% trans %}Global grade{% endtrans %}</p>
|
|
|
|
<p>{% trans %}Utility{% endtrans %}</p>
|
|
|
|
<p>{% trans %}Interest{% endtrans %}</p>
|
|
|
|
<p>{% trans %}Teaching{% endtrans %}</p>
|
|
|
|
<p>{% trans %}Work load{% endtrans %}</p>
|
2019-07-07 14:33:03 +00:00
|
|
|
</div>
|
|
|
|
<div class="grade-stars">
|
|
|
|
<p>{{ display_star(object.grade_global_average) }}</p>
|
|
|
|
<p>{{ display_star(object.grade_utility_average) }}</p>
|
|
|
|
<p>{{ display_star(object.grade_interest_average) }}</p>
|
|
|
|
<p>{{ display_star(object.grade_teaching_average) }}</p>
|
|
|
|
<p>{{ display_star(object.grade_work_load_average) }}</p>
|
|
|
|
</div>
|
|
|
|
<div class="uv-infos">
|
|
|
|
<p><b>{% trans %}Objectives{% endtrans %}</b></p>
|
|
|
|
<p>{{ object.objectives|markdown }}</p>
|
|
|
|
<p><b>{% trans %}Program{% endtrans %}</b></p>
|
|
|
|
<p>{{ object.program|markdown }}</p>
|
|
|
|
<p><b>{% trans %}Earned skills{% endtrans %}</b></p>
|
|
|
|
<p>{{ object.skills|markdown }}</p>
|
|
|
|
<p><b>{% trans %}Key concepts{% endtrans %}</b></p>
|
2019-07-08 07:26:22 +00:00
|
|
|
<p>{{ object.key_concepts|markdown }}</p>
|
2019-07-07 14:33:03 +00:00
|
|
|
<p><b>{% trans %}UV manager: {% endtrans %}</b>{{ object.manager }}</p>
|
|
|
|
</div>
|
|
|
|
</div>
|
2019-07-04 16:07:51 +00:00
|
|
|
|
2019-07-07 16:29:31 +00:00
|
|
|
<br>
|
|
|
|
<div id="leave_comment">
|
|
|
|
<h2>{% trans %}Leave comment{% endtrans %}</h2>
|
|
|
|
<div>
|
|
|
|
<form action="{{ url('pedagogy:uv_detail', uv_id=object.id) }}" method="post" enctype="multipart/form-data">
|
|
|
|
{% csrf_token %}
|
|
|
|
<div class="leave-comment-grid-container">
|
|
|
|
<div class="form-stars">
|
|
|
|
{{ form.author.errors }}
|
|
|
|
{{ form.uv.errors }}
|
|
|
|
|
|
|
|
{{ form.author }}
|
|
|
|
{{ form.uv }}
|
|
|
|
|
|
|
|
<div class="input-stars">
|
|
|
|
<label for="{{ form.grade_global.id_for_label }}">{{ form.grade_global.label }} :</label>
|
|
|
|
{{ form.grade_global.errors }}
|
|
|
|
{{ form.grade_global }}
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="input-stars">
|
|
|
|
<label for="{{ form.grade_utility.id_for_label }}">{{ form.grade_utility.label }} :</label>
|
|
|
|
{{ form.grade_utility.errors }}
|
|
|
|
{{ form.grade_utility }}
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="input-stars">
|
|
|
|
<label for="{{ form.grade_interest.id_for_label }}">{{ form.grade_interest.label }} :</label>
|
|
|
|
{{ form.grade_interest.errors }}
|
|
|
|
{{ form.grade_interest }}
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="input-stars">
|
|
|
|
<label for="{{ form.grade_teaching.id_for_label }}">{{ form.grade_teaching.label }} :</label>
|
|
|
|
{{ form.grade_teaching.errors }}
|
|
|
|
{{ form.grade_teaching }}
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="input-stars">
|
|
|
|
<label for="{{ form.grade_work_load.id_for_label }}">{{ form.grade_work_load.label }} :</label>
|
|
|
|
{{ form.grade_work_load.errors }}
|
|
|
|
{{ form.grade_work_load }}
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div class="form-comment">
|
|
|
|
<label for="{{ form.comment.id_for_label }}">{{ form.comment.label }} :</label>
|
|
|
|
{{ form.comment.errors }}
|
|
|
|
{{ form.comment }}
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<p><input type="submit" value="{% trans %}Comment{% endtrans %}" /></p>
|
|
|
|
</form>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<br>
|
|
|
|
|
2019-07-03 19:19:56 +00:00
|
|
|
{% if object.comments.exists() %}
|
|
|
|
<h2>{% trans %}Comments{% endtrans %}</h2>
|
2019-07-06 00:33:05 +00:00
|
|
|
{% for comment in object.comments.order_by("-publish_date").all() %}
|
2019-07-08 00:54:49 +00:00
|
|
|
<div id="{{ comment.id }}" class="comment-container">
|
|
|
|
|
2019-07-07 16:29:31 +00:00
|
|
|
<div class="grade-block">
|
2019-07-08 00:54:49 +00:00
|
|
|
<div class="grade-type">
|
2019-07-08 21:16:53 +00:00
|
|
|
<p>{% trans %}Global grade{% endtrans %}</p>
|
|
|
|
<p>{% trans %}Utility{% endtrans %}</p>
|
|
|
|
<p>{% trans %}Interest{% endtrans %}</p>
|
|
|
|
<p>{% trans %}Teaching{% endtrans %}</p>
|
|
|
|
<p>{% trans %}Work load{% endtrans %}</p>
|
2019-07-06 00:16:04 +00:00
|
|
|
</div>
|
2019-07-08 00:54:49 +00:00
|
|
|
<div class="grade-stars">
|
2019-07-06 00:16:04 +00:00
|
|
|
<p>{{ display_star(comment.grade_global) }}</p>
|
|
|
|
<p>{{ display_star(comment.grade_utility) }}</p>
|
|
|
|
<p>{{ display_star(comment.grade_interest) }}</p>
|
|
|
|
<p>{{ display_star(comment.grade_teaching) }}</p>
|
|
|
|
<p>{{ display_star(comment.grade_work_load) }}</p>
|
|
|
|
</div>
|
2019-07-09 12:43:46 +00:00
|
|
|
<div class="grade-extension"></div>
|
2019-07-03 19:19:56 +00:00
|
|
|
</div>
|
2019-07-06 00:30:47 +00:00
|
|
|
|
2019-07-08 00:54:49 +00:00
|
|
|
<div class="comment">
|
|
|
|
<div class="anchor">
|
|
|
|
<a href="{{ url('pedagogy:uv_detail', uv_id=uv.id) }}#{{ comment.id }}"><i class="fa fa-paragraph"></i></a>
|
|
|
|
</div>
|
|
|
|
{{ comment.comment|markdown }}
|
|
|
|
</div>
|
2019-07-06 00:30:47 +00:00
|
|
|
|
2019-07-06 00:16:04 +00:00
|
|
|
<div class="info">
|
2019-07-08 00:54:49 +00:00
|
|
|
{% if comment.is_reported %}
|
|
|
|
<p class="status-reported">
|
|
|
|
{% trans %}This comment has been reported{% endtrans %}
|
|
|
|
</p>
|
|
|
|
{% endif %}
|
|
|
|
|
|
|
|
{% if user.is_owner(comment) %}
|
|
|
|
<p class="actions">
|
|
|
|
<a href="{{ url('pedagogy:comment_update', comment_id=comment.id) }}">{% trans %}Edit{% endtrans %}</a>
|
|
|
|
<a href="{{ url('pedagogy:comment_delete', comment_id=comment.id) }}">{% trans %}Delete{% endtrans %}</a>
|
|
|
|
</p>
|
|
|
|
{% endif %}
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="comment-end-bar">
|
2019-07-09 14:03:47 +00:00
|
|
|
<div class="report"><p><a href="{{ url('pedagogy:comment_report', comment_id=comment.id) }}">{% trans %}Report this comment{% endtrans %}</a></p></div>
|
2019-07-08 00:54:49 +00:00
|
|
|
|
2019-07-09 14:03:47 +00:00
|
|
|
<div class="date"><p>{{ comment.publish_date.strftime('%d/%m/%Y') }}</p></div>
|
2019-07-08 00:54:49 +00:00
|
|
|
|
2019-07-08 21:16:53 +00:00
|
|
|
<div class="author"><p>{{ user_profile_link(comment.author) }}</p></div>
|
2019-07-06 00:16:04 +00:00
|
|
|
</div>
|
2019-07-03 19:19:56 +00:00
|
|
|
|
|
|
|
</div>
|
|
|
|
{% endfor %}
|
|
|
|
{% endif %}
|
|
|
|
|
|
|
|
</div>
|
2019-07-08 13:25:28 +00:00
|
|
|
</div>
|
|
|
|
|
|
|
|
<script type="text/javascript">
|
|
|
|
$("#return_noscript").hide();
|
|
|
|
$("#return_js").show();
|
|
|
|
var icons = {
|
|
|
|
header: "fa fa-toggle-right",
|
|
|
|
activeHeader: "fa fa-toggle-down"
|
|
|
|
};
|
|
|
|
$(function(){
|
|
|
|
$("#leave_comment").accordion({
|
|
|
|
icons: icons,
|
|
|
|
heightStyle: "content",
|
|
|
|
active: false,
|
|
|
|
collapsible: true
|
2019-07-07 16:29:31 +00:00
|
|
|
});
|
2019-07-08 13:25:28 +00:00
|
|
|
});
|
|
|
|
// Remove jquery-ui icons to make fontawesome work
|
|
|
|
$(document).ready(function(){
|
|
|
|
$(".ui-accordion-header-icon").first().removeClass("ui-icon");
|
|
|
|
});
|
|
|
|
</script>
|
2019-07-01 16:51:32 +00:00
|
|
|
{% endblock %}
|