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

nicrurin

  • Новичок
  • 1
  • 0 / 0
Здравствуйте.
Движок Joomla! 3.9.13 локализация русская 3.9.12.1 (2019-10-10) от Проект Joomla!.
Проблема, где бы я не написал заглавную букву "И" в публичной части она отображается восклицательным знаком. При этом в админке полностью очищается поле где она стояла не зависимо что это, название или поле для текста или еще что нибудь. И главное, это только с одной буквой. Все остальные руссуие буквы отображаются без проблем.
*

ProtectYourSite

  • Живу я здесь
  • 2364
  • 137 / 4
  • Безопасность вебсайтов
С кодировкой MySQL проблемы, поищите, это и на этом форуме обсуждалось.
Можно попробовать запустить исправление бд от Joomla.
*

ProtectYourSite

  • Живу я здесь
  • 2364
  • 137 / 4
  • Безопасность вебсайтов
Кодировка таблиц utfmb4 ??
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
А может просто "интересный" шрифт, в котором нет заглавной И (встречал вроде кириллические но без Ы и без Ё и без Ж халтурные шрифты)
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

Шмайсер

  • Давно я тут
  • 801
  • 35 / 3
Шрифт, не поддерживаемый в Кириллице, хоть utf-8 пиши хоть что...
Разработка сайтов любой сложности, на Joomla 3.9-4.x и не только на ней. Пишу компоненты, модули и плагины на заказ. Переношу сайты с ветки 2.5.х на 4-ю версию Joomla. Пишу любые скрипты и интерфейсы.
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Шрифт, не поддерживаемый в Кириллице, хоть utf-8 пиши хоть что...
Встречал подобный шрифт, клиент очень хотел именно его, там не было буквы Ы. Скачал редактор, нарисовал эту Ы из мягкого знака и палки, 30 минут времени на поиск редактора шрифтов, создание и компиляцию обратно - для чайника (у меня это был первый опыт) не вижу никаких проблем
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

yurikfirst

  • Осваиваюсь на форуме
  • 13
  • 0 / 0
  • Ты не одинок во вселенной
 - Joomla! 3.9.19 -
Аналогичная ситуация, буква "И" большая прописывается как - "? ?" Шрифт обычный - times new roman, обновлено всё до последнего
Не нашел, как изменить - Кодировку соединения базы данных не совпадает с кодировкой БД.
При сохранении, когда используется отдельная заглавная буква "И", в админской части редактирования страницы оказывается пусто, при сохранении. Но на сайте публикуется. Какая то джумловская магия)))
Кто подскажет, как это лечится??
Спасибо

Данные о системе



и что показывает

*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
А почему у вас кодировка соединения с БД в win1251? Должна же быть utf8_general_ci
Еще нужно посмотреть в какой кодировке сами таблицы в бд

Если в БД сохраните в таблице контента - будет корректно?
(не забываем про бекапы)
Попробуйте вот это сделать
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

draff

  • Гуру
  • 5801
  • 434 / 7
  • ищу работу
При сохранении, когда используется отдельная заглавная буква "И", в админской части редактирования страницы оказывается пусто, при сохранении.
Включить отображение ошибок в админке на уровень - для разработчиков и сохранить страницу ?
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Включить отображение ошибок в админке на уровень - для разработчиков и сохранить страницу ?
Это проблема не на уровне PHP, что-то именно с кодировкой БД, ну не должна быть там win1251 (подобная ерунда была в век Joomla 1.0 и всяких Лавра эдишн лет 13 назад), соответственно ошибки сервера ничего не покажут
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

SeBun

  • BanMaster
  • 4030
  • 259 / 5
  • @SeBun48
Кто подскажет, как это лечится??
Сделайте дамп базы. Посмотрите, в какой кодировке получился файл. Должен быть в кодировке UTF-8 без BOM. Далее проверьте в самом файле, какая кодировка задается таблицам в функции Create. Если задается отличная от UTF-8, правим по всему файлу дампа. Далее идем в phpMyAdmin, полностью очищаем базу. Идем в настройки (скрин @beliyadm выше выложил), меняем кодировку базы на utf8mb4_unicode_ci и заливаем дамп. Проверяем в configuration.php, что стоит драйвер mysqli (dbtype = 'mysqli'). Проверить в .htaccess значение "AddDefaultCharset UTF-8" - если нет такой строки, можно добавить, если есть но вместо UTF-8 что то другое - исправить. Пробуем запуститься.
« Последнее редактирование: 15.06.2020, 22:44:07 от SeBun »
Оказываю услуги по Joomla | Миграция/Обновление | Сопровождение | IT-аутсорсинг | Недорогие домены и хостинг
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Все правильно и подробно.
Но вот это никак не влияет, если при сохранении в базу идёт сбой или при выводе из базы другая кодировка (а на его скрине так и есть, база в утф а соединение в 1251, что за сервер такой самодельный)
Проверить в .htaccess значение "AddDefaultCharset UTF-8" - если нет такой строки, можно добавить, если есть но вместо UTF-8 что то другое - исправить. Пробуем запуститься.
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

yurikfirst

  • Осваиваюсь на форуме
  • 13
  • 0 / 0
  • Ты не одинок во вселенной
Что вообще происходит?? Все JavaScript включены, он их требует включить, еще отправляю, такое сообщение



Админ, сделай, что нибудь, а то жесть, не возможно ответить нажав на цитату..это лес какой то
*

yurikfirst

  • Осваиваюсь на форуме
  • 13
  • 0 / 0
  • Ты не одинок во вселенной
Спасибо, что отозвались

Такие же кодировки в БД - utf8mb4_unicode_ci

Что до - AddDefaultCharset UTF-8 - это вообще, чуть ли не школьник знает

А что в самой таблице контент, где сама запись... там билебирда типа Шесть добрых

Я сам был удивлён, почему используется из каменного века win1251. Поэтому ищу, где это соединение поменять..

Вообще, на https://help.sweb.ru/entry/111/ стало понятно, может хостер грешит, так как перед импортом базы корректировал на utf8mb4_unicode_ci. но хостер то по привычке где-то тупит, и соединяет с cp1251_general_ci. Бардак.
« Последнее редактирование: 16.06.2020, 00:57:27 от yurikfirst »
*

arma

  • Завсегдатай
  • 1753
  • 81 / 3
Конечто хостер. И у меня было такое. Теребите хостера
*

yurikfirst

  • Осваиваюсь на форуме
  • 13
  • 0 / 0
  • Ты не одинок во вселенной
Короче, решил проблему. Правда теперь всё надо переводить каракули на нормальный язык
Просто в Система - Общие настройки - Сервер , тип базы данных был MySQL с PDO, поставил на MySQLi
После этого всё превратилось в ад, но страница сохраняется нормально.
Не делайте, как я)
*

SeBun

  • BanMaster
  • 4030
  • 259 / 5
  • @SeBun48
Я вам написал, как правильно сделать, и довольно подробно. Если бы вы сделали дамп и открыли его в Notepad++, там все было бы видно, в какой кодировке база и в какой кодировке сам дамп. После этого вам нужно было просто преобразовать дамп и залить назад, в базу, кодировку которой вы сменили. И все бы отлично загрузилось. Но вы пошли своим путем.

Все правильно и подробно.
Но вот это никак не влияет, если при сохранении в базу идёт сбой или при выводе из базы другая кодировка (а на его скрине так и есть, база в утф а соединение в 1251, что за сервер такой самодельный)
Не влияет, но часто встречаю, когда люди вставляют эту строку не понимая ее значения. Или даже сам шаблон в кодировке 1251, что тоже встречается. Поэтому на всякий случай дал и такую рекомендацию.
Оказываю услуги по Joomla | Миграция/Обновление | Сопровождение | IT-аутсорсинг | Недорогие домены и хостинг
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Не подставляется информация вместо констант

Автор hazyin

Ответов: 0
Просмотров: 1256
Последний ответ 18.11.2016, 15:25:57
от hazyin
Кракозябры вместо даты материалов после обновления языкового пакета

Автор vvp863

Ответов: 2
Просмотров: 1812
Последний ответ 22.05.2015, 07:37:11
от vvp863