merge master

This commit is contained in:
xdite
2013-02-13 15:16:39 +08:00
260 changed files with 3643 additions and 759 deletions
@@ -29,6 +29,7 @@
thisMousePos = mousePosition(e).y
size = originalDivHeight + (originalPos - thisMousePos)
lastMousePos = thisMousePos
size = Math.min(size, $(window).height())
size = Math.max(min, size)
div.height size + "px"
endDrag e,opts if size < min
@@ -173,6 +173,27 @@ window.Discourse.Post = Ember.Object.extend Discourse.Presence,
loadVersions: (callback) ->
$.get "/posts/#{@get('id')}/versions.json", (result) -> callback(result)
# Whether to show replies directly below
showRepliesBelow: (->
reply_count = @get('reply_count')
# We don't show replies if there aren't any
return false if reply_count is 0
# Always show replies if the setting `supress_reply_directly_below` is false.
return true unless Discourse.SiteSettings.supress_reply_directly_below
# Always show replies if there's more than one
return true if reply_count > 1
# If we have *exactly* one reply, we have to consider if it's directly below us
return false if @get('topic')?.isReplyDirectlyBelow(@)
true
).property('reply_count')
window.Discourse.Post.reopenClass
REGULAR_TYPE: <%= Post::REGULAR %>
@@ -243,6 +243,18 @@ Discourse.Topic = Discourse.Model.extend Discourse.Presence,
newPosts.each (p)->
posts.pushObject(p) unless map[p.get('post_number')]
# Is the reply to a post directly below it?
isReplyDirectlyBelow: (post) ->
posts = @get('posts')
return unless posts
postBelow = posts[posts.indexOf(post) + 1]
# If the post directly below's reply_to_post_number is our post number, it's
# considered directly below.
return postBelow?.get('reply_to_post_number') is post.get('post_number')
window.Discourse.Topic.reopenClass
NotificationLevel:
@@ -1,10 +1,13 @@
window.Discourse.ListCategoryRoute = Discourse.FilteredListRoute.extend
serialize: (params) -> slug: params.get('slug')
setupController: (controller, model) ->
slug = Em.get(model, 'slug')
category = Discourse.get('site.categories').findProperty('slug', slug)
category ||= Discourse.Category.create(name: slug, slug: slug)
listController = @controllerFor('list')
listController.set('filterMode', "category/#{model.slug}")
listController.load("category/#{model.slug}").then (topicList) =>
listController.set('filterMode', "category/#{category.get('slug')}")
listController.load("category/#{category.get('slug')}").then (topicList) =>
listController.set('canCreateTopic', topicList.get('can_create_topic'))
listController.set('category', Discourse.Category.create(name: model.slug))
listController.set('category',category)
@controllerFor('listTopics').set('content', topicList)
@@ -26,15 +26,13 @@ window.Discourse.PostMenuView = Ember.View.extend Discourse.Presence,
# Trigger re rendering
needsToRender: (->
@rerender()
).observes('post.deleted_at', 'post.flagsAvailable.@each', 'post.url', 'post.bookmarked', 'post.reply_count', 'post.can_delete')
).observes('post.deleted_at', 'post.flagsAvailable.@each', 'post.url', 'post.bookmarked', 'post.reply_count', 'post.showRepliesBelow', 'post.can_delete')
# Replies Button
renderReplies: (post, buffer) ->
return if @get('post.replyFollowing')
return unless post.get('showRepliesBelow')
reply_count = post.get('reply_count')
return if reply_count == 0
buffer.push("<button class='show-replies' data-action='replies'>")
buffer.push("<span class='badge-posts'>#{reply_count}</span>")
@@ -97,7 +95,6 @@ window.Discourse.PostMenuView = Ember.View.extend Discourse.Presence,
clickReply: -> @get('controller').replyToPost(@get('post'))
# Bookmark button
renderBookmark: (post, buffer) ->
return unless Discourse.get('currentUser')