diff --git a/native/community-creation/community-configuration.react.js b/native/community-creation/community-configuration.react.js
index 6539379d4..8b5d39128 100644
--- a/native/community-creation/community-configuration.react.js
+++ b/native/community-creation/community-configuration.react.js
@@ -1,199 +1,244 @@
// @flow
import * as React from 'react';
import { Text, TouchableOpacity, View } from 'react-native';
+import { newThread, newThreadActionTypes } from 'lib/actions/thread-actions.js';
+import { threadTypes } from 'lib/types/thread-types-enum.js';
+import type { NewThreadResult } from 'lib/types/thread-types.js';
+import {
+ useDispatchActionPromise,
+ useServerCall,
+} from 'lib/utils/action-utils.js';
+
import type { CommunityCreationNavigationProp } from './community-creation-navigator.react.js';
+import RegistrationButtonContainer from '../account/registration/registration-button-container.react.js';
+import RegistrationButton from '../account/registration/registration-button.react.js';
import RegistrationContainer from '../account/registration/registration-container.react.js';
import RegistrationContentContainer from '../account/registration/registration-content-container.react.js';
import {
ThreadSettingsCategoryFooter,
ThreadSettingsCategoryHeader,
} from '../chat/settings/thread-settings-category.react.js';
import CommIcon from '../components/comm-icon.react.js';
import Pill from '../components/pill.react.js';
import TextInput from '../components/text-input.react.js';
+import { useCalendarQuery } from '../navigation/nav-selectors.js';
import { type NavigationRoute } from '../navigation/route-names.js';
import { useColors, useStyles } from '../themes/colors.js';
type Props = {
+navigation: CommunityCreationNavigationProp<'CommunityConfiguration'>,
+route: NavigationRoute<'CommunityConfiguration'>,
};
// eslint-disable-next-line no-unused-vars
function CommunityConfiguration(props: Props): React.Node {
const styles = useStyles(unboundStyles);
const colors = useColors();
+ const dispatchActionPromise = useDispatchActionPromise();
+
+ const callNewThread = useServerCall(newThread);
+ const calendarQueryFunc = useCalendarQuery();
+
const cloudIcon = (
);
const [pendingCommunityName, setPendingCommunityName] = React.useState('');
const [announcementSetting, setAnnouncementSetting] = React.useState(false);
+ const callCreateNewCommunity = React.useCallback(async () => {
+ const calendarQuery = calendarQueryFunc();
+ const newThreadResult: NewThreadResult = await callNewThread({
+ name: pendingCommunityName,
+ type: announcementSetting
+ ? threadTypes.COMMUNITY_ANNOUNCEMENT_ROOT
+ : threadTypes.COMMUNITY_ROOT,
+ calendarQuery,
+ });
+ return newThreadResult;
+ }, [
+ announcementSetting,
+ calendarQueryFunc,
+ callNewThread,
+ pendingCommunityName,
+ ]);
+
+ const createNewCommunity = React.useCallback(async () => {
+ const newThreadResultPromise = callCreateNewCommunity();
+ dispatchActionPromise(newThreadActionTypes, newThreadResultPromise);
+ await newThreadResultPromise;
+ }, [callCreateNewCommunity, dispatchActionPromise]);
+
const onCheckBoxPress = React.useCallback(() => {
setAnnouncementSetting(!announcementSetting);
}, [announcementSetting]);
let checkBoxFill;
if (announcementSetting) {
checkBoxFill = ;
}
return (
within
Name
You may edit your community’s image and name later.
Announcement root
Make it so that only admins can post to the root channel of the
community.
{checkBoxFill}
+
+
+
);
}
const unboundStyles = {
keyserverRowContainer: {
flexDirection: 'row',
justifyContent: 'center',
alignItems: 'center',
backgroundColor: 'panelForeground',
height: 48,
borderColor: 'panelForegroundBorder',
borderBottomWidth: 1,
},
withinText: {
color: 'panelForegroundLabel',
fontSize: 14,
marginRight: 6,
},
containerPaddingOverride: {
padding: 0,
},
communityNameRow: {
backgroundColor: 'panelForeground',
flexDirection: 'row',
paddingHorizontal: 24,
paddingVertical: 8,
},
communityNameLabel: {
color: 'panelForegroundTertiaryLabel',
fontSize: 16,
width: 96,
},
communityNamePendingValue: {
color: 'panelForegroundSecondaryLabel',
flex: 1,
fontFamily: 'Arial',
fontSize: 16,
margin: 0,
paddingLeft: 4,
paddingRight: 0,
paddingVertical: 0,
borderBottomColor: 'transparent',
},
communityNameNoticeContainer: {
display: 'flex',
flexDirection: 'row',
justifyContent: 'center',
},
communityNameNoticeText: {
color: 'panelForegroundTertiaryLabel',
},
enumCell: {
flexDirection: 'row',
height: 96,
backgroundColor: 'panelForeground',
},
enumIcon: {
padding: 16,
},
enumInfoContainer: {
flex: 1,
flexDirection: 'column',
justifyContent: 'space-evenly',
padding: 8,
},
enumInfoName: {
color: 'panelForegroundLabel',
fontSize: 18,
lineHeight: 24,
},
enumInfoDescription: {
color: 'panelForegroundSecondaryLabel',
lineHeight: 18,
},
enumCheckBoxContainer: {
padding: 22,
justifyContent: 'center',
alignItems: 'center',
},
enumCheckBox: {
height: 32,
width: 32,
borderRadius: 3.5,
borderWidth: 1,
borderColor: 'panelSecondaryForegroundBorder',
justifyContent: 'center',
alignItems: 'center',
},
enumCheckBoxFill: {
height: 20,
width: 20,
borderRadius: 2.1875,
backgroundColor: 'panelForegroundSecondaryLabel',
},
};
export default CommunityConfiguration;