Commit 26536902 by David Ormsbee

Merge pull request #520 from MITx/feature/rocky/discussion

add user profile and fixed edit
parents 22cbc1bd 6de05997
...@@ -21,7 +21,6 @@ from django.contrib.auth.models import User ...@@ -21,7 +21,6 @@ from django.contrib.auth.models import User
from mitxmako.shortcuts import render_to_response, render_to_string from mitxmako.shortcuts import render_to_response, render_to_string
from courseware.courses import get_course_with_access from courseware.courses import get_course_with_access
from django_comment_client.utils import JsonResponse, JsonError, extract from django_comment_client.utils import JsonResponse, JsonError, extract
from django_comment_client.permissions import check_permissions_by_view from django_comment_client.permissions import check_permissions_by_view
...@@ -282,7 +281,7 @@ def update_moderator_status(request, course_id, user_id): ...@@ -282,7 +281,7 @@ def update_moderator_status(request, course_id, user_id):
'course_id': course_id, 'course_id': course_id,
'user': request.user, 'user': request.user,
'django_user': user, 'django_user': user,
'discussion_user': discussion_user.to_dict(), 'profiled_user': discussion_user.to_dict(),
} }
return JsonResponse({ return JsonResponse({
'html': render_to_string('discussion/ajax_user_profile.html', context) 'html': render_to_string('discussion/ajax_user_profile.html', context)
...@@ -298,10 +297,13 @@ def search_similar_threads(request, course_id, commentable_id): ...@@ -298,10 +297,13 @@ def search_similar_threads(request, course_id, commentable_id):
'text': text, 'text': text,
'commentable_id': commentable_id, 'commentable_id': commentable_id,
} }
result = cc.search_similar_threads(course_id, recursive=False, query_params=query_params) threads = cc.search_similar_threads(course_id, recursive=False, query_params=query_params)
return JsonResponse(result)
else: else:
return JsonResponse([]) theads = []
context = { 'threads': map(utils.extend_content, threads) }
return JsonResponse({
'html': render_to_string('discussion/_similar_posts.html', context)
})
@require_GET @require_GET
def tags_autocomplete(request, course_id): def tags_autocomplete(request, course_id):
...@@ -334,8 +336,8 @@ def upload(request, course_id):#ajax upload file to a question or answer ...@@ -334,8 +336,8 @@ def upload(request, course_id):#ajax upload file to a question or answer
# check file type # check file type
f = request.FILES['file-upload'] f = request.FILES['file-upload']
file_extension = os.path.splitext(f.name)[1].lower() file_extension = os.path.splitext(f.name)[1].lower()
if not file_extension in settings.DISCUSSION_ALLOWED_UPLOAD_FILE_TYPES: if not file_extension in cc_settings.ALLOWED_UPLOAD_FILE_TYPES:
file_types = "', '".join(settings.DISCUSSION_ALLOWED_UPLOAD_FILE_TYPES) file_types = "', '".join(cc_settings.ALLOWED_UPLOAD_FILE_TYPES)
msg = _("allowed file types are '%(file_types)s'") % \ msg = _("allowed file types are '%(file_types)s'") % \
{'file_types': file_types} {'file_types': file_types}
raise exceptions.PermissionDenied(msg) raise exceptions.PermissionDenied(msg)
...@@ -354,15 +356,16 @@ def upload(request, course_id):#ajax upload file to a question or answer ...@@ -354,15 +356,16 @@ def upload(request, course_id):#ajax upload file to a question or answer
# check file size # check file size
# byte # byte
size = file_storage.size(new_file_name) size = file_storage.size(new_file_name)
if size > settings.ASKBOT_MAX_UPLOAD_FILE_SIZE: if size > cc_settings.MAX_UPLOAD_FILE_SIZE:
file_storage.delete(new_file_name) file_storage.delete(new_file_name)
msg = _("maximum upload file size is %(file_size)sK") % \ msg = _("maximum upload file size is %(file_size)sK") % \
{'file_size': settings.ASKBOT_MAX_UPLOAD_FILE_SIZE} {'file_size': cc_settings.MAX_UPLOAD_FILE_SIZE}
raise exceptions.PermissionDenied(msg) raise exceptions.PermissionDenied(msg)
except exceptions.PermissionDenied, e: except exceptions.PermissionDenied, e:
error = unicode(e) error = unicode(e)
except Exception, e: except Exception, e:
print e
logging.critical(unicode(e)) logging.critical(unicode(e))
error = _('Error uploading file. Please contact the site administrator. Thank you.') error = _('Error uploading file. Please contact the site administrator. Thank you.')
......
...@@ -83,7 +83,7 @@ def render_discussion(request, course_id, threads, *args, **kwargs): ...@@ -83,7 +83,7 @@ def render_discussion(request, course_id, threads, *args, **kwargs):
'base_url': base_url, 'base_url': base_url,
'query_params': strip_blank(strip_none(extract(query_params, ['page', 'sort_key', 'sort_order', 'tags', 'text']))), 'query_params': strip_blank(strip_none(extract(query_params, ['page', 'sort_key', 'sort_order', 'tags', 'text']))),
'annotated_content_info': json.dumps(annotated_content_info), 'annotated_content_info': json.dumps(annotated_content_info),
'discussion_data': json.dumps({ discussion_id: threads }), 'discussion_data': json.dumps({ (discussion_id or user_id): threads })
} }
context = dict(context.items() + query_params.items()) context = dict(context.items() + query_params.items())
return render_to_string(template, context) return render_to_string(template, context)
...@@ -250,7 +250,10 @@ def user_profile(request, course_id, user_id): ...@@ -250,7 +250,10 @@ def user_profile(request, course_id, user_id):
content = render_user_discussion(request, course_id, threads, user_id=user_id, query_params=query_params) content = render_user_discussion(request, course_id, threads, user_id=user_id, query_params=query_params)
if request.is_ajax(): if request.is_ajax():
return utils.HtmlResponse(content) return utils.JsonResponse({
'html': content,
'discussionData': threads,
})
else: else:
context = { context = {
'course': course, 'course': course,
......
...@@ -12,7 +12,7 @@ import urllib ...@@ -12,7 +12,7 @@ import urllib
import os import os
def pluralize(singular_term, count): def pluralize(singular_term, count):
if int(count) >= 2: if int(count) >= 2 or int(count) == 0:
return singular_term + 's' return singular_term + 's'
return singular_term return singular_term
...@@ -33,24 +33,10 @@ def include_mustache_templates(): ...@@ -33,24 +33,10 @@ def include_mustache_templates():
file_contents = map(read_file, filter(valid_file_name, os.listdir(mustache_dir))) file_contents = map(read_file, filter(valid_file_name, os.listdir(mustache_dir)))
return '\n'.join(map(wrap_in_tag, map(strip_file_name, file_contents))) return '\n'.join(map(wrap_in_tag, map(strip_file_name, file_contents)))
def permalink(content):
if content['type'] == 'thread':
return reverse('django_comment_client.forum.views.single_thread',
args=[content['course_id'], content['commentable_id'], content['id']])
else:
return reverse('django_comment_client.forum.views.single_thread',
args=[content['course_id'], content['commentable_id'], content['thread_id']]) + '#' + content['id']
def render_content(content, additional_context={}): def render_content(content, additional_context={}):
content_info = {
'displayed_title': content.get('highlighted_title') or content.get('title', ''),
'displayed_body': content.get('highlighted_body') or content.get('body', ''),
'raw_tags': ','.join(content.get('tags', [])),
'permalink': permalink(content),
}
context = { context = {
'content': merge_dict(content, content_info), 'content': extend_content(content),
content['type']: True, content['type']: True,
} }
context = merge_dict(context, additional_context) context = merge_dict(context, additional_context)
......
...@@ -7,7 +7,8 @@ import inspect ...@@ -7,7 +7,8 @@ import inspect
def pluralize(content, text): def pluralize(content, text):
num, word = text.split(' ') num, word = text.split(' ')
if int(num or '0') >= 2: num = int(num or '0')
if num >= 2 or num == 0:
return word + 's' return word + 's'
else: else:
return word return word
......
from django.conf import settings
MAX_COMMENT_DEPTH = None
MAX_UPLOAD_FILE_SIZE = 1024 * 1024 #result in bytes
ALLOWED_UPLOAD_FILE_TYPES = ('.jpg', '.jpeg', '.gif', '.bmp', '.png', '.tiff')
if hasattr(settings, 'DISCUSSION_SETTINGS'):
MAX_COMMENT_DEPTH = settings.DISCUSSION_SETTINGS.get('MAX_COMMENT_DEPTH')
MAX_UPLOAD_FILE_SIZE = settings.DISCUSSION_SETTINGS.get('MAX_UPLOAD_FILE_SIZE') or MAX_UPLOAD_FILE_SIZE
ALLOWED_UPLOAD_FILE_TYPES = settings.DISCUSSION_SETTINGS.get('ALLOWED_UPLOAD_FILE_TYPES') or ALLOWED_UPLOAD_FILE_TYPES
...@@ -197,3 +197,20 @@ def url_for_tags(course_id, tags): ...@@ -197,3 +197,20 @@ def url_for_tags(course_id, tags):
def render_mustache(template_name, dictionary, *args, **kwargs): def render_mustache(template_name, dictionary, *args, **kwargs):
template = middleware.lookup['main'].get_template(template_name).source template = middleware.lookup['main'].get_template(template_name).source
return pystache.render(template, dictionary) return pystache.render(template, dictionary)
def permalink(content):
if content['type'] == 'thread':
return reverse('django_comment_client.forum.views.single_thread',
args=[content['course_id'], content['commentable_id'], content['id']])
else:
return reverse('django_comment_client.forum.views.single_thread',
args=[content['course_id'], content['commentable_id'], content['thread_id']]) + '#' + content['id']
def extend_content(content):
content_info = {
'displayed_title': content.get('highlighted_title') or content.get('title', ''),
'displayed_body': content.get('highlighted_body') or content.get('body', ''),
'raw_tags': ','.join(content.get('tags', [])),
'permalink': permalink(content),
}
return merge_dict(content, content_info)
class @Content extends Backbone.Model if Backbone?
class @Content extends Backbone.Model
template: -> DiscussionUtil.getTemplate('_content') template: -> DiscussionUtil.getTemplate('_content')
...@@ -49,7 +50,7 @@ class @Content extends Backbone.Model ...@@ -49,7 +50,7 @@ class @Content extends Backbone.Model
@resetComments(@get('children')) @resetComments(@get('children'))
class @ContentView extends Backbone.View class @ContentView extends Backbone.View
$: (selector) -> $: (selector) ->
@$local.find(selector) @$local.find(selector)
...@@ -256,7 +257,7 @@ class @ContentView extends Backbone.View ...@@ -256,7 +257,7 @@ class @ContentView extends Backbone.View
else else
view.body = @$(".comment-raw-body").html() view.body = @$(".comment-raw-body").html()
@$discussionContent().append Mustache.render DiscussionUtil.getTemplate("_edit_#{@model.get('type')}"), view @$discussionContent().append Mustache.render DiscussionUtil.getTemplate("_edit_#{@model.get('type')}"), view
Discussion.makeWmdEditor @$el, $.proxy(@$, @), "#{@model.get('type')}-body-edit" DiscussionUtil.makeWmdEditor @$el, $.proxy(@$, @), "#{@model.get('type')}-body-edit"
@$(".thread-tags-edit").tagsInput DiscussionUtil.tagsInputOptions() @$(".thread-tags-edit").tagsInput DiscussionUtil.tagsInputOptions()
@$(".discussion-submit-update").unbind("click").click $.proxy(@submitEdit, @) @$(".discussion-submit-update").unbind("click").click $.proxy(@submitEdit, @)
@$(".discussion-cancel-update").unbind("click").click $.proxy(@cancelEdit, @) @$(".discussion-cancel-update").unbind("click").click $.proxy(@cancelEdit, @)
...@@ -332,9 +333,6 @@ class @ContentView extends Backbone.View ...@@ -332,9 +333,6 @@ class @ContentView extends Backbone.View
initTimeago: -> initTimeago: ->
@$("span.timeago").timeago() @$("span.timeago").timeago()
initPermalink: ->
@$(".discussion-permanent-link").attr "href", @model.permalink()
renderPartial: -> renderPartial: ->
for attr, value of @model.changedAttributes() for attr, value of @model.changedAttributes()
if @partial[attr] if @partial[attr]
...@@ -352,7 +350,7 @@ class @ContentView extends Backbone.View ...@@ -352,7 +350,7 @@ class @ContentView extends Backbone.View
@initBody() @initBody()
@initCommentViews() @initCommentViews()
class @Thread extends @Content class @Thread extends @Content
urlMappers: urlMappers:
'retrieve' : -> DiscussionUtil.urlFor('retrieve_single_thread', @discussion.id, @id) 'retrieve' : -> DiscussionUtil.urlFor('retrieve_single_thread', @discussion.id, @id)
'reply' : -> DiscussionUtil.urlFor('create_comment', @id) 'reply' : -> DiscussionUtil.urlFor('create_comment', @id)
...@@ -369,13 +367,9 @@ class @Thread extends @Content ...@@ -369,13 +367,9 @@ class @Thread extends @Content
@set('thread', @) @set('thread', @)
super() super()
permalink: -> class @ThreadView extends @ContentView
discussion_id = @get('commentable_id')
return Discussion.urlFor("permanent_link_thread", discussion_id, @id)
class @ThreadView extends @ContentView
class @Comment extends @Content class @Comment extends @Content
urlMappers: urlMappers:
'reply': -> DiscussionUtil.urlFor('create_sub_comment', @id) 'reply': -> DiscussionUtil.urlFor('create_sub_comment', @id)
'unvote': -> DiscussionUtil.urlFor("undo_vote_for_#{@get('type')}", @id) 'unvote': -> DiscussionUtil.urlFor("undo_vote_for_#{@get('type')}", @id)
...@@ -385,20 +379,15 @@ class @Comment extends @Content ...@@ -385,20 +379,15 @@ class @Comment extends @Content
'update': -> DiscussionUtil.urlFor('update_comment', @id) 'update': -> DiscussionUtil.urlFor('update_comment', @id)
'delete': -> DiscussionUtil.urlFor('delete_comment', @id) 'delete': -> DiscussionUtil.urlFor('delete_comment', @id)
permalink: ->
thread_id = @get('thread').id
discussion_id = @get('thread').get('commentable_id')
return Discussion.urlFor("permanent_link_comment", discussion_id, thread_id, @id)
getCommentsCount: -> getCommentsCount: ->
count = 0 count = 0
@get('comments').each (comment) -> @get('comments').each (comment) ->
count += comment.getCommentsCount() + 1 count += comment.getCommentsCount() + 1
count count
class @CommentView extends @ContentView class @CommentView extends @ContentView
class @Comments extends Backbone.Collection class @Comments extends Backbone.Collection
model: Comment model: Comment
......
class @Discussion extends Backbone.Collection if Backbone?
class @Discussion extends Backbone.Collection
model: Thread model: Thread
initialize: -> initialize: ->
...@@ -15,7 +16,7 @@ class @Discussion extends Backbone.Collection ...@@ -15,7 +16,7 @@ class @Discussion extends Backbone.Collection
@add model @add model
model model
class @DiscussionView extends Backbone.View class @DiscussionView extends Backbone.View
$: (selector) -> $: (selector) ->
@$local.find(selector) @$local.find(selector)
...@@ -45,8 +46,10 @@ class @DiscussionView extends Backbone.View ...@@ -45,8 +46,10 @@ class @DiscussionView extends Backbone.View
@model.reset(response.discussionData, { silent: false }) @model.reset(response.discussionData, { silent: false })
view = new DiscussionView el: $discussion[0], model: @model view = new DiscussionView el: $discussion[0], model: @model
DiscussionUtil.bulkUpdateContentInfo(window.$$annotated_content_info) DiscussionUtil.bulkUpdateContentInfo(window.$$annotated_content_info)
$("html, body").animate({ scrollTop: 0 }, 0)
loadSimilarPost: (event) -> loadSimilarPost: (event) ->
console.log "loading similar"
$title = @$(".new-post-title") $title = @$(".new-post-title")
$wrapper = @$(".new-post-similar-posts-wrapper") $wrapper = @$(".new-post-similar-posts-wrapper")
$similarPosts = @$(".new-post-similar-posts") $similarPosts = @$(".new-post-similar-posts")
...@@ -59,16 +62,16 @@ class @DiscussionView extends Backbone.View ...@@ -59,16 +62,16 @@ class @DiscussionView extends Backbone.View
$elem = $(event.target) $elem = $(event.target)
url = DiscussionUtil.urlFor 'search_similar_threads', @model.id url = DiscussionUtil.urlFor 'search_similar_threads', @model.id
data = { text: @$(".new-post-title").val() } data = { text: @$(".new-post-title").val() }
DiscussionUtil.get $elem, url, data, (response, textStatus) => DiscussionUtil.safeAjax
$similarPosts.empty() $elem: $elem
if $.type(response) == "array" and response.length url: url
data: data
dataType: 'json'
success: (response, textStatus) =>
$wrapper.html(response.html)
if $wrapper.find(".similar-post").length
$wrapper.show() $wrapper.show()
for thread in response $wrapper.find(".hide-similar-posts").click =>
$similarPost = $("<a>").addClass("similar-post")
.html(thread["title"])
.attr("href", "javascript:void(0)") #TODO
.appendTo($similarPosts)
else
$wrapper.hide() $wrapper.hide()
else else
$wrapper.hide() $wrapper.hide()
...@@ -127,7 +130,9 @@ class @DiscussionView extends Backbone.View ...@@ -127,7 +130,9 @@ class @DiscussionView extends Backbone.View
$thread = $(response.html) $thread = $(response.html)
@$el.children(".threads").prepend($thread) @$el.children(".threads").prepend($thread)
@$(".new-post-title").val("") @$(".new-post-similar-posts").empty()
@$(".new-post-similar-posts-wrapper").hide()
@$(".new-post-title").val("").attr("prev-text", "")
DiscussionUtil.setWmdContent @$el, $.proxy(@$, @), "new-post-body", "" DiscussionUtil.setWmdContent @$el, $.proxy(@$, @), "new-post-body", ""
@$(".new-post-tags").val("") @$(".new-post-tags").val("")
@$(".new-post-tags").importTags("") @$(".new-post-tags").importTags("")
......
class @DiscussionModuleView extends Backbone.View if Backbone?
class @DiscussionModuleView extends Backbone.View
events: events:
"click .discussion-show": "toggleDiscussion" "click .discussion-show": "toggleDiscussion"
toggleDiscussion: (event) -> toggleDiscussion: (event) ->
...@@ -15,7 +16,7 @@ class @DiscussionModuleView extends Backbone.View ...@@ -15,7 +16,7 @@ class @DiscussionModuleView extends Backbone.View
$elem = $(event.target) $elem = $(event.target)
discussion_id = $elem.attr("discussion_id") discussion_id = $elem.attr("discussion_id")
url = DiscussionUtil.urlFor 'retrieve_discussion', discussion_id url = DiscussionUtil.urlFor 'retrieve_discussion', discussion_id
Discussion.safeAjax DiscussionUtil.safeAjax
$elem: $elem $elem: $elem
url: url url: url
type: "GET" type: "GET"
......
...@@ -12,4 +12,10 @@ $ -> ...@@ -12,4 +12,10 @@ $ ->
discussion.reset(discussionData, {silent: false}) discussion.reset(discussionData, {silent: false})
view = new DiscussionView(el: elem, model: discussion) view = new DiscussionView(el: elem, model: discussion)
if window.$$annotated_content_info?
DiscussionUtil.bulkUpdateContentInfo(window.$$annotated_content_info) DiscussionUtil.bulkUpdateContentInfo(window.$$annotated_content_info)
$userProfile = $(".discussion-sidebar>.user-profile")
if $userProfile.length
console.log "initialize user profile"
view = new DiscussionUserProfileView(el: $userProfile[0])
if not @Discussion? class @DiscussionUserProfileView extends Backbone.View
@Discussion = {} toggleModeratorStatus: (event) ->
Discussion = @Discussion
@Discussion = $.extend @Discussion,
initializeUserProfile: ($userProfile) ->
$local = Discussion.generateLocal $userProfile
handleUpdateModeratorStatus = (elem, isModerator) ->
confirmValue = confirm("Are you sure?") confirmValue = confirm("Are you sure?")
if not confirmValue then return if not confirmValue then return
url = Discussion.urlFor('update_moderator_status', $$profiled_user_id) $elem = $(event.target)
Discussion.safeAjax if $elem.hasClass("sidebar-promote-moderator-button")
$elem: $(elem) isModerator = true
else if $elem.hasClass("sidebar-revoke-moderator-button")
isModerator = false
else
console.error "unrecognized moderator status"
return
url = DiscussionUtil.urlFor('update_moderator_status', $$profiled_user_id)
DiscussionUtil.safeAjax
$elem: $elem
url: url url: url
type: "POST" type: "POST"
dataType: 'json' dataType: 'json'
...@@ -20,15 +20,10 @@ Discussion = @Discussion ...@@ -20,15 +20,10 @@ Discussion = @Discussion
is_moderator: isModerator is_moderator: isModerator
error: (response, textStatus, e) -> error: (response, textStatus, e) ->
console.log e console.log e
success: (response, textStatus) -> success: (response, textStatus) =>
parent = $userProfile.parent() parent = @$el.parent()
$userProfile.replaceWith(response.html) @$el.replaceWith(response.html)
Discussion.initializeUserProfile parent.children(".user-profile") view = new DiscussionUserProfileView el: parent.children(".user-profile")
Discussion.bindLocalEvents $local,
"click .sidebar-revoke-moderator-button": (event) ->
handleUpdateModeratorStatus(this, false)
"click .sidebar-promote-moderator-button": (event) ->
handleUpdateModeratorStatus(this, true)
initializeUserActiveDiscussion: ($discussion) -> events:
"click .sidebar-toggle-moderator-button": "toggleModeratorStatus"
...@@ -22,6 +22,7 @@ ...@@ -22,6 +22,7 @@
## <script type="text/javascript" src="${static.url('js/vendor/CodeMirror-2.25/mode/python/python.js')}"></script> ## <script type="text/javascript" src="${static.url('js/vendor/CodeMirror-2.25/mode/python/python.js')}"></script>
<%static:js group='courseware'/> <%static:js group='courseware'/>
<%static:js group='discussion'/>
<%include file="../discussion/_js_body_dependencies.html" /> <%include file="../discussion/_js_body_dependencies.html" />
......
<%! import django_comment_client.helpers as helpers %> <%! import django_comment_client.helpers as helpers %>
<%def name="render_content(content)"> <%def name="render_content(content, *args, **kwargs)">
${helpers.render_content(content)} ${helpers.render_content(content, *args, **kwargs)}
</%def> </%def>
<%def name="render_content_with_comments(content)"> <%def name="render_content_with_comments(content, *args, **kwargs)">
<div class="${content['type']}${helpers.show_if(' endorsed', content.get('endorsed'))}" _id="${content['id']}" _discussion_id="${content.get('commentable_id', '')}" _author_id="${helpers.show_if(content['user_id'], not content.get('anonymous'))}"> <div class="${content['type']}${helpers.show_if(' endorsed', content.get('endorsed'))}" _id="${content['id']}" _discussion_id="${content.get('commentable_id', '')}" _author_id="${helpers.show_if(content['user_id'], not content.get('anonymous'))}">
${render_content(content)} ${render_content(content, *args, **kwargs)}
${render_comments(content.get('children', []))} ${render_comments(content.get('children', []), *args, **kwargs)}
</div> </div>
</%def> </%def>
<%def name="render_comments(comments)"> <%def name="render_comments(comments, *args, **kwargs)">
<div class="comments"> <div class="comments">
% for comment in comments: % for comment in comments:
${render_content_with_comments(comment)} ${render_content_with_comments(comment, *args, **kwargs)}
% endfor % endfor
</div> </div>
</%def> </%def>
% if len(threads) > 0:
Similar Posts:
<a class="hide-similar-posts" href="javascript:void(0)">Hide</a>
<div class="new-post-similar-posts">
% for thread in threads:
<a class="similar-post" href="${thread['permalink']}">${thread['title']}</a>
% endfor
</div>
% endif
<%namespace name="renderer" file="_thread.html"/> <%namespace name="renderer" file="_content_renderer.html"/>
<section class="discussion user-active-discussion"> <section class="discussion user-active-discussion" _id="${user_id}">
<div class="discussion-non-content discussion-local"></div> <div class="discussion-non-content local"></div>
<div class="threads"> <div class="threads">
% for thread in threads: % for thread in threads:
${renderer.render_thread(course_id, thread, show_comments=True)} ${renderer.render_content_with_comments(thread, {'partial_comments': True})}
% endfor % endfor
</div> </div>
......
<%! from django_comment_client.utils import pluralize %> <%! from django_comment_client.helpers import pluralize %>
<%! from django_comment_client.permissions import has_permission, check_permissions_by_view %> <%! from django_comment_client.permissions import has_permission, check_permissions_by_view %>
<%! from operator import attrgetter %> <%! from operator import attrgetter %>
...@@ -15,9 +15,9 @@ ...@@ -15,9 +15,9 @@
<div class="sidebar-comments-count"><span>${profiled_user['comments_count']}</span> ${pluralize('comment', profiled_user['comments_count'])}</div> <div class="sidebar-comments-count"><span>${profiled_user['comments_count']}</span> ${pluralize('comment', profiled_user['comments_count'])}</div>
% if check_permissions_by_view(user, course.id, content=None, name='update_moderator_status'): % if check_permissions_by_view(user, course.id, content=None, name='update_moderator_status'):
% if "Moderator" in role_names: % if "Moderator" in role_names:
<a href="javascript:void(0)" class="sidebar-revoke-moderator-button">Revoke Moderator provileges</a> <a href="javascript:void(0)" class="sidebar-toggle-moderator-button sidebar-revoke-moderator-button">Revoke Moderator provileges</a>
% else: % else:
<a href="javascript:void(0)" class="sidebar-promote-moderator-button">Promote to Moderator</a> <a href="javascript:void(0)" class="sidebar-toggle-moderator-button sidebar-promote-moderator-button">Promote to Moderator</a>
% endif % endif
% endif % endif
</div> </div>
<%inherit file="../main.html" /> <%inherit file="../main.html" />
<%namespace name='static' file='../static_content.html'/> <%namespace name='static' file='../static_content.html'/>
<%block name="bodyclass">discussion</%block> <%block name="bodyclass">discussion</%block>
<%block name="title"><title>Discussion – MITx 6.002x</title></%block> <%block name="title"><title>Discussion – ${course.number}</title></%block>
<%block name="headextra"> <%block name="headextra">
<%static:css group='course'/> <%static:css group='course'/>
......
...@@ -37,7 +37,7 @@ ...@@ -37,7 +37,7 @@
anonymous anonymous
{{/content.anonymous}} {{/content.anonymous}}
{{^content.anonymous}} {{^content.anonymous}}
{{content.username}} <a href="{{##url_for_user}}{{content.user_id}}{{/url_for_user}}">{{content.username}}</a>
{{/content.anonymous}} {{/content.anonymous}}
</div> </div>
<div class="show-comments-wrapper"> <div class="show-comments-wrapper">
......
<form class="new-post-form collapsed" id="new-post-form" style="display: block; "> <form class="new-post-form collapsed" id="new-post-form" style="display: block; ">
<ul class="new-post-form-errors discussion-errors"></ul> <ul class="new-post-form-errors discussion-errors"></ul>
<input type="text" class="new-post-title title-input" placeholder="Title" /> <input type="text" class="new-post-title title-input" placeholder="Title" />
<div class="new-post-similar-posts-wrapper" style="display: none"> <div class="new-post-similar-posts-wrapper" style="display: none"></div>
Similar Posts:
<a class="hide-similar-posts" href="javascript:void(0)">Hide</a>
<div class="new-post-similar-posts"></div>
</div>
<div class="new-post-body reply-body"></div> <div class="new-post-body reply-body"></div>
<input class="new-post-tags" placeholder="Tags" /> <input class="new-post-tags" placeholder="Tags" />
<div class="post-options"> <div class="post-options">
......
<%inherit file="../main.html" /> <%inherit file="../main.html" />
<%namespace name='static' file='../static_content.html'/> <%namespace name='static' file='../static_content.html'/>
<%block name="bodyclass">discussion</%block> <%block name="bodyclass">discussion</%block>
<%block name="title"><title>Discussion – MITx 6.002x</title></%block> <%block name="title"><title>Discussion – ${course.number}</title></%block>
<%block name="headextra"> <%block name="headextra">
<%static:css group='course'/> <%static:css group='course'/>
......
<%! from django.template.defaultfilters import escapejs %> <%! from django.template.defaultfilters import escapejs %>
<%namespace name="renderer" file="_thread.html"/>
<%inherit file="../main.html" /> <%inherit file="../main.html" />
<%namespace name='static' file='../static_content.html'/> <%namespace name='static' file='../static_content.html'/>
<%block name="bodyclass">discussion</%block> <%block name="bodyclass">discussion</%block>
<%block name="title"><title>Discussion – MITx 6.002x</title></%block> <%block name="title"><title>Discussion – ${course.number}</title></%block>
<%block name="headextra"> <%block name="headextra">
<%static:css group='course'/> <%static:css group='course'/>
<%include file="_js_head_dependencies.html" />
</%block> </%block>
<%block name="js_extra"> <%block name="js_extra">
<%include file="_js_dependencies.html" /> <%include file="_js_body_dependencies.html" />
<%static:js group='discussion'/>
</%block> </%block>
<%include file="/courseware/course_navigation.html" args="active_page='discussion'" /> <%include file="../courseware/course_navigation.html" args="active_page='discussion'" />
<section class="container"> <section class="container">
<div class="course-wrapper"> <div class="course-wrapper">
......
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