diff --git a/client/index.html b/client/index.html
index e4752dbe..bac11567 100644
--- a/client/index.html
+++ b/client/index.html
@@ -80,9 +80,7 @@
Open Snapdrop on other devices to send files
File Received
Filename
-
-
-
+
diff --git a/client/scripts/ui.js b/client/scripts/ui.js
index 0c159841..2391daf4 100644
--- a/client/scripts/ui.js
+++ b/client/scripts/ui.js
@@ -234,6 +234,7 @@ class ReceiveDialog extends Dialog {
window.blop.play();
});
this._filesQueue = [];
+ this.$previewBox = this.$el.querySelector('.preview')
}
_nextFile(nextFile) {
@@ -266,10 +267,23 @@ class ReceiveDialog extends Dialog {
$a.click()
return
}
- if(file.mime.split('/')[0] === 'image'){
- console.log('the file is image');
- this.$el.querySelector('.preview').style.visibility = 'inherit';
- this.$el.querySelector("#img-preview").src = url;
+
+ let mime = file.mime.split('/')[0]
+ let previewElement = {
+ image: 'img',
+ audio: 'audio',
+ video: 'video'
+ }
+
+ if(Object.keys(previewElement).indexOf(mime) !== -1){
+ console.log('the file is able to preview');
+ let element = document.createElement(previewElement[mime]);
+ element.src = url;
+ element.controls = true;
+ element.classList = 'element-preview'
+
+ this.$previewBox.style.visibility = 'inherit';
+ this.$previewBox.appendChild(element)
}
this.$el.querySelector('#fileName').textContent = file.name;
@@ -297,8 +311,8 @@ class ReceiveDialog extends Dialog {
}
hide() {
- this.$el.querySelector('.preview').style.visibility = 'hidden';
- this.$el.querySelector("#img-preview").src = "";
+ this.$previewBox.style.visibility = 'hidden';
+ this.$previewBox.innerHTML = '';
super.hide();
this._dequeueFile();
}
diff --git a/client/styles.css b/client/styles.css
index 0a9aca98..c3e573d7 100644
--- a/client/styles.css
+++ b/client/styles.css
@@ -717,8 +717,9 @@ x-dialog x-paper {
color: var(--text-color);
background-color: var(--bg-color-secondary);
}
-/* Image Preview */
-#img-preview{
+/* Image/Video/Audio Preview */
+.element-preview {
+ max-width: 100%;
max-height: 50vh;
margin: auto;
display: block;