PHP Classes

File: jqUploader/js/jqUploader.js

Recommend this page to a friend!
  Classes of José Quijado  >  jqUploader  >  jqUploader/js/jqUploader.js  >  Download  
File: jqUploader/js/jqUploader.js
Role: Auxiliary data
Content type: text/plain
Description: Auxiliary data
Class: jqUploader
Process uploaded files with a JavaScript component
Author: By
Last change:
Date: 5 months ago
Size: 89,567 bytes
 

Contents

Class file image Download
(function ($) {
	$.fn.jqUploader = function (opcionesRecibidas) {
		/* Importación de archivos CSS */
		document.write('<style>');
		document.write('@import url("https://fonts.googleapis.com/css?family=Damion");');
		document.write('@import url("https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css");');
		document.write('</style>');

		/*Se definen los rótulos del plugin en los idiomas deseados.
		Si el idioma pedido por el script llamante no está aquí, se 
		tomará, por defecto, el español ('es-ES')*/
		var	Rotulos = {
			'es-ES':{
				rotuloDeEncabezado: 'jqUploader', 
				rotuloAgregarArchivos: 'Agregar archivo(s)', 
				rotuloSubirArchivos: 'Subir archivo(s)', 
				rotuloArrastrarYSoltar: 'Usa el botón \"Agregar archivo(s)\" o arrástralos y suéltalos en la Zona de archivo(s)', 
				rotuloEliminarUnArchivo: 'No enviar este archivo', 
				rotuloEliminarTodosLosArchivos: 'Cancelar todos los archivos', 
				rotuloTipoNoPermitido: 'Hay archivo(s) no admitido(s)', 
				rotuloPesoArchivoNoPermitido: 'Hay archivo(s) demasiado grande(s)', 
				rotuloPesoGlobalNoPermitido: 'El conjunto de archivos supera el peso admitido', 
				rotuloArchivosEnviados: 'Archivo(s) enviado(s)', 
				rotuloDeMinimoDeArchivosNoAlcanzado: 'No hay suficientes archivos', 
				rotuloDeMaximoDeArchivosSuperado: 'Hay demasiados archivos', 
				rotuloTituloDeModalArchivosTransferidos: 'Envío correcto', 
				rotuloTituloDeModalArchivosNoTransferidos: 'Envío interrumpido', 
				rotuloDeModalArchivosTransferidos: 'Se han enviado los datos', 
				rotuloDeModalArchivosNoTransferidos: 'Se ha producido un error', 
				rotuloDeEnvioEnProceso: 'Se están enviando los datos', 
				rotuloDeBotonDeCierreDeModal: 'Aceptar', 
				rotuloDeModalEnvioEnProgreso: 'Envío en curso'
			}, 
			'en-US':{
				rotuloDeEncabezado: 'jqUploader', 
				rotuloAgregarArchivos: 'Add file(s)', 
				rotuloSubirArchivos: 'Upload file(s)', 
				rotuloArrastrarYSoltar: 'Use the \"Add file(s)\" button or drag\'em and drop\'em on the file(s) area', 
				rotuloEliminarUnArchivo: 'Don\'t send this file', 
				rotuloEliminarTodosLosArchivos: 'Clear all files', 
				rotuloTipoNoPermitido: 'There are no allowed file(s)', 
				rotuloPesoArchivoNoPermitido: 'One or more files are too big', 
				rotuloPesoGlobalNoPermitido: 'The global files weight is too big', 
				rotuloArchivosEnviados: 'File(s) sent', 
				rotuloDeMinimoDeArchivosNoAlcanzado: 'There are no quite enough files', 
				rotuloDeMaximoDeArchivosSuperado: 'There are too many files',
				rotuloTituloDeModalArchivosTransferidos: 'Success', 
				rotuloTituloDeModalArchivosNoTransferidos: 'Failure', 
				rotuloDeModalArchivosTransferidos: 'Your data have been sent', 
				rotuloDeModalArchivosNoTransferidos: 'An error happened', 
				rotuloDeEnvioEnProceso: 'Data sending in progress', 
				rotuloDeBotonDeCierreDeModal: 'Accept',
				rotuloDeModalEnvioEnProgreso:'Uploading in progress'
			}, 
			'fr-FR':{
				rotuloDeEncabezado: 'jqUploader', 
				rotuloAgregarArchivos: 'Ajouter des fichiers', 
				rotuloSubirArchivos: 'Envoyer des fichiers', 
				rotuloArrastrarYSoltar: 'Utilisez le bouton \"Ajouter des fichiers\" ou glisser-déposer dans la zone de fichiers', 
				rotuloEliminarUnArchivo: 'Ne pas envoyer ce fichier', 
				rotuloEliminarTodosLosArchivos: 'Annuler tous les fichiers', 
				rotuloTipoNoPermitido: 'Il ne sont pas autorisés fichiers', 
				rotuloPesoArchivoNoPermitido: 'Un ou plusieurs fichiers sont trop volumineux', 
				rotuloPesoGlobalNoPermitido: 'Le poids total des fichiers est trop grand', 
				rotuloArchivosEnviados: 'Les fichiers envoyés', 
				rotuloDeMinimoDeArchivosNoAlcanzado: 'Il n\'y a pas assez de fichiers', 
				rotuloDeMaximoDeArchivosSuperado: 'Trop de fichiers',
				rotuloTituloDeModalArchivosTransferidos: 'Livraison réussie', 
				rotuloTituloDeModalArchivosNoTransferidos: 'Expédition a échoué', 
				rotuloDeModalArchivosTransferidos: 'Vos données ont été envoyées', 
				rotuloDeModalArchivosNoTransferidos: 'Une erreur s\'est produite', 
				rotuloDeEnvioEnProceso: 'Livraison en cours', 
				rotuloDeBotonDeCierreDeModal: 'Accepter',
				rotuloDeModalEnvioEnProgreso: 'Hausse des progrès'
			}
		} 

		this.each(function(){ /* Empieza el procesado del objeto al que se asocia el plugin. */
			/* Definición de opciones por defecto */
			var Options = {
				// Opciones de formulario y envio
				url_destino: 'recibir.php', 
				id_campo_file: 'id_file', 
				name_campo_file: 'name_file', 
				peso_maximo_de_cada_archivo: '2M', 
				peso_maximo_de_la_subida: '10M', 
				tipos_de_archivo: new Array(
					'application/pdf', 
					'application/zip', 
					'application/mp4', 
					'audio/mpeg', 
					'audio/mp4', 
					'audio/mp3', 
					'image/*', 
					'text/plain', 
					'video/mpeg'
				), 
				mostrar_boton_de_subida: true, 
				mostrar_boton_de_borrar_todos: true, 
				minimo_numero_de_archivos: 1, // Nunca debe ser menor que 1
				maximo_numero_de_archivos: 0, // 0 = Sin límite máximo
				/* Los campos complementarios son inherentes a cada archivo que se envíe. 
				Cada uno se definirá, a su vez, como una matriz con cuatro elementos:
					La etiqueta con la que aparece el campo.
					El tipo de campo (actualmente se permite text, date o number)
					El nombre con el que el campo se enviará al script receptor
					Los atributos adicionales, como maxlength (para texto), min o max (para number) */
				campos_complementarios: new Array(), 
				/* Los campos propios de la página en la que se incorpore este plugin, 
				que también deben enviarse al receptor de destino. 
				Cada uno es una cadena con el id del campo en cuestión, y se enviará con ese 
				nombre. */
				campos_procedentes_de_la_pagina: new Array(), 
				// Definición de la capa de archivos.
				anchura: '60%', 
				anchura_min: '500px', 
				altura: '300px', 
				altura_min: '300px', 
				margen_sup: '10px', 
				margen_inf: '10px', 
				margen_izd: 'auto', 
				margen_der: 'auto', 
				color_fondo: 'rgba(200, 200, 200, 1)', 
				borde: '2px dashed black', 
				// Definicion de la capa de encabezado y pie del plugin
				color_fondo_encabezado_y_pie: '#000', 
				// i18n
				lang: 'es-ES', 
				// El botón de envio. Si está vacio, se usará el propio del plugin. Si no, se usará uno de la página.
				boton_de_envio: '', 
				// La funcion callback está prevista para el futuro. De momento, minificado no la ejecuta, por lo que no se incluye
				// funcion_callback: '', 
				// Accion para el envio correcto: "C" Limpia el subidor, y no toca nada en el resto de la pagina.
				// "R" Recarga toda la página
				accion_de_subida_correcta: 'C'
			};

			/*******************************************************************************************************************************************************
			**** DEFINICIÓN DE ICONOS																															****
			********************************************************************************************************************************************************/
			var iconos = new Array();
			//AUDIO.GIF
			iconos[0] = "";

			// VIDEO.GIF
			iconos[1] = "";

			// PDF.GIF
			iconos[2] = "";

			// ZIP.GIF
			iconos[3] = "";

			// TEXTO_PLANO.GIF
			iconos[4] = "";

			// OTROS.GIF
			iconos[5] = "";
			/*******************************************************************************************************************************************************
			**** FINAL DE DEFINICIÓN DE ICONOS																													****
			*******************************************************************************************************************************************************/

			/*******************************************************************************************************************************************
			****		OPCIONES GENERALES 																											****
			*******************************************************************************************************************************************/
			/* Se define una variable para almacenar el peso global de la subida. 
			Esta se define aquí porque se crea cada vez que se instancia el plugin. De este modo 
			se puede incrementar con todos los archivos que añadamos, y se inicia a 0 cuando se carga el 
			documento que usa este uploader. */
			var pesoGlobalDeArchivos = 0;
			// Se extienden las opciones por defecto a partir de las recibidas, y se asocian al objeto.
			var opcionesElegidas = $.extend(Options, opcionesRecibidas);
			this.opciones = opcionesElegidas;

			//i18n
			if (Rotulos[this.opciones.lang] == undefined) this.opciones.lang = "es-ES";
			this.opciones.i18n = Rotulos[this.opciones.lang];

			// Se crean los flags de error de tipos, error de peso de archivo y error de peso global
			this.errorEnTiposMIME = false;
			this.errorDePesoDeArchivo = false;
			this.errorDePesoGLobal = false;
			// Se crea una matriz que alamacenará los objetos FileReader que contendrán los ficheros que se vayan a enviar.
			this.matrizDeArchivosEnviables = new Array();
			/* Se crea una referencia al objeto, que será la que se usará cuando haya que referenciarlo dentro del contexto de funciones, 
			donde "this" no es el objeto principal. */
			var objetoPrincipal = this;
			// Si se ha definido un botón de envio externo al plugin, se agrega la mecánica aquí.
			if (this.opciones.boton_de_envio != ''){
				$('#' + this.opciones.boton_de_envio).on('click', function(e){
					e.preventDefault();
					$(objetoPrincipal).enviarArchivosAlServidor();
				});
			}

			/*******************************************************************************************************************************************
			****		FINAL DE OPCIONES GENERALES 																								****
			*******************************************************************************************************************************************/

			/*******************************************************************************************************************************************
			****		CONSTRUCCIÓN DEL ENTORNO GRÁFICO																							****
			*******************************************************************************************************************************************/
			/* Se le dan estilos al contenedor referenciado en el HTML y que servirá como contenedor global para el subidor de archivos. */
			$(objetoPrincipal).css({
				'min-width': this.opciones['anchura_min'], 
				'width': this.opciones['anchura'], 
				'min-height': this.opciones['altura_min'], 
				'height': this.opciones['altura'], 
				'margin-top': this.opciones['margen_sup'], 
				'margin-bottom': this.opciones['margen_inf'], 
				'margin-left': this.opciones['margen_izd'], 
				'margin-right': this.opciones['margen_der'], 
				'position': 'relative', 
				'padding': '0', 
				'border': 'none'
			});

			/* Creamos el contenedor del encabezado */
			var encabezado = $('<div></div>');
			encabezado.css({
				'z-index': '1', 
				'padding-left': '20px', 
				'width': '100%', 
				'height': '50px', 
				'border': 'none', 
				'background-color': objetoPrincipal.opciones['color_fondo_encabezado_y_pie']
			});
			var signoDeAgregarFicheros = $('<span id="zonaDeSignoMas" class="fa fa-plus" title="' + objetoPrincipal.opciones['i18n']['rotuloAgregarArchivos'] + '"></span>');
			signoDeAgregarFicheros.css({
				'position': 'relative', 
				'top': '4px', 
				'padding': '4px', 
				'color': '#01FF01', 
				'font-size': '40px', 
				'cursor': 'pointer', 
				'float': 'left', 
				'margin-right': '20px'
			});
			var signoDeSubidaDeArchivos = $('<span id="zonaDeSignoSubir" class="fa fa-upload" title="' + objetoPrincipal.opciones['i18n']['rotuloSubirArchivos'] + '"></span>');
			signoDeSubidaDeArchivos.css({
				'position': 'relative', 
				'top': '4px', 
				'padding': '4px', 
				'color': '#006CFF', 
				'font-size': '40px', 
				'cursor': 'pointer', 
				'float': 'left', 
				'margin-right': '20px', 
				'visibility': 'hidden' // A la carga, este botón no es visible
			});
			var signoDeCancelarTodos = $('<span id="zonaDeCancelarSubida" class="fa fa-times-circle-o" title="' + objetoPrincipal.opciones['i18n']['rotuloEliminarTodosLosArchivos'] + '"></span>');
			signoDeCancelarTodos.css({
				'position': 'relative', 
				'top': '4px', 
				'padding': '4px', 
				'color': '#F11313', 
				'font-size': '40px', 
				'cursor': 'pointer', 
				'float': 'left', 
				'margin-right': '20px', 
				'visibility': 'hidden' // A la carga, este botón no es visible
			});
			var zonaDeLogo = $('<span id="zonaDeLogo">' + objetoPrincipal.opciones['i18n']['rotuloDeEncabezado'] + '</span>');
			zonaDeLogo.css({
				'position': 'relative', 
				'top': '10px', 
				'padding': '0', 
				'color': '#97D0EB', 
				'font-size': '30px', 
				'line-height': '30px',  
				'float': 'right', 
				'margin-left': '20px', 
				'margin-right': '20px', 
				'font-family': "'Damion', cursive"
			});
			/* Añadimos el encabezado al contenedor referenciado en HTML */
			signoDeAgregarFicheros.appendTo(encabezado);
			signoDeCancelarTodos.appendTo(encabezado);
			signoDeSubidaDeArchivos.appendTo(encabezado);
			zonaDeLogo.appendTo(encabezado);
			encabezado.appendTo(objetoPrincipal);

			/* Creamos el contenedor para la lista de los ficheros. */
			var contenedorDeFicheros = $('<div></div>');
			var alturaDeContenedorDeFicheros = (parseInt(objetoPrincipal.opciones['altura']) > parseInt(objetoPrincipal.opciones['altura_min']))?(parseInt(objetoPrincipal.opciones['altura']) - 80):(parseInt(objetoPrincipal.opciones['altura_min']) - 80);
			alturaDeContenedorDeFicheros += "px";
			contenedorDeFicheros.css({
				'position':'relative', 
				'top': '0',
				'left': '0', 
				'right': '0',  
				'width': '100%', 
				'height': alturaDeContenedorDeFicheros, 
				'background-color': objetoPrincipal.opciones['color_fondo'], 
				'border': objetoPrincipal.opciones['borde'], 
				'overflow-x': 'hidden', 
				'overflow-y': 'auto'
			});

			/* Añadimos la capa contenedora de archivos al contenendor referenciado en el HTML */
			contenedorDeFicheros.appendTo(objetoPrincipal);

			/* Creamos el pie de contenedor para mensaje estándar de subida */
			var pieDeContenedorEstandar = $('<div class="pie_de_plugin">' + objetoPrincipal.opciones['i18n']['rotuloArrastrarYSoltar'] + '</div>');
			pieDeContenedorEstandar.css({
				'position': 'relative', 
				'left': '0', 
				'right': '0', 
				'bottom': '0', 
				'width': '100%', 
				'height': '30px', 
				'background-color': objetoPrincipal.opciones['color_fondo_encabezado_y_pie'], 
				'border': 'none', 
				'text-align': 'center', 
				'font-family': 'Arial', 
				'font-size': '12px', 
				'line-height': '30px', 
				'color': '#FFF'
			});
			/* Añadimos el pie del contenedor estándar al contenendor referenciado en el HTML */
			pieDeContenedorEstandar.appendTo(objetoPrincipal);

			/* Creamos el pie del contenedor para mensaje de tipo de archivo incorrecto */
			var pieDeContenedorDeTipoIncorrecto = $('<div class="pie_de_plugin">' + objetoPrincipal.opciones['i18n']['rotuloTipoNoPermitido'] + '</div>');
			pieDeContenedorDeTipoIncorrecto.css({
				'position': 'relative', 
				'left': '0', 
				'right': '0', 
				'bottom': '0', 
				'width': '100%', 
				'height': '30px', 
				'background-color': objetoPrincipal.opciones['color_fondo_encabezado_y_pie'], 
				'border': 'none', 
				'text-align': 'center', 
				'font-family': 'Arial', 
				'font-size': '12px', 
				'line-height': '30px', 
				'color': '#F00', 
				'display': 'none'
			});
			/* Añadimos el pie del contenedor de tipos no permitidos al contenendor referenciado en el HTML */
			pieDeContenedorDeTipoIncorrecto.appendTo(objetoPrincipal);

			/* Creamos el pie del contenedor para mensaje de peso de archivo incorrecto */
			var pieDeContenedorDePesoDeArchivoIncorrecto = $('<div class="pie_de_plugin">' + objetoPrincipal.opciones['i18n']['rotuloPesoArchivoNoPermitido'] + '</div>');
			pieDeContenedorDePesoDeArchivoIncorrecto.css({
				'position': 'relative', 
				'left': '0', 
				'right': '0', 
				'bottom': '0', 
				'width': '100%', 
				'height': '30px', 
				'background-color': objetoPrincipal.opciones['color_fondo_encabezado_y_pie'], 
				'border': 'none', 
				'text-align': 'center', 
				'font-family': 'Arial', 
				'font-size': '12px', 
				'line-height': '30px', 
				'color': '#F00', 
				'display': 'none'
			});
			/* Añadimos el pie del contenedor de peso de archivo no permitido al contenendor referenciado en el HTML */
			pieDeContenedorDePesoDeArchivoIncorrecto.appendTo(objetoPrincipal);

			/* Creamos el pie del contenedor para mensaje de peso global incorrecto */
			var pieDeContenedorDePesoGlobalIncorrecto = $('<div class="pie_de_plugin">' + objetoPrincipal.opciones['i18n']['rotuloPesoGlobalNoPermitido'] + '</div>');
			pieDeContenedorDePesoGlobalIncorrecto.css({
				'position': 'relative', 
				'left': '0', 
				'right': '0', 
				'bottom': '0', 
				'width': '100%', 
				'height': '30px', 
				'background-color': objetoPrincipal.opciones['color_fondo_encabezado_y_pie'], 
				'border': 'none', 
				'text-align': 'center', 
				'font-family': 'Arial', 
				'font-size': '12px', 
				'line-height': '30px', 
				'color': '#F00', 
				'display': 'none'
			});
			/* Añadimos el pie del contenedor de peso global no permitido al contenendor referenciado en el HTML */
			pieDeContenedorDePesoGlobalIncorrecto.appendTo(objetoPrincipal);

			/* Creamos el pie del contenedor para mensaje de menos archivos del mínimo */
			var pieDeContenedorDeNumeroDeArchivosInsuficiente = $('<div class="pie_de_plugin">' + objetoPrincipal.opciones['i18n']['rotuloDeMinimoDeArchivosNoAlcanzado'] + '</div>');
			pieDeContenedorDeNumeroDeArchivosInsuficiente.css({
				'position': 'relative', 
				'left': '0', 
				'right': '0', 
				'bottom': '0', 
				'width': '100%', 
				'height': '30px', 
				'background-color': objetoPrincipal.opciones['color_fondo_encabezado_y_pie'], 
				'border': 'none', 
				'text-align': 'center', 
				'font-family': 'Arial', 
				'font-size': '12px', 
				'line-height': '30px', 
				'color': '#F00', 
				'display': 'none'
			});
			/* Añadimos el pie del contenedor de menos archivos del mínimo al contenendor referenciado en el HTML */
			pieDeContenedorDeNumeroDeArchivosInsuficiente.appendTo(objetoPrincipal);

			/* Creamos el pie del contenedor para mensaje de más archivos del máximo */
			var pieDeContenedorDeNumeroDeArchivosExcesivo = $('<div class="pie_de_plugin">' + objetoPrincipal.opciones['i18n']['rotuloDeMaximoDeArchivosSuperado'] + '</div>');
			pieDeContenedorDeNumeroDeArchivosExcesivo.css({
				'position': 'relative', 
				'left': '0', 
				'right': '0', 
				'bottom': '0', 
				'width': '100%', 
				'height': '30px', 
				'background-color': objetoPrincipal.opciones['color_fondo_encabezado_y_pie'], 
				'border': 'none', 
				'text-align': 'center', 
				'font-family': 'Arial', 
				'font-size': '12px', 
				'line-height': '30px', 
				'color': '#F00', 
				'display': 'none'
			});
			/* Añadimos el pie del contenedor de más archivos del máximo al contenendor referenciado en el HTML */
			pieDeContenedorDeNumeroDeArchivosExcesivo.appendTo(objetoPrincipal);

			/* Creamos el pie del contenedor para mensaje de archivos enviados */
			var pieDeContenedorDeArchivosEnviados = $('<div class="pie_de_plugin">' + objetoPrincipal.opciones['i18n']['rotuloArchivosEnviados'] + '</div>');
			pieDeContenedorDeArchivosEnviados.css({
				'position': 'relative', 
				'left': '0', 
				'right': '0', 
				'bottom': '0', 
				'width': '100%', 
				'height': '30px', 
				'background-color': objetoPrincipal.opciones['color_fondo_encabezado_y_pie'], 
				'border': 'none', 
				'text-align': 'center', 
				'font-family': 'Arial', 
				'font-size': '12px', 
				'line-height': '30px', 
				'color': '#00F', 
				'display': 'none'
			});
			/* Añadimos el pie del contenedor de archivos enviados al contenendor referenciado en el HTML */
			pieDeContenedorDeArchivosEnviados.appendTo(objetoPrincipal);
			/*******************************************************************************************************************************************
			****		FINAL DE CONSTRUCCIÓN DEL ENTORNO GRÁFICO																					****
			*******************************************************************************************************************************************/

			/*******************************************************************************************************************************************
			****		CONSTRUCCIÓN DEL FORMULARIO (EN SU CASO) Y DEL CAMPO DE ARCHIVOS															****
			*******************************************************************************************************************************************/
			var cadenaDeFormularioDeEnvio = '<div></div>';
			var formularioDeEnvio = $(cadenaDeFormularioDeEnvio);
			var cadenaDeCampoFile = "<input type='file' id='" + objetoPrincipal.opciones.id_campo_file + "' ";
			cadenaDeCampoFile += "name='" + objetoPrincipal.opciones.name_campo_file + "' multiple style='z-index:0; width:0; height:0; visibility:hidden;'>";
			var campoFile = $(cadenaDeCampoFile);
			/* Campo file y formulario ocultos a la vista */
			campoFile.css({
				'position': 'absolute', 
				'top': '0', 
				'left': '0', 
				'width': '0', 
				'height': '0'
			});
			formularioDeEnvio.css({
				'position': 'absolute', 
				'top': '0', 
				'left': '0', 
				'width': '0', 
				'height': '0'
			});
			/* Se añaden al contenedor global */
			campoFile.appendTo(formularioDeEnvio);
			formularioDeEnvio.appendTo(objetoPrincipal);
			/* Se eliminan variables que ya no son necesarias. */
			cadenaDeFormularioDeEnvio = undefined;
			cadenaDeCampoFile = undefined;
			/*******************************************************************************************************************************************
			****		FINAL DE CONSTRUCCIÓN DEL FORMULARIO (EN SU CASO) Y DEL CAMPO DE ARCHIVOS													****
			*******************************************************************************************************************************************/

			/*******************************************************************************************************************************************
			****		COMPROBACIÓN Y CÁLCULO DE TAMAÑOS MÁXIMOS PERMITIDOS																		****
			*******************************************************************************************************************************************/
			var valorEstablecido, multiplicador, valorNumerico, valorFinal;
			if (objetoPrincipal.opciones.peso_maximo_de_cada_archivo != '0'){
				valorEstablecido = objetoPrincipal.opciones.peso_maximo_de_cada_archivo;
				multiplicador = valorEstablecido.substr(valorEstablecido.length - 1, valorEstablecido.length);
				if (multiplicador != 'K' && multiplicador !='M' && multiplicador !='G'){
					objetoPrincipal.opciones.peso_maximo_de_cada_archivo = 0;
				} else {
					valorNumerico = parseInt(valorEstablecido.substr(0, valorEstablecido.length - 1));
					if (valorNumerico.toString() != valorEstablecido.substr(0, valorEstablecido.length - 1)){
						objetoPrincipal.opciones.peso_maximo_de_cada_archivo = 0;
					} else {
						switch (multiplicador){
							case 'K':
								valorFinal = valorNumerico * 1024;
								break;
							case 'M':
								valorFinal = valorNumerico * 1048576;
								break;
							case 'G':
								valorFinal = valorNumerico * 1073741824;
								break;
						}
						objetoPrincipal.opciones.peso_maximo_de_cada_archivo = valorFinal;
					}
				}
			}

			if (objetoPrincipal.opciones.peso_maximo_de_la_subida != '0'){
				valorEstablecido = objetoPrincipal.opciones.peso_maximo_de_la_subida;
				multiplicador = valorEstablecido.substr(valorEstablecido.length - 1, valorEstablecido.length);
				if (multiplicador != 'K' && multiplicador !='M' && multiplicador !='G'){
					objetoPrincipal.opciones.peso_maximo_de_la_subida = 0;
				} else {
					valorNumerico = parseInt(valorEstablecido.substr(0, valorEstablecido.length - 1));
					if (valorNumerico.toString() != valorEstablecido.substr(0, valorEstablecido.length - 1)){
						objetoPrincipal.opciones.peso_maximo_de_la_subida = 0;
					} else {
						switch (multiplicador){
							case 'K':
								valorFinal = valorNumerico * 1024;
								break;
							case 'M':
								valorFinal = valorNumerico * 1048576;
								break;
							case 'G':
								valorFinal = valorNumerico * 1073741824;
								break;
						}
						objetoPrincipal.opciones.peso_maximo_de_la_subida = valorFinal;
					}
				}
			}

			if (objetoPrincipal.opciones.peso_maximo_de_la_subida < objetoPrincipal.opciones.peso_maximo_de_cada_archivo){
				objetoPrincipal.opciones.peso_maximo_de_cada_archivo = 0;
				objetoPrincipal.opciones.peso_maximo_de_la_subida = 0;
			}
			objetoPrincipal.peso_global_disponible = objetoPrincipal.opciones.peso_maximo_de_la_subida;
			/*******************************************************************************************************************************************
			****		FINAL DE COMPROBACIÓN Y CÁLCULO DE TAMAÑOS MÁXIMOS PERMITIDOS													****
			*******************************************************************************************************************************************/

			/*******************************************************************************************************************************************
			********************************************************************************************************************************************
			****		DETECCIONES DE EVENTOS DEL USUARIO																							****
			********************************************************************************************************************************************
			*******************************************************************************************************************************************/
			/*******************************************************************************************************************************************
			****		FUNCIÓN QUE RESPONDE A LA PULSACIÓN DE AÑADIR ARCHIVOS																		****
			*******************************************************************************************************************************************/
			$('#zonaDeSignoMas').on('click', function(){
				$(objetoPrincipal).mostrarPieDePlugin(pieDeContenedorEstandar);
				campoFile.click();
			});
			/*******************************************************************************************************************************************
			****		FIN DE LA FUNCIÓN QUE RESPONDE A LA PULSACIÓN DE AÑADIR ARCHIVOS															****
			*******************************************************************************************************************************************/

			/*******************************************************************************************************************************************
			****		RESPUESTA A LA SUBIDA DE ARCHIVOS EN EL CAMPO file Y AL DROP EN EL ÁREA CENTRAL												****
			*******************************************************************************************************************************************/
			campoFile.on('change', function(){
				$(objetoPrincipal).checkFiles($(this)[0].files);
				$(objetoPrincipal).createList();
			});

			contenedorDeFicheros.on('dragover', false).on('drop', function (e) {
				event.preventDefault();
				event.stopImmediatePropagation(); 
				event.stopPropagation();
				$(objetoPrincipal).mostrarPieDePlugin(pieDeContenedorEstandar);
				$(objetoPrincipal).checkFiles(event['dataTransfer'].files);
				$(objetoPrincipal).createList();
			});
			/*******************************************************************************************************************************************
			****		FINAL DE RESPUESTA A LA SUBIDA DE ARCHIVOS EN EL CAMPO file Y AL DROP EN EL ÁREA CENTRAL									****
			*******************************************************************************************************************************************/

			/*******************************************************************************************************************************************
			****		RESPUESTA A LA PULSACIÓN DE ELIMINACIÓN DE UN FICHERO INDIVIDUALMENTE														****
			*******************************************************************************************************************************************/
			contenedorDeFicheros.on('click', '.eliminar_fichero', function() {
				$(objetoPrincipal).mostrarPieDePlugin(pieDeContenedorEstandar);
				var id_de_borrador_pulsado = $(this).prop('id').substr($(this).prop('id').lastIndexOf('_') + 1);
				for (var i in objetoPrincipal.matrizDeArchivosEnviables){
					if (objetoPrincipal.matrizDeArchivosEnviables[i]['elements_id'] == id_de_borrador_pulsado){
						objetoPrincipal.peso_global_disponible += parseInt(objetoPrincipal.matrizDeArchivosEnviables[i]['size']);
						objetoPrincipal.matrizDeArchivosEnviables.splice(i, 1);
						break;
					}
				}
				$(objetoPrincipal).createList();

			});
			/*******************************************************************************************************************************************
			****		FINAL DE RESPUESTA A LA PULSACIÓN DE ELIMINACIÓN DE UN FICHERO INDIVIDUALMENTE												****
			*******************************************************************************************************************************************/

			/*******************************************************************************************************************************************
			****		RESPUESTA A LA PULSACIÓN DE ELIMINACIÓN DE TODOS LOS FICHEROS																****
			*******************************************************************************************************************************************/
			$('#zonaDeCancelarSubida').on('click', function(){
				$(objetoPrincipal).mostrarPieDePlugin(pieDeContenedorEstandar);
				objetoPrincipal.peso_global_disponible = objetoPrincipal.opciones.peso_maximo_de_la_subida;
				objetoPrincipal.matrizDeArchivosEnviables = new Array();
				$(objetoPrincipal).createList();
			});
			/*******************************************************************************************************************************************
			****		FINAL DE RESPUESTA A LA PULSACIÓN DE ELIMINACIÓN DE TODOS LOS FICHEROS														****
			*******************************************************************************************************************************************/

			/*******************************************************************************************************************************************
			****		RESPUESTA A LA PULSACIÓN DE SUBIDA DE FICHEROS																				****
			*******************************************************************************************************************************************/
			$('#zonaDeSignoSubir').on('click', function(){
				$(objetoPrincipal).enviarArchivosAlServidor();
			});
			/*******************************************************************************************************************************************
			****		FINAL DE RESPUESTA A LA PULSACIÓN DE SUBIDA DE FICHEROS																		****
			*******************************************************************************************************************************************/
			/*******************************************************************************************************************************************
			********************************************************************************************************************************************
			****		FINAL DE DETECCIONES DE EVENTOS DEL USUARIO																					****
			********************************************************************************************************************************************
			*******************************************************************************************************************************************/

			/*******************************************************************************************************************************************
			****		FUNCIÓN QUE MUESTRA UN PIE PARA EL PLUGIN Y OCULTA LOS DEMÁS																****
			*******************************************************************************************************************************************/
			$.fn.mostrarPieDePlugin = function(pie) {
				$('.pie_de_plugin').css('display', 'none');
				pie.css('display', 'block');
			}
			/*******************************************************************************************************************************************
			****		FINAL DE LA FUNCIÓN QUE MUESTRA UN PIE PARA EL PLUGIN Y OCULTA LOS DEMÁS													****
			*******************************************************************************************************************************************/

			/*******************************************************************************************************************************************
			****		FUNCIÓN QUE COMPRUEBA CADA ARCHIVO SUBIDO, PARA VER SI ES DE UN TIPO mime PERMITIDO O NO EXCEDE EL PESO.					****
			****		TAMBIÉN SE COMPRUEBA EL PESO GLOBAL DE ARCHIVOS.																			****
			*******************************************************************************************************************************************/
			$.fn.checkFiles = function(ficheros) {
				var numeroDeArchivosEnviados = ficheros.length;
				var numeroDeArchivosQueSeAgregaran = ficheros.length;
				var tiposMimeIncorrectos = false;
				var pesosIndividualesIncorrectos = false;
				var pesoGlobalIncorrecto = false;
				/* Comprombamos los tipos MIME de los archivos, para ver si hay alguno incorrecto. */
				for (var i=0; i<numeroDeArchivosEnviados; i++){
					if (ficheros[i]['name'].indexOf('.zip') > -1 && ficheros[i]['type'] == ""){
						var tipoMIME_deEsteFile = 'application/zip';
					} else {
						var tipoMIME_deEsteFile = ficheros[i]['type'];
					}
					/* Comprobamos si el tipo y subtipo mime está en la lista */
					var tipoExisteEnLista = (objetoPrincipal.opciones.tipos_de_archivo.indexOf(tipoMIME_deEsteFile) > -1);
					/* Si el tipo completo no está en la lista, buscamos el tipo principal con comodín de subtipo */
					if (!tipoExisteEnLista){
						var tipoPrincipal = tipoMIME_deEsteFile.substr(0, tipoMIME_deEsteFile.indexOf("/")) + '/*';
						tipoExisteEnLista = (objetoPrincipal.opciones.tipos_de_archivo.indexOf(tipoPrincipal) > -1);
					}
					/* Si, finalmente, no está en la lista, lo eliminamos de la matriz de los enviados 
					y ponemos una marca de tipo de archivo incorrecto. 
					A partir de ahí pasamos al siguiente archivo, ya no seguimos comprobando nada más en este. */
					if (!tipoExisteEnLista){
						ficheros[i]['type_not_allowed'] = true;
						tiposMimeIncorrectos = true;
					} else {
						ficheros[i]['type_not_allowed'] = false;
					}
					if (tiposMimeIncorrectos) $(objetoPrincipal).mostrarPieDePlugin(pieDeContenedorDeTipoIncorrecto);

					/* Si hay un límite establecido de peso individual por archivo, marcamos los que son aptos y los que no */
					if (objetoPrincipal.opciones.peso_maximo_de_cada_archivo != '0'){
						if (ficheros[i]['size'] > objetoPrincipal.opciones.peso_maximo_de_cada_archivo){
							ficheros[i]['size_not_allowed'] = true;
							pesosIndividualesIncorrectos = true;
						}
					} else {
						ficheros[i]['size_not_allowed'] = false;
					}
					if (pesosIndividualesIncorrectos) $(objetoPrincipal).mostrarPieDePlugin(pieDeContenedorDePesoDeArchivoIncorrecto);

					/* Si hay un límite global establecido, se marcan archivos permitidos hasta el límite de peso global.
					Los demás, se marcan como no permitidos. */
					if (objetoPrincipal.opciones.peso_maximo_de_la_subida != '0'){
						if (ficheros[i]['size'] > objetoPrincipal.peso_global_disponible){
							ficheros[i]['blocked_by_global_size'] = true;
							pesoGlobalIncorrecto = true;
						} else {
							objetoPrincipal.peso_global_disponible -= ficheros[i]['size'];
						}
					}
					if (pesoGlobalIncorrecto) $(objetoPrincipal).mostrarPieDePlugin(pieDeContenedorDePesoGlobalIncorrecto);

					/* Si se ha "roto" alguna de las limitaciones impuestas, se descuenta el número de archivos que se agregarán. */
					if (ficheros[i]['type_not_allowed'] || ficheros[i]['size_not_allowed'] || ficheros[i]['blocked_by_global_size']) numeroDeArchivosQueSeAgregaran --;
				}

				/* Si hay archivos que deban agregarse a la cola de subida, se agregan ahora. */
				if (numeroDeArchivosQueSeAgregaran > 0){
					for (var i=0; i<numeroDeArchivosEnviados; i++){
						if (!ficheros[i]['type_not_allowed'] && !ficheros[i]['size_not_allowed'] && !ficheros[i]['blocked_by_global_size']){
							var objetoFile = new FileReader();
							var fichero = ficheros[i];
							objetoFile.readAsDataURL(fichero);
							objetoFile['name'] = fichero['name'];
							objetoFile['type'] = fichero['type'];
							objetoFile['size'] = fichero['size'];
							objetoFile['elements_id'] = $(objetoPrincipal).randomString();
							objetoPrincipal.matrizDeArchivosEnviables.push(objetoFile);
							objetoFile = null;
							fichero = null;
						}
					}
				}
			} // Aquí acaba la función que comprueba los ficheros y sus posible limitación por peso y tipo
			/*******************************************************************************************************************************************
			****		FIN DE LA FUNCIÓN QUE COMPRUEBA CADA ARCHIVO SUBIDO, PARA VER SI ES DE UN TIPO mime PERMITIDO O NO EXCEDE EL PESO.			****
			****		TAMBIÉN SE COMPRUEBA EL PESO GLOBAL DE ARCHIVOS.																			****
			*******************************************************************************************************************************************/

			/*******************************************************************************************************************************************
			****		FUNCIÓN QUE RECREA LA LISTA "VISIBLE" DE LOS ARCHIVOS QUE HAY EN LA COLA DE SUBIDA.											****
			*******************************************************************************************************************************************/
			$.fn.createList = function() {
				/* Se construyen los elementos gráficos para mostrar en la zona de archivos del plugin. 
				Estos elementos se reconstruyen cada vez que se hace una carga de archivos, mientras no 
				se envíen. 
				También se reconstruirá dinámicamente cada vez que se elimine un archivo. */
				contenedorDeFicheros.html('');
				for (var i in objetoPrincipal.matrizDeArchivosEnviables){
					if (objetoPrincipal.matrizDeArchivosEnviables[i]['readyState'] != '2'){
						objetoPrincipal.matrizDeArchivosEnviables[i].onloadend = function(e){
							if (e != undefined) $(objetoPrincipal).renderizarListaDeArchivos(e.target);
						}
					} else {
						$(objetoPrincipal).renderizarListaDeArchivos(objetoPrincipal.matrizDeArchivosEnviables[i]);
					}
				}

				/* Si hay archivos en la matriz de elementos enviables se muestran los iconos de subir y eliminar todos. 
				En caso contrario, estos iconos se ocultan. */
				if (objetoPrincipal.opciones['mostrar_boton_de_borrar_todos']) 
					$('#zonaDeCancelarSubida').css('visibility', (objetoPrincipal.matrizDeArchivosEnviables.length > 0)?'visible':'hidden');
				if (objetoPrincipal.opciones['mostrar_boton_de_subida'])
					$('#zonaDeSignoSubir').css('visibility', (objetoPrincipal.matrizDeArchivosEnviables.length > 0)?'visible':'hidden');
			}
			/*******************************************************************************************************************************************
			****		FUNCIÓN QUE RECREA LA LISTA "VISIBLE" DE LOS ARCHIVOS QUE HAY EN LA COLA DE SUBIDA.											****
			*******************************************************************************************************************************************/

			/*******************************************************************************************************************************************
			****		FUNCIÓN QUE CREA UNA CADENA ALEATORIA QUE SE USARÁ PARA IDS DE ELEMENTOS.													****
			*******************************************************************************************************************************************/
			$.fn.randomString = function() {
				longitud = 16;
				caracteres = "abcdefghijklmnopqrstuvwxyz";
				var cadena = "";
				var max = caracteres.length-1;
				for (var i = 0; i<longitud; i++) cadena += caracteres[Math.floor(Math.random() * (max+1))];
				return cadena;
			}
			/*******************************************************************************************************************************************
			****		FINAL DE FUNCIÓN QUE CREA UNA CADENA ALEATORIA QUE SE USARÁ PARA IDS DE ELEMENTOS.											****
			*******************************************************************************************************************************************/

			/*******************************************************************************************************************************************
			****		FUNCIÓN QUE RENDERIZA LA VISUALIZACIÓN DE LOS ARCHIVOS PARA INCLUIRLA EN LA ZONA CENTRAL.									****
			*******************************************************************************************************************************************/
			$.fn.renderizarListaDeArchivos = function(archivoCargado) {
				var cadenaDeFicheroParaMostrar = "";
				var icono;
				/* Segun el tipo de imagen se determina el icono a mostrar */
				if (archivoCargado['type'].indexOf('image/') > -1){
					icono = archivoCargado['result'];
				} else if(archivoCargado['type'].indexOf('/pdf') > -1) {
					icono = iconos[2];
				} else if(archivoCargado['type'].indexOf('audio/') > -1) {
					icono = iconos[0];
				} else if(archivoCargado['type'].indexOf('text/plain') > -1) {
					icono = iconos[4];
				} else if(archivoCargado['type'].indexOf('video') > -1) {
					icono = iconos[1];
				} else if(archivoCargado['type'].indexOf('/zip') > -1) {
					icono = iconos[3];
				} else {
					icono = iconos[5];
				}

				/* Se crea una capa para mostrar contenido en la zona general de la cola de subida. */
				/* Contenedor global de elemento archivo, que tendrá el icono, nombre, contenido central y 
				papelera de borrado. TODO lo inherente al elemento archivo. */
				cadenaDeFicheroParaMostrar += '<div id="contenedor_' + archivoCargado['elements_id'] + '" style="position:relative; border:1px solid black; ';
				cadenaDeFicheroParaMostrar += 'border-radius: 10px; -moz-border-radius: 10px; -webkit-border-radius: 10px; padding:6px; ';
				cadenaDeFicheroParaMostrar += 'margin:4px auto; width:98%; min-height:112px; display:flex; ';
				cadenaDeFicheroParaMostrar += 'flex-wrap: nowrap; justify-content:space-between;">';
				/* Contenedor izquierdo que, a su vez, alberga el contenedor del icono y el del nombre del archivo. */
				cadenaDeFicheroParaMostrar += '<div style="border:none; min-height: 100px; min-width:80px; display:flex; ';
				cadenaDeFicheroParaMostrar += 'flex-direction: column; justify-content:space-between;">';
				/* Contenedor del icono */
				cadenaDeFicheroParaMostrar += '<div style="border:none; height: 80px; padding: 2px; align-items: center; display:flex;">';
				/* El propio icono */
				cadenaDeFicheroParaMostrar += '<img src="' + icono + '" alt="" style="max-width:90%; max-height:90%; margin: 0 auto;" ';
				cadenaDeFicheroParaMostrar += 'id="imagen_' + archivoCargado['elements_id'] + '">';
				cadenaDeFicheroParaMostrar += '</div>'; /* Fin del contenedor del icono */
				/* Contenedor del nombre del archivo */
				cadenaDeFicheroParaMostrar += '<div style="border:none; align-items: center; padding: 2px; align-items: center; display:flex; text-align: center;">';
				cadenaDeFicheroParaMostrar += archivoCargado['name'];
				cadenaDeFicheroParaMostrar += '</div>'; /* Fin del contenedor del nombre del archivo */
				cadenaDeFicheroParaMostrar += '</div>'; /* Fin del contenedor de icono y nombre del archivo */
				/* Contenedor central para HTML complementario, si es el caso. */
				cadenaDeFicheroParaMostrar += '<div style="border:none; min-height: 100px; padding: 4px; flex-grow: 1; align-items: flex-start; display:flex; flex-wrap: wrap; max-width:70%">';
				/* HTML COMPLEMENTARIO */
				for (var i in objetoPrincipal.opciones['campos_complementarios']){
					cadenaDeFicheroParaMostrar += '<div style="border:none; width:100%; font-size: 14px;">';
					cadenaDeFicheroParaMostrar += '<label for="campo_'+ i + '_' + archivoCargado['elements_id'] + '" style="font-weight:bold;">';
					cadenaDeFicheroParaMostrar += objetoPrincipal.opciones['campos_complementarios'][i][0] + '</label>';
					cadenaDeFicheroParaMostrar += '<input type="' + objetoPrincipal.opciones['campos_complementarios'][i][1] + '" ';
					cadenaDeFicheroParaMostrar += 'id="'+ objetoPrincipal.opciones['campos_complementarios'][i][2] + '_' + archivoCargado['elements_id'] + '" ';
					cadenaDeFicheroParaMostrar += 'class="form-control campo_complementario" ';
					if (objetoPrincipal.opciones['campos_complementarios'][i][3] != undefined) cadenaDeFicheroParaMostrar += objetoPrincipal.opciones['campos_complementarios'][i][3];
					cadenaDeFicheroParaMostrar += '	>';
					cadenaDeFicheroParaMostrar += '</div>';
				}
				cadenaDeFicheroParaMostrar += '</div>';/* Fin del contenedor central para HTML complementario. */
				/* Contenedor para la papelera de borrado. */
				cadenaDeFicheroParaMostrar += '<div style="border:none; min-height: 100px; padding: 2px; width:40px; align-items: center; display:flex;">';
				/* La papelera de borrado */
				cadenaDeFicheroParaMostrar += '<span class="fa fa-trash-o eliminar_fichero" style="border:none; margin: 0 auto; padding: 4px; ';
				cadenaDeFicheroParaMostrar += 'color: red; font-size: 2em; cursor:pointer;" id="borrar_' + archivoCargado['elements_id'] + '"></span>';
				cadenaDeFicheroParaMostrar += '</div>'; /* Fin del contenedor de la papelera de borrado. */
				cadenaDeFicheroParaMostrar += '</div>'; /* Fin del contenedor global del elemento archivo. */
				/* Se crea el icono que se mostrará. */
				var archivo = $(cadenaDeFicheroParaMostrar);
				contenedorDeFicheros.html(contenedorDeFicheros.html() + cadenaDeFicheroParaMostrar);
			}
			/*******************************************************************************************************************************************
			****		FIN DE LA FUNCIÓN QUE RENDERIZA LA VISUALIZACIÓN DE LOS ARCHIVOS PARA INCLUIRLA EN LA ZONA CENTRAL.							****
			*******************************************************************************************************************************************/

			/*******************************************************************************************************************************************
			****		FUNCIÓN QUE ENVIA LOS ARCHIVOS QUE HAY EN LA COLA DE SUBIDA AL SERVIDOR.													****
			*******************************************************************************************************************************************/
			$.fn.enviarArchivosAlServidor = function() {
				$('#' + id_MEP).modal({'show':true, 'backdrop':'static', 'keyboard':false});
				/* Se comprueba que el número de archivos esté entre el mínimo y el máximo. */
				if (objetoPrincipal.matrizDeArchivosEnviables.length < objetoPrincipal.opciones.minimo_numero_de_archivos){
					$(objetoPrincipal).mostrarPieDePlugin(pieDeContenedorDeNumeroDeArchivosInsuficiente);
					$('#' + id_MEP).modal('hide');
					return;
				} else if (objetoPrincipal.opciones.maximo_numero_de_archivos != 0 && objetoPrincipal.matrizDeArchivosEnviables.length > objetoPrincipal.opciones.maximo_numero_de_archivos){
					$(objetoPrincipal).mostrarPieDePlugin(pieDeContenedorDeNumeroDeArchivosExcesivo);
					$('#' + id_MEP).modal('hide');
					return;
				}

				var cadenaDeDatos = '[[';
				$(objetoPrincipal.matrizDeArchivosEnviables).each(function (i){
					var id_fichero = objetoPrincipal.matrizDeArchivosEnviables[i]['elements_id'];
					cadenaDeDatos += '{"name":"' + objetoPrincipal.matrizDeArchivosEnviables[i]['name'] + '",';
					cadenaDeDatos += '"type":"' + objetoPrincipal.matrizDeArchivosEnviables[i]['type'] + '",';
					cadenaDeDatos += '"size":"' + objetoPrincipal.matrizDeArchivosEnviables[i]['size'] + '",';
					cadenaDeDatos += '"randomKey":"' + objetoPrincipal.matrizDeArchivosEnviables[i]['elements_id'] + '",';
					cadenaDeDatos += '"file":"' + objetoPrincipal.matrizDeArchivosEnviables[i]['result'] + '",';
					$(objetoPrincipal.opciones.campos_complementarios).each(function (){
						var nombre_campo = $(this)[2] + "_" + id_fichero;
						var valor_campo = $('#' + nombre_campo).prop('value');
						cadenaDeDatos += '"' + $(this)[2] + '":"' + valor_campo + '",';
					});
					cadenaDeDatos = cadenaDeDatos.substr(0, cadenaDeDatos.length - 1);
					cadenaDeDatos += '},';
				});
				cadenaDeDatos = cadenaDeDatos.substr(0, cadenaDeDatos.length - 1);
				cadenaDeDatos += ']';

				var cadenaCamposPagina = '';
				$(objetoPrincipal.opciones.campos_procedentes_de_la_pagina).each(function (i){
					if ($('#' + objetoPrincipal.opciones.campos_procedentes_de_la_pagina[i]).prop('value') != undefined) {
						cadenaCamposPagina += '"' + objetoPrincipal.opciones.campos_procedentes_de_la_pagina[i] + '":"';
						cadenaCamposPagina += $('#' + objetoPrincipal.opciones.campos_procedentes_de_la_pagina[i]).prop('value') + '",';
					}
				});
				if (cadenaCamposPagina > ''){
					cadenaCamposPagina = cadenaCamposPagina.substr(0, cadenaCamposPagina.length - 1);
					cadenaCamposPagina = ',{' + cadenaCamposPagina + '}';
				}
				cadenaDeDatos += cadenaCamposPagina + ']';
				/* Se envia el paquete de datos por ajax. */
				$.ajax({
					url: objetoPrincipal.opciones.url_destino,
					type: 'POST', // Siempre que se envíen ficheros, por POST, no por GET.var_para_envio_de_datos
					data: {
						cadenaDeDatos:cadenaDeDatos
					}, 
					success: function(resultados){ // En caso de que todo salga bien.
						$('#' + id_MEP).modal('hide');
						matrizResultados = JSON.parse(resultados);
						hecho = matrizResultados.procesado;
						if (hecho == "S"){
							$('#' + id_MEC).modal({'show':true, 'backdrop':'static', 'keyboard':false});
							$('#' + id_MEC).on('hidden.bs.modal', function(){
								if (objetoPrincipal.opciones.accion_de_subida_correcta == 'C'){ // Se limpia el subidor
									// La ejecución del un callback está prevista para el futuro.
									// De momento, minificado no la ejecuta, por lo que no se incluye.
									// if (objetoPrincipal.opciones.funcion_callback > '') eval(objetoPrincipal.opciones.funcion_callback);
									$('#zonaDeCancelarSubida').click();
								} else if (objetoPrincipal.opciones.accion_de_subida_correcta == 'R') { // Se recarga la página
									location.href = location.href;
								}
							});
						} else {
							$('#' + id_MEP).modal('hide');
							$('#' + id_MEF).modal({'show':true, 'backdrop':'static', 'keyboard':false});
						}
					},
					error: function (){ // Si hay algún error.
						$('#' + id_MEP).modal('hide');
						$('#' + id_MEF).modal({'show':true, 'backdrop':'static', 'keyboard':false});
					}
				});
			}
			/*******************************************************************************************************************************************
			****		FINAL DE LA FUNCIÓN QUE ENVIA LOS ARCHIVOS QUE HAY EN LA COLA DE SUBIDA AL SERVIDOR.										****
			*******************************************************************************************************************************************/

			/*******************************************************************************************************************************************************
			**** DEFINICIÓN DE MODALES																															****
			********************************************************************************************************************************************************/
			var prefijoDeModales = $(objetoPrincipal).randomString();

			var id_MEC = prefijoDeModales + '_modalDeEnvioCorrecto';
			var MEC = '<div class="modal fade" tabindex="-1" role="dialog" id="' + id_MEC + '"><!-- Envoltura global del modal -->';
			MEC += '<div class="modal-dialog" role="document"><!-- Contenedor general modal-dialog -->';
			MEC += '<div class="modal-content"><!-- Zona global de los contenidos del modal -->';
			MEC += '<div class="modal-header"><!-- Cabecera del modal -->';
			MEC += '<button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>';
			MEC += '<h4 class="modal-title">' + objetoPrincipal.opciones["i18n"]["rotuloTituloDeModalArchivosTransferidos"] + '</h4>';
			MEC += '</div><!-- Final de cabecera del modal -->';
			MEC += '<div class="modal-body"><!-- Zona principal de contenidos del modal -->';
			MEC += '<p>' + objetoPrincipal.opciones["i18n"]["rotuloDeModalArchivosTransferidos"] + '</p>';
			MEC += '</div><!-- Final de zona principal de contenidos del modal -->';
			MEC += '<div class="modal-footer"><!-- Zona al pie de la ventana modal -->';
			MEC += '<button type="button" class="btn btn-success" data-dismiss="modal" id="' + prefijoDeModales + '_Close">' + objetoPrincipal.opciones["i18n"]["rotuloDeBotonDeCierreDeModal"] + '</button>';
			MEC += '</div><!-- Final de zona al pie de la ventana modal -->';
			MEC += '</div><!-- Final de zona global de los contenidos del modal -->';
			MEC += '</div><!-- Cierre del contenedor general modal-dialog -->';
			MEC += '</div><!-- Cierre de la envoltura global del modal -->';
			var modalDeEnvioCorrecto = $(MEC);
			modalDeEnvioCorrecto.appendTo('body');

			var id_MEF = prefijoDeModales + '_modalDeEnvioFallido';
			var MEF = '<div class="modal fade" tabindex="-1" role="dialog" id="' + id_MEF + '"><!-- Envoltura global del modal -->';
			MEF += '<div class="modal-dialog" role="document"><!-- Contenedor general modal-dialog -->';
			MEF += '<div class="modal-content"><!-- Zona global de los contenidos del modal -->';
			MEF += '<div class="modal-header"><!-- Cabecera del modal -->';
			MEF += '<button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>';
			MEF += '<h4 class="modal-title">' + objetoPrincipal.opciones["i18n"]["rotuloTituloDeModalArchivosNoTransferidos"] + '</h4>';
			MEF += '</div><!-- Final de cabecera del modal -->';
			MEF += '<div class="modal-body"><!-- Zona principal de contenidos del modal -->';
			MEF += '<p>' + objetoPrincipal.opciones["i18n"]["rotuloDeModalArchivosNoTransferidos"] + '</p>';
			MEF += '</div><!-- Final de zona principal de contenidos del modal -->';
			MEF += '<div class="modal-footer"><!-- Zona al pie de la ventana modal -->';
			MEF += '<button type="button" class="btn btn-danger" data-dismiss="modal">' + objetoPrincipal.opciones["i18n"]["rotuloDeBotonDeCierreDeModal"] + '</button>';
			MEF += '</div><!-- Final de zona al pie de la ventana modal -->';
			MEF += '</div><!-- Final de zona global de los contenidos del modal -->';
			MEF += '</div><!-- Cierre del contenedor general modal-dialog -->';
			MEF += '</div><!-- Cierre de la envoltura global del modal -->';
			var modalDeEnvioFallido = $(MEF);
			modalDeEnvioFallido.appendTo('body');

			var id_MEP = prefijoDeModales + '_modalDeEnvioEnProceso';
			var MEP = '<div class="modal fade" tabindex="-1" role="dialog" id="' + id_MEP + '"><!-- Envoltura global del modal -->';
			MEP += '<div class="modal-dialog" role="document"><!-- Contenedor general modal-dialog -->';
			MEP += '<div class="modal-content"><!-- Zona global de los contenidos del modal -->';
			MEP += '<div class="modal-body"><!-- Zona principal de contenidos del modal -->';

			MEP += '<div class="progress">';
			MEP += '<div class="progress-bar progress-bar-striped active" role="progressbar" ';
			MEP += 'aria-valuenow="100" aria-valuemin="0" aria-valuemax="100" style="width:100%">';
			MEP += objetoPrincipal.opciones["i18n"]["rotuloDeModalEnvioEnProgreso"];
			MEP += '</div>';
			MEP += '</div>';

			MEP += '</div><!-- Final de zona principal de contenidos del modal -->';
			MEP += '<div class="modal-footer"><!-- Zona al pie de la ventana modal -->';
			MEP += '</div><!-- Final de zona al pie de la ventana modal -->';
			MEP += '</div><!-- Final de zona global de los contenidos del modal -->';
			MEP += '</div><!-- Cierre del contenedor general modal-dialog -->';
			MEP += '</div><!-- Cierre de la envoltura global del modal -->';
			var modalDeEnvioEnProceso = $(MEP);
			modalDeEnvioEnProceso.appendTo('body');
			/*******************************************************************************************************************************************************
			**** FIN DE DEFINICIÓN DE MODALES																													****
			********************************************************************************************************************************************************/

		});
		return this; // Se devuelve el objeto creado para integrar en el documento.
	}
}(jQuery));
For more information send a message to info at phpclasses dot org.