X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=InterfaceQT4%2Ffeuille.py;h=8eef0582d88dd587380924139c5193ae3c057b91;hb=68af27699b3d841d7d3b21223cbf4e27e4ddd45c;hp=126b2f9afd412b48a32cc25dd99e51e3332b3318;hpb=df0e1a1f57e70d3d99dd7fb381845500c3d3c6dd;p=tools%2Feficas.git diff --git a/InterfaceQT4/feuille.py b/InterfaceQT4/feuille.py index 126b2f9a..8eef0582 100644 --- a/InterfaceQT4/feuille.py +++ b/InterfaceQT4/feuille.py @@ -30,7 +30,7 @@ from gereIcones import ContientIcones from gereIcones import FacultatifOuOptionnel from qtSaisie import SaisieValeur -nomMax=26 +nomMax=250 # ---------------------------------------------------------------------- # class Feuille(QWidget,ContientIcones,SaisieValeur,FacultatifOuOptionnel): # --------------------------------------------------------------------- # @@ -38,6 +38,7 @@ class Feuille(QWidget,ContientIcones,SaisieValeur,FacultatifOuOptionnel): def __init__(self,node,monSimpDef,nom,objSimp,parentQt,commande): #print "Feuille", monSimpDef,nom,objSimp + #print self QWidget.__init__(self,None) self.node=node self.node.fenetre=self @@ -62,8 +63,9 @@ class Feuille(QWidget,ContientIcones,SaisieValeur,FacultatifOuOptionnel): self.setValeurs() self.setNom() self.setValide() - self.setPoubelle() - self.setIcones() + self.setIconePoubelle() + self.setIconesFichier() + self.setIconesSalome() self.setCommentaire() self.setZoneInfo() @@ -71,13 +73,23 @@ class Feuille(QWidget,ContientIcones,SaisieValeur,FacultatifOuOptionnel): def setNom(self): self.debutToolTip="" nomTraduit=tr(self.objSimp.nom) - if len(nomTraduit) >= nomMax : - nom=nomTraduit[0:nomMax]+'...' - self.label.setText(nomTraduit) - self.debutToolTip=nomTraduit+"\n" + #if len(nomTraduit) >= nomMax : + # nom=nomTraduit[0:nomMax]+'...' + # self.label.setText(nomTraduit) + # self.debutToolTip=nomTraduit+"\n" + longueur=QFontMetrics(self.label.font()).width(nomTraduit) + if longueur >= nomMax : + nouveauNom=self.formate(nomTraduit) + self.label.setText(nouveauNom) else : self.label.setText(nomTraduit) + def agrandit(self): + # inutile pour certains widgets + if self.height() < 40 : + self.setMinimumHeight(50) + self.resize(self.width(),200) + def setValeurs(self): # print "passe dans setValeurs pour ", self.objSimp.nom @@ -94,45 +106,20 @@ class Feuille(QWidget,ContientIcones,SaisieValeur,FacultatifOuOptionnel): def setCommentaire(self): c = self.debutToolTip - if self.node.item.definition.validators : c+=self.node.item.definition.validators.aide() + #if self.node.item.definition.validators : c+=self.node.item.definition.validators.aide() + self.aide=c if self.objSimp.get_fr() != None and self.objSimp.get_fr() != "": c2 = '

'+c+str(self.objSimp.get_fr())+"

" self.label.setToolTip(c2) + self.aide=str(self.objSimp.get_fr())+" "+c else : c+=self.finCommentaire() if c != "" and c != None : + self.aide=c #c=str('

')+c+"

" c=str('

')+c+"

" self.label.setToolTip(c) - def setIcones(self): - - mctype = self.monSimpDef.type[0] - # selon - if ( hasattr(self,"BFichier")): - if mctype == "Repertoire": - self.BRepertoire=self.BFichier - self.connect(self.BRepertoire,SIGNAL("clicked()"),self.BRepertoirePressed) - else : - #icon = QIcon(self.repIcon+"/visuFichier.png") - self.connect(self.BFichier,SIGNAL("clicked()"),self.BFichierPressed) - self.connect(self.BVisuFichier,SIGNAL("clicked()"),self.BFichierVisu) - return - - if ( hasattr(self,"BSalome")): - enable_salome_selection = self.editor.salome and \ - (('grma' in repr(mctype)) or ('grno' in repr(mctype)) or ('SalomeEntry' in repr(mctype)) or - (hasattr(mctype, "enable_salome_selection") and mctype.enable_salome_selection)) - if enable_salome_selection: - self.connect(self.BSalome,SIGNAL("pressed()"),self.BSalomePressed) - - if not(('grma' in repr(mctype)) or ('grno' in repr(mctype))) or not(self.editor.salome): - self.BView2D.close() - else : - self.connect(self.BView2D,SIGNAL("clicked()"),self.BView2DPressed) - else: - self.BSalome.close() - self.BView2D.close() def showEvent(self, event): @@ -143,10 +130,9 @@ class Feuille(QWidget,ContientIcones,SaisieValeur,FacultatifOuOptionnel): QWidget.showEvent(self,event) def aideALaSaisie(self): - return mc = self.node.item.get_definition() mctype = mc.type[0] - d_aide = { 'TXM' : tr(u"chaine de caracteres"), + d_aides = { 'TXM' : tr(u"chaine de caracteres"), 'R' : tr("reel"), 'I' : tr("entier"), 'C' : tr("complexe"), @@ -154,7 +140,8 @@ class Feuille(QWidget,ContientIcones,SaisieValeur,FacultatifOuOptionnel): 'Fichier' : tr(u'fichier'), 'FichierNoAbs' : tr(u'fichier existant'), 'Repertoire' : tr(u'repertoire')} - if mc.min == mc.max: commentaire=tr("Entrez ")+str(mc.min) + + if mc.min == mc.max: commentaire=tr("Entrez ")+" "+str(mc.min)+" " else : commentaire=tr("Entrez entre ")+str(mc.min)+tr(" et ")+str(mc.max) if type(mctype) == types.ClassType: ctype = getattr(mctype, 'help_message', tr("Type de base inconnu")) @@ -162,7 +149,7 @@ class Feuille(QWidget,ContientIcones,SaisieValeur,FacultatifOuOptionnel): if ctype == tr("Type de base inconnu") and "Tuple" in str(mctype): ctype=str(mctype) commentaire+=ctype - if self.max!=1 : commentaire+="s" + if mc.max!=1 : commentaire+="s" return commentaire def setZoneInfo(self): @@ -171,3 +158,49 @@ class Feuille(QWidget,ContientIcones,SaisieValeur,FacultatifOuOptionnel): # if self.monSimpDef.get_sug() != None and self.monSimpDef.get_sug() != "": info+="Valeur suggérée : "self.monSimpDef.get_sug() pass #self.editor.affiche_infos(info) + + def reaffiche(self): + #print "dans reaffiche de feuille", self.nom + if self.editor.jdc.aReafficher==True : + #print " j appelle le reaffiche de parentQt" + self.parentQt.reaffiche() + + #PN PN PN pas satisfaisant + #nodeAVoir=self.parentQt.node.chercheNoeudCorrespondant(self.objSimp) + #print nodeAVoir.fenetre + #print "nodeAVoir.fenetre.isVisible()", nodeAVoir.fenetre.isVisible() + #if nodeAVoir.fenetre.isVisible() : return + #self.editor.fenetreCentraleAffichee.rendVisibleNoeud(nodeAVoir) + #nodeAVoir.fenetre.setFocus() + # return # on est bien postionne + if self.objSimp.isvalid() and hasattr(self, 'AAfficher'): + self.editor.fenetreCentraleAffichee.afficheSuivant(self.AAfficher) + else : + if hasattr(self, 'AAfficher'): self.AAfficher.setFocus(7) + + + def traiteClicSurLabel(self,texte): + #print self.aide + aide=self.aide+"\n"+self.aideALaSaisie() + self.editor.affiche_infos(aide) + + def formate(self,t): + if t.find('_')==0 : + newText=t[0:19]+'\n'+t[19:] + else: + listeNom=t.split('_') + newTexte="" + ligne="" + for n in listeNom: + if len(ligne)+len(n) < 25 : + newTexte=newTexte+"_"+n + ligne+="_"+n + else : + newTexte=newTexte+"\n_"+n + ligne="" + #newTexte=t[0:t.rfind('_')]+'\n'+ t[t.rfind('_'):] + newText=newTexte[1:] + return newText + + +