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

salesekspert

  • Осваиваюсь на форуме
  • 13
  • 5 / 0
  • Очень полезно пообщаться с экспертами
Прошу помочь, так, как столкнулся с проблемой шире моих знаний и опыта.
Обновил Joomla! 3.10.12 Stable   до  Joomla! 4.3.2 Stable [ Bora ] 30-May-2023
Получил ошибки

Цитировать
Table 'gazaryan_fin.kczy9_finder_tokens' doesn't exist
Table 'gazaryan_fin.kczy9_finder_tokens_aggregate' doesn't exist
×
Предупреждение
Найдены устаревшие таблицы базы данных.
Кнопка  Исправить базу данных не приводит в порядок, к снятию уведомлений об ошибках.

При наведении на красный знак
Цитировать
1 проблема
  подсвечивается подробный список ошибок как я понимаю.

Привожу скрины с описанием ошибок.

1. Скрин админ панели


2. Скрин ошибок целиком


3. Привожу Скрин ошибок в текстовом формате

Цитировать
1 проблема
•   Таблица kczyQjnder.tokens1 содержит некорректный тип или атрибуты для столбца 'language' типа CHAR(7) (из файла 4.0.0-2018-G7-29.sql}.
•   Таблица lkczy9_finder_tokerisl содержит некорректный тип или атрибуты для столбца term' типа varchar(75) (из файла 4.0.0-2018-07-29.sql).
•   Таблица ,kczy9_finder_tokerisl содержит некорректный тип или атрибуты для столбца stem' типа varchar(75) (из файла 4.0.0-2018-07-29.sql).
•   Таблица 'kczySjoderJokens' не содержит индекса 'idx.stem' (из файла 4.0.0-2018-07-29.sqI}.
•   Таблица kczyQjnder.tokens1 не содержит индекса 'idxjanguage' (из файла 4.0.0-2018*07-29.sql).
•   Таблица kczy9Jnder.tokens.aggregate1 не должна содержать столбец map_suffix' (из файла 4.0.0-2018-07-29sql).
•   Таблица ,kczy9_finder_tokens_aggregateJ содержит некорректный тип или атрибуты для столбца language1 типа CHAR(7) (из файла 4.0,0-2018-07-29.sql).
•   Таблица 'kczy9_finder_tokens_aggregateJ содержит некорректный тип или атрибуты для столбца term1 типа varchar(75) (из файла 4.0.0-2018-07-29.sql).
•   Таблица kczy9_nnder_tokens_aggregateJ содержит некорректный тип или атрибуты для столбца stem" типа varchar(75) (из файла 4.0.0-2018-07-29.sql).
Таблица kczy9_finder_tokens_aggregateJ содержит некорректный тип или атрибуты для столбца term_weighif типа float unsigned (из файла 4.0.0-2018-07-29.sql).
•   Таблица kczy9_finder_tokens_aggregate' содержит некорректный тип или атрибуты для столбца context_weight'типа float unsigned (из файла 4.0.0-2018-07-29.sql).
Таблица kczy9_finder_tokens_aggregate' содержит некорректный тип или атрибуты для столбца totaLweight" типа float unsigned (из файла 4.0.0-2018-07-29.sql).
•   160 изменений базы данных проверены.
•   376 изменений базы данных не изменили структуру таблиц и были пропущены.
__________________________________________________________________

Я никогда не редактировал базы поэтому не знаю что читать и изучать дальше, чтобы сделать следущий шаг.
Прошу вас поделиться идеями куда смотреть, копать и чинить)
« Последнее редактирование: 01.06.2025, 12:03:13 от salesekspert »
*

azm1n

  • Захожу иногда
  • 102
  • 16 / 0
Привет, com_finder — это компонент умный поиск, зайди туда, посмотри что там, удали индекс, обнови вдруг что индекс слов. В общем направление — туда копать.
*

azm1n

  • Захожу иногда
  • 102
  • 16 / 0
Можешь еще зайти в базу данных, через phpMyAdmin, найти таблицу finder, там не одна таблица, и почистить ее содержимое, то есть не уладить таблицу, а почистить ее содержимое. Важно, сделать резервную копию сайта на всякий случай.
*

azm1n

  • Захожу иногда
  • 102
  • 16 / 0
Почисть содержимое вот этих таблиц kczy9_finder_tokens_aggregate и kczy9_finder_tokens, и не забудьте сделать резервную копию сайта, а точнее, базы данных.
*

salesekspert

  • Осваиваюсь на форуме
  • 13
  • 5 / 0
  • Очень полезно пообщаться с экспертами
Спасибо за отклик azm1n, сделаю и поделюсь результатами.
*

sivers

  • Живу я здесь
  • 2578
  • 357 / 0
Почисть содержимое вот этих таблиц kczy9_finder_tokens_aggregate и kczy9_finder_tokens, и не забудьте сделать резервную копию сайта, а точнее, базы данных.
Судя по сообщению, этих таблиц в базе нет. Их не чистить надо, а создать. Взять можно из другой Joomla (той же версии) или установить куда-нибудь новую и взять с нее. Брать надо только структуру таблиц (команда CREATE) без переноса данных, если они имеются у донора.
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

