matrix-react-sdk
Version:
SDK for matrix.org using React
285 lines (237 loc) • 34.8 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireDefault(require("react"));
var _BaseDialog = _interopRequireDefault(require("./BaseDialog"));
var _languageHandler = require("../../../languageHandler");
var _Field = _interopRequireDefault(require("../elements/Field"));
var _AccessibleButton = _interopRequireDefault(require("../elements/AccessibleButton"));
var _MatrixClientPeg = require("../../../MatrixClientPeg");
var _arrays = require("../../../utils/arrays");
var _SdkConfig = _interopRequireDefault(require("../../../SdkConfig"));
var _InviteDialog = _interopRequireDefault(require("./InviteDialog"));
var _BaseAvatar = _interopRequireDefault(require("../avatars/BaseAvatar"));
var _RoomInvite = require("../../../RoomInvite");
var _StyledCheckbox = _interopRequireDefault(require("../elements/StyledCheckbox"));
var _Modal = _interopRequireDefault(require("../../../Modal"));
var _ErrorDialog = _interopRequireDefault(require("./ErrorDialog"));
var _replaceableComponent = require("../../../utils/replaceableComponent");
var _Media = require("../../../customisations/Media");
var _dec, _class, _temp;
let CommunityPrototypeInviteDialog = (_dec = (0, _replaceableComponent.replaceableComponent)("views.dialogs.CommunityPrototypeInviteDialog"), _dec(_class = (_temp = class CommunityPrototypeInviteDialog extends _react.default.PureComponent
/*:: <IProps, IState>*/
{
constructor(props
/*: IProps*/
) {
super(props);
(0, _defineProperty2.default)(this, "onSubmit", async (ev
/*: FormEvent*/
) => {
ev.preventDefault();
ev.stopPropagation();
this.setState({
busy: true
});
try {
const targets = [...this.state.emailTargets, ...this.state.userTargets];
const result = await (0, _RoomInvite.inviteMultipleToRoom)(this.props.roomId, targets);
const room = _MatrixClientPeg.MatrixClientPeg.get().getRoom(this.props.roomId);
const success = (0, _RoomInvite.showAnyInviteErrors)(result.states, room, result.inviter);
if (success) {
this.props.onFinished(true);
} else {
this.setState({
busy: false
});
}
} catch (e) {
this.setState({
busy: false
});
console.error(e);
_Modal.default.createTrackedDialog('Failed to invite', '', _ErrorDialog.default, {
title: (0, _languageHandler._t)("Failed to invite"),
description: e && e.message ? e.message : (0, _languageHandler._t)("Operation failed")
});
}
});
(0, _defineProperty2.default)(this, "onAddressChange", (ev
/*: ChangeEvent<HTMLInputElement>*/
, index
/*: number*/
) => {
const targets = (0, _arrays.arrayFastClone)(this.state.emailTargets);
if (index >= targets.length) {
targets.push(ev.target.value);
} else {
targets[index] = ev.target.value;
}
this.setState({
emailTargets: targets
});
});
(0, _defineProperty2.default)(this, "onAddressBlur", (index
/*: number*/
) => {
const targets = (0, _arrays.arrayFastClone)(this.state.emailTargets);
if (index >= targets.length) return; // not important
if (targets[index].trim() === "") {
targets.splice(index, 1);
this.setState({
emailTargets: targets
});
}
});
(0, _defineProperty2.default)(this, "onShowPeopleClick", () => {
this.setState({
showPeople: !this.state.showPeople
});
});
(0, _defineProperty2.default)(this, "setPersonToggle", (person
/*: IPerson*/
, selected
/*: boolean*/
) => {
const targets = (0, _arrays.arrayFastClone)(this.state.userTargets);
if (selected && !targets.includes(person.userId)) {
targets.push(person.userId);
} else if (!selected && targets.includes(person.userId)) {
targets.splice(targets.indexOf(person.userId), 1);
}
this.setState({
userTargets: targets
});
});
(0, _defineProperty2.default)(this, "onShowMorePeople", () => {
this.setState({
numPeople: this.state.numPeople + 5
}); // arbitrary increase
});
this.state = {
emailTargets: [],
userTargets: [],
showPeople: false,
people: this.buildSuggestions(),
numPeople: 5,
// arbitrary default
busy: false
};
}
buildSuggestions()
/*: IPerson[]*/
{
const alreadyInvited = new Set([_MatrixClientPeg.MatrixClientPeg.get().getUserId(), _SdkConfig.default.get()['welcomeUserId']]);
if (this.props.roomId) {
const room = _MatrixClientPeg.MatrixClientPeg.get().getRoom(this.props.roomId);
if (!room) throw new Error("Room ID given to InviteDialog does not look like a room");
room.getMembersWithMembership('invite').forEach(m => alreadyInvited.add(m.userId));
room.getMembersWithMembership('join').forEach(m => alreadyInvited.add(m.userId)); // add banned users, so we don't try to invite them
room.getMembersWithMembership('ban').forEach(m => alreadyInvited.add(m.userId));
}
return _InviteDialog.default.buildRecents(alreadyInvited);
}
renderPerson(person
/*: IPerson*/
, key
/*: any*/
) {
const avatarSize = 36;
let avatarUrl = null;
if (person.user.getMxcAvatarUrl()) {
avatarUrl = (0, _Media.mediaFromMxc)(person.user.getMxcAvatarUrl()).getSquareThumbnailHttp(avatarSize);
}
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_CommunityPrototypeInviteDialog_person",
key: key
}, /*#__PURE__*/_react.default.createElement(_BaseAvatar.default, {
url: avatarUrl,
name: person.user.name,
idName: person.user.userId,
width: avatarSize,
height: avatarSize
}), /*#__PURE__*/_react.default.createElement("div", {
className: "mx_CommunityPrototypeInviteDialog_personIdentifiers"
}, /*#__PURE__*/_react.default.createElement("span", {
className: "mx_CommunityPrototypeInviteDialog_personName"
}, person.user.name), /*#__PURE__*/_react.default.createElement("span", {
className: "mx_CommunityPrototypeInviteDialog_personId"
}, person.userId)), /*#__PURE__*/_react.default.createElement(_StyledCheckbox.default, {
onChange: e => this.setPersonToggle(person, e.target.checked)
}));
}
render() {
const emailAddresses = [];
this.state.emailTargets.forEach((address, i) => {
emailAddresses.push( /*#__PURE__*/_react.default.createElement(_Field.default, {
key: i,
value: address,
onChange: e => this.onAddressChange(e, i),
label: (0, _languageHandler._t)("Email address"),
placeholder: (0, _languageHandler._t)("Email address"),
onBlur: () => this.onAddressBlur(i)
}));
}); // Push a clean input
emailAddresses.push( /*#__PURE__*/_react.default.createElement(_Field.default, {
key: emailAddresses.length,
value: "",
onChange: e => this.onAddressChange(e, emailAddresses.length),
label: emailAddresses.length > 0 ? (0, _languageHandler._t)("Add another email") : (0, _languageHandler._t)("Email address"),
placeholder: emailAddresses.length > 0 ? (0, _languageHandler._t)("Add another email") : (0, _languageHandler._t)("Email address")
}));
let peopleIntro = null;
const people = [];
if (this.state.showPeople) {
const humansToPresent = this.state.people.slice(0, this.state.numPeople);
humansToPresent.forEach((person, i) => {
people.push(this.renderPerson(person, i));
});
if (humansToPresent.length < this.state.people.length) {
people.push( /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
onClick: this.onShowMorePeople,
kind: "link",
key: "more",
className: "mx_CommunityPrototypeInviteDialog_morePeople"
}, (0, _languageHandler._t)("Show more")));
}
}
if (this.state.people.length > 0) {
peopleIntro = /*#__PURE__*/_react.default.createElement("div", {
className: "mx_CommunityPrototypeInviteDialog_people"
}, /*#__PURE__*/_react.default.createElement("span", null, (0, _languageHandler._t)("People you know on %(brand)s", {
brand: _SdkConfig.default.get().brand
})), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
onClick: this.onShowPeopleClick
}, this.state.showPeople ? (0, _languageHandler._t)("Hide") : (0, _languageHandler._t)("Show")));
}
let buttonText = (0, _languageHandler._t)("Skip");
const targetCount = this.state.userTargets.length + this.state.emailTargets.length;
if (targetCount > 0) {
buttonText = (0, _languageHandler._t)("Send %(count)s invites", {
count: targetCount
});
}
return /*#__PURE__*/_react.default.createElement(_BaseDialog.default, {
className: "mx_CommunityPrototypeInviteDialog",
onFinished: this.props.onFinished,
title: (0, _languageHandler._t)("Invite people to join %(communityName)s", {
communityName: this.props.communityName
})
}, /*#__PURE__*/_react.default.createElement("form", {
onSubmit: this.onSubmit
}, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_Dialog_content"
}, emailAddresses, peopleIntro, people, /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
kind: "primary",
onClick: this.onSubmit,
disabled: this.state.busy,
className: "mx_CommunityPrototypeInviteDialog_primaryButton"
}, buttonText))));
}
}, _temp)) || _class);
exports.default = CommunityPrototypeInviteDialog;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/dialogs/CommunityPrototypeInviteDialog.tsx"],"names":["CommunityPrototypeInviteDialog","React","PureComponent","constructor","props","ev","preventDefault","stopPropagation","setState","busy","targets","state","emailTargets","userTargets","result","roomId","room","MatrixClientPeg","get","getRoom","success","states","inviter","onFinished","e","console","error","Modal","createTrackedDialog","ErrorDialog","title","description","message","index","length","push","target","value","trim","splice","showPeople","person","selected","includes","userId","indexOf","numPeople","people","buildSuggestions","alreadyInvited","Set","getUserId","SdkConfig","Error","getMembersWithMembership","forEach","m","add","InviteDialog","buildRecents","renderPerson","key","avatarSize","avatarUrl","user","getMxcAvatarUrl","getSquareThumbnailHttp","name","setPersonToggle","checked","render","emailAddresses","address","i","onAddressChange","onAddressBlur","peopleIntro","humansToPresent","slice","onShowMorePeople","brand","onShowPeopleClick","buttonText","targetCount","count","communityName","onSubmit"],"mappings":"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","sourcesContent":["/*\nCopyright 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, { ChangeEvent, FormEvent } from 'react';\nimport BaseDialog from \"./BaseDialog\";\nimport { _t } from \"../../../languageHandler\";\nimport { IDialogProps } from \"./IDialogProps\";\nimport Field from \"../elements/Field\";\nimport AccessibleButton from \"../elements/AccessibleButton\";\nimport { MatrixClientPeg } from \"../../../MatrixClientPeg\";\nimport { arrayFastClone } from \"../../../utils/arrays\";\nimport SdkConfig from \"../../../SdkConfig\";\nimport { RoomMember } from \"matrix-js-sdk/src/models/room-member\";\nimport InviteDialog from \"./InviteDialog\";\nimport BaseAvatar from \"../avatars/BaseAvatar\";\nimport {inviteMultipleToRoom, showAnyInviteErrors} from \"../../../RoomInvite\";\nimport StyledCheckbox from \"../elements/StyledCheckbox\";\nimport Modal from \"../../../Modal\";\nimport ErrorDialog from \"./ErrorDialog\";\nimport {replaceableComponent} from \"../../../utils/replaceableComponent\";\nimport {mediaFromMxc} from \"../../../customisations/Media\";\n\ninterface IProps extends IDialogProps {\n    roomId: string;\n    communityName: string;\n}\n\ninterface IPerson {\n    userId: string;\n    user: RoomMember;\n    lastActive: number;\n}\n\ninterface IState {\n    emailTargets: string[];\n    userTargets: string[];\n    showPeople: boolean;\n    people: IPerson[];\n    numPeople: number;\n    busy: boolean;\n}\n\n@replaceableComponent(\"views.dialogs.CommunityPrototypeInviteDialog\")\nexport default class CommunityPrototypeInviteDialog extends React.PureComponent<IProps, IState> {\n    constructor(props: IProps) {\n        super(props);\n\n        this.state = {\n            emailTargets: [],\n            userTargets: [],\n            showPeople: false,\n            people: this.buildSuggestions(),\n            numPeople: 5, // arbitrary default\n            busy: false,\n        };\n    }\n\n    private buildSuggestions(): IPerson[] {\n        const alreadyInvited = new Set([MatrixClientPeg.get().getUserId(), SdkConfig.get()['welcomeUserId']]);\n        if (this.props.roomId) {\n            const room = MatrixClientPeg.get().getRoom(this.props.roomId);\n            if (!room) throw new Error(\"Room ID given to InviteDialog does not look like a room\");\n            room.getMembersWithMembership('invite').forEach(m => alreadyInvited.add(m.userId));\n            room.getMembersWithMembership('join').forEach(m => alreadyInvited.add(m.userId));\n            // add banned users, so we don't try to invite them\n            room.getMembersWithMembership('ban').forEach(m => alreadyInvited.add(m.userId));\n        }\n\n        return InviteDialog.buildRecents(alreadyInvited);\n    }\n\n    private onSubmit = async (ev: FormEvent) => {\n        ev.preventDefault();\n        ev.stopPropagation();\n\n        this.setState({busy: true});\n        try {\n            const targets = [...this.state.emailTargets, ...this.state.userTargets];\n            const result = await inviteMultipleToRoom(this.props.roomId, targets);\n            const room = MatrixClientPeg.get().getRoom(this.props.roomId);\n            const success = showAnyInviteErrors(result.states, room, result.inviter);\n            if (success) {\n                this.props.onFinished(true);\n            } else {\n                this.setState({busy: false});\n            }\n        } catch (e) {\n            this.setState({busy: false});\n            console.error(e);\n            Modal.createTrackedDialog('Failed to invite', '', ErrorDialog, {\n                title: _t(\"Failed to invite\"),\n                description: ((e && e.message) ? e.message : _t(\"Operation failed\")),\n            });\n        }\n    };\n\n    private onAddressChange = (ev: ChangeEvent<HTMLInputElement>, index: number) => {\n        const targets = arrayFastClone(this.state.emailTargets);\n        if (index >= targets.length) {\n            targets.push(ev.target.value);\n        } else {\n            targets[index] = ev.target.value;\n        }\n        this.setState({emailTargets: targets});\n    };\n\n    private onAddressBlur = (index: number) => {\n        const targets = arrayFastClone(this.state.emailTargets);\n        if (index >= targets.length) return; // not important\n        if (targets[index].trim() === \"\") {\n            targets.splice(index, 1);\n            this.setState({emailTargets: targets});\n        }\n    };\n\n    private onShowPeopleClick = () => {\n        this.setState({showPeople: !this.state.showPeople});\n    };\n\n    private setPersonToggle = (person: IPerson, selected: boolean) => {\n        const targets = arrayFastClone(this.state.userTargets);\n        if (selected && !targets.includes(person.userId)) {\n            targets.push(person.userId);\n        } else if (!selected && targets.includes(person.userId)) {\n            targets.splice(targets.indexOf(person.userId), 1);\n        }\n        this.setState({userTargets: targets});\n    };\n\n    private renderPerson(person: IPerson, key: any) {\n        const avatarSize = 36;\n        let avatarUrl = null;\n        if (person.user.getMxcAvatarUrl()) {\n            avatarUrl = mediaFromMxc(person.user.getMxcAvatarUrl()).getSquareThumbnailHttp(avatarSize);\n        }\n        return (\n            <div className=\"mx_CommunityPrototypeInviteDialog_person\" key={key}>\n                <BaseAvatar\n                    url={avatarUrl}\n                    name={person.user.name}\n                    idName={person.user.userId}\n                    width={avatarSize}\n                    height={avatarSize}\n                />\n                <div className=\"mx_CommunityPrototypeInviteDialog_personIdentifiers\">\n                    <span className=\"mx_CommunityPrototypeInviteDialog_personName\">{person.user.name}</span>\n                    <span className=\"mx_CommunityPrototypeInviteDialog_personId\">{person.userId}</span>\n                </div>\n                <StyledCheckbox onChange={(e) => this.setPersonToggle(person, e.target.checked)} />\n            </div>\n        );\n    }\n\n    private onShowMorePeople = () => {\n        this.setState({numPeople: this.state.numPeople + 5}); // arbitrary increase\n    };\n\n    public render() {\n        const emailAddresses = [];\n        this.state.emailTargets.forEach((address, i) => {\n            emailAddresses.push((\n                <Field\n                    key={i}\n                    value={address}\n                    onChange={(e) => this.onAddressChange(e, i)}\n                    label={_t(\"Email address\")}\n                    placeholder={_t(\"Email address\")}\n                    onBlur={() => this.onAddressBlur(i)}\n                />\n            ));\n        });\n\n        // Push a clean input\n        emailAddresses.push((\n            <Field\n                key={emailAddresses.length}\n                value={\"\"}\n                onChange={(e) => this.onAddressChange(e, emailAddresses.length)}\n                label={emailAddresses.length > 0 ? _t(\"Add another email\") : _t(\"Email address\")}\n                placeholder={emailAddresses.length > 0 ? _t(\"Add another email\") : _t(\"Email address\")}\n            />\n        ));\n\n        let peopleIntro = null;\n        const people = [];\n        if (this.state.showPeople) {\n            const humansToPresent = this.state.people.slice(0, this.state.numPeople);\n            humansToPresent.forEach((person, i) => {\n                people.push(this.renderPerson(person, i));\n            });\n            if (humansToPresent.length < this.state.people.length) {\n                people.push((\n                    <AccessibleButton\n                        onClick={this.onShowMorePeople}\n                        kind=\"link\" key=\"more\"\n                        className=\"mx_CommunityPrototypeInviteDialog_morePeople\"\n                    >{_t(\"Show more\")}</AccessibleButton>\n                ));\n            }\n        }\n        if (this.state.people.length > 0) {\n            peopleIntro = (\n                <div className=\"mx_CommunityPrototypeInviteDialog_people\">\n                    <span>{_t(\"People you know on %(brand)s\", {brand: SdkConfig.get().brand})}</span>\n                    <AccessibleButton onClick={this.onShowPeopleClick}>\n                        {this.state.showPeople ? _t(\"Hide\") : _t(\"Show\")}\n                    </AccessibleButton>\n                </div>\n            );\n        }\n\n        let buttonText = _t(\"Skip\");\n        const targetCount = this.state.userTargets.length + this.state.emailTargets.length;\n        if (targetCount > 0) {\n            buttonText = _t(\"Send %(count)s invites\", {count: targetCount});\n        }\n\n        return (\n            <BaseDialog\n                className=\"mx_CommunityPrototypeInviteDialog\"\n                onFinished={this.props.onFinished}\n                title={_t(\"Invite people to join %(communityName)s\", {communityName: this.props.communityName})}\n            >\n                <form onSubmit={this.onSubmit}>\n                    <div className=\"mx_Dialog_content\">\n                        {emailAddresses}\n                        {peopleIntro}\n                        {people}\n                        <AccessibleButton\n                            kind=\"primary\" onClick={this.onSubmit}\n                            disabled={this.state.busy}\n                            className=\"mx_CommunityPrototypeInviteDialog_primaryButton\"\n                        >{buttonText}</AccessibleButton>\n                    </div>\n                </form>\n            </BaseDialog>\n        );\n    }\n}\n"]}