aboutsummaryrefslogtreecommitdiffstats
path: root/sources/pyside6/doc/extras/QtQml.QmlForeign.rst
blob: c58be3cb966660eabf9429bf8f0780709a766c25 (plain)
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
.. currentmodule:: PySide6.QtQml
.. _QmlForeign:

QmlForeign
**********

.. py:decorator:: QmlForeign

   This decorator can be used to change the type that is created by QML.

   This is useful for registering types that cannot be amended by adding the
   QmlElement decorator, for example because they belong to 3rdparty libraries.

   .. code-block:: python

      QML_IMPORT_NAME = "com.library.name"
      QML_IMPORT_MAJOR_VERSION = 1
      QML_IMPORT_MINOR_VERSION = 0 # Optional

      @QmlNamedElement("QWidget")
      @QmlForeign(QWidget)
      class ForeignWidgetHelperClass(QObject):
          ...

   Afterwards the class may be used in QML:

   .. code-block:: javascript

      import com.library.name 1.0

      QWidget {
         // ...
      }