-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrooms.php
executable file
·182 lines (145 loc) · 7.14 KB
/
rooms.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>FERN Hotel - Rooms</title>
<?php require('inc/links.php') ?>
</head>
<body class="bg-light">
<?php
require('inc/header.php');
$checkin_default = '';
$checkout_default = '';
$adult_default = '';
$children_default = '';
if (isset($_GET['check_availability'])) {
$frm_data = filteration($_GET);
// Check if each key exists before accessing it
$checkin_default = isset($frm_data['checkin']) ? $frm_data['checkin'] : '';
$checkout_default = isset($frm_data['checkout']) ? $frm_data['checkout'] : '';
$adult_default = isset($frm_data['adult']) ? $frm_data['adult'] : '';
$children_default = isset($frm_data['children']) ? $frm_data['children'] : '';
}
?>
<div class="my-5 px-4">
<h2 class="fw-bold h-font text-center">OUR ROOMS</h2>
<div class="h-line bg-dark"></div>
</div>
<div class="container-fluid">
<div class="row">
<div class="col-lg-3 col-md-12 mb-4 mb-lg-0 ps-4">
<nav class="navbar navbar-expand-lg navbar-light bg-white rounded shadow">
<div class="container-fluid flex-lg-column align-items-stretch">
<h4 class="mt-2 h-font">FILTERS</h4>
<button class="navbar-toggler shadow-none" type="button" data-bs-toggle="collapse"
data-bs-target="#filterDropdown" aria-controls="navbarNav" aria-expanded="false"
aria-label="Toggle navigation">
<span class="navbar-toggler-icon"></span>
</button>
<div class="collapse navbar-collapse flex-column mt-2 align-items-stretch mx-2"
id="filterDropdown">
<div class="border bg-light p-3 rounded mb-3">
<h5 class="mb-3 h-font d-flex justify-content-between align-items-center"
style="font-size: 18px;">
<span>CHECK AVAILABILITY</span>
<button id="chk_avail_btn" onclick="chk_chk_avail_clear()"
class="btn shadow-none btn-sm text-secondary d-none">Reset</button>
</h5>
<label for="form-label">Check-in</label>
<input type="date" class="form-control shadow-none mb-3" id="checkin"
onchange="chk_avail_filter()" value="<?php echo $checkin_default ?>">
<label for="form-label">Check-out</label>
<input type="date" class="form-control shadow-none" id="checkout"
onchange="chk_avail_filter()" value="<?php echo $checkout_default ?>">
</div>
<div class="border bg-light p-3 rounded mb-3">
<h5 class="mb-3 h-font d-flex justify-content-between align-items-center"
style="font-size: 18px;">
<span>GUESTS</span>
<button id="guests_btn" onclick="guests_clear()"
class="btn shadow-none btn-sm text-secondary d-none">Reset</button>
</h5>
<div class="d-flex">
<div class="me-3">
<label for="form-label">Adults</label>
<input type="number" onchange="guests_filter()" id="adults"
class="form-control shadow-none mb-3" value="<?php echo $adult_default ?>">
</div>
<div>
<label for="form-label">Childern</label>
<input type="number" onchange="guests_filter()" id="children"
class="form-control shadow-none mb-3"
value="<?php echo $children_default ?>">
</div>
</div>
</div>
</div>
</div>
</nav>
</div>
<div class="col-lg-9 col-md-12 px-4" id="rooms-data">
</div>
</div>
</div>
<script>
let rooms_data = document.getElementById('rooms-data');
let checkin = document.getElementById('checkin');
let checkout = document.getElementById('checkout');
let chk_avail_btn = document.getElementById('chk_avail_btn');
let adults = document.getElementById('adults');
let children = document.getElementById('children');
let guests_btn = document.getElementById('guests_btn');
function fetch_rooms() {
let chk_avail = JSON.stringify({
checkin: checkin.value,
checkout: checkout.value
});
let guests = JSON.stringify({
adults: adults.value,
children: children.value
});
let xhr = new XMLHttpRequest();
xhr.open("GET", "ajax/rooms.php?fetch_rooms&chk_avail=" + chk_avail + "&guests=" + guests, true);
xhr.onprogress = function () {
rooms_data.innerHTML = `<div class="spinner-border d-block text-info mb-3 mx-auto" id="loader"><span class="visually-hidden">Loading...</span></div>`;
};
xhr.onload = function () {
rooms_data.innerHTML = this.responseText;
};
xhr.onerror = function () {
console.error("Request failed.");
};
xhr.send();
}
function chk_avail_filter() {
if (checkin.value != '' && checkout.value != '') {
chk_avail_btn.classList.remove('d-none')
fetch_rooms();
}
}
function chk_avail_clear() {
checkin.value = '';
checkout.value = ''
chk_avail_btn.classList.add('d-none')
fetch_rooms();
}
function guests_filter() {
if (adults.value > 0 || children.value > 0) {
guests_btn.classList.remove('d-none')
fetch_rooms();
}
}
function guests_clear() {
adults.value = '';
children.value = ''
guests_btn.classList.add('d-none')
fetch_rooms();
}
window.onload = function () {
fetch_rooms();
}
</script>
<?php require('inc/footer.php'); ?>
</body>
</html>