@fortawesome/free-solid-svg-icons#faSmile TypeScript Examples
The following examples show how to use
@fortawesome/free-solid-svg-icons#faSmile.
You can vote up the ones you like or vote down the ones you don't like,
and go to the original project or source file by following the links above each example. You may check out the related API usage on the sidebar.
Example #1
Source File: Chat.tsx From sync-party with GNU General Public License v3.0 | 4 votes |
export default function Chat({
isActive,
socket,
setPlayerFocused,
freezeUiVisible
}: Props): ReactElement {
const party = useSelector((state: RootAppState) => state.globalState.party);
const user = useSelector((state: RootAppState) => state.globalState.user);
const chat = useSelector((state: RootAppState) => state.globalState.chat);
const uiVisible = useSelector(
(state: RootAppState) => state.globalState.uiVisible
);
const uiFocused = useSelector(
(state: RootAppState) => state.globalState.uiFocused
);
const { t } = useTranslation();
const dispatch = useDispatch();
const [textInput, setTextInput] = useState('');
const [showEmojiPicker, setShowEmojiPicker] = useState(false);
const [historyStaysVisible, setHistoryStaysVisible] = useState(false);
const chatHistoryRef = useRef<HTMLDivElement | null>(null);
const textInputRef = useRef<HTMLTextAreaElement | null>(null);
const scrollHistoryToBottom = (): void => {
if (chatHistoryRef && chatHistoryRef.current) {
chatHistoryRef.current.scrollTop =
chatHistoryRef.current.scrollHeight;
}
};
const sendMessage = (message: string): void => {
if (socket && user && party && message !== '') {
const chatMessage = {
userId: user.id,
partyId: party.id,
userName: user.username,
message: message
};
socket.emit('chatMessage', chatMessage);
setTextInput('');
}
};
const focusTextInput = useCallback((): void => {
if (textInputRef.current) {
textInputRef.current.focus();
freezeUiVisible(true);
}
}, [freezeUiVisible]);
const blurTextInput = (): void => {
if (textInputRef.current) {
textInputRef.current.blur();
}
};
const handleInputFieldKeyDown = (event: React.KeyboardEvent): void => {
if (event.key === 'Enter') {
event.preventDefault();
sendMessage(textInput);
freezeUiVisible(false);
setShowEmojiPicker(false);
} else if (event.key === 'Escape') {
if (showEmojiPicker) {
setShowEmojiPicker(false);
focusTextInput();
} else {
setPlayerFocused(true);
freezeUiVisible(false);
blurTextInput();
}
}
};
const handleEmojiPickerKeydown = (event: React.KeyboardEvent): void => {
if (event.key === 'Escape') {
setShowEmojiPicker(false);
focusTextInput();
}
};
const handleEmojiPickerIconClick = (): void => {
if (!showEmojiPicker) {
freezeUiVisible(true);
}
setShowEmojiPicker(!showEmojiPicker);
setPlayerFocused(!showEmojiPicker);
focusTextInput();
};
const addEmoji = (emoji: BaseEmoji): void => {
if (textInputRef.current) {
textInputRef.current.focus();
setTimeout(() => {
if (textInputRef.current) {
const newCursorPosition =
textInputRef.current.selectionStart +
emoji.native.length;
const textBeforeCursorPosition =
textInputRef.current.value.substring(
0,
textInputRef.current.selectionStart
);
const textAfterCursorPosition =
textInputRef.current.value.substring(
textInputRef.current.selectionEnd,
textInputRef.current.value.length
);
setTextInput(
textBeforeCursorPosition +
emoji.native +
textAfterCursorPosition
);
textInputRef.current.selectionStart =
textInputRef.current.selectionEnd = newCursorPosition;
}
}, 10);
}
};
// At mounting
useEffect(() => {
scrollHistoryToBottom();
}, [isActive]);
// If isActive changes
useEffect(() => {
if (isActive !== uiFocused.chat) {
if (isActive) {
setTimeout(() => {
scrollHistoryToBottom();
focusTextInput();
}, 50);
} else {
setHistoryStaysVisible(false);
}
dispatch(
setGlobalState({
uiFocused: {
...uiFocused,
chat: isActive
}
})
);
}
}, [isActive, dispatch, focusTextInput, uiFocused]);
// If ui visibility or history timeout changes
useEffect(() => {
scrollHistoryToBottom();
}, [uiVisible, historyStaysVisible]);
// If there is a new message
useEffect(() => {
scrollHistoryToBottom();
setHistoryStaysVisible(true);
const historyTimeoutId = setTimeout(() => {
setHistoryStaysVisible(false);
}, 12000);
return (): void => {
clearTimeout(historyTimeoutId);
};
}, [chat, freezeUiVisible]);
return (
<div
className={
'absolute bottom-0 left-0 ml-3' +
(uiVisible ? ' mb-24' : ' mb-10')
}
>
<div className="flex flex-row">
<div className="flex flex-col mt-auto z-50">
{!(uiVisible && !isActive && !historyStaysVisible) &&
(uiVisible || historyStaysVisible) &&
party &&
user &&
chat[party.id] && (
<ChatHistory
chatHistoryRef={chatHistoryRef}
chat={chat}
party={party}
userId={user.id}
isActive={isActive}
uiVisible={uiVisible}
t={t}
></ChatHistory>
)}
{isActive && uiVisible && (
<div className="mt-auto">
<ChatInput
textInputRef={textInputRef}
textInput={textInput}
setPlayerFocused={setPlayerFocused}
freezeUiVisible={freezeUiVisible}
handleInputFieldKeyDown={
handleInputFieldKeyDown
}
setTextInput={setTextInput}
t={t}
></ChatInput>
</div>
)}
</div>
{isActive && (
<div className="mt-auto">
{showEmojiPicker && uiVisible && (
<div
className="ml-2 mb-1"
onKeyDown={handleEmojiPickerKeydown}
>
<Picker
native={true}
sheetSize={16}
showPreview={false}
useButton={false}
onSelect={(emoji: BaseEmoji): void => {
addEmoji(emoji);
}}
></Picker>
</div>
)}
{!showEmojiPicker && uiVisible && (
<FontAwesomeIcon
icon={faSmile}
className="ml-2 cursor-pointer text-2xl mb-1"
onClick={handleEmojiPickerIconClick}
></FontAwesomeIcon>
)}
</div>
)}
</div>
</div>
);
}