150 lines
		
	
	
	
		
			5.3 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			150 lines
		
	
	
	
		
			5.3 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| {% extends "base.html" %}
 | |
| {% load static %}
 | |
| {% load deadliny %}
 | |
| 
 | |
| {% block content %}
 | |
| 
 | |
| {# FIXME: Necopypastovat! Tohle je zkopírované ze static/odevzdavatko/dynamic_formsets.js #}
 | |
| <script type='text/javascript'>
 | |
| // Credit https://medium.com/all-about-django/adding-forms-dynamically-to-a-django-formset-375f1090c2b0
 | |
| function updateElementIndex(el, prefix, ndx) {
 | |
| 	var id_regex = new RegExp('(' + prefix + '-\\d+)');
 | |
| 	var replacement = prefix + '-' + ndx;
 | |
| 	if ($(el).attr("for")) {
 | |
| 		$(el).attr("for", $(el).attr("for").replace(id_regex, replacement));
 | |
| 	}
 | |
| 	if (el.id) {
 | |
| 		el.id = el.id.replace(id_regex, replacement);
 | |
| 	}
 | |
| 	if (el.name) {
 | |
| 		el.name = el.name.replace(id_regex, replacement);
 | |
| 	}
 | |
| }
 | |
| 
 | |
| // Credit https://medium.com/all-about-django/adding-forms-dynamically-to-a-django-formset-375f1090c2b0
 | |
| function deleteForm(prefix, btn) {
 | |
|     var total = parseInt($('#id_' + prefix + '-TOTAL_FORMS').val());
 | |
|     if (total >= 1){
 | |
|         btn.closest('tr').remove();
 | |
|         var forms = $('.hodnoceni');
 | |
|         var formCount = forms.length - 1; // There is one extra such form hidden as template!
 | |
|         $('#id_' + prefix + '-TOTAL_FORMS').val(formCount);
 | |
|         for (var i=0; i<formCount; i++) {
 | |
|             $(forms.get(i)).find(':input').each(function() {
 | |
|                 updateElementIndex(this, prefix, i);
 | |
|             });
 | |
|         }
 | |
|     }
 | |
|     return false;
 | |
| }
 | |
| 
 | |
| // Credit: https://simpleit.rocks/python/django/dynamic-add-form-with-add-button-in-django-modelformset-template/
 | |
| $(document).ready(function(){
 | |
| 	$('#pridat_hodnoceni').click(function() {
 | |
| 		var form_idx = $('#id_form-TOTAL_FORMS').val();
 | |
| 		var new_form = $('#empty_form').html().replace(/__prefix__/g, form_idx);
 | |
| 		$('#form_set').append(new_form);
 | |
| 		// Newly created form has not the binding between remove button and remove function
 | |
| 		// We need to add it manually
 | |
| 		$('.smazat_hodnoceni').click(function(){
 | |
| 			deleteForm("form",this);
 | |
| 		});
 | |
| 		$('#id_form-TOTAL_FORMS').val(parseInt(form_idx) + 1);
 | |
| 	});
 | |
| 	$('.smazat_hodnoceni').click(function(){
 | |
| 		deleteForm("form",this);
 | |
| 	});
 | |
| });
 | |
| </script>
 | |
| 
 | |
| 
 | |
| <p>Řešené problémy: {{ object.problem.all | join:", " }}</p>
 | |
| 
 | |
| <p>Řešitelé: {% for r in object.resitele.all %} {{ r }} (<a href="mailto:{{ r.osoba.email }}?subject={{ "Oprava řešení M&M " | urlencode }}{{ object.problem.all.0.hlavni_problem | urlencode }}">{{ r.osoba.email }}</a>)
 | |
| {% if forloop.revcounter0 != 0 %}, {% endif %} {% endfor %}</p>
 | |
| 
 | |
| {# https://docs.djangoproject.com/en/3.1/ref/models/instances/#django.db.models.Model.get_FOO_display #}
 | |
| <p>Forma: {{ object.get_forma_display }}</p>
 | |
| 
 | |
| <p>Doručeno {{ object.cas_doruceni }}, deadline: {{object.cas_doruceni | deadline_html }}</p>
 | |
| 
 | |
| {# Soubory: #}
 | |
| <h3>Přílohy:</h3>
 | |
| {% if object.prilohy.all %}
 | |
| <table class="dosla_reseni">
 | |
| <tr><th>Soubor</th><th>Řešitelova poznámka</th><th>Datum</th></tr>
 | |
| {% for priloha in object.prilohy.all %}
 | |
| <tr>
 | |
| 	<td><a href="{{ priloha.soubor.url }}" download>{{ priloha.split | last }}</a></td>
 | |
| 	<td>{{ priloha.res_poznamka }}</td>
 | |
| 	<td>{{ priloha.vytvoreno }}</td></tr>
 | |
| 	{# TODO: Orgo-poznámka, ideálně jako formulář #}
 | |
| {% endfor %}
 | |
| </table>
 | |
| {% else %}
 | |
| <p>Žádné přílohy</p>
 | |
| {% endif %}
 | |
| 
 | |
| <form method=post onsubmit="return zkontroluj_hodnoceni();">
 | |
| {# Poznámka #}
 | |
| <h3>Poznámka:</h3>
 | |
| <p>{{ poznamka_form.poznamka }}</p>
 | |
| 
 | |
| {# Hodnocení: #}
 | |
| <h3>Hodnocení:</h3>
 | |
| <table>
 | |
| {% csrf_token %}
 | |
| {{ form.management_form }}
 | |
| </table>
 | |
| <table id="form_set">
 | |
| <tr><th>Problém</th><th>Body</th><th>Deadline pro body</th></tr>
 | |
| {% for subform in form %}
 | |
|     <tbody>
 | |
| 	<tr class="hodnoceni">
 | |
| 		<td>{{ subform.problem }}</td>
 | |
| 		<td>{{ subform.body }}</td>
 | |
| 		<td>{{ subform.deadline_body }}</td>
 | |
| 		<td><a href="#" class="smazat_hodnoceni" id="id_{{subform.prefix}}-jsremove"><img src="{% static "odevzdavatko/cross.png" %}" alt="Smazat"></a></td>
 | |
| 	</tr>
 | |
|     </tbody>
 | |
| {% endfor %}
 | |
| </table>
 | |
| 
 | |
| 
 | |
| <a href="#"> <img src="{% static "odevzdavatko/plus.png" %}" id="pridat_hodnoceni" alt="Přidat hodnocení"></a> </br>
 | |
| <input type=submit value="Uložit"></form>
 | |
| 
 | |
| <table id="empty_form" style="display: none;">
 | |
| 	<tr class="hodnoceni">
 | |
| 		<td>{{ form.empty_form.problem }}</td>
 | |
| 		<td>{{ form.empty_form.body }}</td>
 | |
| 		<td>{{ form.empty_form.deadline_body }}</td>
 | |
| 		<td><a href="#" class="smazat_hodnoceni" id="id_{{form.empty_form.prefix}}-jsremove"><img src="{% static "odevzdavatko/cross.png" %}" alt="Smazat"></a></td>
 | |
| 	</tr>
 | |
| </table>
 | |
| 
 | |
| 
 | |
| <script type="text/javascript">
 | |
|     function zkontroluj_hodnoceni() {
 | |
|         const pocet = $('.hodnoceni').length;
 | |
|         if (pocet === 1) { {# vydím pouze plusko #}
 | |
|             const vysledek = confirm("Odstranil jsi všechny problémy tohoto řešení. Nepůjde tedy dohledat přes problémy, co řeší, tj. například v došlých řešeních. Přesto odeslat?");
 | |
|             if (!vysledek) {
 | |
|                 event.preventDefault();
 | |
|                 return false;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         function problem_is_empty(elem, index, array) {return elem.firstElementChild.children.length !== 1 && elem.firstElementChild.children[1].textContent === "";}
 | |
| 
 | |
|         if ($('.hodnoceni').toArray().some(problem_is_empty)) {
 | |
|             alert("Neuloženo! Nezadal jsi problém, ke kterému posíláš hodnocení. Pokud je toto hodnocení navíc, smaž ho prosím křížkem a znovu odešli.")
 | |
|             event.preventDefault()
 | |
|             return false;
 | |
|         }
 | |
| 
 | |
|         return true;
 | |
|     }
 | |
| </script>
 | |
| 
 | |
| {% endblock %}
 |