platform icon indicating copy to clipboard operation
platform copied to clipboard

`getContent()` returns Array instead of Collection or Model when eager loading relations

Open JeremieSchelb opened this issue 1 year ago • 1 comments

Describe the bug When a relation is eager-loaded, the getContent() method from the Orchid\Screen\AsSource trait returns an array instead of a collection or model.

To Reproduce Steps to reproduce the behavior:

  1. Eager load a relation (in either the Resource class or the Model class).
  2. In Tinker, call YourModel::first()->getContent('relationName').

Expected behavior The getContent() method should return a Collection or Model for consistency, especially when using it in a cell component with usingComponent().

Is there a specific reason for prioritizing an array return?

public function getContent(string $field)
{
    return Arr::get($this->toArray(), $field) // Try to get the field value from the object's array representation.
        ?? Arr::get($this->getRelations(), $field) // Try to get the field value from the object's relations.
        ?? $this->getAttribute($field);  // Try to get the field value from the object's attributes.
}

Server (please complete the following information):

  • Platform Version: 14.25.3
  • Laravel Version: 11.2.0
  • PHP Version: 8.3.10
  • Database: MariaDB
  • Database Version: 10.4

JeremieSchelb avatar Aug 15 '24 15:08 JeremieSchelb

I believe this is related to the dot notation, but I'm open to suggestions if you'd like to improve this behavior.

tabuna avatar Aug 29 '24 22:08 tabuna