Salome HOME
CCAR: correction edition include avec fichier inexistant
[tools/eficas.git] / Editeur / compocomm.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 from Tkinter import *
22 import Pmw
23 import string
24
25 import Objecttreeitem
26 import panels
27 import fontes
28
29 Fonte_Commentaire = fontes.standard_italique
30
31 class COMMPanel(panels.OngletPanel):
32   
33   def init(self):
34     """
35     Initialise les frame des panneaux contextuels relatifs à un COMMENTAIRE
36     """
37     nb = Pmw.NoteBook(self,raisecommand=self.raisecmd)
38     nb.pack(fill = 'both', expand = 1)
39     self.nb=nb
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()
47     nb.setnaturalsize()
48     
49   def makeCOMMPage(self,page):
50     """
51     Crée la page qui permet d'afficher et d'éditer le texte du commentaire
52     """
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,
56                                         borderframe=1,
57                                         labelpos='n',
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')
62     self.make_buttons()
63     self.display_valeur()
64
65   def make_buttons(self):
66     """
67     Crée les boutons du panneau
68     """
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)
73
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')
77
78
79   def change_valeur(self):
80     """
81     Stocke la nouvelle valeur donnée par l'utilisateur comme valeur du commentaire
82     """
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)
86     self.node.update()
87
88   def display_valeur(self):
89     """
90     Affiche dans self.widget_text la valeur de l'objet commentaire
91     (annule d'éventuelles modifications faite par l'utilisateur)
92     """
93     t=self.node.item.get_valeur()
94     try:
95         self.widget_text.settext(unicode(t))
96     except:
97         # Si probleme avec unicode
98         self.widget_text.settext(t)
99     
100 class COMMTreeItem(Objecttreeitem.ObjectTreeItem):
101     panel = COMMPanel
102
103     def init(self):
104       self.setfunction = self.set_valeur
105
106     def GetIconName(self):
107       """
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 ...
111       """
112       return "ast-white-percent"
113
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
119         """
120         return 'commentaire',Fonte_Commentaire,None
121
122     def get_valeur(self):
123       """
124       Retourne la valeur de l'objet Commentaire cad son texte
125       """
126       return self.object.get_valeur() or ''
127     
128     def GetText(self):
129         texte = self.object.valeur
130         texte = string.split(texte,'\n')[0]
131         if len(texte) < 25 :
132             return texte
133         else :
134             return texte[0:24]
135
136     def set_valeur(self,valeur):
137       """
138       Afefcte valeur à l'objet COMMENTAIRE
139       """
140       self.object.set_valeur(valeur)
141       
142     def GetSubList(self):
143       """
144       Retourne la liste des fils de self
145       """
146       return []
147
148
149     def get_objet_commentarise(self):
150        """
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.
154        """
155        raise Exception( 'Citoyen : tu peux "commentariser" une commande MAIS PAS UN COMMENTAIRE' )
156   
157 import Extensions
158 treeitem =COMMTreeItem
159 objet = Extensions.commentaire.COMMENTAIRE