GitPedia

Laravel easy metrics

Generate metrics with ease and precision.

From sakanjo·Updated June 12, 2026·View on GitHub·

> ✨ Help support the maintenance of this package by [sponsoring me](https://github.com/sponsors/sakanjo). The project is written primarily in PHP, distributed under the MIT License license, first published in 2023. Key topics include: charts, laravel, metrics, reports.

Latest release: v1.1.12
June 1, 2026View Changelog →

Easy metrics banner

<p align="center"> <a href="https://github.com/sakanjo/laravel-easy-metrics/actions"><img alt="Workflow status" src="https://img.shields.io/github/actions/workflow/status/sakanjo/laravel-easy-metrics/tests.yml?style=for-the-badge"></a> <a href="https://laravel.com"><img alt="Laravel v10.x" src="https://img.shields.io/badge/Laravel-v10.x-FF2D20?style=for-the-badge&logo=laravel"></a> <a href="https://php.net"><img alt="PHP 8.0" src="https://img.shields.io/badge/PHP-8.0-777BB4?style=for-the-badge&logo=php"></a> </p> <h1 align="center">🔥 Easy metrics</h1> <p align="center">Easily create metrics for your application.</p>

✨ Help support the maintenance of this package by sponsoring me.

Designed to work with Laravel, Filament, Easy enum, and more.

Preview

🚀 Supported metrics

  • Bar metric
  • Doughnut metric
  • Line metric
  • Pie metric
  • Polar metric
  • Trend metric
  • Value metric

Table of contents

📦 Install

composer require sakanjo/laravel-easy-metrics

🦄 Usage

Value metric

php
use SaKanjo\EasyMetrics\Metrics\Value; use App\Models\User; $data = Value::make(User::class) ->count();

Query types

The currently supported aggregate functions to calculate a given column compared to the previous time interval / range

Min
php
Value::make(User::class) ->min('age');
Max
php
Value::make(User::class) ->max('age');
Sum
php
Value::make(User::class) ->sum('age');
Average
php
Value::make(User::class) ->average('age');
Count
php
Value::make(User::class) ->count();

Doughnut metric

php
use SaKanjo\EasyMetrics\Metrics\Doughnut; use App\Models\User; [$labels, $data] = Doughnut::make(User::class) ->count('gender');

Query types

The currently supported aggregate functions to calculate a given column compared to the previous time interval / range

Min
php
Doughnut::make(User::class) ->min('age', 'gender');
Max
php
Doughnut::make(User::class) ->max('age', 'gender');
Sum
php
Doughnut::make(User::class) ->sum('age', 'gender');
Average
php
Doughnut::make(User::class) ->average('age', 'gender');
Count
php
Doughnut::make(User::class) ->count('gender');

Trend metric

php
use SaKanjo\EasyMetrics\Metrics\Trend; use App\Models\User; [$labels, $data] = Trend::make(User::class) ->countByMonths();

Query types

The currently supported aggregate functions to calculate a given column compared to the previous time interval / range

Min
php
$trend->minByYears('age'); $trend->minByMonths('age'); $trend->minByWeeks('age'); $trend->minByDays('age'); $trend->minByHours('age'); $trend->minByMinutes('age');
Max
php
$trend->maxByYears('age'); $trend->maxByMonths('age'); $trend->maxByWeeks('age'); $trend->maxByDays('age'); $trend->maxByHours('age'); $trend->maxByMinutes('age');
Sum
php
$trend->sumByYears('age'); $trend->sumByMonths('age'); $trend->sumByWeeks('age'); $trend->sumByDays('age'); $trend->sumByHours('age'); $trend->sumByMinutes('age');
Average
php
$trend->averageByYears('age'); $trend->averageByMonths('age'); $trend->averageByWeeks('age'); $trend->averageByDays('age'); $trend->averageByHours('age'); $trend->averageByMinutes('age');
Count
php
$trend->countByYears(); $trend->countByMonths(); $trend->countByWeeks(); $trend->countByDays(); $trend->countByHours(); $trend->countByMinutes();

Other metrics

  • Bar extends Trend
  • Line extends Trend
  • Doughnut extends Pie
  • Polar extends Pie

Ranges

Every metric class contains a ranges method, that will determine the range of the results based on it's date column.

php
use SaKanjo\EasyMetrics\Metrics\Trend; use SaKanjo\EasyMetrics\Metrics\Enums\Range; use App\Models\User; Value::make(User::class) ->range(30) ->ranges([ 15, 30, 365, Range::TODAY, // Or 'TODAY' ]);

Available custom ranges

  • Range::TODAY
  • Range::YESTERDAY
  • Range::MTD
  • Range::QTD
  • Range::YTD
  • Range::ALL

Growth rates

Growth rate, expressed as both a value and a percentage, measures the change in a quantity over time, showing the speed of its expansion or contraction in both absolute and relative terms.

Using Value metric

php
use SaKanjo\EasyMetrics\Metrics\Value; use SaKanjo\EasyMetrics\Enums\GrowthRateType; use App\Models\User; [$value, $growth] = Value::make(User::class) ->withGrowthRate() ->growthRateType(GrowthRateType::Value) // default is `Percentage` ->count();

Using Trend metric

php
use SaKanjo\EasyMetrics\Metrics\Trend; use App\Models\User; [$labels, $data, $growth] = Trend::make(User::class) ->withGrowthRate() ->countByYears();

Using Doughnut metric

php
use SaKanjo\EasyMetrics\Metrics\Doughnut; use App\Models\User; [$labels, $data, $growth] = Doughnut::make(User::class) ->withGrowthRate() ->count('gender');

Available growth rate types

  • GrowthRateType::Value
  • GrowthRateType::Percentage

🔥 Tips

Using getLabel

You can use the getLabel method to customize the retreived data labels, for example:

php
<?php namespace App\Enums; use SaKanjo\EasyEnum; enum ExampleEnum: int { use EasyEnum; // Includes getLabel method case Active = 0; case Disabled = 1; }

🔥 Practical examples

Filamentphp v3 widgets

php
<?php namespace App\Filament\Widgets\Admin; use App\Models\User; use Filament\Widgets\ChartWidget; use SaKanjo\EasyMetrics\Metrics\Trend; class UsersCountChart extends ChartWidget { protected static ?string $heading = 'Users count trend'; protected function getData(): array { [$labels, $data] = Trend::make(User::class) ->range($this->filter) ->rangesFromOptions($this->getFilters()) ->countByMonths(); return [ 'datasets' => [ [ 'label' => 'Users', 'data' => $data, ], ], 'labels' => $labels, ]; } protected function getType(): string { return 'line'; } protected function getFilters(): ?array { return [ 15 => '15 Months', 30 => '30 Months', 60 => '60 Months', ]; } }

💖 Support the development

Do you like this project? Support it by donating

Click the "💖 Sponsor" at the top of this repo.

©️ Credits

📄 License

MIT License © 2023-PRESENT Salah Kanjo

Contributors

Showing top 3 contributors by commit count.

View all contributors on GitHub →

This article is auto-generated from sakanjo/laravel-easy-metrics via the GitHub API.Last fetched: 6/25/2026