mirror of
https://github.com/nottinghamtec/PyRIGS.git
synced 2026-01-17 05:22:16 +00:00
Work on event creation form
This commit is contained in:
@@ -104,6 +104,7 @@ class EventRA(generic.base.RedirectView):
|
|||||||
class EventCreate(generic.CreateView):
|
class EventCreate(generic.CreateView):
|
||||||
model = models.Event
|
model = models.Event
|
||||||
form_class = forms.EventForm
|
form_class = forms.EventForm
|
||||||
|
template_name = 'event_form.html'
|
||||||
|
|
||||||
def get_context_data(self, **kwargs):
|
def get_context_data(self, **kwargs):
|
||||||
context = super(EventCreate, self).get_context_data(**kwargs)
|
context = super(EventCreate, self).get_context_data(**kwargs)
|
||||||
|
|||||||
1
RIGS/static/js/asteroids.min.js
vendored
Normal file
1
RIGS/static/js/asteroids.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
1
RIGS/static/js/interaction.js
Normal file
1
RIGS/static/js/interaction.js
Normal file
@@ -0,0 +1 @@
|
|||||||
|
function setupItemTable(t){objectitems=JSON.parse(t),$.each(objectitems,(function(t,e){objectitems[t]=JSON.parse(e)})),newitem=-1}function nl2br(t,e){return(t+"").replace(/([^>\r\n]?)(\r\n|\n\r|\r|\n)/g,"$1"+(e||void 0===e?"<br />":"<br>")+"$2")}function escapeHtml(t){return $("<div/>").text(t).html()}function updatePrices(){var t=0;for(var e in objectitems){var i=objectitems[e].fields,a=i.cost*i.quantity;$("#item-"+e+" .sub-total").html(parseFloat(a).toFixed(2)).data("subtotal",a),t+=Number(a)}$("#sumtotal").text(parseFloat(t).toFixed(2));var o=t*Number($("#vat-rate").data("rate"));$("#vat").text(parseFloat(o).toFixed(2)),$("#total").text(parseFloat(t+o).toFixed(2))}$("#item-table").on("click",".item-delete",(function(){delete objectitems[$(this).data("pk")],$("#item-"+$(this).data("pk")).remove(),updatePrices()})),$("#item-table").on("click",".item-add",(function(){$("#item-form").data("pk",newitem),$("#item_name").val(""),$("#item_description").val(""),$("#item_quantity").val(""),$("#item_cost").val(""),$($(this).data("target")).modal("show")})),$("#item-table").on("click",".item-edit",(function(){var t=$(this).data("pk");$("#item-form").data("pk",t);var e=objectitems[t].fields;$("#item_name").val(e.name),$("#item_description").val(e.description),$("#item_quantity").val(e.quantity),$("#item_cost").val(e.cost),$($(this).data("target")).modal("show")})),$("body").on("submit","#item-form",(function(t){t.preventDefault();var e,i=$(this).data("pk");if($("#itemModal").modal("hide"),i==newitem--){(e=new Object).name=$("#item_name").val(),e.description=$("#item_description").val(),e.cost=$("#item_cost").val(),e.quantity=$("#item_quantity").val();var a=0;for(item in objectitems)a++;e.order=a,objectitems[i]=new Object,objectitems[i].fields=e,$("#new-item-row").clone().attr("id","item-"+i).data("pk",i).appendTo("#item-table-body"),$("#item-"+i+" .item-delete, #item-"+i+" .item-edit").data("pk",i)}else(e=objectitems[i].fields).name=$("#item_name").val(),e.description=$("#item_description").val(),e.cost=$("#item_cost").val(),e.quantity=$("#item_quantity").val(),objectitems[i].fields=e;$row=$("#item-"+i),$row.find(".name").html(escapeHtml(e.name)),$row.find(".description").html(nl2br(escapeHtml(e.description))),$row.find(".cost").html(parseFloat(e.cost).toFixed(2)),$row.find(".quantity").html(e.quantity),updatePrices()})),$("body").on("submit",".itemised_form",(function(t){$("#id_items_json").val(JSON.stringify(objectitems))}));var fixHelper=function(t,e){return e.children().each((function(){$(this).width($(this).width())})),e};$("#item-table tbody").sortable({helper:fixHelper,update:function(t,e){info=$(this).sortable("toArray"),itemorder=new Array,$.each(info,(function(t,e){pk=$("#"+e).data("pk"),objectitems[pk].fields.order=t}))}});
|
||||||
@@ -190,36 +190,31 @@
|
|||||||
<div class="pull-left">
|
<div class="pull-left">
|
||||||
<span id="calendar-header" class="h2"></span>
|
<span id="calendar-header" class="h2"></span>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="form-inline float-right btn-page my-3">
|
||||||
<div class="form-inline pull-right btn-page">
|
<div class="input-group mx-2">
|
||||||
<div class="input-group">
|
|
||||||
<input type="date" class="form-control" id="go-to-date-input" placeholder="Go to date...">
|
<input type="date" class="form-control" id="go-to-date-input" placeholder="Go to date...">
|
||||||
<span class="input-group-btn">
|
<span class="input-group-append">
|
||||||
<button class="btn btn-default" id="go-to-date-button" type="button" disabled>Go!</button>
|
<button class="btn btn-success" id="go-to-date-button" type="button" disabled>Go!</button>
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="btn-group mx-2">
|
||||||
<div class="btn-group">
|
|
||||||
<button type="button" class="btn btn-primary" id="today-button">Today</button>
|
<button type="button" class="btn btn-primary" id="today-button">Today</button>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="btn-group mx-2">
|
||||||
<div class="btn-group">
|
<button type="button" class="btn btn-secondary" id="prev-button"><span class="fas fa-chevron-left"></span></button>
|
||||||
<button type="button" class="btn btn-default" id="prev-button"><span class="fas fa-chevron-left"></span></button>
|
<button type="button" class="btn btn-secondary" id="next-button"><span class="fas fa-chevron-right"></span></button>
|
||||||
<button type="button" class="btn btn-default" id="next-button"><span class="fas fa-chevron-right"></span></button>
|
|
||||||
</div>
|
</div>
|
||||||
|
<div class="btn-group ml-2">
|
||||||
<div class="btn-group">
|
<button type="button" class="btn btn-light" id="month-button">Month</button>
|
||||||
<button type="button" class="btn btn-default" id="month-button">Month</button>
|
<button type="button" class="btn btn-light" id="week-button">Week</button>
|
||||||
<button type="button" class="btn btn-default" id="week-button">Week</button>
|
<button type="button" class="btn btn-light" id="day-button">Day</button>
|
||||||
<button type="button" class="btn btn-default" id="day-button">Day</button>
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-sm-12">
|
<div class="col-sm-12">
|
||||||
<div id='calendar'>
|
<div id='calendar'>
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
|
</div>
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
|||||||
@@ -1,12 +1,17 @@
|
|||||||
{% extends 'base_rigs.html' %}
|
{% extends 'base_rigs.html' %}
|
||||||
|
|
||||||
{% load widget_tweaks %}
|
{% load widget_tweaks %}
|
||||||
{% load static %}
|
{% load static %}
|
||||||
{% load multiply from filters %}
|
{% load multiply from filters %}
|
||||||
{% block title %}{% if object.pk %}Event {% if object.is_rig %}N{{ object.pk|stringformat:"05d" }}{% else %}
|
|
||||||
{{ object.pk }}{% endif %}{% else %}New Event{% endif %}{% endblock %}
|
{% block title %}
|
||||||
|
{% if object.pk %}
|
||||||
|
Event {% if object.is_rig %}N{{ object.pk|stringformat:"05d" }}{% else %}{{ object.pk }}{% endif %}
|
||||||
|
{% else %}New Event{% endif %}
|
||||||
|
{% endblock %}
|
||||||
|
|
||||||
{% block css %}
|
{% block css %}
|
||||||
<link rel="stylesheet" href="{% static "css/bootstrap-select.min.css" %}"/>
|
<link rel="stylesheet" href="{% static "css/bootstrap-select.css" %}"/>
|
||||||
<link rel="stylesheet" href="{% static "css/ajax-bootstrap-select.css" %}"/>
|
<link rel="stylesheet" href="{% static "css/ajax-bootstrap-select.css" %}"/>
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
|
||||||
@@ -16,12 +21,11 @@
|
|||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
|
||||||
{% block js %}
|
{% block js %}
|
||||||
<script src="//code.jquery.com/ui/1.10.4/jquery-ui.js"></script>
|
|
||||||
<script src="{% static "js/interaction.js" %}"></script>
|
<script src="{% static "js/interaction.js" %}"></script>
|
||||||
<script src="{% static "js/modal.js" %}"></script>
|
<script src="{% static "js/modal.js" %}"></script>
|
||||||
<script src="{% static "js/tooltip.js" %}"></script>
|
<script src="{% static "js/tooltip.js" %}"></script>
|
||||||
|
|
||||||
<script src="{% static "js/autocompleter.js" %}"></script>
|
<script src="{% static "js/autocomplete.js" %}"></script>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
function setTime23Hours() {
|
function setTime23Hours() {
|
||||||
@@ -76,7 +80,7 @@
|
|||||||
var input = document.createElement('input');
|
var input = document.createElement('input');
|
||||||
input.setAttribute('type','date');
|
input.setAttribute('type','date');
|
||||||
var notADateValue = 'not-a-date';
|
var notADateValue = 'not-a-date';
|
||||||
input.setAttribute('value', notADateValue);
|
input.setAttribute('value', notADateValue);
|
||||||
return !(input.value === notADateValue);
|
return !(input.value === notADateValue);
|
||||||
}
|
}
|
||||||
if(supportsDate()){
|
if(supportsDate()){
|
||||||
@@ -119,329 +123,69 @@
|
|||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
|
||||||
{% block content %}
|
{% block content %}
|
||||||
<form class="form-horizontal itemised_form" role="form" method="POST">{% csrf_token %}
|
{% include 'item_modal.html' %}
|
||||||
|
<form class="form-horizontal itemised_form" role="form" method="POST">
|
||||||
|
{% csrf_token %}
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="col-sm-12">
|
<div class="col-sm-12">
|
||||||
<div class="col-sm-8">
|
<h2>
|
||||||
<h2>
|
{% if duplicate %}
|
||||||
{% if duplicate %}
|
Duplicate of Event N{{ object.pk|stringformat:"05d" }}
|
||||||
Duplicate of Event N{{ object.pk|stringformat:"05d" }}
|
{% elif object.pk %}
|
||||||
{% elif object.pk %}
|
Event N{{ object.pk|stringformat:"05d" }}
|
||||||
Event N{{ object.pk|stringformat:"05d" }}
|
{% else %}
|
||||||
{% else %}
|
New Event
|
||||||
New Event
|
{% endif %}
|
||||||
{% endif %}
|
</h2>
|
||||||
</h2>
|
|
||||||
</div>
|
|
||||||
<div class="col-sm-4 text-right">
|
|
||||||
<div class="btn-group btn-page">
|
|
||||||
<button type="submit" class="btn btn-default" title="Save"><span
|
|
||||||
class="fas fa-save"></span></button>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
{% include 'form_errors.html' %}
|
||||||
{% include 'form_errors.html' %}
|
{% render_field form.is_rig style="display: none" %}
|
||||||
{% render_field form.is_rig style="display: none" %}
|
<input type="hidden" name="{{ form.items_json.name }}" id="{{ form.items_json.id_for_label }}"
|
||||||
<input type="hidden" name="{{ form.items_json.name }}" id="{{ form.items_json.id_for_label }}"
|
value="{{ form.items_json.value }}"/>
|
||||||
value="{{ form.items_json.value }}"/>
|
|
||||||
|
|
||||||
{# New rig buttons #}
|
{# New rig buttons #}
|
||||||
{% if not object.pk %}
|
{% if not object.pk %}
|
||||||
<div class="col-md-12 well">
|
<div class="col-md-12 card">
|
||||||
<div class="form-group" id="is_rig-selector">
|
<div class="card-body row no-gutters align-items-center" id="is_rig-selector">
|
||||||
<div class="col-sm-12">
|
<span class="col-6" data-toggle="tooltip"
|
||||||
<span class="col-sm-6" data-toggle="tooltip"
|
|
||||||
title="Anything that involves TEC kit, crew, or otherwise us providing a service to anyone.">
|
title="Anything that involves TEC kit, crew, or otherwise us providing a service to anyone.">
|
||||||
<button type="button" class="btn btn-primary col-xs-12" data-is_rig="1">Rig</button>
|
<button type="button" class="btn btn-primary w-75" data-is_rig="1">Rig</button>
|
||||||
</span>
|
</span>
|
||||||
<span class="col-sm-6" data-toggle="tooltip"
|
<span class="col-6" data-toggle="tooltip"
|
||||||
title="Things that aren't service-based, like training, meetings and site visits.">
|
title="Things that aren't service-based, like training, meetings and site visits.">
|
||||||
<button type="button" class="btn btn-info col-xs-12" data-is_rig="0">Non-Rig</button>
|
<button type="button" class="btn btn-info w-75" data-is_rig="0">Non-Rig</button>
|
||||||
</span>
|
</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
|
{# Contact details #}
|
||||||
|
{% include 'partials/contact_details_form.html' %}
|
||||||
|
|
||||||
|
{# Event details #}
|
||||||
|
{% include 'partials/event_details_form.html' %}
|
||||||
|
|
||||||
|
{# Notes and item shit #}
|
||||||
|
<div class="col-sm-12">
|
||||||
|
<div class="card card-default form-hws form-is_rig {% if object.pk and not object.is_rig %}hidden{% endif %}">
|
||||||
|
<div class="card-body">
|
||||||
|
<div class="col-sm-12">
|
||||||
|
<div class="form-group" data-toggle="tooltip" title="Notes on the event. This is only visible to keyholders, and is not displayed on the paperwork">
|
||||||
|
<label for="{{ form.notes.id_for_label }}">{{ form.notes.label }}</label>
|
||||||
|
{% render_field form.notes class+="form-control" %}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
{% include 'item_table.html' %}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
{% endif %}
|
<div class="col-sm-12 text-right form-hws form-is_rig {% if object.pk and not object.is_rig %}hidden{% endif %} my-3">
|
||||||
|
<div class="btn-group btn-page">
|
||||||
{# Contact details #}
|
<button type="submit" class="btn btn-primary" title="Save"><i
|
||||||
<div class="col-sm-12 col-md-6">
|
class="fas fa-save"></i> Save
|
||||||
<div class="card card-default form-hws form-is_rig {% if object.pk and not object.is_rig %}hidden{% endif %}">
|
</button>
|
||||||
<div class="card-header">Contact Details</div>
|
|
||||||
<div class="card-body">
|
|
||||||
<div class="form-group" data-toggle="tooltip" title="The main contact for the event, can be left blank if purely an organisation">
|
|
||||||
<label for="{{ form.person.id_for_label }}"
|
|
||||||
class="col-sm-4 control-label">{{ form.person.label }}</label>
|
|
||||||
|
|
||||||
<div class="col-sm-8">
|
|
||||||
<div class="row">
|
|
||||||
<div class="col-sm-9 col-md-7 col-lg-8">
|
|
||||||
<select id="{{ form.person.id_for_label }}" name="{{ form.person.name }}" class="form-control selectpicker" data-live-search="true" data-sourceurl="{% url 'api_secure' model='person' %}">
|
|
||||||
{% if person %}
|
|
||||||
<option value="{{form.person.value}}" selected="selected" data-update_url="{% url 'person_update' form.person.value %}">{{ person }}</option>
|
|
||||||
{% endif %}
|
|
||||||
</select>
|
|
||||||
</div>
|
|
||||||
<div class="col-sm-3 col-md-5 col-lg-4 align-right">
|
|
||||||
<div class="btn-group">
|
|
||||||
<a href="{% url 'person_create' %}" class="btn btn-default modal-href"
|
|
||||||
data-target="#{{ form.person.id_for_label }}">
|
|
||||||
<span class="fas fa-plus"></span>
|
|
||||||
</a>
|
|
||||||
<a href="{% if form.person.value %}{% url 'person_update' form.person.value %}{% endif %}" class="btn btn-default modal-href" id="{{ form.person.id_for_label }}-update" data-target="#{{ form.person.id_for_label }}">
|
|
||||||
<span class="fas fa-user-edit"></span>
|
|
||||||
</a>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="form-group" data-toggle="tooltip" title="The client organisation, leave blank if client is an individual">
|
|
||||||
<label for="{{ form.organisation.id_for_label }}"
|
|
||||||
class="col-sm-4 control-label">{{ form.organisation.label }}</label>
|
|
||||||
|
|
||||||
<div class="col-sm-8">
|
|
||||||
<div class="row">
|
|
||||||
<div class="col-sm-9 col-md-7 col-lg-8">
|
|
||||||
<select id="{{ form.organisation.id_for_label }}" name="{{ form.organisation.name }}" class="form-control selectpicker" data-live-search="true" data-sourceurl="{% url 'api_secure' model='organisation' %}" >
|
|
||||||
{% if organisation %}
|
|
||||||
<option value="{{form.organisation.value}}" selected="selected" data-update_url="{% url 'organisation_update' form.organisation.value %}">{{ organisation }}</option>
|
|
||||||
{% endif %}
|
|
||||||
</select>
|
|
||||||
</div>
|
|
||||||
<div class="col-sm-3 col-md-5 col-lg-4 align-right">
|
|
||||||
<div class="btn-group">
|
|
||||||
<a href="{% url 'organisation_create' %}" class="btn btn-default modal-href"
|
|
||||||
data-target="#{{ form.organisation.id_for_label }}">
|
|
||||||
<span class="fas fa-plus"></span>
|
|
||||||
</a>
|
|
||||||
<a href="{% if form.organisation.value %}{% url 'organisation_update' form.organisation.value %}{% endif %}" class="btn btn-default modal-href" id="{{ form.organisation.id_for_label }}-update" data-target="#{{ form.organisation.id_for_label }}">
|
|
||||||
<span class="fas fa-edit"></span>
|
|
||||||
</a>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="card card-default form-hws form-non_rig">
|
|
||||||
<div class="card-header">Event Description</div>
|
|
||||||
<div class="card-body">
|
|
||||||
<div class="form-group" data-toggle="tooltip" title="A short description of the event, shown on rigboard and on paperwork">
|
|
||||||
<label for="{{ form.description.id_for_label }}"
|
|
||||||
class="col-sm-4 control-label">{{ form.description.label }}</label>
|
|
||||||
|
|
||||||
<div class="col-sm-8">
|
|
||||||
{% render_field form.description class+="form-control" %}
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<!-- /.col-sm-12 .col-md-6 -->
|
</form>
|
||||||
|
|
||||||
{# Event details #}
|
|
||||||
<div class="col-sm-12 col-md-6">
|
|
||||||
<div class="card card-default form-hws form-non_rig">
|
|
||||||
<div class="card-header">Event Details</div>
|
|
||||||
<div class="card-body">
|
|
||||||
<div id="form-hws">
|
|
||||||
<div class="form-group" data-toggle="tooltip" title="Name of the event, displays on rigboard and on paperwork">
|
|
||||||
<label for="{{ form.name.id_for_label }}"
|
|
||||||
class="col-sm-4 control-label">{{ form.name.label }}</label>
|
|
||||||
|
|
||||||
<div class="col-sm-8">
|
|
||||||
{% render_field form.name class+="form-control" %}
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="form-group" data-toggle="tooltip" title="The venue for the rig, leave blank if unknown (e.g. for a dry hire)">
|
|
||||||
<label for="{{ form.venue.id_for_label }}"
|
|
||||||
class="col-sm-4 control-label">{{ form.venue.label }}</label>
|
|
||||||
|
|
||||||
<div class="col-sm-8">
|
|
||||||
<div class="row">
|
|
||||||
<div class="col-sm-9 col-md-7 col-lg-8">
|
|
||||||
<select id="{{ form.venue.id_for_label }}" name="{{ form.venue.name }}" class="form-control selectpicker" data-live-search="true" data-sourceurl="{% url 'api_secure' model='venue' %}">
|
|
||||||
{% if venue %}
|
|
||||||
<option value="{{form.venue.value}}" selected="selected" data-update_url="{% url 'venue_update' form.venue.value %}">{{ venue }}</option>
|
|
||||||
{% endif %}
|
|
||||||
</select>
|
|
||||||
</div>
|
|
||||||
<div class="col-sm-3 col-md-5 col-lg-4 align-right">
|
|
||||||
<div class="btn-group">
|
|
||||||
<a href="{% url 'venue_create' %}" class="btn btn-default modal-href"
|
|
||||||
data-target="#{{ form.venue.id_for_label }}">
|
|
||||||
<span class="fas fa-plus"></span>
|
|
||||||
</a>
|
|
||||||
<a href="{% if object.venue %}{% url 'venue_update' object.venue.pk %}{% endif %}" class="btn btn-default modal-href" id="{{ form.venue.id_for_label }}-update" data-target="#{{ form.venue.id_for_label }}">
|
|
||||||
<span class="fas fa-edit"></span>
|
|
||||||
</a>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="form-group">
|
|
||||||
<label for="{{ form.start_date.id_for_label }}"
|
|
||||||
class="col-sm-4 control-label">{{ form.start_date.label }}</label>
|
|
||||||
|
|
||||||
<div class="col-sm-8">
|
|
||||||
<div class="row">
|
|
||||||
<div class="col-sm-12 col-md-7" data-toggle="tooltip" title="Start date for event, required">
|
|
||||||
{% render_field form.start_date class+="form-control" %}
|
|
||||||
</div>
|
|
||||||
<div class="col-sm-12 col-md-5" data-toggle="tooltip" title="Start time of event, can be left blank">
|
|
||||||
{% render_field form.start_time class+="form-control" %}
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="form-group">
|
|
||||||
<label for="{{ form.end_date.id_for_label }}"
|
|
||||||
class="col-sm-4 control-label">{{ form.end_date.label }}</label>
|
|
||||||
|
|
||||||
<div class="col-sm-8">
|
|
||||||
<div class="row">
|
|
||||||
<div class="col-sm-12 col-md-7" data-toggle="tooltip" title="End date of event, leave blank if unknown or same as start date">
|
|
||||||
{% render_field form.end_date class+="form-control" %}
|
|
||||||
</div>
|
|
||||||
<div class="col-sm-12 col-md-5" data-toggle="tooltip" title="End time of event, leave blank if unknown">
|
|
||||||
{% render_field form.end_time class+="form-control" %}
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="row">
|
|
||||||
<div class="col-sm-12 col-md-offset-7 col-md-5">
|
|
||||||
<div class="btn-group btn-group-justified">
|
|
||||||
<btn class="btn btn-default btn-xs" onclick="setTime23Hours()">23:00</btn>
|
|
||||||
<btn class="btn btn-default btn-xs" onclick="setTime02Hours()">02:00</btn>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
{# Rig only information #}
|
|
||||||
<div class="form-is_rig {% if object.pk and not object.is_rig %}hidden{% endif %}">
|
|
||||||
<div class="form-group" data-toggle="tooltip" title="The date/time at which TEC have access to the venue">
|
|
||||||
<label for="{{ form.access_at.id_for_label }}"
|
|
||||||
class="col-sm-4 control-label">{{ form.access_at.label }}</label>
|
|
||||||
|
|
||||||
<div class="col-sm-8">
|
|
||||||
{% render_field form.access_at class+="form-control" %}
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="form-group" data-toggle="tooltip" title="The date/time at which crew should meet for this event">
|
|
||||||
<label for="{{ form.meet_at.id_for_label }}"
|
|
||||||
class="col-sm-4 control-label">{{ form.meet_at.label }}</label>
|
|
||||||
|
|
||||||
<div class="col-sm-8">
|
|
||||||
{% render_field form.meet_at class+="form-control" %}
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="form-group">
|
|
||||||
<div class="col-sm-offset-4 col-sm-8">
|
|
||||||
<div class="checkbox">
|
|
||||||
<label data-toggle="tooltip" title="Mark this event as a dry-hire, so it needs to be checked in at the end">
|
|
||||||
{% render_field form.dry_hire %}{{ form.dry_hire.label }}
|
|
||||||
</label>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
{# Status is needed on all events types and it looks good here in the form #}
|
|
||||||
<div class="form-group" data-toggle="tooltip" title="The current status of the event. Only mark as booked once paperwork is received">
|
|
||||||
<label for="{{ form.status.id_for_label }}"
|
|
||||||
class="col-sm-4 control-label">{{ form.status.label }}</label>
|
|
||||||
|
|
||||||
<div class="col-sm-8">
|
|
||||||
{% render_field form.status class+="form-control" %}
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="form-is_rig {% if object.pk and not object.is_rig %}hidden{% endif %}">
|
|
||||||
<div class="form-group" data-toggle="tooltip" title="The Member in Charge of this event">
|
|
||||||
<label for="{{ form.mic.id_for_label }}"
|
|
||||||
class="col-sm-4 control-label">{{ form.mic.label }}</label>
|
|
||||||
|
|
||||||
<div class="col-sm-8">
|
|
||||||
<select id="{{ form.mic.id_for_label }}" name="{{ form.mic.name }}" class="form-control selectpicker" data-live-search="true" data-sourceurl="{% url 'api_secure' model='profile' %}?fields=first_name,last_name,initials">
|
|
||||||
{% if mic %}
|
|
||||||
<option value="{{form.mic.value}}" selected="selected" >{{ mic.name }}</option>
|
|
||||||
{% endif %}
|
|
||||||
</select>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
{% if object.dry_hire %}
|
|
||||||
<div class="form-group" data-toggle="tooltip" title="The person who checked-in this dry hire">
|
|
||||||
<label for="{{ form.checked_in_by.id_for_label }}"
|
|
||||||
class="col-sm-4 control-label">{{ form.checked_in_by.label }}</label>
|
|
||||||
|
|
||||||
<div class="col-sm-8">
|
|
||||||
<select id="{{ form.checked_in_by.id_for_label }}" name="{{ form.checked_in_by.name }}" class="form-control selectpicker" data-live-search="true" data-sourceurl="{% url 'api_secure' model='profile' %}?fields=first_name,last_name,initials">
|
|
||||||
{% if checked_in_by %}
|
|
||||||
<option value="{{form.checked_in_by.value}}" selected="selected" >{{ checked_in_by.name }}</option>
|
|
||||||
{% endif %}
|
|
||||||
</select>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
{% endif %}
|
|
||||||
|
|
||||||
<div class="form-group" data-toggle="tooltip" title="The student ID of the client who collected the dry-hire">
|
|
||||||
<label for="{{ form.collector.id_for_label }}"
|
|
||||||
class="col-sm-4 control-label">{{ form.collector.label }}</label>
|
|
||||||
|
|
||||||
<div class="col-sm-8">
|
|
||||||
{% render_field form.collector class+="form-control" %}
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div class="form-group" data-toggle="tooltip" title="The purchase order number (for external clients)">
|
|
||||||
<label for="{{ form.purchase_order.id_for_label }}"
|
|
||||||
class="col-sm-4 control-label">{{ form.purchase_order.label }}</label>
|
|
||||||
|
|
||||||
<div class="col-sm-8">
|
|
||||||
{% render_field form.purchase_order class+="form-control" %}
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<!-- /.col-sm-12 .col-md-6 -->
|
|
||||||
<div class="col-sm-12 text-right">
|
|
||||||
<div class="btn-group btn-page">
|
|
||||||
<button type="submit" class="btn btn-default" title="Save"><span
|
|
||||||
class="fas fa-save"></span>
|
|
||||||
</button>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
{# Notes and item shit #}
|
|
||||||
<div class="col-sm-12">
|
|
||||||
<div class="card card-default form-hws form-is_rig {% if object.pk and not object.is_rig %}hidden{% endif %}">
|
|
||||||
<div class="card-body">
|
|
||||||
<div class="col-sm-12">
|
|
||||||
<div class="form-group" data-toggle="tooltip" title="Notes on the event. This is only visible to keyholders, and is not displayed on the paperwork">
|
|
||||||
<label for="{{ form.notes.id_for_label }}">{{ form.notes.label }}</label>
|
|
||||||
{% render_field form.notes class+="form-control" %}
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
{% include 'item_table.html' %}
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="col-sm-12 text-right form-hws form-is_rig {% if object.pk and not object.is_rig %}hidden{% endif %}">
|
|
||||||
<div class="btn-group btn-page">
|
|
||||||
<button type="submit" class="btn btn-default" title="Save"><span
|
|
||||||
class="fas fa-save"></span>
|
|
||||||
</button>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</form>
|
|
||||||
{% include 'item_modal.html' %}
|
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
|||||||
@@ -8,18 +8,6 @@
|
|||||||
<div class="col-sm-10">
|
<div class="col-sm-10">
|
||||||
<h3>Organisations</h3>
|
<h3>Organisations</h3>
|
||||||
</div>
|
</div>
|
||||||
<div class="col-sm-2">
|
|
||||||
<a href="{% url 'organisation_create' %}" class="btn btn-default pull-right">New <span
|
|
||||||
class="fas fa-plus"></span></a>
|
|
||||||
</div>
|
|
||||||
<div class="col-sm-3 col-sm-offset-9">
|
|
||||||
<form class="form form-horizontal col-sm-12">
|
|
||||||
<div class="form-group">
|
|
||||||
<input type="search" name="q" placeholder="Search" value="{{ request.GET.q }}"
|
|
||||||
class="form-control"/>
|
|
||||||
</div>
|
|
||||||
</form>
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
{% include 'partials/generic_list.html' with edit="organisation_update" detail="organisation_detail" union_account=True %}
|
{% include 'partials/generic_list.html' with edit="organisation_update" detail="organisation_detail" create="organisation_create" union_account=True %}
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
|||||||
74
RIGS/templates/partials/contact_details_form.html
Normal file
74
RIGS/templates/partials/contact_details_form.html
Normal file
@@ -0,0 +1,74 @@
|
|||||||
|
{% load widget_tweaks %}
|
||||||
|
<div class="col-md-6 my-3">
|
||||||
|
<div class="card form-hws form-is_rig {% if object.pk and not object.is_rig %}hidden{% endif %}">
|
||||||
|
<div class="card-header">Contact Details</div>
|
||||||
|
<div class="card-body">
|
||||||
|
<div class="form-group" data-toggle="tooltip" title="The main contact for the event, can be left blank if purely an organisation">
|
||||||
|
<label for="{{ form.person.id_for_label }}"
|
||||||
|
class="col-sm-4 control-label">{{ form.person.label }}</label>
|
||||||
|
<div class="col-sm-8">
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-sm-9 col-md-7 col-lg-8">
|
||||||
|
<select id="{{ form.person.id_for_label }}" name="{{ form.person.name }}" class="form-control selectpicker" data-live-search="true" data-sourceurl="{% url 'api_secure' model='person' %}">
|
||||||
|
{% if person %}
|
||||||
|
<option value="{{form.person.value}}" selected="selected" data-update_url="{% url 'person_update' form.person.value %}">{{ person }}</option>
|
||||||
|
{% endif %}
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
<div class="col-sm-3 col-md-5 col-lg-4 align-right">
|
||||||
|
<div class="btn-group">
|
||||||
|
<a href="{% url 'person_create' %}" class="btn btn-outline-success modal-href"
|
||||||
|
data-target="#{{ form.person.id_for_label }}">
|
||||||
|
<span class="fas fa-plus"></span>
|
||||||
|
</a>
|
||||||
|
<a href="{% if form.person.value %}{% url 'person_update' form.person.value %}{% endif %}" class="btn btn-outline-warning modal-href" id="{{ form.person.id_for_label }}-update" data-target="#{{ form.person.id_for_label }}">
|
||||||
|
<span class="fas fa-user-edit"></span>
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="form-group" data-toggle="tooltip" title="The client organisation, leave blank if client is an individual">
|
||||||
|
<label for="{{ form.organisation.id_for_label }}"
|
||||||
|
class="col-sm-4 control-label">{{ form.organisation.label }}</label>
|
||||||
|
|
||||||
|
<div class="col-sm-8">
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-sm-9 col-md-7 col-lg-8">
|
||||||
|
<select id="{{ form.organisation.id_for_label }}" name="{{ form.organisation.name }}" class="form-control selectpicker" data-live-search="true" data-sourceurl="{% url 'api_secure' model='organisation' %}" >
|
||||||
|
{% if organisation %}
|
||||||
|
<option value="{{form.organisation.value}}" selected="selected" data-update_url="{% url 'organisation_update' form.organisation.value %}">{{ organisation }}</option>
|
||||||
|
{% endif %}
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
<div class="col-sm-3 col-md-5 col-lg-4 align-right">
|
||||||
|
<div class="btn-group">
|
||||||
|
<a href="{% url 'organisation_create' %}" class="btn btn-outline-success modal-href"
|
||||||
|
data-target="#{{ form.organisation.id_for_label }}">
|
||||||
|
<span class="fas fa-plus"></span>
|
||||||
|
</a>
|
||||||
|
<a href="{% if form.organisation.value %}{% url 'organisation_update' form.organisation.value %}{% endif %}" class="btn btn-outline-warning modal-href" id="{{ form.organisation.id_for_label }}-update" data-target="#{{ form.organisation.id_for_label }}">
|
||||||
|
<span class="fas fa-edit"></span>
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="card form-hws form-non_rig my-3">
|
||||||
|
<div class="card-header">Event Description</div>
|
||||||
|
<div class="card-body">
|
||||||
|
<div class="form-group" data-toggle="tooltip" title="A short description of the event, shown on rigboard and on paperwork">
|
||||||
|
<label for="{{ form.description.id_for_label }}"
|
||||||
|
class="col-sm-4 control-label">{{ form.description.label }}</label>
|
||||||
|
|
||||||
|
<div class="col-sm-8">
|
||||||
|
{% render_field form.description class+="form-control" %}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
171
RIGS/templates/partials/event_details_form.html
Normal file
171
RIGS/templates/partials/event_details_form.html
Normal file
@@ -0,0 +1,171 @@
|
|||||||
|
{% load widget_tweaks %}
|
||||||
|
<div class="col-md-6 my-3">
|
||||||
|
<div class="card card-default form-hws form-non_rig">
|
||||||
|
<div class="card-header">Event Details</div>
|
||||||
|
<div class="card-body">
|
||||||
|
<div id="form-hws">
|
||||||
|
<div class="form-group" data-toggle="tooltip" title="Name of the event, displays on rigboard and on paperwork">
|
||||||
|
<label for="{{ form.name.id_for_label }}"
|
||||||
|
class="col-sm-4 control-label">{{ form.name.label }}</label>
|
||||||
|
|
||||||
|
<div class="col-sm-8">
|
||||||
|
{% render_field form.name class+="form-control" %}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="form-group" data-toggle="tooltip" title="The venue for the rig, leave blank if unknown (e.g. for a dry hire)">
|
||||||
|
<label for="{{ form.venue.id_for_label }}"
|
||||||
|
class="col-sm-4 control-label">{{ form.venue.label }}</label>
|
||||||
|
|
||||||
|
<div class="col-sm-8">
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-sm-9 col-md-7 col-lg-8">
|
||||||
|
<select id="{{ form.venue.id_for_label }}" name="{{ form.venue.name }}" class="form-control selectpicker" data-live-search="true" data-sourceurl="{% url 'api_secure' model='venue' %}">
|
||||||
|
{% if venue %}
|
||||||
|
<option value="{{form.venue.value}}" selected="selected" data-update_url="{% url 'venue_update' form.venue.value %}">{{ venue }}</option>
|
||||||
|
{% endif %}
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
<div class="col-sm-3 col-md-5 col-lg-4 align-right">
|
||||||
|
<div class="btn-group">
|
||||||
|
<a href="{% url 'venue_create' %}" class="btn btn-default modal-href"
|
||||||
|
data-target="#{{ form.venue.id_for_label }}">
|
||||||
|
<span class="fas fa-plus"></span>
|
||||||
|
</a>
|
||||||
|
<a href="{% if object.venue %}{% url 'venue_update' object.venue.pk %}{% endif %}" class="btn btn-default modal-href" id="{{ form.venue.id_for_label }}-update" data-target="#{{ form.venue.id_for_label }}">
|
||||||
|
<span class="fas fa-edit"></span>
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label for="{{ form.start_date.id_for_label }}"
|
||||||
|
class="col-sm-4 control-label">{{ form.start_date.label }}</label>
|
||||||
|
|
||||||
|
<div class="col-sm-8">
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-sm-12 col-md-7" data-toggle="tooltip" title="Start date for event, required">
|
||||||
|
{% render_field form.start_date class+="form-control" %}
|
||||||
|
</div>
|
||||||
|
<div class="col-sm-12 col-md-5" data-toggle="tooltip" title="Start time of event, can be left blank">
|
||||||
|
{% render_field form.start_time class+="form-control" %}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<label for="{{ form.end_date.id_for_label }}"
|
||||||
|
class="col-sm-4 control-label">{{ form.end_date.label }}</label>
|
||||||
|
|
||||||
|
<div class="col-sm-8">
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-sm-12 col-md-7" data-toggle="tooltip" title="End date of event, leave blank if unknown or same as start date">
|
||||||
|
{% render_field form.end_date class+="form-control" %}
|
||||||
|
</div>
|
||||||
|
<div class="col-sm-12 col-md-5" data-toggle="tooltip" title="End time of event, leave blank if unknown">
|
||||||
|
{% render_field form.end_time class+="form-control" %}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-sm-12 col-md-offset-7 col-md-5">
|
||||||
|
<div class="btn-group btn-group-justified">
|
||||||
|
<btn class="btn btn-default btn-xs" onclick="setTime23Hours()">23:00</btn>
|
||||||
|
<btn class="btn btn-default btn-xs" onclick="setTime02Hours()">02:00</btn>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{# Rig only information #}
|
||||||
|
<div class="form-is_rig {% if object.pk and not object.is_rig %}hidden{% endif %}">
|
||||||
|
<div class="form-group" data-toggle="tooltip" title="The date/time at which TEC have access to the venue">
|
||||||
|
<label for="{{ form.access_at.id_for_label }}"
|
||||||
|
class="col-sm-4 control-label">{{ form.access_at.label }}</label>
|
||||||
|
|
||||||
|
<div class="col-sm-8">
|
||||||
|
{% render_field form.access_at class+="form-control" %}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="form-group" data-toggle="tooltip" title="The date/time at which crew should meet for this event">
|
||||||
|
<label for="{{ form.meet_at.id_for_label }}"
|
||||||
|
class="col-sm-4 control-label">{{ form.meet_at.label }}</label>
|
||||||
|
|
||||||
|
<div class="col-sm-8">
|
||||||
|
{% render_field form.meet_at class+="form-control" %}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<div class="col-sm-offset-4 col-sm-8">
|
||||||
|
<div class="checkbox">
|
||||||
|
<label data-toggle="tooltip" title="Mark this event as a dry-hire, so it needs to be checked in at the end">
|
||||||
|
{% render_field form.dry_hire %}{{ form.dry_hire.label }}
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{# Status is needed on all events types and it looks good here in the form #}
|
||||||
|
<div class="form-group" data-toggle="tooltip" title="The current status of the event. Only mark as booked once paperwork is received">
|
||||||
|
<label for="{{ form.status.id_for_label }}"
|
||||||
|
class="col-sm-4 control-label">{{ form.status.label }}</label>
|
||||||
|
|
||||||
|
<div class="col-sm-8">
|
||||||
|
{% render_field form.status class+="form-control" %}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="form-is_rig {% if object.pk and not object.is_rig %}hidden{% endif %}">
|
||||||
|
<div class="form-group" data-toggle="tooltip" title="The Member in Charge of this event">
|
||||||
|
<label for="{{ form.mic.id_for_label }}"
|
||||||
|
class="col-sm-4 control-label">{{ form.mic.label }}</label>
|
||||||
|
|
||||||
|
<div class="col-sm-8">
|
||||||
|
<select id="{{ form.mic.id_for_label }}" name="{{ form.mic.name }}" class="form-control selectpicker" data-live-search="true" data-sourceurl="{% url 'api_secure' model='profile' %}?fields=first_name,last_name,initials">
|
||||||
|
{% if mic %}
|
||||||
|
<option value="{{form.mic.value}}" selected="selected" >{{ mic.name }}</option>
|
||||||
|
{% endif %}
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{% if object.dry_hire %}
|
||||||
|
<div class="form-group" data-toggle="tooltip" title="The person who checked-in this dry hire">
|
||||||
|
<label for="{{ form.checked_in_by.id_for_label }}"
|
||||||
|
class="col-sm-4 control-label">{{ form.checked_in_by.label }}</label>
|
||||||
|
|
||||||
|
<div class="col-sm-8">
|
||||||
|
<select id="{{ form.checked_in_by.id_for_label }}" name="{{ form.checked_in_by.name }}" class="form-control selectpicker" data-live-search="true" data-sourceurl="{% url 'api_secure' model='profile' %}?fields=first_name,last_name,initials">
|
||||||
|
{% if checked_in_by %}
|
||||||
|
<option value="{{form.checked_in_by.value}}" selected="selected" >{{ checked_in_by.name }}</option>
|
||||||
|
{% endif %}
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
|
<div class="form-group" data-toggle="tooltip" title="The student ID of the client who collected the dry-hire">
|
||||||
|
<label for="{{ form.collector.id_for_label }}"
|
||||||
|
class="col-sm-4 control-label">{{ form.collector.label }}</label>
|
||||||
|
|
||||||
|
<div class="col-sm-8">
|
||||||
|
{% render_field form.collector class+="form-control" %}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="form-group" data-toggle="tooltip" title="The purchase order number (for external clients)">
|
||||||
|
<label for="{{ form.purchase_order.id_for_label }}"
|
||||||
|
class="col-sm-4 control-label">{{ form.purchase_order.label }}</label>
|
||||||
|
|
||||||
|
<div class="col-sm-8">
|
||||||
|
{% render_field form.purchase_order class+="form-control" %}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
@@ -11,18 +11,6 @@
|
|||||||
<div class="col-sm-10">
|
<div class="col-sm-10">
|
||||||
<h3>Venues</h3>
|
<h3>Venues</h3>
|
||||||
</div>
|
</div>
|
||||||
<div class="col-sm-2">
|
|
||||||
<a href="{% url 'venue_create' %}" class="btn btn-default pull-right">New <span
|
|
||||||
class="fas fa-plus"></span></a>
|
|
||||||
</div>
|
|
||||||
<div class="col-sm-3 col-sm-offset-9">
|
|
||||||
<form class="form form-horizontal col-sm-12">
|
|
||||||
<div class="form-group">
|
|
||||||
<input type="search" name="q" placeholder="Search" value="{{ request.GET.q }}"
|
|
||||||
class="form-control"/>
|
|
||||||
</div>
|
|
||||||
</form>
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
{% include 'partials/generic_list.html' with edit="venue_update" detail="venue_detail" %}
|
{% include 'partials/generic_list.html' with edit="venue_update" detail="venue_detail" create="venue_create" %}
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
|||||||
@@ -78,7 +78,10 @@ urlpatterns = [
|
|||||||
permission_required_with_403('RIGS.view_event')(versioning.ActivityFeed.as_view()),
|
permission_required_with_403('RIGS.view_event')(versioning.ActivityFeed.as_view()),
|
||||||
name='activity_feed'),
|
name='activity_feed'),
|
||||||
|
|
||||||
path('event/<pk>/', has_oembed(oembed_view="event_oembed")(
|
path('event/create/',
|
||||||
|
permission_required_with_403('RIGS.add_event')(rigboard.EventCreate.as_view()),
|
||||||
|
name='event_create'),
|
||||||
|
path('event/<str:pk>/', has_oembed(oembed_view="event_oembed")(
|
||||||
rigboard.EventDetail.as_view()),
|
rigboard.EventDetail.as_view()),
|
||||||
name='event_detail'),
|
name='event_detail'),
|
||||||
url(r'^event/(?P<pk>\d+)/embed/$', xframe_options_exempt(
|
url(r'^event/(?P<pk>\d+)/embed/$', xframe_options_exempt(
|
||||||
@@ -93,9 +96,6 @@ urlpatterns = [
|
|||||||
url(r'^event/(?P<pk>\d+)/ra/$',
|
url(r'^event/(?P<pk>\d+)/ra/$',
|
||||||
permission_required_with_403('RIGS.change_event')(rigboard.EventRA.as_view()),
|
permission_required_with_403('RIGS.change_event')(rigboard.EventRA.as_view()),
|
||||||
name='event_ra'),
|
name='event_ra'),
|
||||||
url(r'^event/create/$',
|
|
||||||
permission_required_with_403('RIGS.add_event')(rigboard.EventCreate.as_view()),
|
|
||||||
name='event_create'),
|
|
||||||
url(r'^event/(?P<pk>\d+)/edit/$',
|
url(r'^event/(?P<pk>\d+)/edit/$',
|
||||||
permission_required_with_403('RIGS.change_event')(rigboard.EventUpdate.as_view()),
|
permission_required_with_403('RIGS.change_event')(rigboard.EventUpdate.as_view()),
|
||||||
name='event_update'),
|
name='event_update'),
|
||||||
|
|||||||
@@ -1,16 +0,0 @@
|
|||||||
{% load widget_tweaks %}
|
|
||||||
|
|
||||||
<!---TODO: Assign form-control class in here--->
|
|
||||||
<div class="form-group">
|
|
||||||
<label for="{{ field.id_for_label }}">{{ label|default:field.label }}</label>
|
|
||||||
{% if css %}
|
|
||||||
{% render_field field|add_class:css %}
|
|
||||||
{% elif disable_if_filled and field.value %}
|
|
||||||
{% render_field field|attr:'disabled' %}
|
|
||||||
{% elif css and disable_if_filled %}
|
|
||||||
{% render_field field|add_class:css|attr:'disabled' %}
|
|
||||||
{% else %}
|
|
||||||
{{ field }}
|
|
||||||
{% endif %}
|
|
||||||
<span class="helper-text" data-error="{{ field.errors.text }}"></span>
|
|
||||||
</div>
|
|
||||||
@@ -33,7 +33,7 @@ function styles(done) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function scripts() {
|
function scripts() {
|
||||||
return gulp.src(['RIGS/static/js/src/**/.js',
|
return gulp.src(['RIGS/static/js/src/**/*.js',
|
||||||
'node_modules/jquery/dist/jquery.js',
|
'node_modules/jquery/dist/jquery.js',
|
||||||
'node_modules/popper.js/dist/umd/popper.js',
|
'node_modules/popper.js/dist/umd/popper.js',
|
||||||
'node_modules/raven-js/dist/raven.js', //TODO Upgrade to Sentry
|
'node_modules/raven-js/dist/raven.js', //TODO Upgrade to Sentry
|
||||||
@@ -83,6 +83,5 @@ function watchFiles() {
|
|||||||
//gulp.watch("gulpfile.js", gulp.parallel(styles, scripts)); TODO This causes a reload loop
|
//gulp.watch("gulpfile.js", gulp.parallel(styles, scripts)); TODO This causes a reload loop
|
||||||
}
|
}
|
||||||
|
|
||||||
exports.css = styles;
|
exports.build = gulp.parallel(styles, scripts);
|
||||||
exports.js = scripts;
|
|
||||||
exports.watch = gulp.parallel(watchFiles, browserSync);
|
exports.watch = gulp.parallel(watchFiles, browserSync);
|
||||||
|
|||||||
Reference in New Issue
Block a user