1 # -*- coding: utf-8 -*-
2 # Copyright (C) 2007-2013 EDF R&D
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.
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.
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
18 # See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
21 import string,types,os
24 from PyQt4.QtGui import *
25 from PyQt4.QtCore import *
26 from Extensions.i18n import tr
28 from feuille import Feuille
29 from desWidgetPlusieursBase import Ui_WidgetPlusieursBase
30 from politiquesValidation import PolitiquePlusieurs
31 from qtSaisie import SaisieValeur
32 from gereListe import GereListe
33 from gereListe import LECustom
35 dicoLongueur={2:95,3:125,4:154,5:183,6:210}
38 class MonWidgetPlusieursBase (Ui_WidgetPlusieursBase,Feuille,GereListe):
40 def __init__(self,node,monSimpDef,nom,objSimp,parentQt,commande):
41 #print "MonWidgetPlusieursBase", nom
42 self.nomLine="lineEditVal"
44 self.indexDernierLabel=0
45 self.NumLineEditEnCours=0
46 self.listeAffichageWidget=[]
47 Feuille.__init__(self,node,monSimpDef,nom,objSimp,parentQt,commande)
48 GereListe.__init__(self)
49 self.connect(self.BSelectFichier,SIGNAL("clicked()"), self.selectInFile)
51 if sys.platform[0:5]!="linux":
52 repIcon=self.node.editor.appliEficas.repIcon
53 fichier=os.path.join(repIcon, 'arrow_up.png')
55 self.RBHaut.setIcon(icon)
56 self.RBHaut.setIconSize(QSize(32, 32))
57 fichier2=os.path.join(repIcon, 'arrow_down.png')
58 icon2 = QIcon(fichier2)
59 self.RBBas.setIcon(icon2)
60 fichier3=os.path.join(repIcon, 'file-explorer.png')
61 icon3 = QIcon(fichier2)
62 self.BSelectFichier.setIcon(icon3)
63 self.BSelectFichier.setIconSize(QSize(32, 32))
65 self.listeValeursCourantes=self.node.item.GetListeValeurs()
66 if self.monSimpDef.max != "**" and self.monSimpDef.max < 7:
67 hauteur=dicoLongueur[self.monSimpDef.max]
68 self.resize(self.width(),hauteur)
69 self.setMinimumHeight(hauteur)
70 if self.monSimpDef.max == self.monSimpDef.min : self.setMaximumHeight(hauteur)
72 self.resize(self.width(),hauteurMax)
73 self.setMinimumHeight(hauteurMax)
74 self.parentQt.commandesLayout.insertWidget(-1,self)
75 self.maCommande.listeAffichageWidget.append(self.lineEditVal1)
76 self.AAfficher=self.lineEditVal1
81 self.vScrollBar = self.scrollArea.verticalScrollBar()
82 self.politique=PolitiquePlusieurs(self.node,self.editor)
83 # construction du min de valeur a entrer
84 if self.monSimpDef.max == "**" : aConstruire=7
85 else : aConstruire=self.monSimpDef.max
86 for i in range(1,aConstruire):
89 self.scrollArea.ensureWidgetVisible(self.lineEditVal1)
90 self.listeValeursCourantes=self.node.item.GetListeValeurs()
92 for valeur in self.listeValeursCourantes :
93 val=self.politique.GetValeurTexte(valeur)
94 nomLineEdit="lineEditVal"+str(index)
95 if hasattr(self,nomLineEdit) :
96 courant=getattr(self,nomLineEdit)
97 courant.setText(str(val))
99 self.ajoutLineEdit(val)
101 # ajout d'une ligne vide ou affichage commentaire
102 if self.indexDernierLabel < self.monSimpDef.max : self.ajoutLineEdit()
103 else : self.scrollArea.setToolTip('nb max de valeurs atteint')
104 #self.vScrollBar.triggerAction(QScrollBar.SliderToMinimum)
107 def ajoutLineEdit(self,valeur=None,):
108 self.indexDernierLabel=self.indexDernierLabel+1
109 nomLineEdit="lineEditVal"+str(self.indexDernierLabel)
110 if hasattr(self,nomLineEdit) :
111 self.indexDernierLabel=self.indexDernierLabel-1
113 nouveauLE = LECustom(self.scrollArea,self,self.indexDernierLabel)
114 self.verticalLayoutLE.insertWidget(self.indexDernierLabel-1,nouveauLE)
115 nouveauLE.setText("")
116 if self.indexDernierLabel % 2 == 1 : nouveauLE.setStyleSheet("background:rgb(210,210,210)")
117 else : nouveauLE.setStyleSheet("background:rgb(235,235,235)")
118 nouveauLE.setFrame(False)
119 self.connect(nouveauLE,SIGNAL("returnPressed()"),self.changeValeur)
120 setattr(self,nomLineEdit,nouveauLE)
121 self.listeAffichageWidget.append(nouveauLE)
123 if valeur != None : nouveauLE.setText(str(valeur))
124 # deux lignes pour que le ensureVisible fonctionne
125 self.estVisible=nouveauLE
126 if self.inInit==False :QTimer.singleShot(1, self.rendVisibleLigne)
127 #if donneLeFocus==True : nouveauLE.setFocus()
129 def etablitOrdre(self):
131 while(i +1 < len(self.listeAffichageWidget)):
132 self.listeAffichageWidget[i].setFocusPolicy(Qt.StrongFocus)
133 self.setTabOrder(self.listeAffichageWidget[i],self.listeAffichageWidget[i+1])
135 # si on boucle on perd l'ordre
138 def rendVisibleLigne(self):
140 self.estVisible.setFocus()
141 self.scrollArea.ensureWidgetVisible(self.estVisible,0,0)
144 def finCommentaire(self):
146 mc = self.node.item.get_definition()
147 d_aides = { 'TXM' : 'chaines de caracteres',
152 if not d_aides.has_key(type) :
154 commentaire=tr("Entrez ")+str(mc.min)+tr(" valeurs ")
156 commentaire=tr("Entrez entre ")+str(mc.min)+tr(" et ")+str(mc.max)+tr(" valeurs ")
159 commentaire=tr("Entrez ")+str(mc.min)+" "+tr(d_aides[type])
161 commentaire=tr("Entrez entre ")+str(mc.min)+(" et ")+str(mc.max) +" " +tr(d_aides[type])
162 aideval=self.node.item.aide()
163 commentaire=commentaire + " " + QString.toUtf8(QString(aideval))
164 return str(commentaire)
166 def ajout1Valeur(self,valeur=None):
167 if valeur == None : return
168 liste,validite=SaisieValeur.TraiteLEValeur(self,str(valeur))
169 if validite == 0 : return
170 if liste ==[] : return
172 for valeur in self.listeValeursCourantes : listeVal.append(valeur)
173 validite,comm,comm2,listeRetour=self.politique.AjoutValeurs(liste,-1,listeVal)
174 if (comm2 != "" and comm != None) : return comm2
176 self.listeValeursCourantes=self.listeValeursCourantes+listeRetour
177 if len(self.listeValeursCourantes) > self.monSimpDef.min :
178 self.node.item.set_valeur(self.listeValeursCourantes)
182 return(comm2+" "+comm)
185 # A priori, on ne fait rien
188 def AjoutNValeur(self,liste) :
192 while i < self.indexDernierLabel+1:
193 nomLineEdit="lineEditVal"+str(i)
194 courant=getattr(self,nomLineEdit)
195 valeur=courant.text()
196 if valeur == None or valeur == QString("") :
198 courant.setText(str(val))
199 commentaire=self.ajout1Valeur(val)
200 if (commentaire != None ):
201 self.editor.affiche_infos(commentaire,Qt.red)
207 self.ajoutLineEdit(valeur=str(val))
211 def changeValeur(self,changeDePlace=True,oblige=False):
214 self.listeValeursCourantes = []
215 for i in range (1, self.indexDernierLabel+1):
216 nomLineEdit="lineEditVal"+str(i)
217 courant=getattr(self,nomLineEdit)
218 valeur=courant.text()
219 if valeur != None and valeur != "" :
220 commentaire=self.ajout1Valeur(valeur)
221 if (commentaire != None ):
222 self.editor.affiche_infos(commentaire,Qt.red)
228 self.editor.affiche_infos("")
229 elif donneFocus==None : donneFocus=courant
230 nomDernierLineEdit="lineEditVal"+str(self.indexDernierLabel)
231 dernier=getattr(self,nomDernierLineEdit)
232 derniereValeur=dernier.text()
234 if donneFocus != None :
235 donneFocus.setFocus()
236 self.scrollArea.ensureWidgetVisible(donneFocus)
237 elif self.indexDernierLabel < self.monSimpDef.max :
239 if self.listeValeursCourantes == [] : return
240 min,max = self.node.item.GetMinMax()
241 if len(self.listeValeursCourantes) < self.monSimpDef.min :
242 self.editor.affiche_infos(tr('nb min de valeurs : ')+str( self.monSimpDef.min))
243 if len(self.listeValeursCourantes) < min and oblige==True: return
244 if len(self.listeValeursCourantes) > max : return
245 self.node.item.set_valeur(self.listeValeursCourantes)
246 if len(self.listeValeursCourantes) == self.monSimpDef.max :
247 self.editor.affiche_infos(tr('nb max de valeurs atteint'))
253 # Avertissement quand on quitte le widget