matrix-react-sdk
Version:
SDK for matrix.org using React
217 lines (182 loc) • 24.6 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 _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireDefault(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var sdk = _interopRequireWildcard(require("../../../index"));
var _AccessibleButton = _interopRequireDefault(require("../elements/AccessibleButton"));
var _languageHandler = require("../../../languageHandler");
var _classnames = _interopRequireDefault(require("classnames"));
var _E2EIcon = _interopRequireDefault(require("./E2EIcon"));
var _replaceableComponent = require("../../../utils/replaceableComponent");
var _dec, _class, _class2, _temp;
const PRESENCE_CLASS = {
"offline": "mx_EntityTile_offline",
"online": "mx_EntityTile_online",
"unavailable": "mx_EntityTile_unavailable"
};
function presenceClassForMember(presenceState, lastActiveAgo, showPresence) {
if (showPresence === false) {
return 'mx_EntityTile_online_beenactive';
} // offline is split into two categories depending on whether we have
// a last_active_ago for them.
if (presenceState == 'offline') {
if (lastActiveAgo) {
return PRESENCE_CLASS['offline'] + '_beenactive';
} else {
return PRESENCE_CLASS['offline'] + '_neveractive';
}
} else if (presenceState) {
return PRESENCE_CLASS[presenceState];
} else {
return PRESENCE_CLASS['offline'] + '_neveractive';
}
}
let EntityTile = (_dec = (0, _replaceableComponent.replaceableComponent)("views.rooms.EntityTile"), _dec(_class = (_temp = _class2 = class EntityTile extends _react.default.Component {
constructor(...args) {
super(...args);
(0, _defineProperty2.default)(this, "state", {
hover: false
});
}
shouldComponentUpdate(nextProps, nextState) {
if (this.state.hover !== nextState.hover) return true;
return this.props.shouldComponentUpdate(nextProps, nextState);
}
render() {
const mainClassNames = {
"mx_EntityTile": true,
"mx_EntityTile_noHover": this.props.suppressOnHover
};
if (this.props.className) mainClassNames[this.props.className] = true;
const presenceClass = presenceClassForMember(this.props.presenceState, this.props.presenceLastActiveAgo, this.props.showPresence);
mainClassNames[presenceClass] = true;
let nameEl;
const {
name
} = this.props;
if (!this.props.suppressOnHover) {
const activeAgo = this.props.presenceLastActiveAgo ? Date.now() - (this.props.presenceLastTs - this.props.presenceLastActiveAgo) : -1;
const PresenceLabel = sdk.getComponent("rooms.PresenceLabel");
let presenceLabel = null;
if (this.props.showPresence) {
presenceLabel = /*#__PURE__*/_react.default.createElement(PresenceLabel, {
activeAgo: activeAgo,
currentlyActive: this.props.presenceCurrentlyActive,
presenceState: this.props.presenceState
});
}
if (this.props.subtextLabel) {
presenceLabel = /*#__PURE__*/_react.default.createElement("span", {
className: "mx_EntityTile_subtext"
}, this.props.subtextLabel);
}
nameEl = /*#__PURE__*/_react.default.createElement("div", {
className: "mx_EntityTile_details"
}, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_EntityTile_name",
dir: "auto"
}, name), presenceLabel);
} else if (this.props.subtextLabel) {
nameEl = /*#__PURE__*/_react.default.createElement("div", {
className: "mx_EntityTile_details"
}, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_EntityTile_name",
dir: "auto"
}, name), /*#__PURE__*/_react.default.createElement("span", {
className: "mx_EntityTile_subtext"
}, this.props.subtextLabel));
} else {
nameEl = /*#__PURE__*/_react.default.createElement("div", {
className: "mx_EntityTile_name",
dir: "auto"
}, name);
}
let inviteButton;
if (this.props.showInviteButton) {
inviteButton = /*#__PURE__*/_react.default.createElement("div", {
className: "mx_EntityTile_invite"
}, /*#__PURE__*/_react.default.createElement("img", {
src: require("../../../../res/img/plus.svg"),
width: "16",
height: "16"
}));
}
let powerLabel;
const powerStatus = this.props.powerStatus;
if (powerStatus) {
const powerText = {
[EntityTile.POWER_STATUS_MODERATOR]: (0, _languageHandler._t)("Mod"),
[EntityTile.POWER_STATUS_ADMIN]: (0, _languageHandler._t)("Admin")
}[powerStatus];
powerLabel = /*#__PURE__*/_react.default.createElement("div", {
className: "mx_EntityTile_power"
}, powerText);
}
let e2eIcon;
const {
e2eStatus
} = this.props;
if (e2eStatus) {
e2eIcon = /*#__PURE__*/_react.default.createElement(_E2EIcon.default, {
status: e2eStatus,
isUser: true,
bordered: true
});
}
const BaseAvatar = sdk.getComponent('avatars.BaseAvatar');
const av = this.props.avatarJsx || /*#__PURE__*/_react.default.createElement(BaseAvatar, {
name: this.props.name,
width: 36,
height: 36,
"aria-hidden": "true"
}); // The wrapping div is required to make the magic mouse listener work, for some reason.
return /*#__PURE__*/_react.default.createElement("div", {
ref: c => this.container = c
}, /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
className: (0, _classnames.default)(mainClassNames),
title: this.props.title,
onClick: this.props.onClick
}, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_EntityTile_avatar"
}, av, e2eIcon), nameEl, powerLabel, inviteButton));
}
}, (0, _defineProperty2.default)(_class2, "propTypes", {
name: _propTypes.default.string,
title: _propTypes.default.string,
avatarJsx: _propTypes.default.any,
// <BaseAvatar />
className: _propTypes.default.string,
presenceState: _propTypes.default.string,
presenceLastActiveAgo: _propTypes.default.number,
presenceLastTs: _propTypes.default.number,
presenceCurrentlyActive: _propTypes.default.bool,
showInviteButton: _propTypes.default.bool,
shouldComponentUpdate: _propTypes.default.func,
onClick: _propTypes.default.func,
suppressOnHover: _propTypes.default.bool,
showPresence: _propTypes.default.bool,
subtextLabel: _propTypes.default.string,
e2eStatus: _propTypes.default.string
}), (0, _defineProperty2.default)(_class2, "defaultProps", {
shouldComponentUpdate: function (nextProps, nextState) {
return true;
},
onClick: function () {},
presenceState: "offline",
presenceLastActiveAgo: 0,
presenceLastTs: 0,
showInviteButton: false,
suppressOnHover: false,
showPresence: true
}), _temp)) || _class);
EntityTile.POWER_STATUS_MODERATOR = "moderator";
EntityTile.POWER_STATUS_ADMIN = "admin";
var _default = EntityTile;
exports.default = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/rooms/EntityTile.js"],"names":["PRESENCE_CLASS","presenceClassForMember","presenceState","lastActiveAgo","showPresence","EntityTile","React","Component","hover","shouldComponentUpdate","nextProps","nextState","state","props","render","mainClassNames","suppressOnHover","className","presenceClass","presenceLastActiveAgo","nameEl","name","activeAgo","Date","now","presenceLastTs","PresenceLabel","sdk","getComponent","presenceLabel","presenceCurrentlyActive","subtextLabel","inviteButton","showInviteButton","require","powerLabel","powerStatus","powerText","POWER_STATUS_MODERATOR","POWER_STATUS_ADMIN","e2eIcon","e2eStatus","BaseAvatar","av","avatarJsx","c","container","title","onClick","PropTypes","string","any","number","bool","func"],"mappings":"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","sourcesContent":["/*\nCopyright 2015, 2016 OpenMarket Ltd\nCopyright 2018 New Vector Ltd\nCopyright 2020 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 AccessibleButton from '../elements/AccessibleButton';\nimport { _t } from '../../../languageHandler';\nimport classNames from \"classnames\";\nimport E2EIcon from './E2EIcon';\nimport {replaceableComponent} from \"../../../utils/replaceableComponent\";\n\nconst PRESENCE_CLASS = {\n    \"offline\": \"mx_EntityTile_offline\",\n    \"online\": \"mx_EntityTile_online\",\n    \"unavailable\": \"mx_EntityTile_unavailable\",\n};\n\nfunction presenceClassForMember(presenceState, lastActiveAgo, showPresence) {\n    if (showPresence === false) {\n        return 'mx_EntityTile_online_beenactive';\n    }\n\n    // offline is split into two categories depending on whether we have\n    // a last_active_ago for them.\n    if (presenceState == 'offline') {\n        if (lastActiveAgo) {\n            return PRESENCE_CLASS['offline'] + '_beenactive';\n        } else {\n            return PRESENCE_CLASS['offline'] + '_neveractive';\n        }\n    } else if (presenceState) {\n        return PRESENCE_CLASS[presenceState];\n    } else {\n        return PRESENCE_CLASS['offline'] + '_neveractive';\n    }\n}\n\n@replaceableComponent(\"views.rooms.EntityTile\")\nclass EntityTile extends React.Component {\n    static propTypes = {\n        name: PropTypes.string,\n        title: PropTypes.string,\n        avatarJsx: PropTypes.any, // <BaseAvatar />\n        className: PropTypes.string,\n        presenceState: PropTypes.string,\n        presenceLastActiveAgo: PropTypes.number,\n        presenceLastTs: PropTypes.number,\n        presenceCurrentlyActive: PropTypes.bool,\n        showInviteButton: PropTypes.bool,\n        shouldComponentUpdate: PropTypes.func,\n        onClick: PropTypes.func,\n        suppressOnHover: PropTypes.bool,\n        showPresence: PropTypes.bool,\n        subtextLabel: PropTypes.string,\n        e2eStatus: PropTypes.string,\n    };\n\n    static defaultProps = {\n        shouldComponentUpdate: function(nextProps, nextState) { return true; },\n        onClick: function() {},\n        presenceState: \"offline\",\n        presenceLastActiveAgo: 0,\n        presenceLastTs: 0,\n        showInviteButton: false,\n        suppressOnHover: false,\n        showPresence: true,\n    };\n\n    state = {\n        hover: false,\n    };\n\n    shouldComponentUpdate(nextProps, nextState) {\n        if (this.state.hover !== nextState.hover) return true;\n        return this.props.shouldComponentUpdate(nextProps, nextState);\n    }\n\n    render() {\n        const mainClassNames = {\n            \"mx_EntityTile\": true,\n            \"mx_EntityTile_noHover\": this.props.suppressOnHover,\n        };\n        if (this.props.className) mainClassNames[this.props.className] = true;\n\n        const presenceClass = presenceClassForMember(\n            this.props.presenceState, this.props.presenceLastActiveAgo, this.props.showPresence,\n        );\n        mainClassNames[presenceClass] = true;\n\n        let nameEl;\n        const {name} = this.props;\n\n        if (!this.props.suppressOnHover) {\n            const activeAgo = this.props.presenceLastActiveAgo ?\n                (Date.now() - (this.props.presenceLastTs - this.props.presenceLastActiveAgo)) : -1;\n\n            const PresenceLabel = sdk.getComponent(\"rooms.PresenceLabel\");\n            let presenceLabel = null;\n            if (this.props.showPresence) {\n                presenceLabel = <PresenceLabel activeAgo={activeAgo}\n                    currentlyActive={this.props.presenceCurrentlyActive}\n                    presenceState={this.props.presenceState} />;\n            }\n            if (this.props.subtextLabel) {\n                presenceLabel = <span className=\"mx_EntityTile_subtext\">{this.props.subtextLabel}</span>;\n            }\n            nameEl = (\n                <div className=\"mx_EntityTile_details\">\n                    <div className=\"mx_EntityTile_name\" dir=\"auto\">\n                        { name }\n                    </div>\n                    {presenceLabel}\n                </div>\n            );\n        } else if (this.props.subtextLabel) {\n            nameEl = (\n                <div className=\"mx_EntityTile_details\">\n                    <div className=\"mx_EntityTile_name\" dir=\"auto\">\n                        {name}\n                    </div>\n                    <span className=\"mx_EntityTile_subtext\">{this.props.subtextLabel}</span>\n                </div>\n            );\n        } else {\n            nameEl = (\n                <div className=\"mx_EntityTile_name\" dir=\"auto\">{ name }</div>\n            );\n        }\n\n        let inviteButton;\n        if (this.props.showInviteButton) {\n            inviteButton = (\n                <div className=\"mx_EntityTile_invite\">\n                    <img src={require(\"../../../../res/img/plus.svg\")} width=\"16\" height=\"16\" />\n                </div>\n            );\n        }\n\n        let powerLabel;\n        const powerStatus = this.props.powerStatus;\n        if (powerStatus) {\n            const powerText = {\n                [EntityTile.POWER_STATUS_MODERATOR]: _t(\"Mod\"),\n                [EntityTile.POWER_STATUS_ADMIN]: _t(\"Admin\"),\n            }[powerStatus];\n            powerLabel = <div className=\"mx_EntityTile_power\">{powerText}</div>;\n        }\n\n        let e2eIcon;\n        const { e2eStatus } = this.props;\n        if (e2eStatus) {\n            e2eIcon = <E2EIcon status={e2eStatus} isUser={true} bordered={true} />;\n        }\n\n        const BaseAvatar = sdk.getComponent('avatars.BaseAvatar');\n\n        const av = this.props.avatarJsx ||\n            <BaseAvatar name={this.props.name} width={36} height={36} aria-hidden=\"true\" />;\n\n        // The wrapping div is required to make the magic mouse listener work, for some reason.\n        return (\n            <div ref={(c) => this.container = c} >\n                <AccessibleButton\n                    className={classNames(mainClassNames)}\n                    title={this.props.title}\n                    onClick={this.props.onClick}\n                >\n                    <div className=\"mx_EntityTile_avatar\">\n                        { av }\n                        { e2eIcon }\n                    </div>\n                    { nameEl }\n                    { powerLabel }\n                    { inviteButton }\n                </AccessibleButton>\n            </div>\n        );\n    }\n}\n\nEntityTile.POWER_STATUS_MODERATOR = \"moderator\";\nEntityTile.POWER_STATUS_ADMIN = \"admin\";\n\nexport default EntityTile;\n"]}