admins can now clear flags inline

This commit is contained in:
Sam Saffron 2013-02-07 15:15:48 +11:00
parent 0f5bef61dc
commit c7461622a9
10 changed files with 86 additions and 10 deletions

View File

@ -259,6 +259,9 @@ Discourse.TopicController = Ember.ObjectController.extend Discourse.Presence,
post.toggleProperty('bookmarked') post.toggleProperty('bookmarked')
false false
clearFlags: (actionType) ->
actionType.clearFlags()
# Who acted on a particular post / action type # Who acted on a particular post / action type
whoActed: (actionType) -> whoActed: (actionType) ->
actionType.loadUsers() actionType.loadUsers()

View File

@ -18,7 +18,7 @@ window.Discourse.ActionSummary = Em.Object.extend Discourse.Presence,
@set('acted', false) @set('acted', false)
@set('count', @get('count') - 1) @set('count', @get('count') - 1)
@set('can_act', true) @set('can_act', true)
@set('can_undo', false) @set('can_undo', false)
# Perform this action # Perform this action
act: (opts) -> act: (opts) ->
@ -52,16 +52,28 @@ window.Discourse.ActionSummary = Em.Object.extend Discourse.Presence,
@removeAction() @removeAction()
# Remove our post action # Remove our post action
jQuery.ajax jQuery.ajax
url: "/post_actions/#{@get('post.id')}" url: "/post_actions/#{@get('post.id')}"
type: 'DELETE' type: 'DELETE'
data: data:
post_action_type_id: @get('id') post_action_type_id: @get('id')
clearFlags: ->
$.ajax
url: "/post_actions/clear_flags"
type: "POST"
data:
post_action_type_id: @get('id')
id: @get('post.id')
success: (result) =>
@set('post.hidden', result.hidden)
@set('count', 0)
loadUsers: -> loadUsers: ->
$.getJSON "/post_actions/users", $.getJSON "/post_actions/users",
id: @get('post.id'), id: @get('post.id'),
post_action_type_id: @get('id') post_action_type_id: @get('id')
(result) => (result) =>
@set('users', Em.A()) @set('users', Em.A())
result.each (u) => @get('users').pushObject(Discourse.User.create(u)) result.each (u) => @get('users').pushObject(Discourse.User.create(u))

View File

@ -35,12 +35,20 @@ window.Discourse.ActionsHistoryView = Em.View.extend Discourse.Presence,
if c.get('can_undo') if c.get('can_undo')
alsoName = Em.String.i18n("post.actions.undo", alsoName: c.get('actionType.alsoNameLower')) alsoName = Em.String.i18n("post.actions.undo", alsoName: c.get('actionType.alsoNameLower'))
buffer.push(" <a href='#' data-undo='#{c.get('id')}'>#{alsoName}</a>.") buffer.push(" <a href='#' data-undo='#{c.get('id')}'>#{alsoName}</a>.")
if c.get('can_clear_flags')
buffer.push(" <a href='#' data-clear-flags='#{c.get('id')}'>#{Em.String.i18n("post.actions.clear_flags",count: c.count)}</a>.")
buffer.push("</div>") buffer.push("</div>")
click: (e) -> click: (e) ->
$target = $(e.target) $target = $(e.target)
if actionTypeId = $target.data('clear-flags')
@get('controller').clearFlags(@content.findProperty('id', actionTypeId))
return false
# User wants to know who actioned it # User wants to know who actioned it
if actionTypeId = $target.data('who-acted') if actionTypeId = $target.data('who-acted')
@get('controller').whoActed(@content.findProperty('id', actionTypeId)) @get('controller').whoActed(@content.findProperty('id', actionTypeId))
@ -54,4 +62,4 @@ window.Discourse.ActionsHistoryView = Em.View.extend Discourse.Presence,
@get('controller').undoAction(@content.findProperty('id', actionTypeId)) @get('controller').undoAction(@content.findProperty('id', actionTypeId))
return false return false
false false

View File

@ -45,6 +45,21 @@ class PostActionsController < ApplicationController
render nothing: true render nothing: true
end end
def clear_flags
requires_parameter(:post_action_type_id)
raise Discourse::InvalidAccess unless guardian.is_admin?
PostAction.clear_flags!(@post, current_user.id, params[:post_action_type_id].to_i)
@post.reload
if @post.is_flagged?
render json: {success: true, hidden: true}
else
@post.unhide!
render json: {success: true, hidden: false}
end
end
private private
def fetch_post_from_params def fetch_post_from_params

View File

@ -250,6 +250,17 @@ class Post < ActiveRecord::Base
result result
end end
def is_flagged?
post_actions.where('post_action_type_id in (?) and deleted_at is null', PostActionType.FlagTypes).count != 0
end
def unhide!
self.hidden = false
self.hidden_reason_id = nil
self.topic.update_attributes(visible: true)
self.save
end
# Update the body of a post. Will create a new version when appropriate # Update the body of a post. Will create a new version when appropriate
def revise(updated_by, new_raw, opts={}) def revise(updated_by, new_raw, opts={})

View File

@ -47,10 +47,14 @@ class PostAction < ActiveRecord::Base
user_actions user_actions
end end
def self.clear_flags!(post, moderator_id) def self.clear_flags!(post, moderator_id, action_type_id = nil)
# -1 is the automatic system cleary # -1 is the automatic system cleary
actions = moderator_id == -1 ? PostActionType.AutoActionFlagTypes : PostActionType.FlagTypes actions = if action_type_id
[action_type_id]
else
moderator_id == -1 ? PostActionType.AutoActionFlagTypes : PostActionType.FlagTypes
end
PostAction.exec_sql('update post_actions set deleted_at = ?, deleted_by = ? PostAction.exec_sql('update post_actions set deleted_at = ?, deleted_by = ?
where post_id = ? and deleted_at is null and post_action_type_id in (?)', where post_id = ? and deleted_at is null and post_action_type_id in (?)',

View File

@ -140,6 +140,8 @@ class PostSerializer < ApplicationSerializer
next if !action_summary[:can_act] && !scope.current_user next if !action_summary[:can_act] && !scope.current_user
action_summary[:can_clear_flags] = scope.is_admin? && PostActionType.FlagTypes.include?(id)
if post_actions.present? and post_actions.has_key?(id) if post_actions.present? and post_actions.has_key?(id)
action_summary[:acted] = true action_summary[:acted] = true
action_summary[:can_undo] = scope.can_delete?(post_actions[id]) action_summary[:can_undo] = scope.can_delete?(post_actions[id])

View File

@ -853,6 +853,9 @@ en:
actions: actions:
flag: 'Flag' flag: 'Flag'
clear_flags:
one: "Clear flag"
other: "Clear flags"
it_too: "{{alsoName}} it too" it_too: "{{alsoName}} it too"
undo: "Undo {{alsoName}}" undo: "Undo {{alsoName}}"
by_you_and_others: by_you_and_others:

View File

@ -133,6 +133,7 @@ Discourse::Application.routes.draw do
resources :post_actions do resources :post_actions do
collection do collection do
get 'users' => 'post_actions#users' get 'users' => 'post_actions#users'
post 'clear_flags' => 'post_actions#clear_flags'
end end
end end
resources :user_actions resources :user_actions

View File

@ -54,12 +54,29 @@ describe Post do
topic.user.trust_level = TrustLevel.Levels[:moderator] topic.user.trust_level = TrustLevel.Levels[:moderator]
Fabricate.build(:post, post_args).should be_valid Fabricate.build(:post, post_args).should be_valid
end end
end end
end end
describe 'flagging helpers' do
it 'isFlagged is accurate' do
post = Fabricate(:post)
user = Fabricate(:coding_horror)
PostAction.act(user, post, PostActionType.Types[:off_topic])
PostAction.act(post.user, post, PostActionType.Types[:spam])
post.reload
post.is_flagged?.should == true
PostAction.remove_act(post.user, post, PostActionType.Types[:spam])
post.reload
post.is_flagged?.should == true
PostAction.remove_act(user, post, PostActionType.Types[:off_topic])
post.reload
post.is_flagged?.should == false
end
end
describe 'message bus' do describe 'message bus' do
it 'enqueues the post on the message bus' do it 'enqueues the post on the message bus' do