Commit 0e1b247a by Arjun Singh

courseware context links in discussion

parent 91aec6d3
...@@ -13,7 +13,7 @@ from courseware.access import has_access ...@@ -13,7 +13,7 @@ from courseware.access import has_access
from urllib import urlencode from urllib import urlencode
from operator import methodcaller from operator import methodcaller
from django_comment_client.permissions import check_permissions_by_view from django_comment_client.permissions import check_permissions_by_view
from django_comment_client.utils import merge_dict, extract, strip_none, strip_blank from django_comment_client.utils import merge_dict, extract, strip_none, strip_blank, get_courseware_context
import json import json
import django_comment_client.utils as utils import django_comment_client.utils as utils
...@@ -240,15 +240,23 @@ def single_thread(request, course_id, discussion_id, thread_id): ...@@ -240,15 +240,23 @@ def single_thread(request, course_id, discussion_id, thread_id):
category_map = utils.get_discussion_category_map(course) category_map = utils.get_discussion_category_map(course)
threads, query_params = get_threads(request, course_id) threads, query_params = get_threads(request, course_id)
recent_active_threads = cc.search_recent_active_threads( course = get_course_with_access(request.user, course_id, 'load')
course_id,
recursive=False, for thread in threads:
query_params={'follower_id': request.user.id}, courseware_context = get_courseware_context(thread, course)
) if courseware_context:
thread['courseware_location'] = courseware_context['courseware_location']
thread['courseware_title'] = courseware_context['courseware_title']
#recent_active_threads = cc.search_recent_active_threads(
# course_id,
# recursive=False,
# query_params={'follower_id': request.user.id},
#)
trending_tags = cc.search_trending_tags( #trending_tags = cc.search_trending_tags(
course_id, # course_id,
) #)
user_info = cc.User.from_django_user(request.user).to_dict() user_info = cc.User.from_django_user(request.user).to_dict()
escapedict = {'"': '"'} escapedict = {'"': '"'}
...@@ -265,8 +273,8 @@ def single_thread(request, course_id, discussion_id, thread_id): ...@@ -265,8 +273,8 @@ def single_thread(request, course_id, discussion_id, thread_id):
'user_info': saxutils.escape(json.dumps(user_info),escapedict), 'user_info': saxutils.escape(json.dumps(user_info),escapedict),
'annotated_content_info': saxutils.escape(json.dumps(annotated_content_info), escapedict), 'annotated_content_info': saxutils.escape(json.dumps(annotated_content_info), escapedict),
'course': course, 'course': course,
'recent_active_threads': recent_active_threads, #'recent_active_threads': recent_active_threads,
'trending_tags': trending_tags, #'trending_tags': trending_tags,
'course_id': course.id, 'course_id': course.id,
'thread_id': thread_id, 'thread_id': thread_id,
'threads': saxutils.escape(json.dumps(threads), escapedict), 'threads': saxutils.escape(json.dumps(threads), escapedict),
......
...@@ -124,10 +124,7 @@ def initialize_discussion_info(course): ...@@ -124,10 +124,7 @@ def initialize_discussion_info(course):
category_map['entries'][topic] = {"id": entry["id"], category_map['entries'][topic] = {"id": entry["id"],
"sort_key": entry.get("sort_key", topic)} "sort_key": entry.get("sort_key", topic)}
sort_map_entries(category_map) sort_map_entries(category_map)
#for level in category_map["subcategories"].values():
# sort_map_entries(level)
_DISCUSSIONINFO = {} _DISCUSSIONINFO = {}
...@@ -135,12 +132,15 @@ def initialize_discussion_info(course): ...@@ -135,12 +132,15 @@ def initialize_discussion_info(course):
_DISCUSSIONINFO['category_map'] = category_map _DISCUSSIONINFO['category_map'] = category_map
# TODO delete me when you've used me def get_courseware_context(content, course):
#_DISCUSSIONINFO['categorized']['General'] = [{ id_map = get_discussion_id_map(course)
# 'title': 'General', id = content['commentable_id']
# 'discussion_id': url_course_id, content_info = None
# 'category': 'General', if id in id_map:
#}] location = id_map[id]["location"].url()
title = id_map[id]["title"]
content_info = { "courseware_location": location, "courseware_title": title}
return content_info
class JsonResponse(HttpResponse): class JsonResponse(HttpResponse):
def __init__(self, data=None): def __init__(self, data=None):
......
...@@ -1056,6 +1056,12 @@ body.discussion { ...@@ -1056,6 +1056,12 @@ body.discussion {
color: #888; color: #888;
} }
.post-context{
margin-top: 20px;
font-size: 12px;
color: #888;
}
p + p { p + p {
margin-top: 20px; margin-top: 20px;
} }
......
...@@ -13,9 +13,9 @@ ...@@ -13,9 +13,9 @@
<div class="post-body"> <div class="post-body">
${'<%- body %>'} ${'<%- body %>'}
</div> </div>
${'<% if (courseware_location) { %>'} ${'<% if (obj.courseware_location) { %>'}
<div class="post-context"> <div class="post-context">
(this post is about <a href="../../jump_to/<% courseware_location %>"><% courseware_title %></a>) (this post is about <a href="../../jump_to/${'<%- courseware_location %>'}">${'<%- courseware_title %>'}</a>)
</div> </div>
${'<% } %>'} ${'<% } %>'}
<div class="post-status"> <div class="post-status">
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment