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

Adeptus

  • Завсегдатай
  • 1861
  • 219 / 15
По заказу проекта КурортСпб мною был написан

модифицированный модуль поиска для компонента MosetsTree v2.02

Модуль позволяет осуществлять универсальный поиск из одной формы по трем независимым направлениям:
1. поиск в каталоге MosetsTree
2. поиск по всему сайту
3. поиск в Интернете (Яндекс)

Одновременно исправлена имеющая место в MosetsTree известная проблема с неработоспособностью Поиска при вводе поискового запроса кириллицей. Теперь поиск осуществляется корректно и на английском, и на русском языках по всем трем направлениям.

По требованию Заказчика модуль распространяется на коммерческой основе.
Приобрести его можно на моем полигоне или у Заказчика.

Увидеть модуль в работе можно на моем полигоне-2 или на сайте Заказчика.

Скрин прилагается.


[вложение удалено Администратором]
« Последнее редактирование: 09.02.2008, 20:17:12 от Adeptus »
*

timonnn

  • Захожу иногда
  • 366
  • 15 / 0
Re: Новый модуль поиска для MosetsTree 2.XX
« Ответ #1 : 04.05.2009, 20:43:13 »
И какова стоимость на сегодняшний день. И можно увидеть в действии?
*

Adeptus

  • Завсегдатай
  • 1861
  • 219 / 15
Re: Новый модуль поиска для MosetsTree 2.XX
« Ответ #2 : 07.05.2009, 12:11:14 »
И какова стоимость на сегодняшний день. И можно увидеть в действии?

Обращайтесь в личные каналы связи - договоримся... :)
*

dimko300

  • Захожу иногда
  • 61
  • 1 / 0
Re: Новый модуль поиска для MosetsTree 2.XX
« Ответ #3 : 09.06.2009, 02:15:20 »
Доброго времени суток.
А можете сделать фильтрацию в категориях по заданным критериям? Т.е.
1. Я открываю категорию "Туробъекты" - в ней мне необходимо отобрать связанные по общему местонахождению или по общей тематике  и т.д. (все они связанны с Парент одной цепочкой)....
2. Я открываю Описание объекта, а мне необходимо найти все связанные с ним структуры - услуги, инфраструктуру, товары...
Фильтрация производится в идущих друг за другом окошках с дропдаун списками...
*

Adeptus

  • Завсегдатай
  • 1861
  • 219 / 15
Re: Новый модуль поиска для MosetsTree 2.XX
« Ответ #4 : 09.06.2009, 04:41:55 »
Доброго времени суток.
А можете сделать фильтрацию в категориях по заданным критериям?

Я все могу :)

Но удовольствие это не из самых дешевых.
*

dimko300

  • Захожу иногда
  • 61
  • 1 / 0
Re: Новый модуль поиска для MosetsTree 2.XX
« Ответ #5 : 09.06.2009, 14:34:07 »
Ну тогда назавите свой волшебный приговор :) и возможно Вы поможете решить мою проблему...
Только у меня асек всяких нет.... Общение через почту или по телефону.
*

Adeptus

  • Завсегдатай
  • 1861
  • 219 / 15
Re: Новый модуль поиска для MosetsTree 2.XX
« Ответ #6 : 09.06.2009, 19:30:39 »
Только у меня асек всяких нет.... Общение через почту или по телефону.

Ну тогда пишите в почту :)
*

dimko300

  • Захожу иногда
  • 61
  • 1 / 0
Re: Новый модуль поиска для MosetsTree 2.XX
« Ответ #7 : 09.06.2009, 22:35:34 »
Цитировать
Ну тогда пишите в почту

А почта где ?  ^-^
*

dimko300

  • Захожу иногда
  • 61
  • 1 / 0
Re: Новый модуль поиска для MosetsTree 2.XX
« Ответ #8 : 10.06.2009, 13:50:16 »
Я не знаю что Вы молчите? Вот далее принцип того, что мне необходимо... Я думаю это надо прикрутить к sub_listings.tpl.php и прописать в фильтрах , то что мне необходимо... Я создал несколько шаблонов и необходимые мне категории выводятся в разных шаблонах, что дает мне возможность установить разные фильтра для разных категорий. Правда я хотел немного по другому, что бы шел запрос в таблицу б.д. по указанному cat_id (ячейка в таблице). Что Вам проще? и какая все таки цена на доработку???

Код
defined( '_VALID_MOS' ) or die( 'Direct Access to this location is not allowed.' );

