From e35f3b214627d8f2008e88544b8d7589a3c541b2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Dafydd=20Ll=C5=B7r=20Pearson?= Date: Fri, 12 Apr 2024 15:49:12 +0100 Subject: [PATCH 1/8] chore(a11y): Re-order dropzone to be above file cards (#3016) --- .../PrivateFileUpload/PrivateFileUpload.tsx | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/editor.planx.uk/src/@planx/components/shared/PrivateFileUpload/PrivateFileUpload.tsx b/editor.planx.uk/src/@planx/components/shared/PrivateFileUpload/PrivateFileUpload.tsx index 573e9d5022..74b9ac1fcc 100644 --- a/editor.planx.uk/src/@planx/components/shared/PrivateFileUpload/PrivateFileUpload.tsx +++ b/editor.planx.uk/src/@planx/components/shared/PrivateFileUpload/PrivateFileUpload.tsx @@ -23,6 +23,14 @@ export const PrivateFileUpload: React.FC = ({ return ( <> + {hasEmptySlots && ( + + )} {slots.map((slot) => { return ( = ({ ); })} - {hasEmptySlots && ( - - )} ); }; From c772c4bc76898b14b8b2ea2cbc4fed9a706ede3e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Dafydd=20Ll=C5=B7r=20Pearson?= Date: Mon, 15 Apr 2024 10:40:08 +0100 Subject: [PATCH 2/8] fix(e2e): Revert change to GovPay journey (#3018) --- e2e/tests/ui-driven/src/pay.spec.ts | 5 ----- 1 file changed, 5 deletions(-) diff --git a/e2e/tests/ui-driven/src/pay.spec.ts b/e2e/tests/ui-driven/src/pay.spec.ts index fc1bd0c9e2..c5974ae55d 100644 --- a/e2e/tests/ui-driven/src/pay.spec.ts +++ b/e2e/tests/ui-driven/src/pay.spec.ts @@ -225,11 +225,6 @@ test.describe("Gov Pay integration @regression", async () => { // retry the payment await page.getByText("Retry payment").click(); await page.getByText("Continue with your payment").click(); - // Re-enter card details - await fillGovUkCardDetails({ - page, - cardNumber: cards.successful_card_number, - }); await submitCardDetails(page); const { paymentId } = await waitForPaymentResponse(page, context); From c57f7a5c94dc048631c3045af042c1d432b053f9 Mon Sep 17 00:00:00 2001 From: Jessica McInchak Date: Tue, 16 Apr 2024 09:15:47 +0100 Subject: [PATCH 3/8] feat: basic platform admin panel for checking onboarding status & available integrations (#3017) --- .../components/shared/Preview/SummaryList.tsx | 104 +++++------ editor.planx.uk/src/components/Header.tsx | 13 +- .../pages/FlowEditor/lib/store/settings.ts | 13 +- .../src/pages/PlatformAdminPanel.tsx | 168 ++++++++++++++++++ editor.planx.uk/src/routes/authenticated.tsx | 43 +++++ editor.planx.uk/src/types.ts | 26 ++- hasura.planx.uk/metadata/tables.yaml | 26 +++ .../down.sql | 1 + .../up.sql | 26 +++ 9 files changed, 364 insertions(+), 56 deletions(-) create mode 100644 editor.planx.uk/src/pages/PlatformAdminPanel.tsx create mode 100644 hasura.planx.uk/migrations/1713084872473_create_view_teams_summary/down.sql create mode 100644 hasura.planx.uk/migrations/1713084872473_create_view_teams_summary/up.sql diff --git a/editor.planx.uk/src/@planx/components/shared/Preview/SummaryList.tsx b/editor.planx.uk/src/@planx/components/shared/Preview/SummaryList.tsx index c76eea4eb9..eba2d82db3 100644 --- a/editor.planx.uk/src/@planx/components/shared/Preview/SummaryList.tsx +++ b/editor.planx.uk/src/@planx/components/shared/Preview/SummaryList.tsx @@ -20,63 +20,67 @@ const FIND_PROPERTY_DT = "Property address"; const DRAW_BOUNDARY_DT = "Location plan"; export const SummaryListTable = styled("dl", { - shouldForwardProp: (prop) => prop !== "showChangeButton", -})<{ showChangeButton?: boolean }>(({ theme, showChangeButton }) => ({ - display: "grid", - gridTemplateColumns: showChangeButton ? "1fr 2fr 100px" : "1fr 2fr", - gridRowGap: "10px", - marginTop: theme.spacing(2), - marginBottom: theme.spacing(4), - "& > *": { - borderBottom: `1px solid ${theme.palette.border.main}`, - paddingBottom: theme.spacing(2), - paddingTop: theme.spacing(2), - verticalAlign: "top", - margin: 0, - }, - "& ul": { - listStylePosition: "inside", - padding: 0, - margin: 0, - }, - "& dt": { - // left column - fontWeight: FONT_WEIGHT_SEMI_BOLD, - }, - "& dd:nth-of-type(n)": { - // middle column - paddingLeft: "10px", - }, - "& dd:nth-of-type(2n)": { - // right column - textAlign: showChangeButton ? "right" : "left", - }, - [theme.breakpoints.down("sm")]: { - display: "flex", - flexDirection: "column", + shouldForwardProp: (prop) => + !["showChangeButton", "dense"].includes(prop as string), +})<{ showChangeButton?: boolean; dense?: boolean }>( + ({ theme, showChangeButton, dense }) => ({ + display: "grid", + gridTemplateColumns: showChangeButton ? "1fr 2fr 100px" : "1fr 2fr", + gridRowGap: "10px", + marginTop: dense ? theme.spacing(1) : theme.spacing(2), + marginBottom: dense ? theme.spacing(2) : theme.spacing(4), + fontSize: dense ? theme.typography.body2.fontSize : "inherit", + "& > *": { + borderBottom: `1px solid ${theme.palette.border.main}`, + paddingBottom: dense ? theme.spacing(1) : theme.spacing(2), + paddingTop: dense ? theme.spacing(1) : theme.spacing(2), + verticalAlign: "top", + margin: 0, + }, + "& ul": { + listStylePosition: "inside", + padding: 0, + margin: 0, + }, "& dt": { - // top row - paddingLeft: theme.spacing(1), - paddingTop: theme.spacing(2), - marginTop: theme.spacing(1), - borderTop: `1px solid ${theme.palette.border.main}`, - borderBottom: "none", + // left column fontWeight: FONT_WEIGHT_SEMI_BOLD, }, "& dd:nth-of-type(n)": { - // middle row - textAlign: "left", - paddingTop: 0, - paddingBottom: 0, - margin: 0, - borderBottom: "none", + // middle column + paddingLeft: "10px", }, "& dd:nth-of-type(2n)": { - // bottom row - textAlign: "left", + // right column + textAlign: showChangeButton ? "right" : "left", + }, + [theme.breakpoints.down("sm")]: { + display: "flex", + flexDirection: "column", + "& dt": { + // top row + paddingLeft: theme.spacing(1), + paddingTop: dense ? theme.spacing(1) : theme.spacing(2), + marginTop: theme.spacing(1), + borderTop: `1px solid ${theme.palette.border.main}`, + borderBottom: "none", + fontWeight: FONT_WEIGHT_SEMI_BOLD, + }, + "& dd:nth-of-type(n)": { + // middle row + textAlign: "left", + paddingTop: 0, + paddingBottom: 0, + margin: 0, + borderBottom: "none", + }, + "& dd:nth-of-type(2n)": { + // bottom row + textAlign: "left", + }, }, - }, -})); + }), +); const presentationalComponents: { [key in TYPES]: React.FC | undefined; diff --git a/editor.planx.uk/src/components/Header.tsx b/editor.planx.uk/src/components/Header.tsx index 8d5ae9e540..0078c4d336 100644 --- a/editor.planx.uk/src/components/Header.tsx +++ b/editor.planx.uk/src/components/Header.tsx @@ -554,11 +554,16 @@ const EditorToolbar: React.FC<{ )} - {/* Only show global settings link from top-level admin view */} + {/* Only show global settings & admin panel links from top-level view */} {isGlobalSettingsVisible && ( - navigate("/global-settings")}> - Global Settings - + <> + navigate("/global-settings")}> + Global Settings + + navigate("/admin-panel")}> + Admin Panel + + )} navigate("/logout")}>Log out diff --git a/editor.planx.uk/src/pages/FlowEditor/lib/store/settings.ts b/editor.planx.uk/src/pages/FlowEditor/lib/store/settings.ts index 55504aa09d..6c0d6e3a88 100644 --- a/editor.planx.uk/src/pages/FlowEditor/lib/store/settings.ts +++ b/editor.planx.uk/src/pages/FlowEditor/lib/store/settings.ts @@ -1,7 +1,12 @@ import { gql } from "@apollo/client"; import camelcaseKeys from "camelcase-keys"; import { client } from "lib/graphql"; -import { FlowSettings, GlobalSettings, TextContent } from "types"; +import { + AdminPanelData, + FlowSettings, + GlobalSettings, + TextContent, +} from "types"; import type { StateCreator } from "zustand"; import { SharedStore } from "./shared"; @@ -14,6 +19,8 @@ export interface SettingsStore { setGlobalSettings: (globalSettings: GlobalSettings) => void; updateFlowSettings: (newSettings: FlowSettings) => Promise; updateGlobalSettings: (newSettings: { [key: string]: TextContent }) => void; + adminPanelData?: AdminPanelData[]; + setAdminPanelData: (adminPanelData: AdminPanelData[]) => void; } export const settingsStore: StateCreator< @@ -91,4 +98,8 @@ export const settingsStore: StateCreator< }, }); }, + + adminPanelData: undefined, + + setAdminPanelData: (adminPanelData) => set({ adminPanelData }), }); diff --git a/editor.planx.uk/src/pages/PlatformAdminPanel.tsx b/editor.planx.uk/src/pages/PlatformAdminPanel.tsx new file mode 100644 index 0000000000..8acb58c27f --- /dev/null +++ b/editor.planx.uk/src/pages/PlatformAdminPanel.tsx @@ -0,0 +1,168 @@ +import Close from "@mui/icons-material/Close"; +import Done from "@mui/icons-material/Done"; +import Accordion from "@mui/material/Accordion"; +import AccordionDetails from "@mui/material/AccordionDetails"; +import AccordionSummary from "@mui/material/AccordionSummary"; +import Box from "@mui/material/Box"; +import Grid from "@mui/material/Grid"; +import { styled } from "@mui/material/styles"; +import Typography from "@mui/material/Typography"; +import { SummaryListTable } from "@planx/components/shared/Preview/SummaryList"; +import { useStore } from "pages/FlowEditor/lib/store"; +import React from "react"; +import { AdminPanelData } from "types"; +import Caret from "ui/icons/Caret"; + +const StyledTeamAccordion = styled(Accordion, { + shouldForwardProp: (prop) => prop !== "primaryColour", +})<{ primaryColour?: string }>(({ theme, primaryColour }) => ({ + borderTop: "none", // TODO figure out how to remove top border (box shadow?) when collapsed + borderLeft: `10px solid ${primaryColour}`, + backgroundColor: theme.palette.background.paper, + width: "100%", + position: "relative", + marginBottom: theme.spacing(2), + padding: theme.spacing(1), + "&::after": { + position: "absolute", + width: "100%", + }, +})); + +function Component() { + const adminPanelData = useStore((state) => state.adminPanelData); + + return ( + + Platform Admin Panel + + {`This is an overview of each team's integrations and settings for the `} + {process.env.REACT_APP_ENV} + {` environment`} + + {adminPanelData?.map((team) => )} + + ); +} + +interface TeamData { + data: AdminPanelData; +} + +const NotConfigured: React.FC = () => ; + +const Configured: React.FC = () => ; + +const TeamData: React.FC = ({ data }) => { + return ( + + } + sx={{ pr: 1.5 }} + > + {data.name} + + + + + + <> + {"Slug"} + + + {`/`} + {data.slug} + + + + <> + {"Homepage"} + {data.homepage || } + + <> + {"Logo"} + + {data.logo ? : } + + + <> + {"Favicon"} + + {data.favicon ? : } + + + + + + + <> + {"Planning constraints"} + + {data.planningDataEnabled ? ( + + ) : ( + + )} + + + <> + {"Article 4s"} + {"?"} + + <> + {"Reference code"} + + {data.referenceCode || } + + + <> + {"Subdomain"} + {data.subdomain || } + + + + + + <> + {"GOV.UK Notify"} + + {data.govnotifyPersonalisation?.helpEmail || ( + + )} + + + <> + {"GOV.UK Pay"} + + {data.govpayEnabled ? : } + + + <> + {"Send to email"} + + {data.sendToEmailAddress || } + + + <> + {"BOPS"} + + {data.bopsSubmissionURL ? : } + + + + + + + + ); +}; + +export default Component; diff --git a/editor.planx.uk/src/routes/authenticated.tsx b/editor.planx.uk/src/routes/authenticated.tsx index d1b2e42b7b..659b907d79 100644 --- a/editor.planx.uk/src/routes/authenticated.tsx +++ b/editor.planx.uk/src/routes/authenticated.tsx @@ -13,6 +13,7 @@ import React from "react"; import { client } from "../lib/graphql"; import GlobalSettingsView from "../pages/GlobalSettings"; +import AdminPanelView from "../pages/PlatformAdminPanel"; import Teams from "../pages/Teams"; import { makeTitle } from "./utils"; import { authenticatedView } from "./views/authenticated"; @@ -68,6 +69,48 @@ const editorRoutes = compose( }); }), + "/admin-panel": map(async (req) => { + const isAuthorised = useStore.getState().user?.isPlatformAdmin; + if (!isAuthorised) + throw new NotFoundError( + `User does not have access to ${req.originalUrl}`, + ); + + return route(async () => { + const { data } = await client.query({ + query: gql` + query { + adminPanel: teams_summary { + id + name + slug + referenceCode: reference_code + homepage + subdomain + planningDataEnabled: planning_data_enabled + article4sEnabled: article_4s_enabled + govnotifyPersonalisation: govnotify_personalisation + govpayEnabled: govpay_enabled + sendToEmailAddress: send_to_email_address + bopsSubmissionURL: bops_submission_url + logo + favicon + primaryColour: primary_colour + linkColour: link_colour + actionColour: action_colour + } + } + `, + }); + useStore.getState().setAdminPanelData(data.adminPanel); + + return { + title: makeTitle("Platform Admin Panel"), + view: , + }; + }); + }), + "/:team": lazy(() => import("./team")), }), ); diff --git a/editor.planx.uk/src/types.ts b/editor.planx.uk/src/types.ts index 3d8a63117f..66d691976d 100644 --- a/editor.planx.uk/src/types.ts +++ b/editor.planx.uk/src/types.ts @@ -1,4 +1,8 @@ -import { GovUKPayment, Team } from "@opensystemslab/planx-core/types"; +import { + GovUKPayment, + NotifyPersonalisation, + Team, +} from "@opensystemslab/planx-core/types"; import { useFormik } from "formik"; import { Store } from "./pages/FlowEditor/lib/store/index"; @@ -98,3 +102,23 @@ export interface SectionNode extends Store.node { description?: string; }; } + +export interface AdminPanelData { + id: string; + name: string; + slug: string; + referenceCode?: string; + homepage?: string; + subdomain?: string; + planningDataEnabled: boolean; + article4sEnabled: string; + govnotifyPersonalisation?: NotifyPersonalisation; + govpayEnabled: boolean; + sendToEmailAddress?: string; + bopsSubmissionURL?: string; + logo?: string; + favicon?: string; + primaryColour?: string; + linkColour?: string; + actionColour?: string; +} diff --git a/hasura.planx.uk/metadata/tables.yaml b/hasura.planx.uk/metadata/tables.yaml index 87da4e2400..aa82b8aee3 100644 --- a/hasura.planx.uk/metadata/tables.yaml +++ b/hasura.planx.uk/metadata/tables.yaml @@ -1714,6 +1714,32 @@ - submission_email filter: {} check: null +- table: + name: teams_summary + schema: public + select_permissions: + - role: platformAdmin + permission: + columns: + - govpay_enabled + - planning_data_enabled + - id + - govnotify_personalisation + - action_colour + - article_4s_enabled + - bops_submission_url + - favicon + - homepage + - link_colour + - logo + - name + - primary_colour + - reference_code + - send_to_email_address + - slug + - subdomain + filter: {} + comment: "" - table: name: uniform_applications schema: public diff --git a/hasura.planx.uk/migrations/1713084872473_create_view_teams_summary/down.sql b/hasura.planx.uk/migrations/1713084872473_create_view_teams_summary/down.sql new file mode 100644 index 0000000000..ad6843f7d1 --- /dev/null +++ b/hasura.planx.uk/migrations/1713084872473_create_view_teams_summary/down.sql @@ -0,0 +1 @@ +DROP VIEW IF EXISTS "public"."teams_summary" CASCADE; \ No newline at end of file diff --git a/hasura.planx.uk/migrations/1713084872473_create_view_teams_summary/up.sql b/hasura.planx.uk/migrations/1713084872473_create_view_teams_summary/up.sql new file mode 100644 index 0000000000..76180557a4 --- /dev/null +++ b/hasura.planx.uk/migrations/1713084872473_create_view_teams_summary/up.sql @@ -0,0 +1,26 @@ +CREATE OR REPLACE VIEW "public"."teams_summary" AS SELECT + t.id, + t.name, + t.slug, + t.reference_code, + t.settings->>'homepage' as homepage, + t.domain as subdomain, + ti.has_planning_data as planning_data_enabled, + '@todo' as article_4s_enabled, + t.notify_personalisation as govnotify_personalisation, + CASE + WHEN coalesce(ti.production_govpay_secret, ti.staging_govpay_secret) is not null + THEN true + ELSE false + END as govpay_enabled, + t.submission_email as send_to_email_address, + coalesce(ti.production_bops_submission_url, ti.staging_bops_submission_url) as bops_submission_url, + tt.logo, + tt.favicon, + tt.primary_colour, + tt.link_colour, + tt.action_colour +FROM teams t + JOIN team_integrations ti on ti.team_id = t.id + JOIN team_themes tt on tt.team_id = t.id +ORDER BY t.name ASC; From 4b7d32fbc2944debe8de0bd6a496d696e2a2aaa3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Dafydd=20Ll=C5=B7r=20Pearson?= Date: Tue, 16 Apr 2024 17:08:27 +0100 Subject: [PATCH 4/8] chore: Add `decrypt()` util to scripts (#3019) --- scripts/encrypt/decrypt.ts | 33 ++++++++++++++++++++++++ scripts/encrypt/{index.ts => encrypt.ts} | 10 +++---- scripts/encrypt/package.json | 3 ++- 3 files changed, 40 insertions(+), 6 deletions(-) create mode 100644 scripts/encrypt/decrypt.ts rename scripts/encrypt/{index.ts => encrypt.ts} (79%) diff --git a/scripts/encrypt/decrypt.ts b/scripts/encrypt/decrypt.ts new file mode 100644 index 0000000000..532e40d1c9 --- /dev/null +++ b/scripts/encrypt/decrypt.ts @@ -0,0 +1,33 @@ +import { decrypt } from "@opensystemslab/planx-core"; + +/** + * Decrypt a secret + * Currently used to read secure secrets from the team_integrations table back to plain text + * e.g using API keys in another context, checking values + * + * @param encryptionKey - The encryption key - a 32-byte string + * @param secret - The encrypted secret and initialization vector in the format ${secret}:${iv} + * @returns The decrypted secret + * @example pnpm decrypt + */ +function main() { + try { + if (process.argv.length < 4) { + console.error("Usage: pnpm decrypt "); + process.exit(1); + } + + const encryptionKey = process.argv[2]; + const secret = process.argv[3]; + const decrypted = decrypt(secret, encryptionKey); + + console.log("Success!"); + console.log(decrypted); + } catch (error) { + console.log("Error!"); + console.error(error); + process.exit(1); + } +} + +main(); diff --git a/scripts/encrypt/index.ts b/scripts/encrypt/encrypt.ts similarity index 79% rename from scripts/encrypt/index.ts rename to scripts/encrypt/encrypt.ts index 3346e995d5..4b8e459382 100644 --- a/scripts/encrypt/index.ts +++ b/scripts/encrypt/encrypt.ts @@ -5,20 +5,20 @@ import { encrypt } from "@opensystemslab/planx-core"; * Currently used to generate secure secrets for the team_integrations table * e.g converting plain text 3rd-part API keys (such as BOPS tokens) to encrypted strings * - * @param secret - The secret to be encrypted. * @param encryptionKey - The encryption key - a 32-byte string + * @param secret - The secret to be encrypted. * @returns The encrypted secret and initialization vector in the format ${secret}:${iv} - * @example pnpm encode + * @example pnpm encrypt */ function main() { try { if (process.argv.length < 4) { - console.error("Usage: pnpm encode "); + console.error("Usage: pnpm encrypt "); process.exit(1); } - const secret = process.argv[2]; - const encryptionKey = process.argv[3]; + const encryptionKey = process.argv[2]; + const secret = process.argv[3]; const encrypted = encrypt(secret, encryptionKey); console.log("Success!"); diff --git a/scripts/encrypt/package.json b/scripts/encrypt/package.json index 449c8eb30b..2702d7383d 100644 --- a/scripts/encrypt/package.json +++ b/scripts/encrypt/package.json @@ -4,7 +4,8 @@ "description": "", "main": "index.ts", "scripts": { - "encrypt": "ts-node index.ts" + "encrypt": "ts-node encrypt.ts", + "decrypt": "ts-node decrypt.ts" }, "keywords": [], "dependencies": { From 8ce4397076a129eeff1803bdf019acdc97de80a3 Mon Sep 17 00:00:00 2001 From: Jessica McInchak Date: Tue, 16 Apr 2024 19:35:00 +0100 Subject: [PATCH 5/8] feat: add option to skipValidation when using `/digital-planning-application` admin endpoint (#3021) --- .../admin/session/digitalPlanningData.test.ts | 11 +++++++++++ .../modules/admin/session/digitalPlanningData.ts | 13 +++++++++++++ api.planx.uk/package.json | 2 +- api.planx.uk/pnpm-lock.yaml | 8 ++++---- e2e/tests/api-driven/package.json | 2 +- e2e/tests/api-driven/pnpm-lock.yaml | 8 ++++---- e2e/tests/ui-driven/package.json | 2 +- e2e/tests/ui-driven/pnpm-lock.yaml | 8 ++++---- editor.planx.uk/package.json | 2 +- editor.planx.uk/pnpm-lock.yaml | 10 +++++----- 10 files changed, 45 insertions(+), 21 deletions(-) diff --git a/api.planx.uk/modules/admin/session/digitalPlanningData.test.ts b/api.planx.uk/modules/admin/session/digitalPlanningData.test.ts index c8fb078cb3..30c66564af 100644 --- a/api.planx.uk/modules/admin/session/digitalPlanningData.test.ts +++ b/api.planx.uk/modules/admin/session/digitalPlanningData.test.ts @@ -66,4 +66,15 @@ describe("Digital Planning Application payload admin endpoint", () => { expect(res.body).toEqual(expectedPlanningPermissionPayload), ); }); + + it("returns an invalid JSON payload if the skipValidation query param is set", async () => { + await supertest(app) + .get(endpoint`123`.concat("?skipValidation=true")) + .set(authHeader({ role: "platformAdmin" })) + .expect(200) + .expect("content-type", "application/json; charset=utf-8") + .then((res) => + expect(res.body).toEqual(expectedPlanningPermissionPayload), + ); + }); }); diff --git a/api.planx.uk/modules/admin/session/digitalPlanningData.ts b/api.planx.uk/modules/admin/session/digitalPlanningData.ts index eb76b97d0c..f974839b28 100644 --- a/api.planx.uk/modules/admin/session/digitalPlanningData.ts +++ b/api.planx.uk/modules/admin/session/digitalPlanningData.ts @@ -11,6 +11,11 @@ import { $api } from "../../../client"; * - admin * parameters: * - $ref: '#/components/parameters/sessionId' + * - in: query + * name: skipValidation + * type: boolean + * required: false + * description: If invalid JSON data should still be returned, instead of logging validation errors * security: * - bearerAuth: [] */ @@ -20,9 +25,17 @@ export const getDigitalPlanningApplicationPayload = async ( next: NextFunction, ) => { try { + let skipValidation = false; + if (req.query?.skipValidation) { + skipValidation = + (req.query.skipValidation as string).toLowerCase() === "true"; + } + const data = await $api.export.digitalPlanningDataPayload( req.params.sessionId, + skipValidation, ); + res.set("content-type", "application/json"); return res.send(data); } catch (error) { diff --git a/api.planx.uk/package.json b/api.planx.uk/package.json index 2f87ff431f..4f8cca4fde 100644 --- a/api.planx.uk/package.json +++ b/api.planx.uk/package.json @@ -4,7 +4,7 @@ "private": true, "dependencies": { "@airbrake/node": "^2.1.8", - "@opensystemslab/planx-core": "git+https://github.com/theopensystemslab/planx-core#7ff62e4", + "@opensystemslab/planx-core": "git+https://github.com/theopensystemslab/planx-core#15bde6b", "@types/isomorphic-fetch": "^0.0.36", "adm-zip": "^0.5.10", "aws-sdk": "^2.1467.0", diff --git a/api.planx.uk/pnpm-lock.yaml b/api.planx.uk/pnpm-lock.yaml index b03ad0d96f..12362c985b 100644 --- a/api.planx.uk/pnpm-lock.yaml +++ b/api.planx.uk/pnpm-lock.yaml @@ -12,8 +12,8 @@ dependencies: specifier: ^2.1.8 version: 2.1.8 '@opensystemslab/planx-core': - specifier: git+https://github.com/theopensystemslab/planx-core#7ff62e4 - version: github.com/theopensystemslab/planx-core/7ff62e4 + specifier: git+https://github.com/theopensystemslab/planx-core#15bde6b + version: github.com/theopensystemslab/planx-core/15bde6b '@types/isomorphic-fetch': specifier: ^0.0.36 version: 0.0.36 @@ -8411,8 +8411,8 @@ packages: resolution: {integrity: sha512-iC+8Io04lddc+mVqQ9AZ7OQ2MrUKGN+oIQyq1vemgt46jwCwLfhq7/pwnBnNXXXZb8VTVLKwp9EDkx+ryxIWmg==} dev: false - github.com/theopensystemslab/planx-core/7ff62e4: - resolution: {tarball: https://codeload.github.com/theopensystemslab/planx-core/tar.gz/7ff62e4} + github.com/theopensystemslab/planx-core/15bde6b: + resolution: {tarball: https://codeload.github.com/theopensystemslab/planx-core/tar.gz/15bde6b} name: '@opensystemslab/planx-core' version: 1.0.0 prepare: true diff --git a/e2e/tests/api-driven/package.json b/e2e/tests/api-driven/package.json index c1bb41a729..f588363618 100644 --- a/e2e/tests/api-driven/package.json +++ b/e2e/tests/api-driven/package.json @@ -6,7 +6,7 @@ }, "dependencies": { "@cucumber/cucumber": "^9.3.0", - "@opensystemslab/planx-core": "git+https://github.com/theopensystemslab/planx-core#7ff62e4", + "@opensystemslab/planx-core": "git+https://github.com/theopensystemslab/planx-core#15bde6b", "axios": "^1.6.8", "dotenv": "^16.3.1", "dotenv-expand": "^10.0.0", diff --git a/e2e/tests/api-driven/pnpm-lock.yaml b/e2e/tests/api-driven/pnpm-lock.yaml index a838f4d59c..e9f0e220e9 100644 --- a/e2e/tests/api-driven/pnpm-lock.yaml +++ b/e2e/tests/api-driven/pnpm-lock.yaml @@ -9,8 +9,8 @@ dependencies: specifier: ^9.3.0 version: 9.3.0 '@opensystemslab/planx-core': - specifier: git+https://github.com/theopensystemslab/planx-core#7ff62e4 - version: github.com/theopensystemslab/planx-core/7ff62e4 + specifier: git+https://github.com/theopensystemslab/planx-core#15bde6b + version: github.com/theopensystemslab/planx-core/15bde6b axios: specifier: ^1.6.8 version: 1.6.8 @@ -2943,8 +2943,8 @@ packages: resolution: {integrity: sha512-iC+8Io04lddc+mVqQ9AZ7OQ2MrUKGN+oIQyq1vemgt46jwCwLfhq7/pwnBnNXXXZb8VTVLKwp9EDkx+ryxIWmg==} dev: false - github.com/theopensystemslab/planx-core/7ff62e4: - resolution: {tarball: https://codeload.github.com/theopensystemslab/planx-core/tar.gz/7ff62e4} + github.com/theopensystemslab/planx-core/15bde6b: + resolution: {tarball: https://codeload.github.com/theopensystemslab/planx-core/tar.gz/15bde6b} name: '@opensystemslab/planx-core' version: 1.0.0 prepare: true diff --git a/e2e/tests/ui-driven/package.json b/e2e/tests/ui-driven/package.json index 655e504ebf..c3305e837f 100644 --- a/e2e/tests/ui-driven/package.json +++ b/e2e/tests/ui-driven/package.json @@ -8,7 +8,7 @@ "postinstall": "./install-dependencies.sh" }, "dependencies": { - "@opensystemslab/planx-core": "git+https://github.com/theopensystemslab/planx-core#7ff62e4", + "@opensystemslab/planx-core": "git+https://github.com/theopensystemslab/planx-core#15bde6b", "axios": "^1.6.8", "dotenv": "^16.3.1", "eslint": "^8.56.0", diff --git a/e2e/tests/ui-driven/pnpm-lock.yaml b/e2e/tests/ui-driven/pnpm-lock.yaml index c4569ca2ab..e39ecbf311 100644 --- a/e2e/tests/ui-driven/pnpm-lock.yaml +++ b/e2e/tests/ui-driven/pnpm-lock.yaml @@ -6,8 +6,8 @@ settings: dependencies: '@opensystemslab/planx-core': - specifier: git+https://github.com/theopensystemslab/planx-core#7ff62e4 - version: github.com/theopensystemslab/planx-core/7ff62e4 + specifier: git+https://github.com/theopensystemslab/planx-core#15bde6b + version: github.com/theopensystemslab/planx-core/15bde6b axios: specifier: ^1.6.8 version: 1.6.8 @@ -2609,8 +2609,8 @@ packages: resolution: {integrity: sha512-iC+8Io04lddc+mVqQ9AZ7OQ2MrUKGN+oIQyq1vemgt46jwCwLfhq7/pwnBnNXXXZb8VTVLKwp9EDkx+ryxIWmg==} dev: false - github.com/theopensystemslab/planx-core/7ff62e4: - resolution: {tarball: https://codeload.github.com/theopensystemslab/planx-core/tar.gz/7ff62e4} + github.com/theopensystemslab/planx-core/15bde6b: + resolution: {tarball: https://codeload.github.com/theopensystemslab/planx-core/tar.gz/15bde6b} name: '@opensystemslab/planx-core' version: 1.0.0 prepare: true diff --git a/editor.planx.uk/package.json b/editor.planx.uk/package.json index 6d8f797287..d0ca0360f7 100644 --- a/editor.planx.uk/package.json +++ b/editor.planx.uk/package.json @@ -12,7 +12,7 @@ "@mui/material": "^5.15.2", "@mui/utils": "^5.15.2", "@opensystemslab/map": "^0.8.1", - "@opensystemslab/planx-core": "git+https://github.com/theopensystemslab/planx-core#7ff62e4", + "@opensystemslab/planx-core": "git+https://github.com/theopensystemslab/planx-core#15bde6b", "@tiptap/core": "^2.0.3", "@tiptap/extension-bold": "^2.0.3", "@tiptap/extension-bubble-menu": "^2.1.13", diff --git a/editor.planx.uk/pnpm-lock.yaml b/editor.planx.uk/pnpm-lock.yaml index 1b3a055c0b..2643798e8f 100644 --- a/editor.planx.uk/pnpm-lock.yaml +++ b/editor.planx.uk/pnpm-lock.yaml @@ -38,8 +38,8 @@ dependencies: specifier: ^0.8.1 version: 0.8.1 '@opensystemslab/planx-core': - specifier: git+https://github.com/theopensystemslab/planx-core#7ff62e4 - version: github.com/theopensystemslab/planx-core/7ff62e4(@types/react@18.2.45) + specifier: git+https://github.com/theopensystemslab/planx-core#15bde6b + version: github.com/theopensystemslab/planx-core/15bde6b(@types/react@18.2.45) '@tiptap/core': specifier: ^2.0.3 version: 2.0.3(@tiptap/pm@2.0.3) @@ -21139,9 +21139,9 @@ packages: use-sync-external-store: 1.2.0(react@18.2.0) dev: false - github.com/theopensystemslab/planx-core/7ff62e4(@types/react@18.2.45): - resolution: {tarball: https://codeload.github.com/theopensystemslab/planx-core/tar.gz/7ff62e4} - id: github.com/theopensystemslab/planx-core/7ff62e4 + github.com/theopensystemslab/planx-core/15bde6b(@types/react@18.2.45): + resolution: {tarball: https://codeload.github.com/theopensystemslab/planx-core/tar.gz/15bde6b} + id: github.com/theopensystemslab/planx-core/15bde6b name: '@opensystemslab/planx-core' version: 1.0.0 prepare: true From 6979f2bfe0627e42e36d742505ae9cf81a26aaea Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Dafydd=20Ll=C5=B7r=20Pearson?= Date: Tue, 16 Apr 2024 20:17:22 +0100 Subject: [PATCH 6/8] fix: Add zIndex value to settings to cover badge (#3024) --- .../src/pages/FlowEditor/components/Settings/index.tsx | 1 + 1 file changed, 1 insertion(+) diff --git a/editor.planx.uk/src/pages/FlowEditor/components/Settings/index.tsx b/editor.planx.uk/src/pages/FlowEditor/components/Settings/index.tsx index 46bf7a105d..42ec847356 100644 --- a/editor.planx.uk/src/pages/FlowEditor/components/Settings/index.tsx +++ b/editor.planx.uk/src/pages/FlowEditor/components/Settings/index.tsx @@ -105,6 +105,7 @@ const Root = styled(Box)(({ theme }) => ({ backgroundColor: "#f2f2f2", zIndex: 0, }, + zIndex: theme.zIndex.appBar, })); const Settings: React.FC = ({ currentTab, tabs }) => { From a79b79eb97073218d33bcc70eb58bf468e773c59 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Dafydd=20Ll=C5=B7r=20Pearson?= Date: Wed, 17 Apr 2024 08:23:21 +0100 Subject: [PATCH 7/8] fix: Editor layout overflow bug (#3025) --- editor.planx.uk/src/pages/FlowEditor/index.tsx | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/editor.planx.uk/src/pages/FlowEditor/index.tsx b/editor.planx.uk/src/pages/FlowEditor/index.tsx index f9a1cb93a4..2d9386170d 100644 --- a/editor.planx.uk/src/pages/FlowEditor/index.tsx +++ b/editor.planx.uk/src/pages/FlowEditor/index.tsx @@ -99,7 +99,14 @@ const FlowEditor: React.FC = ({ flow, breadcrumbs }) => { return ( - + From 8186afce53c03a18e06544dd80ce29af580bb158 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Dafydd=20Ll=C5=B7r=20Pearson?= Date: Wed, 17 Apr 2024 11:00:14 +0100 Subject: [PATCH 8/8] chore: Rotate Postgres staging password (#3027) --- infrastructure/data/Pulumi.staging.yaml | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/infrastructure/data/Pulumi.staging.yaml b/infrastructure/data/Pulumi.staging.yaml index a056740a4a..47871e74bb 100644 --- a/infrastructure/data/Pulumi.staging.yaml +++ b/infrastructure/data/Pulumi.staging.yaml @@ -1,3 +1,4 @@ config: + aws:profile: planx-staging data:db-password: - secure: AAABAB8n9YndCWHacrUqhkHcPPKh4iWGyB2MT8xYq55zcyp2hCSANG69CWR+6JiehY73+W/eBqA= + secure: AAABANyYBkbNfKWlHJPgQchQUyXbkh/jFGevy7r9Mqsx6mAxtE9ff01Z4T0nCJJ30N0GFwfd6TyvdGcdvuNuXg==