QGIS API Documentation 3.99.0-Master (2fe06baccd8)
Loading...
Searching...
No Matches
qgseditorwidgetwrapper.h
Go to the documentation of this file.
1/***************************************************************************
2 qgseditorwidgetwrapper.h
3 --------------------------------------
4 Date : 20.4.2013
5 Copyright : (C) 2013 Matthias Kuhn
6 Email : matthias at opengis dot ch
7 ***************************************************************************
8 * *
9 * This program is free software; you can redistribute it and/or modify *
10 * it under the terms of the GNU General Public License as published by *
11 * the Free Software Foundation; either version 2 of the License, or *
12 * (at your option) any later version. *
13 * *
14 ***************************************************************************/
15
16#ifndef QGSEDITORWIDGETWRAPPER_H
17#define QGSEDITORWIDGETWRAPPER_H
18
19#include "qgis_sip.h"
20
21#include <QMap>
22#include <QObject>
23#include <QVariant>
24
25class QgsVectorLayer;
26class QgsField;
27
28#include "qgswidgetwrapper.h"
29#include "qgis_gui.h"
30#include "qgis_sip.h"
31
32
50{
51 Q_OBJECT
52
55
56 public:
66
75 explicit QgsEditorWidgetWrapper( QgsVectorLayer *vl, int fieldIdx, QWidget *editor = nullptr, QWidget *parent SIP_TRANSFERTHIS = nullptr );
76
86 virtual QVariant value() const = 0;
87
92 virtual QStringList additionalFields() const { return QStringList(); }
93
100 virtual QVariantList additionalFieldValues() const { return QVariantList(); }
101
109 int fieldIdx() const;
110
118 QgsField field() const;
119
127 QVariant defaultValue() const;
128
134 static QgsEditorWidgetWrapper *fromWidget( QWidget *widget ); // cppcheck-suppress duplInheritedMember
135
141 static bool isInTable( const QWidget *parent );
142
149 void setEnabled( bool enabled ) override;
150
154 virtual void showIndeterminateState() {}
155
162 void updateConstraint( const QgsFeature &featureContext, QgsFieldConstraints::ConstraintOrigin constraintOrigin = QgsFieldConstraints::ConstraintOriginNotSet );
163
173 void updateConstraint( const QgsVectorLayer *layer, int index, const QgsFeature &feature, QgsFieldConstraints::ConstraintOrigin constraintOrigin = QgsFieldConstraints::ConstraintOriginNotSet );
174
181 void updateConstraint( QgsEditorWidgetWrapper::ConstraintResult constraintResult, const QString &constraintFailureReason );
182
190 bool isValidConstraint() const;
191
197 bool isBlockingCommit() const;
198
204 QString constraintFailureReason() const;
205
210 virtual void setHint( const QString &hintText );
211
217 ConstraintResult constraintResult() const;
218
226 bool constraintResultVisible() const;
227
236 void setConstraintResultVisible( bool constraintResultVisible );
237
238 signals:
239
246 Q_DECL_DEPRECATED void valueChanged( const QVariant &value );
247
256 void valuesChanged( const QVariant &value, const QVariantList &additionalFieldValues = QVariantList() );
257
266 void constraintStatusChanged( const QString &constraint, const QString &desc, const QString &err, QgsEditorWidgetWrapper::ConstraintResult status );
267
271 void constraintResultVisibleChanged( bool visible );
272
273 public slots:
274
282 void setFeature( const QgsFeature &feature ) override;
283
284 // TODO Q_DECL_DEPRECATED
285
293 virtual void setValue( const QVariant &value ) SIP_DEPRECATED;
294
301 void setValues( const QVariant &value, const QVariantList &additionalValues );
302
306 void emitValueChanged();
307
319 virtual void parentFormValueChanged( const QString &attribute, const QVariant &value );
320
321 protected:
333 virtual void updateConstraintWidgetStatus();
334
335
342 QgsFeature formFeature() const { return mFormFeature; }
343
349 void setFormFeature( const QgsFeature &feature ) { mFormFeature = feature; }
350
358 bool setFormFeatureAttribute( const QString &attributeName, const QVariant &attributeValue );
359
360 private:
370 virtual void updateValues( const QVariant &value, const QVariantList &additionalValues = QVariantList() ); //TODO QGIS 4: make it pure virtual
371
372 // TODO QGIS 4: remove
373 bool isRunningDeprecatedSetValue = false;
374
378 int mFieldIdx = -1;
379
380 QList<int> mAdditionalFieldIndexes;
381
385 QgsFeature mFormFeature;
386
390 bool mValidConstraint = true;
391
393 bool mIsBlockingCommit = false;
394
396 QString mConstraintFailureReason;
397
399 ConstraintResult mConstraintResult = ConstraintResultPass;
400
402 bool mConstraintResultVisible = false;
403
404 mutable QVariant mDefaultValue; // Cache default value, we don't want to retrieve different serial numbers if called repeatedly
405};
406
407// We'll use this class inside a QVariant in the widgets properties
409
410#endif // QGSEDITORWIDGETWRAPPER_H
Manages an editor widget.
QgsFeature formFeature() const
The feature currently being edited, in its current state.
Q_DECL_DEPRECATED void valueChanged(const QVariant &value)
Emit this signal, whenever the value changed.
virtual void updateConstraintWidgetStatus()
This should update the widget with a visual cue if a constraint status changed.
void setFormFeature(const QgsFeature &feature)
Set the feature currently being edited to feature.
virtual QVariant value() const =0
Will be used to access the widget's value.
virtual QVariantList additionalFieldValues() const
Will be used to access the widget's values for potential additional fields handled by the widget.
virtual void parentFormValueChanged(const QString &attribute, const QVariant &value)
Is called in embedded form widgets when an attribute value in the parent form has changed.
virtual void showIndeterminateState()
Sets the widget to display in an indeterminate "mixed value" state.
QgsEditorWidgetWrapper(QgsVectorLayer *vl, int fieldIdx, QWidget *editor=nullptr, QWidget *parent=nullptr)
Create a new widget wrapper.
virtual QStringList additionalFields() const
Returns the list of additional fields which the editor handles.
void constraintResultVisibleChanged(bool visible)
Emit this signal when the constraint result visibility changed.
void valuesChanged(const QVariant &value, const QVariantList &additionalFieldValues=QVariantList())
Emit this signal, whenever the value changed.
void setValues(const QVariant &value, const QVariantList &additionalValues)
Is called when the value of the widget or additional field values needs to be changed.
void emitValueChanged()
Will call the value() method to determine the emitted value.
ConstraintResult
Result of constraint checks.
@ ConstraintResultFailSoft
Widget failed at least one soft (non-enforced) constraint.
@ ConstraintResultPass
Widget passed constraints successfully.
@ ConstraintResultFailHard
Widget failed at least one hard (enforced) constraint.
void constraintStatusChanged(const QString &constraint, const QString &desc, const QString &err, QgsEditorWidgetWrapper::ConstraintResult status)
Emit this signal when the constraint status changed.
virtual void setValue(const QVariant &value)
Is called when the value of the widget needs to be changed.
void setConstraintResultVisible(bool constraintResultVisible)
Sets whether the constraint result is visible.
The feature class encapsulates a single feature including its unique ID, geometry and a list of field...
Definition qgsfeature.h:58
ConstraintOrigin
Origin of constraints.
@ ConstraintOriginNotSet
Constraint is not set.
Encapsulate a field in an attribute table or data source.
Definition qgsfield.h:54
Represents a vector layer which manages a vector based dataset.
virtual void setFeature(const QgsFeature &feature)=0
Is called when the value of the widget needs to be changed.
static QgsWidgetWrapper * fromWidget(QWidget *widget)
Will return a wrapper for a given widget.
QgsWidgetWrapper(QgsVectorLayer *vl, QWidget *editor=nullptr, QWidget *parent=nullptr)
Create a new widget wrapper.
virtual void setEnabled(bool enabled)
Is used to enable or disable the edit functionality of the managed widget.
#define SIP_DEPRECATED
Definition qgis_sip.h:114
#define SIP_TRANSFERTHIS
Definition qgis_sip.h:53
Q_DECLARE_METATYPE(QgsDatabaseQueryLogEntry)