Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix issue #1936 add auto search fill feature at pickup location box. #1976

Open
wants to merge 3 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
346 changes: 326 additions & 20 deletions index.html
Original file line number Diff line number Diff line change
Expand Up @@ -1337,62 +1337,117 @@ <h3>Local Guide Connection</h3>
});

</script>

<!-- Cab or Auto Booking -->
<img style="position: absolute;height: 450px;left: 1250px;z-index:10;top: 4200px;mix-blend-mode: multiply;"
src="img/BOOK-img.avif" alt="image">


<img style="position: absolute;height: 450px;left: 1250px;z-index:10;top: 4200px;mix-blend-mode: multiply;" src="img/BOOK-img.avif" alt="image">

<!-- <img style="position: absolute;height: 450px;left: 1250px;z-index:10;top: 4200px;mix-blend-mode: multiply;" -->
<!-- src="img/BOOK-img.avif" alt="image"> -->

<section id="cab-booking" class="cab-booking-section light-mode" style="border: 2px solid #FFFFFF;">
<div class="booking-container">
<h1 style="color: white; font-size: xx-large;">Book a Cab or Auto</h1>
<form action="/book-cab" method="POST">
<div class="form-group" style="display: flex; flex-wrap: wrap;">
<!-- <form action="/book-cab" method="POST"> -->

<!--Make sure the form has the autocomplete function switched off:-->
<div class="autocomplete-container">
<form autocomplete="off" action="/action_page.php" style="position: relative;">
<div class="autocomplete " >
<label for="pickup-location" style="font-size: 15px;"><strong>Pickup Location</strong></label>
<input id="myInput" type="text" name="myCountry" placeholder="Enter pickup location" >
</div>
<iframe src="https://www.google.com/maps/embed?pb=!1m16!1m12!1m3!1d2965.0824050173574!2d-93.63905729999999!3d41.998507000000004!2m3!1f0!2f0!3f0!3m2!1i1024!2i768!4f13.1!2m1!1sWebFilings%2C+University+Boulevard%2C+Ames%2C+IA!5e0!3m2!1sen!2sus!4v1390839289319" width="100%" height="60" frameborder="0" style="border:0"></iframe>
</form>
</div>
<div class="autocomplete-container">
<form autocomplete="off" action="/action_page.php" style="position: relative;">
<div class="autocomplete " >
<label for="pickup-location" style="font-size: 15px;"><strong>Drop Location</strong></label>
<input id="myInput" type="text" name="myCountry" placeholder="Enter drop location" >
</div>
<iframe src="https://www.google.com/maps/embed?pb=!1m16!1m12!1m3!1d2965.0824050173574!2d-93.63905729999999!3d41.998507000000004!2m3!1f0!2f0!3f0!3m2!1i1024!2i768!4f13.1!2m1!1sWebFilings%2C+University+Boulevard%2C+Ames%2C+IA!5e0!3m2!1sen!2sus!4v1390839289319" width="100%" height="60" frameborder="0" style="border:0"></iframe>
</form>
</div>



<!-- <div class="form-group" style="display: flex; flex-wrap: wrap;">
<label for="pickup-location" style="font-size: 15px;"><strong>Pickup Location</strong></label>
<input type="text" id="pickup-location" name="pickup-location" placeholder="Enter pickup location"
required />
<iframe
src="https://www.google.com/maps/embed?pb=!1m16!1m12!1m3!1d2965.0824050173574!2d-93.63905729999999!3d41.998507000000004!2m3!1f0!2f0!3f0!3m2!1i1024!2i768!4f13.1!2m1!1sWebFilings%2C+University+Boulevard%2C+Ames%2C+IA!5e0!3m2!1sen!2sus!4v1390839289319"
width="100%" height="60" frameborder="0" style="border:0"></iframe>

