Salome HOME
CCAR: coorection de la prise de focus pour les mots cles simples et la liste des
[tools/eficas.git] / Editeur / panels.py
index 413a34021aadd7c460ad833a33dac3ab665c8013..328015d944d379d3f1462a53f95d37640ba9fb50 100644 (file)
@@ -21,9 +21,12 @@ import string
 import os
 from Tkinter import *
 import Pmw
+import time
 
 from widgets import ListeChoix
+from widgets import ListeChoixParGroupes
 import prefs
+import options
 
 SEPARATEUR = '-'*30
 
@@ -254,6 +257,12 @@ class OngletPanel(Panel) :
               self._any.focus()
           except:
               pass
+      elif page == 'Commande':
+          try:
+              self.command_entry.component('entry').focus()
+          except:
+              pass
+
 
   def affiche(self):
       page=self.nb.getcurselection()
@@ -316,18 +325,30 @@ class OngletPanel(Panel) :
       but_apres.grid(column = 1,row =3)
       
   def makeCommandePage(self,page):
+      """
+         Cree l'onglet
+      """
       frame1 = Frame(page,height = 20)
       frame1.pack(side='top',fill='x')
       label = Label(frame1,text ="La commande choisie sera ajoutée\n APRES la commande courante")
       label.pack(side='top')
       frame2 = Frame(page)
       frame2.pack(side='top',fill='both',expand=1)
-      liste_cmd = self.get_liste_cmd()
       liste_commandes = (("<Enter>",self.selectCmd),
                          ("<Leave>",self.deselectCmd),
                          ("<Double-Button-1>",self.defCmd))
-      Liste = ListeChoix(self,frame2,liste_cmd,liste_commandes = liste_commandes,filtre='oui',titre = "Commandes")
+      if options.affichage_commandes == "alphabetic":
+         liste_cmd = self.get_liste_cmd()
+         Liste = ListeChoix(self,frame2,liste_cmd,liste_commandes = liste_commandes,
+                                   filtre='oui',titre = "Commandes")
+      else:
+         liste_groupes=self.node.item.object.niveau.definition.liste_groupes
+         dict_groupes=self.node.item.object.niveau.definition.dict_groupes
+         Liste = ListeChoixParGroupes(self,frame2,liste_groupes,dict_groupes,
+                                      liste_commandes = liste_commandes,
+                                      filtre='oui',titre = "Commandes")
       Liste.affiche_liste()
+      self.command_entry=Liste.entry
       # aide associée au panneau
       bulle_aide="""Double-cliquez sur la commande que vous voulez ajouter au jeu de commandes"""
       Liste.MCbox.bind("<Button-3>", lambda e,s=self,a=bulle_aide : s.parent.appli.affiche_aide(e,a))
@@ -337,11 +358,19 @@ class OngletPanel(Panel) :
       """
       Crée la page correspondant à un objet de type JDC
       """
-      liste_cmd = self.get_liste_cmd()
       liste_commandes = (("<Enter>",self.selectCmd),
                          ("<Leave>",self.deselectCmd),
                          ("<Double-Button-1>",self.defCmdFirst))
-      Liste = ListeChoix(self,page,liste_cmd,liste_commandes = liste_commandes,filtre='oui',titre = "Commandes")
+      if options.affichage_commandes == "alphabetic":
+         liste_cmd = self.get_liste_cmd()
+         Liste = ListeChoix(self,page,liste_cmd,liste_commandes = liste_commandes,
+                            filtre='oui',titre = "Commandes")
+      else:
+         liste_groupes=self.node.item.object.niveau.definition.liste_groupes
+         dict_groupes=self.node.item.object.niveau.definition.dict_groupes
+         Liste = ListeChoixParGroupes(self,page,liste_groupes,dict_groupes,
+                                      liste_commandes = liste_commandes,
+                                      filtre='oui',titre = "Commandes")
       Liste.affiche_liste()
        # aide associée au panneau
       bulle_aide="""Double-cliquez sur la commande que vous voulez ajouter au jeu de commandes"""
@@ -428,7 +457,6 @@ class OngletPanel(Panel) :
              command = self.comment_commande).place(relx=0.5,rely=0.5,anchor='center')
     
   def deselectMC(self,name):
-      #EFICAS.affiche_infos('')
       self.parent.appli.affiche_infos('')
     
   def get_liste_cmd_old(self):
@@ -440,7 +468,6 @@ class OngletPanel(Panel) :
       return listeCmd
 
   def deselectCmd(self,name):
-      #EFICAS.affiche_infos('')
       self.parent.appli.affiche_infos('')
     
   def execConcept(self):
@@ -457,7 +484,6 @@ class OngletPanel(Panel) :
       # Pourquoi node.etape ???
       #test,mess = self.node.etape.item.nomme_sd(nom)
       test,mess = self.node.item.nomme_sd(nom)
-      #EFICAS.affiche_infos(mess)
       self.parent.appli.affiche_infos(mess)
       self.node.racine.update()
   
@@ -469,9 +495,7 @@ class OngletPanel(Panel) :
     Cette méthode a pour but de commentariser la commande pointée par self.node
     """
     commande_comment = self.node.item.get_objet_commentarise()
-    #XXX il faudrait ici aussi eviter l'appel à EFICAS
     self.parent.appli.bureau.JDCDisplay_courant.ReplaceObjectNode(self.node,commande_comment,None)
-    #EFICAS.JDCDisplay_courant.ReplaceObjectNode(self.node,commande_comment,None)
       
 class Panel_Inactif(Panel):
   """