22 mRelation = relationManager->
relation( mRelationId );
29 element->mRelation = mRelation;
30 element->mButtons = mButtons;
31 element->mForceSuppressFormPopup = mForceSuppressFormPopup;
32 element->mNmRelationId = mNmRelationId;
33 element->mLabel = mLabel;
34 element->mRelationEditorConfig = mRelationEditorConfig;
35 element->mRelationWidgetTypeId = mRelationWidgetTypeId;
41void QgsAttributeEditorRelation::saveConfiguration( QDomElement &elem, QDomDocument &doc )
const
43 elem.setAttribute( QStringLiteral(
"relation" ), mRelation.
id() );
44 elem.setAttribute( QStringLiteral(
"forceSuppressFormPopup" ), mForceSuppressFormPopup );
45 elem.setAttribute( QStringLiteral(
"nmRelationId" ), mNmRelationId.toString() );
46 elem.setAttribute( QStringLiteral(
"label" ), mLabel );
47 elem.setAttribute( QStringLiteral(
"relationWidgetTypeId" ), mRelationWidgetTypeId );
50 elemConfig.setTagName( QStringLiteral(
"editor_configuration" ) );
51 elem.appendChild( elemConfig );
54void QgsAttributeEditorRelation::loadConfiguration(
const QDomElement &element,
const QString &layerId,
const QgsReadWriteContext &context,
const QgsFields &fields )
63 if ( config.isEmpty() )
67 if ( ! config.contains( QStringLiteral(
"buttons" ) ) )
69 if ( element.hasAttribute(
"buttons" ) )
97 if ( element.hasAttribute( QStringLiteral(
"nmRelationId" ) ) )
99 setNmRelationId( element.attribute( QStringLiteral(
"nmRelationId" ) ) );
102 if ( element.hasAttribute(
"label" ) )
104 const QString
label = element.attribute( QStringLiteral(
"label" ) );
107 if ( element.hasAttribute(
"relationWidgetTypeId" ) )
109 const QString
relationWidgetTypeId = element.attribute( QStringLiteral(
"relationWidgetTypeId" ) );
114QString QgsAttributeEditorRelation::typeIdentifier()
const
116 return QStringLiteral(
"attributeEditorRelation" );
126 return mForceSuppressFormPopup;
136 return mNmRelationId;
151 return mRelationWidgetTypeId;
161 return mRelationEditorConfig;
166 mRelationEditorConfig = config;
This is an abstract base class for any elements of a drag and drop form.
QgsAttributeEditorElement * parent() const
Gets the parent of this element.
This element will load a relation editor onto the form.
void setNmRelationId(const QVariant &nmRelationId=QVariant())
Sets nmRelationId for the relation id of the second relation involved in an N:M relation.
bool init(QgsRelationManager *relManager)
Initializes the relation from the id.
void setRelationWidgetTypeId(const QString &relationWidgetTypeId)
Sets the relation widget type.
QgsAttributeEditorElement * clone(QgsAttributeEditorElement *parent) const override
Returns a clone of this element.
QVariantMap relationEditorConfiguration() const
Returns the relation editor widget configuration.
void setForceSuppressFormPopup(bool forceSuppressFormPopup)
Sets force suppress form popup status to forceSuppressFormPopup.
@ SaveChildEdits
Save child edits button.
QVariant nmRelationId() const
Determines the relation id of the second relation involved in an N:M relation.
bool forceSuppressFormPopup() const
Determines the force suppress form popup status.
QString relationWidgetTypeId() const
Returns the current relation widget type id.
void setRelationEditorConfiguration(const QVariantMap &config)
Sets the relation editor configuration.
void setLabel(const QString &label=QString())
Sets label for this element If it's empty it takes the relation id as label.
QString label() const
Determines the label of this element.
Container of fields for a vector layer.
The class is used as a container of context for various read/write operations on other objects.
This class manages a set of relations between layers.
Q_INVOKABLE QgsRelation relation(const QString &id) const
Gets access to a relation by its id.
static QDomElement writeVariant(const QVariant &value, QDomDocument &doc)
Write a QVariant to a QDomElement.
static QVariant readVariant(const QDomElement &element)
Read a QVariant from a QDomElement.
#define Q_NOWARN_DEPRECATED_POP
QString qgsFlagValueToKeys(const T &value, bool *returnOk=nullptr)
Returns the value for the given keys of a flag.
T qgsFlagKeysToValue(const QString &keys, const T &defaultValue, bool tryValueAsKey=true, bool *returnOk=nullptr)
Returns the value corresponding to the given keys of a flag.
#define Q_NOWARN_DEPRECATED_PUSH