matrix-react-sdk
Version:
SDK for matrix.org using React
122 lines (120 loc) • 20.3 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
exports.idNameForRoom = idNameForRoom;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireDefault(require("react"));
var _matrix = require("matrix-js-sdk/src/matrix");
var _BaseAvatar = _interopRequireDefault(require("./BaseAvatar"));
var _ImageView = _interopRequireDefault(require("../elements/ImageView"));
var _MatrixClientPeg = require("../../../MatrixClientPeg");
var _Modal = _interopRequireDefault(require("../../../Modal"));
var Avatar = _interopRequireWildcard(require("../../../Avatar"));
var _DMRoomMap = _interopRequireDefault(require("../../../utils/DMRoomMap"));
var _Media = require("../../../customisations/Media");
var _LocalRoom = require("../../../models/LocalRoom");
var _arrays = require("../../../utils/arrays");
const _excluded = ["room", "oobData", "viewAvatarOnClick", "onClick", "className"];
/*
Copyright 2024 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.
*/
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; }
function idNameForRoom(room) {
const dmMapUserId = _DMRoomMap.default.shared().getUserIdForRoomId(room.roomId);
// If the room is a DM, we use the other user's ID for the color hash
// in order to match the room avatar with their avatar
if (dmMapUserId) return dmMapUserId;
if (room instanceof _LocalRoom.LocalRoom && room.targets.length === 1) {
return room.targets[0].userId;
}
return room.roomId;
}
class RoomAvatar extends _react.default.Component {
constructor(props) {
super(props);
(0, _defineProperty2.default)(this, "onRoomStateEvents", ev => {
if (ev.getRoomId() !== this.props.room?.roomId || ev.getType() !== _matrix.EventType.RoomAvatar) return;
this.setState({
urls: RoomAvatar.getImageUrls(this.props)
});
});
(0, _defineProperty2.default)(this, "onRoomAvatarClick", () => {
const avatarUrl = Avatar.avatarUrlForRoom(this.props.room ?? null, undefined, undefined, undefined);
if (!avatarUrl) return;
const params = {
src: avatarUrl,
name: this.props.room?.name
};
_Modal.default.createDialog(_ImageView.default, params, "mx_Dialog_lightbox", undefined, true);
});
this.state = {
urls: RoomAvatar.getImageUrls(this.props)
};
}
componentDidMount() {
_MatrixClientPeg.MatrixClientPeg.safeGet().on(_matrix.RoomStateEvent.Events, this.onRoomStateEvents);
}
componentWillUnmount() {
_MatrixClientPeg.MatrixClientPeg.get()?.removeListener(_matrix.RoomStateEvent.Events, this.onRoomStateEvents);
}
static getDerivedStateFromProps(nextProps) {
return {
urls: RoomAvatar.getImageUrls(nextProps)
};
}
static getImageUrls(props) {
let oobAvatar = null;
if (props.oobData.avatarUrl) {
oobAvatar = (0, _Media.mediaFromMxc)(props.oobData.avatarUrl).getThumbnailOfSourceHttp(parseInt(props.size, 10), parseInt(props.size, 10), "crop");
}
return (0, _arrays.filterBoolean)([oobAvatar,
// highest priority
RoomAvatar.getRoomAvatarUrl(props)]);
}
static getRoomAvatarUrl(props) {
if (!props.room) return null;
return Avatar.avatarUrlForRoom(props.room, parseInt(props.size, 10), parseInt(props.size, 10), "crop");
}
get roomIdName() {
const room = this.props.room;
if (room) {
return idNameForRoom(room);
} else {
return this.props.oobData?.roomId;
}
}
render() {
const _this$props = this.props,
{
room,
oobData,
viewAvatarOnClick,
onClick,
className
} = _this$props,
otherProps = (0, _objectWithoutProperties2.default)(_this$props, _excluded);
const roomName = room?.name ?? oobData.name ?? "?";
return /*#__PURE__*/_react.default.createElement(_BaseAvatar.default, (0, _extends2.default)({}, otherProps, {
type: (room?.getType() ?? this.props.oobData?.roomType) === _matrix.RoomType.Space ? "square" : "round",
name: roomName,
idName: this.roomIdName,
urls: this.state.urls,
onClick: viewAvatarOnClick && this.state.urls[0] ? this.onRoomAvatarClick : onClick
}));
}
}
exports.default = RoomAvatar;
(0, _defineProperty2.default)(RoomAvatar, "defaultProps", {
size: "36px",
oobData: {}
});
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_matrix","_BaseAvatar","_ImageView","_MatrixClientPeg","_Modal","Avatar","_interopRequireWildcard","_DMRoomMap","_Media","_LocalRoom","_arrays","_excluded","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","idNameForRoom","room","dmMapUserId","DMRoomMap","shared","getUserIdForRoomId","roomId","LocalRoom","targets","length","userId","RoomAvatar","React","Component","constructor","props","_defineProperty2","ev","getRoomId","getType","EventType","setState","urls","getImageUrls","avatarUrl","avatarUrlForRoom","undefined","params","src","name","Modal","createDialog","ImageView","state","componentDidMount","MatrixClientPeg","safeGet","on","RoomStateEvent","Events","onRoomStateEvents","componentWillUnmount","removeListener","getDerivedStateFromProps","nextProps","oobAvatar","oobData","mediaFromMxc","getThumbnailOfSourceHttp","parseInt","size","filterBoolean","getRoomAvatarUrl","roomIdName","render","_this$props","viewAvatarOnClick","onClick","className","otherProps","_objectWithoutProperties2","roomName","createElement","_extends2","type","roomType","RoomType","Space","idName","onRoomAvatarClick","exports"],"sources":["../../../../src/components/views/avatars/RoomAvatar.tsx"],"sourcesContent":["/*\nCopyright 2024 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, { ComponentProps } from \"react\";\nimport { Room, RoomStateEvent, MatrixEvent, EventType, RoomType } from \"matrix-js-sdk/src/matrix\";\n\nimport BaseAvatar from \"./BaseAvatar\";\nimport ImageView from \"../elements/ImageView\";\nimport { MatrixClientPeg } from \"../../../MatrixClientPeg\";\nimport Modal from \"../../../Modal\";\nimport * as Avatar from \"../../../Avatar\";\nimport DMRoomMap from \"../../../utils/DMRoomMap\";\nimport { mediaFromMxc } from \"../../../customisations/Media\";\nimport { IOOBData } from \"../../../stores/ThreepidInviteStore\";\nimport { LocalRoom } from \"../../../models/LocalRoom\";\nimport { filterBoolean } from \"../../../utils/arrays\";\n\ninterface IProps extends Omit<ComponentProps<typeof BaseAvatar>, \"name\" | \"idName\" | \"url\" | \"onClick\"> {\n    // Room may be left unset here, but if it is,\n    // oobData.avatarUrl should be set (else there\n    // would be nowhere to get the avatar from)\n    room?: Room;\n    oobData: IOOBData & {\n        roomId?: string;\n    };\n    viewAvatarOnClick?: boolean;\n    onClick?(): void;\n}\n\ninterface IState {\n    urls: string[];\n}\n\nexport function idNameForRoom(room: Room): string {\n    const dmMapUserId = DMRoomMap.shared().getUserIdForRoomId(room.roomId);\n    // If the room is a DM, we use the other user's ID for the color hash\n    // in order to match the room avatar with their avatar\n    if (dmMapUserId) return dmMapUserId;\n\n    if (room instanceof LocalRoom && room.targets.length === 1) {\n        return room.targets[0].userId;\n    }\n\n    return room.roomId;\n}\n\nexport default class RoomAvatar extends React.Component<IProps, IState> {\n    public static defaultProps = {\n        size: \"36px\",\n        oobData: {},\n    };\n\n    public constructor(props: IProps) {\n        super(props);\n\n        this.state = {\n            urls: RoomAvatar.getImageUrls(this.props),\n        };\n    }\n\n    public componentDidMount(): void {\n        MatrixClientPeg.safeGet().on(RoomStateEvent.Events, this.onRoomStateEvents);\n    }\n\n    public componentWillUnmount(): void {\n        MatrixClientPeg.get()?.removeListener(RoomStateEvent.Events, this.onRoomStateEvents);\n    }\n\n    public static getDerivedStateFromProps(nextProps: IProps): IState {\n        return {\n            urls: RoomAvatar.getImageUrls(nextProps),\n        };\n    }\n\n    private onRoomStateEvents = (ev: MatrixEvent): void => {\n        if (ev.getRoomId() !== this.props.room?.roomId || ev.getType() !== EventType.RoomAvatar) return;\n\n        this.setState({\n            urls: RoomAvatar.getImageUrls(this.props),\n        });\n    };\n\n    private static getImageUrls(props: IProps): string[] {\n        let oobAvatar: string | null = null;\n        if (props.oobData.avatarUrl) {\n            oobAvatar = mediaFromMxc(props.oobData.avatarUrl).getThumbnailOfSourceHttp(\n                parseInt(props.size, 10),\n                parseInt(props.size, 10),\n                \"crop\",\n            );\n        }\n\n        return filterBoolean([\n            oobAvatar, // highest priority\n            RoomAvatar.getRoomAvatarUrl(props),\n        ]);\n    }\n\n    private static getRoomAvatarUrl(props: IProps): string | null {\n        if (!props.room) return null;\n\n        return Avatar.avatarUrlForRoom(props.room, parseInt(props.size, 10), parseInt(props.size, 10), \"crop\");\n    }\n\n    private onRoomAvatarClick = (): void => {\n        const avatarUrl = Avatar.avatarUrlForRoom(this.props.room ?? null, undefined, undefined, undefined);\n        if (!avatarUrl) return;\n        const params = {\n            src: avatarUrl,\n            name: this.props.room?.name,\n        };\n\n        Modal.createDialog(ImageView, params, \"mx_Dialog_lightbox\", undefined, true);\n    };\n\n    private get roomIdName(): string | undefined {\n        const room = this.props.room;\n\n        if (room) {\n            return idNameForRoom(room);\n        } else {\n            return this.props.oobData?.roomId;\n        }\n    }\n\n    public render(): React.ReactNode {\n        const { room, oobData, viewAvatarOnClick, onClick, className, ...otherProps } = this.props;\n        const roomName = room?.name ?? oobData.name ?? \"?\";\n\n        return (\n            <BaseAvatar\n                {...otherProps}\n                type={(room?.getType() ?? this.props.oobData?.roomType) === RoomType.Space ? \"square\" : \"round\"}\n                name={roomName}\n                idName={this.roomIdName}\n                urls={this.state.urls}\n                onClick={viewAvatarOnClick && this.state.urls[0] ? this.onRoomAvatarClick : onClick}\n            />\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}