Новости Joomla

👩‍💻 Компонент "CS Афиши" для Joomla.

👩‍💻 Компонент "CS Афиши" для Joomla.

Расширение "CS Афиши" позволяет выводить список мероприятий, фильтровать их по датам, поиск по заголовкам и описанию.

В состав пакета расширений входят:
- Компонент "CS Афиши"
- Модуль "Календарь событий"
- Модуль "Предстоящие события"
- Библиотека "ImgResize"

Расширение "CS Афиши" позволяет выводить список мероприятий, фильтровать их по датам, поиск по заголовкам и описанию.

Модуль "Календарь событий" отображает предстоящие и прошедшие мероприятие на календаре, с отображением мероприятий на конкретную дату во всплывающем окне.

Модуль "Предстоящие события" показывает список предстоящий событий по порядку их наступления.

P.S. Расширение платное, но плата символическая, чисто для отработки приема платежей. Ключи без ограничения по времени, купившие сейчас - смогут обновляться без ограничений.

Разработчик - участник нашего сообщества Дмитрий Денисов (@codersite).

Страница расширения
Демо

Яндекс выпустил инструмент Видимость сайта в Алисе AI.

Яндекс выпустил инструмент Видимость сайта в Алисе AI.

С тех пор, как в поисковиках появились нейроответы ИИ, трафик на сайты стал гораздо меньше, так как пользователь стал получать информацию непосредственно на странице поисковика без перехода на сайт. Но при генерации ответа ИИ указывает источники - ссылки на сайты, информация которых была использована для генерации ответа.

Долгое время у всех был немой вопрос: "Как же теперь оценивать эффективность сайта?". Теперь этот на этот вопрос отчасти отвечает новый инструмент аналитики.
Процитируем справку Яндекса по инструменту:
На запросы пользователей в Поиске может отвечать Алиса AI. Ответы появляются в поисковой выдаче, в объектных ответах и на отдельной вкладке Поиска. В них чаще всего упоминаются страницы сайтов, на которые Алиса AI опиралась при подготовке ответа.

С помощью инструмента Видимость сайта в Алисе AI в Яндекс Вебмастере вы можете:
- узнать долю упоминаний сайта среди источников в ответах Алисы AI в Поиске и отследить динамику изменений;
- посмотреть примеры запросов, по которым страницы сайта показываются в ответах Алисы AI;
- посмотреть примеры сайтов той же тематики, которые часто упоминаются в генеративной выдаче.
Данные отображаются за последние 3 месяца и обновляются каждую неделю.

Статистика собирается только по тем запросам, по которым ваш сайт уже находится достаточно высоко в поисковой выдаче. Это позволяет анализировать видимость именно в той нише, где вы заинтересованы в продвижении, и избегать «размытия» по малозначимым для вас запросам.

Кроме того, такой подход обусловлен работой Алисы AI: она строит ответ с опорой на самые релевантные, информативные и качественные страницы, которые обычно занимают высокие позиции в Поиске.

Чтобы увидеть статистику вашего сайта в меню Яндекс.Вебмастера перейдите в раздел "Эффективность" и далее в "Показы сайта в Алисе AI".

В начале февраля 2026г. был вебинар с Михаилом Сливинским - амбассадором Поиска Яндекса, и в рамках вебинара была озвучена просьба сделать такой инструмент. Скорее всего разработка на тот момент уже велась, потому что от просьбы до релиза прошло около 2-х месяцев. В любом случае хорошо, что такая статистика появилась.

Показы сайта в Алисе AI в вашем Яндекс,Вебмастере.

@joomlafeed

👩‍💻 ИИ-админ для Joomla ближе, чем вы думаете: Joomla MCP.

👩‍💻 ИИ-админ для Joomla ближе, чем вы думаете: Joomla MCP.

В февральском номере Joomla Community Magazine в статье Evolving Joomla - Joomla CMS MCP Server: Opening the Door to AI-Powered Administration рассказывается о работе команды разработчиков над внедрением в ядро Joomla MCP-сервера.

Что такое MCP-сервер?
Последние годы всех захватывает бум ИИ-технологий. Появились ИИ-агенты - программы, устанавливаемые на сервер или компьютер, которые получают от вас запрос или задачу в человеческом виде и могут выполнять действия с файлами, ходить по сайтам, создавать сайты, программировать и т.д. Люди используют ИИ-агентов в самых разных ситуациях: от написания и проверки кода (даже там, где язык программирования не знаете совсем) до планирования путешествий и бронирования гостиницы.

