]> SALOME platform Git repositories - tools/eficas.git/blob - InterfaceQT4/groupe.py
Salome HOME
d70b59436f09bd4ffdb3aa2cb5f5b0d919feb998
[tools/eficas.git] / InterfaceQT4 / groupe.py
1 # Copyright (C) 2007-2013   EDF R&D
2 #
3 # This library is free software; you can redistribute it and/or
4 # modify it under the terms of the GNU Lesser General Public
5 # License as published by the Free Software Foundation; either
6 # version 2.1 of the License.
7 #
8 # This library is distributed in the hope that it will be useful,
9 # but WITHOUT ANY WARRANTY; without even the implied warranty of
10 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
11 # Lesser General Public License for more details.
12 #
13 # You should have received a copy of the GNU Lesser General Public
14 # License along with this library; if not, write to the Free Software
15 # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
16 #
17 # See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
18 #
19 # Modules Python
20 # Modules Eficas
21
22 from determine import monEnvQT5
23 if monEnvQT5:
24    from PyQt5.QtWidgets import QWidget
25    from PyQt5.QtCore import Qt
26 else :
27    from PyQt4.QtGui import *
28    from PyQt4.QtCore import *
29 from Extensions.i18n import tr
30
31 from Extensions.i18n import tr
32 from gereIcones import FacultatifOuOptionnel
33 import Accas 
34
35     
36 # Import des panels
37
38 class Groupe(QWidget,FacultatifOuOptionnel):
39   """
40   """
41   def __init__(self,node,editor,parentQt,definition,obj,niveau,commande=None):
42       QWidget.__init__(self,None)
43       self.node=node
44       self.node.fenetre=self
45       #print "groupe : ",self.node.item.nom," ",self.node.fenetre
46       self.setupUi(self)
47       self.editor=editor
48       self.obj=obj
49       self.niveau=niveau
50       self.definition=definition
51       self.parentQt=parentQt
52       self.maCommande=commande
53       self.listeFocus=[]
54       self.appliEficas=self.editor.appliEficas
55       self.repIcon=self.appliEficas.repIcon
56       self.jdc=self.node.item.get_jdc()
57       self.setIconePoubelle()
58       self.setIconesGenerales()
59       self.setRun()
60       self.setValide()
61       self.setReglesEtAide()
62       self.afficheMots()
63       self.listeMCAAjouter=[]
64       self.dictMCVenantDesBlocs={}
65       if hasattr(self,'RBDeplie') and not monEnvQT5 : self.connect(self.RBDeplie,SIGNAL("clicked()"), self.Deplie)
66       if hasattr(self,'RBPlie')  and not monEnvQT5: self.connect(self.RBPlie,SIGNAL("clicked()"), self.Plie)
67       if hasattr(self,'RBDeplie')  and monEnvQT5: self.RBDeplie.clicked.connect(self.Deplie)
68       if hasattr(self,'RBPlie')  and monEnvQT5: self.RBPlie.clicked.connect( self.Plie)
69       self.setAcceptDrops(True)
70       #self.donneFocus()
71      
72   def donneFocus(self):
73       for fenetre in self.listeFocus:
74           if fenetre==None : return
75           if fenetre.node.item.isvalid() == 0 :
76              fenetre.prendLeFocus=1
77              fenetre.hide()
78              fenetre.show()
79       
80
81   def afficheMots(self):
82       #print "ds afficheMots ",self.node.item.nom
83       for node in self.node.children:
84            #if node.item.nom == "Background" :print "afficheMots ",node," " ,node.item.nom, " ",node.plie ," ", node.appartientAUnNoeudPlie,node.getPanelGroupe
85            #if node.item.nom == "BackgroundError" :print "afficheMots ",node," " ,node.item.nom, " ",node.plie ," ", node.appartientAUnNoeudPlie,node.getPanelGroupe
86            # non return mais  continue car il faut tenir compte des blocs
87            if node.appartientAUnNoeudPlie==True : continue
88            #print "je suis apres le if pour ",node.item.nom
89            widget=node.getPanelGroupe(self,self.maCommande)
90            #print "widget pour ", node.item.nom, widget
91            self.listeFocus.append(node.fenetre)
92       #print "fin pour " , self.node.item.nom
93
94        
95   def calculOptionnel(self):
96         self.liste_mc=[]
97         genea =self.obj.get_genealogie()
98         # Attention : les mots clefs listes (+sieurs fact )
99         # n ont pas toutes ces methodes
100         try :
101            self.liste_mc=self.obj.get_liste_mc_ordonnee(genea,self.jdc.cata_ordonne_dico)
102         except :
103            return
104         
105   def afficheOptionnel(self):
106         liste=self.ajouteMCOptionnelDesBlocs()
107         self.monOptionnel=self.editor.widgetOptionnel
108         self.monOptionnel.afficheOptionnel(liste,self)
109         #self.monOptionnel.affiche(liste)
110            
111
112   def ajouteMCOptionnelDesBlocs(self):
113       #print "Je passe dans ajouteMCOptionnelDesBlocs pour", self.node.item.nom
114       self.dictMCVenantDesBlocs={}
115       i=0
116       self.calculOptionnel()
117       liste=self.liste_mc
118       for MC in self.liste_mc : self.dictMCVenantDesBlocs[MC]=self
119       while i < self.commandesLayout.count():
120           from monWidgetBloc import MonWidgetBloc
121           widget=self.commandesLayout.itemAt(i).widget()
122           i=i+1
123           if not(isinstance(widget,MonWidgetBloc)) : continue
124           widget.calculOptionnel()
125           listeW=widget.ajouteMCOptionnelDesBlocs() 
126           for MC in widget.dictMCVenantDesBlocs.keys():
127               if MC in self.dictMCVenantDesBlocs.keys(): print "Pb Sur les MC" 
128               else : self.dictMCVenantDesBlocs[MC]=widget.dictMCVenantDesBlocs[MC]
129           liste=liste+listeW
130       return liste
131
132
133   def reaffiche(self,nodeAVoir=None):
134       #print "dans reaffiche de groupe.py", nodeAVoir
135       self.parentQt.reaffiche(nodeAVoir)
136
137   def recalculeListeMC(self,listeMC):
138       #print "pas si peu utile"
139       #on ajoute et on enleve
140       listeNode=[]
141       for name in listeMC :
142           nodeAEnlever=self.node.append_child(name)
143           if nodeAEnlever.item.isMCList(): 
144              nodeAEnlever=nodeAEnlever.children[-1]
145           listeNode.append(nodeAEnlever)
146       self.afficheOptionnel()
147       self.monOptionnel.affiche(self.liste_mc)
148       if len(listeNode) == 0 : return
149       if len(listeNode) == 1 : 
150          listeNode[0].delete()
151          self.editor.affiche_infos("")
152          return
153       for noeud in listeNode:
154           noeud.treeParent.item.suppitem(noeud.item)
155       noeud.treeParent.build_children()
156       self.editor.affiche_infos("")
157
158   def ajoutMC(self,texteListeNom):
159       listeNom=texteListeNom.split("+")[1:]
160       firstNode=None
161       for nom in listeNom:
162         if nom not in self.dictMCVenantDesBlocs.keys():
163            #print "bizarre, bizarre"
164            self.editor.init_modif()
165            nouveau=self.node.append_child(nom)
166         else :
167            self.editor.init_modif()
168            widget=self.dictMCVenantDesBlocs[nom]
169            nouveau=widget.node.append_child(nom)
170         if firstNode==None : firstNode=nouveau 
171         if nouveau == None or nouveau == 0  : 
172            self.editor.affiche_infos(tr('insertion impossible a cet endroit pour '+nom),Qt.red)
173       self.reaffiche(firstNode)
174       if firstNode!=None and firstNode !=0 and firstNode.item!=None :
175         firstNode.select()
176
177
178   def Plie(self):
179       self.node.setPlie()
180       self.reaffiche(self.node) 
181
182   def Deplie(self):
183       self.node.setDeplie()
184       self.reaffiche(self.node) 
185
186   def traiteClicSurLabel(self,texte):
187       if self.editor.code != "CARMELCND" : self.afficheOptionnel()
188