71 lines
2.3 KiB
TypeScript
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));
|