QGIS/python/gui/auto_generated/qgsexpressiontreeview.sip.in
2021-12-15 12:22:19 +01:00

288 lines
7.4 KiB
Plaintext

/************************************************************************
* This file has been generated automatically from *
* *
* src/gui/qgsexpressiontreeview.h *
* *
* Do not edit manually ! Edit header and run scripts/sipify.pl again *
************************************************************************/
class QgsExpressionItem : QStandardItem
{
%Docstring(signature="appended")
An expression item that can be used in the :py:class:`QgsExpressionBuilderWidget` tree.
%End
%TypeHeaderCode
#include "qgsexpressiontreeview.h"
%End
public:
enum ItemType
{
Header,
Field,
ExpressionNode
};
QgsExpressionItem( const QString &label,
const QString &expressionText,
const QString &helpText,
QgsExpressionItem::ItemType itemType = ExpressionNode );
QgsExpressionItem( const QString &label,
const QString &expressionText,
QgsExpressionItem::ItemType itemType = ExpressionNode );
QString getExpressionText() const;
QString getHelpText() const;
%Docstring
Gets the help text that is associated with this expression item.
:return: The help text.
%End
void setHelpText( const QString &helpText );
%Docstring
Set the help text for the current item
.. note::
The help text can be set as a html string.
%End
QgsExpressionItem::ItemType getItemType() const;
%Docstring
Gets the type of expression item, e.g., header, field, ExpressionNode.
:return: The QgsExpressionItem.ItemType
%End
static const int CUSTOM_SORT_ROLE;
static const int ITEM_TYPE_ROLE;
static const int SEARCH_TAGS_ROLE;
static const int ITEM_NAME_ROLE;
static const int LAYER_ID_ROLE;
};
class QgsExpressionItemSearchProxy : QSortFilterProxyModel
{
%Docstring(signature="appended")
Search proxy used to filter the :py:class:`QgsExpressionBuilderWidget` tree.
The default search for a tree model only searches top level this will handle one
level down
%End
%TypeHeaderCode
#include "qgsexpressiontreeview.h"
%End
public:
QgsExpressionItemSearchProxy();
virtual bool filterAcceptsRow( int source_row, const QModelIndex &source_parent ) const;
void setFilterString( const QString &string );
%Docstring
Sets the search filter ``string``.
.. versionadded:: 3.22
%End
protected:
virtual bool lessThan( const QModelIndex &left, const QModelIndex &right ) const;
};
class QgsExpressionTreeView : QTreeView
{
%Docstring(signature="appended")
:py:class:`QgsExpressionTreeView` is a tree view to list all expressions
functions, variables and fields that can be used in an expression.
.. seealso:: :py:class:`QgsExpressionBuilderWidget`
.. versionadded:: 3.14
%End
%TypeHeaderCode
#include "qgsexpressiontreeview.h"
%End
public:
class MenuProvider
{
%Docstring(signature="appended")
Implementation of this interface can be implemented to allow QgsExpressionTreeView
instance to provide custom context menus (opened upon right-click).
.. versionadded:: 3.14
%End
%TypeHeaderCode
#include "qgsexpressiontreeview.h"
%End
public:
explicit MenuProvider();
%Docstring
Constructor
%End
virtual ~MenuProvider();
virtual QMenu *createContextMenu( QgsExpressionItem *item ) /Factory/;
%Docstring
Returns a newly created menu instance
%End
};
QgsExpressionTreeView( QWidget *parent = 0 );
%Docstring
Constructor
%End
void setLayer( QgsVectorLayer *layer );
%Docstring
Sets layer in order to get the fields and values
%End
void loadFieldNames( const QgsFields &fields );
%Docstring
This allows loading fields without specifying a layer
%End
void setExpressionContext( const QgsExpressionContext &context );
%Docstring
Sets the expression context for the tree view. The context is used
to populate the list of available functions and variables.
:param context: expression context
.. seealso:: :py:func:`expressionContext`
%End
QgsExpressionContext expressionContext() const;
%Docstring
Returns the expression context for the widget. The context is used for the expression
preview result and for populating the list of available functions and variables.
.. seealso:: :py:func:`setExpressionContext`
%End
QgsProject *project();
%Docstring
Returns the project currently associated with the widget.
.. seealso:: :py:func:`setProject`
%End
void setProject( QgsProject *project );
%Docstring
Sets the ``project`` currently associated with the widget. This
controls which layers and relations and other project-specific items are shown in the widget.
.. seealso:: :py:func:`project`
%End
void setMenuProvider( MenuProvider *provider );
%Docstring
Sets the menu provider.
This does not take ownership of the provider
%End
void refresh();
%Docstring
Refreshes the content of the tree
%End
QgsExpressionItem *currentItem() const;
%Docstring
Returns the current item or a None
%End
void loadRecent( const QString &collection = QStringLiteral( "generic" ) );
%Docstring
Loads the recent expressions from the given ``collection``.
By default it is loaded from the collection "generic".
%End
void saveToRecent( const QString &expressionText, const QString &collection = "generic" );
%Docstring
Adds the current expression to the given ``collection``.
By default it is saved to the collection "generic".
%End
void saveToUserExpressions( const QString &label, const QString &expression, const QString &helpText );
%Docstring
Stores the user ``expression`` with given ``label`` and ``helpText``.
%End
void removeFromUserExpressions( const QString &label );
%Docstring
Removes the expression ``label`` from the user stored expressions.
%End
void loadUserExpressions( );
%Docstring
Loads the user expressions.
This is done on request since it can be very slow if there are thousands of user expressions
%End
const QList<QgsExpressionItem *> findExpressions( const QString &label );
%Docstring
Returns the list of expression items matching a ``label``.
%End
QJsonDocument exportUserExpressions();
%Docstring
Create the expressions JSON document storing all the user expressions to be exported.
:return: the created expressions JSON file
%End
void loadExpressionsFromJson( const QJsonDocument &expressionsDocument );
%Docstring
Load and permanently store the expressions from the expressions JSON document.
:param expressionsDocument: the parsed expressions JSON file
%End
signals:
void expressionItemDoubleClicked( const QString &text );
%Docstring
Emitted when a expression item is double clicked
%End
void currentExpressionItemChanged( QgsExpressionItem *item );
%Docstring
Emitter when the current expression item changed
%End
public slots:
void setSearchText( const QString &text );
%Docstring
Sets the text to filter the expression tree
%End
};
/************************************************************************
* This file has been generated automatically from *
* *
* src/gui/qgsexpressiontreeview.h *
* *
* Do not edit manually ! Edit header and run scripts/sipify.pl again *
************************************************************************/