Skip to content

Commit

Permalink
allow admins to visit all pages
Browse files Browse the repository at this point in the history
  • Loading branch information
reyniersbram committed May 22, 2024
1 parent 1aa668e commit ade32df
Showing 1 changed file with 23 additions and 19 deletions.
42 changes: 23 additions & 19 deletions frontend/src/router/middleware/canVisit.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { computed, inject, type Ref } from "vue";
import { computed, type Ref } from "vue";
import type { Middleware, MiddlewareContext } from "./index";
import { QueryClient } from "@tanstack/vue-query";
import useIsAdmin from "@/composables/useIsAdmin";
Expand All @@ -15,30 +15,34 @@ export interface CanVisitCondition {
): { condition: Ref<boolean>; isLoading: Ref<boolean> };
}

function useAwaitLoading(isLoading: Ref<boolean>): Promise<void> {
return new Promise<void>((resolve) => {
const interval = setInterval(() => {
if (!isLoading.value) {
clearInterval(interval);
resolve();
}
}, 10);
});
}

function useCanVisit(useCondition: CanVisitCondition): Middleware {
return async (context) => {
const { next } = context;
// TODO: Figure out why this doesn't work anymore
// const queryClient = inject<QueryClient>("queryClient", new QueryClient());
const queryClient = new QueryClient();
const { condition: isAdmin, isLoading: isAdminLoading } = useIsAdminCondition(
queryClient,
context
);
const { condition, isLoading } = useCondition(queryClient, context);
const awaitLoading = () =>
new Promise<void>((resolve) => {
const interval = setInterval(() => {
if (!isLoading.value) {
clearInterval(interval);
resolve();
}
}, 10);
});
await awaitLoading();
if (!condition.value) {
return {
next: () => next({ path: "not-found" }),
final: true,
};
await useAwaitLoading(computed(() => isAdminLoading.value || isLoading.value));
if (isAdmin.value || condition.value) {
return { next, final: false };
}
return { next, final: false };
return {
next: () => next({ path: "not-found" }),
final: true,
};
};
}

Expand Down

0 comments on commit ade32df

Please sign in to comment.