Refactor plant selection options in multiple dashboards to filter by authenticated user's plant ID.
This commit is contained in:
@@ -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]);
|
||||||
|
|||||||
@@ -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]);
|
||||||
|
|||||||
@@ -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) {
|
||||||
|
|||||||
@@ -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]);
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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);
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user