Roland Barkóczi
Roland Barkóczi
FFilament
Created by Roland Barkóczi on 12/6/2024 in #❓┊help
test relationmanager CreateAction
Thank you Vp. With your help I managed to write test for the relationmanager like this:
livewire(EventResource\RelationManagers\AttendeeRelationManager::class,
[
'ownerRecord' => $event,
'pageClass' => EventResource\Pages\ViewEvent::class,
])
->assertSuccessful()
->mountTableAction('create')
->assertSee('Create Attendee')
->setTableActionData($attendee->toArray())
->callMountedTableAction()
->assertHasNoActionErrors();
livewire(EventResource\RelationManagers\AttendeeRelationManager::class,
[
'ownerRecord' => $event,
'pageClass' => EventResource\Pages\ViewEvent::class,
])
->assertSuccessful()
->mountTableAction('create')
->assertSee('Create Attendee')
->setTableActionData($attendee->toArray())
->callMountedTableAction()
->assertHasNoActionErrors();
4 replies
FFilament
Created by Roland Barkóczi on 11/24/2024 in #❓┊help
Customize relationManager authorization
Finally figured out : Just redefine the can and canViewForRecord functions in my relationManager classes:
public static function canViewForRecord(Model $ownerRecord, string $pageClass): bool
{
$model = $ownerRecord->{static::getRelationshipName()}()->getQuery()->getModel()::class;
try {
return Gate::forUser(auth()->user())
** ->authorize('viewAny', [$model, $ownerRecord])**
->allowed();
} catch (AuthorizationException $exception) {
return $exception->toResponse()->allowed();
}
}

protected function can(string $action, ?Model $record = null): bool
{
if (static::shouldSkipAuthorization()) {
return true;
}

$model = $this->getTable()->getModel();
$ownerRecord = $this->getOwnerRecord();
try {
return Gate::forUser(auth()->user())
->authorize(
$action,
**[
$record ?? $model,
$ownerRecord
]**
)
->allowed();
} catch (AuthorizationException $exception) {
return $exception->toResponse()->allowed();
}
}
public static function canViewForRecord(Model $ownerRecord, string $pageClass): bool
{
$model = $ownerRecord->{static::getRelationshipName()}()->getQuery()->getModel()::class;
try {
return Gate::forUser(auth()->user())
** ->authorize('viewAny', [$model, $ownerRecord])**
->allowed();
} catch (AuthorizationException $exception) {
return $exception->toResponse()->allowed();
}
}

protected function can(string $action, ?Model $record = null): bool
{
if (static::shouldSkipAuthorization()) {
return true;
}

$model = $this->getTable()->getModel();
$ownerRecord = $this->getOwnerRecord();
try {
return Gate::forUser(auth()->user())
->authorize(
$action,
**[
$record ?? $model,
$ownerRecord
]**
)
->allowed();
} catch (AuthorizationException $exception) {
return $exception->toResponse()->allowed();
}
}
3 replies
FFilament
Created by Roland Barkóczi on 10/31/2024 in #❓┊help
How should I define the exportAction exporter class in order to export hasMany relation?
Hello awcodes, thanks, finally I imploded the prices into one field separated by a pipe, and import back this way. The main problem here, that the getColumns function is static, and it's content can't be change based on options.
5 replies
FFilament
Created by Roland Barkóczi on 10/17/2024 in #❓┊help
How to manage ManyToMany relation in TableBuilder and FormBuilder?
actually the ->default() will show any data in the cell, even if the referenced attribute does not exists
47 replies
FFilament
Created by Roland Barkóczi on 10/17/2024 in #❓┊help
How to manage ManyToMany relation in TableBuilder and FormBuilder?
thanks again for your support!
47 replies
FFilament
Created by Roland Barkóczi on 10/17/2024 in #❓┊help
How to manage ManyToMany relation in TableBuilder and FormBuilder?
actually I use this data model for ages in my legacy e-commerce projects (even not laravel projects)
47 replies
FFilament
Created by Roland Barkóczi on 10/17/2024 in #❓┊help
How to manage ManyToMany relation in TableBuilder and FormBuilder?
the form won't be a problem, I create some fancy component for it
47 replies
FFilament
Created by Roland Barkóczi on 10/17/2024 in #❓┊help
How to manage ManyToMany relation in TableBuilder and FormBuilder?
yeah, use case is expecting here ~20 product/service per vendor
47 replies
FFilament
Created by Roland Barkóczi on 10/17/2024 in #❓┊help
How to manage ManyToMany relation in TableBuilder and FormBuilder?
I gonna debug it, but I gonna figure out some caching these data in a Redis server
47 replies
FFilament
Created by Roland Barkóczi on 10/17/2024 in #❓┊help
How to manage ManyToMany relation in TableBuilder and FormBuilder?
Anyway, awcodes, thank you so much to try to help me. You're great!
47 replies
FFilament
Created by Roland Barkóczi on 10/17/2024 in #❓┊help
How to manage ManyToMany relation in TableBuilder and FormBuilder?
The default() just inject the $record to the callback function. Of course the 'price_1' still not exists therefore it cannot display anything, but in the default() function I can query the necessary data
47 replies
FFilament
Created by Roland Barkóczi on 10/17/2024 in #❓┊help
How to manage ManyToMany relation in TableBuilder and FormBuilder?
No description
47 replies
FFilament
Created by Roland Barkóczi on 10/17/2024 in #❓┊help
How to manage ManyToMany relation in TableBuilder and FormBuilder?
yeah, it's okay.
47 replies
FFilament
Created by Roland Barkóczi on 10/17/2024 in #❓┊help
How to manage ManyToMany relation in TableBuilder and FormBuilder?
yeah, thats the problem. I can query the price if I iterate through the pricelists. My first idea was using the formatStateUsing() but if in case I add a non-existing or empty attribute to the TextColumn::make('xxxx') it shows nothing, and even the formatStateUsing is not called
47 replies
FFilament
Created by Roland Barkóczi on 10/17/2024 in #❓┊help
How to manage ManyToMany relation in TableBuilder and FormBuilder?
No description
47 replies
FFilament
Created by Roland Barkóczi on 10/17/2024 in #❓┊help
How to manage ManyToMany relation in TableBuilder and FormBuilder?
No description
47 replies
FFilament
Created by Roland Barkóczi on 10/17/2024 in #❓┊help
How to manage ManyToMany relation in TableBuilder and FormBuilder?
Sure:
->columns([
TextColumn::make('name')
->label(__('Name'))
->description(fn(Product $record): string => __('Short name') . ": " . $record->short_name . " | " . __('SKU') . ": " . ($record->sku ?? '-')),
TextColumn::make('category.name')
->label(__('Category')),
ToggleColumn::make('is_active')
->label(__('Active'))->toggleable(),
...array_map(
fn(Pricelist $pricelist) =>
TextColumn::make('pricelists.' . $pricelist->id . ".price")
->label($pricelist->name),
$this->getOwnerRecord()->pricelists()->get()->all()
)
])
->columns([
TextColumn::make('name')
->label(__('Name'))
->description(fn(Product $record): string => __('Short name') . ": " . $record->short_name . " | " . __('SKU') . ": " . ($record->sku ?? '-')),
TextColumn::make('category.name')
->label(__('Category')),
ToggleColumn::make('is_active')
->label(__('Active'))->toggleable(),
...array_map(
fn(Pricelist $pricelist) =>
TextColumn::make('pricelists.' . $pricelist->id . ".price")
->label($pricelist->name),
$this->getOwnerRecord()->pricelists()->get()->all()
)
])
47 replies
FFilament
Created by Roland Barkóczi on 10/17/2024 in #❓┊help
How to manage ManyToMany relation in TableBuilder and FormBuilder?
No, because the pivot table connects only these two tables. I can't see any polymorphic behaviour what is described here: https://laravel.com/docs/11.x/eloquent-relationships#many-to-many-polymorphic-relations
47 replies
FFilament
Created by Roland Barkóczi on 10/17/2024 in #❓┊help
How to manage ManyToMany relation in TableBuilder and FormBuilder?
It should be dynamic. I tried, pricelist_2.price but does not work. I want to display somehow the following result in data table:
$product->pricelists()->where('pricelist_id', 2)->first()->pivot->price
$product->pricelists()->where('pricelist_id', 2)->first()->pivot->price
47 replies
FFilament
Created by Roland Barkóczi on 10/17/2024 in #❓┊help
How to manage ManyToMany relation in TableBuilder and FormBuilder?
Hello Awcodes, I think this is a pure many to many relation: Product -> ProductPrice (Pivot) <- PriceList I modified the Product model, and added:
public function pricelists(): BelongsToMany
{
return $this->belongsToMany(Pricelist::class, 'vendor_product_prices', 'product_id', 'pricelist_id')
->withPivot('price');
}
public function pricelists(): BelongsToMany
{
return $this->belongsToMany(Pricelist::class, 'vendor_product_prices', 'product_id', 'pricelist_id')
->withPivot('price');
}
also the Pricelist model:
public function products(): BelongsToMany
{
return $this->belongsToMany(Product::class, 'vendor_product_prices', 'pricelist_id', 'product_id');
}
public function products(): BelongsToMany
{
return $this->belongsToMany(Product::class, 'vendor_product_prices', 'pricelist_id', 'product_id');
}
Question still open: how can I implement The following table:
name | Retail price | Discount price | ... |
---------------------------------------------------
Product 1 | 1000.000. |800.0000. | ....
---------------------------------------------------
Product 2 | 1200.000. |1000.0000. | ....
name | Retail price | Discount price | ... |
---------------------------------------------------
Product 1 | 1000.000. |800.0000. | ....
---------------------------------------------------
Product 2 | 1200.000. |1000.0000. | ....
47 replies