src/hdalab/views/pages.py
author cavaliet
Mon, 21 Jul 2014 16:07:00 +0200
changeset 299 8e00641076e7
parent 271 8f77cf71ab02
child 594 922fc1545933
permissions -rw-r--r--
remove renkan management to an other django app (see renkan hg repo)
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
253
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
     1
# -*- coding: utf-8 -*-
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
     2
299
8e00641076e7 remove renkan management to an other django app (see renkan hg repo)
cavaliet
parents: 271
diff changeset
     3
from django.shortcuts import render_to_response
253
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
     4
from django.template import RequestContext
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
     5
from hdabo.models import Datasheet, TaggedSheet
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
     6
import re
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
     7
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
     8
def datasheet(request, hda_id=None):
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
     9
    MAX_TAG = 15
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    10
    MAX_RELATED = 50
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    11
    
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    12
    datasheet = Datasheet.objects.select_related("organisation").get(hda_id=hda_id)
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    13
    
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    14
    domain = re.findall(r"^https?://(www\.)?([^/]+)",datasheet.url)
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    15
    ordered_tags = TaggedSheet.objects.filter(datasheet=datasheet,order__lte=MAX_TAG).select_related("tag").order_by('order')
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    16
    tags = [t.tag.id for t in ordered_tags]
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    17
    tagorders = dict([(t.tag.id,t.order) for t in ordered_tags])
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    18
    tsqs = TaggedSheet.objects.exclude(datasheet=datasheet).filter(order__lte=MAX_TAG,tag_id__in=tags)
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    19
    dsscores = {}
260
a15e8cb98525 Remove tag translations for french language
veltr
parents: 253
diff changeset
    20
    addtoscore = 2*MAX_TAG
253
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    21
    
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    22
    for ts in tsqs:
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    23
        a_order = tagorders[ts.tag_id]
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    24
        b_order = ts.order
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    25
        score = addtoscore - a_order - b_order
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    26
        dsscore = dsscores.get(ts.datasheet_id,0)
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    27
        dsscores[ts.datasheet_id] = dsscore + score
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    28
    relatedqs = Datasheet.objects.filter(id__in=dsscores.keys()).select_related("organisation")
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    29
    relatedds = [{
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    30
        'id': ds.id,
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    31
        'hda_id': ds.hda_id,
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    32
        'title': ds.title,
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    33
        'description': ds.description,
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    34
        'organisation_name': ds.organisation.name,
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    35
        'organisation_url': ds.organisation.website,
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    36
        'score': dsscores.get(ds.id,0),
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    37
    } for ds in relatedqs]
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    38
    relatedds = sorted(relatedds, key=lambda ds: -ds['score'])[:MAX_RELATED]
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    39
    
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    40
    for ds in relatedds:
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    41
        otqs = TaggedSheet.objects.filter(datasheet_id=ds['id'],order__lte=MAX_TAG).select_related("tag").order_by('order')
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    42
        ds['ordered_tags'] = [{
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    43
            'id': t.tag.id,
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    44
            'label': t.tag.label,
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    45
            'order': t.order,
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    46
            'common' : (t.tag.id in tags)
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    47
        } for t in otqs]
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    48
    
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    49
    return render_to_response(
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    50
        "notice.html",
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    51
        {
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    52
            'datasheet':datasheet,
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    53
            'domain': domain[0][1] if domain else "",
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    54
            'ordered_tags': ordered_tags,
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    55
            'related': relatedds,
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    56
        },
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    57
        context_instance=RequestContext(request)
1113c3874dd6 Added Datasheet View
veltr
parents:
diff changeset
    58
    )