в форме стоит reCaptcha - https://github.com/himiklab/yii2-recaptcha-widget
Как сделать верную аякс авторизацию?
пытаюсь так через виджет:
Код: Выделить всё
namespace frontend\widgets;
use Yii;
use yii\base\Widget;
use common\models\LoginForm;
class LoginFormWidget extends Widget {
public function run() {
if (Yii::$app->user->isGuest) {
$model = new LoginForm();
return $this->render('loginFormWidget', [
'model' => $model,
]);
} else {
return ;
}
}
}
Код: Выделить всё
<?php
use yii\bootstrap\ActiveForm;
use yii\helpers\Html;
?>
<?php $form = ActiveForm::begin([
'id' => 'login-form',
'class'=>'popup_form',
'enableAjaxValidation' => true,
'action' => ['site/ajax-login'],
]); ?>
<div class="popup__form-row popup__form-row--email">
<span class="popup__form-label">логин</span>
<?= $form->field($model, 'username')->textInput(['autofocus' => true,'class'=>'form-input','placeholder'=>'Введите e-mail'])->label(false) ?>
</div>
<div class="popup__form-row">
<span class="popup__form-label">Пароль</span>
<label class="input-pass">
<?= $form->field($model, 'password')->passwordInput(['class'=>"input-pass",'placeholder'=>"Введите пароль"])->label(false) ?>
</label>
</div>
<div class="popup__form-row popup__form-row--captcha">
<?= $form->field($model, 'reCaptcha',['enableAjaxValidation'=>false])->widget(\himiklab\yii2\recaptcha\ReCaptcha::className())->label(false) ?>
</div>
<div class="popup__form-bottom">
<?= Html::submitButton('Войти', ['class' => 'popup__form-submit', 'name' => 'login-button']) ?>
</div>
<?php ActiveForm::end(); ?>
Код: Выделить всё
public function actionAjaxLogin() {
$model = new LoginForm;
if (Yii::$app->request->isAjax && $model->load(Yii::$app->request->post())) {
if($model->login()) {
return $this->redirect('/site/index');
} else {
Yii::$app->response->format = yii\web\Response::FORMAT_JSON;
return \yii\widgets\ActiveForm::validate($model);
}
//return $this->renderAjax('@frontend/widgets/views/loginFormWidget', ['model' => $model]);
}
}
если неверно ввести а потом верно то почеуто кидает на страницу /ajax-login
и можно без доп js кода прятать кнопку - показывать на ее месте прелоадер
очень прошу помочь