Новости Joomla

SW JProjects v.2.6.0 - компонент каталога расширений для Joomla

👩‍💻 SW JProjects v.2.6.0 - компонент каталога расширений для Joomla.Компонент позволяет сделать свой мини-Joomla Extensions Directory - каталог расширений для CMS (не только для Joomla) или файлов. Есть возможность скачивания по лицензионным ключам.👩‍💻 v.2.6.0. Что нового?Этот релиз прежде всего связан с SEO и AI-оптимизацией. - Микроразметка Schema.org.Добавлен плагин микроразметки Schema.org для сущностей компонента. Для списков используется ListItem, для страницы проекта и версии - SoftwareApplication, для страницы документации - TechArticle. Плагин группы schemaorg в отличие от стандартных плагинов заполняет данные автоматически, но встраивает данные в граф сущностей микроразметки Joomla. Также исправляется одна ошибка генерируемой ядром микроразметки в зоне ответственности компонента.- Улучшение поиска по ключам. В панели администратора в списке ключей теперь можно искать по номеру заказа, email, домену, содержимому примечания к ключу.- Список ключей в админке. В списке ключей в панели администратора добавлен вывод домена и примечания- Поиск в списке проектов. Поиск в списке проектов в панели администратора стал более точным. Из полей для поиска убраны лишние поля.Компонент работает на Joomla 6 без включённого плагина обратной совместимости.Страница расширения и скачатьGitHub расширения.Joomla Extensions Directory#joomla #расширения

Человек на GitHub ускорил Joomla в 600 раз на объёме 150к+ материалов в 1700+ категориях

Человек на GitHub ускорил Joomla в 600 раз на объёме 150к+ материалов в 1700+ категориях

👩‍💻 Человек на GitHub ускорил Joomla в 600 раз на объёме 150к+ материалов в 1700+ категориях. На старте его сайт на Joomla 3 вообще не смог обновиться на Joomla 5. Пришлось делать экспорт/импорт материалов. Проделав всё это он запустил-таки этот объём данных на Joomla 5. Тестовый скрипт грузил 200 материалов из этого объёма всего за 94 секунды ))) А главная страница с категориями грузилась 20 секунд. Добавив индекс для таблицы #__content

CREATE INDEX idx_catid_state ON #__content (catid, state);
он сократил время загрузки категорий до 1 секунды. Затем наш герой решил поковырять SQL-запрос в ArticleModel, который отвечает за выборку материалов. И решил заменить тип JOIN на STRAIGHT_JOIN для категорий.
// ->from($db->quoteName('#__content', 'a'))->from(    $db->quoteName('#__content', 'a')    . ' STRAIGHT_JOIN ' . $db->quoteName('#__categories', 'c')    . ' ON ' . $db->quoteName('c.id') . ' = ' . $db->quoteName('a.catid'))// ->join('LEFT', $db->quoteName('#__categories', 'c'), $db->quoteName('c.id') . ' = ' . $db->quoteName('a.catid'))
Что сократило загрузку 200 материалов из 150к с 94 секунд до 5. К слову сказать, боевой сайт на Joomla 3 крутится на 12CPU 64GB рамы. А все манипуляции с кодом он делает на базовом 1CPU 1GB сервере и замеры скорости даны именно для базового сервера. Но это всё в дискуссии, хотя в идеале должно вылиться в Pull Requests. Мы - Open Source сообщество, где никто никому ничего не должен. Джунгли. Но человек ищет пути оптимизации Joomla и предлагает решения. Если оказать поддержку и предложить помощь хотя бы с тестированием самых разнообразных сценариев, то возможно эти улучшения смогут войти в ядро. Пусть не быстро, пусть через несколько лет, пусть не все, но войдут. Достаточно предложить руку помощи и приложить немного усилий.
Дискуссию на GitHub можно почитать здесь.@joomlafeed#joomla #community #php

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

lovezoom

  • Новичок
  • 4
  • 0 / 0
