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

DImLaeda

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
Внезапно стала появляться ошибка 1005 при создании или редактировании материалов:
1005 - Can't create table '#sql-6fa_ab649' (errno: 28) SQL=ALTER TABLE `rm8nf_finder_tokens` ENGINE = MEMORY
(при этом сами материалы создавались и обновлялись нормально).
Почистил кэш, не помогло. Запустил обновление Joomla.

Теперь в менеджере обновлений получаю ошибку:
 Unknown column 'extra_query' in 'field list' SQL=SELECT DISTINCT update_site_id, type, location, last_check_timestamp, extra_query FROM rm8nf_update_sites WHERE enabled = 1

В менеджере расширений-база данных ошибка:
    Схема базы данных (3.2.1) не соответствует версии CMS (3.2.3-2014-02-20).
    Таблица 'rm8nf_update_sites' не содержит поля 'extra_query'. (из файла 3.2.2-2013-12-22.sql.)
    Таблица 'rm8nf_updates' не содержит поля 'extra_query'. (из файла 3.2.2-2013-12-22.sql.)
    В таблице 'rm8nf_updates' отсутствует поле 'version' типа 'varchar(32)'. (из файла 3.2.2-2014-01-18.sql.)

Кнопка "Исправить" не помогает - пересылает на ошибку в менеджере обновлений.

В подвале админки показывает версию Joomla! 3.2.7 , а в админке слева:
Обслуживание
    Неизвестная версия Joomla!...   
    Неизвестные расширения...   


Каким образом можно исправить проблему?
« Последнее редактирование: 28.01.2015, 10:00:50 от b2z »
*

b2z

  • Глобальный модератор
  • 7284
  • 778 / 0
  • Разраблю понемногу
Re: Ошибка при обновлении
« Ответ #1 : 27.01.2015, 12:25:52 »
Цитировать
Кнопка "Исправить" не помогает - пересылает на ошибку в менеджере обновлений.
В смысле пересылает на ошибку?
*

DImLaeda

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
Re: Ошибка при обновлении
« Ответ #2 : 27.01.2015, 13:08:21 »
В смысле пересылает на ошибку?

Переправляет на страницу менеджера обновления Joomla, где показывает ошибку
 Can't create table '#sql-6fa_b1794' (errno: 28) SQL=ALTER TABLE `rm8nf_update_sites` ADD COLUMN `extra_query` VARCHAR(1000) DEFAULT '';
*

b2z

  • Глобальный модератор
  • 7284
  • 778 / 0
  • Разраблю понемногу
Re: Ошибка при обновлении
« Ответ #3 : 27.01.2015, 14:11:54 »
Похоже, что Вам ручкам придется исправить все ошибки напрямую в базе:

Код: sql
ALTER TABLE `#__update_sites` ADD COLUMN `extra_query` VARCHAR(1000) DEFAULT '';
ALTER TABLE `#__updates` ADD COLUMN `extra_query` VARCHAR(1000) DEFAULT '';

#_ заменить на свой префикс

ПО поводу finder_tokens
Выходит ошибка при создании материала автором

Где-то еще было по поводу finder_tokens на форуме, искать надо.
*

DImLaeda

  • Осваиваюсь на форуме
  • 11
  • 0 / 0
Re: Ошибка при обновлении
« Ответ #4 : 28.01.2015, 06:34:53 »
Похоже, что Вам ручкам придется исправить все ошибки напрямую в базе:

Код: sql
ALTER TABLE `#__update_sites` ADD COLUMN `extra_query` VARCHAR(1000) DEFAULT '';
ALTER TABLE `#__updates` ADD COLUMN `extra_query` VARCHAR(1000) DEFAULT '';

#_ заменить на свой префикс

ПО поводу finder_tokens
Выходит ошибка при создании материала автором

Где-то еще было по поводу finder_tokens на форуме, искать надо.

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

Нужна проф помощь в обновлении Joomla на лок.сервере osp. Можно платно

Автор Fati

Ответов: 0
Просмотров: 58
Последний ответ 16.06.2025, 16:40:04
от Fati
Прошу помощи. Ошибка при обновлении на Joomla 4

Автор wmsonic

Ответов: 1
Просмотров: 2030
Последний ответ 29.10.2023, 22:07:23
от Kukush
Выходит ошибка в админской панели

Автор daymarus

Ответов: 0
Просмотров: 1868
Последний ответ 10.08.2023, 12:43:43
от daymarus
При обновлении ошибка 403 Forbidden Request forbidden by administrative rules

Автор THeCMeX

Ответов: 18
Просмотров: 3756
Последний ответ 14.07.2023, 17:13:19
от art22
Call to a member function NewColorizeImage() on null при переходе PHP 7 [Решено]

Автор Eholov

Ответов: 3
Просмотров: 3188
Последний ответ 17.03.2023, 11:03:04
от Olexa