# -*- coding: utf-8 -*-
-# Copyright (C) 2007-2013 EDF R&D
+# Copyright (C) 2007-2017 EDF R&D
#
# This library is free software; you can redistribute it and/or
# modify it under the terms of the GNU Lesser General Public
# See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
#
# Modules Python
-import string,types,os,sys
+from __future__ import absolute_import
+try :
+ from builtins import str
+ from builtins import range
+ from builtins import object
+except : pass
+
+import types,os,sys
+
+from six.moves import range
+from PyQt5.QtGui import QIcon
+from PyQt5.QtWidgets import QApplication, QMessageBox
+from PyQt5.QtCore import QTimer, QSize, Qt
# Modules Eficas
-from PyQt4.QtGui import *
-from PyQt4.QtCore import *
from Extensions.i18n import tr
-from feuille import Feuille
+from .feuille import Feuille
from desWidgetPlusieursBase import Ui_WidgetPlusieursBase
-from politiquesValidation import PolitiquePlusieurs
-from qtSaisie import SaisieValeur
-from gereListe import GereListe
-from gereListe import GerePlie
-from gereListe import LECustom
+from .politiquesValidation import PolitiquePlusieurs
+from .qtSaisie import SaisieValeur
+from .gereListe import GereListe
+from .gereListe import GerePlie
+from .gereListe import LECustom
-dicoLongueur={2:95,3:125,4:154,5:183,6:210}
+dicoLongueur={2:95,3:125,4:154,5:183,6:210,float('inf'):210}
hauteurMax=253
class MonWidgetPlusieursBase (Ui_WidgetPlusieursBase,Feuille,GereListe,GerePlie):
def __init__(self,node,monSimpDef,nom,objSimp,parentQt,commande):
#print "MonWidgetPlusieursBase", nom
+ self.inFocusOutEvent=False
self.nomLine="lineEditVal"
self.inInit=True
self.indexDernierLabel=0
Feuille.__init__(self,node,monSimpDef,nom,objSimp,parentQt,commande)
GereListe.__init__(self)
self.gereIconePlier()
- self.connect(self.BSelectFichier,SIGNAL("clicked()"), self.selectInFile)
+ self.BSelectFichier.clicked.connect(self.selectInFile)
if sys.platform[0:5]!="linux":
repIcon=self.node.editor.appliEficas.repIcon
icon3 = QIcon(fichier2)
self.BSelectFichier.setIcon(icon3)
self.BSelectFichier.setIconSize(QSize(32, 32))
+ 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.listeValeursCourantes=self.node.item.GetListeValeurs()
if self.monSimpDef.max != "**" and self.monSimpDef.max < 7:
- hauteur=dicoLongueur[self.monSimpDef.max]
- self.resize(self.width(),hauteur)
- self.setMinimumHeight(hauteur)
- if self.monSimpDef.max == self.monSimpDef.min : self.setMaximumHeight(hauteur)
+ hauteurMax=dicoLongueur[self.monSimpDef.max]
else :
- self.resize(self.width(),hauteurMax)
- self.setMinimumHeight(hauteurMax)
+ hauteurMax=220
+ # if self.monSimpDef.max == self.monSimpDef.min : self.setMaximumHeight(hauteur)
+ self.resize(self.width(),hauteurMax)
+ self.setMinimumHeight(hauteurMax)
+ self.finCommentaireListe()
self.parentQt.commandesLayout.insertWidget(-1,self)
self.maCommande.listeAffichageWidget.append(self.lineEditVal1)
self.AAfficher=self.lineEditVal1
self.vScrollBar = self.scrollArea.verticalScrollBar()
self.politique=PolitiquePlusieurs(self.node,self.editor)
# construction du min de valeur a entrer
- if self.monSimpDef.max == "**" : aConstruire=7
- else : aConstruire=self.monSimpDef.max
+ if self.monSimpDef.max == "**" : aConstruire=7
+ elif self.monSimpDef.max == float('inf'): aConstruire=7
+ else : aConstruire=self.monSimpDef.max
+
for i in range(1,aConstruire):
self.ajoutLineEdit()
- qApp.processEvents()
+ QApplication.processEvents()
self.scrollArea.ensureWidgetVisible(self.lineEditVal1)
self.listeValeursCourantes=self.node.item.GetListeValeurs()
index=1
nomLineEdit="lineEditVal"+str(index)
if hasattr(self,nomLineEdit) :
courant=getattr(self,nomLineEdit)
- courant.setText(str(val))
+ if 'R' in self.objSimp.definition.type and str(val) != repr(val) : courant.setText(repr(val))
+ else : courant.setText(str(val))
else :
self.ajoutLineEdit(val)
index=index+1
# ajout d'une ligne vide ou affichage commentaire
if self.indexDernierLabel < self.monSimpDef.max : self.ajoutLineEdit()
else : self.scrollArea.setToolTip('nb max de valeurs atteint')
+ #self.adjustSize()
#self.vScrollBar.triggerAction(QScrollBar.SliderToMinimum)
if self.indexDernierLabel % 2 == 1 : nouveauLE.setStyleSheet("background:rgb(210,210,210)")
else : nouveauLE.setStyleSheet("background:rgb(235,235,235)")
nouveauLE.setFrame(False)
- self.connect(nouveauLE,SIGNAL("returnPressed()"),self.changeValeur)
+ nouveauLE.returnPressed.connect(self.changeValeur)
+
setattr(self,nomLineEdit,nouveauLE)
self.listeAffichageWidget.append(nouveauLE)
self.etablitOrdre()
def rendVisibleLigne(self):
- qApp.processEvents()
+ QApplication.processEvents()
self.estVisible.setFocus()
self.scrollArea.ensureWidgetVisible(self.estVisible,0,0)
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)
+ return self.finCommentaireListe()
def ajout1Valeur(self,valeur=None):
if valeur == None : return
# A priori, on ne fait rien
pass
- def AjoutNValeur(self,liste) :
+ def ajoutNValeur(self,liste) :
for val in liste :
i=1
ajoute=False
nomLineEdit="lineEditVal"+str(i)
courant=getattr(self,nomLineEdit)
valeur=courant.text()
- if valeur == None or valeur == QString("") :
+ if valeur == None or valeur == "" :
ajoute=True
courant.setText(str(val))
commentaire=self.ajout1Valeur(val)
donneFocus=None
derniereValeur=None
self.listeValeursCourantes = []
+ fin=self.indexDernierLabel
+ for i in range (1, fin):
+ nomLineEdit="lineEditVal"+str(i)
+ courant=getattr(self,nomLineEdit)
+ valeur=courant.text()
+ lval=valeur.split(',')
+ if len (lval) > 1 :
+ msgBox=QMessageBox()
+ msgBox.setText("separator ',' ")
+ msgBox.setInformativeText("Do you want to enter " + str (lval) + "?")
+ msgBox.setStandardButtons( QMessageBox.Ok | QMessageBox.Cancel)
+ msgBox.setDefaultButton(QMessageBox.Ok)
+ ret = msgBox.exec_()
+ if ret != 1024 :
+ courant.setText("")
+ return
+ courant.setText(lval[0])
+ self.ajoutNValeur(lval[1:])
+ self.listeValeursCourantes = []
+
for i in range (1, self.indexDernierLabel+1):
nomLineEdit="lineEditVal"+str(i)
courant=getattr(self,nomLineEdit)
else :
self.editor.affiche_infos("")
elif donneFocus==None : donneFocus=courant
+
nomDernierLineEdit="lineEditVal"+str(self.indexDernierLabel)
dernier=getattr(self,nomDernierLineEdit)
derniereValeur=dernier.text()