registroJustificacion.js 5.49 KB
Newer Older
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
const listarPersonal = (selectorName) => {
	initSelect2(selectorName, baseURLRest + URI_TRABAJADORES, {title: "nombresapellidos", subtitle: "documentoidentidad"});
};

const listarTipoJustificacion = (nodeIdentifier) => {
	ajaxWebService.get(URI_JUSTIFICACION_TIPO).then((response) => {
		let data = response.data
		let html = "<option>[SELECCIONE]</option>"
		html += data.map((tipoJustificacion) => `<option value="${tipoJustificacion.id}">${tipoJustificacion.descripcion}</option>`)
		$(nodeIdentifier).html(html)
	})
}

const formControls = {
	init() {
		this.initializeRadioButton()
		this.initializeChooseFile()
		pickersNoConflict()
		initDateRangePicker("#dpRangoFechas")
	},
	initializeRadioButton() {
		$(".styled, .multiselect-container input").uniform({
			radioClass: 'choice'
		});
	},
	initializeChooseFile() {
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 86 87 88 89 90 91 92 93 94 95 96 97
		// Modal template
		var modalTemplate = '<div class="modal-dialog modal-lg" role="document">\n' +
			'  <div class="modal-content">\n' +
			'    <div class="modal-header">\n' +
			'      <div class="kv-zoom-actions btn-group">{toggleheader}{fullscreen}{borderless}{close}</div>\n' +
			'      <h6 class="modal-title">{heading} <small><span class="kv-zoom-title"></span></small></h6>\n' +
			'    </div>\n' +
			'    <div class="modal-body">\n' +
			'      <div class="floating-buttons btn-group"></div>\n' +
			'      <div class="kv-zoom-body file-zoom-content"></div>\n' + '{prev} {next}\n' +
			'    </div>\n' +
			'  </div>\n' +
			'</div>\n';

		// Buttons inside zoom modal
		var previewZoomButtonClasses = {
			toggleheader: 'btn btn-default btn-icon btn-xs btn-header-toggle',
			fullscreen: 'btn btn-default btn-icon btn-xs',
			borderless: 'btn btn-default btn-icon btn-xs',
			close: 'btn btn-default btn-icon btn-xs'
		};

		// Icons inside zoom modal classes
		var previewZoomButtonIcons = {
			prev: '<i class="icon-arrow-left32"></i>',
			next: '<i class="icon-arrow-right32"></i>',
			toggleheader: '<i class="icon-menu-open"></i>',
			fullscreen: '<i class="icon-screen-full"></i>',
			borderless: '<i class="icon-alignment-unalign"></i>',
			close: '<i class="icon-cross3"></i>'
		};

		// File actions
		var fileActionSettings = {
			zoomClass: 'btn btn-link btn-xs btn-icon',
			zoomIcon: '<i class="icon-zoomin3"></i>',
			dragClass: 'btn btn-link btn-xs btn-icon',
			dragIcon: '<i class="icon-three-bars"></i>',
			removeClass: 'btn btn-link btn-icon btn-xs',
			removeIcon: '<i class="icon-trash"></i>',
			indicatorNew: '<i class="icon-file-plus text-slate"></i>',
			indicatorSuccess: '<i class="icon-checkmark3 file-icon-large text-success"></i>',
			indicatorError: '<i class="icon-cross2 text-danger"></i>',
			indicatorLoading: '<i class="icon-spinner2 spinner text-muted"></i>'
		};


		$(".file-input-ajax").fileinput({
			uploadUrl: "http://localhost", // server upload action
			uploadAsync: true,
			maxFileCount: 5,
			initialPreview: [],
			fileActionSettings: {
				removeIcon: '<i class="icon-bin"></i>',
				removeClass: 'btn btn-link btn-xs btn-icon',
				uploadIcon: '<i class="icon-upload"></i>',
				uploadClass: 'btn btn-link btn-xs btn-icon',
				zoomIcon: '<i class="icon-zoomin3"></i>',
				zoomClass: 'btn btn-link btn-xs btn-icon',
				indicatorNew: '<i class="icon-file-plus text-slate"></i>',
				indicatorSuccess: '<i class="icon-checkmark3 file-icon-large text-success"></i>',
				indicatorError: '<i class="icon-cross2 text-danger"></i>',
				indicatorLoading: '<i class="icon-spinner2 spinner text-muted"></i>',
			},
			layoutTemplates: {
				icon: '<i class="icon-file-check"></i>',
				modal: modalTemplate
			},
			initialCaption: "Ningún archivo seleccionado",
			previewZoomButtonClasses: previewZoomButtonClasses,
			previewZoomButtonIcons: previewZoomButtonIcons
98 99 100 101
		});
	}
}

102 103 104 105 106 107 108 109
const registrarJustificacion = () => {
	let personal = $("#cboPersonal").select2('data')[0];
	let {
		id: trabajador_id,
		nombres: trabajador_nombres,
		apellidos: trabajador_apellidos,
		documentoidentidad: trabajador_documentoidentidad
	} = personal
110

111 112 113 114 115 116 117 118 119 120
	let daterangepicker = $("#dpRangoFechas").data('daterangepicker')
	let fecha_inicio = daterangepicker.startDate.format('DD/MM/YYYY')
	let fecha_fin = daterangepicker.endDate.format('DD/MM/YYYY')
	let tipojustificacion_id = $("#cboTipoJustificacion").val()
	let tipojustificacion_descripcion = $("#cboTipoJustificacion option:selected").text()
	let hora_ingreso = $("#txtHora").val()
	let motivo = $("#txtMotivo").val();
	let observacion = $("#txtObservacion").val()
	let numero_documentos_adjuntos = $("#txtNumeroDocumentosAdjuntos").val()
	let documentos_adjuntados = ""
121 122 123 124 125 126 127 128 129 130 131 132

	let documentosSeleccionados = $("#cfDocumentos")[0].files;

	let documentos = []
//	documentosSeleccionados.forEach((file) => {
//	})

	for (let i = 0, length = documentosSeleccionados.length; i < length; i++) {
		documentos.push({url: "https://picsum.photos/300/300/?random"})
	}

	let estado = 0
133 134 135 136 137 138 139 140 141 142 143 144 145 146

	let params = {
		trabajador_id,
		trabajador_nombres,
		trabajador_apellidos,
		trabajador_documentoidentidad,
		fecha_inicio,
		fecha_fin,
		hora_ingreso,
		tipojustificacion_id,
		tipojustificacion_descripcion,
		motivo,
		observacion,
		numero_documentos_adjuntos,
147
		documentos,
148 149 150 151 152 153
		estado
	}

	ajaxWebService.post(URI_JUSTIFICACION, params)
		.then((response) => {
			if (response.status) {
154 155 156 157 158 159
				swal({
					type: 'success',
					title: '¡Justificación registrada!',
					showConfirmButton: false,
					timer: 1500
				});
160 161 162
			}
		})
}
163 164 165 166 167

$(document).ready(function () {
	formControls.init()
	listarTipoJustificacion("#cboTipoJustificacion")
	listarPersonal("#cboPersonal")
168
	$("#btnRegistrar").click(registrarJustificacion)
169
});