matrix-react-sdk
Version:
SDK for matrix.org using React
146 lines (123 loc) • 17 kB
JavaScript
"use strict";
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 _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireDefault(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _classnames = _interopRequireDefault(require("classnames"));
var sdk = _interopRequireWildcard(require("../../../index"));
var _languageHandler = require("../../../languageHandler");
var _UserAddress = require("../../../UserAddress.js");
var _replaceableComponent = require("../../../utils/replaceableComponent");
var _Media = require("../../../customisations/Media");
var _dec, _class, _class2, _temp;
let AddressTile = (_dec = (0, _replaceableComponent.replaceableComponent)("views.elements.AddressTile"), _dec(_class = (_temp = _class2 = class AddressTile extends _react.default.Component {
render() {
const address = this.props.address;
const name = address.displayName || address.address;
const imgUrls = [];
const isMatrixAddress = ['mx-user-id', 'mx-room-id'].includes(address.addressType);
if (isMatrixAddress && address.avatarMxc) {
imgUrls.push((0, _Media.mediaFromMxc)(address.avatarMxc).getSquareThumbnailHttp(25));
} else if (address.addressType === 'email') {
imgUrls.push(require("../../../../res/img/icon-email-user.svg"));
}
const BaseAvatar = sdk.getComponent('avatars.BaseAvatar');
const TintableSvg = sdk.getComponent("elements.TintableSvg");
const nameClasses = (0, _classnames.default)({
"mx_AddressTile_name": true,
"mx_AddressTile_justified": this.props.justified
});
let info;
let error = false;
if (isMatrixAddress && address.isKnown) {
const idClasses = (0, _classnames.default)({
"mx_AddressTile_id": true,
"mx_AddressTile_justified": this.props.justified
});
info = /*#__PURE__*/_react.default.createElement("div", {
className: "mx_AddressTile_mx"
}, /*#__PURE__*/_react.default.createElement("div", {
className: nameClasses
}, name), this.props.showAddress ? /*#__PURE__*/_react.default.createElement("div", {
className: idClasses
}, address.address) : /*#__PURE__*/_react.default.createElement("div", null));
} else if (isMatrixAddress) {
const unknownMxClasses = (0, _classnames.default)({
"mx_AddressTile_unknownMx": true,
"mx_AddressTile_justified": this.props.justified
});
info = /*#__PURE__*/_react.default.createElement("div", {
className: unknownMxClasses
}, this.props.address.address);
} else if (address.addressType === "email") {
const emailClasses = (0, _classnames.default)({
"mx_AddressTile_email": true,
"mx_AddressTile_justified": this.props.justified
});
let nameNode = null;
if (address.displayName) {
nameNode = /*#__PURE__*/_react.default.createElement("div", {
className: nameClasses
}, address.displayName);
}
info = /*#__PURE__*/_react.default.createElement("div", {
className: "mx_AddressTile_mx"
}, /*#__PURE__*/_react.default.createElement("div", {
className: emailClasses
}, address.address), nameNode);
} else {
error = true;
const unknownClasses = (0, _classnames.default)({
"mx_AddressTile_unknown": true,
"mx_AddressTile_justified": this.props.justified
});
info = /*#__PURE__*/_react.default.createElement("div", {
className: unknownClasses
}, (0, _languageHandler._t)("Unknown Address"));
}
const classes = (0, _classnames.default)({
"mx_AddressTile": true,
"mx_AddressTile_error": error
});
let dismiss;
if (this.props.canDismiss) {
dismiss = /*#__PURE__*/_react.default.createElement("div", {
className: "mx_AddressTile_dismiss",
onClick: this.props.onDismissed
}, /*#__PURE__*/_react.default.createElement(TintableSvg, {
src: require("../../../../res/img/icon-address-delete.svg"),
width: "9",
height: "9"
}));
}
return /*#__PURE__*/_react.default.createElement("div", {
className: classes
}, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_AddressTile_avatar"
}, /*#__PURE__*/_react.default.createElement(BaseAvatar, {
defaultToInitialLetter: true,
width: 25,
height: 25,
name: name,
title: name,
urls: imgUrls
})), info, dismiss);
}
}, (0, _defineProperty2.default)(_class2, "propTypes", {
address: _UserAddress.UserAddressType.isRequired,
canDismiss: _propTypes.default.bool,
onDismissed: _propTypes.default.func,
justified: _propTypes.default.bool
}), (0, _defineProperty2.default)(_class2, "defaultProps", {
canDismiss: false,
onDismissed: function () {},
// NOP
justified: false
}), _temp)) || _class);
exports.default = AddressTile;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/elements/AddressTile.js"],"names":["AddressTile","React","Component","render","address","props","name","displayName","imgUrls","isMatrixAddress","includes","addressType","avatarMxc","push","getSquareThumbnailHttp","require","BaseAvatar","sdk","getComponent","TintableSvg","nameClasses","justified","info","error","isKnown","idClasses","showAddress","unknownMxClasses","emailClasses","nameNode","unknownClasses","classes","dismiss","canDismiss","onDismissed","UserAddressType","isRequired","PropTypes","bool","func"],"mappings":"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","sourcesContent":["/*\nCopyright 2015, 2016 OpenMarket Ltd\nCopyright 2017 New Vector 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*/\n\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport classNames from 'classnames';\nimport * as sdk from \"../../../index\";\nimport { _t } from '../../../languageHandler';\nimport { UserAddressType } from '../../../UserAddress.js';\nimport {replaceableComponent} from \"../../../utils/replaceableComponent\";\nimport {mediaFromMxc} from \"../../../customisations/Media\";\n\n@replaceableComponent(\"views.elements.AddressTile\")\nexport default class AddressTile extends React.Component {\n    static propTypes = {\n        address: UserAddressType.isRequired,\n        canDismiss: PropTypes.bool,\n        onDismissed: PropTypes.func,\n        justified: PropTypes.bool,\n    };\n\n    static defaultProps = {\n        canDismiss: false,\n        onDismissed: function() {}, // NOP\n        justified: false,\n    };\n\n    render() {\n        const address = this.props.address;\n        const name = address.displayName || address.address;\n\n        const imgUrls = [];\n        const isMatrixAddress = ['mx-user-id', 'mx-room-id'].includes(address.addressType);\n\n        if (isMatrixAddress && address.avatarMxc) {\n            imgUrls.push(mediaFromMxc(address.avatarMxc).getSquareThumbnailHttp(25));\n        } else if (address.addressType === 'email') {\n            imgUrls.push(require(\"../../../../res/img/icon-email-user.svg\"));\n        }\n\n        const BaseAvatar = sdk.getComponent('avatars.BaseAvatar');\n        const TintableSvg = sdk.getComponent(\"elements.TintableSvg\");\n\n        const nameClasses = classNames({\n            \"mx_AddressTile_name\": true,\n            \"mx_AddressTile_justified\": this.props.justified,\n        });\n\n        let info;\n        let error = false;\n        if (isMatrixAddress && address.isKnown) {\n            const idClasses = classNames({\n                \"mx_AddressTile_id\": true,\n                \"mx_AddressTile_justified\": this.props.justified,\n            });\n\n            info = (\n                <div className=\"mx_AddressTile_mx\">\n                    <div className={nameClasses}>{ name }</div>\n                    { this.props.showAddress ?\n                        <div className={idClasses}>{ address.address }</div> :\n                        <div />\n                    }\n                </div>\n            );\n        } else if (isMatrixAddress) {\n            const unknownMxClasses = classNames({\n                \"mx_AddressTile_unknownMx\": true,\n                \"mx_AddressTile_justified\": this.props.justified,\n            });\n\n            info = (\n                <div className={unknownMxClasses}>{ this.props.address.address }</div>\n            );\n        } else if (address.addressType === \"email\") {\n            const emailClasses = classNames({\n                \"mx_AddressTile_email\": true,\n                \"mx_AddressTile_justified\": this.props.justified,\n            });\n\n            let nameNode = null;\n            if (address.displayName) {\n                nameNode = <div className={nameClasses}>{ address.displayName }</div>;\n            }\n\n            info = (\n                <div className=\"mx_AddressTile_mx\">\n                    <div className={emailClasses}>{ address.address }</div>\n                    { nameNode }\n                </div>\n            );\n        } else {\n            error = true;\n            const unknownClasses = classNames({\n                \"mx_AddressTile_unknown\": true,\n                \"mx_AddressTile_justified\": this.props.justified,\n            });\n\n            info = (\n                <div className={unknownClasses}>{ _t(\"Unknown Address\") }</div>\n            );\n        }\n\n        const classes = classNames({\n            \"mx_AddressTile\": true,\n            \"mx_AddressTile_error\": error,\n        });\n\n        let dismiss;\n        if (this.props.canDismiss) {\n            dismiss = (\n                <div className=\"mx_AddressTile_dismiss\" onClick={this.props.onDismissed} >\n                    <TintableSvg src={require(\"../../../../res/img/icon-address-delete.svg\")} width=\"9\" height=\"9\" />\n                </div>\n            );\n        }\n\n        return (\n            <div className={classes}>\n                <div className=\"mx_AddressTile_avatar\">\n                    <BaseAvatar defaultToInitialLetter={true} width={25} height={25} name={name} title={name} urls={imgUrls} />\n                </div>\n                { info }\n                { dismiss }\n            </div>\n        );\n    }\n}\n"]}