UNPKG

matrix-react-sdk

Version:
179 lines (177 loc) 20.8 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.pillRoomNotifPos = exports.pillRoomNotifLen = exports.PillType = exports.Pill = void 0; var _react = _interopRequireDefault(require("react")); var _classnames = _interopRequireDefault(require("classnames")); var _compoundWeb = require("@vector-im/compound-web"); var _link = _interopRequireDefault(require("@vector-im/compound-design-tokens/assets/web/icons/link")); var _MatrixClientPeg = require("../../../MatrixClientPeg"); var _MatrixClientContext = _interopRequireDefault(require("../../../contexts/MatrixClientContext")); var _usePermalink = require("../../../hooks/usePermalink"); var _RoomAvatar = _interopRequireDefault(require("../avatars/RoomAvatar")); var _MemberAvatar = _interopRequireDefault(require("../avatars/MemberAvatar")); var _languageHandler = require("../../../languageHandler"); var _user = require("../../../../res/img/compound/user.svg"); /* Copyright 2024 New Vector Ltd. Copyright 2017-2019 , 2021 The Matrix.org Foundation C.I.C. SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only Please see LICENSE files in the repository root for full details. */ let PillType = exports.PillType = /*#__PURE__*/function (PillType) { PillType["UserMention"] = "TYPE_USER_MENTION"; PillType["RoomMention"] = "TYPE_ROOM_MENTION"; PillType["AtRoomMention"] = "TYPE_AT_ROOM_MENTION"; PillType["EventInSameRoom"] = "TYPE_EVENT_IN_SAME_ROOM"; PillType["EventInOtherRoom"] = "TYPE_EVENT_IN_OTHER_ROOM"; return PillType; }({}); const pillRoomNotifPos = text => { return text?.indexOf("@room") ?? -1; }; exports.pillRoomNotifPos = pillRoomNotifPos; const pillRoomNotifLen = () => { return "@room".length; }; exports.pillRoomNotifLen = pillRoomNotifLen; const linkIcon = /*#__PURE__*/_react.default.createElement(_link.default, { className: "mx_Pill_LinkIcon mx_BaseAvatar" }); const PillRoomAvatar = ({ shouldShowPillAvatar, room }) => { if (!shouldShowPillAvatar) { return null; } if (room) { return /*#__PURE__*/_react.default.createElement(_RoomAvatar.default, { room: room, size: "16px", "aria-hidden": "true" }); } return linkIcon; }; const PillMemberAvatar = ({ shouldShowPillAvatar, member }) => { if (!shouldShowPillAvatar) { return null; } if (member) { return /*#__PURE__*/_react.default.createElement(_MemberAvatar.default, { member: member, size: "16px", "aria-hidden": "true", hideTitle: true }); } return /*#__PURE__*/_react.default.createElement(_user.Icon, { className: "mx_Pill_UserIcon mx_BaseAvatar" }); }; const Pill = ({ type: propType, url, inMessage, room, shouldShowPillAvatar = true }) => { const { event, member, onClick, resourceId, targetRoom, text, type } = (0, _usePermalink.usePermalink)({ room, type: propType, url }); if (!type || !text) { return null; } const classes = (0, _classnames.default)("mx_Pill", { mx_AtRoomPill: type === PillType.AtRoomMention, mx_RoomPill: type === PillType.RoomMention, mx_SpacePill: type === "space" || targetRoom?.isSpaceRoom(), mx_UserPill: type === PillType.UserMention, mx_UserPill_me: resourceId === _MatrixClientPeg.MatrixClientPeg.safeGet().getUserId(), mx_EventPill: type === PillType.EventInOtherRoom || type === PillType.EventInSameRoom }); let avatar = null; let pillText = text; switch (type) { case PillType.EventInOtherRoom: { avatar = /*#__PURE__*/_react.default.createElement(PillRoomAvatar, { shouldShowPillAvatar: shouldShowPillAvatar, room: targetRoom }); pillText = (0, _languageHandler._t)("pill|permalink_other_room", { room: text }); } break; case PillType.EventInSameRoom: { if (event) { avatar = /*#__PURE__*/_react.default.createElement(PillMemberAvatar, { shouldShowPillAvatar: shouldShowPillAvatar, member: member }); pillText = (0, _languageHandler._t)("pill|permalink_this_room", { user: text }); } else { avatar = linkIcon; pillText = (0, _languageHandler._t)("common|message"); } } break; case PillType.AtRoomMention: case PillType.RoomMention: case "space": avatar = /*#__PURE__*/_react.default.createElement(PillRoomAvatar, { shouldShowPillAvatar: shouldShowPillAvatar, room: targetRoom }); break; case PillType.UserMention: avatar = /*#__PURE__*/_react.default.createElement(PillMemberAvatar, { shouldShowPillAvatar: shouldShowPillAvatar, member: member }); break; default: return null; } const isAnchor = !!inMessage && !!url; return /*#__PURE__*/_react.default.createElement("bdi", null, /*#__PURE__*/_react.default.createElement(_MatrixClientContext.default.Provider, { value: _MatrixClientPeg.MatrixClientPeg.safeGet() }, /*#__PURE__*/_react.default.createElement(_compoundWeb.Tooltip, { description: resourceId ?? "", open: resourceId ? undefined : false, placement: "right", isTriggerInteractive: isAnchor }, isAnchor ? /*#__PURE__*/_react.default.createElement("a", { className: classes, href: url, onClick: onClick }, avatar, /*#__PURE__*/_react.default.createElement("span", { className: "mx_Pill_text" }, pillText)) : /*#__PURE__*/_react.default.createElement("span", { className: classes }, avatar, /*#__PURE__*/_react.default.createElement("span", { className: "mx_Pill_text" }, pillText))))); }; exports.Pill = Pill; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_classnames","_compoundWeb","_link","_MatrixClientPeg","_MatrixClientContext","_usePermalink","_RoomAvatar","_MemberAvatar","_languageHandler","_user","PillType","exports","pillRoomNotifPos","text","indexOf","pillRoomNotifLen","length","linkIcon","default","createElement","className","PillRoomAvatar","shouldShowPillAvatar","room","size","PillMemberAvatar","member","hideTitle","Icon","Pill","type","propType","url","inMessage","event","onClick","resourceId","targetRoom","usePermalink","classes","classNames","mx_AtRoomPill","AtRoomMention","mx_RoomPill","RoomMention","mx_SpacePill","isSpaceRoom","mx_UserPill","UserMention","mx_UserPill_me","MatrixClientPeg","safeGet","getUserId","mx_EventPill","EventInOtherRoom","EventInSameRoom","avatar","pillText","_t","user","isAnchor","Provider","value","Tooltip","description","open","undefined","placement","isTriggerInteractive","href"],"sources":["../../../../src/components/views/elements/Pill.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2017-2019 , 2021 The Matrix.org Foundation C.I.C.\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, { ReactElement } from \"react\";\nimport classNames from \"classnames\";\nimport { Room, RoomMember } from \"matrix-js-sdk/src/matrix\";\nimport { Tooltip } from \"@vector-im/compound-web\";\nimport LinkIcon from \"@vector-im/compound-design-tokens/assets/web/icons/link\";\n\nimport { MatrixClientPeg } from \"../../../MatrixClientPeg\";\nimport MatrixClientContext from \"../../../contexts/MatrixClientContext\";\nimport { usePermalink } from \"../../../hooks/usePermalink\";\nimport RoomAvatar from \"../avatars/RoomAvatar\";\nimport MemberAvatar from \"../avatars/MemberAvatar\";\nimport { _t } from \"../../../languageHandler\";\nimport { Icon as UserIcon } from \"../../../../res/img/compound/user.svg\";\n\nexport enum PillType {\n    UserMention = \"TYPE_USER_MENTION\",\n    RoomMention = \"TYPE_ROOM_MENTION\",\n    AtRoomMention = \"TYPE_AT_ROOM_MENTION\", // '@room' mention\n    EventInSameRoom = \"TYPE_EVENT_IN_SAME_ROOM\",\n    EventInOtherRoom = \"TYPE_EVENT_IN_OTHER_ROOM\",\n}\n\nexport const pillRoomNotifPos = (text: string | null): number => {\n    return text?.indexOf(\"@room\") ?? -1;\n};\n\nexport const pillRoomNotifLen = (): number => {\n    return \"@room\".length;\n};\n\nconst linkIcon = <LinkIcon className=\"mx_Pill_LinkIcon mx_BaseAvatar\" />;\n\nconst PillRoomAvatar: React.FC<{\n    shouldShowPillAvatar: boolean;\n    room: Room | null;\n}> = ({ shouldShowPillAvatar, room }) => {\n    if (!shouldShowPillAvatar) {\n        return null;\n    }\n\n    if (room) {\n        return <RoomAvatar room={room} size=\"16px\" aria-hidden=\"true\" />;\n    }\n    return linkIcon;\n};\n\nconst PillMemberAvatar: React.FC<{\n    shouldShowPillAvatar: boolean;\n    member: RoomMember | null;\n}> = ({ shouldShowPillAvatar, member }) => {\n    if (!shouldShowPillAvatar) {\n        return null;\n    }\n\n    if (member) {\n        return <MemberAvatar member={member} size=\"16px\" aria-hidden=\"true\" hideTitle />;\n    }\n    return <UserIcon className=\"mx_Pill_UserIcon mx_BaseAvatar\" />;\n};\n\nexport interface PillProps {\n    // The Type of this Pill. If url is given, this is auto-detected.\n    type?: PillType;\n    // The URL to pillify (no validation is done)\n    url?: string;\n    /** Whether the pill is in a message. It will act as a link then. */\n    inMessage?: boolean;\n    // The room in which this pill is being rendered\n    room?: Room;\n    // Whether to include an avatar in the pill\n    shouldShowPillAvatar?: boolean;\n}\n\nexport const Pill: React.FC<PillProps> = ({ type: propType, url, inMessage, room, shouldShowPillAvatar = true }) => {\n    const { event, member, onClick, resourceId, targetRoom, text, type } = usePermalink({\n        room,\n        type: propType,\n        url,\n    });\n\n    if (!type || !text) {\n        return null;\n    }\n\n    const classes = classNames(\"mx_Pill\", {\n        mx_AtRoomPill: type === PillType.AtRoomMention,\n        mx_RoomPill: type === PillType.RoomMention,\n        mx_SpacePill: type === \"space\" || targetRoom?.isSpaceRoom(),\n        mx_UserPill: type === PillType.UserMention,\n        mx_UserPill_me: resourceId === MatrixClientPeg.safeGet().getUserId(),\n        mx_EventPill: type === PillType.EventInOtherRoom || type === PillType.EventInSameRoom,\n    });\n\n    let avatar: ReactElement | null = null;\n    let pillText: string | null = text;\n\n    switch (type) {\n        case PillType.EventInOtherRoom:\n            {\n                avatar = <PillRoomAvatar shouldShowPillAvatar={shouldShowPillAvatar} room={targetRoom} />;\n                pillText = _t(\"pill|permalink_other_room\", {\n                    room: text,\n                });\n            }\n            break;\n        case PillType.EventInSameRoom:\n            {\n                if (event) {\n                    avatar = <PillMemberAvatar shouldShowPillAvatar={shouldShowPillAvatar} member={member} />;\n                    pillText = _t(\"pill|permalink_this_room\", {\n                        user: text,\n                    });\n                } else {\n                    avatar = linkIcon;\n                    pillText = _t(\"common|message\");\n                }\n            }\n            break;\n        case PillType.AtRoomMention:\n        case PillType.RoomMention:\n        case \"space\":\n            avatar = <PillRoomAvatar shouldShowPillAvatar={shouldShowPillAvatar} room={targetRoom} />;\n            break;\n        case PillType.UserMention:\n            avatar = <PillMemberAvatar shouldShowPillAvatar={shouldShowPillAvatar} member={member} />;\n            break;\n        default:\n            return null;\n    }\n\n    const isAnchor = !!inMessage && !!url;\n    return (\n        <bdi>\n            <MatrixClientContext.Provider value={MatrixClientPeg.safeGet()}>\n                <Tooltip\n                    description={resourceId ?? \"\"}\n                    open={resourceId ? undefined : false}\n                    placement=\"right\"\n                    isTriggerInteractive={isAnchor}\n                >\n                    {isAnchor ? (\n                        <a className={classes} href={url} onClick={onClick}>\n                            {avatar}\n                            <span className=\"mx_Pill_text\">{pillText}</span>\n                        </a>\n                    ) : (\n                        <span className={classes}>\n                            {avatar}\n                            <span className=\"mx_Pill_text\">{pillText}</span>\n                        </span>\n                    )}\n                </Tooltip>\n            </MatrixClientContext.Provider>\n        </bdi>\n    );\n};\n"],"mappings":";;;;;;;AAQA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,WAAA,GAAAF,sBAAA,CAAAC,OAAA;AAEA,IAAAE,YAAA,GAAAF,OAAA;AACA,IAAAG,KAAA,GAAAJ,sBAAA,CAAAC,OAAA;AAEA,IAAAI,gBAAA,GAAAJ,OAAA;AACA,IAAAK,oBAAA,GAAAN,sBAAA,CAAAC,OAAA;AACA,IAAAM,aAAA,GAAAN,OAAA;AACA,IAAAO,WAAA,GAAAR,sBAAA,CAAAC,OAAA;AACA,IAAAQ,aAAA,GAAAT,sBAAA,CAAAC,OAAA;AACA,IAAAS,gBAAA,GAAAT,OAAA;AACA,IAAAU,KAAA,GAAAV,OAAA;AApBA;AACA;AACA;AACA;AACA;AACA;AACA;AANA,IAsBYW,QAAQ,GAAAC,OAAA,CAAAD,QAAA,0BAARA,QAAQ;EAARA,QAAQ;EAARA,QAAQ;EAARA,QAAQ;EAARA,QAAQ;EAARA,QAAQ;EAAA,OAARA,QAAQ;AAAA;AAQb,MAAME,gBAAgB,GAAIC,IAAmB,IAAa;EAC7D,OAAOA,IAAI,EAAEC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;AACvC,CAAC;AAACH,OAAA,CAAAC,gBAAA,GAAAA,gBAAA;AAEK,MAAMG,gBAAgB,GAAGA,CAAA,KAAc;EAC1C,OAAO,OAAO,CAACC,MAAM;AACzB,CAAC;AAACL,OAAA,CAAAI,gBAAA,GAAAA,gBAAA;AAEF,MAAME,QAAQ,gBAAGpB,MAAA,CAAAqB,OAAA,CAAAC,aAAA,CAACjB,KAAA,CAAAgB,OAAQ;EAACE,SAAS,EAAC;AAAgC,CAAE,CAAC;AAExE,MAAMC,cAGJ,GAAGA,CAAC;EAAEC,oBAAoB;EAAEC;AAAK,CAAC,KAAK;EACrC,IAAI,CAACD,oBAAoB,EAAE;IACvB,OAAO,IAAI;EACf;EAEA,IAAIC,IAAI,EAAE;IACN,oBAAO1B,MAAA,CAAAqB,OAAA,CAAAC,aAAA,CAACb,WAAA,CAAAY,OAAU;MAACK,IAAI,EAAEA,IAAK;MAACC,IAAI,EAAC,MAAM;MAAC,eAAY;IAAM,CAAE,CAAC;EACpE;EACA,OAAOP,QAAQ;AACnB,CAAC;AAED,MAAMQ,gBAGJ,GAAGA,CAAC;EAAEH,oBAAoB;EAAEI;AAAO,CAAC,KAAK;EACvC,IAAI,CAACJ,oBAAoB,EAAE;IACvB,OAAO,IAAI;EACf;EAEA,IAAII,MAAM,EAAE;IACR,oBAAO7B,MAAA,CAAAqB,OAAA,CAAAC,aAAA,CAACZ,aAAA,CAAAW,OAAY;MAACQ,MAAM,EAAEA,MAAO;MAACF,IAAI,EAAC,MAAM;MAAC,eAAY,MAAM;MAACG,SAAS;IAAA,CAAE,CAAC;EACpF;EACA,oBAAO9B,MAAA,CAAAqB,OAAA,CAAAC,aAAA,CAACV,KAAA,CAAAmB,IAAQ;IAACR,SAAS,EAAC;EAAgC,CAAE,CAAC;AAClE,CAAC;AAeM,MAAMS,IAAyB,GAAGA,CAAC;EAAEC,IAAI,EAAEC,QAAQ;EAAEC,GAAG;EAAEC,SAAS;EAAEV,IAAI;EAAED,oBAAoB,GAAG;AAAK,CAAC,KAAK;EAChH,MAAM;IAAEY,KAAK;IAAER,MAAM;IAAES,OAAO;IAAEC,UAAU;IAAEC,UAAU;IAAExB,IAAI;IAAEiB;EAAK,CAAC,GAAG,IAAAQ,0BAAY,EAAC;IAChFf,IAAI;IACJO,IAAI,EAAEC,QAAQ;IACdC;EACJ,CAAC,CAAC;EAEF,IAAI,CAACF,IAAI,IAAI,CAACjB,IAAI,EAAE;IAChB,OAAO,IAAI;EACf;EAEA,MAAM0B,OAAO,GAAG,IAAAC,mBAAU,EAAC,SAAS,EAAE;IAClCC,aAAa,EAAEX,IAAI,KAAKpB,QAAQ,CAACgC,aAAa;IAC9CC,WAAW,EAAEb,IAAI,KAAKpB,QAAQ,CAACkC,WAAW;IAC1CC,YAAY,EAAEf,IAAI,KAAK,OAAO,IAAIO,UAAU,EAAES,WAAW,CAAC,CAAC;IAC3DC,WAAW,EAAEjB,IAAI,KAAKpB,QAAQ,CAACsC,WAAW;IAC1CC,cAAc,EAAEb,UAAU,KAAKc,gCAAe,CAACC,OAAO,CAAC,CAAC,CAACC,SAAS,CAAC,CAAC;IACpEC,YAAY,EAAEvB,IAAI,KAAKpB,QAAQ,CAAC4C,gBAAgB,IAAIxB,IAAI,KAAKpB,QAAQ,CAAC6C;EAC1E,CAAC,CAAC;EAEF,IAAIC,MAA2B,GAAG,IAAI;EACtC,IAAIC,QAAuB,GAAG5C,IAAI;EAElC,QAAQiB,IAAI;IACR,KAAKpB,QAAQ,CAAC4C,gBAAgB;MAC1B;QACIE,MAAM,gBAAG3D,MAAA,CAAAqB,OAAA,CAAAC,aAAA,CAACE,cAAc;UAACC,oBAAoB,EAAEA,oBAAqB;UAACC,IAAI,EAAEc;QAAW,CAAE,CAAC;QACzFoB,QAAQ,GAAG,IAAAC,mBAAE,EAAC,2BAA2B,EAAE;UACvCnC,IAAI,EAAEV;QACV,CAAC,CAAC;MACN;MACA;IACJ,KAAKH,QAAQ,CAAC6C,eAAe;MACzB;QACI,IAAIrB,KAAK,EAAE;UACPsB,MAAM,gBAAG3D,MAAA,CAAAqB,OAAA,CAAAC,aAAA,CAACM,gBAAgB;YAACH,oBAAoB,EAAEA,oBAAqB;YAACI,MAAM,EAAEA;UAAO,CAAE,CAAC;UACzF+B,QAAQ,GAAG,IAAAC,mBAAE,EAAC,0BAA0B,EAAE;YACtCC,IAAI,EAAE9C;UACV,CAAC,CAAC;QACN,CAAC,MAAM;UACH2C,MAAM,GAAGvC,QAAQ;UACjBwC,QAAQ,GAAG,IAAAC,mBAAE,EAAC,gBAAgB,CAAC;QACnC;MACJ;MACA;IACJ,KAAKhD,QAAQ,CAACgC,aAAa;IAC3B,KAAKhC,QAAQ,CAACkC,WAAW;IACzB,KAAK,OAAO;MACRY,MAAM,gBAAG3D,MAAA,CAAAqB,OAAA,CAAAC,aAAA,CAACE,cAAc;QAACC,oBAAoB,EAAEA,oBAAqB;QAACC,IAAI,EAAEc;MAAW,CAAE,CAAC;MACzF;IACJ,KAAK3B,QAAQ,CAACsC,WAAW;MACrBQ,MAAM,gBAAG3D,MAAA,CAAAqB,OAAA,CAAAC,aAAA,CAACM,gBAAgB;QAACH,oBAAoB,EAAEA,oBAAqB;QAACI,MAAM,EAAEA;MAAO,CAAE,CAAC;MACzF;IACJ;MACI,OAAO,IAAI;EACnB;EAEA,MAAMkC,QAAQ,GAAG,CAAC,CAAC3B,SAAS,IAAI,CAAC,CAACD,GAAG;EACrC,oBACInC,MAAA,CAAAqB,OAAA,CAAAC,aAAA,2BACItB,MAAA,CAAAqB,OAAA,CAAAC,aAAA,CAACf,oBAAA,CAAAc,OAAmB,CAAC2C,QAAQ;IAACC,KAAK,EAAEZ,gCAAe,CAACC,OAAO,CAAC;EAAE,gBAC3DtD,MAAA,CAAAqB,OAAA,CAAAC,aAAA,CAAClB,YAAA,CAAA8D,OAAO;IACJC,WAAW,EAAE5B,UAAU,IAAI,EAAG;IAC9B6B,IAAI,EAAE7B,UAAU,GAAG8B,SAAS,GAAG,KAAM;IACrCC,SAAS,EAAC,OAAO;IACjBC,oBAAoB,EAAER;EAAS,GAE9BA,QAAQ,gBACL/D,MAAA,CAAAqB,OAAA,CAAAC,aAAA;IAAGC,SAAS,EAAEmB,OAAQ;IAAC8B,IAAI,EAAErC,GAAI;IAACG,OAAO,EAAEA;EAAQ,GAC9CqB,MAAM,eACP3D,MAAA,CAAAqB,OAAA,CAAAC,aAAA;IAAMC,SAAS,EAAC;EAAc,GAAEqC,QAAe,CAChD,CAAC,gBAEJ5D,MAAA,CAAAqB,OAAA,CAAAC,aAAA;IAAMC,SAAS,EAAEmB;EAAQ,GACpBiB,MAAM,eACP3D,MAAA,CAAAqB,OAAA,CAAAC,aAAA;IAAMC,SAAS,EAAC;EAAc,GAAEqC,QAAe,CAC7C,CAEL,CACiB,CAC7B,CAAC;AAEd,CAAC;AAAC9C,OAAA,CAAAkB,IAAA,GAAAA,IAAA","ignoreList":[]}