Новости Joomla

Перевод и публикация интервью на греческом портале Joomla Утро, просматриваешь входящие письма и...

Перевод и публикация интервью на греческом портале Joomla 🇬🇷Утро, просматриваешь входящие письма и изучаешь новости и внезапно обнаруживаешь, что инициатива, которую ты начал, подхватывается другими людьми. 🎉Недавно я взял интервью у Билла (Василиса) Коциаса - руководителя студии, читающего лекции в университете и популяризатора Joomla в Греции.Это интервью из журнала NorrNext, в оригинале на английском, теперь доступно на греческом языке и опубликовано на портале joomla.gr. 🎉До чего же приятно… 😇😊 Работа замечена и с ней посчитали необходимым ознакомить аудиторию страны, в которой Билл читает лекции. И это солнечная Греция - страна, страна, с которой Россию многое связывает. 🇬🇷🇷🇺🕊Смотрю на греческий алфавит и тут же рисуются картины белоснежных зданий в окружении винограда и амфор, красивых женщин в сандалиях и мужественных воинов, охраняющих покой полисов, в которых ученые мужи работают над трудами, позже вошедшими в века. Красиво! 😇Но вернемся к интервью. Из него вы узнаете, что в Греции доля Joomla среди CMS занимает порядка 30-40%. По моему мнению это - самый высокий показатель во всем мире. Также чтение лекций о Joomla в университетах позволит привести новых пользователей и к тому же молодое поколение. Ну и огромное кол-во сертификтатов Билла на стене (смотрим фото в статье) свидетельствует о том, что Joomla может применяться как профессиональный инструмент. 🇬🇷 Интервью на греческом портале (joomla.gr)🌐 Оригинальное интервью (на английском)Что насчет перевода на русский? Увы, времени всего 24 часа в сутках. Я продолжаю готовить новые интервью. Возможно, после завершения выпуска журнала, рассмотрю перевод некоторых интервью на русский. Но я об этом не говорил. 😊 В блоге @eugenius_blog публикую анонсы интересных событий из мира Joomla, интервью, уроки и полезные советы, а также делюсь мыслями:, связанными с разработкой и веб-дизайном.

Обработка HTTP ответа в Joomla 6+. Изменения по сравнению с Joomla 3 - Joomla 5

👩‍💻 Обработка HTTP ответа в Joomla 6+. Изменения по сравнению с Joomla 3 - Joomla 5.В Joomla для выполнения внешних запросов из PHP к сторонним API используется класс Joomla\Http\Http напрямую или же Joomla\Http\HttpFactory, который возвращает для работы преднастроенный по умолчанию класс Http. О работе с HTTP-запросами подробно рассказывалось в статье 2021 года Создание внешних запросов с использованием HttpFactory (Joomla). Некоторые изменения касаются работы с ответами на запросы. Например, наш запрос:
use Joomla\Http\HttpFactory;$http = (new HttpFactory)->getHttp($options, ['curl', 'stream']);$response = $http->get('https://any-url.ru/api/any/endpoint');
Раньше можно было получить код ответа или тело ответа как свойство $response - $response->code или $response->body. Однако, Joomla, начиная с Joomla 4 во многом переходит на стандарты PSR. В частности для работы с HTTP-ответами - на PSR-7. Также хорошая статья на Хабре о PSR-7: PSR-7 в примерах.
Прямое обращение к свойствам code, headers, body объявлено устаревшим в Joomla 6.0.0 и обещают удалить в Joomla 7.0.0.
Вместо этого нужно работать с HTTP-ответом по стандартам PSR-7. Код ответа.Было $response->code. Стало $response->getStatusCode().Заголовки ответа.Было $response->headers. Стало $response->getHeaders().Тело ответа.Было $response->body. Стало (string)$response->getContents().В тело ответа теперь приходит не строка, а поток - объект класса Laminas\Diactoros\Stream. Поэтому его нужно привести к строке (если это json, к примеру): (string)$response->getContents(). Чаще всего в коде Joomla встречается именно такой вариант. Однако, есть и вариант с перемещением указателя чтения на начало потока:
// Получили ответ в виде потока$stream = $response->getBody();// "перемотали" на начало$stream->rewind();// Получили строковый ответ$json = $stream->getContents();
В итоге результат одинаковый.@joomlafeed#joomla #разработка #php

Quantum Manager нужен сообществу, а автору нужна ваша поддержка!

Quantum Manager нужен сообществу, а автору нужна ваша поддержка!Файловый менеджер Quantum — одно...

Файловый менеджер Quantum — одно из самых популярных решений для Joomla, созданное разработчиком из сообщества Joomla, Дмитрием Цымбалом (@tsymbalmitia). Он делает Quantum удобным, безопасным и современным, обновляет его, исправляет уязвимости и отвечает пользователям — всё это в свободное от основной работы время.

Теперь настал момент для следующего шага: развитие проекта требует больше времени и ресурсов.

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

vkravez

  • Новичок
  • 1
  • 0 / 0
Здравствуйте.
Помогите пожалуйста добавить писание в выгрузку XML.
В коде не очень еще силен.
Есть два файла hotline.php и hotline.xml
Пробовал добавить строку: <description>' . $product['product_desc'] . '</description>
Но результата нет.

Вот код hotline.php
Код
<?php

define('_JEXEC', 1);
define('DS', DIRECTORY_SEPARATOR);
define('JPATH_BASE', str_replace('market', '', dirname(__FILE__)));
define('ORDER', 'на заказ');
define('SKLAD', 'на складе');

require_once(JPATH_BASE.DS.'includes'.DS.'defines.php');
require_once(JPATH_BASE.DS.'includes'.DS.'framework.php');

$app = JFactory::getApplication('site');
$app->initialise();

require(JPATH_ADMINISTRATOR.DS.'components'.DS.'com_virtuemart'.DS.'helpers'.DS.'config.php');
VmConfig::loadConfig();
$confFile = "../configuration.php";
require_once($confFile);
$conf = new JConfig();
$link = mysql_connect($conf->host, $conf->user, $conf->password) or die ("Could not connect to MySQL");
mysql_select_db ($conf->db) or die ("Could not select database");

$db = JFactory::getDBO();
$config = new JConfig();

$query = "SELECT prod.virtuemart_product_id, prod.product_name, prod.slug, price.product_price, price.product_currency, med.file_url, manuf.mf_name, prod_sku.product_sku, prod_sku.product_packaging, cat.category_name,
  MAX(prod_cat.virtuemart_category_id) as caty, cat.slug as slugcat
      FROM rt1fh_virtuemart_products_ru_ru AS prod
      LEFT JOIN rt1fh_virtuemart_product_prices AS price ON price.virtuemart_product_id = prod.virtuemart_product_id
      LEFT JOIN rt1fh_virtuemart_product_medias AS prod_img ON prod.virtuemart_product_id = prod_img.virtuemart_product_id
      LEFT JOIN rt1fh_virtuemart_medias AS med ON prod_img.virtuemart_media_id = med.virtuemart_media_id
      LEFT JOIN rt1fh_virtuemart_product_manufacturers AS prod_manuf ON prod.virtuemart_product_id = prod_manuf.virtuemart_product_id
      LEFT JOIN rt1fh_virtuemart_manufacturers_ru_ru AS manuf ON prod_manuf.virtuemart_manufacturer_id = manuf.virtuemart_manufacturer_id
      LEFT JOIN rt1fh_virtuemart_products AS prod_sku ON prod.virtuemart_product_id = prod_sku.virtuemart_product_id
      LEFT JOIN rt1fh_virtuemart_product_categories AS prod_cat ON prod.virtuemart_product_id = prod_cat.virtuemart_product_id
      LEFT JOIN rt1fh_virtuemart_categories_ru_ru AS cat ON prod_cat.virtuemart_category_id = cat.virtuemart_category_id
      WHERE prod_sku.published = 1 AND price.product_price > 4
      GROUP BY prod.virtuemart_product_id
      ORDER BY prod_sku.product_sku
      ";
mysql_query("SET NAMES 'utf8'");


$db->setQuery($query);
$result = $db->loadAssocList();

$query2 = "SELECT caty.virtuemart_category_id, category_parent_id, category_child_id, category_name  FROM rt1fh_virtuemart_categories AS category
                LEFT JOIN rt1fh_virtuemart_categories_ru_ru AS caty ON category.virtuemart_category_id = caty.virtuemart_category_id
                LEFT JOIN rt1fh_virtuemart_category_categories AS child ON category.virtuemart_category_id = child.category_child_id
                WHERE caty.virtuemart_category_id > 0 AND published = 1
                GROUP BY category.virtuemart_category_id
      ";



$db->setQuery($query2);
$result2 = $db->loadAssocList();
// print_r($result2);



$dom = new domDocument();
$xml='<?xml version="1.0" encoding="UTF-8"?>';
$xml .= '<price date="'.date("Y-m-d H:i").'">
     <firmName>Интернет магазин kgu</firmName>
     <firmId>1234</firmId>
  <categories>';
foreach ($result2 as $caty) {
    if(!empty($caty['virtuemart_category_id'])){
        $str =($caty['category_parent_id'] == 0)?'':'<parent>'.$caty['category_parent_id'].'</parent>';
        $xml  .= '
    <category> <id>'.$caty['virtuemart_category_id'].'</id> '.$str.'<name>'.htmlspecialchars($caty['category_name']).'</name></category>';
    }
}

$xml  .='
</categories>
';

$xml  .='<items>';
foreach ($result as $product) {
    //if(empty($product['caty'])) {


        $xml .= '
    <item> <id>"' . $product['virtuemart_product_id'] . '"</id>
    <categoryId>' . $product['caty'] . '</categoryId>
    <code>' . $product['product_sku'] . '</code>
    <vendor>' . $product['mf_name'] . '</vendor>
    <name>' . $product['product_name'] . '</name>
    <priceRUAH>' . (int)$product['product_price'] . '</priceRUAH>
    <url>http://kgu.com.ua/ru/katalog/' . $product['slug'] . '-detail</url>
    <image>http://kgu.com.ua/' . $product['file_url'] . '</image>
    <stock>В наличии</stock>
    </item>';
  //  }


}
$xml .='
</items>
</price>';
//echo $xml;
$dom->loadXML($xml); // Загружаем в объект domDocument XML-разметку

$dom->save("hotline.xml"); // Сохраняем XML-документ в файл
$dom->load("hotline.xml"); // Выгружаем из файла XML-документ
//echo htmlspecialchars($dom->saveXML()); // Выгрузка в окно браузере XML-документа (уже из файла)

header("Location:http://kgu.com.ua/market/hotline.xml");



?>
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

[Решено] Получить category description image в index.php шаблона

Автор goga_pgasovav

Ответов: 6
Просмотров: 1498
Последний ответ 12.07.2024, 17:06:14
от goga_pgasovav
Блог | Тайтл, description подкатегории

Автор darkghost

Ответов: 0
Просмотров: 642
Последний ответ 02.02.2024, 22:25:53
от darkghost
Блок особенностей, как добавить в поле с информацией кнопку или ссылку Подробнее

Автор Alex from SPb

Ответов: 5
Просмотров: 979
Последний ответ 28.11.2022, 19:54:42
от marksetter
Как добавить текст на раздел без отображения на всех внутренних и статьях?

Автор Igor5

Ответов: 1
Просмотров: 1829
Последний ответ 24.11.2022, 18:35:04
от beliyadm
Разрыв страницы и meta description

Автор seregaы

Ответов: 0
Просмотров: 741
Последний ответ 05.09.2022, 17:19:12
от seregaы