Skip to content

Commit

Permalink
Merge branch 'develop' into bug/member-task-cards-label-scroll-buttons
Browse files Browse the repository at this point in the history
  • Loading branch information
desperado1802 committed Nov 17, 2023
2 parents cb431fe + 9592c96 commit ab60f5b
Show file tree
Hide file tree
Showing 11 changed files with 797 additions and 820 deletions.
234 changes: 112 additions & 122 deletions apps/mobile/app/screens/Authenticated/MembersSettingsScreen/index.tsx
Original file line number Diff line number Diff line change
@@ -1,102 +1,96 @@
/* eslint-disable camelcase */
/* eslint-disable react-native/no-inline-styles */
/* eslint-disable react-native/no-color-literals */
import { View, Text, ViewStyle, TouchableOpacity, StyleSheet } from "react-native"
import React, { FC, SetStateAction, useState } from "react"
import { View, Text, ViewStyle, TouchableOpacity, StyleSheet, StatusBar } from 'react-native';
import React, { FC, SetStateAction, useState } from 'react';
import {
AuthenticatedDrawerScreenProps,
DrawerNavigationProp,
SettingScreenNavigationProp,
} from "../../../navigators/AuthenticatedNavigator"
import { Screen } from "../../../components"
import { typography, useAppTheme } from "../../../theme"
import { AntDesign, Feather } from "@expo/vector-icons"
import { translate } from "../../../i18n"
import { useStores } from "../../../models"
import MembersList from "./components/MembersList"
import { OT_Member } from "../../../services/interfaces/IOrganizationTeam"
import { SvgXml } from "react-native-svg"
import { moreButtonDark, moreButtonLight } from "../../../components/svgs/icons"
import { GLOBAL_STYLE as GS } from "../../../../assets/ts/styles"
import ChangeRoleModal from "./components/ChangeRoleModal"
import ConfirmationModal from "../../../components/ConfirmationModal"
import { useOrganizationTeam } from "../../../services/hooks/useOrganization"
import { useTeamMemberCard } from "../../../services/hooks/features/useTeamMemberCard"
import { useNavigation } from "@react-navigation/native"
SettingScreenNavigationProp
} from '../../../navigators/AuthenticatedNavigator';
import { Screen } from '../../../components';
import { typography, useAppTheme } from '../../../theme';
import { AntDesign, Feather } from '@expo/vector-icons';
import { translate } from '../../../i18n';
import { useStores } from '../../../models';
import MembersList from './components/MembersList';
import { OT_Member } from '../../../services/interfaces/IOrganizationTeam';
import { SvgXml } from 'react-native-svg';
import { moreButtonDark, moreButtonLight } from '../../../components/svgs/icons';
import { GLOBAL_STYLE as GS } from '../../../../assets/ts/styles';
import ChangeRoleModal from './components/ChangeRoleModal';
import ConfirmationModal from '../../../components/ConfirmationModal';
import { useOrganizationTeam } from '../../../services/hooks/useOrganization';
import { useTeamMemberCard } from '../../../services/hooks/features/useTeamMemberCard';
import { useNavigation } from '@react-navigation/native';

export const MembersSettingsScreen: FC<AuthenticatedDrawerScreenProps<"MembersSettingsScreen">> = (
_props,
) => {
const { colors, dark } = useAppTheme()
export const MembersSettingsScreen: FC<AuthenticatedDrawerScreenProps<'MembersSettingsScreen'>> = (_props) => {
const { colors, dark } = useAppTheme();
// const { navigation } = _props
const { isTeamManager } = useOrganizationTeam()
const { isTeamManager } = useOrganizationTeam();

const {
teamStore: { activeTeam },
} = useStores()
teamStore: { activeTeam }
} = useStores();

const [selectMode, setSelectMode] = useState<boolean>(false)
const [showDropdownMenu, setShowDropdownMenu] = useState<boolean>(false)
const [selectedMembers, setSelectedMembers] = useState<OT_Member[]>([])
const [isNameEditMode, setIsNameEditMode] = useState<boolean>(false)
const [selectMode, setSelectMode] = useState<boolean>(false);
const [showDropdownMenu, setShowDropdownMenu] = useState<boolean>(false);
const [selectedMembers, setSelectedMembers] = useState<OT_Member[]>([]);
const [isNameEditMode, setIsNameEditMode] = useState<boolean>(false);

const navigation = useNavigation<SettingScreenNavigationProp<"Profile">>()
const alternateNavigation = useNavigation<DrawerNavigationProp<"AuthenticatedTab">>()
const navigation = useNavigation<SettingScreenNavigationProp<'Profile'>>();
const alternateNavigation = useNavigation<DrawerNavigationProp<'AuthenticatedTab'>>();

const addOrRemoveToSelectedList = (member: OT_Member): void => {
if (selectMode) {
if (!selectedMembers.some((selected) => selected.id === member.id)) {
setSelectedMembers([...selectedMembers, member])
setSelectedMembers([...selectedMembers, member]);
} else {
const updatedSelectedMembers = selectedMembers.filter(
(selectedMember) => selectedMember.id !== member.id,
)
setSelectedMembers(updatedSelectedMembers)
(selectedMember) => selectedMember.id !== member.id
);
setSelectedMembers(updatedSelectedMembers);
if (selectedMembers.length === 1) {
setSelectMode(false)
setShowDropdownMenu(false)
setSelectMode(false);
setShowDropdownMenu(false);
}
}
} else {
alternateNavigation.navigate("AuthenticatedTab")
alternateNavigation.navigate('AuthenticatedTab');
setTimeout(() => {
navigation.navigate("Profile", {
navigation.navigate('Profile', {
userId: member?.employee?.userId,
activeTab: "worked",
})
}, 50)
activeTab: 'worked'
});
}, 50);
}
}
};

