Compare commits

..

No commits in common. "6c1af3c61c742d0810d454b3644079794ee1e27c" and "7df08ae02adf9b952d4240f33e6309f222a11867" have entirely different histories.

22 changed files with 1390 additions and 1274 deletions

View File

@ -4,25 +4,27 @@ __email__ = "info@3liz.org"
from qgis.core import QgsApplication from qgis.core import QgsApplication
from qgis.PyQt.QtCore import QSettings, QUrl from qgis.PyQt.QtCore import QCoreApplication, Qt, QTranslator, QUrl
from qgis.PyQt.QtGui import QDesktopServices, QIcon from qgis.PyQt.QtGui import QDesktopServices, QIcon
from qgis.PyQt.QtWidgets import QAction from qgis.PyQt.QtWidgets import QAction, QMessageBox
from qgis.utils import iface from qgis.utils import iface
import qgis import qgis
# include <QSettings> #include <QSettings>
import socket
import os import os
from .about_form import AboutDialog
from .tools.resources import ( from .tools.resources import (
# plugin_path, plugin_path,
pyperclip, pyperclip,
resources_path, resources_path,
maj_verif, maj_verif,
) )
pyperclip() pyperclip()
from .copie_editor import Copie_Editor from .copie_editor import Copie_Editor
from .about_form import AboutDialog
from qgis.PyQt.QtCore import *
class PgCopie: class PgCopie:
def __init__(self): def __init__(self):
@ -34,18 +36,18 @@ class PgCopie:
self.dock_action = None self.dock_action = None
self.help_action = None self.help_action = None
plugin_dir = os.path.dirname(__file__) plugin_dir = os.path.dirname(__file__)
end_find = plugin_dir.rfind('\\') + 1 end_find = plugin_dir.rfind('\\')+1
global NAME global NAME
NAME = plugin_dir[end_find:] NAME = plugin_dir[end_find:]
maj_verif(NAME) maj_verif(NAME)
# Display About window on first use # Display About window on first use
version = qgis.utils.pluginMetadata('CenRa_COPIE', 'version') version = qgis.utils.pluginMetadata('CenRa_COPIE','version')
s = QSettings() s = QSettings()
versionUse = s.value("copie/version", 1, type=str) versionUse = s.value("copie/version", 1, type=str)
if str(versionUse) != str(version): if str(versionUse) != str(version) :
s.setValue("copie/version", str(version)) s.setValue("copie/version", str(version))
print(versionUse, version) print(versionUse,version)
self.open_about_dialog() self.open_about_dialog()
def initGui(self): def initGui(self):
@ -63,12 +65,12 @@ class PgCopie:
if not self.action_editor: if not self.action_editor:
self.action_editor = Copie_Editor() self.action_editor = Copie_Editor()
self.copie_editor = QAction(icon, 'Copie', None) self.copie_editor = QAction(icon, 'Copie',None)
self.toolBar.addAction(self.copie_editor) self.toolBar.addAction(self.copie_editor)
self.copie_editor.triggered.connect(self.open_editor) self.copie_editor.triggered.connect(self.open_editor)
self.copie_editor.setEnabled(False) self.copie_editor.setEnabled(False)
# IPAddr = socket.gethostbyname(socket.gethostname()) IPAddr=socket.gethostbyname(socket.gethostname())
if os.access('N:/', os.R_OK): if os.access('N:/',os.R_OK):
self.copie_editor.setEnabled(True) self.copie_editor.setEnabled(True)
def open_about_dialog(self): def open_about_dialog(self):
@ -77,7 +79,6 @@ class PgCopie:
""" """
dialog = AboutDialog(iface) dialog = AboutDialog(iface)
dialog.exec() dialog.exec()
def open_help(): def open_help():
""" Open the online help. """ """ Open the online help. """
QDesktopServices.openUrl(QUrl('https://plateformesig.cenra-outils.org/')) QDesktopServices.openUrl(QUrl('https://plateformesig.cenra-outils.org/'))
@ -89,7 +90,8 @@ class PgCopie:
def unload(self): def unload(self):
""" Unload the plugin. """ """ Unload the plugin. """
if self.action_editor: if self.action_editor:
iface.removePluginMenu('CenRa_Copie', self.copie_editor) iface.removePluginMenu('CenRa_Copie',self.copie_editor)
if self.provider: if self.provider:
QgsApplication.processingRegistry().removeProvider(self.provider) QgsApplication.processingRegistry().removeProvider(self.provider)

View File

@ -3,7 +3,7 @@ import os.path
from pathlib import Path from pathlib import Path
from qgis.PyQt import uic from qgis.PyQt import uic
# from qgis.PyQt.QtGui import QPixmap from qgis.PyQt.QtGui import QPixmap
from qgis.PyQt.QtWidgets import QDialog from qgis.PyQt.QtWidgets import QDialog
from .tools.resources import devlog from .tools.resources import devlog

View File

