matrix-react-sdk
Version:
SDK for matrix.org using React
139 lines (111 loc) • 14.7 kB
JavaScript
;
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 _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 _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 _replaceableComponent = require("../../../utils/replaceableComponent");
var _Media = require("../../../customisations/Media");
var _dec, _class, _class2, _temp;
let RoomAvatar = (_dec = (0, _replaceableComponent.replaceableComponent)("views.avatars.RoomAvatar"), _dec(_class = (_temp = _class2 = class RoomAvatar extends _react.default.Component
/*:: <IProps, IState>*/
{
constructor(props
/*: IProps*/
) {
super(props);
(0, _defineProperty2.default)(this, "onRoomStateEvents", (ev
/*: any*/
) => {
if (!this.props.room || ev.getRoomId() !== this.props.room.roomId || ev.getType() !== 'm.room.avatar') return;
this.setState({
urls: RoomAvatar.getImageUrls(this.props)
});
});
(0, _defineProperty2.default)(this, "onRoomAvatarClick", () => {
const avatarUrl = Avatar.avatarUrlForRoom(this.props.room, null, null, null);
const params = {
src: avatarUrl,
name: this.props.room.name
};
_Modal.default.createDialog(_ImageView.default, params, "mx_Dialog_lightbox", null, true);
});
this.state = {
urls: RoomAvatar.getImageUrls(this.props)
};
}
componentDidMount() {
_MatrixClientPeg.MatrixClientPeg.get().on("RoomState.events", this.onRoomStateEvents);
}
componentWillUnmount() {
const cli = _MatrixClientPeg.MatrixClientPeg.get();
if (cli) {
cli.removeListener("RoomState.events", this.onRoomStateEvents);
}
}
static getDerivedStateFromProps(nextProps
/*: IProps*/
)
/*: IState*/
{
return {
urls: RoomAvatar.getImageUrls(nextProps)
};
} // TODO: type when js-sdk has types
static getImageUrls(props
/*: IProps*/
)
/*: string[]*/
{
let oobAvatar = null;
if (props.oobData.avatarUrl) {
oobAvatar = (0, _Media.mediaFromMxc)(props.oobData.avatarUrl).getThumbnailOfSourceHttp(props.width, props.height, props.resizeMethod);
}
return [oobAvatar, // highest priority
RoomAvatar.getRoomAvatarUrl(props)].filter(function (url) {
return url !== null && url !== "";
});
}
static getRoomAvatarUrl(props
/*: IProps*/
)
/*: string*/
{
if (!props.room) return null;
return Avatar.avatarUrlForRoom(props.room, props.width, props.height, props.resizeMethod);
}
render() {
const _this$props = this.props,
{
room,
oobData,
viewAvatarOnClick,
onClick
} = _this$props,
otherProps = (0, _objectWithoutProperties2.default)(_this$props, ["room", "oobData", "viewAvatarOnClick", "onClick"]);
const roomName = room ? room.name : oobData.name;
return /*#__PURE__*/_react.default.createElement(_BaseAvatar.default, (0, _extends2.default)({}, otherProps, {
name: roomName,
idName: room ? room.roomId : null,
urls: this.state.urls,
onClick: viewAvatarOnClick && this.state.urls[0] ? this.onRoomAvatarClick : onClick
}));
}
}, (0, _defineProperty2.default)(_class2, "defaultProps", {
width: 36,
height: 36,
resizeMethod: 'crop',
oobData: {}
}), _temp)) || _class);
exports.default = RoomAvatar;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/avatars/RoomAvatar.tsx"],"names":["RoomAvatar","React","Component","constructor","props","ev","room","getRoomId","roomId","getType","setState","urls","getImageUrls","avatarUrl","Avatar","avatarUrlForRoom","params","src","name","Modal","createDialog","ImageView","state","componentDidMount","MatrixClientPeg","get","on","onRoomStateEvents","componentWillUnmount","cli","removeListener","getDerivedStateFromProps","nextProps","oobAvatar","oobData","getThumbnailOfSourceHttp","width","height","resizeMethod","getRoomAvatarUrl","filter","url","render","viewAvatarOnClick","onClick","otherProps","roomName","onRoomAvatarClick"],"mappings":"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","sourcesContent":["/*\nCopyright 2015, 2016 OpenMarket Ltd\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*/\nimport React, {ComponentProps} from 'react';\nimport Room from 'matrix-js-sdk/src/models/room';\n\nimport BaseAvatar from './BaseAvatar';\nimport ImageView from '../elements/ImageView';\nimport {MatrixClientPeg} from '../../../MatrixClientPeg';\nimport Modal from '../../../Modal';\nimport * as Avatar from '../../../Avatar';\nimport {ResizeMethod} from \"../../../Avatar\";\nimport {replaceableComponent} from \"../../../utils/replaceableComponent\";\nimport {mediaFromMxc} from \"../../../customisations/Media\";\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    // TODO: type when js-sdk has types\n    oobData?: any;\n    width?: number;\n    height?: number;\n    resizeMethod?: ResizeMethod;\n    viewAvatarOnClick?: boolean;\n    onClick?(): void;\n}\n\ninterface IState {\n    urls: string[];\n}\n\n@replaceableComponent(\"views.avatars.RoomAvatar\")\nexport default class RoomAvatar extends React.Component<IProps, IState> {\n    public static defaultProps = {\n        width: 36,\n        height: 36,\n        resizeMethod: 'crop',\n        oobData: {},\n    };\n\n    constructor(props: IProps) {\n        super(props);\n\n        this.state = {\n            urls: RoomAvatar.getImageUrls(this.props),\n        };\n    }\n\n    public componentDidMount() {\n        MatrixClientPeg.get().on(\"RoomState.events\", this.onRoomStateEvents);\n    }\n\n    public componentWillUnmount() {\n        const cli = MatrixClientPeg.get();\n        if (cli) {\n            cli.removeListener(\"RoomState.events\", this.onRoomStateEvents);\n        }\n    }\n\n    public static getDerivedStateFromProps(nextProps: IProps): IState {\n        return {\n            urls: RoomAvatar.getImageUrls(nextProps),\n        };\n    }\n\n    // TODO: type when js-sdk has types\n    private onRoomStateEvents = (ev: any) => {\n        if (!this.props.room ||\n            ev.getRoomId() !== this.props.room.roomId ||\n            ev.getType() !== 'm.room.avatar'\n        ) return;\n\n        this.setState({\n            urls: RoomAvatar.getImageUrls(this.props),\n        });\n    };\n\n    private static getImageUrls(props: IProps): string[] {\n        let oobAvatar = null;\n        if (props.oobData.avatarUrl) {\n            oobAvatar = mediaFromMxc(props.oobData.avatarUrl).getThumbnailOfSourceHttp(\n                props.width,\n                props.height,\n                props.resizeMethod,\n            );\n        }\n        return [\n            oobAvatar, // highest priority\n            RoomAvatar.getRoomAvatarUrl(props),\n        ].filter(function(url) {\n            return (url !== null && url !== \"\");\n        });\n    }\n\n    private static getRoomAvatarUrl(props: IProps): string {\n        if (!props.room) return null;\n\n        return Avatar.avatarUrlForRoom(props.room, props.width, props.height, props.resizeMethod);\n    }\n\n    private onRoomAvatarClick = () => {\n        const avatarUrl = Avatar.avatarUrlForRoom(\n            this.props.room,\n            null,\n            null,\n            null,\n        );\n        const params = {\n            src: avatarUrl,\n            name: this.props.room.name,\n        };\n\n        Modal.createDialog(ImageView, params, \"mx_Dialog_lightbox\", null, true);\n    };\n\n    public render() {\n        const {room, oobData, viewAvatarOnClick, onClick, ...otherProps} = this.props;\n\n        const roomName = room ? room.name : oobData.name;\n\n        return (\n            <BaseAvatar {...otherProps}\n                name={roomName}\n                idName={room ? room.roomId : null}\n                urls={this.state.urls}\n                onClick={viewAvatarOnClick && this.state.urls[0] ? this.onRoomAvatarClick : onClick}\n            />\n        );\n    }\n}\n"]}