Salome HOME
sauve_intermediaire
[tools/eficas.git] / InterfaceQT4 / monWidgetPlusieursIntoOrdonne.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 GereListe
33
34 class MonWidgetPlusieursIntoOrdonne (Ui_WidgetPlusieursInto,Feuille):
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         self.maCommande.listeAffichageWidget.append(self.lineEditVal1)
43
44
45   def setValeurs(self):
46        self.listeValeursCourantes=self.node.item.GetListeValeurs()
47        #print "dans setValeurs"
48        #print self.node.item.definition.validators
49        #print self.monSimpDef.into
50        #if len(self.monSimpDef.into)*20 > 400 : self.setMinimumHeight(400)
51        #else : self.setMinimumHeight(len(self.monSimpDef.into)*30)
52        #self.adjustSize()
53        if hasattr(self.node.item.definition.validators,'set_MCSimp'):
54             obj=self.node.item.getObject()
55             self.node.item.definition.validators.set_MCSimp(obj)
56             if self.node.item.isvalid() == 0 :
57                liste=[]
58                for item in self.listeValeursCourantes:
59                    if self.node.item.definition.validators.verif_item(item)==1:
60                       liste.append(item)
61                self.listeAAfficher=self.node.item.get_liste_possible(liste)
62                #print self.listeAAfficher
63             else: 
64                self.listeAAfficher=self.node.item.get_liste_possible([])
65        else :
66                self.listeAAfficher=self.monSimpDef.into
67        if len(self.listeAAfficher)*20 > 400 : self.setMinimumHeight(400)
68        else : self.setMinimumHeight(len(self.listeAAfficher)*30)
69        self.adjustSize()
70        self.vScrollBar = self.scrollArea.verticalScrollBar()
71        self.politique=PolitiquePlusieurs(self.node,self.editor)
72        self.indexListe=1
73        for i in range(1,len(self.listeAAfficher)+1):
74            self.ajoutCB(i)
75        for i in range(len(self.listeAAfficher)):
76            nomCB="lineEditVal"+str(i+1)
77            courant=getattr(self,nomCB)
78            courant.setText(str(self.listeAAfficher[i]))
79            if self.monSimpDef.into[i] in self.listeValeursCourantes : 
80               courant.setChecked(True)
81            self.connect(courant,SIGNAL("toggled(bool)"),self.changeValeur)
82        self.vScrollBar.triggerAction(QScrollBar.SliderToMinimum)
83        
84
85   def ajoutCB(self,index,valeur=None):
86       #print "ajoutCB ", index
87       nomCB="lineEditVal"+str(index)
88       if hasattr(self,nomCB) : 
89          return
90       nouveauCB = QCheckBox(self.scrollArea)
91       self.CBLayout.addWidget(nouveauCB)
92       qApp.processEvents()
93       nouveauCB.setText("")
94       if index % 2 == 1 : nouveauCB.setStyleSheet("background:rgb(210,210,210)")
95       else :                        nouveauCB.setStyleSheet("background:rgb(240,240,240)")
96       self.vScrollBar.triggerAction(QScrollBar.SliderToMaximum)
97       nouveauCB.setFocus()
98       setattr(self,nomCB,nouveauCB)
99       
100
101   def finCommentaire(self):
102         commentaire=""
103         mc = self.node.item.get_definition()
104         d_aides = { 'TXM' : 'chaines de caracteres',
105                   'R'   : 'reels',
106                   'I'   : 'entiers',
107                   'C'   : 'complexes'}
108         type = mc.type[0]
109         if not d_aides.has_key(type) :
110            if mc.min == mc.max:
111                commentaire=tr("Entrez ")+str(mc.min)+tr(" valeurs ")
112            else :
113                commentaire=tr("Entrez entre ")+str(mc.min)+tr(" et ")+str(mc.max)+tr(" valeurs ")
114         else :
115            if mc.min == mc.max:
116                commentaire=tr("Entrez ")+str(mc.min)+" "+tr(d_aides[type])
117            else :
118                commentaire=tr("Entrez entre ")+str(mc.min)+(" et  ")+str(mc.max) +" " +tr(d_aides[type])
119         aideval=self.node.item.aide()
120         commentaire=commentaire + "   " + QString.toUtf8(QString(aideval))
121         return str(commentaire)
122
123   def ajout1Valeur(self,valeur=None):
124         #print "________________"
125         #print self
126         #print self.node
127         #print self.node.item
128         if valeur == None : return
129         liste,validite=SaisieValeur.TraiteLEValeur(self,str(valeur))
130         if validite == 0 : return
131         if liste ==[]    : return
132         listeVal=[]
133         for valeur in self.listeValeursCourantes : listeVal.append(valeur)
134         validite,comm,comm2,listeRetour=self.politique.AjoutValeurs(liste,-1,listeVal)
135         if (comm2 != "" and comm != None) : return comm2
136         if validite : 
137            self.listeValeursCourantes=self.listeValeursCourantes+listeRetour
138            if len(self.listeValeursCourantes) > self.monSimpDef.min :
139               self.node.item.set_valeur(self.listeValeursCourantes)
140            return None
141         else :
142            return(comm2+" "+comm)
143         
144
145
146   def changeValeur(self):
147       self.listeValeursCourantesAvant=self.listeValeursCourantes
148       self.listeValeursCourantes = []
149       print "changeValeur ____________" , self.monSimpDef.into, len(self.monSimpDef.into)
150       for i in range (1,len(self.listeAAfficher)+1):
151           nomLineEdit="lineEditVal"+str(i)
152           courant=getattr(self,nomLineEdit)
153           if not (courant.isChecked()):continue
154           valeur=courant.text()
155           if valeur != None and valeur != "" : 
156              commentaire=self.ajout1Valeur(valeur)
157              if (commentaire != None ):
158                  self.editor.affiche_infos(commentaire,Qt.red)
159                  courant.setText("")
160       min,max = self.node.item.GetMinMax()
161       if len(self.listeValeursCourantes) < min : 
162          self.editor.affiche_infos(tr("Nombre minimal de valeurs : ") + str(min),Qt.red)
163       elif len(self.listeValeursCourantes) > max : 
164          self.editor.affiche_infos(tr("Nombre maximal de valeurs : ") + str(max),Qt.red)
165       else :
166          self.editor.affiche_infos(tr(""))
167       self.node.item.set_valeur(self.listeValeursCourantes)
168       self.setValide()
169       self.reaffiche()
170
171