UNPKG

matrix-react-sdk

Version:
98 lines (94 loc) 14.6 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _react = _interopRequireDefault(require("react")); var _classnames = _interopRequireDefault(require("classnames")); var _matrix = require("matrix-js-sdk/src/matrix"); var Avatar = _interopRequireWildcard(require("../../../Avatar")); var _EventTile = _interopRequireDefault(require("../rooms/EventTile")); var _Layout = require("../../../settings/enums/Layout"); var _Spinner = _interopRequireDefault(require("./Spinner")); function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; } /* Copyright 2024 New Vector Ltd. Copyright 2020 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. */ const AVATAR_SIZE = 32; class EventTilePreview extends _react.default.Component { constructor(props) { super(props); this.state = { message: props.message }; } fakeEvent({ message }) { // Fake it till we make it /* eslint-disable quote-props */ const rawEvent = { type: "m.room.message", sender: this.props.userId, content: { "m.new_content": { msgtype: _matrix.MsgType.Text, body: message, displayname: this.props.displayName, avatar_url: this.props.avatarUrl }, "msgtype": _matrix.MsgType.Text, "body": message, "displayname": this.props.displayName, "avatar_url": this.props.avatarUrl }, unsigned: { age: 97 }, event_id: "$9999999999999999999999999999999999999999999", room_id: "!999999999999999999:example.org" }; const event = new _matrix.MatrixEvent(rawEvent); /* eslint-enable quote-props */ // Fake it more event.sender = { name: this.props.displayName || this.props.userId, rawDisplayName: this.props.displayName, userId: this.props.userId, getAvatarUrl: (..._) => { return Avatar.avatarUrlForUser({ avatarUrl: this.props.avatarUrl }, AVATAR_SIZE, AVATAR_SIZE, "crop"); }, getMxcAvatarUrl: () => this.props.avatarUrl }; return event; } render() { const className = (0, _classnames.default)(this.props.className, { mx_IRCLayout: this.props.layout == _Layout.Layout.IRC, mx_EventTilePreview_loader: !this.props.userId }); if (!this.props.userId) return /*#__PURE__*/_react.default.createElement("div", { className: className }, /*#__PURE__*/_react.default.createElement(_Spinner.default, null)); const event = this.fakeEvent(this.state); return /*#__PURE__*/_react.default.createElement("div", { className: className, role: "presentation" }, /*#__PURE__*/_react.default.createElement(_EventTile.default, { mxEvent: event, layout: this.props.layout, as: "div", hideTimestamp: true, inhibitInteraction: true })); } } exports.default = EventTilePreview; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_classnames","_matrix","Avatar","_interopRequireWildcard","_EventTile","_Layout","_Spinner","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","AVATAR_SIZE","EventTilePreview","React","Component","constructor","props","state","message","fakeEvent","rawEvent","type","sender","userId","content","msgtype","MsgType","Text","body","displayname","displayName","avatar_url","avatarUrl","unsigned","age","event_id","room_id","event","MatrixEvent","name","rawDisplayName","getAvatarUrl","_","avatarUrlForUser","getMxcAvatarUrl","render","className","classnames","mx_IRCLayout","layout","Layout","IRC","mx_EventTilePreview_loader","createElement","role","mxEvent","as","hideTimestamp","inhibitInteraction","exports"],"sources":["../../../../src/components/views/elements/EventTilePreview.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2020 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 from \"react\";\nimport classnames from \"classnames\";\nimport { MatrixEvent, RoomMember, MsgType } from \"matrix-js-sdk/src/matrix\";\n\nimport * as Avatar from \"../../../Avatar\";\nimport EventTile from \"../rooms/EventTile\";\nimport { Layout } from \"../../../settings/enums/Layout\";\nimport Spinner from \"./Spinner\";\n\ninterface IProps {\n    /**\n     * The text to be displayed in the message preview\n     */\n    message: string;\n\n    /**\n     * Whether to use the irc layout or not\n     */\n    layout: Layout;\n\n    /**\n     * classnames to apply to the wrapper of the preview\n     */\n    className?: string;\n\n    /**\n     * The ID of the displayed user\n     */\n    userId?: string;\n\n    /**\n     * The display name of the displayed user\n     */\n    displayName?: string;\n\n    /**\n     * The mxc:// avatar URL of the displayed user\n     */\n    avatarUrl?: string;\n}\n\ninterface IState {\n    message: string;\n}\n\nconst AVATAR_SIZE = 32;\n\nexport default class EventTilePreview extends React.Component<IProps, IState> {\n    public constructor(props: IProps) {\n        super(props);\n        this.state = {\n            message: props.message,\n        };\n    }\n\n    private fakeEvent({ message }: IState): MatrixEvent {\n        // Fake it till we make it\n        /* eslint-disable quote-props */\n        const rawEvent = {\n            type: \"m.room.message\",\n            sender: this.props.userId,\n            content: {\n                \"m.new_content\": {\n                    msgtype: MsgType.Text,\n                    body: message,\n                    displayname: this.props.displayName,\n                    avatar_url: this.props.avatarUrl,\n                },\n                \"msgtype\": MsgType.Text,\n                \"body\": message,\n                \"displayname\": this.props.displayName,\n                \"avatar_url\": this.props.avatarUrl,\n            },\n            unsigned: {\n                age: 97,\n            },\n            event_id: \"$9999999999999999999999999999999999999999999\",\n            room_id: \"!999999999999999999:example.org\",\n        };\n        const event = new MatrixEvent(rawEvent);\n        /* eslint-enable quote-props */\n\n        // Fake it more\n        event.sender = {\n            name: this.props.displayName || this.props.userId,\n            rawDisplayName: this.props.displayName,\n            userId: this.props.userId,\n            getAvatarUrl: (..._) => {\n                return Avatar.avatarUrlForUser({ avatarUrl: this.props.avatarUrl }, AVATAR_SIZE, AVATAR_SIZE, \"crop\");\n            },\n            getMxcAvatarUrl: () => this.props.avatarUrl,\n        } as RoomMember;\n\n        return event;\n    }\n\n    public render(): React.ReactNode {\n        const className = classnames(this.props.className, {\n            mx_IRCLayout: this.props.layout == Layout.IRC,\n            mx_EventTilePreview_loader: !this.props.userId,\n        });\n\n        if (!this.props.userId)\n            return (\n                <div className={className}>\n                    <Spinner />\n                </div>\n            );\n\n        const event = this.fakeEvent(this.state);\n\n        return (\n            <div className={className} role=\"presentation\">\n                <EventTile mxEvent={event} layout={this.props.layout} as=\"div\" hideTimestamp inhibitInteraction />\n            </div>\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}