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

verstalshik

  • Завсегдатай
  • 1754
  • 95 / 1
Хай алл!

Спс всем за подсказки в соседней теме, вот продолжение)))

Переменная strclassmale может принимать несколько значений:
 (a-class b-class c-class d-class e-class h-class s-class m-class),
специально пишу все, чтобы сразу понять, где можно сэкономить на коде, а где нет))))

И в теле страницы есть несколько блоков, у каждого есть такой же класс, может быть несколько блоков с одинаковым классом, внутри блока ИНПУТ!, вот один из блоков:
Код
<tr class="class-10-11 a-class coloring"><td>459</td><td><input id="aaa" class="CheckBoxClass" name="event" value="1500" type="checkbox"><label for="aaa" class="CheckBoxLabelClass">1500р</label></td></tr>

Задачка - если переменная приняла какое-то значение, то инпуту внутри блока с таким же классом не надо ничего не менять, а вот всем остальным инпутам надо сделать дизаблед.
Временно обхожусь так, но такой кусок кода придется размножить для каждого варианта переменной, простыыыннняяяя:
Код
if (strclassmale == 'a-class') {
$('.h-class input[type="checkbox"]').removeAttr('checked').attr('disabled', 'disabled');
$('.e-class input[type="checkbox"]').removeAttr('checked').attr('disabled', 'disabled');
$('.d-class input[type="checkbox"]').removeAttr('checked').attr('disabled', 'disabled');
$('.c-class input[type="checkbox"]').removeAttr('checked').attr('disabled', 'disabled');
$('.b-class input[type="checkbox"]').removeAttr('checked').attr('disabled', 'disabled');
$('.s-class input[type="checkbox"]').removeAttr('checked').attr('disabled', 'disabled');
$('.m-class input[type="checkbox"]').removeAttr('checked').attr('disabled', 'disabled');
}

Но что-то слышал про оператор :not, вставлял вот так:
Код
if (strclassmale == 'a-class') {
$(':not(.a-class) input[type="checkbox"]').removeAttr('checked').attr('disabled', 'disabled');
}
не пашет(((
« Последнее редактирование: 07.04.2014, 08:28:54 от verstalshik »
❶ НЕ СПРАВЛЯЕШЬСЯ САМ???  Поможем тут...  ❷ Калькулятор доставки - ЗАКАЖИ!!!...  ❸ Каталог компаний - ЖМИ!!!...  ❹ НОВИЧКИ! ВСЕ сюда! Первая консультация БЕСПЛАТНО!!
*

Arkadiy

  • Гуру
  • 5317
  • 463 / 2
  • Крепитесь, други.
Re: Не разобрался с операторм :not
« Ответ #1 : 07.04.2014, 08:30:40 »
not это не псевдокласс, это метод, его надо использовать в цепочке методов через точку
Код
$('input[type="checkbox"]').not(.a-class)...
P.S. На jQuery.com есть офигенская документация.
*

verstalshik

  • Завсегдатай
  • 1754
  • 95 / 1
Re: Не разобрался с операторм :not
« Ответ #2 : 07.04.2014, 08:34:21 »
и чуть сложнее задачка:
есть такие блоки
Код
<tr class="class-19-35 h-class e-class a-class c-class coloring"><td>532</td><td><input id="ppp" class="CheckBoxClass" name="event" value="1500" type="checkbox"><label for="ppp" class="CheckBoxLabelClass">1500р</label></td></tr>

как видно, среди кучи классов у блока есть и искомый класс a-class, этот блок тоже не должен быть отключен
❶ НЕ СПРАВЛЯЕШЬСЯ САМ???  Поможем тут...  ❷ Калькулятор доставки - ЗАКАЖИ!!!...  ❸ Каталог компаний - ЖМИ!!!...  ❹ НОВИЧКИ! ВСЕ сюда! Первая консультация БЕСПЛАТНО!!
*

verstalshik

  • Завсегдатай
  • 1754
  • 95 / 1
Re: Не разобрался с операторм :not
« Ответ #3 : 07.04.2014, 08:49:16 »
not это не псевдокласс, это метод, его надо использовать в цепочке методов через точку
Код
$('input[type="checkbox"]').not(.a-class)...
P.S. На jQuery.com есть офигенская документация.

сделал так, не пашет (класс eventsfinish добавил, внутри блока с этим классом подопытные, чтобы все инпуты не куролесить)
Код
if (strclassmale == 'a-class') {
$('.eventsfinish input[type="checkbox"]').not(".a-class").removeAttr('checked').attr('disabled', 'disabled');
}
upd.
а, у меня ж класс этот не у инпутов, а tr!
т.е. надо найти tr с классами, не равными искомому и внутри инпутам сделать дизаблед.... хм...
« Последнее редактирование: 07.04.2014, 08:52:38 от verstalshik »
❶ НЕ СПРАВЛЯЕШЬСЯ САМ???  Поможем тут...  ❷ Калькулятор доставки - ЗАКАЖИ!!!...  ❸ Каталог компаний - ЖМИ!!!...  ❹ НОВИЧКИ! ВСЕ сюда! Первая консультация БЕСПЛАТНО!!
*

verstalshik

  • Завсегдатай
  • 1754
  • 95 / 1
Re: Не разобрался с операторм :not
« Ответ #4 : 07.04.2014, 10:11:47 »
вот моя простыня, пашет, но простыыыыня...

Спойлер
[свернуть]
❶ НЕ СПРАВЛЯЕШЬСЯ САМ???  Поможем тут...  ❷ Калькулятор доставки - ЗАКАЖИ!!!...  ❸ Каталог компаний - ЖМИ!!!...  ❹ НОВИЧКИ! ВСЕ сюда! Первая консультация БЕСПЛАТНО!!
*

Arkadiy

  • Гуру
  • 5317
  • 463 / 2
  • Крепитесь, други.
Re: Не разобрался с операторм :not
« Ответ #5 : 07.04.2014, 11:14:43 »
Попробуй так:
Код: javascript
var strclassmale = .....
$('input[type="checkbox"]').not('.'+strclassmale+' input[type="checkbox"]').removeAttr('checked').attr('disabled', 'disabled');
*

Arkadiy

  • Гуру
  • 5317
  • 463 / 2
  • Крепитесь, други.
Re: Не разобрался с операторм :not
« Ответ #6 : 07.04.2014, 11:18:45 »
И хорошим тоном является именование переменных понятным для других программистов образом. Я про strclassmale.
*

verstalshik

  • Завсегдатай
  • 1754
  • 95 / 1
Re: Не разобрался с операторм :not
« Ответ #7 : 07.04.2014, 12:53:29 »
Попробуй так:
Код: javascript
var strclassmale = .....
$('input[type="checkbox"]').not('.'+strclassmale+' input[type="checkbox"]').removeAttr('checked').attr('disabled', 'disabled');
круто!! вы СПЕЦ!! плюсанул и ОГРОМНОЕ СПАСИБО, иду учебник плотно изучать джиквери)))

