Skip to content

Instantly share code, notes, and snippets.

@1N0T
Last active August 29, 2019 21:33
Show Gist options
  • Save 1N0T/ce465e9c5d9197f3cc4d4c78db32deff to your computer and use it in GitHub Desktop.
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.
<html lang="es">
<head>
<title>&#x2705; Drag & Drop Files &#x1F4CC; </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