@bigbinary/neeto-editor 1.47.108 → 1.47.110
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/Attachments.js +52 -0
- package/dist/Attachments.js.map +1 -0
- package/dist/Editor.js +22376 -0
- package/dist/Editor.js.map +1 -0
- package/dist/EditorContent.js +250 -0
- package/dist/EditorContent.js.map +1 -0
- package/dist/FormikEditor.js +199 -0
- package/dist/FormikEditor.js.map +1 -0
- package/dist/Menu.js +106 -0
- package/dist/Menu.js.map +1 -0
- package/dist/chunk-BFTU3MAI.js +8 -0
- package/dist/chunk-BFTU3MAI.js.map +1 -0
- package/dist/chunk-BJhk4N3E.js +25765 -0
- package/dist/chunk-BJhk4N3E.js.map +1 -0
- package/dist/chunk-BR5ZkH7J.js +16238 -0
- package/dist/chunk-BR5ZkH7J.js.map +1 -0
- package/dist/chunk-C2dztUxs.js +4 -0
- package/dist/chunk-C2dztUxs.js.map +1 -0
- package/dist/chunk-CAGz17QN.js +571 -0
- package/dist/chunk-CAGz17QN.js.map +1 -0
- package/dist/chunk-CUwAOdCi.js +12640 -0
- package/dist/chunk-CUwAOdCi.js.map +1 -0
- package/dist/chunk-DNMH2cJJ.js +84 -0
- package/dist/chunk-DNMH2cJJ.js.map +1 -0
- package/dist/chunk-Dq9G_Haj.js +6729 -0
- package/dist/chunk-Dq9G_Haj.js.map +1 -0
- package/dist/chunk-DxGDZoUl.js +19 -0
- package/dist/chunk-DxGDZoUl.js.map +1 -0
- package/dist/chunk-sfpDYWCU.js +19022 -0
- package/dist/chunk-sfpDYWCU.js.map +1 -0
- package/dist/chunk-zRPC4lVr.js +9073 -0
- package/dist/chunk-zRPC4lVr.js.map +1 -0
- package/dist/cjs/Attachments.cjs.js +58 -0
- package/dist/cjs/Attachments.cjs.js.map +1 -0
- package/dist/cjs/Editor.cjs.js +22473 -0
- package/dist/cjs/Editor.cjs.js.map +1 -0
- package/dist/cjs/EditorContent.cjs.js +264 -0
- package/dist/cjs/EditorContent.cjs.js.map +1 -0
- package/dist/cjs/FormikEditor.cjs.js +206 -0
- package/dist/cjs/FormikEditor.cjs.js.map +1 -0
- package/dist/cjs/Menu.cjs.js +112 -0
- package/dist/cjs/Menu.cjs.js.map +1 -0
- package/dist/cjs/chunk-2HrSPdAV.cjs.js +92 -0
- package/dist/cjs/chunk-2HrSPdAV.cjs.js.map +1 -0
- package/dist/cjs/chunk-8GIxbIj_.cjs.js +597 -0
- package/dist/cjs/chunk-8GIxbIj_.cjs.js.map +1 -0
- package/dist/cjs/chunk-B6qYtOJe.cjs.js +6 -0
- package/dist/cjs/chunk-B6qYtOJe.cjs.js.map +1 -0
- package/dist/cjs/chunk-BGy3NmZC.cjs.js +49 -0
- package/dist/cjs/chunk-BGy3NmZC.cjs.js.map +1 -0
- package/dist/cjs/chunk-BJu3ubxk.cjs.js +11 -0
- package/dist/cjs/chunk-BJu3ubxk.cjs.js.map +1 -0
- package/dist/cjs/chunk-BzUZpT8V.cjs.js +6770 -0
- package/dist/cjs/chunk-BzUZpT8V.cjs.js.map +1 -0
- package/dist/cjs/chunk-CSn1uTr2.cjs.js +12645 -0
- package/dist/cjs/chunk-CSn1uTr2.cjs.js.map +1 -0
- package/dist/cjs/chunk-CdckCFos.cjs.js +25777 -0
- package/dist/cjs/chunk-CdckCFos.cjs.js.map +1 -0
- package/dist/cjs/chunk-De3nCFAF.cjs.js +16258 -0
- package/dist/cjs/chunk-De3nCFAF.cjs.js.map +1 -0
- package/dist/cjs/chunk-DjozIdFz.cjs.js +9135 -0
- package/dist/cjs/chunk-DjozIdFz.cjs.js.map +1 -0
- package/dist/cjs/chunk-krXdNjm-.cjs.js +19151 -0
- package/dist/cjs/chunk-krXdNjm-.cjs.js.map +1 -0
- package/dist/cjs/constants.cjs.js +13 -0
- package/dist/cjs/constants.cjs.js.map +1 -0
- package/dist/cjs/index.cjs.js +159 -0
- package/dist/cjs/index.cjs.js.map +1 -0
- package/dist/cjs/utils.cjs.js +27 -0
- package/dist/cjs/utils.cjs.js.map +1 -0
- package/dist/codeblockHighlight.js +15155 -0
- package/dist/codeblockHighlight.js.map +1 -0
- package/dist/constants.js +6 -0
- package/dist/constants.js.map +1 -0
- package/dist/editor-content.min.css +1 -0
- package/dist/editor-output-pdf-email.css +1 -0
- package/dist/editor-output-pdf-email.js +4 -0
- package/dist/editor-output-pdf-email.js.map +1 -0
- package/dist/editor-output.js +4 -0
- package/dist/editor-output.js.map +1 -0
- package/dist/editor-stats.html +4860 -0
- package/dist/editorUtils.js +170 -0
- package/dist/headerLinks.js +59 -0
- package/dist/headerLinks.js.map +1 -0
- package/dist/index.js +142 -0
- package/dist/index.js.map +1 -0
- package/dist/utils.js +15 -0
- package/dist/utils.js.map +1 -0
- package/package.json +3 -2
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
var e=[],t=[];function n(n,r){if(n&&"undefined"!=typeof document){var a,s=true===r.prepend?"prepend":"append",d=true===r.singleTag,i="string"==typeof r.container?document.querySelector(r.container):document.getElementsByTagName("head")[0];if(d){var u=e.indexOf(i);-1===u&&(u=e.push(i)-1,t[u]={}),a=t[u]&&t[u][s]?t[u][s]:t[u][s]=c();}else a=c();65279===n.charCodeAt(0)&&(n=n.substring(1)),a.styleSheet?a.styleSheet.cssText+=n:a.appendChild(document.createTextNode(n));}function c(){var e=document.createElement("style");if(e.setAttribute("type","text/css"),r.attributes)for(var t=Object.keys(r.attributes),n=0;n<t.length;n++)e.setAttribute(t[n],r.attributes[t[n]]);var a="prepend"===s?"afterbegin":"beforeend";return i.insertAdjacentElement(a,e),e}}
|
|
2
|
+
|
|
3
|
+
export { n };
|
|
4
|
+
//# sourceMappingURL=chunk-C2dztUxs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"chunk-C2dztUxs.js","sources":["../node_modules/rollup-plugin-styles/dist/runtime/inject-css.js"],"sourcesContent":["var e=[],t=[];function n(n,r){if(n&&\"undefined\"!=typeof document){var a,s=!0===r.prepend?\"prepend\":\"append\",d=!0===r.singleTag,i=\"string\"==typeof r.container?document.querySelector(r.container):document.getElementsByTagName(\"head\")[0];if(d){var u=e.indexOf(i);-1===u&&(u=e.push(i)-1,t[u]={}),a=t[u]&&t[u][s]?t[u][s]:t[u][s]=c()}else a=c();65279===n.charCodeAt(0)&&(n=n.substring(1)),a.styleSheet?a.styleSheet.cssText+=n:a.appendChild(document.createTextNode(n))}function c(){var e=document.createElement(\"style\");if(e.setAttribute(\"type\",\"text/css\"),r.attributes)for(var t=Object.keys(r.attributes),n=0;n<t.length;n++)e.setAttribute(t[n],r.attributes[t[n]]);var a=\"prepend\"===s?\"afterbegin\":\"beforeend\";return i.insertAdjacentElement(a,e),e}}export{n as default};\n"],"names":[],"mappings":"AAAA,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,WAAW,EAAE,OAAO,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAE,GAAG,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAE,GAAG,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,QAAQ,CAAC,oBAAoB,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAE,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,GAAG,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC,CAAC,EAAC,CAAC,SAAS,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,YAAY,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,IAAI,IAAI,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,SAAS,GAAG,CAAC,CAAC,YAAY,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;;;;","x_google_ignoreList":[0]}
|
|
@@ -0,0 +1,571 @@
|
|
|
1
|
+
import _defineProperty from '@babel/runtime/helpers/defineProperty';
|
|
2
|
+
import _toConsumableArray from '@babel/runtime/helpers/toConsumableArray';
|
|
3
|
+
import _asyncToGenerator from '@babel/runtime/helpers/asyncToGenerator';
|
|
4
|
+
import _slicedToArray from '@babel/runtime/helpers/slicedToArray';
|
|
5
|
+
import _regeneratorRuntime from '@babel/runtime/regenerator';
|
|
6
|
+
import { useState, useRef, memo, forwardRef, useMemo, useImperativeHandle, createElement, Suspense, lazy } from 'react';
|
|
7
|
+
import classnames from 'classnames';
|
|
8
|
+
import { removeBy, noop, isPresent, isNotEmpty } from '@bigbinary/neeto-cist';
|
|
9
|
+
import Button from '@bigbinary/neetoui/Button';
|
|
10
|
+
import Toastr from '@bigbinary/neetoui/Toastr';
|
|
11
|
+
import { mergeRight, isEmpty, assoc } from 'ramda';
|
|
12
|
+
import { useTranslation, Trans } from 'react-i18next';
|
|
13
|
+
import { F as File, d as directUploadsApi, a as FileIcon, u as useFileUploader, b as useDropFiles } from './chunk-zRPC4lVr.js';
|
|
14
|
+
import { n } from './chunk-C2dztUxs.js';
|
|
15
|
+
import useOnClickOutside from '@bigbinary/neeto-commons-frontend/react-utils/useOnClickOutside';
|
|
16
|
+
import { withEventTargetValue } from '@bigbinary/neeto-commons-frontend/utils';
|
|
17
|
+
import MenuVertical from '@bigbinary/neeto-icons/MenuVertical';
|
|
18
|
+
import Close from '@bigbinary/neeto-icons/Close';
|
|
19
|
+
import Check from '@bigbinary/neeto-icons/Check';
|
|
20
|
+
import Dropdown from '@bigbinary/neetoui/Dropdown';
|
|
21
|
+
import Input from '@bigbinary/neetoui/Input';
|
|
22
|
+
import Spinner from '@bigbinary/neetoui/Spinner';
|
|
23
|
+
import Tooltip from '@bigbinary/neetoui/Tooltip';
|
|
24
|
+
import Typography from '@bigbinary/neetoui/Typography';
|
|
25
|
+
import Alert from '@bigbinary/neetoui/Alert';
|
|
26
|
+
import { t } from 'i18next';
|
|
27
|
+
import { globalProps } from '@bigbinary/neeto-commons-frontend/initializers';
|
|
28
|
+
import { D as DIRECT_UPLOAD_ENDPOINT } from './chunk-DNMH2cJJ.js';
|
|
29
|
+
import { jsxs, Fragment, jsx } from 'react/jsx-runtime';
|
|
30
|
+
|
|
31
|
+
var css = ".ne-attachments{display:flex;flex-direction:column;gap:8px}.ne-attachments__items{display:flex;flex-wrap:wrap;gap:8px}.ne-attachments__preview{align-items:center;background-color:rgb(var(--neeto-ui-white));border:1px solid rgb(var(--neeto-ui-gray-200));border-radius:var(--neeto-ui-rounded-sm);display:flex;justify-content:space-between;padding-block:4px;padding-inline:8px 2px;width:256px}.ne-attachments__preview-wrapper{display:flex;gap:8px;width:88%}.ne-attachments__preview-wrapper__icon{height:auto;width:15px}.ne-attachments__preview-wrapper p{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:92%}.ne-attachments__preview-wrapper:hover{cursor:pointer}.ne-attachments__preview__progress{display:flex;gap:4px;justify-content:space-between;opacity:.5;width:76%}.ne-attachments__preview__progress p{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:85%}.ne-attachments__preview__progress p:nth-child(2){flex-shrink:0;width:-moz-fit-content;width:fit-content}.ne-attachments__preview__progress-icon{height:auto;width:15px}.ne-attachments__preview:hover{box-shadow:0 0 0 1px rgb(var(--neeto-ui-gray-400))}.ne-attachments input[type=file]{display:none}.ne-attachments-preview{display:flex;flex-direction:column;gap:8px}.ne-attachments-preview .neeto-ui-modal__close{inset-inline-end:16px!important;top:9px!important}.ne-attachments-preview__header{border-bottom:1px solid rgb(var(--neeto-ui-gray-200));display:flex;flex-direction:row;gap:8px;margin-bottom:8px;min-height:58px;padding:16px!important}.ne-attachments-preview__header__fileinfo{align-items:center;border-inline-end:1px solid rgb(var(--neeto-ui-gray-200));display:flex;gap:8px;padding-inline-end:6px}.ne-attachments-preview__body{align-items:center;display:flex;flex-grow:1;justify-content:center;min-height:10px;padding-bottom:8px!important;position:relative;width:100vw}.ne-attachments-preview__body-download{color:rgb(var(--neeto-ui-accent-800));cursor:pointer}.ne-attachments-preview__body-docviewer{height:100%;width:100%}.ne-attachments-preview__body img{max-height:100%;max-width:100%}.ne-attachments-preview__body video{height:100%;width:100%}.ne-attachments-preview__body iframe{height:100%;padding:0 8px;width:100%}.ne-attachments-preview__body-left,.ne-attachments-preview__body-right{position:absolute!important;top:50%;transform:translateY(-50%);z-index:1}.ne-attachments-preview__body-left{inset-inline-start:16px}.ne-attachments-preview__body-right{inset-inline-end:16px}.ne-attachments .attachment-button-loader{scale:.5;width:26px!important}.ne-attachments--integrated{background-color:rgb(var(--neeto-ui-white));border:1px solid rgb(var(--neeto-ui-gray-300));border-radius:0 0 var(--neeto-ui-rounded) var(--neeto-ui-rounded);border-top:none;padding-inline:6px}.ne-attachments__wrapper{position:relative}.ne-attachments__wrapper.is-dragging-over-files:after{align-items:center;background-color:rgba(var(--neeto-ui-gray-300),.5);border:3px dashed rgb(var(--neeto-ui-gray-500));border-radius:5px;color:rgb(var(--neeto-ui-gray-600));content:\"Drop the file here\";display:flex;font-size:1.2rem;font-weight:700;inset:7px;justify-content:center;pointer-events:none;position:absolute}";
|
|
32
|
+
n(css,{});
|
|
33
|
+
|
|
34
|
+
var DEFAULT_FILE_UPLOAD_CONFIG = {
|
|
35
|
+
directUploadEndpoint: DIRECT_UPLOAD_ENDPOINT,
|
|
36
|
+
restrictions: {
|
|
37
|
+
maxFileSize: globalProps.endUserUploadedFileSizeLimitInMb * 1024 * 1024
|
|
38
|
+
}
|
|
39
|
+
};
|
|
40
|
+
var ATTACHMENT_OPTIONS = {
|
|
41
|
+
OPEN_IN_NEW_TAB: t("neetoEditor.common.openInNewTab"),
|
|
42
|
+
DOWNLOAD: t("neetoEditor.common.download"),
|
|
43
|
+
RENAME: t("neetoEditor.attachments.rename"),
|
|
44
|
+
DELETE: t("neetoEditor.menu.delete")
|
|
45
|
+
};
|
|
46
|
+
var ATTACHMENTS_PREVIEW_DATA_CY = "ne-attachments-preview-content";
|
|
47
|
+
|
|
48
|
+
var buildFileUploadConfig = function buildFileUploadConfig(config) {
|
|
49
|
+
return mergeRight(DEFAULT_FILE_UPLOAD_CONFIG, config);
|
|
50
|
+
};
|
|
51
|
+
var downloadFile = /*#__PURE__*/function () {
|
|
52
|
+
var _ref = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee(fileUrl, filename) {
|
|
53
|
+
var response, blob, blobUrl, a;
|
|
54
|
+
return _regeneratorRuntime.wrap(function _callee$(_context) {
|
|
55
|
+
while (1) switch (_context.prev = _context.next) {
|
|
56
|
+
case 0:
|
|
57
|
+
_context.prev = 0;
|
|
58
|
+
_context.next = 3;
|
|
59
|
+
return fetch(fileUrl);
|
|
60
|
+
case 3:
|
|
61
|
+
response = _context.sent;
|
|
62
|
+
_context.next = 6;
|
|
63
|
+
return response.blob();
|
|
64
|
+
case 6:
|
|
65
|
+
blob = _context.sent;
|
|
66
|
+
blobUrl = URL.createObjectURL(blob);
|
|
67
|
+
a = document.createElement("a");
|
|
68
|
+
a.href = blobUrl;
|
|
69
|
+
a.setAttribute("download", filename);
|
|
70
|
+
a.style.display = "none";
|
|
71
|
+
document.body.appendChild(a);
|
|
72
|
+
a.click();
|
|
73
|
+
document.body.removeChild(a);
|
|
74
|
+
URL.revokeObjectURL(blobUrl);
|
|
75
|
+
_context.next = 21;
|
|
76
|
+
break;
|
|
77
|
+
case 18:
|
|
78
|
+
_context.prev = 18;
|
|
79
|
+
_context.t0 = _context["catch"](0);
|
|
80
|
+
Toastr.error(_context.t0);
|
|
81
|
+
case 21:
|
|
82
|
+
case "end":
|
|
83
|
+
return _context.stop();
|
|
84
|
+
}
|
|
85
|
+
}, _callee, null, [[0, 18]]);
|
|
86
|
+
}));
|
|
87
|
+
return function downloadFile(_x, _x2) {
|
|
88
|
+
return _ref.apply(this, arguments);
|
|
89
|
+
};
|
|
90
|
+
}();
|
|
91
|
+
var checkPreviewAvailability = function checkPreviewAvailability(contentType) {
|
|
92
|
+
return contentType && (contentType.startsWith("video/") || contentType === "application/pdf" || contentType === "image/jpeg" || contentType === "image/gif" || contentType === "image/png" || contentType === "image/webp" || contentType === "text/plain" || contentType === "image/bmp" || contentType === "application/msword" || contentType === "application/vnd.openxmlformats-officedocument.wordprocessingml.document" || contentType === "image/jpg" || contentType === "application/vnd.ms-powerpoint" || contentType === "application/vnd.openxmlformats-officedocument.presentationml.presentation" || contentType === "image/tiff" || contentType === "application/vnd.ms-excel" || contentType === "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
|
|
93
|
+
};
|
|
94
|
+
|
|
95
|
+
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; }
|
|
96
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), true).forEach(function (r) { _defineProperty(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; }
|
|
97
|
+
var Menu = Dropdown.Menu,
|
|
98
|
+
MenuItem = Dropdown.MenuItem;
|
|
99
|
+
var Attachment = function Attachment(_ref) {
|
|
100
|
+
var attachment = _ref.attachment,
|
|
101
|
+
attachments = _ref.attachments,
|
|
102
|
+
disabled = _ref.disabled,
|
|
103
|
+
onChange = _ref.onChange,
|
|
104
|
+
setSelectedAttachment = _ref.setSelectedAttachment,
|
|
105
|
+
isLoading = _ref.isLoading,
|
|
106
|
+
allowDelete = _ref.allowDelete,
|
|
107
|
+
allowOpenInNewTab = _ref.allowOpenInNewTab;
|
|
108
|
+
var _useTranslation = useTranslation(),
|
|
109
|
+
t = _useTranslation.t;
|
|
110
|
+
var _useState = useState(false),
|
|
111
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
112
|
+
isRenaming = _useState2[0],
|
|
113
|
+
setIsRenaming = _useState2[1];
|
|
114
|
+
var _useState3 = useState(false),
|
|
115
|
+
_useState4 = _slicedToArray(_useState3, 2),
|
|
116
|
+
isUpdating = _useState4[0],
|
|
117
|
+
setIsUpdating = _useState4[1];
|
|
118
|
+
var _useState5 = useState(false),
|
|
119
|
+
_useState6 = _slicedToArray(_useState5, 2),
|
|
120
|
+
isDeleteAlertOpen = _useState6[0],
|
|
121
|
+
setIsDeleteAlertOpen = _useState6[1];
|
|
122
|
+
var _useState7 = useState(false),
|
|
123
|
+
_useState8 = _slicedToArray(_useState7, 2),
|
|
124
|
+
isDeleting = _useState8[0],
|
|
125
|
+
setIsDeleting = _useState8[1];
|
|
126
|
+
var _useState9 = useState(""),
|
|
127
|
+
_useState0 = _slicedToArray(_useState9, 2),
|
|
128
|
+
newFilename = _useState0[0],
|
|
129
|
+
setNewFilename = _useState0[1];
|
|
130
|
+
var renameRef = useRef(null);
|
|
131
|
+
useOnClickOutside(renameRef, function () {
|
|
132
|
+
if (!isRenaming) return;
|
|
133
|
+
setIsRenaming(false);
|
|
134
|
+
setNewFilename("");
|
|
135
|
+
});
|
|
136
|
+
var handleDownload = function handleDownload() {
|
|
137
|
+
return downloadFile(attachment.url, attachment.filename);
|
|
138
|
+
};
|
|
139
|
+
var handleOpenInNewTab = function handleOpenInNewTab() {
|
|
140
|
+
return window.open(attachment.url, "_blank", "noopener,noreferrer");
|
|
141
|
+
};
|
|
142
|
+
var handleRename = /*#__PURE__*/function () {
|
|
143
|
+
var _ref2 = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee() {
|
|
144
|
+
var _response$data, signedId, payload, response, filename;
|
|
145
|
+
return _regeneratorRuntime.wrap(function _callee$(_context) {
|
|
146
|
+
while (1) switch (_context.prev = _context.next) {
|
|
147
|
+
case 0:
|
|
148
|
+
_context.prev = 0;
|
|
149
|
+
setIsUpdating(true);
|
|
150
|
+
signedId = attachment.signedId;
|
|
151
|
+
payload = {
|
|
152
|
+
blob: {
|
|
153
|
+
filename: newFilename
|
|
154
|
+
}
|
|
155
|
+
};
|
|
156
|
+
_context.next = 6;
|
|
157
|
+
return directUploadsApi.update({
|
|
158
|
+
signedId: signedId,
|
|
159
|
+
payload: payload
|
|
160
|
+
});
|
|
161
|
+
case 6:
|
|
162
|
+
response = _context.sent;
|
|
163
|
+
filename = ((_response$data = response.data) === null || _response$data === void 0 || (_response$data = _response$data.blob) === null || _response$data === void 0 ? void 0 : _response$data.filename) || response.blob.filename;
|
|
164
|
+
onChange(attachments.map(function (attachment) {
|
|
165
|
+
return attachment.signedId === signedId ? assoc("filename", filename, attachment) : attachment;
|
|
166
|
+
}));
|
|
167
|
+
_context.next = 14;
|
|
168
|
+
break;
|
|
169
|
+
case 11:
|
|
170
|
+
_context.prev = 11;
|
|
171
|
+
_context.t0 = _context["catch"](0);
|
|
172
|
+
Toastr.error(_context.t0);
|
|
173
|
+
case 14:
|
|
174
|
+
_context.prev = 14;
|
|
175
|
+
setIsRenaming(false);
|
|
176
|
+
setIsUpdating(false);
|
|
177
|
+
setNewFilename("");
|
|
178
|
+
return _context.finish(14);
|
|
179
|
+
case 19:
|
|
180
|
+
case "end":
|
|
181
|
+
return _context.stop();
|
|
182
|
+
}
|
|
183
|
+
}, _callee, null, [[0, 11, 14, 19]]);
|
|
184
|
+
}));
|
|
185
|
+
return function handleRename() {
|
|
186
|
+
return _ref2.apply(this, arguments);
|
|
187
|
+
};
|
|
188
|
+
}();
|
|
189
|
+
var handleDelete = /*#__PURE__*/function () {
|
|
190
|
+
var _ref3 = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee2() {
|
|
191
|
+
var signedId;
|
|
192
|
+
return _regeneratorRuntime.wrap(function _callee2$(_context2) {
|
|
193
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
194
|
+
case 0:
|
|
195
|
+
if (allowDelete) {
|
|
196
|
+
_context2.next = 2;
|
|
197
|
+
break;
|
|
198
|
+
}
|
|
199
|
+
return _context2.abrupt("return");
|
|
200
|
+
case 2:
|
|
201
|
+
setIsDeleting(true);
|
|
202
|
+
_context2.prev = 3;
|
|
203
|
+
signedId = attachment.signedId;
|
|
204
|
+
_context2.next = 7;
|
|
205
|
+
return directUploadsApi.destroy(signedId);
|
|
206
|
+
case 7:
|
|
207
|
+
onChange(removeBy({
|
|
208
|
+
signedId: signedId
|
|
209
|
+
}, attachments));
|
|
210
|
+
_context2.next = 13;
|
|
211
|
+
break;
|
|
212
|
+
case 10:
|
|
213
|
+
_context2.prev = 10;
|
|
214
|
+
_context2.t0 = _context2["catch"](3);
|
|
215
|
+
Toastr.error(_context2.t0);
|
|
216
|
+
case 13:
|
|
217
|
+
case "end":
|
|
218
|
+
return _context2.stop();
|
|
219
|
+
}
|
|
220
|
+
}, _callee2, null, [[3, 10]]);
|
|
221
|
+
}));
|
|
222
|
+
return function handleDelete() {
|
|
223
|
+
return _ref3.apply(this, arguments);
|
|
224
|
+
};
|
|
225
|
+
}();
|
|
226
|
+
var handlers = _objectSpread(_objectSpread({}, allowOpenInNewTab && _defineProperty({}, ATTACHMENT_OPTIONS.OPEN_IN_NEW_TAB, handleOpenInNewTab)), {}, _defineProperty(_defineProperty({}, ATTACHMENT_OPTIONS.DOWNLOAD, handleDownload), ATTACHMENT_OPTIONS.RENAME, handleRename), allowDelete && _defineProperty({}, ATTACHMENT_OPTIONS.DELETE, handleDelete));
|
|
227
|
+
var onMenuItemClick = function onMenuItemClick(_ref6) {
|
|
228
|
+
var key = _ref6.key,
|
|
229
|
+
handler = _ref6.handler;
|
|
230
|
+
if (key === ATTACHMENT_OPTIONS.RENAME) {
|
|
231
|
+
setIsRenaming(true);
|
|
232
|
+
setNewFilename(attachment.filename);
|
|
233
|
+
} else if (key === ATTACHMENT_OPTIONS.DELETE) {
|
|
234
|
+
setNewFilename(attachment.filename);
|
|
235
|
+
setIsDeleteAlertOpen(true);
|
|
236
|
+
} else {
|
|
237
|
+
handler();
|
|
238
|
+
}
|
|
239
|
+
};
|
|
240
|
+
var handleKeyDown = function handleKeyDown(_ref7) {
|
|
241
|
+
var event = _ref7.event,
|
|
242
|
+
key = _ref7.key;
|
|
243
|
+
var handler = handlers[key];
|
|
244
|
+
if (event.key === "Enter" && handler && !isEmpty(newFilename)) {
|
|
245
|
+
event.stopPropagation();
|
|
246
|
+
event.preventDefault();
|
|
247
|
+
handler();
|
|
248
|
+
}
|
|
249
|
+
if (event.key === "Escape") {
|
|
250
|
+
setIsRenaming(false);
|
|
251
|
+
setNewFilename("");
|
|
252
|
+
}
|
|
253
|
+
};
|
|
254
|
+
return /*#__PURE__*/jsxs(Fragment, {
|
|
255
|
+
children: [/*#__PURE__*/jsx("div", {
|
|
256
|
+
className: "ne-attachments__preview",
|
|
257
|
+
"data-testid": "ne-attachments-wrapper",
|
|
258
|
+
children: isRenaming ? /*#__PURE__*/jsx("div", {
|
|
259
|
+
ref: renameRef,
|
|
260
|
+
children: /*#__PURE__*/jsx(Tooltip, {
|
|
261
|
+
content: newFilename,
|
|
262
|
+
position: "top",
|
|
263
|
+
children: /*#__PURE__*/jsx(Input, {
|
|
264
|
+
autoFocus: true,
|
|
265
|
+
"data-testid": "neeto-editor-preview-rename-input",
|
|
266
|
+
size: "small",
|
|
267
|
+
value: newFilename,
|
|
268
|
+
error: isEmpty(newFilename) ? t("neetoEditor.attachments.nameEmpty") : "",
|
|
269
|
+
suffix: /*#__PURE__*/jsxs("div", {
|
|
270
|
+
className: "flex items-center justify-end",
|
|
271
|
+
children: [/*#__PURE__*/jsx(Button, {
|
|
272
|
+
"data-testid": "neeto-editor-preview-rename-submit-button",
|
|
273
|
+
disabled: isEmpty(newFilename) || isUpdating,
|
|
274
|
+
icon: Check,
|
|
275
|
+
loading: isUpdating,
|
|
276
|
+
size: "small",
|
|
277
|
+
style: "text",
|
|
278
|
+
onClick: handleRename
|
|
279
|
+
}), /*#__PURE__*/jsx(Button, {
|
|
280
|
+
"data-testid": "neeto-editor-preview-rename-cancel-button",
|
|
281
|
+
disabled: isUpdating,
|
|
282
|
+
icon: Close,
|
|
283
|
+
size: "small",
|
|
284
|
+
style: "text",
|
|
285
|
+
onClick: function onClick() {
|
|
286
|
+
setIsRenaming(false);
|
|
287
|
+
setNewFilename("");
|
|
288
|
+
}
|
|
289
|
+
})]
|
|
290
|
+
}),
|
|
291
|
+
onChange: withEventTargetValue(setNewFilename),
|
|
292
|
+
onKeyDown: function onKeyDown(event) {
|
|
293
|
+
return handleKeyDown({
|
|
294
|
+
event: event,
|
|
295
|
+
key: ATTACHMENT_OPTIONS.RENAME
|
|
296
|
+
});
|
|
297
|
+
}
|
|
298
|
+
})
|
|
299
|
+
})
|
|
300
|
+
}) : /*#__PURE__*/jsxs(Fragment, {
|
|
301
|
+
children: [/*#__PURE__*/jsxs("div", {
|
|
302
|
+
className: "ne-attachments__preview-wrapper",
|
|
303
|
+
onClick: function onClick() {
|
|
304
|
+
return setSelectedAttachment(attachment);
|
|
305
|
+
},
|
|
306
|
+
children: [/*#__PURE__*/jsx(File, {
|
|
307
|
+
className: "ne-attachments__preview-wrapper__icon",
|
|
308
|
+
fileName: attachment.filename
|
|
309
|
+
}), /*#__PURE__*/jsx(Tooltip, {
|
|
310
|
+
content: attachment.filename,
|
|
311
|
+
position: "top",
|
|
312
|
+
children: /*#__PURE__*/jsx(Typography, {
|
|
313
|
+
style: "body2",
|
|
314
|
+
children: attachment.filename
|
|
315
|
+
})
|
|
316
|
+
}), isLoading && /*#__PURE__*/jsx(Spinner, {
|
|
317
|
+
className: "attachment-button-loader"
|
|
318
|
+
})]
|
|
319
|
+
}), /*#__PURE__*/jsx(Tooltip, {
|
|
320
|
+
content: t("neetoEditor.attachments.actionsBlocked"),
|
|
321
|
+
disabled: !disabled,
|
|
322
|
+
position: "top",
|
|
323
|
+
children: /*#__PURE__*/jsx(Dropdown, {
|
|
324
|
+
disabled: disabled,
|
|
325
|
+
buttonSize: "small",
|
|
326
|
+
buttonStyle: "text",
|
|
327
|
+
icon: MenuVertical,
|
|
328
|
+
children: /*#__PURE__*/jsx(Menu, {
|
|
329
|
+
children: Object.entries(handlers).map(function (_ref8) {
|
|
330
|
+
var _ref9 = _slicedToArray(_ref8, 2),
|
|
331
|
+
label = _ref9[0],
|
|
332
|
+
handler = _ref9[1];
|
|
333
|
+
return /*#__PURE__*/jsx(MenuItem.Button, {
|
|
334
|
+
"data-testid": "neeto-editor-preview-".concat(label.toLowerCase(), "-button"),
|
|
335
|
+
onClick: function onClick() {
|
|
336
|
+
return onMenuItemClick({
|
|
337
|
+
key: label,
|
|
338
|
+
handler: handler
|
|
339
|
+
});
|
|
340
|
+
},
|
|
341
|
+
children: label
|
|
342
|
+
}, label);
|
|
343
|
+
})
|
|
344
|
+
})
|
|
345
|
+
})
|
|
346
|
+
})]
|
|
347
|
+
})
|
|
348
|
+
}), /*#__PURE__*/jsx(Alert, {
|
|
349
|
+
isOpen: isDeleteAlertOpen,
|
|
350
|
+
isSubmitting: isDeleting,
|
|
351
|
+
submitButtonLabel: t("neetoEditor.menu.delete"),
|
|
352
|
+
title: t("neetoEditor.attachments.deleteTitle"),
|
|
353
|
+
message: /*#__PURE__*/jsx(Trans, {
|
|
354
|
+
i18nKey: "neetoEditor.attachments.deleteConfirmation",
|
|
355
|
+
values: {
|
|
356
|
+
entity: newFilename
|
|
357
|
+
}
|
|
358
|
+
}),
|
|
359
|
+
onClose: function onClose() {
|
|
360
|
+
return setIsDeleteAlertOpen(false);
|
|
361
|
+
},
|
|
362
|
+
onSubmit: handleDelete
|
|
363
|
+
})]
|
|
364
|
+
});
|
|
365
|
+
};
|
|
366
|
+
|
|
367
|
+
var AttachmentProgress = function AttachmentProgress(_ref) {
|
|
368
|
+
var _attachment$progress;
|
|
369
|
+
var attachment = _ref.attachment,
|
|
370
|
+
cancelUpload = _ref.cancelUpload;
|
|
371
|
+
var progressPercentage = "".concat((_attachment$progress = attachment.progress) !== null && _attachment$progress !== void 0 ? _attachment$progress : 0, "%");
|
|
372
|
+
var handleCancel = function handleCancel() {
|
|
373
|
+
cancelUpload(attachment.id);
|
|
374
|
+
};
|
|
375
|
+
return /*#__PURE__*/jsxs("div", {
|
|
376
|
+
className: "ne-attachments__preview",
|
|
377
|
+
children: [/*#__PURE__*/jsx("div", {
|
|
378
|
+
className: "ne-attachments__preview__progress-icon",
|
|
379
|
+
children: /*#__PURE__*/jsx(FileIcon, {})
|
|
380
|
+
}), /*#__PURE__*/jsxs("div", {
|
|
381
|
+
className: "ne-attachments__preview__progress",
|
|
382
|
+
children: [/*#__PURE__*/jsx(Typography, {
|
|
383
|
+
style: "body2",
|
|
384
|
+
children: attachment.filename
|
|
385
|
+
}), /*#__PURE__*/jsx(Typography, {
|
|
386
|
+
style: "body2",
|
|
387
|
+
children: progressPercentage
|
|
388
|
+
})]
|
|
389
|
+
}), /*#__PURE__*/jsx(Button, {
|
|
390
|
+
"data-testid": "neeto-editor-preview-upload-cancel-button",
|
|
391
|
+
icon: Close,
|
|
392
|
+
size: "small",
|
|
393
|
+
style: "text",
|
|
394
|
+
onClick: handleCancel
|
|
395
|
+
})]
|
|
396
|
+
});
|
|
397
|
+
};
|
|
398
|
+
|
|
399
|
+
var Preview = /*#__PURE__*/lazy(function () {
|
|
400
|
+
return import('./chunk-BJhk4N3E.js');
|
|
401
|
+
});
|
|
402
|
+
var Attachments = function Attachments(_ref, ref) {
|
|
403
|
+
var _fileUploadConfig$all;
|
|
404
|
+
var _ref$attachments = _ref.attachments,
|
|
405
|
+
attachments = _ref$attachments === void 0 ? [] : _ref$attachments,
|
|
406
|
+
_ref$className = _ref.className,
|
|
407
|
+
className = _ref$className === void 0 ? "" : _ref$className,
|
|
408
|
+
_ref$onChange = _ref.onChange,
|
|
409
|
+
onChange = _ref$onChange === void 0 ? noop : _ref$onChange,
|
|
410
|
+
_ref$isIndependent = _ref.isIndependent,
|
|
411
|
+
isIndependent = _ref$isIndependent === void 0 ? true : _ref$isIndependent,
|
|
412
|
+
_ref$disabled = _ref.disabled,
|
|
413
|
+
disabled = _ref$disabled === void 0 ? false : _ref$disabled,
|
|
414
|
+
_ref$dragDropRef = _ref.dragDropRef,
|
|
415
|
+
dragDropRef = _ref$dragDropRef === void 0 ? null : _ref$dragDropRef,
|
|
416
|
+
_ref$config = _ref.config,
|
|
417
|
+
config = _ref$config === void 0 ? {} : _ref$config,
|
|
418
|
+
_ref$setIsUploading = _ref.setIsUploading,
|
|
419
|
+
setIsUploading = _ref$setIsUploading === void 0 ? noop : _ref$setIsUploading,
|
|
420
|
+
_ref$allowDelete = _ref.allowDelete,
|
|
421
|
+
allowDelete = _ref$allowDelete === void 0 ? true : _ref$allowDelete,
|
|
422
|
+
_ref$allowOpenInNewTa = _ref.allowOpenInNewTab,
|
|
423
|
+
allowOpenInNewTab = _ref$allowOpenInNewTa === void 0 ? true : _ref$allowOpenInNewTa;
|
|
424
|
+
var _useTranslation = useTranslation(),
|
|
425
|
+
t = _useTranslation.t;
|
|
426
|
+
var _useState = useState({}),
|
|
427
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
428
|
+
selectedAttachment = _useState2[0],
|
|
429
|
+
setSelectedAttachment = _useState2[1];
|
|
430
|
+
var _useState3 = useState(false),
|
|
431
|
+
_useState4 = _slicedToArray(_useState3, 2),
|
|
432
|
+
didFetchPreviewBundle = _useState4[0],
|
|
433
|
+
setDidFetchPreviewBundle = _useState4[1];
|
|
434
|
+
var attachmentInputRef = useRef(null);
|
|
435
|
+
var fileUploadConfig = useMemo(function () {
|
|
436
|
+
return buildFileUploadConfig(config);
|
|
437
|
+
}, [config]);
|
|
438
|
+
var _useFileUploader = useFileUploader({
|
|
439
|
+
config: fileUploadConfig,
|
|
440
|
+
setIsUploadingOnHost: setIsUploading,
|
|
441
|
+
attachments: attachments
|
|
442
|
+
}),
|
|
443
|
+
addFiles = _useFileUploader.addFiles,
|
|
444
|
+
uploadFiles = _useFileUploader.uploadFiles,
|
|
445
|
+
queuedFiles = _useFileUploader.queuedFiles,
|
|
446
|
+
cancelUpload = _useFileUploader.cancelUpload,
|
|
447
|
+
isUploading = _useFileUploader.isUploading;
|
|
448
|
+
var handleAddFile = /*#__PURE__*/function () {
|
|
449
|
+
var _ref2 = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee(event) {
|
|
450
|
+
var uploadedFiles;
|
|
451
|
+
return _regeneratorRuntime.wrap(function _callee$(_context) {
|
|
452
|
+
while (1) switch (_context.prev = _context.next) {
|
|
453
|
+
case 0:
|
|
454
|
+
addFiles(event.target.files);
|
|
455
|
+
_context.next = 3;
|
|
456
|
+
return uploadFiles();
|
|
457
|
+
case 3:
|
|
458
|
+
uploadedFiles = _context.sent;
|
|
459
|
+
isNotEmpty(uploadedFiles) && onChange([].concat(_toConsumableArray(attachments), _toConsumableArray(uploadedFiles)));
|
|
460
|
+
attachmentInputRef.current.value = null;
|
|
461
|
+
case 6:
|
|
462
|
+
case "end":
|
|
463
|
+
return _context.stop();
|
|
464
|
+
}
|
|
465
|
+
}, _callee);
|
|
466
|
+
}));
|
|
467
|
+
return function handleAddFile(_x) {
|
|
468
|
+
return _ref2.apply(this, arguments);
|
|
469
|
+
};
|
|
470
|
+
}();
|
|
471
|
+
var handleUploadAttachments = function handleUploadAttachments() {
|
|
472
|
+
return attachmentInputRef.current.click();
|
|
473
|
+
};
|
|
474
|
+
var handleFileInputClick = function handleFileInputClick(event) {
|
|
475
|
+
if (!(!isEmpty(attachments) && fileUploadConfig.maxNumberOfFiles === 1)) {
|
|
476
|
+
return;
|
|
477
|
+
}
|
|
478
|
+
event.preventDefault();
|
|
479
|
+
Toastr.warning(t("neetoEditor.attachments.oneAttachmentAllowed"));
|
|
480
|
+
};
|
|
481
|
+
useImperativeHandle(ref, function () {
|
|
482
|
+
return {
|
|
483
|
+
handleUploadAttachments: handleUploadAttachments
|
|
484
|
+
};
|
|
485
|
+
}, []);
|
|
486
|
+
var handleFilesDrop = /*#__PURE__*/function () {
|
|
487
|
+
var _ref3 = _asyncToGenerator(/*#__PURE__*/_regeneratorRuntime.mark(function _callee2(files) {
|
|
488
|
+
var uploadedFiles;
|
|
489
|
+
return _regeneratorRuntime.wrap(function _callee2$(_context2) {
|
|
490
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
491
|
+
case 0:
|
|
492
|
+
addFiles(files);
|
|
493
|
+
_context2.next = 3;
|
|
494
|
+
return uploadFiles();
|
|
495
|
+
case 3:
|
|
496
|
+
uploadedFiles = _context2.sent;
|
|
497
|
+
isNotEmpty(uploadedFiles) && onChange([].concat(_toConsumableArray(attachments), _toConsumableArray(uploadedFiles)));
|
|
498
|
+
case 5:
|
|
499
|
+
case "end":
|
|
500
|
+
return _context2.stop();
|
|
501
|
+
}
|
|
502
|
+
}, _callee2);
|
|
503
|
+
}));
|
|
504
|
+
return function handleFilesDrop(_x2) {
|
|
505
|
+
return _ref3.apply(this, arguments);
|
|
506
|
+
};
|
|
507
|
+
}();
|
|
508
|
+
useDropFiles({
|
|
509
|
+
dropTargetRef: dragDropRef,
|
|
510
|
+
attachments: attachments,
|
|
511
|
+
onDrop: handleFilesDrop
|
|
512
|
+
});
|
|
513
|
+
return /*#__PURE__*/jsxs("div", {
|
|
514
|
+
className: classnames("ne-attachments", _defineProperty({}, className, className)),
|
|
515
|
+
children: [/*#__PURE__*/jsxs("div", {
|
|
516
|
+
className: "ne-attachments__items",
|
|
517
|
+
children: [attachments.map(function (attachment) {
|
|
518
|
+
return /*#__PURE__*/createElement(Attachment, {
|
|
519
|
+
allowDelete: allowDelete,
|
|
520
|
+
allowOpenInNewTab: allowOpenInNewTab,
|
|
521
|
+
attachment: attachment,
|
|
522
|
+
attachments: attachments,
|
|
523
|
+
disabled: disabled,
|
|
524
|
+
onChange: onChange,
|
|
525
|
+
setSelectedAttachment: setSelectedAttachment,
|
|
526
|
+
key: attachment.signedId,
|
|
527
|
+
isLoading: !didFetchPreviewBundle && selectedAttachment.url === attachment.url
|
|
528
|
+
});
|
|
529
|
+
}), queuedFiles.map(function (attachment) {
|
|
530
|
+
return /*#__PURE__*/createElement(AttachmentProgress, {
|
|
531
|
+
attachment: attachment,
|
|
532
|
+
cancelUpload: cancelUpload,
|
|
533
|
+
key: attachment.id
|
|
534
|
+
});
|
|
535
|
+
})]
|
|
536
|
+
}), /*#__PURE__*/jsxs("div", {
|
|
537
|
+
children: [isIndependent && /*#__PURE__*/jsx(Button, {
|
|
538
|
+
"data-testid": "neeto-editor-attachments-upload-button",
|
|
539
|
+
disabled: isUploading,
|
|
540
|
+
label: t("neetoEditor.attachments.add"),
|
|
541
|
+
loading: isUploading,
|
|
542
|
+
size: "medium",
|
|
543
|
+
style: "link",
|
|
544
|
+
onClick: handleUploadAttachments
|
|
545
|
+
}), /*#__PURE__*/jsx("input", {
|
|
546
|
+
accept: (_fileUploadConfig$all = fileUploadConfig.allowedFileTypes) === null || _fileUploadConfig$all === void 0 ? void 0 : _fileUploadConfig$all.join(","),
|
|
547
|
+
multiple: fileUploadConfig.maxNumberOfFiles !== 1,
|
|
548
|
+
ref: attachmentInputRef,
|
|
549
|
+
type: "file",
|
|
550
|
+
onChange: handleAddFile,
|
|
551
|
+
onClick: handleFileInputClick
|
|
552
|
+
}), /*#__PURE__*/jsx(Suspense, {
|
|
553
|
+
fallback: /*#__PURE__*/jsx("span", {}),
|
|
554
|
+
children: isPresent(selectedAttachment) && /*#__PURE__*/jsx(Preview, {
|
|
555
|
+
attachments: attachments,
|
|
556
|
+
selectedAttachment: selectedAttachment,
|
|
557
|
+
setDidFetchPreviewBundle: setDidFetchPreviewBundle,
|
|
558
|
+
setSelectedAttachment: setSelectedAttachment,
|
|
559
|
+
onClose: function onClose() {
|
|
560
|
+
return setSelectedAttachment({});
|
|
561
|
+
}
|
|
562
|
+
})
|
|
563
|
+
})]
|
|
564
|
+
})]
|
|
565
|
+
});
|
|
566
|
+
};
|
|
567
|
+
Attachments.displayName = "NeetoEditorAttachments";
|
|
568
|
+
var Attachments$1 = /*#__PURE__*/memo(/*#__PURE__*/forwardRef(Attachments));
|
|
569
|
+
|
|
570
|
+
export { Attachments$1 as A, ATTACHMENTS_PREVIEW_DATA_CY as a, checkPreviewAvailability as c, downloadFile as d };
|
|
571
|
+
//# sourceMappingURL=chunk-CAGz17QN.js.map
|