Онлайн-руководство разработчика NetCat
Модуль «Поиск по сайту» 13.2.1Начало работы с модулем 13.2.2Язык запросов 13.2.3Способы хранения индекса 13.2.4Интерфейс модуля в панели управления сайтом 13.2.5Области индексирования 13.2.6Области HTML-страниц 13.2.7Области поиска на сайте 13.2.8Индексирование по расписанию, запуск индексирования в фоновом режиме 13.2.9Правила индексирования 13.2.10Постановка задачи переиндексирования в очередь 13.2.11Интеграция модуля в макеты дизайна сайта 13.2.12Простая форма поиска 13.2.13Расширенная форма поиска 13.2.14Вывод результатов поиска 13.2.15Стилизация списка подсказок 13.2.16Расширенные настройки 13.2.17Разработка расширений модуля 13.2.18Обзор архитектуры модуля 13.2.19Обработчики документов различных типов 13.2.20Текстовые фильтры 13.2.21Анализаторы текста 13.2.22Корректировщики запросов 13.2.23Подключение других поисковых систем 13.2.24Решение проблем с поиском 13.2.25Решение проблем с индексированием 13.2.26Справочник API

Элементы управления

Чтобы внутри административной зоны можно было использовать стилизованные под системные, свои собственные элементы управления, например, кнопку «подтвердить», в начале файла admin.php, наряду с другими включениями, следует также прописать следующие строки, обозначенные жирным шрифтом:

$NETCAT_FOLDER = join(strstr(__FILE__, "/") ? "/" : "\\", array_slice(preg_split("/[\/\\\]+/", __FILE__), 0, -4)).( strstr(__FILE__, "/") ? "/" : "\\" );
include_once ($NETCAT_FOLDER."vars.inc.php");
require ($MODULE_FOLDER."example/admin.inc.php");
require ($ADMIN_FOLDER."function.inc.php");

require ($ADMIN_FOLDER."modules/ui.php");
$UI_CONFIG = new ui_config_module('example');

if (is_file($MODULE_FOLDER."example/".MAIN_LANG.".lang.php")) {
    require_once ($MODULE_FOLDER."example/".MAIN_LANG.".lang.php");
} else {
    require_once ($MODULE_FOLDER."example/en.lang.php");
}

$perm->ExitIfNotAccess(NC_PERM_MODULE, 0, 0, 0, 1);
$MODULE_VARS = $nc_core->modules->get_module_vars();

Обратите внимание, что в названии класса присутствует ключевое слово модуля «example», его нужно заменить на своё.

Если нужно выделить управляющую кнопку, в код формы стоит вместо стандартной кнопки подтверждения, следует прописать управляющую команду:

$UI_CONFIG->actionButtons[] = array(
    "id"      => "submit",
    "caption" => "подтвердить",
    "action"  => "mainView.submitIframeForm('mainForm')"
);

При необходимости, в этом же массиве можно указать параметр выравнивания элемента:

$UI_CONFIG->actionButtons[] = array(
    "id"      => "submit",
    "caption" => "подтвердить",
    "action"  => "mainView.submitIframeForm('mainForm')",
    "align"   => "left"
);

Соответственно, у формы нужно прописать идентификатор:

<form method='post' id='mainForm' action='admin.php'>
...
$UI_CONFIG->actionButtons[] = array(
    "id"      => "submit",
    "caption" => "подтвердить", 
    "action"  => "mainView.submitIframeForm('mainForm')"
);  
...
</form>

В таком случае, кнопка «подтвердить» будет расположена на нижней панельке системы управления.

Следует заметить, значение переменной $UI_CONFIG должно быть объявлено глобально:

global $UI_CONFIG;

Для организации закладок, в интерфейсе управления модулем, следует модифицировать файлы ui_config.php и url_routes.js

Допустим нужно расширить стандартный модуль «Календарь», установив в его интерфейсе управления несколько вкладок для разных задач. Первая вкладка будет выводить администратора на стандартные настройки календаря, а вторая будет писать приветствие. Для организации такой возможности следует изменить содержимое файлов ui_config.php и url_routes.js, пример приведён ниже.

Содержимое файла ui_config.php, задаёт нужные вкладки:

<?php
class ui_config_module_calendar extends ui_config_module {
    // $toolbar_action = 'main' - определяет действие по-умолчанию
    function ui_config_module_calendar($active_tab = 'admin', $toolbar_action = 'main') {
        global $db, $MODULE_FOLDER;
                   $this->ui_config_module('calendar', $active_tab);
            
        if ($active_tab == 'admin') {
            $this->toolbar[] = array('id' => "main",
                'caption'  => 'Main',
                'location' => "module.calendar.main",
                'group'    => "grp1");
                
            $this->toolbar[] = array('id' => "test",
                'caption'  => 'Test',
                'location' => "module.calendar.test",
                'group'    => "grp1");
                
            $this->locationHash = "module.calendar.$toolbar_action";
                
            $this->activeToolbarButtons[] = $toolbar_action;
            }
    }
}
?>

Содержимое файла url_routes.js, задаёт переходы по вкладкам:

urlDispatcher.addRoutes( {
    'module.calendar.main': NETCAT_PATH + 'modules/calendar/admin.php',
    'module.calendar.test': NETCAT_PATH + 'modules/calendar/test.php',
    1: '' // dummy entry
} );

Теперь в каталоге модуля нужно создать файл test.php, который содержит незамысловатый код:

<?php
    echo "Hello world!!!";
?>

Теперь интерфейс управления модулем «Календарь», располагает двумя вкладками. При нажатии на вторую вкладку появится сообщение «Hello world!!!»

Комментарии 7

Существуют ли стили кнопок actionButtons (Например border красного цвета), если да то как его прописывать?
   
Вячеслав  Студия "Кронос" 12 апреля 2016, 13:25:31
Не работает подключение закладок по данному примеру
   
Вячеслав  Студия "Кронос" 12 апреля 2016, 14:29:52
В файле admin.php нужно подключить класс из ui_config.php
$UI_CONFIG = new ui_config_module_calendar('admin', 'main');
Ни слова в документации
   
GurovPR  Гуров и партнеры 23 июня 2016, 16:59:16
К сожалению, документация по написанию модулей очень слабая, до всего нужно доходить самому, глядя на готовые модули. В начале написано "следует также прописать следующие строки, обозначенные жирным шрифтом" - и никаких жирных строк дальше нет. В идеале нужно сделать урок или записать видео по созданию какого-нибудь модуля с нуля. То видео, которое тут есть тоже ниочем, показаны основы, очень многое опущено.
   
Дмитрий Коновалов  Activica 17 марта 2017, 01:24:53
+1 Очень вялая документация
   
Лев 05 июля 2019, 09:45:10
+1 2019 год, а она все еще вялая
   
ru__slan  Руслан Асадулин 11 августа 2022, 20:55:08
2022, ничего не меняется
   
Описание проекта