Add splitter to Execute sql window

Allow resizing the query editor/results table, and remember
sizes
This commit is contained in:
Nyall Dawson 2025-03-25 15:19:23 +10:00
parent a0c5680b64
commit 2be0a809bd
No known key found for this signature in database
GPG Key ID: 4C61673F0BF197FC
2 changed files with 98 additions and 55 deletions

View File

@ -51,6 +51,16 @@ QgsQueryResultWidget::QgsQueryResultWidget( QWidget *parent, QgsAbstractDatabase
// Unsure :/
// mSqlEditor->setLineNumbersVisible( true );
splitter->setCollapsible( 0, false );
splitter->setCollapsible( 1, false );
QgsSettings settings;
splitter->restoreState( settings.value( QStringLiteral( "Windows/QueryResult/SplitState" ) ).toByteArray() );
connect( splitter, &QSplitter::splitterMoved, this, [this] {
QgsSettings settings;
settings.setValue( QStringLiteral( "Windows/QueryResult/SplitState" ), splitter->saveState() );
} );
mToolBar->setIconSize( QgsGuiUtils::iconSize( false ) );
mPresetQueryMenu = new QMenu( this );

View File

@ -75,61 +75,94 @@
<number>6</number>
</property>
<item>
<widget class="QWidget" name="mSqlEditorContainer" native="true"/>
</item>
<item>
<layout class="QHBoxLayout" name="progressLayout" stretch="0,0,0,1,0">
<item>
<widget class="QPushButton" name="mExecuteButton">
<property name="enabled">
<bool>false</bool>
</property>
<property name="text">
<string>Execute</string>
</property>
</widget>
</item>
<item>
<widget class="QPushButton" name="mStopButton">
<property name="enabled">
<bool>false</bool>
</property>
<property name="text">
<string>Stop</string>
</property>
</widget>
</item>
<item>
<widget class="QLabel" name="mStatusLabel">
<property name="text">
<string>Status and errors goes here.</string>
</property>
</widget>
</item>
<item>
<spacer name="horizontalSpacer">
<property name="orientation">
<enum>Qt::Horizontal</enum>
</property>
<property name="sizeHint" stdset="0">
<size>
<width>40</width>
<height>20</height>
</size>
</property>
</spacer>
</item>
<item>
<widget class="QProgressBar" name="mProgressBar">
<property name="value">
<number>24</number>
</property>
</widget>
</item>
</layout>
</item>
<item>
<widget class="QTableView" name="mQueryResultsTableView"/>
<widget class="QWidget" name="widget" native="true">
<layout class="QVBoxLayout" name="verticalLayout_4">
<property name="leftMargin">
<number>0</number>
</property>
<property name="topMargin">
<number>0</number>
</property>
<property name="rightMargin">
<number>0</number>
</property>
<property name="bottomMargin">
<number>0</number>
</property>
<item>
<widget class="QSplitter" name="splitter">
<property name="frameShape">
<enum>QFrame::NoFrame</enum>
</property>
<property name="orientation">
<enum>Qt::Vertical</enum>
</property>
<widget class="QWidget" name="verticalLayoutWidget">
<layout class="QVBoxLayout" name="verticalLayout_3">
<property name="topMargin">
<number>0</number>
</property>
<item>
<widget class="QWidget" name="mSqlEditorContainer" native="true"/>
</item>
<item>
<layout class="QHBoxLayout" name="progressLayout" stretch="0,0,0,1,0">
<item>
<widget class="QPushButton" name="mExecuteButton">
<property name="enabled">
<bool>false</bool>
</property>
<property name="text">
<string>Execute</string>
</property>
</widget>
</item>
<item>
<widget class="QPushButton" name="mStopButton">
<property name="enabled">
<bool>false</bool>
</property>
<property name="text">
<string>Stop</string>
</property>
</widget>
</item>
<item>
<widget class="QLabel" name="mStatusLabel">
<property name="text">
<string>Status and errors goes here.</string>
</property>
</widget>
</item>
<item>
<spacer name="horizontalSpacer">
<property name="orientation">
<enum>Qt::Horizontal</enum>
</property>
<property name="sizeHint" stdset="0">
<size>
<width>40</width>
<height>20</height>
</size>
</property>
</spacer>
</item>
<item>
<widget class="QProgressBar" name="mProgressBar">
<property name="value">
<number>24</number>
</property>
</widget>
</item>
</layout>
</item>
</layout>
</widget>
<widget class="QTableView" name="mQueryResultsTableView"/>
</widget>
</item>
</layout>
</widget>
</item>
<item>
<widget class="QgsCodeEditorSQL" name="mSqlErrorText" native="true"/>