2023-05-29 10:42:17 +00:00
|
|
|
{% extends 'base.html' %}
|
2023-03-25 16:22:32 +00:00
|
|
|
{% block nav_groups %}selected{% endblock %}
|
2023-05-29 10:42:17 +00:00
|
|
|
|
2023-04-04 20:45:35 +00:00
|
|
|
{% block head %}
|
2023-04-22 11:46:20 +00:00
|
|
|
{% if images %}<meta name="theme-color" content="rgb{{ images.0.colours.0 }}"/>{% endif %}
|
2023-04-04 20:45:35 +00:00
|
|
|
|
|
|
|
{% if current_user.is_authenticated %}
|
|
|
|
<script type="text/javascript">
|
|
|
|
function showCreate() {
|
|
|
|
// Create elements
|
|
|
|
cancelBtn = document.createElement('button');
|
|
|
|
cancelBtn.classList.add('btn-block');
|
2023-04-19 17:16:40 +00:00
|
|
|
cancelBtn.classList.add('transparent');
|
2023-04-04 20:45:35 +00:00
|
|
|
cancelBtn.innerHTML = 'nuuuuuuuu';
|
|
|
|
cancelBtn.onclick = popupDissmiss;
|
|
|
|
|
|
|
|
submitBtn = document.createElement('button');
|
|
|
|
submitBtn.classList.add('btn-block');
|
|
|
|
submitBtn.classList.add('primary');
|
|
|
|
submitBtn.innerHTML = 'Submit!!';
|
|
|
|
submitBtn.type = 'submit';
|
|
|
|
submitBtn.setAttribute('form', 'createForm');
|
|
|
|
|
|
|
|
// Create form
|
|
|
|
createForm = document.createElement('form');
|
|
|
|
createForm.id = 'createForm';
|
|
|
|
createForm.setAttribute('onsubmit', 'return create(event);');
|
|
|
|
|
|
|
|
titleInput = document.createElement('input');
|
|
|
|
titleInput.classList.add('input-block');
|
|
|
|
titleInput.type = 'text';
|
|
|
|
titleInput.placeholder = 'Group namey';
|
|
|
|
titleInput.id = 'name';
|
|
|
|
|
|
|
|
descriptionInput = document.createElement('input');
|
|
|
|
descriptionInput.classList.add('input-block');
|
|
|
|
descriptionInput.type = 'text';
|
|
|
|
descriptionInput.placeholder = 'What it about????';
|
|
|
|
descriptionInput.id = 'description';
|
|
|
|
|
|
|
|
createForm.appendChild(titleInput);
|
|
|
|
createForm.appendChild(descriptionInput);
|
|
|
|
|
|
|
|
popUpShow(
|
|
|
|
'New stuff!',
|
|
|
|
'Image groups are a simple way to "group" images together, are you ready?',
|
|
|
|
createForm,
|
|
|
|
[cancelBtn, submitBtn]
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
function create(event) {
|
|
|
|
// AJAX takes control of subby form :3
|
|
|
|
event.preventDefault();
|
|
|
|
|
|
|
|
let formName = document.querySelector("#name").value;
|
|
|
|
let formDescription = document.querySelector("#description").value;
|
|
|
|
|
|
|
|
if (!formName) {
|
|
|
|
addNotification("Group name must be set!", 3);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Make form
|
|
|
|
const formData = new FormData();
|
|
|
|
formData.append("name", formName);
|
|
|
|
formData.append("description", formDescription);
|
|
|
|
|
2023-04-21 17:34:25 +00:00
|
|
|
fetch('{{ url_for('group_api.create_group') }}', {
|
2023-04-04 20:45:35 +00:00
|
|
|
method: 'POST',
|
|
|
|
body: formData
|
|
|
|
}).then(response => {
|
|
|
|
if (response.status === 200) {
|
|
|
|
addNotification('Group created!', 1);
|
|
|
|
popupDissmiss();
|
|
|
|
} else {
|
|
|
|
switch (response.status) {
|
|
|
|
case 500:
|
|
|
|
addNotification('Server exploded, F\'s in chat', 2);
|
|
|
|
break;
|
|
|
|
case 403:
|
|
|
|
addNotification('None but devils play past here... Bad information', 2);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
addNotification('Error logging in, blame someone', 2);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}).catch(error => {
|
|
|
|
addNotification('Error making group! :c', 2);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
</script>
|
|
|
|
{% endif %}
|
|
|
|
{% endblock %}
|
2023-05-29 10:42:17 +00:00
|
|
|
|
|
|
|
{% block header %}
|
2023-04-04 19:36:24 +00:00
|
|
|
<div class="banner-small">
|
2023-03-09 23:31:58 +00:00
|
|
|
<div class="banner-content">
|
2023-04-07 09:18:03 +00:00
|
|
|
<h1 class="banner-header">{{ config.WEBSITE_CONF.name }}</h1>
|
2023-03-23 15:47:35 +00:00
|
|
|
{% if groups|length == 0 %}
|
2023-04-04 19:36:24 +00:00
|
|
|
<p class="banner-info">No groups!!!!</p>
|
2023-03-23 15:47:35 +00:00
|
|
|
{% elif groups|length == 69 %}
|
2023-04-04 19:36:24 +00:00
|
|
|
<p class="banner-info">{{ groups|length }} groups, uwu</p>
|
2023-03-23 15:47:35 +00:00
|
|
|
{% else %}
|
2023-04-04 19:36:24 +00:00
|
|
|
<p class="banner-info">{{ groups|length }} groups</p>
|
|
|
|
{% endif %}
|
|
|
|
{% if current_user.is_authenticated %}
|
|
|
|
<div class="pill-row">
|
|
|
|
<div>
|
2023-04-20 16:15:51 +00:00
|
|
|
<button class="pill-item" onclick="showCreate()"><i class="ph ph-plus"></i></button>
|
2023-04-04 19:36:24 +00:00
|
|
|
</div>
|
|
|
|
</div>
|
2023-03-23 15:47:35 +00:00
|
|
|
{% endif %}
|
2023-03-09 23:31:58 +00:00
|
|
|
</div>
|
|
|
|
</div>
|
2023-05-29 10:42:17 +00:00
|
|
|
{% endblock %}
|
2023-03-09 23:31:58 +00:00
|
|
|
|
2023-05-29 10:42:17 +00:00
|
|
|
{% block content %}
|
2023-03-09 23:31:58 +00:00
|
|
|
{% if groups %}
|
|
|
|
<div class="gallery-grid">
|
|
|
|
{% for group in groups %}
|
2023-05-29 10:42:17 +00:00
|
|
|
<a
|
|
|
|
class="group-item square"
|
|
|
|
id="group-{{ group.id }}"
|
|
|
|
href="{{ url_for('group.group', group_id=group.id) }}"
|
|
|
|
{% if group.images|length > 0 %} style="background-color: rgba{{ group.images.0.colours.0 }};"{% endif %}
|
|
|
|
>
|
2023-04-01 16:16:07 +00:00
|
|
|
<div class="image-filter">
|
2023-04-12 15:16:43 +00:00
|
|
|
<p class="image-subtitle">By {{ group.author.username }}</p>
|
2023-04-01 16:16:07 +00:00
|
|
|
<p class="image-title">{{ group.name }}</p>
|
|
|
|
</div>
|
|
|
|
<div class="images size-{{ group.images|length }}">
|
|
|
|
{% if group.images|length > 0 %}
|
|
|
|
{% for image in group.images %}
|
2023-04-22 11:46:20 +00:00
|
|
|
<picture>
|
|
|
|
<source srcset="{{ url_for('media_api.media', path='uploads/' + image.filename) }}?r=thumb&e=webp">
|
|
|
|
<source srcset="{{ url_for('media_api.media', path='uploads/' + image.filename) }}?r=thumb&e=png">
|
|
|
|
<img
|
|
|
|
src="{{ url_for('media_api.media', path='uploads/' + image.filename) }}?r=thumb"
|
|
|
|
alt="{% if image.alt %}{{ image.alt }}{% else %}Image Thumbnail{% endif %}"
|
|
|
|
class="data-{{ loop.index }}"
|
|
|
|
onload="imgFade(this)"
|
|
|
|
style="opacity:0;"
|
|
|
|
fetchpriority="low"
|
|
|
|
/>
|
|
|
|
</picture>
|
2023-04-01 16:16:07 +00:00
|
|
|
{% endfor %}
|
|
|
|
{% else %}
|
2023-04-06 21:26:40 +00:00
|
|
|
<img src="{{ url_for('static', filename='error.png') }}" class="loaded" alt="Error thumbnail"/>
|
2023-04-01 16:16:07 +00:00
|
|
|
{% endif %}
|
|
|
|
</div>
|
|
|
|
</a>
|
2023-03-09 23:31:58 +00:00
|
|
|
{% endfor %}
|
|
|
|
</div>
|
|
|
|
{% else %}
|
|
|
|
<div class="big-text">
|
2023-03-26 01:04:13 +00:00
|
|
|
<h1>*crickets chirping*</h1>
|
2023-04-03 18:04:49 +00:00
|
|
|
{% if current_user.is_authenticated %}
|
2023-03-09 23:31:58 +00:00
|
|
|
<p>You can get started by creating a new image group!</p>
|
|
|
|
{% else %}
|
2023-03-26 01:04:13 +00:00
|
|
|
<p>Login to start seeing anything here!</p>
|
2023-03-09 23:31:58 +00:00
|
|
|
{% endif %}
|
|
|
|
</div>
|
|
|
|
{% endif %}
|
|
|
|
{% endblock %}
|