Esempio n. 1
0
        public TiposTicketsClientesModel ActulizarTiposTicketsClientes(TiposTicketsClientesModel tiposTicketsClientesModel)
        {
            TiposTicketsClientesModel model = new TiposTicketsClientesModel();

            try
            {
                iGenericDataAccess.OpenConnection();

                TiposTicket findTiposTicket = iGenericDataAccess.BuscarUno(new TiposTicket()
                {
                    TipoId = tiposTicketsClientesModel.TipoId
                },
                                                                           new OptionsQueryZero()
                {
                    ExcludeNumericsDefaults = true
                });
                if (findTiposTicket != null)
                {
                    if (!findTiposTicket.Descripcion.Equals(tiposTicketsClientesModel.TiposTicket.Descripcion))
                    {
                        StringBuilder findSQL = new StringBuilder();
                        findSQL.Append(" SELECT COUNT(tt.TipoId) TiempoAtencion ");
                        findSQL.Append(" FROM dbo.TiposTicket tt ");
                        findSQL.Append(" INNER JOIN dbo.TiposTicketsClientes ttc ");
                        findSQL.Append(" ON ttc.TipoId = tt.TipoId ");
                        findSQL.Append(" AND ttc.IdCliente = " + tiposTicketsClientesModel.IdCliente);
                        findSQL.Append(" AND tt.Descripcion = '" + tiposTicketsClientesModel.TiposTicket.Descripcion + "'");

                        TiposTicket findTiposTicketsDos = iGenericDataAccess.ExecuteQuery <TiposTicket>(findSQL.ToString())[0];

                        if (findTiposTicketsDos.TiempoAtencion > 0)
                        {
                            throw new DalException(CodesConfigParamTickets.INF_08_01);
                        }
                    }
                }

                TiposTicket tt = new TiposTicket
                {
                    TipoId         = tiposTicketsClientesModel.TipoId,
                    Descripcion    = tiposTicketsClientesModel.TiposTicket.Descripcion,
                    TiempoAtencion = tiposTicketsClientesModel.TiposTicket.TiempoAtencion,
                    Activa         = true
                };
                TiposTicket   saveTicket = iGenericDataAccess.Actualizar(tt);
                StringBuilder sqlUpdate  = new StringBuilder();
                sqlUpdate.Append("UPDATE TiposTicketsClientes ");
                sqlUpdate.Append(" SET IdPersonaResponsable = " + tiposTicketsClientesModel.IdPersonaResponsable + ",");
                sqlUpdate.Append(" IdPersonaEscalamiento1 = " + tiposTicketsClientesModel.IdPersonaEscalamiento1 + ",");
                sqlUpdate.Append(" IdPersonaEscalamiento2 = " + tiposTicketsClientesModel.IdPersonaEscalamiento2 + ",");
                sqlUpdate.Append(" HorasAtencion = " + tiposTicketsClientesModel.HorasAtencion + ",");
                sqlUpdate.Append(" HorasSegundoEscalamiento = " + tiposTicketsClientesModel.HorasSegundoEscalamiento);
                sqlUpdate.Append(" WHERE TipoId = " + saveTicket.TipoId);
                sqlUpdate.Append(" AND IdCliente = " + tiposTicketsClientesModel.IdCliente);
                iGenericDataAccess.ExecuteSql(sqlUpdate.ToString());
                model.TipoId    = saveTicket.TipoId;
                model.IdCliente = tiposTicketsClientesModel.IdCliente;
                iGenericDataAccess.CloseConnection();
                return(model);
            }
            catch (Exception e)
            {
                iGenericDataAccess.CloseConnection();
                throw new DalException(CodesConfigParamTickets.ERR_08_03, e);
            }
        }