Новости 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 Ответов
  • 1514 Просмотров
*

H0ff

  • Осваиваюсь на форуме
  • 23
  • 0 / 0
Всем доброго времени суток.
Проблема такая.
Срегенил себе шаблон с двумя сайдбарами(левый правый)
Все нормально позиционируется.
Но мне нужно запихнуть в них n-ое количество блоков.
Запихнул.И теперь правый сайдбар падает под левый.Сижу ковыряю не могу понять в чем проблема.
Даю архив с шаблонами
Спойлер
[свернуть]
*

Shustry

  • Moderator
  • 6434
  • 745 / 3
Re: Правый сайдбар падает под левый
« Ответ #1 : 07.08.2014, 17:31:31 »
Ссылку на страницу выложите. Скачивать и что-то там ставить на своё комп, думаю, никто не будет.
*

H0ff

  • Осваиваюсь на форуме
  • 23
  • 0 / 0
Re: Правый сайдбар падает под левый
« Ответ #2 : 07.08.2014, 17:49:58 »
Сайт в локалке.
Это то что я срегенил:
Код
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<!--[if lt IE 9]><script src="http://html5shiv.googlecode.com/svn/trunk/html5.js"></script><![endif]-->
<title></title>
<meta name="keywords" content="" />
<meta name="description" content="" />
<link href="style.css" rel="stylesheet">
</head>

<body>

<div class="wrapper">

<header class="header">
<strong>Header:</strong> Lorem ipsum dolor sit amet, consectetur adipiscing elit. Cras tortor. Praesent dictum, libero ut tempus dictum, neque eros elementum mauris, quis mollis arcu velit ac diam. Etiam neque. Quisque nec turpis. Aliquam arcu nulla, dictum et, lacinia a, mollis in, ante. Sed eu felis in elit tempor venenatis. Cum sociis natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Ut ultricies porttitor purus. Proin non tellus at ligula fringilla tristique. Fusce vehicula quam. Curabitur vel tortor vitae pede imperdiet ultrices. Sed tortor.
</header><!-- .header-->

<div class="middle">

<div class="container">
<main class="content">
<strong>Content:</strong> Sed placerat accumsan ligula. Aliquam felis magna, congue quis, tempus eu, aliquam vitae, ante. Cras neque justo, ultrices at, rhoncus a, facilisis eget, nisl. Quisque vitae pede. Nam et augue. Sed a elit. Ut vel massa. Suspendisse nibh pede, ultrices vitae, ultrices nec, mollis non, nibh. In sit amet pede quis leo vulputate hendrerit. Cras laoreet leo et justo auctor condimentum. Integer id enim. Suspendisse egestas, dui ac egestas mollis, libero orci hendrerit lacus, et malesuada lorem neque ac libero. Morbi tempor pulvinar pede. Donec vel elit.
</main><!-- .content -->
</div><!-- .container-->

<aside class="left-sidebar">
<strong>Left Sidebar:</strong> Integer velit. Vestibulum nisi nunc, accumsan ut, vehicula sit amet, porta a, mi. Nam nisl tellus, placerat eget, posuere eget, egestas eget, dui. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. In elementum urna a eros. Integer iaculis. Maecenas vel elit.
</aside><!-- .left-sidebar -->

<aside class="right-sidebar">
<strong>Right Sidebar:</strong> Integer velit. Vestibulum nisi nunc, accumsan ut, vehicula sit amet, porta a, mi. Nam nisl tellus, placerat eget, posuere eget, egestas eget, dui. Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. In elementum urna a eros. Integer iaculis. Maecenas vel elit.
</aside><!-- .right-sidebar -->

</div><!-- .middle-->

<footer class="footer">
<strong>Footer:</strong> Mus elit Morbi mus enim lacus at quis Nam eget morbi. Et semper urna urna non at cursus dolor vestibulum neque enim. Tellus interdum at laoreet laoreet lacinia lacinia sed Quisque justo quis. Hendrerit scelerisque lorem elit orci tempor tincidunt enim Phasellus dignissim tincidunt. Nunc vel et Sed nisl Vestibulum odio montes Aliquam volutpat pellentesque. Ut pede sagittis et quis nunc gravida porttitor ligula.
</footer><!-- .footer -->

