-
-
Notifications
You must be signed in to change notification settings - Fork 355
/
Copy pathcontroller.js
85 lines (83 loc) · 3.39 KB
/
controller.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
import { Controller } from '@hotwired/stimulus';
class default_1 extends Controller {
initialize() {
this.clear = this.clear.bind(this);
this.onInputChange = this.onInputChange.bind(this);
this.onDragEnter = this.onDragEnter.bind(this);
this.onDragLeave = this.onDragLeave.bind(this);
}
connect() {
this.clear();
this.previewClearButtonTarget.addEventListener('click', this.clear);
this.inputTarget.addEventListener('change', this.onInputChange);
this.element.addEventListener('dragenter', this.onDragEnter);
this.element.addEventListener('dragleave', this.onDragLeave);
this.dispatchEvent('connect');
}
disconnect() {
this.previewClearButtonTarget.removeEventListener('click', this.clear);
this.inputTarget.removeEventListener('change', this.onInputChange);
this.element.removeEventListener('dragenter', this.onDragEnter);
this.element.removeEventListener('dragleave', this.onDragLeave);
}
clear() {
this.inputTarget.value = '';
this.inputTarget.style.display = 'block';
this.placeholderTarget.style.display = 'block';
this.previewTarget.style.display = 'none';
this.previewImageTarget.style.display = 'none';
this.previewImageTarget.style.backgroundImage = 'none';
this.previewFilenameTarget.textContent = '';
this.dispatchEvent('clear');
}
onInputChange(event) {
const files = event.target.files;
if (!files.length) {
return;
}
this.inputTarget.style.display = 'none';
this.placeholderTarget.style.display = 'none';
const firstFile = files[0];
let displayText = firstFile.name;
if (files.length > 1) {
const additionalFiles = files.length - 1;
displayText += ` +${additionalFiles} ${additionalFiles === 1 ? 'file' : 'files'}`;
}
this.previewFilenameTarget.textContent = displayText;
this.previewTarget.style.display = 'flex';
this.previewImageTarget.style.display = 'none';
if (firstFile.type && firstFile.type.indexOf('image') !== -1) {
this._populateImagePreview(firstFile);
}
this.dispatchEvent('change', files);
}
_populateImagePreview(file) {
if (typeof FileReader === 'undefined') {
return;
}
const reader = new FileReader();
reader.addEventListener('load', (event) => {
this.previewImageTarget.style.display = 'block';
this.previewImageTarget.style.backgroundImage = `url("${event.target.result}")`;
});
reader.readAsDataURL(file);
}
onDragEnter() {
this.inputTarget.style.display = 'block';
this.placeholderTarget.style.display = 'block';
this.previewTarget.style.display = 'none';
}
onDragLeave(event) {
event.preventDefault();
if (!this.element.contains(event.relatedTarget)) {
this.inputTarget.style.display = 'none';
this.placeholderTarget.style.display = 'none';
this.previewTarget.style.display = 'block';
}
}
dispatchEvent(name, payload = {}) {
this.dispatch(name, { detail: payload, prefix: 'dropzone' });
}
}
default_1.targets = ['input', 'placeholder', 'preview', 'previewClearButton', 'previewFilename', 'previewImage'];
export { default_1 as default };