--- a/src/pyams_content/component/association/paragraph.py Fri Mar 02 17:24:06 2018 +0100
+++ b/src/pyams_content/component/association/paragraph.py Fri Mar 02 17:36:12 2018 +0100
@@ -16,31 +16,39 @@
# import standard library
# import interfaces
-from pyams_content.component.association.interfaces import IAssociationParagraph, ASSOCIATION_PARAGRAPH_TYPE
+from pyams_content.component.association.interfaces import IAssociationParagraph, ASSOCIATION_PARAGRAPH_TYPE, \
+ ASSOCIATION_PARAGRAPH_RENDERERS
from pyams_content.component.extfile.interfaces import IExtFileContainerTarget
from pyams_content.component.links.interfaces import ILinkContainerTarget
from pyams_content.component.paragraph.interfaces import IParagraphFactory
from pyams_content.features.checker.interfaces import IContentChecker, MISSING_VALUE, MISSING_LANG_VALUE
+from pyams_content.features.renderer.interfaces import IContentRenderer
from pyams_i18n.interfaces import II18n, II18nManager, INegotiator
# import packages
from pyams_content.component.paragraph import BaseParagraph, BaseParagraphContentChecker, BaseParagraphFactory
+from pyams_content.features.renderer import RenderedContentMixin
from pyams_utils.adapter import adapter_config
from pyams_utils.registry import utility_config, get_utility
from pyams_utils.request import check_request
from pyams_utils.traversing import get_parent
+from pyams_utils.vocabulary import vocabulary_config
from zope.interface import implementer
+from zope.schema.fieldproperty import FieldProperty
+from zope.schema.vocabulary import SimpleVocabulary, SimpleTerm
from pyams_content import _
@implementer(IAssociationParagraph, IExtFileContainerTarget, ILinkContainerTarget)
-class AssociationParagraph(BaseParagraph):
+class AssociationParagraph(RenderedContentMixin, BaseParagraph):
"""Associations paragraph"""
icon_class = 'fa-link'
icon_hint = _("Associations paragraph")
+ renderer = FieldProperty(IAssociationParagraph['renderer'])
+
@utility_config(name=ASSOCIATION_PARAGRAPH_TYPE, provides=IParagraphFactory)
class AssociationParagraphFactory(BaseParagraphFactory):
@@ -80,3 +88,19 @@
else:
output.append(translate(MISSING_LANG_VALUE).format(field=field_title, lang=lang))
return output
+
+
+@vocabulary_config(name=ASSOCIATION_PARAGRAPH_RENDERERS)
+class AssociationParagraphRendererVocabulary(SimpleVocabulary):
+ """Associations paragraph renderers vocabulary"""
+
+ def __init__(self, context=None):
+ request = check_request()
+ translate = request.localizer.translate
+ registry = request.registry
+ if not IAssociationParagraph.providedBy(context):
+ context = AssociationParagraph()
+ terms = [SimpleTerm(name, title=translate(adapter.label))
+ for name, adapter in sorted(registry.getAdapters((context, request), IContentRenderer),
+ key=lambda x: x[1].weight)]
+ super(AssociationParagraphRendererVocabulary, self).__init__(terms)