TelegramPWA/src/components/left/main/EmptyFolder.tsx

71 lines
2.3 KiB
TypeScript

import React, { FC, memo, useCallback } from '../../../lib/teact/teact';
import { withGlobal } from '../../../lib/teact/teactn';
import { ApiChatFolder, ApiSticker } from '../../../api/types';
import { SettingsScreens } from '../../../types';
import { FolderEditDispatch } from '../../../hooks/reducers/useFoldersReducer';
import { IS_SINGLE_COLUMN_LAYOUT } from '../../../util/environment';
import { selectAnimatedEmoji, selectChatFolder } from '../../../modules/selectors';
import useLang from '../../../hooks/useLang';
import Button from '../../ui/Button';
import AnimatedEmoji from '../../common/AnimatedEmoji';
import './EmptyFolder.scss';
type OwnProps = {
folderId?: number;
folderType: 'all' | 'archived' | 'folder';
foldersDispatch?: FolderEditDispatch;
onScreenSelect?: (screen: SettingsScreens) => void;
};
type StateProps = {
chatFolder?: ApiChatFolder;
animatedEmoji?: ApiSticker;
};
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 && <AnimatedEmoji sticker={animatedEmoji} />}</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));