Sha256: 03abc675d658ee58c5d0a8b0ef9537da7d3c91c0fcece7bac9e31b3573d9d230

Contents?: true

Size: 1.92 KB

Versions: 6

Compression:

Stored size: 1.92 KB

Contents

module Spree
  module Stock
    class Estimator
      attr_reader :order, :currency

      def initialize(order)
        @order = order
        @currency = order.currency
      end

      def shipping_rates(package, frontend_only = true)
        shipping_rates = Array.new
        shipping_methods = shipping_methods(package)
        return [] unless shipping_methods

        shipping_methods.each do |shipping_method|
          cost = calculate_cost(shipping_method, package)
          rate = shipping_method.shipping_rates.new(:cost => cost) unless cost.nil?
          shipping_rates << rate unless rate.nil?
        end

        shipping_rates.sort_by! { |r| r.cost || 0 }

        unless shipping_rates.empty?
          if frontend_only
            shipping_rates.each do |rate|
              rate.selected = true and break if rate.shipping_method.frontend?
            end
          else
            shipping_rates.first.selected = true
          end
        end

        shipping_rates
      end

      private

      def shipping_methods(package)
        package.shipping_methods.select do |ship_method|
          calculator = ship_method.calculator
          begin
            calculator.available?(package) &&
            ship_method.include?(order.ship_address) &&
            (calculator.preferences[:currency].nil? ||
             calculator.preferences[:currency] == currency)
          rescue Exception => exception
            log_calculator_exception(ship_method, exception)
          end
        end
      end

      def calculate_cost(shipping_method, package)
        shipping_method.calculator.compute(package)
      end

      def log_calculator_exception(ship_method, exception)
        Rails.logger.error("Something went wrong calculating rates with the #{ship_method.name} (ID=#{ship_method.id}) shipping method.")
        Rails.logger.error("*" * 50)
        Rails.logger.error(exception.backtrace.join("\n"))
      end
    end
  end
end

Version data entries

6 entries across 6 versions & 1 rubygems

Version Path
spree_core-2.0.13 app/models/spree/stock/estimator.rb
spree_core-2.0.12 app/models/spree/stock/estimator.rb
spree_core-2.0.11 app/models/spree/stock/estimator.rb
spree_core-2.0.10 app/models/spree/stock/estimator.rb
spree_core-2.0.9 app/models/spree/stock/estimator.rb
spree_core-2.0.8 app/models/spree/stock/estimator.rb