29 , mOwnedFeature( featureOwner ? thepFeature : nullptr )
31 init( vl, thepFeature, context, showDialogButtons );
47void QgsAttributeDialog::saveGeometry()
54void QgsAttributeDialog::restoreGeometry()
78 if ( error.isEmpty() )
79 error = tr(
"An unknown error was encountered saving attributes" );
83 Qgis::MessageLevel::Critical );
106 mTrackedVectorLayerTools.
rollback();
114 setWindowTitle( tr(
"%1 - Feature Attributes" ).arg( layer->
name() ) );
115 setLayout(
new QGridLayout() );
116 layout()->setContentsMargins( 0, 0, 0, 0 );
118 mMessageBar->setSizePolicy( QSizePolicy::MinimumExpanding, QSizePolicy::Fixed );
119 layout()->addWidget( mMessageBar );
121 setLayout( layout() );
125 if ( showDialogButtons )
130 layout()->addWidget( mAttributeForm );
131 QDialogButtonBox *buttonBox = mAttributeForm->findChild<QDialogButtonBox *>();
134 connect( layer, &QObject::destroyed,
this, &QWidget::close );
136 mMenu =
new QgsActionMenu( layer, mAttributeForm->
feature(), QStringLiteral(
"Feature" ),
this );
140 mMenuBar =
new QMenuBar(
this );
141 mMenuBar->addMenu( mMenu );
142 layout()->setMenuBar( mMenuBar );
149 mAttributeForm->
setMode( mode );
152 if ( !mMenu->
isEmpty() && !mMenuBar )
154 mMenuBar =
new QMenuBar(
this );
155 mMenuBar->addMenu( mMenu );
156 layout()->setMenuBar( mMenuBar );
158 else if ( mMenu->
isEmpty() && mMenuBar )
160 layout()->setMenuBar(
nullptr );
168 if ( e->type() == QEvent::WindowActivate && mHighlight )
170 else if ( e->type() == QEvent::WindowDeactivate && mHighlight )
173 return QDialog::event( e );
void setMode(QgsAttributeEditorContext::Mode mode)
Toggles the form mode.
const QgsFeature * feature()
~QgsAttributeDialog() override
bool event(QEvent *e) override
Intercept window activate/deactivate events to show/hide the highlighted feature.
QgsMapLayerActionContext createActionContext() override
Creates a QgsMapLayerActionContext.
void show()
Show the dialog non-blocking. Reparents this dialog to be a child of the dialog form.
void setExtraContextScope(QgsExpressionContextScope *extraScope)
Sets extraScope as an additional expression context scope to be used for calculations in this form.
void setHighlight(QgsHighlight *h)
setHighlight
QgsAttributeDialog(QgsVectorLayer *vl, QgsFeature *thepFeature, bool featureOwner, QWidget *parent=nullptr, bool showDialogButtons=true, const QgsAttributeEditorContext &context=QgsAttributeEditorContext())
Create an attribute dialog for a given layer and feature.
This class contains context information for attribute editor widgets.
const QgsVectorLayerTools * vectorLayerTools() const
Returns the associated vector layer tools.
@ StandaloneDialog
A form was opened as a new dialog.
void setFormMode(FormMode mode)
Sets the form mode.
void setVectorLayerTools(QgsVectorLayerTools *vlTools)
Sets the associated vector layer tools.
Single scope for storing variables and functions for use within a QgsExpressionContext.
The feature class encapsulates a single feature including its unique ID, geometry and a list of field...
A class for highlight features on the map.
Encapsulates the context in which a QgsMapLayerAction action is executed.
void setAttributeDialog(QgsAttributeDialog *dialog)
Sets the attribute dialog associated with the action's execution.
void setMessageBar(QgsMessageBar *bar)
Sets the message bar associated with the action's execution.
A bar for displaying non-blocking messages to the user.
void pushMessage(const QString &text, Qgis::MessageLevel level=Qgis::MessageLevel::Info, int duration=-1)
A convenience method for pushing a message with the specified text to the bar.
This class is a composition of two QSettings instances:
void setValue(const QString &key, const QVariant &value, QgsSettings::Section section=QgsSettings::NoSection)
Sets the value of setting key to value.
Represents a vector layer which manages a vector based data sets.
bool restoreGeometry(QWidget *widget, const QString &keyName)
Restore the wigget geometry from settings.
void saveGeometry(QWidget *widget, const QString &keyName)
Save the wigget geometry into settings.