mirror of
https://github.com/nottinghamtec/PyRIGS.git
synced 2026-01-17 13:32:15 +00:00
239 lines
16 KiB
HTML
239 lines
16 KiB
HTML
{% extends request.is_ajax|yesno:'base_ajax.html,base_rigs.html' %}
|
|
{% load widget_tweaks %}
|
|
{% load static %}
|
|
{% load help_text from filters %}
|
|
{% load profile_by_index from filters %}
|
|
{% load button from filters %}
|
|
|
|
{% block css %}
|
|
{{ block.super }}
|
|
<link rel="stylesheet" href="{% static 'css/selects.css' %}"/>
|
|
{% endblock %}
|
|
|
|
{% block preload_js %}
|
|
{{ block.super }}
|
|
<script src="{% static 'js/selects.js' %}"></script>
|
|
{% endblock %}
|
|
|
|
{% block js %}
|
|
{{ block.super }}
|
|
<script src="{% static 'js/autocompleter.js' %}"></script>
|
|
<script src="{% static 'js/tooltip.js' %}"></script>
|
|
|
|
<script>
|
|
$(document).ready(function () {
|
|
$('button[data-action=add]').on('click', function (event) {
|
|
event.preventDefault();
|
|
let target = $($(this).attr('data-target'));
|
|
let newID = Number(target.attr('data-pk'));
|
|
let newRow = $($(this).attr('data-clone'))
|
|
.clone().attr('style', "")
|
|
.attr('id', function(i, val){
|
|
return val.split("_")[0] + '_' + newID;
|
|
})
|
|
.appendTo(target);
|
|
newRow.find('select,input').attr('name', function(i, val){
|
|
return val.split("_")[0] + '_' + newID;
|
|
})//Disabled is to prevent the hidden row being sent to the form
|
|
.removeAttr('disabled');
|
|
newRow.find('button[data-action=delete]').attr('data-id', newID);
|
|
newRow.find('select').addClass('selectpicker');
|
|
newRow.find('.selectpicker').selectpicker('refresh');
|
|
$(".selectpicker").each(function(){initPicker($(this))});
|
|
initDatetime();
|
|
$(target).attr('data-pk', newID - 1);
|
|
});
|
|
$(document).on('click', 'button[data-action=delete]', function(event) {
|
|
event.preventDefault();
|
|
$(this).closest('tr').remove();
|
|
});
|
|
//Somewhat rudimentary way of ensuring people fill in completely (if it hits the database validation the whole table row disappears when the page reloads...)
|
|
//the not is to avoid adding it to some of bootstrap-selects extra crap
|
|
$('#vehiclest,#crewmemberst').on('change', 'select,input', function () {
|
|
$(this).closest('tr').find("select,input").not(':input[type=search]').attr('required', 'true');
|
|
});
|
|
});
|
|
</script>
|
|
{% endblock %}
|
|
|
|
{% block content %}
|
|
<div class="col-12">
|
|
{% include 'form_errors.html' %}
|
|
{% if edit %}
|
|
<form role="form" method="POST" action="{% url 'ec_edit' pk=object.pk %}">
|
|
{% else %}
|
|
<form role="form" method="POST" action="{% url 'event_ec' pk=event.pk %}">
|
|
{% endif %}
|
|
<input type="hidden" name="{{ form.event.name }}" id="{{ form.event.id_for_label }}"
|
|
value="{{event.pk}}"/>
|
|
{% csrf_token %}
|
|
<div class="row">
|
|
<div class="col-12">
|
|
<div class="card">
|
|
<div class="card-header">Event Information</div>
|
|
<div class="card-body">
|
|
<dl class="row">
|
|
<dt class="col-4">Event Date</dt>
|
|
<dd class="col-8">{{ event.start_date}}{%if event.end_date %}-{{ event.end_date}}{%endif%}</dd>
|
|
<dt class="col-4">Event Name</dt>
|
|
<dd class="col-8">{{ event.name }}</dd>
|
|
<dt class="col-4">Client</dt>
|
|
<dd class="col-8">{{ event.person }}</dd>
|
|
<dt class="col-4">Event Size</dt>
|
|
<dd class="col-8">{% include 'partials/event_size.html' with object=event.riskassessment %}</dd>
|
|
</dl>
|
|
<div class="form-group form-row">
|
|
<label for="{{ form.date.id_for_label }}"
|
|
class="col-4 col-form-label">{{ form.date.label }}</label>
|
|
{% if not form.date.value %}
|
|
{% render_field form.date class+="form-control col-8" value=event.start_date %}
|
|
{% else %}
|
|
{% render_field form.date class+="form-control col-8" %}
|
|
{% endif %}
|
|
</div>
|
|
<div class="form-group form-row" id="{{ form.venue.id_for_label }}-group">
|
|
<label for="{{ form.venue.id_for_label }}"
|
|
class="col-4 col-form-label">{{ form.venue.label }}</label>
|
|
<select id="{{ form.venue.id_for_label }}" name="{{ form.venue.name }}" class="form-control selectpicker col-8" data-live-search="true" data-sourceurl="{% url 'api_secure' model='venue' %}">
|
|
{% if venue %}
|
|
<option value="{{venue.pk}}" selected="selected">{{ venue.name }}</option>
|
|
{% elif event.venue %}
|
|
<option value="{{event.venue.pk}}" selected="selected">{{ event.venue.name }}</option>
|
|
{% endif %}
|
|
</select>
|
|
</div>
|
|
<div class="form-group form-row" id="{{ form.power_mic.id_for_label }}-group">
|
|
<label for="{{ form.power_mic.id_for_label }}"
|
|
class="col-4 col-form-label">{{ form.power_mic.help_text }}</label>
|
|
<select id="{{ form.power_mic.id_for_label }}" name="{{ form.power_mic.name }}" class="form-control selectpicker col-8" data-live-search="true" data-sourceurl="{% url 'api_secure' model='profile' %}?fields=first_name,last_name,initials" required="true">
|
|
{% if power_mic %}
|
|
<option value="{{power_mic.pk}}" selected="selected">{{ power_mic.name }}</option>
|
|
{% elif event.riskassessment.power_mic %}
|
|
<option value="{{event.riskassessment.power_mic.pk}}" selected="selected">{{ event.riskassessment.power_mic.name }}</option>
|
|
{% endif %}
|
|
</select>
|
|
</div>
|
|
<p class="pt-3 font-weight-bold">List vehicles and their drivers</p>
|
|
<div class="table-responsive">
|
|
<table class="table table-sm">
|
|
<thead>
|
|
<tr>
|
|
<th scope="col">Vehicle</th>
|
|
<th scope="col">Driver</th>
|
|
<th scope="col"></th>
|
|
</tr>
|
|
</thead>
|
|
<tbody id="vehiclest" data-pk="-1">
|
|
<tr id="vehicles_new" style="display: none;">
|
|
<td><input type="text" class="form-control" name="vehicle_new" disabled="true"/></td>
|
|
<td><select data-container="body" class="form-control" data-live-search="true" data-sourceurl="{% url 'api_secure' model='profile' %}?fields=first_name,last_name,initials" name="driver_new" disabled="true"></select></td>
|
|
<td><button type="button" class="btn btn-danger btn-sm mt-1" data-action='delete' data-target='#vehicle'><span class="fas fa-times"></span></button></td>
|
|
</tr>
|
|
{% for i in object.vehicles.all %}
|
|
<tr id="vehicles_{{i.pk}}">
|
|
<td><input name="vehicle_{{i.pk}}" type="text" class="form-control" value="{{ i.vehicle }}"/></td>
|
|
<td>
|
|
<select data-container="body" name="driver_{{i.pk}}" class="form-control selectpicker" data-live-search="true" data-sourceurl="{% url 'api_secure' model='profile' %}?fields=first_name,last_name,initials">
|
|
{% if i.driver != '' %}
|
|
<option value="{{i.driver.pk}}" selected="selected">{{ i.driver.name }}</option>
|
|
{% endif %}
|
|
</select>
|
|
</td>
|
|
<td><button type="button" class="btn btn-danger btn-sm mt-1" data-id='{{i.pk}}' data-action='delete' data-target='#vehicle'><span class="fas fa-times"></span></button></td>
|
|
</tr>
|
|
{% endfor %}
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
<div class="text-right">
|
|
<button type="button" class="btn btn-secondary" id="vehicle-add" data-action='add' data-target='#vehiclest' data-clone='#vehicles_new'><span class="fas fa-plus"></span> Add Vehicle</button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="row my-3">
|
|
<div class="col-12">
|
|
<div class="card">
|
|
<div class="card-header">Safety Checks</div>
|
|
<div class="card-body">
|
|
{% include 'partials/checklist_checkbox.html' with formitem=form.safe_parking %}
|
|
{% include 'partials/checklist_checkbox.html' with formitem=form.safe_packing %}
|
|
{% include 'partials/checklist_checkbox.html' with formitem=form.exits %}
|
|
{% include 'partials/checklist_checkbox.html' with formitem=form.trip_hazard %}
|
|
{% include 'partials/checklist_checkbox.html' with formitem=form.warning_signs %}
|
|
{% include 'partials/checklist_checkbox.html' with formitem=form.ear_plugs %}
|
|
<div class="row pt-3">
|
|
<label class="col-5" for="{{ form.hs_location.id_for_label }}">{{ form.hs_location.help_text }}</label>
|
|
{% render_field form.hs_location class+="form-control col-7 col-md-4" %}
|
|
</div>
|
|
<div class="row pt-1">
|
|
<label class="col-5" for="{{ form.extinguishers_location.id_for_label }}">{{ form.extinguishers_location.help_text }}</label>
|
|
{% render_field form.extinguishers_location class+="form-control col-7 col-md-4" %}
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="row my-3">
|
|
<div class="col-12">
|
|
<div class="card">
|
|
<div class="card-header">Crew Record</div>
|
|
<div class="card-body">
|
|
<div class="table-responsive">
|
|
<table class="table table-sm">
|
|
<thead>
|
|
<tr>
|
|
<th scope="col">Person</th>
|
|
<th scope="col">Start Time</th>
|
|
<th scope="col">Role</th>
|
|
<th scope="col">End Time</th>
|
|
<th scope="col"></th>
|
|
</tr>
|
|
</thead>
|
|
<tbody id="crewmemberst" data-pk="-1">
|
|
<tr id="crew_new" style="display: none;">
|
|
<td>
|
|
<select name="crewmember_new" class="form-control" data-container="body" data-live-search="true" data-sourceurl="{% url 'api_secure' model='profile' %}?fields=first_name,last_name,initials" disabled="true"></select>
|
|
</td>
|
|
<td style="min-width: 15ch"><input name="start_new" type="datetime-local" class="form-control" value="{{ i.start }}" disabled=""/></td>
|
|
<td style="min-width: 15ch"><input name="role_new" type="text" class="form-control" value="{{ i.role }}" disabled="true"/></td>
|
|
<td style="min-width: 15ch"><input name="end_new" type="datetime-local" class="form-control" value="{{ i.end }}" disabled="true" /></td>
|
|
<td><button type="button" class="btn btn-danger btn-sm mt-1" data-id='{{crew.pk}}' data-action='delete' data-target='#crewmember'><span class="fas fa-times"></span></button></td>
|
|
</tr>
|
|
{% for crew in object.crew.all %}
|
|
<tr id="crew_{{crew.pk}}">
|
|
<td>
|
|
<select data-container="body" name="crewmember_{{crew.pk}}" class="form-control selectpicker" data-live-search="true" data-sourceurl="{% url 'api_secure' model='profile' %}?fields=first_name,last_name,initials">
|
|
{% if crew.crewmember != '' %}
|
|
<option value="{{crew.crewmember.pk}}" selected="selected">{{ crew.crewmember.name }}</option>
|
|
{% endif %}
|
|
</select>
|
|
</td>
|
|
<td><input name="start_{{crew.pk}}" type="datetime-local" class="form-control" value="{{ crew.start|date:'Y-m-d' }}T{{ crew.start|date:'H:i:s' }}"/></td>
|
|
<td><input name="role_{{crew.pk}}" type="text" class="form-control" value="{{ crew.role }}"/></td>
|
|
<td><input name="end_{{crew.pk}}" type="datetime-local" class="form-control" value="{{ crew.end|date:'Y-m-d' }}T{{ crew.end|date:'H:i:s' }}"/></td>
|
|
<td><button type="button" class="btn btn-danger btn-sm mt-1" data-id='{{crew.pk}}' data-action='delete' data-target='#crewmember'><span class="fas fa-times"></span></button></td>
|
|
</tr>
|
|
{% endfor %}
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
</div>
|
|
<div class="card-footer">
|
|
<div class="text-right">
|
|
<button type="button" class="btn btn-secondary" data-action='add' data-target='#crewmemberst' data-clone='#crew_new'><span class="fas fa-plus"></span> Add Crewmember</button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="row mt-3">
|
|
<div class="col-sm-12 text-right">
|
|
{% button 'submit' %}
|
|
</div>
|
|
</div>
|
|
</form>
|
|
</div>
|
|
{% endblock %}
|