Salome HOME
CCAR: modifications pour :
[tools/eficas.git] / Editeur / panels.py
index 61b142c9fabd22604aa7aa94cc737c1a311c26c3..b6a97e9f81a8986672883fd3ea2f35dda49e5582 100644 (file)
@@ -1,3 +1,4 @@
+# -*- coding: utf-8 -*-
 #            CONFIGURATION MANAGEMENT OF EDF VERSION
 # ======================================================================
 # COPYRIGHT (C) 1991 - 2002  EDF R&D                  WWW.CODE-ASTER.ORG
@@ -21,9 +22,10 @@ import string
 import os
 from Tkinter import *
 import Pmw
-import tkMessageBox
 import time
+import traceback
 
+import widgets
 from widgets import ListeChoix
 from widgets import ListeChoixParGroupes
 import prefs
@@ -49,6 +51,10 @@ class Panel(Frame) :
       self.creer_boutons()
       self.init()
 
+  def __del__(self):
+      """ appele a la destruction du panel """
+      #print "PANEL DETRUIT"
+
   def destroy(self):
       Frame.destroy(self)
       self.panneau=None
@@ -62,7 +68,7 @@ class Panel(Frame) :
       self.bouton_doc=None
       self.bouton_com=None
       self.bouton_sup=None
-      self.frame_eval=None
+      #self.frame_eval=None
       self.label=None
       self.frame_boutons=None
       self.frame_comment=None
@@ -103,8 +109,8 @@ class Panel(Frame) :
           self.bouton_cata.place(relx=0.5,rely = 0.5,relheight = 0.8,anchor='center')
           self.bouton_doc.place(relx=0.75,rely = 0.5,relheight = 0.8,anchor='center')
       else:
-          self.bouton_sup.place(relx=0.3,rely = 0.5,relheight = 0.8,anchor='center')
-          self.bouton_doc.place(relx=0.7,rely = 0.5,relheight = 0.8,anchor='center')
+          self.bouton_sup.place(relx=0.25,rely = 0.5,relheight = 0.8,anchor='center')
+          self.bouton_doc.place(relx=0.5,rely = 0.5,relheight = 0.8,anchor='center')
 
   def show_catalogue(self):
       try:
@@ -155,21 +161,21 @@ class Panel(Frame) :
       if self.parent.modified == 'n' : self.parent.init_modif()
       return self.node.append_child("PARAMETRE",'first')
 
-  def ajout_parametre_eval(self,ind='after'):
-      """
-      Ajoute un paramètre EVAL à l'intérieur du JDC :
-      - si ind='after'  : l'ajoute après l'objet courant
-      - si ind='before' : l'ajoute avant.
-      """
-      if self.parent.modified == 'n' : self.parent.init_modif()
-      return self.node.append_brother("PARAMETRE_EVAL",ind)
+#  def ajout_parametre_eval(self,ind='after'):
+#      """
+#      Ajoute un paramètre EVAL à l'intérieur du JDC :
+#      - si ind='after'  : l'ajoute après l'objet courant
+#      - si ind='before' : l'ajoute avant.
+#      """
+#      if self.parent.modified == 'n' : self.parent.init_modif()
+#      return self.node.append_brother("PARAMETRE_EVAL",ind)
     
-  def ajout_parametre_eval_first(self):
-      """
-      Ajoute un paramètre EVAL en début de JDC
-      """
-      if self.parent.modified == 'n' : self.parent.init_modif()
-      return self.node.append_child("PARAMETRE_EVAL",'first')
+#  def ajout_parametre_eval_first(self):
+#      """
+#      Ajoute un paramètre EVAL en début de JDC
+#      """
+#      if self.parent.modified == 'n' : self.parent.init_modif()
+#      return self.node.append_child("PARAMETRE_EVAL",'first')
     
 # ------------------------------------------------------------------------
    
@@ -237,6 +243,9 @@ class Panel(Frame) :
       if name == SEPARATEUR:return
       if self.parent.modified == 'n' : self.parent.init_modif()
       if name != "COMMENTAIRE":
+          #parent=self.node.parent
+          #new_obj = parent.item.append_child(name,self.node.item.getObject())
+          #parent.children[parent.children.index(self.node)+1].select()
           new_node = self.node.append_brother(name,'after')
       else :
           new_node = self.ajout_commentaire()
@@ -246,6 +255,8 @@ class Panel(Frame) :
       if name == SEPARATEUR:return
       if self.parent.modified == 'n' : self.parent.init_modif()
       if name != "COMMENTAIRE":
+          #new_obj = self.node.item.append_child(name,'first')
+          #self.node.children[0].select()
           new_node = self.node.append_child(name,'first')
       else :
           new_node = self.ajout_commentaire_first()
@@ -351,13 +362,13 @@ class OngletPanel(Panel) :
       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")
+                                   filtre='oui',titre = "Commandes",optionReturn="oui")
       else:
-         liste_groupes=self.node.item.object.niveau.definition.liste_groupes
-         dict_groupes=self.node.item.object.niveau.definition.dict_groupes
+         liste_commandes=liste_commandes+(("<Return>",self.defCmd),)
+         liste_groupes,dict_groupes=self.get_groups()
          Liste = ListeChoixParGroupes(self,frame2,liste_groupes,dict_groupes,
                                       liste_commandes = liste_commandes,
-                                      filtre='oui',titre = "Commandes")
+                                      filtre='oui',titre = "Commandes",optionReturn="oui")
       Liste.affiche_liste()
       self.command_entry=Liste.entry
       # aide associée au panneau
@@ -375,13 +386,13 @@ class OngletPanel(Panel) :
       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")
+                            filtre='oui',titre = "Commandes",optionReturn="oui")
       else:
-         liste_groupes=self.node.item.object.niveau.definition.liste_groupes
-         dict_groupes=self.node.item.object.niveau.definition.dict_groupes
+         liste_commandes=liste_commandes+(("<Return>",self.defCmd),)
+         liste_groupes,dict_groupes=self.get_groups()
          Liste = ListeChoixParGroupes(self,page,liste_groupes,dict_groupes,
                                       liste_commandes = liste_commandes,
-                                      filtre='oui',titre = "Commandes")
+                                      filtre='oui',titre = "Commandes",optionReturn="oui")
       Liste.affiche_liste()
        # aide associée au panneau
       bulle_aide="""Double-cliquez sur la commande que vous voulez ajouter au jeu de commandes"""
@@ -425,11 +436,11 @@ class OngletPanel(Panel) :
       # les frame ...
       self.frame_comment = Frame(page,bd=1,relief='raised')
       self.frame_param   = Frame(page,bd=1,relief='raised')
-      self.frame_eval    = Frame(page,bd=1,relief='raised')
+      #self.frame_eval    = Frame(page,bd=1,relief='raised')
       self.frame_boutons = Frame(page,bd=1,relief='raised')
-      self.frame_comment.place(relx=0,rely=0,relwidth=1,relheight=0.28)
-      self.frame_param.place(relx=0,rely=0.28,relwidth=1,relheight=0.28)
-      self.frame_eval.place(relx=0,rely=0.56,relwidth=1,relheight=0.28)
+      self.frame_comment.place(relx=0,rely=0,relwidth=1,relheight=0.40)
+      self.frame_param.place(relx=0,rely=0.40,relwidth=1,relheight=0.40)
+      #self.frame_eval.place(relx=0,rely=0.56,relwidth=1,relheight=0.28)
       self.frame_boutons.place(relx=0,rely=0.84,relwidth=1,relheight=0.16)
       # remplissage de la frame commentaire
       Label(self.frame_comment,text = "Insérer un commentaire :").place(relx=0.1,rely=0.5,anchor='w')
@@ -452,16 +463,16 @@ class OngletPanel(Panel) :
       but_param_avant.place(relx=0.6,rely=0.3,anchor='w',relwidth=0.3)
       but_param_apres.place(relx=0.6,rely=0.7,anchor='w',relwidth=0.3)
       # remplissage de la frame eval
