From e0674de7767a7b2bf9f83f20b2361200e4d8efe0 Mon Sep 17 00:00:00 2001 From: Dan McGee Date: Fri, 27 Aug 2010 16:11:56 -0500 Subject: Add a group details view This makes the support asked for in FS#19801 a lot more useful since we actually have an overview page for the entire group. Signed-off-by: Dan McGee --- packages/views.py | 17 ++++++++++++- templates/packages/group_details.html | 45 +++++++++++++++++++++++++++++++++++ urls.py | 3 +++ 3 files changed, 64 insertions(+), 1 deletion(-) create mode 100644 templates/packages/group_details.html diff --git a/packages/views.py b/packages/views.py index 1ab4749..0a0d0af 100644 --- a/packages/views.py +++ b/packages/views.py @@ -3,7 +3,7 @@ from django.contrib import messages from django.core.mail import send_mail from django.shortcuts import render_to_response from django.template import loader, Context, RequestContext -from django.http import HttpResponse, HttpResponseRedirect +from django.http import HttpResponse, HttpResponseRedirect, Http404 from django.shortcuts import get_object_or_404 from django.contrib.auth.models import User from django.contrib.auth.decorators import permission_required @@ -84,6 +84,21 @@ def details(request, name='', repo='', arch=''): return HttpResponseRedirect("/packages/?arch=%s&repo=%s&q=%s" % ( arch.lower(), repo.title(), name)) +def group_details(request, arch, name): + arch = get_object_or_404(Arch, name=arch) + pkgs = Package.objects.filter(packagegroup__name=name) + pkgs = pkgs.filter(Q(arch__name=arch) | Q(arch__name='any')) + pkgs = pkgs.order_by('pkgname') + if len(pkgs) == 0: + raise Http404 + context = { + 'groupname': name, + 'arch': arch, + 'packages': pkgs, + } + return render_to_response('packages/group_details.html', + RequestContext(request, context)) + def getmaintainer(request, name, repo, arch): "Returns the maintainers as plaintext." diff --git a/templates/packages/group_details.html b/templates/packages/group_details.html new file mode 100644 index 0000000..f15efaa --- /dev/null +++ b/templates/packages/group_details.html @@ -0,0 +1,45 @@ +{% extends "base.html" %} +{% block title %}Arch Linux - {{ groupname }} - Group Details{% endblock %} +{% block navbarclass %}anb-packages{% endblock %} + +{% block content %} +
+

Details for group {{ groupname }} - {{ arch.name }}

+ + + + + + + + + + + + + {% for pkg in packages %} + + + + + {% if pkg.flag_date %} + + {% else %} + + {% endif %} + + + + {% endfor %} + +
ArchRepoNameVersionDescriptionLast Updated
{{ pkg.arch.name }}{{ pkg.repo.name|capfirst }}{{ pkg.pkgname }}{{ pkg.pkgver }}-{{ pkg.pkgrel }}{{ pkg.pkgver }}-{{ pkg.pkgrel }}{{ pkg.pkgdesc }}{{ pkg.last_update|date:"Y-m-d" }}
+
+{% load cdn %}{% jquery %} + + +{% endblock %} diff --git a/urls.py b/urls.py index f2ad6b2..202efe5 100644 --- a/urls.py +++ b/urls.py @@ -50,6 +50,9 @@ urlpatterns = patterns('', (r'^packages/(?P[A-z0-9\-]+)/(?P[A-z0-9]+)/(?P[A-z0-9\-+.]+)/download/$', 'packages.views.download'), + (r'^groups/(?P[A-z0-9]+)/(?P[A-z0-9\-+.]+)/$', + 'packages.views.group_details'), + (r'^todo/(\d+)/$', 'todolists.views.view'), (r'^todo/add/$', 'todolists.views.add'), (r'^todo/edit/(?P\d+)/$', 'todolists.views.edit'), -- cgit v1.2.3-24-g4f1b