""" The onegov organisation homepage. """
from __future__ import annotations
from morepath import redirect
from onegov.core.security import Public, Private
from onegov.core.widgets import inject_variables
from onegov.directory import DirectoryCollection
from onegov.event import OccurrenceCollection
from onegov.form import FormCollection
from onegov.org import _
from onegov.org import OrgApp
from onegov.org.layout import HomepageLayout
from onegov.org.models import Organisation
from onegov.org.models import PublicationCollection
from onegov.reservation import ResourceCollection
from typing import TYPE_CHECKING
if TYPE_CHECKING:
from onegov.core.types import RenderData
from onegov.org.layout import Layout
from onegov.org.request import OrgRequest
from webob import Response
[docs]
def redirect_to(
request: OrgRequest,
target: str | None,
path: str | None
) -> Response | None:
if target == 'directories':
return redirect(request.class_link(DirectoryCollection))
if target == 'events':
return redirect(request.class_link(OccurrenceCollection))
if target == 'forms':
return redirect(request.class_link(FormCollection))
if target == 'publications':
return redirect(request.class_link(PublicationCollection))
if target == 'reservations':
return redirect(request.class_link(ResourceCollection))
if target == 'path' and path:
return redirect(request.class_link(Organisation) + path.lstrip('/'))
return None
@OrgApp.html(model=Organisation, template='homepage.pt', permission=Public)
[docs]
def view_org(
self: Organisation,
request: OrgRequest,
layout: Layout | None = None
) -> RenderData | Response:
""" Renders the org's homepage. """
# the homepage can optionally be used as a jump-pad to redirect to
# sub-part of the organisation -> this is useful if only one specific
# module is used (e.g. only reservations)
redirect = redirect_to(
request,
request.app.org.redirect_homepage_to,
request.app.org.redirect_path)
if redirect:
return redirect
layout = layout or HomepageLayout(self, request)
default = {
'layout': layout,
'title': self.title
}
structure = self.meta.get('homepage_structure')
widgets = request.app.config.homepage_widget_registry.values()
return inject_variables(widgets, layout, structure, default)
@OrgApp.html(
model=Organisation,
template='sort.pt',
name='sort',
permission=Private
)
[docs]
def view_pages_sort(
self: Organisation,
request: OrgRequest,
layout: HomepageLayout | None = None
) -> RenderData:
layout = layout or HomepageLayout(self, request)
return {
'title': _('Sort'),
'layout': layout,
'page': self,
'pages': layout.root_pages
}