Новости Joomla

Как тестировать Joomla PHP-разработчику? Компонент Patch tester.

👩‍💻 Как тестировать Joomla PHP-разработчику? Компонент Patch tester.Joomla - open source PHP-фреймворк с готовой админкой. Его основная разработка ведётся на GitHub. Для того, чтобы международному сообществу разработчиков было удобнее тестировать Pull Requests был создан компонент Patch Tester, который позволяет "накатить" на текущую установку Joomla именно те изменения, которые необходимо протестировать. На стороне инфраструктуры Joomla для каждого PR собираются готовые пакеты, в которых находится ядро + предложенные изменения. В каждом PR обычно находятся инструкции по тестированию: куда зайти, что нажать, ожидаемый результат. Тестировщики могут предположить дополнительные сценарии, исходя из своего опыта и найти баги, о которых сообщить разработчику. Или не найти, и тогда улучшение или исправление ошибки быстрее войдёт в ядро Joomla. Напомню, что для того, чтобы PR вошёл в ядро Joomla нужны минимум 2 положительных теста от 2 участников сообщества, кроме автора. Видео на YouTubeВидео на VK ВидеоВидео на RuTubeКомпонент на GitHub https://github.com/joomla-extensions/patchtester@joomlafeed#joomla #php #webdev #community

Вышел релиз Revo PageBuilder Toolkit for YOOtheme Pro 1.6

Вышел релиз Revo PageBuilder Toolkit for YOOtheme Pro 1.6.2PageBuilder Toolkit - это специализированный плагин для конструктора страниц Yootheme Pro, содержит набор различных утилит для ускорения процесса работы и отладки макета, множественные улучшения в интерфейсе, включая поддержку dark mode, подсказки, быстрая смена разрешения в окне просмотра и много чего еще.v.1.6.2 Что нового?- Индикатор статусов: теперь не просто показывает состояние запросов, но и делает автоматические попытки их отправки при кратковременных сбоях в сети, а если это не помогло, то переводит конструктор в ручной режим, что позволяет сохранит макет и настройки темы прежде чем вы потеряете все, что было сделано с момента последнего сохранения- Подсветка ошибок в макете: плагин анализирует код страницы и может автоматически подсвечивать data атрибуты с кучей мусора, которые попадают в код страницы при копипасте из Figma в TinyMCE (пригодится для старых макетов, в текущей работе плагин сам очищает код мусора). Также есть подсветка семантических ошибок сборки - дубли h1 тега на странице и вложенных друг в друга заголовков.- Улучшена поддержка будущего релиза Yootheme Pro 5 и редактора CodeMirror 6Плагин для русскоязычных пользователей доступен в каталоге расширений SovMart и распространяется за символическую плату (100р). Разработчики Joomla расширений и партнеры автора могут получить плагин бесплатно.Для работы плагина необходим конструктор страниц Yootheme Pro.Разработчик плагина - участник нашего сообщества Александр Судьбинов (@alexrevo), член официальной группы поддержки Yootheme Pro. Страница расширенияОписание на сайте автора@joomlafeed#joomla #yootheme

0 Пользователей и 1 Гость просматривают эту тему.
  • 7 Ответов
  • 3330 Просмотров
*

yager84

  • Новичок
  • 5
  • 0 / 0
Здравствуйте.

В рамках изучения javascript для себя решил переписать стандартный шаблон модуля mod_login таким образом, чтобы посетитель мог авторизоваться без перезагрузки страницы (в случае выключенного javascript - авторизация происходит обычным способом).

Решил делать наверно самым простым способом - в ajax-запросе посылаем форму и при onSuccess, чтобы проверить, авторизовался посетитель или нет, вызываем объект JUser. То есть, если JUser->id != 0  пользователь авторизован. Иначе - попробуй, дорогой гость, еще разок.

Для этого в файле шаблона default.php модуля mod_login при срабатывании события onSubmit формы написал такой код:

Код
$('login-form').addEvent('submit', function(event){ //login-form - id формы
    event.stop();
    $('ajaxLoading').addClass('preloading'); //Добавляем класс, в бэкграунде которого гифка
    $('login-form').set('send', {
        onSuccess: function(){
            var aUser = "<?php echo JFactory::getUser()->id; ?>"; //После выполнения ajax-запроса значение aUser = 42
            alert(aUser); //А вот здесь выводится ноль
        }
    }).send();
})

То, что посетитель авторизован, понятно после перезагрузки страницы, но почему все-же значение aUser себя так "ведет". После выполнения скрипта в коде страницы aUser = 42. Но при попытке вывода значения на экран, оно равно нулю.
« Последнее редактирование: 01.10.2012, 14:58:18 от yager84 »
*

mohax

  • Давно я тут
  • 901
  • 66 / 3
Я не гуру JS, но каким образом в aUser должен занестись id юзера? Ведь код у Вас запускается на стороне клиента. Соответственно
Код
<?php echo JFactory::getUser()->id; ?>
срабатывает один раз при генерации страницы.
Вам необходимо в обработчике запроса на стороне сервера прислать ответ скрипту с id юзера.
*

yager84

  • Новичок
  • 5
  • 0 / 0
Вы правы, конечно... Но в таком случае не ясно, откуда в коде скрипта после выполнения запроса, берется id администратора (я выполняю вход под администратором)...

Ладно, решил последовать вашему совету. Я сейчас напишу примерную последовательность моих рассуждений. Вы, если это возможно, поправьте возможные ошибки.

1. Создаем в папке с нашим шаблоном файл, к примеру mylogin.php, куда будем скидывать по onSubmit значения логина и пароля формы авторизации.
2. В нашем файле mylogin.php создаем свою функцию авторизации, с незначительно измененным кодом стандартной функции авторизации login(), описанную в компоненте com_users (components\com_users\controllers\user.php)

Грубо говоря меняем строчки

Код
if (!JError::isError($error)){
    $app->setUserState('users.login.form.data', array());
    $app->redirect(JRoute::_($data['return'], false))
}

на

Код
if (!JError::isError($error)){
    $app->setUserState('users.login.form.data', array());
    echo JFactory::getUser()->id;
}

3. Ну а скрипт получает значение id пользователя.

Я прав? Или все-же нет?..

PS. В данный момент занимаюсь реализацией. Отпишусь по окончании
*

mohax

  • Давно я тут
  • 901
  • 66 / 3
ну можно и так. Единственное, не забудьте поменять адрес на который уходят данные с формы.
*

yager84

  • Новичок
  • 5
  • 0 / 0
Ну... Это понятно.

Спасибо, mohax.
*

yager84

  • Новичок
  • 5
  • 0 / 0
Эх... Не люблю я просить помощи, но без вас, уважаемые гуру, здесь мне не справиться.

Авторизация проходит нормально.

Скрипт (описан в первом посте)

Код
    $('login-form').set('send', {
        onSuccess: function(html){
             бла бла бла
        }
    }).send();

при onSuccess получает id залогиневшегося пользователя. Но три дня бьюсь над проблемой обновления самого модуля авторизации. То есть, по логике, если JFactory::getUser()->id == 0, то показываем сообщение, что он не авторизован. Сие работает. Но если JFactory::getUser()->id > 0, мне надо перерендерить сам модуль авторизации. Не оставлять же залогиненному пользователю форму с запросом пароля. Вот здесь проблема.

Возможно ли, чтобы модуль, грубо говоря, сам себя перерендерил?
*

varX

  • Живу я здесь
  • 2467
  • 141 / 5
  • разработка компонентов
Во первых вам нужно использовать
Код: javascript
new Ajax(url, option).request();
где в option будет функция, которая получит возвращаемый HTML и вставит его вместо старой формы.
Во вторых сама идея бесперспективная, т.к. объект User не изменится без перезагрузки страницы, соответственно не изменится доступность контента, меню и др. функционал.
Разработка и ремонт. VirtueMart. JoomShopping. Свои компоненты. Принимаю заявки на plasma-web.ru.
*

yager84

  • Новичок
  • 5
  • 0 / 0
Да, я об этом уже думал. Собственно, можно при user_id>0 просто обновлять страницу. Почему именно так хочется сделать? Ради удобства посетителя. Если он авторизуется и неправильно вводит логин/пароль, то много быстрее дать ему понять, что он не прав таким способом без перезагрузки страницы. Тем более, мне совершенно не нравится, как это делает Joomla по умолчанию.

Но основная причина - это самая первая авторизация. При ее прохождении, мне хотелось, чтобы посетитель в том месте, где была форма логина и пароля видел виджеты, на которые он подписан. Ну да ладно. Спасибо.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Не работает в авторизация

Автор Mobist

Ответов: 8
Просмотров: 1890
Последний ответ 05.08.2019, 13:04:34
от voland
Авторизация на сайте без логина и пароля. Это возможно!

Автор Aeliot

Ответов: 28
Просмотров: 10697
Последний ответ 09.03.2017, 22:30:45
от Septdir
Не удается сохранить изменения в модуле

Автор Bit-auto

Ответов: 1
Просмотров: 1386
Последний ответ 05.02.2017, 19:09:30
от Paha_web
Как сделать кликабельными телефоны в модуле login none outline?

Автор andreikul1967

Ответов: 1
Просмотров: 1454
Последний ответ 12.04.2016, 17:39:07
от darkghost
Вывод данных из дополнительного поля в модуле «html-код»

Автор goga_pgasovav

Ответов: 4
Просмотров: 1475
Последний ответ 17.03.2016, 15:08:49
от goga_pgasovav