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

Azizkz

  • Осваиваюсь на форуме
  • 15
  • 0 / 0
Всем привет! Есть сайта на Joomla 2.5 + k2 на сайте имеется почти 60 000 тыс материалов
в начальном этапе создания сайта были выключены все не нужные плагины, был включен стандартный кэш сайта + плагин кэш все оптимизаций каторые были найдены на форумах было сделано.
на сайта кэщ стоит на 5 мин материалы на сайт добавляются очень часто ....  посещаемость очень большая! недели 3 назад началось глюк при обновление кэша к базе идут очень много запросов такого характера
Copying to tmp table   SELECT DISTINCT
               cats.name AS cat_name,
               cat...
их может быть до 60 запрос за раз. хотя я и не использую стандартные категории и материалы Joomla все материалы на к2
так вот при таком потоке запросов сайт начинает виснуть... в админ панеле не возможно работать... стр сайта открывается по 30 секунд
раньше такого не было! на сервере устанавливали оптимизации кэширование MySQL ставили не помогает... может кто сталкивался с такими запросами? Спасибо!
характеристики сервера

SuperServer 6017R-M7RF (Black)• 1U Rackmount (43 x 437 x 503mm)• 2 x Six-Core Intel® Xeon™ Sandy Bridge E5-2640 2.5GHz, 15Mb Cashe, 7.2 GT/s LGA2011• Intel® C602J chipset• 24Gb DDR3-1333 Reg ECC/ 8 x 240-pin DDR3 DIMM sockets Supports up to 256 GB DDR3 ECC Registered memory (RDIMM)Supports up to 64 GB DDR3 ECC/non-ECC Un-Buffered memory (UDIMM) 1600/1333/1066/800MHz ECC DDR3 SDRAM 72-bit, 240-pin gold-plated DIMMs• SAS2 (6Gb/s) via LSI 2208 HW RAID 0, 1, 10 support Supports up to 16 devices; 8 x SAS ports• Intel® C602J chipset, 4 x SATA 2.0 3Gb/s with RAID 0, 1, 5, 10; 2 x SATA 3.0 6Gb/s with RAID 0, 1, 10• Supermicro LAN AOC-CGP-i2 - MicroLP 2-port GbE card based on Intel i350• Intel® i210 Dual port Gigabit Ethernet• 1 x PCI-E 3.0 x8 FHHL Expansion slot• 4 x 1Tb SATA-III 7200 RPM 64Mb Cache / 4 x 3.5" Hot-swap SAS/SATAII Drive Trays with SES2• Integrated IPMI 2.0 with KVM and Dedicated LAN • DVD-RW SATA Slim drive• 400W Redundant Power Supplies Gold Level Certified• 5 x 4cm 17,500 RPM PWM fans
30

Кстати пробовал отключать все модули на сайте + еще в общих настройках сайта выберал параметры выкл сайт все равно идут куча запросов!
На серваке только 1 сайт сервер собственный!
*

thehunter

  • Осваиваюсь на форуме
  • 13
  • 0 / 0
Если собственный сервер то для начала размести tmp для MySQL таблиц в памяти tempfs (dev/shm).
*

Azizkz

  • Осваиваюсь на форуме
  • 15
  • 0 / 0
Если собственный сервер то для начала размести tmp для MySQL таблиц в памяти tempfs (dev/shm).
На время помогло. Ща заного идут запросы....
16360   root   localhost:59073   24kzdbnew   Query   1   Copying to tmp table   SELECT DISTINCT
               cats.name AS cat_name,
               cat...
Завершить   16368   root   localhost:59089   24kzdbnew   Query   1   Copying to tmp table   SELECT DISTINCT
               cats.name AS cat_name,
               cat...
Завершить   16371   root   localhost:59095   24kzdbnew   Query   1   Copying to tmp table   SELECT DISTINCT
               cats.name AS cat_name,
               cat...
Завершить   16393   root   localhost:59142   24kzdbnew   Query   0   Copying to tmp table   SELECT DISTINCT
               cats.name AS cat_name,
               cat...
Завершить   16413   root   localhost:59187   24kzdbnew   Query   2   Copying to tmp table   SELECT DISTINCT
               cats.name AS cat_name,
               cat...
Завершить   16427   root   localhost:59217   24kzdbnew   Query   1   Copying to tmp table   SELECT DISTINCT
               cats.name AS cat_name,
               cat...
Завершить   16432   root   localhost:59227   24kzdbnew   Query   1   Sending data   SELECT i.*,c.name AS categoryname,c.id AS category...
Завершить   16443   root   localhost:59251   24kzdbnew   Query   1   Sending data   SELECT i.*,c.name AS categoryname,c.id AS category...
Завершить   16447   root   localhost:59260   24kzdbnew   Query   1   Copying to tmp table   SELECT DISTINCT
               cats.name AS cat_name,
               cat...
Завершить   16449   root   localhost:59268   24kzdbnew   Query   1   Sending data   SELECT i.*,c.name AS categoryname,c.id AS category...
Завершить   16450   root   localhost:59269   24kzdbnew   Query   1   Sending data   SELECT i.*,c.name AS categoryname,c.id AS category...
Завершить   16452   root   localhost:59272   24kzdbnew   Query   2   Sending data   SELECT i.*,c.name AS categoryname,c.id AS category...
Завершить   16453   root   localhost:59275   24kzdbnew   Sleep   1       NULL
Завершить   16455   root   localhost:59278   24kzdbnew   Sleep   1       NULL
Завершить   16456   root   localhost:59281   24kzdbnew   Query   1   Sending data   SELECT i.*,c.name AS categoryname,c.id AS category...
Завершить   16458   root   localhost:59284   24kzdbnew   Query   1   Sending data   SELECT i.*,c.name AS categoryname,c.id AS category...
Завершить   16459   root   localhost:59286   24kzdbnew   Query   1   Sending data   SELECT i.*,c.name AS categoryname,c.id AS category...
Завершить   16464   root   localhost:59297   24kzdbnew   Query   1   Sending data   SELECT i.*,c.name AS categoryname,c.id AS category...
Завершить   16466   root   localhost:59303   24kzdbnew   Query   1   Sending data   SELECT i.*,c.name AS categoryname,c.id AS category...
Завершить   16470   root   localhost:59313   24kzdbnew   Query   1   Sending data   SELECT i.*,c.name AS categoryname,c.id AS category...
Завершить   16487   root   localhost:59353   24kzdbnew   Query   1   Sending data   SELECT i.*,c.name AS categoryname,c.id AS category...
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Автоматическое сжатие фото при загрузке на сайт

Автор Amerikana

Ответов: 13
Просмотров: 4535
Последний ответ 30.06.2022, 11:52:23
от Nikita2705
Мультиязычность. При включении плагина "система - фильтр языков" сайт падает

Автор yuraok

Ответов: 10
Просмотров: 6251
Последний ответ 25.06.2022, 14:23:49
от ecolora
Сайт на Joomla 2.5.28 долго грузится - 1-2 минуты

Автор DanPel

Ответов: 5
Просмотров: 2152
Последний ответ 22.01.2020, 11:15:34
от SeBun
Неправильно открывается сайт

Автор totalcolor

Ответов: 4
Просмотров: 1471
Последний ответ 20.04.2019, 12:54:20
от draff
Прыгает/дергается/скачет сайт при внутренних переходах

Автор vegastk

Ответов: 7
Просмотров: 3512
Последний ответ 16.06.2018, 13:07:49
от voras