From f5dd23ce97c672d28190f12d06a7b3378f4cc789 Mon Sep 17 00:00:00 2001
From: Maria Rushkova <66270386+mrushkova@users.noreply.github.com>
Date: Wed, 19 Jan 2022 14:22:56 +0100
Subject: [PATCH] Fix creation mode alignment (#195)
---
.../src/components/Buttons/BackButton.tsx | 2 +-
.../src/components/Chat/ChatBody.tsx | 2 +-
.../src/components/Chat/ChatCreation.tsx | 207 ++++++++++--------
.../src/components/Chat/ChatInput.tsx | 6 +-
4 files changed, 124 insertions(+), 93 deletions(-)
diff --git a/packages/react-chat/src/components/Buttons/BackButton.tsx b/packages/react-chat/src/components/Buttons/BackButton.tsx
index 859470b..9bfaf2c 100644
--- a/packages/react-chat/src/components/Buttons/BackButton.tsx
+++ b/packages/react-chat/src/components/Buttons/BackButton.tsx
@@ -21,7 +21,7 @@ const BackBtn = styled.button`
left: 0;
top: 8px;
width: 32px;
- height: 32px;
+ height: 44px;
padding: 0;
&.narrow {
diff --git a/packages/react-chat/src/components/Chat/ChatBody.tsx b/packages/react-chat/src/components/Chat/ChatBody.tsx
index 8ff134b..c076c39 100644
--- a/packages/react-chat/src/components/Chat/ChatBody.tsx
+++ b/packages/react-chat/src/components/Chat/ChatBody.tsx
@@ -134,7 +134,7 @@ export function ChatBody({ onClick, showMembers, permission }: ChatBodyProps) {
return ;
}
-const Wrapper = styled.div`
+export const Wrapper = styled.div`
width: 61%;
display: flex;
flex-direction: column;
diff --git a/packages/react-chat/src/components/Chat/ChatCreation.tsx b/packages/react-chat/src/components/Chat/ChatCreation.tsx
index 3f6f52f..8d7f2f5 100644
--- a/packages/react-chat/src/components/Chat/ChatCreation.tsx
+++ b/packages/react-chat/src/components/Chat/ChatCreation.tsx
@@ -15,6 +15,7 @@ import { Member } from "../Members/Member";
import { SearchBlock } from "../SearchBlock";
import { textMediumStyles } from "../Text";
+import { Wrapper } from "./ChatBody";
import { ChatInput } from "./ChatInput";
interface ChatCreationProps {
@@ -82,84 +83,91 @@ export function ChatCreation({
);
return (
-
-
- {narrow && (
- setChatState(ChatState.ChatBody)}
- className="narrow"
- />
- )}
-
- To:
-
- {styledGroup.map((member) => (
-
- {member.slice(0, 10)}
- removeMember(member)}>
-
-
-
- ))}
-
- {styledGroup.length < 5 && (
-
- setQuery(e.currentTarget.value)}
- />
-
-
+
+
+
+ {narrow && (
+ setChatState(ChatState.ChatBody)}
+ className="narrow"
+ />
)}
- {styledGroup.length === 5 && (
- 5 user Limit reached
- )}
-
- {
- if (!activeChannel) {
- createChat(styledGroup);
- } else {
- addMembers(styledGroup, activeChannel.id);
- }
- setEditGroup?.(false);
- }}
- >
- Confirm
-
- {!narrow && }
-
- {!setEditGroup && !query && (
-
- Contacts
-
- {identity &&
- Object.values(contacts)
- .filter(
- (e) =>
- e.id != bufToHex(identity.publicKey) &&
- !styledGroup.includes(e.id)
- )
- .map((contact) => (
- addMember(contact.id)}
- />
+
+
+ To:
+
+ {styledGroup.map((member) => (
+
+ {member.slice(0, 10)}
+ removeMember(member)}>
+
+
+
))}
-
-
- )}
- {!activeChannel && (
-
- )}
-
+
+ {styledGroup.length < 5 && (
+
+ setQuery(e.currentTarget.value)}
+ />
+
+
+ )}
+ {!narrow && styledGroup.length === 5 && (
+ 5 user Limit reached
+ )}
+
+ {narrow && styledGroup.length === 5 && (
+ 5 user Limit reached
+ )}
+
+ {
+ if (!activeChannel) {
+ createChat(styledGroup);
+ } else {
+ addMembers(styledGroup, activeChannel.id);
+ }
+ setEditGroup?.(false);
+ }}
+ >
+ Confirm
+
+ {!narrow && }
+
+ {!setEditGroup && !query && (
+
+ Contacts
+
+ {identity &&
+ Object.values(contacts)
+ .filter(
+ (e) =>
+ e.id != bufToHex(identity.publicKey) &&
+ !styledGroup.includes(e.id)
+ )
+ .map((contact) => (
+ addMember(contact.id)}
+ />
+ ))}
+
+
+ )}
+ {!activeChannel && (
+
+ )}
+
+
);
}
@@ -167,6 +175,7 @@ const CreationWrapper = styled.div`
display: flex;
flex-direction: column;
width: 100%;
+ height: 100%;
background-color: ${({ theme }) => theme.bodyBackgroundColor};
padding: 8px 16px;
`;
@@ -175,24 +184,35 @@ const CreationBar = styled.div`
display: flex;
align-items: center;
margin-bottom: 32px;
+
+ &.limit {
+ align-items: flex-start;
+ }
+`;
+
+const Column = styled.div`
+ display: flex;
+ flex-direction: column;
+ align-items: center;
+ flex: 1;
+ margin-right: 16px;
+ overflow-x: hidden;
+
+ &.narrow {
+ }
`;
const InputBar = styled.div`
display: flex;
align-items: center;
- flex: 1;
width: 100%;
+ height: 44px;
background-color: ${({ theme }) => theme.inputColor};
border: 1px solid ${({ theme }) => theme.inputColor};
border-radius: 8px;
- padding: 8px 16px;
- margin-right: 16px;
+ padding: 6px 16px;
${textMediumStyles}
-
- &.narrow {
- overflow-x: hidden;
- }
`;
const Input = styled.input`
@@ -227,13 +247,11 @@ const CreationBtn = styled.button`
const StyledList = styled.div`
display: flex;
+ overflow-x: scroll;
+ margin-right: 8px;
- &.narrow {
- overflow-x: scroll;
-
- &::-webkit-scrollbar {
- display: none;
- }
+ &::-webkit-scrollbar {
+ display: none;
}
`;
@@ -244,7 +262,10 @@ const StyledMember = styled.div`
background: ${({ theme }) => theme.tertiary};
color: ${({ theme }) => theme.bodyBackgroundColor};
border-radius: 8px;
- margin-right: 8px;
+
+ & + & {
+ margin-left: 8px;
+ }
`;
const StyledName = styled.p`
@@ -259,6 +280,7 @@ const CloseButton = styled.button`
`;
const Contacts = styled.div`
+ height: calc(100% - 44px);
display: flex;
flex-direction: column;
flex: 1;
@@ -285,4 +307,9 @@ const LimitAlert = styled.p`
text-transform: uppercase;
margin-left: auto;
color: ${({ theme }) => theme.redColor};
+ white-space: nowrap;
+
+ &.narrow {
+ margin: 8px 0 0;
+ }
`;
diff --git a/packages/react-chat/src/components/Chat/ChatInput.tsx b/packages/react-chat/src/components/Chat/ChatInput.tsx
index 70225b3..3250a2d 100644
--- a/packages/react-chat/src/components/Chat/ChatInput.tsx
+++ b/packages/react-chat/src/components/Chat/ChatInput.tsx
@@ -217,7 +217,7 @@ export function ChatInput({
);
return (
-
+
@@ -348,6 +348,10 @@ const View = styled.div`
align-items: flex-end;
padding: 6px 8px 6px 10px;
position: relative;
+
+ &.creation {
+ padding: 0;
+ }
`;
const InputArea = styled.div`