public JsonResult cargarReparacion(int iddiagnostico, int idtipoproducto, int idfabricante)
        {
            var diagnostico = new DiagnosticoData().listarDiagnostico(null, null, null, null, iddiagnostico).ToList();

            var reparacion      = new ReparacionData().listarReparacion(diagnostico[0].idcategoriareparacion, idtipoproducto, null);
            var listareparacion = new SelectList(
                reparacion,
                "idreparacion",
                "descripcion");

            return(Json(new { listareparacion }));
        }
Ejemplo n.º 2
0
        public JsonResult AprobarDesaprobarCotizacion(long idcotizacion, string estado, long idordenservicio)
        {
            var model               = new VentaCotizacionModel();
            var modOrdenServicio    = new OrdenServicioData().obtenerOrdenServicio(idordenservicio);
            var modOrdenTrabajo     = new OrdenTrabajoModel();
            var TrabajoDetalleModel = new OrdenTrabajoDetalleModel();

            if (estado == "aprobado")
            {
                modOrdenServicio.idestado = (Int32)Constantes.EstadoOrdenServicio.PendienteInicioReparacion;
                modOrdenServicio.cotizado = true;
                modOrdenTrabajo.idestado  = (Int32)Constantes.EstadoOrdenTrabajo.Asignada;
                model.aceptado            = true;
            }
            else if (estado == "rechazado")
            {
                modOrdenServicio.idestado = (Int32)Constantes.EstadoOrdenServicio.PendienteEntregaCliente;
                modOrdenTrabajo.idestado  = (Int32)Constantes.EstadoOrdenTrabajo.Completada;
                model.aceptado            = false;
            }


            modOrdenServicio.__tipooperacion = 2;
            modOrdenTrabajo.__tipooperacion  = 2;
            model.__tipooperacion            = 2;

            model.idcotizacion = idcotizacion;
            modOrdenServicio.idordenserviciotecnico = idordenservicio;
            modOrdenTrabajo.idordentrabajo          = modOrdenServicio.idordentrabajo;



            new ReparacionesData().InsertarActualizarOrdenTrabajo(modOrdenTrabajo);
            new VentaData().insertarActualizarCotizacion(model);
            new OrdenServicioData().InsertarActualizarOrdenServicio(modOrdenServicio);



            #region registrar reparaciones


            TarifaModel  modTarifa;
            AlmacenModel modAlmacen;

            var usuario = UsuariosData.ObtenerUsuario(16);

            var listadoTotal = VentaData.listarCotizacionDetalle(idordenservicio).ToList();

            foreach (var item in listadoTotal)
            {
                if (item.descripcion != "Repuesto")
                {
                    continue;
                }
                var modRepuesto = new ProductoData().obtenerProducto(item.idproducto);
                modAlmacen = new InventarioData().obtenerAlmacen(Constantes.CodAlmacen.Telecom_Repuestos);
                var existerepuesto = new InventarioData().obtenerInventario(modAlmacen.idalmacen.Value, item.idproducto, 45);

                #region enviomail
                StringBuilder sb = new StringBuilder();
                sb.Append("<table width='100%' cellpadding='0' cellspacing='0' border='0' dir='ltr' style='font-size:16px;background-color:rgb(227,225,225)'>");
                sb.Append("<tbody>");
                sb.Append("<tr>");
                sb.Append("        <td align='center' valign='top' style='margin:0;padding:40'>");
                sb.Append("            <table align='center' border='0' cellspacing='0' cellpadding='0' width='700' bgcolor='#1ab394' style='width:700px;border:1px solid ");
                sb.Append("         transparent; ");
                sb.Append("order-radius:13px;margin:auto;background-color:#18a689'>");
                sb.Append("                <tbody>");
                sb.Append("					<tr>");
                sb.Append("					<td>");
                sb.Append("						<table cellpadding='0' cellspacing='0' border='0' width='100%'>");
                sb.Append("						<tbody>");
                sb.Append("							<tr>");
                sb.Append("							<td valign='top' align='left' style='padding:0px;margin:0px'>");
                sb.Append("								<table cellpadding='0' cellspacing='0' border='0' width='100%'>");
                sb.Append("								<tbody>");
                sb.Append("									<tr>");
                sb.Append("									<td align='left' valign='top'>");
                sb.Append("									<table width='100%' border='0' cellpadding='0' cellspacing='0' align='center'>");
                sb.Append("										<tbody>");
                sb.Append("											<tr>");
                sb.Append("											<td align='left' valign='top' style='font-family:Arial,Helvetica,sans-serif;font-size:20px;border-radius:6px");
                sb.Append("	                                        color:rgb(' sb.Append('55,255,255)'>");
                sb.Append("												<div style='text-align:center'><span style='color:rgb(255,255,255);font-weight:bold'><br></span></div>");
                sb.Append("												<div style='text-align:center'><span style='color:rgb(255,255,255);font-weight:bold'>Smartway - SIR Notificaciones");
                sb.Append("                                             </span></div>");
                sb.Append("												<div style='text-align:center'><span style='color:rgb(255,255,255);font-weight:bold'><br></span></div>");
                sb.Append("												<span style='color:rgb(38,38,38)'></span>");
                sb.Append("											</td>");
                sb.Append("											</tr>");
                sb.Append("										</tbody>");
                sb.Append("									</table>");
                sb.Append("									</td>");
                sb.Append("									</tr>");
                sb.Append("									<tr>");
                sb.Append("									<td>");
                sb.Append("										<table width='100%' border='0' cellpadding='10' cellspacing='10' align='center'  bgcolor='white'>");
                sb.Append("										<tbody>");
                sb.Append("										       <tr>");
                sb.Append("												<td align='left' valign='top' style='padding:10px;font-family:Arial,Helvetica,sans-serif;color:rgb(38,38,38)");
                sb.Append("                                             font-size:12px;background-color:rgb(255,255,255);width:190px '  colspan='4'> ");
                sb.Append("													Sr(a). "+ usuario.usr_str_nombre + ' ' + usuario.usr_str_apellidos + "");
                sb.Append("												</td>");
                sb.Append("											</tr>");
                sb.Append("											<tr>");
                sb.Append("												<td colspan='10' align='left' valign='top' style='padding:10px;font-family:Arial,Helvetica,sans-serif;color:rgb(38,38,38);");
                sb.Append("                                         font-size:12px;background-color:rgb(255,255,255);width:190px '  colspan='4'>");
                sb.Append("												   Se le informa que el usuario "+ Usuario.NombreUsuario + " ha realizado una solicitud de respuesto para la reparación de la orden de servicio: " + modOrdenServicio.numeroordenservicio);
                sb.Append("												</td>");
                sb.Append("											</tr>");
                sb.Append("												<tr>");
                sb.Append("												<td colspan='10' align='left' valign='top' style='padding:10px;font-family:Arial,Helvetica,sans-serif;color:rgb(38,38,38);");
                sb.Append("                                             font-size:14px;font-weight:bold;background-color:rgb(255,255,255)'  colspan='4'>");
                sb.Append("													<span style='font-family:Arial,Helvetica,sans-serif;color:rgb(38,38,38)'>Se ha solicitado el siguiente respuesto.</span> ");
                sb.Append("");
                sb.Append("												</td>");
                sb.Append("											</tr>");
                sb.Append("											<tr>");
                sb.Append("												<td align='left' valign='top' style='padding:10px;font-family:Arial,Helvetica,sans-serif;color:rgb(38,38,38);");
                sb.Append("ont-size:12px;background-color:rgb(255,255,255);width:190px'>");
                sb.Append("													"+ modRepuesto.codigoproducto);
                sb.Append("												</td>");
                sb.Append("												<td align='left' valign='top' style='padding:10px;font-family:Arial,Helvetica,sans-serif;color:rgb(38,38,38);");
                sb.Append("ont-size:12px;background-color:rgb(255,255,255);width:190px'>");
                sb.Append("												</td>");
                sb.Append("												<td align='left' valign='top' style='padding:10px;font-family:Arial,Helvetica,sans-serif;color:rgb(38,38,38);");
                sb.Append("ont-size:12px;background-color:rgb(255,255,255);width:190px'>");
                sb.Append("													"+ modRepuesto.descripcionlarga);
                sb.Append("												</td>");
                //sb.Append("                                            < td align = 'left' valign = 'top' style = 'padding:10px;font-family:Arial,Helvetica,sans-serif;color:rgb(38,38,38);");
                //sb.Append("ont-size:12px;background-color:rgb(255,255,255);width:190px'>");
                //sb.Append("													" + existerepuesto == null ? "" : existerepuesto.serie);
                sb.Append("												</td>");
                sb.Append("											</tr>");
                sb.Append("									");
                sb.Append("											");
                sb.Append("										</tbody>");
                sb.Append("										");
                sb.Append("										</table>");
                sb.Append("									</td>");
                sb.Append("									</tr>");
                sb.Append("									<tr>");
                sb.Append("									<td>");
                sb.Append("										");
                sb.Append("						</tbody>");
                sb.Append("						</table>");
                sb.Append("					</td>");
                sb.Append("					</tr>");
                sb.Append("				</tbody>");
                sb.Append("			</table>");
                sb.Append("        </td>");
                sb.Append("    </tr>");
                sb.Append("</tbody>");
                sb.Append("</table>");
                #endregion

                bool correo = MailHelper.EnviarMail(usuario.usr_str_email, "[Se ha solicitado un repuesto de almacén]", sb.ToString(), true);


                if (existerepuesto == null)
                {
                }
                else if (existerepuesto.cantidad == 0)
                {
                    // NO se notifica
                }
                else
                {
                    existerepuesto.cantidad = existerepuesto.cantidad - 1;
                    if (existerepuesto.serie != null || existerepuesto.imei != null)
                    {
                        if (existerepuesto.serie != "" || existerepuesto.imei != "")
                        {
                            existerepuesto.idestado = (Int32)Constantes.Producto.NoDisponible;
                        }
                        else
                        {
                            existerepuesto.idestado = (Int32)Constantes.Producto.Disponible;
                        }
                    }
                    else
                    {
                        existerepuesto.idestado = (Int32)Constantes.Producto.Disponible;
                    }

                    existerepuesto.__idoperacion = 2;

                    new InventarioData().InsertarActualizarInventario(existerepuesto);
                }


                var diagnostico = new DiagnosticoData().listarDiagnostico(null, null, null, null, item.iddiagnostico).FirstOrDefault();

                var aux = new ReparacionData().listarReparacion(null
                                                                , null, item.idreparacion).ToList();


                var modReparacion = aux.Where(x => x.idreparacion.Value.Equals(item.idreparacion)).FirstOrDefault();


                var modIncidencia = new IncidenciaData().ObtenerIncidencia(modOrdenServicio.idincidencia.Value);

                modTarifa = new AgendamientoData().calcularTarifa(
                    modIncidencia.idtipoproducto
                    , modReparacion.idnivelreparacion
                    , modIncidencia.idpartner);


                TrabajoDetalleModel                = new OrdenTrabajoDetalleModel();
                TrabajoDetalleModel.activo         = true;
                TrabajoDetalleModel.costo          = modRepuesto.costounitario;
                TrabajoDetalleModel.diagnostico    = diagnostico.descripcion;
                TrabajoDetalleModel.reparacion     = modReparacion.descripcion;
                TrabajoDetalleModel.repuesto       = modRepuesto.descripcionlarga;
                TrabajoDetalleModel.iddiagnostico  = item.iddiagnostico;
                TrabajoDetalleModel.idrepuesto     = item.idproducto;
                TrabajoDetalleModel.idreparacion   = item.idreparacion;
                TrabajoDetalleModel.costo          = modRepuesto.costounitario;
                TrabajoDetalleModel.descripcion    = "Repuesto";
                TrabajoDetalleModel.idordentrabajo = modOrdenServicio.idordentrabajo.Value;
                TrabajoDetalleModel.__idoperacion  = 1;
                TrabajoDetalleModel.servicio       = false;
                if (existerepuesto != null)
                {
                    TrabajoDetalleModel.idinventario = existerepuesto.idinventario;
                }
                var asociado = new ReparacionesData().InsertarActualizarOrdenTrabajoDetalle(TrabajoDetalleModel);



                if (modTarifa != null)
                {
                    TrabajoDetalleModel                    = new OrdenTrabajoDetalleModel();
                    TrabajoDetalleModel.activo             = true;
                    TrabajoDetalleModel.costo              = modTarifa.costo.Value;
                    TrabajoDetalleModel.diagnostico        = diagnostico.descripcion;
                    TrabajoDetalleModel.reparacion         = modReparacion.nivelreparacion;
                    TrabajoDetalleModel.repuesto           = "";
                    TrabajoDetalleModel.iddiagnostico      = item.iddiagnostico;
                    TrabajoDetalleModel.idrepuesto         = item.idrepuesto;
                    TrabajoDetalleModel.idreparacion       = item.idreparacion;
                    TrabajoDetalleModel.descripcion        = modReparacion.nivelreparacion;
                    TrabajoDetalleModel.idordentrabajo     = modOrdenServicio.idordentrabajo.Value;
                    TrabajoDetalleModel.servicio           = true;
                    TrabajoDetalleModel.idservicioasociado = asociado;
                    TrabajoDetalleModel.__idoperacion      = 1;
                    new ReparacionesData().InsertarActualizarOrdenTrabajoDetalle(TrabajoDetalleModel);
                }
            }



            //  return Json(new { res = true });



            #endregion



            return(Json(new { res = true }));
        }
Ejemplo n.º 3
0
 public DiagnosticoBusiness(String cadenaConexion)
 {
     diagnosticoData = new DiagnosticoData(cadenaConexion);
 }
        public JsonResult CotizarIncidencia(int?iddiagnostico
                                            , int?idreparacion
                                            , int?idrepuesto
                                            , int?idpartner
                                            , int?idtipoproducto)
        {
            var modRepuesto = new ProductoData().obtenerProducto(idrepuesto.Value);



            var diagnostico   = new DiagnosticoData().listarDiagnostico(null, null, null, null, iddiagnostico).FirstOrDefault();
            var aux           = new ReparacionData().listarReparacion(null, null, idreparacion.Value).ToList();
            var modReparacion = aux.Where(x => x.idreparacion.Value.Equals(idreparacion)).FirstOrDefault();

            var modServicioReparacion = new AgendamientoData().calcularTarifa(
                idtipoproducto.Value
                , modReparacion.idnivelreparacion
                , idpartner.Value);


            var listadoactual = (List <VentaCotizacionDetalleModel>)Session["CotizacionDetalleModel"];

            if (listadoactual == null)
            {
                listadoactual = new List <VentaCotizacionDetalleModel>();
            }

            listadoactual.Add(new VentaCotizacionDetalleModel
            {
                costototal    = modRepuesto.costounitario,
                descripcion   = "Repuesto",
                diagnostico   = diagnostico.descripcion,
                reparacion    = modReparacion.descripcion,
                repuesto      = modRepuesto.descripcionlarga,
                iddiagnostico = iddiagnostico.Value,
                idrepuesto    = idrepuesto.Value,
                idreparacion  = idreparacion.Value
            });

            if (modServicioReparacion != null)
            {
                var servrep = listadoactual.Where(x => x.descripcion.Equals("Servicio")).FirstOrDefault();

                if (servrep == null)
                {
                    listadoactual.Add(new VentaCotizacionDetalleModel
                    {
                        costototal    = modServicioReparacion.costo.Value,
                        descripcion   = "Servicio",
                        diagnostico   = modServicioReparacion.nivelreparacion,
                        reparacion    = modReparacion.descripcion,
                        repuesto      = modRepuesto.descripcionlarga,
                        iddiagnostico = iddiagnostico.Value,
                        idrepuesto    = idrepuesto.Value,
                        idreparacion  = idreparacion.Value
                    });
                }
                else
                {
                    if (servrep.costototal < modServicioReparacion.costo.Value)
                    {
                        listadoactual.Add(new VentaCotizacionDetalleModel
                        {
                            costototal    = modServicioReparacion.costo.Value,
                            descripcion   = "Servicio",
                            diagnostico   = modServicioReparacion.nivelreparacion,
                            reparacion    = modReparacion.descripcion,
                            repuesto      = modRepuesto.descripcionlarga,
                            iddiagnostico = iddiagnostico.Value,
                            idrepuesto    = idrepuesto.Value,
                            idreparacion  = idreparacion.Value
                        });
                    }
                }
            }
            Session["CotizacionDetalleModel"] = listadoactual;


            var total    = listadoactual.Where(x => x.repuesto == null).Sum(x => x.costototal);
            var subtotal = (double)(total) / 1.18;
            var igv      = total - (decimal)subtotal;

            return(Json(new { res = true, total = total, subtotal = subtotal, igv = igv }));
        }
        public ActionResult Cotizar(long idordentrabajo)
        {
            Session["CotizacionDetalleModel"] = null;
            var model          = new VentaCotizacionModel();
            var dataIncidencia = new IncidenciaData();
            var listadoactual  = new List <VentaCotizacionDetalleModel>();


            var modOrdenTrabajo  = new ReparacionesData().obtenerOrdenTrabajo(idordentrabajo);
            var modOrdenServicio = new OrdenServicioData().obtenerOrdenServicio(modOrdenTrabajo.idordenserviciotecnico.Value);
            var modIncidencia    = new IncidenciaData().ObtenerIncidencia(modOrdenServicio.idincidencia.Value);

            //var listadoTotal = new VentaData().listarCotizacionDetalle(idincidencia).ToList();

            //var modIncidencia = dataIncidencia.ObtenerIncidencia(idincidencia);
            //var modSucursal = new SucursalData().obtenerSucursal(modIncidencia.idsucursal);



            #region EvaluacionDeGarantia

            //model.engarantia = modIncidencia.engarantia;
            //if (model.engarantia)
            //{
            //    if (modIncidencia.idtipogarantia == (Int32)(Constantes.TipoGarantia.Cliente))
            //        model.garantia = "Con garantía de Cliente";
            //    else if (modIncidencia.idtipogarantia == (Int32)(Constantes.TipoGarantia.DAP))
            //        model.garantia = "Con garantía DAP";
            //    else if (modIncidencia.idtipogarantia == (Int32)(Constantes.TipoGarantia.SinGarantia))
            //        model.garantia = "Sin Garantia";
            //}

            #endregion

            //if (listadoTotal.Count > 0)
            //{
            //    Session["CotizacionDetalleModel"] = listadoTotal;
            //    model.idsucursalreparacion = listadoTotal[0].idsucursalreparacion;
            //    model.str_total = (Convert.ToDecimal(listadoTotal.Sum(x => x.costo).ToString()) * (decimal)(1.00)).ToString("0.##");
            //    model.str_subtotal = (Convert.ToDecimal(model.str_total) / (decimal)(1.18)).ToString("0.##");
            //    model.str_igv = (Convert.ToDecimal(model.str_total) - Convert.ToDecimal(model.str_subtotal)).ToString("0.##");
            //    model.idcotizacion = listadoTotal[0].idcotizacion;
            //    model.iddirecciondelivery = listadoTotal[0].iddirecciondelivery;
            //    model.idsucursalreparacion = listadoTotal[0].idsucursalreparacion;
            //}
            //else
            //{
            //    if (!model.engarantia)
            //    {
            //        //listadoTotal.Add(new CotizacionDetalleModel
            //        //{
            //        //    costo = Convert.ToDecimal(20.00),
            //        //    descripcion = "Servicio de Reparación"
            //        //});
            //        //listadoTotal.Add(new CotizacionDetalleModel
            //        //{
            //        //    costo = Convert.ToDecimal(10.00),
            //        //    descripcion = "Delivery"
            //        //});
            //    }
            //    Session["CotizacionDetalleModel"] = listadoTotal;

            //}


            #region combos


            var sucursal = new SucursalData().ListarSucursal("", "", null, (Int32)Constantes.Partner.Smartway).Where(x => x.reparacion);

            var listasucursal = new SelectList(
                sucursal,
                "idsucursal",
                "nombre");


            ViewData["listasucursal"] = listasucursal;


            var diagnostico      = new DiagnosticoData().listarDiagnostico(null, null, modIncidencia.idtipoproducto, modOrdenServicio.engarantia);
            var listadiagnostico = new SelectList(diagnostico, "iddiagnostico", "descripcion");
            ViewData["listadiagnostico"] = listadiagnostico;

            #endregion

            #region Asignar propiedades cotizacion Model

            model.numeroincidencia = modIncidencia.numeroincidencia;
            model.falla            = modIncidencia.falla;
            model.producto         = modIncidencia.producto;
            model.codigoproducto   = modIncidencia.codigoproducto;
            model.fechaasignacion  = modOrdenTrabajo.fechahoraasignacion.Value;
            model.idpartner        = modIncidencia.idpartner;
            model.idtipoproducto   = modIncidencia.idtipoproducto;
            model.idfabricante     = modIncidencia.idfabricante;
            model.idsucursal       = modIncidencia.idsucursal;
            model.idproducto       = modIncidencia.idproducto;

            #endregion

            return(View(model));
        }