possibility to use CSS prefix for menu items
[svjatoslav_commons.git] / src / main / java / eu / svjatoslav / commons / network / navigation / NavigationItem.java
index eef52fb..22ba6b0 100755 (executable)
@@ -1,3 +1,12 @@
+/*
+ * Svjatoslav Commons - shared library of common functionality.
+ * Copyright ©2012-2014, Svjatoslav Agejenko, svjatoslav@svjatoslav.eu
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of version 3 of the GNU Lesser General Public License
+ * or later as published by the Free Software Foundation.
+ */
+
 package eu.svjatoslav.commons.network.navigation;
 
 import java.util.ArrayList;
@@ -17,12 +26,17 @@ public class NavigationItem {
        private NavigationItem parent;
        private final String linkUrl;
 
-       public NavigationItem() {
-               this(Locale.ENG);
-       }
+       /**
+        * CSS prefix is inherited to child menu items.
+        */
+       private String cssPrefix;
 
        public NavigationItem(final Locale... localeOrder) {
-               this.localeOrder = localeOrder;
+               if (localeOrder.length == 0)
+                       this.localeOrder = new Locale[] { Locale.ENG };
+               else
+                       this.localeOrder = localeOrder;
+
                matchingPattern = null;
                linkUrl = null;
        }
@@ -44,6 +58,16 @@ public class NavigationItem {
                return item;
        }
 
+       protected String getCssPrefix() {
+               if (cssPrefix != null)
+                       return cssPrefix;
+
+               if (parent == null)
+                       return null;
+
+               return parent.getCssPrefix();
+       }
+
        public String getLinkUrl() {
                return linkUrl;
        }
@@ -55,6 +79,20 @@ public class NavigationItem {
                return parent.getLocaleOrder();
        }
 
+       NavigationItem getMatchingNavigationItem(final String requestPath) {
+               if (matchesUrl(requestPath))
+                       return this;
+
+               for (final NavigationItem childNavigationItem : subElements) {
+                       final NavigationItem match = childNavigationItem
+                                       .getMatchingNavigationItem(requestPath);
+
+                       if (match != null)
+                               return match;
+               }
+               return null;
+       }
+
        public List<NavigationItem> getSubElements() {
                return subElements;
        }
@@ -82,7 +120,10 @@ public class NavigationItem {
 
        public boolean matchesUrl(final String url) {
                return WildCardMatcher.match(url, matchingPattern);
+       }
 
+       public void setCssPrefix(final String cssPrefix) {
+               this.cssPrefix = cssPrefix;
        }
 
        public NavigationItem setPattern(final String pattern) {