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