Salome HOME
CCAR: correction creation poursuite
[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,macroitem,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.macroitem=macroitem
84     self.jdc=macroitem.object.jdc_aux
85     self.nom_jdc=nom_jdc
86     self.appli=appli
87     self.barre=Tkinter.Frame(self.fenetre,relief="ridge",bd=2)
88     self.barre.pack(expand=1,fill=Tkinter.X)
89     if self.macroitem.object.fichier_text is not None:
90       b=Tkinter.Button(self.barre,image=images.get_image("Zoom24"),command=self.visufile)
91       b.pack(side='left')
92       tp=tooltip.TOOLTIP(b,"View file")
93     self.mainPart=Pmw.ScrolledCanvas(self.fenetre,
94                                      hull_width=600,
95                                      hull_height=500,
96                                      borderframe=1)
97     self.canvas=self.mainPart.component('canvas')
98     Pmw.Color.changecolor(self.canvas,background='gray95')
99     self.mainPart.pack(padx=10,pady=10,fill = 'both', expand = 1)
100     self.item=MACRO2TreeItem(self.appli,nom_jdc,self.jdc)
101     import treewidget
102     self.tree = treewidget.Tree(self.appli,self.item,self.mainPart,command=None,rmenu=self.make_rmenu)
103     self.tree.draw()
104
105   def visufile(self):
106     Fenetre(self.appli,titre="Source du fichier inclus",texte=self.macroitem.object.fichier_text)
107
108   def make_rmenu(self,node,event):
109       if hasattr(node.item,'rmenu_specs'):
110          rmenu = Tkinter.Menu(self.canvas, tearoff=0)
111          self.cree_menu(rmenu,node.item.rmenu_specs,node)
112          rmenu.tk_popup(event.x_root,event.y_root)
113
114   def cree_menu(self,menu,itemlist,node):
115       """
116             Ajoute les items du tuple itemlist
117             dans le menu menu
118       """
119       number_item=0
120       radio=None
121       for item in itemlist:
122          number_item=number_item + 1
123          if not item :
124             menu.add_separator()
125          else:
126             label,method=item
127             if type(method) == types.TupleType:
128                  # On a un tuple => on cree une cascade
129                  menu_cascade=Tkinter.Menu(menu)
130                  menu.add_cascade(label=label,menu=menu_cascade)
131                  self.cree_menu(menu_cascade,method,node)
132             elif method[0] == '&':
133                  # On a une chaine avec & en tete => on cree un radiobouton
134                  try:
135                     command=getattr(node.item,method[1:])
136                     menu.add_radiobutton(label=label,command=lambda a=self.appli,c=command,n=node:c(a,n))
137                     if radio == None:radio=number_item
138                  except:pass
139             else:
140                  try:
141                     command=getattr(node.item,method)
142                     menu.add_command(label=label,command=lambda a=self.appli,c=command,n=node:c(a,n))
143                  except:pass
144       # Si au moins un radiobouton existe on invoke le premier
145       if radio:menu.invoke(radio)
146
147   def quit(self):
148     try:
149        self.macroitem.views.remove(self)
150     except:
151        pass
152     self.fenetre.destroy()
153
154 def makeMacroDisplay(appli,macroitem,nom_item):
155   return MacroDisplay(appli,macroitem,nom_item)
156
157 class TREEITEMINCANVAS:
158    def __init__(self,object,nom="",parent=None,appli=None,sel=None,rmenu=None):
159       print "TREEITEMINCANVAS",object
160       self.object=object
161       self.nom=nom
162       self.appli=appli
163       self.parent=parent
164
165       self.item=MACRO2TreeItem(self.appli,self.nom,self.object)
166       self.canvas=Pmw.ScrolledCanvas(self.parent,borderframe=1,canvas_background='gray95')
167       self.canvas.pack(padx=10,pady=10,fill = 'both', expand = 1)
168       if not sel:
169          def sel(event=None):
170             return
171       self.tree=treewidget.Tree(self.appli,self.item,self.canvas,command=sel,rmenu=rmenu)
172       self.tree.draw()
173
174    def mainloop(self):
175       self.parent.mainloop()
176
177    def update(self):
178       """Cette methode est utilisee pour signaler une mise a jour des objets associes"""
179       self.tree.update()
180
181 import jdcdisplay
182
183 class MACRODISPLAY(jdcdisplay.JDCDISPLAY):
184    def __init__(self,jdc,nom_jdc,appli=None,parent=None):
185       print "MACRODISPLAY",jdc
186       self.jdc=jdc
187       self.nom_jdc=nom_jdc
188       self.fichier=None
189       self.panel_courant=None
190       self.appli=appli
191       self.parent=parent
192       self.node_selected = None
193       self.modified='n'
194
195       self.pane=Pmw.PanedWidget(self.parent,orient='horizontal')
196       self.pane.add('treebrowser',min=0.4,size=0.5)
197       self.pane.add('selected',min=0.4)
198       self.pane.pack(expand=1,fill='both')
199       self.tree=TREEITEMINCANVAS(jdc,nom_jdc,self.pane.pane('treebrowser'),
200                  self.appli,self.select_node,self.make_rmenu)
201