Blame view

common/modules/blog/behaviors/Autocomplete.php 4.33 KB
4253cbec   root   first commit
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
  <?php

  namespace common\modules\blog\behaviors;

  

  use common\models\Tools;

  use yii\db\ActiveRecord;

  use yii\base\Behavior;

  use yii\helpers\StringHelper;

  

  /**

   * Класс для автозаполнения полей некими данными или их форматирования

   *

   * Клас предназначен для заполнения полей данными или форматирования данных

   *

   */

  

  class Autocomplete extends Behavior

  {

      /**

       * Атрибуты для обработки

       *

       * Атрибуты считываются автоматически с настроек поведения в конкретном обьекте.

       * Имеет вид ассоциативного массива, где ключ - метод автозаполнения, а значение - массив, каждій єлемент

       * которого - свойство обьекта для обработки, может включать массив - первый єлемент которого свойство,

       * а дальнейшие конфигурации.

       *

       * @var array Ассоциативны массив [key(метод заполнения) => [[0 => property(свойство обьекта), ... дополнительные

       * настройки]], ...[]]

       *

       */

      public $attributes;

  

      /**

       * События

       *

       * События на которые должно срабатывать поведение. Задается ассоциативный массив, в котором ключ - событие

       * связанного обьекта, а значение - метод, который вызывается при этом событии

       *

       * @return array [key(event)  => val(method)]

       *

       */

      public function events()

      {

          return [

              ActiveRecord::EVENT_BEFORE_INSERT => 'autocomplete',

              ActiveRecord::EVENT_BEFORE_UPDATE => 'autocomplete',

          ];

      }

  

      /**

       * События

       *

       * События на которые должно срабатывать поведение. Задается ассоциативный массив, в котором ключ - событие

       * связанного обьекта, а значение - метод, который вызывается при этом событии

       * Доступные автозаполнения:

       * ['translit' => ['prop1', ... 'prop2']],

       * где prop - свойство подлежащее транслитерации

       * ['repeat' => [[string 'prop1', string 'target1', boolean 'skipFilled', int 'count', boolean 'truncate', string 'suffix'], ...[]],

       *  где prop - свойство для преобразования,

       *      target - свойство с которого взять данные,

       *      count - число для преобразования,

       *      skipFilled - пропустить непустые,

       *      truncate - true - обрезать по словам, false - по символам,

       *      suffix - суффикс, который добавить после обрезки

       *

       * @param mixed $event Yii обьект свойста https://github.com/yiisoft/yii2/blob/master/docs/guide-ru/concept-events.md

       *

       */

      public function autocomplete($event)

      {

          if(!empty($this->attributes['translit'])) {

              foreach($this->attributes['translit'] as $translit) {

                  if($this->owner->hasAttribute($translit)) {

                      $this->owner->$translit = Tools::translit($this->owner->$translit);

                  }

              }

          }

          if(!empty($this->attributes['repeat'])) {

              foreach($this->attributes['repeat'] as $repeat) {

                  if(is_array($repeat) && $this->owner->hasAttribute($repeat[0]) && $this->owner->hasAttribute($repeat[1]) && is_int($repeat[3]) && (empty($this->owner->$repeat[0]) || $repeat[2])) {

                      $suffix =  $repeat[5]?:'';

                      $truncate = $repeat[4]?'truncateWords':'truncate';

                      $this->owner->$repeat[0] = StringHelper::$truncate($this->owner->$repeat[1], $repeat[3], $suffix);

                  }

              }

          }

      }

  }