matrix-react-sdk
Version:
SDK for matrix.org using React
75 lines (72 loc) • 13.3 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _react = _interopRequireWildcard(require("react"));
var _QuestionDialog = _interopRequireDefault(require("./QuestionDialog"));
var _languageHandler = require("../../../languageHandler");
var _Field = _interopRequireDefault(require("../elements/Field"));
var _submitRageshake = require("../../../rageshake/submit-rageshake");
var _StyledCheckbox = _interopRequireDefault(require("../elements/StyledCheckbox"));
var _Modal = _interopRequireDefault(require("../../../Modal"));
var _InfoDialog = _interopRequireDefault(require("./InfoDialog"));
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
/*
Copyright 2024 New Vector Ltd.
Copyright 2021 The Matrix.org Foundation C.I.C.
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only
Please see LICENSE files in the repository root for full details.
*/
const GenericFeatureFeedbackDialog = ({
title,
subheading,
children,
rageshakeLabel,
rageshakeData = {},
onFinished
}) => {
const [comment, setComment] = (0, _react.useState)("");
const [canContact, setCanContact] = (0, _react.useState)(false);
const sendFeedback = async ok => {
if (!ok) return onFinished(false);
(0, _submitRageshake.submitFeedback)(rageshakeLabel, comment, canContact, rageshakeData);
onFinished(true);
_Modal.default.createDialog(_InfoDialog.default, {
title,
description: (0, _languageHandler._t)("feedback|sent"),
button: (0, _languageHandler._t)("action|close"),
hasCloseButton: false,
fixedWidth: false
});
};
return /*#__PURE__*/_react.default.createElement(_QuestionDialog.default, {
className: "mx_GenericFeatureFeedbackDialog",
hasCancelButton: true,
title: title,
description: /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_GenericFeatureFeedbackDialog_subheading"
}, subheading, "\xA0", (0, _languageHandler._t)("feedback|platform_username"), "\xA0", children), /*#__PURE__*/_react.default.createElement(_Field.default, {
id: "feedbackComment",
label: (0, _languageHandler._t)("common|feedback"),
type: "text",
autoComplete: "off",
value: comment,
element: "textarea",
onChange: ev => {
setComment(ev.target.value);
},
autoFocus: true
}), /*#__PURE__*/_react.default.createElement(_StyledCheckbox.default, {
checked: canContact,
onChange: e => setCanContact(e.target.checked)
}, (0, _languageHandler._t)("feedback|can_contact_label"))),
button: (0, _languageHandler._t)("feedback|send_feedback_action"),
buttonDisabled: !comment,
onFinished: sendFeedback
});
};
var _default = exports.default = GenericFeatureFeedbackDialog;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_QuestionDialog","_interopRequireDefault","_languageHandler","_Field","_submitRageshake","_StyledCheckbox","_Modal","_InfoDialog","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","GenericFeatureFeedbackDialog","title","subheading","children","rageshakeLabel","rageshakeData","onFinished","comment","setComment","useState","canContact","setCanContact","sendFeedback","ok","submitFeedback","Modal","createDialog","InfoDialog","description","_t","button","hasCloseButton","fixedWidth","createElement","className","hasCancelButton","Fragment","id","label","type","autoComplete","value","element","onChange","ev","target","autoFocus","checked","buttonDisabled","_default","exports"],"sources":["../../../../src/components/views/dialogs/GenericFeatureFeedbackDialog.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2021 The Matrix.org Foundation C.I.C.\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, { ReactNode, useState } from \"react\";\n\nimport QuestionDialog from \"./QuestionDialog\";\nimport { _t } from \"../../../languageHandler\";\nimport Field from \"../elements/Field\";\nimport { submitFeedback } from \"../../../rageshake/submit-rageshake\";\nimport StyledCheckbox from \"../elements/StyledCheckbox\";\nimport Modal from \"../../../Modal\";\nimport InfoDialog from \"./InfoDialog\";\n\ninterface IProps {\n    title: string;\n    subheading?: string;\n    rageshakeLabel?: string;\n    rageshakeData?: Record<string, any>;\n    children?: ReactNode;\n    onFinished(sendFeedback?: boolean): void;\n}\n\nconst GenericFeatureFeedbackDialog: React.FC<IProps> = ({\n    title,\n    subheading,\n    children,\n    rageshakeLabel,\n    rageshakeData = {},\n    onFinished,\n}) => {\n    const [comment, setComment] = useState(\"\");\n    const [canContact, setCanContact] = useState(false);\n\n    const sendFeedback = async (ok: boolean): Promise<void> => {\n        if (!ok) return onFinished(false);\n\n        submitFeedback(rageshakeLabel, comment, canContact, rageshakeData);\n        onFinished(true);\n\n        Modal.createDialog(InfoDialog, {\n            title,\n            description: _t(\"feedback|sent\"),\n            button: _t(\"action|close\"),\n            hasCloseButton: false,\n            fixedWidth: false,\n        });\n    };\n\n    return (\n        <QuestionDialog\n            className=\"mx_GenericFeatureFeedbackDialog\"\n            hasCancelButton={true}\n            title={title}\n            description={\n                <React.Fragment>\n                    <div className=\"mx_GenericFeatureFeedbackDialog_subheading\">\n                        {subheading}\n                        &nbsp;\n                        {_t(\"feedback|platform_username\")}\n                        &nbsp;\n                        {children}\n                    </div>\n\n                    <Field\n                        id=\"feedbackComment\"\n                        label={_t(\"common|feedback\")}\n                        type=\"text\"\n                        autoComplete=\"off\"\n                        value={comment}\n                        element=\"textarea\"\n                        onChange={(ev) => {\n                            setComment(ev.target.value);\n                        }}\n                        autoFocus={true}\n                    />\n\n                    <StyledCheckbox\n                        checked={canContact}\n                        onChange={(e) => setCanContact((e.target as HTMLInputElement).checked)}\n                    >\n                        {_t(\"feedback|can_contact_label\")}\n                    </StyledCheckbox>\n                </React.Fragment>\n            }\n            button={_t(\"feedback|send_feedback_action\")}\n            buttonDisabled={!comment}\n            onFinished={sendFeedback}\n        />\n    );\n};\n\nexport default GenericFeatureFeedbackDialog;\n"],"mappings":"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","ignoreList":[]}