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

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 21.08.25
  • Доработаны класс для управления навигацией и плагин универсального меню (спасибо Пермский период):
    • Добавлено новое условие IS_EXISTS_IN_BASKET_idтовара??истина::ложь:
      • С его помощью можно задать разное оформление для пункта меню в зависимости от того, добавлен ли в корзину указанный товар

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

Zion WebEngine 21.08.18
  • Доработан класс для управления заказами (спасибо Белый и пушистый):
    • При правке заказа теперь более корректно отображаются цены
    • Доработаны записи по умолчанию для реакций на заказы
  • Создан новый настраиваемый модуль реакции на заказ, который будет изменять скидочный уровень пользователя в зависимости от стоимости заказа в интернет-магазине (спасибо Смарт Мастер):
    • Разработка пока не завершена
    • Для его целей доработано меню администратора для пакета Zion User Control

Zion WebEngine Zion User Control Zion Catalog Что такое Меню администратора? Доступы/Пользователи Интернет-магазин Классы Корзина для заказов Меню администратора Настраиваемые модули Реакции на заказ Скидки/Наценки

Zion WebEngine 21.08.09
  • Доработаны обработчики для форм обратной связи и заказа обратного звонка (спасибо Цифрал Сервис):
    • Реализованы новые возможности SMS-шлюза

Zion Mail Back SMS Корзина для заказов Обработчики Обратная связь/Обратный звонок Формы

Zion WebEngine 21.08.03
  • Доработан класс для управления заказами (спасибо Пермский период):
    • Скорректирован алгоритм смены статуса заказа при оплате через какой-либо платёжный модуль:
      • Учтено, что оплаченными теперь могут стать не только новые, но и подтверждённые заказы
  • Доработан настраиваемый модуль для онлайн-оплаты через интернет-эквайринг от ПромСвязьБанка:
    • Устранены некоторые недочёты
    • Разработка завершена
  • Доработаны класс для управления SMS-шлюзом и настраиваемый модель для отправки SMS через SMSЦентр, а также система мониторинга для SMS:
    • Устранены некоторые недочёты из предыдущего обновления

Zion WebEngine Zion Catalog Zion xPayment Что такое система Мониторинга? SMS Классы Корзина для заказов Мониторинг Настраиваемые модули Обновления CMS Способы оплаты

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

Zion WebEngine Zion Catalog Zion xPayment SMS Классы Корзина для заказов Мониторинг Настраиваемые модули Обновления CMS Способы оплаты Что такое Классы?

Zion WebEngine 21.07.30
  • Доработан класс для управления заказами (спасибо Пермский период):
    • Дополнен список данных, которые могут быть переданы платёжному модулю
  • Создан настраиваемый модуль для онлайн-оплаты через интернет-эквайринг от ПромСвязьБанка:
    • Разработка ещё не завершена
  • Доработан класс для управления способами оплаты:
    • Дополнен список способов оплаты, которые создаются автоматически на новом сайте
  • Доработана система мониторинга для cURL:
    • Актуализирована информация о том, какие функции будут недоступны при отсутствии поддержки данной PHP-библиотеки

Zion WebEngine Zion Catalog Zion xPayment Что такое система Мониторинга? PHP Классы Корзина для заказов Мониторинг Настраиваемые модули Способы оплаты

Zion WebEngine 21.07.29
  • Доработан класс для управления обновлениями CMS:
    • Устранён недочёт с бесконечно повторяющимся успешным обновлением
  • Доработан плагин timemashine (спасибо Хронос Медиа):
    • Добавлен параметр lang:
      • В значении ru (по умолчанию) реализует русификацию для названий месяцев и дней недели (как раньше)
      • В значении en отключает русификацию для названий месяцев и дней недели:
        • Это может быть полезно в тех случаях, когда дата должна быть возвращена в одном из международных форматов
    • Доработан мастер по вставке этого плагина:
      • Учтены новые возможности
  • Доработан плагин для отображения контента:
    • Добавлен параметр htmlspecialchars:
      • При любом его непустом значении в результате все специальные символы будут преобразованы в HTML-сущности:
        • Это может быть полезно, например, для формирования XML-кода, в том числе RSS-ленты
  • Доработаны классы для управления базой данных и настраиваемый модуль для управления бронированием (спасибо Пермский период):
    • Изменены названия некоторых полей в таблице данных заказов
  • Доработаны классы для управления корзиной и заказами, настраиваемые модули для уведомлений о заказах по email и по SMS, а также настраиваемые модули для онлайн-оплаты через Qiwi.Кассу, Робокассу, Альфа Банк и Сбербанк:
    • Реализована поддержка возможности оплаты заказа только после его подтверждения администратором

