Forums / Developer / Dynamic Content Stucture menu (AJAX) prototype

Dynamic Content Stucture menu (AJAX) prototype

Author Message

Kristian Hole

Wednesday 05 October 2005 7:04:26 am

Thanks Bertrand.

I agree that AJAX technology is cool, it should be used with some moderation... But for the contentstructuremenu its perfect.

The good news is that our friends at VisionWT has actually improved the menu, and hopefully their improvements will go into the extension it self in the near future. I'm quite curious to see what fun they have done :-)

About the timeout. I have just set the timeout to 2 seconds inorder to test it.. This should probably be raised to 10 or 30 seconds... To test it you can increase the value in the "startTimeout" function of csm_aj.js

Kristian

http://ez.no/ez_publish/documenta...tricks/show_which_templates_are_used
http://ez.no/doc/ez_publish/techn...te_operators/miscellaneous/attribute

Bertrand Dunogier

Wednesday 05 October 2005 7:11:40 am

Thanks for the infos; I have tried the SVN version, thanks for the icons ;)

Regarding AJAX for web interfaces, in my opinion it could become the future of admin interfaces. It will be great for frontend sites for forms validation, complex search forms or remote information fetching.

A full AJAX interface for ezp would be amazing but not tomorrow ;)

Gabriel Ambuehl

Wednesday 05 October 2005 11:34:49 am

Yeah, icons and context menu work nicely.

One thing makes it look kinda ad hoc though: the chars used to represent the tree (ie + and -) aren't all of the same size and thus not in the same place. It would likely be better to use images for that, no?

(Personally, I rather like the arrow stuff with > and it's downward cousin, think OSX)

Visit http://triligon.org

Bertrand Dunogier

Wednesday 05 October 2005 1:30:39 pm

I think it would be better to just keep the design of the standard content structure menu.

Gabriel Ambuehl

Wednesday 05 October 2005 1:32:39 pm

Which realistically could still be improved upon, no?

Visit http://triligon.org

Frederik Holljen

Wednesday 05 October 2005 11:39:11 pm

There is always room for improvement. If you have any good ideas: shoot :)

Realistically, I'm not certain if an AJAX menu is _the_ sollution since it will generate more requests and the total amount of data transfer will increase. Obviously some of you have been running this, what are your performance experiences with the menu? (how many simultaneous users?)

Gabriel Ambuehl

Thursday 06 October 2005 12:29:11 am

I'd say it should fetch a certain number of levels at the same time, then reload if needed.

With the same argument, the current menu creates a lot of unused traffic and server load for sites with many pages ;)

Visit http://triligon.org

Bertrand Dunogier

Thursday 06 October 2005 12:39:30 am

Unfortunately I have to agree on the multiple server hits for the menu, Frederik. It is clear that it will generate more requests, but on the other hand less data is transfered by default from the server to the client, which reduces the file size and the resource usage for the browser.

I know for instance that I often have to disable the content structure menu on big sites due to the browser getting slow (yes, I should limit the display of nodes with lots of children ^^).

To Gabriel: your answer came while I was writing mine. I see we agree ;)

On a project i'm currently working on, the default admin page is 538 KB with the menu displayed, and 58 KB when it's hidden... almost 90% is for the menu, so in my opinion something HAS to be done.

Regarding AJAX usage in general, I agree that the resource question is relevant when talking about the tree menu, but if you think far ahead and try to imagine a full AJAX interface, the advantages of such an approach are huge, even for the server... you only request the block you need (like the middle block with preview and stuff... when you enable / disable preview or locations or anything, it just gets fetched from the server and added at its location. The children list is not reloaded, nor is the content tree...

Finally, another though regarding the content tree: something similar to bookmarks could be implemented. Most users visit on a regular basis a maximum of 8 to 10 nodes. Maybe these nodes could be loaded by default in the menu in order to limit the number of requests to the server ?

Frederik Holljen

Thursday 06 October 2005 1:11:02 am

Unfortunately I have to agree on the multiple server hits for the menu, Frederik. It is clear that it will generate more requests, but on the other hand less data is transfered by default from the server to the client, which reduces the file size and the resource usage for the browser.
 
 I know for instance that I often have to disable the content structure menu on big sites due to the browser getting slow (yes, I should limit the display of nodes with lots of children ^^).

On a project i'm currently working on, the default admin page is 538 KB with the menu displayed, and 58 KB when it's hidden... almost 90% is for the menu, so in my opinion something HAS to be done.

Of course, but now you are comparing with a menu that is already too big and which should be stripped.
I think you are right about the server load though. If we can implement the ajax menu in such a way that in can cache menu data between requests we can probably make it much more efficient than the current menu.

Regarding AJAX usage in general, I agree that the resource question is relevant when talking about the tree menu, but if you think far ahead and try to imagine a full AJAX interface, the advantages of such an approach are huge, even for the server... you only request the block you need (like the middle block with preview and stuff... when you enable / disable preview or locations or anything, it just gets fetched from the server and added at its location. The children list is not reloaded, nor is the content tree... 

There are a couple of challenges: Sometimes you need to update more than one of the parts. This can even depend on the contents of the new part you are loading. Sometimes some of the parts change behavior according to the changes in other parts. In other words, if you implement a full AJAX admin you need to actually program all of this logic instead of just having it in HTML templates like now. Another interresting issue is writing extensions that should plug into the administration interface, they also need to work with this. And of course most of the time you would like to use the functionality the administration interface provides outside of the AJAX admin. So you would need to support both also for people who don't have all the javascript capabilities.

 Finally, another though regarding the content tree: something similar to bookmarks could be implemented. Most users visit on a regular basis a maximum of 8 to 10 nodes. Maybe these nodes could be loaded by default in the menu in order to limit the number of requests to the server ?

Hmm.. isn't this what the bookmarks do already?

Bertrand Dunogier

Thursday 06 October 2005 1:27:24 am

Hmm.. isn't this what the bookmarks do already?

It was just a suggestion in order to limit the number of server requests using the ajax menu: somewhat store IDs of nodes frequently visited in the tree, and automatically load them in the menu.

Regarding the complexity of a full AJAX interface, I can only agree with you ;) As I said, it was "seeing far far ahead in the future". It would definitely require a whole new approach, and there is indeed a big risk of increased update complexity and lack of reusability. Honnestly, this is a really huge topic, and definitely worth investigation.
Parts of the administration interface could for instance be splitted in reusable blocks that would be used for both AJAX and non-AJAX interfaces. Of course big code pieces would only be used in one interface, but reusability is not a big no here.
Regarding extensions, such a feature would definitely require an AJAX library that would let developers provide a uniform implementation of the interface. Another eZ PHP Component ? :)

Frederik Holljen

Thursday 06 October 2005 1:32:20 am

Parts of the administration interface could for instance be splitted in reusable blocks that would be used for both AJAX and non-AJAX interfaces. Of course big code pieces would only be used in one interface, but reusability is not a big no here.

We are probably going to introduce "widgets" in eZ publish 4.0 which will do exactly this. So in some way we are going in the right direction already.

Another eZ PHP Component ? :)

If implemented, definitely :)

Daniele P.

Thursday 06 October 2005 1:34:16 am

On a project i'm currently working on, the default admin page is 538 KB with the menu displayed, and 58 KB when it's hidden... almost 90% is for the menu, so in my opinion something HAS to be done.

with ob_gzhandler, mod_deflate or mod_gzip you can compress the eZ publish standard output for the admin interface to 1/10 or less of the inital size. I filled a bug report a long time ago regarding this question but nobody cares.
Output compression is mandatory to have a usable admin interface over internet connection.

Bertrand Dunogier

Thursday 06 October 2005 1:42:33 am

