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

hapson

  • Осваиваюсь на форуме
  • 44
  • 4 / 0
Искал решение, но ничего подобного не нашел.
Вот мой сайт Lanos-FAQ
Сейчас у меня имеется куча менюшек, поэтому итоговый адрес каждой статьи таков http://lanos-faq/статья
Статьи поделены на категории, но это деление лишь для моего удобства. По факту ни один пункт ни одного меню не привязан ни к одной категории. Все пункты всех меню привязаны исключительно к материалам.
Например к верхнему пункту меню "Ремонт" привязан материал на тему этого псевдо раздела, то есть о ремонте авто. На странице этого материала имеются подменю слева. Также имеются псевдо подразделы (по количеству меню слева). Например, на странице "Ремонт" имеется три меню: "Двигатель и его системы", "Ходовая и трансмиссия" и "Интерьер и экстерьер"
Для каждого псевдо подраздела есть своя менюшка со ссылками на материалы.
В админке это выглядит так:
Цитировать
Главная                                     (привязан 1 материал)
Ремонт                                      (привязан 1 материал)
/-Двигатель и его системы           (привязано много материалов)
/--Плавают обороты ХХ               (привязано много материалов)
/-Ходовая и трансмиссия            (привязано много материалов)
/-Интерьер и экстерьер               (привязано много материалов)
Доработки                                 (привязан 1 материал)
/-Двигатель и его системы         (привязано много материалов)
/-Электрика                             (привязано много материалов)
/-Интерьер и экстерьер              (привязано много материалов)
/--Проблемы с печкой                (привязано много материалов)
Главное меню состояит из одного уровня, впрочем как и все остальные.
По этой причине, как вы понимаете, нет явной структуры сайта. Посмотрите карту сайта (последняя кнопка верхнего меню) - там все понятно. Сколько блоков - столько у меня менюшек.
Что ж, красивые УРЛы типа сайт/материал - это хорошо, но есть ряд неудобств.
Во-первых, посетители не видят четкой структуры сайта
Во-вторых не работают хлебные крошки
В-третьих при переходе к материалу, кнопка верхнего меню становится не активна, что тоже весьма не гуд.
Ну и, наконец, все это становится очень запутано даже для меня.
Решил я изменить структуру сайта. А именно - сделать одно общее меню на весь сайт. А в 7 позиции выводить нужные куски меню с учетом вложенности. Пример тут http://joomlaforum.ru/index.php/topic,48469.0.html

Таким образом я получу наглядную HTML-карту сайта, работающие хлебные крошки и активный пункт верхнего меню при навигации.
Однако УРЛы станут такими http://lanos-faq.ru/ремонт/двигатель и его системы/замена термостата - это для примера.
Плохо ли это? Нужно ли изгаляться чтобы добиться прежних УРЛов? С редиректом я разобрался, могу без проблем переадресовать со старых алиасов на новые - не вопрос.

Можно ли как-то избавиться от промежуточных алиасов в адресной строке? Прошу учесть, что промежуточные алиасы - это ссылки на материалы.
То есть главная имеет свой материал
Ремонт имеет свой материал
Двигатель и его системы - пока это текстовый разделитель (потом будет материал)
Далее уже идут материалы

Это еще не реализовано - сейчас буду этим заниматься.

Может просто забить на это. Или длинные УРЛы это очень плохо?
« Последнее редактирование: 22.03.2013, 20:09:12 от hapson »
*

jouse

  • Захожу иногда
  • 131
  • 7 / 0
  • Не за что ^_^
Что то ты намудрил с менюшкой, нафига?)
Чем тебе не угодили подпункты меню?
Меню - Главная
Меню - Ремонт
Подменю - /-Двигатель и его системы вязано много материалов)
...
Меню - Доработки
Подменю - /-Двигатель и его системы
...
*

hapson

  • Осваиваюсь на форуме
  • 44
  • 4 / 0
Что то ты намудрил с менюшкой, нафига?)
Чем тебе не угодили подпункты меню?
Меню - Главная
Меню - Ремонт
Подменю - /-Двигатель и его системы вязано много материалов)
...
Меню - Доработки
Подменю - /-Двигатель и его системы
...
Тем что все эти меню не связаны друг с другом и нет явной структуры сайта.
Я буду делать одно меню на весь сайт

То есть:

Главная (статья)
Ремонт (статья)
/-Двигатель и его системы (текстовый разделитель)
/--статья 1
/--статья 2
/--статья 3
/-..........
/-Ходовая и трансмиссия (текстовый разделитель)
/--статья 1
/--статья 2
/--статья 3
Доработки (статья)
/-Двигатель и его системы (текстовый разделитель)
/--статья 1
/--статья 2
/--статья 3
/-..........
и так далее

На весь сайт одно меню, а выводить его части буду модулями с учетом уровней меню.
То есть на странице ремонт будет модуль главного меню, но только его 2-3 уровня.
*

hapson

  • Осваиваюсь на форуме
  • 44
  • 4 / 0
Сейчас у меня много менюшек и соответственно много модулей меню - мороки очень много и путаницы. К примеру, при добавлении статьи, на ее странице должны отображаться определенные 2(3,4...) модуля меню. Нужно пройтись по настройкам этих модулей и поставить галочку, чтобы они отобразились на странице новой статьи.
А если использовать одно большое меню, то для вывода на нужных страницах модуля с дочерними пунктами главного (единственного) меню, достаточно всего одного модуля и один раз настроить его отображение.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Как убрать из индекса Яндекса дубли?

Автор gonzyk263

Ответов: 3
Просмотров: 3812
Последний ответ 01.07.2024, 23:26:54
от Cleaning74
[FAQ] Как убрать <meta name="generator" content="Joomla! 2.5 - Open Source Content Management" />

Автор neket

Ответов: 56
Просмотров: 316117
Последний ответ 05.11.2020, 20:00:15
от Grigoriy82
Убрать название пункта меню из URL материала

Автор fortuner

Ответов: 15
Просмотров: 8749
Последний ответ 31.10.2020, 00:46:04
от spas
Как убрать < class="moduletable ">на лицевой части сайта?

Автор indes

Ответов: 11
Просмотров: 4184
Последний ответ 07.05.2020, 17:35:38
от beliyadm
[FAQ] Как убрать ID из ссылок?

Автор Leshiy

Ответов: 128
Просмотров: 84082
Последний ответ 12.04.2019, 19:19:55
от GURU