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: Force user to go through onboarding steps for every registration #4014

Merged
merged 17 commits into from
Jan 16, 2025

Conversation

AmarTrebinjac
Copy link
Contributor

@AmarTrebinjac AmarTrebinjac commented Dec 22, 2024

Changes

This should prevent the user from refreshing to skip the necessary steps. Users created before the given date (currently 08-01-2 5) will not be required to complete the onboarding

Events

Did you introduce any new tracking events?

Experiment

Did you introduce any new experiments?

Manual Testing

Caution

Please make sure existing components are not breaking/affected by this PR

MI-700 #done

Preview domain

https://mi-700.preview.app.daily.dev

Copy link

vercel bot commented Dec 22, 2024

The latest updates on your projects. Learn more about Vercel for Git ↗︎

Name Status Preview Updated (UTC)
daily-webapp ✅ Ready (Inspect) Visit Preview Jan 16, 2025 11:15am
1 Skipped Deployment
Name Status Preview Updated (UTC)
storybook ⬜️ Ignored (Inspect) Jan 16, 2025 11:15am

@sshanzel
Copy link
Member

sshanzel commented Jan 3, 2025

Either we retro-fix the missing action for existing users, or check the useMyFeed (can't remember the exact name), to check whether any changes were applied to their settings, if so, that would mean the user adjusted their feed already and must not redirect back to onboarding.

@AmarTrebinjac
Copy link
Contributor Author

Either we retro-fix the missing action for existing users, or check the useMyFeed (can't remember the exact name), to check whether any changes were applied to their settings, if so, that would mean the user adjusted their feed already and must not redirect back to onboarding.

@sshanzelI tried creating an user where I skipped tags and settings, then I tried using "useFeedSettings" and both tags and advanced settings is filled with a lot of default stuff. So not sure we can check that way

@sshanzel
Copy link
Member

sshanzel commented Jan 7, 2025

Either we retro-fix the missing action for existing users, or check the useMyFeed (can't remember the exact name), to check whether any changes were applied to their settings, if so, that would mean the user adjusted their feed already and must not redirect back to onboarding.

@sshanzelI tried creating an user where I skipped tags and settings, then I tried using "useFeedSettings" and both tags and advanced settings is filled with a lot of default stuff. So not sure we can check that way

If you skip the tags part, the followTags will be empty, iirc.

@AmarTrebinjac
Copy link
Contributor Author

Either we retro-fix the missing action for existing users, or check the useMyFeed (can't remember the exact name), to check whether any changes were applied to their settings, if so, that would mean the user adjusted their feed already and must not redirect back to onboarding.

@sshanzelI tried creating an user where I skipped tags and settings, then I tried using "useFeedSettings" and both tags and advanced settings is filled with a lot of default stuff. So not sure we can check that way

If you skip the tags part, the followTags will be empty, iirc.

For reference to anyone reading, responded to this here

Anyone who created an account before this date is exempt from the requirement.
*/
const registeredBeforeRequired =
user?.createdAt && new Date(user.createdAt) < new Date('2025-01-08');
Copy link
Contributor

Choose a reason for hiding this comment

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

This will have to match exactly release right?

Copy link
Contributor Author

@AmarTrebinjac AmarTrebinjac Jan 8, 2025

Choose a reason for hiding this comment

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

@rebelchris Not necessarily. If we want to give time for the extension to get published and stuff, we could just set the date a few days in the future. We don't necessarily have to start redirecting users exactly on merge date.

And new extension installs will have to install the newest version, right?

Copy link
Contributor

Choose a reason for hiding this comment

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

Yes, and do you redirect extension as well?
I'm not sure i'm seeing that part now

Copy link
Contributor Author

Choose a reason for hiding this comment

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

The changes in App.tsx are for the extension specifically, while the changes in _app.tsx are for the webapp.

Running pnpm --filter extension dev:chrome and then opening a new tab with a user registered after the given date redirects me to onboarding. Have I missed something? 🤔

Copy link
Contributor

Choose a reason for hiding this comment

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

Then it's fine, maybe we'll need to check with Ido what he thinks on extension vs non extension usage here?

Copy link
Member

Choose a reason for hiding this comment

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

Instead of redirecting immediately can we use the "hijacking" page (or whatever it's called) with slightly different copy and on click it redirects to onboarding? I already see the hate of us auto redirecting and users losing focus

Copy link
Contributor Author

Choose a reason for hiding this comment

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

@idoshamun Not entirely sure what you are referencing here. This is not supposed to affect existing users, and users trying to skip it should never have access to the rest of the page anyway, so they shouldn't really notice the redirecting.

chrome_MspWbpuF2k.mp4

Also, on the extension part, you can't access the extension without logging in, right? So users who installed and registered after the given date should not be able to bypass the onboarding in any way, webapp or extension.

Copy link
Member

Choose a reason for hiding this comment

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

i'm talking specifically on extension, automatically redirecting the extension to onboarding page will lead to complaints that i'd like to avoid. Try to use the extension without being logged in and you'll see the solution i'm referring to

Copy link
Contributor Author

@AmarTrebinjac AmarTrebinjac Jan 9, 2025

Choose a reason for hiding this comment

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

i'm talking specifically on extension, automatically redirecting the extension to onboarding page will lead to complaints that i'd like to avoid. Try to use the extension without being logged in and you'll see the solution i'm referring to

Alright, I think I'm picking up what you're putting down. You basically want me to show this screen instead on the extension:
image
Should be able to make that happen

Copy link
Member

Choose a reason for hiding this comment

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

exactly!

Copy link
Contributor

@rebelchris rebelchris left a comment

Choose a reason for hiding this comment

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

How about extension? 👀

@AmarTrebinjac
Copy link
Contributor Author

@rebelchris Do you have a suggested cutoff date?

Copy link
Contributor

@rebelchris rebelchris left a comment

Choose a reason for hiding this comment

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

Overall looks good, but it's a super, super sensitive flow.
Can we maybe do a sync where you can show me flows from extension and webapp?

Rather double sanity check this then just rolling it out 🙏
(@sshanzel FYI, you might also want to look)

Comment on lines +89 to +92
const isOnboardingComplete =
isOnboardingReady && hasCompletedEditTags && hasCompletedContentTypes;
const shouldRedirectOnboarding =
isPageReady && (!user || !isOnboardingComplete) && !isTesting;
Copy link
Contributor

Choose a reason for hiding this comment

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

Doesn't this affect current users now? (I didn't test it)

@@ -361,7 +374,6 @@ export function OnboardPage(): ReactElement {
initialEmail: email,
isLoginFlow,
targetId,
onSuccessfulLogin,
Copy link
Member

Choose a reason for hiding this comment

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

Is this used anywhere else that existing flows might get affected?

Copy link
Member

@sshanzel sshanzel left a comment

Choose a reason for hiding this comment

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

Looks good to me code wise. We should probably test the critical flows once we get the time before we merge this. To ensure existing users won't be affected and new behavior will be as intended.

@AmarTrebinjac AmarTrebinjac merged commit 1451e07 into main Jan 16, 2025
10 checks passed
@AmarTrebinjac AmarTrebinjac deleted the MI-700 branch January 16, 2025 11:16
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.

4 participants