-
Notifications
You must be signed in to change notification settings - Fork 39
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
mptt tree support for content items #45
Comments
Can you explain a bit more about the types of content items and how they would be nested? I was also looking for a way to add pages which have their own tree of sub-content nodes, but not necessarily content items. The sub-content nodes are more likely to be sub-pages, but I don't want to manage all the sub-pages from the main page tree change list along with all other pages. I want to work with just the tree of sub-pages for a given page. I know that I assume it might be possible to implement this via filtering on the |
"Can you explain a bit more about the types of content items and how they would be nested?" I think of famo.us pages - there are transform ( modifier ) nodes which can contain surface subnodes ( and again transform/modifier subnodes ). Transform modifiers in famo.us can move html subnodes, rotate them etc. so transform is just a 'pivot' placement point - and following nodes can be positioned relative to higher transform so I plan to have 'transform node' ContentItem and various specialised famo.us surfaces wrapped as ContentItems ( in famo.us surfaces are in fact plain divs which can be filled with any valid html, but which can be freely placed/moved in any position on the page - that is where power of assembling trees can be very useful). to output those ContentItems to pages would be relatively easy - there will be just call to famo.us add ( in plain famo.us ) in placeholder ( just almost the same way items are iterated for output in placeholder ) or call to output open 'braket' then output html for inner ContentItems, then call stack with closing brackets backward providing closing brackets to html output. edit June 5,2015: one approach might be to have two/multiple admin views for page(s) - one which is like current, the other view is tailored to bringing sub blocks into tree. That might be not only for famo.us surfaces, but for relative positioning of divs/html elements as well |
Hi! sorry for not getting into this discussion before!
But please, go ahead on this idea! Note, making backward incompatible changes would validate a 2.0 release with many other changes. Some of my idea's include: convert all bundled plugins to separate packages, have frontend editing support (via a different package!), and optionally let the backend look more like a preview, where you can select the item to change. FYI, workarounds and design patterns that I typically use are:
Note how this allows users to select the "theme" or "style" of an item, while the designer still has full control over the layout. |
Thanks for reply, I will try to get deeper into provided information later |
also - to share thoughts: maybe this approach might be used in django-fluent besides tree of page elements another way to ease admin page is to have a checkbox to 'collapse' all items on the page ( so all plugin objects look like entries on the bottom of the page ( like 'publication settings'). Having this feature, the user can concentrate his attention on editing just one item object |
FYI, I'll be working on this feature in the coming weeks - as modern web design requires it! (first work is now in feature/container-items (https://github.com/edoburu/django-fluent-contents/tree/feature/container-items) @ abfa2bb) |
Great to hear, rather currently I use polymorphic inlines to build top level nodes ( say rows ) then those rows have polymorphic links to sub nodes , which in turn could have polymorphic inlines with subnodes. database heavy approach though |
@Kurdakov: having a global "structure" view would be nice to have, though it's not my first focus. The backend support seams rather complete, but I'm still struggling with time to improve the admin-javascript interface. If you could pick some parts of this up, I'd be delighted! |
@vdboor good news. as for help have some crunch-time here and seems it's for long. don't know when I have spare time any time soon. sorry |
@vdboor still I'm open to help, just - can we speak in skype or google hangouts? there are a lot of details which we might resolve and then I could help? |
@Kurdakov I completely missed this mention. If you're still interested, please send me your email address and I'll invite you to the slack channel (https://django-fluent.slack.com/signup) |
The task I'm working on naturally leads me to desire to have nested content items.
It is not difficult to change base class for
class ContentItemMetaClass(PolymorphicMPTTModelBase)
and
class ContentItem(with_metaclass(ContentItemMetaClass, CachedModelMixin, PolymorphicMPTTModel))
but then there is a problem to set relationship between page's contentitems in admin
also, MPTTModel adds it's own 'parent' field so there is either need to completely replace ContentItem placeholder parent field or to combine this field with mpttmodel parent field so that
mptt parent field is used to track tree relations of ContentItems for output for real world page and placeholder parent field is used to keep admin page presentation of ContentItem blocks )
after combining placeholder field mptt parent field also appears in ContentItemForm in admin page, but apparently without additional efforts is non-funtional such that mptt works as usual linear container for ContainerItems
And I have a question to the author, if he considers viable addition of tree relationships to ContentItems and how he would approach setting root node for the page and setting specific relations between ContenItems via setting parents for ContenItems using 'mptt parent' drop down which appears in admin blocks ( maybe providing queryset to dropdown which consists of all objects in given placeholder )
As a first attempt
I tried to add children to 'root' tree content Items via form ModelMultipleChoiceField by adding to derived Form from ContentItemForm
with lines like
localchildren = forms.ModelMultipleChoiceField(widget=FilteredSelectMultiple("Children", is_stacked=False),queryset= ...)
but failed to find a way to pass to Form required queryset which could consist of ContentItems in current placeholder and which could allow to build trees manually from selected data
(edit: one afterthought here is that the solution would be easier if there was way to connect model and form directly in content plugin code )
But still seems setting mptt parent to ContentItem via autogenerated ContentItemForm field might provide a relatively easy way to build a tree of ContentItems -
the question is - how better to approach this task.
The text was updated successfully, but these errors were encountered: