2012-04-16 13:19:40 +02:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
|
|
|
"""
|
|
|
|
/***************************************************************************
|
|
|
|
Name : DB Manager
|
2013-06-09 18:28:52 +02:00
|
|
|
Description : Database manager plugin for QGIS
|
2012-04-16 13:19:40 +02:00
|
|
|
Date : May 23, 2011
|
|
|
|
copyright : (C) 2011 by Giuseppe Sucameli
|
|
|
|
email : brush.tyler@gmail.com
|
|
|
|
|
|
|
|
***************************************************************************/
|
|
|
|
|
|
|
|
/***************************************************************************
|
|
|
|
* *
|
|
|
|
* This program is free software; you can redistribute it and/or modify *
|
|
|
|
* it under the terms of the GNU General Public License as published by *
|
|
|
|
* the Free Software Foundation; either version 2 of the License, or *
|
|
|
|
* (at your option) any later version. *
|
|
|
|
* *
|
|
|
|
***************************************************************************/
|
|
|
|
"""
|
2016-09-21 18:24:26 +02:00
|
|
|
from builtins import object
|
2012-04-16 13:19:40 +02:00
|
|
|
|
2016-04-22 10:38:48 +02:00
|
|
|
from qgis.PyQt.QtCore import Qt
|
|
|
|
from qgis.PyQt.QtWidgets import QAction, QApplication
|
|
|
|
from qgis.PyQt.QtGui import QIcon
|
2016-03-15 23:41:19 +01:00
|
|
|
|
2019-03-27 07:20:43 +10:00
|
|
|
from qgis.core import (
|
|
|
|
QgsProject,
|
|
|
|
QgsMapLayerType,
|
|
|
|
QgsDataSourceUri,
|
|
|
|
QgsApplication
|
|
|
|
)
|
2016-07-20 12:19:07 +02:00
|
|
|
|
2016-03-21 04:51:10 +01:00
|
|
|
from . import resources_rc # NOQA
|
2012-04-16 13:19:40 +02:00
|
|
|
|
|
|
|
|
2016-09-21 18:24:26 +02:00
|
|
|
class DBManagerPlugin(object):
|
2015-08-22 14:29:41 +02:00
|
|
|
|
2015-03-21 10:41:58 +10:00
|
|
|
def __init__(self, iface):
|
|
|
|
self.iface = iface
|
|
|
|
self.dlg = None
|
|
|
|
|
|
|
|
def initGui(self):
|
2018-05-16 07:45:35 +10:00
|
|
|
self.action = QAction(QgsApplication.getThemeIcon('dbmanager.svg'), QApplication.translate("DBManagerPlugin", "DB Manager…"),
|
2015-03-21 10:41:58 +10:00
|
|
|
self.iface.mainWindow())
|
2017-10-03 22:03:47 +13:00
|
|
|
|
2015-03-21 10:41:58 +10:00
|
|
|
self.action.setObjectName("dbManager")
|
2016-03-15 23:41:19 +01:00
|
|
|
self.action.triggered.connect(self.run)
|
2015-03-21 10:41:58 +10:00
|
|
|
# Add toolbar button and menu item
|
|
|
|
if hasattr(self.iface, 'addDatabaseToolBarIcon'):
|
|
|
|
self.iface.addDatabaseToolBarIcon(self.action)
|
|
|
|
else:
|
|
|
|
self.iface.addToolBarIcon(self.action)
|
|
|
|
if hasattr(self.iface, 'addPluginToDatabaseMenu'):
|
2018-05-16 07:38:07 +10:00
|
|
|
self.iface.addPluginToDatabaseMenu(QApplication.translate("DBManagerPlugin", None), self.action)
|
2015-03-21 10:41:58 +10:00
|
|
|
else:
|
|
|
|
self.iface.addPluginToMenu(QApplication.translate("DBManagerPlugin", "DB Manager"), self.action)
|
2012-04-16 13:19:40 +02:00
|
|
|
|
2015-03-21 10:41:58 +10:00
|
|
|
def unload(self):
|
|
|
|
# Remove the plugin menu item and icon
|
2018-05-16 07:38:07 +10:00
|
|
|
if hasattr(self.iface, 'databaseMenu'):
|
|
|
|
self.iface.databaseMenu().removeAction(self.action)
|
2015-03-21 10:41:58 +10:00
|
|
|
else:
|
|
|
|
self.iface.removePluginMenu(QApplication.translate("DBManagerPlugin", "DB Manager"), self.action)
|
|
|
|
if hasattr(self.iface, 'removeDatabaseToolBarIcon'):
|
|
|
|
self.iface.removeDatabaseToolBarIcon(self.action)
|
|
|
|
else:
|
|
|
|
self.iface.removeToolBarIcon(self.action)
|
2012-04-16 13:19:40 +02:00
|
|
|
|
2015-03-21 10:41:58 +10:00
|
|
|
if self.dlg is not None:
|
|
|
|
self.dlg.close()
|
2012-12-10 00:12:07 +01:00
|
|
|
|
2016-07-20 12:19:07 +02:00
|
|
|
def onUpdateSqlLayer(self):
|
2017-10-06 17:38:17 +02:00
|
|
|
# Be able to update every Db layer from Postgres, Spatialite and Oracle
|
2016-11-22 12:21:47 +08:00
|
|
|
l = self.iface.activeLayer()
|
2016-07-20 12:19:07 +02:00
|
|
|
if l.dataProvider().name() in ['postgres', 'spatialite', 'oracle']:
|
2017-10-06 17:38:17 +02:00
|
|
|
self.run()
|
|
|
|
self.dlg.runSqlLayerWindow(l)
|
2016-07-20 12:19:07 +02:00
|
|
|
# virtual has QUrl source
|
|
|
|
# url = QUrl(QUrl.fromPercentEncoding(l.source()))
|
|
|
|
# url.queryItemValue('query')
|
|
|
|
# url.queryItemValue('uid')
|
|
|
|
# url.queryItemValue('geometry')
|
|
|
|
|
2015-03-21 10:41:58 +10:00
|
|
|
def run(self):
|
|
|
|
# keep opened only one instance
|
|
|
|
if self.dlg is None:
|
2016-03-15 23:41:19 +01:00
|
|
|
from .db_manager import DBManager
|
2012-04-16 13:19:40 +02:00
|
|
|
|
2015-03-21 10:41:58 +10:00
|
|
|
self.dlg = DBManager(self.iface)
|
2016-03-15 23:41:19 +01:00
|
|
|
self.dlg.destroyed.connect(self.onDestroyed)
|
2015-03-21 10:41:58 +10:00
|
|
|
self.dlg.show()
|
|
|
|
self.dlg.raise_()
|
|
|
|
self.dlg.setWindowState(self.dlg.windowState() & ~Qt.WindowMinimized)
|
|
|
|
self.dlg.activateWindow()
|
2012-04-16 13:19:40 +02:00
|
|
|
|
2015-03-21 10:41:58 +10:00
|
|
|
def onDestroyed(self, obj):
|
|
|
|
self.dlg = None
|