neon / model-publishable
Set timestamps for content classes to handle publishing and expiring.
Installs: 581
Dependents: 5
Suggesters: 0
Security: 0
Stars: 0
Watchers: 3
Forks: 0
Open Issues: 0
pkg:composer/neon/model-publishable
Requires
- php: >=8.0.2
- laravel/framework: >=9.0
README
Handles any model to became publishable.
Requirements
"neon/model-uuid": "^1.0"
Install
Easily install the composer package:
composer require neon/model-publishable
Usage
Database
In the database, Publishable needs two datetime fields:
- published_at to store from when we should show.
$table->timestamp('published_at') ->nullable() ->default(null); - expired_at to store when the record will be expired.
$table->timestamp('expired_at') ->nullable() ->default(null);
Both of them nullable with the default value NULL.
Model
In the model we just should apply Publishable Trait like this:
use Neon\Model\Traits\Publishable;
class AwesomeModel extends Model
{
use Publishable;
}
Then you can use some common method, like:
- To publish a model, there is
$model->publish()method. - If you have to publish in a certain time, you can use
$model->publishedAt($timestamp)method. - To make it expire you can use
$model->expire()and$model->expiredAt($timestamp)method.
The Published scope automatically being applied to the model. If you would like to get all the models, you can query with ->withNotPublished() method then the scope will not applied.
Events
This trait add some new Eloquent Model event:
publishingwill be called afterpublish()orpublishedAt()method called but before save.- After save will be
publishedevent fired. - For expiring there are
expiringandexpiredmethods.
License
The MIT License (MIT). Please see License File for more information.