QGIS API Documentation 3.28.0-Firenze (ed3ad0430f)
qgsattributeeditorelement.cpp
Go to the documentation of this file.
1/***************************************************************************
2 qgsattributeeditorelement.cpp - QgsAttributeEditorElement
3
4 ---------------------
5 begin : 18.8.2016
6 copyright : (C) 2016 by Matthias Kuhn
8 ***************************************************************************
9 * *
10 * This program is free software; you can redistribute it and/or modify *
11 * it under the terms of the GNU General Public License as published by *
12 * the Free Software Foundation; either version 2 of the License, or *
13 * (at your option) any later version. *
14 * *
15 ***************************************************************************/
16
18
25#include "qgssymbollayerutils.h"
26#include "qgsfontutils.h"
27
28QDomElement QgsAttributeEditorElement::toDomElement( QDomDocument &doc ) const
29{
30 QDomElement elem = doc.createElement( typeIdentifier() );
31 elem.setAttribute( QStringLiteral( "name" ), mName );
32 elem.setAttribute( QStringLiteral( "showLabel" ), mShowLabel );
33 elem.appendChild( mLabelStyle.writeXml( doc ) );
34 saveConfiguration( elem, doc );
35 return elem;
36}
37
39{
40 return mShowLabel;
41}
42
44{
46}
47
49{
50 return mLabelStyle;
51}
52
54{
56}
57
58QgsAttributeEditorElement *QgsAttributeEditorElement::create( const QDomElement &element, const QString &layerId, const QgsFields &fields, const QgsReadWriteContext &context, QgsAttributeEditorElement *parent )
59{
60 QgsAttributeEditorElement *newElement = nullptr;
61
62 const QString name = element.attribute( QStringLiteral( "name" ) );
63
64 if ( element.tagName() == QLatin1String( "attributeEditorContainer" ) )
65 {
66 newElement = new QgsAttributeEditorContainer( context.projectTranslator()->translate( QStringLiteral( "project:layers:%1:formcontainers" ).arg( layerId ),
67 name ), parent );
68 }
69 else if ( element.tagName() == QLatin1String( "attributeEditorField" ) )
70 {
71 const int idx = fields.lookupField( name );
72 newElement = new QgsAttributeEditorField( name, idx, parent );
73 }
74 else if ( element.tagName() == QLatin1String( "attributeEditorRelation" ) )
75 {
76 // At this time, the relations are not loaded
77 // So we only grab the id and delegate the rest to onRelationsLoaded()
78 newElement = new QgsAttributeEditorRelation( element.attribute( QStringLiteral( "relation" ), QStringLiteral( "[None]" ) ), parent );
79 }
80 else if ( element.tagName() == QLatin1String( "attributeEditorQmlElement" ) )
81 {
82 newElement = new QgsAttributeEditorQmlElement( element.attribute( QStringLiteral( "name" ) ), parent );
83 }
84 else if ( element.tagName() == QLatin1String( "attributeEditorHtmlElement" ) )
85 {
86 newElement = new QgsAttributeEditorHtmlElement( element.attribute( QStringLiteral( "name" ) ), parent );
87 }
88 else if ( element.tagName() == QLatin1String( "attributeEditorAction" ) )
89 {
90 newElement = new QgsAttributeEditorAction( QUuid( element.attribute( QStringLiteral( "name" ) ) ), parent );
91 }
92
93 if ( newElement )
94 {
95 if ( element.hasAttribute( QStringLiteral( "showLabel" ) ) )
96 newElement->setShowLabel( element.attribute( QStringLiteral( "showLabel" ) ).toInt() );
97 else
98 newElement->setShowLabel( true );
99
100 // Label font and color
101 LabelStyle style;
102 style.readXml( element );
103 newElement->setLabelStyle( style );
104
105 newElement->loadConfiguration( element, layerId, context, fields );
106 }
107
108 return newElement;
109}
110
111
113{
114 QDomElement element { node.firstChildElement( QStringLiteral( "labelStyle" ) ) };
115
116 if ( ! element.isNull() )
117 {
118
119 // Label font and color
120 if ( element.hasAttribute( QStringLiteral( "labelColor" ) ) )
121 {
122 color = QgsSymbolLayerUtils::decodeColor( element.attribute( QStringLiteral( "labelColor" ) ) );
123 }
124
125 QFont newFont;
126 QgsFontUtils::setFromXmlChildNode( newFont, element, QStringLiteral( "labelFont" ) );
127
128 font = newFont;
129
130 if ( element.hasAttribute( QStringLiteral( "overrideLabelColor" ) ) )
131 {
132 overrideColor = element.attribute( QStringLiteral( "overrideLabelColor" ) ) == QChar( '1' );
133 }
134
135 if ( element.hasAttribute( QStringLiteral( "overrideLabelFont" ) ) )
136 {
137 overrideFont = element.attribute( QStringLiteral( "overrideLabelFont" ) ) == QChar( '1' );
138 }
139 }
140}
141
142QDomElement QgsAttributeEditorElement::LabelStyle::writeXml( QDomDocument &document ) const
143{
144 QDomElement elem { document.createElement( QStringLiteral( "labelStyle" ) ) };
145 elem.setAttribute( QStringLiteral( "labelColor" ), QgsSymbolLayerUtils::encodeColor( color ) );
146 elem.appendChild( QgsFontUtils::toXmlElement( font, document, QStringLiteral( "labelFont" ) ) );
147 elem.setAttribute( QStringLiteral( "overrideLabelColor" ), overrideColor ? QChar( '1' ) : QChar( '0' ) );
148 elem.setAttribute( QStringLiteral( "overrideLabelFont" ), overrideFont ? QChar( '1' ) : QChar( '0' ) );
149 return elem;
150}
151
153{
154 return overrideColor == other.overrideColor && overrideFont == other.overrideFont && color == other.color && font == other.font;
155}
This element will load a layer action onto the form.
This is a container for attribute editors, used to group them visually in the attribute form if it is...
This is an abstract base class for any elements of a drag and drop form.
QDomElement toDomElement(QDomDocument &doc) const
Gets the XML Dom element to save this element.
QgsAttributeEditorElement * parent() const
Gets the parent of this element.
LabelStyle labelStyle() const
Returns the label style.
void setLabelStyle(const LabelStyle &labelStyle)
Sets the labelStyle.
bool showLabel() const
Controls if this element should be labeled with a title (field, relation or groupname).
QString name() const
Returns the name of this element.
static QgsAttributeEditorElement * create(const QDomElement &element, const QString &layerId, const QgsFields &fields, const QgsReadWriteContext &context, QgsAttributeEditorElement *parent=nullptr)
Constructs the editor element from the given element.
void setShowLabel(bool showLabel)
Controls if this element should be labeled with a title (field, relation or groupname).
This element will load a field's widget onto the form.
An attribute editor widget that will represent arbitrary HTML code.
An attribute editor widget that will represent arbitrary QML code.
This element will load a relation editor onto the form.
Container of fields for a vector layer.
Definition: qgsfields.h:45
int lookupField(const QString &fieldName) const
Looks up field's index from the field name.
Definition: qgsfields.cpp:349
static bool setFromXmlChildNode(QFont &font, const QDomElement &element, const QString &childNode)
Sets the properties of a font to match the properties stored in an XML child node.
static QDomElement toXmlElement(const QFont &font, QDomDocument &document, const QString &elementName)
Returns a DOM element containing the properties of the font.
virtual QString translate(const QString &context, const QString &sourceText, const char *disambiguation=nullptr, int n=-1) const =0
The derived translate() translates with QTranslator and qm file the sourceText.
The class is used as a container of context for various read/write operations on other objects.
const QgsProjectTranslator * projectTranslator() const
Returns the project translator.
static QColor decodeColor(const QString &str)
static QString encodeColor(const QColor &color)
The TabStyle struct defines color and font overrides for form fields, tabs and groups labels.
void readXml(const QDomNode &node)
Reads configuration from node.
QDomElement writeXml(QDomDocument &document) const
Creates the XML configuration from document.
bool operator==(LabelStyle const &other) const
Returns true if the style is equal to other.