Salome HOME
gestion des liste et bugs
[tools/eficas.git] / InterfaceQT4 / monWidgetPlusieursIntoOrdonne.py
index 588710a34a52312c0fc85ca967b1eea5893af019..c51ff7b8f7ba5de72a1509e6e3cb028fce5d7c92 100644 (file)
 # 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 desWidgetPlusieursIntoOrdonne import Ui_WidgetPlusieursIntoOrdonne 
-from politiquesValidation   import PolitiquePlusieurs
-from qtSaisie               import SaisieValeur
-from gereListe              import GereListe
-from gereListe              import LECustom
-from monLabelClic           import MonLabelClic
+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_WidgetPlusieursIntoOrdonne, Feuille,GereListe):
+class MonWidgetPlusieursIntoOrdonne (Ui_WidgetPlusieursIntoOrdonne, Feuille,GereListe,GerePlie):
 
-  def __init__(self,node,monSimpDef,nom,objSimp,parentQt,commande):
-        #print "MonWidgetPlusieursInto", nom, self
+  def __init__(self,node,monSimpDef,nom,objSimp,parent,commande):
         self.nomLine="LEResultat"
-        Feuille.__init__(self,node,monSimpDef,nom,objSimp,parentQt,commande)
+        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.parentQt.commandesLayout.insertWidget(-1,self)
-        self.maCommande.listeAffichageWidget.append(self.lineEditVal1)
+        #self.finCommentaireListe()
+        self.gereIconePlier()
+        self.listeValeursCourantes=self.node.item.GetListeValeurs()
+        try :
+          self.maCommande.listeAffichageWidget.append(self.lineEditVal1)
+        except :
+          # cas ou on ne peut rien ajouter
+          pass 
         self.prepareListeResultat()
-        self.vScrollBarRE = self.scrollAreaRE.verticalScrollBar()
-       
+        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)
 
-  def setValeurs(self):
-       listeValeursCourantes=self.node.item.GetListeValeurs()
+        self.parentQt.commandesLayout.insertWidget(-1,self)
+
+       
+  def prepareListeResultat(self):
+       for i in self.listeLE: i.close()
+       self.listeLE=[]
+       self.vScrollBar = self.scrollArea.verticalScrollBar()
+       self.listeValeursCourantes=self.node.item.GetListeValeurs()
        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 listeValeursCourantes:
-                   if self.node.item.definition.validators.verif_item(item)==1:
-                      liste.append(item)
+               for item in self.listeValeursCourantes:
+                   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(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)
-       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)
            courant.setText(str(self.listeAAfficher[i]))
        self.vScrollBar.triggerAction(QScrollBar.SliderToMinimum)
+       if len(self.listeAAfficher) < 30 and hasattr(self,'frameRecherche') : self.frameRecherche.close() 
        
-  def prepareListeResultat(self):
-       listeValeursCourantes=self.node.item.GetListeValeurs()
-       if self.monSimpDef.max == "**" : aConstruire=7
+      
+  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(listeValeursCourantes) > aConstruire : aConstruire=len(listeValeursCourantes)
-       for i in range(1,aConstruire+1):
-           self.ajoutLEResultat(i)
+       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 listeValeursCourantes :
+       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 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)")
       else :             nouveauLE.setStyleSheet("background:rgb(240,240,240)")
-      self.vScrollBar.triggerAction(QScrollBar.SliderToMaximum)
+      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):
-      #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()
+      QApplication.processEvents()
       nouveauLE.setText("")
       if index % 2 == 1 : nouveauLE.setStyleSheet("background:rgb(210,210,210)")
       else :             nouveauLE.setStyleSheet("background:rgb(240,240,240)")
@@ -126,44 +176,24 @@ class MonWidgetPlusieursIntoOrdonne (Ui_WidgetPlusieursIntoOrdonne, Feuille,Gere
       nouveauLE.setFocus()
       setattr(self,nomLE,nouveauLE)
       
-
-  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()
-        com=commentaire + "   " + QString.toUtf8(QString(aideval))
-        return str(com)
+  def ajoutLineEdit(self):
+      self.ajoutLEResultat (self.indexDernierLabel)
 
 
-  def traiteClicSurLabel(self,valeur):
+  def traiteClicSurLabelListe(self,valeur):
         if valeur == None : return
         liste,validite=SaisieValeur.TraiteLEValeur(self,str(valeur))
         if validite == 0 : return
         if liste ==[]    : return
         listeVal=[]
 
-        listeValeursCourantes=self.node.item.GetListeValeurs()
+        self.listeValeursCourantes=self.node.item.GetListeValeurs()
         min,max = self.node.item.GetMinMax()
-        if len(listeValeursCourantes) +1 > max : 
+        if len(self.listeValeursCourantes) +1 > max : 
            self.editor.affiche_infos(tr("Nombre maximal de valeurs : ") + str(max),Qt.red)
            return
         else :
-           self.editor.affiche_infos(tr(""))
+           self.editor.affiche_infos("")
 
         affiche=False
         for i in range(1,self.indexDernierLabel+1):
@@ -183,6 +213,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,15 +227,18 @@ class MonWidgetPlusieursIntoOrdonne (Ui_WidgetPlusieursIntoOrdonne, Feuille,Gere
            listeVal.append(str(valeur))
 
         validite,comm,comm2,listeRetour=self.politique.AjoutValeurs(listeVal,-1,[])
+        
 
-        listeValeursCourantes=self.node.item.GetListeValeurs()
+        self.listeValeursCourantes=self.node.item.GetListeValeurs()
         min,max = self.node.item.GetMinMax()
-        if len(listeValeursCourantes) < min : 
+        if len(self.listeValeursCourantes) < min : 
            self.editor.affiche_infos(tr("Nombre minimal de valeurs : ") + str(min),Qt.red)
         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
@@ -212,7 +246,9 @@ class MonWidgetPlusieursIntoOrdonne (Ui_WidgetPlusieursIntoOrdonne, Feuille,Gere
         self.setValide()
 #
   def rendVisibleLigneRE(self):
-      qApp.processEvents()
+      QApplication.processEvents()
       self.estVisibleRE.setFocus()
       self.scrollArea.ensureWidgetVisible(self.estVisibleRE,0,0)
 #
+
+