@@ 12-80 (lines=69) @@ | ||
9 | * Class Contact |
|
10 | * @package linkprofit\AmoCRM\entities |
|
11 | */ |
|
12 | class Contact extends CustomizableEntity implements LinkableElement |
|
13 | { |
|
14 | /** |
|
15 | * Контакт |
|
16 | */ |
|
17 | const ELEMENT_TYPE = 1; |
|
18 | ||
19 | /** |
|
20 | * @var string Название контакта |
|
21 | */ |
|
22 | public $name; |
|
23 | ||
24 | /** |
|
25 | * @var integer id пользователя создавшего контакт |
|
26 | */ |
|
27 | public $created_by; |
|
28 | ||
29 | /** |
|
30 | * @var string Название новой компании. Параметр указывается для создания новой компании и привязке к ней контакта. Для привязки контакта к уже существующей компании, необходимо использовать параметр company_id |
|
31 | */ |
|
32 | public $company_name; |
|
33 | ||
34 | /** |
|
35 | * @var string Теги, привязываемые к контакту. Задаются целостной строковой переменной, внутри строки перечисляются через запятую |
|
36 | */ |
|
37 | public $tags; |
|
38 | ||
39 | /** |
|
40 | * @var string Покупатели, привязываемые к контакту. Перечисляются через запятую. |
|
41 | */ |
|
42 | public $customers_id; |
|
43 | ||
44 | /** |
|
45 | * @var array |
|
46 | */ |
|
47 | protected $fieldList = [ |
|
48 | 'id', 'name', 'created_at', 'updated_at', |
|
49 | 'responsible_user_id', 'created_by', 'company_name', |
|
50 | 'tags', 'leads_id', 'customers_id', 'company_id', |
|
51 | ]; |
|
52 | ||
53 | use CompanyLinkable, |
|
54 | LeadsLinkable; |
|
55 | ||
56 | /** |
|
57 | * @param $entityClass |
|
58 | * |
|
59 | * @return bool |
|
60 | */ |
|
61 | public function supports($entityClass) |
|
62 | { |
|
63 | $supportedClasses = [Task::class, Note::class]; |
|
64 | ||
65 | return in_array($entityClass, $supportedClasses, 1) && !empty($this->id); |
|
66 | } |
|
67 | ||
68 | /** |
|
69 | * @param LinkElementCapableEntity $entity |
|
70 | * |
|
71 | * @return LinkElementCapableEntity |
|
72 | */ |
|
73 | public function linkSelf(LinkElementCapableEntity $entity) |
|
74 | { |
|
75 | $entity->element_type = self::ELEMENT_TYPE; |
|
76 | $entity->element_id = $this->id; |
|
77 | ||
78 | return $entity; |
|
79 | } |
|
80 | } |
@@ 12-86 (lines=75) @@ | ||
9 | * Class Lead |
|
10 | * @package linkprofit\AmoCRM\entities |
|
11 | */ |
|
12 | class Lead extends CustomizableEntity implements LinkableElement |
|
13 | { |
|
14 | /** |
|
15 | * Сделка |
|
16 | */ |
|
17 | const ELEMENT_TYPE = 2; |
|
18 | ||
19 | /** |
|
20 | * @var string Название сделки |
|
21 | */ |
|
22 | public $name; |
|
23 | ||
24 | /** |
|
25 | * @var integer Статус сделки (id этапа продаж см. Воронки и этапы продаж) Чтобы перенести сделку в другую воронку, необходимо установить ей статус из нужной воронки |
|
26 | */ |
|
27 | public $status_id; |
|
28 | ||
29 | /** |
|
30 | * @var integer ID воронки. Указывается в том случае, если выбраны статусы id 142 или 143, т.к. эти статусы не уникальны и обязательны для всех цифровых воронок. |
|
31 | */ |
|
32 | public $pipeline_id; |
|
33 | ||
34 | /** |
|
35 | * @var integer Бюджет сделки |
|
36 | */ |
|
37 | public $sale; |
|
38 | ||
39 | /** |
|
40 | * @var string Если вы хотите задать новые теги, перечислите их внутри строковой переменной через запятую |
|
41 | */ |
|
42 | public $tags; |
|
43 | ||
44 | /** |
|
45 | * @var int Id пользователя изменившего сущность, если 0, то робот |
|
46 | */ |
|
47 | public $modified_user_id; |
|
48 | ||
49 | /** |
|
50 | * @var array |
|
51 | */ |
|
52 | protected $fieldList = [ |
|
53 | 'id', 'name', 'created_at', 'updated_at', |
|
54 | 'status_id', 'pipeline_id', 'responsible_user_id', |
|
55 | 'sale', 'tags', 'contacts_id', 'company_id', |
|
56 | 'modified_user_id' |
|
57 | ]; |
|
58 | ||
59 | use CompanyLinkable, |
|
60 | ContactsLinkable; |
|
61 | ||
62 | /** |
|
63 | * @param $entityClass |
|
64 | * |
|
65 | * @return bool |
|
66 | */ |
|
67 | public function supports($entityClass) |
|
68 | { |
|
69 | $supportedClasses = [Task::class, Note::class]; |
|
70 | ||
71 | return in_array($entityClass, $supportedClasses, 1) && !empty($this->id); |
|
72 | } |
|
73 | ||
74 | /** |
|
75 | * @param LinkElementCapableEntity $entity |
|
76 | * |
|
77 | * @return LinkElementCapableEntity |
|
78 | */ |
|
79 | public function linkSelf(LinkElementCapableEntity $entity) |
|
80 | { |
|
81 | $entity->element_type = self::ELEMENT_TYPE; |
|
82 | $entity->element_id = $this->id; |
|
83 | ||
84 | return $entity; |
|
85 | } |
|
86 | } |