關於DEV Express 一些控件的使用。 (異步刷新, AJAX的使用)

Dev Express 控件對於異步刷新和異步調用有很好的封裝。具體的詳細分析見下次文檔。這篇文檔主要是代碼的使用:有前段和後端。後端

JS代碼部分:異步

var step = 1;
var CCTypeEnum = {
    Visa: 0,
    MasterCard: 1,
    Discover_Novus: 2,
    Amex: 3
}
var _ccTypeEnum;
var _planId;

function openPurchaseWizard(Id) {
    step = 1;
    _planId = Id;
    ClearAllFields();
    initPlanInfo.PerformCallback(JSON.stringify({
        planId: Id.toString()
    }));
    SetStepVisibility();
}

function ClearAllFields() {
    _ccTypeEnum = null;
    var result = document.getElementById("cbAgree");
    result.checked = false;
    txtCardNumber.SetText("");
    cmbExpMonth.SetText("");
    cmbExpYear.SetText("");   
}
function initPlanInfoCallBack_CallbackComplete(s, e) {
    purchasePlanWizardLightbox.Show();
}

function PurchasePlanWizardTopCloseButton_Click(s, e) {
    document.getElementById('PurchasePlanClose_Contents').innerHTML = messageLanguagePurchasePlanWizard.Get("PurchasePlanWizardJS_CloseWizard");
    purchasePlanCloseMsg.Show();
    document.body.style.overflow = "auto";
    document.documentElement.style.overflow = 'auto';
}
function PurchasePlanPrintButton_Click(s, e) {
    document.getElementById('PurchasePlanPrintIframe').focus();
    document.getElementById('PurchasePlanPrintIframe').contentWindow.focus();
    document.getElementById('PurchasePlanPrintIframe').contentWindow.print();
}

function PurchasePlanNextButton_Click(s, e) {
    if (step == 1) {
        var result = document.getElementById("cbAgree");
        if (!result.checked) {
            document.getElementById('PurchasePlanAlert_Contents').innerHTML = messageLanguagePurchasePlanWizard.Get("PurchasePlanWizardJS_CheckAgreeAlert");
            purchasePlanSlideOutMsg.Show();
            return;        }
    }
    if (step == 2) {
        if (hasBlankField() || (!ValidateField())) {
            document.getElementById('PurchasePlanAlert_Contents').innerHTML = messageLanguagePurchasePlanWizard.Get("PurchasePlanWizardJS_IsRequiredFields");
            purchasePlanSlideOutMsg.Show();         
            return;            
                }  
        var cardNumber = txtCardNumber.GetText();

        for (var i = 0; i < cardNumber.length - 4; i++) {
            cardNumber=cardNumber.replace(cardNumber[i].toString(), '');
        }
    document.getElementById("txtConfirmCardNumber").innerHTML = cardNumber;
        document.getElementById("txtConfirmExpDate").innerHTML = cmbExpMonth.GetValue() + "/" + cmbExpYear.GetValue(); ;
        document.getElementById("txtConfirmBillingZip").innerHTML = txtPostalCode.GetText();
       
    }
    step++;
    SetStepVisibility();
}

function SetStepVisibility() {
    switch (step) {
        case 1:
            document.getElementById("PurchasePlanTitle").innerHTML = messageLanguagePurchasePlanWizard.Get("PurchasePlan_ReviewTermsConditions");
            break;
        case 2:
            document.getElementById("PurchasePlanTitle").innerHTML = messageLanguagePurchasePlanWizard.Get("PurchasePlan_TitleEnterBillingInformation");
            break;
        case 3:
            document.getElementById("PurchasePlanTitle").innerHTML = messageLanguagePurchasePlanWizard.Get("PurchasePlan_TitleReviewAndConfirmPurchase");
            break;
    }    
    document.getElementById("ReviewTermsDiv").style.visibility = step == 1 ? "visible" : "hidden";
    document.getElementById("ReviewTermsDiv").style.display = step == 1 ? "" : "none";
    document.getElementById("ReviewTermsDivFooter").style.visibility = step == 1 ? "visible" : "hidden";
    document.getElementById("ReviewTermsDivFooter").style.display = step == 1 ? "" : "none";
    document.getElementById("EnterBillingInfoDiv").style.visibility = step == 2 ? "visible" : "hidden";
    document.getElementById("EnterBillingInfoDiv").style.display = step == 2 ? "" : "none";
    document.getElementById("ConfirmPurchaseDiv").style.visibility = step == 3 ? "visible" : "hidden";
    document.getElementById("ConfirmPurchaseDiv").style.display = step == 3 ? "" : "none";
    PurchasePlanWizardPreviousButton.SetVisible(step > 1 && step < 4);
    document.getElementById("ReviewTermsStepDiv").className = document.getElementById("ReviewTermsStepDiv").className.
        replace("purchase-plan-step-div" + (step == 1 ? "" : "-current"), "purchase-plan-step-div" + (step == 1 ? "-current" : ""));
    document.getElementById("EnterBillingInfoStepDiv").className = document.getElementById("EnterBillingInfoStepDiv").className.
        replace("purchase-plan-step-div" + (step == 2 ? "" : "-current"), "purchase-plan-step-div" + (step == 2 ? "-current" : ""));
    document.getElementById("ConfirmPurchaseStepDiv").className = document.getElementById("ConfirmPurchaseStepDiv").className.
        replace("purchase-plan-step-div" + (step == 3 ? "" : "-current"), "purchase-plan-step-div" + (step == 3 ? "-current" : ""));
    document.getElementById("ReviewTermsIconDiv").className = step == 1 ? "purchase-plan-step-icon" : "purchase-plan-step-icon-inactive";
    document.getElementById("EnterBillingInfoIconDiv").className = step == 2 ? "purchase-plan-step-icon" : "purchase-plan-step-icon-inactive";
    document.getElementById("ConfirmPurchaseIconDiv").className = step == 3 ? "purchase-plan-step-icon" : "purchase-plan-step-icon-inactive";
    PurchasePlanWizardNextButton.SetVisible(step < 3);
    PurchasePlanWizardConfirmButton.SetVisible(step == 3);
}
function PurchasePlanPreviousButton_Click(s, e) {
    step--;
    SetStepVisibility();
}

function CCTypeButton_Click(CCType) {
    switch (CCType) {
        case CCTypeEnum.Visa:
            document.getElementById("CCType_Visa").className = "purchase-plan-card-visa-select";
            document.getElementById("CCType_Mastercard").className = "purchase-plan-card-mastercard-unselect";
            document.getElementById("CCType_Discover").className = "purchase-plan-card-discover-unselect";
            document.getElementById("CCType_Amex").className = "purchase-plan-card-amex-unselect";
            _ccTypeEnum = CCTypeEnum.Visa;
            break;
        case CCTypeEnum.MasterCard:
            document.getElementById("CCType_Mastercard").className = "purchase-plan-card-mastercard-select";
            document.getElementById("CCType_Visa").className = "purchase-plan-card-visa-unselect";         
            document.getElementById("CCType_Discover").className = "purchase-plan-card-discover-unselect";
            document.getElementById("CCType_Amex").className = "purchase-plan-card-amex-unselect";
            _ccTypeEnum = CCTypeEnum.MasterCard;
            break;
        case CCTypeEnum.Discover_Novus:
            document.getElementById("CCType_Discover").className = "purchase-plan-card-discover-select";
            document.getElementById("CCType_Visa").className = "purchase-plan-card-visa-unselect";
            document.getElementById("CCType_Mastercard").className = "purchase-plan-card-mastercard-unselect"
            document.getElementById("CCType_Amex").className = "purchase-plan-card-amex-unselect";
            _ccTypeEnum = CCTypeEnum.Discover_Novus;
            break;
        case CCTypeEnum.Amex:
            document.getElementById("CCType_Amex").className = "purchase-plan-card-amex-select";
            document.getElementById("CCType_Visa").className = "purchase-plan-card-visa-unselect";
            document.getElementById("CCType_Mastercard").className = "purchase-plan-card-mastercard-unselect";
            document.getElementById("CCType_Discover").className = "purchase-plan-card-discover-unselect";
            _ccTypeEnum = CCTypeEnum.Amex;
            break;

    }
}
function OnCountryChanged(s) {
    cmbStateProvince.PerformCallback(s.GetValue());
}

function cmbStateProvince_EndCallBack(s, e) {
    cmbStateProvince.SetText("");
}

function hasBlankField() {
    var hasBlank = false;
    ImageAddress_ConInvalidCharacter.SetVisible(false);
    ImageCity_ConInvalidCharacter.SetVisible(false);
    ImageStateProvince_ConInvalidCharacter.SetVisible(false);
    ImageCountry_ConInvalidCharacter.SetVisible(false);
    ImagePostalCode_ConInvalidCharacter.SetVisible(false);
    ImageCardNummber_ConInvalidCharacter.SetVisible(false);
    ImageExpDate_Error.SetVisible(false);
    ImageCardType_Error.SetVisible(false);

    if (_ccTypeEnum == null) {
        ImageCardType_Error.SetVisible(true);
        hasBlank = true;
    }
    if (IsBlank(txtCardNumber, ImageCardNummber_Error)) {
        hasBlank = true;
    }

    if (ValidateExpDateBlank()) {
        hasBlank = true;
    }

    if (IsBlank(txtAddress, ImageAddress_ConError)) {
        hasBlank = true;
    }
    if (IsBlank(txtCity, ImageCity_ConError)) {
        hasBlank = true;
    }
    if (IsBlank(cmbStateProvince, ImageStateProvince_ConError)) {
        hasBlank = true;
    }

    if (IsBlank(cmbCountry, ImageCountry_ConError)) {
        hasBlank = true;
    }

    if (IsBlank(txtPostalCode, ImagePostalCode_ConError)) {
        hasBlank = true;
    }
    
    return hasBlank;
}

function IsBlank(instanceName, instanceErrorName) {
    if (Dyna.len(instanceName.GetText().Trim()) < 1) {
        instanceErrorName.SetVisible(true);
        return true;
    } else {
        instanceErrorName.SetVisible(false);
        return false;
    }
}

function ValidateField() {
    var valid = true;
    switch (_ccTypeEnum) {
        case CCTypeEnum.Visa:
            if (!validateVisaCard(txtCardNumber.GetText())) {
                ImageCardNummber_ConInvalidCharacter.SetVisible(true);
                valid = false;
            }
            break;
        case CCTypeEnum.MasterCard:
            if (!validateMasterCardCard(txtCardNumber.GetText())) {
                ImageCardNummber_ConInvalidCharacter.SetVisible(true);
                valid = false;
            }
            break;
        case CCTypeEnum.Discover_Novus:
            if (!validateDiscover_NovusCard(txtCardNumber.GetText())) {
                ImageCardNummber_ConInvalidCharacter.SetVisible(true);
                valid = false;
            }
            break;
        case CCTypeEnum.Amex:
            if (!validateAmexCard(txtCardNumber.GetText())) {
                ImageCardNummber_ConInvalidCharacter.SetVisible(true);
                valid = false;
            }
            break;
    }
    if (!ValidateExpDateField()) {
        valid = false;
        ImageExpDate_Error.SetVisible(true);
     }
    
    if (!validateAddress1(txtAddress.GetText())) {
        ImageAddress_ConInvalidCharacter.SetVisible(true);
        valid = false;
    }
    if (!validateCity(txtCity.GetText())) {
        ImageCity_ConInvalidCharacter.SetVisible(true);
        valid = false;
    }
    if (!validateZip(txtPostalCode.GetText())) {
        ImagePostalCode_ConInvalidCharacter.SetVisible(true);
        valid = false;
    }
    return valid;
}
function ValidateExpDateBlank() {
    if ((Dyna.len(cmbExpMonth.GetText().Trim()) < 1) || (Dyna.len(cmbExpYear.GetText().Trim()) < 1)) {
        ImageExpDate_ConError.SetVisible(true);
        return true;
    } else {
        ImageExpDate_ConError.SetVisible(false);
        return false;
    }
}
function ValidateExpDateField() {
    var valid = true;
    var month = cmbExpMonth.GetValue();
    var year = cmbExpYear.GetValue();
    var date = new Date()
    var nowYear = date.getFullYear();
    var nowMonth = date.getMonth()+1;
    if ((nowYear == year) && (month <= nowMonth)) {
            valid = false;
    }
    return valid;

}
function PurchasePlanConfirmButton_Click(s, e) {

    if ((IsBlank(txtEmailTo, ImageSentEmail_ConError))) {
        document.getElementById('PurchasePlanAlert_Contents').innerHTML = messageLanguagePurchasePlanWizard.Get("PurchasePlan_EmailAddressIsARequiredField");
        purchasePlanSlideOutMsg.Show();
        return;
    }
    if (!validateEmailAddress(txtEmailTo.GetText())) {
        ImageSentEmail_ConInvalidCharacter.SetVisible(true);
        document.getElementById('PurchasePlanAlert_Contents').innerHTML = messageLanguagePurchasePlanWizard.Get("PurchasePlan_EmailAddressContainsInvalidCharacters");
        purchasePlanSlideOutMsg.Show();
        return;
    }
    SavePurchasePlanCallBack.PerformCallback(JSON.stringify({
        planId: _planId.toString()
    }));
}
function savePurchasePlan_CallbackComplete(s, e) {
    if (SavePurchasePlanCallBack.cpError) {
        ShowSimpleAlert(messageLanguagePurchasePlanWizard.Get("PurchasePlanWizardJS_Error"),
        messageLanguagePurchasePlanWizard.Get("PurchasePlanWizardJS_AnErrorOccurred"));
        return;
    }
    if (SavePurchasePlanCallBack.cpFlag) {
        //Call Salesforce to convert lead
        Dyna.Net.callMethod({
            ok: convertLeadSuccess,
            fail: convertLeadFail,
            type: 'Domain.Services.PartnerService',
            method: 'PartnerSalesForceConvertLead',
            args: [
                { name: 'username', value: SavePurchasePlanCallBack.cpUsername }
                ]
        });
        window.location.href = "../home/Home.aspx";
    }
    else {

        ShowSimpleAlert(messageLanguagePurchasePlanWizard.Get("PurchasePlanWizardJS_Error"),
        messageLanguagePurchasePlanWizard.Get("PurchasePlanWizardJS_AnErrorOccurred"));
    }

}

function convertLeadSuccess() {
    //return true;
}
function convertLeadFail() {
    //return false;
}

 

主要的HTML代碼部分:ide

<%@ Control Language="C#" AutoEventWireup="true" CodeBehind="PurchasePlanWizardForm.ascx.cs" Inherits="WebPortalApplication.App_Components.Forms.PurchasePlanWizardForm" %>
<%@ Register TagPrefix="intronis" TagName="PurchasePlanWizardCloseLightbox" Src="~/App_Components/LightBox/PurchasePlanWizardCloseLightbox.ascx" %>
<%@ Register TagPrefix="intronis" TagName="PurchasePlanSlideOutLightbox" Src="~/App_Components/LightBox/PurchasePlanSlideOutLightbox.ascx" %>
<%@ Register TagPrefix="intronis" TagName="ImageButton" Src="~/App_Components/Buttons/ImageButton.ascx" %>

    <div id="purchasePlanWizardDiv"></div>
    <div class="purchase-plan-div">
        <div class="purchase-plan-title" id="PurchasePlanTitle" clientidmode="Static">
        </div>
        <div class="lbHeaderClosePanel purchase-plan-close" 
            onclick="PurchasePlanWizardTopCloseButton_Click()" title=""></div>
        
        <div class="purchase-plan-step-left">
            <div id="ConfirmPurchaseStepDiv" class="purchase-plan-step-float purchase-plan-step-div" style="margin-right:-23px;">
                <div id="ConfirmPurchaseIconDiv" class="purchase-plan-step-icon-inactive">
                </div>
                <div class="purchase-plan-step-text confirm-purchase-title-div"><asp:Localize ID="Localize4" Text="<%$resources:Language,PurchasePlan_ConfirmPurchase%>" runat="server"/></div>
            </div>
            <div id="EnterBillingInfoStepDiv" class="purchase-plan-step-float purchase-plan-step-div" style="margin-right:-27px;">
                <div id="EnterBillingInfoIconDiv" class="purchase-plan-step-icon-inactive">
                </div>
                <div class="purchase-plan-step-text enter-billingInfo-title-div"><asp:Localize ID="Localize3" Text="<%$resources:Language,PurchasePlan_EnterBillingInfo%>" runat="server"/></div>
            </div>
            <div id="ReviewTermsStepDiv" class="purchase-plan-step-float purchase-plan-step-div-current" style="margin-right:-16px;">
                <div id="ReviewTermsIconDiv" class="purchase-plan-step-icon">
                </div>
                <div class="purchase-plan-step-text reviewterms-title-div"><asp:Localize ID="Localize2" Text="<%$resources:Language,PurchasePlan_ReviewTerms%>" runat="server"/> </div>
            </div>
        </div>
        <br />
        <div class="purchase-plan-line"></div> 
        <dxcp:ASPxCallbackPanel ID="InitPlanInfo" runat="server" SkinID="NoLoading"
                HideContentOnCallback="False"
                ClientInstanceName="initPlanInfo"
                OnCallback="InitPlanInfoCallBack_Callback">
            <ClientSideEvents EndCallback="initPlanInfoCallBack_CallbackComplete" />  
                <PanelCollection>
                    <dxp:PanelContent>
                    <dxhf:ASPxHiddenField ID="OriginalBillingAddressHiddenField" runat="server" ClientInstanceName="OriginalBillingAddressHiddenField" />     
        <div id="ReviewTermsDiv" class="purchase-plan-reviewterms" runat="server" clientidmode="Static">  
            <div id="ReviewTermsContentDiv" >
                <div class="plan-summary">
                    <asp:Localize ID="PlanSummary" runat="server"/>
                </div>
                <div style=" margin-top:10px;">
                    <span class="plan-summary"><asp:Localize ID="Localize1" Text="<%$resources:Language,PurchasePlan_OnlineBackupPlan%>" runat="server"/></span>
                    <span class="plan-detail"> <asp:Localize  ID="OnlineBackupPlan" runat="server" /></span>
                </div>
                <div>
                    <span class="plan-summary"><asp:Localize ID="Localize6" Text="<%$resources:Language,PurchasePlan_EffectiveDate%>" runat="server"/></span>
                    <span class="plan-detail"><asp:Localize ID="EffectiveDate" runat="server"/></span>
                </div>
                <div>
                    <span class="plan-summary"><asp:Localize ID="Localize8" Text="<%$resources:Language,PurchasePlan_PaymentSchedule%>" runat="server"/></span>
                    <span class="plan-detail"><asp:Localize ID="PaymentSchedule" runat="server"/></span>
                </div>              
            </div>
            <div style="margin-top:35px;">          
                <iframe id="PurchasePlanPrintIframe" class="purchase-plan-doc" src="../../docs/localization/en-us/ZeroTouchPlanPurchaseTsCs.htm"></iframe>
            </div>
        </div>
        <div id="EnterBillingInfoDiv" runat="server" clientidmode="Static" class="purchase-plan-reviewterms" style="visibility: hidden;display:none;margin-top:22px;">
        
            <div id="EnterBillingInfoContentDiv">
                <div class="purchase-plan-step-enter-text">
                    <asp:Localize ID="Localize5" Text="<%$resources:Language,PurchasePlan_EnterBillingInfo_Content%>" runat="server"/>
                </div>
                <div class="purchase-plan-cridit-card-details">
                    <div class="purchase-plan-card-text">
                        <asp:Localize ID="Localize7" Text="<%$resources:Language,PurchasePlan_CreditCardDetails%>" runat="server"/>
                    </div>
                    <div class="purchase-plan-card-type-text">
                        <asp:Localize ID="Localize9" Text="<%$resources:Language,PurchasePlan_CardType%>" runat="server"/><span class="required-indicator-red">*</span>
                    </div>
                    <div style="height:30px;">
                        <div id="CCType_Visa" class="purchase-plan-card-visa-unselect" onclick="CCTypeButton_Click(<% =(int)Infrastructure.Maestro.PortalTypes.CCTypeEnum.Visa%>)"></div>
                        <div id="CCType_Mastercard" class="purchase-plan-card-mastercard-unselect" onclick="CCTypeButton_Click(<% =(int)Infrastructure.Maestro.PortalTypes.CCTypeEnum.MasterCard%>)"></div>
                        <div  id="CCType_Discover"class="purchase-plan-card-discover-unselect" onclick="CCTypeButton_Click(<% =(int)Infrastructure.Maestro.PortalTypes.CCTypeEnum.Discover_Novus%>)"></div>
                        <div id="CCType_Amex" class="purchase-plan-card-amex-unselect" onclick="CCTypeButton_Click(<% =(int)Infrastructure.Maestro.PortalTypes.CCTypeEnum.Amex%>)"></div>
                        <div class="purchase-plan-card-type-error"><dxe:ASPxImage ID="ImageCardType_Error" runat="server" SkinID="purchasePlanErrorIcon" ClientInstanceName="ImageCardType_Error"
                                ToolTip="<%$ Resources:Language,PurchaseCardTypeIsARequiredField %>" ClientVisible="false" />                        
                        </div>
                    </div>               
                    <div class="purchase-plan-card-number-text">
                        <asp:Localize ID="Localize12" Text="<%$resources:Language,PurchasePlan_CardNumber%>" runat="server"/><span class="required-indicator-red">*</span>                    
                        <div class="purchase-plan-card-number-edit">
                            <div style=" float:left"><dxe:ASPxTextBox runat="server" ID="CardInput" ClientInstanceName="txtCardNumber" 
                                 CssClass="purchase-plan-card-number-field" />
                            </div>
                            <div class="purchase-plan-error-image">
                            <dxe:ASPxImage ID="ImageCardNummber_ConInvalidCharacter" runat="server" SkinID="purchasePlanErrorIcon" ClientInstanceName="ImageCardNummber_ConInvalidCharacter"
                                ToolTip="<%$ Resources:Language,PurchasePlan_ValidCardErrorMessage %>" ClientVisible="false" />
                            <dxe:ASPxImage ID="ImageCardNummber_Error" runat="server" SkinID="purchasePlanErrorIcon" ClientInstanceName="ImageCardNummber_Error"
                                ToolTip="<%$ Resources:Language,PurchaseCardNumberIsARequiredField %>" ClientVisible="false" />                        
                            </div>
                        </div>
                    </div>
                    <div class="purchase-plan-exp-text">
                        <asp:Localize ID="Localize11" Text="<%$resources:Language,PurchasePlan_ExpirationDate%>" runat="server"/><span class="required-indicator-red">*</span>                    
                        <div>
                          <div style=" float:left"><dxe:ASPxComboBox ID="cmbExpMonth" ClientInstanceName="cmbExpMonth" CssClass="purchase-plan-input-expdate" ItemStyle-CssClass="combobox-item" 
                             ItemStyle-SelectedStyle-CssClass="combo-selected-item" ItemStyle-HoverStyle-CssClass="combo-hover-item"
                             runat="server" DataSourceID="dataExpMonth" TextField="Text" ValueField="Value" /></div>
                          <div class="purchase-plan-forward-slash-divider" style=" float:left">/</div>
                          <div style=" float:left"><dxe:ASPxComboBox ID="cmbExpYear" ClientInstanceName="cmbExpYear" CssClass="purchase-plan-input-expdate" ItemStyle-CssClass="combobox-item" 
                                ItemStyle-SelectedStyle-CssClass="combo-selected-item" ItemStyle-HoverStyle-CssClass="combo-hover-item"
                             runat="server" DataSourceID="dataExpYear" /></div>                       
                        </div>
                        <div class="purchase-plan-error-image">
                        <dxe:ASPxImage ID="ImageExpDate_Error" runat="server" SkinID="purchasePlanErrorIcon" ClientInstanceName="ImageExpDate_Error"
                                        ToolTip="<%$ Resources:Language,PurchasePlan_ExpDateErrorMessage %>" ClientVisible="false" />
                        <dxe:ASPxImage ID="ImageExpDate_ConError" runat="server" SkinID="purchasePlanErrorIcon" ClientInstanceName="ImageExpDate_ConError"
                                        ToolTip="<%$ Resources:Language,PurchaseExpDateIsARequiredField %>" ClientVisible="false" />
                        </div>                   
                        </div>
                    </div>       
                <div class="purchase-plan-billing-details" style=" margin-left:50px">
                    <div class="purchase-plan-billing-text">
                        <asp:Localize ID="Localize13" Text="<%$resources:Language,PurchasePlan_BillingAddress%>" runat="server"/>
                    </div>
                    <div class="purchase-plan-billing-detail-text" style="margin-top:20px;">                   
                        <asp:Localize ID="Localize14" Text="<%$resources:Language,PurchasePlan_Address%>" runat="server"/><span class="required-indicator-red">*</span>
                         <div class="purchase-plan-card-number-edit">   
                            <dxe:ASPxTextBox runat="server" ID="AddressInput" ClientInstanceName="txtAddress" 
                                CssClass="purchase-plan-address-field" />
                        </div> 
                         <div class="purchase-plan-billing-error-image" style=" margin-top:0px;"> 
                            <dxe:ASPxImage ID="ImageAddress_ConInvalidCharacter" runat="server" SkinID="purchasePlanErrorIcon"
                                ToolTip="<%$ Resources:Language,BillingAddressContainsInvalidCharacters %>" ClientInstanceName="ImageAddress_ConInvalidCharacter"
                                ClientVisible="false" />
                            <dxe:ASPxImage ID="ImageAddress_ConError" runat="server" SkinID="purchasePlanErrorIcon"
                                ClientInstanceName="ImageAddress_ConError" ToolTip="<%$ Resources:Language,BillingAddressIsARequiredField %>"
                                ClientVisible="false" />
                        </div>                   
                    </div>
                    <div  style="margin-top:30px;">
                        <div class="purchase-plan-billing-address">
                            <asp:Localize ID="Localize15" Text="<%$resources:Language,PurchasePlan_City%>" runat="server"/><span class="required-indicator-red">*</span>
                            <div class="purchase-plan-card-number-edit">   
                                <dxe:ASPxTextBox runat="server" ID="CityInput" ClientInstanceName="txtCity" 
                                    CssClass="purchase-plan-city-field" />
                            </div>
                        </div>
                        <div class="purchase-plan-billing-error-image">                       
                            <dxe:ASPxImage ID="ImageCity_ConInvalidCharacter" runat="server" SkinID="purchasePlanErrorIcon"
                                        ToolTip="<%$ Resources:Language,BillingCityContainsInvalidCharacters %>" ClientInstanceName="ImageCity_ConInvalidCharacter"
                                        ClientVisible="false" />
                            <dxe:ASPxImage ID="ImageCity_ConError" runat="server" SkinID="purchasePlanErrorIcon"
                                ClientInstanceName="ImageCity_ConError" ToolTip="<%$ Resources:Language,BillingCityIsARequiredField %>"
                                ClientVisible="false" />
                        </div>
                        <div class="purchase-plan-billing-address">
                            <asp:Localize ID="Localize16" Text="<%$resources:Language,PurchasePlan_State%>" runat="server"/><span class="required-indicator-red">*</span>
                            <div class="purchase-plan-card-number-edit">   
                                <dxe:ASPxComboBox ID="cmbState" ClientInstanceName="cmbStateProvince" CssClass="purchase-plan-state-field" ItemStyle-CssClass="combobox-item" 
                                    ItemStyle-SelectedStyle-CssClass="combo-selected-item" ItemStyle-HoverStyle-CssClass="combo-hover-item"
                                    runat="server" ValueField = "Code" TextField = "Name" OnCallback="cmbState_Callback"> 
                                    <ClientSideEvents  EndCallback="cmbStateProvince_EndCallBack"/>
                                </dxe:ASPxComboBox>
                            </div>
                        </div>
                        <div class="purchase-plan-billing-error-image"> 
                            <dxe:ASPxImage ID="ImageStateProvince_ConInvalidCharacter" runat="server" SkinID="purchasePlanErrorIcon"
                                        ToolTip="<%$ Resources:Language,StateProvinceContainsInvalidCharacters %>" ClientInstanceName="ImageStateProvince_ConInvalidCharacter"
                                        ClientVisible="false" />
                            <dxe:ASPxImage ID="ImageStateProvince_ConError" runat="server" SkinID="purchasePlanErrorIcon"
                                ClientInstanceName="ImageStateProvince_ConError" ToolTip="<%$ Resources:Language,StateFieldIsRequiredField %>"
                                ClientVisible="false" />
                        </div>
                    </div>
                    <div style="margin-top:80px;">
                        <div class="purchase-plan-billing-address" >
                            <asp:Localize ID="Localize17" Text="<%$resources:Language,PurchasePlan_Country%>" runat="server"/><span class="required-indicator-red">*</span>
                            <div class="purchase-plan-card-number-edit">
                            <dxe:ASPxComboBox ID="cmbCountry" ClientInstanceName="cmbCountry" CssClass="purchase-plan-state-field" ItemStyle-CssClass="combobox-item" 
                                ItemStyle-SelectedStyle-CssClass="combo-selected-item" ItemStyle-HoverStyle-CssClass="combo-hover-item"
                                runat="server" DataSourceID="dataCountry" TextField="Name" ValueField="Code">  
                             <ClientSideEvents  SelectedIndexChanged="function(s, e) { OnCountryChanged(s); }" />
                            </dxe:ASPxComboBox>
                            </div>
                        </div>
                        <div class="purchase-plan-billing-error-image"> 
                             <dxe:ASPxImage ID="ImageCountry_ConInvalidCharacter" runat="server" SkinID="purchasePlanErrorIcon"
                                 ToolTip="<%$ Resources:Language,CountryFieldContainsInvalidCharacters %>" ClientInstanceName="ImageCountry_ConInvalidCharacter"
                                 ClientVisible="false" />
                            <dxe:ASPxImage ID="ImageCountry_ConError" runat="server" SkinID="purchasePlanErrorIcon"
                                ClientInstanceName="ImageCountry_ConError" ToolTip="<%$ Resources:Language,CountryFieldIsRequiredField %>"
                                ClientVisible="false" />
                        </div>
                        <div class="purchase-plan-billing-address">
                            <asp:Localize ID="Localize18" Text="<%$resources:Language,PurchasePlan_PostalCode%>" runat="server"/><span class="required-indicator-red">*</span>
                            <div class="purchase-plan-card-number-edit">   
                                    <dxe:ASPxTextBox runat="server" ID="PostalCodeInput" ClientInstanceName="txtPostalCode" 
                                        CssClass="purchase-plan-state-field" />
                            </div>
                        </div>
                        <div class="purchase-plan-billing-error-image"> 
                            <dxe:ASPxImage ID="ImagePostalCode_ConInvalidCharacter" runat="server" SkinID="purchasePlanErrorIcon"
                                 ToolTip="<%$ Resources:Language,PostalCodeContainsInvalidCharacters %>" ClientInstanceName="ImagePostalCode_ConInvalidCharacter"
                                 ClientVisible="false" />
                            <dxe:ASPxImage ID="ImagePostalCode_ConError" runat="server" SkinID="purchasePlanErrorIcon"
                                ClientInstanceName="ImagePostalCode_ConError" ToolTip="<%$ Resources:Language,PostalCodeIsARequiredField %>"
                                ClientVisible="false" />
                        </div>
                    </div>
                </div>
            </div>
        </div>
        
        <div id="ConfirmPurchaseDiv" runat="server" clientidmode="Static"  style="visibility: hidden;display:none;">
            <div class="purchase-plan-confirm-payment-notice">
               <asp:Localize ID="FirstPaymentNotice" runat="server"/>
            </div>           
           <div class="purchase-plan-reviewterms" style="margin-top:10px;">
               <div class="purchase-plan-step-enter-text">
                    <asp:Localize ID="Localize19" Text="<%$resources:Language,PurchasePlan_ConfirmInstructions%>" runat="server"/>
                  </div>
               <div>
                   <div class="purchase-plan-confirm-detail-left">
                        <div class="purchase-plan-confirm-detail" >
                            <asp:Localize ID="Localize20" Text="<%$resources:Language,PurchasePlan_ConfirmPlanDetails%>" runat="server"/>
                        </div>
                        <div style=" margin-top:10px;">
                            <div class="purchase-plan-confirm-detail-content"><asp:Localize ID="Localize21" Text="<%$resources:Language,PurchasePlan_ConfirmPlanSize%>" runat="server"/></div>
                            <div class="purchase-plan-confirm-detail-content-lable"><asp:Localize ID="txtPlanSize"  runat="server"/></div> 
                        </div>
                         <div style=" margin-top:30px;">
                            <div class="purchase-plan-confirm-detail-content"><asp:Localize ID="Localize23" Text="<%$resources:Language,PurchasePlan_ConfirmBaseMonthlyPrice%>" runat="server"/></div>
                            <div class="purchase-plan-confirm-detail-content-lable"><asp:Localize ID="txtBaseMonthlyPrice"  runat="server"/></div> 
                        </div> 
                         <div style=" margin-top:50px;">
                            <div class="purchase-plan-confirm-detail-content"><asp:Localize ID="Localize25" Text="<%$resources:Language,PurchasePlan_ConfirmExtraGB%>" runat="server"/></div>
                            <div class="purchase-plan-confirm-detail-content-lable"><asp:Localize ID="txtExtraGB" runat="server"/></div> 
                        </div>                     
          
                    </div>
                   <div class="purchase-plan-confirm-detail-left" style="margin-left:15px;">
                        <div class="purchase-plan-confirm-detail" >
                            <asp:Localize ID="Localize22" Text="<%$resources:Language,PurchasePlan_ConfirmPaymentDetails%>" runat="server"/>
                        </div>
                        <div style=" margin-top:10px;">
                            <div class="purchase-plan-confirm-detail-content"><asp:Localize ID="Localize24" Text="<%$resources:Language,PurchasePlan_ConfirmCardNumber%>" runat="server"/></div>
                            <div class="purchase-plan-confirm-detail-content-lable" id="txtConfirmCardNumber"></div> 
                        </div>
                         <div style=" margin-top:30px;">
                            <div class="purchase-plan-confirm-detail-content"><asp:Localize ID="Localize27" Text="<%$resources:Language,PurchasePlan_ConfirmExpDate%>" runat="server"/></div>
                            <div class="purchase-plan-confirm-detail-content-lable" id="txtConfirmExpDate"></div> 
                        </div> 
                         <div style=" margin-top:50px;">
                            <div class="purchase-plan-confirm-detail-content"><asp:Localize ID="Localize29" Text="<%$resources:Language,PurchasePlan_ConfirmBillingZip%>" runat="server"/></div>
                            <div class="purchase-plan-confirm-detail-content-lable" id="txtConfirmBillingZip"></div> 
                        </div>                     
          
                    </div>
               </div>
               <div class="purchase-plan-confirm-billing-works">
                    <asp:Localize ID="Localize26" Text="<%$resources:Language,PurchasePlan_ConfirmHowBillingWorks%>" runat="server"/>
               </div>
               <div class="purchase-plan-confirm-billing-works-content">
                    <asp:Localize ID="Localize28" Text="<%$resources:Language,PurchasePlan_ConfirmHowBillingWorks_Content%>" runat="server"/>
                </div>
               <div style="margin-top:20px;">                   
                    <div class="purchase-plan-confirm-sent-email"><asp:Localize ID="Localize30" Text="<%$resources:Language,PurchasePlan_ConfirmSentEmail%>" runat="server"/><span class="required-indicator-red">*</span></div>
                    <div class="purchase-plan-card-number-edit">   
                        <dxe:ASPxTextBox runat="server" ID="txtEmailTo" ClientInstanceName="txtEmailTo" 
                            CssClass="purchase-plan-email-field" />
                    </div> 
                    <div class="purchase-plan-billing-error-image" style=" margin-top:0px"> 
                        <dxe:ASPxImage ID="ImageSentEmail_ConInvalidCharacter" runat="server" SkinID="purchasePlanErrorIcon"
                            ToolTip="<%$ Resources:Language,PurchasePlan_EmailAddressContainsInvalidCharacters %>" ClientInstanceName="ImageSentEmail_ConInvalidCharacter"
                            ClientVisible="false" />
                        <dxe:ASPxImage ID="ImageSentEmail_ConError" runat="server" SkinID="purchasePlanErrorIcon"
                            ClientInstanceName="ImageSentEmail_ConError" ToolTip="<%$ Resources:Language,PurchasePlan_EmailAddressIsARequiredField %>"
                            ClientVisible="false" />
                   </div>                   
              </div>

           </div>
            
        </div>
                </dxp:PanelContent>
            </PanelCollection>
        </dxcp:ASPxCallbackPanel>      
                  
        <div id="ReviewTermsDivFooter" class="purchase-plan-reviewterms-footer"  runat="server" clientidmode="Static">
            <div style=" margin-top:10px;">
                <div style="float:left"> 
                    <intronis:ImageButton runat="server" ID="PrintButton" DefaultText="<%$ Resources:Language,PurchasePlan_Print %>"
                        InstanceName="PurchasePlanPrintButton" IconCssClass="image-button-no-icon" 
                        ClickFunction="PurchasePlanPrintButton_Click" ClientVisible="true"/>
               </div>
               
               <div style="float:right">           
                     <span class="purchase-plan-check-agree"><asp:Localize ID="Localize10" Text="<%$resources:Language,PurchasePlan_CheckAgree%>" runat="server"/></span>
                     <span style="float:right;"><asp:CheckBox ID="cbAgree" ClientIDMode="Static" runat="server" /></span> 
               </div>
           </div>  
        </div> 
         <div class="purchase-plan-next">
            <div style="float:right;margin-left:5px;">
                <intronis:ImageButton runat="server" ID="Confirm" DefaultText="<%$ Resources:Language,PurchasePlan_Confirm %>"
                    InstanceName="PurchasePlanWizardConfirmButton" IconCssClass="image-button-no-icon" 
                    ClientVisible="false"   ClickFunction="PurchasePlanConfirmButton_Click"  />
            </div>
            <div style="float:right;margin-left:5px;">
                <intronis:ImageButton runat="server" ID="NextButton" DefaultText="<%$ Resources:Language,BrandingWizard_Next %>"
                    InstanceName="PurchasePlanWizardNextButton" IconCssClass="image-button-icon-next image-button-icon-next-arrow" 
                     ClickFunction="PurchasePlanNextButton_Click"/>
            </div>
            <div style="float:right;margin-left:5px;">
                <intronis:ImageButton runat="server" ID="PreviousButton" DefaultText="<%$ Resources:Language,BrandingWizard_Previous %>"
                    InstanceName="PurchasePlanWizardPreviousButton" IconCssClass="image-button-icon-back image-button-icon-back-arrow" 
                  ClickFunction="PurchasePlanPreviousButton_Click"  ClientVisible="false" />
            </div>           
        </div> 
    </div>


<dxhf:ASPxHiddenField ID="PurchasePlanWizardHiddenField" runat="server" ClientInstanceName="PurchasePlanWizardHiddenField" />
<intronis:PurchasePlanSlideOutLightbox runat="server" ID="PurchasePlanSlideOutLightbox"/>
<intronis:PurchasePlanWizardCloseLightbox runat="server" ID="PurchasePlanWizardCloseLightbox" />
<dxhf:ASPxHiddenField ID="messageLanguagePurchasePlanWizard" runat="server" ClientInstanceName="messageLanguagePurchasePlanWizard" />
<asp:ObjectDataSource ID="dataExpMonth" runat="server" TypeName="Domain.Maestro.DAL.GeneralDataSource"
    SelectMethod="ExpMonthList"></asp:ObjectDataSource>
<asp:ObjectDataSource ID="dataExpYear" runat="server" TypeName="Domain.Maestro.DAL.GeneralDataSource"
    SelectMethod="ExpYearList"></asp:ObjectDataSource>
<asp:ObjectDataSource ID="dataCountry" runat="server" TypeName="Domain.Maestro.DAL.GeneralDataSource"
    SelectMethod="CountryList"></asp:ObjectDataSource>
<dxcb:ASPxCallback ID="SavePurchasePlanCallBack" runat="server" 
    ClientInstanceName="SavePurchasePlanCallBack" 
    oncallback="SavePurchasePlanCallBack_Callback">
    <ClientSideEvents CallbackComplete="savePurchasePlan_CallbackComplete" />
</dxcb:ASPxCallback>

 

服務端部分:ui

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using Resources;
using Domain.Utilities;
using Infrastructure.Maestro.PortalTypes.Billing;
using Domain.Maestro.DAL;
using Infrastructure.Maestro.PortalTypes;
using DynaLoad.Server;
using Domain.Data;
using DevExpress.Web.ASPxClasses;
using Domain.Maestro;
using Infrastructure.Maestro.Utilities;
using Domain.Constants;
using Domain;

namespace WebPortalApplication.App_Components.Forms
{
    public partial class PurchasePlanWizardForm : System.Web.UI.UserControl
    {

        protected void Page_Load(object sender, EventArgs e)
        {
            PageResource.IncludeScript("/js/ValidateFields.js", this);
            PageResource.IncludeScript("/js/common.js", this);
            PageResource.IncludeScript("/js/lightboxes/PurchasePlanWizard.js", this);

            this.CardInput.MaxLength = (int)ColumnLengths.CreditCard;
            this.PostalCodeInput.MaxLength = (int)ColumnLengths.Zip;
            this.CityInput.MaxLength = (int)ColumnLengths.City;
            this.AddressInput.MaxLength = (int)ColumnLengths.Address;



            this.cmbExpMonth.DropDownButton.Image.Url = VirtualPathUtility.ToAbsolute("~/App_Themes/" + Page.Theme + "/") + "images/icons/MenuDropdown.png";
            this.cmbExpYear.DropDownButton.Image.Url = VirtualPathUtility.ToAbsolute("~/App_Themes/" + Page.Theme + "/") + "images/icons/MenuDropdown.png";
            this.cmbState.DropDownButton.Image.Url = VirtualPathUtility.ToAbsolute("~/App_Themes/" + Page.Theme + "/") + "images/icons/MenuDropdown.png";
            this.cmbCountry.DropDownButton.Image.Url = VirtualPathUtility.ToAbsolute("~/App_Themes/" + Page.Theme + "/") + "images/icons/MenuDropdown.png";

            this.messageLanguagePurchasePlanWizard.Set("PurchasePlanWizardJS_CloseWizard", Language.PurchasePlanWizardJS_CloseWizard);
            this.messageLanguagePurchasePlanWizard.Set("PurchasePlanWizardJS_CheckAgreeAlert", Language.PurchasePlanWizardJS_CheckAgreeAlert);
            this.messageLanguagePurchasePlanWizard.Set("PurchasePlanWizardJS_IsRequiredFields", Language.PurchasePlanWizardJS_IsRequiredFields);
            this.messageLanguagePurchasePlanWizard.Set("PurchasePlan_ReviewTermsConditions", Language.PurchasePlan_ReviewTermsConditions);
            this.messageLanguagePurchasePlanWizard.Set("PurchasePlan_TitleEnterBillingInformation", Language.PurchasePlan_TitleEnterBillingInformation);
            this.messageLanguagePurchasePlanWizard.Set("PurchasePlan_TitleReviewAndConfirmPurchase", Language.PurchasePlan_TitleReviewAndConfirmPurchase);
            this.messageLanguagePurchasePlanWizard.Set("PurchasePlan_EmailAddressIsARequiredField", Language.PurchasePlan_EmailAddressIsARequiredField);
            this.messageLanguagePurchasePlanWizard.Set("PurchasePlan_EmailAddressContainsInvalidCharacters", Language.PurchasePlan_EmailAddressContainsInvalidCharacters);
            this.messageLanguagePurchasePlanWizard.Set("PurchasePlanWizardJS_Error", Language.PurchasePlanWizardJS_Error);
            this.messageLanguagePurchasePlanWizard.Set("PurchasePlanWizardJS_AnErrorOccurred", Language.PurchasePlanWizardJS_AnErrorOccurred);
        }

        protected void InitPlanInfoCallBack_Callback(object source, CallbackEventArgsBase e)
        {
            var commandArgs = Json.Import<CustomCallbackCommandArgs>(e.Parameter);
            int planId = 0;
            if (commandArgs == null) return;

            if (commandArgs.ContainsKey("planId"))
                planId = commandArgs.PlanId;

            Plan plan = PlanDataSource.GetPlanInfo(planId);
            this.PlanSummary.Text = string.Format(Language.PurchasePlan_PlanSummary, FileSize.ToText(plan.TotalSize, false, 0));
            string costExtraBlock = string.Format("{0:C2}", plan.CostExtraBlock);
            string totalSize = FileSize.ToText(plan.TotalSize, false);
            string blockSize = FileSize.ToText(plan.BlockSize, false);
            this.OnlineBackupPlan.Text = string.Format(Language.PurchasePlan_OnlineBackupPlanContent, totalSize, costExtraBlock, blockSize);
            switch (plan.Frequency)
            {
                case (int)Infrastructure.Maestro.PortalTypes.PaymentSchedule.Recurring_Monthly:
                    this.PaymentSchedule.Text = Language.PaymentSchedule_Recurring_Monthly;
                    break;
                case (int)Infrastructure.Maestro.PortalTypes.PaymentSchedule.Recurring_Quarterly:
                    this.PaymentSchedule.Text = Language.PaymentSchedule_Recurring_Quarterly;
                    break;
                case (int)Infrastructure.Maestro.PortalTypes.PaymentSchedule.Recurring_bi_Annually:
                    this.PaymentSchedule.Text = Language.PaymentSchedule_Recurring_bi_Annually;
                    break;
                case (int)Infrastructure.Maestro.PortalTypes.PaymentSchedule.Recurring_Yearly:
                    this.PaymentSchedule.Text = Language.PaymentSchedule_Recurring_Yearly;
                    break;

                default:
                    this.PaymentSchedule.Text = string.Format(Language.PaymentSchedule_Default_Recurring_Months, plan.Frequency);
                    break;
            };

            string formattedDate = DateTime.Today.AddDays(1).ToString(CultureInfoHelper.DateFormat);
            this.EffectiveDate.Text = formattedDate;

            Partner info = PartnersDataSource.Info();

            //only seve the original values which are not changed 
            this.OriginalBillingAddressHiddenField.Set("BillingAddress_Company", info.BillingAddress.Company);
            this.OriginalBillingAddressHiddenField.Set("BillingAddress_Fax", info.BillingAddress.Fax);
            this.OriginalBillingAddressHiddenField.Set("BillingAddress_Extension", info.BillingAddress.Extension);
            this.OriginalBillingAddressHiddenField.Set("BillingAddress_Name", info.BillingAddress.Name);
            this.OriginalBillingAddressHiddenField.Set("BillingAddress_Phone", info.BillingAddress.Phone);
            this.OriginalBillingAddressHiddenField.Set("BillingAddress_Website", info.BillingAddress.Website);
            this.OriginalBillingAddressHiddenField.Set("BillingAddress_Email", info.BillingAddress.Email);

            AddressInput.Text = (info.BillingAddress.Address1 + " " + info.BillingAddress.Address2).Trim();
            CityInput.Text = info.BillingAddress.City;
            PostalCodeInput.Text = info.BillingAddress.Zip;

            string[] arrSupportedUSCountry = { "US", "USA", "United States" };
            string[] arrSupportedCACountry = { "CA", "CAN", "Canada" };
            string countryCode = "USA";
            if (arrSupportedUSCountry.Contains(info.BillingAddress.Country))
            {
                cmbCountry.SelectedIndex = 0;

            }
            else if (arrSupportedCACountry.Contains(info.BillingAddress.Country))
            {
                cmbCountry.SelectedIndex = 1;
                countryCode = "CAN";
            }
            var stateList = StateProvinceNameList(countryCode);
            cmbState.DataSource = stateList;
            cmbState.DataBind();
            int index = -1;
            index = stateList.FindIndex(state => state.Code.ToLower() == info.BillingAddress.State.ToLower());
            if (index < 0)
            {
                index = stateList.FindIndex(state => state.Name.ToLower() == info.BillingAddress.State.ToLower());
            }
            cmbState.SelectedIndex = index;


            double currentEstimatedCost = plan.Price;
            string currentEstimatedCostFormated = string.Format("{0:C2}", currentEstimatedCost);
            FirstPaymentNotice.Text = string.Format(Language.PurchasePlan_FirstPaymentNotice, currentEstimatedCostFormated, formattedDate);
            this.txtPlanSize.Text = FileSize.ToText(plan.TotalSize, false, 0);
            this.txtBaseMonthlyPrice.Text = string.Format("{0:C2}", plan.Price);
            this.txtExtraGB.Text = string.Format("{0:C2}", plan.CostExtraBlock);

            this.txtEmailTo.Text = info.Email;
        }

        private List<StateProvince> StateProvinceNameList(string countryCode)
        {

            List<StateProvince> ls = new List<StateProvince>();
            List<StateProvince> stateList = GeneralDataSource.StateProvinceList();
            var result = stateList.Where(s => (s.CountryCode.ToLower() == countryCode.ToLower()));
            ls = result.ToList();
            return ls;
        }

        protected void cmbState_Callback(object sender, CallbackEventArgsBase e)
        {
            string countryCode = "USA";
            if (cmbCountry.SelectedIndex == 0)
            {
                countryCode = "USA";
            }
            else if (cmbCountry.SelectedIndex == 1)
            {
                countryCode = "CAN";
            }
            cmbState.DataSource = StateProvinceNameList(countryCode);
            cmbState.DataBind();
        }

        protected void SavePurchasePlanCallBack_Callback(object source, DevExpress.Web.ASPxCallback.CallbackEventArgs e)
        {
            var commandArgs = Json.Import<CustomCallbackCommandArgs>(e.Parameter);
            int planId = 0;
            if (commandArgs == null) return;

            if (commandArgs.ContainsKey("planId"))
                planId = commandArgs.PlanId;

            Address currentBillingAdress = new Address();

            currentBillingAdress.Company = OriginalBillingAddressHiddenField.Get("BillingAddress_Company").ToString();
            currentBillingAdress.Fax = OriginalBillingAddressHiddenField.Get("BillingAddress_Fax").ToString();
            currentBillingAdress.Extension = OriginalBillingAddressHiddenField.Get("BillingAddress_Extension").ToString();
            currentBillingAdress.Name = OriginalBillingAddressHiddenField.Get("BillingAddress_Name").ToString();
            currentBillingAdress.Phone = OriginalBillingAddressHiddenField.Get("BillingAddress_Phone").ToString();
            currentBillingAdress.Website = OriginalBillingAddressHiddenField.Get("BillingAddress_Website").ToString();
            currentBillingAdress.Email = OriginalBillingAddressHiddenField.Get("BillingAddress_Email").ToString();

            currentBillingAdress.Address1 = AddressInput.Text;
            currentBillingAdress.Address2 = string.Empty;
            currentBillingAdress.City = CityInput.Text;
            currentBillingAdress.Country = cmbCountry.Value.ToString();
            currentBillingAdress.State = cmbState.ClientValue.ToString();
            currentBillingAdress.Zip = PostalCodeInput.Text;

            string cardNumber = CardInput.Text;
            int expMonth = Convert.ToInt32(cmbExpMonth.Value);
            int expYear = Convert.ToInt32(cmbExpYear.Value);
            string confirmEmailTo = txtEmailTo.Text;

            try
            {

                bool isSave = PartnersDataSource.PartnerTrialConvertToZeroTouch(PageHelper.CustomerUsername, planId, cardNumber, expYear, expMonth, currentBillingAdress, confirmEmailTo);
                if (isSave)
                {
                    Session["PartnerCategory"] = (int)PartnerCategory.PARTNER_CATEGORY_FULL;
                    Session["TrialRemaining"] = null;
                    Session["EndDate"] = null;
                    Session["DisplayResources"] = null;
                    Session["DisplayBilling"] = null;
                    Session["DisplayManageIntegrations"] = null;
                    Session["DisplayAccountSnapshot"] = null;
                    Session["DisplayDeployableInstaller"] = null;

                    SavePurchasePlanCallBack.JSProperties["cpFlag"] = true;
                    SavePurchasePlanCallBack.JSProperties["cpUsername"] = PageHelper.CustomerUsername;
                }
                else
                {
                    SavePurchasePlanCallBack.JSProperties["cpFlag"] = false;
                }
            }
            catch (Exception)
            {
                SavePurchasePlanCallBack.JSProperties["cpError"] = true;
            }
        }
    }
    internal class CustomCallbackCommandArgs : JsonDictionary
    {
        public int PlanId
        {
            get { return ContainsKey("planId") ? Convert.ToInt32(base["planId"]) : -1; }
        }
    }
}
相關文章
相關標籤/搜索