Что такое Плагины?

06.11.2023

Все плагины в CMS Zion WebEngine служат для выполнения каких-либо целей. Это может быть вывод какого-то текста, корректировка базы данных, изменение глобальных переменных и т.д.

Где хранятся плагины

Плагины могут быть самостоятельными программными модулями или могут быть частью классов

  • Каждый самостоятельный плагин хранится в одном из файлов в папке plugins, либо plugins/custom. Если Вы хотите изменить один из таких плагинов или создать новый, то сохраняйте его в папке plugins/custom - так он не будет заменён стандартным плагинов в случае обновления CMS. При совпадении имён в plugins и в plugins/custom наибольший приоритет имеют плагины из папки plugins/custom.
  • Если плагин является частью класса, то найти его можно в файле соответствующего класса. Это будет отдельный метод, имя которого всегда начинается с Plugin и в качестве параметров к которому должен передаваться массив params

Набор доступных плагинов зависит от комплекта поставки

Имена плагинов

  • Если плагин хранится в отдельном файле с имением мойплагин.php то имя плагина будет мойплагин (.php обязательно должно присутствовать в имени файла)
  • Если плагин является частью класса, например, мойкласс, и хранится в методе PluginМойПлагин, то имя плагина будет мойкласс_МойПлагин

К плагинам можно обращаться через команду вызова, через URL-адрес или через AJAX

  1. В самом простом случае команда вызова плагина выглядит так: {plugin:мойплагин} или {plugin:мойкласс_МойПлагин}
  2. При обращении через URL-адрес всё аналогично: /?plugin=мойплагин или /?plugin=мойкласс_МойПлагин (в URL также могут быть указаны другие GET-параматры, как слева, так и справа от того, что указано в примере)
  3. При обращении через AJAX нужно соблюсти следующие условия:
    • В HTML-коде веб-страницы должна присутствовать команда вызова специального плагина AJAX - {plugin:ajax} (если указать её несколько раз, дублирование вызова нужных модулей не произойдёт)
    • Вызов плагина через AJAX должен происходить через вызов ассинхронной JS-функции sendRequest(URL,objectID,getRequest,oldHTML,okProc), где
      • URL - URL-адрес плагина (пример смотрите выше)
      • objectID - ID HTML-тега, в который будет возвращён результат выполнения плагина
      • getRequest - оставляйте этот параметр без изменений
      • oldHTML - этот параметр не обязательный - можно оставить его пустым, но если заполнить его текстом или HTML-кодом, то он будет отображаться в результирующем теге objectID до того, как плагин вернёт результат
      • okProc - этот параметр не обязательный - можно оставить его пустым, но если указать в нём какую-либо JS-функцию, то она будет выполнена после того, как плагин вернёт результат (эта функция не должна принимать параметры)

Результаты выполнения плагинов

Плагины могут возвращать результирующий текст или HTML-код.

  • В самостоятельных плагинах результат присваивается PHP-переменной $echo
  • В плагинах из классов результат возвращается через оператор return(...);

От способа вызова плагина зависит то, где и как будет выводиться его результат:

  1. Если используется команда вызова плагина, то результат отобразится именно там, где была команда (результат заменит собой команду)
  2. Если используется обращение по URL-адресу, то результат выведется в браузере (при этом на веб-странице не будет ничего кроме результата выполнения плагина)
  3. Если используется вызов через AJAX, то результат будет выведен в тег, свойство id которого совпадает с тем, что указано в objectID

Параметры плагинов

Плагинам можно передавать параметры. В результате многие плагины могут выполняться в сотнях и в тысячах различных режимов

  1. Если используется команда вызова плагина, то она может выглядеть, например, так: {plugin:имя_плагина;color:red;type:apple;action:kick}, при этом
    • после имени плагина должна быть точка с запятой;
    • пары имя-значение (имя и значение параметра) отделяются друг от друга точкой с запятой;
    • имя параметра от значения того же параметра отделяется двоеточием:
    • в именах и в значениях параметров не допускается использовать двоеточия: и точки с запятой;
  2. Если используется обращение по URL-адресу, то для того же плагина с теми же параметрами URL будет такой: /?plugin=имя_плагина&params=color:red;type:apple;action:kick}, при этом
    • после имени плагина нужно написать &params=
    • пары имя-значение (имя и значение параметра) также отделяются друг от друга точкой с запятой;
    • имя параметра от значения того же параметра также отделяется двоеточием:
    • в именах и в значениях параметров не допускается использовать двоеточия: и точки с запятой;, а также амперсанд& и равно=
  3. Если используется вызов через AJAX, то к URL применяются те же требования, что и в предыдущем примере

