Salome HOME
PN Pour les formules
[tools/eficas.git] / Editeur / panels.py
index 78d292aec9b0f82215a946e5ddb1ae20be8a46e9..843ccc42bfb6b3519b623c8a3bde47a86e5fe14b 100644 (file)
@@ -1,16 +1,34 @@
-#@ MODIF panels Editeur  DATE 02/07/2001   AUTEUR D6BHHJP J.P.LEFEBVRE 
+# -*- coding: utf-8 -*-
 #            CONFIGURATION MANAGEMENT OF EDF VERSION
 # ======================================================================
-# COPYRIGHT (C) 1991 - 2001  EDF R&D                  WWW.CODE-ASTER.ORG
-#              SEE THE FILE "LICENSE.TERMS" FOR INFORMATION ON USAGE AND
-#              REDISTRIBUTION OF THIS FILE.
+# COPYRIGHT (C) 1991 - 2002  EDF R&D                  WWW.CODE-ASTER.ORG
+# THIS PROGRAM IS FREE SOFTWARE; YOU CAN REDISTRIBUTE IT AND/OR MODIFY
+# IT UNDER THE TERMS OF THE GNU GENERAL PUBLIC LICENSE AS PUBLISHED BY
+# THE FREE SOFTWARE FOUNDATION; EITHER VERSION 2 OF THE LICENSE, OR
+# (AT YOUR OPTION) ANY LATER VERSION.
+#
+# THIS PROGRAM IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, BUT
+# WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF
+# MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. SEE THE GNU
+# GENERAL PUBLIC LICENSE FOR MORE DETAILS.
+#
+# YOU SHOULD HAVE RECEIVED A COPY OF THE GNU GENERAL PUBLIC LICENSE
+# ALONG WITH THIS PROGRAM; IF NOT, WRITE TO EDF R&D CODE_ASTER,
+#    1 AVENUE DU GENERAL DE GAULLE, 92141 CLAMART CEDEX, FRANCE.
+#
+#
 # ======================================================================
 import string
 import os
 from Tkinter import *
 import Pmw
+import time
 
+import widgets
 from widgets import ListeChoix
+from widgets import ListeChoixParGroupes
+import prefs
+import options
 
 SEPARATEUR = '-'*30
 
@@ -21,6 +39,9 @@ class Panel(Frame) :
   Elle est toujours dérivée.
   """
   def __init__(self,parent,panneau,node) :
+      # Le parent d'un panel est un objet de la classe JDCDISPLAY ou derivee
+      # ou un objet qui a les attributs : appli (de classe APPLI ou derivee),
+      # modified et la methode init_modif
       self.parent=parent
       self.panneau = panneau
       self.node=node
@@ -42,7 +63,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
@@ -135,21 +156,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')
     
 # ------------------------------------------------------------------------
    
@@ -175,8 +196,8 @@ class Panel(Frame) :
       """
       Suppression du noeud courant
       """
+      # On signale au parent du panel (le JDCDisplay) une modification 
       if self.parent.modified == 'n' : self.parent.init_modif()
-      pere = self.node.parent
       self.node.delete()
       
   def affiche(self):
@@ -189,10 +210,9 @@ class Panel(Frame) :
       texte_infos = ''
       for e in cmd.entites.keys() :
           if e == name :
-              texte_infos=cmd.entites[e].fr
+              texte_infos=getattr(cmd.entites[e],prefs.lang)
               break
       if texte_infos == '' : texte_infos="Pas d'infos disponibles"
-      #EFICAS.affiche_infos(texte_infos)
       self.parent.appli.affiche_infos(texte_infos)
 
   def defMC(self,name):
@@ -207,9 +227,8 @@ class Panel(Frame) :
   def selectCmd(self,name):
       """ On retrouve la commande sous le curseur pour affichage du fr """
       if name != 'COMMENTAIRE' and name != SEPARATEUR:
-          #EFICAS.affiche_infos(self.parent.appli.cataitem.d_fils[name].fr)
-          #self.parent.appli.affiche_infos(self.parent.appli.cataitem.d_fils[name].fr)
-          self.parent.appli.affiche_infos(self.parent.jdc.get_cmd(name).fr)
+          texte_infos=getattr(self.parent.jdc.get_cmd(name),prefs.lang)
+          self.parent.appli.affiche_infos(texte_infos)
           
   def defCmd(self,name):
       """
@@ -243,11 +262,24 @@ 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()
       self.nb.page(page).focus_set()
-      if page == 'Concept':self._any.component('entry').focus_set()
+      if page == 'Concept':
+          try:
+#            _any est un pointeur sur entry
+#            component est une methode de pmw 
+#            a priori, jamais ok
+              self._any.component('entry').focus_set()
+          except:
+              pass
       self.tkraise()
 
 # ------------------------------------------------------------------------
@@ -273,7 +305,7 @@ class OngletPanel(Panel) :
       self._any.focus()
       # aide associée au panneau
       bulle_aide="""Tapez dans la zone de saisie le nom que vous voulez donner
-      au concept retoruné par l'opérateur courant et pressez <Return> pour valider"""
+      au concept retounré par l'opérateur courant et pressez <Return> pour valider"""
       page.bind("<Button-3>", lambda e,s=self,a=bulle_aide : s.parent.appli.affiche_aide(e,a))
       page.bind("<ButtonRelease-3>",self.parent.appli.efface_aide)
         
@@ -305,18 +337,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))
@@ -326,11 +370,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"""
@@ -374,11 +426,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')
@@ -401,23 +453,22 @@ 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",
              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):
@@ -429,7 +480,6 @@ class OngletPanel(Panel) :
       return listeCmd
 
   def deselectCmd(self,name):
-      #EFICAS.affiche_infos('')
       self.parent.appli.affiche_infos('')
     
   def execConcept(self):
@@ -443,12 +493,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)
-      #EFICAS.affiche_infos(mess)
-      self.parent.appli.affiche_infos(mess)
+      self.node.verif()
       self.node.racine.update()
+      self.parent.appli.affiche_infos(mess)
   
   def changed(self):
       pass
@@ -457,10 +505,14 @@ 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)
+    # On traite par une exception le cas où l'utilisateur final cherche à désactiver
+    # (commentariser) un commentaire.
+    try :
+        commande_comment = self.node.item.get_objet_commentarise()
+        self.parent.appli.bureau.JDCDisplay_courant.ReplaceObjectNode(self.node,commande_comment,None)
+    except Exception,e:
+        widgets.showerror("TOO BAD",str(e))
+    return
       
 class Panel_Inactif(Panel):
   """
@@ -488,3 +540,4 @@ class Panel_Inactif(Panel):
       self.bouton_sup.place(relx=0.5,rely=0.8,anchor='center')
 
 
+if __name__ == "__main__" : pass