From 05e665fe3885dc65a15f9edfd863021fd10859a0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Dafydd=20Ll=C5=B7r=20Pearson?= Date: Wed, 29 May 2024 11:05:00 +0100 Subject: [PATCH] feat: Route to offline page based on flow status --- .../ui-driven/src/create-flow/create-flow.spec.ts | 4 +++- .../src/pages/FlowEditor/lib/store/shared.ts | 7 +++++-- editor.planx.uk/src/pages/OfflinePage.tsx | 11 +++++++++++ editor.planx.uk/src/routes/published.tsx | 12 +++++++++++- editor.planx.uk/src/routes/views/published.tsx | 8 +++++++- editor.planx.uk/src/types.ts | 6 ++++-- 6 files changed, 41 insertions(+), 7 deletions(-) create mode 100644 editor.planx.uk/src/pages/OfflinePage.tsx diff --git a/e2e/tests/ui-driven/src/create-flow/create-flow.spec.ts b/e2e/tests/ui-driven/src/create-flow/create-flow.spec.ts index f003cb5045..7d86cb19a9 100644 --- a/e2e/tests/ui-driven/src/create-flow/create-flow.spec.ts +++ b/e2e/tests/ui-driven/src/create-flow/create-flow.spec.ts @@ -193,7 +193,9 @@ test.describe("Navigation", () => { `/${context.team.slug}/${serviceProps.slug}/published?analytics=false`, ); - await expect(page.getByText("Not Found")).toBeVisible(); + await expect( + page.getByRole("heading", { level: 1, name: "Offline" }), + ).toBeVisible(); }); test("Turn a flow online", async ({ browser }) => { diff --git a/editor.planx.uk/src/pages/FlowEditor/lib/store/shared.ts b/editor.planx.uk/src/pages/FlowEditor/lib/store/shared.ts index d7143dfa3e..3b4381a463 100644 --- a/editor.planx.uk/src/pages/FlowEditor/lib/store/shared.ts +++ b/editor.planx.uk/src/pages/FlowEditor/lib/store/shared.ts @@ -1,5 +1,6 @@ import { CoreDomainClient } from "@opensystemslab/planx-core"; import { Auth } from "@opensystemslab/planx-core/dist/requests/graphql"; +import { FlowStatus } from "@opensystemslab/planx-core/types"; import { ROOT_NODE_KEY } from "@planx/graph"; import { capitalize } from "lodash"; import { removeSessionIdSearchParam } from "utils"; @@ -23,10 +24,12 @@ export interface SharedStore extends Store.Store { id, flow, flowSlug, + flowStatus, }: { id: string; flow: Store.flow; flowSlug: string; + flowStatus?: FlowStatus; }) => void; wasVisited: (id: Store.nodeId) => boolean; previewEnvironment: PreviewEnvironment; @@ -88,9 +91,9 @@ export const sharedStore: StateCreator< removeSessionIdSearchParam(); }, - setFlow({ id, flow, flowSlug }) { + setFlow({ id, flow, flowSlug, flowStatus }) { this.setFlowNameFromSlug(flowSlug); - set({ id, flow, flowSlug }); + set({ id, flow, flowSlug, flowStatus }); get().initNavigationStore(); }, diff --git a/editor.planx.uk/src/pages/OfflinePage.tsx b/editor.planx.uk/src/pages/OfflinePage.tsx new file mode 100644 index 0000000000..ede316160b --- /dev/null +++ b/editor.planx.uk/src/pages/OfflinePage.tsx @@ -0,0 +1,11 @@ +import Typography from "@mui/material/Typography"; +import StatusPage from "pages/Preview/StatusPage"; +import React from "react"; + +export const OfflinePage: React.FC = () => ( + + + This service is not currently available. Please check back later. + + +); diff --git a/editor.planx.uk/src/routes/published.tsx b/editor.planx.uk/src/routes/published.tsx index 0a14cc6073..bcf02182fe 100644 --- a/editor.planx.uk/src/routes/published.tsx +++ b/editor.planx.uk/src/routes/published.tsx @@ -1,4 +1,6 @@ import { compose, map, mount, route, withData, withView } from "navi"; +import { useStore } from "pages/FlowEditor/lib/store"; +import { OfflinePage } from "pages/OfflinePage"; import ContentPage from "pages/Preview/ContentPage"; import Questions from "pages/Preview/Questions"; import React from "react"; @@ -25,7 +27,15 @@ const routes = compose( mount({ "/": route({ - view: , + view: () => { + const isOnline = useStore.getState().flowStatus === "online"; + + return isOnline ? ( + + ) : ( + + ); + }, }), "/pages/:page": map((req) => { return route({ diff --git a/editor.planx.uk/src/routes/views/published.tsx b/editor.planx.uk/src/routes/views/published.tsx index d22deb94b7..adaf717083 100644 --- a/editor.planx.uk/src/routes/views/published.tsx +++ b/editor.planx.uk/src/routes/views/published.tsx @@ -43,7 +43,12 @@ export const publishedView = async (req: NaviRequest) => { const state = useStore.getState(); // XXX: necessary as long as not every flow is published; aim to remove dataMergedHotfix.ts in future // load pre-flattened published flow if exists, else load & flatten flow - state.setFlow({ id: flow.id, flow: publishedFlow, flowSlug }); + state.setFlow({ + id: flow.id, + flow: publishedFlow, + flowSlug, + flowStatus: flow.status, + }); state.setGlobalSettings(data.globalSettings[0]); state.setFlowSettings(flow.settings); state.setTeam(flow.team); @@ -94,6 +99,7 @@ export const fetchSettingsForPublishedView = async ( boundaryBBox: boundary_bbox } settings + status publishedFlows: published_flows( limit: 1 order_by: { created_at: desc } diff --git a/editor.planx.uk/src/types.ts b/editor.planx.uk/src/types.ts index c2b0b36e3d..ccb534ba1e 100644 --- a/editor.planx.uk/src/types.ts +++ b/editor.planx.uk/src/types.ts @@ -1,13 +1,14 @@ import { + FlowStatus, GovUKPayment, NotifyPersonalisation, Team, } from "@opensystemslab/planx-core/types"; +import { OT } from "@planx/graph/types"; import { useFormik } from "formik"; import { Store } from "./pages/FlowEditor/lib/store/index"; import { SharedStore } from "./pages/FlowEditor/lib/store/shared"; -import { OT } from "@planx/graph/types"; export type Maybe = T | undefined; @@ -18,6 +19,7 @@ export interface Flow { slug: string; team: Team; settings?: FlowSettings; + status?: FlowStatus; } export interface GlobalSettings { footerContent?: { [key: string]: TextContent }; @@ -133,4 +135,4 @@ export interface Operation { lastName: string; }; data: Array; -} \ No newline at end of file +}