Sha256: 26f7d70324a07eacd7c34c9a5527c3e04bca2e9eff10d96d7c9980c3c152a6bc

Contents?: true

Size: 1.54 KB

Versions: 1

Compression:

Stored size: 1.54 KB

Contents

require 'acts_as_tokenizable/string_extensions'

module ActsAsTokenizable

  # default to_token method. needs to have a "name" property on the object.
  # override for more complex token generation
  def to_token
    raise NoMethodError.new("You must redefine to_token in your model. Example: self.name.to_token()")
  end

  #makes self.<token_field_name>=self.to_token
  def tokenize
    self.send("#{self.class.token_field_name}=", self.to_token)
  end

  module ClassMethods
    attr_accessor :token_field_name

    # search_token parameter is used by tokenized_by. This function allows for preparation
    # before tokenized_by function is invoked. Usually this means removing
    # stop words, replacing words.
    # By default it tokenizes each word and removes duplicates.
    def prepare_search_token(search_token)
      StringExtensions::words_to_token(search_token)
    end
  end

  def self.included(base)
    base.class_eval do
      extend ClassMethods

      named_scope :tokenized_by, lambda {|search_token|
        search_strings = []
        search_values = []
        StringExtensions::words(prepare_search_token(search_token)).each do |w|
          if w[0,1] == '-'
            search_strings.push("#{table_name}.#{token_field_name} NOT LIKE ?")
            search_values.push("%#{w[1,w.length]}%")
          else
            search_strings.push("#{table_name}.#{token_field_name} LIKE ?")
            search_values.push("%#{w}%")
          end
        end
        {:conditions => [search_strings.join(' AND '), *search_values]}
      }
    end
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
acts_as_tokenizable-0.4.0 lib/acts_as_tokenizable/acts_as_tokenizable.rb