Корзина для рельсов - заказ не создается при попытке добавить товары в корзину (нулевое значение) - PullRequest
0 голосов
/ 08 июня 2018

Я пытаюсь создать приложение интернет-магазина rails (with devise gem) с базовой корзиной покупок.Я нашел в Интернете несколько руководств по работе с корзиной, и я следовал за ним.
Код очень похож на следующий пост:

Rails Shopping Cart - нетдобавление к текущему заказу

Однако при добавлении товара в корзину у меня возникла проблема с частью заказа.заказ никогда не создается (я предполагаю) и поэтому не может быть сохранен, а продукты не добавлены в корзину.
Я провел много исследований и попытался отладить, но я застрял.

Извините за длинный пост, но я стараюсь быть максимально точным, чтобы облегчить ответы.

Можете ли вы помочь выяснить, в чем я не прав?
Спасибозаранее за ваши ответы.


Контроллеры:

Order_items

class OrderItemsController < ApplicationController
  skip_before_action :authenticate_user!

  def create
    @order = current_order
    @item = @order.order_items.new(order_item_params)
    if @order.save
      session[:order_id] = @order.id
      flash[:notice] = "Product Successfully added to your cart"
      redirect_to produits_path
    else
      flash[:notice] = "Problem"
      redirect_to produits_path
    end
  end

  def update
    @order = current_order
    @order_item = @order.order_items.find(params[:id])
    @order_item.update_attributes(order_item_params)
    @order_items = @order.order_items
  end

  def destroy
    @order = current_order
    @order_item = @order.order_items.find(params[:id])
    @order_item.destroy
    @order_items = @order.order_items
  end

private

  def order_item_params
    params.require(:order_item).permit(:quantity, :produit_id)
  end

end

Тележки

class CartsController < ApplicationController
  skip_before_action :authenticate_user!

  def show
    @order_items = current_order.order_items
  end
end

продукты

class ProduitsController < ApplicationController
  skip_before_action :authenticate_user!

  def index
    @produits = Produit.all
    @order_item = current_order.order_items.new
  end
end

приложение

 class ApplicationController < ActionController::Base
  protect_from_forgery with: :exception
  helper_method :current_order

  before_action :authenticate_user!
  before_action :configure_permitted_parameters, if: :devise_controller?

  def current_order
    if !session[:order_id].nil?
      Order.find(session[:order_id])
    else
      Order.new
    end
  end

  def configure_permitted_parameters
    # For additional fields in app/views/devise/registrations/new.html.erb
    devise_parameter_sanitizer.permit(:sign_up, keys: [:prenom, :nom, :adresse, :telephone])
    devise_parameter_sanitizer.permit(:account_update, keys: [:prenom, :nom, :adresse, :telephone])
  end
end

Модели:

orderItem

class OrderItem < ApplicationRecord
  belongs_to :order
  belongs_to :produit

  validates :quantity, presence: true, numericality: { only_integer: true, greater_than: 0 }
  validate :product_present
  validate :order_present

  before_save :finalize

  def unit_price
    if persisted?
      self[:unit_price]
    else
      produit.prix
    end
  end

  def total_price
    unit_price * quantity
  end

private

  def product_present
    if produit.nil?
      errors.add(:produit, "is not valid or is not active.")
    end
  end

  def order_present
    if order.nil?
      errors.add(:order, "is not a valid order.")
    end
  end

  def finalize
    self[:unit_price] = unit_price
    self[:total_price] = quantity * self[:unit_price]
  end
end

заказ

class Order < ApplicationRecord
  belongs_to :order_status
  belongs_to :user
  has_many :order_items
  before_create :set_order_status
  before_save :update_subtotal

  def subtotal
    order_items.collect { |oi| oi.valid? ? (oi.quantity * oi.prix) : 0 }.sum
  end


private
  def set_order_status
    self.order_status_id = 1
  end

  def update_subtotal
    self[:subtotal] = subtotal
  end
end

При отладке я вижу, что я получил переменную элемента в порядке (идентификатор продукта и количество), но заказвсе еще "ноль", поэтому я ввожу в остальной части кода.

     4: def create
     5:   binding.pry
     6:   @order = current_order
     7:   @item = @order.order_items.new(order_item_params)
 =>  8:   if @order.save
     9:     session[:order_id] = @order.id
    10:     flash[:notice] = "Product Successfully added to your cart"
    11:     redirect_to produits_path
    12:   else
    13:     flash[:notice] = "Problem"
    14:     redirect_to produits_path
    15:   end
    16: end

[4] pry(#<OrderItemsController>)> @order
=> #<Order:0x00007f8714ed1a50
 id: nil,
 status: nil,
 total_price: nil,
 created_at: nil,
 updated_at: nil,
 subtotal: nil,
 shipping: nil,
 user_id: nil>
[5] pry(#<OrderItemsController>)> @item
=> #<OrderItem:0x00007f8718e684e8 id: nil, produit_id: 47, order_id: nil, quantity: 1, created_at: nil, updated_at: nil>


     4: def create
     5:   binding.pry
     6:   @order = current_order
     7:   @item = @order.order_items.new(order_item_params)
     8:   if @order.save
     9:     session[:order_id] = @order.id
    10:     flash[:notice] = "Product Successfully added to your cart"
    11:     redirect_to produits_path
    12:   else
 => 13:     flash[:notice] = "Problem"
    14:     redirect_to produits_path
    15:   end
    16: end


pry(#<OrderItemsController>)> @order.save
   (0.3ms)  BEGIN
  ↳ (pry):7
   (0.3ms)  ROLLBACK
  ↳ (pry):7
=> false

1 Ответ

0 голосов
/ 08 июня 2018

В сеансе pry попробуйте:

@order.errors

, чтобы увидеть, какие проверки не пройдены и, таким образом, остановить сохранение @order.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...