<input type="text" id="pickup-location" onkeyup="changeInput(this.value)" class="form-control form-control-lg search" name="pickup-location" placeholder="Enter pickup location" required style="padding-left: 12px;" />
<div id="result1" class="list-group" >
<iframe src="https://www.google.com/maps/embed?pb=!1m16!1m12!1m3!1d2965.0824050173574!2d-93.63905729999999!3d41.998507000000004!2m3!1f0!2f0!3f0!3m2!1i1024!2i768!4f13.1!2m1!1sWebFilings%2C+University+Boulevard%2C+Ames%2C+IA!5e0!3m2!1sen!2sus!4v1390839289319" width="100%" height="60" frameborder="0" style="border:0"></iframe>
</div>
<div class="form-group" style="display: flex; flex-wrap: wrap;">
<label for="drop-location" style="font-size: 15px;"><strong>Drop Location</strong></label>
<input type="text" id="drop-location" name="drop-location" placeholder="Enter drop location" required />
<iframe
src="https://www.google.com/maps/embed?pb=!1m16!1m12!1m3!1d2965.0824050173574!2d-93.63905729999999!3d41.998507000000004!2m3!1f0!2f0!3f0!3m2!1i1024!2i768!4f13.1!2m1!1sWebFilings%2C+University+Boulevard%2C+Ames%2C+IA!5e0!3m2!1sen!2sus!4v1390839289319"
width="100%" height="60" frameborder="0" style="border:0"></iframe>
</div>
<input type="text" id="drop-location" onkeyup="changeInput(this.value)" class="form-control form-control-lg search" name="drop-location" placeholder="Enter drop location" required style="padding-left: 12px;"/>
<div id="result2" class="list-group">
<iframe src="https://www.google.com/maps/embed?pb=!1m16!1m12!1m3!1d2965.0824050173574!2d-93.63905729999999!3d41.998507000000004!2m3!1f0!2f0!3f0!3m2!1i1024!2i768!4f13.1!2m1!1sWebFilings%2C+University+Boulevard%2C+Ames%2C+IA!5e0!3m2!1sen!2sus!4v1390839289319" width="100%" height="60" frameborder="0" style="border:0"></iframe>
</div> -->


<form action="/book-cab" method="POST" style="
margin-left: 40px;
display: flex;
justify-content: center;
align-items: flex-start;
flex-direction: column;
"
>

<div style="display: flex; align-items: center; margin-bottom: 20px; flex-wrap: wrap;">
<label style="font-size: 1.5em; margin-right: 35px;" for="vehicle-type">
<strong>Vehicle Type</strong>
</label>

<select
id="vehicle-type"
name="vehicle-type"
style="width: 150px; height: 35px; padding: 5px;"
required >
<option value="cab">Cab</option>
<option value="auto">Auto</option>
<option value = "Sharing cab">Sharing Cab</option>
<option value = "Sharing cab">Sharing Auto</option>
<option value = "Sharing cab">Bike</option>
<option value = "Sharing cab">Premium Bike</option>
</select>
</div>

<div class=" form-group" style="display: flex; flex-wrap: wrap; width: 100%;">
<label for="travel-date" style="font-size: 15px;"><strong>Travel Date</strong></label>
<input type="date" id="travel-date" name="travel-date" required min="" />
">

<div style="display: flex; align-items: center; margin-bottom: 20px; flex-wrap: wrap;">
<!-- <div style="display: flex; align-items: center; margin-bottom: 20px; flex-wrap: wrap;">
<label style="font-size: 1.5em; margin-right: 35px;" for="vehicle-type">
<strong>Vehicle Type</strong>
</label>
</label> -->

<select id="vehicle-type" name="vehicle-type" style="width: 150px; height: 35px; padding: 5px;" required>
<!-- <select id="vehicle-type" name="vehicle-type" style="width: 150px; height: 35px; padding: 5px;" required>
<option value="cab">Cab</option>
<option value="auto">Auto</option>
<option value="Sharing cab">Sharing Cab</option>
<option value="Sharing cab">Sharing Auto</option>
<option value="Sharing cab">Bike</option>
<option value="Sharing cab">Premium Bike</option>
</select>
</div>
</div> -->


<div class="form-group" style="display: flex; flex-wrap: wrap;">
<label for="travel-date" style="font-size: 15px;"><strong>Travel Date</strong></label>
<input type="date" id="travel-date" name="travel-date" required min="" />

<!--Logic To prevent the user from selecting an old date -->

</div>

<script>
const today = new Date().toISOString().split('T')[0];
document.getElementById('travel-date').setAttribute('min', today);
</script>
</script>

</div>
<div class="form-group" style="display: flex; flex-wrap: wrap;">
Expand Down Expand Up @@ -4111,8 +4166,259 @@ <h2>Exclusive Deals and Offers!</h2>
<script src="path/to/visitorCounter.js"></script>
<script src="./assets/css/visitors.css"></script>



<style>

body {

font-family: Arial, sans-serif;

}

/* Polls Popup Styles */
.popups {

display: none; /* Hidden by default */
position: fixed; /* Stay in place */
top: 50%; /* Center vertically */
left: 0; /* Position to the left */
transform: translateY(-50%); /* Adjust to center vertically */
width: 200px; /* Set fixed width of 200px */
height: 300px; /* Set fixed height of 300px */
justify-content: center; /* Center the popup */
z-index: 1000; /* Sit on top */
padding: 10px; /* Add padding inside the popup */

}

