disabled select option multiple value base on status from db
I have Select Option Its Disabled Option value when status by id is sold
Select::make('batch_id')
->required()
->relationship('batch_faktur_pajak', 'batch')
->options(BatchFakturPajak::all()->pluck('batch', 'id'))
->live(debounce: 1500)
->disableOptionWhen(function ($value) {
$get_status = BatchFakturPajak::where('status', '=', 'sold')->get();
foreach ($get_status as $status) {
if ($status->id == $value) {
return true;
} else {
return false;
}
}
})
i have 10 and 20 value bot sold status
but On Select It Disabled Only 10
i know because it return bool but i dkw how to fix that
data:image/s3,"s3://crabby-images/75a4d/75a4dfb04965c1f7e680ea11656617b14ce19ec7" alt="No description"
data:image/s3,"s3://crabby-images/1827b/1827b6543966644147d0035d62496e4fad2315b5" alt="No description"
8 Replies
Sth like this, but not tested
data:image/s3,"s3://crabby-images/7f6a5/7f6a516a6770a7dd1a1c11f8a717969f698dfa4b" alt="No description"
Yeah I didn't test π Anyway why don't you query only (! sold) in relationship like this
Then you can remove
options()
and disableOptionWhen()
ya this will work
but i wanna to see history batch value
solved btw with u suggest and little modification
->disableOptionWhen(function (int $value) {
$get_status = BatchFakturPajak::where('status', 'sold')->get('id')->toArray();
return collect($get_status)
->contains(function (array $val, int $key) use ($value) {
return $val['id'] == $value;
});
})
data:image/s3,"s3://crabby-images/8ec07/8ec07ea3a69b41d18c5995dfe22fad514d5ed412" alt="No description"
thx u bro
π
You're welcome. btw you can reduce your code like this
damn that cool
thx u bro π