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-Url: http://juplo.de/gitweb/?a=commitdiff_plain;h=22e98ad0de8ac8e162fea025ad86a2ca78fee515;p=simple-mapper 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 decfec8..b7637fd 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 = '' )