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

Ragnarok

  • Захожу иногда
  • 64
  • 1 / 0
Всем привет!
На Joomla 2.5.28 и JoomShopping 3.11.4 я делал порядок сортировки товаров на сайте по новому полю в Производителях (числовое поле). Но делал это через правку ядра. Все работало. Результатом всего этого было то, что, товары определенного производителя сортировались в зависимости от значения этого поля. То есть, я мог легко товары определенного производителя поднять на самый верх, либо выводить после товаров другого определенного производителя. Чем ниже значение, тем выше товары этого производителя. Что делал:

1. Создал поле "Порядок сортировки товаров" в шаблоне /administrator/components/com_jshopping/views/manufacturer/tmpl/edit.php
2. Создал поле в БД в таблице #__jshopping_manufacturers
2. В файле /administrator/components/com_jshopping/controllers/manufacturers.php в методе save(); дописал:
Код
$post['мое_новое_поле_'.$lang->language] = JRequest::getVar('мое_новое_поле'.$lang->id,'','post',"string", 2);
3. В файле /components/com_jshopping/tables/manufacturer.php в методе getDescription(); добавил:
Код
$мое_новое_поле = $lang->get('мое_новое_поле');
$this->мое_новое_поле= $this->$мое_новое_поле;
4. В файле /components/com_jshopping/lib/jtableauto.php в методе getBuildQueryOrderListProduct(); написал:
Код
$order_query = "ORDER BY `мое_новое_поле_ru-RU` ASC, man.`name_ru-RU`, pr_cat.product_ordering ASC";

Все отлично работало.

Теперь у меня Joomla! 3.9.23 и JoomShopping 4.18.5. На этот раз пытаюсь сделать через плагин, и ничего не выходит. Что делал?
1. Плагин при установке создает новую таблицу #__jshopping_manufacturers_extra_fields, где есть id производителя, название и значение этого нового поля
2. В шаблоне /administrator/templates/isis/html/com_jshopping/manufacturer/edit.php создал это поле
3. В плагине:
Код
defined( '_JEXEC' ) or die;

class plgJshoppingproductsManufacturers_Extra_Fields extends JPlugin {

function __construct(&$subject, $config){
parent::__construct($subject, $config);
}

public function onBeforeEditManufacturers(&$view){
$мое_новое_поле = $man_extra[$view->manufacturer->manufacturer_id]->мое_новое_поле;
$view->manufacturer->мое_новое_поле = $мое_новое_поле;
}

public function onBeforeSaveManufacturer(&$post){
$мое_новое_поле = $post['мое_новое_поле'];

$db = JFactory::getDbo();
$query = "INSERT INTO `#__jshopping_manufacturers_extra_fields` (`man_id`, `man_name`, `мое_новое_поле`)
VALUES ('".$man_id."', '".$man_name."', '".$мое_новое_поле."')
ON DUPLICATE KEY UPDATE `man_id` = '".$man_id."', `man_name` = '".$man_name."', `мое_новое_поле` = '".$мое_новое_поле."'";
$db->setQuery($query);
$db->query();
}

public function onBuildQueryOrderListProduct($order, $orderby, &$adv_from, &$order_query, $order_original){
$order_query = "ORDER BY мое_новое_поле ASC, name, pr_cat.product_ordering ASC";
}
}
В базу поле сохраняется, в админке выводится, тут все ок. Но на сайте выдает ошибку: 1054 Unknown column 'мое_новое_поле' in 'order clause'

Что я делаю не так?
Заранее благодарен.
« Последнее редактирование: 26.12.2020, 11:21:13 от Ragnarok »
*

kit2m2

  • Живу я здесь
  • 3370
  • 276 / 0
  • Беру сайты на полное сопровождение
Что это вообще такое pr_cat.product_ordering? Судя по псевдониму - pr_cat - это обращение к таблице #__jshopping_products_to_categories в которой нет "вашего поля".

В сообщении Вам ясно написано: Не соблюдено условие для сортировки
Расширения для JoomShopping | Ссылка на Телеграм-канал | Сайты и магазины под ключ: Дизайн, Верстка, Программирование (расширения на заказ), СЕО-оптимизация, Сопровождение, Перенос на Joomla 4+ (5+) и JoomShopping 5+
*

Ragnarok

  • Захожу иногда
  • 64
  • 1 / 0
Что это вообще такое pr_cat.product_ordering? Судя по псевдониму - pr_cat - это обращение к таблице #__jshopping_products_to_categories в которой нет "вашего поля".

В сообщении Вам ясно написано: Не соблюдено условие для сортировки
А откуда берутся эти псевдонимы? Как узнать, какой псевдоним у определенной таблицы?
*

kit2m2

  • Живу я здесь
  • 3370
  • 276 / 0
  • Беру сайты на полное сопровождение
А откуда берутся эти псевдонимы?
Они задаются в запросе к таблице при выборки данных для страницы (смотреть нужно в ядре компонента, как формируется запрос)

Подробнее о псевдонимах здесь
Расширения для JoomShopping | Ссылка на Телеграм-канал | Сайты и магазины под ключ: Дизайн, Верстка, Программирование (расширения на заказ), СЕО-оптимизация, Сопровождение, Перенос на Joomla 4+ (5+) и JoomShopping 5+
*

Ragnarok

  • Захожу иногда
  • 64
  • 1 / 0
Методом научного тыка решил вопрос следующим образом. В плагине:
Код
<?php
defined( '_JEXEC' ) or die;

class plgJshoppingproductsManufacturers_Extra_Fields extends JPlugin {

function __construct(&$subject, $config){
parent::__construct($subject, $config);
}

public function onBeforeEditManufacturers(&$view){
$мое_новое_поле = $man_extra[$view->manufacturer->manufacturer_id]->мое_новое_поле;
$view->manufacturer->мое_новое_поле = $мое_новое_поле;
}

public function onBeforeSaveManufacturer(&$post){
$мое_новое_поле = $post['мое_новое_поле'];

$db = JFactory::getDbo();
$query = "INSERT INTO `#__jshopping_manufacturers_extra_fields` (`man_id`, `man_name`, `мое_новое_поле`)
VALUES ('".$man_id."', '".$man_name."', '".$мое_новое_поле."')
ON DUPLICATE KEY UPDATE `man_id` = '".$man_id."', `man_name` = '".$man_name."', `мое_новое_поле` = '".$мое_новое_поле."'";
$db->setQuery($query);
$db->query();
}

public function onBuildQueryOrderListProduct($order, $orderby, &$adv_from, &$order_query, $order_original){
$adv_from = " LEFT JOIN `#__jshopping_manufacturers_extra_fields` AS mef ON prod.product_manufacturer_id = `man_id`";
$order_query = "ORDER BY mef.мое_новое_поле ASC, mef.man_name ASC, pr_cat.product_ordering ASC";
}
}
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

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

Автор thevaca

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

Автор sergeytolkachyov

Ответов: 26
Просмотров: 36002
Последний ответ 14.10.2025, 12:54:56
от sergeytolkachyov
Модуль карусели товаров JoomShopping на Swiper.js для Joomla

Автор sergeytolkachyov

Ответов: 2
Просмотров: 2223
Последний ответ 04.07.2025, 10:30:36
от sergeytolkachyov
[Решено] Сбросить счётчик ID товаров JoomShopping

Автор goga_pgasovav

Ответов: 3
Просмотров: 1478
Последний ответ 13.02.2025, 00:11:20
от goga_pgasovav
Плагин обновления цен и остатков товаров JoomShopping из CSV

Автор sergeytolkachyov

Ответов: 0
Просмотров: 1687
Последний ответ 24.12.2024, 14:50:42
от sergeytolkachyov