Files
cinny/src/app/organisms/navigation/DrawerHeader.jsx
T

152 lines
4.6 KiB
React
Raw Normal View History

2022-02-20 20:17:13 +05:30
import React from 'react';
import PropTypes from 'prop-types';
2022-01-29 13:48:06 +05:30
import './DrawerHeader.scss';
2021-11-23 11:56:02 +05:30
import { twemojify } from '../../../util/twemojify';
2021-09-03 17:58:01 +05:30
import initMatrix from '../../../client/initMatrix';
2021-09-05 18:56:34 +05:30
import cons from '../../../client/state/cons';
import {
2022-02-20 20:17:13 +05:30
openPublicRooms, openCreateRoom, openSpaceManage,
openSpaceAddExisting, openInviteUser, openReusableContextMenu,
} from '../../../client/action/navigation';
2022-01-29 14:11:05 +05:30
import { getEventCords } from '../../../util/common';
2022-01-29 13:48:06 +05:30
import { blurOnBubbling } from '../../atoms/button/script';
import Text from '../../atoms/text/Text';
2022-01-29 13:48:06 +05:30
import RawIcon from '../../atoms/system-icons/RawIcon';
import Header, { TitleWrapper } from '../../atoms/header/Header';
import IconButton from '../../atoms/button/IconButton';
2022-02-20 20:17:13 +05:30
import { MenuItem, MenuHeader } from '../../atoms/context-menu/ContextMenu';
2022-01-29 14:11:05 +05:30
import SpaceOptions from '../../molecules/space-options/SpaceOptions';
import PlusIC from '../../../../public/res/ic/outlined/plus.svg';
import HashPlusIC from '../../../../public/res/ic/outlined/hash-plus.svg';
2022-02-07 15:45:57 +05:30
import HashGlobeIC from '../../../../public/res/ic/outlined/hash-globe.svg';
2022-02-20 20:17:13 +05:30
import HashSearchIC from '../../../../public/res/ic/outlined/hash-search.svg';
import SpacePlusIC from '../../../../public/res/ic/outlined/space-plus.svg';
2022-01-29 13:48:06 +05:30
import ChevronBottomIC from '../../../../public/res/ic/outlined/chevron-bottom.svg';
2022-02-20 20:17:13 +05:30
function HomeSpaceOptions({ spaceId, afterOptionSelect }) {
const mx = initMatrix.matrixClient;
const room = mx.getRoom(spaceId);
const canManage = room
? room.currentState.maySendStateEvent('m.space.child', mx.getUserId())
: true;
return (
<>
<MenuHeader>Add rooms or spaces</MenuHeader>
<MenuItem
iconSrc={HashPlusIC}
onClick={() => { afterOptionSelect(); openCreateRoom(); }}
disabled={!canManage}
>
Create new room
</MenuItem>
<MenuItem
iconSrc={SpacePlusIC}
onClick={() => { afterOptionSelect(); }}
disabled={!canManage}
>
Create new space
</MenuItem>
{ !spaceId && (
<MenuItem
iconSrc={HashGlobeIC}
onClick={() => { afterOptionSelect(); openPublicRooms(); }}
>
Join public room
</MenuItem>
)}
{ spaceId && (
<MenuItem
iconSrc={PlusIC}
onClick={() => { afterOptionSelect(); openSpaceAddExisting(spaceId); }}
disabled={!canManage}
>
Add existing
</MenuItem>
)}
{ spaceId && (
<MenuItem
onClick={() => { afterOptionSelect(); openSpaceManage(spaceId); }}
iconSrc={HashSearchIC}
>
Manage rooms
</MenuItem>
)}
</>
);
}
HomeSpaceOptions.defaultProps = {
spaceId: null,
};
HomeSpaceOptions.propTypes = {
spaceId: PropTypes.string,
afterOptionSelect: PropTypes.func.isRequired,
};
2021-09-03 17:58:01 +05:30
function DrawerHeader({ selectedTab, spaceId }) {
const mx = initMatrix.matrixClient;
2021-09-05 18:56:34 +05:30
const tabName = selectedTab !== cons.tabs.DIRECTS ? 'Home' : 'Direct messages';
2021-09-03 17:58:01 +05:30
2022-02-20 20:17:13 +05:30
const isDMTab = selectedTab === cons.tabs.DIRECTS;
2021-09-03 17:58:01 +05:30
const room = mx.getRoom(spaceId);
2022-02-20 20:17:13 +05:30
const spaceName = isDMTab ? null : (room?.name || null);
2022-01-29 14:11:05 +05:30
const openSpaceOptions = (e) => {
e.preventDefault();
openReusableContextMenu(
'bottom',
2022-01-29 19:54:39 +05:30
getEventCords(e, '.header'),
2022-01-29 14:11:05 +05:30
(closeMenu) => <SpaceOptions roomId={spaceId} afterOptionSelect={closeMenu} />,
);
};
2022-02-20 20:17:13 +05:30
const openHomeSpaceOptions = (e) => {
e.preventDefault();
openReusableContextMenu(
'right',
getEventCords(e, '.ic-btn'),
(closeMenu) => <HomeSpaceOptions spaceId={spaceId} afterOptionSelect={closeMenu} />,
);
};
return (
<Header>
2022-01-29 13:48:06 +05:30
{spaceName ? (
<button
className="drawer-header__btn"
2022-01-29 14:11:05 +05:30
onClick={openSpaceOptions}
2022-01-29 13:48:06 +05:30
type="button"
onMouseUp={(e) => blurOnBubbling(e, '.drawer-header__btn')}
>
<TitleWrapper>
<Text variant="s1" weight="medium" primary>{twemojify(spaceName)}</Text>
</TitleWrapper>
<RawIcon size="small" src={ChevronBottomIC} />
</button>
) : (
<TitleWrapper>
<Text variant="s1" weight="medium" primary>{tabName}</Text>
</TitleWrapper>
)}
2022-02-20 20:17:13 +05:30
{ isDMTab && <IconButton onClick={() => openInviteUser()} tooltip="Start DM" src={PlusIC} size="small" /> }
{ !isDMTab && <IconButton onClick={openHomeSpaceOptions} tooltip="Add rooms/spaces" src={PlusIC} size="small" /> }
</Header>
);
}
2021-09-03 17:58:01 +05:30
DrawerHeader.defaultProps = {
spaceId: null,
};
DrawerHeader.propTypes = {
2021-09-03 17:58:01 +05:30
selectedTab: PropTypes.string.isRequired,
spaceId: PropTypes.string,
};
export default DrawerHeader;