Различия

Показаны различия между двумя версиями страницы.

Ссылка на это сравнение

Предыдущая версия справа и слева Предыдущая версия
Следующая версия
Предыдущая версия
инвентаризация:dev:model:fields [2024/05/26 17:25]
admin
инвентаризация:dev:model:fields [2025/05/20 08:03] (текущий)
admin
Строка 1: Строка 1:
-{{tag>dev Инвентаризация}} +{{tag>dev Инвентаризация model fields}} 
-====== Инвентаризация: modelfields ======+====== Инвентаризация: DEVModel Fields ======
  
 Описание атрибутов модели делаем в одной функции: Описание атрибутов модели делаем в одной функции:
 <code php> <code php>
-    public $parentAttr='parentService'; //имя атрибута в котором у нас объект-предок (родительское помещение/сервис/отдел и т.д.)+    /** @var string как называется один экземпляр модели (для страницы Create -> Новый объект) */ 
 +    public static $title='Объект'; 
 +  
 +    /** @var string как называется список моделей (для страницы Index) */ 
 +    public static $titles='Объекты'; 
 +  
 +    /** @var string надпись на кнопке создания нового объекта в списке */ 
 +    public static $addButtonText='Добавить'; 
 +  
 +    /** @var null|string подсказка для кнопки создания нового объекта */ 
 +    public static $addButtonHint=null; 
 +  
 +    /** @var string Префикс для страницы Create (Новый $title) */ 
 +    public static $newItemPrefix='Новый'; 
 + 
 +    public $parentAttr='parentService'; //имя атрибута в котором у нас объект-предок (родительское помещение/сервис/отдел и т.д.) - нужен для рекурсивных функций обхода дерева
     public function attributeData() {     public function attributeData() {
         return [         return [
Строка 17: Строка 32:
                 //позже транслируется в attributeIndexHints, используется для пояснения атрибута в списках                 //позже транслируется в attributeIndexHints, используется для пояснения атрибута в списках
                 'indexHint'=>'Модели можно перечислить варианты через верт. черту &quot;|&quot;',                   'indexHint'=>'Модели можно перечислить варианты через верт. черту &quot;|&quot;',  
 +                //тип Input этого аттрибута в форме редактирования
 +                //  - boolean - да / нет (чекбокс)
 +                //  - toggle - это как boolean, но только для 0 и 1 есть свои названия, напр сервис/услуга
 +                //  - radios - это как toggle, только значений может быть больше 2
 +                //  - list - это как radios, только значений прям много и оформляется в виде dropdown
 +                //  - ntext - textarea (простой текст без форматирования с конвертацией nl -> <br> при рендере)
 +                //  - text - текст с форматированием (какой формат прописывается в параметрах)
 +                //  - date - дата
 +                //  - datetime - дата/время
 +                //  - ips - список IP
 +                //  - macs - список MAC
 +                //  - urls - список URL 
 +                //  - link - одиночная ссылка
 +                //  - string - обычный текст (по умолчанию)
 +                'fieldType' => 'text',
                 //чем заполнить селектор в форме, если значение не введено                 //чем заполнить селектор в форме, если значение не введено
                 'placeholder' => 'Модель ПК не выбрана',                   'placeholder' => 'Модель ПК не выбрана',  
Строка 24: Строка 54:
                 //при наличии объектов в этом поле, считаем что себя удалять нельзя,                  //при наличии объектов в этом поле, считаем что себя удалять нельзя, 
                 //иначе в объектах ссылающихся на нас будут битые ссылки                 //иначе в объектах ссылающихся на нас будут битые ссылки
-                //(если не объявлять явно, определяется из $linkSchema+                //(если не объявлять явно, определяется из $linkSchema)
                 'is_reverseLink'=false,                 'is_reverseLink'=false,
                 //при вызове функции absorb это поле нужно поглощать из переданного объекта                 //при вызове функции absorb это поле нужно поглощать из переданного объекта
 +                // - false - нет (по умолчанию для полей - "не обратных ссылок"
 +                // - 'ifEmpty' - если локальное значение отсутствует, то принимать с абсорбируемого объекта
 +                // - true - да (по умолчанию для полей, являющихся обратными ссылками)
                 'absorb'=>true,                 'absorb'=>true,
 +                //что нужно заджойнить при отображении этого атрибута в списке (для жадной загрузки + поиск)
 +                'join'=>['techModel','techType']
             ],             ],
             'model'=>['alias'=>'model_id'], //значения параметров атрибута брать из model_id             'model'=>['alias'=>'model_id'], //значения параметров атрибута брать из model_id
Строка 38: Строка 73:
      * 'services_ids'=>[      * 'services_ids'=>[
      * Service::class, //на какой класс ссылаемся      * Service::class, //на какой класс ссылаемся
-     * 'acls_ids', //если там есть обратная ссылка, то в каком аттрибуте +     * 'acls_ids', //если там есть обратная ссылка, то в каком аттрибуте 
-      ], +                      'updater' => ['class' => ManyToManySmartUpdater::class,], //Если запись в many-2-many таблицу делается кастомным способом 
-     * 'user_id'=>[ +                                              //Передается в behaviors() 
-     * Users::class, +                                              //https://github.com/voskobovich/yii2-linker-behavior?tab=readme-ov-file#custom-junction-table-values 
-     * 'loader'=>'user' //как загрузчик этого объекта называется в мастер-классе+     * 'loader'=>'servicesList',//как загрузчик этого объекта называется, если он не формируется автоматически из названия ссылки 
 +     * 'deleteable'=>true,     //можно ли удалять объект с такими ссылками (если ссылки удаляются в beforeDelete)
      * ],      * ],
      * ];      * ];
  • инвентаризация/dev/model/fields.1716744310.txt.gz
  • Последнее изменение: 2024/05/26 17:25
  • admin