slightly more type-safe and extending friendly navigation
[svjatoslav_commons.git] / src / main / java / eu / svjatoslav / commons / network / navigation / NavigationItem.java
index 14c8b0a..76a7d07 100755 (executable)
@@ -17,45 +17,41 @@ import java.util.Map;
 import eu.svjatoslav.commons.network.Locale;
 import eu.svjatoslav.commons.string.WildCardMatcher;
 
-public class NavigationItem {
+public class NavigationItem<NI extends NavigationItem, N extends Navigation> {
 
        private String matchingPattern;
+
        private final Map<Locale, String> localeToTitle = new HashMap<Locale, String>();
-       ArrayList<NavigationItem> subElements = new ArrayList<NavigationItem>();
-       private Locale[] localeOrder;
-       private NavigationItem parent;
+       private final ArrayList<NI> subElements = new ArrayList<NI>();
+       private final NI parent;
+       private final N navigation;
        private final String linkUrl;
-
        /**
         * CSS prefix is inherited to child menu items.
         */
        private String cssPrefix;
 
-       public NavigationItem(final Locale... localeOrder) {
-               if (localeOrder.length == 0)
-                       this.localeOrder = new Locale[] { Locale.ENG };
-               else
-                       this.localeOrder = localeOrder;
-
+       public NavigationItem(final N navigation) {
+               this.navigation = navigation;
+               parent = null;
                matchingPattern = null;
                linkUrl = null;
        }
 
-       public NavigationItem(final NavigationItem parent, final String linkUrl,
+       public NavigationItem(final NI parent, final String linkUrl,
                        final String... titles) {
+               this.navigation = (N) parent.getNavigation();
                this.parent = parent;
                this.linkUrl = linkUrl;
                matchingPattern = linkUrl;
 
                initializeLocalizedTitles(titles);
-       }
 
-       public NavigationItem addChild(final String linkUrl, final String... titles) {
-
-               final NavigationItem item = new NavigationItem(this, linkUrl, titles);
-               subElements.add(item);
+               parent.addNavigationItem(this);
+       }
 
-               return item;
+       public void addNavigationItem(final NI navigationItem) {
+               subElements.add(navigationItem);
        }
 
        protected String getCssPrefix() {
@@ -72,19 +68,12 @@ public class NavigationItem {
                return linkUrl;
        }
 
-       public Locale[] getLocaleOrder() {
-               if (localeOrder != null)
-                       return localeOrder;
-
-               return parent.getLocaleOrder();
-       }
-
-       NavigationItem getMatchingNavigationItem(final String requestPath) {
+       NI getMatchingNavigationItem(final String requestPath) {
                if (matchesUrl(requestPath))
-                       return this;
+                       return (NI) this;
 
-               for (final NavigationItem childNavigationItem : subElements) {
-                       final NavigationItem match = childNavigationItem
+               for (final NI childNavigationItem : subElements) {
+                       final NI match = (NI) childNavigationItem
                                        .getMatchingNavigationItem(requestPath);
 
                        if (match != null)
@@ -93,16 +82,12 @@ public class NavigationItem {
                return null;
        }
 
-       public List<NavigationItem> getSubElements() {
-               return subElements;
+       public N getNavigation() {
+               return navigation;
        }
 
-       public String getTitle() {
-               if (localeToTitle.size() != 1)
-                       throw new RuntimeException(
-                                       "NavigationItem.getTitle() was called without locale parameter, but there there are multiple titles in diffirent locales available.");
-
-               return localeToTitle.values().iterator().next();
+       public List<NI> getSubElements() {
+               return subElements;
        }
 
        public String getTitle(final Locale locale) {
@@ -110,13 +95,14 @@ public class NavigationItem {
        }
 
        private void initializeLocalizedTitles(final String... titles) {
-               final Locale[] locales = getLocaleOrder();
-               if (locales.length != titles.length)
+               final List<Locale> locales = getNavigation().getLocaleConfiguration()
+                               .getAllowedLocales();
+               if (locales.size() != titles.length)
                        throw new RuntimeException("There should be exactly "
-                                       + locales.length + " title(s).");
+                                       + locales.size() + " title(s).");
 
                for (int i = 0; i < titles.length; i++)
-                       localeToTitle.put(locales[i], titles[i]);
+                       localeToTitle.put(locales.get(i), titles[i]);
        }
 
        public boolean matchesUrl(final String url) {
@@ -132,4 +118,12 @@ public class NavigationItem {
                return this;
        }
 
+       @Override
+       public String toString() {
+               return "NavigationItem [matchingPattern=" + matchingPattern
+                               + ", localeToTitle=" + localeToTitle + ", subElements count="
+                               + subElements.size() + ", linkUrl=" + linkUrl + ", cssPrefix="
+                               + cssPrefix + "]";
+       }
+
 }