matrix-react-sdk
Version:
SDK for matrix.org using React
123 lines (96 loc) • 13.6 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 _react = _interopRequireWildcard(require("react"));
var _QuestionDialog = _interopRequireDefault(require("./QuestionDialog"));
var _languageHandler = require("../../../languageHandler");
var _Field = _interopRequireDefault(require("../elements/Field"));
var _SdkConfig = _interopRequireDefault(require("../../../SdkConfig"));
var _SettingsStore = _interopRequireDefault(require("../../../settings/SettingsStore"));
var _submitRageshake = require("../../../rageshake/submit-rageshake");
var _StyledCheckbox = _interopRequireDefault(require("../elements/StyledCheckbox"));
var _Modal = _interopRequireDefault(require("../../../Modal"));
var _InfoDialog = _interopRequireDefault(require("./InfoDialog"));
var _AccessibleButton = _interopRequireDefault(require("../elements/AccessibleButton"));
var _dispatcher = _interopRequireDefault(require("../../../dispatcher/dispatcher"));
var _actions = require("../../../dispatcher/actions");
var _UserSettingsDialog = require("./UserSettingsDialog");
/*
Copyright 2021 The Matrix.org Foundation C.I.C.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
const BetaFeedbackDialog
/*: React.FC<IProps>*/
= ({
featureId,
onFinished
}) => {
const info = _SettingsStore.default.getBetaInfo(featureId);
const [comment, setComment] = (0, _react.useState)("");
const [canContact, setCanContact] = (0, _react.useState)(false);
const sendFeedback = async (ok
/*: boolean*/
) => {
if (!ok) return onFinished(false);
(0, _submitRageshake.submitFeedback)(_SdkConfig.default.get().bug_report_endpoint_url, info.feedbackLabel, comment, canContact);
onFinished(true);
_Modal.default.createTrackedDialog("Beta Dialog Sent", featureId, _InfoDialog.default, {
title: (0, _languageHandler._t)("Beta feedback"),
description: (0, _languageHandler._t)("Thank you for your feedback, we really appreciate it."),
button: (0, _languageHandler._t)("Done"),
hasCloseButton: false,
fixedWidth: false
});
};
return /*#__PURE__*/_react.default.createElement(_QuestionDialog.default, {
className: "mx_BetaFeedbackDialog",
hasCancelButton: true,
title: (0, _languageHandler._t)("%(featureName)s beta feedback", {
featureName: info.title
}),
description: /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_BetaFeedbackDialog_subheading"
}, (0, _languageHandler._t)(info.feedbackSubheading), "\xA0", (0, _languageHandler._t)("Your platform and username will be noted to help us use your feedback as much as we can."), /*#__PURE__*/_react.default.createElement(_AccessibleButton.default, {
kind: "link",
onClick: () => {
onFinished(false);
_dispatcher.default.dispatch({
action: _actions.Action.ViewUserSettings,
initialTabId: _UserSettingsDialog.USER_LABS_TAB
});
}
}, (0, _languageHandler._t)("To leave the beta, visit your settings."))), /*#__PURE__*/_react.default.createElement(_Field.default, {
id: "feedbackComment",
label: (0, _languageHandler._t)("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,
onClick: e => setCanContact(e.target.checked)
}, (0, _languageHandler._t)("You may contact me if you have any follow up questions"))),
button: (0, _languageHandler._t)("Send feedback"),
buttonDisabled: !comment,
onFinished: sendFeedback
});
};
var _default = BetaFeedbackDialog;
exports.default = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/views/dialogs/BetaFeedbackDialog.tsx"],"names":["BetaFeedbackDialog","featureId","onFinished","info","SettingsStore","getBetaInfo","comment","setComment","canContact","setCanContact","sendFeedback","ok","SdkConfig","get","bug_report_endpoint_url","feedbackLabel","Modal","createTrackedDialog","InfoDialog","title","description","button","hasCloseButton","fixedWidth","featureName","feedbackSubheading","defaultDispatcher","dispatch","action","Action","ViewUserSettings","initialTabId","USER_LABS_TAB","ev","target","value","e","checked"],"mappings":"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","sourcesContent":["/*\nCopyright 2021 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, {useState} from \"react\";\n\nimport QuestionDialog from './QuestionDialog';\nimport { _t } from '../../../languageHandler';\nimport Field from \"../elements/Field\";\nimport SdkConfig from \"../../../SdkConfig\";\nimport {IDialogProps} from \"./IDialogProps\";\nimport SettingsStore from \"../../../settings/SettingsStore\";\nimport {submitFeedback} from \"../../../rageshake/submit-rageshake\";\nimport StyledCheckbox from \"../elements/StyledCheckbox\";\nimport Modal from \"../../../Modal\";\nimport InfoDialog from \"./InfoDialog\";\nimport AccessibleButton from \"../elements/AccessibleButton\";\nimport defaultDispatcher from \"../../../dispatcher/dispatcher\";\nimport {Action} from \"../../../dispatcher/actions\";\nimport {USER_LABS_TAB} from \"./UserSettingsDialog\";\n\ninterface IProps extends IDialogProps {\n    featureId: string;\n}\n\nconst BetaFeedbackDialog: React.FC<IProps> = ({featureId, onFinished}) => {\n    const info = SettingsStore.getBetaInfo(featureId);\n\n    const [comment, setComment] = useState(\"\");\n    const [canContact, setCanContact] = useState(false);\n\n    const sendFeedback = async (ok: boolean) => {\n        if (!ok) return onFinished(false);\n\n        submitFeedback(SdkConfig.get().bug_report_endpoint_url, info.feedbackLabel, comment, canContact);\n        onFinished(true);\n\n        Modal.createTrackedDialog(\"Beta Dialog Sent\", featureId, InfoDialog, {\n            title: _t(\"Beta feedback\"),\n            description: _t(\"Thank you for your feedback, we really appreciate it.\"),\n            button: _t(\"Done\"),\n            hasCloseButton: false,\n            fixedWidth: false,\n        });\n    };\n\n    return (<QuestionDialog\n        className=\"mx_BetaFeedbackDialog\"\n        hasCancelButton={true}\n        title={_t(\"%(featureName)s beta feedback\", { featureName: info.title })}\n        description={<React.Fragment>\n            <div className=\"mx_BetaFeedbackDialog_subheading\">\n                { _t(info.feedbackSubheading) }\n                &nbsp;\n                { _t(\"Your platform and username will be noted to help us use your feedback as much as we can.\")}\n\n                <AccessibleButton kind=\"link\" onClick={() => {\n                    onFinished(false);\n                    defaultDispatcher.dispatch({\n                        action: Action.ViewUserSettings,\n                        initialTabId: USER_LABS_TAB,\n                    });\n                }}>\n                    { _t(\"To leave the beta, visit your settings.\") }\n                </AccessibleButton>\n            </div>\n\n            <Field\n                id=\"feedbackComment\"\n                label={_t(\"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                onClick={e => setCanContact((e.target as HTMLInputElement).checked)}\n            >\n                { _t(\"You may contact me if you have any follow up questions\") }\n            </StyledCheckbox>\n        </React.Fragment>}\n        button={_t(\"Send feedback\")}\n        buttonDisabled={!comment}\n        onFinished={sendFeedback}\n    />);\n};\n\nexport default BetaFeedbackDialog;\n"]}