gallowelds.com/themes/gallo/layouts/partials/rental_catalog.html

315 lines
11 KiB
HTML
Raw Normal View History

<div
2024-07-13 21:11:57 -04:00
class="px-1 py-2 flex flex-row gap-2 max-w-full overflow-x-auto whitespace-nowrap"
>
2024-06-09 01:12:33 -04:00
<button
id="all"
2024-07-13 21:11:57 -04:00
class="flex gap-2 items-center px-4 border border-gray-200 rounded-lg focus:outline-none focus:ring"
2024-06-09 01:12:33 -04:00
onclick="window.location.href = '/catalog'"
>
2024-06-09 22:12:59 -04:00
<span class="text-xs p-2 font-medium text-gray-900">All</span>
2024-06-09 01:12:33 -04:00
</button>
{{ $uniqueCategories := slice }} {{ range .Params.catalog }} {{ if not (in
$uniqueCategories .cat) }} {{ $uniqueCategories = $uniqueCategories | append
.cat }}
<div
class="flex gap-2 items-center px-3 py-2 border border-gray-200 rounded-lg"
>
<input
id="radio-button-{{ .cat }}"
type="radio"
value="{{ .cat }}"
name="category"
class="w-4 h-4 text-blue-600 bg-gray-100 border-gray-300 rounded focus:ring-blue-500 focus:ring-2"
/>
<label
for="radio-button-{{ .cat }}"
2024-07-06 17:48:22 -04:00
class="noselect text-xs sm:p-0 font-medium text-gray-900"
>{{ .cat }}</label
>
</div>
{{ end }} {{ end }}
</div>
<div
2024-07-23 21:21:47 -04:00
class="mt-2 grid grid-cols-1 sm:grid-cols-2 md:grid-cols-2 lg:grid-cols-3 xl:grid-cols-3 gap-4"
>
{{ range .Params.catalog }} {{ if ne .item "" }}
2024-07-12 22:37:31 -04:00
<div
class="flex flex-col justify-between bg-white rounded-lg border p-4 relative"
>
{{ if .thumbnail }}
<img
2024-07-06 17:48:22 -04:00
loading="lazy"
2024-07-12 22:34:17 -04:00
src="{{ .thumbnail }}"
alt="Thumbnail"
2024-07-23 20:50:39 -04:00
class="w-full aspect-square rounded-md object-cover"
/>
{{ else }}
2024-07-22 23:36:44 -04:00
<div
class="w-full h-52 rounded-md object-cover border-2 border-gray-200 bg-gray-100"
></div>
{{ end }}
<div class="px-1 pt-4">
<div class="flex flex-row gap-2 justify-between font-bold text-xl mb-2">
{{ .item }} {{ if ne .cat "" }}
2024-06-09 01:25:43 -04:00
<div>
<span
2024-07-23 21:21:47 -04:00
style="white-space: nowrap"
class="bg-blue-100 text-blue-800 text-xs font-medium me-2 px-2.5 py-0.5 rounded-full"
>{{ .cat }}</span
>
2024-06-09 01:25:43 -04:00
</div>
{{ end }}
</div>
2024-07-12 22:34:17 -04:00
<div class="text-sm text-gray-800 text-base mb-4">
{{ if ne .quant "" }}
<div class="flex flex-row justify-between">
<strong>Quantity:</strong>
<span>{{ .quant }}</span>
</div>
{{ end }} {{ if ne .dimensions "" }}
<div class="gap-1 text-right flex flex-row justify-between">
<strong>Dimensions:</strong>
2024-07-12 22:37:31 -04:00
<span>{{ .dimensions }}</span>
</div>
{{ end }} {{ if ne .baseCost "" }}
<div class="flex flex-row justify-between">
2024-07-12 22:34:17 -04:00
<strong>Rental Cost:</strong>
<span>{{ .baseCost }}</span>
</div>
{{ end }} {{ if ne .deliveryPickup "" }}
<div class="flex flex-row justify-between">
<strong>+ Pickup & Delivery:</strong>
<span>{{ .deliveryPickup }}</span>
</div>
{{ end }} {{ if ne .installBreakdown "" }}
<div class="flex flex-row justify-between">
2024-06-09 22:12:59 -04:00
<strong>+ Setup & Breakdown:</strong>
<span>{{ .installBreakdown }}</span>
</div>
2024-07-12 22:34:17 -04:00
{{ end }}
</div>
</div>
<div class="flex flex-col gap-4">
{{ if ne .purchaseCost "" }}
2024-07-12 22:37:31 -04:00
<div
2024-07-13 20:50:53 -04:00
class="flex flex-row justify-between border-[1px] rounded-lg px-4 h-10 py-[0.275rem] w-full"
2024-07-12 22:37:31 -04:00
>
<strong>Purchase Cost:</strong>
<span>{{ .purchaseCost }}</span>
</div>
{{ else }}
<div
2024-07-13 20:50:53 -04:00
class="flex justify-center border-[1px] rounded-lg px-4 h-10 py-[0.275rem] text-gray-600 mt-4 w-full"
2024-07-12 22:37:31 -04:00
>
<strong>Purchase Unavailable</strong>
</div>
{{ end }}
2024-07-12 22:34:17 -04:00
<a class="w-full h-8" href="#modal-{{ .item | urlize }}">
<button
type="button"
class="w-full px-3 py-2 text-xs font-medium text-center text-white bg-black rounded-lg hover:bg-gray-800 focus:ring-4 focus:outline-none transition-all duration-200"
>
Expand
</button>
</a>
</div>
<div
id="modal-{{ .item | urlize }}"
class="fixed z-10 inset-0 overflow-y-auto hidden bg-gray-500 bg-opacity-75 transition-opacity"
aria-labelledby="modal-title"
role="dialog"
aria-modal="true"
>
<div
class="flex items-end justify-center min-h-screen p-4 text-center sm:block sm:p-0"
>
<div class="fixed inset-0" aria-hidden="true"></div>
<span
class="hidden sm:inline-block sm:align-middle sm:h-screen"
aria-hidden="true"
>&#8203;</span
>
<div
class="inline-block align-bottom bg-white rounded-lg text-left overflow-hidden shadow-xl transform transition-all sm:my-8 sm:align-middle self-center sm:max-w-lg w-full"
>
<div class="bg-white px-4 pt-5 pb-4 sm:p-6 sm:pb-4">
<div class="sm:flex sm:items-start">
<div class="w-full mt-3 text-center sm:mt-0 sm:ml-4 sm:text-left">
<h3 class="text-xl mb-2" id="modal-title">
<strong>{{ .item }}</strong>
</h3>
2024-07-23 21:11:47 -04:00
{{ if .gallery }}
<div
class="w-full mt-8 columns-1 gap-2 sm:columns-2 sm:gap-4 [&>div:not(:first-child)]:mt-4"
>
{{ range .gallery }}
2024-07-23 21:21:47 -04:00
<div class="relative">
2024-07-23 21:11:47 -04:00
<img
loading="lazy"
class="rounded-lg w-full"
src="{{ .image }}"
/>
</div>
{{ end }}
</div>
{{ end }}
2024-07-23 20:50:39 -04:00
<div class="px-4 pt-6 w-full">
<div class="text-sm text-gray-800 text-base mb-4">
{{ if ne .quant "" }}
<div class="flex flex-row justify-between">
<strong>Quantity:</strong>
<span>{{ .quant }}</span>
</div>
{{ end }} {{ if ne .dimensions "" }}
2024-07-23 20:50:39 -04:00
<div class="gap-1 text-right flex flex-row justify-between">
<strong>Dimensions:</strong>
<span>{{ .dimensions }}</span>
</div>
{{ end }} {{ if ne .baseCost "" }}
<div class="flex flex-row justify-between">
2024-07-23 20:50:39 -04:00
<strong>Rental Cost:</strong>
<span>{{ .baseCost }}</span>
</div>
{{ end }} {{ if ne .deliveryPickup "" }}
<div class="flex flex-row justify-between">
2024-07-23 20:50:39 -04:00
<strong>+ Pickup & Delivery:</strong>
<span>{{ .deliveryPickup }}</span>
</div>
{{ end }} {{ if ne .installBreakdown "" }}
<div class="flex flex-row justify-between">
2024-07-23 20:50:39 -04:00
<strong>+ Setup & Breakdown:</strong>
<span>{{ .installBreakdown }}</span>
</div>
2024-07-23 20:50:39 -04:00
{{ end }}
</div>
<div class="grid grid-cols-2">
{{ if ne .baseCost "" }}
<div class="border rounded-s-lg p-2 flex justify-between">
<strong>Rental Cost:</strong>
<span>{{ .baseCost }}</span>
</div>
{{ else }}
2024-07-12 22:37:31 -04:00
<div
2024-07-23 20:50:39 -04:00
class="border rounded-s-lg p-2 text-gray-600 text-center"
2024-07-12 22:37:31 -04:00
>
2024-07-23 20:50:39 -04:00
<strong>Rental Unavailable</strong>
</div>
{{ end }} {{ if ne .purchaseCost "" }}
2024-07-23 21:11:47 -04:00
<div
class="border border-s-0 rounded-e-lg p-2 flex justify-between"
>
<strong>Purchase Cost:</strong>
<span>{{ .purchaseCost }}</span>
</div>
2024-07-12 22:37:31 -04:00
{{ else }}
<div
2024-07-23 20:50:39 -04:00
class="border border-s-0 rounded-e-lg p-2 text-gray-600 text-center"
2024-07-12 22:37:31 -04:00
>
<strong>Purchase Unavailable</strong>
</div>
{{ end }}
</div>
</div>
</div>
</div>
</div>
<div class="bg-gray-50 px-4 py-3 sm:px-6 sm:flex sm:flex-row-reverse">
<button
id="close-modal"
2024-07-23 20:50:39 -04:00
class="w-full inline-flex justify-center rounded-md border border-transparent shadow-sm p-2 px-4 bg-black text-base font-medium text-white hover:bg-gray-800 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-black sm:ml-3 sm:w-auto sm:text-sm"
@click="open = false"
>
Close
</button>
</div>
</div>
</div>
</div>
</div>
{{ end }} {{ end }}
</div>
<script>
document.addEventListener("DOMContentLoaded", function () {
2024-07-23 21:11:47 -04:00
const modalButtons = document.querySelectorAll(".grid.grid-cols-1 a");
const closeButtons = document.querySelectorAll("#close-modal");
const modals = document.querySelectorAll(".fixed");
const radioButtons = document.querySelectorAll(
'input[type="radio"][name="category"]'
);
function filterItems(category) {
console.log("Filtering items for category:", category);
2024-07-23 21:11:47 -04:00
const items = document.querySelectorAll(".grid.grid-cols-1 > div");
items.forEach((item) => {
const itemCategory = item.querySelector(".bg-blue-100");
2024-07-23 21:11:47 -04:00
// Decode category to match actual category names in catalog
const decodedCategory = decodeURIComponent(category);
if (!category || itemCategory.textContent.trim() === decodedCategory) {
item.classList.remove("hidden");
} else {
item.classList.add("hidden");
const modalId = item.id.replace("modal-", "");
const modal = document.getElementById(modalId);
if (modal) modal.classList.add("hidden");
}
});
}
function updateUrl(category) {
2024-07-23 21:11:47 -04:00
const url = new URL(window.location.href);
url.hash = encodeURIComponent(category); // Encode category for URL
window.history.replaceState({}, "", url.toString());
2024-07-23 20:50:39 -04:00
}
2024-07-23 21:11:47 -04:00
const category = window.location.hash.substring(1);
console.log("Initial category:", category);
2024-07-23 21:11:47 -04:00
filterItems(category);
window.addEventListener("hashchange", function () {
2024-07-23 21:11:47 -04:00
const newCategory = window.location.hash.substring(1);
console.log("New category:", newCategory);
2024-07-23 21:11:47 -04:00
filterItems(newCategory);
});
radioButtons.forEach((radio) => {
radio.addEventListener("change", function () {
const category = this.value;
2024-07-23 21:11:47 -04:00
console.log("Selected category:", category);
updateUrl(category);
filterItems(category);
});
});
modalButtons.forEach((button) => {
button.addEventListener("click", function (e) {
e.preventDefault();
const modalId = this.getAttribute("href").substring(1);
const modal = document.getElementById(modalId);
modal.classList.remove("hidden");
});
});
closeButtons.forEach((button) => {
button.addEventListener("click", function (e) {
e.preventDefault();
const modal = this.closest(".fixed");
modal.classList.add("hidden");
});
});
if (category) {
const radioToSelect = document.querySelector(
`input[type="radio"][name="category"][value="${category}"]`
);
if (radioToSelect) {
radioToSelect.checked = true;
filterItems(category);
}
}
});
</script>