mirror of
https://github.com/Drop-OSS/drop.git
synced 2025-11-13 00:02:37 +10:00
uses the VueCarousel library to add an actual carousel to the store page for the images. uses responsive styles
25 lines
698 B
TypeScript
25 lines
698 B
TypeScript
const whitelistedPrefixes = ["/signin", "/register", "/api", "/setup"];
|
|
const requireAdmin = ["/admin"];
|
|
|
|
export default defineNuxtRouteMiddleware(async (to, from) => {
|
|
if (import.meta.server) return;
|
|
const error = useError();
|
|
if (error.value !== undefined) return;
|
|
if (whitelistedPrefixes.findIndex((e) => to.fullPath.startsWith(e)) != -1)
|
|
return;
|
|
|
|
const user = useUser();
|
|
if (user === undefined) {
|
|
await updateUser();
|
|
}
|
|
if (!user.value) {
|
|
return navigateTo({ path: "/signin", query: { redirect: to.fullPath } });
|
|
}
|
|
if (
|
|
requireAdmin.findIndex((e) => to.fullPath.startsWith(e)) != -1 &&
|
|
!user.value.admin
|
|
) {
|
|
return navigateTo({ path: "/" });
|
|
}
|
|
});
|