fix promise loading

This commit is contained in:
2023-02-27 22:51:36 +10:00
parent b1769a3326
commit c6b088fdf9

View File

@@ -90,126 +90,125 @@ let postsTotal = ref(0);
* Load page data. * Load page data.
*/ */
const handleLoad = async () => { const handleLoad = async () => {
let query = {}; try {
let query = {};
if (filterKeywords.value && filterKeywords.value.length > 0) { if (filterKeywords.value && filterKeywords.value.length > 0) {
query["q"] = filterKeywords.value; query["q"] = filterKeywords.value;
}
if (filterLocation.value && filterLocation.value.length > 0) {
query["qlocation"] = filterLocation.value;
}
if (filterDateRange.value && filterDateRange.value.length > 0) {
let error = false;
const filterDates = filterDateRange.value
.split(/ *- */)
.map((dateString) => {
const date = new SMDate(dateString).format("yyyy/MM/dd");
if (date.length == 0) {
error = true;
}
return date;
});
if (!error) {
if (filterDates.length == 1) {
query["start_at"] = `>=${filterDates[0]}`;
} else if (filterDates.length >= 2) {
query["start_at"] = `${filterDates[0]}<>${filterDates[1]}`;
}
dateRangeError.value = "";
} else {
dateRangeError.value = "Invalid date range";
return;
} }
} else { if (filterLocation.value && filterLocation.value.length > 0) {
dateRangeError.value = ""; query["qlocation"] = filterLocation.value;
} }
if (filterDateRange.value && filterDateRange.value.length > 0) {
let error = false;
const filterDates = filterDateRange.value
.split(/ *- */)
.map((dateString) => {
const date = new SMDate(dateString).format("yyyy/MM/dd");
loading.value = true; if (date.length == 0) {
formMessage.value = ""; error = true;
events = [];
if (Object.keys(query).length == 0) {
const now = new Date();
const startingDate = new Date(now.setDate(now.getDate() - 14));
query["end_at"] =
">" +
new SMDate(startingDate).format("yyyy/MM/dd HH:mm:ss", {
utc: true,
});
}
query["limit"] = postsPerPage;
query["page"] = postsPage.value;
api.get({
url: "/events",
params: query,
})
.then((result) => {
const data = result.data as EventCollection;
postsTotal.value = data.total;
if (data && data.events) {
events = [];
data.events.forEach((item) => {
let banner = "";
let bannerType = "";
const parsedStartAt = new SMDate(item.start_at, {
format: "yyyy-MM-dd HH:mm:ss",
utc: true,
});
const parsedEndAt = new SMDate(item.end_at, {
format: "yyyy-MM-dd HH:mm:ss",
utc: true,
});
item.start_at = parsedStartAt.format("yyyy-MM-dd HH:mm:ss");
item.end_at = parsedEndAt.format("yyyy-MM-dd HH:mm:ss");
if (
parsedEndAt.isBefore(new SMDate("now")) ||
item.status == "closed"
) {
banner = "closed";
bannerType = "expired";
} else if (item.status == "open") {
banner = "open";
bannerType = "success";
} else if (item.status == "cancelled") {
banner = "cancelled";
bannerType = "danger";
} else if (item.status == "soon") {
banner = "Open Soon";
bannerType = "warning";
} }
events.push({ return date;
event: item,
banner: banner,
bannerType: bannerType,
});
}); });
if (!error) {
if (filterDates.length == 1) {
query["start_at"] = `>=${filterDates[0]}`;
} else if (filterDates.length >= 2) {
query["start_at"] = `${filterDates[0]}<>${filterDates[1]}`;
}
dateRangeError.value = "";
} else {
dateRangeError.value = "Invalid date range";
return;
} }
}) } else {
.catch((error) => { dateRangeError.value = "";
if (error.status != 404) { }
formMessage.value =
error.response?.data?.message || loading.value = true;
"Could not load any events from the server."; formMessage.value = "";
} events = [];
})
.finally(() => { if (Object.keys(query).length == 0) {
loading.value = false; const now = new Date();
const startingDate = new Date(now.setDate(now.getDate() - 14));
query["end_at"] =
">" +
new SMDate(startingDate).format("yyyy/MM/dd HH:mm:ss", {
utc: true,
});
}
query["limit"] = postsPerPage;
query["page"] = postsPage.value;
let result = await api.get({
url: "/events",
params: query,
}); });
const data = result.data as EventCollection;
postsTotal.value = data.total;
if (data && data.events) {
events = [];
data.events.forEach((item) => {
let banner = "";
let bannerType = "";
const parsedStartAt = new SMDate(item.start_at, {
format: "yyyy-MM-dd HH:mm:ss",
utc: true,
});
const parsedEndAt = new SMDate(item.end_at, {
format: "yyyy-MM-dd HH:mm:ss",
utc: true,
});
item.start_at = parsedStartAt.format("yyyy-MM-dd HH:mm:ss");
item.end_at = parsedEndAt.format("yyyy-MM-dd HH:mm:ss");
if (
parsedEndAt.isBefore(new SMDate("now")) ||
item.status == "closed"
) {
banner = "closed";
bannerType = "expired";
} else if (item.status == "open") {
banner = "open";
bannerType = "success";
} else if (item.status == "cancelled") {
banner = "cancelled";
bannerType = "danger";
} else if (item.status == "soon") {
banner = "Open Soon";
bannerType = "warning";
}
events.push({
event: item,
banner: banner,
bannerType: bannerType,
});
});
}
} catch (error) {
if (error.status != 404) {
formMessage.value =
error.response?.data?.message ||
"Could not load any events from the server.";
}
} finally {
loading.value = false;
}
}; };
const handleFilter = async () => { const handleFilter = async () => {