EVent Item changelog rendering

This commit is contained in:
Tom Price
2015-04-25 22:30:40 +01:00
parent 94abfae3ea
commit 0dcbd002db
3 changed files with 64 additions and 14 deletions

View File

@@ -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

View File

@@ -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 %}

Binary file not shown.