2013-04-12 17:32:50 +00:00
|
|
|
# AGPLv3 sysmocom s.f.m.c. GmbH
|
|
|
|
|
|
|
|
module Spree
|
|
|
|
class Calculator::SysmocomValueCalculator < Calculator
|
|
|
|
|
|
|
|
def self.description
|
|
|
|
I18n.t(:sysmocom_value_based)
|
|
|
|
end
|
|
|
|
|
|
|
|
ZONE1 = {
|
2017-01-23 11:04:10 +00:00
|
|
|
"AT" => 1,
|
2013-04-12 17:32:50 +00:00
|
|
|
"BE" => 1,
|
|
|
|
"BG" => 1,
|
2017-01-23 11:04:10 +00:00
|
|
|
"HR" => 1,
|
|
|
|
"CZ" => 1,
|
2013-04-12 17:32:50 +00:00
|
|
|
"DK" => 1,
|
|
|
|
"EE" => 1,
|
|
|
|
"FI" => 1,
|
|
|
|
"FR" => 1,
|
|
|
|
"GR" => 1,
|
2017-01-23 11:04:10 +00:00
|
|
|
"HU" => 1,
|
2013-04-12 17:32:50 +00:00
|
|
|
"IE" => 1,
|
|
|
|
"IT" => 1,
|
|
|
|
"LV" => 1,
|
2017-01-23 11:04:10 +00:00
|
|
|
"LT" => 1,
|
2013-04-12 17:32:50 +00:00
|
|
|
"LU" => 1,
|
|
|
|
"MT" => 1,
|
|
|
|
"MC" => 1,
|
|
|
|
"NL" => 1,
|
|
|
|
"PL" => 1,
|
|
|
|
"PT" => 1,
|
|
|
|
"RO" => 1,
|
|
|
|
"SK" => 1,
|
|
|
|
"SI" => 1,
|
|
|
|
"ES" => 1,
|
2017-01-23 11:04:10 +00:00
|
|
|
"SE" => 1,
|
|
|
|
"GB" => 1
|
|
|
|
}.freeze()
|
|
|
|
|
|
|
|
ZONE2 = {
|
|
|
|
"CH" => 1
|
2013-04-12 17:32:50 +00:00
|
|
|
}.freeze()
|
|
|
|
|
2017-01-23 11:04:10 +00:00
|
|
|
ZONE3 = {
|
|
|
|
"AL" => 1,
|
|
|
|
"AD" => 1,
|
|
|
|
"BY" => 1,
|
|
|
|
"BA" => 1,
|
|
|
|
"CY" => 1,
|
|
|
|
"FO" => 1,
|
|
|
|
"GE" => 1,
|
|
|
|
"GI" => 1,
|
|
|
|
"GL" => 1,
|
|
|
|
"GG" => 1,
|
|
|
|
"VA" => 1,
|
|
|
|
"IS" => 1,
|
|
|
|
"JE" => 1,
|
|
|
|
"KZ" => 1,
|
|
|
|
"LI" => 1,
|
|
|
|
"MK" => 1,
|
|
|
|
"MD" => 1,
|
|
|
|
"ME" => 1,
|
|
|
|
"NO" => 1,
|
|
|
|
"SM" => 1,
|
|
|
|
"RS" => 1,
|
|
|
|
"TR" => 1,
|
|
|
|
"UA" => 1,
|
|
|
|
"AX" => 1
|
2013-04-12 17:32:50 +00:00
|
|
|
}.freeze
|
|
|
|
|
2017-01-23 11:04:10 +00:00
|
|
|
ZONE4 = {
|
|
|
|
"RU" => 1
|
|
|
|
}.freeze()
|
|
|
|
|
|
|
|
ZONE5 = {
|
|
|
|
"US" => 1
|
|
|
|
}.freeze()
|
|
|
|
|
|
|
|
ZONE6 = {
|
|
|
|
"DZ" => 1,
|
|
|
|
"AM" => 1,
|
|
|
|
"AZ" => 1,
|
|
|
|
"CA" => 1,
|
|
|
|
"EG" => 1,
|
|
|
|
"IL" => 1,
|
|
|
|
"JO" => 1,
|
|
|
|
"KZ" => 1,
|
|
|
|
"LB" => 1,
|
|
|
|
"LY" => 1,
|
|
|
|
"MA" => 1,
|
|
|
|
"PS" => 1,
|
|
|
|
"PM" => 1,
|
|
|
|
"SY" => 1,
|
|
|
|
"TN" => 1
|
|
|
|
}.freeze()
|
|
|
|
|
|
|
|
ZONE7 = {
|
|
|
|
"CN" => 1
|
|
|
|
}.freeze()
|
2013-04-12 17:32:50 +00:00
|
|
|
|
|
|
|
def packages_price(value, limit, price_each)
|
|
|
|
price = 0
|
|
|
|
rest = value
|
|
|
|
|
|
|
|
# It is intended that a package reaching the limit is counted twice
|
|
|
|
# Also a zero value should still be one package.
|
|
|
|
while rest >= 0 do
|
|
|
|
price += price_each
|
|
|
|
rest -= limit
|
|
|
|
end
|
|
|
|
|
|
|
|
price
|
|
|
|
end
|
|
|
|
|
2017-01-23 11:04:10 +00:00
|
|
|
# we choose pricing between 2kg and 5gk
|
2013-04-12 17:32:50 +00:00
|
|
|
def price_germany(value)
|
|
|
|
return packages_price(value, 500, 6.0)
|
|
|
|
end
|
|
|
|
|
2017-01-23 11:04:10 +00:00
|
|
|
# We assume a 5kg package in all zones below
|
2013-04-12 17:32:50 +00:00
|
|
|
def price_package_zone1(value)
|
2017-01-23 11:04:10 +00:00
|
|
|
return packages_price(value, 500, 17.0)
|
2013-04-12 17:32:50 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
def price_package_zone2(value)
|
2017-01-23 11:04:10 +00:00
|
|
|
return packages_price(value, 500, 29)
|
2013-04-12 17:32:50 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
def price_package_zone3(value)
|
2017-01-23 11:04:10 +00:00
|
|
|
return packages_price(value, 500, 30)
|
2013-04-12 17:32:50 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
def price_package_zone4(value)
|
2017-01-23 11:04:10 +00:00
|
|
|
return packages_price(value, 500, 33)
|
|
|
|
end
|
|
|
|
|
|
|
|
def price_package_zone5(value)
|
|
|
|
return packages_price(value, 500, 38)
|
2013-04-12 17:32:50 +00:00
|
|
|
end
|
2017-01-23 11:04:10 +00:00
|
|
|
|
|
|
|
def price_package_zone6(value)
|
|
|
|
return packages_price(value, 500, 40)
|
|
|
|
end
|
|
|
|
|
|
|
|
def price_package_zone7(value)
|
|
|
|
return packages_price(value, 500, 60)
|
|
|
|
end
|
|
|
|
|
|
|
|
def price_package_zone8(value)
|
|
|
|
return packages_price(value, 500, 63)
|
|
|
|
end
|
|
|
|
|
2013-04-12 17:32:50 +00:00
|
|
|
|
|
|
|
def total_value_no_tax(o)
|
2013-04-17 08:36:48 +00:00
|
|
|
item_total = o.line_items.map(&:amount).sum
|
|
|
|
item_total
|
2013-04-12 17:32:50 +00:00
|
|
|
end
|
|
|
|
|
2013-04-17 11:56:51 +00:00
|
|
|
def extract_iso_code(o)
|
|
|
|
if o.kind_of?(Spree::Shipment)
|
|
|
|
return o.address.country.iso
|
|
|
|
end
|
|
|
|
return o.ship_address.country.iso
|
|
|
|
end
|
|
|
|
|
|
|
|
def compute(object)
|
2013-04-12 17:32:50 +00:00
|
|
|
# This could be more than an order but not right now
|
2013-04-17 11:56:51 +00:00
|
|
|
shipping_value = total_value_no_tax(object)
|
|
|
|
iso_code = extract_iso_code(object)
|
2013-04-12 17:32:50 +00:00
|
|
|
|
|
|
|
# Go through the zones by name...
|
2013-04-17 11:56:51 +00:00
|
|
|
if iso_code == 'DE'
|
2013-04-12 17:32:50 +00:00
|
|
|
return price_germany(shipping_value)
|
2013-04-17 11:56:51 +00:00
|
|
|
elsif ZONE1.has_key?(iso_code)
|
2013-04-12 17:32:50 +00:00
|
|
|
return price_package_zone1(shipping_value)
|
2013-04-17 11:56:51 +00:00
|
|
|
elsif ZONE2.has_key?(iso_code)
|
2013-04-12 17:32:50 +00:00
|
|
|
return price_package_zone2(shipping_value)
|
2013-04-17 11:56:51 +00:00
|
|
|
elsif ZONE3.has_key?(iso_code)
|
2013-04-12 17:32:50 +00:00
|
|
|
return price_package_zone3(shipping_value)
|
2017-01-23 11:04:10 +00:00
|
|
|
elsif ZONE4.has_key?(iso_code)
|
2013-04-12 17:32:50 +00:00
|
|
|
return price_package_zone4(shipping_value)
|
2017-01-23 11:04:10 +00:00
|
|
|
elsif ZONE5.has_key?(iso_code)
|
|
|
|
return price_package_zone5(shipping_value)
|
|
|
|
elsif ZONE6.has_key?(iso_code)
|
|
|
|
return price_package_zone6(shipping_value)
|
|
|
|
elsif ZONE7.has_key?(iso_code)
|
|
|
|
return price_package_zone7(shipping_value)
|
|
|
|
else
|
|
|
|
return price_package_zone8(shipping_value)
|
2013-04-12 17:32:50 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
|