Новости 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 Ответов
  • 11435 Просмотров
*

IgorWRD

  • Осваиваюсь на форуме
  • 29
  • 0 / 0
Последнее время достали спамеры в комментариях, CAPTCHA включена но не помогает совсем.
Это общая проблема или меня просто "полюбили"?

Может есть другая CAPTCHA, которая более эффективна?
*

draff

  • Гуру
  • 5801
  • 434 / 7
  • ищу работу
Если  в тексте комментария http:// не пропускаю комментарий . Но это хак ядра компонента .
« Последнее редактирование: 05.05.2017, 17:48:15 от draff »
*

ProtectYourSite

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

Biss

  • Давно я тут
  • 995
  • 101 / 0
Recaptcha пробовали?
да, кстати я как поставил от Google,  вроде прекратилось пока. а то тоже уже было обнаглели совсем
*

IgorWRD

  • Осваиваюсь на форуме
  • 29
  • 0 / 0
Если  в тексте комментария http or https не пропускаю комментарий . Но это хак ядра компонента .
отл идея! а как такое реализовать?
*

IgorWRD

  • Осваиваюсь на форуме
  • 29
  • 0 / 0
Recaptcha пробовали?
нет вариантов выбора. только KCAPTCHA
*

ProtectYourSite

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

Karyuudo

  • Захожу иногда
  • 354
  • 0 / 0
Включил уведомления на почту и вручную удаляю если спам.
И потом заношу айпи в банлист.

Можно ли забанить подсеть? смотрю из Чехии много спама
*

ProtectYourSite

  • Живу я здесь
  • 2364
  • 137 / 4
  • Безопасность вебсайтов
В .htaccess можно хоть подсеть добавить.
Есть также решения, можно по странам банить.
Смотрите только нужных не забаньте.
*

tati-2000

  • Захожу иногда
  • 308
  • 2 / 0
Внесла в бан IP сегодня опять с этого IP коммент. Чет не работает бан по IP адресам j3.72 ; JComments 3.0.5
« Последнее редактирование: 07.07.2017, 09:53:30 от tati-2000 »
*

Karyuudo

  • Захожу иногда
  • 354
  • 0 / 0
Внесла в бан IP сегодня опять с этого IP коммент. Чет не работает бан по IP адресам j3.72 ; JComments 3.0.5
аналогично, не работает. Поставил рекапчу - доволен. Спама нет, и люди стали активнее комментить. Так как это гораздо удобнее, чем вводить цифры с картинки
*

tati-2000

  • Захожу иногда
  • 308
  • 2 / 0
не получилось рекапчу поставить, не поняла куда код с кнопкой добавить, ключи и т.д. все сделала, но вариант выбора реCAPTCHA в настройках не добавился. Может что пропустила конечно. 
*

Biss

  • Давно я тут
  • 995
  • 101 / 0
У вас эта версия JComments
*

tati-2000

  • Захожу иногда
  • 308
  • 2 / 0
Спасибо установила поверх. Может это и некорректно, но реCAPTCHA появилась, посмотрим . Спасибо
Но хорошо бы бан лист доработали бы. Реально проблема )
*

tati-2000

  • Захожу иногда
  • 308
  • 2 / 0
Появилась ошибка в консоли :
SCRIPT5022: ReCAPTCHA placeholder element must be empty
recaptcha__ru.js (506,409)

что опять не так? Кто нибудь сталкивался?
*

ProtectYourSite

  • Живу я здесь
  • 2364
  • 137 / 4
  • Безопасность вебсайтов
РеCAPTCHA есть ещё на странице?  Одновременно может быть только одна реCAPTCHA от Google
*

tati-2000

  • Захожу иногда
  • 308
  • 2 / 0
Да, на странице, она одна... не поняла, и только в jC. больше никаких
*

tati-2000

  • Захожу иногда
  • 308
  • 2 / 0
и работает в принципе коммент
*

tati-2000

  • Захожу иногда
  • 308
  • 2 / 0
такое впечатление, что где комментарии были добавлены до установки реCAPTCHA показывает консоль ошибку, а где уже после там ошибка не выскакивает. Но правда неточно, надо будет ещё посмотреть. После новых статей посмотрю
*

ProtectYourSite

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

tati-2000

  • Захожу иногда
  • 308
  • 2 / 0
*

ProtectYourSite

  • Живу я здесь
  • 2364
  • 137 / 4
  • Безопасность вебсайтов
В шаблоне не вставляли случаем скрипт реCAPTCHA?
Код
<script src="https://www.google.com/recaptcha/api.js"></script>
Ибо у вас грузится 2 скрипта
Код
<script type="text/javascript" async="" src="https://www.gstatic.com/recaptcha/api2/r20170712134223/recaptcha__ru.js"></script>
<script type="text/javascript" async="" src="https://www.gstatic.com/recaptcha/api2/r20170712134223/recaptcha__ru.js"></script>

Ищите причину дубля.
*

tati-2000

  • Захожу иногда
  • 308
  • 2 / 0
Спасибо, чет не помню за собой такого, зачем это... пошла искать
*

tati-2000

  • Захожу иногда
  • 308
  • 2 / 0
Вот спасибо, действительно, как -то не догадалась в этом направлении посмотреть ))
*

art22

  • Захожу иногда
  • 332
  • 2 / 0
https://joomla-support.ru/thread/47839/#post-189797

отличный метод. Можете сказать как к имени это прикрутить? Чтобы не пропускал английские имена, а то основной спам идет от англ имен.
*

bormir

  • Осваиваюсь на форуме
  • 25
  • 0 / 0
Вариант:
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');
для последней версии jcomments не проходит. Как вы избавляетесь от спама?
*

wishlight

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

bormir

  • Осваиваюсь на форуме
  • 25
  • 0 / 0
И так мало кто сейчас комментирует (раньше приходило в десятки раз больше сообщений от реальных посетителей). Так такая капча и последних отпугнет, останутся одни боты. Может кто знает как этот хак (код) под новый jcomments приспособить?
*

bormir

  • Осваиваюсь на форуме
  • 25
  • 0 / 0
Сейчас в jcomments.php так:
Код
if (isset($_REQUEST['jtxf']))
{
require_once JPATH_ROOT . '/components/com_jcomments/jcomments.ajax.php';
Если добавить:
Код
$mystring = JRequest::getVar('comment', '', 'post', 'string');
if (preg_match("/(http|https)/i", $mystring)) {echo "OK"; exit;}
или заменить на:
Код
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% спамеров.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться