From 8794782a4e2a13dc2a17dfebbf3903ffa4f9ef0c Mon Sep 17 00:00:00 2001
From: Szymon Szlachtowicz <38212223+Szymx95@users.noreply.github.com>
Date: Tue, 4 Jan 2022 10:39:15 +0100
Subject: [PATCH] Refactor emoji picker (#169)
---
packages/react-chat-example/src/index.tsx | 2 +-
.../src/components/Chat/ChatInput.tsx | 34 ++--------------
.../src/components/Chat/EmojiPicker.tsx | 40 +++++++++++++++++++
3 files changed, 45 insertions(+), 31 deletions(-)
create mode 100644 packages/react-chat/src/components/Chat/EmojiPicker.tsx
diff --git a/packages/react-chat-example/src/index.tsx b/packages/react-chat-example/src/index.tsx
index f346e8df..880fc5f1 100644
--- a/packages/react-chat-example/src/index.tsx
+++ b/packages/react-chat-example/src/index.tsx
@@ -76,7 +76,7 @@ function DragDiv() {
diff --git a/packages/react-chat/src/components/Chat/ChatInput.tsx b/packages/react-chat/src/components/Chat/ChatInput.tsx
index 689364ea..f101fb7c 100644
--- a/packages/react-chat/src/components/Chat/ChatInput.tsx
+++ b/packages/react-chat/src/components/Chat/ChatInput.tsx
@@ -1,4 +1,3 @@
-import { Picker } from "emoji-mart";
import React, {
useCallback,
useEffect,
@@ -6,13 +5,11 @@ import React, {
useRef,
useState,
} from "react";
-import styled, { useTheme } from "styled-components";
+import styled from "styled-components";
import { useMessengerContext } from "../../contexts/messengerProvider";
import { useModal } from "../../contexts/modalProvider";
-import { useLow } from "../../contexts/narrowProvider";
import { Reply } from "../../hooks/useReply";
-import { lightTheme, Theme } from "../../styles/themes";
import { uintToImgUrl } from "../../utils/uintToImgUrl";
import { ClearSvg } from "../Icons/ClearIcon";
import { EmojiIcon } from "../Icons/EmojiIcon";
@@ -25,6 +22,8 @@ import { SizeLimitModal, SizeLimitModalName } from "../Modals/SizeLimitModal";
import { SearchBlock } from "../SearchBlock";
import { textMediumStyles, textSmallStyles } from "../Text";
+import { EmojiPicker } from "./EmojiPicker";
+
interface ChatInputProps {
reply: Reply | undefined;
setReply: (val: Reply | undefined) => void;
@@ -33,15 +32,12 @@ interface ChatInputProps {
export function ChatInput({ reply, setReply, disabled }: ChatInputProps) {
const { sendMessage, contacts } = useMessengerContext();
- const theme = useTheme() as Theme;
const [content, setContent] = useState("");
const [clearComponent, setClearComponent] = useState("");
const [showEmoji, setShowEmoji] = useState(false);
const [inputHeight, setInputHeight] = useState(40);
const [imageUint, setImageUint] = useState(undefined);
- const low = useLow();
-
const { setModal } = useModal(SizeLimitModalName);
const [query, setQuery] = useState("");
@@ -203,29 +199,7 @@ export function ChatInput({ reply, setReply, disabled }: ChatInputProps) {
return (
- {showEmoji && (
-
- )}
-
+
void;
+};
+
+export function EmojiPicker({ showEmoji, addEmoji }: EmojiPickerProps) {
+ const theme = useTheme() as Theme;
+ const low = useLow();
+
+ if (showEmoji) {
+ return (
+
+ );
+ }
+ return null;
+}