【问题标题】:Geocoder Gem: How to use between two different models?Geocoder Gem:如何在两个不同的模型之间使用?
【发布时间】:2014-05-21 17:55:44
【问题描述】:

我正在使用 GeocoderWill Paginate gem 来根据与用户位置的距离和孩子妈妈的地址对结果进行排序。我的模型是这样的:

class User
 has_many :kids
 geocoded_by :address
end

class Kid
  belongs_to :mom
  belongs_to :dad
end

class Mom
  has_many :kids
  has_many :dads, through: :kids
  geocoded_by :address
end

class Dad
  has_many :kids
  has_many :moms, through: :kids
end

现在,我正在尝试使用正确的范围,我将使用 Users.address 并将其与 Kids.moms.addresses 进行比较

def show
 @dad = Dad.find(params[:id])
 @user_location = current_user.address
 @kids = @dad.kids.near(@user_location, 100).paginate(page: params[:page], per_page: 25).order(created_at: :desc)
end

这给了我错误:

NoMethodError - undefined method `address' for nil:NilClass:
  app/controllers/dads_controller.rb:14:in `show'
  actionpack (4.0.2) lib/action_controller/metal/implicit_render.rb:4:in `send_action'
  actionpack (4.0.2) lib/abstract_controller/base.rb:189:in `process_action'
  actionpack (4.0.2) lib/action_controller/metal/rendering.rb:10:in `process_action'
.......

有什么建议吗?


更新

到目前为止,我已经做到了:

class ApplicationController
  before_filter :set_user_location

  private

  def set_user_location
    if signed_in?
      @user_location = current_user.address
    end
  end
end

class DadsController

def show
  @dad = Dad.find(params[:id])
  @kids = @dad.kids.joins(:mom).merge(Mom.near(@user_location, 100)).order(name: :asc, created_at: :desc).paginate(page: params[:page], per_page: 25)
end

上面的代码让当前用户地址工作(使用设计),但现在我得到了错误:

ActiveModel::MissingAttributeError

missing attribute: birthday

对于页面上我的所有孩子属性。

<% @kids.each do |kid| %>
   <%= kid.birthday %>
   <%= kid.name %>
   <% if kid.upkeep.present? %>
     <%= kid.upkeep %>
     <%= kid.upkeep_size %> 
   <% end %>      
   <%= kid.age %>
   <%= kid.favorite_color %>
<% end %>

我认为这是因为它认为妈妈和孩子有相同的属性。有什么想法吗?

【问题讨论】:

    标签: ruby-on-rails ruby ruby-on-rails-3 ruby-on-rails-4 pagination


    【解决方案1】:

    问题是Kids 本身没有进行地理编码,因此您不能使用near 范围。

    这样的事情应该会让你接近:

    @dad.kids.joins(:mom).merge(Mom.near("San Francisco, CA, US")).paginate(...).order(...)
    

    Docs

    编辑

    根据您更新的问题,current_user 似乎是 nil。一旦你解决了这个问题并将它与上面的查询结合起来,你应该会很好。

    【讨论】:

    • 欣赏它。我实际上需要改变我的问题,因为它问错了问题。我试图从用户位置开始,而不是按距离排序。现在看看我的问题。我将如何使用当前用户地址并从那里开始显示结果?
    • 好的,现在我知道我得到了什么。我想将用户的地址与@kids 循环中的kid.mom.address 进行比较。
    【解决方案2】:

    这是使用 Geocoder 的方法:

    def show
      @dad = Dad.find(params[:id])
        near = Mom.near(@user_location, 100, :select => "kids.*")
      @kids = @dad.kids.joins(:mom).merge(near).order(name: :asc, created_at: :desc).page(params[:page])
    end
    

    :select 选项是我需要添加的。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2021-05-23
      • 2022-01-06
      • 1970-01-01
      • 1970-01-01
      • 2014-03-23
      • 1970-01-01
      • 2014-09-22
      • 1970-01-01
      相关资源
      最近更新 更多