Expandable/expanded info in treemenu operator results

Author Message

Piotrek Karaƛ

Saturday 14 April 2007 6:03:31 am

I'm currently developing a design that will solely rely on left menu as its primary navigation tool. Let's say it is a complex, multilevel structure that consists of objects of two classes: my_page and my_comment, the first of which will be included by treemenu operator, the second of which will be left out and not be visible in the actual menu (a classical 'page and its comments' combination).

I want the menu to comply with the best tree-like menu practices by means of:
- implementation of structured HTML list element,
- highlighting current item,
- highlighting selected items,
- level indentation,
- providing information about <b>expandable</b>/<b>expanded</b> elements with use of additional design elements (either with +/- or right-arrow/down-arrow images).

As far as I can figure it out, all but the last one are quite 'easy' to achieve since the result of treemenu operator provides us with all necessary parameters for each node. While the 'expanded' information can also be arranged - basically, it is equal or close to selected items information - there isn't any 'is_expandable' information. There is 'has_children' attribute, but that's not exactly what we need since there may be many my_pages that do contain my_comment child nodes, but no my_page objects whatsoever.

Is it possible to calculate the 'is_expandable' information? Of course it is. For each node in the treemenu operator result array, that isn't expanded and does have child nodes, we can investigate the node attribute, find the list of its children and then check if any of them constitutes my_page class. The problem is that according to the documentation, the 'children' attribute of ezcontentobjecttreenode object is not pre-fetched, which means that lots of additional fetching will have to be done, depending on the complexity of the menu.

In other words: it is possible to tell eZ publish: some nodes I want in the menu, some nodes I don't. Since I have told the system, that I only wanted objects of my_page class, wouldn't it be a good idea to get it calculated just as if there were no other nodes in the system? 'has_children' parameter isn't as useful as would 'has_the_right_children' be ;)

Has anyone similar thoughts on this? How do you deal with this problem? Maybe I am missing something? Some other operator? Some configuration detail?

Any suggestions/explanations would be appreciated.

Maybe little illustration to my 'novel' :)
Here's a sample structure [<i>with class information</i>]:

My site [<i>my_root</i>] (id.101)
+ About me [<i>my_page</i>] (id.102)
+ What I do [<i>my_page</i>] (id.103)
++ eZ publish [<i>my_page</i>] (id.104)
++ Multimedia [<i>my_page</i>] (id.105)
+ My portfolio [<i>my_page</i>] (id.106)
++ eZ publish [<i>my_page</i>] (id.107)
+++ Small Corporation [<i>my_project</i>] (id.108)
+++ Very Big Corporation [<i>my_project</i>] (id.109)
++ Multimedia [<i>my_page</i>] (id.110)
+++ Some Corporation [<i>my_project</i>] (id.111)
+++ Huge Corporation [<i>my_project</i>] (id.112)
+++ Little business [<i>my_project</i>] (id.113)

...and the fetch:

{def
$myMenuRoot=2
$myMenu=treemenu(
  is_set($module_result.node_id)|choose($myMenuRoot, $module_result.node_id),
  ezini('MenuContentSettings', 'LeftIdentifierList', 'menu.ini'),
  0,
  5
)}

Let's say LeftIdentifierList contains <b>my_root</b> and <b>my_page</b> classes.

<b>Example 1:</b>
Current location: My site / What I do
Result:

<b>My site</b> [<i>my_root</i>] (id.101)
+ About me [<i>my_page</i>] (id.102)
<b>+ What I do</b> [<i>my_page</i>] (id.103)
++ eZ publish [<i>my_page</i>] (id.104)
++ Multimedia [<i>my_page</i>] (id.105)
+ My portfolio [<i>my_page</i>] (id.106)

Nodes 104 and 105 don't have child sub-nodes so there is no problem. However, node 106 has my_page class child objects, so it would be nice if we could indicate: My portfolio <b>is_expandable</b>.

<b>Example 2:</b>
Current location: My site / My Portfolio / eZ publish
Result:

<b>My site</b> [<i>my_root</i>] (id.101)
+ About me [<i>my_page</i>] (id.102)
+ What I do [<i>my_page</i>] (id.103)
<b>+ My portfolio</b> [<i>my_page</i>] (id.106)
<b>++ eZ publish</b> [<i>my_page</i>] (id.107)
++ Multimedia [<i>my_page</i>] (id.110)

Here's where situation gets much worse. We do know that 103 node is expandable, we've just been there, so it would be nice to suggest with 'expandable' representation that it's content hasn't disappeared all of the sudden. Next, our 107 node contains project elements, but we don't want to consider them menu elements (otherwise has_children information would be exactly what we need).

--
Company: mediaSELF Sp. z o.o., http://www.mediaself.pl
eZ references: http://ez.no/partners/worldwide_partners/mediaself
eZ certified developer: http://ez.no/certification/verify/272585
eZ blog: http://ez.ryba.eu

Powered by eZ Publish™ CMS Open Source Web Content Management. Copyright © 1999-2014 eZ Systems AS (except where otherwise noted). All rights reserved.

eZ debug

Timing: Jan 18 2025 11:02:34
Script start
Timing: Jan 18 2025 11:02:34
Module start 'layout'
Timing: Jan 18 2025 11:02:34
Module start 'content'
Timing: Jan 18 2025 11:02:35
Module end 'content'
Timing: Jan 18 2025 11:02:35
Script end

Main resources:

Total runtime0.5029 sec
Peak memory usage4,096.0000 KB
Database Queries46

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0054 589.2734152.6563
Module start 'layout' 0.00540.0022 741.929739.5078
Module start 'content' 0.00760.4935 781.4375499.1953
Module end 'content' 0.50110.0018 1,280.632812.1094
Script end 0.5029  1,292.7422 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00360.7076160.0002
Check MTime0.00150.3038160.0001
Mysql Total
Database connection0.00080.167010.0008
Mysqli_queries0.446688.7892460.0097
Looping result0.00040.0859440.0000
Template Total0.472193.920.2361
Template load0.00240.474220.0012
Template processing0.469793.396820.2349
Template load and register function0.00010.024110.0001
states
state_id_array0.00200.404710.0020
state_identifier_array0.00100.202220.0005
Override
Cache load0.00180.3673540.0000
Sytem overhead
Fetch class attribute can translate value0.00080.157110.0008
Fetch class attribute name0.00090.180520.0005
XML
Image XML parsing0.00060.128410.0006
class_abstraction
Instantiating content class attribute0.00000.000820.0000
General
dbfile0.00080.1604170.0000
String conversion0.00000.001040.0000
Note: percentages do not add up to 100% because some accumulators overlap

Templates used to render the page:

UsageRequested templateTemplateTemplate loadedEditOverride
1node/view/full.tplfull/forum_topic.tplextension/sevenx/design/simple/override/templates/full/forum_topic.tplEdit templateOverride template
1content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
1content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
9content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
7content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
1content/datatype/view/ezxmltags/literal.tpl<No override>extension/community/design/standard/templates/content/datatype/view/ezxmltags/literal.tplEdit templateOverride template
1print_pagelayout.tpl<No override>extension/community/design/community/templates/print_pagelayout.tplEdit templateOverride template
 Number of times templates used: 21
 Number of unique templates used: 7

Time used to render debug report: 0.0001 secs