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

garytopor

  • Новичок
  • 9
  • 0 / 0
Разработка компонента
« : 06.10.2014, 20:46:10 »
Доброго времени суток!

Есть исходная страница http://wakesurfclub.ru/ . Делаю компонент на Joomla 3 :  http://wakeschool.ru/test
Проблема в AJAX запросе:
Где создать файл для AJAX и как прописать AJAX запрос, как прописать URL? И есть идеи как это все реализовать со стороны MVC?

Вот AJAX запрос исходной страницы.
$('.ui-state-default').die('click');
        $('.ui-state-default').live('click',function(){
            query = 'ajax/booking_aj.php?query=getSchedule&day=' + $("#datepicker").datepicker('getDate').getDate() + '&month=' + ($("#datepicker").datepicker('getDate').getMonth()+1)  + '&sid=';
            $.get(query, function(data){
                $('#schedule').html(data);
            });
            return false
        });
« Последнее редактирование: 06.10.2014, 20:54:42 от garytopor »
*

garytopor

  • Новичок
  • 9
  • 0 / 0
Re: Разработка компонента
« Ответ #2 : 07.10.2014, 12:03:45 »
А как вызвать нужную вьюшку?
Мои не работающие варианты :
1)
$('.ui-state-default').die('click');
        $('.ui-state-default').live('click',function(){
            query = 'index.php?option=com_similar&task=abc&format=raw';
            $.get(query, function(data){
                $('#schedule').html(data);
            });
            return false
        });
2)jQuery(document).ready(function() {
    $('.ui-state-default').die('click');
        $('.ui-state-default').live('click',function(){
        jQuery.ajax({
            url: url,
            type: "GET",
            success: function(data) {
                 $('#schedule').html(data);
            }
        });
    });
});
*

zomby6888

  • Завсегдатай
  • 1473
  • 171 / 3
Re: Разработка компонента
« Ответ #4 : 07.10.2014, 12:52:42 »
А как вызвать нужную вьюшку?
правильно прописать url в запросе либо в задаче контролера прогрузить вьюху и в урле указать задачу, или указать в урле view
интернет-блог: http://websiteprog.ru
*

garytopor

  • Новичок
  • 9
  • 0 / 0
Re: Разработка компонента
« Ответ #5 : 07.10.2014, 12:57:59 »
можно на примере?
*

b2z

  • Глобальный модератор
  • 7287
  • 778 / 0
  • Разраблю понемногу
Re: Разработка компонента
« Ответ #6 : 07.10.2014, 14:18:07 »
либо в задаче контролера прогрузить вьюху

Код: php
$this->input->set('view', 'viewName');

или указать в урле view

Код: php
query = 'index.php?option=com_similar&task=abc&view=viewName&format=raw'
*

garytopor

  • Новичок
  • 9
  • 0 / 0
Re: Разработка компонента
« Ответ #7 : 07.10.2014, 15:23:20 »
а как использовать если через контроллер $this->input->set('view', 'viewName');
?
*

b2z

  • Глобальный модератор
  • 7287
  • 778 / 0
  • Разраблю понемногу
Re: Разработка компонента
« Ответ #8 : 07.10.2014, 15:40:05 »
а как использовать если через контроллер $this->input->set('view', 'viewName');
?
Мне непонятен вопрос.
*

garytopor

  • Новичок
  • 9
  • 0 / 0
Re: Разработка компонента
« Ответ #9 : 07.10.2014, 19:47:44 »
Извиняюсь, что то никак не получается, кто нибудь может скинуть элементарный  работающий  исходник ?
*

b2z

  • Глобальный модератор
  • 7287
  • 778 / 0
  • Разраблю понемногу
*

garytopor

  • Новичок
  • 9
  • 0 / 0
