protected void Page_Load(object sender, EventArgs e) { // Init labels lblShippingCostValue.Text = GetString("com.shippingcost.costlabel"); lblShippingCostMinWeight.Text = GetString("com.shippingcost.minweightlabel"); rfvMinWeight.ErrorMessage = GetString("com.shippingcost.minweightempty"); rvMinWeight.ErrorMessage = GetString("com.shippingcost.minweightrange"); txtShippingCostCharge.EmptyErrorMessage = GetString("com.shippingcost.costempty"); txtShippingCostCharge.ValidationErrorMessage = GetString("com.shippingcost.costrange"); // Get parameters from querystring mShippingCostId = QueryHelper.GetInteger("shippingCostId", 0); mShippingOptionId = QueryHelper.GetInteger("shippingCostShippingOptionId", 0); // Check if configured shipping option record belongs to correct site mShippingOptionInfoObj = ShippingOptionInfoProvider.GetShippingOptionInfo(mShippingOptionId); if (mShippingOptionInfoObj != null) { CheckEditedObjectSiteID(mShippingOptionInfoObj.ShippingOptionSiteID); txtShippingCostCharge.CurrencySiteID = mShippingOptionInfoObj.ShippingOptionSiteID; // Check presence of main currency string currencyWarning = CheckMainCurrency(mShippingOptionInfoObj.ShippingOptionSiteID); if (!string.IsNullOrEmpty(currencyWarning)) { ShowWarning(currencyWarning, null, null); } } string[,] breadcrumbs = new string[2, 4]; breadcrumbs[0, 0] = GetString("com.ui.shippingcost"); breadcrumbs[0, 1] = ResolveUrl("ShippingOption_Edit_ShippingCosts.aspx?shippingoptionid=" + mShippingOptionId + "&siteId=" + SiteID); // If true, then we will edit existing record if (mShippingCostId > 0) { // Check if there is already ShippingCostInfo with this shippingCostID ShippingCostInfo shippingCostInfo = ShippingCostInfoProvider.GetShippingCostInfo(mShippingCostId); // Check if shipping cost belongs to edited shipping option if ((shippingCostInfo != null) && (shippingCostInfo.ShippingCostShippingOptionID != mShippingOptionId)) { shippingCostInfo = null; } EditedObject = shippingCostInfo; if (shippingCostInfo != null) { // Fill editing form with existing data when not postback if (!RequestHelper.IsPostBack()) { LoadData(shippingCostInfo); // Show that the shippingCost was created or updated successfully if (QueryHelper.GetString("saved", "") == "1") { // Show message ShowChangesSaved(); } } } // Set title to "shipping cost properties" breadcrumbs[1, 0] = GetString("com.ui.shippingcost.edit"); breadcrumbs[1, 1] = ""; } // Do this when creating new cost else { // Set header to "new item" breadcrumbs[1, 0] = GetString("com.ui.shippingcost.edit_new"); } CurrentMaster.Title.Breadcrumbs = breadcrumbs; }
/// <summary> /// Sets data to database. /// </summary> protected void btnOK_Click(object sender, EventArgs e) { // No option to save under if (mShippingOptionInfoObj == null) { return; } // Check permissions CheckConfigurationModification(mShippingOptionInfoObj.ShippingOptionSiteID); // True if there is already same min count; bool isMinCountUnique = false; // Server side validation of user input string errorMessage = new Validator().NotEmpty(txtShippingCostMinWeight.Text.Trim(), "com.shippingcost.minweightempty").Result; if (errorMessage == "") { errorMessage = txtShippingCostCharge.Validate(false); } double minWeight = ValidationHelper.GetDouble(txtShippingCostMinWeight.Text.Trim(), 0); if ((errorMessage == "") && (minWeight <= 0)) { errorMessage = GetString("com.shippingcost.minweightrange"); } if (errorMessage == "") { ShippingCostInfo shippingCostObj = ShippingCostInfoProvider.GetShippingCostInfo(mShippingCostId); // If ShippingCost doesn't already exist, create new one if (shippingCostObj == null) { // Create new shipping cost shippingCostObj = new ShippingCostInfo(); shippingCostObj.ShippingCostShippingOptionID = mShippingOptionId; } // Look for record with same minimum weight DataSet ds = ShippingCostInfoProvider.GetShippingCosts("ShippingCostMinWeight = " + minWeight + " AND ShippingCostShippingOptionID = " + mShippingOptionId, null, 1, "ShippingCostID"); if (DataHelper.DataSourceIsEmpty(ds)) { isMinCountUnique = true; } // Check if min weight is unique or it is update of existing item if ((isMinCountUnique) || (ValidationHelper.GetInteger(ds.Tables[0].Rows[0]["ShippingCostID"], -1) == shippingCostObj.ShippingCostID)) { // Set ShippingCostObj values shippingCostObj.ShippingCostValue = txtShippingCostCharge.Price; shippingCostObj.ShippingCostMinWeight = minWeight; // Set data to database ShippingCostInfoProvider.SetShippingCostInfo(shippingCostObj); string redirectUrl = "ShippingOption_Edit_ShippingCosts_Edit.aspx?shippingCostId=" + Convert.ToString(shippingCostObj.ShippingCostID) + "&saved=1&shippingCostShippingOptionId=" + mShippingOptionId + "&siteId=" + SiteID; URLHelper.Redirect(redirectUrl); } else { // Show error message ShowError(GetString("com.ui.shippingcost.edit_costexists")); } } else { // Show error message ShowError(errorMessage); } }