Module: Redmine::Acts::Watchable::InstanceMethods

Defined in:
lib/plugins/acts_as_watchable/lib/acts_as_watchable.rb

Overview

Since:

  • 0.5.1

Defined Under Namespace

Modules: ClassMethods

Instance Method Summary collapse

Instance Method Details

#add_watcher(user) ⇒ Object

Adds user as a watcher



40
41
42
43
44
# File 'lib/plugins/acts_as_watchable/lib/acts_as_watchable.rb', line 40

def add_watcher(user)
  # Rails does not reset the has_many :through association
  watcher_users.reset
  self.watchers << Watcher.new(:user => user)
end

#addable_watcher_usersObject

Returns an array of users that are proposed as watchers



31
32
33
34
35
36
37
# File 'lib/plugins/acts_as_watchable/lib/acts_as_watchable.rb', line 31

def addable_watcher_users
  users = self.project.users.sort - self.watcher_users
  if respond_to?(:visible?)
    users.reject! {|user| !visible?(user)}
  end
  users
end

#notified_watchersObject

Since:

  • 2.2.0



72
73
74
75
76
77
78
79
# File 'lib/plugins/acts_as_watchable/lib/acts_as_watchable.rb', line 72

def notified_watchers
  notified = watcher_users.active.to_a
  notified.reject! {|user| user.mail.blank? || user.mail_notification == 'none'}
  if respond_to?(:visible?)
    notified.reject! {|user| !visible?(user)}
  end
  notified
end

#remove_watcher(user) ⇒ Object

Removes user from the watchers list



47
48
49
50
51
52
# File 'lib/plugins/acts_as_watchable/lib/acts_as_watchable.rb', line 47

def remove_watcher(user)
  return nil unless user && user.is_a?(User)
  # Rails does not reset the has_many :through association
  watcher_users.reset
  watchers.where(:user_id => user.id).delete_all
end

#set_watcher(user, watching = true) ⇒ Object

Adds/removes watcher



55
56
57
# File 'lib/plugins/acts_as_watchable/lib/acts_as_watchable.rb', line 55

def set_watcher(user, watching=true)
  watching ? add_watcher(user) : remove_watcher(user)
end

#watched_by?(user) ⇒ Boolean

Returns true if object is watched by user

Returns:

  • (Boolean)


68
69
70
# File 'lib/plugins/acts_as_watchable/lib/acts_as_watchable.rb', line 68

def watched_by?(user)
  !!(user && self.watcher_user_ids.detect {|uid| uid == user.id })
end

#watcher_recipientsObject

Returns an array of watchers' email addresses



82
83
84
# File 'lib/plugins/acts_as_watchable/lib/acts_as_watchable.rb', line 82

def watcher_recipients
  notified_watchers.collect(&:mail)
end

#watcher_user_ids=(user_ids) ⇒ Object

Overrides watcher_user_ids= to make user_ids uniq

Since:

  • 3.4.0



60
61
62
63
64
65
# File 'lib/plugins/acts_as_watchable/lib/acts_as_watchable.rb', line 60

def watcher_user_ids=(user_ids)
  if user_ids.is_a?(Array)
    user_ids = user_ids.uniq
  end
  super user_ids
end