.popups-content {

background: linear-gradient(#0c5769, #5ac8e4);
padding: 10px; /* Adjusted padding for the smaller popup */
border-radius: 5px;
height: 100%; /* Ensure content fills the height */
display: flex;
flex-direction: column;
justify-content: space-between; /* Space between elements */
text-align: center;

margin-top: 75px;

}


/* Close Button Styles */
.close-btn {

position: absolute; /* Position it in the top-right corner */
top: 83px;
right: 10px;
background: transparent;
border: none;
font-size: 16px; /* Smaller size for the close button */
color: #ffffff;
cursor: pointer;
font-weight: bold;
padding: 0; /* Remove extra padding */
line-height: 1;
width: 20px; /* Set a fixed width */
height: 20px; /* Set a fixed height */
text-align: center; /* Ensure the X is centered */
transition: color 0.3s ease;

}

.close-btn:hover {

color: #f44336; /* Change color to red on hover */

}


.uppercase {

font-size: 12px; /* Reduced font size for compact layout */
color: #000000;
margin-bottom: 10px; /* Space between title and buttons */
line-height: 1.2; /* Adjust line height for better readability */

}

#pollOptions {

display: flex;
flex-direction: column; /* Stack buttons vertically */
align-items: center;
flex-grow: 1; /* Allow buttons to expand and fill space */
justify-content: space-between; /* Evenly space buttons */

}

.poll-button,
.vote-button {

display: block; /* Full width for buttons */
margin: 5px 0; /* Vertical margin between buttons */
padding: 6px 8px; /* Smaller padding to fit within the box */
border: none;
border-radius: 5px;
color: white;
cursor: pointer;
transition: background-color 0.3s;
width: 100%; /* Full width of the container */
font-size: 11px; /* Reduced font size */
text-align: center;

}

.poll-button {

background-color: rgba(16, 22, 26, .4); /* Green */

}

.poll-button:hover {

background-color: #095493; /* Darker green */

}

.poll-button.selected {

background-color: #095493; /* Blue for selected */

}

.vote-button {

background-color: #f44336; /* Red */

}

.vote-button:hover {

background-color: #d32f2f; /* Darker red */

}

#result {

margin-top: 10px;
color: #000000;
font-size: 8px; /* Smaller font size for result */
word-wrap: break-word;
text-align: center;
overflow: visible; /* Ensure result text is not clipped */
max-height: none; /* Remove max-height constraint */
height: auto; /* Allow the height to adjust based on content */

}

</style>
<!-- Poll Pop-up -->
<div class="popups" id="pollPopup">
<div class="popups-content">
<!-- Close Button -->
<button id="closeButton" class="close-btn">&times;</button>

<h2 class="uppercase">What is your main priority when choosing a hotel?</h2>
<div id="pollOptions">
<button class="poll-button" data-value="Price and discounts">Price and discounts</button>
<button class="poll-button" data-value="Location and accessibility">Location and accessibility</button>
<button class="poll-button" data-value="Amenities and services offered">Amenities and services offered</button>
</div>
<button id="voteButton" class="vote-button">Vote</button>
<p id="result"></p> <!-- Result display -->
</div>
</div>


<script>

// Check if the user has already voted in this session
const hasVoted = sessionStorage.getItem('hasVoted');


// Show the poll popup after a delay, only if the user hasn't voted
function checkAndDisplayPollPopup() {
if (!hasVoted) {
document.getElementById('pollPopup').style.display = 'flex'; // Show poll
}
}


// Set timeout for poll display
setTimeout(checkAndDisplayPollPopup, 10000);


// Manage user selections and votes
const pollButtons = document.querySelectorAll('.poll-button[data-value]');
let selectedValue = '';


// Handle clicks on poll buttons
pollButtons.forEach(button => {
button.addEventListener('click', function() {
pollButtons.forEach(btn => btn.classList.remove('selected')); // Clear previous selections
button.classList.add('selected'); // Highlight selected button
selectedValue = button.getAttribute('data-value'); // Store selected value
});
});


// Handle voting process
document.getElementById('voteButton').addEventListener('click', function() {
if (selectedValue) {
document.getElementById('result').innerHTML = `You voted for: ${selectedValue}<br>Thank you!`; // Show result
sessionStorage.setItem('hasVoted', 'true'); // Save voting status
setTimeout(() => {
document.getElementById('pollPopup').style.display = 'none'; // Hide poll
}, 2000);
} else {
alert("Please select an option!"); // Alert if no option is selected
}
});


// Function to manage button focus for accessibility
function handleFocus(event) {
event.target.style.border = '2px solid #0058ff'; // Optional highlight effect
}


// Attach focus event for accessibility improvement
pollButtons.forEach(button => {
button.addEventListener('focus', handleFocus);
});


// Function to remove focus style
function handleBlur(event) {
event.target.style.border = ''; // Remove highlight effect
}


// Attach blur event for accessibility improvement
pollButtons.forEach(button => {
button.addEventListener('blur', handleBlur);
});


// Log when the script has loaded
console.log("Poll script initialized and ready!");


// Close button functionality
document.getElementById('closeButton').addEventListener('click', function() {
document.getElementById('pollPopup').style.display = 'none'; // Hide poll
});

</script>
<script src="visi.js"></script>
<script src="script.js"></script>
<script src="map autofill.js"></script>


</body>
</html>
Loading