Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: Add Preview/Draft Layout Wrapper for Testing Links #4090

Open
wants to merge 13 commits into
base: main
Choose a base branch
from

Conversation

RODO94
Copy link
Contributor

@RODO94 RODO94 commented Dec 18, 2024

What does this PR do?

This PR adds a wrapper around the Preview and Draft view to initially show a 'This is a test environment' node that a user would have to navigate past.

For this PR, I used the Layout pattern as a guide, but just used a Page rather than a Layout to wrap the View. I started with the Layout in place of the Page below but it didn't contain any extra logic or anything useful, so I removed it.

  return (
    <PublicLayout>
      <TestWarningPage>
        <View />
      </TestWarningPage>
    </PublicLayout>
  );

I used the Save and Return journey as a guide and created a new component inside the Card component to control which Or route is used. This has all been decoupled from the Card component and added to the OrNavigationButton

       <OrNavigationButton handleSubmit={handleSubmit} />

Hopefully this is an elegant solution and I have overcomplicated this <OrNavigationButton>. An unintended consequence of this is that the Go to live link is now present as an Or option on the Send component. This is why I had to mock the react-navi import for the tests

Important

When clicking "Go to published..." the flow data is deleted from localStorage and window is reset similar to the Restart button while you are navigated to the published?analytics=false page

Copy link

github-actions bot commented Dec 18, 2024

Pizza

Deployed 09964f7 to https://4090.planx.pizza.

Useful links:

@RODO94 RODO94 requested a review from a team December 19, 2024 09:21
@RODO94 RODO94 marked this pull request as ready for review December 19, 2024 09:21
Copy link
Contributor

@DafyddLlyr DafyddLlyr left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looking good!

A few comments to take a look at 👍

@RODO94 RODO94 force-pushed the rory/preview-wrapper branch from 30fbf51 to a2d1a18 Compare January 6, 2025 11:10
@RODO94 RODO94 requested a review from a team January 6, 2025 16:46
@jessicamcinchak
Copy link
Member

One question related to this point:

Important
"Go to the live service" remains across each node and when you click it, it will navigate you to that node in the flow rather than back at the start with pre-filled in questions

What happens when the /preview or /draft links have a node that is not in the published version? (As is most commonly the case? think this could lead to very strange and opaque submisison data errors?)

I don't think I actually agree that this is intended behavior, and I think users should be dropped at the beginning of a published service when clicking this link rather than midway?

@RODO94
Copy link
Contributor Author

RODO94 commented Jan 7, 2025

One question related to this point:

Important
"Go to the live service" remains across each node and when you click it, it will navigate you to that node in the flow rather than back at the start with pre-filled in questions

What happens when the /preview or /draft links have a node that is not in the published version? (As is most commonly the case? think this could lead to very strange and opaque submisison data errors?)

I don't think I actually agree that this is intended behavior, and I think users should be dropped at the beginning of a published service when clicking this link rather than midway?

@jessicamcinchak yeah, I wasn't sure on this, thanks for the clarification, I'll reset back to start on this

@RODO94 RODO94 requested a review from jessicamcinchak January 7, 2025 11:23
@RODO94 RODO94 force-pushed the rory/preview-wrapper branch from 0203d71 to c69cf29 Compare January 7, 2025 11:25
@RODO94 RODO94 requested a review from DafyddLlyr January 7, 2025 12:04
Copy link
Contributor

@DafyddLlyr DafyddLlyr left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is looking great - really a big step up in clarity (and quality!) than last time I reviewed it. I appreciate the work and though that's gone into it 👍

There's some very minor nit comments on the code below, no showstoppers.

Only thing blocking an approve from me is @jessicamcinchak's previous point about retaining the "or" option as the user progresses through their journey. This could lead to both weird submission behaviours and a very unexpected user journey.

I would suggest that we want would be -

  • The TestWarningPage shows ✅
  • The user can go to the published version ✅
  • The user can continue ✅
    • If they do continue, the "or" option goes away ❌

I think this is actually relatively simple to achieve.

If the TestWarningPage sets hasAcknowledgedWarning to global state (via the Zustand store) instead of it's local React useState() then we can check this inside the OrNavigationButton when deciding what to show.

@RODO94 RODO94 force-pushed the rory/preview-wrapper branch from c69cf29 to 2dce127 Compare January 14, 2025 14:17
@RODO94 RODO94 requested a review from DafyddLlyr January 14, 2025 14:51
import React, { PropsWithChildren, useState } from "react";

export const TestWarningPage = ({ children }: PropsWithChildren) => {
const { hasAcknowledgedWarning, setHasAcknowledgedWarning } = useStore();
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Great!

Comment on lines +69 to +70
if (hasAcknowledgedWarning && orNavigationType === "navigate-to-published")
return null;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This logic seems a little out of place.

What we really mean here is that in order for the orNavigationType to be "navigate-to-published", hasAcknowledgedWarning must be false.

This logic would make more sense to me as part of defineNavigationType(). Splitting this up make it harder to reason with and expand upon in future.

if (!showSaveResumeButton && isTestEnvironment && !hasAcknowledgedWarning) {
  return "navigate-to-published";
}

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants