示例#1
0
        /// <summary>
        /// Guarda la entidad de dominio <see cref="ContactoEntity"/> en la Base de Datos
        /// </summary>
        /// <author>@Charly</author>
        /// <created>05-09-2017 23:35:48</created>
        /// <param name="contacto">Referencia a una clase <see cref="ContactoEntity"/>.</param>
        /// <returns>Clave primaria resultante de la operación</returns>
        public static long Guardar(ContactoEntity contacto)
        {
            Parametros parametros = new Parametros
            {
                new Parametro("@CodTipoEntidad", contacto.CodTipoEntidad),
                new Parametro("@RutEntidad", contacto.RutEntidad),
                new Parametro("@CodCategoria", contacto.CodCategoria),
                new Parametro("@CodTipo", contacto.CodTipo),
                new Parametro("@ValorContacto", contacto.ValorContacto),
                new Parametro("@CodContacto", contacto.CodContacto),
            };

            return(DBHelper.InstanceEngine.ObtenerEscalar <long>("engine.sp_Contacto_Guardar", parametros));
        }
示例#2
0
        /// <summary>
        /// Guarda la entidad de dominio <see cref="ContactoEntity"/> en la Base de Datos
        /// </summary>
        /// <author>@Charly</author>
        /// <created>06-03-2018 17:58:02</created>
        /// <param name="contacto">Referencia a una clase <see cref="ContactoEntity"/>.</param>
        /// <returns>Clave primaria resultante de la operación</returns>
        public static int Guardar(ContactoEntity contacto)
        {
            Parametros parametros = new Parametros
            {
                new Parametro("@cnt_id", contacto.cnt_id),
                new Parametro("@encabezado_id", contacto.encabezado_id),
                new Parametro("@nombre", contacto.nombre),
                new Parametro("@telefono", contacto.telefono),
                new Parametro("@email", contacto.email),
                new Parametro("@direccion", contacto.direccion),
                new Parametro("@compromisos", contacto.compromisos),
                new Parametro("@tipo", contacto.tipo),
            };

            return(DBHelper.InstanceCRM.ObtenerEscalar <int>("fichas.spFicha_Contacto_Guardar", parametros));
        }
示例#3
0
        public ContactoViewModel GetById(int id)
        {
            ContactoViewModel contacto = new ContactoViewModel();

            try
            {
                using (var context = new AgendaContext())
                {
                    ContactoEntity contactoEntity = context.Contactos.FirstOrDefault(c => c.IdContacto == id);
                    if (contactoEntity != null)
                    {
                        contacto.Id               = contactoEntity.IdContacto;
                        contacto.NombreContacto   = contactoEntity.NombreContacto;
                        contacto.ApellidoContacto = contactoEntity.ApellidoContacto;
                        contacto.TelefonoContacto = contactoEntity.TelefonoContacto;
                        contacto.MailContacto     = contactoEntity.MailContacto;
                    }
                    else
                    {
                        Log.Debug("No existe contacto con ese id.");
                        Log.Error("No existe contacto con ese id.");
                        throw new Exception("No existe contacto con ese id.");
                    }
                }
            }
            catch (SqlException ex)
            {
                Log.Debug(string.Format("Error: {0}", ex.InnerException));
                Log.Error(string.Format("Error: {0}", ex.InnerException));
                throw ex;
            }
            catch (Exception ex)
            {
                Log.Debug(string.Format("Error: {0}", ex.InnerException));
                Log.Error(string.Format("Error: {0}", ex.InnerException));
                throw ex;
            }
            return(contacto);
        }
示例#4
0
        public void Add(ContactoViewModel viewModel)
        {
            ContactoEntity contactoEntity = new ContactoEntity()
            {
                NombreContacto   = viewModel.NombreContacto,
                ApellidoContacto = viewModel.ApellidoContacto,
                TelefonoContacto = viewModel.TelefonoContacto,
                MailContacto     = viewModel.MailContacto
            };

            try
            {
                using (var context = new AgendaContext())
                {
                    context.Contactos.Add(new ContactoEntity()
                    {
                        NombreContacto   = viewModel.NombreContacto,
                        ApellidoContacto = viewModel.ApellidoContacto,
                        TelefonoContacto = viewModel.TelefonoContacto,
                        MailContacto     = viewModel.MailContacto
                    });
                    context.SaveChanges();
                }
                Log.Debug("Se agrego el contacto.");
            }
            catch (SqlException ex)
            {
                Log.Debug(string.Format("Error: {0}", ex.InnerException));
                Log.Error(string.Format("Error: {0}", ex.InnerException));
                throw ex;
            }
            catch (Exception ex)
            {
                Log.Debug(string.Format("Error: {0}", ex.InnerException));
                Log.Error(string.Format("Error: {0}", ex.InnerException));
                throw ex;
            }
        }
示例#5
0
        public ResultadoBase GuardarFomulario(webFRM entrada)
        {
            try
            {
                string            token      = ActionContext.Request.Headers.GetValues("Token").First();
                int               _uid       = Security.Data.TokenDataAccess.Obtener(token).FirstOrDefault().UserId;
                string            _rut       = Security.Data.UsuarioDataAccess.UsuarioData(_uid).RutUsuario;
                CookieHeaderValue cookie     = Request.Headers.GetCookies("Oficina").FirstOrDefault();
                int               codOficina = Convert.ToInt32(cookie.Cookies.FirstOrDefault(s => s.Name == "Oficina").Value);

                EncabezadoEntity enx;
                if (entrada.encabezado.id_ficha == "NEW")
                {
                    EncabezadoEntity muestra = EncabezadoDataAccess.ObtenerEntidades().FirstOrDefault(s => s.cod_sucursal == codOficina && s.rut_empresa == entrada.encabezado.rut_empresa);

                    enx = new EncabezadoEntity();
                    enx.cod_sucursal    = codOficina;
                    enx.cuestionario_id = muestra.cuestionario_id;
                    enx.rut_empresa     = entrada.encabezado.rut_empresa;

                    enx.estamento          = entrada.encabezado.estamento_empresa;
                    enx.cantidad_empleados = Convert.ToInt32(entrada.encabezado.numero_empleados_empresa);
                    enx.nombre_funcionario = entrada.encabezado.nombre_funcionario;
                    enx.cargo_funcionario  = entrada.encabezado.cargo_funcionario;
                    enx.fecha_entrevista   = Convert.ToDateTime(entrada.encabezado.fecha_entrevista);
                    enx.rut_ejecutivo      = _rut;

                    int codigonuea = EncabezadoDataAccess.Guardar(enx);
                    enx.enc_id = codigonuea;
                    EncabezadoEntity rs = EncabezadoDataAccess.ObtenerPorID(codigonuea);
                    rs.nombre_empresa = muestra.nombre_empresa;
                    EncabezadoDataAccess.GuardarNombre(rs);
                }
                else
                {
                    enx                    = EncabezadoDataAccess.ObtenerEntidades().Find(e => e.enc_id == Convert.ToInt32(entrada.encabezado.id_ficha));
                    enx.estamento          = entrada.encabezado.estamento_empresa;
                    enx.cantidad_empleados = Convert.ToInt32(entrada.encabezado.numero_empleados_empresa);
                    enx.nombre_funcionario = entrada.encabezado.nombre_funcionario;
                    enx.cargo_funcionario  = entrada.encabezado.cargo_funcionario;
                    enx.fecha_entrevista   = Convert.ToDateTime(entrada.encabezado.fecha_entrevista);
                    enx.rut_ejecutivo      = _rut;
                    EncabezadoDataAccess.Guardar(enx);
                }



                if (entrada.personalidad.nombre_persona_juridica != null)
                {
                    DesarrolloEntity datosperjuridica = DesarrolloDataAccess.ObtenerEntidades().Find(f => f.encabezado_id == enx.enc_id && f.respuesta_id == 20);

                    if (datosperjuridica == null)
                    {
                        datosperjuridica = new DesarrolloEntity();
                    }

                    datosperjuridica.encabezado_id = enx.enc_id;
                    datosperjuridica.respuesta_id  = 20;
                    DesarrolloDataAccess.Guardar(datosperjuridica);

                    ContactoEntity perjur = ContactoDataAccess.ObtenerEntidades().Find(d => d.encabezado_id == enx.enc_id && d.tipo == "PERSONALIDAD_JURIDICA");

                    if (perjur == null)
                    {
                        perjur = new ContactoEntity();
                    }


                    perjur.encabezado_id = enx.enc_id;
                    perjur.nombre        = entrada.personalidad.nombre_persona_juridica;
                    perjur.direccion     = entrada.personalidad.direccion_persona_juridica;
                    perjur.email         = entrada.personalidad.email_persona_juridica;
                    perjur.telefono      = Convert.ToInt32(entrada.personalidad.telefono_persona_juridica);
                    perjur.compromisos   = entrada.personalidad.compromisos_persona_juridica;
                    perjur.tipo          = "PERSONALIDAD_JURIDICA";

                    ContactoDataAccess.Guardar(perjur);
                }

                if (entrada.director.nombre_director_ejecutivo != null)
                {
                    DesarrolloEntity datosdirector = DesarrolloDataAccess.ObtenerEntidades().Find(f => f.encabezado_id == enx.enc_id && f.respuesta_id == 17);

                    if (datosdirector == null)
                    {
                        datosdirector = new DesarrolloEntity();
                    }


                    datosdirector.encabezado_id = enx.enc_id;
                    datosdirector.respuesta_id  = 17;
                    DesarrolloDataAccess.Guardar(datosdirector);


                    ContactoEntity direc = ContactoDataAccess.ObtenerEntidades().Find(d => d.encabezado_id == enx.enc_id && d.tipo == "DIRECTOR_EJECUTIVO");

                    if (direc == null)
                    {
                        direc = new ContactoEntity();
                    }


                    direc.encabezado_id = enx.enc_id;
                    direc.nombre        = entrada.director.nombre_director_ejecutivo;
                    direc.direccion     = entrada.director.direccion_director_ejecutivo;
                    direc.email         = entrada.director.email_director_ejecutivo;
                    direc.telefono      = Convert.ToInt32(entrada.director.telefono_director_ejecutivo);
                    direc.tipo          = "DIRECTOR_EJECUTIVO";

                    ContactoDataAccess.Guardar(direc);
                }

                if (entrada.desvinculacion.cantidad_desvinculacion != null)
                {
                    RespuestaEntity  rvl = RespuestaDataAccess.ObtenerEntidades().Find(x => x.pregunta_id == 15 && x.nuberespuesta_id == Convert.ToInt32(entrada.desvinculacion.tipo_conteo_desvinculacion));
                    DesarrolloEntity desarrolloFormulario = DesarrolloDataAccess.ObtenerEntidades().Find(y => y.encabezado_id == enx.enc_id && (y.respuesta_id == 26 || y.respuesta_id == 27));

                    if (desarrolloFormulario == null)
                    {
                        desarrolloFormulario = new DesarrolloEntity();
                    }
                    desarrolloFormulario.encabezado_id = enx.enc_id;
                    desarrolloFormulario.respuesta_id  = rvl.resp_id;
                    desarrolloFormulario.texto         = entrada.desvinculacion.cantidad_desvinculacion;
                    DesarrolloDataAccess.Guardar(desarrolloFormulario);
                }

                if (entrada.agenda.fecha_prox_reunion != null)
                {
                    AgendaEntity lg = AgendaDataAccess.ObtenerEntidades().Find(d => d.encabezado_id == enx.enc_id);
                    if (lg == null)
                    {
                        lg = new AgendaEntity();
                    }

                    lg.encabezado_id      = enx.enc_id;
                    lg.fecha              = Convert.ToDateTime(entrada.agenda.fecha_prox_reunion);
                    lg.estamento          = entrada.agenda.estamento;
                    lg.nombre_funcionario = entrada.agenda.nombre_funcionario_empresa;
                    lg.cargo_funcionario  = entrada.agenda.cargo_funcionario_empresa;

                    AgendaDataAccess.Guardar(lg);
                }

                entrada.data.ToList().ForEach(v =>
                {
                    if (v.valor != null)
                    {
                        RespuestaEntity resval = new RespuestaEntity();
                        string texti           = "";
                        if (v.tipo == "texto")
                        {
                            resval = RespuestaDataAccess.ObtenerEntidades().Find(x => x.pregunta_id == v.id && x.nuberespuesta_id == 1);
                            texti  = v.valor;
                        }
                        else
                        {
                            resval = RespuestaDataAccess.ObtenerEntidades().Find(x => x.pregunta_id == v.id && x.nuberespuesta_id.ToString() == v.valor);
                        }
                        DesarrolloEntity desarrolloFormulario = DesarrolloDataAccess.ObtenerEntidades().Find(y => y.encabezado_id == enx.enc_id && y.respuesta_id == resval.resp_id);

                        if (desarrolloFormulario == null)
                        {
                            desarrolloFormulario = new DesarrolloEntity();
                        }

                        desarrolloFormulario.encabezado_id = enx.enc_id;
                        desarrolloFormulario.respuesta_id  = resval.resp_id;
                        desarrolloFormulario.texto         = texti;

                        DesarrolloDataAccess.Guardar(desarrolloFormulario);
                    }
                });

                return(new ResultadoBase()
                {
                    Estado = "OK", Mensaje = "Ficha Guardada con éxito!", Objeto = entrada
                });
            }catch (Exception ex) {
                return(new ResultadoBase()
                {
                    Estado = "Error", Mensaje = "Error", Objeto = ex
                });
            }
        }