vgapp 1.1.5 → 1.1.6
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/CHANGELOG.md +28 -21
- package/README.md +48 -48
- package/agents.md +7 -0
- package/app/langs/en/buttons.json +17 -17
- package/app/langs/en/messages.json +36 -36
- package/app/langs/ru/buttons.json +17 -17
- package/app/langs/ru/messages.json +36 -36
- package/app/modules/vgfilepreview/js/i18n.js +56 -56
- package/app/modules/vgfilepreview/js/renderers/image-modal.js +145 -145
- package/app/modules/vgfilepreview/js/renderers/image.js +92 -92
- package/app/modules/vgfilepreview/js/renderers/index.js +19 -19
- package/app/modules/vgfilepreview/js/renderers/office-modal.js +168 -168
- package/app/modules/vgfilepreview/js/renderers/office.js +79 -79
- package/app/modules/vgfilepreview/js/renderers/pdf-modal.js +260 -260
- package/app/modules/vgfilepreview/js/renderers/pdf.js +76 -76
- package/app/modules/vgfilepreview/js/renderers/playlist.js +71 -71
- package/app/modules/vgfilepreview/js/renderers/text-modal.js +343 -343
- package/app/modules/vgfilepreview/js/renderers/text.js +83 -83
- package/app/modules/vgfilepreview/js/renderers/video-modal.js +272 -272
- package/app/modules/vgfilepreview/js/renderers/video.js +80 -80
- package/app/modules/vgfilepreview/js/renderers/zip-modal.js +522 -522
- package/app/modules/vgfilepreview/js/renderers/zip.js +89 -89
- package/app/modules/vgfilepreview/js/vgfilepreview.js +10 -5
- package/app/modules/vgfilepreview/readme.md +68 -68
- package/app/modules/vgfilepreview/scss/_variables.scss +113 -113
- package/app/modules/vgfilepreview/scss/vgfilepreview.scss +464 -464
- package/app/modules/vgfiles/js/base.js +18 -0
- package/app/modules/vgfiles/js/droppable.js +260 -260
- package/app/modules/vgfiles/js/render.js +153 -153
- package/app/modules/vgfiles/js/vgfiles.js +41 -41
- package/app/modules/vgfiles/readme.md +123 -123
- package/app/modules/vgfiles/scss/_variables.scss +18 -18
- package/app/modules/vgfiles/scss/vgfiles.scss +148 -148
- package/app/modules/vgformsender/js/vgformsender.js +13 -13
- package/app/modules/vgmodal/js/vgmodal.drag.js +332 -332
- package/app/modules/vgmodal/js/vgmodal.js +33 -33
- package/app/modules/vgmodal/js/vgmodal.resize.js +435 -435
- package/app/modules/vgnav/js/vgnav.js +135 -135
- package/app/modules/vgnav/readme.md +67 -67
- package/app/modules/vgnestable/README.md +307 -307
- package/app/modules/vgnestable/scss/_variables.scss +60 -60
- package/app/modules/vgnestable/scss/vgnestable.scss +163 -163
- package/app/modules/vgselect/js/vgselect.js +39 -39
- package/app/modules/vgselect/scss/vgselect.scss +22 -22
- package/app/modules/vgspy/readme.md +28 -28
- package/app/modules/vgtoast/js/vgtoast.drag.js +335 -0
- package/app/modules/vgtoast/js/vgtoast.js +198 -76
- package/app/modules/vgtoast/js/vgtoast.resize.js +437 -0
- package/app/utils/js/components/audio-metadata.js +240 -240
- package/app/utils/js/components/file-icon.js +109 -109
- package/app/utils/js/components/file-preview.js +304 -304
- package/app/utils/js/components/sanitize.js +150 -150
- package/app/utils/js/components/video-metadata.js +140 -140
- package/build/vgapp.css +1 -1
- package/build/vgapp.css.map +1 -1
- package/build/vgapp.js.map +1 -1
- package/index.scss +9 -9
- package/package.json +1 -1
|
@@ -1,145 +1,145 @@
|
|
|
1
|
-
import VGModal from "../../../vgmodal";
|
|
2
|
-
|
|
3
|
-
class ImageModal {
|
|
4
|
-
constructor() {
|
|
5
|
-
this._modalId = 'vg-filepreview-image-modal';
|
|
6
|
-
}
|
|
7
|
-
|
|
8
|
-
static getInstance() {
|
|
9
|
-
if (!ImageModal._instance) {
|
|
10
|
-
ImageModal._instance = new ImageModal();
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
return ImageModal._instance;
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
open(payload = {}) {
|
|
17
|
-
const src = String(payload.src || '').trim();
|
|
18
|
-
if (!src) {
|
|
19
|
-
return;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
this._ensureModal();
|
|
23
|
-
if (!this._modal || !this._image) {
|
|
24
|
-
return;
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
const defaultTitle = String(payload.defaultTitle || '').trim();
|
|
28
|
-
const title = String(payload.title || '').trim();
|
|
29
|
-
this._title.textContent = title || defaultTitle;
|
|
30
|
-
this._image.src = src;
|
|
31
|
-
this._image.alt = title || defaultTitle;
|
|
32
|
-
|
|
33
|
-
this._modal.show();
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
close() {
|
|
37
|
-
if (!this._modal) {
|
|
38
|
-
return;
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
this._modal.hide();
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
_ensureModal() {
|
|
45
|
-
if (this._modal && this._root) {
|
|
46
|
-
return;
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
this._initModal();
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
_initModal() {
|
|
53
|
-
const params = {
|
|
54
|
-
centered: true,
|
|
55
|
-
dismiss: true,
|
|
56
|
-
backdrop: true,
|
|
57
|
-
keyboard: true,
|
|
58
|
-
sizes: {
|
|
59
|
-
width: 'fit-content',
|
|
60
|
-
},
|
|
61
|
-
animation: {
|
|
62
|
-
enable: false
|
|
63
|
-
}
|
|
64
|
-
};
|
|
65
|
-
|
|
66
|
-
const existed = document.getElementById(this._modalId);
|
|
67
|
-
if (existed) {
|
|
68
|
-
this._root = existed;
|
|
69
|
-
this._modal = VGModal.getOrCreateInstance(existed, params);
|
|
70
|
-
this._bindElements(existed);
|
|
71
|
-
this._bindLifecycle(existed);
|
|
72
|
-
return;
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
this._modal = VGModal.build(this._modalId, params, (modalInstance) => {
|
|
76
|
-
const element = modalInstance._element;
|
|
77
|
-
this._root = element;
|
|
78
|
-
element.classList.add('vg-filepreview-image-modal');
|
|
79
|
-
|
|
80
|
-
const body = element.querySelector('.vg-modal-body');
|
|
81
|
-
const content = element.querySelector('.vg-modal-content');
|
|
82
|
-
if (!body || !content) {
|
|
83
|
-
return;
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
body.classList.add('vg-filepreview-image-modal__body');
|
|
87
|
-
body.innerHTML = '';
|
|
88
|
-
|
|
89
|
-
let header = element.querySelector('.vg-modal-header');
|
|
90
|
-
if (!header) {
|
|
91
|
-
header = document.createElement('div');
|
|
92
|
-
header.className = 'vg-modal-header';
|
|
93
|
-
content.prepend(header);
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
this._title = document.createElement('div');
|
|
97
|
-
this._title.className = 'vg-modal-title';
|
|
98
|
-
this._title.textContent = '';
|
|
99
|
-
|
|
100
|
-
this._image = document.createElement('img');
|
|
101
|
-
this._image.className = 'vg-filepreview-image-modal__img';
|
|
102
|
-
this._image.loading = 'eager';
|
|
103
|
-
this._image.decoding = 'async';
|
|
104
|
-
|
|
105
|
-
header.appendChild(this._title);
|
|
106
|
-
body.appendChild(this._image);
|
|
107
|
-
|
|
108
|
-
this._bindLifecycle(element);
|
|
109
|
-
});
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
_bindElements(root) {
|
|
113
|
-
this._title = root.querySelector('.vg-filepreview-image-modal__title');
|
|
114
|
-
this._image = root.querySelector('.vg-filepreview-image-modal__img');
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
_bindLifecycle(root) {
|
|
118
|
-
if (!root || root.hasAttribute('data-vg-filepreview-image-lifecycle-bind')) {
|
|
119
|
-
return;
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
root.setAttribute('data-vg-filepreview-image-lifecycle-bind', 'true');
|
|
123
|
-
root.addEventListener('vg.modal.hidden', () => {
|
|
124
|
-
this._destroyModal();
|
|
125
|
-
});
|
|
126
|
-
}
|
|
127
|
-
|
|
128
|
-
_destroyModal() {
|
|
129
|
-
if (this._modal && typeof this._modal.dispose === 'function') {
|
|
130
|
-
this._modal.dispose();
|
|
131
|
-
}
|
|
132
|
-
|
|
133
|
-
if (this._root && this._root.parentNode) {
|
|
134
|
-
this._root.parentNode.removeChild(this._root);
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
this._root = null;
|
|
138
|
-
this._modal = null;
|
|
139
|
-
this._title = null;
|
|
140
|
-
this._image = null;
|
|
141
|
-
}
|
|
142
|
-
|
|
143
|
-
}
|
|
144
|
-
|
|
145
|
-
export default ImageModal;
|
|
1
|
+
import VGModal from "../../../vgmodal";
|
|
2
|
+
|
|
3
|
+
class ImageModal {
|
|
4
|
+
constructor() {
|
|
5
|
+
this._modalId = 'vg-filepreview-image-modal';
|
|
6
|
+
}
|
|
7
|
+
|
|
8
|
+
static getInstance() {
|
|
9
|
+
if (!ImageModal._instance) {
|
|
10
|
+
ImageModal._instance = new ImageModal();
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
return ImageModal._instance;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
open(payload = {}) {
|
|
17
|
+
const src = String(payload.src || '').trim();
|
|
18
|
+
if (!src) {
|
|
19
|
+
return;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
this._ensureModal();
|
|
23
|
+
if (!this._modal || !this._image) {
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
const defaultTitle = String(payload.defaultTitle || '').trim();
|
|
28
|
+
const title = String(payload.title || '').trim();
|
|
29
|
+
this._title.textContent = title || defaultTitle;
|
|
30
|
+
this._image.src = src;
|
|
31
|
+
this._image.alt = title || defaultTitle;
|
|
32
|
+
|
|
33
|
+
this._modal.show();
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
close() {
|
|
37
|
+
if (!this._modal) {
|
|
38
|
+
return;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
this._modal.hide();
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
_ensureModal() {
|
|
45
|
+
if (this._modal && this._root) {
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
this._initModal();
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
_initModal() {
|
|
53
|
+
const params = {
|
|
54
|
+
centered: true,
|
|
55
|
+
dismiss: true,
|
|
56
|
+
backdrop: true,
|
|
57
|
+
keyboard: true,
|
|
58
|
+
sizes: {
|
|
59
|
+
width: 'fit-content',
|
|
60
|
+
},
|
|
61
|
+
animation: {
|
|
62
|
+
enable: false
|
|
63
|
+
}
|
|
64
|
+
};
|
|
65
|
+
|
|
66
|
+
const existed = document.getElementById(this._modalId);
|
|
67
|
+
if (existed) {
|
|
68
|
+
this._root = existed;
|
|
69
|
+
this._modal = VGModal.getOrCreateInstance(existed, params);
|
|
70
|
+
this._bindElements(existed);
|
|
71
|
+
this._bindLifecycle(existed);
|
|
72
|
+
return;
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
this._modal = VGModal.build(this._modalId, params, (modalInstance) => {
|
|
76
|
+
const element = modalInstance._element;
|
|
77
|
+
this._root = element;
|
|
78
|
+
element.classList.add('vg-filepreview-image-modal');
|
|
79
|
+
|
|
80
|
+
const body = element.querySelector('.vg-modal-body');
|
|
81
|
+
const content = element.querySelector('.vg-modal-content');
|
|
82
|
+
if (!body || !content) {
|
|
83
|
+
return;
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
body.classList.add('vg-filepreview-image-modal__body');
|
|
87
|
+
body.innerHTML = '';
|
|
88
|
+
|
|
89
|
+
let header = element.querySelector('.vg-modal-header');
|
|
90
|
+
if (!header) {
|
|
91
|
+
header = document.createElement('div');
|
|
92
|
+
header.className = 'vg-modal-header';
|
|
93
|
+
content.prepend(header);
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
this._title = document.createElement('div');
|
|
97
|
+
this._title.className = 'vg-modal-title';
|
|
98
|
+
this._title.textContent = '';
|
|
99
|
+
|
|
100
|
+
this._image = document.createElement('img');
|
|
101
|
+
this._image.className = 'vg-filepreview-image-modal__img';
|
|
102
|
+
this._image.loading = 'eager';
|
|
103
|
+
this._image.decoding = 'async';
|
|
104
|
+
|
|
105
|
+
header.appendChild(this._title);
|
|
106
|
+
body.appendChild(this._image);
|
|
107
|
+
|
|
108
|
+
this._bindLifecycle(element);
|
|
109
|
+
});
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
_bindElements(root) {
|
|
113
|
+
this._title = root.querySelector('.vg-filepreview-image-modal__title');
|
|
114
|
+
this._image = root.querySelector('.vg-filepreview-image-modal__img');
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
_bindLifecycle(root) {
|
|
118
|
+
if (!root || root.hasAttribute('data-vg-filepreview-image-lifecycle-bind')) {
|
|
119
|
+
return;
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
root.setAttribute('data-vg-filepreview-image-lifecycle-bind', 'true');
|
|
123
|
+
root.addEventListener('vg.modal.hidden', () => {
|
|
124
|
+
this._destroyModal();
|
|
125
|
+
});
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
_destroyModal() {
|
|
129
|
+
if (this._modal && typeof this._modal.dispose === 'function') {
|
|
130
|
+
this._modal.dispose();
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
if (this._root && this._root.parentNode) {
|
|
134
|
+
this._root.parentNode.removeChild(this._root);
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
this._root = null;
|
|
138
|
+
this._modal = null;
|
|
139
|
+
this._title = null;
|
|
140
|
+
this._image = null;
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
export default ImageModal;
|
|
@@ -1,92 +1,92 @@
|
|
|
1
|
-
import ImageModal from "./image-modal";
|
|
2
|
-
|
|
3
|
-
const IMAGE_EXTENSIONS = new Set([
|
|
4
|
-
'.png',
|
|
5
|
-
'.jpg',
|
|
6
|
-
'.jpeg',
|
|
7
|
-
'.gif',
|
|
8
|
-
'.webp',
|
|
9
|
-
'.svg',
|
|
10
|
-
'.bmp',
|
|
11
|
-
'.tif',
|
|
12
|
-
'.tiff',
|
|
13
|
-
'.heic',
|
|
14
|
-
'.heif',
|
|
15
|
-
'.avif'
|
|
16
|
-
]);
|
|
17
|
-
|
|
18
|
-
class ImageFilePreviewRenderer {
|
|
19
|
-
constructor() {
|
|
20
|
-
this.name = 'image';
|
|
21
|
-
this._modal = ImageModal.getInstance();
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
canRender(context = {}) {
|
|
25
|
-
const ext = String(context?.fileMeta?.ext || '').toLowerCase();
|
|
26
|
-
return IMAGE_EXTENSIONS.has(ext);
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
render(context = {}) {
|
|
30
|
-
const container = context?.previewContainer;
|
|
31
|
-
const nameOnly = Boolean(context?.ui?.nameOnly);
|
|
32
|
-
const i18n = context?.i18n;
|
|
33
|
-
|
|
34
|
-
const src = context?.fileUrl?.href || context?.filePath || '';
|
|
35
|
-
if (!src) {
|
|
36
|
-
return false;
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
const openImage = (event) => {
|
|
40
|
-
if (event) {
|
|
41
|
-
event.preventDefault();
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
this._modal.open({
|
|
45
|
-
src,
|
|
46
|
-
title: context?.fileMeta?.name || i18n?.message('image_title') || '',
|
|
47
|
-
defaultTitle: i18n?.message('image_title') || ''
|
|
48
|
-
});
|
|
49
|
-
};
|
|
50
|
-
|
|
51
|
-
const titleLink = context?.element?.querySelector('.name');
|
|
52
|
-
if (titleLink && !titleLink.hasAttribute('data-vg-filepreview-image-bind')) {
|
|
53
|
-
titleLink.setAttribute('data-vg-filepreview-image-bind', 'true');
|
|
54
|
-
titleLink.classList.add('is-preview-action');
|
|
55
|
-
titleLink.addEventListener('click', openImage);
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
const listImage = context?.element?.closest('.file')?.querySelector('.file-image .file-preview');
|
|
59
|
-
if (listImage && !listImage.hasAttribute('data-vg-filepreview-image-bind')) {
|
|
60
|
-
listImage.setAttribute('data-vg-filepreview-image-bind', 'true');
|
|
61
|
-
listImage.classList.add('is-preview-action');
|
|
62
|
-
listImage.addEventListener('click', openImage);
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
if (nameOnly) {
|
|
66
|
-
return Boolean(titleLink || listImage);
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
if (!container) {
|
|
70
|
-
return false;
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
const trigger = document.createElement('button');
|
|
74
|
-
trigger.type = 'button';
|
|
75
|
-
trigger.className = 'vg-filepreview-image-trigger';
|
|
76
|
-
trigger.textContent = i18n?.button('open_image') || '';
|
|
77
|
-
trigger.addEventListener('click', openImage);
|
|
78
|
-
container.appendChild(trigger);
|
|
79
|
-
|
|
80
|
-
const thumbnail = document.createElement('img');
|
|
81
|
-
thumbnail.className = 'vg-filepreview-image-thumb';
|
|
82
|
-
thumbnail.src = src;
|
|
83
|
-
thumbnail.alt = context?.fileMeta?.name || i18n?.message('image_thumbnail_alt') || '';
|
|
84
|
-
thumbnail.loading = 'lazy';
|
|
85
|
-
thumbnail.addEventListener('click', openImage);
|
|
86
|
-
container.appendChild(thumbnail);
|
|
87
|
-
|
|
88
|
-
return true;
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
|
|
92
|
-
export default ImageFilePreviewRenderer;
|
|
1
|
+
import ImageModal from "./image-modal";
|
|
2
|
+
|
|
3
|
+
const IMAGE_EXTENSIONS = new Set([
|
|
4
|
+
'.png',
|
|
5
|
+
'.jpg',
|
|
6
|
+
'.jpeg',
|
|
7
|
+
'.gif',
|
|
8
|
+
'.webp',
|
|
9
|
+
'.svg',
|
|
10
|
+
'.bmp',
|
|
11
|
+
'.tif',
|
|
12
|
+
'.tiff',
|
|
13
|
+
'.heic',
|
|
14
|
+
'.heif',
|
|
15
|
+
'.avif'
|
|
16
|
+
]);
|
|
17
|
+
|
|
18
|
+
class ImageFilePreviewRenderer {
|
|
19
|
+
constructor() {
|
|
20
|
+
this.name = 'image';
|
|
21
|
+
this._modal = ImageModal.getInstance();
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
canRender(context = {}) {
|
|
25
|
+
const ext = String(context?.fileMeta?.ext || '').toLowerCase();
|
|
26
|
+
return IMAGE_EXTENSIONS.has(ext);
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
render(context = {}) {
|
|
30
|
+
const container = context?.previewContainer;
|
|
31
|
+
const nameOnly = Boolean(context?.ui?.nameOnly);
|
|
32
|
+
const i18n = context?.i18n;
|
|
33
|
+
|
|
34
|
+
const src = context?.fileUrl?.href || context?.filePath || '';
|
|
35
|
+
if (!src) {
|
|
36
|
+
return false;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
const openImage = (event) => {
|
|
40
|
+
if (event) {
|
|
41
|
+
event.preventDefault();
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
this._modal.open({
|
|
45
|
+
src,
|
|
46
|
+
title: context?.fileMeta?.name || i18n?.message('image_title') || '',
|
|
47
|
+
defaultTitle: i18n?.message('image_title') || ''
|
|
48
|
+
});
|
|
49
|
+
};
|
|
50
|
+
|
|
51
|
+
const titleLink = context?.element?.querySelector('.name');
|
|
52
|
+
if (titleLink && !titleLink.hasAttribute('data-vg-filepreview-image-bind')) {
|
|
53
|
+
titleLink.setAttribute('data-vg-filepreview-image-bind', 'true');
|
|
54
|
+
titleLink.classList.add('is-preview-action');
|
|
55
|
+
titleLink.addEventListener('click', openImage);
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
const listImage = context?.element?.closest('.file')?.querySelector('.file-image .file-preview');
|
|
59
|
+
if (listImage && !listImage.hasAttribute('data-vg-filepreview-image-bind')) {
|
|
60
|
+
listImage.setAttribute('data-vg-filepreview-image-bind', 'true');
|
|
61
|
+
listImage.classList.add('is-preview-action');
|
|
62
|
+
listImage.addEventListener('click', openImage);
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
if (nameOnly) {
|
|
66
|
+
return Boolean(titleLink || listImage);
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
if (!container) {
|
|
70
|
+
return false;
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
const trigger = document.createElement('button');
|
|
74
|
+
trigger.type = 'button';
|
|
75
|
+
trigger.className = 'vg-filepreview-image-trigger';
|
|
76
|
+
trigger.textContent = i18n?.button('open_image') || '';
|
|
77
|
+
trigger.addEventListener('click', openImage);
|
|
78
|
+
container.appendChild(trigger);
|
|
79
|
+
|
|
80
|
+
const thumbnail = document.createElement('img');
|
|
81
|
+
thumbnail.className = 'vg-filepreview-image-thumb';
|
|
82
|
+
thumbnail.src = src;
|
|
83
|
+
thumbnail.alt = context?.fileMeta?.name || i18n?.message('image_thumbnail_alt') || '';
|
|
84
|
+
thumbnail.loading = 'lazy';
|
|
85
|
+
thumbnail.addEventListener('click', openImage);
|
|
86
|
+
container.appendChild(thumbnail);
|
|
87
|
+
|
|
88
|
+
return true;
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
export default ImageFilePreviewRenderer;
|
|
@@ -1,19 +1,19 @@
|
|
|
1
|
-
import ImageFilePreviewRenderer from "./image";
|
|
2
|
-
import OfficeFilePreviewRenderer from "./office";
|
|
3
|
-
import PdfFilePreviewRenderer from "./pdf";
|
|
4
|
-
import TextFilePreviewRenderer from "./text";
|
|
5
|
-
import VideoFilePreviewRenderer from "./video";
|
|
6
|
-
import ZipFilePreviewRenderer from "./zip";
|
|
7
|
-
|
|
8
|
-
const createFilePreviewRenderers = () => {
|
|
9
|
-
return [
|
|
10
|
-
new ImageFilePreviewRenderer(),
|
|
11
|
-
new VideoFilePreviewRenderer(),
|
|
12
|
-
new PdfFilePreviewRenderer(),
|
|
13
|
-
new OfficeFilePreviewRenderer(),
|
|
14
|
-
new ZipFilePreviewRenderer(),
|
|
15
|
-
new TextFilePreviewRenderer()
|
|
16
|
-
];
|
|
17
|
-
};
|
|
18
|
-
|
|
19
|
-
export default createFilePreviewRenderers;
|
|
1
|
+
import ImageFilePreviewRenderer from "./image";
|
|
2
|
+
import OfficeFilePreviewRenderer from "./office";
|
|
3
|
+
import PdfFilePreviewRenderer from "./pdf";
|
|
4
|
+
import TextFilePreviewRenderer from "./text";
|
|
5
|
+
import VideoFilePreviewRenderer from "./video";
|
|
6
|
+
import ZipFilePreviewRenderer from "./zip";
|
|
7
|
+
|
|
8
|
+
const createFilePreviewRenderers = () => {
|
|
9
|
+
return [
|
|
10
|
+
new ImageFilePreviewRenderer(),
|
|
11
|
+
new VideoFilePreviewRenderer(),
|
|
12
|
+
new PdfFilePreviewRenderer(),
|
|
13
|
+
new OfficeFilePreviewRenderer(),
|
|
14
|
+
new ZipFilePreviewRenderer(),
|
|
15
|
+
new TextFilePreviewRenderer()
|
|
16
|
+
];
|
|
17
|
+
};
|
|
18
|
+
|
|
19
|
+
export default createFilePreviewRenderers;
|