QGIS API Documentation  3.24.2-Tisler (13c1a02865)
qgsdatasourcemanagerdialog.cpp
Go to the documentation of this file.
1 /***************************************************************************
2  qgsdatasourcemanagerdialog.cpp - datasource manager dialog
3 
4  ---------------------
5  begin : May 19, 2017
6  copyright : (C) 2017 by Alessandro Pasotti
7  email : apasotti at itopen dot it
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 
17 #include <QListWidgetItem>
18 
20 #include "ui_qgsdatasourcemanagerdialog.h"
21 #include "qgsbrowserdockwidget.h"
22 #include "qgssettings.h"
23 #include "qgsproviderregistry.h"
27 #include "qgsmapcanvas.h"
28 #include "qgsmessagelog.h"
29 #include "qgsmessagebar.h"
30 #include "qgsgui.h"
31 #include "qgsbrowserguimodel.h"
32 #include "qgsbrowserwidget.h"
33 
34 QgsDataSourceManagerDialog::QgsDataSourceManagerDialog( QgsBrowserGuiModel *browserModel, QWidget *parent, QgsMapCanvas *canvas, Qt::WindowFlags fl )
35  : QgsOptionsDialogBase( tr( "Data Source Manager" ), parent, fl )
36  , ui( new Ui::QgsDataSourceManagerDialog )
37  , mPreviousRow( -1 )
38  , mMapCanvas( canvas )
39  , mBrowserModel( browserModel )
40 {
41  ui->setupUi( this );
42  ui->verticalLayout_2->setSpacing( 6 );
43  ui->verticalLayout_2->setContentsMargins( 0, 0, 0, 0 );
44 
45  mMessageBar = new QgsMessageBar( this );
46  mMessageBar->setSizePolicy( QSizePolicy::MinimumExpanding, QSizePolicy::Fixed );
47  static_cast<QVBoxLayout *>( layout() )->insertWidget( 0, mMessageBar );
48 
49  // QgsOptionsDialogBase handles saving/restoring of geometry, splitter and current tab states,
50  // switching vertical tabs between icon/text to icon-only modes (splitter collapsed to left),
51  // and connecting QDialogButtonBox's accepted/rejected signals to dialog's accept/reject slots
52  initOptionsBase( false );
53 
54  // Bind list index to the stacked dialogs
55  connect( ui->mOptionsListWidget, &QListWidget::currentRowChanged, this, &QgsDataSourceManagerDialog::setCurrentPage );
56 
57  // BROWSER Add the browser widget to the first stacked widget page
58  mBrowserWidget = new QgsBrowserDockWidget( QStringLiteral( "Browser" ), mBrowserModel, this );
59  mBrowserWidget->setFeatures( QDockWidget::NoDockWidgetFeatures );
60  ui->mOptionsStackedWidget->addWidget( mBrowserWidget );
61  mPageNames.append( QStringLiteral( "browser" ) );
62  // Forward all browser signals
64  connect( mBrowserWidget, &QgsBrowserDockWidget::openFile, this, &QgsDataSourceManagerDialog::openFile );
67 
68  // Add provider dialogs
69  const QList<QgsSourceSelectProvider *> sourceSelectProviders = QgsGui::sourceSelectProviderRegistry()->providers( );
70  for ( QgsSourceSelectProvider *provider : sourceSelectProviders )
71  {
72  QgsAbstractDataSourceWidget *dlg = provider->createDataSourceWidget( this );
73  if ( !dlg )
74  {
75  QgsMessageLog::logMessage( tr( "Cannot get %1 select dialog from source select provider %2." ).arg( provider->name(), provider->providerKey() ), QStringLiteral( "DataSourceManager" ), Qgis::MessageLevel::Critical );
76  continue;
77  }
78  addProviderDialog( dlg, provider->providerKey(), provider->text(), provider->icon( ), provider->toolTip( ) );
79  }
80 
81  restoreOptionsBaseUi( tr( "Data Source Manager" ) );
82 }
83 
85 {
86  delete ui;
87 }
88 
89 void QgsDataSourceManagerDialog::openPage( const QString &pageName )
90 {
91  const int pageIdx = mPageNames.indexOf( pageName );
92  if ( pageIdx != -1 )
93  {
94  QTimer::singleShot( 0, this, [ = ] { setCurrentPage( pageIdx ); } );
95  }
96 }
97 
99 {
100  return mMessageBar;
101 }
102 
104 {
105  mPreviousRow = ui->mOptionsStackedWidget->currentIndex();
106  ui->mOptionsStackedWidget->setCurrentIndex( index );
107  setWindowTitle( tr( "Data Source Manager | %1" ).arg( ui->mOptionsListWidget->currentItem()->text() ) );
108  resizeAlltabs( index );
109 }
110 
112 {
113  const int prevPage = mPreviousRow != -1 ? mPreviousRow : 0;
114  setCurrentPage( prevPage );
115 }
116 
118 {
119  mBrowserWidget->browserWidget()->refresh();
121 }
122 
124 {
125  const int pageCount = ui->mOptionsStackedWidget->count();
126  for ( int i = 0; i < pageCount; ++i )
127  {
128  QWidget *widget = ui->mOptionsStackedWidget->widget( i );
129  QgsAbstractDataSourceWidget *dataSourceWidget = qobject_cast<QgsAbstractDataSourceWidget *>( widget );
130  if ( dataSourceWidget )
131  dataSourceWidget->reset();
132  }
133 }
134 
135 void QgsDataSourceManagerDialog::rasterLayerAdded( const QString &uri, const QString &baseName, const QString &providerKey )
136 {
137  emit addRasterLayer( uri, baseName, providerKey );
138 }
139 
140 void QgsDataSourceManagerDialog::rasterLayersAdded( const QStringList &layersList )
141 {
142  emit addRasterLayers( layersList );
143 }
144 
145 void QgsDataSourceManagerDialog::vectorLayerAdded( const QString &vectorLayerPath, const QString &baseName, const QString &providerKey )
146 {
147  emit addVectorLayer( vectorLayerPath, baseName, providerKey );
148 }
149 
150 void QgsDataSourceManagerDialog::vectorLayersAdded( const QStringList &layerQStringList, const QString &enc, const QString &dataSourceType )
151 {
152  emit addVectorLayers( layerQStringList, enc, dataSourceType );
153 }
154 
155 void QgsDataSourceManagerDialog::addProviderDialog( QgsAbstractDataSourceWidget *dlg, const QString &providerKey, const QString &providerName, const QIcon &icon, const QString &toolTip )
156 {
157  mPageNames.append( providerKey );
158  ui->mOptionsStackedWidget->addWidget( dlg );
159  QListWidgetItem *layerItem = new QListWidgetItem( providerName, ui->mOptionsListWidget );
160  layerItem->setToolTip( toolTip.isEmpty() ? tr( "Add %1 layer" ).arg( providerName ) : toolTip );
161  layerItem->setIcon( icon );
162  // Set crs and extent from canvas
163  if ( mMapCanvas )
164  {
165  dlg->setMapCanvas( mMapCanvas );
166  }
167  dlg->setBrowserModel( mBrowserModel );
168 
169  connect( dlg, &QgsAbstractDataSourceWidget::rejected, this, &QgsDataSourceManagerDialog::reject );
170  connect( dlg, &QgsAbstractDataSourceWidget::accepted, this, &QgsDataSourceManagerDialog::accept );
171  makeConnections( dlg, providerKey );
172 }
173 
174 void QgsDataSourceManagerDialog::makeConnections( QgsAbstractDataSourceWidget *dlg, const QString &providerKey )
175 {
176  // DB
181  // Vector
182  connect( dlg, &QgsAbstractDataSourceWidget::addVectorLayer, this, [ = ]( const QString & vectorLayerPath, const QString & baseName, const QString & specifiedProvider )
183  {
184  const QString key = specifiedProvider.isEmpty() ? providerKey : specifiedProvider;
185  this->vectorLayerAdded( vectorLayerPath, baseName, key );
186  }
187  );
191  // Raster
193  this, [ = ]( const QString & uri, const QString & baseName, const QString & providerKey )
194  {
195  addRasterLayer( uri, baseName, providerKey );
196  } );
199  // Mesh
201  // Vector tile
203  // Point Cloud
205  // Virtual
208  // Common
211 
212  // Message
213  connect( dlg, &QgsAbstractDataSourceWidget::pushMessage, this, [ = ]( const QString & title, const QString & message, const Qgis::MessageLevel level )
214  {
215  mMessageBar->pushMessage( title, message, level );
216  } );
217 }
218 
220 {
221  ui->mOptionsStackedWidget->currentWidget()->show();
223  resizeAlltabs( ui->mOptionsStackedWidget->currentIndex() );
224 }
MessageLevel
Level for messages This will be used both for message log and message bar in application.
Definition: qgis.h:107
Abstract base Data Source Widget to create connections and add layers This class provides common func...
void addPointCloudLayer(const QString &url, const QString &baseName, const QString &providerKey)
Emitted when a point cloud layer has been selected for addition.
void setMapCanvas(const QgsMapCanvas *mapCanvas)
Store a pointer to the map canvas to retrieve extent and CRS Used to select an appropriate CRS and po...
void pushMessage(const QString &title, const QString &message, const Qgis::MessageLevel level=Qgis::MessageLevel::Info)
Emitted when a message with title and level must be shown to the user using the parent visible messag...
void replaceVectorLayer(const QString &oldId, const QString &source, const QString &name, const QString &provider)
Emitted when a layer needs to be replaced.
void connectionsChanged()
Emitted when the provider's connections have changed This signal is normally forwarded the app and us...
void addRasterLayers(const QStringList &layersList)
Emitted when one or more GDAL supported layers are selected for addition.
void addMeshLayer(const QString &url, const QString &baseName, const QString &providerKey)
Emitted when a mesh layer has been selected for addition.
void addRasterLayer(const QString &rasterLayerPath, const QString &baseName, const QString &providerKey)
Emitted when a raster layer has been selected for addition.
virtual void refresh()
Triggered when the provider's connections need to be refreshed The default implementation does nothin...
void setBrowserModel(QgsBrowserModel *model)
Sets a browser model to use with the widget.
void progressMessage(QString message)
Emitted when a progress dialog is shown by the provider dialog.
void addVectorLayers(const QStringList &layerList, const QString &encoding, const QString &dataSourceType)
Emitted when one or more OGR supported layers are selected for addition.
void addVectorLayer(const QString &uri, const QString &layerName, const QString &providerKey=QString())
Emitted when a vector layer has been selected for addition.
void addDatabaseLayers(const QStringList &paths, const QString &providerKey)
Emitted when a DB layer has been selected for addition.
void addVectorTileLayer(const QString &url, const QString &baseName)
Emitted when a vector tile layer has been selected for addition.
virtual void reset()
Called when this source select widget is being shown in a "new and clean" dialog.
A dock widget containing a QgsBrowserWidget for navigating and managing data sources.
void connectionsChanged()
Connections changed in the browser.
QgsBrowserWidget * browserWidget()
Returns a pointer to the QgsBrowserWidget used by the dock widget.
void handleDropUriList(const QgsMimeDataUtils::UriList &)
Emitted when drop uri list needs to be handled.
void openFile(const QString &fileName, const QString &fileTypeHint=QString())
Emitted when a file needs to be opened.
A model for showing available data sources and other items in a structured tree.
void updateProjectHome()
Update project home directory.
void refresh()
Refreshes the browser model and view.
The QgsDataSourceManagerDialog class embeds the browser panel and all the provider dialogs.
void reset()
Resets the interface of the datasource manager after reopening the dialog.
void refresh()
Refresh the browser view.
void addVectorLayers(const QStringList &layerQStringList, const QString &enc, const QString &dataSourceType)
Emitted when a one or more layer were selected for addition: for signal forwarding to QgisApp.
void openFile(const QString &fileName, const QString &fileTypeHint=QString())
Emitted when a file needs to be opened.
void addMeshLayer(const QString &uri, const QString &baseName, const QString &providerKey)
Emitted when a mesh layer was selected for addition: for signal forwarding to QgisApp.
QgsMessageBar * messageBar() const
Returns the dialog's message bar.
void addPointCloudLayer(const QString &pointCloudLayerPath, const QString &baseName, const QString &providerKey)
Emitted when a point cloud layer was selected for addition: for signal forwarding to QgisApp.
QgsDataSourceManagerDialog(QgsBrowserGuiModel *browserModel, QWidget *parent=nullptr, QgsMapCanvas *canvas=nullptr, Qt::WindowFlags fl=QgsGuiUtils::ModalDialogFlags)
QgsDataSourceManagerDialog constructor.
void rasterLayersAdded(const QStringList &layersList)
One or more raster layer were added: for signal forwarding to QgisApp.
void setPreviousPage()
Reset current page to previously selected page.
void addVectorLayer(const QString &vectorLayerPath, const QString &baseName, const QString &providerKey)
Emitted when a vector layer was selected for addition: for signal forwarding to QgisApp.
void showStatusMessage(const QString &message)
Emitted when a status message needs to be shown: for signal forwarding to QgisApp.
void showEvent(QShowEvent *event) override
void replaceSelectedVectorLayer(const QString &oldId, const QString &uri, const QString &layerName, const QString &provider)
Replace the selected layer by a vector layer defined by uri, layer name, data source uri.
void addRasterLayer(const QString &uri, const QString &baseName, const QString &providerKey)
Emitted when a raster layer was selected for addition: for signal forwarding to QgisApp.
void openPage(const QString &pageName)
Open a given page in the dialog.
void connectionsChanged()
Emitted when a connection has changed inside the provider dialogs This signal is normally forwarded t...
void vectorLayersAdded(const QStringList &layerQStringList, const QString &enc, const QString &dataSourceType)
One or more vector layer were added: for signal forwarding to QgisApp.
void addDatabaseLayers(const QStringList &layerPathList, const QString &providerKey)
Emitted when a DB layer was selected for addition: for signal forwarding to QgisApp.
void handleDropUriList(const QgsMimeDataUtils::UriList &)
Emitted when drop uri list needs to be handled from the browser.
void addVectorTileLayer(const QString &uri, const QString &baseName)
Emitted when a vector tile layer was selected for addition: for signal forwarding to QgisApp.
void rasterLayerAdded(QString const &uri, QString const &baseName, QString const &providerKey)
A raster layer was added: for signal forwarding to QgisApp.
void providerDialogsRefreshRequested()
One or more provider connections have changed and the dialogs should be refreshed.
void updateProjectHome()
Update project home directory.
void setCurrentPage(int index)
Sync current page with the leftbar list.
void addRasterLayers(const QStringList &layersList)
Emitted when a one or more layer were selected for addition: for signal forwarding to QgisApp.
void vectorLayerAdded(const QString &vectorLayerPath, const QString &baseName, const QString &providerKey)
A vector layer was added: for signal forwarding to QgisApp.
static QgsSourceSelectProviderRegistry * sourceSelectProviderRegistry()
Returns the global source select provider registry, used for managing all known source select widget ...
Definition: qgsgui.cpp:94
Map canvas is a class for displaying all GIS data types on a canvas.
Definition: qgsmapcanvas.h:90
A bar for displaying non-blocking messages to the user.
Definition: qgsmessagebar.h:61
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.
static void logMessage(const QString &message, const QString &tag=QString(), Qgis::MessageLevel level=Qgis::MessageLevel::Warning, bool notifyUser=true)
Adds a message to the log instance (and creates it if necessary).
A base dialog for options and properties dialogs that offers vertical tabs.
void resizeAlltabs(int index)
Resizes all tabs when the dialog is resized.
void restoreOptionsBaseUi(const QString &title=QString())
Restore the base ui.
void initOptionsBase(bool restoreUi=true, const QString &title=QString())
Set up the base ui connections for vertical tabs.
void showEvent(QShowEvent *e) override
QList< QgsSourceSelectProvider * > providers()
Gets list of available providers.
This is the interface for those who want to add entries to the QgsDataSourceManagerDialog.