В плагине эти параметры можно использовать, как элементы ассоциативного массива $params. Например, параметры из примеров выше будут доступны, как переменные $params['color']$params['type'] и $params['action'].

Плагины могут воспринимать только те параметры, которые в них запрограммированы. Список доступных параметров смотрите в документации к каждому конкретном плагину


CMS Zion WebEngine является бесплатной системой. Развивается за счёт рекламы, помощи веб-студии #webZion и других спонсоров.

 

Будем рады, если Вы поддержите нас любой суммой, а также поделитесь идеями на счёт каких-либо улучшений и доработок для CMS...

 

Заранее, большое, спасибо

 

Блог обновлений

Zion WebEngine X7.12.09
  • Доработана возможность изменения заголовков, передаваемых веб-сервером (спасибо MKV Pro):
    • В том числе теперь значительно проще сменить тип контента с обычного "text/html" на "application/xml" или на любой другой
      • Так значительно проще создавать не только HTML-, но и XML-сайты и различные XML-выдачи, например RSS, YML и т.д.
    • Также доступно более простое указание альтернативной кодировки символов, например, универсальной utf-8, вместо стандартной для CMS windows-1251
      • При этом не только корректируется заголовок от сервера, но и происходит автоматическая конвертация всего контента в указанную кодировку
    • Новый функционал в внедрён в плагин универсального меню, но оказывает влияние на весь комплекс CMS
      • В помощнике по вставке плагина универсального меню добавлены необходимые подсказки
    • Из комплекта поставки удалён плагин RSS, так как его функционал теперь полностью доступен в других компонентах новой платформы
  • Отключена автоматическая подстановка некоторых HTML-тегов
    • Так управление HTML-кодом веб-страницы будет более гибкое
  • Внедрена поддержка многоуровневого ЧПУ
    • Количество подразделов в человеко-понятном URL не ограничено
    • CMS автоматически определяет, который раздел необходимо открыть, по последнему подразделу в списке, независимо от того, указан ли корректный список надразделов
    • Управление данной возможностью, а также задание канонического URL будет реализовано в ближайших обновлениях

Zion WebEngine HTML-код веб-страницы XML/RSS/1С/YML Адрес (URL)/ЧПУ/Переадресация Веб-сервер/Хостинг Кодировки/Наборы символов Меню/Списки/Навигация Обновления CMS Плагины Платформа Помощники/Мастеры/Инструкции/Подсказки

Zion WebEngine X7.12.08
  • Доработан класс для работы с HTML-кодом веб-страницы
    • Теперь в HTML-коде веб-страниц, как и в случае с меню/списками доступно указание условий, в зависимости от выполнения или невыполнения которых HTML-код может быть разным. Доступны следующие условия:
      • Если у данного раздела есть подразделы
      • Если у данного раздела соответствующий индентификатор (ID)
      • Если у данного раздела указанное поле не заполнено или равно 0 (спасибо Moto-Retail18)
      • Если у данного раздела соответсвующий тип
      • Если данный раздел связан с записью с указанным идентификатором

Zion WebEngine HTML-код веб-страницы Меню/Списки/Навигация Связи Типы Условия

Zion WebEngine X7.11.27
  • Доработано меню администратора для данного пакета:
    • Создан раздел Инструменты, в который перемещены некоторые подразделы раздела Опции
  • Класс Catalog переименован в Import, так как это больше соответствует его сути
  • Доработан класс для работы с Корзиной заказов
    • Устранена вероятность возникновения ошибок на некоторых веб-серверах
  • Доработано создание записей по умолчанию
    • Реализовано автоматическое создание связей между товарами и аксессуарами (для примера)
    • Расширен список автоматически создаваемых меню и списков
      • В том числе товаров, аксессуаров и связей между ними
        • Также реализованы сразу несколько способов добавления товаров/аксессуаров в корзину (для примера)
          • Ещё несколько вариантов будут добавлены в ближайших обновлениях
      • Некоторые ранее создаваемые меню теперь организованы более продуманно
    • Доработан HTML-код некоторых шаблонов по умолчанию
    • Созданы новые шаблоны по умолчанию
      • В том числе для товаров и аксессуаров (по умолчанию)
    • Реализовано создание нескольких товаров и аксессуаров по умолчанию, а также связей между ними (для примера)