Re: Разработка компонента
« Ответ #11 : 07.10.2014, 22:16:56 »
http://wakeschool.ru/test при нажатии на датапикер прикручивается к div , HTML вьюхи abc через AJAX.
Пока получилось вызывать самого себя, url : index.php?option=com_mycomponents&view=abc&tmpl=component .
Компонент делал по инструкции http://joomla-umnik.ru/manual-kak-sozdat-komponent-na-joomla-3-kh .
*

Aleks.Denezh

  • Живу я здесь
  • 3401
  • 428 / 4
Re: Разработка компонента
« Ответ #12 : 07.10.2014, 22:30:32 »
index.php?option=com_mycomponents&task=getData

в components/com_mycomponents/controller.php в вашем классе создаете метод:

public function getData(){
echo 'lalala';
exit; //важно что бы не отрендерился весь сайт!
}

Все!
p.s. у меня в подписи мой блог там вы можете почитать про AJAX, а так же есть конструктор для каркаса компонента!
*

garytopor

  • Новичок
  • 9
  • 0 / 0
Re: Разработка компонента
« Ответ #13 : 08.10.2014, 21:55:12 »
Спасибо всем! не получается рендерить другую вьюшку. Видимо я Неправильно подхожу со стороны MVC. Посоветуете хорошую  книгу/статьи по MVC Joomla?
*

b2z

  • Глобальный модератор
  • 7287
  • 778 / 0
  • Разраблю понемногу
Re: Разработка компонента
« Ответ #14 : 09.10.2014, 10:40:25 »
Спасибо всем! не получается рендерить другую вьюшку. Видимо я Неправильно подхожу со стороны MVC. Посоветуете хорошую  книгу/статьи по MVC Joomla?
Где рендерить? Вы бы писали больше информации, ответы бы толковые получали. Статьи - тыц, а вот и книга.
*

andrejdi

  • Захожу иногда
  • 329
  • 32 / 0
Re: Разработка компонента
« Ответ #15 : 09.10.2014, 10:53:32 »
Та же книга, что предложил b2z, только в переводе, есть на ozon.ru. Книга очень толковая, но под ветку !J 2.5
*

b2z

  • Глобальный модератор
  • 7287
  • 778 / 0
  • Разраблю понемногу
Re: Разработка компонента
« Ответ #16 : 09.10.2014, 11:16:09 »
Ядро в 2.5 не сильно отличается. Поэтому книга из разряда must have.
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Re: Разработка компонента
« Ответ #17 : 09.10.2014, 13:30:59 »
garytopor (ох и ник себе вы выбрали), по поводу литературы - вторая строчка в моей подписи, там много всего.
« Последнее редактирование: 09.10.2014, 15:26:47 от AlekVolsk »
*

garytopor

  • Новичок
  • 9
  • 0 / 0
Re: Разработка компонента
« Ответ #18 : 09.10.2014, 14:58:43 »
Наконец то получилось!
Помогли: Istaan http://joomlaforum.ru/index.php?action=profile;u=161380   и b2z http://joomlaforum.ru/index.php?action=profile;u=7180
1) я сформировал компонент через ваш сайт, в ней 2 вьюшки : main и AJAX
2) во вьюхе AJAX выполняется запрос с переменными к базе данных, в main надо рендерить вьюху AJAX
3) что пишу в main :
$.ajax
      ({
      type: "POST",
      url: 'index.php?option=com_order&view=ajax&format=raw',
      cache: false,
      success: function(data)
      {
       $('#main').html(data);
      }
      });
      });
Решение:
У меня вьюшка AJAX была view.html.php . Соответственно url будет таким :
 url: 'index.php?option=com_order&view=ajax&format=html',
Всем спасибо!
*

b2z

  • Глобальный модератор
  • 7287
  • 778 / 0
  • Разраблю понемногу
Re: Разработка компонента
« Ответ #19 : 09.10.2014, 15:16:49 »
Цитировать
У меня вьюшка AJAX была view.html.php
Так сделайте её view.raw.php
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться