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

astanaplus

  • Осваиваюсь на форуме
  • 33
  • 0 / 0
Подскажите, пожалуйста, как отделить позицию (Left) вертикальной чертой. Он в настоящее время отделяется только не на всю высоту, а только на высоты расположенного в левой части текста. Проблема здесь http://za.kz/sintez2/napravleniya-deyatelnosti/proizvodstvo/litsenzii
Буду очень благодарна.
« Последнее редактирование: 25.01.2014, 01:02:44 от Shustry »
*

astanaplus

  • Осваиваюсь на форуме
  • 33
  • 0 / 0
<div class="left" style="width:20%; height:3000px;"> но так не выход... нужно подогнать под высоту правой части
*

Shustry

  • Moderator
  • 6434
  • 745 / 3
Назначить бордер большему по-высоте блоку, т.е. контенту:
Код: css
#middle-content > .content {
    left: 0;
    overflow: hidden;
    position: relative;
    top: 10px;
    z-index: 1;
    border-left: 2px solid #000;
    padding-left: 10px;
}
#middle-content {
    padding-bottom: 20px;
}
Ширину и отступы сами подгоните, думаю.
*

astanaplus

  • Осваиваюсь на форуме
  • 33
  • 0 / 0
Назначить бордер большему по-высоте блоку, т.е. контенту:
Код: css
#middle-content > .content {
    left: 0;
    overflow: hidden;
    position: relative;
    top: 10px;
    z-index: 1;
    border-left: 2px solid #000;
    padding-left: 10px;
}
#middle-content {
    padding-bottom: 20px;
}
Ширину и отступы сами подгоните, думаю.
Благодарю. Всё получилось. Наложила друг на друга и теперь всё ок и когда контент больше и когда меньше. Полоска занимает всю необходимую высоту.
« Последнее редактирование: 24.01.2014, 22:46:08 от astanaplus »
*

Shustry

  • Moderator
  • 6434
  • 745 / 3
Если неизвестно, какая колонка будет выше, то сложнее конечно, но решаемо:
Вариант 1: просто назначить эту полосу фоном к общему родительскому элементу. Просто.
Вариант 2: требует некоторых знаний вёрстки и двух дополнительных контейнеров.

Типа схема:
Спойлер
[свернуть]

Суть метода в том, что бордер колонки будет у общего контейнера со специально уменьшенной шириной. Уменьшенной до ширины колонки. Следующий контейнер просто растягивает область до первоначального размера. Ну а дальше просто наши колонки идут. Стили для примера будут такие (условно)

Разметка будет такая:

Код: html4strict
<div id="wrapper">
<div id="container">
<div id="left">Левая колонка</div>
<div id="right">Правая колонка</div>
<div class="clear"></div>
</div>
</div>

Код: css
#wrapper {width:300px; border-right:#ccc solid 2px;}
#container {width:700px;}
#left {width:300px; float:left;}
#right {width:700px; float:right;}
.clear {clear:both;}
*

astanaplus

  • Осваиваюсь на форуме
  • 33
  • 0 / 0
Если неизвестно, какая колонка будет выше, то сложнее конечно, но решаемо:
Вариант 1: просто назначить эту полосу фоном к общему родительскому элементу. Просто.
Вариант 2: требует некоторых знаний вёрстки и двух дополнительных контейнеров.

Типа схема:
Спойлер
[свернуть]

Суть метода в том, что бордер колонки будет у общего контейнера со специально уменьшенной шириной. Уменьшенной до ширины колонки. Следующий контейнер просто растягивает область до первоначального размера. Ну а дальше просто наши колонки идут. Стили для примера будут такие (условно)

Разметка будет такая:

Код: html4strict
<div id="wrapper">
<div id="container">
<div id="left">Левая колонка</div>
<div id="right">Правая колонка</div>
<div class="clear"></div>
</div>
</div>

Код: css
#wrapper {width:300px; border-right:#ccc solid 2px;}
#container {width:700px;}
#left {width:300px; float:left;}
#right {width:700px; float:right;}
.clear {clear:both;}

Благодарю. Наложили. Решили проблему. Вам плюс.
« Последнее редактирование: 24.01.2014, 22:52:28 от astanaplus »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

[Решено] Как сделать чтобы фотография открылась в отдельном окне?

Автор a-two

Ответов: 11
Просмотров: 2119
Последний ответ 03.11.2020, 16:57:40
от Nikolay89
[Решено] Слетает правый сайдбар на шаблоне protostar

Автор Mick_20

Ответов: 4
Просмотров: 2260
Последний ответ 28.05.2020, 15:45:06
от Muzzy
[Решено] UiKit: сетка на 12 колонок, а также на 7, 8, 9 и (для uikit3) 10

Автор AlekVolsk

Ответов: 1
Просмотров: 6077
Последний ответ 08.08.2019, 19:02:41
от AlekVolsk
Элемент flexbox выходит за края родителя [РЕШЕНО]

Автор dm-krv

Ответов: 3
Просмотров: 10112
Последний ответ 05.04.2019, 16:07:44
от dm-krv
Вертикальное выравнивание текста внутри textarea [РЕШЕНО]

Автор dm-krv

Ответов: 11
Просмотров: 8211
Последний ответ 23.03.2019, 21:53:08
от sivers