matrix-react-sdk
Version:
SDK for matrix.org using React
107 lines (104 loc) • 15.9 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 _classnames = _interopRequireDefault(require("classnames"));
var _languageHandler = require("../../../languageHandler");
var _MemberAvatar = _interopRequireDefault(require("../avatars/MemberAvatar"));
var _BaseDialog = _interopRequireDefault(require("./BaseDialog"));
var _DialogButtons = _interopRequireDefault(require("../elements/DialogButtons"));
var _Field = _interopRequireDefault(require("../elements/Field"));
var _UserIdentifier = _interopRequireDefault(require("../../../customisations/UserIdentifier"));
/*
Copyright 2024 New Vector Ltd.
Copyright 2017 Vector Creations Ltd
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only
Please see LICENSE files in the repository root for full details.
*/
/*
* A dialog for confirming an operation on another user.
* Takes a user ID and a verb, displays the target user prominently
* such that it should be easy to confirm that the operation is being
* performed on the right person, and displays the operation prominently
* to make it obvious what is going to happen.
* Also tweaks the style for 'dangerous' actions (albeit only with colour)
*/
class ConfirmUserActionDialog extends _react.default.Component {
constructor(props) {
super(props);
(0, _defineProperty2.default)(this, "onOk", ev => {
ev.preventDefault();
this.props.onFinished(true, this.state.reason);
});
(0, _defineProperty2.default)(this, "onCancel", () => {
this.props.onFinished(false);
});
(0, _defineProperty2.default)(this, "onReasonChange", ev => {
this.setState({
reason: ev.target.value
});
});
this.state = {
reason: ""
};
}
render() {
const confirmButtonClass = this.props.danger ? "danger" : "";
let reasonBox;
if (this.props.askReason) {
reasonBox = /*#__PURE__*/_react.default.createElement("form", {
onSubmit: this.onOk
}, /*#__PURE__*/_react.default.createElement(_Field.default, {
type: "text",
onChange: this.onReasonChange,
value: this.state.reason,
className: "mx_ConfirmUserActionDialog_reasonField",
label: (0, _languageHandler._t)("room_settings|permissions|ban_reason"),
autoFocus: true
}));
}
const avatar = /*#__PURE__*/_react.default.createElement(_MemberAvatar.default, {
member: this.props.member,
size: "48px"
});
const name = this.props.member.name;
const userId = this.props.member.userId;
const displayUserIdentifier = _UserIdentifier.default.getDisplayUserIdentifier(userId, {
roomId: this.props.roomId,
withDisplayName: true
});
return /*#__PURE__*/_react.default.createElement(_BaseDialog.default, {
className: (0, _classnames.default)("mx_ConfirmUserActionDialog", this.props.className),
onFinished: this.props.onFinished,
title: this.props.title,
contentId: "mx_Dialog_content"
}, /*#__PURE__*/_react.default.createElement("div", {
id: "mx_Dialog_content",
className: "mx_Dialog_content"
}, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_ConfirmUserActionDialog_user"
}, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_ConfirmUserActionDialog_avatar"
}, avatar), /*#__PURE__*/_react.default.createElement("div", {
className: "mx_ConfirmUserActionDialog_name"
}, name), /*#__PURE__*/_react.default.createElement("div", {
className: "mx_ConfirmUserActionDialog_userId"
}, displayUserIdentifier)), reasonBox, this.props.children), /*#__PURE__*/_react.default.createElement(_DialogButtons.default, {
primaryButton: this.props.action,
onPrimaryButtonClick: this.onOk,
primaryButtonClass: confirmButtonClass,
focus: !this.props.askReason,
onCancel: this.onCancel
}));
}
}
exports.default = ConfirmUserActionDialog;
(0, _defineProperty2.default)(ConfirmUserActionDialog, "defaultProps", {
danger: false,
askReason: false
});
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_classnames","_languageHandler","_MemberAvatar","_BaseDialog","_DialogButtons","_Field","_UserIdentifier","ConfirmUserActionDialog","React","Component","constructor","props","_defineProperty2","default","ev","preventDefault","onFinished","state","reason","setState","target","value","render","confirmButtonClass","danger","reasonBox","askReason","createElement","onSubmit","onOk","type","onChange","onReasonChange","className","label","_t","autoFocus","avatar","member","size","name","userId","displayUserIdentifier","UserIdentifierCustomisations","getDisplayUserIdentifier","roomId","withDisplayName","classNames","title","contentId","id","children","primaryButton","action","onPrimaryButtonClick","primaryButtonClass","focus","onCancel","exports"],"sources":["../../../../src/components/views/dialogs/ConfirmUserActionDialog.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2017 Vector Creations 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, { ChangeEvent, FormEvent, ReactNode } from \"react\";\nimport { RoomMember } from \"matrix-js-sdk/src/matrix\";\nimport classNames from \"classnames\";\n\nimport { _t } from \"../../../languageHandler\";\nimport MemberAvatar from \"../avatars/MemberAvatar\";\nimport BaseDialog from \"./BaseDialog\";\nimport DialogButtons from \"../elements/DialogButtons\";\nimport Field from \"../elements/Field\";\nimport UserIdentifierCustomisations from \"../../../customisations/UserIdentifier\";\n\ninterface IProps {\n    // matrix-js-sdk (room) member object.\n    member: RoomMember;\n    action: string; // eg. 'Ban'\n    title: string; // eg. 'Ban this user?'\n\n    // Whether to display a text field for a reason\n    // If true, the second argument to onFinished will\n    // be the string entered.\n    askReason?: boolean;\n    danger?: boolean;\n    children?: ReactNode;\n    className?: string;\n    roomId?: string;\n    onFinished: (success?: boolean, reason?: string) => void;\n}\n\ninterface IState {\n    reason: string;\n}\n\n/*\n * A dialog for confirming an operation on another user.\n * Takes a user ID and a verb, displays the target user prominently\n * such that it should be easy to confirm that the operation is being\n * performed on the right person, and displays the operation prominently\n * to make it obvious what is going to happen.\n * Also tweaks the style for 'dangerous' actions (albeit only with colour)\n */\nexport default class ConfirmUserActionDialog extends React.Component<IProps, IState> {\n    public static defaultProps: Partial<IProps> = {\n        danger: false,\n        askReason: false,\n    };\n\n    public constructor(props: IProps) {\n        super(props);\n\n        this.state = {\n            reason: \"\",\n        };\n    }\n\n    private onOk = (ev: FormEvent): void => {\n        ev.preventDefault();\n        this.props.onFinished(true, this.state.reason);\n    };\n\n    private onCancel = (): void => {\n        this.props.onFinished(false);\n    };\n\n    private onReasonChange = (ev: ChangeEvent<HTMLInputElement>): void => {\n        this.setState({\n            reason: ev.target.value,\n        });\n    };\n\n    public render(): React.ReactNode {\n        const confirmButtonClass = this.props.danger ? \"danger\" : \"\";\n\n        let reasonBox;\n        if (this.props.askReason) {\n            reasonBox = (\n                <form onSubmit={this.onOk}>\n                    <Field\n                        type=\"text\"\n                        onChange={this.onReasonChange}\n                        value={this.state.reason}\n                        className=\"mx_ConfirmUserActionDialog_reasonField\"\n                        label={_t(\"room_settings|permissions|ban_reason\")}\n                        autoFocus={true}\n                    />\n                </form>\n            );\n        }\n\n        const avatar = <MemberAvatar member={this.props.member} size=\"48px\" />;\n        const name = this.props.member.name;\n        const userId = this.props.member.userId;\n\n        const displayUserIdentifier = UserIdentifierCustomisations.getDisplayUserIdentifier(userId, {\n            roomId: this.props.roomId,\n            withDisplayName: true,\n        });\n\n        return (\n            <BaseDialog\n                className={classNames(\"mx_ConfirmUserActionDialog\", this.props.className)}\n                onFinished={this.props.onFinished}\n                title={this.props.title}\n                contentId=\"mx_Dialog_content\"\n            >\n                <div id=\"mx_Dialog_content\" className=\"mx_Dialog_content\">\n                    <div className=\"mx_ConfirmUserActionDialog_user\">\n                        <div className=\"mx_ConfirmUserActionDialog_avatar\">{avatar}</div>\n                        <div className=\"mx_ConfirmUserActionDialog_name\">{name}</div>\n                        <div className=\"mx_ConfirmUserActionDialog_userId\">{displayUserIdentifier}</div>\n                    </div>\n\n                    {reasonBox}\n                    {this.props.children}\n                </div>\n                <DialogButtons\n                    primaryButton={this.props.action}\n                    onPrimaryButtonClick={this.onOk}\n                    primaryButtonClass={confirmButtonClass}\n                    focus={!this.props.askReason}\n                    onCancel={this.onCancel}\n                />\n            </BaseDialog>\n        );\n    }\n}\n"],"mappings":"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","ignoreList":[]}