Wystarczy wskazać, w jaki sposób obchodzić ten wykorzystując IDataErrorInfo
...
umieścić wezwanie do nowej metody zwanej OnDataUpdated()
w każdej podstawce mojego widoku związana nieruchomości, takich jak:
private string username;
public string Username
{
get { return username; }
set
{
username = value;
OnDataUpdated();
}
}
private string password;
public string Password
{
get { return password; }
set
{
password = value;
OnDataUpdated();
}
}
następnie wewnątrz OnDataUpdated()
znakiem prywatna logiczna pole jako true
wskazujący dane uległy zmianie po raz pierwszy (FormType
było konieczne tylko dla mojego przypadku biznesowego):
private void OnDataUpdated()
{
dataChanged = true;
// .. Any other universal RaisePropertyChanged() events you may want to call to get your UI into sync. Eg. RaisePropertyChanged(() => CanConfirm);
}
Następnie w mojej właściwości indeksowania IDataErrorInfo
robię co następuje (Rozdzielam ją, aby "ValidForm()" można było wywołać ręcznie, aby wykonać także sprawdzanie poprawności formularza.
public string this[string columnName]
{
get
{
string result = null;
if (columnName == "Username")
{
// If other payment amounts have fully paid for balance, and cash amount has been entered, deny
if (!ValidForm(FormType.Step1, columnName))
result = "Please enter the username field.";
}
else if (columnName == "Password")
{
if (!ValidForm(FormType.Step1, columnName))
result = "Please enter the password field.";
}
return result;
}
}
/// <summary>
/// Test if valid form.
/// </summary>
/// <param name="formType">Specify which form we should validate.</param>
/// <param name="columnName">If ommitted, entire form will be validated.</param>
/// <returns></returns>
private bool ValidForm(FormType formType, string columnName = null)
{
// This field is used to denote when data has changed on the form.
// If data has changed, we know we can activate any form validation.
// We do not activate the form validation until after a user has typed
// something in at least.
if (!dataChanged) return true;
var errors = false;
if (formType == FormType.Step1 && ((string.IsNullOrEmpty(columnName) || columnName == "Username") && string.IsNullOrEmpty(Username)))
errors = true;
if (formType == FormType.Step1 && ((string.IsNullOrEmpty(columnName) || columnName == "Password") && string.IsNullOrEmpty(Password)))
errors = true;
return !errors;
}
Działa pięknie. Teraz mam tylko style sprawdzania poprawności pojawiające się po edycji przez użytkownika formularza.
Jeśli chcesz jakieś dodatkowe wisienką na torcie, można skomentować w moim RaisePropertyChanged(() => CanConfirm);
w metodzie OnDataUpdated()
i wiążą że do Confirm IsEnabled={Binding CanConfirm}
ze skojarzoną nieruchomości:
/// <summary>
/// Can the user confirm step 1?
/// </summary>
public bool CanConfirm
{
get { return ValidForm(FormType.Step1); }
}
a przycisk będzie tylko włączone, gdy twój formularz jest również ważny. :)
Ciesz się! i powodzenia z behemotem, który jest WPF.
Czy opracowałeś najlepsze podejście do tego Briana? : \ – GONeale