Module: MakeTaggable::Tagger::InstanceMethods

Defined in:
lib/make_taggable/tagger.rb

Instance Method Summary collapse

Instance Method Details

#is_tagger?Boolean

Returns:

  • (Boolean)


74
75
76
# File 'lib/make_taggable/tagger.rb', line 74

def is_tagger?
  tagger?
end

#tag(taggable, opts = {}) ⇒ Object

Tag a taggable model with tags that are owned by the tagger.

Example:

@user.tag(@photo, :with => "paris, normandy", :on => :locations)

Parameters:

  • taggable

    The object that will be tagged

  • options (Hash)

    An hash with options. Available options are:

    • :with - The tags that you want to

    • :on - The context on which you want to tag



57
58
59
60
61
62
63
64
65
66
67
68
# File 'lib/make_taggable/tagger.rb', line 57

def tag(taggable, opts = {})
  opts.reverse_merge!(force: true)
  skip_save = opts.delete(:skip_save)
  return false unless taggable.respond_to?(:is_taggable?) && taggable.is_taggable?

  fail "You need to specify a tag context using :on" unless opts.key?(:on)
  fail "You need to specify some tags using :with" unless opts.key?(:with)
  fail "No context :#{opts[:on]} defined in #{taggable.class}" unless opts[:force] || taggable.tag_types.include?(opts[:on])

  taggable.set_owner_tag_list_on(self, opts[:on].to_s, opts[:with])
  taggable.save unless skip_save
end

#tagger?Boolean

Returns:

  • (Boolean)


70
71
72
# File 'lib/make_taggable/tagger.rb', line 70

def tagger?
  self.class.is_tagger?
end