# See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
#
# Modules Python
-import string,types,os
+from __future__ import absolute_import
+try :
+ from builtins import str
+ from builtins import range
+except : pass
+
+import types,os,sys
# Modules Eficas
-from PyQt4.QtGui import *
-from PyQt4.QtCore import *
+from .feuille import Feuille
+from desWidgetPlusieursIntoOrdonne import Ui_WidgetPlusieursIntoOrdonne
+from .politiquesValidation import PolitiquePlusieurs
+from .qtSaisie import SaisieValeur
+from .gereListe import GereListe
+from .gereListe import GerePlie
+from .gereListe import LECustom
+from .gereListe import MonLabelListeClic
from Extensions.i18n import tr
-from feuille import Feuille
-from desWidgetPlusieursInto import Ui_WidgetPlusieursInto
-from politiquesValidation import PolitiquePlusieurs
-from qtSaisie import SaisieValeur
-from gereListe import GereListe
+from six.moves import range
+from PyQt5.QtWidgets import QFrame, QApplication, QScrollBar
+from PyQt5.QtCore import QTimer, QSize, Qt
+from PyQt5.QtGui import QIcon
+
-class MonWidgetPlusieursIntoOrdonne (Ui_WidgetPlusieursInto,Feuille):
+class MonWidgetPlusieursIntoOrdonne (Ui_WidgetPlusieursIntoOrdonne, Feuille,GereListe,GerePlie):
- def __init__(self,node,monSimpDef,nom,objSimp,parentQt,commande):
- #print "MonWidgetPlusieursInto", nom, self
- self.index=1
- Feuille.__init__(self,node,monSimpDef,nom,objSimp,parentQt,commande)
+ def __init__(self,node,monSimpDef,nom,objSimp,parent,commande):
+ self.nomLine="LEResultat"
+ self.listeLE=[]
+ self.ouAjouter=0
+ self.NumLineEditEnCours=0
+ self.alpha=0
+ self.filtre=""
+ Feuille.__init__(self,node,monSimpDef,nom,objSimp,parent,commande)
+ GereListe.__init__(self)
+ #self.finCommentaireListe()
+ self.gereIconePlier()
self.listeValeursCourantes=self.node.item.GetListeValeurs()
- self.parentQt.commandesLayout.insertWidget(-1,self)
- self.maCommande.listeAffichageWidget.append(self.lineEditVal1)
+ try :
+ self.maCommande.listeAffichageWidget.append(self.lineEditVal1)
+ except :
+ # cas ou on ne peut rien ajouter
+ pass
+ self.prepareListeResultat()
+ if len(self.listeAAfficher) < 20 : self.frameRecherche2.close()
+ if len(self.listeAAfficher) < 8 : self.frameRecherche.close()
+ self.adjustSize()
+ if sys.platform[0:5]!="linux":
+ repIcon=self.node.editor.appliEficas.repIcon
+ fichier=os.path.join(repIcon, 'arrow_up.png')
+ icon = QIcon(fichier)
+ self.RBHaut.setIcon(icon)
+ self.RBHaut.setIconSize(QSize(32, 32))
+ fichier2=os.path.join(repIcon, 'arrow_down.png')
+ icon2 = QIcon(fichier2)
+ self.RBBas.setIcon(icon2)
+ if self.editor.salome :
+ icon=QIcon(self.repIcon+"/MoinsBleu.png")
+ self.RBMoins.setIcon(icon)
+ icon=QIcon(self.repIcon+"/PlusBleu.png")
+ self.RBPlus.setIcon(icon)
+ icon=QIcon(self.repIcon+"/verre-loupe-icone-6087-64.png")
+ self.RBVoisListe.setIcon(icon)
+ self.parentQt.commandesLayout.insertWidget(-1,self)
- def setValeurs(self):
+
+ def prepareListeResultat(self):
+ for i in self.listeLE: i.close()
+ self.listeLE=[]
+ self.vScrollBar = self.scrollArea.verticalScrollBar()
self.listeValeursCourantes=self.node.item.GetListeValeurs()
- #print "dans setValeurs"
- #print self.node.item.definition.validators
- #print self.monSimpDef.into
- #if len(self.monSimpDef.into)*20 > 400 : self.setMinimumHeight(400)
- #else : self.setMinimumHeight(len(self.monSimpDef.into)*30)
- #self.adjustSize()
if hasattr(self.node.item.definition.validators,'set_MCSimp'):
obj=self.node.item.getObject()
self.node.item.definition.validators.set_MCSimp(obj)
if self.node.item.isvalid() == 0 :
liste=[]
for item in self.listeValeursCourantes:
- if self.node.item.definition.validators.verif_item(item)==1:
- liste.append(item)
+ if self.node.item.definition.validators.verif_item(item)==1: liste.append(item)
self.listeAAfficher=self.node.item.get_liste_possible(liste)
- #print self.listeAAfficher
else:
self.listeAAfficher=self.node.item.get_liste_possible([])
else :
- self.listeAAfficher=self.monSimpDef.into
+ self.listeAAfficher=self.node.item.get_liste_possible(self.listeValeursCourantes)
+
+ if self.listeAAfficher==[] :
+ self.ajoutLE(0)
+ return
+ self.filtreListe()
if len(self.listeAAfficher)*20 > 400 : self.setMinimumHeight(400)
else : self.setMinimumHeight(len(self.listeAAfficher)*30)
- self.adjustSize()
- self.vScrollBar = self.scrollArea.verticalScrollBar()
+
self.politique=PolitiquePlusieurs(self.node,self.editor)
- self.indexListe=1
- for i in range(1,len(self.listeAAfficher)+1):
- self.ajoutCB(i)
+ for i in range(1,len(self.listeAAfficher)+1): self.ajoutLE(i)
for i in range(len(self.listeAAfficher)):
- nomCB="lineEditVal"+str(i+1)
- courant=getattr(self,nomCB)
+ nomLE="lineEditVal"+str(i+1)
+ courant=getattr(self,nomLE)
courant.setText(str(self.listeAAfficher[i]))
- if self.monSimpDef.into[i] in self.listeValeursCourantes :
- courant.setChecked(True)
- self.connect(courant,SIGNAL("toggled(bool)"),self.changeValeur)
self.vScrollBar.triggerAction(QScrollBar.SliderToMinimum)
+ if len(self.listeAAfficher) < 30 and hasattr(self,'frameRecherche') : self.frameRecherche.close()
+
+ def setValeurs(self):
+ self.listeValeursCourantes=self.node.item.GetListeValeurs()
+ if self.monSimpDef.max == "**" or self.monSimpDef.max == float('inf') : aConstruire=7
+ else : aConstruire=self.monSimpDef.max
+ if len(self.listeValeursCourantes) > aConstruire : aConstruire=len(self.listeValeursCourantes)
+ for i in range(1,aConstruire+1): self.ajoutLEResultat(i)
+ self.indexDernierLabel=aConstruire
+ index=1
+ for val in self.listeValeursCourantes :
+ nomLE="LEResultat"+str(index)
+ courant=getattr(self,nomLE)
+ courant.setText(str(val))
+ courant.setReadOnly(True)
+ index=index+1
+ self.prepareListeResultat()
+
+ def moinsPushed(self):
+ self.ouAjouter=self.ouAjouter-1
+ GereListe.moinsPushed(self)
+ self.setValeurs()
+
- def ajoutCB(self,index,valeur=None):
- #print "ajoutCB ", index
- nomCB="lineEditVal"+str(index)
- if hasattr(self,nomCB) :
- return
- nouveauCB = QCheckBox(self.scrollArea)
- self.CBLayout.addWidget(nouveauCB)
- qApp.processEvents()
- nouveauCB.setText("")
- if index % 2 == 1 : nouveauCB.setStyleSheet("background:rgb(210,210,210)")
- else : nouveauCB.setStyleSheet("background:rgb(240,240,240)")
+ def ajoutLEResultat (self,index,valeur=None):
+ nomLE="LEResultat"+str(index)
+ if hasattr(self,nomLE) : return
+ nouveauLE = LECustom(self.scrollAreaRE,self,index)
+ nouveauLE.setFrame(False)
+ self.CBChoisis.insertWidget(self.ouAjouter,nouveauLE)
+ self.ouAjouter=self.ouAjouter+1
+ nouveauLE.setText("")
+ nouveauLE.setReadOnly(True)
+ if index % 2 == 1 : nouveauLE.setStyleSheet("background:rgb(210,210,210)")
+ else : nouveauLE.setStyleSheet("background:rgb(240,240,240)")
+ self.vScrollBarRE = self.scrollAreaRE.verticalScrollBar()
+ self.vScrollBarRE.triggerAction(QScrollBar.SliderToMaximum)
+ setattr(self,nomLE,nouveauLE)
+ self.estVisibleRE=nouveauLE
+ if valeur != None :
+ nouveauLE.setText(valeur)
+
+ def ajoutLE(self,index,valeur=None):
+ nomLE="lineEditVal"+str(index)
+ nouveauLE = MonLabelListeClic(self)
+ #self.CBLayout.addWidget(nouveauLE)
+ self.CBLayout.insertWidget(index -1,nouveauLE)
+ self.listeLE.append(nouveauLE)
+ nouveauLE.setFrameShape(QFrame.NoFrame)
+ QApplication.processEvents()
+ nouveauLE.setText("")
+ if index % 2 == 1 : nouveauLE.setStyleSheet("background:rgb(210,210,210)")
+ else : nouveauLE.setStyleSheet("background:rgb(240,240,240)")
self.vScrollBar.triggerAction(QScrollBar.SliderToMaximum)
- nouveauCB.setFocus()
- setattr(self,nomCB,nouveauCB)
+ nouveauLE.setFocus()
+ setattr(self,nomLE,nouveauLE)
+ def ajoutLineEdit(self):
+ self.ajoutLEResultat (self.indexDernierLabel)
- def finCommentaire(self):
- commentaire=""
- mc = self.node.item.get_definition()
- d_aides = { 'TXM' : 'chaines de caracteres',
- 'R' : 'reels',
- 'I' : 'entiers',
- 'C' : 'complexes'}
- type = mc.type[0]
- if not d_aides.has_key(type) :
- if mc.min == mc.max:
- commentaire=tr("Entrez ")+str(mc.min)+tr(" valeurs ")
- else :
- commentaire=tr("Entrez entre ")+str(mc.min)+tr(" et ")+str(mc.max)+tr(" valeurs ")
- else :
- if mc.min == mc.max:
- commentaire=tr("Entrez ")+str(mc.min)+" "+tr(d_aides[type])
- else :
- commentaire=tr("Entrez entre ")+str(mc.min)+(" et ")+str(mc.max) +" " +tr(d_aides[type])
- aideval=self.node.item.aide()
- commentaire=commentaire + " " + QString.toUtf8(QString(aideval))
- return str(commentaire)
-
- def ajout1Valeur(self,valeur=None):
- #print "________________"
- #print self
- #print self.node
- #print self.node.item
+
+ def traiteClicSurLabelListe(self,valeur):
if valeur == None : return
liste,validite=SaisieValeur.TraiteLEValeur(self,str(valeur))
if validite == 0 : return
if liste ==[] : return
listeVal=[]
- for valeur in self.listeValeursCourantes : listeVal.append(valeur)
- validite,comm,comm2,listeRetour=self.politique.AjoutValeurs(liste,-1,listeVal)
- if (comm2 != "" and comm != None) : return comm2
- if validite :
- self.listeValeursCourantes=self.listeValeursCourantes+listeRetour
- if len(self.listeValeursCourantes) > self.monSimpDef.min :
- self.node.item.set_valeur(self.listeValeursCourantes)
- return None
+
+ self.listeValeursCourantes=self.node.item.GetListeValeurs()
+ min,max = self.node.item.GetMinMax()
+ if len(self.listeValeursCourantes) +1 > max :
+ self.editor.affiche_infos(tr("Nombre maximal de valeurs : ") + str(max),Qt.red)
+ return
else :
- return(comm2+" "+comm)
-
+ self.editor.affiche_infos("")
+ affiche=False
+ for i in range(1,self.indexDernierLabel+1):
+ nomLE="LEResultat"+str(i)
+ courant=getattr(self,nomLE)
+ if str(courant.text())==str("") :
+ courant.setText(valeur)
+ courant.setReadOnly(True)
+ affiche=True
+ self.estVisibleRE=courant
+ QTimer.singleShot(1, self.rendVisibleLigneRE)
+ break
+
+ if affiche == False:
+ self.indexDernierLabel = self.indexDernierLabel+1
+ self.ajoutLEResultat (self.indexDernierLabel,str(valeur))
+ self.vScrollBarRE.triggerAction(QScrollBar.SliderToMaximum)
+ QTimer.singleShot(1, self.rendVisibleLigneRE)
+ self.changeValeur()
+ self.setValeurs()
+
+ def changeValeur(self,changeDePlace=False,oblige=False):
+#PN les 2 arg sont pour que la signature de ma fonction soit identique a monWidgetPlusieursBase
+ listeVal=[]
+ for i in range(1,self.indexDernierLabel+1):
+ nomLE="LEResultat"+str(i)
+ courant=getattr(self,nomLE)
+ valeur=courant.text()
+ if str(valeur)=="" : continue
+ liste,validite=SaisieValeur.TraiteLEValeur(self,str(valeur))
+ listeVal.append(str(valeur))
- def changeValeur(self):
- self.listeValeursCourantesAvant=self.listeValeursCourantes
- self.listeValeursCourantes = []
- print "changeValeur ____________" , self.monSimpDef.into, len(self.monSimpDef.into)
- for i in range (1,len(self.listeAAfficher)+1):
- nomLineEdit="lineEditVal"+str(i)
- courant=getattr(self,nomLineEdit)
- if not (courant.isChecked()):continue
- valeur=courant.text()
- if valeur != None and valeur != "" :
- commentaire=self.ajout1Valeur(valeur)
- if (commentaire != None ):
- self.editor.affiche_infos(commentaire,Qt.red)
- courant.setText("")
- min,max = self.node.item.GetMinMax()
- if len(self.listeValeursCourantes) < min :
- self.editor.affiche_infos(tr("Nombre minimal de valeurs : ") + str(min),Qt.red)
- elif len(self.listeValeursCourantes) > max :
- self.editor.affiche_infos(tr("Nombre maximal de valeurs : ") + str(max),Qt.red)
- else :
- self.editor.affiche_infos(tr(""))
- self.node.item.set_valeur(self.listeValeursCourantes)
- self.setValide()
- self.reaffiche()
+ validite,comm,comm2,listeRetour=self.politique.AjoutValeurs(listeVal,-1,[])
+
+
+ self.listeValeursCourantes=self.node.item.GetListeValeurs()
+ min,max = self.node.item.GetMinMax()
+ if len(self.listeValeursCourantes) < min :
+ self.editor.affiche_infos(tr("Nombre minimal de valeurs : ") + str(min),Qt.red)
+ else :
+ self.editor.affiche_infos("")
+
+ if len(listeRetour) == 0 :
+ self.node.item.set_valeur(None)
+ elif validite :
+ self.node.item.set_valeur(listeRetour)
+ else :
+ commentaire=comm+" "+comm2
+ self.editor.affiche_infos(commentaire,Qt.red)
+ self.setValide()
+#
+ def rendVisibleLigneRE(self):
+ QApplication.processEvents()
+ self.estVisibleRE.setFocus()
+ self.scrollArea.ensureWidgetVisible(self.estVisibleRE,0,0)
+#