Подскажите, как запретить добавлять определенные значения в поля. Есть встроенная в icms2 валидация но нужны свои условия. Как прописать правила для запрета на добавление значения при вводе недопустимого значения?
Спасибо.
public function getRules() { if ($this->parse($value) == недопустимое значение) { return $this->rules; }else { return false; }
печально… по двум причинам — название поля в БД может быть произвольным и поле может использоваться несколько раз на странице (как отлавливать учитывая этот момент); не очень (даже очень не очень) разбираюсь в хуках...
Если возможно пару примеров перехвата с пояснениями (на нескольких примерах, думаю будет разобраться проще).
Спасибо.
Ответить что-то более точно по Вашему коду невозможно, так как неизвестно откуда этот код, как вызывается и т.п.
В типах контента в типе поля… примеры по работе с контентом (а точнее примеры хуков для полей контена) к сожалению (доступно понятных) не нашел.
P.s. некоторые только учаться, а не уже знают…
Перехват событий для контента, если я правильно понял Вашу задачу, осуществляется так же, как написано в документации. Например, если нужно обработать полученные от пользователя данные перед добавлением контента, то можно перехватывать или событие "content_before_add" (для всех типов контента), или "content_ИмяНужногоТипаКонтента_before_add" (для контента только одного нужного типа, например, "content_articles_before_add" для статей в демо).
Для этого нужно сделать два действия, описанных в "Документация — Перехват событий": добавить запись о перехвате нужного события в манифест Вашего контроллера и добавить в этот контроллер обработчик события с проверкой введённых данных.
Да, согласен, извините.Fenix, Вы предоставляете слишком мало данных и слишком сумбурно
Пробую разобраться на примерах...
Тип контента заранее не известен (поле может использоваться в любых компонентах, предусматривающих создание полей с помощью существующих типов полей) как и системное имя созданного поля.
допустим есть тип поля my_fields.php внутри функции parse($value) значение $value сравнивается со списком недопустимых значений $value.
В \system\controllers\content\manifest.php
добавляю 'value_delete',
В system\controllers\content\hooks\
создаю хук: называю его value_delete.php
<?php class onContentValueDelete extends cmsAction { public function run($ctype){ return $value; } }
if ($value = недопустимое значение) {$value= cmsEventsManager::hook('value_delete', $ctype);}
P.S. что-то окончательно запутался сам😥…
Да создается свое поле.я пока не понял Вашу задачу
Нужно проверить введенные пользователем данные и при введении им недопустимого значения (определены в поле) — сбросить введенное пользователем значение (обнулить поле, тем самым не дав сохранить это значение, но оставить возможность ввести новое). (надеюсь понятно объяснил😊)
И на этом спасибо.Только сходу про создание полей я подсказать не смогу
в system\controllers\content\manifest.php добавляем:
'value_delete'
добавляю условие
if($value == недопустимое значение) { $value= cmsEventsManager::hook('value_delete', $value);}
Осталось решить вопрос что прописать для сброса значения в форме...
Если прописать
class onContentValueDelete extends cmsAction { public function run($value){ return $value; } }
public function store($value, $is_submitted, $old_value=null){ if($value === недопустимое значение){ return false; } return $value; }
А вот как именно это сделать "по феншую" посмотрите в стандартных полях или в бесплатных полях в "Дополнениях". Или подождите ответа на форуме.