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

ice77

  • Осваиваюсь на форуме
  • 40
  • 0 / 0
А причём тут выборка? Посмотрите как в com_content сделано
https://github.com/joomla/joomla-cms/blob/staging/components/com_content/models/form.php#L205
Код: php
$form->setFieldAttribute('catid', 'readonly', 'true');
Спасибо за ответ.
А выборка у меня была, для полей из другой таблицы. Если я сделаю в компоненте, выборку в поле, при создании или изменении одного элемента в полях, которые выбраны из второй таблицы. Должны ли они хранится в первой таблице?
*

ice77

  • Осваиваюсь на форуме
  • 40
  • 0 / 0
Добрый день!
Добавляю в форму дополнительное поле, данные берутся из другой таблицы.
Код
<input type="text" class="dopolnitelno" [<?php echo $value; ?>] value="<?php 

$db = JFactory::getDbo();
$query = $db->getQuery(true);

$query->clear();
$query = '
SELECT #__programma_meroprijatij.dopolnitelno as prog_dop
 FROM #__plan_obuchenie_
INNER JOIN #__programma_meroprijatij
 ON #__programma_meroprijatij.id=#__plan_obuchenie_.nazvanie_programmi
';

$db->setQuery($query);
$data_result = $db->loadresult('prog_dop');

 echo $value=$data_result; ?>" />

В поле показывается только одно и тоже значения при смене nazvanie_programmi. Хотя должно брать значение из таблицы #__programma_meroprijatij поле dopolnitelno.
В чем я ошибся подскажите пожалуйста.
*

b2z

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

ice77

  • Осваиваюсь на форуме
  • 40
  • 0 / 0
Добрый вечер, у меня возникла проблема.
Две таблицы из которых берутся данные. Первая таблица(#__plan_obuchenie_), с которой непосредственно работает компонент и вторая таблица(#__programma_meroprijatij).Из второй таблицы нужно только поле dopolnitelno.
Добавляю поле, которое в режиме редактирования должен отображаться.Но вместо записи по определенной записи дополнительно показывает:Array.
Код: php
$db = JFactory::getDbo();
$query = $db->getQuery(true);
$query->clear();
$query = '
SELECT prog.dopolnitelno
FROM #__plan_obuchenie_ plan
INNER JOIN #__programma_meroprijatij prog ON plan.nazvanie_programmi = prog.id
;'
$data_result = $db->loadObjectList('prog.dopolnitelno');
echo $data_result;
Подскажите пожалуйста в чем я ошибся? И как могу исправить? !!!???!!!
« Последнее редактирование: 27.08.2017, 23:00:50 от ice77 »
*

ice77

  • Осваиваюсь на форуме
  • 40
  • 0 / 0
Доброго времени суток.
Логика работы двух таблиц и компонентов. Может я ошибаюсь в построении логики запроса.
Есть две таблицы(из этих двух таблиц и сделаны компоненты)
Первая таблица имеет имя #__programma_meroprijatij(имя компонента Программа мероприятий) в ней есть поле id,naimenovanie_programmi, dopolnitelno(другие поля не используются в запросе).
Вторая таблица - #__plan_obuchenie_(Компонент-план обучения) поля - id, nazvanie_programmi(другие поля не используются в запросе).
В компоненте план обучения поле nazvanie_programmi является внешним ключем и соединен с id Программы мероприятий.
И вот в запросе я пытаюсь сделать при выборе в плане обучения третьей записи из плана и чтобы подтягивывалось поле дополнительно, согласно из выбора nazvanie_programmi=naimenovanie_programmi.
Запрос:
Код
$db = JFactory::getDbo();
$query = $db->getQuery(true);
$query->clear();
$query = '
select prog.dopolnitelno
from #__programma_meroprijatij prog
INNER JOIN #__plan_obuchenie_ plan on plan.nazvanie_programmi = prog.id
INNER JOIN #__plan_obuchenie_  ON plan.nazvanie_programmi =plan.id

';
$db->setQuery($query);
$data_result = $db->loadResult();
Проблема такая с запросом, что выводит вторую строку только из таблицы #__programma_meroprijatij. В чем может проблема подскажите пожалуйста
*

robert

  • Живу я здесь
  • 4974
  • 457 / 20
 
#__programma_meroprijatij, #__plan_obuchenie_(Компонент-план обучения), nazvanie_programmi=naimenovanie_programmi
Что за ***ня? Если с английским не дружите, то хотя бы укоротите названия таблиц и столбцов, а то в глазах просто рябит от вашего кода.
А это
INNER JOIN #__plan_obuchenie_ plan on plan.nazvanie_programmi = prog.id
INNER JOIN #__plan_obuchenie_  ON plan.nazvanie_programmi =plan.id
что такое? Как я понял, при этом вы написали, как минимум, 2 компонента?
С выражением мыслей тоже проблематично
Проблема такая с запросом, что выводит вторую строку только из таблицы #__programma_meroprijatij.
Так выводит вторую строку только из таблицы #__programma_meroprijatij или выводит только вторую строку из таблицы #__programma_meroprijatij?
Не будь паразитом, сделай что-нибудь самостоятельно!
*

ice77

  • Осваиваюсь на форуме
  • 40
  • 0 / 0
Так выводит вторую строку только из таблицы #__programma_meroprijatij
*

robert

  • Живу я здесь
  • 4974
  • 457 / 20
только из таблицы #__programma_meroprijatij
Из какой таблицы тогда надо выводить?
Не будь паразитом, сделай что-нибудь самостоятельно!
*

ice77

  • Осваиваюсь на форуме
  • 40
  • 0 / 0
Люди добрые помогите пожалуйста написанием условие в запросе. 
Нужно, в where написать так, что при выборе из компонента любой строки из другой таблице сопоставлялось поле dopolnitelno соответствующее связки.
$db = JFactory::getDbo();
$query = $db->getQuery(true);
$query->clear();
$query = '
   select prog.dopolnitelno, prog.id
from #__programma_meroprijatij prog
INNER JOIN #__plan_obuchenie_ plan on plan.nazvanie_programmi = prog.id
INNER JOIN #__plan_obuchenie_  ON plan.nazvanie_programmi =plan.id

where plan.id
';   
$db->setQuery($query);

$data_result = $db->loadResult();

Заранее благодарю.
*

ice77

  • Осваиваюсь на форуме
  • 40
  • 0 / 0
Доброго времени, суток!
Такой вопрос, если я не ошибаюсь, то данная строчка выводит по 20 записей на одной странице:
$list['limit']     = (int) JFactory::getConfig()->get('list_limit', 20);
Прав я или нет?
Подскажите пожалуйста заранее благодарю.
« Последнее редактирование: 22.05.2018, 11:59:09 от ice77 »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

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

Автор hemicide

Ответов: 19
Просмотров: 2107
Последний ответ 11.04.2022, 08:44:33
от sivers
Документация по разработки компонента для Joomla 3.x

Автор Aspik

Ответов: 9
Просмотров: 3285
Последний ответ 23.01.2021, 07:55:56
от hmr
Применение ajax (Аякс) в модуле Joomla

Автор tm2010

Ответов: 34
Просмотров: 5220
Последний ответ 26.09.2020, 09:38:35
от b2z
Обработка AJAX в компоненте Joomla!3

Автор balancer

Ответов: 33
Просмотров: 11757
Последний ответ 23.07.2020, 07:45:53
от Dolphin4ik_1
Пагинатор в нестандартном компоненте

Автор sesil

Ответов: 8
Просмотров: 1220
Последний ответ 04.09.2019, 11:24:30
от sesil