Daniele, indeed you are right about that. But I also know that such a page size is somewhat hurting my browser, so it's not just about transfer size, but it would already be a big improvement if that was properly handled.

About your widgets thing, Frederik: great :)

As far as I can see based on new projects, AJAX is the next big thing in web applications interfaces, and it would probably be a mistake if eZ was not considering that... but since you are always keeping at the top of new technologies, I'm pretty confident ;)

Gabriel Ambuehl

Thursday 06 October 2005 2:13:36 am

IMHO, the correct way to COMPRESS the data is on Apache's level. It's not so much an eZpublish issue but one of proper Apache config.

But as said, it doesn't really solve the issues with giant pages taking ages to render in browsers (not using Firefox but Opera or Konqueror could help there but those lack support for WYSIWYG editors :().

A more generalized way to do AJAX within eZpublish would obviously be greatly appreciated ;)

Visit http://triligon.org

Daniele P.

Thursday 06 October 2005 3:12:14 am

> A more generalized way to do AJAX within eZpublish would obviously be greatly appreciated ;)

Yes, I agree, the compress method is a workaround, ajax solution is the right solution. We are waiting for it to become the real solution.

Kristian Hole

Friday 07 October 2005 9:43:29 am

@Gabriel: The menu should offcourse look like the normal menu. I just used the + and - letters for simplicity.

AJAX indeed brings some cool stuff. But what happens if the networkconnection is slow or faulty and the extra complexity really have to be considered.

On the long run, i think eZ publish will benefit from using AJAX technology, and i predict we will see some thing like this in eZ publish in the long run... Don't be shoot me mister productmanager Frederik ;-)

Kristian

http://ez.no/ez_publish/documenta...tricks/show_which_templates_are_used
http://ez.no/doc/ez_publish/techn...te_operators/miscellaneous/attribute

Kristian Hole

Friday 07 October 2005 9:50:36 am

And about the : Only show the elements which are bookmarked. This is pure _evil_! This is the same as Microsoft has been doing for Office for some years, and i really hate it!

This is just my 50 norwegian øre (equivalent of 50cent only worth a bit less ;-) )

Kristian

http://ez.no/ez_publish/documenta...tricks/show_which_templates_are_used
http://ez.no/doc/ez_publish/techn...te_operators/miscellaneous/attribute

Bertrand Dunogier

Sunday 09 October 2005 11:52:46 pm

No no no Kristian, the bookmark thing was not to SHOW the bookmarked items, it was to automatically load the bookmarked items ;)

The idea is just here to limit the number of requests used to load the default menu. If something is bookmarked, it is automatically loaded in the menu, that's all. Any non bookmarked stuff could still be opened by clicking your nice little pluses or arrows or whatever :)

Gabriel Ambuehl

Monday 10 October 2005 12:28:41 am

Well if the network connection is spotty, the current admin interface will be a pain to use as well.

But a real world example: I got a site with about 50 pages and about 200 forum posts (which is very little by my standards for a forum) but already, with 250 objects, loading up the standard admin interface becomes nearly unbearable so I think I'll install the dhtml menu soon. Of course I might also try to figure out how to exclude forums from the dynamic menu ;)

Visit http://triligon.org

Kristian Hole

Monday 10 October 2005 6:06:35 am

Ahh.. that makes much more sence Bertrand :-)

But like the menu says: "Content structure". This means it should only show the structure, for example only folders. This is done the same way in for example Windows Explorer, which shows the folders on the left side, and the content in the right side. Thats why i think it would be better if the normal eZp installation only showed folders, and other classes that are used to group information, and not for example articles (That was a long sentance..)

Kristian

http://ez.no/ez_publish/documenta...tricks/show_which_templates_are_used
http://ez.no/doc/ez_publish/techn...te_operators/miscellaneous/attribute

eZ debug

Timing: Jan 15 2025 06:54:24
Script start
Timing: Jan 15 2025 06:54:24
Module start 'content'
Timing: Jan 15 2025 06:54:24
Module end 'content'
Timing: Jan 15 2025 06:54:24
Script end