ИИ-агенты могут использовать различные программные инструменты по протоколу Model Context Protocol (MCP). Для этого разработчик программы должен внедрить MCP в свой продукт или сервис. Так, например, ваш ИИ-агент может ходить по сайтам через браузер и собирать нужную информацию, управляя браузером через MCP-сервер. Или использовать функционал IDE PHP Storm для написания кода, сбора и отладки ошибок, использовать поиск PHP Storm по кодовой базе, а не простой текстовый поиск по файлам. MCP предоставляет набор функций для полноценного управления программным обеспечением.

В случае с Joomla, сервер MCP может предоставить администраторам следующие возможности:
- Автоматическое создание категорий, материалов и меню на основе карты сайта или PDF-файла.
- Создавайть SEO-оптимизированные заголовки и метаописания в пакетном режиме.
- Обновлять расширения на нескольких сайтах одновременно
- Создание посадочные страницы.

Важно отметить, что сервер MCP не задумывался как функция, доступная только «супер-администраторам». Цель инициативы — создать решение, которое будет простым в настройке, маломощным и доступным для широкого круга пользователей.

В процессе разработки точка входа Joomla (аналогично Site, Administrator, Api, Cli), которая будет работать с Streamable HTTP, необходимым для MCP. Аутентификация пока что предполагается на токенах, но затем планируется создание универсального OAuth-сервера для Joomla.
Фактические возможности MCP — инструменты, ресурсы и подсказки — реализованы в виде плагинов для обеспечения расширяемости. Таким образом ожидаем, что и сторонние разработчики смогут создавать MCP-плагины для внедрения поддержки своих расширений Joomla для работы с ИИ.

@joomlafeed

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

Aspik

  • Давно я тут
  • 542
  • 63 / 2
  • В личку не писать, не отвечу.
Пишу плагин для вывода alternate url. (для мультиязычных сайтов)
Есть ли событие типа onBeforeCompileHead, но для компонента JS.
Или любое другое событие которое отправит $html в head до вывода скриптов?
Как получить альтернативные url существующих языков?

Базовый код плагина:


Код
class plgJshoppingProductsJSextalternateurl extends JPlugin {

function __construct(&$subject, $config){
        parent::__construct($subject, $config);
    }

public function onBeforeDisplayProduct(&$product) {  
//
$document = JFactory::getDocument();
$lang = JFactory::getLanguage();
$lang_tag = $lang->getTag();

foreach (JLanguageHelper::getLanguages() as $language) {
if ($language->lang_code != $lang_tag)  {
//print_r($language->lang_code);
$alias = 'alias_'.$language->lang_code;
//print_r($product);
$product_id = JRequest::getInt('product_id');
$category_id = JRequest::getInt('category_id');

if ($product->$alias != '') {
$url = SEFLink('index.php?option=com_jshopping&controller=product&task=view&category_id='.$category_id.'&product_id='.$product_id, 1);
$html = '<link href="'.$url.'" rel="alternate" hreflang="'.$language->lang_code.'" />';
$document->addCustomTag($html);
}
}
}
}
}

« Последнее редактирование: 26.11.2013, 23:52:43 от Aspik »
Мои расширения - http://eco-joom.com/ru/
*

ELLE

  • Глобальный модератор
  • 4505
  • 893 / 0
Re: Есть ли событие типа onBeforeCompileHead ?
« Ответ #1 : 26.11.2013, 23:06:54 »
Есть ли событие типа onBeforeCompileHead, но для компонента JS.
обычно по контексту определяют, если плагин системный

для JS такого отдельного нету, насколько я знаю
триггеров вообще много, но под конкретные события
*

Aspik

  • Давно я тут
  • 542
  • 63 / 2
  • В личку не писать, не отвечу.
Re: Есть ли событие типа onBeforeCompileHead ?
« Ответ #2 : 26.11.2013, 23:22:04 »
Вопросов даже 2, но они связанные.
1) Как получить альтернативные url существующих языков. (Проверка на альтернативный язык представлена в первом посте)
2) Как отправить в head тег типа "<link href="URL" rel="alternate" hreflang="LANG" />"

Или может быть разработчик это в компонент по умолчанию сделает ? Я не вижу нормальных способов получения альтернативных url.

