-
Notifications
You must be signed in to change notification settings - Fork 465
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
arrange that discards orphans #539
Comments
It is that code that allows sorting in ruby - that is the main issue. It adds ambiguity so the sql query can not properly sort and the tree can not properly come back with pagination. I would like to ask the community what I can change about that feature but know of no good way how to ask the community for what features they need. Since it is difficult to know if the missing nodes are from the previous page, from filtering a Are you thinking about adding a flag that says to drop nodes without a parent? I think we could keep a similar algorithm to do that - but it would not work for pagination or I tried to distinguish the behavior in the specs where the wrong thing happens but it is the best we can do. Also tried to document it so it was clear to all that I did not like the results but again, it was the best that we could do. |
Yes it's certainly a hairy method. I get confused every time I try to read it and understand how it works. Perhaps it's quite efficient, but yes it seems like it's difficult to determine what is a real root node, and what is coming from the subtree. I don't think it's impossible though. The idea would be check if any of the I honestly can't imagine a scenario where pagination with an arranged set of nodes would even make sense. You certainly couldn't ever use a |
ok, so you are focused on this line? arranged[node] = children unless node_ids.include?(node.parent_id) It says that this is a root if this node is not a child of a node already represented in another tree in this result set. Really need to find a way to properly sort nodes based upon a numerical form of the ancestor ids. Well, that and join on those ids rather than splitting them up in ruby before they are usable. I tend to be more postgres centric - so the array or the ltree datatypes interest me, but I'm sure mysql and others have an equally interesting way to expose that data in a reasonable way. Going the join table route like closure_trees is one solution, but there are other ways of having a sql accessible mechanism for those keys stored in the primary table. Also this whole iso/internationalization effort has rendered the indexes on the field useless in many ways. For our purposes, an old school cstring array will index and search much easier than a unicode friendly field. This gem was definitely designed before iso was taken into account. |
Sounds like you're having an existential crisis! :D I definitely think there's room here for a new library that does both parentage and ordering within, and does it well. On the ordering front, being the maintainer of Anywho, with regards to the
We can do this based on the What do you think? |
yup The code only looks at I agree that the interface for displaying a second page for a tree is not that straight forward. In this case, simply displaying But as you joked before, I am considering gutting most of this and going a more native rails friendly route. Implementing a serialization routine to add slashes and remove them at the model layer may have made sense in rails 2 but it is getting in my way. Just having trouble knowing that everyone expects |
Hehe, yea avoid that green field. You'll never get out! I think there's probably a decent upgrade path where you keep your old serialisation logic, but work in options for storing the materialised ancestry as a An idea for finding out what people need is to add a post-install message to the gem pointing people at some kind of discussion forum where you lay out your proposals for the future. Then give it a few months to see what comes out of the woodwork. |
Hi @kbrock,
I was wondering if there was appetite for altering the
arrange
method to allow for an option to drop orphans instead of promoting them to root nodes?The use case is for when we select a part of a tree, and then also have conditions that remove some intermediate nodes but not their descendants.
The text was updated successfully, but these errors were encountered: