2025-04-12 22:25:54 -04:00
|
|
|
{% extends "root.html" %} {% block head %}
|
|
|
|
<title>Requests - {{ config.name }}</title>
|
|
|
|
{% endblock %} {% block body %} {{ macros::nav(selected="requests") }}
|
|
|
|
<main class="flex flex-col gap-2">
|
|
|
|
<div class="card-nest">
|
|
|
|
<div class="card small flex items-center justify-between gap-2">
|
|
|
|
<span class="flex items-center gap-2">
|
|
|
|
{{ icon "inbox" }}
|
|
|
|
<span>{{ text "requests:label.requests" }}</span>
|
|
|
|
</span>
|
|
|
|
|
|
|
|
<button onclick="clear_requests()" class="small red quaternary">
|
|
|
|
{{ icon "bomb" }}
|
|
|
|
<span>{{ text "notifs:action.clear" }}</span>
|
|
|
|
</button>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="card tertiary flex flex-col gap-4">
|
|
|
|
{% for request in requests %} {% if request.action_type ==
|
|
|
|
"CommunityJoin" %}
|
|
|
|
<div class="card-nest">
|
|
|
|
<div class="card small flex items-center gap-2">
|
|
|
|
{{ icon "user-plus" }}
|
|
|
|
<span
|
|
|
|
>{{ text "requests:label.community_join_request"
|
|
|
|
}}</span
|
|
|
|
>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="card flex flex-wrap gap-2">
|
|
|
|
<a
|
|
|
|
href="/community/{{ request.linked_asset }}/manage?uid={{ request.id }}#/members"
|
|
|
|
class="button"
|
|
|
|
>
|
|
|
|
{{ icon "external-link" }}
|
|
|
|
<span>{{ text "requests:label.review" }}</span>
|
|
|
|
</a>
|
|
|
|
|
|
|
|
<button
|
|
|
|
class="quaternary red"
|
|
|
|
onclick="remove_request('{{ request.id }}', '{{ request.linked_asset }}')"
|
|
|
|
>
|
|
|
|
{{ icon "trash" }}
|
|
|
|
<span>{{ text "general:action.delete" }}</span>
|
|
|
|
</button>
|
|
|
|
</div>
|
|
|
|
</div>
|
2025-04-14 17:21:52 -04:00
|
|
|
{% elif request.action_type == "Follow" %}
|
|
|
|
<div class="card-nest">
|
|
|
|
<div class="card small flex items-center gap-2">
|
|
|
|
{{ icon "user-plus" }}
|
|
|
|
<span>{{ text "requests:label.user_follow_request" }}</span>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="card flex flex-col gap-2">
|
|
|
|
<span>
|
|
|
|
{{ text "requests:label.user_follow_request_message" }}
|
|
|
|
</span>
|
|
|
|
|
|
|
|
<div class="card flex w-full secondary gap-2">
|
|
|
|
<a
|
|
|
|
href="/api/v1/auth/user/find/{{ request.id }}"
|
|
|
|
class="button"
|
|
|
|
>
|
|
|
|
{{ icon "external-link" }}
|
|
|
|
<span
|
|
|
|
>{{ text "requests:action.view_profile" }}</span
|
|
|
|
>
|
|
|
|
</a>
|
|
|
|
|
|
|
|
<button
|
|
|
|
class="quaternary green"
|
|
|
|
onclick="accept_follow_request(event, '{{ request.id }}')"
|
|
|
|
>
|
|
|
|
{{ icon "check" }}
|
|
|
|
<span>{{ text "general:action.accept" }}</span>
|
|
|
|
</button>
|
|
|
|
|
|
|
|
<button
|
|
|
|
class="quaternary red"
|
|
|
|
onclick="remove_request('{{ request.id }}', '{{ request.linked_asset }}')"
|
|
|
|
>
|
|
|
|
{{ icon "trash" }}
|
|
|
|
<span>{{ text "general:action.delete" }}</span>
|
|
|
|
</button>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
2025-04-12 22:25:54 -04:00
|
|
|
{% endif %} {% endfor %} {% for question in questions %}
|
|
|
|
<!-- prettier-ignore -->
|
|
|
|
<div class="card-nest">
|
|
|
|
{{ components::question(question=question[0], owner=question[1]) }}
|
|
|
|
|
|
|
|
<form
|
|
|
|
class="card flex flex-col gap-2"
|
|
|
|
onsubmit="answer_question_from_form(event, '{{ question[0].id }}')"
|
|
|
|
>
|
|
|
|
<div class="flex flex-col gap-1">
|
|
|
|
<label for="content">{{ text "communities:label.content" }}</label>
|
|
|
|
<textarea
|
|
|
|
type="text"
|
|
|
|
name="content"
|
|
|
|
id="content"
|
|
|
|
placeholder="content"
|
|
|
|
required
|
|
|
|
minlength="2"
|
|
|
|
maxlength="4096"
|
|
|
|
></textarea>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="flex gap-2">
|
|
|
|
<button class="primary">{{ text "requests:label.answer" }}</button>
|
2025-04-13 12:15:14 -04:00
|
|
|
<button class="red quaternary" onclick="trigger('me::remove_question', ['{{ question[0].id }}'])">{{ text "general:action.delete" }}</button>
|
2025-04-12 22:25:54 -04:00
|
|
|
</div>
|
|
|
|
</form>
|
|
|
|
</div>
|
|
|
|
{% endfor %}
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</main>
|
|
|
|
|
|
|
|
<script>
|
|
|
|
async function remove_request(id, linked_asset) {
|
|
|
|
if (
|
|
|
|
!(await trigger("atto::confirm", [
|
|
|
|
"Are you sure you want to do this?",
|
|
|
|
]))
|
|
|
|
) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
fetch(`/api/v1/requests/${id}/${linked_asset}`, {
|
|
|
|
method: "DELETE",
|
|
|
|
})
|
|
|
|
.then((res) => res.json())
|
|
|
|
.then((res) => {
|
|
|
|
trigger("atto::toast", [
|
|
|
|
res.ok ? "success" : "error",
|
|
|
|
res.message,
|
|
|
|
]);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
async function clear_requests() {
|
|
|
|
if (
|
|
|
|
!(await trigger("atto::confirm", [
|
|
|
|
"Are you sure you want to do this?",
|
|
|
|
]))
|
|
|
|
) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
fetch("/api/v1/requests/my", {
|
|
|
|
method: "DELETE",
|
|
|
|
})
|
|
|
|
.then((res) => res.json())
|
|
|
|
.then((res) => {
|
|
|
|
trigger("atto::toast", [
|
|
|
|
res.ok ? "success" : "error",
|
|
|
|
res.message,
|
|
|
|
]);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
async function answer_question_from_form(e, answering) {
|
|
|
|
e.preventDefault();
|
|
|
|
await trigger("atto::debounce", ["posts::create"]);
|
|
|
|
fetch("/api/v1/posts", {
|
|
|
|
method: "POST",
|
|
|
|
headers: {
|
|
|
|
"Content-Type": "application/json",
|
|
|
|
},
|
|
|
|
body: JSON.stringify({
|
|
|
|
content: e.target.content.value,
|
|
|
|
community: "{{ config.town_square }}",
|
|
|
|
answering,
|
|
|
|
}),
|
|
|
|
})
|
|
|
|
.then((res) => res.json())
|
|
|
|
.then((res) => {
|
|
|
|
trigger("atto::toast", [
|
|
|
|
res.ok ? "success" : "error",
|
|
|
|
res.message,
|
|
|
|
]);
|
|
|
|
|
|
|
|
if (res.ok) {
|
|
|
|
e.target.parentElement.remove();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
2025-04-14 17:21:52 -04:00
|
|
|
|
|
|
|
globalThis.accept_follow_request = async (e, id) => {
|
|
|
|
await trigger("atto::debounce", ["users::follow"]);
|
|
|
|
|
|
|
|
if (
|
|
|
|
!(await trigger("atto::confirm", [
|
|
|
|
"Are you sure you would like to do this?",
|
|
|
|
]))
|
|
|
|
) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
fetch(`/api/v1/auth/user/${id}/follow/accept`, {
|
|
|
|
method: "POST",
|
|
|
|
})
|
|
|
|
.then((res) => res.json())
|
|
|
|
.then(async (res) => {
|
|
|
|
trigger("atto::toast", [
|
|
|
|
res.ok ? "success" : "error",
|
|
|
|
res.message,
|
|
|
|
]);
|
|
|
|
|
|
|
|
if (res.ok) {
|
|
|
|
e.target.parentElement.parentElement.parentElement.parentElement.remove();
|
|
|
|
|
|
|
|
if (
|
|
|
|
await trigger("atto::confirm", [
|
|
|
|
"Would you like to follow this user back? This will allow them to view your profile.",
|
|
|
|
])
|
|
|
|
) {
|
|
|
|
fetch(`/api/v1/auth/user/${id}/follow`, {
|
|
|
|
method: "POST",
|
|
|
|
})
|
|
|
|
.then((res) => res.json())
|
|
|
|
.then((res) => {
|
|
|
|
trigger("atto::toast", [
|
|
|
|
res.ok ? "success" : "error",
|
|
|
|
res.message,
|
|
|
|
]);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
};
|
2025-04-12 22:25:54 -04:00
|
|
|
</script>
|
|
|
|
{% endblock %}
|