Проверка 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 из них - один для кода проверки, а другой для пароля. Если вы хотите общаться со своей деятельностью, передайте ее или реализуйте соответствующие интерфейсы слушателя.

Подумайте об упрощении вашей формы, если это возможно.

Другие вопросы по тегам