Source code for org.views.sitecollection

from __future__ import annotations

from onegov.core.security import Private
from onegov.org import _, OrgApp
from onegov.org.models import SiteCollection


from typing import TYPE_CHECKING
if TYPE_CHECKING:
    from onegov.core.types import JSON_ro
    from onegov.org.request import OrgRequest


@OrgApp.json(model=SiteCollection, permission=Private)
[docs] def get_site_collection( self: SiteCollection, request: OrgRequest ) -> JSON_ro: """ Returns a list of internal links to be used by the redactor. See `<https://imperavi.com/redactor/plugins/predefined-links/>`_ """ objects = self.get() groups = [ ('topics', request.translate(_('Topics'))), ('news', request.translate(_('Latest news'))), ('imagesets', request.translate(_('Photo Albums'))), ('forms', request.translate(_('Forms'))), ('directories', request.translate(_('Directories'))), ('resources', request.translate(_('Resources'))), ] # in addition to the default url/name pairings we use a group # label which will be used as optgroup label return [ { 'group': label, 'name': obj.title, 'url': request.link(obj) } for id, label in groups for obj in objects[id] ]