Перейти к публикации
View in the app

A better way to browse. Learn more.

Дизайн и модификация Invision Community

A full-screen app on your home screen with push notifications, badges and more.

To install this app on iOS and iPadOS
  1. Tap the Share icon in Safari
  2. Scroll the menu and tap Add to Home Screen.
  3. Tap Add in the top-right corner.
To install this app on Android
  1. Tap the 3-dot menu (⋮) in the top-right corner of the browser.
  2. Tap Add to Home screen or Install app.
  3. Confirm by tapping Install.

Окно входа без перезагрузки

Опубликовано:

Добрый вечер!

Подскажите, пожалуйста, возможно ли полностью отказаться от отдельной страницы входа на сайт, чтобы все происходило в стоковом всплывающем окне?

 

Например, когда пользователь вводит неправильный пароль в окне входа, его перебрасывает на новую страницу по адресу site.ru/index.php?app=core&module=global&section=login&do=process

 

Как убрать эту страницу, чтобы ошибку выдавало с ajax-обновлением в этом же popup-окне?

Рекомендованные сообщения

Опубликовано:

Теоретически можно отправить авторизационные данные через ajax запрос и в зависимость от полученного ответа вывести либо ошибку, либо, при успешной авторизации, обновить текущую страницу.

 

После формы авторизации () в globalTemplate > inlineLogin добавить скрипт

 

<script>
$$('#inline_login_form #login')[0].observe('submit', function(e){
   e.preventDefault();
   var form = this;
   new Ajax.Request(form.action, {
       method: 'post',
       parameters: this.serialize(true),
       onSuccess: function(r) {
           var div = document.createElement('div');
           div.innerHTML = r.responseText;
           var script = div.select('script:contains("member_id")')[0];
           if(script){
               var toEval = script.innerHTML.replace('Loader.boot();', '');
               eval(toEval);
               if(ipb.vars['member_id']){
                   var params = document.location.search.toQueryParams();
                   if(params['module'] == 'global' && ['register', 'login'].indexOf(params['section']) != -1){
                       window.location = ipb.vars['board_url']+'/';
                   }
                   else{
                       window.location.reload();
                   }
               }
               else{
                   var error = form.select('p.error.message')[0];
                   if(!error){
                       form.select('div.ipsForm fieldset')[0].insert({
                           before: '<p class="error message" style="margin-bottom:10px;"></p>'
                       });
                       error = form.select('p.error.message')[0];
                   }
                   var p = div.select('p.error.message')[0];
                   error.innerHTML = p ? p.innerHTML : 'Authentication error';
               }
           }
           else{
               window.location.href = form.action;
           }
       }
   });
   return false;
});
</script>

Опубликовано:
  • Автор

Добавил в шаблон inlineLogin этот скрипт, но теперь popup-окно входа вообще не всплывает после нажатия на кнопку входа, сразу перенаправляет на отдельную страницу...

Upd. - Извиняюсь, все правильно работает! Спасибо огромное!! Именно то, что нужно!

Изменено пользователем Strategius

  • 4 недели спустя...
Опубликовано:
  • Автор

Заметил, что с отдельного окна входа (site.ru/index.php?app=core&module=global&section=login&do=process) после добавления модификации перестала работать переадресация на прошлую страницу. Например, до модификации при авторизации с того окна раньше происходила переадресация на предыдущую страницу, с которой мы попали на страницу входа. Теперь мы остаемся на странице авторизации, даже после входа... В чем проблема?

Опубликовано:

Нужно сделать исключение для формы с отдельной страницы авторизации.

Опубликовано:
  • Автор

А как прописать страницу (ссылку) в исключение? Оно будет формироваться так примерно?

 

if(ipb.vars['member_id']){
                   window.location.reload();
				try {
                   if ($this->settings['base_url']."app=core&module=global&section=login");
                   window.location.assign();
                   }
                   catch () {
                   window.location.assign();
                   }
                   finally {
                   window.location.assign();
                   }
               }

Изменено пользователем Strategius

Опубликовано:
if(window.location.search.indexOf('app=core&module=global&section=login') == -1)
$('login').onsubmit = function(e){
...

Опубликовано:
  • Автор

Спасибо Вам большое, работает! :)

  • 5 месяцев спустя...
Опубликовано:
  • Автор

Вылез баг - авторизация не работает, если пытаемся логиниться под забаненной учетной записью :(

Опубликовано:

Вылез баг - авторизация не работает, если пытаемся логиниться под забаненной учетной записью

 

Перед

        onSuccess: function(r) {

добавить

	onFailure: function( t )
{
              // Тут пишите, что делать. Можете редиректить, можете посылать письмо почтой России.
},

Опубликовано:
  • Автор

// Тут пишите, что делать. Можете редиректить, можете посылать письмо почтой России.

А что нужно прописать, чтобы редиректило?

Опубликовано:

А что нужно прописать, чтобы редиректило?

 

Вот же у Вас в коде

                    if(params['module'] == 'global' && ['register', 'login'].indexOf(params['section']) != -1){
                       window.location = ipb.vars['board_url']+'/';
                   }
                   else{
                       window.location.reload();
                   }

В первом случае редиректит на индексную страница, во втором - перезагружает страницу.

Опубликовано:
  • Автор

Добавил, но все равно если логиниться забаненным, то ajax-авторизация не работает... Авторизовывается только после перезагрузки страницы.

Опубликовано:

Добавил, но все равно если логиниться забаненным, то ajax-авторизация не работает... Авторизовывается только после перезагрузки страницы.

Переменная params у Вас находится в другой части кода. Можете переместить

                    var params = document.location.search.toQueryParams();

выше. Например, под var form

Опубликовано:
  • Автор

Огромное спасибо, заработало!

Опубликовано:

Огромное спасибо, заработало!

Можете выложить полностью рабочий код? :)

Создайте аккаунт или войдите в него для комментирования

Сейчас на странице 0

  • Нет пользователей, просматривающих эту страницу.

Configure browser push notifications

Chrome (Android)
  1. Tap the lock icon next to the address bar.
  2. Tap Permissions → Notifications.
  3. Adjust your preference.
Chrome (Desktop)
  1. Click the padlock icon in the address bar.
  2. Select Site settings.
  3. Find Notifications and adjust your preference.