UNPKG

matrix-react-sdk

Version:
137 lines (132 loc) 18.8 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = exports.PowerStatus = void 0; var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _react = _interopRequireDefault(require("react")); var _classnames = _interopRequireDefault(require("classnames")); var _AccessibleButton = _interopRequireDefault(require("../elements/AccessibleButton")); var _languageHandler = require("../../../languageHandler"); var _E2EIcon = _interopRequireDefault(require("./E2EIcon")); var _BaseAvatar = _interopRequireDefault(require("../avatars/BaseAvatar")); var _PresenceLabel = _interopRequireDefault(require("./PresenceLabel")); /* Copyright 2024 New Vector Ltd. Copyright 2020 The Matrix.org Foundation C.I.C. Copyright 2018 New Vector Ltd Copyright 2015, 2016 OpenMarket Ltd SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only Please see LICENSE files in the repository root for full details. */ let PowerStatus = exports.PowerStatus = /*#__PURE__*/function (PowerStatus) { PowerStatus["Admin"] = "admin"; PowerStatus["Moderator"] = "moderator"; return PowerStatus; }({}); const PowerLabel = { [PowerStatus.Admin]: (0, _languageHandler._td)("power_level|admin"), [PowerStatus.Moderator]: (0, _languageHandler._td)("power_level|mod") }; const PRESENCE_CLASS = { "offline": "mx_EntityTile_offline", "online": "mx_EntityTile_online", "unavailable": "mx_EntityTile_unavailable", "io.element.unreachable": "mx_EntityTile_unreachable" }; 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"; } } class EntityTile extends _react.default.PureComponent { constructor(props) { super(props); this.state = { hover: false }; } /** * Creates the PresenceLabel component if needed * @returns The PresenceLabel component if we need to render it, undefined otherwise */ getPresenceLabel() { if (!this.props.showPresence) return; const activeAgo = this.props.presenceLastActiveAgo ? Date.now() - (this.props.presenceLastTs - this.props.presenceLastActiveAgo) : -1; return /*#__PURE__*/_react.default.createElement(_PresenceLabel.default, { activeAgo: activeAgo, currentlyActive: this.props.presenceCurrentlyActive, presenceState: this.props.presenceState }); } render() { const mainClassNames = { mx_EntityTile: true }; if (this.props.className) mainClassNames[this.props.className] = true; const presenceClass = presenceClassForMember(this.props.presenceState, this.props.presenceLastActiveAgo, this.props.showPresence); mainClassNames[presenceClass] = true; const name = this.props.nameJSX || this.props.name; const nameAndPresence = /*#__PURE__*/_react.default.createElement("div", { className: "mx_EntityTile_details" }, /*#__PURE__*/_react.default.createElement("div", { className: "mx_EntityTile_name" }, name), this.getPresenceLabel()); let powerLabel; const powerStatus = this.props.powerStatus; if (powerStatus) { const powerText = (0, _languageHandler._t)(PowerLabel[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 av = this.props.avatarJsx || /*#__PURE__*/_react.default.createElement(_BaseAvatar.default, { name: this.props.name, size: "36px", "aria-hidden": "true" }); // The wrapping div is required to make the magic mouse listener work, for some reason. return /*#__PURE__*/_react.default.createElement("div", null, /*#__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), nameAndPresence, powerLabel)); } } exports.default = EntityTile; (0, _defineProperty2.default)(EntityTile, "defaultProps", { onClick: () => {}, presenceState: "offline", presenceLastActiveAgo: 0, presenceLastTs: 0, showInviteButton: false, showPresence: true }); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_classnames","_AccessibleButton","_languageHandler","_E2EIcon","_BaseAvatar","_PresenceLabel","PowerStatus","exports","PowerLabel","Admin","_td","Moderator","PRESENCE_CLASS","presenceClassForMember","presenceState","lastActiveAgo","showPresence","EntityTile","React","PureComponent","constructor","props","state","hover","getPresenceLabel","activeAgo","presenceLastActiveAgo","Date","now","presenceLastTs","default","createElement","currentlyActive","presenceCurrentlyActive","render","mainClassNames","mx_EntityTile","className","presenceClass","name","nameJSX","nameAndPresence","powerLabel","powerStatus","powerText","_t","e2eIcon","e2eStatus","status","isUser","bordered","av","avatarJsx","size","classNames","title","onClick","_defineProperty2","showInviteButton"],"sources":["../../../../src/components/views/rooms/EntityTile.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2020 The Matrix.org Foundation C.I.C.\nCopyright 2018 New Vector Ltd\nCopyright 2015, 2016 OpenMarket Ltd\n\nSPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only\nPlease see LICENSE files in the repository root for full details.\n*/\n\nimport React from \"react\";\nimport classNames from \"classnames\";\n\nimport AccessibleButton from \"../elements/AccessibleButton\";\nimport { _t, _td, TranslationKey } from \"../../../languageHandler\";\nimport E2EIcon, { E2EState } from \"./E2EIcon\";\nimport BaseAvatar from \"../avatars/BaseAvatar\";\nimport PresenceLabel from \"./PresenceLabel\";\n\nexport enum PowerStatus {\n    Admin = \"admin\",\n    Moderator = \"moderator\",\n}\n\nconst PowerLabel: Record<PowerStatus, TranslationKey> = {\n    [PowerStatus.Admin]: _td(\"power_level|admin\"),\n    [PowerStatus.Moderator]: _td(\"power_level|mod\"),\n};\n\nexport type PresenceState = \"offline\" | \"online\" | \"unavailable\" | \"io.element.unreachable\";\n\nconst PRESENCE_CLASS: Record<PresenceState, string> = {\n    \"offline\": \"mx_EntityTile_offline\",\n    \"online\": \"mx_EntityTile_online\",\n    \"unavailable\": \"mx_EntityTile_unavailable\",\n    \"io.element.unreachable\": \"mx_EntityTile_unreachable\",\n};\n\nfunction presenceClassForMember(presenceState?: PresenceState, lastActiveAgo?: number, showPresence?: boolean): string {\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\ninterface IProps {\n    name?: string;\n    nameJSX?: JSX.Element;\n    title?: string;\n    avatarJsx?: JSX.Element; // <BaseAvatar />\n    className?: string;\n    presenceState: PresenceState;\n    presenceLastActiveAgo: number;\n    presenceLastTs: number;\n    presenceCurrentlyActive?: boolean;\n    onClick(): void;\n    showPresence: boolean;\n    subtextLabel?: string;\n    e2eStatus?: E2EState;\n    powerStatus?: PowerStatus;\n}\n\ninterface IState {\n    hover: boolean;\n}\n\nexport default class EntityTile extends React.PureComponent<IProps, IState> {\n    public static defaultProps = {\n        onClick: () => {},\n        presenceState: \"offline\",\n        presenceLastActiveAgo: 0,\n        presenceLastTs: 0,\n        showInviteButton: false,\n        showPresence: true,\n    };\n\n    public constructor(props: IProps) {\n        super(props);\n\n        this.state = {\n            hover: false,\n        };\n    }\n\n    /**\n     * Creates the PresenceLabel component if needed\n     * @returns The PresenceLabel component if we need to render it, undefined otherwise\n     */\n    private getPresenceLabel(): JSX.Element | undefined {\n        if (!this.props.showPresence) return;\n        const activeAgo = this.props.presenceLastActiveAgo\n            ? Date.now() - (this.props.presenceLastTs - this.props.presenceLastActiveAgo)\n            : -1;\n        return (\n            <PresenceLabel\n                activeAgo={activeAgo}\n                currentlyActive={this.props.presenceCurrentlyActive}\n                presenceState={this.props.presenceState}\n            />\n        );\n    }\n\n    public render(): React.ReactNode {\n        const mainClassNames: Record<string, boolean> = {\n            mx_EntityTile: true,\n        };\n        if (this.props.className) mainClassNames[this.props.className] = true;\n\n        const presenceClass = presenceClassForMember(\n            this.props.presenceState,\n            this.props.presenceLastActiveAgo,\n            this.props.showPresence,\n        );\n        mainClassNames[presenceClass] = true;\n\n        const name = this.props.nameJSX || this.props.name;\n        const nameAndPresence = (\n            <div className=\"mx_EntityTile_details\">\n                <div className=\"mx_EntityTile_name\">{name}</div>\n                {this.getPresenceLabel()}\n            </div>\n        );\n\n        let powerLabel;\n        const powerStatus = this.props.powerStatus;\n        if (powerStatus) {\n            const powerText = _t(PowerLabel[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 av = this.props.avatarJsx || <BaseAvatar name={this.props.name} size=\"36px\" aria-hidden=\"true\" />;\n\n        // The wrapping div is required to make the magic mouse listener work, for some reason.\n        return (\n            <div>\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                    {nameAndPresence}\n                    {powerLabel}\n                </AccessibleButton>\n            </div>\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}