예제 #1
0
        private void repSelect_EditValueChanging(object sender, DevExpress.XtraEditors.Controls.ChangingEventArgs e)
        {
            // --- edit if user row is equal to current user
            // --- guardar check
            bool sign_factor_authorized = SignFactorAuthorized();

            CSolution_titration oSolution_titration = gvSolTitration.GetRow(gvSolTitration.FocusedRowHandle) as CSolution_titration;

            if (oSolution_titration.Prepared_by == Comun.User_system.Iduser ||
                sign_factor_authorized)
            {
                oSolution_titration.Status_titration = Convert.ToBoolean(e.NewValue);
                oSolution_titration.Date_prepared    = Comun.GetDate();
                faSolution_titration.Update(oSolution_titration);
                gvSolTitration.UpdateCurrentRow();

                // --- recalcular promedio
                Assign_average();

                // --- habilitar para firmar
                EnabledSignData();
            }
            else
            {
                e.Cancel = true;
            }
        }
예제 #2
0
        private void gvSolTitration_CellValueChanged(object sender, DevExpress.XtraGrid.Views.Base.CellValueChangedEventArgs e)
        {
            if (e.Column == gcCol_Practice_reading || e.Column == gcCol_Theorical_reading)
            {
                if (gvSolTitration.GetFocusedRowCellValue(gcCol_Theorical_reading) != null)
                {
                    CSolution_titration oSolution_titration = gvSolTitration.GetRow(gvSolTitration.FocusedRowHandle) as CSolution_titration;
                    oSolution_titration.Date_prepared = Comun.GetDate();
                    if (!faSolution_titration.Update(oSolution_titration))
                    {
                        faSolution_titration.Insert(oSolution_titration);
                    }
                }

                if (gvSolTitration.GetFocusedRowCellValue(gcCol_Practice_reading) != null)
                {
                    CSolution_titration oSolution_titration = gvSolTitration.GetRow(gvSolTitration.FocusedRowHandle) as CSolution_titration;
                    oSolution_titration.Date_prepared = Comun.GetDate();
                    if (!faSolution_titration.Update(oSolution_titration))
                    {
                        faSolution_titration.Insert(oSolution_titration);
                    }
                }

                if (gvSolTitration.GetFocusedRowCellValue(gcCol_Theorical_reading) != null &&
                    gvSolTitration.GetFocusedRowCellValue(gcCol_Practice_reading) != null)
                {
                    decimal theorical_reading = Convert.ToDecimal(gvSolTitration.GetFocusedRowCellValue(gcCol_Theorical_reading));
                    decimal practice_reading  = Convert.ToDecimal(gvSolTitration.GetFocusedRowCellValue(gcCol_Practice_reading));
                    decimal factor            = 0;

                    if (practice_reading > 0)
                    {
                        factor = Math.Round(theorical_reading / practice_reading, 4);
                    }

                    gvSolTitration.SetFocusedRowCellValue(gcCol_Factor, factor);

                    CSolution_titration oSolution_titration = gvSolTitration.GetRow(gvSolTitration.FocusedRowHandle) as CSolution_titration;
                    oSolution_titration.Date_prepared = Comun.GetDate();
                    if (!faSolution_titration.Update(oSolution_titration))
                    {
                        faSolution_titration.Insert(oSolution_titration);
                    }
                }

                // --- habilitar la firma del analista
                Flag_Date_Modified = true;

                EnabledSignData();
            }
            if (e.Column == gcCol_Factor)
            {
                Assign_average();
            }
        }
