Новости Joomla

SW JProjects v.2.6.0 - компонент каталога расширений для Joomla

👩‍💻 SW JProjects v.2.6.0 - компонент каталога расширений для Joomla.Компонент позволяет сделать свой мини-Joomla Extensions Directory - каталог расширений для CMS (не только для Joomla) или файлов. Есть возможность скачивания по лицензионным ключам.👩‍💻 v.2.6.0. Что нового?Этот релиз прежде всего связан с SEO и AI-оптимизацией. - Микроразметка Schema.org.Добавлен плагин микроразметки Schema.org для сущностей компонента. Для списков используется ListItem, для страницы проекта и версии - SoftwareApplication, для страницы документации - TechArticle. Плагин группы schemaorg в отличие от стандартных плагинов заполняет данные автоматически, но встраивает данные в граф сущностей микроразметки Joomla. Также исправляется одна ошибка генерируемой ядром микроразметки в зоне ответственности компонента.- Улучшение поиска по ключам. В панели администратора в списке ключей теперь можно искать по номеру заказа, email, домену, содержимому примечания к ключу.- Список ключей в админке. В списке ключей в панели администратора добавлен вывод домена и примечания- Поиск в списке проектов. Поиск в списке проектов в панели администратора стал более точным. Из полей для поиска убраны лишние поля.Компонент работает на Joomla 6 без включённого плагина обратной совместимости.Страница расширения и скачатьGitHub расширения.Joomla Extensions Directory#joomla #расширения

Человек на GitHub ускорил Joomla в 600 раз на объёме 150к+ материалов в 1700+ категориях

Человек на GitHub ускорил Joomla в 600 раз на объёме 150к+ материалов в 1700+ категориях

👩‍💻 Человек на GitHub ускорил Joomla в 600 раз на объёме 150к+ материалов в 1700+ категориях. На старте его сайт на Joomla 3 вообще не смог обновиться на Joomla 5. Пришлось делать экспорт/импорт материалов. Проделав всё это он запустил-таки этот объём данных на Joomla 5. Тестовый скрипт грузил 200 материалов из этого объёма всего за 94 секунды ))) А главная страница с категориями грузилась 20 секунд. Добавив индекс для таблицы #__content

CREATE INDEX idx_catid_state ON #__content (catid, state);
он сократил время загрузки категорий до 1 секунды. Затем наш герой решил поковырять SQL-запрос в ArticleModel, который отвечает за выборку материалов. И решил заменить тип JOIN на STRAIGHT_JOIN для категорий.
// ->from($db->quoteName('#__content', 'a'))->from(    $db->quoteName('#__content', 'a')    . ' STRAIGHT_JOIN ' . $db->quoteName('#__categories', 'c')    . ' ON ' . $db->quoteName('c.id') . ' = ' . $db->quoteName('a.catid'))// ->join('LEFT', $db->quoteName('#__categories', 'c'), $db->quoteName('c.id') . ' = ' . $db->quoteName('a.catid'))
Что сократило загрузку 200 материалов из 150к с 94 секунд до 5. К слову сказать, боевой сайт на Joomla 3 крутится на 12CPU 64GB рамы. А все манипуляции с кодом он делает на базовом 1CPU 1GB сервере и замеры скорости даны именно для базового сервера. Но это всё в дискуссии, хотя в идеале должно вылиться в Pull Requests. Мы - Open Source сообщество, где никто никому ничего не должен. Джунгли. Но человек ищет пути оптимизации Joomla и предлагает решения. Если оказать поддержку и предложить помощь хотя бы с тестированием самых разнообразных сценариев, то возможно эти улучшения смогут войти в ядро. Пусть не быстро, пусть через несколько лет, пусть не все, но войдут. Достаточно предложить руку помощи и приложить немного усилий.
Дискуссию на GitHub можно почитать здесь.@joomlafeed#joomla #community #php

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

goga_pgasovav

  • Захожу иногда
  • 445
  • 6 / 0
  • Внимательный джумловод
Друзья, хочется немного улучшить стандартный вывод в блоке сопутствующих товаров.
А именно: скрывать те, которых в наличии нет. А если все сопутствующии не в наличии, то вообще скрыть этот блок.
С перым я разобрался быстро:
Код
<?php if ($product->product_quantity > 0) { ?>
добавил это в цикле вывода.

Но вот со вторым всё гораздо сложнее. Надо сначала как-то в цикле перебрать все сопутствующие товары, узнать, есть ли хотя бы один из них в наличии, и только тогда продолжить обработку всего остального.

Может кто делал для себя нечто подобное? Спасибо!  :D
« Последнее редактирование: 20.03.2023, 19:29:01 от goga_pgasovav »
*

kit2m2

  • Живу я здесь
  • 3370
  • 276 / 0
  • Беру сайты на полное сопровождение
Но вот со вторым всё гораздо сложнее. Надо сначала как-то в цикле перебрать все сопутствующие товары, узнать, есть ли хотя бы один из них в наличии, и только тогда продолжить обработку всего остального.
Можно попробовать так:
Код
if ($product->product_quantity == 0)
{
    $hide_related_products = 1;
}

И потом уже:

Код
if ($hide_related_products == 1)
{
    unset($this->related_prod);
}

Или пересобрать по условию новый массив сопутствующих товаров и уже его выводить... Ну или не выводить

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

goga_pgasovav

  • Захожу иногда
  • 445
  • 6 / 0
  • Внимательный джумловод
kit2m2, спасибо за подсказки!
Всегда вам очень благодарен за помощь и всем ставлю плюсы в карму.
Если упустил — дико извиняюсь. Я готов и десять плюсов поставить за помощь.
*

goga_pgasovav

  • Захожу иногда
  • 445
  • 6 / 0
  • Внимательный джумловод
В общем в итоге доделал эту задачу.
Публикую готовое решение для тех, кому это так же может быть полезно:
Код
<?php if (count($this->related_prod)) { //проверяем есть ли у товара спуствующие товары вообще ?>
<?php $hide_related = 0; //устанавливаем флаг скрытия блока сопутствующих в ноль ?>
<?php foreach($this->related_prod as $k=>$product) { //в цикле для всех сопуствующих проверяем количество ?>
    <?php if ($product->product_quantity > 0) { ?>
        <?php $hide_related++; // увеличиваем флаг на 1 если продукт в наличии (кол-во > 0) ?>
    <?php } ?>
<?php } ?>
 <?php   if ($hide_related > 0) { // если флаг > 1, то выводим блок сопутствующих ?>
    <aside role=complementary>
        <div class="inner">
            <h2><?php echo JText::_('JSHOP_SIMILAR'); ?></h2>
            <div class="similar_items">
            <?php foreach($this->related_prod as $k=>$product) { ?>
                <?php if ($product->product_quantity > 0) { // если товар в наличии, то отображаем его в блоке сопутствующих ?>
                <?php include(dirname(__FILE__)."/../".$this->folder_list_products."/mini_product.php"); ?>
                <?php } ?>
            <?php } ?>
            </div>
        </div>
    </aside>
    <?php
    }
}?>

Ещё раз благодарю камрада kit2m2 за его подсказки и помощь в этом нелёгком деле  *DRINK*

P.S.: Само собой разумеется, что html разметка у вас будет совсем другая. Я лишь привёл пример, как это реализовано у меня.

P.S.2: Один нюанс: долго не мог понять, почему конструкция не работает.
Оказывается, $product->product_quantity у меня возвращало не «0», а «0.00». Поэтому условие if ($product->product_quantity == 0) не срабатывало.
В итоге переделал, и получилось то, что описано выше.
« Последнее редактирование: 20.03.2023, 19:20:05 от goga_pgasovav »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Стоимость доставки для нескольких товаров. Должна ли рассчитываться?

Автор goga_pgasovav

Ответов: 2
Просмотров: 897
Последний ответ 14.06.2025, 13:08:57
от victorantoniak
Не увеличивать Product image, если изображение меньше заданных параметров

Автор goga_pgasovav

Ответов: 6
Просмотров: 1364
Последний ответ 13.12.2024, 12:54:00
от goga_pgasovav
Не сохраняется порядок товаров в админке

Автор heartlink

Ответов: 7
Просмотров: 2019
Последний ответ 08.10.2024, 10:24:02
от kit2m2
[Решено] Не удаляются товары из корзины (Multi basket ajax)

Автор goga_pgasovav

Ответов: 0
Просмотров: 1311
Последний ответ 14.08.2024, 23:19:57
от goga_pgasovav
Сортировка товаров внутри категории

Автор oslyabya

Ответов: 1
Просмотров: 1426
Последний ответ 02.08.2024, 22:06:39
от nevigen