Пагинация с помощью Elasticsearch, Tire и Kaminari

У меня проблемы с разбивкой на страницы результатов поиска для работы с Elasticsearch, Tire и Kaminari.

Я ищу все модели в своем приложении (новости, картины, книги) в качестве общего поиска по сайту и, следовательно, мне нужен блок для поиска шин в моем контроллере сайта для более детального управления, например, отображение большего, чем значение по умолчанию 10 записей:

class SiteController < ApplicationController
  def search
    # @results = Painting.search(params[:query])
    query = params[:query]
    @results = Tire.search ['news','paintings', 'books'], :page => (params[:page]||1), :per_page=> (params[:per_page] || 3) do
      query { string query }
      size 100
    end
  end
end

На моей странице результатов поиска у меня есть следующий код:

- if @results
  - @results.results.each do |result|
    = result.title
#pagination
  = paginate @results

и во всех моих моделях у меня есть правильное отображение и включает из шины:

  # - - - - - - - - - - - - - - - - 
  # Elasticsearch
  # - - - - - - - - - - - - - - - - 
  include Tire::Model::Search
  include Tire::Model::Callbacks

  mapping do
    indexes :id, index: :not_analyzed
    indexes :title, boost: 100
    indexes :slug, boost: 100, as: 'slug'
    indexes :content
    indexes :image, as: 'image.thumb.url'
    indexes :tags, as: 'tags'
    indexes :gallery_name, as: 'gallery.name'
    indexes :created_at, :type => 'date'
  end

Я убедился, что все мои записи правильно проиндексированы в Elasticsearch.

У меня проблема в том, что я не могу заставить его работать, последняя ошибка:

неопределенный метод `current_page '

Приветствуются любые мысли. Спасибо.


person anthony    schedule 12.03.2013    source источник


Ответы (2)


Вы можете попробовать это ??? Когда я использовал опцию per_page, у меня была аналогичная проблема. Итак, я перешел к вариантам размера от Tire. Я не уверен, что пошло не так. Но явная установка и использование from и size помогли мне ...

class SiteController < ApplicationController
  def search
    # @results = Painting.search(params[:query])
    options = { :page => (params[:page] || 1), :size => 100 }
    query = params[:query]
    @results = Tire.search ['news','paintings', 'books'], options do
      query { string query }
      from options[:size].to_i * (options[:page].to_i-1)
    end
  end
end
person Vamsi Krishna    schedule 06.06.2013
comment
Что действительно помогло мне в этом фрагменте кода, так это то, откуда я должен исходить и какие параметры размера. Они должны быть сбоку от блока кода для поиска, а не как часть параметров метода. Спасибо за это, Вамши Кришна - person Yosep Kim; 09.05.2014
comment
Рад, что этот фрагмент кода вам помог ... @YosepKim - person Vamsi Krishna; 15.05.2014

В библиотеке Tire есть метод Will-paginate gem, поэтому я бы предпочел его, а не Kaminari gem. Если в любом случае вы все же хотите быть с Каминари, соберите результаты поиска шин.

@results = @results.all.to_hash

paginate @results
person Arpit Kulshrestha    schedule 20.03.2013