matrix-react-sdk
Version:
SDK for matrix.org using React
200 lines (163 loc) • 24.2 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireDefault(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var sdk = _interopRequireWildcard(require("../../../index"));
var _dispatcher = _interopRequireDefault(require("../../../dispatcher/dispatcher"));
var _languageHandler = require("../../../languageHandler");
var _classnames = _interopRequireDefault(require("classnames"));
var _MatrixClientPeg = require("../../../MatrixClientPeg");
var _ContextMenu = require("../../structures/ContextMenu");
var _MatrixClientContext = _interopRequireDefault(require("../../../contexts/MatrixClientContext"));
var _RovingTabIndex = require("../../../accessibility/RovingTabIndex");
var _replaceableComponent = require("../../../utils/replaceableComponent");
var _Media = require("../../../customisations/Media");
var _dec, _class, _class2, _temp;
let GroupInviteTile = ( // XXX this class copies a lot from RoomTile.js
_dec = (0, _replaceableComponent.replaceableComponent)("views.groups.GroupInviteTile"), _dec(_class = (_temp = _class2 = class GroupInviteTile extends _react.default.Component {
constructor(props, context) {
super(props, context);
(0, _defineProperty2.default)(this, "onClick", e => {
_dispatcher.default.dispatch({
action: 'view_group',
group_id: this.props.group.groupId
});
});
(0, _defineProperty2.default)(this, "onMouseEnter", () => {
const state = {
hover: true
}; // Only allow non-guests to access the context menu
if (!this.context.isGuest()) {
state.badgeHover = true;
}
this.setState(state);
});
(0, _defineProperty2.default)(this, "onMouseLeave", () => {
this.setState({
badgeHover: false,
hover: false
});
});
(0, _defineProperty2.default)(this, "onContextMenuButtonClick", e => {
// Prevent the RoomTile onClick event firing as well
e.stopPropagation();
e.preventDefault();
this._showContextMenu(e.target.getBoundingClientRect());
});
(0, _defineProperty2.default)(this, "onContextMenu", e => {
// Prevent the native context menu
e.preventDefault();
this._showContextMenu({
right: e.clientX,
top: e.clientY,
height: 0
});
});
(0, _defineProperty2.default)(this, "closeMenu", () => {
this.setState({
contextMenuPosition: null
});
});
this.state = {
hover: false,
badgeHover: false,
menuDisplayed: false,
selected: this.props.group.groupId === null // XXX: this needs linking to LoggedInView/GroupView state
};
}
_showContextMenu(boundingClientRect) {
// Only allow non-guests to access the context menu
if (_MatrixClientPeg.MatrixClientPeg.get().isGuest()) return;
const state = {
contextMenuPosition: boundingClientRect
}; // If the badge is clicked, then no longer show tooltip
if (this.props.collapsed) {
state.hover = false;
}
this.setState(state);
}
render() {
const AccessibleButton = sdk.getComponent('elements.AccessibleButton');
const BaseAvatar = sdk.getComponent('avatars.BaseAvatar');
const groupName = this.props.group.name || this.props.group.groupId;
const httpAvatarUrl = this.props.group.avatarUrl ? (0, _Media.mediaFromMxc)(this.props.group.avatarUrl).getSquareThumbnailHttp(24) : null;
const av = /*#__PURE__*/_react.default.createElement(BaseAvatar, {
name: groupName,
width: 24,
height: 24,
url: httpAvatarUrl
});
const isMenuDisplayed = Boolean(this.state.contextMenuPosition);
const nameClasses = (0, _classnames.default)('mx_RoomTile_name mx_RoomTile_invite mx_RoomTile_badgeShown', {
'mx_RoomTile_badgeShown': this.state.badgeHover || isMenuDisplayed
}); // XXX: this is a workaround for Firefox giving this div a tabstop :( [tabIndex]
const label = /*#__PURE__*/_react.default.createElement("div", {
title: this.props.group.groupId,
className: nameClasses,
tabIndex: -1,
dir: "auto"
}, groupName);
const badgeEllipsis = this.state.badgeHover || isMenuDisplayed;
const badgeClasses = (0, _classnames.default)('mx_RoomTile_badge mx_RoomTile_highlight', {
'mx_RoomTile_badgeButton': badgeEllipsis
});
const badgeContent = badgeEllipsis ? '\u00B7\u00B7\u00B7' : '!';
let tooltip;
if (this.props.collapsed && this.state.hover) {
const Tooltip = sdk.getComponent("elements.Tooltip");
tooltip = /*#__PURE__*/_react.default.createElement(Tooltip, {
className: "mx_RoomTile_tooltip",
label: groupName,
dir: "auto"
});
}
const classes = (0, _classnames.default)('mx_RoomTile mx_RoomTile_highlight', {
'mx_RoomTile_menuDisplayed': isMenuDisplayed,
'mx_RoomTile_selected': this.state.selected,
'mx_GroupInviteTile': true
});
let contextMenu;
if (isMenuDisplayed) {
const GroupInviteTileContextMenu = sdk.getComponent('context_menus.GroupInviteTileContextMenu');
contextMenu = /*#__PURE__*/_react.default.createElement(_ContextMenu.ContextMenu, (0, _extends2.default)({}, (0, _ContextMenu.toRightOf)(this.state.contextMenuPosition), {
onFinished: this.closeMenu
}), /*#__PURE__*/_react.default.createElement(GroupInviteTileContextMenu, {
group: this.props.group,
onFinished: this.closeMenu
}));
}
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_RovingTabIndex.RovingTabIndexWrapper, null, ({
onFocus,
isActive,
ref
}) => /*#__PURE__*/_react.default.createElement(AccessibleButton, {
onFocus: onFocus,
tabIndex: isActive ? 0 : -1,
inputRef: ref,
className: classes,
onClick: this.onClick,
onMouseEnter: this.onMouseEnter,
onMouseLeave: this.onMouseLeave,
onContextMenu: this.onContextMenu
}, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_RoomTile_avatar"
}, av), /*#__PURE__*/_react.default.createElement("div", {
className: "mx_RoomTile_nameContainer"
}, label, /*#__PURE__*/_react.default.createElement(_ContextMenu.ContextMenuButton, {
className: badgeClasses,
onClick: this.onContextMenuButtonClick,
label: (0, _languageHandler._t)("Options"),
isExpanded: isMenuDisplayed,
tabIndex: isActive ? 0 : -1
}, badgeContent)), tooltip)), contextMenu);
}
}, (0, _defineProperty2.default)(_class2, "propTypes", void 0), (0, _defineProperty2.default)(_class2, "contextType", _MatrixClientContext.default), _temp)) || _class);
exports.default = GroupInviteTile;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/groups/GroupInviteTile.js"],"names":["GroupInviteTile","React","Component","constructor","props","context","e","dis","dispatch","action","group_id","group","groupId","state","hover","isGuest","badgeHover","setState","stopPropagation","preventDefault","_showContextMenu","target","getBoundingClientRect","right","clientX","top","clientY","height","contextMenuPosition","menuDisplayed","selected","boundingClientRect","MatrixClientPeg","get","collapsed","render","AccessibleButton","sdk","getComponent","BaseAvatar","groupName","name","httpAvatarUrl","avatarUrl","getSquareThumbnailHttp","av","isMenuDisplayed","Boolean","nameClasses","label","badgeEllipsis","badgeClasses","badgeContent","tooltip","Tooltip","classes","contextMenu","GroupInviteTileContextMenu","closeMenu","onFocus","isActive","ref","onClick","onMouseEnter","onMouseLeave","onContextMenu","onContextMenuButtonClick","MatrixClientContext"],"mappings":"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","sourcesContent":["/*\nCopyright 2017, 2018 New Vector Ltd\nCopyright 2018 Michael Telatynski <7t3chguy@gmail.com>\nCopyright 2019 The Matrix.org Foundation C.I.C.\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n    http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n*/\n\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport * as sdk from '../../../index';\nimport dis from '../../../dispatcher/dispatcher';\nimport {_t} from '../../../languageHandler';\nimport classNames from 'classnames';\nimport {MatrixClientPeg} from \"../../../MatrixClientPeg\";\nimport {ContextMenu, ContextMenuButton, toRightOf} from \"../../structures/ContextMenu\";\nimport MatrixClientContext from \"../../../contexts/MatrixClientContext\";\nimport {RovingTabIndexWrapper} from \"../../../accessibility/RovingTabIndex\";\nimport {replaceableComponent} from \"../../../utils/replaceableComponent\";\nimport {mediaFromMxc} from \"../../../customisations/Media\";\n\n// XXX this class copies a lot from RoomTile.js\n@replaceableComponent(\"views.groups.GroupInviteTile\")\nexport default class GroupInviteTile extends React.Component {\n    static propTypes: {\n        group: PropTypes.object.isRequired,\n    };\n\n    static contextType = MatrixClientContext;\n\n    constructor(props, context) {\n        super(props, context);\n\n        this.state = {\n            hover: false,\n            badgeHover: false,\n            menuDisplayed: false,\n            selected: this.props.group.groupId === null, // XXX: this needs linking to LoggedInView/GroupView state\n        };\n    }\n\n    onClick = e => {\n        dis.dispatch({\n            action: 'view_group',\n            group_id: this.props.group.groupId,\n        });\n    };\n\n    onMouseEnter = () => {\n        const state = {hover: true};\n        // Only allow non-guests to access the context menu\n        if (!this.context.isGuest()) {\n            state.badgeHover = true;\n        }\n        this.setState(state);\n    };\n\n    onMouseLeave = () => {\n        this.setState({\n            badgeHover: false,\n            hover: false,\n        });\n    };\n\n    _showContextMenu(boundingClientRect) {\n        // Only allow non-guests to access the context menu\n        if (MatrixClientPeg.get().isGuest()) return;\n\n        const state = {\n            contextMenuPosition: boundingClientRect,\n        };\n\n        // If the badge is clicked, then no longer show tooltip\n        if (this.props.collapsed) {\n            state.hover = false;\n        }\n\n        this.setState(state);\n    }\n\n    onContextMenuButtonClick = e => {\n        // Prevent the RoomTile onClick event firing as well\n        e.stopPropagation();\n        e.preventDefault();\n\n        this._showContextMenu(e.target.getBoundingClientRect());\n    };\n\n    onContextMenu = e => {\n        // Prevent the native context menu\n        e.preventDefault();\n\n        this._showContextMenu({\n            right: e.clientX,\n            top: e.clientY,\n            height: 0,\n        });\n    };\n\n    closeMenu = () => {\n        this.setState({\n            contextMenuPosition: null,\n        });\n    };\n\n    render() {\n        const AccessibleButton = sdk.getComponent('elements.AccessibleButton');\n        const BaseAvatar = sdk.getComponent('avatars.BaseAvatar');\n\n        const groupName = this.props.group.name || this.props.group.groupId;\n        const httpAvatarUrl = this.props.group.avatarUrl\n            ? mediaFromMxc(this.props.group.avatarUrl).getSquareThumbnailHttp(24)\n            : null;\n\n        const av = <BaseAvatar name={groupName} width={24} height={24} url={httpAvatarUrl} />;\n\n        const isMenuDisplayed = Boolean(this.state.contextMenuPosition);\n        const nameClasses = classNames('mx_RoomTile_name mx_RoomTile_invite mx_RoomTile_badgeShown', {\n            'mx_RoomTile_badgeShown': this.state.badgeHover || isMenuDisplayed,\n        });\n\n        // XXX: this is a workaround for Firefox giving this div a tabstop :( [tabIndex]\n        const label = <div title={this.props.group.groupId} className={nameClasses} tabIndex={-1} dir=\"auto\">\n            { groupName }\n        </div>;\n\n        const badgeEllipsis = this.state.badgeHover || isMenuDisplayed;\n        const badgeClasses = classNames('mx_RoomTile_badge mx_RoomTile_highlight', {\n            'mx_RoomTile_badgeButton': badgeEllipsis,\n        });\n\n        const badgeContent = badgeEllipsis ? '\\u00B7\\u00B7\\u00B7' : '!';\n\n        let tooltip;\n        if (this.props.collapsed && this.state.hover) {\n            const Tooltip = sdk.getComponent(\"elements.Tooltip\");\n            tooltip = <Tooltip className=\"mx_RoomTile_tooltip\" label={groupName} dir=\"auto\" />;\n        }\n\n        const classes = classNames('mx_RoomTile mx_RoomTile_highlight', {\n            'mx_RoomTile_menuDisplayed': isMenuDisplayed,\n            'mx_RoomTile_selected': this.state.selected,\n            'mx_GroupInviteTile': true,\n        });\n\n        let contextMenu;\n        if (isMenuDisplayed) {\n            const GroupInviteTileContextMenu = sdk.getComponent('context_menus.GroupInviteTileContextMenu');\n            contextMenu = (\n                <ContextMenu {...toRightOf(this.state.contextMenuPosition)} onFinished={this.closeMenu}>\n                    <GroupInviteTileContextMenu group={this.props.group} onFinished={this.closeMenu} />\n                </ContextMenu>\n            );\n        }\n\n        return <React.Fragment>\n            <RovingTabIndexWrapper>\n                {({onFocus, isActive, ref}) =>\n                    <AccessibleButton\n                        onFocus={onFocus}\n                        tabIndex={isActive ? 0 : -1}\n                        inputRef={ref}\n                        className={classes}\n                        onClick={this.onClick}\n                        onMouseEnter={this.onMouseEnter}\n                        onMouseLeave={this.onMouseLeave}\n                        onContextMenu={this.onContextMenu}\n                    >\n                        <div className=\"mx_RoomTile_avatar\">\n                            { av }\n                        </div>\n                        <div className=\"mx_RoomTile_nameContainer\">\n                            { label }\n                            <ContextMenuButton\n                                className={badgeClasses}\n                                onClick={this.onContextMenuButtonClick}\n                                label={_t(\"Options\")}\n                                isExpanded={isMenuDisplayed}\n                                tabIndex={isActive ? 0 : -1}\n                            >\n                                { badgeContent }\n                            </ContextMenuButton>\n                        </div>\n                        { tooltip }\n                    </AccessibleButton>\n                }\n            </RovingTabIndexWrapper>\n\n            { contextMenu }\n        </React.Fragment>;\n    }\n}\n"]}