update sale_payment database

This commit is contained in:
Nweni
2017-06-07 14:45:03 +06:30
parent 9a23716c23
commit 810a6d8afc
5 changed files with 52 additions and 41 deletions

View File

@@ -6,9 +6,12 @@ class Origami::PaymentsController < BaseOrigamiController
def create def create
cash = params[:cash] cash = params[:cash]
card = params[:card] sale_id = params[:sale_id]
if(Sale.exists?(sale_id))
#process_payment(invoice, action_by) saleObj = Sale.find(sale_id)
sale_payment = SalePayment.new
sale_payment.process_payment(saleObj, @user, cash)
end
end end
def show def show

View File

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

View File

@@ -1,17 +1,21 @@
class SalePayment < ApplicationRecord class SalePayment < ApplicationRecord
self.primary_key = "sale_payment_id" self.primary_key = "sale_payment_id"
#primary key - need to be unique generated for multiple shops #primary key - need to be unique generated for multiple shops
before_create :generate_custom_id before_create :generate_custom_id
belongs_to :sale belongs_to :sale
:attr_accessor :received_amount, :card_payment_reference, :voucher_no, :giftcard_no, :customer_id, :external_payment_status attr_accessor :received_amount, :card_payment_reference, :voucher_no, :giftcard_no, :customer_id, :external_payment_status
def process_payment(invoice, action_by, cash_amount)
def process_payment(invoice, action_by)
self.sale = invoice self.sale = invoice
self.received_amount = cash_amount
payment_method = "cash"
amount_due = invoice.grand_total amount_due = invoice.grand_total
#get all payment for this invoices #get all payment for this invoices
invoice.sale_payments.each do |payment| invoice.sale_payments.each do |payment|
if (payment.payment_status == "paid" ) if (payment.payment_status == "paid" )
@@ -22,32 +26,33 @@ class SalePayment < ApplicationRecord
if (amount_due > 0) if (amount_due > 0)
payment_status = false payment_status = false
#route to payment type #route to payment type
switch (payment_method) case payment_method
case "cash" when "cash"
payment_status = cash_payment payment_status = cash_payment
case "creditnote" when "creditnote"
payment_status = creditnote_payment if !self.customer_id.nil?
case "visa" payment_status = creditnote_payment(self.customer_id)
payment_status = external_terminal_card_payment(:visa) end
case "master" when "visa"
payment_status = external_terminal_card_payment(:master) payment_status = external_terminal_card_payment(:visa)
case "jcb" when "master"
payment_status = external_terminal_card_payment(:jcb) payment_status = external_terminal_card_payment(:master)
case "mpu" when "jcb"
payment_status = external_terminal_card_payment(:mpu) payment_status = external_terminal_card_payment(:jcb)
case "unionpay" when "mpu"
payment_status = external_terminal_card_payment(:unionpay) payment_status = external_terminal_card_payment(:mpu)
case "vochure" when "unionpay"
payment_status = vochure_payment payment_status = external_terminal_card_payment(:unionpay)
case "giftcard" when "vochure"
payment_status = giftcard_payment payment_status = vochure_payment
case "paypar" when "giftcard"
#TODO: implement paypar implementation payment_status = giftcard_payment
when "paypar"
payment_status = paypar_payment payment_status = paypar_payment
else
puts "it was something else"
end end
#record an payment in sale-audit #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}" 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) sale_audit = SaleAudit.record_payment(invoice.id, remark, action_by)
@@ -66,10 +71,9 @@ class SalePayment < ApplicationRecord
private private
def cash_payment def cash_payment
payment_status = false payment_status = false
self.payment_method = "cash" self.payment_method = "cash"
self.payment_amount = self.received_amount self.payment_amount = self.received_amount
self.outstanding_amount = self.sale.grand_total - received_amount self.outstanding_amount = self.sale.grand_total - self.received_amount
self.payment_status = "paid" self.payment_status = "paid"
payment_method = self.save! payment_method = self.save!
@@ -78,7 +82,8 @@ class SalePayment < ApplicationRecord
return payment_status return payment_status
end end
def creditnote_payment(self.customer_id) def creditnote_payment(customer_id)
payment_status = false payment_status = false
self.payment_method = "creditnote" self.payment_method = "creditnote"
@@ -147,11 +152,12 @@ class SalePayment < ApplicationRecord
end end
def sale_update_payment_status(paid_amount) def sale_update_payment_status(paid_amount)
puts "paid_amount"
puts paid_amount
#update amount_outstanding #update amount_outstanding
self.sale.amount_received = self.sale.amount_received + paid_amount self.sale.amount_received = self.sale.amount_received + paid_amount
self.sale.amount_changed = amount - self.sale.amount_received self.sale.amount_changed = amount - self.sale.amount_received
if (self.sale.grand_total <= self.sale.amount_received && self.sale.amount_changed > 0) if (self.sale.grand_total <= self.sale.amount_received && self.sale.amount_changed > 0)
self.sale.payment_status = "paid" self.sale.payment_status = "paid"
self.sale.sale_status = "completed" self.sale.sale_status = "completed"
self.sale.save! self.sale.save!

View File

@@ -172,6 +172,7 @@ $(document).on('click', '.cashier_number', function(event){
original_value = $('#cash').text(); original_value = $('#cash').text();
var input_type = $(this).attr("data-type"); var input_type = $(this).attr("data-type");
switch (input_type) { switch (input_type) {
case 'num': case 'num':
var input_value = $(this).attr("data-value"); var input_value = $(this).attr("data-value");
@@ -224,10 +225,10 @@ $( document ).ready(function() {
var cash = $('#cash').text(); var cash = $('#cash').text();
var credit = $('#credit').text(); var credit = $('#credit').text();
var card = $('#card').text(); var card = $('#card').text();
var sale_id = $('#sale_id').text();
$.ajax({type: "POST", $.ajax({type: "POST",
url: "<%= origami_payment_process_path %>", url: "<%= origami_payment_process_path %>",
data: "cash="+ cash, data: "cash="+ cash + "&sale_id=" + sale_id,
success:function(result){ success:function(result){
alert("THANK YOU") alert("THANK YOU")
} }

View File

@@ -7,8 +7,8 @@ class CreateSaleAudits < ActiveRecord::Migration[5.0]
t.string :action, :null => false t.string :action, :null => false
t.datetime :action_at, :null => false t.datetime :action_at, :null => false
t.string :action_by, :null => false t.string :action_by, :null => false
t.string :approved_by, :null => false t.string :approved_by, :null => true
t.datetime :approved_by, :null => false t.datetime :approved_at, :null => true
t.string :remark t.string :remark
t.timestamps t.timestamps
end end