F

Fenix

Кому хочу- тому и плюсую, кому не хочу - "прохожу лесом, который там -->"
+164
Репутация
54
Рейтинг
#1 Запрет добавления значения 15 мая 2016 в 15:21

Вот с них и надо было начинать

Loadырь
Понемногу и с нюансами разобрался😊. еще раз спасибо.
#2 Запрет добавления значения 15 мая 2016 в 13:52

Вот с них и надо было начинать,

Loadырь
Спасибо, подсказка Ваша — уже большая помощь, пробую дальше разбираться сам.
Работает😊.
#3 Запрет добавления значения 15 мая 2016 в 13:40
Спасибо! Будем пробовать😊.
Есть еще много немаловажных ньюансов… тему не закрываю.
#4 Запрет добавления значения 15 мая 2016 в 13:21
Что-то вроде получается😊:
в system\controllers\content\manifest.php добавляем:
  1. 'value_delete'
в \system\fields\my_fields.php
добавляю условие
  1. if($value == недопустимое значение) { $value= cmsEventsManager::hook('value_delete', $value);}
в \system\controllers\content\hooks\ добавляю value_delete.php
Осталось решить вопрос что прописать для сброса значения в форме...
Если прописать
  1.  
  2. class onContentValueDelete extends cmsAction {
  3.  
  4. public function run($value){
  5.  
  6. unset ($value);
  7.  
  8. return $value;
  9.  
  10. }
  11.  
  12. }
Форма сохранится, правда уничтожит $value при выводе сохраненной записи… этого результата можно добиться и просто прописав в my_fields.php

  1. if ($value = недопустимое значение) {unset ($value);}
.....😥…
#5 Запрет добавления значения 15 мая 2016 в 12:13

Только сходу про создание полей я подсказать не смогу

WebMan
И на этом спасибо.
#6 Запрет добавления значения 15 мая 2016 в 11:57

я пока не понял Вашу задачу

WebMan
Да создается свое поле.
Нужно проверить введенные пользователем данные и при введении им недопустимого значения (определены в поле) — сбросить введенное пользователем значение (обнулить поле, тем самым не дав сохранить это значение, но оставить возможность ввести новое). (надеюсь понятно объяснил😊)
#7 Запрет добавления значения 15 мая 2016 в 11:42

Fenix, Вы предоставляете слишком мало данных и слишком сумбурно

WebMan
Да, согласен, извините.
Пробую разобраться на примерах...
Тип контента заранее не известен (поле может использоваться в любых компонентах, предусматривающих создание полей с помощью существующих типов полей) как и системное имя созданного поля.
допустим есть тип поля my_fields.php внутри функции parse($value) значение $value сравнивается со списком недопустимых значений $value.
В \system\controllers\content\manifest.php
добавляю 'value_delete',
В system\controllers\content\hooks\
создаю хук: называю его value_delete.php
  1.  
  2. <?php
  3. class onContentValueDelete extends cmsAction {
  4. public function run($ctype){
  5. $value = unset ($value);
  6. return $value;
  7. }
  8. }
  9.  
И вызываю в my_fields.php
  1.  
  2. if ($value = недопустимое значение) {$value= cmsEventsManager::hook('value_delete', $ctype);}
  3.  
Я правильно понял?
P.S. что-то окончательно запутался сам😥…
#8 Запрет добавления значения 15 мая 2016 в 10:12
Дело не в лени, а в отсутствии достаточных знаний, по этой причине и спрашиваю.
В типах контента в типе поля… примеры по работе с контентом (а точнее примеры хуков для полей контена) к сожалению (доступно понятных) не нашел.
P.s. некоторые только учаться, а не уже знают…
#9 Запрет добавления значения 15 мая 2016 в 08:57
значит бесполезно пытаться "соорудить" нечто вроде:
  1.  
  2. public function getRules() {
  3. $this->rules[] = array('условия');
  4. if ($this->parse($value) == недопустимое значение) {
  5. return $this->rules;
  6. }else {
  7. return false;
  8. }
  9.  
Да и значение $this->parse($value) до сохранения не передаются в конструкцию...
печально… по двум причинам — название поля в БД может быть произвольным и поле может использоваться несколько раз на странице (как отлавливать учитывая этот момент); не очень (даже очень не очень) разбираюсь в хуках...
Если возможно пару примеров перехвата с пояснениями (на нескольких примерах, думаю будет разобраться проще).
Спасибо.
#1 Запрет добавления значения 15 мая 2016 в 08:09
Здравствуйте.
Подскажите, как запретить добавлять определенные значения в поля. Есть встроенная в icms2 валидация но нужны свои условия. Как прописать правила для запрета на добавление значения при вводе недопустимого значения?
Спасибо.
#11 Передача переменной между функциями 14 мая 2016 в 15:51
UP!
#12 Передача переменной между функциями 8 мая 2016 в 20:59
Чтобы не "плодить темы" еще один маленький вопрос :
как сбросить значение поля при условии?
  1. if($value == 1 ) { сбросить значение, вывести текст ошибки ;}
Спасибо.
#13 Передача переменной между функциями 4 мая 2016 в 19:44
UP!
Уточню. Возможно не достаточно точно изъясняюсь.
В функции А одним из промежуточных значений (в зависимости от условий присваиваем переменной С значение 1 или 0 ) — конечный результат выполнения функции $value.
В функции Б результат выполнения функции зависит от значения $С, принятого в функции А.
Спасибо.
#14 Передача переменной между функциями 3 мая 2016 в 06:46
Pasha, можно по подробнее?
Допустим внутри класса я объявил private $С;
внутри public function А() присвоил переменной значение "1" — $this->$С =1;
как получить внутри public function Б() $С =1;? ($this->$С =1; — по сути новое присвоение значения переменной, а не получение значения из предыдущей функции).
Спасибо.
#15 Передача переменной между функциями 2 мая 2016 в 14:34

Почитайте тему об областях видимости переменных.

Странник
Да глобальные переменные пробовал, но не хочется к ним пребегать.

ну а если следовать коду буквально, то

Pasha
Да если переменная конечная, а в данном случае одна из промежуточных.
Используя этот сайт, вы соглашаетесь с тем, что мы используем файлы cookie.