-
Notifications
You must be signed in to change notification settings - Fork 382
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Model extending and attributes #1939
Comments
Things seem got buggy after upgrading from the last Alpha version to first Beta version. Like you I also extended the product class to add custom scopes. I lookup every table and change |
I've experienced this to. The getMorphClass method in This is how it worked in the last alpha.37 public function getMorphClass(): string
{
$morphClass = ModelManifest::getMorphClassBaseModel(get_class($this));
return $this->morphClass ?: ($morphClass ?? parent::getMorphClass());
} Currently there is no getMorphClass and it uses the Laravel default way on the model. It seems we can now utilize the default Laravel way to handle the morph map https://laravel.com/docs/11.x/eloquent-relationships#custom-polymorphic-types So for now, I think the best way to handle this to is define your own morph map for the models: Relation::enforceMorphMap([
'product' => \Lunar\Models\Product::class,
'product_variant' => \Lunar\Models\ProductVariant::class,
'product_option' => \Lunar\Models\ProductOption::class,
'product_option_value' => \Lunar\Models\ProductOptionValue::class,
'collection' => \Lunar\Models\Collection::class,
'customer' => \Lunar\Models\Customer::class,
'cart' => \Lunar\Models\Cart::class,
'cart_line' => \Lunar\Models\CartLine::class,
'order' => \Lunar\Models\Order::class,
'order_line' => \Lunar\Models\OrderLine::class,
]); If you extend the Lunar models you should also add the morphClass to the extended model, for example: <?php
namespace App\Models;
class Cart extends \Lunar\Models\Cart
{
public function getMorphClass(): string
{
return 'cart';
}
} |
@ryanmitchell Are able to test against the latest merge #1944 to see if this fixes the problem for you? 🙏 |
@alecritson I've since updated all the data to point to our model class paths, so I can't verify it I'm afraid. |
the next release which fixed this in #1944 might break your app, you need to revert the data back to the relationship alias |
Expected Behaviour:
When using model extending attributes would still be available on the product and product variant view.
Actual Behaviour:
When you go to the views the are no attributes.
Steps To Reproduce:
Set up lunar, set up an attribute, then after extend your model.
Internally Lunar is using product and product_variant to look them up, which no longer links with extending. When I switch them manually in the database to be \App\Models\Product (etc) they return, except that if I change them all I get no attributes as there is obviously a check somewhere to only display if there are any.
I would have expected that product and product_variant attributes were maintained.
The text was updated successfully, but these errors were encountered: