单击下一步后,向导工具包验证

时间:2014-10-09 15:03:43

标签: c# wpf mvvm mvvm-light wizard

我正在使用wpf扩展工具包中的Wizard控件,但是现在我遇到了一个问题。这是我的观点:

<xctk:Wizard Width="300" Height="300" HelpButtonVisibility="Collapsed" FinishButtonVisibility="Visible" Name="wizard" Next="wizard_Next">
<i:Interaction.Triggers>
    <i:EventTrigger EventName="Next">
        <mvvm:EventToCommand Command="{Binding NextCommand}" PassEventArgsToCommand="True"/>
    </i:EventTrigger>
</i:Interaction.Triggers>
<xctk:WizardPage x:Name="Step1Page" PageType="Blank" CanSelectNextPage="{Binding CanGoNext}" FinishButtonVisibility="Collapsed">
    <Grid Margin="10">
        <Grid.RowDefinitions>
            <RowDefinition Height="Auto"/>
            <RowDefinition Height="Auto"/>
            <RowDefinition Height="Auto"/>

        </Grid.RowDefinitions>
        <TextBlock Grid.Row="0" FontSize="14" Foreground="Red" Text="Log in to Vodafone One Net"/>
        <StackPanel Grid.Row="1" Margin="0,15,0,0">
            <TextBlock  Text="Step 1" FontWeight="SemiBold"/>
            <TextBlock  Text="Please enter your mobile number"/>
        </StackPanel>
        <xctk:WatermarkTextBox Grid.Row="2" Name="mobileNumber" PreviewKeyDown="OnPreviewKeyDown" AcceptsReturn="False" AcceptsTab="False" Watermark="Enter mobile number" Text="{Binding MobileNumber}"  Margin="0,10,0,0">
            <i:Interaction.Triggers>
                <i:EventTrigger EventName="TextChanged">
                    <i:InvokeCommandAction Command="{Binding MobileNumberTextChangedCommand}" CommandParameter="{Binding ElementName=mobileNumber, Path=Text}"/>
                </i:EventTrigger>
            </i:Interaction.Triggers>

            <i:Interaction.Behaviors>
                <v:AllowableCharactersTextBoxBehavior RegularExpression="^\d+$" MaxLength="50" />
            </i:Interaction.Behaviors>
        </xctk:WatermarkTextBox>

    </Grid>
</xctk:WizardPage>

...

然后在带有CanGoNext的ViewModel中我进行了一种验证,以便用户可以进行下一步或不进行(取决于文本框是否填充了某些东西)。

当用户单击“下一步”时,我会进行REST调用以验证该号码,如果该号码不是有效号码,我不想转到步骤2,但向导始终转到步骤2。

我甚至试图在我的RelayCommand中传递CancelRoutedEventArgs:

public async Task Next(CancelRoutedEventArgs e)
{
    var resp = await this._requestService.PostRequestPin(this.MobileNumber);

    if (resp.StatusCode == ERROR)
    {
        e.Cancel = true;
        e.Handled = true;
    }

}

用户总是转到第2步。谁知道我该怎么办?

感谢。 的问候,

1 个答案:

答案 0 :(得分:0)

找到解决方案。太简单了。

RelayCommand CanExecute方法做我想要的。到那儿那么容易和那么多时间!