Сделал скрипт генерации xml-файла для Яндекс-Маркета( http://skill-spb.ru/market.php).
Но на сайте включен ЧПУ sef404, а скрипт,генерирующий  uml-файл формирует только не ЧПУ ссылки.
Для того, чтобы он стал формировать ЧПУ, необходимо в этом файле подключить  JRoute::_.
Пробовал подключение ядра как в index.php, но не работает.
Как подключить метод  JRoute::_, чтобы он заработал в этом файле?
Листинг market.php
Цитировать
<?php
// Версия коннектора к Yandex.Market
// Доработки:
// 1. Подключение к настройкам Joomla (теперь не надо прописывать реквизиты доступа к БД,
//         а достаточно указать конфигурационный файл 'configuration.php')
// 2. Добавлены комментарии для новичков
// 3. ВЫБОРКА ВСЕХ ТОВАРОВ ПРОИСХОДИТ ОДНИМ ЗАПРОСОМ!
// 4. Добавлен шаблон для описания товара (тег <description>)
// 5. Rурсы валют, приравнены к курсу ЦБРФ
// 6. Добавленны теги "доставка" и "производитель" (просто мне они нужны, а Вы решайте сами)
// а также: форматирование для удобства кода и вывода и еще что то по мелочам.
//
// Проверялось на Joomla! 1.5.9 Production/Stable / VirtueMart 1.1.2 stable
//
//***********************************************************
// Пропишите относительный путь к 'configuration.php' (он находится в корне Joomla)
// Например: include '../configuration.php';
include 'configuration.php';
$cfg = new JConfig();
//NAME - Короткое название магазина (название, которое выводится в списке найденных на Яндекс.Маркете товаров.
//Не должно содержать более 20 символов). Нельзя использовать слова, не имеющие отношения к
//наименованию магазина ("лучший", "дешевый"), указывать номер телефона и т.п. Название магазина,
//должно совпадать с фактическим названием магазина, которое публикуется на сайте. При несоблюдении
//данного требования наименование может быть изменено Яндексом самостоятельно без уведомления Клиента.
$cfg_name = $cfg->fromname;

//Полное наименование компании, владеющей магазином. Не публикуется, используется для внутренней идентификации.
$cfg_company = $cfg->sitename;

//URL-адрес главной страницы магазина
$cfg_url = 'www.skill-spb.ru';

// Шаблон для описания товара
// Вместо {product_name} - будет вставлено наименование товара
// Вместо {product_desc} - будет вставлено краткое описание
// ПРИМЕР:
// $description_template = '{product_name} от производителя';
$description_template = '{product_desc}';

// Ставка за клик (в центах)
$bid = '11';


$hostname             = $cfg->host;
$username             = $cfg->user;
$password             = $cfg->password;
$dbName             = $cfg->db;
$category             = $cfg->dbprefix."vm_category";
$category_xref          = $cfg->dbprefix."vm_category_xref";
$userstable          = $cfg->dbprefix."vm_product";
$pricetable          = $cfg->dbprefix."vm_product_price";
$product_category_xref    = $cfg->dbprefix."vm_product_category_xref";

mysql_connect($hostname,$username,$password) OR DIE("Не могу создать соединение ");
mysql_select_db($dbName) or die(mysql_error());

// Исправтье, если у вас другая кодировка в БД
mysql_query('set names utf8');

echo"<?xml version=\"1.0\" encoding=\"utf-8\"?>\n";
echo"<!DOCTYPE yml_catalog SYSTEM \"shops.dtd\">\n";
echo"<yml_catalog date=\"";
echo date('Y-m-d H:i');
echo"\">\n";
echo"<shop>\n";
echo"<name>$cfg_name</name>\n";
echo"<company>$cfg_company</company>\n";
echo"<url>http://$cfg_url</url>\n";

// курсы валют, приравнены к курсу ЦБРФ
echo"<currencies>\n";
echo"<currency  id=\"RUR\" rate=\"1\"/>\n";
echo"<currency  id=\"USD\" rate=\"CBRF\"/>\n";
echo"<currency  id=\"EUR\" rate=\"CBRF\"/>\n";
echo"</currencies>\n";

// Секция категорий
echo"<categories>\n";
$query_cat = "SELECT * FROM $category_xref";
$res_cat = mysql_query($query_cat) or die(mysql_error());
$rw=1;
while ($row_cat=mysql_fetch_array($res_cat)) {
   $cat_parent_id=$row_cat['category_parent_id'];
   $cat_child_id=$row_cat['category_child_id'];
   $query2 = "SELECT category_name FROM $category WHERE category_id=".$row_cat['category_child_id'];
   $res_cat1 = mysql_query($query2) or die(mysql_error());
   $name_cat=mysql_fetch_array($res_cat1);
   $cat_name=$name_cat['category_name'];
   if ($cat_parent_id==0) {
      echo"<category id=\"".$cat_child_id."\">".$cat_name."</category>\n";
   }
   else {
      echo"<category id=\"".$cat_child_id."\" parentId=\"".$cat_parent_id."\">".$cat_name."</category>\n";
   }
   $rw++;
}
echo"</categories>\n";

// Секция описания товаров
echo"<offers>\n";

$tb_product             = $cfg->dbprefix."vm_product";
$tb_manufacturer         = $cfg->dbprefix."vm_manufacturer";
$tb_product_mf_xref       = $cfg->dbprefix."vm_product_mf_xref";
$tb_category            = $cfg->dbprefix."vm_category";
$tb_product_category_xref   = $cfg->dbprefix."vm_product_category_xref";
$tb_price               = $cfg->dbprefix."vm_product_price";

$query = "
SELECT
   $tb_product.product_id,
   $tb_product.product_name,
   $tb_manufacturer.mf_name,
   $tb_manufacturer.manufacturer_id,
   $tb_category.category_name,
   $tb_category.category_id,
   $tb_product_category_xref.category_id,
   $tb_price.product_price,
   $tb_product.product_sku,
   $tb_product.product_in_stock,
   $tb_product.product_unit,
   $tb_product.product_full_image,
   $tb_product.product_s_desc,
   $tb_product.product_weight
FROM
   ($tb_product_category_xref
RIGHT JOIN ($tb_price
RIGHT JOIN (($tb_product_mf_xref
RIGHT JOIN $tb_product
ON $tb_product_mf_xref.product_id = $tb_product.product_id)
LEFT JOIN $tb_manufacturer
ON $tb_product_mf_xref.manufacturer_id = $tb_manufacturer.manufacturer_id)
ON $tb_price.product_id = $tb_product.product_id)
ON $tb_product_category_xref.product_id = $tb_product.product_id)
LEFT JOIN $tb_category
ON $tb_product_category_xref.category_id = $tb_category.category_id
WHERE $tb_product.product_publish='Y'
";

$row = d2a($query);
$product_log = Array();
for($i=0;$i<count($row);$i++) {
   if (!in_array($row[$i]['product_id'],$product_log) AND ($row[$i]['product_price'])) {
      $product_log[] = $row[$i]['product_id'];

      $url="http://$cfg_url/index.php?page=shop.product_details&amp;flypage=shop.flypage&amp;option=com/_virtuemart&amp;product_id=".$row[$i]['product_id'];
      
      
            //$url="http://$cfg_url/index.php?page=shop.product_details&flypage=shop.flypage&option=com_virtuemart&product_id=".$row[$i]['product_id'];
      //$url="index.php?page=shop.product_details&flypage=shop.flypage&option=com_virtuemart&product_id=".$row[$i]['product_id'];
      
      
      
      //$url="http://$cfg_url/client?page=shop.product_details&flypage=flypage-ask.tpl&product_id=".$row[$i]['product_id']."&category_id=".$row[$i]['category_id']."&manufacturer_id=".$row[$i]['manufacturer_id'];
      //$url="http://".$cfg_url."/".$row[$i]['product_id']."-".$row[$i]['product_name'].".html";
      $product_full_image = "http://$cfg_url/components/com_virtuemart/shop_image/product/".$row[$i]['product_full_image'];
      $tags = Array ('{product_name}','{product_desc}');
      $repl = Array ($row[$i]['product_name'],$row[$i]['product_s_desc']);
      $product_price = substr($row[$i]['product_price'], 0, -3);
      $product_cat_id=$row[$i]['category_id'];
      echo"\n<offer id=\"".$row[$i]['product_id']."\" available=\"true\" bid=\"$bid\">\n";
      //echo"<url>".htmlspecialchars($url)."</url>\n";
      echo"<url>".$url."</url>\n";
//echo"<a href='".$url."'</a>\n";
      echo"<price>$product_price</price>\n";
      // Валюта в которой указаны Ваши цены
      echo"<currencyId>RUR</currencyId>\n";
      echo"<categoryId>".$product_cat_id."</categoryId>\n";
      echo"<picture>".$product_full_image ."</picture>\n";
      // Возможность доставки
      echo"<delivery>true</delivery> \n";
      echo"<name>".strip_tags($row[$i]['product_name'])."</name>\n";
      echo"<description>".strip_tags(str_replace($tags,$repl,$description_template))."</description>\n";
      echo"</offer>\n";
   }
}

echo"</offers>\n";
echo"</shop>\n";
echo"</yml_catalog>\n";

function d2a($query){
    $result = mysql_query($query) or die("Query failed : " . mysql_error());
    while ($line = mysql_fetch_array($result, MYSQL_ASSOC)) {$res[] = $line;}
    mysql_free_result($result);
    return $res;
}

?>
*

lovezoom

  • Новичок
  • 4
  • 0 / 0
 JRoute::_  должен обрабатывать $url
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Подключение jQuery к Joomla 1.5

Автор Sergei_Han

Ответов: 1
Просмотров: 1679
Последний ответ 23.04.2015, 14:23:31
от kik84
CSS 3 Pie подключение к Joomla

Автор MaBudda

Ответов: 25
Просмотров: 15648
Последний ответ 31.03.2013, 00:13:30
от i-grek
Установка файла CSS и его подключение.

Автор Woland66

Ответов: 2
Просмотров: 1242
Последний ответ 02.02.2012, 19:11:16
от Woland66
Подключение к Базе данных

Автор Okulo

Ответов: 12
Просмотров: 6267
Последний ответ 20.01.2012, 16:16:41
от SnowMan
подключение сторонних PHP

Автор rewuxiin

Ответов: 2
Просмотров: 1443
Последний ответ 22.11.2011, 19:00:01
от rewuxiin