const setSelectMembersMode = (member: OT_Member): void => {
if (!isTeamManager) return
if (!isTeamManager) return;
if (!selectMode) {
setSelectMode(true)
setSelectMode(true);
}
if (!selectedMembers.some((selectedMember) => selectedMember.id === member.id)) {
const updatedSelectedMembers = [...selectedMembers, member]
setSelectedMembers(updatedSelectedMembers)
const updatedSelectedMembers = [...selectedMembers, member];
setSelectedMembers(updatedSelectedMembers);
}
setSelectMode(true)
}
setSelectMode(true);
};

return (
<Screen
contentContainerStyle={[$container, { backgroundColor: colors.background }]}
safeAreaEdges={["top"]}
>
<Screen contentContainerStyle={[$container, { backgroundColor: colors.background }]} safeAreaEdges={['top']}>
<StatusBar barStyle={dark ? 'light-content' : 'dark-content'} />
<View style={[$headerContainer, { backgroundColor: colors.background }]}>
<View style={[styles.container, { backgroundColor: colors.background }]}>
<TouchableOpacity onPress={() => navigation.navigate("Setting")}>
<TouchableOpacity onPress={() => navigation.navigate('Setting')}>
<AntDesign name="arrowleft" size={24} color={colors.primary} />

Check warning on line 87 in apps/mobile/app/screens/Authenticated/MembersSettingsScreen/index.tsx

View workflow job for this annotation

GitHub Actions / Cspell

Unknown word (arrowleft)
</TouchableOpacity>
<Text style={[styles.title, { color: colors.primary }]}>
{translate("settingScreen.membersSettingsScreen.mainTitle")}
{translate('settingScreen.membersSettingsScreen.mainTitle')}
</Text>
<View style={{ position: "relative" }}>
<TouchableOpacity
onPress={() => selectMode && setShowDropdownMenu(!showDropdownMenu)}
>
<View style={{ position: 'relative' }}>
<TouchableOpacity onPress={() => selectMode && setShowDropdownMenu(!showDropdownMenu)}>
{selectMode ? (
showDropdownMenu ? (
<AntDesign name="close" size={24} color={colors.primary} />
Expand Down Expand Up @@ -128,16 +122,16 @@ export const MembersSettingsScreen: FC<AuthenticatedDrawerScreenProps<"MembersSe
addOrRemoveToSelectedList={addOrRemoveToSelectedList}
/>
</Screen>
)
}
);
};

interface IMenuDropdown {
showDropdownMenu: boolean
setShowDropdownMenu: React.Dispatch<SetStateAction<boolean>>
selectedMembers: OT_Member[]
setIsNameEditMode: React.Dispatch<SetStateAction<boolean>>
setSelectedMembers: React.Dispatch<SetStateAction<OT_Member[]>>
setSelectMode: React.Dispatch<SetStateAction<boolean>>
showDropdownMenu: boolean;
setShowDropdownMenu: React.Dispatch<SetStateAction<boolean>>;
selectedMembers: OT_Member[];
setIsNameEditMode: React.Dispatch<SetStateAction<boolean>>;
setSelectedMembers: React.Dispatch<SetStateAction<OT_Member[]>>;
setSelectMode: React.Dispatch<SetStateAction<boolean>>;
}

