diff --git a/src/AppRoutes.tsx b/src/AppRoutes.tsx
index 8ee64e203c..e589d816a7 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';
@@ -195,6 +197,7 @@ const MainTabBar = createBottomTabNavigator(tabs, {
backgroundColor: theme.white,
paddingTop: 4,
},
+ safeAreaInset: { vertical: 'always' },
activeTintColor: theme.primaryColor,
inactiveTintColor: theme.lightGrey,
// @ts-ignore
@@ -283,6 +286,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/containers/Groups/__tests__/GroupsListScreen.tsx b/src/containers/Groups/__tests__/GroupsListScreen.tsx
index a8c7f56739..d24ef33be4 100644
--- a/src/containers/Groups/__tests__/GroupsListScreen.tsx
+++ b/src/containers/Groups/__tests__/GroupsListScreen.tsx
@@ -15,6 +15,7 @@ import { resetScrollGroups } from '../../../actions/swipe';
import { ACTIONS } from '../../../constants';
import {
CREATE_COMMUNITY_UNAUTHENTICATED_FLOW,
+ JOIN_COMMUNITY_UNAUTHENTICATED_FLOW,
JOIN_BY_CODE_FLOW,
} from '../../../routes/constants';
import {
@@ -194,10 +195,29 @@ describe('GroupsListScreen', () => {
expect(navigatePush).toHaveBeenCalledWith(JOIN_BY_CODE_FLOW);
expect(store.getActions()).toEqual([navigatePushResponse]);
});
+
+ it('navigates to Upgrade Account Screen if not signed in', () => {
+ (useIsAnonymousUser as jest.Mock).mockReturnValue(true);
+
+ const { getByTestId, store } = renderWithContext(, {
+ initialState: {
+ ...initialState,
+ },
+ });
+
+ fireEvent.press(getByTestId('joinCommunity'));
+
+ expect(navigatePush).toHaveBeenCalledWith(
+ JOIN_COMMUNITY_UNAUTHENTICATED_FLOW,
+ );
+ expect(store.getActions()).toEqual([navigatePushResponse]);
+ });
});
describe('create community button press', () => {
it('navigates to create community screen if signed', () => {
+ (useIsAnonymousUser as jest.Mock).mockReturnValue(false);
+
const { getByTestId, store } = renderWithContext(, {
initialState,
});
diff --git a/src/containers/LandingScreen/__tests__/LandingScreen.tsx b/src/containers/LandingScreen/__tests__/LandingScreen.tsx
index 77fcf8494a..247e252981 100644
--- a/src/containers/LandingScreen/__tests__/LandingScreen.tsx
+++ b/src/containers/LandingScreen/__tests__/LandingScreen.tsx
@@ -7,7 +7,7 @@ import { navigatePush } from '../../../actions/navigation';
import { startOnboarding } from '../../../actions/onboarding';
import {
FULL_ONBOARDING_FLOW,
- JOIN_BY_CODE_ONBOARDING_FLOW,
+ JOIN_COMMUNITY_UNAUTHENTICATED_FLOW,
SIGN_IN_FLOW,
} from '../../../routes/constants';
import { useAnalytics } from '../../../utils/hooks/useAnalytics';
@@ -54,7 +54,9 @@ describe('a button is clicked', () => {
fireEvent.press(getByTestId('communityCodeButton'));
expect(startOnboarding).toHaveBeenCalledWith();
- expect(navigatePush).toHaveBeenCalledWith(JOIN_BY_CODE_ONBOARDING_FLOW);
+ expect(navigatePush).toHaveBeenCalledWith(
+ JOIN_COMMUNITY_UNAUTHENTICATED_FLOW,
+ );
expect(store.getActions()).toEqual([
startOnboardingResult,
navigatePushResult,
diff --git a/src/containers/LandingScreen/index.tsx b/src/containers/LandingScreen/index.tsx
index aa7d5e6dfe..94f8384d66 100644
--- a/src/containers/LandingScreen/index.tsx
+++ b/src/containers/LandingScreen/index.tsx
@@ -9,7 +9,7 @@ import { Button } from '../../components/common';
import { useAnalytics } from '../../utils/hooks/useAnalytics';
import {
FULL_ONBOARDING_FLOW,
- JOIN_BY_CODE_ONBOARDING_FLOW,
+ JOIN_COMMUNITY_UNAUTHENTICATED_FLOW,
SIGN_IN_FLOW,
} from '../../routes/constants';
import { startOnboarding } from '../../actions/onboarding';
@@ -40,7 +40,7 @@ const LandingScreen = () => {
const communityCode = () => {
dispatch(startOnboarding());
- dispatch(navigatePush(JOIN_BY_CODE_ONBOARDING_FLOW));
+ dispatch(navigatePush(JOIN_COMMUNITY_UNAUTHENTICATED_FLOW));
};
const signIn = () => {
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,
+ },
+ },
+);