class MenuItem(object):
html_id = None
+ class InvalidMenuItem(BaseException):
+ pass
+
def __init__(self, url, title, html_id=None, more_urls=None):
self.url = url
self.title = title
self.html_id = html_id
self.more_urls = more_urls or set()
+ def is_valid(self):
+ return True
+
def is_active(self, request, value):
url = request.get_full_path()
return url == str(self.url) or url in set(str(url) for url in self.more_urls)
def check_active(self, request, value):
- self.active = self.is_active(request, value)
+ try:
+ self.active = self.is_active(request, value)
+ except self.InvalidMenuItem, e:
+ pass
def get_url(self):
return self.url
If no url or title is provided, get_absolute_url and __unicode__ are used.
You can also provide a reverse lookup dictionary, as in {model: field_name}.
"""
- def __init__(self, obj, url=None, rev_lookups=None, title=None, html_id=None):
+ def __init__(self,
+ obj=None, obj_get=None,
+ url=None, rev_lookups=None, title=None, html_id=None):
super(ObjectMenuItem, self).__init__(url=url, title=title, html_id=html_id)
self.obj = obj
+ self.obj_get = obj_get
self.rev_lookups = rev_lookups
+ def get_object(self):
+ try:
+ return self.obj or self.obj_get()
+ except BaseException, e:
+ raise self.InvalidMenuItem(e)
+
def get_title(self):
- return self.title or unicode(self.obj)
+ return self.title or unicode(self.get_object())
- @property
def get_url(self):
- return self.url or self.obj.get_absolute_url()
+ return self.url or self.get_object().get_absolute_url()
+
+ def is_valid(self):
+ try:
+ obj = self.get_object()
+ except self.InvalidMenuItem, e:
+ return False
+ return True
def is_active(self, request, value):
- if value == self.obj:
+ if value == self.get_object():
return True
if self.rev_lookups:
for model, manager in self.rev_lookups.items():
if (isinstance(value, model) and
- self.obj in getattr(value, manager).all()):
+ self.get_object() in getattr(value, manager).all()):
return True
return False
ITEMS = []
-def add_entry(**qs):
- try:
- entry = Entry.objects.get(**qs)
- except Entry.DoesNotExist:
- return
- if not entry.published:
- return
- ITEMS.append(ObjectMenuItem(entry))
-
-add_entry(slug_pl='o-nas')
+ITEMS.append(ObjectMenuItem(
+ obj_get=lambda:Entry.published_objects.get(slug_pl='o-nas')
+))
ITEMS.append(ModelMenuItem(Entry, reverse_lazy('migdal_entry_list_publications'),
field_lookups={'type': 'publications'}, title=_('Publications')))
ITEMS.append(MenuItem(reverse_lazy('events'), _('Events'),
more_urls=(reverse_lazy('events_past'),)))
-ITEMS.append(ObjectMenuItem(Category.objects.get(slug_pl='stanowisko'),
- rev_lookups={Entry: 'categories'}, title=_('Positions')))
-#CategoryMenuItem(Category.objects.get(slug_pl='stanowisko'),
-# title=_('Positions')),
-
-ITEMS.append(ObjectMenuItem(Entry.objects.get(slug_pl='pierwsza-pomoc'),
- title=_('First aid in copyright')))
+ITEMS.append(ObjectMenuItem(
+ obj_get=lambda:Category.objects.get(slug_pl='stanowisko'),
+ rev_lookups={Entry: 'categories'},
+ title=_('Positions')
+))
+ITEMS.append(ObjectMenuItem(
+ obj_get=lambda:Entry.published_objects.get(slug_pl='pierwsza-pomoc'),
+ title=_('First aid in copyright')
+))