Новости 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 Гость просматривают эту тему.
  • 12 Ответов
  • 1039 Просмотров
*

Masha0701

  • Осваиваюсь на форуме
  • 28
  • 0 / 0
При обновлении с 3.2.7 до 3.6.2 выдается ошибка

Error displaying the error page: Illegal mix of collations (utf8_unicode_ci,IMPLICIT) and (utf8_general_ci,IMPLICIT) for operation '=' SQL=SELECT template, s.params FROM #__template_styles as s LEFT JOIN #__extensions as e ON e.type='template' AND e.element=s.template AND e.client_id=s.client_id WHERE s.client_id = 1 AND home = '1' ORDER BY home: Illegal mix of collations (utf8_unicode_ci,IMPLICIT) and (utf8_general_ci,IMPLICIT) for operation '=' SQL=SELECT template, s.params FROM #__template_styles as s LEFT JOIN #__extensions as e ON e.type='template' AND e.element=s.template AND e.client_id=s.client_id WHERE s.client_id = 1 AND home = '1' ORDER BY home

Зашла в phpMyAdmin перекодировала все таблицы с юникода на general. После этого смогла зайти в админку. Поставила корректировку баз данных ( ошибка Joomla! Core database tables have not been converted yet to UTF-8.) но система опять перекодировала часть баз в юникод и выдала эту ошибку по новой.
*

voland

  • Легенда
  • 11028
  • 588 / 112
  • Эта строка съедает место на вашем мониторе
*

Masha0701

  • Осваиваюсь на форуме
  • 28
  • 0 / 0
Параметры хостинга?

сейчас пытаюсь прогнать сайт на Дэнвере
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Цитировать
но система опять перекодировала часть баз в юникод и выдала эту ошибку по новой.
Какая такая система взяла и перекодировала базу? Не бывает такого
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

voland

  • Легенда
  • 11028
  • 588 / 112
  • Эта строка съедает место на вашем мониторе
Не надо мучать труп (денвер), параметры реального хостинга какие?
*

Masha0701

  • Осваиваюсь на форуме
  • 28
  • 0 / 0
Какая такая система взяла и перекодировала базу? Не бывает такого
все таблицы в базе были utf8_general_ci . После База данных -> исправить часть таблиц кодируются utf8_unicode_ci .

Опять захожу  в базу данных, меняю кодировку на utf8_general_ci . повторяем отладку... и результат опять тот же
*

Masha0701

  • Осваиваюсь на форуме
  • 28
  • 0 / 0
Не надо мучать труп (денвер), параметры реального хостинга какие?
На реальном хостинге пока не обновляла. Сейчас рискну
*

Masha0701

  • Осваиваюсь на форуме
  • 28
  • 0 / 0
Собственно на хостинге обновилось без проблем и даже без танцев с бубном.
Но если у кого-нибудь есть ответ, как эту ошибку можно обойти на Дэнвере - я бы была крайне благодарна.
*

Филипп Сорокин

  • Завсегдатай
  • 1918
  • 160 / 4
  • разработчик.москва
Цитировать
как эту ошибку можно обойти на Дэнвере

Не использовать Денвер.

Вам уже ранее говорили, что он устарел и больше не поддерживается его разработчиками. Используйте Open Server или Wamp Server взамен.
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Не использовать Денвер.
Почему? с 2006 года сижу на денвере и никаких проблем нет. Ошибки связанные с руками или незнанием чего-либо могут вылезти на любой платформе.
Но с такой ошибкой никогда не сталкивался, чтобы слетала кодировка.
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

Филипп Сорокин

  • Завсегдатай
  • 1918
  • 160 / 4
  • разработчик.москва
Заходим на официальный сайт:

Цитировать
Денвер - локальный сервер. Состав: Apache 2.2.22, PHP 5.3.13, MySQL 5.5, phpMyAdmin 3.5.1 etc.

Подходил к концу 2016 год...
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Подходил к концу 2016 год...
Ну а что мешает обновить нужные компоненты руками? У меня три разные версии денвера стоят, с разным набором версий пхп\мускуля. Вполне удобно для разных сайтов
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

Филипп Сорокин

  • Завсегдатай
  • 1918
  • 160 / 4
  • разработчик.москва
Цитировать
Ну а что мешает обновить нужные компоненты руками?
Лень-матушка. Я поставил WAMP и не парюсь -- не такой мудрёный как Open Server, прост в использовании, хотя на вкус и цвет...
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

При переходе в категорию остается активной страница, с которой пришел

Автор Vika24

Ответов: 4
Просмотров: 891
Последний ответ 12.05.2023, 18:26:33
от Vika24
Call to a member function NewColorizeImage() on null при переходе PHP 7 [Решено]

Автор Eholov

Ответов: 3
Просмотров: 3188
Последний ответ 17.03.2023, 11:03:04
от Olexa
Ошибка при переходе на php 8

Автор Andru

Ответов: 1
Просмотров: 1964
Последний ответ 09.01.2023, 20:39:03
от sivers
Ошибка при переходе PHP от 5.7 к 7.4

Автор Yakov51

Ответов: 4
Просмотров: 738
Последний ответ 08.04.2022, 13:33:49
от marksetter
Перенос отдельных таблиц из одной базы данных в другую для обновления Joomla

Автор alex-nosov1980

Ответов: 3
Просмотров: 1301
Последний ответ 13.09.2021, 08:58:55
от alex-nosov1980