public JsonResult _UpdateProducts(Product ins)
        {
            //...Update Object
            ins.Total = ins.BTW + ins.Price;
            Product ins2 = ProdRep.Update(ins);

            //...Repopulate Grid...
            return Json(new GridModel(ProdRep.GetAllProduct()));
        }
        public List<Product> GetAllProduct()
        {
            //...Create New Instance of Object...
            List<Product> list = new List<Product>();
            Product ins;

            //...Database Connection...
            DataBaseConnection dbConn = new DataBaseConnection();
            SqlConnection con = dbConn.SqlConn();
            SqlCommand cmdI;

            //...SQL Commands...
            cmdI = new SqlCommand("SELECT t.*,s.Supplier FROM t_Product t inner join t_Supplier s on t.SupplierID = s.SupplierID WHERE t.Removed=0", con);
            cmdI.Connection.Open();
            SqlDataReader drI = cmdI.ExecuteReader();

            //...Retrieve Data...
            if (drI.HasRows)
            {
                while (drI.Read())
                {
                    ins = new Product();
                    ins.ProductID = Convert.ToInt32(drI["ProductID"]);
                    ins.Products = (drI["Product"]).ToString();
                    ins.ProductDescription = (drI["ProductDescription"]).ToString();
                    ins.Price = Convert.ToDecimal(drI["Price"]);
                    ins.Quantity = Convert.ToInt32(drI["Quantity"]);
                    ins.Total = Convert.ToDecimal(drI["Total"]);
                    ins.supplier = drI["Supplier"].ToString();
                    ins.BTW = Convert.ToDecimal(drI["BTW"]);
                    ins.CreatedDate = Convert.ToDateTime(drI["CreatedDate"]);
                    ins.CompanyID = Convert.ToInt32(drI["CompanyID"]);
                    ins.ModifiedDate = Convert.ToDateTime(drI["ModifiedDate"]);
                    ins.ModifiedBy = Convert.ToString(drI["ModifiedBy"]);
                    ins.Removed = Convert.ToBoolean(drI["Removed"]);
                    ins.SupplierID = Convert.ToInt32(drI["SupplierID"]);
                    list.Add(ins);
                }
            }

            //...Close Connections...
            drI.Close();
            con.Close();

            //...Return...
            return list;
        }
        public Product GetProduct(int ProductID)
        {
            //...Create New Instance of Object...
            Product ins = new Product();

            //...Database Connection...
            DataBaseConnection dbConn = new DataBaseConnection();
            SqlConnection con = dbConn.SqlConn();
            SqlCommand cmdI;

            //...SQL Commands...
            cmdI = new SqlCommand("SELECT * FROM t_Product WHERE ProductID =" + ProductID, con);
            cmdI.Connection.Open();
            SqlDataReader drI = cmdI.ExecuteReader();

            //...Retrieve Data...
            if (drI.HasRows)
            {
                while (drI.Read())
                {
                    ins.ProductID = Convert.ToInt32(drI["ProductID"]);
                    ins.Products = (drI["Product"]).ToString();
                    ins.ProductDescription = (drI["ProductDescription"]).ToString();
                    ins.Price = Convert.ToDecimal(drI["Price"]);
                    ins.Quantity = Convert.ToInt32(drI["Quantity"]);
                    ins.Total = Convert.ToDecimal(drI["Total"]);
                    ins.BTW = Convert.ToDecimal(drI["BTW"]);
                    ins.CreatedDate = Convert.ToDateTime(drI["CreatedDate"]);
                    ins.CompanyID = Convert.ToInt32(drI["CompanyID"]);
                    ins.ModifiedDate = Convert.ToDateTime(drI["ModifiedDate"]);
                    ins.ModifiedBy = Convert.ToString(drI["ModifiedBy"]);
                    ins.Removed = Convert.ToBoolean(drI["Removed"]);
                    ins.SupplierID = Convert.ToInt32(drI["SupplierID"]);
                }
            }

            //...Close Connections...
            drI.Close();
            con.Close();

            //...Return...
            return ins;
        }
        public Product Update(Product ins)
        {
            //...Get User and Date Data...
             string ModifiedDate = string.Format("{0:yyyy-MM-dd hh:mm:ss}", DateTime.Now);
             string EmployeeId = Convert.ToString(HttpContext.Current.Session["Username"]);

            //...Database Connection...
            DataBaseConnection dbConn = new DataBaseConnection();
            SqlConnection con = dbConn.SqlConn();
            con.Open();
            SqlCommand cmdI = con.CreateCommand();
            cmdI.Connection = con;

            //...Update Record...
            cmdI.Parameters.Clear();
            cmdI.CommandText = StoredProcedures.ProductUpdate;
            cmdI.CommandType = System.Data.CommandType.StoredProcedure;
            cmdI.Parameters.AddWithValue("@ProductID", ins.ProductID);
            cmdI.Parameters.AddWithValue("@Products", ins.Products);
            cmdI.Parameters.AddWithValue("@ProductDescription", ins.ProductDescription);
            cmdI.Parameters.AddWithValue("@Price", ins.Price);
            cmdI.Parameters.AddWithValue("@Quantity", ins.Quantity);
            cmdI.Parameters.AddWithValue("@Total", ins.Total);
            cmdI.Parameters.AddWithValue("@BTW", ins.BTW);
            cmdI.Parameters.AddWithValue("@CreatedDate", DateTime.Now);
            cmdI.Parameters.AddWithValue("@CompanyID", ins.CompanyID);
            cmdI.Parameters.AddWithValue("@ModifiedDate",ModifiedDate);
            cmdI.Parameters.AddWithValue("@ModifiedBy",EmployeeId);
            cmdI.Parameters.AddWithValue("@SupplierID", ins.SupplierID);

            cmdI.ExecuteNonQuery();
            cmdI.Connection.Close();

            return ins;
        }
        public Product Insert(Product ins)
        {
            //...Get User and Date Data...
             string ModifiedDate = string.Format("{0:yyyy-MM-dd hh:mm:ss}", DateTime.Now);
              string EmployeeId = Convert.ToString(HttpContext.Current.Session["Username"]);
             string strTrx = "ProductIns_" + EmployeeId;

            //...Database Connection...
            DataBaseConnection dbConn = new DataBaseConnection();
            SqlConnection con = dbConn.SqlConn();
            con.Open();

            //...Command Interface...
            SqlCommand cmdI = con.CreateCommand();
            SqlTransaction trx;
            trx = con.BeginTransaction(strTrx);
            cmdI.Connection = con;
            cmdI.Transaction = trx;

            try
            {
                //...Insert Record...
                cmdI.CommandText = StoredProcedures.ProductInsert;
                cmdI.CommandType = System.Data.CommandType.StoredProcedure;
                //cmdI.Parameters.AddWithValue("@ProductID", ins.ProductID);
                cmdI.Parameters.AddWithValue("@Products", ins.Products);
                cmdI.Parameters.AddWithValue("@ProductDescription", ins.ProductDescription);
                cmdI.Parameters.AddWithValue("@Price", ins.Price);
                cmdI.Parameters.AddWithValue("@Quantity", ins.Quantity);
                cmdI.Parameters.AddWithValue("@Total", ins.Total);
                cmdI.Parameters.AddWithValue("@BTW", ins.BTW);
                cmdI.Parameters.AddWithValue("@CreatedDate", DateTime.Now);
                cmdI.Parameters.AddWithValue("@CompanyID", ins.CompanyID);
                cmdI.Parameters.AddWithValue("@ModifiedDate",ModifiedDate);
               cmdI.Parameters.AddWithValue("@ModifiedBy",EmployeeId);
                cmdI.Parameters.AddWithValue("@Removed", ins.Removed);
                cmdI.Parameters.AddWithValue("@SupplierID", ins.SupplierID);

                //...Return new ID
                ins.ProductID = (int)cmdI.ExecuteScalar();

                trx.Commit();
                cmdI.Connection.Close();
            }
            catch (SqlException ex)
            {
                if (trx != null) trx.Rollback();
            }
            finally
            {
                //Check for close and respond accordingly
                if (con.State != ConnectionState.Closed)
                {
                    con.Close();
                }
                //Clean up
                con.Dispose();
                cmdI.Dispose();
                trx.Dispose();
            }
            return ins;
        }