matrix-react-sdk
Version:
SDK for matrix.org using React
342 lines (339 loc) • 55.4 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _react = _interopRequireWildcard(require("react"));
var _logger = require("matrix-js-sdk/src/logger");
var _languageHandler = require("../../../languageHandler");
var _BaseDialog = _interopRequireDefault(require("./BaseDialog"));
var _DialogButtons = _interopRequireDefault(require("../elements/DialogButtons"));
var _Field = _interopRequireDefault(require("../elements/Field"));
var _StyledRadioGroup = _interopRequireDefault(require("../elements/StyledRadioGroup"));
var _StyledCheckbox = _interopRequireDefault(require("../elements/StyledCheckbox"));
var _exportUtils = require("../../../utils/exportUtils/exportUtils");
var _Validation = _interopRequireDefault(require("../elements/Validation"));
var _HtmlExport = _interopRequireDefault(require("../../../utils/exportUtils/HtmlExport"));
var _JSONExport = _interopRequireDefault(require("../../../utils/exportUtils/JSONExport"));
var _PlainTextExport = _interopRequireDefault(require("../../../utils/exportUtils/PlainTextExport"));
var _useStateCallback = require("../../../hooks/useStateCallback");
var _Spinner = _interopRequireDefault(require("../elements/Spinner"));
var _InfoDialog = _interopRequireDefault(require("./InfoDialog"));
var _ChatExport = _interopRequireDefault(require("../../../customisations/ChatExport"));
var _validate = require("../../../utils/validate");
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.
*/
/**
* Set up form state using "forceRoomExportParameters" or defaults
* Form fields configured in ForceRoomExportParameters are not allowed to be edited
* Only return change handlers for editable values
*/
const useExportFormState = () => {
const config = _ChatExport.default.getForceChatExportParameters();
const [exportFormat, setExportFormat] = (0, _react.useState)(config.format ?? _exportUtils.ExportFormat.Html);
const [exportType, setExportType] = (0, _react.useState)(config.range ?? _exportUtils.ExportType.Timeline);
const [includeAttachments, setAttachments] = (0, _react.useState)(config.includeAttachments ?? false);
const [numberOfMessages, setNumberOfMessages] = (0, _react.useState)(config.numberOfMessages ?? 100);
const [sizeLimit, setSizeLimit] = (0, _react.useState)(config.sizeMb ?? 8);
return {
exportFormat,
exportType,
includeAttachments,
numberOfMessages,
sizeLimit,
setExportFormat: !config.format ? setExportFormat : undefined,
setExportType: !config.range ? setExportType : undefined,
setNumberOfMessages: !config.numberOfMessages ? setNumberOfMessages : undefined,
setSizeLimit: !config.sizeMb ? setSizeLimit : undefined,
setAttachments: config.includeAttachments === undefined ? setAttachments : undefined
};
};
const ExportDialog = ({
room,
onFinished
}) => {
const {
exportFormat,
exportType,
includeAttachments,
numberOfMessages,
sizeLimit,
setExportFormat,
setExportType,
setNumberOfMessages,
setSizeLimit,
setAttachments
} = useExportFormState();
const [isExporting, setExporting] = (0, _react.useState)(false);
const sizeLimitRef = (0, _react.useRef)(null);
const messageCountRef = (0, _react.useRef)(null);
const [exportProgressText, setExportProgressText] = (0, _react.useState)((0, _languageHandler._t)("export_chat|processing"));
const [displayCancel, setCancelWarning] = (0, _react.useState)(false);
const [exportCancelled, setExportCancelled] = (0, _react.useState)(false);
const [exportSuccessful, setExportSuccessful] = (0, _react.useState)(false);
const [exporter, setExporter] = (0, _useStateCallback.useStateCallback)(null, async exporter => {
await exporter?.export().then(() => {
if (!exportCancelled) setExportSuccessful(true);
});
});
const startExport = async () => {
const exportOptions = {
numberOfMessages,
attachmentsIncluded: includeAttachments,
maxSize: sizeLimit * 1024 * 1024
};
switch (exportFormat) {
case _exportUtils.ExportFormat.Html:
setExporter(new _HtmlExport.default(room, _exportUtils.ExportType[exportType], exportOptions, setExportProgressText));
break;
case _exportUtils.ExportFormat.Json:
setExporter(new _JSONExport.default(room, _exportUtils.ExportType[exportType], exportOptions, setExportProgressText));
break;
case _exportUtils.ExportFormat.PlainText:
setExporter(new _PlainTextExport.default(room, _exportUtils.ExportType[exportType], exportOptions, setExportProgressText));
break;
default:
_logger.logger.error("Unknown export format");
return;
}
};
const onExportClick = async () => {
const isValidSize = !setSizeLimit || (await sizeLimitRef.current?.validate({
focused: false
}));
if (!isValidSize) {
sizeLimitRef.current?.validate({
focused: true
});
return;
}
if (exportType === _exportUtils.ExportType.LastNMessages) {
const isValidNumberOfMessages = await messageCountRef.current?.validate({
focused: false
});
if (!isValidNumberOfMessages) {
messageCountRef.current?.validate({
focused: true
});
return;
}
}
setExporting(true);
await startExport();
};
const validateSize = (0, _Validation.default)({
rules: [{
key: "required",
test({
value,
allowEmpty
}) {
return allowEmpty || !!value;
},
invalid: () => {
const min = 1;
const max = 2000;
return (0, _languageHandler._t)("export_chat|enter_number_between_min_max", {
min,
max
});
}
}, {
key: "number",
test: ({
value
}) => {
const parsedSize = parseInt(value, 10);
return (0, _validate.validateNumberInRange)(1, 2000)(parsedSize);
},
invalid: () => {
const min = 1;
const max = 2000;
return (0, _languageHandler._t)("export_chat|size_limit_min_max", {
min,
max
});
}
}]
});
const onValidateSize = async fieldState => {
const result = await validateSize(fieldState);
return result;
};
const validateNumberOfMessages = (0, _Validation.default)({
rules: [{
key: "required",
test({
value,
allowEmpty
}) {
return allowEmpty || !!value;
},
invalid: () => {
const min = 1;
const max = 10 ** 8;
return (0, _languageHandler._t)("export_chat|enter_number_between_min_max", {
min,
max
});
}
}, {
key: "number",
test: ({
value
}) => {
const parsedSize = parseInt(value, 10);
return (0, _validate.validateNumberInRange)(1, 10 ** 8)(parsedSize);
},
invalid: () => {
const min = 1;
const max = 10 ** 8;
return (0, _languageHandler._t)("export_chat|num_messages_min_max", {
min,
max
});
}
}]
});
const onValidateNumberOfMessages = async fieldState => {
const result = await validateNumberOfMessages(fieldState);
return result;
};
const onCancel = async () => {
if (isExporting) setCancelWarning(true);else onFinished(false);
};
const confirmCancel = async () => {
await exporter?.cancelExport();
setExportCancelled(true);
setExporting(false);
setExporter(null);
};
const exportFormatOptions = Object.values(_exportUtils.ExportFormat).map(format => ({
value: format,
label: (0, _exportUtils.textForFormat)(format)
}));
const exportTypeOptions = Object.values(_exportUtils.ExportType).map(type => {
return /*#__PURE__*/_react.default.createElement("option", {
key: _exportUtils.ExportType[type],
value: type
}, (0, _exportUtils.textForType)(type));
});
let messageCount;
if (exportType === _exportUtils.ExportType.LastNMessages && setNumberOfMessages) {
messageCount = /*#__PURE__*/_react.default.createElement(_Field.default, {
id: "message-count",
element: "input",
type: "number",
value: numberOfMessages.toString(),
ref: messageCountRef,
onValidate: onValidateNumberOfMessages,
label: (0, _languageHandler._t)("export_chat|num_messages"),
onChange: e => {
setNumberOfMessages(parseInt(e.target.value));
}
});
}
const sizePostFix = /*#__PURE__*/_react.default.createElement("span", null, (0, _languageHandler._t)("export_chat|size_limit_postfix"));
if (exportCancelled) {
// Display successful cancellation message
return /*#__PURE__*/_react.default.createElement(_InfoDialog.default, {
title: (0, _languageHandler._t)("export_chat|cancelled"),
description: (0, _languageHandler._t)("export_chat|cancelled_detail"),
hasCloseButton: true,
onFinished: onFinished
});
} else if (exportSuccessful) {
// Display successful export message
return /*#__PURE__*/_react.default.createElement(_InfoDialog.default, {
title: (0, _languageHandler._t)("export_chat|successful"),
description: (0, _languageHandler._t)("export_chat|successful_detail"),
hasCloseButton: true,
onFinished: onFinished
});
} else if (displayCancel) {
// Display cancel warning
return /*#__PURE__*/_react.default.createElement(_BaseDialog.default, {
title: (0, _languageHandler._t)("common|warning"),
className: "mx_ExportDialog",
contentId: "mx_Dialog_content",
onFinished: onFinished,
fixedWidth: true
}, /*#__PURE__*/_react.default.createElement("p", null, (0, _languageHandler._t)("export_chat|confirm_stop")), /*#__PURE__*/_react.default.createElement(_DialogButtons.default, {
primaryButton: (0, _languageHandler._t)("action|stop"),
primaryButtonClass: "danger",
hasCancel: true,
cancelButton: (0, _languageHandler._t)("action|continue"),
onCancel: () => setCancelWarning(false),
onPrimaryButtonClick: confirmCancel
}));
} else {
// Display export settings
return /*#__PURE__*/_react.default.createElement(_BaseDialog.default, {
title: isExporting ? (0, _languageHandler._t)("export_chat|exporting_your_data") : (0, _languageHandler._t)("export_chat|title"),
className: `mx_ExportDialog ${isExporting && "mx_ExportDialog_Exporting"}`,
contentId: "mx_Dialog_content",
hasCancel: true,
onFinished: onFinished,
fixedWidth: true
}, !isExporting ? /*#__PURE__*/_react.default.createElement("p", null, (0, _languageHandler._t)("export_chat|select_option")) : null, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_ExportDialog_options"
}, !!setExportFormat && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("span", {
className: "mx_ExportDialog_subheading"
}, (0, _languageHandler._t)("export_chat|format")), /*#__PURE__*/_react.default.createElement(_StyledRadioGroup.default, {
name: "exportFormat",
value: exportFormat,
onChange: key => setExportFormat(_exportUtils.ExportFormat[key]),
definitions: exportFormatOptions
})), !!setExportType && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("span", {
className: "mx_ExportDialog_subheading"
}, (0, _languageHandler._t)("export_chat|messages")), /*#__PURE__*/_react.default.createElement(_Field.default, {
id: "export-type",
element: "select",
value: exportType,
onChange: e => {
setExportType(_exportUtils.ExportType[e.target.value]);
}
}, exportTypeOptions), messageCount), setSizeLimit && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("span", {
className: "mx_ExportDialog_subheading"
}, (0, _languageHandler._t)("export_chat|size_limit")), /*#__PURE__*/_react.default.createElement(_Field.default, {
id: "size-limit",
type: "number",
autoComplete: "off",
onValidate: onValidateSize,
element: "input",
ref: sizeLimitRef,
value: sizeLimit.toString(),
postfixComponent: sizePostFix,
onChange: e => setSizeLimit(parseInt(e.target.value))
})), setAttachments && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_StyledCheckbox.default, {
className: "mx_ExportDialog_attachments-checkbox",
id: "include-attachments",
checked: includeAttachments,
onChange: e => setAttachments(e.target.checked)
}, (0, _languageHandler._t)("export_chat|include_attachments")))), isExporting ? /*#__PURE__*/_react.default.createElement("div", {
"data-testid": "export-progress",
className: "mx_ExportDialog_progress"
}, /*#__PURE__*/_react.default.createElement(_Spinner.default, {
w: 24,
h: 24
}), /*#__PURE__*/_react.default.createElement("p", null, exportProgressText), /*#__PURE__*/_react.default.createElement(_DialogButtons.default, {
primaryButton: (0, _languageHandler._t)("action|cancel"),
primaryButtonClass: "danger",
hasCancel: false,
onPrimaryButtonClick: onCancel
})) : /*#__PURE__*/_react.default.createElement(_DialogButtons.default, {
primaryButton: (0, _languageHandler._t)("action|export"),
onPrimaryButtonClick: onExportClick,
onCancel: () => onFinished(false)
}));
}
};
var _default = exports.default = ExportDialog;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_logger","_languageHandler","_BaseDialog","_interopRequireDefault","_DialogButtons","_Field","_StyledRadioGroup","_StyledCheckbox","_exportUtils","_Validation","_HtmlExport","_JSONExport","_PlainTextExport","_useStateCallback","_Spinner","_InfoDialog","_ChatExport","_validate","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","useExportFormState","config","ChatExport","getForceChatExportParameters","exportFormat","setExportFormat","useState","format","ExportFormat","Html","exportType","setExportType","range","ExportType","Timeline","includeAttachments","setAttachments","numberOfMessages","setNumberOfMessages","sizeLimit","setSizeLimit","sizeMb","undefined","ExportDialog","room","onFinished","isExporting","setExporting","sizeLimitRef","useRef","messageCountRef","exportProgressText","setExportProgressText","_t","displayCancel","setCancelWarning","exportCancelled","setExportCancelled","exportSuccessful","setExportSuccessful","exporter","setExporter","useStateCallback","export","then","startExport","exportOptions","attachmentsIncluded","maxSize","HTMLExporter","Json","JSONExporter","PlainText","PlainTextExporter","logger","error","onExportClick","isValidSize","current","validate","focused","LastNMessages","isValidNumberOfMessages","validateSize","withValidation","rules","key","test","value","allowEmpty","invalid","min","max","parsedSize","parseInt","validateNumberInRange","onValidateSize","fieldState","result","validateNumberOfMessages","onValidateNumberOfMessages","onCancel","confirmCancel","cancelExport","exportFormatOptions","values","map","label","textForFormat","exportTypeOptions","type","createElement","textForType","messageCount","id","element","toString","ref","onValidate","onChange","target","sizePostFix","title","description","hasCloseButton","className","contentId","fixedWidth","primaryButton","primaryButtonClass","hasCancel","cancelButton","onPrimaryButtonClick","Fragment","name","definitions","autoComplete","postfixComponent","checked","w","h","_default","exports"],"sources":["../../../../src/components/views/dialogs/ExportDialog.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, { useRef, useState, Dispatch, SetStateAction } from \"react\";\nimport { Room } from \"matrix-js-sdk/src/matrix\";\nimport { logger } from \"matrix-js-sdk/src/logger\";\n\nimport { _t } from \"../../../languageHandler\";\nimport BaseDialog from \"./BaseDialog\";\nimport DialogButtons from \"../elements/DialogButtons\";\nimport Field from \"../elements/Field\";\nimport StyledRadioGroup from \"../elements/StyledRadioGroup\";\nimport StyledCheckbox from \"../elements/StyledCheckbox\";\nimport {\n    ExportFormat,\n    ExportFormatKey,\n    ExportType,\n    ExportTypeKey,\n    textForFormat,\n    textForType,\n} from \"../../../utils/exportUtils/exportUtils\";\nimport withValidation, { IFieldState, IValidationResult } from \"../elements/Validation\";\nimport HTMLExporter from \"../../../utils/exportUtils/HtmlExport\";\nimport JSONExporter from \"../../../utils/exportUtils/JSONExport\";\nimport PlainTextExporter from \"../../../utils/exportUtils/PlainTextExport\";\nimport { useStateCallback } from \"../../../hooks/useStateCallback\";\nimport Exporter from \"../../../utils/exportUtils/Exporter\";\nimport Spinner from \"../elements/Spinner\";\nimport InfoDialog from \"./InfoDialog\";\nimport ChatExport from \"../../../customisations/ChatExport\";\nimport { validateNumberInRange } from \"../../../utils/validate\";\n\ninterface IProps {\n    room: Room;\n    onFinished(doExport?: boolean): void;\n}\n\ninterface ExportConfig {\n    exportFormat: ExportFormat;\n    exportType: ExportType;\n    numberOfMessages: number;\n    sizeLimit: number;\n    includeAttachments: boolean;\n    setExportFormat?: Dispatch<SetStateAction<ExportFormat>>;\n    setExportType?: Dispatch<SetStateAction<ExportType>>;\n    setAttachments?: Dispatch<SetStateAction<boolean>>;\n    setNumberOfMessages?: Dispatch<SetStateAction<number>>;\n    setSizeLimit?: Dispatch<SetStateAction<number>>;\n}\n\n/**\n * Set up form state using \"forceRoomExportParameters\" or defaults\n * Form fields configured in ForceRoomExportParameters are not allowed to be edited\n * Only return change handlers for editable values\n */\nconst useExportFormState = (): ExportConfig => {\n    const config = ChatExport.getForceChatExportParameters();\n\n    const [exportFormat, setExportFormat] = useState(config.format ?? ExportFormat.Html);\n    const [exportType, setExportType] = useState(config.range ?? ExportType.Timeline);\n    const [includeAttachments, setAttachments] = useState(config.includeAttachments ?? false);\n    const [numberOfMessages, setNumberOfMessages] = useState<number>(config.numberOfMessages ?? 100);\n    const [sizeLimit, setSizeLimit] = useState<number>(config.sizeMb ?? 8);\n\n    return {\n        exportFormat,\n        exportType,\n        includeAttachments,\n        numberOfMessages,\n        sizeLimit,\n        setExportFormat: !config.format ? setExportFormat : undefined,\n        setExportType: !config.range ? setExportType : undefined,\n        setNumberOfMessages: !config.numberOfMessages ? setNumberOfMessages : undefined,\n        setSizeLimit: !config.sizeMb ? setSizeLimit : undefined,\n        setAttachments: config.includeAttachments === undefined ? setAttachments : undefined,\n    };\n};\n\nconst ExportDialog: React.FC<IProps> = ({ room, onFinished }) => {\n    const {\n        exportFormat,\n        exportType,\n        includeAttachments,\n        numberOfMessages,\n        sizeLimit,\n        setExportFormat,\n        setExportType,\n        setNumberOfMessages,\n        setSizeLimit,\n        setAttachments,\n    } = useExportFormState();\n\n    const [isExporting, setExporting] = useState(false);\n    const sizeLimitRef = useRef<Field>(null);\n    const messageCountRef = useRef<Field>(null);\n    const [exportProgressText, setExportProgressText] = useState(_t(\"export_chat|processing\"));\n    const [displayCancel, setCancelWarning] = useState(false);\n    const [exportCancelled, setExportCancelled] = useState(false);\n    const [exportSuccessful, setExportSuccessful] = useState(false);\n    const [exporter, setExporter] = useStateCallback<Exporter | null>(\n        null,\n        async (exporter: Exporter | null): Promise<void> => {\n            await exporter?.export().then(() => {\n                if (!exportCancelled) setExportSuccessful(true);\n            });\n        },\n    );\n\n    const startExport = async (): Promise<void> => {\n        const exportOptions = {\n            numberOfMessages,\n            attachmentsIncluded: includeAttachments,\n            maxSize: sizeLimit * 1024 * 1024,\n        };\n        switch (exportFormat) {\n            case ExportFormat.Html:\n                setExporter(new HTMLExporter(room, ExportType[exportType], exportOptions, setExportProgressText));\n                break;\n            case ExportFormat.Json:\n                setExporter(new JSONExporter(room, ExportType[exportType], exportOptions, setExportProgressText));\n                break;\n            case ExportFormat.PlainText:\n                setExporter(new PlainTextExporter(room, ExportType[exportType], exportOptions, setExportProgressText));\n                break;\n            default:\n                logger.error(\"Unknown export format\");\n                return;\n        }\n    };\n\n    const onExportClick = async (): Promise<void> => {\n        const isValidSize =\n            !setSizeLimit ||\n            (await sizeLimitRef.current?.validate({\n                focused: false,\n            }));\n\n        if (!isValidSize) {\n            sizeLimitRef.current?.validate({ focused: true });\n            return;\n        }\n        if (exportType === ExportType.LastNMessages) {\n            const isValidNumberOfMessages = await messageCountRef.current?.validate({ focused: false });\n            if (!isValidNumberOfMessages) {\n                messageCountRef.current?.validate({ focused: true });\n                return;\n            }\n        }\n        setExporting(true);\n        await startExport();\n    };\n\n    const validateSize = withValidation({\n        rules: [\n            {\n                key: \"required\",\n                test({ value, allowEmpty }) {\n                    return allowEmpty || !!value;\n                },\n                invalid: () => {\n                    const min = 1;\n                    const max = 2000;\n                    return _t(\"export_chat|enter_number_between_min_max\", {\n                        min,\n                        max,\n                    });\n                },\n            },\n            {\n                key: \"number\",\n                test: ({ value }) => {\n                    const parsedSize = parseInt(value!, 10);\n                    return validateNumberInRange(1, 2000)(parsedSize);\n                },\n                invalid: () => {\n                    const min = 1;\n                    const max = 2000;\n                    return _t(\"export_chat|size_limit_min_max\", { min, max });\n                },\n            },\n        ],\n    });\n\n    const onValidateSize = async (fieldState: IFieldState): Promise<IValidationResult> => {\n        const result = await validateSize(fieldState);\n        return result;\n    };\n\n    const validateNumberOfMessages = withValidation({\n        rules: [\n            {\n                key: \"required\",\n                test({ value, allowEmpty }) {\n                    return allowEmpty || !!value;\n                },\n                invalid: () => {\n                    const min = 1;\n                    const max = 10 ** 8;\n                    return _t(\"export_chat|enter_number_between_min_max\", {\n                        min,\n                        max,\n                    });\n                },\n            },\n            {\n                key: \"number\",\n                test: ({ value }) => {\n                    const parsedSize = parseInt(value!, 10);\n                    return validateNumberInRange(1, 10 ** 8)(parsedSize);\n                },\n                invalid: () => {\n                    const min = 1;\n                    const max = 10 ** 8;\n                    return _t(\"export_chat|num_messages_min_max\", { min, max });\n                },\n            },\n        ],\n    });\n\n    const onValidateNumberOfMessages = async (fieldState: IFieldState): Promise<IValidationResult> => {\n        const result = await validateNumberOfMessages(fieldState);\n        return result;\n    };\n\n    const onCancel = async (): Promise<void> => {\n        if (isExporting) setCancelWarning(true);\n        else onFinished(false);\n    };\n\n    const confirmCancel = async (): Promise<void> => {\n        await exporter?.cancelExport();\n        setExportCancelled(true);\n        setExporting(false);\n        setExporter(null);\n    };\n\n    const exportFormatOptions = Object.values(ExportFormat).map((format) => ({\n        value: format,\n        label: textForFormat(format),\n    }));\n\n    const exportTypeOptions = Object.values(ExportType).map((type) => {\n        return (\n            <option key={ExportType[type]} value={type}>\n                {textForType(type)}\n            </option>\n        );\n    });\n\n    let messageCount: JSX.Element | undefined;\n    if (exportType === ExportType.LastNMessages && setNumberOfMessages) {\n        messageCount = (\n            <Field\n                id=\"message-count\"\n                element=\"input\"\n                type=\"number\"\n                value={numberOfMessages.toString()}\n                ref={messageCountRef}\n                onValidate={onValidateNumberOfMessages}\n                label={_t(\"export_chat|num_messages\")}\n                onChange={(e) => {\n                    setNumberOfMessages(parseInt(e.target.value));\n                }}\n            />\n        );\n    }\n\n    const sizePostFix = <span>{_t(\"export_chat|size_limit_postfix\")}</span>;\n\n    if (exportCancelled) {\n        // Display successful cancellation message\n        return (\n            <InfoDialog\n                title={_t(\"export_chat|cancelled\")}\n                description={_t(\"export_chat|cancelled_detail\")}\n                hasCloseButton={true}\n                onFinished={onFinished}\n            />\n        );\n    } else if (exportSuccessful) {\n        // Display successful export message\n        return (\n            <InfoDialog\n                title={_t(\"export_chat|successful\")}\n                description={_t(\"export_chat|successful_detail\")}\n                hasCloseButton={true}\n                onFinished={onFinished}\n            />\n        );\n    } else if (displayCancel) {\n        // Display cancel warning\n        return (\n            <BaseDialog\n                title={_t(\"common|warning\")}\n                className=\"mx_ExportDialog\"\n                contentId=\"mx_Dialog_content\"\n                onFinished={onFinished}\n                fixedWidth={true}\n            >\n                <p>{_t(\"export_chat|confirm_stop\")}</p>\n                <DialogButtons\n                    primaryButton={_t(\"action|stop\")}\n                    primaryButtonClass=\"danger\"\n                    hasCancel={true}\n                    cancelButton={_t(\"action|continue\")}\n                    onCancel={() => setCancelWarning(false)}\n                    onPrimaryButtonClick={confirmCancel}\n                />\n            </BaseDialog>\n        );\n    } else {\n        // Display export settings\n        return (\n            <BaseDialog\n                title={isExporting ? _t(\"export_chat|exporting_your_data\") : _t(\"export_chat|title\")}\n                className={`mx_ExportDialog ${isExporting && \"mx_ExportDialog_Exporting\"}`}\n                contentId=\"mx_Dialog_content\"\n                hasCancel={true}\n                onFinished={onFinished}\n                fixedWidth={true}\n            >\n                {!isExporting ? <p>{_t(\"export_chat|select_option\")}</p> : null}\n\n                <div className=\"mx_ExportDialog_options\">\n                    {!!setExportFormat && (\n                        <>\n                            <span className=\"mx_ExportDialog_subheading\">{_t(\"export_chat|format\")}</span>\n\n                            <StyledRadioGroup\n                                name=\"exportFormat\"\n                                value={exportFormat}\n                                onChange={(key: ExportFormatKey) => setExportFormat(ExportFormat[key])}\n                                definitions={exportFormatOptions}\n                            />\n                        </>\n                    )}\n\n                    {!!setExportType && (\n                        <>\n                            <span className=\"mx_ExportDialog_subheading\">{_t(\"export_chat|messages\")}</span>\n\n                            <Field\n                                id=\"export-type\"\n                                element=\"select\"\n                                value={exportType}\n                                onChange={(e) => {\n                                    setExportType(ExportType[e.target.value as ExportTypeKey]);\n                                }}\n                            >\n                                {exportTypeOptions}\n                            </Field>\n                            {messageCount}\n                        </>\n                    )}\n\n                    {setSizeLimit && (\n                        <>\n                            <span className=\"mx_ExportDialog_subheading\">{_t(\"export_chat|size_limit\")}</span>\n\n                            <Field\n                                id=\"size-limit\"\n                                type=\"number\"\n                                autoComplete=\"off\"\n                                onValidate={onValidateSize}\n                                element=\"input\"\n                                ref={sizeLimitRef}\n                                value={sizeLimit.toString()}\n                                postfixComponent={sizePostFix}\n                                onChange={(e) => setSizeLimit(parseInt(e.target.value))}\n                            />\n                        </>\n                    )}\n\n                    {setAttachments && (\n                        <>\n                            <StyledCheckbox\n                                className=\"mx_ExportDialog_attachments-checkbox\"\n                                id=\"include-attachments\"\n                                checked={includeAttachments}\n                                onChange={(e) => setAttachments((e.target as HTMLInputElement).checked)}\n                            >\n                                {_t(\"export_chat|include_attachments\")}\n                            </StyledCheckbox>\n                        </>\n                    )}\n                </div>\n                {isExporting ? (\n                    <div data-testid=\"export-progress\" className=\"mx_ExportDialog_progress\">\n                        <Spinner w={24} h={24} />\n                        <p>{exportProgressText}</p>\n                        <DialogButtons\n                            primaryButton={_t(\"action|cancel\")}\n                            primaryButtonClass=\"danger\"\n                            hasCancel={false}\n                            onPrimaryButtonClick={onCancel}\n                        />\n                    </div>\n                ) : (\n                    <DialogButtons\n                        primaryButton={_t(\"action|export\")}\n                        onPrimaryButtonClick={onExportClick}\n                        onCancel={() => onFinished(false)}\n                    />\n                )}\n            </BaseDialog>\n        );\n    }\n};\n\nexport default ExportDialog;\n"],"mappings":"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