Build your time series with ease
Laravel Time Series provides an API to projects data from your Eloquent models, and convert them to time series.
The full documentation can be found here.
composer require timothepearce/laravel-time-series
php artisan migrate
php artisan make:projection MyProjection
When you want to make your model projectable, you must add it the Projectable
trait and define the $projections
class attribute:
use App\Models\Projections\MyProjection;
use TimothePearce\TimeSeries\Projectable;
class MyProjectableModel extends Model
{
use Projectable;
protected array $projections = [
MyProjection::class,
];
}
When you're implementing a projection, follow theses three steps:
A Projection is an Eloquent model and is queried the same way, but keep in mind that the projections are all stored in a single table. That means you'll have to use scope methods to get the correct projections regarding the period you defined earlier:
MyProjection::period('1 day')
->between(
today()->subDay(), // start date
today(), // end date
)
->get();
To get a time series from a projection model, use the toTimeSeries method:
MyProjection::period('1 day')
->toTimeSeries(
today()->subDay(),
today(),
);
Note that this method fill the missing projections between the given dates with the default content you defined earlier.
The MIT License (MIT). Please see License File for more information.