</div><!-- .wrapper -->

</body>
</html>

[b]CSS[/b]
* {
margin: 0;
padding: 0;
}
article, aside, details, figcaption, figure, footer, header, hgroup, main, nav, section, summary {
display: block;
}
body {
font: 12px/18px Arial, sans-serif;
width: 100%;
}
.wrapper {
width: 1000px;
margin: 0 auto;
}


/* Header
-----------------------------------------------------------------------------*/
.header {
height: 200px;
background: #FFE680;
}


/* Middle
-----------------------------------------------------------------------------*/
.middle {
width: 100%;
position: relative;
}
.middle:after {
display: table;
clear: both;
content: '';
}
.container {
width: 100%;
float: left;
overflow: hidden;
}
.content {
padding: 0 220px 0 220px;
}


/* Left Sidebar
-----------------------------------------------------------------------------*/
.left-sidebar {
float: left;
width: 200px;
margin-left: -100%;
position: relative;
background: #B5E3FF;
}


/* Right Sidebar
-----------------------------------------------------------------------------*/
.right-sidebar {
float: left;
width: 200px;
margin-left: -200px;
position: relative;
background: #FFACAA;
}


/* Footer
-----------------------------------------------------------------------------*/
.footer {
height: 200px;
background: #BFF08E;
}

Мое
Код
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<!--[if lt IE 9]><script src="http://html5shiv.googlecode.com/svn/trunk/html5.js"></script><![endif]-->
<title></title>
<meta name="keywords" content="" />
<meta name="description" content="" />
<link href="style.css" rel="stylesheet">
</head>

<body>

<div class="wrapper">

<header class="header">
<strong>ШАПКА</strong>
</header><!-- .header-->

<div class="middle">
<div class="topmenu"><jdoc:include type="modules" name="topmenu" style="xhtml" /><strong>МЕНЮ</strong></div>
<div class="container">
<main class="content">
<strong>КОНТЕНТ</strong>
</main><!-- .content -->
</div><!-- .container-->

<aside class="left-sidebar"><strong>ЛЕВЫЙ САЙД</strong>
<div class="position-left1"><jdoc:include type="modules" name="position-left1" style="xhtml" /></div>
<div class="position-left2"><jdoc:include type="modules" name="position-left2" style="xhtml" /></div>
<div class="position-left3"><jdoc:include type="modules" name="position-left3" style="xhtml" /></div>
</aside><!-- .left-sidebar -->

<aside class="right-sidebar"><strong>ПРАВЫЙ САЙД</strong>
<div class="position-right1"><jdoc:include type="modules" name="position-right1" style="xhtml" /></div>
<div class="position-right2"><jdoc:include type="modules" name="position-right2" style="xhtml" /></div>
<div class="position-right3"><jdoc:include type="modules" name="position-right3" style="xhtml" /></div>
</aside><!-- .right-sidebar -->

</div><!-- .middle-->

<footer class="footer"><strong>ФУТЕР</strong>

</footer><!-- .footer -->

</div><!-- .wrapper -->

</body>
</html>
[b]CSS[/b]
* {
margin: 0;
padding: 0;
}
article, aside, details, figcaption, figure, footer, header, hgroup, main, nav, section, summary {
display: block;
}
body {
font: 12px/18px Arial, sans-serif;
width: 100%;
}
.wrapper {
width: 1000px;
margin: 0 auto;
}


/* Header
-----------------------------------------------------------------------------*/
.header {
height: 200px;
background: #FFE680;
}


/* Middle
-----------------------------------------------------------------------------*/
.middle {
width: 100%;
position: relative;
}
.topmenu{
width:100%;
height:20px;
border-style:solid;
border-width:1px;
}
.middle:after {
display: table;
clear: both;
content: '';
}
.container {
width: 100%;
float: left;
overflow: hidden;

}
.content {
padding: 0 220px 0 220px;
border-style:solid;
border-width:1px;
}


/* Left Sidebar
-----------------------------------------------------------------------------*/
#left-sidebar {
float: left;
width: 200px;
margin-left: -100%;
position: relative;
background: #B5E3FF;
}
.position-left1{
background-color:#33CCFF;
width:190px;
height:250px;
border-style:solid;
border-width:1px;
}
.position-left2{
background-color:#33CCFF;
width:190px;
height:250px;
border-style:solid;
border-width:1px;
}
.position-left3{
background-color:#33CCFF;
width:190px;
height:250px;
border-style:solid;
border-width:1px;
}

/* Right Sidebar
-----------------------------------------------------------------------------*/
#right-sidebar {
float: left;
width: 200px;
margin-left: -200px;
position: relative;
background: #FFACAA;
}
.position-right1{
background-color:#33CCFF;
width:190px;
height:190px;
border-style:solid;
border-width:1px;
}
.position-right2{
background-color:#33CCFF;
width:190px;
height:190px;
border-style:solid;
border-width:1px;
}
.position-right3{
background-color:#33CCFF;
width:190px;
height:190px;
border-style:solid;
border-width:1px;
}

/* Footer
-----------------------------------------------------------------------------*/
.footer {
height: 200px;
background: #BFF08E;
}
*

midav

  • Давно я тут
  • 926
  • 115 / 1
Re: Правый сайдбар падает под левый
« Ответ #3 : 09.08.2014, 22:46:51 »
Найди два отличия. Оригинал :
Код
/* Left Sidebar
-----------------------------------------------------------------------------*/
.left-sidebar {
float: left;
width: 200px;
margin-left: -100%;
position: relative;
background: #B5E3FF;
}


/* Right Sidebar
-----------------------------------------------------------------------------*/
.right-sidebar {
float: left;
width: 200px;
margin-left: -200px;
position: relative;
background: #FFACAA;
}
и твой код :
Код
/* Left Sidebar
-----------------------------------------------------------------------------*/
#left-sidebar {
float: left;
width: 200px;
margin-left: -100%;
position: relative;
background: #B5E3FF;
}

...

/* Right Sidebar
-----------------------------------------------------------------------------*/
#right-sidebar {
float: left;
width: 200px;
margin-left: -200px;
position: relative;
background: #FFACAA;
}
Ответы на вопросы по CSS . Откройте для себя Firebug
*

H0ff

  • Осваиваюсь на форуме
  • 23
  • 0 / 0
Re: Правый сайдбар падает под левый
« Ответ #4 : 12.08.2014, 11:15:34 »
Найди два отличия. Оригинал :
Код
/* Left Sidebar
-----------------------------------------------------------------------------*/
.left-sidebar {
float: left;
width: 200px;
margin-left: -100%;
position: relative;
background: #B5E3FF;
}


/* Right Sidebar
-----------------------------------------------------------------------------*/
.right-sidebar {
float: left;
width: 200px;
margin-left: -200px;
position: relative;
background: #FFACAA;
}
и твой код :
Код
/* Left Sidebar
-----------------------------------------------------------------------------*/
#left-sidebar {
float: left;
width: 200px;
margin-left: -100%;
position: relative;
background: #B5E3FF;
}

...

/* Right Sidebar
-----------------------------------------------------------------------------*/
#right-sidebar {
float: left;
width: 200px;
margin-left: -200px;
position: relative;
background: #FFACAA;
}
Тю действительно. Все заработало огромное спасибо
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

[Решено] Слетает правый сайдбар на шаблоне protostar

Автор Mick_20

Ответов: 4
Просмотров: 2259
Последний ответ 28.05.2020, 15:45:06
от Muzzy
При уменьшении окна, правый столбик перепрыгивает влево

Автор smit1987

Ответов: 5
Просмотров: 1218
Последний ответ 28.04.2014, 01:03:30
от Shustry
Слетел правый блок

Автор laslatin

Ответов: 5
Просмотров: 1543
Последний ответ 21.06.2013, 12:50:06
от laslatin
Правый модуль съезжает под материалы в блоге

Автор profitural

Ответов: 1
Просмотров: 1867
Последний ответ 12.03.2013, 01:00:58
от midav
Правый блок съезжает вниз

Автор annaz

Ответов: 3
Просмотров: 4156
Последний ответ 03.05.2010, 01:25:24
от annaz