Main resources:

Total runtime0.1770 sec
Peak memory usage6,144.0000 KB
Database Queries134

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0064 686.3750214.7734
Module start 'content' 0.00640.0066 901.1484217.8750
Module end 'content' 0.01290.1639 1,119.02341,506.7891
Script end 0.1769  2,625.8125 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00653.6858200.0003
Check MTime0.00140.7806200.0001
Mysql Total
Database connection0.00080.474110.0008
Mysqli_queries0.126971.73231340.0009
Looping result0.00110.63591310.0000
Template Total0.163392.310.1633
Template load0.00271.498110.0027
Template processing0.160690.758810.1606
Override
Cache load0.00231.324010.0023
Sytem overhead
Fetch class attribute can translate value0.00080.474710.0008
XML
Image XML parsing0.00030.180810.0003
General
dbfile0.00181.0210140.0001
String conversion0.00000.003530.0000
Note: percentages do not add up to 100% because some accumulators overlap

CSS/JS files loaded with "ezjscPacker" during request:

CacheTypePacklevelSourceFiles
CSS0extension/community/design/community/stylesheets/ext/jquery.autocomplete.css
extension/community_design/design/suncana/stylesheets/scrollbars.css
extension/community_design/design/suncana/stylesheets/tabs.css
extension/community_design/design/suncana/stylesheets/roadmap.css
extension/community_design/design/suncana/stylesheets/content.css
extension/community_design/design/suncana/stylesheets/star-rating.css
extension/community_design/design/suncana/stylesheets/syntax_and_custom_tags.css
extension/community_design/design/suncana/stylesheets/buttons.css
extension/community_design/design/suncana/stylesheets/tweetbox.css
extension/community_design/design/suncana/stylesheets/jquery.fancybox-1.3.4.css
extension/bcsmoothgallery/design/standard/stylesheets/magnific-popup.css
extension/sevenx/design/simple/stylesheets/star_rating.css
extension/sevenx/design/simple/stylesheets/libs/fontawesome/css/all.min.css
extension/sevenx/design/simple/stylesheets/main.v02.css
extension/sevenx/design/simple/stylesheets/main.v02.res.css
JS0extension/ezjscore/design/standard/lib/yui/3.17.2/build/yui/yui-min.js
extension/ezjscore/design/standard/javascript/jquery-3.7.0.min.js
extension/community_design/design/suncana/javascript/jquery.ui.core.min.js
extension/community_design/design/suncana/javascript/jquery.ui.widget.min.js
extension/community_design/design/suncana/javascript/jquery.easing.1.3.js
extension/community_design/design/suncana/javascript/jquery.ui.tabs.js
extension/community_design/design/suncana/javascript/jquery.hoverIntent.min.js
extension/community_design/design/suncana/javascript/jquery.popmenu.js
extension/community_design/design/suncana/javascript/jScrollPane.js
extension/community_design/design/suncana/javascript/jquery.mousewheel.js
extension/community_design/design/suncana/javascript/jquery.cycle.all.js
extension/sevenx/design/simple/javascript/jquery.scrollTo.js
extension/community_design/design/suncana/javascript/jquery.cookie.js
extension/community_design/design/suncana/javascript/ezstarrating_jquery.js
extension/community_design/design/suncana/javascript/jquery.initboxes.js
extension/community_design/design/suncana/javascript/app.js
extension/community_design/design/suncana/javascript/twitterwidget.js
extension/community_design/design/suncana/javascript/community.js
extension/community_design/design/suncana/javascript/roadmap.js
extension/community_design/design/suncana/javascript/ez.js
extension/community_design/design/suncana/javascript/ezshareevents.js
extension/sevenx/design/simple/javascript/main.js

Templates used to render the page:

UsageRequested templateTemplateTemplate loadedEditOverride
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 1
 Number of unique templates used: 1

Time used to render debug report: 0.0001 secs