-      Label(self.frame_eval,text="Insérer un paramètre EVAL :").place(relx=0.1,rely=0.5,anchor='w')
+      #Label(self.frame_eval,text="Insérer un paramètre EVAL :").place(relx=0.1,rely=0.5,anchor='w')
           #Label(self.frame_eval,text='Non encore disponible').place(relx=0.6,rely=0.5,anchor='w')
-      but_eval_avant = Button(self.frame_eval,
-                              text = "AVANT "+self.node.item.get_nom(),
-                              command = lambda s=self :s.ajout_parametre_eval(ind = 'before'))
-      but_eval_apres = Button(self.frame_eval,
-                              text = "APRES "+self.node.item.get_nom(),
-                              command = self.ajout_parametre_eval)
-      but_eval_avant.place(relx=0.6,rely=0.3,anchor='w',relwidth=0.3)
-      but_eval_apres.place(relx=0.6,rely=0.7,anchor='w',relwidth=0.3)      
+      #but_eval_avant = Button(self.frame_eval,
+      #                        text = "AVANT "+self.node.item.get_nom(),
+      #                        command = lambda s=self :s.ajout_parametre_eval(ind = 'before'))
+      #but_eval_apres = Button(self.frame_eval,
+      #                        text = "APRES "+self.node.item.get_nom(),
+      #                        command = self.ajout_parametre_eval)
+      #but_eval_avant.place(relx=0.6,rely=0.3,anchor='w',relwidth=0.3)
+      #but_eval_apres.place(relx=0.6,rely=0.7,anchor='w',relwidth=0.3)      
       # remplissage de la frame boutons
       Button(self.frame_boutons,
              text="Commentariser toute la commande",
@@ -470,12 +481,18 @@ class OngletPanel(Panel) :
   def deselectMC(self,name):
       self.parent.appli.affiche_infos('')
     
-  def get_liste_cmd_old(self):
+  def get_liste_cmd_BAK(self):
       listeCmd = self.cata.listCmd()
       return listeCmd
 
+  def get_groups(self):
+      jdc=self.node.item.object.get_jdc_root()
+      return jdc.get_groups()
+
   def get_liste_cmd(self):
-      listeCmd = self.node.item.object.niveau.definition.get_liste_cmd()
+      #print "get_liste_cmd",self.node.item.object
+      jdc=self.node.item.object.get_jdc_root()
+      listeCmd = jdc.get_liste_cmd()
       return listeCmd
 
   def deselectCmd(self,name):
@@ -492,11 +509,10 @@ class OngletPanel(Panel) :
       nom = string.strip(nom)
       if nom == '' : return # si pas de nom, on ressort sans rien faire ...
       if self.parent.modified == 'n' : self.parent.init_modif()
-      # Pourquoi node.etape ???
-      #test,mess = self.node.etape.item.nomme_sd(nom)
       test,mess = self.node.item.nomme_sd(nom)
+      #self.node.verif()
+      #self.node.racine.update()
       self.parent.appli.affiche_infos(mess)
-      self.node.racine.update()
   
   def changed(self):
       pass
@@ -508,11 +524,15 @@ class OngletPanel(Panel) :
     # On traite par une exception le cas où l'utilisateur final cherche à désactiver
     # (commentariser) un commentaire.
     try :
+        pos=self.node.parent.children.index(self.node)
         commande_comment = self.node.item.get_objet_commentarise()
-        self.parent.appli.bureau.JDCDisplay_courant.ReplaceObjectNode(self.node,commande_comment,None)
+        self.node.parent.children[pos].select()
+        #self.parent.appli.bureau.JDCDisplay_courant.ReplaceObjectNode(self.node,commande_comment,None)
     except Exception,e:
-        tkMessageBox.showerror("TOO BAD",str(e))
+        traceback.print_exc()
+        widgets.showerror("TOO BAD",str(e))
     return
+
       
 class Panel_Inactif(Panel):
   """