/* global defaultImage */ "use strict"; // globals let objFamiliar = [], objExperienciaLaboral = [], objFormacionAcademica = [], objRetencionJudicial = [] let codigoUbigeoNacimiento = 0, codigoUbigeoResidencia = 0, codigoGradoEstudio = 0 let flagExperienciaLaboral = false, flagRegimenPensionario = true, statusFoto = false, flagActualidadFormacionAcademica = false, flagRetencionJudicial = false const getNode = node => document.querySelector(node) const getNodeAll = nodeList => document.querySelectorAll(nodeList) const dontLeaveMe = () => { // Get page title const pageTitle = document.querySelector('title').innerText // Change page title on blur window.addEventListener('blur', (event) => { document.querySelector('title').innerText = ' ¡Hey! ¡No olvides la ficha!' }) // Change page title back on focus window.addEventListener('focus', (event) => { document.querySelector('title').innerText = pageTitle }) } const helpers = { defaultSelect(el) { el.setAttribute('disabled', true) el.innerHTML = '<option value="0">[SELECCIONAR]</option>' $(el).selectpicker('refresh') }, filteredSelect(el, options) { el.removeAttribute('disabled') el.innerHTML = options $(el).selectpicker('refresh') }, createSelectOptions(obj, valueName, textName) { let options = '<option value="0">[SELECCIONAR]</option>' obj.forEach((data) => { options += '<option value="' + data[valueName] + '">' + data[textName] + '</option>' }); return options }, ajaxRequest(obj) { return new Promise((resolve, reject) => { $.ajax({ url: obj.url, type: obj.type, dataType: obj.dataType, data: obj.body, beforeSend: (xhr, settings) => { load(obj.loadingMessage) }, success: (response, textStatus, jqXHR) => { unload() resolve(response) }, error: (jqXHR, textStatus, errorThrown) => { reject({ status: textStatus, message: `Error making the request`, request: obj }) } }) }) }, randomId() { let S4 = () => (((1 + Math.random()) * 0x10000) | 0).toString(16).substring(1) return (S4() + S4() + "-" + S4() + "-" + S4() + "-" + S4() + "-" + S4() + S4() + S4()); }, validateValueFromArray(value, array, x_value) { for (let i = 0; i < array.length; i++) { if (value === array[i][x_value]) { return true; } } return false; }, dateLessThan(str, str2) { str2 = str2 || new Date() if (str2 instanceof Date) { let anio = str2.getFullYear() let mes = str2.getMonth() + 1 let dia = str2.getDate() str2 = `${dia}/${mes}/${anio}` } if (helpers.toDate(str) > helpers.toDate(str2)) { return false } return true }, toDate(str) { let parts = str.split("/"); return new Date(parts[2], parts[1] - 1, parts[0]); }, addObjToDataTable(element, obj) { $(getNode(element)).DataTable().row.add(obj, 1).draw() }, getRow(el, row) { return $(getNode(el)).DataTable().row($(row).parents('tr')) }, setDataTableLocalStorage(objName, table) { if (localStorage.getItem(objName)) { let obj = JSON.parse(localStorage.getItem(objName)) for (let o in obj) { helpers.addObjToDataTable(table, obj[o]) } return obj } }, calculateAge(dateOfBirth) { let date = new Date() let calculateYear = date.getFullYear(); let calculateMonth = date.getMonth(); let calculateDay = date.getDate(); let birthYear = dateOfBirth.getFullYear(); let birthMonth = dateOfBirth.getMonth(); let birthDay = dateOfBirth.getDate(); let age = calculateYear - birthYear; let ageMonth = calculateMonth - birthMonth; let ageDay = calculateDay - birthDay; if (ageMonth < 0 || (ageMonth === 0 && ageDay < 0)) { age = parseInt(age) - 1; } return age; } } const DOMComponents = { init() { this.noEntryInputs() this.initializePluginComponents() this.configComponents(); }, noEntryInputs() { // datos personales new Input({el: '#txtNumeroRUC', param: 'numbers'}).validate() new Input({el: '#txtApellidoPaterno', param: 'letters'}).validate() new Input({el: '#txtApellidoMaterno', param: 'letters'}).validate() new Input({el: '#txtNombre', param: 'letters'}).validate() new Input({el: '#dpFechaNacimiento', param: 'date'}).validate() new Input({el: '#txtTelefonoFijo', param: 'numbers'}).validate() new Input({el: '#txtTelefonoMovil', param: 'numbers'}).validate() //retencion judicial new Input({el: '#txtBenificiarioRetencionJudicial', param: 'letters'}).validate() new Input({el: '#txtBenificiarioRetencionJudicial', rules: 'abcdefghijklmnñopqrstuvwxyzáéíóú°,.-1234567890 '}).validate() new Input({el: '#txtPorcentajeSueldo', param: 'numbers'}).validate() $('#txtPorcentajeSueldo').mask('00.00', {reverse: true}); // datos familiares new Input({el: '#txtApellidoPaternoFamiliar', param: 'letters'}).validate() new Input({el: '#txtApellidoMaternoFamiliar', param: 'letters'}).validate() new Input({el: '#txtNombreFamiliar', param: 'letters'}).validate() new Input({el: '#dpFechaNacimientoFamiliar', param: 'date'}).validate() // new Input({el: '#txtNumeroDocumentoFamiliar', param: 'alphanumeric'}).validate() new Input({el: '#txtTelefonoFamiliar', param: 'numbers'}).validate() // formacion academica new Input({el: '#txtCentroEstudiosFormacionAcademica', rules: 'abcdefghijklmnñopqrstuvwxyzáéíóú°,.-1234567890 '}).validate() new Input({el: '#txtCarreraProfesional', param: 'letters'}).validate() new Input({el: '#dpFechaInicioFormacionAcademica', param: 'date'}).validate() new Input({el: '#dpFechaFinFormacionAcademica', param: 'date'}).validate() // experiencia laboral new Input({el: '#txtEmpresaExperienciaLaboral', param: 'alphanumeric'}).validate() new Input({el: '#txtCargoExperienciaLaboral', param: 'letters'}).validate() new Input({el: '#dpFechaInicioExperienciaLaboral', param: 'date'}).validate() new Input({el: '#dpFechaFinExperienciaLaboral', param: 'date'}).validate() new Input({el: '#txtTelefonoExperienciaLaboral', param: 'numbers'}).validate() }, initializePluginComponents() { // datepicker settings let date = new Date(); $("#dpFechaNacimientoFamiliar, #dpFechaInicioFormacionAcademica, #dpFechaInicioExperienciaLaboral, #dpFechaFinExperienciaLaboral").datepicker({ dateFormat: 'dd/mm/yy', showButtonPanel: false, changeMonth: true, changeYear: true, yearRange: '1900:' + date.getFullYear(), onSelect: function () { $(this).valid() } }); // fecha de nacimiento // date.setFullYear(new Date().getFullYear() - 18); $("#dpFechaNacimiento").datepicker({ minDate: new Date(1900, 1 - 1, 1), maxDate: '-18Y', dateFormat: 'dd/mm/yy', defaultDate: new Date(1970, 1 - 1, 1), changeMonth: true, changeYear: true, yearRange: '-110:-18', onSelect: function () { $(this).valid(); } }); // fecha fin de formacion academica $("#dpFechaFinFormacionAcademica").datepicker({ dateFormat: 'dd/mm/yy', showButtonPanel: false, changeMonth: true, changeYear: true, yearRange: '1900:' + (date.getFullYear() + 10), onSelect: function () { $(this).valid() } }); // datepicker $.datepicker.regional['es'] = { closeText: 'Cerrar', prevText: '<Ant', nextText: 'Sig>', currentText: 'Hoy', monthNames: ['Enero', 'Febrero', 'Marzo', 'Abril', 'Mayo', 'Junio', 'Julio', 'Agosto', 'Septiembre', 'Octubre', 'Noviembre', 'Diciembre'], monthNamesShort: ['Ene', 'Feb', 'Mar', 'Abr', 'May', 'Jun', 'Jul', 'Ago', 'Sep', 'Oct', 'Nov', 'Dic'], dayNames: ['Domingo', 'Lunes', 'Martes', 'Miércoles', 'Jueves', 'Viernes', 'Sábado'], dayNamesShort: ['Dom', 'Lun', 'Mar', 'Mié', 'Jue', 'Vie', 'Sáb'], dayNamesMin: ['Do', 'Lu', 'Ma', 'Mi', 'Ju', 'Vi', 'Sá'], weekHeader: 'Sm', dateFormat: 'dd/mm/yy', firstDay: 1, isRTL: false, showMonthAfterYear: false, yearSuffix: '' }; $.datepicker.setDefaults($.datepicker.regional['es']); // bootstrap select $('.bootstrap-select').selectpicker(); // Image lightbox $('[data-popup="lightbox"]').fancybox({ padding: 3, 'transitionIn': 'elastic', 'transitionOut': 'elastic', 'speedIn': 600, 'speedOut': 200, 'overlayShow': false }); // jasny bootstrap $('div.fileinput-preview').children('img').attr('src', '').css({ "max-height": "180px", "width": "160px", "height": "180px", "object-fit": "cover" }); // Primary $(".control-primary").uniform({ radioClass: 'choice', wrapperClass: 'border-blue text-blue' }); }, configComponents() { getNode('#cboDepartamentoNacimiento').setAttribute('disabled', true) $(getNode('#cboDepartamentoNacimiento')).selectpicker('refresh') getNodeAll('#dpFechaNacimiento, #dpFechaNacimientoFamiliar, #dpFechaInicioFormacionAcademica, #dpFechaFinFormacionAcademica, #dpFechaInicioExperienciaLaboral, #dpFechaFinExperienciaLaboral') .forEach((el) => { el.setAttribute('readonly', true) el.style.cursor = 'pointer' }) getNodeAll('#cboProvinciaNacimiento, #cboDistritoNacimiento, #cboProvinciaResidencia, #cboDistritoResidencia, #cboEstadoEstudioFormacionAcademica') .forEach((el) => helpers.defaultSelect(el)) getNodeAll('#txtNumeroDocumentoFamiliar, #txtEmpresaExperienciaLaboral, \n\ #txtCargoExperienciaLaboral, #dpFechaInicioExperienciaLaboral, \n\ #dpFechaFinExperienciaLaboral, #txtTelefonoExperienciaLaboral, \n\ #btnAgregarExperienciaLaboral, #txtBenificiarioRetencionJudicial, \n\ #txtMotivoRetencionJudicial, #txtPorcentajeSueldo, \n\ #btnAgregarRetencionJudicial') .forEach((el) => el.setAttribute('disabled', true)) if (parseInt(getNode('#codigoTipoDocumento').value) !== 1) { getNode('#mostrarDniDireccionDocumento').style.display = 'none' getNode('#txtDireccionDocumento').setAttribute('disabled', true) getNode('.tp-asterico-dni').style.display = 'none' $('.tp-asterico-dni').parent('label').addClass('text-grey') } }, switchery(node) { let switches = Array.prototype.slice.call(getNodeAll(node)); switches.forEach(function (el) { let switchery = new Switchery(el, {color: '#FFE66D', secondaryColor: '#F7FFF7'}); }); }, radioButton() { $(".styled, .multiselect-container input").uniform({ radioClass: 'choice' }); } } const httpRequest = { datosPersonales: { listarEstadoCivil() { return helpers.ajaxRequest({ url: '../EstadoCivilServlet', type: 'POST', dataType: 'json', loadingMessage: 'Listando estados civiles', body: { accion: 'listarEstadoCivil' } }) }, listarNacionalidad() { return helpers.ajaxRequest({ url: '../NacionalidadServlet', type: 'POST', dataType: 'json', loadingMessage: 'Listando nacionalidades', body: { accion: 'listarNacionalidad' } }) }, listarDepartamentos() { return helpers.ajaxRequest({ url: '../UbigeoServlet', type: 'POST', dataType: 'json', loadingMessage: 'Listado departamentos', body: { accion: 'listarDepartamento' } }) }, listarProvincia(codigoDepartamento) { return helpers.ajaxRequest({ url: '../UbigeoServlet', type: 'POST', dataType: 'json', loadingMessage: 'Listando provincias', body: { accion: 'listarProvincia', codigoDepartamento: codigoDepartamento } }) }, listarDistrito(codigoDepartamento, codigoProvincia) { return helpers.ajaxRequest({ url: '../UbigeoServlet', type: 'POST', dataType: 'json', loadingMessage: 'Listando distritos', body: { accion: 'listarDistrito', codigoDepartamento: codigoDepartamento, codigoProvincia: codigoProvincia } }) }, obtenerUbigeo(codigoDepartamento, codigoProvincia, codigoDistrito) { return helpers.ajaxRequest({ url: '../UbigeoServlet', type: 'POST', dataType: 'json', loadingMessage: 'Obteniendo ubigeo', body: { accion: 'obtenerCodigoUbigeo', codigoDepartamento: codigoDepartamento, codigoProvincia: codigoProvincia, codigoDistrito: codigoDistrito } }) } }, datosFamiliares: { listarParentesco() { return helpers.ajaxRequest({ url: '../ParentescoServlet', type: 'POST', dataType: 'json', loadingMessage: 'Listando parentescos', body: { accion: 'listarParentesco' } }) }, listarTipoDocumento() { return helpers.ajaxRequest({ url: '../TipoDocumentoServlet', type: 'POST', dataType: 'json', loadingMessage: 'Listado documentos', body: { accion: 'listarTipoDocumento' } }) }, obtenerConfiguracionTipoDocumento(codigoTipoDocumento) { return helpers.ajaxRequest({ url: '../TipoDocumentoServlet', type: 'POST', dataType: 'json', loadingMessage: 'Obteniendo configuración del documento', body: { accion: 'obtenerLongitudTipoEntrdadaTipoDocumento', codigoTipoDocumento: codigoTipoDocumento } }) } }, datosFormacionAcademica: { listarGradoEstudio() { return helpers.ajaxRequest({ url: '../NivelEstudioServlet', type: 'POST', dataType: 'json', loadingMessage: 'Listando grado de estudios', body: { accion: 'listarNivelEstudio' } }) }, listarEstadoEstudio(codigoGradoEstudio) { return helpers.ajaxRequest({ url: '../EstadoEstudioServlet', type: 'POST', dataType: 'json', loadingMessage: 'Listando estado de estudios', body: { accion: 'listarEstadoEstudio', codigoNivelEstudio: codigoGradoEstudio } }) }, obtenerGradoEstadoEstudio(codigoGradoEstudio, codigoEstadoEstudio) { return helpers.ajaxRequest({ url: '../NivelEstadoServlet', type: 'POST', dataType: 'json', loadingMessage: 'Obteniendo grado y estado del estudio', body: { accion: 'obtenerNivelEstado', codigoNivelEstudio: codigoGradoEstudio, codigoEstadoEstudio: codigoEstadoEstudio } }) } }, datosRegimenPensionario: { listarRegimenPensionario() { return helpers.ajaxRequest({ url: '../FondoPensionServlet', type: 'POST', dataType: 'json', loadingMessage: 'Listando regimen pensionario', body: { accion: 'listarFondoPension' } }) } }, registrarFicha(obj) { return helpers.ajaxRequest({ url: '../FichaServlet', type: 'POST', dataType: 'json', loadingMessage: 'Validando datos ingresados, espere un momento por favor', body: { accion: 'registrarFicha', json: JSON.stringify(obj) } }) } } const DOMEvents = () => { // datos personales getNode('#cboNacionalidad').addEventListener('change', (e) => { let nacionalidad = parseInt(e.currentTarget.value) codigoUbigeoNacimiento = 0 if (nacionalidad === 144) { getNode('#cboDepartamentoNacimiento').removeAttribute('disabled') $('#cboDepartamentoNacimiento').selectpicker('refresh') } else { getNode('#cboDepartamentoNacimiento').selectedIndex = 0 getNode('#cboDepartamentoNacimiento').setAttribute('disabled', true) $(getNode('#cboDepartamentoNacimiento')).selectpicker('refresh') getNodeAll('#cboProvinciaNacimiento, #cboDistritoNacimiento').forEach((el) => helpers.defaultSelect(el)) } }) getNode('#cboDepartamentoNacimiento').addEventListener('change', (e) => { let departamento = parseInt(e.currentTarget.value) codigoUbigeoNacimiento = 0 if (departamento !== 0) { httpRequest.datosPersonales.listarProvincia(departamento) .then((data) => { let options = helpers.createSelectOptions(data.data.provincias, 'codigoProvincia', 'nombreProvincia') helpers.filteredSelect(getNode('#cboProvinciaNacimiento'), options) helpers.defaultSelect(getNode('#cboDistritoNacimiento')) }) } else { getNodeAll('#cboProvinciaNacimiento, #cboDistritoNacimiento').forEach((el) => helpers.defaultSelect(el)) } }) getNode('#cboProvinciaNacimiento').addEventListener('change', (e) => { let departamento = parseInt(getNode('#cboDepartamentoNacimiento').value) let provincia = parseInt(e.currentTarget.value) codigoUbigeoNacimiento = 0 if (provincia !== 0) { httpRequest.datosPersonales.listarDistrito(departamento, provincia) .then((data) => { let options = helpers.createSelectOptions(data.data.distritos, 'codigoDistrito', 'nombreDistrito') helpers.filteredSelect(getNode('#cboDistritoNacimiento'), options) }) } else { helpers.defaultSelect(getNode('#cboDistritoNacimiento')) } }) getNode('#cboDistritoNacimiento').addEventListener('change', (e) => { let distrito = parseInt(e.currentTarget.value) let provincia = parseInt(getNode('#cboProvinciaNacimiento').value) let departamento = parseInt(getNode('#cboDepartamentoNacimiento').value) httpRequest.datosPersonales.obtenerUbigeo(departamento, provincia, distrito) .then((data) => { codigoUbigeoNacimiento = data.data.getResultedKey }) }) getNode('#cboDepartamentoResidencia').addEventListener('change', (e) => { let departamento = parseInt(e.currentTarget.value) codigoUbigeoResidencia = 0 if (departamento !== 0) { httpRequest.datosPersonales.listarProvincia(departamento) .then((data) => { let options = helpers.createSelectOptions(data.data.provincias, 'codigoProvincia', 'nombreProvincia') helpers.filteredSelect(getNode('#cboProvinciaResidencia'), options) helpers.defaultSelect(getNode('#cboDistritoResidencia')) }) } else { getNodeAll('#cboProvinciaResidencia, #cboDistritoResidencia').forEach((el) => helpers.defaultSelect(el)) } }) getNode('#cboProvinciaResidencia').addEventListener('change', (e) => { let departamento = parseInt(getNode('#cboDepartamentoResidencia').value) let provincia = parseInt(e.currentTarget.value) codigoUbigeoResidencia = 0 if (provincia !== 0) { httpRequest.datosPersonales.listarDistrito(departamento, provincia) .then((data) => { let options = helpers.createSelectOptions(data.data.distritos, 'codigoDistrito', 'nombreDistrito') helpers.filteredSelect(getNode('#cboDistritoResidencia'), options) }) } else { helpers.defaultSelect(getNode('#cboDistritoResidencia')) } }) getNode('#cboDistritoResidencia').addEventListener('change', (e) => { let distrito = parseInt(e.currentTarget.value) let provincia = parseInt(getNode('#cboProvinciaResidencia').value) let departamento = parseInt(getNode('#cboDepartamentoResidencia').value) httpRequest.datosPersonales.obtenerUbigeo(departamento, provincia, distrito) .then((data) => { codigoUbigeoResidencia = data.data.getResultedKey }) }) $('#lblFoto').on('change.bs.fileinput', (e) => { let imgName = getNode('#lblFoto').value.split('\\'); let imgExtension = imgName[imgName.length - 1].substring(imgName[imgName.length - 1].indexOf('.'), imgName[imgName.length - 1].length); if (imgExtension === '.PNG' || imgExtension === '.png' || imgExtension === '.JPG' || imgExtension === '.jpg' || imgExtension === '.JPEG' || imgExtension === '.jpeg') { statusFoto = true; } else { statusFoto = false; } }); getNode('#mostrarCorreoCorporativo').addEventListener('click', (e) => { e.preventDefault() alert('Solo si su responsable le brindo un correo corporativo') }) // retencion judicial getNode('#chkRetencionJudicial').addEventListener('click', (e) => { Objetos.retencionJudicial.clean() let chkRetencionJudicial = getNode('#chkRetencionJudicial') if (chkRetencionJudicial.checked) { console.log('esta checkeado') getNode('#textChkRetencionJudicial').innerHTML = 'SI ' getNodeAll('#txtBenificiarioRetencionJudicial, #txtMotivoRetencionJudicial, #txtPorcentajeSueldo, #btnAgregarRetencionJudicial') .forEach((el) => { el.removeAttribute('disabled') }) flagRetencionJudicial = true } else { console.log('no esta checkeado') getNode('#textChkRetencionJudicial').innerHTML = 'NO' getNodeAll('#txtBenificiarioRetencionJudicial, #txtMotivoRetencionJudicial, #txtPorcentajeSueldo, #btnAgregarRetencionJudicial') .forEach((el) => { el.setAttribute('disabled', true) }) flagRetencionJudicial = false } }) // datos familiares getNode('#cbotipoDocumentoFamiliar').addEventListener('change', (e) => { let tipoDocumento = parseInt(e.currentTarget.value) if (tipoDocumento !== 0) { getNode('#txtNumeroDocumentoFamiliar').removeAttribute('disabled') getNode('#txtNumeroDocumentoFamiliar').value = '' httpRequest.datosFamiliares.obtenerConfiguracionTipoDocumento(tipoDocumento) .then((data) => { if (data.status) { return { longitud: data.data.tipodocumentos[0].longitud, tipoEntrada: data.data.tipodocumentos[0].tipoEntrada } } else { alert('ERROR A OBTENER CONFIGURACION DEL TIPO DE DOCUMENTO') } }) .then((configTipoDocumento) => { getNode('#txtNumeroDocumentoFamiliar').setAttribute('maxlength', configTipoDocumento.longitud) getNode('#txtNumeroDocumentoFamiliar').setAttribute('minlength', configTipoDocumento.longitud) getNode('#txtNumeroDocumentoFamiliar').setAttribute('entrada', configTipoDocumento.tipoEntrada) if (configTipoDocumento.tipoEntrada === 'N') { $('#txtNumeroDocumentoFamiliar').off('keypress keyup blur'); soloNumeros('txtNumeroDocumentoFamiliar'); } else { $('#txtNumeroDocumentoFamiliar').off('keypress keyup blur'); soloAlfanumerico('txtNumeroDocumentoFamiliar'); } getNode('#txtNumeroDocumentoFamiliar').focus() }) } else { getNode('#txtNumeroDocumentoFamiliar').setAttribute('disabled', true) getNode('#txtNumeroDocumentoFamiliar').value = '' } }) getNode('#cboParentescoFamiliar').addEventListener('change', (e) => { let parentesco = parseInt(e.currentTarget.value) if (parentesco === 1 || parentesco === 2) { getNode('#cboSexoFamiliar').value = parentesco === 1 ? 'M' : 'F' getNode('#cboSexoFamiliar').setAttribute('disabled', true) } else { getNode('#cboSexoFamiliar').value = 0 getNode('#cboSexoFamiliar').removeAttribute('disabled') } $(getNode('#cboSexoFamiliar')).selectpicker('refresh') }) // formacion academica getNode('#cboGradoEstudioFormacionAcademica').addEventListener('change', (e) => { codigoGradoEstudio = 0 let gradoEstudio = parseInt(e.currentTarget.value) if (gradoEstudio !== 0) { httpRequest.datosFormacionAcademica.listarEstadoEstudio(gradoEstudio) .then((data) => { let options = helpers.createSelectOptions(data.data.estadoestudio, 'codigoEstadoEstudio', 'nombre') helpers.filteredSelect(getNode('#cboEstadoEstudioFormacionAcademica'), options) }) getNodeAll('#txtNumeroColegiatura, #txtCarreraProfesional').forEach((el) => { el.removeAttribute('disabled') }) if (gradoEstudio === 1 || gradoEstudio === 2) { getNodeAll('#txtNumeroColegiatura, #txtCarreraProfesional').forEach((el) => { el.setAttribute('disabled', true) el.value = '' }) } } else { helpers.defaultSelect(getNode('#cboEstadoEstudioFormacionAcademica')) } }) getNode('#cboEstadoEstudioFormacionAcademica').addEventListener('change', (e) => { let estado = parseInt(e.currentTarget.value) let grado = parseInt(getNode('#cboGradoEstudioFormacionAcademica').value) if (estado !== 0) { httpRequest.datosFormacionAcademica.obtenerGradoEstadoEstudio(grado, estado) .then((data) => { codigoGradoEstudio = data.data.getResultedKey }) } }) getNode('#chkActualidadFormacionAcademica').addEventListener('click', (e) => { if (e.currentTarget.checked) { getNode('#dpFechaFinFormacionAcademica').setAttribute('disabled', true) getNode('#divFechaFinFormacionAcademica').style.display = 'none' getNode('#divActualidadFormacionAcademica').style.display = 'inline-block' getNode('#dpFechaFinFormacionAcademica').style.cursor = 'default' getNode('.tp-asterico-fecha-fin-fa').style.visibility = 'hidden' flagActualidadFormacionAcademica = true } else { getNode('#dpFechaFinFormacionAcademica').removeAttribute('disabled') getNode('#dpFechaFinFormacionAcademica').style.cursor = 'pointer' getNode('.tp-asterico-fecha-fin-fa').style.visibility = 'initial' getNode('#divFechaFinFormacionAcademica').style.display = 'table' getNode('#divActualidadFormacionAcademica').style.display = 'none' flagActualidadFormacionAcademica = false } }) // experiencia laboral getNode('#chkExperienciaLaboral').addEventListener('click', (e) => { Objetos.experienciaLaboral.clean() let chkExperienciaLaboral = getNode('#chkExperienciaLaboral') if (chkExperienciaLaboral.checked) { getNode('#textChkExperienciaLaboral').innerHTML = 'SI ' getNodeAll('#txtEmpresaExperienciaLaboral, #txtCargoExperienciaLaboral, #dpFechaInicioExperienciaLaboral, #dpFechaFinExperienciaLaboral, #txtTelefonoExperienciaLaboral, #btnAgregarExperienciaLaboral') .forEach((el) => { el.removeAttribute('disabled') }) flagExperienciaLaboral = true } else { getNode('#textChkExperienciaLaboral').innerHTML = 'NO' getNodeAll('#txtEmpresaExperienciaLaboral, #txtCargoExperienciaLaboral, #dpFechaInicioExperienciaLaboral, #dpFechaFinExperienciaLaboral, #txtTelefonoExperienciaLaboral, #btnAgregarExperienciaLaboral') .forEach((el) => { el.setAttribute('disabled', true) }) flagExperienciaLaboral = false } }) // regimen pensionario getNode('#chkFondoPension').addEventListener('click', (e) => { document.getElementsByName('rdFondoPension').forEach(el => { el.checked = false }) DOMComponents.radioButton() let chkRegimenPensionario = getNode('#chkFondoPension') if (chkRegimenPensionario.checked) { getNode('#textChkRegimenPensionario').innerHTML = 'SI ' getNode('.regimenPensionarioTitulo').innerText = 'SELECCIONE EL SISTEMA PENSIONARIO EN EL QUE SE ENCUENTRA ACTUALMENTE' flagRegimenPensionario = true } else { getNode('#textChkRegimenPensionario').innerHTML = 'NO' getNode('.regimenPensionarioTitulo').innerText = 'SELECCIONE EL SISTEMA PENSIONARIO AL QUE DESEA APORTAR' flagRegimenPensionario = false } }) // registrar fichas getNode('#btnRegistrarFicha').addEventListener('click', (e) => { let formsValid = formsValidation.valid() if (formsValid.status) { let valid = Objetos.datosPersonales.validar() if (valid.status) { delete valid["status"] delete valid["node"] delete valid["codigoDepartamentoNacimiento"] delete valid["codigoProvinciaNacimiento"] delete valid["codigoDistritoNacimiento"] $.confirm({ icon: 'glyphicon glyphicon-question-sign', theme: 'material', closeIcon: true, animation: 'scale', // type: 'blue', type: 'dark', title: 'Confirmar', content: '<span class="text-semibold">Asegúrese de haber ingresado los datos con total veracidad, si usted está seguro de haber ingresado los datos correctos, de clic en registrar de lo contrario dar clic en cancelar <br/> ¿Desea registrar la ficha?</span>', buttons: { Registrar: { btnClass: 'btn-success', action: function () { localStorage.clear(); httpRequest.registrarFicha(valid) .then((data) => { // console.log(data) window.location.href = data.page }) .catch(err => { console.log(err) unload() errorMessage('Hubo un error al registrar la información, por favor contactarsé con el área de Sistemas') }) } }, Cancelar: { btnClass: 'btn-danger' } } }) } else { warningMessage(valid.message, smoothScrolling(valid.node)) } } else { warningMessage(formsValid.message, smoothScrolling(formsValid.node)) } }) } const initRequest = () => { return new Promise((resolve, reject) => { httpRequest.datosPersonales.listarEstadoCivil() .then((data) => { let options = helpers.createSelectOptions(data.data.EstadosCiviles, 'codigoEstadoCivil', 'nombre') helpers.filteredSelect(getNode('#cboEstadoCivil'), options) }) .catch(err => reject(err)) httpRequest.datosPersonales.listarNacionalidad() .then((data) => { let nacionalidad = data.data.Nacionalidades; let cboNacionalidad = `<option value="0">[SELECCIONAR]</option>`; for (let i in nacionalidad) { cboNacionalidad += `<option value="${nacionalidad[i].codigoNacionalidad}" data-content="${nacionalidad[i].gentilicio} <img class='tp-countrie-icon' src='../img/countries/${nacionalidad[i].iso}.svg'"></option>`; } helpers.filteredSelect(getNode('#cboNacionalidad'), cboNacionalidad) $('.tp-countrie-icon').parent().addClass('tp-countrie-container') }) .catch(err => reject(err)) httpRequest.datosPersonales.listarDepartamentos() .then((data) => { let options = helpers.createSelectOptions(data.data.departamentos, 'codigoDepartamento', 'nombreDepartamento') helpers.filteredSelect(getNode('#cboDepartamentoResidencia'), options) getNode('#cboDepartamentoNacimiento').innerHTML = options getNode('#cboDepartamentoNacimiento').setAttribute('disabled', true) $(getNode('#cboDepartamentoNacimiento')).selectpicker('refresh') }) .catch(err => reject(err)) httpRequest.datosFamiliares.listarParentesco() .then((data) => { let options = helpers.createSelectOptions(data.data.parentescos, 'codigoParentesco', 'nombre') helpers.filteredSelect(getNode('#cboParentescoFamiliar'), options) }) .catch(err => reject(err)) httpRequest.datosFamiliares.listarTipoDocumento() .then((data) => { let options = helpers.createSelectOptions(data.data.tipodocumentos, 'codigoTipoDocumento', 'descripcionCorta') helpers.filteredSelect(getNode('#cbotipoDocumentoFamiliar'), options) }) .catch(err => reject(err)) httpRequest.datosFormacionAcademica.listarGradoEstudio(). then((data) => { let options = helpers.createSelectOptions(data.data.nivelestudio, 'codigoNivelEstudio', 'nombre') helpers.filteredSelect(getNode('#cboGradoEstudioFormacionAcademica'), options) }) .catch(err => reject(err)) httpRequest.datosRegimenPensionario.listarRegimenPensionario() .then((data) => { if (data.status) { let fondopension = data.data.fondopension; let rowFondoPension = ``; for (let i in fondopension) { rowFondoPension += ` <div class="radio"> <label> <input type="radio" id="rd${fondopension[i].descripcionCorta}" name="rdFondoPension" class="styled" value="${fondopension[i].codigoFondoPension}"> ${fondopension[i].descripcionLarga} <span class="text-bold">(${fondopension[i].descripcionCorta})</span> </label> </div> `; } getNode('#divFondoPension').innerHTML = rowFondoPension getNode('#rdAFP').setAttribute('required', true) DOMComponents.radioButton() } }) .catch(err => reject(err)) resolve('ok') }) } const formsValidation = { init() { this.initValidateForm() this.initRulesForms() this.initActionFormChange() }, initRulesForms() { this.datosPersonales.rules() this.datosRetencionJudicial.rules() this.datosFamiliares.rules() this.datosFormacionAcademica.rules() this.datosExperienciaLaboral.rules() this.datosRegimenPensionario.rules() }, initActionFormChange() { this.datosPersonales.formChangeListener() this.datosRetencionJudicial.formChangeListener() this.datosFamiliares.formChangeListener() this.datosFormacionAcademica.formChangeListener() this.datosExperienciaLaboral.formChangeListener() this.datosRegimenPensionario.formChangeListener() }, datosPersonales: { rules() { $(getNode('#txtNumeroRUC')).rules('add', { number: true, minlength: 11, maxlength: 11 }) $(getNode('#txtApellidoPaterno')).rules('add', { required: true, lettersonly: true }) $(getNode('#txtApellidoMaterno')).rules('add', { required: true, lettersonly: true }) $(getNode('#txtNombre')).rules('add', { required: true, lettersonly: true }) $(getNode('#cboSexo')).rules('add', { valueNotEquals: '0' }) $(getNode('#cboEstadoCivil')).rules('add', { valueNotEquals: '0' }) $(getNode('#dpFechaNacimiento')).rules('add', { required: true, dateonly: true }) $(getNode('#cboNacionalidad')).rules('add', { valueNotEquals: '0' }) $(getNode('#cboDepartamentoNacimiento')).rules('add', { valueNotEquals: '0' }) $(getNode('#cboProvinciaNacimiento')).rules('add', { valueNotEquals: '0' }) $(getNode('#cboDistritoNacimiento')).rules('add', { valueNotEquals: '0' }) $(getNode('#txtDireccionDocumento')).rules('add', { required: true }) $(getNode('#txtTelefonoFijo')).rules('add', { number: true }) $(getNode('#txtTelefonoMovil')).rules('add', { number: true }) $(getNode('#txtCorreoElectronico')).rules('add', { required: true, email: true }) $(getNode('#txtCorreoCorporativo')).rules('add', { email: true }) $(getNode('#cboDepartamentoResidencia')).rules('add', { valueNotEquals: '0' }) $(getNode('#cboProvinciaResidencia')).rules('add', { valueNotEquals: '0' }) $(getNode('#cboDistritoResidencia')).rules('add', { valueNotEquals: '0' }) $(getNode('#txtDireccionResidencia')).rules('add', { required: true }) $(getNode('#flImage')).rules('add', { required: true, accept: 'image/png, image/jpeg, image/jpg' }) }, formChangeListener() { getNode('#formDatosPersonales').addEventListener('change', (e) => { $(e.currentTarget).valid() this.rules() // localStorage.setItem('objDatosPersonales', JSON.stringify({ // ruc: getNode('#txtNumeroRUC').value, // apellidoPaterno: getNode('#txtApellidoPaterno').value, // apellidoMaterno: getNode('#txtApellidoMaterno').value, // nombre: getNode('#txtNombre').value, // sexo: getNode('#cboSexo').value, // codigoEstadoCivil: parseInt(getNode('#cboEstadoCivil').value), // fechaNacimiento: getNode('#dpFechaNacimiento').value, // codigoNacionalidad: parseInt(getNode('#cboNacionalidad').value), // codigoDepartamentoNacimiento: parseInt(getNode('#cboDepartamentoNacimiento').value), // codigoProvinciaNacimiento: parseInt(getNode('#cboProvinciaNacimiento').value), // codigoDistritoNacimiento: parseInt(getNode('#cboDistritoNacimiento').value), //// codigoUbigeoNacimiento: codigoUbigeoNacimiento, // direccionDocumento: getNode('#txtDireccionDocumento').value, // telefonoFijo: getNode('#txtTelefonoFijo').value, // telefonoMovil: getNode('#txtTelefonoMovil').value, // correo: getNode('#txtCorreoElectronico').value, // correoCorporativo: getNode('#txtCorreoCorporativo').value.trim(), // codigoDepartamentoResidencia: parseInt(getNode('#cboDepartamentoResidencia').value), // codigoProvinciaResidencia: parseInt(getNode('#cboProvinciaResidencia').value), // codigoDistritoResidencia: parseInt(getNode('#cboDistritoResidencia').value), //// codigoUbigeoResidencia: codigoUbigeoResidencia, // direccionResidencia: getNode('#txtDireccionResidencia').value, // latitudResidencia: getNode('#latitudResidencia').value, // longitudResidencia: getNode('#longitudResidencia').value // })) }) } }, datosRetencionJudicial: { rules() { $(getNode('#txtBenificiarioRetencionJudicial')).rules('add', { required: true, lettersonly: true }) $(getNode('#txtMotivoRetencionJudicial')).rules('add', { required: true }) $(getNode('#txtPorcentajeSueldo')).rules('add', { required: true }) }, formChangeListener() { getNode('#formRetencionJudicial').addEventListener('change', (e) => { $(e.currentTarget).valid() this.rules() }) } }, datosFamiliares: { rules() { $(getNode('#cboParentescoFamiliar')).rules('add', { valueNotEquals: '0' }) $(getNode('#txtApellidoPaternoFamiliar')).rules('add', { required: true, lettersonly: true }) $(getNode('#txtApellidoMaternoFamiliar')).rules('add', { required: true, lettersonly: true }) $(getNode('#txtNombreFamiliar')).rules('add', { required: true, lettersonly: true }) $(getNode('#dpFechaNacimientoFamiliar')).rules('add', { required: true, dateonly: true }) $(getNode('#cbotipoDocumentoFamiliar')).rules('add', { valueNotEquals: '0' }) $(getNode('#txtNumeroDocumentoFamiliar')).rules('add', { required: true }) $(getNode('#cboSexoFamiliar')).rules('add', { valueNotEquals: '0' }) $(getNode('#txtTelefonoFamiliar')).rules('add', { number: true }) }, formChangeListener() { getNode('#formDatosFamiliares').addEventListener('change', (e) => { $(e.currentTarget).valid() this.rules() }) } }, datosFormacionAcademica: { rules() { $(getNode('#cboGradoEstudioFormacionAcademica')).rules('add', { valueNotEquals: '0' }) $(getNode('#cboEstadoEstudioFormacionAcademica')).rules('add', { valueNotEquals: '0' }) $(getNode('#cboPosicionInstitucion')).rules('add', { valueNotEquals: '0' }) $(getNode('#txtCentroEstudiosFormacionAcademica')).rules('add', { required: true }) $(getNode('#txtCarreraProfesional')).rules('add', { required: true, lettersonly: true }) $(getNode('#dpFechaInicioFormacionAcademica')).rules('add', { required: true, dateonly: true }) $(getNode('#dpFechaFinFormacionAcademica')).rules('add', { required: true, dateonly: true }) }, formChangeListener() { getNode('#formFormacionAcademica').addEventListener('change', (e) => { $(e.currentTarget).valid() this.rules() }) } }, datosExperienciaLaboral: { rules() { $(getNode('#txtEmpresaExperienciaLaboral')).rules('add', { required: true, lettersonly: true }) $(getNode('#txtCargoExperienciaLaboral')).rules('add', { required: true, lettersonly: true }) $(getNode('#dpFechaInicioExperienciaLaboral')).rules('add', { required: true, dateonly: true }) $(getNode('#dpFechaFinExperienciaLaboral')).rules('add', { required: true, dateonly: true }) $(getNode('#txtTelefonoExperienciaLaboral')).rules('add', { number: true }) }, formChangeListener() { getNode('#formExperienciaLaboral').addEventListener('change', (e) => { $(e.currentTarget).valid() this.rules() }) } }, datosRegimenPensionario: { rules() { $(getNode('#rdFondoPension')).rules('add', { required: true }) }, formChangeListener() { getNode('#formFondoPension').addEventListener('change', (e) => { $(e.currentTarget).valid() this.rules() // localStorage.setItem('objRegimenPensionario', JSON.stringify({ // regimenPensionario: getNode('input[name=rdFondoPension]:checked') === null ? 0 : parseInt(getNode('input[name=rdFondoPension]:checked').value), // tieneRegimenPensionario: flagRegimenPensionario, // tituloRegimenPensionario: getNode('.regimenPensionarioTitulo').innerText // })) }) } }, initValidateForm() { getNodeAll('#formDatosPersonales, #formRetencionJudicial, #formDatosFamiliares, #formFormacionAcademica, #formExperienciaLaboral, #formFondoPension') .forEach((el) => $(el).validate()) }, valid() { if (!$(getNode('#formDatosPersonales')).valid()) { return { status: false, message: 'Ingrese sus datos personales completos, por favor.', node: '#formDatosPersonales' } } if (flagRetencionJudicial) { if (objRetencionJudicial.length === 0) { return { status: false, message: 'Debe ingresar una retención judicial si tiene marcada la opción.', node: '#formRetencionJudicial' } } } if (objFamiliar.length === 0) { return { status: false, message: 'Debe ingresar al menos un familiar, por favor.', node: '#formDatosFamiliares' } } if (objFormacionAcademica.length === 0) { return { status: false, message: 'Debe ingresar al menos una formación académica, por favor.', node: '#formFormacionAcademica' } } if (flagExperienciaLaboral) { if (objExperienciaLaboral.length === 0) { return { status: false, message: 'Debe ingresar una experiencia laboral si tiene marcado la opción.', node: '#formExperienciaLaboral' } } } if (!$(getNode('#formFondoPension')).valid()) { return { status: false, message: 'Debe escoger un fondo pensionario, por favor.', node: '#formFondoPension' } } return { status: true } } } const getDataFromLocalStorage = { init() { this.datosPersonales() this.datosFamiliares() this.formacionAcademica() this.experienciaLaboral() this.regimenPensionario() }, datosPersonales() { if (localStorage.getItem('objDatosPersonales')) { let obj = JSON.parse(localStorage.getItem('objDatosPersonales')) getNode('#txtNumeroRUC').value = obj.ruc $('#txtApellidoPaterno').val(obj.apellidoPaterno) $('#txtApellidoMaterno').val(obj.apellidoMaterno) $('#txtNombre').val(obj.nombre) getNode('#cboSexo').value = obj.sexo getNode('#cboEstadoCivil').value = obj.codigoEstadoCivil getNode('#dpFechaNacimiento').value = obj.fechaNacimiento getNode('#cboNacionalidad').value = obj.codigoNacionalidad if (obj.codigoNacionalidad === 144) { getNode('#cboDepartamentoNacimiento').removeAttribute('disabled') if (obj.codigoDepartamentoNacimiento !== 0) { getNode('#cboDepartamentoNacimiento').value = obj.codigoDepartamentoNacimiento $(getNode('#cboDepartamentoNacimiento')).selectpicker('refresh') httpRequest.datosPersonales.listarProvincia(obj.codigoDepartamentoNacimiento). then(data => { let options = helpers.createSelectOptions(data.data.provincias, 'codigoProvincia', 'nombreProvincia') helpers.filteredSelect(getNode('#cboProvinciaNacimiento'), options) helpers.defaultSelect(getNode('#cboDistritoNacimiento')) return obj.codigoProvinciaNacimiento }) .then((codigoProvincia) => { if (codigoProvincia !== 0) { getNode('#cboProvinciaNacimiento').value = codigoProvincia $(getNode('#cboProvinciaNacimiento')).selectpicker('refresh') httpRequest.datosPersonales.listarDistrito(obj.codigoDepartamentoNacimiento, codigoProvincia) .then((data) => { let options = helpers.createSelectOptions(data.data.distritos, 'codigoDistrito', 'nombreDistrito') helpers.filteredSelect(getNode('#cboDistritoNacimiento'), options) return obj.codigoDistritoNacimiento }) .then((codigoDistrito) => { if (codigoDistrito !== 0) { getNode('#cboDistritoNacimiento').value = codigoDistrito $(getNode('#cboDistritoNacimiento')).selectpicker('refresh') httpRequest.datosPersonales.obtenerUbigeo(obj.codigoDepartamentoNacimiento, obj.codigoProvinciaNacimiento, codigoDistrito) .then((data) => { codigoUbigeoNacimiento = data.data.getResultedKey }) } }) } }) } $(getNode('#cboDepartamentoNacimiento')).selectpicker('refresh') } getNode('#txtDireccionDocumento').value = obj.direccionDocumento getNode('#txtTelefonoFijo').value = obj.telefonoFijo getNode('#txtTelefonoMovil').value = obj.telefonoMovil getNode('#txtCorreoElectronico').value = obj.correo getNode('#txtCorreoCorporativo').value = obj.correoCorporativo if (obj.codigoDepartamentoResidencia !== 0) { getNode('#cboDepartamentoResidencia').value = obj.codigoDepartamentoResidencia $(getNode('#cboDepartamentoResidencia')).selectpicker('refresh') httpRequest.datosPersonales.listarProvincia(obj.codigoDepartamentoResidencia). then(data => { let options = helpers.createSelectOptions(data.data.provincias, 'codigoProvincia', 'nombreProvincia') helpers.filteredSelect(getNode('#cboProvinciaResidencia'), options) helpers.defaultSelect(getNode('#cboDistritoResidencia')) return obj.codigoProvinciaResidencia }) .then((codigoProvincia) => { if (codigoProvincia !== 0) { getNode('#cboProvinciaResidencia').value = codigoProvincia $(getNode('#cboProvinciaResidencia')).selectpicker('refresh') httpRequest.datosPersonales.listarDistrito(obj.codigoDepartamentoResidencia, codigoProvincia) .then((data) => { let options = helpers.createSelectOptions(data.data.distritos, 'codigoDistrito', 'nombreDistrito') helpers.filteredSelect(getNode('#cboDistritoResidencia'), options) return obj.codigoDistritoResidencia }) .then((codigoDistrito) => { if (codigoDistrito !== 0) { getNode('#cboDistritoResidencia').value = codigoDistrito $(getNode('#cboDistritoResidencia')).selectpicker('refresh') httpRequest.datosPersonales.obtenerUbigeo(obj.codigoDepartamentoResidencia, obj.codigoProvinciaResidencia, codigoDistrito) .then((data) => { codigoUbigeoResidencia = data.data.getResultedKey }) } }) } }) } getNode('#txtDireccionResidencia').value = obj.direccionResidencia getNodeAll('#cboSexo, #cboEstadoCivil, #cboNacionalidad').forEach((el) => $(el).selectpicker('refresh')) } }, datosFamiliares() { if (localStorage.getItem('objFamiliar')) { let objJsonFamiliar = JSON.parse(localStorage.getItem('objFamiliar')) for (let obj in objJsonFamiliar) { helpers.addObjToDataTable('#tblFamiliar', objJsonFamiliar[obj]) if (objJsonFamiliar[obj].codigoParentesco === 1 || objJsonFamiliar[obj].codigoParentesco === 2 || objJsonFamiliar[obj].codigoParentesco === 5) { getNode(`#cboParentescoFamiliar option[value='${objJsonFamiliar[obj].codigoParentesco}']`).setAttribute('disabled', true) $(getNode('#cboParentescoFamiliar')).selectpicker('refresh') } } objFamiliar = objJsonFamiliar } }, formacionAcademica() { if (localStorage.getItem('objFormacionAcademica')) { let objJsonFormacionAcademica = JSON.parse(localStorage.getItem('objFormacionAcademica')) for (let o in objJsonFormacionAcademica) { helpers.addObjToDataTable('#tblFormacionAcademica', objJsonFormacionAcademica[o]) } objFormacionAcademica = objJsonFormacionAcademica } }, experienciaLaboral() { if (localStorage.getItem('objExperienciaLaboral')) { let objJsonExperienciaLaboral = JSON.parse(localStorage.getItem('objExperienciaLaboral')) if (objJsonExperienciaLaboral.length !== 0) { getNode('#textChkExperienciaLaboral').innerHTML = 'SI ' getNodeAll('#txtEmpresaExperienciaLaboral, #txtCargoExperienciaLaboral, #dpFechaInicioExperienciaLaboral, #dpFechaFinExperienciaLaboral, #txtTelefonoExperienciaLaboral, #btnAgregarExperienciaLaboral') .forEach((el) => { el.removeAttribute('disabled') }) getNode('#chkExperienciaLaboral').setAttribute('checked', 'checked') getNode('#chkExperienciaLaboral').checked = true flagExperienciaLaboral = true } for (let obj in objJsonExperienciaLaboral) { helpers.addObjToDataTable('#tblExperienciaLaboral', objJsonExperienciaLaboral[obj]) } objExperienciaLaboral = objJsonExperienciaLaboral } DOMComponents.switchery('#chkExperienciaLaboral') }, regimenPensionario() { if (localStorage.getItem('objRegimenPensionario')) { let objJsonRegimenPensionario = JSON.parse(localStorage.getItem('objRegimenPensionario')) getNode('.regimenPensionarioTitulo').innerText = objJsonRegimenPensionario.tituloRegimenPensionario getNode('#chkFondoPension').checked = objJsonRegimenPensionario.tieneRegimenPensionario getNodeAll('input[name=rdFondoPension]').forEach((el) => { parseInt(el.value) === objJsonRegimenPensionario.regimenPensionario ? el.checked = true : el.checked = false }) getNode('#textChkRegimenPensionario').innerText = objJsonRegimenPensionario.tieneRegimenPensionario === true ? 'SI' : 'NO' flagRegimenPensionario = objJsonRegimenPensionario.tieneRegimenPensionario } DOMComponents.radioButton() DOMComponents.switchery('#chkFondoPension') } } const Objetos = { init() { this.datosFamiliares.init() this.retencionJudicial.init() this.formacionAcademica.init() this.experienciaLaboral.init() }, retencionJudicial: { init() { this.agregar() this.listar() this.eliminar() }, validar() { let obj = { id: helpers.randomId(), beneficiario: getNode('#txtBenificiarioRetencionJudicial').value.toUpperCase().trim(), numeroDocumento: '', motivo: getNode('#txtMotivoRetencionJudicial').value.toUpperCase().trim(), porcentajeSueldo: getNode('#txtPorcentajeSueldo').value.trim() } obj.status = true return obj }, agregar() { getNode('#btnAgregarRetencionJudicial').addEventListener('click', (e) => { if (flagRetencionJudicial) { let obj = this.validar() if ($(getNode('#formRetencionJudicial')).valid()) { if (obj.status) { delete obj["status"] objRetencionJudicial.push(obj) // localStorage.setItem('objExperienciaLaboral', JSON.stringify(objExperienciaLaboral)) helpers.addObjToDataTable('#tblRetencionJudicial', obj) successMessage('Retención judicial agregada!') this.clean() } else { warningMessage(obj.message) } } } else { errorMessage('No puede agregar experiencia laboral.') } }) }, listar() { defaultConfigDataTable() let numeroFilas = 1 $(getNode('#tblRetencionJudicial')).DataTable({ bInfo: false, bPaginate: false, columns: [ { data: null, render: (data, type, row) => numeroFilas++ }, { data: 'beneficiario' }, { data: 'motivo' }, { data: 'porcentajeSueldo' }, { data: null, render: (data, type, row) => { return `<ul class="icons-list"> <li title="Eliminar" class="text-danger-600"> <a href="#" onclick="return false" class="eliminarRetencionJudicial"><i class="fa fa-trash-o fa-lg"></i></a> </li> </ul>`; } } ] }) }, eliminar() { $(getNode('#tblRetencionJudicial tbody')).on('click', '.eliminarRetencionJudicial', (e) => { let fila = helpers.getRow('#tblRetencionJudicial', e.currentTarget) let data = fila.data() $.confirm({ icon: 'glyphicon glyphicon-question-sign', theme: 'material', closeIcon: true, animation: 'scale', type: 'dark', title: 'Confirmar', content: `<span class="text-semibold">¿Seguro de eliminar la retencion judicial?</span>`, buttons: { Eliminar: { btnClass: 'btn-success', action: function () { removeByKey(objRetencionJudicial, {key: 'id', value: data.id}); fila.remove().draw(); successMessage("Retencion judicial eliminada"); } }, Cancelar: { btnClass: 'btn-danger' } } }); }) }, clean() { getNodeAll('#txtBenificiarioRetencionJudicial, #txtMotivoRetencionJudicial, #txtPorcentajeSueldo') .forEach((el) => el.value = '') } }, datosPersonales: { init() { }, validar() { let obj = { ruc: $('#txtNumeroRUC').val().trim(), apellidoPaterno: $('#txtApellidoPaterno').val().toUpperCase().trim(), apellidoMaterno: $('#txtApellidoMaterno').val().toUpperCase().trim(), nombre: $('#txtNombre').val().toUpperCase().trim(), sexo: getNode('#cboSexo').value, codigoEstadoCivil: getNode('#cboEstadoCivil').value, fechaNacimiento: getNode('#dpFechaNacimiento').value.trim(), codigoNacionalidad: getNode('#cboNacionalidad').value, codigoDepartamentoNacimiento: parseInt(getNode('#cboDepartamentoNacimiento').value), codigoProvinciaNacimiento: parseInt(getNode('#cboProvinciaNacimiento').value), codigoDistritoNacimiento: parseInt(getNode('#cboDistritoNacimiento').value), codigoUbigeoNacimiento: codigoUbigeoNacimiento, direccionDocumento: getNode('#txtDireccionDocumento').value.toUpperCase().trim(), telefonoFijo: getNode('#txtTelefonoFijo').value.trim(), telefonoMovil: getNode('#txtTelefonoMovil').value.trim(), correo: getNode('#txtCorreoElectronico').value.toUpperCase().trim(), correoCorporativo: getNode('#txtCorreoCorporativo').value.toUpperCase().trim(), codigoDepartamentoResidencia: parseInt(getNode('#cboDepartamentoResidencia').value), codigoProvinciaResidencia: parseInt(getNode('#cboProvinciaResidencia').value), codigoDistritoResidencia: parseInt(getNode('#cboDistritoResidencia').value), codigoUbigeoResidencia: codigoUbigeoResidencia, direccionResidencia: getNode('#txtDireccionResidencia').value.toUpperCase().trim(), latitudResidencia: getNode('#latitudResidencia').value, longitudResidencia: getNode('#longitudResidencia').value, fondoPensionActivo: flagRegimenPensionario, codigoFondoPension: parseInt(getNode('input[name=rdFondoPension]:checked').value), experienciaLaboralActivo: flagExperienciaLaboral, codigoTipoDocumento: parseInt(getNode('#codigoTipoDocumento').value), cargaFamiliar: objFamiliar, formacionAcademica: objFormacionAcademica, retencionJudicial: objRetencionJudicial, flagRetencionJudicial: flagRetencionJudicial, experienciaLaboral: objExperienciaLaboral, cargaFamiliarTotal: objFamiliar.length, experienciaLaboralTotal: objExperienciaLaboral.length, formacionAcademicaTotal: objFormacionAcademica.length, statusFoto: statusFoto } if (parseInt(getNode('#cboEstadoCivil').value) === 2) { let flagTieneConyuge; for (let o in objFamiliar) { flagTieneConyuge = false if (objFamiliar[o]["codigoParentesco"] !== 5) { flagTieneConyuge = false } else { flagTieneConyuge = true break; } } if (!flagTieneConyuge) { return obj = { status: false, message: 'Debe registrar a su cónyuge', node: '#formDatosFamiliares' } } } if (helpers.calculateAge(helpers.toDate(obj.fechaNacimiento)) < 18) { return obj = { status: false, message: 'Verifique la edad ingresada.', node: '#formDatosPersonales' } } if (obj.latitudResidencia === '' || obj.longitudResidencia === '') { return obj = { status: false, message: 'Por favor ubique en el mapa su lugar de residencia (dirección referencial) <br/> <span class="text-muted">arrastrar el marcador o dar clic sobre el mapa</span>', node: '#formDatosPersonales' } } if (!obj.statusFoto) { return obj = { status: false, message: 'Debe cargar una foto, por favor.', node: '#formDatosPersonales' } } if (getNode('#lblFoto').files[0].size / 1024 / 1024 > 1) { return obj = { status: false, message: 'El peso de la foto debe ser menor a 1 MB', node: '#formDatosPersonales' } } if (getNode('div.fileinput-preview').children[0].getAttribute('src') === '') { getNode('div.fileinput-preview').children[0].setAttribute('src', defaultImage) obj.foto = defaultImage obj.extension = '.png' } else { obj.foto = getNode('div.fileinput-preview').children[0].getAttribute('src') let lblFoto = getNode('#lblFoto').value.split('\\') let imgExtension = lblFoto[lblFoto.length - 1].substring(lblFoto[lblFoto.length - 1].indexOf('.'), lblFoto[lblFoto.length - 1].length); obj.extension = imgExtension } if (obj.codigoNacionalidad !== "144") { delete obj["codigoUbigeoNacimiento"] } obj.status = true return obj } }, datosFamiliares: { init() { this.agregar() this.listar() this.eliminar() }, validar() { let obj = { id: helpers.randomId(), codigoParentesco: parseInt(getNode('#cboParentescoFamiliar').value), nombreParentesco: getNode('#cboParentescoFamiliar').options[getNode('#cboParentescoFamiliar').selectedIndex].text.toUpperCase(), apellidoPaterno: getNode('#txtApellidoPaternoFamiliar').value.toUpperCase().trim(), apellidoMaterno: getNode('#txtApellidoMaternoFamiliar').value.toUpperCase().trim(), nombre: getNode('#txtNombreFamiliar').value.toUpperCase().trim(), fechaNacimiento: getNode('#dpFechaNacimientoFamiliar').value.trim(), codigoTipoDocumento: parseInt(getNode('#cbotipoDocumentoFamiliar').value), nombreTipoDocumento: getNode('#cbotipoDocumentoFamiliar').options[getNode('#cbotipoDocumentoFamiliar').selectedIndex].text.toUpperCase(), longitud: getNode('#txtNumeroDocumentoFamiliar').getAttribute('maxlength'), tipoEntrada: getNode('#txtNumeroDocumentoFamiliar').getAttribute('entrada'), numeroDocumento: getNode('#txtNumeroDocumentoFamiliar').value.trim(), sexo: getNode('#cboSexoFamiliar').value, telefono: getNode('#txtTelefonoFamiliar').value.trim() } if (helpers.validateValueFromArray(obj.numeroDocumento, objFamiliar, 'numeroDocumento')) { return obj = { status: false, message: 'El número de documento es repetido.' } } if (obj.sexo !== 'M' && obj.sexo !== 'F') { return obj = { status: false, message: 'No se encontró el sexo registrado.' } } if (!helpers.dateLessThan(obj.fechaNacimiento)) { return obj = { status: false, message: 'La fecha de nacimiento no puede ser mayor a la actual.' } } if (obj.telefono.length !== 7 && obj.telefono.length !== 9 && obj.telefono.length !== 0) { return obj = { status: false, message: 'Verifique el número de teléfono ingresado.' } } if (obj.numeroDocumento === getNode('#lblNumeroDocumento').innerText) { return obj = { status: false, message: 'Cuidado con quien agregas como familiar.' } } obj.status = true return obj }, agregar() { getNode('#btnAgregarFamiliar').addEventListener('click', (e) => { let obj = this.validar() if ($(getNode('#formDatosFamiliares')).valid()) { if (obj.status) { delete obj["status"] objFamiliar.push(obj) // localStorage.setItem('objFamiliar', JSON.stringify(objFamiliar)) helpers.addObjToDataTable('#tblFamiliar', obj) if (obj.codigoParentesco === 1 || obj.codigoParentesco === 2 || obj.codigoParentesco === 5) { getNode(`#cboParentescoFamiliar option[value='${obj.codigoParentesco}']`).setAttribute('disabled', true) $(getNode('#cboParentescoFamiliar')).selectpicker('refresh') } successMessage('Familiar agregado!') this.clean() } else { warningMessage(obj.message) } } }) }, listar() { defaultConfigDataTable() // # , apellidos y nombres, parentesco, fecha de nacimiento, tipo de documento, numero documento, // sexo, telefono, accion let numeroFilas = 1 $(getNode('#tblFamiliar')).DataTable({ bInfo: false, bPaginate: false, columns: [ { data: null, render: (data, type, row) => numeroFilas++ }, { data: null, render: (data, type, row) => `${data.apellidoPaterno} ${data.apellidoMaterno} ${data.nombre}` }, { data: 'nombreParentesco' }, { data: 'fechaNacimiento' }, { data: 'nombreTipoDocumento' }, { data: 'numeroDocumento' }, { data: 'sexo', render: (data, type, row) => data === 'M' ? 'MASCULINO' : 'FEMENINO' }, { data: 'telefono', render: (data, type, row) => data === '' ? '-' : data }, { data: null, render: (data, type, row) => { return `<ul class="icons-list"> <li title="Eliminar" class="text-danger-600"> <a href="#" onclick="return false" class="eliminarFamiliar"><i class="fa fa-trash-o fa-lg"></i></a> </li> </ul>`; } } ] }) }, eliminar() { $(getNode('#tblFamiliar tbody')).on('click', '.eliminarFamiliar', (e) => { let fila = helpers.getRow('#tblFamiliar', e.currentTarget) let data = fila.data() $.confirm({ icon: 'glyphicon glyphicon-question-sign', theme: 'material', closeIcon: true, animation: 'scale', type: 'dark', title: 'Confirmar', content: `<span class="text-semibold">¿Seguro de eliminar a ${data.nombre} ${data.apellidoPaterno}?</span>`, buttons: { Eliminar: { btnClass: 'btn-success', action: function () { let objJsonFamiliar = removeByKey(objFamiliar, {key: 'id', value: data.id}); getNode(`#cboParentescoFamiliar option[value='${data.codigoParentesco}']`).removeAttribute('disabled') $(getNode('#cboParentescoFamiliar')).selectpicker('refresh') // if (objJsonFamiliar.length === 0) { // localStorage.removeItem('objFamiliar'); // } else { // localStorage.setItem("objFamiliar", JSON.stringify(objJsonFamiliar)); // } fila.remove().draw(); successMessage("Familiar eliminado"); } }, Cancelar: { btnClass: 'btn-danger' } } }); }) }, clean() { getNodeAll('#txtApellidoPaternoFamiliar, #txtApellidoMaternoFamiliar, #txtNombreFamiliar, #dpFechaNacimientoFamiliar, #txtNumeroDocumentoFamiliar, #txtTelefonoFamiliar').forEach((el) => el.value = '') getNode('#txtNumeroDocumentoFamiliar').setAttribute('disabled', true) getNodeAll('#cboParentescoFamiliar, #cbotipoDocumentoFamiliar, #cboSexoFamiliar').forEach((el) => { el.selectedIndex = 0 $(el).selectpicker('refresh') }) } }, formacionAcademica: { init() { this.agregar() this.listar() this.eliminar() }, validar() { let obj = { id: helpers.randomId(), codigoGrado: parseInt(getNode('#cboGradoEstudioFormacionAcademica').value), codigoEstado: parseInt(getNode('#cboEstadoEstudioFormacionAcademica').value), nombreGrado: getNode('#cboGradoEstudioFormacionAcademica').options[getNode('#cboGradoEstudioFormacionAcademica').selectedIndex].text.toUpperCase(), nombreEstado: getNode('#cboEstadoEstudioFormacionAcademica').options[getNode('#cboEstadoEstudioFormacionAcademica').selectedIndex].text.toUpperCase(), codigoNivelEstado: codigoGradoEstudio, sectorInstitucion: getNode('#cboPosicionInstitucion').options[getNode('#cboPosicionInstitucion').selectedIndex].text.toUpperCase(), centroEstudios: getNode('#txtCentroEstudiosFormacionAcademica').value.toUpperCase().trim(), numeroColegiatura: getNode('#txtNumeroColegiatura').value.toUpperCase().trim(), nombreCarreraProfesional: getNode('#txtCarreraProfesional').value.toUpperCase().trim(), fechaInicio: getNode('#dpFechaInicioFormacionAcademica').value.trim(), fechaFin: getNode('#dpFechaFinFormacionAcademica').value.trim(), flagActualidad: flagActualidadFormacionAcademica } if (!flagActualidadFormacionAcademica) { if (helpers.toDate(obj.fechaInicio) > helpers.toDate(obj.fechaFin)) { return obj = { status: false, message: 'La fecha de inicio es mayor a la de fin. Verifique por favor.' } } } else { obj.fechaFin = '' } if (obj.codigoGrado === 1 || obj.codigoGrado === 2) { obj.nombreCarreraProfesional = '' } delete obj["codigoGrado"] delete obj["codigoEstado"] obj.status = true return obj }, agregar() { getNode('#btnAgregarFormacionAcademica').addEventListener('click', (e) => { let obj = this.validar() if ($(getNode('#formFormacionAcademica')).valid()) { if (obj.status) { delete obj["status"] obj.codigoCarreraProfesional = 404 objFormacionAcademica.push(obj) // localStorage.setItem('objFormacionAcademica', JSON.stringify(objFormacionAcademica)) helpers.addObjToDataTable('#tblFormacionAcademica', obj) successMessage('Formacion académica agregada!') this.clean() } else { warningMessage(obj.message) } } }) }, listar() { defaultConfigDataTable() let numeroFilas = 1 $(getNode('#tblFormacionAcademica')).DataTable({ bInfo: false, bPaginate: false, columns: [ { data: null, render: (data, type, row) => numeroFilas++ }, { data: 'nombreGrado' }, { data: 'nombreEstado' }, { data: 'sectorInstitucion' }, { data: 'centroEstudios' }, { data: 'numeroColegiatura', render: (data, type, row) => data === '' ? '-' : data }, { data: 'nombreCarreraProfesional', render: (data, type, row) => data === '' ? '-' : data }, { data: 'fechaInicio' }, { data: 'fechaFin', render: (data, type, row) => data === '' ? 'Actualidad' : data }, { data: null, render: (data, type, row) => { return `<ul class="icons-list"> <li title="Eliminar" class="text-danger-600"> <a href="#" onclick="return false" class="eliminarFormacionAcademica"><i class="fa fa-trash-o fa-lg"></i></a> </li> </ul>`; } } ] }) }, eliminar() { $(getNode('#tblFormacionAcademica tbody')).on('click', '.eliminarFormacionAcademica', (e) => { let fila = helpers.getRow('#tblFormacionAcademica', e.currentTarget) let data = fila.data() $.confirm({ icon: 'glyphicon glyphicon-question-sign', theme: 'material', closeIcon: true, animation: 'scale', type: 'dark', title: 'Confirmar', content: `<span class="text-semibold">¿Seguro de eliminar la formación académica?</span>`, buttons: { Eliminar: { btnClass: 'btn-success', action: function () { let objJsonFormacionAcademica = removeByKey(objFormacionAcademica, {key: 'id', value: data.id}); // if (objJsonFormacionAcademica.length === 0) { // localStorage.removeItem('objFormacionAcademica'); // } else { // localStorage.setItem("objFormacionAcademica", JSON.stringify(objFormacionAcademica)); // } fila.remove().draw(); successMessage("Formación académica eliminada"); } }, Cancelar: { btnClass: 'btn-danger' } } }); }) }, clean() { getNode('#dpFechaFinFormacionAcademica').removeAttribute('disabled') getNode('#dpFechaFinFormacionAcademica').style.cursor = 'pointer' getNode('.tp-asterico-fecha-fin-fa').style.visibility = 'initial' getNode('#divFechaFinFormacionAcademica').style.display = 'table' getNode('#divActualidadFormacionAcademica').style.display = 'none' $('#chkActualidadFormacionAcademica').parent('span').removeClass('checked') flagActualidadFormacionAcademica = false getNode('#cboEstadoEstudioFormacionAcademica').setAttribute('disabled', true) getNodeAll('#txtCentroEstudiosFormacionAcademica, #txtNumeroColegiatura, #txtCarreraProfesional, #dpFechaInicioFormacionAcademica, #dpFechaFinFormacionAcademica') .forEach((el) => el.value = '') getNodeAll('#cboGradoEstudioFormacionAcademica, #cboEstadoEstudioFormacionAcademica, #cboPosicionInstitucion').forEach((el) => { el.selectedIndex = 0 $(el).selectpicker('refresh') }) codigoGradoEstudio = 0 } }, experienciaLaboral: { init() { this.agregar() this.listar() this.eliminar() }, validar() { let obj = { id: helpers.randomId(), empresa: getNode('#txtEmpresaExperienciaLaboral').value.toUpperCase().trim(), cargo: getNode('#txtCargoExperienciaLaboral').value.toUpperCase().trim(), fechaInicio: getNode('#dpFechaInicioExperienciaLaboral').value.trim(), fechaFin: getNode('#dpFechaFinExperienciaLaboral').value.trim(), telefono: getNode('#txtTelefonoExperienciaLaboral').value.trim() } if (toDate(obj.fechaInicio) > toDate(obj.fechaFin)) { return obj = { status: false, message: 'La fecha de inicio es mayor a la de fin. Verifique por favor.' } } if (obj.telefono.length !== 7 && obj.telefono.length !== 9 && obj.telefono.length !== 0) { return obj = { status: false, message: 'Verifique el número de teléfono ingresado.' } } obj.status = true return obj }, agregar() { getNode('#btnAgregarExperienciaLaboral').addEventListener('click', (e) => { if (flagExperienciaLaboral) { let obj = this.validar() if ($(getNode('#formExperienciaLaboral')).valid()) { if (obj.status) { delete obj["status"] objExperienciaLaboral.push(obj) // localStorage.setItem('objExperienciaLaboral', JSON.stringify(objExperienciaLaboral)) helpers.addObjToDataTable('#tblExperienciaLaboral', obj) successMessage('Experiencia laboral agregada!') this.clean() } else { warningMessage(obj.message) } } } else { errorMessage('No puede agregar experiencia laboral.') } }) }, listar() { defaultConfigDataTable() let numeroFilas = 1 $(getNode('#tblExperienciaLaboral')).DataTable({ bInfo: false, bPaginate: false, columns: [ { data: null, render: (data, type, row) => numeroFilas++ }, { data: 'empresa' }, { data: 'cargo' }, { data: 'fechaInicio' }, { data: 'fechaFin' }, { data: 'telefono', render: (data, type, row) => data === '' ? '-' : data }, { data: null, render: (data, type, row) => { return `<ul class="icons-list"> <li title="Eliminar" class="text-danger-600"> <a href="#" onclick="return false" class="eliminarExperienciaLaboral"><i class="fa fa-trash-o fa-lg"></i></a> </li> </ul>`; } } ] }) }, eliminar() { $(getNode('#tblExperienciaLaboral tbody')).on('click', '.eliminarExperienciaLaboral', (e) => { let fila = helpers.getRow('#tblExperienciaLaboral', e.currentTarget) let data = fila.data() $.confirm({ icon: 'glyphicon glyphicon-question-sign', theme: 'material', closeIcon: true, animation: 'scale', type: 'dark', title: 'Confirmar', content: `<span class="text-semibold">¿Seguro de eliminar la experiencia laboral?</span>`, buttons: { Eliminar: { btnClass: 'btn-success', action: function () { let objJsonExperienciaLaboral = removeByKey(objExperienciaLaboral, {key: 'id', value: data.id}); // if (objJsonExperienciaLaboral.length === 0) { // localStorage.removeItem('objExperienciaLaboral'); // } else { // localStorage.setItem("objExperienciaLaboral", JSON.stringify(objExperienciaLaboral)); // } fila.remove().draw(); successMessage("Experiencia laboral eliminada"); } }, Cancelar: { btnClass: 'btn-danger' } } }); }) }, clean() { getNodeAll('#txtEmpresaExperienciaLaboral, #txtCargoExperienciaLaboral, #dpFechaInicioExperienciaLaboral, #dpFechaFinExperienciaLaboral, #txtTelefonoExperienciaLaboral') .forEach((el) => el.value = '') } } } DOMComponents.init() initRequest() .then(() => { DOMEvents() }) .catch(err => console.log(err)) formsValidation.init() Objetos.init() setTimeout(() => { // getDataFromLocalStorage.init() DOMComponents.switchery('#chkExperienciaLaboral, #chkFondoPension, #chkRetencionJudicial') }, 2) dontLeaveMe() /* TODO: 4) CHECKBOX DEBE VALIDAR: SI TRATA DE QUITAR CHECK Y TIENE EXPERIENCIAS REGISTRADAS, NO LE DEBE DEJAR 5) ESTILO DE VALIDACION DE LA IMAGEN 8) ORDENAR LA DATA DE LAS TABLAS */