1 # -*- coding: utf-8 -*-
2 # Copyright (C) 2007-2021 EDF R&D
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.
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.
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
18 # See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
21 from __future__ import absolute_import
23 from builtins import str
24 from builtins import range
28 from Extensions.i18n import tr
30 from PyQt5.QtCore import Qt
35 class SaisieValeur(object):
37 Classe contenant les methodes communes aux panels
38 permettant de choisir des valeurs
44 def LEvaleurPressed(self,valeur=None):
45 #print('LEvaleurPressed', valeur, type(valeur))
46 if not hasattr(self, 'inSaisieValeur' ) : self.inSaisieValeur=False
47 if self.inSaisieValeur : return
48 self.inSaisieValeur=True
52 nouvelleValeur=str(self.lineEditVal.text())
53 except UnicodeEncodeError as e :
54 self.editor.afficheInfos("pb d encoding", Qt.red)
55 validite,commentaire=self.politique.recordValeur(None)
56 self.lineEditVal.setText('')
58 self.inSaisieValeur=False
62 # la 1 ligne est tres bizarre. remplacee par le 3nd le 01 10 19
63 #if hasattr(self,"lineEditVal"):self.lineEditVal.setText(tr(valeur.nom))
64 if hasattr(self,"lineEditVal") : self.lineEditVal.setText(tr(valeur))
66 if hasattr(self,"lineEditVal"):self.lineEditVal.setText(valeur)
69 if self.node.item.definition.validators != None :
70 if self.node.item.definition.validators.verifItem(nouvelleValeur) !=1 :
71 commentaire=self.node.item.definition.validators.infoErreurItem()
72 self.editor.afficheInfos(commentaire,Qt.red)
73 self.inSaisieValeur=False
76 nouvelleValeurFormat=self.politique.getValeurTexte(nouvelleValeur)
77 validite,commentaire=self.politique.recordValeur(nouvelleValeurFormat)
78 if commentaire != "" :
80 self.editor.afficheCommentaire(commentaire)
82 self.editor.afficheInfos(commentaire,Qt.red)
83 self.inSaisieValeur=False
88 def TraiteLEValeur(self,valeurTraitee=None) :
89 # lit la chaine entree dans le line edit
90 # et la tranforme en chaine de valeurs
91 # a traiter. renvoie eventuellement des complexes
93 if valeurTraitee == None :
94 valeurBrute=str(self.LEValeur.text())
96 valeurBrute=valeurTraitee
97 if valeurBrute == str("") : return listeValeurs,1
100 valeur=eval(valeurBrute,{})
104 # pour traiter 11.0 - 30.0 pour le CIST
105 #if (valeurTraitee and (type(valeurTraitee) in types.StringTypes) and (self.node.item.waitTxm())) :
106 if (valeurTraitee and isinstance(valeurTraitee, str) and (self.node.item.waitTxm())) :
107 valeur=str(valeurTraitee)
110 if type(valeur) in (list,tuple) :
111 if self.node.item.waitComplex() :
113 while (indice < len(valeur)):
116 if (v== 'RI' or v == 'MP'):
118 t=tuple([v,valeur[indice+1],valeur[indice+2]])
119 listeValeurs.append(t)
122 commentaire = tr("Veuillez entrer le complexe sous forme aster ou sous forme python")
123 self.editor.afficheInfos(commentaire)
124 return listeValeurs,0
127 else : # ce n'est pas un tuple a la mode aster
128 listeValeurs.append(v)
131 else: # on n'attend pas un complexe
132 listeValeurs=valeurBrute.split(',')
134 elif type(valeur) == bytes:
135 listeValeurs=valeur.split(',')
137 #listeValeurs.append(valeurBrute)
138 listeValeurs.append(valeur)
140 return listeValeurs,1
142 class SaisieSDCO(object) :
144 def LESDCOReturnPressed(self):
146 Lit le nom donne par l'utilisateur au concept de type CO qui doit être
147 la valeur du MCS courant et stocke cette valeur
149 self.editor.initModif()
150 anc_val = self.node.item.getValeur()
152 # il faut egalement propager la destruction de l'ancien concept
153 self.node.item.deleteValeurCo(valeur=anc_val)
154 # et on force le recalcul des concepts de sortie de l'etape
155 self.node.item.object.etape.getType_produit(force=1)
156 # et le recalcul du contexte
157 self.node.item.object.etape.parent.resetContext()
158 nomConcept = str(self.LESDCO.text())
159 if nomConcept == "" : return
161 test,commentaire=self.node.item.setValeurCo(nomConcept)
163 commentaire=tr("Valeur du mot-clef enregistree")
164 self.node.updateNodeValid()
166 cr = self.node.item.getCr()
167 commentaire = tr("Valeur du mot-clef non autorisee :")+cr.getMessFatal()