layout node traversal: handling of special cases, keep target view in request
git-svn-id: svn://svn.cy55.de/Zope3/src/loops/trunk@3313 fd906abe-77d9-0310-91a1-e0d9ade77398
This commit is contained in:
parent
b82f776b0b
commit
79e225e054
3 changed files with 38 additions and 6 deletions
|
@ -50,6 +50,14 @@ class BaseView(object):
|
|||
def virtualTarget(self):
|
||||
return self.viewAnnotations.get('target')
|
||||
|
||||
@Lazy
|
||||
def virtualTargetView(self):
|
||||
return self.viewAnnotations.get('targetView')
|
||||
|
||||
@Lazy
|
||||
def node(self):
|
||||
return self.viewAnnotations.get('node')
|
||||
|
||||
@Lazy
|
||||
def title(self):
|
||||
return self.context.title
|
||||
|
|
|
@ -44,6 +44,10 @@ class LayoutNodeView(Page):
|
|||
def conceptManager(self):
|
||||
return self.loopsRoot.getConceptManager()
|
||||
|
||||
@Lazy
|
||||
def resourceManager(self):
|
||||
return self.loopsRoot.getResourceManager()
|
||||
|
||||
@Lazy
|
||||
def defaultPredicate(self):
|
||||
return self.conceptManager.getDefaultPredicate()
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
#
|
||||
# Copyright (c) 2008 Helmut Merz helmutm@cy55.de
|
||||
# Copyright (c) 2009 Helmut Merz helmutm@cy55.de
|
||||
#
|
||||
# This program is free software; you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License as published by
|
||||
|
@ -24,6 +24,7 @@ $Id$
|
|||
|
||||
from zope.app.container.traversal import ItemTraverser
|
||||
from zope.cachedescriptors.property import Lazy
|
||||
from zope import component
|
||||
from zope.component import adapts
|
||||
from zope.publisher.interfaces import NotFound
|
||||
|
||||
|
@ -40,21 +41,26 @@ class NodeTraverser(ItemTraverser):
|
|||
|
||||
def publishTraverse(self, request, name):
|
||||
viewAnnotations = request.annotations.setdefault('loops.view', {})
|
||||
viewAnnotations['node'] = self.context
|
||||
if name == '.loops':
|
||||
return self.context.getLoopsRoot()
|
||||
if name.startswith('.'):
|
||||
if len(name) > 1:
|
||||
name = self.cleanUpTraversalStack(request, name)[1:]
|
||||
if name:
|
||||
if name.startswith('target'):
|
||||
name = name[6:]
|
||||
if '-' in name:
|
||||
name, ignore = name.split('-', 1)
|
||||
uid = int(name[1:])
|
||||
uid = int(name)
|
||||
target = util.getObjectForUid(uid)
|
||||
else:
|
||||
target = self.context.target
|
||||
if target is not None:
|
||||
#viewAnnotations = request.annotations.setdefault('loops.view', {})
|
||||
viewAnnotations['node'] = self.context
|
||||
target = getVersion(target, request)
|
||||
target = adapted(target, LanguageInfo(target, request))
|
||||
viewAnnotations['target'] = target
|
||||
#return target
|
||||
tv = component.getMultiAdapter((target, request), name='layout')
|
||||
viewAnnotations['targetView'] = tv
|
||||
return self.context
|
||||
try:
|
||||
obj = super(NodeTraverser, self).publishTraverse(request, name)
|
||||
|
@ -62,3 +68,17 @@ class NodeTraverser(ItemTraverser):
|
|||
viewAnnotations['pageName'] = name
|
||||
return self.context
|
||||
return obj
|
||||
|
||||
def cleanUpTraversalStack(self, request, name):
|
||||
traversalStack = request._traversal_stack
|
||||
while traversalStack and traversalStack[0].startswith('.'):
|
||||
# skip obsolete target references in the url
|
||||
name = traversalStack.pop(0)
|
||||
traversedNames = request._traversed_names
|
||||
if traversedNames:
|
||||
lastTraversed = traversedNames[-1]
|
||||
if lastTraversed.startswith('.') and lastTraversed != name:
|
||||
# let <base .../> tag show the current object
|
||||
traversedNames[-1] = name
|
||||
return name
|
||||
|
||||
|
|
Loading…
Add table
Reference in a new issue