예제 #3
0
        /// <summary>
        /// insert new row in the table
        /// </summary>
        /// <param name="businessObject">business object</param>
        /// <returns>true of successfully insert</returns>
        public bool Insert(CSolution_titration businessObject)
        {
            NpgsqlCommand sqlCommand = new NpgsqlCommand();

            sqlCommand.CommandText = "public.sp_solution_titration_Insert";
            sqlCommand.CommandType = CommandType.StoredProcedure;

            // Use connection object of base class
            sqlCommand.Connection = MainConnection;

            try
            {
                sqlCommand.Parameters.AddWithValue("p_idsolution_titration", businessObject.Idsolution_titration);
                sqlCommand.Parameters["p_idsolution_titration"].NpgsqlDbType = NpgsqlDbType.Integer;
                sqlCommand.Parameters["p_idsolution_titration"].Direction    = ParameterDirection.InputOutput;

                sqlCommand.Parameters.AddWithValue("p_idtitration_main", businessObject.Idtitration_main);
                sqlCommand.Parameters["p_idtitration_main"].NpgsqlDbType = NpgsqlDbType.Integer;
                sqlCommand.Parameters.AddWithValue("p_idsolution", businessObject.Idsolution);
                sqlCommand.Parameters["p_idsolution"].NpgsqlDbType = NpgsqlDbType.Integer;
                sqlCommand.Parameters.AddWithValue("p_aliquot", businessObject.Aliquot);
                sqlCommand.Parameters["p_aliquot"].NpgsqlDbType = NpgsqlDbType.Numeric;
                sqlCommand.Parameters.AddWithValue("p_theorical_reading", businessObject.Theorical_reading);
                sqlCommand.Parameters["p_theorical_reading"].NpgsqlDbType = NpgsqlDbType.Numeric;
                sqlCommand.Parameters.AddWithValue("p_practice_reading", businessObject.Practice_reading);
                sqlCommand.Parameters["p_practice_reading"].NpgsqlDbType = NpgsqlDbType.Numeric;
                sqlCommand.Parameters.AddWithValue("p_factor", businessObject.Factor);
                sqlCommand.Parameters["p_factor"].NpgsqlDbType = NpgsqlDbType.Numeric;
                sqlCommand.Parameters.AddWithValue("p_prepared_by", businessObject.Prepared_by);
                sqlCommand.Parameters["p_prepared_by"].NpgsqlDbType = NpgsqlDbType.Smallint;
                sqlCommand.Parameters.AddWithValue("p_date_prepared", businessObject.Date_prepared);
                sqlCommand.Parameters["p_date_prepared"].NpgsqlDbType = NpgsqlDbType.Timestamp;
                sqlCommand.Parameters.AddWithValue("p_status_titration", businessObject.Status_titration);
                sqlCommand.Parameters["p_status_titration"].NpgsqlDbType = NpgsqlDbType.Boolean;
                sqlCommand.Parameters.AddWithValue("p_average", businessObject.Average);
                sqlCommand.Parameters["p_average"].NpgsqlDbType = NpgsqlDbType.Numeric;


                MainConnection.Open();

                sqlCommand.ExecuteNonQuery();
                businessObject.Idsolution_titration = Convert.ToInt32(sqlCommand.Parameters["p_idsolution_titration"].Value);

                return(true);
            }
            catch (Exception ex)
            {
                throw new Exception("CSolution_titration::Insert::Error occured.", ex);
            }
            finally
            {
                MainConnection.Close();
                sqlCommand.Dispose();
            }
        }
예제 #4
0
        private void repValue_EditValueChanging(object sender, DevExpress.XtraEditors.Controls.ChangingEventArgs e)
        {
            // --- get user of current row
            CSolution_titration oSolution_titration = gvSolTitration.GetRow(gvSolTitration.FocusedRowHandle) as CSolution_titration;

            // --- edit if user row is equal to current user
            if (oSolution_titration.Prepared_by != Comun.User_system.Iduser)
            {
                e.Cancel = true;
            }
        }
