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 setWindowTitle( tr(
"%1 - Feature Attributes" ).arg( layer->
name() ) );
107 setLayout(
new QGridLayout() );
108 layout()->setContentsMargins( 0, 0, 0, 0 );
110 mMessageBar->setSizePolicy( QSizePolicy::MinimumExpanding, QSizePolicy::Fixed );
111 layout()->addWidget( mMessageBar );
113 setLayout( layout() );
117 if ( showDialogButtons )
122 layout()->addWidget( mAttributeForm );
123 QDialogButtonBox *buttonBox = mAttributeForm->findChild<QDialogButtonBox *>();
126 connect( layer, &QObject::destroyed,
this, &QWidget::close );
128 mMenu =
new QgsActionMenu( layer, mAttributeForm->
feature(), QStringLiteral(
"Feature" ),
this );
132 mMenuBar =
new QMenuBar(
this );
133 mMenuBar->addMenu( mMenu );
134 layout()->setMenuBar( mMenuBar );
143 mAttributeForm->
setMode( mode );
146 if ( !mMenu->
isEmpty() && !mMenuBar )
148 mMenuBar =
new QMenuBar(
this );
149 mMenuBar->addMenu( mMenu );
150 layout()->setMenuBar( mMenuBar );
152 else if ( mMenu->
isEmpty() && mMenuBar )
154 layout()->setMenuBar(
nullptr );
162 if ( e->type() == QEvent::WindowActivate && mHighlight )
164 else if ( e->type() == QEvent::WindowDeactivate && mHighlight )
167 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.