This commit is contained in:
Moe Su
2017-06-07 18:11:03 +06:30
40 changed files with 463 additions and 183 deletions

View File

@@ -3,5 +3,7 @@ class Account < ApplicationRecord
has_many :menu_items
# belongs_to :lookup , :class_name => "Lookup"
def self.collection
Account.select("id, title").map { |e| [e.title, e.id] }
end
end

View File

@@ -1,10 +1,10 @@
class MenuItem < ApplicationRecord
#belongs_to :account
belongs_to :menu_category, :optional => true
has_many :menu_item_instances
belongs_to :parent, :class_name => "MenuItem", foreign_key: "menu_item_id", :optional => true
has_many :children, :class_name => "MenuItem", foreign_key: "menu_item_id"
belongs_to :account
validates_presence_of :item_code, :name, :type, :min_qty, :taxable, :min_selectable_item, :max_selectable_item

View File

@@ -1,6 +1,6 @@
class SaleAudit < ApplicationRecord
self.primary_key = "sale_audit_id"
#primary key - need to be unique generated for SaleAudit
before_create :generate_custom_id
@@ -44,13 +44,14 @@ class SaleAudit < ApplicationRecord
sale_audit.save!
end
def record_payment(sale_id, remark, action_by)
def self.record_payment(sale_id, remark, action_by)
sale_audit = SaleAudit.new()
sale_audit.sale_id = sale_id
sale_audit.action = "SALEPAYMENT"
sale_audit.action_at = DateTime.now.utc
sale_audit.action_by = action_by
sale_audit.remark = remark
sale_audit.approved_by = Time.now
sale_audit.save!
end

View File

@@ -1,6 +1,6 @@
class SalePayment < ApplicationRecord
self.primary_key = "sale_payment_id"
#primary key - need to be unique generated for multiple shops
before_create :generate_custom_id
@@ -8,62 +8,67 @@ class SalePayment < ApplicationRecord
attr_accessor :received_amount, :card_payment_reference, :voucher_no, :giftcard_no, :customer_id, :external_payment_status
# def process_payment(invoice, action_by)
# self.sale = invoice
def process_payment(invoice, action_by, cash_amount)
# amount_due = invoice.grand_total
# #get all payment for this invoices
# invoice.sale_payments.each do |payment|
# if (payment.payment_status == "paid" )
# amount_due = amount_due - payment.payment_amount
# end
# end
self.sale = invoice
self.received_amount = cash_amount
payment_method = "cash"
amount_due = invoice.grand_total
# if (amount_due > 0)
# payment_status = false
# #route to payment type
# switch (payment_method)
# case "cash"
# payment_status = cash_payment
# case "creditnote"
# payment_status = creditnote_payment
# case "visa"
# payment_status = external_terminal_card_payment(:visa)
# case "master"
# payment_status = external_terminal_card_payment(:master)
# case "jcb"
# payment_status = external_terminal_card_payment(:jcb)
# case "mpu"
# payment_status = external_terminal_card_payment(:mpu)
# case "unionpay"
# payment_status = external_terminal_card_payment(:unionpay)
# case "vochure"
# payment_status = vochure_payment
# case "giftcard"
# payment_status = giftcard_payment
# case "paypar"
# #TODO: implement paypar implementation
# payment_status = paypar_payment
# end
#get all payment for this invoices
invoice.sale_payments.each do |payment|
if (payment.payment_status == "paid" )
amount_due = amount_due - payment.payment_amount
end
end
if (amount_due > 0)
payment_status = false
#route to payment type
case payment_method
when "cash"
payment_status = cash_payment
when "creditnote"
if !self.customer_id.nil?
payment_status = creditnote_payment(self.customer_id)
end
when "visa"
payment_status = external_terminal_card_payment(:visa)
when "master"
payment_status = external_terminal_card_payment(:master)
when "jcb"
payment_status = external_terminal_card_payment(:jcb)
when "mpu"
payment_status = external_terminal_card_payment(:mpu)
when "unionpay"
payment_status = external_terminal_card_payment(:unionpay)
when "vochure"
payment_status = vochure_payment
when "giftcard"
payment_status = giftcard_payment
when "paypar"
payment_status = paypar_payment
else
puts "it was something else"
end
#record an payment in sale-audit
remark = "Payment #{payment_method}- for Invoice #{invoice.receipt_no} Due [#{amount_due}]| pay amount -> #{amount} | Payment Status ->#{payment_status}"
sale_audit = SaleAudit.record_payment(invoice.id, remark, action_by)
# #record an payment in sale-audit
# remark = "Payment #{payment_method}- for Invoice #{invoice.receipt_no} Due [#{amount_due}]| pay amount -> #{amount} | Payment Status ->#{payment_status}"
# sale_audit = SaleAudit.record_payment(invoice.id, remark, action_by)
return true, self.sale
else
#record an payment in sale-audit
remark = "No outstanding Amount - Grand Total [#{invoice.grand_total}] | Due [#{amount_due}] | Paid [#{invoice.amount_received}]"
sale_audit = SaleAudit.record_payment(invoice.id, remark,action_by)
# return true, self.sale
# else
# #record an payment in sale-audit
# remark = "No outstanding Amount - Grand Total [#{invoice.grand_total}] | Due [#{amount_due}] | Paid [#{invoice.amount_received}]"
# sale_audit = SaleAudit.record_payment(invoice.id, remark,action_by)
return false, "No outstanding Amount"
end
# return false, "No outstanding Amount"
# end
end
# end
def self.get_paypar_account(paypar_url,token,membership_id)
def self.get_paypar_account(paypar_url,token,membership_id)
url = paypar_url.to_s + "/api/get_membership_data".to_s
response = HTTParty.get(url,
:body => { app_token: token,membership_id:membership_id}.to_json,
@@ -76,102 +81,102 @@ class SalePayment < ApplicationRecord
end
# private
# def cash_payment
# payment_status = false
private
def cash_payment
payment_status = false
self.payment_method = "cash"
self.payment_amount = self.received_amount
self.outstanding_amount = self.sale.grand_total - self.received_amount
self.payment_status = "paid"
payment_method = self.save!
# self.payment_method = "cash"
# self.payment_amount = self.received_amount
# self.outstanding_amount = self.sale.grand_total - received_amount
# self.payment_status = "paid"
# payment_method = self.save!
sale_update_payment_status(self.received_amount)
# sale_update_payment_status(self.received_amount)
return payment_status
end
# return payment_status
# end
def creditnote_payment(customer_id)
# def creditnote_payment(self.customer_id)
# payment_status = false
payment_status = false
# self.payment_method = "creditnote"
# self.payment_amount = self.received_amount
# self.customer_id = self.customer_id
# self.outstanding_amount = 0 - self.received_amount
# self.payment_status = "outstanding"
# payment_method = self.save!
self.payment_method = "creditnote"
self.payment_amount = self.received_amount
self.customer_id = self.customer_id
self.outstanding_amount = 0 - self.received_amount
self.payment_status = "outstanding"
payment_method = self.save!
# sale_update_payment_status(self.received_amount)
sale_update_payment_status(self.received_amount)
# return payment_status
# end
return payment_status
end
# def external_terminal_card_payment(method)
# payment_status = false
def external_terminal_card_payment(method)
payment_status = false
# self.payment_method = method
# self.payment_amount = self.received_amount
# self.payment_reference = self.card_payment_reference
# self.outstanding_amount = self.sale.grand_total- self.received_amount
# self.payment_status = "paid"
# payment_method = self.save!
self.payment_method = method
self.payment_amount = self.received_amount
self.payment_reference = self.card_payment_reference
self.outstanding_amount = self.sale.grand_total- self.received_amount
self.payment_status = "paid"
payment_method = self.save!
# sale_update_payment_status(self.received_amount)
sale_update_payment_status(self.received_amount)
# return payment_status
# end
return payment_status
end
# def voucher_payment
# payment_status = false
def voucher_payment
payment_status = false
# #Next time - validate if the vochure number is valid - within
# self.payment_method = "voucher"
# self.payment_amount = self.received_amount
# self.payment_reference = self.voucher_no
# self.outstanding_amount = self.sale.grand_total- self.received_amount
# self.payment_status = "paid"
# payment_method = self.save!
#Next time - validate if the vochure number is valid - within
self.payment_method = "voucher"
self.payment_amount = self.received_amount
self.payment_reference = self.voucher_no
self.outstanding_amount = self.sale.grand_total- self.received_amount
self.payment_status = "paid"
payment_method = self.save!
# sale_update_payment_status(self.received_amount)
sale_update_payment_status(self.received_amount)
# return payment_status
return payment_status
# end
end
# def giftcard_payment
# payment_status = false
def giftcard_payment
payment_status = false
# #Next time - validate if the vochure number is valid - within
# self.payment_method = "giftcard"
# self.payment_amount = self.received_amount
# self.payment_reference = self.giftcard_no
# self.outstanding_amount = self.sale.grand_total- self.received_amount
# self.payment_status = "paid"
# payment_method = self.save!
#Next time - validate if the vochure number is valid - within
self.payment_method = "giftcard"
self.payment_amount = self.received_amount
self.payment_reference = self.giftcard_no
self.outstanding_amount = self.sale.grand_total- self.received_amount
self.payment_status = "paid"
payment_method = self.save!
# sale_update_payment_status(self.received_amount)
sale_update_payment_status(self.received_amount)
# return payment_status
return payment_status
# end
end
# def paypar_payment
# ##TODO - Integration with Paypar (SmartPay)
# end
def paypar_payment
##TODO - Integration with Paypar (SmartPay)
end
# def sale_update_payment_status(paid_amount)
# #update amount_outstanding
# self.sale.amount_received = self.sale.amount_received + paid_amount
# self.sale.amount_changed = amount - self.sale.amount_received
# if (self.sale.grand_total <= self.sale.amount_received && self.sale.amount_changed > 0)
# self.sale.payment_status = "paid"
# self.sale.sale_status = "completed"
# self.sale.save!
# end
# end
def sale_update_payment_status(paid_amount)
puts "paid_amount"
puts paid_amount
#update amount_outstanding
self.sale.amount_received = self.sale.amount_received + paid_amount
self.sale.amount_changed = amount - self.sale.amount_received
if (self.sale.grand_total <= self.sale.amount_received && self.sale.amount_changed > 0)
self.sale.payment_status = "paid"
self.sale.sale_status = "completed"
self.sale.save!
end
end
private
def generate_custom_id