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

Stasweb

  • Завсегдатай
  • 1501
  • 24 / 0
Как сделать порядковый номер артикула
код такой
Код
		<?php  //AUTO product_sku
    echo '<input type="text" class="inputbox" name="product_sku" id="product_sku" value="';
          if ($this->product->product_sku) $val_sku= $this->product->product_sku;
                    else {
                        $db_sku = JFactory::getDBO();
                        $q_sku = 'SELECT `product_sku` FROM #__virtuemart_products ORDER BY `product_sku` DESC LIMIT 1';
                        $db_sku->setQuery($q_sku);
                        $db_sku->next_record();
                        $val_sku = intval($this->product->virtuemart_product_id)+rand(intval($this->product->product_id), 9999);
                          }
    echo $val_sku.'" size="32" maxlength="64" />';
?>
меняю в /administrator/components/com_virtuemart/views/product/tmpl/product_edit_information.php
артикул присваивает по разному не по порядку.
как сделать так чтоб он его присваивал по порядку 
*

motokraft

  • Завсегдатай
  • 1326
  • 72 / 13
Re: Порядковый номер артикула
« Ответ #1 : 20.05.2015, 08:28:23 »
в базе данных id записи указываются по порядку, можно все эти записи сортировать по возрастанию и к последнему плюсуй 1....
...
*

Stasweb

  • Завсегдатай
  • 1501
  • 24 / 0
Re: Порядковый номер артикула
« Ответ #2 : 20.05.2015, 08:29:45 »
то есть так
Код
$q_sku = 'SELECT `product_sku` FROM #__virtuemart_products ORDER BY `product_sku` DESC LIMIT +1';
то сохраняет 4021 потом пере сохраняю 2336
« Последнее редактирование: 20.05.2015, 08:32:53 от Stasweb »
*

Stasweb

  • Завсегдатай
  • 1501
  • 24 / 0
Re: Порядковый номер артикула
« Ответ #3 : 20.05.2015, 08:34:48 »
Сделал так
Код
<?php  //AUTO product_sku
    echo '<input type="text" class="inputbox" name="product_sku" id="product_sku" value="';
          if ($this->product->product_sku) $val_sku= $this->product->product_sku;
                    else {
                        $db_sku = JFactory::getDBO();
                        $q_sku = 'SELECT `product_sku` FROM #__virtuemart_products ORDER BY `product_sku` DESC LIMIT 1';
                        $db_sku->setQuery($q_sku);
                        $db_sku->next_record();
                        $val_sku = intval($this->product->virtuemart_product_id)+rand(intval($this->product->product_id), +1);
                          }
    echo $val_sku.'" size="32" maxlength="64" />';
?>
теперь присваивает 138 - 139 а потом 137 два раза подряд
*

motokraft

  • Завсегдатай
  • 1326
  • 72 / 13
Re: Порядковый номер артикула
« Ответ #4 : 20.05.2015, 08:39:46 »
При создании материала создается артикл, вместо его выводи id последней записи и прибавляй 1, не используй sql запрос для формирования артикла...
...
*

Stasweb

  • Завсегдатай
  • 1501
  • 24 / 0
Re: Порядковый номер артикула
« Ответ #5 : 20.05.2015, 08:41:42 »
как это сделать вот стандартный запрос
<input type="text" class="inputbox" name="product_sku" id="product_sku" value="<?php echo $this->product->product_sku; ?>" size="32" maxlength="64" />
*

motokraft

  • Завсегдатай
  • 1326
  • 72 / 13
Re: Порядковый номер артикула
« Ответ #6 : 20.05.2015, 08:45:14 »
А какой вид артикла формируется....
...
*

Stasweb

  • Завсегдатай
  • 1501
  • 24 / 0
Re: Порядковый номер артикула
« Ответ #7 : 20.05.2015, 08:47:47 »
Если так
Код
<input type="text" class="inputbox" name="product_sku" id="product_sku" value="<?php echo $this->product->product_sku; ?>" size="32" maxlength="64" /> 
то вообще пусто
*

motokraft

  • Завсегдатай
  • 1326
  • 72 / 13
Re: Порядковый номер артикула
« Ответ #8 : 20.05.2015, 08:54:52 »
Да нееее, не код формирования, а как он сам выглядит на странице...
...
*

Stasweb

  • Завсегдатай
  • 1501
  • 24 / 0
Re: Порядковый номер артикула
« Ответ #9 : 20.05.2015, 08:59:57 »
Вот скрин

id товара есть а артикул поля пустое
*

motokraft

  • Завсегдатай
  • 1326
  • 72 / 13
Re: Порядковый номер артикула
« Ответ #10 : 20.05.2015, 09:10:49 »
Я сейчас с телефона сежу, полный код првести не могу. Но SQL запросом надо вывести id последней записи, укажи LIMIT 1, так выводится одна последняя запись а не все в сортированном виде...
Получив id последней записи, надо прибавить +1 и записать в поле. При сохранении товара все что в этом поле будет использоваться как артткл....

Можно еще отдельно генерировать две буквы в начале....
...
*

Stasweb

  • Завсегдатай
  • 1501
  • 24 / 0
Re: Порядковый номер артикула
« Ответ #11 : 20.05.2015, 09:20:27 »
А тут разве не так
Код
 if ($this->product->product_sku) $val_sku= $this->product->product_sku;
 else {
 $db_sku = JFactory::getDBO();
 $q_sku = 'SELECT `product_sku` FROM #__virtuemart_products ORDER BY `product_sku` DESC LIMIT 1';
 $db_sku->setQuery($q_sku);
 $db_sku->next_record();
 $val_sku = intval($this->product->virtuemart_product_id)+rand(intval($this->product->product_id), +1);
     }
 echo $val_sku.'" size="32" maxlength="64" />';
?>
*

Stasweb

  • Завсегдатай
  • 1501
  • 24 / 0
Re: Порядковый номер артикула
« Ответ #12 : 20.05.2015, 09:55:53 »
РЕШИЛ ОСТАВИТЬ ТАК ПО ТЕСТИРУЮ НА НОВЫХ ТОВАРАХ
Код
<?php  //AUTO product_sku
 echo '<input type="text" class="inputbox" name="product_sku" id="product_sku" value="';
 if ($this->product->product_sku) $val_sku= $this->product->product_sku;
 else {
 $db_sku = JFactory::getDBO();
 $q_sku = 'SELECT `product_sku` FROM #__virtuemart_products ORDER BY `product_sku` DESC LIMIT 1';
 $db_sku->setQuery($q_sku);
 $db_sku->next_record();
 $val_sku = intval($this->product->virtuemart_product_id)+rand(intval($this->product->product_id), +1);
     }
 echo $val_sku.'" size="32" maxlength="64" />';
?>
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Человеческий номер заказа

Автор vlom

Ответов: 28
Просмотров: 13702
Последний ответ 25.04.2018, 16:45:54
от SLAVJAN
Обновление артикула при выборе цвета или размера

Автор umbabaraumba

Ответов: 3
Просмотров: 1373
Последний ответ 23.07.2015, 21:03:23
от gartes