]> SALOME platform Git repositories - tools/eficas.git/blobdiff - InterfaceQT4/monWidgetPlusieursIntoOrdonne.py
Salome HOME
onItem=Deplie
[tools/eficas.git] / InterfaceQT4 / monWidgetPlusieursIntoOrdonne.py
index 588710a34a52312c0fc85ca967b1eea5893af019..c08781ecb2efe2317be6a65469c2a60e73783433 100644 (file)
@@ -18,7 +18,7 @@
 # See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
 #
 # Modules Python
-import string,types,os
+import string,types,os,sys
 
 # Modules Eficas
 from PyQt4.QtGui import *
@@ -31,7 +31,8 @@ from politiquesValidation   import PolitiquePlusieurs
 from qtSaisie               import SaisieValeur
 from gereListe              import GereListe
 from gereListe              import LECustom
-from monLabelClic           import MonLabelClic
+from gereListe              import MonLabelListeClic
+
 
 
 class MonWidgetPlusieursIntoOrdonne (Ui_WidgetPlusieursIntoOrdonne, Feuille,GereListe):
@@ -39,15 +40,34 @@ class MonWidgetPlusieursIntoOrdonne (Ui_WidgetPlusieursIntoOrdonne, Feuille,Gere
   def __init__(self,node,monSimpDef,nom,objSimp,parentQt,commande):
         #print "MonWidgetPlusieursInto", nom, self
         self.nomLine="LEResultat"
+        self.listeLE=[]
         Feuille.__init__(self,node,monSimpDef,nom,objSimp,parentQt,commande)
         GereListe.__init__(self)
         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.ouAjouter=0
         self.prepareListeResultat()
+        self.adjustSize()
         self.vScrollBarRE = self.scrollAreaRE.verticalScrollBar()
-       
+        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)
 
+       
   def setValeurs(self):
+       for i in self.listeLE:
+           i.close()
+       self.listeLE=[]
        listeValeursCourantes=self.node.item.GetListeValeurs()
        if hasattr(self.node.item.definition.validators,'set_MCSimp'):
             obj=self.node.item.getObject()
@@ -55,20 +75,19 @@ class MonWidgetPlusieursIntoOrdonne (Ui_WidgetPlusieursIntoOrdonne, Feuille,Gere
             if self.node.item.isvalid() == 0 :
                liste=[]
                for item in 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)
             else: 
                self.listeAAfficher=self.node.item.get_liste_possible([])
        else :
-               self.listeAAfficher=self.monSimpDef.into
+               self.listeAAfficher=self.node.item.get_liste_possible(listeValeursCourantes)
+
        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)
-       for i in range(1,len(self.listeAAfficher)+1):
-           self.ajoutLE(i)
+       for i in range(1,len(self.listeAAfficher)+1): self.ajoutLE(i)
        for i in range(len(self.listeAAfficher)):
            nomLE="lineEditVal"+str(i+1)
            courant=getattr(self,nomLE)
@@ -80,8 +99,7 @@ class MonWidgetPlusieursIntoOrdonne (Ui_WidgetPlusieursIntoOrdonne, Feuille,Gere
        if self.monSimpDef.max == "**" : aConstruire=7
        else                           : aConstruire=self.monSimpDef.max
        if len(listeValeursCourantes) > aConstruire : aConstruire=len(listeValeursCourantes)
-       for i in range(1,aConstruire+1):
-           self.ajoutLEResultat(i)
+       for i in range(1,aConstruire+1): self.ajoutLEResultat(i)
        self.indexDernierLabel=aConstruire
        index=1
        for val in listeValeursCourantes :
@@ -91,16 +109,19 @@ class MonWidgetPlusieursIntoOrdonne (Ui_WidgetPlusieursIntoOrdonne, Feuille,Gere
           courant.setReadOnly(True)
           index=index+1
 
+  def moinsPushed(self):
+      self.ouAjouter=self.ouAjouter-1
+      GereListe.moinsPushed(self)
+      self.setValeurs()
 
-  def ajoutLineEdit(self):
-      print "kljlkj"
 
   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.addWidget(nouveauLE)
+      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)")
@@ -112,11 +133,11 @@ class MonWidgetPlusieursIntoOrdonne (Ui_WidgetPlusieursIntoOrdonne, Feuille,Gere
          nouveauLE.setText(valeur)
       
   def ajoutLE(self,index,valeur=None):
-      #print "ajoutLE ", index
       nomLE="lineEditVal"+str(index)
-      if hasattr(self,nomLE) : return
-      nouveauLE = MonLabelClic(self)
-      self.CBLayout.addWidget(nouveauLE)
+      nouveauLE = MonLabelListeClic(self)
+      #self.CBLayout.addWidget(nouveauLE)
+      self.CBLayout.insertWidget(index -1,nouveauLE)
+      self.listeLE.append(nouveauLE)
       nouveauLE.setFrameShape(QFrame.NoFrame)
       qApp.processEvents()
       nouveauLE.setText("")
@@ -150,7 +171,7 @@ class MonWidgetPlusieursIntoOrdonne (Ui_WidgetPlusieursIntoOrdonne, Feuille,Gere
         return str(com)
 
 
-  def traiteClicSurLabel(self,valeur):
+  def traiteClicSurLabelListe(self,valeur):
         if valeur == None : return
         liste,validite=SaisieValeur.TraiteLEValeur(self,str(valeur))
         if validite == 0 : return
@@ -183,6 +204,7 @@ class MonWidgetPlusieursIntoOrdonne (Ui_WidgetPlusieursIntoOrdonne, Feuille,Gere
            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
@@ -196,6 +218,7 @@ class MonWidgetPlusieursIntoOrdonne (Ui_WidgetPlusieursIntoOrdonne, Feuille,Gere
            listeVal.append(str(valeur))
 
         validite,comm,comm2,listeRetour=self.politique.AjoutValeurs(listeVal,-1,[])
+        
 
         listeValeursCourantes=self.node.item.GetListeValeurs()
         min,max = self.node.item.GetMinMax()
@@ -204,7 +227,9 @@ class MonWidgetPlusieursIntoOrdonne (Ui_WidgetPlusieursIntoOrdonne, Feuille,Gere
         else :
            self.editor.affiche_infos("")
     
-        if validite :
+        if len(listeRetour) == 0 :
+           self.node.item.set_valeur(None)
+        elif validite :
            self.node.item.set_valeur(listeRetour)
         else :
            commentaire=comm+" "+comm2