azm1n

  • Захожу иногда
  • 102
  • 16 / 0
У меня Joomla 4, и у меня эти таблицы пустые, я умный поиск не использую, а возможно вы и правы, автору смотреть и решать что делать.
*

azm1n

  • Захожу иногда
  • 102
  • 16 / 0
А что будет, если Joomla обновить до версии Joomla! 4.4.13, это последний релиз Joomla 4, может таблицы создадутся, в общем как вариант, а возможно и нет, я не знаю, так предположения.
« Последнее редактирование: 01.06.2025, 14:55:01 от azm1n »
*

salesekspert

  • Осваиваюсь на форуме
  • 13
  • 5 / 0
  • Очень полезно пообщаться с экспертами
Спасибо за отклик sivers , уточните, пожалуйста, где почитать или видео посмотреть про аналогичную  процедуру копирования структуры таблиц?
Я с базой не сталкивался кроме импорта и экспорта Damp файла, поэтому боюсь творить без примера)
*

salesekspert

  • Осваиваюсь на форуме
  • 13
  • 5 / 0
  • Очень полезно пообщаться с экспертами
Цитировать
А что будет, если Joomla обновить до версии Joomla! 4.4.13, это последний релиз Joomla 4, может таблицы создадутся, в общем как вариант, а возможно и нет, я не знаю, так предположения.


azm1n[/url], я пробовал, но  не активна кнопка обновления, видимо, из-за 

1 проблема

где подсвечивается подробный список ошибок.
« Последнее редактирование: 01.06.2025, 20:04:28 от salesekspert »
*

sivers

  • Живу я здесь
  • 2578
  • 357 / 0
Спасибо за отклик sivers , уточните, пожалуйста, где почитать или видео посмотреть про аналогичную  процедуру копирования структуры таблиц?
Я с базой не сталкивался кроме импорта и экспорта Damp файла, поэтому боюсь творить без примера)
Зайдите в вашу БД (из панели хостинга, либо скачайте скрипт adminer.php с одноименного сайта). На сайте-доноре сделайте экспорт необходимых таблиц, выбрав только "структура" без данных. На своем сайте сделайте импорт полученного файла. Предварительно сохраните оба сайта в копию на всякий случай.
Либо закажите платную услугу у местных умельцев, если в себе не очень уверены.
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

azm1n

  • Захожу иногда
  • 102
  • 16 / 0
Слушайте, так а в другой Joomla будет префикс таблиц другой, ему еще и префикс таблиц менять придется, или нет?
*

sivers

  • Живу я здесь
  • 2578
  • 357 / 0
ему еще и префикс таблиц менять придется, или нет?
Да, придется.
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

salesekspert

  • Осваиваюсь на форуме
  • 13
  • 5 / 0
  • Очень полезно пообщаться с экспертами
Друзья Спасибо всем за отклик и отдельные советы.
Я оценил необходимые навыки для поддержания сайта Joomla в актуальном состоянии.
И кажется что мне предстоит учиться и учиться.
Проблема ограничивалась не только ошибками с базами данных.
Видимо из-за неудаления компонента  jshopping перед обновлением Joomla 3.10, возникла ещё проблема с этим компонентом  jshopping.



Как я не пробовал его удалять не получается.
Как я не пробовал его искать в папках и файлах сайта он не находится.
Сделал даже видео обзор этого процесса охоты на  jshopping.
https://rutube.ru/video/b9fed87c80b6681af76427e0a70977a6/

Слава Богу сайт о котором идёт речь он небольшой, только начал создаваться материалов там было всего 15
Поэтому  ошибки с базами данных и ошибки неудачного удаления компонента  jshopping я решил переносом всех материалов сайта на новый Joomla 5.3.1.

Может быть в будущем я столкнусь с аналогичной сложностью.
Если есть аналогичный опыт, как удалить этот компонент поделитесь.





« Последнее редактирование: 03.06.2025, 16:16:21 от salesekspert »
*

azm1n

  • Захожу иногда
  • 102
  • 16 / 0
Абсолютно правильное решение, что перенесли свой сайт на новую Joomla, если сайт молодой и небольшой это правильное решение. По поводу jshopping не знаю нечего, удачи, успехов!
*

azm1n

  • Захожу иногда
  • 102
  • 16 / 0
Если структура url адресов сохранена, то будет все в порядке, если нет, нужно будет сделать 301 редирект, или ждать полной переиндексации сайта.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Таблица в колонку при отображении на сотовом

Автор antipod

Ответов: 6
Просмотров: 1263
Последний ответ 02.07.2024, 12:37:05
от SK
Некорректный MimeType

Автор ivano183

Ответов: 5
Просмотров: 890
Последний ответ 14.05.2024, 20:21:08
от sivers
Адаптивная таблица в материале

Автор phvsfpgs

Ответов: 3
Просмотров: 953
Последний ответ 18.09.2023, 00:58:25
от phvsfpgs
Таблица finder_links

Автор slalexpost

Ответов: 1
Просмотров: 905
Последний ответ 22.05.2023, 11:17:15
от b2z
Некорректный вывод блога

Автор valexi1980

Ответов: 5
Просмотров: 615
Последний ответ 06.11.2021, 09:53:31
от draff