Zion WebEngine Zion Catalog Zion xDelivery Zion xPayment Что такое CMS Zion WebEngine? Email-сообщения HTML-код веб-страницы Qiwi Касса Robokassa SMS XML/RSS/1С/YML База данных/Таблицы данных Бронирование/Расписание Дата/Время/TimeMashine Классы Кодировки/Наборы символов Контент/Контентные единицы Корзина для заказов Многоязычность/Языки Настраиваемые модули Обновления CMS Плагины Помощники/Мастеры/Инструкции/Подсказки Реакции на заказ Способы оплаты

Zion WebEngine 21.07.28
  • Доработаны классы для управления заказами и базой данных (спасибо Пермский период):
    • Завершено внедрение функционала для добавления новых и удаления уже имеющихся в заказе товаров через административный интерфейс
    • Там же реализовано изменение/сохранение дат заезда/выезда, если в качестве способа получения заказа выбрано Бронирование

Zion WebEngine Zion Catalog Что такое Административный интерфейс и Гостевой интерфейс? База данных/Таблицы данных Бронирование/Расписание Дата/Время/TimeMashine Интернет-магазин Классы Корзина для заказов Способы доставки/самовывоза

Zion WebEngine 21.07.27
  • Доработан класс для управления заказами (спасибо Пермский период):
    • Реализована возможность редактировать некоторые данные в заказе:
      • Менять/выбирать зарегистрированного пользователя:
        • Для этого также доработан класс для управления пользователями
      • Редактировать контактные лицо, телефон и email:
        • Для этого также доработан элемент Однострочное поле
      • Менять названия, цены и количества для уже имеющихся в заказе товаров:
        • Нулевые количества и пустые названия не сохраняются
      • Начато внедрение функционала для добавления новых и удаления уже имеющихся в заказе товаров 

Zion WebEngine Zion Catalog Доступы/Пользователи Интернет-магазин Классы Корзина для заказов Элементы Что такое Элементы?

Zion WebEngine 21.07.22
  • Доработаны настраиваемый модуль доставки через транспортные компании и класс корзины заказов (спасибо Moto-Retail18):
    • Теперь для доставки транспортной компанией доступно указание адреса получателя
    • Устранены некоторые недочёты в форме заказа в интернет-магазине
  • Создан новый настраиваемый модуль способа доставки (спасибо Пермский период):
    • С его помощью можно бронировать товар или услугу на промежуток дат
    • При выборе такого способа доставки заказ создаётся со статусом не Новый, а Ожидает подтверждения:
      • Онлайн-оплата для клиента при этом становится невозможна, пока администратор не проверит параметры бронирования
      • В связи с этим также доработаны класс для управления заказами, меню администратора для пакета Zion Catalog, система мониторинга для заказов, настраиваемые модули реакций на заказы, необходимые для уведомлений о заказах по e-mail и SMS

Zion WebEngine Zion Catalog Zion xDelivery Email-сообщения SMS Бронирование/Расписание Дата/Время/TimeMashine Интернет-магазин Классы Корзина для заказов Меню администратора Мониторинг Настраиваемые модули Реакции на заказ Способы доставки/самовывоза Способы оплаты Формы Что такое Классы?

Zion WebEngine 21.07.15
  • Доработан плагин универсального меню (спасибо Good Авто):
    • Параметр hidden (скрывать ли пункты с пустым, нулевым или незаполненным значением) со значением hide (скрывать) стал доступен в сочетании с types:elements;select:list (список элементов, перечисленных через запятую):
      • При этом, как и раньше в параметре include должны быть перечислены через запятую ID элементов, которые нужно отоборазить (скрыв незаполненные)
      • Важно! Если, например, в include указаны stringfield_5,number_3, то на заполненность будут проверяться поля stringfield_5_value и number_3_value - то есть поля, имена которых заканчиваются на _value
  • Доработаны класс для работы с корзиной заказов и настраиваемые модули для управления самовывозом и доставкой через транспортные компании (спасибо Moto-Retail18):
    • Устранена проблема, при которой в данные о заказе могла попадать информация, неприменимая для выбранного способа доставки/самовывоза

Zion WebEngine Zion Catalog Zion xDelivery Классы Корзина для заказов Меню/Списки/Навигация Настраиваемые модули Плагины Способы доставки/самовывоза Элементы Плагин Menu

Zion WebEngine 21.07.08
  • Доработаны классы для управления корзиной заказов и способами доставки (спасибо ЛеоСталь):
    • Параметр Скрывать поля для указания адреса в настройках способа доставки теперь принимается во внимание только, если НЕ выбран настраиваемый модуль для данного способа доставки
    • Если модуль выбран, то этот параметр игнорируется, так как управление им происходит уже из модуля, который может, как заменять, так и дополнять форму с полями для указания адреса
  • Доработан настраиваемый модуль для оплаты через банк:
    • Устранены недочёты при обращении к базе данных

