X-Git-Url: https://juplo.de/gitweb/?a=blobdiff_plain;f=src%2Fmain%2Fresources%2FMETA-INF%2Fmaven%2Fsite.vm;h=7f1a87a1d85d1a53eed89034451852f4f01bb94a;hb=18264996e6b581927eba843ec128ad93b18c0d4f;hp=86006d7135c79208a025e1ad17e1bcfc63ae8c8d;hpb=b4577ed4f3ffde6a7fcb2f77f8b3a7efbfe6a765;p=maven-thymeleaf-skin
diff --git a/src/main/resources/META-INF/maven/site.vm b/src/main/resources/META-INF/maven/site.vm
index 86006d7..7f1a87a 100644
--- a/src/main/resources/META-INF/maven/site.vm
+++ b/src/main/resources/META-INF/maven/site.vm
@@ -7,72 +7,87 @@
#set ( $stack = $project.getClass().forName('java.util.LinkedList').newInstance() )
#macro ( buildPages $menu )
- #set ( $currentItemHref = $PathTool.calculateLink( $item.href, $relativePath ) )
+ #if ( $menu.href )
+ #set ( $currentItemHref = $PathTool.calculateLink( $menu.href, $relativePath ) )
+ #else
+ #set ( $currentItemHref = '' )
+ #end
#set ( $currentItemHref = $currentItemHref.replaceAll( '\\', '/' ) )
- #if ($currentItemHref)
- #set( $sinkhole = $stack.peek().childs.put($currentItemHref, $menu.name) )
+ #set ( $seen = false )
+ #foreach ( $entry in $stack )
+ #if ( $entry.uri == $currentItemHref )
+ #set ( $seen = true )
+ #end
#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 ) )
+ #if ( !$seen )
+ #if ($currentItemHref)
+ #set( $sinkhole = $stack.peek().childs.put($currentItemHref, $menu.name) )
+ #end
- #if ($menu.title)
- #set( $sinkhole = $page.put("title", $menu.title) )
- #end
- #if ($menu.alt)
- #set( $sinkhole = $page.put("alt", $menu.alt) )
- #end
- #if ($menu.img)
- #set( $sinkhole = $page.put("img", $menu.img) )
- #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
+ #if ($menu.title)
+ #set( $sinkhole = $page.put("title", $menu.title) )
+ #end
+ #if ($menu.alt)
+ #set( $sinkhole = $page.put("alt", $menu.alt) )
+ #end
+ #if ($menu.img)
+ #set( $sinkhole = $page.put("img", $menu.img) )
+ #end
- #set ( $page = $stack.pop() )
- #if ( $page.uri != "" )
-
- #set ( $crumbs = $project.getClass().forName('java.util.LinkedList').newInstance() )
- #set ( $crumb = $project.getClass().forName('java.util.LinkedHashMap').newInstance() )
- #set ( $sinkhole = $crumb.put("uri", $page.uri) )
- #set ( $sinkhole = $crumb.put("name", $page.name) )
- #set ( $sinkhole = $crumbs.push($crumb) )
- #foreach ( $entry in $stack )
- #if ( $entry.uri != "" )
- #set ( $crumb = $project.getClass().forName('java.util.LinkedHashMap').newInstance() )
- #set ( $sinkhole = $crumb.put("uri", $entry.uri) )
- #set ( $sinkhole = $crumb.put("name", $entry.name) )
- #set ( $sinkhole = $crumbs.push($crumb) )
- #end
+ #foreach ( $item in $menu.items )
+ #buildPages ( $item )
#end
- #set ( $sinkhole = $page.put("crumbs", $crumbs) )
- #if ( $pages.containsKey($page.uri) )
- #set ( $childs = $pages.get($page.uri).childs )
- #set ( $sinkhole = $page.put("childs", $childs) )
+ #set ( $page = $stack.pop() )
+ #if ( $page.uri != "" )
+
+ #set ( $crumbs = $project.getClass().forName('java.util.LinkedList').newInstance() )
+ #set ( $crumb = $project.getClass().forName('java.util.LinkedHashMap').newInstance() )
+ #set ( $sinkhole = $crumb.put("uri", $page.uri) )
+ #set ( $sinkhole = $crumb.put("name", $page.name) )
+ #set ( $sinkhole = $crumbs.push($crumb) )
+ #foreach ( $entry in $stack )
+ #if ( $entry.uri != "" )
+ #set ( $crumb = $project.getClass().forName('java.util.LinkedHashMap').newInstance() )
+ #set ( $sinkhole = $crumb.put("uri", $entry.uri) )
+ #set ( $sinkhole = $crumb.put("name", $entry.name) )
+ #set ( $sinkhole = $crumbs.push($crumb) )
+ #end
+ #end
+ #set ( $sinkhole = $page.put("crumbs", $crumbs) )
-
- #else
+ #if ( $pages.containsKey($page.uri) )
+ #set ( $childs = $pages.get($page.uri).childs )
+ #set ( $sinkhole = $page.put("childs", $childs) )
-
- #end
+
+ #else
- #set ( $sinkhole = $pages.put($page.uri, $page) )
+
+ #end
- #else
+ #set ( $sinkhole = $pages.put($page.uri, $page) )
- #else(no name)-->
- #set( $siteTitle = $menu.title )
- #set( $siteAlt = $menu.alt )
- #set( $siteImg = $menu.img )
- #set( $sinkhole = $pages.get("index.html").put("childs", $page.childs) )
- #end
+ #else
+ #else(no name)-->
+ #set( $siteTitle = $menu.title )
+ #set( $siteAlt = $menu.alt )
+ #set( $siteImg = $menu.img )
+ #set( $sinkhole = $pages.get("index.html").put("childs", $page.childs) )
+ #end
+
+ #end
+ #else
+
#end
#end
@@ -81,6 +96,13 @@
#set ( $page = $project.getClass().forName('java.util.LinkedHashMap').newInstance() )
#set ( $sinkhole = $page.put("uri", "index.html") )
#set ( $sinkhole = $page.put("name", "$project.name") )
+#set ( $crumbs = $project.getClass().forName('java.util.LinkedList').newInstance() )
+#set ( $crumb = $project.getClass().forName('java.util.LinkedHashMap').newInstance() )
+#set ( $sinkhole = $crumb.put("uri", $page.uri) )
+#set ( $sinkhole = $crumb.put("name", $page.name) )
+#set ( $sinkhole = $crumbs.push( $crumb ) )
+#set ( $sinkhole = $page.put("crumbs", $crumbs ) )
+#set ( $sinkhole = $pages.put($page.uri, $page) )
#set ( $sinkhole = $stack.push($page) )
#foreach ( $menu in $decoration.body.menus )
## Nur benannte Menüs werden berücksichtigt
@@ -96,10 +118,11 @@
#end
## Custom Variablen einlesen
-#set ( $sitePath = $decoration.custom.getChild( 'thymeproxy' ).getChild( 'path' ).getValue() )
-#if ( !$sitePath )
- #set ( $sitePath = "" )
+#set ( $canonicalPath = $decoration.custom.getChild( 'thymeproxy' ).getChild( 'path' ).getValue() )
+#if ( !$canonicalPath )
+ #set ( $canonicalPath = "" )
#end
+#set ( $sitePath = $canonicalPath + $project.version + "/" )
#set ( $siteCrumbs = $decoration.custom.getChild( 'thymeproxy' ).getChild( 'crumbs' ).getValue() )
@@ -114,19 +137,18 @@
+ title=~{:: title},
+ maincontent=~{:: .maincontent},
+ json='MERGE:' + ~{:: pre[class='json']/text()})}" >
- #if($shortTitle and $shortTitle != '')$title#else$project.name — $pages.get($alignedFileName).name#end
+ $title
-
+
+ $shortTitle
Path
@@ -134,11 +156,37 @@
-
+
$bodyContent
- Pages
+ Page Structure as JSON
+
+{
+ "_titles": {#set($sep = "")#foreach($page in $pages)$sep
+ "$sitePath$page.uri": "$page.name"#set($sep = ",")
+#end
+
+ },
+ "_childs": {#set($sep = "")#foreach($page in $pages)#if(!$page.childs.isEmpty())$sep
+ "$sitePath$page.uri": [#set($csep = "")#foreach($child in $page.childs.entrySet())$csep
+ "$sitePath$child.key"#set($csep = ",")#end
+
+ ]#set($sep = ",")#end#end
+
+ },
+ "_crumbs": {#set($sep = "")#foreach($page in $pages)$sep
+ "$sitePath$page.uri": [
+#set($csep = "")#if($siteCrumbs)
+ $siteCrumbs#set($csep = ",")#end#set($last = "")#foreach($crumb in $page.crumbs)#if($sitePath+$crumb.uri != $last)$csep
+ "$sitePath$crumb.uri"#set($csep = ",")#set($last = $sitePath+$crumb.uri)#end#end
+
+ ]#set($sep = ",")#end
+
+ }
+}
+
+ All Pages