1 {% extends "base.html" %}
3 <h2>Bookings I Own</h2>
5 {% for booking in bookings %}
6 <div class="col-12 col-md-6 col-lg-4 col-xl-3 mb-3">
7 <div class="card h-100">
8 <div class="card-header">
9 <h3>Booking {{booking.id}}</h3>
11 <ul class="list-group list-group-flush h-100">
12 <li class="list-group-item">id: {{booking.id}}</li>
13 <li class="list-group-item">lab: {{booking.lab}}</li>
14 <li class="list-group-item">resource: {{booking.resource.template.name}}</li>
15 <li class="list-group-item">start: {{booking.start}}</li>
16 <li class="list-group-item">end: {{booking.end}}</li>
17 <li class="list-group-item">purpose: {{booking.purpose}}</li>
19 <div class="card-footer d-flex">
20 <a class="btn btn-primary ml-auto mr-2" href="/booking/detail/{{booking.id}}/">Details</a>
22 class="btn btn-danger"
23 onclick='cancel_booking({{booking.id}});'
25 data-target="#resModal"
32 <p>You don't have any bookings. You can create a booking by booking a pod.</p>
37 <h2>Bookings I Collaborate On</h2>
40 {% for booking in collab_bookings %}
41 <div class="col-12 col-md-6 col-lg-4 col-xl-3 mb-3">
42 <div class="card h-100">
43 <div class="card-header">
44 <h3>Booking {{booking.id}}</h3>
46 <ul class="list-group list-group-flush h-100">
47 <li class="list-group-item">id: {{booking.id}}</li>
48 <li class="list-group-item">lab: {{booking.lab}}</li>
49 <li class="list-group-item">resource: {{booking.resource.template.name}}</li>
50 <li class="list-group-item">start: {{booking.start}}</li>
51 <li class="list-group-item">end: {{booking.end}}</li>
52 <li class="list-group-item">purpose: {{booking.purpose}}</li>
54 <div class="card-footer d-flex">
55 <a class="btn btn-primary ml-auto" href="/booking/detail/{{booking.id}}/">Details</a>
61 <p>There are no collaborative bookings.</p>
66 <a href="#expired_bookings" data-toggle="collapse" class="h2 discrete-a">
68 <i class="fas fa-angle-down rotate"></i>
70 <div id="expired_bookings" class="row collapse">
71 {% for booking in expired_bookings %}
72 <div class="col-12 col-md-6 col-lg-4 col-xl-3 mb-3">
73 <div class="card h-100">
74 <div class="card-header">
75 <h3>Booking {{booking.id}}</h3>
77 <ul class="list-group list-group-flush h-100">
78 <li class="list-group-item">id: {{booking.id}}</li>
79 <li class="list-group-item">lab: {{booking.lab}}</li>
80 <li class="list-group-item">resource: {{booking.resource.template.name}}</li>
81 <li class="list-group-item">start: {{booking.start}}</li>
82 <li class="list-group-item">end: {{booking.end}}</li>
83 <li class="list-group-item">purpose: {{booking.purpose}}</li>
84 <li class="list-group-item">owner: {{booking.owner.userprofile.email_addr}}</li>
86 <div class="card-footer d-flex">
87 <a class="btn btn-primary ml-auto" href="/booking/detail/{{booking.id}}/">Details</a>
93 <p>There are no expired bookings.</p>
99 var current_booking_id = -1;
100 function cancel_booking(booking_id) {
101 current_booking_id = booking_id;
104 function submit_cancel_form() {
105 var ajaxForm = $("#booking_cancel_form");
106 var formData = ajaxForm.serialize();
107 req = new XMLHttpRequest();
108 var url = "cancel/" + current_booking_id;
109 req.open("POST", url, true);
110 req.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
111 req.onerror = function() { alert("problem submitting form"); }
116 <div class="modal fade" id="resModal" tabindex="-1" role="dialog" aria-hidden="true">
117 <div class="modal-dialog" role="document">
118 <div class="modal-content">
119 <div class="modal-header">
120 <h4 class="modal-title d-inline float-left">Cancel Booking?</h4>
121 <button type="button" class="close" data-dismiss="modal" aria-label="Close">
122 <span aria-hidden="true">×</span>
125 <form id="booking_cancel_form">
128 <div class="modal-footer d-flex flex-column">
129 <p>Everything on your machine(s) will be lost</p>
131 <button type="button" class="btn btn-outline-secondary" data-dismiss="modal">Close</button>
132 <button type="button" class="btn btn-danger" data-toggle="collapse" data-target="#warning">Cancel Booking</button>
134 <div class="collapse w-100 text-center border-top" id="warning">
136 <h3>Are You Sure?</h3>
137 <p>This cannot be undone</p>
138 <button class="btn btn-outline-secondary" data-dismiss="modal">Nevermind</button>
139 <button class="btn btn-danger" id="confirm_cancel_button" data-dismiss="modal" onclick="submit_cancel_form();">I'm Sure</button>