Merge branch 'feature/#3_accounting_dialog' into develop
# Conflicts: # billard/models.py # billard/views.py
This commit is contained in:
@@ -51,6 +51,7 @@ class Location(models.Model):
|
||||
class Client(models.Model):
|
||||
uuid = models.UUIDField(unique=True, default=uuid.uuid4, verbose_name="Identifier")
|
||||
location = models.ForeignKey(Location, verbose_name="Standort")
|
||||
report_user = models.ForeignKey(User, blank=True, null=True, verbose_name="Reporting Benutzer", related_name='reporting_clients')
|
||||
|
||||
def __str__(self):
|
||||
return '{}, {}'.format(self.location.name, self.uuid)
|
||||
@@ -69,24 +70,6 @@ class Desk(models.Model):
|
||||
prize_hh = models.DecimalField(max_digits=5, decimal_places=2, blank=True, null=True,
|
||||
verbose_name="Preis Happy Hour")
|
||||
|
||||
def accounting_for(self):
|
||||
t = Accounting.objects.filter(client=self.client, desk_no=self.desk_no)[:3][::-1]
|
||||
client = self.client
|
||||
location = client.location
|
||||
if t.__len__() > 0:
|
||||
a = t[t.__len__() - 1]
|
||||
if a.time_to is None:
|
||||
prize = utils.get_prize_for(
|
||||
start=a.time_from,
|
||||
end=datetime.now(timezone.utc),
|
||||
pph=self.prize,
|
||||
hh_start=location.happy_hour_start,
|
||||
hh_end=location.happy_hour_end,
|
||||
pphh=self.prize_hh,
|
||||
)
|
||||
if prize != a.prize:
|
||||
a.prize = prize
|
||||
return t
|
||||
|
||||
def __str__(self):
|
||||
return '{}, {}'.format(self.client.uuid, self.name)
|
||||
@@ -102,6 +85,9 @@ class Accounting(models.Model):
|
||||
time_to = models.DateTimeField(blank=True, null=True, verbose_name="Ende")
|
||||
prize = models.DecimalField(max_digits=6, decimal_places=2, blank=True, null=True, verbose_name="Preis")
|
||||
billed = models.BooleanField(default=False, verbose_name="Abgerechnet")
|
||||
reporter_uuid = models.UUIDField(blank=True, null=True, verbose_name='Reporter UUID')
|
||||
prize_normal = models.DecimalField(max_digits=5, decimal_places=2, blank=True, null=True, verbose_name="Preis Normalzeit")
|
||||
prize_hh = models.DecimalField(max_digits=5, decimal_places=2, blank=True, null=True, verbose_name="Preis Happy Hour")
|
||||
|
||||
def __str__(self):
|
||||
return '{}: {} -> {}, {}, {}'.format(self.desk, self.time_from, self.time_to, self.prize, self.billed)
|
||||
@@ -116,5 +102,3 @@ class Accounting(models.Model):
|
||||
def test(sender, **kwargs):
|
||||
from .tasks import process_location_data
|
||||
process_location_data.delay()
|
||||
|
||||
|
||||
|
||||
Reference in New Issue
Block a user