Новости Joomla

Как тестировать Joomla PHP-разработчику? Компонент Patch tester.

👩‍💻 Как тестировать Joomla PHP-разработчику? Компонент Patch tester.Joomla - open source PHP-фреймворк с готовой админкой. Его основная разработка ведётся на GitHub. Для того, чтобы международному сообществу разработчиков было удобнее тестировать Pull Requests был создан компонент Patch Tester, который позволяет "накатить" на текущую установку Joomla именно те изменения, которые необходимо протестировать. На стороне инфраструктуры Joomla для каждого PR собираются готовые пакеты, в которых находится ядро + предложенные изменения. В каждом PR обычно находятся инструкции по тестированию: куда зайти, что нажать, ожидаемый результат. Тестировщики могут предположить дополнительные сценарии, исходя из своего опыта и найти баги, о которых сообщить разработчику. Или не найти, и тогда улучшение или исправление ошибки быстрее войдёт в ядро Joomla. Напомню, что для того, чтобы PR вошёл в ядро Joomla нужны минимум 2 положительных теста от 2 участников сообщества, кроме автора. Видео на YouTubeВидео на VK ВидеоВидео на RuTubeКомпонент на GitHub https://github.com/joomla-extensions/patchtester@joomlafeed#joomla #php #webdev #community

Вышел релиз Revo PageBuilder Toolkit for YOOtheme Pro 1.6

Вышел релиз Revo PageBuilder Toolkit for YOOtheme Pro 1.6.2PageBuilder Toolkit - это специализированный плагин для конструктора страниц Yootheme Pro, содержит набор различных утилит для ускорения процесса работы и отладки макета, множественные улучшения в интерфейсе, включая поддержку dark mode, подсказки, быстрая смена разрешения в окне просмотра и много чего еще.v.1.6.2 Что нового?- Индикатор статусов: теперь не просто показывает состояние запросов, но и делает автоматические попытки их отправки при кратковременных сбоях в сети, а если это не помогло, то переводит конструктор в ручной режим, что позволяет сохранит макет и настройки темы прежде чем вы потеряете все, что было сделано с момента последнего сохранения- Подсветка ошибок в макете: плагин анализирует код страницы и может автоматически подсвечивать data атрибуты с кучей мусора, которые попадают в код страницы при копипасте из Figma в TinyMCE (пригодится для старых макетов, в текущей работе плагин сам очищает код мусора). Также есть подсветка семантических ошибок сборки - дубли h1 тега на странице и вложенных друг в друга заголовков.- Улучшена поддержка будущего релиза Yootheme Pro 5 и редактора CodeMirror 6Плагин для русскоязычных пользователей доступен в каталоге расширений SovMart и распространяется за символическую плату (100р). Разработчики Joomla расширений и партнеры автора могут получить плагин бесплатно.Для работы плагина необходим конструктор страниц Yootheme Pro.Разработчик плагина - участник нашего сообщества Александр Судьбинов (@alexrevo), член официальной группы поддержки Yootheme Pro. Страница расширенияОписание на сайте автора@joomlafeed#joomla #yootheme

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

Gremlin

  • Захожу иногда
  • 293
  • 11 / 0
Скажу сразу - это не Большой Брат  ;D
Задача - отслеживать действия покупателей в корзине: что положили в корзинку, на каком этапе оформления заказа задерживались, с какого этапа отказались делать заказ и т.д.
Настройки Целей в Яндексе и Гугле не очень помогают, особенно при установленном SEF404. Сделал логирование самостоятельно. Теперь в отдельный файл пишется когда, кто (id, email и имя) на каком этапе оформления заказа находился покупатель. Дополнительно выводится содержимое его корзины. Эти данные нужны для улучшения эффективности работы магазина ;).
Код писался очень быстро и далек от совершенства, но работает ;)
Правим файл administrator/components/com_virtuemart/html/checkout.index.php. В самом начале с 24-й строки пишем:
Код
function getUserName ( $user_id )
{
$q = 'SELECT `name`, `email` FROM `jos_users` WHERE `id` ='.$user_id;
$db = new ps_DB();
$db->query( $q );
$name = "-----------------";
while ( $db->next_record() ) {
$name = $db->f ( "name" );
$name .= " : " . $db->f ( "email" );
}
return $name;
}

function getProductName ( $id )
{
$q = 'SELECT `product_sku` FROM `jos_vm_product` WHERE `product_id` = ' . $id;
$db = new ps_DB();
$db->query( $q );
$sku = "------------------";
while ( $db->next_record() ) {
$sku = $db->f ( "product_sku" );
}
return $sku;
}
Где-то в районе 304-й строки после кода:
Код
	<input type="hidden" name="zone_qty" value="'. $zone_qty .'" />
        <input type="hidden" name="ship_to_info_id" value="'. $ship_to_info_id .'" />
        <input type="hidden" name="shipping_rate_id" value="'. urlencode($shipping_rate_id).'" />
        <input type="hidden" name="payment_method_id" value="'. $payment_method_id .'" />
        <input type="hidden" name="checkout_last_step" value="'. $current_stage .'" />';

$theme->set( 'basket_html', $basket_html );
   
вставляем:
Код
// Определяем имя файла для записи лога
$logfilename = "logs/" . date ( "d-m-Y" ). ".log";
- тут определяем имя файла для лога. Я пишу в файл с именем соответсвующим текущей дате, файлы складываю в папке /logs в корне сайта. Не забываем закрыть ее от посторонних и поисковых роботов!
Буквально через пару строк, после кода:
Код
	    if( in_array('CHECK_OUT_GET_SHIPPING_ADDR', $checkout_steps[$current_stage]) ) {
echo '<a name="CHECK_OUT_GET_SHIPPING_ADDR"></a>';
echo $theme->fetch( 'checkout/get_shipping_address.tpl.php');
$theme->set('basket_html', '');
пишем:
Код
// Мы на шаге выбора адреса
if ( $logfile = fopen ( $logfilename, 'a+' ) ) {
fwrite ( $logfile, date ( "d-m-Y H:i:s") );
fwrite ( $logfile, "  -  Adress  . UserId = " );
fwrite ( $logfile, (int)$auth['user_id'] . " : " . getUserName ( (int)$auth['user_id'] ). "\n" );
for($i = 0; $i < $cart["idx"]; $i++) {
fwrite ( $logfile, "      " . $cart[$i]['quantity'] . " : " . getProductName ( $cart[$i]['product_id'] ). "\n" );
}
fwrite ( $logfile, "  \n" );
fclose ( $logfile );
}
// Выбор адреса закончился
- тут производим запись в лог данных о текущем времени, данных пользователя и его корзину.
после:
Код
        if( in_array('CHECK_OUT_GET_SHIPPING_METHOD', $checkout_steps[$current_stage]) ) {   
        echo '<a name="CHECK_OUT_GET_SHIPPING_METHOD"></a>';
        echo $theme->fetch( 'checkout/get_shipping_method.tpl.php');
$theme->set('basket_html', '');
вставляем:
Код
// Мы на шаге выбора метода доставки
if ( $logfile = fopen ( $logfilename, 'a+' ) ) {
fwrite ( $logfile, date ( "d-m-Y H:i:s") );
fwrite ( $logfile, "  -  Shipping. UserId = " );
fwrite ( $logfile, (int)$auth['user_id'] . " : " . getUserName ( (int)$auth['user_id'] ). "\n" );
for($i = 0; $i < $cart["idx"]; $i++) {
fwrite ( $logfile, "      " . $cart[$i]['quantity'] . " : " . getProductName ( $cart[$i]['product_id'] ). "\n" );
}
fwrite ( $logfile, "\n" );
fclose ( $logfile );
}
// Выбор метода доставки закончился
,
после кода:
Код
        if( in_array('CHECK_OUT_GET_PAYMENT_METHOD', $checkout_steps[$current_stage]) ) {   
        echo '<a name="CHECK_OUT_GET_PAYMENT_METHOD"></a>';

if(!empty( $paypal_api_payment_method_id ) && $paypalActive)
{
echo $theme->fetch('checkout/get_payment_method_paypal_ex.tpl.php');
}
else
{
echo $theme->fetch( 'checkout/get_payment_method.tpl.php');
}

$theme->set('basket_html', '');
вставляем:
Код
// Мы на шаге выбора метода оплаты
if ( $logfile = fopen ( $logfilename, 'a+' ) ) {
fwrite ( $logfile, date ( "d-m-Y H:i:s") );
fwrite ( $logfile, "  -  Paymed  . UserId = " );
fwrite ( $logfile, (int)$auth['user_id'] . " : " . getUserName ( (int)$auth['user_id'] ). "\n" );
for($i = 0; $i < $cart["idx"]; $i++) {
fwrite ( $logfile, "      " . $cart[$i]['quantity'] . " : " . getProductName ( $cart[$i]['product_id'] ). "\n" );
}
fwrite ( $logfile, "\n" );
fclose ( $logfile );
}
// Выбор метода оплаты закончился
после кода:
Код
        if( in_array('CHECK_OUT_GET_FINAL_CONFIRMATION', $checkout_steps[$current_stage]) ) {   
вставляем:
Код
// Мы на финальном шаге - подтверждение заказа
if ( $logfile = fopen ( $logfilename, 'a+' ) ) {
fwrite ( $logfile, date ( "d-m-Y H:i:s") );
fwrite ( $logfile, "  -  Final   . UserId = " );
fwrite ( $logfile, (int)$auth['user_id'] . " : " . getUserName ( (int)$auth['user_id'] ). "\n" );
for($i = 0; $i < $cart["idx"]; $i++) {
fwrite ( $logfile, "      " . $cart[$i]['quantity'] . " : " . getProductName ( $cart[$i]['product_id'] ). "\n" );
}
fwrite ( $logfile, "\n" );
fclose ( $logfile );
}
// Финальный шаг- подтверждение заказа
.

В приложении мой файл, для тех, кому лень ковыряться ;)

[вложение удалено Администратором]
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Отображение скидки на каждый товар в корзине.

Автор magic21

Ответов: 27
Просмотров: 4131
Последний ответ 03.10.2013, 10:30:19
от spsyper
возможность вывода в корзине свойств товара

Автор aleks_yug

Ответов: 102
Просмотров: 37988
Последний ответ 15.02.2013, 11:04:26
от kpk17
Последние добавленные товары в мини корзине

Автор Sonio

Ответов: 0
Просмотров: 1071
Последний ответ 06.12.2012, 16:42:02
от Sonio
[Решено] [Joomla 1.5.x] [VM 1.1.x] Изображение товара в корзине.

Автор urodoff

Ответов: 103
Просмотров: 25969
Последний ответ 14.11.2012, 00:28:14
от kreolka_8
Изменять количество товаров в мини-корзине VM 1.1.9

Автор bipw

Ответов: 1
Просмотров: 1800
Последний ответ 27.08.2012, 22:13:44
от TyT