1109 lines
44 KiB
Plaintext
Executable File
1109 lines
44 KiB
Plaintext
Executable File
<div class="container-fluid">
|
|
<div id="loading_wrapper" style="display:none;">
|
|
<div id="loading"></div>
|
|
</div>
|
|
<% if !@print_settings.nil? %>
|
|
<% if @print_settings.precision.to_i > 0
|
|
precision = @print_settings.precision
|
|
else
|
|
precision = 0
|
|
end
|
|
#check delimiter
|
|
if @print_settings.delimiter
|
|
delimiter = ","
|
|
else
|
|
delimiter = ""
|
|
end
|
|
%>
|
|
<% end %>
|
|
|
|
<div class="row clearfix">
|
|
<div class="col-lg-6 col-md-6 col-sm-6 col-xs-6">
|
|
<div class="card">
|
|
<div class="card-header m-l-5 m-r-5">
|
|
<div id="order-title">
|
|
<div class="row p-l-5 p-r-5">
|
|
<div class="col-lg-6 col-md-6 col-sm-6"><strong>Receipt No :</strong> <span id="receipt_no"><%=@sale_data.receipt_no rescue ' '%></span></div>
|
|
<div class="col-lg-6 col-md-6 col-sm-6 text-left"><strong>Receipt Date :</strong> <span id="receipt_date"><%=@sale_data.receipt_date.utc.getlocal.strftime("%d/%m/%Y-%I:%M %p") rescue '-' %></span></div>
|
|
</div>
|
|
<div class="row p-l-5 p-r-5">
|
|
<div class="col-lg-6 col-md-6 col-sm-6"><strong>Table No :</strong> <%=@table_no%></div>
|
|
<span class="hidden" id="dining"><%if !@dining.nil?%><%= @dining.id%><%end%></span>
|
|
<div class="col-lg-6 col-md-6 col-sm-6 text-left"><strong>Sale ID :</strong> <span id="sale_id"><% if @sale_data %><%=@sale_data.sale_id %><% end %></span></div>
|
|
</div>
|
|
|
|
<div class="row p-l-5 p-r-5">
|
|
<div class="col-lg-6 col-md-6 col-sm-6"><strong>Customer :</strong> <span id="customer_name"> <%= @sale_data.customer.name%></span> <span class="hidden" id="membership_id"><%= @sale_data.customer.membership_id%></span>
|
|
<span class="hidden" id="member_discount"><%= @member_discount%></span></div>
|
|
<div class="col-lg-6 col-md-6 col-sm-6 text-left"><strong>Checkin Time : </strong> <%if !@checkin_time.nil?%><%= @checkin_time.utc.getlocal.strftime("%I:%M %p") %>
|
|
<%end%></div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="card-block m-l-5 m-r-5 m-t--10">
|
|
<div class="card-title">
|
|
<div id="table-details" class="card-text" >
|
|
<table class="table" id="append-table">
|
|
<tr>
|
|
<!-- <tr> -->
|
|
<th>#</th>
|
|
<th class="item-name">Items</th>
|
|
<th class="item-attr">QTY</th>
|
|
<th class="item-attr">Price</th>
|
|
<!-- </tr> -->
|
|
</tr>
|
|
</table>
|
|
</div>
|
|
</div>
|
|
<div id="order-detail-slimscroll" data-height="300">
|
|
<!-- <div id="table-details" class="card-text" style="min-height:400px; max-height:400px; overflow-x:scroll"> -->
|
|
<div id="table-details" class="card-text m-t--10" >
|
|
<table class="table" id="append-table">
|
|
<tbody>
|
|
<% sub_total = 0
|
|
count = 0
|
|
%>
|
|
<% @sale_data.sale_items.each do |sale_item|
|
|
count += 1
|
|
%>
|
|
|
|
<% sub_total += sale_item.price%>
|
|
<tr>
|
|
<td><%= count %></td>
|
|
<td class="item-name"><%=sale_item.product_name%>@<%=number_with_precision( sale_item.unit_price, precision: precision.to_i )%></td>
|
|
<td class="item-attr"><%=sale_item.qty%></td>
|
|
<td class="item-attr"><%=(number_with_precision(sale_item.price, precision: precision.to_i ))%></td>
|
|
</tr>
|
|
<%end %>
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="card-footer ">
|
|
<table class="table m-t--10 ">
|
|
<tfooter>
|
|
<tr>
|
|
<td class="charges-name"><strong>Sub Total</strong></td>
|
|
<td class="item-attr"><strong><span id="sub-total"><%=number_with_precision(sub_total, precision: precision.to_i)%></span></strong></td>
|
|
</tr>
|
|
<tr>
|
|
<%if @sale_data.discount_type == 'member_discount'%>
|
|
<td class="charges-name"><strong>Member Discount:</strong></td>
|
|
<%else%>
|
|
<td class="charges-name"><strong>(Discount)</strong></td>
|
|
<%end%>
|
|
<td class="item-attr"><strong><span>(<%= number_with_precision(@sale_data.total_discount, precision: precision.to_i ) rescue number_with_precision(0, precision: precision.to_i ) %>)</span></strong></td>
|
|
</tr>
|
|
<tr>
|
|
<td class="charges-name"><strong>Tax
|
|
(<% @i = 0
|
|
@account_arr.each do |ct| %>
|
|
<%=ct.name%>
|
|
<% if @account_arr.count != @i+1%>
|
|
+ <% @i =+1 %>
|
|
<%end%>
|
|
<%end %>)
|
|
</strong></td>
|
|
<td class="item-attr"><strong><span><%= number_with_precision(@sale_data.total_tax, precision: precision.to_i ) rescue number_with_precision(0, precision: precision.to_i )%></span></strong></td>
|
|
</tr>
|
|
<tr>
|
|
<td class="charges-name"><strong>Rounding Adj:</strong></td>
|
|
<td class="item-attr"><strong><%= number_with_precision(@sale_data.rounding_adjustment, precision: precision.to_i ) rescue number_with_precision(0, precision: precision.to_i )%></strong></td>
|
|
</tr>
|
|
<tr>
|
|
<td class="charges-name"><strong>Grand Total</strong></td>
|
|
<td class="item-attr"><strong><span><%= number_with_precision(@sale_data.grand_total, precision: precision.to_i ) rescue number_with_precision(0, precision: precision.to_i )%></span></strong></td>
|
|
</tr>
|
|
<%if @balance > 0%>
|
|
<tr>
|
|
<td class="charges-name"><strong><%= @accountable_type %></strong></td>
|
|
<td class="item-attr"><strong><span><%=number_with_precision(@balance, precision: precision.to_i )%></span></strong></td>
|
|
</tr>
|
|
<% end %>
|
|
<% if !@individual_total[0].nil? %>
|
|
<tr>
|
|
<td class="charges-name">
|
|
<strong>Split Bill for <%= @individual_total[0]['total_customer'] %> persons</strong>
|
|
</td>
|
|
<td></td>
|
|
</tr>
|
|
<tr>
|
|
<td class="charges-name">
|
|
<strong>Amount Due (per person)</strong>
|
|
</td>
|
|
<td class="item-attr"><strong><span><%= number_with_precision(@individual_total[0]['per_person_amount'], precision: precision.to_i )%></span></strong></td>
|
|
</tr>
|
|
<% end %>
|
|
</tfooter>
|
|
</table>
|
|
</div>
|
|
<!-- <div> -->
|
|
<!-- <INPUT TYPE="Button" class='btn btn-primary' VALUE="Reprint" onClick="" style='width:120px'/>
|
|
<INPUT TYPE="Submit" class='btn btn-primary' VALUE="CANCEL" action="origami/index" style='width:120px'/> -->
|
|
<!-- </div> -->
|
|
</div>
|
|
</div>
|
|
|
|
<div class="col-lg-5 col-md-5 col-sm-5 col-xs-5">
|
|
<div class="card">
|
|
<div class="card-header">
|
|
<div class="row m-l-5 m-r-5">
|
|
<div class="col-md-8"><strong>Amount Due</strong></div>
|
|
<div class="col-md-4">
|
|
<strong>
|
|
<span id="grand_total" class="hidden"><%= number_with_precision(@sale_data.grand_total, precision: precision.to_i ) rescue number_with_precision(0, precision: precision.to_i)%></span>
|
|
<span id="amount_due"><%= number_with_precision(@sale_data.grand_total, precision: precision.to_i ) rescue number_with_precision(0, precision: precision.to_i ) %></span></strong>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="row payment cash-color p-l-5 p-r-5">
|
|
<div class="col-md-8">Cash</div>
|
|
<div class="col-md-4" id="cash" ><%= number_with_precision(@cash, precision: precision.to_i ) rescue number_with_precision(0, precision: precision.to_i ) %></div>
|
|
</div>
|
|
|
|
<div class="row payment credit-color p-l-5 p-r-5" id="credit_payment" >
|
|
<div class="col-md-8">Credit</div>
|
|
<div class="col-md-4" id="credit"><%= number_with_precision(@credit, precision: precision.to_i ) rescue number_with_precision(0, precision: precision.to_i ) %></div>
|
|
</div>
|
|
<% if @other == 0.0 && @ppamount == 0.0 && @visacount == 0.0 && @jcbcount == 0.0 && @mastercount == 0.0%>
|
|
<div class="row payment other-payment-color" id="card_payment" >
|
|
<div class="col-md-8">Other Payments</div>
|
|
<div class="col-md-4" id="others"><%= number_with_precision(@other, precision: precision.to_i) rescue number_with_precision(0, precision: precision.to_i) %></div>
|
|
</div>
|
|
<% else %>
|
|
<div class="row payment other-payment-color" id="card_payment" >
|
|
<div class="col-md-12">Other Payments</div>
|
|
</div>
|
|
<% end %>
|
|
</div>
|
|
<div class="card-block">
|
|
<div class="card-title m-l-5 m-r-5">
|
|
<!-- mpu -->
|
|
<% if @other != 0.0 %>
|
|
<div class="row payment others-color">
|
|
<div class="col-md-5"></div>
|
|
<div class="col-md-3">MPU</div>
|
|
<div class="col-md-4 mpu is_card" id="others"><%= number_with_precision(@other, precision: precision.to_i ) rescue number_with_precision(0, precision: precision.to_i ) %></div>
|
|
</div>
|
|
<% else %>
|
|
<div class="row hidden">
|
|
<div class="col-md-5"></div>
|
|
<div class="col-md-3">MPU</div>
|
|
<div class="col-md-4" id="others"><%= number_with_precision(0, precision: precision.to_i ) %></div>
|
|
</div>
|
|
<% end %>
|
|
<!-- paypar -->
|
|
<% if @ppamount != 0.0 %>
|
|
<div class="row payment others-color">
|
|
<div class="col-md-5"></div>
|
|
<div class="col-md-3">Redeem</div>
|
|
<div class="col-md-4" id="ppamount"><%= number_with_precision(@ppamount, precision: precision.to_i ) rescue number_with_precision(0, precision: precision.to_i ) %></div>
|
|
</div>
|
|
<% else %>
|
|
<div class="row hidden">
|
|
<div class="col-md-5"></div>
|
|
<div class="col-md-3">Redeem</div>
|
|
<div class="col-md-4" id="ppamount"><%= number_with_precision(0, precision: precision.to_i ) %></div>
|
|
</div>
|
|
<% end %>
|
|
<!-- Visa -->
|
|
<% if @visacount != 0.0 %>
|
|
<div class="row payment others-color">
|
|
<div class="col-md-5"></div>
|
|
<div class="col-md-3">VISA</div>
|
|
<div class="col-md-4 visa is_card" id="visacount"><%= number_with_precision(@visacount, precision: precision.to_i ) rescue number_with_precision(0, precision: precision.to_i ) %></div>
|
|
</div>
|
|
<% else %>
|
|
<div class="row hidden">
|
|
<div class="col-md-5"></div>
|
|
<div class="col-md-3">VISA</div>
|
|
<div class="col-md-4" id="visacount"><%= number_with_precision(0, precision: precision.to_i ) %></div>
|
|
</div>
|
|
<% end %>
|
|
<!-- JCB -->
|
|
<% if @jcbcount != 0.0 %>
|
|
<div class="row payment others-color">
|
|
<div class="col-md-5"></div>
|
|
<div class="col-md-3">JCB</div>
|
|
<div class="col-md-4 jcb is_card" id="jcbcount"><%= number_with_precision(@jcbcount, precision: precision.to_i ) rescue number_with_precision(0, precision: precision.to_i ) %></div>
|
|
</div>
|
|
<% else %>
|
|
<div class="row hidden">
|
|
<div class="col-md-5"></div>
|
|
<div class="col-md-3">JCB</div>
|
|
<div class="col-md-4" id="jcbcount"><%= number_with_precision(0, precision: precision.to_i ) %></div>
|
|
</div>
|
|
<% end %>
|
|
<!-- Master -->
|
|
<% if @mastercount != 0.0 %>
|
|
<div class="row payment others-color">
|
|
<div class="col-md-5"></div>
|
|
<div class="col-md-3">MASTER</div>
|
|
<div class="col-md-4 master is_card" id="mastercount"><%= number_with_precision(@mastercount, precision: precision.to_i) rescue number_with_precision(0, precision: precision.to_i ) %></div>
|
|
</div>
|
|
<% else %>
|
|
<div class="row hidden">
|
|
<div class="col-md-5"></div>
|
|
<div class="col-md-3">MASTER</div>
|
|
<div class="col-md-4" id="mastercount"><%= number_with_precision(0, precision: precision.to_i ) %></div>
|
|
</div>
|
|
<% end %>
|
|
<!-- <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"><%= number_with_precision(@unionpaycount, precision: precision.to_i ) rescue number_with_precision(0, precision: precision.to_i ) %></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"><%= number_with_precision(0, precision: precision.to_i ) %></div>
|
|
</div>
|
|
<% end %>
|
|
<div class="row m-l-5 m-r-5">
|
|
<div class="col-md-8"><strong>Balance</strong></div>
|
|
<div class="col-md-4"><strong><span id='balance'><%= number_with_precision(@sale_data.grand_total, precision: precision.to_i ) rescue number_with_precision(0, precision: precision.to_i ) %></span></strong></div>
|
|
</div>
|
|
<!-- <br> -->
|
|
</div>
|
|
</div>
|
|
|
|
<div class="card-footer">
|
|
<div class="row m-l-5 m-r-5">
|
|
<div class="col-lg-6 col-md-6 col-sm-6">
|
|
<div class="row bottom">
|
|
<div class="col-md-4 cashier_number border-top border- border-left" data-value="1" data-type="num">1</div>
|
|
<div class="col-md-4 cashier_number border-top border- border-left" data-value="2" data-type="num">2</div>
|
|
<div class="col-md-4 cashier_number border-top border- border-left" data-value="3" data-type="num">3</div>
|
|
</div>
|
|
<div class="row bottom">
|
|
<div class="col-md-4 cashier_number border-top border- border-left" data-value="4" data-type="num">4</div>
|
|
<div class="col-md-4 cashier_number border-top border- border-left" data-value="5" data-type="num">5</div>
|
|
<div class="col-md-4 cashier_number border-top border- border-left" data-value="6" data-type="num">6</div>
|
|
</div>
|
|
<div class="row bottom">
|
|
<div class="col-md-4 cashier_number border-top border- border-left" data-value="7" data-type="num">7</div>
|
|
<div class="col-md-4 cashier_number border-top border- border-left" data-value="8" data-type="num">8</div>
|
|
<div class="col-md-4 cashier_number border-top border- border-left" data-value="9" data-type="num">9</div>
|
|
</div>
|
|
<div class="row bottom">
|
|
<div class="col-md-4 cashier_number border-top border- border-left" data-value="0" data-type="num">0</div>
|
|
<div class="col-md-4 cashier_number border-top border- border-left" data-value="." data-type="num">.</div>
|
|
<div class="col-md-4 cashier_number border-top border- border-left" data-value="00" data-type="num">00</div>
|
|
</div>
|
|
<div class="row bottom">
|
|
<div class="col-md-4 cashier_number border-top border- border-left green" data-type="nett">Nett</div>
|
|
<div class="col-md-4 cashier_number border-top border- border-left red" data-type="del">Del</div>
|
|
<div class="col-md-4 cashier_number border-top border- border-left orange" data-type="clr">Clr</div>
|
|
</div>
|
|
</div>
|
|
<div class="col-lg-6 col-md-6 col-sm-6">
|
|
<div class="row bottom">
|
|
<div class="cashier_number border-top border- border-left payment-long payment-left" data-value="1000" data-type="add">1000</div>
|
|
<div class="cashier_number border-top border- border-left payment-long" data-value="3000" data-type="add">3000</div>
|
|
</div>
|
|
<div class="row bottom">
|
|
<div class="cashier_number border-top border- border-left payment-long payment-left" data-value="5000" data-type="add">5000</div>
|
|
<div class="cashier_number border-top border- border-left payment-long" data-value="10000" data-type="add">10000</div>
|
|
</div>
|
|
<div class="row bottom">
|
|
<div class="pay border-top border- border-left purple payment-left" id="pay">Pay</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="col-lg-1 col-md-1 col-sm-1 col-xs-1">
|
|
<button type="button" class="btn btn-block btn-default waves-effect" id='back'>
|
|
<i class="material-icons">reply</i>
|
|
Back
|
|
</button>
|
|
<button type="button" class="btn bg-deep-purple btn-block" data-toggle="modal" data-target="#focModal" <%= (can? :foc, :payment)? ' ': 'disabled=' %> active="true"> FOC </button>
|
|
<button type="button" class="btn bg-red btn-block" data-toggle="modal" data-target="#voidModal" <%= (can? :overall_void, :void)? ' ': 'disabled=' %> > Void </button>
|
|
<% if @cashier_type=="quick_service" %>
|
|
<hr>
|
|
|
|
<button type="button" id="survey" class="btn btn-block bg-blue waves-effect"><%= t("views.right_panel.detail.survey") %></button>
|
|
<button type="button" id="customer" class="btn btn-block bg-blue waves-effect" >Customer</button>
|
|
<button type="button" class="btn btn-block bg-blue waves-effect" id='edit' <%= (can? :edit, :sale_edit)? ' ': 'disabled=' %> active="true">Edit</button>
|
|
<button type="button" id="discount" class="btn btn-block bg-blue waves-effect" <%= (can? :index, :discount)? ' ': 'disabled=' %> active="true">Discount</button>
|
|
<button type="button" id="other-charges" class="btn btn-block bg-blue waves-effect">Charges</button>
|
|
<!-- Waiter Buttons -->
|
|
<%end %>
|
|
</div>
|
|
<input type="hidden" id="server_mode" value="<%= ENV["SERVER_MODE"] %>">
|
|
</div>
|
|
<div class="modal fade" id="voidModal" tabindex="-1" role="dialog">
|
|
<div class="modal-dialog" role="document">
|
|
<div class="modal-content">
|
|
<div class="modal-header">
|
|
<h4 class="modal-title" id="voidModalLabel">Please Enter Reason for Void</h4>
|
|
</div>
|
|
<div class="modal-body">
|
|
<input type="textarea" name="remark" class="form-control col-md-12 remark" id="remark">
|
|
</div>
|
|
<div class="modal-footer ">
|
|
<div class="row p-r-20">
|
|
<div class="col-md-5">
|
|
<button type="button" class="btn btn-link p-t-5 p-b-5 bg-red waves-effect " id="void" active="true">VOID</button>
|
|
</div>
|
|
<div class="col-md-5">
|
|
<button type="button" class="btn btn-link p-t-5 p-b-5 bg-blue waves-effect" data-dismiss="modal">CLOSE</button>
|
|
</div>
|
|
</div>
|
|
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="modal fade" id="focModal" tabindex="-1" role="dialog">
|
|
<div class="modal-dialog" role="document">
|
|
<div class="modal-content">
|
|
<div class="modal-header">
|
|
<h4 class="modal-title" id="focModalLabel">Please Enter Reason for FOC</h4>
|
|
</div>
|
|
<div class="modal-body">
|
|
<input type="textarea" name="remark" class="form-control col-md-12 remark" id="foc_remark">
|
|
</div>
|
|
<div class="modal-footer ">
|
|
<div class="row p-r-20">
|
|
<div class="col-md-5">
|
|
<button type="button" class="btn btn-link bg-red waves-effect " id="foc" active="true">FOC</button>
|
|
</div>
|
|
<div class="col-md-5">
|
|
<button type="button" class="btn btn-link bg-blue waves-effect" data-dismiss="modal">CLOSE</button>
|
|
</div>
|
|
</div>
|
|
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- pdf light box -->
|
|
<div class="modal fade" id="pdfModal" tabindex="-1" role="dialog">
|
|
<div class="modal-dialog modal-md" role="document">
|
|
<div class="modal-content">
|
|
<div class="modal-header">
|
|
<h4 class="modal-title" id="pdfModalLabel"></h4>
|
|
</div>
|
|
<div class="modal-body">
|
|
<input type="hidden" name="sale_receipt_no" id="sale_receipt_no">
|
|
<input type="hidden" name="filename" id="filename">
|
|
<input type="hidden" name="printer_name" id="printer_name">
|
|
<p id="changed_amount"></p>
|
|
<div class="text-center">
|
|
<iframe id="receipt_pdf" src="" style="width: 400px; height: 600px;"></iframe>
|
|
</div>
|
|
</div>
|
|
<div class="modal-footer ">
|
|
<div class="row p-r-20">
|
|
<% if ENV["SERVER_MODE"] != 'cloud' %>
|
|
<div class="col-md-5">
|
|
<button type="button" class="btn btn-link bg-red waves-effect print_receipt">Print</button>
|
|
</div>
|
|
<% end %>
|
|
<div class="col-md-5">
|
|
<button type="button" class="btn btn-link bg-blue waves-effect btn_pdf_close" data-dismiss="modal">CLOSE</button>
|
|
</div>
|
|
</div>
|
|
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- customer light box -->
|
|
<div class="modal fade" id="is_memberModal" tabindex="-1" role="dialog">
|
|
<div class="modal-dialog modal-md" role="document">
|
|
<div class="modal-content">
|
|
<div class="modal-header">
|
|
<h1 class="modal-title" id="is_memberModalLabel">Are you Member?</h1>
|
|
</div>
|
|
<div class="modal-body">
|
|
<input type="hidden" name="paypar_account_no" id="paypar_account_no" />
|
|
<input type="hidden" name="qr_code" id="qr_code" />
|
|
<div class="row text-center m-t-20">
|
|
<div class="col-lg-6 col-md-6 col-sm-6 col-xs-6">
|
|
<button type="button" class="btn btn-lg btn-link bg-primary waves-effect btn_member">Card Member</button>
|
|
</div>
|
|
|
|
<div class="col-lg-6 col-md-6 col-sm-6 col-xs-6">
|
|
<button type="button" class="btn btn-lg btn-link bg-primary waves-effect btn_qr_code">QR Code</button>
|
|
</div>
|
|
</div>
|
|
<div class="row clearfix"></div>
|
|
<div class="row text-center m-t-20">
|
|
<div class="col-lg-6 col-md-6 col-sm-6 col-xs-6">
|
|
<button type="button" class="btn btn-lg btn-link bg-green waves-effect btn_customer_yes">Yes</button>
|
|
</div>
|
|
|
|
<div class="col-lg-6 col-md-6 col-sm-6 col-xs-6">
|
|
<button type="button" class="btn btn-lg btn-link bg-red waves-effect" data-dismiss="modal">No</button>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="modal-footer"></div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div id="sxModal">
|
|
<div id="sxModal-Content">
|
|
<h3>Card Tap</h3>
|
|
</div>
|
|
<div>
|
|
<button type="button" class="btn btn-lg btn-link bg-red waves-effect" data-dismiss="modal">Cancel</button>
|
|
</div>
|
|
</div>
|
|
|
|
<script type="text/javascript">
|
|
var cashier_type = "<%= @cashier_type %>";
|
|
var customer_id = "<%= @customer.id %>";
|
|
var customer_name = "<%= @customer.name %>";
|
|
$(document).ready(function(){
|
|
//start customer modal popup
|
|
if((customer_id!=undefined) && (customer_id!=null) && (customer_id!="")){
|
|
if((customer_id == 'CUS-000000000001') && (customer_name == 'WALK-IN')){
|
|
$("#is_memberModal").modal({show : true, backdrop: false, keyboard : false});
|
|
}
|
|
}
|
|
|
|
/* start check first bill or not*/
|
|
var member_id = $('#membership_id').text();
|
|
var member_discount = $('#member_discount').text();
|
|
var receipt_no = "";
|
|
if(($("#receipt_no").html()!=undefined) && ($("#receipt_no").html()!="")){
|
|
receipt_no = ($("#receipt_no").html()).trim();
|
|
}
|
|
|
|
payment_type = '';
|
|
|
|
if ($("#server_mode").val() != "cloud") { // first bill not used in cloud
|
|
console.log("ssssssssssss")
|
|
payment_type = checkReceiptNoInFirstBillData(receipt_no,"payment")
|
|
if (member_id && member_discount) {
|
|
if(parseInt(jQuery.inArray("Credit", payment_type)) == -1){
|
|
$("#credit_payment").hide();
|
|
} else{
|
|
$("#credit_payment").show();
|
|
}
|
|
|
|
if(parseInt(jQuery.inArray("MPU", payment_type)) !=-1 || parseInt(jQuery.inArray("VISA", payment_type)) !=-1 || parseInt(jQuery.inArray("JCB", payment_type)) !=-1 || parseInt(jQuery.inArray("Master", payment_type)) !=-1 || parseInt(jQuery.inArray("UNIONPAY", payment_type)) !=-1 || parseInt(jQuery.inArray("Redeem", payment_type)) !=-1){
|
|
$("#card_payment").show();
|
|
} else{
|
|
$("#card_payment").hide();
|
|
}
|
|
}
|
|
}
|
|
/* end check first bill or not*/
|
|
|
|
var dining_id = "<%= @sale_data.bookings[0].dining_facility_id %>";
|
|
|
|
$("#back").on('click', function() {
|
|
localStorage.removeItem('cash');
|
|
customer_display_view(null,"reload");
|
|
if (cashier_type=="cashier") {
|
|
window.location.href = '/origami/table/'+ dining_id;
|
|
}else{
|
|
window.location.href = '/origami/quick_service';
|
|
}
|
|
});
|
|
|
|
if(localStorage.getItem("cash") == null || localStorage.getItem("cash") == 'null'){
|
|
|
|
}
|
|
else {
|
|
$('#cash').text(localStorage.getItem("cash"));
|
|
}
|
|
update_balance();
|
|
|
|
// Disable click event cash to prevent
|
|
$(".payment .cash-color").off('click');
|
|
|
|
$('#credit_payment').click(function() {
|
|
var sale_id = $('#sale_id').text();
|
|
window.location.href = '/origami/sale/'+ sale_id +"/"+cashier_type+"/payment/credit_payment"
|
|
return false;
|
|
});
|
|
|
|
$('#card_payment').click(function() {
|
|
localStorage.setItem("cash",$('#cash').text() );
|
|
var sale_id = $('#sale_id').text();
|
|
window.location.href = '/origami/sale/'+ sale_id + "/"+cashier_type+"/payment/others_payment"
|
|
return false;
|
|
});
|
|
|
|
$('#pay').click(function() {
|
|
sub_total = $('#sub-total').text();
|
|
if (payment_type == 'MPU' && $('.mpu').text() == 0 && sub_total != 0.0) {
|
|
swal("Oops","Please Pay with MPU Payment","warning");
|
|
}else if(payment_type == "Redeem" && $('#ppamount').text()==0 && sub_total != 0.0){
|
|
swal("Oops","Please Pay with Redeem Payment","warning");
|
|
}else if(payment_type == "VISA" && $('#visacount').text()==0 && sub_total != 0.0){
|
|
swal("Oops","Please Pay with Visa Payment","warning");
|
|
|
|
}else if(payment_type == "JCB" && $('#jcbcount').text()==0 && sub_total != 0.0){
|
|
swal("Oops","Please Pay with jcb Payment","warning");
|
|
}
|
|
else if(payment_type == "Master" && $('#mastercount').text()==0 && sub_total != 0.0){
|
|
swal("Oops","Please Pay with Master Payment","warning");
|
|
}
|
|
else if(payment_type == "UNIONPAY" && $('#unionpaycount').text()==0 && sub_total != 0.0){
|
|
swal("Oops","Please Pay with UNIONPAY Payment","warning");
|
|
}
|
|
else if(payment_type == "Credit" && $('#credit').text()==0 && sub_total != 0.0){
|
|
swal("Oops","Please Pay with Credit Payment","warning");
|
|
}else{
|
|
|
|
$( "#loading_wrapper").show();
|
|
if($('#balance').text() > 0){
|
|
swal ( "Oops", "Insufficient Amount!" , "error" );
|
|
$("#loading_wrapper").hide();
|
|
}else{
|
|
$(this).off("click");
|
|
var sale_id = $('#sale_id').text();
|
|
// var item_row = $('.is_card');
|
|
|
|
// payment
|
|
var cash = $('#cash').text();
|
|
var credit = $('#credit').text();
|
|
var card = $('#card').text();
|
|
|
|
if (credit <= 0) {
|
|
calculate_member_discount(sale_id);
|
|
}
|
|
|
|
$.ajax({type: "POST",
|
|
url: "<%= origami_payment_cash_path %>",
|
|
data: "cash="+ cash + "&sale_id=" + sale_id + "&type=" + cashier_type,
|
|
success:function(result){
|
|
/* start delete receipt no in first bill*/
|
|
if(($("#receipt_no").html()!=undefined) && ($("#receipt_no").html()!="")){
|
|
var receipt_no = ($("#receipt_no").html()).trim();
|
|
deleteReceiptNoInFirstBillData(receipt_no);
|
|
}
|
|
/* end delete receipt no in first bill*/
|
|
|
|
localStorage.removeItem("cash");
|
|
if (result.status) {
|
|
var msg = result.message;
|
|
}
|
|
else{
|
|
var msg = '';
|
|
}
|
|
|
|
$("#loading_wrapper" ).hide();
|
|
|
|
//PDF lightbox data
|
|
$("#sale_receipt_no").val(result.receipt_no);
|
|
$("#filename").val(result.filename);
|
|
$("#printer_name").val(result.printer_name);
|
|
$("#receipt_pdf").attr("src", result.filename);
|
|
$("#pdfModal").modal({show : true, backdrop : false, keyboard : false});
|
|
$("#pdfModalLabel").text("Payment Successful!");
|
|
$("#changed_amount").text("");
|
|
if($('#balance').text() < 0){
|
|
<% if precision.to_i > 0 %>
|
|
$("#changed_amount").text('Changed amount ' + parseFloat($('#balance').text() * (-1)).toFixed(<%= precision %>));
|
|
<% else %>
|
|
$("#changed_amount").text('Changed amount ' + parseFloat($('#balance').text() * (-1)));
|
|
<% end %>
|
|
}
|
|
|
|
//PDF lightbox data
|
|
// if($('#balance').text() < 0){
|
|
// swal({
|
|
// title: "Payment Successful!",
|
|
// text: 'Changed amount ' + $('#balance').text() * (-1),
|
|
// html: true,
|
|
// closeOnConfirm: false,
|
|
// closeOnCancel: false,
|
|
// allowOutsideClick: false
|
|
// }, function () {
|
|
// if (cashier_type=="cashier") {
|
|
// window.location.href = '/origami';
|
|
// }else{
|
|
// window.location.href = '/origami/quick_service';
|
|
// }
|
|
// });
|
|
// }else{
|
|
// $('#pay').text("Pay");
|
|
// swal({
|
|
// title: "Payment Successful!",
|
|
// text: 'Thank You !',
|
|
// html: true,
|
|
// closeOnConfirm: false,
|
|
// closeOnCancel: false,
|
|
// allowOutsideClick: false
|
|
// }, function () {
|
|
// if (cashier_type=="cashier") {
|
|
// window.location.href = '/origami';
|
|
// }else{
|
|
// window.location.href = '/origami/quick_service';
|
|
// }
|
|
// });
|
|
// }
|
|
}
|
|
});
|
|
}
|
|
}
|
|
});
|
|
|
|
// $('#void').on('click',function () {
|
|
// if ($(this).attr('active') === "true") {
|
|
// var sale_id = $('#sale_id').text();
|
|
// var remark = $("#remark").val();
|
|
// var ajax_url = "/origami/sale/" + sale_id + '/void';
|
|
// $.ajax({
|
|
// type: 'POST',
|
|
// url: ajax_url,
|
|
// data: "remark="+ remark + "&sale_id=" + sale_id,
|
|
// success: function () {
|
|
// window.location.href = '/origami/';
|
|
// }
|
|
// })
|
|
// }else{
|
|
// swal("Opps","You are not authorized for void","warning")
|
|
// }
|
|
// });
|
|
$('#void').on('click', function () {
|
|
if ($(this).attr('active')=== "true") {
|
|
swal({
|
|
title: "Alert",
|
|
text: "Are you sure want to Void?",
|
|
type: "warning",
|
|
showCancelButton: true,
|
|
confirmButtonColor: "#DD6B55",
|
|
confirmButtonText: "Yes, void it!",
|
|
closeOnConfirm: false
|
|
}, function (isConfirm) {
|
|
if (isConfirm) {
|
|
var sale_id = $('#sale_id').text();
|
|
var remark = $("#remark").val();
|
|
var ajax_url = "/origami/sale/" + sale_id + '/void';
|
|
$.ajax({
|
|
type: 'POST',
|
|
url: ajax_url,
|
|
data: "remark="+ remark + "&sale_id=" + sale_id,
|
|
success: function () {
|
|
customer_display_view(null,"reload");
|
|
if (cashier_type=="cashier") {
|
|
window.location.href = '/origami';
|
|
}else{
|
|
window.location.href = '/origami/quick_service';
|
|
}
|
|
}
|
|
})
|
|
}
|
|
});
|
|
}else{
|
|
swal("Oops","You are not authorized for void","warning")
|
|
}
|
|
});
|
|
});
|
|
|
|
// bind survey to order or sale
|
|
$("#survey").on('click', function () {
|
|
var sale = $('#sale_id').text();
|
|
if (sale) {
|
|
var sale_id = sale
|
|
} else {
|
|
var sale_id = $('#dining').text();
|
|
}
|
|
//var table_id = $('.tables').attr("data-id");
|
|
window.location.href = '/origami/' + sale_id +"/"+ cashier_type + "/surveys";
|
|
});
|
|
|
|
// bind customer to order or sale
|
|
$("#customer").on('click', function () {
|
|
var sale = $('#sale_id').text();
|
|
if (sale) {
|
|
var sale_id = sale
|
|
} else {
|
|
var sale_id = $('#save_order_id').attr('data-order');
|
|
}
|
|
var table_id = $('.tables').attr("data-id");
|
|
window.location.href = '/origami/' + sale_id + "/"+cashier_type+"/customers/payment";
|
|
});
|
|
|
|
// Add Other Charges
|
|
$('#other-charges').click(function () {
|
|
var sale = $('#sale_id').text();
|
|
if (sale != "") {
|
|
var sale_id = sale
|
|
} else {
|
|
var sale_id = $('#save_order_id').attr('data-order');
|
|
}
|
|
if (sale_id != "") {
|
|
window.location.href = '/origami/' + sale_id +"/"+cashier_type+ '/other_charges'
|
|
}
|
|
else {
|
|
swal ( "Oops" , "Please select an table!" , "warning" );
|
|
}
|
|
return false;
|
|
});
|
|
// Discount for Payment
|
|
$('#discount').click(function () {
|
|
if ($(this).attr('active')=== "true") {
|
|
var sale = $('#sale_id').text();
|
|
if (sale != "") {
|
|
var sale_id = sale
|
|
} else {
|
|
var sale_id = $('#save_order_id').attr('data-order');
|
|
}
|
|
|
|
if (sale_id != "") {
|
|
window.location.href = '/origami/' + sale_id + "/"+cashier_type+'/discount'
|
|
}
|
|
else {
|
|
swal ( "Oops" , "Please select an table!" , "warning" );
|
|
}
|
|
}else{
|
|
swal("Oops","You are not authorized for Discount","warning")
|
|
}
|
|
return false;
|
|
});
|
|
|
|
$('#edit').on('click', function () {
|
|
var dining_id = $('#dining').text();
|
|
var sale_id = $('#sale_id').text();
|
|
if ($(this).attr('active')=== "true") {
|
|
if (dining_id) {
|
|
window.location.href = '/origami/table/' + dining_id + "/sale/" + sale_id + "/"+cashier_type+"/edit";
|
|
}else{
|
|
window.location.href = "/origami/table/sale/" + sale_id + "/"+cashier_type+"/edit";
|
|
}
|
|
|
|
}else{
|
|
swal("Oops","You are not authorized for void","warning")
|
|
}
|
|
});
|
|
|
|
$(document).on('click', '.cashier_number', function(event){
|
|
if(event.handled !== true) {
|
|
var original_value;
|
|
original_value = $('#cash').text();
|
|
|
|
var input_type = $(this).attr("data-type");
|
|
|
|
switch (input_type) {
|
|
case 'num':
|
|
var input_value = $(this).attr("data-value");
|
|
if (original_value == "0.0"){
|
|
$('#cash').text(input_value);
|
|
update_balance();
|
|
}else{
|
|
if($('#cash').text() == '0'){
|
|
$('#cash').text("");
|
|
}
|
|
$('#cash').append(input_value);
|
|
update_balance();
|
|
}
|
|
break;
|
|
case 'add':
|
|
var input_value = $(this).attr("data-value");
|
|
amount = parseInt(input_value) + parseInt(original_value);
|
|
$('#cash').text(amount);
|
|
update_balance();
|
|
break;
|
|
case 'del' :
|
|
var cash=$('#cash').text();
|
|
if(cash.length == 1)
|
|
$('#cash').text("0.0");
|
|
else
|
|
$('#cash').text(cash.substr(0,cash.length-1));
|
|
update_balance();
|
|
break;
|
|
case 'clr':
|
|
$('#cash').text("0.0");
|
|
update_balance();
|
|
break;
|
|
case 'nett':
|
|
var credit1 = $('#credit').text();
|
|
var card1 = $('#others').text();
|
|
var paypar1 = $('#ppamount').text();
|
|
var visa1 = $('#visacount').text();
|
|
var jcb1 = $('#jcbcount').text();
|
|
var master1 = $('#mastercount').text();
|
|
var unionpay1 = $('#unionpaycount').text();
|
|
var othertotal = parseFloat(credit1) + parseFloat(card1) + parseFloat(paypar1) + parseFloat(visa1) + parseFloat(jcb1) + parseFloat(master1) + parseFloat(unionpay1);
|
|
var total = $('#amount_due').text();
|
|
var amt = 0;
|
|
<% if precision.to_i > 0 %>;
|
|
amt = parseFloat(parseFloat(total) - parseFloat(othertotal)).toFixed(<%= precision %>);
|
|
<% else %>
|
|
amt = parseFloat(parseFloat(total) - parseFloat(othertotal));
|
|
<% end %>
|
|
$('#cash').text(amt);
|
|
update_balance();
|
|
break;
|
|
}
|
|
event.handled = true;
|
|
} else {
|
|
return false;
|
|
}
|
|
});
|
|
|
|
|
|
function update_balance(){
|
|
var cash = $('#cash').text();
|
|
var credit = $('#credit').text();
|
|
var card = $('#others').text();
|
|
var paypar = $('#ppamount').text();
|
|
var visa = $('#visacount').text();
|
|
var jcb = $('#jcbcount').text();
|
|
var master = $('#mastercount').text();
|
|
var unionpay = $('#unionpaycount').text();
|
|
var amount_due = $('#amount_due').text();
|
|
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);
|
|
<% if precision.to_i > 0 %>
|
|
$('#balance').text(parseFloat(result).toFixed(<%= precision %>));
|
|
<% else %>
|
|
$('#balance').text(parseFloat(result));
|
|
<% end %>
|
|
}
|
|
|
|
$('#foc').click(function() {
|
|
//$( "#loading_wrapper" ).show();
|
|
// payment
|
|
var remark = $("#foc_remark").val();
|
|
var cash = $('#grand_total').text();
|
|
var sub_total = $('#sub-total').text();
|
|
var sale_id = $('#sale_id').text();
|
|
var params = { 'cash':cash,'sale_id':sale_id,'sub_total':sub_total,'remark':remark,'type':cashier_type };
|
|
|
|
if ($(this).attr('active')=== "true") {
|
|
swal({
|
|
title: "Alert",
|
|
text: "Are you sure want to FOC This Receipt?",
|
|
type: "warning",
|
|
showCancelButton: true,
|
|
confirmButtonColor: "#DD6B55",
|
|
confirmButtonText: "Yes, FOC it!",
|
|
closeOnConfirm: false
|
|
}, function (isConfirm) {
|
|
if (isConfirm) {
|
|
$.ajax({
|
|
type: "POST",
|
|
url: "<%= origami_payment_foc_path %>",
|
|
data: params,
|
|
success:function(result){
|
|
customer_display_view(null,"reload");
|
|
if (cash >= 0) {
|
|
swal({
|
|
title: "Information!",
|
|
text: 'Thank You !',
|
|
}, function () {
|
|
if (cashier_type=="cashier") {
|
|
window.location.href = '/origami';
|
|
}else{
|
|
window.location.href = '/origami/quick_service';
|
|
}
|
|
});
|
|
}
|
|
}
|
|
});
|
|
}
|
|
});
|
|
|
|
}else{
|
|
swal("Oops","You are not authorized for foc","warning")
|
|
}
|
|
});
|
|
|
|
function customer_display_view(data,status) {
|
|
$.ajax({
|
|
type: "POST",
|
|
url: '../../../customer_view',
|
|
data: {"data":data,"status":status},
|
|
dataType: "json",
|
|
success:function(result){
|
|
}
|
|
});
|
|
}
|
|
|
|
function calculate_member_discount(sale_id) {
|
|
var sub_total = $('#sub-total').text();
|
|
var member_id = $('#membership_id').text();
|
|
var member_discount = $('#member_discount').text();
|
|
var item_row = $('.is_card');
|
|
|
|
if (member_id && member_discount) {
|
|
if (item_row.length < 1) {
|
|
is_card = false
|
|
}else{
|
|
is_card = true
|
|
}
|
|
$.ajax({
|
|
type: "POST",
|
|
url: "/origami/" + sale_id + "/member_discount",
|
|
data: {'sale_id':sale_id, 'sub_total':sub_total,'is_card':is_card },
|
|
async: false,
|
|
success:function(result){
|
|
}
|
|
});
|
|
}
|
|
}
|
|
|
|
//print pdf function
|
|
$(".print_receipt").on('click',function(){
|
|
var sale_id = $('#sale_id').text();
|
|
var filename = $("#filename").val();
|
|
var printer_name = $("#printer_name").val();
|
|
var receipt_no = $("#sale_receipt_no").val();
|
|
var params = { 'filename':filename, 'receipt_no':receipt_no, 'printer_name':printer_name };
|
|
|
|
// swal({
|
|
// title: "Alert",
|
|
// text: "Are you sure want to print?",
|
|
// type: "warning",
|
|
// showCancelButton: true,
|
|
// confirmButtonColor: "#DD6B55",
|
|
// confirmButtonText: "Print",
|
|
// closeOnConfirm: false
|
|
// }, function (isConfirm) {
|
|
// if (isConfirm) {
|
|
$.ajax({
|
|
type: "POST",
|
|
url: "/origami/sale/"+sale_id+"/"+cashier_type+"/payment/print",
|
|
data: params,
|
|
success:function(result){
|
|
console.log(result);
|
|
if (cashier_type=="cashier") {
|
|
window.location.href = '/origami';
|
|
}else{
|
|
window.location.href = '/origami/quick_service';
|
|
customer_display_view(null,"reload");
|
|
}
|
|
}
|
|
});
|
|
// }
|
|
// });
|
|
|
|
});
|
|
|
|
|
|
$(".btn_pdf_close").on('click',function(){
|
|
if (cashier_type=="cashier") {
|
|
window.location.href = '/origami';
|
|
}else{
|
|
window.location.href = '/origami/quick_service';
|
|
}
|
|
});
|
|
|
|
$(".btn_customer_yes").on('click',function(){
|
|
var sale_id = $('#sale_id').text();
|
|
window.location.href = "/origami/"+sale_id+"/"+cashier_type+"/customers/payment";
|
|
});
|
|
|
|
// Read Card Reader
|
|
$(".btn_member").on('click', function(){
|
|
var cardNo = "";
|
|
var customer_id = '';
|
|
var customer_name = '';
|
|
var membership_id = '';
|
|
var membership_type = '';
|
|
var sale_id = $("#sale_id").text() || 0;
|
|
var customer_mamber_card_no = 0;
|
|
|
|
$("#is_memberModal").hide();
|
|
$("#sxModal").show();
|
|
setTimeout(function(){
|
|
getCardNo();
|
|
$("#sxModal").hide();
|
|
customer_mamber_card_no = $("#paypar_account_no").val();
|
|
|
|
if(sale_id != 0 && customer_mamber_card_no != 0){
|
|
$.ajax({
|
|
type: "POST",
|
|
url: "/origami/"+sale_id+"/get_customer" ,
|
|
data: { filter : customer_mamber_card_no ,type :"card"},
|
|
dataType: "json",
|
|
success: function(data) {
|
|
if (data[0].customer_id == false) {
|
|
swal("Alert!", data[0].message, "error");
|
|
}else{
|
|
customer_id = data[0].customer_id;
|
|
customer_name = data[0].name;
|
|
membership_id = data[0].membership_id;
|
|
membership_type = data[0].membership_type;
|
|
update_sale(membership_id, customer_id, customer_name,sale_id);
|
|
}
|
|
|
|
}
|
|
});
|
|
}
|
|
},100);
|
|
});
|
|
|
|
// Read NFC card no from java
|
|
function getCardNo(){
|
|
code2lab.readNFC();
|
|
}
|
|
|
|
// get CardNo from Java
|
|
function setCardNo(cardNo){
|
|
if(cardNo.length == 16){
|
|
$("#paypar_account_no").val(cardNo);
|
|
}
|
|
}
|
|
|
|
// QR Code Reader
|
|
$(".btn_qr_code").on('click', function(e){
|
|
$("#is_memberModal").hide();
|
|
var code = "";
|
|
setTimeout(function(){
|
|
code=getQRCode();
|
|
$("#qr_code").val(code);
|
|
},100);
|
|
});
|
|
|
|
// Read qrcode from java
|
|
function getQRCode(){
|
|
return code2lab.readQRCode();
|
|
}
|
|
|
|
function update_sale(membership_id, customer_id, customer_name, sale_id) {
|
|
var customer="";
|
|
if(customer_name != ""){
|
|
customer = '(' + customer_name + ')';
|
|
}
|
|
|
|
swal({
|
|
title: "Confirmation !",
|
|
text: 'Are You Sure to assign this customer' + customer + '!',
|
|
showCancelButton: true,
|
|
confirmButtonColor: "green",
|
|
confirmButtonText: "Yes!",
|
|
cancelButtonClass: 'btn btn-danger',
|
|
closeOnConfirm: false,
|
|
}, function () {
|
|
$.ajax({
|
|
type: "POST",
|
|
url: "/origami/"+sale_id+"/"+cashier_type+"/customers/update_sale" ,
|
|
data: {customer_id:customer_id,sale_id:sale_id},
|
|
dataType: "json",
|
|
success: function(data) {
|
|
if(data.status == true)
|
|
{
|
|
//change customer detail
|
|
$("#customer_name").html(customer_name);
|
|
$("#membership_id").html(membership_id);
|
|
window.location.href = '/origami/sale/'+sale_id+'/'+cashier_type+'/payment/';
|
|
}else{
|
|
swal("Alert!", "Record not found!", "error");
|
|
location.reload();
|
|
}
|
|
}
|
|
});
|
|
});
|
|
}
|
|
</script> |