Новости Joomla

Свои типы полей в Joomla.

Свои типы полей в Joomla.Это большая тема, о которой можно говорить очень много

Это большая тема, о которой можно говорить очень много. Самое главное, что возможности применения ограничиваются только вашей больной фантазией. Вы строите интерфейс своего модуля или плагина и вам нужно подтянуть данные из сторонней системы (список чего-нибудь по какому-нибудь API), чтобы сохранить выбранный id в Joomla. Или сделать какую-то проверку и в зависимости от неё показать то или иное сообщение пользователю. Для этого подойдут свои пользовательские типы полей. Интерфейс Joomla по большей части описан в XML-файлах. У каждого из них свои параметры. Некоторые не описаны в документации (manual.joomla.org), поэтому самым любопытным будет полезно заглянуть в собственно файлы фреймворка по пути

libraries/src/Form/FormField.php, а так же в
libraries/src/Form/Fields. У каждого класса поля перечислены его специфические свойства, которые можно описывать в XML. А в своём типе поля вы можете устанавливать эти значения программно. В моём модуле WT Quick links под капотом происходят изменения. Теперь для работы (в админке) ему нужен вспомогательный плагин. А в самом модуле нам бы проверить, а не выключен ли он? В Joomla есть тип поля Note - заметка. Его можно использовать для вывода примечаний.

<field type="note" name="your_note_for_user" label="Заголовок примечания" title="Альтернативный способ для заголовка" description="Текст примечания" class="col-12 alert alert-info" heading="h1" close="true" />

heading - указывать уровень заголовка.
close - позволяет закрыть это примечание. В классе поля
libraries/src/Form/Field/NoteField.php описана логика вывода. И в принципе оно нам подходит для нашей задачи. Но оно будет выводить сообщение всегда, а нам нужно только тогда, когда плагин отключён. Поэтому берём и создаём свой класс поля, который мы унаследуем от
NoteField. Это значит, что у нас в руках будет весь инструментарий стандартного поля
Note + то, что мы сами добавим. В XML-манифест добавляем наше поле

<field type="systempluginstatus" name="systempluginstatus" addfieldprefix="Joomla\Module\Wtquicklinks\Site\Fields"/>

-

type - имя файла и класса,-
addfieldprefix - указываем namespace к нашему классу, может быть любой нам нужный-
name - нельзя полю без имени...Это означает, что Joomla будет использовать класс поля из файла
modules/mod_wt_quick_links/src/Fields/SystempluginstatusField.php.А в классе поля будет написано следующее:

<?php // namespace для атрибута addfieldprefix namespace Joomla\Module\Wtquicklinks\Site\Fields; // нельзя напрямую обращаться к этому файлу defined('_JEXEC') or die; // подключаем родительский класс для переопределения use Joomla\CMS\Form\Field\NoteField; use Joomla\CMS\Language\Text; use Joomla\CMS\Plugin\PluginHelper; // имя класса и имя файла точь-в-точь class SystempluginstatusField extends NoteField { protected $type = 'Systempluginstatus'; protected function getLabel() { // если плагин не включён if(PluginHelper::isEnabled('system','wtquicklinks')) { // меняем свойства родительского класса $this->class = 'alert alert-danger w-100'; $this->element['label'] = '⚠️ А-а-а-а!'; $this->element['description'] = 'Плагин не включён!!'; // и просто рендерим его с нашими свойствами return parent::getLabel(); } // А иначе всё хорошо, скрываем поле из виду. $this->parentclass = 'd-none'; return ''; } }

Просто и удобно. И людям приятно, что о них позаботились и рассказали почему что-то не работает. @webtolkru#joomla #php #webdev #разработка

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

Helios

  • Захожу иногда
  • 421
  • 31 / 1
  • Аэтошозадеталь?
под новый jcomments приспособить
под какую конкретно версию jcomments?
/* Have a nice day! */
*

bormir

  • Осваиваюсь на форуме
  • 25
  • 0 / 0
4.0.33
*

wishlight

  • Гуру
  • 5051
  • 314 / 1
  • От 300 руб быстрый хостинг. Сервера.
*

bormir

  • Осваиваюсь на форуме
  • 25
  • 0 / 0
Там hcaptcha есть
Хотелось без отпугивающих посетителей и замедляющих скорость капч обойтись.
*

ProtectYourSite

  • Живу я здесь
  • 2364
  • 137 / 4
  • Безопасность вебсайтов
Хотелось без отпугивающих посетителей и замедляющих скорость капч обойтись.
А пример, такой капчи есть? Вам скорее надо в таком случае каким cloudfare пользоваться, там за вас будут отсекать ботов
*

bormir

  • Осваиваюсь на форуме
  • 25
  • 0 / 0
А пример, такой капчи есть? Вам скорее надо в таком случае каким cloudfare пользоваться, там за вас будут отсекать ботов
С этим вариантом раньше:
Код
if (isset($_REQUEST['jtxf'])) {
    $mystring = JRequest::getVar('comment', '', 'post', 'string');
if (preg_match("/(http|https)/i", $mystring)) {echo "OK"; exit;}
    require_once (JCOMMENTS_BASE.'/jcomments.ajax.php');
можно было отсекать до 90% спама, что решало проблему. Теперь придется с капчей заморачиваться.
*

ProtectYourSite

  • Живу я здесь
  • 2364
  • 137 / 4
  • Безопасность вебсайтов
*

bormir

  • Осваиваюсь на форуме
  • 25
  • 0 / 0
А сейчас как?
В версии 4.0.33 не работает такой вариант.
*

ProtectYourSite

  • Живу я здесь
  • 2364
  • 137 / 4
  • Безопасность вебсайтов
В версии 4.0.33 не работает такой вариант.
Ну теперь это надо просто в другом месте вставлять, к примеру:
components/com_jcomments/classes/security.php

Код

public static function badRequest()
{
return (int) (empty($_SERVER['HTTP_USER_AGENT']) || (!$_SERVER['REQUEST_METHOD'] == 'POST') || preg_match("/(http|https)/i",$_POST['comment']));
}

*

bormir

  • Осваиваюсь на форуме
  • 25
  • 0 / 0
Ну теперь это надо просто в другом месте вставлять, к примеру:
components/com_jcomments/classes/security.php

Код

public static function badRequest()
{
return (int) (empty($_SERVER['HTTP_USER_AGENT']) || (!$_SERVER['REQUEST_METHOD'] == 'POST') || preg_match("/(http|https)/i",$_POST['comment']));
}

Спасибо! Так похоже работает, протестирую пару дней.
*

bormir

  • Осваиваюсь на форуме
  • 25
  • 0 / 0
За два дня только штук 5 левых комментариев. Отлично работает, еще раз, спасибо! Кто-нибудь обновился до новой версии, нормально работает?
*

Helios

  • Захожу иногда
  • 421
  • 31 / 1
  • Аэтошозадеталь?
За два дня только штук 5 левых комментариев. Отлично работает, еще раз, спасибо! Кто-нибудь обновился до новой версии, нормально работает?
В новой версии нет этого добавления.
/* Have a nice day! */
*

bormir

  • Осваиваюсь на форуме
  • 25
  • 0 / 0
В новой версии нет этого добавления.
В 4.0.34 в components/com_jcomments/classes/security.php уже не проходит вариант?
Код
public static function badRequest()
{
return (int) (empty($_SERVER['HTTP_USER_AGENT']) || (!$_SERVER['REQUEST_METHOD'] == 'POST') || preg_match("/(http|https)/i",$_POST['comment']));
}
*

Helios

  • Захожу иногда
  • 421
  • 31 / 1
  • Аэтошозадеталь?
В 4.0.34 в components/com_jcomments/classes/security.php уже не проходит вариант?
Код
public static function badRequest()
{
return (int) (empty($_SERVER['HTTP_USER_AGENT']) || (!$_SERVER['REQUEST_METHOD'] == 'POST') || preg_match("/(http|https)/i",$_POST['comment']));
}

проходит, но нужно добавить заново если вы обновитесь с 4.0.33
/* Have a nice day! */
*

bormir

  • Осваиваюсь на форуме
  • 25
  • 0 / 0
проходит, но нужно добавить заново если вы обновитесь с 4.0.33
Добавить не проблема, но пока останусь на JComments v.4.0.33, все отлично работает. Плагин умного поиска, капчу, вывод последних комментариев не использую.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться