1 | <?php |
||
39 | class Company extends Model implements AuthenticatableContract, |
||
40 | AuthorizableContract, |
||
41 | CanResetPasswordContract, |
||
42 | PolicyCheckable |
||
43 | { |
||
44 | use Authenticatable, Authorizable, CanResetPassword; |
||
45 | |||
46 | /** |
||
47 | * The attributes that are mass assignable. |
||
48 | * |
||
49 | * @var array |
||
50 | */ |
||
51 | protected $fillable = ['name', 'email', 'password']; |
||
52 | |||
53 | /** |
||
54 | * The attributes excluded from the model's JSON form. |
||
55 | * |
||
56 | * @var array |
||
57 | */ |
||
58 | protected $hidden = ['password', 'remember_token']; |
||
59 | |||
60 | /** |
||
61 | * @return \Illuminate\Database\Eloquent\Relations\HasMany |
||
62 | */ |
||
63 | 54 | public function employees() |
|
64 | { |
||
65 | 54 | return $this->hasMany(Employee::class); |
|
66 | } |
||
67 | |||
68 | 38 | public function groups() |
|
69 | { |
||
70 | 38 | return $this->hasMany(Group::class); |
|
71 | } |
||
72 | |||
73 | /** |
||
74 | * @param Group $group |
||
75 | * @return bool |
||
76 | */ |
||
77 | 16 | public function verifyGroup(Group $group) |
|
78 | { |
||
79 | 16 | return $group->company_id === $this->id; |
|
80 | } |
||
81 | |||
82 | /** |
||
83 | * @param Employee $employee |
||
84 | * @return bool |
||
85 | */ |
||
86 | 16 | public function verifyEmployee(Employee $employee) |
|
87 | { |
||
88 | 16 | return $employee->company_id === $this->id; |
|
89 | } |
||
90 | |||
91 | /** |
||
92 | * @param Company $company |
||
93 | * @return bool |
||
94 | */ |
||
95 | public function verifyCompany(Company $company) |
||
96 | { |
||
97 | return $company->id === $this->id; |
||
98 | } |
||
99 | |||
100 | /** |
||
101 | * @param Calendar $calendar |
||
102 | * @return bool |
||
103 | */ |
||
104 | public function verifyCalendar(Calendar $calendar) |
||
109 | |||
110 | /** |
||
111 | * @param \DateTime $from |
||
112 | * @param \DateTime $to |
||
113 | * @return \Illuminate\Support\Collection |
||
114 | */ |
||
115 | 2 | public function getEmployeesTimeSlots($from, $to) |
|
127 | |||
128 | /** |
||
129 | * @param \DateTime $from |
||
130 | * @param \DateTime $to |
||
131 | * @return \Illuminate\Support\Collection |
||
132 | */ |
||
133 | 2 | public function getMeetingsTimeSlots($from, $to) |
|
134 | { |
||
135 | 2 | return \DB::table('meetings') |
|
136 | 2 | ->join('groups', 'meetings.group_id', '=', 'groups.id') |
|
137 | 2 | ->join('meeting_timeslots', 'meetings.id', '=', 'meeting_timeslots.meeting_id') |
|
138 | 2 | ->where('meeting_timeslots.time_start', '>=', $from) |
|
139 | 2 | ->where('meeting_timeslots.time_end', '<=', $to) |
|
140 | 2 | ->where('groups.company_id','=', $this->id) |
|
141 | 2 | ->where('meetings.start_time','=', NULL) |
|
142 | 2 | ->select('meetings.id', 'meetings.duration','meeting_timeslots.time_start','meeting_timeslots.time_end') |
|
143 | 2 | ->get(); |
|
144 | } |
||
145 | |||
146 | 2 | public function getUsersMeetings($users, $meetings) |
|
159 | } |
||
160 |