Ejemplo n.º 1
0
        /*
         *
         *
         * public static bool AjusteStock(ref DataRow row, string IdDeposito, string IdSeccion, string IdTipoDeAjuste, string IdProducto, decimal Cantidad)
         * {
         *      long IdSucursal = Security.IdSucursal;
         *      long IdEmpresa = Security.IdEmpresa;
         *
         *      return AjusteStock(ref row, IdSucursal, IdEmpresa, IdDeposito, IdSeccion, IdTipoDeAjuste, IdProducto, Cantidad);
         * }
         *
         *
         * /// <summary>
         * /// Permite realizar un ajuste de stock especificando todos los parámetros.
         * /// </summary>
         * /// <param name="row"></param>
         * /// <param name="IdSucursal"></param>
         * /// <param name="IdEmpresa"></param>
         * /// <param name="IdDeposito"></param>
         * /// <param name="IdSeccion"></param>
         * /// <param name="IdTipoDeAjuste"></param>
         * /// <param name="IdProducto"></param>
         * /// <param name="Cantidad"></param>
         * /// <returns></returns>
         * public static bool AjusteStock(ref DataRow row, long IdSucursal, long IdEmpresa, string IdDeposito, string IdSeccion, string IdTipoDeAjuste, string IdProducto, decimal Cantidad)
         * {
         *      tlg_MovimientosDeStockDataset.tlg_MovimientosDeStockRow rowS = tlg_MovimientosDeStock.NewRow();
         *      if (IdProducto == String.Empty)
         *      {
         *              row = (DataRow) rowS;
         *
         *              row.SetColumnError( "IdProducto" , "Falta ingresar el producto");
         *              return false;
         *      }
         *      if (IdTipoDeAjuste == String.Empty)
         *      {
         *              row = (DataRow) rowS;
         *              row.SetColumnError( "IdTipoDeAjuste" , "Falta ingresar el tipo de ajuste");
         *              return false;
         *      }
         *      if (IdDeposito == String.Empty)
         *      {
         *              row = (DataRow) rowS;
         *              row.SetColumnError( "IdDeposito" , "Falta ingresar el depósito");
         *              return false;
         *      }
         *      if (IdSeccion == String.Empty)
         *      {
         *              row = (DataRow) rowS;
         *              row.SetColumnError( "IdSeccion" , "Falta ingresar la sección");
         *              return false;
         *      }
         *      if (Cantidad <= 0)
         *      {
         *              row = (DataRow) rowS;
         *              row.SetColumnError( "Cantidad" , "La cantidad debe ser mayor a cero");
         *              return false;
         *      }
         *
         *      string IdEstadoDeStockDestino = String.Empty;
         *      decimal Signo = 1;
         *      GetEstadoDeStock(IdTipoDeAjuste, ref IdEstadoDeStockDestino, ref Signo);
         *
         *      Cantidad = Signo * Cantidad;
         *      rowS = GetMovimiento(IdSucursal, IdEmpresa, IdDeposito, IdSeccion,  null, IdEstadoDeStockDestino, IdTipoDeAjuste, IdProducto, Cantidad);
         *
         *      SentenciasReplicacion replicacion =  GenerateReplication();
         *      dataaccess.Stock.Update(rowS, String.Empty, IdEstadoDeStockDestino, replicacion);
         *      row = (DataRow) rowS;
         *      return true;
         * }
         *
         * /// <summary>
         * /// Función que realiza el movimiento de stock de los dos estados de stock definidos por el momento sin especificar sucursal ni empresa.
         * /// </summary>
         * /// <param name="IdDeposito"></param>
         * /// <param name="IdSeccion"></param>
         * /// <param name="IdMomento"></param>
         * /// <param name="IdProducto"></param>
         * /// <param name="Cantidad"></param>
         * /// <returns></returns>
         * public static bool MueveStock(string IdDeposito, string IdSeccion, long IdMomento, string IdProducto, decimal Cantidad)
         * {
         *
         *      long IdSucursal = Security.IdSucursal;
         *      long IdEmpresa = Security.IdEmpresa;
         *      return MueveStock(IdSucursal, IdEmpresa, IdDeposito, IdSeccion, IdMomento, IdProducto, Cantidad);
         * }
         * /// <summary>
         * /// Función que realiza el movimiento de stock de los dos estados de stock definidos por el momento.
         * /// </summary>
         * /// <param name="IdSucursal"></param>
         * /// <param name="IdEmpresa"></param>
         * /// <param name="IdDeposito"></param>
         * /// <param name="IdSeccion"></param>
         * /// <param name="IdMomento"></param>
         * /// <param name="IdProducto"></param>
         * /// <param name="Cantidad"></param>
         * /// <remarks > Dentro de Update row se graba dos veces, primero con origen y luego con destino.</remarks>
         * /// <returns></returns>
         * public static bool MueveStock(long IdSucursal, long IdEmpresa, string IdDeposito, string IdSeccion, long IdMomento, string IdProducto, decimal Cantidad)
         * {
         *      if (Cantidad <= 0) {return false;}
         *
         *      tlg_MovimientosDeStockDataset.tlg_MovimientosDeStockRow row = tlg_MovimientosDeStock.NewRow();
         *      string IdTipoDeAjuste = String.Empty;
         *      string EstadoStockOrigen = String.Empty;
         *      string EstadoStockDestino = String.Empty;
         *
         *      GetEstados(IdMomento, ref EstadoStockOrigen, ref EstadoStockDestino);
         *      row = GetMovimiento(IdSucursal, IdEmpresa, IdDeposito, IdSeccion, EstadoStockOrigen,EstadoStockDestino, IdTipoDeAjuste, IdProducto, Cantidad);
         *
         *      SentenciasReplicacion replicacion =  GenerateReplication();
         *      return dataaccess.Stock.Update(row, EstadoStockOrigen, EstadoStockDestino, replicacion);
         * }
         * /// <summary>
         * /// Función que copia todos los valores pasados por parámetros a la row de Movimientos de stock.
         * /// </summary>
         * /// <param name="IdSucursal"></param>
         * /// <param name="IdEmpresa"></param>
         * /// <param name="IdDeposito"></param>
         * /// <param name="IdSeccion"></param>
         * /// <param name="IdEstadoDeStock"></param>
         * /// <param name="IdTipoDeAjuste"></param>
         * /// <param name="IdProducto"></param>
         * /// <param name="Cantidad"></param>
         * /// <returns></returns>
         * ///
         */
        public static tlg_MovimientosDeStockDataset.tlg_MovimientosDeStockRow GetMovimiento(long IdSucursal, long IdEmpresa, string IdDeposito, string IdSeccion, string IdEstadoDeStock, string IdTipoDeAjuste, string IdProducto, decimal Cantidad)
        {
            tlg_MovimientosDeStockDataset data = new tlg_MovimientosDeStockDataset();

            tlg_MovimientosDeStockDataset.tlg_MovimientosDeStockRow row = data.tlg_MovimientosDeStock.Newtlg_MovimientosDeStockRow();
            row.IdMovimientoDeStock          = Util.NewStringId();
            row.IdSucursal                   = IdSucursal;
            row.IdEmpresa                    = IdEmpresa;
            row.IdDeposito                   = IdDeposito;
            row.IdSeccion                    = IdSeccion;
            row.IdEstadoDeStock              = IdEstadoDeStock;
            row.IdTipoDeAjuste               = IdTipoDeAjuste;
            row.IdProducto                   = IdProducto;
            row.Cantidad                     = Cantidad;
            row.IdConexionCreacion           = Security.IdConexion;
            row.FechaCreacion                = mz.erp.businessrules.Sistema.DateTime.Now;
            row.IdConexionUltimaModificacion = Security.IdConexion;
            row.IdReservado                  = 0;
            row.RowId      = Guid.Empty;
            row.IdEmpresa  = Security.IdEmpresa;
            row.IdSucursal = Security.IdSucursal;
            data.tlg_MovimientosDeStock.Addtlg_MovimientosDeStockRow(row);

            return(row);
        }
