X-Git-Url: https://git.yukkurigames.com/?p=mlpccg-meta.git;a=blobdiff_plain;f=meta%2Fviews.py;h=71684b1f3a6d76f9c1a59792f5c4cce3aa3b3909;hp=a1cf06be9c5b3466152e379c4319112d6d88be1b;hb=88d04533bca919d52194a1c3c0e6e982c926a75f;hpb=ac0c692e40ad6aca1b28199a4ef9c850fa680427 diff --git a/meta/views.py b/meta/views.py index a1cf06b..71684b1 100644 --- a/meta/views.py +++ b/meta/views.py @@ -1,10 +1,9 @@ -import datetime -import difflib +from datetime import datetime import json -from django.shortcuts import render +from django.shortcuts import render, get_object_or_404 from django.template import RequestContext from django.http import HttpResponse -from meta.models import TournamentModel, RecordModel +from meta.models import TournamentModel, RecordModel, DeckListModel from mlpccg.CardDb import CARDDB from mlpccg.DeckList import DeckList from mlpccg.Clustering import Clustering @@ -14,24 +13,70 @@ def index(request): tournament_data = [] for tournament in tournament_models: tournament_records = tournament.recordmodel_set.all().order_by('placement') - tournament_decks = [DeckList(name=record.decklist.name, url=record.decklist.url) for record in tournament_records] + tournament_decks = [(record.placement, DeckList(name=record.decklist.name, url=record.decklist.url)) for record in tournament_records] tournament_data += [{'tournament': tournament, 'decklists': tournament_decks}] records = RecordModel.objects.all() placements = [{'decklist': DeckList(name=record.decklist.name, url=record.decklist.url), 'placement': record.placement} for record in records if record.decklist.url] clustering = Clustering(records=placements) - ranking = [(int(avg), label, [decklist for decklist in clustering.clusters[label]]) for avg, label in clustering.ranking()] + ranking = [(int(avg), label, clustering.clusters[label]) for avg, label in clustering.ranking()] return render(request, 'index.html', { 'ranking': ranking, - 'tournaments': tournament_data}, - context_instance=RequestContext(request)) + 'tournaments': tournament_data + }, context_instance=RequestContext(request)) -def tournaments(request): - return HttpResponse(json.dumps([{'name': t.name} for t in TournamentModel.objects.all()]), content_type='application/json') +def tournaments_json(request): + return HttpResponse(json.dumps([{'name': t.name, 'id': t.id} for t in TournamentModel.objects.all()]), + content_type='application/json') + +def tournaments_detail(request, tournament_id): + tournament = get_object_or_404(TournamentModel, pk=tournament_id) + records = [(record.placement, + DeckList(name=record.decklist.name, url=record.decklist.url), + record.verified) for record in tournament.recordmodel_set.all()] + + records.sort(key=lambda x: x[0]) + + return render(request, 'tournament_detail.html', { + 'records': records, + 'tournament': tournament}) + +def decklists(request): + decklists = DeckListModel.objects.all() + + return render(request, 'decklists.html', { + 'decklists': decklists}) + +def decklists_detail(request, decklist_id): + decklist = get_object_or_404(DeckListModel, pk=decklist_id) + + return render(request, 'decklists_detail.html', { + 'decklist': decklist}) def rate(request): - decklist = DeckList(url=request.POST['url']) + url = request.POST.get('url', 'v1code=%s' % request.GET.get('v1code')) + + decklist = DeckList(url=url) + + if request.POST.get('d_name') and request.POST.get('t_date') and request.POST.get('t_name') and request.POST.get('t_placement'): + try: + tournament = TournamentModel.objects.get(name__iexact=request.POST['t_name']) + + except TournamentModel.DoesNotExist: + tournament = TournamentModel(name=request.POST['t_name'], + date=datetime.strptime(request.POST['t_date'], '%Y-%m-%d'), + verified=False) + tournament.save() + + decklist_model = DeckListModel(name=request.POST['d_name'], url=request.POST['url']) + decklist_model.save() + + record = RecordModel(placement=request.POST['t_placement'], + tournament=tournament, + decklist=decklist_model, + verified=False) + record.save() records = RecordModel.objects.all() placements = [{'decklist': DeckList(name=record.decklist.name, url=record.decklist.url), 'placement': record.placement, 'record': record} for record in records if record.decklist.url] @@ -46,4 +91,5 @@ def rate(request): return render(request, 'rate.html', { 'deck': decklist, - 'similiar': similiar}, context_instance=RequestContext(request)) + 'similiar': similiar + }, context_instance=RequestContext(request))