X-Git-Url: https://asedeno.scripts.mit.edu/gitweb/?a=blobdiff_plain;f=bluechips%2Fmodel%2Fexpenditure.py;h=6b3b1cb242c6c1e4ecd4de1fef70e537870cc3b6;hb=f4d8f4cc0fa9643c3ca04c7dcc2c87f3790160de;hp=21172b9bcb046185e36e7c9ebf369651585623ac;hpb=02aef840ac4ce1018da4b7d1b5312c6179683203;p=bluechips.git diff --git a/bluechips/model/expenditure.py b/bluechips/model/expenditure.py index 21172b9..6b3b1cb 100644 --- a/bluechips/model/expenditure.py +++ b/bluechips/model/expenditure.py @@ -2,6 +2,7 @@ from bluechips.model.user import User from bluechips.model.split import Split from bluechips.model import meta from bluechips.model.types import Currency +from bluechips.model.tag import Tag from decimal import Decimal from datetime import datetime import random @@ -28,7 +29,7 @@ class Expenditure(object): split_percentage = Decimal(100) / Decimal(residents.count()) self.split(dict((resident, split_percentage) for resident in residents)) - def split(self, split_dict): + def split(self, split_dict, split_text_dict): """ Split up an expenditure. @@ -53,13 +54,11 @@ class Expenditure(object): for user, share in split_dict.items(): if share == 0: del split_dict[user] - else: - split_dict[user] = share / total amounts_dict = dict() for user, share in split_dict.iteritems(): - amounts_dict[user] = Currency(split_dict[user] * self.amount) + amounts_dict[user] = Currency((share * self.amount) / total) difference = self.amount - sum(amounts_dict.itervalues()) @@ -73,9 +72,17 @@ class Expenditure(object): amounts_dict[winner] -= Currency(1) for user, share in amounts_dict.iteritems(): - s = Split(self, user, share) + s = Split(self, user, share, split_text_dict[user]) meta.Session.add(s) + def tag(self, tags): + map(meta.Session.delete, + meta.Session.query(Tag).filter_by(expenditure_id=self.id)) + + for tag in tags: + t = Tag(self, tag) + meta.Session.add(t) + def involves(self, user): "Returns True if ``user`` is involved in this expenditure." return (any((split.user == user) and (split.share != 0)