Skip to content
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

Fix error in collection deletion #2110

Draft
wants to merge 1 commit into
base: 1.x
Choose a base branch
from

Conversation

glennjacobs
Copy link
Contributor

When deleting a collection that has child collections in the admin panel, it will error. I believe this is because the child-collections attempt to be removed by nestedset, but their associated customer groups etc are not being removed.

The simplest and safest approach might be to simply not allow the deletion of collections if they have child collections.

This PR introduces a quick solution for that, but there may be a nicer way.

Copy link

vercel bot commented Feb 14, 2025

The latest updates on your projects. Learn more about Vercel for Git ↗︎

Name Status Preview Comments Updated (UTC)
lunar-docs ✅ Ready (Inspect) Visit Preview 💬 Add feedback Feb 14, 2025 6:17pm

@wychoong
Copy link
Contributor

wychoong commented Apr 2, 2025

this is because the child-collections attempt to be removed by nestedset, but their associated customer groups etc are not being removed.

getting this error when try to delete a collection with childs

> Collection::whereIn('id', [21])->get()->each->delete()

   Illuminate\Database\QueryException  SQLSTATE[23000]: Integrity constraint violation: 14
51 Cannot delete or update a parent row: a foreign key constraint fails (`ems_klef`.`lunar
_collection_customer_group`, CONSTRAINT `lunar_collection_customer_group_collection_id_for
eign` FOREIGN KEY (`collection_id`) REFERENCES `lunar_collections` (`id`)) (Connection: ma
riadb, SQL: delete from `lunar_collections` where (`lunar_collections`.`collection_group_i
d` = 1 and `lunar_collections`.`_lft` between 67 and 71) and `lunar_collections`.`collecti
on_group_id` = 1).

since now we already have Collection observer to cleanup the related customerGroups, discounts, etc.
we might just need to override the deleteDescendants method to $this->descendants->each->delete() the child model instead of delete by query $this->descendants()->delete()

https://github.com/lazychaser/laravel-nestedset/blob/fa3f77bb96709eb6b394f66b54eb08f0d8d47d63/src/NodeTrait.php#L622-L643

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants