Sha256: b08d85fba33799ff7592655afaf6c3fdb8bfc3230f475722cd581075ef6031a0
Contents?: true
Size: 1.94 KB
Versions: 9
Compression:
Stored size: 1.94 KB
Contents
module Logistics module Core class ServiceRate < ApplicationRecord belongs_to :container_size belongs_to :transaction_type belongs_to :chargeable_service_unit_of_charge def self.get_service_delivery_units transport_id = ServiceDeliveryUnitType.select(:id).where('lower(name) = ?', 'Transport'.downcase) return ServiceDeliveryUnit.where.not('service_delivery_unit_type_id' => transport_id) end def self.get_chargeable_services(service_delivery_unit_id) unit_of_charge_id = UnitOfCharge.select(:id).where('code' => 'CNT') acsuocs = ChargeableServiceUnitOfCharge.where('service_delivery_unit_id' => service_delivery_unit_id, 'unit_of_charge_id' => unit_of_charge_id ) return acsuocs end def self.generate_rate_for_containerized_chargeable_service(effective_date) service_delivery_units = ServiceDeliveryUnit.all transaction_types = TransactionType.all container_sizes = ContainerSize.all service_delivery_units.each{ |sdu| transaction_types.each { |transaction_type| container_sizes.each {|container_size| chargeable_services = get_chargeable_services(sdu.id) chargeable_services.each { |cs| service_rate = ServiceRate.where('chargeable_service_unit_of_charge_id' => cs.id, 'transaction_type_id' => transaction_type.id, 'container_size_id' => container_size.id) if service_rate.count == 0 ServiceRate.create('chargeable_service_unit_of_charge_id' => cs.id, 'transaction_type_id' => transaction_type.id, 'container_size_id' => container_size.id, 'effective_date' => effective_date, 'low' => 0, 'medium' => 0, 'high' => 0, 'margin' => 0) end } } } } end end end end
Version data entries
9 entries across 9 versions & 1 rubygems