Worker.php
2.32 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
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
class Worker extends Model
{
use HasFactory;
protected $table = 'workers';
protected $fillable = [
'user_id',
'status_work',
'position_work',
'telephone',
'telephone2',
'persent_anketa',
'photo',
'email_data',
'status_profile',
'old_year',
'experience',
'en_is',
'education',
'email',
'interpassport',
'mk',
'vvp',
'vlm',
'reka_diplom',
'more_diplom',
'mpss',
'tanker',
'gmssb',
'resume',
'sort',
'updated_at',
'text',
'address',
'city',
'coord',
'file',
'is_remove',
'favorite_user',
'sroch_user'
];
/*
* Связь таблицы users с таблицей workers
*/
public function users() {
return $this->belongsTo(User::class, 'user_id');
}
// Связь Работника с сертификами (0-0 - 1)
public function sertificate() {
return $this->hasMany(sertification::class);
}
// Связь Работника с должностями (0-0 - 1)
public function job_titles() {
return $this->belongsToMany(Job_title::class, 'title_workers');
}
//Связь Работника с опытом работы (1 - 0-0)
public function place_worker() {
return $this->hasMany(place_works::class);
}
public function scopeActive($query) {
return $query->where('is_remove', '=', '0');
}
//Связь Работника с предыдущими компаниями
public function prev_company() {
return $this->hasMany(PrevCompany::class);
}
//Связь Работника с инфоблоками (0-0 - 0-0)
public function infobloks() {
return $this->belongsToMany(infobloks::class,'dop_info', 'worker_id', 'infoblok_id');
}
//Связи Работника с дополнительными
public function dop_info() {
return $this->hasMany(Dop_info::class, 'worker_id');
}
public function response() {
return $this->hasMany(ResponseWork::class);
}
}