X-Git-Url: http://www2.svjatoslav.eu/gitweb/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Feu%2Fsvjatoslav%2Fcommons%2Fnetwork%2Fnavigation%2FNavigationItem.java;h=6ab67e27cc56af16f9a84502d3cc9a4a3b7e9fc1;hb=6ddfea297cc4a1136503a454631f5bc5c72412b1;hp=6392fa9afc3e6cf5e817880825a08059b2b69f74;hpb=a2d7f6f310a1c44e15574b4acf056894b4ed4b33;p=svjatoslav_commons.git diff --git a/src/main/java/eu/svjatoslav/commons/network/navigation/NavigationItem.java b/src/main/java/eu/svjatoslav/commons/network/navigation/NavigationItem.java index 6392fa9..6ab67e2 100755 --- a/src/main/java/eu/svjatoslav/commons/network/navigation/NavigationItem.java +++ b/src/main/java/eu/svjatoslav/commons/network/navigation/NavigationItem.java @@ -1,37 +1,72 @@ package eu.svjatoslav.commons.network.navigation; import java.util.ArrayList; +import java.util.HashMap; import java.util.List; +import java.util.Map; +import eu.svjatoslav.commons.network.Locale; import eu.svjatoslav.commons.string.WildCardMatcher; public class NavigationItem { - private final String title; - private final String link; - private final String matchingWildcard; - + private String matchingPattern; + private final Map localeToTitle = new HashMap(); ArrayList subElements = new ArrayList(); + private Locale[] localeOrder; + private NavigationItem parent; + private final String linkUrl; + + public NavigationItem(final Locale... localeOrder) { + if (localeOrder.length == 0) + this.localeOrder = new Locale[] { Locale.ENG }; + else + this.localeOrder = localeOrder; - public NavigationItem(final String title, final String link) { - this.title = title; - this.link = link; - matchingWildcard = link; + matchingPattern = null; + linkUrl = null; } - public NavigationItem(final String title, final String link, - final String wildcard) { - this.title = title; - this.link = link; - matchingWildcard = wildcard; + public NavigationItem(final NavigationItem parent, final String linkUrl, + final String... titles) { + this.parent = parent; + this.linkUrl = linkUrl; + matchingPattern = linkUrl; + + initializeLocalizedTitles(titles); } - public void addSubNavigation(final NavigationItem item) { + public NavigationItem addChild(final String linkUrl, final String... titles) { + + final NavigationItem item = new NavigationItem(this, linkUrl, titles); subElements.add(item); + + return item; + } + + public String getLinkUrl() { + return linkUrl; + } + + public Locale[] getLocaleOrder() { + if (localeOrder != null) + return localeOrder; + + return parent.getLocaleOrder(); } - public String getLink() { - return link; + 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 getSubElements() { @@ -39,13 +74,33 @@ public class NavigationItem { } public String getTitle() { - return title; + if (localeToTitle.size() != 1) + throw new RuntimeException("there shall be exactly one title"); + + return localeToTitle.values().iterator().next(); } - public boolean matchesUrl(final String url) { + public String getTitle(final Locale locale) { + return localeToTitle.get(locale); + } - return WildCardMatcher.match(url, matchingWildcard); + private void initializeLocalizedTitles(final String... titles) { + final Locale[] locales = getLocaleOrder(); + if (locales.length != titles.length) + throw new RuntimeException("There should be exactly " + + locales.length + " title(s)."); + + for (int i = 0; i < titles.length; i++) + localeToTitle.put(locales[i], titles[i]); + } + + public boolean matchesUrl(final String url) { + return WildCardMatcher.match(url, matchingPattern); + } + public NavigationItem setPattern(final String pattern) { + matchingPattern = pattern; + return this; } }