Commit 4778002b by Tom Giannattasio

fixed merge conflict

parents 4a3f85b4 fb88df45
...@@ -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
...@@ -71,6 +71,15 @@ def render_discussion(request, course_id, threads, *args, **kwargs): ...@@ -71,6 +71,15 @@ def render_discussion(request, course_id, threads, *args, **kwargs):
annotated_content_info = reduce(merge_dict, map(infogetter, threads), {}) annotated_content_info = reduce(merge_dict, map(infogetter, threads), {})
if discussion_type != 'inline':
course = get_course_with_access(request.user, course_id, 'load')
for thread in threads:
courseware_context = get_courseware_context(thread, course)
if courseware_context:
thread['courseware_location'] = courseware_context['courseware_location']
thread['courseware_title'] = courseware_context['courseware_title']
context = { context = {
'threads': threads, 'threads': threads,
'discussion_id': discussion_id, 'discussion_id': discussion_id,
...@@ -231,15 +240,23 @@ def single_thread(request, course_id, discussion_id, thread_id): ...@@ -231,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 = {'"': '"'}
...@@ -256,8 +273,8 @@ def single_thread(request, course_id, discussion_id, thread_id): ...@@ -256,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):
......
...@@ -1074,6 +1074,12 @@ body.discussion { ...@@ -1074,6 +1074,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,6 +13,14 @@ ...@@ -13,6 +13,14 @@
<div class="post-body"> <div class="post-body">
${'<%- body %>'} ${'<%- body %>'}
</div> </div>
${'<% if (obj.courseware_location) { %>'}
<div class="post-context">
(this post is about <a href="../../jump_to/${'<%- courseware_location %>'}">${'<%- courseware_title %>'}</a>)
</div>
${'<% } %>'}
<div class="post-status-closed" style="display: none">
This thread is closed.
</div>
<ul class="moderator-actions"> <ul class="moderator-actions">
<li style="display: none"><a class="action-edit" href="javascript:void(0)"><span class="edit-icon"></span> Edit</a></li> <li style="display: none"><a class="action-edit" href="javascript:void(0)"><span class="edit-icon"></span> Edit</a></li>
<li style="display: none"><a class="action-delete" href="javascript:void(0)"><span class="delete-icon"></span> Delete</a></li> <li style="display: none"><a class="action-delete" href="javascript:void(0)"><span class="delete-icon"></span> Delete</a></li>
......
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