| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154 | <?php
namespace App\Filament\Pages\Widgets\Companies\Charts;
use App\Models\Company;
use Illuminate\Contracts\View\View;
use Leandrocfe\FilamentApexCharts\Widgets\ApexChartWidget;
class CumulativeGrowth extends ApexChartWidget
{
    protected static ?int $sort = 1;
    /**
     * Chart Id
     *
     * @var string
     */
    protected static string $chartId = 'cumulative-growth';
    protected static ?string $pollingInterval = null;
    protected function getOptions(): array
    {
        $startOfYear = today()->startOfYear();
        $today = today();
        // Company data
        $companyData = Company::selectRaw("COUNT(*) as aggregate, DATE_FORMAT(created_at, '%Y%m') as month")
            ->whereBetween('created_at', [$startOfYear, $today])
            ->groupByRaw('month')
            ->get();
        $months = [];
        for ($month = $startOfYear->copy(); $month->lte($today); $month->addMonth()) {
            $months[$month->format('Ym')] = 0;
        }
        $monthlyData = collect($months)->mapWithKeys(static function ($value, $month) use ($companyData) {
            $matchingData = $companyData->firstWhere('month', $month);
            return [$month => $matchingData->aggregate ?? 0];
        });
        $totalCompanies = $monthlyData->reduce(static function ($carry, $value) {
            $carry[] = ($carry ? end($carry) : 0) + $value;
            return $carry;
        }, []);
        // Calculate percentage increase and increase in companies per month
        $newCompanies = [0];
        $monthlyPercentageChange = [0];
        for ($i = 1, $iMax = count($totalCompanies); $i < $iMax; $i++) {
            $newCompanies[] = $totalCompanies[$i] - $totalCompanies[$i - 1];
            $monthlyPercentageChange[] = ($newCompanies[$i] / $totalCompanies[$i - 1]) * 100;
        }
        $labels = collect($months)->keys()->map(static function ($month) {
            $year = substr($month, 0, 4);
            $monthNumber = substr($month, 4);
            return today()->startOfYear()->setDate($year, $monthNumber, 1)->format('M');
        });
        return [
            'chart' => [
                'type' => 'area',
                'height' => 350,
                'fontFamily' => 'inherit',
                'toolbar' => [
                    'show' => false,
                ],
            ],
            'title' => [
                'text' => 'Cumulative Growth',
                'align' => 'left',
                'margin' => 20,
                'style' => [
                    'fontSize' => '20px',
                ],
            ],
            'subtitle' => [
                'text' => 'Monthly',
                'align' => 'left',
                'margin' => 20,
                'style' => [
                    'fontSize' => '14px',
                ],
            ],
            'series' => [
                [
                    'name' => 'Growth Rate',
                    'data' => $monthlyPercentageChange,
                ],
                [
                    'name' => 'New Companies',
                    'data' => $newCompanies,
                ],
            ],
            'xaxis' => [
                'categories' => $labels,
                'position' => 'bottom',
                'labels' => [
                    'show' => true,
                    'style' => [
                        'colors' => '#9ca3af',
                    ],
                ],
            ],
            'yaxis' => [
                'decimalsInFloat' => 2,
                'labels' => [
                    'style' => [
                        'colors' => '#9ca3af',
                    ],
                ],
            ],
            'dataLabels' => [
                'enabled' => false,
            ],
            'legend' => [
                'show' => true,
                'position' => 'bottom',
                'horizontalAlign' => 'center',
                'floating' => false,
                'labels' => [
                    'useSeriesColors' => true,
                ],
                'markers' => [
                    'width' => 30,
                    'height' => 8,
                    'radius' => 0,
                ],
            ],
            'colors' => ['#454DC8', '#22d3ee'],
            'fill' => [
                'type' => 'gradient',
                'gradient' => [
                    'opacityFrom' => 0.6,
                    'opacityTo' => 0.8,
                ],
            ],
            'markers' => [
                'size' => 4,
                'hover' => [
                    'size' => 7,
                ],
            ],
            'stroke' => [
                'curve' => 'smooth',
            ],
        ];
    }
}
 |