2

我有一个模型订单。在索引中,我希望 current_user 仅查看包含他们的订单的索引。订单belongs_to :admin_user。AdminUser has_many:订单。我在我的应用程序中使用 activeadmin,如果这有影响的话。我收到此错误:

Couldn't find Order without an ID

给出错误的行是我的订单控制器中的第二行。(编辑了不必要的信息)

index do 
    @order = Order.where(admin_user_id: current_admin_user.id, order_id: resource.id)
     column "ID" do |order|
      link_to order.id, admin_order_path(order)
     end
    column "Proof" do |order|
     image_tag order.proof_url(:proof).to_s
        end
        column "Name" do |order|
      link_to order.name, admin_order_path(order)
    end
    column(:customer, :sortable => :customer_id)
        column "Category", :order_category
        column "Status", :order_status
        column "Priority", :order_priority 
    column "Due Date", :end_date
    default_actions
  end

这是@jamesw 要求的我的订单模型

class Order < ActiveRecord::Base
  attr_accessible :color_back, :color_front, :color_sleeve, :end_date, :name, :start_date, :whiteboard, :customer_id, :order_category_id, :order_type_id, :order_status_id, :order_priority_id, :print_location_id, :artwork, :proof, :line_items_attributes, :assignee_id, :admin_user_id

  mount_uploader :artwork, ArtworkUploader
  mount_uploader :proof, ProofUploader


  has_many :line_items
  belongs_to :assignee, :class_name => "AdminUser"
  belongs_to :customer
  belongs_to :order_category
  belongs_to :order_type
  belongs_to :order_status
  belongs_to :order_priority
  belongs_to :print_location
  belongs_to :admin_user
  accepts_nested_attributes_for :line_items, :allow_destroy => true

  scope :owned_by, lambda { |user| includes(:assignee).where("admin_users.id = ?", user.id) }



  def default_values
    if new_record?
      self.start_date ||= Date.today
      self.number ||= (Order.maximum(:number) + 1 rescue 1)
    end
  end
end
4

3 回答 3

0

我通过取出有问题的线路并使用scope_to :current_user. 不过我想知道,如何添加条件语句以仍然允许管理员查看?现在来看看控制器。

scope_to current_user

index do 
     column "ID" do |order|
      link_to order.id, admin_order_path(order)
     end
    column "Proof" do |order|
     image_tag order.proof_url(:proof).to_s
        end
        column "Name" do |order|
      link_to order.name, admin_order_path(order)
    end
    column(:customer, :sortable => :customer_id)
        column "Category", :order_category
        column "Status", :order_status
        column "Priority", :order_priority 
    column "Due Date", :end_date
    default_actions
  end
于 2013-05-23T12:27:56.680 回答
0

看起来您正在尝试按 过滤 Orders 表order_id。除非您以非标准方式构建数据库,否则订单表的 ID 字段通常是id​​(not order_id)。

撇开这个问题不谈,我怀疑你是否想为索引操作传递一个订单 ID,因为它只会返回一条记录,而且从本质上讲,索引操作应该列出许多记录(在你的情况下,是 current_admin_user 的所有记录) .

如果这些问题都不能解决您的问题,请尝试逐一注释掉这些行。

于 2013-05-21T00:47:02.860 回答
0

尝试添加此控制器方法

ActiveAdmin.register Order do
  controller do
    def scoped_collection
     Order.where(:admin_user => current_admin_user.id)
    end
  end
end

在此处查看更多信息: 同一资源的两个页面 - ActiveAdmin

于 2013-05-21T06:17:54.983 回答