pattern_history.py
8.07 KB
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
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
# -*- coding: utf-8 -*-
from django.core.exceptions import ObjectDoesNotExist
from django.utils.translation import ugettext_lazy as _, string_concat
from common.util import GroupDict
from dictionary.models import Qualifier, Gender
from history.models import History
from patterns.models import BaseFormLabel, PatternType, Pattern, Ending
# FIXME dużo copypasty, można kiedyś zrefaktoryzować
attribute_translation_list = [
# Wzór
('wzory', 'w_id', _(u'name')),
('wzory', 'typ', _(u'type')),
('wzory', 'przyklad', _(u'example')),
('wzory', 'zakp', _(u'basic form ending')),
('wzory', 'status', _(u'status')),
('wzory', 'komentarz', _(u'comment')),
('wzory_genders', 'gender_id', _(u'genders')),
# Zakończenie
('zakonczenia', 'zind', _(u'index')),
('zakonczenia', 'efobaz', _(u'base form label')),
('zakonczenia', 'zak', _(u'ending')),
]
attribute_translation = dict(
((table, column), label)
for table, column, label in attribute_translation_list)
pattern_attribute_order = [
_(u'name'),
_(u'type'),
_(u'genders'),
_(u'example'),
_(u'basic form ending'),
_(u'status'),
_(u'comment'),
]
ending_attribute_order = [
_(u'index'),
_(u'base form label'),
_(u'ending'),
# _(u'kwalifikator'),
]
def get_pattern_attr(attr, pattern):
if attr == 'w_id':
return pattern.name
elif attr == 'typ':
return unicode(pattern.type)
elif attr == 'przyklas':
return pattern.example
elif attr == 'zakp':
return pattern.basic_form_ending
elif attr == 'status':
return pattern.status
elif attr == 'komentarz':
return pattern.comment
def get_ending_attr(attr, ending):
if attr == 'zind':
return ending.index
elif attr == 'efobaz':
return ending.base_form_label.symbol
elif attr == 'zak':
return ending.string
def prepare_value(column, value):
try:
if column == 'qualifier_id':
prepared = Qualifier.all_objects.get(id=int(value)).label
elif column == 'status':
prepared = dict(Pattern.STATUS_CHOICES).get(value)
elif column == 'typ':
prepared = unicode(PatternType.objects.get(id=int(value)))
elif column == 'efobaz':
prepared = BaseFormLabel.objects.get(id=int(value)).symbol
elif column == 'gender_id':
prepared = Gender.objects.get(id=value).symbol
# elif value == 'true':
# prepared = 'tak'
# elif value == 'false':
# prepared = 'nie'
else:
prepared = value
except ObjectDoesNotExist:
prepared = None
except ValueError:
prepared = None
return prepared
def ending_header(base_form_label, index):
return u'%s #%s' % (base_form_label.symbol, index)
def transaction_table(transaction_data):
transaction_dict = {}
endings = GroupDict()
ending_qualifiers = {}
deleted = False
genders_before, genders_after = ([], [])
for item1 in transaction_data:
table = item1.table_name
column = item1.column_name
if (table == 'leksemy' and column == 'deleted' and
item1.new_value == 'true' and item1.old_value == 'false'):
deleted = True
attr = None
if (table, column) in attribute_translation:
attr = attribute_translation[(table, column)]
before, after = tuple(
prepare_value(column, v)
for v in (item1.old_value, item1.new_value))
before_after = (
before if item1.operation != 'INSERT' else None,
after if item1.operation != 'DELETE' else None)
if attr:
if table not in (
'zakonczenia', 'kwalifikatory_zakonczen', 'wzory_genders'):
transaction_dict[attr] = before_after
elif table == 'zakonczenia':
if item1.row_id not in endings:
endings[item1.row_id] = {}
endings[item1.row_id][attr] = before_after
if table == 'kwalifikatory_zakonczen':
if item1.row_id not in ending_qualifiers:
ending_qualifiers[item1.row_id] = {}
if column:
ending_qualifiers[item1.row_id][column] = before_after
if column == 'gender_id':
if before:
genders_before.append(before)
if after:
genders_after.append(after)
if deleted:
return deleted_pattern_table(transaction_data[0].pattern)
if genders_before or genders_after:
transaction_dict[_('genders')] = [
', '.join(sorted(values)) for values in (genders_before, genders_after)]
rows = []
for attr in pattern_attribute_order:
if attr in transaction_dict:
rows.append((attr, transaction_dict[attr]))
ending_dict = GroupDict()
for ending_id, ending_data in endings.iteritems():
for attr in ending_attribute_order:
if attr in ending_data:
ending_dict.add(ending_id, (attr, ending_data[attr]))
for q_data in ending_qualifiers.itervalues():
if q_data:
attr = _(u'qualifier')
ending_data = q_data['ending_id']
ending_id = int(ending_data[0] or ending_data[1])
ending_dict.add(ending_id, (attr, q_data['qualifier_id']))
ending_tables = []
for ending_id, ending_data in ending_dict.iteritems():
ending = Ending.all_objects.filter(pk=ending_id)
if ending:
ending = ending[0]
header = ending_header(ending.base_form_label, ending.index)
else:
records = History.objects.filter(
operation='DELETE', table_name='zakonczenia', row_id=ending_id)
bfl_id = records.get(column_name='efobaz').old_value
index = records.get(column_name='zind').old_value
try:
bfl = BaseFormLabel.objects.get(id=bfl_id)
header = string_concat(
ending_header(bfl, index), u' ', _(u'(deleted)'))
except BaseFormLabel.DoesNotExist:
header = string_concat(
_(u'(deleted)'), u' %s ' % index, _(u'(deleted)'))
ending_tables.append((header, ending_data))
return rows, ending_tables
def deleted_pattern_table(pattern):
rows = []
for table, column, attr in attribute_translation_list:
if table == 'wzory':
rows.append((
attr,
(prepare_value(
column, get_pattern_attr(column, pattern)), None)
))
ending_tables = []
for ending in pattern.genders.all():
ending_data = []
for table, column, attr in attribute_translation_list:
if table == 'zakonczenia':
ending_data.append(
(attr, (get_ending_attr(column, ending), None)))
for q in ending.qualifiers.all():
attr = _(u'qualifier')
ending_data.append((attr, (q.label, None)))
header = ending_header(ending.base_form_label, ending.index)
ending_tables.append((header, ending_data))
return rows, ending_tables
def pattern_table(transaction_data, last_tb):
rows, ending_tables = transaction_table(transaction_data)
pattern = transaction_data[0].pattern
return {
'rows': rows,
'ending_tables': ending_tables,
'user': transaction_data[0].user,
'date': last_tb,
'pattern': pattern,
}
def pattern_table_from_row(row):
transaction_data = History.objects.filter(
pattern_id=row['pattern'], user_id=row['user'],
transaction_began=row['transaction_began'])
return pattern_table(transaction_data, row['transaction_began'])
def pattern_tables(history_items):
transaction_data = []
last_tb = None
for item in history_items:
if last_tb and item.transaction_began != last_tb:
yield pattern_table(transaction_data, last_tb)
transaction_data = []
last_tb = item.transaction_began
transaction_data.append(item)
if transaction_data:
yield pattern_table(transaction_data, last_tb)