Refactor plant selection options in multiple dashboards to filter by authenticated user's plant ID.

This commit is contained in:
dhanabalan
2025-09-30 14:50:16 +05:30
parent 355ce26475
commit fad5bec0de
6 changed files with 136 additions and 112 deletions

View File

@@ -4,6 +4,7 @@ namespace App\Filament\Pages;
use App\Models\Plant; use App\Models\Plant;
use Filament\Facades\Filament;
use Filament\Forms\Components\Select; use Filament\Forms\Components\Select;
use Filament\Forms\Components\TextInput; use Filament\Forms\Components\TextInput;
use Filament\Forms\Form; use Filament\Forms\Form;
@@ -38,8 +39,12 @@ class InvoiceDashboard extends Page
->statePath('filters') // Explicitly set where to store form data ->statePath('filters') // Explicitly set where to store form data
->schema([ ->schema([
Select::make('plant') Select::make('plant')
->options(Plant::pluck('name', 'id'))
->label('Select Plant') ->label('Select Plant')
//->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();
})
->reactive() ->reactive()
->afterStateUpdated(function ($state) { ->afterStateUpdated(function ($state) {
session(['selec_plant' => $state]); session(['selec_plant' => $state]);

View File

@@ -3,6 +3,7 @@
namespace App\Filament\Pages; namespace App\Filament\Pages;
use App\Models\Plant; use App\Models\Plant;
use Filament\Facades\Filament;
use Filament\Pages\Page; use Filament\Pages\Page;
use Filament\Pages\Dashboard\Concerns\HasFiltersForm; use Filament\Pages\Dashboard\Concerns\HasFiltersForm;
use Filament\Forms\Form; use Filament\Forms\Form;
@@ -35,8 +36,12 @@ class InvoiceQuantityDashboard extends Page
->statePath('filters') // Explicitly set where to store form data ->statePath('filters') // Explicitly set where to store form data
->schema([ ->schema([
Select::make('plant') Select::make('plant')
->options(Plant::pluck('name', 'id'))
->label('Select Plant') ->label('Select Plant')
//->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();
})
->reactive() ->reactive()
->afterStateUpdated(function ($state) { ->afterStateUpdated(function ($state) {
session(['selec_plant' => $state]); session(['selec_plant' => $state]);

View File

@@ -7,6 +7,7 @@ use App\Models\Plant;
use App\Models\ProductionQuantity; use App\Models\ProductionQuantity;
use App\Models\QualityValidation; use App\Models\QualityValidation;
use App\Models\StickerMaster; use App\Models\StickerMaster;
use Filament\Facades\Filament;
use Filament\Forms\Components\Actions; use Filament\Forms\Components\Actions;
use Filament\Forms\Components\Actions\Action; use Filament\Forms\Components\Actions\Action;
use Filament\Forms\Form; use Filament\Forms\Form;
@@ -55,10 +56,14 @@ class ProductionDataSap extends Page implements HasForms
->statePath('data') ->statePath('data')
->schema([ ->schema([
Select::make('plant_id') Select::make('plant_id')
->options(Plant::pluck('name', 'id'))
->label('Plant') ->label('Plant')
->reactive() ->reactive()
->required() ->required()
//->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, $set, callable $get) { ->afterStateUpdated(function ($state, $set, callable $get) {
$plantId = $get('plant_id'); $plantId = $get('plant_id');
if (!$plantId) { if (!$plantId) {

View File

@@ -3,6 +3,7 @@
namespace App\Filament\Pages; namespace App\Filament\Pages;
use App\Models\Plant; use App\Models\Plant;
use Filament\Facades\Filament;
use Filament\Forms\Components\Select; use Filament\Forms\Components\Select;
use Filament\Forms\Components\TextInput; use Filament\Forms\Components\TextInput;
use Filament\Forms\Form; use Filament\Forms\Form;
@@ -38,8 +39,12 @@ class ProductionLineStopCount extends Page
->schema([ ->schema([
Select::make('plant') Select::make('plant')
->options(Plant::pluck('name', 'id'))
->label('Select Plant') ->label('Select Plant')
//->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();
})
->reactive() ->reactive()
->afterStateUpdated(function ($state) { ->afterStateUpdated(function ($state) {
session(['selected_plant' => $state]); session(['selected_plant' => $state]);

View File

@@ -4,6 +4,7 @@ namespace App\Filament\Pages;
use App\Filament\Widgets\TrendChartAnalysis; use App\Filament\Widgets\TrendChartAnalysis;
use App\Models\MfmMeter; use App\Models\MfmMeter;
use Filament\Facades\Filament;
use Filament\Pages\Page; use Filament\Pages\Page;
use Filament\Pages\Dashboard\Concerns\HasFiltersForm; use Filament\Pages\Dashboard\Concerns\HasFiltersForm;
use App\Models\Plant; use App\Models\Plant;
@@ -37,33 +38,36 @@ class TrendChartAnalys extends Page
public function filtersForm(Form $form): Form public function filtersForm(Form $form): Form
{ {
return $form return $form
->statePath('filters') ->statePath('filters')
->schema([ ->schema([
DateTimePicker::make('from_datetime')
DateTimePicker::make('from_datetime') ->label('From DateTime')
->label('From DateTime') ->required()
->required() ->before('to_datetime')
->before('to_datetime') ->reactive()
->reactive() ->afterStateUpdated(function ($state) {
->afterStateUpdated(function ($state) { $formatted = \Carbon\Carbon::parse($state)->format('Y-m-d H:i:s');
$formatted = \Carbon\Carbon::parse($state)->format('Y-m-d H:i:s'); session(['from_datetime' => $formatted]);
session(['from_datetime' => $formatted]); }),
}), DateTimePicker::make('to_datetime')
DateTimePicker::make('to_datetime') ->label('To DateTime')
->label('To DateTime') ->required()
->required() ->after('from_datetime')
->after('from_datetime') ->reactive()
->reactive() ->afterStateUpdated(function ($state) {
->afterStateUpdated(function ($state) { $formatted = \Carbon\Carbon::parse($state)->format('Y-m-d H:i:s');
$formatted = \Carbon\Carbon::parse($state)->format('Y-m-d H:i:s'); session(['to_datetime' => $formatted]);
session(['to_datetime' => $formatted]); }),
}), Select::make('plant')
Select::make('plant') ->label('Select Plant')
->options(Plant::pluck('name', 'id')) ->reactive()
->label('Select Plant') ->required()
->reactive() //->options(Plant::pluck('name', 'id'))
->required() ->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) { ->afterStateUpdated(function ($state, callable $set) {
session(['selected_plant' => $state]); session(['selected_plant' => $state]);
// When plant changes, also reset meter_name // When plant changes, also reset meter_name
@@ -71,37 +75,35 @@ class TrendChartAnalys extends Page
session(['selected_meter' => null]); session(['selected_meter' => null]);
// dd($state); // dd($state);
}), }),
Select::make('meter_name')
Select::make('meter_name') ->options(function ($get) {
->options(function ($get) { $plantId = $get('plant');
$plantId = $get('plant'); // Return meter name/id pairs from mfm_meters where plant_id matches selected plant
// Return meter name/id pairs from mfm_meters where plant_id matches selected plant return $plantId ? MfmMeter::where('plant_id', $plantId)->pluck('name', 'id') : [];
return $plantId ? MfmMeter::where('plant_id', $plantId)->pluck('name', 'id') : []; })
}) ->label('Select Meter')
->label('Select Meter') ->reactive()
->reactive() ->required()
->required() ->afterStateUpdated(function ($state) {
->afterStateUpdated(function ($state) { session(['selected_meter' => $state]);
session(['selected_meter' => $state]); }),
}), Select::make('parameter')
Select::make('parameter') ->options([
->options([ 'Phase Voltage' => 'Phase Voltage',
'Phase Voltage' => 'Phase Voltage', 'Line Voltage' => 'Line Voltage',
'Line Voltage' => 'Line Voltage', 'Current' => 'Current',
'Current' => 'Current', 'Active Power' => 'Active Power',
'Active Power' => 'Active Power', 'Power Factor' => 'Power Factor',
'Power Factor' => 'Power Factor', 'Units' => 'Units',
'Units' => 'Units', ])
]) ->label('Select Parameter')
->label('Select Parameter') ->reactive()
->reactive() ->required()
->required() ->afterStateUpdated(function ($state) {
->afterStateUpdated(function ($state) {
session(['parameter' => $state]); session(['parameter' => $state]);
}), }),
])
]) ->columns(5);
->columns(5);
} }
public static function getNavigationLabel(): string public static function getNavigationLabel(): string

View File

@@ -3,6 +3,7 @@
namespace App\Filament\Pages; namespace App\Filament\Pages;
use App\Filament\Widgets\TrendLineChart; use App\Filament\Widgets\TrendLineChart;
use Filament\Facades\Filament;
use Filament\Pages\Page; use Filament\Pages\Page;
use Filament\Pages\Dashboard\Concerns\HasFiltersForm; use Filament\Pages\Dashboard\Concerns\HasFiltersForm;
use App\Models\Plant; use App\Models\Plant;
@@ -39,66 +40,67 @@ class TrendLineAnalysis extends Page
return $form return $form
->statePath('filters') ->statePath('filters')
->schema([ ->schema([
DateTimePicker::make('from_datetime')
DateTimePicker::make('from_datetime') ->label('From DateTime')
->label('From DateTime') ->required()
->required() ->before('to_datetime')
->before('to_datetime') ->reactive()
->reactive() ->afterStateUpdated(function ($state) {
->afterStateUpdated(function ($state) { $formatted = \Carbon\Carbon::parse($state)->format('Y-m-d H:i:s');
$formatted = \Carbon\Carbon::parse($state)->format('Y-m-d H:i:s'); session(['from_datetime' => $formatted]);
session(['from_datetime' => $formatted]); }),
}), DateTimePicker::make('to_datetime')
DateTimePicker::make('to_datetime') ->label('To DateTime')
->label('To DateTime') ->required()
->required() ->after('from_datetime')
->after('from_datetime') ->reactive()
->reactive() ->afterStateUpdated(function ($state) {
->afterStateUpdated(function ($state) { $formatted = \Carbon\Carbon::parse($state)->format('Y-m-d H:i:s');
$formatted = \Carbon\Carbon::parse($state)->format('Y-m-d H:i:s');
session(['to_datetime' => $formatted]); session(['to_datetime' => $formatted]);
}), }),
Select::make('plant') Select::make('plant')
->options(Plant::pluck('name', 'id')) ->label('Select Plant')
->label('Select Plant') ->reactive()
->reactive() ->required()
->required() //->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) { ->afterStateUpdated(function ($state, callable $set) {
session(['selected_plant' => $state]); session(['selected_plant' => $state]);
// When plant changes, also reset meter_name // When plant changes, also reset meter_name
$set('meter_name', null); $set('meter_name', null);
session(['selected_meter' => null]); session(['selected_meter' => null]);
// dd($state); // dd($state);
}), }),
Select::make('meter_name')
Select::make('meter_name') ->options(function ($get) {
->options(function ($get) { $plantId = $get('plant');
$plantId = $get('plant'); // Return meter name/id pairs from mfm_meters where plant_id matches selected plant
// Return meter name/id pairs from mfm_meters where plant_id matches selected plant return $plantId ? MfmMeter::where('plant_id', $plantId)->pluck('name', 'id') : [];
return $plantId ? MfmMeter::where('plant_id', $plantId)->pluck('name', 'id') : []; })
}) ->label('Select Meter')
->label('Select Meter') ->reactive()
->reactive() ->required()
->required() ->afterStateUpdated(function ($state) {
->afterStateUpdated(function ($state) {
session(['selected_meter' => $state]); session(['selected_meter' => $state]);
}), }),
Select::make('parameter') Select::make('parameter')
->options([ ->options([
'Phase Voltage' => 'Phase Voltage', 'Phase Voltage' => 'Phase Voltage',
'Line Voltage' => 'Line Voltage', 'Line Voltage' => 'Line Voltage',
'Current' => 'Current', 'Current' => 'Current',
'Active Power' => 'Active Power', 'Active Power' => 'Active Power',
'Power Factor' => 'Power Factor', 'Power Factor' => 'Power Factor',
'Units' => 'Units', 'Units' => 'Units',
]) ])
->label('Select Parameter') ->label('Select Parameter')
->reactive() ->reactive()
->required() ->required()
->afterStateUpdated(function ($state) { ->afterStateUpdated(function ($state) {
session(['parameter' => $state]); session(['parameter' => $state]);
}), }),
]) ])
->columns(5); ->columns(5);
} }