-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathWdgInterventi.py
119 lines (102 loc) · 4.79 KB
/
WdgInterventi.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
# -*- coding: utf-8 -*-
"""
/***************************************************************************
Name : Omero RT
Description : Omero plugin
Date : August 15, 2010
copyright : (C) 2010 by Giuseppe Sucameli (Faunalia)
email : [email protected]
***************************************************************************/
Omero plugin
Works done from Faunalia (http://www.faunalia.it) with funding from Regione
Toscana - S.I.T.A. (http://www.regione.toscana.it/territorio/cartografia/index.html)
/***************************************************************************
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU General Public License as published by *
* the Free Software Foundation; either version 2 of the License, or *
* (at your option) any later version. *
* *
***************************************************************************/
"""
from PyQt4.QtCore import *
from PyQt4.QtGui import *
from ui.wdgInterventi_ui import Ui_Form
from AutomagicallyUpdater import *
class WdgInterventi(QWidget, MappingOne2One, Ui_Form):
def __init__(self, parent=None):
QWidget.__init__(self, parent)
MappingOne2One.__init__(self, "INTERVENTO_EDIFICIO")
self.setupUi(self)
self.SCHEDA_EDIFICIOID.hide()
# carica i widget multivalore con i valori delle relative tabelle
tablesDict = {
self.ZZ_QUALITA_INFORMAZIONEID: AutomagicallyUpdater.ZZTable( "ZZ_QUALITA_INFORMAZIONE" ),
self.ZZ_TIPO_INTERVENTOID: AutomagicallyUpdater.ZZTable( "ZZ_TIPO_INTERVENTO" ),
self.ZZ_NORMATIVA_SISMICAID: AutomagicallyUpdater.ZZTable( "ZZ_NORMATIVA_SISMICA" )
}
self.setupTablesUpdater(tablesDict)
self.loadTables()
self.showOtherInfos(False)
# mappa i widget con i campi delle tabelle
childrenList = [
self.SCHEDA_EDIFICIOID,
(self.ANNO_PROGETTAZIONE, AutomagicallyUpdater.OPTIONAL),
self.ZZ_QUALITA_INFORMAZIONEID,
(self.DESCRIZ_INTERV, AutomagicallyUpdater.OPTIONAL),
(self.TITOLO_ABILITATIVO, AutomagicallyUpdater.OPTIONAL),
(self.DATA_TITOLO_ABILITATIVO, AutomagicallyUpdater.OPTIONAL),
self.ZZ_TIPO_INTERVENTOID,
self.INTERVENTO_IN_CORSO,
(self.ZZ_NORMATIVA_SISMICAID, AutomagicallyUpdater.OPTIONAL)
]
self.setupValuesUpdater(childrenList)
def setValue(self, widget, value):
widget = self._getRealWidget(widget)
value = self._getRealValue(value)
if widget == self.DATA_TITOLO_ABILITATIVO:
self.DATA_TITOLO_ABILITATIVO_check.setChecked( value != None )
if value == None:
value = QDate.currentDate()
if widget == self.ANNO_PROGETTAZIONE:
self.ANNO_PROGETTAZIONE_check.setChecked( value != None )
if value == None:
value = QDate.currentDate().year()
return AutomagicallyUpdater.setValue(widget, value)
def showOtherInfos(self, show=True):
# fix ticket 181
sql = "SELECT * FROM ZZ_TIPO_INTERVENTO WHERE DESCRIZIONE %s LIKE '01 %%' ORDER BY DESCRIZIONE ASC" % ( "" if show else "NOT" )
self._widget2action[ self.ZZ_TIPO_INTERVENTOID ] = AutomagicallyUpdater.Query( sql )
self.loadTables(self.ZZ_TIPO_INTERVENTOID)
if show and self.ZZ_TIPO_INTERVENTOID.count() > 0:
self.ZZ_TIPO_INTERVENTOID.setCurrentIndex(0)
self.EPOCA_COSTRUTTIVA.setVisible(show)
def toHtml(self, index):
descrizione = self.getValue(self.DESCRIZ_INTERV)
titolo_abilitivo = self.getValue(self.TITOLO_ABILITATIVO)
data_titolo_abilitativo = self.getValue(self.DATA_TITOLO_ABILITATIVO)
return u"""
<table class="white border">
<tr class="line">
<td colspan="4" class="subtitle">Interventi strutturali successivi</td>
</tr>
<tr class="line">
<td>Categoria di intervento</td><td class="value">%s</td>
<td class="line">Normativa sismica di riferimento</td><td class="value">%s</td>
</tr>
<tr class="line">
<td>Anno di progettazione</td><td class="value">%s</td>
<td class="line">Qualità dell'informazione</td><td class="value">%s</td>
</tr>
<tr class="line">
<td>Descrizione dell'intervento</td><td colspan="3" class="value">%s</td>
</tr>
<tr class="line">
<td>Titolo abilitativo n.</td><td class="value">%s</td>
<td>data</td><td class="value">%s</td>
</tr>
<tr>
<td>Intervento in corso</td><td colspan="3" class="value">%s</td>
</tr>
</table>
""" % ( self.ZZ_TIPO_INTERVENTOID.currentText(), self.ZZ_NORMATIVA_SISMICAID.currentText(), self.getValue(self.ANNO_PROGETTAZIONE), self.ZZ_QUALITA_INFORMAZIONEID.currentText(), descrizione if descrizione != None else '', titolo_abilitivo if titolo_abilitivo != None else '', data_titolo_abilitativo if data_titolo_abilitativo != None else '', "SI" if self.getValue(self.INTERVENTO_IN_CORSO) else "NO" )