]> SALOME platform Git repositories - tools/eficas.git/blob - InterfaceQT4/compofact.py
Salome HOME
ce43add587f613a65170b53a5e4fa604c8041bed
[tools/eficas.git] / InterfaceQT4 / compofact.py
1 # -*- coding: utf-8 -*-
2 # Copyright (C) 2007-2013   EDF R&D
3 #
4 # This library is free software; you can redistribute it and/or
5 # modify it under the terms of the GNU Lesser General Public
6 # License as published by the Free Software Foundation; either
7 # version 2.1 of the License.
8 #
9 # This library is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12 # Lesser General Public License for more details.
13 #
14 # You should have received a copy of the GNU Lesser General Public
15 # License along with this library; if not, write to the Free Software
16 # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
17 #
18 # See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
19 #
20
21 from __future__ import absolute_import
22 from . import browser
23 from . import typeNode
24 from Extensions.i18n import tr
25
26
27 from Editeur import Objecttreeitem
28 import six
29
30
31 class Node(browser.JDCNode,typeNode.PopUpMenuNodePartiel):
32
33     def getPanelGroupe(self,parentQt,commande):
34         maDefinition=self.item.get_definition()
35         monObjet=self.item.object
36         monNom=self.item.nom
37         maCommande=commande
38         if hasattr(parentQt,'niveau'): self.niveau=parentQt.niveau+1
39         else : self.niveau=1
40         #if  hasattr(self,'plie') :print self.item.nom, self.plie
41         #if maDefinition.sensLayout == 'horizontal':
42         #   from .monWidgetFact import MonWidgetFactHorizontal
43         #   widget=MonWidgetFactHorizontal(self,self.editor,parentQt,maDefinition,monObjet,self.niveau,maCommande)
44         #elif  hasattr(self,'plie') and self.plie==True : 
45         if  hasattr(self,'plie') and self.plie==True : 
46            from .monWidgetFactPlie import MonWidgetFactPlie
47            widget=MonWidgetFactPlie(self,self.editor,parentQt,maDefinition,monObjet,self.niveau,maCommande)
48         else:
49            from .monWidgetFact import MonWidgetFact
50            widget=MonWidgetFact(self,self.editor,parentQt,maDefinition,monObjet,self.niveau,maCommande)
51         return widget
52
53
54     def createPopUpMenu(self):
55         typeNode.PopUpMenuNodeMinimal.createPopUpMenu(self)
56
57
58 class FACTTreeItem(Objecttreeitem.ObjectTreeItem):
59   itemNode=Node
60   
61   def IsExpandable(self):
62     return 1
63
64   def GetText(self):
65       return  ''
66
67   def GetLabelText(self):
68       """ Retourne 3 valeurs :
69         - le texte à afficher dans le noeud representant l'item
70         - la fonte dans laquelle afficher ce texte
71         - la couleur du texte
72       """
73       # None --> fonte et couleur par defaut
74       if not(hasattr(self.object,'getlabeltext')): return self.object.nom,None,None
75       return self.object.getlabeltext(),None,None
76
77   def isvalid(self):
78     return self.object.isvalid()
79
80   def iscopiable(self):
81     return 1
82
83   def GetIconName(self):
84     if self.object.isvalid():
85       return "ast-green-los"
86     elif self.object.isoblig():
87       return "ast-red-los"
88     else:
89       return "ast-yel-los"
90
91   #PNPN ????
92   #def keys(self):
93   #  keys=self.object.mc_dict
94   #  return keys
95
96   def GetSubList(self):
97       """
98          Reactualise la liste des items fils stockes dans self.sublist
99       """
100       liste=self.object.mc_liste
101       sublist=[None]*len(liste)
102       # suppression des items lies aux objets disparus
103       for item in self.sublist:
104          old_obj=item.getObject()
105          if old_obj in liste:
106             pos=liste.index(old_obj)
107             sublist[pos]=item
108          else:
109             pass # objets supprimes ignores
110       # ajout des items lies aux nouveaux objets
111       pos=0
112       for obj in liste:
113          if sublist[pos] is None:
114             # nouvel objet : on cree un nouvel item
115             def setfunction(value, object=obj):
116                 object.setval(value)
117             item = self.make_objecttreeitem(self.appli, obj.nom + " : ", obj, setfunction)
118             sublist[pos]=item
119          pos=pos+1
120
121       self.sublist=sublist
122       return self.sublist
123
124   def additem(self,name,pos):
125     objet = self.object.addentite(name,pos)
126     return objet
127
128   def suppitem(self,item) :
129       """ 
130          Cette methode a pour fonction de supprimer l'item passee en argument
131          des fils de l'item FACT qui est son pere
132            - item = item du MOCLE a supprimer du MOCLE pere
133            - item.getObject() = MCSIMP ou MCBLOC 
134       """
135       itemobject=item.getObject()
136       if itemobject.isoblig() :
137          #self.editor.affiche_infos(tr('Impossible de supprimer un mot-cle obligatoire '),Qt.red)
138          return (0, tr('Impossible de supprimer un mot-cle obligatoire '))
139
140       if self.object.suppentite(itemobject):
141          message = tr("Mot-cle %s supprime")+ six.text_type(itemobject.nom)
142          #self.editor.affiche_commentaire(message)
143          return (1, message)
144       else:
145          #self.editor.affiche_infos(tr('Pb interne : impossible de supprimer ce mot-cle'),Qt.red)
146          return (0,tr('Pb interne : impossible de supprimer ce mot-cle'))
147
148 import Accas
149 objet = Accas.MCFACT
150 treeitem = FACTTreeItem