File: index.rst

package info (click to toggle)
django-polymorphic 4.10.2-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 2,104 kB
  • sloc: python: 12,304; javascript: 280; makefile: 15
file content (155 lines) | stat: -rw-r--r-- 5,437 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
.. _integrations:

Integrations
============

When integrating polymorphic models into third party apps you have three primary options:

0. Hope it just works (it might!).
1. Ensure the querysets the third party apps see are
   :meth:`not polymorphic <polymorphic.query.PolymorphicQuerySet.non_polymorphic>`.
2. Override or extend relevant third party app code to work with polymorphic querysets.

If it does not just work, option 1 is usually the easiest. We provide some integrations in
:mod:`polymorphic.contrib` for popular third party apps and provide guidance for others below.

This page does not exhaustively cover all integrations. If you feel your integration need is
very common you may consider opening a PR to either provide support in code or documentation here.

This page covers supported and tested integration advice. For all other integration advice please
refer to `our integrations discussion page
<https://github.com/jazzband/django-polymorphic/discussions/categories/integrations>`_.

For the integration examples on this page, we use the following polymorphic model hierarchy:

.. literalinclude:: ../../src/polymorphic/tests/examples/integrations/models.py
    :language: python
    :linenos:

.. _django-django-guardian-support:

django-guardian
---------------

.. versionadded:: 1.0.2

No special modifications are required to integrate with :pypi:`django-guardian`. However, if you
would like all object level permissions to be managed at the base model level, rather than have
unique permissions for each polymorphic subclass, then you can use the helper function
:func:`polymorphic.contrib.guardian.get_polymorphic_base_content_type` to unify the permissions
for your entire polymorphic model tree into a single namespace a the base level:

.. code-block:: python

    GUARDIAN_GET_CONTENT_TYPE = \
        "polymorphic.contrib.guardian.get_polymorphic_base_content_type"

This option requires :pypi:`django-guardian` >= 1.4.6. Details about how this option works are
available in the `django-guardian documentation
<https://django-guardian.readthedocs.io/en/stable/configuration>`_.

.. _django-extra-views-support:

django-extra-views
------------------

.. versionadded:: 1.1

The :mod:`polymorphic.contrib.extra_views` package provides classes to display polymorphic formsets
using the classes from :pypi:`django-extra-views`. See the documentation of:

* :class:`~polymorphic.contrib.extra_views.PolymorphicFormSetView`
* :class:`~polymorphic.contrib.extra_views.PolymorphicInlineFormSetView`
* :class:`~polymorphic.contrib.extra_views.PolymorphicInlineFormSet`

.. tip::

    The complete working code for this example can be found `in the extra_views integration test
    <https://github.com/jazzband/django-polymorphic/tree/HEAD/src/polymorphic/tests/examples/integrations/extra_views>`_.


Example View
~~~~~~~~~~~~

Here's how to create a view using :class:`~polymorphic.contrib.extra_views.PolymorphicFormSetView`
to handle polymorphic formsets:

.. literalinclude:: ../../src/polymorphic/tests/examples/integrations/extra_views/views.py
    :language: python
    :linenos:


URL Configuration
~~~~~~~~~~~~~~~~~

Configure the URL patterns to route to your formset view:

.. literalinclude:: ../../src/polymorphic/tests/examples/integrations/extra_views/urls.py
    :language: python
    :linenos:


Template
~~~~~~~~

The template for rendering the formset:

.. literalinclude:: ../../src/polymorphic/tests/examples/integrations/extra_views/templates/extra_views/article_formset.html
    :language: html+django

``model_name`` is a template tag implemented like so:

.. literalinclude:: ../../src/polymorphic/tests/examples/integrations/extra_views/templatetags/extra_views_tags.py
    :language: python
    :lines: 6-

.. _django-reversion-support:

django-reversion
----------------

Support for :pypi:`django-reversion` works as expected with polymorphic models. We just need to
do two things:

1. Inherit our admin classes from both :class:`~polymorphic.admin.PolymorphicParentModelAdmin` /
   :class:`~polymorphic.admin.PolymorphicChildModelAdmin` and
   :ref:`VersionAdmin <django-reversion:versionadmin>`.
2. Override the ``admin/polymorphic/object_history.html`` template.

.. tip::

    The complete working code for this example can be found `in the reversion integration test
    <https://github.com/jazzband/django-polymorphic/tree/HEAD/src/polymorphic/tests/examples/integrations/reversion>`_.


Admin Configuration
~~~~~~~~~~~~~~~~~~~

The admin configuration combines :class:`~polymorphic.admin.PolymorphicParentModelAdmin` and
:class:`~polymorphic.admin.PolymorphicChildModelAdmin` with
:ref:`VersionAdmin <django-reversion:versionadmin>`:

.. literalinclude:: ../../src/polymorphic/tests/examples/integrations/reversion/admin.py
    :language: python
    :linenos:


Custom Template
~~~~~~~~~~~~~~~

Since both :class:`~polymorphic.admin.PolymorphicParentModelAdmin` and
:ref:`VersionAdmin <django-reversion:versionadmin>`. define ``object_history.html`` template, you
need to create a custom template that combines both:

.. literalinclude:: ../../src/polymorphic/tests/examples/integrations/reversion/templates/admin/polymorphic/object_history.html
    :language: html+django

This makes sure both the reversion template is used, and the breadcrumb is corrected for the
polymorphic model using the :templatetag:`breadcrumb_scope`
tag.


.. toctree::

   djangorestframework