Новости Joomla

Вышел WT Quick links v.2.4.0 - релиз модуля для Joomla

Вышел WT Quick links v.2.4.0 - релиз модуля для Joomla.Это модуль-конструктор для быстрого создания набора элементов. Это могут быть ссылки на компоненты Joomla, пункт меню или пользовательская ссылка. Есть условия для исключений показа элементов списка. Вы можете создавать собственные макеты вывода модуля, создавая таким образом почти всё, что угодно: от простого списка ссылок до стены фотографий на главную страницу или ссылки-теги для перелинковки категорий интернет-магазина, список FAQ, табы или аккордеоны. Модуль позволяет выводить изображения, адаптивные изображения, видео, адаптивные видео.v.2.4.0. Что нового?Добавлена поддержка новых компонентов. Добавлены новые типы ссылок и исключений для них: - Phoca Download, - Phoca Gallery, - RadicalMart (@radicalmart).Joomla 6. Успешно протестирована работа модуля на Joomla 6-alpha2.РазработчикамПроведён большой рефакторинг кода. Для типов ссылок созданы классы-драйверы. Теперь для того, чтобы добавить новый тип ссылки в модуль достаточно скопировать класс-образец из
modules/mod_wt_quick_links/src/Driver/Collection и наполнить его данными по образцу, а так же добавить необходимые языковые константы в панели администратора Joomla.Модуль бесплатный. Страница расширенияGitHub расширенияJoomla Extensions Directory👩‍💻 Подпишись на @joomlafeed.#joomla #разработка

Свои типы полей в Joomla.Это большая тема, о которой можно говорить очень много

Свои типы полей в Joomla.Это большая тема, о которой можно говорить очень много

👩‍💻 Свои типы полей в Joomla.Это большая тема, о которой можно говорить очень много. Самое главное, что возможности применения ограничиваются только вашей больной фантазией. Вы строите интерфейс своего модуля или плагина и вам нужно подтянуть данные из сторонней системы (список чего-нибудь по какому-нибудь API), чтобы сохранить выбранный id в Joomla. Или сделать какую-то проверку и в зависимости от неё показать то или иное сообщение пользователю. Для этого подойдут свои пользовательские типы полей. Интерфейс Joomla по большей части описан в XML-файлах. У каждого из них свои параметры. Некоторые не описаны в документации (manual.joomla.org), поэтому самым любопытным будет полезно заглянуть в собственно файлы фреймворка по пути

libraries/src/Form/FormField.php, а так же в
libraries/src/Form/Fields. У каждого класса поля перечислены его специфические свойства, которые можно описывать в XML. А в своём типе поля вы можете устанавливать эти значения программно. В моём модуле WT Quick links под капотом происходят изменения. Теперь для работы (в админке) ему нужен вспомогательный плагин. А в самом модуле нам бы проверить, а не выключен ли он? В Joomla есть тип поля Note - заметка. Его можно использовать для вывода примечаний.

<field type="note"     name="your_note_for_user"     label="Заголовок примечания"     title="Альтернативный способ для заголовка"     description="Текст примечания"     class="col-12 alert alert-info"     heading="h1"     close="true"/>
heading - указывать уровень заголовка.
close - позволяет закрыть это примечание. В классе поля
libraries/src/Form/Field/NoteField.php описана логика вывода. И в принципе оно нам подходит для нашей задачи. Но оно будет выводить сообщение всегда, а нам нужно только тогда, когда плагин отключён.Поэтому берём и создаём свой класс поля, который мы унаследуем от
NoteField. Это значит, что у нас в руках будет весь инструментарий стандартного поля
Note + то, что мы сами добавим. В XML-манифест добавляем наше поле
<field type="systempluginstatus"      name="systempluginstatus"     addfieldprefix="Joomla\Module\Wtquicklinks\Site\Fields"/>
-
type - имя файла и класса,-
addfieldprefix - указываем namespace к нашему классу, может быть любой нам нужный-
name - нельзя полю без имени...Это означает, что Joomla будет использовать класс поля из файла
modules/mod_wt_quick_links/src/Fields/SystempluginstatusField.php.А в классе поля будет написано следующее:
<?php// namespace для атрибута addfieldprefixnamespace Joomla\Module\Wtquicklinks\Site\Fields;// нельзя напрямую обращаться к этому файлуdefined('_JEXEC') or die;// подключаем родительский класс для переопределенияuse Joomla\CMS\Form\Field\NoteField;use Joomla\CMS\Language\Text;use Joomla\CMS\Plugin\PluginHelper;// имя класса и имя файла точь-в-точьclass SystempluginstatusField extends NoteField{     protected $type = 'Systempluginstatus';     protected function getLabel()          {               // если плагин не включён               if(PluginHelper::isEnabled('system','wtquicklinks')) {                    // меняем свойства родительского класса                    $this->class = 'alert alert-danger w-100';                    $this->element['label'] = '⚠️ А-а-а-а!';                    $this->element['description'] = 'Плагин не включён!!';                    // и просто рендерим его с нашими свойствами                    return parent::getLabel();               }          // А иначе всё хорошо, скрываем поле из виду.          $this->parentclass = 'd-none';          return '';     }}
Просто и удобно. И людям приятно, что о них позаботились и рассказали почему что-то не работает.@webtolkru#joomla #php #webdev #разработка

Обновлена информация в Плане развития Joomla

👩‍💻 Обновлена информация в Плане развития Joomla.Здесь собрана информация о датах релизов, описаны принципы версионирования, указаны ответственные за релизы, а так же даты окончания поддержки релизов. Опираясь на эту информацию вы можете планировать развитие ваших интернет-проектов.👩‍💻 Что нового?⛔️ Joomla 4.Дата окончания исправления ошибок безопасности в версии 4.x - 14 октября 2025г. ⚠️ После этой даты Joomla 4 прекратит получать какие-либо обновления, в том числе безопасности - вообще. Рекомендуем обновить ваши сайты до актуальной Joomla 5.✅ Joomla 5.- Дата окончания исправления ошибок в версии 5.x - 13 октября 2026г.- Дата окончания исправления ошибок безопасности в версии 5.x - 12 октября 2027 года.- Текущая актуальная (на момент написания заметки) версия - 5.3.1.- Опубликовано расписание выхода релизов Joomla 5.4. Стабильный релиз ожидается 14 октября 2025 года.✅ Joomla 6.- Дата окончания исправления ошибок в версии 6.x - 17 октября 2028г.- Дата окончания исправления ошибок безопасности в версии 6.x - 16 октября 2029г.- Опубликовано расписание выхода релизов Joomla 6.0. Стабильный релиз ожидается 14 октября 2025 года.- Для разработчиков уже доступна Joomla 6.0.0-alpha1.✅ Joomla! Framework.Обновлена информация о Joomla! Framework - полноценном PHP-фреймворке для разработки. Он в версиях 1.х и 2.х был самостоятельным параллельным проектом, однако начиная с версии Joomla 4.0 стал её основой. Добавлена информация о Joomla! Framework 3.x, который вышел 6 октября 2023 года. Его можно использовать в тех случаях, когда вам в проекте не нужна CMS Joomla целиком.Подробнее на сайте Joomla-сообщества Joomlaportal.ru#joomla #community

0 Пользователей и 1 Гость просматривают эту тему.
  • 23 Ответов
  • 1102 Просмотров
*

Vas80

  • Захожу иногда
  • 238
  • 0 / 1
Делаю через поле Sql выборку статей
Получаю в админке название статьи

А чтобы прикреплять статью вот так


В коде вывожу название статьи через всем известный код
<?php
// Вывод дополнительных полей
$additionalFields = array(); //Создаем пустой массив, имя переменной выставляем по своему усмотрению
foreach($this->item->jcfields as $field) {/*Пробегаемся циклом по всем полям текущего материала*/
$additionalFields[$field->name] = $field->value; /*И добавляем их значения в наш ранее созданный массив*/
}

$fieldsLink = array(); //Создаем пустой массив, имя переменной выставляем по своему усмотрению
foreach($this->item->jcfields as $field) {/*Пробегаемся циклом по всем полям текущего материала*/
$fieldsLink[$field->name] = $field->rawvalue; /*И добавляем их значения в наш ранее созданный массив*/
}
?>

Все работает. Но как получить ссылку на выбранную статью. Если в массиве присутствует только поле alias.
Идея в том, чтобы не вводить url вручную, как здесь.
« Последнее редактирование: 21.10.2020, 12:51:24 от Vas80 »
*

NewUsers

  • Живу я здесь
  • 2310
  • 216 / 0
  • +375 (25) 627-16-99 (WhatsApp, Telegram)
Но как получить ссылку на выбранную статью.
Код: php
JRoute::_(ContentHelperRoute::getArticleRoute(slug, catid, language));
slug - это id:alias
НО, тип поля SQL поддерживает только два параметра в select (text, value).
Как вариант возвращать id и title и переименовать из в имена value и text что корректно встали данные в выпадающий список. В вашем коде добавить один запрос в базу что бы получить alias и title материала который выбрали.... (Если у вас сайт мультиязычный, то и язык выводить тоже надо будет)
Занимаюсь создание расширений для Joomla 4.2.x | Доработка и настройка сайтов. Занимаюсь создание Интернет магазинов с нуля на собственном компоненте + оптимизация загрузки страницы (после предоставляю техподдержку).
*

Vas80

  • Захожу иногда
  • 238
  • 0 / 1
А как сделать такой запрос, чтобы одновременно вытаскивать из базы alias и title
и потом связывать выбранные данные с значениями поля sql value и text?
*

NewUsers

  • Живу я здесь
  • 2310
  • 216 / 0
  • +375 (25) 627-16-99 (WhatsApp, Telegram)
А как сделать такой запрос, чтобы одновременно вытаскивать из базы alias и title
Код: sql
SELECT alias, title FROM #__content WHERE id = 1;

и потом связывать выбранные данные с значениями поля sql value и text?
Вам нужно указать в поле Запрос сам запрос который будет выводить данные в выпадающий список
Код: sql
SELECT id as value, title as text FROM #__content
Занимаюсь создание расширений для Joomla 4.2.x | Доработка и настройка сайтов. Занимаюсь создание Интернет магазинов с нуля на собственном компоненте + оптимизация загрузки страницы (после предоставляю техподдержку).
*

Vas80

  • Захожу иногда
  • 238
  • 0 / 1
Ну и в чем логика. В статье мне нужно получить url страницы, которая привязана к автору


А я получаю по id просто первую статью
<?php
      $db = JFactory::getDbo();
        $query = $db->getQuery(true);
        $query->select('alias, title');
        $query->from($db->quoteName('#__content'));
      $query->where($db->quoteName('id'). " = " . (int)1);
        $db->setQuery($query);
       
       $result = $db->loadObjectList();
      print_r($result);
?>
« Последнее редактирование: 21.10.2020, 12:50:53 от Vas80 »
*

NewUsers

  • Живу я здесь
  • 2310
  • 216 / 0
  • +375 (25) 627-16-99 (WhatsApp, Telegram)
В статье мне нужно получить url страницы, которая привязана к автору
Прочитайте то что вы сами написали Как получить ссылку на статью это ни как не вяжется с тем что вы хотите получить ссылку на страницу автора, вы и так ее получаете...

У вас поле Ссылка на страницу автора тоже добавлено как доп. поле, и вы хотите получить значение этого поля в другом поле.
Что за гавно вы лепите!
Занимаюсь создание расширений для Joomla 4.2.x | Доработка и настройка сайтов. Занимаюсь создание Интернет магазинов с нуля на собственном компоненте + оптимизация загрузки страницы (после предоставляю техподдержку).
*

Vas80

  • Захожу иногда
  • 238
  • 0 / 1
Еще раз....
Смотрите
Joomla раздел Пользователи. Поля.

1. Добавляю в поле sql запрос SELECT id as value, title as text FROM #__content


2. Выбираю пользователя и уже в профиле выбираю статью (страница пользователя, которая создана в материалах)


3. Необходимо получить ссылку прикрепленного материала.

Логика:
На страницах блога прикреплять Автора статьи и выводить ссылкой через дополнительное поле sql в профиле на страницу Автора, которая создана
в материалах

То есть не создавать страницу Автора в компоненте "Контакты", как это делается по умолчанию в Joomla.
На сайте создан раздел "Специалисты". Каждый специалист - это стандартный материал Joomla.
Создается Пользователь. В профиле пользователя прикрепляется материал (страница с таким же названием пользователя/автора)
И теперь надо как-то вытаскивать ссылку на выбранный материал в профиле.
« Последнее редактирование: 21.10.2020, 12:50:39 от Vas80 »
*

sivers

  • Живу я здесь
  • 2578
  • 357 / 0
А что мешает указать ИД автора в материале (поле `created_by`) и потом подтягивать материал по этому полю?
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

Vas80

  • Захожу иногда
  • 238
  • 0 / 1
дружище подскажи как это сделать на практике
*

sivers

  • Живу я здесь
  • 2578
  • 357 / 0
Ну как. Стандартно. При добавлении/редактировании материала указать автором одноименного юзера. Если через админку, то на закладке "Параметры публикации". Если через фронт, то надо смотреть как там сделано.
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

Vas80

  • Захожу иногда
  • 238
  • 0 / 1
так и делаю. а как кодом ссылку получить из дополнительного поля sql? вот в чем вопрос?
надо чтобы читатель статьи попадал на страницу Автора через кликабельную ссылку
« Последнее редактирование: 21.10.2020, 12:50:18 от Vas80 »
*

sivers

  • Живу я здесь
  • 2578
  • 357 / 0
а как кодом ссылку получить
надо знать 2 вещи:
1. На какой странице (компонент/вид) вы хотите получить ссылку? На странице материала или на странице контакта?
2. На какую страницу нужна ссылка? На страницу материала, в котором описание автора? Или на страницу контакта?
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

Vas80

  • Захожу иногда
  • 238
  • 0 / 1
1. На какой странице (компонент/вид) вы хотите получить ссылку? На странице материала или на странице контакта?
Ответ: на странице материала (стандартный компонент материала)
com_content
article
default.php


2. На какую страницу нужна ссылка? На страницу материала, в котором описание автора? Или на страницу контакта?
Ответ: на страницу материала, в котором описание автора (страница которая прикреплена в профиле через поле sql)
« Последнее редактирование: 20.10.2020, 13:55:10 от Vas80 »
*

sivers

  • Живу я здесь
  • 2578
  • 357 / 0
Код
$cont = JFactory::getDbo()->setQuery("SELECT `id`, `alias`, `catid`, `language` FROM `#__content` WHERE `catid` = '{$catId}' AND `created_by` = '{$this->item->created_by}'")->loadObject();
$contLink = JRoute::_(ContentHelperRoute::getArticleRoute($cont->slug, $cont->catid, $cont->language));
где $catId - это ид категории, в которой хранятся описания авторов; $this->item - текущий материал
Здесь предполагается, что код будет вставлен в макет материала и что ИД автора просматриваемого и подтягиваемого материала совпадает. А так же - что все материалы с описанием авторов лежат в отдельной категории.
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

Vas80

  • Захожу иногда
  • 238
  • 0 / 1
не. не выводиться ссылка статьи автора

$cont = JFactory::getDbo()->setQuery("SELECT `id`, `alias`, `catid`, `language` FROM `#__content` WHERE `catid` = '16' AND `created_by` = '{$this->item->created_by}'")->loadObject();
$contLink = JRoute::_(ContentHelperRoute::getArticleRoute($cont->slug, $cont->catid, $cont->language));
print_r($contLink);

====
`catid` = '16' подставил цифру категории
=====
вывело просто категорию там где специалисты
/index.php/speczialisty.html

сам специалист находится по url
/index.php/speczialisty/askerova-vusala.html
« Последнее редактирование: 21.10.2020, 12:50:05 от Vas80 »
*

Vas80

  • Захожу иногда
  • 238
  • 0 / 1
Код
$cont = JFactory::getDbo()->setQuery("SELECT `id`, `alias`, `catid`, `language` FROM `#__content` WHERE `catid` = '{$catId}' AND `created_by` = '{$this->item->created_by}'")->loadObject();
$contLink = JRoute::_(ContentHelperRoute::getArticleRoute($cont->slug, $cont->catid, $cont->language));
где $catId - это ид категории, в которой хранятся описания авторов; $this->item - текущий материал
Здесь предполагается, что код будет вставлен в макет материала и что ИД автора просматриваемого и подтягиваемого материала совпадает. А так же - что все материалы с описанием авторов лежат в отдельной категории.
Сообщение выше написал.
*

Vas80

  • Захожу иногда
  • 238
  • 0 / 1
Там скорее всего надо как-то достучаться в запросе к произвольному полю sql что в профиле пользователя
и оттуда вытаскивать ссылку
*

