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 # ======================================================================
29 Fonte_Commentaire = fontes.standard_italique
31 class COMMPanel(panels.OngletPanel):
35 Initialise les frame des panneaux contextuels relatifs à un COMMENTAIRE
37 nb = Pmw.NoteBook(self,raisecommand=self.raisecmd)
38 nb.pack(fill = 'both', expand = 1)
40 nb.add('TexteComm', tab_text='Texte Commentaire')
41 nb.add('Commande', tab_text='Nouvelle Commande')
42 nb.add('Commentaire',tab_text='Paramètre/Commentaire')
43 self.makeCOMMPage(nb.page("TexteComm"))
44 self.makeCommandePage(nb.page("Commande"))
45 self.makeParamCommentPage_for_etape(nb.page("Commentaire"))
46 nb.tab('TexteComm').focus_set()
49 def makeCOMMPage(self,page):
51 Crée la page qui permet d'afficher et d'éditer le texte du commentaire
53 self.frame_valeur = Frame(page)
54 self.frame_valeur.place(relwidth=0.9,relheight=0.9,relx=0.05,rely=0.05,anchor='nw')
55 self.widget_text = Pmw.ScrolledText(self.frame_valeur,
58 label_text = 'Texte du commentaire\n ')
59 self.widget_text.pack(side='top',expand=1,fill='both')
60 self.widget_text.configure(hscrollmode='dynamic',
61 vscrollmode='dynamic')
65 def make_buttons(self):
67 Crée les boutons du panneau
69 self.bouton_sup.place_forget()
70 self.bouton_doc.place_forget()
71 self.bouton_val = Button(self.fr_but,text='Valider',command=self.change_valeur,width=14)
72 self.bouton_ann = Button(self.fr_but,text='Annuler',command=self.display_valeur,width=14)
74 self.bouton_val.place(relx=0.25,rely=0.5,relheight=0.8,anchor='center')
75 self.bouton_ann.place(relx=0.50,rely=0.5,relheight=0.8,anchor='center')
76 self.bouton_sup.place(relx=0.75,rely=0.5,relheight=0.8,anchor='center')
79 def change_valeur(self):
81 Stocke la nouvelle valeur donnée par l'utilisateur comme valeur du commentaire
83 if self.parent.modified == 'n' : self.parent.init_modif()
84 new_valeur = self.widget_text.get()
85 self.node.item.set_valeur(new_valeur)
88 def display_valeur(self):
90 Affiche dans self.widget_text la valeur de l'objet commentaire
91 (annule d'éventuelles modifications faite par l'utilisateur)
93 t=self.node.item.get_valeur()
95 self.widget_text.settext(unicode(t))
97 # Si probleme avec unicode
98 self.widget_text.settext(t)
100 class COMMTreeItem(Objecttreeitem.ObjectTreeItem):
104 self.setfunction = self.set_valeur
106 def GetIconName(self):
108 Retourne le nom de l'icône associée au noeud qui porte self,
109 dépendant de la validité de l'objet
110 NB : un commentaire est toujours valide ...
112 return "ast-white-percent"
114 def GetLabelText(self):
115 """ Retourne 3 valeurs :
116 - le texte à afficher dans le noeud représentant l'item
117 - la fonte dans laquelle afficher ce texte
118 - la couleur du texte
120 return 'commentaire',Fonte_Commentaire,None
122 def get_valeur(self):
124 Retourne la valeur de l'objet Commentaire cad son texte
126 return self.object.get_valeur() or ''
129 texte = self.object.valeur
130 texte = string.split(texte,'\n')[0]
136 def set_valeur(self,valeur):
138 Afefcte valeur à l'objet COMMENTAIRE
140 self.object.set_valeur(valeur)
142 def GetSubList(self):
144 Retourne la liste des fils de self
149 def get_objet_commentarise(self):
151 La méthode get_objet_commentarise() de la classe compocomm.COMMTreeItem
152 surcharge la méthode get_objet_commentarise de la classe Objecttreeitem.ObjectTreeItem
153 elle a pour but d'empecher l'utilisateur final de commentariser un commentaire.
155 raise Exception( 'Citoyen : tu peux "commentariser" une commande MAIS PAS UN COMMENTAIRE' )
158 treeitem =COMMTreeItem
159 objet = Extensions.commentaire.COMMENTAIRE