Мои расширения - http://eco-joom.com/ru/
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Есть ли событие типа onBeforeCompileHead ?
« Ответ #3 : 26.11.2013, 23:30:06 »
самое первое событие в ЖШ это
Код
            JPluginHelper::importPlugin('jshopping');
            $dispatcher = JDispatcher::getInstance();
            $dispatcher->trigger('onLoadJshopConfig', array(&$config));
только не пойму чем не подходит onBeforeCompileHead? и не пойму конечную цель
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

Fedor Vlasenko

  • Живу я здесь
  • 3845
  • 733 / 7
  • https://fedor-vlasenko.web.app
Re: Есть ли событие типа onBeforeCompileHead ?
« Ответ #4 : 26.11.2013, 23:33:21 »
В смысле
Код: php-brief
$url = str_replace('/ru/', '/en/', JFactory::getURI()->toString());
2.
Код: php-brief
$doc = JFactory::getDocument();
$doc->addCustomTag( '<link href="URL" rel="alternate" hreflang="LANG" />' );
*

Aspik

  • Давно я тут
  • 542
  • 63 / 2
  • В личку не писать, не отвечу.
Re: Есть ли событие типа onBeforeCompileHead ?
« Ответ #5 : 26.11.2013, 23:50:10 »
В смысле
Код: php-brief
$url = str_replace('/ru/', '/en/', JFactory::getURI()->toString());
2.
Код: php-brief
$doc = JFactory::getDocument();
$doc->addCustomTag( '<link href="URL" rel="alternate" hreflang="LANG" />' );



1) alias разные, как правильно сформировать url вопрос остается.
2) с addCustomTag то решение я сделал:

Код плагина:
Код
class plgJshoppingProductsJSextalternateurl extends JPlugin {

function __construct(&$subject, $config){
        parent::__construct($subject, $config);
    }

public function onBeforeDisplayProduct(&$product) {  
//
$document = JFactory::getDocument();
$lang = JFactory::getLanguage();
$lang_tag = $lang->getTag();

public function onBeforeDisplayProduct(&$product) { 
//
$document = JFactory::getDocument();
$lang = JFactory::getLanguage();
$lang_tag = $lang->getTag();

foreach (JLanguageHelper::getLanguages() as $language) {
if ($language->lang_code != $lang_tag)  {
//print_r($language->lang_code);
$alias = 'alias_'.$language->lang_code;
//print_r($product);
$product_id = JRequest::getInt('product_id');
$category_id = JRequest::getInt('category_id');
$Itemid = JRequest::getInt('Itemid');

if ($product->$alias != '') {
$url = SEFLink('index.php?option=com_jshopping&controller=product&task=view&category_id='.$category_id.'&product_id='.$product_id.'&Itemid='.$Itemid.'&lang='.$language->sef, 1);
$html = '<link href="'.$url.'" rel="alternate" hreflang="'.$language->lang_code.'" />';
$document->addCustomTag($html);
}
}
}
}

}




При выключенном ЧПУ такой вид URL рабочий. (Был добавлен &lang='.$language->sef)

Код
$url = SEFLink('index.php?option=com_jshopping&controller=product&task=view&category_id='.$category_id.'&product_id='.$product_id.'&lang='.$language->sef, 1);
« Последнее редактирование: 27.11.2013, 09:26:25 от Aspik »
Мои расширения - http://eco-joom.com/ru/
*

Fedor Vlasenko

  • Живу я здесь
  • 3845
  • 733 / 7
  • https://fedor-vlasenko.web.app
Re: Есть ли событие типа onBeforeCompileHead ?
« Ответ #6 : 27.11.2013, 00:18:14 »
нужно добавить к ссылке язык я так понимаю
а какой адрес у ссылки сейчас
что выведет echo $_SERVER["HTTP_HOST"].'/index.php?' . http_build_query($_REQUEST);
*

Aspik

  • Давно я тут
  • 542
  • 63 / 2
  • В личку не писать, не отвечу.
Re: Есть ли событие типа onBeforeCompileHead ?
« Ответ #7 : 27.11.2013, 00:21:09 »
нужно добавить к ссылке язык я так понимаю
а какой адрес у ссылки сейчас
что выведет echo $_SERVER["HTTP_HOST"].'/index.php?' . http_build_query($_REQUEST);



Добавления языка при включенном ЧПУ ничего не меняет.
При выключенном ЧПУ такой вид URL рабочий. (Был добавлен &lang='.$language->sef)

Код
$url = SEFLink('index.php?option=com_jshopping&controller=product&task=view&category_id='.$category_id.'&product_id='.$product_id.'&lang='.$language->sef, 1);
Мои расширения - http://eco-joom.com/ru/
*

Fedor Vlasenko

  • Живу я здесь
  • 3845
  • 733 / 7
  • https://fedor-vlasenko.web.app
Re: Есть ли событие типа onBeforeCompileHead ?
« Ответ #8 : 27.11.2013, 00:30:04 »
какие сейчас есть ссылки и для каких языков и какие они должны быть. Почему не использовать замену с помощью  str_replace
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Есть ли событие типа onBeforeCompileHead ?
« Ответ #9 : 27.11.2013, 00:38:43 »
Цитировать
Почему не использовать замену с помощью  str_replace
alias разный для разных языков. не получится просто замена.

1. вызываем SEFLink с флагом языка.
2. onBeforeBuildRoute - смотрим, если есть на флаг, делаем $query = array() чтобы не выполнялись условия в роутере, попутно сохраняя $query в плагине в первоначальном виде для дальнейшего использования
3. onAfterBuildRoute - дублируем блок роутера, отвечающий за генерацию ссылки на товар, заменяя JSFactory::getAliasProduct() и JSFactory::getAliasCategory() своими обработками с учетом нужного языка. исходя из начальной $query генерируем алиас
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

Fedor Vlasenko

  • Живу я здесь
  • 3845
  • 733 / 7
  • https://fedor-vlasenko.web.app
Re: Есть ли событие типа onBeforeCompileHead ?
« Ответ #10 : 27.11.2013, 01:17:04 »
Цитировать
alias разный для разных языков. не получится просто замена
что мешает менять алиасы? их я вытащу одним запросом с базы насколько я понимаю
тем самым уменьшу количество запросов на формировании ссылок стандартным роутером
Или они уже есть в $product
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Есть ли событие типа onBeforeCompileHead ?
« Ответ #11 : 27.11.2013, 02:09:13 »
ну можно и так конечно, но по сути в роутере и так по одному запросу делается на алиасы, а в дальнейшем статика возвращается уже. тут надо смотреть по ситуации, что по обработке проще. если бы речь шла только об алиасе товара - тут да, проще замена. а так тут же присутствует еще и алиас(ы) категории, и может быть в зависимости от вложенности категории: категория/подкатегория/подподкатегория/товар, а может быть проще - категория/товар. тяжеловато подмену будет делать. а если рассматривать вариант, когда для русского языка заполнен алиас, а для английского нет, то вообще :)
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

Fedor Vlasenko

  • Живу я здесь
  • 3845
  • 733 / 7
  • https://fedor-vlasenko.web.app
Re: Есть ли событие типа onBeforeCompileHead ?
« Ответ #12 : 27.11.2013, 02:25:11 »
Цитировать
а если рассматривать вариант, когда для русского языка заполнен алиас, а для английского нет
эт самое простое пропустили обработку данной части  ^-^
Aspik по коду для материалов пишет. Так прямо в карточку товара можно и всталять плагин то зачем
*

Aspik

  • Давно я тут
  • 542
  • 63 / 2
  • В личку не писать, не отвечу.
Re: Есть ли событие типа onBeforeCompileHead ?
« Ответ #13 : 27.11.2013, 09:37:44 »
эт самое простое пропустили обработку данной части  ^-^
Aspik по коду для материалов пишет. Так прямо в карточку товара можно и всталять плагин то зачем
Угу.
Код должен быть универсальным. Он должен работать как при включенном ЧПУ, так и без него.

По правилам компонента URL составлен правильно, есть category_id, product_id, Itemid и lang. Без ЧПУ все работает прекрасно. Вывод проблема в router.
router не может понять что я от него хочу когда добавляю lang. Нет он конечно меняет язык, заменяет один язык на другой в URL, но на этом все законченно.

Код
$url = SEFLink('index.php?option=com_jshopping&controller=product&task=view&category_id='.$category_id.'&product_id='.$product_id.'&Itemid='.$Itemid.'&lang='.$language->sef, 1);

Оставил эту разработку на потом.
Всем спасибо. Всем +
« Последнее редактирование: 27.11.2013, 09:43:27 от Aspik »
Мои расширения - http://eco-joom.com/ru/
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться