Отчет по дизайнерам переведен на table2
This commit is contained in:
@@ -86,7 +86,7 @@ class Order(models.Model):
|
|||||||
|
|
||||||
@property
|
@property
|
||||||
def approved_date(self):
|
def approved_date(self):
|
||||||
return self.approved.strftime("%d/%m/%Y")
|
return self.approved.strftime("%d/%m/%Y %H:%M")
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def ostatok(self):
|
def ostatok(self):
|
||||||
|
|||||||
@@ -71,3 +71,17 @@ class ArchiveOrdersTable(OrdersTable):
|
|||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
attrs = {'class': 'paleblue'}
|
attrs = {'class': 'paleblue'}
|
||||||
|
|
||||||
|
class DesignerTable(tables.Table):
|
||||||
|
full_name = tables.Column(empty_values=(), verbose_name = 'Дизайнер')
|
||||||
|
designer__count = tables.Column(verbose_name = 'Всего заказов')
|
||||||
|
price__sum = tables.Column(verbose_name = 'Общая сумма')
|
||||||
|
|
||||||
|
def render_full_name(self, record):
|
||||||
|
return " ".join((record['designer__first_name'], record['designer__last_name']))
|
||||||
|
|
||||||
|
def render_sum_price(self, value):
|
||||||
|
return '%0.1f' % value
|
||||||
|
|
||||||
|
class Meta:
|
||||||
|
attrs = {'class': 'paleblue'}
|
||||||
|
|||||||
@@ -120,14 +120,11 @@ def desreport(request):
|
|||||||
sdate = datetime.strptime(start_date, '%d.%m.%y')
|
sdate = datetime.strptime(start_date, '%d.%m.%y')
|
||||||
end_date = request.GET.get('edate', date.today().strftime('%d.%m.%y'))
|
end_date = request.GET.get('edate', date.today().strftime('%d.%m.%y'))
|
||||||
edate = datetime.strptime(end_date, '%d.%m.%y')
|
edate = datetime.strptime(end_date, '%d.%m.%y')
|
||||||
des_list = Order.objects.filter(cancelled=False, date__range=(sdate,edate)).values('designer__first_name','designer__last_name').annotate(Sum('price'),Count('designer'))
|
Table = DesignerTable
|
||||||
t=loader.get_template('asuzr/desreport.html')
|
table = Table(Order.objects.filter(cancelled=False, date__range=(sdate,edate)).values('designer__first_name','designer__last_name').annotate(Sum('price'),Count('designer')))
|
||||||
c=RequestContext(request,{
|
title = 'Отчет по дизайнерам за '+' - '.join((start_date, end_date))
|
||||||
'des_list' : des_list,
|
RequestConfig(request).configure(table)
|
||||||
'start_date' : start_date,
|
return render(request, 'asuzr/table.html', {'table': table, 'title': title})
|
||||||
'end_date' : end_date,
|
|
||||||
})
|
|
||||||
return HttpResponse(t.render(c))
|
|
||||||
|
|
||||||
@login_required
|
@login_required
|
||||||
def production_table(request, order_id):
|
def production_table(request, order_id):
|
||||||
|
|||||||
Reference in New Issue
Block a user