Zion Catalog База данных/Таблицы данных Классы Корзина для заказов Настраиваемые модули Способы доставки/самовывоза Способы оплаты Что такое Классы?

Zion WebEngine 21.07.01
  • Доработан класс для управления местом в структуре (спасибо Good Авто):
    • Устранена вероятность возникновения зацикливания при выборе страницы по умолчанию в опциях проекта
    • Такая вероятность могла возникнуть, например, при наличии в структуре записей без ID, появившихся, например, при некорректном импорте данных:
      • Теперь такие записи исключаются при построении структуры
  • Доработан класс для интеграции с SMS-шлюзом:
    • Обновлена инструкция по тому, что делать, если SMS-сообщения не приходят из-за подозрения в рассылке спама

Zion WebEngine SMS Импорт/Экспорт Классы Место в структуре Помощники/Мастеры/Инструкции/Подсказки Спам Элемент "Место в структуре"

Zion WebEngine 21.06.30
  • Доработан настраиваемый модуль для предоставления накладных при заказе (спасибо Moto-Retail18):
    • Устранены некоторые недочёты:
      • Имя покупателя отображалось только для зарегистрированных пользователей
      • В редких случаях при переходе по ссылке на распечатку накладной из письма могло появиться сообщение "В доступе отказано"
    • В настройках модуля добавлена опция Сделать доступным выбор сразу нескольких вариантов:
      • При её включении, покупатель сможет выбирать сразу несколько доступных вариантов предоставления накладной
      • Без её отключении, покупатель сможет выбрать только один из доступных вариантов предоставления накладной

Zion Catalog Email-сообщения Доступы/Пользователи Корзина для заказов Настраиваемые модули Реакции на заказ

Zion WebEngine 21.06.29
  • Доработан класс для управления импортом из CRM Intrum (спасибо Good Авто):
    • Из-за того, что CRM отправляла данные об изображениях ещё до сохранения в ней записи, на сайте могла создаваться огромная галерея из по сути ненужных фотографий:
      • Теперь для устранения данной ситуации перед добавлением новых слайдов происходит полная очистка соответствующей галереи

Zion Import Галереи/Слайды Изображение Импорт/Экспорт Классы Что такое Классы?

Zion WebEngine 21.06.28
  • Завершена разработка настраиваемого модуля для предоставления накладных при заказе (спасибо Moto-Retail18):
    • Реализованы отображение и распечатка накладной в интерфейсе администратора (администратору) и (клиенту) сразу же после заказа
    • Реализована отправка на email ссылки на накладную (клиенту) сразу же после заказа
  • Доработан плагин универсального меню:
    • Список товаров в том или ином заказе теперь доступен не только клиенту, сделавшему заказ, но и администратору, а также тому пользователю, который перейдёт по специальной ссылке
  • Доработан класс для управления числами:
    • Доступен новый плагин number_ToString, с помощью, которого можно отобразить, например, сумму прописью, например, в накладной
  • Доработан класс для управления базой данных:
    • Устранены вероятность возникновения ошибок при смене статуса заказов в случае отсутствия в комплекте поставки пакета Zion User Control

Zion WebEngine Zion Catalog Что такое Комплект поставки? Email-сообщения Административный интерфейс База данных/Таблицы данных Доступы/Пользователи Интернет-магазин Классы Корзина для заказов Меню/Списки/Навигация Настраиваемые модули Плагины Реакции на заказ Число

Zion WebEngine 21.06.24
  • Доработан класс для управления импортом из CRM Intrum (спасибо Good Авто):
    • Устранены некоторые недочёты, из-за которых могли создаваться надкатегории без идентификаторов

Zion Import Импорт/Экспорт Категории Классы Что такое Классы?

Zion WebEngine 21.06.23
  • Доработан элемент Выбор одного из вариантов (спасибо Good Авто):
    • Теперь данные и из этого элемента могут быть использованы для быстрого просмотра в списке контентных единиц в административном интерфейсе

Zion Catalog Административный интерфейс Выбор одного из вариантов Контент/Контентные единицы Элементы Что такое Элементы?

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

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

Zion WebEngine 21.06.18
  • Доработаны класс для управления типами и элемент Место в структуре (спасибо Цифрал Сервис):
    • Теперь для быстрого просмотра в списке контентных единиц в административном интерфейсе могут быть доступны не только обычные, но и уникальные элементы:
      • В том числе эта возможность реализована для элемента Место в структуре

Zion WebEngine Административный интерфейс Классы Контент/Контентные единицы Место в структуре Типы Элементы Элемент "Место в структуре"