<?phpnamespaceIlluminate\Notifications;
useIlluminate\Database\Eloquent\Builder;
useIlluminate\Database\Eloquent\HasCollection;
useIlluminate\Database\Eloquent\Model;
classDatabaseNotificationextendsModel{
/** @use HasCollection<DatabaseNotificationCollection> */useHasCollection;
/**
* The "type" of the primary key ID.
*
* @var string
*/protected$keyType = 'string';
/**
* Indicates if the IDs are auto-incrementing.
*
* @var bool
*/public$incrementing = false;
/**
* The table associated with the model.
*
* @var string
*/protected$table = 'notifications';
/**
* The guarded attributes on the model.
*
* @var array
*/protected$guarded = [];
/**
* The attributes that should be cast to native types.
*
* @var array
*/protected$casts = [
'data' => 'array',
'read_at' => 'datetime',
];
/**
* The type of collection that should be used for the model.
*/protectedstaticstring$collectionClass = DatabaseNotificationCollection::class;
/**
* Get the notifiable entity that the notification belongs to.
*
* @return \Illuminate\Database\Eloquent\Relations\MorphTo<\Illuminate\Database\Eloquent\Model, $this>
*/publicfunctionnotifiable()
{
return$this->morphTo();
}
/**
* Mark the notification as read.
*
* @return void
*/publicfunctionmarkAsRead()
{
if (is_null($this->read_at)) {
$this->forceFill(['read_at' => $this->freshTimestamp()])->save();
}
}
/**
* Mark the notification as unread.
*
* @return void
*/publicfunctionmarkAsUnread()
{
if (! is_null($this->read_at)) {
$this->forceFill(['read_at' => null])->save();
}
}
/**
* Determine if a notification has been read.
*
* @return bool
*/publicfunctionread()
{
return$this->read_at !== null;
}
/**
* Determine if a notification has not been read.
*
* @return bool
*/publicfunctionunread()
{
return$this->read_at === null;
}
/**
* Scope a query to only include read notifications.
*
* @param \Illuminate\Database\Eloquent\Builder<static> $query
* @return \Illuminate\Database\Eloquent\Builder<static>
*/publicfunctionscopeRead(Builder $query)
{
return$query->whereNotNull('read_at');
}
/**
* Scope a query to only include unread notifications.
*
* @param \Illuminate\Database\Eloquent\Builder<static> $query
* @return \Illuminate\Database\Eloquent\Builder<static>
*/publicfunctionscopeUnread(Builder $query)
{
return$query->whereNull('read_at');
}
}