Salome HOME
optim eciture
[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
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.get_regles()
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.get_docu()
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.CONFIGURATION.adresse+"/"
73       except :
74         return None
75       for k in self.editor.readercata.cata[0].JdC.dict_groupes:
76           if self.obj.nom in self.editor.readercata.cata[0].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       #print " c est le moment de gerer le passage au suivant"
190       if not(hasattr (self,'RBValide')) : return
191       icon = QIcon()
192       if self.node.item.object.isvalid() : 
193          icon=QIcon(self.repIcon+"/ast-green-ball.png")
194       else :
195          icon=QIcon(self.repIcon+"/ast-red-ball.png")
196       self.RBValide.setIcon(icon)
197
198   # il faut chercher la bonne fenetre
199   def rendVisible(self):
200       #print "je passe par rendVisible de FacultatifOuOptionnel"
201       #print self
202       #print self.node.fenetre
203       #print "return pour etre sure"
204       return
205       #PNPN
206       newNode=self.node.treeParent.chercheNoeudCorrespondant(self.node.item.object)
207       #print newNode
208       self.editor.fenetreCentraleAffichee.scrollAreaCommandes.ensureWidgetVisible(newNode.fenetre)
209       #newNode.fenetre.setFocus()
210
211
212   def ajoutScript(self):
213         if not hasattr(self,'CBScripts') : return # Cas des Widgets Plies
214         self.dictCommandes={}
215         listeCommandes=self.dict_commandes_mesScripts[self.obj.nom]
216         if type(listeCommandes) != tuple: listeCommandes=(listeCommandes,)
217         i=0
218         for commande in listeCommandes :
219           conditionSalome=commande[3]
220           if (self.appliEficas.salome == 0 and conditionSalome == True): continue
221           self.CBScripts.addItem(commande[1])
222           self.dictCommandes[commande[1]]=i
223           i=i+1
224         self.CBScripts.activated.connect(self.choixSaisi)
225
226   def choixSaisi(self):
227       fction=str(self.CBScripts.currentText())
228       numero= self.dictCommandes[fction]
229       self.node.AppelleFonction(numero,nodeTraite=self.node)
230       #self.reaffiche()
231
232 class ContientIcones(object):
233
234   def BFichierVisu(self):
235        fichier=self.lineEditVal.text()
236        if fichier == None or str(fichier)=="" : return
237        from .monViewTexte import ViewText
238        try :
239          if sys.platform[0:5]=="linux" :
240            cmd="xdg-open "+ str(fichier)
241            os.system(cmd)
242          else                          :
243            os.startfile(str(fichier)) 
244        except:
245          try :
246             fp=open(fichier)
247             txt=fp.read()
248             nomFichier=QFileInfo(fichier).baseName()
249             maVue=ViewText(self,entete=nomFichier)
250             maVue.setText(txt)
251             maVue.show()
252             fp.close()
253          except:
254             QMessageBox.warning( None,
255                        tr("Visualisation Fichier "),
256                        tr("Impossibilite d'afficher le Fichier"),)
257
258   def BFichierPressed(self):
259       mctype = self.node.item.get_definition().type
260       if len(mctype) > 1:
261           filters = mctype[1]
262       elif hasattr(mctype[0], "filters"):
263           filters = mctype[0].filters
264       else:
265           filters = ""
266       if len(mctype) > 2 and mctype[2] == "Sauvegarde":
267           fichier = QFileDialog.getSaveFileName(self.appliEficas,
268                               tr('Sauvegarder Fichier'),
269                               self.appliEficas.CONFIGURATION.savedir,
270                               filters)
271       else:
272           print(filters)
273           fichier = QFileDialog.getOpenFileName(self.appliEficas,
274                               tr('Ouvrir Fichier'),
275                               self.appliEficas.CONFIGURATION.savedir,
276                               filters)
277
278       fichier=fichier[0]
279       if not(fichier == ""):
280          ulfile = os.path.abspath(six.text_type(fichier))
281          self.appliEficas.CONFIGURATION.savedir=os.path.split(ulfile)[0]
282          self.lineEditVal.setText(fichier)
283          self.editor.affiche_commentaire(tr("Fichier selectionne"))
284          self.LEValeurPressed()
285          if (QFileInfo(fichier).suffix() in listeSuffixe ):
286              self.image=fichier
287              if (not hasattr(self,"BSelectInFile")):
288                try :
289                  self.BSelectInFile = QPushButton(self)
290                  self.BSelectInFile.setMinimumSize(QSize(140,40))
291                  self.BSelectInFile.setObjectName("BSelectInFile")
292                  self.gridLayout.addWidget(self.BSelectInFile,1,1,1,1)
293                  self.BSelectInFile.setText(tr("Selection"))
294                  self.BSelectInFile.clicked.connect(self.BSelectInFilePressed)
295                except :
296                 pass
297              else :
298                self.BSelectInFile.setVisible(1)
299                
300          elif hasattr(self, "BSelectInFile"):
301              self.BSelectInFile.setVisible(0)
302
303   def BFichierOuRepertoirePressed(self):
304       self.fileName=""
305       print (0)
306       self.file_dialog=QFileDialog()
307       print (1)
308       self.file_dialog.setFileMode(QFileDialog.Directory);
309       print (2)
310       self.file_dialog.setFileMode(QFileDialog.Directory|QFileDialog.ExistingFiles)
311       print (3)
312       self.file_dialog.setOption(QFileDialog.DontUseNativeDialog,True);
313       self.file_dialog.setWindowTitle('Choose File or Directory')
314       self.explore(self.file_dialog)
315       self.file_dialog.exec_()
316       if self.fileName == "" : return
317       self.lineEditVal.setText(self.fileName)
318       self.LEValeurPressed()
319      
320
321   def explore(self,widget):
322       for c in widget.children() :
323           if isinstance(c, QTreeView) :
324              c.clicked.connect (self.changeBoutonOpen)
325              self.monTreeView=c
326           try :
327              if c.text() == "&Open" : self.monBoutonOpen=c
328           except : pass
329           self.explore(c) 
330
331
332   def changeBoutonOpen(self):
333       self.monBoutonOpen.setEnabled(True)
334       self.monBoutonOpen.setText("Choose")
335       self.monBoutonOpen.clicked.connect(self.monBoutonOpenClicked)
336       index = self.monTreeView.currentIndex();
337       self.fileName2 = self.monTreeView.model().data(index)
338
339   def monBoutonOpenClicked(self):
340       try :
341         self.fileName=self.file_dialog.selectedFiles()[0]
342       except :
343          self.fileName=self.file_dialog.directory().absolutePath()
344       self.file_dialog.close()
345       self.file_dialog=None
346
347   def BRepertoirePressed(self):
348       directory = QFileDialog.getExistingDirectory(self.appliEficas,
349             directory = self.appliEficas.CONFIGURATION.savedir,
350             options = QFileDialog.ShowDirsOnly)
351
352       if not (directory == "") :
353          absdir = os.path.abspath(six.text_type(directory))
354          self.appliEficas.CONFIGURATION.savedir = os.path.dirname(absdir)
355          self.lineEditVal.setText(directory)
356          self.LEValeurPressed()
357
358   def BSelectInFilePressed(self):
359       from monSelectImage import MonSelectImage
360       MonSelectImage(file=self.image,parent=self).show()
361
362           
363
364   def BSalomePressed(self):
365         self.editor.affiche_commentaire("")
366         selection=[]
367         commentaire=""
368         genea=self.node.item.get_genealogie()
369         kwType = self.node.item.get_definition().type[0]
370         for e in genea:
371             if "GROUP_NO" in e: kwType = "GROUP_NO"
372             if "GROUP_MA" in e: kwType = "GROUP_MA"
373
374         if 'grno' in repr(kwType): kwType = "GROUP_NO"
375         if 'grma' in repr(kwType): kwType = "GROUP_MA"
376
377         if kwType in ("GROUP_NO","GROUP_MA"):
378            selection, commentaire = self.appliEficas.selectGroupFromSalome(kwType,editor=self.editor)
379
380         mc = self.node.item.get_definition()
381
382         if  (isinstance(mc.type,tuple) and len(mc.type) > 1 and "(*.med)" in mc.type[1] ):
383            selection, commentaire = self.appliEficas.selectMeshFile(editor=self.editor)
384            #print selection, commentaire
385            if commentaire != "" : 
386                   QMessageBox.warning( None,
387                   tr("Export Med vers Fichier "),
388                   tr("Impossibilite d exporter le Fichier"),)
389                   return
390            else :
391                   self.lineEditVal.setText(str(selection))
392                   return
393
394         from Accas import SalomeEntry
395         if isinstance(kwType, type) and issubclass(kwType, SalomeEntry):
396            selection, commentaire = self.appliEficas.selectEntryFromSalome(kwType,editor=self.editor)
397
398         if commentaire !="" :
399             self.editor.affiche_infos(tr(str(commentaire)))
400         if selection == [] : return
401
402         min,max=self.node.item.GetMinMax()
403         if max > 1 : 
404            self.ajoutNValeur(selection)
405            return
406
407         monTexte=""
408         for geomElt in selection: monTexte=geomElt+","
409         monTexte= monTexte[0:-1]
410         self.lineEditVal.setText(str(monTexte))
411         self.LEValeurPressed()
412
413   def BView2DPressed(self):
414         try :
415           # cas d un Simp de base
416           valeur=self.lineEditVal.text()
417         except :
418           valeur=self.textSelected
419         valeur = str(valeur)
420         if valeur == str("") : return
421         if valeur :
422            ok, msgError = self.appliEficas.displayShape(valeur)
423            if not ok:
424               self.editor.affiche_infos(msgError,Qt.red)
425
426   def BParametresPressed(self):
427         liste=self.node.item.get_liste_param_possible()
428         from monListeParamPanel import MonListeParamPanel
429         MonListeParamPanel(liste=liste,parent=self).show()
430