sivers

  • Живу я здесь
  • 2578
  • 357 / 0
Проверяйте что у вас получается на каждом шагу (строке):
Код
$cont = JFactory::getDbo()->setQuery($query = "SELECT `id`, `alias`, `catid`, `language` FROM `#__content` WHERE `catid` = '{$catId}' AND `created_by` = '{$this->item->created_by}'")->loadObject();
print_r($query);
print_r($cont);
Должна вывестись строка запроса и результат запроса - напишите их сюда.

Добавьте еще:
Код
print_r($this->item);
А ссылка на материал в профиле юзера, имхо, лишнее. И запроса 2 требует.
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

Vas80

  • Захожу иногда
  • 238
  • 0 / 1
print_r($query);
Выводит SELECT `id`, `alias`, `catid`, `language` FROM `#__content` WHERE `catid` = '' AND `created_by` = '688'


print_r($cont);
Выводит ничего

print_r($this->item);
Выводит всю информацию о текущей статье. Там тоже нет ссылки на другую статью автора из другой категории.
*

sivers

  • Живу я здесь
  • 2578
  • 357 / 0
print_r($query);
Выводит SELECT `id`, `alias`, `catid`, `language` FROM `#__content` WHERE `catid` = '' AND `created_by` = '688'
1. Если в категории с ИД = 16 у вас лежат материалы с инфой об авторах, то перед запросом к БД добавьте строку $catId = 16;:
Код
$catId = 16;
$cont = JFactory::getDbo()->setQuery($query = "SELECT `id`, `alias`, `catid`, `language` FROM `#__content` WHERE `catid` = '{$catId}' AND `created_by` = '{$this->item->created_by}'")->loadObject();
print_r($query);
print_r($cont);
2. Если все равно ничего не выведет, то откройте в админке материал с инфой об авторе и на закладке "Параметры публикации" проверьте, чтоб автором был указан правильный автор (у которого ИД = 688).
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

Vas80

  • Захожу иногда
  • 238
  • 0 / 1
Да. Есть. Появился нужный alias автора

SELECT `id`, `alias`, `catid`, `language` FROM `#__content` WHERE `catid` = '16' AND `created_by` = '688'stdClass Object
(
    [id] => 117
    [alias] => askerova-vusala
    [catid] => 16
    [language] => *
)

А как теперь получить полноценную ссылку на автора
$contLink = JRoute::_(ContentHelperRoute::getArticleRoute($cont->slug, $cont->catid, $cont->language));
print_r($contLink);
Такой код выводит на категорию там где размещен автор
*

sivers

  • Живу я здесь
  • 2578
  • 357 / 0
пардон, проглядел, там ссылку немного не так получать надо. попробуйте это:
Код
$contLink = JRoute::_(ContentHelperRoute::getArticleRoute($cont->id.':'.$cont->alias, $cont->catid, $cont->language));
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

Vas80

  • Захожу иногда
  • 238
  • 0 / 1
Ай маладец. То что надо! Получил ссылку автора и действительно.
Гениально!
*

gartes

  • Завсегдатай
  • 1859
  • 142 / 6
  • Е = mс²
Простите меня что вклинился в вопрос ! - собственно решение - ВЫ нашли !
Автор: Vas80 : А можно узнать для чего вам эта ссылка ?
С Уважением !
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Вставка видео со своего сервера через media manager

Автор goga_pgasovav

Ответов: 2
Просмотров: 855
Последний ответ 27.03.2025, 14:51:43
от Akeksandr
[Решено] Получить category description image в index.php шаблона

Автор goga_pgasovav

Ответов: 6
Просмотров: 1006
Последний ответ 12.07.2024, 17:06:14
от goga_pgasovav
Регистрация и авторизация через соц сети

Автор DamaVbubi

Ответов: 3
Просмотров: 1488
Последний ответ 14.04.2024, 16:15:05
от Гоша_Компьютерный
Убрать из модуля новостей ссылку на статью, на которой выводится модуль

Автор zeus07

Ответов: 3
Просмотров: 1256
Последний ответ 08.11.2023, 21:17:26
от GrayAn
Получить ошибку

Автор KevinSimon

Ответов: 0
Просмотров: 548
Последний ответ 22.09.2023, 15:20:21
от KevinSimon