Проверка Saripaar Android, несколько форм
У меня есть 3 формы в одном упражнении (и макете), которые я хочу проверить с помощью saripaar. Это подтверждает три формы, но они не проверяют независимо.
Это макет:
- Форма 1: ввод для электронной почты и кнопка отправки.
- Форма 2: Введите код подтверждения и кнопку отправки.
- Форма 3: введите пароль, подтвердите пароль и кнопку отправки.
Я хочу, чтобы, когда вы нажимаете "отправить" для формы 1, проверяйте только правила формы 1 и формы 2 и формы 3.
У меня есть 3 объекта валидаторов и логика каждого из них схожа. Пример:
validatorEmail = new Validator(this);
editTextRecoveryEmail = (EditText) findViewById(R.id.editTextRecoveryEmail);
buttonRecoveryEmail = (Button) findViewById(R.id.buttonRecoveryEmail);
validatorEmail.setValidationListener(new ValidationListener() {
@Override
public void onValidationSucceeded() {
// Enviar el email
}
@Override
public void onValidationFailed(View failedView, Rule<?> failedRule) {
String message = failedRule.getFailureMessage();
if (failedView instanceof EditText) {
if (failedView.getId() == editTextRecoveryEmail.getId()) {
failedView.requestFocus();
((EditText) failedView).setError(message);
}
}
}
});
buttonRecoveryEmail.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
validatorEmail.validate();
}
});
Это мой полный код активности:
/* Inicializamos los controles */
editTextRecoveryEmail = (EditText) findViewById(R.id.editTextRecoveryEmail);
editTextRecoveryCode = (EditText) findViewById(R.id.editTextRecoveryCode);
editTextRecoveryPassword = (EditText) findViewById(R.id.editTextRecoveryPassword);
editTextRecoveryPasswordConfirm = (EditText) findViewById(R.id.editTextRecoveryPasswordConfirm);
buttonRecoverySubmit = (Button) findViewById(R.id.buttonRecoverySubmit);
buttonRecoveryCode = (Button) findViewById(R.id.buttonRecoveryCode);
buttonRecoveryEmail = (Button) findViewById(R.id.buttonRecoveryEmail);
/* Objeto validador */
validatorEmail = new Validator(this);
validatorCode = new Validator(this);
validatorSubmit = new Validator(this);
validatorEmail.setValidationListener(new ValidationListener() {
@Override
public void onValidationSucceeded() {
// Enviar el email
}
@Override
public void onValidationFailed(View failedView, Rule<?> failedRule) {
String message = failedRule.getFailureMessage();
if (failedView instanceof EditText) {
if (failedView.getId() == editTextRecoveryEmail.getId()) {
failedView.requestFocus();
((EditText) failedView).setError(message);
}
}
}
});
validatorCode.setValidationListener(new ValidationListener() {
@Override
public void onValidationSucceeded() {
// Validar código
}
@Override
public void onValidationFailed(View failedView, Rule<?> failedRule) {
String message = failedRule.getFailureMessage();
if (failedView instanceof EditText) {
if (failedView.getId() == editTextRecoveryCode.getId()) {
failedView.requestFocus();
((EditText) failedView).setError(message);
}
}
}
});
validatorSubmit.setValidationListener(new ValidationListener() {
@Override
public void onValidationSucceeded() {
// Validar Submit
}
@Override
public void onValidationFailed(View failedView, Rule<?> failedRule) {
String message = failedRule.getFailureMessage();
if (failedView instanceof EditText) {
if (failedView.getId() == editTextRecoveryPassword.getId()
|| failedView.getId() == editTextRecoveryPasswordConfirm.getId()) {
failedView.requestFocus();
((EditText) failedView).setError(message);
}
}
}
});
/* Comportamiento del botón de Registro */
buttonRecoveryEmail.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
validatorEmail.validate();
}
});
/* Comportamiento del botón de Registro */
buttonRecoveryCode.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
validatorCode.validate();
}
});
/* Comportamiento del botón de Registro */
buttonRecoverySubmit.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
validatorSubmit.validate();
}
});
1 ответ
Решение
Это интересная проблема. Вам понадобится 3 валидатора в 3 разных классах контроллеров, чтобы справиться с этой ситуацией.
static class EmailController implements ValidationListener {
@Email
private EditText mEmailEditText;
private Button mSubmitButton;
private Context mContext;
private Validator mValidator;
public EmailController(@NonNull EditText emailEditText, @NonNull Button submitButton) {
mEmailEditText = emailEditText;
mSubmitButton = submitButton;
mContext = emailEditText.getContext();
mValidator = new Validator(this);
mValidator.setValidationListener(this);
mSubmitButton.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
validator.validate();
}
});
}
@Override
public void onValidationSucceeded() {
// Success...
}
@Override
public void onValidationFailed(List<ValidationError> errors) {
// Failure...
}
}
Вам понадобятся еще 2 из них - один для кода проверки, а другой для пароля. Если вы хотите общаться со своей деятельностью, передайте ее или реализуйте соответствующие интерфейсы слушателя.
Подумайте об упрощении вашей формы, если это возможно.