UNPKG

matrix-react-sdk

Version:
107 lines (104 loc) 15.9 kB
"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":[]}