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

john.deff

  • Захожу иногда
  • 115
  • 0 / 0
по сути всё просто
подключаем в файл administrator/components/com_ИМЯКОМПОНЕНТА/ИМЯКОМПОНЕНТА.php
Код
# Подключение файлов
$document = JFactory::getDocument();
$document->addStyleSheet(JUri::base(true)."/components/com_abread/assets/css/style.css");
$document->addScript(JUri::base(true)."/components/com_abread/assets/js/javascript.js");

но проблема в том, что всё это начинает подключаться раньше стандартных библиотек, при выводе HTML шаблона:
Код
// СЮДА ПРОИСХОДИТ ПОДКЛЮЧЕНИЕ!
<script src="/media/jui/js/jquery.min.js" type="text/javascript"></script>
<script src="/media/jui/js/jquery-noconflict.js" type="text/javascript"></script>
<script src="/media/jui/js/jquery-migrate.min.js" type="text/javascript"></script>
<script src="/media/jui/js/bootstrap.min.js" type="text/javascript"></script>
<script src="/administrator/templates/isis/js/template.js?87038b9a2ef696699f9361889cf45365" type="text/javascript"></script>
// А НАДО ПОДКЛЮЧАТЬ СЮДА!

как решить правильно данную проблему?
ведь если я буду подключать всё стандартным HTML способом там где мне надо, это влечет за собой следующие проблемы
 - В каждый вид надо вставлять один и тот же код
 - если отправлять AJAX запрос, то HTML подключение происходит через AJAX методами GET

Прошу помощи в решении данной проблемы!
*

Aleks.Denezh

  • Живу я здесь
  • 3401
  • 428 / 4
как решить правильно данную проблему?
Вызвать нужные скрипты до  подключения ваших:

JHtml::_( 'bootstrap.tooltip' );  вот это подрубит JQ и бутстрап,
а дальше ваши подключения!
*

john.deff

  • Захожу иногда
  • 115
  • 0 / 0
Вызвать нужные скрипты до  подключения ваших:

JHtml::_( 'bootstrap.tooltip' );  вот это подрубит JQ и бутстрап,
а дальше ваши подключения!

Работает! спасибо!

Но возникает дополнительный вопрос, как сделать подгрузку библиотек снизу страницы?
Так как для работы некоторых скриптов сами библиотеки должны быть подключены ниже вызова:
<input id="fileupload" type="file" name="files[]" data-url="server/php/" multiple>
Например для этой библиотеки: https://github.com/blueimp/jQuery-File-Upload/wiki/Basic-plugin

скажите ещё какие значения есть у JHtml::_(); ?
так как https://api.joomla.org/cms-3/classes/JHtml.html#method__ - бестолковый мануал, ничего не понятно..
например я хочу поменять версию jQuery


сейчас поковырявшись в коде понял!
дело в том, что загрузка файлов с помощью https://github.com/blueimp/jQuery-File-Upload/wiki/Basic-plugin у меня реализуется во всплывающем окне, а содержимое подгружается с помощью AJAX, следовательно, надо как-то подгружать саму библиотеку во всплывающем окне (подгружаемым контентом),
как это сделать?
« Последнее редактирование: 29.04.2016, 13:03:28 от john.deff »
*

Aleks.Denezh

  • Живу я здесь
  • 3401
  • 428 / 4
сейчас поковырявшись в коде понял!
дело в том, что загрузка файлов с помощью https://github.com/blueimp/jQuery-File-Upload/wiki/Basic-plugin у меня реализуется во всплывающем окне, а содержимое подгружается с помощью AJAX, следовательно, надо как-то подгружать саму библиотеку во всплывающем окне (подгружаемым контентом),
как это сделать?
Грузите просто в всплывающее окно через AJAX:

разметка для JQuery-File-Upload
<script src="путь к JQuery-File-Upload"></script>
<script>
инициализация fileupload
</script>


и все будет работать!
*

john.deff

  • Захожу иногда
  • 115
  • 0 / 0
Грузите просто в всплывающее окно через AJAX:

разметка для JQuery-File-Upload
<script src="путь к JQuery-File-Upload"></script>
<script>
инициализация fileupload
</script>


и все будет работать!

неа, не работает!
вызываю на прямую > onclick=""
это только помогло решить проблему
« Последнее редактирование: 29.04.2016, 21:55:16 от john.deff »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Отправка файлов через ajax в модуль Joomla

Автор hemicide

Ответов: 19
Просмотров: 2112
Последний ответ 11.04.2022, 08:44:33
от sivers
[РЕШЕНО] curl-файл Joomla $model->save($data) подключение модели администратора

Автор platonische

Ответов: 31
Просмотров: 1812
Последний ответ 30.05.2019, 16:10:57
от sivers
Приём и сохранение файлов в модуле Joomla 3.7

Автор Inoken

Ответов: 5
Просмотров: 1129
Последний ответ 06.10.2017, 12:03:15
от Inoken
В каком файле осуществлять удаление файлов?

Автор borro

Ответов: 27
Просмотров: 1179
Последний ответ 30.06.2017, 21:35:32
от robert
Вывод в формате JSON и подключение к Яндекс карте

Автор Septdir

Ответов: 11
Просмотров: 5190
Последний ответ 16.05.2016, 19:55:50
от Septdir