Ejemplo n.º 2
0
        public static void Update(tlg_MovimientosDeStockDataset.tlg_MovimientosDeStockRow row)
        {
            if (row.RowState == DataRowState.Detached)
            {
                ((tlg_MovimientosDeStockDataset.tlg_MovimientosDeStockDataTable)row.Table).Addtlg_MovimientosDeStockRow(row);
            }

            Update(row.Table);
        }
Ejemplo n.º 3
0
        public static void Update(tlg_MovimientosDeStockDataset.tlg_MovimientosDeStockRow row, SqlTransaction trx, SentenciasReplicacion replicacion)
        {
            if (row.RowState == DataRowState.Detached)
            {
                ((tlg_MovimientosDeStockDataset.tlg_MovimientosDeStockDataTable)row.Table).Addtlg_MovimientosDeStockRow(row);
            }

            Update(row.Table, trx, replicacion);
        }
Ejemplo n.º 4
0
        public static void UpdateWithValidation(tlg_MovimientosDeStockDataset.tlg_MovimientosDeStockRow row)
        {
            ApplicationAssert.Check(row != null, "El argumento row no debe ser nulo.", ApplicationAssert.LineNumber);

            if (RowIsValid(row))
            {
                Update(row);
            }
        }
Ejemplo n.º 5
0
 /// <summary>
 /// Obtiene un registro de la tabla tlg_MovimientosDeStock que luego puede ser persistido en la base de datos.
 /// </summary>
 public static tlg_MovimientosDeStockDataset.tlg_MovimientosDeStockRow GetByPk(string IdMovimientoDeStock)
 {
     tlg_MovimientosDeStockDataset.tlg_MovimientosDeStockRow row = mz.erp.dataaccess.tlg_MovimientosDeStock.GetByPk(IdMovimientoDeStock);
     foreach (DataColumn dc in row.Table.Columns)
     {
         if (row[dc] == System.DBNull.Value)
         {
             row[dc] = Util.DefaultValue(dc.DataType);
         }
     }
     return(row);
 }
Ejemplo n.º 6
0
        /// Método para utilizacion de proceso "Stock a cero" (no tiene el parámetro row ni la cantidad)
        /// ya que el ajuste (positivo y negativo) para todos los estados de stock del producto depende
        /// del stock que tiene.
        /// <param name="row"></param>
        /// <param name="IdSucursal"></param>
        /// <param name="IdEmpresa"></param>
        /// <param name="IdDeposito"></param>
        /// <param name="IdSeccion"></param>
        /// <param name="IdTipoDeAjuste"></param>
        /// <param name="IdEstadoDeStock"></param>
        /// <param name="IdProducto"></param>
        /// <returns></returns>
        public static bool AjusteStock(ref DataRow row, long IdSucursal, long IdEmpresa, string IdDeposito, string IdSeccion, string IdTipoDeAjuste, string IdEstadoDeStock, string IdProducto, decimal Cantidad)
        {
            tlg_MovimientosDeStockDataset.tlg_MovimientosDeStockRow rowS = tlg_MovimientosDeStock.NewRow();
            if (IdProducto == String.Empty)
            {
                row = (DataRow)rowS;

                row.SetColumnError("IdProducto", "Falta ingresar el producto");
                return(false);
            }
            if (IdTipoDeAjuste == String.Empty)
            {
                row = (DataRow)rowS;
                row.SetColumnError("IdTipoDeAjuste", "Falta ingresar el tipo de ajuste");
                return(false);
            }
            if (IdDeposito == String.Empty)
            {
                row = (DataRow)rowS;
                row.SetColumnError("IdDeposito", "Falta ingresar el depósito");
                return(false);
            }
            if (IdSeccion == String.Empty)
            {
                row = (DataRow)rowS;
                row.SetColumnError("IdSeccion", "Falta ingresar la sección");
                return(false);
            }

            rowS = GetMovimiento(IdSucursal, IdEmpresa, IdDeposito, IdSeccion, IdEstadoDeStock, IdTipoDeAjuste, IdProducto, Cantidad * (-1));
            SentenciasReplicacion replicacion = GenerateReplication();

            dataaccess.Stock.UpdateStockACero(rowS, String.Empty, IdEstadoDeStock, replicacion);
            row = (DataRow)rowS;
            return(true);
        }
Ejemplo n.º 7
0
        /// <summary>
        /// Establece los valores por defecto de tlg_MovimientosDeStockRow.
        /// </summary>
        public static tlg_MovimientosDeStockDataset.tlg_MovimientosDeStockRow SetRowDefaultValues(tlg_MovimientosDeStockDataset.tlg_MovimientosDeStockRow row)
        {
            row.IdMovimientoDeStock = Util.NewStringId();
            row.IdProducto          = string.Empty;
            row.Cantidad            = 0;
            row.IdDeposito          = string.Empty;
            row.IdSeccion           = string.Empty;
            row.IdEstadoDeStock     = string.Empty;
            row.IdTipoDeAjuste      = string.Empty;
            row.FechaCreacion       = mz.erp.businessrules.Sistema.DateTime.Now;
            row.IdConexionCreacion  = Security.IdConexion;
            //row.UltimaModificacion = null;
            row.IdConexionUltimaModificacion = Security.IdConexion;
            row.IdReservado = 0;
            row.RowId       = Guid.Empty;
            row.IdSucursal  = Security.IdSucursal;
            row.IdEmpresa   = Security.IdEmpresa;

            return(row);
        }
