2022-12-01 18:48:31 +00:00
|
|
|
{% extends 'layout.html' %}
|
2023-01-10 12:39:29 +00:00
|
|
|
|
2023-03-08 13:36:35 +00:00
|
|
|
{% block nav_home %}navigation-item__selected{% endblock %}
|
|
|
|
|
|
|
|
{% block content %}
|
2023-03-01 23:29:34 +00:00
|
|
|
<div class="banner">
|
2023-03-08 09:01:20 +00:00
|
|
|
<img src="{{ url_for('static', filename='images/bg.svg') }}" onload="imgFade(this)" style="opacity:0;"/>
|
2023-03-01 23:29:34 +00:00
|
|
|
<span></span>
|
|
|
|
|
2023-03-08 13:36:35 +00:00
|
|
|
<div class="banner-content">
|
2023-03-01 23:29:34 +00:00
|
|
|
<p>{{ motto }}</p>
|
|
|
|
<h1>{{ name }}</h1>
|
|
|
|
<p>Serving {{ image_count }} images</p>
|
|
|
|
</div>
|
|
|
|
</div>
|
2023-01-10 12:39:29 +00:00
|
|
|
|
2023-03-08 13:36:35 +00:00
|
|
|
<div class="gallery-grid">
|
2023-01-25 15:13:56 +00:00
|
|
|
{% for image in images %}
|
2023-03-08 13:36:35 +00:00
|
|
|
<a id="image-{{ image['id'] }}" class="gallery-item" href="/image/{{ image['id'] }}" style="background-color: rgb({{ image['image_colours'][0][0] }}, {{ image['image_colours'][0][1] }}, {{ image['image_colours'][0][2] }})">
|
|
|
|
<span>
|
2023-03-08 09:01:20 +00:00
|
|
|
<p></p>
|
2023-01-26 16:55:42 +00:00
|
|
|
<h2><span class="time">{{ image['created_at'] }}</span></h2>
|
2023-01-26 14:43:08 +00:00
|
|
|
</span>
|
2023-01-25 15:13:56 +00:00
|
|
|
<img
|
2023-01-26 16:55:42 +00:00
|
|
|
data-src="{{ image['file_name'] }}"
|
2023-01-25 15:13:56 +00:00
|
|
|
onload="imgFade(this)"
|
|
|
|
style="opacity:0;"
|
|
|
|
/>
|
|
|
|
</a>
|
|
|
|
{% endfor %}
|
2022-12-01 18:48:31 +00:00
|
|
|
</div>
|
2023-01-25 15:13:56 +00:00
|
|
|
{% endblock %}
|
|
|
|
|
|
|
|
{% block script %}
|
2022-12-01 18:48:31 +00:00
|
|
|
<script>
|
2023-01-31 17:32:22 +00:00
|
|
|
function loadOnView() {
|
2023-03-08 13:36:35 +00:00
|
|
|
var images = document.querySelectorAll('.gallery-item img');
|
|
|
|
|
2023-01-26 16:55:42 +00:00
|
|
|
for (var i = 0; i < images.length; i++) {
|
|
|
|
var image = images[i];
|
|
|
|
if (image.getBoundingClientRect().top < window.innerHeight && image.getBoundingClientRect().bottom > 0) {
|
|
|
|
if (!image.src) {
|
2023-03-02 13:19:10 +00:00
|
|
|
image.src = `/api/uploads/${image.getAttribute('data-src')}?w=500&h=500`
|
2023-01-26 16:55:42 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2023-01-31 17:32:22 +00:00
|
|
|
}
|
|
|
|
window.onload = function() {
|
|
|
|
loadOnView();
|
2023-01-26 16:55:42 +00:00
|
|
|
};
|
|
|
|
window.onscroll = function() {
|
2023-01-31 17:32:22 +00:00
|
|
|
loadOnView();
|
|
|
|
};
|
|
|
|
window.onresize = function() {
|
|
|
|
loadOnView();
|
2023-01-26 16:55:42 +00:00
|
|
|
};
|
|
|
|
|
2023-02-01 00:57:36 +00:00
|
|
|
if (document.referrer.includes('image')) {
|
2023-03-08 09:01:20 +00:00
|
|
|
try {
|
|
|
|
var referrerId = document.referrer.split('/').pop();
|
|
|
|
|
|
|
|
var imgOffset = document.getElementById('image-' + referrerId).offsetTop;
|
|
|
|
var imgHeight = document.getElementById('image-' + referrerId).offsetHeight;
|
|
|
|
var windowHeight = window.innerHeight;
|
|
|
|
|
|
|
|
document.querySelector('html').style.scrollBehavior = 'auto';
|
|
|
|
window.scrollTo(0, imgOffset + (imgHeight / 2) - (windowHeight / 2));
|
|
|
|
document.querySelector('html').style.scrollBehavior = 'smooth';
|
|
|
|
} catch (e) {
|
|
|
|
console.log(e);
|
|
|
|
}
|
2022-12-14 19:55:40 +00:00
|
|
|
}
|
2022-12-01 18:48:31 +00:00
|
|
|
</script>
|
|
|
|
{% endblock %}
|