Разработка кастомного модуля Joomla

Наша компания занимается разработкой, поддержкой и обслуживанием сайтов любой сложности. От простых одностраничных сайтов до масштабных кластерных систем построенных на микро сервисах. Опыт разработчиков подтвержден сертификатами от вендоров.

Разработка и обслуживание любых видов сайтов:

Информационные сайты или веб-приложения
Сайты визитки, landing page, корпоративные сайты, онлайн каталоги, квиз, промо-сайты, блоги, новостные ресурсы, информационные порталы, форумы, агрегаторы
Сайты или веб-приложения электронной коммерции
Интернет-магазины, B2B-порталы, маркетплейсы, онлайн-обменники, кэшбэк-сайты, биржи, дропшиппинг-платформы, парсеры товаров
Веб-приложения для управления бизнес-процессами
CRM-системы, ERP-системы, корпоративные порталы, системы управления производством, парсеры информации
Сайты или веб-приложения электронных услуг
Доски объявлений, онлайн-школы, онлайн-кинотеатры, конструкторы сайтов, порталы предоставления электронных услуг, видеохостинги, тематические порталы

Это лишь некоторые из технических типов сайтов, с которыми мы работаем, и каждый из них может иметь свои специфические особенности и функциональность, а также быть адаптированным под конкретные потребности и цели клиента

Предлагаемые услуги
Показано 1 из 1 услугВсе 2065 услуг
Разработка кастомного модуля Joomla
Средняя
~2-3 рабочих дня
Часто задаваемые вопросы

Наши компетенции:

Этапы разработки

Последние работы

  • image_website-b2b-advance_0.png
    Разработка сайта компании B2B ADVANCE
    1262
  • image_web-applications_feedme_466_0.webp
    Разработка веб-приложения для компании FEEDME
    1171
  • image_websites_belfingroup_462_0.webp
    Разработка веб-сайта для компании БЕЛФИНГРУПП
    874
  • image_ecommerce_furnoro_435_0.webp
    Разработка интернет магазина для компании FURNORO
    1094
  • image_crm_enviok_479_0.webp
    Разработка веб-приложения для компании Enviok
    831
  • image_bitrix-bitrix-24-1c_fixper_448_0.png
    Разработка веб-сайта для компании ФИКСПЕР
    851

Разработка кастомного модуля Joomla

Модуль Joomla — небольшой блок контента, размещаемый в позициях шаблона. Отображает данные из БД, внешних API, вычисляет и выводит что угодно. Примеры: последние статьи, форма поиска, статистика посещений, курсы валют.

Структура модуля

mod_product_highlights/
├── mod_product_highlights.php   # Точка входа
├── mod_product_highlights.xml   # Манифест
├── src/
│   ├── Dispatcher/
│   │   └── Dispatcher.php
│   └── Helper/
│       └── ProductHighlightsHelper.php
├── tmpl/
│   └── default.php              # Шаблон
└── language/
    └── ru-RU/
        └── mod_product_highlights.ini

Манифест

<?xml version="1.0" encoding="utf-8"?>
<extension type="module" client="site" version="4.0">
    <name>mod_product_highlights</name>
    <author>Your Company</author>
    <version>1.0.0</version>
    <description>Выделенные товары каталога</description>
    <namespace path="src">MyCompany\Module\ProductHighlights</namespace>

    <files>
        <filename module="mod_product_highlights">mod_product_highlights.php</filename>
        <folder>src</folder>
        <folder>tmpl</folder>
    </files>

    <config>
        <fields name="params">
            <fieldset name="basic">
                <field name="count" type="number" label="Количество товаров"
                    default="4" min="1" max="12" />
                <field name="category_id" type="sql"
                    label="Категория"
                    query="SELECT id AS value, title AS text FROM #__catalog_categories WHERE published = 1"
                    default="" />
                <field name="show_price" type="radio" label="Показать цену" default="1">
                    <option value="1">Да</option>
                    <option value="0">Нет</option>
                </field>
            </fieldset>
        </fields>
    </config>
</extension>

Точка входа

// mod_product_highlights.php
\defined('_JEXEC') or die;

use Joomla\CMS\Helper\ModuleHelper;

// Joomla 4/5 стиль — через Dispatcher
$app = \Joomla\CMS\Factory::getApplication();
$module = $module ?? null;

echo ModuleHelper::renderModule($module, $params);

Helper

// src/Helper/ProductHighlightsHelper.php
namespace MyCompany\Module\ProductHighlights\Site\Helper;

use Joomla\CMS\Factory;

class ProductHighlightsHelper {
    public static function getProducts(object $params): array {
        $db    = Factory::getDbo();
        $count = (int) $params->get('count', 4);
        $catId = (int) $params->get('category_id', 0);

        $query = $db->getQuery(true)
            ->select(['id', 'title', 'price', 'image', 'alias'])
            ->from($db->quoteName('#__catalog_products'))
            ->where($db->quoteName('published') . ' = 1')
            ->where($db->quoteName('featured') . ' = 1');

        if ($catId) {
            $query->where($db->quoteName('category_id') . ' = ' . $catId);
        }

        $query->order('ordering ASC')->setLimit($count);

        $db->setQuery($query);
        return $db->loadObjectList() ?: [];
    }
}

Dispatcher

// src/Dispatcher/Dispatcher.php
namespace MyCompany\Module\ProductHighlights\Site\Dispatcher;

use Joomla\CMS\Dispatcher\AbstractModuleDispatcher;
use MyCompany\Module\ProductHighlights\Site\Helper\ProductHighlightsHelper;

class Dispatcher extends AbstractModuleDispatcher {
    protected function getLayoutData(): array {
        $data     = parent::getLayoutData();
        $products = ProductHighlightsHelper::getProducts($data['params']);
        $data['products']  = $products;
        $data['showPrice'] = (bool) $data['params']->get('show_price', true);
        return $data;
    }
}

Шаблон

// tmpl/default.php
defined('_JEXEC') or die;
use Joomla\CMS\Router\Route;
?>
<div class="mod-product-highlights">
    <?php foreach ($products as $product) : ?>
    <div class="product-card">
        <?php if ($product->image) : ?>
            <img src="<?php echo $product->image; ?>"
                 alt="<?php echo htmlspecialchars($product->title); ?>"
                 loading="lazy">
        <?php endif; ?>

        <h4 class="product-card__title">
            <a href="<?php echo Route::_('index.php?option=com_catalog&view=product&alias=' . $product->alias); ?>">
                <?php echo htmlspecialchars($product->title); ?>
            </a>
        </h4>

        <?php if ($showPrice && $product->price) : ?>
            <p class="product-card__price"><?php echo number_format($product->price, 0, '.', ' '); ?> ₽</p>
        <?php endif; ?>
    </div>
    <?php endforeach; ?>
</div>

Кэширование модуля

// В Helper — кэшировать результат
public static function getProducts(object $params): array {
    $cacheId = md5('product_highlights_' . json_encode($params));

    $cache = Factory::getCache('mod_product_highlights', 'callback');
    $cache->setCaching(true);
    $cache->setLifeTime(15); // минут

    return $cache->get([static::class, '_fetchProducts'], [$params], $cacheId) ?: [];
}

Сроки

Разработка кастомного модуля с настраиваемыми параметрами, запросом к БД, шаблоном и кэшированием — 1–3 дня.