matrix-react-sdk
Version:
SDK for matrix.org using React
224 lines (181 loc) • 23.4 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 _MatrixClientPeg = require("../../../MatrixClientPeg");
var sdk = _interopRequireWildcard(require("../../../index"));
var _languageHandler = require("../../../languageHandler");
var _KeyVerificationStateObserver = require("../../../utils/KeyVerificationStateObserver");
var _dispatcher = _interopRequireDefault(require("../../../dispatcher/dispatcher"));
var _RightPanelStorePhases = require("../../../stores/RightPanelStorePhases");
var _actions = require("../../../dispatcher/actions");
var _EventTileBubble = _interopRequireDefault(require("./EventTileBubble"));
var _replaceableComponent = require("../../../utils/replaceableComponent");
var _dec, _class, _temp;
let MKeyVerificationRequest = (_dec = (0, _replaceableComponent.replaceableComponent)("views.messages.MKeyVerificationRequest"), _dec(_class = (_temp = class MKeyVerificationRequest extends _react.default.Component {
constructor(props) {
super(props);
(0, _defineProperty2.default)(this, "_openRequest", () => {
const {
verificationRequest
} = this.props.mxEvent;
const member = _MatrixClientPeg.MatrixClientPeg.get().getUser(verificationRequest.otherUserId);
_dispatcher.default.dispatch({
action: _actions.Action.SetRightPanelPhase,
phase: _RightPanelStorePhases.RightPanelPhases.EncryptionPanel,
refireParams: {
verificationRequest,
member
}
});
});
(0, _defineProperty2.default)(this, "_onRequestChanged", () => {
this.forceUpdate();
});
(0, _defineProperty2.default)(this, "_onAcceptClicked", async () => {
const request = this.props.mxEvent.verificationRequest;
if (request) {
try {
this._openRequest();
await request.accept();
} catch (err) {
console.error(err.message);
}
}
});
(0, _defineProperty2.default)(this, "_onRejectClicked", async () => {
const request = this.props.mxEvent.verificationRequest;
if (request) {
try {
await request.cancel();
} catch (err) {
console.error(err.message);
}
}
});
this.state = {};
}
componentDidMount() {
const request = this.props.mxEvent.verificationRequest;
if (request) {
request.on("change", this._onRequestChanged);
}
}
componentWillUnmount() {
const request = this.props.mxEvent.verificationRequest;
if (request) {
request.off("change", this._onRequestChanged);
}
}
_acceptedLabel(userId) {
const client = _MatrixClientPeg.MatrixClientPeg.get();
const myUserId = client.getUserId();
if (userId === myUserId) {
return (0, _languageHandler._t)("You accepted");
} else {
return (0, _languageHandler._t)("%(name)s accepted", {
name: (0, _KeyVerificationStateObserver.getNameForEventRoom)(userId, this.props.mxEvent.getRoomId())
});
}
}
_cancelledLabel(userId) {
const client = _MatrixClientPeg.MatrixClientPeg.get();
const myUserId = client.getUserId();
const {
cancellationCode
} = this.props.mxEvent.verificationRequest;
const declined = cancellationCode === "m.user";
if (userId === myUserId) {
if (declined) {
return (0, _languageHandler._t)("You declined");
} else {
return (0, _languageHandler._t)("You cancelled");
}
} else {
if (declined) {
return (0, _languageHandler._t)("%(name)s declined", {
name: (0, _KeyVerificationStateObserver.getNameForEventRoom)(userId, this.props.mxEvent.getRoomId())
});
} else {
return (0, _languageHandler._t)("%(name)s cancelled", {
name: (0, _KeyVerificationStateObserver.getNameForEventRoom)(userId, this.props.mxEvent.getRoomId())
});
}
}
}
render() {
const AccessibleButton = sdk.getComponent("elements.AccessibleButton");
const FormButton = sdk.getComponent("elements.FormButton");
const {
mxEvent
} = this.props;
const request = mxEvent.verificationRequest;
if (!request || request.invalid) {
return null;
}
let title;
let subtitle;
let stateNode;
if (!request.canAccept) {
let stateLabel;
const accepted = request.ready || request.started || request.done;
if (accepted) {
stateLabel = /*#__PURE__*/_react.default.createElement(AccessibleButton, {
onClick: this._openRequest
}, this._acceptedLabel(request.receivingUserId));
} else if (request.cancelled) {
stateLabel = this._cancelledLabel(request.cancellingUserId);
} else if (request.accepting) {
stateLabel = (0, _languageHandler._t)("Accepting …");
} else if (request.declining) {
stateLabel = (0, _languageHandler._t)("Declining …");
}
stateNode = /*#__PURE__*/_react.default.createElement("div", {
className: "mx_cryptoEvent_state"
}, stateLabel);
}
if (!request.initiatedByMe) {
const name = (0, _KeyVerificationStateObserver.getNameForEventRoom)(request.requestingUserId, mxEvent.getRoomId());
title = (0, _languageHandler._t)("%(name)s wants to verify", {
name
});
subtitle = (0, _KeyVerificationStateObserver.userLabelForEventRoom)(request.requestingUserId, mxEvent.getRoomId());
if (request.canAccept) {
stateNode = /*#__PURE__*/_react.default.createElement("div", {
className: "mx_cryptoEvent_buttons"
}, /*#__PURE__*/_react.default.createElement(FormButton, {
kind: "danger",
onClick: this._onRejectClicked,
label: (0, _languageHandler._t)("Decline")
}), /*#__PURE__*/_react.default.createElement(FormButton, {
onClick: this._onAcceptClicked,
label: (0, _languageHandler._t)("Accept")
}));
}
} else {
// request sent by us
title = (0, _languageHandler._t)("You sent a verification request");
subtitle = (0, _KeyVerificationStateObserver.userLabelForEventRoom)(request.receivingUserId, mxEvent.getRoomId());
}
if (title) {
return /*#__PURE__*/_react.default.createElement(_EventTileBubble.default, {
className: "mx_cryptoEvent mx_cryptoEvent_icon",
title: title,
subtitle: subtitle
}, stateNode);
}
return null;
}
}, _temp)) || _class);
exports.default = MKeyVerificationRequest;
MKeyVerificationRequest.propTypes = {
/* the MatrixEvent to show */
mxEvent: _propTypes.default.object.isRequired
};
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/messages/MKeyVerificationRequest.js"],"names":["MKeyVerificationRequest","React","Component","constructor","props","verificationRequest","mxEvent","member","MatrixClientPeg","get","getUser","otherUserId","dis","dispatch","action","Action","SetRightPanelPhase","phase","RightPanelPhases","EncryptionPanel","refireParams","forceUpdate","request","_openRequest","accept","err","console","error","message","cancel","state","componentDidMount","on","_onRequestChanged","componentWillUnmount","off","_acceptedLabel","userId","client","myUserId","getUserId","name","getRoomId","_cancelledLabel","cancellationCode","declined","render","AccessibleButton","sdk","getComponent","FormButton","invalid","title","subtitle","stateNode","canAccept","stateLabel","accepted","ready","started","done","receivingUserId","cancelled","cancellingUserId","accepting","declining","initiatedByMe","requestingUserId","_onRejectClicked","_onAcceptClicked","propTypes","PropTypes","object","isRequired"],"mappings":";;;;;;;;;;;;;AAgBA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAEA;;AACA;;AACA;;AACA;;AACA;;;;IAGqBA,uB,WADpB,gDAAqB,wCAArB,C,yBAAD,MACqBA,uBADrB,SACqDC,eAAMC,SAD3D,CACqE;AACjEC,EAAAA,WAAW,CAACC,KAAD,EAAQ;AACf,UAAMA,KAAN;AADe,wDAmBJ,MAAM;AACjB,YAAM;AAACC,QAAAA;AAAD,UAAwB,KAAKD,KAAL,CAAWE,OAAzC;;AACA,YAAMC,MAAM,GAAGC,iCAAgBC,GAAhB,GAAsBC,OAAtB,CAA8BL,mBAAmB,CAACM,WAAlD,CAAf;;AACAC,0BAAIC,QAAJ,CAAa;AACTC,QAAAA,MAAM,EAAEC,gBAAOC,kBADN;AAETC,QAAAA,KAAK,EAAEC,wCAAiBC,eAFf;AAGTC,QAAAA,YAAY,EAAE;AAACf,UAAAA,mBAAD;AAAsBE,UAAAA;AAAtB;AAHL,OAAb;AAKH,KA3BkB;AAAA,6DA6BC,MAAM;AACtB,WAAKc,WAAL;AACH,KA/BkB;AAAA,4DAiCA,YAAY;AAC3B,YAAMC,OAAO,GAAG,KAAKlB,KAAL,CAAWE,OAAX,CAAmBD,mBAAnC;;AACA,UAAIiB,OAAJ,EAAa;AACT,YAAI;AACA,eAAKC,YAAL;;AACA,gBAAMD,OAAO,CAACE,MAAR,EAAN;AACH,SAHD,CAGE,OAAOC,GAAP,EAAY;AACVC,UAAAA,OAAO,CAACC,KAAR,CAAcF,GAAG,CAACG,OAAlB;AACH;AACJ;AACJ,KA3CkB;AAAA,4DA6CA,YAAY;AAC3B,YAAMN,OAAO,GAAG,KAAKlB,KAAL,CAAWE,OAAX,CAAmBD,mBAAnC;;AACA,UAAIiB,OAAJ,EAAa;AACT,YAAI;AACA,gBAAMA,OAAO,CAACO,MAAR,EAAN;AACH,SAFD,CAEE,OAAOJ,GAAP,EAAY;AACVC,UAAAA,OAAO,CAACC,KAAR,CAAcF,GAAG,CAACG,OAAlB;AACH;AACJ;AACJ,KAtDkB;AAEf,SAAKE,KAAL,GAAa,EAAb;AACH;;AAEDC,EAAAA,iBAAiB,GAAG;AAChB,UAAMT,OAAO,GAAG,KAAKlB,KAAL,CAAWE,OAAX,CAAmBD,mBAAnC;;AACA,QAAIiB,OAAJ,EAAa;AACTA,MAAAA,OAAO,CAACU,EAAR,CAAW,QAAX,EAAqB,KAAKC,iBAA1B;AACH;AACJ;;AAEDC,EAAAA,oBAAoB,GAAG;AACnB,UAAMZ,OAAO,GAAG,KAAKlB,KAAL,CAAWE,OAAX,CAAmBD,mBAAnC;;AACA,QAAIiB,OAAJ,EAAa;AACTA,MAAAA,OAAO,CAACa,GAAR,CAAY,QAAZ,EAAsB,KAAKF,iBAA3B;AACH;AACJ;;AAuCDG,EAAAA,cAAc,CAACC,MAAD,EAAS;AACnB,UAAMC,MAAM,GAAG9B,iCAAgBC,GAAhB,EAAf;;AACA,UAAM8B,QAAQ,GAAGD,MAAM,CAACE,SAAP,EAAjB;;AACA,QAAIH,MAAM,KAAKE,QAAf,EAAyB;AACrB,aAAO,yBAAG,cAAH,CAAP;AACH,KAFD,MAEO;AACH,aAAO,yBAAG,mBAAH,EAAwB;AAACE,QAAAA,IAAI,EAAE,uDAAoBJ,MAApB,EAA4B,KAAKjC,KAAL,CAAWE,OAAX,CAAmBoC,SAAnB,EAA5B;AAAP,OAAxB,CAAP;AACH;AACJ;;AAEDC,EAAAA,eAAe,CAACN,MAAD,EAAS;AACpB,UAAMC,MAAM,GAAG9B,iCAAgBC,GAAhB,EAAf;;AACA,UAAM8B,QAAQ,GAAGD,MAAM,CAACE,SAAP,EAAjB;AACA,UAAM;AAACI,MAAAA;AAAD,QAAqB,KAAKxC,KAAL,CAAWE,OAAX,CAAmBD,mBAA9C;AACA,UAAMwC,QAAQ,GAAGD,gBAAgB,KAAK,QAAtC;;AACA,QAAIP,MAAM,KAAKE,QAAf,EAAyB;AACrB,UAAIM,QAAJ,EAAc;AACV,eAAO,yBAAG,cAAH,CAAP;AACH,OAFD,MAEO;AACH,eAAO,yBAAG,eAAH,CAAP;AACH;AACJ,KAND,MAMO;AACH,UAAIA,QAAJ,EAAc;AACV,eAAO,yBAAG,mBAAH,EAAwB;AAACJ,UAAAA,IAAI,EAAE,uDAAoBJ,MAApB,EAA4B,KAAKjC,KAAL,CAAWE,OAAX,CAAmBoC,SAAnB,EAA5B;AAAP,SAAxB,CAAP;AACH,OAFD,MAEO;AACH,eAAO,yBAAG,oBAAH,EAAyB;AAACD,UAAAA,IAAI,EAAE,uDAAoBJ,MAApB,EAA4B,KAAKjC,KAAL,CAAWE,OAAX,CAAmBoC,SAAnB,EAA5B;AAAP,SAAzB,CAAP;AACH;AACJ;AACJ;;AAEDI,EAAAA,MAAM,GAAG;AACL,UAAMC,gBAAgB,GAAGC,GAAG,CAACC,YAAJ,CAAiB,2BAAjB,CAAzB;AACA,UAAMC,UAAU,GAAGF,GAAG,CAACC,YAAJ,CAAiB,qBAAjB,CAAnB;AAEA,UAAM;AAAC3C,MAAAA;AAAD,QAAY,KAAKF,KAAvB;AACA,UAAMkB,OAAO,GAAGhB,OAAO,CAACD,mBAAxB;;AAEA,QAAI,CAACiB,OAAD,IAAYA,OAAO,CAAC6B,OAAxB,EAAiC;AAC7B,aAAO,IAAP;AACH;;AAED,QAAIC,KAAJ;AACA,QAAIC,QAAJ;AACA,QAAIC,SAAJ;;AAEA,QAAI,CAAChC,OAAO,CAACiC,SAAb,EAAwB;AACpB,UAAIC,UAAJ;AACA,YAAMC,QAAQ,GAAGnC,OAAO,CAACoC,KAAR,IAAiBpC,OAAO,CAACqC,OAAzB,IAAoCrC,OAAO,CAACsC,IAA7D;;AACA,UAAIH,QAAJ,EAAc;AACVD,QAAAA,UAAU,gBAAI,6BAAC,gBAAD;AAAkB,UAAA,OAAO,EAAE,KAAKjC;AAAhC,WACT,KAAKa,cAAL,CAAoBd,OAAO,CAACuC,eAA5B,CADS,CAAd;AAGH,OAJD,MAIO,IAAIvC,OAAO,CAACwC,SAAZ,EAAuB;AAC1BN,QAAAA,UAAU,GAAG,KAAKb,eAAL,CAAqBrB,OAAO,CAACyC,gBAA7B,CAAb;AACH,OAFM,MAEA,IAAIzC,OAAO,CAAC0C,SAAZ,EAAuB;AAC1BR,QAAAA,UAAU,GAAG,yBAAG,aAAH,CAAb;AACH,OAFM,MAEA,IAAIlC,OAAO,CAAC2C,SAAZ,EAAuB;AAC1BT,QAAAA,UAAU,GAAG,yBAAG,aAAH,CAAb;AACH;;AACDF,MAAAA,SAAS,gBAAI;AAAK,QAAA,SAAS,EAAC;AAAf,SAAuCE,UAAvC,CAAb;AACH;;AAED,QAAI,CAAClC,OAAO,CAAC4C,aAAb,EAA4B;AACxB,YAAMzB,IAAI,GAAG,uDAAoBnB,OAAO,CAAC6C,gBAA5B,EAA8C7D,OAAO,CAACoC,SAAR,EAA9C,CAAb;AACAU,MAAAA,KAAK,GAAG,yBAAG,0BAAH,EAA+B;AAACX,QAAAA;AAAD,OAA/B,CAAR;AACAY,MAAAA,QAAQ,GAAG,yDAAsB/B,OAAO,CAAC6C,gBAA9B,EAAgD7D,OAAO,CAACoC,SAAR,EAAhD,CAAX;;AACA,UAAIpB,OAAO,CAACiC,SAAZ,EAAuB;AACnBD,QAAAA,SAAS,gBAAI;AAAK,UAAA,SAAS,EAAC;AAAf,wBACT,6BAAC,UAAD;AAAY,UAAA,IAAI,EAAC,QAAjB;AAA0B,UAAA,OAAO,EAAE,KAAKc,gBAAxC;AAA0D,UAAA,KAAK,EAAE,yBAAG,SAAH;AAAjE,UADS,eAET,6BAAC,UAAD;AAAY,UAAA,OAAO,EAAE,KAAKC,gBAA1B;AAA4C,UAAA,KAAK,EAAE,yBAAG,QAAH;AAAnD,UAFS,CAAb;AAIH;AACJ,KAVD,MAUO;AAAE;AACLjB,MAAAA,KAAK,GAAG,yBAAG,iCAAH,CAAR;AACAC,MAAAA,QAAQ,GAAG,yDAAsB/B,OAAO,CAACuC,eAA9B,EAA+CvD,OAAO,CAACoC,SAAR,EAA/C,CAAX;AACH;;AAED,QAAIU,KAAJ,EAAW;AACP,0BAAO,6BAAC,wBAAD;AACH,QAAA,SAAS,EAAC,oCADP;AAEH,QAAA,KAAK,EAAEA,KAFJ;AAGH,QAAA,QAAQ,EAAEC;AAHP,SAKDC,SALC,CAAP;AAOH;;AACD,WAAO,IAAP;AACH;;AAhJgE,C;;AAmJrEtD,uBAAuB,CAACsE,SAAxB,GAAoC;AAChC;AACAhE,EAAAA,OAAO,EAAEiE,mBAAUC,MAAV,CAAiBC;AAFM,CAApC","sourcesContent":["/*\nCopyright 2019, 2020 The Matrix.org Foundation C.I.C.\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 {MatrixClientPeg} from '../../../MatrixClientPeg';\nimport * as sdk from '../../../index';\nimport { _t } from '../../../languageHandler';\nimport {getNameForEventRoom, userLabelForEventRoom}\n    from '../../../utils/KeyVerificationStateObserver';\nimport dis from \"../../../dispatcher/dispatcher\";\nimport {RightPanelPhases} from \"../../../stores/RightPanelStorePhases\";\nimport {Action} from \"../../../dispatcher/actions\";\nimport EventTileBubble from \"./EventTileBubble\";\nimport {replaceableComponent} from \"../../../utils/replaceableComponent\";\n\n@replaceableComponent(\"views.messages.MKeyVerificationRequest\")\nexport default class MKeyVerificationRequest extends React.Component {\n    constructor(props) {\n        super(props);\n        this.state = {};\n    }\n\n    componentDidMount() {\n        const request = this.props.mxEvent.verificationRequest;\n        if (request) {\n            request.on(\"change\", this._onRequestChanged);\n        }\n    }\n\n    componentWillUnmount() {\n        const request = this.props.mxEvent.verificationRequest;\n        if (request) {\n            request.off(\"change\", this._onRequestChanged);\n        }\n    }\n\n    _openRequest = () => {\n        const {verificationRequest} = this.props.mxEvent;\n        const member = MatrixClientPeg.get().getUser(verificationRequest.otherUserId);\n        dis.dispatch({\n            action: Action.SetRightPanelPhase,\n            phase: RightPanelPhases.EncryptionPanel,\n            refireParams: {verificationRequest, member},\n        });\n    };\n\n    _onRequestChanged = () => {\n        this.forceUpdate();\n    };\n\n    _onAcceptClicked = async () => {\n        const request = this.props.mxEvent.verificationRequest;\n        if (request) {\n            try {\n                this._openRequest();\n                await request.accept();\n            } catch (err) {\n                console.error(err.message);\n            }\n        }\n    };\n\n    _onRejectClicked = async () => {\n        const request = this.props.mxEvent.verificationRequest;\n        if (request) {\n            try {\n                await request.cancel();\n            } catch (err) {\n                console.error(err.message);\n            }\n        }\n    };\n\n    _acceptedLabel(userId) {\n        const client = MatrixClientPeg.get();\n        const myUserId = client.getUserId();\n        if (userId === myUserId) {\n            return _t(\"You accepted\");\n        } else {\n            return _t(\"%(name)s accepted\", {name: getNameForEventRoom(userId, this.props.mxEvent.getRoomId())});\n        }\n    }\n\n    _cancelledLabel(userId) {\n        const client = MatrixClientPeg.get();\n        const myUserId = client.getUserId();\n        const {cancellationCode} = this.props.mxEvent.verificationRequest;\n        const declined = cancellationCode === \"m.user\";\n        if (userId === myUserId) {\n            if (declined) {\n                return _t(\"You declined\");\n            } else {\n                return _t(\"You cancelled\");\n            }\n        } else {\n            if (declined) {\n                return _t(\"%(name)s declined\", {name: getNameForEventRoom(userId, this.props.mxEvent.getRoomId())});\n            } else {\n                return _t(\"%(name)s cancelled\", {name: getNameForEventRoom(userId, this.props.mxEvent.getRoomId())});\n            }\n        }\n    }\n\n    render() {\n        const AccessibleButton = sdk.getComponent(\"elements.AccessibleButton\");\n        const FormButton = sdk.getComponent(\"elements.FormButton\");\n\n        const {mxEvent} = this.props;\n        const request = mxEvent.verificationRequest;\n\n        if (!request || request.invalid) {\n            return null;\n        }\n\n        let title;\n        let subtitle;\n        let stateNode;\n\n        if (!request.canAccept) {\n            let stateLabel;\n            const accepted = request.ready || request.started || request.done;\n            if (accepted) {\n                stateLabel = (<AccessibleButton onClick={this._openRequest}>\n                    {this._acceptedLabel(request.receivingUserId)}\n                </AccessibleButton>);\n            } else if (request.cancelled) {\n                stateLabel = this._cancelledLabel(request.cancellingUserId);\n            } else if (request.accepting) {\n                stateLabel = _t(\"Accepting …\");\n            } else if (request.declining) {\n                stateLabel = _t(\"Declining …\");\n            }\n            stateNode = (<div className=\"mx_cryptoEvent_state\">{stateLabel}</div>);\n        }\n\n        if (!request.initiatedByMe) {\n            const name = getNameForEventRoom(request.requestingUserId, mxEvent.getRoomId());\n            title = _t(\"%(name)s wants to verify\", {name});\n            subtitle = userLabelForEventRoom(request.requestingUserId, mxEvent.getRoomId());\n            if (request.canAccept) {\n                stateNode = (<div className=\"mx_cryptoEvent_buttons\">\n                    <FormButton kind=\"danger\" onClick={this._onRejectClicked} label={_t(\"Decline\")} />\n                    <FormButton onClick={this._onAcceptClicked} label={_t(\"Accept\")} />\n                </div>);\n            }\n        } else { // request sent by us\n            title = _t(\"You sent a verification request\");\n            subtitle = userLabelForEventRoom(request.receivingUserId, mxEvent.getRoomId());\n        }\n\n        if (title) {\n            return <EventTileBubble\n                className=\"mx_cryptoEvent mx_cryptoEvent_icon\"\n                title={title}\n                subtitle={subtitle}\n            >\n                { stateNode }\n            </EventTileBubble>;\n        }\n        return null;\n    }\n}\n\nMKeyVerificationRequest.propTypes = {\n    /* the MatrixEvent to show */\n    mxEvent: PropTypes.object.isRequired,\n};\n"]}