We were very inconsistent regarding these rules. Personally I prefer no empty lines around blocks, clases, etc... as recommended by the Ruby style guide [1], and they're the default values in rubocop, so those are the settings I'm applying. The exception is the `private` access modifier, since we were leaving empty lines around it most of the time. That's the default rubocop rule as well. Personally I don't have a strong preference about this one. [1] https://rubystyle.guide/#empty-lines-around-bodies
34 lines
815 B
Ruby
34 lines
815 B
Ruby
module SearchCache
|
|
extend ActiveSupport::Concern
|
|
|
|
included do
|
|
after_save :calculate_tsvector
|
|
end
|
|
|
|
def calculate_tsvector
|
|
ActiveRecord::Base.connection.execute("
|
|
UPDATE #{self.class.table_name} SET tsv = (#{searchable_values_sql}) WHERE id = #{id}")
|
|
end
|
|
|
|
private
|
|
|
|
def searchable_values_sql
|
|
searchable_values
|
|
.select { |k, _| k.present? }
|
|
.collect { |value, weight| set_tsvector(value, weight) }
|
|
.join(" || ")
|
|
end
|
|
|
|
def set_tsvector(value, weight)
|
|
"setweight(to_tsvector('spanish', unaccent(coalesce(#{quote(strip_html(value))}, ''))), #{quote(weight)})"
|
|
end
|
|
|
|
def quote(value)
|
|
ActiveRecord::Base.connection.quote(value)
|
|
end
|
|
|
|
def strip_html(value)
|
|
ActionController::Base.helpers.sanitize(value, tags: [])
|
|
end
|
|
end
|