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

Etegro

  • Новичок
  • 3
  • 0 / 0
Пропала таблица из БД
« : 04.08.2012, 01:07:44 »
Здравствуйте, уважаемые. Столкнулся с такой ситуацией: создал знакомым сайт на Joomla 2.5. Два месяца все спокойно работало после первоначальной настройки и наполнения, как вдруг захожу на главную страницу и вижу сообщение: "Table 'hudeem-krasivo.ruzc4_session' doesn't exist SQL=INSERT INTO `ruzc4_session` (`session_id`, `client_id`, `time`) VALUES ('253f39de5eaaf2d4ce22e65fb603a801', 0, '1344027855')". В phpMyAdmin такой таблицы действительно нет. Дело в том, что пароли были не только у меня и я не исключаю, что кто-то постарался. Вопрос: могла ли пропасть эта таблица из БД сама по себе, без постороннего вмешательства?
*

Marques

  • Завсегдатай
  • 1410
  • 190 / 9
  • Ctrl+F5
Re: Пропала таблица из БД
« Ответ #1 : 04.08.2012, 03:45:02 »
Сама она конечно пропасть не могла, чудес не бывает. А причина... да множество, у меня вот недавно на одном из сайтов клиента пропали все мои правки кода за несколько дней, я ему говорю все сделал, а он говорит - все по старому, сам посмотри. Я реально подумал, что все... пора отдохнуть пару-тройку дней. :) Потом выяснилось - HDD на сервере у хостера полетел, причем весь рейд умер, они и восстановили резервную копию недельной давности.

А по теме, вы просто сделайте эту таблицу по новой.
Код: sql
#
# Table structure for table `#__session`
#

  CREATE TABLE `#__session` (
  `session_id` varchar(200) NOT NULL default '',
  `client_id` tinyint(3) unsigned NOT NULL default '0',
  `guest` tinyint(4) unsigned default '1',
  `time` varchar(14) default '',
  `data` mediumtext default NULL,
  `userid` int(11) default '0',
  `username` varchar(150) default '',
  `usertype` varchar(50) default '',
  PRIMARY KEY  (`session_id`),
  KEY `whosonline` (`guest`,`usertype`),
  KEY `userid` (`userid`),
  KEY `time` (`time`)
)  DEFAULT CHARSET=utf8;
Зануда перфекционист, не признающий авторитетов, ищет легкую работу за большие деньги - http://dtkp.ru/ s@dtkp.ru
*

Etegro

  • Новичок
  • 3
  • 0 / 0
Re: Пропала таблица из БД
« Ответ #2 : 04.08.2012, 13:37:56 »
Попробовал по совету выше, подставив свой префикс в название. Таблица восстановилась, но засыпало фатал эррорами, походу, побилась вся таблица и виноват, скорее всего хостер. Самое интересное, что теперь старые пароли от ISP Manager те, что у меня были не подходят (кто и зачем их поменял - не знаю), от phpMyAdmin все подходит как и раньше.
*

Marques

  • Завсегдатай
  • 1410
  • 190 / 9
  • Ctrl+F5
Re: Пропала таблица из БД
« Ответ #3 : 04.08.2012, 14:35:09 »
Похоже и правда на стороне хостинга кто-то накосячил...  Обратите внимание на полезное и бесплатное расширение Akeeba Backup и когда восстановите сайт, делайте регулярно бэкапы. Как говорится админы сайтов деляться на две категории, на тех кто бэкапы не делает, и на тех кто ТЕПЕРЬ УЖЕ делает бэкапы.
Зануда перфекционист, не признающий авторитетов, ищет легкую работу за большие деньги - http://dtkp.ru/ s@dtkp.ru
*

Etegro

  • Новичок
  • 3
  • 0 / 0
Re: Пропала таблица из БД
« Ответ #4 : 04.08.2012, 15:41:57 »
Спасибо за совет. Сам когда-то использовал Sypex Dumper для переноса БД.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Пропала постраничная навигация с главной страницы

Автор Омск

Ответов: 3
Просмотров: 1316
Последний ответ 25.03.2016, 09:19:45
от Омск
В модуле поиска пропала кнопка "Поиск"

Автор mnogoto4ka

Ответов: 3
Просмотров: 1562
Последний ответ 04.03.2015, 12:16:24
от DiabloZet
Пропала админка сайта

Автор Lirik

Ответов: 3
Просмотров: 1123
Последний ответ 02.03.2014, 15:11:05
от Lirik
После смены хостинга пропала админка. Происходит редиректит с administator на /installation/index.ph

Автор Andrei-M

Ответов: 7
Просмотров: 1815
Последний ответ 13.12.2012, 16:16:35
от Andrei-M
таблица базы данных *_session

Автор linkin

Ответов: 4
Просмотров: 2333
Последний ответ 19.11.2012, 22:57:33
от microsmaster