GoalAdGroup.php
3.27 KB
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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
<?php
namespace App\Models\Pivots;
use App\Models\AdGroup;
use App\Models\Campaigns;
use App\Models\Variable;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Database\Eloquent\Relations\Pivot;
use Illuminate\Support\Collection;
class GoalAdGroup extends Pivot
{
protected $table = 'goal_ad_groups';
protected $fillable = [
'external_id',
'campaign_external_id',
'dictionary_campaign_id',
'name',
'negative_keywords',
'external_upload_at',
'external_updated_at',
'updated_need',
'updated_self',
];
protected $casts = [
'dictionary_campaign_id' => 'int',
'external_id' => 'int',
'campaign_external_id' => 'int',
'negative_keywords' => 'array',
'external_upload_at' => 'datetime',
'external_updated_at' => 'datetime',
'updated_need' => 'datetime',
'updated_self' => 'datetime',
];
static public function getWithPivot()
{
return [
'id',
'external_id',
'campaign_external_id',
'dictionary_campaign_id',
'name',
'negative_keywords',
'external_upload_at',
'external_updated_at',
'updated_self',
'updated_need',
];
}
/**
* @return Collection
*/
static public function getPropertiesCopyWithPivot()
{
return collect([
'name',
'negative_keywords',
]);
}
/**
* @param AdGroup|array $ad_group
*/
static public function copyPropertyFromMain($ad_group)
{
return self::getPropertiesCopyWithPivot()
->transform(function ($property_name) use ($ad_group) {
$value = null;
if ($ad_group instanceof AdGroup) {
$value = $ad_group->{$property_name};
} elseif (is_array($ad_group) && isset($ad_group[$property_name])) {
$value = $ad_group[$property_name];
}
return [
$property_name => $value
];
})->flatMap(function ($val) {
return $val;
})->all();
}
public function scopeForExternal(Builder $query)
{
return $query->whereNotNull('external_id');
}
public function scopeForNotExternal(Builder $query)
{
return $query->whereNull('external_id');
}
public function scopeNeedUpdated(Builder $query)
{
return $query->whereNotNull('updated_need');
}
public function scopeForUpdatedSelf(Builder $query)
{
$query->whereNotNull('updated_self');
}
public function dictionaryCampaign()
{
return $this->belongsTo(Campaigns::class, 'dictionary_campaign_id');
}
public function dictionaryCampaignVariables()
{
return $this->hasMany(DictionaryCampaignVariable::class, 'dictionary_campaign_id');
}
public function variables()
{
return $this->belongsToMany(Variable::class, 'dictionary_campaign_variables', 'dictionary_campaign_id', 'variable_id')
->using(DictionaryCampaignVariable::class)
->withPivot(DictionaryCampaignVariable::getWithPivot())
->withTimestamps();
}
}