это получается, ВСЕ инпуты будут задизаблены, кроме тех, которые с текущим классом? тут бы еще ограничить классом общего блока.... а то все формы тогда зачекаются наверное...
« Последнее редактирование: 07.04.2014, 13:06:11 от verstalshik »
❶ НЕ СПРАВЛЯЕШЬСЯ САМ???  Поможем тут...  ❷ Калькулятор доставки - ЗАКАЖИ!!!...  ❸ Каталог компаний - ЖМИ!!!...  ❹ НОВИЧКИ! ВСЕ сюда! Первая консультация БЕСПЛАТНО!!
*

verstalshik

  • Завсегдатай
  • 1754
  • 95 / 1
Re: Не разобрался с операторм :not
« Ответ #8 : 07.04.2014, 12:58:34 »
И хорошим тоном является именование переменных понятным для других программистов образом. Я про strclassmale.
тут хз, вроде постарался вложить смысл))):
str - взял это для всех переменных, стандартный расчет (там на сайте стандартный и индивидуальный)
class - это класс (типа уровень знаний), он так и вписывается в той сфере, для которой все это задумано
male - это мужчина (или female - женщина)

а как тут понятнее сделать?
❶ НЕ СПРАВЛЯЕШЬСЯ САМ???  Поможем тут...  ❷ Калькулятор доставки - ЗАКАЖИ!!!...  ❸ Каталог компаний - ЖМИ!!!...  ❹ НОВИЧКИ! ВСЕ сюда! Первая консультация БЕСПЛАТНО!!
*

Arkadiy

  • Гуру
  • 5317
  • 463 / 2
  • Крепитесь, други.
Re: Не разобрался с операторм :not
« Ответ #9 : 07.04.2014, 17:13:19 »
Слова в сложном названии разделяются либо горбамиВерблюда, либо нижними_подчеркиваниями, тогда понятно где кончается одно слово и начинается другое.
это получается, ВСЕ инпуты будут задизаблены, кроме тех, которые с текущим классом? тут бы еще ограничить классом общего блока.... а то все формы тогда зачекаются наверное...
это совершенно не проблема, в первой выборке ты выбираешь исходный набор, типа $('input[type="checkbox"]', '.classParentDiv') где '.classParentDiv' - класс родительского контейнера детей которого надо выбирать, либо аналогично $('.classParentDiv input[type="checkbox"]') то есть если ты верстальщик - то ты должен лучше меня знать селекторы jQuery потому что они практически аналогичны селекторам CSS.
*

verstalshik

  • Завсегдатай
  • 1754
  • 95 / 1
Re: Не разобрался с операторм :not
« Ответ #10 : 07.04.2014, 19:26:34 »
Слова в сложном названии разделяются либо горбамиВерблюда, либо нижними_подчеркиваниями, тогда понятно где кончается одно слово и начинается другое. это совершенно не проблема, в первой выборке ты выбираешь исходный набор, типа $('input[type="checkbox"]', '.classParentDiv') где '.classParentDiv' - класс родительского контейнера детей которого надо выбирать, либо аналогично $('.classParentDiv input[type="checkbox"]') то есть если ты верстальщик - то ты должен лучше меня знать селекторы jQuery потому что они практически аналогичны селекторам CSS.
я так и предполагал -  $('.classParentDiv input[type="checkbox"]')
хотя верстальщик из меня - так, одно название, никчемный, я больше любитель коньяка...))))
❶ НЕ СПРАВЛЯЕШЬСЯ САМ???  Поможем тут...  ❷ Калькулятор доставки - ЗАКАЖИ!!!...  ❸ Каталог компаний - ЖМИ!!!...  ❹ НОВИЧКИ! ВСЕ сюда! Первая консультация БЕСПЛАТНО!!
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться