diff --git a/src/AppRoutes.tsx b/src/AppRoutes.tsx index 8ee64e203c..e79fa8405c 100644 --- a/src/AppRoutes.tsx +++ b/src/AppRoutes.tsx @@ -78,6 +78,7 @@ import { SIGN_IN_FLOW, SIGN_UP_FLOW, CREATE_COMMUNITY_UNAUTHENTICATED_FLOW, + JOIN_COMMUNITY_UNAUTHENTICATED_FLOW, COMPLETE_STEP_FLOW_NAVIGATE_BACK, ADD_MY_STEP_FLOW, ADD_PERSON_STEP_FLOW, @@ -138,6 +139,7 @@ import { VideoFullScreen, VIDEO_FULL_SCREEN, } from './containers/VideoFullScreen'; +import { JoinCommunityUnauthenticatedFlowNavigator } from './routes/groups/joinCommunityUnauthenticatedFlow'; // Do custom animations between pages // import CardStackStyleInterpolator from 'react-navigation/src/views/CardStack/CardStackStyleInterpolator'; @@ -283,6 +285,7 @@ const screens = { [SIGN_IN_FLOW]: SignInFlowNavigator, [SIGN_UP_FLOW]: SignUpFlowNavigator, [CREATE_COMMUNITY_UNAUTHENTICATED_FLOW]: CreateCommunityUnauthenticatedFlowNavigator, + [JOIN_COMMUNITY_UNAUTHENTICATED_FLOW]: JoinCommunityUnauthenticatedFlowNavigator, [JOIN_BY_CODE_FLOW]: JoinByCodeFlowNavigator, [JOIN_BY_CODE_ONBOARDING_FLOW]: JoinByCodeOnboardingFlowNavigator, [ADD_SOMEONE_ONBOARDING_FLOW]: AddSomeoneOnboardingFlowNavigator, diff --git a/src/containers/Auth/SignUpScreen/index.tsx b/src/containers/Auth/SignUpScreen/index.tsx index 5695f79ba5..87caba6993 100644 --- a/src/containers/Auth/SignUpScreen/index.tsx +++ b/src/containers/Auth/SignUpScreen/index.tsx @@ -31,6 +31,7 @@ import styles from './styles'; export const SIGNUP_TYPES = { CREATE_COMMUNITY: 'login/CREATE_COMMUNITY', + JOIN_COMMUNITY: 'login/JOIN_COMMUNITY', SETTINGS_MENU: 'login/SIDE_MENU', }; @@ -48,6 +49,11 @@ const headerContentOptions: { title: i18Next.t('loginOptions:createCommunityTitle'), description: i18Next.t('loginOptions:createCommunityDescription'), }, + [SIGNUP_TYPES.JOIN_COMMUNITY]: { + image: PEOPLE, + title: i18Next.t('loginOptions:joinCommunityTitle'), + description: i18Next.t('loginOptions:joinCommunityDescription'), + }, }; const SignUpScreen = ({ diff --git a/src/containers/Groups/GroupsListScreen.tsx b/src/containers/Groups/GroupsListScreen.tsx index ae3f38b57d..2a08c76df9 100644 --- a/src/containers/Groups/GroupsListScreen.tsx +++ b/src/containers/Groups/GroupsListScreen.tsx @@ -22,6 +22,7 @@ import { resetScrollGroups } from '../../actions/swipe'; import { ACTIONS, GLOBAL_COMMUNITY_ID } from '../../constants'; import { CREATE_COMMUNITY_UNAUTHENTICATED_FLOW, + JOIN_COMMUNITY_UNAUTHENTICATED_FLOW, JOIN_BY_CODE_FLOW, } from '../../routes/constants'; import { useRefreshing } from '../../utils/hooks/useRefreshing'; @@ -195,7 +196,13 @@ const GroupsListScreen = () => { }; const join = () => { - dispatch(navigatePush(JOIN_BY_CODE_FLOW)); + dispatch( + navigatePush( + isAnonymousUser + ? JOIN_COMMUNITY_UNAUTHENTICATED_FLOW + : JOIN_BY_CODE_FLOW, + ), + ); }; const create = () => { diff --git a/src/i18n/locales/en-US.js b/src/i18n/locales/en-US.js index 797df76444..7592713acc 100644 --- a/src/i18n/locales/en-US.js +++ b/src/i18n/locales/en-US.js @@ -176,6 +176,8 @@ export default { member: 'Already a Member?', createCommunityTitle: 'Create a Community', createCommunityDescription: 'Sign Up to create a MissionHub community.', + joinCommunityTitle: 'Join a Community', + joinCommunityDescription: 'Sign Up to join a MissionHub community.', }, keyLogin: { emailLabel: 'Email', diff --git a/src/routes/constants.ts b/src/routes/constants.ts index b57d052358..d115731c6c 100644 --- a/src/routes/constants.ts +++ b/src/routes/constants.ts @@ -9,6 +9,8 @@ export const SIGN_IN_FLOW = 'nav/SIGN_IN_FLOW'; export const SIGN_UP_FLOW = 'nav/SIGN_UP_FLOW'; export const CREATE_COMMUNITY_UNAUTHENTICATED_FLOW = 'nav/CREATE_COMMUNITY_UNAUTHENTICATED_FLOW'; +export const JOIN_COMMUNITY_UNAUTHENTICATED_FLOW = + 'nav/JOIN_COMMUNITY_UNAUTHENTICATED_FLOW'; export const JOIN_BY_CODE_FLOW = 'nav/JOIN_BY_CODE_FLOW'; export const JOIN_BY_CODE_ONBOARDING_FLOW = 'nav/JOIN_BY_CODE_ONBOARDING_FLOW'; export const ADD_SOMEONE_ONBOARDING_FLOW = 'nav/ADD_SOMEONE_ONBOARDING_FLOW'; diff --git a/src/routes/groups/joinCommunityUnauthenticatedFlow.ts b/src/routes/groups/joinCommunityUnauthenticatedFlow.ts new file mode 100644 index 0000000000..a811701eb3 --- /dev/null +++ b/src/routes/groups/joinCommunityUnauthenticatedFlow.ts @@ -0,0 +1,29 @@ +import { createStackNavigator } from 'react-navigation-stack'; + +import { navigateNestedReset } from '../../actions/navigation'; +import { COMMUNITIES_TAB, MAIN_TABS } from '../../constants'; +import { JOIN_GROUP_SCREEN } from '../../containers/Groups/JoinGroupScreen'; +import { authFlowGenerator } from '../auth/authFlowGenerator'; +import { SIGNUP_TYPES } from '../../containers/Auth/SignUpScreen'; + +const JoinCommunityUnauthenticatedFlowScreens = authFlowGenerator({ + completeAction: navigateNestedReset([ + { + routeName: MAIN_TABS, + tabName: COMMUNITIES_TAB, + }, + { routeName: JOIN_GROUP_SCREEN }, + ]), + includeSignUp: true, + // @ts-ignore + signUpType: SIGNUP_TYPES.JOIN_COMMUNITY, +}); + +export const JoinCommunityUnauthenticatedFlowNavigator = createStackNavigator( + JoinCommunityUnauthenticatedFlowScreens, + { + defaultNavigationOptions: { + header: null, + }, + }, +);