Новости Joomla

SW JProjects v.2.5.0 - компонент каталога цифровых проектов на Joomla

SW JProjects v.2.5.0 - компонент каталога цифровых проектов на Joomla

👩‍💻 SW JProjects v.2.5.0 - компонент каталога цифровых проектов на Joomla.Компонент - менеджер цифровых проектов для Joomla! CMS. Компонент обеспечивает создание каталога цифровых проектов и предоставляет возможность скачивания, в том числе с использованием лицензионных ключей.👩‍💻 v.2.5.0. Что нового?Схемы структур данных для серверов обновлений. Теперь с SW JProjects вы может создавать сервер обновлений не только для расширений Joomla, но и свои собственные. Например, вам нужно, чтобы структура данных сервера обновлений была другая и формат должен быть, например, не XML, а JSON. Формирование структуры данных для сервера обновлений расширений Joomla вынесено в отдельный плагин. Вы можете создать свой собственный плагин и реализовать в нём нужную вам структуру данных, добавив или наоборот исключив отображаемые данные. Сервер обновлений в компоненте по-прежнему отображает информацию о списке проектов и их версиях, о конкретном проекте и его changelog.Можно выбрать схему данных сервера обновлений глобально для всего компонента, выбрать другую схему данных для категории проектов, а так же выбрать схему в каждом проекте.

Разработчикам в качестве образца можно посмотреть плагин схемы данных для Joomla в составе компонента или же плагин-образец JSON-схемы на GitHub.
Группа плагинов swjprojects. Для нужд компонента создана группа плагинов swjprojects. В частности, в этой группе находится плагин структуры данных Joomla расширений для сервера обновлений.Изменение языковых констант. Изменены некоторые языковые константы в панели администратора. Если вы делали переопределение констант - переопределите их снова.👩‍💻 Joomla 6. Внесены изменения для корректной установки и работы компонента на Joomla 6. Компонент успешно протестирован на Joomla 6-beta2.Минимальная версия Joomla - 5. Подняты минимальные системные требования: Joomla 5.0.0 и PHP 8.1.
- Страница расширения👉 Плагин-образец кастомной JSON-схемы данных для сервера обновлений на GitHub.- GitHub расширения- Документация на GitHub- Joomla Extensions Directory#joomla #расширения

Как триггерить события для плагинов на манер Joomla 5+?В Joomla 6 должны удалить метод...

Как триггерить события для плагинов на манер Joomla 5+?В Joomla 6 должны удалить метод...

👩‍💻 Как триггерить события для плагинов на манер Joomla 5+?В Joomla 6 должны удалить метод triggerEvent(), с помощью которого раньше вызывались события для плагинов. Теперь чтобы в своём коде вызвать событие для плагина и получить от него результаты нужно:- создать объект класса события- передать в него параметры

