Updating Data โ
This section covers validating and updating in your Table Component. Here you will find:
Introduction โ
Some PowerGrid features like Toggleable and Edit On Click provide a quick way to edit and update data directly from the grid.
On this page, you can find information on handling, processing, validating, and update data coming from the user input via.
Toggleable Switch โ
Data submitted by the user via a Toggleable switch will be handled by the method onUpdatedToggleable()
.
To update your records, you must create a method onUpdatedToggleable()
in your Table Component. This method will receive the parameters string|int
$id
, string
$field
, and string
$value
.
Using those parameters, you will have access to the record's primary key, the field being updated, and the value submitted, so you can perform an update operation.
// app/Livewire/DishTable.php
use PowerComponents\LivewirePowerGrid\PowerGridComponent;
use App\Models\Dish;
class DishTable extends PowerGridComponent
{
public function onUpdatedToggleable(string|int $id, string $field, string $value): void
{
Dish::query()->find($id)->update([
$field => e($value),
]);
}
}
๐ See it in action
See an interactive example of Saving Toggleable Data.
Edit On Click โ
Data submitted by the user via Edit On Click will be handled by the method onUpdatedEditable()
.
To update your records, you must create a method onUpdatedEditable()
in your Table Component. This method will receive the parameters string|int
$id
, string
$field
, and string
$value
.
Using those parameters, you will have access to the record's primary key, the field being updated, and the value submitted, so you can perform an update operation.
Example:
// app/Livewire/DishTable.php
use PowerComponents\LivewirePowerGrid\PowerGridComponent;
use App\Models\Dish;
class DishTable extends PowerGridComponent
{
public function onUpdatedEditable(string|int $id, string $field, string $value): void
{
Dish::query()->find($id)->update([
$field => e($value),
]);
}
}
โ WARNING
For security reasons, data input must be escaped and validated before it is stored in the database.
It's highly recommended to use Laravel's e() helper
and Livewire Validation when dealing with user input.
๐ See it in action
See an interactive example of Saving Edit On Click Data.
Updating Custom Fields โ
When using Custom Fields, most likely the field name in the $field
variable will not match your database column name.
Since you probably have formatted the data, the data received in the $value
variable will not match your column data type.
To update Custom Fields, you must first "catch" the custom field name, override it with the original field name, and then, most likely, reverted its data formatting.
The next example demonstrates handling data from a formatted currency input (E.g, 10.000,00 $) to be saved in a double
database field (E.g, 10000.00).
// app/Livewire/DishTable.php
use PowerComponents\LivewirePowerGrid\PowerGridComponent;
use App\Models\Dish;
class DishTable extends PowerGridComponent
{
public function onUpdatedEditable(string|int $id, string $field, string $value): void
{
//Catch the "price_formatted" field
if ($field === 'price_formatted') {
//Override the field
$field = 'price';
// Parse the value
// 10.000,00 $ => 10000.00
$value = str($value)->replace('.', '')
->replace(',', '.')
->replaceMatches('/[^Z0-9\.]/', '')
->toString();
}
Dish::query()->find($id)->update([
$field => e($value),
]);
}
}
The field price_formatted
, which the $value
is formatted currency (E.g, 10.000,00 $). The formatted string will be reverted to 10000.00
, for a double
database column. Moreover, note that the parameter $field
is set to price
, which is the database column to be updated.
Reload Data on Update โ
You may call the method $this->fillData()
to reload data after a successful update.
Example:
// app/Livewire/DishTable.php
use PowerComponents\LivewirePowerGrid\PowerGridComponent;
use App\Models\Dish;
class DishTable extends PowerGridComponent
{
public function onUpdatedEditable(string|int $id, string $field, string $value): void
{
$updated = Dish::query()->find($id)->update([
$field => e($value),
]);
if ($updated) {
$this->fillData();
}
}
}
Reload Data from External Component โ
A web application might have other components that interact with the data displayed in your grid, requiring you to refresh your Table after an update has occurred.
In order to refresh the data, first you must set a unique Table Name for your Component.
Then, you can dispatch the event pg:eventRefresh-YourTableName
within your component to refresh your Table.
Example:
namespace App\Livewire;
use Livewire\Component;
class SomeComponent extends Component
{
public function save()
{
//... some code ...
$this->dispatch('pg:eventRefresh-DishTable');
}
}
Skip Reload After Update โ
You may use Livewire's Skipping re-renders functionality by calling the method $this->skipRender()
after the update.
Example:
// app/Livewire/DishTable.php
use PowerComponents\LivewirePowerGrid\PowerGridComponent;
use App\Models\Dish;
class DishTable extends PowerGridComponent
{
public function onUpdatedToggleable($id, $field, $value): void
{
Dish::query()->where('id', $id)->update([
$field => $value,
]);
$this->skipRender();
}
}
Data Validation โ
PowerGrid Table Components can use the Livewire Validation feature to validate inputted data.
Just add a call to $this->validate()
inside the onUpdatedEditable()
or onUpdatedToggleable()
methods.
Example:
// app/Livewire/DishTable.php
use PowerComponents\LivewirePowerGrid\PowerGridComponent;
use App\Models\Dish;
class DishTable extends PowerGridComponent
{
public function rules()
{
return [
'name.*' => ['required', 'alpha', 'max:130'],
];
}
public function onUpdatedEditable(string|int $id, string $field, string $value): void
{
$this->validate();
Dish::query()->find($id)->update([
$field => e($value),
]);
}
}
๐ See it in action
See an interactive example using Data Validation in PowerGrid.
Custom Field Validation โ
If you are rendering a Blade component via a Custom Fields, you may share your Validation Errors as exemplified below:
// app/Livewire/DishTable.php
use PowerComponents\LivewirePowerGrid\PowerGrid;
use PowerComponents\LivewirePowerGrid\PowerGridFields;
use PowerComponents\LivewirePowerGrid\PowerGridComponent;
use Illuminate\Support\Facades\Blade;
class DishTable extends PowerGridComponent
{
public bool $showErrorBag = true;
public function fields(): PowerGridFields
{
return PowerGrid::fields()
->add('id')
->add('dish_review', function ($dish) {
$error = isset($this->getErrorBag()->getMessages()['dish_review.'.$dish->id])
? $this->getErrorBag()->getMessages()['dish_review.'.$dish->id][0]
: null;
return Blade::render('<x-editable :id="'.$dish->id.'" errors="'.$error.'" />');
});
}
}
The Blade component may look something like this:
// app/View/Components/Editable.php
@props([
'id' => null,
'errors' => null
])
<div>
<input wire:model="dish_review.{{ $id }}" type="text" class="form-control" placeholder="Enter your review">
@if($errors)
<div class="text-red-800">
{!! $errors !!}
</div>
@endif
</div>