/*# Include the language file. Default is English
global $mt_language;
if ($mt_language=='') $mt_language='english';
include_once('components/com_mtree/language/'.$mt_language.'.php');
if ( !isset($_MT_LANG) ) $_MT_LANG =& new mtLanguage();*/

# Get params
$moduleclass_sfx = $params->get( 'moduleclass_sfx' );

$filter_by_country = $params->get( 'filter_by_country', '1' );
$filter_by_state = $params->get( 'filter_by_state', '1' );
$filter_by_city = $params->get( 'filter_by_city', '1' );
$filter_by_cust1 = $params->get( 'filter_by_cust1', '0' );
$filter_by_cust2 = $params->get( 'filter_by_cust2', '0' );

$caption_cust2 = $params->get( 'caption_cust2', 'Select %1' );
$caption_country = $params->get( 'caption_country', 'Select Country' );
$caption_state = $params->get( 'caption_state', 'Select State' );
$caption_city = $params->get( 'caption_city', 'Select City' );
$caption_cust1 = $params->get( 'caption_cust1', 'Select %1' );
$caption_cust2 = $params->get( 'caption_cust2', 'Select %1' );
$text = "Что ищем?..." /*_SEARCH_BOX*/;
if( $filter_by_cust2 == $filter_by_cust1 ) {
$filter_by_cust2 = '0';
}

# Countries
$loc_countries = array();
$loc_countries[] = mosHTML::makeOption( '', $caption_country );

$database->setQuery( "SELECT DISTINCT country AS text, country AS value FROM #__mt_links WHERE country <> '' ORDER BY country ASC" );
$tmp_countries = $database->loadObjectList();

$loc_countries = array_merge( $loc_countries, $tmp_countries );

/*if there is only one country it creates the ,select. however it does not show it (display:none)*/
if(sizeof($loc_countries)>2){$displayCountry= " ";}else{$displayCountry=" style='display:none;' ";}

$lists['countries'] = mosHTML::selectList( $loc_countries, 'country', 'name="country"'.$displayCountry.' class="inputbox" size="1" '.( ( $filter_by_state ) ? 'onChange="loadLoc(this,\'State\')"' : ''), 'value', 'text', '' );

# Filter 1

/*$database->setQuery( "SELECT name, value FROM #__mt_config WHERE name LIKE 'cust_%'" );
$custom_fields = $database->loadObjectList('name');

if ( $filter_by_cust1 <> '0' ) $caption_cust1 = str_replace("%1", $custom_fields[$filter_by_cust1]->value, $caption_cust1);
if ( $filter_by_cust2 <> '0' ) $caption_cust2 = str_replace("%1", $custom_fields[$filter_by_cust2]->value, $caption_cust2);

if ( $filter_by_cust1 <> '0' ) {
$filterItems = array();
$filterItems[] = mosHTML::makeOption( '', $caption_cust1 );

$database->setQuery( "SELECT DISTINCT ".$filter_by_cust1." AS text, ".$filter_by_cust1." AS value FROM #__mt_links WHERE ".$filter_by_cust1." <> '' ORDER BY ".$filter_by_cust1." ASC" );
$tmp_filter_1 = $database->loadObjectList();

$filterItems = array_merge( $filterItems, $tmp_filter_1);
$lists['filter1'] = mosHTML::selectList( $filterItems, $filter_by_cust1, 'name="'.$filter_by_cust1.'" class="inputbox" size="1" '.( ($filter_by_cust2  <> '0') ? 'onChange="loadLoc(this,\''.$filter_by_cust2.'\')"' : '' ), 'value', 'text', '' );
}*/

?>
<script language="Javascript">
var state = new Array();
var city = new Array();
var filter2 = new Array();
<?php
foreach( $tmp_countries AS $tmp_country ) {

$database->setQuery( "SELECT DISTINCT state FROM #__mt_links WHERE country = '".$tmp_country->text."' AND country <> '' ORDER BY state ASC" );
$tmp_states = $database->loadResultArray();
if( count($tmp_states) > 0 ) {
echo "state['".$tmp_country->text."']=new Array('";
echo implode("','",$tmp_states);
echo "');\n";
}

if( $filter_by_city ) {
foreach( $tmp_states AS $tmp_state ) {

$database->setQuery( "SELECT DISTINCT city FROM #__mt_links WHERE state = '".$tmp_state."' AND state <> '' ORDER BY city ASC" );
$tmp_cities = $database->loadResultArray();
if( count($tmp_cities) > 0 && !empty($tmp_cities[0]) ) {
echo "city['".$tmp_state."']=new Array('";
echo implode("','",$tmp_cities);
echo "');\n";
}

}
}

}

