@webiny/app-admin 5.35.0 → 5.35.1

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.
Files changed (94) hide show
  1. package/package.json +28 -28
  2. package/assets/images/icons.png +0 -0
  3. package/assets/images/icons_retina.png +0 -0
  4. package/assets/images/swich.png +0 -0
  5. package/components/FileManager/BottomInfoBar/SupportedFileTypes.d.ts +0 -6
  6. package/components/FileManager/BottomInfoBar/SupportedFileTypes.js +0 -55
  7. package/components/FileManager/BottomInfoBar/SupportedFileTypes.js.map +0 -1
  8. package/components/FileManager/BottomInfoBar/UploadStatus.d.ts +0 -6
  9. package/components/FileManager/BottomInfoBar/UploadStatus.js +0 -60
  10. package/components/FileManager/BottomInfoBar/UploadStatus.js.map +0 -1
  11. package/components/FileManager/BottomInfoBar.d.ts +0 -5
  12. package/components/FileManager/BottomInfoBar.js +0 -60
  13. package/components/FileManager/BottomInfoBar.js.map +0 -1
  14. package/components/FileManager/DropFilesHere.d.ts +0 -10
  15. package/components/FileManager/DropFilesHere.js +0 -76
  16. package/components/FileManager/DropFilesHere.js.map +0 -1
  17. package/components/FileManager/File.d.ts +0 -17
  18. package/components/FileManager/File.js +0 -155
  19. package/components/FileManager/File.js.map +0 -1
  20. package/components/FileManager/FileDetails/Name.d.ts +0 -8
  21. package/components/FileManager/FileDetails/Name.js +0 -138
  22. package/components/FileManager/FileDetails/Name.js.map +0 -1
  23. package/components/FileManager/FileDetails/Tags.d.ts +0 -10
  24. package/components/FileManager/FileDetails/Tags.js +0 -339
  25. package/components/FileManager/FileDetails/Tags.js.map +0 -1
  26. package/components/FileManager/FileDetails.d.ts +0 -24
  27. package/components/FileManager/FileDetails.js +0 -474
  28. package/components/FileManager/FileDetails.js.map +0 -1
  29. package/components/FileManager/FileManagerContext.d.ts +0 -42
  30. package/components/FileManager/FileManagerContext.js +0 -224
  31. package/components/FileManager/FileManagerContext.js.map +0 -1
  32. package/components/FileManager/FileManagerView.d.ts +0 -18
  33. package/components/FileManager/FileManagerView.js +0 -721
  34. package/components/FileManager/FileManagerView.js.map +0 -1
  35. package/components/FileManager/LeftSidebar.d.ts +0 -10
  36. package/components/FileManager/LeftSidebar.js +0 -127
  37. package/components/FileManager/LeftSidebar.js.map +0 -1
  38. package/components/FileManager/NoPermissionView.d.ts +0 -3
  39. package/components/FileManager/NoPermissionView.js +0 -87
  40. package/components/FileManager/NoPermissionView.js.map +0 -1
  41. package/components/FileManager/NoResults.d.ts +0 -3
  42. package/components/FileManager/NoResults.js +0 -28
  43. package/components/FileManager/NoResults.js.map +0 -1
  44. package/components/FileManager/getFileTypePlugin.d.ts +0 -4
  45. package/components/FileManager/getFileTypePlugin.js +0 -57
  46. package/components/FileManager/getFileTypePlugin.js.map +0 -1
  47. package/components/FileManager/getFileUploader.d.ts +0 -3
  48. package/components/FileManager/getFileUploader.js +0 -20
  49. package/components/FileManager/getFileUploader.js.map +0 -1
  50. package/components/FileManager/graphql.d.ts +0 -96
  51. package/components/FileManager/graphql.js +0 -58
  52. package/components/FileManager/graphql.js.map +0 -1
  53. package/components/FileManager/icons/content_copy-black-24px.svg +0 -1
  54. package/components/FileManager/icons/delete.svg +0 -12
  55. package/components/FileManager/icons/privacy_tip-24px.svg +0 -10
  56. package/components/FileManager/icons/round-check_box-24px.svg +0 -4
  57. package/components/FileManager/icons/round-check_box_outline_blank-24px.svg +0 -4
  58. package/components/FileManager/icons/round-cloud_download-24px.svg +0 -4
  59. package/components/FileManager/icons/round-cloud_upload-24px.svg +0 -4
  60. package/components/FileManager/icons/round-description-24px.svg +0 -4
  61. package/components/FileManager/icons/round-edit-24px.svg +0 -4
  62. package/components/FileManager/icons/round-info-24px.svg +0 -4
  63. package/components/FileManager/icons/round-label-24px.svg +0 -4
  64. package/components/FileManager/icons/round-more_vert-24px.svg +0 -4
  65. package/components/FileManager/icons/round-search-24px.svg +0 -20
  66. package/components/FileManager/outputFileSelectionError.d.ts +0 -7
  67. package/components/FileManager/outputFileSelectionError.js +0 -54
  68. package/components/FileManager/outputFileSelectionError.js.map +0 -1
  69. package/components/FileManager/types.d.ts +0 -21
  70. package/components/FileManager/types.js +0 -5
  71. package/components/FileManager/types.js.map +0 -1
  72. package/components/FileManager.d.ts +0 -67
  73. package/components/FileManager.js +0 -144
  74. package/components/FileManager.js.map +0 -1
  75. package/plugins/FileManagerFileTypePlugin.d.ts +0 -33
  76. package/plugins/FileManagerFileTypePlugin.js +0 -63
  77. package/plugins/FileManagerFileTypePlugin.js.map +0 -1
  78. package/plugins/fileManager/fileDefault.d.ts +0 -2
  79. package/plugins/fileManager/fileDefault.js +0 -34
  80. package/plugins/fileManager/fileDefault.js.map +0 -1
  81. package/plugins/fileManager/fileImage/DeleteAction.d.ts +0 -7
  82. package/plugins/fileManager/fileImage/DeleteAction.js +0 -83
  83. package/plugins/fileManager/fileImage/DeleteAction.js.map +0 -1
  84. package/plugins/fileManager/fileImage/EditAction.d.ts +0 -10
  85. package/plugins/fileManager/fileImage/EditAction.js +0 -179
  86. package/plugins/fileManager/fileImage/EditAction.js.map +0 -1
  87. package/plugins/fileManager/fileImage/index.d.ts +0 -2
  88. package/plugins/fileManager/fileImage/index.js +0 -46
  89. package/plugins/fileManager/fileImage/index.js.map +0 -1
  90. package/plugins/fileManager/icons/edit.svg +0 -17
  91. package/plugins/fileManager/icons/round-description-24px.svg +0 -1
  92. package/plugins/fileManager/index.d.ts +0 -2
  93. package/plugins/fileManager/index.js +0 -21
  94. package/plugins/fileManager/index.js.map +0 -1
@@ -1,474 +0,0 @@
1
- "use strict";
2
-
3
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
-
5
- var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
6
-
7
- Object.defineProperty(exports, "__esModule", {
8
- value: true
9
- });
10
- exports.default = void 0;
11
-
12
- var _regeneratorRuntime2 = _interopRequireDefault(require("@babel/runtime/helpers/regeneratorRuntime"));
13
-
14
- var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
15
-
16
- var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
17
-
18
- var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
19
-
20
- var _react = _interopRequireWildcard(require("react"));
21
-
22
- var _bytes = _interopRequireDefault(require("bytes"));
23
-
24
- var _classnames = _interopRequireDefault(require("classnames"));
25
-
26
- var _emotion = require("emotion");
27
-
28
- var _Drawer = require("@webiny/ui/Drawer");
29
-
30
- var _Button = require("@webiny/ui/Button");
31
-
32
- var _getFileTypePlugin = _interopRequireDefault(require("./getFileTypePlugin"));
33
-
34
- var _dayjs = _interopRequireDefault(require("dayjs"));
35
-
36
- var _get = _interopRequireDefault(require("lodash/get"));
37
-
38
- var _set = _interopRequireDefault(require("lodash/set"));
39
-
40
- var _cloneDeep = _interopRequireDefault(require("lodash/cloneDeep"));
41
-
42
- var _Tags = _interopRequireDefault(require("./FileDetails/Tags"));
43
-
44
- var _Name = _interopRequireDefault(require("./FileDetails/Name"));
45
-
46
- var _Tooltip = require("@webiny/ui/Tooltip");
47
-
48
- var _Icon = require("@webiny/ui/Icon");
49
-
50
- var _Typography = require("@webiny/ui/Typography");
51
-
52
- var _reactHotkeyz = require("react-hotkeyz");
53
-
54
- var _content_copyBlack24px = require("./icons/content_copy-black-24px.svg");
55
-
56
- var _delete = require("./icons/delete.svg");
57
-
58
- var _insert_photo24px = require("../../assets/icons/insert_photo-24px.svg");
59
-
60
- var _insert_drive_file24px = require("../../assets/icons/insert_drive_file-24px.svg");
61
-
62
- var _today24px = require("../../assets/icons/today-24px.svg");
63
-
64
- var _highlight24px = require("../../assets/icons/highlight-24px.svg");
65
-
66
- var _FileManagerContext = require("./FileManagerContext");
67
-
68
- var _reactHooks = require("@apollo/react-hooks");
69
-
70
- var _useSnackbar2 = require("../../hooks/useSnackbar");
71
-
72
- var _appSecurity = require("@webiny/app-security");
73
-
74
- var _ConfirmationDialog = require("@webiny/ui/ConfirmationDialog");
75
-
76
- var _graphql = require("./graphql");
77
-
78
- var _i18n = require("@webiny/app/i18n");
79
-
80
- var _mime = _interopRequireDefault(require("mime"));
81
-
82
- var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9;
83
-
84
- var t = _i18n.i18n.ns("app-admin/file-manager/file-details");
85
-
86
- var fileDetailsSidebar = /*#__PURE__*/(0, _emotion.css)({
87
- "&.mdc-drawer": {
88
- width: 360
89
- }
90
- }, "label:fileDetailsSidebar;");
91
- var style = {
92
- wrapper: /*#__PURE__*/(0, _emotion.css)({
93
- height: "100vh",
94
- overflowY: "auto"
95
- }, "label:wrapper;"),
96
- header: /*#__PURE__*/(0, _emotion.css)({
97
- textAlign: "center",
98
- marginBottom: 24,
99
- paddingTop: 16,
100
- "& span": {
101
- textTransform: "capitalize",
102
- color: "var(--mdc-theme-on-surface)",
103
- fontWeight: 600
104
- }
105
- }, "label:header;"),
106
- preview: /*#__PURE__*/(0, _emotion.css)({
107
- boxSizing: "border-box",
108
- display: "flex",
109
- justifyContent: "center",
110
- alignItems: "center",
111
- position: "relative",
112
- width: "100%",
113
- height: 300,
114
- margin: "0 auto 24px",
115
- img: {
116
- objectFit: "contain",
117
- maxHeight: 300,
118
- maxWidth: 300,
119
- width: "100%",
120
- position: "static",
121
- transform: "none"
122
- },
123
- "&.dark": {
124
- backgroundColor: "var(--mdc-theme-background)"
125
- }
126
- }, "label:preview;"),
127
- download: /*#__PURE__*/(0, _emotion.css)({
128
- textAlign: "center",
129
- margin: "0 auto",
130
- width: "100%",
131
- "& .icon--active": {
132
- "&.mdc-icon-button": {
133
- color: "var(--mdc-theme-text-on-primary)"
134
- }
135
- }
136
- }, "label:download;"),
137
- list: /*#__PURE__*/(0, _emotion.css)({
138
- textAlign: "left",
139
- color: "var(--mdc-theme-on-surface)",
140
- li: {
141
- padding: "12px 16px",
142
- lineHeight: "22px",
143
- "li-title": {
144
- display: "flex",
145
- alignItems: "center",
146
- justifyContent: "flex-start",
147
- minHeight: 48,
148
- "& .list-item__title": {
149
- fontWeight: 600
150
- },
151
- "& .list-item__icon": {
152
- marginRight: 24
153
- },
154
- "& .list-item__content": {
155
- flex: "1 0 200px"
156
- }
157
- },
158
- "li-content": {
159
- width: "100%",
160
- display: "block",
161
- "& .list-item__truncate": {
162
- display: "block",
163
- width: "100%",
164
- whiteSpace: "nowrap",
165
- overflow: "hidden",
166
- textOverflow: "ellipsis"
167
- }
168
- }
169
- }
170
- }, "label:list;"),
171
- drawerContent: /*#__PURE__*/(0, _emotion.css)({
172
- "&.mdc-drawer__content": {
173
- height: "auto",
174
- overflowY: "inherit"
175
- }
176
- }, "label:drawerContent;")
177
- };
178
-
179
- var isImage = function isImage(file) {
180
- var fileType = _mime.default.getType(file && file.name);
181
-
182
- if (fileType && typeof fileType === "string") {
183
- return fileType.includes("image");
184
- }
185
-
186
- return false;
187
- };
188
-
189
- var FileDetails = function FileDetails(props) {
190
- var file = props.file,
191
- uploadFile = props.uploadFile,
192
- validateFiles = props.validateFiles;
193
- var filePlugin = (0, _getFileTypePlugin.default)(file);
194
- var actions = (0, _get.default)(filePlugin, "fileDetails.actions") || (0, _get.default)(filePlugin, "actions") || [];
195
-
196
- var _useFileManager = (0, _FileManagerContext.useFileManager)(),
197
- hideFileDetails = _useFileManager.hideFileDetails,
198
- queryParams = _useFileManager.queryParams;
199
-
200
- var _useState = (0, _react.useState)(false),
201
- _useState2 = (0, _slicedToArray2.default)(_useState, 2),
202
- darkImageBackground = _useState2[0],
203
- setDarkImageBackground = _useState2[1];
204
-
205
- var _useSecurity = (0, _appSecurity.useSecurity)(),
206
- identity = _useSecurity.identity,
207
- getPermission = _useSecurity.getPermission;
208
-
209
- var fmFilePermission = (0, _react.useMemo)(function () {
210
- return getPermission("fm.file");
211
- }, [identity]);
212
- var canDelete = (0, _react.useCallback)(function (item) {
213
- // Bail out early if no access
214
- if (!fmFilePermission) {
215
- return false;
216
- }
217
-
218
- if (fmFilePermission.own) {
219
- var identityId = identity ? identity.id || identity.login : null;
220
-
221
- if (!identityId) {
222
- return false;
223
- }
224
-
225
- return (0, _get.default)(item, "createdBy.id") === identityId;
226
- }
227
-
228
- if (typeof fmFilePermission.rwd === "string") {
229
- return fmFilePermission.rwd.includes("d");
230
- }
231
-
232
- return true;
233
- }, [fmFilePermission]);
234
- (0, _reactHotkeyz.useHotkeys)({
235
- zIndex: 55,
236
- disabled: !file,
237
- keys: {
238
- esc: hideFileDetails
239
- }
240
- });
241
-
242
- var _useMutation = (0, _reactHooks.useMutation)(_graphql.DELETE_FILE, {
243
- update: function update(cache) {
244
- var _listTagsData$fileMan;
245
-
246
- // 1. Update files list cache
247
- var data = (0, _cloneDeep.default)(cache.readQuery({
248
- query: _graphql.LIST_FILES,
249
- variables: queryParams
250
- }));
251
-
252
- if (!data) {
253
- data = {
254
- fileManager: {
255
- listFiles: {
256
- data: [],
257
- error: null,
258
- meta: {
259
- hasMoreItems: false,
260
- cursor: null,
261
- totalItem: 0
262
- }
263
- }
264
- }
265
- };
266
- }
267
-
268
- var filteredList = data.fileManager.listFiles.data.filter(function (item) {
269
- return item.id !== file.id;
270
- });
271
- var selectedFile = data.fileManager.listFiles.data.find(function (item) {
272
- return item.id === file.id;
273
- });
274
- cache.writeQuery({
275
- query: _graphql.LIST_FILES,
276
- variables: queryParams,
277
- data: (0, _set.default)(data, "fileManager.listFiles.data", filteredList)
278
- }); // 2. Update "ListTags" cache
279
-
280
- if (!selectedFile || Array.isArray(selectedFile.tags) === false) {
281
- return;
282
- }
283
-
284
- var tagCountMap = {}; // Prepare "tag" count map
285
-
286
- data.fileManager.listFiles.data.forEach(function (file) {
287
- if (!Array.isArray(file.tags)) {
288
- return;
289
- }
290
-
291
- file.tags.forEach(function (tag) {
292
- if (tagCountMap[tag]) {
293
- tagCountMap[tag] += 1;
294
- } else {
295
- tagCountMap[tag] = 1;
296
- }
297
- });
298
- }); // Get tags from cache
299
-
300
- var listTagsData = (0, _cloneDeep.default)(cache.readQuery({
301
- query: _graphql.LIST_TAGS,
302
- variables: {
303
- where: (0, _FileManagerContext.getWhere)(queryParams.scope)
304
- }
305
- })); // Remove selected file tags from list.
306
-
307
- var filteredTags = ((listTagsData === null || listTagsData === void 0 ? void 0 : (_listTagsData$fileMan = listTagsData.fileManager) === null || _listTagsData$fileMan === void 0 ? void 0 : _listTagsData$fileMan.listTags) || []).filter(function (tag) {
308
- if (!selectedFile.tags.includes(tag)) {
309
- return true;
310
- }
311
-
312
- return tagCountMap[tag] > 1;
313
- }); // Write it to cache
314
-
315
- cache.writeQuery({
316
- query: _graphql.LIST_TAGS,
317
- variables: {
318
- where: (0, _FileManagerContext.getWhere)(queryParams.scope)
319
- },
320
- data: (0, _set.default)(data, "fileManager.listTags", filteredTags)
321
- });
322
- }
323
- }),
324
- _useMutation2 = (0, _slicedToArray2.default)(_useMutation, 1),
325
- deleteFile = _useMutation2[0];
326
-
327
- var _useSnackbar = (0, _useSnackbar2.useSnackbar)(),
328
- showSnackbar = _useSnackbar.showSnackbar;
329
-
330
- var renderDeleteImageAction = (0, _react.useCallback)(function (file) {
331
- if (!canDelete(file)) {
332
- return null;
333
- }
334
-
335
- var fileDeleteConfirmationProps = {
336
- title: t(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2.default)(["Delete file"]))),
337
- message: file && /*#__PURE__*/_react.default.createElement("span", null, t(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2.default)(["You're about to delete file {name}. Are you sure you want to continue?"])))({
338
- name: file.name
339
- }))
340
- };
341
- return /*#__PURE__*/_react.default.createElement(_ConfirmationDialog.ConfirmationDialog, Object.assign({}, fileDeleteConfirmationProps, {
342
- "data-testid": "fm-delete-file-confirmation-dialog",
343
- style: {
344
- zIndex: 100
345
- }
346
- }), function (_ref) {
347
- var showConfirmation = _ref.showConfirmation;
348
- return /*#__PURE__*/_react.default.createElement(_Tooltip.Tooltip, {
349
- content: isImage(file) ? /*#__PURE__*/_react.default.createElement("span", null, t(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2.default)(["Delete image"])))) : /*#__PURE__*/_react.default.createElement("span", null, t(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2.default)(["Delete file"])))),
350
- placement: "bottom"
351
- }, /*#__PURE__*/_react.default.createElement(_Button.IconButton, {
352
- "data-testid": "fm-delete-file-button",
353
- icon: /*#__PURE__*/_react.default.createElement(_delete.ReactComponent, {
354
- style: {
355
- margin: "0 8px 0 0"
356
- }
357
- }),
358
- onClick: function onClick() {
359
- return showConfirmation( /*#__PURE__*/(0, _asyncToGenerator2.default)( /*#__PURE__*/(0, _regeneratorRuntime2.default)().mark(function _callee() {
360
- return (0, _regeneratorRuntime2.default)().wrap(function _callee$(_context) {
361
- while (1) {
362
- switch (_context.prev = _context.next) {
363
- case 0:
364
- _context.next = 2;
365
- return deleteFile({
366
- variables: {
367
- id: file.id
368
- }
369
- });
370
-
371
- case 2:
372
- showSnackbar(t(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2.default)(["File deleted successfully."]))));
373
-
374
- case 3:
375
- case "end":
376
- return _context.stop();
377
- }
378
- }
379
- }, _callee);
380
- })));
381
- }
382
- }));
383
- });
384
- }, []);
385
- var fileTypeIcon = (0, _react.useMemo)(function () {
386
- if (file && typeof file.type === "string") {
387
- return file.type.includes("image") ? /*#__PURE__*/_react.default.createElement(_insert_photo24px.ReactComponent, null) : /*#__PURE__*/_react.default.createElement(_insert_drive_file24px.ReactComponent, null);
388
- }
389
-
390
- return /*#__PURE__*/_react.default.createElement(_insert_photo24px.ReactComponent, null);
391
- }, [file]);
392
- return /*#__PURE__*/_react.default.createElement(_Drawer.Drawer, {
393
- className: fileDetailsSidebar,
394
- dir: "rtl",
395
- modal: true,
396
- open: Boolean(file),
397
- onClose: hideFileDetails,
398
- "data-testid": "fm.file-details.drawer"
399
- }, file && /*#__PURE__*/_react.default.createElement("div", {
400
- className: style.wrapper,
401
- dir: "ltr"
402
- }, /*#__PURE__*/_react.default.createElement("div", {
403
- className: style.header
404
- }, /*#__PURE__*/_react.default.createElement(_Typography.Typography, {
405
- use: "headline5"
406
- }, t(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2.default)(["File details"]))))), /*#__PURE__*/_react.default.createElement("div", {
407
- className: (0, _classnames.default)(style.preview, {
408
- dark: darkImageBackground
409
- })
410
- }, filePlugin && filePlugin.render({
411
- /**
412
- * TODO: @ts-refactor
413
- * Figure out which type is the file
414
- */
415
- // @ts-ignore
416
- file: file,
417
- uploadFile: uploadFile,
418
- validateFiles: validateFiles
419
- })), /*#__PURE__*/_react.default.createElement("div", {
420
- className: style.download
421
- }, /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_Tooltip.Tooltip, {
422
- content: /*#__PURE__*/_react.default.createElement("span", null, t(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2.default)(["Copy URL"])))),
423
- placement: "bottom"
424
- }, /*#__PURE__*/_react.default.createElement(_Button.IconButton, {
425
- onClick: function onClick() {
426
- navigator.clipboard.writeText(file.src);
427
- showSnackbar(t(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2.default)(["URL copied successfully."]))));
428
- },
429
- icon: /*#__PURE__*/_react.default.createElement(_content_copyBlack24px.ReactComponent, {
430
- style: {
431
- margin: "0 8px 0 0"
432
- }
433
- })
434
- })), actions.map(function (Component, index) {
435
- return /*#__PURE__*/_react.default.createElement(Component, Object.assign({
436
- key: index
437
- }, props));
438
- }), renderDeleteImageAction(file), /*#__PURE__*/_react.default.createElement(_Tooltip.Tooltip, {
439
- content: t(_templateObject9 || (_templateObject9 = (0, _taggedTemplateLiteral2.default)(["Toggle background"]))),
440
- placement: "bottom"
441
- }, /*#__PURE__*/_react.default.createElement(_Button.IconButton, {
442
- icon: /*#__PURE__*/_react.default.createElement(_highlight24px.ReactComponent, null),
443
- onClick: function onClick() {
444
- return setDarkImageBackground(!darkImageBackground);
445
- },
446
- className: (0, _classnames.default)({
447
- "icon--active": darkImageBackground
448
- })
449
- })))), /*#__PURE__*/_react.default.createElement(_Drawer.DrawerContent, {
450
- dir: "ltr",
451
- className: style.drawerContent
452
- }, /*#__PURE__*/_react.default.createElement("ul", {
453
- className: style.list
454
- }, /*#__PURE__*/_react.default.createElement("li", null, /*#__PURE__*/_react.default.createElement(_Name.default, props)), /*#__PURE__*/_react.default.createElement("li", null, /*#__PURE__*/_react.default.createElement("li-title", null, /*#__PURE__*/_react.default.createElement(_Icon.Icon, {
455
- className: "list-item__icon",
456
- icon: fileTypeIcon
457
- }), /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement(_Typography.Typography, {
458
- use: "subtitle1"
459
- }, file.type), " ", " - ", /*#__PURE__*/_react.default.createElement(_Typography.Typography, {
460
- use: "subtitle1"
461
- }, _bytes.default.format(file.size, {
462
- unitSeparator: " "
463
- }))))), /*#__PURE__*/_react.default.createElement("li", null, /*#__PURE__*/_react.default.createElement("li-title", null, /*#__PURE__*/_react.default.createElement(_Icon.Icon, {
464
- className: "list-item__icon",
465
- icon: /*#__PURE__*/_react.default.createElement(_today24px.ReactComponent, null)
466
- }), /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement(_Typography.Typography, {
467
- use: "subtitle1"
468
- }, (0, _dayjs.default)(file.createdOn).format("DD MMM YYYY [at] HH:mm"))))), /*#__PURE__*/_react.default.createElement("li", null, /*#__PURE__*/_react.default.createElement(_Tags.default, Object.assign({
469
- key: props.file.id
470
- }, props)))))));
471
- };
472
-
473
- var _default = FileDetails;
474
- exports.default = _default;
@@ -1 +0,0 @@
1
- {"version":3,"names":["t","i18n","ns","fileDetailsSidebar","css","width","style","wrapper","height","overflowY","header","textAlign","marginBottom","paddingTop","textTransform","color","fontWeight","preview","boxSizing","display","justifyContent","alignItems","position","margin","img","objectFit","maxHeight","maxWidth","transform","backgroundColor","download","list","li","padding","lineHeight","minHeight","marginRight","flex","whiteSpace","overflow","textOverflow","drawerContent","isImage","file","fileType","mime","getType","name","includes","FileDetails","props","uploadFile","validateFiles","filePlugin","getFileTypePlugin","actions","get","useFileManager","hideFileDetails","queryParams","useState","darkImageBackground","setDarkImageBackground","useSecurity","identity","getPermission","fmFilePermission","useMemo","canDelete","useCallback","item","own","identityId","id","login","rwd","useHotkeys","zIndex","disabled","keys","esc","useMutation","DELETE_FILE","update","cache","data","cloneDeep","readQuery","query","LIST_FILES","variables","fileManager","listFiles","error","meta","hasMoreItems","cursor","totalItem","filteredList","filter","selectedFile","find","writeQuery","set","Array","isArray","tags","tagCountMap","forEach","tag","listTagsData","LIST_TAGS","where","getWhere","scope","filteredTags","listTags","deleteFile","useSnackbar","showSnackbar","renderDeleteImageAction","fileDeleteConfirmationProps","title","message","showConfirmation","fileTypeIcon","type","Boolean","classNames","dark","render","navigator","clipboard","writeText","src","map","Component","index","bytes","format","size","unitSeparator","dayjs","createdOn"],"sources":["FileDetails.tsx"],"sourcesContent":["import React, { useCallback, useMemo, useState } from \"react\";\nimport bytes from \"bytes\";\nimport classNames from \"classnames\";\nimport { css } from \"emotion\";\nimport { Drawer, DrawerContent } from \"@webiny/ui/Drawer\";\nimport { IconButton } from \"@webiny/ui/Button\";\nimport getFileTypePlugin from \"./getFileTypePlugin\";\nimport dayjs from \"dayjs\";\nimport get from \"lodash/get\";\nimport set from \"lodash/set\";\nimport cloneDeep from \"lodash/cloneDeep\";\nimport Tags from \"./FileDetails/Tags\";\nimport Name from \"./FileDetails/Name\";\nimport { Tooltip } from \"@webiny/ui/Tooltip\";\nimport { Icon } from \"@webiny/ui/Icon\";\nimport { Typography } from \"@webiny/ui/Typography\";\n/**\n * Package react-hotkeyz has no types.\n */\n// @ts-ignore\nimport { useHotkeys } from \"react-hotkeyz\";\nimport { ReactComponent as CopyContentIcon } from \"./icons/content_copy-black-24px.svg\";\nimport { ReactComponent as DeleteIcon } from \"./icons/delete.svg\";\nimport { ReactComponent as ImageIcon } from \"../../assets/icons/insert_photo-24px.svg\";\nimport { ReactComponent as FileIcon } from \"../../assets/icons/insert_drive_file-24px.svg\";\nimport { ReactComponent as CalendarIcon } from \"../../assets/icons/today-24px.svg\";\nimport { ReactComponent as HighlightIcon } from \"../../assets/icons/highlight-24px.svg\";\nimport { getWhere, useFileManager } from \"./FileManagerContext\";\nimport { useMutation } from \"@apollo/react-hooks\";\nimport { useSnackbar } from \"~/hooks/useSnackbar\";\nimport { useSecurity } from \"@webiny/app-security\";\nimport { ConfirmationDialog } from \"@webiny/ui/ConfirmationDialog\";\nimport {\n DELETE_FILE,\n DeleteFileMutationResponse,\n DeleteFileMutationVariables,\n LIST_FILES,\n LIST_TAGS,\n ListFilesQueryResponse,\n ListFileTagsQueryResponse\n} from \"./graphql\";\nimport { i18n } from \"@webiny/app/i18n\";\nimport mime from \"mime\";\nimport { FileItem, FileManagerSecurityPermission } from \"./types\";\nimport { FilesRenderChildren } from \"react-butterfiles\";\n\nconst t = i18n.ns(\"app-admin/file-manager/file-details\");\n\nconst fileDetailsSidebar = css({\n \"&.mdc-drawer\": {\n width: 360\n }\n});\n\ndeclare global {\n // eslint-disable-next-line\n namespace JSX {\n interface IntrinsicElements {\n \"li-title\": {\n children?: React.ReactNode;\n };\n\n \"li-content\": {\n children?: React.ReactNode;\n };\n }\n }\n}\n\nconst style: any = {\n wrapper: css({\n height: \"100vh\",\n overflowY: \"auto\"\n }),\n header: css({\n textAlign: \"center\",\n marginBottom: 24,\n paddingTop: 16,\n \"& span\": {\n textTransform: \"capitalize\",\n color: \"var(--mdc-theme-on-surface)\",\n fontWeight: 600\n }\n }),\n preview: css({\n boxSizing: \"border-box\",\n display: \"flex\",\n justifyContent: \"center\",\n alignItems: \"center\",\n position: \"relative\",\n width: \"100%\",\n height: 300,\n margin: \"0 auto 24px\",\n img: {\n objectFit: \"contain\",\n maxHeight: 300,\n maxWidth: 300,\n width: \"100%\",\n position: \"static\",\n transform: \"none\"\n },\n \"&.dark\": {\n backgroundColor: \"var(--mdc-theme-background)\"\n }\n }),\n download: css({\n textAlign: \"center\",\n margin: \"0 auto\",\n width: \"100%\",\n \"& .icon--active\": {\n \"&.mdc-icon-button\": {\n color: \"var(--mdc-theme-text-on-primary)\"\n }\n }\n }),\n list: css({\n textAlign: \"left\",\n color: \"var(--mdc-theme-on-surface)\",\n li: {\n padding: \"12px 16px\",\n lineHeight: \"22px\",\n \"li-title\": {\n display: \"flex\",\n alignItems: \"center\",\n justifyContent: \"flex-start\",\n minHeight: 48,\n \"& .list-item__title\": {\n fontWeight: 600\n },\n \"& .list-item__icon\": {\n marginRight: 24\n },\n \"& .list-item__content\": {\n flex: \"1 0 200px\"\n }\n },\n \"li-content\": {\n width: \"100%\",\n display: \"block\",\n \"& .list-item__truncate\": {\n display: \"block\",\n width: \"100%\",\n whiteSpace: \"nowrap\",\n overflow: \"hidden\",\n textOverflow: \"ellipsis\"\n }\n }\n }\n }),\n drawerContent: css({\n \"&.mdc-drawer__content\": {\n height: \"auto\",\n overflowY: \"inherit\"\n }\n })\n};\ninterface FileDetailsProps {\n canEdit: (item: any) => boolean;\n file: FileItem;\n uploadFile: (files: FileItem[] | FileItem) => Promise<number | null>;\n validateFiles: FilesRenderChildren[\"validateFiles\"];\n [key: string]: any;\n}\n\nconst isImage = (file: FileItem) => {\n const fileType = mime.getType(file && file.name);\n\n if (fileType && typeof fileType === \"string\") {\n return fileType.includes(\"image\");\n }\n\n return false;\n};\n\nconst FileDetails: React.FC<FileDetailsProps> = props => {\n const { file, uploadFile, validateFiles } = props;\n\n const filePlugin = getFileTypePlugin(file);\n const actions: React.FC[] =\n get(filePlugin, \"fileDetails.actions\") || get(filePlugin, \"actions\") || [];\n\n const { hideFileDetails, queryParams } = useFileManager();\n const [darkImageBackground, setDarkImageBackground] = useState(false);\n\n const { identity, getPermission } = useSecurity();\n const fmFilePermission = useMemo((): FileManagerSecurityPermission | null => {\n return getPermission(\"fm.file\");\n }, [identity]);\n const canDelete = useCallback(\n item => {\n // Bail out early if no access\n if (!fmFilePermission) {\n return false;\n }\n if (fmFilePermission.own) {\n const identityId = identity ? identity.id || identity.login : null;\n if (!identityId) {\n return false;\n }\n return get(item, \"createdBy.id\") === identityId;\n }\n if (typeof fmFilePermission.rwd === \"string\") {\n return fmFilePermission.rwd.includes(\"d\");\n }\n return true;\n },\n [fmFilePermission]\n );\n\n useHotkeys({\n zIndex: 55,\n disabled: !file,\n keys: {\n esc: hideFileDetails\n }\n });\n\n const [deleteFile] = useMutation<DeleteFileMutationResponse, DeleteFileMutationVariables>(\n DELETE_FILE,\n {\n update: cache => {\n // 1. Update files list cache\n let data = cloneDeep(\n cache.readQuery<ListFilesQueryResponse>({\n query: LIST_FILES,\n variables: queryParams\n })\n );\n if (!data) {\n data = {\n fileManager: {\n listFiles: {\n data: [],\n error: null,\n meta: {\n hasMoreItems: false,\n cursor: null,\n totalItem: 0\n }\n }\n }\n };\n }\n const filteredList = data.fileManager.listFiles.data.filter(\n (item: FileItem) => item.id !== file.id\n );\n const selectedFile = data.fileManager.listFiles.data.find(\n (item: FileItem) => item.id === file.id\n );\n\n cache.writeQuery({\n query: LIST_FILES,\n variables: queryParams,\n data: set(data, \"fileManager.listFiles.data\", filteredList)\n });\n // 2. Update \"ListTags\" cache\n if (!selectedFile || Array.isArray(selectedFile.tags) === false) {\n return;\n }\n const tagCountMap: Record<string, number> = {};\n // Prepare \"tag\" count map\n data.fileManager.listFiles.data.forEach((file: FileItem) => {\n if (!Array.isArray(file.tags)) {\n return;\n }\n file.tags.forEach(tag => {\n if (tagCountMap[tag]) {\n tagCountMap[tag] += 1;\n } else {\n tagCountMap[tag] = 1;\n }\n });\n });\n\n // Get tags from cache\n const listTagsData = cloneDeep(\n cache.readQuery<ListFileTagsQueryResponse>({\n query: LIST_TAGS,\n variables: { where: getWhere(queryParams.scope) }\n })\n );\n // Remove selected file tags from list.\n const filteredTags = (listTagsData?.fileManager?.listTags || []).filter(\n (tag: string) => {\n if (!selectedFile.tags.includes(tag)) {\n return true;\n }\n return tagCountMap[tag] > 1;\n }\n );\n\n // Write it to cache\n cache.writeQuery({\n query: LIST_TAGS,\n variables: { where: getWhere(queryParams.scope) },\n data: set(data, \"fileManager.listTags\", filteredTags)\n });\n }\n }\n );\n const { showSnackbar } = useSnackbar();\n\n const renderDeleteImageAction = useCallback(file => {\n if (!canDelete(file)) {\n return null;\n }\n const fileDeleteConfirmationProps = {\n title: t`Delete file`,\n message: file && (\n <span>\n {t`You're about to delete file {name}. Are you sure you want to continue?`({\n name: file.name\n })}\n </span>\n )\n };\n return (\n <ConfirmationDialog\n {...fileDeleteConfirmationProps}\n data-testid={\"fm-delete-file-confirmation-dialog\"}\n style={{ zIndex: 100 }}\n >\n {({ showConfirmation }) => {\n return (\n <Tooltip\n content={\n isImage(file) ? (\n <span>{t`Delete image`}</span>\n ) : (\n <span>{t`Delete file`}</span>\n )\n }\n placement={\"bottom\"}\n >\n <IconButton\n data-testid={\"fm-delete-file-button\"}\n icon={<DeleteIcon style={{ margin: \"0 8px 0 0\" }} />}\n onClick={() =>\n showConfirmation(async () => {\n await deleteFile({\n variables: {\n id: file.id\n }\n });\n showSnackbar(t`File deleted successfully.`);\n })\n }\n />\n </Tooltip>\n );\n }}\n </ConfirmationDialog>\n );\n }, []);\n\n const fileTypeIcon = useMemo(() => {\n if (file && typeof file.type === \"string\") {\n return file.type.includes(\"image\") ? <ImageIcon /> : <FileIcon />;\n }\n return <ImageIcon />;\n }, [file]);\n\n return (\n <Drawer\n className={fileDetailsSidebar}\n dir=\"rtl\"\n modal\n open={Boolean(file)}\n onClose={hideFileDetails}\n data-testid={\"fm.file-details.drawer\"}\n >\n {file && (\n <div className={style.wrapper} dir=\"ltr\">\n <div className={style.header}>\n <Typography use={\"headline5\"}>{t`File details`}</Typography>\n </div>\n <div\n className={classNames(style.preview, {\n dark: darkImageBackground\n })}\n >\n {filePlugin &&\n filePlugin.render({\n /**\n * TODO: @ts-refactor\n * Figure out which type is the file\n */\n // @ts-ignore\n file,\n uploadFile,\n validateFiles\n })}\n </div>\n <div className={style.download}>\n <>\n <Tooltip content={<span>{t`Copy URL`}</span>} placement={\"bottom\"}>\n <IconButton\n onClick={() => {\n navigator.clipboard.writeText(file.src);\n showSnackbar(t`URL copied successfully.`);\n }}\n icon={<CopyContentIcon style={{ margin: \"0 8px 0 0\" }} />}\n />\n </Tooltip>\n\n {actions.map((Component: React.FC, index: number) => (\n <Component key={index} {...props} />\n ))}\n {renderDeleteImageAction(file)}\n {/* Render background switcher */}\n <Tooltip content={t`Toggle background`} placement={\"bottom\"}>\n <IconButton\n icon={<HighlightIcon />}\n onClick={() => setDarkImageBackground(!darkImageBackground)}\n className={classNames({ \"icon--active\": darkImageBackground })}\n />\n </Tooltip>\n </>\n </div>\n <DrawerContent dir=\"ltr\" className={style.drawerContent}>\n <ul className={style.list}>\n <li>\n <Name {...props} />\n </li>\n <li>\n <li-title>\n <Icon className={\"list-item__icon\"} icon={fileTypeIcon} />\n <div>\n <Typography use={\"subtitle1\"}>{file.type}</Typography>{\" \"}\n {\" - \"}\n <Typography use={\"subtitle1\"}>\n {bytes.format(file.size, { unitSeparator: \" \" })}\n </Typography>\n </div>\n </li-title>\n </li>\n <li>\n <li-title>\n <Icon className={\"list-item__icon\"} icon={<CalendarIcon />} />\n <div>\n <Typography use={\"subtitle1\"}>\n {dayjs(file.createdOn).format(\"DD MMM YYYY [at] HH:mm\")}\n </Typography>\n </div>\n </li-title>\n </li>\n <li>\n <Tags key={props.file.id} {...props} />\n </li>\n </ul>\n </DrawerContent>\n </div>\n )}\n </Drawer>\n );\n};\n\nexport default FileDetails;\n"],"mappings":"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"}
@@ -1,42 +0,0 @@
1
- import React from "react";
2
- import { FileItem } from "./types";
3
- export declare const getWhere: (scope: string | undefined) => {
4
- tag_not_startsWith: string;
5
- tag_startsWith?: undefined;
6
- } | {
7
- tag_startsWith: string;
8
- tag_not_startsWith?: undefined;
9
- };
10
- interface StateQueryParams {
11
- types: string[];
12
- limit: number;
13
- sort: number;
14
- tags: string[];
15
- scope?: string;
16
- where: Record<string, any>;
17
- }
18
- export interface FileManagerProviderProps {
19
- accept: string[];
20
- tags: string[];
21
- scope?: string;
22
- own?: boolean;
23
- }
24
- declare const FileManagerProvider: React.FC<FileManagerProviderProps>;
25
- declare function useFileManager(): {
26
- selected: any;
27
- toggleSelected(file: FileItem): void;
28
- hasPreviouslyUploadedFiles: any;
29
- setHasPreviouslyUploadedFiles(hasPreviouslyUploadedFiles: boolean): void;
30
- queryParams: any;
31
- setQueryParams(queryParams: StateQueryParams): void;
32
- setDragging(state?: boolean): void;
33
- dragging: any;
34
- setUploading(state?: boolean): void;
35
- uploading: any;
36
- showFileDetails(src: string): void;
37
- hideFileDetails(): void;
38
- showingFileDetails: any;
39
- state: any;
40
- dispatch: any;
41
- };
42
- export { FileManagerProvider, useFileManager };