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

GuDeVic

  • Захожу иногда
  • 228
  • 0 / 0
Здравствуйте!
В примере:
Код
 <a onclick="MyPrint1();" href="#">TestPrint</a>
<br />
<h1>Big Company</h1>
<div id="NDA1" class="page-break-after">
<h3>NDA #1</h3>
<p>This project is top secret. You are the only one in the world to ever know about this project (outside of yours truly).</p>
<p>&nbsp;</p>
</div>
<div id="NDA2" class="page-break-after">
<h3>NDA #2</h3>
<p>This project is top secret but not as secret as NDA #1. You will like this proejct though...it includes visits to farms.</p>
</div>
<button id="btnPrint" class="no-print btn btn-primary">Print</button>
CSS:
Код
@media print {
  .no-print, .no-print *
  {
    display: none !important;
  }
  div.page-break-after {
    display: block !important;
    page-break-after: always;
    padding: 15px;
    border: 1px solid #ccc;
  }
}
При нажатии на кнопку Print блоки <div id="NDA1"> и <div id="NDA2"> выводятся на печать на разных страницах.
Но это пример.
А при печати по ссылке TestPrint 
Код
<script type="text/javascript">
function MyPrint1(){       
var printText1 = document.getElementById('NDA1').innerHTML;
var printText2= document.getElementById('NDA2').innerHTML;
var windowPrint = window.open('','','left=30,top=0,width=800,height=640,toolbar=0,scrollbars=1,status=0');
windowPrint.document.write(printText1);
windowPrint.document.write(printText2);
windowPrint.document.close();
windowPrint.focus();
windowPrint.print();
windowPrint.close();
}
</script>
разбиение на страницы не происходит.
Что я делаю не так?
*

sivers

  • Живу я здесь
  • 2581
  • 358 / 0
Что я делаю не так?
Скорее всего забываете подключить css-блок из примера (который содержит @media print) в том новом окне, которое по клику открывается.
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

GuDeVic

  • Захожу иногда
  • 228
  • 0 / 0
Скорее всего забываете подключить css-блок из примера (который содержит @media print) в том новом окне, которое по клику открывается.
Так и кнопка Print, и ссылка TestPrint находятся на одной странице и обращаются к одним и тем же блокам. Разве @media print для них разный?
*

sivers

  • Живу я здесь
  • 2581
  • 358 / 0
innerHTML берет только теги, вложенные внутрь блока - без тега верхнего уровня, к которому применен innerHTML, но именно на нем прописаны классы, к котоым в CSS привязан разрыв страницы.
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

GuDeVic

  • Захожу иногда
  • 228
  • 0 / 0
innerHTML берет только теги, вложенные внутрь блока - без тега верхнего уровня, к которому применен innerHTML, но именно на нем прописаны классы, к котоым в CSS привязан разрыв страницы.
Большое спасибо!
*

sivers

  • Живу я здесь
  • 2581
  • 358 / 0
на здоровье
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

One Page Checkout

Автор Georgy4536

Ответов: 2
Просмотров: 698
Последний ответ 23.10.2022, 23:45:28
от gartes
Вывод картинки, находящейся внутри нескольких блоков, на всю ширину экрана

Автор GuDeVic

Ответов: 10
Просмотров: 816
Последний ответ 26.05.2022, 17:42:59
от marksetter
Просмотр документов на сайте

Автор riba

Ответов: 4
Просмотров: 947
Последний ответ 06.10.2021, 14:40:18
от khan-alex
Расширениет для вставки документов в материал

Автор mak200

Ответов: 1
Просмотров: 646
Последний ответ 02.08.2021, 03:43:18
от pavelrer
Что за странный адресс появляется при проверке Page speed

Автор polezniy

Ответов: 0
Просмотров: 557
Последний ответ 06.07.2021, 02:26:14
от polezniy