diff --git a/editor.planx.uk/src/pages/layout/LoadingLayout.tsx b/editor.planx.uk/src/pages/layout/LoadingLayout.tsx
index 3198b87999..4d8019a494 100644
--- a/editor.planx.uk/src/pages/layout/LoadingLayout.tsx
+++ b/editor.planx.uk/src/pages/layout/LoadingLayout.tsx
@@ -5,6 +5,7 @@ import { useLoadingRoute, View } from "react-navi";
export const loadingView = () => ;
export const LoadingLayout = () => {
+ console.log("LOADING LAYOUT");
const isLoading = useLoadingRoute();
return isLoading ? : ;
};
diff --git a/editor.planx.uk/src/routes/index.tsx b/editor.planx.uk/src/routes/index.tsx
index c1cad20ee9..73c77abf78 100644
--- a/editor.planx.uk/src/routes/index.tsx
+++ b/editor.planx.uk/src/routes/index.tsx
@@ -57,38 +57,48 @@ const editorRoutes = mount({
),
});
-const mountPayRoutes = () =>
- map(async () => {
- compose(withView(loadingView));
- return lazy(() => import("./pay"));
- });
+const loadPayRoutes = () =>
+ compose(
+ withView(loadingView),
+ lazy(() => import("./pay")),
+ );
-export default isPreviewOnlyDomain
- ? compose(
- withView(loadingView),
+const loadPublishedRoutes = () =>
+ compose(
+ withView(loadingView),
+ lazy(() => import("./published")),
+ );
+
+const loadPreviewRoutes = () =>
+ compose(
+ withView(loadingView),
+ lazy(() => import("./preview")),
+ );
- mount({
- "/:team/:flow/published": lazy(() => import("./published")), // XXX: keeps old URL working, but only for the team listed in the domain.
- "/:flow": lazy(() => import("./published")),
- "/:flow/pay": mountPayRoutes(),
- // XXX: We're not sure where to redirect `/` to so for now we'll just return the default 404
- // "/": redirect("somewhere?"),
- }),
- )
- : compose(
- withView(loadingView),
+const loadDraftRoutes = () =>
+ compose(
+ withView(loadingView),
+ lazy(() => import("./draft")),
+ );
- mount({
- "/:team/:flow/published": lazy(() => import("./published")), // loads current published flow if exists, or throws Not Found if unpublished
- "/canterbury/find-out-if-you-need-planning-permission/preview": map(
- async (req) =>
- redirect(
- `/canterbury/find-out-if-you-need-planning-permission/published${req?.search}`,
- ),
- ), // temporary redirect while Canterbury works with internal IT to update advertised service links
- "/:team/:flow/preview": lazy(() => import("./preview")), // loads current draft flow and latest published external portals, or throws Not Found if any external portal is unpublished
- "/:team/:flow/draft": lazy(() => import("./draft")), // loads current draft flow and draft external portals
- "/:team/:flow/pay": mountPayRoutes(),
- "*": editorRoutes,
- }),
- );
+export default isPreviewOnlyDomain
+ ? mount({
+ "/:team/:flow/published": loadPublishedRoutes(), // XXX: keeps old URL working, but only for the team listed in the domain.
+ "/:flow": loadPublishedRoutes(),
+ "/:flow/pay": loadPayRoutes(),
+ // XXX: We're not sure where to redirect `/` to so for now we'll just return the default 404
+ // "/": redirect("somewhere?"),
+ })
+ : mount({
+ "/:team/:flow/published": loadPublishedRoutes(), // loads current published flow if exists, or throws Not Found if unpublished
+ "/canterbury/find-out-if-you-need-planning-permission/preview": map(
+ async (req) =>
+ redirect(
+ `/canterbury/find-out-if-you-need-planning-permission/published${req?.search}`,
+ ),
+ ), // temporary redirect while Canterbury works with internal IT to update advertised service links
+ "/:team/:flow/preview": loadPreviewRoutes(), // loads current draft flow and latest published external portals, or throws Not Found if any external portal is unpublished
+ "/:team/:flow/draft": loadDraftRoutes(), // loads current draft flow and draft external portals
+ "/:team/:flow/pay": loadPayRoutes(),
+ "*": editorRoutes,
+ });