我有一个模型订单。在索引中,我希望current_user只查看其订单的索引。订单belongs_to:admin_user。 AdminUser has_many:orders。我在我的应用程序中使用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
答案 0 :(得分:0)
看起来您正试图按order_id
过滤订单表。除非您以非标准方式构建数据库,否则订单表的ID字段通常为id
(不是order_id
)。
除了这个问题之外,我怀疑你是否希望传递索引操作的订单ID,因为这只会返回一条记录,而且本质上索引操作应列出许多记录(在您的情况下,所有记录为current_admin_user)。
如果这些问题都没有解决您的问题,请尝试逐行注释掉第1行。
答案 1 :(得分:0)
尝试添加此控制器方法
ActiveAdmin.register Order do
controller do
def scoped_collection
Order.where(:admin_user => current_admin_user.id)
end
end
end
答案 2 :(得分: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