Salome HOME
bug sur un mesage dans une exception sur un validator (cf JPA)
[tools/eficas.git] / InterfaceQT4 / gereIcones.py
1 # -*- coding: utf-8 -*-
2 # Copyright (C) 2007-2021   EDF R&D
3 #
4 # This library is free software; you can redistribute it and/or
5 # modify it under the terms of the GNU Lesser General Public
6 # License as published by the Free Software Foundation; either
7 # version 2.1 of the License.
8 #
9 # This library is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12 # Lesser General Public License for more details.
13 #
14 # You should have received a copy of the GNU Lesser General Public
15 # License along with this library; if not, write to the Free Software
16 # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
17 #
18 # See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
19 #
20 # Modules Python
21 from __future__ import absolute_import
22 from __future__ import print_function
23 try :
24     from builtins import str
25     from builtins import object
26 except : pass
27
28 import types,os,re,sys
29 import traceback
30 import inspect
31
32 from PyQt5.QtWidgets import QMessageBox, QFileDialog , QMenu, QPushButton, QTreeView ,QListView, QAbstractItemView
33 from PyQt5.QtGui import QIcon
34 from PyQt5.QtCore import  QFileInfo,  Qt, QSize, QVariant
35
36
37 from Extensions.i18n import tr
38 listeSuffixe=('bmp','png','jpg' ,'txt','med')
39
40
41 class FacultatifOuOptionnel(object):
42
43     def setReglesEtAide(self):
44         listeRegles=()
45         try :
46             listeRegles     = self.node.item.getRegles()
47         except :
48             pass
49         if hasattr(self,"RBRegle"):
50             if listeRegles==() : self.RBRegle.close()
51             else :
52                 icon3=QIcon(self.repIcon+"/lettreRblanc30.png")
53                 self.RBRegle.setIcon(icon3)
54                 self.RBRegle.clicked.connect(self.viewRegles)
55
56         cle_doc=None
57         if not hasattr(self,"RBInfo"):return
58         icon=QIcon(self.repIcon+"/point-interrogation30.png")
59         self.RBInfo.setIcon(icon)
60
61         from .monWidgetCommande import MonWidgetCommande
62         if isinstance(self,MonWidgetCommande) and self.editor.code =="MAP":
63             self.cle_doc = self.chercheDocMAP()
64         else :
65             self.cle_doc = self.node.item.getDocu()
66         if self.cle_doc == None  : self.RBInfo.close()
67         else : self.RBInfo.clicked.connect (self.viewDoc)
68
69
70     def chercheDocMAP(self):
71         try :
72             clef=self.editor.maConfiguration.adresse+"/"
73         except :
74             return None
75         for k in self.editor.readercata.cata.JdC.dict_groupes:
76             if self.obj.nom in self.editor.readercata.cata.JdC.dict_groupes[k]:
77                 clef+=k
78                 break
79         clef+="/"+ self.obj.nom[0:-5].lower()+"/spec_"+self.obj.nom[0:-5].lower()+".html"
80
81         return clef
82
83     def viewDoc(self):
84         try :
85             if sys.platform[0:5]=="linux" : cmd="xdg-open "+self.cle_doc
86             else                          : cmd="start "+self.cle_doc
87             os.system(cmd)
88         except:
89             QMessageBox.warning( self,tr( "Aide Indisponible"),tr( "l'aide n est pas installee "))
90
91     def viewRegles(self):
92         self.node.appellebuildLBRegles()
93
94
95     def setIconePoubelle(self):
96         if not(hasattr(self,"RBPoubelle")):return
97
98         if self.node.item.object.isOblig()  and not( hasattr(self.node.item.object,'isDeletable') ):
99             icon=QIcon(self.repIcon+"/deleteRondVide.png")
100             self.RBPoubelle.setIcon(icon)
101             return
102         icon=QIcon(self.repIcon+"/deleteRond.png")
103         self.RBPoubelle.setIcon(icon)
104         self.RBPoubelle.clicked.connect(self.aDetruire)
105
106     def setIconesSalome(self):
107         if not (hasattr(self,"RBSalome")): return
108         from Accas import SalomeEntry
109         mc = self.node.item.get_definition()
110         mctype = mc.type[0]
111         enable_salome_selection = self.editor.salome and \
112           (('grma' in repr(mctype)) or ('grno' in repr(mctype)) or ('SalomeEntry' in repr(mctype)) or \
113           (hasattr(mctype, "enable_salome_selection") and mctype.enable_salome_selection))
114
115         if enable_salome_selection:
116             icon=QIcon(self.repIcon+"/flecheSalome.png")
117             self.RBSalome.setIcon(icon)
118             self.RBSalome.pressed.connect(self.BSalomePressed)
119
120 #PNPN --> Telemac A revoir surement
121 # cela ou le catalogue grpma ou salomeEntry
122             if not(('grma' in repr(mctype)) or ('grno' in repr(mctype))) or not(self.editor.salome):
123                 if hasattr(self,"RBSalomeVue") : self.RBSalomeVue.close()
124             else :
125                 icon1=QIcon(self.repIcon+"/eye.png")
126                 self.RBSalomeVue.setIcon(icon1)
127                 self.RBSalomeVue.clicked.connect(self.BView2DPressed)
128         else:
129             self.RBSalome.close()
130             self.RBSalomeVue.close()
131
132
133     def setIconesFichier(self):
134         if not ( hasattr(self,"BFichier")): return
135         mc = self.node.item.get_definition()
136         mctype = mc.type[0]
137         if mctype == "FichierOuRepertoire":
138             self.BFichierOuRepertoire=self.BFichier
139             self.BFichierOuRepertoire.clicked.connect(self.BFichierOuRepertoirePressed)
140             self.BVisuFichier.close()
141         elif mctype == "Repertoire":
142             self.BRepertoire=self.BFichier
143             self.BRepertoire.clicked.connect(self.BRepertoirePressed)
144             self.BVisuFichier.close()
145         else :
146             self.BFichier.clicked.connect(self.BFichierPressed)
147             self.BVisuFichier.clicked.connect(self.BFichierVisu)
148
149
150
151     def setIconesGenerales(self):
152         repIcon=self.node.editor.appliEficas.repIcon
153         if hasattr(self,"BVisuListe") :
154             fichier=os.path.join(repIcon, 'plusnode.png')
155             icon = QIcon(fichier)
156             self.BVisuListe.setIcon(icon)
157         if hasattr(self,"RBDeplie") :
158             fichier=os.path.join(repIcon, 'plusnode.png')
159             icon = QIcon(fichier)
160             self.RBDeplie.setIcon(icon)
161         if hasattr(self,"RBPlie") :
162             fichier=os.path.join(repIcon, 'minusnode.png')
163             icon = QIcon(fichier)
164             self.RBPlie.setIcon(icon)
165         if hasattr(self,"BVisuFichier") :
166             fichier=os.path.join(repIcon, 'visuFichier.png')
167             icon = QIcon(fichier)
168             self.BVisuFichier.setIcon(icon)
169
170
171
172     def setRun(self):
173         if hasattr(self.editor.appliEficas, 'mesScripts') :
174             if self.editor.code in  self.editor.appliEficas.mesScripts :
175                 self.dict_commandes_mesScripts=self.appliEficas.mesScripts[self.editor.code].dict_commandes
176                 if self.obj.nom in self.dict_commandes_mesScripts :
177                     self.ajoutScript()
178                     icon=QIcon(self.repIcon+"/roue.png")
179                     if hasattr(self,"RBRun"):self.RBRun.setIcon(icon)
180                     return
181         if hasattr(self,"RBRun"): self.RBRun.close()
182         if hasattr(self,"CBScripts"): self.CBScripts.close()
183
184
185     def aDetruire(self):
186         self.node.delete()
187
188     def setValide(self):
189         if not(hasattr (self,'RBValide')) : return
190         couleur=self.node.item.getIconName()
191         monIcone = QIcon(self.repIcon+"/" + couleur + ".png")
192         self.RBValide.setIcon(monIcone)
193
194     # il faut chercher la bonne fenetre
195     def rendVisible(self):
196         #print "je passe par rendVisible de FacultatifOuOptionnel"
197         #print self
198         #print self.node.fenetre
199         #print "return pour etre sure"
200         return
201         #PNPN
202         newNode=self.node.treeParent.chercheNoeudCorrespondant(self.node.item.object)
203         #print newNode
204         self.editor.fenetreCentraleAffichee.scrollAreaCommandes.ensureWidgetVisible(newNode.fenetre)
205         #newNode.fenetre.setFocus()
206
207
208     def ajoutScript(self):
209         if not hasattr(self,'CBScripts') : return # Cas des Widgets Plies
210         self.dictCommandes={}
211         listeCommandes=self.dict_commandes_mesScripts[self.obj.nom]
212         if type(listeCommandes) != tuple: listeCommandes=(listeCommandes,)
213         i=0
214         for commande in listeCommandes :
215             conditionSalome=commande[3]
216             if (self.appliEficas.salome == 0 and conditionSalome == True): continue
217             self.CBScripts.addItem(commande[1])
218             self.dictCommandes[commande[1]]=i
219             i=i+1
220         self.CBScripts.activated.connect(self.choixSaisi)
221
222     def choixSaisi(self):
223         fction=str(self.CBScripts.currentText())
224         numero= self.dictCommandes[fction]
225         self.node.appelleFonction(numero,nodeTraite=self.node)
226         #self.reaffiche()
227
228 class ContientIcones(object):
229
230     def BFichierVisu(self):
231         fichier=self.lineEditVal.text()
232         if fichier == None or str(fichier)=="" : return
233         from .monViewTexte import ViewText
234         try :
235             if sys.platform[0:5]=="linux" :
236                 #cmd="xdg-open "+ str(fichier)
237                 #changer pour marcher dans l'EDC
238                 #cmd="gedit "+ str(fichier)
239                 from os.path import splitext
240                 fileName,extension = splitext(fichier)
241                 if extension in  self.parentQt.editor.appliEficas.maConfiguration.utilParExtensions:
242                     cmd=self.parentQt.editor.appliEficas.maConfiguration.utilParExtensions[extension] + " " + str(fichier)
243                 else:  cmd="xdg-open "+ str(fichier)
244                 os.system(cmd)
245             else                          :
246                 os.startfile(str(fichier))
247         except:
248             try :
249                 fp=open(fichier)
250                 txt=fp.read()
251                 nomFichier=QFileInfo(fichier).baseName()
252                 maVue=ViewText(self,entete=nomFichier)
253                 maVue.setText(txt)
254                 maVue.show()
255                 fp.close()
256             except:
257                 QMessageBox.warning( None,
258                            tr("Visualisation Fichier "),
259                            tr("Impossibilite d'afficher le Fichier"),)
260
261     def BFichierPressed(self):
262         mctype = self.node.item.get_definition().type
263         if len(mctype) > 1:
264             filters = mctype[1]
265         elif hasattr(mctype[0], "filters"):
266             filters = mctype[0].filters
267         else:
268             filters = ""
269         if len(mctype) > 2 and mctype[2] == "Sauvegarde":
270             fichier = QFileDialog.getSaveFileName(self.appliEficas,
271                                 tr('Use File'),
272                                 self.appliEficas.maConfiguration.savedir,
273                                 filters)
274         else:
275             #print(filters)
276             fichier = QFileDialog.getOpenFileName(self.appliEficas,
277                                 tr('Ouvrir Fichier'),
278                                 self.appliEficas.maConfiguration.savedir,
279                                 filters)
280
281         fichier=fichier[0]
282         if not(fichier == ""):
283             ulfile = os.path.abspath(fichier)
284             self.appliEficas.maConfiguration.savedir=os.path.split(ulfile)[0]
285             self.lineEditVal.setText(fichier)
286             self.editor.afficheCommentaire(tr("Fichier selectionne"))
287             self.LEvaleurPressed()
288             if (QFileInfo(fichier).suffix() in listeSuffixe ):
289                 self.image=fichier
290                 if (not hasattr(self,"BSelectInFile")):
291                     try :
292                         self.BSelectInFile = QPushButton(self)
293                         self.BSelectInFile.setMinimumSize(QSize(140,40))
294                         self.BSelectInFile.setObjectName("BSelectInFile")
295                         self.gridLayout.addWidget(self.BSelectInFile,1,1,1,1)
296                         self.BSelectInFile.setText(tr("Selection"))
297                         self.BSelectInFile.clicked.connect(self.BSelectInFilePressed)
298                     except :
299                         pass
300                 else :
301                     self.BSelectInFile.setVisible(1)
302
303             elif hasattr(self, "BSelectInFile"):
304                 self.BSelectInFile.setVisible(0)
305
306     def BFichierOuRepertoirePressed(self):
307         self.fileName=""
308         self.file_dialog=QFileDialog()
309         self.file_dialog.setFileMode(QFileDialog.Directory);
310         self.file_dialog.setFileMode(QFileDialog.Directory|QFileDialog.ExistingFiles)
311         self.file_dialog.setOption(QFileDialog.DontUseNativeDialog,True);
312         self.file_dialog.setWindowTitle('Choose File or Directory')
313         self.explore(self.file_dialog)
314         self.file_dialog.exec_()
315         if self.fileName == "" : return
316         self.lineEditVal.setText(self.fileName)
317         self.LEvaleurPressed()
318
319
320     def explore(self,widget):
321         for c in widget.children() :
322             if isinstance(c, QTreeView) :
323                 c.clicked.connect (self.changeBoutonOpen)
324                 self.monTreeView=c
325             try :
326                 if c.text() == "&Open" : self.monBoutonOpen=c
327             except : pass
328             self.explore(c)
329
330
331     def changeBoutonOpen(self):
332         self.monBoutonOpen.setEnabled(True)
333         self.monBoutonOpen.setText("Choose")
334         self.monBoutonOpen.clicked.connect(self.monBoutonOpenClicked)
335         index = self.monTreeView.currentIndex();
336         self.fileName2 = self.monTreeView.model().data(index)
337
338     def monBoutonOpenClicked(self):
339         try :
340             self.fileName=self.file_dialog.selectedFiles()[0]
341         except :
342             self.fileName=self.file_dialog.directory().absolutePath()
343         self.file_dialog.close()
344         self.file_dialog=None
345
346     def BRepertoirePressed(self):
347         directory = QFileDialog.getExistingDirectory(self.appliEficas,
348               directory = self.appliEficas.maConfiguration.savedir,
349               options = QFileDialog.ShowDirsOnly)
350
351         if not (directory == "") :
352             absdir = os.path.abspath(directory)
353             self.appliEficas.maConfiguration.savedir = os.path.dirname(absdir)
354             self.lineEditVal.setText(directory)
355             self.LEvaleurPressed()
356
357     def BSelectInFilePressed(self):
358         from monSelectImage import MonSelectImage
359         MonSelectImage(file=self.image,parent=self).show()
360
361
362
363     def BSalomePressed(self):
364         self.editor.afficheCommentaire("")
365         selection=[]
366         commentaire=""
367         genea=self.node.item.getGenealogie()
368         kwType = self.node.item.get_definition().type[0]
369         for e in genea:
370             if "GROUP_NO" in e: kwType = "GROUP_NO"
371             if "GROUP_MA" in e: kwType = "GROUP_MA"
372
373         if 'grno' in repr(kwType): kwType = "GROUP_NO"
374         if 'grma' in repr(kwType): kwType = "GROUP_MA"
375
376         if kwType in ("GROUP_NO","GROUP_MA"):
377             selection, commentaire = self.appliEficas.selectGroupFromSalome(kwType,editor=self.editor)
378
379         mc = self.node.item.get_definition()
380
381         if  (isinstance(mc.type,tuple) and len(mc.type) > 1 and "(*.med)" in mc.type[1] ):
382             selection, commentaire = self.appliEficas.selectMeshFile(editor=self.editor)
383             #print selection, commentaire
384             if commentaire != "" :
385                 QMessageBox.warning( None,
386                 tr("Export Med vers Fichier "),
387                 tr("Impossibilite d exporter le Fichier"),)
388                 return
389             else :
390                 self.lineEditVal.setText(str(selection))
391                 return
392
393         from Accas import SalomeEntry
394         if inspect.isclass(kwType) and issubclass(kwType, SalomeEntry):
395             selection, commentaire = self.appliEficas.selectEntryFromSalome(kwType,editor=self.editor)
396
397         if commentaire !="" :
398             self.editor.afficheInfos(tr(str(commentaire)))
399         if selection == [] : return
400
401         min,max=self.node.item.getMinMax()
402         if max > 1 :
403             self.ajoutNValeur(selection)
404             return
405
406         monTexte=""
407         for geomElt in selection: monTexte=geomElt+","
408         monTexte= monTexte[0:-1]
409         self.lineEditVal.setText(str(monTexte))
410         self.LEvaleurPressed()
411
412     def BView2DPressed(self):
413         try :
414             # cas d un Simp de base
415             valeur=self.lineEditVal.text()
416         except :
417             valeur=self.textSelected
418         valeur = str(valeur)
419         if valeur == str("") : return
420         if valeur :
421             ok, msgError = self.appliEficas.displayShape(valeur)
422             if not ok:
423                 self.editor.afficheInfos(msgError,Qt.red)
424
425     def BParametresPressed(self):
426         liste=self.node.item.getListeParamPossible()
427         from monListeParamPanel import MonListeParamPanel
428         MonListeParamPanel(liste=liste,parent=self).show()