add unionpay process for payment
This commit is contained in:
3
app/assets/javascripts/origami/unionpay.coffee
Normal file
3
app/assets/javascripts/origami/unionpay.coffee
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
# Place all the behaviors and hooks related to the matching controller here.
|
||||||
|
# All this logic will automatically be available in application.js.
|
||||||
|
# You can use CoffeeScript in this file: http://coffeescript.org/
|
||||||
3
app/assets/stylesheets/origami/unionpay.scss
Normal file
3
app/assets/stylesheets/origami/unionpay.scss
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
// Place all the styles related to the origami/unionpay controller here.
|
||||||
|
// They will automatically be included in application.css.
|
||||||
|
// You can use Sass (SCSS) here: http://sass-lang.com/
|
||||||
@@ -155,6 +155,7 @@ class Origami::PaymentsController < BaseOrigamiController
|
|||||||
@visacount= 0.0
|
@visacount= 0.0
|
||||||
@jcbcount= 0.0
|
@jcbcount= 0.0
|
||||||
@mastercount = 0.0
|
@mastercount = 0.0
|
||||||
|
@unionpaycount = 0.0
|
||||||
@credit = 0.0
|
@credit = 0.0
|
||||||
@sale_data = Sale.find_by_sale_id(sale_id)
|
@sale_data = Sale.find_by_sale_id(sale_id)
|
||||||
@balance = 0.00
|
@balance = 0.00
|
||||||
@@ -216,6 +217,8 @@ class Origami::PaymentsController < BaseOrigamiController
|
|||||||
@jcbcount += spay.payment_amount
|
@jcbcount += spay.payment_amount
|
||||||
elsif spay.payment_method == "master"
|
elsif spay.payment_method == "master"
|
||||||
@mastercount += spay.payment_amount
|
@mastercount += spay.payment_amount
|
||||||
|
elsif spay.payment_method == "unionpay"
|
||||||
|
@unionpaycount += spay.payment_amount
|
||||||
elsif spay.payment_method == "creditnote"
|
elsif spay.payment_method == "creditnote"
|
||||||
@credit += spay.payment_amount
|
@credit += spay.payment_amount
|
||||||
end
|
end
|
||||||
@@ -272,7 +275,7 @@ class Origami::PaymentsController < BaseOrigamiController
|
|||||||
# Calculate price_by_accounts
|
# Calculate price_by_accounts
|
||||||
item_price_by_accounts = SaleItem.calculate_price_by_accounts(saleObj.sale_items)
|
item_price_by_accounts = SaleItem.calculate_price_by_accounts(saleObj.sale_items)
|
||||||
discount_price_by_accounts = SaleItem.get_discount_price_by_accounts(saleObj.sale_items)
|
discount_price_by_accounts = SaleItem.get_discount_price_by_accounts(saleObj.sale_items)
|
||||||
|
|
||||||
printer = Printer::ReceiptPrinter.new(print_settings)
|
printer = Printer::ReceiptPrinter.new(print_settings)
|
||||||
printer.print_receipt_bill(print_settings,cashier_terminal,saleObj.sale_items,saleObj,customer.name, item_price_by_accounts, discount_price_by_accounts, member_info,rebate_amount,shop_details, "Re-print",current_balance,card_data)
|
printer.print_receipt_bill(print_settings,cashier_terminal,saleObj.sale_items,saleObj,customer.name, item_price_by_accounts, discount_price_by_accounts, member_info,rebate_amount,shop_details, "Re-print",current_balance,card_data)
|
||||||
end
|
end
|
||||||
|
|||||||
61
app/controllers/origami/unionpay_controller.rb
Normal file
61
app/controllers/origami/unionpay_controller.rb
Normal file
@@ -0,0 +1,61 @@
|
|||||||
|
class Origami::UnionpayController < BaseOrigamiController
|
||||||
|
def index
|
||||||
|
@sale_id = params[:sale_id]
|
||||||
|
|
||||||
|
# limit unionpay_amount
|
||||||
|
sale_data = Sale.find_by_sale_id(@sale_id)
|
||||||
|
total = sale_data.grand_total
|
||||||
|
@unionpaycount = 0
|
||||||
|
others = 0
|
||||||
|
|
||||||
|
@shop = Shop::ShopDetail
|
||||||
|
if @shop.is_rounding_adj
|
||||||
|
new_total = Sale.get_rounding_adjustment(sale_data.grand_total)
|
||||||
|
else
|
||||||
|
new_total = sale_data.grand_total
|
||||||
|
end
|
||||||
|
@rounding_adj = new_total-sale_data.grand_total
|
||||||
|
|
||||||
|
sale_data.sale_payments.each do |sale_payment|
|
||||||
|
if sale_payment.payment_method == "unionpay"
|
||||||
|
@unionpaycount = @unionpaycount + sale_payment.payment_amount
|
||||||
|
else
|
||||||
|
others = others + sale_payment.payment_amount
|
||||||
|
end
|
||||||
|
end
|
||||||
|
puts "unionpaycount"
|
||||||
|
puts @unionpaycount
|
||||||
|
@can_unionpay = total - @unionpaycount - others
|
||||||
|
@member_discount = MembershipSetting.find_by_discount(1)
|
||||||
|
@sub_total = sale_data.total_amount
|
||||||
|
@membership_id = sale_data.customer.membership_id
|
||||||
|
#for bank integration
|
||||||
|
@receipt_no = sale_data.receipt_no
|
||||||
|
bank_integration = Lookup.collection_of('bank_integration')
|
||||||
|
@bank_integration = 0
|
||||||
|
if !bank_integration[0].nil?
|
||||||
|
@bank_integration = bank_integration[0][1]
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def create
|
||||||
|
cash = params[:amount]
|
||||||
|
sale_id = params[:sale_id]
|
||||||
|
if(Sale.exists?(sale_id))
|
||||||
|
saleObj = Sale.find(sale_id)
|
||||||
|
shop_details = Shop::ShopDetail
|
||||||
|
|
||||||
|
# rounding adjustment
|
||||||
|
if shop_details.is_rounding_adj
|
||||||
|
new_total = Sale.get_rounding_adjustment(saleObj.grand_total)
|
||||||
|
rounding_adj = new_total-saleObj.grand_total
|
||||||
|
saleObj.update_attributes(grand_total: new_total,old_grand_total: saleObj.grand_total,rounding_adjustment:rounding_adj)
|
||||||
|
end
|
||||||
|
|
||||||
|
saleObj = Sale.find(sale_id)
|
||||||
|
#end rounding adjustment
|
||||||
|
sale_payment = SalePayment.new
|
||||||
|
@status, @sale = sale_payment.process_payment(saleObj, @user, cash, "unionpay")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
2
app/helpers/origami/unionpay_helper.rb
Normal file
2
app/helpers/origami/unionpay_helper.rb
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
module Origami::UnionpayHelper
|
||||||
|
end
|
||||||
@@ -512,12 +512,12 @@ class ReceiptBillPdf < Prawn::Document
|
|||||||
|
|
||||||
#start card sale trans data
|
#start card sale trans data
|
||||||
def card_sale_data(card_data)
|
def card_sale_data(card_data)
|
||||||
move_down 5
|
if card_data != nil && !card_data.empty?
|
||||||
stroke_horizontal_rule
|
move_down 5
|
||||||
move_down 5
|
stroke_horizontal_rule
|
||||||
|
move_down 5
|
||||||
|
|
||||||
y_position = cursor
|
y_position = cursor
|
||||||
if !card_data.nil?
|
|
||||||
card_data.each do |data|
|
card_data.each do |data|
|
||||||
if data['app'] == 'CUP'
|
if data['app'] == 'CUP'
|
||||||
data['app'] = 'UNIONPAY'
|
data['app'] = 'UNIONPAY'
|
||||||
|
|||||||
@@ -182,13 +182,13 @@
|
|||||||
<% if @visacount != 0.0 %>
|
<% if @visacount != 0.0 %>
|
||||||
<div class="row payment others-color">
|
<div class="row payment others-color">
|
||||||
<div class="col-md-5"></div>
|
<div class="col-md-5"></div>
|
||||||
<div class="col-md-3">Visa</div>
|
<div class="col-md-3">VISA</div>
|
||||||
<div class="col-md-4 visa is_card" id="visacount"><%= @visacount %></div>
|
<div class="col-md-4 visa is_card" id="visacount"><%= @visacount %></div>
|
||||||
</div>
|
</div>
|
||||||
<% else %>
|
<% else %>
|
||||||
<div class="row hidden">
|
<div class="row hidden">
|
||||||
<div class="col-md-5"></div>
|
<div class="col-md-5"></div>
|
||||||
<div class="col-md-3">Visa</div>
|
<div class="col-md-3">VISA</div>
|
||||||
<div class="col-md-4" id="visacount">0.0</div>
|
<div class="col-md-4" id="visacount">0.0</div>
|
||||||
</div>
|
</div>
|
||||||
<% end %>
|
<% end %>
|
||||||
@@ -210,17 +210,31 @@
|
|||||||
<% if @mastercount != 0.0 %>
|
<% if @mastercount != 0.0 %>
|
||||||
<div class="row payment others-color">
|
<div class="row payment others-color">
|
||||||
<div class="col-md-5"></div>
|
<div class="col-md-5"></div>
|
||||||
<div class="col-md-3">Master</div>
|
<div class="col-md-3">MASTER</div>
|
||||||
<div class="col-md-4 master is_card" id="mastercount"><%= @mastercount %></div>
|
<div class="col-md-4 master is_card" id="mastercount"><%= @mastercount %></div>
|
||||||
</div>
|
</div>
|
||||||
<% else %>
|
<% else %>
|
||||||
<div class="row hidden">
|
<div class="row hidden">
|
||||||
<div class="col-md-5"></div>
|
<div class="col-md-5"></div>
|
||||||
<div class="col-md-3">Master</div>
|
<div class="col-md-3">MASTER</div>
|
||||||
<div class="col-md-4" id="mastercount">0.0</div>
|
<div class="col-md-4" id="mastercount">0.0</div>
|
||||||
</div>
|
</div>
|
||||||
<% end %>
|
<% end %>
|
||||||
<!-- <br> -->
|
<!-- <br> -->
|
||||||
|
<!-- UNIONPAY -->
|
||||||
|
<% if @unionpaycount != 0.0 %>
|
||||||
|
<div class="row payment others-color">
|
||||||
|
<div class="col-md-5"></div>
|
||||||
|
<div class="col-md-3">UNIONPAY</div>
|
||||||
|
<div class="col-md-4 master is_card" id="unionpaycount"><%= @unionpaycount %></div>
|
||||||
|
</div>
|
||||||
|
<% else %>
|
||||||
|
<div class="row hidden">
|
||||||
|
<div class="col-md-5"></div>
|
||||||
|
<div class="col-md-3">UNIONPAY</div>
|
||||||
|
<div class="col-md-4" id="unionpaycount">0.0</div>
|
||||||
|
</div>
|
||||||
|
<% end %>
|
||||||
<div class="row m-l-5 m-r-5">
|
<div class="row m-l-5 m-r-5">
|
||||||
<div class="col-md-8"><strong>Balance</strong></div>
|
<div class="col-md-8"><strong>Balance</strong></div>
|
||||||
<div class="col-md-4"><strong><span id='balance'><%= @sale_data.grand_total rescue 0 %></span></strong></div>
|
<div class="col-md-4"><strong><span id='balance'><%= @sale_data.grand_total rescue 0 %></span></strong></div>
|
||||||
@@ -303,7 +317,7 @@
|
|||||||
}else if(payment_type=="Credit"){
|
}else if(payment_type=="Credit"){
|
||||||
$("#card_payment").hide();
|
$("#card_payment").hide();
|
||||||
$("#others_payment").hide();
|
$("#others_payment").hide();
|
||||||
}else if(payment_type=="MPU"||payment_type=="VISA"||payment_type=="JCB"||payment_type=="Master"){
|
}else if(payment_type=="MPU"||payment_type=="VISA"||payment_type=="JCB"||payment_type=="Master" || payment_type=="UNIONPAY"){
|
||||||
$("#credit_payment").hide();
|
$("#credit_payment").hide();
|
||||||
}
|
}
|
||||||
/* end check first bill or not*/
|
/* end check first bill or not*/
|
||||||
@@ -361,17 +375,18 @@
|
|||||||
update_balance();
|
update_balance();
|
||||||
break;
|
break;
|
||||||
case 'nett':
|
case 'nett':
|
||||||
var credit1 = $('#credit').text();
|
var credit1 = $('#credit').text();
|
||||||
var card1 = $('#others').text();
|
var card1 = $('#others').text();
|
||||||
var paypar1 = $('#ppamount').text();
|
var paypar1 = $('#ppamount').text();
|
||||||
var visa1 = $('#visacount').text();
|
var visa1 = $('#visacount').text();
|
||||||
var jcb1 = $('#jcbcount').text();
|
var jcb1 = $('#jcbcount').text();
|
||||||
var master1 = $('#mastercount').text();
|
var master1 = $('#mastercount').text();
|
||||||
var othertotal = parseFloat(credit1) + parseFloat(card1) + parseFloat(paypar1) + parseFloat(visa1) + parseFloat(jcb1) + parseFloat(master1);
|
var unionpay1 = $('#unionpaycount').text();
|
||||||
var total = $('#amount_due').text();
|
var othertotal = parseFloat(credit1) + parseFloat(card1) + parseFloat(paypar1) + parseFloat(visa1) + parseFloat(jcb1) + parseFloat(master1) + parseFloat(unionpay1);
|
||||||
var amt = parseFloat(total) - parseFloat(othertotal);
|
var total = $('#amount_due').text();
|
||||||
$('#cash').text(parseFloat(amt).toFixed(2));
|
var amt = parseFloat(total) - parseFloat(othertotal);
|
||||||
update_balance();
|
$('#cash').text(parseFloat(amt).toFixed(2));
|
||||||
|
update_balance();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
event.handled = true;
|
event.handled = true;
|
||||||
@@ -412,6 +427,9 @@
|
|||||||
else if(payment_type == "Master" && $('#mastercount').text()==0 && sub_total != 0.0){
|
else if(payment_type == "Master" && $('#mastercount').text()==0 && sub_total != 0.0){
|
||||||
swal("Opps","Please Pay with Master Payment","warning");
|
swal("Opps","Please Pay with Master Payment","warning");
|
||||||
}
|
}
|
||||||
|
else if(payment_type == "UNIONPAY" && $('#unionpaycount').text()==0 && sub_total != 0.0){
|
||||||
|
swal("Opps","Please Pay with UNIONPAY Payment","warning");
|
||||||
|
}
|
||||||
else if(payment_type == "Credit" && $('#credit').text()==0 && sub_total != 0.0){
|
else if(payment_type == "Credit" && $('#credit').text()==0 && sub_total != 0.0){
|
||||||
swal("Opps","Please Pay with Credit Payment","warning");
|
swal("Opps","Please Pay with Credit Payment","warning");
|
||||||
}else{
|
}else{
|
||||||
@@ -515,8 +533,9 @@
|
|||||||
var visa = $('#visacount').text();
|
var visa = $('#visacount').text();
|
||||||
var jcb = $('#jcbcount').text();
|
var jcb = $('#jcbcount').text();
|
||||||
var master = $('#mastercount').text();
|
var master = $('#mastercount').text();
|
||||||
|
var unionpay = $('#unionpaycount').text();
|
||||||
var amount_due = $('#amount_due').text();
|
var amount_due = $('#amount_due').text();
|
||||||
var total = parseFloat(cash) + parseFloat(credit) + parseFloat(card) + parseFloat(paypar) + parseFloat(visa) + parseFloat(jcb) + parseFloat(master)
|
var total = parseFloat(cash) + parseFloat(credit) + parseFloat(card) + parseFloat(paypar) + parseFloat(visa) + parseFloat(jcb) + parseFloat(master) + parseFloat(unionpay)
|
||||||
var result = parseFloat(amount_due) - parseFloat(total);
|
var result = parseFloat(amount_due) - parseFloat(total);
|
||||||
$('#balance').text(result.toFixed(2));
|
$('#balance').text(result.toFixed(2));
|
||||||
}
|
}
|
||||||
|
|||||||
5
app/views/origami/unionpay/create.json.jbuilder
Executable file
5
app/views/origami/unionpay/create.json.jbuilder
Executable file
@@ -0,0 +1,5 @@
|
|||||||
|
if(@status)
|
||||||
|
json.status @status
|
||||||
|
else
|
||||||
|
json.status false
|
||||||
|
end
|
||||||
247
app/views/origami/unionpay/index.html.erb
Executable file
247
app/views/origami/unionpay/index.html.erb
Executable file
@@ -0,0 +1,247 @@
|
|||||||
|
<div class="container-fluid">
|
||||||
|
<div id="loading_wrapper" style="display:none;">
|
||||||
|
<div id="loading"></div>
|
||||||
|
</div>
|
||||||
|
<!-- <div class="page-header">
|
||||||
|
<ol class="breadcrumb">
|
||||||
|
<li class="breadcrumb-item"><a href="<%=origami_root_path %>"><%= t :home %></a></li>
|
||||||
|
<li class="breadcrumb-item"><a href="/origami/sale/<%=@sale_id %>/payment"><%= t("views.btn.payment") %></a></li>
|
||||||
|
<li class="breadcrumb-item active"><%= t("views.btn.unionpay") %></li>
|
||||||
|
<span class="float-right">
|
||||||
|
<%= link_to t('.back',:default => t("views.btn.back")),'/origami/sale/'+@sale_id+'/payment/others_payment'%>
|
||||||
|
</span>
|
||||||
|
</ol>
|
||||||
|
</div> -->
|
||||||
|
<h5>UNIONPAY Payment</h5>
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-lg-5 col-md-5 col-sm-5">
|
||||||
|
<span class="hidden" id="membership_id"><%= @membership_id%></span>
|
||||||
|
<span class="hidden" id="member_discount"><%= @member_discount%></span>
|
||||||
|
<span class="hidden" id="sub-total"><%= @sub_total%></span>
|
||||||
|
<div class="card m-l-10 m-t-10" style="padding:0px 20px;">
|
||||||
|
<div class="rebate-form">
|
||||||
|
<% if @bank_integration == '1' %>
|
||||||
|
<div class="row">
|
||||||
|
<div class="form-group col-lg-12 col-md-12 col-sm-12">
|
||||||
|
<label for="com_port_name">Select Device</label>
|
||||||
|
<select id="com_port_name" name="com_port_name" class="form-control select col-lg-7 col-md-7 col-sm-7">
|
||||||
|
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
<hr>
|
||||||
|
</div>
|
||||||
|
<% end %>
|
||||||
|
|
||||||
|
<div class="row">
|
||||||
|
<div class="form-group col-lg-12 col-md-12 col-sm-12">
|
||||||
|
<label>You can pay up to </label>
|
||||||
|
<%@can_unionpay = @can_unionpay +@rounding_adj%>
|
||||||
|
<input type="text" name="validamount" id="validamount" class="form-control col-lg-7 col-md-7 col-sm-7" readonly="" value="<%=@can_unionpay %>" data-member-value="">
|
||||||
|
</div>
|
||||||
|
<hr>
|
||||||
|
</div>
|
||||||
|
<% if @unionpaycount != 0 %>
|
||||||
|
<div class="row">
|
||||||
|
<div class="form-group col-lg-12 col-md-12 col-sm-12">
|
||||||
|
<label>Recent Visa paid amount </label>
|
||||||
|
<input type="text" name="" id="" class="form-control col-lg-7 col-md-7 col-sm-7" readonly="" value="<%=@unionpaycount %>" data-member-value="">
|
||||||
|
</div>
|
||||||
|
<hr>
|
||||||
|
</div>
|
||||||
|
<% end %>
|
||||||
|
<div class="row">
|
||||||
|
<div class="form-group col-lg-12 col-md-12 col-sm-12">
|
||||||
|
<label>Reference Number</label>
|
||||||
|
<input type="text" name="valid_amount" id="valid_amount" class="form-control col-lg-7 col-md-7 col-sm-7" value="" data-value="<%=@sale_id %>" data-member-value="">
|
||||||
|
</div>
|
||||||
|
<hr>
|
||||||
|
</div>
|
||||||
|
<div class="row">
|
||||||
|
<div class="form-group col-lg-12 col-md-12 col-sm-12">
|
||||||
|
<label>Amount</label>
|
||||||
|
<div id="amount" class="form-control col-lg-7 col-md-7 col-sm-7">0.0</div>
|
||||||
|
</div>
|
||||||
|
<hr>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="col-lg-6 col-md-6 col-sm-6" style="">
|
||||||
|
<div class=" m-t-10 p-l-20">
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-lg-6 col-md-6 col-sm-6">
|
||||||
|
<div class="row bottom">
|
||||||
|
<div class="col-md-4 cashier_number " data-value="1" data-type="num">1</div>
|
||||||
|
<div class="col-md-4 cashier_number border-left" data-value="2" data-type="num">2</div>
|
||||||
|
<div class="col-md-4 cashier_number border-left" data-value="3" data-type="num">3</div>
|
||||||
|
</div>
|
||||||
|
<div class="row bottom">
|
||||||
|
<div class="col-md-4 cashier_number border-left" data-value="4" data-type="num">4</div>
|
||||||
|
<div class="col-md-4 cashier_number border-left" data-value="5" data-type="num">5</div>
|
||||||
|
<div class="col-md-4 cashier_number border-left" data-value="6" data-type="num">6</div>
|
||||||
|
</div>
|
||||||
|
<div class="row bottom">
|
||||||
|
<div class="col-md-4 cashier_number border-left" data-value="7" data-type="num">7</div>
|
||||||
|
<div class="col-md-4 cashier_number border-left" data-value="8" data-type="num">8</div>
|
||||||
|
<div class="col-md-4 cashier_number border-left" data-value="9" data-type="num">9</div>
|
||||||
|
</div>
|
||||||
|
<div class="row bottom">
|
||||||
|
<div class="col-md-4 cashier_number border-left" data-value="0" data-type="num">0</div>
|
||||||
|
<div class="col-md-4 cashier_number border-left" data-value="." data-type="num">.</div>
|
||||||
|
<div class="col-md-4 cashier_number border-left" data-value="00" data-type="num">00</div>
|
||||||
|
</div>
|
||||||
|
<div class="row bottom">
|
||||||
|
<div class="col-md-4 cashier_number green border-left" data-type="nett" >Nett</div>
|
||||||
|
<div class="col-md-4 cashier_number red border-left" data-type="del">Del</div>
|
||||||
|
<div class="col-md-4 cashier_number orange border-left" data-type="clr">Clr</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="col-lg-6 col-md-6 col-sm-6">
|
||||||
|
<div class="row bottom m-l-5">
|
||||||
|
<div class="cashier_number long border-left" data-value="1000" data-type="add">1000</div>
|
||||||
|
<div class="cashier_number long left" data-value="3000" data-type="add">3000</div>
|
||||||
|
</div>
|
||||||
|
<div class="row bottom m-l-5">
|
||||||
|
<div class="cashier_number long border-left" data-value="5000" data-type="add">5000</div>
|
||||||
|
<div class="cashier_number long left" data-value="10000" data-type="add">10000</div>
|
||||||
|
</div>
|
||||||
|
<div class="row bottom m-l-5">
|
||||||
|
<div class="pay purple left" id="unionpay_pay">Pay</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="col-lg-1 col-md-1 col-sm-1">
|
||||||
|
<button type="button" class="btn bg-default m-t-10 btn-block" onclick="window.location.href = '/origami/sale/<%= @sale_id %>/payment/others_payment';"><i class="material-icons m-t--5">reply</i> Back </button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<script>
|
||||||
|
$(document).ready(function() {
|
||||||
|
var sale_id = "<%= @sale_id %>";
|
||||||
|
var bank_integration = "<%= @bank_integration %>";
|
||||||
|
|
||||||
|
if(localStorage.getItem("cash") == null || localStorage.getItem("cash") == 'null'){}
|
||||||
|
else {
|
||||||
|
$('#validamount').attr("value",parseFloat("<%= @can_unionpay %>") - parseFloat(localStorage.getItem("cash")));
|
||||||
|
}
|
||||||
|
|
||||||
|
if(bank_integration == '1'){
|
||||||
|
if(typeof code2lab != 'undefined'){
|
||||||
|
code2lab.getCommPorts(); //get comportlists from jade
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
swal({
|
||||||
|
title: 'Oops',
|
||||||
|
text: 'UNIONPAY is not available in here!',
|
||||||
|
type: 'error',
|
||||||
|
html: true,
|
||||||
|
closeOnConfirm: false,
|
||||||
|
closeOnCancel: false,
|
||||||
|
allowOutsideClick: false
|
||||||
|
}, function () {
|
||||||
|
window.location.href = '/origami/sale/'+ sale_id + "/payment/others_payment";
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
$(document).on('click', '.cashier_number', function(event){
|
||||||
|
event.stopPropagation();
|
||||||
|
event.preventDefault();
|
||||||
|
if(event.handled !== true) {
|
||||||
|
var original_value;
|
||||||
|
original_value = $('#amount').text();
|
||||||
|
|
||||||
|
var input_value = $(this).attr("data-value");
|
||||||
|
|
||||||
|
var input_type = $(this).attr("data-type");
|
||||||
|
switch (input_type) {
|
||||||
|
case 'num':
|
||||||
|
if (original_value == "0.0"){
|
||||||
|
$('#amount').text(input_value);
|
||||||
|
}else{
|
||||||
|
$('#amount').append(input_value);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'add':
|
||||||
|
var input_value = $(this).attr("data-value");
|
||||||
|
amount = parseInt(input_value) + parseInt(original_value);
|
||||||
|
$('#amount').html(amount);
|
||||||
|
|
||||||
|
break;
|
||||||
|
case 'clr':
|
||||||
|
$('#amount').html("0.0");
|
||||||
|
break;
|
||||||
|
case 'del' :
|
||||||
|
var cash=$('#amount').text();
|
||||||
|
$('#amount').text(cash.substr(0,cash.length-1));
|
||||||
|
break;
|
||||||
|
case 'nett':
|
||||||
|
var remain_amount = $('#validamount').val();
|
||||||
|
$('#amount').text(remain_amount);
|
||||||
|
break;
|
||||||
|
|
||||||
|
}
|
||||||
|
event.handled = true;
|
||||||
|
} else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
$('#unionpay_pay').on('click',function(){
|
||||||
|
var amount = $('#amount').text();
|
||||||
|
var sale_id = "<%= @sale_id %>";
|
||||||
|
var receipt_no = "<%= @receipt_no %>";
|
||||||
|
if(parseFloat(amount) <= parseFloat($("#validamount").attr("value")) && amount > 0){
|
||||||
|
$(this).off("click");
|
||||||
|
//start member discount 5% by pay card
|
||||||
|
// var sub_total = $('#sub-total').text();
|
||||||
|
// var member_id = $('#membership_id').text();
|
||||||
|
// var member_discount = $('#member_discount').text();
|
||||||
|
// if (member_id && member_discount) {
|
||||||
|
// $.ajax({
|
||||||
|
// type: "POST",
|
||||||
|
// url: "/origami/" + sale_id + "/member_discount",
|
||||||
|
// data: {'sale_id':sale_id, 'sub_total':sub_total,'is_card':true },
|
||||||
|
// success:function(result){
|
||||||
|
// }
|
||||||
|
// });
|
||||||
|
// }
|
||||||
|
//end member discount
|
||||||
|
var bank_integration = "<%= @bank_integration %>";
|
||||||
|
if(bank_integration == '1'){
|
||||||
|
pay_withBank("SALE", "unionpay", amount, sale_id, receipt_no);
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
$.ajax({type: "POST",
|
||||||
|
url: "<%= origami_payment_unionpay_path %>",
|
||||||
|
data: "amount="+ amount + "&sale_id="+ sale_id,
|
||||||
|
success:function(result){
|
||||||
|
if(result){
|
||||||
|
swal({
|
||||||
|
title: "Information!",
|
||||||
|
text: "Payment Successfully",
|
||||||
|
html: true,
|
||||||
|
closeOnConfirm: false,
|
||||||
|
closeOnCancel: false,
|
||||||
|
allowOutsideClick: false
|
||||||
|
}, function () {
|
||||||
|
window.location.href = '/origami/sale/'+ sale_id + "/payment";
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}else{
|
||||||
|
if (amount>0) {
|
||||||
|
swal ( "Oops" , "Paid Amount is over!" , "error" );
|
||||||
|
}else{
|
||||||
|
swal ( "Oops" , "Enter Amount!" , "error" );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
</script>
|
||||||
@@ -156,6 +156,7 @@ scope "(:locale)", locale: /en|mm/ do
|
|||||||
post 'payment/jcb' => "jcb#create"
|
post 'payment/jcb' => "jcb#create"
|
||||||
post 'payment/master' => "master#create"
|
post 'payment/master' => "master#create"
|
||||||
post 'payment/visa' => "visa#create"
|
post 'payment/visa' => "visa#create"
|
||||||
|
post 'payment/unionpay' => "unionpay#create"
|
||||||
post 'payment/paypar' => 'paypar_payments#create'
|
post 'payment/paypar' => 'paypar_payments#create'
|
||||||
post 'payment/credit' => 'credit_payments#create'
|
post 'payment/credit' => 'credit_payments#create'
|
||||||
post 'payment/voucher' => 'voucher_payments#create'
|
post 'payment/voucher' => 'voucher_payments#create'
|
||||||
@@ -166,6 +167,7 @@ scope "(:locale)", locale: /en|mm/ do
|
|||||||
get 'sale/:sale_id/payment/others_payment/VISA' => "visa#index"
|
get 'sale/:sale_id/payment/others_payment/VISA' => "visa#index"
|
||||||
get 'sale/:sale_id/payment/others_payment/Master' => "master#index"
|
get 'sale/:sale_id/payment/others_payment/Master' => "master#index"
|
||||||
get 'sale/:sale_id/payment/others_payment/JCB' => "jcb#index"
|
get 'sale/:sale_id/payment/others_payment/JCB' => "jcb#index"
|
||||||
|
get 'sale/:sale_id/payment/others_payment/UNIONPAY' => "unionpay#index"
|
||||||
get 'sale/:sale_id/payment/others_payment/Redeem' => "redeem_payments#index"
|
get 'sale/:sale_id/payment/others_payment/Redeem' => "redeem_payments#index"
|
||||||
get 'sale/:sale_id/payment/others_payment/Voucher' => "voucher#index"
|
get 'sale/:sale_id/payment/others_payment/Voucher' => "voucher#index"
|
||||||
|
|
||||||
|
|||||||
5
spec/controllers/origami/unionpay_controller_spec.rb
Normal file
5
spec/controllers/origami/unionpay_controller_spec.rb
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
require 'rails_helper'
|
||||||
|
|
||||||
|
RSpec.describe Origami::UnionpayController, type: :controller do
|
||||||
|
|
||||||
|
end
|
||||||
15
spec/helpers/origami/unionpay_helper_spec.rb
Normal file
15
spec/helpers/origami/unionpay_helper_spec.rb
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
require 'rails_helper'
|
||||||
|
|
||||||
|
# Specs in this file have access to a helper object that includes
|
||||||
|
# the Origami::UnionpayHelper. For example:
|
||||||
|
#
|
||||||
|
# describe Origami::UnionpayHelper do
|
||||||
|
# describe "string concat" do
|
||||||
|
# it "concats two strings with spaces" do
|
||||||
|
# expect(helper.concat_strings("this","that")).to eq("this that")
|
||||||
|
# end
|
||||||
|
# end
|
||||||
|
# end
|
||||||
|
RSpec.describe Origami::UnionpayHelper, type: :helper do
|
||||||
|
pending "add some examples to (or delete) #{__FILE__}"
|
||||||
|
end
|
||||||
Reference in New Issue
Block a user