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.
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.
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.
20 # ======================================================================
22 Ce module contient la classe MacroDisplay qui realise l'affichage
23 des sous commandes d'une macro sous forme d'arbre
33 from widgets import Fenetre
35 class MACRO2TreeItem(Objecttreeitem.ObjectTreeItem):
36 def IsExpandable(self):
42 def GetIconName(self):
43 if self.object.isvalid():
44 return "ast-green-square"
46 return "ast-red-square"
49 return range(len(self.object.etapes))
53 for key in self.keys():
54 liste = self.object.etapes
59 def setfunction(value, key=key, object=liste):
61 item = self.make_objecttreeitem(self.appli,value.ident() + " : ", value, setfunction)
65 def verif_condition_bloc(self):
66 # retourne la liste des sous-items dont la condition est valide
67 # sans objet pour le JDC
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()
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")
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)
88 tp=tooltip.TOOLTIP(b,"View file")
89 self.mainPart=Pmw.ScrolledCanvas(self.fenetre,
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)
98 self.tree = treewidget.Tree(self.appli,self.item,self.mainPart,command=None,rmenu=self.make_rmenu)
102 Fenetre(self.appli,titre="Source du fichier inclus",texte=self.jdc.fichier_text)
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)
110 def cree_menu(self,menu,itemlist,node):
112 Ajoute les items du tuple itemlist
117 for item in itemlist:
118 number_item=number_item + 1
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
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
137 command=getattr(node.item,method)
138 menu.add_command(label=label,command=lambda a=self.appli,c=command:c(a))
140 # Si au moins un radiobouton existe on invoke le premier
141 if radio:menu.invoke(radio)
144 self.fenetre.destroy()
146 def makeMacroDisplay(appli,jdc,nom_jdc):
147 return MacroDisplay(appli,jdc,nom_jdc)