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

155 lines
5.8 KiB
HTML
Raw Normal View History

<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-07-22 23:36:44 -04:00
{{ range $index, $element := .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">
<img
2024-07-06 17:48:22 -04:00
loading="lazy"
src="{{ .main }}"
class="h-72 w-full rounded-md object-cover"
/>
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">
2024-07-22 23:36:44 -04:00
<a class="w-full" href="#modal-{{ $index | 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
2024-07-22 23:36:44 -04:00
id="modal-{{ $index | 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
2024-07-22 23:36:44 -04:00
class="border 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
>
<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">
<strong>{{ .item }}</strong>
</h3>
{{ 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
>
2024-07-22 23:36:44 -04:00
{{ range $index, $element := .gallery }}
<div class="relative ease-in-out duration-200 transition-all">
2024-07-06 17:48:22 -04:00
<img
2024-07-22 23:36:44 -04:00
id="img-{{ $index }}"
2024-07-06 17:48:22 -04:00
loading="lazy"
2024-07-22 23:36:44 -04:00
class="rounded-md w-full"
2024-07-06 17:48:22 -04:00
src="{{ .image }}"
/>
2024-07-06 16:00:51 -04:00
</div>
2024-07-06 17:48:22 -04:00
{{ end }}
</div>
{{ 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>
</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"
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>
</div>
</div>
</div>
</div>
{{ end }} {{ end }}
</div>
<script>
document.addEventListener("DOMContentLoaded", function () {
const modalButtons = document.querySelectorAll(".grid-cols-1 a");
const closeButtons = document.querySelectorAll("#close-modal");
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");
});
});
});
</script>