разбиение на страницы через хэш - PullRequest
1 голос
/ 06 мая 2011
{#<Farm id: 1, name: "Farm A", harvest: 2, offers: "Buy now, Delivery", about: "We rocks!", 
created_at: "2011-04-23 12:33:43", updated_at: "2011-04-25 09:02:15",logo: "images__9_.jpg", latitude: 42.3214, longitude: -71.0722, address: "555 Dudley Street, Boston, MA",  votes_count: 2>=>4482.753159399051, #<Farm id: 2, name: "Farm B",harvest: 3,
 offers: "Buy Now, Delivery", about: "We rock the farm A!", created_at: "2011-04-23 12:36:29", updated_at: "2011-04-25 09:02:15", logo: "images__7_.jpg", latitude: 42.3442, longitude: -71.0995, address: "1345 Boylston Street,Boston, MA", votes_count: 2 > => 4482.571841402453}

Я вырезал образец (также можно посмотреть там http://pastie.org/1871728). Мне нужна нумерация страниц для этого хэша. Нет никакой разницы, что использовать kaminari или will_paginate. Если это важно, я вывожу в представление этот хэшкак

  - @sort_farms.count.times do
    - farm = @sort_farms.shift
      %p
        = image_tag farm[0].logo.url.to_s
        = farm[0].harvest

и так далее ... Можете ли вы помочь мне, пожалуйста.

1 Ответ

1 голос
/ 06 мая 2011

Во-первых. Ваш код будет работать очень медленно, когда у вас будет много ферм.

Во-вторых. Итак, простая нумерация страниц:

per_page = 50.0 # show 50 farms per page
@page = params[:page] ? params[:page].to_i : 1
@address = get_user_address
@farms = Farm.all
@pages = (Farm.count/per_page).ceil
@sorted_farms = @farms.sort_by{|farm| farm.distance_from(@address)}[(@page-1)*per_page, per_page]

Итак, в контроллере мы получаем несколько ферм. Вы должны обернуть всю эту работу по нумерации страниц в вашу модель

Сейчас просмотров:

@sorted_farms.each do |farm|
  image_tag farm.logo.url
  farm.harvest
  distance: farm.distance_from(@address)
end
Pages:
1.upto(@pages).do |page|
  link_to page, :page => page
end

вот и все.

Конвертируй это представление в HAML или erb, мне было лень :))

...