ChatInfoModal.jsx 3.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. import { Avatar, Button, IconButton } from "@mui/material";
  2. import { connect } from "react-redux";
  3. import { history } from "../../App";
  4. import { backendURL } from "../../helpers/gql";
  5. import { MemberList } from "../MemberList/MemberList";
  6. import { ChatInfoModalHeader, ChatInfoModalWrapper, ChatInfoModalName, ChatInfoTitle, ChatInfoModalMain, Divider, MemberListHeader, MemberAmount, ChatInfoModalAvatar, Drop } from "./ChatInfoModal.style";
  7. import CloseIcon from "./icons8-close.svg";
  8. import MembersIcon from "./user.png";
  9. import AddUserIcon from "./add-user.png";
  10. import { useEffect, useState } from "react";
  11. import { SearchUserForChat } from "../SearchUserForChat/SearchUserForChat";
  12. import {actionUpsertChat } from "../../actions/actionsForChats";
  13. import DropZoneAvatar from "../DropZone/DropZoneAvatar";
  14. import { actionSetChatAvatar } from "../../actions/actionsMedia";
  15. import ChatInfoOptions from "../ChatInfoOptions/ChatInfoOptions";
  16. const CDropZoneAvatarForChat = connect(null, {onLoad: actionSetChatAvatar})(DropZoneAvatar);
  17. const ChatInfoModal = ({handleClose, chats, userId, updateChat}) => {
  18. const [,route, histId] = history.location.pathname.split('/');
  19. useEffect(() => {
  20. chats[histId] || handleClose()
  21. }, [chats[histId]])
  22. const [isOpenSearch, setIsOpenSearch] = useState();
  23. // old members + new
  24. const [users, setUsers] = useState();
  25. const amount = chats[histId]?.members?.length;
  26. const isOwner = userId === chats[histId]?.owner?._id;
  27. //current memberd (old)
  28. const currMembers = chats[histId]?.members?.map(item => {
  29. let {_id} = item;
  30. return {_id}
  31. });
  32. return(!isOpenSearch) ?
  33. <ChatInfoModalWrapper>
  34. <ChatInfoModalHeader>
  35. <ChatInfoModalName>Chat Info</ChatInfoModalName>
  36. <div style={{paddingLeft: "150px"}}>
  37. <ChatInfoOptions setIsOpenSearch={setIsOpenSearch} isOwner={isOwner} chatId={histId}/>
  38. </div>
  39. <IconButton onClick={handleClose}>
  40. <img style={{cursor: 'pointer'}} src={CloseIcon}/>
  41. </IconButton>
  42. </ChatInfoModalHeader>
  43. <ChatInfoModalMain>
  44. <ChatInfoModalAvatar>
  45. <Avatar
  46. src={`${backendURL}/${chats[histId]?.avatar?.url || ''}`}
  47. alt="chatavatar"
  48. sx={{ width: 75, height: 75}}
  49. />
  50. {isOwner && <CDropZoneAvatarForChat component={"dropAvatarPopupComponent"}/>}
  51. </ChatInfoModalAvatar>
  52. <ChatInfoTitle>{chats[histId]?.title}</ChatInfoTitle>
  53. </ChatInfoModalMain>
  54. <Divider/>
  55. <MemberListHeader>
  56. <img src={MembersIcon} style={{height: "20px", marginRight: "30px"}}/>
  57. <MemberAmount>{amount} {amount === 1 ? 'member' : 'members'}</MemberAmount>
  58. {isOwner && <img src={AddUserIcon} style={{height: "20px", cursor: "pointer"}} onClick={() => setIsOpenSearch(true)}/>}
  59. </MemberListHeader>
  60. <MemberList members={chats[histId]?.members}/>
  61. </ChatInfoModalWrapper>
  62. :
  63. <>
  64. <SearchUserForChat getUsers={setUsers} members={currMembers}/>
  65. <div style={{display: "flex",
  66. padding: "10px 15px",
  67. justifyContent: "right",
  68. alignItems: "center"}}>
  69. <Button variant="text" onClick={handleClose} >Cancel</Button>
  70. <Button variant="text" onClick={() => {updateChat(histId, null, users); handleClose()}}>Add</Button>
  71. </div>
  72. </>
  73. }
  74. export default connect(state => ({
  75. chats: state?.chats || [],
  76. userId: state?.auth?.payload?.sub?.id
  77. }), {updateChat: actionUpsertChat})(ChatInfoModal);