1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586 |
- from django.contrib.auth.decorators import login_required
- from django.core.urlresolvers import reverse
- from django.shortcuts import render, get_object_or_404
- from .models import Document, Service, ServiceUse, CostUse, GoodUse
- @login_required
- def list_documents(request):
- breadcrumbs = (
- ('Documents', reverse('list-documents')),
- )
- docs = Document.objects.all()\
- .prefetch_related('service_set')\
- .order_by('-date')
- return render(
- request, 'costs/documents_list.html', {
- 'documents': docs,
- 'planning_documents': docs.filter(type=Document.TYPE_PLAN),
- 'factual_documents': docs.filter(type=Document.TYPE_FACT),
- 'breadcrumbs': breadcrumbs,
- })
- @login_required
- def detail_document(request, pk):
- doc = get_object_or_404(Document, pk=pk)
- breadcrumbs = (
- ('Documents', reverse('list-documents')),
- (str(doc), doc.get_absolute_url())
- )
- return render(
- request, 'costs/document_detail.html', {
- 'document': doc,
- 'other_documents': Document.objects.exclude(pk=doc.pk),
- 'breadcrumbs': breadcrumbs,
- 'total_recuring_costs': doc.get_total_recuring_costs(),
- 'total_goods': doc.get_total_goods()
- })
- @login_required
- def compare_document(request, pk, other_pk):
- doc = Document.objects.get(pk=pk)
- other_doc = Document.objects.get(pk=other_pk)
- breadcrumbs = (
- ('Documents', reverse('list-documents')),
- (str(doc), doc.get_absolute_url()),
- ('Variations depuis {}'.format(other_doc), request.path),
- )
- context = {
- 'breadcrumbs': breadcrumbs,
- 'document': doc,
- 'other_document': other_doc,
- 'deltas': doc.compare(other_doc),
- }
- return render(request, 'costs/document_compare.html', context)
- @login_required
- def detail_service(request, pk):
- service = Service.objects.get(pk=pk)
- doc = service.document
- breadcrumbs = (
- ('Documents', reverse('list-documents')),
- (str(doc), doc.get_absolute_url()),
- (service.name, service.get_absolute_url())
- )
- costs_uses = CostUse.objects.filter(service=service)
- goods_uses = GoodUse.objects.filter(service=service)
- services_uses = ServiceUse.objects.filter(service=service)
- context = {}
- context.update(service.get_prices())
- context.update({
- 'breadcrumbs': breadcrumbs,
- 'document': doc,
- 'service': service,
- 'costs_uses': costs_uses,
- 'goods_uses': goods_uses,
- 'services_uses': services_uses,
- })
- return render(request, 'costs/service_detail.html', context)
|