.. _tutorial-module-extend:
Extend model
============
Sometimes we want to extend an existing :class:`~trytond.model.Model` to add
:class:`~trytond.model.fields.Field` or methods.
This can be done using the extension mechanism of Tryton which can combine
classes with the same ``__name__`` that are registered in the
:class:`~trytond.pool.Pool`.
Extend the Party model
----------------------
Let's add an ``opportunities`` field on the ``party.party`` model.
The model in :file:`party.py` file of our module looks like this:
.. code-block:: python
from trytond.model import fields
from trytond.pool import PoolMeta
class Party(metaclass=PoolMeta):
__name__ = 'party.party'
opportunities = fields.One2Many(
'training.opportunity', 'party', "Opportunities")
This new class must be register in the :class:`~trytond.pool.Pool`.
So in :file:`__init__.py` we add:
.. code-block:: python
from . import party
def register():
Pool.register(
...,
party.Party,
module='opportunity', type_='model')
Extend the Party view
---------------------
Now that we added a new field to the ``party.party``
:class:`~trytond.model.Model`, we can also add it the form view.
This is done by adding a ``ir.ui.view`` record that inherit the party form view
of the ``party`` module.
Here is the content of the :file:`party.xml` file:
.. code-block:: xml
party.party
party_form
The ``type`` is replaced by:
``inherit``
A reference to the XML id of the view extended prefixed by the name of the
module where the view is declared.
The content of the inheriting view must contain an XPath_ expression to define
the position from which to include the partial view XML.
Here is the content of the form view in :file:`view/party_form.xml`:
.. code-block:: xml
.. _XPath: https://en.wikipedia.org/wiki/XPath
And finally we must declare the new XML data in the :file:`tryton.cfg` file:
.. code-block:: ini
[tryton]
...
xml:
...
party.xml
Update database
---------------
As we have defined new field and XML record, we need to update the database
with:
.. code-block:: console
$ trytond-admin -d test --all
And restart the server and reconnect with the client to see the new field on
the party:
.. code-block:: console
$ trytond
Let's use a :ref:`wizard to convert the opportunity `.