Zion WebEngine Zion Catalog HTML-код веб-страницы Веб-сервер/Хостинг Импорт/Экспорт Классы Корзина для заказов Меню/Списки/Навигация Меню администратора Обновления CMS Сайт-каталог Связи Шаблоны контента

Zion WebEngine X7.11.24
  • Доработан класс для работы с Корзиной заказов в интернет-магазине (спасибо Moto-Retail18):
    • Реализована возможность опционально использовать альтернативную реакцию на добавление товара в Корзину
      • Посетитель может быть отправлен не только на ту страницу, на которой он был до этого, но и на то же самое место на этой странице.
      • Также доступно отображение уведомления в браузерном окне Alert (JavaScript)
    • Классическая реакция доступна и используется по умолчанию
      • Она более гибкая и позволяет настроить перенаправление посетителя в любое явно определённое место на сайте
      • При это выводится обычное уведомление - не в отдельном окне, а на настраиваемом месте на странице

Zion Catalog Интернет-магазин Классы Корзина для заказов Уведомления

Zion WebEngine X7.11.23
  • Доработаны класс для управения навигацией и плагин универсального меню (спасибо Moto-Retail18):
    • Доступно для использования новое условие
      • Теперь можно особым образом оформлять тот или иной пункт в меню или в списке в зависимости от того, заполнено ли у него указанное поле

Zion WebEngine Классы Меню/Списки/Навигация Плагины Условия

Zion WebEngine X7.11.18
  • Доработаны класс дя управления навигацией и плагин универсального меню (спасибо Феникс):
    • Теперь в меню можно использовать ещё больше переданных в меню параметров, для того, чтобы более гибко управлять вызовом вложенных в меню

Zion WebEngine Классы Меню/Списки/Навигация Плагины

Zion WebEngine X7.11.13
  • Доработан класс для работы с каталогом (спасибо Феникс):
    • Устранена проблема с пагинацией в Интерфейсе администратора, которая могла возникнуть при отсутствии необходимых настроек

Zion WebEngine Классы Пагинация/Подстраницы Сайт-каталог

Zion WebEngine X7.11.11
  • Расширен функционал класса для работы с текущими данными (спасибо Moto-Retail18):
    • В частности стала доступна возможность, позволяющая после добавления товара в корзину вернуться не только на ту же страницу, но и на ту же подстраницу
      • Все необходимые параметры подставляются автоматически и только в тех случаях, когда это необходимо (это положительно влияет в том числе на SEO)

Zion WebEngine Классы Корзина для заказов Пагинация/Подстраницы Текущие данные

Zion WebEngine X7.11.05
  • Создан класс Catalog (спасибо Moto-Retail18)
    • Реализована возможность быстрого настраиваемого импорта данных (например, крупного каталога товаров)
      • Потенциально импортировать можно не только товары, но, и страницы, новости, статьи... Любой контент

Zion Catalog Импорт/Экспорт Классы Сайт-каталог

Zion WebEngine X7.11.03
  • Доработан класс для управления базой данных (спасибо Moto-Retail18)
    • Реализована фильтрация записей в административном интерфейсе:
      • Например, можно отобразить все подразделы указанного надраздела:
        • При этом во время настройки фильтра можно фильтровать сами надразделы по типам, что сокращает скорость настройки и снижает нагрузку на веб-сервер
      • В случае применения фильтра отображается соответствующее уведомление
      • Можно настраивать уже имеющуюся фильтрацию или создавать новую, удалив старую

Zion WebEngine Административный интерфейс База данных/Таблицы данных Веб-сервер/Хостинг Классы Типы Уведомления Фильтрация

Zion WebEngine X7.11.02
  • Доработан класс для управления базой данных (спасибо Moto-Retail18)
    • Реализована пагинация в административном интерфейсе
      • Настройки пагинации не будут появляться, если в списках мало записей
      • Список подстраниц не будет появляться, если для листания доступна всего одна подстраница
  • Оптимизирован дистрибутив пакета SEO Booster:
    • Удалено всё, чтобы было необходимо для поиска текста в старой платформе (в новой платформе это уже в базовой поставке)
    • Размер дистрибутива уменьшился в 2,5 раза
    • Теперь этот пакет служит только для создания условий качественной SEO-оптимизации

