2024-06-08 22:48:56 -04:00
|
|
|
<div
|
|
|
|
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"
|
2024-06-08 21:01:38 -04:00
|
|
|
>
|
2024-07-06 21:11:39 -04:00
|
|
|
{{ range .Params.art }} {{ if ne .item "" }}
|
2024-07-07 16:43:25 -04:00
|
|
|
<div class="relative flex flex-col bg-white rounded-lg border p-4 relative">
|
2024-06-08 21:01:38 -04:00
|
|
|
<img
|
2024-07-06 17:48:22 -04:00
|
|
|
loading="lazy"
|
2024-07-06 21:11:39 -04:00
|
|
|
src="{{ .main }}"
|
2024-07-22 14:30:28 -04:00
|
|
|
class="h-72 w-full rounded-md object-cover"
|
2024-06-08 21:01:38 -04:00
|
|
|
/>
|
2024-07-07 17:35:15 -04:00
|
|
|
<div class="flex flex-row gap-2 my-2 justify-between">
|
|
|
|
<div class="flex flex-col items-start">
|
|
|
|
<span>
|
|
|
|
<strong class="text-base text-gray-700"> {{ .title }}</strong>
|
2024-07-12 22:34:11 -04:00
|
|
|
<span class="text-[0.6rem] text-gray-600">{{ .year }}</span>
|
2024-07-07 17:35:15 -04:00
|
|
|
</span>
|
|
|
|
</div>
|
|
|
|
{{ if .status }}
|
|
|
|
<div>
|
|
|
|
<span
|
|
|
|
class="bg-red-100 text-red-800 text-xs font-medium px-2.5 py-0.5 rounded-full"
|
|
|
|
>{{ .status }}</span
|
|
|
|
>
|
|
|
|
</div>
|
|
|
|
{{ end }}
|
|
|
|
</div>
|
|
|
|
<div class="grid grid-cols-1 place-items-end">
|
|
|
|
<a class="w-full" href="#modal-{{ .listOrder | urlize }}">
|
2024-06-08 21:01:38 -04:00
|
|
|
<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
|
2024-07-07 17:35:15 -04:00
|
|
|
id="modal-{{ .listOrder | urlize }}"
|
2024-06-08 21:01:38 -04:00
|
|
|
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"
|
|
|
|
>​</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"
|
|
|
|
>
|
2024-07-07 16:43:25 -04:00
|
|
|
<div
|
2024-07-07 17:35:15 -04:00
|
|
|
class="bg-white max-h-[80vh] overflow-y-scroll overflow-x-hidden px-4 pt-5 pb-4 sm:p-6 sm:pb-4"
|
2024-07-07 16:43:25 -04:00
|
|
|
>
|
2024-06-08 21:01:38 -04:00
|
|
|
<div class="sm:flex sm:items-start">
|
2024-07-07 16:43:25 -04:00
|
|
|
<div class="w-full mt-3 text-center sm:mt-0 sm:text-left">
|
|
|
|
<h3 class="text-xl" id="modal-title">
|
2024-06-08 21:01:38 -04:00
|
|
|
<strong>{{ .item }}</strong>
|
|
|
|
</h3>
|
2024-06-08 21:59:09 -04:00
|
|
|
{{ if .gallery }}
|
2024-07-06 17:48:22 -04:00
|
|
|
<div
|
2024-07-07 16:43:25 -04:00
|
|
|
class="columns-1 gap-2 sm:columns-2 sm:gap-4 [&>div:not(:first-child)]:mt-4"
|
2024-07-06 17:48:22 -04:00
|
|
|
>
|
|
|
|
{{ range .gallery }}
|
2024-07-06 16:00:51 -04:00
|
|
|
<div
|
2024-07-22 14:30:28 -04:00
|
|
|
class="relative ease-in-out duration-200 transition-all"
|
2024-06-10 19:21:08 -04:00
|
|
|
>
|
2024-07-06 17:48:22 -04:00
|
|
|
<img
|
|
|
|
loading="lazy"
|
|
|
|
class="rounded-lg w-full"
|
|
|
|
src="{{ .image }}"
|
|
|
|
/>
|
|
|
|
<button class="absolute right-2 top-2">
|
2024-06-10 19:21:08 -04:00
|
|
|
<svg
|
|
|
|
xmlns="http://www.w3.org/2000/svg"
|
2024-07-06 17:48:22 -04:00
|
|
|
viewBox="0 0 448 512"
|
2024-07-06 17:53:34 -04:00
|
|
|
class="fill-black w-6 h-6 bg-white p-1 rounded-sm"
|
2024-06-10 19:21:08 -04:00
|
|
|
>
|
|
|
|
<path
|
2024-07-06 17:48:22 -04:00
|
|
|
d="M32 32C14.3 32 0 46.3 0 64v96c0 17.7 14.3 32 32 32s32-14.3 32-32V96h64c17.7 0 32-14.3 32-32s-14.3-32-32-32H32zM64 352c0-17.7-14.3-32-32-32s-32 14.3-32 32v96c0 17.7 14.3 32 32 32h96c17.7 0 32-14.3 32-32s-14.3-32-32-32H64V352zM320 32c-17.7 0-32 14.3-32 32s14.3 32 32 32h64v64c0 17.7 14.3 32 32 32s32-14.3 32-32V64c0-17.7-14.3-32-32-32H320zM448 352c0-17.7-14.3-32-32-32s-32 14.3-32 32v64H320c-17.7 0-32 14.3-32 32s14.3 32 32 32h96c17.7 0 32-14.3 32-32V352z"
|
2024-06-10 19:21:08 -04:00
|
|
|
/>
|
|
|
|
</svg>
|
2024-07-06 16:00:51 -04:00
|
|
|
</button>
|
|
|
|
</div>
|
2024-07-06 17:48:22 -04:00
|
|
|
{{ end }}
|
|
|
|
</div>
|
2024-06-08 21:59:09 -04:00
|
|
|
{{ end }}
|
2024-07-07 17:35:15 -04:00
|
|
|
<div>
|
|
|
|
<div class="flex flex-row gap-2 my-2 justify-between mt-4">
|
|
|
|
<div class="flex flex-col items-start">
|
|
|
|
<span class="text-xs text-gray-600">Title:</span>
|
|
|
|
<span>
|
|
|
|
<strong class="text-lg text-gray-700">
|
|
|
|
{{ .title }}</strong
|
|
|
|
>
|
|
|
|
</span>
|
|
|
|
</div>
|
|
|
|
{{ if .status }}
|
|
|
|
<div>
|
|
|
|
<span
|
|
|
|
class="bg-red-100 text-red-800 text-xs font-medium px-2.5 py-0.5 rounded-full"
|
|
|
|
>{{ .status }}</span
|
|
|
|
>
|
|
|
|
</div>
|
|
|
|
{{ end }}
|
|
|
|
</div>
|
2024-07-12 22:34:11 -04:00
|
|
|
{{ if .location }}
|
|
|
|
<div class="flex flex-col items-start mb-2">
|
|
|
|
<span class="text-xs text-gray-600">Location:</span>
|
|
|
|
<span> {{ .location }} </span>
|
|
|
|
</div>
|
|
|
|
{{ end }}
|
2024-07-07 17:35:15 -04:00
|
|
|
<div class="flex flex-col items-start mb-2">
|
|
|
|
<span class="text-xs text-gray-600">Year:</span>
|
|
|
|
<span> {{ .year }} </span>
|
|
|
|
</div>
|
|
|
|
<div class="flex flex-col items-start">
|
|
|
|
<span class="text-xs text-gray-600">Description:</span>
|
|
|
|
<span> {{ .description }} </span>
|
|
|
|
</div>
|
|
|
|
</div>
|
2024-06-04 14:15:20 -04:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
2024-06-08 21:01:38 -04:00
|
|
|
<div class="bg-gray-50 px-4 py-3 sm:px-6 sm:flex sm:flex-row-reverse">
|
|
|
|
<button
|
|
|
|
id="close-modal"
|
|
|
|
class="w-full inline-flex justify-center rounded-md border border-transparent shadow-sm px-4 py-2 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>
|
2024-06-04 05:12:29 -04:00
|
|
|
</div>
|
2024-06-08 21:01:38 -04:00
|
|
|
</div>
|
|
|
|
</div>
|
2024-06-04 05:12:29 -04:00
|
|
|
</div>
|
2024-06-08 21:01:38 -04:00
|
|
|
{{ end }} {{ end }}
|
|
|
|
</div>
|
|
|
|
<script>
|
|
|
|
document.addEventListener("DOMContentLoaded", function () {
|
|
|
|
const modalButtons = document.querySelectorAll(".grid-cols-1 a");
|
|
|
|
const closeButtons = document.querySelectorAll("#close-modal");
|
|
|
|
const modals = document.querySelectorAll(".fixed");
|
2024-06-08 22:48:56 -04:00
|
|
|
const radioButtons = document.querySelectorAll(
|
|
|
|
'input[type="radio"][name="category"]'
|
|
|
|
);
|
2024-06-08 21:01:38 -04:00
|
|
|
|
2024-06-08 21:59:09 -04:00
|
|
|
function filterItems(category) {
|
|
|
|
console.log("Filtering items for category:", category);
|
|
|
|
const items = document.querySelectorAll(".grid > div");
|
|
|
|
|
|
|
|
items.forEach((item) => {
|
|
|
|
const itemCategory = item.querySelector(".bg-blue-100");
|
2024-06-08 22:48:56 -04:00
|
|
|
if (!category || itemCategory.textContent === category) {
|
2024-06-08 21:59:09 -04:00
|
|
|
item.classList.remove("hidden");
|
|
|
|
} else {
|
|
|
|
item.classList.add("hidden");
|
2024-06-08 22:48:56 -04:00
|
|
|
|
2024-06-08 21:59:09 -04:00
|
|
|
const modalId = item.id.replace("modal-", "");
|
|
|
|
const modal = document.getElementById(modalId);
|
|
|
|
if (modal) modal.classList.add("hidden");
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2024-06-08 22:48:56 -04:00
|
|
|
function updateUrl(category) {
|
|
|
|
const url = window.location.href.split("#")[0];
|
|
|
|
const newUrl = category ? `${url}#${category}` : url;
|
|
|
|
window.history.replaceState({}, "", newUrl);
|
|
|
|
}
|
|
|
|
|
2024-06-08 21:59:09 -04:00
|
|
|
const category = window.location.hash.substring(1);
|
|
|
|
console.log("Initial category:", category);
|
|
|
|
filterItems(category);
|
|
|
|
|
|
|
|
window.addEventListener("hashchange", function () {
|
|
|
|
const newCategory = window.location.hash.substring(1);
|
|
|
|
console.log("New category:", newCategory);
|
|
|
|
filterItems(newCategory);
|
|
|
|
});
|
|
|
|
|
2024-06-08 22:48:56 -04:00
|
|
|
radioButtons.forEach((radio) => {
|
|
|
|
radio.addEventListener("change", function () {
|
|
|
|
const category = this.value;
|
|
|
|
console.log("Selected category:", category);
|
|
|
|
updateUrl(category);
|
|
|
|
filterItems(category);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2024-06-08 21:01:38 -04:00
|
|
|
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");
|
2024-06-04 14:15:20 -04:00
|
|
|
});
|
|
|
|
});
|
2024-06-08 21:01:38 -04:00
|
|
|
|
|
|
|
closeButtons.forEach((button) => {
|
|
|
|
button.addEventListener("click", function (e) {
|
|
|
|
e.preventDefault();
|
2024-06-08 21:59:09 -04:00
|
|
|
const modal = this.closest(".fixed");
|
|
|
|
modal.classList.add("hidden");
|
2024-06-04 14:15:20 -04:00
|
|
|
});
|
|
|
|
});
|
2024-06-08 22:48:56 -04:00
|
|
|
|
|
|
|
if (category) {
|
|
|
|
const radioToSelect = document.querySelector(
|
|
|
|
`input[type="radio"][name="category"][value="${category}"]`
|
|
|
|
);
|
|
|
|
if (radioToSelect) {
|
|
|
|
radioToSelect.checked = true;
|
|
|
|
filterItems(category);
|
|
|
|
}
|
|
|
|
}
|
2024-06-08 21:01:38 -04:00
|
|
|
});
|
|
|
|
</script>
|