Новости Joomla

Вышел WT Quick links v.2.4.0 - релиз модуля для Joomla

Вышел WT Quick links v.2.4.0 - релиз модуля для Joomla.Это модуль-конструктор для быстрого создания набора элементов. Это могут быть ссылки на компоненты Joomla, пункт меню или пользовательская ссылка. Есть условия для исключений показа элементов списка. Вы можете создавать собственные макеты вывода модуля, создавая таким образом почти всё, что угодно: от простого списка ссылок до стены фотографий на главную страницу или ссылки-теги для перелинковки категорий интернет-магазина, список FAQ, табы или аккордеоны. Модуль позволяет выводить изображения, адаптивные изображения, видео, адаптивные видео.v.2.4.0. Что нового?Добавлена поддержка новых компонентов. Добавлены новые типы ссылок и исключений для них: - Phoca Download, - Phoca Gallery, - RadicalMart (@radicalmart).Joomla 6. Успешно протестирована работа модуля на Joomla 6-alpha2.РазработчикамПроведён большой рефакторинг кода. Для типов ссылок созданы классы-драйверы. Теперь для того, чтобы добавить новый тип ссылки в модуль достаточно скопировать класс-образец из
modules/mod_wt_quick_links/src/Driver/Collection и наполнить его данными по образцу, а так же добавить необходимые языковые константы в панели администратора Joomla.Модуль бесплатный. Страница расширенияGitHub расширенияJoomla Extensions Directory👩‍💻 Подпишись на @joomlafeed.#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

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

web3.0

  • Захожу иногда
  • 349
  • 6 / 6
Где хранятся данные доп. полей товаров в базе? Можно созданное поле в одном товаре как-то продублировать запросом по всем товарам?
*

web3.0

  • Захожу иногда
  • 349
  • 6 / 6
Обработать нужно одну таблицу jos_virtuemart_product_customfields. Проверено.

Пример запроса:
Код
INSERT INTO `jos_virtuemart_product_customfields` (`virtuemart_customfield_id`, `virtuemart_product_id`, `virtuemart_custom_id`, `customfield_value`, `customfield_price`, `disabler`, `override`, `noninheritable`, `customfield_params`, `product_sku`, `product_gtin`, `product_mpn`, `published`, `created_on`, `created_by`, `modified_on`, `modified_by`, `locked_on`, `locked_by`, `ordering`) VALUES (NULL, '1960', '31', '', '0.000000', '0', '0', '0', 'custom_size=\"10\"|custom_price_by_letter=\"0\"|', NULL, NULL, NULL, '0', '0000-00-00 00:00:00', '0', '2020-05-18 12:42:44', '42', '0000-00-00 00:00:00', '0', '3')

В запросах меняется значение одного поля virtuemart_product_id от 0 до 3000 (в примере 1960).

Как циклом сделать добавление строк?

*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Как циклом сделать добавление строк?
В мускуле есть циклы, доки в Google.
Но проще набросать скрипт на php - забирать данные из базы и в foreach делать нужный insert для нужного id
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

sivers

  • Живу я здесь
  • 2578
  • 357 / 0
Не циклом, а селектом:
Код
INSERT INTO `jos_virtuemart_product_customfields` (`virtuemart_customfield_id`, `virtuemart_product_id`, `virtuemart_custom_id`, `customfield_value`, `customfield_price`, `disabler`, `override`, `noninheritable`, `customfield_params`, `product_sku`, `product_gtin`, `product_mpn`, `published`, `created_on`, `created_by`, `modified_on`, `modified_by`, `locked_on`, `locked_by`, `ordering`)
SELECT NULL, `product_id`, '31', '', '0.000000', '0', '0', '0', 'custom_size=\"10\"|custom_price_by_letter=\"0\"|', NULL, NULL, NULL, '0', '0000-00-00 00:00:00', '0', '2020-05-18 12:42:44', '42', '0000-00-00 00:00:00', '0', '3'
FROM `таблица товаров`
где `таблица товаров` - имя таблицы товаров (сори, не помню как оно в ВМ называется),
а `product_id` - поле первичного ключа таблицы товаров (возможно, оно там зовется просто `id`)

Если нужно не во все товары - исключить их в селекте стандартным WHERE
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Не циклом, а селектом:
А если разные параметры для товаров нужно вставлять?
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

sivers

  • Живу я здесь
  • 2578
  • 357 / 0
А если разные параметры для товаров нужно вставлять?
ТС написал, что в запросе меняется только ИД товара.

Если надо менять еще какие-то параметры, то надо знать какие именно и от чего они зависят. Возможно, их можно вытянуть из той же таблицы товаров, как значение полей или результат вычисления. Да и другие таблицы привязать можно. Короче, если можно вытянуть все необходимые данные одним запросом, то получится. Если такой возможности нет, то предпочтительней использовать PHP.
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Логично, я когда писал на MSSql обходился курсорами (циклами)

Код
declare curr cursor for
(select objectid from table )
open curr

set @i=0
fetch next from curr into @id
while(@@fetch_status=0)
begin
exec zzUpdateGraduateResult @id
set @i=@i+1
print @i
fetch next from curr into @id
end
close curr
deallocate curr

Аналог циклов на PHP, в мускуле не очень силен, знаю что есть подобное, но не пользовался
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

web3.0

  • Захожу иногда
  • 349
  • 6 / 6
sivers, спасибо, вы мне сделали пятницу! Запрос рабочий, отработал корректно и быстро. Предполагал, что должно же быть простое решение.
*

sivers

  • Живу я здесь
  • 2578
  • 357 / 0
На здоровье )
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

sivers

  • Живу я здесь
  • 2578
  • 357 / 0
Аналог циклов на PHP, в мускуле не очень силен, знаю что есть подобное, но не пользовался
beliyadm, крутую вещь вы написали, но это слишком мудрено для меня )) Общий смысл улавливаю, но целиком осознать не получается приведенный код )
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
beliyadm, крутую вещь вы написали, но это слишком мудрено для меня )) Общий смысл улавливаю, но целиком осознать не получается приведенный код )
Это кусок кода для MSSQL - обработка чего-то в цикле.
В курсор curr (первые строки) мы закладываем выборку ID по запросу (массив) и дальше в  fetch next from curr проводим определенные действия по этому ID, обычный цикл (я просто из старого кода копировал, там идет исполнение функции и прочее много лишнего).
Все напрямую в базе, без PHP или других языков
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

sivers

  • Живу я здесь
  • 2578
  • 357 / 0
Это кусок кода для MSSQL - обработка чего-то в цикле.
а... Ну да, там БД является полноценным и полнофункциональным приложением. Разве что без интерфейса.
Кое что и MySQL уже научился делать. Переменные, триггеры... Но в сайтостроении это пока не востребовано. Или вернее будет - в Joomla не востребовано.
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Добавить пользовательскую позицию для вывода

Автор AndreySeo

Ответов: 2
Просмотров: 1858
Последний ответ 25.05.2023, 10:48:09
от AndreySeo
VirtueMart 3 Через RO csvi не могу загрузить больше 956 товаров

Автор artem_wrong

Ответов: 11
Просмотров: 1674
Последний ответ 25.09.2021, 21:13:23
от ShopES
Кнопка добавить в корзину

Автор tmpnikl

Ответов: 1
Просмотров: 976
Последний ответ 28.07.2021, 13:17:53
от Wargoth
Дополнительное фото к товару?

Автор warlocksp

Ответов: 2
Просмотров: 588
Последний ответ 01.09.2020, 17:04:16
от warlocksp
Поле вариант и дочерние товары

Автор snikolai

Ответов: 5
Просмотров: 869
Последний ответ 19.08.2020, 14:08:38
от sivers