Salome HOME
CCAR: ajout des fichiers macros
[tools/eficas.git] / Editeur / macrodisplay.py
1 # -*- coding: utf-8 -*-
2 #            CONFIGURATION MANAGEMENT OF EDF VERSION
3 # ======================================================================
4 # COPYRIGHT (C) 1991 - 2002  EDF R&D                  WWW.CODE-ASTER.ORG
5 # THIS PROGRAM IS FREE SOFTWARE; YOU CAN REDISTRIBUTE IT AND/OR MODIFY
6 # IT UNDER THE TERMS OF THE GNU GENERAL PUBLIC LICENSE AS PUBLISHED BY
7 # THE FREE SOFTWARE FOUNDATION; EITHER VERSION 2 OF THE LICENSE, OR
8 # (AT YOUR OPTION) ANY LATER VERSION.
9 #
10 # THIS PROGRAM IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, BUT
11 # WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF
12 # MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. SEE THE GNU
13 # GENERAL PUBLIC LICENSE FOR MORE DETAILS.
14 #
15 # YOU SHOULD HAVE RECEIVED A COPY OF THE GNU GENERAL PUBLIC LICENSE
16 # ALONG WITH THIS PROGRAM; IF NOT, WRITE TO EDF R&D CODE_ASTER,
17 #    1 AVENUE DU GENERAL DE GAULLE, 92141 CLAMART CEDEX, FRANCE.
18 #
19 #
20 # ======================================================================
21 """
22    Ce module contient la classe MacroDisplay qui realise l'affichage 
23    des sous commandes d'une macro sous forme d'arbre
24 """
25 # Modules Python
26 import types
27 import Tkinter,Pmw
28
29 # Modules EFICAS
30 import images
31 import tooltip
32 import Objecttreeitem
33 from widgets import Fenetre
34
35 class MACRO2TreeItem(Objecttreeitem.ObjectTreeItem):
36   def IsExpandable(self):
37     return 1
38
39   def GetText(self):
40       return  "    "
41
42   def GetIconName(self):
43     if self.object.isvalid():
44       return "ast-green-square"
45     else:
46       return "ast-red-square"
47
48   def keys(self):
49     return range(len(self.object.etapes))
50
51   def GetSubList(self):
52     sublist=[]
53     for key in self.keys():
54       liste = self.object.etapes
55       try:
56         value = liste[key]
57       except KeyError:
58         continue
59       def setfunction(value, key=key, object=liste):
60         object[key] = value
61       item = self.make_objecttreeitem(self.appli,value.ident() + " : ", value, setfunction)
62       sublist.append(item)
63     return sublist
64
65   def verif_condition_bloc(self):
66       # retourne la liste des sous-items dont la condition est valide
67       # sans objet pour le JDC
68       return [],[]
69
70   def get_l_noms_etapes(self):
71       """ Retourne la liste des noms des étapes de self.object"""
72       return self.object.get_l_noms_etapes()
73
74 class MacroDisplay:
75   def __init__(self,appli,jdc,nom_jdc):
76     self.fenetre = Tkinter.Toplevel()
77     self.fenetre.configure(width = 800,height=500)
78     self.fenetre.protocol("WM_DELETE_WINDOW", self.quit)
79     self.fenetre.title("Visualisation Macro_Etape")
80     self.jdc=jdc
81     self.nom_jdc=nom_jdc
82     self.appli=appli
83     self.barre=Tkinter.Frame(self.fenetre,relief="ridge",bd=2)
84     self.barre.pack(expand=1,fill=Tkinter.X)
85     if self.jdc.fichier_text is not None:
86       b=Tkinter.Button(self.barre,image=images.get_image("Zoom24"),command=self.visufile)
87       b.pack(side='left')
88       tp=tooltip.TOOLTIP(b,"View file")
89     self.mainPart=Pmw.ScrolledCanvas(self.fenetre,
90                                      hull_width=600,
91                                      hull_height=500,
92                                      borderframe=1)
93     self.canvas=self.mainPart.component('canvas')
94     Pmw.Color.changecolor(self.canvas,background='gray95')
95     self.mainPart.pack(padx=10,pady=10,fill = 'both', expand = 1)
96     self.item=MACRO2TreeItem(self.appli,nom_jdc,jdc)
97     import treewidget
98     self.tree = treewidget.Tree(self.appli,self.item,self.mainPart,command=None,rmenu=self.make_rmenu)
99     self.tree.draw()
100
101   def visufile(self):
102     Fenetre(self.appli,titre="Source du fichier inclus",texte=self.jdc.fichier_text)
103
104   def make_rmenu(self,node,event):
105       if hasattr(node.item,'rmenu_specs'):
106          rmenu = Tkinter.Menu(self.canvas, tearoff=0)
107          self.cree_menu(rmenu,node.item.rmenu_specs,node)
108          rmenu.tk_popup(event.x_root,event.y_root)
109
110   def cree_menu(self,menu,itemlist,node):
111       """
112             Ajoute les items du tuple itemlist
113             dans le menu menu
114       """
115       number_item=0
116       radio=None
117       for item in itemlist:
118          number_item=number_item + 1
119          if not item :
120             menu.add_separator()
121          else:
122             label,method=item
123             if type(method) == types.TupleType:
124                  # On a un tuple => on cree une cascade
125                  menu_cascade=Tkinter.Menu(menu)
126                  menu.add_cascade(label=label,menu=menu_cascade)
127                  self.cree_menu(menu_cascade,method,node)
128             elif method[0] == '&':
129                  # On a une chaine avec & en tete => on cree un radiobouton
130                  try:
131                     command=getattr(node.item,method[1:])
132                     menu.add_radiobutton(label=label,command=lambda a=self.appli,c=command:c(a))
133                     if radio == None:radio=number_item
134                  except:pass
135             else:
136                  try:
137                     command=getattr(node.item,method)
138                     menu.add_command(label=label,command=lambda a=self.appli,c=command:c(a))
139                  except:pass
140       # Si au moins un radiobouton existe on invoke le premier
141       if radio:menu.invoke(radio)
142
143   def quit(self):
144     self.fenetre.destroy()
145
146 def makeMacroDisplay(appli,jdc,nom_jdc):
147   return MacroDisplay(appli,jdc,nom_jdc)
148