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

poiuy

  • Захожу иногда
  • 203
  • 30 / 6
  • o_O
Шаблон CommunityBuilder
« : 17.08.2011, 18:51:26 »
У меня вопрос такого плана: как немного видоизменить дефолтный шаблон CB?
Не спешите отправлять в поиск или гугль (и там и там искал), проблема вот в чем:
Как изменить вот эту панель:


Просто в template.css его не переделаешь, див который отвечает за вывод этого поля берет данные CSS из шаблона Jooml'ы (./templates/шаблон/css/template.css)

Вот код php который это делает (default.php):
Код
<?php
/**
 * Core CB default template for user profiles rendering
 * @version $Id: default.php 1323 2010-12-02 18:21:41Z beat $
 * @package Community Builder
 * @subpackage Default CB template
 * @author Beat
 * @copyright (C) Beat, www.joomlapolis.com
 * @license http://www.gnu.org/licenses/old-licenses/gpl-2.0.html GNU/GPL version 2
 */

/** ensure this file is being included by a parent file */
if ( ! ( defined( '_VALID_CB' ) || defined( '_JEXEC' ) || defined( '_VALID_MOS' ) ) ) {
die( 'Direct Access to this location is not allowed.' );
}

global $_PLUGINS;

// WARNING: THIS IS EXPERIMENTAL, INTRODUCED IN CB 1.2 AND THIS PART WILL EVOLVE IN FUTURE CB RELEASES.

/**
 * VIEW: User profile view class
 *
-------------------------
!          head         !
!-----------------------!
!      !        !       !
! left ! middle ! right !
!      !        !       !
!-----------------------!
!                       !
!        tabmain        !
!                       !
!-----------------------!
!        underall       !
-------------------------
!      !        !       !
! L1C1 ! L1C2   ! L1C3  !   L1C1...C9
!      !        !       !
!-----------------------!
!      !        !       !
! L2C1 ! L2C4   ! L2C8  !   ...
!      !        !       !
!-----------------------!
!                       !
!        L4C7           !
!                       !
!-----------------------!
!          !            !
!   L8C3   !    L8C4    !   ...L9C9
!          !            !
!-----------------------!
    ! + not_on_profile_1..9
 */
class CBProfileView_html_default extends cbProfileView {
var $wLeft;
var $wMiddle;
var $wRight;
var $nCols;
/**
* Draws the user profile
*
* @return string
*/
function draw( $part = '' ) {
global $ueConfig;
// $params = $this->params;

if ( $part == '' ) {
// Profile view:

//positions: head left middle right tabmain underall
$this->wLeft = isset( $this->userViewTabs['cb_left'] )? 100 : 0;
$this->wMiddle = isset( $this->userViewTabs['cb_middle'] )? 100 : 0;
$this->wRight = isset( $this->userViewTabs['cb_right'] )? 100 : 0;
$this->nCols = intval( ( $this->wLeft + $this->wMiddle + $this->wRight ) / 100 );
switch ( $this->nCols ) {
case 0 :
case 1 :
break;
case 2 :
$this->wLeft = $this->wLeft ? intval( $ueConfig['left2colsWidth'] ) - 1 : 0;
$this->wMiddle = $this->wMiddle ? ( $this->wLeft ? 100 - intval( $ueConfig['left2colsWidth'] ) - 1 : intval( $ueConfig['left2colsWidth'] ) - 1 ) : 0;
$this->wRight = $this->wRight ? 100 - intval( $ueConfig['left2colsWidth'] ) - 1 : 0;
break;
case 3 :
$this->wLeft = intval( $ueConfig['left3colsWidth'] ) - 1;
$this->wMiddle = 100 - intval( $ueConfig['left3colsWidth'] ) - intval( $ueConfig['right3colsWidth'] ) - 1;
$this->wRight = intval( $ueConfig['right3colsWidth'] ) - 1;
break;
}
}
// else: Edit profile view: nothing to setup
return parent::draw( $part );
}
/**
* Renders by ECHO the User Profile view
* here typically if you prefer to include a view-type php-html file you would include it.
*/
function _render( ) {
/*
// add any HTML in HTML head section:

global $_CB_framework;
$_CB_framework->document->addHeadStyleSheet( selectTemplate(). 'file.css' );
$_CB_framework->document->addHeadStyleInline( 'input { border: red 1px solid; }');
*/
// Display "head" tabs: (Menu + shortest connection path / Degree of relationship + Uname Profile Page)
if ( isset( $this->userViewTabs['cb_head'] ) ) {
echo '<div class="cbPosHead">';
echo $this->userViewTabs['cb_head'];
echo '</div><div class="cbClr"></div>';
}
if ( $this->nCols != 0 ) {
echo "\n\t\t<div class=\"cbPosTop\">";

// Display "Left" tabs
if ( isset( $this->userViewTabs['cb_left'] ) ) {
echo "\n\t\t\t<div class=\"cbPosLeft\" style=\"width:" . $this->wLeft . "%;\">";
echo $this->userViewTabs['cb_left'];
echo '</div>';
}
// Display "Middle" tabs (User Avatar/Image):
if ( isset( $this->userViewTabs['cb_middle'] ) ) {
echo "\n\t\t\t<div class=\"cbPosMiddle\" style=\"width:" . $this->wMiddle . "%;\">";
echo $this->userViewTabs['cb_middle'];
echo '</div>';
}
// Display "Right" tabs (User Status):
if ( isset( $this->userViewTabs['cb_right'] ) ) {
echo "\n\t\t\t<div class=\"cbPosRight\" style=\"width:" . $this->wRight . "%;\">";
echo $this->userViewTabs['cb_right'];
echo '</div>';
}
echo '<div class="cbClr"></div></div>';
}
if ( isset( $this->userViewTabs['cb_tabmain'] ) ) {
echo "\n\t\t<div class=\"cbPosTabMain\">";
echo $this->userViewTabs['cb_tabmain'];
echo '</div><div class="cbClr"></div>';
}
if ( isset( $this->userViewTabs['cb_underall'] ) ) {
echo "\n\t\t<div class=\"cbPosUnderAll\">";
echo $this->userViewTabs['cb_underall'];
echo '</div><div class="cbClr"></div>';
}

// New CB 1.2 grid layout:

$line = null;
$tabsIdxes = array_keys( $this->userViewTabs );
foreach ( $tabsIdxes as $k => $v ) {
if ( $v && $v[0] == 'L' ) {
$L = $v[1];
if ( $line === null ) {
// new line: mark begin:
$line = $k;
}
if ( ! ( isset( $tabsIdxes[$k + 1] ) && ( $tabsIdxes[$k + 1][1] == $L ) ) ) {
// line is now complete, next entry, if exists, is another line: generate line:
$cols = $k - $line + 1;
$width = 100;
$step = floor( $width / $cols );
echo "\n\t\t" . '<div class="cbPosGridLine" id="cbPosLine' . substr( $v, 0, 2 ). '">';
for ( $i = $line ; $i <= $k ; $i++ ) {
if ( $i == $k ) {
$step = $width - ( ( $cols - 1 ) * $step );
}
echo "\n\t\t" . '<div class="cbPosGrid" id="cbPos' . $v . '_' . $i . '" style="width:' . $step . '%;"><div class="cbPosGridE">';
echo $this->userViewTabs[$tabsIdxes[$i]];
echo '</div></div>';
}
echo '</div><div class="cbClr" id="cbPosSep' . substr( $v, 0, 2 ). '"> </div>';

$line = null;
}
}
}
}
/**
* Renders by ECHO the user profile edit view
* here typically if you prefer to include a view-type php-html file you would include it.
*/
function _renderEdit( ) {
echo $this->tabcontent;
?>

<span class="cb_button_wrapper"><input class="button cbProfileEditSubmit" type="submit" id="cbbtneditsubmit" value="<?php echo $this->submitValue; ?>" /></span>
<span class="cb_button_wrapper"><input class="button cbProfileEditCancel" type="button" id="cbbtncancel" name="btncancel" value="<?php echo $this->cancelValue; ?>" /></span>
<div id="cbIconsBottom">
<?php echo $this->bottomIcons; ?>

</div>

<?php
}
} // class CBProfileView_default

/**
 * VIEW: User registration view class
 */
class CBRegisterFormView_html_default extends cbRegistrationView {
/**
* Renders by ECHO the Registration form view
* here typically if you prefer to include a view-type php-html file you would include it.
*/
function _renderRegistrationHead( ) {
if ( $this->moduleContent ) {
if ( $this->introMessage ) {
?>
<div class="componentheading" id="cb_comp_login_register_head"><?php echo $this->loginOrRegisterTitle; ?></div><div class="cb_comp_outer"><div class="cb_comp_inner">
<div class="contentpaneopen" id="cb_comp_login_register_content"><?php echo $this->introMessage; ?></div>
</div></div>
<?php
}
echo '<div class="cbclearboth"><div id="cb_comp_login"><div class="componentheading">' . _LOGIN_TITLE . '</div><div class="cb_comp_outer"><div class="cb_comp_inner">';
echo $this->moduleContent;
echo '</div></div></div><div id="cb_comp_register">';
}
?>
<div class="componentheading"><?php echo $this->registerTitle; ?></div><div class="contentpaneopen"><div class="cb_comp_outer"><div class="cb_comp_inner cbHtmlEdit cbRegistration">
<?php
if ( $this->topIcons ) {
echo '<div id="cbIconsTop">';
echo $this->topIcons;
echo '</div>';
}
echo $this->regFormTag; // '<form...>'
}
/**
* Renders by ECHO the Registration form view NEW DIVs view:
* here typically if you prefer to include a view-type php-html file you would include it.
*/
function _renderdivs( ) {
$this->_renderRegistrationHead();
?>
<div class="contentpane" id="registrationTable">
<?php
if ( $this->introMessage && ( ! $this->moduleContent ) ) {
?>
    <div class="contentpaneopen"><?php echo $this->introMessage; ?></div>
<?php
}
// outputs all tabs, including contact tab and Terms & Conditions:
echo $this->tabcontent;

// outputs conclusion text and different default values:
?>
    <div class="contentpaneopen"><?php
      if ( $this->conclusionMessage ) {
  echo $this->conclusionMessage;
      } else {
      echo "&nbsp;";
      }
      ?></div>
    <div class="contentpaneopen">
<span class="cb_button_wrapper"><input type="submit" value="<?php echo $this->registerButton; ?>" class="button" /></span>
    </div>
</div>
<?php
$this->_renderRegistrationFooter();
}
/**
* Renders by ECHO the Registration form view OLD TABLE view
* here typically if you prefer to include a view-type php-html file you would include it.
*/
function _render( ) {
$this->_renderRegistrationHead();
?>
<table class="contentpane" id="registrationTable">
<?php
if ( $this->introMessage && ( ! $this->moduleContent ) ) {
?>
    <tr>
      <td colspan="2" class="contentpaneopen"><?php echo $this->introMessage; ?></td>
    </tr>
<?php
}
// outputs all tabs, including contact tab and Terms & Conditions:
echo $this->tabcontent;

// outputs conclusion text and different default values:
?>
    <tr>
      <td colspan="2" class="contentpaneopen"><?php
      if ( $this->conclusionMessage ) {
  echo $this->conclusionMessage;
      } else {
      echo "&nbsp;";
      }
      ?></td>
    </tr>
    <tr>
      <td colspan="2">
<span class="cb_button_wrapper"><input type="submit" value="<?php echo $this->registerButton; ?>" class="button" /></span>
      </td>
    </tr>
</table>
<?php
$this->_renderRegistrationFooter();
}
/**
* Renders by ECHO the Registration form view
* here typically if you prefer to include a view-type php-html file you would include it.
*/
function _renderRegistrationFooter( ) {
echo '</form>';
if ( $this->bottomIcons ) {
echo '<div id="cbIconsBottom">';
echo $this->bottomIcons;
echo '</div>';
}
echo '</div></div></div>';
if ( $this->moduleContent ) {
echo '</div></div>';
}
echo "<div class=\"cbClr\"></div>";
}
} // class CBProfileView_default

/**
 * VIEW: User profile view class
 *
 */
class CBListView_html_default extends cbListView {
/**
* Renders by ECHO the list header view
* here typically if you prefer to include a view-type php-html file you would include it.
*/
function _renderHead( ) {
global $_CB_framework;
?>

<div class="cbUserListHeadTitle">
<?php
if ( ( count( $this->lists ) > 0 ) || $this->searchTabContent ) {
?>

<div class="cbUserListChanger">
<?php
// selector for user-list:
if ( count( $this->lists ) > 0 ) {
foreach ( $this->lists as $kname => $ncontent ) {
?>

<div class="cbUserListChangeItem cbUserList<?php echo $kname; ?>"><?php
echo $ncontent;
?></div>

<?php
}
}
if ( $this->searchTabContent ) {
if ( ! $this->searchResultDisplaying ) {
?>
<div class="cbUserListSearchButtons" id="cbUserListsSearchTrigger"><a class="pagenav" href="#"><?php echo _UE_SEARCH_USERS; ?></a></div>
<?php
} else {
echo '<div id="cbUserListListAll"><a class="pagenav" href="' . cbSef($this->ue_base_url). '">' . _UE_LIST_ALL . '</a></div>';
}
}
?>
</div>
<?php
}
// List title:
?>

<div class="contentheading cbUserListTitle"><?php echo $this->listTitleHtml; ?></div>
<?php
if ( TRUE && trim( $this->listDescription ) ) { // to remove description from front-end display as was before CB 1.2: change TRUE to FALSE.

// List description:
?>

    <div class="contentdescription cbUserListDescription"><?php echo $this->listDescription; ?></div>
<?php
}

// users-count:
?>

<div class="contentdescription cbUserListResultCount"><?php
if ( $this->totalIsAllUsers ) {
echo $_CB_framework->getCfg( 'sitename' ). " " . _UE_HAS . " <strong>" . $this->total . "</strong> " . _UE_USERS;
} else {
echo "<strong>" . $this->total . "</strong> " . _UE_USERPENDAPPRACTION . ":";
}
  ?></div>
<div class="cbClr"></div>
<?php
if ( $this->searchTabContent ) {
?>
<div class="contentdescription cbUserListSearch" id="cbUserListsSearcher">
<div class="componentheading"><?php echo $this->searchCriteriaTitleHtml; ?></div>
<div class="cbUserListSearchFields">
<?php
echo $this->searchTabContent;
?>
<div class="cbClr"></div>
<div class="cb_form_buttons_line">
<input type="submit" class="button" id="cbsearchlist" value="<?php echo _UE_FIND_USERS; ?>" />
</div>
<div class="cbClr"></div>
</div>
<?php
if ( $this->searchResultsTitleHtml ) {
?>
<div class="componentheading"><?php echo $this->searchResultsTitleHtml; ?></div>
<?php
}
?>

</div>
<?php
}
?>

</div>
<?php
}
/**
* Renders by ECHO the list body view
* here typically if you prefer to include a view-type php-html file you would include it.
*/
function _renderBody( ) {
?>
<hr class="cbUserListHrTop" size="1" />
<table id="cbUserTable" class="cbUserListTable cbUserListT_<?php echo $this->listid ?>">
  <thead>
<tr class="sectiontableheader">
<?php
// table headers:

$colsNbr = count( $this->columns );
foreach ( $this->columns as $column ) {
echo "\t\t\t<th><b>" . $column->titleRendered . "</b></th>\n";
}
?>

</tr>
  </thead>
  <tbody>
<?php

// table content:

$i = 0;
if ( is_array( $this->users ) && count( $this->users ) > 0 ) {
foreach ( $this->users as $userIdx => $user) {
$class = "sectiontableentry" . ( 1 + ( $i % 2 ) ); // evenodd class

if ( $this->allow_profilelink ) {
$style = "style=\"cursor:hand;cursor:pointer;\"";
$style .= " id=\"cbU".$i."\"" ;
} else {
$style = "";
}
if ( $user->banned ) {
echo "\t\t<tr class=\"$class\"><td colspan=\"".$colsNbr."\"><span class=\"error\" style=\"color:red;\">"._UE_BANNEDUSER." ("._UE_VISIBLE_ONLY_MODERATOR.") :</span></td></tr>\n";
}
echo "\t\t<tr class=\"$class\" ".$style.">\n";

foreach ( array_keys( $this->columns ) as $colIdx ) {
echo "\t\t\t<td valign=\"top\" class=\"cbUserListCol" . $colIdx . "\">" . $this->_getUserListCell( $this->tableContent[$userIdx][$colIdx] ). "\t\t\t</td>\n";
}
echo "\t\t</tr>\n";
$i++;
}
} else {
echo "\t\t<tr class=\"sectiontableentry1\"><td colspan=\"".$colsNbr."\">"._UE_NO_USERS_IN_LIST."</td></tr>\n";
}
?>
  </tbody>
</table>

<hr class="cbUserListHrBottom" size="1" />
<?php
}
function _getUserListCell( &$cellFields ) {
$html = array();
foreach ( $cellFields as $fieldView ) {
if ( $fieldView->value !== null ) {
if  ( $fieldView->title ) {
$title = '<span class="cbUserListFieldTitle cbUserListFT_' . $fieldView->name . '">'
. $fieldView->title
. ':'
. '</span> ';
} else {
$title = '';
}
$html[] = '<div class="cbUserListFieldLine">'
. $title
. '<span class="cbListFieldCont cbUserListFC_' . $fieldView->name . '">'
. $fieldView->value
. '</span>'
. '</div>';
}
}
return "\n\t\t\t\t" . implode( "\n\t\t\t\t", $html ). "\n";
}
}
?>
А именно вот это:
Код
// Display "Right" tabs (User Status):
if ( isset( $this->userViewTabs['cb_right'] ) ) {
echo "\n\t\t\t<div class=\"cbPosRight\" style=\"width:" . $this->wRight . "%;\">";
echo $this->userViewTabs['cb_right'];
echo '</div>';
}
Конечно можно и этот файл поправить, я пробовал, все нормально но я хотел бы сделать так, что бы файлы шаблона не трогать, так как у всех разные шаблоны, а шаблоном хотелось бы поделиться.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Решит ли CommunityBuilder задачу организацию форумов для управлениями группами?

Автор dss

Ответов: 1
Просмотров: 3920
Последний ответ 07.03.2023, 07:27:52
от marksetter
Как отключить уведомления об обновлениях CommunityBuilder?

Автор ivan.sergeev

Ответов: 3
Просмотров: 6537
Последний ответ 03.06.2020, 19:44:50
от Torchez
Кроссбраузерность профиля CommunityBuilder 2

Автор warlocksp

Ответов: 1
Просмотров: 5112
Последний ответ 05.03.2018, 08:15:18
от warlocksp
CommunityBuilder 2.1.2 не приходит email уведомление Администраm

Автор bicka

Ответов: 2
Просмотров: 5310
Последний ответ 14.07.2017, 13:34:11
от bicka
Галерея в CommunityBuilder

Автор d13v555

Ответов: 3
Просмотров: 5342
Последний ответ 04.04.2017, 06:35:20
от d13v555