Zion WebEngine Zion SEO Booster Административный интерфейс База данных/Таблицы данных Классы Меню/Списки/Навигация Пагинация/Подстраницы Платформа Поиск текста

Zion WebEngine X7.11.01
  • Для нужд поиска текста доработана пагинация списков и меню

Zion WebEngine Меню/Списки/Навигация Пагинация/Подстраницы Поиск текста

Zion WebEngine X7.10.31
  • Оптимизирован дистрибутив пакета Catalog:
    • Удалено всё, чтобы было необходимо для работы сайта-каталога и интернет-магазина в старой платформе
    • Размер дистрибутива уменьшился в 3,5 раза
  • В новой платформе реализован полноценный, быстрый, многофункциональный поиск текста (спасибо Moto-Retail18):
    • К результатам поиска применим весь "ассортимент" "фишек", доступных для других меню и списков

Zion WebEngine Zion Catalog Интернет-магазин Меню/Списки/Навигация Платформа Поиск текста Сайт-каталог

Zion WebEngine X7.10.28
  • Доработано формирование заказов из корзины (спасибо Moto-Retail18):
    • Теперь интернет-магазин работает целиком на новой платформе
    • Стало доступно оформление уведомлений о заказе через административный интерфейс

Zion Catalog Административный интерфейс Интернет-магазин Корзина для заказов Платформа Реакции на заказ

Zion WebEngine X7.10.27
  • Завершена работа над классом для управления корзиной (спасибо Moto-Retail18)
    • Реализован весь функционал, необходимый для работы с корзиной в новой платформе
  • Создан класс для предоставления доступа к текущим данным: позволяет более гибко настраивать каталог товаров и корзину
  • Расширен функционал плагина универсального меню:
    • Теперь с помощью него можно настраивать отображение товаров из корзины:
      • Дополнительные плагины для этого более не требуются
      • Для товаров из корзины применим весь огромный набор функционала, доступный для других меню и списков
  • Доработан помощник по вставке плагина универсального меню:
    • Дополнено описание новых доступных параметров

Zion WebEngine Zion Catalog Классы Корзина для заказов Меню/Списки/Навигация Плагины Платформа Помощники/Мастеры/Инструкции/Подсказки Текущие данные

Zion WebEngine X7.10.26
  • Доработан плагин универсального меню (спасибо Moto-Retail18):
    • Добавлена возможность отображать в одном меню или списке не только непосредственные подразделы, но и все другие разделы, находящиеся глубже в структуре
  • Доработан помощник по вставке плагина универсального меню:
    • Добавлена информация о новых доступных параметрах
    • Уточнена информация об использовании других параметров
  • Доработан элемент "Число":
    • Реализованы некоторые дополнительные возможности, в том числе позволяющие использовать данный элемент в качестве цены для товара: таких элементов может быть несколько, но выбрать в качестве цены можно только один из них
  • Доработан класс для работы с контентом:
    • Расширен набор доступных функций: так внедрение нового функционала станет более быстрым
    • Улучшено кэширование: так производительность системы значительно повысится
  • Создан класс, позволяющей управлять корзиной заказов в новой платформе:
    • Работа ещё не завершена, но уже очень скоро мы сможем представить Вам новые компоненты для нового интернет-магазина

Zion WebEngine Zion Catalog Интернет-магазин Классы Контент/Контентные единицы Корзина для заказов Кэш/Кеш Меню/Списки/Навигация Плагины Платформа Помощники/Мастеры/Инструкции/Подсказки Число Элементы

Zion WebEngine X7.10.12
  • Устранена вероятность многократного дублирования одних и тех же уведомлений (спасибо Учебный Центра "Алекс")

Zion WebEngine Уведомления

Zion WebEngine X7.10.10
  • Доработана система мониторинга
    • Реализована проверка на наличие параметров для защиты от спама (спасибо Про-Отделка)

Zion WebEngine Мониторинг Спам

Zion WebEngine X7.10.09
  • Доработана система мониторинга
    • Реализована проверка на наличие параметров для корректной работы SMTP

Zion WebEngine SMTP/PHP-mail Мониторинг

Zion WebEngine X7.10.02
  • Доработан поиск текста для новой платформы (спасибо Теплодом)

Zion SEO Booster Платформа Поиск текста