Salome HOME
efac292baeda318525326ba2bd30d21795b52f94
[tools/eficas.git] / InterfaceQT4 / monWidgetPlusieursInto.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 import string,types,os
22
23 # Modules Eficas
24 from PyQt4.QtGui import *
25 from PyQt4.QtCore import *
26 from Extensions.i18n import tr
27
28 from feuille                import Feuille
29 from desWidgetPlusieursInto import Ui_WidgetPlusieursInto 
30 from politiquesValidation   import PolitiquePlusieurs
31 from qtSaisie               import SaisieValeur
32 from gereListe              import GerePlie
33
34 class MonWidgetPlusieursInto (Ui_WidgetPlusieursInto,Feuille,GerePlie):
35
36   def __init__(self,node,monSimpDef,nom,objSimp,parentQt,commande):
37         #print "MonWidgetPlusieursInto", nom, self
38         self.index=1
39         Feuille.__init__(self,node,monSimpDef,nom,objSimp,parentQt,commande)
40         self.listeValeursCourantes=self.node.item.GetListeValeurs()
41         self.parentQt.commandesLayout.insertWidget(-1,self)
42         #if len(self.listeValeursCourantes) == len(self.monSimpDef.into) : self.CBCheck.setChecked(False)
43         #else : self.CBCheck.setChecked(True)
44         self.connect(self.CBCheck, SIGNAL('stateChanged(int)'),self.change)
45         self.gereIconePlier()
46         self.inhibe=False
47         # try except si la liste des possibles est vide
48         # prevoir qqchose
49         try :
50           self.maCommande.listeAffichageWidget.append(self.lineEditVal1)
51         except :
52           pass
53
54
55   def change(self,int):
56        if self.inhibe:return
57        self.inhibe=True
58        if not(self.CBCheck.isChecked()) : 
59           for i in range(len(self.listeAAfficher)):
60               nomCB="lineEditVal"+str(i+1)
61               courant=getattr(self,nomCB)
62               courant.setChecked(True)
63           self.CBCheck.setChecked(False)
64        else :
65           min,max = self.node.item.GetMinMax()
66           for i in range(len(self.listeAAfficher)):
67               nomCB="lineEditVal"+str(i+1)
68               courant=getattr(self,nomCB)
69               courant.setChecked(False)
70           self.CBCheck.setChecked(True)
71        self.inhibe=False
72
73   def setValeurs(self):
74        self.listeValeursCourantes=self.node.item.GetListeValeurs()
75        if hasattr(self.node.item.definition.validators,'set_MCSimp'):
76             obj=self.node.item.getObject()
77             self.node.item.definition.validators.set_MCSimp(obj)
78             if self.node.item.isvalid() == 0 :
79                liste=[]
80                for item in self.listeValeursCourantes:
81                    if self.node.item.definition.validators.verif_item(item)==1:
82                       liste.append(item)
83                self.listeAAfficher=self.node.item.get_liste_possible(liste)
84                #print self.listeAAfficher
85             else: 
86                self.listeAAfficher=self.node.item.get_liste_possible([])
87        else :
88                self.listeAAfficher=self.node.item.get_liste_possible([])
89
90        self.PourEtreCoche=self.listeValeursCourantes
91        if self.objSimp.wait_assd() : 
92           self.listeAAfficher=self.node.item.get_sd_avant_du_bon_type()
93           self.PourEtreCoche=[]
94           for concept in self.listeValeursCourantes:
95               self.PourEtreCoche.append(concept.nom)
96        if len(self.listeAAfficher)*20 > 400 : self.setMinimumHeight(400)
97        else : self.setMinimumHeight(len(self.listeAAfficher)*30)
98        self.adjustSize()
99        self.vScrollBar = self.scrollArea.verticalScrollBar()
100        self.politique=PolitiquePlusieurs(self.node,self.editor)
101        self.indexListe=1
102        for i in range(1,len(self.listeAAfficher)+1): self.ajoutCB(i)
103        for i in range(len(self.listeAAfficher)):
104            nomCB="lineEditVal"+str(i+1)
105            courant=getattr(self,nomCB)
106            courant.setText(str(self.listeAAfficher[i]))
107            #if self.monSimpDef.into[i] in self.listeValeursCourantes : 
108            if self.listeAAfficher[i] in self.PourEtreCoche : 
109               courant.setChecked(True)
110            self.connect(courant,SIGNAL("toggled(bool)"),self.changeValeur)
111        self.vScrollBar.triggerAction(QScrollBar.SliderToMinimum)
112        
113
114   def ajoutCB(self,index,valeur=None):
115       #print "ajoutCB ", index
116       nomCB="lineEditVal"+str(index)
117       if hasattr(self,nomCB) : return
118       nouveauCB = QCheckBox(self.scrollArea)
119       self.CBLayout.addWidget(nouveauCB)
120       qApp.processEvents()
121       nouveauCB.setText("")
122       if index % 2 == 1 : nouveauCB.setStyleSheet("background:rgb(210,210,210)")
123       else :                        nouveauCB.setStyleSheet("background:rgb(240,240,240)")
124       self.vScrollBar.triggerAction(QScrollBar.SliderToMaximum)
125       nouveauCB.setFocus()
126       setattr(self,nomCB,nouveauCB)
127       
128
129   def finCommentaire(self):
130         commentaire=""
131         mc = self.node.item.get_definition()
132         d_aides = { 'TXM' : 'chaines de caracteres',
133                   'R'   : 'reels',
134                   'I'   : 'entiers',
135                   'C'   : 'complexes'}
136         type = mc.type[0]
137         if not d_aides.has_key(type) :
138            if mc.min == mc.max:
139                commentaire=tr("Entrez ")+str(mc.min)+tr(" valeurs ")
140            else :
141                commentaire=tr("Entrez entre ")+str(mc.min)+tr(" et ")+str(mc.max)+tr(" valeurs ")
142         else :
143            if mc.min == mc.max:
144                commentaire=tr("Entrez ")+str(mc.min)+" "+tr(d_aides[type])
145            else :
146                commentaire=tr("Entrez entre ")+str(mc.min)+(" et  ")+str(mc.max) +" " +tr(d_aides[type])
147         aideval=self.node.item.aide()
148         commentaire=commentaire + "   " + QString.toUtf8(QString(aideval))
149         return str(commentaire)
150
151   def ajout1Valeur(self,valeur=None):
152         #print "________________"
153         #print self
154         #print self.node
155         #print self.node.item
156         if valeur == None : return
157         liste,validite=SaisieValeur.TraiteLEValeur(self,str(valeur))
158         if validite == 0 : return
159         if liste ==[]    : return
160         listeVal=[]
161         for valeur in self.listeValeursCourantes : listeVal.append(valeur)
162         validite,comm,comm2,listeRetour=self.politique.AjoutValeurs(liste,-1,listeVal)
163         if (comm2 != "" and comm != None) : return comm2
164         if validite : 
165            self.listeValeursCourantes=self.listeValeursCourantes+listeRetour
166            if len(self.listeValeursCourantes) > self.monSimpDef.min :
167               self.node.item.set_valeur(self.listeValeursCourantes)
168            return None
169         else :
170            return(comm2+" "+comm)
171         
172
173
174   def changeValeur(self):
175       self.listeValeursCourantesAvant=self.listeValeursCourantes
176       self.listeValeursCourantes = []
177       #print "changeValeur ____________" , self.monSimpDef.into, len(self.monSimpDef.into)
178       for i in range (1,len(self.listeAAfficher)+1):
179           nomLineEdit="lineEditVal"+str(i)
180           courant=getattr(self,nomLineEdit)
181           if not (courant.isChecked()):continue
182           valeur=courant.text()
183           if valeur != None and valeur != "" : 
184              commentaire=self.ajout1Valeur(valeur)
185              if (commentaire != None ):
186                  self.editor.affiche_infos(commentaire,Qt.red)
187                  courant.setText("")
188       min,max = self.node.item.GetMinMax()
189       if len(self.listeValeursCourantes) < min : 
190          self.editor.affiche_infos(tr("Nombre minimal de valeurs : ") + str(min),Qt.red)
191       elif len(self.listeValeursCourantes) > max : 
192          self.editor.affiche_infos(tr("Nombre maximal de valeurs : ") + str(max),Qt.red)
193       else :
194          self.editor.affiche_infos(tr(""))
195       if self.listeValeursCourantes== [] : self.listeValeursCourantes=None
196       self.node.item.set_valeur(self.listeValeursCourantes)
197       if self.listeValeursCourantes != None and (len(self.listeValeursCourantes) != len(self.monSimpDef.into)) : 
198          self.inhibe=True
199          self.CBCheck.setChecked(True)
200          self.inhibe=False
201       self.setValide()
202       self.reaffiche()
203
204