2

here is my whole code fro the txtProductQuantity_TextChange:

protected void txtProductQuantity_TextChanged(object sender, EventArgs e)
    {
        TextBox txtQuantity = (sender as TextBox);

        //int tempForTryParse = 0;
        //if (!int.TryParse(txtQuantity.Text, out tempForTryParse))
        //{
        //    txtQuantity.Text = txtQuantity.Text.Substring(0, txtQuantity.Text.Length - 1);
        //}

        DataListItem currentItem = (sender as TextBox).NamingContainer as DataListItem; // getting current item on where user wants to add or remove
        HiddenField ProductID = currentItem.FindControl("hfProductID") as HiddenField;
        Label lblAvailableStock = currentItem.FindControl("lblAvailableStock") as Label;

        int tempInt = 0;
        if (txtQuantity.Text == string.Empty || txtQuantity.Text == "0" || txtQuantity.Text == "1" || double.Parse(txtQuantity.Text) < 0 || !int.TryParse(txtQuantity.Text, out tempInt))
        {
            txtQuantity.Text = "1"; //default value is 1, no action 
        }
        else
        {
            if (Session["MyCart"] != null) // not null means user has added a product in the shopping cart
            {
                if (Convert.ToInt32(txtQuantity.Text) <= Convert.ToInt32(lblAvailableStock.Text)) // check if quantity is greater than available stock
                {
                    DataTable dt = (DataTable)Session["MyCart"]; // if quantity is less than the available stock, go inside the code

                    DataRow[] rows = dt.Select("ProductID = '" + ProductID.Value + "'"); // select specific row depending on the product id

                    int index = dt.Rows.IndexOf(rows[0]);

                    dt.Rows[index]["ProductQuantity"] = txtQuantity.Text; // putting the value in the txtQuantityTextbox. changing the product quantity in the data table

                    Session["MyCart"] = dt; // add updated value to datatable
                }
                else // error if quntity is greater than available stock
                {
                    lblAvailableStockAlert.Text = " Alert: product buyout should not be more than the available stock!";
                    txtQuantity.Text = "1"; // automatically change the quantity back to 1.
                }

            }
        }
        UpdateTotalBill();
    }

what i want to happen is to avoid letters being an input from the user. or something like it will be defaulted to "1" if they do.

Paolo Duhaylungsod
  • 487
  • 1
  • 7
  • 25

2 Answers2

3

Use an if statement to check

if(txtQuantity.Text.StartsWith("-")
{
    //Code if negative
}

You could also parse the string as a number and then check if it is negative

if(int.Parse(txtQuantity.Text) < 0)
{
    //Code if negative
}

So in the context of your code you could use it like this

if (txtQuantity.Text == string.Empty || txtQuantity.Text == "0" || txtQuantity.Text == "1" || txtQuantity.Text.StartsWith("-"))
   {
        txtQuantity.Text = "1"; //default value is 1, no action 
   }

or

if (txtQuantity.Text == string.Empty || txtQuantity.Text == "0" || txtQuantity.Text == "1" || int.Parse(txtQuantity.Text) < 0)
   {
        txtQuantity.Text = "1"; //default value is 1, no action 
   }

To avoid text being entered into the field, on the Text Changed event for the textBox you should add another criteria into this if statement, as well as an integer variable to act as an out

int tempInt = 0;
bool parsed = int.TryParse(txtQuantity.Text, out tempInt);
if (txtQuantity.Text == string.Empty || txtQuantity.Text == "0" || txtQuantity.Text == "1" || tempInt < 0 || !parsed)
   {
        txtQuantity.Text = "1"; //default value is 1, no action 
   }
Alfie Goodacre
  • 2,753
  • 1
  • 13
  • 26
1

managed to solve it.i added

int.Parse(txtQuantity.Text)<1)

to the first line of my code.

Paolo Duhaylungsod
  • 487
  • 1
  • 7
  • 25