| Author | Message | 
                                                                                                    
                                                        | sergey podlesnyi
                                                                                                                             
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Thursday 23 January 2003 4:36:50 am 
                                                                
                                                                 Are nested loops possible? If so, could you help me find reason why the following code is not working: 
{section name=Folder loop=$folder_list}<a href={concat("content/view/full/",$Folder:item.node_id,"/")|ezurl}>{$Folder:item.name}</A>
 <UL>
 {section name=sub loop=$subfolder_list}
 <LI><a href=#>{$sub:item.name}</a>
 {/section}
 </UL>
 {/section}
 Here $folder_list and $subfolder_list are valid arrays built by fetch; I can print them out separately without problems but when I nest it one into another they fail. Interesting, $subfolder_list still has correct number of elements, I can see it by bullets printed by <UL>. But real data (name) is lost. I need a solutin because I want to build left-hand menu on site where top level menu entries are dynamically built from folders on root level (variable: $folder_list) and second-level menu is built from folders located inside root level folders. | 
                                                
                                                                                                                                                        
                                                        | Tony Wood
                                                                                                                             | Thursday 23 January 2003 5:05:58 am 
                                                                 I tried to use nested loops, but i found the loops worked but the values were not being returned correctly, so gave up till full version comes out... It may be a bug..  
> Are nested loops possible? If so, could you help me find> reason why the following code is not working:
 >
 > {section name=Folder loop=$folder_list}
 > <a
 > href={concat("content/view/full/",$Folder:item.node_id,"/")|ezurl}>{$Folder:item.name}</a>
 > <UL>
 > {section name=sub loop=$subfolder_list}
 > <LI><a href=#>{$sub:item.name}</a>
 > {/section}
 > </ul>
 > {/section}
 >
 > Here $folder_list and $subfolder_list are valid arrays
 > built by fetch; I can print them out separately without
 > problems but when I nest it one into another they fail.
 > Interesting, $subfolder_list still has correct number of
 > elements, I can see it by bullets printed by <UL>. But real
 > data (name) is lost.
 >
 > I need a solutin because I want to build left-hand menu on
 > site where top level menu entries are dynamically built from
 > folders on root level (variable: $folder_list) and
 > second-level menu is built from folders located inside root
 > level folders.
 Tony Wood : twitter.com/tonywoodVision with Technology
 Experts in eZ Publish consulting & development
 
 Power to the Editor!
 
 Free eZ Training : http://www.VisionWT.com/training
 eZ Future Podcast : http://www.VisionWT.com/eZ-Future
 
 
 | 
                                                                                                    
                                                        | Alexei Pechekhonov
                                                                                                                             | Saturday 25 January 2003 5:18:41 am 
                                                                 
> {section name=sub loop=$subfolder_list}> <LI><a href=#>{$sub:item.name}</a>
 > {/section}
 
Try the following (do remember name spaces){section name=sub loop=$subfolder_list}
 <LI><a href=#>{$Folder:sub.item.name}</a>
 {/section}
 Alexei
 [email protected]
 | 
                                                                                                    
                                                        | sergey podlesnyi
                                                                                                                             | Monday 27 January 2003 8:56:09 am 
                                                                 
> Try to use this code:> {section name=Folder loop=$folder_list}
 > <a
 > href={concat("content/view/full/",$Folder:item.node_id,"/")|ezurl}>{$Folder:item.name}</A>
 >
 > <UL>
 > {section loop=$subfolder_list}
 > <LI><a href=#>{$Folder:item.name}</a>
 > {/section}
 > </UL>
 > {/section}
 > -----------
 Thank you Sergey: tested - it worked! | 
                                                                                                    
                                                        | Volker Lenz
                                                                                                                             | Thursday 30 January 2003 1:27:55 pm 
                                                                 
> > Try to use this code:> > {section name=Folder loop=$folder_list}
 > > <a
 > >
 > href={concat("content/view/full/",$Folder:item.node_id,"/")|ezurl}>{$Folder:item.name}</A>
 > >
 > > <UL>
 > > {section loop=$subfolder_list}
 > > <LI><a href=#>{$Folder:item.name}</a>
 > > {/section}
 > > </UL>
 > > {/section}
 > > -----------
 >
 
This one should do the job, too -- if you have reasons to seperate namespaces in more complicated situations:{section name=Folder loop=$folder_list}
 <a href={concat("content/view/full/",$Folder:item.node_id,"/"|ezurl}>{$Folder:item.name}</a>
 
 <ul>
 {section name=SubFolder loop=$subfolder_list}
 <li><a href=#>{$Folder:$SubFolder:item.name}</a></li>
 {/section}
 </ul>
 {/section}
 | 
                                                                                                    
                                                        | Matthew Rat
                                                                                                                             | Thursday 10 April 2003 6:54:46 am 
                                                                 I am having a problem with this too and I have read through the replies but still cannot seem to get this to work. One thing I did NOT see is LET statements that FETCH the content based on the NODE_ID of the primary section. Take: 
{let folder_list=fetch(content,list,hash(parent_node_id,240,sort_by,array(array(priority))))}{section name=Folder loop=$folder_list}
 {let subfolder_list=fetch(content,list,hash(parent_node_id,$Folder:item.node_id,sort_by,array(array(priority))))}
 <a href={concat("content/view/full/",$Folder:item.node_id,"/"|ezurl}>{$Folder:item.name}</a>
 <ul>
 {section name=SubFolder loop=$subfolder_list}
 <li><a href=#>{$Folder:$SubFolder:item.name}</a></li>
 {/section}
 </ul>
 {/section}
 Even when I hardcode a value for the 2nd fetch's "parent_node_id", I get nothing and there are 5 folders in there. If I take the 2nd SECTION (including LET) and put it outside the loop, hardcode the node_id, and remove the "$Folder:" prefix from the line, THEN I get some results. Am I doing something wrong with my LET statements or something? | 
                                                                                                    
                                                        | Bård Farstad
                                                                                                                             | Thursday 10 April 2003 8:01:19 am 
                                                                 The problem seems to be with namespaces. This is an example that works: Notice the $Folder:sub_folder_list.  {let folder_list=fetch(content,list,hash(parent_node_id,2,sort_by,array(array(priority))))} 
{section name=Folder loop=$folder_list}<b>{$Folder:item.name}</b>:<br />
 {let sub_folder_list=fetch(content,list,hash(parent_node_id,$Folder:item.node_id,sort_by,array(array(priority))))}
 
{section name=SubFolder loop=$Folder:sub_folder_list}-{$Folder:SubFolder:item.name}<br />
 {/section}
 
{/let}{/section}
 {/let} --bård Documentation: http://ez.no/doc
 | 
                                                                                                    
                                                        | Mr Win
                                                                                                                             | Thursday 24 April 2003 9:46:57 am 
                                                                 Yeah !!! working. 
But if I want to listing only "subfolder" under "folder", not all itemor listing all article with out folder.
 |