Новости Joomla

Свои типы полей в 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 для атрибута addfieldprefixnamespace 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 #разработка

Обновлена информация в Плане развития Joomla

👩‍💻 Обновлена информация в Плане развития Joomla.Здесь собрана информация о датах релизов, описаны принципы версионирования, указаны ответственные за релизы, а так же даты окончания поддержки релизов. Опираясь на эту информацию вы можете планировать развитие ваших интернет-проектов.👩‍💻 Что нового?⛔️ Joomla 4.Дата окончания исправления ошибок безопасности в версии 4.x - 14 октября 2025г. ⚠️ После этой даты Joomla 4 прекратит получать какие-либо обновления, в том числе безопасности - вообще. Рекомендуем обновить ваши сайты до актуальной Joomla 5.✅ Joomla 5.- Дата окончания исправления ошибок в версии 5.x - 13 октября 2026г.- Дата окончания исправления ошибок безопасности в версии 5.x - 12 октября 2027 года.- Текущая актуальная (на момент написания заметки) версия - 5.3.1.- Опубликовано расписание выхода релизов Joomla 5.4. Стабильный релиз ожидается 14 октября 2025 года.✅ Joomla 6.- Дата окончания исправления ошибок в версии 6.x - 17 октября 2028г.- Дата окончания исправления ошибок безопасности в версии 6.x - 16 октября 2029г.- Опубликовано расписание выхода релизов Joomla 6.0. Стабильный релиз ожидается 14 октября 2025 года.- Для разработчиков уже доступна Joomla 6.0.0-alpha1.✅ Joomla! Framework.Обновлена информация о Joomla! Framework - полноценном PHP-фреймворке для разработки. Он в версиях 1.х и 2.х был самостоятельным параллельным проектом, однако начиная с версии Joomla 4.0 стал её основой. Добавлена информация о Joomla! Framework 3.x, который вышел 6 октября 2023 года. Его можно использовать в тех случаях, когда вам в проекте не нужна CMS Joomla целиком.Подробнее на сайте Joomla-сообщества Joomlaportal.ru#joomla #community

Компания JetBrains рассказала о своей поддержке Joomla

Компания JetBrains рассказала о своей поддержке Joomla

JetBrains - один из мировых лидеров в разработке программного обеспечения для разработчиков. Её программные продукты - это IDE - профессиональные среды разработки, которые отличаются от простого блокнота/редактора с плагинами набором всевозможных инструментов для разработчиков, глубоким анализом кодовой базы, подсказками по ней и по языку программирования, отладкой ошибок и многим-многим другим. Одним из самых известных продуктов компании является IDE PHP Storm, который можно назвать отраслевым стандартом PHP-разработчика.

В статье How PhpStorm Helps Maintain PHP Open-Source Projects: Interviews and Real-World Examples в блоге компании описываются Open Source проекты, которым JetBrains оказывает поддержку (это могут быть бесплатные лицензии для разработчиков для некоммерческих проектов).

В список попали:

  • PHPUnit - фреймворк для unit-тестирования в PHP
  • Doctrine DBAL - библиотека для PHP, которая предоставляет лёгкий и гибкий слой для коммуникации с базой данных. Она поддерживает различные базы данных через единый и согласованный API.
  • CodeIgniter — популярный MVC-фреймворк для разработки на PHP
  • Joomla! - наша любимая CMS.

Эти названия (кроме "Joomla") чаще всего не слышат вебмастера и разработчики обычных сайтов и интернет-магазинов. Но эти названия хорошо знакомы PHP-разработчикам, которые создают сложные и высоконагруженные проекты и микросервисы. То, что Joomla оказалась в одном ряду с такими программными инструментами - делает ей честь.

🙏 За ссылку спасибо участнику нашего сообщества Ринату Кажетову (@rkazhet).

Подпишитесь на @joomlafeed

0 Пользователей и 1 Гость просматривают эту тему.
  • 11 Ответов
  • 8318 Просмотров
*

Alex-heat-shot

  • Новичок
  • 7
  • 0 / 0
Здравствуйте! Таблица на сайте выходит за пределы блока, не могу понять в чем дело, помогите пожалуйста или скиньте ссылку где можно прочитать или скажите в чем проблему, вот ссылка на таблицу http://tverdyy-pereplet.ru/izgotovlenie-flaerov.html. Если не видно, нажмите на ctrl и покрутите колёсико на мышке.
*

Shustry

  • Гуру
  • 6434
  • 745 / 3
Жуть какая

Код: html4strict
<table class="MsoTableGrid" style="border-collapse: collapse; mso-table-layout-alt: fixed; border: none; mso-border-alt: double windowtext 1.5pt; mso-table-overlap: never; mso-yfti-tbllook: 1184; mso-table-lspace: 9.0pt; margin-left: 6.75pt; mso-table-rspace: 9.0pt; margin-right: 6.75pt; mso-table-anchor-vertical: paragraph; mso-table-anchor-horizontal: column; mso-table-left: center; mso-table-top: .05pt; mso-padding-alt: 0cm 5.4pt 0cm 5.4pt; mso-border-insideh: 1.5pt double windowtext; mso-border-insidev: 1.5pt double windowtext;" border="1" cellspacing="0" cellpadding="0" align="left">

Вот это всё нужно заменить на

Код: html4strict
<table class="MsoTableGrid">
*

Shustry

  • Гуру
  • 6434
  • 745 / 3
И далее по-содержимому, конечно, все атрибуты поудалять. Стили оформить в CSS.
*

Kasyanov

  • Захожу иногда
  • 123
  • 9 / 0
  • Всё будет хорошо)
Если убрать отступы по бокам таблицы (margin-left и margin-right) и слегка уменьшить внутренние padding (в td), то всё входит.

А вы её из Wordа вставляли?
*

Alex-heat-shot

  • Новичок
  • 7
  • 0 / 0
Если убрать отступы по бокам таблицы (margin-left и margin-right) и слегка уменьшить внутренние padding (в td), то всё входит.

А вы её из Wordа вставляли?
да, из word и с других своих сайтов, таблица не уменьшается при изменении размера контейнера, а просто выходит за блок.
*

Kasyanov

  • Захожу иногда
  • 123
  • 9 / 0
  • Всё будет хорошо)
Она не уменьшиться, потому что в ячейках стоят отступы, можно попробовать уменьшить шрифт.

А если по правильному, то из Wordа не надо вставлять. Word добавляет свои ненужные теги. Посмотрите на html-код - он должен быть раза в 4-5 корче.
Таблицы в HTML создавать не сложно.

Если что вот курс в помощь - http://kasyanov.info/page/free-html/
*

Alex-heat-shot

  • Новичок
  • 7
  • 0 / 0
И далее по-содержимому, конечно, все атрибуты поудалять. Стили оформить в CSS.
всё равно выходит, убрал все стили, на планшете с маленьким экраном она выходит за борт, это можно увидеть на компьютере нажав контрл и колёсико крутануть. Вот код
Код
<div align="center">
<table class="MsoTableGrid">
<tbody>
<tr>
<td>
<p><strong><span>50шт</span></strong>
</p>
</td>
<td>
<p><strong><span>100шт</span></strong>
</p>
</td>
<td>
<p><strong><span>200шт</span></strong>
</p>
</td>
<td>
<p><strong><span>300шт</span></strong>
</p>
</td>
<td>
<p><strong><span>Размер</span></strong>
</p>
</td>
<td>
<p><strong><span>500шт</span></strong>
</p>
</td>
<td>
<p><strong><span>1000шт</span></strong>
</p>
</td>
<td>
<p><strong><span>2000шт</span></strong>
</p>
</td>
<td>
<p><strong><span>5000шт</span></strong>
</p>
</td>
</tr>
<tr>
<td>
<p><span>305р</span>
</p>
</td>
<td>
<p><span>370р</span>
</p>
</td>
<td>
<p><span>685р</span>
</p>
</td>
<td>
<p><span>998р</span>
</p>
</td>
<td>
<p><strong><span>7*10см</span></strong>
</p>
</td>
<td>
<p><span>1,100р</span>
</p>
</td>
<td>
<p><span>2,115р</span>
</p>
</td>
<td>
<p><span>4,105р</span>
</p>
</td>
<td>
<p><span>10,080р</span>
</p>
</td>
</tr>
<tr>
<td>
<p><span>365р</span>
</p>
</td>
<td>
<p><span>545р</span>
</p>
</td>
<td>
<p><span>725р</span>
</p>
</td>
<td>
<p><span>1,100р</span>
</p>
</td>
<td>
<p><strong><span>5*15см</span></strong>
</p>
</td>
<td>
<p><span>1,205р</span>
</p>
</td>
<td>
<p><span>2,235р</span>
</p>
</td>
<td>
<p><span>4,350р</span>
</p>
</td>
<td>
<p><span>10,265р</span>
</p>
</td>
</tr>
<tr>
<td>
<p><span>485р</span>
</p>
</td>
<td>
<p><span>665р</span>
</p>
</td>
<td>
<p><span>1,100р</span>
</p>
</td>
<td>
<p><span>1,630р</span>
</p>
</td>
<td>
<p><strong><span>7*15см</span></strong>
</p>
</td>
<td>
<p><span>1,840р</span>
</p>
</td>
<td>
<p><span>3,325р</span>
</p>
</td>
<td>
<p><span>6,520р</span>
</p>
</td>
<td>
<p><span>15,905р</span>
</p>
</td>
</tr>
<tr>
<td>
<p><span>615р</span>
</p>
</td>
<td>
<p><span>790р</span>
</p>
</td>
<td>
<p><span>1,570р</span>
</p>
</td>
<td>
<p><span>2,365р</span>
</p>
</td>
<td>
<p><strong><span>10*15см</span></strong>
</p>
</td>
<td>
<p><span>3,625р</span>
</p>
</td>
<td>
<p><span>5,985р</span>
</p>
</td>
<td>
<p><span>8,695р</span>
</p>
</td>
<td>
<p><span>19,925р</span>
</p>
</td>
</tr>
<tr>
<td>
<p><span>605р</span>
</p>
</td>
<td>
<p><span>735р</span>
</p>
</td>
<td>
<p><span>1,530р</span>
</p>
</td>
<td>
<p><span>2,265р</span>
</p>
</td>
<td>
<p><strong><span>7*20см</span></strong>
</p>
</td>
<td>
<p><span>3,500р</span>
</p>
</td>
<td>
<p><span>5,860р</span>
</p>
</td>
<td>
<p><span>8,575р</span>
</p>
</td>
<td>
<p><span>19,805р</span>
</p>
</td>
</tr>
<tr>
<td>
<p><span>910р</span>
</p>
</td>
<td>
<p><span>1,155р</span>
</p>
</td>
<td>
<p><span>2,295р</span>
</p>
</td>
<td>
<p><span>3,280р</span>
</p>
</td>
<td>
<p><strong><span>10*20см</span></strong>
</p>
</td>
<td>
<p><span>4,470р</span>
</p>
</td>
<td>
<p><span>6,885р</span>
</p>
</td>
<td>
<p><span>12,075р</span>
</p>
</td>
<td>
<p><span>27,170р</span>
</p>
</td>
</tr>
<tr>
<td>
<p><span>1030р</span>
</p>
</td>
<td>
<p><span>1,570р</span>
</p>
</td>
<td>
<p><span>2,965р</span>
</p>
</td>
<td>
<p><span>4,440р</span>
</p>
</td>
<td>
<p><strong><span>15*20см</span></strong>
</p>
</td>
<td>
<p><span>5,985р</span>
</p>
</td>
<td>
<p><span>8,695р</span>
</p>
</td>
<td>
<p><span>16,905р</span>
</p>
</td>
<td>
<p><span>37,435р</span>
</p>
</td>
</tr>
</tbody>
</table>
</div>
, Это дело в шаблоне, на других моих сайтах эта таблица не выходит за пределы контейнера
*

Shustry

  • Гуру
  • 6434
  • 745 / 3
Сейчас же всё прекрасно входит. Пропишите вот так <table class="MsoTableGrid" width="100%">
*

Alex-heat-shot

  • Новичок
  • 7
  • 0 / 0
Ничего не получается, таблицы всё равно выходят за предел блока, как сделать так, что бы они уменьшали в размере подстраиваясь под блок?
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
ТС, минус таблиц в том, что они всегда имеют при определенном контенте минимальную ширину, меньше которой сделать не получится, зато можно обернуть таблицу в блок с горизонтальной прокруткой, это в настоящий момент самое распространенное решение вашей проблемы
*

Alex-heat-shot

  • Новичок
  • 7
  • 0 / 0
спасибо! Ещё можно в виде картинки её выложить ^-^
*

fsv

  • Живу я здесь
  • 2781
  • 410 / 2
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться