1 | <?php |
||
11 | trait BookingCustomer |
||
12 | { |
||
13 | use BookingScopes; |
||
14 | |||
15 | /** |
||
16 | * The customer may have many bookings. |
||
17 | * |
||
18 | * @return \Illuminate\Database\Eloquent\Relations\MorphMany |
||
19 | */ |
||
20 | public function bookings(): MorphMany |
||
24 | |||
25 | /** |
||
26 | * Get bookings of the given resource. |
||
27 | * |
||
28 | * @param \Illuminate\Database\Eloquent\Model $resource |
||
29 | * |
||
30 | * @return \Illuminate\Database\Eloquent\Relations\MorphMany |
||
31 | */ |
||
32 | public function bookingsOfResource(Model $resource): MorphMany |
||
33 | { |
||
34 | return $this->bookings()->where('resource_type', $resource->getMorphClass())->where('resource_id', $resource->getKey()); |
||
35 | } |
||
36 | |||
37 | /** |
||
38 | * Check if the person booked the given model. |
||
39 | * |
||
40 | * @param \Illuminate\Database\Eloquent\Model $resource |
||
41 | * |
||
42 | * @return bool |
||
43 | */ |
||
44 | public function isBooked(Model $resource): bool |
||
48 | |||
49 | /** |
||
50 | * Book the given model at the given dates with the given price. |
||
51 | * |
||
52 | * @param \Illuminate\Database\Eloquent\Model $resource |
||
53 | * @param string $startsAt |
||
54 | * @param string $endsAt |
||
55 | * |
||
56 | * @return \Rinvex\Bookings\Models\Booking |
||
57 | */ |
||
58 | public function newBooking(Model $resource, string $startsAt, string $endsAt): Booking |
||
69 | } |
||
70 |
This check looks for methods that are used by a trait but not required by it.
To illustrate, let’s look at the following code example
The trait
Idable
provides a methodequalsId
that in turn relies on the methodgetId()
. If this method does not exist on a class mixing in this trait, the method will fail.Adding the
getId()
as an abstract method to the trait will make sure it is available.