Новости Joomla

Перевод и публикация интервью с 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

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

max_max

  • Осваиваюсь на форуме
  • 40
  • 0 / 0
Здравствуйте. Мне необходимо исключить неопубликованные товары из выгрузки товаров в ЯндексМаркет. На данный момент, все неопубликованные товары попадают в выгрузку (в файл YML). В файле yml.php есть подключение через запрос. Выглядит данное подключение так:

Код
if ($products = mysqli_query($mysqli, 'SELECT a.product_id, a.`name_ru-RU`, a.product_price,  a.`description_ru-RU`, a.image, a.`alias_ru-RU`, b.category_id, c.category_parent_id, c.`short_description_ru-RU` FROM jf1yo_jshopping_products as a, jf1yo_jshopping_products_to_categories as b, jf1yo_jshopping_categories as c  WHERE b.product_id = a.product_id AND c.category_id = b.category_id')) {
    $xml .= "<offers>\n";

    while( $row = mysqli_fetch_assoc($products) ){
        // $url = SEFLink("index.php?option=com_jshopping&controller=product&task=view&category_id=".$row['category_id']."&product_id=".$row['product_id'], 1);
        if ($row[product_price] > 0){
        $xml .= "<offer id=\"".$row['product_id']."\" available=\"true\">\n";
        setlocale(LC_MONETARY, 'en_US');
        $price = money_format('%i', $row['product_price']);
        $xml .= "<price>".$price."</price>\n";
        $xml .= "<currencyId>RUR</currencyId>\n";
        $xml .= "<categoryId>".$row['category_id']."</categoryId>\n";
        $xml .= "<name>".$row['name_ru-RU']."</name>\n";   
        $xml .= "<description> \n <![CDATA[".$row['description_ru-RU']."\n ]]> \n </description>\n";
        $xml .= "<picture>http://dmk.su/components/com_jshopping/files/img_products/".$row['image']."</picture>\n";
            if ($row['short_description_ru-RU'] != "")
                if ($row['alias_ru-RU'] != "")
                $xml .= "<url>".$row['short_description_ru-RU'].'/'.$row['alias_ru-RU']."</url>\n";
                else
                $xml .= "<url>".$row['short_description_ru-RU'].'/product/view/'.$row['category_id'].'/'.$row['product_id']."</url>\n";
            else {
                $parentdisc = mysqli_query($mysqli, 'SELECT `short_description_ru-RU` FROM jf1yo_jshopping_categories WHERE category_id = '.$row["category_parent_id"]);
                $discrow = mysqli_fetch_assoc($parentdisc);
                $parental = mysqli_query($mysqli, 'SELECT `alias_ru-RU` FROM jf1yo_jshopping_categories WHERE category_id = '.$row["category_id"]);
                $aliasrow = mysqli_fetch_assoc($aliasrow);
                // $xml .= "<test>".var_dump('SELECT `short_description_ru-RU` FROM jf1yo_jshopping_categories WHERE category_id = '.$row["category_parent_id"])."----".var_dump($discrow)."</test>\n\n\n\n";
                if ($row['alias_ru-RU'] != "")
                $xml .= "<url>".$discrow['short_description_ru-RU'].'/'.$aliasrow['alias_ru-RU'].'/'.$row['alias_ru-RU']."</url>\n";
                else
                 $xml .= "<url>".$discrow['short_description_ru-RU'].'/'.$aliasrow['alias_ru-RU'].'/'.$row['product_id']."</url>\n";   
               
            }
        $xml .= "</offer>\n";
        }
    }
    $xml .= "</offers>\n";

    mysqli_free_result($products);
}

mysqli_close($mysqli);

$xml .= "</shop>\n</yml_catalog>";

echo $xml;

Нужно прописать условие в этом запросе, которое не позволит выводит неопубликованные товары. Но я не знаю как обратиться к этим товарам со статусом "Неопубликованные".

Используйется JoomShopping.

Спасибо за помощь!
« Последнее редактирование: 25.05.2021, 12:29:22 от max_max »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Плагин уведомлений о заказах в телеграмм для JoomShopping

Автор thevaca

Ответов: 0
Просмотров: 84
Последний ответ 10.11.2025, 14:11:40
от thevaca
WT JoomShopping Favorite - кнопки избранного в категории товаров и карточке тов

Автор sergeytolkachyov

Ответов: 26
Просмотров: 35995
Последний ответ 14.10.2025, 12:54:56
от sergeytolkachyov
Не работает lightbox в JoomShopping

Автор d13v555

Ответов: 6
Просмотров: 1311
Последний ответ 08.10.2025, 15:34:46
от kit2m2
Атрибуты полей при оформлении заказа в JoomShopping

Автор goga_pgasovav

Ответов: 1
Просмотров: 765
Последний ответ 12.08.2025, 11:21:29
от kit2m2
Конфликт js шаблонов JoomShaper helix3 J5 с JoomShopping 5

Автор heartlink

Ответов: 6
Просмотров: 1536
Последний ответ 22.07.2025, 12:40:12
от heartlink