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

motor1

  • Осваиваюсь на форуме
  • 38
  • 4 / 0
Доброе время суток
возникла проблема с реализацией
нужно сделать такой вид в каталоге 
как я понимаю нужно править  шаблон по ссылки
/сайт/public_html/components/com_virtuemart/views/categories/tmpl

Если я правильно понимаю нужно данный шаблон сделать в таблицу?
Если кто знает как это сделать буду очень благодарен.)
*

motor1

  • Осваиваюсь на форуме
  • 38
  • 4 / 0
Нашёл вот такую статью
Итак, для решения описанной выше проблемы необходимо подключиться к вашему серверу по FTP и открыть на редактирование ps_product_category.php, который лежит на сервере вашего хостинга в папке administrator\components\com_virtuemart\classes. Нашли?

Теперь с помощью встроенного поиска того редактора, в котором вы открыли на редактирование данный файл (рекомендую скачать портабл версию Notepad ++ здесь), найдите следующий кусок кода:
Код
function products_in_category( $category_id ) {
  if( PSHOP_SHOW_PRODUCTS_IN_CATEGORY == '1' ) {
   $num = ps_product_category::product_count($category_id);
   if( empty($num) && ps_product_category::has_childs( $category_id )) {
    $db = new ps_DB;
    $q = "SELECT category_child_id FROM #__{vm}_category_xref ";
    $q .= "WHERE category_parent_id='$category_id' ";
    $db->query($q);
    while( $db->next_record() ) {
     $num += ps_product_category::product_count($db->f("category_child_id"));
    }
   }
 
   return " ($num) ";
  }
  else
  return ( "" );
 }

Выделите его и замените следующим кодом:

Код
function prod_in_cat_recursive( $category_id ) {
 $num=0;
 if (ps_product_category::has_childs( $category_id )) {
  $db = new ps_DB;
  $q = "SELECT category_child_id FROM #__{vm}_category_xref ";
  $q .= "WHERE category_parent_id='$category_id' ";
  $db->query($q);
  while( $db->next_record() ) {
   $num += ps_product_category::prod_in_cat_recursive($db->f("category_child_id"));
    }
   }
    $num += ps_product_category::product_count($category_id);
   return $num;
   }
 function products_in_category( $category_id ) {
  if( PSHOP_SHOW_PRODUCTS_IN_CATEGORY == '1' ) {
  $num = ps_product_category::prod_in_cat_recursive( $category_id );
  return " ($num) ";
  }
  else
  return "";
  }


но как понимаю я это вариант в старой версии как сделать в новой VirtueMart 2 а то во 2  нет файла ps_product_category.php
*

Максим Пишняк

  • Давно я тут
  • 837
  • 35 / 0
Странно, в форумном поиске должна показываться тема "Колличество товара в категории".
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться