Salome HOME
58a72da4be600635e6a4759a06ac28f7258c7073
[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 import compojdc
34 import treewidget
35 from widgets import Fenetre
36
37 #class MACRO2TreeItem(Objecttreeitem.ObjectTreeItem):
38 class MACRO2TreeItem(compojdc.JDCTreeItem):
39   def IsExpandable(self):
40     return 1
41
42   def GetText(self):
43       return  "    "
44
45   def GetIconName(self):
46     if self.object.isvalid():
47       return "ast-green-square"
48     else:
49       return "ast-red-square"
50
51   def keys(self):
52     return range(len(self.object.etapes))
53
54   def GetSubList(self):
55     sublist=[]
56     for key in self.keys():
57       liste = self.object.etapes
58       try:
59         value = liste[key]
60       except KeyError:
61         continue
62       def setfunction(value, key=key, object=liste):
63         object[key] = value
64       item = self.make_objecttreeitem(self.appli,value.ident() + " : ", value, setfunction)
65       sublist.append(item)
66     return sublist
67
68   def verif_condition_bloc(self):
69       # retourne la liste des sous-items dont la condition est valide
70       # sans objet pour le JDC
71       return [],[]
72
73   def get_l_noms_etapes(self):
74       """ Retourne la liste des noms des étapes de self.object"""
75       return self.object.get_l_noms_etapes()
76
77 class MacroDisplay:
78   def __init__(self,appli,jdc,nom_jdc):
79     self.fenetre = Tkinter.Toplevel()
80     self.fenetre.configure(width = 800,height=500)
81     self.fenetre.protocol("WM_DELETE_WINDOW", self.quit)
82     self.fenetre.title("Visualisation Macro_Etape")
83     self.jdc=jdc
84     self.nom_jdc=nom_jdc
85     self.appli=appli
86     self.barre=Tkinter.Frame(self.fenetre,relief="ridge",bd=2)
87     self.barre.pack(expand=1,fill=Tkinter.X)
88     if self.jdc.fichier_text is not None:
89       b=Tkinter.Button(self.barre,image=images.get_image("Zoom24"),command=self.visufile)
90       b.pack(side='left')
91       tp=tooltip.TOOLTIP(b,"View file")
92     self.mainPart=Pmw.ScrolledCanvas(self.fenetre,
93                                      hull_width=600,
94                                      hull_height=500,
95                                      borderframe=1)
96     self.canvas=self.mainPart.component('canvas')
97     Pmw.Color.changecolor(self.canvas,background='gray95')
98     self.mainPart.pack(padx=10,pady=10,fill = 'both', expand = 1)
99     self.item=MACRO2TreeItem(self.appli,nom_jdc,jdc)
100     import treewidget
101     self.tree = treewidget.Tree(self.appli,self.item,self.mainPart,command=None,rmenu=self.make_rmenu)
102     self.tree.draw()
103
104   def visufile(self):
105     Fenetre(self.appli,titre="Source du fichier inclus",texte=self.jdc.fichier_text)
106
107   def make_rmenu(self,node,event):
108       if hasattr(node.item,'rmenu_specs'):
109          rmenu = Tkinter.Menu(self.canvas, tearoff=0)
110          self.cree_menu(rmenu,node.item.rmenu_specs,node)
111          rmenu.tk_popup(event.x_root,event.y_root)
112
113   def cree_menu(self,menu,itemlist,node):
114       """
115             Ajoute les items du tuple itemlist
116             dans le menu menu
117       """
118       number_item=0
119       radio=None
120       for item in itemlist:
121          number_item=number_item + 1
122          if not item :
123             menu.add_separator()
124          else:
125             label,method=item
126             if type(method) == types.TupleType:
127                  # On a un tuple => on cree une cascade
128                  menu_cascade=Tkinter.Menu(menu)
129                  menu.add_cascade(label=label,menu=menu_cascade)
130                  self.cree_menu(menu_cascade,method,node)
131             elif method[0] == '&':
132                  # On a une chaine avec & en tete => on cree un radiobouton
133                  try:
134                     command=getattr(node.item,method[1:])
135                     menu.add_radiobutton(label=label,command=lambda a=self.appli,c=command,n=node:c(a,n))
136                     if radio == None:radio=number_item
137                  except:pass
138             else:
139                  try:
140                     command=getattr(node.item,method)
141                     menu.add_command(label=label,command=lambda a=self.appli,c=command,n=node:c(a,n))
142                  except:pass
143       # Si au moins un radiobouton existe on invoke le premier
144       if radio:menu.invoke(radio)
145
146   def quit(self):
147     self.fenetre.destroy()
148
149 def makeMacroDisplay(appli,jdc,nom_jdc):
150   return MacroDisplay(appli,jdc,nom_jdc)
151
152 class TREEITEMINCANVAS:
153    def __init__(self,object,nom="",parent=None,appli=None,sel=None,rmenu=None):
154       print "TREEITEMINCANVAS",object
155       self.object=object
156       self.nom=nom
157       self.appli=appli
158       self.parent=parent
159
160       self.item=MACRO2TreeItem(self.appli,self.nom,self.object)
161       self.canvas=Pmw.ScrolledCanvas(self.parent,borderframe=1,canvas_background='gray95')
162       self.canvas.pack(padx=10,pady=10,fill = 'both', expand = 1)
163       if not sel:
164          def sel(event=None):
165             return
166       self.tree=treewidget.Tree(self.appli,self.item,self.canvas,command=sel,rmenu=rmenu)
167       self.tree.draw()
168
169    def mainloop(self):
170       self.parent.mainloop()
171
172    def update(self):
173       """Cette methode est utilisee pour signaler une mise a jour des objets associes"""
174       self.tree.update()
175
176 import jdcdisplay
177
178 class MACRODISPLAY(jdcdisplay.JDCDISPLAY):
179    def __init__(self,jdc,nom_jdc,appli=None,parent=None):
180       print "MACRODISPLAY",jdc
181       self.jdc=jdc
182       self.nom_jdc=nom_jdc
183       self.fichier=None
184       self.panel_courant=None
185       self.appli=appli
186       self.parent=parent
187       self.node_selected = None
188       self.modified='n'
189
190       self.pane=Pmw.PanedWidget(self.parent,orient='horizontal')
191       self.pane.add('treebrowser',min=0.4,size=0.5)
192       self.pane.add('selected',min=0.4)
193       self.pane.pack(expand=1,fill='both')
194       self.tree=TREEITEMINCANVAS(jdc,nom_jdc,self.pane.pane('treebrowser'),
195                  self.appli,self.select_node,self.make_rmenu)
196