Last active
August 29, 2019 21:33
-
-
Save 1N0T/ce465e9c5d9197f3cc4d4c78db32deff to your computer and use it in GitHub Desktop.
(HTML javascript) Muestra atributos y contenido de los ficheros arrastrados sobre la división.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<html lang="es"> | |
<head> | |
<title>✅ Drag & Drop Files 📌 </title> | |
<meta charset="UTF-8"/> | |
<style type="text/css"> | |
/* Importamos las fuentes "Work Sans" */ | |
@import url('https://fonts.googleapis.com/css?family=Work+Sans&display=swap'); | |
/* elemento que admintirá drop de ficheros. */ | |
#upload { | |
font-family: "Work Sans", sans-serif; | |
overflow-x: hidden; | |
overflow-y: auto; | |
padding: 20px; | |
margin: 20px; | |
box-shadow: | |
inset 0 -3em 4em rgba(0,136,135,0.1), | |
0 0 0 2px rgb(0,136,135), | |
0.3em 0.3em 1em rgba(0,0,0,0.3); | |
} | |
/* Para prevenir que no se dispare el evento "dragleave" al pasar sobre los elementos hijos. */ | |
#upload * { | |
pointer-events: none; | |
} | |
/* Detalles de ficheros permitidos. */ | |
.fileAllowed { | |
border-radius: 5px; | |
border: 3px solid rgb(0,137,0); | |
padding: 0px; | |
padding-left: 20px; | |
margin: 0px; | |
margin-left: 0px; | |
margin-top: 15px; | |
margin-bottom: 5px; | |
} | |
/* Detalles de ficheros no permitidos. */ | |
.fileNotAllowed { | |
border-radius: 5px; | |
border: 3px solid rgb(137,0,0); | |
padding: 0px; | |
padding-left: 20px; | |
margin: 0px; | |
margin-left: 0px; | |
margin-top: 15px; | |
margin-bottom: 5px; | |
} | |
/* Colocamos logo a la izquierda del encabezado */ | |
#logo { | |
float: left; | |
margin-right: 15px; | |
} | |
</style> | |
</head> | |
<body> | |
<div id='upload'> | |
<img id="logo" src=""> | |
<h1>Drag & Drop file here.</h1> | |
</div> | |
<script type="text/javascript"> | |
// Seleccionamos por id del elemento que soportará el drop de ficheros. | |
var element = document.querySelector('#upload'); | |
// Guardamos la configuración inicial del atributo CSS que modificaremos para indicar visualmente | |
// que se permite realizar el drop de ficheros sobre el mismo. Y definimos el estilo CSS que aplicaremos. | |
var originalBoxShadow = element.style.boxShadow; | |
var enterBoxShadow = "inset 0 -3em 4em rgba(0,136,135,0.1), 0 0 0 2px rgb(0,255,0), 0.3em 0.3em 1em rgba(0,137,0,0.5)"; | |
// Al entrar en el elemento, aplicamos el estilo CSS para indicar que se puede realizar el drop de ficheros. | |
element.addEventListener("dragenter", function (event) { | |
event.preventDefault(); | |
event.target.style.boxShadow = enterBoxShadow; | |
}, false); | |
// Reestablecemos el estilo CSS original al salir del elemento que permite el drop de ficheros. | |
element.addEventListener("dragleave", function (event) { | |
event.preventDefault(); | |
event.target.style.boxShadow = originalBoxShadow; | |
}, false); | |
// Requerido para que el evento sólo sea procesado por nuestro elemento del DOM | |
element.addEventListener("dragover", function (event) { | |
event.preventDefault(); | |
}, false); | |
// Procesamos el "drop" de los ficheros. | |
element.addEventListener("drop", function (event) { | |
// Guardamos la lista de ficheros arrastrados. | |
var files = event.dataTransfer.files; | |
// Reestablecemos estilos CSS originales, para indicar que el proceso ha concluido. | |
event.preventDefault(); | |
event.target.style.boxShadow = originalBoxShadow; | |
// Procesamos la lista de ficheros arrastrados. Como intervienen operaciones asíncronas, creamos | |
// variables locales para cada iteración y evitar que una nueva iteración sobre la lista de ficheros, | |
// modifique los valores anterirores que todavía puedan estar procesandose. | |
for (var i = 0; i < files.length; i++) { | |
console.log(files[i]); | |
// Creamos el objeto lector de ficheros. | |
let reader = new FileReader(); | |
// Guardamos los datos del fichero actual y realizamos el formateo que nos interesa. | |
let file = files[i]; | |
let lastModifiedDate = new Date(file.lastModified); | |
let fileSize = (file.size / 1024).toFixed(2).toLocaleString(); | |
// Creamos la división y el string de plantilla para mostrar los detalles del fichero. | |
let fileAttributes = document.createElement('div'); | |
let fileMmarkup = ` | |
<h4> | |
${file.name} | |
</h4> | |
<pre> | |
<b>Type.............:</b> ${file.type} | |
<b>Size.............:</b> ${fileSize} <b>KB.</b> | |
<b>Last modification: </b>${lastModifiedDate.toLocaleTimeString()} ${lastModifiedDate.toLocaleDateString()} | |
</pre> | |
`; | |
// Procesamos cada tipo de fichero de forma pertinente. | |
switch (file.type.toLowerCase()) { | |
case "text/plain": | |
case "text/html": | |
// Cuando ha finalizado la lectura asíncrona del fichero, añadimos los elemntos al DOM | |
// con los atributos y el contenido del texto del fichero. | |
reader.onloadend = function (event) { | |
console.log(event.target.result); | |
fileAttributes.className = "fileAllowed"; | |
let node = document.createElement("div"); | |
node.innerHTML = reader.result; | |
fileAttributes.innerHTML = fileMmarkup; | |
element.appendChild(fileAttributes); | |
element.appendChild(node); | |
} | |
// Leemos el fichero como texto. | |
reader.readAsText(file); | |
break; | |
case "image/png": | |
case "image/jpeg": | |
// Cuando ha finalizado la lectura asíncrona del fichero, añadimos los elemntos al DOM | |
// con los atributos y el contenido codificado en base64 del fichero de imagen (se | |
// mostrará como una imagen incrustada). | |
reader.onloadend = function (event) { | |
console.log(event.target.result); | |
fileAttributes.className = "fileAllowed"; | |
let node = document.createElement("img"); | |
node.setAttribute( | |
'src', reader.result | |
); | |
fileAttributes.innerHTML = fileMmarkup; | |
element.appendChild(fileAttributes); | |
element.appendChild(node); | |
} | |
// Leemos el fichero binario y lo codificamos con su tipo y contenido en formato base64. | |
reader.readAsDataURL(file); | |
break; | |
default: | |
// Mostramos atributos de ficheros no contemplados. | |
fileAttributes.className = "fileNotAllowed"; | |
fileAttributes.innerHTML = fileMmarkup; | |
element.appendChild(fileAttributes); | |
} | |
} | |
}, false); | |
</script> | |
</body> | |
</html> |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment