mirror of
https://github.com/nottinghamtec/PyRIGS.git
synced 2026-01-23 16:32:15 +00:00
EVent Item changelog rendering
This commit is contained in:
@@ -229,29 +229,41 @@ class EventRevisions(generic.ListView):
|
|||||||
# Build some dicts of what we have
|
# Build some dicts of what we have
|
||||||
item_dict = {}
|
item_dict = {}
|
||||||
for item in old_items:
|
for item in old_items:
|
||||||
item_dict[item.object_id] = ItemCompare(old=item)
|
compare = ItemCompare(old=item)
|
||||||
|
compare.old.field_dict['event_id'] = compare.old.field_dict.pop('event')
|
||||||
|
item_dict[item.object_id] = compare
|
||||||
|
|
||||||
for item in new_items:
|
for item in new_items:
|
||||||
try:
|
try:
|
||||||
item_dict[item.object_id].new = item
|
compare = item_dict[item.object_id]
|
||||||
|
compare.new = item
|
||||||
except KeyError:
|
except KeyError:
|
||||||
item_dict[item.object_id] = ItemCompare(new=item)
|
compare = ItemCompare(new=item)
|
||||||
|
compare.new.field_dict['event_id'] = compare.new.field_dict.pop('event')
|
||||||
|
item_dict[item.object_id] = compare
|
||||||
|
|
||||||
# calculate changes
|
# calculate changes
|
||||||
key, old, new = [], [], []
|
key, old, new = [], [], []
|
||||||
for items in item_dict:
|
for (_, items) in item_dict.items():
|
||||||
if items.new is None:
|
if items.new is None:
|
||||||
key.append("Deleted \"%s\"" % items.old.field_dict['name'])
|
key.append("Deleted \"%s\"" % items.old.field_dict['name'])
|
||||||
old.append(models.EventItem(**old.field_dict))
|
old.append(models.EventItem(**items.old.field_dict))
|
||||||
new.append(None)
|
new.append(None)
|
||||||
|
|
||||||
elif items.old is None:
|
elif items.old is None:
|
||||||
key.append("Added \"%s\"" % items.new.field_dict['name'])
|
key.append("Added \"%s\"" % items.new.field_dict['name'])
|
||||||
old.append(None)
|
old.append(None)
|
||||||
new.append(models.EventItem(**new.field_dict))
|
new.append(models.EventItem(**items.new.field_dict))
|
||||||
if items.old.field_dict != items.new.field_dict:
|
|
||||||
key.append("Changed \"%s\"" % items.old.field_dict['name'])
|
elif items.old.field_dict != items.new.field_dict:
|
||||||
old.append(models.EventItem(**old.field_dict))
|
if items.old.field_dict['name'] == items.new.field_dict['name']:
|
||||||
new.append(models.EventItem(**new.field_dict))
|
change_text = "\"%s\"" % items.old.field_dict['name']
|
||||||
|
else:
|
||||||
|
change_text = "\"%s\" to \"%s\"" % (items.old.field_dict['name'], items.new.field_dict['name'])
|
||||||
|
key.append("Changed %s" % change_text)
|
||||||
|
|
||||||
|
old.append(models.EventItem(**items.old.field_dict))
|
||||||
|
new.append(models.EventItem(**items.new.field_dict))
|
||||||
|
|
||||||
return zip(key,old,new)
|
return zip(key,old,new)
|
||||||
|
|
||||||
@@ -273,13 +285,15 @@ class EventRevisions(generic.ListView):
|
|||||||
else:
|
else:
|
||||||
changes = self.compare(revisions[revisionNo+1].field_dict,thisRevision.field_dict)
|
changes = self.compare(revisions[revisionNo+1].field_dict,thisRevision.field_dict)
|
||||||
thisItem['item_changes'] = self.compare_items(revisions[revisionNo+1], thisRevision)
|
thisItem['item_changes'] = self.compare_items(revisions[revisionNo+1], thisRevision)
|
||||||
|
logger.debug(thisItem['item_changes'])
|
||||||
thisItem['changes'] = changes
|
thisItem['changes'] = changes
|
||||||
|
|
||||||
items.append(thisItem)
|
items.append(thisItem)
|
||||||
logger.info(thisItem)
|
logger.info(thisItem)
|
||||||
|
|
||||||
context = {}
|
context = {
|
||||||
context['object_list'] = items
|
'object_list': items
|
||||||
|
}
|
||||||
|
|
||||||
return context
|
return context
|
||||||
|
|
||||||
|
|||||||
@@ -26,7 +26,7 @@
|
|||||||
<tbody>
|
<tbody>
|
||||||
{% for version in object_list %}
|
{% for version in object_list %}
|
||||||
<tr>
|
<tr>
|
||||||
<td>{{ version.pk }}</td>
|
<td>{{ version.revision.pk }}</td>
|
||||||
<td>{{ version.revision.date_created }}</td>
|
<td>{{ version.revision.date_created }}</td>
|
||||||
<td>{{ version.revision.user.name }}</td>
|
<td>{{ version.revision.user.name }}</td>
|
||||||
<td>{% for key, old, new in version.changes %}
|
<td>{% for key, old, new in version.changes %}
|
||||||
@@ -37,7 +37,43 @@
|
|||||||
|
|
||||||
|
|
||||||
'>{{ key }}</button>
|
'>{{ key }}</button>
|
||||||
{% endfor %}</td>
|
{% endfor %}
|
||||||
|
{% for key, old, new in version.item_changes %}
|
||||||
|
<button title="{{ key }}" type="button" class="btn btn-default btn-xs" data-container="body" data-html="true" data-trigger='hover' data-placement='left' data-toggle="popover" data-content='
|
||||||
|
|
||||||
|
{% if new %}
|
||||||
|
<div class="alert alert-success">
|
||||||
|
<dl>
|
||||||
|
<dt>Name</dt>
|
||||||
|
<dd>{{new.name}}</dd>
|
||||||
|
<dt>Description</dt>
|
||||||
|
<dd>{{new.description}}</dd>
|
||||||
|
<dt>Quantity</dt>
|
||||||
|
<dd>{{new.quantity}}</dd>
|
||||||
|
<dt>Price</dt>
|
||||||
|
<dd>{{new.price}}
|
||||||
|
</dl>
|
||||||
|
</div>
|
||||||
|
{% endif %}
|
||||||
|
{% if old %}
|
||||||
|
<div class="alert alert-danger">
|
||||||
|
<dl>
|
||||||
|
<dt>Name</dt>
|
||||||
|
<dd>{{old.name}}</dd>
|
||||||
|
<dt>Description</dt>
|
||||||
|
<dd>{{old.description}}</dd>
|
||||||
|
<dt>Quantity</dt>
|
||||||
|
<dd>{{old.quantity}}</dd>
|
||||||
|
<dt>Price</dt>
|
||||||
|
<dd>{{old.price}}
|
||||||
|
</dl>
|
||||||
|
</div>
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
|
|
||||||
|
'>{{ key }}</button>
|
||||||
|
{% endfor %}
|
||||||
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
|
|
||||||
|
|||||||
BIN
db.sqlite3
BIN
db.sqlite3
Binary file not shown.
Reference in New Issue
Block a user