1
0
forked from poc/pds

Added invoice data dashboard page

This commit is contained in:
dhanabalan
2025-10-31 17:45:05 +05:30
parent 3ea3e6519d
commit 3cf34dedb3
2 changed files with 124 additions and 0 deletions

View File

@@ -0,0 +1,111 @@
<?php
namespace App\Filament\Pages;
use App\Filament\Widgets\InvoiceDataChart;
use App\Models\InvoiceDataValidation;
use App\Models\Plant;
use Filament\Pages\Page;
use Filament\Forms\Form;
use Filament\Pages\Dashboard\Concerns\HasFiltersForm;
use Filament\Forms\Components\Select;
use Illuminate\Support\Facades\Auth;
use Filament\Facades\Filament;
use Filament\Forms\Components\Section;
class InvoiceDataDashboard extends Page
{
use HasFiltersForm;
protected static ?string $navigationIcon = 'heroicon-o-document-text';
protected static string $view = 'filament.pages.invoice-data-dashboard';
protected static ?string $navigationGroup = 'Invoice Management';
public function mount(): void
{
session()->forget(['selected_plant','dist_channel']);
$this->filtersForm->fill([
'plant' => null,
'distribution_channel' => null,
]);
}
public function filtersForm(Form $form): Form
{
return $form
->statePath('filters') // Store form state in 'filters'
->schema([
Section::make('')
->schema([
Select::make('plant')
->label('Select Plant')
->reactive()
// ->options(Plant::pluck('name', 'id'))
->options(function (callable $get) {
$userHas = Filament::auth()->user()->plant_id;
return ($userHas && strlen($userHas) > 0) ? Plant::where('id', $userHas)->pluck('name', 'id')->toArray() : Plant::pluck('name', 'id')->toArray();
})
->afterStateUpdated(function ($state,callable $set) {
session(['selected_plant' => $state]);
$set('distribution_channel', null);
session()->forget('distribution_channel');
}),
Select::make('distribution_channel')
->label('Distribution Channel')
->options(function (callable $get) {
$plant = $get('plant');
if (!$plant) {
return [];
}
$options = InvoiceDataValidation::where('plant_id', $plant)
->whereNotNull('distribution_channel_desc')
->where('distribution_channel_desc', '!=', '')
->select('distribution_channel_desc')
->distinct()
->pluck('distribution_channel_desc', 'distribution_channel_desc')
->toArray();
$hasEmpty = InvoiceDataValidation::where('plant_id', $plant)
->where(function ($q) {
$q->whereNull('distribution_channel_desc')
->orWhere('distribution_channel_desc', '');
})
->exists();
if ($hasEmpty) {
$options['Challan'] = 'Challan';
}
return $options;
})
->afterStateUpdated(callback: function ($state,callable $set) {
session(['dist_channel' => $state]);
})
->reactive(),
])
->columns(2),
]);
}
public static function getNavigationLabel(): string
{
return 'Invoice Data Dashboard';
}
public function getHeading(): string
{
return 'Invoice Data Dashboard';
}
public static function canAccess(): bool
{
return Auth::check() && Auth::user()->can('view invoice data dashboard');
}
}

View File

@@ -0,0 +1,13 @@
<x-filament-panels::page>
<div class="space-y-4">
{{-- Render the Select form fields --}}
<div class="space-y-4">
{{ $this->filtersForm($this->form) }}
</div>
{{-- Render the chart widget below the form --}}
<div class="mt-6">
@livewire(\App\Filament\Widgets\InvoiceDataChart::class)
</div>
</div>
</x-filament-panels::page>