@ -4,70 +4,78 @@ from __future__ import absolute_import
# Import the PyQt and QGIS libraries # Import the PyQt and QGIS libraries
from builtins import next from builtins import next
from builtins import str from builtins import str
# from builtins import object from builtins import object
# import qgis import qgis
from qgis.PyQt.QtCore import QSettings from qgis.PyQt.QtCore import QSettings
from qgis.PyQt.QtWidgets import QDialog, QMessageBox from qgis.PyQt.QtWidgets import QAction, QMenu, QDialog
from qgis.PyQt.QtGui import QIcon
from qgis.PyQt.QtCore import *
from qgis.PyQt.QtGui import *
from qgis.PyQt import QtGui from qgis.PyQt import QtGui
from qgis.core import QgsDataSourceUri, QgsSettings, QgsWkbTypes
from qgis.core import *
from qgis.core import QgsDataSourceUri
import os
try: try:
from .tools.PythonSQL import login_base from .tools.PythonSQL import login_base
except ValueError: except:
print('Pas de fichier PythonSQL') print('Pas de fichier PythonSQL')
from .tools.SQLRequet import *
from .tools.resources import ( from .tools.resources import (
load_ui, load_ui,
resources_path, resources_path,
# send_issues, send_issues,
) )
# from .issues import CenRa_Issues from .issues import CenRa_Issues
from qgis.utils import iface from qgis.utils import iface
# import os import os.path
# import os.path import webbrowser, os
# import webbrowser import psycopg2
# import psycopg2 import psycopg2.extras
# import psycopg2.extras import base64
# import base64
EDITOR_CLASS = load_ui('CenRa_Copie_base.ui') EDITOR_CLASS = load_ui('CenRa_Copie_base.ui')
class Copie_Editor(QDialog, EDITOR_CLASS): class Copie_Editor(QDialog, EDITOR_CLASS):
def __init__(self, parent=None): def __init__(self, parent=None):
_ = parent _ = parent
super().__init__() super().__init__()
self.setupUi(self) self.setupUi(self)
self.settings = QgsSettings() self.settings = QgsSettings()
self.s = QSettings() self.s = QSettings()
self.setWindowIcon(QtGui.QIcon(resources_path('icons', 'icon.png'))) self.setWindowIcon(QtGui.QIcon(resources_path('icons','icon.png')))
self.iface = iface self.iface = iface
def raise_(self): def raise_(self):
"""Run method that performs all the real work""" """Run method that performs all the real work"""
layer = self.iface.activeLayer() layer = self.iface.activeLayer()
if layer is None: if layer == None :
# self.iface.messageBar().pushMessage(u"Vous devez sélectionner une table !", level=QgsMessageBar.WARNING, duration=5) #self.iface.messageBar().pushMessage(u"Vous devez sélectionner une table !", level=QgsMessageBar.WARNING, duration=5)
self.iface.messageBar().pushMessage("Ooops", u"Vous devez sélectionner une table !", level=1, duration=5) self.iface.messageBar().pushMessage("Ooops", u"Vous devez sélectionner une table !", level=Qgis.Warning, duration=5)
else: else :
# Récupération des sources de la couche active # Récupération des sources de la couche active
list_sources = layer.source().split(" ") list_sources = layer.source().split(" ")
# dbname # dbname
source_db = [s for s in list_sources if "dbname" in s][0].split("'")[1] source_db = [s for s in list_sources if "dbname" in s][0].split("'")[1]
# schema # schema
source_schema = [s for s in list_sources if "table" in s][0].split('"')[1] source_schema = [s for s in list_sources if "table" in s][0].split('"')[1]
# tablename # tablename
source_tablename = [s for s in list_sources if "table" in s][0].split('"')[3] source_tablename = [s for s in list_sources if "table" in s][0].split('"')[3]
account = login_base("account") account = login_base("account")
sigdb = account[5] sigdb = account[5]
if source_db != sigdb: if source_db != sigdb:
# self.iface.messageBar().pushMessage(u"Un référentiel ne peut être copié, utilisez les filtres !", level=QgsMessageBar.CRITICAL, duration=10) #self.iface.messageBar().pushMessage(u"Un référentiel ne peut être copié, utilisez les filtres !", level=QgsMessageBar.CRITICAL, duration=10)
self.iface.messageBar().pushMessage("Ooops", u"Vous ne pouvez copier des couches que dans sigXX", level=2, duration=5) self.iface.messageBar().pushMessage("Ooops", u"Vous ne pouvez copier des couches que dans sigXX", level=Qgis.Critical, duration=5)
else: else:
user = account[0] user = account[0]
mdp = account[1] mdp = account[1]
@ -77,7 +85,7 @@ class Copie_Editor(QDialog, EDITOR_CLASS):
cur = account[7] cur = account[7]
con = account[8] con = account[8]
# Creation de la liste des schemas de la base de donnees # Creation de la liste des schemas de la base de donnees
SQL = """WITH list_schema AS ( SQL = """WITH list_schema AS (
SELECT catalog_name, schema_name SELECT catalog_name, schema_name
FROM information_schema.schemata FROM information_schema.schemata
@ -94,25 +102,26 @@ class Copie_Editor(QDialog, EDITOR_CLASS):
list_brut = str(next(cur)) list_brut = str(next(cur))
list = list_brut[2:-3] list = list_brut [2:-3]
listItems = list.split(",") listItems = list.split(",")
con.close() con.close()
self.schema.clear() self.schema.clear()
self.schema.addItems(listItems) self.schema.addItems(listItems)
# Pour ne pas commencer la liste au premier schema self.schema.setCurrentIndex(-1) # Pour ne pas commencer la liste au premier schema
self.schema.setCurrentIndex(-1)
# Affiche le nom de la table source
self.table_source.setText(source_schema + "." + source_tablename) self.table_source.setText(source_schema + "." + source_tablename) # Affiche le nom de la table source
# show the dialog # show the dialog
self.show() self.show()
# Run the dialog event loop # Run the dialog event loop
result = self.exec() result = self.exec()
# See if OK was pressed # See if OK was pressed
if result: if result:
# ******************************debut script********************************* #******************************debut script*********************************
account = login_base("account") account = login_base("account")
user = account[0] user = account[0]
mdp = account[1] mdp = account[1]
@ -127,33 +136,33 @@ class Copie_Editor(QDialog, EDITOR_CLASS):
# Récupération des sources de la couche active # Récupération des sources de la couche active
list_sources = layer.source().split(" ") list_sources = layer.source().split(" ")
# dbname # dbname
source_db = [s for s in list_sources if "dbname" in s][0].split("'")[1] source_db = [s for s in list_sources if "dbname" in s][0].split("'")[1]
# schema # schema
source_schema = [s for s in list_sources if "table" in s][0].split('"')[1] source_schema = [s for s in list_sources if "table" in s][0].split('"')[1]
# tablename # tablename
source_tablename = [s for s in list_sources if "table" in s][0].split('"')[3] source_tablename = [s for s in list_sources if "table" in s][0].split('"')[3]
if self.schema.currentIndex() == - 1: if self.schema.currentIndex() == -1 :
QMessageBox.warning(None, "Oups :", "Veuillez choisir un dossier de destination.") QMessageBox.warning(None, "Oups :", "Veuillez choisir un dossier de destination.")
return return
schema = self.schema.currentText() schema = self.schema.currentText()
if self.table_destination.text() == '': if self.table_destination.text() == '' :
QMessageBox.warning(None, "Oups :", "Veuillez choisir un nom de destination.") QMessageBox.warning(None, "Oups :", "Veuillez choisir un nom de destination.")
return return
if self.annee.text() == 'aaaa' or self.annee.text() == '': if self.annee.text() == 'aaaa' or self.annee.text() == '':
tablename = schema + "_" + self.table_destination.text().lower() tablename = schema + "_" + self.table_destination.text().lower()
else: else :
tablename = schema + "_" + self.table_destination.text().lower() + "_" + self.annee.text() tablename = schema + "_" + self.table_destination.text().lower() + "_" + self.annee.text()
tablename_qgis = tablename[1:] # Permet d'enlever le "_", ajouter a la premiere etape, dans qgis tablename_qgis = tablename[1:] # Permet d'enlever le "_", ajouter a la premiere etape, dans qgis
if self.table_vide.isChecked() == 1: if self.table_vide.isChecked() == 1 :
SQL_table = "CREATE TABLE " + schema + "." + tablename + " AS SELECT * FROM " + source_schema + "." + source_tablename + " LIMIT 0;" SQL_table = "CREATE TABLE " + schema + "." + tablename + " AS SELECT * FROM " + source_schema + "." + source_tablename + " LIMIT 0;"
else: else :
SQL_table = "CREATE TABLE " + schema + "." + tablename + " AS SELECT * FROM " + source_schema + "." + source_tablename SQL_table = "CREATE TABLE " + schema + "." + tablename + " AS SELECT * FROM " + source_schema + "." + source_tablename
SQL_pkey = "ALTER TABLE " + schema + "." + tablename + " ADD CONSTRAINT " + tablename + "_pkey" + " PRIMARY KEY (gid)" SQL_pkey = "ALTER TABLE " + schema + "." + tablename + " ADD CONSTRAINT " + tablename + "_pkey" + " PRIMARY KEY (gid)"
@ -175,38 +184,38 @@ class Copie_Editor(QDialog, EDITOR_CLASS):
cur.execute(SQL_sequence_03) cur.execute(SQL_sequence_03)
cur.execute(SQL_sequence_04) cur.execute(SQL_sequence_04)
RETURNE = "SELECT pg_get_serial_sequence('" + schema + "." + tablename + "','gid')" RETURNE = "SELECT pg_get_serial_sequence('"+schema + "."+ tablename+"','gid')"
cur.execute(RETURNE) cur.execute(RETURNE)
sequence_name = cur.fetchone()[0] sequence_name = cur.fetchone()[0]
print(sequence_name) print(sequence_name)
SQL_GRANT_TABLE = "GRANT DELETE, INSERT, REFERENCES, SELECT, TRIGGER, TRUNCATE, UPDATE ON " + schema + "." + tablename + " TO grp_qgis;GRANT DELETE, INSERT, REFERENCES, SELECT, TRIGGER, TRUNCATE, UPDATE ON " + schema + "." + tablename + " TO grp_sig;GRANT ALL ON SEQUENCE " + sequence_name + " TO grp_qgis;" SQL_GRANT_TABLE="GRANT DELETE, INSERT, REFERENCES, SELECT, TRIGGER, TRUNCATE, UPDATE ON "+schema+"."+tablename+" TO grp_qgis;GRANT DELETE, INSERT, REFERENCES, SELECT, TRIGGER, TRUNCATE, UPDATE ON "+schema+"."+tablename+" TO grp_sig;GRANT ALL ON SEQUENCE "+sequence_name+" TO grp_qgis;"
cur.execute(SQL_GRANT_TABLE) cur.execute(SQL_GRANT_TABLE)
if layer.wkbType() == QgsWkbTypes.PointGeometry: if layer.wkbType() == QgsWkbTypes.PointGeometry :
cur.execute(SQL_trigger_coordonnees) cur.execute(SQL_trigger_coordonnees)
if layer.wkbType() == QgsWkbTypes.LineGeometry: if layer.wkbType() == QgsWkbTypes.LineGeometry :
cur.execute(SQL_trigger_length_m) cur.execute(SQL_trigger_length_m)
cur.execute(SQL_trigger_length_km) cur.execute(SQL_trigger_length_km)
if layer.wkbType() == QgsWkbTypes.PolygonGeometry: if layer.wkbType() == QgsWkbTypes.PolygonGeometry :
cur.execute(SQL_trigger_area_m2) cur.execute(SQL_trigger_area_m2)
cur.execute(SQL_trigger_area_ha) cur.execute(SQL_trigger_area_ha)
con.commit() con.commit()
# Affichage de la table ### Affichage de la table
uri = QgsDataSourceUri() uri = QgsDataSourceUri()
# set host name, port, database name, username and password # set host name, port, database name, username and password
uri.setConnection(host, port, dbname, user, mdp) uri.setConnection(host ,port ,dbname ,user ,mdp)
# set database schema, table name, geometry column and optionaly subset (WHERE clause) # set database schema, table name, geometry column and optionaly subset (WHERE clause)
uri.setDataSource(schema, tablename, "geom") uri.setDataSource(schema, tablename, geom)
layer = self.iface.addVectorLayer(uri.uri(), tablename_qgis, "postgres") layer = self.iface.addVectorLayer(uri.uri(), tablename_qgis, "postgres")
con.commit() con.commit()
con.close() con.close()
# self.iface.messageBar().pushMessage("Table \"" + source_schema + "." + source_tablename + u"\" copiée dans \"" + schema + "." + tablename + "\"." , level=QgsMessageBar.INFO, duration=10) #self.iface.messageBar().pushMessage("Table \"" + source_schema + "." + source_tablename + u"\" copiée dans \"" + schema + "." + tablename + "\"." , level=QgsMessageBar.INFO, duration=10)
self.iface.messageBar().pushMessage("Bravo!", "Table \"" + source_schema + "." + source_tablename + u"\" copiée dans \"" + schema + "." + tablename + "\".", level=3, duration=5) self.iface.messageBar().pushMessage("Bravo!", "Table \"" + source_schema + "." + source_tablename + u"\" copiée dans \"" + schema + "." + tablename + "\".", level=Qgis.Success, duration=5)
pass pass

View File

@ -0,0 +1,141 @@
geom = "geom"
champ_travaux_prevus_multipolygon="""(gid serial NOT NULL, groupe_gestion text, gestion_lib text, id_gestion text, datedebut date, datefin date, commentaire text, surface_m2 double precision, surface_ha double precision, date_creation date, date_maj date, geom geometry(MultiPolygon,2154))"""
champ_travaux_prevus_multilinestring="""(gid serial NOT NULL, groupe_gestion text, gestion_lib text, id_gestion text, datedebut date, datefin date, commentaire text, longueur_m double precision, longueur_km double precision, date_creation date, date_maj date, geom geometry(MultiLineString,2154))"""
champ_travaux_prevus_point = """(gid serial NOT NULL, groupe_gestion text, gestion_lib text, id_gestion text, datedebut date, datefin date, commentaire text, x_wgs84 double precision, y_wgs84 double precision, date_creation date, date_maj date, geom geometry(Point,2154))"""
champ_viergePolygone = """(gid serial NOT NULL, commentaire text, surface_m2 double precision, surface_ha double precision, geom geometry(MultiPolygon,2154))"""
champ_viergeLigne = """(gid serial NOT NULL, commentaire text, longueur_m double precision, longueur_km double precision, geom geometry(MultiLineString,2154))"""
champ_viergePoint = """(gid serial NOT NULL, commentaire text, x_wgs84 double precision, y_wgs84 double precision, geom geometry(Point,2154))"""
champ_habitat = """(gid serial NOT NULL, cd_cb_01 text, lb_cb97_fr_01 text, occupation_01 integer, cd_cb_02 text, lb_cb97_fr_02 text, occupation_02 integer, cd_cb_03 text, lb_cb97_fr_03 text, occupation_03 integer, milieu_code text, milieu_libelle text, surface_m2 double precision, surface_ha double precision, commentaire text, date_creation date, date_maj date, geom geometry(MultiPolygon,2154))"""
champ_contour="""(gid serial NOT NULL, date_creation date, date_maj date, utilisateur character varying, dept character(2), nom character varying, surface_m2 double precision, surface_ha double precision, type_site character varying, type_milieu character varying, date_premier_pg integer, date_debut_pg integer, date_fin_pg integer, referent character varying, gestion_deleguee character varying, terrain_militaire character(3), ens character(3), zh character(3), adapt_pmr character(3), inform character(3), guide character(3), ouverture_public character(3), obs character(3), anim character(3), n2000_anim character(3), contrat_n2000_conseil character(3), n2000_op character(3), contrat_n2000_benef character(3), contrat_agri character(3), bc_habitat integer, bc_amphibien integer, bc_coleoptere integer, bc_crustace integer, bc_mammifere integer, bc_chiroptere integer, bc_mollusque integer, bc_odonate integer, bc_oiseau integer, bc_orthoptere integer, bc_poisson integer, bc_reptile integer, bc_rhopalocere integer, bc_heterocere integer, bc_autre_invertebre integer, bc_flore integer, bc_bryophyte integer, bc_champignon integer, suiv_analyse_sol character(3), suiv_piezo character(3), suiv_climat character(3), suiv_topo character(3), suiv_habitat character(3), suiv_amphibien character(3), suiv_coleoptere character(3), suiv_crustace character(3), suiv_mammifere character(3), suiv_chiroptere character(3), suiv_mollusque character(3), suiv_odonate character(3), suiv_oiseau character(3), suiv_orthoptere character(3), suiv_poisson character(3), suiv_reptile character(3), suiv_rhopalocere character(3), suiv_heterocere character(3), suiv_autre_invertebre character(3), suiv_flore character(3), suiv_bryophyte character(3), suiv_champignon character(3), suiv_analyse_eau character(3), suiv_phenologie character(3), suiv_frequentation character(3), suiv_paysager character(3), suiv_autre character(3), commentaire text, geom geometry(MultiPolygon,2154))
"""
champ_vegethab_point = """(
gid serial NOT NULL ,
cd_eu_01 character varying(254) COLLATE pg_catalog."default",
lb_eu_01 character varying(254) COLLATE pg_catalog."default",
occupati_1 bigint,
cd_eu_02 character varying(254) COLLATE pg_catalog."default",
lb_eu_02 character varying(254) COLLATE pg_catalog."default",
occupati_2 bigint,
cd_eu_03 character varying(254) COLLATE pg_catalog."default",
lb_eu_03 character varying(254) COLLATE pg_catalog."default",
occupati_3 bigint,
milieu_cod character varying(254) COLLATE pg_catalog."default",
milieu_lib character varying(254) COLLATE pg_catalog."default",
surface_m2 numeric,
surface_ha numeric,
commentair character varying(254) COLLATE pg_catalog."default",
date_creat date,
date_maj date,
num_phyto character varying(254) COLLATE pg_catalog."default",
type_unite character varying(254) COLLATE pg_catalog."default",
dynamique character varying(254) COLLATE pg_catalog."default",
gestio_obs character varying(254) COLLATE pg_catalog."default",
degrad_obs character varying(254) COLLATE pg_catalog."default",
eta_conser character varying(254) COLLATE pg_catalog."default",
clas_phyto character varying(254) COLLATE pg_catalog."default",
alli_phyto character varying(254) COLLATE pg_catalog."default",
syntaxon character varying(254) COLLATE pg_catalog."default",
n2000 character varying(254) COLLATE pg_catalog."default",
lrr_aura character varying(254) COLLATE pg_catalog."default",
lrr_cbna character varying(254) COLLATE pg_catalog."default",
lrr_cbnmc character varying(254) COLLATE pg_catalog."default",
vege_enjeu character varying(254) COLLATE pg_catalog."default",
num_photo character varying(254) COLLATE pg_catalog."default",
nature_obs character varying(254) COLLATE pg_catalog."default",
date_sais date,
s_al_phyto character varying(254) COLLATE pg_catalog."default",
alli_name character varying(254) COLLATE pg_catalog."default",
salli_name character varying(254) COLLATE pg_catalog."default",
class_name character varying(254) COLLATE pg_catalog."default",
geom geometry(Point,2154)
)
"""
champ_vegethab_multilinestring = """(
gid serial NOT NULL ,
cd_eu_01 character varying(254) COLLATE pg_catalog."default",
lb_eu_01 character varying(254) COLLATE pg_catalog."default",
occupati_1 bigint,
cd_eu_02 character varying(254) COLLATE pg_catalog."default",
lb_eu_02 character varying(254) COLLATE pg_catalog."default",
occupati_2 bigint,
cd_eu_03 character varying(254) COLLATE pg_catalog."default",
lb_eu_03 character varying(254) COLLATE pg_catalog."default",
occupati_3 bigint,
milieu_cod character varying(254) COLLATE pg_catalog."default",
milieu_lib character varying(254) COLLATE pg_catalog."default",
surface_m2 numeric,
surface_ha numeric,
commentair character varying(254) COLLATE pg_catalog."default",
date_creat date,
date_maj date,
num_phyto character varying(254) COLLATE pg_catalog."default",
type_unite character varying(254) COLLATE pg_catalog."default",
dynamique character varying(254) COLLATE pg_catalog."default",
gestio_obs character varying(254) COLLATE pg_catalog."default",
degrad_obs character varying(254) COLLATE pg_catalog."default",
eta_conser character varying(254) COLLATE pg_catalog."default",
clas_phyto character varying(254) COLLATE pg_catalog."default",
alli_phyto character varying(254) COLLATE pg_catalog."default",
syntaxon character varying(254) COLLATE pg_catalog."default",
n2000 character varying(254) COLLATE pg_catalog."default",
lrr_aura character varying(254) COLLATE pg_catalog."default",
lrr_cbna character varying(254) COLLATE pg_catalog."default",
lrr_cbnmc character varying(254) COLLATE pg_catalog."default",
vege_enjeu character varying(254) COLLATE pg_catalog."default",
num_photo character varying(254) COLLATE pg_catalog."default",
nature_obs character varying(254) COLLATE pg_catalog."default",
date_sais date,
s_al_phyto character varying(254) COLLATE pg_catalog."default",
alli_name character varying(254) COLLATE pg_catalog."default",
salli_name character varying(254) COLLATE pg_catalog."default",
class_name character varying(254) COLLATE pg_catalog."default",
geom geometry(MultiLineString,2154)
)
"""
champ_vegethab_multipolygon = """(
gid serial NOT NULL ,
cd_eu_01 character varying(254) COLLATE pg_catalog."default",
lb_eu_01 character varying(254) COLLATE pg_catalog."default",
occupati_1 bigint,
cd_eu_02 character varying(254) COLLATE pg_catalog."default",
lb_eu_02 character varying(254) COLLATE pg_catalog."default",
occupati_2 bigint,
cd_eu_03 character varying(254) COLLATE pg_catalog."default",
lb_eu_03 character varying(254) COLLATE pg_catalog."default",
occupati_3 bigint,
milieu_cod character varying(254) COLLATE pg_catalog."default",
milieu_lib character varying(254) COLLATE pg_catalog."default",
surface_m2 numeric,
surface_ha numeric,
commentair character varying(254) COLLATE pg_catalog."default",
date_creat date,
date_maj date,
num_phyto character varying(254) COLLATE pg_catalog."default",
type_unite character varying(254) COLLATE pg_catalog."default",
dynamique character varying(254) COLLATE pg_catalog."default",
gestio_obs character varying(254) COLLATE pg_catalog."default",
degrad_obs character varying(254) COLLATE pg_catalog."default",
eta_conser character varying(254) COLLATE pg_catalog."default",
clas_phyto character varying(254) COLLATE pg_catalog."default",
alli_phyto character varying(254) COLLATE pg_catalog."default",
syntaxon character varying(254) COLLATE pg_catalog."default",
n2000 character varying(254) COLLATE pg_catalog."default",
lrr_aura character varying(254) COLLATE pg_catalog."default",
lrr_cbna character varying(254) COLLATE pg_catalog."default",
lrr_cbnmc character varying(254) COLLATE pg_catalog."default",
vege_enjeu character varying(254) COLLATE pg_catalog."default",
num_photo character varying(254) COLLATE pg_catalog."default",
nature_obs character varying(254) COLLATE pg_catalog."default",
date_sais date,
s_al_phyto character varying(254) COLLATE pg_catalog."default",
alli_name character varying(254) COLLATE pg_catalog."default",
salli_name character varying(254) COLLATE pg_catalog."default",
class_name character varying(254) COLLATE pg_catalog."default",
geom geometry(MultiPolygon,2154)
)
"""

View File

@ -3,9 +3,9 @@
import configparser import configparser
import shutil import shutil
import tempfile import tempfile
# import base64 import base64
# import psycopg2 import psycopg2
# import psycopg2.extras import psycopg2.extras
import os import os
from os.path import abspath, join, pardir, dirname from os.path import abspath, join, pardir, dirname
@ -108,77 +108,71 @@ def load_ui(*args):
return ui_class return ui_class
def pyperclip(): def pyperclip():
dst = dirname(dirname(__file__)) + "\\tools\\" dst = dirname(dirname(__file__))+"\\tools\\"
if os.access('N:/', os.R_OK): if os.access('N:/',os.R_OK):
src = 'N:/SI_Systeme d information/Z_QGIS/PLUGIN/PythonSQL.py' src = 'N:/SI_Systeme d information/Z_QGIS/PLUGIN/PythonSQL.py'
try: try:
shutil.copy(src, dst) shutil.copy(src, dst)
except FileNotFoundError: except:
print('404')
except UnboundLocalError:
print('404') print('404')
def send_issues(url,titre,body,labels):
def send_issues(url, titre, body, labels):
import requests import requests
import urllib.request
import json import json
# import os import os
# import qgis import qgis
# usr = os.environ['USERNAME'] usr = os.environ['USERNAME']
token = '9d0a4e0bea561710e0728f161f7edf4e5201e112' token = '9d0a4e0bea561710e0728f161f7edf4e5201e112'
url = url + '?token=' + token url=url+'?token='+token
headers = {'Authorization': 'token ' + token,'accept': 'application/json','Content-Type': 'application/json'}
headers = {'Authorization': 'token ' + token, 'accept': 'application/json', 'Content-Type': 'application/json'}
payload = {'title': titre, 'body': body, 'labels': labels} payload = {'title': titre, 'body': body, 'labels': labels}
try: try:
urllib.request.urlopen('https://google.com') urllib.request.urlopen('https://google.com')
binar = True binar = True
except ValueError: except:
binar = False binar = False
r = '' r = ''
if binar: if binar:
r = requests.post(url, data=json.dumps(payload), headers=headers) r = requests.post(url, data=json.dumps(payload), headers=headers)
return r return r
def maj_verif(NAME): def maj_verif(NAME):
import qgis import qgis
import urllib.request import urllib.request
iface = qgis.utils.iface iface = qgis.utils.iface
from qgis.core import Qgis from qgis.core import Qgis
# url = qgis.utils.pluginMetadata(NAME, 'repository') url = qgis.utils.pluginMetadata(NAME,'repository')
# URL = url+'/raw/branch/main/plugins.xml' #URL = url+'/raw/branch/main/plugins.xml'
URL = 'https://gitea.cenra-outils.org/CEN-RA/Plugin_QGIS/releases/download/latest/plugins.xml' URL = 'https://gitea.cenra-outils.org/CEN-RA/Plugin_QGIS/releases/download/latest/plugins.xml'
# print(URL) # print(URL)
version = qgis.utils.pluginMetadata(NAME, 'version') version = qgis.utils.pluginMetadata(NAME,'version')
len_version = len(version) len_version = len(version)
try: try:
urllib.request.urlopen('https://google.com') urllib.request.urlopen('https://google.com')
binar = True binar = True
except urllib.error.URLError: except:
binar = False binar = False
if binar: if binar:
try: try:
version_web = str(urllib.request.urlopen(URL).read()) version_web = str(urllib.request.urlopen(URL).read())
plugin_num = version_web.find(NAME) plugin_num = version_web.find(NAME)
valeur_version_web = version_web.find('<version>', plugin_num) + 9 valeur_version_web = version_web.find('<version>',plugin_num)+9
version_plugin = version_web[valeur_version_web:valeur_version_web + len_version] version_plugin = version_web[valeur_version_web:valeur_version_web+len_version]
if version_plugin != version: if version_plugin != version:
iface.messageBar().pushMessage("MAJ :", "Des mise à jour de plugin sont disponibles.", level=Qgis.Info, duration=30) iface.messageBar().pushMessage("MAJ :", "Des mise à jour de plugin sont disponibles.", level=Qgis.Info, duration=30)
except urllib.error.URLError: except:
print("error gitea version ssl") print("error gitea version ssl")
else: else:
iface.messageBar().pushMessage("WiFi :", "Pas de connection à internet.", level=Qgis.Warning, duration=30) iface.messageBar().pushMessage("WiFi :", "Pas de connection à internet.", level=Qgis.Warning, duration=30)
def devlog(NAME): def devlog(NAME):
import qgis import qgis
devmaj = '<head><style>* {margin:0; padding:0; }</style></head>' devmaj = '<head><style>* {margin:0; padding:0; }</style></head>'
devmaj = devmaj + qgis.utils.pluginMetadata(NAME, 'changelog') devmaj = devmaj+qgis.utils.pluginMetadata(NAME,'changelog')
return devmaj return devmaj

View File

@ -1,13 +1,35 @@
import os import os
# from qgis.gui import * from qgis.gui import *
from qgis.core import QgsSettings from qgis.core import (
from qgis.PyQt.QtWidgets import QDialog NULL,
QgsApplication,
QgsDataSourceUri,
QgsProject,
QgsProviderConnectionException,
QgsProviderRegistry,
QgsRasterLayer,
QgsSettings,
QgsVectorLayer,
QgsGeometry,
)
from qgis.PyQt.QtWidgets import (
QDialog,
QAction,
QDockWidget,
QFileDialog,
QInputDialog,
QMenu,
QToolButton,
QTableWidget,
QTableWidgetItem,
)
from qgis.utils import iface from qgis.utils import iface
from .tools.resources import ( from .tools.resources import (
load_ui, load_ui,
# resources_path,
send_issues, send_issues,
) )
plugin_dir = os.path.dirname(__file__) plugin_dir = os.path.dirname(__file__)
@ -60,11 +82,11 @@ class CenRa_Issues(QDialog, EDITOR_CLASS):
else: else:
code = 423 code = 423
if code == 201: if code == 201:
iface.messageBar().pushMessage("Envoyer :", "Votre messages à bien été envoyer.", level=0, duration=20) iface.messageBar().pushMessage("Envoyer :", "Votre messages à bien été envoyer.", level=Qgis.Success, duration=20)
self.close() self.close()
elif code == 422: elif code == 422:
iface.messageBar().pushMessage("Erreur :", "Erreur dans le contenu du messages.", level=2, duration=20) iface.messageBar().pushMessage("Erreur :", "Erreur dans le contenu du messages.", level=Qgis.Critical, duration=20)
elif code == 423: elif code == 423:
iface.messageBar().pushMessage("Erreur :", "Pas de sujet sélectionné.", level=2, duration=20) iface.messageBar().pushMessage("Erreur :", "Pas de sujet sélectionné.", level=Qgis.Critical, duration=20)
elif code == 404: elif code == 404:
iface.messageBar().pushMessage("Missing :", "Le serveur de messagerie est injoignable.", level=1, duration=20) iface.messageBar().pushMessage("Missing :", "Le serveur de messagerie est injoignable.", level=Qgis.Warning, duration=20)

View File

@ -4,13 +4,14 @@ __email__ = "info@3liz.org"
from qgis.core import QgsApplication from qgis.core import QgsApplication
from qgis.PyQt.QtCore import Qt, QUrl, QSettings from qgis.PyQt.QtCore import QCoreApplication, Qt, QTranslator, QUrl
from qgis.PyQt.QtGui import QDesktopServices, QIcon from qgis.PyQt.QtGui import QDesktopServices, QIcon
from qgis.PyQt.QtWidgets import QAction from qgis.PyQt.QtWidgets import QAction, QMessageBox
from qgis.utils import iface from qgis.utils import iface
import qgis import qgis
# include <QSettings>
#include <QSettings>
''' '''
from pg_metadata.connection_manager import ( from pg_metadata.connection_manager import (
store_connections, store_connections,
@ -23,9 +24,8 @@ from pg_metadata.processing.provider import PgMetadataProvider
from pg_metadata.qgis_plugin_tools.tools.custom_logging import setup_logger from pg_metadata.qgis_plugin_tools.tools.custom_logging import setup_logger
''' '''
import os import os
from .about_form import MetabaseAboutDialog
from .tools.resources import ( from .tools.resources import (
# plugin_path, plugin_path,
pyperclip, pyperclip,
resources_path, resources_path,
maj_verif, maj_verif,
@ -33,8 +33,10 @@ from .tools.resources import (
pyperclip() pyperclip()
from .dock import CenRa_Metabase from .dock import CenRa_Metabase
from .editor import Metabase_Editor from .editor import Metabase_Editor
from .about_form import MetabaseAboutDialog
#from CenRa_Metabase.issues import CenRa_Issues
# from CenRa_Metabase.issues import CenRa_Issues from qgis.PyQt.QtCore import *
class PgMetadata: class PgMetadata:
@ -48,42 +50,42 @@ class PgMetadata:
self.dock_action = None self.dock_action = None
self.help_action = None self.help_action = None
plugin_dir = os.path.dirname(__file__) plugin_dir = os.path.dirname(__file__)
end_find = plugin_dir.rfind('\\') + 1 end_find = plugin_dir.rfind('\\')+1
global NAME global NAME
NAME = plugin_dir[end_find:] NAME = plugin_dir[end_find:]
maj_verif(NAME) maj_verif(NAME)
# Display About window on first use # Display About window on first use
version = qgis.utils.pluginMetadata('CenRa_METABASE', 'version') version = qgis.utils.pluginMetadata('CenRa_METABASE','version')
s = QSettings() s = QSettings()
versionUse = s.value("metadata/version", 1, type=str) versionUse = s.value("metadata/version", 1, type=str)
if str(versionUse) != str(version): if str(versionUse) != str(version) :
s.setValue("metadata/version", str(version)) s.setValue("metadata/version", str(version))
print(versionUse, version) print(versionUse,version)
self.open_about_dialog() self.open_about_dialog()
# setup_logger('pg_metadata') # setup_logger('pg_metadata')
# locale, file_path = setup_translation( #locale, file_path = setup_translation(
# folder=plugin_path("i18n"), file_pattern="CenRa_Metabase_{}.qm") # folder=plugin_path("i18n"), file_pattern="CenRa_Metabase_{}.qm")
# if file_path: #if file_path:
# self.translator = QTranslator() # self.translator = QTranslator()
# self.translator.load(file_path) # self.translator.load(file_path)
# noinspection PyCallByClass,PyArgumentList # noinspection PyCallByClass,PyArgumentList
# QCoreApplication.installTranslator(self.translator) # QCoreApplication.installTranslator(self.translator)
# noinspection PyPep8Naming # noinspection PyPep8Naming
# def initProcessing(self): #def initProcessing(self):
# """ Add the QGIS Processing provider. """ #""" Add the QGIS Processing provider. """
# if not self.provider: #if not self.provider:
# self.provider = PgMetadataProvider() #self.provider = PgMetadataProvider()
# QgsApplication.processingRegistry().addProvider(self.provider) #QgsApplication.processingRegistry().addProvider(self.provider)
# noinspection PyPep8Naming # noinspection PyPep8Naming
def initGui(self): def initGui(self):
""" Build the plugin GUI. """ """ Build the plugin GUI. """
# self.initProcessing() #self.initProcessing()
# self.check_invalid_connection_names() #self.check_invalid_connection_names()
self.toolBar = iface.addToolBar("CenRa_Metabase") self.toolBar = iface.addToolBar("CenRa_Metabase")
self.toolBar.setObjectName("CenRa_Metabase") self.toolBar.setObjectName("CenRa_Metabase")
@ -98,7 +100,8 @@ class PgMetadata:
if not self.editor: if not self.editor:
self.editor = Metabase_Editor() self.editor = Metabase_Editor()
self.editor_action = QAction(icon2, 'CenRa_Metabase', None)
self.editor_action = QAction(icon2, 'CenRa_Metabase',None)
self.toolBar.addAction(self.editor_action) self.toolBar.addAction(self.editor_action)
self.editor_action.triggered.connect(self.open_editor) self.editor_action.triggered.connect(self.open_editor)
@ -156,7 +159,6 @@ class PgMetadata:
""" """
dialog = MetabaseAboutDialog(iface) dialog = MetabaseAboutDialog(iface)
dialog.exec() dialog.exec()
def open_help(): def open_help():
""" Open the online help. """ """ Open the online help. """
QDesktopServices.openUrl(QUrl('https://plateformesig.cenra-outils.org/')) QDesktopServices.openUrl(QUrl('https://plateformesig.cenra-outils.org/'))
@ -176,9 +178,9 @@ class PgMetadata:
def unload(self): def unload(self):
""" Unload the plugin. """ """ Unload the plugin. """
# if self.editor: #if self.editor:
# iface.removePluginMenu('CenRa_Metabase',self.editor_action) #iface.removePluginMenu('CenRa_Metabase',self.editor_action)
# self.editor.removeToolBarIcon(self.editor_action) #self.editor.removeToolBarIcon(self.editor_action)
if self.dock: if self.dock:
iface.removeDockWidget(self.dock) iface.removeDockWidget(self.dock)
@ -200,6 +202,7 @@ class PgMetadata:
iface.pluginMenu().removeAction(self.dock_action) iface.pluginMenu().removeAction(self.dock_action)
del self.dock_action del self.dock_action
@staticmethod @staticmethod
def run_tests(pattern='test_*.py', package=None): def run_tests(pattern='test_*.py', package=None):
"""Run the test inside QGIS.""" """Run the test inside QGIS."""

View File

@ -3,7 +3,7 @@ import os.path
from pathlib import Path from pathlib import Path
from qgis.PyQt import uic from qgis.PyQt import uic
# from qgis.PyQt.QtGui import QPixmap from qgis.PyQt.QtGui import QPixmap
from qgis.PyQt.QtWidgets import QDialog from qgis.PyQt.QtWidgets import QDialog
from .tools.resources import devlog from .tools.resources import devlog
@ -16,7 +16,6 @@ ABOUT_FORM_CLASS, _ = uic.loadUiType(
) )
) )
class MetabaseAboutDialog(QDialog, ABOUT_FORM_CLASS): class MetabaseAboutDialog(QDialog, ABOUT_FORM_CLASS):
""" About - Let the user display the about dialog. """ """ About - Let the user display the about dialog. """

View File

@ -14,31 +14,48 @@ from pathlib import Path
from xml.dom.minidom import parseString from xml.dom.minidom import parseString
from qgis.core import ( from qgis.core import (
NULL,
QgsApplication, QgsApplication,
QgsDataSourceUri,
QgsProject,
QgsProviderConnectionException,
QgsProviderRegistry, QgsProviderRegistry,
QgsRasterLayer,
QgsSettings, QgsSettings,
QgsVectorLayer,
) )
from qgis.PyQt.QtCore import QLocale, QUrl from qgis.PyQt.QtCore import QLocale, QUrl
from qgis.PyQt.QtGui import QDesktopServices, QIcon from qgis.PyQt.QtGui import QDesktopServices, QIcon
from qgis.PyQt.QtPrintSupport import QPrinter from qgis.PyQt.QtPrintSupport import QPrinter
# from qgis.PyQt.QtWebKitWidgets import QWebPage #from qgis.PyQt.QtWebKitWidgets import QWebPage
from qgis.PyQt.QtWidgets import ( from qgis.PyQt.QtWidgets import (
QDialog,
QAction, QAction,
QDockWidget, QDockWidget,
QFileDialog, QFileDialog,
QInputDialog,
QMenu, QMenu,
QToolButton, QToolButton,
) )
from qgis.gui import *
from qgis.utils import iface from qgis.utils import iface
import qgis import qgis
'''
from pg_metadata.connection_manager import (
check_pgmetadata_is_installed,
connections_list,
settings_connections_names,
)
'''
try:
from .tools.PythonSQL import login_base
except:
print('Pas de fichier PythonSQL')
from .tools.resources import ( from .tools.resources import (
load_ui, load_ui,
resources_path, resources_path,
) )
try:
from .tools.PythonSQL import login_base
except ValueError:
print('Pas de fichier PythonSQL')
DOCK_CLASS = load_ui('CenRa_Metabase_dockwidget_base.ui') DOCK_CLASS = load_ui('CenRa_Metabase_dockwidget_base.ui')
LOGGER = logging.getLogger('CenRa_Metabase') LOGGER = logging.getLogger('CenRa_Metabase')
@ -67,8 +84,8 @@ class CenRa_Metabase(QDockWidget, DOCK_CLASS):
self.current_datasource_uri = None self.current_datasource_uri = None
self.current_connection = None self.current_connection = None
# self.viewer.page().setLinkDelegationPolicy(QWebPage.DelegateAllLinks) #self.viewer.page().setLinkDelegationPolicy(QWebPage.DelegateAllLinks)
# self.viewer.page().linkClicked.connect(self.open_link) #self.viewer.page().linkClicked.connect(self.open_link)
# Help button # Help button
self.external_help.setText('') self.external_help.setText('')
@ -77,13 +94,13 @@ class CenRa_Metabase(QDockWidget, DOCK_CLASS):
# Flat table button # Flat table button
self.flatten_dataset_table.setText('') self.flatten_dataset_table.setText('')
# self.flatten_dataset_table.setToolTip(tr("Add the catalog table")) #self.flatten_dataset_table.setToolTip(tr("Add the catalog table"))
self.flatten_dataset_table.setIcon(QgsApplication.getThemeIcon("/mActionAddHtml.svg")) self.flatten_dataset_table.setIcon(QgsApplication.getThemeIcon("/mActionAddHtml.svg"))
# self.flatten_dataset_table.clicked.connect(self.add_flatten_dataset_table) #self.flatten_dataset_table.clicked.connect(self.add_flatten_dataset_table)
# Settings menu # Settings menu
self.config.setAutoRaise(True) self.config.setAutoRaise(True)
# self.config.setToolTip(tr("Settings")) #self.config.setToolTip(tr("Settings"))
self.config.setPopupMode(QToolButton.ToolButtonPopupMode(2)) self.config.setPopupMode(QToolButton.ToolButtonPopupMode(2))
self.config.setIcon(QgsApplication.getThemeIcon("/mActionOptions.svg")) self.config.setIcon(QgsApplication.getThemeIcon("/mActionOptions.svg"))
@ -101,7 +118,7 @@ class CenRa_Metabase(QDockWidget, DOCK_CLASS):
# Setting PDF/HTML menu # Setting PDF/HTML menu
self.save_button.setAutoRaise(True) self.save_button.setAutoRaise(True)
# self.save_button.setToolTip(tr("Save metadata")) #self.save_button.setToolTip(tr("Save metadata"))
self.save_button.setPopupMode(QToolButton.ToolButtonPopupMode(2)) self.save_button.setPopupMode(QToolButton.ToolButtonPopupMode(2))
self.save_button.setIcon(QIcon(QgsApplication.iconPath('mActionFileSave.svg'))) self.save_button.setIcon(QIcon(QgsApplication.iconPath('mActionFileSave.svg')))
@ -129,21 +146,21 @@ class CenRa_Metabase(QDockWidget, DOCK_CLASS):
self.metadata = QgsProviderRegistry.instance().providerMetadata('postgres') self.metadata = QgsProviderRegistry.instance().providerMetadata('postgres')
# Display message in the dock # Display message in the dock
# if not settings_connections_names(): #if not settings_connections_names():
# self.default_html_content_not_installed() #self.default_html_content_not_installed()
# else: #else:
self.default_html_content_not_pg_layer() self.default_html_content_not_pg_layer()
iface.layerTreeView().currentLayerChanged.connect(self.layer_changed)
try: try:
login_base() login_base()
iface.layerTreeView().currentLayerChanged.connect(self.layer_changed) iface.layerTreeView().currentLayerChanged.connect(self.layer_changed)
except ValueError: except:
# qgis.utils.plugins['CenRa_METABASE'].initGui() #qgis.utils.plugins['CenRa_METABASE'].initGui()
qgis.utils.plugins['CenRa_METABASE'].unload() qgis.utils.plugins['CenRa_METABASE'].unload()
# self.default_html_content_not_pg_layer() #self.default_html_content_not_pg_layer()
if iface.activeLayer(): if iface.activeLayer():
layer = iface.activeLayer() layer=iface.activeLayer()
iface.layerTreeView().setCurrentLayer(None) iface.layerTreeView().setCurrentLayer(None)
iface.layerTreeView().setCurrentLayer(layer) iface.layerTreeView().setCurrentLayer(layer)
@ -175,7 +192,7 @@ class CenRa_Metabase(QDockWidget, DOCK_CLASS):
if output_format == OutputFormats.PDF: if output_format == OutputFormats.PDF:
printer = QPrinter() printer = QPrinter()
printer.setOutputFormat(QPrinter.OutputFormat(1)) printer.setOutputFormat(QPrinter.OutputFormat(1))
# printer.setPageMargins(20,20,20,20,QPrinter.Unit(0)) #printer.setPageMargins(20,20,20,20,QPrinter.Unit(0))
printer.setOutputFileName(output_file_path) printer.setOutputFileName(output_file_path)
self.viewer.print(printer) self.viewer.print(printer)
iface.messageBar().pushSuccess( iface.messageBar().pushSuccess(
@ -185,7 +202,7 @@ class CenRa_Metabase(QDockWidget, DOCK_CLASS):
"<a href=\"{}\">{}</a>").format(parent_folder, output_file_path) "<a href=\"{}\">{}</a>").format(parent_folder, output_file_path)
) )
elif output_format in [OutputFormats.HTML, OutputFormats.DCAT]: elif output_format in [OutputFormats.HTML,OutputFormats.DCAT]:
if output_format == OutputFormats.HTML: if output_format == OutputFormats.HTML:
data_str = self.viewer.page().currentFrame().toHtml() data_str = self.viewer.page().currentFrame().toHtml()
else: else:
@ -214,15 +231,43 @@ class CenRa_Metabase(QDockWidget, DOCK_CLASS):
def save_auto_open_dock(self): def save_auto_open_dock(self):
""" Save settings about the dock. """ """ Save settings about the dock. """
self.settings.setValue("pgmetadata/auto_open_dock", self.auto_open_dock_action.isChecked()) self.settings.setValue("pgmetadata/auto_open_dock", self.auto_open_dock_action.isChecked())
def sql_to_xml(self,dataall):
def sql_to_xml(self, dataall): distribution=''
distribution = ''
for y in dataall[1]: for y in dataall[1]:
distribution = distribution + ('<dcat:distribution>' + '<dcat:Distribution>' + '<dct:title>{data}</dct:title>'.format(data=y[0]) + '<dcat:downloadURL>{data}</dcat:downloadURL>'.format(data=y[1]) + '<dcat:mediaType>{data}</dcat:mediaType>'.format(data=y[2]) + '<dct:format>{data}</dct:format>'.format(data=y[3]) + '<dct:bytesize>{data}</dct:bytesize>'.format(data=y[4]) + '</dcat:Distribution>' + '</dcat:distribution>') distribution = distribution + (
publisher = '' '<dcat:distribution>'+
'<dcat:Distribution>'+
'<dct:title>{data}</dct:title>'.format(data=y[0])+
'<dcat:downloadURL>{data}</dcat:downloadURL>'.format(data=y[1])+
'<dcat:mediaType>{data}</dcat:mediaType>'.format(data=y[2])+
'<dct:format>{data}</dct:format>'.format(data=y[3])+
'<dct:bytesize>{data}</dct:bytesize>'.format(data=y[4])+
'</dcat:Distribution>'+
'</dcat:distribution>')
publisher=''
for z in dataall[2]: for z in dataall[2]:
publisher = publisher + ('<dct:publisher>' + '<foaf:Organization>' + '<foaf:name>{data}</foaf:name>'.format(data=z[1]) + '<foaf:mbox>{data}</foaf:mbox>'.format(data=z[3]) + '</foaf:Organization>' + '</dct:publisher>') publisher = publisher + (
data_str = [[dataall[0][26], '<dct:identifier>{data}</dct:identifier>'.format(data=dataall[0][1]) + '<dct:title>{data}</dct:title>'.format(data=dataall[0][4]) + '<dct:description>{data}</dct:description>'.format(data=dataall[0][5]) + '<dct:language>{data}</dct:language>'.format(data=dataall[0][26]) + '<dct:spatial>{data}</dct:spatial>'.format(data=dataall[0][28]) + '<dct:created rdf:datatype="http://www.w3.org/2001/XMLSchema#dateTime">{data}</dct:created>'.format(data=dataall[0][20]) + '<dct:issued rdf:datatype="http://www.w3.org/2001/XMLSchema#dateTime">{data}</dct:issued>'.format(data=dataall[0][11]) + '<dct:modified rdf:datatype="http://www.w3.org/2001/XMLSchema#dateTime">{data}</dct:modified>'.format(data=dataall[0][21]) + '<dct:license>{data}</dct:license>'.format(data=dataall[0][13]) + distribution + publisher + '<dcat:theme>{data}</dcat:theme>'.format(data=", ".join(str(x) for x in dataall[0][24])) + '<dcat:keyword>{data}</dcat:keyword>'.format(data=", ".join(str(x) for x in dataall[0][6])) + '<dct:accrualPeriodicity>{data}</dct:accrualPeriodicity>'.format(data=dataall[0][12])]] '<dct:publisher>'+
'<foaf:Organization>'+
'<foaf:name>{data}</foaf:name>'.format(data=z[1])+
'<foaf:mbox>{data}</foaf:mbox>'.format(data=z[3])+
'</foaf:Organization>'+
'</dct:publisher>')
data_str = [[dataall[0][26],
'<dct:identifier>{data}</dct:identifier>'.format(data=dataall[0][1])+
'<dct:title>{data}</dct:title>'.format(data=dataall[0][4])+
'<dct:description>{data}</dct:description>'.format(data=dataall[0][5])+
'<dct:language>{data}</dct:language>'.format(data=dataall[0][26])+
'<dct:spatial>{data}</dct:spatial>'.format(data=dataall[0][28])+
'<dct:created rdf:datatype="http://www.w3.org/2001/XMLSchema#dateTime">{data}</dct:created>'.format(data=dataall[0][20])+
'<dct:issued rdf:datatype="http://www.w3.org/2001/XMLSchema#dateTime">{data}</dct:issued>'.format(data=dataall[0][11])+
'<dct:modified rdf:datatype="http://www.w3.org/2001/XMLSchema#dateTime">{data}</dct:modified>'.format(data=dataall[0][21])+
'<dct:license>{data}</dct:license>'.format(data=dataall[0][13])+
distribution+
publisher+
'<dcat:theme>{data}</dcat:theme>'.format(data=", ".join(str(x) for x in dataall[0][24]))+
'<dcat:keyword>{data}</dcat:keyword>'.format(data=", ".join(str(x) for x in dataall[0][6]))+
'<dct:accrualPeriodicity>{data}</dct:accrualPeriodicity>'.format(data=dataall[0][12])]]
return data_str return data_str
@ -232,7 +277,7 @@ class CenRa_Metabase(QDockWidget, DOCK_CLASS):
locale = QgsSettings().value("locale/userLocale", QLocale().name()) locale = QgsSettings().value("locale/userLocale", QLocale().name())
locale = locale.split('_')[0].lower() locale = locale.split('_')[0].lower()
if output_format == [OutputFormats.HTML, OutputFormats.DCAT]: if output_format == [OutputFormats.HTML,OutputFormats.DCAT]:
sql = ( sql = (
"SELECT pgmetadata.get_dataset_item_html_content('{schema}', '{table}', '{locale}');" "SELECT pgmetadata.get_dataset_item_html_content('{schema}', '{table}', '{locale}');"
).format(schema=uri.schema(), table=uri.table(), locale=locale) ).format(schema=uri.schema(), table=uri.table(), locale=locale)
@ -247,6 +292,7 @@ class CenRa_Metabase(QDockWidget, DOCK_CLASS):
self.current_connection = None self.current_connection = None
self.ce_trouve_dans_psql(layer) self.ce_trouve_dans_psql(layer)
def add_flatten_dataset_table(self): def add_flatten_dataset_table(self):
""" Add a flatten dataset table with all links and contacts. """ """ Add a flatten dataset table with all links and contacts. """
''' '''
@ -291,17 +337,17 @@ class CenRa_Metabase(QDockWidget, DOCK_CLASS):
def set_html_content(self, title=None, body=None): def set_html_content(self, title=None, body=None):
""" Set the content in the dock. """ """ Set the content in the dock. """
# ink_logo=resources_path('icons', 'CEN_RA.png') #link_logo=resources_path('icons', 'CEN_RA.png')
css_file = resources_path('css', 'dock.css') css_file = resources_path('css', 'dock.css')
with open(css_file, 'r', encoding='utf8') as f: with open(css_file, 'r', encoding='utf8') as f:
css = f.read() css = f.read()
html = '<html><head>' html = '<html><head>'
# html += '<script src="http://ignf.github.io/geoportal-sdk/latest/dist/2d/GpSDK2D.js" defer ></script>' #html += '<script src="http://ignf.github.io/geoportal-sdk/latest/dist/2d/GpSDK2D.js" defer ></script>'
html += '<style>{css}</style></head><body>'.format(css=css) html += '<style>{css}</style></head><body>'.format(css=css)
# html += '<link rel="stylesheet" href="http://ignf.github.io/geoportal-sdk/latest/dist/2d/GpSDK2D.css" >' #html += '<link rel="stylesheet" href="http://ignf.github.io/geoportal-sdk/latest/dist/2d/GpSDK2D.css" >'
# html += '<script src="file:///C:/Users/tlaveille/Desktop/maps.js" defer></script>' #html += '<script src="file:///C:/Users/tlaveille/Desktop/maps.js" defer></script>'
# html += '<noscript>Your browser does not support JavaScript!</noscript>' #html += '<noscript>Your browser does not support JavaScript!</noscript>'
if title: if title:
html += '<h2>{title} <img class=logo src=https://i2.wp.com/www.cen-rhonealpes.fr/wp-content/uploads/2013/04/cen-rhonealpes-couleurs1.jpg?w=340&ssl=1></h2>'.format(title=title) html += '<h2>{title} <img class=logo src=https://i2.wp.com/www.cen-rhonealpes.fr/wp-content/uploads/2013/04/cen-rhonealpes-couleurs1.jpg?w=340&ssl=1></h2>'.format(title=title)
if body: if body:
@ -310,16 +356,16 @@ class CenRa_Metabase(QDockWidget, DOCK_CLASS):
html += '</body></html>' html += '</body></html>'
# It must be a file, even if it does not exist on the file system. # It must be a file, even if it does not exist on the file system.
# base_url = QUrl.fromLocalFile(resources_path('images', 'must_be_a_file.png')) base_url = QUrl.fromLocalFile(resources_path('images', 'must_be_a_file.png'))
self.viewer.setHtml(html) self.viewer.setHtml(html)#, base_url)
def ce_trouve_dans_psql(self, layer): def ce_trouve_dans_psql(self,layer):
try: try:
uri = layer.dataProvider().uri() uri = layer.dataProvider().uri()
except AttributeError: except:
self.default_html_content_not_pg_layer() self.default_html_content_not_pg_layer()
self.save_button.setEnabled(False) self.save_button.setEnabled(False)
uri = '' uri=''
if uri != '': if uri != '':
if not uri.table(): if not uri.table():
layertype = layer.providerType().lower() layertype = layer.providerType().lower()
@ -330,23 +376,23 @@ class CenRa_Metabase(QDockWidget, DOCK_CLASS):
self.save_button.setEnabled(False) self.save_button.setEnabled(False)
else: else:
data_count = self.sql_check(uri) data_count = self.sql_check(uri)
# print(data_count) #print(data_count)
if data_count == 0: if data_count == 0:
self.default_html_content_not_metadata() self.default_html_content_not_metadata()
self.save_button.setEnabled(False) self.save_button.setEnabled(False)
else: else:
self.build_html_content(layer, uri) self.build_html_content(layer,uri)
self.save_button.setEnabled(True) self.save_button.setEnabled(True)
def build_html_content(self, layer, uri): def build_html_content(self,layer,uri):
body = '' body = ''
dataall = self.sql_info(uri) dataall=self.sql_info(uri)
data = dataall[0] data=dataall[0]
data_url = dataall[1] data_url=dataall[1]
data_contact = dataall[2] data_contact=dataall[2]
# print(len(data_url)) #print(len(data_url))
# data_collonne = [field.name() for field in layer.dataProvider().fields()] data_collonne=[field.name() for field in layer.dataProvider().fields()]
body += '<div><h3>Identification</h3><table class="table table-condensed">' body += '<div><h3>Identification</h3><table class="table table-condensed">'
body += '<tr><th>Titre</th><td>{data[4]}</td></tr>'.format(data=data) body += '<tr><th>Titre</th><td>{data[4]}</td></tr>'.format(data=data)
@ -369,7 +415,7 @@ class CenRa_Metabase(QDockWidget, DOCK_CLASS):
body += '<tr><th>Emprise</th><td>{data[28]}</td></tr>'.format(data=data) body += '<tr><th>Emprise</th><td>{data[28]}</td></tr>'.format(data=data)
body += '</table></div>' body += '</table></div>'
# body += '<div id="map"></div>' #body += '<div id="map"></div>'
body += '<div><h3>Publication</h3><table class="table table-condensed">' body += '<div><h3>Publication</h3><table class="table table-condensed">'
body += '<tr><th>Date</th><td>{data[11]}</td></tr>'.format(data=data) body += '<tr><th>Date</th><td>{data[11]}</td></tr>'.format(data=data)
@ -408,46 +454,45 @@ class CenRa_Metabase(QDockWidget, DOCK_CLASS):
self.set_html_content( self.set_html_content(
layer.name(), body) layer.name(), body)
def set_html_to_wms(self, layer): def set_html_to_wms(self,layer):
self.set_html_content( self.set_html_content(
'CenRa Metadata', (layer.htmlMetadata())) 'CenRa Metadata',(layer.htmlMetadata()))
def default_html_content_not_pg_layer(self): def default_html_content_not_pg_layer(self):
""" When it's not a PostgreSQL layer. """ """ When it's not a PostgreSQL layer. """
self.set_html_content( self.set_html_content(
'CenRa Metadata', ('Vous devez cliquer sur une couche dans la légende qui est stockée dans PostgreSQL.')) 'CenRa Metadata', ('Vous devez cliquer sur une couche dans la légende qui est stockée dans PostgreSQL.'))
def default_html_content_not_metadata(self): def default_html_content_not_metadata(self):
self.set_html_content( self.set_html_content(
'CenRa Metadata', ('La couche ne contien pas de métadonnée.')) 'CenRa Metadata', ('La couche ne contien pas de métadonnée.'))
def sql_check(self, uri): def sql_check(self,uri):
cur = login_base() cur=login_base()
table = uri.table() table = uri.table()
schema = uri.schema() schema = uri.schema()
sql_count = """SELECT count(uid) FROM metadata.dataset sql_count = """SELECT count(uid) FROM metadata.dataset
WHERE schema_name LIKE '""" + schema + """' AND table_name LIKE '""" + table + """';""" WHERE schema_name LIKE '"""+schema+"""' AND table_name LIKE '"""+table+"""';"""
cur.execute(sql_count) cur.execute(sql_count)
data_count = cur.fetchall() data_count = cur.fetchall()
cur.close() cur.close()
return data_count[0][0] return data_count[0][0]
def sql_info(self, uri): def sql_info(self,uri):
cur = login_base() cur=login_base()
table = uri.table() table = uri.table()
schema = uri.schema() schema = uri.schema()
# [s for s in iface.activeLayer().source().split(" ") if "dbname" in s][0].split("'")[1] #[s for s in iface.activeLayer().source().split(" ") if "dbname" in s][0].split("'")[1]
sql_find = """SELECT *,right(left(st_astext(geom,2),-2),-9) FROM metadata.dataset sql_find = """SELECT *,right(left(st_astext(geom,2),-2),-9) FROM metadata.dataset
WHERE schema_name LIKE '""" + schema + """' AND table_name LIKE '""" + table + """';""" WHERE schema_name LIKE '"""+schema+"""' AND table_name LIKE '"""+table+"""';"""
cur.execute(sql_find) cur.execute(sql_find)
data_general = cur.fetchall() data_general = cur.fetchall()
sql_findurl = """SELECT type,url,mime,format,taille FROM metadata.dataurl WHERE schema_name LIKE '""" + schema + """' AND table_name LIKE '""" + table + """';""" sql_findurl = """SELECT type,url,mime,format,taille FROM metadata.dataurl WHERE schema_name LIKE '"""+schema+"""' AND table_name LIKE '"""+table+"""';"""
cur.execute(sql_findurl) cur.execute(sql_findurl)
data_url = cur.fetchall() data_url = cur.fetchall()
sql_findcontact = """SELECT role,nom,organisation,email,telephone FROM metadata.datacontact WHERE schema_name LIKE '""" + schema + """' AND table_name LIKE '""" + table + """';""" sql_findcontact = """SELECT role,nom,organisation,email,telephone FROM metadata.datacontact WHERE schema_name LIKE '"""+schema+"""' AND table_name LIKE '"""+table+"""';"""
cur.execute(sql_findcontact) cur.execute(sql_findcontact)
data_contact = cur.fetchall() data_contact = cur.fetchall()
cur.close() cur.close()
return data_general[0], data_url, data_contact return data_general[0],data_url,data_contact

View File

@ -1,53 +1,66 @@
import logging import logging
import os import os
# from collections import namedtuple from collections import namedtuple
# from enum import Enum from enum import Enum
# from functools import partial from functools import partial
# from pathlib import Path from pathlib import Path
# from xml.dom.minidom import parseString from xml.dom.minidom import parseString
# from qgis.gui import * from qgis.gui import *
from qgis.core import ( from qgis.core import (
NULL,
QgsApplication, QgsApplication,
QgsDataSourceUri,
QgsProject,
QgsProviderConnectionException,
QgsProviderRegistry,
QgsRasterLayer,
QgsSettings, QgsSettings,
QgsVectorLayer,
QgsGeometry, QgsGeometry,
QgsWkbTypes, QgsWkbTypes,
) )
from qgis.PyQt import QtGui, QtCore from qgis.PyQt import QtGui
from qgis.PyQt.QtGui import QIcon from qgis.PyQt.QtCore import QLocale, QUrl, QDateTime
# from qgis.PyQt.QtPrintSupport import QPrinter from qgis.PyQt.QtGui import QDesktopServices, QIcon
# from qgis.PyQt.QtWebKitWidgets import QWebPage from qgis.PyQt.QtPrintSupport import QPrinter
import psycopg2 #from qgis.PyQt.QtWebKitWidgets import QWebPage
from qgis.PyQt.QtWidgets import ( from qgis.PyQt.QtWidgets import (
QDialog, QDialog,
QAction,
QDockWidget,
QFileDialog, QFileDialog,
QInputDialog,
QMenu,
QToolButton,
QTableWidget,
QTableWidgetItem, QTableWidgetItem,
) )
from qgis.utils import iface from qgis.utils import iface
try: try:
from .tools.PythonSQL import login_base from .tools.PythonSQL import login_base
except ValueError: except:
print('Pas de fichier PythonSQL') print('Pas de fichier PythonSQL')
from .tools.resources import ( from .tools.resources import (
load_ui, load_ui,
resources_path, resources_path,
# send_issues, send_issues,
) )
# from .issues import CenRa_Issues from .issues import CenRa_Issues
EDITOR_CLASS = load_ui('CenRa_Metabase_editorwidget_base.ui') EDITOR_CLASS = load_ui('CenRa_Metabase_editorwidget_base.ui')
LOGGEr = logging.getLogger('CenRa_Metabase') LOGGER = logging.getLogger('CenRa_Metabase')
class Metabase_Editor(QDialog, EDITOR_CLASS): class Metabase_Editor(QDialog, EDITOR_CLASS):
def __init__(self, parent=None): def __init__(self, parent=None):
_ = parent _ = parent
super().__init__() super().__init__()
self.setupUi(self) self.setupUi(self)
self.settings = QgsSettings() self.settings = QgsSettings()
self.setWindowIcon(QtGui.QIcon(resources_path('icons', 'icon.png'))) self.setWindowIcon(QtGui.QIcon(resources_path('icons','icon.png')))
self.import_xml.setAutoRaise(True) self.import_xml.setAutoRaise(True)
self.import_xml.setText('') self.import_xml.setText('')
self.import_xml.setIcon(QIcon(QgsApplication.iconPath('mActionAddHtml.svg'))) self.import_xml.setIcon(QIcon(QgsApplication.iconPath('mActionAddHtml.svg')))
@ -55,13 +68,13 @@ class Metabase_Editor(QDialog, EDITOR_CLASS):
self.issues_app.setAutoRaise(True) self.issues_app.setAutoRaise(True)
self.issues_app.setText('') self.issues_app.setText('')
self.issues_app.setIcon(QIcon(QgsApplication.iconPath('mIconInfo.svg'))) self.issues_app.setIcon(QIcon(QgsApplication.iconPath('mIconInfo.svg')))
self.auto_adding.setIcon(QtGui.QIcon(resources_path('icons', 'auto_add.png'))) self.auto_adding.setIcon(QtGui.QIcon(resources_path('icons','auto_add.png')))
self.auto_adding.hide() self.auto_adding.hide()
if os.getlogin() == 'tlaveille' or 'lpoulin' or 'rclement': if os.getlogin() == 'tlaveille' or 'lpoulin' or 'rclement':
self.auto_adding.show() self.auto_adding.show()
self.auto_adding.clicked.connect(self.auto_run) self.auto_adding.clicked.connect(self.auto_run)
# self.issues_app.clicked.connect(self.issues_open) self.issues_app.clicked.connect(self.issues_open)
self.categories_select_view.itemDoubleClicked.connect(self.add_categories_view) self.categories_select_view.itemDoubleClicked.connect(self.add_categories_view)
self.categories_view.itemDoubleClicked.connect(self.deleter_categories_view) self.categories_view.itemDoubleClicked.connect(self.deleter_categories_view)
self.themes_select_view.itemDoubleClicked.connect(self.add_themes_view) self.themes_select_view.itemDoubleClicked.connect(self.add_themes_view)
@ -89,7 +102,6 @@ class Metabase_Editor(QDialog, EDITOR_CLASS):
self.format_box.setCurrentIndex(0) self.format_box.setCurrentIndex(0)
self.taille_line.setText('45') self.taille_line.setText('45')
self.add_lien() self.add_lien()
def add_metadata(self): def add_metadata(self):
table_name = layer.dataProvider().uri().table() table_name = layer.dataProvider().uri().table()
schema_name = layer.dataProvider().uri().schema() schema_name = layer.dataProvider().uri().schema()
@ -105,19 +117,19 @@ class Metabase_Editor(QDialog, EDITOR_CLASS):
array_categories = '{' array_categories = '{'
while row_count_categories >= row: while row_count_categories >= row:
if row_count_categories != row: if row_count_categories != row:
array_categories += (self.categories_view.item(row - 1, 0).text()) + ', ' array_categories += (self.categories_view.item(row-1,0).text())+','
else: else:
array_categories += (self.categories_view.item(row - 1, 0).text()) array_categories += (self.categories_view.item(row-1,0).text())
row = row + 1 row = row+1
array_categories += '}' array_categories += '}'
row = 1 row = 1
array_themes = '{' array_themes = '{'
while row_count_themes >= row: while row_count_themes >= row:
if row_count_themes != row: if row_count_themes != row:
array_themes += (self.themes_view.item(row - 1, 0).text()) + ', ' array_themes += (self.themes_view.item(row-1,0).text())+','
else: else:
array_themes += (self.themes_view.item(row - 1, 0).text()) array_themes += (self.themes_view.item(row-1,0).text())
row = row + 1 row = row+1
array_themes += '}' array_themes += '}'
text_date_creation = str(self.date_creation_date.date().toPyDate()) text_date_creation = str(self.date_creation_date.date().toPyDate())
@ -150,65 +162,65 @@ class Metabase_Editor(QDialog, EDITOR_CLASS):
array_link = '' array_link = ''
while row_count_link >= row: while row_count_link >= row:
if row_count_link != row: if row_count_link != row:
array_link += "('" + table_name + "', '" + schema_name + "', '" + (self.table_lien.item(row - 1,1).text()) + "', '" + (self.table_lien.item(row - 1,2).text()) + "', '" + (self.table_lien.item(row - 1,3).text()) + "', '" + (self.table_lien.item(row - 1,4).text()) + "', '" + (self.table_lien.item(row - 1,5).text()) + "')" + ', ' array_link += "('"+ table_name +"','"+ schema_name +"','"+ (self.table_lien.item(row-1,1).text()) +"','"+ (self.table_lien.item(row-1,2).text()) +"','"+ (self.table_lien.item(row-1,3).text()) +"','"+ (self.table_lien.item(row-1,4).text()) +"','"+ (self.table_lien.item(row-1,5).text()) +"')"+','
else: else:
array_link += "('" + table_name + "', '" + schema_name + "', '" + (self.table_lien.item(row - 1,1).text()) + "', '" + (self.table_lien.item(row - 1,2).text()) + "', '" + (self.table_lien.item(row - 1,3).text()) + "', '" + (self.table_lien.item(row - 1,4).text()) + "', '" + (self.table_lien.item(row - 1,5).text()) + "')" array_link += "('"+ table_name +"','"+ schema_name +"','"+ (self.table_lien.item(row-1,1).text()) +"','"+ (self.table_lien.item(row-1,2).text()) +"','"+ (self.table_lien.item(row-1,3).text()) +"','"+ (self.table_lien.item(row-1,4).text()) +"','"+ (self.table_lien.item(row-1,5).text()) +"')"
row = row + 1 row = row+1
row_count_contact = self.table_contact.rowCount() row_count_contact = self.table_contact.rowCount()
row = 1 row = 1
array_contact = '' array_contact = ''
while row_count_contact >= row: while row_count_contact >= row:
if row_count_contact != row: if row_count_contact != row:
array_contact += "('" + table_name + "', '" + schema_name + "', '" + (self.table_contact.item(row - 1,1).text()) + "', '" + (self.table_contact.item(row - 1,2).text()) + "', '" + (self.table_contact.item(row - 1,3).text()) + "', '" + (self.table_contact.item(row - 1,4).text()) + "', '" + (self.table_contact.item(row - 1,5).text()) + "')" + ', ' array_contact += "('"+ table_name +"','"+ schema_name +"','"+ (self.table_contact.item(row-1,1).text()) +"','"+ (self.table_contact.item(row-1,2).text()) +"','"+ (self.table_contact.item(row-1,3).text()) +"','"+ (self.table_contact.item(row-1,4).text()) +"','"+ (self.table_contact.item(row-1,5).text()) +"')"+','
else: else:
array_contact += "('" + table_name + "', '" + schema_name + "', '" + (self.table_contact.item(row - 1,1).text()) + "', '" + (self.table_contact.item(row - 1,2).text()) + "', '" + (self.table_contact.item(row - 1,3).text()) + "', '" + (self.table_contact.item(row - 1,4).text()) + "', '" + (self.table_contact.item(row - 1,5).text()) + "')" array_contact += "('"+ table_name +"','"+ schema_name +"','"+ (self.table_contact.item(row-1,1).text()) +"','"+ (self.table_contact.item(row-1,2).text()) +"','"+ (self.table_contact.item(row-1,3).text()) +"','"+ (self.table_contact.item(row-1,4).text()) +"','"+ (self.table_contact.item(row-1,5).text()) +"')"
row = row + 1 row = row+1
''' '''
exist = self.status_metadata(layer) exist=self.status_metadata(layer)
cur_con = login_base(take=True) cur_con=login_base(take=True)
cur = cur_con[0] cur=cur_con[0]
con = cur_con[1] con=cur_con[1]
list_champs_sql = '' list_champs_sql = ''
values_sql_add = '' values_sql_add = ''
if exist: if exist:
SQL_uid = """SELECT uid from metadata.dataset where table_name like '""" + table_name + """' and schema_name like '""" + schema_name + """';""" SQL_uid = """SELECT uid from metadata.dataset where table_name like '"""+table_name+"""' and schema_name like '"""+schema_name+"""';"""
cur.execute(SQL_uid) cur.execute(SQL_uid)
text_uid = (cur.fetchall())[0][0] text_uid = (cur.fetchall())[0][0]
SQL_delete = """DELETE from metadata.dataset where table_name like '""" + table_name + """' and schema_name like '""" + schema_name + """';""" SQL_delete = """DELETE from metadata.dataset where table_name like '"""+table_name+"""' and schema_name like '"""+schema_name+"""';"""
cur.execute(SQL_delete) cur.execute(SQL_delete)
values_sql_add += "'" + text_uid + "'," values_sql_add += "'"+text_uid+"',"
list_champs_sql += 'uid,' list_champs_sql+='uid,'
global uid_delete_list_link, uid_delete_list_contact global uid_delete_list_link,uid_delete_list_contact
if len(uid_delete_list_link) >= 35: if len(uid_delete_list_link) >= 35:
SQL_delete_link = """DELETE FROM metadata.dataurl WHERE uid IN (""" + uid_delete_list_link[:- 1] + """);""" SQL_delete_link = """DELETE FROM metadata.dataurl WHERE uid IN ("""+ uid_delete_list_link[:-1] +""");"""
cur.execute(SQL_delete_link) cur.execute(SQL_delete_link)
uid_delete_list_link = '' uid_delete_list_link = ''
if len(uid_delete_list_contact) >= 35: if len(uid_delete_list_contact) >= 35:
SQL_delete_contact = """DELETE FROM metadata.datacontact WHERE uid IN (""" + uid_delete_list_contact[:- 1] + """);""" SQL_delete_contact = """DELETE FROM metadata.datacontact WHERE uid IN ("""+ uid_delete_list_contact[:-1] +""");"""
cur.execute(SQL_delete_contact) cur.execute(SQL_delete_contact)
uid_delete_list_contact = '' uid_delete_list_contact=''
list_champs_sql += 'table_name, schema_name, title, abstract, keywords, data_last_update, langue, categories, themes, creation_date, update_date, encode, geom, spatial_extent, feature_count, geometry_type, projection_name, projection_authid, spatial_level, minimum_optimal_scale, maximum_optimal_scale, publication_date, publication_frequency, confidentiality, license, license_attribution' list_champs_sql += 'table_name,schema_name,title,abstract,keywords,data_last_update,langue,categories,themes,creation_date,update_date,encode,geom,spatial_extent,feature_count,geometry_type,projection_name,projection_authid,spatial_level,minimum_optimal_scale,maximum_optimal_scale,publication_date,publication_frequency,confidentiality,license,license_attribution'
values_sql_add += "'" + table_name + "', '" + schema_name + "', '" + text_titre + "', '" + text_description + "', '" + text_mots_cles + "', '" + text_date_maj + "', '" + text_langue + "', '" + array_categories + "', '" + array_themes + "', '" + text_date_creation + "', '" + text_date_modification + "', '" + text_encode + "', '" + text_extend + "', '" + text_extend + "', '" + int_nbr_entites + "', '" + text_geomtype + "', '" + text_crsname + "', '" + text_crscode + "', '" + text_niveau + "'," + text_echelle_min + "," + text_echelle_max + ",'" + text_date_publication + "', '" + text_frequence + "', '" + text_restriction + "', '" + text_licence + "', '" + text_licence_attrib + "'" values_sql_add += "'"+table_name+"','"+schema_name+"','"+text_titre+"','"+text_description+"','"+text_mots_cles+"','"+text_date_maj+"','"+text_langue+"','"+array_categories+"','"+array_themes+"','"+text_date_creation+"','"+text_date_modification+"','"+text_encode+"','"+text_extend+"','"+text_extend+"','"+int_nbr_entites+"','"+text_geomtype+"','"+text_crsname+"','"+text_crscode+"','"+text_niveau+"',"+text_echelle_min+","+text_echelle_max+",'"+text_date_publication+"','"+text_frequence+"','"+text_restriction+"','"+text_licence+"','"+text_licence_attrib+"'"
SQL_add = """INSERT INTO metadata.dataset (""" + list_champs_sql + """) VALUES (""" + values_sql_add + """);""" SQL_add = """INSERT INTO metadata.dataset ("""+list_champs_sql+""") VALUES ("""+values_sql_add+""");"""
cur.execute(SQL_add) cur.execute(SQL_add)
global array_link, array_contact global array_link,array_contact
if len(array_link) >= 25: if len(array_link) >= 25:
array_link = array_link[:- 1] array_link=array_link[:-1]
SQL_add_link = """INSERT INTO metadata.dataurl (table_name, schema_name, type, url, mime, format, taille) VALUES """ + array_link + """;""" SQL_add_link = """INSERT INTO metadata.dataurl (table_name,schema_name,type,url,mime,format,taille) VALUES """+array_link+""";"""
cur.execute(SQL_add_link) cur.execute(SQL_add_link)
array_link = '' array_link = ''
if len(array_contact) >= 25: if len(array_contact) >= 25:
array_contact = array_contact[0:- 1] array_contact=array_contact[0:-1]
SQL_add_contact = """INSERT INTO metadata.datacontact (table_name, schema_name, role, nom, organisation, email, telephone) VALUES """ + array_contact + """;""" SQL_add_contact = """INSERT INTO metadata.datacontact (table_name,schema_name,role,nom,organisation,email,telephone) VALUES """+array_contact+""";"""
cur.execute(SQL_add_contact) cur.execute(SQL_add_contact)
array_contact = '' array_contact = ''
@ -223,28 +235,28 @@ class Metabase_Editor(QDialog, EDITOR_CLASS):
self.activateWindow() self.activateWindow()
global layer global layer
layer = iface.activeLayer() layer = iface.activeLayer()
global uid_delete_list_link, uid_delete_list_contact, array_link, array_contact global uid_delete_list_link,uid_delete_list_contact,array_link,array_contact
uid_delete_list_link = '' uid_delete_list_link=''
uid_delete_list_contact = '' uid_delete_list_contact=''
array_link = '' array_link = ''
array_contact = '' array_contact = ''
is_ok = self.is_in_psql(layer) is_ok=self.is_in_psql(layer)
if is_ok: if is_ok:
exist = self.status_metadata(layer) exist=self.status_metadata(layer)
if exist: if exist:
self.reload_data(layer) self.reload_data(layer)
else: else:
self.new_data(layer) self.new_data(layer)
else: else:
self.close() self.close()
iface.messageBar().pushMessage("Information:", "Cette couche n'est pas stockée dans PostgreSQL", level=1, duration=30) iface.messageBar().pushMessage("Information :", "Cette couche n'est pas stockée dans PostgreSQL", level=Qgis.Warning, duration=30)
def is_in_psql(self, layer): def is_in_psql(self,layer):
try: try:
uri = layer.dataProvider().uri() uri = layer.dataProvider().uri()
except AttributeError: except:
uri = '' uri=''
return False return False
if uri != '': if uri != '':
if not uri.table(): if not uri.table():
@ -252,13 +264,13 @@ class Metabase_Editor(QDialog, EDITOR_CLASS):
else: else:
return True return True
def status_metadata(self, layer): def status_metadata(self,layer):
uri = layer.dataProvider().uri() uri = layer.dataProvider().uri()
table = uri.table() table = uri.table()
schema = uri.schema() schema = uri.schema()
cur = login_base() cur=login_base()
count_sql = """ SELECT count(uid) FROM metadata.dataset WHERE table_name LIKE '""" + table + """' AND schema_name LIKE '""" + schema + """';""" count_sql = """ SELECT count(uid) FROM metadata.dataset WHERE table_name LIKE '"""+table+"""' AND schema_name LIKE '"""+schema+"""';"""
cur.execute(count_sql) cur.execute(count_sql)
data_count = (cur.fetchall())[0][0] data_count = (cur.fetchall())[0][0]
@ -268,17 +280,17 @@ class Metabase_Editor(QDialog, EDITOR_CLASS):
return False return False
cur.close() cur.close()
def new_data(self, layer): def new_data(self,layer):
# print(layer.name(),'is new data') #print(layer.name(),'is new data')
reloader = False reloader=False
self.interface_view(layer, reloader) self.interface_view(layer,reloader)
def reload_data(self, layer): def reload_data(self,layer):
# print(layer.name(),'reload data') #print(layer.name(),'reload data')
reloader = True reloader=True
self.interface_view(layer, reloader) self.interface_view(layer,reloader)
def interface_view(self, layer, reloader): def interface_view(self,layer,reloader):
self.description_text.setText(None) self.description_text.setText(None)
self.mots_cles_text.setText(None) self.mots_cles_text.setText(None)
@ -297,26 +309,27 @@ class Metabase_Editor(QDialog, EDITOR_CLASS):
self.licence_attrib_box.clear() self.licence_attrib_box.clear()
self.restriction_box.clear() self.restriction_box.clear()
all_list = self.fletch_ref() all_list=self.fletch_ref()
categories_list = all_list[0] categories_list=all_list[0]
themes_list = all_list[1] themes_list=all_list[1]
langue_list = all_list[2] langue_list=all_list[2]
encodage_list = all_list[3] encodage_list=all_list[3]
frequency_list = all_list[4] frequency_list=all_list[4]
confidentiality_list = all_list[5] confidentiality_list=all_list[5]
license_list = all_list[6] license_list=all_list[6]
type_list = all_list[7] type_list=all_list[7]
mime_list = all_list[8] mime_list=all_list[8]
format_list = all_list[9] format_list=all_list[9]
role_list = all_list[10] role_list=all_list[10]
organisation_list = all_list[11] organisation_list=all_list[11]
# langue_box
#langue_box
self.langue_box.clear() self.langue_box.clear()
self.langue_box.addItem('') self.langue_box.addItem('')
# self.langue_box.addItem('Fr') #self.langue_box.addItem('Fr')
# self.langue_box.addItem('En') #self.langue_box.addItem('En')
for langue_list_data in langue_list: for langue_list_data in langue_list:
self.langue_box.addItem(langue_list_data[0]) self.langue_box.addItem(langue_list_data[0])
@ -326,46 +339,46 @@ class Metabase_Editor(QDialog, EDITOR_CLASS):
self.table_ligne.setText(layer.dataProvider().uri().table()) self.table_ligne.setText(layer.dataProvider().uri().table())
self.schema_ligne.setText(layer.dataProvider().uri().schema()) self.schema_ligne.setText(layer.dataProvider().uri().schema())
# categories_select_view #categories_select_view
self.categories_select_view.setColumnCount(1) self.categories_select_view.setColumnCount(1)
self.categories_select_view.setColumnWidth(0, 230) self.categories_select_view.setColumnWidth(0, 230)
self.categories_select_view.setHorizontalHeaderLabels(['List des categories']) self.categories_select_view.setHorizontalHeaderLabels(['List des categories'])
# categories_view #categories_view
self.categories_view.setRowCount(0) self.categories_view.setRowCount(0)
self.categories_view.setColumnCount(1) self.categories_view.setColumnCount(1)
self.categories_view.setColumnWidth(0, 230) self.categories_view.setColumnWidth(0, 230)
self.categories_view.setHorizontalHeaderLabels(['Categories']) self.categories_view.setHorizontalHeaderLabels(['Categories'])
# themes_select_view #themes_select_view
self.themes_select_view.setColumnCount(1) self.themes_select_view.setColumnCount(1)
self.themes_select_view.setColumnWidth(0, 230) self.themes_select_view.setColumnWidth(0, 230)
self.themes_select_view.setHorizontalHeaderLabels(['List des thèmes']) self.themes_select_view.setHorizontalHeaderLabels(['List des thèmes'])
# themes_view #themes_view
self.themes_view.setRowCount(0) self.themes_view.setRowCount(0)
self.themes_view.setColumnCount(1) self.themes_view.setColumnCount(1)
self.themes_view.setColumnWidth(0, 230) self.themes_view.setColumnWidth(0, 230)
self.themes_view.setHorizontalHeaderLabels(['Thèmes']) self.themes_view.setHorizontalHeaderLabels(['Thèmes'])
# lien_view #lien_view
self.table_lien.setRowCount(0) self.table_lien.setRowCount(0)
self.table_lien.setColumnCount(6) self.table_lien.setColumnCount(6)
self.table_lien.setColumnWidth(0, 0) self.table_lien.setColumnWidth(0, 0)
self.table_lien.setHorizontalHeaderLabels(['', 'Type', 'URL', 'MIME', 'Format', 'Taille']) self.table_lien.setHorizontalHeaderLabels(['','Type','URL','MIME','Format','Taille'])
# contact_view #contact_view
self.table_contact.setRowCount(0) self.table_contact.setRowCount(0)
self.table_contact.setColumnCount(6) self.table_contact.setColumnCount(6)
self.table_contact.setColumnWidth(0, 0) self.table_contact.setColumnWidth(0, 0)
self.table_contact.setHorizontalHeaderLabels(['', 'Rôle', 'Nom', 'Organisation', 'Email', 'Telephone']) self.table_contact.setHorizontalHeaderLabels(['','Rôle','Nom','Organisation','Email','Telephone'])
# print(self.date_maj_date.date().toPyDate()) #print(self.date_maj_date.date().toPyDate())
vector_extend = layer.extent() vector_extend = layer.extent()
polygone_extend = QgsGeometry.fromRect(vector_extend).asWkt() polygone_extend = QgsGeometry.fromRect(vector_extend).asWkt()
self.extend_plaintext.setPlainText(str(polygone_extend)) self.extend_plaintext.setPlainText(str(polygone_extend))
qgstype = str(layer.type())[10:] qgstype = str(layer.type())[10:]
if qgstype != 'Raster': if qgstype != 'Raster' :
count_layers = str(layer.featureCount()) count_layers = str(layer.featureCount())
geomtype = QgsWkbTypes.displayString(layer.wkbType()) geomtype = QgsWkbTypes.displayString(layer.wkbType())
elif qgstype == 'Raster': elif qgstype == 'Raster':
@ -379,6 +392,7 @@ class Metabase_Editor(QDialog, EDITOR_CLASS):
crs_code = str(layer.crs().authid()) crs_code = str(layer.crs().authid())
self.crscode_plaintext.setPlainText(crs_code) self.crscode_plaintext.setPlainText(crs_code)
self.frequence_box.addItem('') self.frequence_box.addItem('')
self.restriction_box.addItem('') self.restriction_box.addItem('')
self.licence_box.addItem('') self.licence_box.addItem('')
@ -414,12 +428,12 @@ class Metabase_Editor(QDialog, EDITOR_CLASS):
self.organisation_box.addItem(organisation_list_data[0]) self.organisation_box.addItem(organisation_list_data[0])
if reloader: if reloader:
sql_dataload = self.sql_info(layer.dataProvider().uri()) sql_dataload=self.sql_info(layer.dataProvider().uri())
sql_contactlink = self.sql_infoother(layer.dataProvider().uri()) sql_contactlink=self.sql_infoother(layer.dataProvider().uri())
sql_datalink = sql_contactlink[0] sql_datalink=sql_contactlink[0]
sql_datacontact = sql_contactlink[1] sql_datacontact=sql_contactlink[1]
# print(sql_dataload) #print(sql_dataload)
self.titre_line.setText(sql_dataload[4]) self.titre_line.setText(sql_dataload[4])
self.date_maj_date.setDateTime(sql_dataload[23]) self.date_maj_date.setDateTime(sql_dataload[23])
self.date_publication_date.setDateTime(sql_dataload[11]) self.date_publication_date.setDateTime(sql_dataload[11])
@ -430,38 +444,38 @@ class Metabase_Editor(QDialog, EDITOR_CLASS):
self.uuid_ligne.setText(sql_dataload[1]) self.uuid_ligne.setText(sql_dataload[1])
self.categories_view.setRowCount(len(sql_dataload[6])) self.categories_view.setRowCount(len(sql_dataload[6]))
i = 0 i=0
for categorie_data in sql_dataload[6]: for categorie_data in sql_dataload[6]:
self.categories_view.setItem(i, 0, QTableWidgetItem(categorie_data)) self.categories_view.setItem(i,0,QTableWidgetItem(categorie_data))
i = i + 1 i=i+1
self.themes_view.setRowCount(len(sql_dataload[24])) self.themes_view.setRowCount(len(sql_dataload[24]))
i = 0 i=0
for themes_data in sql_dataload[24]: for themes_data in sql_dataload[24]:
self.themes_view.setItem(i, 0, QTableWidgetItem(themes_data)) self.themes_view.setItem(i,0,QTableWidgetItem(themes_data))
i = i + 1 i=i+1
self.categories_select_view.setRowCount(len(categories_list) - len(sql_dataload[6])) self.categories_select_view.setRowCount(len(categories_list)-len(sql_dataload[6]))
self.themes_select_view.setRowCount(len(themes_list) - len(sql_dataload[24])) self.themes_select_view.setRowCount(len(themes_list)-len(sql_dataload[24]))
i = 0 i=0
for categorie_select_data in categories_list: for categorie_select_data in categories_list:
try: try:
in_index = sql_dataload[6].index(categorie_select_data[0]) in_index = sql_dataload[6].index(categorie_select_data[0])
in_index = False in_index=False
except ValueError: except:
in_index = True in_index=True
if in_index: if in_index:
self.categories_select_view.setItem(i, 0, QTableWidgetItem(categorie_select_data[0])) self.categories_select_view.setItem(i,0,QTableWidgetItem(categorie_select_data[0]))
i = i + 1 i=i+1
i = 0 i=0
for themes_select_data in themes_list: for themes_select_data in themes_list:
try: try:
in_index = sql_dataload[24].index(themes_select_data[0]) in_index = sql_dataload[24].index(themes_select_data[0])
in_index = False in_index=False
except ValueError: except:
in_index = True in_index=True
if in_index: if in_index:
self.themes_select_view.setItem(i, 0, QTableWidgetItem(themes_select_data[0])) self.themes_select_view.setItem(i,0,QTableWidgetItem(themes_select_data[0]))
i = i + 1 i=i+1
array_encodage_box = [self.encodage_box.itemText(i) for i in range(self.encodage_box.count())] array_encodage_box = [self.encodage_box.itemText(i) for i in range(self.encodage_box.count())]
self.encodage_box.setCurrentIndex(array_encodage_box.index(sql_dataload[27])) self.encodage_box.setCurrentIndex(array_encodage_box.index(sql_dataload[27]))
@ -490,35 +504,35 @@ class Metabase_Editor(QDialog, EDITOR_CLASS):
array_licence_attrib_box = [self.licence_attrib_box.itemText(i) for i in range(self.licence_attrib_box.count())] array_licence_attrib_box = [self.licence_attrib_box.itemText(i) for i in range(self.licence_attrib_box.count())]
self.licence_attrib_box.setCurrentIndex(array_licence_attrib_box.index(sql_dataload[25])) self.licence_attrib_box.setCurrentIndex(array_licence_attrib_box.index(sql_dataload[25]))
c = 0 c=0
# self.table_lien.setRowCount(len(sql_datalink)) #self.table_lien.setRowCount(len(sql_datalink))
for lien_data in sql_datalink: for lien_data in sql_datalink:
self.table_lien.insertRow(c) self.table_lien.insertRow(c)
self.table_lien.setItem(c, 0, QTableWidgetItem(lien_data[1])) self.table_lien.setItem(c,0,QTableWidgetItem(lien_data[1]))
self.table_lien.setItem(c, 1, QTableWidgetItem(lien_data[4])) self.table_lien.setItem(c,1,QTableWidgetItem(lien_data[4]))
self.table_lien.setItem(c, 2, QTableWidgetItem(lien_data[5])) self.table_lien.setItem(c,2,QTableWidgetItem(lien_data[5]))
self.table_lien.setItem(c, 3, QTableWidgetItem(lien_data[6])) self.table_lien.setItem(c,3,QTableWidgetItem(lien_data[6]))
self.table_lien.setItem(c, 4, QTableWidgetItem(lien_data[7])) self.table_lien.setItem(c,4,QTableWidgetItem(lien_data[7]))
self.table_lien.setItem(c, 5, QTableWidgetItem(lien_data[8])) self.table_lien.setItem(c,5,QTableWidgetItem(lien_data[8]))
c = c + 1 c=c+1
c = 0 c=0
# self.table_contact.setRowCount(len(sql_datacontact)) #self.table_contact.setRowCount(len(sql_datacontact))
for contact_data in sql_datacontact: for contact_data in sql_datacontact:
self.table_contact.insertRow(c) self.table_contact.insertRow(c)
self.table_contact.setItem(c, 0, QTableWidgetItem(contact_data[1])) self.table_contact.setItem(c,0,QTableWidgetItem(contact_data[1]))
self.table_contact.setItem(c, 1, QTableWidgetItem(contact_data[4])) self.table_contact.setItem(c,1,QTableWidgetItem(contact_data[4]))
self.table_contact.setItem(c, 2, QTableWidgetItem(contact_data[5])) self.table_contact.setItem(c,2,QTableWidgetItem(contact_data[5]))
self.table_contact.setItem(c, 3, QTableWidgetItem(contact_data[6])) self.table_contact.setItem(c,3,QTableWidgetItem(contact_data[6]))
self.table_contact.setItem(c, 4, QTableWidgetItem(contact_data[7])) self.table_contact.setItem(c,4,QTableWidgetItem(contact_data[7]))
self.table_contact.setItem(c, 5, QTableWidgetItem(contact_data[8])) self.table_contact.setItem(c,5,QTableWidgetItem(contact_data[8]))
c = c + 1 c=c+1
else: else:
# titre_line #titre_line
self.titre_line.setText(layer.name()) self.titre_line.setText(layer.name())
self.langue_box.setCurrentIndex(1) self.langue_box.setCurrentIndex(1)
# date_maj_date #date_maj_date
now = QtCore.QDateTime.currentDateTime() now = QtCore.QDateTime.currentDateTime()
self.date_maj_date.setDateTime(now) self.date_maj_date.setDateTime(now)
self.date_creation_date.setDateTime(now) self.date_creation_date.setDateTime(now)
@ -526,89 +540,87 @@ class Metabase_Editor(QDialog, EDITOR_CLASS):
self.date_publication_date.setDateTime(now) self.date_publication_date.setDateTime(now)
self.categories_select_view.setRowCount(len(categories_list)) self.categories_select_view.setRowCount(len(categories_list))
self.themes_select_view.setRowCount(len(themes_list)) self.themes_select_view.setRowCount(len(themes_list))
i = 0 i=0
for categorie_select_data in categories_list: for categorie_select_data in categories_list:
self.categories_select_view.setItem(i, 0, QTableWidgetItem(categorie_select_data[0])) self.categories_select_view.setItem(i,0,QTableWidgetItem(categorie_select_data[0]))
i = i + 1 i=i+1
i = 0 i=0
for themes_select_data in themes_list: for themes_select_data in themes_list:
self.themes_select_view.setItem(i, 0, QTableWidgetItem(themes_select_data[0])) self.themes_select_view.setItem(i,0,QTableWidgetItem(themes_select_data[0]))
i = i + 1 i=i+1
# print(self.langue_box.currentText()) #print(self.langue_box.currentText())
def sql_info(self, uri): def sql_info(self,uri):
cur = login_base() cur=login_base()
table = uri.table() table = uri.table()
schema = uri.schema() schema = uri.schema()
# [s for s in iface.activeLayer().source().split(" ") if "dbname" in s][0].split("'")[1] #[s for s in iface.activeLayer().source().split(" ") if "dbname" in s][0].split("'")[1]
sql_find = """SELECT *, right(left(st_astext(geom,2),-2),-9) FROM metadata.dataset sql_find = """SELECT *,right(left(st_astext(geom,2),-2),-9) FROM metadata.dataset
WHERE schema_name LIKE '""" + schema + """' AND table_name LIKE '""" + table + """';""" WHERE schema_name LIKE '"""+schema+"""' AND table_name LIKE '"""+table+"""';"""
cur.execute(sql_find) cur.execute(sql_find)
data_general = cur.fetchall() data_general = cur.fetchall()
cur.close() cur.close()
return data_general[0] return data_general[0]
def sql_infoother(self, uri): def sql_infoother(self,uri):
cur = login_base() cur=login_base()
table = uri.table() table = uri.table()
schema = uri.schema() schema = uri.schema()
sql_findlink = """SELECT * FROM metadata.dataurl sql_findlink = """SELECT * FROM metadata.dataurl
WHERE schema_name LIKE '""" + schema + """' AND table_name LIKE '""" + table + """';""" WHERE schema_name LIKE '"""+schema+"""' AND table_name LIKE '"""+table+"""';"""
cur.execute(sql_findlink) cur.execute(sql_findlink)
data_link = cur.fetchall() data_link = cur.fetchall()
sql_findcontact = """SELECT * FROM metadata.datacontact sql_findcontact = """SELECT * FROM metadata.datacontact
WHERE schema_name LIKE '""" + schema + """' AND table_name LIKE '""" + table + """';""" WHERE schema_name LIKE '"""+schema+"""' AND table_name LIKE '"""+table+"""';"""
cur.execute(sql_findcontact) cur.execute(sql_findcontact)
data_contact = cur.fetchall() data_contact = cur.fetchall()
cur.close() cur.close()
return data_link, data_contact return data_link,data_contact
def add_categories_view(self): def add_categories_view(self):
values_add_categories = self.categories_select_view.selectedItems()[0].text() values_add_categories = self.categories_select_view.selectedItems()[0].text()
self.categories_select_view.removeRow(self.categories_select_view.currentRow()) self.categories_select_view.removeRow(self.categories_select_view.currentRow())
self.categories_view.insertRow(0) self.categories_view.insertRow(0)
self.categories_view.setItem(0, 0, QTableWidgetItem(values_add_categories)) self.categories_view.setItem(0,0,QTableWidgetItem(values_add_categories))
def deleter_categories_view(self): def deleter_categories_view(self):
values_deleter_categories = self.categories_view.selectedItems()[0].text() values_deleter_categories = self.categories_view.selectedItems()[0].text()
self.categories_view.removeRow(self.categories_view.currentRow()) self.categories_view.removeRow(self.categories_view.currentRow())
self.categories_select_view.insertRow(0) self.categories_select_view.insertRow(0)
self.categories_select_view.setItem(0, 0, QTableWidgetItem(values_deleter_categories)) self.categories_select_view.setItem(0,0,QTableWidgetItem(values_deleter_categories))
def add_themes_view(self): def add_themes_view(self):
values_add_themes = self.themes_select_view.selectedItems()[0].text() values_add_themes = self.themes_select_view.selectedItems()[0].text()
self.themes_select_view.removeRow(self.themes_select_view.currentRow()) self.themes_select_view.removeRow(self.themes_select_view.currentRow())
self.themes_view.insertRow(0) self.themes_view.insertRow(0)
self.themes_view.setItem(0, 0, QTableWidgetItem(values_add_themes)) self.themes_view.setItem(0,0,QTableWidgetItem(values_add_themes))
def deleter_themes_view(self): def deleter_themes_view(self):
values_deleter_themes = self.themes_view.selectedItems()[0].text() values_deleter_themes = self.themes_view.selectedItems()[0].text()
self.themes_view.removeRow(self.themes_view.currentRow()) self.themes_view.removeRow(self.themes_view.currentRow())
self.themes_select_view.insertRow(0) self.themes_select_view.insertRow(0)
self.themes_select_view.setItem(0, 0, QTableWidgetItem(values_deleter_themes)) self.themes_select_view.setItem(0,0,QTableWidgetItem(values_deleter_themes))
def add_lien(self): def add_lien(self):
cur = login_base() cur=login_base()
maxrow = self.table_lien.rowCount() maxrow=self.table_lien.rowCount()
self.table_lien.insertRow(maxrow) self.table_lien.insertRow(maxrow)
table = layer.dataProvider().uri().table() table = layer.dataProvider().uri().table()
schema = layer.dataProvider().uri().schema() schema = layer.dataProvider().uri().schema()
if self.taille_line.text() == '': if self.taille_line.text() == '':
sql_sizefile = """SELECT pg_size_pretty(pg_total_relation_size('""" + schema + '.' + table + """'));""" sql_sizefile = """SELECT pg_size_pretty(pg_total_relation_size('"""+schema+'.'+table+"""'));"""
try: try:
cur.execute(sql_sizefile) cur.execute(sql_sizefile)
boolean = True boolean = True
except psycopg2.errors.UndefinedTable: except:
boolean = False boolean = False
if boolean is True: if boolean == True:
size_file = (cur.fetchall())[0][0] size_file = (cur.fetchall())[0][0]
else: else:
size_file = '' size_file = ''
@ -616,159 +628,148 @@ class Metabase_Editor(QDialog, EDITOR_CLASS):
else: else:
size_file = self.taille_line.text() size_file = self.taille_line.text()
self.table_lien.setItem(maxrow, 0, QTableWidgetItem('new_value')) self.table_lien.setItem(maxrow,0,QTableWidgetItem('new_value'))
self.table_lien.setItem(maxrow, 1, QTableWidgetItem(self.type_box.currentText())) self.table_lien.setItem(maxrow,1,QTableWidgetItem(self.type_box.currentText()))
self.table_lien.setItem(maxrow, 2, QTableWidgetItem(self.url_line.text())) self.table_lien.setItem(maxrow,2,QTableWidgetItem(self.url_line.text()))
self.table_lien.setItem(maxrow, 3, QTableWidgetItem(self.mime_box.currentText())) self.table_lien.setItem(maxrow,3,QTableWidgetItem(self.mime_box.currentText()))
self.table_lien.setItem(maxrow, 4, QTableWidgetItem(self.format_box.currentText())) self.table_lien.setItem(maxrow,4,QTableWidgetItem(self.format_box.currentText()))
self.table_lien.setItem(maxrow, 5, QTableWidgetItem(str(size_file))) self.table_lien.setItem(maxrow,5,QTableWidgetItem(str(size_file)))
global array_link global array_link
array_link += "('" + table + "', '" + schema + "', '" + self.type_box.currentText() + "', '" + self.url_line.text() + "', '" + self.mime_box.currentText() + "', '" + self.format_box.currentText() + "', '" + size_file + "')," array_link += "('"+ table +"','"+ schema +"','"+ self.type_box.currentText() +"','"+ self.url_line.text() +"','"+ self.mime_box.currentText() +"','"+ self.format_box.currentText() +"','"+ size_file +"'),"
cur.close() cur.close()
def add_contact(self): def add_contact(self):
maxrow = self.table_contact.rowCount() maxrow=self.table_contact.rowCount()
self.table_contact.insertRow(maxrow) self.table_contact.insertRow(maxrow)
self.table_contact.setItem(maxrow, 0, QTableWidgetItem('new_value')) self.table_contact.setItem(maxrow,0,QTableWidgetItem('new_value'))
self.table_contact.setItem(maxrow, 1, QTableWidgetItem(self.role_box.currentText())) self.table_contact.setItem(maxrow,1,QTableWidgetItem(self.role_box.currentText()))
self.table_contact.setItem(maxrow, 2, QTableWidgetItem(self.nom_line.text())) self.table_contact.setItem(maxrow,2,QTableWidgetItem(self.nom_line.text()))
self.table_contact.setItem(maxrow, 3, QTableWidgetItem(self.organisation_box.currentText())) self.table_contact.setItem(maxrow,3,QTableWidgetItem(self.organisation_box.currentText()))
self.table_contact.setItem(maxrow, 4, QTableWidgetItem(self.email_line.text())) self.table_contact.setItem(maxrow,4,QTableWidgetItem(self.email_line.text()))
self.table_contact.setItem(maxrow, 5, QTableWidgetItem(self.telephone_line.text())) self.table_contact.setItem(maxrow,5,QTableWidgetItem(self.telephone_line.text()))
table = layer.dataProvider().uri().table() table = layer.dataProvider().uri().table()
schema = layer.dataProvider().uri().schema() schema = layer.dataProvider().uri().schema()
global array_contact global array_contact
array_contact += "('" + table + "', '" + schema + "', '" + self.role_box.currentText() + "', '" + self.nom_line.text() + "', '" + self.organisation_box.currentText() + "', '" + self.email_line.text() + "', '" + self.telephone_line.text() + "')," array_contact += "('"+ table +"','"+ schema +"','"+ self.role_box.currentText() +"','"+ self.nom_line.text() +"','"+ self.organisation_box.currentText() +"','"+ self.email_line.text() +"','"+ self.telephone_line.text() +"'),"
def delete_lien(self): def delete_lien(self):
fin = ''
global uid_delete_list_link, array_link global uid_delete_list_link,array_link
try: lien_uid = self.table_lien.item(self.table_lien.currentRow(),0).text()
lien_uid = self.table_lien.item(self.table_lien.currentRow(), 0).text()
except AttributeError:
lien_uid = True
self.table_lien.removeRow(self.table_lien.currentRow()) self.table_lien.removeRow(self.table_lien.currentRow())
if lien_uid == 'new_value': if lien_uid == 'new_value':
position = self.table_lien.currentRow() position = self.table_lien.currentRow()
if position < 0: if position < 0:
position = position + 1 position=position+1
run_x = 0 run_x = 0
while position >= run_x: while position >= run_x:
# print(position, run_x) #print(position,run_x)
if run_x == 0: if run_x == 0:
debut = array_link.find("(") debut = array_link.find("(")
else: else:
debut = array_link.find("(", fin + 1) debut = array_link.find("(",fin+1)
fin = array_link.find(")", debut) fin = array_link.find(")",debut)
# print(debut, fin) #print(debut,fin)
if run_x == 50: if run_x == 50:
break break
run_x += 1 run_x+=1
# print(array_link[fin + 1:]) #print(array_link[fin+1:])
if debut <= 0: if debut <= 0:
debut = 1 debut = 1
fin += 1 fin+= 1
array_link = array_link[:debut - 1] + array_link[fin + 1:] array_link = array_link[:debut-1]+array_link[fin+1:]
# print('a:', array_link) #print('a:',array_link)
elif lien_uid is True:
print('Pas de ligne "Lien"')
else: else:
uid_delete_list_link += "'" + lien_uid + "'," uid_delete_list_link += "'"+lien_uid+"',"
def delete_contact(self): def delete_contact(self):
fin = '' global uid_delete_list_contact,array_contact
global uid_delete_list_contact, array_contact contact_uid = self.table_contact.item(self.table_contact.currentRow(),0).text()
try:
contact_uid = self.table_contact.item(self.table_contact.currentRow(), 0).text()
except AttributeError:
contact_uid = True
self.table_contact.removeRow(self.table_contact.currentRow()) self.table_contact.removeRow(self.table_contact.currentRow())
if contact_uid == 'new_value': if contact_uid == 'new_value':
position = self.table_contact.currentRow() position = self.table_contact.currentRow()
if position < 0: if position < 0:
position = position + 1 position=position+1
# print('p:', position) #print('p:',position)
run_x = 0 run_x = 0
while position >= run_x: while position >= run_x:
if run_x == 0: if run_x == 0:
debut = array_contact.find("(") debut = array_contact.find("(")
else: else:
debut = array_contact.find("(", fin + 1) debut = array_contact.find("(",fin+1)
fin = array_contact.find(")", debut) fin = array_contact.find(")",debut)
# print(debut, fin) #print(debut,fin)
if run_x == 50: if run_x == 50:
break break
run_x += 1 run_x+=1
# print(array_contact[fin + 1:]) #print(array_contact[fin+1:])
if debut <= 0: if debut <= 0:
debut = 1 debut = 1
fin += 1 fin+= 1
array_contact = array_contact[:debut - 1] + array_contact[fin + 1:] array_contact = array_contact[:debut-1]+array_contact[fin+1:]
# print('a:', array_contact) #print('a:',array_contact)
elif contact_uid is True:
print('Pas de ligne "Contact"')
else: else:
uid_delete_list_contact += "'" + contact_uid + "'," uid_delete_list_contact += "'"+contact_uid+"',"
def fletch_ref(self): def fletch_ref(self):
cur = login_base() cur=login_base()
SQL_categories = """SELECT label_fr FROM metadata.glossary WHERE field LIKE 'dataset.categories' ORDER BY code, item_order;""" SQL_categories="""SELECT label_fr FROM metadata.glossary WHERE field LIKE 'dataset.categories' ORDER BY code,item_order;"""
SQL_themes = """SELECT label_fr FROM metadata.glossary WHERE field LIKE 'dataset.themes' ORDER BY label_fr;""" SQL_themes="""SELECT label_fr FROM metadata.glossary WHERE field LIKE 'dataset.themes' ORDER BY label_fr;"""
SQL_langue = """SELECT label_fr FROM metadata.glossary WHERE field LIKE 'dataset.langue';""" SQL_langue="""SELECT label_fr FROM metadata.glossary WHERE field LIKE 'dataset.langue';"""
SQL_encodage = """SELECT label_fr FROM metadata.glossary WHERE field LIKE 'dataset.encodage';""" SQL_encodage="""SELECT label_fr FROM metadata.glossary WHERE field LIKE 'dataset.encodage';"""
SQL_frequency = """SELECT label_fr FROM metadata.glossary WHERE field LIKE 'dataset.publication_frequency' ORDER BY label_fr;""" SQL_frequency="""SELECT label_fr FROM metadata.glossary WHERE field LIKE 'dataset.publication_frequency' ORDER BY label_fr;"""
SQL_confidentiality = """SELECT label_fr FROM metadata.glossary WHERE field LIKE 'dataset.confidentiality' ORDER BY label_fr;""" SQL_confidentiality="""SELECT label_fr FROM metadata.glossary WHERE field LIKE 'dataset.confidentiality' ORDER BY label_fr;"""
SQL_license = """SELECT label_fr FROM metadata.glossary WHERE field LIKE 'dataset.license' ORDER BY label_fr;""" SQL_license="""SELECT label_fr FROM metadata.glossary WHERE field LIKE 'dataset.license' ORDER BY label_fr;"""
SQL_type = """SELECT label_fr FROM metadata.glossary WHERE field LIKE 'link.type' ORDER BY label_fr;""" SQL_type="""SELECT label_fr FROM metadata.glossary WHERE field LIKE 'link.type' ORDER BY label_fr;"""
SQL_mime = """SELECT label_fr FROM metadata.glossary WHERE field LIKE 'link.mime' ORDER BY label_fr;""" SQL_mime="""SELECT label_fr FROM metadata.glossary WHERE field LIKE 'link.mime' ORDER BY label_fr;"""
SQL_format = """SELECT label_fr FROM metadata.glossary WHERE field LIKE 'link.format' ORDER BY label_fr;""" SQL_format="""SELECT label_fr FROM metadata.glossary WHERE field LIKE 'link.format' ORDER BY label_fr;"""
SQL_role = """SELECT label_fr FROM metadata.glossary WHERE field LIKE 'contact.contact_role' ORDER BY label_fr;""" SQL_role="""SELECT label_fr FROM metadata.glossary WHERE field LIKE 'contact.contact_role' ORDER BY label_fr;"""
SQL_organisation = """SELECT label_fr FROM metadata.glossary WHERE field LIKE 'contact.organisation' ORDER BY label_fr;""" SQL_organisation="""SELECT label_fr FROM metadata.glossary WHERE field LIKE 'contact.organisation' ORDER BY label_fr;"""
cur.execute(SQL_categories) cur.execute(SQL_categories)
categories_list = cur.fetchall() categories_list=cur.fetchall()
cur.execute(SQL_themes) cur.execute(SQL_themes)
themes_list = cur.fetchall() themes_list=cur.fetchall()
cur.execute(SQL_langue) cur.execute(SQL_langue)
langue_list = cur.fetchall() langue_list=cur.fetchall()
cur.execute(SQL_encodage) cur.execute(SQL_encodage)
encodage_list = cur.fetchall() encodage_list=cur.fetchall()
cur.execute(SQL_frequency) cur.execute(SQL_frequency)
frequency_list = cur.fetchall() frequency_list=cur.fetchall()
cur.execute(SQL_confidentiality) cur.execute(SQL_confidentiality)
confidentiality_list = cur.fetchall() confidentiality_list=cur.fetchall()
cur.execute(SQL_license) cur.execute(SQL_license)
license_list = cur.fetchall() license_list=cur.fetchall()
cur.execute(SQL_type) cur.execute(SQL_type)
type_list = cur.fetchall() type_list=cur.fetchall()
cur.execute(SQL_mime) cur.execute(SQL_mime)
mime_list = cur.fetchall() mime_list=cur.fetchall()
cur.execute(SQL_format) cur.execute(SQL_format)
format_list = cur.fetchall() format_list=cur.fetchall()
cur.execute(SQL_role) cur.execute(SQL_role)
role_list = cur.fetchall() role_list=cur.fetchall()
cur.execute(SQL_organisation) cur.execute(SQL_organisation)
organisation_list = cur.fetchall() organisation_list=cur.fetchall()
return categories_list, themes_list, langue_list, encodage_list, frequency_list, confidentiality_list, license_list, type_list, mime_list, format_list, role_list, organisation_list return categories_list,themes_list,langue_list,encodage_list,frequency_list,confidentiality_list,license_list,type_list,mime_list,format_list,role_list,organisation_list
cur.close() cur.close()
def py_import_xml(self): def py_import_xml(self):
folder = QFileDialog.getOpenFileName() folder = QFileDialog.getOpenFileName()
if folder: if folder:
folder = folder[0] folder=folder[0]
if folder[len(folder) - 4:] == '.xml': if folder[len(folder)-4:] == '.xml' :
print('is .xml') print('is .xml')
def issues_open(self):
# def issues_open(self): self.issues = CenRa_Issues()
# self.issues = CenRa_Issues() self.issues.show()
# self.issues.show()

View File

@ -3,12 +3,9 @@
import configparser import configparser
import shutil import shutil
import tempfile import tempfile
# import base64
# import psycopg2
# import psycopg2.extras
import os import os
from os.path import abspath, join, pardir, dirname from os.path import abspath, join, pardir, dirname
from qgis.PyQt.QtWidgets import QApplication
from qgis.PyQt import uic from qgis.PyQt import uic
__copyright__ = "Copyright 2019, 3Liz" __copyright__ = "Copyright 2019, 3Liz"
@ -95,6 +92,14 @@ def resources_path(*args):
path = abspath(join(path, item)) path = abspath(join(path, item))
return path return path
def pyperclip():
dst = dirname(dirname(__file__))+"\\tools\\"
if os.access('N:/',os.R_OK):
src = 'N:/SI_Systeme d information/Z_QGIS/PLUGIN/PythonSQL.py'
try:
shutil.copy(src, dst)
except:
print('404')
def load_ui(*args): def load_ui(*args):
"""Get compile UI file. """Get compile UI file.
@ -108,77 +113,65 @@ def load_ui(*args):
return ui_class return ui_class
def send_issues(url,titre,body,labels):
def pyperclip():
dst = dirname(dirname(__file__)) + "\\tools\\"
if os.access('N:/', os.R_OK):
src = 'N:/SI_Systeme d information/Z_QGIS/PLUGIN/PythonSQL.py'
try:
shutil.copy(src, dst)
except FileNotFoundError:
print('404')
except UnboundLocalError:
print('404')
def send_issues(url, titre, body, labels):
import requests import requests
import urllib.request
import json import json
# import os import os
# import qgis import qgis
# usr = os.environ['USERNAME'] usr = os.environ['USERNAME']
token = '9d0a4e0bea561710e0728f161f7edf4e5201e112' token = '9d0a4e0bea561710e0728f161f7edf4e5201e112'
url = url + '?token=' + token url=url+'?token='+token
headers = {'Authorization': 'token ' + token,'accept': 'application/json','Content-Type': 'application/json'}
headers = {'Authorization': 'token ' + token, 'accept': 'application/json', 'Content-Type': 'application/json'}
payload = {'title': titre, 'body': body, 'labels': labels} payload = {'title': titre, 'body': body, 'labels': labels}
try: try:
urllib.request.urlopen('https://google.com') urllib.request.urlopen('https://google.com')
binar = True binar = True
except ValueError: except:
binar = False binar = False
r = '' r = ''
if binar: if binar:
r = requests.post(url, data=json.dumps(payload), headers=headers) r = requests.post(url, data=json.dumps(payload), headers=headers)
return r return r
def maj_verif(NAME): def maj_verif(NAME):
import qgis import qgis
import urllib.request import urllib.request
iface = qgis.utils.iface iface = qgis.utils.iface
from qgis.core import Qgis from qgis.core import Qgis
# url = qgis.utils.pluginMetadata(NAME, 'repository') url = qgis.utils.pluginMetadata(NAME,'repository')
# URL = url+'/raw/branch/main/plugins.xml' #URL = url+'/raw/branch/main/plugins.xml'
URL = 'https://gitea.cenra-outils.org/CEN-RA/Plugin_QGIS/releases/download/latest/plugins.xml' URL = 'https://gitea.cenra-outils.org/CEN-RA/Plugin_QGIS/releases/download/latest/plugins.xml'
# print(URL) # print(URL)
version = qgis.utils.pluginMetadata(NAME, 'version') version = qgis.utils.pluginMetadata(NAME,'version')
len_version = len(version) len_version = len(version)
try: try:
urllib.request.urlopen('https://google.com') urllib.request.urlopen('https://google.com')
binar = True binar = True
except urllib.error.URLError: except:
binar = False binar = False
if binar: if binar:
try: try:
version_web = str(urllib.request.urlopen(URL).read()) version_web = str(urllib.request.urlopen(URL).read())
plugin_num = version_web.find(NAME) plugin_num = version_web.find(NAME)
valeur_version_web = version_web.find('<version>', plugin_num) + 9 valeur_version_web = version_web.find('<version>',plugin_num)+9
version_plugin = version_web[valeur_version_web:valeur_version_web + len_version] version_plugin = version_web[valeur_version_web:valeur_version_web+len_version]
if version_plugin != version: if version_plugin != version:
iface.messageBar().pushMessage("MAJ :", "Des mise à jour de plugin sont disponibles.", level=Qgis.Info, duration=30) iface.messageBar().pushMessage("MAJ :", "Des mise à jour de plugin sont disponibles.", level=Qgis.Info, duration=30)
except urllib.error.URLError: except:
print("error gitea version ssl") print("error gitea version ssl")
else: else:
iface.messageBar().pushMessage("WiFi :", "Pas de connection à internet.", level=Qgis.Warning, duration=30) iface.messageBar().pushMessage("WiFi :", "Pas de connection à internet.", level=Qgis.Warning, duration=30)
def tr(text, context="@default"):
return QApplication.translate(context, text)
def devlog(NAME): def devlog(NAME):
import qgis import qgis
devmaj = '<head><style>* {margin:0; padding:0; }</style></head>' devmaj = '<head><style>* {margin:0; padding:0; }</style></head>'
devmaj = devmaj + qgis.utils.pluginMetadata(NAME, 'changelog') devmaj = devmaj+qgis.utils.pluginMetadata(NAME,'changelog')
return devmaj return devmaj

View File

@ -4,14 +4,14 @@ __email__ = "info@3liz.org"
from qgis.core import QgsApplication from qgis.core import QgsApplication
from qgis.PyQt.QtCore import QUrl, QSettings from qgis.PyQt.QtCore import QCoreApplication, Qt, QTranslator, QUrl
from qgis.PyQt.QtGui import QDesktopServices, QIcon from qgis.PyQt.QtGui import QDesktopServices, QIcon
from qgis.PyQt.QtWidgets import QAction from qgis.PyQt.QtWidgets import QAction, QMessageBox
from qgis.utils import iface from qgis.utils import iface
import qgis import qgis
# include <QSettings> #include <QSettings>
''' '''
from pg_metadata.connection_manager import ( from pg_metadata.connection_manager import (
store_connections, store_connections,
@ -25,13 +25,15 @@ from pg_metadata.qgis_plugin_tools.tools.custom_logging import setup_logger
''' '''
import os import os
from .tools.resources import ( from .tools.resources import (
# plugin_path, plugin_path,
resources_path, resources_path,
maj_verif, maj_verif,
) )
from .canvas_editor import PageRender_Editor from .canvas_editor import PageRender_Editor
from .about_form import AboutDialog from .about_form import AboutDialog
from qgis.PyQt.QtCore import *
class PgPageRender: class PgPageRender:
def __init__(self): def __init__(self):
@ -43,18 +45,18 @@ class PgPageRender:
self.dock_action = None self.dock_action = None
self.help_action = None self.help_action = None
plugin_dir = os.path.dirname(__file__) plugin_dir = os.path.dirname(__file__)
end_find = plugin_dir.rfind('\\') + 1 end_find = plugin_dir.rfind('\\')+1
global NAME global NAME
NAME = plugin_dir[end_find:] NAME = plugin_dir[end_find:]
maj_verif(NAME) maj_verif(NAME)
# Display About window on first use # Display About window on first use
version = qgis.utils.pluginMetadata('CenRa_PAGERENDER', 'version') version = qgis.utils.pluginMetadata('CenRa_PAGERENDER','version')
s = QSettings() s = QSettings()
versionUse = s.value("pagerender/version", 1, type=str) versionUse = s.value("pagerender/version", 1, type=str)
if str(versionUse) != str(version): if str(versionUse) != str(version) :
s.setValue("pagerender/version", str(version)) s.setValue("pagerender/version", str(version))
print(versionUse, version) print(versionUse,version)
self.open_about_dialog() self.open_about_dialog()
def initGui(self): def initGui(self):
@ -72,7 +74,8 @@ class PgPageRender:
if not self.canvas_editor: if not self.canvas_editor:
self.canvas_editor = PageRender_Editor() self.canvas_editor = PageRender_Editor()
self.pagerender_action = QAction(icon, 'CenRa_PAGERENDER', None)
self.pagerender_action = QAction(icon, 'CenRa_PAGERENDER',None)
self.toolBar.addAction(self.pagerender_action) self.toolBar.addAction(self.pagerender_action)
self.pagerender_action.triggered.connect(self.open_editor) self.pagerender_action.triggered.connect(self.open_editor)
''' '''
@ -114,7 +117,6 @@ class PgPageRender:
""" """
dialog = AboutDialog(iface) dialog = AboutDialog(iface)
dialog.exec() dialog.exec()
def open_help(): def open_help():
""" Open the online help. """ """ Open the online help. """
QDesktopServices.openUrl(QUrl('https://plateformesig.cenra-outils.org/')) QDesktopServices.openUrl(QUrl('https://plateformesig.cenra-outils.org/'))
@ -126,7 +128,7 @@ class PgPageRender:
def unload(self): def unload(self):
""" Unload the plugin. """ """ Unload the plugin. """
if self.canvas_editor: if self.canvas_editor:
iface.removePluginMenu('CenRa_PAGERENDER', self.pagerender_action) iface.removePluginMenu('CenRa_PAGERENDER',self.pagerender_action)
if self.provider: if self.provider:
QgsApplication.processingRegistry().removeProvider(self.provider) QgsApplication.processingRegistry().removeProvider(self.provider)

View File

@ -3,7 +3,7 @@ import os.path
from pathlib import Path from pathlib import Path
from qgis.PyQt import uic from qgis.PyQt import uic
# from qgis.PyQt.QtGui import QPixmap from qgis.PyQt.QtGui import QPixmap
from qgis.PyQt.QtWidgets import QDialog from qgis.PyQt.QtWidgets import QDialog
from .tools.resources import devlog from .tools.resources import devlog

View File

@ -1,84 +1,144 @@
import logging import logging
import os import os
# from collections import namedtuple from collections import namedtuple
# from enum import Enum from enum import Enum
# from functools import partial from functools import partial
# from pathlib import Path from pathlib import Path
# from xml.dom.minidom import parseString from xml.dom.minidom import parseString
# from qgis.gui import * from qgis.gui import *
# import qgis import qgis
from qgis.core import QgsSettings from qgis.core import (
from qgis.PyQt.QtCore import Qt NULL,
# from qgis.PyQt.QtPrintSupport import QPrinter QgsApplication,
# from qgis.PyQt.QtWebKitWidgets import QWebPage QgsScaleBarSettings,
QgsDataSourceUri,
QgsProject,
QgsProviderConnectionException,
QgsProviderRegistry,
QgsRasterLayer,
QgsSettings,
QgsVectorLayer,
QgsGeometry,
QgsPrintLayout,
QgsReadWriteContext,
QgsLayoutItemMap,
QgsLayoutItemPage,
QgsLayoutSize,
QgsUnitTypes,
QgsLayoutPoint,
QgsLayoutItemLabel,
QgsLayoutItemPicture,
QgsLayoutItemLegend,
QgsLegendStyle,
QgsLayoutItemScaleBar,
QgsLayerTreeGroup,
QgsCoordinateReferenceSystem,
QgsCoordinateTransform,
QgsLayerTree,
QgsLayoutTableColumn,
QgsRectangle,
QgsLayoutItemMapOverviewStack,
QgsLayoutItemHtml,
)
from qgis.PyQt.QtCore import QLocale, QUrl, QDateTime, Qt
from qgis.PyQt.QtGui import QDesktopServices, QIcon, QColor, QFont, QMovie
from qgis.PyQt.QtPrintSupport import QPrinter
#from qgis.PyQt.QtWebKitWidgets import QWebPage
from qgis.PyQt.QtWidgets import ( from qgis.PyQt.QtWidgets import (
QDialog, QDialog,
QAction,
QDockWidget,
QFileDialog, QFileDialog,
QInputDialog,
QMenu,
QToolButton,
QTableWidget,
QTableWidgetItem, QTableWidgetItem,
QVBoxLayout,
) )
from qgis.PyQt import QtGui from qgis.PyQt import QtGui
from qgis.PyQt.QtWidgets import QApplication from qgis.PyQt.QtWidgets import QApplication
from qgis.PyQt.QtCore import QSettings from qgis.PyQt.QtCore import QSettings,QPointF
# from qgis.PyQt.QtXml import QDomDocument from qgis.PyQt.QtXml import QDomDocument
# from qgis.utils import iface from qgis.utils import iface
# import glob import glob
from .tools.resources import ( from .tools.resources import (
load_ui, load_ui,
resources_path, resources_path,
# send_issues, send_issues,
) )
# from .issues import CenRa_Issues from .issues import CenRa_Issues
# from datetime import date from datetime import date
last_select = None last_select = None
maxV = 210 maxV=210
maxH = 296 maxH=296
EDITOR_CLASS = load_ui('CenRa_PageRender_base.ui') EDITOR_CLASS = load_ui('CenRa_PageRender_base.ui')
LOGGER = logging.getLogger('CenRa_PageRender') LOGGER = logging.getLogger('CenRa_PageRender')
url_osm = 'https://osm.datagrandest.fr/mapcache/?crs=EPSG:2154&featureCount=10&format=image/png&layers=pure&maxHeight=256&maxWidth=256&styles=&url=https://osm.datagrandest.fr/mapcache' url_osm = 'https://osm.datagrandest.fr/mapcache/?crs=EPSG:2154&featureCount=10&format=image/png&layers=pure&maxHeight=256&maxWidth=256&styles=&url=https://osm.datagrandest.fr/mapcache'
url_ortho = 'http://tiles.craig.fr/ortho/service/?crs=EPSG:2154&featureCount=10&format=image/jpeg&layers=ortho&maxHeight=256&maxWidth=256&styles=&url=http://tiles.craig.fr/ortho/service' url_ortho = 'http://tiles.craig.fr/ortho/service/?crs=EPSG:2154&featureCount=10&format=image/jpeg&layers=ortho&maxHeight=256&maxWidth=256&styles=&url=http://tiles.craig.fr/ortho/service'
url_mnt = 'http://tiles.craig.fr/mnt/crs=EPSG:2154&featureCount=10&format=image/png&layers=relief&maxHeight=256&maxWidth=256&styles=&url=http://tiles.craig.fr/mnt' url_mnt = 'http://tiles.craig.fr/mnt/crs=EPSG:2154&featureCount=10&format=image/png&layers=relief&maxHeight=256&maxWidth=256&styles=&url=http://tiles.craig.fr/mnt'
url_pente = 'http://tiles.craig.fr/mnt/crs=EPSG:2154&featureCount=10&format=image/png&layers=pente&maxHeight=256&maxWidth=256&styles=&url=http://tiles.craig.fr/mnt' url_pente = 'http://tiles.craig.fr/mnt/crs=EPSG:2154&featureCount=10&format=image/png&layers=pente&maxHeight=256&maxWidth=256&styles=&url=http://tiles.craig.fr/mnt'
data_source = ['CENRA', 'IGN', 'CRAIG', 'OpenStreetMap', 'Sandre', 'BRGM', 'MUSÉUM NATIONAL DHISTOIRE NATURELLE', "Muséum national d'Histoire naturelle", 'ONF', '20xx LPO', 'ofb.gouv.fr', 'Stamen Design', 'MTES', 'MTES', 'FEDER', 'DREAL Auvergne-Rhône-Alpes', 'INSEE', 'DGFiP', 'Fédération des Conservatoires despaces naturels', 'Plan cadastral informatisé - Etalab - juillet 202X', 'Parcellaire Express - IGN - 202X'] data_source = [
'CENRA',
'IGN',
'CRAIG',
'OpenStreetMap',
'Sandre',
'BRGM',
'MUSÉUM NATIONAL DHISTOIRE NATURELLE',
"Muséum national d'Histoire naturelle",
'ONF',
'20xx LPO',
'ofb.gouv.fr',
'Stamen Design',
'MTES',
'MTES',
'FEDER',
'DREAL Auvergne-Rhône-Alpes',
'INSEE',
'DGFiP',
'Fédération des Conservatoires despaces naturels',
'Plan cadastral informatisé - Etalab - juillet 202X',
'Parcellaire Express - IGN - 202X',
]
class PageRender_Editor(QDialog, EDITOR_CLASS): class PageRender_Editor(QDialog, EDITOR_CLASS):
def __init__(self, parent=None): def __init__(self, parent=None):
_ = parent _ = parent
super().__init__() super().__init__()
self.setupUi(self) self.setupUi(self)
self.settings = QgsSettings() self.settings = QgsSettings()
self.s = QSettings() self.s = QSettings()
self.setWindowIcon(QtGui.QIcon(resources_path('icons', 'icon.png'))) self.setWindowIcon(QtGui.QIcon(resources_path('icons','icon.png')))
self.varLandscape = {} self.varLandscape = {}
self.varPortrait = {} self.varPortrait = {}
self.rotate_object = { self.rotate_object = {
'Titre': 0, 'Titre':0,
'Sous_titre': 0, 'Sous_titre':0,
'Carte': 0, 'Carte':0,
'Carte_2': 0, 'Carte_2':0,
'Legande': 0, 'Legande':0,
'Arrow': 0, 'Arrow':0,
'Echelle': 0, 'Echelle':0,
'Logo': 0, 'Logo':0,
'Credit': 0, 'Credit':0,
'Source': 0, 'Source':0,
'Echelle_2': 0, 'Echelle_2':0,
'Logo_2': 0} 'Logo_2':0,}
path = '' path = ''
ix = 0 ix = 0
plugin_dir = str(os.path.dirname(os.path.abspath(__file__))).split(os.sep) plugin_dir = str(os.path.dirname(os.path.abspath(__file__))).split(os.sep)
for i in plugin_dir: for i in plugin_dir:
ix = ix + 1 ix = ix+1
path = path + '\\' + i path = path+'\\'+i
self.path = path[1:] + '\\demoV2.py' self.path = path[1:]+'\\demoV2.py'
# self.tabWidget.setStyleSheet('background-image: url('+path+'/tools/bg/Capture.png);') #self.tabWidget.setStyleSheet('background-image: url('+path+'/tools/bg/Capture.png);')
self.toolButton.setIcon(QtGui.QIcon(resources_path('ui', 'rotate.png'))) self.toolButton.setIcon(QtGui.QIcon(resources_path('ui','rotate.png')))
self.horizontalSlider.valueChanged.connect(self.horizontal) self.horizontalSlider.valueChanged.connect(self.horizontal)
self.verticalSlider.valueChanged.connect(self.vertical) self.verticalSlider.valueChanged.connect(self.vertical)
@ -91,44 +151,44 @@ class PageRender_Editor(QDialog, EDITOR_CLASS):
self.toolButton_2.clicked.connect(self.type_page) self.toolButton_2.clicked.connect(self.type_page)
self.pushButton_2.clicked.connect(self.load) self.pushButton_2.clicked.connect(self.load)
self.verticalScrollBar.valueChanged.connect(self.moveFrame) self.verticalScrollBar.valueChanged.connect(self.moveFrame)
# self.setAcceptHoverEvents(True) #self.setAcceptHoverEvents(True)
self.tableWidget.setTabKeyNavigation(False) self.tableWidget.setTabKeyNavigation(False)
def raise_(self): def raise_(self):
self.activateWindow() self.activateWindow()
self.setNavigator() self.setNavigator()
self.verticalScrollBar.setValue(self.frame.y()) self.verticalScrollBar.setValue(self.frame.y())
def mousePressEvent(self, event): def mousePressEvent(self, event):
if self.tableWidget.currentItem() is not None: if self.tableWidget.currentItem() != None:
QApplication.setOverrideCursor(Qt.CursorShape(18)) QApplication.setOverrideCursor(Qt.CursorShape(18))
global lastPos global lastPos
lastPos = {'x': event.pos().x(), 'y': event.pos().y()} lastPos = {'x':event.pos().x(),'y':event.pos().y()}
def moveFrame(self): def moveFrame(self):
self.frame.move(self.frame.x(), self.verticalScrollBar.value()) self.frame.move(self.frame.x(),self.verticalScrollBar.value())
def keyPressEvent(self, event): def keyPressEvent(self, event):
# if event.modifiers() & Qt.ControlModifier: #if event.modifiers() & Qt.ControlModifier:
if event.key() == Qt.Key(0x01000015): if event.key() == Qt.Key(0x01000015):
self.verticalSlider.setValue(self.spinBox_2.value() + 1) self.verticalSlider.setValue(self.spinBox_2.value()+1)
if event.key() == Qt.Key(0x01000013): if event.key() == Qt.Key(0x01000013):
self.verticalSlider.setValue(self.spinBox_2.value() - 1) self.verticalSlider.setValue(self.spinBox_2.value()-1)
if event.key() == Qt.Key(0x01000014): if event.key() == Qt.Key(0x01000014):
self.horizontalSlider.setValue(self.spinBox.value() + 1) self.horizontalSlider.setValue(self.spinBox.value()+1)
if event.key() == Qt.Key(0x01000012): if event.key() == Qt.Key(0x01000012):
self.horizontalSlider.setValue(self.spinBox.value() - 1) self.horizontalSlider.setValue(self.spinBox.value()-1)
def wheelEvent(self, event):
def wheelEvent(self,event):
if (event.angleDelta().y() >= 1): if (event.angleDelta().y() >= 1):
vsb = self.verticalScrollBar.value() + 50 vsb = self.verticalScrollBar.value()+50
else: else:
vsb = self.verticalScrollBar.value() - 50 vsb = self.verticalScrollBar.value()-50
self.verticalScrollBar.setValue(vsb) self.verticalScrollBar.setValue(vsb)
def mouseMoveEvent(self, event): def mouseMoveEvent(self, event):
updated_cursor_position = event.pos() updated_cursor_position = event.pos()
if self.tableWidget.currentItem() is not None: if self.tableWidget.currentItem() != None:
selection_name = (self.tableWidget.currentItem()).text() selection_name = (self.tableWidget.currentItem()).text()
all_children = self.frame.children() all_children = self.frame.children()
selection = 0 selection = 0
@ -138,97 +198,96 @@ class PageRender_Editor(QDialog, EDITOR_CLASS):
frame_x = self.frame.x() frame_x = self.frame.x()
frame_y = self.frame.y() frame_y = self.frame.y()
frame_w = self.frame.width() + frame_x frame_w = self.frame.width()+frame_x
frame_h = self.frame.height() + frame_y frame_h = self.frame.height()+frame_y
global lastPos global lastPos
orig_position_w = selection.width() orig_position_w = selection.width()
orig_position_h = selection.height() orig_position_h = selection.height()
if (frame_x <= round(updated_cursor_position.x()) <= frame_w and self.radioButton.isChecked() is True): if (frame_x <= round(updated_cursor_position.x()) <= frame_w and self.radioButton.isChecked() == True):
updated_cursor_position_x = orig_position_w + (round(updated_cursor_position.x() - lastPos['x'])) updated_cursor_position_x = orig_position_w+(round(updated_cursor_position.x()-lastPos['x']))
lastPos['x'] = event.pos().x() lastPos['x'] = event.pos().x()
selection.resize(updated_cursor_position_x, orig_position_h) selection.resize(updated_cursor_position_x,orig_position_h)
self.horizontalSlider.setValue(round(updated_cursor_position_x / 3.5)) self.horizontalSlider.setValue(round(updated_cursor_position_x/3.5))
orig_position_w = selection.width() orig_position_w = selection.width()
orig_position_h = selection.height() orig_position_h = selection.height()
if (frame_y <= round(updated_cursor_position.y()) <= frame_h and self.radioButton.isChecked() is True): if (frame_y <= round(updated_cursor_position.y()) <= frame_h and self.radioButton.isChecked() == True):
updated_cursor_position_y = orig_position_h + (round(updated_cursor_position.y() - lastPos['y'])) updated_cursor_position_y = orig_position_h+(round(updated_cursor_position.y()-lastPos['y']))
lastPos['y'] = event.pos().y() lastPos['y'] = event.pos().y()
selection.resize(orig_position_w, updated_cursor_position_y) selection.resize(orig_position_w,updated_cursor_position_y)
self.verticalSlider.setValue(round(updated_cursor_position_y / 3.5)) self.verticalSlider.setValue(round(updated_cursor_position_y/3.5))
orig_position_x = selection.pos().x() orig_position_x = selection.pos().x()
orig_position_y = selection.pos().y() orig_position_y = selection.pos().y()
if (frame_x <= round(updated_cursor_position.x()) <= frame_w and self.radioButton.isChecked() is False): if (frame_x <= round(updated_cursor_position.x()) <= frame_w and self.radioButton.isChecked() == False):
updated_cursor_position_x = orig_position_x + (round(updated_cursor_position.x() - lastPos['x'])) updated_cursor_position_x = orig_position_x+(round(updated_cursor_position.x()-lastPos['x']))
lastPos['x'] = event.pos().x() lastPos['x'] = event.pos().x()
# print(updated_cursor_position_x) #print(updated_cursor_position_x)
selection.move(updated_cursor_position_x, orig_position_y) selection.move(updated_cursor_position_x,orig_position_y)
self.horizontalSlider.setValue(round(updated_cursor_position_x / 3.5)) self.horizontalSlider.setValue(round(updated_cursor_position_x/3.5))
orig_position_x = selection.pos().x() orig_position_x = selection.pos().x()
orig_position_y = selection.pos().y() orig_position_y = selection.pos().y()
if (frame_y <= round(updated_cursor_position.y()) <= frame_h and self.radioButton.isChecked() is False): if (frame_y <= round(updated_cursor_position.y()) <= frame_h and self.radioButton.isChecked() == False):
updated_cursor_position_y = orig_position_y + (round(updated_cursor_position.y() - lastPos['y'])) updated_cursor_position_y = orig_position_y+(round(updated_cursor_position.y()-lastPos['y']))
lastPos['y'] = event.pos().y() lastPos['y'] = event.pos().y()
# print(updated_cursor_position_y) #print(updated_cursor_position_y)
selection.move(orig_position_x, updated_cursor_position_y) selection.move(orig_position_x,updated_cursor_position_y)
self.verticalSlider.setValue(round(updated_cursor_position_y / 3.5)) self.verticalSlider.setValue(round(updated_cursor_position_y/3.5))
def mouseReleaseEvent(self, event): def mouseReleaseEvent(self, event):
# print('x: {0}, y: {1}'.format(event.pos().x(), event.pos().y())) #print('x: {0}, y: {1}'.format(event.pos().x(), event.pos().y()))
if self.tableWidget.currentItem() is not None: if self.tableWidget.currentItem() != None:
QApplication.restoreOverrideCursor() QApplication.restoreOverrideCursor()
def select_file(self): def select_file(self):
options = QFileDialog.Options() options = QFileDialog.Options()
options |= QFileDialog.ShowDirsOnly options |= QFileDialog.ShowDirsOnly
folder = QFileDialog.getOpenFileName(self, "Sélection du fichier ", '', 'Python(*.py)') folder = QFileDialog.getOpenFileName(self, "Sélection du fichier ",'','Python(*.py)')
if folder[0] != '': if folder[0] != '':
return folder[0] return folder[0]
else: else:
return '' return ''
def load(self): def load(self):
folder = self.select_file() folder = self.select_file()
logopath = folder logopath = folder
if logopath != '': if logopath != '':
# logopath = (os.path.dirname(logopath).split('/')) #logopath = (os.path.dirname(logopath).split('/'))
sourcefile = open(logopath, 'r') sourcefile = open(logopath, 'r')
splitsource = sourcefile.read().splitlines() splitsource = sourcefile.read().splitlines()
all_children = self.frame.children() all_children = self.frame.children()
all_element = ['_locals', '_size', '_rotate'] all_element = ['_locals','_size','_rotate']
for children in all_children: for children in all_children:
flen = 0 flen = 0
for element in all_element: for element in all_element:
flen = 0 flen = 0
recherche_element = children.objectName() + element recherche_element = children.objectName()+element
for find_it in splitsource: for find_it in splitsource:
if find_it.find(recherche_element) != -1: if find_it.find(recherche_element) != -1:
flen = flen + 1 flen = flen+1
if flen == 1: if flen == 1:
if element != '_rotate': if element != '_rotate':
value_find = (find_it[find_it[:].find('(') + 1:-33]).split(',') value_find = (find_it[find_it[:].find('(')+1:-33]).split(',')
if element == '_size': if element == '_size':
Psize_h = float(value_find[0]) * 3.5 Psize_h = float(value_find[0])*3.5
Psize_w = float(value_find[1]) * 3.5 Psize_w = float(value_find[1])*3.5
if element == '_locals': if element == '_locals':
Plocals_h = float(value_find[0]) * 3.5 Plocals_h = float(value_find[0])*3.5
Plocals_w = float(value_find[1]) * 3.5 Plocals_w = float(value_find[1])*3.5
else: else:
Protate = float((find_it[find_it[:].find('=') + 2:]).split(',')[0]) Protate = float((find_it[find_it[:].find('=')+2:]).split(',')[0])
if flen == 3: if flen == 3:
if element != '_rotate': if element != '_rotate':
value_find = (find_it[find_it[:].find('(') + 1:-33]).split(',') value_find = (find_it[find_it[:].find('(')+1:-33]).split(',')
if element == '_size': if element == '_size':
Lsize_h = float(value_find[0]) * 3.5 Lsize_h = float(value_find[0])*3.5
Lsize_w = float(value_find[1]) * 3.5 Lsize_w = float(value_find[1])*3.5
if element == '_locals': if element == '_locals':
Llocals_h = float(value_find[0]) * 3.5 Llocals_h = float(value_find[0])*3.5
Llocals_w = float(value_find[1]) * 3.5 Llocals_w = float(value_find[1])*3.5
else: else:
Lrotate = float((find_it[find_it[:].find('=') + 2:]).split(',')[0]) Lrotate = float((find_it[find_it[:].find('=')+2:]).split(',')[0])
# print('sh',Psize_h,',sw',Psize_w,',lh',Plocals_h,',lw',Plocals_w,',r',Protate) #print('sh',Psize_h,',sw',Psize_w,',lh',Plocals_h,',lw',Plocals_w,',r',Protate)
if Lrotate == 90 or Lrotate == 270: if Lrotate == 90 or Lrotate == 270:
old = Lsize_w old = Lsize_w
Lsize_w = Lsize_h Lsize_w = Lsize_h
@ -238,12 +297,12 @@ class PageRender_Editor(QDialog, EDITOR_CLASS):
Psize_w = Psize_h Psize_w = Psize_h
Psize_h = old Psize_h = old
if self.toolButton_2.text() == 'Landscape': if self.toolButton_2.text() == 'Landscape':
children.resize(round(Lsize_h), round(Lsize_w)) children.resize(round(Lsize_h),round(Lsize_w))
children.move(round(Llocals_h), round(Llocals_w)) children.move(round(Llocals_h),round(Llocals_w))
self.rotate_object[children.objectName()] = Lrotate self.rotate_object[children.objectName()] = Lrotate
if self.toolButton_2.text() == 'Portrait': if self.toolButton_2.text() == 'Portrait':
children.resize(round(Psize_h), round(Psize_w)) children.resize(round(Psize_h),round(Psize_w))
children.move(round(Plocals_h), round(Plocals_w)) children.move(round(Plocals_h),round(Plocals_w))
self.rotate_object[children.objectName()] = Protate self.rotate_object[children.objectName()] = Protate
def valueSlider(self): def valueSlider(self):
@ -252,53 +311,52 @@ class PageRender_Editor(QDialog, EDITOR_CLASS):
def setNavigator(self): def setNavigator(self):
all_children = self.frame.children() all_children = self.frame.children()
xR = 0 xR=0
baseRow = self.tableWidget.rowCount() baseRow = self.tableWidget.rowCount()
while baseRow >= xR: while baseRow >= xR:
self.tableWidget.removeRow(0) self.tableWidget.removeRow(0)
xR = xR + 1 xR = xR+1
self.tableWidget.clear() self.tableWidget.clear()
# id = 0 id=0
for children in all_children: for children in all_children:
position = self.tableWidget.rowCount() position = self.tableWidget.rowCount()
self.tableWidget.insertRow(position) self.tableWidget.insertRow(position)
self.tableWidget.setItem(position, 0, QTableWidgetItem(children.objectName())) self.tableWidget.setItem(position,0,QTableWidgetItem(children.objectName()))
# print(children.objectName()) #print(children.objectName())
def export(self): def export(self):
self.type_page() self.type_page()
self.type_page() self.type_page()
all_children = self.frame.children() all_children = self.frame.children()
# selection_name = (self.tableWidget.currentItem()).text() #selection_name = (self.tableWidget.currentItem()).text()
export_str = """ export_str = """
from qgis.core import ( from qgis.core import (
QgsLayoutSize, QgsLayoutSize,
QgsUnitTypes, QgsUnitTypes,
QgsLayoutPoint, QgsLayoutPoint,
) )
def fletch_canvas(self): def fletch_canvas(self):
if self.radioButton_6.isChecked(): if self.radioButton_6.isChecked():
values_page = 'A4' values_page = 'A4'
else: else:
values_page = 'A3' values_page = 'A3'
if self.radioButton_7.isChecked(): if self.radioButton_7.isChecked():
page_rotate = 'Portrait' page_rotate = 'Portrait'
else: else:
page_rotate = 'Landscape' page_rotate = 'Landscape'
""" """
type = ["Portrait", "Landscape"] type = ["Portrait","Landscape"]
page = ["A4", "A3"] page = ["A4","A3"]
for page_type in type: for page_type in type:
export_str = export_str + """ export_str = export_str+"""
if page_rotate == '""" + page_type + """':""" if page_rotate == '"""+page_type+"""':"""
for page_size in page: for page_size in page:
export_str = export_str + """ export_str = export_str+"""
if values_page == '""" + page_size + """':""" if values_page == '"""+page_size+"""':"""
for children in all_children: for children in all_children:
selection = children selection = children
if page_type == 'Portrait': if page_type == 'Portrait':
item_rotate_object = self.varPortrait[selection.objectName() + '_rotate'][0] item_rotate_object=self.varPortrait[selection.objectName()+'_rotate'][0]
if item_rotate_object == 0 or item_rotate_object == 180: if item_rotate_object == 0 or item_rotate_object == 180:
sw = 0 sw = 0
sh = 1 sh = 1
@ -306,17 +364,17 @@ def fletch_canvas(self):
sw = 1 sw = 1
sh = 0 sh = 0
if page_size == 'A3': if page_size == 'A3':
size_w = (round((self.varPortrait[selection.objectName() + '_size'][sw] / 3.5) * 1.41)) size_w = (round((self.varPortrait[selection.objectName()+'_size'][sw]/3.5)*1.41))
size_h = (round((self.varPortrait[selection.objectName() + '_size'][sh] / 3.5) * 1.41)) size_h = (round((self.varPortrait[selection.objectName()+'_size'][sh]/3.5)*1.41))
locals_w = (round((self.varPortrait[selection.objectName() + '_locals'][1] / 3.5) * 1.41)) locals_w = (round((self.varPortrait[selection.objectName()+'_locals'][1]/3.5)*1.41))
locals_h = (round((self.varPortrait[selection.objectName() + '_locals'][0] / 3.5) * 1.41)) locals_h = (round((self.varPortrait[selection.objectName()+'_locals'][0]/3.5)*1.41))
else: else:
size_w = (round(self.varPortrait[selection.objectName() + '_size'][sw]) / 3.5) size_w = (round(self.varPortrait[selection.objectName()+'_size'][sw])/3.5)
size_h = (round(self.varPortrait[selection.objectName() + '_size'][sh] / 3.5)) size_h = (round(self.varPortrait[selection.objectName()+'_size'][sh]/3.5))
locals_w = (round(self.varPortrait[selection.objectName() + '_locals'][1] / 3.5)) locals_w = (round(self.varPortrait[selection.objectName()+'_locals'][1]/3.5))
locals_h = (round(self.varPortrait[selection.objectName() + '_locals'][0] / 3.5)) locals_h = (round(self.varPortrait[selection.objectName()+'_locals'][0]/3.5))
if page_type == 'Landscape': if page_type == 'Landscape':
item_rotate_object = self.varLandscape[selection.objectName() + '_rotate'][0] item_rotate_object=self.varLandscape[selection.objectName()+'_rotate'][0]
if item_rotate_object == 0 or item_rotate_object == 180: if item_rotate_object == 0 or item_rotate_object == 180:
sw = 0 sw = 0
sh = 1 sh = 1
@ -324,43 +382,42 @@ def fletch_canvas(self):
sw = 1 sw = 1
sh = 0 sh = 0
if page_size == 'A3': if page_size == 'A3':
size_w = (round((self.varLandscape[selection.objectName() + '_size'][sw] / 3.5) * 1.41)) size_w = (round((self.varLandscape[selection.objectName()+'_size'][sw]/3.5)*1.41))
size_h = (round((self.varLandscape[selection.objectName() + '_size'][sh] / 3.5) * 1.41)) size_h = (round((self.varLandscape[selection.objectName()+'_size'][sh]/3.5)*1.41))
locals_w = (round((self.varLandscape[selection.objectName() + '_locals'][1] / 3.5) * 1.41)) locals_w = (round((self.varLandscape[selection.objectName()+'_locals'][1]/3.5)*1.41))
locals_h = (round((self.varLandscape[selection.objectName() + '_locals'][0] / 3.5) * 1.41)) locals_h = (round((self.varLandscape[selection.objectName()+'_locals'][0]/3.5)*1.41))
else: else:
size_w = (round(self.varLandscape[selection.objectName() + '_size'][sw]) / 3.5) size_w = (round(self.varLandscape[selection.objectName()+'_size'][sw])/3.5)
size_h = (round(self.varLandscape[selection.objectName() + '_size'][sh] / 3.5)) size_h = (round(self.varLandscape[selection.objectName()+'_size'][sh]/3.5))
locals_w = (round(self.varLandscape[selection.objectName() + '_locals'][1] / 3.5)) locals_w = (round(self.varLandscape[selection.objectName()+'_locals'][1]/3.5))
locals_h = (round(self.varLandscape[selection.objectName() + '_locals'][0] / 3.5)) locals_h = (round(self.varLandscape[selection.objectName()+'_locals'][0]/3.5))
if item_rotate_object == 270: if item_rotate_object == 270:
locals_h = locals_h + size_w locals_h= locals_h + size_w
if item_rotate_object == 180: if item_rotate_object == 180:
locals_h = locals_h + size_h locals_h= locals_h + size_h
locals_w = locals_w + size_w locals_w= locals_w + size_w
size_w = str(size_w) size_w = str(size_w)
size_h = str(size_h) size_h = str(size_h)
locals_w = str(locals_w) locals_w = str(locals_w)
locals_h = str(locals_h) locals_h = str(locals_h)
export_str = export_str + """ export_str = export_str+"""
self.template_parameters['""" + selection.objectName() + """_size'] = QgsLayoutSize(""" + size_w + """,""" + size_h + """, QgsUnitTypes.LayoutMillimeters) self.template_parameters['"""+selection.objectName()+"""_size'] = QgsLayoutSize("""+size_w+""","""+ size_h+""", QgsUnitTypes.LayoutMillimeters)
self.template_parameters['""" + selection.objectName() + """_locals'] = QgsLayoutPoint(""" + locals_w + """, """ + locals_h + """, QgsUnitTypes.LayoutMillimeters) self.template_parameters['"""+selection.objectName()+"""_locals'] = QgsLayoutPoint("""+locals_w+""", """+locals_h+""", QgsUnitTypes.LayoutMillimeters)
self.template_parameters['""" + selection.objectName() + """_rotate'] = """ + str(item_rotate_object) self.template_parameters['"""+selection.objectName()+"""_rotate'] = """+str(item_rotate_object)
export_str = export_str + """ export_str= export_str+"""
return self.template_parameters""" return self.template_parameters"""
sourceFile = open(self.path, 'w') sourceFile = open(self.path,'w')
print(export_str, file=sourceFile) print(export_str, file = sourceFile)
sourceFile.close() sourceFile.close()
def type_page(self): def type_page(self):
all_children = self.frame.children() all_children = self.frame.children()
if self.toolButton_2.text() == 'Landscape': if self.toolButton_2.text() == 'Landscape':
self.horizontalSlider.setMaximum(maxV) self.horizontalSlider.setMaximum(maxV)
self.verticalSlider.setMaximum(maxH) self.verticalSlider.setMaximum(maxH)
last_children = 0 last_children=0
for children in all_children: for children in all_children:
selection = children selection = children
size_w = selection.size().width() size_w = selection.size().width()
@ -368,20 +425,20 @@ def fletch_canvas(self):
locals_h = selection.x() locals_h = selection.x()
locals_w = selection.y() locals_w = selection.y()
item_rotate_object = self.rotate_object[selection.objectName()] item_rotate_object = self.rotate_object[selection.objectName()]
self.varLandscape[selection.objectName() + '_size'] = [size_w, size_h] self.varLandscape[selection.objectName()+'_size'] = [size_w,size_h]
self.varLandscape[selection.objectName() + '_locals'] = [locals_w, locals_h] self.varLandscape[selection.objectName()+'_locals'] = [locals_w,locals_h]
self.varLandscape[selection.objectName() + '_rotate'] = [item_rotate_object] self.varLandscape[selection.objectName()+'_rotate'] = [item_rotate_object]
if self.varPortrait != {}: if self.varPortrait != {}:
selection.move(self.varPortrait[selection.objectName() + '_locals'][1], self.varPortrait[selection.objectName() + '_locals'][0]) selection.move(self.varPortrait[selection.objectName()+'_locals'][1],self.varPortrait[selection.objectName()+'_locals'][0])
selection.resize(self.varPortrait[selection.objectName() + '_size'][0], self.varPortrait[selection.objectName() + '_size'][1]) selection.resize(self.varPortrait[selection.objectName()+'_size'][0],self.varPortrait[selection.objectName()+'_size'][1])
self.rotate_object[selection.objectName()] = self.varPortrait[selection.objectName() + '_rotate'][0] self.rotate_object[selection.objectName()] = self.varPortrait[selection.objectName()+'_rotate'][0]
self.rotate_color(selection, last_children) self.rotate_color(selection,last_children)
last_children = selection last_children = selection
self.toolButton_2.setText('Portrait') self.toolButton_2.setText('Portrait')
elif self.toolButton_2.text() == 'Portrait': elif self.toolButton_2.text() == 'Portrait':
self.horizontalSlider.setMaximum(maxH) self.horizontalSlider.setMaximum(maxH)
self.verticalSlider.setMaximum(maxV) self.verticalSlider.setMaximum(maxV)
last_children = 0 last_children=0
for children in all_children: for children in all_children:
selection = children selection = children
size_w = selection.size().width() size_w = selection.size().width()
@ -389,25 +446,24 @@ def fletch_canvas(self):
locals_h = selection.x() locals_h = selection.x()
locals_w = selection.y() locals_w = selection.y()
item_rotate_object = self.rotate_object[selection.objectName()] item_rotate_object = self.rotate_object[selection.objectName()]
self.varPortrait[selection.objectName() + '_size'] = [size_w, size_h] self.varPortrait[selection.objectName()+'_size'] = [size_w,size_h]
self.varPortrait[selection.objectName() + '_locals'] = [locals_w, locals_h] self.varPortrait[selection.objectName()+'_locals'] = [locals_w,locals_h]
self.varPortrait[selection.objectName() + '_rotate'] = [item_rotate_object] self.varPortrait[selection.objectName()+'_rotate'] = [item_rotate_object]
if self.varLandscape != {}: if self.varLandscape != {}:
selection.move(self.varLandscape[selection.objectName() + '_locals'][1], self.varLandscape[selection.objectName() + '_locals'][0]) selection.move(self.varLandscape[selection.objectName()+'_locals'][1],self.varLandscape[selection.objectName()+'_locals'][0])
selection.resize(self.varLandscape[selection.objectName() + '_size'][0], self.varLandscape[selection.objectName() + '_size'][1]) selection.resize(self.varLandscape[selection.objectName()+'_size'][0],self.varLandscape[selection.objectName()+'_size'][1])
self.rotate_object[selection.objectName()] = self.varLandscape[selection.objectName() + '_rotate'][0] self.rotate_object[selection.objectName()] = self.varLandscape[selection.objectName()+'_rotate'][0]
self.rotate_color(selection, last_children) self.rotate_color(selection,last_children)
last_children = selection last_children = selection
self.toolButton_2.setText('Landscape') self.toolButton_2.setText('Landscape')
frame_w = self.frame.width() frame_w = self.frame.width()
frame_h = self.frame.height() frame_h = self.frame.height()
self.frame.resize(frame_h, frame_w) self.frame.resize(frame_h,frame_w)
frame_x = round(frame_w / 3) frame_x = round(frame_w / 3)
frame_y = self.frame.y() frame_y = self.frame.y()
self.frame.move(frame_x, frame_y) self.frame.move(frame_x,frame_y)
def setSlider(self): def setSlider(self):
if self.tableWidget.currentItem() is not None: if self.tableWidget.currentItem() != None:
print(self.tableWidget.tabKeyNavigation()) print(self.tableWidget.tabKeyNavigation())
selection_name = (self.tableWidget.currentItem()).text() selection_name = (self.tableWidget.currentItem()).text()
all_children = self.frame.children() all_children = self.frame.children()
@ -419,33 +475,33 @@ def fletch_canvas(self):
if selection_name == children.objectName(): if selection_name == children.objectName():
selection = children selection = children
if selection != 0: if selection != 0:
self.rotate_color(selection, last_children) self.rotate_color(selection,last_children)
if self.radioButton.isChecked() is False: if self.radioButton.isChecked() == False:
xx = round(selection.x() / 3.5) xx = round(selection.x()/3.5)
yy = round(selection.y() / 3.5) yy = round(selection.y()/3.5)
else: else:
xx = round(selection.size().width() / 3.5) xx = round(selection.size().width()/3.5)
yy = round(selection.size().height() / 3.5) yy = round(selection.size().height()/3.5)
# print(xx,yy) #print(xx,yy)
self.horizontalSlider.setValue(xx) self.horizontalSlider.setValue(xx)
self.verticalSlider.setValue(yy) self.verticalSlider.setValue(yy)
self.spinBox.setValue(xx) self.spinBox.setValue(xx)
self.spinBox_2.setValue(yy) self.spinBox_2.setValue(yy)
def rotate_color(self, selection, last_children): def rotate_color(self,selection,last_children):
global last_select global last_select
if self.radioButton.isChecked() is False: if self.radioButton.isChecked() == False:
ColorCode = "10, 10, 80, 50" ColorCode = "10, 10, 80, 50"
else: else:
ColorCode = "249, 238, 148, 50" ColorCode = "249, 238, 148, 50"
if self.rotate_object[selection.objectName()] == 0: if self.rotate_object[selection.objectName()] == 0:
selection.setStyleSheet("border: 2px solid;border-color:red;border-bottom-color: blue;background-color: rgb(" + ColorCode + ")") selection.setStyleSheet("border: 2px solid;border-color:red;border-bottom-color: blue;background-color: rgb("+ColorCode+")")
elif self.rotate_object[selection.objectName()] == 90: elif self.rotate_object[selection.objectName()] == 90:
selection.setStyleSheet("border: 2px solid;border-color:red;border-left-color: blue;background-color: rgb(" + ColorCode + ")") selection.setStyleSheet("border: 2px solid;border-color:red;border-left-color: blue;background-color: rgb("+ColorCode+")")
elif self.rotate_object[selection.objectName()] == 180: elif self.rotate_object[selection.objectName()] == 180:
selection.setStyleSheet("border: 2px solid;border-color:red;border-top-color: blue;background-color: rgb(" + ColorCode + ")") selection.setStyleSheet("border: 2px solid;border-color:red;border-top-color: blue;background-color: rgb("+ColorCode+")")
elif self.rotate_object[selection.objectName()] == 270: elif self.rotate_object[selection.objectName()] == 270:
selection.setStyleSheet("border: 2px solid;border-color:red;border-right-color: blue;background-color: rgb(" + ColorCode + ")") selection.setStyleSheet("border: 2px solid;border-color:red;border-right-color: blue;background-color: rgb("+ColorCode+")")
if last_children != 0: if last_children != 0:
if last_select != selection.objectName(): if last_select != selection.objectName():
last_children.setStyleSheet("background-color: rgb(10, 10, 10, 50)") last_children.setStyleSheet("background-color: rgb(10, 10, 10, 50)")
@ -453,7 +509,7 @@ def fletch_canvas(self):
last_select = selection.objectName() last_select = selection.objectName()
def rotate(self): def rotate(self):
if self.tableWidget.currentItem() is not None: if self.tableWidget.currentItem() != None:
selection_name = (self.tableWidget.currentItem()).text() selection_name = (self.tableWidget.currentItem()).text()
all_children = self.frame.children() all_children = self.frame.children()
selection = 0 selection = 0
@ -466,21 +522,21 @@ def fletch_canvas(self):
if selection != 0: if selection != 0:
xx = round(selection.size().width()) xx = round(selection.size().width())
yy = round(selection.size().height()) yy = round(selection.size().height())
selection.resize(round(yy), round(xx)) selection.resize(round(yy),round(xx))
if self.radioButton.isChecked() is True: if self.radioButton.isChecked() == True:
self.spinBox.setValue(yy) self.spinBox.setValue(yy)
self.spinBox_2.setValue(xx) self.spinBox_2.setValue(xx)
self.horizontalSlider.setValue(round(yy / 3.5)) self.horizontalSlider.setValue(round(yy/3.5))
self.verticalSlider.setValue(round(xx / 3.5)) self.verticalSlider.setValue(round(xx/3.5))
if self.rotate_object[selection.objectName()] == 270: if self.rotate_object[selection.objectName()] == 270:
self.rotate_object[selection.objectName()] = 0 self.rotate_object[selection.objectName()] = 0
else: else:
self.rotate_object[selection.objectName()] = self.rotate_object[selection.objectName()] + 90 self.rotate_object[selection.objectName()] = self.rotate_object[selection.objectName()] + 90
self.rotate_color(selection, last_children) self.rotate_color(selection,last_children)
def vertical(self): def vertical(self):
if self.tableWidget.currentItem() is not None: if self.tableWidget.currentItem() != None:
selection_name = (self.tableWidget.currentItem()).text() selection_name = (self.tableWidget.currentItem()).text()
all_children = self.frame.children() all_children = self.frame.children()
selection = 0 selection = 0
@ -488,15 +544,15 @@ def fletch_canvas(self):
if selection_name == children.objectName(): if selection_name == children.objectName():
selection = children selection = children
if selection != 0: if selection != 0:
if self.radioButton.isChecked() is False: if self.radioButton.isChecked() == False:
selection.move(round(self.horizontalSlider.value() * 3.5), round(self.verticalSlider.value() * 3.5)) selection.move(round(self.horizontalSlider.value()*3.5),round(self.verticalSlider.value()*3.5))
else: else:
selection.resize(round(self.horizontalSlider.value() * 3.5), round(self.verticalSlider.value() * 3.5)) selection.resize(round(self.horizontalSlider.value()*3.5),round(self.verticalSlider.value()*3.5))
self.spinBox.setValue(round(self.horizontalSlider.value())) self.spinBox.setValue(round(self.horizontalSlider.value()))
self.spinBox_2.setValue(round(self.verticalSlider.value())) self.spinBox_2.setValue(round(self.verticalSlider.value()))
def horizontal(self): def horizontal(self):
if self.tableWidget.currentItem() is not None: if self.tableWidget.currentItem() != None:
selection_name = (self.tableWidget.currentItem()).text() selection_name = (self.tableWidget.currentItem()).text()
all_children = self.frame.children() all_children = self.frame.children()
selection = 0 selection = 0
@ -504,9 +560,10 @@ def fletch_canvas(self):
if selection_name == children.objectName(): if selection_name == children.objectName():
selection = children selection = children
if selection != 0: if selection != 0:
if self.radioButton.isChecked() is False: if self.radioButton.isChecked() == False:
selection.move(round(self.horizontalSlider.value() * 3.5), round(self.verticalSlider.value() * 3.5)) selection.move(round(self.horizontalSlider.value()*3.5),round(self.verticalSlider.value()*3.5))
else: else:
selection.resize(round(self.horizontalSlider.value() * 3.5), round(self.verticalSlider.value() * 3.5)) selection.resize(round(self.horizontalSlider.value()*3.5),round(self.verticalSlider.value()*3.5))
self.spinBox.setValue(round(self.horizontalSlider.value())) self.spinBox.setValue(round(self.horizontalSlider.value()))
self.spinBox_2.setValue(round(self.verticalSlider.value())) self.spinBox_2.setValue(round(self.verticalSlider.value()))

View File

@ -1,167 +0,0 @@
from qgis.core import (
QgsLayoutSize,
QgsUnitTypes,
QgsLayoutPoint,
)
def fletch_canvas(self):
if self.radioButton_6.isChecked():
values_page = 'A4'
else:
values_page = 'A3'
if self.radioButton_7.isChecked():
page_rotate = 'Portrait'
else:
page_rotate = 'Landscape'
if page_rotate == 'Portrait':
if values_page == 'A4':
self.template_parameters['Carte_size'] = QgsLayoutSize(200.0,200, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Carte_locals'] = QgsLayoutPoint(6, 6, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Carte_rotate'] = 0
self.template_parameters['Carte_2_size'] = QgsLayoutSize(85.71428571428571,69, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Carte_2_locals'] = QgsLayoutPoint(209, 3, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Carte_2_rotate'] = 0
self.template_parameters['Legande_size'] = QgsLayoutSize(140.0,147, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Legande_locals'] = QgsLayoutPoint(41, 110, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Legande_rotate'] = 0
self.template_parameters['Arrow_size'] = QgsLayoutSize(14.285714285714286,14, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Arrow_locals'] = QgsLayoutPoint(189, 20, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Arrow_rotate'] = 0
self.template_parameters['Echelle_size'] = QgsLayoutSize(51.42857142857143,7, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Echelle_locals'] = QgsLayoutPoint(9, 197, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Echelle_rotate'] = 0
self.template_parameters['Logo_size'] = QgsLayoutSize(45.714285714285715,11, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Logo_locals'] = QgsLayoutPoint(3, 3, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Logo_rotate'] = 0
self.template_parameters['Titre_size'] = QgsLayoutSize(154.28571428571428,11, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Titre_locals'] = QgsLayoutPoint(51, 3, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Titre_rotate'] = 0
self.template_parameters['Credit_size'] = QgsLayoutSize(51.42857142857143,6, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Credit_locals'] = QgsLayoutPoint(151, 197, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Credit_rotate'] = 0
self.template_parameters['Source_size'] = QgsLayoutSize(51.42857142857143,6, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Source_locals'] = QgsLayoutPoint(229, 197, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Source_rotate'] = 0
self.template_parameters['Sous_titre_size'] = QgsLayoutSize(125.71428571428571,14, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Sous_titre_locals'] = QgsLayoutPoint(60, 20, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Sous_titre_rotate'] = 0
self.template_parameters['Echelle_2_size'] = QgsLayoutSize(51.42857142857143,13, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Echelle_2_locals'] = QgsLayoutPoint(9, 184, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Echelle_2_rotate'] = 0
self.template_parameters['Logo_2_size'] = QgsLayoutSize(28.571428571428573,29, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Logo_2_locals'] = QgsLayoutPoint(9, 151, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Logo_2_rotate'] = 0
if values_page == 'A3':
self.template_parameters['Carte_size'] = QgsLayoutSize(282,282, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Carte_locals'] = QgsLayoutPoint(8, 8, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Carte_rotate'] = 0
self.template_parameters['Carte_2_size'] = QgsLayoutSize(121,97, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Carte_2_locals'] = QgsLayoutPoint(294, 4, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Carte_2_rotate'] = 0
self.template_parameters['Legande_size'] = QgsLayoutSize(197,207, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Legande_locals'] = QgsLayoutPoint(58, 156, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Legande_rotate'] = 0
self.template_parameters['Arrow_size'] = QgsLayoutSize(20,20, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Arrow_locals'] = QgsLayoutPoint(266, 28, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Arrow_rotate'] = 0
self.template_parameters['Echelle_size'] = QgsLayoutSize(73,10, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Echelle_locals'] = QgsLayoutPoint(12, 278, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Echelle_rotate'] = 0
self.template_parameters['Logo_size'] = QgsLayoutSize(64,16, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Logo_locals'] = QgsLayoutPoint(4, 4, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Logo_rotate'] = 0
self.template_parameters['Titre_size'] = QgsLayoutSize(218,16, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Titre_locals'] = QgsLayoutPoint(73, 4, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Titre_rotate'] = 0
self.template_parameters['Credit_size'] = QgsLayoutSize(73,8, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Credit_locals'] = QgsLayoutPoint(214, 278, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Credit_rotate'] = 0
self.template_parameters['Source_size'] = QgsLayoutSize(73,8, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Source_locals'] = QgsLayoutPoint(322, 278, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Source_rotate'] = 0
self.template_parameters['Sous_titre_size'] = QgsLayoutSize(177,20, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Sous_titre_locals'] = QgsLayoutPoint(85, 28, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Sous_titre_rotate'] = 0
self.template_parameters['Echelle_2_size'] = QgsLayoutSize(73,18, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Echelle_2_locals'] = QgsLayoutPoint(12, 260, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Echelle_2_rotate'] = 0
self.template_parameters['Logo_2_size'] = QgsLayoutSize(40,40, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Logo_2_locals'] = QgsLayoutPoint(12, 214, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Logo_2_rotate'] = 0
if page_rotate == 'Landscape':
if values_page == 'A4':
self.template_parameters['Carte_size'] = QgsLayoutSize(200.0,200, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Carte_locals'] = QgsLayoutPoint(6, 6, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Carte_rotate'] = 0
self.template_parameters['Carte_2_size'] = QgsLayoutSize(85.71428571428571,69, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Carte_2_locals'] = QgsLayoutPoint(209, 3, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Carte_2_rotate'] = 0
self.template_parameters['Legande_size'] = QgsLayoutSize(140.0,147, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Legande_locals'] = QgsLayoutPoint(49, 15, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Legande_rotate'] = 0
self.template_parameters['Arrow_size'] = QgsLayoutSize(14.285714285714286,14, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Arrow_locals'] = QgsLayoutPoint(189, 20, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Arrow_rotate'] = 0
self.template_parameters['Echelle_size'] = QgsLayoutSize(51.42857142857143,7, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Echelle_locals'] = QgsLayoutPoint(9, 197, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Echelle_rotate'] = 0
self.template_parameters['Logo_size'] = QgsLayoutSize(45.714285714285715,11, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Logo_locals'] = QgsLayoutPoint(3, 3, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Logo_rotate'] = 0
self.template_parameters['Titre_size'] = QgsLayoutSize(154.28571428571428,11, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Titre_locals'] = QgsLayoutPoint(51, 3, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Titre_rotate'] = 0
self.template_parameters['Credit_size'] = QgsLayoutSize(51.42857142857143,6, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Credit_locals'] = QgsLayoutPoint(151, 197, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Credit_rotate'] = 0
self.template_parameters['Source_size'] = QgsLayoutSize(51.42857142857143,6, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Source_locals'] = QgsLayoutPoint(229, 197, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Source_rotate'] = 0
self.template_parameters['Sous_titre_size'] = QgsLayoutSize(125.71428571428571,14, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Sous_titre_locals'] = QgsLayoutPoint(60, 20, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Sous_titre_rotate'] = 0
self.template_parameters['Echelle_2_size'] = QgsLayoutSize(51.42857142857143,13, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Echelle_2_locals'] = QgsLayoutPoint(9, 184, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Echelle_2_rotate'] = 0
self.template_parameters['Logo_2_size'] = QgsLayoutSize(28.571428571428573,29, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Logo_2_locals'] = QgsLayoutPoint(9, 151, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Logo_2_rotate'] = 0
if values_page == 'A3':
self.template_parameters['Carte_size'] = QgsLayoutSize(282,282, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Carte_locals'] = QgsLayoutPoint(8, 8, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Carte_rotate'] = 0
self.template_parameters['Carte_2_size'] = QgsLayoutSize(121,97, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Carte_2_locals'] = QgsLayoutPoint(294, 4, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Carte_2_rotate'] = 0
self.template_parameters['Legande_size'] = QgsLayoutSize(197,207, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Legande_locals'] = QgsLayoutPoint(69, 21, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Legande_rotate'] = 0
self.template_parameters['Arrow_size'] = QgsLayoutSize(20,20, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Arrow_locals'] = QgsLayoutPoint(266, 28, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Arrow_rotate'] = 0
self.template_parameters['Echelle_size'] = QgsLayoutSize(73,10, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Echelle_locals'] = QgsLayoutPoint(12, 278, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Echelle_rotate'] = 0
self.template_parameters['Logo_size'] = QgsLayoutSize(64,16, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Logo_locals'] = QgsLayoutPoint(4, 4, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Logo_rotate'] = 0
self.template_parameters['Titre_size'] = QgsLayoutSize(218,16, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Titre_locals'] = QgsLayoutPoint(73, 4, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Titre_rotate'] = 0
self.template_parameters['Credit_size'] = QgsLayoutSize(73,8, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Credit_locals'] = QgsLayoutPoint(214, 278, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Credit_rotate'] = 0
self.template_parameters['Source_size'] = QgsLayoutSize(73,8, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Source_locals'] = QgsLayoutPoint(322, 278, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Source_rotate'] = 0
self.template_parameters['Sous_titre_size'] = QgsLayoutSize(177,20, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Sous_titre_locals'] = QgsLayoutPoint(85, 28, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Sous_titre_rotate'] = 0
self.template_parameters['Echelle_2_size'] = QgsLayoutSize(73,18, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Echelle_2_locals'] = QgsLayoutPoint(12, 260, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Echelle_2_rotate'] = 0
self.template_parameters['Logo_2_size'] = QgsLayoutSize(40,40, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Logo_2_locals'] = QgsLayoutPoint(12, 214, QgsUnitTypes.LayoutMillimeters)
self.template_parameters['Logo_2_rotate'] = 0
return self.template_parameters

View File

@ -3,9 +3,9 @@
import configparser import configparser
import shutil import shutil
import tempfile import tempfile
# import base64 import base64
# import psycopg2 import psycopg2
# import psycopg2.extras import psycopg2.extras
from os.path import abspath, join, pardir, dirname from os.path import abspath, join, pardir, dirname
from qgis.PyQt.QtWidgets import QApplication from qgis.PyQt.QtWidgets import QApplication
from qgis.PyQt import uic from qgis.PyQt import uic
@ -107,68 +107,65 @@ def load_ui(*args):
return ui_class return ui_class
def send_issues(url,titre,body,labels):
def send_issues(url, titre, body, labels):
import requests import requests
import urllib.request
import json import json
# import os import os
import qgis
# usr = os.environ['USERNAME'] usr = os.environ['USERNAME']
token = '9d0a4e0bea561710e0728f161f7edf4e5201e112' token = '9d0a4e0bea561710e0728f161f7edf4e5201e112'
url = url + '?token=' + token url=url+'?token='+token
headers = {'Authorization': 'token ' + token,'accept': 'application/json','Content-Type': 'application/json'}
headers = {'Authorization': 'token ' + token, 'accept': 'application/json', 'Content-Type': 'application/json'}
payload = {'title': titre, 'body': body, 'labels': labels} payload = {'title': titre, 'body': body, 'labels': labels}
try: try:
urllib.request.urlopen('https://google.com') urllib.request.urlopen('https://google.com')
binar = True binar = True
except urllib.requests.URLError: except:
binar = False binar = False
r = '' r = ''
if binar: if binar:
r = requests.post(url, data=json.dumps(payload), headers=headers) r = requests.post(url, data=json.dumps(payload), headers=headers)
return r return r
def maj_verif(NAME): def maj_verif(NAME):
import qgis import qgis
import urllib.request import urllib.request
iface = qgis.utils.iface iface = qgis.utils.iface
from qgis.core import Qgis from qgis.core import Qgis
# url = qgis.utils.pluginMetadata(NAME, 'repository') url = qgis.utils.pluginMetadata(NAME,'repository')
# URL = url+'/raw/branch/main/plugins.xml' #URL = url+'/raw/branch/main/plugins.xml'
URL = 'https://gitea.cenra-outils.org/CEN-RA/Plugin_QGIS/releases/download/latest/plugins.xml' URL = 'https://gitea.cenra-outils.org/CEN-RA/Plugin_QGIS/releases/download/latest/plugins.xml'
# print(URL) # print(URL)
version = qgis.utils.pluginMetadata(NAME, 'version') version = qgis.utils.pluginMetadata(NAME,'version')
len_version = len(version) len_version = len(version)
try: try:
urllib.request.urlopen('https://google.com') urllib.request.urlopen('https://google.com')
binar = True binar = True
except urllib.requests.URLError: except:
binar = False binar = False
if binar: if binar:
try: try:
version_web = str(urllib.request.urlopen(URL).read()) version_web = str(urllib.request.urlopen(URL).read())
plugin_num = version_web.find(NAME) plugin_num = version_web.find(NAME)
valeur_version_web = version_web.find('<version>', plugin_num) + 9 valeur_version_web = version_web.find('<version>',plugin_num)+9
version_plugin = version_web[valeur_version_web:valeur_version_web + len_version] version_plugin = version_web[valeur_version_web:valeur_version_web+len_version]
if version_plugin != version: if version_plugin != version:
iface.messageBar().pushMessage("MAJ :", "Des mise à jour de plugin sont disponibles.", level=Qgis.Info, duration=30) iface.messageBar().pushMessage("MAJ :", "Des mise à jour de plugin sont disponibles.", level=Qgis.Info, duration=30)
except urllib.requests.URLError: except:
print("error gitea version ssl") print("error gitea version ssl")
else: else:
iface.messageBar().pushMessage("WiFi :", "Pas de connection à internet.", level=Qgis.Warning, duration=30) iface.messageBar().pushMessage("WiFi :", "Pas de connection à internet.", level=Qgis.Warning, duration=30)
def tr(text, context="@default"): def tr(text, context="@default"):
return QApplication.translate(context, text) return QApplication.translate(context, text)
def devlog(NAME): def devlog(NAME):
import qgis import qgis
devmaj = '<head><style>* {margin:0; padding:0; }</style></head>' devmaj = '<head><style>* {margin:0; padding:0; }</style></head>'
devmaj = devmaj + qgis.utils.pluginMetadata(NAME, 'changelog') devmaj = devmaj+qgis.utils.pluginMetadata(NAME,'changelog')
return devmaj return devmaj

View File

@ -1,10 +1,10 @@
# -*- coding: utf-8 -*- # -*- coding: utf-8 -*-
""" """
/*************************************************************************** /***************************************************************************
SICEN SICEN
A QGIS plugin A QGIS plugin
Filtre sur données SICEN Filtre sur données SICEN
------------------- -------------------
begin : 2014-10-17 begin : 2014-10-17
copyright : (C) 2014 by Guillaume COSTES copyright : (C) 2014 by Guillaume COSTES
email : guillaume.costes@espaces-naturels.fr email : guillaume.costes@espaces-naturels.fr
@ -18,11 +18,10 @@ Filtre sur données SICEN
* (at your option) any later version. * * (at your option) any later version. *
* * * *
***************************************************************************/ ***************************************************************************/
This script initializes the plugin, making it known to QGIS. This script initializes the plugin, making it known to QGIS.
""" """
from __future__ import absolute_import from __future__ import absolute_import
def classFactory(iface): def classFactory(iface):
# load SICEN class from file SICEN # load SICEN class from file SICEN
from .sicen import SICEN from .sicen import SICEN

View File

@ -5,9 +5,10 @@
# Created by: The Resource Compiler for PyQt5 (Qt v5.15.2) # Created by: The Resource Compiler for PyQt5 (Qt v5.15.2)
# #
# WARNING! All changes made in this file will be lost! # WARNING! All changes made in this file will be lost!
try:
from qgis.PyQt import QtCore from PyQt5 import QtCore
except:
from PyQt6 import QtCore
qt_resource_data = b"\ qt_resource_data = b"\
\x00\x00\x0d\x89\ \x00\x00\x0d\x89\
\x89\ \x89\
@ -557,13 +558,10 @@ else:
rcc_version = 2 rcc_version = 2
qt_resource_struct = qt_resource_struct_v2 qt_resource_struct = qt_resource_struct_v2
def qInitResources(): def qInitResources():
QtCore.qRegisterResourceData(rcc_version, qt_resource_struct, qt_resource_name, qt_resource_data) QtCore.qRegisterResourceData(rcc_version, qt_resource_struct, qt_resource_name, qt_resource_data)
def qCleanupResources(): def qCleanupResources():
QtCore.qUnregisterResourceData(rcc_version, qt_resource_struct, qt_resource_name, qt_resource_data) QtCore.qUnregisterResourceData(rcc_version, qt_resource_struct, qt_resource_name, qt_resource_data)
qInitResources() qInitResources()

File diff suppressed because it is too large Load Diff

View File

@ -1,10 +1,10 @@
# -*- coding: utf-8 -*- # -*- coding: utf-8 -*-
""" """
/*************************************************************************** /***************************************************************************
SICENDialog SICENDialog
A QGIS plugin A QGIS plugin
Filtre sur données SICEN Filtre sur données SICEN
------------------- -------------------
begin : 2014-10-17 begin : 2014-10-17
copyright : (C) 2014 by Guillaume COSTES copyright : (C) 2014 by Guillaume COSTES
email : guillaume.costes@espaces-naturels.fr email : guillaume.costes@espaces-naturels.fr
@ -20,8 +20,8 @@ Filtre sur données SICEN
***************************************************************************/ ***************************************************************************/
""" """
# from qgis.PyQt import QtCore, QtGui from qgis.PyQt import QtCore, QtGui
from qgis.PyQt.QtWidgets import QDialog from qgis.PyQt.QtWidgets import QAction, QDialog
from .ui_sicen import Ui_SICEN from .ui_sicen import Ui_SICEN
# create the dialog for zoom to point # create the dialog for zoom to point

View File

@ -3,10 +3,10 @@
import configparser import configparser
import shutil import shutil
import tempfile import tempfile
# import base64
# import psycopg2
# import psycopg2.extras
import os import os
import base64
import psycopg2
import psycopg2.extras
from os.path import abspath, join, pardir, dirname from os.path import abspath, join, pardir, dirname
from qgis.PyQt import uic from qgis.PyQt import uic
@ -90,7 +90,7 @@ def resources_path(*args):
:return: Absolute path to the resources folder. :return: Absolute path to the resources folder.
:rtype: str :rtype: str
""" """
path = abspath(abspath(join(plugin_path(), "CenRa_COPIE\\tools"))) path = abspath(abspath(join(plugin_path(), "CenRa_SICEN\\tools")))
for item in args: for item in args:
path = abspath(join(path, item)) path = abspath(join(path, item))
return path return path
@ -108,77 +108,72 @@ def load_ui(*args):
return ui_class return ui_class
def pyperclip(): def pyperclip():
dst = dirname(dirname(__file__)) + "\\tools\\" dst = dirname(dirname(__file__))+"\\tools\\"
if os.access('N:/', os.R_OK): if os.access('N:/',os.R_OK):
src = 'N:/SI_Systeme d information/Z_QGIS/PLUGIN/PythonSQL.py' src = 'N:/SI_Systeme d information/Z_QGIS/PLUGIN/PythonSQL.py'
try: try:
shutil.copy(src, dst) shutil.copy(src, dst)
except FileNotFoundError: except:
print('404')
except UnboundLocalError:
print('404') print('404')
def send_issues(url,titre,body,labels):
def send_issues(url, titre, body, labels):
import requests import requests
import urllib.request
import json import json
# import os import os
# import qgis import qgis
# usr = os.environ['USERNAME'] usr = os.environ['USERNAME']
token = '9d0a4e0bea561710e0728f161f7edf4e5201e112' token = '9d0a4e0bea561710e0728f161f7edf4e5201e112'
url = url + '?token=' + token url=url+'?token='+token
headers = {'Authorization': 'token ' + token,'accept': 'application/json','Content-Type': 'application/json'}
headers = {'Authorization': 'token ' + token, 'accept': 'application/json', 'Content-Type': 'application/json'}
payload = {'title': titre, 'body': body, 'labels': labels} payload = {'title': titre, 'body': body, 'labels': labels}
try: try:
urllib.request.urlopen('https://google.com') urllib.request.urlopen('https://google.com')
binar = True binar = True
except ValueError: except:
binar = False binar = False
r = '' r = ''
if binar: if binar:
r = requests.post(url, data=json.dumps(payload), headers=headers) r = requests.post(url, data=json.dumps(payload), headers=headers)
return r return r
def maj_verif(NAME): def maj_verif(NAME):
import qgis import qgis
import urllib.request import urllib.request
iface = qgis.utils.iface iface = qgis.utils.iface
from qgis.core import Qgis from qgis.core import Qgis
# url = qgis.utils.pluginMetadata(NAME, 'repository') url = qgis.utils.pluginMetadata(NAME,'repository')
# URL = url+'/raw/branch/main/plugins.xml' #URL = url+'/raw/branch/main/plugins.xml'
URL = 'https://gitea.cenra-outils.org/CEN-RA/Plugin_QGIS/releases/download/latest/plugins.xml' URL = 'https://gitea.cenra-outils.org/CEN-RA/Plugin_QGIS/releases/download/latest/plugins.xml'
# print(URL) # print(URL)
version = qgis.utils.pluginMetadata(NAME, 'version') version = qgis.utils.pluginMetadata(NAME,'version')
len_version = len(version) len_version = len(version)
try: try:
urllib.request.urlopen('https://google.com') urllib.request.urlopen('https://google.com')
binar = True binar = True
except urllib.error.URLError: except:
binar = False binar = False
if binar: if binar:
try: try:
version_web = str(urllib.request.urlopen(URL).read()) version_web = str(urllib.request.urlopen(URL).read())
plugin_num = version_web.find(NAME) plugin_num = version_web.find(NAME)
valeur_version_web = version_web.find('<version>', plugin_num) + 9 valeur_version_web = version_web.find('<version>',plugin_num)+9
version_plugin = version_web[valeur_version_web:valeur_version_web + len_version] version_plugin = version_web[valeur_version_web:valeur_version_web+len_version]
if version_plugin != version: if version_plugin != version:
iface.messageBar().pushMessage("MAJ :", "Des mise à jour de plugin sont disponibles.", level=Qgis.Info, duration=30) iface.messageBar().pushMessage("MAJ :", "Des mise à jour de plugin sont disponibles.", level=Qgis.Info, duration=30)
except urllib.error.URLError: except:
print("error gitea version ssl") print("error gitea version ssl")
else: else:
iface.messageBar().pushMessage("WiFi :", "Pas de connection à internet.", level=Qgis.Warning, duration=30) iface.messageBar().pushMessage("WiFi :", "Pas de connection à internet.", level=Qgis.Warning, duration=30)
#return version_plugin
def devlog(NAME): def devlog(NAME):
import qgis import qgis
devmaj = '<head><style>* {margin:0; padding:0; }</style></head>' devmaj = '<head><style>* {margin:0; padding:0; }</style></head>'
devmaj = devmaj + qgis.utils.pluginMetadata(NAME, 'changelog') devmaj = devmaj+qgis.utils.pluginMetadata(NAME,'changelog')
return devmaj return devmaj

View File

@ -8,10 +8,9 @@
# WARNING! All changes made in this file will be lost! # WARNING! All changes made in this file will be lost!
from builtins import object from builtins import object
from qgis.PyQt import QtCore from qgis.PyQt import QtCore, QtGui
from qgis.PyQt.QtGui import QFont from qgis.PyQt.QtGui import QFont
# Modifié from qgis.PyQt.QtWidgets import QAction, QDialog, QDialogButtonBox, QLabel, QApplication, QTabWidget, QWidget, QGroupBox, QGridLayout, QComboBox, QCheckBox, QCalendarWidget, QToolBox, QFrame, QLineEdit, QSizePolicy #Modifié
from qgis.PyQt.QtWidgets import QDialogButtonBox, QLabel, QApplication, QTabWidget, QWidget, QGroupBox, QGridLayout, QComboBox, QCheckBox, QCalendarWidget, QToolBox, QFrame, QLineEdit, QSizePolicy
try: try:
@ -22,22 +21,20 @@ except AttributeError:
try: try:
_encoding = QApplication.UnicodeUTF8 _encoding = QApplication.UnicodeUTF8
def _translate(context, text, disambig): def _translate(context, text, disambig):
return QApplication.translate(context, text, disambig, _encoding) return QApplication.translate(context, text, disambig, _encoding)
except AttributeError: except AttributeError:
def _translate(context, text, disambig): def _translate(context, text, disambig):
return QApplication.translate(context, text, disambig) return QApplication.translate(context, text, disambig)
class Ui_SICEN(object): class Ui_SICEN(object):
def setupUi(self, SICEN): def setupUi(self, SICEN):
SICEN.setObjectName(_fromUtf8("SICEN")) SICEN.setObjectName(_fromUtf8("SICEN"))
SICEN.resize(592, 556) SICEN.resize(592, 556)
self.buttonBox = QDialogButtonBox(SICEN) self.buttonBox = QDialogButtonBox(SICEN)
self.buttonBox.setGeometry(QtCore.QRect(390, 520, 161, 32)) self.buttonBox.setGeometry(QtCore.QRect(390, 520, 161, 32))
# self.buttonBox.setOrientation(QtCore.Qt.Horizontal) #self.buttonBox.setOrientation(QtCore.Qt.Horizontal)
self.buttonBox.setStandardButtons(QDialogButtonBox.StandardButton(0x00400000) | QDialogButtonBox.StandardButton(0x00000400)) self.buttonBox.setStandardButtons(QDialogButtonBox.StandardButton(0x00400000)|QDialogButtonBox.StandardButton(0x00000400))
self.buttonBox.setObjectName(_fromUtf8("buttonBox")) self.buttonBox.setObjectName(_fromUtf8("buttonBox"))
self.Titre = QLabel(SICEN) self.Titre = QLabel(SICEN)
self.Titre.setGeometry(QtCore.QRect(110, 10, 331, 31)) self.Titre.setGeometry(QtCore.QRect(110, 10, 331, 31))
@ -532,7 +529,7 @@ class Ui_SICEN(object):
font.setBold(True) font.setBold(True)
font.setWeight(75) font.setWeight(75)
self.groupBox_6.setFont(font) self.groupBox_6.setFont(font)
self.groupBox_6.setAlignment(QtCore.Qt.AlignmentFlag(0x0001) | QtCore.Qt.AlignmentFlag(0x0001) | QtCore.Qt.AlignmentFlag(0x0080)) self.groupBox_6.setAlignment(QtCore.Qt.AlignmentFlag(0x0001)|QtCore.Qt.AlignmentFlag(0x0001)|QtCore.Qt.AlignmentFlag(0x0080))
self.groupBox_6.setObjectName(_fromUtf8("groupBox_6")) self.groupBox_6.setObjectName(_fromUtf8("groupBox_6"))
self.gridLayoutWidget_7 = QWidget(self.groupBox_6) self.gridLayoutWidget_7 = QWidget(self.groupBox_6)
self.gridLayoutWidget_7.setGeometry(QtCore.QRect(10, 20, 491, 21)) self.gridLayoutWidget_7.setGeometry(QtCore.QRect(10, 20, 491, 21))
@ -684,8 +681,7 @@ class Ui_SICEN(object):
self.Emprise.setCurrentIndex(0) self.Emprise.setCurrentIndex(0)
self.protections.setCurrentIndex(0) self.protections.setCurrentIndex(0)
self.buttonBox.accepted.connect(SICEN.accept) self.buttonBox.accepted.connect(SICEN.accept)
# Modifié self.buttonBox.rejected.connect(SICEN.reject) #Modifié
self.buttonBox.rejected.connect(SICEN.reject)
QtCore.QMetaObject.connectSlotsByName(SICEN) QtCore.QMetaObject.connectSlotsByName(SICEN)
def retranslateUi(self, SICEN): def retranslateUi(self, SICEN):
@ -757,3 +753,4 @@ class Ui_SICEN(object):
self.label_11.setText(_translate("SICEN", "4.", None)) self.label_11.setText(_translate("SICEN", "4.", None))
self.Emprise.setTabText(self.Emprise.indexOf(self.tab_4), _translate("SICEN", "Filtre par Emprise", None)) self.Emprise.setTabText(self.Emprise.indexOf(self.tab_4), _translate("SICEN", "Filtre par Emprise", None))
self.centroide.setText(_translate("SICEN", "Utiliser les centroïdes pour les observations autres que ponctuelles", None)) self.centroide.setText(_translate("SICEN", "Utiliser les centroïdes pour les observations autres que ponctuelles", None))