TelegramPWA/src/components/left/main/EmptyFolder.tsx
2022-05-31 20:58:47 +04:00

76 lines
2.4 KiB
TypeScript

import type { FC } from '../../../lib/teact/teact';
import React, { memo, useCallback } from '../../../lib/teact/teact';
import { withGlobal } from '../../../global';
import type { ApiChatFolder, ApiSticker } from '../../../api/types';
import { SettingsScreens } from '../../../types';
import type { FolderEditDispatch } from '../../../hooks/reducers/useFoldersReducer';
import { IS_SINGLE_COLUMN_LAYOUT } from '../../../util/environment';
import { selectAnimatedEmoji, selectChatFolder } from '../../../global/selectors';
import useLang from '../../../hooks/useLang';
import Button from '../../ui/Button';
import AnimatedIconFromSticker from '../../common/AnimatedIconFromSticker';
import './EmptyFolder.scss';
type OwnProps = {
folderId?: number;
folderType: 'all' | 'archived' | 'folder';
foldersDispatch?: FolderEditDispatch;
onScreenSelect?: (screen: SettingsScreens) => void;
};
type StateProps = {
chatFolder?: ApiChatFolder;
animatedEmoji?: ApiSticker;
};
const ICON_SIZE = 128;
const EmptyFolder: FC<OwnProps & StateProps> = ({
chatFolder, animatedEmoji, foldersDispatch, onScreenSelect,
}) => {
const lang = useLang();
const handleEditFolder = useCallback(() => {
foldersDispatch!({ type: 'editFolder', payload: chatFolder });
onScreenSelect!(SettingsScreens.FoldersEditFolderFromChatList);
}, [chatFolder, foldersDispatch, onScreenSelect]);
return (
<div className="EmptyFolder">
<div className="sticker">
{animatedEmoji && <AnimatedIconFromSticker sticker={animatedEmoji} size={ICON_SIZE} />}
</div>
<h3 className="title" dir="auto">{lang('FilterNoChatsToDisplay')}</h3>
<p className="description" dir="auto">
{lang(chatFolder ? 'ChatList.EmptyChatListFilterText' : 'Chat.EmptyChat')}
</p>
{chatFolder && foldersDispatch && onScreenSelect && (
<Button
ripple={!IS_SINGLE_COLUMN_LAYOUT}
fluid
pill
onClick={handleEditFolder}
size="smaller"
isRtl={lang.isRtl}
>
<i className="icon-settings" />
{lang('ChatList.EmptyChatListEditFilter')}
</Button>
)}
</div>
);
};
export default memo(withGlobal<OwnProps>((global, { folderId, folderType }): StateProps => {
const chatFolder = folderId && folderType === 'folder' ? selectChatFolder(global, folderId) : undefined;
return {
chatFolder,
animatedEmoji: selectAnimatedEmoji(global, '📂'),
};
})(EmptyFolder));