From: Kai Moritz Date: Fri, 8 Jul 2016 07:04:46 +0000 (+0200) Subject: Projekt-Seite erstellt: Velocity-Template - Einlesen der Daten überarbeitet X-Git-Tag: tmp2~13 X-Git-Url: https://juplo.de/gitweb/?p=maven-thymeleaf-skin;a=commitdiff_plain;h=2f89199db749b90422c828c2479b3407e45357ca Projekt-Seite erstellt: Velocity-Template - Einlesen der Daten überarbeitet Die Verarbeitung der Menüdaten wurde so überarbeitet, dass automatisch erzeugte Seiten in dem explizit in der site.xml definierten Menü überschrieben werden können. Dabei/dadurch wird dann der Name der Seite überschrieben. Ggf. der Seite untergeordnete Unterseiten bleiben erhalten. Außerdem bleibt die Seite auch weiterhin in anderen Untermenüs unter dem alten Namen erhalten, falls sie in einem Untermenü eingetragen war. Umsetzung: Die Daten werden zunächst in eine Map eingelesen. Dabei werden die unbenannten Menüs (dies sind in der Regel die von der Hand definierten Menüs) zuletzt eingelesen. Wenn die selbe URI in mehreren Menüs definiert ist, werden zuvor eingelesenen Einträge überschrieben. Dabei werden aber die zuvor erkannten Kind-Knoten erhalten. --- diff --git a/src/site/template.vm b/src/site/template.vm index 4fda7f5..c91a1b2 100644 --- a/src/site/template.vm +++ b/src/site/template.vm @@ -2,26 +2,68 @@ -## Automatisch generierte Seiten einlesen #set ( $pages = $project.getClass().forName('java.util.LinkedHashMap').newInstance() ) -#macro ( buildPages $items ) - #foreach ( $item in $items ) - #set ( $currentItemHref = $PathTool.calculateLink( $item.href, $relativePath ) ) - #set ( $currentItemHref = $currentItemHref.replaceAll( '\\', '/' ) ) - #set ( $sinkhole = $pages.put( $item.name, $currentItemHref ) ) - #if ( !$item.items.empty ) - #buildPages ( $item.items ) +#set ( $stack = $project.getClass().forName('java.util.LinkedList').newInstance() ) +#macro ( buildPages $menu ) + + #set ( $currentItemHref = $PathTool.calculateLink( $item.href, $relativePath ) ) + #set ( $currentItemHref = $currentItemHref.replaceAll( '\\', '/' ) ) + + #if ($currentItemHref) + #set( $sinkhole = $stack.peek().childs.put($currentItemHref, $menu.name) ) + #end + + #set ( $page = $project.getClass().forName('java.util.LinkedHashMap').newInstance() ) + #set ( $sinkhole = $page.put("name", $menu.name) ) + #set ( $sinkhole = $page.put("uri", $currentItemHref) ) + #set ( $sinkhole = $page.put("childs", $project.getClass().forName('java.util.LinkedHashMap').newInstance()) ) + #set ( $sinkhole = $stack.push( $page ) ) + + #foreach ( $item in $menu.items ) + #buildPages ( $item ) + #end + + #set ( $page = $stack.pop() ) + #if ( $page.uri != "" ) + + #if ( $pages.containsKey($page.uri) ) + #set ( $childs = $pages.get($page.uri).childs ) + #set ( $sinkhole = $page.put("childs", $childs) ) + + + #else + + #end + + #set ( $sinkhole = $pages.put($page.uri, $page) ) + #set ( $sinkhole = $page.remove("uri") ) + + #else + + #end #end + + +## Seiten einlesen #foreach ( $menu in $decoration.body.menus ) ## Nur benannte Menüs werden berücksichtigt #if ($menu.name) - #buildPages ( $menu.items ) + #buildPages ( $menu ) #end #end +#foreach ( $menu in $decoration.body.menus ) + ## Nur unbenannte Menüs werden berücksichtigt + #if (!($menu.name)) + #buildPages ( $menu ) + #end +#end + + + #set ( $crumbs = $project.getClass().forName('java.util.LinkedHashMap').newInstance() ) #macro ( searchBreadcrumbTrail $items ) #set ( $sep = '' )