matrix-react-sdk
Version:
SDK for matrix.org using React
63 lines (60 loc) • 13.6 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.ModuleUiDialog = void 0;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireWildcard(require("react"));
var _logger = require("matrix-js-sdk/src/logger");
var _ScrollableBaseModal = _interopRequireDefault(require("./ScrollableBaseModal"));
var _languageHandler = require("../../../languageHandler");
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; }
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2.default)(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } /*
Copyright 2024 New Vector Ltd.
Copyright 2022 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.
*/
class ModuleUiDialog extends _ScrollableBaseModal.default {
constructor(props) {
super(props);
(0, _defineProperty2.default)(this, "contentRef", /*#__PURE__*/(0, _react.createRef)());
this.state = {
title: this.props.initialOptions.title,
actionLabel: this.props.initialOptions.actionLabel ?? (0, _languageHandler._t)("action|ok"),
cancelLabel: this.props.initialOptions.cancelLabel,
canSubmit: this.props.initialOptions.canSubmit ?? true
};
}
async submit() {
try {
const model = await this.contentRef.current.trySubmit();
this.props.onFinished(true, model);
} catch (e) {
_logger.logger.error("Error during submission of module dialog:", e);
}
}
cancel() {
this.props.onFinished(false);
}
setOptions(options) {
this.setState(state => _objectSpread(_objectSpread({}, state), options));
}
renderContent() {
const dialogProps = {
moduleApi: this.props.moduleApi,
setOptions: this.setOptions.bind(this),
cancel: this.cancel.bind(this)
};
// Typescript isn't very happy understanding that `contentProps` satisfies `P`
const contentProps = _objectSpread(_objectSpread({}, this.props.additionalContentProps), dialogProps);
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_ModuleUiDialog"
}, this.props.contentFactory(contentProps, this.contentRef));
}
}
exports.ModuleUiDialog = ModuleUiDialog;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_logger","_ScrollableBaseModal","_interopRequireDefault","_languageHandler","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ownKeys","keys","getOwnPropertySymbols","o","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","ModuleUiDialog","ScrollableBaseModal","constructor","props","createRef","state","title","initialOptions","actionLabel","_t","cancelLabel","canSubmit","submit","model","contentRef","current","trySubmit","onFinished","logger","error","cancel","setOptions","options","setState","renderContent","dialogProps","moduleApi","bind","contentProps","additionalContentProps","createElement","className","contentFactory","exports"],"sources":["../../../../src/components/views/dialogs/ModuleUiDialog.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2022 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, { createRef } from \"react\";\nimport { DialogContent, DialogProps } from \"@matrix-org/react-sdk-module-api/lib/components/DialogContent\";\nimport { logger } from \"matrix-js-sdk/src/logger\";\nimport { ModuleApi } from \"@matrix-org/react-sdk-module-api/lib/ModuleApi\";\nimport { ModuleUiDialogOptions } from \"@matrix-org/react-sdk-module-api/lib/types/ModuleUiDialogOptions\";\n\nimport ScrollableBaseModal, { IScrollableBaseState } from \"./ScrollableBaseModal\";\nimport { _t } from \"../../../languageHandler\";\n\ninterface IProps<P extends DialogProps, C extends DialogContent<P>> {\n    contentFactory: (props: P, ref: React.RefObject<C>) => React.ReactNode;\n    additionalContentProps: Omit<P, keyof DialogProps> | undefined;\n    initialOptions: ModuleUiDialogOptions;\n    moduleApi: ModuleApi;\n    onFinished(ok?: boolean, model?: Awaited<ReturnType<DialogContent<P & DialogProps>[\"trySubmit\"]>>): void;\n}\n\ninterface IState extends IScrollableBaseState {\n    // nothing special\n}\n\nexport class ModuleUiDialog<P extends DialogProps, C extends DialogContent<P>> extends ScrollableBaseModal<\n    IProps<P, C>,\n    IState\n> {\n    private contentRef = createRef<C>();\n\n    public constructor(props: IProps<P, C>) {\n        super(props);\n\n        this.state = {\n            title: this.props.initialOptions.title,\n            actionLabel: this.props.initialOptions.actionLabel ?? _t(\"action|ok\"),\n            cancelLabel: this.props.initialOptions.cancelLabel,\n            canSubmit: this.props.initialOptions.canSubmit ?? true,\n        };\n    }\n\n    protected async submit(): Promise<void> {\n        try {\n            const model = await this.contentRef.current!.trySubmit();\n            this.props.onFinished(true, model);\n        } catch (e) {\n            logger.error(\"Error during submission of module dialog:\", e);\n        }\n    }\n\n    protected cancel(): void {\n        this.props.onFinished(false);\n    }\n\n    private setOptions(options: ModuleUiDialogOptions): void {\n        this.setState((state) => ({ ...state, ...options }));\n    }\n\n    protected renderContent(): React.ReactNode {\n        const dialogProps: DialogProps = {\n            moduleApi: this.props.moduleApi,\n            setOptions: this.setOptions.bind(this),\n            cancel: this.cancel.bind(this),\n        };\n\n        // Typescript isn't very happy understanding that `contentProps` satisfies `P`\n        const contentProps: P = {\n            ...this.props.additionalContentProps,\n            ...dialogProps,\n        } as unknown as P;\n\n        return <div className=\"mx_ModuleUiDialog\">{this.props.contentFactory(contentProps, this.contentRef)}</div>;\n    }\n}\n"],"mappings":"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","ignoreList":[]}