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