class PgSearch::Configuration::Association

def initialize(model, name, column_names)

def initialize(model, name, column_names)
  @model = model
  @name = name
  @columns = Array(column_names).map do |column_name, weight|
    Column.new(column_name, weight, @model, self)
  end
end

def join(primary_key)

def join(primary_key)
  selects = columns.map do |column|
    case @model.connection.send(:postgresql_version)
    when 0..90000
      "array_to_string(array_agg(#{column.full_name}), ' ') AS #{column.alias}"
    else
      "string_agg(#{column.full_name}, ' ') AS #{column.alias}"
    end
  end.join(", ")
  relation = @model.joins(@name).select("#{primary_key} AS id, #{selects}").group(primary_key)
  "LEFT OUTER JOIN (#{relation.to_sql}) #{subselect_alias} ON #{subselect_alias}.id = #{primary_key}"
end

def subselect_alias

def subselect_alias
  Configuration.alias(table_name, @name, "subselect")
end

def table_name

def table_name
  @model.reflect_on_association(@name).table_name
end