Ejemplo n.º 8
0
        /// <summary>
        /// Valida un tlg_MovimientosDeStockRow.
        /// </summary>
        public static bool RowIsValid(tlg_MovimientosDeStockDataset.tlg_MovimientosDeStockRow row)
        {
            ApplicationAssert.Check(row != null, "El argumento row no debe ser nulo.", ApplicationAssert.LineNumber);
            bool   isValid = true;
            string mensaje;


            if (!IdMovimientoDeStockIsValid(row.IdMovimientoDeStock, out mensaje))
            {
                row.SetColumnError("IdMovimientoDeStock", mensaje);
                isValid = false;
            }

            if (!IdProductoIsValid(row.IdProducto, out mensaje))
            {
                row.SetColumnError("IdProducto", mensaje);
                isValid = false;
            }

            if (!CantidadIsValid(row.Cantidad, out mensaje))
            {
                row.SetColumnError("Cantidad", mensaje);
                isValid = false;
            }

            if (!IdDepositoIsValid(row.IdDeposito, out mensaje))
            {
                row.SetColumnError("IdDeposito", mensaje);
                isValid = false;
            }

            if (!IdSeccionIsValid(row.IdSeccion, out mensaje))
            {
                row.SetColumnError("IdSeccion", mensaje);
                isValid = false;
            }

            if (!IdEstadoDeStockIsValid(row.IdEstadoDeStock, out mensaje))
            {
                row.SetColumnError("IdEstadoDeStock", mensaje);
                isValid = false;
            }

            if (!IdTipoDeAjusteIsValid(row.IdTipoDeAjuste, out mensaje))
            {
                row.SetColumnError("IdTipoDeAjuste", mensaje);
                isValid = false;
            }

            /*if ( !FechaCreacionIsValid( row.FechaCreacion, out mensaje) )
             * {
             *      row.SetColumnError( "FechaCreacion" , mensaje);
             *      isValid=false;
             *
             * }
             *
             * if ( !IdConexionCreacionIsValid( row.IdConexionCreacion, out mensaje) )
             * {
             *      row.SetColumnError( "IdConexionCreacion" , mensaje);
             *      isValid=false;
             *
             * }
             *
             * if ( !UltimaModificacionIsValid( row.UltimaModificacion, out mensaje) )
             * {
             *      row.SetColumnError( "UltimaModificacion" , mensaje);
             *      isValid=false;
             *
             * }
             *
             * if ( !IdConexionUltimaModificacionIsValid( row.IdConexionUltimaModificacion, out mensaje) )
             * {
             *      row.SetColumnError( "IdConexionUltimaModificacion" , mensaje);
             *      isValid=false;
             *
             * }
             *
             * if ( !IdReservadoIsValid( row.IdReservado, out mensaje) )
             * {
             *      row.SetColumnError( "IdReservado" , mensaje);
             *      isValid=false;
             *
             * }
             *
             * if ( !RowIdIsValid( row.RowId, out mensaje) )
             * {
             *      row.SetColumnError( "RowId" , mensaje);
             *      isValid=false;
             *
             * }
             *
             * if ( !IdSucursalIsValid( row.IdSucursal, out mensaje) )
             * {
             *      row.SetColumnError( "IdSucursal" , mensaje);
             *      isValid=false;
             *
             * }
             *
             * if ( !IdEmpresaIsValid( row.IdEmpresa, out mensaje) )
             * {
             *      row.SetColumnError( "IdEmpresa" , mensaje);
             *      isValid=false;
             *
             * }
             * ;*/

            return(isValid);
        }
Ejemplo n.º 9
0
        /// <summary>
        /// Envia los cambios del tlg_MovimientosDeStockRow a la base de datos.
        /// </summary>
        public static void Update(tlg_MovimientosDeStockDataset.tlg_MovimientosDeStockRow row)
        {
            ApplicationAssert.Check(row != null, "El argumento row no debe ser nulo.", ApplicationAssert.LineNumber);

            mz.erp.dataaccess.tlg_MovimientosDeStock.Update(row);
        }