예제 #5
0
        /// <summary>
        /// Populate business object from data reader
        /// </summary>
        /// <param name="businessObject">business object</param>
        /// <param name="dataReader">data reader</param>
        internal void PopulateBusinessObjectFromReader(CSolution_titration businessObject, IDataReader dataReader)
        {
            businessObject.Idsolution_titration = dataReader.GetInt32(dataReader.GetOrdinal(CSolution_titration.CSolution_titrationFields.Idsolution_titration.ToString()));

            if (!dataReader.IsDBNull(dataReader.GetOrdinal(CSolution_titration.CSolution_titrationFields.Idtitration_main.ToString())))
            {
                businessObject.Idtitration_main = dataReader.GetInt32(dataReader.GetOrdinal(CSolution_titration.CSolution_titrationFields.Idtitration_main.ToString()));
            }

            if (!dataReader.IsDBNull(dataReader.GetOrdinal(CSolution_titration.CSolution_titrationFields.Idsolution.ToString())))
            {
                businessObject.Idsolution = dataReader.GetInt32(dataReader.GetOrdinal(CSolution_titration.CSolution_titrationFields.Idsolution.ToString()));
            }

            if (!dataReader.IsDBNull(dataReader.GetOrdinal(CSolution_titration.CSolution_titrationFields.Aliquot.ToString())))
            {
                businessObject.Aliquot = dataReader.GetDecimal(dataReader.GetOrdinal(CSolution_titration.CSolution_titrationFields.Aliquot.ToString()));
            }

            if (!dataReader.IsDBNull(dataReader.GetOrdinal(CSolution_titration.CSolution_titrationFields.Theorical_reading.ToString())))
            {
                businessObject.Theorical_reading = dataReader.GetDecimal(dataReader.GetOrdinal(CSolution_titration.CSolution_titrationFields.Theorical_reading.ToString()));
            }

            if (!dataReader.IsDBNull(dataReader.GetOrdinal(CSolution_titration.CSolution_titrationFields.Practice_reading.ToString())))
            {
                businessObject.Practice_reading = dataReader.GetDecimal(dataReader.GetOrdinal(CSolution_titration.CSolution_titrationFields.Practice_reading.ToString()));
            }

            if (!dataReader.IsDBNull(dataReader.GetOrdinal(CSolution_titration.CSolution_titrationFields.Factor.ToString())))
            {
                businessObject.Factor = dataReader.GetDecimal(dataReader.GetOrdinal(CSolution_titration.CSolution_titrationFields.Factor.ToString()));
            }

            if (!dataReader.IsDBNull(dataReader.GetOrdinal(CSolution_titration.CSolution_titrationFields.Prepared_by.ToString())))
            {
                businessObject.Prepared_by = (short?)dataReader.GetInt16(dataReader.GetOrdinal(CSolution_titration.CSolution_titrationFields.Prepared_by.ToString()));
            }

            if (!dataReader.IsDBNull(dataReader.GetOrdinal(CSolution_titration.CSolution_titrationFields.Date_prepared.ToString())))
            {
                businessObject.Date_prepared = dataReader.GetDateTime(dataReader.GetOrdinal(CSolution_titration.CSolution_titrationFields.Date_prepared.ToString()));
            }

            if (!dataReader.IsDBNull(dataReader.GetOrdinal(CSolution_titration.CSolution_titrationFields.Status_titration.ToString())))
            {
                businessObject.Status_titration = dataReader.GetBoolean(dataReader.GetOrdinal(CSolution_titration.CSolution_titrationFields.Status_titration.ToString()));
            }

            if (!dataReader.IsDBNull(dataReader.GetOrdinal(CSolution_titration.CSolution_titrationFields.Average.ToString())))
            {
                businessObject.Average = dataReader.GetDecimal(dataReader.GetOrdinal(CSolution_titration.CSolution_titrationFields.Average.ToString()));
            }
        }
예제 #6
0
        /// <summary>
        /// Populate business objects from the data reader
        /// </summary>
        /// <param name="dataReader">data reader</param>
        /// <returns>list of CSolution_titration</returns>
        internal List <CSolution_titration> PopulateObjectsFromReader(IDataReader dataReader)
        {
            List <CSolution_titration> list = new List <CSolution_titration>();

            while (dataReader.Read())
            {
                CSolution_titration businessObject = new CSolution_titration();
                PopulateBusinessObjectFromReader(businessObject, dataReader);
                list.Add(businessObject);
            }
            return(list);
        }
예제 #7
0
        /// <summary>
        /// Select by primary key
        /// </summary>
        /// <param name="keys">primary keys</param>
        /// <returns>CSolution_titration business object</returns>
        public CSolution_titration SelectByPrimaryKey(CSolution_titrationKeys keys)
        {
            NpgsqlCommand sqlCommand = new NpgsqlCommand();

            sqlCommand.CommandText = "public.sp_solution_titration_SelectByPrimaryKey";
            sqlCommand.CommandType = CommandType.StoredProcedure;

            // Use connection object of base class
            sqlCommand.Connection = MainConnection;

            try
            {
                sqlCommand.Parameters.Add(new NpgsqlParameter("p_idsolution_titration", NpgsqlDbType.Integer, 4, "", ParameterDirection.Input, false, 0, 0, DataRowVersion.Proposed, keys.Idsolution_titration));


                MainConnection.Open();

                NpgsqlDataReader dataReader = sqlCommand.ExecuteReader();

                if (dataReader.Read())
                {
                    CSolution_titration businessObject = new CSolution_titration();

                    PopulateBusinessObjectFromReader(businessObject, dataReader);

                    return(businessObject);
                }
                else
                {
                    return(null);
                }
            }
            catch (Exception ex)
            {
                throw new Exception("CSolution_titration::SelectByPrimaryKey::Error occured.", ex);
            }
            finally
            {
                MainConnection.Close();
                sqlCommand.Dispose();
            }
        }