use Joomla\CMS\Event\AbstractEvent;use Joomla\CMS\Factory;use Joomla\CMS\Plugin\PluginHelper;// Грузим плагины нужных группPluginHelper::importPlugin('system');// Создаём объект события$event = AbstractEvent::create('onAfterInitUniverse', [    'subject' => $this,    'data'    => $data, // какие-то данные    'article' => $article, // ещё материал вдовесок    'product' => $product, // и товаров подвезли]);// Триггерим событиеFactory::getApplication()->getDispatcher()->dispatch(    $event->getName(), // Тут можно строку передать 'onAfterInitUniverse'    $event);// Получаем результаты// В случае с AbstractEvent это может быть не 'result',// а что-то ещё - куда сами отдадите данные.// 2-й аргумент - значение по умолчанию, // если не получены результаты$results = $event->getArgument('result', []);
Плюсы такого подхода - вам не нужно запоминать порядок аргументов и проверять их наличие. Если вы написали свой класс события, то в плагине можно получать аргументы с помощью методов $event->getArticle(), $event->getData(), $event->getProduct() и подобными - реализуете сами под свои нужды. Если такой класс события написали, то создаёте экземпляр своего класса события и укажите его явно в аргументе eventClass
use Joomla\Component\MyComponent\Administrator\Event\MyCoolEvent;$event = MyCoolEvent::create('onAfterInitUniverse', [    'subject'    => $this,    'eventClass' => MyCoolEvent::class, // ваш класс события    'data'       => $data, // какие-то данные    'article'    => $article, // ещё материал вдовесок    'product'    => $product, // и товаров подвезли]);
Ожидаемо, что класс вашего события будет расширять AbsractEvent или другие классы событий Joomla.🙁 Есть неприятный нюанс - нельзя просто так вызывать событие и ничего не передать в аргументы. Аргумент subject обязательный. Но если вы всё-таки не хотите туда ничего передавать - передайте туда пустой stdClass или объект Joomla\registry\Registry.
@joomlafeed#joomla #php #webdev

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

CaHeK_pk

  • Захожу иногда
  • 114
  • 2 / 0
SQL работа с массивом
« : 23.09.2015, 15:13:09 »
Добрый день, нужно добавить значения в определенную строку в которой хранится вот это
Код: sql
{"hideempty":"1","color":"FFFFFF",
"mirror_module":"0","mirror_moduleid":"132","match_method":"or","show_assignments":"1","assignto_menuitems":"0",
"assignto_menuitems_selection":["159","173"],"assignto_menuitems_inc_children":"1","assignto_menuitems_inc_noitemid":"0",
"assignto_homepage":"0",
"assignto_date":"0","assignto_date_publish_up":"0000-00-00 00:00",
"assignto_date_publish_down":"0000-00-00 00:00","assignto_date_recurring":"0","assignto_seasons":"0",
"assignto_seasons_selection":["x"],"assignto_seasons_hemisphere":"northern","assignto_months":"0","assignto_months_selection":["x"],"assignto_days":"0","assignto_days_selection":["x"],"assignto_time":"0","assignto_time_publish_up":"0:00","assignto_time_publish_down":"0:00","assignto_usergrouplevels":"0",
"assignto_users":"0","assignto_users_selection":"","assignto_languages":"0","assignto_ips":"0","assignto_ips_selection":"",
"assignto_geocontinents":"0","assignto_geocountries":"0","assignto_georegions":"0","assignto_templates":"0","assignto_urls":"0",
"assignto_urls_selection":"","assignto_urls_regex":"0","assignto_os":"0","assignto_browsers":"0","assignto_components":"0",
"assignto_contentpagetypes":"0","assignto_cats":"0","assignto_cats_inc_children":"0","assignto_cats_inc":["inc_cats","inc_arts","x"],"assignto_articles":"0","assignto_articles_keywords":"","assignto_virtuemartpagetypes":"1",
"assignto_virtuemartcats":"1","assignto_virtuemartcats_inc_children":"0","assignto_virtuemartcats_inc":["inc_cats","x"],"assignto_virtuemartproducts":"2",
"assignto_virtuemartproducts_selection":["31","31","[color=red][b]Вот сюда добавляем id с номером материала[/b][/color]","25","31","25","29","24","24","27","27","23","23","30","30"],
"assignto_php":"2","assignto_php_selection":""}
при помощи php скрипта... как это можно сделать, если обычным методом update, то всю эту строку перезаписывает...
*

Arkadiy

  • Гуру
  • 5317
  • 463 / 2
  • Крепитесь, други.
Re: SQL работа с массивом
« Ответ #1 : 23.09.2015, 15:24:13 »
В SET надо писать
Код
set `fieldname` = CONCAT(`fieldname`, 'new string value')
*

CaHeK_pk

  • Захожу иногда
  • 114
  • 2 / 0
Re: SQL работа с массивом
« Ответ #2 : 23.09.2015, 15:41:41 »
В SET надо писать
Код
set `fieldname` = CONCAT(`fieldname`, 'new string value')
Благодарю, но можете полностью запрос прописать, с SET ни-разу не работал просто.
получается нужно поменять строку "params" где "moduleid = 132", как раз в "params"  находится тот код который указывал в первом посте, благодарю заранее за помощь
*

Arkadiy

  • Гуру
  • 5317
  • 463 / 2
  • Крепитесь, други.
Re: SQL работа с массивом
« Ответ #3 : 23.09.2015, 19:09:43 »
Вы писали "если обычным методом update", каким методом вы делали?
*

CaHeK_pk

  • Захожу иногда
  • 114
  • 2 / 0
Re: SQL работа с массивом
« Ответ #4 : 24.09.2015, 05:03:54 »
Вы писали "если обычным методом update", каким методом вы делали?
Код: sql
UPDATE  `kamsales_new`.`kmsls_advancedmodules` SET  `params` = CONCAT('assignto_virtuemartproducts', '25') WHERE `kmsls_advancedmodules`.`moduleid` =161;
что не так делаю? по итогу в записи все заменяется на "assignto_virtuemartproducts1"...
*

Arkadiy

  • Гуру
  • 5317
  • 463 / 2
  • Крепитесь, други.
Re: SQL работа с массивом
« Ответ #5 : 24.09.2015, 06:12:58 »
Прямые кавычки обрамляют строку, название поля принято обрамлять ` или вообще не обрамлять.
*

CaHeK_pk

  • Захожу иногда
  • 114
  • 2 / 0
Re: SQL работа с массивом
« Ответ #6 : 24.09.2015, 06:55:25 »
Прямые кавычки обрамляют строку, название поля принято обрамлять ` или вообще не обрамлять.
Код: sql
UPDATE  `kamsales_new`.`kmsls_advancedmodules` SET  `params` = CONCAT(`assignto_virtuemartproducts_selection`, '25') WHERE `kmsls_advancedmodules`.`moduleid` =161;
пишет
#1054 - Unknown column 'assignto_virtuemartproducts' in 'field list'
понять не могу что не так
*

Arkadiy

  • Гуру
  • 5317
  • 463 / 2
  • Крепитесь, други.
Re: SQL работа с массивом
« Ответ #7 : 24.09.2015, 16:19:48 »
Пишет что такой ячейки нет в этой таблице. Но в запросе и в ошибке разные ячейки.
*

CaHeK_pk

  • Захожу иногда
  • 114
  • 2 / 0
Re: SQL работа с массивом
« Ответ #8 : 28.09.2015, 12:24:10 »
Пишет что такой ячейки нет в этой таблице. Но в запросе и в ошибке разные ячейки.
это да, просто запросы разные делал, вообщем ничего не выходит увы...
наглядно как выглядит структура таблицы, может тогда подскажете
moduleid | asset_id | params |
------------------------------------
161        | 291        | здесь и производим изменеия
*

Arkadiy

  • Гуру
  • 5317
  • 463 / 2
  • Крепитесь, други.
Re: SQL работа с массивом
« Ответ #9 : 29.09.2015, 05:51:12 »
Код: sql
UPDATE  `kamsales_new` SET  `params` = CONCAT(`params`, ' 25') WHERE `moduleid` =161;
И не говорите что не работает, проверил, все работает.
*

CaHeK_pk

  • Захожу иногда
  • 114
  • 2 / 0
Re: SQL работа с массивом
« Ответ #10 : 29.09.2015, 08:10:12 »
Код: sql
UPDATE  `kamsales_new` SET  `params` = CONCAT(`params`, ' 25') WHERE `moduleid` =161;
И не говорите что не работает, проверил, все работает.
ну а как добавить именно в определенное место?
Код: sql
.....,"assignto_virtuemartcats_inc_children":"0","assignto_virtuemartcats_inc":["inc_cats","x"],"assignto_virtuemartproducts":"2",

"assignto_virtuemartproducts_selection":["31","31","Вот сюда добавляем id с номером материала","25","31","25","29","24","24","27","27","23","23","30","30"],

"assignto_php":"2","assignto_php_selection":""}
*

Arkadiy

  • Гуру
  • 5317
  • 463 / 2
  • Крепитесь, други.
Re: SQL работа с массивом
« Ответ #11 : 29.09.2015, 08:22:58 »
Запрашивайте поле, обрататывайте его в php, пишите обратно без всяких конкатенаций.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Непонятная работа плагина "Поиск"

Автор Snip

Ответов: 0
Просмотров: 2486
Последний ответ 20.03.2023, 10:47:56
от Snip
Работа со сриптами в Joomla

Автор Viclingvolive

Ответов: 3
Просмотров: 1367
Последний ответ 11.12.2019, 04:14:04
от aztekadv
Hotspots или что то другое? (работа с картами)

Автор Governor

Ответов: 3
Просмотров: 3050
Последний ответ 26.03.2018, 06:59:08
от bato
Ищу специалиста для различных изменений на сайтах в модулях за деньги, работа есть

Автор GuN

Ответов: 1
Просмотров: 1048
Последний ответ 01.02.2017, 20:05:39
от Septdir
Работа WidgetKit Lite в разных браузерах.

Автор Ser_g

Ответов: 0
Просмотров: 1369
Последний ответ 18.04.2016, 12:35:58
от Ser_g