graceful shutdown
This commit is contained in:
@ -9,7 +9,7 @@ mod routes;
|
||||
use std::{collections::HashMap, env};
|
||||
|
||||
use oauth2::{basic::BasicClient, AuthUrl, ClientId, ClientSecret, RedirectUrl, TokenUrl};
|
||||
use rocket::fs::FileServer;
|
||||
use rocket::{fs::FileServer, tokio::sync::broadcast::Sender};
|
||||
use rocket_dyn_templates::Template;
|
||||
use serenity::{
|
||||
client::Context,
|
||||
@ -53,6 +53,7 @@ async fn internal_server_error() -> Template {
|
||||
}
|
||||
|
||||
pub async fn initialize(
|
||||
kill_channel: Sender<()>,
|
||||
serenity_context: Context,
|
||||
db_pool: Pool<Database>,
|
||||
) -> Result<(), Box<dyn std::error::Error>> {
|
||||
@ -119,6 +120,10 @@ pub async fn initialize(
|
||||
.launch()
|
||||
.await?;
|
||||
|
||||
warn!("Exiting rocket runtime");
|
||||
// distribute kill signal
|
||||
kill_channel.send(());
|
||||
|
||||
Ok(())
|
||||
}
|
||||
|
||||
|
@ -57,6 +57,14 @@ button.change-color {
|
||||
left: calc(-1rem - 40px);
|
||||
}
|
||||
|
||||
button.disable-enable[data-action="enable"]:after {
|
||||
content: "Enable";
|
||||
}
|
||||
|
||||
button.disable-enable[data-action="disable"]:after {
|
||||
content: "Disable";
|
||||
}
|
||||
|
||||
.media-content {
|
||||
overflow-x: visible;
|
||||
}
|
||||
|
@ -3,10 +3,7 @@ let $discordFrame;
|
||||
const $loader = document.querySelector("#loader");
|
||||
const $colorPickerModal = document.querySelector("div#pickColorModal");
|
||||
const $colorPickerInput = $colorPickerModal.querySelector("input");
|
||||
|
||||
let timezone = luxon.DateTime.now().zone.name;
|
||||
const browserTimezone = luxon.DateTime.now().zone.name;
|
||||
let botTimezone = "UTC";
|
||||
const $deleteReminderBtn = document.querySelector("#delete-reminder-confirm");
|
||||
|
||||
let channels;
|
||||
let roles;
|
||||
@ -75,6 +72,8 @@ function fetch_roles(guild_id) {
|
||||
}
|
||||
|
||||
async function fetch_reminders(guild_id) {
|
||||
document.dispatchEvent(new Event("remindersLoading"));
|
||||
|
||||
const $reminderBox = document.querySelector("div#guildReminders");
|
||||
|
||||
// reset div contents
|
||||
@ -113,7 +112,6 @@ async function fetch_reminders(guild_id) {
|
||||
}
|
||||
|
||||
let $enableBtn = newFrame.querySelector(".disable-enable");
|
||||
$enableBtn.textContent = reminder["enabled"] ? "Disable" : "Enable";
|
||||
$enableBtn.dataset.action = reminder["enabled"]
|
||||
? "disable"
|
||||
: "enable";
|
||||
@ -164,14 +162,36 @@ document.addEventListener("remindersLoaded", (event) => {
|
||||
if (data.error) {
|
||||
show_error(data.error);
|
||||
} else {
|
||||
enableBtn.textContent = data["enabled"] ? "Disable" : "Enable";
|
||||
enableBtn.dataset.action = data["enabled"] ? "enable" : "disable";
|
||||
}
|
||||
});
|
||||
});
|
||||
|
||||
reminder.node
|
||||
.querySelector("button.delete-reminder")
|
||||
.addEventListener("click", () => {
|
||||
let uid = reminder.node.closest(".reminderContent").dataset.uid;
|
||||
|
||||
$deleteReminderBtn.dataset["uid"] = uid;
|
||||
$deleteReminderBtn.closest(".modal").classList.toggle("is-active");
|
||||
});
|
||||
}
|
||||
});
|
||||
|
||||
$deleteReminderBtn.addEventListener("click", () => {
|
||||
let guild = document.querySelector(".guildList a.is-active").dataset["guild"];
|
||||
|
||||
fetch(`/dashboard/api/guild/${guild}/reminders`, {
|
||||
method: "DELETE",
|
||||
body: JSON.stringify({
|
||||
uid: $deleteReminderBtn.dataset["uid"],
|
||||
}),
|
||||
}).then(() => {
|
||||
document.querySelector("#deleteReminderModal").classList.remove("is-active");
|
||||
fetch_reminders(guild);
|
||||
});
|
||||
});
|
||||
|
||||
function show_error(error) {
|
||||
document.getElementById("errors").querySelector("span.error-message").textContent =
|
||||
error;
|
||||
@ -182,60 +202,6 @@ function show_error(error) {
|
||||
}, 5000);
|
||||
}
|
||||
|
||||
function update_times() {
|
||||
document.querySelectorAll("span.set-timezone").forEach((element) => {
|
||||
element.textContent = timezone;
|
||||
});
|
||||
document.querySelectorAll("span.set-time").forEach((element) => {
|
||||
element.textContent = luxon.DateTime.now().setZone(timezone).toFormat("HH:mm");
|
||||
});
|
||||
document.querySelectorAll("span.browser-timezone").forEach((element) => {
|
||||
element.textContent = browserTimezone;
|
||||
});
|
||||
document.querySelectorAll("span.browser-time").forEach((element) => {
|
||||
element.textContent = luxon.DateTime.now().toFormat("HH:mm");
|
||||
});
|
||||
document.querySelectorAll("span.bot-timezone").forEach((element) => {
|
||||
element.textContent = botTimezone;
|
||||
});
|
||||
document.querySelectorAll("span.bot-time").forEach((element) => {
|
||||
element.textContent = luxon.DateTime.now().setZone(botTimezone).toFormat("HH:mm");
|
||||
});
|
||||
}
|
||||
|
||||
window.setInterval(() => {
|
||||
update_times();
|
||||
}, 30000);
|
||||
|
||||
document.getElementById("set-bot-timezone").addEventListener("click", () => {
|
||||
timezone = botTimezone;
|
||||
update_times();
|
||||
});
|
||||
document.getElementById("set-browser-timezone").addEventListener("click", () => {
|
||||
timezone = browserTimezone;
|
||||
update_times();
|
||||
});
|
||||
document.getElementById("update-bot-timezone").addEventListener("click", () => {
|
||||
timezone = browserTimezone;
|
||||
fetch("/dashboard/api/user", {
|
||||
method: "PATCH",
|
||||
headers: {
|
||||
Accept: "application/json",
|
||||
"Content-Type": "application/json",
|
||||
},
|
||||
body: JSON.stringify({ timezone: timezone }),
|
||||
})
|
||||
.then((response) => response.json())
|
||||
.then((data) => {
|
||||
if (data.error) {
|
||||
show_error(data.error);
|
||||
} else {
|
||||
botTimezone = browserTimezone;
|
||||
update_times();
|
||||
}
|
||||
});
|
||||
});
|
||||
|
||||
$colorPickerInput.value = colorPicker.color.hexString;
|
||||
|
||||
$colorPickerInput.addEventListener("input", () => {
|
||||
@ -482,6 +448,7 @@ $createReminder.querySelector("button#createReminder").addEventListener("click",
|
||||
.then((data) => console.log(data));
|
||||
|
||||
// process response
|
||||
fetch_reminders(guild);
|
||||
|
||||
// reset inputs
|
||||
});
|
||||
|
57
web/static/js/timezone.js
Normal file
57
web/static/js/timezone.js
Normal file
@ -0,0 +1,57 @@
|
||||
let timezone = luxon.DateTime.now().zone.name;
|
||||
const browserTimezone = luxon.DateTime.now().zone.name;
|
||||
let botTimezone = "UTC";
|
||||
|
||||
function update_times() {
|
||||
document.querySelectorAll("span.set-timezone").forEach((element) => {
|
||||
element.textContent = timezone;
|
||||
});
|
||||
document.querySelectorAll("span.set-time").forEach((element) => {
|
||||
element.textContent = luxon.DateTime.now().setZone(timezone).toFormat("HH:mm");
|
||||
});
|
||||
document.querySelectorAll("span.browser-timezone").forEach((element) => {
|
||||
element.textContent = browserTimezone;
|
||||
});
|
||||
document.querySelectorAll("span.browser-time").forEach((element) => {
|
||||
element.textContent = luxon.DateTime.now().toFormat("HH:mm");
|
||||
});
|
||||
document.querySelectorAll("span.bot-timezone").forEach((element) => {
|
||||
element.textContent = botTimezone;
|
||||
});
|
||||
document.querySelectorAll("span.bot-time").forEach((element) => {
|
||||
element.textContent = luxon.DateTime.now().setZone(botTimezone).toFormat("HH:mm");
|
||||
});
|
||||
}
|
||||
|
||||
window.setInterval(() => {
|
||||
update_times();
|
||||
}, 30000);
|
||||
|
||||
document.getElementById("set-bot-timezone").addEventListener("click", () => {
|
||||
timezone = botTimezone;
|
||||
update_times();
|
||||
});
|
||||
document.getElementById("set-browser-timezone").addEventListener("click", () => {
|
||||
timezone = browserTimezone;
|
||||
update_times();
|
||||
});
|
||||
document.getElementById("update-bot-timezone").addEventListener("click", () => {
|
||||
timezone = browserTimezone;
|
||||
fetch("/dashboard/api/user", {
|
||||
method: "PATCH",
|
||||
headers: {
|
||||
Accept: "application/json",
|
||||
"Content-Type": "application/json",
|
||||
},
|
||||
body: JSON.stringify({ timezone: timezone }),
|
||||
})
|
||||
.then((response) => response.json())
|
||||
.then((data) => {
|
||||
if (data.error) {
|
||||
show_error(data.error);
|
||||
} else {
|
||||
botTimezone = browserTimezone;
|
||||
update_times();
|
||||
}
|
||||
});
|
||||
});
|
@ -140,6 +140,27 @@
|
||||
<button class="modal-close is-large close-modal" aria-label="close"></button>
|
||||
</div>
|
||||
|
||||
<div class="modal" id="deleteReminderModal">
|
||||
<div class="modal-background"></div>
|
||||
<div class="modal-card">
|
||||
<header class="modal-card-head">
|
||||
<label class="modal-card-title" for="urlInput">Delete Reminder</label>
|
||||
<button class="delete close-modal" aria-label="close"></button>
|
||||
</header>
|
||||
<section class="modal-card-body">
|
||||
<p>
|
||||
This reminder will be permenantly deleted. Are you sure?
|
||||
</p>
|
||||
<br>
|
||||
<div class="has-text-centered">
|
||||
<button class="button is-danger" id="delete-reminder-confirm">Delete</button>
|
||||
<button class="button is-light close-modal">Cancel</button>
|
||||
</div>
|
||||
</section>
|
||||
</div>
|
||||
<button class="modal-close is-large close-modal" aria-label="close"></button>
|
||||
</div>
|
||||
|
||||
<div class="columns is-gapless dashboard-frame">
|
||||
<div class="column is-2 is-sidebar-menu dashboard-sidebar is-hidden-touch" style="display: flex; flex-direction: column;">
|
||||
<a href="/">
|
||||
@ -300,6 +321,7 @@
|
||||
{% include "reminder_dashboard/personal_reminder" %}
|
||||
</template>
|
||||
|
||||
<script src="/static/js/timezone.js"></script>
|
||||
<script src="/static/js/main.js"></script>
|
||||
|
||||
</body>
|
||||
|
@ -215,9 +215,8 @@
|
||||
Saved!
|
||||
</button>
|
||||
<button class="button is-warning disable-enable">
|
||||
Disable
|
||||
</button>
|
||||
<button class="button is-danger">
|
||||
<button class="button is-danger delete-reminder">
|
||||
Delete
|
||||
</button>
|
||||
{% endif %}
|
||||
|
Reference in New Issue
Block a user