const MenuDropdown: React.FC<IMenuDropdown> = ({
Expand All @@ -146,138 +140,134 @@ const MenuDropdown: React.FC<IMenuDropdown> = ({
selectedMembers,
setIsNameEditMode,
setSelectMode,
setSelectedMembers,
setSelectedMembers
}) => {
const [showRoleModal, setShowRoleModal] = useState<boolean>(false)
const [showDeleteConfirmation, setShowDeleteConfirmation] = useState<boolean>(false)
const [showRoleModal, setShowRoleModal] = useState<boolean>(false);
const [showDeleteConfirmation, setShowDeleteConfirmation] = useState<boolean>(false);

const { colors } = useAppTheme()
const { colors } = useAppTheme();

const { removeMemberFromTeam } = useTeamMemberCard(selectedMembers[0])
const { removeMemberFromTeam } = useTeamMemberCard(selectedMembers[0]);

const reset = () => {
setSelectMode(false)
setSelectedMembers([])
}
setSelectMode(false);
setSelectedMembers([]);
};

return showDropdownMenu ? (
<>
<ChangeRoleModal
member={selectedMembers[0]}
visible={showRoleModal}
onDismiss={() => {
setShowRoleModal(false)
setTimeout(() => setShowDropdownMenu(false), 300)
reset()
setShowRoleModal(false);
setTimeout(() => setShowDropdownMenu(false), 300);
reset();
}}
/>
<ConfirmationModal
visible={showDeleteConfirmation}
onDismiss={() => {
setShowDeleteConfirmation(false)
setTimeout(() => setShowDropdownMenu(false), 300)
reset()
setShowDeleteConfirmation(false);
setTimeout(() => setShowDropdownMenu(false), 300);
reset();
}}
onConfirm={() => {
removeMemberFromTeam()
setShowDeleteConfirmation(false)
setShowDropdownMenu(false)
reset()
removeMemberFromTeam();
setShowDeleteConfirmation(false);
setShowDropdownMenu(false);
reset();
}}
confirmationText={translate(
"settingScreen.membersSettingsScreen.deleteUserConfirmation",
)}
confirmationText={translate('settingScreen.membersSettingsScreen.deleteUserConfirmation')}
/>
{selectedMembers.length === 1 && (
<View
style={[
styles.dropdownContainer,
{
...GS.shadowLg,
backgroundColor: colors.background,
},
backgroundColor: colors.background
}
]}
>
<TouchableOpacity
onPress={() => {
setShowRoleModal(true)
setShowRoleModal(true);
}}
>
<Text style={{ fontSize: 12, color: colors.primary }}>
{translate("settingScreen.membersSettingsScreen.changeRole")}
{translate('settingScreen.membersSettingsScreen.changeRole')}
</Text>
</TouchableOpacity>

<TouchableOpacity
onPress={() => {
setIsNameEditMode(true)
setShowDropdownMenu(false)
setIsNameEditMode(true);
setShowDropdownMenu(false);
}}
>
<Text style={{ fontSize: 12, color: colors.primary }}>
{translate("common.edit")}
</Text>
<Text style={{ fontSize: 12, color: colors.primary }}>{translate('common.edit')}</Text>
</TouchableOpacity>

<TouchableOpacity
onPress={() => {
setShowDeleteConfirmation(true)
setShowDeleteConfirmation(true);
}}
>
<Text style={{ fontSize: 12, color: "#DA5E5E" }}>
{translate("settingScreen.membersSettingsScreen.delete")}
<Text style={{ fontSize: 12, color: '#DA5E5E' }}>
{translate('settingScreen.membersSettingsScreen.delete')}
</Text>
</TouchableOpacity>
</View>
)}
</>
) : (
<></>
)
}
);
};

const $container: ViewStyle = {
flex: 1,
}
flex: 1
};

const $headerContainer: ViewStyle = {
padding: 20,
paddingVertical: 16,
shadowColor: "rgba(0, 0, 0, 0.6)",
shadowColor: 'rgba(0, 0, 0, 0.6)',
shadowOffset: {
width: 0,
height: 5,
height: 5
},
shadowOpacity: 0.07,
shadowRadius: 10,
elevation: 1,
zIndex: 10,
}
zIndex: 10
};

const styles = StyleSheet.create({
container: {
alignItems: "center",
flexDirection: "row",
justifyContent: "space-between",
width: "100%",
alignItems: 'center',
flexDirection: 'row',
justifyContent: 'space-between',
width: '100%'
},
dropdownContainer: {
borderRadius: 14,
flexDirection: "column",
flexDirection: 'column',
gap: 8,
padding: 10,
position: "absolute",
position: 'absolute',
right: 20,
shadowColor: "rgba(0, 0, 0, 0.52)",
shadowColor: 'rgba(0, 0, 0, 0.52)',
top: 6,
width: 100,
width: 100
},

title: {
alignSelf: "center",
alignSelf: 'center',
fontFamily: typography.primary.semiBold,
fontSize: 16,
textAlign: "center",
width: "80%",
},
})
textAlign: 'center',
width: '80%'
}
});
Loading

0 comments on commit ab60f5b

Please sign in to comment.