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

Vasabi

  • Осваиваюсь на форуме
  • 25
  • 3 / 0
У меня интеграция Joomla и vBulletin

Проблема заключается в том, что при регистрации данные пользователя записываются в таблицы (Joomla и vBulletin), а мне нужно, чтобы и в таблицу comprofiler от Community Builder.

Все начинает правильно работать, если воспользоваться синхронизацией в админке Joomla Components -> Community Builder->Tools Manager.

Коротко о том, что мне нужно:
Подскажите, пожалуйста, как очеловечить запрос, чтобы он работал не в joomla, а скажем если его поместить в в vb/register.php

$sql ="INSERT IGNORE INTO j_pp_comprofiler(id,user_id,lastname,firstname) "
." SELECT id,id, SUBSTRING_INDEX(name,' ',-1), "
."SUBSTRING( name, 1, length( name ) - length( SUBSTRING_INDEX( name, ' ', -1 ) ) -1 ) "
." FROM j_pp_users";

Подробнее:

Я из компонента достал полностью функцию, которая занимается синхронизацией
////////////////////////////////////////////////////////////////////////////////////////////////
Код
function syncUsers() {
    global $_CB_database, $my, $ueConfig;

    // 1. add missing comprofiler entries, guessing naming depending on CB's name style:
switch ( $ueConfig['name_style'] ) {
case 2:
// firstname + lastname:
  $sql = "INSERT IGNORE INTO #__comprofiler(id,user_id,lastname,firstname) "
    ." SELECT id,id, SUBSTRING_INDEX(name,' ',-1), "
  ."SUBSTRING( name, 1, length( name ) - length( SUBSTRING_INDEX( name, ' ', -1 ) ) -1 ) "
    ." FROM #__users";   
break;
case 3:
// firstname + middlename + lastname:
$sql = "INSERT IGNORE INTO #__comprofiler(id,user_id,middlename,lastname,firstname) "
. " SELECT id,id,SUBSTRING( name, INSTR( name, ' ' ) +1,"
  ." length( name ) - INSTR( name, ' ' ) - length( SUBSTRING_INDEX( name, ' ', -1 ) ) -1 ),"
." SUBSTRING_INDEX(name,' ',-1),"
." IF(INSTR(name,' '),SUBSTRING_INDEX( name, ' ', 1 ),'') "
. " FROM #__users";
    break;
    default:
  // name only:
$sql = "INSERT IGNORE INTO #__comprofiler(id,user_id) SELECT id,id FROM #__users";
    break;
    }
$_CB_database->setQuery($sql);
if (!$_CB_database->query()) {
print("<font color=red>SQL error" . $_CB_database->stderr(true)."</font><br />");
return;
}
$affected = mysql_affected_rows();
if ($affected) {
print "<p><font color='orange'>Added ".$affected." new entries to Community Builder from users Table.</font></p>";
}

$sql = "UPDATE #__comprofiler SET `user_id`=`id`";
$_CB_database->setQuery($sql);
if (!$_CB_database->query()) {
print("<font color=red>SQL error" . $_CB_database->stderr(true)."</font><br />");
return;
}
$affected = mysql_affected_rows();
if ($affected) {
print "<p><font color='orange'>Fixed ".$affected." existing entries in Community Builder: fixed wrong user_id.</font></p>";
}

// 2. remove excessive comprofiler entries (e.g. if admin used mambo/joomla delete user function:
$sql = "SELECT c.id FROM #__comprofiler c LEFT JOIN #__users u ON u.id = c.id WHERE u.id IS NULL";
$_CB_database->setQuery($sql);
$users = $_CB_database->loadResultArray();
if (count($users)) {
print "<p><font color='orange'>Removing ".count($users)." entries from Community Builder missing in users Table.</font></p>";
}
if ($_CB_database->getErrorNum()) {
print("<font color=red>SQL error" . $_CB_database->stderr(true)."</font><br />");
return;
}
$msg = deleteUsers($users, true);
print "<p>".$msg."</p>";
print "<font color=green>Joomla/Mambo User Table and Joomla/Mambo Community Builder User Table now in sync!</font>";
}
function _cb_prov_loadAssoc() {
global $_CB_database;
if (!($cur = $_CB_database->query())) {
return null;
}
$ret = null;
if ($array = mysql_fetch_array( $cur, MYSQL_ASSOC )) {
$ret = $array;
}
mysql_free_result( $cur );
return $ret;
}

/**
* Fetch a result row as an associative array
*
* return array
*/

С того, что я понял, мне нужно, чтобы при регистрации  выполнялся вот такой запрос :
Код
$sql ="INSERT IGNORE INTO j_pp_comprofiler(id,user_id,lastname,firstname) "
." SELECT id,id, SUBSTRING_INDEX(name,' ',-1), "
."SUBSTRING( name, 1, length( name ) - length( SUBSTRING_INDEX( name, ' ', -1 ) ) -1 ) "
." FROM j_pp_users";

По моих соображениях, если вставить
Код
$sql ="INSERT IGNORE INTO j_comprofiler ….."
$db->setQuery($sql);
в vb/register.php
в строку 1020 до команды
// activate account
$userdata->save();

Должно заработать

Заранее спасибо!
« Последнее редактирование: 28.08.2007, 19:37:33 от Vasabi »
*

Vasabi

  • Осваиваюсь на форуме
  • 25
  • 3 / 0
сразу говорю, что далек от программирования

но я так понимаю, что запрос в таком виде не есть рабочим, если, например, через phpmyadmin запустить

INSERT IGNORE INTO j_pp_comprofiler(id,user_id,lastname,firstname) "
." SELECT id,id, SUBSTRING_INDEX(name,' ',-1), "
."SUBSTRING( name, 1, length( name ) - length( SUBSTRING_INDEX( name, ' ', -1 ) ) -1 ) "
." FROM j_pp_users"


Как его нужно подправить?
*

Yurets

  • Захожу иногда
  • 405
  • 92 / 0
  • Губернатор острова Борнео
А если поудалять двойные кавычки и точки между ними?
В комнате с белым потолком
*

Vasabi

  • Осваиваюсь на форуме
  • 25
  • 3 / 0
Да, спасибо помогло

Запрос выполнен:
Добавлены ряды: 1 (Запрос занял 0.0042 сек)

как и должно было.

Но теперь не заходит в личный профиль CB.

Хочу заново переустановить Joomla, vBulletin, CB и мост.
Есть вариант, что до этого запроса я уже что-то там запорол.

Я еще в эту тему вернусь)
*

Vasabi

  • Осваиваюсь на форуме
  • 25
  • 3 / 0
Задача, чтобы с помощью моста ббПиксель при регистрации данные профиля еще и записывались в таблицу jos_comprofiler компонента Community Builder для Joomla.

На будущее тем, кто захочет, чтобы при сборке joomla, vBulletin, bbpixel и Community Builder для Joomla проходила полная регистрация, в смысле, чтобы и работал профиль Community Builder нужно:

В админке VB => продукты и модули => управлиние модулями => выбераем jvbRegister => в конце ‘Код PHP модуля’ добавляем строку

$db->query_write ("INSERT IGNORE INTO jos_comprofiler(id,user_id) SELECT id,id FROM jos_users");

И все работает!

Предупреждение:
vBulletin, bbpixel являются платными продуктами и использование без лицензии их может привести к тому, что однажды ваш сайт закроют!
*

Yurets

  • Захожу иногда
  • 405
  • 92 / 0
  • Губернатор острова Борнео
Vasabi, а можно в личку скинуть ссылку на "http://посмотреть.что.получилось/"?
В комнате с белым потолком
*

Vasabi

  • Осваиваюсь на форуме
  • 25
  • 3 / 0
Ок, скину.

Как только закончится реконструкция!.
Потому что сейчас там большая надпись – «Реконструкція! Скоро повернемося».

На выходных планирую все сделать.

Я сразу скину.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

CommunityBuilder 2.1.2 не приходит email уведомление Администраm

Автор bicka

Ответов: 2
Просмотров: 3666
Последний ответ 14.07.2017, 13:34:11
от bicka
Поля, невидимые пользователям - только адм

Автор stepan39

Ответов: 0
Просмотров: 1266
Последний ответ 30.09.2015, 13:50:00
от stepan39
Про скрытие вкладок в профиле

Автор Kalipso

Ответов: 6
Просмотров: 1431
Последний ответ 15.12.2013, 15:34:49
от Kalipso
Как сделать имя автора, ссылкой на странич

Автор spanchermen

Ответов: 3
Просмотров: 2634
Последний ответ 20.10.2012, 04:07:14
от asv1001
Глюки с вкладкой "статистика" в профиле

Автор 20strannik08

Ответов: 2
Просмотров: 1626
Последний ответ 10.10.2012, 20:21:54
от 20strannik08