QGIS API Documentation 3.38.0-Grenoble (exported)
Loading...
Searching...
No Matches
qgskeyvaluewidgetwrapper.cpp
Go to the documentation of this file.
1/***************************************************************************
2 qgskeyvaluewidgetwrapper.cpp
3 --------------------------------------
4 Date : 08.2016
5 Copyright : (C) 2016 Patrick Valsecchi
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
17#include "qgskeyvaluewidget.h"
18#include "qgsattributeform.h"
19
20QgsKeyValueWidgetWrapper::QgsKeyValueWidgetWrapper( QgsVectorLayer *layer, int fieldIdx, QWidget *editor, QWidget *parent ):
21 QgsEditorWidgetWrapper( layer, fieldIdx, editor, parent )
22{
23}
24
26{
27 if ( !mWidget ) return QgsVariantUtils::createNullVariant( QMetaType::Type::QVariantMap );
28 return mWidget->map();
29}
30
32{
33 mWidget->setMap( QVariantMap() );
34}
35
37{
38 if ( mWidget )
39 {
40 mWidget->setReadOnly( !enabled );
41 }
42}
43
44QWidget *QgsKeyValueWidgetWrapper::createWidget( QWidget *parent )
45{
46 if ( isInTable( parent ) )
47 {
48 // if to be put in a table, draw a border and set a decent size
49 QFrame *ret = new QFrame( parent );
50 ret->setFrameShape( QFrame::StyledPanel );
51 QHBoxLayout *layout = new QHBoxLayout( ret );
52 layout->addWidget( new QgsKeyValueWidget( ret ) );
53 ret->setMinimumSize( QSize( 320, 110 ) );
54 return ret;
55 }
56 else
57 {
58 return new QgsKeyValueWidget( parent );
59 }
60}
61
63{
64 mWidget = qobject_cast<QgsKeyValueWidget *>( editor );
65 if ( !mWidget )
66 {
67 mWidget = editor->findChild<QgsKeyValueWidget *>();
68 }
69
70 connect( mWidget, &QgsKeyValueWidget::valueChanged, this, &QgsKeyValueWidgetWrapper::onValueChanged );
71}
72
74{
75 return true;
76}
77
78void QgsKeyValueWidgetWrapper::updateValues( const QVariant &value, const QVariantList & )
79{
80 mWidget->setMap( value.toMap() );
81}
82
83void QgsKeyValueWidgetWrapper::updateConstraintWidgetStatus()
84{
85 // Nothing
86}
87
88void QgsKeyValueWidgetWrapper::onValueChanged()
89{
91}
Manages an editor widget Widget and wrapper share the same parent.
static bool isInTable(const QWidget *parent)
Check if the given widget or one of its parent is a QTableView.
void emitValueChanged()
Will call the value() method to determine the emitted value.
QVariant value() const override
Will be used to access the widget's value.
QWidget * createWidget(QWidget *parent) override
This method should create a new widget with the provided parent.
void showIndeterminateState() override
Sets the widget to display in an indeterminate "mixed value" state.
QgsKeyValueWidgetWrapper(QgsVectorLayer *layer, int fieldIdx, QWidget *editor=nullptr, QWidget *parent=nullptr)
Constructor for QgsKeyValueWidgetWrapper.
void initWidget(QWidget *editor) override
This method should initialize the editor widget with runtime data.
void setEnabled(bool enabled) override
bool valid() const override
Returns true if the widget has been properly initialized.
Widget allowing to edit a QVariantMap, using a table.
void setReadOnly(bool readOnly) override
void setMap(const QVariantMap &map)
Set the initial value of the widget.
void valueChanged()
Emitted each time a key or a value is changed.
static QVariant createNullVariant(QMetaType::Type metaType)
Helper method to properly create a null QVariant from a metaType Returns the created QVariant.
Represents a vector layer which manages a vector based data sets.