/* 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&nbsp;&nbsp;'
      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&nbsp;&nbsp;'
      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&nbsp;&nbsp;'
      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&nbsp;&nbsp;'
        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 
 
 */