/*foreach( $tmp_filter_1 AS $tmp_filter ) {
$database->setQuery( "SELECT DISTINCT ".$filter_by_cust2." FROM #__mt_links WHERE ".$filter_by_cust1." = '".$tmp_filter->text."' ORDER BY ".$filter_by_cust1." ASC" );
$tmp_filter_2 = $database->loadResultArray();

if( count($tmp_filter_2) > 0 ) {
echo "filter2['".$tmp_filter->text."']=new Array('";
echo implode("','",$tmp_filter_2);
echo "');\n";
}
}*/

?>

function loadLoc(ref,loc) { loadLoc2(ref.options[ref.selectedIndex].value,loc) }
function loadLoc2(val,loc) { switch(loc) { case 'State':
if(typeof state[val] != "undefined") { var locations = state[val]; <?php if( $filter_by_city ) { ?>
clearList('City'); disableLoc('City'); <?php } ?>
} else { disableLoc(loc); return;}
break; case 'City':
if(typeof city[val] != 'undefined') { var locations = city[val];} else { disableLoc(loc); return;}
break; case '<?php echo $filter_by_cust2 ?>':
if(typeof filter2[val] != 'undefined') { var locations = filter2[val];} else { disableLoc(loc); return;}
break;}
enableLoc(loc); clearList(loc); if ( typeof locations != 'undefined' && locations.length > 0 ) { for (c=0; c < locations.length; c++) { var newOpt = document.createElement("OPTION"); newOpt.text = locations[c]; newOpt.value = locations[c]; document.mtdrilldown.elements['dd'+loc].options[c+1] = newOpt;}
}
}
function disableLoc(id) { gebid('dd'+id).disabled=true;}
function enableLoc(id) { gebid('dd'+id).disabled=false;}
function clearList(id) { var clength = gebid('dd'+id).length; for(var i=(clength-1);i>=0;i--) { gebid('dd'+id).remove(i);}
var newOpt = document.createElement("OPTION"); newOpt.value = ''; switch(id) { <?php if( $filter_by_cust1 <> '0' ) { ?>
case '<?php echo $filter_by_cust1 ?>':
newOpt.text = '<?php echo $caption_cust1 ?>'; break; <?php } ?>
<?php if( $filter_by_cust2 <> '0' ) { ?>
case '<?php echo $filter_by_cust2 ?>':
newOpt.text = '<?php echo $caption_cust2 ?>'; break; <?php } ?>
case "Country":
newOpt.text = '<?php echo $caption_country ?>'; break; case "State":
newOpt.text = '<?php echo $caption_state ?>'; break; case "City":
newOpt.text = '<?php echo $caption_city ?>'; break;}
document.mtdrilldown.elements['dd'+id].options[0] = newOpt;}
function gebid(id){return document.getElementById(id);}
function NormalizeAccents(text) { var i, ac, nc; ac = 'бдвагйлкинпомуцфтъ&\щзс%$БДВАГЙЛКИНПОМУЦФТХЪЬЫЩЗСЭ'; nc = 'aaaaaeeeeiiiiooooouuuucnyyAAAAAEEEEIIIIOOOOOUUUUCNY'; for (i = 0; i < ac.length; i++) { text = text.replace(ac.charAt(i), nc.charAt(i));}
return text;}
</script>
<form action="<?php echo sefRelToAbs($mosConfig_live_site) /*sefRelToAbs("index.php")*/; ?>" method="post" name="mtdrilldown" style="padding:0px; margin:0px;" >
<?php
echo '<input type="text" name="link_desc" size="20" class="inputbox"  value="'. $text .'"  onblur="if(this.value==\'\') this.value=\''. $text .'\';" onfocus="if(this.value==\''. $text .'\') this.value=\'\';" />'; ?>
<?php echo $lists['countries']; ?>
<?php if( $filter_by_state ) { ?>
<select name="state" class="inputbox" size="1" id="ddState" <?php if( $filter_by_city ) echo "onChange=\"loadLoc(this,'City')\" " ?>disabled>
<option value="" selected="selected"><?php echo $caption_state ?></option>
</select>
<?php } ?>
<?php if( $filter_by_city && $filter_by_state ) { ?>
<select name="city" class="inputbox selectCity" size="1" id="ddCity" disabled>
<option value="" selected="selected"><?php echo $caption_city ?></option>
</select>
<?php } ?>
<?php if ( $filter_by_cust1 <> '0') echo $lists['filter1']; ?>
<?php if ( $filter_by_cust1 <> '0' && $filter_by_cust2 <> '0' ) { ?>
<select name="<?php echo $filter_by_cust2 ?>" class="inputbox" size="1" id="dd<?php echo $filter_by_cust2 ?>" disabled>
<option value="" selected="selected"><?php echo $caption_cust2 ?></option>
</select>
<?php } ?>
<?php
?>
<br><input type="submit" value="Поиск" class="button" />
<input type="hidden" name="Itemid" value="<?php echo $Itemid ?>" />
<input type="hidden" name="option" value="com_mtree" />
<input type="hidden" name="task" value="advsearch2" />
</form><?php
if(sizeof($loc_countries)<=2){ ?>
<script language="Javascript">
loadLoc2(document.mtdrilldown.country.options[1].value,"State"); </script>
<?php } ?>
!!!???!!!
*

Adeptus

  • Завсегдатай
  • 1861
  • 219 / 15
Re: Новый модуль поиска для MosetsTree 2.XX
« Ответ #9 : 10.06.2009, 17:41:38 »
А почта где ? 

Там же, где всегда - моем профайле.
*

dimko300

  • Захожу иногда
  • 61
  • 1 / 0
Re: Новый модуль поиска для MosetsTree 2.XX
« Ответ #10 : 10.06.2009, 20:13:55 »
Там она закрыта! Я попробовал написать через внутреннюю почту сайта ( по ссылке из профайла), но помоему безуспешно! Может быть Вы мне тест отправите на мою почту? kokorind@mail.ru
*

Adeptus

  • Завсегдатай
  • 1861
  • 219 / 15
Re: Новый модуль поиска для MosetsTree 2.XX
« Ответ #11 : 10.06.2009, 20:21:16 »
adeptus@adeptsite.info
*

timonnn

  • Захожу иногда
  • 366
  • 15 / 0
Re: Новый модуль поиска для MosetsTree 2.XX
« Ответ #12 : 12.06.2009, 23:10:20 »
Adeptus, а можно данный модуль переделать под 1.5?
*

Adeptus

  • Завсегдатай
  • 1861
  • 219 / 15
Re: Новый модуль поиска для MosetsTree 2.XX
« Ответ #13 : 13.06.2009, 14:46:47 »
Adeptus, а можно данный модуль переделать под 1.5?

Можно.
*

dimko300

  • Захожу иногда
  • 61
  • 1 / 0
Re: Новый модуль поиска для MosetsTree 2.XX
« Ответ #14 : 17.06.2009, 17:08:46 »
Цитировать
adeptus@adeptsite.info
Ну и сколько на него можно писать? Ответ то будет или нет? Или задача для Вас не выполнима? ;)
*

Adeptus

  • Завсегдатай
  • 1861
  • 219 / 15
Re: Новый модуль поиска для MosetsTree 2.XX
« Ответ #15 : 17.06.2009, 17:29:07 »
Ну и сколько на него можно писать? Ответ то будет или нет? Или задача для Вас не выполнима? ;)

Ровным счетом ничего я от вас не получал.
*

dimko300

  • Захожу иногда
  • 61
  • 1 / 0
Re: Новый модуль поиска для MosetsTree 2.XX
« Ответ #16 : 17.06.2009, 18:31:35 »
Вот прямо сейчас отправлю еще раз, посмотрите пожалуйста!!!
- Отправил!!!!
« Последнее редактирование: 17.06.2009, 18:35:29 от dimko300 »
*

portal

  • Захожу иногда
  • 50
  • 0 / 0
Re: Новый модуль поиска для MosetsTree 2.XX
« Ответ #17 : 04.02.2011, 00:45:35 »
не понятно, ни один сайт полигон не работает, где 't тогда посмотреть в работе?
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Как добавить к title mosetstree в конце чтобы выводилась любой мой текст?

Автор bogdanmedia

Ответов: 0
Просмотров: 19791
Последний ответ 07.01.2019, 15:36:13
от bogdanmedia
Модуль (Лучшие материалы)

Автор sinij

Ответов: 0
Просмотров: 4051
Последний ответ 27.10.2017, 15:25:20
от sinij
Не создается новый профиль

Автор Sambola

Ответов: 0
Просмотров: 2443
Последний ответ 24.07.2016, 00:45:39
от Sambola
Русский язык для MosetsTree

Автор alex_rus

Ответов: 64
Просмотров: 50224
Последний ответ 29.11.2015, 14:51:32
от 12mv
Вывести модуль Joomla в файле sub_listingDetails.tpl.php

Автор rafaello9

Ответов: 3
Просмотров: 3008
Последний ответ 07.04.2014, 13:53:14
от ivan.andreyev